From 6df50956c49439635099ef47e27f2ba2fda5f223 Mon Sep 17 00:00:00 2001 From: Amar Mahmutbegovic Date: Sun, 28 Apr 2024 00:57:39 +0200 Subject: [PATCH] add Chapter04 bare example --- Chapter04/bare/.clang-format | 9 + Chapter04/bare/.vscode/launch.json | 32 + Chapter04/bare/.vscode/tasks.json | 115 + Chapter04/bare/CMakeLists.txt | 149 + Chapter04/bare/app/src/main.cpp | 28 + Chapter04/bare/hal/inc/hal.hpp | 21 + Chapter04/bare/hal/uart/inc/uart.hpp | 28 + Chapter04/bare/hal/uart/inc/uart_stm32.hpp | 25 + Chapter04/bare/hal/uart/src/uart_stm32.cpp | 33 + .../platform/CMSIS/Core/Include/cmsis_armcc.h | 865 + .../CMSIS/Core/Include/cmsis_armclang.h | 1869 ++ .../CMSIS/Core/Include/cmsis_compiler.h | 266 + .../platform/CMSIS/Core/Include/cmsis_gcc.h | 2085 ++ .../CMSIS/Core/Include/cmsis_iccarm.h | 935 + .../CMSIS/Core/Include/cmsis_version.h | 39 + .../CMSIS/Core/Include/core_armv8mbl.h | 1918 ++ .../CMSIS/Core/Include/core_armv8mml.h | 2927 ++ .../platform/CMSIS/Core/Include/core_cm0.h | 949 + .../CMSIS/Core/Include/core_cm0plus.h | 1083 + .../platform/CMSIS/Core/Include/core_cm1.h | 976 + .../platform/CMSIS/Core/Include/core_cm23.h | 1993 ++ .../platform/CMSIS/Core/Include/core_cm3.h | 1941 ++ .../platform/CMSIS/Core/Include/core_cm33.h | 3002 ++ .../platform/CMSIS/Core/Include/core_cm4.h | 2129 ++ .../platform/CMSIS/Core/Include/core_cm7.h | 2671 ++ .../platform/CMSIS/Core/Include/core_sc000.h | 1022 + .../platform/CMSIS/Core/Include/core_sc300.h | 1915 ++ .../platform/CMSIS/Core/Include/mpu_armv7.h | 270 + .../platform/CMSIS/Core/Include/mpu_armv8.h | 333 + .../platform/CMSIS/Core/Include/tz_context.h | 70 + .../CMSIS/Core/Template/ARMv8-M/main_s.c | 58 + .../CMSIS/Core/Template/ARMv8-M/tz_context.c | 200 + .../CMSIS/Core_A/Include/cmsis_armcc.h | 544 + .../CMSIS/Core_A/Include/cmsis_armclang.h | 503 + .../CMSIS/Core_A/Include/cmsis_compiler.h | 201 + .../CMSIS/Core_A/Include/cmsis_cp15.h | 514 + .../platform/CMSIS/Core_A/Include/cmsis_gcc.h | 679 + .../CMSIS/Core_A/Include/cmsis_iccarm.h | 559 + .../platform/CMSIS/Core_A/Include/core_ca.h | 2614 ++ .../platform/CMSIS/Core_A/Include/irq_ctrl.h | 186 + .../CMSIS/Core_A/Source/irq_ctrl_gic.c | 410 + .../Common/JTest/inc/arr_desc/arr_desc.h | 220 + .../Common/JTest/inc/jtest.h | 17 + .../Common/JTest/inc/jtest_cycle.h | 65 + .../Common/JTest/inc/jtest_define.h | 37 + .../Common/JTest/inc/jtest_fw.h | 253 + .../Common/JTest/inc/jtest_group.h | 66 + .../Common/JTest/inc/jtest_group_call.h | 126 + .../Common/JTest/inc/jtest_group_define.h | 87 + .../Common/JTest/inc/jtest_pf.h | 85 + .../Common/JTest/inc/jtest_systick.h | 93 + .../Common/JTest/inc/jtest_test.h | 100 + .../Common/JTest/inc/jtest_test_call.h | 121 + .../Common/JTest/inc/jtest_test_define.h | 133 + .../Common/JTest/inc/jtest_test_ret.h | 17 + .../Common/JTest/inc/jtest_util.h | 27 + .../Common/JTest/inc/opt_arg/opt_arg.h | 15 + .../Common/JTest/inc/opt_arg/pp_narg.h | 25 + .../Common/JTest/inc/opt_arg/splice.h | 8 + .../Common/JTest/inc/util/util.h | 52 + .../Common/JTest/src/jtest_cycle.c | 9 + .../JTest/src/jtest_dump_str_segments.c | 36 + .../Common/JTest/src/jtest_fw.c | 9 + .../Common/JTest/src/jtest_trigger_action.c | 37 + .../DSP_Lib_TestSuite/Common/inc/all_tests.h | 9 + .../basic_math_tests/basic_math_templates.h | 267 + .../basic_math_tests/basic_math_test_data.h | 46 + .../basic_math_tests/basic_math_test_group.h | 9 + .../inc/basic_math_tests/basic_math_tests.h | 17 + .../complex_math_templates.h | 222 + .../complex_math_test_data.h | 50 + .../complex_math_test_group.h | 9 + .../complex_math_tests/complex_math_tests.h | 14 + .../controller_tests/controller_templates.h | 46 + .../controller_tests/controller_test_data.h | 33 + .../controller_tests/controller_test_group.h | 9 + .../inc/controller_tests/controller_tests.h | 11 + .../inc/fast_math_tests/fast_math_templates.h | 102 + .../inc/fast_math_tests/fast_math_test_data.h | 29 + .../fast_math_tests/fast_math_test_group.h | 9 + .../inc/filtering_tests/filtering_templates.h | 91 + .../inc/filtering_tests/filtering_test_data.h | 81 + .../filtering_tests/filtering_test_group.h | 9 + .../inc/filtering_tests/filtering_tests.h | 15 + .../intrinsics_tests/intrinsics_templates.h | 166 + .../intrinsics_tests/intrinsics_test_data.h | 27 + .../intrinsics_tests/intrinsics_test_group.h | 9 + .../Common/inc/math_helper.h | 52 + .../inc/matrix_tests/matrix_templates.h | 370 + .../inc/matrix_tests/matrix_test_data.h | 54 + .../inc/matrix_tests/matrix_test_group.h | 9 + .../Common/inc/matrix_tests/matrix_tests.h | 17 + .../statistics_tests/statistics_templates.h | 157 + .../statistics_tests/statistics_test_data.h | 44 + .../statistics_tests/statistics_test_group.h | 9 + .../inc/statistics_tests/statistics_tests.h | 15 + .../inc/support_tests/support_templates.h | 120 + .../inc/support_tests/support_test_data.h | 31 + .../inc/support_tests/support_test_group.h | 9 + .../Common/inc/support_tests/support_tests.h | 11 + .../Common/inc/templates/template.h | 88 + .../Common/inc/templates/test_templates.h | 458 + .../inc/transform_tests/transform_templates.h | 181 + .../inc/transform_tests/transform_test_data.h | 48 + .../transform_tests/transform_test_group.h | 9 + .../inc/transform_tests/transform_tests.h | 13 + .../Common/inc/type_abbrev.h | 37 + .../Common/platform/ARMCC/Retarget.c | 52 + .../Common/platform/ARMCC/startup_armv6-m.s | 195 + .../Common/platform/ARMCC/startup_armv7-m.s | 218 + .../platform/ARMCLANG/startup_armv6-m.S | 203 + .../platform/ARMCLANG/startup_armv7-m.S | 235 + .../Common/platform/GCC/Retarget.c | 106 + .../Common/platform/GCC/startup_armv6-m.S | 263 + .../Common/platform/GCC/startup_armv7-m.S | 257 + .../Common/platform/startup_generic.S | 62 + .../Common/platform/system_ARMCM0.c | 56 + .../Common/platform/system_ARMCM23.c | 82 + .../Common/platform/system_ARMCM3.c | 68 + .../Common/platform/system_ARMCM33.c | 99 + .../Common/platform/system_ARMCM4.c | 83 + .../Common/platform/system_ARMCM7.c | 85 + .../Common/platform/system_ARMSC000.c | 56 + .../Common/platform/system_ARMSC300.c | 72 + .../Common/platform/system_ARMv8MBL.c | 76 + .../Common/platform/system_ARMv8MML.c | 99 + .../Common/platform/system_generic.c | 27 + .../DSP_Lib_TestSuite/Common/src/all_tests.c | 30 + .../Common/src/basic_math_tests/abs_tests.c | 32 + .../Common/src/basic_math_tests/add_tests.c | 33 + .../basic_math_test_common_data.c | 101 + .../basic_math_tests/basic_math_test_group.c | 17 + .../src/basic_math_tests/dot_prod_tests.c | 33 + .../Common/src/basic_math_tests/mult_tests.c | 33 + .../src/basic_math_tests/negate_tests.c | 32 + .../src/basic_math_tests/offset_tests.c | 33 + .../Common/src/basic_math_tests/scale_tests.c | 52 + .../Common/src/basic_math_tests/shift_tests.c | 31 + .../Common/src/basic_math_tests/sub_tests.c | 33 + .../src/complex_math_tests/cmplx_conj_tests.c | 31 + .../complex_math_tests/cmplx_dot_prod_tests.c | 31 + .../cmplx_mag_squared_tests.c | 31 + .../src/complex_math_tests/cmplx_mag_tests.c | 31 + .../cmplx_mult_cmplx_tests.c | 31 + .../complex_math_tests/cmplx_mult_real_test.c | 31 + .../complex_math_test_common_data.c | 114 + .../complex_math_test_group.c | 14 + .../controller_test_common_data.c | 499 + .../controller_tests/controller_test_group.c | 13 + .../src/controller_tests/pid_reset_tests.c | 52 + .../Common/src/controller_tests/pid_tests.c | 79 + .../src/controller_tests/sin_cos_tests.c | 151 + .../src/fast_math_tests/fast_math_tests.c | 38 + .../fast_math_tests_common_data.c | 364 + .../Common/src/filtering_tests/biquad_tests.c | 244 + .../Common/src/filtering_tests/conv_tests.c | 473 + .../src/filtering_tests/correlate_tests.c | 310 + .../filtering_test_common_data.c | 757 + .../filtering_tests/filtering_test_group.c | 17 + .../Common/src/filtering_tests/fir_tests.c | 402 + .../Common/src/filtering_tests/iir_tests.c | 76 + .../Common/src/filtering_tests/lms_tests.c | 219 + .../src/intrinsics_tests/intrinsics_tests.c | 62 + .../intrinsics_tests_common_data.c | 189 + .../DSP/DSP_Lib_TestSuite/Common/src/main.c | 27 + .../Common/src/math_helper.c | 491 + .../Common/src/matrix_tests/mat_add_tests.c | 31 + .../src/matrix_tests/mat_cmplx_mult_tests.c | 59 + .../Common/src/matrix_tests/mat_init_tests.c | 58 + .../src/matrix_tests/mat_inverse_tests.c | 92 + .../src/matrix_tests/mat_mult_fast_tests.c | 57 + .../Common/src/matrix_tests/mat_mult_tests.c | 59 + .../Common/src/matrix_tests/mat_scale_tests.c | 90 + .../Common/src/matrix_tests/mat_sub_tests.c | 34 + .../Common/src/matrix_tests/mat_trans_tests.c | 33 + .../matrix_tests/matrix_test_common_data.c | 255 + .../src/matrix_tests/matrix_test_group.c | 19 + .../Common/src/statistics_tests/max_tests.c | 36 + .../Common/src/statistics_tests/mean_tests.c | 36 + .../Common/src/statistics_tests/min_tests.c | 36 + .../Common/src/statistics_tests/power_tests.c | 36 + .../Common/src/statistics_tests/rms_tests.c | 34 + .../statistics_test_common_data.c | 94 + .../statistics_tests/statistics_test_group.c | 14 + .../Common/src/statistics_tests/std_tests.c | 34 + .../Common/src/statistics_tests/var_tests.c | 34 + .../Common/src/support_tests/copy_tests.c | 33 + .../Common/src/support_tests/fill_tests.c | 36 + .../support_tests/support_test_common_data.c | 85 + .../src/support_tests/support_test_group.c | 10 + .../Common/src/support_tests/x_to_y_tests.c | 80 + .../src/transform_tests/cfft_family_tests.c | 183 + .../Common/src/transform_tests/cfft_tests.c | 144 + .../Common/src/transform_tests/dct4_tests.c | 197 + .../src/transform_tests/rfft_fast_tests.c | 75 + .../Common/src/transform_tests/rfft_tests.c | 94 + .../transform_tests/transform_test_group.c | 11 + .../transform_tests_common_data.c | 3311 +++ .../DspLibTest_FVP/ARMCM23_config.txt | 163 + .../DspLibTest_FVP/ARMCM33_DSP_FP_config.txt | 183 + .../DspLibTest_FVP/ARMCM33_DSP_config.txt | 183 + .../DspLibTest_FVP/ARMCM33_FP_config.txt | 183 + .../DspLibTest_FVP/ARMCM33_config.txt | 183 + .../DspLibTest_MPS2/HowTo.txt | 29 + .../CMSIS/DSP/DSP_Lib_TestSuite/HowTo.txt | 144 + .../DSP/DSP_Lib_TestSuite/RefLibs/inc/ref.h | 1396 + .../RefLibs/src/BasicMathFunctions/abs.c | 53 + .../RefLibs/src/BasicMathFunctions/add.c | 57 + .../RefLibs/src/BasicMathFunctions/dot_prod.c | 65 + .../RefLibs/src/BasicMathFunctions/mult.c | 64 + .../RefLibs/src/BasicMathFunctions/negate.c | 53 + .../RefLibs/src/BasicMathFunctions/offset.c | 57 + .../RefLibs/src/BasicMathFunctions/scale.c | 69 + .../RefLibs/src/BasicMathFunctions/shift.c | 73 + .../RefLibs/src/BasicMathFunctions/sub.c | 57 + .../src/ComplexMathFunctions/cmplx_conj.c | 40 + .../src/ComplexMathFunctions/cmplx_dot_prod.c | 72 + .../src/ComplexMathFunctions/cmplx_mag.c | 49 + .../ComplexMathFunctions/cmplx_mag_squared.c | 46 + .../ComplexMathFunctions/cmplx_mult_cmplx.c | 56 + .../ComplexMathFunctions/cmplx_mult_real.c | 52 + .../RefLibs/src/ControllerFunctions/pid.c | 97 + .../RefLibs/src/ControllerFunctions/sin_cos.c | 21 + .../RefLibs/src/FastMathFunctions/cos.c | 11 + .../RefLibs/src/FastMathFunctions/sin.c | 11 + .../RefLibs/src/FastMathFunctions/sqrt.c | 15 + .../RefLibs/src/FilteringFunctions/biquad.c | 713 + .../RefLibs/src/FilteringFunctions/conv.c | 350 + .../src/FilteringFunctions/correlate.c | 513 + .../RefLibs/src/FilteringFunctions/fir.c | 325 + .../src/FilteringFunctions/fir_decimate.c | 386 + .../src/FilteringFunctions/fir_interpolate.c | 291 + .../src/FilteringFunctions/fir_lattice.c | 241 + .../src/FilteringFunctions/fir_sparse.c | 485 + .../src/FilteringFunctions/iir_lattice.c | 271 + .../RefLibs/src/FilteringFunctions/lms.c | 695 + .../RefLibs/src/HelperFunctions/mat_helper.c | 193 + .../RefLibs/src/HelperFunctions/ref_helper.c | 103 + .../RefLibs/src/Intrinsics/intrinsics.c | 238 + .../RefLibs/src/MatrixFunctions/mat_add.c | 58 + .../src/MatrixFunctions/mat_cmplx_mult.c | 118 + .../RefLibs/src/MatrixFunctions/mat_inverse.c | 57 + .../RefLibs/src/MatrixFunctions/mat_mult.c | 91 + .../RefLibs/src/MatrixFunctions/mat_scale.c | 64 + .../RefLibs/src/MatrixFunctions/mat_sub.c | 58 + .../RefLibs/src/MatrixFunctions/mat_trans.c | 77 + .../RefLibs/src/StatisticsFunctions/max.c | 85 + .../RefLibs/src/StatisticsFunctions/mean.c | 61 + .../RefLibs/src/StatisticsFunctions/min.c | 85 + .../RefLibs/src/StatisticsFunctions/power.c | 61 + .../RefLibs/src/StatisticsFunctions/rms.c | 65 + .../RefLibs/src/StatisticsFunctions/std.c | 74 + .../RefLibs/src/StatisticsFunctions/var.c | 70 + .../RefLibs/src/SupportFunctions/copy.c | 53 + .../RefLibs/src/SupportFunctions/fill.c | 53 + .../src/SupportFunctions/fixed_to_fixed.c | 79 + .../src/SupportFunctions/fixed_to_float.c | 53 + .../src/SupportFunctions/float_to_fixed.c | 52 + .../src/TransformFunctions/bitreversal.c | 30 + .../RefLibs/src/TransformFunctions/cfft.c | 598 + .../RefLibs/src/TransformFunctions/dct4.c | 89 + .../RefLibs/src/TransformFunctions/rfft.c | 302 + .../ARM/arm_class_marks_example/Abstract.txt | 4 + .../arm_class_marks_example_f32.c | 211 + .../ARM/arm_convolution_example/Abstract.txt | 4 + .../arm_convolution_example_f32.c | 247 + .../ARM/arm_convolution_example/math_helper.c | 466 + .../ARM/arm_convolution_example/math_helper.h | 63 + .../ARM/arm_dotproduct_example/Abstract.txt | 4 + .../arm_dotproduct_example_f32.c | 178 + .../ARM/arm_fft_bin_example/Abstract.txt | 4 + .../arm_fft_bin_example/arm_fft_bin_data.c | 308 + .../arm_fft_bin_example_f32.c | 158 + .../Examples/ARM/arm_fir_example/Abstract.txt | 4 + .../ARM/arm_fir_example/arm_fir_data.c | 134 + .../ARM/arm_fir_example/arm_fir_example_f32.c | 233 + .../ARM/arm_fir_example/math_helper.c | 466 + .../ARM/arm_fir_example/math_helper.h | 63 + .../Abstract.txt | 4 + .../arm_graphic_equalizer_data.c | 134 + .../arm_graphic_equalizer_example_q31.c | 411 + .../math_helper.c | 466 + .../math_helper.h | 63 + .../arm_linear_interp_example/Abstract.txt | 4 + .../arm_linear_interp_data.c | 23616 ++++++++++++++++ .../arm_linear_interp_example_f32.c | 204 + .../arm_linear_interp_example/math_helper.c | 466 + .../arm_linear_interp_example/math_helper.h | 63 + .../ARM/arm_matrix_example/Abstract.txt | 4 + .../arm_matrix_example_f32.c | 233 + .../ARM/arm_matrix_example/math_helper.c | 466 + .../ARM/arm_matrix_example/math_helper.h | 63 + .../arm_signal_converge_example/Abstract.txt | 4 + .../arm_signal_converge_data.c | 269 + .../arm_signal_converge_example_f32.c | 259 + .../arm_signal_converge_example/math_helper.c | 466 + .../arm_signal_converge_example/math_helper.h | 63 + .../ARM/arm_sin_cos_example/Abstract.txt | 4 + .../arm_sin_cos_example_f32.c | 161 + .../ARM/arm_variance_example/Abstract.txt | 4 + .../arm_variance_example_f32.c | 204 + .../CMSIS/DSP/Include/arm_common_tables.h | 121 + .../CMSIS/DSP/Include/arm_const_structs.h | 66 + .../platform/CMSIS/DSP/Include/arm_math.h | 7157 +++++ .../Source/BasicMathFunctions/arm_abs_f32.c | 153 + .../Source/BasicMathFunctions/arm_abs_q15.c | 167 + .../Source/BasicMathFunctions/arm_abs_q31.c | 118 + .../Source/BasicMathFunctions/arm_abs_q7.c | 145 + .../Source/BasicMathFunctions/arm_add_f32.c | 138 + .../Source/BasicMathFunctions/arm_add_q15.c | 128 + .../Source/BasicMathFunctions/arm_add_q31.c | 136 + .../Source/BasicMathFunctions/arm_add_q7.c | 122 + .../BasicMathFunctions/arm_dot_prod_f32.c | 123 + .../BasicMathFunctions/arm_dot_prod_q15.c | 128 + .../BasicMathFunctions/arm_dot_prod_q31.c | 131 + .../BasicMathFunctions/arm_dot_prod_q7.c | 147 + .../Source/BasicMathFunctions/arm_mult_f32.c | 162 + .../Source/BasicMathFunctions/arm_mult_q15.c | 142 + .../Source/BasicMathFunctions/arm_mult_q31.c | 148 + .../Source/BasicMathFunctions/arm_mult_q7.c | 115 + .../BasicMathFunctions/arm_negate_f32.c | 134 + .../BasicMathFunctions/arm_negate_q15.c | 131 + .../BasicMathFunctions/arm_negate_q31.c | 117 + .../Source/BasicMathFunctions/arm_negate_q7.c | 113 + .../BasicMathFunctions/arm_offset_f32.c | 154 + .../BasicMathFunctions/arm_offset_q15.c | 124 + .../BasicMathFunctions/arm_offset_q31.c | 128 + .../Source/BasicMathFunctions/arm_offset_q7.c | 123 + .../Source/BasicMathFunctions/arm_scale_f32.c | 157 + .../Source/BasicMathFunctions/arm_scale_q15.c | 150 + .../Source/BasicMathFunctions/arm_scale_q31.c | 227 + .../Source/BasicMathFunctions/arm_scale_q7.c | 137 + .../Source/BasicMathFunctions/arm_shift_q15.c | 236 + .../Source/BasicMathFunctions/arm_shift_q31.c | 191 + .../Source/BasicMathFunctions/arm_shift_q7.c | 208 + .../Source/BasicMathFunctions/arm_sub_f32.c | 138 + .../Source/BasicMathFunctions/arm_sub_q15.c | 128 + .../Source/BasicMathFunctions/arm_sub_q31.c | 134 + .../Source/BasicMathFunctions/arm_sub_q7.c | 119 + .../Source/CommonTables/arm_common_tables.c | 22176 +++++++++++++++ .../Source/CommonTables/arm_const_structs.c | 379 + .../ComplexMathFunctions/arm_cmplx_conj_f32.c | 171 + .../ComplexMathFunctions/arm_cmplx_conj_q15.c | 149 + .../ComplexMathFunctions/arm_cmplx_conj_q31.c | 169 + .../arm_cmplx_dot_prod_f32.c | 191 + .../arm_cmplx_dot_prod_q15.c | 177 + .../arm_cmplx_dot_prod_q31.c | 175 + .../ComplexMathFunctions/arm_cmplx_mag_f32.c | 153 + .../ComplexMathFunctions/arm_cmplx_mag_q15.c | 141 + .../ComplexMathFunctions/arm_cmplx_mag_q31.c | 173 + .../arm_cmplx_mag_squared_f32.c | 204 + .../arm_cmplx_mag_squared_q15.c | 136 + .../arm_cmplx_mag_squared_q31.c | 149 + .../arm_cmplx_mult_cmplx_f32.c | 196 + .../arm_cmplx_mult_cmplx_q15.c | 181 + .../arm_cmplx_mult_cmplx_q31.c | 314 + .../arm_cmplx_mult_real_f32.c | 213 + .../arm_cmplx_mult_real_q15.c | 191 + .../arm_cmplx_mult_real_q31.c | 211 + .../ControllerFunctions/arm_pid_init_f32.c | 74 + .../ControllerFunctions/arm_pid_init_q15.c | 110 + .../ControllerFunctions/arm_pid_init_q31.c | 95 + .../ControllerFunctions/arm_pid_reset_f32.c | 53 + .../ControllerFunctions/arm_pid_reset_q15.c | 52 + .../ControllerFunctions/arm_pid_reset_q31.c | 53 + .../ControllerFunctions/arm_sin_cos_f32.c | 144 + .../ControllerFunctions/arm_sin_cos_q31.c | 110 + .../Source/FastMathFunctions/arm_cos_f32.c | 115 + .../Source/FastMathFunctions/arm_cos_q15.c | 84 + .../Source/FastMathFunctions/arm_cos_q31.c | 84 + .../Source/FastMathFunctions/arm_sin_f32.c | 123 + .../Source/FastMathFunctions/arm_sin_q15.c | 76 + .../Source/FastMathFunctions/arm_sin_q31.c | 75 + .../Source/FastMathFunctions/arm_sqrt_q15.c | 144 + .../Source/FastMathFunctions/arm_sqrt_q31.c | 142 + .../arm_biquad_cascade_df1_32x64_init_q31.c | 98 + .../arm_biquad_cascade_df1_32x64_q31.c | 549 + .../arm_biquad_cascade_df1_f32.c | 412 + .../arm_biquad_cascade_df1_fast_q15.c | 273 + .../arm_biquad_cascade_df1_fast_q31.c | 292 + .../arm_biquad_cascade_df1_init_f32.c | 97 + .../arm_biquad_cascade_df1_init_q15.c | 99 + .../arm_biquad_cascade_df1_init_q31.c | 98 + .../arm_biquad_cascade_df1_q15.c | 398 + .../arm_biquad_cascade_df1_q31.c | 392 + .../arm_biquad_cascade_df2T_f32.c | 590 + .../arm_biquad_cascade_df2T_f64.c | 590 + .../arm_biquad_cascade_df2T_init_f32.c | 89 + .../arm_biquad_cascade_df2T_init_f64.c | 89 + .../arm_biquad_cascade_stereo_df2T_f32.c | 670 + .../arm_biquad_cascade_stereo_df2T_init_f32.c | 89 + .../Source/FilteringFunctions/arm_conv_f32.c | 635 + .../arm_conv_fast_opt_q15.c | 531 + .../FilteringFunctions/arm_conv_fast_q15.c | 1398 + .../FilteringFunctions/arm_conv_fast_q31.c | 565 + .../FilteringFunctions/arm_conv_opt_q15.c | 533 + .../FilteringFunctions/arm_conv_opt_q7.c | 423 + .../FilteringFunctions/arm_conv_partial_f32.c | 678 + .../arm_conv_partial_fast_opt_q15.c | 756 + .../arm_conv_partial_fast_q15.c | 1494 + .../arm_conv_partial_fast_q31.c | 620 + .../arm_conv_partial_opt_q15.c | 753 + .../arm_conv_partial_opt_q7.c | 791 + .../FilteringFunctions/arm_conv_partial_q15.c | 795 + .../FilteringFunctions/arm_conv_partial_q31.c | 616 + .../FilteringFunctions/arm_conv_partial_q7.c | 750 + .../Source/FilteringFunctions/arm_conv_q15.c | 722 + .../Source/FilteringFunctions/arm_conv_q31.c | 553 + .../Source/FilteringFunctions/arm_conv_q7.c | 678 + .../FilteringFunctions/arm_correlate_f32.c | 727 + .../arm_correlate_fast_opt_q15.c | 500 + .../arm_correlate_fast_q15.c | 1307 + .../arm_correlate_fast_q31.c | 600 + .../arm_correlate_opt_q15.c | 501 + .../FilteringFunctions/arm_correlate_opt_q7.c | 452 + .../FilteringFunctions/arm_correlate_q15.c | 707 + .../FilteringFunctions/arm_correlate_q31.c | 653 + .../FilteringFunctions/arm_correlate_q7.c | 778 + .../FilteringFunctions/arm_fir_decimate_f32.c | 512 + .../arm_fir_decimate_fast_q15.c | 586 + .../arm_fir_decimate_fast_q31.c | 339 + .../arm_fir_decimate_init_f32.c | 105 + .../arm_fir_decimate_init_q15.c | 107 + .../arm_fir_decimate_init_q31.c | 105 + .../FilteringFunctions/arm_fir_decimate_q15.c | 684 + .../FilteringFunctions/arm_fir_decimate_q31.c | 299 + .../Source/FilteringFunctions/arm_fir_f32.c | 985 + .../FilteringFunctions/arm_fir_fast_q15.c | 333 + .../FilteringFunctions/arm_fir_fast_q31.c | 293 + .../FilteringFunctions/arm_fir_init_f32.c | 84 + .../FilteringFunctions/arm_fir_init_q15.c | 142 + .../FilteringFunctions/arm_fir_init_q31.c | 84 + .../FilteringFunctions/arm_fir_init_q7.c | 82 + .../arm_fir_interpolate_f32.c | 569 + .../arm_fir_interpolate_init_f32.c | 109 + .../arm_fir_interpolate_init_q15.c | 108 + .../arm_fir_interpolate_init_q31.c | 109 + .../arm_fir_interpolate_q15.c | 496 + .../arm_fir_interpolate_q31.c | 492 + .../FilteringFunctions/arm_fir_lattice_f32.c | 494 + .../arm_fir_lattice_init_f32.c | 71 + .../arm_fir_lattice_init_q15.c | 71 + .../arm_fir_lattice_init_q31.c | 71 + .../FilteringFunctions/arm_fir_lattice_q15.c | 524 + .../FilteringFunctions/arm_fir_lattice_q31.c | 341 + .../Source/FilteringFunctions/arm_fir_q15.c | 679 + .../Source/FilteringFunctions/arm_fir_q31.c | 353 + .../Source/FilteringFunctions/arm_fir_q7.c | 385 + .../FilteringFunctions/arm_fir_sparse_f32.c | 433 + .../arm_fir_sparse_init_f32.c | 95 + .../arm_fir_sparse_init_q15.c | 95 + .../arm_fir_sparse_init_q31.c | 94 + .../arm_fir_sparse_init_q7.c | 95 + .../FilteringFunctions/arm_fir_sparse_q15.c | 470 + .../FilteringFunctions/arm_fir_sparse_q31.c | 450 + .../FilteringFunctions/arm_fir_sparse_q7.c | 469 + .../FilteringFunctions/arm_iir_lattice_f32.c | 435 + .../arm_iir_lattice_init_f32.c | 79 + .../arm_iir_lattice_init_q15.c | 79 + .../arm_iir_lattice_init_q31.c | 79 + .../FilteringFunctions/arm_iir_lattice_q15.c | 452 + .../FilteringFunctions/arm_iir_lattice_q31.c | 338 + .../Source/FilteringFunctions/arm_lms_f32.c | 430 + .../FilteringFunctions/arm_lms_init_f32.c | 83 + .../FilteringFunctions/arm_lms_init_q15.c | 93 + .../FilteringFunctions/arm_lms_init_q31.c | 93 + .../FilteringFunctions/arm_lms_norm_f32.c | 454 + .../arm_lms_norm_init_f32.c | 93 + .../arm_lms_norm_init_q15.c | 100 + .../arm_lms_norm_init_q31.c | 99 + .../FilteringFunctions/arm_lms_norm_q15.c | 428 + .../FilteringFunctions/arm_lms_norm_q31.c | 419 + .../Source/FilteringFunctions/arm_lms_q15.c | 368 + .../Source/FilteringFunctions/arm_lms_q31.c | 357 + .../Source/MatrixFunctions/arm_mat_add_f32.c | 196 + .../Source/MatrixFunctions/arm_mat_add_q15.c | 151 + .../Source/MatrixFunctions/arm_mat_add_q31.c | 195 + .../MatrixFunctions/arm_mat_cmplx_mult_f32.c | 272 + .../MatrixFunctions/arm_mat_cmplx_mult_q15.c | 413 + .../MatrixFunctions/arm_mat_cmplx_mult_q31.c | 282 + .../Source/MatrixFunctions/arm_mat_init_f32.c | 76 + .../Source/MatrixFunctions/arm_mat_init_q15.c | 67 + .../Source/MatrixFunctions/arm_mat_init_q31.c | 72 + .../MatrixFunctions/arm_mat_inverse_f32.c | 691 + .../MatrixFunctions/arm_mat_inverse_f64.c | 691 + .../Source/MatrixFunctions/arm_mat_mult_f32.c | 274 + .../MatrixFunctions/arm_mat_mult_fast_q15.c | 525 + .../MatrixFunctions/arm_mat_mult_fast_q31.c | 384 + .../Source/MatrixFunctions/arm_mat_mult_q15.c | 457 + .../Source/MatrixFunctions/arm_mat_mult_q31.c | 282 + .../MatrixFunctions/arm_mat_scale_f32.c | 169 + .../MatrixFunctions/arm_mat_scale_q15.c | 171 + .../MatrixFunctions/arm_mat_scale_q31.c | 191 + .../Source/MatrixFunctions/arm_mat_sub_f32.c | 197 + .../Source/MatrixFunctions/arm_mat_sub_q15.c | 148 + .../Source/MatrixFunctions/arm_mat_sub_q31.c | 196 + .../MatrixFunctions/arm_mat_trans_f32.c | 206 + .../MatrixFunctions/arm_mat_trans_q15.c | 272 + .../MatrixFunctions/arm_mat_trans_q31.c | 198 + .../Source/StatisticsFunctions/arm_max_f32.c | 170 + .../Source/StatisticsFunctions/arm_max_q15.c | 162 + .../Source/StatisticsFunctions/arm_max_q31.c | 162 + .../Source/StatisticsFunctions/arm_max_q7.c | 162 + .../Source/StatisticsFunctions/arm_mean_f32.c | 125 + .../Source/StatisticsFunctions/arm_mean_q15.c | 120 + .../Source/StatisticsFunctions/arm_mean_q31.c | 123 + .../Source/StatisticsFunctions/arm_mean_q7.c | 120 + .../Source/StatisticsFunctions/arm_min_f32.c | 170 + .../Source/StatisticsFunctions/arm_min_q15.c | 163 + .../Source/StatisticsFunctions/arm_min_q31.c | 163 + .../Source/StatisticsFunctions/arm_min_q7.c | 163 + .../StatisticsFunctions/arm_power_f32.c | 129 + .../StatisticsFunctions/arm_power_q15.c | 138 + .../StatisticsFunctions/arm_power_q31.c | 129 + .../Source/StatisticsFunctions/arm_power_q7.c | 127 + .../Source/StatisticsFunctions/arm_rms_f32.c | 127 + .../Source/StatisticsFunctions/arm_rms_q15.c | 139 + .../Source/StatisticsFunctions/arm_rms_q31.c | 137 + .../Source/StatisticsFunctions/arm_std_f32.c | 186 + .../Source/StatisticsFunctions/arm_std_q15.c | 174 + .../Source/StatisticsFunctions/arm_std_q31.c | 169 + .../Source/StatisticsFunctions/arm_var_f32.c | 181 + .../Source/StatisticsFunctions/arm_var_q15.c | 172 + .../Source/StatisticsFunctions/arm_var_q31.c | 169 + .../Source/SupportFunctions/arm_copy_f32.c | 123 + .../Source/SupportFunctions/arm_copy_q15.c | 102 + .../Source/SupportFunctions/arm_copy_q31.c | 111 + .../DSP/Source/SupportFunctions/arm_copy_q7.c | 103 + .../Source/SupportFunctions/arm_fill_f32.c | 122 + .../Source/SupportFunctions/arm_fill_q15.c | 108 + .../Source/SupportFunctions/arm_fill_q31.c | 109 + .../DSP/Source/SupportFunctions/arm_fill_q7.c | 106 + .../SupportFunctions/arm_float_to_q15.c | 192 + .../SupportFunctions/arm_float_to_q31.c | 199 + .../Source/SupportFunctions/arm_float_to_q7.c | 191 + .../SupportFunctions/arm_q15_to_float.c | 122 + .../Source/SupportFunctions/arm_q15_to_q31.c | 144 + .../Source/SupportFunctions/arm_q15_to_q7.c | 142 + .../SupportFunctions/arm_q31_to_float.c | 119 + .../Source/SupportFunctions/arm_q31_to_q15.c | 133 + .../Source/SupportFunctions/arm_q31_to_q7.c | 124 + .../Source/SupportFunctions/arm_q7_to_float.c | 119 + .../Source/SupportFunctions/arm_q7_to_q15.c | 145 + .../Source/SupportFunctions/arm_q7_to_q31.c | 130 + .../TransformFunctions/arm_bitreversal.c | 230 + .../TransformFunctions/arm_bitreversal2.S | 216 + .../Source/TransformFunctions/arm_cfft_f32.c | 620 + .../Source/TransformFunctions/arm_cfft_q15.c | 345 + .../Source/TransformFunctions/arm_cfft_q31.c | 252 + .../TransformFunctions/arm_cfft_radix2_f32.c | 472 + .../arm_cfft_radix2_init_f32.c | 192 + .../arm_cfft_radix2_init_q15.c | 177 + .../arm_cfft_radix2_init_q31.c | 174 + .../TransformFunctions/arm_cfft_radix2_q15.c | 729 + .../TransformFunctions/arm_cfft_radix2_q31.c | 338 + .../TransformFunctions/arm_cfft_radix4_f32.c | 1209 + .../arm_cfft_radix4_init_f32.c | 152 + .../arm_cfft_radix4_init_q15.c | 140 + .../arm_cfft_radix4_init_q31.c | 136 + .../TransformFunctions/arm_cfft_radix4_q15.c | 1910 ++ .../TransformFunctions/arm_cfft_radix4_q31.c | 1389 + .../TransformFunctions/arm_cfft_radix8_f32.c | 285 + .../Source/TransformFunctions/arm_dct4_f32.c | 449 + .../TransformFunctions/arm_dct4_init_f32.c | 16513 +++++++++++ .../TransformFunctions/arm_dct4_init_q15.c | 4280 +++ .../TransformFunctions/arm_dct4_init_q31.c | 7686 +++++ .../Source/TransformFunctions/arm_dct4_q15.c | 382 + .../Source/TransformFunctions/arm_dct4_q31.c | 383 + .../Source/TransformFunctions/arm_rfft_f32.c | 318 + .../TransformFunctions/arm_rfft_fast_f32.c | 317 + .../arm_rfft_fast_init_f32.c | 131 + .../TransformFunctions/arm_rfft_init_f32.c | 4273 +++ .../TransformFunctions/arm_rfft_init_q15.c | 2229 ++ .../TransformFunctions/arm_rfft_init_q31.c | 4280 +++ .../Source/TransformFunctions/arm_rfft_q15.c | 426 + .../Source/TransformFunctions/arm_rfft_q31.c | 283 + .../Device/ST/STM32F0xx/Include/stm32f030x6.h | 5368 ++++ .../Device/ST/STM32F0xx/Include/stm32f030x8.h | 5435 ++++ .../Device/ST/STM32F0xx/Include/stm32f030xc.h | 5814 ++++ .../Device/ST/STM32F0xx/Include/stm32f031x6.h | 5694 ++++ .../Device/ST/STM32F0xx/Include/stm32f038xx.h | 5659 ++++ .../Device/ST/STM32F0xx/Include/stm32f042x6.h | 10677 +++++++ .../Device/ST/STM32F0xx/Include/stm32f048xx.h | 10641 +++++++ .../Device/ST/STM32F0xx/Include/stm32f051x8.h | 6776 +++++ .../Device/ST/STM32F0xx/Include/stm32f058xx.h | 6741 +++++ .../Device/ST/STM32F0xx/Include/stm32f070x6.h | 5620 ++++ .../Device/ST/STM32F0xx/Include/stm32f070xb.h | 5806 ++++ .../Device/ST/STM32F0xx/Include/stm32f071xb.h | 7374 +++++ .../Device/ST/STM32F0xx/Include/stm32f072xb.h | 11307 ++++++++ .../Device/ST/STM32F0xx/Include/stm32f078xx.h | 11277 ++++++++ .../Device/ST/STM32F0xx/Include/stm32f091xc.h | 11858 ++++++++ .../Device/ST/STM32F0xx/Include/stm32f098xx.h | 11825 ++++++++ .../Device/ST/STM32F0xx/Include/stm32f0xx.h | 275 + .../ST/STM32F0xx/Include/system_stm32f0xx.h | 105 + .../CMSIS/Device/ST/STM32F0xx/License.md | 83 + .../Templates/arm/startup_stm32f030x6.s | 230 + .../Templates/arm/startup_stm32f030x8.s | 240 + .../Templates/arm/startup_stm32f030xc.s | 245 + .../Templates/arm/startup_stm32f031x6.s | 234 + .../Templates/arm/startup_stm32f038xx.s | 232 + .../Templates/arm/startup_stm32f042x6.s | 275 + .../Templates/arm/startup_stm32f048xx.s | 247 + .../Templates/arm/startup_stm32f051x8.s | 250 + .../Templates/arm/startup_stm32f058xx.s | 248 + .../Templates/arm/startup_stm32f070x6.s | 265 + .../Templates/arm/startup_stm32f070xb.s | 249 + .../Templates/arm/startup_stm32f071xb.s | 254 + .../Templates/arm/startup_stm32f072xb.s | 257 + .../Templates/arm/startup_stm32f078xx.s | 257 + .../Templates/arm/startup_stm32f091xc.s | 254 + .../Templates/arm/startup_stm32f098xx.s | 254 + .../Templates/gcc/startup_stm32f030x6.s | 258 + .../Templates/gcc/startup_stm32f030x8.s | 273 + .../Templates/gcc/startup_stm32f030xc.s | 278 + .../Templates/gcc/startup_stm32f031x6.s | 264 + .../Templates/gcc/startup_stm32f038xx.s | 261 + .../Templates/gcc/startup_stm32f042x6.s | 309 + .../Templates/gcc/startup_stm32f048xx.s | 279 + .../Templates/gcc/startup_stm32f051x8.s | 285 + .../Templates/gcc/startup_stm32f058xx.s | 282 + .../Templates/gcc/startup_stm32f070x6.s | 294 + .../Templates/gcc/startup_stm32f070xb.s | 282 + .../Templates/gcc/startup_stm32f071xb.s | 291 + .../Templates/gcc/startup_stm32f072xb.s | 294 + .../Templates/gcc/startup_stm32f078xx.s | 294 + .../Templates/gcc/startup_stm32f091xc.s | 290 + .../Templates/gcc/startup_stm32f098xx.s | 290 + .../iar/linker/stm32f030x6_flash.icf | 33 + .../iar/linker/stm32f030x8_flash.icf | 33 + .../iar/linker/stm32f030xc_flash.icf | 33 + .../iar/linker/stm32f031x6_flash.icf | 33 + .../iar/linker/stm32f038xx_flash.icf | 33 + .../iar/linker/stm32f042x6_flash.icf | 33 + .../iar/linker/stm32f048xx_flash.icf | 33 + .../iar/linker/stm32f051x8_flash.icf | 33 + .../iar/linker/stm32f058xx_flash.icf | 33 + .../iar/linker/stm32f070x6_flash.icf | 33 + .../iar/linker/stm32f070xb_flash.icf | 33 + .../iar/linker/stm32f071xb_flash.icf | 33 + .../iar/linker/stm32f072xb_flash.icf | 33 + .../iar/linker/stm32f078xx_flash.icf | 33 + .../iar/linker/stm32f091xc_flash.icf | 33 + .../Templates/iar/linker/stm32f091xc_sram.icf | 31 + .../iar/linker/stm32f098xx_flash.icf | 33 + .../Templates/iar/linker/stm32f098xx_sram.icf | 31 + .../Templates/iar/startup_stm32f030x6.s | 245 + .../Templates/iar/startup_stm32f030x8.s | 274 + .../Templates/iar/startup_stm32f030xc.s | 283 + .../Templates/iar/startup_stm32f031x6.s | 255 + .../Templates/iar/startup_stm32f038xx.s | 250 + .../Templates/iar/startup_stm32f042x6.s | 306 + .../Templates/iar/startup_stm32f048xx.s | 283 + .../Templates/iar/startup_stm32f051x8.s | 293 + .../Templates/iar/startup_stm32f058xx.s | 287 + .../Templates/iar/startup_stm32f070x6.s | 281 + .../Templates/iar/startup_stm32f070xb.s | 288 + .../Templates/iar/startup_stm32f071xb.s | 302 + .../Templates/iar/startup_stm32f072xb.s | 308 + .../Templates/iar/startup_stm32f078xx.s | 308 + .../Templates/iar/startup_stm32f091xc.s | 302 + .../Templates/iar/startup_stm32f098xx.s | 302 + .../Source/Templates/system_stm32f0xx.c | 247 + .../bare/platform/CMSIS/Include/cmsis_armcc.h | 865 + .../platform/CMSIS/Include/cmsis_armclang.h | 1869 ++ .../platform/CMSIS/Include/cmsis_compiler.h | 266 + .../bare/platform/CMSIS/Include/cmsis_gcc.h | 2085 ++ .../platform/CMSIS/Include/cmsis_iccarm.h | 935 + .../platform/CMSIS/Include/cmsis_version.h | 39 + .../platform/CMSIS/Include/core_armv8mbl.h | 1918 ++ .../platform/CMSIS/Include/core_armv8mml.h | 2927 ++ .../bare/platform/CMSIS/Include/core_cm0.h | 949 + .../platform/CMSIS/Include/core_cm0plus.h | 1083 + .../bare/platform/CMSIS/Include/core_cm1.h | 976 + .../bare/platform/CMSIS/Include/core_cm23.h | 1993 ++ .../bare/platform/CMSIS/Include/core_cm3.h | 1941 ++ .../bare/platform/CMSIS/Include/core_cm33.h | 3002 ++ .../bare/platform/CMSIS/Include/core_cm4.h | 2129 ++ .../bare/platform/CMSIS/Include/core_cm7.h | 2671 ++ .../bare/platform/CMSIS/Include/core_sc000.h | 1022 + .../bare/platform/CMSIS/Include/core_sc300.h | 1915 ++ .../bare/platform/CMSIS/Include/mpu_armv7.h | 270 + .../bare/platform/CMSIS/Include/mpu_armv8.h | 333 + .../bare/platform/CMSIS/Include/tz_context.h | 70 + Chapter04/bare/platform/CMSIS/LICENSE.txt | 201 + .../CMSIS/Lib/ARM/arm_cortexM0b_math.lib | Bin 0 -> 13085890 bytes .../CMSIS/Lib/ARM/arm_cortexM0l_math.lib | Bin 0 -> 13063030 bytes .../cifar10/RTE/Compiler/EventRecorderConf.h | 44 + .../cifar10/RTE/_ARMCM0/RTE_Components.h | 24 + .../cifar10/RTE/_ARMCM3/RTE_Components.h | 22 + .../cifar10/RTE/_ARMCM4_FP/RTE_Components.h | 22 + .../cifar10/RTE/_ARMCM7_SP/RTE_Components.h | 22 + .../cifar10/arm_nnexamples_cifar10.cpp | 196 + .../cifar10/arm_nnexamples_cifar10_inputs.h | 6 + .../arm_nnexamples_cifar10_parameter.h | 43 + .../cifar10/arm_nnexamples_cifar10_weights.h | 26 + .../ARM/arm_nn_examples/cifar10/readme.txt | 4 + .../gru/RTE/Compiler/EventRecorderConf.h | 44 + .../gru/RTE/_ARMCM0/RTE_Components.h | 24 + .../gru/RTE/_ARMCM3/RTE_Components.h | 22 + .../gru/RTE/_ARMCM4_FP/RTE_Components.h | 22 + .../gru/RTE/_ARMCM7_SP/RTE_Components.h | 22 + .../gru/arm_nnexamples_gru.cpp | 221 + .../gru/arm_nnexamples_gru_test_data.h | 23 + .../ARM/arm_nn_examples/gru/readme.txt | 4 + .../platform/CMSIS/NN/Include/arm_nn_tables.h | 59 + .../CMSIS/NN/Include/arm_nnfunctions.h | 1010 + .../CMSIS/NN/Include/arm_nnsupportfunctions.h | 202 + .../nn_test/RTE/_ARMCM0/RTE_Components.h | 20 + .../nn_test/RTE/_ARMCM3/RTE_Components.h | 26 + .../nn_test/RTE/_ARMCM4_FP/RTE_Components.h | 26 + .../nn_test/RTE/_ARMCM7_SP/RTE_Components.h | 26 + .../arm_convolve_HWC_q15_ref.c | 71 + .../arm_convolve_HWC_q15_ref_nonsquare.c | 83 + .../arm_convolve_HWC_q7_ref.c | 72 + .../arm_convolve_HWC_q7_ref_nonsquare.c | 78 + .../arm_depthwise_separable_conv_HWC_q7_ref.c | 70 + ...wise_separable_conv_HWC_q7_ref_nonsquare.c | 75 + ...m_fully_connected_mat_q7_vec_q15_opt_ref.c | 120 + .../arm_fully_connected_mat_q7_vec_q15_ref.c | 43 + .../arm_fully_connected_q15_opt_ref.c | 119 + .../arm_fully_connected_q15_ref.c | 43 + .../arm_fully_connected_q7_opt_ref.c | 138 + .../arm_fully_connected_q7_ref.c | 43 + .../Ref_Implementations/arm_nn_mult_ref.c | 58 + .../Ref_Implementations/arm_pool_ref.c | 96 + .../Ref_Implementations/arm_relu_ref.c | 42 + .../fully_connected_testing_weights.h | 7 + .../Ref_Implementations/ref_functions.h | 250 + .../nn_test/arm_nnexamples_nn_test.cpp | 801 + .../nn_test/arm_nnexamples_nn_test.h | 78 + .../CMSIS/NN/NN_Lib_Tests/nn_test/readme.txt | 4 + .../arm_nn_activations_q15.c | 101 + .../arm_nn_activations_q7.c | 91 + .../Source/ActivationFunctions/arm_relu_q15.c | 106 + .../Source/ActivationFunctions/arm_relu_q7.c | 110 + .../arm_convolve_1x1_HWC_q7_fast_nonsquare.c | 235 + .../arm_convolve_HWC_q15_basic.c | 207 + .../arm_convolve_HWC_q15_fast.c | 255 + .../arm_convolve_HWC_q15_fast_nonsquare.c | 265 + .../arm_convolve_HWC_q7_RGB.c | 279 + .../arm_convolve_HWC_q7_basic.c | 230 + .../arm_convolve_HWC_q7_basic_nonsquare.c | 228 + .../arm_convolve_HWC_q7_fast.c | 408 + .../arm_convolve_HWC_q7_fast_nonsquare.c | 379 + .../arm_depthwise_separable_conv_HWC_q7.c | 418 + ...epthwise_separable_conv_HWC_q7_nonsquare.c | 411 + .../arm_nn_mat_mult_kernel_q7_q15.c | 187 + .../arm_nn_mat_mult_kernel_q7_q15_reordered.c | 138 + .../arm_fully_connected_mat_q7_vec_q15.c | 199 + .../arm_fully_connected_mat_q7_vec_q15_opt.c | 403 + .../arm_fully_connected_q15.c | 193 + .../arm_fully_connected_q15_opt.c | 332 + .../arm_fully_connected_q7.c | 198 + .../arm_fully_connected_q7_opt.c | 484 + .../NNSupportFunctions/arm_nn_mult_q15.c | 147 + .../NNSupportFunctions/arm_nn_mult_q7.c | 119 + .../Source/NNSupportFunctions/arm_nntables.c | 297 + .../arm_q7_to_q15_no_shift.c | 134 + .../arm_q7_to_q15_reordered_no_shift.c | 145 + .../Source/PoolingFunctions/arm_pool_q7_HWC.c | 448 + .../Source/SoftmaxFunctions/arm_softmax_q15.c | 120 + .../Source/SoftmaxFunctions/arm_softmax_q7.c | 121 + .../platform/CMSIS/RTOS/Template/cmsis_os.h | 698 + .../platform/CMSIS/RTOS2/Include/cmsis_os2.h | 756 + .../platform/CMSIS/RTOS2/Include/os_tick.h | 71 + .../platform/CMSIS/RTOS2/Source/os_systick.c | 132 + .../CMSIS/RTOS2/Source/os_tick_gtim.c | 187 + .../CMSIS/RTOS2/Source/os_tick_ptim.c | 165 + .../platform/CMSIS/RTOS2/Template/cmsis_os.h | 922 + .../platform/CMSIS/RTOS2/Template/cmsis_os1.c | 361 + .../bare/platform/STM32F072C8Tx_FLASH.ld | 189 + .../Inc/Legacy/stm32_hal_legacy.h | 3850 +++ .../Inc/Legacy/stm32f0xx_hal_can_legacy.h | 794 + .../Inc/stm32_assert_template.h | 57 + .../STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal.h | 585 + .../Inc/stm32f0xx_hal_adc.h | 1019 + .../Inc/stm32f0xx_hal_adc_ex.h | 299 + .../Inc/stm32f0xx_hal_can.h | 842 + .../Inc/stm32f0xx_hal_cec.h | 794 + .../Inc/stm32f0xx_hal_comp.h | 700 + .../Inc/stm32f0xx_hal_conf_template.h | 326 + .../Inc/stm32f0xx_hal_cortex.h | 133 + .../Inc/stm32f0xx_hal_crc.h | 359 + .../Inc/stm32f0xx_hal_crc_ex.h | 153 + .../Inc/stm32f0xx_hal_dac.h | 429 + .../Inc/stm32f0xx_hal_dac_ex.h | 292 + .../Inc/stm32f0xx_hal_def.h | 178 + .../Inc/stm32f0xx_hal_dma.h | 563 + .../Inc/stm32f0xx_hal_dma_ex.h | 811 + .../Inc/stm32f0xx_hal_exti.h | 375 + .../Inc/stm32f0xx_hal_flash.h | 353 + .../Inc/stm32f0xx_hal_flash_ex.h | 448 + .../Inc/stm32f0xx_hal_gpio.h | 322 + .../Inc/stm32f0xx_hal_gpio_ex.h | 800 + .../Inc/stm32f0xx_hal_i2c.h | 838 + .../Inc/stm32f0xx_hal_i2c_ex.h | 193 + .../Inc/stm32f0xx_hal_i2s.h | 546 + .../Inc/stm32f0xx_hal_irda.h | 856 + .../Inc/stm32f0xx_hal_irda_ex.h | 399 + .../Inc/stm32f0xx_hal_iwdg.h | 240 + .../Inc/stm32f0xx_hal_pcd.h | 1004 + .../Inc/stm32f0xx_hal_pcd_ex.h | 91 + .../Inc/stm32f0xx_hal_pwr.h | 189 + .../Inc/stm32f0xx_hal_pwr_ex.h | 459 + .../Inc/stm32f0xx_hal_rcc.h | 1686 ++ .../Inc/stm32f0xx_hal_rcc_ex.h | 2085 ++ .../Inc/stm32f0xx_hal_rtc.h | 854 + .../Inc/stm32f0xx_hal_rtc_ex.h | 1048 + .../Inc/stm32f0xx_hal_smartcard.h | 1058 + .../Inc/stm32f0xx_hal_smartcard_ex.h | 568 + .../Inc/stm32f0xx_hal_smbus.h | 789 + .../Inc/stm32f0xx_hal_spi.h | 852 + .../Inc/stm32f0xx_hal_spi_ex.h | 75 + .../Inc/stm32f0xx_hal_tim.h | 2131 ++ .../Inc/stm32f0xx_hal_tim_ex.h | 268 + .../Inc/stm32f0xx_hal_tsc.h | 800 + .../Inc/stm32f0xx_hal_uart.h | 1633 ++ .../Inc/stm32f0xx_hal_uart_ex.h | 592 + .../Inc/stm32f0xx_hal_usart.h | 795 + .../Inc/stm32f0xx_hal_usart_ex.h | 520 + .../Inc/stm32f0xx_hal_wwdg.h | 301 + .../Inc/stm32f0xx_ll_adc.h | 3411 +++ .../Inc/stm32f0xx_ll_bus.h | 845 + .../Inc/stm32f0xx_ll_comp.h | 831 + .../Inc/stm32f0xx_ll_cortex.h | 320 + .../Inc/stm32f0xx_ll_crc.h | 474 + .../Inc/stm32f0xx_ll_crs.h | 783 + .../Inc/stm32f0xx_ll_dac.h | 1422 + .../Inc/stm32f0xx_ll_dma.h | 2236 ++ .../Inc/stm32f0xx_ll_exti.h | 1016 + .../Inc/stm32f0xx_ll_gpio.h | 940 + .../Inc/stm32f0xx_ll_i2c.h | 2277 ++ .../Inc/stm32f0xx_ll_iwdg.h | 341 + .../Inc/stm32f0xx_ll_pwr.h | 552 + .../Inc/stm32f0xx_ll_rcc.h | 2261 ++ .../Inc/stm32f0xx_ll_rtc.h | 3169 +++ .../Inc/stm32f0xx_ll_spi.h | 2286 ++ .../Inc/stm32f0xx_ll_system.h | 1852 ++ .../Inc/stm32f0xx_ll_tim.h | 4015 +++ .../Inc/stm32f0xx_ll_usart.h | 3840 +++ .../Inc/stm32f0xx_ll_usb.h | 238 + .../Inc/stm32f0xx_ll_utils.h | 274 + .../Inc/stm32f0xx_ll_wwdg.h | 319 + .../platform/STM32F0xx_HAL_Driver/License.md | 3 + .../STM32F0xx_HAL_Driver/Src/stm32f0xx_hal.c | 514 + .../Src/stm32f0xx_hal_adc.c | 2497 ++ .../Src/stm32f0xx_hal_adc_ex.c | 192 + .../Src/stm32f0xx_hal_can.c | 2432 ++ .../Src/stm32f0xx_hal_cec.c | 997 + .../Src/stm32f0xx_hal_comp.c | 984 + .../Src/stm32f0xx_hal_cortex.c | 341 + .../Src/stm32f0xx_hal_crc.c | 520 + .../Src/stm32f0xx_hal_crc_ex.c | 227 + .../Src/stm32f0xx_hal_dac.c | 1090 + .../Src/stm32f0xx_hal_dac_ex.c | 1183 + .../Src/stm32f0xx_hal_dma.c | 901 + .../Src/stm32f0xx_hal_exti.c | 549 + .../Src/stm32f0xx_hal_flash.c | 694 + .../Src/stm32f0xx_hal_flash_ex.c | 984 + .../Src/stm32f0xx_hal_gpio.c | 540 + .../Src/stm32f0xx_hal_i2c.c | 6794 +++++ .../Src/stm32f0xx_hal_i2c_ex.c | 365 + .../Src/stm32f0xx_hal_i2s.c | 1800 ++ .../Src/stm32f0xx_hal_irda.c | 2998 ++ .../Src/stm32f0xx_hal_iwdg.c | 285 + .../Src/stm32f0xx_hal_msp_template.c | 101 + .../Src/stm32f0xx_hal_pcd.c | 2184 ++ .../Src/stm32f0xx_hal_pcd_ex.c | 336 + .../Src/stm32f0xx_hal_pwr.c | 454 + .../Src/stm32f0xx_hal_pwr_ex.c | 274 + .../Src/stm32f0xx_hal_rcc.c | 1365 + .../Src/stm32f0xx_hal_rcc_ex.c | 964 + .../Src/stm32f0xx_hal_rtc.c | 1733 ++ .../Src/stm32f0xx_hal_rtc_ex.c | 1600 ++ .../Src/stm32f0xx_hal_smartcard.c | 2933 ++ .../Src/stm32f0xx_hal_smartcard_ex.c | 198 + .../Src/stm32f0xx_hal_smbus.c | 2750 ++ .../Src/stm32f0xx_hal_spi.c | 4404 +++ .../Src/stm32f0xx_hal_spi_ex.c | 115 + .../Src/stm32f0xx_hal_tim.c | 7635 +++++ .../Src/stm32f0xx_hal_tim_ex.c | 2390 ++ ...tm32f0xx_hal_timebase_rtc_alarm_template.c | 318 + ...m32f0xx_hal_timebase_rtc_wakeup_template.c | 295 + .../Src/stm32f0xx_hal_timebase_tim_template.c | 179 + .../Src/stm32f0xx_hal_tsc.c | 1080 + .../Src/stm32f0xx_hal_uart.c | 4128 +++ .../Src/stm32f0xx_hal_uart_ex.c | 816 + .../Src/stm32f0xx_hal_usart.c | 3265 +++ .../Src/stm32f0xx_hal_usart_ex.c | 138 + .../Src/stm32f0xx_hal_wwdg.c | 422 + .../Src/stm32f0xx_ll_adc.c | 562 + .../Src/stm32f0xx_ll_comp.c | 316 + .../Src/stm32f0xx_ll_crc.c | 122 + .../Src/stm32f0xx_ll_crs.c | 87 + .../Src/stm32f0xx_ll_dac.c | 276 + .../Src/stm32f0xx_ll_dma.c | 397 + .../Src/stm32f0xx_ll_exti.c | 223 + .../Src/stm32f0xx_ll_gpio.c | 277 + .../Src/stm32f0xx_ll_i2c.c | 229 + .../Src/stm32f0xx_ll_pwr.c | 86 + .../Src/stm32f0xx_ll_rcc.c | 609 + .../Src/stm32f0xx_ll_rtc.c | 714 + .../Src/stm32f0xx_ll_spi.c | 537 + .../Src/stm32f0xx_ll_tim.c | 1170 + .../Src/stm32f0xx_ll_usart.c | 504 + .../Src/stm32f0xx_ll_usb.c | 810 + .../Src/stm32f0xx_ll_utils.c | 622 + .../bare/platform/inc/stm32f0xx_hal_conf.h | 322 + Chapter04/bare/platform/inc/stm32f0xx_it.h | 74 + .../bare/platform/src/stm32f0xx_hal_msp.c | 89 + Chapter04/bare/platform/src/stm32f0xx_it.c | 133 + .../bare/platform/src/system_stm32f0xx.c | 305 + Chapter04/bare/platform/startup_stm32f072xb.s | 294 + Chapter04/bare/renode_scripts/stm32f072.resc | 17 + .../bare/renode_scripts/stm32f072_debug.resc | 17 + 915 files changed, 571018 insertions(+) create mode 100644 Chapter04/bare/.clang-format create mode 100644 Chapter04/bare/.vscode/launch.json create mode 100644 Chapter04/bare/.vscode/tasks.json create mode 100644 Chapter04/bare/CMakeLists.txt create mode 100644 Chapter04/bare/app/src/main.cpp create mode 100644 Chapter04/bare/hal/inc/hal.hpp create mode 100644 Chapter04/bare/hal/uart/inc/uart.hpp create mode 100644 Chapter04/bare/hal/uart/inc/uart_stm32.hpp create mode 100644 Chapter04/bare/hal/uart/src/uart_stm32.cpp create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armcc.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armclang.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/cmsis_compiler.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/cmsis_gcc.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/cmsis_iccarm.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/cmsis_version.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mbl.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mml.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm0.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm0plus.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm1.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm23.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm3.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm33.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm4.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_cm7.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_sc000.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/core_sc300.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv7.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv8.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Include/tz_context.h create mode 100644 Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/main_s.c create mode 100644 Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/tz_context.c create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armcc.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armclang.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_compiler.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_cp15.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_gcc.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_iccarm.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/core_ca.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Include/irq_ctrl.h create mode 100644 Chapter04/bare/platform/CMSIS/Core_A/Source/irq_ctrl_gic.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/arr_desc/arr_desc.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_cycle.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_define.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_fw.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_call.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_define.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_pf.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_systick.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_call.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_define.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_ret.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_util.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/opt_arg.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/pp_narg.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/splice.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/util/util.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_cycle.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_dump_str_segments.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_fw.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_trigger_action.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/all_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/fast_math_tests/fast_math_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/fast_math_tests/fast_math_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/fast_math_tests/fast_math_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/filtering_tests/filtering_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/filtering_tests/filtering_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/filtering_tests/filtering_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/filtering_tests/filtering_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/intrinsics_tests/intrinsics_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/intrinsics_tests/intrinsics_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/intrinsics_tests/intrinsics_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/math_helper.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/template.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/test_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_templates.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_group.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_tests.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/type_abbrev.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/Retarget.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv6-m.s create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv7-m.s create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv6-m.S create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv7-m.S create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/Retarget.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv6-m.S create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv7-m.S create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/startup_generic.S create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM0.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM23.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM3.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM33.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM4.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC000.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC300.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MBL.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MML.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_generic.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/all_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/abs_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/add_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/dot_prod_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/mult_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/negate_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/offset_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/scale_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/shift_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/sub_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_conj_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_dot_prod_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_squared_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_cmplx_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_real_test.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_reset_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/sin_cos_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/biquad_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/conv_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/correlate_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/fir_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/iir_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/lms_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/intrinsics_tests/intrinsics_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/intrinsics_tests/intrinsics_tests_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/main.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/math_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_add_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_cmplx_mult_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_init_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_inverse_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_fast_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_scale_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_sub_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_trans_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/max_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/mean_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/min_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/power_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/rms_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/std_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/var_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/copy_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/fill_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/x_to_y_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_family_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/dct4_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_fast_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_tests.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_test_group.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_tests_common_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM23_config.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_FP_config.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_config.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_FP_config.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_config.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_MPS2/HowTo.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/HowTo.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/inc/ref.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/abs.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/add.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/dot_prod.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/mult.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/negate.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/offset.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/scale.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/shift.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/sub.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_conj.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_dot_prod.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag_squared.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_cmplx.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_real.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/pid.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/sin_cos.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/cos.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sin.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sqrt.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/biquad.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/conv.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/correlate.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_decimate.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_interpolate.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_lattice.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_sparse.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/iir_lattice.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/lms.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/mat_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/ref_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/Intrinsics/intrinsics.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_add.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_cmplx_mult.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_inverse.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_mult.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_scale.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_sub.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_trans.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/max.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/mean.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/min.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/power.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/rms.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/std.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/var.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/copy.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/fill.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/fixed_to_fixed.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/fixed_to_float.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/float_to_fixed.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/bitreversal.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/cfft.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/dct4.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/rfft.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/arm_class_marks_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/arm_convolution_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/arm_dotproduct_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_example_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/arm_matrix_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_data.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/arm_sin_cos_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/Abstract.txt create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/arm_variance_example_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Include/arm_common_tables.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Include/arm_const_structs.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Include/arm_math.h create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_common_tables.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_const_structs.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f64.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f64.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_opt_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_opt_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_opt_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f64.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_float.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_float.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_float.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal2.S create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix8_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_f32.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q31.c create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f030x6.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f030x8.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f030xc.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f031x6.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f038xx.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f042x6.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f048xx.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f051x8.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f058xx.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f070x6.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f070xb.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f071xb.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f072xb.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f078xx.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f091xc.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f098xx.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f0xx.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/system_stm32f0xx.h create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/License.md create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x8.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030xc.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f031x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f038xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f042x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f048xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f051x8.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f058xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f071xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f072xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f078xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f091xc.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f098xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x8.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030xc.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f031x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f038xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f042x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f048xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f051x8.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f058xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f071xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f072xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f078xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f091xc.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f098xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x6_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x8_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030xc_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f031x6_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f038xx_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f042x6_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f048xx_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f051x8_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f058xx_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070x6_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070xb_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f071xb_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f072xb_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f078xx_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_sram.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_flash.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_sram.icf create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x8.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030xc.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f031x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f038xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f042x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f048xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f051x8.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f058xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070x6.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f071xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f072xb.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f078xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f091xc.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f098xx.s create mode 100644 Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/system_stm32f0xx.c create mode 100644 Chapter04/bare/platform/CMSIS/Include/cmsis_armcc.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/cmsis_armclang.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/cmsis_compiler.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/cmsis_gcc.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/cmsis_iccarm.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/cmsis_version.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_armv8mbl.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_armv8mml.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm0.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm0plus.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm1.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm23.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm3.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm33.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm4.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_cm7.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_sc000.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/core_sc300.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/mpu_armv7.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/mpu_armv8.h create mode 100644 Chapter04/bare/platform/CMSIS/Include/tz_context.h create mode 100644 Chapter04/bare/platform/CMSIS/LICENSE.txt create mode 100644 Chapter04/bare/platform/CMSIS/Lib/ARM/arm_cortexM0b_math.lib create mode 100644 Chapter04/bare/platform/CMSIS/Lib/ARM/arm_cortexM0l_math.lib create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/Compiler/EventRecorderConf.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM0/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM3/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM4_FP/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM7_SP/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10.cpp create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_inputs.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_parameter.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_weights.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/readme.txt create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/Compiler/EventRecorderConf.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM0/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM3/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM4_FP/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM7_SP/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru.cpp create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru_test_data.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/readme.txt create mode 100644 Chapter04/bare/platform/CMSIS/NN/Include/arm_nn_tables.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Include/arm_nnfunctions.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/Include/arm_nnsupportfunctions.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM0/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM3/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM4_FP/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM7_SP/RTE_Components.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_opt_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_opt_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_opt_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_nn_mult_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_pool_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_relu_ref.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/fully_connected_testing_weights.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/ref_functions.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.cpp create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.h create mode 100644 Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/readme.txt create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_1x1_HWC_q7_fast_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_basic.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_RGB.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7_nonsquare.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15_reordered.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15_opt.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15_opt.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7_opt.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nntables.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_no_shift.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_reordered_no_shift.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/PoolingFunctions/arm_pool_q7_HWC.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q15.c create mode 100644 Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q7.c create mode 100644 Chapter04/bare/platform/CMSIS/RTOS/Template/cmsis_os.h create mode 100644 Chapter04/bare/platform/CMSIS/RTOS2/Include/cmsis_os2.h create mode 100644 Chapter04/bare/platform/CMSIS/RTOS2/Include/os_tick.h create mode 100644 Chapter04/bare/platform/CMSIS/RTOS2/Source/os_systick.c create mode 100644 Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_gtim.c create mode 100644 Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_ptim.c create mode 100644 Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os.h create mode 100644 Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os1.c create mode 100644 Chapter04/bare/platform/STM32F072C8Tx_FLASH.ld create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32f0xx_hal_can_legacy.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32_assert_template.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_can.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cec.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_comp.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_conf_template.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cortex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_def.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_exti.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_gpio.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_gpio_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2s.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_iwdg.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smbus.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tsc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart_ex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_wwdg.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_adc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_bus.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_comp.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_cortex.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crs.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dac.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dma.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_exti.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_gpio.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_i2c.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_iwdg.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_pwr.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rcc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rtc.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_spi.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_system.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_tim.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usart.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usb.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_utils.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_wwdg.h create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/License.md create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_can.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cec.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_comp.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cortex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dma.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_exti.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_gpio.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2s.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_irda.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_iwdg.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_msp_template.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smbus.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_alarm_template.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_wakeup_template.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_tim_template.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tsc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart_ex.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_wwdg.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_adc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_comp.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crs.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dac.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dma.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_exti.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_gpio.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_i2c.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_pwr.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rcc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rtc.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_spi.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_tim.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usart.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usb.c create mode 100644 Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_utils.c create mode 100644 Chapter04/bare/platform/inc/stm32f0xx_hal_conf.h create mode 100644 Chapter04/bare/platform/inc/stm32f0xx_it.h create mode 100644 Chapter04/bare/platform/src/stm32f0xx_hal_msp.c create mode 100644 Chapter04/bare/platform/src/stm32f0xx_it.c create mode 100644 Chapter04/bare/platform/src/system_stm32f0xx.c create mode 100644 Chapter04/bare/platform/startup_stm32f072xb.s create mode 100644 Chapter04/bare/renode_scripts/stm32f072.resc create mode 100644 Chapter04/bare/renode_scripts/stm32f072_debug.resc diff --git a/Chapter04/bare/.clang-format b/Chapter04/bare/.clang-format new file mode 100644 index 0000000..3e8d8da --- /dev/null +++ b/Chapter04/bare/.clang-format @@ -0,0 +1,9 @@ +IndentWidth: 4 +KeepEmptyLinesAtTheStartOfBlocks: false +BreakBeforeBraces: Allman +ColumnLimit: 80 +SpaceBeforeParens: Never +AlignTrailingComments: true +AllowAllParametersOfDeclarationOnNextLine: true +AllowShortFunctionsOnASingleLine: false +AllowShortIfStatementsOnASingleLine: false diff --git a/Chapter04/bare/.vscode/launch.json b/Chapter04/bare/.vscode/launch.json new file mode 100644 index 0000000..7240d65 --- /dev/null +++ b/Chapter04/bare/.vscode/launch.json @@ -0,0 +1,32 @@ +{ + "version": "0.2.0", + "configurations": [ + { + "name": "Debug application in Renode", + "type": "cortex-debug", + "request": "launch", + "preLaunchTask": "Run Renode Debug", + "postDebugTask": "Close Renode", + "servertype": "external", + "gdbPath": "arm-none-eabi-gdb", + "gdbTarget": "localhost:3333", + "cwd": "${workspaceRoot}", + "executable": "${workspaceFolder}/build/bare.elf", + "preLaunchCommands": [ + "monitor machine Reset", + "monitor start", + "monitor continue" + ], + }, + { + "name": "Run Without Debugging", + "type": "node", + "request": "launch", + "cwd": "${workspaceFolder}", + "preLaunchTask": "Run Renode", + "postDebugTask": "Close Renode", + "internalConsoleOptions": "neverOpen", + } + ] +} + diff --git a/Chapter04/bare/.vscode/tasks.json b/Chapter04/bare/.vscode/tasks.json new file mode 100644 index 0000000..7d50a41 --- /dev/null +++ b/Chapter04/bare/.vscode/tasks.json @@ -0,0 +1,115 @@ +{ + "version": "2.0.0", + "tasks": [ + { + "label": "Configure", + "type": "shell", + "command": "cmake", + "args": [ + "-S", + "${workspaceFolder}", // Specifies the source directory + "-B", + "${workspaceFolder}/build", // Specifies the build directory + "-DCMAKE_BUILD_TYPE=Debug" // Example of setting a CMake variable + ], + "group": "build", + "problemMatcher": [], + "detail": "Generates build system files with CMake" + }, + { + "label": "Build", + "type": "shell", + "dependsOn": [ + "Configure" + ], + "command": "make", + "args": [ + "-C", "build" + ], + "group": { + "kind": "build", + "isDefault": true + }, + "problemMatcher": [], + "presentation": { + "reveal": "always", + "panel": "shared" + } + }, + { + "label": "Run Renode", + "type": "shell", + "command": "renode", + "args": [ + "--console", + "--disable-xwt", + "${workspaceFolder}/renode_scripts/stm32f072.resc" + ], + "dependsOn": [ + "Build" + ], + "isBackground": true, + "problemMatcher": { + "source": "Renode", + "pattern": { + "regexp": "" + }, + "background": { + "activeOnStart": true, + "beginsPattern": "Renode, version .*", + "endsPattern": ".*GDB server with all CPUs started on port.*" + } + }, + "group": "build", + "presentation": { + "reveal": "always", + "panel": "dedicated" + } + }, + { + "label": "Run Renode Debug", + "type": "shell", + "command": "renode", + "args": [ + "--console", + "--disable-xwt", + "${workspaceFolder}/renode_scripts/stm32f072_debug.resc" + ], + "dependsOn": [ + "Build" + ], + "isBackground": true, + "problemMatcher": { + "source": "Renode", + "pattern": { + "regexp": "" + }, + "background": { + "activeOnStart": true, + "beginsPattern": "Renode, version .*", + "endsPattern": ".*GDB server with all CPUs started on port.*" + } + }, + "group": "build", + "presentation": { + "reveal": "always", + "panel": "dedicated" + } + }, + { + "label": "Close Renode", + "command": "echo ${input:terminate}", + "type": "shell", + "problemMatcher": [] + } + ], + "inputs": [ + { + "id": "terminate", + "type": "command", + "command": "workbench.action.tasks.terminate", + "args": "terminateAll" + } + ] +} + diff --git a/Chapter04/bare/CMakeLists.txt b/Chapter04/bare/CMakeLists.txt new file mode 100644 index 0000000..6786535 --- /dev/null +++ b/Chapter04/bare/CMakeLists.txt @@ -0,0 +1,149 @@ +cmake_minimum_required(VERSION 3.13) + +set(CMAKE_EXPORT_COMPILE_COMMANDS 1) + +set(CMAKE_C_COMPILER "arm-none-eabi-gcc") +set(CMAKE_CXX_COMPILER "arm-none-eabi-g++") +set(CMAKE_ASM_COMPILER "arm-none-eabi-gcc") +set(CMAKE_OBJCOPY "arm-none-eabi-objcopy") +set(CMAKE_SIZE "arm-none-eabi-size") + +set(RENODE "renode" CACHE STRING "Path to Renode executable") +message(STATUS "Using Renode at: ${RENODE}") + + +find_program(CCACHE_FOUND ccache) +if(CCACHE_FOUND) + set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache) +endif(CCACHE_FOUND) + +set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY) + +set(CDEFS "-DUSE_HAL_DRIVER -DSTM32F072xB") +set(MCU "-mcpu=cortex-m0 -mthumb") +set(CMAKE_C_FLAGS + "${MCU} ${CDEFS} -fdata-sections -ffunction-sections -Wno-address-of-packed-member -Wall -Wextra -Wno-unused-parameter" + CACHE INTERNAL "") +set(CMAKE_CXX_FLAGS + "${CMAKE_C_FLAGS} -Wno-register -fno-exceptions -fno-rtti -fno-threadsafe-statics" + CACHE INTERNAL "") + +set(ASM_OPTIONS "-x assembler-with-cpp") +set(CMAKE_ASM_FLAGS "${CMAKE_C_FLAGS} ${ASM_OPTIONS}") + +set(CMAKE_C_FLAGS_DEBUG "-g -gdwarf-2 -O0") +set(CMAKE_CXX_FLAGS_DEBUG "-g -gdwarf-2 -O0") +set(CMAKE_C_FLAGS_RELEASE "-O2 -flto") +set(CMAKE_CXX_FLAGS_RELEASE "-O2 -flto") +set(CMAKE_C_FLAGS_MINSIZEREL "-Os -flto") +set(CMAKE_CXX_FLAGS_MINSIZEREL "-Os -flto") + +if(CMAKE_EXPORT_COMPILE_COMMANDS) + # This dreadful mess is to communicate to clang-tidy the C++ system includes. + # It seems that CMake doesn't support using its own compile_commands.json + # database, and that clang-tidy doesn't pick up non-default system headers. + execute_process( + COMMAND + bash -c + "${CMAKE_CXX_COMPILER} -x c++ -Wp,-v /dev/null 2>&1 > /dev/null | grep '^ /' | grep -w 'c++'" + OUTPUT_VARIABLE COMPILER_HEADERS + OUTPUT_STRIP_TRAILING_WHITESPACE) + string(REGEX REPLACE "[ \n\t]+" ";" INCLUDE_COMPILER_HEADERS + ${COMPILER_HEADERS}) + set(CMAKE_CXX_STANDARD_INCLUDE_DIRECTORIES ${INCLUDE_COMPILER_HEADERS}) + message(STATUS "${CMAKE_CXX_STANDARD_INCLUDE_DIRECTORIES}") + + execute_process( + COMMAND + bash -c + "${CMAKE_C_COMPILER} -x c -Wp,-v /dev/null 2>&1 > /dev/null | grep '^ /' " + OUTPUT_VARIABLE COMPILER_HEADERS + OUTPUT_STRIP_TRAILING_WHITESPACE) + string(REGEX REPLACE "[ \n\t]+" ";" INCLUDE_COMPILER_HEADERS + ${COMPILER_HEADERS}) + set(CMAKE_C_STANDARD_INCLUDE_DIRECTORIES ${INCLUDE_COMPILER_HEADERS}) + message(STATUS "${CMAKE_C_STANDARD_INCLUDE_DIRECTORIES}") + + set(CMAKE_CXX_STANDARD_INCLUDE_DIRECTORIES + "${CMAKE_CXX_STANDARD_INCLUDE_DIRECTORIES} ${CMAKE_C_STANDARD_INCLUDE_DIRECTORIES}" + ) +endif() + +project(bare VERSION 1.0.6) + +enable_language(C CXX ASM) + +set(CMAKE_CXX_STANDARD 17) +set(CMAKE_CXX_STANDARD_REQUIRED True) + +# global include directories +include_directories( + ${CMAKE_SOURCE_DIR}/platform/inc + ${CMAKE_SOURCE_DIR}/platform/CMSIS/Device/ST/STM32F0xx/Include + ${CMAKE_SOURCE_DIR}/platform/CMSIS/Include + ${CMAKE_SOURCE_DIR}/platform/STM32F0xx_HAL_Driver/Inc + ${CMAKE_SOURCE_DIR}/app/inc + ${CMAKE_SOURCE_DIR}/hal/uart/inc + ${CMAKE_SOURCE_DIR}/hal/inc + ) + + +set(EXECUTABLE ${PROJECT_NAME}.elf) + +add_executable( + ${EXECUTABLE} + platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal.c + platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cortex.c + platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_gpio.c + platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc.c + platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart.c + platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart_ex.c + platform/startup_stm32f072xb.s + platform/src/stm32f0xx_hal_msp.c + platform/src/stm32f0xx_it.c + platform/src/system_stm32f0xx.c + app/src/main.cpp + hal/uart/src/uart_stm32.cpp + ) + +target_link_libraries(${EXECUTABLE} PUBLIC) + +target_include_directories(${EXECUTABLE} PUBLIC ${PROJECT_BINARY_DIR} + ${CMAKE_SOURCE_DIR}) + +set_target_properties(${EXECUTABLE} PROPERTIES LINKER_LANGUAGE CXX) + +target_link_options( + ${EXECUTABLE} + PUBLIC + -T${CMAKE_SOURCE_DIR}/platform/STM32F072C8Tx_FLASH.ld + -mcpu=cortex-m0 + -mthumb + -specs=nosys.specs + -specs=nano.specs + -u + -lc + -lm + -lnosys + -Wl,-Map=${PROJECT_NAME}.map,--cref + -Wl,--gc-sections) + +# Print executable size +add_custom_command( + TARGET ${EXECUTABLE} + POST_BUILD + COMMAND arm-none-eabi-size ${EXECUTABLE}) + +# Create hex file +add_custom_command( + TARGET ${EXECUTABLE} + POST_BUILD + COMMAND arm-none-eabi-objcopy -O ihex ${EXECUTABLE} ${PROJECT_NAME}.hex + COMMAND arm-none-eabi-objcopy -O binary ${EXECUTABLE} ${PROJECT_NAME}.bin) + +# Run elf in Renode +add_custom_target( + run_in_renode + COMMAND ${RENODE} --console --disable-xwt ${CMAKE_SOURCE_DIR}/renode_scripts/stm32f072.resc -e start + DEPENDS ${PROJECT_NAME}.elf) + diff --git a/Chapter04/bare/app/src/main.cpp b/Chapter04/bare/app/src/main.cpp new file mode 100644 index 0000000..342c679 --- /dev/null +++ b/Chapter04/bare/app/src/main.cpp @@ -0,0 +1,28 @@ +#include + +#include + +#include +#include + +extern "C" int main(void) +{ + hal::init(); + + hal::uart_stm32 uart(USART2); + uart.init(); + + uart.puts("Hello world !\r\n"); + + std::uint32_t time_prev = hal::time::get_ms(); + while(1) + { + if(volatile auto time_now = hal::time::get_ms(); + time_now - time_prev > 1000) + { + uart.puts("While loop 1000 ms ping ...\r\n"); + time_prev = time_now; + } + } +} + diff --git a/Chapter04/bare/hal/inc/hal.hpp b/Chapter04/bare/hal/inc/hal.hpp new file mode 100644 index 0000000..2ff4a9d --- /dev/null +++ b/Chapter04/bare/hal/inc/hal.hpp @@ -0,0 +1,21 @@ +#pragma once + +#include + +#include + +namespace hal +{ +inline void init() +{ + HAL_Init(); +} + +struct time +{ + inline static std::uint32_t get_ms() + { + return HAL_GetTick(); + } +}; +}; // namespace hal diff --git a/Chapter04/bare/hal/uart/inc/uart.hpp b/Chapter04/bare/hal/uart/inc/uart.hpp new file mode 100644 index 0000000..082d57a --- /dev/null +++ b/Chapter04/bare/hal/uart/inc/uart.hpp @@ -0,0 +1,28 @@ +#pragma once + +#include + +namespace hal +{ +class uart +{ + public: + virtual void init() = 0; + + virtual void putchar(char c) = 0; + + void puts(const char *str) + { + std::size_t ind = 0; + + if(str != nullptr) + { + while(str[ind] != '\0') + { + putchar(str[ind]); + ind++; + } + } + } +}; +}; // namespace hal diff --git a/Chapter04/bare/hal/uart/inc/uart_stm32.hpp b/Chapter04/bare/hal/uart/inc/uart_stm32.hpp new file mode 100644 index 0000000..abd9690 --- /dev/null +++ b/Chapter04/bare/hal/uart/inc/uart_stm32.hpp @@ -0,0 +1,25 @@ +#pragma once + +#include + +#include + +#include + +namespace hal +{ +class uart_stm32 : public uart +{ + public: + uart_stm32(USART_TypeDef *inst, std::uint32_t baud = 115200); + + void init() override; + + void putchar(char c) override; + + private: + UART_HandleTypeDef huart; + USART_TypeDef *instance; + std::uint32_t baudrate; +}; +}; // namespace hal diff --git a/Chapter04/bare/hal/uart/src/uart_stm32.cpp b/Chapter04/bare/hal/uart/src/uart_stm32.cpp new file mode 100644 index 0000000..c4091a1 --- /dev/null +++ b/Chapter04/bare/hal/uart/src/uart_stm32.cpp @@ -0,0 +1,33 @@ +#include + +hal::uart_stm32::uart_stm32(USART_TypeDef *inst, std::uint32_t baud) + : instance(inst), baudrate(baud) +{ +} + +void hal::uart_stm32::init() +{ + huart.Instance = USART2; + huart.Init.BaudRate = 115200; + huart.Init.WordLength = UART_WORDLENGTH_8B; + huart.Init.StopBits = UART_STOPBITS_1; + huart.Init.Parity = UART_PARITY_NONE; + huart.Init.Mode = UART_MODE_TX_RX; + huart.Init.HwFlowCtl = UART_HWCONTROL_NONE; + huart.Init.OverSampling = UART_OVERSAMPLING_16; + huart.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE; + huart.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT; + + // huart.MspInitCallback = mspInitCallback; + + if(HAL_UART_Init(&huart) != HAL_OK) + { + // Error_Handler(); + } +} + +void hal::uart_stm32::putchar(char c) +{ + HAL_UART_Transmit(&huart, reinterpret_cast(&c), 1, + HAL_MAX_DELAY); +} diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armcc.h b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armcc.h new file mode 100644 index 0000000..7d751fb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armcc.h @@ -0,0 +1,865 @@ +/**************************************************************************//** + * @file cmsis_armcc.h + * @brief CMSIS compiler ARMCC (Arm Compiler 5) header file + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_ARMCC_H +#define __CMSIS_ARMCC_H + + +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 400677) + #error "Please use Arm Compiler Toolchain V4.0.677 or later!" +#endif + +/* CMSIS compiler control architecture macros */ +#if ((defined (__TARGET_ARCH_6_M ) && (__TARGET_ARCH_6_M == 1)) || \ + (defined (__TARGET_ARCH_6S_M ) && (__TARGET_ARCH_6S_M == 1)) ) + #define __ARM_ARCH_6M__ 1 +#endif + +#if (defined (__TARGET_ARCH_7_M ) && (__TARGET_ARCH_7_M == 1)) + #define __ARM_ARCH_7M__ 1 +#endif + +#if (defined (__TARGET_ARCH_7E_M) && (__TARGET_ARCH_7E_M == 1)) + #define __ARM_ARCH_7EM__ 1 +#endif + + /* __ARM_ARCH_8M_BASE__ not applicable */ + /* __ARM_ARCH_8M_MAIN__ not applicable */ + + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE __inline +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static __inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE static __forceinline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __declspec(noreturn) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed)) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT __packed struct +#endif +#ifndef __PACKED_UNION + #define __PACKED_UNION __packed union +#endif +#ifndef __UNALIGNED_UINT32 /* deprecated */ + #define __UNALIGNED_UINT32(x) (*((__packed uint32_t *)(x))) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #define __UNALIGNED_UINT16_WRITE(addr, val) ((*((__packed uint16_t *)(addr))) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #define __UNALIGNED_UINT16_READ(addr) (*((const __packed uint16_t *)(addr))) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #define __UNALIGNED_UINT32_WRITE(addr, val) ((*((__packed uint32_t *)(addr))) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #define __UNALIGNED_UINT32_READ(addr) (*((const __packed uint32_t *)(addr))) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + +/* ########################### Core Function Access ########################### */ +/** \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions + @{ + */ + +/** + \brief Enable IRQ Interrupts + \details Enables IRQ interrupts by clearing the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __enable_irq(); */ + + +/** + \brief Disable IRQ Interrupts + \details Disables IRQ interrupts by setting the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __disable_irq(); */ + +/** + \brief Get Control Register + \details Returns the content of the Control Register. + \return Control Register value + */ +__STATIC_INLINE uint32_t __get_CONTROL(void) +{ + register uint32_t __regControl __ASM("control"); + return(__regControl); +} + + +/** + \brief Set Control Register + \details Writes the given value to the Control Register. + \param [in] control Control Register value to set + */ +__STATIC_INLINE void __set_CONTROL(uint32_t control) +{ + register uint32_t __regControl __ASM("control"); + __regControl = control; +} + + +/** + \brief Get IPSR Register + \details Returns the content of the IPSR Register. + \return IPSR Register value + */ +__STATIC_INLINE uint32_t __get_IPSR(void) +{ + register uint32_t __regIPSR __ASM("ipsr"); + return(__regIPSR); +} + + +/** + \brief Get APSR Register + \details Returns the content of the APSR Register. + \return APSR Register value + */ +__STATIC_INLINE uint32_t __get_APSR(void) +{ + register uint32_t __regAPSR __ASM("apsr"); + return(__regAPSR); +} + + +/** + \brief Get xPSR Register + \details Returns the content of the xPSR Register. + \return xPSR Register value + */ +__STATIC_INLINE uint32_t __get_xPSR(void) +{ + register uint32_t __regXPSR __ASM("xpsr"); + return(__regXPSR); +} + + +/** + \brief Get Process Stack Pointer + \details Returns the current value of the Process Stack Pointer (PSP). + \return PSP Register value + */ +__STATIC_INLINE uint32_t __get_PSP(void) +{ + register uint32_t __regProcessStackPointer __ASM("psp"); + return(__regProcessStackPointer); +} + + +/** + \brief Set Process Stack Pointer + \details Assigns the given value to the Process Stack Pointer (PSP). + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_INLINE void __set_PSP(uint32_t topOfProcStack) +{ + register uint32_t __regProcessStackPointer __ASM("psp"); + __regProcessStackPointer = topOfProcStack; +} + + +/** + \brief Get Main Stack Pointer + \details Returns the current value of the Main Stack Pointer (MSP). + \return MSP Register value + */ +__STATIC_INLINE uint32_t __get_MSP(void) +{ + register uint32_t __regMainStackPointer __ASM("msp"); + return(__regMainStackPointer); +} + + +/** + \brief Set Main Stack Pointer + \details Assigns the given value to the Main Stack Pointer (MSP). + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_INLINE void __set_MSP(uint32_t topOfMainStack) +{ + register uint32_t __regMainStackPointer __ASM("msp"); + __regMainStackPointer = topOfMainStack; +} + + +/** + \brief Get Priority Mask + \details Returns the current state of the priority mask bit from the Priority Mask Register. + \return Priority Mask value + */ +__STATIC_INLINE uint32_t __get_PRIMASK(void) +{ + register uint32_t __regPriMask __ASM("primask"); + return(__regPriMask); +} + + +/** + \brief Set Priority Mask + \details Assigns the given value to the Priority Mask Register. + \param [in] priMask Priority Mask + */ +__STATIC_INLINE void __set_PRIMASK(uint32_t priMask) +{ + register uint32_t __regPriMask __ASM("primask"); + __regPriMask = (priMask); +} + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + +/** + \brief Enable FIQ + \details Enables FIQ interrupts by clearing the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __enable_fault_irq __enable_fiq + + +/** + \brief Disable FIQ + \details Disables FIQ interrupts by setting the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __disable_fault_irq __disable_fiq + + +/** + \brief Get Base Priority + \details Returns the current value of the Base Priority register. + \return Base Priority register value + */ +__STATIC_INLINE uint32_t __get_BASEPRI(void) +{ + register uint32_t __regBasePri __ASM("basepri"); + return(__regBasePri); +} + + +/** + \brief Set Base Priority + \details Assigns the given value to the Base Priority register. + \param [in] basePri Base Priority value to set + */ +__STATIC_INLINE void __set_BASEPRI(uint32_t basePri) +{ + register uint32_t __regBasePri __ASM("basepri"); + __regBasePri = (basePri & 0xFFU); +} + + +/** + \brief Set Base Priority with condition + \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, + or the new value increases the BASEPRI priority level. + \param [in] basePri Base Priority value to set + */ +__STATIC_INLINE void __set_BASEPRI_MAX(uint32_t basePri) +{ + register uint32_t __regBasePriMax __ASM("basepri_max"); + __regBasePriMax = (basePri & 0xFFU); +} + + +/** + \brief Get Fault Mask + \details Returns the current value of the Fault Mask register. + \return Fault Mask register value + */ +__STATIC_INLINE uint32_t __get_FAULTMASK(void) +{ + register uint32_t __regFaultMask __ASM("faultmask"); + return(__regFaultMask); +} + + +/** + \brief Set Fault Mask + \details Assigns the given value to the Fault Mask register. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_INLINE void __set_FAULTMASK(uint32_t faultMask) +{ + register uint32_t __regFaultMask __ASM("faultmask"); + __regFaultMask = (faultMask & (uint32_t)1U); +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ + + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value + */ +__STATIC_INLINE uint32_t __get_FPSCR(void) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + register uint32_t __regfpscr __ASM("fpscr"); + return(__regfpscr); +#else + return(0U); +#endif +} + + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set + */ +__STATIC_INLINE void __set_FPSCR(uint32_t fpscr) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + register uint32_t __regfpscr __ASM("fpscr"); + __regfpscr = (fpscr); +#else + (void)fpscr; +#endif +} + + +/*@} end of CMSIS_Core_RegAccFunctions */ + + +/* ########################## Core Instruction Access ######################### */ +/** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface + Access to dedicated instructions + @{ +*/ + +/** + \brief No Operation + \details No Operation does nothing. This instruction can be used for code alignment purposes. + */ +#define __NOP __nop + + +/** + \brief Wait For Interrupt + \details Wait For Interrupt is a hint instruction that suspends execution until one of a number of events occurs. + */ +#define __WFI __wfi + + +/** + \brief Wait For Event + \details Wait For Event is a hint instruction that permits the processor to enter + a low-power state until one of a number of events occurs. + */ +#define __WFE __wfe + + +/** + \brief Send Event + \details Send Event is a hint instruction. It causes an event to be signaled to the CPU. + */ +#define __SEV __sev + + +/** + \brief Instruction Synchronization Barrier + \details Instruction Synchronization Barrier flushes the pipeline in the processor, + so that all instructions following the ISB are fetched from cache or memory, + after the instruction has been completed. + */ +#define __ISB() do {\ + __schedule_barrier();\ + __isb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Synchronization Barrier + \details Acts as a special kind of Data Memory Barrier. + It completes when all explicit memory accesses before this instruction complete. + */ +#define __DSB() do {\ + __schedule_barrier();\ + __dsb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Memory Barrier + \details Ensures the apparent order of the explicit memory operations before + and after the instruction, without ensuring their completion. + */ +#define __DMB() do {\ + __schedule_barrier();\ + __dmb(0xF);\ + __schedule_barrier();\ + } while (0U) + + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV __rev + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".rev16_text"))) __STATIC_INLINE __ASM uint32_t __REV16(uint32_t value) +{ + rev16 r0, r0 + bx lr +} +#endif + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".revsh_text"))) __STATIC_INLINE __ASM int16_t __REVSH(int16_t value) +{ + revsh r0, r0 + bx lr +} +#endif + + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +#define __ROR __ror + + +/** + \brief Breakpoint + \details Causes the processor to enter Debug state. + Debug tools can use this to investigate system state when the instruction at a particular address is reached. + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __breakpoint(value) + + +/** + \brief Reverse bit order of value + \details Reverses the bit order of the given value. + \param [in] value Value to reverse + \return Reversed value + */ +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + #define __RBIT __rbit +#else +__attribute__((always_inline)) __STATIC_INLINE uint32_t __RBIT(uint32_t value) +{ + uint32_t result; + uint32_t s = (4U /*sizeof(v)*/ * 8U) - 1U; /* extra shift needed at end */ + + result = value; /* r will be reversed bits of v; first get LSB of v */ + for (value >>= 1U; value != 0U; value >>= 1U) + { + result <<= 1U; + result |= value & 1U; + s--; + } + result <<= s; /* shift when v's highest bits are zero */ + return result; +} +#endif + + +/** + \brief Count leading zeros + \details Counts the number of leading zeros of a data value. + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ __clz + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXB(ptr) ((uint8_t ) __ldrex(ptr)) +#else + #define __LDREXB(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint8_t ) __ldrex(ptr)) _Pragma("pop") +#endif + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXH(ptr) ((uint16_t) __ldrex(ptr)) +#else + #define __LDREXH(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint16_t) __ldrex(ptr)) _Pragma("pop") +#endif + + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXW(ptr) ((uint32_t ) __ldrex(ptr)) +#else + #define __LDREXW(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint32_t ) __ldrex(ptr)) _Pragma("pop") +#endif + + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXB(value, ptr) __strex(value, ptr) +#else + #define __STREXB(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXH(value, ptr) __strex(value, ptr) +#else + #define __STREXH(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXW(value, ptr) __strex(value, ptr) +#else + #define __STREXW(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +#define __CLREX __clrex + + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT __ssat + + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT __usat + + +/** + \brief Rotate Right with Extend (32 bit) + \details Moves each bit of a bitstring right by one bit. + The carry input is shifted in at the left end of the bitstring. + \param [in] value Value to rotate + \return Rotated value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".rrx_text"))) __STATIC_INLINE __ASM uint32_t __RRX(uint32_t value) +{ + rrx r0, r0 + bx lr +} +#endif + + +/** + \brief LDRT Unprivileged (8 bit) + \details Executes a Unprivileged LDRT instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#define __LDRBT(ptr) ((uint8_t ) __ldrt(ptr)) + + +/** + \brief LDRT Unprivileged (16 bit) + \details Executes a Unprivileged LDRT instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#define __LDRHT(ptr) ((uint16_t) __ldrt(ptr)) + + +/** + \brief LDRT Unprivileged (32 bit) + \details Executes a Unprivileged LDRT instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#define __LDRT(ptr) ((uint32_t ) __ldrt(ptr)) + + +/** + \brief STRT Unprivileged (8 bit) + \details Executes a Unprivileged STRT instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +#define __STRBT(value, ptr) __strt(value, ptr) + + +/** + \brief STRT Unprivileged (16 bit) + \details Executes a Unprivileged STRT instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +#define __STRHT(value, ptr) __strt(value, ptr) + + +/** + \brief STRT Unprivileged (32 bit) + \details Executes a Unprivileged STRT instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +#define __STRT(value, ptr) __strt(value, ptr) + +#else /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +__attribute__((always_inline)) __STATIC_INLINE int32_t __SSAT(int32_t val, uint32_t sat) +{ + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; +} + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +__attribute__((always_inline)) __STATIC_INLINE uint32_t __USAT(int32_t val, uint32_t sat) +{ + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ + +/*@}*/ /* end of group CMSIS_Core_InstructionInterface */ + + +/* ################### Compiler specific Intrinsics ########################### */ +/** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics + Access to dedicated SIMD instructions + @{ +*/ + +#if ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + +#define __SADD8 __sadd8 +#define __QADD8 __qadd8 +#define __SHADD8 __shadd8 +#define __UADD8 __uadd8 +#define __UQADD8 __uqadd8 +#define __UHADD8 __uhadd8 +#define __SSUB8 __ssub8 +#define __QSUB8 __qsub8 +#define __SHSUB8 __shsub8 +#define __USUB8 __usub8 +#define __UQSUB8 __uqsub8 +#define __UHSUB8 __uhsub8 +#define __SADD16 __sadd16 +#define __QADD16 __qadd16 +#define __SHADD16 __shadd16 +#define __UADD16 __uadd16 +#define __UQADD16 __uqadd16 +#define __UHADD16 __uhadd16 +#define __SSUB16 __ssub16 +#define __QSUB16 __qsub16 +#define __SHSUB16 __shsub16 +#define __USUB16 __usub16 +#define __UQSUB16 __uqsub16 +#define __UHSUB16 __uhsub16 +#define __SASX __sasx +#define __QASX __qasx +#define __SHASX __shasx +#define __UASX __uasx +#define __UQASX __uqasx +#define __UHASX __uhasx +#define __SSAX __ssax +#define __QSAX __qsax +#define __SHSAX __shsax +#define __USAX __usax +#define __UQSAX __uqsax +#define __UHSAX __uhsax +#define __USAD8 __usad8 +#define __USADA8 __usada8 +#define __SSAT16 __ssat16 +#define __USAT16 __usat16 +#define __UXTB16 __uxtb16 +#define __UXTAB16 __uxtab16 +#define __SXTB16 __sxtb16 +#define __SXTAB16 __sxtab16 +#define __SMUAD __smuad +#define __SMUADX __smuadx +#define __SMLAD __smlad +#define __SMLADX __smladx +#define __SMLALD __smlald +#define __SMLALDX __smlaldx +#define __SMUSD __smusd +#define __SMUSDX __smusdx +#define __SMLSD __smlsd +#define __SMLSDX __smlsdx +#define __SMLSLD __smlsld +#define __SMLSLDX __smlsldx +#define __SEL __sel +#define __QADD __qadd +#define __QSUB __qsub + +#define __PKHBT(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0x0000FFFFUL) | \ + ((((uint32_t)(ARG2)) << (ARG3)) & 0xFFFF0000UL) ) + +#define __PKHTB(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0xFFFF0000UL) | \ + ((((uint32_t)(ARG2)) >> (ARG3)) & 0x0000FFFFUL) ) + +#define __SMMLA(ARG1,ARG2,ARG3) ( (int32_t)((((int64_t)(ARG1) * (ARG2)) + \ + ((int64_t)(ARG3) << 32U) ) >> 32U)) + +#endif /* ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ +/*@} end of group CMSIS_SIMD_intrinsics */ + + +#endif /* __CMSIS_ARMCC_H */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armclang.h b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armclang.h new file mode 100644 index 0000000..d8031b0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_armclang.h @@ -0,0 +1,1869 @@ +/**************************************************************************//** + * @file cmsis_armclang.h + * @brief CMSIS compiler armclang (Arm Compiler 6) header file + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/*lint -esym(9058, IRQn)*/ /* disable MISRA 2012 Rule 2.4 for IRQn */ + +#ifndef __CMSIS_ARMCLANG_H +#define __CMSIS_ARMCLANG_H + +#pragma clang system_header /* treat file as system include file */ + +#ifndef __ARM_COMPAT_H +#include /* Compatibility header for Arm Compiler 5 intrinsics */ +#endif + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE __inline +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static __inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __attribute__((always_inline)) static __inline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __attribute__((__noreturn__)) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_UNION + #define __PACKED_UNION union __attribute__((packed, aligned(1))) +#endif +#ifndef __UNALIGNED_UINT32 /* deprecated */ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32 */ + struct __attribute__((packed)) T_UINT32 { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_WRITE */ + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_READ)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_READ */ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32_WRITE */ + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32_READ)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32_READ */ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + + +/* ########################### Core Function Access ########################### */ +/** \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions + @{ + */ + +/** + \brief Enable IRQ Interrupts + \details Enables IRQ interrupts by clearing the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __enable_irq(); see arm_compat.h */ + + +/** + \brief Disable IRQ Interrupts + \details Disables IRQ interrupts by setting the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __disable_irq(); see arm_compat.h */ + + +/** + \brief Get Control Register + \details Returns the content of the Control Register. + \return Control Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CONTROL(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Control Register (non-secure) + \details Returns the content of the non-secure Control Register when in secure mode. + \return non-secure Control Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_CONTROL_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Control Register + \details Writes the given value to the Control Register. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __set_CONTROL(uint32_t control) +{ + __ASM volatile ("MSR control, %0" : : "r" (control) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Control Register (non-secure) + \details Writes the given value to the non-secure Control Register when in secure state. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) +{ + __ASM volatile ("MSR control_ns, %0" : : "r" (control) : "memory"); +} +#endif + + +/** + \brief Get IPSR Register + \details Returns the content of the IPSR Register. + \return IPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_IPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, ipsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get APSR Register + \details Returns the content of the APSR Register. + \return APSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_APSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, apsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get xPSR Register + \details Returns the content of the xPSR Register. + \return xPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_xPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, xpsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get Process Stack Pointer + \details Returns the current value of the Process Stack Pointer (PSP). + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer (non-secure) + \details Returns the current value of the non-secure Process Stack Pointer (PSP) when in secure state. + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Process Stack Pointer + \details Assigns the given value to the Process Stack Pointer (PSP). + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_PSP(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp, %0" : : "r" (topOfProcStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Process Stack Pointer (PSP) when in secure state. + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSP_NS(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp_ns, %0" : : "r" (topOfProcStack) : ); +} +#endif + + +/** + \brief Get Main Stack Pointer + \details Returns the current value of the Main Stack Pointer (MSP). + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer (non-secure) + \details Returns the current value of the non-secure Main Stack Pointer (MSP) when in secure state. + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Main Stack Pointer + \details Assigns the given value to the Main Stack Pointer (MSP). + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_MSP(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp, %0" : : "r" (topOfMainStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Main Stack Pointer (MSP) when in secure state. + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSP_NS(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp_ns, %0" : : "r" (topOfMainStack) : ); +} +#endif + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Stack Pointer (non-secure) + \details Returns the current value of the non-secure Stack Pointer (SP) when in secure state. + \return SP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_SP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, sp_ns" : "=r" (result) ); + return(result); +} + + +/** + \brief Set Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Stack Pointer (SP) when in secure state. + \param [in] topOfStack Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_SP_NS(uint32_t topOfStack) +{ + __ASM volatile ("MSR sp_ns, %0" : : "r" (topOfStack) : ); +} +#endif + + +/** + \brief Get Priority Mask + \details Returns the current state of the priority mask bit from the Priority Mask Register. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __get_PRIMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Priority Mask (non-secure) + \details Returns the current state of the non-secure priority mask bit from the Priority Mask Register when in secure state. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PRIMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Priority Mask + \details Assigns the given value to the Priority Mask Register. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __set_PRIMASK(uint32_t priMask) +{ + __ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Priority Mask (non-secure) + \details Assigns the given value to the non-secure Priority Mask Register when in secure state. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __TZ_set_PRIMASK_NS(uint32_t priMask) +{ + __ASM volatile ("MSR primask_ns, %0" : : "r" (priMask) : "memory"); +} +#endif + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) +/** + \brief Enable FIQ + \details Enables FIQ interrupts by clearing the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __enable_fault_irq __enable_fiq /* see arm_compat.h */ + + +/** + \brief Disable FIQ + \details Disables FIQ interrupts by setting the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __disable_fault_irq __disable_fiq /* see arm_compat.h */ + + +/** + \brief Get Base Priority + \details Returns the current value of the Base Priority register. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __get_BASEPRI(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Base Priority (non-secure) + \details Returns the current value of the non-secure Base Priority register when in secure state. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_BASEPRI_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Base Priority + \details Assigns the given value to the Base Priority register. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI(uint32_t basePri) +{ + __ASM volatile ("MSR basepri, %0" : : "r" (basePri) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Base Priority (non-secure) + \details Assigns the given value to the non-secure Base Priority register when in secure state. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __TZ_set_BASEPRI_NS(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_ns, %0" : : "r" (basePri) : "memory"); +} +#endif + + +/** + \brief Set Base Priority with condition + \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, + or the new value increases the BASEPRI priority level. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI_MAX(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_max, %0" : : "r" (basePri) : "memory"); +} + + +/** + \brief Get Fault Mask + \details Returns the current value of the Fault Mask register. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __get_FAULTMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Fault Mask (non-secure) + \details Returns the current value of the non-secure Fault Mask register when in secure state. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_FAULTMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Fault Mask + \details Assigns the given value to the Fault Mask register. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __set_FAULTMASK(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask, %0" : : "r" (faultMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Fault Mask (non-secure) + \details Assigns the given value to the non-secure Fault Mask register when in secure state. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __TZ_set_FAULTMASK_NS(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask_ns, %0" : : "r" (faultMask) : "memory"); +} +#endif + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + +/** + \brief Get Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the Process Stack Pointer Limit (PSPLIM). + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim" : "=r" (result) ); + return result; +#endif +} + +#if (defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the Process Stack Pointer Limit (PSPLIM). + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_PSPLIM(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim, %0" : : "r" (ProcStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSPLIM_NS(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim_ns, %0\n" : : "r" (ProcStackPtrLimit)); +#endif +} +#endif + + +/** + \brief Get Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the Main Stack Pointer Limit (MSPLIM). + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim" : "=r" (result) ); + return result; +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the non-secure Main Stack Pointer Limit(MSPLIM) when in secure state. + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the Main Stack Pointer Limit (MSPLIM). + \param [in] MainStackPtrLimit Main Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_MSPLIM(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim, %0" : : "r" (MainStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the non-secure Main Stack Pointer Limit (MSPLIM) when in secure state. + \param [in] MainStackPtrLimit Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSPLIM_NS(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim_ns, %0" : : "r" (MainStackPtrLimit)); +#endif +} +#endif + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value + */ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#define __get_FPSCR (uint32_t)__builtin_arm_get_fpscr +#else +#define __get_FPSCR() ((uint32_t)0U) +#endif + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set + */ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#define __set_FPSCR __builtin_arm_set_fpscr +#else +#define __set_FPSCR(x) ((void)(x)) +#endif + + +/*@} end of CMSIS_Core_RegAccFunctions */ + + +/* ########################## Core Instruction Access ######################### */ +/** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface + Access to dedicated instructions + @{ +*/ + +/* Define macros for porting to both thumb1 and thumb2. + * For thumb1, use low register (r0-r7), specified by constraint "l" + * Otherwise, use general registers, specified by constraint "r" */ +#if defined (__thumb__) && !defined (__thumb2__) +#define __CMSIS_GCC_OUT_REG(r) "=l" (r) +#define __CMSIS_GCC_USE_REG(r) "l" (r) +#else +#define __CMSIS_GCC_OUT_REG(r) "=r" (r) +#define __CMSIS_GCC_USE_REG(r) "r" (r) +#endif + +/** + \brief No Operation + \details No Operation does nothing. This instruction can be used for code alignment purposes. + */ +#define __NOP __builtin_arm_nop + +/** + \brief Wait For Interrupt + \details Wait For Interrupt is a hint instruction that suspends execution until one of a number of events occurs. + */ +#define __WFI __builtin_arm_wfi + + +/** + \brief Wait For Event + \details Wait For Event is a hint instruction that permits the processor to enter + a low-power state until one of a number of events occurs. + */ +#define __WFE __builtin_arm_wfe + + +/** + \brief Send Event + \details Send Event is a hint instruction. It causes an event to be signaled to the CPU. + */ +#define __SEV __builtin_arm_sev + + +/** + \brief Instruction Synchronization Barrier + \details Instruction Synchronization Barrier flushes the pipeline in the processor, + so that all instructions following the ISB are fetched from cache or memory, + after the instruction has been completed. + */ +#define __ISB() __builtin_arm_isb(0xF); + +/** + \brief Data Synchronization Barrier + \details Acts as a special kind of Data Memory Barrier. + It completes when all explicit memory accesses before this instruction complete. + */ +#define __DSB() __builtin_arm_dsb(0xF); + + +/** + \brief Data Memory Barrier + \details Ensures the apparent order of the explicit memory operations before + and after the instruction, without ensuring their completion. + */ +#define __DMB() __builtin_arm_dmb(0xF); + + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV(value) __builtin_bswap32(value) + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV16(value) __ROR(__REV(value), 16) + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REVSH(value) (int16_t)__builtin_bswap16(value) + + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __ROR(uint32_t op1, uint32_t op2) +{ + op2 %= 32U; + if (op2 == 0U) + { + return op1; + } + return (op1 >> op2) | (op1 << (32U - op2)); +} + + +/** + \brief Breakpoint + \details Causes the processor to enter Debug state. + Debug tools can use this to investigate system state when the instruction at a particular address is reached. + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __ASM volatile ("bkpt "#value) + + +/** + \brief Reverse bit order of value + \details Reverses the bit order of the given value. + \param [in] value Value to reverse + \return Reversed value + */ +#define __RBIT __builtin_arm_rbit + +/** + \brief Count leading zeros + \details Counts the number of leading zeros of a data value. + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ (uint8_t)__builtin_clz + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#define __LDREXB (uint8_t)__builtin_arm_ldrex + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#define __LDREXH (uint16_t)__builtin_arm_ldrex + + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#define __LDREXW (uint32_t)__builtin_arm_ldrex + + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXB (uint32_t)__builtin_arm_strex + + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXH (uint32_t)__builtin_arm_strex + + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXW (uint32_t)__builtin_arm_strex + + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +#define __CLREX __builtin_arm_clrex + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT __builtin_arm_ssat + + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT __builtin_arm_usat + + +/** + \brief Rotate Right with Extend (32 bit) + \details Moves each bit of a bitstring right by one bit. + The carry input is shifted in at the left end of the bitstring. + \param [in] value Value to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __RRX(uint32_t value) +{ + uint32_t result; + + __ASM volatile ("rrx %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return(result); +} + + +/** + \brief LDRT Unprivileged (8 bit) + \details Executes a Unprivileged LDRT instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDRBT(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrbt %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (16 bit) + \details Executes a Unprivileged LDRT instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDRHT(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrht %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (32 bit) + \details Executes a Unprivileged LDRT instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDRT(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrt %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief STRT Unprivileged (8 bit) + \details Executes a Unprivileged STRT instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRBT(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("strbt %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (16 bit) + \details Executes a Unprivileged STRT instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRHT(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("strht %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (32 bit) + \details Executes a Unprivileged STRT instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRT(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("strt %1, %0" : "=Q" (*ptr) : "r" (value) ); +} + +#else /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +__STATIC_FORCEINLINE int32_t __SSAT(int32_t val, uint32_t sat) +{ + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; +} + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +__STATIC_FORCEINLINE uint32_t __USAT(int32_t val, uint32_t sat) +{ + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief Load-Acquire (8 bit) + \details Executes a LDAB instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDAB(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldab %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); +} + + +/** + \brief Load-Acquire (16 bit) + \details Executes a LDAH instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDAH(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldah %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); +} + + +/** + \brief Load-Acquire (32 bit) + \details Executes a LDA instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDA(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("lda %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief Store-Release (8 bit) + \details Executes a STLB instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLB(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("stlb %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (16 bit) + \details Executes a STLH instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLH(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("stlh %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (32 bit) + \details Executes a STL instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STL(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("stl %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Load-Acquire Exclusive (8 bit) + \details Executes a LDAB exclusive instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#define __LDAEXB (uint8_t)__builtin_arm_ldaex + + +/** + \brief Load-Acquire Exclusive (16 bit) + \details Executes a LDAH exclusive instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#define __LDAEXH (uint16_t)__builtin_arm_ldaex + + +/** + \brief Load-Acquire Exclusive (32 bit) + \details Executes a LDA exclusive instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#define __LDAEX (uint32_t)__builtin_arm_ldaex + + +/** + \brief Store-Release Exclusive (8 bit) + \details Executes a STLB exclusive instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STLEXB (uint32_t)__builtin_arm_stlex + + +/** + \brief Store-Release Exclusive (16 bit) + \details Executes a STLH exclusive instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STLEXH (uint32_t)__builtin_arm_stlex + + +/** + \brief Store-Release Exclusive (32 bit) + \details Executes a STL exclusive instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STLEX (uint32_t)__builtin_arm_stlex + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + +/*@}*/ /* end of group CMSIS_Core_InstructionInterface */ + + +/* ################### Compiler specific Intrinsics ########################### */ +/** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics + Access to dedicated SIMD instructions + @{ +*/ + +#if (defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1)) + +__STATIC_FORCEINLINE uint32_t __SADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usad8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USADA8(uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("usada8 %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#define __SSAT16(ARG1,ARG2) \ +({ \ + int32_t __RES, __ARG1 = (ARG1); \ + __ASM ("ssat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +#define __USAT16(ARG1,ARG2) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1); \ + __ASM ("usat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +__STATIC_FORCEINLINE uint32_t __UXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("uxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("sxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUAD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuad %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUADX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuadx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLAD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlad %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLADX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smladx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLALD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLALDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SMUSD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUSDX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusdx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsd %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSDX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsdx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SEL (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sel %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QADD( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qadd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QSUB( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qsub %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +#if 0 +#define __PKHBT(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + __ASM ("pkhbt %0, %1, %2, lsl %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) + +#define __PKHTB(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + if (ARG3 == 0) \ + __ASM ("pkhtb %0, %1, %2" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2) ); \ + else \ + __ASM ("pkhtb %0, %1, %2, asr %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) +#endif + +#define __PKHBT(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0x0000FFFFUL) | \ + ((((uint32_t)(ARG2)) << (ARG3)) & 0xFFFF0000UL) ) + +#define __PKHTB(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0xFFFF0000UL) | \ + ((((uint32_t)(ARG2)) >> (ARG3)) & 0x0000FFFFUL) ) + +__STATIC_FORCEINLINE int32_t __SMMLA (int32_t op1, int32_t op2, int32_t op3) +{ + int32_t result; + + __ASM volatile ("smmla %0, %1, %2, %3" : "=r" (result): "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#endif /* (__ARM_FEATURE_DSP == 1) */ +/*@} end of group CMSIS_SIMD_intrinsics */ + + +#endif /* __CMSIS_ARMCLANG_H */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_compiler.h b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_compiler.h new file mode 100644 index 0000000..79a2cac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_compiler.h @@ -0,0 +1,266 @@ +/**************************************************************************//** + * @file cmsis_compiler.h + * @brief CMSIS compiler generic header file + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_COMPILER_H +#define __CMSIS_COMPILER_H + +#include + +/* + * Arm Compiler 4/5 + */ +#if defined ( __CC_ARM ) + #include "cmsis_armcc.h" + + +/* + * Arm Compiler 6 (armclang) + */ +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #include "cmsis_armclang.h" + + +/* + * GNU Compiler + */ +#elif defined ( __GNUC__ ) + #include "cmsis_gcc.h" + + +/* + * IAR Compiler + */ +#elif defined ( __ICCARM__ ) + #include + + +/* + * TI Arm Compiler + */ +#elif defined ( __TI_ARM__ ) + #include + + #ifndef __ASM + #define __ASM __asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + #define __NO_RETURN __attribute__((noreturn)) + #endif + #ifndef __USED + #define __USED __attribute__((used)) + #endif + #ifndef __WEAK + #define __WEAK __attribute__((weak)) + #endif + #ifndef __PACKED + #define __PACKED __attribute__((packed)) + #endif + #ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed)) + #endif + #ifndef __PACKED_UNION + #define __PACKED_UNION union __attribute__((packed)) + #endif + #ifndef __UNALIGNED_UINT32 /* deprecated */ + struct __attribute__((packed)) T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __UNALIGNED_UINT16_WRITE + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void*)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT16_READ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) + #endif + #ifndef __UNALIGNED_UINT32_WRITE + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT32_READ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) + #endif + #ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) + #endif + #ifndef __RESTRICT + #warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. + #define __RESTRICT + #endif + + +/* + * TASKING Compiler + */ +#elif defined ( __TASKING__ ) + /* + * The CMSIS functions have been implemented as intrinsics in the compiler. + * Please use "carm -?i" to get an up to date list of all intrinsics, + * Including the CMSIS ones. + */ + + #ifndef __ASM + #define __ASM __asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + #define __NO_RETURN __attribute__((noreturn)) + #endif + #ifndef __USED + #define __USED __attribute__((used)) + #endif + #ifndef __WEAK + #define __WEAK __attribute__((weak)) + #endif + #ifndef __PACKED + #define __PACKED __packed__ + #endif + #ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __packed__ + #endif + #ifndef __PACKED_UNION + #define __PACKED_UNION union __packed__ + #endif + #ifndef __UNALIGNED_UINT32 /* deprecated */ + struct __packed__ T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __UNALIGNED_UINT16_WRITE + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT16_READ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) + #endif + #ifndef __UNALIGNED_UINT32_WRITE + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT32_READ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) + #endif + #ifndef __ALIGNED + #define __ALIGNED(x) __align(x) + #endif + #ifndef __RESTRICT + #warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. + #define __RESTRICT + #endif + + +/* + * COSMIC Compiler + */ +#elif defined ( __CSMC__ ) + #include + + #ifndef __ASM + #define __ASM _asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + // NO RETURN is automatically detected hence no warning here + #define __NO_RETURN + #endif + #ifndef __USED + #warning No compiler specific solution for __USED. __USED is ignored. + #define __USED + #endif + #ifndef __WEAK + #define __WEAK __weak + #endif + #ifndef __PACKED + #define __PACKED @packed + #endif + #ifndef __PACKED_STRUCT + #define __PACKED_STRUCT @packed struct + #endif + #ifndef __PACKED_UNION + #define __PACKED_UNION @packed union + #endif + #ifndef __UNALIGNED_UINT32 /* deprecated */ + @packed struct T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __UNALIGNED_UINT16_WRITE + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT16_READ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) + #endif + #ifndef __UNALIGNED_UINT32_WRITE + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT32_READ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) + #endif + #ifndef __ALIGNED + #warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored. + #define __ALIGNED(x) + #endif + #ifndef __RESTRICT + #warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. + #define __RESTRICT + #endif + + +#else + #error Unknown compiler. +#endif + + +#endif /* __CMSIS_COMPILER_H */ + diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_gcc.h b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_gcc.h new file mode 100644 index 0000000..1bd41a4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_gcc.h @@ -0,0 +1,2085 @@ +/**************************************************************************//** + * @file cmsis_gcc.h + * @brief CMSIS compiler GCC header file + * @version V5.0.4 + * @date 09. April 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_GCC_H +#define __CMSIS_GCC_H + +/* ignore some GCC warnings */ +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wsign-conversion" +#pragma GCC diagnostic ignored "-Wconversion" +#pragma GCC diagnostic ignored "-Wunused-parameter" + +/* Fallback for __has_builtin */ +#ifndef __has_builtin + #define __has_builtin(x) (0) +#endif + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE inline +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __attribute__((always_inline)) static inline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __attribute__((__noreturn__)) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_UNION + #define __PACKED_UNION union __attribute__((packed, aligned(1))) +#endif +#ifndef __UNALIGNED_UINT32 /* deprecated */ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + struct __attribute__((packed)) T_UINT32 { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + + +/* ########################### Core Function Access ########################### */ +/** \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions + @{ + */ + +/** + \brief Enable IRQ Interrupts + \details Enables IRQ interrupts by clearing the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __enable_irq(void) +{ + __ASM volatile ("cpsie i" : : : "memory"); +} + + +/** + \brief Disable IRQ Interrupts + \details Disables IRQ interrupts by setting the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __disable_irq(void) +{ + __ASM volatile ("cpsid i" : : : "memory"); +} + + +/** + \brief Get Control Register + \details Returns the content of the Control Register. + \return Control Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CONTROL(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Control Register (non-secure) + \details Returns the content of the non-secure Control Register when in secure mode. + \return non-secure Control Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_CONTROL_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Control Register + \details Writes the given value to the Control Register. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __set_CONTROL(uint32_t control) +{ + __ASM volatile ("MSR control, %0" : : "r" (control) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Control Register (non-secure) + \details Writes the given value to the non-secure Control Register when in secure state. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) +{ + __ASM volatile ("MSR control_ns, %0" : : "r" (control) : "memory"); +} +#endif + + +/** + \brief Get IPSR Register + \details Returns the content of the IPSR Register. + \return IPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_IPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, ipsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get APSR Register + \details Returns the content of the APSR Register. + \return APSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_APSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, apsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get xPSR Register + \details Returns the content of the xPSR Register. + \return xPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_xPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, xpsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get Process Stack Pointer + \details Returns the current value of the Process Stack Pointer (PSP). + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer (non-secure) + \details Returns the current value of the non-secure Process Stack Pointer (PSP) when in secure state. + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Process Stack Pointer + \details Assigns the given value to the Process Stack Pointer (PSP). + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_PSP(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp, %0" : : "r" (topOfProcStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Process Stack Pointer (PSP) when in secure state. + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSP_NS(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp_ns, %0" : : "r" (topOfProcStack) : ); +} +#endif + + +/** + \brief Get Main Stack Pointer + \details Returns the current value of the Main Stack Pointer (MSP). + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer (non-secure) + \details Returns the current value of the non-secure Main Stack Pointer (MSP) when in secure state. + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Main Stack Pointer + \details Assigns the given value to the Main Stack Pointer (MSP). + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_MSP(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp, %0" : : "r" (topOfMainStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Main Stack Pointer (MSP) when in secure state. + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSP_NS(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp_ns, %0" : : "r" (topOfMainStack) : ); +} +#endif + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Stack Pointer (non-secure) + \details Returns the current value of the non-secure Stack Pointer (SP) when in secure state. + \return SP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_SP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, sp_ns" : "=r" (result) ); + return(result); +} + + +/** + \brief Set Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Stack Pointer (SP) when in secure state. + \param [in] topOfStack Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_SP_NS(uint32_t topOfStack) +{ + __ASM volatile ("MSR sp_ns, %0" : : "r" (topOfStack) : ); +} +#endif + + +/** + \brief Get Priority Mask + \details Returns the current state of the priority mask bit from the Priority Mask Register. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __get_PRIMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory"); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Priority Mask (non-secure) + \details Returns the current state of the non-secure priority mask bit from the Priority Mask Register when in secure state. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PRIMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask_ns" : "=r" (result) :: "memory"); + return(result); +} +#endif + + +/** + \brief Set Priority Mask + \details Assigns the given value to the Priority Mask Register. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __set_PRIMASK(uint32_t priMask) +{ + __ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Priority Mask (non-secure) + \details Assigns the given value to the non-secure Priority Mask Register when in secure state. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __TZ_set_PRIMASK_NS(uint32_t priMask) +{ + __ASM volatile ("MSR primask_ns, %0" : : "r" (priMask) : "memory"); +} +#endif + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) +/** + \brief Enable FIQ + \details Enables FIQ interrupts by clearing the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __enable_fault_irq(void) +{ + __ASM volatile ("cpsie f" : : : "memory"); +} + + +/** + \brief Disable FIQ + \details Disables FIQ interrupts by setting the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __disable_fault_irq(void) +{ + __ASM volatile ("cpsid f" : : : "memory"); +} + + +/** + \brief Get Base Priority + \details Returns the current value of the Base Priority register. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __get_BASEPRI(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Base Priority (non-secure) + \details Returns the current value of the non-secure Base Priority register when in secure state. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_BASEPRI_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Base Priority + \details Assigns the given value to the Base Priority register. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI(uint32_t basePri) +{ + __ASM volatile ("MSR basepri, %0" : : "r" (basePri) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Base Priority (non-secure) + \details Assigns the given value to the non-secure Base Priority register when in secure state. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __TZ_set_BASEPRI_NS(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_ns, %0" : : "r" (basePri) : "memory"); +} +#endif + + +/** + \brief Set Base Priority with condition + \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, + or the new value increases the BASEPRI priority level. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI_MAX(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_max, %0" : : "r" (basePri) : "memory"); +} + + +/** + \brief Get Fault Mask + \details Returns the current value of the Fault Mask register. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __get_FAULTMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Fault Mask (non-secure) + \details Returns the current value of the non-secure Fault Mask register when in secure state. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_FAULTMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Fault Mask + \details Assigns the given value to the Fault Mask register. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __set_FAULTMASK(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask, %0" : : "r" (faultMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Fault Mask (non-secure) + \details Assigns the given value to the non-secure Fault Mask register when in secure state. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __TZ_set_FAULTMASK_NS(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask_ns, %0" : : "r" (faultMask) : "memory"); +} +#endif + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + +/** + \brief Get Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the Process Stack Pointer Limit (PSPLIM). + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim" : "=r" (result) ); + return result; +#endif +} + +#if (defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the Process Stack Pointer Limit (PSPLIM). + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_PSPLIM(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim, %0" : : "r" (ProcStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSPLIM_NS(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim_ns, %0\n" : : "r" (ProcStackPtrLimit)); +#endif +} +#endif + + +/** + \brief Get Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the Main Stack Pointer Limit (MSPLIM). + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim" : "=r" (result) ); + return result; +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the non-secure Main Stack Pointer Limit(MSPLIM) when in secure state. + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the Main Stack Pointer Limit (MSPLIM). + \param [in] MainStackPtrLimit Main Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_MSPLIM(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim, %0" : : "r" (MainStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the non-secure Main Stack Pointer Limit (MSPLIM) when in secure state. + \param [in] MainStackPtrLimit Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSPLIM_NS(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim_ns, %0" : : "r" (MainStackPtrLimit)); +#endif +} +#endif + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value + */ +__STATIC_FORCEINLINE uint32_t __get_FPSCR(void) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#if __has_builtin(__builtin_arm_get_fpscr) +// Re-enable using built-in when GCC has been fixed +// || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2) + /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */ + return __builtin_arm_get_fpscr(); +#else + uint32_t result; + + __ASM volatile ("VMRS %0, fpscr" : "=r" (result) ); + return(result); +#endif +#else + return(0U); +#endif +} + + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set + */ +__STATIC_FORCEINLINE void __set_FPSCR(uint32_t fpscr) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#if __has_builtin(__builtin_arm_set_fpscr) +// Re-enable using built-in when GCC has been fixed +// || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2) + /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */ + __builtin_arm_set_fpscr(fpscr); +#else + __ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc", "memory"); +#endif +#else + (void)fpscr; +#endif +} + + +/*@} end of CMSIS_Core_RegAccFunctions */ + + +/* ########################## Core Instruction Access ######################### */ +/** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface + Access to dedicated instructions + @{ +*/ + +/* Define macros for porting to both thumb1 and thumb2. + * For thumb1, use low register (r0-r7), specified by constraint "l" + * Otherwise, use general registers, specified by constraint "r" */ +#if defined (__thumb__) && !defined (__thumb2__) +#define __CMSIS_GCC_OUT_REG(r) "=l" (r) +#define __CMSIS_GCC_RW_REG(r) "+l" (r) +#define __CMSIS_GCC_USE_REG(r) "l" (r) +#else +#define __CMSIS_GCC_OUT_REG(r) "=r" (r) +#define __CMSIS_GCC_RW_REG(r) "+r" (r) +#define __CMSIS_GCC_USE_REG(r) "r" (r) +#endif + +/** + \brief No Operation + \details No Operation does nothing. This instruction can be used for code alignment purposes. + */ +#define __NOP() __ASM volatile ("nop") + +/** + \brief Wait For Interrupt + \details Wait For Interrupt is a hint instruction that suspends execution until one of a number of events occurs. + */ +#define __WFI() __ASM volatile ("wfi") + + +/** + \brief Wait For Event + \details Wait For Event is a hint instruction that permits the processor to enter + a low-power state until one of a number of events occurs. + */ +#define __WFE() __ASM volatile ("wfe") + + +/** + \brief Send Event + \details Send Event is a hint instruction. It causes an event to be signaled to the CPU. + */ +#define __SEV() __ASM volatile ("sev") + + +/** + \brief Instruction Synchronization Barrier + \details Instruction Synchronization Barrier flushes the pipeline in the processor, + so that all instructions following the ISB are fetched from cache or memory, + after the instruction has been completed. + */ +__STATIC_FORCEINLINE void __ISB(void) +{ + __ASM volatile ("isb 0xF":::"memory"); +} + + +/** + \brief Data Synchronization Barrier + \details Acts as a special kind of Data Memory Barrier. + It completes when all explicit memory accesses before this instruction complete. + */ +__STATIC_FORCEINLINE void __DSB(void) +{ + __ASM volatile ("dsb 0xF":::"memory"); +} + + +/** + \brief Data Memory Barrier + \details Ensures the apparent order of the explicit memory operations before + and after the instruction, without ensuring their completion. + */ +__STATIC_FORCEINLINE void __DMB(void) +{ + __ASM volatile ("dmb 0xF":::"memory"); +} + + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __REV(uint32_t value) +{ +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5) + return __builtin_bswap32(value); +#else + uint32_t result; + + __ASM volatile ("rev %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +#endif +} + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __REV16(uint32_t value) +{ + uint32_t result; + + __ASM volatile ("rev16 %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +} + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE int16_t __REVSH(int16_t value) +{ +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + return (int16_t)__builtin_bswap16(value); +#else + int16_t result; + + __ASM volatile ("revsh %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +#endif +} + + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __ROR(uint32_t op1, uint32_t op2) +{ + op2 %= 32U; + if (op2 == 0U) + { + return op1; + } + return (op1 >> op2) | (op1 << (32U - op2)); +} + + +/** + \brief Breakpoint + \details Causes the processor to enter Debug state. + Debug tools can use this to investigate system state when the instruction at a particular address is reached. + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __ASM volatile ("bkpt "#value) + + +/** + \brief Reverse bit order of value + \details Reverses the bit order of the given value. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __RBIT(uint32_t value) +{ + uint32_t result; + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) + __ASM volatile ("rbit %0, %1" : "=r" (result) : "r" (value) ); +#else + uint32_t s = (4U /*sizeof(v)*/ * 8U) - 1U; /* extra shift needed at end */ + + result = value; /* r will be reversed bits of v; first get LSB of v */ + for (value >>= 1U; value != 0U; value >>= 1U) + { + result <<= 1U; + result |= value & 1U; + s--; + } + result <<= s; /* shift when v's highest bits are zero */ +#endif + return result; +} + + +/** + \brief Count leading zeros + \details Counts the number of leading zeros of a data value. + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ (uint8_t)__builtin_clz + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDREXB(volatile uint8_t *addr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrexb %0, %1" : "=r" (result) : "Q" (*addr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrexb %0, [%1]" : "=r" (result) : "r" (addr) : "memory" ); +#endif + return ((uint8_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDREXH(volatile uint16_t *addr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrexh %0, %1" : "=r" (result) : "Q" (*addr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrexh %0, [%1]" : "=r" (result) : "r" (addr) : "memory" ); +#endif + return ((uint16_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDREXW(volatile uint32_t *addr) +{ + uint32_t result; + + __ASM volatile ("ldrex %0, %1" : "=r" (result) : "Q" (*addr) ); + return(result); +} + + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXB(uint8_t value, volatile uint8_t *addr) +{ + uint32_t result; + + __ASM volatile ("strexb %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXH(uint16_t value, volatile uint16_t *addr) +{ + uint32_t result; + + __ASM volatile ("strexh %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXW(uint32_t value, volatile uint32_t *addr) +{ + uint32_t result; + + __ASM volatile ("strex %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" (value) ); + return(result); +} + + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +__STATIC_FORCEINLINE void __CLREX(void) +{ + __ASM volatile ("clrex" ::: "memory"); +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] ARG1 Value to be saturated + \param [in] ARG2 Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT(ARG1,ARG2) \ +__extension__ \ +({ \ + int32_t __RES, __ARG1 = (ARG1); \ + __ASM ("ssat %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] ARG1 Value to be saturated + \param [in] ARG2 Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT(ARG1,ARG2) \ + __extension__ \ +({ \ + uint32_t __RES, __ARG1 = (ARG1); \ + __ASM ("usat %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + + +/** + \brief Rotate Right with Extend (32 bit) + \details Moves each bit of a bitstring right by one bit. + The carry input is shifted in at the left end of the bitstring. + \param [in] value Value to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __RRX(uint32_t value) +{ + uint32_t result; + + __ASM volatile ("rrx %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return(result); +} + + +/** + \brief LDRT Unprivileged (8 bit) + \details Executes a Unprivileged LDRT instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDRBT(volatile uint8_t *ptr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrbt %0, %1" : "=r" (result) : "Q" (*ptr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrbt %0, [%1]" : "=r" (result) : "r" (ptr) : "memory" ); +#endif + return ((uint8_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (16 bit) + \details Executes a Unprivileged LDRT instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDRHT(volatile uint16_t *ptr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrht %0, %1" : "=r" (result) : "Q" (*ptr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrht %0, [%1]" : "=r" (result) : "r" (ptr) : "memory" ); +#endif + return ((uint16_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (32 bit) + \details Executes a Unprivileged LDRT instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDRT(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrt %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief STRT Unprivileged (8 bit) + \details Executes a Unprivileged STRT instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRBT(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("strbt %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (16 bit) + \details Executes a Unprivileged STRT instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRHT(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("strht %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (32 bit) + \details Executes a Unprivileged STRT instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRT(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("strt %1, %0" : "=Q" (*ptr) : "r" (value) ); +} + +#else /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +__STATIC_FORCEINLINE int32_t __SSAT(int32_t val, uint32_t sat) +{ + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; +} + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +__STATIC_FORCEINLINE uint32_t __USAT(int32_t val, uint32_t sat) +{ + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief Load-Acquire (8 bit) + \details Executes a LDAB instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDAB(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldab %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); +} + + +/** + \brief Load-Acquire (16 bit) + \details Executes a LDAH instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDAH(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldah %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); +} + + +/** + \brief Load-Acquire (32 bit) + \details Executes a LDA instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDA(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("lda %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief Store-Release (8 bit) + \details Executes a STLB instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLB(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("stlb %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (16 bit) + \details Executes a STLH instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLH(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("stlh %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (32 bit) + \details Executes a STL instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STL(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("stl %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Load-Acquire Exclusive (8 bit) + \details Executes a LDAB exclusive instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDAEXB(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldaexb %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); +} + + +/** + \brief Load-Acquire Exclusive (16 bit) + \details Executes a LDAH exclusive instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDAEXH(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldaexh %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); +} + + +/** + \brief Load-Acquire Exclusive (32 bit) + \details Executes a LDA exclusive instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDAEX(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldaex %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief Store-Release Exclusive (8 bit) + \details Executes a STLB exclusive instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STLEXB(uint8_t value, volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("stlexb %0, %2, %1" : "=&r" (result), "=Q" (*ptr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief Store-Release Exclusive (16 bit) + \details Executes a STLH exclusive instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STLEXH(uint16_t value, volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("stlexh %0, %2, %1" : "=&r" (result), "=Q" (*ptr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief Store-Release Exclusive (32 bit) + \details Executes a STL exclusive instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STLEX(uint32_t value, volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("stlex %0, %2, %1" : "=&r" (result), "=Q" (*ptr) : "r" ((uint32_t)value) ); + return(result); +} + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + +/*@}*/ /* end of group CMSIS_Core_InstructionInterface */ + + +/* ################### Compiler specific Intrinsics ########################### */ +/** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics + Access to dedicated SIMD instructions + @{ +*/ + +#if (defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1)) + +__STATIC_FORCEINLINE uint32_t __SADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usad8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USADA8(uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("usada8 %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#define __SSAT16(ARG1,ARG2) \ +({ \ + int32_t __RES, __ARG1 = (ARG1); \ + __ASM ("ssat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +#define __USAT16(ARG1,ARG2) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1); \ + __ASM ("usat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +__STATIC_FORCEINLINE uint32_t __UXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("uxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("sxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUAD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuad %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUADX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuadx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLAD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlad %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLADX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smladx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLALD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLALDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SMUSD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUSDX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusdx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsd %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSDX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsdx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SEL (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sel %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QADD( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qadd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QSUB( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qsub %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +#if 0 +#define __PKHBT(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + __ASM ("pkhbt %0, %1, %2, lsl %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) + +#define __PKHTB(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + if (ARG3 == 0) \ + __ASM ("pkhtb %0, %1, %2" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2) ); \ + else \ + __ASM ("pkhtb %0, %1, %2, asr %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) +#endif + +#define __PKHBT(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0x0000FFFFUL) | \ + ((((uint32_t)(ARG2)) << (ARG3)) & 0xFFFF0000UL) ) + +#define __PKHTB(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0xFFFF0000UL) | \ + ((((uint32_t)(ARG2)) >> (ARG3)) & 0x0000FFFFUL) ) + +__STATIC_FORCEINLINE int32_t __SMMLA (int32_t op1, int32_t op2, int32_t op3) +{ + int32_t result; + + __ASM volatile ("smmla %0, %1, %2, %3" : "=r" (result): "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#endif /* (__ARM_FEATURE_DSP == 1) */ +/*@} end of group CMSIS_SIMD_intrinsics */ + + +#pragma GCC diagnostic pop + +#endif /* __CMSIS_GCC_H */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_iccarm.h b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_iccarm.h new file mode 100644 index 0000000..3c90a2c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_iccarm.h @@ -0,0 +1,935 @@ +/**************************************************************************//** + * @file cmsis_iccarm.h + * @brief CMSIS compiler ICCARM (IAR Compiler for Arm) header file + * @version V5.0.7 + * @date 19. June 2018 + ******************************************************************************/ + +//------------------------------------------------------------------------------ +// +// Copyright (c) 2017-2018 IAR Systems +// +// Licensed under the Apache License, Version 2.0 (the "License") +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +//------------------------------------------------------------------------------ + + +#ifndef __CMSIS_ICCARM_H__ +#define __CMSIS_ICCARM_H__ + +#ifndef __ICCARM__ + #error This file should only be compiled by ICCARM +#endif + +#pragma system_include + +#define __IAR_FT _Pragma("inline=forced") __intrinsic + +#if (__VER__ >= 8000000) + #define __ICCARM_V8 1 +#else + #define __ICCARM_V8 0 +#endif + +#ifndef __ALIGNED + #if __ICCARM_V8 + #define __ALIGNED(x) __attribute__((aligned(x))) + #elif (__VER__ >= 7080000) + /* Needs IAR language extensions */ + #define __ALIGNED(x) __attribute__((aligned(x))) + #else + #warning No compiler specific solution for __ALIGNED.__ALIGNED is ignored. + #define __ALIGNED(x) + #endif +#endif + + +/* Define compiler macros for CPU architecture, used in CMSIS 5. + */ +#if __ARM_ARCH_6M__ || __ARM_ARCH_7M__ || __ARM_ARCH_7EM__ || __ARM_ARCH_8M_BASE__ || __ARM_ARCH_8M_MAIN__ +/* Macros already defined */ +#else + #if defined(__ARM8M_MAINLINE__) || defined(__ARM8EM_MAINLINE__) + #define __ARM_ARCH_8M_MAIN__ 1 + #elif defined(__ARM8M_BASELINE__) + #define __ARM_ARCH_8M_BASE__ 1 + #elif defined(__ARM_ARCH_PROFILE) && __ARM_ARCH_PROFILE == 'M' + #if __ARM_ARCH == 6 + #define __ARM_ARCH_6M__ 1 + #elif __ARM_ARCH == 7 + #if __ARM_FEATURE_DSP + #define __ARM_ARCH_7EM__ 1 + #else + #define __ARM_ARCH_7M__ 1 + #endif + #endif /* __ARM_ARCH */ + #endif /* __ARM_ARCH_PROFILE == 'M' */ +#endif + +/* Alternativ core deduction for older ICCARM's */ +#if !defined(__ARM_ARCH_6M__) && !defined(__ARM_ARCH_7M__) && !defined(__ARM_ARCH_7EM__) && \ + !defined(__ARM_ARCH_8M_BASE__) && !defined(__ARM_ARCH_8M_MAIN__) + #if defined(__ARM6M__) && (__CORE__ == __ARM6M__) + #define __ARM_ARCH_6M__ 1 + #elif defined(__ARM7M__) && (__CORE__ == __ARM7M__) + #define __ARM_ARCH_7M__ 1 + #elif defined(__ARM7EM__) && (__CORE__ == __ARM7EM__) + #define __ARM_ARCH_7EM__ 1 + #elif defined(__ARM8M_BASELINE__) && (__CORE == __ARM8M_BASELINE__) + #define __ARM_ARCH_8M_BASE__ 1 + #elif defined(__ARM8M_MAINLINE__) && (__CORE == __ARM8M_MAINLINE__) + #define __ARM_ARCH_8M_MAIN__ 1 + #elif defined(__ARM8EM_MAINLINE__) && (__CORE == __ARM8EM_MAINLINE__) + #define __ARM_ARCH_8M_MAIN__ 1 + #else + #error "Unknown target." + #endif +#endif + + + +#if defined(__ARM_ARCH_6M__) && __ARM_ARCH_6M__==1 + #define __IAR_M0_FAMILY 1 +#elif defined(__ARM_ARCH_8M_BASE__) && __ARM_ARCH_8M_BASE__==1 + #define __IAR_M0_FAMILY 1 +#else + #define __IAR_M0_FAMILY 0 +#endif + + +#ifndef __ASM + #define __ASM __asm +#endif + +#ifndef __INLINE + #define __INLINE inline +#endif + +#ifndef __NO_RETURN + #if __ICCARM_V8 + #define __NO_RETURN __attribute__((__noreturn__)) + #else + #define __NO_RETURN _Pragma("object_attribute=__noreturn") + #endif +#endif + +#ifndef __PACKED + #if __ICCARM_V8 + #define __PACKED __attribute__((packed, aligned(1))) + #else + /* Needs IAR language extensions */ + #define __PACKED __packed + #endif +#endif + +#ifndef __PACKED_STRUCT + #if __ICCARM_V8 + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) + #else + /* Needs IAR language extensions */ + #define __PACKED_STRUCT __packed struct + #endif +#endif + +#ifndef __PACKED_UNION + #if __ICCARM_V8 + #define __PACKED_UNION union __attribute__((packed, aligned(1))) + #else + /* Needs IAR language extensions */ + #define __PACKED_UNION __packed union + #endif +#endif + +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline +#endif + +#ifndef __FORCEINLINE + #define __FORCEINLINE _Pragma("inline=forced") +#endif + +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __FORCEINLINE __STATIC_INLINE +#endif + +#ifndef __UNALIGNED_UINT16_READ +#pragma language=save +#pragma language=extended +__IAR_FT uint16_t __iar_uint16_read(void const *ptr) +{ + return *(__packed uint16_t*)(ptr); +} +#pragma language=restore +#define __UNALIGNED_UINT16_READ(PTR) __iar_uint16_read(PTR) +#endif + + +#ifndef __UNALIGNED_UINT16_WRITE +#pragma language=save +#pragma language=extended +__IAR_FT void __iar_uint16_write(void const *ptr, uint16_t val) +{ + *(__packed uint16_t*)(ptr) = val;; +} +#pragma language=restore +#define __UNALIGNED_UINT16_WRITE(PTR,VAL) __iar_uint16_write(PTR,VAL) +#endif + +#ifndef __UNALIGNED_UINT32_READ +#pragma language=save +#pragma language=extended +__IAR_FT uint32_t __iar_uint32_read(void const *ptr) +{ + return *(__packed uint32_t*)(ptr); +} +#pragma language=restore +#define __UNALIGNED_UINT32_READ(PTR) __iar_uint32_read(PTR) +#endif + +#ifndef __UNALIGNED_UINT32_WRITE +#pragma language=save +#pragma language=extended +__IAR_FT void __iar_uint32_write(void const *ptr, uint32_t val) +{ + *(__packed uint32_t*)(ptr) = val;; +} +#pragma language=restore +#define __UNALIGNED_UINT32_WRITE(PTR,VAL) __iar_uint32_write(PTR,VAL) +#endif + +#ifndef __UNALIGNED_UINT32 /* deprecated */ +#pragma language=save +#pragma language=extended +__packed struct __iar_u32 { uint32_t v; }; +#pragma language=restore +#define __UNALIGNED_UINT32(PTR) (((struct __iar_u32 *)(PTR))->v) +#endif + +#ifndef __USED + #if __ICCARM_V8 + #define __USED __attribute__((used)) + #else + #define __USED _Pragma("__root") + #endif +#endif + +#ifndef __WEAK + #if __ICCARM_V8 + #define __WEAK __attribute__((weak)) + #else + #define __WEAK _Pragma("__weak") + #endif +#endif + + +#ifndef __ICCARM_INTRINSICS_VERSION__ + #define __ICCARM_INTRINSICS_VERSION__ 0 +#endif + +#if __ICCARM_INTRINSICS_VERSION__ == 2 + + #if defined(__CLZ) + #undef __CLZ + #endif + #if defined(__REVSH) + #undef __REVSH + #endif + #if defined(__RBIT) + #undef __RBIT + #endif + #if defined(__SSAT) + #undef __SSAT + #endif + #if defined(__USAT) + #undef __USAT + #endif + + #include "iccarm_builtin.h" + + #define __disable_fault_irq __iar_builtin_disable_fiq + #define __disable_irq __iar_builtin_disable_interrupt + #define __enable_fault_irq __iar_builtin_enable_fiq + #define __enable_irq __iar_builtin_enable_interrupt + #define __arm_rsr __iar_builtin_rsr + #define __arm_wsr __iar_builtin_wsr + + + #define __get_APSR() (__arm_rsr("APSR")) + #define __get_BASEPRI() (__arm_rsr("BASEPRI")) + #define __get_CONTROL() (__arm_rsr("CONTROL")) + #define __get_FAULTMASK() (__arm_rsr("FAULTMASK")) + + #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + #define __get_FPSCR() (__arm_rsr("FPSCR")) + #define __set_FPSCR(VALUE) (__arm_wsr("FPSCR", (VALUE))) + #else + #define __get_FPSCR() ( 0 ) + #define __set_FPSCR(VALUE) ((void)VALUE) + #endif + + #define __get_IPSR() (__arm_rsr("IPSR")) + #define __get_MSP() (__arm_rsr("MSP")) + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + #define __get_MSPLIM() (0U) + #else + #define __get_MSPLIM() (__arm_rsr("MSPLIM")) + #endif + #define __get_PRIMASK() (__arm_rsr("PRIMASK")) + #define __get_PSP() (__arm_rsr("PSP")) + + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + #define __get_PSPLIM() (0U) + #else + #define __get_PSPLIM() (__arm_rsr("PSPLIM")) + #endif + + #define __get_xPSR() (__arm_rsr("xPSR")) + + #define __set_BASEPRI(VALUE) (__arm_wsr("BASEPRI", (VALUE))) + #define __set_BASEPRI_MAX(VALUE) (__arm_wsr("BASEPRI_MAX", (VALUE))) + #define __set_CONTROL(VALUE) (__arm_wsr("CONTROL", (VALUE))) + #define __set_FAULTMASK(VALUE) (__arm_wsr("FAULTMASK", (VALUE))) + #define __set_MSP(VALUE) (__arm_wsr("MSP", (VALUE))) + + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + #define __set_MSPLIM(VALUE) ((void)(VALUE)) + #else + #define __set_MSPLIM(VALUE) (__arm_wsr("MSPLIM", (VALUE))) + #endif + #define __set_PRIMASK(VALUE) (__arm_wsr("PRIMASK", (VALUE))) + #define __set_PSP(VALUE) (__arm_wsr("PSP", (VALUE))) + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + #define __set_PSPLIM(VALUE) ((void)(VALUE)) + #else + #define __set_PSPLIM(VALUE) (__arm_wsr("PSPLIM", (VALUE))) + #endif + + #define __TZ_get_CONTROL_NS() (__arm_rsr("CONTROL_NS")) + #define __TZ_set_CONTROL_NS(VALUE) (__arm_wsr("CONTROL_NS", (VALUE))) + #define __TZ_get_PSP_NS() (__arm_rsr("PSP_NS")) + #define __TZ_set_PSP_NS(VALUE) (__arm_wsr("PSP_NS", (VALUE))) + #define __TZ_get_MSP_NS() (__arm_rsr("MSP_NS")) + #define __TZ_set_MSP_NS(VALUE) (__arm_wsr("MSP_NS", (VALUE))) + #define __TZ_get_SP_NS() (__arm_rsr("SP_NS")) + #define __TZ_set_SP_NS(VALUE) (__arm_wsr("SP_NS", (VALUE))) + #define __TZ_get_PRIMASK_NS() (__arm_rsr("PRIMASK_NS")) + #define __TZ_set_PRIMASK_NS(VALUE) (__arm_wsr("PRIMASK_NS", (VALUE))) + #define __TZ_get_BASEPRI_NS() (__arm_rsr("BASEPRI_NS")) + #define __TZ_set_BASEPRI_NS(VALUE) (__arm_wsr("BASEPRI_NS", (VALUE))) + #define __TZ_get_FAULTMASK_NS() (__arm_rsr("FAULTMASK_NS")) + #define __TZ_set_FAULTMASK_NS(VALUE)(__arm_wsr("FAULTMASK_NS", (VALUE))) + + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + #define __TZ_get_PSPLIM_NS() (0U) + #define __TZ_set_PSPLIM_NS(VALUE) ((void)(VALUE)) + #else + #define __TZ_get_PSPLIM_NS() (__arm_rsr("PSPLIM_NS")) + #define __TZ_set_PSPLIM_NS(VALUE) (__arm_wsr("PSPLIM_NS", (VALUE))) + #endif + + #define __TZ_get_MSPLIM_NS() (__arm_rsr("MSPLIM_NS")) + #define __TZ_set_MSPLIM_NS(VALUE) (__arm_wsr("MSPLIM_NS", (VALUE))) + + #define __NOP __iar_builtin_no_operation + + #define __CLZ __iar_builtin_CLZ + #define __CLREX __iar_builtin_CLREX + + #define __DMB __iar_builtin_DMB + #define __DSB __iar_builtin_DSB + #define __ISB __iar_builtin_ISB + + #define __LDREXB __iar_builtin_LDREXB + #define __LDREXH __iar_builtin_LDREXH + #define __LDREXW __iar_builtin_LDREX + + #define __RBIT __iar_builtin_RBIT + #define __REV __iar_builtin_REV + #define __REV16 __iar_builtin_REV16 + + __IAR_FT int16_t __REVSH(int16_t val) + { + return (int16_t) __iar_builtin_REVSH(val); + } + + #define __ROR __iar_builtin_ROR + #define __RRX __iar_builtin_RRX + + #define __SEV __iar_builtin_SEV + + #if !__IAR_M0_FAMILY + #define __SSAT __iar_builtin_SSAT + #endif + + #define __STREXB __iar_builtin_STREXB + #define __STREXH __iar_builtin_STREXH + #define __STREXW __iar_builtin_STREX + + #if !__IAR_M0_FAMILY + #define __USAT __iar_builtin_USAT + #endif + + #define __WFE __iar_builtin_WFE + #define __WFI __iar_builtin_WFI + + #if __ARM_MEDIA__ + #define __SADD8 __iar_builtin_SADD8 + #define __QADD8 __iar_builtin_QADD8 + #define __SHADD8 __iar_builtin_SHADD8 + #define __UADD8 __iar_builtin_UADD8 + #define __UQADD8 __iar_builtin_UQADD8 + #define __UHADD8 __iar_builtin_UHADD8 + #define __SSUB8 __iar_builtin_SSUB8 + #define __QSUB8 __iar_builtin_QSUB8 + #define __SHSUB8 __iar_builtin_SHSUB8 + #define __USUB8 __iar_builtin_USUB8 + #define __UQSUB8 __iar_builtin_UQSUB8 + #define __UHSUB8 __iar_builtin_UHSUB8 + #define __SADD16 __iar_builtin_SADD16 + #define __QADD16 __iar_builtin_QADD16 + #define __SHADD16 __iar_builtin_SHADD16 + #define __UADD16 __iar_builtin_UADD16 + #define __UQADD16 __iar_builtin_UQADD16 + #define __UHADD16 __iar_builtin_UHADD16 + #define __SSUB16 __iar_builtin_SSUB16 + #define __QSUB16 __iar_builtin_QSUB16 + #define __SHSUB16 __iar_builtin_SHSUB16 + #define __USUB16 __iar_builtin_USUB16 + #define __UQSUB16 __iar_builtin_UQSUB16 + #define __UHSUB16 __iar_builtin_UHSUB16 + #define __SASX __iar_builtin_SASX + #define __QASX __iar_builtin_QASX + #define __SHASX __iar_builtin_SHASX + #define __UASX __iar_builtin_UASX + #define __UQASX __iar_builtin_UQASX + #define __UHASX __iar_builtin_UHASX + #define __SSAX __iar_builtin_SSAX + #define __QSAX __iar_builtin_QSAX + #define __SHSAX __iar_builtin_SHSAX + #define __USAX __iar_builtin_USAX + #define __UQSAX __iar_builtin_UQSAX + #define __UHSAX __iar_builtin_UHSAX + #define __USAD8 __iar_builtin_USAD8 + #define __USADA8 __iar_builtin_USADA8 + #define __SSAT16 __iar_builtin_SSAT16 + #define __USAT16 __iar_builtin_USAT16 + #define __UXTB16 __iar_builtin_UXTB16 + #define __UXTAB16 __iar_builtin_UXTAB16 + #define __SXTB16 __iar_builtin_SXTB16 + #define __SXTAB16 __iar_builtin_SXTAB16 + #define __SMUAD __iar_builtin_SMUAD + #define __SMUADX __iar_builtin_SMUADX + #define __SMMLA __iar_builtin_SMMLA + #define __SMLAD __iar_builtin_SMLAD + #define __SMLADX __iar_builtin_SMLADX + #define __SMLALD __iar_builtin_SMLALD + #define __SMLALDX __iar_builtin_SMLALDX + #define __SMUSD __iar_builtin_SMUSD + #define __SMUSDX __iar_builtin_SMUSDX + #define __SMLSD __iar_builtin_SMLSD + #define __SMLSDX __iar_builtin_SMLSDX + #define __SMLSLD __iar_builtin_SMLSLD + #define __SMLSLDX __iar_builtin_SMLSLDX + #define __SEL __iar_builtin_SEL + #define __QADD __iar_builtin_QADD + #define __QSUB __iar_builtin_QSUB + #define __PKHBT __iar_builtin_PKHBT + #define __PKHTB __iar_builtin_PKHTB + #endif + +#else /* __ICCARM_INTRINSICS_VERSION__ == 2 */ + + #if __IAR_M0_FAMILY + /* Avoid clash between intrinsics.h and arm_math.h when compiling for Cortex-M0. */ + #define __CLZ __cmsis_iar_clz_not_active + #define __SSAT __cmsis_iar_ssat_not_active + #define __USAT __cmsis_iar_usat_not_active + #define __RBIT __cmsis_iar_rbit_not_active + #define __get_APSR __cmsis_iar_get_APSR_not_active + #endif + + + #if (!((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) )) + #define __get_FPSCR __cmsis_iar_get_FPSR_not_active + #define __set_FPSCR __cmsis_iar_set_FPSR_not_active + #endif + + #ifdef __INTRINSICS_INCLUDED + #error intrinsics.h is already included previously! + #endif + + #include + + #if __IAR_M0_FAMILY + /* Avoid clash between intrinsics.h and arm_math.h when compiling for Cortex-M0. */ + #undef __CLZ + #undef __SSAT + #undef __USAT + #undef __RBIT + #undef __get_APSR + + __STATIC_INLINE uint8_t __CLZ(uint32_t data) + { + if (data == 0U) { return 32U; } + + uint32_t count = 0U; + uint32_t mask = 0x80000000U; + + while ((data & mask) == 0U) + { + count += 1U; + mask = mask >> 1U; + } + return count; + } + + __STATIC_INLINE uint32_t __RBIT(uint32_t v) + { + uint8_t sc = 31U; + uint32_t r = v; + for (v >>= 1U; v; v >>= 1U) + { + r <<= 1U; + r |= v & 1U; + sc--; + } + return (r << sc); + } + + __STATIC_INLINE uint32_t __get_APSR(void) + { + uint32_t res; + __asm("MRS %0,APSR" : "=r" (res)); + return res; + } + + #endif + + #if (!((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) )) + #undef __get_FPSCR + #undef __set_FPSCR + #define __get_FPSCR() (0) + #define __set_FPSCR(VALUE) ((void)VALUE) + #endif + + #pragma diag_suppress=Pe940 + #pragma diag_suppress=Pe177 + + #define __enable_irq __enable_interrupt + #define __disable_irq __disable_interrupt + #define __NOP __no_operation + + #define __get_xPSR __get_PSR + + #if (!defined(__ARM_ARCH_6M__) || __ARM_ARCH_6M__==0) + + __IAR_FT uint32_t __LDREXW(uint32_t volatile *ptr) + { + return __LDREX((unsigned long *)ptr); + } + + __IAR_FT uint32_t __STREXW(uint32_t value, uint32_t volatile *ptr) + { + return __STREX(value, (unsigned long *)ptr); + } + #endif + + + /* __CORTEX_M is defined in core_cm0.h, core_cm3.h and core_cm4.h. */ + #if (__CORTEX_M >= 0x03) + + __IAR_FT uint32_t __RRX(uint32_t value) + { + uint32_t result; + __ASM("RRX %0, %1" : "=r"(result) : "r" (value) : "cc"); + return(result); + } + + __IAR_FT void __set_BASEPRI_MAX(uint32_t value) + { + __asm volatile("MSR BASEPRI_MAX,%0"::"r" (value)); + } + + + #define __enable_fault_irq __enable_fiq + #define __disable_fault_irq __disable_fiq + + + #endif /* (__CORTEX_M >= 0x03) */ + + __IAR_FT uint32_t __ROR(uint32_t op1, uint32_t op2) + { + return (op1 >> op2) | (op1 << ((sizeof(op1)*8)-op2)); + } + + #if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + + __IAR_FT uint32_t __get_MSPLIM(void) + { + uint32_t res; + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + res = 0U; + #else + __asm volatile("MRS %0,MSPLIM" : "=r" (res)); + #endif + return res; + } + + __IAR_FT void __set_MSPLIM(uint32_t value) + { + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)value; + #else + __asm volatile("MSR MSPLIM,%0" :: "r" (value)); + #endif + } + + __IAR_FT uint32_t __get_PSPLIM(void) + { + uint32_t res; + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + res = 0U; + #else + __asm volatile("MRS %0,PSPLIM" : "=r" (res)); + #endif + return res; + } + + __IAR_FT void __set_PSPLIM(uint32_t value) + { + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)value; + #else + __asm volatile("MSR PSPLIM,%0" :: "r" (value)); + #endif + } + + __IAR_FT uint32_t __TZ_get_CONTROL_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,CONTROL_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_CONTROL_NS(uint32_t value) + { + __asm volatile("MSR CONTROL_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_PSP_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,PSP_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_PSP_NS(uint32_t value) + { + __asm volatile("MSR PSP_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_MSP_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,MSP_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_MSP_NS(uint32_t value) + { + __asm volatile("MSR MSP_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_SP_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,SP_NS" : "=r" (res)); + return res; + } + __IAR_FT void __TZ_set_SP_NS(uint32_t value) + { + __asm volatile("MSR SP_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_PRIMASK_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,PRIMASK_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_PRIMASK_NS(uint32_t value) + { + __asm volatile("MSR PRIMASK_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_BASEPRI_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,BASEPRI_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_BASEPRI_NS(uint32_t value) + { + __asm volatile("MSR BASEPRI_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_FAULTMASK_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,FAULTMASK_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_FAULTMASK_NS(uint32_t value) + { + __asm volatile("MSR FAULTMASK_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_PSPLIM_NS(void) + { + uint32_t res; + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + res = 0U; + #else + __asm volatile("MRS %0,PSPLIM_NS" : "=r" (res)); + #endif + return res; + } + + __IAR_FT void __TZ_set_PSPLIM_NS(uint32_t value) + { + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)value; + #else + __asm volatile("MSR PSPLIM_NS,%0" :: "r" (value)); + #endif + } + + __IAR_FT uint32_t __TZ_get_MSPLIM_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,MSPLIM_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_MSPLIM_NS(uint32_t value) + { + __asm volatile("MSR MSPLIM_NS,%0" :: "r" (value)); + } + + #endif /* __ARM_ARCH_8M_MAIN__ or __ARM_ARCH_8M_BASE__ */ + +#endif /* __ICCARM_INTRINSICS_VERSION__ == 2 */ + +#define __BKPT(value) __asm volatile ("BKPT %0" : : "i"(value)) + +#if __IAR_M0_FAMILY + __STATIC_INLINE int32_t __SSAT(int32_t val, uint32_t sat) + { + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; + } + + __STATIC_INLINE uint32_t __USAT(int32_t val, uint32_t sat) + { + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; + } +#endif + +#if (__CORTEX_M >= 0x03) /* __CORTEX_M is defined in core_cm0.h, core_cm3.h and core_cm4.h. */ + + __IAR_FT uint8_t __LDRBT(volatile uint8_t *addr) + { + uint32_t res; + __ASM("LDRBT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); + return ((uint8_t)res); + } + + __IAR_FT uint16_t __LDRHT(volatile uint16_t *addr) + { + uint32_t res; + __ASM("LDRHT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); + return ((uint16_t)res); + } + + __IAR_FT uint32_t __LDRT(volatile uint32_t *addr) + { + uint32_t res; + __ASM("LDRT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); + return res; + } + + __IAR_FT void __STRBT(uint8_t value, volatile uint8_t *addr) + { + __ASM("STRBT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); + } + + __IAR_FT void __STRHT(uint16_t value, volatile uint16_t *addr) + { + __ASM("STRHT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); + } + + __IAR_FT void __STRT(uint32_t value, volatile uint32_t *addr) + { + __ASM("STRT %1, [%0]" : : "r" (addr), "r" (value) : "memory"); + } + +#endif /* (__CORTEX_M >= 0x03) */ + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + + + __IAR_FT uint8_t __LDAB(volatile uint8_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAB %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint8_t)res); + } + + __IAR_FT uint16_t __LDAH(volatile uint16_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAH %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint16_t)res); + } + + __IAR_FT uint32_t __LDA(volatile uint32_t *ptr) + { + uint32_t res; + __ASM volatile ("LDA %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return res; + } + + __IAR_FT void __STLB(uint8_t value, volatile uint8_t *ptr) + { + __ASM volatile ("STLB %1, [%0]" :: "r" (ptr), "r" (value) : "memory"); + } + + __IAR_FT void __STLH(uint16_t value, volatile uint16_t *ptr) + { + __ASM volatile ("STLH %1, [%0]" :: "r" (ptr), "r" (value) : "memory"); + } + + __IAR_FT void __STL(uint32_t value, volatile uint32_t *ptr) + { + __ASM volatile ("STL %1, [%0]" :: "r" (ptr), "r" (value) : "memory"); + } + + __IAR_FT uint8_t __LDAEXB(volatile uint8_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAEXB %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint8_t)res); + } + + __IAR_FT uint16_t __LDAEXH(volatile uint16_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAEXH %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint16_t)res); + } + + __IAR_FT uint32_t __LDAEX(volatile uint32_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAEX %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return res; + } + + __IAR_FT uint32_t __STLEXB(uint8_t value, volatile uint8_t *ptr) + { + uint32_t res; + __ASM volatile ("STLEXB %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory"); + return res; + } + + __IAR_FT uint32_t __STLEXH(uint16_t value, volatile uint16_t *ptr) + { + uint32_t res; + __ASM volatile ("STLEXH %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory"); + return res; + } + + __IAR_FT uint32_t __STLEX(uint32_t value, volatile uint32_t *ptr) + { + uint32_t res; + __ASM volatile ("STLEX %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory"); + return res; + } + +#endif /* __ARM_ARCH_8M_MAIN__ or __ARM_ARCH_8M_BASE__ */ + +#undef __IAR_FT +#undef __IAR_M0_FAMILY +#undef __ICCARM_V8 + +#pragma diag_default=Pe940 +#pragma diag_default=Pe177 + +#endif /* __CMSIS_ICCARM_H__ */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_version.h b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_version.h new file mode 100644 index 0000000..ae3f2e3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/cmsis_version.h @@ -0,0 +1,39 @@ +/**************************************************************************//** + * @file cmsis_version.h + * @brief CMSIS Core(M) Version definitions + * @version V5.0.2 + * @date 19. April 2017 + ******************************************************************************/ +/* + * Copyright (c) 2009-2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CMSIS_VERSION_H +#define __CMSIS_VERSION_H + +/* CMSIS Version definitions */ +#define __CM_CMSIS_VERSION_MAIN ( 5U) /*!< [31:16] CMSIS Core(M) main version */ +#define __CM_CMSIS_VERSION_SUB ( 1U) /*!< [15:0] CMSIS Core(M) sub version */ +#define __CM_CMSIS_VERSION ((__CM_CMSIS_VERSION_MAIN << 16U) | \ + __CM_CMSIS_VERSION_SUB ) /*!< CMSIS Core(M) version number */ +#endif diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mbl.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mbl.h new file mode 100644 index 0000000..ec76ab2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mbl.h @@ -0,0 +1,1918 @@ +/**************************************************************************//** + * @file core_armv8mbl.h + * @brief CMSIS Armv8-M Baseline Core Peripheral Access Layer Header File + * @version V5.0.7 + * @date 22. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_ARMV8MBL_H_GENERIC +#define __CORE_ARMV8MBL_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_ARMv8MBL + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS definitions */ +#define __ARMv8MBL_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __ARMv8MBL_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __ARMv8MBL_CMSIS_VERSION ((__ARMv8MBL_CMSIS_VERSION_MAIN << 16U) | \ + __ARMv8MBL_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M ( 2U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MBL_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_ARMV8MBL_H_DEPENDANT +#define __CORE_ARMV8MBL_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __ARMv8MBL_REV + #define __ARMv8MBL_REV 0x0000U + #warning "__ARMv8MBL_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __VTOR_PRESENT + #define __VTOR_PRESENT 0U + #warning "__VTOR_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif + + #ifndef __ETM_PRESENT + #define __ETM_PRESENT 0U + #warning "__ETM_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MTB_PRESENT + #define __MTB_PRESENT 0U + #warning "__MTB_PRESENT not defined in device header file; using default!" + #endif + +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group ARMv8MBL */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint32_t IPR[124U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ +#else + uint32_t RESERVED0; +#endif + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHPR[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + uint32_t RESERVED0[6U]; + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x3UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Sizes Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Sizes Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[809U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) Software Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) Software Lock Status Register */ + uint32_t RESERVED4[4U]; + __IM uint32_t TYPE; /*!< Offset: 0xFC8 (R/ ) Device Identifier Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_SWOSCALER_Pos 0U /*!< TPI ACPR: SWOSCALER Position */ +#define TPI_ACPR_SWOSCALER_Msk (0xFFFFUL /*<< TPI_ACPR_SWOSCALER_Pos*/) /*!< TPI ACPR: SWOSCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI Periodic Synchronization Control Register Definitions */ +#define TPI_PSCR_PSCount_Pos 0U /*!< TPI PSCR: PSCount Position */ +#define TPI_PSCR_PSCount_Msk (0x1FUL /*<< TPI_PSCR_PSCount_Pos*/) /*!< TPI PSCR: TPSCount Mask */ + +/* TPI Software Lock Status Register Definitions */ +#define TPI_LSR_nTT_Pos 1U /*!< TPI LSR: Not thirty-two bit. Position */ +#define TPI_LSR_nTT_Msk (0x1UL << TPI_LSR_nTT_Pos) /*!< TPI LSR: Not thirty-two bit. Mask */ + +#define TPI_LSR_SLK_Pos 1U /*!< TPI LSR: Software Lock status Position */ +#define TPI_LSR_SLK_Msk (0x1UL << TPI_LSR_SLK_Pos) /*!< TPI LSR: Software Lock status Mask */ + +#define TPI_LSR_SLI_Pos 0U /*!< TPI LSR: Software Lock implemented Position */ +#define TPI_LSR_SLI_Msk (0x1UL /*<< TPI_LSR_SLI_Pos*/) /*!< TPI LSR: Software Lock implemented Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFO depth Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFO depth Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + uint32_t RESERVED0[7U]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 1U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: EN Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: EN Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#endif +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register */ +#define CoreDebug_DEMCR_DWTENA_Pos 24U /*!< CoreDebug DEMCR: DWTENA Position */ +#define CoreDebug_DEMCR_DWTENA_Msk (1UL << CoreDebug_DEMCR_DWTENA_Pos) /*!< CoreDebug DEMCR: DWTENA Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + If VTOR is not present address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC_NS->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB_NS->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB_NS->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB_NS->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MBL_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mml.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mml.h new file mode 100644 index 0000000..2d0f106 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_armv8mml.h @@ -0,0 +1,2927 @@ +/**************************************************************************//** + * @file core_armv8mml.h + * @brief CMSIS Armv8-M Mainline Core Peripheral Access Layer Header File + * @version V5.0.7 + * @date 06. July 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_ARMV8MML_H_GENERIC +#define __CORE_ARMV8MML_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_ARMv8MML + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS Armv8MML definitions */ +#define __ARMv8MML_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __ARMv8MML_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __ARMv8MML_CMSIS_VERSION ((__ARMv8MML_CMSIS_VERSION_MAIN << 16U) | \ + __ARMv8MML_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (81U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MML_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_ARMV8MML_H_DEPENDANT +#define __CORE_ARMV8MML_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __ARMv8MML_REV + #define __ARMv8MML_REV 0x0000U + #warning "__ARMv8MML_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DSP_PRESENT + #define __DSP_PRESENT 0U + #warning "__DSP_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group ARMv8MML */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:7; /*!< bit: 9..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t IT:2; /*!< bit: 25..26 saved IT state (read 0) */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_IT_Pos 25U /*!< xPSR: IT Position */ +#define xPSR_IT_Msk (3UL << xPSR_IT_Pos) /*!< xPSR: IT Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t FPCA:1; /*!< bit: 2 Floating-point context active */ + uint32_t SFPA:1; /*!< bit: 3 Secure floating-point active */ + uint32_t _reserved1:28; /*!< bit: 4..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SFPA_Pos 3U /*!< CONTROL: SFPA Position */ +#define CONTROL_SFPA_Msk (1UL << CONTROL_SFPA_Pos) /*!< CONTROL: SFPA Mask */ + +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint8_t IPR[496U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED6[580U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHPR[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t ID_PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t ID_DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ID_ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t ID_MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ID_ISAR[6U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + __IM uint32_t CLIDR; /*!< Offset: 0x078 (R/ ) Cache Level ID register */ + __IM uint32_t CTR; /*!< Offset: 0x07C (R/ ) Cache Type register */ + __IM uint32_t CCSIDR; /*!< Offset: 0x080 (R/ ) Cache Size ID Register */ + __IOM uint32_t CSSELR; /*!< Offset: 0x084 (R/W) Cache Size Selection Register */ + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + __IOM uint32_t NSACR; /*!< Offset: 0x08C (R/W) Non-Secure Access Control Register */ + uint32_t RESERVED3[92U]; + __OM uint32_t STIR; /*!< Offset: 0x200 ( /W) Software Triggered Interrupt Register */ + uint32_t RESERVED4[15U]; + __IM uint32_t MVFR0; /*!< Offset: 0x240 (R/ ) Media and VFP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x244 (R/ ) Media and VFP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x248 (R/ ) Media and VFP Feature Register 2 */ + uint32_t RESERVED5[1U]; + __OM uint32_t ICIALLU; /*!< Offset: 0x250 ( /W) I-Cache Invalidate All to PoU */ + uint32_t RESERVED6[1U]; + __OM uint32_t ICIMVAU; /*!< Offset: 0x258 ( /W) I-Cache Invalidate by MVA to PoU */ + __OM uint32_t DCIMVAC; /*!< Offset: 0x25C ( /W) D-Cache Invalidate by MVA to PoC */ + __OM uint32_t DCISW; /*!< Offset: 0x260 ( /W) D-Cache Invalidate by Set-way */ + __OM uint32_t DCCMVAU; /*!< Offset: 0x264 ( /W) D-Cache Clean by MVA to PoU */ + __OM uint32_t DCCMVAC; /*!< Offset: 0x268 ( /W) D-Cache Clean by MVA to PoC */ + __OM uint32_t DCCSW; /*!< Offset: 0x26C ( /W) D-Cache Clean by Set-way */ + __OM uint32_t DCCIMVAC; /*!< Offset: 0x270 ( /W) D-Cache Clean and Invalidate by MVA to PoC */ + __OM uint32_t DCCISW; /*!< Offset: 0x274 ( /W) D-Cache Clean and Invalidate by Set-way */ + uint32_t RESERVED7[6U]; + __IOM uint32_t ITCMCR; /*!< Offset: 0x290 (R/W) Instruction Tightly-Coupled Memory Control Register */ + __IOM uint32_t DTCMCR; /*!< Offset: 0x294 (R/W) Data Tightly-Coupled Memory Control Registers */ + __IOM uint32_t AHBPCR; /*!< Offset: 0x298 (R/W) AHBP Control Register */ + __IOM uint32_t CACR; /*!< Offset: 0x29C (R/W) L1 Cache Control Register */ + __IOM uint32_t AHBSCR; /*!< Offset: 0x2A0 (R/W) AHB Slave Control Register */ + uint32_t RESERVED8[1U]; + __IOM uint32_t ABFSR; /*!< Offset: 0x2A8 (R/W) Auxiliary Bus Fault Status Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTPENDED_Pos 20U /*!< SCB SHCSR: SECUREFAULTPENDED Position */ +#define SCB_SHCSR_SECUREFAULTPENDED_Msk (1UL << SCB_SHCSR_SECUREFAULTPENDED_Pos) /*!< SCB SHCSR: SECUREFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTENA_Pos 19U /*!< SCB SHCSR: SECUREFAULTENA Position */ +#define SCB_SHCSR_SECUREFAULTENA_Msk (1UL << SCB_SHCSR_SECUREFAULTENA_Pos) /*!< SCB SHCSR: SECUREFAULTENA Mask */ + +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_SECUREFAULTACT_Pos 4U /*!< SCB SHCSR: SECUREFAULTACT Position */ +#define SCB_SHCSR_SECUREFAULTACT_Msk (1UL << SCB_SHCSR_SECUREFAULTACT_Pos) /*!< SCB SHCSR: SECUREFAULTACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_STKOF_Pos (SCB_CFSR_USGFAULTSR_Pos + 4U) /*!< SCB CFSR (UFSR): STKOF Position */ +#define SCB_CFSR_STKOF_Msk (1UL << SCB_CFSR_STKOF_Pos) /*!< SCB CFSR (UFSR): STKOF Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/* SCB Non-Secure Access Control Register Definitions */ +#define SCB_NSACR_CP11_Pos 11U /*!< SCB NSACR: CP11 Position */ +#define SCB_NSACR_CP11_Msk (1UL << SCB_NSACR_CP11_Pos) /*!< SCB NSACR: CP11 Mask */ + +#define SCB_NSACR_CP10_Pos 10U /*!< SCB NSACR: CP10 Position */ +#define SCB_NSACR_CP10_Msk (1UL << SCB_NSACR_CP10_Pos) /*!< SCB NSACR: CP10 Mask */ + +#define SCB_NSACR_CPn_Pos 0U /*!< SCB NSACR: CPn Position */ +#define SCB_NSACR_CPn_Msk (1UL /*<< SCB_NSACR_CPn_Pos*/) /*!< SCB NSACR: CPn Mask */ + +/* SCB Cache Level ID Register Definitions */ +#define SCB_CLIDR_LOUU_Pos 27U /*!< SCB CLIDR: LoUU Position */ +#define SCB_CLIDR_LOUU_Msk (7UL << SCB_CLIDR_LOUU_Pos) /*!< SCB CLIDR: LoUU Mask */ + +#define SCB_CLIDR_LOC_Pos 24U /*!< SCB CLIDR: LoC Position */ +#define SCB_CLIDR_LOC_Msk (7UL << SCB_CLIDR_LOC_Pos) /*!< SCB CLIDR: LoC Mask */ + +/* SCB Cache Type Register Definitions */ +#define SCB_CTR_FORMAT_Pos 29U /*!< SCB CTR: Format Position */ +#define SCB_CTR_FORMAT_Msk (7UL << SCB_CTR_FORMAT_Pos) /*!< SCB CTR: Format Mask */ + +#define SCB_CTR_CWG_Pos 24U /*!< SCB CTR: CWG Position */ +#define SCB_CTR_CWG_Msk (0xFUL << SCB_CTR_CWG_Pos) /*!< SCB CTR: CWG Mask */ + +#define SCB_CTR_ERG_Pos 20U /*!< SCB CTR: ERG Position */ +#define SCB_CTR_ERG_Msk (0xFUL << SCB_CTR_ERG_Pos) /*!< SCB CTR: ERG Mask */ + +#define SCB_CTR_DMINLINE_Pos 16U /*!< SCB CTR: DminLine Position */ +#define SCB_CTR_DMINLINE_Msk (0xFUL << SCB_CTR_DMINLINE_Pos) /*!< SCB CTR: DminLine Mask */ + +#define SCB_CTR_IMINLINE_Pos 0U /*!< SCB CTR: ImInLine Position */ +#define SCB_CTR_IMINLINE_Msk (0xFUL /*<< SCB_CTR_IMINLINE_Pos*/) /*!< SCB CTR: ImInLine Mask */ + +/* SCB Cache Size ID Register Definitions */ +#define SCB_CCSIDR_WT_Pos 31U /*!< SCB CCSIDR: WT Position */ +#define SCB_CCSIDR_WT_Msk (1UL << SCB_CCSIDR_WT_Pos) /*!< SCB CCSIDR: WT Mask */ + +#define SCB_CCSIDR_WB_Pos 30U /*!< SCB CCSIDR: WB Position */ +#define SCB_CCSIDR_WB_Msk (1UL << SCB_CCSIDR_WB_Pos) /*!< SCB CCSIDR: WB Mask */ + +#define SCB_CCSIDR_RA_Pos 29U /*!< SCB CCSIDR: RA Position */ +#define SCB_CCSIDR_RA_Msk (1UL << SCB_CCSIDR_RA_Pos) /*!< SCB CCSIDR: RA Mask */ + +#define SCB_CCSIDR_WA_Pos 28U /*!< SCB CCSIDR: WA Position */ +#define SCB_CCSIDR_WA_Msk (1UL << SCB_CCSIDR_WA_Pos) /*!< SCB CCSIDR: WA Mask */ + +#define SCB_CCSIDR_NUMSETS_Pos 13U /*!< SCB CCSIDR: NumSets Position */ +#define SCB_CCSIDR_NUMSETS_Msk (0x7FFFUL << SCB_CCSIDR_NUMSETS_Pos) /*!< SCB CCSIDR: NumSets Mask */ + +#define SCB_CCSIDR_ASSOCIATIVITY_Pos 3U /*!< SCB CCSIDR: Associativity Position */ +#define SCB_CCSIDR_ASSOCIATIVITY_Msk (0x3FFUL << SCB_CCSIDR_ASSOCIATIVITY_Pos) /*!< SCB CCSIDR: Associativity Mask */ + +#define SCB_CCSIDR_LINESIZE_Pos 0U /*!< SCB CCSIDR: LineSize Position */ +#define SCB_CCSIDR_LINESIZE_Msk (7UL /*<< SCB_CCSIDR_LINESIZE_Pos*/) /*!< SCB CCSIDR: LineSize Mask */ + +/* SCB Cache Size Selection Register Definitions */ +#define SCB_CSSELR_LEVEL_Pos 1U /*!< SCB CSSELR: Level Position */ +#define SCB_CSSELR_LEVEL_Msk (7UL << SCB_CSSELR_LEVEL_Pos) /*!< SCB CSSELR: Level Mask */ + +#define SCB_CSSELR_IND_Pos 0U /*!< SCB CSSELR: InD Position */ +#define SCB_CSSELR_IND_Msk (1UL /*<< SCB_CSSELR_IND_Pos*/) /*!< SCB CSSELR: InD Mask */ + +/* SCB Software Triggered Interrupt Register Definitions */ +#define SCB_STIR_INTID_Pos 0U /*!< SCB STIR: INTID Position */ +#define SCB_STIR_INTID_Msk (0x1FFUL /*<< SCB_STIR_INTID_Pos*/) /*!< SCB STIR: INTID Mask */ + +/* SCB D-Cache Invalidate by Set-way Register Definitions */ +#define SCB_DCISW_WAY_Pos 30U /*!< SCB DCISW: Way Position */ +#define SCB_DCISW_WAY_Msk (3UL << SCB_DCISW_WAY_Pos) /*!< SCB DCISW: Way Mask */ + +#define SCB_DCISW_SET_Pos 5U /*!< SCB DCISW: Set Position */ +#define SCB_DCISW_SET_Msk (0x1FFUL << SCB_DCISW_SET_Pos) /*!< SCB DCISW: Set Mask */ + +/* SCB D-Cache Clean by Set-way Register Definitions */ +#define SCB_DCCSW_WAY_Pos 30U /*!< SCB DCCSW: Way Position */ +#define SCB_DCCSW_WAY_Msk (3UL << SCB_DCCSW_WAY_Pos) /*!< SCB DCCSW: Way Mask */ + +#define SCB_DCCSW_SET_Pos 5U /*!< SCB DCCSW: Set Position */ +#define SCB_DCCSW_SET_Msk (0x1FFUL << SCB_DCCSW_SET_Pos) /*!< SCB DCCSW: Set Mask */ + +/* SCB D-Cache Clean and Invalidate by Set-way Register Definitions */ +#define SCB_DCCISW_WAY_Pos 30U /*!< SCB DCCISW: Way Position */ +#define SCB_DCCISW_WAY_Msk (3UL << SCB_DCCISW_WAY_Pos) /*!< SCB DCCISW: Way Mask */ + +#define SCB_DCCISW_SET_Pos 5U /*!< SCB DCCISW: Set Position */ +#define SCB_DCCISW_SET_Msk (0x1FFUL << SCB_DCCISW_SET_Pos) /*!< SCB DCCISW: Set Mask */ + +/* Instruction Tightly-Coupled Memory Control Register Definitions */ +#define SCB_ITCMCR_SZ_Pos 3U /*!< SCB ITCMCR: SZ Position */ +#define SCB_ITCMCR_SZ_Msk (0xFUL << SCB_ITCMCR_SZ_Pos) /*!< SCB ITCMCR: SZ Mask */ + +#define SCB_ITCMCR_RETEN_Pos 2U /*!< SCB ITCMCR: RETEN Position */ +#define SCB_ITCMCR_RETEN_Msk (1UL << SCB_ITCMCR_RETEN_Pos) /*!< SCB ITCMCR: RETEN Mask */ + +#define SCB_ITCMCR_RMW_Pos 1U /*!< SCB ITCMCR: RMW Position */ +#define SCB_ITCMCR_RMW_Msk (1UL << SCB_ITCMCR_RMW_Pos) /*!< SCB ITCMCR: RMW Mask */ + +#define SCB_ITCMCR_EN_Pos 0U /*!< SCB ITCMCR: EN Position */ +#define SCB_ITCMCR_EN_Msk (1UL /*<< SCB_ITCMCR_EN_Pos*/) /*!< SCB ITCMCR: EN Mask */ + +/* Data Tightly-Coupled Memory Control Register Definitions */ +#define SCB_DTCMCR_SZ_Pos 3U /*!< SCB DTCMCR: SZ Position */ +#define SCB_DTCMCR_SZ_Msk (0xFUL << SCB_DTCMCR_SZ_Pos) /*!< SCB DTCMCR: SZ Mask */ + +#define SCB_DTCMCR_RETEN_Pos 2U /*!< SCB DTCMCR: RETEN Position */ +#define SCB_DTCMCR_RETEN_Msk (1UL << SCB_DTCMCR_RETEN_Pos) /*!< SCB DTCMCR: RETEN Mask */ + +#define SCB_DTCMCR_RMW_Pos 1U /*!< SCB DTCMCR: RMW Position */ +#define SCB_DTCMCR_RMW_Msk (1UL << SCB_DTCMCR_RMW_Pos) /*!< SCB DTCMCR: RMW Mask */ + +#define SCB_DTCMCR_EN_Pos 0U /*!< SCB DTCMCR: EN Position */ +#define SCB_DTCMCR_EN_Msk (1UL /*<< SCB_DTCMCR_EN_Pos*/) /*!< SCB DTCMCR: EN Mask */ + +/* AHBP Control Register Definitions */ +#define SCB_AHBPCR_SZ_Pos 1U /*!< SCB AHBPCR: SZ Position */ +#define SCB_AHBPCR_SZ_Msk (7UL << SCB_AHBPCR_SZ_Pos) /*!< SCB AHBPCR: SZ Mask */ + +#define SCB_AHBPCR_EN_Pos 0U /*!< SCB AHBPCR: EN Position */ +#define SCB_AHBPCR_EN_Msk (1UL /*<< SCB_AHBPCR_EN_Pos*/) /*!< SCB AHBPCR: EN Mask */ + +/* L1 Cache Control Register Definitions */ +#define SCB_CACR_FORCEWT_Pos 2U /*!< SCB CACR: FORCEWT Position */ +#define SCB_CACR_FORCEWT_Msk (1UL << SCB_CACR_FORCEWT_Pos) /*!< SCB CACR: FORCEWT Mask */ + +#define SCB_CACR_ECCEN_Pos 1U /*!< SCB CACR: ECCEN Position */ +#define SCB_CACR_ECCEN_Msk (1UL << SCB_CACR_ECCEN_Pos) /*!< SCB CACR: ECCEN Mask */ + +#define SCB_CACR_SIWT_Pos 0U /*!< SCB CACR: SIWT Position */ +#define SCB_CACR_SIWT_Msk (1UL /*<< SCB_CACR_SIWT_Pos*/) /*!< SCB CACR: SIWT Mask */ + +/* AHBS Control Register Definitions */ +#define SCB_AHBSCR_INITCOUNT_Pos 11U /*!< SCB AHBSCR: INITCOUNT Position */ +#define SCB_AHBSCR_INITCOUNT_Msk (0x1FUL << SCB_AHBPCR_INITCOUNT_Pos) /*!< SCB AHBSCR: INITCOUNT Mask */ + +#define SCB_AHBSCR_TPRI_Pos 2U /*!< SCB AHBSCR: TPRI Position */ +#define SCB_AHBSCR_TPRI_Msk (0x1FFUL << SCB_AHBPCR_TPRI_Pos) /*!< SCB AHBSCR: TPRI Mask */ + +#define SCB_AHBSCR_CTL_Pos 0U /*!< SCB AHBSCR: CTL Position*/ +#define SCB_AHBSCR_CTL_Msk (3UL /*<< SCB_AHBPCR_CTL_Pos*/) /*!< SCB AHBSCR: CTL Mask */ + +/* Auxiliary Bus Fault Status Register Definitions */ +#define SCB_ABFSR_AXIMTYPE_Pos 8U /*!< SCB ABFSR: AXIMTYPE Position*/ +#define SCB_ABFSR_AXIMTYPE_Msk (3UL << SCB_ABFSR_AXIMTYPE_Pos) /*!< SCB ABFSR: AXIMTYPE Mask */ + +#define SCB_ABFSR_EPPB_Pos 4U /*!< SCB ABFSR: EPPB Position*/ +#define SCB_ABFSR_EPPB_Msk (1UL << SCB_ABFSR_EPPB_Pos) /*!< SCB ABFSR: EPPB Mask */ + +#define SCB_ABFSR_AXIM_Pos 3U /*!< SCB ABFSR: AXIM Position*/ +#define SCB_ABFSR_AXIM_Msk (1UL << SCB_ABFSR_AXIM_Pos) /*!< SCB ABFSR: AXIM Mask */ + +#define SCB_ABFSR_AHBP_Pos 2U /*!< SCB ABFSR: AHBP Position*/ +#define SCB_ABFSR_AHBP_Msk (1UL << SCB_ABFSR_AHBP_Pos) /*!< SCB ABFSR: AHBP Mask */ + +#define SCB_ABFSR_DTCM_Pos 1U /*!< SCB ABFSR: DTCM Position*/ +#define SCB_ABFSR_DTCM_Msk (1UL << SCB_ABFSR_DTCM_Pos) /*!< SCB ABFSR: DTCM Mask */ + +#define SCB_ABFSR_ITCM_Pos 0U /*!< SCB ABFSR: ITCM Position*/ +#define SCB_ABFSR_ITCM_Msk (1UL /*<< SCB_ABFSR_ITCM_Pos*/) /*!< SCB ABFSR: ITCM Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ + __IOM uint32_t CPPWR; /*!< Offset: 0x00C (R/W) Coprocessor Power Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) ITM Device Architecture Register */ + uint32_t RESERVED6[4U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Stimulus Port Register Definitions */ +#define ITM_STIM_DISABLED_Pos 1U /*!< ITM STIM: DISABLED Position */ +#define ITM_STIM_DISABLED_Msk (0x1UL << ITM_STIM_DISABLED_Pos) /*!< ITM STIM: DISABLED Mask */ + +#define ITM_STIM_FIFOREADY_Pos 0U /*!< ITM STIM: FIFOREADY Position */ +#define ITM_STIM_FIFOREADY_Msk (0x1UL /*<< ITM_STIM_FIFOREADY_Pos*/) /*!< ITM STIM: FIFOREADY Mask */ + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TRACEBUSID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TRACEBUSID_Msk (0x7FUL << ITM_TCR_TRACEBUSID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPRESCALE_Pos 8U /*!< ITM TCR: TSPRESCALE Position */ +#define ITM_TCR_TSPRESCALE_Msk (3UL << ITM_TCR_TSPRESCALE_Pos) /*!< ITM TCR: TSPRESCALE Mask */ + +#define ITM_TCR_STALLENA_Pos 5U /*!< ITM TCR: STALLENA Position */ +#define ITM_TCR_STALLENA_Msk (1UL << ITM_TCR_STALLENA_Pos) /*!< ITM TCR: STALLENA Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ + uint32_t RESERVED32[934U]; + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R ) Lock Status Register */ + uint32_t RESERVED33[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) Device Architecture Register */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCDISS_Pos 23U /*!< DWT CTRL: CYCDISS Position */ +#define DWT_CTRL_CYCDISS_Msk (0x1UL << DWT_CTRL_CYCDISS_Pos) /*!< DWT CTRL: CYCDISS Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x1UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Sizes Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Sizes Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[809U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) Software Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) Software Lock Status Register */ + uint32_t RESERVED4[4U]; + __IM uint32_t TYPE; /*!< Offset: 0xFC8 (R/ ) Device Identifier Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_SWOSCALER_Pos 0U /*!< TPI ACPR: SWOSCALER Position */ +#define TPI_ACPR_SWOSCALER_Msk (0xFFFFUL /*<< TPI_ACPR_SWOSCALER_Pos*/) /*!< TPI ACPR: SWOSCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI Periodic Synchronization Control Register Definitions */ +#define TPI_PSCR_PSCount_Pos 0U /*!< TPI PSCR: PSCount Position */ +#define TPI_PSCR_PSCount_Msk (0x1FUL /*<< TPI_PSCR_PSCount_Pos*/) /*!< TPI PSCR: TPSCount Mask */ + +/* TPI Software Lock Status Register Definitions */ +#define TPI_LSR_nTT_Pos 1U /*!< TPI LSR: Not thirty-two bit. Position */ +#define TPI_LSR_nTT_Msk (0x1UL << TPI_LSR_nTT_Pos) /*!< TPI LSR: Not thirty-two bit. Mask */ + +#define TPI_LSR_SLK_Pos 1U /*!< TPI LSR: Software Lock status Position */ +#define TPI_LSR_SLK_Msk (0x1UL << TPI_LSR_SLK_Pos) /*!< TPI LSR: Software Lock status Mask */ + +#define TPI_LSR_SLI_Pos 0U /*!< TPI LSR: Software Lock implemented Position */ +#define TPI_LSR_SLI_Msk (0x1UL /*<< TPI_LSR_SLI_Pos*/) /*!< TPI LSR: Software Lock implemented Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFO depth Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFO depth Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Region Base Address Register Alias 1 */ + __IOM uint32_t RLAR_A1; /*!< Offset: 0x018 (R/W) MPU Region Limit Address Register Alias 1 */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Region Base Address Register Alias 2 */ + __IOM uint32_t RLAR_A2; /*!< Offset: 0x020 (R/W) MPU Region Limit Address Register Alias 2 */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Region Base Address Register Alias 3 */ + __IOM uint32_t RLAR_A3; /*!< Offset: 0x028 (R/W) MPU Region Limit Address Register Alias 3 */ + uint32_t RESERVED0[1]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: Region enable bit Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: Region enable bit Disable Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#else + uint32_t RESERVED0[3]; +#endif + __IOM uint32_t SFSR; /*!< Offset: 0x014 (R/W) Secure Fault Status Register */ + __IOM uint32_t SFAR; /*!< Offset: 0x018 (R/W) Secure Fault Address Register */ +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/* Secure Fault Status Register Definitions */ +#define SAU_SFSR_LSERR_Pos 7U /*!< SAU SFSR: LSERR Position */ +#define SAU_SFSR_LSERR_Msk (1UL << SAU_SFSR_LSERR_Pos) /*!< SAU SFSR: LSERR Mask */ + +#define SAU_SFSR_SFARVALID_Pos 6U /*!< SAU SFSR: SFARVALID Position */ +#define SAU_SFSR_SFARVALID_Msk (1UL << SAU_SFSR_SFARVALID_Pos) /*!< SAU SFSR: SFARVALID Mask */ + +#define SAU_SFSR_LSPERR_Pos 5U /*!< SAU SFSR: LSPERR Position */ +#define SAU_SFSR_LSPERR_Msk (1UL << SAU_SFSR_LSPERR_Pos) /*!< SAU SFSR: LSPERR Mask */ + +#define SAU_SFSR_INVTRAN_Pos 4U /*!< SAU SFSR: INVTRAN Position */ +#define SAU_SFSR_INVTRAN_Msk (1UL << SAU_SFSR_INVTRAN_Pos) /*!< SAU SFSR: INVTRAN Mask */ + +#define SAU_SFSR_AUVIOL_Pos 3U /*!< SAU SFSR: AUVIOL Position */ +#define SAU_SFSR_AUVIOL_Msk (1UL << SAU_SFSR_AUVIOL_Pos) /*!< SAU SFSR: AUVIOL Mask */ + +#define SAU_SFSR_INVER_Pos 2U /*!< SAU SFSR: INVER Position */ +#define SAU_SFSR_INVER_Msk (1UL << SAU_SFSR_INVER_Pos) /*!< SAU SFSR: INVER Mask */ + +#define SAU_SFSR_INVIS_Pos 1U /*!< SAU SFSR: INVIS Position */ +#define SAU_SFSR_INVIS_Msk (1UL << SAU_SFSR_INVIS_Pos) /*!< SAU SFSR: INVIS Mask */ + +#define SAU_SFSR_INVEP_Pos 0U /*!< SAU SFSR: INVEP Position */ +#define SAU_SFSR_INVEP_Msk (1UL /*<< SAU_SFSR_INVEP_Pos*/) /*!< SAU SFSR: INVEP Mask */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_LSPENS_Pos 29U /*!< FPCCR: LSPENS Position */ +#define FPU_FPCCR_LSPENS_Msk (1UL << FPU_FPCCR_LSPENS_Pos) /*!< FPCCR: LSPENS bit Mask */ + +#define FPU_FPCCR_CLRONRET_Pos 28U /*!< FPCCR: CLRONRET Position */ +#define FPU_FPCCR_CLRONRET_Msk (1UL << FPU_FPCCR_CLRONRET_Pos) /*!< FPCCR: CLRONRET bit Mask */ + +#define FPU_FPCCR_CLRONRETS_Pos 27U /*!< FPCCR: CLRONRETS Position */ +#define FPU_FPCCR_CLRONRETS_Msk (1UL << FPU_FPCCR_CLRONRETS_Pos) /*!< FPCCR: CLRONRETS bit Mask */ + +#define FPU_FPCCR_TS_Pos 26U /*!< FPCCR: TS Position */ +#define FPU_FPCCR_TS_Msk (1UL << FPU_FPCCR_TS_Pos) /*!< FPCCR: TS bit Mask */ + +#define FPU_FPCCR_UFRDY_Pos 10U /*!< FPCCR: UFRDY Position */ +#define FPU_FPCCR_UFRDY_Msk (1UL << FPU_FPCCR_UFRDY_Pos) /*!< FPCCR: UFRDY bit Mask */ + +#define FPU_FPCCR_SPLIMVIOL_Pos 9U /*!< FPCCR: SPLIMVIOL Position */ +#define FPU_FPCCR_SPLIMVIOL_Msk (1UL << FPU_FPCCR_SPLIMVIOL_Pos) /*!< FPCCR: SPLIMVIOL bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_SFRDY_Pos 7U /*!< FPCCR: SFRDY Position */ +#define FPU_FPCCR_SFRDY_Msk (1UL << FPU_FPCCR_SFRDY_Pos) /*!< FPCCR: SFRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_S_Pos 2U /*!< FPCCR: Security status of the FP context bit Position */ +#define FPU_FPCCR_S_Msk (1UL << FPU_FPCCR_S_Pos) /*!< FPCCR: Security status of the FP context bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + #define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + + #define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ + #define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCnSCB_NS ((SCnSCB_Type *) SCS_BASE_NS ) /*!< System control Register not in SCB(non-secure address space) */ + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + + #define FPU_BASE_NS (SCS_BASE_NS + 0x0F30UL) /*!< Floating Point Unit (non-secure address space) */ + #define FPU_NS ((FPU_Type *) FPU_BASE_NS ) /*!< Floating Point Unit (non-secure address space) */ + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priorty group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Set Priority Grouping (non-secure) + \details Sets the non-secure priority grouping field when in secure state using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void TZ_NVIC_SetPriorityGrouping_NS(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB_NS->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priorty group */ + SCB_NS->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping (non-secure) + \details Reads the priority grouping field from the non-secure NVIC when in secure state. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriorityGrouping_NS(void) +{ + return ((uint32_t)((SCB_NS->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC_NS->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = FPU->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x220U) + { + return 2U; /* Double + Single precision FPU */ + } + else if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MML_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm0.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm0.h new file mode 100644 index 0000000..6f82227 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm0.h @@ -0,0 +1,949 @@ +/**************************************************************************//** + * @file core_cm0.h + * @brief CMSIS Cortex-M0 Core Peripheral Access Layer Header File + * @version V5.0.5 + * @date 28. May 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM0_H_GENERIC +#define __CORE_CM0_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M0 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM0 definitions */ +#define __CM0_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM0_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM0_CMSIS_VERSION ((__CM0_CMSIS_VERSION_MAIN << 16U) | \ + __CM0_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (0U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM0_H_DEPENDANT +#define __CORE_CM0_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM0_REV + #define __CM0_REV 0x0000U + #warning "__CM0_REV not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M0 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t _reserved0:1; /*!< bit: 0 Reserved */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + uint32_t RESERVED0; + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Cortex-M0 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the Cortex-M0 header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M0 */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + Address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)0x0U; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)0x0U; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm0plus.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm0plus.h new file mode 100644 index 0000000..b9377e8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm0plus.h @@ -0,0 +1,1083 @@ +/**************************************************************************//** + * @file core_cm0plus.h + * @brief CMSIS Cortex-M0+ Core Peripheral Access Layer Header File + * @version V5.0.6 + * @date 28. May 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM0PLUS_H_GENERIC +#define __CORE_CM0PLUS_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex-M0+ + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM0+ definitions */ +#define __CM0PLUS_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM0PLUS_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM0PLUS_CMSIS_VERSION ((__CM0PLUS_CMSIS_VERSION_MAIN << 16U) | \ + __CM0PLUS_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (0U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0PLUS_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM0PLUS_H_DEPENDANT +#define __CORE_CM0PLUS_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM0PLUS_REV + #define __CM0PLUS_REV 0x0000U + #warning "__CM0PLUS_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __VTOR_PRESENT + #define __VTOR_PRESENT 0U + #warning "__VTOR_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex-M0+ */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ +#else + uint32_t RESERVED0; +#endif + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) +/* SCB Interrupt Control State Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 8U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0xFFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 1U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 8U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0xFFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Cortex-M0+ Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the Cortex-M0+ header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M0+ */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + If VTOR is not present address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; + +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0PLUS_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm1.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm1.h new file mode 100644 index 0000000..fd1c407 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm1.h @@ -0,0 +1,976 @@ +/**************************************************************************//** + * @file core_cm1.h + * @brief CMSIS Cortex-M1 Core Peripheral Access Layer Header File + * @version V1.0.0 + * @date 23. July 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM1_H_GENERIC +#define __CORE_CM1_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M1 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM1 definitions */ +#define __CM1_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM1_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM1_CMSIS_VERSION ((__CM1_CMSIS_VERSION_MAIN << 16U) | \ + __CM1_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (1U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM1_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM1_H_DEPENDANT +#define __CORE_CM1_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM1_REV + #define __CM1_REV 0x0100U + #warning "__CM1_REV not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M1 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t _reserved0:1; /*!< bit: 0 Reserved */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + uint32_t RESERVED0; + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_ITCMUAEN_Pos 4U /*!< ACTLR: Instruction TCM Upper Alias Enable Position */ +#define SCnSCB_ACTLR_ITCMUAEN_Msk (1UL << SCnSCB_ACTLR_ITCMUAEN_Pos) /*!< ACTLR: Instruction TCM Upper Alias Enable Mask */ + +#define SCnSCB_ACTLR_ITCMLAEN_Pos 3U /*!< ACTLR: Instruction TCM Lower Alias Enable Position */ +#define SCnSCB_ACTLR_ITCMLAEN_Msk (1UL << SCnSCB_ACTLR_ITCMLAEN_Pos) /*!< ACTLR: Instruction TCM Lower Alias Enable Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Cortex-M1 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the Cortex-M1 header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M1 */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + Address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)0x0U; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)0x0U; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM1_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm23.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm23.h new file mode 100644 index 0000000..8202a8d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm23.h @@ -0,0 +1,1993 @@ +/**************************************************************************//** + * @file core_cm23.h + * @brief CMSIS Cortex-M23 Core Peripheral Access Layer Header File + * @version V5.0.7 + * @date 22. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM23_H_GENERIC +#define __CORE_CM23_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M23 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS definitions */ +#define __CM23_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM23_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM23_CMSIS_VERSION ((__CM23_CMSIS_VERSION_MAIN << 16U) | \ + __CM23_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (23U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM23_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM23_H_DEPENDANT +#define __CORE_CM23_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM23_REV + #define __CM23_REV 0x0000U + #warning "__CM23_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __VTOR_PRESENT + #define __VTOR_PRESENT 0U + #warning "__VTOR_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif + + #ifndef __ETM_PRESENT + #define __ETM_PRESENT 0U + #warning "__ETM_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MTB_PRESENT + #define __MTB_PRESENT 0U + #warning "__MTB_PRESENT not defined in device header file; using default!" + #endif + +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M23 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint32_t IPR[124U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ +#else + uint32_t RESERVED0; +#endif + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHPR[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + uint32_t RESERVED0[6U]; + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x3UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t ITFTTD0; /*!< Offset: 0xEEC (R/ ) Integration Test FIFO Test Data 0 Register */ + __IOM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/W) Integration Test ATB Control Register 2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) Integration Test ATB Control Register 0 */ + __IM uint32_t ITFTTD1; /*!< Offset: 0xEFC (R/ ) Integration Test FIFO Test Data 1 Register */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) Device Configuration Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Identifier Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration Test FIFO Test Data 0 Register Definitions */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD0: ATB Interface 2 ATVALIDPosition */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD0: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD0_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD0: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD0_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data2_Pos 16U /*!< TPI ITFTTD0: ATB Interface 1 data2 Position */ +#define TPI_ITFTTD0_ATB_IF1_data2_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data2 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data1_Pos 8U /*!< TPI ITFTTD0: ATB Interface 1 data1 Position */ +#define TPI_ITFTTD0_ATB_IF1_data1_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data1 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data0_Pos 0U /*!< TPI ITFTTD0: ATB Interface 1 data0 Position */ +#define TPI_ITFTTD0_ATB_IF1_data0_Msk (0xFFUL /*<< TPI_ITFTTD0_ATB_IF1_data0_Pos*/) /*!< TPI ITFTTD0: ATB Interface 1 data0 Mask */ + +/* TPI Integration Test ATB Control Register 2 Register Definitions */ +#define TPI_ITATBCTR2_AFVALID2S_Pos 1U /*!< TPI ITATBCTR2: AFVALID2S Position */ +#define TPI_ITATBCTR2_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID2S_Pos) /*!< TPI ITATBCTR2: AFVALID2SS Mask */ + +#define TPI_ITATBCTR2_AFVALID1S_Pos 1U /*!< TPI ITATBCTR2: AFVALID1S Position */ +#define TPI_ITATBCTR2_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID1S_Pos) /*!< TPI ITATBCTR2: AFVALID1SS Mask */ + +#define TPI_ITATBCTR2_ATREADY2S_Pos 0U /*!< TPI ITATBCTR2: ATREADY2S Position */ +#define TPI_ITATBCTR2_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2S_Pos*/) /*!< TPI ITATBCTR2: ATREADY2S Mask */ + +#define TPI_ITATBCTR2_ATREADY1S_Pos 0U /*!< TPI ITATBCTR2: ATREADY1S Position */ +#define TPI_ITATBCTR2_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1S_Pos*/) /*!< TPI ITATBCTR2: ATREADY1S Mask */ + +/* TPI Integration Test FIFO Test Data 1 Register Definitions */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD1: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD1_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD1: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD1_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data2_Pos 16U /*!< TPI ITFTTD1: ATB Interface 2 data2 Position */ +#define TPI_ITFTTD1_ATB_IF2_data2_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data2 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data1_Pos 8U /*!< TPI ITFTTD1: ATB Interface 2 data1 Position */ +#define TPI_ITFTTD1_ATB_IF2_data1_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data1 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data0_Pos 0U /*!< TPI ITFTTD1: ATB Interface 2 data0 Position */ +#define TPI_ITFTTD1_ATB_IF2_data0_Msk (0xFFUL /*<< TPI_ITFTTD1_ATB_IF2_data0_Pos*/) /*!< TPI ITFTTD1: ATB Interface 2 data0 Mask */ + +/* TPI Integration Test ATB Control Register 0 Definitions */ +#define TPI_ITATBCTR0_AFVALID2S_Pos 1U /*!< TPI ITATBCTR0: AFVALID2S Position */ +#define TPI_ITATBCTR0_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID2S_Pos) /*!< TPI ITATBCTR0: AFVALID2SS Mask */ + +#define TPI_ITATBCTR0_AFVALID1S_Pos 1U /*!< TPI ITATBCTR0: AFVALID1S Position */ +#define TPI_ITATBCTR0_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID1S_Pos) /*!< TPI ITATBCTR0: AFVALID1SS Mask */ + +#define TPI_ITATBCTR0_ATREADY2S_Pos 0U /*!< TPI ITATBCTR0: ATREADY2S Position */ +#define TPI_ITATBCTR0_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2S_Pos*/) /*!< TPI ITATBCTR0: ATREADY2S Mask */ + +#define TPI_ITATBCTR0_ATREADY1S_Pos 0U /*!< TPI ITATBCTR0: ATREADY1S Position */ +#define TPI_ITATBCTR0_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1S_Pos*/) /*!< TPI ITATBCTR0: ATREADY1S Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFOSZ Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFOSZ Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x3FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + uint32_t RESERVED0[7U]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 1U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: EN Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: EN Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#endif +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register */ +#define CoreDebug_DEMCR_DWTENA_Pos 24U /*!< CoreDebug DEMCR: DWTENA Position */ +#define CoreDebug_DEMCR_DWTENA_Msk (1UL << CoreDebug_DEMCR_DWTENA_Pos) /*!< CoreDebug DEMCR: DWTENA Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else +/*#define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping not available for Cortex-M23 */ +/*#define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping not available for Cortex-M23 */ + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + If VTOR is not present address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC_NS->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB_NS->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB_NS->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB_NS->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM23_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm3.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm3.h new file mode 100644 index 0000000..b0dfbd3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm3.h @@ -0,0 +1,1941 @@ +/**************************************************************************//** + * @file core_cm3.h + * @brief CMSIS Cortex-M3 Core Peripheral Access Layer Header File + * @version V5.0.8 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM3_H_GENERIC +#define __CORE_CM3_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M3 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM3 definitions */ +#define __CM3_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM3_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM3_CMSIS_VERSION ((__CM3_CMSIS_VERSION_MAIN << 16U) | \ + __CM3_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (3U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM3_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM3_H_DEPENDANT +#define __CORE_CM3_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM3_REV + #define __CM3_REV 0x0200U + #warning "__CM3_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M3 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:27; /*!< bit: 0..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t _reserved1:8; /*!< bit: 16..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHP[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[5U]; + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#if defined (__CM3_REV) && (__CM3_REV < 0x0201U) /* core r2p1 */ +#define SCB_VTOR_TBLBASE_Pos 29U /*!< SCB VTOR: TBLBASE Position */ +#define SCB_VTOR_TBLBASE_Msk (1UL << SCB_VTOR_TBLBASE_Pos) /*!< SCB VTOR: TBLBASE Mask */ + +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x3FFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#else +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ +#if defined (__CM3_REV) && (__CM3_REV >= 0x200U) + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +#else + uint32_t RESERVED1[1U]; +#endif +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/* Auxiliary Control Register Definitions */ + +#define SCnSCB_ACTLR_DISFOLD_Pos 2U /*!< ACTLR: DISFOLD Position */ +#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos) /*!< ACTLR: DISFOLD Mask */ + +#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1U /*!< ACTLR: DISDEFWBUF Position */ +#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos) /*!< ACTLR: DISDEFWBUF Mask */ + +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM3_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm33.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm33.h new file mode 100644 index 0000000..02f82e2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm33.h @@ -0,0 +1,3002 @@ +/**************************************************************************//** + * @file core_cm33.h + * @brief CMSIS Cortex-M33 Core Peripheral Access Layer Header File + * @version V5.0.9 + * @date 06. July 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM33_H_GENERIC +#define __CORE_CM33_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M33 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM33 definitions */ +#define __CM33_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM33_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM33_CMSIS_VERSION ((__CM33_CMSIS_VERSION_MAIN << 16U) | \ + __CM33_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (33U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined (__TARGET_FPU_VFP) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined (__ARM_PCS_VFP) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined (__ARMVFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined (__TI_VFP_SUPPORT__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined (__FPU_VFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM33_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM33_H_DEPENDANT +#define __CORE_CM33_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM33_REV + #define __CM33_REV 0x0000U + #warning "__CM33_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DSP_PRESENT + #define __DSP_PRESENT 0U + #warning "__DSP_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M33 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:7; /*!< bit: 9..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t IT:2; /*!< bit: 25..26 saved IT state (read 0) */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_IT_Pos 25U /*!< xPSR: IT Position */ +#define xPSR_IT_Msk (3UL << xPSR_IT_Pos) /*!< xPSR: IT Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t FPCA:1; /*!< bit: 2 Floating-point context active */ + uint32_t SFPA:1; /*!< bit: 3 Secure floating-point active */ + uint32_t _reserved1:28; /*!< bit: 4..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SFPA_Pos 3U /*!< CONTROL: SFPA Position */ +#define CONTROL_SFPA_Msk (1UL << CONTROL_SFPA_Pos) /*!< CONTROL: SFPA Mask */ + +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint8_t IPR[496U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED6[580U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHPR[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t ID_PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t ID_DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ID_ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t ID_MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ID_ISAR[6U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + __IM uint32_t CLIDR; /*!< Offset: 0x078 (R/ ) Cache Level ID register */ + __IM uint32_t CTR; /*!< Offset: 0x07C (R/ ) Cache Type register */ + __IM uint32_t CCSIDR; /*!< Offset: 0x080 (R/ ) Cache Size ID Register */ + __IOM uint32_t CSSELR; /*!< Offset: 0x084 (R/W) Cache Size Selection Register */ + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + __IOM uint32_t NSACR; /*!< Offset: 0x08C (R/W) Non-Secure Access Control Register */ + uint32_t RESERVED3[92U]; + __OM uint32_t STIR; /*!< Offset: 0x200 ( /W) Software Triggered Interrupt Register */ + uint32_t RESERVED4[15U]; + __IM uint32_t MVFR0; /*!< Offset: 0x240 (R/ ) Media and VFP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x244 (R/ ) Media and VFP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x248 (R/ ) Media and VFP Feature Register 2 */ + uint32_t RESERVED5[1U]; + __OM uint32_t ICIALLU; /*!< Offset: 0x250 ( /W) I-Cache Invalidate All to PoU */ + uint32_t RESERVED6[1U]; + __OM uint32_t ICIMVAU; /*!< Offset: 0x258 ( /W) I-Cache Invalidate by MVA to PoU */ + __OM uint32_t DCIMVAC; /*!< Offset: 0x25C ( /W) D-Cache Invalidate by MVA to PoC */ + __OM uint32_t DCISW; /*!< Offset: 0x260 ( /W) D-Cache Invalidate by Set-way */ + __OM uint32_t DCCMVAU; /*!< Offset: 0x264 ( /W) D-Cache Clean by MVA to PoU */ + __OM uint32_t DCCMVAC; /*!< Offset: 0x268 ( /W) D-Cache Clean by MVA to PoC */ + __OM uint32_t DCCSW; /*!< Offset: 0x26C ( /W) D-Cache Clean by Set-way */ + __OM uint32_t DCCIMVAC; /*!< Offset: 0x270 ( /W) D-Cache Clean and Invalidate by MVA to PoC */ + __OM uint32_t DCCISW; /*!< Offset: 0x274 ( /W) D-Cache Clean and Invalidate by Set-way */ + uint32_t RESERVED7[6U]; + __IOM uint32_t ITCMCR; /*!< Offset: 0x290 (R/W) Instruction Tightly-Coupled Memory Control Register */ + __IOM uint32_t DTCMCR; /*!< Offset: 0x294 (R/W) Data Tightly-Coupled Memory Control Registers */ + __IOM uint32_t AHBPCR; /*!< Offset: 0x298 (R/W) AHBP Control Register */ + __IOM uint32_t CACR; /*!< Offset: 0x29C (R/W) L1 Cache Control Register */ + __IOM uint32_t AHBSCR; /*!< Offset: 0x2A0 (R/W) AHB Slave Control Register */ + uint32_t RESERVED8[1U]; + __IOM uint32_t ABFSR; /*!< Offset: 0x2A8 (R/W) Auxiliary Bus Fault Status Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTPENDED_Pos 20U /*!< SCB SHCSR: SECUREFAULTPENDED Position */ +#define SCB_SHCSR_SECUREFAULTPENDED_Msk (1UL << SCB_SHCSR_SECUREFAULTPENDED_Pos) /*!< SCB SHCSR: SECUREFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTENA_Pos 19U /*!< SCB SHCSR: SECUREFAULTENA Position */ +#define SCB_SHCSR_SECUREFAULTENA_Msk (1UL << SCB_SHCSR_SECUREFAULTENA_Pos) /*!< SCB SHCSR: SECUREFAULTENA Mask */ + +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_SECUREFAULTACT_Pos 4U /*!< SCB SHCSR: SECUREFAULTACT Position */ +#define SCB_SHCSR_SECUREFAULTACT_Msk (1UL << SCB_SHCSR_SECUREFAULTACT_Pos) /*!< SCB SHCSR: SECUREFAULTACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_STKOF_Pos (SCB_CFSR_USGFAULTSR_Pos + 4U) /*!< SCB CFSR (UFSR): STKOF Position */ +#define SCB_CFSR_STKOF_Msk (1UL << SCB_CFSR_STKOF_Pos) /*!< SCB CFSR (UFSR): STKOF Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/* SCB Non-Secure Access Control Register Definitions */ +#define SCB_NSACR_CP11_Pos 11U /*!< SCB NSACR: CP11 Position */ +#define SCB_NSACR_CP11_Msk (1UL << SCB_NSACR_CP11_Pos) /*!< SCB NSACR: CP11 Mask */ + +#define SCB_NSACR_CP10_Pos 10U /*!< SCB NSACR: CP10 Position */ +#define SCB_NSACR_CP10_Msk (1UL << SCB_NSACR_CP10_Pos) /*!< SCB NSACR: CP10 Mask */ + +#define SCB_NSACR_CPn_Pos 0U /*!< SCB NSACR: CPn Position */ +#define SCB_NSACR_CPn_Msk (1UL /*<< SCB_NSACR_CPn_Pos*/) /*!< SCB NSACR: CPn Mask */ + +/* SCB Cache Level ID Register Definitions */ +#define SCB_CLIDR_LOUU_Pos 27U /*!< SCB CLIDR: LoUU Position */ +#define SCB_CLIDR_LOUU_Msk (7UL << SCB_CLIDR_LOUU_Pos) /*!< SCB CLIDR: LoUU Mask */ + +#define SCB_CLIDR_LOC_Pos 24U /*!< SCB CLIDR: LoC Position */ +#define SCB_CLIDR_LOC_Msk (7UL << SCB_CLIDR_LOC_Pos) /*!< SCB CLIDR: LoC Mask */ + +/* SCB Cache Type Register Definitions */ +#define SCB_CTR_FORMAT_Pos 29U /*!< SCB CTR: Format Position */ +#define SCB_CTR_FORMAT_Msk (7UL << SCB_CTR_FORMAT_Pos) /*!< SCB CTR: Format Mask */ + +#define SCB_CTR_CWG_Pos 24U /*!< SCB CTR: CWG Position */ +#define SCB_CTR_CWG_Msk (0xFUL << SCB_CTR_CWG_Pos) /*!< SCB CTR: CWG Mask */ + +#define SCB_CTR_ERG_Pos 20U /*!< SCB CTR: ERG Position */ +#define SCB_CTR_ERG_Msk (0xFUL << SCB_CTR_ERG_Pos) /*!< SCB CTR: ERG Mask */ + +#define SCB_CTR_DMINLINE_Pos 16U /*!< SCB CTR: DminLine Position */ +#define SCB_CTR_DMINLINE_Msk (0xFUL << SCB_CTR_DMINLINE_Pos) /*!< SCB CTR: DminLine Mask */ + +#define SCB_CTR_IMINLINE_Pos 0U /*!< SCB CTR: ImInLine Position */ +#define SCB_CTR_IMINLINE_Msk (0xFUL /*<< SCB_CTR_IMINLINE_Pos*/) /*!< SCB CTR: ImInLine Mask */ + +/* SCB Cache Size ID Register Definitions */ +#define SCB_CCSIDR_WT_Pos 31U /*!< SCB CCSIDR: WT Position */ +#define SCB_CCSIDR_WT_Msk (1UL << SCB_CCSIDR_WT_Pos) /*!< SCB CCSIDR: WT Mask */ + +#define SCB_CCSIDR_WB_Pos 30U /*!< SCB CCSIDR: WB Position */ +#define SCB_CCSIDR_WB_Msk (1UL << SCB_CCSIDR_WB_Pos) /*!< SCB CCSIDR: WB Mask */ + +#define SCB_CCSIDR_RA_Pos 29U /*!< SCB CCSIDR: RA Position */ +#define SCB_CCSIDR_RA_Msk (1UL << SCB_CCSIDR_RA_Pos) /*!< SCB CCSIDR: RA Mask */ + +#define SCB_CCSIDR_WA_Pos 28U /*!< SCB CCSIDR: WA Position */ +#define SCB_CCSIDR_WA_Msk (1UL << SCB_CCSIDR_WA_Pos) /*!< SCB CCSIDR: WA Mask */ + +#define SCB_CCSIDR_NUMSETS_Pos 13U /*!< SCB CCSIDR: NumSets Position */ +#define SCB_CCSIDR_NUMSETS_Msk (0x7FFFUL << SCB_CCSIDR_NUMSETS_Pos) /*!< SCB CCSIDR: NumSets Mask */ + +#define SCB_CCSIDR_ASSOCIATIVITY_Pos 3U /*!< SCB CCSIDR: Associativity Position */ +#define SCB_CCSIDR_ASSOCIATIVITY_Msk (0x3FFUL << SCB_CCSIDR_ASSOCIATIVITY_Pos) /*!< SCB CCSIDR: Associativity Mask */ + +#define SCB_CCSIDR_LINESIZE_Pos 0U /*!< SCB CCSIDR: LineSize Position */ +#define SCB_CCSIDR_LINESIZE_Msk (7UL /*<< SCB_CCSIDR_LINESIZE_Pos*/) /*!< SCB CCSIDR: LineSize Mask */ + +/* SCB Cache Size Selection Register Definitions */ +#define SCB_CSSELR_LEVEL_Pos 1U /*!< SCB CSSELR: Level Position */ +#define SCB_CSSELR_LEVEL_Msk (7UL << SCB_CSSELR_LEVEL_Pos) /*!< SCB CSSELR: Level Mask */ + +#define SCB_CSSELR_IND_Pos 0U /*!< SCB CSSELR: InD Position */ +#define SCB_CSSELR_IND_Msk (1UL /*<< SCB_CSSELR_IND_Pos*/) /*!< SCB CSSELR: InD Mask */ + +/* SCB Software Triggered Interrupt Register Definitions */ +#define SCB_STIR_INTID_Pos 0U /*!< SCB STIR: INTID Position */ +#define SCB_STIR_INTID_Msk (0x1FFUL /*<< SCB_STIR_INTID_Pos*/) /*!< SCB STIR: INTID Mask */ + +/* SCB D-Cache Invalidate by Set-way Register Definitions */ +#define SCB_DCISW_WAY_Pos 30U /*!< SCB DCISW: Way Position */ +#define SCB_DCISW_WAY_Msk (3UL << SCB_DCISW_WAY_Pos) /*!< SCB DCISW: Way Mask */ + +#define SCB_DCISW_SET_Pos 5U /*!< SCB DCISW: Set Position */ +#define SCB_DCISW_SET_Msk (0x1FFUL << SCB_DCISW_SET_Pos) /*!< SCB DCISW: Set Mask */ + +/* SCB D-Cache Clean by Set-way Register Definitions */ +#define SCB_DCCSW_WAY_Pos 30U /*!< SCB DCCSW: Way Position */ +#define SCB_DCCSW_WAY_Msk (3UL << SCB_DCCSW_WAY_Pos) /*!< SCB DCCSW: Way Mask */ + +#define SCB_DCCSW_SET_Pos 5U /*!< SCB DCCSW: Set Position */ +#define SCB_DCCSW_SET_Msk (0x1FFUL << SCB_DCCSW_SET_Pos) /*!< SCB DCCSW: Set Mask */ + +/* SCB D-Cache Clean and Invalidate by Set-way Register Definitions */ +#define SCB_DCCISW_WAY_Pos 30U /*!< SCB DCCISW: Way Position */ +#define SCB_DCCISW_WAY_Msk (3UL << SCB_DCCISW_WAY_Pos) /*!< SCB DCCISW: Way Mask */ + +#define SCB_DCCISW_SET_Pos 5U /*!< SCB DCCISW: Set Position */ +#define SCB_DCCISW_SET_Msk (0x1FFUL << SCB_DCCISW_SET_Pos) /*!< SCB DCCISW: Set Mask */ + +/* Instruction Tightly-Coupled Memory Control Register Definitions */ +#define SCB_ITCMCR_SZ_Pos 3U /*!< SCB ITCMCR: SZ Position */ +#define SCB_ITCMCR_SZ_Msk (0xFUL << SCB_ITCMCR_SZ_Pos) /*!< SCB ITCMCR: SZ Mask */ + +#define SCB_ITCMCR_RETEN_Pos 2U /*!< SCB ITCMCR: RETEN Position */ +#define SCB_ITCMCR_RETEN_Msk (1UL << SCB_ITCMCR_RETEN_Pos) /*!< SCB ITCMCR: RETEN Mask */ + +#define SCB_ITCMCR_RMW_Pos 1U /*!< SCB ITCMCR: RMW Position */ +#define SCB_ITCMCR_RMW_Msk (1UL << SCB_ITCMCR_RMW_Pos) /*!< SCB ITCMCR: RMW Mask */ + +#define SCB_ITCMCR_EN_Pos 0U /*!< SCB ITCMCR: EN Position */ +#define SCB_ITCMCR_EN_Msk (1UL /*<< SCB_ITCMCR_EN_Pos*/) /*!< SCB ITCMCR: EN Mask */ + +/* Data Tightly-Coupled Memory Control Register Definitions */ +#define SCB_DTCMCR_SZ_Pos 3U /*!< SCB DTCMCR: SZ Position */ +#define SCB_DTCMCR_SZ_Msk (0xFUL << SCB_DTCMCR_SZ_Pos) /*!< SCB DTCMCR: SZ Mask */ + +#define SCB_DTCMCR_RETEN_Pos 2U /*!< SCB DTCMCR: RETEN Position */ +#define SCB_DTCMCR_RETEN_Msk (1UL << SCB_DTCMCR_RETEN_Pos) /*!< SCB DTCMCR: RETEN Mask */ + +#define SCB_DTCMCR_RMW_Pos 1U /*!< SCB DTCMCR: RMW Position */ +#define SCB_DTCMCR_RMW_Msk (1UL << SCB_DTCMCR_RMW_Pos) /*!< SCB DTCMCR: RMW Mask */ + +#define SCB_DTCMCR_EN_Pos 0U /*!< SCB DTCMCR: EN Position */ +#define SCB_DTCMCR_EN_Msk (1UL /*<< SCB_DTCMCR_EN_Pos*/) /*!< SCB DTCMCR: EN Mask */ + +/* AHBP Control Register Definitions */ +#define SCB_AHBPCR_SZ_Pos 1U /*!< SCB AHBPCR: SZ Position */ +#define SCB_AHBPCR_SZ_Msk (7UL << SCB_AHBPCR_SZ_Pos) /*!< SCB AHBPCR: SZ Mask */ + +#define SCB_AHBPCR_EN_Pos 0U /*!< SCB AHBPCR: EN Position */ +#define SCB_AHBPCR_EN_Msk (1UL /*<< SCB_AHBPCR_EN_Pos*/) /*!< SCB AHBPCR: EN Mask */ + +/* L1 Cache Control Register Definitions */ +#define SCB_CACR_FORCEWT_Pos 2U /*!< SCB CACR: FORCEWT Position */ +#define SCB_CACR_FORCEWT_Msk (1UL << SCB_CACR_FORCEWT_Pos) /*!< SCB CACR: FORCEWT Mask */ + +#define SCB_CACR_ECCEN_Pos 1U /*!< SCB CACR: ECCEN Position */ +#define SCB_CACR_ECCEN_Msk (1UL << SCB_CACR_ECCEN_Pos) /*!< SCB CACR: ECCEN Mask */ + +#define SCB_CACR_SIWT_Pos 0U /*!< SCB CACR: SIWT Position */ +#define SCB_CACR_SIWT_Msk (1UL /*<< SCB_CACR_SIWT_Pos*/) /*!< SCB CACR: SIWT Mask */ + +/* AHBS Control Register Definitions */ +#define SCB_AHBSCR_INITCOUNT_Pos 11U /*!< SCB AHBSCR: INITCOUNT Position */ +#define SCB_AHBSCR_INITCOUNT_Msk (0x1FUL << SCB_AHBPCR_INITCOUNT_Pos) /*!< SCB AHBSCR: INITCOUNT Mask */ + +#define SCB_AHBSCR_TPRI_Pos 2U /*!< SCB AHBSCR: TPRI Position */ +#define SCB_AHBSCR_TPRI_Msk (0x1FFUL << SCB_AHBPCR_TPRI_Pos) /*!< SCB AHBSCR: TPRI Mask */ + +#define SCB_AHBSCR_CTL_Pos 0U /*!< SCB AHBSCR: CTL Position*/ +#define SCB_AHBSCR_CTL_Msk (3UL /*<< SCB_AHBPCR_CTL_Pos*/) /*!< SCB AHBSCR: CTL Mask */ + +/* Auxiliary Bus Fault Status Register Definitions */ +#define SCB_ABFSR_AXIMTYPE_Pos 8U /*!< SCB ABFSR: AXIMTYPE Position*/ +#define SCB_ABFSR_AXIMTYPE_Msk (3UL << SCB_ABFSR_AXIMTYPE_Pos) /*!< SCB ABFSR: AXIMTYPE Mask */ + +#define SCB_ABFSR_EPPB_Pos 4U /*!< SCB ABFSR: EPPB Position*/ +#define SCB_ABFSR_EPPB_Msk (1UL << SCB_ABFSR_EPPB_Pos) /*!< SCB ABFSR: EPPB Mask */ + +#define SCB_ABFSR_AXIM_Pos 3U /*!< SCB ABFSR: AXIM Position*/ +#define SCB_ABFSR_AXIM_Msk (1UL << SCB_ABFSR_AXIM_Pos) /*!< SCB ABFSR: AXIM Mask */ + +#define SCB_ABFSR_AHBP_Pos 2U /*!< SCB ABFSR: AHBP Position*/ +#define SCB_ABFSR_AHBP_Msk (1UL << SCB_ABFSR_AHBP_Pos) /*!< SCB ABFSR: AHBP Mask */ + +#define SCB_ABFSR_DTCM_Pos 1U /*!< SCB ABFSR: DTCM Position*/ +#define SCB_ABFSR_DTCM_Msk (1UL << SCB_ABFSR_DTCM_Pos) /*!< SCB ABFSR: DTCM Mask */ + +#define SCB_ABFSR_ITCM_Pos 0U /*!< SCB ABFSR: ITCM Position*/ +#define SCB_ABFSR_ITCM_Msk (1UL /*<< SCB_ABFSR_ITCM_Pos*/) /*!< SCB ABFSR: ITCM Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ + __IOM uint32_t CPPWR; /*!< Offset: 0x00C (R/W) Coprocessor Power Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) ITM Device Architecture Register */ + uint32_t RESERVED6[4U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Stimulus Port Register Definitions */ +#define ITM_STIM_DISABLED_Pos 1U /*!< ITM STIM: DISABLED Position */ +#define ITM_STIM_DISABLED_Msk (0x1UL << ITM_STIM_DISABLED_Pos) /*!< ITM STIM: DISABLED Mask */ + +#define ITM_STIM_FIFOREADY_Pos 0U /*!< ITM STIM: FIFOREADY Position */ +#define ITM_STIM_FIFOREADY_Msk (0x1UL /*<< ITM_STIM_FIFOREADY_Pos*/) /*!< ITM STIM: FIFOREADY Mask */ + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TRACEBUSID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TRACEBUSID_Msk (0x7FUL << ITM_TCR_TRACEBUSID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPRESCALE_Pos 8U /*!< ITM TCR: TSPRESCALE Position */ +#define ITM_TCR_TSPRESCALE_Msk (3UL << ITM_TCR_TSPRESCALE_Pos) /*!< ITM TCR: TSPRESCALE Mask */ + +#define ITM_TCR_STALLENA_Pos 5U /*!< ITM TCR: STALLENA Position */ +#define ITM_TCR_STALLENA_Msk (1UL << ITM_TCR_STALLENA_Pos) /*!< ITM TCR: STALLENA Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ + uint32_t RESERVED32[934U]; + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R ) Lock Status Register */ + uint32_t RESERVED33[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) Device Architecture Register */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCDISS_Pos 23U /*!< DWT CTRL: CYCDISS Position */ +#define DWT_CTRL_CYCDISS_Msk (0x1UL << DWT_CTRL_CYCDISS_Pos) /*!< DWT CTRL: CYCDISS Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x1UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t ITFTTD0; /*!< Offset: 0xEEC (R/ ) Integration Test FIFO Test Data 0 Register */ + __IOM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/W) Integration Test ATB Control Register 2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) Integration Test ATB Control Register 0 */ + __IM uint32_t ITFTTD1; /*!< Offset: 0xEFC (R/ ) Integration Test FIFO Test Data 1 Register */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) Device Configuration Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Identifier Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration Test FIFO Test Data 0 Register Definitions */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD0: ATB Interface 2 ATVALIDPosition */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD0: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD0_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD0: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD0_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data2_Pos 16U /*!< TPI ITFTTD0: ATB Interface 1 data2 Position */ +#define TPI_ITFTTD0_ATB_IF1_data2_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data2 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data1_Pos 8U /*!< TPI ITFTTD0: ATB Interface 1 data1 Position */ +#define TPI_ITFTTD0_ATB_IF1_data1_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data1 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data0_Pos 0U /*!< TPI ITFTTD0: ATB Interface 1 data0 Position */ +#define TPI_ITFTTD0_ATB_IF1_data0_Msk (0xFFUL /*<< TPI_ITFTTD0_ATB_IF1_data0_Pos*/) /*!< TPI ITFTTD0: ATB Interface 1 data0 Mask */ + +/* TPI Integration Test ATB Control Register 2 Register Definitions */ +#define TPI_ITATBCTR2_AFVALID2S_Pos 1U /*!< TPI ITATBCTR2: AFVALID2S Position */ +#define TPI_ITATBCTR2_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID2S_Pos) /*!< TPI ITATBCTR2: AFVALID2SS Mask */ + +#define TPI_ITATBCTR2_AFVALID1S_Pos 1U /*!< TPI ITATBCTR2: AFVALID1S Position */ +#define TPI_ITATBCTR2_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID1S_Pos) /*!< TPI ITATBCTR2: AFVALID1SS Mask */ + +#define TPI_ITATBCTR2_ATREADY2S_Pos 0U /*!< TPI ITATBCTR2: ATREADY2S Position */ +#define TPI_ITATBCTR2_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2S_Pos*/) /*!< TPI ITATBCTR2: ATREADY2S Mask */ + +#define TPI_ITATBCTR2_ATREADY1S_Pos 0U /*!< TPI ITATBCTR2: ATREADY1S Position */ +#define TPI_ITATBCTR2_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1S_Pos*/) /*!< TPI ITATBCTR2: ATREADY1S Mask */ + +/* TPI Integration Test FIFO Test Data 1 Register Definitions */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD1: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD1_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD1: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD1_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data2_Pos 16U /*!< TPI ITFTTD1: ATB Interface 2 data2 Position */ +#define TPI_ITFTTD1_ATB_IF2_data2_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data2 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data1_Pos 8U /*!< TPI ITFTTD1: ATB Interface 2 data1 Position */ +#define TPI_ITFTTD1_ATB_IF2_data1_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data1 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data0_Pos 0U /*!< TPI ITFTTD1: ATB Interface 2 data0 Position */ +#define TPI_ITFTTD1_ATB_IF2_data0_Msk (0xFFUL /*<< TPI_ITFTTD1_ATB_IF2_data0_Pos*/) /*!< TPI ITFTTD1: ATB Interface 2 data0 Mask */ + +/* TPI Integration Test ATB Control Register 0 Definitions */ +#define TPI_ITATBCTR0_AFVALID2S_Pos 1U /*!< TPI ITATBCTR0: AFVALID2S Position */ +#define TPI_ITATBCTR0_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID2S_Pos) /*!< TPI ITATBCTR0: AFVALID2SS Mask */ + +#define TPI_ITATBCTR0_AFVALID1S_Pos 1U /*!< TPI ITATBCTR0: AFVALID1S Position */ +#define TPI_ITATBCTR0_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID1S_Pos) /*!< TPI ITATBCTR0: AFVALID1SS Mask */ + +#define TPI_ITATBCTR0_ATREADY2S_Pos 0U /*!< TPI ITATBCTR0: ATREADY2S Position */ +#define TPI_ITATBCTR0_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2S_Pos*/) /*!< TPI ITATBCTR0: ATREADY2S Mask */ + +#define TPI_ITATBCTR0_ATREADY1S_Pos 0U /*!< TPI ITATBCTR0: ATREADY1S Position */ +#define TPI_ITATBCTR0_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1S_Pos*/) /*!< TPI ITATBCTR0: ATREADY1S Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFOSZ Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFOSZ Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x3FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Region Base Address Register Alias 1 */ + __IOM uint32_t RLAR_A1; /*!< Offset: 0x018 (R/W) MPU Region Limit Address Register Alias 1 */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Region Base Address Register Alias 2 */ + __IOM uint32_t RLAR_A2; /*!< Offset: 0x020 (R/W) MPU Region Limit Address Register Alias 2 */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Region Base Address Register Alias 3 */ + __IOM uint32_t RLAR_A3; /*!< Offset: 0x028 (R/W) MPU Region Limit Address Register Alias 3 */ + uint32_t RESERVED0[1]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: Region enable bit Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: Region enable bit Disable Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#else + uint32_t RESERVED0[3]; +#endif + __IOM uint32_t SFSR; /*!< Offset: 0x014 (R/W) Secure Fault Status Register */ + __IOM uint32_t SFAR; /*!< Offset: 0x018 (R/W) Secure Fault Address Register */ +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/* Secure Fault Status Register Definitions */ +#define SAU_SFSR_LSERR_Pos 7U /*!< SAU SFSR: LSERR Position */ +#define SAU_SFSR_LSERR_Msk (1UL << SAU_SFSR_LSERR_Pos) /*!< SAU SFSR: LSERR Mask */ + +#define SAU_SFSR_SFARVALID_Pos 6U /*!< SAU SFSR: SFARVALID Position */ +#define SAU_SFSR_SFARVALID_Msk (1UL << SAU_SFSR_SFARVALID_Pos) /*!< SAU SFSR: SFARVALID Mask */ + +#define SAU_SFSR_LSPERR_Pos 5U /*!< SAU SFSR: LSPERR Position */ +#define SAU_SFSR_LSPERR_Msk (1UL << SAU_SFSR_LSPERR_Pos) /*!< SAU SFSR: LSPERR Mask */ + +#define SAU_SFSR_INVTRAN_Pos 4U /*!< SAU SFSR: INVTRAN Position */ +#define SAU_SFSR_INVTRAN_Msk (1UL << SAU_SFSR_INVTRAN_Pos) /*!< SAU SFSR: INVTRAN Mask */ + +#define SAU_SFSR_AUVIOL_Pos 3U /*!< SAU SFSR: AUVIOL Position */ +#define SAU_SFSR_AUVIOL_Msk (1UL << SAU_SFSR_AUVIOL_Pos) /*!< SAU SFSR: AUVIOL Mask */ + +#define SAU_SFSR_INVER_Pos 2U /*!< SAU SFSR: INVER Position */ +#define SAU_SFSR_INVER_Msk (1UL << SAU_SFSR_INVER_Pos) /*!< SAU SFSR: INVER Mask */ + +#define SAU_SFSR_INVIS_Pos 1U /*!< SAU SFSR: INVIS Position */ +#define SAU_SFSR_INVIS_Msk (1UL << SAU_SFSR_INVIS_Pos) /*!< SAU SFSR: INVIS Mask */ + +#define SAU_SFSR_INVEP_Pos 0U /*!< SAU SFSR: INVEP Position */ +#define SAU_SFSR_INVEP_Msk (1UL /*<< SAU_SFSR_INVEP_Pos*/) /*!< SAU SFSR: INVEP Mask */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_LSPENS_Pos 29U /*!< FPCCR: LSPENS Position */ +#define FPU_FPCCR_LSPENS_Msk (1UL << FPU_FPCCR_LSPENS_Pos) /*!< FPCCR: LSPENS bit Mask */ + +#define FPU_FPCCR_CLRONRET_Pos 28U /*!< FPCCR: CLRONRET Position */ +#define FPU_FPCCR_CLRONRET_Msk (1UL << FPU_FPCCR_CLRONRET_Pos) /*!< FPCCR: CLRONRET bit Mask */ + +#define FPU_FPCCR_CLRONRETS_Pos 27U /*!< FPCCR: CLRONRETS Position */ +#define FPU_FPCCR_CLRONRETS_Msk (1UL << FPU_FPCCR_CLRONRETS_Pos) /*!< FPCCR: CLRONRETS bit Mask */ + +#define FPU_FPCCR_TS_Pos 26U /*!< FPCCR: TS Position */ +#define FPU_FPCCR_TS_Msk (1UL << FPU_FPCCR_TS_Pos) /*!< FPCCR: TS bit Mask */ + +#define FPU_FPCCR_UFRDY_Pos 10U /*!< FPCCR: UFRDY Position */ +#define FPU_FPCCR_UFRDY_Msk (1UL << FPU_FPCCR_UFRDY_Pos) /*!< FPCCR: UFRDY bit Mask */ + +#define FPU_FPCCR_SPLIMVIOL_Pos 9U /*!< FPCCR: SPLIMVIOL Position */ +#define FPU_FPCCR_SPLIMVIOL_Msk (1UL << FPU_FPCCR_SPLIMVIOL_Pos) /*!< FPCCR: SPLIMVIOL bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_SFRDY_Pos 7U /*!< FPCCR: SFRDY Position */ +#define FPU_FPCCR_SFRDY_Msk (1UL << FPU_FPCCR_SFRDY_Pos) /*!< FPCCR: SFRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_S_Pos 2U /*!< FPCCR: Security status of the FP context bit Position */ +#define FPU_FPCCR_S_Msk (1UL << FPU_FPCCR_S_Pos) /*!< FPCCR: Security status of the FP context bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + #define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + + #define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ + #define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCnSCB_NS ((SCnSCB_Type *) SCS_BASE_NS ) /*!< System control Register not in SCB(non-secure address space) */ + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + + #define FPU_BASE_NS (SCS_BASE_NS + 0x0F30UL) /*!< Floating Point Unit (non-secure address space) */ + #define FPU_NS ((FPU_Type *) FPU_BASE_NS ) /*!< Floating Point Unit (non-secure address space) */ + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Set Priority Grouping (non-secure) + \details Sets the non-secure priority grouping field when in secure state using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void TZ_NVIC_SetPriorityGrouping_NS(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB_NS->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB_NS->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping (non-secure) + \details Reads the priority grouping field from the non-secure NVIC when in secure state. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriorityGrouping_NS(void) +{ + return ((uint32_t)((SCB_NS->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC_NS->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = FPU->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x220U) + { + return 2U; /* Double + Single precision FPU */ + } + else if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM33_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm4.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm4.h new file mode 100644 index 0000000..308b868 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm4.h @@ -0,0 +1,2129 @@ +/**************************************************************************//** + * @file core_cm4.h + * @brief CMSIS Cortex-M4 Core Peripheral Access Layer Header File + * @version V5.0.8 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM4_H_GENERIC +#define __CORE_CM4_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M4 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM4 definitions */ +#define __CM4_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM4_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM4_CMSIS_VERSION ((__CM4_CMSIS_VERSION_MAIN << 16U) | \ + __CM4_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (4U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM4_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM4_H_DEPENDANT +#define __CORE_CM4_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM4_REV + #define __CM4_REV 0x0000U + #warning "__CM4_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M4 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t FPCA:1; /*!< bit: 2 FP extension active flag */ + uint32_t _reserved0:29; /*!< bit: 3..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHP[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[5U]; + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_DISOOFP_Pos 9U /*!< ACTLR: DISOOFP Position */ +#define SCnSCB_ACTLR_DISOOFP_Msk (1UL << SCnSCB_ACTLR_DISOOFP_Pos) /*!< ACTLR: DISOOFP Mask */ + +#define SCnSCB_ACTLR_DISFPCA_Pos 8U /*!< ACTLR: DISFPCA Position */ +#define SCnSCB_ACTLR_DISFPCA_Msk (1UL << SCnSCB_ACTLR_DISFPCA_Pos) /*!< ACTLR: DISFPCA Mask */ + +#define SCnSCB_ACTLR_DISFOLD_Pos 2U /*!< ACTLR: DISFOLD Position */ +#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos) /*!< ACTLR: DISFOLD Mask */ + +#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1U /*!< ACTLR: DISDEFWBUF Position */ +#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos) /*!< ACTLR: DISDEFWBUF Mask */ + +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif /* defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +#define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ +#define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ +#define EXC_RETURN_HANDLER_FPU (0xFFFFFFE1UL) /* return to Handler mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_MSP_FPU (0xFFFFFFE9UL) /* return to Thread mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_PSP_FPU (0xFFFFFFEDUL) /* return to Thread mode, uses PSP after return, restore floating-point state */ + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = FPU->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM4_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_cm7.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm7.h new file mode 100644 index 0000000..ada6c2a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_cm7.h @@ -0,0 +1,2671 @@ +/**************************************************************************//** + * @file core_cm7.h + * @brief CMSIS Cortex-M7 Core Peripheral Access Layer Header File + * @version V5.0.8 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM7_H_GENERIC +#define __CORE_CM7_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M7 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM7 definitions */ +#define __CM7_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM7_CMSIS_VERSION_SUB ( __CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM7_CMSIS_VERSION ((__CM7_CMSIS_VERSION_MAIN << 16U) | \ + __CM7_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (7U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM7_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM7_H_DEPENDANT +#define __CORE_CM7_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM7_REV + #define __CM7_REV 0x0000U + #warning "__CM7_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __ICACHE_PRESENT + #define __ICACHE_PRESENT 0U + #warning "__ICACHE_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DCACHE_PRESENT + #define __DCACHE_PRESENT 0U + #warning "__DCACHE_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DTCM_PRESENT + #define __DTCM_PRESENT 0U + #warning "__DTCM_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M7 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t FPCA:1; /*!< bit: 2 FP extension active flag */ + uint32_t _reserved0:29; /*!< bit: 3..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHPR[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t ID_PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t ID_DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ID_AFR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t ID_MFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ID_ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[1U]; + __IM uint32_t CLIDR; /*!< Offset: 0x078 (R/ ) Cache Level ID register */ + __IM uint32_t CTR; /*!< Offset: 0x07C (R/ ) Cache Type register */ + __IM uint32_t CCSIDR; /*!< Offset: 0x080 (R/ ) Cache Size ID Register */ + __IOM uint32_t CSSELR; /*!< Offset: 0x084 (R/W) Cache Size Selection Register */ + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + uint32_t RESERVED3[93U]; + __OM uint32_t STIR; /*!< Offset: 0x200 ( /W) Software Triggered Interrupt Register */ + uint32_t RESERVED4[15U]; + __IM uint32_t MVFR0; /*!< Offset: 0x240 (R/ ) Media and VFP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x244 (R/ ) Media and VFP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x248 (R/ ) Media and VFP Feature Register 2 */ + uint32_t RESERVED5[1U]; + __OM uint32_t ICIALLU; /*!< Offset: 0x250 ( /W) I-Cache Invalidate All to PoU */ + uint32_t RESERVED6[1U]; + __OM uint32_t ICIMVAU; /*!< Offset: 0x258 ( /W) I-Cache Invalidate by MVA to PoU */ + __OM uint32_t DCIMVAC; /*!< Offset: 0x25C ( /W) D-Cache Invalidate by MVA to PoC */ + __OM uint32_t DCISW; /*!< Offset: 0x260 ( /W) D-Cache Invalidate by Set-way */ + __OM uint32_t DCCMVAU; /*!< Offset: 0x264 ( /W) D-Cache Clean by MVA to PoU */ + __OM uint32_t DCCMVAC; /*!< Offset: 0x268 ( /W) D-Cache Clean by MVA to PoC */ + __OM uint32_t DCCSW; /*!< Offset: 0x26C ( /W) D-Cache Clean by Set-way */ + __OM uint32_t DCCIMVAC; /*!< Offset: 0x270 ( /W) D-Cache Clean and Invalidate by MVA to PoC */ + __OM uint32_t DCCISW; /*!< Offset: 0x274 ( /W) D-Cache Clean and Invalidate by Set-way */ + uint32_t RESERVED7[6U]; + __IOM uint32_t ITCMCR; /*!< Offset: 0x290 (R/W) Instruction Tightly-Coupled Memory Control Register */ + __IOM uint32_t DTCMCR; /*!< Offset: 0x294 (R/W) Data Tightly-Coupled Memory Control Registers */ + __IOM uint32_t AHBPCR; /*!< Offset: 0x298 (R/W) AHBP Control Register */ + __IOM uint32_t CACR; /*!< Offset: 0x29C (R/W) L1 Cache Control Register */ + __IOM uint32_t AHBSCR; /*!< Offset: 0x2A0 (R/W) AHB Slave Control Register */ + uint32_t RESERVED8[1U]; + __IOM uint32_t ABFSR; /*!< Offset: 0x2A8 (R/W) Auxiliary Bus Fault Status Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: Branch prediction enable bit Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: Branch prediction enable bit Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: Instruction cache enable bit Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: Instruction cache enable bit Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: Cache enable bit Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: Cache enable bit Mask */ + +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/* SCB Cache Level ID Register Definitions */ +#define SCB_CLIDR_LOUU_Pos 27U /*!< SCB CLIDR: LoUU Position */ +#define SCB_CLIDR_LOUU_Msk (7UL << SCB_CLIDR_LOUU_Pos) /*!< SCB CLIDR: LoUU Mask */ + +#define SCB_CLIDR_LOC_Pos 24U /*!< SCB CLIDR: LoC Position */ +#define SCB_CLIDR_LOC_Msk (7UL << SCB_CLIDR_LOC_Pos) /*!< SCB CLIDR: LoC Mask */ + +/* SCB Cache Type Register Definitions */ +#define SCB_CTR_FORMAT_Pos 29U /*!< SCB CTR: Format Position */ +#define SCB_CTR_FORMAT_Msk (7UL << SCB_CTR_FORMAT_Pos) /*!< SCB CTR: Format Mask */ + +#define SCB_CTR_CWG_Pos 24U /*!< SCB CTR: CWG Position */ +#define SCB_CTR_CWG_Msk (0xFUL << SCB_CTR_CWG_Pos) /*!< SCB CTR: CWG Mask */ + +#define SCB_CTR_ERG_Pos 20U /*!< SCB CTR: ERG Position */ +#define SCB_CTR_ERG_Msk (0xFUL << SCB_CTR_ERG_Pos) /*!< SCB CTR: ERG Mask */ + +#define SCB_CTR_DMINLINE_Pos 16U /*!< SCB CTR: DminLine Position */ +#define SCB_CTR_DMINLINE_Msk (0xFUL << SCB_CTR_DMINLINE_Pos) /*!< SCB CTR: DminLine Mask */ + +#define SCB_CTR_IMINLINE_Pos 0U /*!< SCB CTR: ImInLine Position */ +#define SCB_CTR_IMINLINE_Msk (0xFUL /*<< SCB_CTR_IMINLINE_Pos*/) /*!< SCB CTR: ImInLine Mask */ + +/* SCB Cache Size ID Register Definitions */ +#define SCB_CCSIDR_WT_Pos 31U /*!< SCB CCSIDR: WT Position */ +#define SCB_CCSIDR_WT_Msk (1UL << SCB_CCSIDR_WT_Pos) /*!< SCB CCSIDR: WT Mask */ + +#define SCB_CCSIDR_WB_Pos 30U /*!< SCB CCSIDR: WB Position */ +#define SCB_CCSIDR_WB_Msk (1UL << SCB_CCSIDR_WB_Pos) /*!< SCB CCSIDR: WB Mask */ + +#define SCB_CCSIDR_RA_Pos 29U /*!< SCB CCSIDR: RA Position */ +#define SCB_CCSIDR_RA_Msk (1UL << SCB_CCSIDR_RA_Pos) /*!< SCB CCSIDR: RA Mask */ + +#define SCB_CCSIDR_WA_Pos 28U /*!< SCB CCSIDR: WA Position */ +#define SCB_CCSIDR_WA_Msk (1UL << SCB_CCSIDR_WA_Pos) /*!< SCB CCSIDR: WA Mask */ + +#define SCB_CCSIDR_NUMSETS_Pos 13U /*!< SCB CCSIDR: NumSets Position */ +#define SCB_CCSIDR_NUMSETS_Msk (0x7FFFUL << SCB_CCSIDR_NUMSETS_Pos) /*!< SCB CCSIDR: NumSets Mask */ + +#define SCB_CCSIDR_ASSOCIATIVITY_Pos 3U /*!< SCB CCSIDR: Associativity Position */ +#define SCB_CCSIDR_ASSOCIATIVITY_Msk (0x3FFUL << SCB_CCSIDR_ASSOCIATIVITY_Pos) /*!< SCB CCSIDR: Associativity Mask */ + +#define SCB_CCSIDR_LINESIZE_Pos 0U /*!< SCB CCSIDR: LineSize Position */ +#define SCB_CCSIDR_LINESIZE_Msk (7UL /*<< SCB_CCSIDR_LINESIZE_Pos*/) /*!< SCB CCSIDR: LineSize Mask */ + +/* SCB Cache Size Selection Register Definitions */ +#define SCB_CSSELR_LEVEL_Pos 1U /*!< SCB CSSELR: Level Position */ +#define SCB_CSSELR_LEVEL_Msk (7UL << SCB_CSSELR_LEVEL_Pos) /*!< SCB CSSELR: Level Mask */ + +#define SCB_CSSELR_IND_Pos 0U /*!< SCB CSSELR: InD Position */ +#define SCB_CSSELR_IND_Msk (1UL /*<< SCB_CSSELR_IND_Pos*/) /*!< SCB CSSELR: InD Mask */ + +/* SCB Software Triggered Interrupt Register Definitions */ +#define SCB_STIR_INTID_Pos 0U /*!< SCB STIR: INTID Position */ +#define SCB_STIR_INTID_Msk (0x1FFUL /*<< SCB_STIR_INTID_Pos*/) /*!< SCB STIR: INTID Mask */ + +/* SCB D-Cache Invalidate by Set-way Register Definitions */ +#define SCB_DCISW_WAY_Pos 30U /*!< SCB DCISW: Way Position */ +#define SCB_DCISW_WAY_Msk (3UL << SCB_DCISW_WAY_Pos) /*!< SCB DCISW: Way Mask */ + +#define SCB_DCISW_SET_Pos 5U /*!< SCB DCISW: Set Position */ +#define SCB_DCISW_SET_Msk (0x1FFUL << SCB_DCISW_SET_Pos) /*!< SCB DCISW: Set Mask */ + +/* SCB D-Cache Clean by Set-way Register Definitions */ +#define SCB_DCCSW_WAY_Pos 30U /*!< SCB DCCSW: Way Position */ +#define SCB_DCCSW_WAY_Msk (3UL << SCB_DCCSW_WAY_Pos) /*!< SCB DCCSW: Way Mask */ + +#define SCB_DCCSW_SET_Pos 5U /*!< SCB DCCSW: Set Position */ +#define SCB_DCCSW_SET_Msk (0x1FFUL << SCB_DCCSW_SET_Pos) /*!< SCB DCCSW: Set Mask */ + +/* SCB D-Cache Clean and Invalidate by Set-way Register Definitions */ +#define SCB_DCCISW_WAY_Pos 30U /*!< SCB DCCISW: Way Position */ +#define SCB_DCCISW_WAY_Msk (3UL << SCB_DCCISW_WAY_Pos) /*!< SCB DCCISW: Way Mask */ + +#define SCB_DCCISW_SET_Pos 5U /*!< SCB DCCISW: Set Position */ +#define SCB_DCCISW_SET_Msk (0x1FFUL << SCB_DCCISW_SET_Pos) /*!< SCB DCCISW: Set Mask */ + +/* Instruction Tightly-Coupled Memory Control Register Definitions */ +#define SCB_ITCMCR_SZ_Pos 3U /*!< SCB ITCMCR: SZ Position */ +#define SCB_ITCMCR_SZ_Msk (0xFUL << SCB_ITCMCR_SZ_Pos) /*!< SCB ITCMCR: SZ Mask */ + +#define SCB_ITCMCR_RETEN_Pos 2U /*!< SCB ITCMCR: RETEN Position */ +#define SCB_ITCMCR_RETEN_Msk (1UL << SCB_ITCMCR_RETEN_Pos) /*!< SCB ITCMCR: RETEN Mask */ + +#define SCB_ITCMCR_RMW_Pos 1U /*!< SCB ITCMCR: RMW Position */ +#define SCB_ITCMCR_RMW_Msk (1UL << SCB_ITCMCR_RMW_Pos) /*!< SCB ITCMCR: RMW Mask */ + +#define SCB_ITCMCR_EN_Pos 0U /*!< SCB ITCMCR: EN Position */ +#define SCB_ITCMCR_EN_Msk (1UL /*<< SCB_ITCMCR_EN_Pos*/) /*!< SCB ITCMCR: EN Mask */ + +/* Data Tightly-Coupled Memory Control Register Definitions */ +#define SCB_DTCMCR_SZ_Pos 3U /*!< SCB DTCMCR: SZ Position */ +#define SCB_DTCMCR_SZ_Msk (0xFUL << SCB_DTCMCR_SZ_Pos) /*!< SCB DTCMCR: SZ Mask */ + +#define SCB_DTCMCR_RETEN_Pos 2U /*!< SCB DTCMCR: RETEN Position */ +#define SCB_DTCMCR_RETEN_Msk (1UL << SCB_DTCMCR_RETEN_Pos) /*!< SCB DTCMCR: RETEN Mask */ + +#define SCB_DTCMCR_RMW_Pos 1U /*!< SCB DTCMCR: RMW Position */ +#define SCB_DTCMCR_RMW_Msk (1UL << SCB_DTCMCR_RMW_Pos) /*!< SCB DTCMCR: RMW Mask */ + +#define SCB_DTCMCR_EN_Pos 0U /*!< SCB DTCMCR: EN Position */ +#define SCB_DTCMCR_EN_Msk (1UL /*<< SCB_DTCMCR_EN_Pos*/) /*!< SCB DTCMCR: EN Mask */ + +/* AHBP Control Register Definitions */ +#define SCB_AHBPCR_SZ_Pos 1U /*!< SCB AHBPCR: SZ Position */ +#define SCB_AHBPCR_SZ_Msk (7UL << SCB_AHBPCR_SZ_Pos) /*!< SCB AHBPCR: SZ Mask */ + +#define SCB_AHBPCR_EN_Pos 0U /*!< SCB AHBPCR: EN Position */ +#define SCB_AHBPCR_EN_Msk (1UL /*<< SCB_AHBPCR_EN_Pos*/) /*!< SCB AHBPCR: EN Mask */ + +/* L1 Cache Control Register Definitions */ +#define SCB_CACR_FORCEWT_Pos 2U /*!< SCB CACR: FORCEWT Position */ +#define SCB_CACR_FORCEWT_Msk (1UL << SCB_CACR_FORCEWT_Pos) /*!< SCB CACR: FORCEWT Mask */ + +#define SCB_CACR_ECCEN_Pos 1U /*!< SCB CACR: ECCEN Position */ +#define SCB_CACR_ECCEN_Msk (1UL << SCB_CACR_ECCEN_Pos) /*!< SCB CACR: ECCEN Mask */ + +#define SCB_CACR_SIWT_Pos 0U /*!< SCB CACR: SIWT Position */ +#define SCB_CACR_SIWT_Msk (1UL /*<< SCB_CACR_SIWT_Pos*/) /*!< SCB CACR: SIWT Mask */ + +/* AHBS Control Register Definitions */ +#define SCB_AHBSCR_INITCOUNT_Pos 11U /*!< SCB AHBSCR: INITCOUNT Position */ +#define SCB_AHBSCR_INITCOUNT_Msk (0x1FUL << SCB_AHBPCR_INITCOUNT_Pos) /*!< SCB AHBSCR: INITCOUNT Mask */ + +#define SCB_AHBSCR_TPRI_Pos 2U /*!< SCB AHBSCR: TPRI Position */ +#define SCB_AHBSCR_TPRI_Msk (0x1FFUL << SCB_AHBPCR_TPRI_Pos) /*!< SCB AHBSCR: TPRI Mask */ + +#define SCB_AHBSCR_CTL_Pos 0U /*!< SCB AHBSCR: CTL Position*/ +#define SCB_AHBSCR_CTL_Msk (3UL /*<< SCB_AHBPCR_CTL_Pos*/) /*!< SCB AHBSCR: CTL Mask */ + +/* Auxiliary Bus Fault Status Register Definitions */ +#define SCB_ABFSR_AXIMTYPE_Pos 8U /*!< SCB ABFSR: AXIMTYPE Position*/ +#define SCB_ABFSR_AXIMTYPE_Msk (3UL << SCB_ABFSR_AXIMTYPE_Pos) /*!< SCB ABFSR: AXIMTYPE Mask */ + +#define SCB_ABFSR_EPPB_Pos 4U /*!< SCB ABFSR: EPPB Position*/ +#define SCB_ABFSR_EPPB_Msk (1UL << SCB_ABFSR_EPPB_Pos) /*!< SCB ABFSR: EPPB Mask */ + +#define SCB_ABFSR_AXIM_Pos 3U /*!< SCB ABFSR: AXIM Position*/ +#define SCB_ABFSR_AXIM_Msk (1UL << SCB_ABFSR_AXIM_Pos) /*!< SCB ABFSR: AXIM Mask */ + +#define SCB_ABFSR_AHBP_Pos 2U /*!< SCB ABFSR: AHBP Position*/ +#define SCB_ABFSR_AHBP_Msk (1UL << SCB_ABFSR_AHBP_Pos) /*!< SCB ABFSR: AHBP Mask */ + +#define SCB_ABFSR_DTCM_Pos 1U /*!< SCB ABFSR: DTCM Position*/ +#define SCB_ABFSR_DTCM_Msk (1UL << SCB_ABFSR_DTCM_Pos) /*!< SCB ABFSR: DTCM Mask */ + +#define SCB_ABFSR_ITCM_Pos 0U /*!< SCB ABFSR: ITCM Position*/ +#define SCB_ABFSR_ITCM_Msk (1UL /*<< SCB_ABFSR_ITCM_Pos*/) /*!< SCB ABFSR: ITCM Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_DISITMATBFLUSH_Pos 12U /*!< ACTLR: DISITMATBFLUSH Position */ +#define SCnSCB_ACTLR_DISITMATBFLUSH_Msk (1UL << SCnSCB_ACTLR_DISITMATBFLUSH_Pos) /*!< ACTLR: DISITMATBFLUSH Mask */ + +#define SCnSCB_ACTLR_DISRAMODE_Pos 11U /*!< ACTLR: DISRAMODE Position */ +#define SCnSCB_ACTLR_DISRAMODE_Msk (1UL << SCnSCB_ACTLR_DISRAMODE_Pos) /*!< ACTLR: DISRAMODE Mask */ + +#define SCnSCB_ACTLR_FPEXCODIS_Pos 10U /*!< ACTLR: FPEXCODIS Position */ +#define SCnSCB_ACTLR_FPEXCODIS_Msk (1UL << SCnSCB_ACTLR_FPEXCODIS_Pos) /*!< ACTLR: FPEXCODIS Mask */ + +#define SCnSCB_ACTLR_DISFOLD_Pos 2U /*!< ACTLR: DISFOLD Position */ +#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos) /*!< ACTLR: DISFOLD Mask */ + +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED3[981U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( W) Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R ) Lock Status Register */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif /* defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x018 (R/ ) Media and FP Feature Register 2 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/* Media and FP Feature Register 2 Definitions */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +#define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ +#define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ +#define EXC_RETURN_HANDLER_FPU (0xFFFFFFE1UL) /* return to Handler mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_MSP_FPU (0xFFFFFFE9UL) /* return to Thread mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_PSP_FPU (0xFFFFFFEDUL) /* return to Thread mode, uses PSP after return, restore floating-point state */ + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = SCB->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x220U) + { + return 2U; /* Double + Single precision FPU */ + } + else if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## Cache functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_CacheFunctions Cache Functions + \brief Functions that configure Instruction and Data cache. + @{ + */ + +/* Cache Size ID Register Macros */ +#define CCSIDR_WAYS(x) (((x) & SCB_CCSIDR_ASSOCIATIVITY_Msk) >> SCB_CCSIDR_ASSOCIATIVITY_Pos) +#define CCSIDR_SETS(x) (((x) & SCB_CCSIDR_NUMSETS_Msk ) >> SCB_CCSIDR_NUMSETS_Pos ) + + +/** + \brief Enable I-Cache + \details Turns on I-Cache + */ +__STATIC_INLINE void SCB_EnableICache (void) +{ + #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) + __DSB(); + __ISB(); + SCB->ICIALLU = 0UL; /* invalidate I-Cache */ + __DSB(); + __ISB(); + SCB->CCR |= (uint32_t)SCB_CCR_IC_Msk; /* enable I-Cache */ + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Disable I-Cache + \details Turns off I-Cache + */ +__STATIC_INLINE void SCB_DisableICache (void) +{ + #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) + __DSB(); + __ISB(); + SCB->CCR &= ~(uint32_t)SCB_CCR_IC_Msk; /* disable I-Cache */ + SCB->ICIALLU = 0UL; /* invalidate I-Cache */ + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Invalidate I-Cache + \details Invalidates I-Cache + */ +__STATIC_INLINE void SCB_InvalidateICache (void) +{ + #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) + __DSB(); + __ISB(); + SCB->ICIALLU = 0UL; + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Enable D-Cache + \details Turns on D-Cache + */ +__STATIC_INLINE void SCB_EnableDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | + ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + __DSB(); + + SCB->CCR |= (uint32_t)SCB_CCR_DC_Msk; /* enable D-Cache */ + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Disable D-Cache + \details Turns off D-Cache + */ +__STATIC_INLINE void SCB_DisableDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + SCB->CCR &= ~(uint32_t)SCB_CCR_DC_Msk; /* disable D-Cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* clean & invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | + ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Invalidate D-Cache + \details Invalidates D-Cache + */ +__STATIC_INLINE void SCB_InvalidateDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | + ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Clean D-Cache + \details Cleans D-Cache + */ +__STATIC_INLINE void SCB_CleanDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* clean D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCCSW = (((sets << SCB_DCCSW_SET_Pos) & SCB_DCCSW_SET_Msk) | + ((ways << SCB_DCCSW_WAY_Pos) & SCB_DCCSW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Clean & Invalidate D-Cache + \details Cleans and Invalidates D-Cache + */ +__STATIC_INLINE void SCB_CleanInvalidateDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* clean & invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | + ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief D-Cache Invalidate by address + \details Invalidates D-Cache for the given address + \param[in] addr address (aligned to 32-byte boundary) + \param[in] dsize size of memory block (in number of bytes) +*/ +__STATIC_INLINE void SCB_InvalidateDCache_by_Addr (uint32_t *addr, int32_t dsize) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + int32_t op_size = dsize; + uint32_t op_addr = (uint32_t)addr; + int32_t linesize = 32; /* in Cortex-M7 size of cache line is fixed to 8 words (32 bytes) */ + + __DSB(); + + while (op_size > 0) { + SCB->DCIMVAC = op_addr; + op_addr += (uint32_t)linesize; + op_size -= linesize; + } + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief D-Cache Clean by address + \details Cleans D-Cache for the given address + \param[in] addr address (aligned to 32-byte boundary) + \param[in] dsize size of memory block (in number of bytes) +*/ +__STATIC_INLINE void SCB_CleanDCache_by_Addr (uint32_t *addr, int32_t dsize) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + int32_t op_size = dsize; + uint32_t op_addr = (uint32_t) addr; + int32_t linesize = 32; /* in Cortex-M7 size of cache line is fixed to 8 words (32 bytes) */ + + __DSB(); + + while (op_size > 0) { + SCB->DCCMVAC = op_addr; + op_addr += (uint32_t)linesize; + op_size -= linesize; + } + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief D-Cache Clean and Invalidate by address + \details Cleans and invalidates D_Cache for the given address + \param[in] addr address (aligned to 32-byte boundary) + \param[in] dsize size of memory block (in number of bytes) +*/ +__STATIC_INLINE void SCB_CleanInvalidateDCache_by_Addr (uint32_t *addr, int32_t dsize) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + int32_t op_size = dsize; + uint32_t op_addr = (uint32_t) addr; + int32_t linesize = 32; /* in Cortex-M7 size of cache line is fixed to 8 words (32 bytes) */ + + __DSB(); + + while (op_size > 0) { + SCB->DCCIMVAC = op_addr; + op_addr += (uint32_t)linesize; + op_size -= linesize; + } + + __DSB(); + __ISB(); + #endif +} + + +/*@} end of CMSIS_Core_CacheFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM7_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_sc000.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_sc000.h new file mode 100644 index 0000000..9086c64 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_sc000.h @@ -0,0 +1,1022 @@ +/**************************************************************************//** + * @file core_sc000.h + * @brief CMSIS SC000 Core Peripheral Access Layer Header File + * @version V5.0.5 + * @date 28. May 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_SC000_H_GENERIC +#define __CORE_SC000_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup SC000 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS SC000 definitions */ +#define __SC000_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __SC000_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __SC000_CMSIS_VERSION ((__SC000_CMSIS_VERSION_MAIN << 16U) | \ + __SC000_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_SC (000U) /*!< Cortex secure core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC000_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_SC000_H_DEPENDANT +#define __CORE_SC000_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __SC000_REV + #define __SC000_REV 0x0000U + #warning "__SC000_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group SC000 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t _reserved0:1; /*!< bit: 0 Reserved */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED0[1U]; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + uint32_t RESERVED1[154U]; + __IOM uint32_t SFCR; /*!< Offset: 0x290 (R/W) Security Features Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ +} MPU_Type; + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 8U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0xFFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief SC000 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the SC000 header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else +/*#define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping not available for SC000 */ +/*#define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping not available for SC000 */ + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for SC000 */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC000_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/core_sc300.h b/Chapter04/bare/platform/CMSIS/Core/Include/core_sc300.h new file mode 100644 index 0000000..665822d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/core_sc300.h @@ -0,0 +1,1915 @@ +/**************************************************************************//** + * @file core_sc300.h + * @brief CMSIS SC300 Core Peripheral Access Layer Header File + * @version V5.0.6 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_SC300_H_GENERIC +#define __CORE_SC300_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup SC3000 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS SC300 definitions */ +#define __SC300_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __SC300_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __SC300_CMSIS_VERSION ((__SC300_CMSIS_VERSION_MAIN << 16U) | \ + __SC300_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_SC (300U) /*!< Cortex secure core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC300_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_SC300_H_DEPENDANT +#define __CORE_SC300_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __SC300_REV + #define __SC300_REV 0x0000U + #warning "__SC300_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group SC300 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:27; /*!< bit: 0..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t _reserved1:8; /*!< bit: 16..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHP[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[5U]; + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + uint32_t RESERVED1[129U]; + __IOM uint32_t SFCR; /*!< Offset: 0x290 (R/W) Security Features Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLBASE_Pos 29U /*!< SCB VTOR: TBLBASE Position */ +#define SCB_VTOR_TBLBASE_Msk (1UL << SCB_VTOR_TBLBASE_Pos) /*!< SCB VTOR: TBLBASE Mask */ + +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x3FFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + uint32_t RESERVED1[1U]; +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priorty group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC300_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv7.h b/Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv7.h new file mode 100644 index 0000000..7d4b600 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv7.h @@ -0,0 +1,270 @@ +/****************************************************************************** + * @file mpu_armv7.h + * @brief CMSIS MPU API for Armv7-M MPU + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef ARM_MPU_ARMV7_H +#define ARM_MPU_ARMV7_H + +#define ARM_MPU_REGION_SIZE_32B ((uint8_t)0x04U) ///!< MPU Region Size 32 Bytes +#define ARM_MPU_REGION_SIZE_64B ((uint8_t)0x05U) ///!< MPU Region Size 64 Bytes +#define ARM_MPU_REGION_SIZE_128B ((uint8_t)0x06U) ///!< MPU Region Size 128 Bytes +#define ARM_MPU_REGION_SIZE_256B ((uint8_t)0x07U) ///!< MPU Region Size 256 Bytes +#define ARM_MPU_REGION_SIZE_512B ((uint8_t)0x08U) ///!< MPU Region Size 512 Bytes +#define ARM_MPU_REGION_SIZE_1KB ((uint8_t)0x09U) ///!< MPU Region Size 1 KByte +#define ARM_MPU_REGION_SIZE_2KB ((uint8_t)0x0AU) ///!< MPU Region Size 2 KBytes +#define ARM_MPU_REGION_SIZE_4KB ((uint8_t)0x0BU) ///!< MPU Region Size 4 KBytes +#define ARM_MPU_REGION_SIZE_8KB ((uint8_t)0x0CU) ///!< MPU Region Size 8 KBytes +#define ARM_MPU_REGION_SIZE_16KB ((uint8_t)0x0DU) ///!< MPU Region Size 16 KBytes +#define ARM_MPU_REGION_SIZE_32KB ((uint8_t)0x0EU) ///!< MPU Region Size 32 KBytes +#define ARM_MPU_REGION_SIZE_64KB ((uint8_t)0x0FU) ///!< MPU Region Size 64 KBytes +#define ARM_MPU_REGION_SIZE_128KB ((uint8_t)0x10U) ///!< MPU Region Size 128 KBytes +#define ARM_MPU_REGION_SIZE_256KB ((uint8_t)0x11U) ///!< MPU Region Size 256 KBytes +#define ARM_MPU_REGION_SIZE_512KB ((uint8_t)0x12U) ///!< MPU Region Size 512 KBytes +#define ARM_MPU_REGION_SIZE_1MB ((uint8_t)0x13U) ///!< MPU Region Size 1 MByte +#define ARM_MPU_REGION_SIZE_2MB ((uint8_t)0x14U) ///!< MPU Region Size 2 MBytes +#define ARM_MPU_REGION_SIZE_4MB ((uint8_t)0x15U) ///!< MPU Region Size 4 MBytes +#define ARM_MPU_REGION_SIZE_8MB ((uint8_t)0x16U) ///!< MPU Region Size 8 MBytes +#define ARM_MPU_REGION_SIZE_16MB ((uint8_t)0x17U) ///!< MPU Region Size 16 MBytes +#define ARM_MPU_REGION_SIZE_32MB ((uint8_t)0x18U) ///!< MPU Region Size 32 MBytes +#define ARM_MPU_REGION_SIZE_64MB ((uint8_t)0x19U) ///!< MPU Region Size 64 MBytes +#define ARM_MPU_REGION_SIZE_128MB ((uint8_t)0x1AU) ///!< MPU Region Size 128 MBytes +#define ARM_MPU_REGION_SIZE_256MB ((uint8_t)0x1BU) ///!< MPU Region Size 256 MBytes +#define ARM_MPU_REGION_SIZE_512MB ((uint8_t)0x1CU) ///!< MPU Region Size 512 MBytes +#define ARM_MPU_REGION_SIZE_1GB ((uint8_t)0x1DU) ///!< MPU Region Size 1 GByte +#define ARM_MPU_REGION_SIZE_2GB ((uint8_t)0x1EU) ///!< MPU Region Size 2 GBytes +#define ARM_MPU_REGION_SIZE_4GB ((uint8_t)0x1FU) ///!< MPU Region Size 4 GBytes + +#define ARM_MPU_AP_NONE 0U ///!< MPU Access Permission no access +#define ARM_MPU_AP_PRIV 1U ///!< MPU Access Permission privileged access only +#define ARM_MPU_AP_URO 2U ///!< MPU Access Permission unprivileged access read-only +#define ARM_MPU_AP_FULL 3U ///!< MPU Access Permission full access +#define ARM_MPU_AP_PRO 5U ///!< MPU Access Permission privileged access read-only +#define ARM_MPU_AP_RO 6U ///!< MPU Access Permission read-only access + +/** MPU Region Base Address Register Value +* +* \param Region The region to be configured, number 0 to 15. +* \param BaseAddress The base address for the region. +*/ +#define ARM_MPU_RBAR(Region, BaseAddress) \ + (((BaseAddress) & MPU_RBAR_ADDR_Msk) | \ + ((Region) & MPU_RBAR_REGION_Msk) | \ + (MPU_RBAR_VALID_Msk)) + +/** +* MPU Memory Access Attributes +* +* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral. +* \param IsShareable Region is shareable between multiple bus masters. +* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache. +* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy. +*/ +#define ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable) \ + ((((TypeExtField ) << MPU_RASR_TEX_Pos) & MPU_RASR_TEX_Msk) | \ + (((IsShareable ) << MPU_RASR_S_Pos) & MPU_RASR_S_Msk) | \ + (((IsCacheable ) << MPU_RASR_C_Pos) & MPU_RASR_C_Msk) | \ + (((IsBufferable ) << MPU_RASR_B_Pos) & MPU_RASR_B_Msk)) + +/** +* MPU Region Attribute and Size Register Value +* +* \param DisableExec Instruction access disable bit, 1= disable instruction fetches. +* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode. +* \param AccessAttributes Memory access attribution, see \ref ARM_MPU_ACCESS_. +* \param SubRegionDisable Sub-region disable field. +* \param Size Region size of the region to be configured, for example 4K, 8K. +*/ +#define ARM_MPU_RASR_EX(DisableExec, AccessPermission, AccessAttributes, SubRegionDisable, Size) \ + ((((DisableExec ) << MPU_RASR_XN_Pos) & MPU_RASR_XN_Msk) | \ + (((AccessPermission) << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk) | \ + (((AccessAttributes) ) & (MPU_RASR_TEX_Msk | MPU_RASR_S_Msk | MPU_RASR_C_Msk | MPU_RASR_B_Msk))) + +/** +* MPU Region Attribute and Size Register Value +* +* \param DisableExec Instruction access disable bit, 1= disable instruction fetches. +* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode. +* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral. +* \param IsShareable Region is shareable between multiple bus masters. +* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache. +* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy. +* \param SubRegionDisable Sub-region disable field. +* \param Size Region size of the region to be configured, for example 4K, 8K. +*/ +#define ARM_MPU_RASR(DisableExec, AccessPermission, TypeExtField, IsShareable, IsCacheable, IsBufferable, SubRegionDisable, Size) \ + ARM_MPU_RASR_EX(DisableExec, AccessPermission, ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable), SubRegionDisable, Size) + +/** +* MPU Memory Access Attribute for strongly ordered memory. +* - TEX: 000b +* - Shareable +* - Non-cacheable +* - Non-bufferable +*/ +#define ARM_MPU_ACCESS_ORDERED ARM_MPU_ACCESS_(0U, 1U, 0U, 0U) + +/** +* MPU Memory Access Attribute for device memory. +* - TEX: 000b (if non-shareable) or 010b (if shareable) +* - Shareable or non-shareable +* - Non-cacheable +* - Bufferable (if shareable) or non-bufferable (if non-shareable) +* +* \param IsShareable Configures the device memory as shareable or non-shareable. +*/ +#define ARM_MPU_ACCESS_DEVICE(IsShareable) ((IsShareable) ? ARM_MPU_ACCESS_(0U, 1U, 0U, 1U) : ARM_MPU_ACCESS_(2U, 0U, 0U, 0U)) + +/** +* MPU Memory Access Attribute for normal memory. +* - TEX: 1BBb (reflecting outer cacheability rules) +* - Shareable or non-shareable +* - Cacheable or non-cacheable (reflecting inner cacheability rules) +* - Bufferable or non-bufferable (reflecting inner cacheability rules) +* +* \param OuterCp Configures the outer cache policy. +* \param InnerCp Configures the inner cache policy. +* \param IsShareable Configures the memory as shareable or non-shareable. +*/ +#define ARM_MPU_ACCESS_NORMAL(OuterCp, InnerCp, IsShareable) ARM_MPU_ACCESS_((4U | (OuterCp)), IsShareable, ((InnerCp) & 2U), ((InnerCp) & 1U)) + +/** +* MPU Memory Access Attribute non-cacheable policy. +*/ +#define ARM_MPU_CACHEP_NOCACHE 0U + +/** +* MPU Memory Access Attribute write-back, write and read allocate policy. +*/ +#define ARM_MPU_CACHEP_WB_WRA 1U + +/** +* MPU Memory Access Attribute write-through, no write allocate policy. +*/ +#define ARM_MPU_CACHEP_WT_NWA 2U + +/** +* MPU Memory Access Attribute write-back, no write allocate policy. +*/ +#define ARM_MPU_CACHEP_WB_NWA 3U + + +/** +* Struct for a single MPU Region +*/ +typedef struct { + uint32_t RBAR; //!< The region base address register value (RBAR) + uint32_t RASR; //!< The region attribute and size register value (RASR) \ref MPU_RASR +} ARM_MPU_Region_t; + +/** Enable the MPU. +* \param MPU_Control Default access permissions for unconfigured regions. +*/ +__STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control) +{ + __DSB(); + __ISB(); + MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; +#endif +} + +/** Disable the MPU. +*/ +__STATIC_INLINE void ARM_MPU_Disable(void) +{ + __DSB(); + __ISB(); +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; +#endif + MPU->CTRL &= ~MPU_CTRL_ENABLE_Msk; +} + +/** Clear and disable the given MPU region. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr) +{ + MPU->RNR = rnr; + MPU->RASR = 0U; +} + +/** Configure an MPU region. +* \param rbar Value for RBAR register. +* \param rsar Value for RSAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rbar, uint32_t rasr) +{ + MPU->RBAR = rbar; + MPU->RASR = rasr; +} + +/** Configure the given MPU region. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rsar Value for RSAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegionEx(uint32_t rnr, uint32_t rbar, uint32_t rasr) +{ + MPU->RNR = rnr; + MPU->RBAR = rbar; + MPU->RASR = rasr; +} + +/** Memcopy with strictly ordered memory access, e.g. for register targets. +* \param dst Destination data is copied to. +* \param src Source data is copied from. +* \param len Amount of data words to be copied. +*/ +__STATIC_INLINE void orderedCpy(volatile uint32_t* dst, const uint32_t* __RESTRICT src, uint32_t len) +{ + uint32_t i; + for (i = 0U; i < len; ++i) + { + dst[i] = src[i]; + } +} + +/** Load the given number of MPU regions from a table. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_Load(ARM_MPU_Region_t const* table, uint32_t cnt) +{ + const uint32_t rowWordSize = sizeof(ARM_MPU_Region_t)/4U; + while (cnt > MPU_TYPE_RALIASES) { + orderedCpy(&(MPU->RBAR), &(table->RBAR), MPU_TYPE_RALIASES*rowWordSize); + table += MPU_TYPE_RALIASES; + cnt -= MPU_TYPE_RALIASES; + } + orderedCpy(&(MPU->RBAR), &(table->RBAR), cnt*rowWordSize); +} + +#endif diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv8.h b/Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv8.h new file mode 100644 index 0000000..99ee9f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/mpu_armv8.h @@ -0,0 +1,333 @@ +/****************************************************************************** + * @file mpu_armv8.h + * @brief CMSIS MPU API for Armv8-M MPU + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef ARM_MPU_ARMV8_H +#define ARM_MPU_ARMV8_H + +/** \brief Attribute for device memory (outer only) */ +#define ARM_MPU_ATTR_DEVICE ( 0U ) + +/** \brief Attribute for non-cacheable, normal memory */ +#define ARM_MPU_ATTR_NON_CACHEABLE ( 4U ) + +/** \brief Attribute for normal memory (outer and inner) +* \param NT Non-Transient: Set to 1 for non-transient data. +* \param WB Write-Back: Set to 1 to use write-back update policy. +* \param RA Read Allocation: Set to 1 to use cache allocation on read miss. +* \param WA Write Allocation: Set to 1 to use cache allocation on write miss. +*/ +#define ARM_MPU_ATTR_MEMORY_(NT, WB, RA, WA) \ + (((NT & 1U) << 3U) | ((WB & 1U) << 2U) | ((RA & 1U) << 1U) | (WA & 1U)) + +/** \brief Device memory type non Gathering, non Re-ordering, non Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_nGnRnE (0U) + +/** \brief Device memory type non Gathering, non Re-ordering, Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_nGnRE (1U) + +/** \brief Device memory type non Gathering, Re-ordering, Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_nGRE (2U) + +/** \brief Device memory type Gathering, Re-ordering, Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_GRE (3U) + +/** \brief Memory Attribute +* \param O Outer memory attributes +* \param I O == ARM_MPU_ATTR_DEVICE: Device memory attributes, else: Inner memory attributes +*/ +#define ARM_MPU_ATTR(O, I) (((O & 0xFU) << 4U) | (((O & 0xFU) != 0U) ? (I & 0xFU) : ((I & 0x3U) << 2U))) + +/** \brief Normal memory non-shareable */ +#define ARM_MPU_SH_NON (0U) + +/** \brief Normal memory outer shareable */ +#define ARM_MPU_SH_OUTER (2U) + +/** \brief Normal memory inner shareable */ +#define ARM_MPU_SH_INNER (3U) + +/** \brief Memory access permissions +* \param RO Read-Only: Set to 1 for read-only memory. +* \param NP Non-Privileged: Set to 1 for non-privileged memory. +*/ +#define ARM_MPU_AP_(RO, NP) (((RO & 1U) << 1U) | (NP & 1U)) + +/** \brief Region Base Address Register value +* \param BASE The base address bits [31:5] of a memory region. The value is zero extended. Effective address gets 32 byte aligned. +* \param SH Defines the Shareability domain for this memory region. +* \param RO Read-Only: Set to 1 for a read-only memory region. +* \param NP Non-Privileged: Set to 1 for a non-privileged memory region. +* \oaram XN eXecute Never: Set to 1 for a non-executable memory region. +*/ +#define ARM_MPU_RBAR(BASE, SH, RO, NP, XN) \ + ((BASE & MPU_RBAR_BASE_Msk) | \ + ((SH << MPU_RBAR_SH_Pos) & MPU_RBAR_SH_Msk) | \ + ((ARM_MPU_AP_(RO, NP) << MPU_RBAR_AP_Pos) & MPU_RBAR_AP_Msk) | \ + ((XN << MPU_RBAR_XN_Pos) & MPU_RBAR_XN_Msk)) + +/** \brief Region Limit Address Register value +* \param LIMIT The limit address bits [31:5] for this memory region. The value is one extended. +* \param IDX The attribute index to be associated with this memory region. +*/ +#define ARM_MPU_RLAR(LIMIT, IDX) \ + ((LIMIT & MPU_RLAR_LIMIT_Msk) | \ + ((IDX << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \ + (MPU_RLAR_EN_Msk)) + +/** +* Struct for a single MPU Region +*/ +typedef struct { + uint32_t RBAR; /*!< Region Base Address Register value */ + uint32_t RLAR; /*!< Region Limit Address Register value */ +} ARM_MPU_Region_t; + +/** Enable the MPU. +* \param MPU_Control Default access permissions for unconfigured regions. +*/ +__STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control) +{ + __DSB(); + __ISB(); + MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; +#endif +} + +/** Disable the MPU. +*/ +__STATIC_INLINE void ARM_MPU_Disable(void) +{ + __DSB(); + __ISB(); +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; +#endif + MPU->CTRL &= ~MPU_CTRL_ENABLE_Msk; +} + +#ifdef MPU_NS +/** Enable the Non-secure MPU. +* \param MPU_Control Default access permissions for unconfigured regions. +*/ +__STATIC_INLINE void ARM_MPU_Enable_NS(uint32_t MPU_Control) +{ + __DSB(); + __ISB(); + MPU_NS->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB_NS->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; +#endif +} + +/** Disable the Non-secure MPU. +*/ +__STATIC_INLINE void ARM_MPU_Disable_NS(void) +{ + __DSB(); + __ISB(); +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB_NS->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; +#endif + MPU_NS->CTRL &= ~MPU_CTRL_ENABLE_Msk; +} +#endif + +/** Set the memory attribute encoding to the given MPU. +* \param mpu Pointer to the MPU to be configured. +* \param idx The attribute index to be set [0-7] +* \param attr The attribute value to be set. +*/ +__STATIC_INLINE void ARM_MPU_SetMemAttrEx(MPU_Type* mpu, uint8_t idx, uint8_t attr) +{ + const uint8_t reg = idx / 4U; + const uint32_t pos = ((idx % 4U) * 8U); + const uint32_t mask = 0xFFU << pos; + + if (reg >= (sizeof(mpu->MAIR) / sizeof(mpu->MAIR[0]))) { + return; // invalid index + } + + mpu->MAIR[reg] = ((mpu->MAIR[reg] & ~mask) | ((attr << pos) & mask)); +} + +/** Set the memory attribute encoding. +* \param idx The attribute index to be set [0-7] +* \param attr The attribute value to be set. +*/ +__STATIC_INLINE void ARM_MPU_SetMemAttr(uint8_t idx, uint8_t attr) +{ + ARM_MPU_SetMemAttrEx(MPU, idx, attr); +} + +#ifdef MPU_NS +/** Set the memory attribute encoding to the Non-secure MPU. +* \param idx The attribute index to be set [0-7] +* \param attr The attribute value to be set. +*/ +__STATIC_INLINE void ARM_MPU_SetMemAttr_NS(uint8_t idx, uint8_t attr) +{ + ARM_MPU_SetMemAttrEx(MPU_NS, idx, attr); +} +#endif + +/** Clear and disable the given MPU region of the given MPU. +* \param mpu Pointer to MPU to be used. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegionEx(MPU_Type* mpu, uint32_t rnr) +{ + mpu->RNR = rnr; + mpu->RLAR = 0U; +} + +/** Clear and disable the given MPU region. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr) +{ + ARM_MPU_ClrRegionEx(MPU, rnr); +} + +#ifdef MPU_NS +/** Clear and disable the given Non-secure MPU region. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegion_NS(uint32_t rnr) +{ + ARM_MPU_ClrRegionEx(MPU_NS, rnr); +} +#endif + +/** Configure the given MPU region of the given MPU. +* \param mpu Pointer to MPU to be used. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rlar Value for RLAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegionEx(MPU_Type* mpu, uint32_t rnr, uint32_t rbar, uint32_t rlar) +{ + mpu->RNR = rnr; + mpu->RBAR = rbar; + mpu->RLAR = rlar; +} + +/** Configure the given MPU region. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rlar Value for RLAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rnr, uint32_t rbar, uint32_t rlar) +{ + ARM_MPU_SetRegionEx(MPU, rnr, rbar, rlar); +} + +#ifdef MPU_NS +/** Configure the given Non-secure MPU region. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rlar Value for RLAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegion_NS(uint32_t rnr, uint32_t rbar, uint32_t rlar) +{ + ARM_MPU_SetRegionEx(MPU_NS, rnr, rbar, rlar); +} +#endif + +/** Memcopy with strictly ordered memory access, e.g. for register targets. +* \param dst Destination data is copied to. +* \param src Source data is copied from. +* \param len Amount of data words to be copied. +*/ +__STATIC_INLINE void orderedCpy(volatile uint32_t* dst, const uint32_t* __RESTRICT src, uint32_t len) +{ + uint32_t i; + for (i = 0U; i < len; ++i) + { + dst[i] = src[i]; + } +} + +/** Load the given number of MPU regions from a table to the given MPU. +* \param mpu Pointer to the MPU registers to be used. +* \param rnr First region number to be configured. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_LoadEx(MPU_Type* mpu, uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt) +{ + const uint32_t rowWordSize = sizeof(ARM_MPU_Region_t)/4U; + if (cnt == 1U) { + mpu->RNR = rnr; + orderedCpy(&(mpu->RBAR), &(table->RBAR), rowWordSize); + } else { + uint32_t rnrBase = rnr & ~(MPU_TYPE_RALIASES-1U); + uint32_t rnrOffset = rnr % MPU_TYPE_RALIASES; + + mpu->RNR = rnrBase; + while ((rnrOffset + cnt) > MPU_TYPE_RALIASES) { + uint32_t c = MPU_TYPE_RALIASES - rnrOffset; + orderedCpy(&(mpu->RBAR)+(rnrOffset*2U), &(table->RBAR), c*rowWordSize); + table += c; + cnt -= c; + rnrOffset = 0U; + rnrBase += MPU_TYPE_RALIASES; + mpu->RNR = rnrBase; + } + + orderedCpy(&(mpu->RBAR)+(rnrOffset*2U), &(table->RBAR), cnt*rowWordSize); + } +} + +/** Load the given number of MPU regions from a table. +* \param rnr First region number to be configured. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_Load(uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt) +{ + ARM_MPU_LoadEx(MPU, rnr, table, cnt); +} + +#ifdef MPU_NS +/** Load the given number of MPU regions from a table to the Non-secure MPU. +* \param rnr First region number to be configured. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_Load_NS(uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt) +{ + ARM_MPU_LoadEx(MPU_NS, rnr, table, cnt); +} +#endif + +#endif + diff --git a/Chapter04/bare/platform/CMSIS/Core/Include/tz_context.h b/Chapter04/bare/platform/CMSIS/Core/Include/tz_context.h new file mode 100644 index 0000000..d4c1474 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Include/tz_context.h @@ -0,0 +1,70 @@ +/****************************************************************************** + * @file tz_context.h + * @brief Context Management for Armv8-M TrustZone + * @version V1.0.1 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef TZ_CONTEXT_H +#define TZ_CONTEXT_H + +#include + +#ifndef TZ_MODULEID_T +#define TZ_MODULEID_T +/// \details Data type that identifies secure software modules called by a process. +typedef uint32_t TZ_ModuleId_t; +#endif + +/// \details TZ Memory ID identifies an allocated memory slot. +typedef uint32_t TZ_MemoryId_t; + +/// Initialize secure context memory system +/// \return execution status (1: success, 0: error) +uint32_t TZ_InitContextSystem_S (void); + +/// Allocate context memory for calling secure software modules in TrustZone +/// \param[in] module identifies software modules called from non-secure mode +/// \return value != 0 id TrustZone memory slot identifier +/// \return value 0 no memory available or internal error +TZ_MemoryId_t TZ_AllocModuleContext_S (TZ_ModuleId_t module); + +/// Free context memory that was previously allocated with \ref TZ_AllocModuleContext_S +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +uint32_t TZ_FreeModuleContext_S (TZ_MemoryId_t id); + +/// Load secure context (called on RTOS thread context switch) +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +uint32_t TZ_LoadContext_S (TZ_MemoryId_t id); + +/// Store secure context (called on RTOS thread context switch) +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +uint32_t TZ_StoreContext_S (TZ_MemoryId_t id); + +#endif // TZ_CONTEXT_H diff --git a/Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/main_s.c b/Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/main_s.c new file mode 100644 index 0000000..cde9ff0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/main_s.c @@ -0,0 +1,58 @@ +/****************************************************************************** + * @file main_s.c + * @brief Code template for secure main function + * @version V1.1.1 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2013-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* Use CMSE intrinsics */ +#include + +#include "RTE_Components.h" +#include CMSIS_device_header + +/* TZ_START_NS: Start address of non-secure application */ +#ifndef TZ_START_NS +#define TZ_START_NS (0x200000U) +#endif + +/* typedef for non-secure callback functions */ +typedef void (*funcptr_void) (void) __attribute__((cmse_nonsecure_call)); + +/* Secure main() */ +int main(void) { + funcptr_void NonSecure_ResetHandler; + + /* Add user setup code for secure part here*/ + + /* Set non-secure main stack (MSP_NS) */ + __TZ_set_MSP_NS(*((uint32_t *)(TZ_START_NS))); + + /* Get non-secure reset handler */ + NonSecure_ResetHandler = (funcptr_void)(*((uint32_t *)((TZ_START_NS) + 4U))); + + /* Start non-secure state software application */ + NonSecure_ResetHandler(); + + /* Non-secure software does not return, this code is not executed */ + while (1) { + __NOP(); + } +} diff --git a/Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/tz_context.c b/Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/tz_context.c new file mode 100644 index 0000000..298bbf7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core/Template/ARMv8-M/tz_context.c @@ -0,0 +1,200 @@ +/****************************************************************************** + * @file tz_context.c + * @brief Context Management for Armv8-M TrustZone - Sample implementation + * @version V1.1.1 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2016-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "RTE_Components.h" +#include CMSIS_device_header +#include "tz_context.h" + +/// Number of process slots (threads may call secure library code) +#ifndef TZ_PROCESS_STACK_SLOTS +#define TZ_PROCESS_STACK_SLOTS 8U +#endif + +/// Stack size of the secure library code +#ifndef TZ_PROCESS_STACK_SIZE +#define TZ_PROCESS_STACK_SIZE 256U +#endif + +typedef struct { + uint32_t sp_top; // stack space top + uint32_t sp_limit; // stack space limit + uint32_t sp; // current stack pointer +} stack_info_t; + +static stack_info_t ProcessStackInfo [TZ_PROCESS_STACK_SLOTS]; +static uint64_t ProcessStackMemory[TZ_PROCESS_STACK_SLOTS][TZ_PROCESS_STACK_SIZE/8U]; +static uint32_t ProcessStackFreeSlot = 0xFFFFFFFFU; + + +/// Initialize secure context memory system +/// \return execution status (1: success, 0: error) +__attribute__((cmse_nonsecure_entry)) +uint32_t TZ_InitContextSystem_S (void) { + uint32_t n; + + if (__get_IPSR() == 0U) { + return 0U; // Thread Mode + } + + for (n = 0U; n < TZ_PROCESS_STACK_SLOTS; n++) { + ProcessStackInfo[n].sp = 0U; + ProcessStackInfo[n].sp_limit = (uint32_t)&ProcessStackMemory[n]; + ProcessStackInfo[n].sp_top = (uint32_t)&ProcessStackMemory[n] + TZ_PROCESS_STACK_SIZE; + *((uint32_t *)ProcessStackMemory[n]) = n + 1U; + } + *((uint32_t *)ProcessStackMemory[--n]) = 0xFFFFFFFFU; + + ProcessStackFreeSlot = 0U; + + // Default process stack pointer and stack limit + __set_PSPLIM((uint32_t)ProcessStackMemory); + __set_PSP ((uint32_t)ProcessStackMemory); + + // Privileged Thread Mode using PSP + __set_CONTROL(0x02U); + + return 1U; // Success +} + + +/// Allocate context memory for calling secure software modules in TrustZone +/// \param[in] module identifies software modules called from non-secure mode +/// \return value != 0 id TrustZone memory slot identifier +/// \return value 0 no memory available or internal error +__attribute__((cmse_nonsecure_entry)) +TZ_MemoryId_t TZ_AllocModuleContext_S (TZ_ModuleId_t module) { + uint32_t slot; + + (void)module; // Ignore (fixed Stack size) + + if (__get_IPSR() == 0U) { + return 0U; // Thread Mode + } + + if (ProcessStackFreeSlot == 0xFFFFFFFFU) { + return 0U; // No slot available + } + + slot = ProcessStackFreeSlot; + ProcessStackFreeSlot = *((uint32_t *)ProcessStackMemory[slot]); + + ProcessStackInfo[slot].sp = ProcessStackInfo[slot].sp_top; + + return (slot + 1U); +} + + +/// Free context memory that was previously allocated with \ref TZ_AllocModuleContext_S +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +__attribute__((cmse_nonsecure_entry)) +uint32_t TZ_FreeModuleContext_S (TZ_MemoryId_t id) { + uint32_t slot; + + if (__get_IPSR() == 0U) { + return 0U; // Thread Mode + } + + if ((id == 0U) || (id > TZ_PROCESS_STACK_SLOTS)) { + return 0U; // Invalid ID + } + + slot = id - 1U; + + if (ProcessStackInfo[slot].sp == 0U) { + return 0U; // Inactive slot + } + ProcessStackInfo[slot].sp = 0U; + + *((uint32_t *)ProcessStackMemory[slot]) = ProcessStackFreeSlot; + ProcessStackFreeSlot = slot; + + return 1U; // Success +} + + +/// Load secure context (called on RTOS thread context switch) +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +__attribute__((cmse_nonsecure_entry)) +uint32_t TZ_LoadContext_S (TZ_MemoryId_t id) { + uint32_t slot; + + if ((__get_IPSR() == 0U) || ((__get_CONTROL() & 2U) == 0U)) { + return 0U; // Thread Mode or using Main Stack for threads + } + + if ((id == 0U) || (id > TZ_PROCESS_STACK_SLOTS)) { + return 0U; // Invalid ID + } + + slot = id - 1U; + + if (ProcessStackInfo[slot].sp == 0U) { + return 0U; // Inactive slot + } + + // Setup process stack pointer and stack limit + __set_PSPLIM(ProcessStackInfo[slot].sp_limit); + __set_PSP (ProcessStackInfo[slot].sp); + + return 1U; // Success +} + + +/// Store secure context (called on RTOS thread context switch) +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +__attribute__((cmse_nonsecure_entry)) +uint32_t TZ_StoreContext_S (TZ_MemoryId_t id) { + uint32_t slot; + uint32_t sp; + + if ((__get_IPSR() == 0U) || ((__get_CONTROL() & 2U) == 0U)) { + return 0U; // Thread Mode or using Main Stack for threads + } + + if ((id == 0U) || (id > TZ_PROCESS_STACK_SLOTS)) { + return 0U; // Invalid ID + } + + slot = id - 1U; + + if (ProcessStackInfo[slot].sp == 0U) { + return 0U; // Inactive slot + } + + sp = __get_PSP(); + if ((sp < ProcessStackInfo[slot].sp_limit) || + (sp > ProcessStackInfo[slot].sp_top)) { + return 0U; // SP out of range + } + ProcessStackInfo[slot].sp = sp; + + // Default process stack pointer and stack limit + __set_PSPLIM((uint32_t)ProcessStackMemory); + __set_PSP ((uint32_t)ProcessStackMemory); + + return 1U; // Success +} diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armcc.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armcc.h new file mode 100644 index 0000000..b2ccb1f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armcc.h @@ -0,0 +1,544 @@ +/**************************************************************************//** + * @file cmsis_armcc.h + * @brief CMSIS compiler specific macros, functions, instructions + * @version V1.0.2 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_ARMCC_H +#define __CMSIS_ARMCC_H + +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 400677) + #error "Please use Arm Compiler Toolchain V4.0.677 or later!" +#endif + +/* CMSIS compiler control architecture macros */ +#if (defined (__TARGET_ARCH_7_A ) && (__TARGET_ARCH_7_A == 1)) + #define __ARM_ARCH_7A__ 1 +#endif + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE __inline +#endif +#ifndef __FORCEINLINE + #define __FORCEINLINE __forceinline +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static __inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE static __forceinline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __declspec(noreturn) +#endif +#ifndef CMSIS_DEPRECATED + #define CMSIS_DEPRECATED __attribute__((deprecated)) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed)) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT __packed struct +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #define __UNALIGNED_UINT16_WRITE(addr, val) ((*((__packed uint16_t *)(addr))) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #define __UNALIGNED_UINT16_READ(addr) (*((const __packed uint16_t *)(addr))) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #define __UNALIGNED_UINT32_WRITE(addr, val) ((*((__packed uint32_t *)(addr))) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #define __UNALIGNED_UINT32_READ(addr) (*((const __packed uint32_t *)(addr))) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed)) +#endif + +/* ########################## Core Instruction Access ######################### */ +/** + \brief No Operation + */ +#define __NOP __nop + +/** + \brief Wait For Interrupt + */ +#define __WFI __wfi + +/** + \brief Wait For Event + */ +#define __WFE __wfe + +/** + \brief Send Event + */ +#define __SEV __sev + +/** + \brief Instruction Synchronization Barrier + */ +#define __ISB() do {\ + __schedule_barrier();\ + __isb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Synchronization Barrier + */ +#define __DSB() do {\ + __schedule_barrier();\ + __dsb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Memory Barrier + */ +#define __DMB() do {\ + __schedule_barrier();\ + __dmb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV __rev + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".rev16_text"))) __STATIC_INLINE __ASM uint32_t __REV16(uint32_t value) +{ + rev16 r0, r0 + bx lr +} +#endif + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".revsh_text"))) __STATIC_INLINE __ASM int16_t __REVSH(int16_t value) +{ + revsh r0, r0 + bx lr +} +#endif + +/** + \brief Rotate Right in unsigned value (32 bit) + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +#define __ROR __ror + +/** + \brief Breakpoint + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __breakpoint(value) + +/** + \brief Reverse bit order of value + \param [in] value Value to reverse + \return Reversed value + */ +#define __RBIT __rbit + +/** + \brief Count leading zeros + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ __clz + +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXB(ptr) ((uint8_t ) __ldrex(ptr)) +#else + #define __LDREXB(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint8_t ) __ldrex(ptr)) _Pragma("pop") +#endif + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXH(ptr) ((uint16_t) __ldrex(ptr)) +#else + #define __LDREXH(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint16_t) __ldrex(ptr)) _Pragma("pop") +#endif + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXW(ptr) ((uint32_t ) __ldrex(ptr)) +#else + #define __LDREXW(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint32_t ) __ldrex(ptr)) _Pragma("pop") +#endif + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXB(value, ptr) __strex(value, ptr) +#else + #define __STREXB(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXH(value, ptr) __strex(value, ptr) +#else + #define __STREXH(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXW(value, ptr) __strex(value, ptr) +#else + #define __STREXW(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +#define __CLREX __clrex + + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT __ssat + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT __usat + +/* ########################### Core Function Access ########################### */ + +/** + \brief Get FPSCR (Floating Point Status/Control) + \return Floating Point Status/Control register value + */ +__STATIC_INLINE uint32_t __get_FPSCR(void) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + register uint32_t __regfpscr __ASM("fpscr"); + return(__regfpscr); +#else + return(0U); +#endif +} + +/** + \brief Set FPSCR (Floating Point Status/Control) + \param [in] fpscr Floating Point Status/Control value to set + */ +__STATIC_INLINE void __set_FPSCR(uint32_t fpscr) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + register uint32_t __regfpscr __ASM("fpscr"); + __regfpscr = (fpscr); +#else + (void)fpscr; +#endif +} + +/** \brief Get CPSR (Current Program Status Register) + \return CPSR Register value + */ +__STATIC_INLINE uint32_t __get_CPSR(void) +{ + register uint32_t __regCPSR __ASM("cpsr"); + return(__regCPSR); +} + + +/** \brief Set CPSR (Current Program Status Register) + \param [in] cpsr CPSR value to set + */ +__STATIC_INLINE void __set_CPSR(uint32_t cpsr) +{ + register uint32_t __regCPSR __ASM("cpsr"); + __regCPSR = cpsr; +} + +/** \brief Get Mode + \return Processor Mode + */ +__STATIC_INLINE uint32_t __get_mode(void) +{ + return (__get_CPSR() & 0x1FU); +} + +/** \brief Set Mode + \param [in] mode Mode value to set + */ +__STATIC_INLINE __ASM void __set_mode(uint32_t mode) +{ + MOV r1, lr + MSR CPSR_C, r0 + BX r1 +} + +/** \brief Get Stack Pointer + \return Stack Pointer + */ +__STATIC_INLINE __ASM uint32_t __get_SP(void) +{ + MOV r0, sp + BX lr +} + +/** \brief Set Stack Pointer + \param [in] stack Stack Pointer value to set + */ +__STATIC_INLINE __ASM void __set_SP(uint32_t stack) +{ + MOV sp, r0 + BX lr +} + + +/** \brief Get USR/SYS Stack Pointer + \return USR/SYSStack Pointer + */ +__STATIC_INLINE __ASM uint32_t __get_SP_usr(void) +{ + ARM + PRESERVE8 + + MRS R1, CPSR + CPS #0x1F ;no effect in USR mode + MOV R0, SP + MSR CPSR_c, R1 ;no effect in USR mode + ISB + BX LR +} + +/** \brief Set USR/SYS Stack Pointer + \param [in] topOfProcStack USR/SYS Stack Pointer value to set + */ +__STATIC_INLINE __ASM void __set_SP_usr(uint32_t topOfProcStack) +{ + ARM + PRESERVE8 + + MRS R1, CPSR + CPS #0x1F ;no effect in USR mode + MOV SP, R0 + MSR CPSR_c, R1 ;no effect in USR mode + ISB + BX LR +} + +/** \brief Get FPEXC (Floating Point Exception Control Register) + \return Floating Point Exception Control Register value + */ +__STATIC_INLINE uint32_t __get_FPEXC(void) +{ +#if (__FPU_PRESENT == 1) + register uint32_t __regfpexc __ASM("fpexc"); + return(__regfpexc); +#else + return(0); +#endif +} + +/** \brief Set FPEXC (Floating Point Exception Control Register) + \param [in] fpexc Floating Point Exception Control value to set + */ +__STATIC_INLINE void __set_FPEXC(uint32_t fpexc) +{ +#if (__FPU_PRESENT == 1) + register uint32_t __regfpexc __ASM("fpexc"); + __regfpexc = (fpexc); +#endif +} + +/* + * Include common core functions to access Coprocessor 15 registers + */ + +#define __get_CP(cp, op1, Rt, CRn, CRm, op2) do { register volatile uint32_t tmp __ASM("cp" # cp ":" # op1 ":c" # CRn ":c" # CRm ":" # op2); (Rt) = tmp; } while(0) +#define __set_CP(cp, op1, Rt, CRn, CRm, op2) do { register volatile uint32_t tmp __ASM("cp" # cp ":" # op1 ":c" # CRn ":c" # CRm ":" # op2); tmp = (Rt); } while(0) +#define __get_CP64(cp, op1, Rt, CRm) \ + do { \ + uint32_t ltmp, htmp; \ + __ASM volatile("MRRC p" # cp ", " # op1 ", ltmp, htmp, c" # CRm); \ + (Rt) = ((((uint64_t)htmp) << 32U) | ((uint64_t)ltmp)); \ + } while(0) + +#define __set_CP64(cp, op1, Rt, CRm) \ + do { \ + const uint64_t tmp = (Rt); \ + const uint32_t ltmp = (uint32_t)(tmp); \ + const uint32_t htmp = (uint32_t)(tmp >> 32U); \ + __ASM volatile("MCRR p" # cp ", " # op1 ", ltmp, htmp, c" # CRm); \ + } while(0) + +#include "cmsis_cp15.h" + +/** \brief Enable Floating Point Unit + + Critical section, called from undef handler, so systick is disabled + */ +__STATIC_INLINE __ASM void __FPU_Enable(void) +{ + ARM + + //Permit access to VFP/NEON, registers by modifying CPACR + MRC p15,0,R1,c1,c0,2 + ORR R1,R1,#0x00F00000 + MCR p15,0,R1,c1,c0,2 + + //Ensure that subsequent instructions occur in the context of VFP/NEON access permitted + ISB + + //Enable VFP/NEON + VMRS R1,FPEXC + ORR R1,R1,#0x40000000 + VMSR FPEXC,R1 + + //Initialise VFP/NEON registers to 0 + MOV R2,#0 + + //Initialise D16 registers to 0 + VMOV D0, R2,R2 + VMOV D1, R2,R2 + VMOV D2, R2,R2 + VMOV D3, R2,R2 + VMOV D4, R2,R2 + VMOV D5, R2,R2 + VMOV D6, R2,R2 + VMOV D7, R2,R2 + VMOV D8, R2,R2 + VMOV D9, R2,R2 + VMOV D10,R2,R2 + VMOV D11,R2,R2 + VMOV D12,R2,R2 + VMOV D13,R2,R2 + VMOV D14,R2,R2 + VMOV D15,R2,R2 + + IF {TARGET_FEATURE_EXTENSION_REGISTER_COUNT} == 32 + //Initialise D32 registers to 0 + VMOV D16,R2,R2 + VMOV D17,R2,R2 + VMOV D18,R2,R2 + VMOV D19,R2,R2 + VMOV D20,R2,R2 + VMOV D21,R2,R2 + VMOV D22,R2,R2 + VMOV D23,R2,R2 + VMOV D24,R2,R2 + VMOV D25,R2,R2 + VMOV D26,R2,R2 + VMOV D27,R2,R2 + VMOV D28,R2,R2 + VMOV D29,R2,R2 + VMOV D30,R2,R2 + VMOV D31,R2,R2 + ENDIF + + //Initialise FPSCR to a known state + VMRS R2,FPSCR + LDR R3,=0x00086060 //Mask off all bits that do not have to be preserved. Non-preserved bits can/should be zero. + AND R2,R2,R3 + VMSR FPSCR,R2 + + BX LR +} + +#endif /* __CMSIS_ARMCC_H */ diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armclang.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armclang.h new file mode 100644 index 0000000..e0de5a4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_armclang.h @@ -0,0 +1,503 @@ +/**************************************************************************//** + * @file cmsis_armclang.h + * @brief CMSIS compiler specific macros, functions, instructions + * @version V1.0.2 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_ARMCLANG_H +#define __CMSIS_ARMCLANG_H + +#pragma clang system_header /* treat file as system include file */ + +#ifndef __ARM_COMPAT_H +#include /* Compatibility header for Arm Compiler 5 intrinsics */ +#endif + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE __inline +#endif +#ifndef __FORCEINLINE + #define __FORCEINLINE __attribute__((always_inline)) +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static __inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __attribute__((always_inline)) static __inline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __attribute__((__noreturn__)) +#endif +#ifndef CMSIS_DEPRECATED + #define CMSIS_DEPRECATED __attribute__((deprecated)) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_WRITE */ + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_READ)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_READ */ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32_WRITE */ + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed)) +#endif + +/* ########################## Core Instruction Access ######################### */ +/** + \brief No Operation + */ +#define __NOP __builtin_arm_nop + +/** + \brief Wait For Interrupt + */ +#define __WFI __builtin_arm_wfi + +/** + \brief Wait For Event + */ +#define __WFE __builtin_arm_wfe + +/** + \brief Send Event + */ +#define __SEV __builtin_arm_sev + +/** + \brief Instruction Synchronization Barrier + */ +#define __ISB() do {\ + __schedule_barrier();\ + __builtin_arm_isb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Synchronization Barrier + */ +#define __DSB() do {\ + __schedule_barrier();\ + __builtin_arm_dsb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Memory Barrier + */ +#define __DMB() do {\ + __schedule_barrier();\ + __builtin_arm_dmb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV(value) __builtin_bswap32(value) + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV16(value) __ROR(__REV(value), 16) + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REVSH(value) (int16_t)__builtin_bswap16(value) + + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __ROR(uint32_t op1, uint32_t op2) +{ + op2 %= 32U; + if (op2 == 0U) + { + return op1; + } + return (op1 >> op2) | (op1 << (32U - op2)); +} + + +/** + \brief Breakpoint + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __ASM volatile ("bkpt "#value) + +/** + \brief Reverse bit order of value + \param [in] value Value to reverse + \return Reversed value + */ +#define __RBIT __builtin_arm_rbit + +/** + \brief Count leading zeros + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ (uint8_t)__builtin_clz + +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#define __LDREXB (uint8_t)__builtin_arm_ldrex + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#define __LDREXH (uint16_t)__builtin_arm_ldrex + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#define __LDREXW (uint32_t)__builtin_arm_ldrex + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXB (uint32_t)__builtin_arm_strex + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXH (uint32_t)__builtin_arm_strex + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXW (uint32_t)__builtin_arm_strex + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +#define __CLREX __builtin_arm_clrex + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT __builtin_arm_ssat + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT __builtin_arm_usat + + +/* ########################### Core Function Access ########################### */ + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value + */ +#define __get_FPSCR __builtin_arm_get_fpscr + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set + */ +#define __set_FPSCR __builtin_arm_set_fpscr + +/** \brief Get CPSR Register + \return CPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CPSR(void) +{ + uint32_t result; + __ASM volatile("MRS %0, cpsr" : "=r" (result) ); + return(result); +} + +/** \brief Set CPSR Register + \param [in] cpsr CPSR value to set + */ +__STATIC_FORCEINLINE void __set_CPSR(uint32_t cpsr) +{ +__ASM volatile ("MSR cpsr, %0" : : "r" (cpsr) : "memory"); +} + +/** \brief Get Mode + \return Processor Mode + */ +__STATIC_FORCEINLINE uint32_t __get_mode(void) +{ + return (__get_CPSR() & 0x1FU); +} + +/** \brief Set Mode + \param [in] mode Mode value to set + */ +__STATIC_FORCEINLINE void __set_mode(uint32_t mode) +{ + __ASM volatile("MSR cpsr_c, %0" : : "r" (mode) : "memory"); +} + +/** \brief Get Stack Pointer + \return Stack Pointer value + */ +__STATIC_FORCEINLINE uint32_t __get_SP() +{ + uint32_t result; + __ASM volatile("MOV %0, sp" : "=r" (result) : : "memory"); + return result; +} + +/** \brief Set Stack Pointer + \param [in] stack Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_SP(uint32_t stack) +{ + __ASM volatile("MOV sp, %0" : : "r" (stack) : "memory"); +} + +/** \brief Get USR/SYS Stack Pointer + \return USR/SYS Stack Pointer value + */ +__STATIC_FORCEINLINE uint32_t __get_SP_usr() +{ + uint32_t cpsr; + uint32_t result; + __ASM volatile( + "MRS %0, cpsr \n" + "CPS #0x1F \n" // no effect in USR mode + "MOV %1, sp \n" + "MSR cpsr_c, %2 \n" // no effect in USR mode + "ISB" : "=r"(cpsr), "=r"(result) : "r"(cpsr) : "memory" + ); + return result; +} + +/** \brief Set USR/SYS Stack Pointer + \param [in] topOfProcStack USR/SYS Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_SP_usr(uint32_t topOfProcStack) +{ + uint32_t cpsr; + __ASM volatile( + "MRS %0, cpsr \n" + "CPS #0x1F \n" // no effect in USR mode + "MOV sp, %1 \n" + "MSR cpsr_c, %2 \n" // no effect in USR mode + "ISB" : "=r"(cpsr) : "r" (topOfProcStack), "r"(cpsr) : "memory" + ); +} + +/** \brief Get FPEXC + \return Floating Point Exception Control register value + */ +__STATIC_FORCEINLINE uint32_t __get_FPEXC(void) +{ +#if (__FPU_PRESENT == 1) + uint32_t result; + __ASM volatile("VMRS %0, fpexc" : "=r" (result) : : "memory"); + return(result); +#else + return(0); +#endif +} + +/** \brief Set FPEXC + \param [in] fpexc Floating Point Exception Control value to set + */ +__STATIC_FORCEINLINE void __set_FPEXC(uint32_t fpexc) +{ +#if (__FPU_PRESENT == 1) + __ASM volatile ("VMSR fpexc, %0" : : "r" (fpexc) : "memory"); +#endif +} + +/* + * Include common core functions to access Coprocessor 15 registers + */ + +#define __get_CP(cp, op1, Rt, CRn, CRm, op2) __ASM volatile("MRC p" # cp ", " # op1 ", %0, c" # CRn ", c" # CRm ", " # op2 : "=r" (Rt) : : "memory" ) +#define __set_CP(cp, op1, Rt, CRn, CRm, op2) __ASM volatile("MCR p" # cp ", " # op1 ", %0, c" # CRn ", c" # CRm ", " # op2 : : "r" (Rt) : "memory" ) +#define __get_CP64(cp, op1, Rt, CRm) __ASM volatile("MRRC p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : "=r" (Rt) : : "memory" ) +#define __set_CP64(cp, op1, Rt, CRm) __ASM volatile("MCRR p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : : "r" (Rt) : "memory" ) + +#include "cmsis_cp15.h" + +/** \brief Enable Floating Point Unit + + Critical section, called from undef handler, so systick is disabled + */ +__STATIC_INLINE void __FPU_Enable(void) +{ + __ASM volatile( + //Permit access to VFP/NEON, registers by modifying CPACR + " MRC p15,0,R1,c1,c0,2 \n" + " ORR R1,R1,#0x00F00000 \n" + " MCR p15,0,R1,c1,c0,2 \n" + + //Ensure that subsequent instructions occur in the context of VFP/NEON access permitted + " ISB \n" + + //Enable VFP/NEON + " VMRS R1,FPEXC \n" + " ORR R1,R1,#0x40000000 \n" + " VMSR FPEXC,R1 \n" + + //Initialise VFP/NEON registers to 0 + " MOV R2,#0 \n" + + //Initialise D16 registers to 0 + " VMOV D0, R2,R2 \n" + " VMOV D1, R2,R2 \n" + " VMOV D2, R2,R2 \n" + " VMOV D3, R2,R2 \n" + " VMOV D4, R2,R2 \n" + " VMOV D5, R2,R2 \n" + " VMOV D6, R2,R2 \n" + " VMOV D7, R2,R2 \n" + " VMOV D8, R2,R2 \n" + " VMOV D9, R2,R2 \n" + " VMOV D10,R2,R2 \n" + " VMOV D11,R2,R2 \n" + " VMOV D12,R2,R2 \n" + " VMOV D13,R2,R2 \n" + " VMOV D14,R2,R2 \n" + " VMOV D15,R2,R2 \n" + +#if __ARM_NEON == 1 + //Initialise D32 registers to 0 + " VMOV D16,R2,R2 \n" + " VMOV D17,R2,R2 \n" + " VMOV D18,R2,R2 \n" + " VMOV D19,R2,R2 \n" + " VMOV D20,R2,R2 \n" + " VMOV D21,R2,R2 \n" + " VMOV D22,R2,R2 \n" + " VMOV D23,R2,R2 \n" + " VMOV D24,R2,R2 \n" + " VMOV D25,R2,R2 \n" + " VMOV D26,R2,R2 \n" + " VMOV D27,R2,R2 \n" + " VMOV D28,R2,R2 \n" + " VMOV D29,R2,R2 \n" + " VMOV D30,R2,R2 \n" + " VMOV D31,R2,R2 \n" +#endif + + //Initialise FPSCR to a known state + " VMRS R2,FPSCR \n" + " LDR R3,=0x00086060 \n" //Mask off all bits that do not have to be preserved. Non-preserved bits can/should be zero. + " AND R2,R2,R3 \n" + " VMSR FPSCR,R2 " + ); +} + +#endif /* __CMSIS_ARMCLANG_H */ diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_compiler.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_compiler.h new file mode 100644 index 0000000..cd14cbc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_compiler.h @@ -0,0 +1,201 @@ +/**************************************************************************//** + * @file cmsis_compiler.h + * @brief CMSIS compiler specific macros, functions, instructions + * @version V1.0.2 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_COMPILER_H +#define __CMSIS_COMPILER_H + +#include + +/* + * Arm Compiler 4/5 + */ +#if defined ( __CC_ARM ) + #include "cmsis_armcc.h" + + +/* + * Arm Compiler 6 (armclang) + */ +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #include "cmsis_armclang.h" + + +/* + * GNU Compiler + */ +#elif defined ( __GNUC__ ) + #include "cmsis_gcc.h" + + +/* + * IAR Compiler + */ +#elif defined ( __ICCARM__ ) + #include "cmsis_iccarm.h" + + +/* + * TI Arm Compiler + */ +#elif defined ( __TI_ARM__ ) + #include + + #ifndef __ASM + #define __ASM __asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + #define __NO_RETURN __attribute__((noreturn)) + #endif + #ifndef CMSIS_DEPRECATED + #define CMSIS_DEPRECATED __attribute__((deprecated)) + #endif + #ifndef __USED + #define __USED __attribute__((used)) + #endif + #ifndef __WEAK + #define __WEAK __attribute__((weak)) + #endif + #ifndef __UNALIGNED_UINT32 + struct __attribute__((packed)) T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) + #endif + #ifndef __PACKED + #define __PACKED __attribute__((packed)) + #endif + + +/* + * TASKING Compiler + */ +#elif defined ( __TASKING__ ) + /* + * The CMSIS functions have been implemented as intrinsics in the compiler. + * Please use "carm -?i" to get an up to date list of all intrinsics, + * Including the CMSIS ones. + */ + + #ifndef __ASM + #define __ASM __asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + #define __NO_RETURN __attribute__((noreturn)) + #endif + #ifndef CMSIS_DEPRECATED + #define CMSIS_DEPRECATED __attribute__((deprecated)) + #endif + #ifndef __USED + #define __USED __attribute__((used)) + #endif + #ifndef __WEAK + #define __WEAK __attribute__((weak)) + #endif + #ifndef __UNALIGNED_UINT32 + struct __packed__ T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __ALIGNED + #define __ALIGNED(x) __align(x) + #endif + #ifndef __PACKED + #define __PACKED __packed__ + #endif + + +/* + * COSMIC Compiler + */ +#elif defined ( __CSMC__ ) + #include + + #ifndef __ASM + #define __ASM _asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + // NO RETURN is automatically detected hence no warning here + #define __NO_RETURN + #endif + #ifndef __USED + #warning No compiler specific solution for __USED. __USED is ignored. + #define __USED + #endif + #ifndef CMSIS_DEPRECATED + #warning No compiler specific solution for CMSIS_DEPRECATED. CMSIS_DEPRECATED is ignored. + #define CMSIS_DEPRECATED + #endif + #ifndef __WEAK + #define __WEAK __weak + #endif + #ifndef __UNALIGNED_UINT32 + @packed struct T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __ALIGNED + #warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored. + #define __ALIGNED(x) + #endif + #ifndef __PACKED + #define __PACKED @packed + #endif + + +#else + #error Unknown compiler. +#endif + + +#endif /* __CMSIS_COMPILER_H */ + diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_cp15.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_cp15.h new file mode 100644 index 0000000..75e57b8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_cp15.h @@ -0,0 +1,514 @@ +/**************************************************************************//** + * @file cmsis_cp15.h + * @brief CMSIS compiler specific macros, functions, instructions + * @version V1.0.1 + * @date 07. Sep 2017 + ******************************************************************************/ +/* + * Copyright (c) 2009-2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CMSIS_CP15_H +#define __CMSIS_CP15_H + +/** \brief Get ACTLR + \return Auxiliary Control register value + */ +__STATIC_FORCEINLINE uint32_t __get_ACTLR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 1, 0, 1); + return(result); +} + +/** \brief Set ACTLR + \param [in] actlr Auxiliary Control value to set + */ +__STATIC_FORCEINLINE void __set_ACTLR(uint32_t actlr) +{ + __set_CP(15, 0, actlr, 1, 0, 1); +} + +/** \brief Get CPACR + \return Coprocessor Access Control register value + */ +__STATIC_FORCEINLINE uint32_t __get_CPACR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 1, 0, 2); + return result; +} + +/** \brief Set CPACR + \param [in] cpacr Coprocessor Access Control value to set + */ +__STATIC_FORCEINLINE void __set_CPACR(uint32_t cpacr) +{ + __set_CP(15, 0, cpacr, 1, 0, 2); +} + +/** \brief Get DFSR + \return Data Fault Status Register value + */ +__STATIC_FORCEINLINE uint32_t __get_DFSR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 5, 0, 0); + return result; +} + +/** \brief Set DFSR + \param [in] dfsr Data Fault Status value to set + */ +__STATIC_FORCEINLINE void __set_DFSR(uint32_t dfsr) +{ + __set_CP(15, 0, dfsr, 5, 0, 0); +} + +/** \brief Get IFSR + \return Instruction Fault Status Register value + */ +__STATIC_FORCEINLINE uint32_t __get_IFSR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 5, 0, 1); + return result; +} + +/** \brief Set IFSR + \param [in] ifsr Instruction Fault Status value to set + */ +__STATIC_FORCEINLINE void __set_IFSR(uint32_t ifsr) +{ + __set_CP(15, 0, ifsr, 5, 0, 1); +} + +/** \brief Get ISR + \return Interrupt Status Register value + */ +__STATIC_FORCEINLINE uint32_t __get_ISR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 12, 1, 0); + return result; +} + +/** \brief Get CBAR + \return Configuration Base Address register value + */ +__STATIC_FORCEINLINE uint32_t __get_CBAR(void) +{ + uint32_t result; + __get_CP(15, 4, result, 15, 0, 0); + return result; +} + +/** \brief Get TTBR0 + + This function returns the value of the Translation Table Base Register 0. + + \return Translation Table Base Register 0 value + */ +__STATIC_FORCEINLINE uint32_t __get_TTBR0(void) +{ + uint32_t result; + __get_CP(15, 0, result, 2, 0, 0); + return result; +} + +/** \brief Set TTBR0 + + This function assigns the given value to the Translation Table Base Register 0. + + \param [in] ttbr0 Translation Table Base Register 0 value to set + */ +__STATIC_FORCEINLINE void __set_TTBR0(uint32_t ttbr0) +{ + __set_CP(15, 0, ttbr0, 2, 0, 0); +} + +/** \brief Get DACR + + This function returns the value of the Domain Access Control Register. + + \return Domain Access Control Register value + */ +__STATIC_FORCEINLINE uint32_t __get_DACR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 3, 0, 0); + return result; +} + +/** \brief Set DACR + + This function assigns the given value to the Domain Access Control Register. + + \param [in] dacr Domain Access Control Register value to set + */ +__STATIC_FORCEINLINE void __set_DACR(uint32_t dacr) +{ + __set_CP(15, 0, dacr, 3, 0, 0); +} + +/** \brief Set SCTLR + + This function assigns the given value to the System Control Register. + + \param [in] sctlr System Control Register value to set + */ +__STATIC_FORCEINLINE void __set_SCTLR(uint32_t sctlr) +{ + __set_CP(15, 0, sctlr, 1, 0, 0); +} + +/** \brief Get SCTLR + \return System Control Register value + */ +__STATIC_FORCEINLINE uint32_t __get_SCTLR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 1, 0, 0); + return result; +} + +/** \brief Set ACTRL + \param [in] actrl Auxiliary Control Register value to set + */ +__STATIC_FORCEINLINE void __set_ACTRL(uint32_t actrl) +{ + __set_CP(15, 0, actrl, 1, 0, 1); +} + +/** \brief Get ACTRL + \return Auxiliary Control Register value + */ +__STATIC_FORCEINLINE uint32_t __get_ACTRL(void) +{ + uint32_t result; + __get_CP(15, 0, result, 1, 0, 1); + return result; +} + +/** \brief Get MPIDR + + This function returns the value of the Multiprocessor Affinity Register. + + \return Multiprocessor Affinity Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MPIDR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 0, 0, 5); + return result; +} + +/** \brief Get VBAR + + This function returns the value of the Vector Base Address Register. + + \return Vector Base Address Register + */ +__STATIC_FORCEINLINE uint32_t __get_VBAR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 12, 0, 0); + return result; +} + +/** \brief Set VBAR + + This function assigns the given value to the Vector Base Address Register. + + \param [in] vbar Vector Base Address Register value to set + */ +__STATIC_FORCEINLINE void __set_VBAR(uint32_t vbar) +{ + __set_CP(15, 0, vbar, 12, 0, 0); +} + +/** \brief Get MVBAR + + This function returns the value of the Monitor Vector Base Address Register. + + \return Monitor Vector Base Address Register + */ +__STATIC_FORCEINLINE uint32_t __get_MVBAR(void) +{ + uint32_t result; + __get_CP(15, 0, result, 12, 0, 1); + return result; +} + +/** \brief Set MVBAR + + This function assigns the given value to the Monitor Vector Base Address Register. + + \param [in] mvbar Monitor Vector Base Address Register value to set + */ +__STATIC_FORCEINLINE void __set_MVBAR(uint32_t mvbar) +{ + __set_CP(15, 0, mvbar, 12, 0, 1); +} + +#if (defined(__CORTEX_A) && (__CORTEX_A == 7U) && \ + defined(__TIM_PRESENT) && (__TIM_PRESENT == 1U)) || \ + defined(DOXYGEN) + +/** \brief Set CNTFRQ + + This function assigns the given value to PL1 Physical Timer Counter Frequency Register (CNTFRQ). + + \param [in] value CNTFRQ Register value to set +*/ +__STATIC_FORCEINLINE void __set_CNTFRQ(uint32_t value) +{ + __set_CP(15, 0, value, 14, 0, 0); +} + +/** \brief Get CNTFRQ + + This function returns the value of the PL1 Physical Timer Counter Frequency Register (CNTFRQ). + + \return CNTFRQ Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CNTFRQ(void) +{ + uint32_t result; + __get_CP(15, 0, result, 14, 0 , 0); + return result; +} + +/** \brief Set CNTP_TVAL + + This function assigns the given value to PL1 Physical Timer Value Register (CNTP_TVAL). + + \param [in] value CNTP_TVAL Register value to set +*/ +__STATIC_FORCEINLINE void __set_CNTP_TVAL(uint32_t value) +{ + __set_CP(15, 0, value, 14, 2, 0); +} + +/** \brief Get CNTP_TVAL + + This function returns the value of the PL1 Physical Timer Value Register (CNTP_TVAL). + + \return CNTP_TVAL Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CNTP_TVAL(void) +{ + uint32_t result; + __get_CP(15, 0, result, 14, 2, 0); + return result; +} + +/** \brief Get CNTPCT + + This function returns the value of the 64 bits PL1 Physical Count Register (CNTPCT). + + \return CNTPCT Register value + */ +__STATIC_FORCEINLINE uint64_t __get_CNTPCT(void) +{ + uint64_t result; + __get_CP64(15, 0, result, 14); + return result; +} + +/** \brief Set CNTP_CVAL + + This function assigns the given value to 64bits PL1 Physical Timer CompareValue Register (CNTP_CVAL). + + \param [in] value CNTP_CVAL Register value to set +*/ +__STATIC_FORCEINLINE void __set_CNTP_CVAL(uint64_t value) +{ + __set_CP64(15, 2, value, 14); +} + +/** \brief Get CNTP_CVAL + + This function returns the value of the 64 bits PL1 Physical Timer CompareValue Register (CNTP_CVAL). + + \return CNTP_CVAL Register value + */ +__STATIC_FORCEINLINE uint64_t __get_CNTP_CVAL(void) +{ + uint64_t result; + __get_CP64(15, 2, result, 14); + return result; +} + +/** \brief Set CNTP_CTL + + This function assigns the given value to PL1 Physical Timer Control Register (CNTP_CTL). + + \param [in] value CNTP_CTL Register value to set +*/ +__STATIC_FORCEINLINE void __set_CNTP_CTL(uint32_t value) +{ + __set_CP(15, 0, value, 14, 2, 1); +} + +/** \brief Get CNTP_CTL register + \return CNTP_CTL Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CNTP_CTL(void) +{ + uint32_t result; + __get_CP(15, 0, result, 14, 2, 1); + return result; +} + +#endif + +/** \brief Set TLBIALL + + TLB Invalidate All + */ +__STATIC_FORCEINLINE void __set_TLBIALL(uint32_t value) +{ + __set_CP(15, 0, value, 8, 7, 0); +} + +/** \brief Set BPIALL. + + Branch Predictor Invalidate All + */ +__STATIC_FORCEINLINE void __set_BPIALL(uint32_t value) +{ + __set_CP(15, 0, value, 7, 5, 6); +} + +/** \brief Set ICIALLU + + Instruction Cache Invalidate All + */ +__STATIC_FORCEINLINE void __set_ICIALLU(uint32_t value) +{ + __set_CP(15, 0, value, 7, 5, 0); +} + +/** \brief Set DCCMVAC + + Data cache clean + */ +__STATIC_FORCEINLINE void __set_DCCMVAC(uint32_t value) +{ + __set_CP(15, 0, value, 7, 10, 1); +} + +/** \brief Set DCIMVAC + + Data cache invalidate + */ +__STATIC_FORCEINLINE void __set_DCIMVAC(uint32_t value) +{ + __set_CP(15, 0, value, 7, 6, 1); +} + +/** \brief Set DCCIMVAC + + Data cache clean and invalidate + */ +__STATIC_FORCEINLINE void __set_DCCIMVAC(uint32_t value) +{ + __set_CP(15, 0, value, 7, 14, 1); +} + +/** \brief Set CSSELR + */ +__STATIC_FORCEINLINE void __set_CSSELR(uint32_t value) +{ +// __ASM volatile("MCR p15, 2, %0, c0, c0, 0" : : "r"(value) : "memory"); + __set_CP(15, 2, value, 0, 0, 0); +} + +/** \brief Get CSSELR + \return CSSELR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CSSELR(void) +{ + uint32_t result; +// __ASM volatile("MRC p15, 2, %0, c0, c0, 0" : "=r"(result) : : "memory"); + __get_CP(15, 2, result, 0, 0, 0); + return result; +} + +/** \brief Set CCSIDR + \deprecated CCSIDR itself is read-only. Use __set_CSSELR to select cache level instead. + */ +CMSIS_DEPRECATED +__STATIC_FORCEINLINE void __set_CCSIDR(uint32_t value) +{ + __set_CSSELR(value); +} + +/** \brief Get CCSIDR + \return CCSIDR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CCSIDR(void) +{ + uint32_t result; +// __ASM volatile("MRC p15, 1, %0, c0, c0, 0" : "=r"(result) : : "memory"); + __get_CP(15, 1, result, 0, 0, 0); + return result; +} + +/** \brief Get CLIDR + \return CLIDR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CLIDR(void) +{ + uint32_t result; +// __ASM volatile("MRC p15, 1, %0, c0, c0, 1" : "=r"(result) : : "memory"); + __get_CP(15, 1, result, 0, 0, 1); + return result; +} + +/** \brief Set DCISW + */ +__STATIC_FORCEINLINE void __set_DCISW(uint32_t value) +{ +// __ASM volatile("MCR p15, 0, %0, c7, c6, 2" : : "r"(value) : "memory") + __set_CP(15, 0, value, 7, 6, 2); +} + +/** \brief Set DCCSW + */ +__STATIC_FORCEINLINE void __set_DCCSW(uint32_t value) +{ +// __ASM volatile("MCR p15, 0, %0, c7, c10, 2" : : "r"(value) : "memory") + __set_CP(15, 0, value, 7, 10, 2); +} + +/** \brief Set DCCISW + */ +__STATIC_FORCEINLINE void __set_DCCISW(uint32_t value) +{ +// __ASM volatile("MCR p15, 0, %0, c7, c14, 2" : : "r"(value) : "memory") + __set_CP(15, 0, value, 7, 14, 2); +} + +#endif diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_gcc.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_gcc.h new file mode 100644 index 0000000..fb1442c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_gcc.h @@ -0,0 +1,679 @@ +/**************************************************************************//** + * @file cmsis_gcc.h + * @brief CMSIS compiler specific macros, functions, instructions + * @version V1.0.2 + * @date 09. April 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_GCC_H +#define __CMSIS_GCC_H + +/* ignore some GCC warnings */ +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wsign-conversion" +#pragma GCC diagnostic ignored "-Wconversion" +#pragma GCC diagnostic ignored "-Wunused-parameter" + +/* Fallback for __has_builtin */ +#ifndef __has_builtin + #define __has_builtin(x) (0) +#endif + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM asm +#endif +#ifndef __INLINE + #define __INLINE inline +#endif +#ifndef __FORCEINLINE + #define __FORCEINLINE __attribute__((always_inline)) +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __attribute__((always_inline)) static inline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __attribute__((__noreturn__)) +#endif +#ifndef CMSIS_DEPRECATED + #define CMSIS_DEPRECATED __attribute__((deprecated)) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_WRITE */ + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_READ)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_READ */ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32_WRITE */ + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif + +/* ########################## Core Instruction Access ######################### */ +/** + \brief No Operation + */ +#define __NOP() __ASM volatile ("nop") + +/** + \brief Wait For Interrupt + */ +#define __WFI() __ASM volatile ("wfi") + +/** + \brief Wait For Event + */ +#define __WFE() __ASM volatile ("wfe") + +/** + \brief Send Event + */ +#define __SEV() __ASM volatile ("sev") + +/** + \brief Instruction Synchronization Barrier + \details Instruction Synchronization Barrier flushes the pipeline in the processor, + so that all instructions following the ISB are fetched from cache or memory, + after the instruction has been completed. + */ +__STATIC_FORCEINLINE void __ISB(void) +{ + __ASM volatile ("isb 0xF":::"memory"); +} + + +/** + \brief Data Synchronization Barrier + \details Acts as a special kind of Data Memory Barrier. + It completes when all explicit memory accesses before this instruction complete. + */ +__STATIC_FORCEINLINE void __DSB(void) +{ + __ASM volatile ("dsb 0xF":::"memory"); +} + +/** + \brief Data Memory Barrier + \details Ensures the apparent order of the explicit memory operations before + and after the instruction, without ensuring their completion. + */ +__STATIC_FORCEINLINE void __DMB(void) +{ + __ASM volatile ("dmb 0xF":::"memory"); +} + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __REV(uint32_t value) +{ +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5) + return __builtin_bswap32(value); +#else + uint32_t result; + + __ASM volatile ("rev %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +#endif +} + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".rev16_text"))) __STATIC_INLINE uint32_t __REV16(uint32_t value) +{ + uint32_t result; + __ASM volatile("rev16 %0, %1" : "=r" (result) : "r" (value)); + return result; +} +#endif + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE int16_t __REVSH(int16_t value) +{ +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + return (int16_t)__builtin_bswap16(value); +#else + int16_t result; + + __ASM volatile ("revsh %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +#endif +} + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __ROR(uint32_t op1, uint32_t op2) +{ + op2 %= 32U; + if (op2 == 0U) { + return op1; + } + return (op1 >> op2) | (op1 << (32U - op2)); +} + + +/** + \brief Breakpoint + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __ASM volatile ("bkpt "#value) + +/** + \brief Reverse bit order of value + \details Reverses the bit order of the given value. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __RBIT(uint32_t value) +{ + uint32_t result; + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) + __ASM volatile ("rbit %0, %1" : "=r" (result) : "r" (value) ); +#else + int32_t s = (4U /*sizeof(v)*/ * 8U) - 1U; /* extra shift needed at end */ + + result = value; /* r will be reversed bits of v; first get LSB of v */ + for (value >>= 1U; value; value >>= 1U) + { + result <<= 1U; + result |= value & 1U; + s--; + } + result <<= s; /* shift when v's highest bits are zero */ +#endif + return result; +} + +/** + \brief Count leading zeros + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ (uint8_t)__builtin_clz + +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDREXB(volatile uint8_t *addr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrexb %0, %1" : "=r" (result) : "Q" (*addr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrexb %0, [%1]" : "=r" (result) : "r" (addr) : "memory" ); +#endif + return ((uint8_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDREXH(volatile uint16_t *addr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrexh %0, %1" : "=r" (result) : "Q" (*addr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrexh %0, [%1]" : "=r" (result) : "r" (addr) : "memory" ); +#endif + return ((uint16_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDREXW(volatile uint32_t *addr) +{ + uint32_t result; + + __ASM volatile ("ldrex %0, %1" : "=r" (result) : "Q" (*addr) ); + return(result); +} + + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXB(uint8_t value, volatile uint8_t *addr) +{ + uint32_t result; + + __ASM volatile ("strexb %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXH(uint16_t value, volatile uint16_t *addr) +{ + uint32_t result; + + __ASM volatile ("strexh %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXW(uint32_t value, volatile uint32_t *addr) +{ + uint32_t result; + + __ASM volatile ("strex %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" (value) ); + return(result); +} + + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +__STATIC_FORCEINLINE void __CLREX(void) +{ + __ASM volatile ("clrex" ::: "memory"); +} + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT(ARG1,ARG2) \ +__extension__ \ +({ \ + int32_t __RES, __ARG1 = (ARG1); \ + __ASM ("ssat %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT(ARG1,ARG2) \ +__extension__ \ +({ \ + uint32_t __RES, __ARG1 = (ARG1); \ + __ASM ("usat %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +/* ########################### Core Function Access ########################### */ + +/** + \brief Enable IRQ Interrupts + \details Enables IRQ interrupts by clearing the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __enable_irq(void) +{ + __ASM volatile ("cpsie i" : : : "memory"); +} + +/** + \brief Disable IRQ Interrupts + \details Disables IRQ interrupts by setting the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __disable_irq(void) +{ + __ASM volatile ("cpsid i" : : : "memory"); +} + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value +*/ +__STATIC_FORCEINLINE uint32_t __get_FPSCR(void) +{ + #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + #if __has_builtin(__builtin_arm_get_fpscr) + // Re-enable using built-in when GCC has been fixed + // || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2) + /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */ + return __builtin_arm_get_fpscr(); + #else + uint32_t result; + + __ASM volatile ("VMRS %0, fpscr" : "=r" (result) ); + return(result); + #endif + #else + return(0U); + #endif +} + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set +*/ +__STATIC_FORCEINLINE void __set_FPSCR(uint32_t fpscr) +{ + #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + #if __has_builtin(__builtin_arm_set_fpscr) + // Re-enable using built-in when GCC has been fixed + // || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2) + /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */ + __builtin_arm_set_fpscr(fpscr); + #else + __ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc", "memory"); + #endif + #else + (void)fpscr; + #endif +} + +/** \brief Get CPSR Register + \return CPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CPSR(void) +{ + uint32_t result; + __ASM volatile("MRS %0, cpsr" : "=r" (result) ); + return(result); +} + +/** \brief Set CPSR Register + \param [in] cpsr CPSR value to set + */ +__STATIC_FORCEINLINE void __set_CPSR(uint32_t cpsr) +{ +__ASM volatile ("MSR cpsr, %0" : : "r" (cpsr) : "memory"); +} + +/** \brief Get Mode + \return Processor Mode + */ +__STATIC_FORCEINLINE uint32_t __get_mode(void) +{ + return (__get_CPSR() & 0x1FU); +} + +/** \brief Set Mode + \param [in] mode Mode value to set + */ +__STATIC_FORCEINLINE void __set_mode(uint32_t mode) +{ + __ASM volatile("MSR cpsr_c, %0" : : "r" (mode) : "memory"); +} + +/** \brief Get Stack Pointer + \return Stack Pointer value + */ +__STATIC_FORCEINLINE uint32_t __get_SP(void) +{ + uint32_t result; + __ASM volatile("MOV %0, sp" : "=r" (result) : : "memory"); + return result; +} + +/** \brief Set Stack Pointer + \param [in] stack Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_SP(uint32_t stack) +{ + __ASM volatile("MOV sp, %0" : : "r" (stack) : "memory"); +} + +/** \brief Get USR/SYS Stack Pointer + \return USR/SYS Stack Pointer value + */ +__STATIC_FORCEINLINE uint32_t __get_SP_usr(void) +{ + uint32_t cpsr = __get_CPSR(); + uint32_t result; + __ASM volatile( + "CPS #0x1F \n" + "MOV %0, sp " : "=r"(result) : : "memory" + ); + __set_CPSR(cpsr); + __ISB(); + return result; +} + +/** \brief Set USR/SYS Stack Pointer + \param [in] topOfProcStack USR/SYS Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_SP_usr(uint32_t topOfProcStack) +{ + uint32_t cpsr = __get_CPSR(); + __ASM volatile( + "CPS #0x1F \n" + "MOV sp, %0 " : : "r" (topOfProcStack) : "memory" + ); + __set_CPSR(cpsr); + __ISB(); +} + +/** \brief Get FPEXC + \return Floating Point Exception Control register value + */ +__STATIC_FORCEINLINE uint32_t __get_FPEXC(void) +{ +#if (__FPU_PRESENT == 1) + uint32_t result; + __ASM volatile("VMRS %0, fpexc" : "=r" (result) ); + return(result); +#else + return(0); +#endif +} + +/** \brief Set FPEXC + \param [in] fpexc Floating Point Exception Control value to set + */ +__STATIC_FORCEINLINE void __set_FPEXC(uint32_t fpexc) +{ +#if (__FPU_PRESENT == 1) + __ASM volatile ("VMSR fpexc, %0" : : "r" (fpexc) : "memory"); +#endif +} + +/* + * Include common core functions to access Coprocessor 15 registers + */ + +#define __get_CP(cp, op1, Rt, CRn, CRm, op2) __ASM volatile("MRC p" # cp ", " # op1 ", %0, c" # CRn ", c" # CRm ", " # op2 : "=r" (Rt) : : "memory" ) +#define __set_CP(cp, op1, Rt, CRn, CRm, op2) __ASM volatile("MCR p" # cp ", " # op1 ", %0, c" # CRn ", c" # CRm ", " # op2 : : "r" (Rt) : "memory" ) +#define __get_CP64(cp, op1, Rt, CRm) __ASM volatile("MRRC p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : "=r" (Rt) : : "memory" ) +#define __set_CP64(cp, op1, Rt, CRm) __ASM volatile("MCRR p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : : "r" (Rt) : "memory" ) + +#include "cmsis_cp15.h" + +/** \brief Enable Floating Point Unit + + Critical section, called from undef handler, so systick is disabled + */ +__STATIC_INLINE void __FPU_Enable(void) +{ + __ASM volatile( + //Permit access to VFP/NEON, registers by modifying CPACR + " MRC p15,0,R1,c1,c0,2 \n" + " ORR R1,R1,#0x00F00000 \n" + " MCR p15,0,R1,c1,c0,2 \n" + + //Ensure that subsequent instructions occur in the context of VFP/NEON access permitted + " ISB \n" + + //Enable VFP/NEON + " VMRS R1,FPEXC \n" + " ORR R1,R1,#0x40000000 \n" + " VMSR FPEXC,R1 \n" + + //Initialise VFP/NEON registers to 0 + " MOV R2,#0 \n" + + //Initialise D16 registers to 0 + " VMOV D0, R2,R2 \n" + " VMOV D1, R2,R2 \n" + " VMOV D2, R2,R2 \n" + " VMOV D3, R2,R2 \n" + " VMOV D4, R2,R2 \n" + " VMOV D5, R2,R2 \n" + " VMOV D6, R2,R2 \n" + " VMOV D7, R2,R2 \n" + " VMOV D8, R2,R2 \n" + " VMOV D9, R2,R2 \n" + " VMOV D10,R2,R2 \n" + " VMOV D11,R2,R2 \n" + " VMOV D12,R2,R2 \n" + " VMOV D13,R2,R2 \n" + " VMOV D14,R2,R2 \n" + " VMOV D15,R2,R2 \n" + +#if (defined(__ARM_NEON) && (__ARM_NEON == 1)) + //Initialise D32 registers to 0 + " VMOV D16,R2,R2 \n" + " VMOV D17,R2,R2 \n" + " VMOV D18,R2,R2 \n" + " VMOV D19,R2,R2 \n" + " VMOV D20,R2,R2 \n" + " VMOV D21,R2,R2 \n" + " VMOV D22,R2,R2 \n" + " VMOV D23,R2,R2 \n" + " VMOV D24,R2,R2 \n" + " VMOV D25,R2,R2 \n" + " VMOV D26,R2,R2 \n" + " VMOV D27,R2,R2 \n" + " VMOV D28,R2,R2 \n" + " VMOV D29,R2,R2 \n" + " VMOV D30,R2,R2 \n" + " VMOV D31,R2,R2 \n" +#endif + + //Initialise FPSCR to a known state + " VMRS R2,FPSCR \n" + " LDR R3,=0x00086060 \n" //Mask off all bits that do not have to be preserved. Non-preserved bits can/should be zero. + " AND R2,R2,R3 \n" + " VMSR FPSCR,R2 " + ); +} + +#pragma GCC diagnostic pop + +#endif /* __CMSIS_GCC_H */ diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_iccarm.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_iccarm.h new file mode 100644 index 0000000..c46c397 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/cmsis_iccarm.h @@ -0,0 +1,559 @@ +/**************************************************************************//** + * @file cmsis_iccarm.h + * @brief CMSIS compiler ICCARM (IAR Compiler for Arm) header file + * @version V5.0.6 + * @date 02. March 2018 + ******************************************************************************/ + +//------------------------------------------------------------------------------ +// +// Copyright (c) 2017-2018 IAR Systems +// +// Licensed under the Apache License, Version 2.0 (the "License") +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +//------------------------------------------------------------------------------ + + +#ifndef __CMSIS_ICCARM_H__ +#define __CMSIS_ICCARM_H__ + +#ifndef __ICCARM__ + #error This file should only be compiled by ICCARM +#endif + +#pragma system_include + +#define __IAR_FT _Pragma("inline=forced") __intrinsic + +#if (__VER__ >= 8000000) + #define __ICCARM_V8 1 +#else + #define __ICCARM_V8 0 +#endif + +#pragma language=extended + +#ifndef __ALIGNED + #if __ICCARM_V8 + #define __ALIGNED(x) __attribute__((aligned(x))) + #elif (__VER__ >= 7080000) + /* Needs IAR language extensions */ + #define __ALIGNED(x) __attribute__((aligned(x))) + #else + #warning No compiler specific solution for __ALIGNED.__ALIGNED is ignored. + #define __ALIGNED(x) + #endif +#endif + + +/* Define compiler macros for CPU architecture, used in CMSIS 5. + */ +#if __ARM_ARCH_7A__ +/* Macro already defined */ +#else + #if defined(__ARM7A__) + #define __ARM_ARCH_7A__ 1 + #endif +#endif + +#ifndef __ASM + #define __ASM __asm +#endif + +#ifndef __INLINE + #define __INLINE inline +#endif + +#ifndef __NO_RETURN + #if __ICCARM_V8 + #define __NO_RETURN __attribute__((__noreturn__)) + #else + #define __NO_RETURN _Pragma("object_attribute=__noreturn") + #endif +#endif + +#ifndef __PACKED + /* Needs IAR language extensions */ + #if __ICCARM_V8 + #define __PACKED __attribute__((packed, aligned(1))) + #else + #define __PACKED __packed + #endif +#endif + +#ifndef __PACKED_STRUCT + /* Needs IAR language extensions */ + #if __ICCARM_V8 + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) + #else + #define __PACKED_STRUCT __packed struct + #endif +#endif + +#ifndef __PACKED_UNION + /* Needs IAR language extensions */ + #if __ICCARM_V8 + #define __PACKED_UNION union __attribute__((packed, aligned(1))) + #else + #define __PACKED_UNION __packed union + #endif +#endif + +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline +#endif + +#ifndef __FORCEINLINE + #define __FORCEINLINE _Pragma("inline=forced") +#endif + +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __FORCEINLINE __STATIC_INLINE +#endif + +#ifndef CMSIS_DEPRECATED + #define CMSIS_DEPRECATED __attribute__((deprecated)) +#endif + +#ifndef __UNALIGNED_UINT16_READ + #pragma language=save + #pragma language=extended + __IAR_FT uint16_t __iar_uint16_read(void const *ptr) + { + return *(__packed uint16_t*)(ptr); + } + #pragma language=restore + #define __UNALIGNED_UINT16_READ(PTR) __iar_uint16_read(PTR) +#endif + + +#ifndef __UNALIGNED_UINT16_WRITE + #pragma language=save + #pragma language=extended + __IAR_FT void __iar_uint16_write(void const *ptr, uint16_t val) + { + *(__packed uint16_t*)(ptr) = val;; + } + #pragma language=restore + #define __UNALIGNED_UINT16_WRITE(PTR,VAL) __iar_uint16_write(PTR,VAL) +#endif + +#ifndef __UNALIGNED_UINT32_READ + #pragma language=save + #pragma language=extended + __IAR_FT uint32_t __iar_uint32_read(void const *ptr) + { + return *(__packed uint32_t*)(ptr); + } + #pragma language=restore + #define __UNALIGNED_UINT32_READ(PTR) __iar_uint32_read(PTR) +#endif + +#ifndef __UNALIGNED_UINT32_WRITE + #pragma language=save + #pragma language=extended + __IAR_FT void __iar_uint32_write(void const *ptr, uint32_t val) + { + *(__packed uint32_t*)(ptr) = val;; + } + #pragma language=restore + #define __UNALIGNED_UINT32_WRITE(PTR,VAL) __iar_uint32_write(PTR,VAL) +#endif + +#if 0 +#ifndef __UNALIGNED_UINT32 /* deprecated */ + #pragma language=save + #pragma language=extended + __packed struct __iar_u32 { uint32_t v; }; + #pragma language=restore + #define __UNALIGNED_UINT32(PTR) (((struct __iar_u32 *)(PTR))->v) +#endif +#endif + +#ifndef __USED + #if __ICCARM_V8 + #define __USED __attribute__((used)) + #else + #define __USED _Pragma("__root") + #endif +#endif + +#ifndef __WEAK + #if __ICCARM_V8 + #define __WEAK __attribute__((weak)) + #else + #define __WEAK _Pragma("__weak") + #endif +#endif + + +#ifndef __ICCARM_INTRINSICS_VERSION__ + #define __ICCARM_INTRINSICS_VERSION__ 0 +#endif + +#if __ICCARM_INTRINSICS_VERSION__ == 2 + + #if defined(__CLZ) + #undef __CLZ + #endif + #if defined(__REVSH) + #undef __REVSH + #endif + #if defined(__RBIT) + #undef __RBIT + #endif + #if defined(__SSAT) + #undef __SSAT + #endif + #if defined(__USAT) + #undef __USAT + #endif + + #include "iccarm_builtin.h" + + #define __enable_irq __iar_builtin_enable_interrupt + #define __disable_irq __iar_builtin_disable_interrupt + #define __enable_fault_irq __iar_builtin_enable_fiq + #define __disable_fault_irq __iar_builtin_disable_fiq + #define __arm_rsr __iar_builtin_rsr + #define __arm_wsr __iar_builtin_wsr + + #if __FPU_PRESENT + #define __get_FPSCR() (__arm_rsr("FPSCR")) + #else + #define __get_FPSCR() ( 0 ) + #endif + + #define __set_FPSCR(VALUE) (__arm_wsr("FPSCR", VALUE)) + + #define __get_CPSR() (__arm_rsr("CPSR")) + #define __get_mode() (__get_CPSR() & 0x1FU) + + #define __set_CPSR(VALUE) (__arm_wsr("CPSR", (VALUE))) + #define __set_mode(VALUE) (__arm_wsr("CPSR_c", (VALUE))) + + + #define __get_FPEXC() (__arm_rsr("FPEXC")) + #define __set_FPEXC(VALUE) (__arm_wsr("FPEXC", VALUE)) + + #define __get_CP(cp, op1, RT, CRn, CRm, op2) \ + ((RT) = __arm_rsr("p" # cp ":" # op1 ":c" # CRn ":c" # CRm ":" # op2)) + + #define __set_CP(cp, op1, RT, CRn, CRm, op2) \ + (__arm_wsr("p" # cp ":" # op1 ":c" # CRn ":c" # CRm ":" # op2, (RT))) + + #define __get_CP64(cp, op1, Rt, CRm) \ + __ASM volatile("MRRC p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : "=r" (Rt) : : "memory" ) + + #define __set_CP64(cp, op1, Rt, CRm) \ + __ASM volatile("MCRR p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : : "r" (Rt) : "memory" ) + + #include "cmsis_cp15.h" + + #define __NOP __iar_builtin_no_operation + + #define __CLZ __iar_builtin_CLZ + #define __CLREX __iar_builtin_CLREX + + #define __DMB __iar_builtin_DMB + #define __DSB __iar_builtin_DSB + #define __ISB __iar_builtin_ISB + + #define __LDREXB __iar_builtin_LDREXB + #define __LDREXH __iar_builtin_LDREXH + #define __LDREXW __iar_builtin_LDREX + + #define __RBIT __iar_builtin_RBIT + #define __REV __iar_builtin_REV + #define __REV16 __iar_builtin_REV16 + + __IAR_FT int16_t __REVSH(int16_t val) + { + return (int16_t) __iar_builtin_REVSH(val); + } + + #define __ROR __iar_builtin_ROR + #define __RRX __iar_builtin_RRX + + #define __SEV __iar_builtin_SEV + + #define __SSAT __iar_builtin_SSAT + + #define __STREXB __iar_builtin_STREXB + #define __STREXH __iar_builtin_STREXH + #define __STREXW __iar_builtin_STREX + + #define __USAT __iar_builtin_USAT + + #define __WFE __iar_builtin_WFE + #define __WFI __iar_builtin_WFI + + #define __SADD8 __iar_builtin_SADD8 + #define __QADD8 __iar_builtin_QADD8 + #define __SHADD8 __iar_builtin_SHADD8 + #define __UADD8 __iar_builtin_UADD8 + #define __UQADD8 __iar_builtin_UQADD8 + #define __UHADD8 __iar_builtin_UHADD8 + #define __SSUB8 __iar_builtin_SSUB8 + #define __QSUB8 __iar_builtin_QSUB8 + #define __SHSUB8 __iar_builtin_SHSUB8 + #define __USUB8 __iar_builtin_USUB8 + #define __UQSUB8 __iar_builtin_UQSUB8 + #define __UHSUB8 __iar_builtin_UHSUB8 + #define __SADD16 __iar_builtin_SADD16 + #define __QADD16 __iar_builtin_QADD16 + #define __SHADD16 __iar_builtin_SHADD16 + #define __UADD16 __iar_builtin_UADD16 + #define __UQADD16 __iar_builtin_UQADD16 + #define __UHADD16 __iar_builtin_UHADD16 + #define __SSUB16 __iar_builtin_SSUB16 + #define __QSUB16 __iar_builtin_QSUB16 + #define __SHSUB16 __iar_builtin_SHSUB16 + #define __USUB16 __iar_builtin_USUB16 + #define __UQSUB16 __iar_builtin_UQSUB16 + #define __UHSUB16 __iar_builtin_UHSUB16 + #define __SASX __iar_builtin_SASX + #define __QASX __iar_builtin_QASX + #define __SHASX __iar_builtin_SHASX + #define __UASX __iar_builtin_UASX + #define __UQASX __iar_builtin_UQASX + #define __UHASX __iar_builtin_UHASX + #define __SSAX __iar_builtin_SSAX + #define __QSAX __iar_builtin_QSAX + #define __SHSAX __iar_builtin_SHSAX + #define __USAX __iar_builtin_USAX + #define __UQSAX __iar_builtin_UQSAX + #define __UHSAX __iar_builtin_UHSAX + #define __USAD8 __iar_builtin_USAD8 + #define __USADA8 __iar_builtin_USADA8 + #define __SSAT16 __iar_builtin_SSAT16 + #define __USAT16 __iar_builtin_USAT16 + #define __UXTB16 __iar_builtin_UXTB16 + #define __UXTAB16 __iar_builtin_UXTAB16 + #define __SXTB16 __iar_builtin_SXTB16 + #define __SXTAB16 __iar_builtin_SXTAB16 + #define __SMUAD __iar_builtin_SMUAD + #define __SMUADX __iar_builtin_SMUADX + #define __SMMLA __iar_builtin_SMMLA + #define __SMLAD __iar_builtin_SMLAD + #define __SMLADX __iar_builtin_SMLADX + #define __SMLALD __iar_builtin_SMLALD + #define __SMLALDX __iar_builtin_SMLALDX + #define __SMUSD __iar_builtin_SMUSD + #define __SMUSDX __iar_builtin_SMUSDX + #define __SMLSD __iar_builtin_SMLSD + #define __SMLSDX __iar_builtin_SMLSDX + #define __SMLSLD __iar_builtin_SMLSLD + #define __SMLSLDX __iar_builtin_SMLSLDX + #define __SEL __iar_builtin_SEL + #define __QADD __iar_builtin_QADD + #define __QSUB __iar_builtin_QSUB + #define __PKHBT __iar_builtin_PKHBT + #define __PKHTB __iar_builtin_PKHTB + +#else /* __ICCARM_INTRINSICS_VERSION__ == 2 */ + + #if !__FPU_PRESENT + #define __get_FPSCR __cmsis_iar_get_FPSR_not_active + #endif + + #ifdef __INTRINSICS_INCLUDED + #error intrinsics.h is already included previously! + #endif + + #include + + #if !__FPU_PRESENT + #define __get_FPSCR() (0) + #endif + + #pragma diag_suppress=Pe940 + #pragma diag_suppress=Pe177 + + #define __enable_irq __enable_interrupt + #define __disable_irq __disable_interrupt + #define __enable_fault_irq __enable_fiq + #define __disable_fault_irq __disable_fiq + #define __NOP __no_operation + + #define __get_xPSR __get_PSR + + __IAR_FT void __set_mode(uint32_t mode) + { + __ASM volatile("MSR cpsr_c, %0" : : "r" (mode) : "memory"); + } + + __IAR_FT uint32_t __LDREXW(uint32_t volatile *ptr) + { + return __LDREX((unsigned long *)ptr); + } + + __IAR_FT uint32_t __STREXW(uint32_t value, uint32_t volatile *ptr) + { + return __STREX(value, (unsigned long *)ptr); + } + + + __IAR_FT uint32_t __RRX(uint32_t value) + { + uint32_t result; + __ASM("RRX %0, %1" : "=r"(result) : "r" (value) : "cc"); + return(result); + } + + + __IAR_FT uint32_t __ROR(uint32_t op1, uint32_t op2) + { + return (op1 >> op2) | (op1 << ((sizeof(op1)*8)-op2)); + } + + __IAR_FT uint32_t __get_FPEXC(void) + { + #if (__FPU_PRESENT == 1) + uint32_t result; + __ASM volatile("VMRS %0, fpexc" : "=r" (result) : : "memory"); + return(result); + #else + return(0); + #endif + } + + __IAR_FT void __set_FPEXC(uint32_t fpexc) + { + #if (__FPU_PRESENT == 1) + __ASM volatile ("VMSR fpexc, %0" : : "r" (fpexc) : "memory"); + #endif + } + + + #define __get_CP(cp, op1, Rt, CRn, CRm, op2) \ + __ASM volatile("MRC p" # cp ", " # op1 ", %0, c" # CRn ", c" # CRm ", " # op2 : "=r" (Rt) : : "memory" ) + #define __set_CP(cp, op1, Rt, CRn, CRm, op2) \ + __ASM volatile("MCR p" # cp ", " # op1 ", %0, c" # CRn ", c" # CRm ", " # op2 : : "r" (Rt) : "memory" ) + #define __get_CP64(cp, op1, Rt, CRm) \ + __ASM volatile("MRRC p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : "=r" (Rt) : : "memory" ) + #define __set_CP64(cp, op1, Rt, CRm) \ + __ASM volatile("MCRR p" # cp ", " # op1 ", %Q0, %R0, c" # CRm : : "r" (Rt) : "memory" ) + + #include "cmsis_cp15.h" + +#endif /* __ICCARM_INTRINSICS_VERSION__ == 2 */ + +#define __BKPT(value) __asm volatile ("BKPT %0" : : "i"(value)) + + +__IAR_FT uint32_t __get_SP_usr(void) +{ + uint32_t cpsr; + uint32_t result; + __ASM volatile( + "MRS %0, cpsr \n" + "CPS #0x1F \n" // no effect in USR mode + "MOV %1, sp \n" + "MSR cpsr_c, %2 \n" // no effect in USR mode + "ISB" : "=r"(cpsr), "=r"(result) : "r"(cpsr) : "memory" + ); + return result; +} + +__IAR_FT void __set_SP_usr(uint32_t topOfProcStack) +{ + uint32_t cpsr; + __ASM volatile( + "MRS %0, cpsr \n" + "CPS #0x1F \n" // no effect in USR mode + "MOV sp, %1 \n" + "MSR cpsr_c, %2 \n" // no effect in USR mode + "ISB" : "=r"(cpsr) : "r" (topOfProcStack), "r"(cpsr) : "memory" + ); +} + +#define __get_mode() (__get_CPSR() & 0x1FU) + +__STATIC_INLINE +void __FPU_Enable(void) +{ + __ASM volatile( + //Permit access to VFP/NEON, registers by modifying CPACR + " MRC p15,0,R1,c1,c0,2 \n" + " ORR R1,R1,#0x00F00000 \n" + " MCR p15,0,R1,c1,c0,2 \n" + + //Ensure that subsequent instructions occur in the context of VFP/NEON access permitted + " ISB \n" + + //Enable VFP/NEON + " VMRS R1,FPEXC \n" + " ORR R1,R1,#0x40000000 \n" + " VMSR FPEXC,R1 \n" + + //Initialise VFP/NEON registers to 0 + " MOV R2,#0 \n" + + //Initialise D16 registers to 0 + " VMOV D0, R2,R2 \n" + " VMOV D1, R2,R2 \n" + " VMOV D2, R2,R2 \n" + " VMOV D3, R2,R2 \n" + " VMOV D4, R2,R2 \n" + " VMOV D5, R2,R2 \n" + " VMOV D6, R2,R2 \n" + " VMOV D7, R2,R2 \n" + " VMOV D8, R2,R2 \n" + " VMOV D9, R2,R2 \n" + " VMOV D10,R2,R2 \n" + " VMOV D11,R2,R2 \n" + " VMOV D12,R2,R2 \n" + " VMOV D13,R2,R2 \n" + " VMOV D14,R2,R2 \n" + " VMOV D15,R2,R2 \n" + +#ifdef __ARM_ADVANCED_SIMD__ + //Initialise D32 registers to 0 + " VMOV D16,R2,R2 \n" + " VMOV D17,R2,R2 \n" + " VMOV D18,R2,R2 \n" + " VMOV D19,R2,R2 \n" + " VMOV D20,R2,R2 \n" + " VMOV D21,R2,R2 \n" + " VMOV D22,R2,R2 \n" + " VMOV D23,R2,R2 \n" + " VMOV D24,R2,R2 \n" + " VMOV D25,R2,R2 \n" + " VMOV D26,R2,R2 \n" + " VMOV D27,R2,R2 \n" + " VMOV D28,R2,R2 \n" + " VMOV D29,R2,R2 \n" + " VMOV D30,R2,R2 \n" + " VMOV D31,R2,R2 \n" +#endif + + //Initialise FPSCR to a known state + " VMRS R2,FPSCR \n" + " MOV32 R3,#0x00086060 \n" //Mask off all bits that do not have to be preserved. Non-preserved bits can/should be zero. + " AND R2,R2,R3 \n" + " VMSR FPSCR,R2 \n"); +} + + + +#undef __IAR_FT +#undef __ICCARM_V8 + +#pragma diag_default=Pe940 +#pragma diag_default=Pe177 + +#endif /* __CMSIS_ICCARM_H__ */ diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/core_ca.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/core_ca.h new file mode 100644 index 0000000..c7b451f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/core_ca.h @@ -0,0 +1,2614 @@ +/**************************************************************************//** + * @file core_ca.h + * @brief CMSIS Cortex-A Core Peripheral Access Layer Header File + * @version V1.0.1 + * @date 07. May 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifdef __cplusplus + extern "C" { +#endif + +#ifndef __CORE_CA_H_GENERIC +#define __CORE_CA_H_GENERIC + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ + +/* CMSIS CA definitions */ +#define __CA_CMSIS_VERSION_MAIN (1U) /*!< \brief [31:16] CMSIS-Core(A) main version */ +#define __CA_CMSIS_VERSION_SUB (1U) /*!< \brief [15:0] CMSIS-Core(A) sub version */ +#define __CA_CMSIS_VERSION ((__CA_CMSIS_VERSION_MAIN << 16U) | \ + __CA_CMSIS_VERSION_SUB ) /*!< \brief CMSIS-Core(A) version number */ + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #if (__FPU_PRESENT == 1) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #if (__FPU_PRESENT == 1) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TMS470__ ) + #if defined __TI_VFP_SUPPORT__ + #if (__FPU_PRESENT == 1) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if (__FPU_PRESENT == 1) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #if (__FPU_PRESENT == 1) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CA_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CA_H_DEPENDANT +#define __CORE_CA_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + + /* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CA_REV + #define __CA_REV 0x0000U + #warning "__CA_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __GIC_PRESENT + #define __GIC_PRESENT 1U + #warning "__GIC_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __TIM_PRESENT + #define __TIM_PRESENT 1U + #warning "__TIM_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __L2C_PRESENT + #define __L2C_PRESENT 0U + #warning "__L2C_PRESENT not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +#ifdef __cplusplus + #define __I volatile /*!< \brief Defines 'read only' permissions */ +#else + #define __I volatile const /*!< \brief Defines 'read only' permissions */ +#endif +#define __O volatile /*!< \brief Defines 'write only' permissions */ +#define __IO volatile /*!< \brief Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*!< \brief Defines 'read only' structure member permissions */ +#define __OM volatile /*!< \brief Defines 'write only' structure member permissions */ +#define __IOM volatile /*!< \brief Defines 'read / write' structure member permissions */ +#define RESERVED(N, T) T RESERVED##N; // placeholder struct members used for "reserved" areas + + /******************************************************************************* + * Register Abstraction + Core Register contain: + - CPSR + - CP15 Registers + - L2C-310 Cache Controller + - Generic Interrupt Controller Distributor + - Generic Interrupt Controller Interface + ******************************************************************************/ + +/* Core Register CPSR */ +typedef union +{ + struct + { + uint32_t M:5; /*!< \brief bit: 0.. 4 Mode field */ + uint32_t T:1; /*!< \brief bit: 5 Thumb execution state bit */ + uint32_t F:1; /*!< \brief bit: 6 FIQ mask bit */ + uint32_t I:1; /*!< \brief bit: 7 IRQ mask bit */ + uint32_t A:1; /*!< \brief bit: 8 Asynchronous abort mask bit */ + uint32_t E:1; /*!< \brief bit: 9 Endianness execution state bit */ + uint32_t IT1:6; /*!< \brief bit: 10..15 If-Then execution state bits 2-7 */ + uint32_t GE:4; /*!< \brief bit: 16..19 Greater than or Equal flags */ + RESERVED(0:4, uint32_t) + uint32_t J:1; /*!< \brief bit: 24 Jazelle bit */ + uint32_t IT0:2; /*!< \brief bit: 25..26 If-Then execution state bits 0-1 */ + uint32_t Q:1; /*!< \brief bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< \brief bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< \brief bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< \brief bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< \brief bit: 31 Negative condition code flag */ + } b; /*!< \brief Structure used for bit access */ + uint32_t w; /*!< \brief Type used for word access */ +} CPSR_Type; + + + +/* CPSR Register Definitions */ +#define CPSR_N_Pos 31U /*!< \brief CPSR: N Position */ +#define CPSR_N_Msk (1UL << CPSR_N_Pos) /*!< \brief CPSR: N Mask */ + +#define CPSR_Z_Pos 30U /*!< \brief CPSR: Z Position */ +#define CPSR_Z_Msk (1UL << CPSR_Z_Pos) /*!< \brief CPSR: Z Mask */ + +#define CPSR_C_Pos 29U /*!< \brief CPSR: C Position */ +#define CPSR_C_Msk (1UL << CPSR_C_Pos) /*!< \brief CPSR: C Mask */ + +#define CPSR_V_Pos 28U /*!< \brief CPSR: V Position */ +#define CPSR_V_Msk (1UL << CPSR_V_Pos) /*!< \brief CPSR: V Mask */ + +#define CPSR_Q_Pos 27U /*!< \brief CPSR: Q Position */ +#define CPSR_Q_Msk (1UL << CPSR_Q_Pos) /*!< \brief CPSR: Q Mask */ + +#define CPSR_IT0_Pos 25U /*!< \brief CPSR: IT0 Position */ +#define CPSR_IT0_Msk (3UL << CPSR_IT0_Pos) /*!< \brief CPSR: IT0 Mask */ + +#define CPSR_J_Pos 24U /*!< \brief CPSR: J Position */ +#define CPSR_J_Msk (1UL << CPSR_J_Pos) /*!< \brief CPSR: J Mask */ + +#define CPSR_GE_Pos 16U /*!< \brief CPSR: GE Position */ +#define CPSR_GE_Msk (0xFUL << CPSR_GE_Pos) /*!< \brief CPSR: GE Mask */ + +#define CPSR_IT1_Pos 10U /*!< \brief CPSR: IT1 Position */ +#define CPSR_IT1_Msk (0x3FUL << CPSR_IT1_Pos) /*!< \brief CPSR: IT1 Mask */ + +#define CPSR_E_Pos 9U /*!< \brief CPSR: E Position */ +#define CPSR_E_Msk (1UL << CPSR_E_Pos) /*!< \brief CPSR: E Mask */ + +#define CPSR_A_Pos 8U /*!< \brief CPSR: A Position */ +#define CPSR_A_Msk (1UL << CPSR_A_Pos) /*!< \brief CPSR: A Mask */ + +#define CPSR_I_Pos 7U /*!< \brief CPSR: I Position */ +#define CPSR_I_Msk (1UL << CPSR_I_Pos) /*!< \brief CPSR: I Mask */ + +#define CPSR_F_Pos 6U /*!< \brief CPSR: F Position */ +#define CPSR_F_Msk (1UL << CPSR_F_Pos) /*!< \brief CPSR: F Mask */ + +#define CPSR_T_Pos 5U /*!< \brief CPSR: T Position */ +#define CPSR_T_Msk (1UL << CPSR_T_Pos) /*!< \brief CPSR: T Mask */ + +#define CPSR_M_Pos 0U /*!< \brief CPSR: M Position */ +#define CPSR_M_Msk (0x1FUL << CPSR_M_Pos) /*!< \brief CPSR: M Mask */ + +#define CPSR_M_USR 0x10U /*!< \brief CPSR: M User mode (PL0) */ +#define CPSR_M_FIQ 0x11U /*!< \brief CPSR: M Fast Interrupt mode (PL1) */ +#define CPSR_M_IRQ 0x12U /*!< \brief CPSR: M Interrupt mode (PL1) */ +#define CPSR_M_SVC 0x13U /*!< \brief CPSR: M Supervisor mode (PL1) */ +#define CPSR_M_MON 0x16U /*!< \brief CPSR: M Monitor mode (PL1) */ +#define CPSR_M_ABT 0x17U /*!< \brief CPSR: M Abort mode (PL1) */ +#define CPSR_M_HYP 0x1AU /*!< \brief CPSR: M Hypervisor mode (PL2) */ +#define CPSR_M_UND 0x1BU /*!< \brief CPSR: M Undefined mode (PL1) */ +#define CPSR_M_SYS 0x1FU /*!< \brief CPSR: M System mode (PL1) */ + +/* CP15 Register SCTLR */ +typedef union +{ + struct + { + uint32_t M:1; /*!< \brief bit: 0 MMU enable */ + uint32_t A:1; /*!< \brief bit: 1 Alignment check enable */ + uint32_t C:1; /*!< \brief bit: 2 Cache enable */ + RESERVED(0:2, uint32_t) + uint32_t CP15BEN:1; /*!< \brief bit: 5 CP15 barrier enable */ + RESERVED(1:1, uint32_t) + uint32_t B:1; /*!< \brief bit: 7 Endianness model */ + RESERVED(2:2, uint32_t) + uint32_t SW:1; /*!< \brief bit: 10 SWP and SWPB enable */ + uint32_t Z:1; /*!< \brief bit: 11 Branch prediction enable */ + uint32_t I:1; /*!< \brief bit: 12 Instruction cache enable */ + uint32_t V:1; /*!< \brief bit: 13 Vectors bit */ + uint32_t RR:1; /*!< \brief bit: 14 Round Robin select */ + RESERVED(3:2, uint32_t) + uint32_t HA:1; /*!< \brief bit: 17 Hardware Access flag enable */ + RESERVED(4:1, uint32_t) + uint32_t WXN:1; /*!< \brief bit: 19 Write permission implies XN */ + uint32_t UWXN:1; /*!< \brief bit: 20 Unprivileged write permission implies PL1 XN */ + uint32_t FI:1; /*!< \brief bit: 21 Fast interrupts configuration enable */ + uint32_t U:1; /*!< \brief bit: 22 Alignment model */ + RESERVED(5:1, uint32_t) + uint32_t VE:1; /*!< \brief bit: 24 Interrupt Vectors Enable */ + uint32_t EE:1; /*!< \brief bit: 25 Exception Endianness */ + RESERVED(6:1, uint32_t) + uint32_t NMFI:1; /*!< \brief bit: 27 Non-maskable FIQ (NMFI) support */ + uint32_t TRE:1; /*!< \brief bit: 28 TEX remap enable. */ + uint32_t AFE:1; /*!< \brief bit: 29 Access flag enable */ + uint32_t TE:1; /*!< \brief bit: 30 Thumb Exception enable */ + RESERVED(7:1, uint32_t) + } b; /*!< \brief Structure used for bit access */ + uint32_t w; /*!< \brief Type used for word access */ +} SCTLR_Type; + +#define SCTLR_TE_Pos 30U /*!< \brief SCTLR: TE Position */ +#define SCTLR_TE_Msk (1UL << SCTLR_TE_Pos) /*!< \brief SCTLR: TE Mask */ + +#define SCTLR_AFE_Pos 29U /*!< \brief SCTLR: AFE Position */ +#define SCTLR_AFE_Msk (1UL << SCTLR_AFE_Pos) /*!< \brief SCTLR: AFE Mask */ + +#define SCTLR_TRE_Pos 28U /*!< \brief SCTLR: TRE Position */ +#define SCTLR_TRE_Msk (1UL << SCTLR_TRE_Pos) /*!< \brief SCTLR: TRE Mask */ + +#define SCTLR_NMFI_Pos 27U /*!< \brief SCTLR: NMFI Position */ +#define SCTLR_NMFI_Msk (1UL << SCTLR_NMFI_Pos) /*!< \brief SCTLR: NMFI Mask */ + +#define SCTLR_EE_Pos 25U /*!< \brief SCTLR: EE Position */ +#define SCTLR_EE_Msk (1UL << SCTLR_EE_Pos) /*!< \brief SCTLR: EE Mask */ + +#define SCTLR_VE_Pos 24U /*!< \brief SCTLR: VE Position */ +#define SCTLR_VE_Msk (1UL << SCTLR_VE_Pos) /*!< \brief SCTLR: VE Mask */ + +#define SCTLR_U_Pos 22U /*!< \brief SCTLR: U Position */ +#define SCTLR_U_Msk (1UL << SCTLR_U_Pos) /*!< \brief SCTLR: U Mask */ + +#define SCTLR_FI_Pos 21U /*!< \brief SCTLR: FI Position */ +#define SCTLR_FI_Msk (1UL << SCTLR_FI_Pos) /*!< \brief SCTLR: FI Mask */ + +#define SCTLR_UWXN_Pos 20U /*!< \brief SCTLR: UWXN Position */ +#define SCTLR_UWXN_Msk (1UL << SCTLR_UWXN_Pos) /*!< \brief SCTLR: UWXN Mask */ + +#define SCTLR_WXN_Pos 19U /*!< \brief SCTLR: WXN Position */ +#define SCTLR_WXN_Msk (1UL << SCTLR_WXN_Pos) /*!< \brief SCTLR: WXN Mask */ + +#define SCTLR_HA_Pos 17U /*!< \brief SCTLR: HA Position */ +#define SCTLR_HA_Msk (1UL << SCTLR_HA_Pos) /*!< \brief SCTLR: HA Mask */ + +#define SCTLR_RR_Pos 14U /*!< \brief SCTLR: RR Position */ +#define SCTLR_RR_Msk (1UL << SCTLR_RR_Pos) /*!< \brief SCTLR: RR Mask */ + +#define SCTLR_V_Pos 13U /*!< \brief SCTLR: V Position */ +#define SCTLR_V_Msk (1UL << SCTLR_V_Pos) /*!< \brief SCTLR: V Mask */ + +#define SCTLR_I_Pos 12U /*!< \brief SCTLR: I Position */ +#define SCTLR_I_Msk (1UL << SCTLR_I_Pos) /*!< \brief SCTLR: I Mask */ + +#define SCTLR_Z_Pos 11U /*!< \brief SCTLR: Z Position */ +#define SCTLR_Z_Msk (1UL << SCTLR_Z_Pos) /*!< \brief SCTLR: Z Mask */ + +#define SCTLR_SW_Pos 10U /*!< \brief SCTLR: SW Position */ +#define SCTLR_SW_Msk (1UL << SCTLR_SW_Pos) /*!< \brief SCTLR: SW Mask */ + +#define SCTLR_B_Pos 7U /*!< \brief SCTLR: B Position */ +#define SCTLR_B_Msk (1UL << SCTLR_B_Pos) /*!< \brief SCTLR: B Mask */ + +#define SCTLR_CP15BEN_Pos 5U /*!< \brief SCTLR: CP15BEN Position */ +#define SCTLR_CP15BEN_Msk (1UL << SCTLR_CP15BEN_Pos) /*!< \brief SCTLR: CP15BEN Mask */ + +#define SCTLR_C_Pos 2U /*!< \brief SCTLR: C Position */ +#define SCTLR_C_Msk (1UL << SCTLR_C_Pos) /*!< \brief SCTLR: C Mask */ + +#define SCTLR_A_Pos 1U /*!< \brief SCTLR: A Position */ +#define SCTLR_A_Msk (1UL << SCTLR_A_Pos) /*!< \brief SCTLR: A Mask */ + +#define SCTLR_M_Pos 0U /*!< \brief SCTLR: M Position */ +#define SCTLR_M_Msk (1UL << SCTLR_M_Pos) /*!< \brief SCTLR: M Mask */ + +/* CP15 Register ACTLR */ +typedef union +{ +#if __CORTEX_A == 5 || defined(DOXYGEN) + /** \brief Structure used for bit access on Cortex-A5 */ + struct + { + uint32_t FW:1; /*!< \brief bit: 0 Cache and TLB maintenance broadcast */ + RESERVED(0:5, uint32_t) + uint32_t SMP:1; /*!< \brief bit: 6 Enables coherent requests to the processor */ + uint32_t EXCL:1; /*!< \brief bit: 7 Exclusive L1/L2 cache control */ + RESERVED(1:2, uint32_t) + uint32_t DODMBS:1; /*!< \brief bit: 10 Disable optimized data memory barrier behavior */ + uint32_t DWBST:1; /*!< \brief bit: 11 AXI data write bursts to Normal memory */ + uint32_t RADIS:1; /*!< \brief bit: 12 L1 Data Cache read-allocate mode disable */ + uint32_t L1PCTL:2; /*!< \brief bit:13..14 L1 Data prefetch control */ + uint32_t BP:2; /*!< \brief bit:16..15 Branch prediction policy */ + uint32_t RSDIS:1; /*!< \brief bit: 17 Disable return stack operation */ + uint32_t BTDIS:1; /*!< \brief bit: 18 Disable indirect Branch Target Address Cache (BTAC) */ + RESERVED(3:9, uint32_t) + uint32_t DBDI:1; /*!< \brief bit: 28 Disable branch dual issue */ + RESERVED(7:3, uint32_t) + } b; +#endif +#if __CORTEX_A == 7 || defined(DOXYGEN) + /** \brief Structure used for bit access on Cortex-A7 */ + struct + { + RESERVED(0:6, uint32_t) + uint32_t SMP:1; /*!< \brief bit: 6 Enables coherent requests to the processor */ + RESERVED(1:3, uint32_t) + uint32_t DODMBS:1; /*!< \brief bit: 10 Disable optimized data memory barrier behavior */ + uint32_t L2RADIS:1; /*!< \brief bit: 11 L2 Data Cache read-allocate mode disable */ + uint32_t L1RADIS:1; /*!< \brief bit: 12 L1 Data Cache read-allocate mode disable */ + uint32_t L1PCTL:2; /*!< \brief bit:13..14 L1 Data prefetch control */ + uint32_t DDVM:1; /*!< \brief bit: 15 Disable Distributed Virtual Memory (DVM) transactions */ + RESERVED(3:12, uint32_t) + uint32_t DDI:1; /*!< \brief bit: 28 Disable dual issue */ + RESERVED(7:3, uint32_t) + } b; +#endif +#if __CORTEX_A == 9 || defined(DOXYGEN) + /** \brief Structure used for bit access on Cortex-A9 */ + struct + { + uint32_t FW:1; /*!< \brief bit: 0 Cache and TLB maintenance broadcast */ + RESERVED(0:1, uint32_t) + uint32_t L1PE:1; /*!< \brief bit: 2 Dside prefetch */ + uint32_t WFLZM:1; /*!< \brief bit: 3 Cache and TLB maintenance broadcast */ + RESERVED(1:2, uint32_t) + uint32_t SMP:1; /*!< \brief bit: 6 Enables coherent requests to the processor */ + uint32_t EXCL:1; /*!< \brief bit: 7 Exclusive L1/L2 cache control */ + uint32_t AOW:1; /*!< \brief bit: 8 Enable allocation in one cache way only */ + uint32_t PARITY:1; /*!< \brief bit: 9 Support for parity checking, if implemented */ + RESERVED(7:22, uint32_t) + } b; +#endif + uint32_t w; /*!< \brief Type used for word access */ +} ACTLR_Type; + +#define ACTLR_DDI_Pos 28U /*!< \brief ACTLR: DDI Position */ +#define ACTLR_DDI_Msk (1UL << ACTLR_DDI_Pos) /*!< \brief ACTLR: DDI Mask */ + +#define ACTLR_DBDI_Pos 28U /*!< \brief ACTLR: DBDI Position */ +#define ACTLR_DBDI_Msk (1UL << ACTLR_DBDI_Pos) /*!< \brief ACTLR: DBDI Mask */ + +#define ACTLR_BTDIS_Pos 18U /*!< \brief ACTLR: BTDIS Position */ +#define ACTLR_BTDIS_Msk (1UL << ACTLR_BTDIS_Pos) /*!< \brief ACTLR: BTDIS Mask */ + +#define ACTLR_RSDIS_Pos 17U /*!< \brief ACTLR: RSDIS Position */ +#define ACTLR_RSDIS_Msk (1UL << ACTLR_RSDIS_Pos) /*!< \brief ACTLR: RSDIS Mask */ + +#define ACTLR_BP_Pos 15U /*!< \brief ACTLR: BP Position */ +#define ACTLR_BP_Msk (3UL << ACTLR_BP_Pos) /*!< \brief ACTLR: BP Mask */ + +#define ACTLR_DDVM_Pos 15U /*!< \brief ACTLR: DDVM Position */ +#define ACTLR_DDVM_Msk (1UL << ACTLR_DDVM_Pos) /*!< \brief ACTLR: DDVM Mask */ + +#define ACTLR_L1PCTL_Pos 13U /*!< \brief ACTLR: L1PCTL Position */ +#define ACTLR_L1PCTL_Msk (3UL << ACTLR_L1PCTL_Pos) /*!< \brief ACTLR: L1PCTL Mask */ + +#define ACTLR_RADIS_Pos 12U /*!< \brief ACTLR: RADIS Position */ +#define ACTLR_RADIS_Msk (1UL << ACTLR_RADIS_Pos) /*!< \brief ACTLR: RADIS Mask */ + +#define ACTLR_L1RADIS_Pos 12U /*!< \brief ACTLR: L1RADIS Position */ +#define ACTLR_L1RADIS_Msk (1UL << ACTLR_L1RADIS_Pos) /*!< \brief ACTLR: L1RADIS Mask */ + +#define ACTLR_DWBST_Pos 11U /*!< \brief ACTLR: DWBST Position */ +#define ACTLR_DWBST_Msk (1UL << ACTLR_DWBST_Pos) /*!< \brief ACTLR: DWBST Mask */ + +#define ACTLR_L2RADIS_Pos 11U /*!< \brief ACTLR: L2RADIS Position */ +#define ACTLR_L2RADIS_Msk (1UL << ACTLR_L2RADIS_Pos) /*!< \brief ACTLR: L2RADIS Mask */ + +#define ACTLR_DODMBS_Pos 10U /*!< \brief ACTLR: DODMBS Position */ +#define ACTLR_DODMBS_Msk (1UL << ACTLR_DODMBS_Pos) /*!< \brief ACTLR: DODMBS Mask */ + +#define ACTLR_PARITY_Pos 9U /*!< \brief ACTLR: PARITY Position */ +#define ACTLR_PARITY_Msk (1UL << ACTLR_PARITY_Pos) /*!< \brief ACTLR: PARITY Mask */ + +#define ACTLR_AOW_Pos 8U /*!< \brief ACTLR: AOW Position */ +#define ACTLR_AOW_Msk (1UL << ACTLR_AOW_Pos) /*!< \brief ACTLR: AOW Mask */ + +#define ACTLR_EXCL_Pos 7U /*!< \brief ACTLR: EXCL Position */ +#define ACTLR_EXCL_Msk (1UL << ACTLR_EXCL_Pos) /*!< \brief ACTLR: EXCL Mask */ + +#define ACTLR_SMP_Pos 6U /*!< \brief ACTLR: SMP Position */ +#define ACTLR_SMP_Msk (1UL << ACTLR_SMP_Pos) /*!< \brief ACTLR: SMP Mask */ + +#define ACTLR_WFLZM_Pos 3U /*!< \brief ACTLR: WFLZM Position */ +#define ACTLR_WFLZM_Msk (1UL << ACTLR_WFLZM_Pos) /*!< \brief ACTLR: WFLZM Mask */ + +#define ACTLR_L1PE_Pos 2U /*!< \brief ACTLR: L1PE Position */ +#define ACTLR_L1PE_Msk (1UL << ACTLR_L1PE_Pos) /*!< \brief ACTLR: L1PE Mask */ + +#define ACTLR_FW_Pos 0U /*!< \brief ACTLR: FW Position */ +#define ACTLR_FW_Msk (1UL << ACTLR_FW_Pos) /*!< \brief ACTLR: FW Mask */ + +/* CP15 Register CPACR */ +typedef union +{ + struct + { + uint32_t CP0:2; /*!< \brief bit: 0..1 Access rights for coprocessor 0 */ + uint32_t CP1:2; /*!< \brief bit: 2..3 Access rights for coprocessor 1 */ + uint32_t CP2:2; /*!< \brief bit: 4..5 Access rights for coprocessor 2 */ + uint32_t CP3:2; /*!< \brief bit: 6..7 Access rights for coprocessor 3 */ + uint32_t CP4:2; /*!< \brief bit: 8..9 Access rights for coprocessor 4 */ + uint32_t CP5:2; /*!< \brief bit:10..11 Access rights for coprocessor 5 */ + uint32_t CP6:2; /*!< \brief bit:12..13 Access rights for coprocessor 6 */ + uint32_t CP7:2; /*!< \brief bit:14..15 Access rights for coprocessor 7 */ + uint32_t CP8:2; /*!< \brief bit:16..17 Access rights for coprocessor 8 */ + uint32_t CP9:2; /*!< \brief bit:18..19 Access rights for coprocessor 9 */ + uint32_t CP10:2; /*!< \brief bit:20..21 Access rights for coprocessor 10 */ + uint32_t CP11:2; /*!< \brief bit:22..23 Access rights for coprocessor 11 */ + uint32_t CP12:2; /*!< \brief bit:24..25 Access rights for coprocessor 11 */ + uint32_t CP13:2; /*!< \brief bit:26..27 Access rights for coprocessor 11 */ + uint32_t TRCDIS:1; /*!< \brief bit: 28 Disable CP14 access to trace registers */ + RESERVED(0:1, uint32_t) + uint32_t D32DIS:1; /*!< \brief bit: 30 Disable use of registers D16-D31 of the VFP register file */ + uint32_t ASEDIS:1; /*!< \brief bit: 31 Disable Advanced SIMD Functionality */ + } b; /*!< \brief Structure used for bit access */ + uint32_t w; /*!< \brief Type used for word access */ +} CPACR_Type; + +#define CPACR_ASEDIS_Pos 31U /*!< \brief CPACR: ASEDIS Position */ +#define CPACR_ASEDIS_Msk (1UL << CPACR_ASEDIS_Pos) /*!< \brief CPACR: ASEDIS Mask */ + +#define CPACR_D32DIS_Pos 30U /*!< \brief CPACR: D32DIS Position */ +#define CPACR_D32DIS_Msk (1UL << CPACR_D32DIS_Pos) /*!< \brief CPACR: D32DIS Mask */ + +#define CPACR_TRCDIS_Pos 28U /*!< \brief CPACR: D32DIS Position */ +#define CPACR_TRCDIS_Msk (1UL << CPACR_D32DIS_Pos) /*!< \brief CPACR: D32DIS Mask */ + +#define CPACR_CP_Pos_(n) (n*2U) /*!< \brief CPACR: CPn Position */ +#define CPACR_CP_Msk_(n) (3UL << CPACR_CP_Pos_(n)) /*!< \brief CPACR: CPn Mask */ + +#define CPACR_CP_NA 0U /*!< \brief CPACR CPn field: Access denied. */ +#define CPACR_CP_PL1 1U /*!< \brief CPACR CPn field: Accessible from PL1 only. */ +#define CPACR_CP_FA 3U /*!< \brief CPACR CPn field: Full access. */ + +/* CP15 Register DFSR */ +typedef union +{ + struct + { + uint32_t FS0:4; /*!< \brief bit: 0.. 3 Fault Status bits bit 0-3 */ + uint32_t Domain:4; /*!< \brief bit: 4.. 7 Fault on which domain */ + RESERVED(0:1, uint32_t) + uint32_t LPAE:1; /*!< \brief bit: 9 Large Physical Address Extension */ + uint32_t FS1:1; /*!< \brief bit: 10 Fault Status bits bit 4 */ + uint32_t WnR:1; /*!< \brief bit: 11 Write not Read bit */ + uint32_t ExT:1; /*!< \brief bit: 12 External abort type */ + uint32_t CM:1; /*!< \brief bit: 13 Cache maintenance fault */ + RESERVED(1:18, uint32_t) + } s; /*!< \brief Structure used for bit access in short format */ + struct + { + uint32_t STATUS:5; /*!< \brief bit: 0.. 5 Fault Status bits */ + RESERVED(0:3, uint32_t) + uint32_t LPAE:1; /*!< \brief bit: 9 Large Physical Address Extension */ + RESERVED(1:1, uint32_t) + uint32_t WnR:1; /*!< \brief bit: 11 Write not Read bit */ + uint32_t ExT:1; /*!< \brief bit: 12 External abort type */ + uint32_t CM:1; /*!< \brief bit: 13 Cache maintenance fault */ + RESERVED(2:18, uint32_t) + } l; /*!< \brief Structure used for bit access in long format */ + uint32_t w; /*!< \brief Type used for word access */ +} DFSR_Type; + +#define DFSR_CM_Pos 13U /*!< \brief DFSR: CM Position */ +#define DFSR_CM_Msk (1UL << DFSR_CM_Pos) /*!< \brief DFSR: CM Mask */ + +#define DFSR_Ext_Pos 12U /*!< \brief DFSR: Ext Position */ +#define DFSR_Ext_Msk (1UL << DFSR_Ext_Pos) /*!< \brief DFSR: Ext Mask */ + +#define DFSR_WnR_Pos 11U /*!< \brief DFSR: WnR Position */ +#define DFSR_WnR_Msk (1UL << DFSR_WnR_Pos) /*!< \brief DFSR: WnR Mask */ + +#define DFSR_FS1_Pos 10U /*!< \brief DFSR: FS1 Position */ +#define DFSR_FS1_Msk (1UL << DFSR_FS1_Pos) /*!< \brief DFSR: FS1 Mask */ + +#define DFSR_LPAE_Pos 9U /*!< \brief DFSR: LPAE Position */ +#define DFSR_LPAE_Msk (1UL << DFSR_LPAE_Pos) /*!< \brief DFSR: LPAE Mask */ + +#define DFSR_Domain_Pos 4U /*!< \brief DFSR: Domain Position */ +#define DFSR_Domain_Msk (0xFUL << DFSR_Domain_Pos) /*!< \brief DFSR: Domain Mask */ + +#define DFSR_FS0_Pos 0U /*!< \brief DFSR: FS0 Position */ +#define DFSR_FS0_Msk (0xFUL << DFSR_FS0_Pos) /*!< \brief DFSR: FS0 Mask */ + +#define DFSR_STATUS_Pos 0U /*!< \brief DFSR: STATUS Position */ +#define DFSR_STATUS_Msk (0x3FUL << DFSR_STATUS_Pos) /*!< \brief DFSR: STATUS Mask */ + +/* CP15 Register IFSR */ +typedef union +{ + struct + { + uint32_t FS0:4; /*!< \brief bit: 0.. 3 Fault Status bits bit 0-3 */ + RESERVED(0:5, uint32_t) + uint32_t LPAE:1; /*!< \brief bit: 9 Large Physical Address Extension */ + uint32_t FS1:1; /*!< \brief bit: 10 Fault Status bits bit 4 */ + RESERVED(1:1, uint32_t) + uint32_t ExT:1; /*!< \brief bit: 12 External abort type */ + RESERVED(2:19, uint32_t) + } s; /*!< \brief Structure used for bit access in short format */ + struct + { + uint32_t STATUS:6; /*!< \brief bit: 0.. 5 Fault Status bits */ + RESERVED(0:3, uint32_t) + uint32_t LPAE:1; /*!< \brief bit: 9 Large Physical Address Extension */ + RESERVED(1:2, uint32_t) + uint32_t ExT:1; /*!< \brief bit: 12 External abort type */ + RESERVED(2:19, uint32_t) + } l; /*!< \brief Structure used for bit access in long format */ + uint32_t w; /*!< \brief Type used for word access */ +} IFSR_Type; + +#define IFSR_ExT_Pos 12U /*!< \brief IFSR: ExT Position */ +#define IFSR_ExT_Msk (1UL << IFSR_ExT_Pos) /*!< \brief IFSR: ExT Mask */ + +#define IFSR_FS1_Pos 10U /*!< \brief IFSR: FS1 Position */ +#define IFSR_FS1_Msk (1UL << IFSR_FS1_Pos) /*!< \brief IFSR: FS1 Mask */ + +#define IFSR_LPAE_Pos 9U /*!< \brief IFSR: LPAE Position */ +#define IFSR_LPAE_Msk (0x1UL << IFSR_LPAE_Pos) /*!< \brief IFSR: LPAE Mask */ + +#define IFSR_FS0_Pos 0U /*!< \brief IFSR: FS0 Position */ +#define IFSR_FS0_Msk (0xFUL << IFSR_FS0_Pos) /*!< \brief IFSR: FS0 Mask */ + +#define IFSR_STATUS_Pos 0U /*!< \brief IFSR: STATUS Position */ +#define IFSR_STATUS_Msk (0x3FUL << IFSR_STATUS_Pos) /*!< \brief IFSR: STATUS Mask */ + +/* CP15 Register ISR */ +typedef union +{ + struct + { + RESERVED(0:6, uint32_t) + uint32_t F:1; /*!< \brief bit: 6 FIQ pending bit */ + uint32_t I:1; /*!< \brief bit: 7 IRQ pending bit */ + uint32_t A:1; /*!< \brief bit: 8 External abort pending bit */ + RESERVED(1:23, uint32_t) + } b; /*!< \brief Structure used for bit access */ + uint32_t w; /*!< \brief Type used for word access */ +} ISR_Type; + +#define ISR_A_Pos 13U /*!< \brief ISR: A Position */ +#define ISR_A_Msk (1UL << ISR_A_Pos) /*!< \brief ISR: A Mask */ + +#define ISR_I_Pos 12U /*!< \brief ISR: I Position */ +#define ISR_I_Msk (1UL << ISR_I_Pos) /*!< \brief ISR: I Mask */ + +#define ISR_F_Pos 11U /*!< \brief ISR: F Position */ +#define ISR_F_Msk (1UL << ISR_F_Pos) /*!< \brief ISR: F Mask */ + +/* DACR Register */ +#define DACR_D_Pos_(n) (2U*n) /*!< \brief DACR: Dn Position */ +#define DACR_D_Msk_(n) (3UL << DACR_D_Pos_(n)) /*!< \brief DACR: Dn Mask */ +#define DACR_Dn_NOACCESS 0U /*!< \brief DACR Dn field: No access */ +#define DACR_Dn_CLIENT 1U /*!< \brief DACR Dn field: Client */ +#define DACR_Dn_MANAGER 3U /*!< \brief DACR Dn field: Manager */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param [in] field Name of the register bit field. + \param [in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param [in] field Name of the register bit field. + \param [in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + + +/** + \brief Union type to access the L2C_310 Cache Controller. +*/ +#if (__L2C_PRESENT == 1U) || defined(DOXYGEN) +typedef struct +{ + __IM uint32_t CACHE_ID; /*!< \brief Offset: 0x0000 (R/ ) Cache ID Register */ + __IM uint32_t CACHE_TYPE; /*!< \brief Offset: 0x0004 (R/ ) Cache Type Register */ + RESERVED(0[0x3e], uint32_t) + __IOM uint32_t CONTROL; /*!< \brief Offset: 0x0100 (R/W) Control Register */ + __IOM uint32_t AUX_CNT; /*!< \brief Offset: 0x0104 (R/W) Auxiliary Control */ + RESERVED(1[0x3e], uint32_t) + __IOM uint32_t EVENT_CONTROL; /*!< \brief Offset: 0x0200 (R/W) Event Counter Control */ + __IOM uint32_t EVENT_COUNTER1_CONF; /*!< \brief Offset: 0x0204 (R/W) Event Counter 1 Configuration */ + __IOM uint32_t EVENT_COUNTER0_CONF; /*!< \brief Offset: 0x0208 (R/W) Event Counter 1 Configuration */ + RESERVED(2[0x2], uint32_t) + __IOM uint32_t INTERRUPT_MASK; /*!< \brief Offset: 0x0214 (R/W) Interrupt Mask */ + __IM uint32_t MASKED_INT_STATUS; /*!< \brief Offset: 0x0218 (R/ ) Masked Interrupt Status */ + __IM uint32_t RAW_INT_STATUS; /*!< \brief Offset: 0x021c (R/ ) Raw Interrupt Status */ + __OM uint32_t INTERRUPT_CLEAR; /*!< \brief Offset: 0x0220 ( /W) Interrupt Clear */ + RESERVED(3[0x143], uint32_t) + __IOM uint32_t CACHE_SYNC; /*!< \brief Offset: 0x0730 (R/W) Cache Sync */ + RESERVED(4[0xf], uint32_t) + __IOM uint32_t INV_LINE_PA; /*!< \brief Offset: 0x0770 (R/W) Invalidate Line By PA */ + RESERVED(6[2], uint32_t) + __IOM uint32_t INV_WAY; /*!< \brief Offset: 0x077c (R/W) Invalidate by Way */ + RESERVED(5[0xc], uint32_t) + __IOM uint32_t CLEAN_LINE_PA; /*!< \brief Offset: 0x07b0 (R/W) Clean Line by PA */ + RESERVED(7[1], uint32_t) + __IOM uint32_t CLEAN_LINE_INDEX_WAY; /*!< \brief Offset: 0x07b8 (R/W) Clean Line by Index/Way */ + __IOM uint32_t CLEAN_WAY; /*!< \brief Offset: 0x07bc (R/W) Clean by Way */ + RESERVED(8[0xc], uint32_t) + __IOM uint32_t CLEAN_INV_LINE_PA; /*!< \brief Offset: 0x07f0 (R/W) Clean and Invalidate Line by PA */ + RESERVED(9[1], uint32_t) + __IOM uint32_t CLEAN_INV_LINE_INDEX_WAY; /*!< \brief Offset: 0x07f8 (R/W) Clean and Invalidate Line by Index/Way */ + __IOM uint32_t CLEAN_INV_WAY; /*!< \brief Offset: 0x07fc (R/W) Clean and Invalidate by Way */ + RESERVED(10[0x40], uint32_t) + __IOM uint32_t DATA_LOCK_0_WAY; /*!< \brief Offset: 0x0900 (R/W) Data Lockdown 0 by Way */ + __IOM uint32_t INST_LOCK_0_WAY; /*!< \brief Offset: 0x0904 (R/W) Instruction Lockdown 0 by Way */ + __IOM uint32_t DATA_LOCK_1_WAY; /*!< \brief Offset: 0x0908 (R/W) Data Lockdown 1 by Way */ + __IOM uint32_t INST_LOCK_1_WAY; /*!< \brief Offset: 0x090c (R/W) Instruction Lockdown 1 by Way */ + __IOM uint32_t DATA_LOCK_2_WAY; /*!< \brief Offset: 0x0910 (R/W) Data Lockdown 2 by Way */ + __IOM uint32_t INST_LOCK_2_WAY; /*!< \brief Offset: 0x0914 (R/W) Instruction Lockdown 2 by Way */ + __IOM uint32_t DATA_LOCK_3_WAY; /*!< \brief Offset: 0x0918 (R/W) Data Lockdown 3 by Way */ + __IOM uint32_t INST_LOCK_3_WAY; /*!< \brief Offset: 0x091c (R/W) Instruction Lockdown 3 by Way */ + __IOM uint32_t DATA_LOCK_4_WAY; /*!< \brief Offset: 0x0920 (R/W) Data Lockdown 4 by Way */ + __IOM uint32_t INST_LOCK_4_WAY; /*!< \brief Offset: 0x0924 (R/W) Instruction Lockdown 4 by Way */ + __IOM uint32_t DATA_LOCK_5_WAY; /*!< \brief Offset: 0x0928 (R/W) Data Lockdown 5 by Way */ + __IOM uint32_t INST_LOCK_5_WAY; /*!< \brief Offset: 0x092c (R/W) Instruction Lockdown 5 by Way */ + __IOM uint32_t DATA_LOCK_6_WAY; /*!< \brief Offset: 0x0930 (R/W) Data Lockdown 5 by Way */ + __IOM uint32_t INST_LOCK_6_WAY; /*!< \brief Offset: 0x0934 (R/W) Instruction Lockdown 5 by Way */ + __IOM uint32_t DATA_LOCK_7_WAY; /*!< \brief Offset: 0x0938 (R/W) Data Lockdown 6 by Way */ + __IOM uint32_t INST_LOCK_7_WAY; /*!< \brief Offset: 0x093c (R/W) Instruction Lockdown 6 by Way */ + RESERVED(11[0x4], uint32_t) + __IOM uint32_t LOCK_LINE_EN; /*!< \brief Offset: 0x0950 (R/W) Lockdown by Line Enable */ + __IOM uint32_t UNLOCK_ALL_BY_WAY; /*!< \brief Offset: 0x0954 (R/W) Unlock All Lines by Way */ + RESERVED(12[0xaa], uint32_t) + __IOM uint32_t ADDRESS_FILTER_START; /*!< \brief Offset: 0x0c00 (R/W) Address Filtering Start */ + __IOM uint32_t ADDRESS_FILTER_END; /*!< \brief Offset: 0x0c04 (R/W) Address Filtering End */ + RESERVED(13[0xce], uint32_t) + __IOM uint32_t DEBUG_CONTROL; /*!< \brief Offset: 0x0f40 (R/W) Debug Control Register */ +} L2C_310_TypeDef; + +#define L2C_310 ((L2C_310_TypeDef *)L2C_310_BASE) /*!< \brief L2C_310 register set access pointer */ +#endif + +#if (__GIC_PRESENT == 1U) || defined(DOXYGEN) + +/** \brief Structure type to access the Generic Interrupt Controller Distributor (GICD) +*/ +typedef struct +{ + __IOM uint32_t CTLR; /*!< \brief Offset: 0x000 (R/W) Distributor Control Register */ + __IM uint32_t TYPER; /*!< \brief Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IM uint32_t IIDR; /*!< \brief Offset: 0x008 (R/ ) Distributor Implementer Identification Register */ + RESERVED(0, uint32_t) + __IOM uint32_t STATUSR; /*!< \brief Offset: 0x010 (R/W) Error Reporting Status Register, optional */ + RESERVED(1[11], uint32_t) + __OM uint32_t SETSPI_NSR; /*!< \brief Offset: 0x040 ( /W) Set SPI Register */ + RESERVED(2, uint32_t) + __OM uint32_t CLRSPI_NSR; /*!< \brief Offset: 0x048 ( /W) Clear SPI Register */ + RESERVED(3, uint32_t) + __OM uint32_t SETSPI_SR; /*!< \brief Offset: 0x050 ( /W) Set SPI, Secure Register */ + RESERVED(4, uint32_t) + __OM uint32_t CLRSPI_SR; /*!< \brief Offset: 0x058 ( /W) Clear SPI, Secure Register */ + RESERVED(5[9], uint32_t) + __IOM uint32_t IGROUPR[32]; /*!< \brief Offset: 0x080 (R/W) Interrupt Group Registers */ + __IOM uint32_t ISENABLER[32]; /*!< \brief Offset: 0x100 (R/W) Interrupt Set-Enable Registers */ + __IOM uint32_t ICENABLER[32]; /*!< \brief Offset: 0x180 (R/W) Interrupt Clear-Enable Registers */ + __IOM uint32_t ISPENDR[32]; /*!< \brief Offset: 0x200 (R/W) Interrupt Set-Pending Registers */ + __IOM uint32_t ICPENDR[32]; /*!< \brief Offset: 0x280 (R/W) Interrupt Clear-Pending Registers */ + __IOM uint32_t ISACTIVER[32]; /*!< \brief Offset: 0x300 (R/W) Interrupt Set-Active Registers */ + __IOM uint32_t ICACTIVER[32]; /*!< \brief Offset: 0x380 (R/W) Interrupt Clear-Active Registers */ + __IOM uint32_t IPRIORITYR[255]; /*!< \brief Offset: 0x400 (R/W) Interrupt Priority Registers */ + RESERVED(6, uint32_t) + __IOM uint32_t ITARGETSR[255]; /*!< \brief Offset: 0x800 (R/W) Interrupt Targets Registers */ + RESERVED(7, uint32_t) + __IOM uint32_t ICFGR[64]; /*!< \brief Offset: 0xC00 (R/W) Interrupt Configuration Registers */ + __IOM uint32_t IGRPMODR[32]; /*!< \brief Offset: 0xD00 (R/W) Interrupt Group Modifier Registers */ + RESERVED(8[32], uint32_t) + __IOM uint32_t NSACR[64]; /*!< \brief Offset: 0xE00 (R/W) Non-secure Access Control Registers */ + __OM uint32_t SGIR; /*!< \brief Offset: 0xF00 ( /W) Software Generated Interrupt Register */ + RESERVED(9[3], uint32_t) + __IOM uint32_t CPENDSGIR[4]; /*!< \brief Offset: 0xF10 (R/W) SGI Clear-Pending Registers */ + __IOM uint32_t SPENDSGIR[4]; /*!< \brief Offset: 0xF20 (R/W) SGI Set-Pending Registers */ + RESERVED(10[5236], uint32_t) + __IOM uint64_t IROUTER[988]; /*!< \brief Offset: 0x6100(R/W) Interrupt Routing Registers */ +} GICDistributor_Type; + +#define GICDistributor ((GICDistributor_Type *) GIC_DISTRIBUTOR_BASE ) /*!< \brief GIC Distributor register set access pointer */ + +/** \brief Structure type to access the Generic Interrupt Controller Interface (GICC) +*/ +typedef struct +{ + __IOM uint32_t CTLR; /*!< \brief Offset: 0x000 (R/W) CPU Interface Control Register */ + __IOM uint32_t PMR; /*!< \brief Offset: 0x004 (R/W) Interrupt Priority Mask Register */ + __IOM uint32_t BPR; /*!< \brief Offset: 0x008 (R/W) Binary Point Register */ + __IM uint32_t IAR; /*!< \brief Offset: 0x00C (R/ ) Interrupt Acknowledge Register */ + __OM uint32_t EOIR; /*!< \brief Offset: 0x010 ( /W) End Of Interrupt Register */ + __IM uint32_t RPR; /*!< \brief Offset: 0x014 (R/ ) Running Priority Register */ + __IM uint32_t HPPIR; /*!< \brief Offset: 0x018 (R/ ) Highest Priority Pending Interrupt Register */ + __IOM uint32_t ABPR; /*!< \brief Offset: 0x01C (R/W) Aliased Binary Point Register */ + __IM uint32_t AIAR; /*!< \brief Offset: 0x020 (R/ ) Aliased Interrupt Acknowledge Register */ + __OM uint32_t AEOIR; /*!< \brief Offset: 0x024 ( /W) Aliased End Of Interrupt Register */ + __IM uint32_t AHPPIR; /*!< \brief Offset: 0x028 (R/ ) Aliased Highest Priority Pending Interrupt Register */ + __IOM uint32_t STATUSR; /*!< \brief Offset: 0x02C (R/W) Error Reporting Status Register, optional */ + RESERVED(1[40], uint32_t) + __IOM uint32_t APR[4]; /*!< \brief Offset: 0x0D0 (R/W) Active Priority Register */ + __IOM uint32_t NSAPR[4]; /*!< \brief Offset: 0x0E0 (R/W) Non-secure Active Priority Register */ + RESERVED(2[3], uint32_t) + __IM uint32_t IIDR; /*!< \brief Offset: 0x0FC (R/ ) CPU Interface Identification Register */ + RESERVED(3[960], uint32_t) + __OM uint32_t DIR; /*!< \brief Offset: 0x1000( /W) Deactivate Interrupt Register */ +} GICInterface_Type; + +#define GICInterface ((GICInterface_Type *) GIC_INTERFACE_BASE ) /*!< \brief GIC Interface register set access pointer */ +#endif + +#if (__TIM_PRESENT == 1U) || defined(DOXYGEN) +#if ((__CORTEX_A == 5U) || (__CORTEX_A == 9U)) || defined(DOXYGEN) +/** \brief Structure type to access the Private Timer +*/ +typedef struct +{ + __IOM uint32_t LOAD; //!< \brief Offset: 0x000 (R/W) Private Timer Load Register + __IOM uint32_t COUNTER; //!< \brief Offset: 0x004 (R/W) Private Timer Counter Register + __IOM uint32_t CONTROL; //!< \brief Offset: 0x008 (R/W) Private Timer Control Register + __IOM uint32_t ISR; //!< \brief Offset: 0x00C (R/W) Private Timer Interrupt Status Register + RESERVED(0[4], uint32_t) + __IOM uint32_t WLOAD; //!< \brief Offset: 0x020 (R/W) Watchdog Load Register + __IOM uint32_t WCOUNTER; //!< \brief Offset: 0x024 (R/W) Watchdog Counter Register + __IOM uint32_t WCONTROL; //!< \brief Offset: 0x028 (R/W) Watchdog Control Register + __IOM uint32_t WISR; //!< \brief Offset: 0x02C (R/W) Watchdog Interrupt Status Register + __IOM uint32_t WRESET; //!< \brief Offset: 0x030 (R/W) Watchdog Reset Status Register + __OM uint32_t WDISABLE; //!< \brief Offset: 0x034 ( /W) Watchdog Disable Register +} Timer_Type; +#define PTIM ((Timer_Type *) TIMER_BASE ) /*!< \brief Timer register struct */ +#endif +#endif + + /******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - L1 Cache Functions + - L2C-310 Cache Controller Functions + - PL1 Timer Functions + - GIC Functions + - MMU Functions + ******************************************************************************/ + +/* ########################## L1 Cache functions ################################# */ + +/** \brief Enable Caches by setting I and C bits in SCTLR register. +*/ +__STATIC_FORCEINLINE void L1C_EnableCaches(void) { + __set_SCTLR( __get_SCTLR() | SCTLR_I_Msk | SCTLR_C_Msk); + __ISB(); +} + +/** \brief Disable Caches by clearing I and C bits in SCTLR register. +*/ +__STATIC_FORCEINLINE void L1C_DisableCaches(void) { + __set_SCTLR( __get_SCTLR() & (~SCTLR_I_Msk) & (~SCTLR_C_Msk)); + __ISB(); +} + +/** \brief Enable Branch Prediction by setting Z bit in SCTLR register. +*/ +__STATIC_FORCEINLINE void L1C_EnableBTAC(void) { + __set_SCTLR( __get_SCTLR() | SCTLR_Z_Msk); + __ISB(); +} + +/** \brief Disable Branch Prediction by clearing Z bit in SCTLR register. +*/ +__STATIC_FORCEINLINE void L1C_DisableBTAC(void) { + __set_SCTLR( __get_SCTLR() & (~SCTLR_Z_Msk)); + __ISB(); +} + +/** \brief Invalidate entire branch predictor array +*/ +__STATIC_FORCEINLINE void L1C_InvalidateBTAC(void) { + __set_BPIALL(0); + __DSB(); //ensure completion of the invalidation + __ISB(); //ensure instruction fetch path sees new state +} + +/** \brief Invalidate the whole instruction cache +*/ +__STATIC_FORCEINLINE void L1C_InvalidateICacheAll(void) { + __set_ICIALLU(0); + __DSB(); //ensure completion of the invalidation + __ISB(); //ensure instruction fetch path sees new I cache state +} + +/** \brief Clean data cache line by address. +* \param [in] va Pointer to data to clear the cache for. +*/ +__STATIC_FORCEINLINE void L1C_CleanDCacheMVA(void *va) { + __set_DCCMVAC((uint32_t)va); + __DMB(); //ensure the ordering of data cache maintenance operations and their effects +} + +/** \brief Invalidate data cache line by address. +* \param [in] va Pointer to data to invalidate the cache for. +*/ +__STATIC_FORCEINLINE void L1C_InvalidateDCacheMVA(void *va) { + __set_DCIMVAC((uint32_t)va); + __DMB(); //ensure the ordering of data cache maintenance operations and their effects +} + +/** \brief Clean and Invalidate data cache by address. +* \param [in] va Pointer to data to invalidate the cache for. +*/ +__STATIC_FORCEINLINE void L1C_CleanInvalidateDCacheMVA(void *va) { + __set_DCCIMVAC((uint32_t)va); + __DMB(); //ensure the ordering of data cache maintenance operations and their effects +} + +/** \brief Calculate log2 rounded up +* - log(0) => 0 +* - log(1) => 0 +* - log(2) => 1 +* - log(3) => 2 +* - log(4) => 2 +* - log(5) => 3 +* : : +* - log(16) => 4 +* - log(32) => 5 +* : : +* \param [in] n input value parameter +* \return log2(n) +*/ +__STATIC_FORCEINLINE uint8_t __log2_up(uint32_t n) +{ + if (n < 2U) { + return 0U; + } + uint8_t log = 0U; + uint32_t t = n; + while(t > 1U) + { + log++; + t >>= 1U; + } + if (n & 1U) { log++; } + return log; +} + +/** \brief Apply cache maintenance to given cache level. +* \param [in] level cache level to be maintained +* \param [in] maint 0 - invalidate, 1 - clean, otherwise - invalidate and clean +*/ +__STATIC_FORCEINLINE void __L1C_MaintainDCacheSetWay(uint32_t level, uint32_t maint) +{ + uint32_t Dummy; + uint32_t ccsidr; + uint32_t num_sets; + uint32_t num_ways; + uint32_t shift_way; + uint32_t log2_linesize; + int32_t log2_num_ways; + + Dummy = level << 1U; + /* set csselr, select ccsidr register */ + __set_CSSELR(Dummy); + /* get current ccsidr register */ + ccsidr = __get_CCSIDR(); + num_sets = ((ccsidr & 0x0FFFE000U) >> 13U) + 1U; + num_ways = ((ccsidr & 0x00001FF8U) >> 3U) + 1U; + log2_linesize = (ccsidr & 0x00000007U) + 2U + 2U; + log2_num_ways = __log2_up(num_ways); + if ((log2_num_ways < 0) || (log2_num_ways > 32)) { + return; // FATAL ERROR + } + shift_way = 32U - (uint32_t)log2_num_ways; + for(int32_t way = num_ways-1; way >= 0; way--) + { + for(int32_t set = num_sets-1; set >= 0; set--) + { + Dummy = (level << 1U) | (((uint32_t)set) << log2_linesize) | (((uint32_t)way) << shift_way); + switch (maint) + { + case 0U: __set_DCISW(Dummy); break; + case 1U: __set_DCCSW(Dummy); break; + default: __set_DCCISW(Dummy); break; + } + } + } + __DMB(); +} + +/** \brief Clean and Invalidate the entire data or unified cache +* Generic mechanism for cleaning/invalidating the entire data or unified cache to the point of coherency +* \param [in] op 0 - invalidate, 1 - clean, otherwise - invalidate and clean +*/ +__STATIC_FORCEINLINE void L1C_CleanInvalidateCache(uint32_t op) { + uint32_t clidr; + uint32_t cache_type; + clidr = __get_CLIDR(); + for(uint32_t i = 0U; i<7U; i++) + { + cache_type = (clidr >> i*3U) & 0x7UL; + if ((cache_type >= 2U) && (cache_type <= 4U)) + { + __L1C_MaintainDCacheSetWay(i, op); + } + } +} + +/** \brief Clean and Invalidate the entire data or unified cache +* Generic mechanism for cleaning/invalidating the entire data or unified cache to the point of coherency +* \param [in] op 0 - invalidate, 1 - clean, otherwise - invalidate and clean +* \deprecated Use generic L1C_CleanInvalidateCache instead. +*/ +CMSIS_DEPRECATED +__STATIC_FORCEINLINE void __L1C_CleanInvalidateCache(uint32_t op) { + L1C_CleanInvalidateCache(op); +} + +/** \brief Invalidate the whole data cache. +*/ +__STATIC_FORCEINLINE void L1C_InvalidateDCacheAll(void) { + L1C_CleanInvalidateCache(0); +} + +/** \brief Clean the whole data cache. + */ +__STATIC_FORCEINLINE void L1C_CleanDCacheAll(void) { + L1C_CleanInvalidateCache(1); +} + +/** \brief Clean and invalidate the whole data cache. + */ +__STATIC_FORCEINLINE void L1C_CleanInvalidateDCacheAll(void) { + L1C_CleanInvalidateCache(2); +} + +/* ########################## L2 Cache functions ################################# */ +#if (__L2C_PRESENT == 1U) || defined(DOXYGEN) +/** \brief Cache Sync operation by writing CACHE_SYNC register. +*/ +__STATIC_INLINE void L2C_Sync(void) +{ + L2C_310->CACHE_SYNC = 0x0; +} + +/** \brief Read cache controller cache ID from CACHE_ID register. + * \return L2C_310_TypeDef::CACHE_ID + */ +__STATIC_INLINE int L2C_GetID (void) +{ + return L2C_310->CACHE_ID; +} + +/** \brief Read cache controller cache type from CACHE_TYPE register. +* \return L2C_310_TypeDef::CACHE_TYPE +*/ +__STATIC_INLINE int L2C_GetType (void) +{ + return L2C_310->CACHE_TYPE; +} + +/** \brief Invalidate all cache by way +*/ +__STATIC_INLINE void L2C_InvAllByWay (void) +{ + unsigned int assoc; + + if (L2C_310->AUX_CNT & (1U << 16U)) { + assoc = 16U; + } else { + assoc = 8U; + } + + L2C_310->INV_WAY = (1U << assoc) - 1U; + while(L2C_310->INV_WAY & ((1U << assoc) - 1U)); //poll invalidate + + L2C_Sync(); +} + +/** \brief Clean and Invalidate all cache by way +*/ +__STATIC_INLINE void L2C_CleanInvAllByWay (void) +{ + unsigned int assoc; + + if (L2C_310->AUX_CNT & (1U << 16U)) { + assoc = 16U; + } else { + assoc = 8U; + } + + L2C_310->CLEAN_INV_WAY = (1U << assoc) - 1U; + while(L2C_310->CLEAN_INV_WAY & ((1U << assoc) - 1U)); //poll invalidate + + L2C_Sync(); +} + +/** \brief Enable Level 2 Cache +*/ +__STATIC_INLINE void L2C_Enable(void) +{ + L2C_310->CONTROL = 0; + L2C_310->INTERRUPT_CLEAR = 0x000001FFuL; + L2C_310->DEBUG_CONTROL = 0; + L2C_310->DATA_LOCK_0_WAY = 0; + L2C_310->CACHE_SYNC = 0; + L2C_310->CONTROL = 0x01; + L2C_Sync(); +} + +/** \brief Disable Level 2 Cache +*/ +__STATIC_INLINE void L2C_Disable(void) +{ + L2C_310->CONTROL = 0x00; + L2C_Sync(); +} + +/** \brief Invalidate cache by physical address +* \param [in] pa Pointer to data to invalidate cache for. +*/ +__STATIC_INLINE void L2C_InvPa (void *pa) +{ + L2C_310->INV_LINE_PA = (unsigned int)pa; + L2C_Sync(); +} + +/** \brief Clean cache by physical address +* \param [in] pa Pointer to data to invalidate cache for. +*/ +__STATIC_INLINE void L2C_CleanPa (void *pa) +{ + L2C_310->CLEAN_LINE_PA = (unsigned int)pa; + L2C_Sync(); +} + +/** \brief Clean and invalidate cache by physical address +* \param [in] pa Pointer to data to invalidate cache for. +*/ +__STATIC_INLINE void L2C_CleanInvPa (void *pa) +{ + L2C_310->CLEAN_INV_LINE_PA = (unsigned int)pa; + L2C_Sync(); +} +#endif + +/* ########################## GIC functions ###################################### */ +#if (__GIC_PRESENT == 1U) || defined(DOXYGEN) + +/** \brief Enable the interrupt distributor using the GIC's CTLR register. +*/ +__STATIC_INLINE void GIC_EnableDistributor(void) +{ + GICDistributor->CTLR |= 1U; +} + +/** \brief Disable the interrupt distributor using the GIC's CTLR register. +*/ +__STATIC_INLINE void GIC_DisableDistributor(void) +{ + GICDistributor->CTLR &=~1U; +} + +/** \brief Read the GIC's TYPER register. +* \return GICDistributor_Type::TYPER +*/ +__STATIC_INLINE uint32_t GIC_DistributorInfo(void) +{ + return (GICDistributor->TYPER); +} + +/** \brief Reads the GIC's IIDR register. +* \return GICDistributor_Type::IIDR +*/ +__STATIC_INLINE uint32_t GIC_DistributorImplementer(void) +{ + return (GICDistributor->IIDR); +} + +/** \brief Sets the GIC's ITARGETSR register for the given interrupt. +* \param [in] IRQn Interrupt to be configured. +* \param [in] cpu_target CPU interfaces to assign this interrupt to. +*/ +__STATIC_INLINE void GIC_SetTarget(IRQn_Type IRQn, uint32_t cpu_target) +{ + uint32_t mask = GICDistributor->ITARGETSR[IRQn / 4U] & ~(0xFFUL << ((IRQn % 4U) * 8U)); + GICDistributor->ITARGETSR[IRQn / 4U] = mask | ((cpu_target & 0xFFUL) << ((IRQn % 4U) * 8U)); +} + +/** \brief Read the GIC's ITARGETSR register. +* \param [in] IRQn Interrupt to acquire the configuration for. +* \return GICDistributor_Type::ITARGETSR +*/ +__STATIC_INLINE uint32_t GIC_GetTarget(IRQn_Type IRQn) +{ + return (GICDistributor->ITARGETSR[IRQn / 4U] >> ((IRQn % 4U) * 8U)) & 0xFFUL; +} + +/** \brief Enable the CPU's interrupt interface. +*/ +__STATIC_INLINE void GIC_EnableInterface(void) +{ + GICInterface->CTLR |= 1U; //enable interface +} + +/** \brief Disable the CPU's interrupt interface. +*/ +__STATIC_INLINE void GIC_DisableInterface(void) +{ + GICInterface->CTLR &=~1U; //disable distributor +} + +/** \brief Read the CPU's IAR register. +* \return GICInterface_Type::IAR +*/ +__STATIC_INLINE IRQn_Type GIC_AcknowledgePending(void) +{ + return (IRQn_Type)(GICInterface->IAR); +} + +/** \brief Writes the given interrupt number to the CPU's EOIR register. +* \param [in] IRQn The interrupt to be signaled as finished. +*/ +__STATIC_INLINE void GIC_EndInterrupt(IRQn_Type IRQn) +{ + GICInterface->EOIR = IRQn; +} + +/** \brief Enables the given interrupt using GIC's ISENABLER register. +* \param [in] IRQn The interrupt to be enabled. +*/ +__STATIC_INLINE void GIC_EnableIRQ(IRQn_Type IRQn) +{ + GICDistributor->ISENABLER[IRQn / 32U] = 1U << (IRQn % 32U); +} + +/** \brief Get interrupt enable status using GIC's ISENABLER register. +* \param [in] IRQn The interrupt to be queried. +* \return 0 - interrupt is not enabled, 1 - interrupt is enabled. +*/ +__STATIC_INLINE uint32_t GIC_GetEnableIRQ(IRQn_Type IRQn) +{ + return (GICDistributor->ISENABLER[IRQn / 32U] >> (IRQn % 32U)) & 1UL; +} + +/** \brief Disables the given interrupt using GIC's ICENABLER register. +* \param [in] IRQn The interrupt to be disabled. +*/ +__STATIC_INLINE void GIC_DisableIRQ(IRQn_Type IRQn) +{ + GICDistributor->ICENABLER[IRQn / 32U] = 1U << (IRQn % 32U); +} + +/** \brief Get interrupt pending status from GIC's ISPENDR register. +* \param [in] IRQn The interrupt to be queried. +* \return 0 - interrupt is not pending, 1 - interrupt is pendig. +*/ +__STATIC_INLINE uint32_t GIC_GetPendingIRQ(IRQn_Type IRQn) +{ + uint32_t pend; + + if (IRQn >= 16U) { + pend = (GICDistributor->ISPENDR[IRQn / 32U] >> (IRQn % 32U)) & 1UL; + } else { + // INTID 0-15 Software Generated Interrupt + pend = (GICDistributor->SPENDSGIR[IRQn / 4U] >> ((IRQn % 4U) * 8U)) & 0xFFUL; + // No CPU identification offered + if (pend != 0U) { + pend = 1U; + } else { + pend = 0U; + } + } + + return (pend); +} + +/** \brief Sets the given interrupt as pending using GIC's ISPENDR register. +* \param [in] IRQn The interrupt to be enabled. +*/ +__STATIC_INLINE void GIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if (IRQn >= 16U) { + GICDistributor->ISPENDR[IRQn / 32U] = 1U << (IRQn % 32U); + } else { + // INTID 0-15 Software Generated Interrupt + GICDistributor->SPENDSGIR[IRQn / 4U] = 1U << ((IRQn % 4U) * 8U); + } +} + +/** \brief Clears the given interrupt from being pending using GIC's ICPENDR register. +* \param [in] IRQn The interrupt to be enabled. +*/ +__STATIC_INLINE void GIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if (IRQn >= 16U) { + GICDistributor->ICPENDR[IRQn / 32U] = 1U << (IRQn % 32U); + } else { + // INTID 0-15 Software Generated Interrupt + GICDistributor->CPENDSGIR[IRQn / 4U] = 1U << ((IRQn % 4U) * 8U); + } +} + +/** \brief Sets the interrupt configuration using GIC's ICFGR register. +* \param [in] IRQn The interrupt to be configured. +* \param [in] int_config Int_config field value. Bit 0: Reserved (0 - N-N model, 1 - 1-N model for some GIC before v1) +* Bit 1: 0 - level sensitive, 1 - edge triggered +*/ +__STATIC_INLINE void GIC_SetConfiguration(IRQn_Type IRQn, uint32_t int_config) +{ + uint32_t icfgr = GICDistributor->ICFGR[IRQn / 16U]; + uint32_t shift = (IRQn % 16U) << 1U; + + icfgr &= (~(3U << shift)); + icfgr |= ( int_config << shift); + + GICDistributor->ICFGR[IRQn / 16U] = icfgr; +} + +/** \brief Get the interrupt configuration from the GIC's ICFGR register. +* \param [in] IRQn Interrupt to acquire the configuration for. +* \return Int_config field value. Bit 0: Reserved (0 - N-N model, 1 - 1-N model for some GIC before v1) +* Bit 1: 0 - level sensitive, 1 - edge triggered +*/ +__STATIC_INLINE uint32_t GIC_GetConfiguration(IRQn_Type IRQn) +{ + return (GICDistributor->ICFGR[IRQn / 16U] >> ((IRQn % 16U) >> 1U)); +} + +/** \brief Set the priority for the given interrupt in the GIC's IPRIORITYR register. +* \param [in] IRQn The interrupt to be configured. +* \param [in] priority The priority for the interrupt, lower values denote higher priorities. +*/ +__STATIC_INLINE void GIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + uint32_t mask = GICDistributor->IPRIORITYR[IRQn / 4U] & ~(0xFFUL << ((IRQn % 4U) * 8U)); + GICDistributor->IPRIORITYR[IRQn / 4U] = mask | ((priority & 0xFFUL) << ((IRQn % 4U) * 8U)); +} + +/** \brief Read the current interrupt priority from GIC's IPRIORITYR register. +* \param [in] IRQn The interrupt to be queried. +*/ +__STATIC_INLINE uint32_t GIC_GetPriority(IRQn_Type IRQn) +{ + return (GICDistributor->IPRIORITYR[IRQn / 4U] >> ((IRQn % 4U) * 8U)) & 0xFFUL; +} + +/** \brief Set the interrupt priority mask using CPU's PMR register. +* \param [in] priority Priority mask to be set. +*/ +__STATIC_INLINE void GIC_SetInterfacePriorityMask(uint32_t priority) +{ + GICInterface->PMR = priority & 0xFFUL; //set priority mask +} + +/** \brief Read the current interrupt priority mask from CPU's PMR register. +* \result GICInterface_Type::PMR +*/ +__STATIC_INLINE uint32_t GIC_GetInterfacePriorityMask(void) +{ + return GICInterface->PMR; +} + +/** \brief Configures the group priority and subpriority split point using CPU's BPR register. +* \param [in] binary_point Amount of bits used as subpriority. +*/ +__STATIC_INLINE void GIC_SetBinaryPoint(uint32_t binary_point) +{ + GICInterface->BPR = binary_point & 7U; //set binary point +} + +/** \brief Read the current group priority and subpriority split point from CPU's BPR register. +* \return GICInterface_Type::BPR +*/ +__STATIC_INLINE uint32_t GIC_GetBinaryPoint(void) +{ + return GICInterface->BPR; +} + +/** \brief Get the status for a given interrupt. +* \param [in] IRQn The interrupt to get status for. +* \return 0 - not pending/active, 1 - pending, 2 - active, 3 - pending and active +*/ +__STATIC_INLINE uint32_t GIC_GetIRQStatus(IRQn_Type IRQn) +{ + uint32_t pending, active; + + active = ((GICDistributor->ISACTIVER[IRQn / 32U]) >> (IRQn % 32U)) & 1UL; + pending = ((GICDistributor->ISPENDR[IRQn / 32U]) >> (IRQn % 32U)) & 1UL; + + return ((active<<1U) | pending); +} + +/** \brief Generate a software interrupt using GIC's SGIR register. +* \param [in] IRQn Software interrupt to be generated. +* \param [in] target_list List of CPUs the software interrupt should be forwarded to. +* \param [in] filter_list Filter to be applied to determine interrupt receivers. +*/ +__STATIC_INLINE void GIC_SendSGI(IRQn_Type IRQn, uint32_t target_list, uint32_t filter_list) +{ + GICDistributor->SGIR = ((filter_list & 3U) << 24U) | ((target_list & 0xFFUL) << 16U) | (IRQn & 0x0FUL); +} + +/** \brief Get the interrupt number of the highest interrupt pending from CPU's HPPIR register. +* \return GICInterface_Type::HPPIR +*/ +__STATIC_INLINE uint32_t GIC_GetHighPendingIRQ(void) +{ + return GICInterface->HPPIR; +} + +/** \brief Provides information about the implementer and revision of the CPU interface. +* \return GICInterface_Type::IIDR +*/ +__STATIC_INLINE uint32_t GIC_GetInterfaceId(void) +{ + return GICInterface->IIDR; +} + +/** \brief Set the interrupt group from the GIC's IGROUPR register. +* \param [in] IRQn The interrupt to be queried. +* \param [in] group Interrupt group number: 0 - Group 0, 1 - Group 1 +*/ +__STATIC_INLINE void GIC_SetGroup(IRQn_Type IRQn, uint32_t group) +{ + uint32_t igroupr = GICDistributor->IGROUPR[IRQn / 32U]; + uint32_t shift = (IRQn % 32U); + + igroupr &= (~(1U << shift)); + igroupr |= ( (group & 1U) << shift); + + GICDistributor->IGROUPR[IRQn / 32U] = igroupr; +} +#define GIC_SetSecurity GIC_SetGroup + +/** \brief Get the interrupt group from the GIC's IGROUPR register. +* \param [in] IRQn The interrupt to be queried. +* \return 0 - Group 0, 1 - Group 1 +*/ +__STATIC_INLINE uint32_t GIC_GetGroup(IRQn_Type IRQn) +{ + return (GICDistributor->IGROUPR[IRQn / 32U] >> (IRQn % 32U)) & 1UL; +} +#define GIC_GetSecurity GIC_GetGroup + +/** \brief Initialize the interrupt distributor. +*/ +__STATIC_INLINE void GIC_DistInit(void) +{ + uint32_t i; + uint32_t num_irq = 0U; + uint32_t priority_field; + + //A reset sets all bits in the IGROUPRs corresponding to the SPIs to 0, + //configuring all of the interrupts as Secure. + + //Disable interrupt forwarding + GIC_DisableDistributor(); + //Get the maximum number of interrupts that the GIC supports + num_irq = 32U * ((GIC_DistributorInfo() & 0x1FU) + 1U); + + /* Priority level is implementation defined. + To determine the number of priority bits implemented write 0xFF to an IPRIORITYR + priority field and read back the value stored.*/ + GIC_SetPriority((IRQn_Type)0U, 0xFFU); + priority_field = GIC_GetPriority((IRQn_Type)0U); + + for (i = 32U; i < num_irq; i++) + { + //Disable the SPI interrupt + GIC_DisableIRQ((IRQn_Type)i); + //Set level-sensitive (and N-N model) + GIC_SetConfiguration((IRQn_Type)i, 0U); + //Set priority + GIC_SetPriority((IRQn_Type)i, priority_field/2U); + //Set target list to CPU0 + GIC_SetTarget((IRQn_Type)i, 1U); + } + //Enable distributor + GIC_EnableDistributor(); +} + +/** \brief Initialize the CPU's interrupt interface +*/ +__STATIC_INLINE void GIC_CPUInterfaceInit(void) +{ + uint32_t i; + uint32_t priority_field; + + //A reset sets all bits in the IGROUPRs corresponding to the SPIs to 0, + //configuring all of the interrupts as Secure. + + //Disable interrupt forwarding + GIC_DisableInterface(); + + /* Priority level is implementation defined. + To determine the number of priority bits implemented write 0xFF to an IPRIORITYR + priority field and read back the value stored.*/ + GIC_SetPriority((IRQn_Type)0U, 0xFFU); + priority_field = GIC_GetPriority((IRQn_Type)0U); + + //SGI and PPI + for (i = 0U; i < 32U; i++) + { + if(i > 15U) { + //Set level-sensitive (and N-N model) for PPI + GIC_SetConfiguration((IRQn_Type)i, 0U); + } + //Disable SGI and PPI interrupts + GIC_DisableIRQ((IRQn_Type)i); + //Set priority + GIC_SetPriority((IRQn_Type)i, priority_field/2U); + } + //Enable interface + GIC_EnableInterface(); + //Set binary point to 0 + GIC_SetBinaryPoint(0U); + //Set priority mask + GIC_SetInterfacePriorityMask(0xFFU); +} + +/** \brief Initialize and enable the GIC +*/ +__STATIC_INLINE void GIC_Enable(void) +{ + GIC_DistInit(); + GIC_CPUInterfaceInit(); //per CPU +} +#endif + +/* ########################## Generic Timer functions ############################ */ +#if (__TIM_PRESENT == 1U) || defined(DOXYGEN) + +/* PL1 Physical Timer */ +#if (__CORTEX_A == 7U) || defined(DOXYGEN) + +/** \brief Physical Timer Control register */ +typedef union +{ + struct + { + uint32_t ENABLE:1; /*!< \brief bit: 0 Enables the timer. */ + uint32_t IMASK:1; /*!< \brief bit: 1 Timer output signal mask bit. */ + uint32_t ISTATUS:1; /*!< \brief bit: 2 The status of the timer. */ + RESERVED(0:29, uint32_t) + } b; /*!< \brief Structure used for bit access */ + uint32_t w; /*!< \brief Type used for word access */ +} CNTP_CTL_Type; + +/** \brief Configures the frequency the timer shall run at. +* \param [in] value The timer frequency in Hz. +*/ +__STATIC_INLINE void PL1_SetCounterFrequency(uint32_t value) +{ + __set_CNTFRQ(value); + __ISB(); +} + +/** \brief Sets the reset value of the timer. +* \param [in] value The value the timer is loaded with. +*/ +__STATIC_INLINE void PL1_SetLoadValue(uint32_t value) +{ + __set_CNTP_TVAL(value); + __ISB(); +} + +/** \brief Get the current counter value. +* \return Current counter value. +*/ +__STATIC_INLINE uint32_t PL1_GetCurrentValue(void) +{ + return(__get_CNTP_TVAL()); +} + +/** \brief Get the current physical counter value. +* \return Current physical counter value. +*/ +__STATIC_INLINE uint64_t PL1_GetCurrentPhysicalValue(void) +{ + return(__get_CNTPCT()); +} + +/** \brief Set the physical compare value. +* \param [in] value New physical timer compare value. +*/ +__STATIC_INLINE void PL1_SetPhysicalCompareValue(uint64_t value) +{ + __set_CNTP_CVAL(value); + __ISB(); +} + +/** \brief Get the physical compare value. +* \return Physical compare value. +*/ +__STATIC_INLINE uint64_t PL1_GetPhysicalCompareValue(void) +{ + return(__get_CNTP_CVAL()); +} + +/** \brief Configure the timer by setting the control value. +* \param [in] value New timer control value. +*/ +__STATIC_INLINE void PL1_SetControl(uint32_t value) +{ + __set_CNTP_CTL(value); + __ISB(); +} + +/** \brief Get the control value. +* \return Control value. +*/ +__STATIC_INLINE uint32_t PL1_GetControl(void) +{ + return(__get_CNTP_CTL()); +} +#endif + +/* Private Timer */ +#if ((__CORTEX_A == 5U) || (__CORTEX_A == 9U)) || defined(DOXYGEN) +/** \brief Set the load value to timers LOAD register. +* \param [in] value The load value to be set. +*/ +__STATIC_INLINE void PTIM_SetLoadValue(uint32_t value) +{ + PTIM->LOAD = value; +} + +/** \brief Get the load value from timers LOAD register. +* \return Timer_Type::LOAD +*/ +__STATIC_INLINE uint32_t PTIM_GetLoadValue(void) +{ + return(PTIM->LOAD); +} + +/** \brief Set current counter value from its COUNTER register. +*/ +__STATIC_INLINE void PTIM_SetCurrentValue(uint32_t value) +{ + PTIM->COUNTER = value; +} + +/** \brief Get current counter value from timers COUNTER register. +* \result Timer_Type::COUNTER +*/ +__STATIC_INLINE uint32_t PTIM_GetCurrentValue(void) +{ + return(PTIM->COUNTER); +} + +/** \brief Configure the timer using its CONTROL register. +* \param [in] value The new configuration value to be set. +*/ +__STATIC_INLINE void PTIM_SetControl(uint32_t value) +{ + PTIM->CONTROL = value; +} + +/** ref Timer_Type::CONTROL Get the current timer configuration from its CONTROL register. +* \return Timer_Type::CONTROL +*/ +__STATIC_INLINE uint32_t PTIM_GetControl(void) +{ + return(PTIM->CONTROL); +} + +/** ref Timer_Type::CONTROL Get the event flag in timers ISR register. +* \return 0 - flag is not set, 1- flag is set +*/ +__STATIC_INLINE uint32_t PTIM_GetEventFlag(void) +{ + return (PTIM->ISR & 1UL); +} + +/** ref Timer_Type::CONTROL Clears the event flag in timers ISR register. +*/ +__STATIC_INLINE void PTIM_ClearEventFlag(void) +{ + PTIM->ISR = 1; +} +#endif +#endif + +/* ########################## MMU functions ###################################### */ + +#define SECTION_DESCRIPTOR (0x2) +#define SECTION_MASK (0xFFFFFFFC) + +#define SECTION_TEXCB_MASK (0xFFFF8FF3) +#define SECTION_B_SHIFT (2) +#define SECTION_C_SHIFT (3) +#define SECTION_TEX0_SHIFT (12) +#define SECTION_TEX1_SHIFT (13) +#define SECTION_TEX2_SHIFT (14) + +#define SECTION_XN_MASK (0xFFFFFFEF) +#define SECTION_XN_SHIFT (4) + +#define SECTION_DOMAIN_MASK (0xFFFFFE1F) +#define SECTION_DOMAIN_SHIFT (5) + +#define SECTION_P_MASK (0xFFFFFDFF) +#define SECTION_P_SHIFT (9) + +#define SECTION_AP_MASK (0xFFFF73FF) +#define SECTION_AP_SHIFT (10) +#define SECTION_AP2_SHIFT (15) + +#define SECTION_S_MASK (0xFFFEFFFF) +#define SECTION_S_SHIFT (16) + +#define SECTION_NG_MASK (0xFFFDFFFF) +#define SECTION_NG_SHIFT (17) + +#define SECTION_NS_MASK (0xFFF7FFFF) +#define SECTION_NS_SHIFT (19) + +#define PAGE_L1_DESCRIPTOR (0x1) +#define PAGE_L1_MASK (0xFFFFFFFC) + +#define PAGE_L2_4K_DESC (0x2) +#define PAGE_L2_4K_MASK (0xFFFFFFFD) + +#define PAGE_L2_64K_DESC (0x1) +#define PAGE_L2_64K_MASK (0xFFFFFFFC) + +#define PAGE_4K_TEXCB_MASK (0xFFFFFE33) +#define PAGE_4K_B_SHIFT (2) +#define PAGE_4K_C_SHIFT (3) +#define PAGE_4K_TEX0_SHIFT (6) +#define PAGE_4K_TEX1_SHIFT (7) +#define PAGE_4K_TEX2_SHIFT (8) + +#define PAGE_64K_TEXCB_MASK (0xFFFF8FF3) +#define PAGE_64K_B_SHIFT (2) +#define PAGE_64K_C_SHIFT (3) +#define PAGE_64K_TEX0_SHIFT (12) +#define PAGE_64K_TEX1_SHIFT (13) +#define PAGE_64K_TEX2_SHIFT (14) + +#define PAGE_TEXCB_MASK (0xFFFF8FF3) +#define PAGE_B_SHIFT (2) +#define PAGE_C_SHIFT (3) +#define PAGE_TEX_SHIFT (12) + +#define PAGE_XN_4K_MASK (0xFFFFFFFE) +#define PAGE_XN_4K_SHIFT (0) +#define PAGE_XN_64K_MASK (0xFFFF7FFF) +#define PAGE_XN_64K_SHIFT (15) + +#define PAGE_DOMAIN_MASK (0xFFFFFE1F) +#define PAGE_DOMAIN_SHIFT (5) + +#define PAGE_P_MASK (0xFFFFFDFF) +#define PAGE_P_SHIFT (9) + +#define PAGE_AP_MASK (0xFFFFFDCF) +#define PAGE_AP_SHIFT (4) +#define PAGE_AP2_SHIFT (9) + +#define PAGE_S_MASK (0xFFFFFBFF) +#define PAGE_S_SHIFT (10) + +#define PAGE_NG_MASK (0xFFFFF7FF) +#define PAGE_NG_SHIFT (11) + +#define PAGE_NS_MASK (0xFFFFFFF7) +#define PAGE_NS_SHIFT (3) + +#define OFFSET_1M (0x00100000) +#define OFFSET_64K (0x00010000) +#define OFFSET_4K (0x00001000) + +#define DESCRIPTOR_FAULT (0x00000000) + +/* Attributes enumerations */ + +/* Region size attributes */ +typedef enum +{ + SECTION, + PAGE_4k, + PAGE_64k, +} mmu_region_size_Type; + +/* Region type attributes */ +typedef enum +{ + NORMAL, + DEVICE, + SHARED_DEVICE, + NON_SHARED_DEVICE, + STRONGLY_ORDERED +} mmu_memory_Type; + +/* Region cacheability attributes */ +typedef enum +{ + NON_CACHEABLE, + WB_WA, + WT, + WB_NO_WA, +} mmu_cacheability_Type; + +/* Region parity check attributes */ +typedef enum +{ + ECC_DISABLED, + ECC_ENABLED, +} mmu_ecc_check_Type; + +/* Region execution attributes */ +typedef enum +{ + EXECUTE, + NON_EXECUTE, +} mmu_execute_Type; + +/* Region global attributes */ +typedef enum +{ + GLOBAL, + NON_GLOBAL, +} mmu_global_Type; + +/* Region shareability attributes */ +typedef enum +{ + NON_SHARED, + SHARED, +} mmu_shared_Type; + +/* Region security attributes */ +typedef enum +{ + SECURE, + NON_SECURE, +} mmu_secure_Type; + +/* Region access attributes */ +typedef enum +{ + NO_ACCESS, + RW, + READ, +} mmu_access_Type; + +/* Memory Region definition */ +typedef struct RegionStruct { + mmu_region_size_Type rg_t; + mmu_memory_Type mem_t; + uint8_t domain; + mmu_cacheability_Type inner_norm_t; + mmu_cacheability_Type outer_norm_t; + mmu_ecc_check_Type e_t; + mmu_execute_Type xn_t; + mmu_global_Type g_t; + mmu_secure_Type sec_t; + mmu_access_Type priv_t; + mmu_access_Type user_t; + mmu_shared_Type sh_t; + +} mmu_region_attributes_Type; + +//Following macros define the descriptors and attributes +//Sect_Normal. Outer & inner wb/wa, non-shareable, executable, rw, domain 0 +#define section_normal(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = WB_WA; \ + region.outer_norm_t = WB_WA; \ + region.mem_t = NORMAL; \ + region.sec_t = SECURE; \ + region.xn_t = EXECUTE; \ + region.priv_t = RW; \ + region.user_t = RW; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); + +//Sect_Normal_NC. Outer & inner non-cacheable, non-shareable, executable, rw, domain 0 +#define section_normal_nc(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = NON_CACHEABLE; \ + region.outer_norm_t = NON_CACHEABLE; \ + region.mem_t = NORMAL; \ + region.sec_t = SECURE; \ + region.xn_t = EXECUTE; \ + region.priv_t = RW; \ + region.user_t = RW; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); + +//Sect_Normal_Cod. Outer & inner wb/wa, non-shareable, executable, ro, domain 0 +#define section_normal_cod(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = WB_WA; \ + region.outer_norm_t = WB_WA; \ + region.mem_t = NORMAL; \ + region.sec_t = SECURE; \ + region.xn_t = EXECUTE; \ + region.priv_t = READ; \ + region.user_t = READ; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); + +//Sect_Normal_RO. Sect_Normal_Cod, but not executable +#define section_normal_ro(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = WB_WA; \ + region.outer_norm_t = WB_WA; \ + region.mem_t = NORMAL; \ + region.sec_t = SECURE; \ + region.xn_t = NON_EXECUTE; \ + region.priv_t = READ; \ + region.user_t = READ; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); + +//Sect_Normal_RW. Sect_Normal_Cod, but writeable and not executable +#define section_normal_rw(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = WB_WA; \ + region.outer_norm_t = WB_WA; \ + region.mem_t = NORMAL; \ + region.sec_t = SECURE; \ + region.xn_t = NON_EXECUTE; \ + region.priv_t = RW; \ + region.user_t = RW; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); +//Sect_SO. Strongly-ordered (therefore shareable), not executable, rw, domain 0, base addr 0 +#define section_so(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = NON_CACHEABLE; \ + region.outer_norm_t = NON_CACHEABLE; \ + region.mem_t = STRONGLY_ORDERED; \ + region.sec_t = SECURE; \ + region.xn_t = NON_EXECUTE; \ + region.priv_t = RW; \ + region.user_t = RW; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); + +//Sect_Device_RO. Device, non-shareable, non-executable, ro, domain 0, base addr 0 +#define section_device_ro(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = NON_CACHEABLE; \ + region.outer_norm_t = NON_CACHEABLE; \ + region.mem_t = STRONGLY_ORDERED; \ + region.sec_t = SECURE; \ + region.xn_t = NON_EXECUTE; \ + region.priv_t = READ; \ + region.user_t = READ; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); + +//Sect_Device_RW. Sect_Device_RO, but writeable +#define section_device_rw(descriptor_l1, region) region.rg_t = SECTION; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = NON_CACHEABLE; \ + region.outer_norm_t = NON_CACHEABLE; \ + region.mem_t = STRONGLY_ORDERED; \ + region.sec_t = SECURE; \ + region.xn_t = NON_EXECUTE; \ + region.priv_t = RW; \ + region.user_t = RW; \ + region.sh_t = NON_SHARED; \ + MMU_GetSectionDescriptor(&descriptor_l1, region); +//Page_4k_Device_RW. Shared device, not executable, rw, domain 0 +#define page4k_device_rw(descriptor_l1, descriptor_l2, region) region.rg_t = PAGE_4k; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = NON_CACHEABLE; \ + region.outer_norm_t = NON_CACHEABLE; \ + region.mem_t = SHARED_DEVICE; \ + region.sec_t = SECURE; \ + region.xn_t = NON_EXECUTE; \ + region.priv_t = RW; \ + region.user_t = RW; \ + region.sh_t = NON_SHARED; \ + MMU_GetPageDescriptor(&descriptor_l1, &descriptor_l2, region); + +//Page_64k_Device_RW. Shared device, not executable, rw, domain 0 +#define page64k_device_rw(descriptor_l1, descriptor_l2, region) region.rg_t = PAGE_64k; \ + region.domain = 0x0; \ + region.e_t = ECC_DISABLED; \ + region.g_t = GLOBAL; \ + region.inner_norm_t = NON_CACHEABLE; \ + region.outer_norm_t = NON_CACHEABLE; \ + region.mem_t = SHARED_DEVICE; \ + region.sec_t = SECURE; \ + region.xn_t = NON_EXECUTE; \ + region.priv_t = RW; \ + region.user_t = RW; \ + region.sh_t = NON_SHARED; \ + MMU_GetPageDescriptor(&descriptor_l1, &descriptor_l2, region); + +/** \brief Set section execution-never attribute + + \param [out] descriptor_l1 L1 descriptor. + \param [in] xn Section execution-never attribute : EXECUTE , NON_EXECUTE. + + \return 0 +*/ +__STATIC_INLINE int MMU_XNSection(uint32_t *descriptor_l1, mmu_execute_Type xn) +{ + *descriptor_l1 &= SECTION_XN_MASK; + *descriptor_l1 |= ((xn & 0x1) << SECTION_XN_SHIFT); + return 0; +} + +/** \brief Set section domain + + \param [out] descriptor_l1 L1 descriptor. + \param [in] domain Section domain + + \return 0 +*/ +__STATIC_INLINE int MMU_DomainSection(uint32_t *descriptor_l1, uint8_t domain) +{ + *descriptor_l1 &= SECTION_DOMAIN_MASK; + *descriptor_l1 |= ((domain & 0xF) << SECTION_DOMAIN_SHIFT); + return 0; +} + +/** \brief Set section parity check + + \param [out] descriptor_l1 L1 descriptor. + \param [in] p_bit Parity check: ECC_DISABLED, ECC_ENABLED + + \return 0 +*/ +__STATIC_INLINE int MMU_PSection(uint32_t *descriptor_l1, mmu_ecc_check_Type p_bit) +{ + *descriptor_l1 &= SECTION_P_MASK; + *descriptor_l1 |= ((p_bit & 0x1) << SECTION_P_SHIFT); + return 0; +} + +/** \brief Set section access privileges + + \param [out] descriptor_l1 L1 descriptor. + \param [in] user User Level Access: NO_ACCESS, RW, READ + \param [in] priv Privilege Level Access: NO_ACCESS, RW, READ + \param [in] afe Access flag enable + + \return 0 +*/ +__STATIC_INLINE int MMU_APSection(uint32_t *descriptor_l1, mmu_access_Type user, mmu_access_Type priv, uint32_t afe) +{ + uint32_t ap = 0; + + if (afe == 0) { //full access + if ((priv == NO_ACCESS) && (user == NO_ACCESS)) { ap = 0x0; } + else if ((priv == RW) && (user == NO_ACCESS)) { ap = 0x1; } + else if ((priv == RW) && (user == READ)) { ap = 0x2; } + else if ((priv == RW) && (user == RW)) { ap = 0x3; } + else if ((priv == READ) && (user == NO_ACCESS)) { ap = 0x5; } + else if ((priv == READ) && (user == READ)) { ap = 0x7; } + } + + else { //Simplified access + if ((priv == RW) && (user == NO_ACCESS)) { ap = 0x1; } + else if ((priv == RW) && (user == RW)) { ap = 0x3; } + else if ((priv == READ) && (user == NO_ACCESS)) { ap = 0x5; } + else if ((priv == READ) && (user == READ)) { ap = 0x7; } + } + + *descriptor_l1 &= SECTION_AP_MASK; + *descriptor_l1 |= (ap & 0x3) << SECTION_AP_SHIFT; + *descriptor_l1 |= ((ap & 0x4)>>2) << SECTION_AP2_SHIFT; + + return 0; +} + +/** \brief Set section shareability + + \param [out] descriptor_l1 L1 descriptor. + \param [in] s_bit Section shareability: NON_SHARED, SHARED + + \return 0 +*/ +__STATIC_INLINE int MMU_SharedSection(uint32_t *descriptor_l1, mmu_shared_Type s_bit) +{ + *descriptor_l1 &= SECTION_S_MASK; + *descriptor_l1 |= ((s_bit & 0x1) << SECTION_S_SHIFT); + return 0; +} + +/** \brief Set section Global attribute + + \param [out] descriptor_l1 L1 descriptor. + \param [in] g_bit Section attribute: GLOBAL, NON_GLOBAL + + \return 0 +*/ +__STATIC_INLINE int MMU_GlobalSection(uint32_t *descriptor_l1, mmu_global_Type g_bit) +{ + *descriptor_l1 &= SECTION_NG_MASK; + *descriptor_l1 |= ((g_bit & 0x1) << SECTION_NG_SHIFT); + return 0; +} + +/** \brief Set section Security attribute + + \param [out] descriptor_l1 L1 descriptor. + \param [in] s_bit Section Security attribute: SECURE, NON_SECURE + + \return 0 +*/ +__STATIC_INLINE int MMU_SecureSection(uint32_t *descriptor_l1, mmu_secure_Type s_bit) +{ + *descriptor_l1 &= SECTION_NS_MASK; + *descriptor_l1 |= ((s_bit & 0x1) << SECTION_NS_SHIFT); + return 0; +} + +/* Page 4k or 64k */ +/** \brief Set 4k/64k page execution-never attribute + + \param [out] descriptor_l2 L2 descriptor. + \param [in] xn Page execution-never attribute : EXECUTE , NON_EXECUTE. + \param [in] page Page size: PAGE_4k, PAGE_64k, + + \return 0 +*/ +__STATIC_INLINE int MMU_XNPage(uint32_t *descriptor_l2, mmu_execute_Type xn, mmu_region_size_Type page) +{ + if (page == PAGE_4k) + { + *descriptor_l2 &= PAGE_XN_4K_MASK; + *descriptor_l2 |= ((xn & 0x1) << PAGE_XN_4K_SHIFT); + } + else + { + *descriptor_l2 &= PAGE_XN_64K_MASK; + *descriptor_l2 |= ((xn & 0x1) << PAGE_XN_64K_SHIFT); + } + return 0; +} + +/** \brief Set 4k/64k page domain + + \param [out] descriptor_l1 L1 descriptor. + \param [in] domain Page domain + + \return 0 +*/ +__STATIC_INLINE int MMU_DomainPage(uint32_t *descriptor_l1, uint8_t domain) +{ + *descriptor_l1 &= PAGE_DOMAIN_MASK; + *descriptor_l1 |= ((domain & 0xf) << PAGE_DOMAIN_SHIFT); + return 0; +} + +/** \brief Set 4k/64k page parity check + + \param [out] descriptor_l1 L1 descriptor. + \param [in] p_bit Parity check: ECC_DISABLED, ECC_ENABLED + + \return 0 +*/ +__STATIC_INLINE int MMU_PPage(uint32_t *descriptor_l1, mmu_ecc_check_Type p_bit) +{ + *descriptor_l1 &= SECTION_P_MASK; + *descriptor_l1 |= ((p_bit & 0x1) << SECTION_P_SHIFT); + return 0; +} + +/** \brief Set 4k/64k page access privileges + + \param [out] descriptor_l2 L2 descriptor. + \param [in] user User Level Access: NO_ACCESS, RW, READ + \param [in] priv Privilege Level Access: NO_ACCESS, RW, READ + \param [in] afe Access flag enable + + \return 0 +*/ +__STATIC_INLINE int MMU_APPage(uint32_t *descriptor_l2, mmu_access_Type user, mmu_access_Type priv, uint32_t afe) +{ + uint32_t ap = 0; + + if (afe == 0) { //full access + if ((priv == NO_ACCESS) && (user == NO_ACCESS)) { ap = 0x0; } + else if ((priv == RW) && (user == NO_ACCESS)) { ap = 0x1; } + else if ((priv == RW) && (user == READ)) { ap = 0x2; } + else if ((priv == RW) && (user == RW)) { ap = 0x3; } + else if ((priv == READ) && (user == NO_ACCESS)) { ap = 0x5; } + else if ((priv == READ) && (user == READ)) { ap = 0x6; } + } + + else { //Simplified access + if ((priv == RW) && (user == NO_ACCESS)) { ap = 0x1; } + else if ((priv == RW) && (user == RW)) { ap = 0x3; } + else if ((priv == READ) && (user == NO_ACCESS)) { ap = 0x5; } + else if ((priv == READ) && (user == READ)) { ap = 0x7; } + } + + *descriptor_l2 &= PAGE_AP_MASK; + *descriptor_l2 |= (ap & 0x3) << PAGE_AP_SHIFT; + *descriptor_l2 |= ((ap & 0x4)>>2) << PAGE_AP2_SHIFT; + + return 0; +} + +/** \brief Set 4k/64k page shareability + + \param [out] descriptor_l2 L2 descriptor. + \param [in] s_bit 4k/64k page shareability: NON_SHARED, SHARED + + \return 0 +*/ +__STATIC_INLINE int MMU_SharedPage(uint32_t *descriptor_l2, mmu_shared_Type s_bit) +{ + *descriptor_l2 &= PAGE_S_MASK; + *descriptor_l2 |= ((s_bit & 0x1) << PAGE_S_SHIFT); + return 0; +} + +/** \brief Set 4k/64k page Global attribute + + \param [out] descriptor_l2 L2 descriptor. + \param [in] g_bit 4k/64k page attribute: GLOBAL, NON_GLOBAL + + \return 0 +*/ +__STATIC_INLINE int MMU_GlobalPage(uint32_t *descriptor_l2, mmu_global_Type g_bit) +{ + *descriptor_l2 &= PAGE_NG_MASK; + *descriptor_l2 |= ((g_bit & 0x1) << PAGE_NG_SHIFT); + return 0; +} + +/** \brief Set 4k/64k page Security attribute + + \param [out] descriptor_l1 L1 descriptor. + \param [in] s_bit 4k/64k page Security attribute: SECURE, NON_SECURE + + \return 0 +*/ +__STATIC_INLINE int MMU_SecurePage(uint32_t *descriptor_l1, mmu_secure_Type s_bit) +{ + *descriptor_l1 &= PAGE_NS_MASK; + *descriptor_l1 |= ((s_bit & 0x1) << PAGE_NS_SHIFT); + return 0; +} + +/** \brief Set Section memory attributes + + \param [out] descriptor_l1 L1 descriptor. + \param [in] mem Section memory type: NORMAL, DEVICE, SHARED_DEVICE, NON_SHARED_DEVICE, STRONGLY_ORDERED + \param [in] outer Outer cacheability: NON_CACHEABLE, WB_WA, WT, WB_NO_WA, + \param [in] inner Inner cacheability: NON_CACHEABLE, WB_WA, WT, WB_NO_WA, + + \return 0 +*/ +__STATIC_INLINE int MMU_MemorySection(uint32_t *descriptor_l1, mmu_memory_Type mem, mmu_cacheability_Type outer, mmu_cacheability_Type inner) +{ + *descriptor_l1 &= SECTION_TEXCB_MASK; + + if (STRONGLY_ORDERED == mem) + { + return 0; + } + else if (SHARED_DEVICE == mem) + { + *descriptor_l1 |= (1 << SECTION_B_SHIFT); + } + else if (NON_SHARED_DEVICE == mem) + { + *descriptor_l1 |= (1 << SECTION_TEX1_SHIFT); + } + else if (NORMAL == mem) + { + *descriptor_l1 |= 1 << SECTION_TEX2_SHIFT; + switch(inner) + { + case NON_CACHEABLE: + break; + case WB_WA: + *descriptor_l1 |= (1 << SECTION_B_SHIFT); + break; + case WT: + *descriptor_l1 |= 1 << SECTION_C_SHIFT; + break; + case WB_NO_WA: + *descriptor_l1 |= (1 << SECTION_B_SHIFT) | (1 << SECTION_C_SHIFT); + break; + } + switch(outer) + { + case NON_CACHEABLE: + break; + case WB_WA: + *descriptor_l1 |= (1 << SECTION_TEX0_SHIFT); + break; + case WT: + *descriptor_l1 |= 1 << SECTION_TEX1_SHIFT; + break; + case WB_NO_WA: + *descriptor_l1 |= (1 << SECTION_TEX0_SHIFT) | (1 << SECTION_TEX0_SHIFT); + break; + } + } + return 0; +} + +/** \brief Set 4k/64k page memory attributes + + \param [out] descriptor_l2 L2 descriptor. + \param [in] mem 4k/64k page memory type: NORMAL, DEVICE, SHARED_DEVICE, NON_SHARED_DEVICE, STRONGLY_ORDERED + \param [in] outer Outer cacheability: NON_CACHEABLE, WB_WA, WT, WB_NO_WA, + \param [in] inner Inner cacheability: NON_CACHEABLE, WB_WA, WT, WB_NO_WA, + \param [in] page Page size + + \return 0 +*/ +__STATIC_INLINE int MMU_MemoryPage(uint32_t *descriptor_l2, mmu_memory_Type mem, mmu_cacheability_Type outer, mmu_cacheability_Type inner, mmu_region_size_Type page) +{ + *descriptor_l2 &= PAGE_4K_TEXCB_MASK; + + if (page == PAGE_64k) + { + //same as section + MMU_MemorySection(descriptor_l2, mem, outer, inner); + } + else + { + if (STRONGLY_ORDERED == mem) + { + return 0; + } + else if (SHARED_DEVICE == mem) + { + *descriptor_l2 |= (1 << PAGE_4K_B_SHIFT); + } + else if (NON_SHARED_DEVICE == mem) + { + *descriptor_l2 |= (1 << PAGE_4K_TEX1_SHIFT); + } + else if (NORMAL == mem) + { + *descriptor_l2 |= 1 << PAGE_4K_TEX2_SHIFT; + switch(inner) + { + case NON_CACHEABLE: + break; + case WB_WA: + *descriptor_l2 |= (1 << PAGE_4K_B_SHIFT); + break; + case WT: + *descriptor_l2 |= 1 << PAGE_4K_C_SHIFT; + break; + case WB_NO_WA: + *descriptor_l2 |= (1 << PAGE_4K_B_SHIFT) | (1 << PAGE_4K_C_SHIFT); + break; + } + switch(outer) + { + case NON_CACHEABLE: + break; + case WB_WA: + *descriptor_l2 |= (1 << PAGE_4K_TEX0_SHIFT); + break; + case WT: + *descriptor_l2 |= 1 << PAGE_4K_TEX1_SHIFT; + break; + case WB_NO_WA: + *descriptor_l2 |= (1 << PAGE_4K_TEX0_SHIFT) | (1 << PAGE_4K_TEX0_SHIFT); + break; + } + } + } + + return 0; +} + +/** \brief Create a L1 section descriptor + + \param [out] descriptor L1 descriptor + \param [in] reg Section attributes + + \return 0 +*/ +__STATIC_INLINE int MMU_GetSectionDescriptor(uint32_t *descriptor, mmu_region_attributes_Type reg) +{ + *descriptor = 0; + + MMU_MemorySection(descriptor, reg.mem_t, reg.outer_norm_t, reg.inner_norm_t); + MMU_XNSection(descriptor,reg.xn_t); + MMU_DomainSection(descriptor, reg.domain); + MMU_PSection(descriptor, reg.e_t); + MMU_APSection(descriptor, reg.priv_t, reg.user_t, 1); + MMU_SharedSection(descriptor,reg.sh_t); + MMU_GlobalSection(descriptor,reg.g_t); + MMU_SecureSection(descriptor,reg.sec_t); + *descriptor &= SECTION_MASK; + *descriptor |= SECTION_DESCRIPTOR; + + return 0; +} + + +/** \brief Create a L1 and L2 4k/64k page descriptor + + \param [out] descriptor L1 descriptor + \param [out] descriptor2 L2 descriptor + \param [in] reg 4k/64k page attributes + + \return 0 +*/ +__STATIC_INLINE int MMU_GetPageDescriptor(uint32_t *descriptor, uint32_t *descriptor2, mmu_region_attributes_Type reg) +{ + *descriptor = 0; + *descriptor2 = 0; + + switch (reg.rg_t) + { + case PAGE_4k: + MMU_MemoryPage(descriptor2, reg.mem_t, reg.outer_norm_t, reg.inner_norm_t, PAGE_4k); + MMU_XNPage(descriptor2, reg.xn_t, PAGE_4k); + MMU_DomainPage(descriptor, reg.domain); + MMU_PPage(descriptor, reg.e_t); + MMU_APPage(descriptor2, reg.priv_t, reg.user_t, 1); + MMU_SharedPage(descriptor2,reg.sh_t); + MMU_GlobalPage(descriptor2,reg.g_t); + MMU_SecurePage(descriptor,reg.sec_t); + *descriptor &= PAGE_L1_MASK; + *descriptor |= PAGE_L1_DESCRIPTOR; + *descriptor2 &= PAGE_L2_4K_MASK; + *descriptor2 |= PAGE_L2_4K_DESC; + break; + + case PAGE_64k: + MMU_MemoryPage(descriptor2, reg.mem_t, reg.outer_norm_t, reg.inner_norm_t, PAGE_64k); + MMU_XNPage(descriptor2, reg.xn_t, PAGE_64k); + MMU_DomainPage(descriptor, reg.domain); + MMU_PPage(descriptor, reg.e_t); + MMU_APPage(descriptor2, reg.priv_t, reg.user_t, 1); + MMU_SharedPage(descriptor2,reg.sh_t); + MMU_GlobalPage(descriptor2,reg.g_t); + MMU_SecurePage(descriptor,reg.sec_t); + *descriptor &= PAGE_L1_MASK; + *descriptor |= PAGE_L1_DESCRIPTOR; + *descriptor2 &= PAGE_L2_64K_MASK; + *descriptor2 |= PAGE_L2_64K_DESC; + break; + + case SECTION: + //error + break; + } + + return 0; +} + +/** \brief Create a 1MB Section + + \param [in] ttb Translation table base address + \param [in] base_address Section base address + \param [in] count Number of sections to create + \param [in] descriptor_l1 L1 descriptor (region attributes) + +*/ +__STATIC_INLINE void MMU_TTSection(uint32_t *ttb, uint32_t base_address, uint32_t count, uint32_t descriptor_l1) +{ + uint32_t offset; + uint32_t entry; + uint32_t i; + + offset = base_address >> 20; + entry = (base_address & 0xFFF00000) | descriptor_l1; + + //4 bytes aligned + ttb = ttb + offset; + + for (i = 0; i < count; i++ ) + { + //4 bytes aligned + *ttb++ = entry; + entry += OFFSET_1M; + } +} + +/** \brief Create a 4k page entry + + \param [in] ttb L1 table base address + \param [in] base_address 4k base address + \param [in] count Number of 4k pages to create + \param [in] descriptor_l1 L1 descriptor (region attributes) + \param [in] ttb_l2 L2 table base address + \param [in] descriptor_l2 L2 descriptor (region attributes) + +*/ +__STATIC_INLINE void MMU_TTPage4k(uint32_t *ttb, uint32_t base_address, uint32_t count, uint32_t descriptor_l1, uint32_t *ttb_l2, uint32_t descriptor_l2 ) +{ + + uint32_t offset, offset2; + uint32_t entry, entry2; + uint32_t i; + + offset = base_address >> 20; + entry = ((int)ttb_l2 & 0xFFFFFC00) | descriptor_l1; + + //4 bytes aligned + ttb += offset; + //create l1_entry + *ttb = entry; + + offset2 = (base_address & 0xff000) >> 12; + ttb_l2 += offset2; + entry2 = (base_address & 0xFFFFF000) | descriptor_l2; + for (i = 0; i < count; i++ ) + { + //4 bytes aligned + *ttb_l2++ = entry2; + entry2 += OFFSET_4K; + } +} + +/** \brief Create a 64k page entry + + \param [in] ttb L1 table base address + \param [in] base_address 64k base address + \param [in] count Number of 64k pages to create + \param [in] descriptor_l1 L1 descriptor (region attributes) + \param [in] ttb_l2 L2 table base address + \param [in] descriptor_l2 L2 descriptor (region attributes) + +*/ +__STATIC_INLINE void MMU_TTPage64k(uint32_t *ttb, uint32_t base_address, uint32_t count, uint32_t descriptor_l1, uint32_t *ttb_l2, uint32_t descriptor_l2 ) +{ + uint32_t offset, offset2; + uint32_t entry, entry2; + uint32_t i,j; + + + offset = base_address >> 20; + entry = ((int)ttb_l2 & 0xFFFFFC00) | descriptor_l1; + + //4 bytes aligned + ttb += offset; + //create l1_entry + *ttb = entry; + + offset2 = (base_address & 0xff000) >> 12; + ttb_l2 += offset2; + entry2 = (base_address & 0xFFFF0000) | descriptor_l2; + for (i = 0; i < count; i++ ) + { + //create 16 entries + for (j = 0; j < 16; j++) + { + //4 bytes aligned + *ttb_l2++ = entry2; + } + entry2 += OFFSET_64K; + } +} + +/** \brief Enable MMU +*/ +__STATIC_INLINE void MMU_Enable(void) +{ + // Set M bit 0 to enable the MMU + // Set AFE bit to enable simplified access permissions model + // Clear TRE bit to disable TEX remap and A bit to disable strict alignment fault checking + __set_SCTLR( (__get_SCTLR() & ~(1 << 28) & ~(1 << 1)) | 1 | (1 << 29)); + __ISB(); +} + +/** \brief Disable MMU +*/ +__STATIC_INLINE void MMU_Disable(void) +{ + // Clear M bit 0 to disable the MMU + __set_SCTLR( __get_SCTLR() & ~1); + __ISB(); +} + +/** \brief Invalidate entire unified TLB +*/ + +__STATIC_INLINE void MMU_InvalidateTLB(void) +{ + __set_TLBIALL(0); + __DSB(); //ensure completion of the invalidation + __ISB(); //ensure instruction fetch path sees new state +} + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CA_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Include/irq_ctrl.h b/Chapter04/bare/platform/CMSIS/Core_A/Include/irq_ctrl.h new file mode 100644 index 0000000..a6d313d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Include/irq_ctrl.h @@ -0,0 +1,186 @@ +/**************************************************************************//** + * @file irq_ctrl.h + * @brief Interrupt Controller API header file + * @version V1.0.0 + * @date 23. June 2017 + ******************************************************************************/ +/* + * Copyright (c) 2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef IRQ_CTRL_H_ +#define IRQ_CTRL_H_ + +#include + +#ifndef IRQHANDLER_T +#define IRQHANDLER_T +/// Interrupt handler data type +typedef void (*IRQHandler_t) (void); +#endif + +#ifndef IRQN_ID_T +#define IRQN_ID_T +/// Interrupt ID number data type +typedef int32_t IRQn_ID_t; +#endif + +/* Interrupt mode bit-masks */ +#define IRQ_MODE_TRIG_Pos (0U) +#define IRQ_MODE_TRIG_Msk (0x07UL /*<< IRQ_MODE_TRIG_Pos*/) +#define IRQ_MODE_TRIG_LEVEL (0x00UL /*<< IRQ_MODE_TRIG_Pos*/) ///< Trigger: level triggered interrupt +#define IRQ_MODE_TRIG_LEVEL_LOW (0x01UL /*<< IRQ_MODE_TRIG_Pos*/) ///< Trigger: low level triggered interrupt +#define IRQ_MODE_TRIG_LEVEL_HIGH (0x02UL /*<< IRQ_MODE_TRIG_Pos*/) ///< Trigger: high level triggered interrupt +#define IRQ_MODE_TRIG_EDGE (0x04UL /*<< IRQ_MODE_TRIG_Pos*/) ///< Trigger: edge triggered interrupt +#define IRQ_MODE_TRIG_EDGE_RISING (0x05UL /*<< IRQ_MODE_TRIG_Pos*/) ///< Trigger: rising edge triggered interrupt +#define IRQ_MODE_TRIG_EDGE_FALLING (0x06UL /*<< IRQ_MODE_TRIG_Pos*/) ///< Trigger: falling edge triggered interrupt +#define IRQ_MODE_TRIG_EDGE_BOTH (0x07UL /*<< IRQ_MODE_TRIG_Pos*/) ///< Trigger: rising and falling edge triggered interrupt + +#define IRQ_MODE_TYPE_Pos (3U) +#define IRQ_MODE_TYPE_Msk (0x01UL << IRQ_MODE_TYPE_Pos) +#define IRQ_MODE_TYPE_IRQ (0x00UL << IRQ_MODE_TYPE_Pos) ///< Type: interrupt source triggers CPU IRQ line +#define IRQ_MODE_TYPE_FIQ (0x01UL << IRQ_MODE_TYPE_Pos) ///< Type: interrupt source triggers CPU FIQ line + +#define IRQ_MODE_DOMAIN_Pos (4U) +#define IRQ_MODE_DOMAIN_Msk (0x01UL << IRQ_MODE_DOMAIN_Pos) +#define IRQ_MODE_DOMAIN_NONSECURE (0x00UL << IRQ_MODE_DOMAIN_Pos) ///< Domain: interrupt is targeting non-secure domain +#define IRQ_MODE_DOMAIN_SECURE (0x01UL << IRQ_MODE_DOMAIN_Pos) ///< Domain: interrupt is targeting secure domain + +#define IRQ_MODE_CPU_Pos (5U) +#define IRQ_MODE_CPU_Msk (0xFFUL << IRQ_MODE_CPU_Pos) +#define IRQ_MODE_CPU_ALL (0x00UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets all CPUs +#define IRQ_MODE_CPU_0 (0x01UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 0 +#define IRQ_MODE_CPU_1 (0x02UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 1 +#define IRQ_MODE_CPU_2 (0x04UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 2 +#define IRQ_MODE_CPU_3 (0x08UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 3 +#define IRQ_MODE_CPU_4 (0x10UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 4 +#define IRQ_MODE_CPU_5 (0x20UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 5 +#define IRQ_MODE_CPU_6 (0x40UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 6 +#define IRQ_MODE_CPU_7 (0x80UL << IRQ_MODE_CPU_Pos) ///< CPU: interrupt targets CPU 7 + +#define IRQ_MODE_ERROR (0x80000000UL) ///< Bit indicating mode value error + +/* Interrupt priority bit-masks */ +#define IRQ_PRIORITY_Msk (0x0000FFFFUL) ///< Interrupt priority value bit-mask +#define IRQ_PRIORITY_ERROR (0x80000000UL) ///< Bit indicating priority value error + +/// Initialize interrupt controller. +/// \return 0 on success, -1 on error. +int32_t IRQ_Initialize (void); + +/// Register interrupt handler. +/// \param[in] irqn interrupt ID number +/// \param[in] handler interrupt handler function address +/// \return 0 on success, -1 on error. +int32_t IRQ_SetHandler (IRQn_ID_t irqn, IRQHandler_t handler); + +/// Get the registered interrupt handler. +/// \param[in] irqn interrupt ID number +/// \return registered interrupt handler function address. +IRQHandler_t IRQ_GetHandler (IRQn_ID_t irqn); + +/// Enable interrupt. +/// \param[in] irqn interrupt ID number +/// \return 0 on success, -1 on error. +int32_t IRQ_Enable (IRQn_ID_t irqn); + +/// Disable interrupt. +/// \param[in] irqn interrupt ID number +/// \return 0 on success, -1 on error. +int32_t IRQ_Disable (IRQn_ID_t irqn); + +/// Get interrupt enable state. +/// \param[in] irqn interrupt ID number +/// \return 0 - interrupt is disabled, 1 - interrupt is enabled. +uint32_t IRQ_GetEnableState (IRQn_ID_t irqn); + +/// Configure interrupt request mode. +/// \param[in] irqn interrupt ID number +/// \param[in] mode mode configuration +/// \return 0 on success, -1 on error. +int32_t IRQ_SetMode (IRQn_ID_t irqn, uint32_t mode); + +/// Get interrupt mode configuration. +/// \param[in] irqn interrupt ID number +/// \return current interrupt mode configuration with optional IRQ_MODE_ERROR bit set. +uint32_t IRQ_GetMode (IRQn_ID_t irqn); + +/// Get ID number of current interrupt request (IRQ). +/// \return interrupt ID number. +IRQn_ID_t IRQ_GetActiveIRQ (void); + +/// Get ID number of current fast interrupt request (FIQ). +/// \return interrupt ID number. +IRQn_ID_t IRQ_GetActiveFIQ (void); + +/// Signal end of interrupt processing. +/// \param[in] irqn interrupt ID number +/// \return 0 on success, -1 on error. +int32_t IRQ_EndOfInterrupt (IRQn_ID_t irqn); + +/// Set interrupt pending flag. +/// \param[in] irqn interrupt ID number +/// \return 0 on success, -1 on error. +int32_t IRQ_SetPending (IRQn_ID_t irqn); + +/// Get interrupt pending flag. +/// \param[in] irqn interrupt ID number +/// \return 0 - interrupt is not pending, 1 - interrupt is pending. +uint32_t IRQ_GetPending (IRQn_ID_t irqn); + +/// Clear interrupt pending flag. +/// \param[in] irqn interrupt ID number +/// \return 0 on success, -1 on error. +int32_t IRQ_ClearPending (IRQn_ID_t irqn); + +/// Set interrupt priority value. +/// \param[in] irqn interrupt ID number +/// \param[in] priority interrupt priority value +/// \return 0 on success, -1 on error. +int32_t IRQ_SetPriority (IRQn_ID_t irqn, uint32_t priority); + +/// Get interrupt priority. +/// \param[in] irqn interrupt ID number +/// \return current interrupt priority value with optional IRQ_PRIORITY_ERROR bit set. +uint32_t IRQ_GetPriority (IRQn_ID_t irqn); + +/// Set priority masking threshold. +/// \param[in] priority priority masking threshold value +/// \return 0 on success, -1 on error. +int32_t IRQ_SetPriorityMask (uint32_t priority); + +/// Get priority masking threshold +/// \return current priority masking threshold value with optional IRQ_PRIORITY_ERROR bit set. +uint32_t IRQ_GetPriorityMask (void); + +/// Set priority grouping field split point +/// \param[in] bits number of MSB bits included in the group priority field comparison +/// \return 0 on success, -1 on error. +int32_t IRQ_SetPriorityGroupBits (uint32_t bits); + +/// Get priority grouping field split point +/// \return current number of MSB bits included in the group priority field comparison with +/// optional IRQ_PRIORITY_ERROR bit set. +uint32_t IRQ_GetPriorityGroupBits (void); + +#endif // IRQ_CTRL_H_ diff --git a/Chapter04/bare/platform/CMSIS/Core_A/Source/irq_ctrl_gic.c b/Chapter04/bare/platform/CMSIS/Core_A/Source/irq_ctrl_gic.c new file mode 100644 index 0000000..cf08a53 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Core_A/Source/irq_ctrl_gic.c @@ -0,0 +1,410 @@ +/**************************************************************************//** + * @file irq_ctrl_gic.c + * @brief Interrupt controller handling implementation for GIC + * @version V1.0.1 + * @date 9. April 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include + +#include "RTE_Components.h" +#include CMSIS_device_header + +#include "irq_ctrl.h" + +#if defined(__GIC_PRESENT) && (__GIC_PRESENT == 1U) + +/// Number of implemented interrupt lines +#ifndef IRQ_GIC_LINE_COUNT +#define IRQ_GIC_LINE_COUNT (1020U) +#endif + +static IRQHandler_t IRQTable[IRQ_GIC_LINE_COUNT] = { 0U }; +static uint32_t IRQ_ID0; + +/// Initialize interrupt controller. +__WEAK int32_t IRQ_Initialize (void) { + uint32_t i; + + for (i = 0U; i < IRQ_GIC_LINE_COUNT; i++) { + IRQTable[i] = (IRQHandler_t)NULL; + } + GIC_Enable(); + return (0); +} + + +/// Register interrupt handler. +__WEAK int32_t IRQ_SetHandler (IRQn_ID_t irqn, IRQHandler_t handler) { + int32_t status; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + IRQTable[irqn] = handler; + status = 0; + } else { + status = -1; + } + + return (status); +} + + +/// Get the registered interrupt handler. +__WEAK IRQHandler_t IRQ_GetHandler (IRQn_ID_t irqn) { + IRQHandler_t h; + + // Ignore CPUID field (software generated interrupts) + irqn &= 0x3FFU; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + h = IRQTable[irqn]; + } else { + h = (IRQHandler_t)0; + } + + return (h); +} + + +/// Enable interrupt. +__WEAK int32_t IRQ_Enable (IRQn_ID_t irqn) { + int32_t status; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + GIC_EnableIRQ ((IRQn_Type)irqn); + status = 0; + } else { + status = -1; + } + + return (status); +} + + +/// Disable interrupt. +__WEAK int32_t IRQ_Disable (IRQn_ID_t irqn) { + int32_t status; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + GIC_DisableIRQ ((IRQn_Type)irqn); + status = 0; + } else { + status = -1; + } + + return (status); +} + + +/// Get interrupt enable state. +__WEAK uint32_t IRQ_GetEnableState (IRQn_ID_t irqn) { + uint32_t enable; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + enable = GIC_GetEnableIRQ((IRQn_Type)irqn); + } else { + enable = 0U; + } + + return (enable); +} + + +/// Configure interrupt request mode. +__WEAK int32_t IRQ_SetMode (IRQn_ID_t irqn, uint32_t mode) { + uint32_t val; + uint8_t cfg; + uint8_t secure; + uint8_t cpu; + int32_t status = 0; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + // Check triggering mode + val = (mode & IRQ_MODE_TRIG_Msk); + + if (val == IRQ_MODE_TRIG_LEVEL) { + cfg = 0x00U; + } else if (val == IRQ_MODE_TRIG_EDGE) { + cfg = 0x02U; + } else { + cfg = 0x00U; + status = -1; + } + + // Check interrupt type + val = mode & IRQ_MODE_TYPE_Msk; + + if (val != IRQ_MODE_TYPE_IRQ) { + status = -1; + } + + // Check interrupt domain + val = mode & IRQ_MODE_DOMAIN_Msk; + + if (val == IRQ_MODE_DOMAIN_NONSECURE) { + secure = 0U; + } else { + // Check security extensions support + val = GIC_DistributorInfo() & (1UL << 10U); + + if (val != 0U) { + // Security extensions are supported + secure = 1U; + } else { + secure = 0U; + status = -1; + } + } + + // Check interrupt CPU targets + val = mode & IRQ_MODE_CPU_Msk; + + if (val == IRQ_MODE_CPU_ALL) { + cpu = 0xFFU; + } else { + cpu = val >> IRQ_MODE_CPU_Pos; + } + + // Apply configuration if no mode error + if (status == 0) { + GIC_SetConfiguration((IRQn_Type)irqn, cfg); + GIC_SetTarget ((IRQn_Type)irqn, cpu); + + if (secure != 0U) { + GIC_SetGroup ((IRQn_Type)irqn, secure); + } + } + } + + return (status); +} + + +/// Get interrupt mode configuration. +__WEAK uint32_t IRQ_GetMode (IRQn_ID_t irqn) { + uint32_t mode; + uint32_t val; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + mode = IRQ_MODE_TYPE_IRQ; + + // Get trigger mode + val = GIC_GetConfiguration((IRQn_Type)irqn); + + if ((val & 2U) != 0U) { + // Corresponding interrupt is edge triggered + mode |= IRQ_MODE_TRIG_EDGE; + } else { + // Corresponding interrupt is level triggered + mode |= IRQ_MODE_TRIG_LEVEL; + } + + // Get interrupt CPU targets + mode |= GIC_GetTarget ((IRQn_Type)irqn) << IRQ_MODE_CPU_Pos; + + } else { + mode = IRQ_MODE_ERROR; + } + + return (mode); +} + + +/// Get ID number of current interrupt request (IRQ). +__WEAK IRQn_ID_t IRQ_GetActiveIRQ (void) { + IRQn_ID_t irqn; + uint32_t prio; + + /* Dummy read to avoid GIC 390 errata 801120 */ + GIC_GetHighPendingIRQ(); + + irqn = GIC_AcknowledgePending(); + + __DSB(); + + /* Workaround GIC 390 errata 733075 (GIC-390_Errata_Notice_v6.pdf, 09-Jul-2014) */ + /* The following workaround code is for a single-core system. It would be */ + /* different in a multi-core system. */ + /* If the ID is 0 or 0x3FE or 0x3FF, then the GIC CPU interface may be locked-up */ + /* so unlock it, otherwise service the interrupt as normal. */ + /* Special IDs 1020=0x3FC and 1021=0x3FD are reserved values in GICv1 and GICv2 */ + /* so will not occur here. */ + + if ((irqn == 0) || (irqn >= 0x3FE)) { + /* Unlock the CPU interface with a dummy write to Interrupt Priority Register */ + prio = GIC_GetPriority((IRQn_Type)0); + GIC_SetPriority ((IRQn_Type)0, prio); + + __DSB(); + + if ((irqn == 0U) && ((GIC_GetIRQStatus ((IRQn_Type)irqn) & 1U) != 0U) && (IRQ_ID0 == 0U)) { + /* If the ID is 0, is active and has not been seen before */ + IRQ_ID0 = 1U; + } + /* End of Workaround GIC 390 errata 733075 */ + } + + return (irqn); +} + + +/// Get ID number of current fast interrupt request (FIQ). +__WEAK IRQn_ID_t IRQ_GetActiveFIQ (void) { + return ((IRQn_ID_t)-1); +} + + +/// Signal end of interrupt processing. +__WEAK int32_t IRQ_EndOfInterrupt (IRQn_ID_t irqn) { + int32_t status; + IRQn_Type irq = (IRQn_Type)irqn; + + irqn &= 0x3FFU; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + GIC_EndInterrupt (irq); + + if (irqn == 0) { + IRQ_ID0 = 0U; + } + + status = 0; + } else { + status = -1; + } + + return (status); +} + + +/// Set interrupt pending flag. +__WEAK int32_t IRQ_SetPending (IRQn_ID_t irqn) { + int32_t status; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + GIC_SetPendingIRQ ((IRQn_Type)irqn); + status = 0; + } else { + status = -1; + } + + return (status); +} + +/// Get interrupt pending flag. +__WEAK uint32_t IRQ_GetPending (IRQn_ID_t irqn) { + uint32_t pending; + + if ((irqn >= 16) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + pending = GIC_GetPendingIRQ ((IRQn_Type)irqn); + } else { + pending = 0U; + } + + return (pending & 1U); +} + + +/// Clear interrupt pending flag. +__WEAK int32_t IRQ_ClearPending (IRQn_ID_t irqn) { + int32_t status; + + if ((irqn >= 16) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + GIC_ClearPendingIRQ ((IRQn_Type)irqn); + status = 0; + } else { + status = -1; + } + + return (status); +} + + +/// Set interrupt priority value. +__WEAK int32_t IRQ_SetPriority (IRQn_ID_t irqn, uint32_t priority) { + int32_t status; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + GIC_SetPriority ((IRQn_Type)irqn, priority); + status = 0; + } else { + status = -1; + } + + return (status); +} + + +/// Get interrupt priority. +__WEAK uint32_t IRQ_GetPriority (IRQn_ID_t irqn) { + uint32_t priority; + + if ((irqn >= 0) && (irqn < (IRQn_ID_t)IRQ_GIC_LINE_COUNT)) { + priority = GIC_GetPriority ((IRQn_Type)irqn); + } else { + priority = IRQ_PRIORITY_ERROR; + } + + return (priority); +} + + +/// Set priority masking threshold. +__WEAK int32_t IRQ_SetPriorityMask (uint32_t priority) { + GIC_SetInterfacePriorityMask (priority); + return (0); +} + + +/// Get priority masking threshold +__WEAK uint32_t IRQ_GetPriorityMask (void) { + return GIC_GetInterfacePriorityMask(); +} + + +/// Set priority grouping field split point +__WEAK int32_t IRQ_SetPriorityGroupBits (uint32_t bits) { + int32_t status; + + if (bits == IRQ_PRIORITY_Msk) { + bits = 7U; + } + + if (bits < 8U) { + GIC_SetBinaryPoint (7U - bits); + status = 0; + } else { + status = -1; + } + + return (status); +} + + +/// Get priority grouping field split point +__WEAK uint32_t IRQ_GetPriorityGroupBits (void) { + uint32_t bp; + + bp = GIC_GetBinaryPoint() & 0x07U; + + return (7U - bp); +} + +#endif diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/arr_desc/arr_desc.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/arr_desc/arr_desc.h new file mode 100644 index 0000000..effab26 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/arr_desc/arr_desc.h @@ -0,0 +1,220 @@ +#ifndef _ARR_DESC_H_ +#define _ARR_DESC_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ +#include +#include /* memset() */ +#include "../util/util.h" /* CONCAT() */ + +/*--------------------------------------------------------------------------------*/ +/* Type Definitions */ +/*--------------------------------------------------------------------------------*/ + +/** + * Array-descriptor struct. + */ +typedef struct ARR_DESC_struct +{ + void * data_ptr; /* Pointer to the array contents. */ + int32_t element_count; /* Number of current elements. */ + int32_t element_size; /* Size of current elements in bytes. */ + int32_t underlying_size; /* Size of underlying array in bytes. */ +} ARR_DESC_t; + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Prefix of the array variable's name when creating an array and an array + * descriptor at the same time. + */ +#define ARR_DESC_ARR_PREFIX ARR_DESC_ARR_ + +/** + * Evaluate to the array variable's name when creating an array and an array + * descriptor at the same time. + */ +#define ARR_DESC_ARR_NAME(name) \ + CONCAT(ARR_DESC_ARR_PREFIX, name) + +/** + * Define an #ARR_DESC_t by itself. + * + * @note The user must supply an array to store the data used by the + * #ARR_DESC_t. + */ +#define ARR_DESC_INTERNAL_DEFINE(name, data_ptr, \ + element_count, element_size) \ + ARR_DESC_t name = { \ + data_ptr, \ + element_count, \ + element_size, \ + element_count * element_size \ + } \ + +/** + * Define both an array and an #ARR_DESC_t that describes it. + * + * @note Use the #CURLY() macro for the content field; it provides the curly + * braces necessary for an array initialization. + */ +#define ARR_DESC_DEFINE(type, name, element_count, content) \ + type ARR_DESC_ARR_NAME(name)[element_count] = content; \ + ARR_DESC_INTERNAL_DEFINE(name, \ + &ARR_DESC_ARR_NAME(name), \ + element_count, \ + sizeof(type)) /* Note the lacking semicolon */ + +/** + * Create a #ARR_DESC_t which refers to a subset of the data in another. + * + * The new #ARR_DESC_t shares the same underlying array as the aliased + * #ARR_DESC_t, but only describes a subset of the originals values. + */ +#define ARR_DESC_DEFINE_SUBSET(name, original, element_cnt) \ + ARR_DESC_INTERNAL_DEFINE(name, \ + &ARR_DESC_ARR_NAME(original), \ + element_cnt, \ + sizeof(ARR_DESC_ARR_NAME(original)[0]) \ + ) /* Note the lacking semicolon */ + +/** + * Creat an #ARR_DESC_t which points to the data in an existing array. + * + * @param start_idx Offset in array_ptr of first element. + * @param element_cnt Number of elements to include in the #ARR_DESC_t. + * + * @example + * + * float my_floats[4] = {0.0f, 1.0f, 2.0f, 3.0f}; + * + * ARR_DESC_DEFINE_USING_ARR(my_arr_desc, my_floats, 1, 3); + * + * printf("Element 0: %f\n", ARR_DESC_ELT(float, 0, &my_arr_desc)); + * printf("Element 1: %f\n", ARR_DESC_ELT(float, 1, &my_arr_desc)); + * + * Outputs: + * + * Element 0: 1.000000 + * Element 1: 2.000000 + * + * @warning There are no checks in place to catch invalid start indices; This + * is left to the user. + */ +#define ARR_DESC_DEFINE_USING_ARR(type, name, array_ptr, start_idx, element_cnt) \ + ARR_DESC_INTERNAL_DEFINE( \ + name, \ + (type *) (array_ptr + start_idx), \ + element_cnt, \ + sizeof(type) \ + ) /* Note the lacking semicolon*/ + +/** + * Declare an #ARR_DESC_t object. + */ +#define ARR_DESC_DECLARE(name) \ + extern ARR_DESC_t name /* Note the lacking semicolon */ + +/** + * Evaluate to the number of bytes stored in the #ARR_DESC_t. + */ +#define ARR_DESC_BYTES(arr_desc_ptr) \ + ((arr_desc_ptr)->element_count * (arr_desc_ptr)->element_size) + +/** + * Set the contents of #ARR_DESC_t to value. + */ +#define ARR_DESC_MEMSET(arr_desc_ptr, value, bytes) \ + do \ + { \ + memset((arr_desc_ptr)->data_ptr, \ + value, \ + BOUND(0, \ + (arr_desc_ptr)->underlying_size, \ + bytes) \ + ); \ + } while (0) + +/** + * Perform a memcpy of 'bytes' bytes from the source #ARR_DESC_t to the + * destination #ARR_DESC_t. + */ +#define ARR_DESC_MEMCPY(arr_desc_dest_ptr, arr_desc_src_ptr, bytes) \ + do \ + { \ + memcpy((arr_desc_dest_ptr)->data_ptr, \ + (arr_desc_src_ptr)->data_ptr, \ + BOUND(0, \ + (arr_desc_dest_ptr)->underlying_size, \ + bytes)); \ + } while (0) + +/** + * Evaluate to true if the source #ARR_DESC_t contents will fit into the + * destination #ARR_DESC_t and false otherwise. + */ +#define ARR_DESC_COPYABLE(arr_desc_dest_ptr, arr_desc_src_ptr) \ + (ARR_DESC_BYTES(arr_desc_src_ptr) <= \ + (arr_desc_dest_ptr)->underlying_size) + +/** + * Copy all the data from the source #ARR_DESC_t to the destination + * #ARR_DESC_t. + * + * @note If the destination #ARR_DESC_t is too small to fit the source data the + * copy is aborted and nothing happens. + */ +#define ARR_DESC_COPY(arr_desc_dest_ptr, arr_desc_src_ptr) \ + do \ + { \ + if (ARR_DESC_COPYABLE(arr_desc_dest_ptr, \ + arr_desc_src_ptr)) \ + { \ + ARR_DESC_MEMCPY(arr_desc_dest_ptr, \ + arr_desc_src_ptr, \ + ARR_DESC_BYTES(arr_desc_src_ptr)); \ + /* Update the properties*/ \ + (arr_desc_dest_ptr)->element_count = \ + (arr_desc_src_ptr)->element_count; \ + (arr_desc_dest_ptr)->element_size = \ + (arr_desc_src_ptr)->element_size; \ + } \ + } while (0) + +/** + * Compare the data in two #ARR_DESC_t structs for the specified number of + * bytes. + */ +#define ARR_DESC_MEMCMP(arr_desc_ptr_a, arr_desc_ptr_b, bytes) \ + memcmp((arr_desc_ptr_a)->data_ptr, \ + (arr_desc_ptr_b)->data_ptr, \ + bytes) /* Note the lacking semicolon */ \ + +/** + * Zero out the contents of the #ARR_DESC_t. + */ +#define ARR_DESC_ZERO(arr_desc_ptr) \ + ARR_DESC_MEMSET(arr_desc_ptr, \ + 0, \ + (arr_desc_ptr)->underlying_size) + +/** + * Evaluate to the data address in #ARR_DESC_t at offset. + */ +#define ARR_DESC_DATA_ADDR(type, arr_desc_ptr, offset) \ + ((void*)(((type *) \ + ((arr_desc_ptr)->data_ptr)) \ + + offset)) + +/** + * Evaluate to the element in #ARR_DESC_t with type at idx. + */ +#define ARR_DESC_ELT(type, idx, arr_desc_ptr) \ + (*((type *) ARR_DESC_DATA_ADDR(type, \ + arr_desc_ptr, \ + idx))) + +#endif /* _ARR_DESC_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest.h new file mode 100644 index 0000000..9d0af06 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest.h @@ -0,0 +1,17 @@ +#ifndef _JTEST_H_ +#define _JTEST_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "jtest_fw.h" +#include "jtest_test.h" +#include "jtest_test_define.h" +#include "jtest_test_call.h" +#include "jtest_group.h" +#include "jtest_group_define.h" +#include "jtest_group_call.h" +#include "jtest_cycle.h" + +#endif /* _JTEST_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_cycle.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_cycle.h new file mode 100644 index 0000000..1934af8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_cycle.h @@ -0,0 +1,65 @@ +#ifndef _JTEST_CYCLE_H_ +#define _JTEST_CYCLE_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "jtest_fw.h" /* JTEST_DUMP_STRF() */ +#include "jtest_systick.h" +#include "jtest_util.h" /* STR() */ + +/*--------------------------------------------------------------------------------*/ +/* Declare Module Variables */ +/*--------------------------------------------------------------------------------*/ +extern const char * JTEST_CYCLE_STRF; + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Wrap the function call, fn_call, to count execution cycles and display the + * results. + */ +/* skipp function name + param +#define JTEST_COUNT_CYCLES(fn_call) \ + do \ + { \ + uint32_t __jtest_cycle_end_count; \ + \ + JTEST_SYSTICK_RESET(SysTick); \ + JTEST_SYSTICK_START(SysTick); \ + \ + fn_call; \ + \ + __jtest_cycle_end_count = \ + JTEST_SYSTICK_VALUE(SysTick); \ + \ + JTEST_SYSTICK_RESET(SysTick); \ + JTEST_DUMP_STRF(JTEST_CYCLE_STRF, \ + STR(fn_call), \ + (JTEST_SYSTICK_INITIAL_VALUE - \ + __jtest_cycle_end_count)); \ + } while (0) +*/ +#define JTEST_COUNT_CYCLES(fn_call) \ + do \ + { \ + uint32_t __jtest_cycle_end_count; \ + \ + JTEST_SYSTICK_RESET(SysTick); \ + JTEST_SYSTICK_START(SysTick); \ + \ + fn_call; \ + \ + __jtest_cycle_end_count = \ + JTEST_SYSTICK_VALUE(SysTick); \ + \ + JTEST_SYSTICK_RESET(SysTick); \ + JTEST_DUMP_STRF(JTEST_CYCLE_STRF, \ + (JTEST_SYSTICK_INITIAL_VALUE - \ + __jtest_cycle_end_count)); \ + } while (0) + +#endif /* _JTEST_CYCLE_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_define.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_define.h new file mode 100644 index 0000000..cbec329 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_define.h @@ -0,0 +1,37 @@ +#ifndef _JTEST_DEFINE_H_ +#define _JTEST_DEFINE_H_ + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Makes a symbol for use as a struct name. Names made this way have two parts; + * the first parts is a prefix common to all structs of that class. The second + * is a specifier which differs for each instance of that struct type. + */ +#define JTEST_STRUCT_NAME(prefix, specifier) \ + CONCAT(prefix, specifier) + +/** + * Define a struct with type with a name generated by #JTEST_STRUCT_NAME(). + */ +#define JTEST_DEFINE_STRUCT(type, struct_name) \ + type struct_name + +/** + * Declare a struct with type with a name generated by #JTEST_STRUCT_NAME(). + */ +#define JTEST_DECLARE_STRUCT(struct_definition) \ + extern struct_definition + +/** + * Define and initialize a struct (created with JTEST_DEFINE_STRUCT()) and + * initialize it with init_values. + */ +#define JTEST_INIT_STRUCT(struct_definition, init_values) \ + struct_definition = { \ + init_values \ + } + +#endif /* _JTEST_DEFINE_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_fw.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_fw.h new file mode 100644 index 0000000..13b015d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_fw.h @@ -0,0 +1,253 @@ +#ifndef _JTEST_FW_H_ +#define _JTEST_FW_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include /* int32_t */ +#include /* strcpy() */ +#include /* sprintf() */ +#include "jtest_pf.h" /* Extend JTEST_FW_t with Pass/Fail data */ +#include "jtest_group.h" + +/*--------------------------------------------------------------------------------*/ +/* Type Definitions */ +/*--------------------------------------------------------------------------------*/ + +/** + * A struct used to interface with the Keil Debugger. + */ +typedef struct JTEST_FW_struct +{ + /* Action Triggers: The Keil debugger monitors these values for changes. In + * response to a change, the debugger executes code on the host. */ + volatile int32_t test_start; + volatile int32_t test_end; + volatile int32_t group_start; + volatile int32_t group_end; + volatile int32_t dump_str; + volatile int32_t dump_data; + volatile int32_t exit_fw; + + JTEST_GROUP_t * current_group_ptr; + + /* Buffers: The C-code cannot send strings and data directly to the + * debugging framework. Instead, the debugger can be told to read 128 byte + * (by default) chunks of memory. Data received in this manner requires + * post-processing to be legible.*/ + char * str_buffer; + char * data_buffer; + + /* Pass/Fail Data */ + JTEST_PF_MEMBERS; + +} JTEST_FW_t; + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Default name for the JTEST_FW struct. + * + * Define your own if you want the variable containing the #JTEST_FW_t to have + * a different name. + */ +#ifndef JTEST_FW +#define JTEST_FW JTEST_FW +#endif + +/** + * Default name for the JTEST_FW_STR_BUFFER. + * + * Define your own if you want the variable containing the char buffer to have + * a different name. + */ +#ifndef JTEST_FW_STR_BUFFER +#define JTEST_FW_STR_BUFFER JTEST_FW_STR_BUFFER +#endif + +/** + * Size of the #JTEST_FW_t, output string-buffer. + * + * If you change this value, make sure the "dump_str_fn" and "dump_data_fn" + * functions in jtest_fns.ini uses the same size. If you aren't sure, read the + * documentation Keil Debugger Command 'DISPLAY'. + */ +#define JTEST_BUF_SIZE 256 + + +/** + * The maximum number of bytes output at once using #JTEST_DUMP_STRF(). + */ +#define JTEST_STR_MAX_OUTPUT_SIZE 128 + +/** + * The maximum number of block transimissions needed to send a string from a + * buffer with JTEST_BUF_SIZE. + */ +#define JTEST_STR_MAX_OUTPUT_SEGMENTS \ + (JTEST_BUF_SIZE / JTEST_STR_MAX_OUTPUT_SIZE) + +/** + * Initialize the JTEST framework. + */ +#define JTEST_INIT() \ + do \ + { \ + JTEST_FW.str_buffer = JTEST_FW_STR_BUFFER; \ + } while (0) + +/* Debugger Action-triggering Macros */ +/*--------------------------------------------------------------------------------*/ + +/** + * Dispatch macro to trigger various actions in the Keil Debugger. + */ +#define JTEST_TRIGGER_ACTION(action_name) \ + do \ + { \ + action_name(); \ + } while (0) + +/** + * Trigger the "Test Start" action in the Keil Debugger. + */ +#define JTEST_ACT_TEST_START() \ + JTEST_TRIGGER_ACTION(test_start) + +/** + * Trigger the "Test End" action in the Keil Debugger. + */ +#define JTEST_ACT_TEST_END() \ + JTEST_TRIGGER_ACTION(test_end) + + +/** + * Trigger the "Group Start" action in the Keil Debugger. + */ +#define JTEST_ACT_GROUP_START() \ + JTEST_TRIGGER_ACTION(group_start) + +/** + * Trigger the "Group End" action in the Keil Debugger. + */ +#define JTEST_ACT_GROUP_END() \ + JTEST_TRIGGER_ACTION(group_end) + + +/** + * Fill the buffer named buf_name with value and dump it to the Keil debugger + * using action. + */ +#define JTEST_ACT_DUMP(action, buf_name, value) \ + do \ + { \ + JTEST_CLEAR_BUFFER(buf_name); \ + strcpy(JTEST_FW.buf_name, (value)); \ + JTEST_TRIGGER_ACTION(action); \ + } while (0) + +/** + * Trigger the "Exit Framework" action in the Keil Debugger. + */ +#define JTEST_ACT_EXIT_FW() \ + do \ + { \ + JTEST_TRIGGER_ACTION(exit_fw); \ + } while (0) + + +/* Buffer Manipulation Macros */ +/*--------------------------------------------------------------------------------*/ + +/** + * Clear the JTEST_FW buffer with name buf_name. + */ +#define JTEST_CLEAR_BUFFER(buf_name) \ + do \ + { \ + memset(JTEST_FW.buf_name, 0, JTEST_BUF_SIZE); \ + } while (0) + +/** + * Clear the memory needed for the JTEST_FW's string buffer. + */ +#define JTEST_CLEAR_STR_BUFFER() \ + JTEST_CLEAR_BUFFER(str_buffer) + +/** + * Clear the memory needed for the JTEST_FW's data buffer. + */ +#define JTEST_CLEAR_DATA_BUFFER() \ + JTEST_CLEAR_BUFFER(data_buffer) + +/** + * Dump the given string to the Keil Debugger. + */ +#define JTEST_DUMP_STR(string) \ + JTEST_ACT_DUMP(dump_str, str_buffer, string) + +/** + * Dump a formatted string to the Keil Debugger. + */ +#define JTEST_DUMP_STRF(format_str, ... ) \ + do \ + { \ + JTEST_CLEAR_STR_BUFFER(); \ + sprintf(JTEST_FW.str_buffer,format_str, __VA_ARGS__); \ + jtest_dump_str_segments(); \ + } while (0) + +/* Pass/Fail Macros */ +/*--------------------------------------------------------------------------------*/ + +/** + * Increment the number of passed tests in #JTEST_FW. + */ +#define JTEST_FW_INC_PASSED(amount) \ + JTEST_PF_INC_PASSED(&JTEST_FW, amount) + +/** + * Increment the number of passed tests in #JTEST_FW. + */ +#define JTEST_FW_INC_FAILED(amount) \ + JTEST_PF_INC_FAILED(&JTEST_FW, amount) + +/* Manipulating the Current Group */ +/*--------------------------------------------------------------------------------*/ + +/** + * Evaluate to the current_group_ptr in #JTEST_FW. + */ +#define JTEST_CURRENT_GROUP_PTR() \ + (JTEST_FW.current_group_ptr) + +#define JTEST_SET_CURRENT_GROUP(group_ptr) \ + do \ + { \ + JTEST_CURRENT_GROUP_PTR() = group_ptr; \ + } while (0) + +/*--------------------------------------------------------------------------------*/ +/* Declare Global Variables */ +/*--------------------------------------------------------------------------------*/ +extern char JTEST_FW_STR_BUFFER[JTEST_BUF_SIZE]; +extern volatile JTEST_FW_t JTEST_FW; + +/*--------------------------------------------------------------------------------*/ +/* Function Prototypes */ +/*--------------------------------------------------------------------------------*/ +void jtest_dump_str_segments(void); + +void test_start (void); +void test_end (void); +void group_start (void); +void group_end (void); +void dump_str (void); +void dump_data (void); +void exit_fw (void); + + +#endif /* _JTEST_FW_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group.h new file mode 100644 index 0000000..3b37ae4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group.h @@ -0,0 +1,66 @@ +#ifndef _JTEST_GROUP_H_ +#define _JTEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "jtest_pf.h" +#include "jtest_util.h" + +/*--------------------------------------------------------------------------------*/ +/* Type Definitions */ +/*--------------------------------------------------------------------------------*/ + +/** + * A struct which represents a group of #JTEST_TEST_t structs. This struct is + * used to run the group of tests, and report on their outcomes. + */ +typedef struct JTEST_GROUP_struct +{ + void (* group_fn_ptr) (void); /**< Pointer to the test group */ + char * name_str; /**< Name of the group */ + + /* Extend the #JTEST_GROUP_t with Pass/Fail information.*/ + JTEST_PF_MEMBERS; +} JTEST_GROUP_t; + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Set the name of JTEST_GROUP_t. + */ +#define JTEST_GROUP_SET_NAME(group_ptr, name) \ + JTEST_SET_STRUCT_ATTRIBUTE(group_ptr, name_str, name) + +#define JTEST_GROUP_SET_FN(group_ptr, fn_ptr) \ + JTEST_SET_STRUCT_ATTRIBUTE(group_ptr, group_fn_ptr, fn_ptr) + +/** + * Increment the number of tests passed in the JTEST_GROUP_t pointed to by + * group_ptr. + */ +#define JTEST_GROUP_INC_PASSED(group_ptr, amount) \ + JTEST_PF_INC_PASSED(group_ptr, amount) + +/** + * Increment the number of tests failed in the JTEST_GROUP_t pointed to by + * group_ptr. + */ +#define JTEST_GROUP_INC_FAILED(group_ptr, amount) \ + JTEST_PF_INC_FAILED(group_ptr, amount) + +/** + * Reset the pass/fail information of the #JTEST_GROUP_t pointed to by + * group_ptr. + */ +#define JTEST_GROUP_RESET_PF(group_ptr) \ + do \ + { \ + JTEST_PF_RESET_PASSED(group_ptr); \ + JTEST_PF_RESET_FAILED(group_ptr); \ + } while (0) + +#endif /* _JTEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_call.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_call.h new file mode 100644 index 0000000..d565a4c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_call.h @@ -0,0 +1,126 @@ +#ifndef _JTEST_GROUP_CALL_H_ +#define _JTEST_GROUP_CALL_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "jtest_fw.h" +#include + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Execute the test in the #JTEST_GROUP_t struct associated witht he identifier + * group_fn. + */ +#define JTEST_GROUP_RUN(group_fn) \ + do \ + { \ + JTEST_DUMP_STR("Group Name:\n"); \ + JTEST_DUMP_STR(JTEST_GROUP_STRUCT_NAME(group_fn).name_str); \ + JTEST_GROUP_STRUCT_NAME(group_fn).group_fn_ptr(); \ + } while (0) + + +/** + * Update the enclosing #JTEST_GROUP_t's pass/fail information using the + * current #JTEST_GROUP_t's. + * + * @param group_ptr Pointer to the current #JTEST_GROUP_t. + * @param parent_ptr Pointer to the enclosing #JTEST_GROUP_t. + * + * @warning Only run this if the current #JTEST_GROUP_t is being called within + * the context of another #JTEST_GROUP_t. + */ +#define JTEST_GROUP_UPDATE_PARENT_GROUP_PF(group_ptr, parent_group_ptr) \ + do \ + { \ + JTEST_GROUP_INC_PASSED(parent_group_ptr, \ + (group_ptr)->passed); \ + JTEST_GROUP_INC_FAILED(parent_group_ptr, \ + (group_ptr)->failed); \ + } while (0) + +/** + * Update the #JTEST_FW's pass/fail information using the current + * #JTEST_GROUP_t's. + */ +#define JTEST_GROUP_UPDATE_FW_PF(group_ptr) \ + do \ + { \ + JTEST_FW_INC_PASSED((group_ptr)->passed); \ + JTEST_FW_INC_FAILED((group_ptr)->failed); \ + } while (0) + +/** + * Update the enclosing context with the current #JTEST_GROUP_t's pass/fail + * information. If this group isn't in an enclosing group, it updates the + * #JTEST_FW's pass/fail info by default. + */ +#define JTEST_GROUP_UPDATE_PARENT_GROUP_OR_FW_PF(group_ptr, \ + parent_group_ptr) \ + do \ + { \ + /* Update the pass fail counts in the parent group */ \ + if (parent_group_ptr /* Null implies Top*/) \ + { \ + JTEST_GROUP_UPDATE_PARENT_GROUP_PF( \ + group_ptr, \ + parent_group_ptr); \ + } else { \ + JTEST_GROUP_UPDATE_FW_PF( \ + group_ptr); \ + } \ + } while (0) + +/** + * Dump the results of running the #JTEST_GROUP_t to the Keil Debugger. + */ +#define JTEST_GROUP_DUMP_RESULTS(group_ptr) \ + do \ + { \ + JTEST_DUMP_STRF( \ + "Tests Run: %" PRIu32 "\n" \ + "----------\n" \ + " Passed: %" PRIu32 "\n" \ + " Failed: %" PRIu32 "\n", \ + (group_ptr)->passed + (group_ptr)->failed, \ + (group_ptr)->passed, \ + (group_ptr)->failed); \ + } while (0) + +/** + * Call the #JTEST_GROUP_t associated with the identifier group_fn. + */ +#define JTEST_GROUP_CALL(group_fn) \ + do \ + { /* Save the current group from JTEST_FW_t before swapping */ \ + /* it to this group (in order to restore it later )*/ \ + JTEST_GROUP_t * __jtest_temp_group_ptr = \ + JTEST_CURRENT_GROUP_PTR(); \ + JTEST_SET_CURRENT_GROUP(&JTEST_GROUP_STRUCT_NAME(group_fn)); \ + \ + /* Reset this group's pass/fail count. Each group */ \ + /* should only remember counts for its last execution. */ \ + JTEST_GROUP_RESET_PF(JTEST_CURRENT_GROUP_PTR()); \ + \ + /* Run the current group */ \ + JTEST_ACT_GROUP_START(); \ + JTEST_GROUP_RUN(group_fn); \ + JTEST_ACT_GROUP_END(); \ + \ + /* Update the pass fail counts in the parent group (or FW) */ \ + JTEST_GROUP_UPDATE_PARENT_GROUP_OR_FW_PF( \ + JTEST_CURRENT_GROUP_PTR(), \ + __jtest_temp_group_ptr); \ + \ + JTEST_GROUP_DUMP_RESULTS(JTEST_CURRENT_GROUP_PTR()); \ + \ + /* Restore the previously current group */ \ + JTEST_SET_CURRENT_GROUP(__jtest_temp_group_ptr); \ + } while (0) + +#endif /* _JTEST_GROUP_CALL_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_define.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_define.h new file mode 100644 index 0000000..b3a86c0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_group_define.h @@ -0,0 +1,87 @@ +#ifndef _JTEST_GROUP_DEFINE_H_ +#define _JTEST_GROUP_DEFINE_H_ + + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "jtest_util.h" +#include "jtest_define.h" +#include "jtest_group.h" + +/* For defining macros with optional arguments */ +#include "opt_arg/opt_arg.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Prefix for all #JTEST_GROUP_t structs. + */ +#define JTEST_GROUP_STRUCT_NAME_PREFIX G_JTEST_GROUP_STRUCT_ + +/** + * Define test template used by #JTEST_GROUP_t tests. + */ +#define JTEST_GROUP_FN_TEMPLATE(group_fn) \ + void group_fn(void) + +#define JTEST_GROUP_FN_PROTOTYPE JTEST_GROUP_FN_TEMPLATE /**< Alias for + #JTEST_GROUP_FN_TEMPLATE. */ + +/** + * Evaluate to the name of the #JTEST_GROUP_t struct associated with group_fn. + */ +#define JTEST_GROUP_STRUCT_NAME(group_fn) \ + JTEST_STRUCT_NAME(JTEST_GROUP_STRUCT_NAME_PREFIX, group_fn) + +/** + * Define a #JTEST_GROUP_t struct based on the given group_fn. + */ +#define JTEST_GROUP_DEFINE_STRUCT(group_fn) \ + JTEST_DEFINE_STRUCT(JTEST_GROUP_t, \ + JTEST_GROUP_STRUCT_NAME(group_fn)) + +/** + * Declare a #JTEST_GROUP_t struct based on the given group_fn. + */ +#define JTEST_GROUP_DECLARE_STRUCT(group_fn) \ + JTEST_DECLARE_STRUCT(JTEST_GROUP_DEFINE_STRUCT(group_fn)) + +/** + * Contents needed to initialize a JTEST_GROUP_t struct. + */ +#define JTEST_GROUP_STRUCT_INIT(group_fn) \ + group_fn, \ + STR_NL(group_fn), \ + JTEST_PF_MEMBER_INIT + +/** + * Initialize the contents of a #JTEST_GROUP_t struct. + */ +#define JTEST_GROUP_INIT(group_fn) \ + JTEST_GROUP_DEFINE_STRUCT(group_fn) = { \ + JTEST_GROUP_STRUCT_INIT(group_fn) \ + } + +/* Test Definition Macro */ +/*--------------------------------------------------------------------------------*/ + +/** + * Define a #JTEST_GROUP_t object and a test function. + */ +#define JTEST_DEFINE_GROUP(group_fn) \ + JTEST_GROUP_FN_PROTOTYPE(group_fn); \ + JTEST_GROUP_INIT(group_fn); \ + JTEST_GROUP_FN_PROTOTYPE(group_fn) /* Notice the lacking semicolon */ + +/** + * Declare a #JTEST_GROUP_t object and a test function prototype. + */ +#define JTEST_DECLARE_GROUP(group_fn) \ + JTEST_GROUP_FN_PROTOTYPE(group_fn); \ + JTEST_GROUP_DECLARE_STRUCT(group_fn) /* Note the lacking semicolon */ + +#endif /* _JTEST_GROUP_DEFINE_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_pf.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_pf.h new file mode 100644 index 0000000..2b005b6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_pf.h @@ -0,0 +1,85 @@ +#ifndef _JTEST_PF_H_ +#define _JTEST_PF_H_ + +/*--------------------------------------------------------------------------------*/ +/* Purpose */ +/*--------------------------------------------------------------------------------*/ +/* jtest_pf.h Contains macros useful for capturing pass/fail data. */ + + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Members that can be added to other structs to extend them pass/fail data and + * corresponding functionality. + */ +#define JTEST_PF_MEMBERS \ + uint32_t passed; \ + uint32_t failed /* Note the lacking semicolon*/ \ + +/** + * Used for initializing JTEST_PF_MEMBERS in a struct declaration. + */ +#define JTEST_PF_MEMBER_INIT \ + 0, \ + 0 + +/* Member-Incrementing Macros */ +/*--------------------------------------------------------------------------------*/ + +/** + * Dispatch macro for incrementing #JTEST_PF_MEMBERS. + * + * @param xxx Values: 'passed', 'failed' + */ +#define JTEST_PF_INC_XXX(xxx, struct_pf_ptr, amount) \ + do \ + { \ + ((struct_pf_ptr)->xxx) += (amount); \ + } while (0) + +/** + * Specialization of the #JTEST_PF_INC_XXX macro to increment the passed + * member. + */ +#define JTEST_PF_INC_PASSED(struct_pf_ptr, amount) \ + JTEST_PF_INC_XXX(passed, struct_pf_ptr, amount) + + +/** + * Specialization of the #JTEST_PF_INC_XXX macro to increment the failed + * member. + */ +#define JTEST_PF_INC_FAILED(struct_pf_ptr, amount) \ + JTEST_PF_INC_XXX(failed, struct_pf_ptr, amount) + + +/* Member-Resetting Macros */ +/*--------------------------------------------------------------------------------*/ + +/** + * Dispatch macro for setting #JTEST_PF_MEMBERS to zero. + * + * @param xxx Values: 'passed', 'failed' + */ +#define JTEST_PF_RESET_XXX(xxx, struct_pf_ptr) \ + do \ + { \ + ((struct_pf_ptr)->xxx) = UINT32_C(0); \ + } while (0) + +/** + * Specialization of #JTEST_PF_RESET_XXX for the 'passed' member. + */ +#define JTEST_PF_RESET_PASSED(struct_pf_ptr) \ + JTEST_PF_RESET_XXX(passed, struct_pf_ptr) + +/** + * Specialization of #JTEST_PF_RESET_XXX for the 'failed' member. + */ +#define JTEST_PF_RESET_FAILED(struct_pf_ptr) \ + JTEST_PF_RESET_XXX(failed, struct_pf_ptr) + +#endif /* _JTEST_PF_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_systick.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_systick.h new file mode 100644 index 0000000..339ecf2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_systick.h @@ -0,0 +1,93 @@ +#ifndef _JTEST_SYSTICK_H_ +#define _JTEST_SYSTICK_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +/* Get access to the SysTick structure. */ +#if defined ARMCM0 + #include "ARMCM0.h" +#elif defined ARMCM0P + #include "ARMCM0plus.h" +#elif defined ARMCM3 + #include "ARMCM3.h" +#elif defined ARMCM4 + #include "ARMCM4.h" +#elif defined ARMCM4_FP + #include "ARMCM4_FP.h" +#elif defined ARMCM7 + #include "ARMCM7.h" +#elif defined ARMCM7_SP + #include "ARMCM7_SP.h" +#elif defined ARMCM7_DP + #include "ARMCM7_DP.h" +#elif defined ARMSC000 + #include "ARMSC000.h" +#elif defined ARMSC300 + #include "ARMSC300.h" +#elif defined ARMv8MBL + #include "ARMv8MBL.h" +#elif defined ARMv8MML + #include "ARMv8MML.h" +#elif defined ARMv8MML_DSP + #include "ARMv8MML_DSP.h" +#elif defined ARMv8MML_SP + #include "ARMv8MML_SP.h" +#elif defined ARMv8MML_DSP_SP + #include "ARMv8MML_DSP_SP.h" +#elif defined ARMv8MML_DP + #include "ARMv8MML_DP.h" +#elif defined ARMv8MML_DSP_DP + #include "ARMv8MML_DSP_DP.h" + +#else + #warning "no appropriate header file found!" +#endif + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Initial value for the SysTick module. + * + * @note This is also the maximum value, important as SysTick is a decrementing + * counter. + */ +#define JTEST_SYSTICK_INITIAL_VALUE 0xFFFFFF + +/** + * Reset the SysTick, decrementing timer to it's maximum value and disable it. + * + * This macro should leave the SysTick timer in a state that's ready for cycle + * counting. + */ +#define JTEST_SYSTICK_RESET(systick_ptr) \ + do \ + { \ + (systick_ptr)->LOAD = JTEST_SYSTICK_INITIAL_VALUE; \ + (systick_ptr)->VAL = 1; \ + \ + /* Disable the SysTick module. */ \ + (systick_ptr)->CTRL = UINT32_C(0x000000); \ + } while (0) + +/** + * Start the SysTick timer, sourced by the processor clock. + */ +#define JTEST_SYSTICK_START(systick_ptr) \ + do \ + { \ + (systick_ptr)->CTRL = \ + SysTick_CTRL_ENABLE_Msk | \ + SysTick_CTRL_CLKSOURCE_Msk; /* Internal clk*/ \ + } while (0) + +/** + * Evaluate to the current value of the SysTick timer. + */ +#define JTEST_SYSTICK_VALUE(systick_ptr) \ + ((systick_ptr)->VAL) + +#endif /* _JTEST_SYSTICK_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test.h new file mode 100644 index 0000000..023145f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test.h @@ -0,0 +1,100 @@ +#ifndef _JTEST_TEST_H_ +#define _JTEST_TEST_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include +#include "jtest_util.h" +#include "jtest_test_ret.h" + +/*--------------------------------------------------------------------------------*/ +/* Type Definitions */ +/*--------------------------------------------------------------------------------*/ + +/** + * A struct which represents a Test in the JTEST framework. This struct is + * used to enable, run, and describe the test it represents. + */ +typedef struct JTEST_TEST_struct +{ + JTEST_TEST_RET_t ( * test_fn_ptr)(void); /**< Pointer to the test function. */ + char * test_fn_str; /**< Name of the test function */ + char * fut_str; /**< Name of the function under test. */ + + /** + * Flags that govern how the #JTEST_TEST_t behaves. + */ + union { + struct { + unsigned enabled : 1; + unsigned unused : 7; + } bits; + uint8_t byte; /* Access all flags at once. */ + } flags; + +} JTEST_TEST_t; + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Assign a test function to the #JTEST_TEST_t struct. + */ +#define JTEST_TEST_SET_FN(jtest_test_ptr, fn_ptr) \ + JTEST_SET_STRUCT_ATTRIBUTE(jtest_test_ptr, test_fn_ptr, fn_ptr) + +/** + * Specify a function under test (FUT) for the #JTEST_TEST_t struct. + */ +#define JTEST_TEST_SET_FUT(jtest_test_ptr, str) \ + JTEST_SET_STRUCT_ATTRIBUTE(jtest_test_ptr, fut_str, str) + +/* Macros concerning JTEST_TEST_t flags */ +/*--------------------------------------------------------------------------------*/ + +#define JTEST_TEST_FLAG_SET 1 /**< Value of a set #JTEST_TEST_t flag. */ +#define JTEST_TEST_FLAG_CLR 0 /**< Value of a cleared #JTEST_TEST_t flag. */ + +/** + * Evaluate to the flag in #JTEST_TEST_t having flag_name. + */ +#define JTEST_TEST_FLAG(jtest_test_ptr, flag_name) \ + ((jtest_test_ptr)->flags.bits.flag_name) + +/** + * Dispatch macro for setting and clearing #JTEST_TEST_t flags. + * + * @param jtest_test_ptr Pointer to a #JTEST_TEST_t struct. + * @param flag_name Name of the flag to set in #JTEST_TEST_t.flags.bits + * @param xxx Vaid values: "SET" or "CLR" + * + * @note This function depends on JTEST_TEST_FLAG_SET and JTEST_TEST_FLAG_CLR. + */ +#define JTEST_TEST_XXX_FLAG(jtest_test_ptr, flag_name, xxx) \ + do \ + { \ + JTEST_TEST_FLAG(jtest_test_ptr, flag_name) = JTEST_TEST_FLAG_##xxx ; \ + } while (0) + +/** + * Specification of #JTEST_TEST_XXX_FLAG to set #JTEST_TEST_t flags. + */ +#define JTEST_TEST_SET_FLAG(jtest_test_ptr, flag_name) \ + JTEST_TEST_XXX_FLAG(jtest_test_ptr, flag_name, SET) + +/** + * Specification of #JTEST_TEST_XXX_FLAG to clear #JTEST_TEST_t flags. + */ +#define JTEST_TEST_CLR_FLAG(jtest_test_ptr, flag_name) \ + JTEST_TEST_XXX_FLAG(jtest_test_ptr, flag_name, CLR) + +/** + * Evaluate to true if the #JTEST_TEST_t is enabled. + */ +#define JTEST_TEST_IS_ENABLED(jtest_test_ptr) \ + (JTEST_TEST_FLAG(jtest_test_ptr, enabled) == JTEST_TEST_FLAG_SET) + +#endif /* _JTEST_TEST_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_call.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_call.h new file mode 100644 index 0000000..9325185 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_call.h @@ -0,0 +1,121 @@ +#ifndef _JTEST_TEST_CALL_H_ +#define _JTEST_TEST_CALL_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ +#include "jtest_test.h" +#include "jtest_test_define.h" +#include "jtest_fw.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Exectute the test in the #JTEST_TEST_t struct associated with the identifier + * test_fn and store the result in retval. + */ +#define JTEST_TEST_RUN(retval, test_fn) \ + do \ + { \ + JTEST_DUMP_STR("Test Name:\n"); \ + JTEST_DUMP_STR(JTEST_TEST_STRUCT_NAME(test_fn).test_fn_str); \ + JTEST_DUMP_STR("Function Under Test:\n"); \ + JTEST_DUMP_STR(JTEST_TEST_STRUCT_NAME(test_fn).fut_str); \ + retval = JTEST_TEST_STRUCT_NAME(test_fn).test_fn_ptr(); \ + } while (0) + +/** + * Update the enclosing #JTEST_GROUP_t's pass/fail information based on + * test_retval. + * + * @param test_retval A #JTEST_TEST_RET_enum for the current test. + * + * @warning Only use if #JTEST_TEST_t is called in the context of a + * #JTEST_GROUP_t. + */ +#define JTEST_TEST_UPDATE_PARENT_GROUP_PF(test_retval) \ + do \ + { \ + /* Update enclosing JTEST_GROUP_t with pass/fail info */ \ + if (test_retval == JTEST_TEST_PASSED) \ + { \ + JTEST_GROUP_INC_PASSED(JTEST_CURRENT_GROUP_PTR(), 1); \ + } else { \ + JTEST_GROUP_INC_FAILED(JTEST_CURRENT_GROUP_PTR(), 1); \ + } \ + } while (0) + +/** + * Update the #JTEST_FW with pass/fail information based on test_retval. + * + * @param test_retval A #JTEST_TEST_RET_enum for the current test. + */ +#define JTEST_TEST_UPDATE_FW_PF(test_retval) \ + do \ + { \ + /* Update the JTEST_FW with pass/fail info */ \ + if (test_retval == JTEST_TEST_PASSED) \ + { \ + JTEST_FW_INC_PASSED( 1); \ + } else { \ + JTEST_FW_INC_FAILED(1); \ + } \ + } while (0) + +/** + * Update the enclosing JTEST_GROUP_t's pass/fail information, or the + * #JTEST_FW's if this test has no enclosing #JTEST_GROUP_t. + * + * @param test_retval A #JTEST_TEST_RET_enum for the current test. + */ +#define JTEST_TEST_UPDATE_PARENT_GROUP_OR_FW_PF(test_retval) \ + do \ + { \ + /* Update pass-fail information */ \ + if (JTEST_CURRENT_GROUP_PTR() /* Non-null */) \ + { \ + JTEST_TEST_UPDATE_PARENT_GROUP_PF(test_retval); \ + } else { \ + JTEST_TEST_UPDATE_FW_PF(test_retval); \ + } \ + } while (0) + +/** + * Dump the results of the test to the Keil Debugger. + */ +#define JTEST_TEST_DUMP_RESULTS(test_retval) \ + do \ + { \ + if (test_retval == JTEST_TEST_PASSED) \ + { \ + JTEST_DUMP_STR("Test Passed\n"); \ + } else { \ + JTEST_DUMP_STR("Test Failed\n"); \ + } \ + } while (0) + +/** + * Call the #JTEST_TEST_t assocaited with the identifier test_fn. + */ +#define JTEST_TEST_CALL(test_fn) \ + do \ + { \ + if (JTEST_TEST_IS_ENABLED(&JTEST_TEST_STRUCT_NAME(test_fn))) \ + { \ + /* Default to failure */ \ + JTEST_TEST_RET_t __jtest_test_ret = JTEST_TEST_FAILED; \ + \ + JTEST_ACT_TEST_START(); \ + JTEST_TEST_RUN(__jtest_test_ret, test_fn); \ + \ + /* Update pass-fail information */ \ + JTEST_TEST_UPDATE_PARENT_GROUP_OR_FW_PF(__jtest_test_ret); \ + \ + JTEST_TEST_DUMP_RESULTS(__jtest_test_ret); \ + JTEST_ACT_TEST_END(); \ + } \ + } while (0) + +#endif /* _JTEST_TEST_CALL_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_define.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_define.h new file mode 100644 index 0000000..1447dd0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_define.h @@ -0,0 +1,133 @@ +#ifndef _JTEST_TEST_DEFINE_H_ +#define _JTEST_TEST_DEFINE_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "jtest_util.h" +#include "jtest_define.h" +#include "jtest_test.h" + +/* For defining macros with optional arguments */ +#include "opt_arg/opt_arg.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Prefix for all #JTEST_TEST_t structs. + */ +#define JTEST_TEST_STRUCT_NAME_PREFIX G_JTEST_TEST_STRUCT_ + +/** + * Define test template used by #JTEST_TEST_t tests. + */ +#define JTEST_TEST_FN_TEMPLATE(test_fn) \ + JTEST_TEST_RET_t test_fn(void) + +#define JTEST_TEST_FN_PROTOTYPE JTEST_TEST_FN_TEMPLATE /**< Alias for + * #JTEST_TEST_FN_TEMPLATE. */ + +/** + * Evaluate to the name of the #JTEST_TEST_t struct associated with test_fn. + */ +#define JTEST_TEST_STRUCT_NAME(test_fn) \ + JTEST_STRUCT_NAME(JTEST_TEST_STRUCT_NAME_PREFIX, test_fn) + +/** + * Define a #JTEST_TEST_t struct based on the given test_fn. + */ +#define JTEST_TEST_DEFINE_STRUCT(test_fn) \ + JTEST_DEFINE_STRUCT(JTEST_TEST_t, \ + JTEST_TEST_STRUCT_NAME(test_fn)) + +/** + * Declare a #JTEST_TEST_t struct based on the given test_fn. + */ +#define JTEST_TEST_DECLARE_STRUCT(test_fn) \ + JTEST_DECLARE_STRUCT(JTEST_TEST_DEFINE_STRUCT(test_fn)) + +/** + * Contents needed to initialize a JTEST_TEST_t struct. + */ +#define JTEST_TEST_STRUCT_INIT(test_fn, fut, enable) \ + test_fn, \ + STR_NL(test_fn), \ + STR_NL(fut), \ + { \ + { \ + enable, \ + 0 \ + } \ + } \ + + +/** + * Initialize the contents of a #JTEST_TEST_t struct. + */ +#define JTEST_TEST_INIT(test_fn, fut, enable) \ + JTEST_TEST_DEFINE_STRUCT(test_fn) = { \ + JTEST_TEST_STRUCT_INIT(test_fn, fut, enable) \ + } + +/* Test Definition Macro */ +/*--------------------------------------------------------------------------------*/ + +/** + * Define a #JTEST_TEST_t object and a test function. + */ +#define _JTEST_DEFINE_TEST(test_fn, fut, enable) \ + JTEST_TEST_FN_PROTOTYPE(test_fn); \ + JTEST_TEST_INIT(test_fn, fut, enable); \ + JTEST_TEST_FN_PROTOTYPE(test_fn) /* Notice the lacking semicolon */ + +/** + * Declare a #JTEST_TEST_t object and a test function prototype. + */ +#define JTEST_DECLARE_TEST(test_fn) \ + JTEST_TEST_FN_PROTOTYPE(test_fn); \ + JTEST_TEST_DECLARE_STRUCT(test_fn) /* Note the lacking semicolon */ + +/*--------------------------------------------------------------------------------*/ +/* Macros with optional arguments */ +/*--------------------------------------------------------------------------------*/ + +/* Top-level Interface */ +#define JTEST_DEFINE_TEST(...) \ + JTEST_DEFINE_TEST_(PP_NARG(__VA_ARGS__), ##__VA_ARGS__) + +/* Dispatch Macro*/ +#define JTEST_DEFINE_TEST_(N, ...) \ + SPLICE(JTEST_DEFINE_TEST_, N)(__VA_ARGS__) + +/* Default Arguments */ +#define JTEST_DEFINE_TEST_DEFAULT_FUT /* Blank */ +#define JTEST_DEFINE_TEST_DEFAULT_ENABLE \ + JTEST_TRUE /* Tests enabled by + * default. */ + +/* Dispatch Cases*/ +#define JTEST_DEFINE_TEST_1(_1) \ + _JTEST_DEFINE_TEST( \ + _1, \ + JTEST_DEFINE_TEST_DEFAULT_FUT, \ + JTEST_DEFINE_TEST_DEFAULT_ENABLE \ + ) + +#define JTEST_DEFINE_TEST_2(_1, _2) \ + _JTEST_DEFINE_TEST( \ + _1, \ + _2, \ + JTEST_DEFINE_TEST_DEFAULT_ENABLE \ + ) + +#define JTEST_DEFINE_TEST_3(_1, _2, _3) \ + _JTEST_DEFINE_TEST( \ + _1, \ + _2, \ + _3 \ + ) + +#endif /* _JTEST_TEST_DEFINE_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_ret.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_ret.h new file mode 100644 index 0000000..c3176e5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_test_ret.h @@ -0,0 +1,17 @@ +#ifndef _JTEST_TEST_RET_H_ +#define _JTEST_TEST_RET_H_ + +/*--------------------------------------------------------------------------------*/ +/* Type Definitions */ +/*--------------------------------------------------------------------------------*/ + +/** + * Values a #JTEST_TEST_t can return. + */ +typedef enum JTEST_TEST_RET_enum +{ + JTEST_TEST_PASSED, + JTEST_TEST_FAILED +} JTEST_TEST_RET_t; + +#endif /* _JTEST_TEST_RET_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_util.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_util.h new file mode 100644 index 0000000..3e07d2e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/jtest_util.h @@ -0,0 +1,27 @@ +#ifndef _JTEST_UTIL_H_ +#define _JTEST_UTIL_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "util/util.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/* Define boolean values for the framework. */ +#define JTEST_TRUE 1 /**< Value used for TRUE in JTEST. */ +#define JTEST_FALSE 0 /**< Value used for FALSE in JTEST. */ + +/** + * Set the value of the attribute in the struct to by struct_ptr to value. + */ +#define JTEST_SET_STRUCT_ATTRIBUTE(struct_ptr, attribute, value) \ + do \ + { \ + (struct_ptr)->attribute = (value); \ + } while (0) + +#endif /* _JTEST_UTIL_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/opt_arg.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/opt_arg.h new file mode 100644 index 0000000..683be1d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/opt_arg.h @@ -0,0 +1,15 @@ +#ifndef _OPT_ARG_H_ +#define _OPT_ARG_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "pp_narg.h" +#include "splice.h" + +/* If you are Joseph Jaoudi, you have a snippet which expands into an + example. If you are not Joseph, but possess his code, study the examples. If + you have no examples, turn back contact Joseph. */ + +#endif /* _OPT_ARG_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/pp_narg.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/pp_narg.h new file mode 100644 index 0000000..d3248f4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/pp_narg.h @@ -0,0 +1,25 @@ +#ifndef _PP_NARG_H_ +#define _PP_NARG_H_ + +#define PP_NARG(...) \ + PP_NARG_(__VA_ARGS__,PP_RSEQ_N()) +#define PP_NARG_(...) \ + PP_ARG_N(__VA_ARGS__) +#define PP_ARG_N( \ + _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,N,...) N +#define PP_RSEQ_N() \ + 63,62,61,60, \ + 59,58,57,56,55,54,53,52,51,50, \ + 49,48,47,46,45,44,43,42,41,40, \ + 39,38,37,36,35,34,33,32,31,30, \ + 29,28,27,26,25,24,23,22,21,20, \ + 19,18,17,16,15,14,13,12,11,10, \ + 9,8,7,6,5,4,3,2,1,0 + +#endif /* _PP_NARG_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/splice.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/splice.h new file mode 100644 index 0000000..ec9142b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/opt_arg/splice.h @@ -0,0 +1,8 @@ +#ifndef _SPLICE_H_ +#define _SPLICE_H_ + +#define SPLICE(a,b) SPLICE_1(a,b) +#define SPLICE_1(a,b) SPLICE_2(a,b) +#define SPLICE_2(a,b) a##b + +#endif /* _SPLICE_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/util/util.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/util/util.h new file mode 100644 index 0000000..f56e0e6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/inc/util/util.h @@ -0,0 +1,52 @@ +#ifndef _UTIL_H_ +#define _UTIL_H_ + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Convert a symbol to a string and add a 'NewLine'. + */ +#define STR_NL(x) STR1_NL(x) +#define STR1_NL(x) (STR2_NL(x)"\n") +#define STR2_NL(x) #x + +/** + * Convert a symbol to a string. + */ +#define STR(x) STR1(x) +#define STR1(x) STR2(x) +#define STR2(x) #x + +/** + * Concatenate two symbols. + */ +#define CONCAT(a, b) CONCAT1(a, b) +#define CONCAT1(a, b) CONCAT2(a, b) +#define CONCAT2(a, b) a##b + + +/** + * Place curly braces around a varaible number of macro arguments. + */ +#define CURLY(...) {__VA_ARGS__} + +/** + * Place parenthesis around a variable number of macro arguments. + */ +#define PAREN(...) (__VA_ARGS__) + +/* Standard min/max macros. */ +#define MIN(x,y) (((x) < (y)) ? (x) : (y) ) +#define MAX(x,y) (((x) > (y)) ? (x) : (y) ) + +/** + * Bound value using low and high limits. + * + * Evaluate to a number in the range, endpoint inclusive. + */ +#define BOUND(low, high, value) \ + MAX(MIN(high, value), low) + +#endif /* _UTIL_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_cycle.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_cycle.c new file mode 100644 index 0000000..24d552d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_cycle.c @@ -0,0 +1,9 @@ +#include "../inc/jtest_cycle.h" +#include + +/*--------------------------------------------------------------------------------*/ +/* Define Module Variables */ +/*--------------------------------------------------------------------------------*/ + +/* const char * JTEST_CYCLE_STRF = "Running: %s\nCycles: %" PRIu32 "\n"; */ +const char * JTEST_CYCLE_STRF = "Cycles: %" PRIu32 "\n"; /* function name + parameter string skipped */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_dump_str_segments.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_dump_str_segments.c new file mode 100644 index 0000000..c3a9bf8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_dump_str_segments.c @@ -0,0 +1,36 @@ +#include "jtest_fw.h" + +/** + * Dump the JTEST_FW.str_buffer the Keil framework in pieces. + * + * The JTEST_FW.str_buffer contains more characters than the Keil framework can + * dump at once. This function dumps them in blocks. + */ +void jtest_dump_str_segments(void) +{ + uint32_t seg_idx = 0; + uint32_t memmove_idx = 0; + uint32_t seg_cnt = + (strlen(JTEST_FW.str_buffer) / JTEST_STR_MAX_OUTPUT_SIZE) + 1; + + for( seg_idx = 0; seg_idx < seg_cnt; ++seg_idx) + { + JTEST_TRIGGER_ACTION(dump_str); + + if (seg_idx < JTEST_STR_MAX_OUTPUT_SEGMENTS) + { + memmove_idx = 0; + while (memmove_idx < (seg_cnt - seg_idx -1) ) + { + memmove( + JTEST_FW.str_buffer+ + (memmove_idx* JTEST_STR_MAX_OUTPUT_SIZE), + JTEST_FW.str_buffer+ + ((memmove_idx+1)*JTEST_STR_MAX_OUTPUT_SIZE), + JTEST_BUF_SIZE); + ++memmove_idx; + } + } + } + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_fw.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_fw.c new file mode 100644 index 0000000..69d7a63 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_fw.c @@ -0,0 +1,9 @@ +#include "../inc/jtest.h" + +/*--------------------------------------------------------------------------------*/ +/* Define Global Variables */ +/*--------------------------------------------------------------------------------*/ + +char JTEST_FW_STR_BUFFER[JTEST_BUF_SIZE] = {0}; + +volatile JTEST_FW_t JTEST_FW = {0}; diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_trigger_action.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_trigger_action.c new file mode 100644 index 0000000..a3901da --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/JTest/src/jtest_trigger_action.c @@ -0,0 +1,37 @@ + +#include "jtest_fw.h" + +void test_start (void) { +// ; + JTEST_FW.test_start++; +} + +void test_end (void) { +// ; + JTEST_FW.test_end++; +} + +void group_start (void) { +// ; + JTEST_FW.group_start++; +} + +void group_end (void) { +// ; + JTEST_FW.group_end++; +} + +void dump_str (void) { +// ; + JTEST_FW.dump_str++; +} + +void dump_data (void) { +// ; + JTEST_FW.dump_data++; +} + +void exit_fw (void) { +// ; + JTEST_FW.exit_fw++; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/all_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/all_tests.h new file mode 100644 index 0000000..df1e998 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/all_tests.h @@ -0,0 +1,9 @@ +#ifndef _ALL_TESTS_H_ +#define _ALL_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Groups */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(all_tests); + +#endif /* _ALL_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_templates.h new file mode 100644 index 0000000..958ef78 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_templates.h @@ -0,0 +1,267 @@ +#ifndef _BASIC_MATH_TEMPLATES_H_ +#define _BASIC_MATH_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ +#include "test_templates.h" + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Compare the outputs used by basic math tests for the function under test and + * the reference function. + */ +#define BASIC_MATH_COMPARE_INTERFACE(block_size, output_type) \ + TEST_ASSERT_BUFFERS_EQUAL( \ + basic_math_output_ref.data_ptr, \ + basic_math_output_fut.data_ptr, \ + block_size * sizeof(output_type)) + +/* + * Comparison SNR thresholds for the data types used in basic_math_tests. + */ +#define BASIC_MATH_SNR_THRESHOLD_float32_t 120 +#define BASIC_MATH_SNR_THRESHOLD_q31_t 100 +#define BASIC_MATH_SNR_THRESHOLD_q15_t 75 +#define BASIC_MATH_SNR_THRESHOLD_q7_t 25 + +/** + * Compare reference and fut outputs using SNR. + * + * @note The outputs are converted to float32_t before comparison. + */ +#define BASIC_MATH_SNR_COMPARE_INTERFACE(block_size, output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + basic_math_output_f32_ref, \ + basic_math_output_ref.data_ptr, \ + basic_math_output_f32_fut, \ + basic_math_output_fut.data_ptr, \ + block_size, \ + output_type, \ + BASIC_MATH_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) + + +/** + * Compare reference and fut outputs using SNR. + * + * @note The outputs are converted to float32_t before comparison. + */ +#define BASIC_MATH_SNR_ELT1_COMPARE_INTERFACE(block_size, output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + basic_math_output_f32_ref, \ + basic_math_output_ref.data_ptr, \ + basic_math_output_f32_fut, \ + basic_math_output_fut.data_ptr, \ + 1, \ + output_type, \ + BASIC_MATH_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) + + + +/*--------------------------------------------------------------------------------*/ +/* Input Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* + * General: + * Input interfaces provide inputs to functions inside test templates. They + * ONLY provide the inputs. The output variables should be hard coded. + * + * The input interfaces must have the following format: + * + * ARM_xxx_INPUT_INTERFACE() or + * REF_xxx_INPUT_INTERFACE() + * + * The xxx must be lowercase, and is intended to be the indentifying substring + * in the function's name. Acceptable values are 'sub' or 'add' from the + * functions arm_add_q31. + */ + +#define ARM_abs_INPUT_INTERFACE(input, block_size) \ + PAREN(input, basic_math_output_fut.data_ptr, block_size) + +#define REF_abs_INPUT_INTERFACE(input, block_size) \ + PAREN(input, basic_math_output_ref.data_ptr, block_size) + +#define ARM_add_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, basic_math_output_fut.data_ptr, block_size) \ + +#define REF_add_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, basic_math_output_ref.data_ptr, block_size) \ + +#define ARM_dot_prod_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, block_size, basic_math_output_fut.data_ptr) \ + +#define REF_dot_prod_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, block_size, basic_math_output_ref.data_ptr) \ + +#define ARM_mult_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, basic_math_output_fut.data_ptr, block_size) \ + +#define REF_mult_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, basic_math_output_ref.data_ptr, block_size) \ + +#define ARM_negate_INPUT_INTERFACE(input, block_size) \ + PAREN(input, basic_math_output_fut.data_ptr, block_size) + +#define REF_negate_INPUT_INTERFACE(input, block_size) \ + PAREN(input, basic_math_output_ref.data_ptr, block_size) + +#define ARM_offset_INPUT_INTERFACE(input, elt, block_size) \ + PAREN(input, elt, basic_math_output_fut.data_ptr, block_size) \ + +#define REF_offset_INPUT_INTERFACE(input, elt, block_size) \ + PAREN(input, elt, basic_math_output_ref.data_ptr, block_size) \ + +#define ARM_shift_INPUT_INTERFACE(input, elt, block_size) \ + PAREN(input, elt, basic_math_output_fut.data_ptr, block_size) \ + +#define REF_shift_INPUT_INTERFACE(input, elt, block_size) \ + PAREN(input, elt, basic_math_output_ref.data_ptr, block_size) \ + +#define ARM_scale_float_INPUT_INTERFACE(input, elt, block_size) \ + PAREN(input, elt, basic_math_output_fut.data_ptr, block_size) \ + +#define REF_scale_float_INPUT_INTERFACE(input, elt, block_size) \ + PAREN(input, elt, basic_math_output_ref.data_ptr, block_size) \ + +/* These two are for the fixed point functions */ +#define ARM_scale_INPUT_INTERFACE(input, elt1, elt2, block_size) \ + PAREN(input, elt1, elt2, basic_math_output_fut.data_ptr, block_size) \ + +#define REF_scale_INPUT_INTERFACE(input, elt1, elt2, block_size) \ + PAREN(input, elt1, elt2, basic_math_output_ref.data_ptr, block_size) \ + +#define ARM_sub_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, basic_math_output_fut.data_ptr, block_size) \ + +#define REF_sub_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, basic_math_output_ref.data_ptr, block_size) \ + + +/*--------------------------------------------------------------------------------*/ +/* Test Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Specialization of #TEST_TEMPLATE_BUF1_BLK() for basic math tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_BLK(fn_name, \ + suffix, \ + input_type, \ + output_type) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF1_BLK( \ + basic_math_f_all, \ + basic_math_block_sizes, \ + input_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + BASIC_MATH_COMPARE_INTERFACE); \ + } + +/** + * Specialization of #TEST_TEMPLATE_BUF2_BLK() for basic math tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK(fn_name, \ + suffix, \ + input_type, \ + output_type, \ + comparison_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF2_BLK( \ + basic_math_f_all, \ + basic_math_f_all, \ + basic_math_block_sizes, \ + input_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + comparison_interface); \ + } + +/** + * Specialization of #TEST_TEMPLATE_BUF1_ELT1_BLK() for basic math tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_ELT1_BLK(fn_name, \ + suffix, \ + input_type, \ + elt_type, \ + output_type) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF1_ELT1_BLK( \ + basic_math_f_all, \ + basic_math_elts, \ + basic_math_block_sizes, \ + input_type, \ + elt_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + BASIC_MATH_COMPARE_INTERFACE); \ + } + +/** + * Specialization of #TEST_TEMPLATE_BUF1_ELT2_BLK() for basic math tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_ELT2_BLK(fn_name, \ + suffix, \ + input_type, \ + elt1_type, \ + elt2_type, \ + output_type) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF1_ELT2_BLK( \ + basic_math_f_all, \ + basic_math_elts, \ + basic_math_elts2, \ + basic_math_block_sizes, \ + input_type, \ + elt1_type, \ + elt2_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + BASIC_MATH_COMPARE_INTERFACE); \ + } + +#endif /* _BASIC_MATH_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_data.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_data.h new file mode 100644 index 0000000..2f0b239 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_data.h @@ -0,0 +1,46 @@ +#ifndef ARM_BASIC_MATH_TEST_DATA_H +#define ARM_BASIC_MATH_TEST_DATA_H + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "arr_desc.h" +#include "arm_math.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ +#define BASIC_MATH_MAX_INPUT_ELEMENTS 32 +#define BASIC_MATH_BIGGEST_INPUT_TYPE float32_t + +/*--------------------------------------------------------------------------------*/ +/* Declare Variables */ +/*--------------------------------------------------------------------------------*/ + +/* Input/Output Buffers */ +ARR_DESC_DECLARE(basic_math_output_fut); +ARR_DESC_DECLARE(basic_math_output_ref); + +extern BASIC_MATH_BIGGEST_INPUT_TYPE +basic_math_output_f32_ref[BASIC_MATH_MAX_INPUT_ELEMENTS]; + +extern BASIC_MATH_BIGGEST_INPUT_TYPE +basic_math_output_f32_fut[BASIC_MATH_MAX_INPUT_ELEMENTS]; + +/* Block Sizes*/ +ARR_DESC_DECLARE(basic_math_block_sizes); + +/* Numbers */ +ARR_DESC_DECLARE(basic_math_elts); +ARR_DESC_DECLARE(basic_math_elts2); +ARR_DESC_DECLARE(basic_math_eltsf); + +/* Float Inputs */ +ARR_DESC_DECLARE(basic_math_zeros); +ARR_DESC_DECLARE(basic_math_f_2); +ARR_DESC_DECLARE(basic_math_f_15); +ARR_DESC_DECLARE(basic_math_f_32); +ARR_DESC_DECLARE(basic_math_f_all); + +#endif diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_group.h new file mode 100644 index 0000000..ece92c7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_test_group.h @@ -0,0 +1,9 @@ +#ifndef _BASIC_MATH_TEST_GROUP_H_ +#define _BASIC_MATH_TEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Groups */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(basic_math_tests); + +#endif /* _BASIC_MATH_TEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_tests.h new file mode 100644 index 0000000..0550444 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/basic_math_tests/basic_math_tests.h @@ -0,0 +1,17 @@ +#ifndef _BASIC_MATH_TESTS_H_ +#define _BASIC_MATH_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Test/Group Declarations */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(abs_tests); +JTEST_DECLARE_GROUP(add_tests); +JTEST_DECLARE_GROUP(dot_prod_tests); +JTEST_DECLARE_GROUP(mult_tests); +JTEST_DECLARE_GROUP(negate_tests); +JTEST_DECLARE_GROUP(offset_tests); +JTEST_DECLARE_GROUP(scale_tests); +JTEST_DECLARE_GROUP(shift_tests); +JTEST_DECLARE_GROUP(sub_tests); + +#endif /* _BASIC_MATH_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_templates.h new file mode 100644 index 0000000..3b7f22f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_templates.h @@ -0,0 +1,222 @@ +#ifndef _COMPLEX_MATH_TEMPLATES_H_ +#define _COMPLEX_MATH_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ +#include "test_templates.h" + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Compare the real outputs from the function under test and the reference + * function. + */ +#define COMPLEX_MATH_COMPARE_RE_INTERFACE(block_size, output_type) \ + TEST_ASSERT_BUFFERS_EQUAL( \ + complex_math_output_ref_a.data_ptr, \ + complex_math_output_fut_a.data_ptr, \ + block_size * sizeof(output_type)) + +/** + * Compare the real and imaginary outputs from the function under test and the + * reference function. + */ +#define COMPLEX_MATH_COMPARE_CMPLX_INTERFACE(block_size, output_type) \ + do \ + { \ + COMPLEX_MATH_COMPARE_RE_INTERFACE(block_size * 2, output_type); \ + } while (0) + + +/* + * Comparison SNR thresholds for the data types used in complex_math_tests. + */ +#define COMPLEX_MATH_SNR_THRESHOLD_float32_t 120 +#define COMPLEX_MATH_SNR_THRESHOLD_q31_t 100 +#define COMPLEX_MATH_SNR_THRESHOLD_q15_t 75 + +/** + * Compare reference and fut outputs using SNR. + * + * The output_suffix specifies which output buffers to use for the + * comparison. An output_suffix of 'a' expands to the following buffers: + * + * - complex_math_output_f32_ref_a + * - complex_math_output_f32_fut_a + * - complex_math_output_ref_a + * - complex_math_output_fut_a + * + * @note The outputs are converted to float32_t before comparison. + */ +#define COMPLEX_MATH_SNR_COMPARE_OUT_INTERFACE(block_size, \ + output_type, \ + output_suffix) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + complex_math_output_f32_ref_##output_suffix, \ + complex_math_output_ref_##output_suffix.data_ptr, \ + complex_math_output_f32_fut_##output_suffix, \ + complex_math_output_fut_##output_suffix.data_ptr, \ + block_size, \ + output_type, \ + COMPLEX_MATH_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) + +/** + * Specification of #COMPLEX_MATH_SNR_COMPARE_INTERFACE() for real outputs. + */ +#define COMPLEX_MATH_SNR_COMPARE_RE_INTERFACE(block_size, \ + output_type) \ + COMPLEX_MATH_SNR_COMPARE_OUT_INTERFACE(block_size, \ + output_type, \ + a) + +/** + * Specification of #COMPLEX_MATH_SNR_COMPARE_INTERFACE() for complex outputs. + */ +#define COMPLEX_MATH_SNR_COMPARE_CMPLX_INTERFACE(block_size, \ + output_type) \ + COMPLEX_MATH_SNR_COMPARE_OUT_INTERFACE(block_size * 2, \ + output_type, \ + a) + +/** + * Compare reference and fut split outputs using SNR. + * + * 'Split' refers to two separate output buffers; one for real and one for + * complex. + */ +#define COMPLEX_MATH_SNR_COMPARE_SPLIT_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + COMPLEX_MATH_SNR_COMPARE_OUT_INTERFACE(block_size, \ + output_type, \ + a); \ + COMPLEX_MATH_SNR_COMPARE_OUT_INTERFACE(block_size, \ + output_type, \ + b); \ + } while (0) + + +/*--------------------------------------------------------------------------------*/ +/* Input Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* + * General: + * Input interfaces provide inputs to functions inside test templates. They + * ONLY provide the inputs. The output variables should be hard coded. + * + * The input interfaces must have the following format: + * + * ARM_xxx_INPUT_INTERFACE() or + * REF_xxx_INPUT_INTERFACE() + * + * The xxx must be lowercase, and is intended to be the indentifying substring + * in the function's name. Acceptable values are 'sub' or 'add' from the + * functions arm_add_q31. + */ + +#define ARM_cmplx_conj_INPUT_INTERFACE(input, block_size) \ + PAREN(input, complex_math_output_fut_a.data_ptr, block_size) + +#define REF_cmplx_conj_INPUT_INTERFACE(input, block_size) \ + PAREN(input, complex_math_output_ref_a.data_ptr, block_size) + +#define ARM_cmplx_dot_prod_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, block_size, \ + complex_math_output_fut_a.data_ptr, \ + complex_math_output_fut_b.data_ptr) + +#define REF_cmplx_dot_prod_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, block_size, \ + complex_math_output_ref_a.data_ptr, \ + complex_math_output_ref_b.data_ptr) + +#define ARM_cmplx_mag_INPUT_INTERFACE(input, block_size) \ + PAREN(input, complex_math_output_fut_a.data_ptr, block_size) + +#define REF_cmplx_mag_INPUT_INTERFACE(input, block_size) \ + PAREN(input, complex_math_output_ref_a.data_ptr, block_size) + +#define ARM_cmplx_mag_squared_INPUT_INTERFACE(input, block_size) \ + PAREN(input, complex_math_output_fut_a.data_ptr, block_size) + +#define REF_cmplx_mag_squared_INPUT_INTERFACE(input, block_size) \ + PAREN(input, complex_math_output_ref_a.data_ptr, block_size) + +#define ARM_cmplx_mult_cmplx_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, complex_math_output_fut_a.data_ptr, block_size) + +#define REF_cmplx_mult_cmplx_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, complex_math_output_ref_a.data_ptr, block_size) + +#define ARM_cmplx_mult_real_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, complex_math_output_fut_a.data_ptr, block_size) + +#define REF_cmplx_mult_real_INPUT_INTERFACE(input_a, input_b, block_size) \ + PAREN(input_a, input_b, complex_math_output_ref_a.data_ptr, block_size) + +/*--------------------------------------------------------------------------------*/ +/* Test Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Specialization of #TEST_TEMPLATE_BUF1_BLK() for complex math tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF1_BLK(fn_name, \ + suffix, \ + input_type, \ + output_type, \ + comparison_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF1_BLK( \ + complex_math_f_all, \ + complex_math_block_sizes, \ + input_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + comparison_interface); \ + } + +/** + * Specialization of #TEST_TEMPLATE_BUF2_BLK1() for complex math tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK(fn_name, \ + suffix, \ + input_type, \ + output_type, \ + comparison_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF2_BLK( \ + complex_math_f_all, \ + complex_math_f_all, \ + complex_math_block_sizes, \ + input_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + comparison_interface); \ + } + +#endif /* _COMPLEX_MATH_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_data.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_data.h new file mode 100644 index 0000000..df561b4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_data.h @@ -0,0 +1,50 @@ +#ifndef _COMPLEX_MATH_TEST_DATA_H_ +#define _COMPLEX_MATH_TEST_DATA_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "arr_desc.h" +#include "arm_math.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ +#define COMPLEX_MATH_MAX_INPUT_ELEMENTS 32 +#define COMPLEX_MATH_BIGGEST_INPUT_TYPE float32_t + +/*--------------------------------------------------------------------------------*/ +/* Decalare Variables */ +/*--------------------------------------------------------------------------------*/ + +/* Input/Output Buffers */ +ARR_DESC_DECLARE(complex_math_output_fut_a); +ARR_DESC_DECLARE(complex_math_output_fut_b); +ARR_DESC_DECLARE(complex_math_output_ref_a); +ARR_DESC_DECLARE(complex_math_output_ref_b); + +extern COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_ref_a[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +extern COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_ref_b[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +extern COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_fut_a[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +extern COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_fut_b[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +/* Block Sizes*/ +ARR_DESC_DECLARE(complex_math_block_sizes); + +/* Float Inputs */ +ARR_DESC_DECLARE(complex_math_zeros); +ARR_DESC_DECLARE(complex_math_f_2); +ARR_DESC_DECLARE(complex_math_f_15); +ARR_DESC_DECLARE(complex_math_f_32); +ARR_DESC_DECLARE(complex_math_f_all); + + +#endif /* _COMPLEX_MATH_TEST_DATA_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_group.h new file mode 100644 index 0000000..5c2ea1f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_test_group.h @@ -0,0 +1,9 @@ +#ifndef _COMPLEX_MATH_TEST_GROUP_H_ +#define _COMPLEX_MATH_TEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Groups */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(complex_math_tests); + +#endif /* _COMPLEX_MATH_TEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_tests.h new file mode 100644 index 0000000..ab4f0ae --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/complex_math_tests/complex_math_tests.h @@ -0,0 +1,14 @@ +#ifndef _COMPLEX_MATH_TESTS_H_ +#define _COMPLEX_MATH_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Test/Group Declarations */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(cmplx_conj_tests); +JTEST_DECLARE_GROUP(cmplx_dot_prod_tests); +JTEST_DECLARE_GROUP(cmplx_mag_tests); +JTEST_DECLARE_GROUP(cmplx_mag_squared_tests); +JTEST_DECLARE_GROUP(cmplx_mult_cmplx_tests); +JTEST_DECLARE_GROUP(cmplx_mult_real_tests); + +#endif /* _COMPLEX_MATH_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_templates.h new file mode 100644 index 0000000..f7956fb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_templates.h @@ -0,0 +1,46 @@ +#ifndef _CONTROLLER_TEMPLATES_H_ +#define _CONTROLLER_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "test_templates.h" +#include /* memcpy() */ + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Comparison SNR thresholds for the data types used in transform_tests. + */ +#define CONTROLLER_SNR_THRESHOLD_float32_t 110 +#define CONTROLLER_SNR_THRESHOLD_q31_t 100 +#define CONTROLLER_SNR_THRESHOLD_q15_t 45 + +/** + * Compare the outputs from the function under test and the reference + * function using SNR. + */ +#define CONTROLLER_SNR_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + controller_output_f32_ref, \ + (output_type *) controller_output_ref, \ + controller_output_f32_fut, \ + (output_type *) controller_output_fut, \ + block_size, \ + output_type, \ + CONTROLLER_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) + + +/*--------------------------------------------------------------------------------*/ +/* TEST Templates */ +/*--------------------------------------------------------------------------------*/ + +#endif /* _CONTROLLER_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_data.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_data.h new file mode 100644 index 0000000..5aa63eb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_data.h @@ -0,0 +1,33 @@ +#ifndef _CONTROLLER_TEST_DATA_H_ +#define _CONTROLLER_TEST_DATA_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "arm_math.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +#define CONTROLLER_MAX_LEN 1024 +#define CONTROLLER_MAX_COEFFS_LEN (12 * 3) +#define TRANFORM_BIGGEST_INPUT_TYPE float32_t + +/*--------------------------------------------------------------------------------*/ +/* Variable Declarations */ +/*--------------------------------------------------------------------------------*/ + +extern float32_t controller_output_fut[CONTROLLER_MAX_LEN]; +extern float32_t controller_output_ref[CONTROLLER_MAX_LEN]; +extern float32_t controller_output_f32_fut[CONTROLLER_MAX_LEN]; +extern float32_t controller_output_f32_ref[CONTROLLER_MAX_LEN]; +extern const float32_t controller_f32_inputs[CONTROLLER_MAX_LEN]; +extern const q31_t controller_q31_inputs[CONTROLLER_MAX_LEN]; +extern const q15_t * controller_q15_inputs; +extern const float32_t controller_f32_coeffs[CONTROLLER_MAX_COEFFS_LEN]; +extern const q31_t controller_q31_coeffs[CONTROLLER_MAX_COEFFS_LEN]; +extern const q15_t controller_q15_coeffs[CONTROLLER_MAX_COEFFS_LEN]; + +#endif /* _CONTROLLER_TEST_DATA_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_group.h new file mode 100644 index 0000000..baead25 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_test_group.h @@ -0,0 +1,9 @@ +#ifndef _CONTROLLER_TEST_GROUP_H_ +#define _CONTROLLER_TEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Group */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(controller_tests); + +#endif /* _CONTROLLER_TEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_tests.h new file mode 100644 index 0000000..41996a8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/controller_tests/controller_tests.h @@ -0,0 +1,11 @@ +#ifndef _CONTROLLER_TESTS_H_ +#define _CONTROLLER_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Test/Group Declarations */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(pid_reset_tests); +JTEST_DECLARE_GROUP(sin_cos_tests); +JTEST_DECLARE_GROUP(pid_tests); + +#endif /* _CONTROLLER_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/fast_math_tests/fast_math_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/fast_math_tests/fast_math_templates.h new file mode 100644 index 0000000..5b49512 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/fast_math_tests/fast_math_templates.h @@ -0,0 +1,102 @@ +#ifndef _FAST_MATH_TEMPLATES_H_ +#define _FAST_MATH_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "test_templates.h" +#include /* memcpy() */ + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Comparison SNR thresholds for the data types used in transform_tests. + */ +#define FAST_MATH_SNR_THRESHOLD_float32_t 95 +#define FAST_MATH_SNR_THRESHOLD_q31_t 95 +#define FAST_MATH_SNR_THRESHOLD_q15_t 45 + +/** + * Compare the outputs from the function under test and the reference + * function using SNR. + */ +#define FAST_MATH_SNR_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + fast_math_output_f32_ref, \ + (output_type *) fast_math_output_ref, \ + fast_math_output_f32_fut, \ + (output_type *) fast_math_output_fut, \ + block_size, \ + output_type, \ + FAST_MATH_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) + + +/*--------------------------------------------------------------------------------*/ +/* TEST Templates */ +/*--------------------------------------------------------------------------------*/ + +#define SQRT_TEST_TEMPLATE_ELT1(suffix) \ + \ + JTEST_DEFINE_TEST(arm_sqrt_##suffix##_test, arm_sqrt_##suffix) \ + { \ + uint32_t i; \ + \ + JTEST_COUNT_CYCLES( \ + for(i=0;i /* memcpy() */ + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** +* Comparison SNR thresholds for the data types used in transform_tests. +*/ +#define INTRINSICS_SNR_THRESHOLD_q63_t 120 +#define INTRINSICS_SNR_THRESHOLD_q31_t 95 + +/** +* Compare the outputs from the function under test and the reference +* function using SNR. +*/ +#define INTRINSICS_SNR_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + intrinsics_output_f32_ref, \ + (output_type##_t *) intrinsics_output_ref, \ + intrinsics_output_f32_fut, \ + (output_type##_t *) intrinsics_output_fut, \ + block_size, \ + output_type, \ + INTRINSICS_SNR_THRESHOLD_##output_type##_t \ + ); \ + } while (0) + + +/*--------------------------------------------------------------------------------*/ +/* TEST Templates */ +/*--------------------------------------------------------------------------------*/ + +#define INTRINSICS_TEST_TEMPLATE_ELT1(functionName, dataType) \ + \ + JTEST_DEFINE_TEST(functionName##_test, functionName) \ + { \ + uint32_t i; \ + \ + JTEST_COUNT_CYCLES( \ + for(i=0;ipData, \ + ((output_type *) &matrix_output_fut)->pData, \ + ((output_type *) &matrix_output_fut)->numRows * \ + ((output_type *) &matrix_output_ref)->numCols * \ + sizeof(output_content_type)) + +/** + * Comparison SNR thresholds for the data types used in matrix_tests. + */ +#define MATRIX_SNR_THRESHOLD 120 + +/** + * Compare the outputs from the function under test and the reference + * function using SNR. + */ +#define MATRIX_SNR_COMPARE_INTERFACE(output_type, output_content_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + (float32_t *)matrix_output_f32_ref, \ + ((output_type *) &matrix_output_ref)->pData, \ + (float32_t *)matrix_output_f32_fut, \ + ((output_type *) &matrix_output_ref)->pData, \ + ((output_type *) &matrix_output_fut)->numRows * \ + ((output_type *) &matrix_output_ref)->numCols, \ + output_content_type, \ + MATRIX_SNR_THRESHOLD \ + ); \ + } while (0) + +/** + * Compare the outputs from the function under test and the reference + * function using SNR. This is special for float64_t + */ +#define MATRIX_DBL_SNR_COMPARE_INTERFACE(output_type) \ + do \ + { \ + TEST_ASSERT_DBL_SNR( \ + (float64_t *)matrix_output_f32_ref, \ + (float64_t *)matrix_output_f32_fut, \ + ((output_type *) &matrix_output_fut)->numRows * \ + ((output_type *) &matrix_output_ref)->numCols, \ + MATRIX_SNR_THRESHOLD \ + ); \ + } while (0) + +/*--------------------------------------------------------------------------------*/ +/* Input Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* + * General: + * Input interfaces provide inputs to functions inside test templates. They + * ONLY provide the inputs. The output variables should be hard coded. + * + * The input interfaces must have the following format: + * + * ARM_xxx_INPUT_INTERFACE() or + * REF_xxx_INPUT_INTERFACE() + * + * The xxx must be lowercase, and is intended to be the indentifying substring + * in the function's name. Acceptable values are 'sub' or 'add' from the + * functions arm_add_q31. + */ + +#define ARM_mat_add_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_fut) + +#define REF_mat_add_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_ref) + +#define ARM_mat_cmplx_mult_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_fut) + +#define REF_mat_cmplx_mult_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_ref) + +#define ARM_mat_inverse_INPUT_INTERFACE(input_ptr) \ + PAREN(input_ptr, (void *) &matrix_output_fut) + +#define REF_mat_inverse_INPUT_INTERFACE(input_ptr) \ + PAREN(input_ptr, (void *) &matrix_output_ref) + +#define ARM_mat_mult_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_fut) + +#define REF_mat_mult_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_ref) + +#define ARM_mat_mult_fast_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_fut) + +#define REF_mat_mult_fast_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_ref) + +#define ARM_mat_sub_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_fut) + +#define REF_mat_sub_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, (void *) &matrix_output_ref) + +#define ARM_mat_trans_INPUT_INTERFACE(input_ptr) \ + PAREN(input_ptr, (void *) &matrix_output_fut) + +#define REF_mat_trans_INPUT_INTERFACE(input_ptr) \ + PAREN(input_ptr, (void *) &matrix_output_ref) + +/*--------------------------------------------------------------------------------*/ +/* Dimension Validation Interfaces */ +/*--------------------------------------------------------------------------------*/ + +#define MATRIX_TEST_VALID_ADDITIVE_DIMENSIONS(input_type, \ + matrix_a_ptr, \ + matrix_b_ptr) \ + ((((input_type) (matrix_a_ptr))->numRows == \ + ((input_type) (matrix_b_ptr))->numRows) && \ + (((input_type) (matrix_a_ptr))->numCols == \ + ((input_type) (matrix_b_ptr))->numCols)) + +#define MATRIX_TEST_VALID_MULTIPLICATIVE_DIMENSIONS(input_type, \ + matrix_a_ptr, \ + matrix_b_ptr) \ + (((input_type) (matrix_a_ptr))->numCols == \ + ((input_type) (matrix_b_ptr))->numRows) + +#define MATRIX_TEST_VALID_SQUARE_DIMENSIONS(input_type, \ + matrix_ptr) \ + (((input_type)(matrix_ptr))->numRows == \ + ((input_type)(matrix_ptr))->numCols) + +#define MATRIX_TEST_VALID_DIMENSIONS_ALWAYS(input_type, \ + matrix_ptr) \ + (1 == 1) \ + +/*--------------------------------------------------------------------------------*/ +/* Output Configuration Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* The matrix tests assume the output matrix is always the correct size. These + * interfaces size the properly size the output matrices according to the input + * matrices and the operation at hand.*/ + +#define MATRIX_TEST_CONFIG_ADDITIVE_OUTPUT(input_type, \ + matrix_a_ptr, \ + matrix_b_ptr) \ + do \ + { \ + ((input_type) &matrix_output_fut)->numRows = \ + ((input_type)(matrix_a_ptr))->numRows; \ + ((input_type) &matrix_output_fut)->numCols = \ + ((input_type)(matrix_a_ptr))->numCols; \ + ((input_type) &matrix_output_ref)->numRows = \ + ((input_type)(matrix_a_ptr))->numRows; \ + ((input_type) &matrix_output_ref)->numCols = \ + ((input_type)(matrix_a_ptr))->numCols; \ + } while (0) + +#define MATRIX_TEST_CONFIG_MULTIPLICATIVE_OUTPUT(input_type, \ + matrix_a_ptr, \ + matrix_b_ptr) \ + do \ + { \ + ((input_type) &matrix_output_fut)->numRows = \ + ((input_type)(matrix_a_ptr))->numRows; \ + ((input_type) &matrix_output_fut)->numCols = \ + ((input_type)(matrix_b_ptr))->numCols; \ + ((input_type) &matrix_output_ref)->numRows = \ + ((input_type)(matrix_a_ptr))->numRows; \ + ((input_type) &matrix_output_ref)->numCols = \ + ((input_type)(matrix_b_ptr))->numCols; \ + } while (0) + +#define MATRIX_TEST_CONFIG_SAMESIZE_OUTPUT(input_type, \ + matrix_ptr) \ + do \ + { \ + ((input_type) &matrix_output_fut)->numRows = \ + ((input_type)(matrix_ptr))->numRows; \ + ((input_type) &matrix_output_fut)->numCols = \ + ((input_type)(matrix_ptr))->numCols; \ + ((input_type) &matrix_output_ref)->numRows = \ + ((input_type)(matrix_ptr))->numRows; \ + ((input_type) &matrix_output_ref)->numCols = \ + ((input_type)(matrix_ptr))->numCols; \ + } while (0) + +#define MATRIX_TEST_CONFIG_TRANSPOSE_OUTPUT(input_type, \ + matrix_ptr) \ + do \ + { \ + ((input_type) &matrix_output_fut)->numRows = \ + ((input_type)(matrix_ptr))->numCols; \ + ((input_type) &matrix_output_fut)->numCols = \ + ((input_type)(matrix_ptr))->numRows; \ + ((input_type) &matrix_output_ref)->numRows = \ + ((input_type)(matrix_ptr))->numCols; \ + ((input_type) &matrix_output_ref)->numCols = \ + ((input_type)(matrix_ptr))->numRows; \ + } while (0) + +/*--------------------------------------------------------------------------------*/ +/* TEST Templates */ +/*--------------------------------------------------------------------------------*/ + +#define MATRIX_TEST_TEMPLATE_ELT1(arr_desc_inputs, \ + input_type, \ + output_type, output_content_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + output_config_interface, \ + dim_validation_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + input_idx, input_type, input, arr_desc_inputs \ + , \ + JTEST_DUMP_STRF("Matrix Dimensions: %dx%d\n", \ + (int)input->numRows, \ + (int)input->numCols); \ + \ + if (dim_validation_interface(input_type, \ + input)) { \ + output_config_interface(input_type, \ + input); \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface(input), \ + ref, ref_arg_interface(input)); \ + compare_interface(output_type, \ + output_content_type); \ + } else { \ + arm_status matrix_test_retval; \ + TEST_CALL_FUT( \ + matrix_test_retval = fut, \ + fut_arg_interface(input)); \ + \ + /* If dimensions are known bad, the fut should */ \ + /* detect it. */ \ + if ( matrix_test_retval != ARM_MATH_SIZE_MISMATCH) { \ + return JTEST_TEST_FAILED; \ + } \ + }); \ + return JTEST_TEST_PASSED; \ + } while (0) + + +#define MATRIX_TEST_TEMPLATE_ELT2(arr_desc_inputs_a, \ + arr_desc_inputs_b, \ + input_type, \ + output_type, output_content_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + output_config_interface, \ + dim_validation_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + input_a_idx, input_type, input_a, arr_desc_inputs_a \ + , \ + input_type input_b = ARR_DESC_ELT( \ + input_type, input_a_idx, \ + &(arr_desc_inputs_b)); \ + \ + JTEST_DUMP_STRF("Matrix Dimensions: A %dx%d B %dx%d\n", \ + (int)input_a->numRows, \ + (int)input_a->numCols, \ + (int)input_b->numRows, \ + (int)input_b->numCols); \ + \ + if (dim_validation_interface(input_type, \ + input_a, \ + input_b)) { \ + \ + output_config_interface(input_type, \ + input_a, \ + input_b); \ + \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface(input_a, input_b), \ + ref, ref_arg_interface(input_a, input_b)); \ + \ + compare_interface(output_type, output_content_type); \ + \ + } else { \ + arm_status matrix_test_retval; \ + TEST_CALL_FUT( \ + matrix_test_retval = fut, fut_arg_interface(input_a, input_b)); \ + \ + /* If dimensions are known bad, the fut should */ \ + /* detect it. */ \ + if ( matrix_test_retval != ARM_MATH_SIZE_MISMATCH) { \ + return JTEST_TEST_FAILED; \ + } \ + }); \ + return JTEST_TEST_PASSED; \ + } while (0) + +/** + * Specialization of #MATRIX_TEST_TEMPLATE_ELT2() for matrix tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define MATRIX_DEFINE_TEST_TEMPLATE_ELT2(fn_name, suffix, \ + output_config_interface, \ + dim_validation_interface, \ + comparison_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + MATRIX_TEST_TEMPLATE_ELT2( \ + matrix_##suffix##_a_inputs, \ + matrix_##suffix##_b_inputs, \ + arm_matrix_instance_##suffix * , \ + arm_matrix_instance_##suffix, \ + TYPE_FROM_ABBREV(suffix), \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + output_config_interface, \ + dim_validation_interface, \ + comparison_interface); \ + } \ + +/** + * Specialization of #MATRIX_TEST_TEMPLATE_ELT1() for matrix tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define MATRIX_DEFINE_TEST_TEMPLATE_ELT1(fn_name, suffix, \ + output_config_interface, \ + dim_validation_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + MATRIX_TEST_TEMPLATE_ELT1( \ + matrix_##suffix##_a_inputs, \ + arm_matrix_instance_##suffix * , \ + arm_matrix_instance_##suffix, \ + TYPE_FROM_ABBREV(suffix), \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + output_config_interface, \ + dim_validation_interface, \ + MATRIX_COMPARE_INTERFACE); \ + } \ + + +#endif /* _MATRIX_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_data.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_data.h new file mode 100644 index 0000000..5940ae3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_data.h @@ -0,0 +1,54 @@ +#ifndef _MATRIX_TEST_DATA_H_ +#define _MATRIX_TEST_DATA_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "arr_desc.h" +#include "arm_math.h" /* float32_t */ + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ +#define MATRIX_TEST_MAX_ROWS 4 +#define MATRIX_TEST_MAX_COLS 4 +#define MATRIX_TEST_BIGGEST_INPUT_TYPE float64_t +#define MATRIX_TEST_MAX_ELTS (MATRIX_TEST_MAX_ROWS * MATRIX_TEST_MAX_COLS) +#define MATRIX_MAX_COEFFS_LEN 16 +#define MATRIX_MAX_SHIFTS_LEN 5 + +/** + * Declare the matrix inputs defined by MATRIX_DEFINE_INPUTS. + */ +#define MATRIX_DECLARE_INPUTS(suffix) \ + ARR_DESC_DECLARE(matrix_##suffix##_a_inputs); \ + ARR_DESC_DECLARE(matrix_##suffix##_b_inputs); \ + ARR_DESC_DECLARE(matrix_##suffix##_invertible_inputs) + + +/*--------------------------------------------------------------------------------*/ +/* Declare Variables */ +/*--------------------------------------------------------------------------------*/ + +/* Input/Output Buffers */ +extern arm_matrix_instance_f32 matrix_output_fut; +extern arm_matrix_instance_f32 matrix_output_ref; +extern arm_matrix_instance_f64 matrix_output_fut64; +extern arm_matrix_instance_f64 matrix_output_ref64; +extern MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_f32_fut[MATRIX_TEST_MAX_ELTS]; +extern MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_f32_ref[MATRIX_TEST_MAX_ELTS]; +extern MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_scratch[MATRIX_TEST_MAX_ELTS]; + +/* Matrix Inputs */ +MATRIX_DECLARE_INPUTS(f64); +MATRIX_DECLARE_INPUTS(f32); +MATRIX_DECLARE_INPUTS(q31); +MATRIX_DECLARE_INPUTS(q15); + +extern const float32_t matrix_f32_scale_values[MATRIX_MAX_COEFFS_LEN]; +extern const q31_t matrix_q31_scale_values[MATRIX_MAX_COEFFS_LEN]; +extern const q15_t matrix_q15_scale_values[MATRIX_MAX_COEFFS_LEN]; +extern const int32_t matrix_shift_values[MATRIX_MAX_SHIFTS_LEN]; + +#endif /* _MATRIX_TEST_DATA_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_group.h new file mode 100644 index 0000000..017b125 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_test_group.h @@ -0,0 +1,9 @@ +#ifndef _MATRIX_TEST_GROUP_H_ +#define _MATRIX_TEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Groups */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(matrix_tests); + +#endif /* _MATRIX_TEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_tests.h new file mode 100644 index 0000000..9947c02 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/matrix_tests/matrix_tests.h @@ -0,0 +1,17 @@ +#ifndef _MATRIX_TESTS_H_ +#define _MATRIX_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Test/Group Declarations */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(mat_add_tests); +JTEST_DECLARE_GROUP(mat_cmplx_mult_tests); +JTEST_DECLARE_GROUP(mat_init_tests); +JTEST_DECLARE_GROUP(mat_inverse_tests); +JTEST_DECLARE_GROUP(mat_mult_tests); +JTEST_DECLARE_GROUP(mat_mult_fast_tests); +JTEST_DECLARE_GROUP(mat_sub_tests); +JTEST_DECLARE_GROUP(mat_trans_tests); +JTEST_DECLARE_GROUP(mat_scale_tests); + +#endif /* _MATRIX_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_templates.h new file mode 100644 index 0000000..ddca35c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_templates.h @@ -0,0 +1,157 @@ +#ifndef _STATISTICS_TEMPLATES_H_ +#define _STATISTICS_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "test_templates.h" + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Compare the outputs from the function under test and the reference function. + */ +#define STATISTICS_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_ASSERT_BUFFERS_EQUAL( \ + statistics_output_ref.data_ptr, \ + statistics_output_fut.data_ptr, \ + 1 * sizeof(output_type) /* All fns return one value*/ \ + ); \ + TEST_ASSERT_EQUAL( \ + statistics_idx_fut, \ + statistics_idx_ref); \ + } while (0) \ + +/* + * Comparison SNR thresholds for the data types used in statistics_tests. + */ +#define STATISTICS_SNR_THRESHOLD_float32_t 120 +#define STATISTICS_SNR_THRESHOLD_q31_t 100 +#define STATISTICS_SNR_THRESHOLD_q15_t 60 +#define STATISTICS_SNR_THRESHOLD_q7_t 30 + +/** + * Compare reference and fut outputs using SNR. + * + * @note The outputs are converted to float32_t before comparison. + */ +#define STATISTICS_SNR_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + statistics_output_f32_ref, \ + statistics_output_ref.data_ptr, \ + statistics_output_f32_fut, \ + statistics_output_fut.data_ptr, \ + 1, /* All fns return one element*/ \ + output_type, \ + STATISTICS_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) + + + +/*--------------------------------------------------------------------------------*/ +/* Input Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* + * General: + * Input interfaces provide inputs to functions inside test templates. They + * ONLY provide the inputs. The output variables should be hard coded. + * + * The input interfaces must have the following format: + * + * ARM_xxx_INPUT_INTERFACE() or + * REF_xxx_INPUT_INTERFACE() + * + * The xxx must be lowercase, and is intended to be the indentifying substring + * in the function's name. Acceptable values are 'sub' or 'add' from the + * functions arm_add_q31. + */ + +#define ARM_max_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, \ + statistics_output_fut.data_ptr, &statistics_idx_fut) + +#define REF_max_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, \ + statistics_output_ref.data_ptr, &statistics_idx_ref) + +#define ARM_mean_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_fut.data_ptr) + +#define REF_mean_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_ref.data_ptr) + +#define ARM_min_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, \ + statistics_output_fut.data_ptr, &statistics_idx_fut) + +#define REF_min_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, \ + statistics_output_ref.data_ptr, &statistics_idx_ref) + +#define ARM_power_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_fut.data_ptr) + +#define REF_power_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_ref.data_ptr) + +#define ARM_rms_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_fut.data_ptr) + +#define REF_rms_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_ref.data_ptr) + +#define ARM_std_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_fut.data_ptr) + +#define REF_std_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_ref.data_ptr) + +#define ARM_var_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_fut.data_ptr) + +#define REF_var_INPUT_INTERFACE(input, block_size) \ + PAREN(input, block_size, statistics_output_ref.data_ptr) + + +/*--------------------------------------------------------------------------------*/ +/* Test Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Specialization of #TEST_TEMPLATE_BUF1_BLK() for statistics tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK(fn_name, \ + suffix, \ + input_type, \ + output_type, \ + comparison_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF1_BLK( \ + statistics_f_all, \ + statistics_block_sizes, \ + input_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + comparison_interface); \ + } + + +#endif /* _STATISTICS_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_data.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_data.h new file mode 100644 index 0000000..3e1ee09 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_data.h @@ -0,0 +1,44 @@ +#ifndef _STATISTICS_TEST_DATA_H_ +#define _STATISTICS_TEST_DATA_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "arr_desc.h" +#include "arm_math.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ +#define STATISTICS_MAX_INPUT_ELEMENTS 32 +#define STATISTICS_BIGGEST_INPUT_TYPE float32_t + +/*--------------------------------------------------------------------------------*/ +/* Declare Variables */ +/*--------------------------------------------------------------------------------*/ + +/* Input/Output Buffers */ +ARR_DESC_DECLARE(statistics_output_fut); +ARR_DESC_DECLARE(statistics_output_ref); +extern uint32_t statistics_idx_fut; +extern uint32_t statistics_idx_ref; + +extern STATISTICS_BIGGEST_INPUT_TYPE +statistics_output_f32_ref[STATISTICS_MAX_INPUT_ELEMENTS]; + +extern STATISTICS_BIGGEST_INPUT_TYPE +statistics_output_f32_fut[STATISTICS_MAX_INPUT_ELEMENTS]; + + +/* Block Sizes */ +ARR_DESC_DECLARE(statistics_block_sizes); + +/* Float Inputs */ +ARR_DESC_DECLARE(statistics_zeros); +ARR_DESC_DECLARE(statistics_f_2); +ARR_DESC_DECLARE(statistics_f_15); +ARR_DESC_DECLARE(statistics_f_32); +ARR_DESC_DECLARE(statistics_f_all); + +#endif /* _STATISTICS_TEST_DATA_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_group.h new file mode 100644 index 0000000..d1446ed --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_test_group.h @@ -0,0 +1,9 @@ +#ifndef _STATISTICS_TEST_GROUP_H_ +#define _STATISTICS_TEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Groups */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(statistics_tests); + +#endif /* _STATISTICS_TEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_tests.h new file mode 100644 index 0000000..20df03e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/statistics_tests/statistics_tests.h @@ -0,0 +1,15 @@ +#ifndef _STATISTICS_TESTS_H_ +#define _STATISTICS_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Test/Group Declarations */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(max_tests); +JTEST_DECLARE_GROUP(mean_tests); +JTEST_DECLARE_GROUP(min_tests); +JTEST_DECLARE_GROUP(power_tests); +JTEST_DECLARE_GROUP(rms_tests); +JTEST_DECLARE_GROUP(std_tests); +JTEST_DECLARE_GROUP(var_tests); + +#endif /* _STATISTICS_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_templates.h new file mode 100644 index 0000000..bc94791 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_templates.h @@ -0,0 +1,120 @@ +#ifndef _SUPPORT_TEMPLATES_H_ +#define _SUPPORT_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "test_templates.h" + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Compare the outputs from the function under test and the reference function. + */ +#define SUPPORT_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_ASSERT_BUFFERS_EQUAL( \ + support_output_ref.data_ptr, \ + support_output_fut.data_ptr, \ + block_size * sizeof(output_type)); \ + } while (0) \ + +/*--------------------------------------------------------------------------------*/ +/* Input Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* + * General: + * Input interfaces provide inputs to functions inside test templates. They + * ONLY provide the inputs. The output variables should be hard coded. + * + * The input interfaces must have the following format: + * + * ARM_xxx_INPUT_INTERFACE() or + * REF_xxx_INPUT_INTERFACE() + * + * The xxx must be lowercase, and is intended to be the indentifying substring + * in the function's name. Acceptable values are 'sub' or 'add' from the + * functions arm_add_q31. + */ + +#define ARM_copy_INPUT_INTERFACE(input, block_size) \ + PAREN(input, support_output_fut.data_ptr, block_size) + +#define REF_copy_INPUT_INTERFACE(input, block_size) \ + PAREN(input, support_output_ref.data_ptr, block_size) + +#define ARM_fill_INPUT_INTERFACE(elt, block_size) \ + PAREN(elt, support_output_fut.data_ptr, block_size) + +#define REF_fill_INPUT_INTERFACE(elt, block_size) \ + PAREN(elt, support_output_ref.data_ptr, block_size) + +#define ARM_x_to_y_INPUT_INTERFACE(input, block_size) \ + PAREN(input, support_output_fut.data_ptr, block_size) + +#define REF_x_to_y_INPUT_INTERFACE(input, block_size) \ + PAREN(input, support_output_ref.data_ptr, block_size) + +/*--------------------------------------------------------------------------------*/ +/* Test Templates */ +/*--------------------------------------------------------------------------------*/ + + +/** + * Specialization of #TEST_TEMPLATE_BUF1_BLK() for support tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define SUPPORT_DEFINE_TEST_TEMPLATE_BUF1_BLK(fn_name, \ + suffix, \ + input_type, \ + output_type, \ + comparison_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_BUF1_BLK( \ + support_f_all, \ + support_block_sizes, \ + input_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + comparison_interface); \ + } + +/** + * Specialization of #TEST_TEMPLATE_ELT1_BLK() for support tests. + * + * @note This macro relies on the existance of ARM_xxx_INPUT_INTERFACE and + * REF_xxx_INPUT_INTERFACEs. + */ +#define SUPPORT_DEFINE_TEST_TEMPLATE_ELT1_BLK(fn_name, \ + suffix, \ + elt_type, \ + output_type, \ + comparison_interface) \ + JTEST_DEFINE_TEST(arm_##fn_name##_##suffix##_test, \ + arm_##fn_name##_##suffix) \ + { \ + TEST_TEMPLATE_ELT1_BLK( \ + support_elts, \ + support_block_sizes, \ + elt_type, \ + output_type, \ + arm_##fn_name##_##suffix, \ + ARM_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + REF_##fn_name##_INPUT_INTERFACE, \ + comparison_interface); \ + } + +#endif /* _SUPPORT_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_data.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_data.h new file mode 100644 index 0000000..cc6c636 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_data.h @@ -0,0 +1,31 @@ +#ifndef ARM_SUPPORT_TEST_DATA_H +#define ARM_SUPPORT_TEST_DATA_H + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "arr_desc.h" + +/*--------------------------------------------------------------------------------*/ +/* Declare Variables */ +/*--------------------------------------------------------------------------------*/ + +/* Input/Output Buffers */ +ARR_DESC_DECLARE(support_output_fut); +ARR_DESC_DECLARE(support_output_ref); + +/* Block Sizes*/ +ARR_DESC_DECLARE(support_block_sizes); + +/* Numbers */ +ARR_DESC_DECLARE(support_elts); + +/* Float Inputs */ +ARR_DESC_DECLARE(support_zeros); +ARR_DESC_DECLARE(support_f_2); +ARR_DESC_DECLARE(support_f_15); +ARR_DESC_DECLARE(support_f_32); +ARR_DESC_DECLARE(support_f_all); + +#endif diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_group.h new file mode 100644 index 0000000..ef3a768 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_test_group.h @@ -0,0 +1,9 @@ +#ifndef _SUPPORT_TEST_GROUP_H_ +#define _SUPPORT_TEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Groups */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(support_tests); + +#endif /* _SUPPORT_TEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_tests.h new file mode 100644 index 0000000..2eab273 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/support_tests/support_tests.h @@ -0,0 +1,11 @@ +#ifndef _SUPPORT_TESTS_H_ +#define _SUPPORT_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Test/Group Declarations */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(copy_tests); +JTEST_DECLARE_GROUP(fill_tests); +JTEST_DECLARE_GROUP(x_to_y_tests); + +#endif /* _SUPPORT_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/template.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/template.h new file mode 100644 index 0000000..e4577d1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/template.h @@ -0,0 +1,88 @@ +#ifndef _TEMPLATE_H_ +#define _TEMPLATE_H_ + +/*--------------------------------------------------------------------------------*/ +/* Looping and Iteration */ +/*--------------------------------------------------------------------------------*/ + +/** + * Template for the general structure of a loop. + */ +#define TEMPLATE_LOOP(setup, loop_def, body) \ + do \ + { \ + setup; \ + loop_def { \ + body; \ + } \ + } while (0) + +/** + * Template for looping over an array-like sequence. + */ +#define TEMPLATE_DO_ARR_LIKE(iter_idx, type, \ + arr, arr_length, \ + iter_elem_setup, \ + body) \ + do \ + { \ + TEMPLATE_LOOP( \ + int iter_idx, \ + for(iter_idx = 0; iter_idx < (arr_length); ++iter_idx), \ + iter_elem_setup; \ + body); \ + } while (0) + +/** + * Template for looping over the contents of an array. + */ +#define TEMPLATE_DO_ARR(iter_idx, type, iter_elem, arr, arr_length, body) \ + do \ + { \ + TEMPLATE_DO_ARR_LIKE( \ + iter_idx, type, arr, arr_length, \ + type iter_elem = (arr)[iter_idx], \ + body); \ + } while (0) + +/** + * Template for looping over the contents of an #ARR_DESC. + */ +#define TEMPLATE_DO_ARR_DESC(iter_idx, type, iter_elem, arr_desc, body) \ + do \ + { \ + TEMPLATE_DO_ARR_LIKE( \ + iter_idx, type, arr_desc, (arr_desc).element_count, \ + type iter_elem = ARR_DESC_ELT(type, iter_idx, &(arr_desc)), \ + body); \ + } while (0) + +/*--------------------------------------------------------------------------------*/ +/* Test Definition */ +/*--------------------------------------------------------------------------------*/ + +/** + * Template for the general structure of a test. + */ +#define TEMPLATE_TEST(setup, body, teardown) \ + do \ + { \ + setup; \ + body; \ + teardown; \ + } while (0) + +/** + * Template for calling a function. + * + * @note Surround function arguments with the #PAREN() macro. + * + * @example + * void my_func(int arg1, int arg2); + * + * TEMPLATE_CALL_FN(my_func, PAREN(3, 7)); + */ +#define TEMPLATE_CALL_FN(fn, fn_args) \ + fn fn_args + +#endif /* _TEMPLATE_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/test_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/test_templates.h new file mode 100644 index 0000000..700bbe1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/templates/test_templates.h @@ -0,0 +1,458 @@ +#ifndef _TEST_TEMPLATES_H_ +#define _TEST_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ +#include "template.h" +#include /* memcmp() */ +#include /* PRIu32 */ +#include "math_helper.h" /* arm_snr_f32() */ + +/*--------------------------------------------------------------------------------*/ +/* Function Aliases for use in Templates. */ +/*--------------------------------------------------------------------------------*/ +#define ref_q31_t_to_float ref_q31_to_float +#define ref_q15_t_to_float ref_q15_to_float +#define ref_q7_t_to_float ref_q7_to_float +#define ref_float_to_q31_t ref_float_to_q31 +#define ref_float_to_q15_t ref_float_to_q15 +#define ref_float_to_q7_t ref_float_to_q7 +#define ref_float32_t_to_float ref_copy_f32 +#define ref_float_to_float32_t ref_copy_f32 + + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Call the function-under-test. + */ +#define TEST_CALL_FUT(fut, fut_args) \ + JTEST_COUNT_CYCLES(TEMPLATE_CALL_FN(fut, fut_args)) + +/** + * Call the reference-function. + */ +#define TEST_CALL_REF(ref, ref_args) \ + TEMPLATE_CALL_FN(ref, ref_args) + +/** + * Call the function-under-test and the reference-function. + */ +#define TEST_CALL_FUT_AND_REF(fut, fut_args, ref, ref_args) \ + do { \ + TEST_CALL_FUT(fut, fut_args); \ + TEST_CALL_REF(ref, ref_args); \ + } while (0) + +/** + * This macro eats a variable number of arguments and evaluates to a null + * statement. + */ +#define TEST_NULL_STATEMENT(...) (void) "TEST_NULL_STATEMENT" + +/** + * A function name, Usable in any template where a fut or ref name is accepted, + * that evaluates to a #TEST_NULL_STATEMENT(). + */ +#define TEST_NULL_FN TEST_NULL_STATEMENT + +/** + * Assert that buffers A and B are byte-equivalent for a number of bytes. + */ +#define TEST_ASSERT_BUFFERS_EQUAL(buf_a, buf_b, bytes) \ + do \ + { \ + if (memcmp(buf_a, buf_b, bytes) != 0) \ + { \ + return JTEST_TEST_FAILED; \ + } \ + } while (0) + +/** + * Assert that the two entities are equal. + */ +#define TEST_ASSERT_EQUAL(a, b) \ + do \ + { \ + if ((a) != (b)) \ + { \ + return JTEST_TEST_FAILED; \ + } \ + } while (0) + +/** + * Convert elements to from src_type to float. + */ +#define TEST_CONVERT_TO_FLOAT(src_ptr, dst_ptr, block_size, src_type) \ + do \ + { \ + ref_##src_type##_to_float( \ + src_ptr, \ + dst_ptr, \ + block_size); \ + } while (0) \ + +/** + * Convert elements to from float to dst_type . + */ +#define TEST_CONVERT_FLOAT_TO(src_ptr, dst_ptr, block_size, dst_type) \ + do \ + { \ + ref_float_to_##dst_type( \ + src_ptr, \ + dst_ptr, \ + block_size); \ + } while (0) \ + +/** + * Assert that the SNR between a reference and test sample is above a given + * threshold. + */ +#define TEST_ASSERT_SNR(ref_ptr, tst_ptr, block_size, threshold) \ + do \ + { \ + float32_t snr = arm_snr_f32(ref_ptr, tst_ptr, block_size); \ + if ( snr <= threshold) \ + { \ + JTEST_DUMP_STRF("SNR: %f\n", snr); \ + return JTEST_TEST_FAILED; \ + } \ + } while (0) \ + +/** + * Assert that the SNR between a reference and test sample is above a given + * threshold. Special case for float64_t + */ +#define TEST_ASSERT_DBL_SNR(ref_ptr, tst_ptr, block_size, threshold) \ + do \ + { \ + float64_t snr = arm_snr_f64(ref_ptr, tst_ptr, block_size); \ + if ( snr <= threshold) \ + { \ + JTEST_DUMP_STRF("SNR: %f\n", snr); \ + return JTEST_TEST_FAILED; \ + } \ + } while (0) \ + +/** + * Compare test and reference elements by converting to float and + * calculating an SNR. + * + * This macro is a merger of the #TEST_CONVERT_TO_FLOAT() and + * #TEST_ASSERT_SNR() macros. + */ +#define TEST_CONVERT_AND_ASSERT_SNR(ref_dst_ptr, ref_src_ptr, \ + tst_dst_ptr, tst_src_ptr, \ + block_size, \ + tst_src_type, \ + threshold) \ + do \ + { \ + TEST_CONVERT_TO_FLOAT(ref_src_ptr, \ + ref_dst_ptr, \ + block_size, \ + tst_src_type); \ + TEST_CONVERT_TO_FLOAT(tst_src_ptr, \ + tst_dst_ptr, \ + block_size, \ + tst_src_type); \ + TEST_ASSERT_SNR(ref_dst_ptr, \ + tst_dst_ptr, \ + block_size, \ + threshold); \ + } while (0) + +/** + * Execute statements only if the combination of block size, function type + * specifier, and input ARR_DESC_t are valid. + * + * @example An ARR_DESC_t that contains 64 bytes cant service a 32 element + * block size if they are extracted in float32_t increments. + * + * 8 * 32 = 256 > 64. + */ +#define TEST_DO_VALID_BLOCKSIZE(block_size, fn_type_spec, \ + input_arr_desc, body) \ + do \ + { \ + if (block_size * sizeof(fn_type_spec) <= \ + ARR_DESC_BYTES(input_arr_desc)) \ + { \ + JTEST_DUMP_STRF("Block Size: %"PRIu32"\n", block_size); \ + body; \ + } \ + } while (0) \ + +/** + * Template for tests that rely on one input buffer and a blocksize parameter. + * + * The buffer is an #ARR_DESC_t. It is iterated over and it's values are + * passed to the function under test and reference functions through their + * appropriate argument interfaces. The argument interfaces this template to + * execute structurally similar functions. + * + */ +#define TEST_TEMPLATE_BUF1_BLK(arr_desc_inputs, \ + arr_desc_block_sizes, \ + input_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + input_idx, ARR_DESC_t *, input_ptr, arr_desc_inputs \ + , \ + TEMPLATE_DO_ARR_DESC( \ + block_size_idx, uint32_t, block_size, arr_desc_block_sizes \ + , \ + void * input_data_ptr = input_ptr->data_ptr; \ + \ + TEST_DO_VALID_BLOCKSIZE( \ + block_size, input_type, input_ptr \ + , \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + input_data_ptr, block_size), \ + ref, ref_arg_interface( \ + input_data_ptr, block_size)); \ + \ + compare_interface(block_size, output_type)))); \ + \ + return JTEST_TEST_PASSED; \ + \ + } while (0) + +/** + * Template for tests that rely on an input buffer and an element. + * + * An element can is any thing which doesn't walk and talk like a + * sequence. Examples include numbers, and structures. + */ +#define TEST_TEMPLATE_BUF1_ELT1(arr_desc_inputs, \ + arr_desc_elts, \ + input_type, elt_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + input_idx, ARR_DESC_t *, input_ptr, arr_desc_inputs \ + , \ + TEMPLATE_DO_ARR_DESC( \ + elt_idx, elt_type, elt, arr_desc_elts \ + , \ + void * input_data_ptr = input_ptr->data_ptr; \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface(input_data_ptr, elt), \ + ref, ref_arg_interface(input_data_ptr, elt)); \ + \ + compare_interface(output_type))); \ + return JTEST_TEST_PASSED; \ + } while (0) + +/** + * Template for tests that rely on an input buffer, an element, and a blocksize + * parameter. + */ +#define TEST_TEMPLATE_BUF1_ELT1_BLK(arr_desc_inputs, \ + arr_desc_elts, \ + arr_desc_block_sizes, \ + input_type, elt_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface); \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + inut_idx, ARR_DESC_t *, input_ptr, arr_desc_inputs \ + , \ + TEMPLATE_DO_ARR_DESC( \ + block_size_idx, uint32_t, block_size, \ + arr_desc_block_sizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + elt_idx, elt_type, elt, arr_desc_elts \ + , \ + void * input_data_ptr = input_ptr->data_ptr; \ + TEST_DO_VALID_BLOCKSIZE( \ + block_size, input_type, input_ptr, \ + \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + input_data_ptr, elt, block_size), \ + ref, ref_arg_interface( \ + input_data_ptr, elt, block_size)); \ + compare_interface(block_size, output_type))))); \ + return JTEST_TEST_PASSED; \ + } while (0) + +/** + * Template for tests that rely on an input buffer, two elements, and a blocksize + * parameter. + */ +#define TEST_TEMPLATE_BUF1_ELT2_BLK(arr_desc_inputs, \ + arr_desc_elt1s, \ + arr_desc_elt2s, \ + arr_desc_block_sizes, \ + input_type, elt1_type, \ + elt2_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + inut_idx, ARR_DESC_t *, input_ptr, arr_desc_inputs \ + , \ + TEMPLATE_DO_ARR_DESC( \ + block_size_idx, uint32_t, block_size, \ + arr_desc_block_sizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + elt1_idx, elt1_type, elt1, arr_desc_elt1s \ + , \ + TEMPLATE_DO_ARR_DESC( \ + elt2_idx, elt2_type, elt2, arr_desc_elt2s \ + , \ + void * input_data_ptr = input_ptr->data_ptr; \ + TEST_DO_VALID_BLOCKSIZE( \ + block_size, input_type, input_ptr, \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + input_data_ptr, elt1, elt2, block_size), \ + ref, ref_arg_interface( \ + input_data_ptr, elt1, elt2, block_size)); \ + compare_interface(block_size, output_type)))))); \ + return JTEST_TEST_PASSED; \ + } while (0) + +/** + * Template for tests that rely on two input buffers and a blocksize parameter. + * + * The two #ARR_DESC_t, input buffers are iterated through in parallel. The + * length of the first #ARR_DESC_t determines the length of the iteration. + */ +#define TEST_TEMPLATE_BUF2_BLK(arr_desc_inputs_a, \ + arr_desc_inputs_b, \ + arr_desc_block_sizes, \ + input_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface) \ + do \ + { \ + /* Iterate over two input arrays in parallel.*/ \ + TEMPLATE_DO_ARR_DESC( \ + input_idx, ARR_DESC_t *, input_ptr, arr_desc_inputs_a \ + , \ + TEMPLATE_DO_ARR_DESC( \ + block_size_idx, uint32_t, block_size, arr_desc_block_sizes, \ + void * input_a_ptr = input_ptr->data_ptr; \ + void * input_b_ptr = ARR_DESC_ELT( \ + ARR_DESC_t *, input_idx, \ + &(arr_desc_inputs_b))->data_ptr; \ + \ + TEST_DO_VALID_BLOCKSIZE( \ + block_size, input_type, input_ptr \ + , \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + input_a_ptr, input_b_ptr, block_size), \ + ref, ref_arg_interface( \ + input_a_ptr, input_b_ptr, block_size)); \ + \ + compare_interface(block_size, output_type)))); \ + return JTEST_TEST_PASSED; \ + } while (0) + +/** + * Test template that uses a single element. + */ +#define TEST_TEMPLATE_ELT1(arr_desc_elts, \ + elt_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + elt_idx, elt_type, elt, arr_desc_elts \ + , \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + elt), \ + ref, ref_arg_interface( \ + elt)); \ + /* Comparison interfaces typically accept */ \ + /* a block_size. Pass a dummy value 1.*/ \ + compare_interface(1, output_type)); \ + return JTEST_TEST_PASSED; \ + } while (0) + +/** + * Test template that iterates over two sets of elements in parallel. + * + * The length of the first set determines the number of iteratsions. + */ +#define TEST_TEMPLATE_ELT2(arr_desc_elts_a, \ + arr_desc_elts_b, \ + elt_a_type, elt_b_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + elt_a_idx, elt_a_type, elt_a, arr_desc_elts_a \ + , \ + elt_b_type * elt_b = ARR_DESC_ELT( \ + elt_b_type, \ + elt_a_idx, \ + arr_desc_elts_b); \ + \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + elt_a, elt_b), \ + ref, ref_arg_interface( \ + elt_a, elt_b)); \ + /* Comparison interfaces typically accept */ \ + /* a block_size. Pass a dummy value 1.*/ \ + compare_interface(1, output_type)); \ + return JTEST_TEST_PASSED; \ + } while (0) + +/** + * Test template that uses an element and a block size. + */ +#define TEST_TEMPLATE_ELT1_BLK(arr_desc_elts, \ + arr_desc_block_sizes, \ + elt_type, output_type, \ + fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + compare_interface) \ + do \ + { \ + TEMPLATE_DO_ARR_DESC( \ + block_size_idx, uint32_t, block_size, \ + arr_desc_block_sizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + elt_idx, elt_type, elt, arr_desc_elts \ + , \ + JTEST_DUMP_STRF("Block Size: %d\n", \ + (int)block_size); \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + elt, block_size), \ + ref, ref_arg_interface( \ + elt, block_size)); \ + compare_interface(block_size, output_type))); \ + return JTEST_TEST_PASSED; \ + } while (0) + +#endif /* _TEST_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_templates.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_templates.h new file mode 100644 index 0000000..c6314b5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_templates.h @@ -0,0 +1,181 @@ +#ifndef _TRANSFORM_TEMPLATES_H_ +#define _TRANSFORM_TEMPLATES_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "test_templates.h" +#include /* memcpy() */ + +/*--------------------------------------------------------------------------------*/ +/* Group Specific Templates */ +/*--------------------------------------------------------------------------------*/ + +/** + * Comparison SNR thresholds for the data types used in transform_tests. + */ +#define TRANSFORM_SNR_THRESHOLD_float32_t 90 +#define TRANSFORM_SNR_THRESHOLD_q31_t 90 +#define TRANSFORM_SNR_THRESHOLD_q15_t 30 + +#define DCT4_TRANSFORM_SNR_THRESHOLD_float32_t 80 +#define DCT4_TRANSFORM_SNR_THRESHOLD_q31_t 75 +#define DCT4_TRANSFORM_SNR_THRESHOLD_q15_t 11 + +/** + * Compare the outputs from the function under test and the reference + * function using SNR. + */ +#define TRANSFORM_SNR_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + transform_fft_output_f32_ref, \ + (output_type *) transform_fft_output_ref, \ + transform_fft_output_f32_fut, \ + (output_type *) transform_fft_output_fut, \ + block_size, \ + output_type, \ + TRANSFORM_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) + +/** + * Compare the outputs from the function under test and the reference + * function using SNR. + */ +#define DCT_TRANSFORM_SNR_COMPARE_INTERFACE(block_size, \ + output_type) \ + do \ + { \ + TEST_CONVERT_AND_ASSERT_SNR( \ + transform_fft_output_f32_ref, \ + (output_type *) transform_fft_output_ref, \ + transform_fft_output_f32_fut, \ + (output_type *) transform_fft_output_fut, \ + block_size, \ + output_type, \ + DCT4_TRANSFORM_SNR_THRESHOLD_##output_type \ + ); \ + } while (0) \ + +/** + * Specialization on #TRANSFORM_SNR_COMPARE_INTERFACE() to fix the block_size + * for complex datasets. + */ +#define TRANSFORM_SNR_COMPARE_CMPLX_INTERFACE(block_size, output_type) \ + /* Complex numbers have two components*/ \ + TRANSFORM_SNR_COMPARE_INTERFACE(block_size * 2, output_type ) + +/** + * This macro copys data from the input_ptr into input arrays. + * + * Some functions modify their input data; in order to provide the same data to + * multiple tests, copies must be made so the changes from one function don't + * impact the others. + */ +#define TRANSFORM_COPY_INPUTS(input_ptr, \ + bytes) \ + do \ + { \ + memcpy( \ + transform_fft_input_fut, \ + input_ptr, \ + bytes); \ + memcpy( \ + transform_fft_input_ref, \ + input_ptr, \ + bytes); \ + } while (0) + +/** + * This macro copys data from the input_ptr into input arrays. It also creates + * symmetric input data for rfft inverse. + * + * The 4.534234f just makes the middle entry of the array semi random. It's + * actual value doesn't seem to matter much. + * + * Some functions modify their input data; in order to provide the same data to + * multiple tests, copies must be made so the changes from one function don't + * impact the others. + */ +#define TRANSFORM_PREPARE_INVERSE_INPUTS(input_ptr, \ + fftlen, input_type, bytes) \ + do \ + { \ + uint32_t i; \ + \ + memcpy( \ + transform_fft_input_fut, \ + input_ptr, \ + bytes); \ + \ + ((input_type*)transform_fft_input_fut)[1] = 0; \ + ((input_type*)transform_fft_input_fut)[fftlen + 0] = 0; \ + ((input_type*)transform_fft_input_fut)[fftlen + 1] = 0; \ + for(i=1;i>= 1; \ + *((type*)transform_fft_inplace_input_ref + i) >>= 1;} \ + } while (0) + +/** + * This macro copys data from the input_ptr into the in-place input arrays. + * + * Some functions modify their input data; in order to provide the same data to + * multiple tests, copies must be made so the changes from one function don't + * impact the others. + */ +#define TRANSFORM_PREPARE_INPLACE_INPUTS(input_ptr, \ + bytes) \ + do \ + { \ + memcpy( \ + transform_fft_inplace_input_fut, \ + input_ptr, \ + bytes); \ + memcpy( \ + transform_fft_inplace_input_ref, \ + input_ptr, \ + bytes); \ + } while (0) + + +#endif /* _TRANSFORM_TEMPLATES_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_data.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_data.h new file mode 100644 index 0000000..bda5e12 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_data.h @@ -0,0 +1,48 @@ +#ifndef _TRANSFORM_TEST_DATA_H_ +#define _TRANSFORM_TEST_DATA_H_ + +/*--------------------------------------------------------------------------------*/ +/* Includes */ +/*--------------------------------------------------------------------------------*/ + +#include "arr_desc.h" +#include "arm_math.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +#define TRANSFORM_MAX_FFT_LEN 4096 +#define TRANFORM_BIGGEST_INPUT_TYPE float32_t + +/*--------------------------------------------------------------------------------*/ +/* Variable Declarations */ +/*--------------------------------------------------------------------------------*/ + +/* Lengths are multiplied by 2 to accomodate complex numbers*/ +extern float32_t transform_fft_output_fut[TRANSFORM_MAX_FFT_LEN * 2]; +extern float32_t transform_fft_output_ref[TRANSFORM_MAX_FFT_LEN * 2]; +extern float32_t transform_fft_input_fut[TRANSFORM_MAX_FFT_LEN * 2]; +extern float32_t transform_fft_input_ref[TRANSFORM_MAX_FFT_LEN * 2]; +extern float32_t transform_fft_output_f32_fut[TRANSFORM_MAX_FFT_LEN * 2]; +extern float32_t transform_fft_output_f32_ref[TRANSFORM_MAX_FFT_LEN * 2]; +extern float32_t * transform_fft_inplace_input_fut; +extern float32_t * transform_fft_inplace_input_ref; +extern float32_t transform_fft_f32_inputs[TRANSFORM_MAX_FFT_LEN * 2]; +extern q31_t transform_fft_q31_inputs[TRANSFORM_MAX_FFT_LEN * 2]; +extern q15_t * transform_fft_q15_inputs; +extern q15_t dct4_transform_fft_q15_inputs[TRANSFORM_MAX_FFT_LEN * 2]; + +/* FFT Lengths */ +ARR_DESC_DECLARE(transform_radix2_fftlens); +ARR_DESC_DECLARE(transform_radix4_fftlens); +ARR_DESC_DECLARE(transform_rfft_fftlens); +ARR_DESC_DECLARE(transform_rfft_fast_fftlens); +ARR_DESC_DECLARE(transform_dct_fftlens); + +/* CFFT Structs */ +ARR_DESC_DECLARE(transform_cfft_f32_structs); +ARR_DESC_DECLARE(transform_cfft_q31_structs); +ARR_DESC_DECLARE(transform_cfft_q15_structs); + +#endif /* _TRANSFORM_TEST_DATA_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_group.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_group.h new file mode 100644 index 0000000..c1c7c9e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_test_group.h @@ -0,0 +1,9 @@ +#ifndef _TRANSFORM_TEST_GROUP_H_ +#define _TRANSFORM_TEST_GROUP_H_ + +/*--------------------------------------------------------------------------------*/ +/* Declare Test Groups */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(transform_tests); + +#endif /* _TRANSFORM_TEST_GROUP_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_tests.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_tests.h new file mode 100644 index 0000000..874c83f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/transform_tests/transform_tests.h @@ -0,0 +1,13 @@ +#ifndef _TRANSFORM_TESTS_H_ +#define _TRANSFORM_TESTS_H_ + +/*--------------------------------------------------------------------------------*/ +/* Test/Group Declarations */ +/*--------------------------------------------------------------------------------*/ +JTEST_DECLARE_GROUP(cfft_tests); +JTEST_DECLARE_GROUP(cfft_family_tests); +JTEST_DECLARE_GROUP(dct4_tests); +JTEST_DECLARE_GROUP(rfft_tests); +JTEST_DECLARE_GROUP(rfft_fast_tests); + +#endif /* _TRANSFORM_TESTS_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/type_abbrev.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/type_abbrev.h new file mode 100644 index 0000000..5909124 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/inc/type_abbrev.h @@ -0,0 +1,37 @@ +#ifndef _TYPE_ABBREV_H_ +#define _TYPE_ABBREV_H_ + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +/** + * Expand the abbreviation for a type into the type itself. + */ +#define TYPE_FROM_ABBREV(abbrev) \ + TYPE_ABBREV_##abbrev \ + +/** + * Expand the type to an abbreviation for that type. + * + * Inverse of #TYPE_FROM_ABBREV(). + * + * @note Should be able to get a type back by writing. + * TYPE_FROM_ABBREV(ABBREV_FROM_TYPE(type)) + */ +#define ABBREV_FROM_TYPE(type) \ + TYPE_SUFFIX_##type + +#define TYPE_ABBREV_f64 float64_t +#define TYPE_ABBREV_f32 float32_t +#define TYPE_ABBREV_q31 q31_t +#define TYPE_ABBREV_q15 q15_t +#define TYPE_ABBREV_q7 q7_t + +#define TYPE_SUFFIX_float64_t f64 +#define TYPE_SUFFIX_float32_t f32 +#define TYPE_SUFFIX_q31_t q31 +#define TYPE_SUFFIX_q15_t q15 +#define TYPE_SUFFIX_q7_t q7 + +#endif /* _TYPE_ABBREV_H_ */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/Retarget.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/Retarget.c new file mode 100644 index 0000000..ffac3df --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/Retarget.c @@ -0,0 +1,52 @@ +/*---------------------------------------------------------------------------- + * Name: Retarget.c + * Purpose: 'Retarget' layer for target-dependent low level functions + * Note(s): + *---------------------------------------------------------------------------- + * This file is part of the uVision/ARM development tools. + * This software may only be used under the terms of a valid, current, + * end user licence from KEIL for a compatible version of KEIL software + * development tools. Nothing else gives you the right to use this software. + * + * This software is supplied "AS IS" without warranties of any kind. + * + * Copyright (c) 2011 Keil - An ARM Company. All rights reserved. + *----------------------------------------------------------------------------*/ + +#include +#include +#include "Serial.h" + +#pragma import(__use_no_semihosting_swi) + + + +struct __FILE { int handle; /* Add whatever you need here */ }; +FILE __stdout; +FILE __stdin; + + +int fputc(int c, FILE *f) { + return (SER_PutChar(c)); +} + + +int fgetc(FILE *f) { + return (SER_GetChar()); +} + + +int ferror(FILE *f) { + /* Your implementation of ferror */ + return EOF; +} + + +void _ttywrch(int c) { + SER_PutChar(c); +} + + +void _sys_exit(int return_code) { +label: goto label; /* endless loop */ +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv6-m.s b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv6-m.s new file mode 100644 index 0000000..fa814eb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv6-m.s @@ -0,0 +1,195 @@ +;/* File: startup_armv6-m.s +; * Purpose: startup file for armv7-m architecture devices. +; * Should be used with ARMCC +; * Version: V2.00 +; * Date: 16 November 2015 +; * +; */ +;/* Copyright (c) 2011 - 2014 ARM LIMITED +; +; All rights reserved. +; Redistribution and use in source and binary forms, with or without +; modification, are permitted provided that the following conditions are met: +; - Redistributions of source code must retain the above copyright +; notice, this list of conditions and the following disclaimer. +; - Redistributions in binary form must reproduce the above copyright +; notice, this list of conditions and the following disclaimer in the +; documentation and/or other materials provided with the distribution. +; - Neither the name of ARM nor the names of its contributors may be used +; to endorse or promote products derived from this software without +; specific prior written permission. +; * +; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +; AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +; IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +; ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE +; LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +; CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +; SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +; CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +; ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +; POSSIBILITY OF SUCH DAMAGE. +; ---------------------------------------------------------------------------*/ +;/* +; //-------- <<< Use Configuration Wizard in Context Menu >>> ------------------ +;*/ + + +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000C00 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + + +; Reset Handler + +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT SystemInit + IMPORT __main + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + BKPT #0 + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + BKPT #0 + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + + ALIGN + +; User Initial Stack & Heap + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + +;/* +; __user_setup_stackheap() returns the: +; - heap base in r0 (if the program uses the heap) +; - stack base in sp +; - heap limit in r2 (if the program uses the heap and uses two-region memory). +; */ + EXPORT __user_setup_stackheap + +__user_setup_stackheap PROC + LDR R0, = __initial_sp + MOV SP, R0 + IF Heap_Size > 0 + LDR R2, = __heap_limit + LDR R0, = __heap_base + ELSE + MOV R0, #0 + MOV R2, #0 + ENDIF + BX LR + ENDP + + +;/* +;__user_initial_stackheap() returns the: +; - heap base in r0 +; - stack base in r1, that is, the highest address in the stack region +; - heap limit in r2 +; - stack limit in r3, that is, the lowest address in the stack region. +; */ +; +;/* DEPRICATED +; EXPORT __user_initial_stackheap +; +;__user_initial_stackheap PROC +; LDR R0, = Heap_Mem +; LDR R1, =(Stack_Mem + Stack_Size) +; LDR R2, = (Heap_Mem + Heap_Size) +; LDR R3, = Stack_Mem +; BX LR +; ENDP +; */ + + ALIGN + + ENDIF + + + END diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv7-m.s b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv7-m.s new file mode 100644 index 0000000..899f2de --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCC/startup_armv7-m.s @@ -0,0 +1,218 @@ +;/* File: startup_armv7-m.s +; * Purpose: startup file for armv7-m architecture devices. +; * Should be used with ARMCC +; * Version: V2.00 +; * Date: 16 November 2015 +; * +; */ +;/* Copyright (c) 2011 - 2014 ARM LIMITED +; +; All rights reserved. +; Redistribution and use in source and binary forms, with or without +; modification, are permitted provided that the following conditions are met: +; - Redistributions of source code must retain the above copyright +; notice, this list of conditions and the following disclaimer. +; - Redistributions in binary form must reproduce the above copyright +; notice, this list of conditions and the following disclaimer in the +; documentation and/or other materials provided with the distribution. +; - Neither the name of ARM nor the names of its contributors may be used +; to endorse or promote products derived from this software without +; specific prior written permission. +; * +; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +; AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +; IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +; ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE +; LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +; CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +; SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +; CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +; ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +; POSSIBILITY OF SUCH DAMAGE. +; ---------------------------------------------------------------------------*/ +;/* +; //-------- <<< Use Configuration Wizard in Context Menu >>> ------------------ +;*/ + + +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000C00 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD MemManage_Handler ; MPU Fault Handler + DCD BusFault_Handler ; Bus Fault Handler + DCD UsageFault_Handler ; Usage Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD DebugMon_Handler ; Debug Monitor Handler + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + + +; Reset Handler + +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT SystemInit + IMPORT __main + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + BKPT #0 + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + BKPT #0 + B . + ENDP +MemManage_Handler\ + PROC + EXPORT MemManage_Handler [WEAK] + BKPT #0 + B . + ENDP +BusFault_Handler\ + PROC + EXPORT BusFault_Handler [WEAK] + BKPT #0 + B . + ENDP +UsageFault_Handler\ + PROC + EXPORT UsageFault_Handler [WEAK] + BKPT #0 + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +DebugMon_Handler\ + PROC + EXPORT DebugMon_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + + ALIGN + +; User Initial Stack & Heap + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + +;/* +; __user_setup_stackheap() returns the: +; - heap base in r0 (if the program uses the heap) +; - stack base in sp +; - heap limit in r2 (if the program uses the heap and uses two-region memory). +; */ + EXPORT __user_setup_stackheap + +__user_setup_stackheap PROC + LDR R0, = __initial_sp + MOV SP, R0 + IF Heap_Size > 0 + LDR R2, = __heap_limit + LDR R0, = __heap_base + ELSE + MOV R0, #0 + MOV R2, #0 + ENDIF + BX LR + ENDP + + +;/* +;__user_initial_stackheap() returns the: +; - heap base in r0 +; - stack base in r1, that is, the highest address in the stack region +; - heap limit in r2 +; - stack limit in r3, that is, the lowest address in the stack region. +; */ +; +;/* DEPRICATED +; EXPORT __user_initial_stackheap +; +;__user_initial_stackheap PROC +; LDR R0, = Heap_Mem +; LDR R1, =(Stack_Mem + Stack_Size) +; LDR R2, = (Heap_Mem + Heap_Size) +; LDR R3, = Stack_Mem +; BX LR +; ENDP +; */ + + ALIGN + + ENDIF + + + END diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv6-m.S b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv6-m.S new file mode 100644 index 0000000..2e60478 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv6-m.S @@ -0,0 +1,203 @@ +/* File: startup_armv6-m.S + * Purpose: startup file for armv6-m architecture devices. + * Should be used with ARMCLANG + * Version: V2.00 + * Date: 16 November 2015 + * + */ +/* Copyright (c) 2011 - 2015 ARM LIMITED + + All rights reserved. + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + - Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + - Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + - Neither the name of ARM nor the names of its contributors may be used + to endorse or promote products derived from this software without + specific prior written permission. + * + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + ---------------------------------------------------------------------------*/ +/* + ;//-------- <<< Use Configuration Wizard in Context Menu >>> ------------------ +*/ + + + .syntax unified + .arch armv6-m + +/* .eabi_attribute Tag_ABI_align8_preserved,1 www.support.code-red-tech.com/CodeRedWiki/Preserve8 */ +.eabi_attribute 25, 1 /* Tag_ABI_align_preserved */ + + +/* + ; Stack Configuration + ; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> + ; +*/ + .equ Stack_Size, 0x00000400 + + .section STACK, "w" + .align 3 + .globl __StackTop + .globl __StackLimit +__StackLimit: + .space Stack_Size +__StackTop: /* formerly known as __initial_sp */ + + +/* + ; Heap Configuration + ; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> + ; +*/ + .equ Heap_Size, 0x00000C00 + + .section HEAP, "w" + .align 3 + .globl __HeapBase + .globl __HeapLimit +__HeapBase: + .if Heap_Size + .space Heap_Size + .endif +__HeapLimit: + + + .section RESET, "x" + .align 2 + .globl __Vectors + .globl __Vectors_End + .globl __Vectors_Size +__Vectors: + .long __StackTop /* Top of Stack */ + .long Reset_Handler /* Reset Handler */ + .long NMI_Handler /* NMI Handler */ + .long HardFault_Handler /* Hard Fault Handler */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long SVC_Handler /* SVCall Handler */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long PendSV_Handler /* PendSV Handler */ + .long SysTick_Handler /* SysTick Handler */ +__Vectors_End: + + .equ __Vectors_Size, __Vectors_End - __Vectors + + + .text + .thumb + .align 2 + + .globl Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function + .thumb_func +Reset_Handler: + bl SystemInit + bl __main + + .globl NMI_Handler + .weak NMI_Handler + .type NMI_Handler, %function + .thumb_func +NMI_Handler: + bkpt #0 + b . + + .globl HardFault_Handler + .weak HardFault_Handler + .type HardFault_Handler, %function + .thumb_func +HardFault_Handler: + bkpt #0 + b . + + .globl SVC_Handler + .weak SVC_Handler + .type SVC_Handler, %function + .thumb_func +SVC_Handler: + bkpt #0 + b . + + .globl PendSV_Handler + .weak PendSV_Handler + .type PendSV_Handler, %function + .thumb_func +PendSV_Handler: + bkpt #0 + b . + + .globl SysTick_Handler + .weak SysTick_Handler + .type SysTick_Handler, %function + .thumb_func +SysTick_Handler: + bkpt #0 + b . + + + .global __use_two_region_memory + +/* + __user_setup_stackheap() returns the: + - heap base in r0 (if the program uses the heap) + - stack base in sp + - heap limit in r2 (if the program uses the heap and uses two-region memory). + */ + .globl __user_setup_stackheap + .type __user_setup_stackheap, %function + .thumb_func +__user_setup_stackheap: + ldr r0, =__StackTop + mov sp, r0 + .if Heap_Size + ldr r0, =__HeapBase + ldr r2, =__HeapLimit + .else + mov r0, #0 + mov r2, #0 + .endif + bx lr + + +/* +__user_initial_stackheap() returns the: + - heap base in r0 + - stack base in r1, that is, the highest address in the stack region + - heap limit in r2 + - stack limit in r3, that is, the lowest address in the stack region. + */ +/* DEPRICATED + .globl __user_initial_stackheap + .type __user_initial_stackheap, %function + .thumb_func +__user_initial_stackheap: + ldr r0, = __HeapBase + ldr r1, = __StackTop + ldr r2, = __HeapLimit + ldr r3, = __StackLimit + bx lr +*/ + + .end diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv7-m.S b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv7-m.S new file mode 100644 index 0000000..93ba4a9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/ARMCLANG/startup_armv7-m.S @@ -0,0 +1,235 @@ +/* File: startup_armv7-m.S + * Purpose: startup file for armv7-m architecture devices. + * Should be used with ARMCLANG + * Version: V2.00 + * Date: 16 November 2015 + * + */ +/* Copyright (c) 2011 - 2015 ARM LIMITED + + All rights reserved. + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + - Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + - Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + - Neither the name of ARM nor the names of its contributors may be used + to endorse or promote products derived from this software without + specific prior written permission. + * + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + ---------------------------------------------------------------------------*/ +/* + ;//-------- <<< Use Configuration Wizard in Context Menu >>> ------------------ +*/ + + + .syntax unified + .arch armv6-m + +/* .eabi_attribute Tag_ABI_align8_preserved,1 www.support.code-red-tech.com/CodeRedWiki/Preserve8 */ +.eabi_attribute 25, 1 /* Tag_ABI_align_preserved */ + + +/* + ; Stack Configuration + ; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> + ; +*/ + .equ Stack_Size, 0x00000400 + + .section STACK, "w" + .align 3 + .globl __StackTop + .globl __StackLimit +__StackLimit: + .space Stack_Size +__StackTop: /* formerly known as __initial_sp */ + + +/* + ; Heap Configuration + ; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> + ; +*/ + .equ Heap_Size, 0x00000C00 + + .section HEAP, "w" + .align 3 + .globl __HeapBase + .globl __HeapLimit +__HeapBase: + .if Heap_Size + .space Heap_Size + .endif +__HeapLimit: + + + .section RESET, "x" + .align 2 + .globl __Vectors + .globl __Vectors_End + .globl __Vectors_Size +__Vectors: + .long __StackTop /* Top of Stack */ + .long Reset_Handler /* Reset Handler */ + .long NMI_Handler /* NMI Handler */ + .long HardFault_Handler /* Hard Fault Handler */ + .long MemManage_Handler /* MPU Fault Handler */ + .long BusFault_Handler /* Bus Fault Handler */ + .long UsageFault_Handler /* Usage Fault Handler */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long SVC_Handler /* SVCall Handler */ + .long DebugMon_Handler /* Debug Monitor Handler */ + .long 0 /* Reserved */ + .long PendSV_Handler /* PendSV Handler */ + .long SysTick_Handler /* SysTick Handler */ +__Vectors_End: + + .equ __Vectors_Size, __Vectors_End - __Vectors + + + .text + .thumb + .align 2 + + .globl Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function + .thumb_func +Reset_Handler: + bl SystemInit + bl __main + + .globl NMI_Handler + .weak NMI_Handler + .type NMI_Handler, %function + .thumb_func +NMI_Handler: + bkpt #0 + b . + + .globl HardFault_Handler + .weak HardFault_Handler + .type HardFault_Handler, %function + .thumb_func +HardFault_Handler: + bkpt #0 + b . + + .globl MemManage_Handler + .weak MemManage_Handler + .type MemManage_Handler, %function + .thumb_func +MemManage_Handler: + bkpt #0 + b . + + .globl BusFault_Handler + .weak BusFault_Handler + .type BusFault_Handler, %function + .thumb_func +BusFault_Handler: + bkpt #0 + b . + + .globl UsageFault_Handler + .weak UsageFault_Handler + .type UsageFault_Handler, %function + .thumb_func +UsageFault_Handler: + bkpt #0 + b . + + .globl SVC_Handler + .weak SVC_Handler + .type SVC_Handler, %function + .thumb_func +SVC_Handler: + bkpt #0 + b . + + .globl DebugMon_Handler + .weak DebugMon_Handler + .type DebugMon_Handler, %function + .thumb_func +DebugMon_Handler: + bkpt #0 + b . + + .globl PendSV_Handler + .weak PendSV_Handler + .type PendSV_Handler, %function + .thumb_func +PendSV_Handler: + bkpt #0 + b . + + .globl SysTick_Handler + .weak SysTick_Handler + .type SysTick_Handler, %function + .thumb_func +SysTick_Handler: + bkpt #0 + b . + + + .global __use_two_region_memory + +/* + __user_setup_stackheap() returns the: + - heap base in r0 (if the program uses the heap) + - stack base in sp + - heap limit in r2 (if the program uses the heap and uses two-region memory). + */ + .globl __user_setup_stackheap + .type __user_setup_stackheap, %function + .thumb_func +__user_setup_stackheap: + ldr r0, =__StackTop + mov sp, r0 + .if Heap_Size + ldr r0, =__HeapBase + ldr r2, =__HeapLimit + .else + mov r0, #0 + mov r2, #0 + .endif + bx lr + + +/* +__user_initial_stackheap() returns the: + - heap base in r0 + - stack base in r1, that is, the highest address in the stack region + - heap limit in r2 + - stack limit in r3, that is, the lowest address in the stack region. + */ +/* DEPRICATED + .globl __user_initial_stackheap + .type __user_initial_stackheap, %function + .thumb_func +__user_initial_stackheap: + ldr r0, = __HeapBase + ldr r1, = __StackTop + ldr r2, = __HeapLimit + ldr r3, = __StackLimit + bx lr +*/ + + .end diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/Retarget.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/Retarget.c new file mode 100644 index 0000000..0ab6c13 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/Retarget.c @@ -0,0 +1,106 @@ +/*---------------------------------------------------------------------------- + * Name: Retarget.c + * Purpose: 'Retarget' layer for target-dependent low level functions + * Note(s): + *---------------------------------------------------------------------------- + * This file is part of the uVision/ARM development tools. + * This software may only be used under the terms of a valid, current, + * end user licence from KEIL for a compatible version of KEIL software + * development tools. Nothing else gives you the right to use this software. + * + * This software is supplied "AS IS" without warranties of any kind. + * + * Copyright (c) 2012 Keil - An ARM Company. All rights reserved. + *----------------------------------------------------------------------------*/ + +#include +#include +#include + +int SER_PutChar (int c) { + + return (c); +} + +int SER_GetChar (void) { + + return (-1); +} + +/*-- GCC - Newlib runtime support --------------------------------------------*/ + +extern int __HeapBase; +extern int __HeapLimit; + +int _open (const char * path, int flags, ...) +{ + return (-1); +} + +int _close (int fd) +{ + return (-1); +} + +int _lseek (int fd, int ptr, int dir) +{ + return (0); +} + +int __attribute__((weak)) _fstat (int fd, struct stat * st) +{ + memset (st, 0, sizeof (* st)); + st->st_mode = S_IFCHR; + return (0); +} + +int _isatty (int fd) +{ + return (1); +} + +int _read (int fd, char * ptr, int len) +{ + char c; + int i; + + for (i = 0; i < len; i++) + { + c = SER_GetChar(); + if (c == 0x0D) break; + *ptr++ = c; + SER_PutChar(c); + } + return (len - i); +} + +int _write (int fd, char * ptr, int len) +{ + int i; + + for (i = 0; i < len; i++) SER_PutChar (*ptr++); + return (i); +} + +caddr_t _sbrk (int incr) +{ + static char * heap; + char * prev_heap; + + if (heap == NULL) + { + heap = (char *)&__HeapBase; + } + + prev_heap = heap; + + if ((heap + incr) > (char *)&__HeapLimit) + { + errno = ENOMEM; + return (caddr_t) -1; + } + + heap += incr; + + return (caddr_t) prev_heap; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv6-m.S b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv6-m.S new file mode 100644 index 0000000..c928912 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv6-m.S @@ -0,0 +1,263 @@ +/* File: startup_armv6-m.S + * Purpose: startup file for armv6-m architecture devices. + * Should be used with GCC for ARM Embedded Processors + * Version: V2.00 + * Date: 16 November 2015 + * + */ +/* Copyright (c) 2011 - 2015 ARM LIMITED + + All rights reserved. + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + - Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + - Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + - Neither the name of ARM nor the names of its contributors may be used + to endorse or promote products derived from this software without + specific prior written permission. + * + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + ---------------------------------------------------------------------------*/ + + + .syntax unified + .arch armv6-m + + .section .stack + .align 3 +#ifdef __STACK_SIZE + .equ Stack_Size, __STACK_SIZE +#else + .equ Stack_Size, 0x00000400 +#endif + .globl __StackTop + .globl __StackLimit +__StackLimit: + .space Stack_Size + .size __StackLimit, . - __StackLimit +__StackTop: + .size __StackTop, . - __StackTop + + .section .heap + .align 3 +#ifdef __HEAP_SIZE + .equ Heap_Size, __HEAP_SIZE +#else + .equ Heap_Size, 0x00000C00 +#endif + .globl __HeapBase + .globl __HeapLimit +__HeapBase: + .if Heap_Size + .space Heap_Size + .endif + .size __HeapBase, . - __HeapBase +__HeapLimit: + .size __HeapLimit, . - __HeapLimit + + .section .vectors + .align 2 + .globl __Vectors +__Vectors: + .long __StackTop /* Top of Stack */ + .long Reset_Handler /* Reset Handler */ + .long NMI_Handler /* NMI Handler */ + .long HardFault_Handler /* Hard Fault Handler */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long SVC_Handler /* SVCall Handler */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long PendSV_Handler /* PendSV Handler */ + .long SysTick_Handler /* SysTick Handler */ + + .size __Vectors, . - __Vectors + + .text + .thumb + .thumb_func + .align 1 + .globl Reset_Handler + .type Reset_Handler, %function +Reset_Handler: +/* Firstly it copies data from read only memory to RAM. There are two schemes + * to copy. One can copy more than one sections. Another can only copy + * one section. The former scheme needs more instructions and read-only + * data to implement than the latter. + * Macro __STARTUP_COPY_MULTIPLE is used to choose between two schemes. */ + +#ifdef __STARTUP_COPY_MULTIPLE +/* Multiple sections scheme. + * + * Between symbol address __copy_table_start__ and __copy_table_end__, + * there are array of triplets, each of which specify: + * offset 0: LMA of start of a section to copy from + * offset 4: VMA of start of a section to copy to + * offset 8: size of the section to copy. Must be multiply of 4 + * + * All addresses must be aligned to 4 bytes boundary. + */ + ldr r4, =__copy_table_start__ + ldr r5, =__copy_table_end__ + +.L_loop0: + cmp r4, r5 + bge .L_loop0_done + ldr r1, [r4] + ldr r2, [r4, #4] + ldr r3, [r4, #8] + +.L_loop0_0: + subs r3, #4 + blt .L_loop0_0_done + ldr r0, [r1, r3] + str r0, [r2, r3] + b .L_loop0_0 + +.L_loop0_0_done: + adds r4, #12 + b .L_loop0 + +.L_loop0_done: +#else +/* Single section scheme. + * + * The ranges of copy from/to are specified by following symbols + * __etext: LMA of start of the section to copy from. Usually end of text + * __data_start__: VMA of start of the section to copy to + * __data_end__: VMA of end of the section to copy to + * + * All addresses must be aligned to 4 bytes boundary. + */ + ldr r1, =__etext + ldr r2, =__data_start__ + ldr r3, =__data_end__ + + subs r3, r2 + ble .L_loop1_done + +.L_loop1: + subs r3, #4 + ldr r0, [r1,r3] + str r0, [r2,r3] + bgt .L_loop1 + +.L_loop1_done: +#endif /*__STARTUP_COPY_MULTIPLE */ + +/* This part of work usually is done in C library startup code. Otherwise, + * define this macro to enable it in this startup. + * + * There are two schemes too. One can clear multiple BSS sections. Another + * can only clear one section. The former is more size expensive than the + * latter. + * + * Define macro __STARTUP_CLEAR_BSS_MULTIPLE to choose the former. + * Otherwise efine macro __STARTUP_CLEAR_BSS to choose the later. + */ +#ifdef __STARTUP_CLEAR_BSS_MULTIPLE +/* Multiple sections scheme. + * + * Between symbol address __copy_table_start__ and __copy_table_end__, + * there are array of tuples specifying: + * offset 0: Start of a BSS section + * offset 4: Size of this BSS section. Must be multiply of 4 + */ + ldr r3, =__zero_table_start__ + ldr r4, =__zero_table_end__ + +.L_loop2: + cmp r3, r4 + bge .L_loop2_done + ldr r1, [r3] + ldr r2, [r3, #4] + movs r0, 0 + +.L_loop2_0: + subs r2, #4 + blt .L_loop2_0_done + str r0, [r1, r2] + b .L_loop2_0 +.L_loop2_0_done: + + adds r3, #8 + b .L_loop2 +.L_loop2_done: +#elif defined (__STARTUP_CLEAR_BSS) +/* Single BSS section scheme. + * + * The BSS section is specified by following symbols + * __bss_start__: start of the BSS section. + * __bss_end__: end of the BSS section. + * + * Both addresses must be aligned to 4 bytes boundary. + */ + ldr r1, =__bss_start__ + ldr r2, =__bss_end__ + + movs r0, 0 + + subs r2, r1 + ble .L_loop3_done + +.L_loop3: + subs r2, #4 + str r0, [r1, r2] + bgt .L_loop3 +.L_loop3_done: +#endif /* __STARTUP_CLEAR_BSS_MULTIPLE || __STARTUP_CLEAR_BSS */ + +#ifndef __NO_SYSTEM_INIT + bl SystemInit +#endif + +#ifndef __START +#define __START _start +#endif + bl __START + + .pool + .size Reset_Handler, . - Reset_Handler + + .align 1 + .thumb_func + .weak Default_Handler + .type Default_Handler, %function +Default_Handler: + bkpt #0 + b . + .size Default_Handler, . - Default_Handler + +/* Macro to define default handlers. Default handler + * will be weak symbol and just dead loops. They can be + * overwritten by other handlers */ + .macro def_irq_handler handler_name + .weak \handler_name + .set \handler_name, Default_Handler + .endm + + def_irq_handler NMI_Handler + def_irq_handler HardFault_Handler + def_irq_handler SVC_Handler + def_irq_handler PendSV_Handler + def_irq_handler SysTick_Handler + + .end diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv7-m.S b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv7-m.S new file mode 100644 index 0000000..2320877 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/GCC/startup_armv7-m.S @@ -0,0 +1,257 @@ +/* File: startup_armv7-m.S + * Purpose: startup file for armv7-m architecture devices. + * Should be used with GCC for ARM Embedded Processors + * Version: V2.00 + * Date: 16 November 2015 + * + */ +/* Copyright (c) 2011 - 2015 ARM LIMITED + + All rights reserved. + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + - Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + - Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + - Neither the name of ARM nor the names of its contributors may be used + to endorse or promote products derived from this software without + specific prior written permission. + * + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDERS AND CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + ---------------------------------------------------------------------------*/ + + + .syntax unified + .arch armv7-m + + .section .stack + .align 3 +#ifdef __STACK_SIZE + .equ Stack_Size, __STACK_SIZE +#else + .equ Stack_Size, 0x00000400 +#endif + .globl __StackTop + .globl __StackLimit +__StackLimit: + .space Stack_Size + .size __StackLimit, . - __StackLimit +__StackTop: + .size __StackTop, . - __StackTop + + .section .heap + .align 3 +#ifdef __HEAP_SIZE + .equ Heap_Size, __HEAP_SIZE +#else + .equ Heap_Size, 0x00000C00 +#endif + .globl __HeapBase + .globl __HeapLimit +__HeapBase: + .if Heap_Size + .space Heap_Size + .endif + .size __HeapBase, . - __HeapBase +__HeapLimit: + .size __HeapLimit, . - __HeapLimit + + .section .vectors + .align 2 + .globl __Vectors +__Vectors: + .long __StackTop /* Top of Stack */ + .long Reset_Handler /* Reset Handler */ + .long NMI_Handler /* NMI Handler */ + .long HardFault_Handler /* Hard Fault Handler */ + .long MemManage_Handler /* MPU Fault Handler */ + .long BusFault_Handler /* Bus Fault Handler */ + .long UsageFault_Handler /* Usage Fault Handler */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long 0 /* Reserved */ + .long SVC_Handler /* SVCall Handler */ + .long DebugMon_Handler /* Debug Monitor Handler */ + .long 0 /* Reserved */ + .long PendSV_Handler /* PendSV Handler */ + .long SysTick_Handler /* SysTick Handler */ + + .size __Vectors, . - __Vectors + + .text + .thumb + .thumb_func + .align 2 + .globl Reset_Handler + .type Reset_Handler, %function +Reset_Handler: +/* Firstly it copies data from read only memory to RAM. There are two schemes + * to copy. One can copy more than one sections. Another can only copy + * one section. The former scheme needs more instructions and read-only + * data to implement than the latter. + * Macro __STARTUP_COPY_MULTIPLE is used to choose between two schemes. */ + +#ifdef __STARTUP_COPY_MULTIPLE +/* Multiple sections scheme. + * + * Between symbol address __copy_table_start__ and __copy_table_end__, + * there are array of triplets, each of which specify: + * offset 0: LMA of start of a section to copy from + * offset 4: VMA of start of a section to copy to + * offset 8: size of the section to copy. Must be multiply of 4 + * + * All addresses must be aligned to 4 bytes boundary. + */ + ldr r4, =__copy_table_start__ + ldr r5, =__copy_table_end__ + +.L_loop0: + cmp r4, r5 + bge .L_loop0_done + ldr r1, [r4] + ldr r2, [r4, #4] + ldr r3, [r4, #8] + +.L_loop0_0: + subs r3, #4 + ittt ge + ldrge r0, [r1, r3] + strge r0, [r2, r3] + bge .L_loop0_0 + + adds r4, #12 + b .L_loop0 + +.L_loop0_done: +#else +/* Single section scheme. + * + * The ranges of copy from/to are specified by following symbols + * __etext: LMA of start of the section to copy from. Usually end of text + * __data_start__: VMA of start of the section to copy to + * __data_end__: VMA of end of the section to copy to + * + * All addresses must be aligned to 4 bytes boundary. + */ + ldr r1, =__etext + ldr r2, =__data_start__ + ldr r3, =__data_end__ + +.L_loop1: + cmp r2, r3 + ittt lt + ldrlt r0, [r1], #4 + strlt r0, [r2], #4 + blt .L_loop1 +#endif /*__STARTUP_COPY_MULTIPLE */ + +/* This part of work usually is done in C library startup code. Otherwise, + * define this macro to enable it in this startup. + * + * There are two schemes too. One can clear multiple BSS sections. Another + * can only clear one section. The former is more size expensive than the + * latter. + * + * Define macro __STARTUP_CLEAR_BSS_MULTIPLE to choose the former. + * Otherwise efine macro __STARTUP_CLEAR_BSS to choose the later. + */ +#ifdef __STARTUP_CLEAR_BSS_MULTIPLE +/* Multiple sections scheme. + * + * Between symbol address __copy_table_start__ and __copy_table_end__, + * there are array of tuples specifying: + * offset 0: Start of a BSS section + * offset 4: Size of this BSS section. Must be multiply of 4 + */ + ldr r3, =__zero_table_start__ + ldr r4, =__zero_table_end__ + +.L_loop2: + cmp r3, r4 + bge .L_loop2_done + ldr r1, [r3] + ldr r2, [r3, #4] + movs r0, 0 + +.L_loop2_0: + subs r2, #4 + itt ge + strge r0, [r1, r2] + bge .L_loop2_0 + + adds r3, #8 + b .L_loop2 +.L_loop2_done: +#elif defined (__STARTUP_CLEAR_BSS) +/* Single BSS section scheme. + * + * The BSS section is specified by following symbols + * __bss_start__: start of the BSS section. + * __bss_end__: end of the BSS section. + * + * Both addresses must be aligned to 4 bytes boundary. + */ + ldr r1, =__bss_start__ + ldr r2, =__bss_end__ + + movs r0, 0 +.L_loop3: + cmp r1, r2 + itt lt + strlt r0, [r1], #4 + blt .L_loop3 +#endif /* __STARTUP_CLEAR_BSS_MULTIPLE || __STARTUP_CLEAR_BSS */ + +#ifndef __NO_SYSTEM_INIT + bl SystemInit +#endif + +#ifndef __START +#define __START _start +#endif + bl __START + + .pool + .size Reset_Handler, . - Reset_Handler + + .align 1 + .thumb_func + .weak Default_Handler + .type Default_Handler, %function +Default_Handler: + bkpt #0 + b . + .size Default_Handler, . - Default_Handler + +/* Macro to define default handlers. Default handler + * will be weak symbol and just dead loops. They can be + * overwritten by other handlers */ + .macro def_irq_handler handler_name + .weak \handler_name + .set \handler_name, Default_Handler + .endm + + def_irq_handler NMI_Handler + def_irq_handler HardFault_Handler + def_irq_handler MemManage_Handler + def_irq_handler BusFault_Handler + def_irq_handler UsageFault_Handler + def_irq_handler SVC_Handler + def_irq_handler DebugMon_Handler + def_irq_handler PendSV_Handler + def_irq_handler SysTick_Handler + + .end diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/startup_generic.S b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/startup_generic.S new file mode 100644 index 0000000..1826a78 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/startup_generic.S @@ -0,0 +1,62 @@ + +#if defined (__CC_ARM) + #if (defined (ARM_MATH_CM0)) + #include "ARMCC\startup_armv6-m.s" + #elif (defined (ARM_MATH_CM0P)) + #include "ARMCC\startup_armv6-m.s" + #elif (defined (ARM_MATH_CM3)) + #include "ARMCC\startup_armv7-m.s" + #elif (defined (ARM_MATH_CM4)) + #include "ARMCC\startup_armv7-m.s" + #elif (defined (ARM_MATH_CM7)) + #include "ARMCC\startup_armv7-m.s" + #elif (defined (ARM_MATH_ARMV8MBL)) + #include "ARMCC\startup_armv6-m.s" + #elif (defined (ARM_MATH_ARMV8MML)) + #include "ARMCC\startup_armv7-m.s" + #else + #error "No appropriate startup file found!" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if (defined (ARM_MATH_CM0)) + #include "ARMCLANG\startup_armv6-m.S" + #elif (defined (ARM_MATH_CM0P)) + #include "ARMCLANG\startup_armv6-m.S" + #elif (defined (ARM_MATH_CM3)) + #include "ARMCLANG\startup_armv7-m.S" + #elif (defined (ARM_MATH_CM4)) + #include "ARMCLANG\startup_armv7-m.S" + #elif (defined (ARM_MATH_CM7)) + #include "ARMCLANG\startup_armv7-m.S" + #elif (defined (ARM_MATH_ARMV8MBL)) + #include "ARMCLANG\startup_armv6-m.S" + #elif (defined (ARM_MATH_ARMV8MML)) + #include "ARMCLANG\startup_armv7-m.S" + #else + #error "No appropriate startup file found!" + #endif + +#elif defined (__GNUC__) + #if (defined (ARM_MATH_CM0)) + #include "GCC\startup_armv6-m.S" + #elif (defined (ARM_MATH_CM0P)) + #include "GCC\startup_armv6-m.S" + #elif (defined (ARM_MATH_CM3)) + #include "GCC\startup_armv7-m.S" + #elif (defined (ARM_MATH_CM4)) + #include "GCC\startup_armv7-m.S" + #elif (defined (ARM_MATH_CM7)) + #include "GCC\startup_armv7-m.S" + #elif (defined (ARM_MATH_ARMV8MBL)) + #include "GCC\startup_armv6-m.S" + #elif (defined (ARM_MATH_ARMV8MML)) + #include "GCC\startup_armv7-m.S" + #else + #error "No appropriate startup file found!" + #endif + +#else + #error "Compiler not supported!" +#endif + diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM0.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM0.c new file mode 100644 index 0000000..b272255 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM0.c @@ -0,0 +1,56 @@ +/**************************************************************************//** + * @file system_ARMCM0.c + * @brief CMSIS Device System Source File for + * ARMCM0 Device Series + * @version V5.00 + * @date 07. September 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ARMCM0.h" + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM23.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM23.c new file mode 100644 index 0000000..791ee34 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM23.c @@ -0,0 +1,82 @@ +/**************************************************************************//** + * @file system_ARMCM23.c + * @brief CMSIS Device System Source File for + * ARMCM23 Device Series + * @version V5.00 + * @date 21. October 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined (ARMCM23) + #include "ARMCM23.h" +#elif defined (ARMCM23_TZ) + #include "ARMCM23_TZ.h" + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #include "partition_ARMCM23.h" + #endif +#else + #error device not specified! +#endif + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + TZ_SAU_Setup(); +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM3.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM3.c new file mode 100644 index 0000000..2544c43 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM3.c @@ -0,0 +1,68 @@ +/**************************************************************************//** + * @file system_ARMCM3.c + * @brief CMSIS Device System Source File for + * ARMCM3 Device Series + * @version V5.00 + * @date 07. September 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ARMCM3.h" + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM33.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM33.c new file mode 100644 index 0000000..287119c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM33.c @@ -0,0 +1,99 @@ +/**************************************************************************//** + * @file system_ARMCM33.c + * @brief CMSIS Device System Source File for + * ARMCM33 Device Series + * @version V5.00 + * @date 02. November 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined (ARMCM33) + #include "ARMCM33.h" +#elif defined (ARMCM33_TZ) + #include "ARMCM33_TZ.h" + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #include "partition_ARMCM33.h" + #endif +#elif defined (ARMCM33_DSP_FP) + #include "ARMCM33_DSP_FP.h" +#elif defined (ARMCM33_DSP_FP_TZ) + #include "ARMCM33_DSP_FP_TZ.h" + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #include "partition_ARMCM33.h" + #endif +#else + #error device not specified! +#endif + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + +#if defined (__FPU_USED) && (__FPU_USED == 1U) + SCB->CPACR |= ((3U << 10U*2U) | /* set CP10 Full Access */ + (3U << 11U*2U) ); /* set CP11 Full Access */ +#endif + +#ifdef UNALIGNED_SUPPORT_DISABLE + SCB->CCR |= SCB_CCR_UNALIGN_TRP_Msk; +#endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + TZ_SAU_Setup(); +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM4.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM4.c new file mode 100644 index 0000000..cea212e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM4.c @@ -0,0 +1,83 @@ +/**************************************************************************//** + * @file system_ARMCM4.c + * @brief CMSIS Device System Source File for + * ARMCM4 Device Series + * @version V5.00 + * @date 07. September 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined (ARMCM4) + #include "ARMCM4.h" +#elif defined (ARMCM4_FP) + #include "ARMCM4_FP.h" +#else + #error device not specified! +#endif + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + +#if defined (__FPU_USED) && (__FPU_USED == 1U) + SCB->CPACR |= ((3U << 10U*2U) | /* set CP10 Full Access */ + (3U << 11U*2U) ); /* set CP11 Full Access */ +#endif + +#ifdef UNALIGNED_SUPPORT_DISABLE + SCB->CCR |= SCB_CCR_UNALIGN_TRP_Msk; +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM7.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM7.c new file mode 100644 index 0000000..6a99c08 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMCM7.c @@ -0,0 +1,85 @@ +/**************************************************************************//** + * @file system_ARMCM7.c + * @brief CMSIS Device System Source File for + * ARMCM7 Device Series + * @version V5.00 + * @date 07. September 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined (ARMCM7) + #include "ARMCM7.h" +#elif defined (ARMCM7_SP) + #include "ARMCM7_SP.h" +#elif defined (ARMCM7_DP) + #include "ARMCM7_DP.h" +#else + #error device not specified! +#endif + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + +#if defined (__FPU_USED) && (__FPU_USED == 1U) + SCB->CPACR |= ((3U << 10U*2U) | /* set CP10 Full Access */ + (3U << 11U*2U) ); /* set CP11 Full Access */ +#endif + +#ifdef UNALIGNED_SUPPORT_DISABLE + SCB->CCR |= SCB_CCR_UNALIGN_TRP_Msk; +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC000.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC000.c new file mode 100644 index 0000000..7fda345 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC000.c @@ -0,0 +1,56 @@ +/**************************************************************************//** + * @file system_ARMSC000.c + * @brief CMSIS Device System Source File for + * for ARMSC000 Device Series + * @version V5.00 + * @date 07. September 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ARMSC000.h" + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC300.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC300.c new file mode 100644 index 0000000..3db4ee7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMSC300.c @@ -0,0 +1,72 @@ +/**************************************************************************//** + * @file system_ARMSC300.c + * @brief CMSIS Device System Source File for + * ARMSC300 Device Series + * @version V5.00 + * @date 07. September 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ARMSC300.h" + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + +#ifdef UNALIGNED_SUPPORT_DISABLE + SCB->CCR |= SCB_CCR_UNALIGN_TRP_Msk; +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MBL.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MBL.c new file mode 100644 index 0000000..8310b8f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MBL.c @@ -0,0 +1,76 @@ +/**************************************************************************//** + * @file system_ARMv8MBL.c + * @brief CMSIS Device System Source File for + * ARMv8MBL Device Series + * @version V5.00 + * @date 07. September 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ARMv8MBL.h" + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #include "partition_ARMv8MBL.h" +#endif + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + TZ_SAU_Setup(); +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MML.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MML.c new file mode 100644 index 0000000..bd77100 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_ARMv8MML.c @@ -0,0 +1,99 @@ +/**************************************************************************//** + * @file system_ARMv8MML.c + * @brief CMSIS Device System Source File for + * ARMv8MML Device Series + * @version V5.00 + * @date 02. November 2016 + ******************************************************************************/ +/* + * Copyright (c) 2009-2016 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined (ARMv8MML) + #include "ARMv8MML.h" +#elif defined (ARMv8MML_DSP) + #include "ARMv8MML_DSP.h" +#elif defined (ARMv8MML_SP) + #include "ARMv8MML_SP.h" +#elif defined (ARMv8MML_DSP_SP) + #include "ARMv8MML_DSP_SP.h" +#elif defined (ARMv8MML_DP) + #include "ARMv8MML_DP.h" +#elif defined (ARMv8MML_DSP_DP) + #include "ARMv8MML_DSP_DP.h" +#else + #error device not specified! +#endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #include "partition_ARMv8MML.h" +#endif + +/*---------------------------------------------------------------------------- + Define clocks + *----------------------------------------------------------------------------*/ +#define XTAL ( 5000000UL) /* Oscillator frequency */ + +#define SYSTEM_CLOCK (5U * XTAL) + + +/*---------------------------------------------------------------------------- + Externals + *----------------------------------------------------------------------------*/ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + extern uint32_t __Vectors; +#endif + +/*---------------------------------------------------------------------------- + System Core Clock Variable + *----------------------------------------------------------------------------*/ +uint32_t SystemCoreClock = SYSTEM_CLOCK; + + +/*---------------------------------------------------------------------------- + System Core Clock update function + *----------------------------------------------------------------------------*/ +void SystemCoreClockUpdate (void) +{ + SystemCoreClock = SYSTEM_CLOCK; +} + +/*---------------------------------------------------------------------------- + System initialization function + *----------------------------------------------------------------------------*/ +void SystemInit (void) +{ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + SCB->VTOR = (uint32_t) &__Vectors; +#endif + +#if defined (__FPU_USED) && (__FPU_USED == 1U) + SCB->CPACR |= ((3U << 10U*2U) | /* set CP10 Full Access */ + (3U << 11U*2U) ); /* set CP11 Full Access */ +#endif + +#ifdef UNALIGNED_SUPPORT_DISABLE + SCB->CCR |= SCB_CCR_UNALIGN_TRP_Msk; +#endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + TZ_SAU_Setup(); +#endif + + SystemCoreClock = SYSTEM_CLOCK; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_generic.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_generic.c new file mode 100644 index 0000000..37d82ab --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/platform/system_generic.c @@ -0,0 +1,27 @@ + +#if (defined (ARMCM0)) + #include "system_ARMCM0.c" + +#elif (defined (ARMCM0P)) + #include "system_ARMCM0plus.c" + +#elif (defined (ARMCM3)) + #include "system_ARMCM3.c" + +#elif (defined (ARMCM4) || defined (ARMCM4_FP)) + #include "system_ARMCM4.c" + +#elif (defined (ARMCM7) || defined (ARMCM7_SP) || defined (ARMCM7_DP)) + #include "system_ARMCM7.c" + +#elif defined (ARMv8MBL) + #include "system_ARMv8MBL.c" + +#elif (defined (ARMv8MML) || defined (ARMv8MML_DSP) || \ + defined (ARMv8MML_SP) || defined (ARMv8MML_DSP_SP) || \ + defined (ARMv8MML_DP) || defined (ARMv8MML_DSP_DP) ) + #include "system_ARMv8MML.c" + +#else + #error "No appropriate system file found!" +#endif diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/all_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/all_tests.c new file mode 100644 index 0000000..7b7a8fd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/all_tests.c @@ -0,0 +1,30 @@ +#include "jtest.h" +#include "basic_math_test_group.h" +#include "complex_math_test_group.h" +#include "controller_test_group.h" +#include "fast_math_test_group.h" +#include "filtering_test_group.h" +#include "matrix_test_group.h" +#include "statistics_test_group.h" +#include "support_test_group.h" +#include "transform_test_group.h" +#include "intrinsics_test_group.h" + +JTEST_DEFINE_GROUP(all_tests) +{ + /* + To skip a test, comment it out + */ + JTEST_GROUP_CALL(basic_math_tests); + JTEST_GROUP_CALL(complex_math_tests); + JTEST_GROUP_CALL(controller_tests); + JTEST_GROUP_CALL(fast_math_tests); + JTEST_GROUP_CALL(filtering_tests); + JTEST_GROUP_CALL(matrix_tests); + JTEST_GROUP_CALL(statistics_tests); + JTEST_GROUP_CALL(support_tests); + JTEST_GROUP_CALL(transform_tests); + JTEST_GROUP_CALL(intrinsics_tests); + + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/abs_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/abs_tests.c new file mode 100644 index 0000000..6e6bedb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/abs_tests.c @@ -0,0 +1,32 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_ABS_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + abs, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix)) + +JTEST_ARM_ABS_TEST(f32); +JTEST_ARM_ABS_TEST(q31); +JTEST_ARM_ABS_TEST(q15); +JTEST_ARM_ABS_TEST(q7 ); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(abs_tests) +{ + JTEST_TEST_CALL(arm_abs_f32_test); + JTEST_TEST_CALL(arm_abs_q31_test); + JTEST_TEST_CALL(arm_abs_q15_test); + JTEST_TEST_CALL(arm_abs_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/add_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/add_tests.c new file mode 100644 index 0000000..a2d043c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/add_tests.c @@ -0,0 +1,33 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_ADD_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK( \ + add, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + BASIC_MATH_COMPARE_INTERFACE) + +JTEST_ARM_ADD_TEST(f32); +JTEST_ARM_ADD_TEST(q31); +JTEST_ARM_ADD_TEST(q15); +JTEST_ARM_ADD_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(add_tests) +{ + JTEST_TEST_CALL(arm_add_f32_test); + JTEST_TEST_CALL(arm_add_q31_test); + JTEST_TEST_CALL(arm_add_q15_test); + JTEST_TEST_CALL(arm_add_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_common_data.c new file mode 100644 index 0000000..86728f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_common_data.c @@ -0,0 +1,101 @@ +#include "basic_math_test_data.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(BASIC_MATH_BIGGEST_INPUT_TYPE, + basic_math_output_fut, + BASIC_MATH_MAX_INPUT_ELEMENTS, + CURLY(0)); + +ARR_DESC_DEFINE(BASIC_MATH_BIGGEST_INPUT_TYPE, + basic_math_output_ref, + BASIC_MATH_MAX_INPUT_ELEMENTS, + CURLY(0)); + +BASIC_MATH_BIGGEST_INPUT_TYPE +basic_math_output_f32_ref[BASIC_MATH_MAX_INPUT_ELEMENTS]; + +BASIC_MATH_BIGGEST_INPUT_TYPE +basic_math_output_f32_fut[BASIC_MATH_MAX_INPUT_ELEMENTS]; + +/*--------------------------------------------------------------------------------*/ +/* Block Sizes */ +/*--------------------------------------------------------------------------------*/ + +/* + To change test parameter values add/remove values inside CURLY and update + the preceeding parameter to reflect the number of values inside CURLY. +*/ + +ARR_DESC_DEFINE(uint32_t, + basic_math_block_sizes, + 4, + CURLY( 2, 7, 15, 32)); + +/*--------------------------------------------------------------------------------*/ +/* Numbers */ +/*--------------------------------------------------------------------------------*/ + +/* + To change test parameter values add/remove values inside CURLY and update + the preceeding parameter to reflect the number of values inside CURLY. +*/ + +ARR_DESC_DEFINE(uint32_t, + basic_math_elts, + 4, + CURLY( 0, 1, 0x80000000, 0x7fffffff)); + +ARR_DESC_DEFINE(int8_t, + basic_math_elts2, + 5, + CURLY( 0, 3, -3, -7, 7)); + +ARR_DESC_DEFINE(float32_t, + basic_math_eltsf, + 6, + CURLY( 0.0f, 1.0f, 1.254001, -1.665584, -127.435646, 245.34634267)); + +/*--------------------------------------------------------------------------------*/ +/* Test Data */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(float32_t, + basic_math_f_32, + 32, + CURLY( + -0.432565, -1.665584, 0.125332, 0.287676, -1.146471, + 1.190915, 1.189164, -0.037633, 0.327292, 0.174639, + -0.186709, 0.725791, -0.588317, 2.183186, -0.136396, + 0.113931, 1.066768, 0.059281, -0.095648, -0.832349, + 0.294411, -1.336182, 0.714325, 1.623562, -0.691776, + 0.857997, 1.254001, -1.593730, -1.440964, 0.571148, + -0.399886, 0.689997 + )); + +/* Alias the 32 element array with wrappers that end sooner. */ +ARR_DESC_DEFINE_SUBSET(basic_math_f_15, + basic_math_f_32, + 15); + +ARR_DESC_DEFINE_SUBSET(basic_math_f_2, + basic_math_f_32, + 2); + +ARR_DESC_DEFINE(float32_t, + basic_math_zeros, + 32, + CURLY(0)); + +/* Aggregate all float datasets. */ +ARR_DESC_DEFINE(ARR_DESC_t *, + basic_math_f_all, + 4, + CURLY( + &basic_math_zeros, + &basic_math_f_2, + &basic_math_f_15, + &basic_math_f_32 + )); diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_group.c new file mode 100644 index 0000000..7b219fe --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/basic_math_test_group.c @@ -0,0 +1,17 @@ +#include "jtest.h" +#include "basic_math_tests.h" + +JTEST_DEFINE_GROUP(basic_math_tests) +{ + JTEST_GROUP_CALL(abs_tests); + JTEST_GROUP_CALL(add_tests); + JTEST_GROUP_CALL(dot_prod_tests); + JTEST_GROUP_CALL(mult_tests); + JTEST_GROUP_CALL(negate_tests); + JTEST_GROUP_CALL(offset_tests); + JTEST_GROUP_CALL(scale_tests); + JTEST_GROUP_CALL(shift_tests); + JTEST_GROUP_CALL(sub_tests); + + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/dot_prod_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/dot_prod_tests.c new file mode 100644 index 0000000..ed758a1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/dot_prod_tests.c @@ -0,0 +1,33 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_DOT_PROD_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK( \ + dot_prod, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + BASIC_MATH_SNR_ELT1_COMPARE_INTERFACE) + +JTEST_ARM_DOT_PROD_TEST(f32); +JTEST_ARM_DOT_PROD_TEST(q31); +JTEST_ARM_DOT_PROD_TEST(q15); +JTEST_ARM_DOT_PROD_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(dot_prod_tests) +{ + JTEST_TEST_CALL(arm_dot_prod_f32_test); + JTEST_TEST_CALL(arm_dot_prod_q31_test); + JTEST_TEST_CALL(arm_dot_prod_q15_test); + JTEST_TEST_CALL(arm_dot_prod_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/mult_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/mult_tests.c new file mode 100644 index 0000000..a94bf68 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/mult_tests.c @@ -0,0 +1,33 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MULT_TEST(suffix, compare_interface) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK( \ + mult, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + compare_interface) + +JTEST_ARM_MULT_TEST(f32, BASIC_MATH_COMPARE_INTERFACE); +JTEST_ARM_MULT_TEST(q31, BASIC_MATH_SNR_COMPARE_INTERFACE); +JTEST_ARM_MULT_TEST(q15, BASIC_MATH_COMPARE_INTERFACE); +JTEST_ARM_MULT_TEST(q7 , BASIC_MATH_COMPARE_INTERFACE); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mult_tests) +{ + JTEST_TEST_CALL(arm_mult_f32_test); + JTEST_TEST_CALL(arm_mult_q31_test); + JTEST_TEST_CALL(arm_mult_q15_test); + JTEST_TEST_CALL(arm_mult_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/negate_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/negate_tests.c new file mode 100644 index 0000000..276cdac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/negate_tests.c @@ -0,0 +1,32 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_NEGATE_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + negate, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix)) + +JTEST_ARM_NEGATE_TEST(f32); +JTEST_ARM_NEGATE_TEST(q31); +JTEST_ARM_NEGATE_TEST(q15); +JTEST_ARM_NEGATE_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(negate_tests) +{ + JTEST_TEST_CALL(arm_negate_f32_test); + JTEST_TEST_CALL(arm_negate_q31_test); + JTEST_TEST_CALL(arm_negate_q15_test); + JTEST_TEST_CALL(arm_negate_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/offset_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/offset_tests.c new file mode 100644 index 0000000..4e10f78 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/offset_tests.c @@ -0,0 +1,33 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_OFFSET_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_ELT1_BLK( \ + offset, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix)) + +JTEST_ARM_OFFSET_TEST(f32); +JTEST_ARM_OFFSET_TEST(q31); +JTEST_ARM_OFFSET_TEST(q15); +JTEST_ARM_OFFSET_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(offset_tests) +{ + JTEST_TEST_CALL(arm_offset_f32_test); + JTEST_TEST_CALL(arm_offset_q31_test); + JTEST_TEST_CALL(arm_offset_q15_test); + JTEST_TEST_CALL(arm_offset_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/scale_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/scale_tests.c new file mode 100644 index 0000000..2839a8f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/scale_tests.c @@ -0,0 +1,52 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + + +#define JTEST_ARM_SCALE_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_ELT2_BLK( \ + scale, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), /*elt1_type*/ \ + int8_t, /*elt2_type*/ \ + TYPE_FROM_ABBREV(suffix)) + +/* float32_t defined separately because it has less arguments */ +JTEST_DEFINE_TEST(arm_scale_f32_test, + arm_scale_f32) +{ + TEST_TEMPLATE_BUF1_ELT1_BLK( + basic_math_f_all, + basic_math_eltsf, + basic_math_block_sizes, + float32_t, + float32_t, + float32_t, + arm_scale_f32, + ARM_scale_float_INPUT_INTERFACE, + ref_scale_f32, + REF_scale_float_INPUT_INTERFACE, + BASIC_MATH_COMPARE_INTERFACE); +} + +JTEST_ARM_SCALE_TEST(q31); +JTEST_ARM_SCALE_TEST(q15); +JTEST_ARM_SCALE_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(scale_tests) +{ + JTEST_TEST_CALL(arm_scale_f32_test); + JTEST_TEST_CALL(arm_scale_q31_test); + JTEST_TEST_CALL(arm_scale_q15_test); + JTEST_TEST_CALL(arm_scale_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/shift_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/shift_tests.c new file mode 100644 index 0000000..ed83b63 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/shift_tests.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_SHIFT_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF1_ELT1_BLK( \ + shift, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + int8_t, /*elt_type*/ \ + TYPE_FROM_ABBREV(suffix)) + +JTEST_ARM_SHIFT_TEST(q31); +JTEST_ARM_SHIFT_TEST(q15); +JTEST_ARM_SHIFT_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(shift_tests) +{ + JTEST_TEST_CALL(arm_shift_q31_test); + JTEST_TEST_CALL(arm_shift_q15_test); + JTEST_TEST_CALL(arm_shift_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/sub_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/sub_tests.c new file mode 100644 index 0000000..a486842 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/basic_math_tests/sub_tests.c @@ -0,0 +1,33 @@ +#include "jtest.h" +#include "basic_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "basic_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_SUB_TEST(suffix) \ + BASIC_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK( \ + sub, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + BASIC_MATH_COMPARE_INTERFACE) + +JTEST_ARM_SUB_TEST(f32); +JTEST_ARM_SUB_TEST(q31); +JTEST_ARM_SUB_TEST(q15); +JTEST_ARM_SUB_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(sub_tests) +{ + JTEST_TEST_CALL(arm_sub_f32_test); + JTEST_TEST_CALL(arm_sub_q31_test); + JTEST_TEST_CALL(arm_sub_q15_test); + JTEST_TEST_CALL(arm_sub_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_conj_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_conj_tests.c new file mode 100644 index 0000000..7fcc0bc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_conj_tests.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "complex_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "complex_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_CMPLX_CONJ_TEST(suffix) \ + COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + cmplx_conj, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + COMPLEX_MATH_SNR_COMPARE_CMPLX_INTERFACE) + +JTEST_ARM_CMPLX_CONJ_TEST(f32); +JTEST_ARM_CMPLX_CONJ_TEST(q31); +JTEST_ARM_CMPLX_CONJ_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cmplx_conj_tests) +{ + JTEST_TEST_CALL(arm_cmplx_conj_f32_test); + JTEST_TEST_CALL(arm_cmplx_conj_q31_test); + JTEST_TEST_CALL(arm_cmplx_conj_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_dot_prod_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_dot_prod_tests.c new file mode 100644 index 0000000..bcdaf5b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_dot_prod_tests.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "complex_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "complex_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_CMPLX_DOT_PROD_TEST(suffix, comparison_interface) \ + COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK( \ + cmplx_dot_prod, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + comparison_interface) + +JTEST_ARM_CMPLX_DOT_PROD_TEST(f32, COMPLEX_MATH_SNR_COMPARE_SPLIT_INTERFACE); +JTEST_ARM_CMPLX_DOT_PROD_TEST(q31, COMPLEX_MATH_SNR_COMPARE_SPLIT_INTERFACE); +JTEST_ARM_CMPLX_DOT_PROD_TEST(q15, COMPLEX_MATH_SNR_COMPARE_SPLIT_INTERFACE); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cmplx_dot_prod_tests) +{ + JTEST_TEST_CALL(arm_cmplx_dot_prod_f32_test); + JTEST_TEST_CALL(arm_cmplx_dot_prod_q31_test); + JTEST_TEST_CALL(arm_cmplx_dot_prod_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_squared_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_squared_tests.c new file mode 100644 index 0000000..9ca11fc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_squared_tests.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "complex_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "complex_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_CMPLX_MAG_SQUARED_TEST(suffix) \ + COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + cmplx_mag_squared, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + COMPLEX_MATH_COMPARE_RE_INTERFACE) + +JTEST_ARM_CMPLX_MAG_SQUARED_TEST(f32); +JTEST_ARM_CMPLX_MAG_SQUARED_TEST(q31); +JTEST_ARM_CMPLX_MAG_SQUARED_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cmplx_mag_squared_tests) +{ + JTEST_TEST_CALL(arm_cmplx_mag_squared_f32_test); + JTEST_TEST_CALL(arm_cmplx_mag_squared_q31_test); + JTEST_TEST_CALL(arm_cmplx_mag_squared_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_tests.c new file mode 100644 index 0000000..8711957 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mag_tests.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "complex_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "complex_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_CMPLX_MAG_TEST(suffix, comparison_interface) \ + COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + cmplx_mag, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + comparison_interface) + +JTEST_ARM_CMPLX_MAG_TEST(f32, COMPLEX_MATH_COMPARE_RE_INTERFACE); +JTEST_ARM_CMPLX_MAG_TEST(q31, COMPLEX_MATH_SNR_COMPARE_RE_INTERFACE); +JTEST_ARM_CMPLX_MAG_TEST(q15, COMPLEX_MATH_SNR_COMPARE_RE_INTERFACE); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cmplx_mag_tests) +{ + JTEST_TEST_CALL(arm_cmplx_mag_f32_test); + JTEST_TEST_CALL(arm_cmplx_mag_q31_test); + JTEST_TEST_CALL(arm_cmplx_mag_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_cmplx_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_cmplx_tests.c new file mode 100644 index 0000000..22c5a70 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_cmplx_tests.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "complex_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "complex_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_CMPLX_MULT_CMPLX_TEST(suffix) \ + COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK( \ + cmplx_mult_cmplx, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + COMPLEX_MATH_COMPARE_CMPLX_INTERFACE) + +JTEST_ARM_CMPLX_MULT_CMPLX_TEST(f32); +JTEST_ARM_CMPLX_MULT_CMPLX_TEST(q31); +JTEST_ARM_CMPLX_MULT_CMPLX_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cmplx_mult_cmplx_tests) +{ + JTEST_TEST_CALL(arm_cmplx_mult_cmplx_f32_test); + JTEST_TEST_CALL(arm_cmplx_mult_cmplx_q31_test); + JTEST_TEST_CALL(arm_cmplx_mult_cmplx_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_real_test.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_real_test.c new file mode 100644 index 0000000..fce7b82 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/cmplx_mult_real_test.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "complex_math_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "complex_math_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_CMPLX_MULT_REAL_TEST(suffix, comparison_interface) \ + COMPLEX_MATH_DEFINE_TEST_TEMPLATE_BUF2_BLK( \ + cmplx_mult_real, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + comparison_interface) + +JTEST_ARM_CMPLX_MULT_REAL_TEST(f32, COMPLEX_MATH_COMPARE_CMPLX_INTERFACE); +JTEST_ARM_CMPLX_MULT_REAL_TEST(q31, COMPLEX_MATH_SNR_COMPARE_CMPLX_INTERFACE); +JTEST_ARM_CMPLX_MULT_REAL_TEST(q15, COMPLEX_MATH_COMPARE_CMPLX_INTERFACE); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cmplx_mult_real_tests) +{ + JTEST_TEST_CALL(arm_cmplx_mult_real_f32_test); + JTEST_TEST_CALL(arm_cmplx_mult_real_q31_test); + JTEST_TEST_CALL(arm_cmplx_mult_real_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_common_data.c new file mode 100644 index 0000000..396dc2f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_common_data.c @@ -0,0 +1,114 @@ +#include "complex_math_test_data.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(COMPLEX_MATH_BIGGEST_INPUT_TYPE, + complex_math_output_fut_a, + COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2 /*Complex data has two parts*/, + CURLY(0)); + +ARR_DESC_DEFINE(COMPLEX_MATH_BIGGEST_INPUT_TYPE, + complex_math_output_fut_b, + COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2 /*Complex data has two parts*/, + CURLY(0)); + +ARR_DESC_DEFINE(COMPLEX_MATH_BIGGEST_INPUT_TYPE, + complex_math_output_ref_a, + COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2 /*Complex data has two parts*/, + CURLY(0)); + + +ARR_DESC_DEFINE(COMPLEX_MATH_BIGGEST_INPUT_TYPE, + complex_math_output_ref_b, + COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2 /*Complex data has two parts*/, + CURLY(0)); + + +COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_ref_a[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_ref_b[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_fut_a[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +COMPLEX_MATH_BIGGEST_INPUT_TYPE +complex_math_output_f32_fut_b[COMPLEX_MATH_MAX_INPUT_ELEMENTS * 2]; + +/*--------------------------------------------------------------------------------*/ +/* Block Sizes */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(uint32_t, + complex_math_block_sizes, + 4, + CURLY(1, 2, 15, 32)); + +/*--------------------------------------------------------------------------------*/ +/* Test Data */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(float32_t, + complex_math_f_32, + 32 * 2 /*Complex data has two parts*/, + CURLY( + -0.432564811528220680 , 0.815622288876143300, + -1.665584378238097000 , 0.711908323500893280, + 0.125332306474830680 , 1.290249754932477000, + 0.287676420358548850 , 0.668600505682040320, + -1.146471350681463700 , 1.190838074243369100, + 1.190915465642998800 , -1.202457114773944000, + 1.189164201652103100 , -0.019789557768770449, + -0.037633276593317645 , -0.156717298831980680, + 0.327292361408654140 , -1.604085562001158500, + 0.174639142820924520 , 0.257304234677489860, + -0.186708577681439360 , -1.056472928081482400, + 0.725790548293302700 , 1.415141485872338600, + -0.588316543014188680 , -0.805090404196879830, + 2.183185818197101100 , 0.528743010962224870, + -0.136395883086595700 , 0.219320672667622370, + 0.113931313520809620 , -0.921901624355539130, + 1.066768211359188800 , -2.170674494305262500, + 0.059281460523605348 , -0.059187824521191180, + -0.095648405483669041 , -1.010633706474247400, + -0.832349463650022490 , 0.614463048895480980, + 0.294410816392640380 , 0.507740785341985520, + -1.336181857937804000 , 1.692429870190521400, + 0.714324551818952160 , 0.591282586924175900, + 1.623562064446270700 , -0.643595202682526120, + -0.691775701702286750 , 0.380337251713910140, + 0.857996672828262640 , -1.009115524340785000, + 1.254001421602532400 , -0.019510669530289293, + -1.593729576447476800 , -0.048220789145312269, + -1.440964431901020000 , 0.000043191841625545, + 0.571147623658177950 , -0.317859451247687890, + -0.399885577715363150 , 1.095003738787492500, + 0.689997375464345140 , -1.873990257640960800 + )); + +ARR_DESC_DEFINE_SUBSET(complex_math_f_15, + complex_math_f_32, + 15 * 2 /*Complex data has two parts*/); + +ARR_DESC_DEFINE_SUBSET(complex_math_f_2, + complex_math_f_32, + 2 * 2 /*Complex data has two parts*/); + +ARR_DESC_DEFINE(float32_t, + complex_math_zeros, + 32 * 2 /*Complex data has two parts*/, + CURLY(0)); + +/* Aggregate all float datasets */ +ARR_DESC_DEFINE(ARR_DESC_t *, + complex_math_f_all, + 4, + CURLY( + &complex_math_zeros, + &complex_math_f_2, + &complex_math_f_15, + &complex_math_f_32 + )); diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_group.c new file mode 100644 index 0000000..38546fb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/complex_math_tests/complex_math_test_group.c @@ -0,0 +1,14 @@ +#include "jtest.h" +#include "complex_math_tests.h" + +JTEST_DEFINE_GROUP(complex_math_tests) +{ + JTEST_GROUP_CALL(cmplx_conj_tests); + JTEST_GROUP_CALL(cmplx_dot_prod_tests); + JTEST_GROUP_CALL(cmplx_mag_tests); + JTEST_GROUP_CALL(cmplx_mag_squared_tests); + JTEST_GROUP_CALL(cmplx_mult_cmplx_tests); + JTEST_GROUP_CALL(cmplx_mult_real_tests); + + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_common_data.c new file mode 100644 index 0000000..661a487 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_common_data.c @@ -0,0 +1,499 @@ +#include "controller_test_data.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +float32_t controller_output_fut[CONTROLLER_MAX_LEN] = {0}; +float32_t controller_output_ref[CONTROLLER_MAX_LEN] = {0}; +float32_t controller_output_f32_fut[CONTROLLER_MAX_LEN] = {0}; +float32_t controller_output_f32_ref[CONTROLLER_MAX_LEN] = {0}; + +const q31_t controller_q31_inputs[CONTROLLER_MAX_LEN] = +{ + 0xC14A5524, 0xCCABDA17, 0xAD6F5B56, 0xFDAFCE3B, 0xA9B226EB, 0x41F6F6A, + 0xA5CE38BF, 0x3A978AFA, 0xBA44B82A, 0x855C0F8, 0x3D060524, 0x93D5E570, + 0x97D7791D, 0xFFE0C38C, 0x26749841, 0xC0A6EE54, 0x218EC386, 0x39FF3726, + 0x8DC1F7CA, 0x702F2CF5, 0xC1142FF1, 0xEC1476AB, 0x15F640DD, 0xE62CCE49, + 0x3805DE7E, 0xF70871FE, 0xCF8BD360, 0x8D19A8A0, 0xD764F821, 0xA58558CF, + 0x8C0CE04D, 0x50A46C19, 0x66D2370D, 0x50FA359A, 0xB646AE24, 0x6CE00F5C, + 0xE6D48948, 0xB55BD831, 0x3B72950A, 0x9EB69530, 0x73394127, 0x773FA6F4, + 0x9805A980, 0x838DE587, 0x9CF597F4, 0xA2AD1691, 0xFA81A473, 0x7CDC7D7F, + 0x4A5190D0, 0xED895BB9, 0x8FD60F35, 0x1A21D530, 0xA0EB6DDA, 0xBDE6A516, + 0x2501A3E1, 0x5ED893C8, 0xE1E175B1, 0xACBBB2F3, 0xED350907, 0xDB140D7E, + 0xEEAE272D, 0xBE229841, 0xC18BFB88, 0xA6BB9B80, 0xBCF090E4, 0x24DB166C, + 0xF9AB7E42, 0x62DF28D1, 0xC7004665, 0xE3F56FC6, 0x419E0C75, 0x46BE9F38, + 0x2432B9B2, 0x758D83E0, 0xDCE12926, 0x3F57CB74, 0x1F4458E2, 0xF1DD639, + 0x83A1FB49, 0x173AFC76, 0x86EF7531, 0x48D32F34, 0x7D3E3063, 0x8F2FB549, + 0x5C314C9, 0x18CBEB6D, 0xA6F8B697, 0x447B9E9C, 0x2E32BA33, 0xD074D715, + 0x81ACD746, 0xE55A4E04, 0x4891860F, 0x1DA3EB4F, 0xE0E6A27F, 0x20BFDEB4, + 0xD0B3A25B, 0x40C10544, 0xC15656C, 0x15405EAE, 0x9858E3E1, 0xA36A9C4E, + 0x88BD21F9, 0xAACF7A68, 0x773665E5, 0xCEDFDF66, 0x617A9610, 0x524FC968, + 0xC2D086CD, 0x5F008079, 0x24DCA447, 0x6A4F5599, 0xB706CD4A, 0x1DE70608, + 0xA33A2EE5, 0x137E488E, 0x98061B7B, 0x4079D69D, 0xA4A897D5, 0xC4CEC8F5, + 0xD75F7883, 0x22406802, 0xF1AD70BB, 0x9D4ADD79, 0xBCBC7CE4, 0xB358C0D8, + 0x85792E47, 0xA7ADAC05, 0x3D19EEAB, 0x331AC0AF, 0x33035831, 0x13D93987, + 0xFC542094, 0x845F317E, 0xDDC4BF8B, 0x1379E50C, 0x5C20193F, 0xFDD58298, + 0x9D482B82, 0x4A6BE062, 0xDC8A757B, 0x272917C1, 0x90E1EFBC, 0x355AD882, + 0xE6F8EA35, 0x604555A1, 0x7DFFFBB, 0xF58AE216, 0x9A11B463, 0xD3541BAD, + 0xA1576756, 0x483BED8D, 0x1F05AFCC, 0xCEA63DFB, 0x55B84677, 0xFB2E04F2, + 0x787AF96C, 0x84A12CD3, 0x460A9BD, 0x9DB22DD8, 0x1A8C7F28, 0x861E452E, + 0x932D3F78, 0x7652D852, 0x73357BBA, 0xEBBB0A58, 0x62536AFA, 0x3F6B65EF, + 0x6DC57B58, 0x9EB798CE, 0xE6B0A740, 0xDFF68B47, 0x3247FB8F, 0xFFF3D302, + 0xA9FD3E40, 0x475A43D1, 0x6FF9528A, 0x2018A09D, 0x47E0F9C9, 0x4CF5F6D3, + 0x2807CE34, 0xDD6FD8ED, 0x234045D1, 0x51CEB5F9, 0x25297896, 0x6443A0FE, + 0x8F4449A9, 0xD4C3E1C6, 0xF01D52F1, 0x4E09C820, 0xF18F0810, 0xE1548689, + 0xF9DE5A1F, 0x5286DC23, 0x48AC3A4B, 0xEA0C1BE0, 0xA1B785DB, 0x7086465D, + 0x1CC10929, 0x1E1D716E, 0xED231D4C, 0x2049D108, 0xB8FF9971, 0x949CF8D4, + 0x441F1E8B, 0xC3D95372, 0x69C324B4, 0xA10BFDC9, 0xC781DE78, 0x82476137, + 0xE163DDF, 0x390DEEC2, 0xAF68CE5B, 0x8E680ABD, 0x8223A615, 0x92593380, + 0x7B1465FE, 0x865AE957, 0x930F53EB, 0xED772EF7, 0x10E916B6, 0xE3BCFA68, + 0x2ACB80BB, 0xE51C5590, 0x994714B5, 0xF30984EE, 0x59BBE1B4, 0xB4867DBC, + 0xB91C706C, 0xBC16C218, 0xA8931CD0, 0x129A66AB, 0x13171F4D, 0x62882872, + 0x4B167FD4, 0xE6902F4C, 0xFA794932, 0xD4B152C, 0xB0856EA9, 0x39466D55, + 0x3669E451, 0x8F5B9E8C, 0x877A3C6A, 0x51B956B4, 0x367EAD2A, 0x9D2C662A, + 0x78FB6880, 0x4E6D40B6, 0x4070EFDC, 0x4DF9679C, 0x20306EDB, 0xE381AAE7, + 0xA55DA748, 0x9B8B617B, 0x3E036FAD, 0x84E4C4A7, 0xD5A3F517, 0x669BA988, + 0x98FDDE8C, 0x67BD85CE, 0x34BBB46C, 0x76994800, 0x85B9D8B6, 0x6DFA2FEF, + 0x205DB5C, 0x9F843C4C, 0x72721B52, 0x73EF6B86, 0x5FB98B61, 0xC323DDAC, + 0x31D424B4, 0xF68C0D7E, 0x162FAF9D, 0x7B2A7A99, 0xF9392693, 0xC42D12C0, + 0x8692A73E, 0xD9A1EE80, 0xDD956856, 0x44E7BDAC, 0x8D874532, 0x5F5C9DD0, + 0x5D167858, 0x8559FEA2, 0x9D821476, 0xD9654ED2, 0x594C0DC7, 0x1A87B506, + 0x3F693200, 0x7A651AB5, 0xA0CCBC8A, 0x9F9E662C, 0x78EF631, 0x2A09DA0, + 0xB088C72F, 0x92EE0D42, 0x360DCD5F, 0xF333FE48, 0x8D63CC06, 0x233A8ACB, + 0x706651ED, 0x7AA5C079, 0x262239D1, 0x3EBBEBB6, 0xA25A4F3D, 0x32581A06, + 0x6E6FD780, 0x5773F7C7, 0x75ED1DDC, 0x90DF2D15, 0xBC79A9BC, 0xB7175917, + 0x354E381C, 0x762AADD7, 0xF643DAC1, 0xF3BBF49E, 0xD2FECE7E, 0x6C8140F4, + 0xD7694875, 0x92D30822, 0xC742A7CF, 0xB792ED98, 0x121CFE24, 0xA04E1EE7, + 0x58CE268, 0x215A080, 0x316CB323, 0xFAB14A31, 0xE1C13C03, 0xFD8EF4F1, + 0xF3F446D0, 0x6C6CEA0A, 0xBBFDF9FB, 0x67242969, 0xBE55A4EB, 0x8FF5534, + 0x52F0DF1C, 0x9710ADE3, 0xD40F4A21, 0x7984E8E7, 0x419545EB, 0x993F7880, + 0xAB246B20, 0x408AABC4, 0xCBF6EA49, 0xC0894C55, 0x4CAA6398, 0xA47856E9, + 0xAF2AE47D, 0x22F55D33, 0xF0D37915, 0xD0634C72, 0xD983671, 0x2BCC5AF8, + 0x9A77D48, 0xC11B5CFA, 0xF107CD7E, 0x3A6B3593, 0xE1425F05, 0x6271812A, + 0x5B838310, 0xBD8418CA, 0x10A58792, 0x239F7137, 0xA13D5071, 0x7F9930D4, + 0xA462664F, 0x54180F8E, 0x291585BA, 0xE586B87A, 0x144B2C12, 0x98E425C7, + 0xBAA4B373, 0x18F0D03C, 0x99462AC0, 0xD8B4D2EF, 0x72473895, 0xA6BF5435, + 0xEDAD53B, 0xE0912FA6, 0x5C33F331, 0x3D93CD7, 0x4D03D752, 0x20699929, + 0xB89962F9, 0x36E781E9, 0xF58B642C, 0x5FCA69E3, 0x5960A7F4, 0xAD5AAFD0, + 0xDF18324A, 0x3DB1E5AA, 0x76BA3876, 0x1BC29AF6, 0xBCC18841, 0x73A60174, + 0x625BFF58, 0x67C57724, 0x4458E53C, 0xE157B095, 0x2B370837, 0x83DF6CE3, + 0xDD08EEFA, 0x3F52A7C2, 0x191B4785, 0x60843D82, 0xB0DE11F1, 0x105EA26C, + 0x6E1C7AA2, 0x47AADD14, 0xB6676D03, 0x3B8D4DF6, 0x737A694, 0x409521DC, + 0x744206A, 0xC722023F, 0x2BE4EAD5, 0x63E11D76, 0xCA4A09AB, 0x5CF2D2B9, + 0x31586916, 0xCDFD7D84, 0xB203F634, 0xAD7329D4, 0xC524582F, 0x2E53E6C1, + 0xBB0E019B, 0xB8538C6A, 0x6A2542D, 0x8A6A00E5, 0x119725CC, 0x5406D347, + 0x1B6FFAF1, 0xECCF71F1, 0x981117F2, 0x7167CA76, 0x74F4B880, 0x77A55F47, + 0x59EADB62, 0x4A331D95, 0xBCBBA76F, 0xA45C4D50, 0xC718D5, 0x87CE05D1, + 0x60D47AD5, 0xA5CA9C40, 0xB0061766, 0xE69B39DF, 0xBD5F1320, 0x9930EAD3, + 0xA8B38325, 0x8DD090F, 0x6A6EEF37, 0x2DF16F66, 0xAB514C7E, 0x31109C58, + 0xFD48C7FC, 0x515341CA, 0x77AB8EA6, 0x41328DAF, 0xBAF8D31E, 0xA4B31611, + 0xED37F331, 0x7A832A22, 0xA22591C7, 0x722D1F89, 0x3B19CF18, 0x261B8A4D, + 0xC3F6F6DB, 0xCF8CED61, 0x990FA250, 0xA02E72A9, 0x560DCEA2, 0xB08E67B4, + 0x3674E663, 0x97CC3852, 0xA7EB2EAC, 0xFFDE0AA8, 0xA64719A, 0x23269EDD, + 0x3C0B339E, 0x86284D40, 0x48D82ECB, 0xA4D4CCF8, 0x43631B91, 0x4BF0C248, + 0xB6497B9B, 0x6827BC58, 0xE30B7AF9, 0xA0CCBF26, 0x6C3B7B71, 0xD744B3ED, + 0xFA25D2F6, 0x4CDE642D, 0xD65B8142, 0xA6F9207F, 0xE7A207BE, 0xDB506684, + 0x44DA4780, 0x9175EA0C, 0x156104AF, 0x4155E1B0, 0x6E3A6886, 0x9DBA1EA2, + 0x5423D9C8, 0xCC024E22, 0x758F852A, 0x1DD6395, 0x2D19CBAD, 0xE164F5A1, + 0xC2084602, 0x89C274AD, 0x13CB5562, 0xD7FE2D5B, 0xE07A4EE5, 0x1672BA91, + 0x4F624CCF, 0x2E5EA4A3, 0x28FEEFAF, 0xBDDA6EF4, 0x32AFD40C, 0x99A5FB3B, + 0xDD1D73A3, 0xA342CB3E, 0xA78445F5, 0x53979C3B, 0x427D7943, 0x5221B58C, + 0xA6CE9A5E, 0xFB50ECA4, 0xBB86E36E, 0x60839F6D, 0xC5E1C2F3, 0xA1B7FB04, + 0xFBB65E0C, 0x78B80F5E, 0xFD8D972B, 0x3BF3BA90, 0x2D572D9, 0x2B5BC920, + 0xB6A0DE01, 0xD274D306, 0xC7C6C855, 0x9CAA669B, 0xB04AA641, 0x4D6B1760, + 0x3E17ED79, 0xD23241B0, 0xA4A6F957, 0xCBDE76AF, 0x4E5F9493, 0x4C215DA5, + 0x33A052B, 0x1A4D80C2, 0x40AEEBCA, 0x390D106B, 0xE9E8E018, 0x5AF3D6CF, + 0xE35E1D4, 0xC4FB1C6, 0x14B6299B, 0x8D2E25F0, 0xCCBF932A, 0xC5AC18B6, + 0x2227567D, 0x86B5CE2F, 0x26344534, 0x22C515EC, 0x2442B70D, 0xEC3721C6, + 0x34EF687D, 0x9C06323A, 0xEAF3EA60, 0x60396F52, 0xEAE78AA1, 0xC9D06CBC, + 0x6F95F6C8, 0x584CC258, 0xBA9A27BB, 0x66DF8D47, 0x9D4804EA, 0x57DD9E67, + 0xF89C7895, 0xF5336111, 0x25C122C8, 0x62742114, 0xCFBF6D26, 0xBF9F6482, + 0xE6F02CD9, 0x11083202, 0xC99E2618, 0x7EBC9351, 0x440112F1, 0xC9DFFBC1, + 0x3BF4DC25, 0xB1BA7FA0, 0x61AF9AED, 0x6B1F7D29, 0xAD865294, 0xE3E01129, + 0x7E9E77A5, 0x100435D7, 0x9FE3A71, 0x88597C81, 0x722849FA, 0x31C5A0AF, + 0xFBA178DC, 0x7F102D31, 0x5CA07864, 0x950E6F98, 0x82C34882, 0x5D041F11, + 0x8C613C57, 0xD398CFD1, 0x426F38AD, 0x5599AB1D, 0xFAFA078D, 0xAB25B413, + 0xD94B32CF, 0xB288FE38, 0x2893BB46, 0x9A0B4168, 0xA91BCA94, 0x653A5E8D, + 0x2174EBBE, 0xDEFE6415, 0x30DA429C, 0xD0C5E40C, 0xB4719AA4, 0xD29CE7A6, + 0x905957CD, 0xCD287499, 0x83CA0AA7, 0xA8385832, 0x25A0CA02, 0xC20D47A4, + 0xB562F556, 0x4BC19E4C, 0xD9E215C7, 0x27E838B4, 0xC58612F4, 0xA2827F6F, + 0xC49DCDBA, 0x679B7362, 0x4E495845, 0xCFD2F0D1, 0x395E76A0, 0x375A655E, + 0x92E2058F, 0x73F9F0CA, 0x61EFF3B3, 0x51FFD362, 0xE7410345, 0x7FDA8B3B, + 0xA219E2E8, 0x17ABE543, 0x26557412, 0x4B30084D, 0xA68E191D, 0xFE0D93DF, + 0x73EF127D, 0x4DECDDB1, 0x77FAF45F, 0xD6002898, 0x92DD0A40, 0x157F6DDF, + 0xC2A55F8E, 0x4359F924, 0xFB630C3F, 0x338B6B58, 0xB2945F75, 0x4FA23A0E, + 0x836EB8C0, 0xB3B18FD, 0x86114337, 0x24668ACB, 0x99BB82F0, 0x924C8A47, + 0xBA959701, 0x81155ABF, 0x8C612D71, 0x36074CA7, 0xD1668C41, 0xE35F58C7, + 0x7FC2802D, 0x8E6A7CF3, 0x65B07D07, 0x815F6A6B, 0x791BF0DD, 0x6E47D719, + 0xC24394C7, 0xE84A6EB, 0xF194AFEE, 0x464A2F52, 0x677579FD, 0xEBA775AE, + 0x1F6EEFF, 0x9A795237, 0x78D9D45F, 0x9D0B344D, 0xBBD34AB7, 0x2F85B12A, + 0x16C5C2AD, 0x3990985D, 0x88DF3351, 0x82811AA5, 0x6D351F41, 0x4066A69D, + 0x86B660BF, 0x6EDB4768, 0xDDD78CF0, 0xB5D74F6E, 0xE89E220C, 0x91439687, + 0x947CC9C9, 0x3857E2BD, 0x302F8AE4, 0x1DABE7F8, 0x4832D6C9, 0x37D58FCB, + 0x4EA8A711, 0xCD7BAC98, 0x19DBF8BC, 0xD8DE8DC2, 0xEAFF7E7B, 0xB7629C93, + 0x792C6E19, 0xF7009192, 0xFF88439D, 0x2E196A66, 0xEC71B78C, 0xEAF4BB3A, + 0x7C16225E, 0x668F337, 0xCBEE1608, 0x6D5B5552, 0x345DC590, 0x681209CC, + 0x7B24A819, 0xD08A1416, 0x99888FE3, 0x9FC7288A, 0x24BD8502, 0xEA1D9678, + 0x20EECA0, 0x59BEA057, 0x5ADE91EB, 0xDEA8E49D, 0xFA200E6F, 0x9149C81D, + 0xF2281E93, 0x8A5B0451, 0x67312D58, 0xE3B849F1, 0xD2217960, 0x7CDF59F3, + 0x33C775C0, 0x9EBA8799, 0x7DF9506, 0xB4E96110, 0xB8FCF3E3, 0xDEA059B2, + 0x8229B6EA, 0x316486F6, 0x43919185, 0x6C0D90F3, 0x1C6F3DF8, 0x38DB92A9, + 0x5CD41244, 0x2C9F0A7B, 0xDF4A315F, 0xF7CE9C66, 0x4C800860, 0x318D53E0, + 0xF105C20D, 0xD753E1F2, 0x750810BA, 0xA17ECCA5, 0x2010140, 0x4D884763, + 0xC2BB0DA7, 0xB2D5BA74, 0x141CECD4, 0x887FDFC3, 0xC64B53, 0x2D2A85F6, + 0x15532B45, 0x5D5CBCE1, 0xBEB9A16A, 0xA214611B, 0x9FC5AC5F, 0x11AE5DD7, + 0xA0B9A5A9, 0xFC648AF4, 0x740009AC, 0xED0E0321, 0xB8E6A61, 0x8910C544, + 0xC74F26C8, 0x9525CCF3, 0xB41AEB59, 0xE61984CE, 0x598B2197, 0xA412E59D, + 0xE1976DD4, 0xB29BBE16, 0x88FD9FB0, 0xB04006F3, 0xB45E309, 0xD5CC15F1, + 0xD9DAF630, 0xDC809335, 0x803ED52, 0xB537F5A5, 0xA994F6EB, 0xF5288568, + 0xF66FD264, 0x2EA2B3A6, 0x647619F3, 0xFFB38C7A, 0x1BC03B9, 0xB6BC3061, + 0xBF30596E, 0xBE2AD27B, 0x8AC04220, 0x641979A3, 0x9ECCBB89, 0xA144FBC1, + 0x4E8FAE26, 0x8C5A9D90, 0x299ED467, 0xD7C9C7E3, 0x1D4865ED, 0x76F31C3D, + 0xCEE81CDF, 0xB479195E, 0x6FFB3AE1, 0xDC8A398, 0x300F7364, 0xC7940AFA, + 0x3B85BE3E, 0xD98CC40D, 0xA24A3D89, 0x3A674204, 0x22888A38, 0x2E77F2D, + 0xA2841C9C, 0xCF0689C3, 0x9FE98922, 0x89335017, 0x2D6B69A7, 0xFEDB63F9, + 0x899AF4EF, 0x9F9F9B40, 0xA4BE97E8, 0xA51DAF7A, 0x16AC50D3, 0xA8D7ED6, + 0xED193443, 0x7615EF1B, 0xB0DF6A4E, 0x64FFE794, 0xE3DB2C9A, 0x7435B022, + 0x556E825C, 0x23802AF9, 0xC25098A4, 0xE75A18BB, 0x70B2A7B9, 0x7FB81BF, + 0x63EF910, 0x6C669591, 0x6574DD2B, 0xCF6E379D, 0xD2B3AFAC, 0x1E6A1101, + 0x1DE22385, 0x2338191F, 0xC69704B6, 0xCBABC599, 0x54EB4809, 0x7839BE6D, + 0xD50017DD, 0x39B1A0E1, 0x288D52D3, 0x2D52668C, 0x20D22A68, 0x4E1207D1, + 0x3FCC0EFE, 0x47F3FE64, 0x25177A90, 0xB4BFDD4D, 0xDA8DBDCE, 0x6F7275A8, + 0x6BEAA655, 0xAA1810FC, 0xE4DB593A, 0x8A4D4BC0, 0x2C402E93, 0xF1C0F7F9, + 0x6F0CC577, 0x70412414, 0x752F9DC1, 0xD82E38EA, 0xAC455F7B, 0x4DCD4EDB, + 0x92BC2696, 0xFB03F135, 0x4FCA1F8C, 0xBD5E75F6, 0x502F41B0, 0x3616D3F1, + 0x2E5B8E31, 0x2026EB19, 0x57E783D7, 0x467BBE00, 0x4703ABA3, 0x1F776B9C, + 0xE2570A84, 0xFEC7DB48, 0x1BD5012, 0xFD0A2D5D, 0x7FCC29F2, 0x291304B6, + 0x99D5D8ED, 0xC7551C8, 0xFD12F38F, 0xBADE8892, 0xDF749997, 0xA5DAE2F, + 0x2B9FA269, 0x5C13CFED, 0x15E9A399, 0x54437F4E, 0xA72DB2AB, 0x56186AA1, + 0xFE4DB55C, 0xA34D7836, 0x2A879760, 0xC63FA94, 0xAC18B207, 0x5FC78B3, + 0x7F10621E, 0xA769E6B2, 0xEC9F4A11, 0xCE3F982C, 0x62BA2EF5, 0xA5F239CD, + 0x73D63FED, 0xE36E9F5E, 0x8AC1DA0E, 0x3F3DB3EB, 0x738326EA, 0x35C366B1, + 0xCD476E86, 0x82F6B208, 0xF11A9FC1, 0x426AC396, 0x7E4D1B93, 0x75E4EDB7, + 0xAF3C44A7, 0x51A5EF5C, 0xFAD2463D, 0x8A5639CA, 0xC995AC78, 0xCC4BE4F6, + 0x3AFE7F8D, 0x66993D04, 0x4386FF37, 0xCBC1C6C2, 0x55A8F5EC, 0xE81A9A75, + 0x30A67E1B, 0x4A4A7D0C, 0x20F7F993, 0x1891805, 0x738976AD, 0xD426E7D6, + 0x3C5CEEBF, 0x4499187F, 0xABF17C97, 0x447C317F, 0x68D8419C, 0x7AAB6456, + 0x421BCF29, 0xF6740F9C, 0x8916BB8D, 0x3D72AAB, 0x9AD54DD7, 0x7549C6EE, + 0x7317342B, 0xA18546D4, 0x1056BDA7, 0x54BBCCCE, 0x8CE63E46, 0x5D146234, + 0x33BE6C63, 0xB250C4E5, 0x89D72335, 0x87C36BA, 0xB65530CC, 0x2DFAC48C, + 0x1663D16F, 0x59B80AA, 0x950274EA, 0x92532D4A, 0x3CEF802D, 0x492FBDA5, + 0xA63A2574, 0xEF8005C2, 0x94A18651, 0xAF627ABA, 0x6829B238, 0xA698F646, + 0xD2598516, 0x10144D36, 0xD9B1D1B9, 0xAB2ACF05, 0x5395B699, 0xA7851C75, + 0x1806C6F3, 0xAE970306, 0x3284B145, 0x98F4FE8F +}; + +/* The source data is random across the q31_t range. Accessing it by word should + remain random. */ +const q15_t * controller_q15_inputs = (q15_t *) controller_q31_inputs; + +const float32_t controller_f32_inputs[CONTROLLER_MAX_LEN] = +{ + 43.0264275639 , -17.0525215570 , -94.8488973910 , -8.1924989580 , + 7.2830326091 , 66.8368719314 , 33.9778190671 , 117.8652289772 , + -129.6077797465, -14.6420815368 , 18.0239223278 , 20.6760530292 , + 55.0375037651 , 1.8674609862 , -85.6534302408 , -33.5750364909 , + 29.2110949614 , 110.4727049460 , -94.1914619387 , -1.4084169343 , + 83.5181653041 , 47.3073514127 , -13.3420621181 , 30.3389699104 , + 12.1188124277 , 100.9730921941 , -114.0146362390, -77.5823200409 , + 37.2019034618 , 40.0026301128 , -58.3387276630 , -34.9472398600 , + -5.1169678311 , -87.7660091118 , -150.5888601131, 56.0349370503 , + 50.2168884079 , -74.2313236767 , 22.3648603560 , -6.8676387051 , + 74.8957303680 , -90.1292012823 , -55.1436241586 , -66.6732976100 , + -6.7918147615 , 7.7612697081 , 35.7892605979 , -20.0470508830 , + 41.8369017546 , -143.7378056984, -41.9127158600 , -108.3531841158, + -57.1917422289 , -124.2808828105, 38.9316388820 , -77.9212517405 , + 37.1990818377 , -28.9545952748 , -155.6371057564, 45.8088886393 , + 36.2537018275 , -6.5727656016 , -104.2070491921, 45.5583813729 , + -19.7674717059 , -80.4802190947 , -1.4444563441 , -42.2142256438 , + 36.6546339194 , -57.0866498590 , 44.4677067511 , 65.7285753407 , + -103.8158864647, 25.4348723711 , -153.5419639389, 39.3608409474 , + 49.1658103436 , 79.5570602275 , 75.2944095996 , 58.9394700746 , + -53.1018534392 , 33.4172444014 , 35.6224682287 , -64.4353396418 , + -125.8464291251, -47.6072111617 , -26.2177687594 , -12.0061322096 , + -17.7887967585 , -28.2926175090 , -62.0691715749 , 40.5098573604 , + -191.1123732593, 119.6750713043 , 19.6182375803 , -26.7615252921 , + 2.2957847015 , -108.3436451287, -50.5906164995 , -5.6360985100 , + -11.6772204201 , -84.2765293757 , -60.9317810068 , 82.0446350218 , + -70.2048296348 , 72.8738253222 , 60.2450218115 , 114.2741231228 , + 46.8180775285 , 6.9915412654 , -8.9909197429 , -78.9165936808 , + 66.4731535459 , -68.4235455651 , -79.8254597080 , -10.6308477115 , + -62.6161569330 , -55.7744410292 , -11.8408366528 , 98.1034940997 , + 35.8213741877 , -54.4694482732 , 86.9631830044 , -53.0343838122 , + -47.4898642865 , -47.2010929590 , -31.3312639685 , -23.0908245172 , + 12.0258009869 , -5.1098204703 , -9.8420230737 , -107.3328761158, + 44.6810431959 , -17.9083820345 , -60.9753512872 , -7.5915088994 , + 17.2250813329 , 57.9176125648 , 124.3004161362 , -63.1950908493 , + 120.5788885640 , -44.1734238117 , -91.7408095116 , -43.5696066595 , + -49.9560710099 , -167.8513443296, -70.9437505499 , -46.4109705355 , + -64.2264526456 , -13.9995803916 , -100.9548186356, 9.9101010575 , + -50.0615130815 , -55.7590145012 , -60.3195153388 , 61.7913378549 , + -102.0850899209, 53.2360193126 , -25.8997883369 , 75.1445512333 , + -113.8148602310, 17.8027281119 , -19.5006822722 , -44.2169628471 , + 107.5017084384 , -113.7909124666, -43.9735396033 , 7.6880981388 , + 46.7384653508 , 9.9047443751 , 81.8646964362 , 132.3812863877 , + -95.6959050236 , -68.5015813484 , 65.8586404494 , 18.5039353889 , + -30.1786166621 , -90.3098515667 , -22.9356228552 , -20.5778272423 , + -2.2127786675 , -35.4418447703 , -51.8722915974 , -107.9024439078, + -51.5940748232 , -51.7463262677 , 74.2795485984 , 94.2205022462 , + 9.7016384049 , -47.3556083155 , -36.7822314478 , -151.6455525363, + -15.7183814485 , 78.2063383182 , 0.1516414969 , 37.9304181609 , + 20.6185902740 , -22.2164106778 , 6.1160554677 , 2.4061326953 , + -111.6681824598, -60.0858917090 , 75.1698614693 , -76.5787410444 , + 28.3391655715 , -2.4946186443 , -68.0378899682 , 104.0893199171 , + -51.8319647254 , 38.8521710524 , 75.9114239564 , 73.9206172905 , + -103.2533029987, 6.9002718274 , -36.6346436319 , -25.1990926265 , + 1.5852145953 , -50.6438436795 , 21.5018844428 , -151.9305562846, + -51.7326681814 , 21.4475994143 , 42.2564011921 , -74.0520586926 , + 49.7370635809 , -13.2957534126 , 36.6746826778 , -31.7005492589 , + 148.4894964268 , 79.7890632353 , 16.8856024809 , 16.1690460177 , + 39.2665169484 , 117.2461167794 , -37.4827984831 , -47.8387803604 , + -95.7025286193 , 34.3058214285 , -124.9536456028, 56.1640195764 , + 94.3636873606 , 35.3992852810 , -38.3920852159 , -100.5738062016, + -29.7837022314 , 42.9133913996 , -34.2715618187 , -14.3589115627 , + -16.5935468750 , 20.4574192236 , -88.7897972666 , -38.6285080386 , + 53.3203422726 , 98.5991486746 , 122.7305462474 , 67.7902817187 , + 5.1764117389 , 5.0632821624 , 21.9288789574 , -78.3140512638 , + -21.2069682335 , 23.6342010925 , 34.4445769455 , 59.1346766615 , + 28.9978778000 , 39.8121180845 , -17.1650033520 , -56.9174900874 , + 17.8157086148 , -112.8801457350, -122.4019040408, 140.8669393157 , + -65.4664329639 , 40.6952775518 , 32.7260891658 , -43.2565155866 , + 19.3945751928 , -20.1815002000 , -67.6601711640 , -18.1921178207 , + -35.6802153684 , 49.9550290306 , 131.4925251016 , -31.2940938167 , + -5.2848453344 , -109.5580577933, 20.2437599390 , -8.8782958734 , + 54.1836717264 , 7.2555852190 , -3.5698316137 , -51.9236786262 , + 6.7861547980 , -104.4814551670, 45.8458629668 , 70.0890876844 , + 38.3572837740 , 61.8024165129 , 68.0176962024 , -12.8193934080 , + -21.4661610917 , -0.9377108815 , -74.2100679061 , 71.0490808147 , + 91.9813889497 , -14.5797640164 , 3.5036749129 , -138.3605478356, + -48.1501349794 , -16.0636922482 , -12.1334197606 , 15.0562207637 , + -34.0878176054 , 55.1075126157 , 97.3829871877 , 0.2053358099 , + -94.8713267382 , 51.5460954054 , 21.2966946363 , 58.1331025047 , + -23.4599044132 , -19.3315856528 , -8.4497193577 , -1.9594679356 , + -33.1906549336 , -144.6825417978, -57.1218958072 , 35.7353406097 , + 61.4666549819 , 14.6536253128 , 82.1632196866 , -44.6230161723 , + -91.1022589278 , -18.5737673927 , -136.8975612334, 56.9606788003 , + 70.7059960183 , -68.2829345081 , -10.2629800455 , -53.6385325047 , + -68.7928766204 , 88.2444688302 , 83.1412324801 , -102.9206928160, + -68.2329763159 , -69.7552955469 , 108.2132269009 , -28.2582329307 , + 5.6685898328 , -36.0392956840 , 43.3269513128 , -8.6436416796 , + -16.5054886972 , 11.5008791788 , 39.6923606683 , -28.9039554061 , + 13.5938214364 , -23.6296332202 , 49.1171161163 , 53.1636857935 , + -62.9672053166 , -54.2594757384 , 48.3838956696 , 8.0469071555 , + -33.6472086213 , -120.5381752144, 55.0880453111 , 17.8990740563 , + 144.9402232336 , 101.7886229203 , -73.3666393712 , -16.4721379138 , + -12.7447935685 , 101.8245160983 , -49.7026860415 , -15.1227790364 , + 65.7430288442 , -131.8695390036, 10.2750933946 , 90.9752774838 , + -26.5859990591 , -95.6962772568 , 76.2174589344 , 24.8796848060 , + -38.8938223046 , 54.1687774852 , -37.3585968996 , -34.6848570502 , + 33.0151011570 , -55.8345877671 , -3.9009101671 , -31.5024971691 , + -9.6863895491 , 91.8719195957 , -58.9993249744 , -25.6887030614 , + -8.0829472205 , 4.6386491741 , -71.4019697167 , -21.3734669095 , + 86.2079144404 , 79.6823974266 , -0.0910915997 , 44.8067718095 , + 58.7204020766 , 72.6856808976 , -50.3373732478 , -116.1175365534, + -15.0884909384 , 5.4593772059 , -63.6553527905 , 37.3460388205 , + -32.2399421679 , 95.7569350513 , -7.3700141964 , -56.0370832967 , + -41.7377150439 , -42.0042856519 , 12.5134312941 , 93.7845584531 , + -32.4801087157 , -33.3976050318 , -24.2252126001 , -46.3199064467 , + -20.3704610276 , 15.8571376404 , 88.9127217235 , -33.1132582267 , + -1.0005675836 , -28.1780471904 , 150.9349379135 , 38.0600520828 , + 36.4338677563 , -3.3709201641 , 29.7709773016 , 16.5064119077 , + 21.3147729463 , 110.6714300904 , 18.8406036507 , 14.8963298097 , + 50.9975960392 , 16.3991140350 , -194.0805845907, -41.6723945839 , + -74.8991127408 , -6.4587655805 , -0.6883628218 , -49.8709647175 , + 194.2265120473 , 64.3043624521 , 16.0040882780 , 68.4032551772 , + -43.4050313128 , 84.6826289824 , -28.1357565943 , 134.6895584120 , + -7.9746152680 , -95.6692886462 , -48.9444370342 , 79.4479343188 , + -50.5345228122 , 52.4800633307 , -14.7735051703 , -20.1510237050 , + 22.5049816980 , 64.4191999102 , 24.8385648232 , 99.4265041360 , + 62.0189508473 , -28.3892600378 , -109.8842008564, -79.0407483407 , + 18.3408112020 , 49.1650536089 , 31.5419844924 , -36.1160722679 , + -132.9148081329, 10.4053531567 , -129.2463715470, -43.4602207151 , + -24.2420653292 , 91.5388317556 , 21.4762248190 , -44.3810909139 , + 18.4098011282 , -45.8691164539 , -20.9831197962 , 16.2076792914 , + 66.0224147666 , -13.6794615513 , 101.2163279622 , -62.4462618603 , + 22.2040981785 , -52.3208382802 , -24.7909079016 , 58.5150375093 , + 18.8569705105 , -55.6083430939 , 131.0273367422 , -34.5209015065 , + 121.4357296573 , -77.2590299593 , -51.5929566898 , 5.0247131098 , + -23.8451707592 , -4.5912313547 , 31.1387246821 , 61.7019310824 , + 49.1912429744 , -50.5836913031 , -74.8182600630 , -21.6209317022 , + 20.9409464654 , -72.7870824583 , -28.3530746820 , -45.0794425434 , + -13.4910629905 , -62.0158772255 , -34.1421181246 , 44.2844972784 , + 8.4213193211 , 79.9349022793 , 60.0160502260 , 32.2272994080 , + -72.2893887746 , 17.3063698247 , -134.6335742431, 64.6499736261 , + 7.1411921919 , -37.5517577873 , 6.2405670930 , 117.1920927305 , + 128.7420689815 , -3.1556854963 , -13.4100422909 , -11.9336372907 , + -8.6022400553 , -102.0033506666, -78.4696575074 , 15.0765861403 , + -111.5219718576, -13.4162786508 , 38.2437013694 , 61.1637732561 , + -34.4804160003 , 107.4438003830 , -79.4193067813 , -81.1842853968 , + -26.2622970331 , 132.3205425408 , -119.1464268477, 67.3048866598 , + 103.3266736715 , -58.1865815617 , 27.6231908601 , -11.2004371750 , + 26.0340617206 , 12.5696123916 , 0.6442714420 , -30.7393043544 , + 1.5314955897 , 49.9110088250 , -106.1358721920, 51.1608329944 , + -32.8684239794 , -27.7215905745 , -11.6450303367 , -36.7731678028 , + 59.9383486599 , -4.6301990580 , 5.0361682939 , -10.5669407980 , + 124.0908762205 , 35.8305364082 , -123.6216777114, -74.2569079167 , + -56.7651776816 , 16.0736385582 , 23.5030632215 , -110.6764295938, + 44.3086821806 , 9.4452708243 , 5.3300080251 , 39.0483916714 , + 151.4550562868 , 62.8957092621 , -116.8103461233, 5.1129927759 , + -33.2252515135 , -9.4522506046 , 22.7026048372 , -15.5264414569 , + 71.2087620034 , 19.1191568332 , 50.3019546809 , -5.6096922409 , + 22.9344126462 , -7.7591876203 , 31.8949515564 , -58.4253952381 , + 66.4341297173 , -19.0583083044 , 96.7695087855 , 20.4934280047 , + 4.9544603116 , -20.8288135920 , -173.2659655408, -62.4883621640 , + -48.5528422703 , 12.1437504278 , 60.2482234666 , -19.6072312919 , + -34.6320214291 , 129.0089698963 , -50.9042160618 , 98.3952661477 , + -4.7051792479 , -13.1768910826 , 69.5138802139 , 58.5748201565 , + -45.9385652563 , 151.7952104306 , 34.2541941013 , -58.0417838381 , + 28.1480473670 , 46.4006562684 , 97.7001828545 , 4.0855607626 , + -32.6097018162 , 16.8913949959 , 105.7266202978 , -89.3978374651 , + -60.9338593128 , -41.2220734230 , 49.9393070783 , 95.0974764854 , + 49.2498366456 , 58.6214364590 , 34.1113830569 , 45.6634098874 , + -22.5356086770 , -97.1978653617 , 86.5565049535 , 70.6118545777 , + -30.6978082909 , 118.7238621666 , 14.5922386932 , 11.3449652072 , + 65.6007783405 , 82.6369678204 , -52.0390492248 , -47.0160551227 , + -95.5142448634 , 99.7162626888 , -36.5523815090 , -42.8042935534 , + 68.3566199798 , -13.8451547552 , -71.1629911780 , 36.2989433752 , + -32.4867163365 , 112.4079947071 , -75.6295117422 , 47.5276421639 , + 51.8078250755 , -26.8715188457 , -9.6291144797 , 40.1999849640 , + -38.4634033246 , 40.9764960915 , -26.1715730268 , 36.5996396515 , + -26.9924731886 , 53.7879986570 , -83.1658398348 , 23.6381378489 , + 43.8794937753 , -55.4133836419 , 90.0266130838 , 14.1036181982 , + -18.1225736715 , 85.1363181151 , -62.5970846379 , -18.5291947838 , + -25.7341986703 , -49.7061342931 , -59.0442763971 , 50.8960636803 , + -87.6471123430 , -36.7217762531 , 22.5952364054 , 11.1107885650 , + -0.5377327229 , 160.8145792630 , 73.3103441505 , 10.1656872354 , + -50.4554350397 , -57.3478171016 , -15.4201715357 , -26.9135446491 , + -4.9891264771 , -37.0226770057 , -80.9919535641 , 50.4418660876 , + -25.8517575250 , -69.9538258421 , -17.5730160671 , 15.9405836751 , + 113.9545230349 , -46.1040379057 , -94.2458635014 , -69.0338522452 , + 43.5813790265 , 107.1836101171 , -55.1012654323 , -77.1529555887 , + -33.1530320656 , -94.5582659641 , -53.6837586872 , 27.0680381378 , + 93.9385415207 , -61.0955216188 , 18.0530957225 , 7.9150142320 , + -12.1218191587 , 34.0173961457 , 40.0084937565 , 9.8119275580 , + 44.2065861274 , -1.8718514394 , 67.4740024215 , 46.7391150131 , + 207.2404815875 , 45.1635364462 , 43.3580102761 , -44.0244218674 , + 83.2387206007 , -8.6441851856 , 12.3993902588 , -22.5091685270 , + -19.8332981376 , 97.9196509289 , -76.6720306234 , 28.9740705859 , + 121.9415248016 , 9.6656982611 , -51.0996453694 , 37.3704374740 , + 74.7589840907 , -113.4066752631, 120.0029566342 , -105.3786221360, + 81.8152755619 , -13.4979932982 , -21.4680758393 , -85.1088235539 , + -65.3610798409 , -35.0444139470 , -48.0220794487 , -41.6210317362 , + 33.1212995259 , -82.1480936443 , -10.5479715135 , 76.4601917004 , + 42.1983651157 , 92.6104239912 , -42.3536237955 , -24.5644182272 , + 30.4446637772 , -90.2899420489 , 63.6723540422 , 103.0895811428 , + 64.1706769263 , -10.7069812309 , 21.8927240409 , 6.3571071738 , + 57.1457649358 , -52.9866276448 , 66.0981829072 , -29.5372056881 , + -79.2252039810 , -136.2440652798, -57.0106422562 , 86.8203548141 , + 66.4244149837 , 53.3230426111 , -66.1283059222 , -131.0402660353, + 8.0548411081 , 122.9088988100 , 1.2626894208 , -60.5059112373 , + -68.8707203082 , -6.4747987200 , 85.8411327244 , 99.9624156733 , + 90.4197864338 , -35.9630441182 , -22.9158275507 , -17.3660128776 , + 16.7845345761 , 34.7219749782 , -39.3513765878 , 1.0460702756 , + -60.9494500182 , 20.0900333387 , -85.9636743832 , 88.4400782168 , + 15.0729628728 , 61.5499846243 , 11.8579871757 , 107.8617581581 , + -42.9393027864 , -62.8422307621 , -19.0589600542 , 4.0750325807 , + -36.0651825425 , 55.7638724501 , -10.4691736080 , -55.5672537178 , + -61.2061519915 , -21.1885348576 , -131.2535612498, 24.7463552676 , + 22.9426321237 , 14.3038202264 , -138.0926317438, -59.0892900856 , + -162.5416439986, 7.1307658250 , -141.1236672256, -4.7173618068 , + -16.7741532807 , -68.2615451173 , -2.6608701102 , 84.1978109826 , + -11.3446202072 , 59.9630033088 , -1.8994925010 , -37.9301641959 , + -119.4435600954, -11.4587491646 , 12.2423215240 , -7.3169898616 , + -67.0373621128 , 36.0198843055 , 53.9791315249 , -134.5885680695, + -83.8330811965 , -16.6714816463 , -8.8498552035 , -24.0513088196 , + -22.9444328877 , -37.7961441531 , 25.1975736186 , -136.1611637464, + -5.0843464033 , -10.3939554694 , 20.7422826935 , 75.6854136623 , + 46.4179626736 , -57.0052830175 , 7.3457235521 , -51.5504447254 , + -158.4375751701, -200.2426967181, -48.1234996261 , 1.6623945527 , + 21.1746524375 , 99.4092980367 , -2.3206772903 , 45.7989166757 , + 2.0181548348 , -88.0556010969 , -59.1527212096 , 47.3607925077 , + -10.4181140309 , 56.3558125650 , -8.9799125560 , -30.0376711812 , + -36.7132904688 , 35.7785050392 , -13.0763909369 , -2.1855594714 , + 18.1550954005 , -28.6711803575 , -55.4495172398 , -2.8812973198 , + -59.9575059158 , 40.0588875786 , 57.4713686602 , -3.2835144853 , + -36.7193552111 , -64.9415131516 , -166.9555466445, -23.5556853844 , + -54.9408569587 , -35.2310451959 , 21.3345143458 , 65.7590671151 , + 51.2214538168 , 46.1271939944 , -42.2235267919 , 127.2329928299 , + 105.2391778600 , 17.6726845966 , -129.9021148044, 8.7065613044 , + -94.0987112511 , -3.5375742950 , -23.1385452379 , 60.6219530633 , + 92.5445564235 , 48.5111974469 , -52.5699309159 , -60.0634811685 , + 25.9034368684 , 140.0249495491 , 1.5918852392 , 38.0266038291 , + 17.5588710703 , 3.4294066089 , -27.6748782173 , 59.6182974489 , + -35.2924781853 , -38.6198576115 , -13.6119803198 , 7.8375587489 , + 22.7250686519 , -28.3524510951 , -34.4269062817 , 22.6464817325 , + -61.6528147860 , -5.9782002429 , 61.4730771294 , 43.5582379527 , + 55.6862408270 , 87.8745651631 , 46.3401042715 , -19.8780979663 , + 74.1272633369 , 29.8590452377 , -12.8665765140 , 34.2931401219 , + 53.9279617551 , -16.9017895140 , -70.1527553166 , -79.6367897992 , + 109.3728271017 , -129.2214826835, -53.4644539730 , -51.5654458993 , + 17.6062148433 , 3.5090251835 , 74.2615941204 , -109.3431097845, + 40.1403465151 , 28.8714561280 , 94.0868659302 , -19.0047033845 , + -60.0967410050 , -19.0998457619 , -67.2027075128 , 72.0711434846 , + -17.8737851232 , 123.7050551274 , 132.6331504104 , 25.5018761009 , + -36.7817189239 , -29.1580893235 , -6.5848563828 , 90.2868948516 , + -35.7017258498 , -68.5675432955 , -52.4888589786 , 47.1377730021 , + -7.4546621940 , -52.0657517138 , -49.0404829633 , -114.6910280126, + -117.6819819437, -32.7856729408 , 31.8232065591 , 12.1192973039 , + 35.2678513420 , -1.0336778293 , 30.7021249679 , 127.0442906046 , + -84.8457819393 , 28.9862843096 , -47.3524701726 , -126.1094998460, + -2.9700276582 , -2.4956545870 , -53.8624121141 , -85.2114117637 , + 76.9057985618 , 137.1205201755 , -19.0830817212 , 14.3407526579 , + -56.5921994449 , -25.6084873186 , -44.9470801106 , -133.3139496090, + 0.3487447576 , 33.4499716730 , 34.7126257844 , -9.3307383323 , + 27.2996276947 , 10.8765676134 , -91.1032360444 , -90.9584216222 , + 1.6981490570 , 96.8557438791 , 56.7726390913 , -44.3246449237 , + 52.3260643361 , 21.5551140465 , 27.4535327381 , 2.0072717479 , + 7.4823125629 , 77.1185863870 , 16.1372262663 , -10.7206012957 +}; + +const float32_t controller_f32_coeffs[CONTROLLER_MAX_COEFFS_LEN] = +{ + /* S->Kp, S->Ki, S->Kd; */ + 0.0000000000 , -1.0336778293 , 56.7726390913 , + 0.3487447576 , 0.0000000000 , 27.4535327381 , + -29.1580893235, 1.6981490570 , 0.0000000000 , + 0.0000000000 , 0.0000000000 , -2.4956545870 , + 0.0000000000 , 8.7065613044 , 0.0000000000 , + 0.0000000000 , 0.0000000000 , 0.0000000000 , + 18.1550954005 , -5.9782002429 , 2.0072717479 , + 33.1212995259 , -82.1480936443, -10.5479715135, + -23.6296332202, 49.1171161163 , 53.1636857935 , + 7.2830326091 , 66.8368719314 , 33.9778190671 , + 9.4452708243 , 5.3300080251 , 39.0483916714 , + 6.9915412654 , -8.9909197429 , -78.9165936808 +}; + +const q31_t controller_q31_coeffs[CONTROLLER_MAX_COEFFS_LEN] = +{ + 0x00000000, 0xFEF760E4, 0x38C5CBAD, + 0x00594756, 0x00000000, 0x1B741AB9, + 0xE2D78775, 0x01B2B9E6, 0x00000000, + 0x00000000, 0x00000000, 0xFD811CC8, + 0x00000000, 0x08B4E134, 0x00000000, + 0x00000000, 0x00000000, 0x00000000, + 0x1227B455, 0xFA0594AB, 0x0201DC90, + 0x211F0D7C, 0xADDA1689, 0xF573B824, + 0xE85ED05B, 0x311DFB52, 0x3529E750, + 0x074874D3, 0x42D63D3D, 0x21FA525A, + 0x0971FD45, 0x05547B68, 0x270C6366, + 0x06FDD5A6, 0xF7025315, 0xB1155A1E +}; + + +const q15_t controller_q15_coeffs[CONTROLLER_MAX_COEFFS_LEN] = +{ + 0x0000, 0xFEF7, 0x38C6, + 0x0059, 0x0000, 0x1B74, + 0xE2D8, 0x01B3, 0x0000, + 0x0000, 0x0000, 0xFD81, + 0x0000, 0x08B5, 0x0000, + 0x0000, 0x0000, 0x0000, + 0x1228, 0xFA06, 0x0202, + 0x211F, 0xADDA, 0xF574, + 0xE85F, 0x311E, 0x352A, + 0x0748, 0x42D6, 0x21FA, + 0x0972, 0x0554, 0x270C, + 0x06FE, 0xF702, 0xB115 +}; diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_group.c new file mode 100644 index 0000000..0f9709e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/controller_test_group.c @@ -0,0 +1,13 @@ +#include "jtest.h" +#include "controller_tests.h" + +JTEST_DEFINE_GROUP(controller_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_GROUP_CALL(pid_reset_tests); + JTEST_GROUP_CALL(pid_tests); + JTEST_GROUP_CALL(sin_cos_tests); + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_reset_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_reset_tests.c new file mode 100644 index 0000000..a930dbb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_reset_tests.c @@ -0,0 +1,52 @@ +#include "jtest.h" +#include "arr_desc.h" +#include "arm_math.h" +#include "type_abbrev.h" +#include "test_templates.h" + +/* Bucket of zeros. For comparison with the output of arm_pid_reset_xxx. */ +ARR_DESC_DEFINE(float32_t, zeroes, 3, CURLY(0)); + +/** + * Define a JTEST_TEST_t for the function arm_pid_reset_xxx function having + * suffix. + */ +#define ARM_PID_RESET_TEST(suffix) \ + JTEST_DEFINE_TEST(arm_pid_reset_##suffix##_test, \ + arm_pid_reset_##suffix) \ + { \ + /* Initialise the pid_instance */ \ + arm_pid_instance_##suffix pid_inst = { 0 }; \ + pid_inst.state[0] = (TYPE_FROM_ABBREV(suffix)) 0xffffffff; \ + pid_inst.state[1] = (TYPE_FROM_ABBREV(suffix)) 0xffffffff; \ + pid_inst.state[2] = (TYPE_FROM_ABBREV(suffix)) 0xffffffff; \ + \ + /* Display cycle count and run test */ \ + JTEST_COUNT_CYCLES(arm_pid_reset_##suffix(&pid_inst)); \ + \ + /* Test correctness */ \ + TEST_ASSERT_BUFFERS_EQUAL( \ + pid_inst.state, \ + zeroes.data_ptr, \ + 3 * sizeof(TYPE_FROM_ABBREV(suffix))); \ + \ + return JTEST_TEST_PASSED; \ + } + +ARM_PID_RESET_TEST(f32); +ARM_PID_RESET_TEST(q31); +ARM_PID_RESET_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(pid_reset_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_pid_reset_f32_test); + JTEST_TEST_CALL(arm_pid_reset_q31_test); + JTEST_TEST_CALL(arm_pid_reset_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_tests.c new file mode 100644 index 0000000..2e1c56e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/controller_tests/pid_tests.c @@ -0,0 +1,79 @@ +#include "jtest.h" +#include "arr_desc.h" +#include "arm_math.h" +#include "ref.h" +#include "type_abbrev.h" +#include "test_templates.h" +#include "controller_test_data.h" +#include "controller_templates.h" + +/** + * Define a JTEST_TEST_t for the function arm_pid_xxx function having + * suffix. + */ +#define ARM_PID_TEST(suffix,type) \ + JTEST_DEFINE_TEST(arm_pid_##suffix##_test, arm_pid_##suffix) \ + { \ + uint32_t i,j; \ + \ + arm_pid_instance_##suffix fut_pid_inst = { 0 }; \ + arm_pid_instance_##suffix ref_pid_inst = { 0 }; \ + \ + for(i=0;i 0 ? (x) : -(x)) + +/* + Function to test correctness of sin_cos output by comparing it with reference library +*/ +#define COMPARISON_INTERFACE(type, threshold) \ + if ( (ABS((type) sin_val_ref - (type) sin_val_fut) > \ + (type) threshold ) || \ + (ABS((type) cos_val_ref - (type) cos_val_fut) > \ + (type) threshold)) \ + { \ + JTEST_DUMP_STRF("Error: %f %f\n", \ + ABS((type) sin_val_ref - (type) sin_val_fut), \ + ABS((type) cos_val_ref - (type) cos_val_fut)); \ + return JTEST_TEST_FAILED; \ + } + +/* + Sine and cosine test function for float32_t input +*/ +JTEST_DEFINE_TEST(arm_sin_cos_f32_test, arm_sin_cos_f32) +{ + /* Test function for all input degree values */ + TEMPLATE_DO_ARR_DESC( + degree_idx, TYPE_FROM_ABBREV(f32), + degree, arm_sin_cos_degrees_f32 + , + /* Display cycle count and run test */ + JTEST_COUNT_CYCLES( + arm_sin_cos_f32( + degree, + (TYPE_FROM_ABBREV(f32) *) &sin_val_fut, + (TYPE_FROM_ABBREV(f32) *) &cos_val_fut) + ); + ref_sin_cos_f32( + degree, + (TYPE_FROM_ABBREV(f32) *) &sin_val_ref, + (TYPE_FROM_ABBREV(f32) *) &cos_val_ref); + + /* Test correctness */ + COMPARISON_INTERFACE( + TYPE_FROM_ABBREV(f32), + MAX_DELTA_f32)); + + return JTEST_TEST_PASSED; +} + + +/* + Sine and cosine test function for q31_t input +*/ +JTEST_DEFINE_TEST(arm_sin_cos_q31_test, + arm_sin_cos_q31) +{ + /* Test function for all input degree values */ + TEMPLATE_DO_ARR_DESC( + degree_idx, TYPE_FROM_ABBREV(q31), + degree, arm_sin_cos_degrees_q31 + , + /* Display cycle count and run test */ + JTEST_COUNT_CYCLES( + arm_sin_cos_q31( + degree, + (TYPE_FROM_ABBREV(q31) *) &sin_val_fut, + (TYPE_FROM_ABBREV(q31) *) &cos_val_fut) + ); + ref_sin_cos_q31( + degree, + (TYPE_FROM_ABBREV(q31) *) &sin_val_ref, + (TYPE_FROM_ABBREV(q31) *) &cos_val_ref); + + /* Convert q31 numbers to float for comparison purposes. */ + ref_q31_t_to_float((TYPE_FROM_ABBREV(q31) *) &sin_val_fut, &sin_val_fut, 1); + ref_q31_t_to_float((TYPE_FROM_ABBREV(q31) *) &cos_val_fut, &cos_val_fut, 1); + ref_q31_t_to_float((TYPE_FROM_ABBREV(q31) *) &sin_val_ref, &sin_val_ref, 1); + ref_q31_t_to_float((TYPE_FROM_ABBREV(q31) *) &cos_val_ref, &cos_val_ref, 1); + + /* Test correctness */ + COMPARISON_INTERFACE( + TYPE_FROM_ABBREV(f32), + MAX_DELTA_f32)); + + return JTEST_TEST_PASSED; +} + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(sin_cos_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_sin_cos_f32_test); + JTEST_TEST_CALL(arm_sin_cos_q31_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests.c new file mode 100644 index 0000000..50ec433 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests.c @@ -0,0 +1,38 @@ +#include "jtest.h" +#include "ref.h" +#include "arr_desc.h" +#include "fast_math_templates.h" +#include "fast_math_test_data.h" +#include "type_abbrev.h" + +SQRT_TEST_TEMPLATE_ELT1(q31); +SQRT_TEST_TEMPLATE_ELT1(q15); + +SIN_COS_TEST_TEMPLATE_ELT1(f32, float32_t, sin); +SIN_COS_TEST_TEMPLATE_ELT1(q31, q31_t, sin); +SIN_COS_TEST_TEMPLATE_ELT1(q15, q15_t, sin); + +SIN_COS_TEST_TEMPLATE_ELT1(f32, float32_t, cos); +SIN_COS_TEST_TEMPLATE_ELT1(q31, q31_t, cos); +SIN_COS_TEST_TEMPLATE_ELT1(q15, q15_t, cos); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(fast_math_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_sqrt_q31_test); + JTEST_TEST_CALL(arm_sqrt_q15_test); + + JTEST_TEST_CALL(arm_sin_f32_test); + JTEST_TEST_CALL(arm_sin_q31_test); + JTEST_TEST_CALL(arm_sin_q15_test); + + JTEST_TEST_CALL(arm_cos_f32_test); + JTEST_TEST_CALL(arm_cos_q31_test); + JTEST_TEST_CALL(arm_cos_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests_common_data.c new file mode 100644 index 0000000..cf806e3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/fast_math_tests/fast_math_tests_common_data.c @@ -0,0 +1,364 @@ +#include "fast_math_test_data.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +float32_t fast_math_output_fut[FAST_MATH_MAX_LEN] = {0}; +float32_t fast_math_output_ref[FAST_MATH_MAX_LEN] = {0}; +float32_t fast_math_output_f32_fut[FAST_MATH_MAX_LEN] = {0}; +float32_t fast_math_output_f32_ref[FAST_MATH_MAX_LEN] = {0}; + +const q31_t fast_math_q31_inputs[FAST_MATH_MAX_LEN] = +{ + 0x414A5524, 0x4CAB5A17, 0x2D6F5B56, 0x7DAF4E3B, 0x29B226EB, 0x41F6F6A , + 0x25CE38BF, 0x3A970AFA, 0x3A44382A, 0x05540F8 , 0x3D060524, 0x13D56570, + 0x17D7791D, 0x7FE0438C, 0x26741841, 0x40A66E54, 0x218E4386, 0x39FF3726, + 0x0DC177CA, 0x702F2CF5, 0x41142FF1, 0x6C1476AB, 0x15F640DD, 0x662C4E49, + 0x38055E7E, 0x770871FE, 0x4F8B5360, 0x0D1928A0, 0x57647821, 0x258558CF, + 0x0C0C604D, 0x50A46C19, 0x66D2370D, 0x50FA359A, 0x36462E24, 0x6CE00F5C, + 0x66D40948, 0x355B5831, 0x3B72150A, 0x1EB61530, 0x73394127, 0x773F26F4, + 0x18052980, 0x038D6587, 0x1CF517F4, 0x22AD1691, 0x7A812473, 0x7CDC7D7F, + 0x4A5110D0, 0x6D895BB9, 0x0FD60F35, 0x1A215530, 0x20EB6DDA, 0x3DE62516, + 0x250123E1, 0x5ED813C8, 0x61E175B1, 0x2CBB32F3, 0x6D350907, 0x5B140D7E, + 0x6EAE272D, 0x3E221841, 0x418B7B88, 0x26BB1B80, 0x3CF010E4, 0x24DB166C, + 0x79AB7E42, 0x62DF28D1, 0x47004665, 0x63F56FC6, 0x419E0C75, 0x46BE1F38, + 0x243239B2, 0x758D03E0, 0x5CE12926, 0x3F574B74, 0x1F4458E2, 0x71D5639 , + 0x03A17B49, 0x173A7C76, 0x06EF7531, 0x48D32F34, 0x7D3E3063, 0x0F2F3549, + 0x5C314C9 , 0x18CB6B6D, 0x26F83697, 0x447B1E9C, 0x2E323A33, 0x50745715, + 0x01AC5746, 0x655A4E04, 0x4891060F, 0x1DA36B4F, 0x60E6227F, 0x20BF5EB4, + 0x50B3225B, 0x40C10544, 0x415656C , 0x15405EAE, 0x185863E1, 0x236A1C4E, + 0x08BD21F9, 0x2ACF7A68, 0x773665E5, 0x4EDF5F66, 0x617A1610, 0x524F4968, + 0x42D006CD, 0x5F000079, 0x24DC2447, 0x6A4F5599, 0x37064D4A, 0x1DE70608, + 0x233A2EE5, 0x137E488E, 0x18061B7B, 0x4079569D, 0x24A817D5, 0x44CE48F5, + 0x575F7883, 0x22406802, 0x71AD70BB, 0x1D4A5D79, 0x3CBC7CE4, 0x335840D8, + 0x05792E47, 0x27AD2C05, 0x3D196EAB, 0x331A40AF, 0x33035831, 0x13D93987, + 0x7C542094, 0x045F317E, 0x5DC43F8B, 0x1379650C, 0x5C20193F, 0x7DD50298, + 0x1D482B82, 0x4A6B6062, 0x5C8A757B, 0x272917C1, 0x10E16FBC, 0x355A5882, + 0x66F86A35, 0x604555A1, 0x7DF7FBB , 0x758A6216, 0x1A113463, 0x53541BAD, + 0x21576756, 0x483B6D8D, 0x1F052FCC, 0x4EA63DFB, 0x55B84677, 0x7B2E04F2, + 0x787A796C, 0x04A12CD3, 0x46029BD , 0x1DB22DD8, 0x1A8C7F28, 0x061E452E, + 0x132D3F78, 0x76525852, 0x73357BBA, 0x6BBB0A58, 0x62536AFA, 0x3F6B65EF, + 0x6DC57B58, 0x1EB718CE, 0x66B02740, 0x5FF60B47, 0x32477B8F, 0x7FF35302, + 0x29FD3E40, 0x475A43D1, 0x6FF9528A, 0x2018209D, 0x47E079C9, 0x4CF576D3, + 0x28074E34, 0x5D6F58ED, 0x234045D1, 0x51CE35F9, 0x25297896, 0x644320FE, + 0x0F4449A9, 0x54C361C6, 0x701D52F1, 0x4E094820, 0x718F0810, 0x61540689, + 0x79DE5A1F, 0x52865C23, 0x48AC3A4B, 0x6A0C1BE0, 0x21B705DB, 0x7086465D, + 0x1CC10929, 0x1E1D716E, 0x6D231D4C, 0x20495108, 0x38FF1971, 0x149C78D4, + 0x441F1E8B, 0x43D95372, 0x69C324B4, 0x210B7DC9, 0x47815E78, 0x02476137, + 0x6163DDF , 0x390D6EC2, 0x2F684E5B, 0x0E680ABD, 0x02232615, 0x12593380, + 0x7B1465FE, 0x065A6957, 0x130F53EB, 0x6D772EF7, 0x10E916B6, 0x63BC7A68, + 0x2ACB00BB, 0x651C5590, 0x194714B5, 0x730904EE, 0x59BB61B4, 0x34867DBC, + 0x391C706C, 0x3C164218, 0x28931CD0, 0x129A66AB, 0x13171F4D, 0x62882872, + 0x4B167FD4, 0x66902F4C, 0x7A794932, 0x54B152C , 0x30856EA9, 0x39466D55, + 0x36696451, 0x0F5B1E8C, 0x077A3C6A, 0x51B956B4, 0x367E2D2A, 0x1D2C662A, + 0x78FB6880, 0x4E6D40B6, 0x40706FDC, 0x4DF9679C, 0x20306EDB, 0x63812AE7, + 0x255D2748, 0x1B8B617B, 0x3E036FAD, 0x04E444A7, 0x55A37517, 0x669B2988, + 0x18FD5E8C, 0x67BD05CE, 0x34BB346C, 0x76994800, 0x05B958B6, 0x6DFA2FEF, + 0x2055B5C , 0x1F843C4C, 0x72721B52, 0x73EF6B86, 0x5FB90B61, 0x43235DAC, + 0x31D424B4, 0x768C0D7E, 0x162F2F9D, 0x7B2A7A99, 0x79392693, 0x442D12C0, + 0x0692273E, 0x59A16E80, 0x5D956856, 0x44E73DAC, 0x0D874532, 0x5F5C1DD0, + 0x5D167858, 0x05597EA2, 0x1D821476, 0x59654ED2, 0x594C0DC7, 0x1A873506, + 0x3F693200, 0x7A651AB5, 0x20CC3C8A, 0x1F9E662C, 0x78E7631 , 0x2A01DA0 , + 0x3088472F, 0x12EE0D42, 0x360D4D5F, 0x73337E48, 0x0D634C06, 0x233A0ACB, + 0x706651ED, 0x7AA54079, 0x262239D1, 0x3EBB6BB6, 0x225A4F3D, 0x32581A06, + 0x6E6F5780, 0x577377C7, 0x75ED1DDC, 0x10DF2D15, 0x3C7929BC, 0x37175917, + 0x354E381C, 0x762A2DD7, 0x76435AC1, 0x73BB749E, 0x52FE4E7E, 0x6C8140F4, + 0x57694875, 0x12D30822, 0x474227CF, 0x37926D98, 0x121C7E24, 0x204E1EE7, + 0x58C6268 , 0x2152080 , 0x316C3323, 0x7AB14A31, 0x61C13C03, 0x7D8E74F1, + 0x73F446D0, 0x6C6C6A0A, 0x3BFD79FB, 0x67242969, 0x3E5524EB, 0x0FF5534 , + 0x52F05F1C, 0x17102DE3, 0x540F4A21, 0x798468E7, 0x419545EB, 0x193F7880, + 0x2B246B20, 0x408A2BC4, 0x4BF66A49, 0x40894C55, 0x4CAA6398, 0x247856E9, + 0x2F2A647D, 0x22F55D33, 0x70D37915, 0x50634C72, 0x5983671 , 0x2BCC5AF8, + 0x1A77D48 , 0x411B5CFA, 0x71074D7E, 0x3A6B3593, 0x61425F05, 0x6271012A, + 0x5B830310, 0x3D8418CA, 0x10A50792, 0x239F7137, 0x213D5071, 0x7F9930D4, + 0x2462664F, 0x54180F8E, 0x291505BA, 0x6586387A, 0x144B2C12, 0x18E425C7, + 0x3AA43373, 0x18F0503C, 0x19462AC0, 0x58B452EF, 0x72473895, 0x26BF5435, + 0x6DA553B , 0x60912FA6, 0x5C337331, 0x3D93CD7 , 0x4D035752, 0x20691929, + 0x389962F9, 0x36E701E9, 0x758B642C, 0x5FCA69E3, 0x596027F4, 0x2D5A2FD0, + 0x5F18324A, 0x3DB165AA, 0x76BA3876, 0x1BC21AF6, 0x3CC10841, 0x73A60174, + 0x625B7F58, 0x67C57724, 0x4458653C, 0x61573095, 0x2B370837, 0x03DF6CE3, + 0x5D086EFA, 0x3F5227C2, 0x191B4785, 0x60843D82, 0x30DE11F1, 0x105E226C, + 0x6E1C7AA2, 0x47AA5D14, 0x36676D03, 0x3B8D4DF6, 0x7372694 , 0x409521DC, + 0x744206A , 0x4722023F, 0x2BE46AD5, 0x63E11D76, 0x4A4A09AB, 0x5CF252B9, + 0x31586916, 0x4DFD7D84, 0x32037634, 0x2D7329D4, 0x4524582F, 0x2E5366C1, + 0x3B0E019B, 0x38530C6A, 0x6A2542D , 0x0A6A00E5, 0x119725CC, 0x54065347, + 0x1B6F7AF1, 0x6CCF71F1, 0x181117F2, 0x71674A76, 0x74F43880, 0x77A55F47, + 0x59EA5B62, 0x4A331D95, 0x3CBB276F, 0x245C4D50, 0x4718D5 , 0x07CE05D1, + 0x60D47AD5, 0x25CA1C40, 0x30061766, 0x669B39DF, 0x3D5F1320, 0x19306AD3, + 0x28B30325, 0x0DD090F , 0x6A6E6F37, 0x2DF16F66, 0x2B514C7E, 0x31101C58, + 0x7D4847FC, 0x515341CA, 0x77AB0EA6, 0x41320DAF, 0x3AF8531E, 0x24B31611, + 0x6D377331, 0x7A832A22, 0x222511C7, 0x722D1F89, 0x3B194F18, 0x261B0A4D, + 0x43F676DB, 0x4F8C6D61, 0x190F2250, 0x202E72A9, 0x560D4EA2, 0x308E67B4, + 0x36746663, 0x17CC3852, 0x27EB2EAC, 0x7FDE0AA8, 0x264719A , 0x23261EDD, + 0x3C0B339E, 0x06284D40, 0x48D82ECB, 0x24D44CF8, 0x43631B91, 0x4BF04248, + 0x36497B9B, 0x68273C58, 0x630B7AF9, 0x20CC3F26, 0x6C3B7B71, 0x574433ED, + 0x7A2552F6, 0x4CDE642D, 0x565B0142, 0x26F9207F, 0x67A207BE, 0x5B506684, + 0x44DA4780, 0x11756A0C, 0x156104AF, 0x415561B0, 0x6E3A6886, 0x1DBA1EA2, + 0x542359C8, 0x4C024E22, 0x758F052A, 0x1DD6395 , 0x2D194BAD, 0x616475A1, + 0x42084602, 0x09C274AD, 0x13CB5562, 0x57FE2D5B, 0x607A4EE5, 0x16723A91, + 0x4F624CCF, 0x2E5E24A3, 0x28FE6FAF, 0x3DDA6EF4, 0x32AF540C, 0x19A57B3B, + 0x5D1D73A3, 0x23424B3E, 0x278445F5, 0x53971C3B, 0x427D7943, 0x5221358C, + 0x26CE1A5E, 0x7B506CA4, 0x3B86636E, 0x60831F6D, 0x45E142F3, 0x21B77B04, + 0x7BB65E0C, 0x78B80F5E, 0x7D8D172B, 0x3BF33A90, 0x2D572D9 , 0x2B5B4920, + 0x36A05E01, 0x52745306, 0x47C64855, 0x1CAA669B, 0x304A2641, 0x4D6B1760, + 0x3E176D79, 0x523241B0, 0x24A67957, 0x4BDE76AF, 0x4E5F1493, 0x4C215DA5, + 0x33A052B , 0x1A4D00C2, 0x40AE6BCA, 0x390D106B, 0x69E86018, 0x5AF356CF, + 0x63561D4 , 0x44F31C6 , 0x14B6299B, 0x0D2E25F0, 0x4CBF132A, 0x45AC18B6, + 0x2227567D, 0x06B54E2F, 0x26344534, 0x22C515EC, 0x2442370D, 0x6C3721C6, + 0x34EF687D, 0x1C06323A, 0x6AF36A60, 0x60396F52, 0x6AE70AA1, 0x49D06CBC, + 0x6F9576C8, 0x584C4258, 0x3A9A27BB, 0x66DF0D47, 0x1D4804EA, 0x57DD1E67, + 0x789C7895, 0x75336111, 0x25C122C8, 0x62742114, 0x4FBF6D26, 0x3F9F6482, + 0x66F02CD9, 0x11083202, 0x499E2618, 0x7EBC1351, 0x440112F1, 0x49DF7BC1, + 0x3BF45C25, 0x31BA7FA0, 0x61AF1AED, 0x6B1F7D29, 0x2D865294, 0x63E01129, + 0x7E9E77A5, 0x100435D7, 0x1FE3A71 , 0x08597C81, 0x722849FA, 0x31C520AF, + 0x7BA178DC, 0x7F102D31, 0x5CA07864, 0x150E6F98, 0x02C34882, 0x5D041F11, + 0x0C613C57, 0x53984FD1, 0x426F38AD, 0x55992B1D, 0x7AFA078D, 0x2B253413, + 0x594B32CF, 0x32887E38, 0x28933B46, 0x1A0B4168, 0x291B4A94, 0x653A5E8D, + 0x21746BBE, 0x5EFE6415, 0x30DA429C, 0x50C5640C, 0x34711AA4, 0x529C67A6, + 0x105957CD, 0x4D287499, 0x03CA0AA7, 0x28385832, 0x25A04A02, 0x420D47A4, + 0x35627556, 0x4BC11E4C, 0x59E215C7, 0x27E838B4, 0x458612F4, 0x22827F6F, + 0x449D4DBA, 0x679B7362, 0x4E495845, 0x4FD270D1, 0x395E76A0, 0x375A655E, + 0x12E2058F, 0x73F970CA, 0x61EF73B3, 0x51FF5362, 0x67410345, 0x7FDA0B3B, + 0x221962E8, 0x17AB6543, 0x26557412, 0x4B30084D, 0x268E191D, 0x7E0D13DF, + 0x73EF127D, 0x4DEC5DB1, 0x77FA745F, 0x56002898, 0x12DD0A40, 0x157F6DDF, + 0x42A55F8E, 0x43597924, 0x7B630C3F, 0x338B6B58, 0x32945F75, 0x4FA23A0E, + 0x036E38C0, 0x33B18FD , 0x06114337, 0x24660ACB, 0x19BB02F0, 0x124C0A47, + 0x3A951701, 0x01155ABF, 0x0C612D71, 0x36074CA7, 0x51660C41, 0x635F58C7, + 0x7FC2002D, 0x0E6A7CF3, 0x65B07D07, 0x015F6A6B, 0x791B70DD, 0x6E475719, + 0x424314C7, 0x68426EB , 0x71942FEE, 0x464A2F52, 0x677579FD, 0x6BA775AE, + 0x1F66EFF , 0x1A795237, 0x78D9545F, 0x1D0B344D, 0x3BD34AB7, 0x2F85312A, + 0x16C542AD, 0x3990185D, 0x08DF3351, 0x02811AA5, 0x6D351F41, 0x4066269D, + 0x06B660BF, 0x6EDB4768, 0x5DD70CF0, 0x35D74F6E, 0x689E220C, 0x11431687, + 0x147C49C9, 0x385762BD, 0x302F0AE4, 0x1DAB67F8, 0x483256C9, 0x37D50FCB, + 0x4EA82711, 0x4D7B2C98, 0x19DB78BC, 0x58DE0DC2, 0x6AFF7E7B, 0x37621C93, + 0x792C6E19, 0x77001192, 0x7F88439D, 0x2E196A66, 0x6C71378C, 0x6AF43B3A, + 0x7C16225E, 0x6687337 , 0x4BEE1608, 0x6D5B5552, 0x345D4590, 0x681209CC, + 0x7B242819, 0x508A1416, 0x19880FE3, 0x1FC7288A, 0x24BD0502, 0x6A1D1678, + 0x20E6CA0 , 0x59BE2057, 0x5ADE11EB, 0x5EA8649D, 0x7A200E6F, 0x1149481D, + 0x72281E93, 0x0A5B0451, 0x67312D58, 0x63B849F1, 0x52217960, 0x7CDF59F3, + 0x33C775C0, 0x1EBA0799, 0x7DF1506 , 0x34E96110, 0x38FC73E3, 0x5EA059B2, + 0x022936EA, 0x316406F6, 0x43911185, 0x6C0D10F3, 0x1C6F3DF8, 0x38DB12A9, + 0x5CD41244, 0x2C9F0A7B, 0x5F4A315F, 0x77CE1C66, 0x4C800860, 0x318D53E0, + 0x7105420D, 0x575361F2, 0x750810BA, 0x217E4CA5, 0x2010140 , 0x4D884763, + 0x42BB0DA7, 0x32D53A74, 0x141C6CD4, 0x087F5FC3, 0x464B53 , 0x2D2A05F6, + 0x15532B45, 0x5D5C3CE1, 0x3EB9216A, 0x2214611B, 0x1FC52C5F, 0x11AE5DD7, + 0x20B925A9, 0x7C640AF4, 0x740009AC, 0x6D0E0321, 0x38E6A61 , 0x09104544, + 0x474F26C8, 0x15254CF3, 0x341A6B59, 0x661904CE, 0x598B2197, 0x2412659D, + 0x61976DD4, 0x329B3E16, 0x08FD1FB0, 0x304006F3, 0x3456309 , 0x55CC15F1, + 0x59DA7630, 0x5C801335, 0x0036D52 , 0x353775A5, 0x299476EB, 0x75280568, + 0x766F5264, 0x2EA233A6, 0x647619F3, 0x7FB30C7A, 0x1BC03B9 , 0x36BC3061, + 0x3F30596E, 0x3E2A527B, 0x0AC04220, 0x641979A3, 0x1ECC3B89, 0x21447BC1, + 0x4E8F2E26, 0x0C5A1D90, 0x299E5467, 0x57C947E3, 0x1D4865ED, 0x76F31C3D, + 0x4EE81CDF, 0x3479195E, 0x6FFB3AE1, 0x5C82398 , 0x300F7364, 0x47940AFA, + 0x3B853E3E, 0x598C440D, 0x224A3D89, 0x3A674204, 0x22880A38, 0x2E77F2D , + 0x22841C9C, 0x4F0609C3, 0x1FE90922, 0x09335017, 0x2D6B69A7, 0x7EDB63F9, + 0x099A74EF, 0x1F9F1B40, 0x24BE17E8, 0x251D2F7A, 0x16AC50D3, 0x28D7ED6 , + 0x6D193443, 0x76156F1B, 0x30DF6A4E, 0x64FF6794, 0x63DB2C9A, 0x74353022, + 0x556E025C, 0x23802AF9, 0x425018A4, 0x675A18BB, 0x70B227B9, 0x7FB01BF , + 0x63E7910 , 0x6C661591, 0x65745D2B, 0x4F6E379D, 0x52B32FAC, 0x1E6A1101, + 0x1DE22385, 0x2338191F, 0x469704B6, 0x4BAB4599, 0x54EB4809, 0x78393E6D, + 0x550017DD, 0x39B120E1, 0x288D52D3, 0x2D52668C, 0x20D22A68, 0x4E1207D1, + 0x3FCC0EFE, 0x47F37E64, 0x25177A90, 0x34BF5D4D, 0x5A8D3DCE, 0x6F7275A8, + 0x6BEA2655, 0x2A1810FC, 0x64DB593A, 0x0A4D4BC0, 0x2C402E93, 0x71C077F9, + 0x6F0C4577, 0x70412414, 0x752F1DC1, 0x582E38EA, 0x2C455F7B, 0x4DCD4EDB, + 0x12BC2696, 0x7B037135, 0x4FCA1F8C, 0x3D5E75F6, 0x502F41B0, 0x361653F1, + 0x2E5B0E31, 0x20266B19, 0x57E703D7, 0x467B3E00, 0x47032BA3, 0x1F776B9C, + 0x62570A84, 0x7EC75B48, 0x1BD5012 , 0x7D0A2D5D, 0x7FCC29F2, 0x291304B6, + 0x19D558ED, 0x47551C8 , 0x7D12738F, 0x3ADE0892, 0x5F741997, 0x25D2E2F , + 0x2B9F2269, 0x5C134FED, 0x15E92399, 0x54437F4E, 0x272D32AB, 0x56186AA1, + 0x7E4D355C, 0x234D7836, 0x2A871760, 0x4637A94 , 0x2C183207, 0x5FC78B3 , + 0x7F10621E, 0x276966B2, 0x6C9F4A11, 0x4E3F182C, 0x62BA2EF5, 0x25F239CD, + 0x73D63FED, 0x636E1F5E, 0x0AC15A0E, 0x3F3D33EB, 0x738326EA, 0x35C366B1, + 0x4D476E86, 0x02F63208, 0x711A1FC1, 0x426A4396, 0x7E4D1B93, 0x75E46DB7, + 0x2F3C44A7, 0x51A56F5C, 0x7AD2463D, 0x0A5639CA, 0x49952C78, 0x4C4B64F6, + 0x3AFE7F8D, 0x66993D04, 0x43867F37, 0x4BC146C2, 0x55A875EC, 0x681A1A75, + 0x30A67E1B, 0x4A4A7D0C, 0x20F77993, 0x1891805 , 0x738976AD, 0x542667D6, + 0x3C5C6EBF, 0x4499187F, 0x2BF17C97, 0x447C317F, 0x68D8419C, 0x7AAB6456, + 0x421B4F29, 0x76740F9C, 0x09163B8D, 0x3D72AAB , 0x1AD54DD7, 0x754946EE, + 0x7317342B, 0x218546D4, 0x10563DA7, 0x54BB4CCE, 0x0CE63E46, 0x5D146234, + 0x33BE6C63, 0x325044E5, 0x09D72335, 0x07C36BA , 0x365530CC, 0x2DFA448C, + 0x1663516F, 0x59B00AA , 0x150274EA, 0x12532D4A, 0x3CEF002D, 0x492F3DA5, + 0x263A2574, 0x6F8005C2, 0x14A10651, 0x2F627ABA, 0x68293238, 0x26987646, + 0x52590516, 0x10144D36, 0x59B151B9, 0x2B2A4F05, 0x53953699, 0x27851C75, + 0x180646F3, 0x2E970306, 0x32843145, 0x18F4FE8F +}; + +/* The source data is random across the q31_t range. Accessing it by word should + remain random. */ +const q15_t * fast_math_q15_inputs = (q15_t *) fast_math_q31_inputs; + +const float32_t fast_math_f32_inputs[FAST_MATH_MAX_LEN] = +{ + -1.5E-07, 5.0545058, 6.1958757, 0.1884450, 3.3656774, 0.5471223, + -5.0396892, 6.2149808, 0.4206357, 5.9024140, 0.1142128, 4.2966847, + -4.9243615, 3.3560853, 5.5628775, 5.6486144, 3.9328821, 0.8662564, + -1.3684878, 1.1444261, 0.2627620, 0.6719343, 3.8732286, 5.9040643, + -2.2271110, 2.5800587, 6.1848498, 5.9412493, 4.2514839, 6.2096863, + -4.8181437, 2.1155439, 4.1618680, 1.5341357, 1.8567268, 4.2736867, + -3.3165594, 2.5861183, 3.7864876, 4.7156566, 3.6664471, 3.4670146, + -3.6666823, 3.2158594, 0.5189454, 4.5211925, 6.2590334, 2.2276047, + -6.1025991, 2.1768018, 5.5703194, 2.8569321, 2.5976403, 1.3680509, + -0.7895111, 1.9409676, 4.5622487, 4.9189303, 4.3591961, 0.0615894, + -5.2980657, 5.7951829, 4.8440482, 0.2680398, 2.3762136, 4.4254964, + -4.5836656, 1.4091744, 1.6905207, 4.2287795, 3.0001720, 3.9189258, + -1.4856273, 1.1129014, 5.2128031, 4.8187110, 5.8715002, 0.6778860, + -1.1449692, 0.6226340, 3.0772767, 1.2141962, 5.6290528, 0.6225986, + -0.2775005, 3.5015887, 4.8537297, 1.9599772, 1.1245801, 2.1297213, + -1.3203840, 3.2053828, 5.6948550, 3.9516457, 0.6379562, 2.4558128, + -0.3431663, 3.1496534, 2.7125841, 6.2678565, 5.0994494, 3.0514394, + -5.6199810, 0.8642307, 2.4504731, 5.8267510, 5.7647838, 4.4835177, + 3.8851284, 2.1569414, 5.8812331, 0.7839784, 4.5904032, 4.0619375, + 5.2348483, 2.5024810, 4.7112719, 5.2478452, 2.0260784, 3.4699621, + 6.1520498, 3.4514073, 2.0761128, 3.8922546, 2.2659464, 4.7532896, + 2.6006151, 3.0934955, 4.3652005, 6.1118673, 2.0593452, 5.2640727, + 4.6437278, 5.9952549, 0.2005758, 2.2422740, 4.1635768, 1.7687265, + 1.4475395, 4.4681525, 3.9243074, 3.7109036, 4.1496541, 0.2987948, + 2.1914796, 2.8358565, 1.5136507, 4.4927603, 5.3795520, 1.7687650, + 4.5933278, 0.8655898, 5.2572843, 0.8708603, 3.6958286, 2.3006310, + 5.0690197, 3.1653480, 3.0762120, 5.5106597, 2.2188555, 2.8239372, + 6.0540393, 0.2657649, 6.1132775, 1.1888217, 4.1916405, 3.6847088, + 4.2418564, 2.2683684, 3.8973243, 5.0966113, 0.1209983, 0.5269928, + 6.1248595, 4.0925498, 1.4529100, 2.5352096, 0.7666775, 1.6866509, + 1.6200953, 2.0839142, 0.9565145, 2.1865966, 0.7644026, 5.5552975, + 0.5923686, 5.8436176, 2.5071164, 0.2978322, 2.1511962, 4.6242118, + 4.9931353, 3.4237447, 4.3116692, 5.6148598, 0.3442670, 1.9079607, + 0.2902301, 1.2282167, 4.5249352, 4.5349096, 5.5153742, 3.6595342, + 0.4441228, 5.7977751, 5.0288862, 1.7966571, 3.4159368, 6.1875316, + 4.4967379, 5.2714014, 2.7222564, 2.9570223, 3.5230663, 1.6907520, + 4.7062218, 3.1660203, 4.0640250, 1.9336225, 0.8716326, 2.9881129, + 2.2773988, 4.9518627, 4.9027432, 4.2003861, 0.8388295, 0.1354396, + 3.5175829, 1.8901016, 5.9024853, 6.1631993, 1.8008890, 5.0317023, + 5.6304337, 3.7543702, 5.5544410, 5.9296402, 3.4504620, 4.5765894, + 3.6238793, 0.1624673, 2.8056369, 4.0608350, 3.2748147, 2.3393094, + 5.8881908, 5.2121085, 5.3349614, 2.3407017, 3.7270886, 5.4824095, + 5.8653636, 4.2000849, 1.2992148, 4.1082644, 0.4527132, 2.5555406, + 4.1904544, 5.8667713, 5.0953493, 3.0445066, 4.7547955, 2.6203864, + 6.1059115, 6.2076281, 5.4295991, 2.4434288, 2.8572272, 1.5499814, + 4.9286757, 5.5470323, 5.7410198, 3.5078076, 3.7627993, 0.9354200, + 5.6530665, 2.8299063, 1.2922774, 5.6526739, 4.7914663, 5.5448250, + 1.7903950, 4.2300036, 4.1737937, 0.7716694, 2.5592571, 1.7296789, + 4.5029688, 1.7805566, 5.6309835, 5.1935484, 2.4506089, 3.1284165, + 4.3655898, 5.2424950, 3.8304163, 3.6111801, 2.0485834, 2.8678003, + 4.4849099, 5.5568808, 4.5292698, 0.1169475, 4.2397456, 2.7552322, + 2.7509053, 0.7353640, 5.1187960, 2.0411269, 1.5470969, 2.1533307, + 2.3605433, 3.4340988, 3.5306485, 2.4870244, 2.5015301, 3.2381477, + 4.1313862, 5.9747764, 4.5386496, 2.5137752, 5.2268018, 0.8440727, + 0.3799239, 0.5293398, 0.0000000, 2.0371338, 1.8958053, 0.0733938, + 3.3923238, 0.5992443, 0.9205800, 3.9655772, 5.3992694, 6.1212150, + 3.5866836, 6.2633946, 3.4780043, 3.2387210, 2.0777367, 2.7017810, + 3.0901098, 0.4463392, 5.5778300, 0.4061048, 2.7406309, 5.1938664, + 2.4789345, 3.8545764, 5.1436714, 5.5683790, 5.8503469, 1.1987353, + 1.6247202, 5.6414565, 3.7282025, 3.1657206, 3.8503962, 5.1485818, + 3.3419582, 1.2696753, 2.8518968, 2.6886436, 6.0698884, 3.8959208, + 4.3692639, 4.5249277, 2.1796068, 3.2483466, 3.4978155, 0.9832885, + 3.5315023, 4.3655778, 2.6794992, 5.2544420, 4.5954405, 2.2621418, + 2.8539005, 2.4277593, 4.8729535, 4.6135614, 2.7035154, 4.3589760, + 5.9389515, 4.9274787, 4.4332387, 0.6869673, 2.4500066, 3.7127639, + 2.8863700, 0.3162955, 1.4368865, 5.2413645, 0.0982985, 5.4268554, + 0.4905223, 4.2037186, 3.1429204, 1.3696954, 3.5915675, 0.7677371, + 4.2170618, 3.7673071, 0.3517086, 0.3540136, 0.9581898, 0.1232828, + 2.7342886, 5.2290017, 3.8791769, 3.2680695, 5.4278441, 0.6138541, + 5.7054603, 0.6786889, 3.2483864, 0.8994758, 3.5146290, 0.0287746, + 4.8172051, 5.3325973, 5.7605579, 6.2013046, 3.1738449, 1.7053924, + 0.6330341, 3.1909083, 3.6794907, 4.7933610, 0.5212697, 4.1569315, + 3.2482749, 1.0747264, 5.8971330, 3.7101152, 2.7685894, 5.9182512, + 4.1212281, 2.8396586, 5.2759745, 3.3465722, 3.4801751, 4.2729777, + 2.3071222, 1.5035072, 3.6374836, 5.4468120, 2.5558538, 0.7075818, + 2.7887656, 1.8861142, 2.5219880, 5.2361777, 2.5360737, 2.4515477, + 2.2647672, 0.8812504, 1.6344462, 0.5454754, 2.6979830, 1.6165554, + 1.8695956, 2.6694641, 0.7490013, 3.1105972, 4.4384875, 1.5304166, + 4.9327408, 0.4655185, 2.4748426, 0.0213259, 1.3865538, 0.0081717, + 1.1886509, 0.8952537, 1.6843712, 1.0988793, 0.8711572, 3.7629093, + 5.6615138, 5.9022971, 1.3897429, 3.0327137, 2.3625475, 3.2910070, + 1.6642436, 0.4295011, 2.7415239, 1.0923508, 0.1640358, 5.9984205, + 2.7055177, 6.0416507, 4.7903915, 0.0461730, 4.2728088, 4.4356194, + 4.0534637, 3.4702651, 1.3704176, 4.8529200, 1.4327442, 2.3302118, + 5.5978709, 5.3807748, 2.5285646, 1.9981730, 3.8241692, 5.7189253, + 5.7120324, 3.7170973, 2.0896078, 5.3599569, 2.7796679, 5.6822331, + 0.2084724, 3.3453343, 4.5018856, 1.1265867, 2.1144987, 1.1794352, + 2.0227281, 2.5375066, 3.4467437, 0.3062336, 3.4729184, 1.7266910, + 1.5174002, 1.5277262, 0.9686124, 6.0093412, 5.8789338, 5.1441345, + 4.5758041, 1.1046577, 2.2642776, 1.1862024, 0.0075297, 1.9881224, + 4.3958232, 3.9285942, 3.4121603, 2.7585521, 1.8059588, 3.1520171, + 4.7849358, 4.7903511, 3.6194660, 4.6977042, 4.0560129, 0.7742111, + 3.1692252, 2.1819072, 0.5789810, 0.9289656, 1.2451370, 4.2239985, + 2.7112647, 4.3630684, 1.6134250, 0.0613154, 3.3444332, 1.7554715, + 5.9453394, 5.6953510, 2.4673100, 0.1561700, 4.2187618, 5.2600982, + 6.1041123, 0.3577199, 2.8294680, 3.6597688, 4.3142726, 4.5203293, + 4.0843265, 4.5673388, 2.3489542, 3.6541880, 0.7295941, 0.3622530, + 6.1560465, 1.7896003, 3.7383338, 6.0454361, 1.1672793, 1.2129049, + 2.1466132, 5.8615704, 2.4546365, 1.7166712, 0.9547117, 2.4951084, + 2.3544507, 0.8238180, 2.7334414, 0.5749942, 3.8618151, 0.0689837, + 3.6019012, 4.9620190, 1.4788531, 2.8149909, 3.5773830, 0.3857966, + 3.1182750, 4.0357856, 1.3902536, 5.2593808, 6.1014456, 5.3179177, + 3.1792883, 1.7522271, 4.6911344, 1.4886775, 6.0151778, 3.8972087, + 3.7715583, 1.0845061, 0.5676653, 1.6038597, 5.3945577, 5.7244031, + 4.3959286, 4.5564551, 1.4444168, 3.6194506, 5.0933266, 2.5374227, + 6.2105471, 0.5654792, 2.0165320, 3.2132771, 0.3808010, 4.5596317, + 3.4969429, 3.3260664, 5.2149334, 5.3957421, 4.9576149, 1.9970040, + 2.8413032, 4.7263877, 0.6902815, 0.6895316, 1.6957291, 3.2963937, + 6.1113470, 4.4636294, 1.9594738, 1.8312791, 5.3429527, 5.7280497, + 4.0166905, 1.6045389, 0.5571039, 5.2669152, 3.6738954, 5.9571429, + 0.3834561, 3.6734096, 1.7913869, 5.2007946, 1.2000032, 2.7804978, + 2.4718774, 5.1935175, 4.2529065, 1.3044083, 1.9987109, 0.8407592, + 4.2189258, 3.5876427, 1.0666779, 0.9277486, 2.9912971, 5.7057758, + 3.4694180, 0.2069675, 0.3384307, 5.0583614, 2.8360719, 2.4042372, + 4.9614777, 2.2888819, 3.3448533, 4.4714710, 5.4756485, 2.0652177, + 4.0848120, 6.1250762, 0.4773170, 3.6883502, 2.6005256, 1.9423615, + 1.6577182, 4.7674690, 6.2531264, 1.1722630, 4.9080805, 1.2302350, + 6.2351753, 5.0407581, 2.6654950, 4.5795867, 3.1312479, 5.0830358, + 2.2400117, 0.4602021, 3.7133088, 5.7188788, 1.2174673, 2.7166470, + 4.7071094, 0.2462034, 5.9459353, 4.7983010, 3.5111731, 1.1551193, + 3.1287047, 3.2537199, 6.2470131, 5.3711915, 6.0469623, 4.2659122, + 2.5352740, 5.8746469, 3.0126903, 1.4563896, 2.4899651, 4.4301324, + 3.5095299, 4.7540509, 6.2547920, 6.0471349, 3.3619258, 6.0561746, + 0.7264988, 0.3232592, 1.9122808, 3.6454528, 3.3361480, 5.6624574, + 3.3963785, 2.7142142, 3.4096772, 4.4762342, 0.1047703, 5.0323343, + 0.8954125, 3.0063438, 1.6137441, 2.3190715, 4.1579916, 1.0656836, + 1.7516517, 1.2454643, 1.2256706, 2.0535941, 5.5313259, 2.9600203, + 2.5382144, 1.1261446, 6.0879353, 2.5601199, 5.3060708, 3.8662016, + 2.3663172, 5.5114955, 4.9313732, 2.9213939, 5.1143679, 5.6450910, + 2.6969853, 2.1006537, 3.7488443, 5.6673754, 4.4112136, 2.3716204, + 4.6178643, 5.9948046, 3.4105954, 3.3935850, 1.9547595, 0.4475800, + 1.1434170, 0.5842667, 2.9121888, 0.0586379, 5.7492774, 4.0384655, + 0.0089162, 0.1909163, 1.3098570, 2.8586366, 0.7996361, 0.0543350, + 4.5683759, 2.2249794, 4.9036865, 2.7435946, 2.7429546, 0.3092155, + 0.3118464, 0.5723993, 3.7324447, 1.5147758, 5.2864780, 5.3860266, + 6.0545540, 3.0718480, 1.3842492, 1.4213108, 3.3727372, 4.7884765, + 2.1838288, 2.8980046, 4.0169897, 5.7637923, 1.0151904, 4.4964699, + 3.6300404, 2.7224978, 5.5558613, 2.4696170, 1.1245340, 3.9793522, + 3.9207111, 2.0605178, 5.0451799, 6.2799046, 6.1636676, 0.7981966, + 1.4592079, 0.1484872, 3.8166117, 0.6962355, 2.5601436, 5.5548184, + 3.4440198, 2.3185147, 1.3090764, 2.7705283, 6.0079576, 0.7792778, + 2.9578927, 5.3840384, 0.2726304, 4.3456090, 6.1511471, 1.7798247, + 0.8405677, 4.3057392, 5.7142715, 3.8382030, 5.6547587, 1.2153801, + 4.7401894, 2.1756202, 2.6303011, 0.9784166, 5.1459324, 3.9265103, + 4.6405120, 5.0586705, 0.4223724, 5.9739917, 3.1263686, 4.7447217, + 4.6646686, 5.2221411, 0.9833301, 2.8733554, 3.8836400, 5.8570808, + -5.2470141, 5.6261119, 3.6600718, 3.6615062, 5.3716581, 0.2190677, + -5.5632585, 2.5618482, 0.2285950, 4.6881858, 0.9728179, 0.9042027, + -3.8073530, 1.5989503, 2.0367209, 2.5245268, 2.5533189, 2.4265105, + -3.8314979, 1.0486053, 1.1818174, 0.5945707, 2.0306392, 4.8355201, + -1.4710068, 4.6518534, 4.3531065, 5.1778361, 5.2023364, 1.8432851, + -1.9438243, 3.2862931, 2.0439139, 5.2266206, 5.0912323, 3.4997233, + -1.6522518, 4.2761236, 1.4680860, 2.8678051, 2.4163051, 3.3841326, + -6.2310582, 4.7451897, 6.1603795, 1.4751828, 3.3210347, 0.3231823, + -4.7555888, 3.7823504, 5.3857498, 6.2095284, 5.8401232, 2.5730582, + -0.0021455, 3.3984387, 1.3052100, 1.3777994, 2.0471011, 0.6028680, + -4.6968925, 4.7030205, 3.4136510, 2.1245480, 5.2297066, 3.4719134, + -6.0164208, 5.6098372, 2.2399783, 3.4331443, 2.1782657, 3.9131853, + -5.0053405, 4.6864702, 0.7887674, 5.1672539, 0.1580253, 2.6039335, + -4.5955687, 4.9095176, 2.3077255, 4.6801428, 5.6062801, 1.5243220, + -0.8142818, 1.4141432, 2.1992023, 1.8038058, 5.8275790, 0.3224138, + -3.7238350, 1.0235240, 5.2678588, 1.0528164, 3.1554195, 6.2789723, + -2.2330890, 0.2957980, 1.3424690, 2.4996969, 2.0964990, 1.4426353, + -5.8818165, 4.2926017, 6.0451393, 2.7518666, 5.9083095, 0.0366581, + -3.8346722, 5.0333074, 1.4638661, 5.8588735, 4.7957215, 5.1927356, + -3.6031780, 4.9799375, 2.0674268, 1.4040530, 1.9627813, 3.6726693, + -5.2145043, 1.8250297, 2.5293238, 5.4164658, 3.8625225, 6.2278165, + -1.2798778, 5.1975080, 4.2465638, 1.5641957, 2.9894493, 2.5074636, + -3.7663816, 5.0298329, 0.6601666, 5.1612735, 5.2847013, 2.2274284, + -2.7022061, 3.5954850, 4.4034117, 4.6650751, 4.7619266, 2.4449681, + -2.6973871, 6.0088907, 3.6000853, 5.3389611 +}; diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/biquad_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/biquad_tests.c new file mode 100644 index 0000000..3157d1c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/biquad_tests.c @@ -0,0 +1,244 @@ +#include "jtest.h" +#include "filtering_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "filtering_templates.h" +#include "type_abbrev.h" + +#define BIQUAD_DEFINE_TEST(suffix, instance_name, config_suffix, output_type) \ + JTEST_DEFINE_TEST(arm_biquad_cascade_##config_suffix##_##suffix##_test, \ + arm_biquad_cascade_##config_suffix##_##suffix) \ + { \ + instance_name biquad_inst_fut = { 0 }; \ + instance_name biquad_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numstages_idx, uint16_t, numStages, filtering_numstages \ + , \ + /* Initialize the BIQUAD Instances */ \ + arm_biquad_cascade_##config_suffix##_init_##suffix( \ + &biquad_inst_fut, numStages, \ + (output_type*)filtering_coeffs_b_##suffix, \ + (void *) filtering_pState); \ + \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Stages: %d\n", \ + (int)blockSize, \ + (int)numStages); \ + \ + JTEST_COUNT_CYCLES( \ + arm_biquad_cascade_##config_suffix##_##suffix( \ + &biquad_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + blockSize)); \ + \ + arm_biquad_cascade_##config_suffix##_init_##suffix( \ + &biquad_inst_ref, numStages, \ + (output_type*)filtering_coeffs_b_##suffix, \ + (void *) filtering_pState); \ + \ + ref_biquad_cascade_##config_suffix##_##suffix( \ + &biquad_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } + +#define BIQUAD_WITH_POSTSHIFT_DEFINE_TEST(suffix, config_suffix, speed, output_type) \ + JTEST_DEFINE_TEST(arm_biquad_cascade_##config_suffix##speed##_##suffix##_test, \ + arm_biquad_cascade_##config_suffix##speed##_##suffix) \ + { \ + arm_biquad_casd_##config_suffix##_inst_##suffix biquad_inst_fut = { 0 }; \ + arm_biquad_casd_##config_suffix##_inst_##suffix biquad_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numstages_idx, uint16_t, numStages, filtering_numstages \ + , \ + TEMPLATE_DO_ARR_DESC( \ + postshifts_idx, uint8_t, postShift, filtering_postshifts \ + , \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Stages: %d\n" \ + "Post Shift: %d\n", \ + (int)blockSize, \ + (int)numStages, \ + (int)postShift); \ + \ + /* Initialize the BIQUAD Instances */ \ + arm_biquad_cascade_##config_suffix##_init_##suffix( \ + &biquad_inst_fut, numStages, \ + (output_type*)filtering_coeffs_b_##suffix, \ + (void *) filtering_pState, postShift); \ + \ + JTEST_COUNT_CYCLES( \ + arm_biquad_cascade_##config_suffix##speed##_##suffix( \ + &biquad_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + blockSize)); \ + \ + arm_biquad_cascade_##config_suffix##_init_##suffix( \ + &biquad_inst_ref, numStages, \ + (output_type*)filtering_coeffs_b_##suffix, \ + (void *) filtering_pState, postShift); \ + \ + ref_biquad_cascade_##config_suffix##speed##_##suffix( \ + &biquad_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize, \ + output_type)))); \ + \ + return JTEST_TEST_PASSED; \ + } + + +JTEST_DEFINE_TEST(arm_biquad_cas_df1_32x64_q31_test, + arm_biquad_cas_df1_32x64_q31) +{ + arm_biquad_cas_df1_32x64_ins_q31 biquad_inst_fut = { 0 }; + arm_biquad_cas_df1_32x64_ins_q31 biquad_inst_ref = { 0 }; + + TEMPLATE_DO_ARR_DESC( + blocksize_idx, uint32_t, blockSize, filtering_blocksizes + , + TEMPLATE_DO_ARR_DESC( + numstages_idx, uint16_t, numStages, filtering_numstages + , + TEMPLATE_DO_ARR_DESC( + postshifts_idx, uint8_t, postShift, filtering_postshifts + , + /* Initialize the BIQUAD Instances */ + arm_biquad_cas_df1_32x64_init_q31( + &biquad_inst_fut, numStages, + (q31_t*)filtering_coeffs_b_q31, + (void *) filtering_pState, postShift); + + /* Display test parameter values */ + JTEST_DUMP_STRF("Block Size: %d\n" + "Number of Stages: %d\n", + (int)blockSize, + (int)numStages); + + JTEST_COUNT_CYCLES( + arm_biquad_cas_df1_32x64_q31( + &biquad_inst_fut, + (void *) filtering_q31_inputs, + (void *) filtering_output_fut, + blockSize)); + + arm_biquad_cas_df1_32x64_init_q31( + &biquad_inst_ref, numStages, + (q31_t*)filtering_coeffs_b_q31, + (void *) filtering_pState, postShift); + + ref_biquad_cas_df1_32x64_q31( + &biquad_inst_ref, + (void *) filtering_q31_inputs, + (void *) filtering_output_ref, + blockSize); + + FILTERING_SNR_COMPARE_INTERFACE( + blockSize, + q31_t)))); + + return JTEST_TEST_PASSED; +} + +JTEST_DEFINE_TEST(arm_biquad_cascade_df2T_f64_test, + arm_biquad_cascade_df2T_f64) +{ + arm_biquad_cascade_df2T_instance_f64 biquad_inst_fut = { 0 }; + arm_biquad_cascade_df2T_instance_f64 biquad_inst_ref = { 0 }; + + TEMPLATE_DO_ARR_DESC( + blocksize_idx, uint32_t, blockSize, filtering_blocksizes + , + TEMPLATE_DO_ARR_DESC( + numstages_idx, uint16_t, numStages, filtering_numstages + , + /* Display test parameter values */ + JTEST_DUMP_STRF("Block Size: %d\n" + "Number of Stages: %d\n", + (int)blockSize, + (int)numStages); + + /* Initialize the BIQUAD Instances */ + arm_biquad_cascade_df2T_init_f64( + &biquad_inst_fut, numStages, + (float64_t*)filtering_coeffs_b_f64, + (void *) filtering_pState); + + JTEST_COUNT_CYCLES( + arm_biquad_cascade_df2T_f64( + &biquad_inst_fut, + (void *) filtering_f64_inputs, + (void *) filtering_output_fut, + blockSize)); + + arm_biquad_cascade_df2T_init_f64( + &biquad_inst_ref, numStages, + (float64_t*)filtering_coeffs_b_f64, + (void *) filtering_pState); + + ref_biquad_cascade_df2T_f64( + &biquad_inst_ref, + (void *) filtering_f64_inputs, + (void *) filtering_output_ref, + blockSize); + + FILTERING_DBL_SNR_COMPARE_INTERFACE( + blockSize, + float64_t))); + + return JTEST_TEST_PASSED; +} + + +BIQUAD_DEFINE_TEST(f32,arm_biquad_casd_df1_inst_f32, df1,float32_t); +BIQUAD_DEFINE_TEST(f32,arm_biquad_cascade_df2T_instance_f32,df2T,float32_t); +BIQUAD_DEFINE_TEST(f32,arm_biquad_cascade_stereo_df2T_instance_f32,stereo_df2T,float32_t); +BIQUAD_WITH_POSTSHIFT_DEFINE_TEST(q31,df1,,q31_t); +BIQUAD_WITH_POSTSHIFT_DEFINE_TEST(q15,df1,,q15_t); +BIQUAD_WITH_POSTSHIFT_DEFINE_TEST(q31,df1,_fast,q31_t); +BIQUAD_WITH_POSTSHIFT_DEFINE_TEST(q15,df1,_fast,q15_t); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(biquad_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_biquad_cascade_df1_f32_test); + JTEST_TEST_CALL(arm_biquad_cascade_df2T_f32_test); + JTEST_TEST_CALL(arm_biquad_cascade_stereo_df2T_f32_test); + JTEST_TEST_CALL(arm_biquad_cascade_df2T_f64_test); + JTEST_TEST_CALL(arm_biquad_cascade_df1_q31_test); + JTEST_TEST_CALL(arm_biquad_cascade_df1_q15_test); + JTEST_TEST_CALL(arm_biquad_cascade_df1_fast_q31_test); + JTEST_TEST_CALL(arm_biquad_cascade_df1_fast_q15_test); + JTEST_TEST_CALL(arm_biquad_cas_df1_32x64_q31_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/conv_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/conv_tests.c new file mode 100644 index 0000000..c2fdf0f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/conv_tests.c @@ -0,0 +1,473 @@ +#include "jtest.h" +#include "filtering_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "filtering_templates.h" +#include "type_abbrev.h" + +/*--------------------------------------------------------------------------------*/ +/* Header Stuff */ +/*--------------------------------------------------------------------------------*/ + +#define CONV_MAX_INPUT_ELTS 32 +#define CONV_MAX_OUTPUT_ELTS (CONV_MAX_INPUT_ELTS * 2) + +#define CONV_TEST_VALID_PARTIAL_PARAMS(input_a_len, input_b_len, \ + first_index, num_points) \ + (((((input_a_len) + (input_b_len) - 1)) >= num_points + first_index ) \ + && (num_points > 0)) + +/*--------------------------------------------------------------------------------*/ +/* Input Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* + * General: + * Input interfaces provide inputs to functions inside test templates. They + * ONLY provide the inputs. The output variables should be hard coded. + * + * The input interfaces must have the following format: + * + * ARM_xxx_INPUT_INTERFACE() or + * REF_xxx_INPUT_INTERFACE() + * + * The xxx must be lowercase, and is intended to be the indentifying substring + * in the function's name. Acceptable values are 'sub' or 'add' from the + * functions arm_add_q31. + */ + +#define CONV_arm_conv_INPUT_INTERFACE(input_a, input_a_len, input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_fut) + +#define CONV_ref_conv_INPUT_INTERFACE(input_a, input_a_len, input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_ref) + +#define CONV_arm_conv_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_fut, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CONV_ref_conv_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_ref, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CONV_arm_conv_fast_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_fut) + +#define CONV_ref_conv_fast_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_ref) + +#define CONV_arm_conv_fast_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_fut, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CONV_ref_conv_fast_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_ref, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CONV_arm_conv_partial_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_fut, first_index, num_points) + +#define CONV_ref_conv_partial_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_ref, first_index, num_points) + +#define CONV_arm_conv_partial_fast_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_fut, first_index, num_points) + +#define CONV_ref_conv_partial_fast_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_ref, first_index, num_points) + +#define CONV_arm_conv_partial_opt_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_fut, first_index, num_points, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CONV_ref_conv_partial_opt_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_ref, first_index, num_points, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CONV_arm_conv_partial_fast_opt_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_fut, first_index, num_points, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CONV_ref_conv_partial_fast_opt_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len, \ + first_index, num_points) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*)filtering_output_ref, first_index, num_points, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +/*--------------------------------------------------------------------------------*/ +/* Convolution Inputs */ +/*--------------------------------------------------------------------------------*/ + +/* The following symbols alias the filtering_q31_inputs array: + * + * - filtering_q15_inputs + * - filtering_q7_inputs + * + * The aliasing conflicts with the instantiation of #ARR_DESC_t structs. + * + * These macro-level aliases allow the #CONV_DEFINE_RAND_INPUT_ARR_DESCS() macro + * to correctly select the filtering_q31_input or filtering_f32_input array, + * within a template, by type_suffix. + * + */ +#define CONV_f32_INPUTS filtering_f32_inputs +#define CONV_q31_INPUTS filtering_q31_inputs +#define CONV_q15_INPUTS filtering_q31_inputs +#define CONV_q7_INPUTS filtering_q31_inputs + +/** + * Defines #ARR_DESC_t objects that wrap existing, type-specific, common + * inputs. + */ +#define CONV_DEFINE_RAND_INPUT_ARR_DESCS(type_suffix) \ + ARR_DESC_DEFINE_USING_ARR( \ + TYPE_FROM_ABBREV(type_suffix), \ + conv_input_rand1_##type_suffix, \ + CONV_##type_suffix##_INPUTS, \ + 0, \ + CONV_MAX_INPUT_ELTS); \ + \ + ARR_DESC_DEFINE_USING_ARR( \ + TYPE_FROM_ABBREV(type_suffix), \ + conv_input_rand2_##type_suffix, \ + CONV_##type_suffix##_INPUTS, \ + 1, \ + CONV_MAX_INPUT_ELTS) /* Note the lacking semicolon */ + +CONV_DEFINE_RAND_INPUT_ARR_DESCS(f32); +CONV_DEFINE_RAND_INPUT_ARR_DESCS(q31); +CONV_DEFINE_RAND_INPUT_ARR_DESCS(q15); +CONV_DEFINE_RAND_INPUT_ARR_DESCS(q7); +ARR_DESC_DEFINE(float32_t, conv_input_zeros, CONV_MAX_INPUT_ELTS, CURLY(0)); + +/** + * Define Input #ARR_DESC_t arrays by type suffix. + * + * Taking inputs in parallel from the 'a' and 'b' arrays yields the following + * test cases (star is convolution): + * + * - zero_array * zero_array + * - zero_array * random_array + * - random_array * zero_array + * - random_array * different_random_arary + */ +#define CONV_DEFINE_ALL_INPUTS(type_suffix) \ + ARR_DESC_DEFINE(ARR_DESC_t *, \ + conv_##type_suffix##_a_inputs, \ + 4, \ + CURLY( \ + &conv_input_zeros, \ + &conv_input_zeros, \ + &conv_input_rand1_##type_suffix, \ + &conv_input_rand1_##type_suffix \ + )); \ + ARR_DESC_DEFINE(ARR_DESC_t *, \ + conv_##type_suffix##_b_inputs, \ + 4, \ + CURLY( \ + &conv_input_zeros, \ + &conv_input_rand1_##type_suffix, \ + &conv_input_zeros, \ + &conv_input_rand2_##type_suffix \ + )) /* Note the lacking semicolon */ + +CONV_DEFINE_ALL_INPUTS(f32); +CONV_DEFINE_ALL_INPUTS(q31); +CONV_DEFINE_ALL_INPUTS(q15); +CONV_DEFINE_ALL_INPUTS(q7); + +/*--------------------------------------------------------------------------------*/ +/* Convolution Lengths */ +/*--------------------------------------------------------------------------------*/ + +/* + * The conv_lens_a and conv_lens_b #ARR_DESC_t objects are accessed in parallel + * to provide convolution-length pairs. Taken in parallel they provide the + * following cases: + * + * - 1 * 1 : Shortest convolution possible. + * - 1 * 2 : Short convolution , one side is degenerate . + * - 17 * 1 : Medium convolution , one side is degenerate . + * - 15 * MAX : Longest convolution , one side is degenerate . + * MAX * MAX : Longest convolution. + */ +ARR_DESC_DEFINE(uint32_t, + conv_lens_a, + 5, + CURLY( + 1, + 1, + 17, + 15, + CONV_MAX_INPUT_ELTS + )); + +ARR_DESC_DEFINE(uint32_t, + conv_lens_b, + 5, + CURLY( + 1, + 2, + 1, + CONV_MAX_INPUT_ELTS, + CONV_MAX_INPUT_ELTS + )); + +/*--------------------------------------------------------------------------------*/ +/* Partial Indexing */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(uint32_t, + first_index_arr_desc, + 4, + CURLY( + 0, + 1, + CONV_MAX_INPUT_ELTS / 2, + CONV_MAX_INPUT_ELTS + )); + +ARR_DESC_DEFINE(uint32_t, + num_points_arr_desc, + 3, + CURLY( + 1, + CONV_MAX_OUTPUT_ELTS / 2, + CONV_MAX_OUTPUT_ELTS + )); + +/*--------------------------------------------------------------------------------*/ +/* Convolution Tests */ +/*--------------------------------------------------------------------------------*/ + +#define CONV_TEST_TEMPLATE(fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + suffix, output_type) \ + JTEST_DEFINE_TEST(fut##_tests, fut) \ + { \ + TEMPLATE_DO_ARR_DESC( \ + input_idx, ARR_DESC_t *, input_ptr, conv_##suffix##_a_inputs \ + , \ + void * input_a_ptr = input_ptr->data_ptr; \ + void * input_b_ptr = ARR_DESC_ELT( \ + ARR_DESC_t *, input_idx, \ + &(conv_##suffix##_b_inputs))->data_ptr; \ + \ + TEMPLATE_DO_ARR_DESC( \ + conv_len_idx, uint32_t, conv_len_a, conv_lens_a \ + , \ + uint32_t conv_len_b = ARR_DESC_ELT( \ + uint32_t, conv_len_idx, &(conv_lens_b)); \ + \ + JTEST_DUMP_STRF("Input A Length: %d\n" \ + "Input B Length: %d\n", \ + (int)conv_len_a, \ + (int)conv_len_b); \ + \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + input_a_ptr, conv_len_a, input_b_ptr, conv_len_b), \ + ref, ref_arg_interface( \ + input_a_ptr, conv_len_a, input_b_ptr, conv_len_b)); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + conv_len_a + conv_len_b - 1, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } \ + \ + +#define CONV_PARTIAL_TEST_TEMPLATE(fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + suffix, output_type) \ + JTEST_DEFINE_TEST(fut##_tests, fut) \ + { \ + TEMPLATE_DO_ARR_DESC( \ + input_idx, ARR_DESC_t *, input_ptr, conv_##suffix##_a_inputs \ + , \ + void * input_a_ptr = input_ptr->data_ptr; \ + void * input_b_ptr = ARR_DESC_ELT( \ + ARR_DESC_t *, input_idx, \ + &(conv_##suffix##_b_inputs))->data_ptr; \ + TEMPLATE_DO_ARR_DESC( \ + conv_len_idx, uint32_t, conv_len_a, conv_lens_a \ + , \ + uint32_t conv_len_b = ARR_DESC_ELT( \ + uint32_t, conv_len_idx, &(conv_lens_b)); \ + \ + TEMPLATE_DO_ARR_DESC( \ + first_index_idx, uint32_t, first_index, \ + first_index_arr_desc \ + , \ + TEMPLATE_DO_ARR_DESC( \ + num_points_idx, uint32_t, num_points, \ + num_points_arr_desc \ + , \ + if (CONV_TEST_VALID_PARTIAL_PARAMS( \ + conv_len_a, conv_len_b, \ + first_index, num_points)) \ + { \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Input A Length: %d\n" \ + "Input B Length: %d\n" \ + "First Sample Index: %d\n" \ + "Number of Output Points: %d\n", \ + (int)conv_len_a, \ + (int)conv_len_b, \ + (int)first_index, \ + (int)num_points); \ + \ + memset(filtering_output_ref,0, \ + (2*CONV_MAX_INPUT_ELTS)*sizeof(output_type)); \ + memset(filtering_output_fut,0, \ + (2*CONV_MAX_INPUT_ELTS)*sizeof(output_type)); \ + \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + input_a_ptr, conv_len_a, \ + input_b_ptr, conv_len_b, \ + first_index, num_points), \ + ref, ref_arg_interface( \ + input_a_ptr, conv_len_a, \ + input_b_ptr, conv_len_b, \ + first_index, num_points)); \ + \ + FILTERING_SNR_COMPARE_INTERFACE_OFFSET( \ + first_index, \ + num_points, \ + output_type); \ + } else { \ + /* FUT should return ARM_MATH_ARGUMENT_ERROR*/ \ + /* if first_index and num_points don't make */ \ + /* sense*/ \ + \ + arm_status conv_test_retval; \ + TEST_CALL_FUT( \ + conv_test_retval = fut, \ + fut_arg_interface( \ + input_a_ptr, conv_len_a, \ + input_b_ptr, conv_len_b, \ + first_index, num_points)); \ + \ + if (conv_test_retval != ARM_MATH_ARGUMENT_ERROR) { \ + JTEST_DUMP_STR("FUT failed to raise error."); \ + /* return JTEST_TEST_FAILED; */ \ + } \ + })))); \ + \ + return JTEST_TEST_PASSED; \ + } + +#define CONV_DEFINE_TEST(fn_name, suffix, output_type, test_template) \ + test_template( \ + arm_##fn_name##_##suffix, \ + CONV_arm_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + CONV_ref_##fn_name##_INPUT_INTERFACE, \ + suffix, \ + output_type \ + ) /* Note the lacking semicolon*/ + +/* Tests on functions without partial outputs */ +CONV_DEFINE_TEST(conv , f32, float32_t, CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv , q31, q31_t , CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv , q15, q15_t , CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv , q7 , q7_t , CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_opt , q15, q15_t , CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_opt , q7 , q7_t , CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_fast , q31, q31_t , CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_fast , q15, q15_t , CONV_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_fast_opt , q15, q15_t , CONV_TEST_TEMPLATE); + +/* Tests on functions with partial outputs */ +CONV_DEFINE_TEST(conv_partial , f32, float32_t, CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial , q31, q31_t , CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial , q15, q15_t , CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial , q7 , q7_t , CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial_fast , q31, q31_t , CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial_fast , q15, q15_t , CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial_fast_opt , q15, q15_t , CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial_opt , q15, q15_t , CONV_PARTIAL_TEST_TEMPLATE); +CONV_DEFINE_TEST(conv_partial_opt , q7 , q7_t , CONV_PARTIAL_TEST_TEMPLATE); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(conv_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_conv_f32_tests); + JTEST_TEST_CALL(arm_conv_q31_tests); + JTEST_TEST_CALL(arm_conv_q15_tests); + JTEST_TEST_CALL(arm_conv_q7_tests); + + JTEST_TEST_CALL(arm_conv_opt_q15_tests); + JTEST_TEST_CALL(arm_conv_opt_q7_tests); + + JTEST_TEST_CALL(arm_conv_fast_q31_tests); + JTEST_TEST_CALL(arm_conv_fast_q15_tests); + + JTEST_TEST_CALL(arm_conv_fast_opt_q15_tests); + + JTEST_TEST_CALL(arm_conv_partial_f32_tests); + JTEST_TEST_CALL(arm_conv_partial_q31_tests); + JTEST_TEST_CALL(arm_conv_partial_q15_tests); + JTEST_TEST_CALL(arm_conv_partial_q7_tests); + + JTEST_TEST_CALL(arm_conv_partial_fast_q31_tests); + JTEST_TEST_CALL(arm_conv_partial_fast_q15_tests); + + JTEST_TEST_CALL(arm_conv_partial_fast_opt_q15_tests); + + JTEST_TEST_CALL(arm_conv_partial_opt_q15_tests); + JTEST_TEST_CALL(arm_conv_partial_opt_q7_tests); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/correlate_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/correlate_tests.c new file mode 100644 index 0000000..689b075 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/correlate_tests.c @@ -0,0 +1,310 @@ +#include "jtest.h" +#include "filtering_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "filtering_templates.h" +#include "type_abbrev.h" + +/*--------------------------------------------------------------------------------*/ +/* Header Stuff */ +/*--------------------------------------------------------------------------------*/ + +#define CORRELATE_MAX_INPUT_ELTS 32 +#define CORRELATE_MAX_OUTPUT_ELTS (CORRELATE_MAX_INPUT_ELTS * 2) + +/*--------------------------------------------------------------------------------*/ +/* Input Interfaces */ +/*--------------------------------------------------------------------------------*/ +/* + * General: + * Input interfaces provide inputs to functions inside test templates. They + * ONLY provide the inputs. The output variables should be hard coded. + * + * The input interfaces must have the following format: + * + * ARM_xxx_INPUT_INTERFACE() or + * REF_xxx_INPUT_INTERFACE() + * + * The xxx must be lowercase, and is intended to be the indentifying substring + * in the function's name. Acceptable values are 'sub' or 'add' from the + * functions arm_add_q31. + */ + +#define CORRELATE_arm_correlate_INPUT_INTERFACE(input_a, input_a_len, input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_fut) + +#define CORRELATE_ref_correlate_INPUT_INTERFACE(input_a, input_a_len, input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_ref) + +#define CORRELATE_arm_correlate_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_fut, \ + (void*) filtering_scratch) + +#define CORRELATE_arm_correlate_opt_q7_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_fut, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CORRELATE_ref_correlate_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_ref, \ + (void*) filtering_scratch) + +#define CORRELATE_ref_correlate_opt_q7_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_ref, \ + (void*) filtering_scratch, \ + (void*) filtering_scratch2) + +#define CORRELATE_arm_correlate_fast_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_fut) + +#define CORRELATE_ref_correlate_fast_INPUT_INTERFACE(input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, (void*)filtering_output_ref) + +#define CORRELATE_arm_correlate_fast_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_fut, \ + (void*) filtering_scratch) + +#define CORRELATE_ref_correlate_fast_opt_INPUT_INTERFACE( \ + input_a, input_a_len, \ + input_b, input_b_len) \ + PAREN(input_a, input_a_len, input_b, input_b_len, \ + (void*) filtering_output_ref, \ + (void*) filtering_scratch) + +/*--------------------------------------------------------------------------------*/ +/* Convolution Inputs */ +/*--------------------------------------------------------------------------------*/ + +/* The following symbols alias the filtering_q31_inputs array: + * + * - filtering_q15_inputs + * - filtering_q7_inputs + * + * The aliasing conflicts with the instantiation of #ARR_DESC_t structs. + * + * These macro-level aliases allow the #CORRELATE_DEFINE_RAND_INPUT_ARR_DESCS() macro + * to correctly select the filtering_q31_input or filtering_f32_input array, + * within a template, by type_suffix. + * + */ +#define CORRELATE_f32_INPUTS filtering_f32_inputs +#define CORRELATE_q31_INPUTS filtering_q31_inputs +#define CORRELATE_q15_INPUTS filtering_q31_inputs +#define CORRELATE_q7_INPUTS filtering_q31_inputs + +/** + * Defines #ARR_DESC_t objects that wrap existing, type-specific, common + * inputs. + */ +#define CORRELATE_DEFINE_RAND_INPUT_ARR_DESCS(type_suffix) \ + ARR_DESC_DEFINE_USING_ARR( \ + TYPE_FROM_ABBREV(type_suffix), \ + correlate_input_rand1_##type_suffix, \ + CORRELATE_##type_suffix##_INPUTS, \ + 0, \ + CORRELATE_MAX_INPUT_ELTS); \ + \ + ARR_DESC_DEFINE_USING_ARR( \ + TYPE_FROM_ABBREV(type_suffix), \ + correlate_input_rand2_##type_suffix, \ + CORRELATE_##type_suffix##_INPUTS, \ + 1, \ + CORRELATE_MAX_INPUT_ELTS) /* Note the lacking semicolon */ + +CORRELATE_DEFINE_RAND_INPUT_ARR_DESCS(f32); +CORRELATE_DEFINE_RAND_INPUT_ARR_DESCS(q31); +CORRELATE_DEFINE_RAND_INPUT_ARR_DESCS(q15); +CORRELATE_DEFINE_RAND_INPUT_ARR_DESCS(q7); +ARR_DESC_DEFINE(float32_t, correlate_input_zeros, CORRELATE_MAX_INPUT_ELTS, CURLY(0)); + +/** + * Define Input #ARR_DESC_t arrays by type suffix. + * + * Taking inputs in parallel from the 'a' and 'b' arrays yields the following + * test cases (star is correlate): + * + * - zero_array * zero_array + * - zero_array * random_array + * - random_array * zero_array + * - random_array * different_random_arary + */ +#define CORRELATE_DEFINE_ALL_INPUTS(type_suffix) \ + ARR_DESC_DEFINE(ARR_DESC_t *, \ + correlate_##type_suffix##_a_inputs, \ + 4, \ + CURLY( \ + &correlate_input_zeros, \ + &correlate_input_zeros, \ + &correlate_input_rand1_##type_suffix, \ + &correlate_input_rand1_##type_suffix \ + )); \ + ARR_DESC_DEFINE(ARR_DESC_t *, \ + correlate_##type_suffix##_b_inputs, \ + 4, \ + CURLY( \ + &correlate_input_zeros, \ + &correlate_input_rand1_##type_suffix, \ + &correlate_input_zeros, \ + &correlate_input_rand2_##type_suffix \ + )) /* Note the lacking semicolon */ + +CORRELATE_DEFINE_ALL_INPUTS(f32); +CORRELATE_DEFINE_ALL_INPUTS(q31); +CORRELATE_DEFINE_ALL_INPUTS(q15); +CORRELATE_DEFINE_ALL_INPUTS(q7); + +/*--------------------------------------------------------------------------------*/ +/* Convolution Lengths */ +/*--------------------------------------------------------------------------------*/ + +/* + * The correlate_lens_a and correlate_lens_b #ARR_DESC_t objects are accessed in parallel + * to provide correlate-length pairs. Taken in parallel they provide the + * following cases: + * + * - 1 * 1 : Shortest correlate possible. + * - 1 * 2 : Short correlate , one side is degenerate. + * - 17 * 1 : Medium correlate, one side is degenerate. + * - 15 * MAX : Longest correlate. + * MAX * MAX : Longest correlate. + */ +ARR_DESC_DEFINE(uint32_t, + correlate_lens_a, + 5, + CURLY( + 1, + 1, + 17, + 15, + CORRELATE_MAX_INPUT_ELTS + )); + +ARR_DESC_DEFINE(uint32_t, + correlate_lens_b, + 5, + CURLY( + 1, + 2, + 1, + CORRELATE_MAX_INPUT_ELTS, + CORRELATE_MAX_INPUT_ELTS + )); + +/*--------------------------------------------------------------------------------*/ +/* Convolution Tests */ +/*--------------------------------------------------------------------------------*/ + +#define CORRELATE_TEST_TEMPLATE(fut, fut_arg_interface, \ + ref, ref_arg_interface, \ + suffix, output_type) \ + JTEST_DEFINE_TEST(fut##_tests, fut) \ + { \ + TEMPLATE_DO_ARR_DESC( \ + input_idx, ARR_DESC_t *, input_ptr, correlate_##suffix##_a_inputs \ + , \ + void * input_a_ptr = input_ptr->data_ptr; \ + void * input_b_ptr = ARR_DESC_ELT( \ + ARR_DESC_t *, input_idx, \ + &(correlate_##suffix##_b_inputs))->data_ptr; \ + \ + TEMPLATE_DO_ARR_DESC( \ + correlate_len_idx, uint32_t, correlate_len_a, correlate_lens_a \ + , \ + uint32_t correlate_len_b = ARR_DESC_ELT( \ + uint32_t, correlate_len_idx, &(correlate_lens_b)); \ + \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Input A Length: %d\n" \ + "Input B Length: %d\n", \ + (int)correlate_len_a, \ + (int)correlate_len_b); \ + \ + memset(filtering_output_ref,0, \ + (2*CORRELATE_MAX_INPUT_ELTS)*sizeof(output_type)); \ + memset(filtering_output_fut,0, \ + (2*CORRELATE_MAX_INPUT_ELTS)*sizeof(output_type)); \ + \ + TEST_CALL_FUT_AND_REF( \ + fut, fut_arg_interface( \ + input_a_ptr, correlate_len_a, input_b_ptr, correlate_len_b), \ + ref, ref_arg_interface( \ + input_a_ptr, correlate_len_a, input_b_ptr, correlate_len_b)); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + correlate_len_a + correlate_len_b - 2, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } + +#define CORRELATE_DEFINE_TEST(fn_name, suffix, output_type, test_template) \ + test_template( \ + arm_##fn_name##_##suffix, \ + CORRELATE_arm_##fn_name##_INPUT_INTERFACE, \ + ref_##fn_name##_##suffix, \ + CORRELATE_ref_##fn_name##_INPUT_INTERFACE, \ + suffix, \ + output_type \ + ) /* Note the lacking semicolon*/ + +/* Tests on functions without partial outputs */ +CORRELATE_DEFINE_TEST(correlate , f32, float32_t, CORRELATE_TEST_TEMPLATE); +CORRELATE_DEFINE_TEST(correlate , q31, q31_t , CORRELATE_TEST_TEMPLATE); +CORRELATE_DEFINE_TEST(correlate , q15, q15_t , CORRELATE_TEST_TEMPLATE); +CORRELATE_DEFINE_TEST(correlate , q7 , q7_t , CORRELATE_TEST_TEMPLATE); +CORRELATE_DEFINE_TEST(correlate_opt , q15, q15_t , CORRELATE_TEST_TEMPLATE); + +CORRELATE_TEST_TEMPLATE( + arm_correlate_opt_q7, + CORRELATE_arm_correlate_opt_q7_INPUT_INTERFACE, + ref_correlate_opt_q7, + CORRELATE_ref_correlate_opt_q7_INPUT_INTERFACE, + q7, + q7_t + ); + +CORRELATE_DEFINE_TEST(correlate_fast , q31, q31_t , CORRELATE_TEST_TEMPLATE); +CORRELATE_DEFINE_TEST(correlate_fast , q15, q15_t , CORRELATE_TEST_TEMPLATE); +CORRELATE_DEFINE_TEST(correlate_fast_opt , q15, q15_t , CORRELATE_TEST_TEMPLATE); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(correlate_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_correlate_f32_tests); + JTEST_TEST_CALL(arm_correlate_q31_tests); + JTEST_TEST_CALL(arm_correlate_q15_tests); + JTEST_TEST_CALL(arm_correlate_q7_tests); + + JTEST_TEST_CALL(arm_correlate_opt_q15_tests); + JTEST_TEST_CALL(arm_correlate_opt_q7_tests); + + JTEST_TEST_CALL(arm_correlate_fast_q31_tests); + JTEST_TEST_CALL(arm_correlate_fast_q15_tests); + + JTEST_TEST_CALL(arm_correlate_fast_opt_q15_tests); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_common_data.c new file mode 100644 index 0000000..3bd1afb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_common_data.c @@ -0,0 +1,757 @@ +#include "filtering_test_data.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +//must be max(LMS_MAX_BLOCKSIZE*2, FILTERING_MAX_BLOCKSIZE * FILTERING_MAX_L) +float32_t filtering_output_fut[LMS_MAX_BLOCKSIZE*2] = {0}; +float32_t filtering_output_ref[LMS_MAX_BLOCKSIZE*2] = {0}; +float32_t filtering_output_f32_fut[LMS_MAX_BLOCKSIZE*2] = {0}; +float32_t filtering_output_f32_ref[LMS_MAX_BLOCKSIZE*2] = {0}; +float32_t filtering_input_lms[LMS_MAX_BLOCKSIZE*2] = {0}; +float32_t filtering_pState[LMS_MAX_BLOCKSIZE + FILTERING_MAX_NUMTAPS] = {0}; +float32_t filtering_scratch[FILTERING_MAX_BLOCKSIZE * 3] = {0}; +float32_t filtering_scratch2[FILTERING_MAX_BLOCKSIZE * 3] = {0}; +float32_t filtering_coeffs_lms[FILTERING_MAX_NUMTAPS]; + +const q31_t filtering_q31_inputs[FILTERING_MAX_BLOCKSIZE * FILTERING_MAX_M + FILTERING_MAX_NUMTAPS] = +{ + 0xC14A5524, 0xCCABDA17, 0xAD6F5B56, 0xFDAFCE3B, 0xA9B226EB, + 0x41F6F6A, 0xA5CE38BF, 0x3A978AFA, 0xBA44B82A, 0x855C0F8, + 0x3D060524, 0x93D5E570, 0x97D7791D, 0xFFE0C38C, 0x26749841, + 0xC0A6EE54, 0x218EC386, 0x39FF3726, 0x8DC1F7CA, 0x702F2CF5, + 0xC1142FF1, 0xEC1476AB, 0x15F640DD, 0xE62CCE49, 0x3805DE7E, + 0xF70871FE, 0xCF8BD360, 0x8D19A8A0, 0xD764F821, 0xA58558CF, + 0x8C0CE04D, 0x50A46C19, 0x66D2370D, 0x50FA359A, 0xB646AE24, + 0x6CE00F5C, 0xE6D48948, 0xB55BD831, 0x3B72950A, 0x9EB69530, + 0x73394127, 0x773FA6F4, 0x9805A980, 0x838DE587, 0x9CF597F4, + 0xA2AD1691, 0xFA81A473, 0x7CDC7D7F, 0x4A5190D0, 0xED895BB9, + 0x8FD60F35, 0x1A21D530, 0xA0EB6DDA, 0xBDE6A516, 0x2501A3E1, + 0x5ED893C8, 0xE1E175B1, 0xACBBB2F3, 0xED350907, 0xDB140D7E, + 0xEEAE272D, 0xBE229841, 0xC18BFB88, 0xA6BB9B80, 0xBCF090E4, + 0x24DB166C, 0xF9AB7E42, 0x62DF28D1, 0xC7004665, 0xE3F56FC6, + 0x419E0C75, 0x46BE9F38, 0x2432B9B2, 0x758D83E0, 0xDCE12926, + 0x3F57CB74, 0x1F4458E2, 0xF1DD639, 0x83A1FB49, 0x173AFC76, + 0x86EF7531, 0x48D32F34, 0x7D3E3063, 0x8F2FB549, 0x5C314C9, + 0x18CBEB6D, 0xA6F8B697, 0x447B9E9C, 0x2E32BA33, 0xD074D715, + 0x81ACD746, 0xE55A4E04, 0x4891860F, 0x1DA3EB4F, 0xE0E6A27F, + 0x20BFDEB4, 0xD0B3A25B, 0x40C10544, 0xC15656C, 0x15405EAE, + 0x9858E3E1, 0xA36A9C4E, 0x88BD21F9, 0xAACF7A68, 0x773665E5, + 0xCEDFDF66, 0x617A9610, 0x524FC968, 0xC2D086CD, 0x5F008079, + 0x24DCA447, 0x6A4F5599, 0xB706CD4A, 0x1DE70608, 0xA33A2EE5, + 0x137E488E, 0x98061B7B, 0x4079D69D, 0xA4A897D5, 0xC4CEC8F5, + 0xD75F7883, 0x22406802, 0xF1AD70BB, 0x9D4ADD79, 0xBCBC7CE4, + 0xB358C0D8, 0x85792E47, 0xA7ADAC05, 0x3D19EEAB, 0x331AC0AF, + 0x33035831, 0x13D93987, 0xFC542094, 0x845F317E, 0xDDC4BF8B, + 0x1379E50C, 0x5C20193F, 0xFDD58298, 0x9D482B82, 0x4A6BE062, + 0xDC8A757B, 0x272917C1, 0x90E1EFBC, 0x355AD882, 0xE6F8EA35, + 0x604555A1, 0x7DFFFBB, 0xF58AE216, 0x9A11B463, 0xD3541BAD, + 0xA1576756, 0x483BED8D, 0x1F05AFCC, 0xCEA63DFB, 0x55B84677, + 0xFB2E04F2, 0x787AF96C, 0x84A12CD3, 0x460A9BD, 0x9DB22DD8, + 0x1A8C7F28, 0x861E452E, 0x932D3F78, 0x7652D852, 0x73357BBA, + 0xEBBB0A58, 0x62536AFA, 0x3F6B65EF, 0x6DC57B58, 0x9EB798CE, + 0xE6B0A740, 0xDFF68B47, 0x3247FB8F, 0xFFF3D302, 0xA9FD3E40, + 0x475A43D1, 0x6FF9528A, 0x2018A09D, 0x47E0F9C9, 0x4CF5F6D3, + 0x2807CE34, 0xDD6FD8ED, 0x234045D1, 0x51CEB5F9, 0x25297896, + 0x6443A0FE, 0x8F4449A9, 0xD4C3E1C6, 0xF01D52F1, 0x4E09C820, + 0xF18F0810, 0xE1548689, 0xF9DE5A1F, 0x5286DC23, 0x48AC3A4B, + 0xEA0C1BE0, 0xA1B785DB, 0x7086465D, 0x1CC10929, 0x1E1D716E, + 0xED231D4C, 0x2049D108, 0xB8FF9971, 0x949CF8D4, 0x441F1E8B, + 0xC3D95372, 0x69C324B4, 0xA10BFDC9, 0xC781DE78, 0x82476137, + 0xE163DDF, 0x390DEEC2, 0xAF68CE5B, 0x8E680ABD, 0x8223A615, + 0x92593380, 0x7B1465FE, 0x865AE957, 0x930F53EB, 0xED772EF7, + 0x10E916B6, 0xE3BCFA68, 0x2ACB80BB, 0xE51C5590, 0x994714B5, + 0xF30984EE, 0x59BBE1B4, 0xB4867DBC, 0xB91C706C, 0xBC16C218, + 0xA8931CD0, 0x129A66AB, 0x13171F4D, 0x62882872, 0x4B167FD4, + 0xE6902F4C, 0xFA794932, 0xD4B152C, 0xB0856EA9, 0x39466D55, + 0x3669E451, 0x8F5B9E8C, 0x877A3C6A, 0x51B956B4, 0x367EAD2A, + 0x9D2C662A, 0x78FB6880, 0x4E6D40B6, 0x4070EFDC, 0x4DF9679C, + 0x20306EDB, 0xE381AAE7, 0xA55DA748, 0x9B8B617B, 0x3E036FAD, + 0x84E4C4A7, 0xD5A3F517, 0x669BA988, 0x98FDDE8C, 0x67BD85CE, + 0x34BBB46C, 0x76994800, 0x85B9D8B6, 0x6DFA2FEF, 0x205DB5C, + 0x9F843C4C, 0x72721B52, 0x73EF6B86, 0x5FB98B61, 0xC323DDAC, + 0x31D424B4, 0xF68C0D7E, 0x162FAF9D, 0x7B2A7A99, 0xF9392693, + 0xC42D12C0, 0x8692A73E, 0xD9A1EE80, 0xDD956856, 0x44E7BDAC, + 0x8D874532, 0x5F5C9DD0, 0x5D167858, 0x8559FEA2, 0x9D821476, + 0xD9654ED2, 0x594C0DC7, 0x1A87B506, 0x3F693200, 0x7A651AB5, + 0xA0CCBC8A, 0x9F9E662C, 0x78EF631, 0x2A09DA0, 0xB088C72F, + 0x92EE0D42, 0x360DCD5F, 0xF333FE48, 0x8D63CC06, 0x233A8ACB, + 0x706651ED, 0x7AA5C079, 0x262239D1, 0x3EBBEBB6, 0xA25A4F3D, + 0x32581A06, 0x6E6FD780, 0x5773F7C7, 0x75ED1DDC, 0x90DF2D15, + 0xBC79A9BC, 0xB7175917, 0x354E381C, 0x762AADD7, 0xF643DAC1, + 0xF3BBF49E, 0xD2FECE7E, 0x6C8140F4, 0xD7694875, 0x92D30822, + 0xC742A7CF, 0xB792ED98, 0x121CFE24, 0xA04E1EE7, 0x58CE268, + 0x215A080, 0x316CB323, 0xFAB14A31, 0xE1C13C03, 0xFD8EF4F1, + 0xF3F446D0, 0x6C6CEA0A, 0xBBFDF9FB, 0x67242969, 0xBE55A4EB, + 0x8FF5534, 0x52F0DF1C, 0x9710ADE3, 0xD40F4A21, 0x7984E8E7, + 0x419545EB, 0x993F7880, 0xAB246B20, 0x408AABC4, 0xCBF6EA49, + 0xC0894C55, 0x4CAA6398, 0xA47856E9, 0xAF2AE47D, 0x22F55D33, + 0xF0D37915, 0xD0634C72, 0xD983671, 0x2BCC5AF8, 0x9A77D48, + 0xC11B5CFA, 0xF107CD7E, 0x3A6B3593, 0xE1425F05, 0x6271812A, + 0x5B838310, 0xBD8418CA, 0x10A58792, 0x239F7137, 0xA13D5071, + 0x7F9930D4, 0xA462664F, 0x54180F8E, 0x291585BA, 0xE586B87A, + 0x144B2C12, 0x98E425C7, 0xBAA4B373, 0x18F0D03C, 0x99462AC0, + 0xD8B4D2EF, 0x72473895, 0xA6BF5435, 0xEDAD53B, 0xE0912FA6, + 0x5C33F331, 0x3D93CD7, 0x4D03D752, 0x20699929, 0xB89962F9, + 0x36E781E9, 0xF58B642C, 0x5FCA69E3, 0x5960A7F4, 0xAD5AAFD0, + 0xDF18324A, 0x3DB1E5AA, 0x76BA3876, 0x1BC29AF6, 0xBCC18841, + 0x73A60174, 0x625BFF58, 0x67C57724, 0x4458E53C, 0xE157B095, + 0x2B370837, 0x83DF6CE3, 0xDD08EEFA, 0x3F52A7C2, 0x191B4785, + 0x60843D82, 0xB0DE11F1, 0x105EA26C, 0x6E1C7AA2, 0x47AADD14, + 0xB6676D03, 0x3B8D4DF6, 0x737A694, 0x409521DC, 0x744206A, + 0xC722023F, 0x2BE4EAD5, 0x63E11D76, 0xCA4A09AB, 0x5CF2D2B9, + 0x31586916, 0xCDFD7D84, 0xB203F634, 0xAD7329D4, 0xC524582F, + 0x2E53E6C1, 0xBB0E019B, 0xB8538C6A, 0x6A2542D, 0x8A6A00E5, + 0x119725CC, 0x5406D347, 0x1B6FFAF1, 0xECCF71F1, 0x981117F2, + 0x7167CA76, 0x74F4B880, 0x77A55F47, 0x59EADB62, 0x4A331D95, + 0xBCBBA76F, 0xA45C4D50, 0xC718D5, 0x87CE05D1, 0x60D47AD5, + 0xA5CA9C40, 0xB0061766, 0xE69B39DF, 0xBD5F1320, 0x9930EAD3, + 0xA8B38325, 0x8DD090F, 0x6A6EEF37, 0x2DF16F66, 0xAB514C7E, + 0x31109C58, 0xFD48C7FC, 0x515341CA, 0x77AB8EA6, 0x41328DAF, + 0xBAF8D31E, 0xA4B31611, 0xED37F331, 0x7A832A22, 0xA22591C7, + 0x722D1F89, 0x3B19CF18, 0x261B8A4D, 0xC3F6F6DB, 0xCF8CED61, + 0x990FA250, 0xA02E72A9, 0x560DCEA2, 0xB08E67B4, 0x3674E663, + 0x97CC3852, 0xA7EB2EAC, 0xFFDE0AA8, 0xA64719A, 0x23269EDD, + 0x3C0B339E, 0x86284D40, 0x48D82ECB, 0xA4D4CCF8, 0x43631B91, + 0x4BF0C248, 0xB6497B9B, 0x6827BC58, 0xE30B7AF9, 0xA0CCBF26, + 0x6C3B7B71, 0xD744B3ED, 0xFA25D2F6, 0x4CDE642D, 0xD65B8142, + 0xA6F9207F, 0xE7A207BE, 0xDB506684, 0x44DA4780, 0x9175EA0C, + 0x156104AF, 0x4155E1B0, 0x6E3A6886, 0x9DBA1EA2, 0x5423D9C8, + 0xCC024E22, 0x758F852A, 0x1DD6395, 0x2D19CBAD, 0xE164F5A1, + 0xC2084602, 0x89C274AD, 0x13CB5562, 0xD7FE2D5B, 0xE07A4EE5, + 0x1672BA91, 0x4F624CCF, 0x2E5EA4A3, 0x28FEEFAF, 0xBDDA6EF4, + 0x32AFD40C, 0x99A5FB3B, 0xDD1D73A3, 0xA342CB3E, 0xA78445F5, + 0x53979C3B, 0x427D7943, 0x5221B58C, 0xA6CE9A5E, 0xFB50ECA4, + 0xBB86E36E, 0x60839F6D, 0xC5E1C2F3, 0xA1B7FB04, 0xFBB65E0C, + 0x78B80F5E, 0xFD8D972B, 0x3BF3BA90, 0x2D572D9, 0x2B5BC920, + 0xB6A0DE01, 0xD274D306, 0xC7C6C855, 0x9CAA669B, 0xB04AA641, + 0x4D6B1760, 0x3E17ED79, 0xD23241B0, 0xA4A6F957, 0xCBDE76AF, + 0x4E5F9493, 0x4C215DA5, 0x33A052B, 0x1A4D80C2, 0x40AEEBCA, + 0x390D106B, 0xE9E8E018, 0x5AF3D6CF, 0xE35E1D4, 0xC4FB1C6, + 0x14B6299B, 0x8D2E25F0, 0xCCBF932A, 0xC5AC18B6, 0x2227567D, + 0x86B5CE2F, 0x26344534, 0x22C515EC, 0x2442B70D, 0xEC3721C6, + 0x34EF687D, 0x9C06323A, 0xEAF3EA60, 0x60396F52, 0xEAE78AA1, + 0xC9D06CBC, 0x6F95F6C8, 0x584CC258, 0xBA9A27BB, 0x66DF8D47, + 0x9D4804EA, 0x57DD9E67, 0xF89C7895, 0xF5336111, 0x25C122C8, + 0x62742114, 0xCFBF6D26, 0xBF9F6482, 0xE6F02CD9, 0x11083202, + 0xC99E2618, 0x7EBC9351, 0x440112F1, 0xC9DFFBC1, 0x3BF4DC25, + 0xB1BA7FA0, 0x61AF9AED, 0x6B1F7D29, 0xAD865294, 0xE3E01129, + 0x7E9E77A5, 0x100435D7, 0x9FE3A71, 0x88597C81, 0x722849FA, + 0x31C5A0AF, 0xFBA178DC, 0x7F102D31, 0x5CA07864, 0x950E6F98, + 0x82C34882, 0x5D041F11, 0x8C613C57, 0xD398CFD1, 0x426F38AD, + 0x5599AB1D, 0xFAFA078D, 0xAB25B413, 0xD94B32CF, 0xB288FE38, + 0x2893BB46, 0x9A0B4168, 0xA91BCA94, 0x653A5E8D, 0x2174EBBE, + 0xDEFE6415, 0x30DA429C, 0xD0C5E40C, 0xB4719AA4, 0xD29CE7A6, + 0x905957CD, 0xCD287499, 0x83CA0AA7, 0xA8385832, 0x25A0CA02, + 0xC20D47A4, 0xB562F556, 0x4BC19E4C, 0xD9E215C7, 0x27E838B4, + 0xC58612F4, 0xA2827F6F, 0xC49DCDBA, 0x679B7362, 0x4E495845, + 0xCFD2F0D1, 0x395E76A0, 0x375A655E, 0x92E2058F, 0x73F9F0CA, + 0x61EFF3B3, 0x51FFD362, 0xE7410345, 0x7FDA8B3B, 0xA219E2E8, + 0x17ABE543, 0x26557412, 0x4B30084D, 0xA68E191D, 0xFE0D93DF, + 0x73EF127D, 0x4DECDDB1, 0x77FAF45F, 0xD6002898, 0x92DD0A40, + 0x157F6DDF, 0xC2A55F8E, 0x4359F924, 0xFB630C3F, 0x338B6B58, + 0xB2945F75, 0x4FA23A0E, 0x836EB8C0, 0xB3B18FD, 0x86114337, + 0x24668ACB, 0x99BB82F0, 0x924C8A47, 0xBA959701, 0x81155ABF, + 0x8C612D71, 0x36074CA7, 0xD1668C41, 0xE35F58C7, 0x7FC2802D, + 0x8E6A7CF3, 0x65B07D07, 0x815F6A6B, 0x791BF0DD, 0x6E47D719, + 0xC24394C7, 0xE84A6EB, 0xF194AFEE, 0x464A2F52, 0x677579FD, + 0xEBA775AE, 0x1F6EEFF, 0x9A795237, 0x78D9D45F, 0x9D0B344D, + 0xBBD34AB7, 0x2F85B12A, 0x16C5C2AD, 0x3990985D, 0x88DF3351, + 0x82811AA5, 0x6D351F41, 0x4066A69D, 0x86B660BF, 0x6EDB4768, + 0xDDD78CF0, 0xB5D74F6E, 0xE89E220C, 0x91439687, 0x947CC9C9, + 0x3857E2BD, 0x302F8AE4, 0x1DABE7F8, 0x4832D6C9, 0x37D58FCB, + 0x4EA8A711, 0xCD7BAC98, 0x19DBF8BC, 0xD8DE8DC2, 0xEAFF7E7B, + 0xB7629C93, 0x792C6E19, 0xF7009192, 0xFF88439D, 0x2E196A66, + 0xEC71B78C, 0xEAF4BB3A, 0x7C16225E, 0x668F337, 0xCBEE1608, + 0x6D5B5552, 0x345DC590, 0x681209CC, 0x7B24A819, 0xD08A1416, + 0x99888FE3, 0x9FC7288A, 0x24BD8502, 0xEA1D9678, 0x20EECA0, + 0x59BEA057, 0x5ADE91EB, 0xDEA8E49D, 0xFA200E6F, 0x9149C81D, + 0xF2281E93, 0x8A5B0451, 0x67312D58, 0xE3B849F1, 0xD2217960, + 0x7CDF59F3, 0x33C775C0, 0x9EBA8799, 0x7DF9506, 0xB4E96110, + 0xB8FCF3E3, 0xDEA059B2, 0x8229B6EA, 0x316486F6, 0x43919185, + 0x6C0D90F3, 0x1C6F3DF8, 0x38DB92A9, 0x5CD41244, 0x2C9F0A7B, + 0xDF4A315F, 0xF7CE9C66, 0x4C800860, 0x318D53E0, 0xF105C20D, + 0xD753E1F2, 0x750810BA, 0xA17ECCA5, 0x2010140, 0x4D884763, + 0xC2BB0DA7, 0xB2D5BA74, 0x141CECD4, 0x887FDFC3, 0xC64B53, + 0x2D2A85F6, 0x15532B45, 0x5D5CBCE1, 0xBEB9A16A, 0xA214611B, + 0x9FC5AC5F, 0x11AE5DD7, 0xA0B9A5A9, 0xFC648AF4, 0x740009AC, + 0xED0E0321, 0xB8E6A61, 0x8910C544, 0xC74F26C8, 0x9525CCF3, + 0xB41AEB59, 0xE61984CE, 0x598B2197, 0xA412E59D, 0xE1976DD4, + 0xB29BBE16, 0x88FD9FB0, 0xB04006F3, 0xB45E309, 0xD5CC15F1, + 0xD9DAF630, 0xDC809335, 0x803ED52, 0xB537F5A5, 0xA994F6EB, + 0xF5288568, 0xF66FD264, 0x2EA2B3A6, 0x647619F3, 0xFFB38C7A, + 0x1BC03B9, 0xB6BC3061, 0xBF30596E, 0xBE2AD27B, 0x8AC04220, + 0x641979A3, 0x9ECCBB89, 0xA144FBC1, 0x4E8FAE26, 0x8C5A9D90, + 0x299ED467, 0xD7C9C7E3, 0x1D4865ED, 0x76F31C3D, 0xCEE81CDF, + 0xB479195E, 0x6FFB3AE1, 0xDC8A398, 0x300F7364, 0xC7940AFA, + 0x3B85BE3E, 0xD98CC40D, 0xA24A3D89, 0x3A674204, 0x22888A38, + 0x2E77F2D, 0xA2841C9C, 0xCF0689C3, 0x9FE98922, 0x89335017, + 0x2D6B69A7, 0xFEDB63F9, 0x899AF4EF, 0x9F9F9B40, 0xA4BE97E8, + 0xA51DAF7A, 0x16AC50D3, 0xA8D7ED6, 0xED193443, 0x7615EF1B, + 0xB0DF6A4E, 0x64FFE794, 0xE3DB2C9A, 0x7435B022, 0x556E825C, + 0x23802AF9, 0xC25098A4, 0xE75A18BB, 0x70B2A7B9, 0x7FB81BF, + 0x63EF910, 0x6C669591, 0x6574DD2B, 0xCF6E379D, 0xD2B3AFAC, + 0x1E6A1101, 0x1DE22385, 0x2338191F, 0xC69704B6, 0xCBABC599, + 0x54EB4809, 0x7839BE6D, 0xD50017DD, 0x39B1A0E1, 0x288D52D3, + 0x2D52668C, 0x20D22A68, 0x4E1207D1, 0x3FCC0EFE, 0x47F3FE64, + 0x25177A90, 0xB4BFDD4D, 0xDA8DBDCE, 0x6F7275A8, 0x6BEAA655, + 0xAA1810FC, 0xE4DB593A, 0x8A4D4BC0, 0x2C402E93, 0xF1C0F7F9, + 0x6F0CC577, 0x70412414, 0x752F9DC1, 0xD82E38EA, 0xAC455F7B, + 0x4DCD4EDB, 0x92BC2696, 0xFB03F135, 0x4FCA1F8C, 0xBD5E75F6, + 0x502F41B0, 0x3616D3F1, 0x2E5B8E31, 0x2026EB19, 0x57E783D7, + 0x467BBE00, 0x4703ABA3, 0x1F776B9C, 0xE2570A84, 0xFEC7DB48, + 0x1BD5012, 0xFD0A2D5D, 0x7FCC29F2, 0x291304B6, 0x99D5D8ED, + 0xC7551C8, 0xFD12F38F, 0xBADE8892, 0xDF749997, 0xA5DAE2F, + 0x2B9FA269, 0x5C13CFED, 0x15E9A399, 0x54437F4E, 0xA72DB2AB, + 0x56186AA1, 0xFE4DB55C, 0xA34D7836, 0x2A879760, 0xC63FA94, + 0xAC18B207, 0x5FC78B3, 0x7F10621E, 0xA769E6B2, 0xEC9F4A11, + 0xCE3F982C, 0x62BA2EF5, 0xA5F239CD, 0x73D63FED, 0xE36E9F5E, + 0x8AC1DA0E, 0x3F3DB3EB, 0x738326EA, 0x35C366B1, 0xCD476E86, + 0x82F6B208, 0xF11A9FC1, 0x426AC396, 0x7E4D1B93, 0x75E4EDB7, + 0xAF3C44A7, 0x51A5EF5C, 0xFAD2463D, 0x8A5639CA, 0xC995AC78, + 0xCC4BE4F6, 0x3AFE7F8D, 0x66993D04, 0x4386FF37, 0xCBC1C6C2, + 0x55A8F5EC, 0xE81A9A75, 0x30A67E1B, 0x4A4A7D0C, 0x20F7F993, + 0x1891805, 0x738976AD, 0xD426E7D6, 0x3C5CEEBF, 0x4499187F, + 0xABF17C97, 0x447C317F, 0x68D8419C, 0x7AAB6456, 0x421BCF29, + 0xF6740F9C, 0x8916BB8D, 0x3D72AAB, 0x9AD54DD7, 0x7549C6EE, + 0x7317342B, 0xA18546D4, 0x1056BDA7, 0x54BBCCCE, 0x8CE63E46, + 0x5D146234, 0x33BE6C63, 0xB250C4E5, 0x89D72335, 0x87C36BA, + 0xB65530CC, 0x2DFAC48C, 0x1663D16F, 0x59B80AA, 0x950274EA, + 0x92532D4A, 0x3CEF802D, 0x492FBDA5, 0xA63A2574, 0xEF8005C2, + 0x94A18651, 0xAF627ABA, 0x6829B238, 0xA698F646, 0xD2598516, + 0x10144D36, 0xD9B1D1B9, 0xAB2ACF05, 0x5395B699, 0xA7851C75, + 0x1806C6F3, 0xAE970306, 0x3284B145, 0x98F4FE8F, 0xECDD35CC, + 0xDDC1EE0E, 0xC4848865, 0x925826BD, 0x4078BE39, 0x68A8561A, + 0x323045DC, 0xA933B37F, 0xBA2AEE2E, 0x4F24F65D, 0x349EE246, + 0xF97B9D0E, 0x46DC5759, 0x4529F425, 0x80D17B42, 0x8E16F709, + 0x1B42206A, 0x4934A526, 0x391BB6DE, 0xB52EF45C, 0x26C30290, + 0xCBA23CAA, 0xA501A8C3, 0xD922C4F8, 0xE8824E53, 0x6F4255DC, + 0x5960B544, 0x58BC69D6, 0xCA936323, 0xFDDF053C, 0xC2E002D6, + 0x7D750755, 0x8A3F9CD1, 0x35F8F6F8, 0xFB7BD154, 0x65CFF94F, + 0x390A58DD, 0xD97C4093, 0x501CA2A3, 0x8EA5DEBC, 0xCA93461F, + 0xE02D984C, 0x126F8517, 0x39FDD887, 0x46241AE9, 0x777E854D, + 0xE2B36349, 0x58E3FA9F, 0x971DEF1E, 0x8E156228, 0xC0E14E9, + 0xA9A01BE6, 0xB318C990, 0x971680D6, 0xA1F359CE, 0x487E23F4, + 0x7DE465B0, 0x4E4C905E, 0x2A652959, 0x116FF167, 0x5C74AAB9, + 0x467BBE00, 0x4703ABA3, 0x1F776B9C, 0xE2570A84, 0xFEC7DB48, + 0x1BD5012, 0xFD0A2D5D, 0x7FCC29F2, 0x291304B6, 0x99D5D8ED, + 0xC7551C8, 0xFD12F38F, 0xBADE8892, 0xDF749997, 0xA5DAE2F, + 0x2B9FA269, 0x5C13CFED, 0x15E9A399, 0x54437F4E, 0xA72DB2AB, + 0x56186AA1, 0xFE4DB55C, 0xA34D7836, 0x2A879760, 0xC63FA94, + 0xAC18B207, 0x5FC78B3, 0x7F10621E, 0xA769E6B2, 0xEC9F4A11, + 0xCE3F982C, 0x62BA2EF5, 0xA5F239CD, 0x4FEFC920, 0x28DF4EB8, + 0x29EBF45A, 0x1E350CF6 + }; + +/* The source data is random across the q31_t range. Accessing it by word should + remain random. */ +const q15_t * filtering_q15_inputs = (q15_t *) filtering_q31_inputs; +const q7_t * filtering_q7_inputs = (q7_t *) filtering_q31_inputs; + +const float32_t filtering_f32_inputs[FILTERING_MAX_BLOCKSIZE * FILTERING_MAX_M + FILTERING_MAX_NUMTAPS] = +{ + 43.0264275639 , -17.0525215570 , -94.8488973910 , -8.1924989580 , 7.2830326091 , 66.8368719314 , 33.9778190671 , 117.8652289772 , + -129.6077797465, -14.6420815368 , 18.0239223278 , 20.6760530292 , 55.0375037651 , 1.8674609862 , -85.6534302408 , -33.5750364909 , + 29.2110949614 , 110.4727049460 , -94.1914619387 , -1.4084169343 , 83.5181653041 , 47.3073514127 , -13.3420621181 , 30.3389699104 , + 12.1188124277 , 100.9730921941 , -114.0146362390, -77.5823200409 , 37.2019034618 , 40.0026301128 , -58.3387276630 , -34.9472398600 , + -5.1169678311 , -87.7660091118 , -150.5888601131, 56.0349370503 , 50.2168884079 , -74.2313236767 , 22.3648603560 , -6.8676387051 , + 74.8957303680 , -90.1292012823 , -55.1436241586 , -66.6732976100 , -6.7918147615 , 7.7612697081 , 35.7892605979 , -20.0470508830 , + 41.8369017546 , -143.7378056984, -41.9127158600 , -108.3531841158, -57.1917422289 , -124.2808828105, 38.9316388820 , -77.9212517405 , + 37.1990818377 , -28.9545952748 , -155.6371057564, 45.8088886393 , 36.2537018275 , -6.5727656016 , -104.2070491921, 45.5583813729 , + -19.7674717059 , -80.4802190947 , -1.4444563441 , -42.2142256438 , 36.6546339194 , -57.0866498590 , 44.4677067511 , 65.7285753407 , + -103.8158864647, 25.4348723711 , -153.5419639389, 39.3608409474 , 49.1658103436 , 79.5570602275 , 75.2944095996 , 58.9394700746 , + -53.1018534392 , 33.4172444014 , 35.6224682287 , -64.4353396418 , -125.8464291251, -47.6072111617 , -26.2177687594 , -12.0061322096 , + -17.7887967585 , -28.2926175090 , -62.0691715749 , 40.5098573604 , -191.1123732593, 119.6750713043 , 19.6182375803 , -26.7615252921 , + 2.2957847015 , -108.3436451287, -50.5906164995 , -5.6360985100 , -11.6772204201 , -84.2765293757 , -60.9317810068 , 82.0446350218 , + -70.2048296348 , 72.8738253222 , 60.2450218115 , 114.2741231228 , 46.8180775285 , 6.9915412654 , -8.9909197429 , -78.9165936808 , + 66.4731535459 , -68.4235455651 , -79.8254597080 , -10.6308477115 , -62.6161569330 , -55.7744410292 , -11.8408366528 , 98.1034940997 , + 35.8213741877 , -54.4694482732 , 86.9631830044 , -53.0343838122 , -47.4898642865 , -47.2010929590 , -31.3312639685 , -23.0908245172 , + 12.0258009869 , -5.1098204703 , -9.8420230737 , -107.3328761158, 44.6810431959 , -17.9083820345 , -60.9753512872 , -7.5915088994 , + 17.2250813329 , 57.9176125648 , 124.3004161362 , -63.1950908493 , 120.5788885640 , -44.1734238117 , -91.7408095116 , -43.5696066595 , + -49.9560710099 , -167.8513443296, -70.9437505499 , -46.4109705355 , -64.2264526456 , -13.9995803916 , -100.9548186356, 9.9101010575 , + -50.0615130815 , -55.7590145012 , -60.3195153388 , 61.7913378549 , -102.0850899209, 53.2360193126 , -25.8997883369 , 75.1445512333 , + -113.8148602310, 17.8027281119 , -19.5006822722 , -44.2169628471 , 107.5017084384 , -113.7909124666, -43.9735396033 , 7.6880981388 , + 46.7384653508 , 9.9047443751 , 81.8646964362 , 132.3812863877 , -95.6959050236 , -68.5015813484 , 65.8586404494 , 18.5039353889 , + -30.1786166621 , -90.3098515667 , -22.9356228552 , -20.5778272423 , -2.2127786675 , -35.4418447703 , -51.8722915974 , -107.9024439078, + -51.5940748232 , -51.7463262677 , 74.2795485984 , 94.2205022462 , 9.7016384049 , -47.3556083155 , -36.7822314478 , -151.6455525363, + -15.7183814485 , 78.2063383182 , 0.1516414969 , 37.9304181609 , 20.6185902740 , -22.2164106778 , 6.1160554677 , 2.4061326953 , + -111.6681824598, -60.0858917090 , 75.1698614693 , -76.5787410444 , 28.3391655715 , -2.4946186443 , -68.0378899682 , 104.0893199171 , + -51.8319647254 , 38.8521710524 , 75.9114239564 , 73.9206172905 , -103.2533029987, 6.9002718274 , -36.6346436319 , -25.1990926265 , + 1.5852145953 , -50.6438436795 , 21.5018844428 , -151.9305562846, -51.7326681814 , 21.4475994143 , 42.2564011921 , -74.0520586926 , + 49.7370635809 , -13.2957534126 , 36.6746826778 , -31.7005492589 , 148.4894964268 , 79.7890632353 , 16.8856024809 , 16.1690460177 , + 39.2665169484 , 117.2461167794 , -37.4827984831 , -47.8387803604 , -95.7025286193 , 34.3058214285 , -124.9536456028, 56.1640195764 , + 94.3636873606 , 35.3992852810 , -38.3920852159 , -100.5738062016, -29.7837022314 , 42.9133913996 , -34.2715618187 , -14.3589115627 , + -16.5935468750 , 20.4574192236 , -88.7897972666 , -38.6285080386 , 53.3203422726 , 98.5991486746 , 122.7305462474 , 67.7902817187 , + 5.1764117389 , 5.0632821624 , 21.9288789574 , -78.3140512638 , -21.2069682335 , 23.6342010925 , 34.4445769455 , 59.1346766615 , + 28.9978778000 , 39.8121180845 , -17.1650033520 , -56.9174900874 , 17.8157086148 , -112.8801457350, -122.4019040408, 140.8669393157 , + -65.4664329639 , 40.6952775518 , 32.7260891658 , -43.2565155866 , 19.3945751928 , -20.1815002000 , -67.6601711640 , -18.1921178207 , + -35.6802153684 , 49.9550290306 , 131.4925251016 , -31.2940938167 , -5.2848453344 , -109.5580577933, 20.2437599390 , -8.8782958734 , + 54.1836717264 , 7.2555852190 , -3.5698316137 , -51.9236786262 , 6.7861547980 , -104.4814551670, 45.8458629668 , 70.0890876844 , + 38.3572837740 , 61.8024165129 , 68.0176962024 , -12.8193934080 , -21.4661610917 , -0.9377108815 , -74.2100679061 , 71.0490808147 , + 91.9813889497 , -14.5797640164 , 3.5036749129 , -138.3605478356, -48.1501349794 , -16.0636922482 , -12.1334197606 , 15.0562207637 , + -34.0878176054 , 55.1075126157 , 97.3829871877 , 0.2053358099 , -94.8713267382 , 51.5460954054 , 21.2966946363 , 58.1331025047 , + -23.4599044132 , -19.3315856528 , -8.4497193577 , -1.9594679356 , -33.1906549336 , -144.6825417978, -57.1218958072 , 35.7353406097 , + 61.4666549819 , 14.6536253128 , 82.1632196866 , -44.6230161723 , -91.1022589278 , -18.5737673927 , -136.8975612334, 56.9606788003 , + 70.7059960183 , -68.2829345081 , -10.2629800455 , -53.6385325047 , -68.7928766204 , 88.2444688302 , 83.1412324801 , -102.9206928160, + -68.2329763159 , -69.7552955469 , 108.2132269009 , -28.2582329307 , 5.6685898328 , -36.0392956840 , 43.3269513128 , -8.6436416796 , + -16.5054886972 , 11.5008791788 , 39.6923606683 , -28.9039554061 , 13.5938214364 , -23.6296332202 , 49.1171161163 , 53.1636857935 , + -62.9672053166 , -54.2594757384 , 48.3838956696 , 8.0469071555 , -33.6472086213 , -120.5381752144, 55.0880453111 , 17.8990740563 , + 144.9402232336 , 101.7886229203 , -73.3666393712 , -16.4721379138 , -12.7447935685 , 101.8245160983 , -49.7026860415 , -15.1227790364 , + 65.7430288442 , -131.8695390036, 10.2750933946 , 90.9752774838 , -26.5859990591 , -95.6962772568 , 76.2174589344 , 24.8796848060 , + -38.8938223046 , 54.1687774852 , -37.3585968996 , -34.6848570502 , 33.0151011570 , -55.8345877671 , -3.9009101671 , -31.5024971691 , + -9.6863895491 , 91.8719195957 , -58.9993249744 , -25.6887030614 , -8.0829472205 , 4.6386491741 , -71.4019697167 , -21.3734669095 , + 86.2079144404 , 79.6823974266 , -0.0910915997 , 44.8067718095 , 58.7204020766 , 72.6856808976 , -50.3373732478 , -116.1175365534, + -15.0884909384 , 5.4593772059 , -63.6553527905 , 37.3460388205 , -32.2399421679 , 95.7569350513 , -7.3700141964 , -56.0370832967 , + -41.7377150439 , -42.0042856519 , 12.5134312941 , 93.7845584531 , -32.4801087157 , -33.3976050318 , -24.2252126001 , -46.3199064467 , + -20.3704610276 , 15.8571376404 , 88.9127217235 , -33.1132582267 , -1.0005675836 , -28.1780471904 , 150.9349379135 , 38.0600520828 , + 36.4338677563 , -3.3709201641 , 29.7709773016 , 16.5064119077 , 21.3147729463 , 110.6714300904 , 18.8406036507 , 14.8963298097 , + 50.9975960392 , 16.3991140350 , -194.0805845907, -41.6723945839 , -74.8991127408 , -6.4587655805 , -0.6883628218 , -49.8709647175 , + 194.2265120473 , 64.3043624521 , 16.0040882780 , 68.4032551772 , -43.4050313128 , 84.6826289824 , -28.1357565943 , 134.6895584120 , + -7.9746152680 , -95.6692886462 , -48.9444370342 , 79.4479343188 , -50.5345228122 , 52.4800633307 , -14.7735051703 , -20.1510237050 , + 22.5049816980 , 64.4191999102 , 24.8385648232 , 99.4265041360 , 62.0189508473 , -28.3892600378 , -109.8842008564, -79.0407483407 , + 18.3408112020 , 49.1650536089 , 31.5419844924 , -36.1160722679 , -132.9148081329, 10.4053531567 , -129.2463715470, -43.4602207151 , + -24.2420653292 , 91.5388317556 , 21.4762248190 , -44.3810909139 , 18.4098011282 , -45.8691164539 , -20.9831197962 , 16.2076792914 , + 66.0224147666 , -13.6794615513 , 101.2163279622 , -62.4462618603 , 22.2040981785 , -52.3208382802 , -24.7909079016 , 58.5150375093 , + 18.8569705105 , -55.6083430939 , 131.0273367422 , -34.5209015065 , 121.4357296573 , -77.2590299593 , -51.5929566898 , 5.0247131098 , + -23.8451707592 , -4.5912313547 , 31.1387246821 , 61.7019310824 , 49.1912429744 , -50.5836913031 , -74.8182600630 , -21.6209317022 , + 20.9409464654 , -72.7870824583 , -28.3530746820 , -45.0794425434 , -13.4910629905 , -62.0158772255 , -34.1421181246 , 44.2844972784 , + 8.4213193211 , 79.9349022793 , 60.0160502260 , 32.2272994080 , -72.2893887746 , 17.3063698247 , -134.6335742431, 64.6499736261 , + 7.1411921919 , -37.5517577873 , 6.2405670930 , 117.1920927305 , 128.7420689815 , -3.1556854963 , -13.4100422909 , -11.9336372907 , + -8.6022400553 , -102.0033506666, -78.4696575074 , 15.0765861403 , -111.5219718576, -13.4162786508 , 38.2437013694 , 61.1637732561 , + -34.4804160003 , 107.4438003830 , -79.4193067813 , -81.1842853968 , -26.2622970331 , 132.3205425408 , -119.1464268477, 67.3048866598 , + 103.3266736715 , -58.1865815617 , 27.6231908601 , -11.2004371750 , 26.0340617206 , 12.5696123916 , 0.6442714420 , -30.7393043544 , + 1.5314955897 , 49.9110088250 , -106.1358721920, 51.1608329944 , -32.8684239794 , -27.7215905745 , -11.6450303367 , -36.7731678028 , + 59.9383486599 , -4.6301990580 , 5.0361682939 , -10.5669407980 , 124.0908762205 , 35.8305364082 , -123.6216777114, -74.2569079167 , + -56.7651776816 , 16.0736385582 , 23.5030632215 , -110.6764295938, 44.3086821806 , 9.4452708243 , 5.3300080251 , 39.0483916714 , + 151.4550562868 , 62.8957092621 , -116.8103461233, 5.1129927759 , -33.2252515135 , -9.4522506046 , 22.7026048372 , -15.5264414569 , + 71.2087620034 , 19.1191568332 , 50.3019546809 , -5.6096922409 , 22.9344126462 , -7.7591876203 , 31.8949515564 , -58.4253952381 , + 66.4341297173 , -19.0583083044 , 96.7695087855 , 20.4934280047 , 4.9544603116 , -20.8288135920 , -173.2659655408, -62.4883621640 , + -48.5528422703 , 12.1437504278 , 60.2482234666 , -19.6072312919 , -34.6320214291 , 129.0089698963 , -50.9042160618 , 98.3952661477 , + -4.7051792479 , -13.1768910826 , 69.5138802139 , 58.5748201565 , -45.9385652563 , 151.7952104306 , 34.2541941013 , -58.0417838381 , + 28.1480473670 , 46.4006562684 , 97.7001828545 , 4.0855607626 , -32.6097018162 , 16.8913949959 , 105.7266202978 , -89.3978374651 , + -60.9338593128 , -41.2220734230 , 49.9393070783 , 95.0974764854 , 49.2498366456 , 58.6214364590 , 34.1113830569 , 45.6634098874 , + -22.5356086770 , -97.1978653617 , 86.5565049535 , 70.6118545777 , -30.6978082909 , 118.7238621666 , 14.5922386932 , 11.3449652072 , + 65.6007783405 , 82.6369678204 , -52.0390492248 , -47.0160551227 , -95.5142448634 , 99.7162626888 , -36.5523815090 , -42.8042935534 , + 68.3566199798 , -13.8451547552 , -71.1629911780 , 36.2989433752 , -32.4867163365 , 112.4079947071 , -75.6295117422 , 47.5276421639 , + 51.8078250755 , -26.8715188457 , -9.6291144797 , 40.1999849640 , -38.4634033246 , 40.9764960915 , -26.1715730268 , 36.5996396515 , + -26.9924731886 , 53.7879986570 , -83.1658398348 , 23.6381378489 , 43.8794937753 , -55.4133836419 , 90.0266130838 , 14.1036181982 , + -18.1225736715 , 85.1363181151 , -62.5970846379 , -18.5291947838 , -25.7341986703 , -49.7061342931 , -59.0442763971 , 50.8960636803 , + -87.6471123430 , -36.7217762531 , 22.5952364054 , 11.1107885650 , -0.5377327229 , 160.8145792630 , 73.3103441505 , 10.1656872354 , + -50.4554350397 , -57.3478171016 , -15.4201715357 , -26.9135446491 , -4.9891264771 , -37.0226770057 , -80.9919535641 , 50.4418660876 , + -25.8517575250 , -69.9538258421 , -17.5730160671 , 15.9405836751 , 113.9545230349 , -46.1040379057 , -94.2458635014 , -69.0338522452 , + 43.5813790265 , 107.1836101171 , -55.1012654323 , -77.1529555887 , -33.1530320656 , -94.5582659641 , -53.6837586872 , 27.0680381378 , + 93.9385415207 , -61.0955216188 , 18.0530957225 , 7.9150142320 , -12.1218191587 , 34.0173961457 , 40.0084937565 , 9.8119275580 , + 44.2065861274 , -1.8718514394 , 67.4740024215 , 46.7391150131 , 207.2404815875 , 45.1635364462 , 43.3580102761 , -44.0244218674 , + 83.2387206007 , -8.6441851856 , 12.3993902588 , -22.5091685270 , -19.8332981376 , 97.9196509289 , -76.6720306234 , 28.9740705859 , + 121.9415248016 , 9.6656982611 , -51.0996453694 , 37.3704374740 , 74.7589840907 , -113.4066752631, 120.0029566342 , -105.3786221360, + 81.8152755619 , -13.4979932982 , -21.4680758393 , -85.1088235539 , -65.3610798409 , -35.0444139470 , -48.0220794487 , -41.6210317362 , + 33.1212995259 , -82.1480936443 , -10.5479715135 , 76.4601917004 , 42.1983651157 , 92.6104239912 , -42.3536237955 , -24.5644182272 , + 30.4446637772 , -90.2899420489 , 63.6723540422 , 103.0895811428 , 64.1706769263 , -10.7069812309 , 21.8927240409 , 6.3571071738 , + 57.1457649358 , -52.9866276448 , 66.0981829072 , -29.5372056881 , -79.2252039810 , -136.2440652798, -57.0106422562 , 86.8203548141 , + 66.4244149837 , 53.3230426111 , -66.1283059222 , -131.0402660353, 8.0548411081 , 122.9088988100 , 1.2626894208 , -60.5059112373 , + -68.8707203082 , -6.4747987200 , 85.8411327244 , 99.9624156733 , 90.4197864338 , -35.9630441182 , -22.9158275507 , -17.3660128776 , + 16.7845345761 , 34.7219749782 , -39.3513765878 , 1.0460702756 , -60.9494500182 , 20.0900333387 , -85.9636743832 , 88.4400782168 , + 15.0729628728 , 61.5499846243 , 11.8579871757 , 107.8617581581 , -42.9393027864 , -62.8422307621 , -19.0589600542 , 4.0750325807 , + -36.0651825425 , 55.7638724501 , -10.4691736080 , -55.5672537178 , -61.2061519915 , -21.1885348576 , -131.2535612498, 24.7463552676 , + 22.9426321237 , 14.3038202264 , -138.0926317438, -59.0892900856 , -162.5416439986, 7.1307658250 , -141.1236672256, -4.7173618068 , + -16.7741532807 , -68.2615451173 , -2.6608701102 , 84.1978109826 , -11.3446202072 , 59.9630033088 , -1.8994925010 , -37.9301641959 , + -119.4435600954, -11.4587491646 , 12.2423215240 , -7.3169898616 , -67.0373621128 , 36.0198843055 , 53.9791315249 , -134.5885680695, + -83.8330811965 , -16.6714816463 , -8.8498552035 , -24.0513088196 , -22.9444328877 , -37.7961441531 , 25.1975736186 , -136.1611637464, + -5.0843464033 , -10.3939554694 , 20.7422826935 , 75.6854136623 , 46.4179626736 , -57.0052830175 , 7.3457235521 , -51.5504447254 , + -158.4375751701, -200.2426967181, -48.1234996261 , 1.6623945527 , 21.1746524375 , 99.4092980367 , -2.3206772903 , 45.7989166757 , + 2.0181548348 , -88.0556010969 , -59.1527212096 , 47.3607925077 , -10.4181140309 , 56.3558125650 , -8.9799125560 , -30.0376711812 , + -36.7132904688 , 35.7785050392 , -13.0763909369 , -2.1855594714 , 18.1550954005 , -28.6711803575 , -55.4495172398 , -2.8812973198 , + -59.9575059158 , 40.0588875786 , 57.4713686602 , -3.2835144853 , -36.7193552111 , -64.9415131516 , -166.9555466445, -23.5556853844 , + -54.9408569587 , -35.2310451959 , 21.3345143458 , 65.7590671151 , 51.2214538168 , 46.1271939944 , -42.2235267919 , 127.2329928299 , + 105.2391778600 , 17.6726845966 , -129.9021148044, 8.7065613044 , -94.0987112511 , -3.5375742950 , -23.1385452379 , 60.6219530633 , + 92.5445564235 , 48.5111974469 , -52.5699309159 , -60.0634811685 , 25.9034368684 , 140.0249495491 , 1.5918852392 , 38.0266038291 , + 17.5588710703 , 3.4294066089 , -27.6748782173 , 59.6182974489 , -35.2924781853 , -38.6198576115 , -13.6119803198 , 7.8375587489 , + 22.7250686519 , -28.3524510951 , -34.4269062817 , 22.6464817325 , -61.6528147860 , -5.9782002429 , 61.4730771294 , 43.5582379527 , + 55.6862408270 , 87.8745651631 , 46.3401042715 , -19.8780979663 , 74.1272633369 , 29.8590452377 , -12.8665765140 , 34.2931401219 , + 53.9279617551 , -16.9017895140 , -70.1527553166 , -79.6367897992 , 109.3728271017 , -129.2214826835, -53.4644539730 , -51.5654458993 , + 17.6062148433 , 3.5090251835 , 74.2615941204 , -109.3431097845, 40.1403465151 , 28.8714561280 , 94.0868659302 , -19.0047033845 , + -60.0967410050 , -19.0998457619 , -67.2027075128 , 72.0711434846 , -17.8737851232 , 123.7050551274 , 132.6331504104 , 25.5018761009 , + -36.7817189239 , -29.1580893235 , -6.5848563828 , 90.2868948516 , -35.7017258498 , -68.5675432955 , -52.4888589786 , 47.1377730021 , + -7.4546621940 , -52.0657517138 , -49.0404829633 , -114.6910280126, -117.6819819437, -32.7856729408 , 31.8232065591 , 12.1192973039 , + 35.2678513420 , -1.0336778293 , 30.7021249679 , 127.0442906046 , -84.8457819393 , 28.9862843096 , -47.3524701726 , -126.1094998460, + -2.9700276582 , -2.4956545870 , -53.8624121141 , -85.2114117637 , 76.9057985618 , 137.1205201755 , -19.0830817212 , 14.3407526579 , + -56.5921994449 , -25.6084873186 , -44.9470801106 , -133.3139496090, 0.3487447576 , 33.4499716730 , 34.7126257844 , -9.3307383323 , + 27.2996276947 , 10.8765676134 , -91.1032360444 , -90.9584216222 , 1.6981490570 , 96.8557438791 , 56.7726390913 , -44.3246449237 , + 52.3260643361 , 21.5551140465 , 27.4535327381 , 2.0072717479 , 7.4823125629 , 77.1185863870 , 16.1372262663 , -10.7206012957 , + 66.8830091413 , 49.3523828287 , 54.0855375598 , 30.8570349345 , -10.9255375390 , 62.3910624674 , 30.9238561381 , 0.3352881853 , + 72.1022806197 , -28.8319885008 , 23.3335288806 , 46.8999035980 , -67.0984424822 , -164.7917209112, 42.5767681360 , -92.4668227688 , + 43.8491734282 , -17.1126540408 , 37.4819594334 , 69.0774409673 , -39.3530526854 , -14.0693747124 , -60.2520781215 , -80.3860105519 , + 32.6689956840 , 15.3393042576 , -18.5529761307 , 97.3942151573 , -4.4462855745 , 13.7614349817 , 158.3358780719 , -44.7258299667 , + -17.7741912819 , 116.5136962268 , -33.6261057820 , 22.8344441288 , -155.1423976144, 5.7070117893 , -22.7906543902 , -45.0633909283 , + -13.9329987929 , -66.0848932507 , 1.1383038109 , 123.8386958483 , 67.6662401589 , 45.9152963554 , -27.4397697462 , 97.9596747354 , + -6.3544655181 , 29.0832146722 , 96.3468162499 , 32.4535976137 , -91.0650399301 , 2.7293262791 , 70.7853483111 , -92.3655274571 , + 69.0359217256 , 83.1530567979 , 35.8375091111 , 7.3393552348 , -95.1770165365 , 76.4905790891 , 55.6253140577 , -29.5315327050 , + -16.5935468750 , 20.4574192236 , -88.7897972666 , -38.6285080386 , 53.3203422726 , 98.5991486746 , 122.7305462474 , 67.7902817187 , + 5.1764117389 , 5.0632821624 , 21.9288789574 , -78.3140512638 , -21.2069682335 , 23.6342010925 , 34.4445769455 , 59.1346766615 , + 28.9978778000 , 39.8121180845 , -17.1650033520 , -56.9174900874 , 17.8157086148 , -112.8801457350, -122.4019040408, 140.8669393157 , + -65.4664329639 , 40.6952775518 , 32.7260891658 , -43.2565155866 , 19.3945751928 , -20.1815002000 , -67.6601711640 , -18.1921178207 , + -35.6802153684 , -19.6571455162 +}; + +const float64_t filtering_f64_inputs[FILTERING_MAX_BLOCKSIZE * FILTERING_MAX_M + FILTERING_MAX_NUMTAPS] = +{ + 43.0264275639 , -17.0525215570 , -94.8488973910 , -8.1924989580 , 7.2830326091 , 66.8368719314 , 33.9778190671 , 117.8652289772 , + -129.6077797465, -14.6420815368 , 18.0239223278 , 20.6760530292 , 55.0375037651 , 1.8674609862 , -85.6534302408 , -33.5750364909 , + 29.2110949614 , 110.4727049460 , -94.1914619387 , -1.4084169343 , 83.5181653041 , 47.3073514127 , -13.3420621181 , 30.3389699104 , + 12.1188124277 , 100.9730921941 , -114.0146362390, -77.5823200409 , 37.2019034618 , 40.0026301128 , -58.3387276630 , -34.9472398600 , + -5.1169678311 , -87.7660091118 , -150.5888601131, 56.0349370503 , 50.2168884079 , -74.2313236767 , 22.3648603560 , -6.8676387051 , + 74.8957303680 , -90.1292012823 , -55.1436241586 , -66.6732976100 , -6.7918147615 , 7.7612697081 , 35.7892605979 , -20.0470508830 , + 41.8369017546 , -143.7378056984, -41.9127158600 , -108.3531841158, -57.1917422289 , -124.2808828105, 38.9316388820 , -77.9212517405 , + 37.1990818377 , -28.9545952748 , -155.6371057564, 45.8088886393 , 36.2537018275 , -6.5727656016 , -104.2070491921, 45.5583813729 , + -19.7674717059 , -80.4802190947 , -1.4444563441 , -42.2142256438 , 36.6546339194 , -57.0866498590 , 44.4677067511 , 65.7285753407 , + -103.8158864647, 25.4348723711 , -153.5419639389, 39.3608409474 , 49.1658103436 , 79.5570602275 , 75.2944095996 , 58.9394700746 , + -53.1018534392 , 33.4172444014 , 35.6224682287 , -64.4353396418 , -125.8464291251, -47.6072111617 , -26.2177687594 , -12.0061322096 , + -17.7887967585 , -28.2926175090 , -62.0691715749 , 40.5098573604 , -191.1123732593, 119.6750713043 , 19.6182375803 , -26.7615252921 , + 2.2957847015 , -108.3436451287, -50.5906164995 , -5.6360985100 , -11.6772204201 , -84.2765293757 , -60.9317810068 , 82.0446350218 , + -70.2048296348 , 72.8738253222 , 60.2450218115 , 114.2741231228 , 46.8180775285 , 6.9915412654 , -8.9909197429 , -78.9165936808 , + 66.4731535459 , -68.4235455651 , -79.8254597080 , -10.6308477115 , -62.6161569330 , -55.7744410292 , -11.8408366528 , 98.1034940997 , + 35.8213741877 , -54.4694482732 , 86.9631830044 , -53.0343838122 , -47.4898642865 , -47.2010929590 , -31.3312639685 , -23.0908245172 , + 12.0258009869 , -5.1098204703 , -9.8420230737 , -107.3328761158, 44.6810431959 , -17.9083820345 , -60.9753512872 , -7.5915088994 , + 17.2250813329 , 57.9176125648 , 124.3004161362 , -63.1950908493 , 120.5788885640 , -44.1734238117 , -91.7408095116 , -43.5696066595 , + -49.9560710099 , -167.8513443296, -70.9437505499 , -46.4109705355 , -64.2264526456 , -13.9995803916 , -100.9548186356, 9.9101010575 , + -50.0615130815 , -55.7590145012 , -60.3195153388 , 61.7913378549 , -102.0850899209, 53.2360193126 , -25.8997883369 , 75.1445512333 , + -113.8148602310, 17.8027281119 , -19.5006822722 , -44.2169628471 , 107.5017084384 , -113.7909124666, -43.9735396033 , 7.6880981388 , + 46.7384653508 , 9.9047443751 , 81.8646964362 , 132.3812863877 , -95.6959050236 , -68.5015813484 , 65.8586404494 , 18.5039353889 , + -30.1786166621 , -90.3098515667 , -22.9356228552 , -20.5778272423 , -2.2127786675 , -35.4418447703 , -51.8722915974 , -107.9024439078, + -51.5940748232 , -51.7463262677 , 74.2795485984 , 94.2205022462 , 9.7016384049 , -47.3556083155 , -36.7822314478 , -151.6455525363, + -15.7183814485 , 78.2063383182 , 0.1516414969 , 37.9304181609 , 20.6185902740 , -22.2164106778 , 6.1160554677 , 2.4061326953 , + -111.6681824598, -60.0858917090 , 75.1698614693 , -76.5787410444 , 28.3391655715 , -2.4946186443 , -68.0378899682 , 104.0893199171 , + -51.8319647254 , 38.8521710524 , 75.9114239564 , 73.9206172905 , -103.2533029987, 6.9002718274 , -36.6346436319 , -25.1990926265 , + 1.5852145953 , -50.6438436795 , 21.5018844428 , -151.9305562846, -51.7326681814 , 21.4475994143 , 42.2564011921 , -74.0520586926 , + 49.7370635809 , -13.2957534126 , 36.6746826778 , -31.7005492589 , 148.4894964268 , 79.7890632353 , 16.8856024809 , 16.1690460177 , + 39.2665169484 , 117.2461167794 , -37.4827984831 , -47.8387803604 , -95.7025286193 , 34.3058214285 , -124.9536456028, 56.1640195764 , + 94.3636873606 , 35.3992852810 , -38.3920852159 , -100.5738062016, -29.7837022314 , 42.9133913996 , -34.2715618187 , -14.3589115627 , + -16.5935468750 , 20.4574192236 , -88.7897972666 , -38.6285080386 , 53.3203422726 , 98.5991486746 , 122.7305462474 , 67.7902817187 , + 5.1764117389 , 5.0632821624 , 21.9288789574 , -78.3140512638 , -21.2069682335 , 23.6342010925 , 34.4445769455 , 59.1346766615 , + 28.9978778000 , 39.8121180845 , -17.1650033520 , -56.9174900874 , 17.8157086148 , -112.8801457350, -122.4019040408, 140.8669393157 , + -65.4664329639 , 40.6952775518 , 32.7260891658 , -43.2565155866 , 19.3945751928 , -20.1815002000 , -67.6601711640 , -18.1921178207 , + -35.6802153684 , 49.9550290306 , 131.4925251016 , -31.2940938167 , -5.2848453344 , -109.5580577933, 20.2437599390 , -8.8782958734 , + 54.1836717264 , 7.2555852190 , -3.5698316137 , -51.9236786262 , 6.7861547980 , -104.4814551670, 45.8458629668 , 70.0890876844 , + 38.3572837740 , 61.8024165129 , 68.0176962024 , -12.8193934080 , -21.4661610917 , -0.9377108815 , -74.2100679061 , 71.0490808147 , + 91.9813889497 , -14.5797640164 , 3.5036749129 , -138.3605478356, -48.1501349794 , -16.0636922482 , -12.1334197606 , 15.0562207637 , + -34.0878176054 , 55.1075126157 , 97.3829871877 , 0.2053358099 , -94.8713267382 , 51.5460954054 , 21.2966946363 , 58.1331025047 , + -23.4599044132 , -19.3315856528 , -8.4497193577 , -1.9594679356 , -33.1906549336 , -144.6825417978, -57.1218958072 , 35.7353406097 , + 61.4666549819 , 14.6536253128 , 82.1632196866 , -44.6230161723 , -91.1022589278 , -18.5737673927 , -136.8975612334, 56.9606788003 , + 70.7059960183 , -68.2829345081 , -10.2629800455 , -53.6385325047 , -68.7928766204 , 88.2444688302 , 83.1412324801 , -102.9206928160, + -68.2329763159 , -69.7552955469 , 108.2132269009 , -28.2582329307 , 5.6685898328 , -36.0392956840 , 43.3269513128 , -8.6436416796 , + -16.5054886972 , 11.5008791788 , 39.6923606683 , -28.9039554061 , 13.5938214364 , -23.6296332202 , 49.1171161163 , 53.1636857935 , + -62.9672053166 , -54.2594757384 , 48.3838956696 , 8.0469071555 , -33.6472086213 , -120.5381752144, 55.0880453111 , 17.8990740563 , + 144.9402232336 , 101.7886229203 , -73.3666393712 , -16.4721379138 , -12.7447935685 , 101.8245160983 , -49.7026860415 , -15.1227790364 , + 65.7430288442 , -131.8695390036, 10.2750933946 , 90.9752774838 , -26.5859990591 , -95.6962772568 , 76.2174589344 , 24.8796848060 , + -38.8938223046 , 54.1687774852 , -37.3585968996 , -34.6848570502 , 33.0151011570 , -55.8345877671 , -3.9009101671 , -31.5024971691 , + -9.6863895491 , 91.8719195957 , -58.9993249744 , -25.6887030614 , -8.0829472205 , 4.6386491741 , -71.4019697167 , -21.3734669095 , + 86.2079144404 , 79.6823974266 , -0.0910915997 , 44.8067718095 , 58.7204020766 , 72.6856808976 , -50.3373732478 , -116.1175365534, + -15.0884909384 , 5.4593772059 , -63.6553527905 , 37.3460388205 , -32.2399421679 , 95.7569350513 , -7.3700141964 , -56.0370832967 , + -41.7377150439 , -42.0042856519 , 12.5134312941 , 93.7845584531 , -32.4801087157 , -33.3976050318 , -24.2252126001 , -46.3199064467 , + -20.3704610276 , 15.8571376404 , 88.9127217235 , -33.1132582267 , -1.0005675836 , -28.1780471904 , 150.9349379135 , 38.0600520828 , + 36.4338677563 , -3.3709201641 , 29.7709773016 , 16.5064119077 , 21.3147729463 , 110.6714300904 , 18.8406036507 , 14.8963298097 , + 50.9975960392 , 16.3991140350 , -194.0805845907, -41.6723945839 , -74.8991127408 , -6.4587655805 , -0.6883628218 , -49.8709647175 , + 194.2265120473 , 64.3043624521 , 16.0040882780 , 68.4032551772 , -43.4050313128 , 84.6826289824 , -28.1357565943 , 134.6895584120 , + -7.9746152680 , -95.6692886462 , -48.9444370342 , 79.4479343188 , -50.5345228122 , 52.4800633307 , -14.7735051703 , -20.1510237050 , + 22.5049816980 , 64.4191999102 , 24.8385648232 , 99.4265041360 , 62.0189508473 , -28.3892600378 , -109.8842008564, -79.0407483407 , + 18.3408112020 , 49.1650536089 , 31.5419844924 , -36.1160722679 , -132.9148081329, 10.4053531567 , -129.2463715470, -43.4602207151 , + -24.2420653292 , 91.5388317556 , 21.4762248190 , -44.3810909139 , 18.4098011282 , -45.8691164539 , -20.9831197962 , 16.2076792914 , + 66.0224147666 , -13.6794615513 , 101.2163279622 , -62.4462618603 , 22.2040981785 , -52.3208382802 , -24.7909079016 , 58.5150375093 , + 18.8569705105 , -55.6083430939 , 131.0273367422 , -34.5209015065 , 121.4357296573 , -77.2590299593 , -51.5929566898 , 5.0247131098 , + -23.8451707592 , -4.5912313547 , 31.1387246821 , 61.7019310824 , 49.1912429744 , -50.5836913031 , -74.8182600630 , -21.6209317022 , + 20.9409464654 , -72.7870824583 , -28.3530746820 , -45.0794425434 , -13.4910629905 , -62.0158772255 , -34.1421181246 , 44.2844972784 , + 8.4213193211 , 79.9349022793 , 60.0160502260 , 32.2272994080 , -72.2893887746 , 17.3063698247 , -134.6335742431, 64.6499736261 , + 7.1411921919 , -37.5517577873 , 6.2405670930 , 117.1920927305 , 128.7420689815 , -3.1556854963 , -13.4100422909 , -11.9336372907 , + -8.6022400553 , -102.0033506666, -78.4696575074 , 15.0765861403 , -111.5219718576, -13.4162786508 , 38.2437013694 , 61.1637732561 , + -34.4804160003 , 107.4438003830 , -79.4193067813 , -81.1842853968 , -26.2622970331 , 132.3205425408 , -119.1464268477, 67.3048866598 , + 103.3266736715 , -58.1865815617 , 27.6231908601 , -11.2004371750 , 26.0340617206 , 12.5696123916 , 0.6442714420 , -30.7393043544 , + 1.5314955897 , 49.9110088250 , -106.1358721920, 51.1608329944 , -32.8684239794 , -27.7215905745 , -11.6450303367 , -36.7731678028 , + 59.9383486599 , -4.6301990580 , 5.0361682939 , -10.5669407980 , 124.0908762205 , 35.8305364082 , -123.6216777114, -74.2569079167 , + -56.7651776816 , 16.0736385582 , 23.5030632215 , -110.6764295938, 44.3086821806 , 9.4452708243 , 5.3300080251 , 39.0483916714 , + 151.4550562868 , 62.8957092621 , -116.8103461233, 5.1129927759 , -33.2252515135 , -9.4522506046 , 22.7026048372 , -15.5264414569 , + 71.2087620034 , 19.1191568332 , 50.3019546809 , -5.6096922409 , 22.9344126462 , -7.7591876203 , 31.8949515564 , -58.4253952381 , + 66.4341297173 , -19.0583083044 , 96.7695087855 , 20.4934280047 , 4.9544603116 , -20.8288135920 , -173.2659655408, -62.4883621640 , + -48.5528422703 , 12.1437504278 , 60.2482234666 , -19.6072312919 , -34.6320214291 , 129.0089698963 , -50.9042160618 , 98.3952661477 , + -4.7051792479 , -13.1768910826 , 69.5138802139 , 58.5748201565 , -45.9385652563 , 151.7952104306 , 34.2541941013 , -58.0417838381 , + 28.1480473670 , 46.4006562684 , 97.7001828545 , 4.0855607626 , -32.6097018162 , 16.8913949959 , 105.7266202978 , -89.3978374651 , + -60.9338593128 , -41.2220734230 , 49.9393070783 , 95.0974764854 , 49.2498366456 , 58.6214364590 , 34.1113830569 , 45.6634098874 , + -22.5356086770 , -97.1978653617 , 86.5565049535 , 70.6118545777 , -30.6978082909 , 118.7238621666 , 14.5922386932 , 11.3449652072 , + 65.6007783405 , 82.6369678204 , -52.0390492248 , -47.0160551227 , -95.5142448634 , 99.7162626888 , -36.5523815090 , -42.8042935534 , + 68.3566199798 , -13.8451547552 , -71.1629911780 , 36.2989433752 , -32.4867163365 , 112.4079947071 , -75.6295117422 , 47.5276421639 , + 51.8078250755 , -26.8715188457 , -9.6291144797 , 40.1999849640 , -38.4634033246 , 40.9764960915 , -26.1715730268 , 36.5996396515 , + -26.9924731886 , 53.7879986570 , -83.1658398348 , 23.6381378489 , 43.8794937753 , -55.4133836419 , 90.0266130838 , 14.1036181982 , + -18.1225736715 , 85.1363181151 , -62.5970846379 , -18.5291947838 , -25.7341986703 , -49.7061342931 , -59.0442763971 , 50.8960636803 , + -87.6471123430 , -36.7217762531 , 22.5952364054 , 11.1107885650 , -0.5377327229 , 160.8145792630 , 73.3103441505 , 10.1656872354 , + -50.4554350397 , -57.3478171016 , -15.4201715357 , -26.9135446491 , -4.9891264771 , -37.0226770057 , -80.9919535641 , 50.4418660876 , + -25.8517575250 , -69.9538258421 , -17.5730160671 , 15.9405836751 , 113.9545230349 , -46.1040379057 , -94.2458635014 , -69.0338522452 , + 43.5813790265 , 107.1836101171 , -55.1012654323 , -77.1529555887 , -33.1530320656 , -94.5582659641 , -53.6837586872 , 27.0680381378 , + 93.9385415207 , -61.0955216188 , 18.0530957225 , 7.9150142320 , -12.1218191587 , 34.0173961457 , 40.0084937565 , 9.8119275580 , + 44.2065861274 , -1.8718514394 , 67.4740024215 , 46.7391150131 , 207.2404815875 , 45.1635364462 , 43.3580102761 , -44.0244218674 , + 83.2387206007 , -8.6441851856 , 12.3993902588 , -22.5091685270 , -19.8332981376 , 97.9196509289 , -76.6720306234 , 28.9740705859 , + 121.9415248016 , 9.6656982611 , -51.0996453694 , 37.3704374740 , 74.7589840907 , -113.4066752631, 120.0029566342 , -105.3786221360, + 81.8152755619 , -13.4979932982 , -21.4680758393 , -85.1088235539 , -65.3610798409 , -35.0444139470 , -48.0220794487 , -41.6210317362 , + 33.1212995259 , -82.1480936443 , -10.5479715135 , 76.4601917004 , 42.1983651157 , 92.6104239912 , -42.3536237955 , -24.5644182272 , + 30.4446637772 , -90.2899420489 , 63.6723540422 , 103.0895811428 , 64.1706769263 , -10.7069812309 , 21.8927240409 , 6.3571071738 , + 57.1457649358 , -52.9866276448 , 66.0981829072 , -29.5372056881 , -79.2252039810 , -136.2440652798, -57.0106422562 , 86.8203548141 , + 66.4244149837 , 53.3230426111 , -66.1283059222 , -131.0402660353, 8.0548411081 , 122.9088988100 , 1.2626894208 , -60.5059112373 , + -68.8707203082 , -6.4747987200 , 85.8411327244 , 99.9624156733 , 90.4197864338 , -35.9630441182 , -22.9158275507 , -17.3660128776 , + 16.7845345761 , 34.7219749782 , -39.3513765878 , 1.0460702756 , -60.9494500182 , 20.0900333387 , -85.9636743832 , 88.4400782168 , + 15.0729628728 , 61.5499846243 , 11.8579871757 , 107.8617581581 , -42.9393027864 , -62.8422307621 , -19.0589600542 , 4.0750325807 , + -36.0651825425 , 55.7638724501 , -10.4691736080 , -55.5672537178 , -61.2061519915 , -21.1885348576 , -131.2535612498, 24.7463552676 , + 22.9426321237 , 14.3038202264 , -138.0926317438, -59.0892900856 , -162.5416439986, 7.1307658250 , -141.1236672256, -4.7173618068 , + -16.7741532807 , -68.2615451173 , -2.6608701102 , 84.1978109826 , -11.3446202072 , 59.9630033088 , -1.8994925010 , -37.9301641959 , + -119.4435600954, -11.4587491646 , 12.2423215240 , -7.3169898616 , -67.0373621128 , 36.0198843055 , 53.9791315249 , -134.5885680695, + -83.8330811965 , -16.6714816463 , -8.8498552035 , -24.0513088196 , -22.9444328877 , -37.7961441531 , 25.1975736186 , -136.1611637464, + -5.0843464033 , -10.3939554694 , 20.7422826935 , 75.6854136623 , 46.4179626736 , -57.0052830175 , 7.3457235521 , -51.5504447254 , + -158.4375751701, -200.2426967181, -48.1234996261 , 1.6623945527 , 21.1746524375 , 99.4092980367 , -2.3206772903 , 45.7989166757 , + 2.0181548348 , -88.0556010969 , -59.1527212096 , 47.3607925077 , -10.4181140309 , 56.3558125650 , -8.9799125560 , -30.0376711812 , + -36.7132904688 , 35.7785050392 , -13.0763909369 , -2.1855594714 , 18.1550954005 , -28.6711803575 , -55.4495172398 , -2.8812973198 , + -59.9575059158 , 40.0588875786 , 57.4713686602 , -3.2835144853 , -36.7193552111 , -64.9415131516 , -166.9555466445, -23.5556853844 , + -54.9408569587 , -35.2310451959 , 21.3345143458 , 65.7590671151 , 51.2214538168 , 46.1271939944 , -42.2235267919 , 127.2329928299 , + 105.2391778600 , 17.6726845966 , -129.9021148044, 8.7065613044 , -94.0987112511 , -3.5375742950 , -23.1385452379 , 60.6219530633 , + 92.5445564235 , 48.5111974469 , -52.5699309159 , -60.0634811685 , 25.9034368684 , 140.0249495491 , 1.5918852392 , 38.0266038291 , + 17.5588710703 , 3.4294066089 , -27.6748782173 , 59.6182974489 , -35.2924781853 , -38.6198576115 , -13.6119803198 , 7.8375587489 , + 22.7250686519 , -28.3524510951 , -34.4269062817 , 22.6464817325 , -61.6528147860 , -5.9782002429 , 61.4730771294 , 43.5582379527 , + 55.6862408270 , 87.8745651631 , 46.3401042715 , -19.8780979663 , 74.1272633369 , 29.8590452377 , -12.8665765140 , 34.2931401219 , + 53.9279617551 , -16.9017895140 , -70.1527553166 , -79.6367897992 , 109.3728271017 , -129.2214826835, -53.4644539730 , -51.5654458993 , + 17.6062148433 , 3.5090251835 , 74.2615941204 , -109.3431097845, 40.1403465151 , 28.8714561280 , 94.0868659302 , -19.0047033845 , + -60.0967410050 , -19.0998457619 , -67.2027075128 , 72.0711434846 , -17.8737851232 , 123.7050551274 , 132.6331504104 , 25.5018761009 , + -36.7817189239 , -29.1580893235 , -6.5848563828 , 90.2868948516 , -35.7017258498 , -68.5675432955 , -52.4888589786 , 47.1377730021 , + -7.4546621940 , -52.0657517138 , -49.0404829633 , -114.6910280126, -117.6819819437, -32.7856729408 , 31.8232065591 , 12.1192973039 , + 35.2678513420 , -1.0336778293 , 30.7021249679 , 127.0442906046 , -84.8457819393 , 28.9862843096 , -47.3524701726 , -126.1094998460, + -2.9700276582 , -2.4956545870 , -53.8624121141 , -85.2114117637 , 76.9057985618 , 137.1205201755 , -19.0830817212 , 14.3407526579 , + -56.5921994449 , -25.6084873186 , -44.9470801106 , -133.3139496090, 0.3487447576 , 33.4499716730 , 34.7126257844 , -9.3307383323 , + 27.2996276947 , 10.8765676134 , -91.1032360444 , -90.9584216222 , 1.6981490570 , 96.8557438791 , 56.7726390913 , -44.3246449237 , + 52.3260643361 , 21.5551140465 , 27.4535327381 , 2.0072717479 , 7.4823125629 , 77.1185863870 , 16.1372262663 , -10.7206012957 , + 66.8830091413 , 49.3523828287 , 54.0855375598 , 30.8570349345 , -10.9255375390 , 62.3910624674 , 30.9238561381 , 0.3352881853 , + 72.1022806197 , -28.8319885008 , 23.3335288806 , 46.8999035980 , -67.0984424822 , -164.7917209112, 42.5767681360 , -92.4668227688 , + 43.8491734282 , -17.1126540408 , 37.4819594334 , 69.0774409673 , -39.3530526854 , -14.0693747124 , -60.2520781215 , -80.3860105519 , + 32.6689956840 , 15.3393042576 , -18.5529761307 , 97.3942151573 , -4.4462855745 , 13.7614349817 , 158.3358780719 , -44.7258299667 , + -17.7741912819 , 116.5136962268 , -33.6261057820 , 22.8344441288 , -155.1423976144, 5.7070117893 , -22.7906543902 , -45.0633909283 , + -13.9329987929 , -66.0848932507 , 1.1383038109 , 123.8386958483 , 67.6662401589 , 45.9152963554 , -27.4397697462 , 97.9596747354 , + -6.3544655181 , 29.0832146722 , 96.3468162499 , 32.4535976137 , -91.0650399301 , 2.7293262791 , 70.7853483111 , -92.3655274571 , + 69.0359217256 , 83.1530567979 , 35.8375091111 , 7.3393552348 , -95.1770165365 , 76.4905790891 , 55.6253140577 , -29.5315327050 , + -16.5935468750 , 20.4574192236 , -88.7897972666 , -38.6285080386 , 53.3203422726 , 98.5991486746 , 122.7305462474 , 67.7902817187 , + 5.1764117389 , 5.0632821624 , 21.9288789574 , -78.3140512638 , -21.2069682335 , 23.6342010925 , 34.4445769455 , 59.1346766615 , + 28.9978778000 , 39.8121180845 , -17.1650033520 , -56.9174900874 , 17.8157086148 , -112.8801457350, -122.4019040408, 140.8669393157 , + -65.4664329639 , 40.6952775518 , 32.7260891658 , -43.2565155866 , 19.3945751928 , -20.1815002000 , -67.6601711640 , -18.1921178207 , + -35.6802153684 , -19.6571455162 +}; + +/*--------------------------------------------------------------------------------*/ +/* Blocksizes */ +/*--------------------------------------------------------------------------------*/ +ARR_DESC_DEFINE(uint32_t, + filtering_blocksizes, + 5, + CURLY( + 1, 7, 14, 32, FILTERING_MAX_BLOCKSIZE)); + +ARR_DESC_DEFINE(uint32_t, + lms_blocksizes, + 3, + CURLY( + 128, 256, LMS_MAX_BLOCKSIZE)); + +ARR_DESC_DEFINE(uint16_t, + filtering_numtaps, + 5, + CURLY( + 4, 6, 14, 32, FILTERING_MAX_NUMTAPS)); + +ARR_DESC_DEFINE(uint16_t, + filtering_numtaps2, + 5, + CURLY( + 6, 12, 18, 24, 30)); + +ARR_DESC_DEFINE(uint16_t, + filtering_numstages, + 3, + CURLY( + 1, 7, FILTERING_MAX_NUMSTAGES)); + +ARR_DESC_DEFINE(uint8_t, + filtering_postshifts, + 3, + CURLY( + 0, 1, FILTERING_MAX_POSTSHIFT)); + +ARR_DESC_DEFINE(uint8_t, + filtering_Ls, + 3, + CURLY( + 1, 2, FILTERING_MAX_L)); + +ARR_DESC_DEFINE(uint8_t, + filtering_Ms, + 6, + CURLY( + 1, 2, 4, 7, 11, FILTERING_MAX_M)); + + +/*--------------------------------------------------------------------------------*/ +/* Coefficient Lists */ +/*--------------------------------------------------------------------------------*/ + +// There must be at least max( FILTERING_MAX_NUMTAPS + 2 , FILTERING_MAX_NUMSTAGES * 6 + 2) coefficients +const float32_t filtering_coeffs_f32[FILTERING_MAX_NUMSTAGES * 6 + 2] = +{ + -13.0572f, 0.0f , -97.4724f, 8.4111f , -7.2193f , -53.7577f, 22.2630f , + -1.0509f , -25.9198f, 26.5207f , -12.6697f, -78.7453f, -0.6540f , 0.3119f , + 13.4595f , -6.7225f , -4.1313f , -38.5974f, 3.2700f , -51.6191f, -22.4314f, + 0.2481f , 32.9779f , -37.6421f, 5.4469f , -7.0023f , 24.3657f , 9.9140f , + 0.2870f , -13.0499f, 29.3333f , -53.1396f, -2.7555f , 0.5377f , 35.3491f , + -3.7134f , 0.8548f , 4.7469f , -10.5865f, -2.7285f , -1.5912f , -13.3502f, + 6.8532f , -8.2304f , -8.1193f , 3.8257f , -2.1703f , 13.5727f , 14.2736f , + -0.9855f , -8.9334f , -13.8883f, 11.8430f , -2.2024f , 0.9795f , 15.6191f , + 5.2121f , 10.8102f , -9.4171f , 6.0411f , -0.9131f , 10.6992f , -3.2634f , + 7.5849f , -4.9305f , -6.0549f , -7.9409f , 1.5827f , 13.3177f , 8.6727f , + -13.2268f , 11.1239f , 0.2481f , 32.9779f , -37.6421f, 5.4469f , -13.8883f, + 11.8430f , -2.2024f , 0.9795f , 15.6191f , 0.2481f , 32.9779f , -37.6421f, + 3.2700f , -51.6191f +}; +const float64_t filtering_coeffs_f64[FILTERING_MAX_NUMSTAGES * 6 + 2] = +{ + -13.0572f, 0.0f , -97.4724f, 8.4111f , -7.2193f , -53.7577f, 22.2630f , + -1.0509f , -25.9198f, 26.5207f , -12.6697f, -78.7453f, -0.6540f , 0.3119f , + 13.4595f , -6.7225f , -4.1313f , -38.5974f, 3.2700f , -51.6191f, -22.4314f, + 0.2481f , 32.9779f , -37.6421f, 5.4469f , -7.0023f , 24.3657f , 9.9140f , + 0.2870f , -13.0499f, 29.3333f , -53.1396f, -2.7555f , 0.5377f , 35.3491f , + -3.7134f , 0.8548f , 4.7469f , -10.5865f, -2.7285f , -1.5912f , -13.3502f, + 6.8532f , -8.2304f , -8.1193f , 3.8257f , -2.1703f , 13.5727f , 14.2736f , + -0.9855f , -8.9334f , -13.8883f, 11.8430f , -2.2024f , 0.9795f , 15.6191f , + 5.2121f , 10.8102f , -9.4171f , 6.0411f , -0.9131f , 10.6992f , -3.2634f , + 7.5849f , -4.9305f , -6.0549f , -7.9409f , 1.5827f , 13.3177f , 8.6727f , + -13.2268f , 11.1239f , 0.2481f , 32.9779f , -37.6421f, 5.4469f , -13.8883f, + 11.8430f , -2.2024f , 0.9795f , 15.6191f , 0.2481f , 32.9779f , -37.6421f, + 3.2700f , -51.6191f +}; + +const float32_t filtering_coeffs_b_f32[FILTERING_MAX_NUMSTAGES * 6 + 2] = +{ + -0.0572f, 0.0f , -0.4724f, 0.4111f , -0.9999f, -0.7577f, 0.2630f , + -0.0509f, -1.0000f, 0.5207f , -0.6697f, -0.7453f, -0.6540f, 0.3119f , + 0.4595f , -0.7225f, -0.1313f, -0.5974f, 0.2700f , -0.6191f, -0.4314f, + 0.2481f , 0.9779f , -0.6421f, 0.4469f , -0.0023f, 0.3657f , 0.9140f , + 0.2870f , -0.0499f, 0.3333f , -0.1396f, -0.7555f, 0.5377f , 0.3491f , + 0.2369f , -0.5310f, -0.5904f, 0.6263f , 0.0205f , 0.1088f , -0.2926f, + -0.4187f, -0.5094f, 0.4479f , -0.3594f, -0.3102f, 0.6748f , 0.7620f , + 0.0033f , -0.9195f, 0.3192f , -0.1705f, 0.5524f , -0.5025f, 0.4898f , + -0.0119f, -0.3982f, -0.7818f, -0.9186f, -0.0944f, 0.7228f , 0.7014f , + 0.4850f , -0.6814f, 0.4914f , -0.6286f, 0.5130f , -0.8585f, 0.3000f , + 0.6068f , 0.4978f , -0.7225f, -0.1313f, -0.5974f, 0.2700f , -0.6191f, + 0.2481f , 0.9779f , -0.6421f, 0.4469f , -0.0023f, 0.3657f , 0.9140f , + 0.2369f , -0.5310f +}; + +const float64_t filtering_coeffs_b_f64[FILTERING_MAX_NUMSTAGES * 6 + 2] = +{ + -0.0572f, 0.0f , -0.4724f, 0.4111f , -0.9999f, -0.7577f, 0.2630f , + -0.0509f, -1.0000f, 0.5207f , -0.6697f, -0.7453f, -0.6540f, 0.3119f , + 0.4595f , -0.7225f, -0.1313f, -0.5974f, 0.2700f , -0.6191f, -0.4314f, + 0.2481f , 0.9779f , -0.6421f, 0.4469f , -0.0023f, 0.3657f , 0.9140f , + 0.2870f , -0.0499f, 0.3333f , -0.1396f, -0.7555f, 0.5377f , 0.3491f , + 0.2369f , -0.5310f, -0.5904f, 0.6263f , 0.0205f , 0.1088f , -0.2926f, + -0.4187f, -0.5094f, 0.4479f , -0.3594f, -0.3102f, 0.6748f , 0.7620f , + 0.0033f , -0.9195f, 0.3192f , -0.1705f, 0.5524f , -0.5025f, 0.4898f , + -0.0119f, -0.3982f, -0.7818f, -0.9186f, -0.0944f, 0.7228f , 0.7014f , + 0.4850f , -0.6814f, 0.4914f , -0.6286f, 0.5130f , -0.8585f, 0.3000f , + 0.6068f , 0.4978f , -0.7225f, -0.1313f, -0.5974f, 0.2700f , -0.6191f, + 0.2481f , 0.9779f , -0.6421f, 0.4469f , -0.0023f, 0.3657f , 0.9140f , + 0.2369f , -0.5310f +}; + +const float32_t *filtering_coeffs_c_f32 = filtering_coeffs_b_f32 + 1; + +const q31_t filtering_coeffs_q31[FILTERING_MAX_NUMSTAGES * 6 + 2] = +{ + 0xEEDA759C, 0x00000000, 0x80000000, 0x0B0BA027, 0xF6850544, 0xB967E3EC, + 0x1D3C4F64, 0xFFFFFFFF, 0xDDF65B14, 0x22D3A62D, 0xEF5CBB89, 0x98979EE0, + 0xFF242597, 0x0068D9E9, 0x11ACC4F3, 0xF72C0F21, 0xFA9326BC, 0xCD506BD5, + 0x044B50CD, 0xBC36D4BC, 0xE28B1589, 0x0053690B, 0x2B4E6639, 0xCE919690, + 0x0727234D, 0xF6CDFB14, 0x1FFF2FCF, 0x0D04DC35, 0x00607E4D, 0xEEDCF04A, + 0x268530EF, 0xBA37B050, 0x7FFFFFFF, 0xEF5CBB89, 0x00000000, 0x2B4E6639, + 0xFF242597, 0x0068D9E9, 0x11ACC4F3, 0xF72C0F21, 0xFA9326BC, 0xCD506BD5, + 0x1D3C4F64, 0xFFFFFFFF, 0xDDF65B14, 0x22D3A62D, 0xEF5CBB89, 0x98979EE0, + 0x044B50CD, 0xBC36D4BC, 0xE28B1589, 0x0053690B, 0x2B4E6639, 0xCE919690, + 0x0727234D, 0xF6CDFB14, 0x1FFF2FCF, 0x0D04DC35, 0x00607E4D, 0xEEDCF04A, + 0xE28B1589, 0x0053690B, 0x044B50CD, 0xBC36D4BC, 0xE28B1589, 0xB967E3EC, + 0x044B50CD, 0xBC36D4BC, 0xE28B1589, 0x0053690B, 0x2B4E6639, 0xCE919690, + 0x1FFF2FCF, 0x0D04DC35, 0x00607E4D, 0xEEDCF04A, 0xFFFFFFFF, 0xDDF65B14, + 0xFF242597, 0x0068D9E9, 0x11ACC4F3, 0xF72C0F21, 0xFA9326BC, 0xCD506BD5, + 0x2B4E6639, 0xCE919690 +}; + +const q31_t *filtering_coeffs_b_q31 = filtering_coeffs_q31 + 1; +const q31_t *filtering_coeffs_c_q31 = filtering_coeffs_q31 + 2; + +//fourth coefficient MUST be zero for arm_biquad_cascade_df1_fast_q15 to work +//every 6th coefficient after that must also be zero +const q15_t filtering_coeffs_q15[FILTERING_MAX_NUMSTAGES * 6 + 4] = +{ + 0xBA37, 0xEEDA, 0x8000, 0x0000, 0x0B0B, 0xF685, 0xB967, + 0x1D3C, 0xFFFF, 0x0000, 0x22D3, 0xEF5C, 0x9897, + 0xFF24, 0x0068, 0x0000, 0xF72C, 0xFA93, 0xCD50, + 0x044B, 0xBC36, 0x0000, 0x0053, 0x2B4E, 0xCE91, + 0x0727, 0xF6CD, 0x0000, 0x0D04, 0x0060, 0xEEDC, + 0x2685, 0xBA37, 0x0000, 0xDDF6, 0x0000, 0x2B4E, + 0xFF24, 0x0068, 0x0000, 0xF72C, 0xFA93, 0xCD50, + 0x1D3C, 0xFFFF, 0x0000, 0x22D3, 0xEF5C, 0x9897, + 0x044B, 0xBC36, 0x0000, 0x0053, 0x2B4E, 0xCE91, + 0x0727, 0xF6CD, 0x0000, 0x0D04, 0x0060, 0xEEDC, + 0xE28B, 0x0053, 0x0000, 0xBC36, 0xE28B, 0xB967, + 0x044B, 0xBC36, 0x0000, 0x0053, 0x2B4E, 0xCE91, + 0x044B, 0xBC36, 0x0000, 0x0053, 0x2B4E, 0xCE91, + 0x0727, 0xF6CD, 0x0000, 0x0D04, 0x0060, 0xEEDC, + 0xE28B, 0x11AC, 0x0000, +}; + +const q15_t *filtering_coeffs_b_q15 = filtering_coeffs_q15 + 2; +const q15_t *filtering_coeffs_c_q15 = filtering_coeffs_q15 + 4; + +const q7_t filtering_coeffs_q7[FILTERING_MAX_NUMSTAGES * 6 + 8] = +{ + 0xEE, 0x00, 0x80, 0x0B, 0xF6, 0xB9, + 0x1D, 0xFF, 0xDD, 0x22, 0xEF, 0x98, + 0xFF, 0x00, 0x11, 0xF7, 0xFA, 0xCD, + 0x04, 0xBC, 0xE2, 0x00, 0x2B, 0xCE, + 0x07, 0xF6, 0x1F, 0x0D, 0x00, 0xEE, + 0x26, 0xBA, 0x7F, 0x00, 0x80, 0x2B, + 0xFF, 0x00, 0x11, 0xF7, 0xFA, 0xCD, + 0x1D, 0xFF, 0xDD, 0x22, 0xEF, 0x98, + 0x04, 0xBC, 0xE2, 0x00, 0x2B, 0xCE, + 0x07, 0xF6, 0x1F, 0x0D, 0x00, 0xEE, + 0xE2, 0x00, 0x04, 0xBC, 0xE2, 0xB9, + 0x04, 0xBC, 0xE2, 0x00, 0x2B, 0xCE, + 0x07, 0xF6, 0x1F, 0x0D, 0x00, 0xEE, + 0x26, 0xBA, 0x7F, 0x00, 0x80, 0x2B, + 0x07, 0xF6, 0x1F, 0x0D, 0x00, 0xEE, + 0xFA, 0xCD +}; + +const q7_t *filtering_coeffs_b_q7 = filtering_coeffs_q7 + 4; +const q7_t *filtering_coeffs_c_q7 = filtering_coeffs_q7 + 8; + +/*--------------------------------------------------------------------------------*/ +/* Tap Delay Lists */ +/*--------------------------------------------------------------------------------*/ +//const int32_t filtering_tap_delay[FILTERING_MAX_NUMTAPS] = { +// 0xEE, 0x00, 0x10, 0x0B, 0xF6, 0xD9, +// 0x1D, 0xFF, 0xDD, 0x1A, 0xEF, 0xE8, +// 0xFF, 0x00, 0x11, 0xF7, 0xFA, 0xDD, +// 0x04, 0xEC, 0xE2, 0x00, 0x2B, 0xFE, +// 0x07, 0xF6, 0x1F, 0x0D, 0x00, 0xEE, +// 0x20, 0xDF, 0x21 +//}; + +const int32_t filtering_tap_delay[FILTERING_MAX_NUMTAPS] = { + 0x00, 0x01, 0x10, 0x0B, 0x03, 0x05, + 0x1D, 0x21, 0x11, 0x1A, 0x1F, 0x07, + 0x20, 0x01, 0x10, 0x0B, 0x03, 0x05, + 0x1D, 0x21, 0x11, 0x1A, 0x1F, 0x07, + 0x00, 0x01, 0x10, 0x0B, 0x03, 0x05, + 0x1D, 0x21, 0x11 +}; + diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_group.c new file mode 100644 index 0000000..21ac7fc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/filtering_test_group.c @@ -0,0 +1,17 @@ +#include "jtest.h" +#include "filtering_tests.h" + +JTEST_DEFINE_GROUP(filtering_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_GROUP_CALL(biquad_tests); + JTEST_GROUP_CALL(conv_tests); + JTEST_GROUP_CALL(correlate_tests); + JTEST_GROUP_CALL(fir_tests); + JTEST_GROUP_CALL(iir_tests); + JTEST_GROUP_CALL(lms_tests); + + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/fir_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/fir_tests.c new file mode 100644 index 0000000..40e52b2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/fir_tests.c @@ -0,0 +1,402 @@ +#include "jtest.h" +#include "filtering_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "filtering_templates.h" +#include "type_abbrev.h" + +#define FIR_DEFINE_TEST(suffix, config_suffix, output_type) \ + JTEST_DEFINE_TEST(arm_fir##config_suffix##_##suffix##_test, \ + arm_fir##config_suffix##_##suffix) \ + { \ + arm_fir_instance_##suffix fir_inst_fut = { 0 }; \ + arm_fir_instance_##suffix fir_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numtaps_idx, uint16_t, numTaps, filtering_numtaps \ + , \ + /* Initialize the FIR Instances */ \ + arm_fir_init_##suffix( \ + &fir_inst_fut, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Taps: %d\n", \ + (int)blockSize, \ + (int)numTaps); \ + \ + JTEST_COUNT_CYCLES( \ + arm_fir##config_suffix##_##suffix( \ + &fir_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + blockSize)); \ + \ + arm_fir_init_##suffix( \ + &fir_inst_ref, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + ref_fir##config_suffix##_##suffix( \ + &fir_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } + +#define FIR_INTERPOLATE_DEFINE_TEST(suffix, output_type) \ + JTEST_DEFINE_TEST(arm_fir_interpolate_##suffix##_test, \ + arm_fir_interpolate_##suffix) \ + { \ + arm_fir_interpolate_instance_##suffix fir_inst_fut = { 0 }; \ + arm_fir_interpolate_instance_##suffix fir_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numtaps_idx, uint16_t, numTaps, filtering_numtaps2 \ + , \ + TEMPLATE_DO_ARR_DESC( \ + L_idx, uint8_t, L, filtering_Ls \ + , \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Taps: %d\n" \ + "Upsample factor: %d\n", \ + (int)blockSize, \ + (int)numTaps, \ + (int)L); \ + \ + /* Initialize the FIR Instances */ \ + arm_fir_interpolate_init_##suffix( \ + &fir_inst_fut, L, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + JTEST_COUNT_CYCLES( \ + arm_fir_interpolate_##suffix( \ + &fir_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + blockSize)); \ + \ + arm_fir_interpolate_init_##suffix( \ + &fir_inst_ref, L, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + ref_fir_interpolate_##suffix( \ + &fir_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize * (uint32_t)L, \ + output_type)))); \ + \ + return JTEST_TEST_PASSED; \ + } + +#define FIR_DECIMATE_DEFINE_TEST(suffix, config_suffix, output_type) \ + JTEST_DEFINE_TEST(arm_fir_decimate##config_suffix##_##suffix##_test, \ + arm_fir_decimate##config_suffix##_##suffix) \ + { \ + arm_fir_decimate_instance_##suffix fir_inst_fut = { 0 }; \ + arm_fir_decimate_instance_##suffix fir_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numtaps_idx, uint16_t, numTaps, filtering_numtaps \ + , \ + TEMPLATE_DO_ARR_DESC( \ + M_idx, uint8_t, M, filtering_Ms \ + , \ + if (blockSize % M == 0) \ + { \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Taps: %d\n" \ + "Decimation Factor: %d\n", \ + (int)blockSize, \ + (int)numTaps, \ + (int)M); \ + \ + /* Initialize the FIR Instances */ \ + arm_fir_decimate_init_##suffix( \ + &fir_inst_fut, numTaps, M, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + JTEST_COUNT_CYCLES( \ + arm_fir_decimate##config_suffix##_##suffix( \ + &fir_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + blockSize)); \ + \ + arm_fir_decimate_init_##suffix( \ + &fir_inst_ref, numTaps, M, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + ref_fir_decimate##config_suffix##_##suffix( \ + &fir_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize / M, \ + output_type); \ + }))); \ + \ + return JTEST_TEST_PASSED; \ + } + +#define FIR_LATTICE_DEFINE_TEST(suffix, output_type) \ + JTEST_DEFINE_TEST(arm_fir_lattice_##suffix##_test, \ + arm_fir_lattice_##suffix) \ + { \ + arm_fir_lattice_instance_##suffix fir_inst_fut = { 0 }; \ + arm_fir_lattice_instance_##suffix fir_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numstages_idx, uint16_t, numStages, filtering_numstages \ + , \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Stages: %d\n", \ + (int)blockSize, \ + (int)numStages); \ + \ + /* Initialize the FIR Instances */ \ + arm_fir_lattice_init_##suffix( \ + &fir_inst_fut, numStages, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState); \ + \ + JTEST_COUNT_CYCLES( \ + arm_fir_lattice_##suffix( \ + &fir_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + blockSize)); \ + \ + arm_fir_lattice_init_##suffix( \ + &fir_inst_ref, numStages, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState); \ + \ + ref_fir_lattice_##suffix( \ + &fir_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } + + +#define FIR_SPARSE_DEFINE_TEST(suffix, output_type) \ + JTEST_DEFINE_TEST(arm_fir_sparse_##suffix##_test, \ + arm_fir_sparse_##suffix) \ + { \ + arm_fir_sparse_instance_##suffix fir_inst_fut = { 0 }; \ + arm_fir_sparse_instance_##suffix fir_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numtaps_idx, uint16_t, numTaps, filtering_numtaps \ + , \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Taps: %d\n" \ + "Tap Delay: %d\n", \ + (int)blockSize, \ + (int)numTaps, \ + (int)FILTERING_MAX_TAP_DELAY); \ + \ + /* Initialize the FIR Instances */ \ + arm_fir_sparse_init_##suffix( \ + &fir_inst_fut, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, \ + (int32_t*)filtering_tap_delay, \ + FILTERING_MAX_TAP_DELAY, blockSize); \ + \ + JTEST_COUNT_CYCLES( \ + arm_fir_sparse_##suffix( \ + &fir_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + (void *) filtering_scratch, \ + blockSize)); \ + \ + arm_fir_sparse_init_##suffix( \ + &fir_inst_ref, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, \ + (int32_t*)filtering_tap_delay, \ + FILTERING_MAX_TAP_DELAY, blockSize); \ + \ + ref_fir_sparse_##suffix( \ + &fir_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + (void *) filtering_scratch, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } + +#define FIR_SPARSE2_DEFINE_TEST(suffix, output_type) \ + JTEST_DEFINE_TEST(arm_fir_sparse_##suffix##_test, \ + arm_fir_sparse_##suffix) \ + { \ + arm_fir_sparse_instance_##suffix fir_inst_fut = { 0 }; \ + arm_fir_sparse_instance_##suffix fir_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numtaps_idx, uint16_t, numTaps, filtering_numtaps \ + , \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Taps: %d\n" \ + "Tap Delay: %d\n", \ + (int)blockSize, \ + (int)numTaps, \ + (int)FILTERING_MAX_TAP_DELAY); \ + \ + /* Initialize the FIR Instances */ \ + arm_fir_sparse_init_##suffix( \ + &fir_inst_fut, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, \ + (int32_t*)filtering_tap_delay, \ + FILTERING_MAX_TAP_DELAY, blockSize); \ + \ + JTEST_COUNT_CYCLES( \ + arm_fir_sparse_##suffix( \ + &fir_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + (void *) filtering_scratch, \ + (void *) filtering_scratch2, \ + blockSize)); \ + \ + arm_fir_sparse_init_##suffix( \ + &fir_inst_ref, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, \ + (int32_t*)filtering_tap_delay, \ + FILTERING_MAX_TAP_DELAY, blockSize); \ + \ + ref_fir_sparse_##suffix( \ + &fir_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + (void *) filtering_scratch, \ + (void *) filtering_scratch2, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } + +FIR_DEFINE_TEST(f32,,float32_t); +FIR_DEFINE_TEST(q31,,q31_t); +FIR_DEFINE_TEST(q15,,q15_t); +FIR_DEFINE_TEST(q31,_fast,q31_t); +FIR_DEFINE_TEST(q15,_fast,q15_t); +FIR_DEFINE_TEST(q7,,q7_t); + +FIR_LATTICE_DEFINE_TEST(f32,float32_t); +FIR_LATTICE_DEFINE_TEST(q31,q31_t); +FIR_LATTICE_DEFINE_TEST(q15,q15_t); + +FIR_INTERPOLATE_DEFINE_TEST(f32,float32_t); +FIR_INTERPOLATE_DEFINE_TEST(q31,q31_t); +FIR_INTERPOLATE_DEFINE_TEST(q15,q15_t); + +FIR_DECIMATE_DEFINE_TEST(f32,,float32_t); +FIR_DECIMATE_DEFINE_TEST(q31,,q31_t); +FIR_DECIMATE_DEFINE_TEST(q15,,q15_t); +FIR_DECIMATE_DEFINE_TEST(q31,_fast,q31_t); +FIR_DECIMATE_DEFINE_TEST(q15,_fast,q15_t); + +FIR_SPARSE_DEFINE_TEST(f32,float32_t); +FIR_SPARSE_DEFINE_TEST(q31,q31_t); +FIR_SPARSE2_DEFINE_TEST(q15,q15_t); +FIR_SPARSE2_DEFINE_TEST(q7,q7_t); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(fir_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_fir_f32_test); + JTEST_TEST_CALL(arm_fir_q31_test); + JTEST_TEST_CALL(arm_fir_q15_test); + JTEST_TEST_CALL(arm_fir_q7_test); + JTEST_TEST_CALL(arm_fir_fast_q31_test); + JTEST_TEST_CALL(arm_fir_fast_q15_test); + + JTEST_TEST_CALL(arm_fir_lattice_f32_test); + JTEST_TEST_CALL(arm_fir_lattice_q31_test); + JTEST_TEST_CALL(arm_fir_lattice_q15_test); + + JTEST_TEST_CALL(arm_fir_interpolate_f32_test); + JTEST_TEST_CALL(arm_fir_interpolate_q31_test); + JTEST_TEST_CALL(arm_fir_interpolate_q15_test); + + JTEST_TEST_CALL(arm_fir_decimate_f32_test); + JTEST_TEST_CALL(arm_fir_decimate_q31_test); + JTEST_TEST_CALL(arm_fir_decimate_q15_test); + JTEST_TEST_CALL(arm_fir_decimate_fast_q31_test); + JTEST_TEST_CALL(arm_fir_decimate_fast_q15_test); + + JTEST_TEST_CALL(arm_fir_sparse_f32_test); + JTEST_TEST_CALL(arm_fir_sparse_q31_test); + JTEST_TEST_CALL(arm_fir_sparse_q15_test); + JTEST_TEST_CALL(arm_fir_sparse_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/iir_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/iir_tests.c new file mode 100644 index 0000000..8d31c3f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/iir_tests.c @@ -0,0 +1,76 @@ +#include "jtest.h" +#include "filtering_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "filtering_templates.h" +#include "type_abbrev.h" + +#define IIR_DEFINE_TEST(suffix, output_type) \ + JTEST_DEFINE_TEST(arm_iir_lattice_##suffix##_test, \ + arm_iir_lattice_##suffix) \ + { \ + arm_iir_lattice_instance_##suffix iir_inst_fut = { 0 }; \ + arm_iir_lattice_instance_##suffix iir_inst_ref = { 0 }; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, filtering_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numstages_idx, uint16_t, numStages, filtering_numstages \ + , \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Stages: %d\n", \ + (int)blockSize, \ + (int)numStages); \ + \ + /* Initialize the IIR Instances */ \ + arm_iir_lattice_init_##suffix( \ + &iir_inst_fut, numStages, (output_type*)filtering_coeffs_b_##suffix, \ + (output_type*)filtering_coeffs_c_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + JTEST_COUNT_CYCLES( \ + arm_iir_lattice_##suffix( \ + &iir_inst_fut, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_fut, \ + blockSize)); \ + \ + arm_iir_lattice_init_##suffix( \ + &iir_inst_ref, numStages, (output_type*)filtering_coeffs_b_##suffix, \ + (output_type*)filtering_coeffs_c_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + ref_iir_lattice_##suffix( \ + &iir_inst_ref, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_output_ref, \ + blockSize); \ + \ + FILTERING_SNR_COMPARE_INTERFACE( \ + blockSize, \ + output_type))); \ + \ + return JTEST_TEST_PASSED; \ + } + +IIR_DEFINE_TEST(f32, float32_t); +IIR_DEFINE_TEST(q31, q31_t); +IIR_DEFINE_TEST(q15, q15_t); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(iir_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_iir_lattice_f32_test); + JTEST_TEST_CALL(arm_iir_lattice_q31_test); + JTEST_TEST_CALL(arm_iir_lattice_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/lms_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/lms_tests.c new file mode 100644 index 0000000..06e96b6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/filtering_tests/lms_tests.c @@ -0,0 +1,219 @@ +#include "jtest.h" +#include "filtering_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "filtering_templates.h" +#include "type_abbrev.h" + +static const float32_t mu_f32 = 0.00854f;//1.0f; +static const float32_t mu2_f32 = 1.0f; +static const q31_t mu_q31 = 0x7fffffff; +static const q15_t mu_q15 = 0x7fff; + +#define LMS_DEFINE_TEST(suffix, config_suffix, output_type, mu) \ + JTEST_DEFINE_TEST(arm_lms##config_suffix##_##suffix##_test, \ + arm_lms##config_suffix##_##suffix) \ + { \ + arm_lms##config_suffix##_instance_##suffix lms_inst_fut = { 0 }; \ + arm_lms##config_suffix##_instance_##suffix lms_inst_ref = { 0 }; \ + arm_fir_instance_##suffix fir_inst = { 0 }; \ + uint32_t i; \ + \ + TEMPLATE_DO_ARR_DESC( \ + blocksize_idx, uint32_t, blockSize, lms_blocksizes \ + , \ + TEMPLATE_DO_ARR_DESC( \ + numtaps_idx, uint16_t, numTaps, filtering_numtaps \ + , \ + /* Initialize the FIR Instances */ \ + arm_fir_init_##suffix( \ + &fir_inst, numTaps, \ + (output_type*)filtering_coeffs_##suffix, \ + (void *) filtering_pState, blockSize); \ + \ + ref_fir_##suffix( \ + &fir_inst, \ + (void *) filtering_##suffix##_inputs, \ + (void *) filtering_input_lms, \ + blockSize); \ + \ + for(i=0;i> 6; \ + } \ + \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Number of Taps: %d\n" \ + "Post Shift: %d\n", \ + (int)blockSize, \ + (int)numTaps, \ + (int)postShift); \ + \ + /* Initialize the LMS Instances */ \ + arm_lms##config_suffix##_init_##suffix( \ + &lms_inst_fut, numTaps, \ + (output_type*)filtering_coeffs_lms, \ + (void *) filtering_pState, mu_##suffix, blockSize, postShift); \ + \ + JTEST_COUNT_CYCLES( \ + arm_lms##config_suffix##_##suffix( \ + &lms_inst_fut, \ + (void *) filtering_output_f32_fut, \ + (void *) filtering_input_lms, \ + (void *) filtering_output_fut, \ + (void *) ((output_type*)filtering_output_fut+blockSize), \ + blockSize)); \ + \ + for(i=0;i= 6010050) +asm(" .global __ARM_use_no_argv\n"); +#endif + + +void debug_init(void) +{ + uint32_t * SHCSR_ptr = (uint32_t *) 0xE000ED24; /* System Handler Control and State Register */ + *SHCSR_ptr |= 0x70000; /* Enable UsageFault, BusFault, and MemManage fault*/ +} + +int main(void) +{ + debug_init(); + + JTEST_INIT(); /* Initialize test framework. */ + + JTEST_GROUP_CALL(all_tests); /* Run all tests. */ + + JTEST_ACT_EXIT_FW(); /* Exit test framework. */ + while (1); /* Never return. */ +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/math_helper.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/math_helper.c new file mode 100644 index 0000000..ef09e40 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/math_helper.c @@ -0,0 +1,491 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010 ARM Limited. All rights reserved. +* +* $Date: 29. November 2010 +* $Revision: V1.0.3 +* +* Project: CMSIS DSP Library +* +* Title: math_helper.c +* +* Description: Definition of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Version 1.0.3 2010/11/29 +* Re-organized the CMSIS folders and updated documentation. +* +* Version 1.0.2 2010/11/11 +* Documentation updated. +* +* Version 1.0.1 2010/10/05 +* Production release and review comments incorporated. +* +* Version 1.0.0 2010/09/20 +* Production release and review comments incorporated. +* +* Version 0.0.7 2010/06/10 +* Misra-C changes done +* -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Include standard header files +* -------------------------------------------------------------------- */ +#include + +/* ---------------------------------------------------------------------- +* Include project header files +* -------------------------------------------------------------------- */ +#include "math_helper.h" + +/** + * @brief Caluclation of SNR + * @param float* Pointer to the reference buffer + * @param float* Pointer to the test buffer + * @param uint32_t total number of samples + * @return float SNR + * The function Caluclates signal to noise ratio for the reference output + * and test output + */ + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize) +{ + float EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + float SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10f (EnergySignal / EnergyError); + + return (SNR); + +} + + + +double arm_snr_f64(double *pRef, double *pTest, uint32_t buffSize) +{ + double EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + double SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10 (EnergySignal / EnergyError); + + return (SNR); + +} + +/** + * @brief Provide guard bits for Input buffer + * @param q15_t* Pointer to input buffer + * @param uint32_t blockSize + * @param uint32_t guard_bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q15 (q15_t * input_buf, uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Converts float to fixed in q12.20 format + * @param uint32_t number of samples in the buffer + * @return none + * The function converts floating point values to fixed point(q12.20) values + */ + +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1048576.0f corresponds to pow(2, 20) */ + pOut[i] = (q31_t) (pIn[i] * 1048576.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 1.0) + { + pOut[i] = 0x000FFFFF; + } + } +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param q15_t* Pointer to Ref buffer + * @param q15_t* Pointer to Test buffer + * @param uint32_t number of samples in the buffer + * @return none + */ + +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param q31_t* Pointer to Ref buffer + * @param q31_t* Pointer to Test buffer + * @param uint32_t number of samples in the buffer + * @return none + */ + +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Provide guard bits for Input buffer + * @param q31_t* Pointer to input buffer + * @param uint32_t blockSize + * @param uint32_t guard_bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q31 (q31_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Provide guard bits for Input buffer + * @param q31_t* Pointer to input buffer + * @param uint32_t blockSize + * @param uint32_t guard_bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q7 (q7_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + + + +/** + * @brief Caluclates number of guard bits + * @param uint32_t number of additions + * @return none + * The function Caluclates the number of guard bits + * depending on the numtaps + */ + +uint32_t arm_calc_guard_bits (uint32_t num_adds) +{ + uint32_t i = 1, j = 0; + + if (num_adds == 1) + { + return (0); + } + + while (i < num_adds) + { + i = i * 2; + j++; + } + + return (j); +} + +/** + * @brief Converts Q15 to floating-point + * @param uint32_t number of samples in the buffer + * @return none + */ + +void arm_apply_guard_bits (float32_t * pIn, + uint32_t numSamples, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + pIn[i] = pIn[i] * arm_calc_2pow(guard_bits); + } +} + +/** + * @brief Calculates pow(2, numShifts) + * @param uint32_t number of shifts + * @return pow(2, numShifts) + */ +uint32_t arm_calc_2pow(uint32_t numShifts) +{ + + uint32_t i, val = 1; + + for (i = 0; i < numShifts; i++) + { + val = val * 2; + } + + return(val); +} + + + +/** + * @brief Converts float to fixed q14 + * @param uint32_t number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q14 (float *pIn, q15_t * pOut, + uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 16384.0f corresponds to pow(2, 14) */ + pOut[i] = (q15_t) (pIn[i] * 16384.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFF; + } + + } + +} + + +/** + * @brief Converts float to fixed q30 format + * @param uint32_t number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q30 (float *pIn, q31_t * pOut, + uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 1073741824.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Converts float to fixed q30 format + * @param uint32_t number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q29 (float *pIn, q31_t * pOut, + uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 536870912.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 4.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + + +/** + * @brief Converts float to fixed q28 format + * @param uint32_t number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q28 (float *pIn, q31_t * pOut, + uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 268435456.0f corresponds to pow(2, 28) */ + pOut[i] = (q31_t) (pIn[i] * 268435456.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 8.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Clip the float values to +/- 1 + * @param pIn input buffer + * @param numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_clip_f32 (float *pIn, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + if (pIn[i] > 1.0f) + { + pIn[i] = 1.0; + } + else if ( pIn[i] < -1.0f) + { + pIn[i] = -1.0; + } + + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_add_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_add_tests.c new file mode 100644 index 0000000..c536899 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_add_tests.c @@ -0,0 +1,31 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAT_ADD_TEST(suffix) \ + MATRIX_DEFINE_TEST_TEMPLATE_ELT2( \ + mat_add, \ + suffix, \ + MATRIX_TEST_CONFIG_ADDITIVE_OUTPUT, \ + MATRIX_TEST_VALID_ADDITIVE_DIMENSIONS, \ + MATRIX_COMPARE_INTERFACE) + +JTEST_ARM_MAT_ADD_TEST(f32); +JTEST_ARM_MAT_ADD_TEST(q31); +JTEST_ARM_MAT_ADD_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_add_tests) +{ + JTEST_TEST_CALL(arm_mat_add_f32_test); + JTEST_TEST_CALL(arm_mat_add_q31_test); + JTEST_TEST_CALL(arm_mat_add_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_cmplx_mult_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_cmplx_mult_tests.c new file mode 100644 index 0000000..50cd57e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_cmplx_mult_tests.c @@ -0,0 +1,59 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAT_CMPLX_MULT_TEST(suffix, comparison_interface) \ + MATRIX_DEFINE_TEST_TEMPLATE_ELT2( \ + mat_cmplx_mult, \ + suffix, \ + MATRIX_TEST_CONFIG_MULTIPLICATIVE_OUTPUT, \ + MATRIX_TEST_VALID_MULTIPLICATIVE_DIMENSIONS, \ + comparison_interface) + +JTEST_ARM_MAT_CMPLX_MULT_TEST(f32, MATRIX_SNR_COMPARE_INTERFACE); +JTEST_ARM_MAT_CMPLX_MULT_TEST(q31, MATRIX_COMPARE_INTERFACE); + +/*--------------------------------------------------------------------------------*/ +/* Q15 Uses a Different interface than the others. */ +/*--------------------------------------------------------------------------------*/ + +#define ARM_mat_cmplx_mult_q15_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, \ + (void *) &matrix_output_fut, \ + (q15_t *) matrix_output_scratch) + +JTEST_DEFINE_TEST(arm_mat_cmplx_mult_q15_test, arm_mat_cmplx_mult_q15) +{ + MATRIX_TEST_TEMPLATE_ELT2( + matrix_q15_a_inputs, + matrix_q15_b_inputs, + arm_matrix_instance_q15 * , + arm_matrix_instance_q15, + TYPE_FROM_ABBREV(q15), + arm_mat_cmplx_mult_q15, + ARM_mat_cmplx_mult_q15_INPUT_INTERFACE, + ref_mat_cmplx_mult_q15, + REF_mat_cmplx_mult_INPUT_INTERFACE, + MATRIX_TEST_CONFIG_MULTIPLICATIVE_OUTPUT, + MATRIX_TEST_VALID_MULTIPLICATIVE_DIMENSIONS, + MATRIX_COMPARE_INTERFACE); +} + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_cmplx_mult_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_cmplx_mult_f32_test); + JTEST_TEST_CALL(arm_mat_cmplx_mult_q31_test); + JTEST_TEST_CALL(arm_mat_cmplx_mult_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_init_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_init_tests.c new file mode 100644 index 0000000..7d879ee --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_init_tests.c @@ -0,0 +1,58 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAT_INIT_TEST(suffix) \ + JTEST_DEFINE_TEST(arm_mat_init_##suffix##_test, \ + arm_mat_init_##suffix) \ + { \ + const uint16_t rows = 4; \ + const uint16_t cols = 2; \ + arm_matrix_instance_##suffix matrix = {0}; \ + /* TYPE_FROM_ABBREV(suffix) data[rows*cols] = {0}; */ \ + TYPE_FROM_ABBREV(suffix) data[4*2] = {0}; \ + \ + arm_mat_init_##suffix(&matrix, \ + rows, \ + cols, \ + data); \ + \ + JTEST_DUMP_STRF("Matrix Dimensions: %dx%d\n", \ + (int)matrix.numRows, \ + (int)matrix.numCols); \ + \ + if ((matrix.numRows == rows) && \ + (matrix.numCols == cols) && \ + (matrix.pData == data)) \ + { \ + return JTEST_TEST_PASSED; \ + } \ + else \ + { \ + return JTEST_TEST_FAILED; \ + } \ + \ + } + +JTEST_ARM_MAT_INIT_TEST(f32); +JTEST_ARM_MAT_INIT_TEST(q31); +JTEST_ARM_MAT_INIT_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_init_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_init_f32_test); + JTEST_TEST_CALL(arm_mat_init_q31_test); + JTEST_TEST_CALL(arm_mat_init_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_inverse_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_inverse_tests.c new file mode 100644 index 0000000..372ac1d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_inverse_tests.c @@ -0,0 +1,92 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +JTEST_DEFINE_TEST(arm_mat_inverse_f32_test, arm_mat_inverse_f32) +{ + TEMPLATE_DO_ARR_DESC( + mat_idx, arm_matrix_instance_f32 *, mat_ptr, matrix_f32_invertible_inputs + , + JTEST_DUMP_STRF("Matrix Dimensions: %dx%d\n", + (int)mat_ptr->numRows, + (int)mat_ptr->numCols); + + if (MATRIX_TEST_VALID_SQUARE_DIMENSIONS(arm_matrix_instance_f32 *, mat_ptr)) + { + MATRIX_TEST_CONFIG_SAMESIZE_OUTPUT(arm_matrix_instance_f32 *, mat_ptr); + + /* arm_mat_inverse_f32() modifies its source input. Use the scratch + * buffer to store a copy of the intended input. */ + { + float32_t * original_pdata_ptr = mat_ptr->pData; + + memcpy(matrix_output_scratch, + mat_ptr->pData, + mat_ptr->numRows * mat_ptr->numCols * sizeof(float32_t)); + mat_ptr->pData = (void*) &matrix_output_scratch; + + JTEST_COUNT_CYCLES(arm_mat_inverse_f32(mat_ptr, &matrix_output_fut)); + mat_ptr->pData = original_pdata_ptr; + } + + ref_mat_inverse_f32(mat_ptr, &matrix_output_ref); + + MATRIX_SNR_COMPARE_INTERFACE(arm_matrix_instance_f32, + float32_t); + }); + + return JTEST_TEST_PASSED; +} + +JTEST_DEFINE_TEST(arm_mat_inverse_f64_test, arm_mat_inverse_f64) +{ + TEMPLATE_DO_ARR_DESC( + mat_idx, arm_matrix_instance_f64 *, mat_ptr, matrix_f64_invertible_inputs + , + JTEST_DUMP_STRF("Matrix Dimensions: %dx%d\n", + (int)mat_ptr->numRows, + (int)mat_ptr->numCols); + + if (MATRIX_TEST_VALID_SQUARE_DIMENSIONS(arm_matrix_instance_f64 *, mat_ptr)) + { + MATRIX_TEST_CONFIG_SAMESIZE_OUTPUT(arm_matrix_instance_f64 *, mat_ptr); + + /* arm_mat_inverse_f64() modifies its source input. Use the scratch + * buffer to store a copy of the intended input. */ + { + float64_t * original_pdata_ptr = mat_ptr->pData; + + memcpy(matrix_output_scratch, + mat_ptr->pData, + mat_ptr->numRows * mat_ptr->numCols * sizeof(float64_t)); + mat_ptr->pData = (void*) &matrix_output_scratch; + + JTEST_COUNT_CYCLES(arm_mat_inverse_f64(mat_ptr, &matrix_output_fut64)); + mat_ptr->pData = original_pdata_ptr; + } + + ref_mat_inverse_f64(mat_ptr, &matrix_output_ref64); + + MATRIX_DBL_SNR_COMPARE_INTERFACE(arm_matrix_instance_f64); + }); + + return JTEST_TEST_PASSED; +} + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_inverse_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_inverse_f32_test); + JTEST_TEST_CALL(arm_mat_inverse_f64_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_fast_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_fast_tests.c new file mode 100644 index 0000000..313aa04 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_fast_tests.c @@ -0,0 +1,57 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAT_MULT_FAST_TEST(suffix) \ + MATRIX_DEFINE_TEST_TEMPLATE_ELT2( \ + mat_mult_fast, \ + suffix, \ + MATRIX_TEST_CONFIG_MULTIPLICATIVE_OUTPUT, \ + MATRIX_TEST_VALID_MULTIPLICATIVE_DIMENSIONS, \ + MATRIX_SNR_COMPARE_INTERFACE) + +JTEST_ARM_MAT_MULT_FAST_TEST(q31); + +/*--------------------------------------------------------------------------------*/ +/* Q15 Uses a Different interface than the others. */ +/*--------------------------------------------------------------------------------*/ + +#define ARM_mat_mult_fast_q15_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, \ + (void *) &matrix_output_fut, \ + (q15_t *) matrix_output_scratch) + +JTEST_DEFINE_TEST(arm_mat_mult_fast_q15_test, arm_mat_mult_fast_q15) +{ + MATRIX_TEST_TEMPLATE_ELT2( + matrix_q15_a_inputs, + matrix_q15_b_inputs, + arm_matrix_instance_q15 * , + arm_matrix_instance_q15, + TYPE_FROM_ABBREV(q15), + arm_mat_mult_fast_q15, + ARM_mat_mult_fast_q15_INPUT_INTERFACE, + ref_mat_mult_fast_q15, + REF_mat_mult_fast_INPUT_INTERFACE, + MATRIX_TEST_CONFIG_MULTIPLICATIVE_OUTPUT, + MATRIX_TEST_VALID_MULTIPLICATIVE_DIMENSIONS, + MATRIX_SNR_COMPARE_INTERFACE); +} + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_mult_fast_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_mult_fast_q31_test); + JTEST_TEST_CALL(arm_mat_mult_fast_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_tests.c new file mode 100644 index 0000000..c74bdc8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_mult_tests.c @@ -0,0 +1,59 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAT_MULT_TEST(suffix) \ + MATRIX_DEFINE_TEST_TEMPLATE_ELT2( \ + mat_mult, \ + suffix, \ + MATRIX_TEST_CONFIG_MULTIPLICATIVE_OUTPUT, \ + MATRIX_TEST_VALID_MULTIPLICATIVE_DIMENSIONS, \ + MATRIX_COMPARE_INTERFACE) + +JTEST_ARM_MAT_MULT_TEST(f32); +JTEST_ARM_MAT_MULT_TEST(q31); + +/*--------------------------------------------------------------------------------*/ +/* Q15 Uses a Different interface than the others. */ +/*--------------------------------------------------------------------------------*/ + +#define ARM_mat_mult_q15_INPUT_INTERFACE(input_a_ptr, input_b_ptr) \ + PAREN(input_a_ptr, input_b_ptr, \ + (void *) &matrix_output_fut, \ + (q15_t *) matrix_output_scratch) + +JTEST_DEFINE_TEST(arm_mat_mult_q15_test, arm_mat_mult_q15) +{ + MATRIX_TEST_TEMPLATE_ELT2( + matrix_q15_a_inputs, + matrix_q15_b_inputs, + arm_matrix_instance_q15 * , + arm_matrix_instance_q15, + TYPE_FROM_ABBREV(q15), + arm_mat_mult_q15, + ARM_mat_mult_q15_INPUT_INTERFACE, + ref_mat_mult_q15, + REF_mat_mult_INPUT_INTERFACE, + MATRIX_TEST_CONFIG_MULTIPLICATIVE_OUTPUT, + MATRIX_TEST_VALID_MULTIPLICATIVE_DIMENSIONS, + MATRIX_COMPARE_INTERFACE); +} + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_mult_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_mult_f32_test); + JTEST_TEST_CALL(arm_mat_mult_q31_test); + JTEST_TEST_CALL(arm_mat_mult_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_scale_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_scale_tests.c new file mode 100644 index 0000000..63fba94 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_scale_tests.c @@ -0,0 +1,90 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +/* This is for the two fixed point cases */ +#define JTEST_ARM_MAT_SCALE_TEST(suffix,type) \ + JTEST_DEFINE_TEST(arm_mat_scale_##suffix##_test, arm_mat_scale_##suffix) \ + { \ + uint32_t i,j; \ + \ + TEMPLATE_DO_ARR_DESC( \ + mat_idx, arm_matrix_instance_##suffix *, \ + mat_ptr, matrix_##suffix##_b_inputs \ + , \ + MATRIX_TEST_CONFIG_SAMESIZE_OUTPUT( \ + arm_matrix_instance_##suffix *, mat_ptr); \ + \ + for(i=0;inumRows, \ + (int)mat_ptr->numCols); \ + \ + JTEST_COUNT_CYCLES( \ + arm_mat_scale_##suffix(mat_ptr, \ + matrix_##suffix##_scale_values[i], \ + matrix_shift_values[j], \ + (arm_matrix_instance_##suffix*) &matrix_output_fut)); \ + \ + ref_mat_scale_##suffix(mat_ptr, \ + matrix_##suffix##_scale_values[i], \ + matrix_shift_values[j], \ + (arm_matrix_instance_##suffix*) &matrix_output_ref); \ + \ + MATRIX_SNR_COMPARE_INTERFACE(arm_matrix_instance_##suffix, \ + type); \ + } \ + }); \ + \ + return JTEST_TEST_PASSED; \ + } + +JTEST_DEFINE_TEST(arm_mat_scale_f32_test, arm_mat_scale_f32) +{ + uint32_t i; + + TEMPLATE_DO_ARR_DESC( + mat_idx, arm_matrix_instance_f32 *, mat_ptr, matrix_f32_b_inputs + , + MATRIX_TEST_CONFIG_SAMESIZE_OUTPUT(arm_matrix_instance_f32 *, mat_ptr); + + for(i=0;inumRows, + (int)mat_ptr->numCols); + JTEST_COUNT_CYCLES(arm_mat_scale_f32(mat_ptr, matrix_f32_scale_values[i], &matrix_output_fut)); + + ref_mat_scale_f32(mat_ptr, matrix_f32_scale_values[i], &matrix_output_ref); + + MATRIX_SNR_COMPARE_INTERFACE(arm_matrix_instance_f32, + float32_t); + }); + + return JTEST_TEST_PASSED; +} + +JTEST_ARM_MAT_SCALE_TEST(q31,q31_t); +JTEST_ARM_MAT_SCALE_TEST(q15,q15_t); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_scale_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_scale_f32_test); + JTEST_TEST_CALL(arm_mat_scale_q31_test); + JTEST_TEST_CALL(arm_mat_scale_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_sub_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_sub_tests.c new file mode 100644 index 0000000..245c28e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_sub_tests.c @@ -0,0 +1,34 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAT_SUB_TEST(suffix) \ + MATRIX_DEFINE_TEST_TEMPLATE_ELT2( \ + mat_sub, \ + suffix, \ + MATRIX_TEST_CONFIG_ADDITIVE_OUTPUT, \ + MATRIX_TEST_VALID_ADDITIVE_DIMENSIONS, \ + MATRIX_COMPARE_INTERFACE) + +JTEST_ARM_MAT_SUB_TEST(f32); +JTEST_ARM_MAT_SUB_TEST(q31); +JTEST_ARM_MAT_SUB_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_sub_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_sub_f32_test); + JTEST_TEST_CALL(arm_mat_sub_q31_test); + JTEST_TEST_CALL(arm_mat_sub_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_trans_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_trans_tests.c new file mode 100644 index 0000000..e49c80b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/mat_trans_tests.c @@ -0,0 +1,33 @@ +#include "jtest.h" +#include "matrix_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "matrix_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAT_TRANS_TEST(suffix) \ + MATRIX_DEFINE_TEST_TEMPLATE_ELT1( \ + mat_trans, \ + suffix, \ + MATRIX_TEST_CONFIG_TRANSPOSE_OUTPUT, \ + MATRIX_TEST_VALID_DIMENSIONS_ALWAYS) + +JTEST_ARM_MAT_TRANS_TEST(f32); +JTEST_ARM_MAT_TRANS_TEST(q31); +JTEST_ARM_MAT_TRANS_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mat_trans_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mat_trans_f32_test); + JTEST_TEST_CALL(arm_mat_trans_q31_test); + JTEST_TEST_CALL(arm_mat_trans_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_common_data.c new file mode 100644 index 0000000..033fe10 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_common_data.c @@ -0,0 +1,255 @@ +#include "arm_math.h" +#include "matrix_test_data.h" +#include "type_abbrev.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_fut_data[2*MATRIX_TEST_MAX_ELTS] = {0}; +MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_ref_data[2*MATRIX_TEST_MAX_ELTS] = {0}; +MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_scratch[MATRIX_TEST_MAX_ELTS] = {0}; + +MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_f32_fut[MATRIX_TEST_MAX_ELTS]; +MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_output_f32_ref[MATRIX_TEST_MAX_ELTS]; + +arm_matrix_instance_f32 matrix_output_fut = { + 0, + 0, + (float32_t *) &matrix_output_fut_data +}; + +arm_matrix_instance_f32 matrix_output_ref = { + 0, + 0, + (float32_t *) &matrix_output_ref_data +}; + +arm_matrix_instance_f64 matrix_output_fut64 = { + 0, + 0, + (float64_t *) &matrix_output_fut_data +}; + +arm_matrix_instance_f64 matrix_output_ref64 = { + 0, + 0, + (float64_t *) &matrix_output_ref_data +}; + +/*--------------------------------------------------------------------------------*/ +/* Data Buckets */ +/*--------------------------------------------------------------------------------*/ + +/** + * Pool of random data to base matrix inputs from. + */ +float32_t matrix_f32_100_rand[100] = { + -45.0345569674258, -11.0261163038747, -14.6841428777929, + 0.0345569674258, -11.0261163038747, -14.6841428777929, + -20.3679194392227, 27.5712678608402, -12.1390617339732, + -19.8753669720509, 42.3379642103244, -23.7788252219155, + -23.7517765301667, 40.2716109915281, -25.8308714086167, + 32.1194040197959, 24.4692807074156, -1.32083675968276, + 31.1580458282477, -2.90766514824093, -6.97926086704160, + 10.2843089382083, 30.1014622769739, 44.4787189721646, + -9.60878544118853, -48.4596562348445, -31.1044984967456, + -6.41414114190809, 3.28255887994549, -26.9511839788442, + -31.5183679875864, 21.1215780433683, -47.0779722437854, + -0.913590753192006, -40.3545474831611, -45.6976198342192, + 18.6775433365315, -5.32162505701938, -14.9272896423117, + 34.4308792695389, 40.4880968679893, -27.8253265982760, + 42.8854139478045, -1.07473615999811, -36.8026707393665, + -33.1009970537296, -31.6488844262730, -19.3650527983443, + 43.9001561999887, -30.5235710432951, 47.9748378356085, + -38.2582349144194, 23.0330862855453, -16.2280590178623, + 44.2050590775485, 14.9115474956452, -13.1515403509664, + 0.850865538112700, 37.5942811492984, -27.4078219027601, + -6.11300268738968, -20.3324126781673, -1.13910261964209, + 40.0053846417662, 45.6134540229802, 23.1722385658670, + 12.5618560729690, 1.07715641721097, 5.01563428984222, + -32.9291952852141, -38.8880776559401, -18.1221698074118, + 7.85250610234389, -13.0753218879785, 7.52085950784656, + 14.7745963136307, 28.0227435151377, 31.7627708322262, + 12.2475086001227, -27.2335702183447, -24.1935304087933, + -7.58332402861928, -26.2716420228479, -38.8797244706213, + -44.0220457052844, -4.90762935690551, -41.8874231134215, + 29.4831416883453, 8.70447045314168, -6.43013158961009, + -9.12801538874479, 0.785828466111815, -4.11511718200689, + 28.0252068321138, -26.5220086627594, 4.70088922863450, + 42.9385970968730, 14.4318130193692, -29.2257707266972, + 46.3088539286913 +}; + +float64_t matrix_f64_100_rand[100] = { + -45.0345569674258, -11.0261163038747, -14.6841428777929, + 0.0345569674258, -11.0261163038747, -14.6841428777929, + -20.3679194392227, 27.5712678608402, -12.1390617339732, + -19.8753669720509, 42.3379642103244, -23.7788252219155, + -23.7517765301667, 40.2716109915281, -25.8308714086167, + 32.1194040197959, 24.4692807074156, -1.32083675968276, + 31.1580458282477, -2.90766514824093, -6.97926086704160, + 10.2843089382083, 30.1014622769739, 44.4787189721646, + -9.60878544118853, -48.4596562348445, -31.1044984967456, + -6.41414114190809, 3.28255887994549, -26.9511839788442, + -31.5183679875864, 21.1215780433683, -47.0779722437854, + -0.913590753192006, -40.3545474831611, -45.6976198342192, + 18.6775433365315, -5.32162505701938, -14.9272896423117, + 34.4308792695389, 40.4880968679893, -27.8253265982760, + 42.8854139478045, -1.07473615999811, -36.8026707393665, + -33.1009970537296, -31.6488844262730, -19.3650527983443, + 43.9001561999887, -30.5235710432951, 47.9748378356085, + -38.2582349144194, 23.0330862855453, -16.2280590178623, + 44.2050590775485, 14.9115474956452, -13.1515403509664, + 0.850865538112700, 37.5942811492984, -27.4078219027601, + -6.11300268738968, -20.3324126781673, -1.13910261964209, + 40.0053846417662, 45.6134540229802, 23.1722385658670, + 12.5618560729690, 1.07715641721097, 5.01563428984222, + -32.9291952852141, -38.8880776559401, -18.1221698074118, + 7.85250610234389, -13.0753218879785, 7.52085950784656, + 14.7745963136307, 28.0227435151377, 31.7627708322262, + 12.2475086001227, -27.2335702183447, -24.1935304087933, + -7.58332402861928, -26.2716420228479, -38.8797244706213, + -44.0220457052844, -4.90762935690551, -41.8874231134215, + 29.4831416883453, 8.70447045314168, -6.43013158961009, + -9.12801538874479, 0.785828466111815, -4.11511718200689, + 28.0252068321138, -26.5220086627594, 4.70088922863450, + 42.9385970968730, 14.4318130193692, -29.2257707266972, + 46.3088539286913 +}; + +MATRIX_TEST_BIGGEST_INPUT_TYPE matrix_zeros[MATRIX_TEST_MAX_ELTS] = {0}; + +const float32_t matrix_f32_scale_values[MATRIX_MAX_COEFFS_LEN] = +{ + 43.0264275639 , -17.0525215570 , -94.8488973910 , -8.1924989580 , + 7.2830326091 , 66.8368719314 , 33.9778190671 , 117.8652289772 , + -129.6077797465, -14.6420815368 , 18.0239223278 , 1.0000000000 , + 55.0375037651 , 1.8674609862 , 0.00000000000 , -33.5750364909 +}; + +const q31_t matrix_q31_scale_values[MATRIX_MAX_COEFFS_LEN] = +{ + 0x0201DC90, 0x211F0D7C, 0x80000000, 0xF573B824, + 0xE85ED05B, 0x311DFB52, 0x3529E750, 0x00000000, + 0x7FFFFFFF, 0x21FA525A, 0x0971FD45, 0x05547B68, + 0x270C6366, 0x06FDD5A6, 0xF7025315, 0xB1155A1E +}; + +const q15_t matrix_q15_scale_values[MATRIX_MAX_COEFFS_LEN] = +{ + 0x0201, 0x211F, 0x8000, 0xF573, + 0xE85E, 0x311D, 0x3529, 0x0000, + 0x7FFF, 0x21FA, 0x0971, 0x0554, + 0x270C, 0x06FD, 0xF702, 0xB115 +}; + +const int32_t matrix_shift_values[MATRIX_MAX_SHIFTS_LEN] = +{ + -16, -7, 0, 7, 16 +}; + +/*--------------------------------------------------------------------------------*/ +/* Matrix Definitions */ +/*--------------------------------------------------------------------------------*/ + +/** + * Define matrices by suffix (f32, q31, q15) for use in test cases. + * + * The rand1 and rand2 suffixes get their data from the same pool of random + * data, but their starting points differ by 1 element. + * + * Makes available: + * - matrix_`suffix`_1x1_rand1/2 + * - matrix_`suffix`_1x4_rand1/2 + * - matrix_`suffix`_2x4_rand1/2 + * - matrix_`suffix`_4x4_rand1/2 + */ +#define MATRIX_DEFINE_MATRICES(suffix) \ + arm_matrix_instance_##suffix matrix_##suffix##_1x1_rand1 = \ + {1, 1, (TYPE_FROM_ABBREV(suffix) *) matrix_f32_100_rand }; \ + arm_matrix_instance_##suffix matrix_##suffix##_1x1_rand2 = \ + {1, 1, (TYPE_FROM_ABBREV(suffix) *) (matrix_f32_100_rand+1)}; \ + arm_matrix_instance_##suffix matrix_##suffix##_1x1_zeros = \ + {1, 1, (TYPE_FROM_ABBREV(suffix) *) matrix_zeros}; \ + \ + arm_matrix_instance_##suffix matrix_##suffix##_1x4_rand1 = \ + {1, 4, (TYPE_FROM_ABBREV(suffix) *) matrix_f32_100_rand }; \ + arm_matrix_instance_##suffix matrix_##suffix##_1x4_rand2 = \ + {1, 4, (TYPE_FROM_ABBREV(suffix) *) (matrix_f32_100_rand+1)}; \ + arm_matrix_instance_##suffix matrix_##suffix##_1x4_zeros = \ + {1, 4, (TYPE_FROM_ABBREV(suffix) *) matrix_zeros}; \ + \ + arm_matrix_instance_##suffix matrix_##suffix##_2x4_rand1 = \ + {2, 4, (TYPE_FROM_ABBREV(suffix) *) matrix_f32_100_rand }; \ + arm_matrix_instance_##suffix matrix_##suffix##_2x4_rand2 = \ + {2, 4, (TYPE_FROM_ABBREV(suffix) *) (matrix_f32_100_rand+1)}; \ + arm_matrix_instance_##suffix matrix_##suffix##_2x4_zeros = \ + {2, 4, (TYPE_FROM_ABBREV(suffix) *) matrix_zeros}; \ + \ + arm_matrix_instance_##suffix matrix_##suffix##_4x4_rand1 = \ + {4, 4, (TYPE_FROM_ABBREV(suffix) *) matrix_f32_100_rand }; \ + arm_matrix_instance_##suffix matrix_##suffix##_4x4_rand2 = \ + {4, 4, (TYPE_FROM_ABBREV(suffix) *) (matrix_f32_100_rand+1)}; \ + arm_matrix_instance_##suffix matrix_##suffix##_4x4_zeros = \ + {4, 4, (TYPE_FROM_ABBREV(suffix) *) matrix_zeros} + +MATRIX_DEFINE_MATRICES(f64); +MATRIX_DEFINE_MATRICES(f32); +MATRIX_DEFINE_MATRICES(q31); +MATRIX_DEFINE_MATRICES(q15); + +/*--------------------------------------------------------------------------------*/ +/* Matrix-Input Arrays */ +/*--------------------------------------------------------------------------------*/ + +/* Define Input #ARR_DESC_t by suffix. + * + * Taking inputs in parallel from the 'a' and 'b' arrays yields the following + * test cases: + * - 1x1 multiplication by zero + * - 1x1 multiplication between random numbers + * - 1x1 * 1x4 valid dimension interaction + * - 1x1 * 2x4 invalid dimension interaction + * - 2x4 * 4x4 larger valid dimension interaction + * - 4x4 * 4x4 larger valid dimension interaction + */ +#define MATRIX_DEFINE_INPUTS(suffix) \ + ARR_DESC_DEFINE(arm_matrix_instance_##suffix *, \ + matrix_##suffix##_a_inputs, \ + 6, \ + CURLY( \ + &matrix_##suffix##_1x1_rand1, \ + &matrix_##suffix##_1x1_rand1, \ + &matrix_##suffix##_1x1_rand1, \ + &matrix_##suffix##_1x1_rand1, \ + &matrix_##suffix##_2x4_rand1, \ + &matrix_##suffix##_4x4_rand1 \ + )); \ + \ + ARR_DESC_DEFINE(arm_matrix_instance_##suffix *, \ + matrix_##suffix##_b_inputs, \ + 6, \ + CURLY( \ + &matrix_##suffix##_1x1_zeros, \ + &matrix_##suffix##_1x1_rand2, \ + &matrix_##suffix##_1x4_rand2, \ + &matrix_##suffix##_2x4_rand2, \ + &matrix_##suffix##_4x4_rand2, \ + &matrix_##suffix##_4x4_rand2 \ + )); \ + \ + ARR_DESC_DEFINE(arm_matrix_instance_##suffix *, \ + matrix_##suffix##_invertible_inputs, \ + 4, \ + CURLY( \ + &matrix_##suffix##_1x1_rand1, \ + &matrix_##suffix##_1x1_rand2, \ + &matrix_##suffix##_4x4_rand1, \ + &matrix_##suffix##_4x4_rand2 \ + )) \ + +MATRIX_DEFINE_INPUTS(f64); +MATRIX_DEFINE_INPUTS(f32); +MATRIX_DEFINE_INPUTS(q31); +MATRIX_DEFINE_INPUTS(q15); diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_group.c new file mode 100644 index 0000000..c87439d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/matrix_tests/matrix_test_group.c @@ -0,0 +1,19 @@ +#include "jtest.h" +#include "matrix_tests.h" + +JTEST_DEFINE_GROUP(matrix_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_GROUP_CALL(mat_add_tests); + JTEST_GROUP_CALL(mat_cmplx_mult_tests); + JTEST_GROUP_CALL(mat_init_tests); + JTEST_GROUP_CALL(mat_inverse_tests); + JTEST_GROUP_CALL(mat_mult_tests); + JTEST_GROUP_CALL(mat_mult_fast_tests); + JTEST_GROUP_CALL(mat_sub_tests); + JTEST_GROUP_CALL(mat_trans_tests); + JTEST_GROUP_CALL(mat_scale_tests); + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/max_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/max_tests.c new file mode 100644 index 0000000..d60973b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/max_tests.c @@ -0,0 +1,36 @@ +#include "jtest.h" +#include "statistics_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "statistics_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MAX_TEST(suffix) \ + STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + max, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + STATISTICS_COMPARE_INTERFACE) + +JTEST_ARM_MAX_TEST(f32); +JTEST_ARM_MAX_TEST(q31); +JTEST_ARM_MAX_TEST(q15); +JTEST_ARM_MAX_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(max_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_max_f32_test); + JTEST_TEST_CALL(arm_max_q31_test); + JTEST_TEST_CALL(arm_max_q15_test); + JTEST_TEST_CALL(arm_max_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/mean_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/mean_tests.c new file mode 100644 index 0000000..291c10a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/mean_tests.c @@ -0,0 +1,36 @@ +#include "jtest.h" +#include "statistics_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "statistics_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MEAN_TEST(suffix) \ + STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + mean, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + STATISTICS_COMPARE_INTERFACE) + +JTEST_ARM_MEAN_TEST(f32); +JTEST_ARM_MEAN_TEST(q31); +JTEST_ARM_MEAN_TEST(q15); +JTEST_ARM_MEAN_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(mean_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_mean_f32_test); + JTEST_TEST_CALL(arm_mean_q31_test); + JTEST_TEST_CALL(arm_mean_q15_test); + JTEST_TEST_CALL(arm_mean_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/min_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/min_tests.c new file mode 100644 index 0000000..9d831d0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/min_tests.c @@ -0,0 +1,36 @@ +#include "jtest.h" +#include "statistics_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "statistics_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_MIN_TEST(suffix) \ + STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + min, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + STATISTICS_COMPARE_INTERFACE) + +JTEST_ARM_MIN_TEST(f32); +JTEST_ARM_MIN_TEST(q31); +JTEST_ARM_MIN_TEST(q15); +JTEST_ARM_MIN_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(min_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_min_f32_test); + JTEST_TEST_CALL(arm_min_q31_test); + JTEST_TEST_CALL(arm_min_q15_test); + JTEST_TEST_CALL(arm_min_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/power_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/power_tests.c new file mode 100644 index 0000000..12c30ea --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/power_tests.c @@ -0,0 +1,36 @@ +#include "jtest.h" +#include "statistics_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "statistics_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_POWER_TEST(suffix, output_type) \ + STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + power, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + STATISTICS_SNR_COMPARE_INTERFACE) + +JTEST_ARM_POWER_TEST(f32, float32_t); +JTEST_ARM_POWER_TEST(q31, q63_t); +JTEST_ARM_POWER_TEST(q15, q63_t); +JTEST_ARM_POWER_TEST(q7, q31_t); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(power_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_power_f32_test); + JTEST_TEST_CALL(arm_power_q31_test); + JTEST_TEST_CALL(arm_power_q15_test); + JTEST_TEST_CALL(arm_power_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/rms_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/rms_tests.c new file mode 100644 index 0000000..d9b1a24 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/rms_tests.c @@ -0,0 +1,34 @@ +#include "jtest.h" +#include "statistics_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "statistics_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_RMS_TEST(suffix) \ + STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + rms, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + STATISTICS_SNR_COMPARE_INTERFACE) + +JTEST_ARM_RMS_TEST(f32); +JTEST_ARM_RMS_TEST(q31); +JTEST_ARM_RMS_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(rms_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_rms_f32_test); + JTEST_TEST_CALL(arm_rms_q31_test); + JTEST_TEST_CALL(arm_rms_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_common_data.c new file mode 100644 index 0000000..ebf4580 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_common_data.c @@ -0,0 +1,94 @@ +#include "statistics_test_data.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + + +ARR_DESC_DEFINE(STATISTICS_BIGGEST_INPUT_TYPE, + statistics_output_fut, + STATISTICS_MAX_INPUT_ELEMENTS, + CURLY(0)); + +ARR_DESC_DEFINE(STATISTICS_BIGGEST_INPUT_TYPE, + statistics_output_ref, + STATISTICS_MAX_INPUT_ELEMENTS, + CURLY(0)); + +uint32_t statistics_idx_fut = 0; +uint32_t statistics_idx_ref = 0; + +STATISTICS_BIGGEST_INPUT_TYPE +statistics_output_f32_ref[STATISTICS_MAX_INPUT_ELEMENTS]; + +STATISTICS_BIGGEST_INPUT_TYPE +statistics_output_f32_fut[STATISTICS_MAX_INPUT_ELEMENTS]; + +/*--------------------------------------------------------------------------------*/ +/* Block Sizes */ +/*--------------------------------------------------------------------------------*/ + +/* + To change test parameter values add/remove values inside CURLY and update + the preceeding parameter to reflect the number of values inside CURLY. +*/ + +ARR_DESC_DEFINE(uint32_t, + statistics_block_sizes, + 4, + CURLY(1, 2, 15, 32)); + +/*--------------------------------------------------------------------------------*/ +/* Test Data */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(float32_t, + statistics_f_32, + 32, + CURLY( + -0.0865129623056441 , -0.3331168756476194, + 0.0250664612949661 , 0.0575352840717098, + -0.2292942701362928 , 0.2381830931285998, + 0.2378328403304206 , -0.0075266553186635, + 0.0654584722817308 , 0.0349278285641849, + -0.0373417155362879 , 0.1451581096586606, + -0.1176633086028378 , 0.4366371636394202, + -0.0272791766173191 , 0.0227862627041619, + 0.2133536422718378 , 0.0118562921047211, + -0.0191296810967338 , -0.1664698927300045, + 0.0588821632785281 , -0.2672363715875608, + 0.1428649103637904 , 0.3247124128892542, + -0.1383551403404573 , 0.1715993345656525, + 0.2508002843205065 , -0.3187459152894954, + -0.2881928863802040 , 0.1142295247316356, + -0.0799771155430726 , 0.1379994750928690 + )); + + +ARR_DESC_DEFINE_SUBSET(statistics_f_31, + statistics_f_32, + 31); + +ARR_DESC_DEFINE_SUBSET(statistics_f_15, + statistics_f_32, + 15); + +ARR_DESC_DEFINE_SUBSET(statistics_f_2, + statistics_f_32, + 2); + +ARR_DESC_DEFINE(float32_t, + statistics_zeros, + 32, + CURLY(0)); + +/* Aggregate all float datasets */ +ARR_DESC_DEFINE(ARR_DESC_t *, + statistics_f_all, + 4, + CURLY( + &statistics_zeros, + &statistics_f_2, + &statistics_f_15, + &statistics_f_32 + )); diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_group.c new file mode 100644 index 0000000..6a610a6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/statistics_test_group.c @@ -0,0 +1,14 @@ +#include "jtest.h" +#include "statistics_tests.h" + +JTEST_DEFINE_GROUP(statistics_tests) +{ + JTEST_GROUP_CALL(max_tests); + JTEST_GROUP_CALL(mean_tests); + JTEST_GROUP_CALL(min_tests); + JTEST_GROUP_CALL(power_tests); + JTEST_GROUP_CALL(rms_tests); + JTEST_GROUP_CALL(std_tests); + JTEST_GROUP_CALL(var_tests); + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/std_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/std_tests.c new file mode 100644 index 0000000..b80ed71 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/std_tests.c @@ -0,0 +1,34 @@ +#include "jtest.h" +#include "statistics_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "statistics_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_STD_TEST(suffix) \ + STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + std, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + STATISTICS_SNR_COMPARE_INTERFACE) + +JTEST_ARM_STD_TEST(f32); +JTEST_ARM_STD_TEST(q31); +JTEST_ARM_STD_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(std_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_std_f32_test); + JTEST_TEST_CALL(arm_std_q31_test); + JTEST_TEST_CALL(arm_std_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/var_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/var_tests.c new file mode 100644 index 0000000..3aa7c27 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/statistics_tests/var_tests.c @@ -0,0 +1,34 @@ +#include "jtest.h" +#include "statistics_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "statistics_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_VAR_TEST(suffix) \ + STATISTICS_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + var, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + STATISTICS_SNR_COMPARE_INTERFACE) + +JTEST_ARM_VAR_TEST(f32); +JTEST_ARM_VAR_TEST(q31); +JTEST_ARM_VAR_TEST(q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(var_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_var_f32_test); + JTEST_TEST_CALL(arm_var_q31_test); + JTEST_TEST_CALL(arm_var_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/copy_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/copy_tests.c new file mode 100644 index 0000000..3804f63 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/copy_tests.c @@ -0,0 +1,33 @@ +#include "jtest.h" +#include "support_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "support_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_COPY_TEST(suffix) \ + SUPPORT_DEFINE_TEST_TEMPLATE_BUF1_BLK( \ + copy, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + SUPPORT_COMPARE_INTERFACE) + +JTEST_ARM_COPY_TEST(f32); +JTEST_ARM_COPY_TEST(q31); +JTEST_ARM_COPY_TEST(q15); +JTEST_ARM_COPY_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(copy_tests) +{ + JTEST_TEST_CALL(arm_copy_f32_test); + JTEST_TEST_CALL(arm_copy_q31_test); + JTEST_TEST_CALL(arm_copy_q15_test); + JTEST_TEST_CALL(arm_copy_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/fill_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/fill_tests.c new file mode 100644 index 0000000..fc5892d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/fill_tests.c @@ -0,0 +1,36 @@ +#include "jtest.h" +#include "support_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "support_templates.h" +#include "type_abbrev.h" + +#define JTEST_ARM_FILL_TEST(suffix) \ + SUPPORT_DEFINE_TEST_TEMPLATE_ELT1_BLK( \ + fill, \ + suffix, \ + TYPE_FROM_ABBREV(suffix), \ + TYPE_FROM_ABBREV(suffix), \ + SUPPORT_COMPARE_INTERFACE) + +JTEST_ARM_FILL_TEST(f32); +JTEST_ARM_FILL_TEST(q31); +JTEST_ARM_FILL_TEST(q15); +JTEST_ARM_FILL_TEST(q7); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(fill_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_fill_f32_test); + JTEST_TEST_CALL(arm_fill_q31_test); + JTEST_TEST_CALL(arm_fill_q15_test); + JTEST_TEST_CALL(arm_fill_q7_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_common_data.c new file mode 100644 index 0000000..f4b5911 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_common_data.c @@ -0,0 +1,85 @@ +#include "arm_math.h" +#include "support_test_data.h" + +#define MAX_INPUT_ELEMENTS 32 +#define BIGGEST_INPUT_TYPE float32_t + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(BIGGEST_INPUT_TYPE, + support_output_fut, + MAX_INPUT_ELEMENTS, + CURLY(0)); + +ARR_DESC_DEFINE(BIGGEST_INPUT_TYPE, + support_output_ref, + MAX_INPUT_ELEMENTS, + CURLY(0)); + +/*--------------------------------------------------------------------------------*/ +/* Block Sizes */ +/*--------------------------------------------------------------------------------*/ + +/* + To change test parameter values add/remove values inside CURLY and update + the preceeding parameter to reflect the number of values inside CURLY. +*/ + +ARR_DESC_DEFINE(uint32_t, + support_block_sizes, + 4, + CURLY( 2, 7, 15, 32)); + +/*--------------------------------------------------------------------------------*/ +/* Numbers */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(uint32_t, + support_elts, + 4, + CURLY( 0, 1, 0x80000000, 0x7fffffff)); + +/*--------------------------------------------------------------------------------*/ +/* Test Data */ +/*--------------------------------------------------------------------------------*/ + +ARR_DESC_DEFINE(float32_t, + support_f_32, + 32, + CURLY( + 0.24865986 , -0.13364227, -0.27233250 , -7.33488200, + 0.42190653 , 1.17435880 , -0.49824914 , 0.87883663, + 0.63066370 , 1.80275680 , -84.83916000, -2.06773800, + 7.63452500 , 1.01487610 , -0.65785825 , 1.78019030, + -0.34160388, 0.68546050 , -1.81721590 , -0.10340453, + -4.48600340, -1.69763480, -1.26022340 , -1.58457480, + 0.51993870 , 2.83526470 , -0.21502694 , -0.57690346, + -0.22945681, 0.79509383 , 0.07275216 , -2.16279080 + )); + +/* Alias the 32 element array with wrappers that end sooner. */ +ARR_DESC_DEFINE_SUBSET(support_f_15, + support_f_32, + 15); + +ARR_DESC_DEFINE_SUBSET(support_f_2, + support_f_32, + 2); + +ARR_DESC_DEFINE(float32_t, + support_zeros, + 32, + CURLY(0)); + +/* Aggregate all float datasets. */ +ARR_DESC_DEFINE(ARR_DESC_t *, + support_f_all, + 4, + CURLY( + &support_zeros, + &support_f_2, + &support_f_15, + &support_f_32 + )); diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_group.c new file mode 100644 index 0000000..7cc2732 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/support_test_group.c @@ -0,0 +1,10 @@ +#include "jtest.h" +#include "support_tests.h" + +JTEST_DEFINE_GROUP(support_tests) +{ + JTEST_GROUP_CALL(copy_tests); + JTEST_GROUP_CALL(fill_tests); + JTEST_GROUP_CALL(x_to_y_tests); + return; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/x_to_y_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/x_to_y_tests.c new file mode 100644 index 0000000..4667031 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/support_tests/x_to_y_tests.c @@ -0,0 +1,80 @@ +#include "jtest.h" +#include "support_test_data.h" +#include "arr_desc.h" +#include "arm_math.h" /* FUTs */ +#include "ref.h" /* Reference Functions */ +#include "test_templates.h" +#include "support_templates.h" +#include "type_abbrev.h" + +/* Aliases to play nicely with templates. */ +#define arm_f32_to_q31 arm_float_to_q31 +#define arm_f32_to_q15 arm_float_to_q15 +#define arm_f32_to_q7 arm_float_to_q7 +#define arm_q31_to_f32 arm_q31_to_float +#define arm_q15_to_f32 arm_q15_to_float +#define arm_q7_to_f32 arm_q7_to_float +#define ref_f32_to_q31 ref_float_to_q31 +#define ref_f32_to_q15 ref_float_to_q15 +#define ref_f32_to_q7 ref_float_to_q7 +#define ref_q31_to_f32 ref_q31_to_float +#define ref_q15_to_f32 ref_q15_to_float +#define ref_q7_to_f32 ref_q7_to_float + +#define JTEST_ARM_X_TO_Y_TEST(prefix, suffix) \ + JTEST_DEFINE_TEST(arm_##prefix##_to_##suffix##_test, \ + arm_##prefix##_to_##suffix) \ + { \ + TEST_TEMPLATE_BUF1_BLK( \ + support_f_all, \ + support_block_sizes, \ + TYPE_FROM_ABBREV(prefix), \ + TYPE_FROM_ABBREV(suffix), \ + arm_##prefix##_to_##suffix, \ + ARM_x_to_y_INPUT_INTERFACE, \ + ref_##prefix##_to_##suffix, \ + REF_x_to_y_INPUT_INTERFACE, \ + SUPPORT_COMPARE_INTERFACE); \ + } + +JTEST_ARM_X_TO_Y_TEST(f32, q31); +JTEST_ARM_X_TO_Y_TEST(f32, q15); +JTEST_ARM_X_TO_Y_TEST(f32, q7); + +JTEST_ARM_X_TO_Y_TEST(q31, f32); +JTEST_ARM_X_TO_Y_TEST(q31, q15); +JTEST_ARM_X_TO_Y_TEST(q31, q7); + +JTEST_ARM_X_TO_Y_TEST(q15, f32); +JTEST_ARM_X_TO_Y_TEST(q15, q31); +JTEST_ARM_X_TO_Y_TEST(q15, q7); + +JTEST_ARM_X_TO_Y_TEST(q7, f32); +JTEST_ARM_X_TO_Y_TEST(q7, q31); +JTEST_ARM_X_TO_Y_TEST(q7, q15); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group. */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(x_to_y_tests) +{ + /* + To skip a test, comment it out. + */ + JTEST_TEST_CALL(arm_f32_to_q31_test); + JTEST_TEST_CALL(arm_f32_to_q15_test); + JTEST_TEST_CALL(arm_f32_to_q7_test); + + JTEST_TEST_CALL(arm_q31_to_f32_test); + JTEST_TEST_CALL(arm_q31_to_q15_test); + JTEST_TEST_CALL(arm_q31_to_q7_test); + + JTEST_TEST_CALL(arm_q15_to_f32_test); + JTEST_TEST_CALL(arm_q15_to_q31_test); + JTEST_TEST_CALL(arm_q15_to_q7_test); + + JTEST_TEST_CALL(arm_q7_to_f32_test); + JTEST_TEST_CALL(arm_q7_to_q31_test); + JTEST_TEST_CALL(arm_q7_to_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_family_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_family_tests.c new file mode 100644 index 0000000..d3e775e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_family_tests.c @@ -0,0 +1,183 @@ +#include "jtest.h" +#include "ref.h" +#include "arr_desc.h" +#include "transform_templates.h" +#include "transform_test_data.h" +#include "type_abbrev.h" + +/*--------------------------------------------------------------------------------*/ +/* Macros and Defines */ +/*--------------------------------------------------------------------------------*/ + +#define CFFT_FN_NAME(fn_specifier, type_suffix) \ + arm_cfft_##fn_specifier##_##type_suffix \ + +#define CFFT_TEST_NAME(fn_specifier, type_suffix, config_suffix) \ + arm_cfft_##fn_specifier##_##type_suffix##_##config_suffix##_test \ + +/*--------------------------------------------------------------------------------*/ +/* Function Aliases */ +/*--------------------------------------------------------------------------------*/ + +/* These aliases allow expansions in the CFFT_FAMILY_DEFINE_TEST() template to + make sense */ +#define arm_cfft_mag_init_f32 arm_cfft_radix4_init_f32 +#define arm_cfft_mag_init_q31 arm_cfft_radix4_init_q31 +#define arm_cfft_mag_init_q15 arm_cfft_radix4_init_q15 +#define arm_cfft_mag_instance_f32 arm_cfft_radix4_instance_f32 +#define arm_cfft_mag_instance_q31 arm_cfft_radix4_instance_q31 +#define arm_cfft_mag_instance_q15 arm_cfft_radix4_instance_q15 +#define transform_mag_fftlens transform_radix4_fftlens + +/*--------------------------------------------------------------------------------*/ +/* Test Definition */ +/*--------------------------------------------------------------------------------*/ + +/** + * Defines a test for the family of CFFT transforms. + * + * The family of CFFT transforms includes: + * + * - arm_cfft_radix4_xxx + * - arm_cfft_radix2_xxx + * - arm_cfft_mag_xxx + * + * Where xxx can be f32, q31, or q15. + * + * @param fn_specifier Allowed values: radix4, radix2, mag. + * @param type_suffix Allowed values: f32, q31, q15. + * + * @param config_suffix Used to differentiate test names based configuration + * (in this case whether the ifft_flag is set or not.) + + * @param comparison_interface Macro name used to compare reference and fut + * outputs. + * + * @param output_tpe The type of variable contained in the output + * (e.g. float32_t, uint32_t, etc). + * + * @param ifft_flag Determines whether the arm_cfft_instance_xxx is configured + * for an inverse FFT. + */ +#define CFFT_FAMILY_DEFINE_TEST(fn_specifier, \ + type_suffix, \ + config_suffix, /* Delineate between test configs*/ \ + comparison_interface, \ + output_type, \ + ifft_flag) \ + JTEST_DEFINE_TEST(CFFT_TEST_NAME(fn_specifier, type_suffix, \ + config_suffix), \ + CFFT_FN_NAME(fn_specifier, type_suffix)) \ + { \ + arm_cfft_##fn_specifier##_instance_##type_suffix cfft_inst_fut; \ + arm_cfft_##fn_specifier##_instance_##type_suffix cfft_inst_ref; \ + \ + TEMPLATE_DO_ARR_DESC( \ + fftlen_idx, uint16_t, fftlen, transform_##fn_specifier##_fftlens \ + , \ + \ + /* Initialize the cfft instance */ \ + arm_cfft_##fn_specifier##_init_##type_suffix( \ + &cfft_inst_fut, fftlen, ifft_flag, (uint8_t)1); \ + arm_cfft_##fn_specifier##_init_##type_suffix( \ + &cfft_inst_ref, fftlen, ifft_flag, (uint8_t)1); \ + \ + TRANSFORM_PREPARE_INPLACE_INPUTS( \ + transform_fft_##type_suffix##_inputs, \ + fftlen * \ + sizeof(TYPE_FROM_ABBREV(type_suffix)) * \ + 2 /*complex_inputs*/); \ + \ + /* Display parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Inverse-transform flag: %d\n", \ + (int)fftlen, \ + (int)ifft_flag); \ + \ + /* Display cycle count and run test */ \ + JTEST_COUNT_CYCLES( \ + arm_cfft_##fn_specifier##_##type_suffix( \ + &cfft_inst_fut, \ + (void*) transform_fft_inplace_input_fut)); \ + \ + ref_cfft_##fn_specifier##_##type_suffix( \ + &cfft_inst_ref, \ + (void *) transform_fft_inplace_input_ref); \ + \ + /* Test correctness */ \ + comparison_interface( \ + fftlen, \ + output_type)); \ + \ + return JTEST_TEST_PASSED; \ + } + +/** + * Bulk wrapper for all tests instantiated using #CFFT_FAMILY_DEFINE_TEST(). + * + * This macro allows several test definitions to share the same config_suffix + * and ifft_flag settings. + */ +#define CFFT_FAMILY_DEFINE_ALL_TESTS(config_suffix, ifft_flag) \ + /* Radix2 tests*/ \ + CFFT_FAMILY_DEFINE_TEST(radix2, q31, config_suffix, \ + TRANSFORM_SNR_COMPARE_CMPLX_INTERFACE, \ + TYPE_FROM_ABBREV(q31), \ + ifft_flag); \ + CFFT_FAMILY_DEFINE_TEST(radix2, q15, config_suffix, \ + TRANSFORM_SNR_COMPARE_CMPLX_INTERFACE, \ + TYPE_FROM_ABBREV(q15), \ + ifft_flag); \ + /* Radix4 tests*/ \ + CFFT_FAMILY_DEFINE_TEST(radix4, q31, config_suffix, \ + TRANSFORM_SNR_COMPARE_CMPLX_INTERFACE, \ + TYPE_FROM_ABBREV(q31), \ + ifft_flag); \ + CFFT_FAMILY_DEFINE_TEST(radix4, q15, config_suffix, \ + TRANSFORM_SNR_COMPARE_CMPLX_INTERFACE, \ + TYPE_FROM_ABBREV(q15), \ + ifft_flag) + /* /\* Mag tests*\/ \ */ + /* CFFT_FAMILY_DEFINE_TEST(mag, f32, config_suffix, \ */ + /* TRANSFORM_SNR_COMPARE_INTERFACE, \ */ + /* TYPE_FROM_ABBREV(f32), \ */ + /* ifft_flag); \ */ + /* CFFT_FAMILY_DEFINE_TEST(mag, q31, config_suffix, \ */ + /* TRANSFORM_SNR_COMPARE_INTERFACE, \ */ + /* TYPE_FROM_ABBREV(q31), \ */ + /* ifft_flag); \ */ + /* CFFT_FAMILY_DEFINE_TEST(mag, q15, config_suffix, \ */ + /* TRANSFORM_SNR_COMPARE_INTERFACE, \ */ + /* TYPE_FROM_ABBREV(q15), \ */ + /* ifft_flag) */ + +CFFT_FAMILY_DEFINE_ALL_TESTS(forward, 0U); +CFFT_FAMILY_DEFINE_ALL_TESTS(inverse, 1U); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cfft_family_tests) +{ + /* Forward FFT tests */ + JTEST_TEST_CALL(arm_cfft_radix2_q31_forward_test); + JTEST_TEST_CALL(arm_cfft_radix2_q15_forward_test); + JTEST_TEST_CALL(arm_cfft_radix4_q31_forward_test); + JTEST_TEST_CALL(arm_cfft_radix4_q15_forward_test); + + /* Inverse FFT Tests */ + JTEST_TEST_CALL(arm_cfft_radix2_q31_inverse_test); + JTEST_TEST_CALL(arm_cfft_radix2_q15_inverse_test); + JTEST_TEST_CALL(arm_cfft_radix4_q31_inverse_test); + JTEST_TEST_CALL(arm_cfft_radix4_q15_inverse_test); + + /* Magnitude tests removed from the DSP Library. Keeping them here in case + minds are changed. */ + /* JTEST_TEST_CALL(arm_cfft_mag_f32_forward_test); */ + /* JTEST_TEST_CALL(arm_cfft_mag_q31_forward_test); */ + /* JTEST_TEST_CALL(arm_cfft_mag_q15_forward_test); */ + /* JTEST_TEST_CALL(arm_cfft_mag_f32_inverse_test); */ + /* JTEST_TEST_CALL(arm_cfft_mag_q31_inverse_test); */ + /* JTEST_TEST_CALL(arm_cfft_mag_q15_inverse_test); */ +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_tests.c new file mode 100644 index 0000000..f26c6f6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/cfft_tests.c @@ -0,0 +1,144 @@ +#include "jtest.h" +#include "ref.h" +#include "arr_desc.h" +#include "transform_templates.h" +#include "transform_test_data.h" + +#define CFFT_SNR_THRESHOLD 120 + +/* + CFFT function test template. Arguments are: inverse-transform flag, function + suffix (q7/q15/q31/f32) and the output type (q7_t, q15_t, q31_t, float32_t) +*/ +#define CFFT_TEST_BODY(ifft_flag, suffix, output_type) \ + do \ + { \ + /* Go through all arm_cfft_instances */ \ + TEMPLATE_DO_ARR_DESC( \ + cfft_inst_idx, const arm_cfft_instance_##suffix *, cfft_inst_ptr, \ + transform_cfft_##suffix##_structs \ + , \ + \ + TRANSFORM_PREPARE_INPLACE_INPUTS( \ + transform_fft_##suffix##_inputs, \ + cfft_inst_ptr->fftLen * \ + sizeof(output_type) * \ + 2 /*complex_inputs*/); \ + \ + /* Display parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Inverse-transform flag: %d\n", \ + (int)cfft_inst_ptr->fftLen, \ + (int)ifft_flag); \ + \ + /* Display cycle count and run test */ \ + JTEST_COUNT_CYCLES( \ + arm_cfft_##suffix(cfft_inst_ptr, \ + (void *) transform_fft_inplace_input_fut, \ + ifft_flag, /* IFFT Flag */ \ + 1)); /* Bitreverse flag */ \ + ref_cfft_##suffix(cfft_inst_ptr, \ + (void *) transform_fft_inplace_input_ref, \ + ifft_flag, /* IFFT Flag */ \ + 1); /* Bitreverse flag */ \ + \ + /* Test correctness */ \ + TRANSFORM_SNR_COMPARE_CMPLX_INTERFACE( \ + cfft_inst_ptr->fftLen, \ + output_type)); \ + \ + return JTEST_TEST_PASSED; \ + } while (0) + + +/* + CFFT function with downshift test template. Arguments are: inverse-transform flag, + function suffix (q7/q15/q31/f32) and the output type (q7_t, q15_t, q31_t, float32_t) +*/ +#define CFFT_DOWNSHIFT_INPUT_TEST_BODY(ifft_flag, suffix, output_type) \ + do \ + { \ + /* Go through all arm_cfft_instances */ \ + TEMPLATE_DO_ARR_DESC( \ + cfft_inst_idx, const arm_cfft_instance_##suffix *, cfft_inst_ptr, \ + transform_cfft_##suffix##_structs \ + , \ + \ + TRANSFORM_PREPARE_INPLACE_INPUTS_DOWNSHIFT( \ + transform_fft_##suffix##_inputs, \ + cfft_inst_ptr->fftLen * \ + sizeof(output_type) * \ + 2 /*complex_inputs*/, output_type); \ + \ + /* Display parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Inverse-transform flag: %d\n", \ + (int)cfft_inst_ptr->fftLen, \ + (int)ifft_flag); \ + \ + /* Display cycle count and run test */ \ + JTEST_COUNT_CYCLES( \ + arm_cfft_##suffix(cfft_inst_ptr, \ + (void *) transform_fft_inplace_input_fut, \ + ifft_flag, /* IFFT Flag */ \ + 1)); /* Bitreverse flag */ \ + ref_cfft_##suffix(cfft_inst_ptr, \ + (void *) transform_fft_inplace_input_ref, \ + ifft_flag, /* IFFT Flag */ \ + 1); /* Bitreverse flag */ \ + \ + /* Test correctness */ \ + TRANSFORM_SNR_COMPARE_CMPLX_INTERFACE( \ + cfft_inst_ptr->fftLen, \ + output_type)); \ + \ + return JTEST_TEST_PASSED; \ + } while (0) + + +/* Test declarations */ +JTEST_DEFINE_TEST(cfft_f32_test, cfft_f32) +{ + CFFT_TEST_BODY((uint8_t) 0, f32, float32_t); +} + +JTEST_DEFINE_TEST(cfft_f32_ifft_test, cfft_f32) +{ + CFFT_TEST_BODY((uint8_t) 1, f32, float32_t); +} + +JTEST_DEFINE_TEST(cfft_q31_test, cfft_q31) +{ + CFFT_TEST_BODY((uint8_t) 0, q31, q31_t); +} + +JTEST_DEFINE_TEST(cfft_q31_ifft_test, cfft_q31) +{ + CFFT_TEST_BODY((uint8_t) 1, q31, q31_t); +} + +JTEST_DEFINE_TEST(cfft_q15_test, cfft_q15) +{ + CFFT_TEST_BODY((uint8_t) 0, q15, q15_t); +} + +JTEST_DEFINE_TEST(cfft_q15_ifft_test, cfft_q15) +{ + CFFT_TEST_BODY((uint8_t) 1, q15, q15_t); +} + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(cfft_tests) +{ + JTEST_TEST_CALL(cfft_f32_test); + JTEST_TEST_CALL(cfft_f32_ifft_test); + + JTEST_TEST_CALL(cfft_q31_test); + JTEST_TEST_CALL(cfft_q31_ifft_test); + + JTEST_TEST_CALL(cfft_q15_test); + JTEST_TEST_CALL(cfft_q15_ifft_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/dct4_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/dct4_tests.c new file mode 100644 index 0000000..aae5a42 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/dct4_tests.c @@ -0,0 +1,197 @@ +#include "jtest.h" +#include "ref.h" +#include "arm_math.h" +#include "arr_desc.h" +#include "transform_templates.h" +#include "transform_test_data.h" +#include "type_abbrev.h" +#include /* sqrtf() */ + +/*--------------------------------------------------------------------------------*/ +/* Aliases to aid macro expansion */ +/*--------------------------------------------------------------------------------*/ +#define ref_sqrt_f32(x) sqrtf(x) + +/*--------------------------------------------------------------------------------*/ +/* Test Definitions */ +/*--------------------------------------------------------------------------------*/ + +/* +DCT function test template. Arguments are: function configuration suffix +(q7/q15/q31/f32) and input type (q7_t/q15_t/q31_t/float32_t) +*/ +#define DCT4_DEFINE_TEST(suffix, input_type) \ + JTEST_DEFINE_TEST(arm_dct4_##suffix##_test, arm_dct4_##suffix) \ + { \ + CONCAT(arm_dct4_instance_,suffix) dct4_inst_fut = {0}; \ + CONCAT(arm_rfft_instance_,suffix) rfft_inst_fut = {0}; \ + CONCAT(arm_cfft_radix4_instance_,suffix) cfft_inst_fut = {0}; \ + \ + CONCAT(arm_dct4_instance_,suffix) dct4_inst_ref = {0}; \ + CONCAT(arm_rfft_instance_,suffix) rfft_inst_ref = {0}; \ + CONCAT(arm_cfft_radix4_instance_,suffix) cfft_inst_ref = {0}; \ + \ + /* Go through all dct lengths */ \ + TEMPLATE_DO_ARR_DESC( \ + fftlen_idx, uint16_t, fftlen, transform_dct_fftlens \ + , \ + \ + float32_t normalize_f32 = \ + ref_sqrt_f32((2.0f/(float32_t)fftlen)); \ + input_type normalize; \ + \ + /* Calculate normalized DCT4 value for input_type. */ \ + TEST_CONVERT_FLOAT_TO(&normalize_f32, &normalize, \ + 1, input_type); \ + \ + /* Initialize the DCT4, RFFT, and CFFT instances */ \ + arm_dct4_init_##suffix( \ + &dct4_inst_fut, &rfft_inst_fut, &cfft_inst_fut, \ + fftlen, \ + fftlen/2, \ + normalize); \ + \ + arm_dct4_init_##suffix( \ + &dct4_inst_ref, &rfft_inst_ref, &cfft_inst_ref, \ + fftlen, \ + fftlen/2, \ + normalize); \ + \ + memset( transform_fft_input_fut,0, \ + fftlen*sizeof(input_type)); \ + \ + TRANSFORM_PREPARE_INPLACE_INPUTS( \ + transform_fft_##suffix##_inputs, \ + fftlen * sizeof(input_type)); \ + \ + /* Display parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n", \ + (int)fftlen); \ + \ + /* Input provided as a scratch buffer. Inplace input is \ + * actual input. Display cycle count and run test*/ \ + JTEST_COUNT_CYCLES( \ + arm_dct4_##suffix( \ + &dct4_inst_fut, \ + (void *) transform_fft_input_fut, \ + (void *) transform_fft_inplace_input_fut)); \ + \ + memset( transform_fft_input_ref,0, \ + fftlen*sizeof(input_type)); \ + \ + /* Input provided as a scratch buffer. Inplace input is */ \ + /* actual input. */ \ + ref_dct4_##suffix( \ + &dct4_inst_ref, \ + (void *) transform_fft_input_ref, \ + (void *) transform_fft_inplace_input_ref); \ + \ + /* Test correctness */ \ + DCT_TRANSFORM_SNR_COMPARE_INTERFACE( \ + fftlen, \ + input_type)); \ + \ + return JTEST_TEST_PASSED; \ + } + +/* + DCT function test template for fixed point data. Arguments are: function + suffix (q7/q15/q31/f32), input type (q7_t/q15_t/q31_t/float32_t) and prefix + (dct_4) +*/ +#define DCT4_FIXED_POINT_DEFINE_TEST(suffix, input_type, prefix) \ + JTEST_DEFINE_TEST(arm_dct4_##suffix##_test, arm_dct4_##suffix) \ + { \ + CONCAT(arm_dct4_instance_,suffix) dct4_inst_fut = {0}; \ + CONCAT(arm_rfft_instance_,suffix) rfft_inst_fut = {0}; \ + CONCAT(arm_cfft_radix4_instance_,suffix) cfft_inst_fut = {0}; \ + \ + CONCAT(arm_dct4_instance_,suffix) dct4_inst_ref = {0}; \ + CONCAT(arm_rfft_instance_,suffix) rfft_inst_ref = {0}; \ + CONCAT(arm_cfft_radix4_instance_,suffix) cfft_inst_ref = {0}; \ + \ + TEMPLATE_DO_ARR_DESC( \ + fftlen_idx, uint16_t, fftlen, transform_dct_fftlens \ + , \ + uint32_t i; \ + float32_t normalize_f32 = \ + ref_sqrt_f32((2.0f/(float32_t)fftlen)); \ + input_type normalize; \ + \ + /* Calculate normalized DCT4 value for input_type. */ \ + TEST_CONVERT_FLOAT_TO(&normalize_f32, &normalize, \ + 1, input_type); \ + \ + /* Initialize the DCT4, RFFT, and CFFT instances */ \ + arm_dct4_init_##suffix( \ + &dct4_inst_fut, &rfft_inst_fut, &cfft_inst_fut, \ + fftlen, \ + fftlen/2, \ + normalize); \ + \ + arm_dct4_init_##suffix( \ + &dct4_inst_ref, &rfft_inst_ref, &cfft_inst_ref, \ + fftlen, \ + fftlen/2, \ + normalize); \ + \ + /* Input samples need to be downscaled by 1 bit to \ + * avoid saturations in the Q31 DCT process, \ + * as the conversion from DCT2 to DCT4 involves \ + * one subtraction. \ + */ \ + for(i=0; i < fftlen; i++) \ + { \ + ((input_type*)transform_fft_inplace_input_fut)[i] = \ + prefix##transform_fft_##suffix##_inputs[i] >> 1; \ + ((input_type*)transform_fft_inplace_input_ref)[i] = \ + prefix##transform_fft_##suffix##_inputs[i] >> 1; \ + } \ + \ + memset( transform_fft_input_fut,0, \ + fftlen*sizeof(input_type)); \ + \ + /* Display test parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n", \ + (int)fftlen); \ + \ + /* Input provided as a scratch buffer. Inplace input is \ + * actual input. */ \ + JTEST_COUNT_CYCLES( \ + arm_dct4_##suffix( \ + &dct4_inst_fut, \ + (void *) transform_fft_input_fut, \ + (void *) transform_fft_inplace_input_fut)); \ + \ + memset( transform_fft_input_ref,0, \ + fftlen*sizeof(input_type)); \ + \ + /* Input provided as a scratch buffer. Inplace input is */ \ + /* actual input. */ \ + ref_dct4_##suffix( \ + &dct4_inst_ref, \ + (void *) transform_fft_input_ref, \ + (void *) transform_fft_inplace_input_ref); \ + \ + /* Test correctness */ \ + DCT_TRANSFORM_SNR_COMPARE_INTERFACE( \ + fftlen, \ + input_type)); \ + \ + return JTEST_TEST_PASSED; \ + } + +DCT4_DEFINE_TEST(f32, float32_t); +DCT4_FIXED_POINT_DEFINE_TEST(q31, q31_t,); +DCT4_FIXED_POINT_DEFINE_TEST(q15, q15_t, dct4_); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(dct4_tests) +{ + JTEST_TEST_CALL(arm_dct4_f32_test); + JTEST_TEST_CALL(arm_dct4_q31_test); + JTEST_TEST_CALL(arm_dct4_q15_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_fast_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_fast_tests.c new file mode 100644 index 0000000..d8a8e17 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_fast_tests.c @@ -0,0 +1,75 @@ +#include "jtest.h" +#include "ref.h" +#include "arr_desc.h" +#include "transform_templates.h" +#include "transform_test_data.h" +#include "type_abbrev.h" + +/* +FFT fast function test template. Arguments are: function configuration suffix +(q7/q15/q31/f32) and inverse-transform flag +*/ +#define RFFT_FAST_DEFINE_TEST(config_suffix, ifft_flag) \ + JTEST_DEFINE_TEST(arm_rfft_fast_f32_##config_suffix##_test, \ + arm_fft_f32) \ + { \ + arm_rfft_fast_instance_f32 rfft_inst_fut = {{0}, 0, 0}; \ + arm_rfft_fast_instance_f32 rfft_inst_ref = {{0}, 0, 0}; \ + \ + /* Go through all FFT lengths */ \ + TEMPLATE_DO_ARR_DESC( \ + fftlen_idx, uint16_t, fftlen, transform_rfft_fast_fftlens \ + , \ + \ + /* Initialize the RFFT and CFFT Instances */ \ + arm_rfft_fast_init_f32( \ + &rfft_inst_fut, fftlen); \ + \ + arm_rfft_fast_init_f32( \ + &rfft_inst_ref, fftlen); \ + \ + TRANSFORM_COPY_INPUTS( \ + transform_fft_f32_inputs, \ + fftlen * \ + sizeof(float32_t)); \ + \ + /* Display parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Inverse-transform flag: %d\n", \ + (int)fftlen, \ + (int)ifft_flag); \ + \ + /* Display cycle count and run test */ \ + JTEST_COUNT_CYCLES( \ + arm_rfft_fast_f32( \ + &rfft_inst_fut, \ + (void *) transform_fft_input_fut, \ + (void *) transform_fft_output_fut, \ + ifft_flag)); \ + \ + ref_rfft_fast_f32( \ + &rfft_inst_ref, \ + (void *) transform_fft_input_ref, \ + (void *) transform_fft_output_ref, \ + ifft_flag); \ + \ + /* Test correctness */ \ + TRANSFORM_SNR_COMPARE_INTERFACE( \ + fftlen, \ + float32_t)); \ + \ + return JTEST_TEST_PASSED; \ + } + +RFFT_FAST_DEFINE_TEST(forward, 0U); +RFFT_FAST_DEFINE_TEST(inverse, 1U); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(rfft_fast_tests) +{ + JTEST_TEST_CALL(arm_rfft_fast_f32_forward_test); + JTEST_TEST_CALL(arm_rfft_fast_f32_inverse_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_tests.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_tests.c new file mode 100644 index 0000000..6fbc8e6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/rfft_tests.c @@ -0,0 +1,94 @@ +#include "jtest.h" +#include "ref.h" +#include "arr_desc.h" +#include "transform_templates.h" +#include "transform_test_data.h" +#include "type_abbrev.h" + +/* + FFT function test template. Arguments are: function suffix (q7/q15/q31/f32) + function configuration suffix (same as function suffix), inverse-transform flag, + input and output type (both q7_t/q15_t/q31_t/float32_t) +*/ +#define RFFT_DEFINE_TEST(suffix, config_suffix, \ + ifft_flag, input_type, output_type) \ + JTEST_DEFINE_TEST(arm_rfft_##suffix##_##config_suffix##_test, \ + arm_rfft_##suffix) \ + { \ + CONCAT(arm_rfft_instance_, suffix) rfft_inst_fut = {0}; \ + CONCAT(arm_rfft_instance_, suffix) rfft_inst_ref = {0}; \ + \ + /* Go through all arm_rfft lengths */ \ + TEMPLATE_DO_ARR_DESC( \ + fftlen_idx, uint16_t, fftlen, transform_rfft_fftlens \ + , \ + \ + /* Initialize the RFFT and CFFT Instances */ \ + arm_rfft_init_##suffix( \ + &rfft_inst_fut, \ + (uint32_t) fftlen, ifft_flag, 1U); \ + \ + arm_rfft_init_##suffix( \ + &rfft_inst_ref, \ + (uint32_t) fftlen, ifft_flag, 1U); \ + \ + if (ifft_flag) \ + { \ + TRANSFORM_PREPARE_INVERSE_INPUTS( \ + transform_fft_##suffix##_inputs, \ + fftlen, input_type, \ + fftlen * \ + sizeof(input_type)); \ + } \ + else \ + { \ + TRANSFORM_COPY_INPUTS( \ + transform_fft_##suffix##_inputs, \ + fftlen * \ + sizeof(input_type)); \ + } \ + \ + /* Display parameter values */ \ + JTEST_DUMP_STRF("Block Size: %d\n" \ + "Inverse-transform flag: %d\n", \ + (int)fftlen, \ + (int)ifft_flag); \ + \ + /* Display cycle count and run test */ \ + JTEST_COUNT_CYCLES( \ + arm_rfft_##suffix( \ + &rfft_inst_fut, \ + (void *) transform_fft_input_fut, \ + (void *) transform_fft_output_fut)); \ + \ + ref_rfft_##suffix( \ + &rfft_inst_ref, \ + (void *) transform_fft_input_ref, \ + (void *) transform_fft_output_ref); \ + \ + /* Test correctness */ \ + TRANSFORM_SNR_COMPARE_INTERFACE( \ + fftlen, \ + output_type)); \ + \ + return JTEST_TEST_PASSED; \ + } + +RFFT_DEFINE_TEST(q31, forward, 0U, TYPE_FROM_ABBREV(q31), TYPE_FROM_ABBREV(q31)); +RFFT_DEFINE_TEST(q15, forward, 0U, TYPE_FROM_ABBREV(q15), TYPE_FROM_ABBREV(q15)); +//RFFT_DEFINE_TEST(f32, inverse, 1U, TYPE_FROM_ABBREV(f32), TYPE_FROM_ABBREV(f32)); +RFFT_DEFINE_TEST(q31, inverse, 1U, TYPE_FROM_ABBREV(q31), TYPE_FROM_ABBREV(q31)); +RFFT_DEFINE_TEST(q15, inverse, 1U, TYPE_FROM_ABBREV(q15), TYPE_FROM_ABBREV(q15)); + +/*--------------------------------------------------------------------------------*/ +/* Collect all tests in a group */ +/*--------------------------------------------------------------------------------*/ + +JTEST_DEFINE_GROUP(rfft_tests) +{ + JTEST_TEST_CALL(arm_rfft_q31_forward_test); + JTEST_TEST_CALL(arm_rfft_q15_forward_test); + //JTEST_TEST_CALL(arm_rfft_f32_inverse_test); + JTEST_TEST_CALL(arm_rfft_q31_inverse_test); + JTEST_TEST_CALL(arm_rfft_q15_inverse_test); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_test_group.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_test_group.c new file mode 100644 index 0000000..f071068 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_test_group.c @@ -0,0 +1,11 @@ +#include "jtest.h" +#include "transform_tests.h" + +JTEST_DEFINE_GROUP(transform_tests) +{ + JTEST_GROUP_CALL(cfft_tests); + JTEST_GROUP_CALL(cfft_family_tests); + JTEST_GROUP_CALL(rfft_tests); + JTEST_GROUP_CALL(rfft_fast_tests); + JTEST_GROUP_CALL(dct4_tests); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_tests_common_data.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_tests_common_data.c new file mode 100644 index 0000000..98987b3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/Common/src/transform_tests/transform_tests_common_data.c @@ -0,0 +1,3311 @@ +#include "transform_test_data.h" +#include "arm_const_structs.h" + +/*--------------------------------------------------------------------------------*/ +/* Input/Output Buffers */ +/*--------------------------------------------------------------------------------*/ + +float32_t transform_fft_output_fut[TRANSFORM_MAX_FFT_LEN * 2] = {0}; +float32_t transform_fft_output_ref[TRANSFORM_MAX_FFT_LEN * 2] = {0}; +float32_t transform_fft_input_fut[TRANSFORM_MAX_FFT_LEN * 2] = {0}; +float32_t transform_fft_input_ref[TRANSFORM_MAX_FFT_LEN * 2] = {0}; +float32_t transform_fft_output_f32_fut[TRANSFORM_MAX_FFT_LEN * 2] = {0}; +float32_t transform_fft_output_f32_ref[TRANSFORM_MAX_FFT_LEN * 2] = {0}; + +/* Some of the transform function modify their inputs in-place, so that they + * become the outputs. */ +float32_t * transform_fft_inplace_input_fut = transform_fft_output_fut; +float32_t * transform_fft_inplace_input_ref = transform_fft_output_ref; + +q31_t transform_fft_q31_inputs[TRANSFORM_MAX_FFT_LEN * 2] = +{ + 0xC14A5524, 0xCCABDA17, 0xAD6F5B56, 0xFDAFCE3B, 0xA9B226EB, + 0x41F6F6A, 0xA5CE38BF, 0x3A978AFA, 0xBA44B82A, 0x855C0F8, + 0x3D060524, 0x93D5E570, 0x97D7791D, 0xFFE0C38C, 0x26749841, + 0xC0A6EE54, 0x218EC386, 0x39FF3726, 0x8DC1F7CA, 0x702F2CF5, + 0xC1142FF1, 0xEC1476AB, 0x15F640DD, 0xE62CCE49, 0x3805DE7E, + 0xF70871FE, 0xCF8BD360, 0x8D19A8A0, 0xD764F821, 0xA58558CF, + 0x8C0CE04D, 0x50A46C19, 0x66D2370D, 0x50FA359A, 0xB646AE24, + 0x6CE00F5C, 0xE6D48948, 0xB55BD831, 0x3B72950A, 0x9EB69530, + 0x73394127, 0x773FA6F4, 0x9805A980, 0x838DE587, 0x9CF597F4, + 0xA2AD1691, 0xFA81A473, 0x7CDC7D7F, 0x4A5190D0, 0xED895BB9, + 0x8FD60F35, 0x1A21D530, 0xA0EB6DDA, 0xBDE6A516, 0x2501A3E1, + 0x5ED893C8, 0xE1E175B1, 0xACBBB2F3, 0xED350907, 0xDB140D7E, + 0xEEAE272D, 0xBE229841, 0xC18BFB88, 0xA6BB9B80, 0xBCF090E4, + 0x24DB166C, 0xF9AB7E42, 0x62DF28D1, 0xC7004665, 0xE3F56FC6, + 0x419E0C75, 0x46BE9F38, 0x2432B9B2, 0x758D83E0, 0xDCE12926, + 0x3F57CB74, 0x1F4458E2, 0xF1DD639, 0x83A1FB49, 0x173AFC76, + 0x86EF7531, 0x48D32F34, 0x7D3E3063, 0x8F2FB549, 0x5C314C9, + 0x18CBEB6D, 0xA6F8B697, 0x447B9E9C, 0x2E32BA33, 0xD074D715, + 0x81ACD746, 0xE55A4E04, 0x4891860F, 0x1DA3EB4F, 0xE0E6A27F, + 0x20BFDEB4, 0xD0B3A25B, 0x40C10544, 0xC15656C, 0x15405EAE, + 0x9858E3E1, 0xA36A9C4E, 0x88BD21F9, 0xAACF7A68, 0x773665E5, + 0xCEDFDF66, 0x617A9610, 0x524FC968, 0xC2D086CD, 0x5F008079, + 0x24DCA447, 0x6A4F5599, 0xB706CD4A, 0x1DE70608, 0xA33A2EE5, + 0x137E488E, 0x98061B7B, 0x4079D69D, 0xA4A897D5, 0xC4CEC8F5, + 0xD75F7883, 0x22406802, 0xF1AD70BB, 0x9D4ADD79, 0xBCBC7CE4, + 0xB358C0D8, 0x85792E47, 0xA7ADAC05, 0x3D19EEAB, 0x331AC0AF, + 0x33035831, 0x13D93987, 0xFC542094, 0x845F317E, 0xDDC4BF8B, + 0x1379E50C, 0x5C20193F, 0xFDD58298, 0x9D482B82, 0x4A6BE062, + 0xDC8A757B, 0x272917C1, 0x90E1EFBC, 0x355AD882, 0xE6F8EA35, + 0x604555A1, 0x7DFFFBB, 0xF58AE216, 0x9A11B463, 0xD3541BAD, + 0xA1576756, 0x483BED8D, 0x1F05AFCC, 0xCEA63DFB, 0x55B84677, + 0xFB2E04F2, 0x787AF96C, 0x84A12CD3, 0x460A9BD, 0x9DB22DD8, + 0x1A8C7F28, 0x861E452E, 0x932D3F78, 0x7652D852, 0x73357BBA, + 0xEBBB0A58, 0x62536AFA, 0x3F6B65EF, 0x6DC57B58, 0x9EB798CE, + 0xE6B0A740, 0xDFF68B47, 0x3247FB8F, 0xFFF3D302, 0xA9FD3E40, + 0x475A43D1, 0x6FF9528A, 0x2018A09D, 0x47E0F9C9, 0x4CF5F6D3, + 0x2807CE34, 0xDD6FD8ED, 0x234045D1, 0x51CEB5F9, 0x25297896, + 0x6443A0FE, 0x8F4449A9, 0xD4C3E1C6, 0xF01D52F1, 0x4E09C820, + 0xF18F0810, 0xE1548689, 0xF9DE5A1F, 0x5286DC23, 0x48AC3A4B, + 0xEA0C1BE0, 0xA1B785DB, 0x7086465D, 0x1CC10929, 0x1E1D716E, + 0xED231D4C, 0x2049D108, 0xB8FF9971, 0x949CF8D4, 0x441F1E8B, + 0xC3D95372, 0x69C324B4, 0xA10BFDC9, 0xC781DE78, 0x82476137, + 0xE163DDF, 0x390DEEC2, 0xAF68CE5B, 0x8E680ABD, 0x8223A615, + 0x92593380, 0x7B1465FE, 0x865AE957, 0x930F53EB, 0xED772EF7, + 0x10E916B6, 0xE3BCFA68, 0x2ACB80BB, 0xE51C5590, 0x994714B5, + 0xF30984EE, 0x59BBE1B4, 0xB4867DBC, 0xB91C706C, 0xBC16C218, + 0xA8931CD0, 0x129A66AB, 0x13171F4D, 0x62882872, 0x4B167FD4, + 0xE6902F4C, 0xFA794932, 0xD4B152C, 0xB0856EA9, 0x39466D55, + 0x3669E451, 0x8F5B9E8C, 0x877A3C6A, 0x51B956B4, 0x367EAD2A, + 0x9D2C662A, 0x78FB6880, 0x4E6D40B6, 0x4070EFDC, 0x4DF9679C, + 0x20306EDB, 0xE381AAE7, 0xA55DA748, 0x9B8B617B, 0x3E036FAD, + 0x84E4C4A7, 0xD5A3F517, 0x669BA988, 0x98FDDE8C, 0x67BD85CE, + 0x34BBB46C, 0x76994800, 0x85B9D8B6, 0x6DFA2FEF, 0x205DB5C, + 0x9F843C4C, 0x72721B52, 0x73EF6B86, 0x5FB98B61, 0xC323DDAC, + 0x31D424B4, 0xF68C0D7E, 0x162FAF9D, 0x7B2A7A99, 0xF9392693, + 0xC42D12C0, 0x8692A73E, 0xD9A1EE80, 0xDD956856, 0x44E7BDAC, + 0x8D874532, 0x5F5C9DD0, 0x5D167858, 0x8559FEA2, 0x9D821476, + 0xD9654ED2, 0x594C0DC7, 0x1A87B506, 0x3F693200, 0x7A651AB5, + 0xA0CCBC8A, 0x9F9E662C, 0x78EF631, 0x2A09DA0, 0xB088C72F, + 0x92EE0D42, 0x360DCD5F, 0xF333FE48, 0x8D63CC06, 0x233A8ACB, + 0x706651ED, 0x7AA5C079, 0x262239D1, 0x3EBBEBB6, 0xA25A4F3D, + 0x32581A06, 0x6E6FD780, 0x5773F7C7, 0x75ED1DDC, 0x90DF2D15, + 0xBC79A9BC, 0xB7175917, 0x354E381C, 0x762AADD7, 0xF643DAC1, + 0xF3BBF49E, 0xD2FECE7E, 0x6C8140F4, 0xD7694875, 0x92D30822, + 0xC742A7CF, 0xB792ED98, 0x121CFE24, 0xA04E1EE7, 0x58CE268, + 0x215A080, 0x316CB323, 0xFAB14A31, 0xE1C13C03, 0xFD8EF4F1, + 0xF3F446D0, 0x6C6CEA0A, 0xBBFDF9FB, 0x67242969, 0xBE55A4EB, + 0x8FF5534, 0x52F0DF1C, 0x9710ADE3, 0xD40F4A21, 0x7984E8E7, + 0x419545EB, 0x993F7880, 0xAB246B20, 0x408AABC4, 0xCBF6EA49, + 0xC0894C55, 0x4CAA6398, 0xA47856E9, 0xAF2AE47D, 0x22F55D33, + 0xF0D37915, 0xD0634C72, 0xD983671, 0x2BCC5AF8, 0x9A77D48, + 0xC11B5CFA, 0xF107CD7E, 0x3A6B3593, 0xE1425F05, 0x6271812A, + 0x5B838310, 0xBD8418CA, 0x10A58792, 0x239F7137, 0xA13D5071, + 0x7F9930D4, 0xA462664F, 0x54180F8E, 0x291585BA, 0xE586B87A, + 0x144B2C12, 0x98E425C7, 0xBAA4B373, 0x18F0D03C, 0x99462AC0, + 0xD8B4D2EF, 0x72473895, 0xA6BF5435, 0xEDAD53B, 0xE0912FA6, + 0x5C33F331, 0x3D93CD7, 0x4D03D752, 0x20699929, 0xB89962F9, + 0x36E781E9, 0xF58B642C, 0x5FCA69E3, 0x5960A7F4, 0xAD5AAFD0, + 0xDF18324A, 0x3DB1E5AA, 0x76BA3876, 0x1BC29AF6, 0xBCC18841, + 0x73A60174, 0x625BFF58, 0x67C57724, 0x4458E53C, 0xE157B095, + 0x2B370837, 0x83DF6CE3, 0xDD08EEFA, 0x3F52A7C2, 0x191B4785, + 0x60843D82, 0xB0DE11F1, 0x105EA26C, 0x6E1C7AA2, 0x47AADD14, + 0xB6676D03, 0x3B8D4DF6, 0x737A694, 0x409521DC, 0x744206A, + 0xC722023F, 0x2BE4EAD5, 0x63E11D76, 0xCA4A09AB, 0x5CF2D2B9, + 0x31586916, 0xCDFD7D84, 0xB203F634, 0xAD7329D4, 0xC524582F, + 0x2E53E6C1, 0xBB0E019B, 0xB8538C6A, 0x6A2542D, 0x8A6A00E5, + 0x119725CC, 0x5406D347, 0x1B6FFAF1, 0xECCF71F1, 0x981117F2, + 0x7167CA76, 0x74F4B880, 0x77A55F47, 0x59EADB62, 0x4A331D95, + 0xBCBBA76F, 0xA45C4D50, 0xC718D5, 0x87CE05D1, 0x60D47AD5, + 0xA5CA9C40, 0xB0061766, 0xE69B39DF, 0xBD5F1320, 0x9930EAD3, + 0xA8B38325, 0x8DD090F, 0x6A6EEF37, 0x2DF16F66, 0xAB514C7E, + 0x31109C58, 0xFD48C7FC, 0x515341CA, 0x77AB8EA6, 0x41328DAF, + 0xBAF8D31E, 0xA4B31611, 0xED37F331, 0x7A832A22, 0xA22591C7, + 0x722D1F89, 0x3B19CF18, 0x261B8A4D, 0xC3F6F6DB, 0xCF8CED61, + 0x990FA250, 0xA02E72A9, 0x560DCEA2, 0xB08E67B4, 0x3674E663, + 0x97CC3852, 0xA7EB2EAC, 0xFFDE0AA8, 0xA64719A, 0x23269EDD, + 0x3C0B339E, 0x86284D40, 0x48D82ECB, 0xA4D4CCF8, 0x43631B91, + 0x4BF0C248, 0xB6497B9B, 0x6827BC58, 0xE30B7AF9, 0xA0CCBF26, + 0x6C3B7B71, 0xD744B3ED, 0xFA25D2F6, 0x4CDE642D, 0xD65B8142, + 0xA6F9207F, 0xE7A207BE, 0xDB506684, 0x44DA4780, 0x9175EA0C, + 0x156104AF, 0x4155E1B0, 0x6E3A6886, 0x9DBA1EA2, 0x5423D9C8, + 0xCC024E22, 0x758F852A, 0x1DD6395, 0x2D19CBAD, 0xE164F5A1, + 0xC2084602, 0x89C274AD, 0x13CB5562, 0xD7FE2D5B, 0xE07A4EE5, + 0x1672BA91, 0x4F624CCF, 0x2E5EA4A3, 0x28FEEFAF, 0xBDDA6EF4, + 0x32AFD40C, 0x99A5FB3B, 0xDD1D73A3, 0xA342CB3E, 0xA78445F5, + 0x53979C3B, 0x427D7943, 0x5221B58C, 0xA6CE9A5E, 0xFB50ECA4, + 0xBB86E36E, 0x60839F6D, 0xC5E1C2F3, 0xA1B7FB04, 0xFBB65E0C, + 0x78B80F5E, 0xFD8D972B, 0x3BF3BA90, 0x2D572D9, 0x2B5BC920, + 0xB6A0DE01, 0xD274D306, 0xC7C6C855, 0x9CAA669B, 0xB04AA641, + 0x4D6B1760, 0x3E17ED79, 0xD23241B0, 0xA4A6F957, 0xCBDE76AF, + 0x4E5F9493, 0x4C215DA5, 0x33A052B, 0x1A4D80C2, 0x40AEEBCA, + 0x390D106B, 0xE9E8E018, 0x5AF3D6CF, 0xE35E1D4, 0xC4FB1C6, + 0x14B6299B, 0x8D2E25F0, 0xCCBF932A, 0xC5AC18B6, 0x2227567D, + 0x86B5CE2F, 0x26344534, 0x22C515EC, 0x2442B70D, 0xEC3721C6, + 0x34EF687D, 0x9C06323A, 0xEAF3EA60, 0x60396F52, 0xEAE78AA1, + 0xC9D06CBC, 0x6F95F6C8, 0x584CC258, 0xBA9A27BB, 0x66DF8D47, + 0x9D4804EA, 0x57DD9E67, 0xF89C7895, 0xF5336111, 0x25C122C8, + 0x62742114, 0xCFBF6D26, 0xBF9F6482, 0xE6F02CD9, 0x11083202, + 0xC99E2618, 0x7EBC9351, 0x440112F1, 0xC9DFFBC1, 0x3BF4DC25, + 0xB1BA7FA0, 0x61AF9AED, 0x6B1F7D29, 0xAD865294, 0xE3E01129, + 0x7E9E77A5, 0x100435D7, 0x9FE3A71, 0x88597C81, 0x722849FA, + 0x31C5A0AF, 0xFBA178DC, 0x7F102D31, 0x5CA07864, 0x950E6F98, + 0x82C34882, 0x5D041F11, 0x8C613C57, 0xD398CFD1, 0x426F38AD, + 0x5599AB1D, 0xFAFA078D, 0xAB25B413, 0xD94B32CF, 0xB288FE38, + 0x2893BB46, 0x9A0B4168, 0xA91BCA94, 0x653A5E8D, 0x2174EBBE, + 0xDEFE6415, 0x30DA429C, 0xD0C5E40C, 0xB4719AA4, 0xD29CE7A6, + 0x905957CD, 0xCD287499, 0x83CA0AA7, 0xA8385832, 0x25A0CA02, + 0xC20D47A4, 0xB562F556, 0x4BC19E4C, 0xD9E215C7, 0x27E838B4, + 0xC58612F4, 0xA2827F6F, 0xC49DCDBA, 0x679B7362, 0x4E495845, + 0xCFD2F0D1, 0x395E76A0, 0x375A655E, 0x92E2058F, 0x73F9F0CA, + 0x61EFF3B3, 0x51FFD362, 0xE7410345, 0x7FDA8B3B, 0xA219E2E8, + 0x17ABE543, 0x26557412, 0x4B30084D, 0xA68E191D, 0xFE0D93DF, + 0x73EF127D, 0x4DECDDB1, 0x77FAF45F, 0xD6002898, 0x92DD0A40, + 0x157F6DDF, 0xC2A55F8E, 0x4359F924, 0xFB630C3F, 0x338B6B58, + 0xB2945F75, 0x4FA23A0E, 0x836EB8C0, 0xB3B18FD, 0x86114337, + 0x24668ACB, 0x99BB82F0, 0x924C8A47, 0xBA959701, 0x81155ABF, + 0x8C612D71, 0x36074CA7, 0xD1668C41, 0xE35F58C7, 0x7FC2802D, + 0x8E6A7CF3, 0x65B07D07, 0x815F6A6B, 0x791BF0DD, 0x6E47D719, + 0xC24394C7, 0xE84A6EB, 0xF194AFEE, 0x464A2F52, 0x677579FD, + 0xEBA775AE, 0x1F6EEFF, 0x9A795237, 0x78D9D45F, 0x9D0B344D, + 0xBBD34AB7, 0x2F85B12A, 0x16C5C2AD, 0x3990985D, 0x88DF3351, + 0x82811AA5, 0x6D351F41, 0x4066A69D, 0x86B660BF, 0x6EDB4768, + 0xDDD78CF0, 0xB5D74F6E, 0xE89E220C, 0x91439687, 0x947CC9C9, + 0x3857E2BD, 0x302F8AE4, 0x1DABE7F8, 0x4832D6C9, 0x37D58FCB, + 0x4EA8A711, 0xCD7BAC98, 0x19DBF8BC, 0xD8DE8DC2, 0xEAFF7E7B, + 0xB7629C93, 0x792C6E19, 0xF7009192, 0xFF88439D, 0x2E196A66, + 0xEC71B78C, 0xEAF4BB3A, 0x7C16225E, 0x668F337, 0xCBEE1608, + 0x6D5B5552, 0x345DC590, 0x681209CC, 0x7B24A819, 0xD08A1416, + 0x99888FE3, 0x9FC7288A, 0x24BD8502, 0xEA1D9678, 0x20EECA0, + 0x59BEA057, 0x5ADE91EB, 0xDEA8E49D, 0xFA200E6F, 0x9149C81D, + 0xF2281E93, 0x8A5B0451, 0x67312D58, 0xE3B849F1, 0xD2217960, + 0x7CDF59F3, 0x33C775C0, 0x9EBA8799, 0x7DF9506, 0xB4E96110, + 0xB8FCF3E3, 0xDEA059B2, 0x8229B6EA, 0x316486F6, 0x43919185, + 0x6C0D90F3, 0x1C6F3DF8, 0x38DB92A9, 0x5CD41244, 0x2C9F0A7B, + 0xDF4A315F, 0xF7CE9C66, 0x4C800860, 0x318D53E0, 0xF105C20D, + 0xD753E1F2, 0x750810BA, 0xA17ECCA5, 0x2010140, 0x4D884763, + 0xC2BB0DA7, 0xB2D5BA74, 0x141CECD4, 0x887FDFC3, 0xC64B53, + 0x2D2A85F6, 0x15532B45, 0x5D5CBCE1, 0xBEB9A16A, 0xA214611B, + 0x9FC5AC5F, 0x11AE5DD7, 0xA0B9A5A9, 0xFC648AF4, 0x740009AC, + 0xED0E0321, 0xB8E6A61, 0x8910C544, 0xC74F26C8, 0x9525CCF3, + 0xB41AEB59, 0xE61984CE, 0x598B2197, 0xA412E59D, 0xE1976DD4, + 0xB29BBE16, 0x88FD9FB0, 0xB04006F3, 0xB45E309, 0xD5CC15F1, + 0xD9DAF630, 0xDC809335, 0x803ED52, 0xB537F5A5, 0xA994F6EB, + 0xF5288568, 0xF66FD264, 0x2EA2B3A6, 0x647619F3, 0xFFB38C7A, + 0x1BC03B9, 0xB6BC3061, 0xBF30596E, 0xBE2AD27B, 0x8AC04220, + 0x641979A3, 0x9ECCBB89, 0xA144FBC1, 0x4E8FAE26, 0x8C5A9D90, + 0x299ED467, 0xD7C9C7E3, 0x1D4865ED, 0x76F31C3D, 0xCEE81CDF, + 0xB479195E, 0x6FFB3AE1, 0xDC8A398, 0x300F7364, 0xC7940AFA, + 0x3B85BE3E, 0xD98CC40D, 0xA24A3D89, 0x3A674204, 0x22888A38, + 0x2E77F2D, 0xA2841C9C, 0xCF0689C3, 0x9FE98922, 0x89335017, + 0x2D6B69A7, 0xFEDB63F9, 0x899AF4EF, 0x9F9F9B40, 0xA4BE97E8, + 0xA51DAF7A, 0x16AC50D3, 0xA8D7ED6, 0xED193443, 0x7615EF1B, + 0xB0DF6A4E, 0x64FFE794, 0xE3DB2C9A, 0x7435B022, 0x556E825C, + 0x23802AF9, 0xC25098A4, 0xE75A18BB, 0x70B2A7B9, 0x7FB81BF, + 0x63EF910, 0x6C669591, 0x6574DD2B, 0xCF6E379D, 0xD2B3AFAC, + 0x1E6A1101, 0x1DE22385, 0x2338191F, 0xC69704B6, 0xCBABC599, + 0x54EB4809, 0x7839BE6D, 0xD50017DD, 0x39B1A0E1, 0x288D52D3, + 0x2D52668C, 0x20D22A68, 0x4E1207D1, 0x3FCC0EFE, 0x47F3FE64, + 0x25177A90, 0xB4BFDD4D, 0xDA8DBDCE, 0x6F7275A8, 0x6BEAA655, + 0xAA1810FC, 0xE4DB593A, 0x8A4D4BC0, 0x2C402E93, 0xF1C0F7F9, + 0x6F0CC577, 0x70412414, 0x752F9DC1, 0xD82E38EA, 0xAC455F7B, + 0x4DCD4EDB, 0x92BC2696, 0xFB03F135, 0x4FCA1F8C, 0xBD5E75F6, + 0x502F41B0, 0x3616D3F1, 0x2E5B8E31, 0x2026EB19, 0x57E783D7, + 0x467BBE00, 0x4703ABA3, 0x1F776B9C, 0xE2570A84, 0xFEC7DB48, + 0x1BD5012, 0xFD0A2D5D, 0x7FCC29F2, 0x291304B6, 0x99D5D8ED, + 0xC7551C8, 0xFD12F38F, 0xBADE8892, 0xDF749997, 0xA5DAE2F, + 0x2B9FA269, 0x5C13CFED, 0x15E9A399, 0x54437F4E, 0xA72DB2AB, + 0x56186AA1, 0xFE4DB55C, 0xA34D7836, 0x2A879760, 0xC63FA94, + 0xAC18B207, 0x5FC78B3, 0x7F10621E, 0xA769E6B2, 0xEC9F4A11, + 0xCE3F982C, 0x62BA2EF5, 0xA5F239CD, 0x73D63FED, 0xE36E9F5E, + 0x8AC1DA0E, 0x3F3DB3EB, 0x738326EA, 0x35C366B1, 0xCD476E86, + 0x82F6B208, 0xF11A9FC1, 0x426AC396, 0x7E4D1B93, 0x75E4EDB7, + 0xAF3C44A7, 0x51A5EF5C, 0xFAD2463D, 0x8A5639CA, 0xC995AC78, + 0xCC4BE4F6, 0x3AFE7F8D, 0x66993D04, 0x4386FF37, 0xCBC1C6C2, + 0x55A8F5EC, 0xE81A9A75, 0x30A67E1B, 0x4A4A7D0C, 0x20F7F993, + 0x1891805, 0x738976AD, 0xD426E7D6, 0x3C5CEEBF, 0x4499187F, + 0xABF17C97, 0x447C317F, 0x68D8419C, 0x7AAB6456, 0x421BCF29, + 0xF6740F9C, 0x8916BB8D, 0x3D72AAB, 0x9AD54DD7, 0x7549C6EE, + 0x7317342B, 0xA18546D4, 0x1056BDA7, 0x54BBCCCE, 0x8CE63E46, + 0x5D146234, 0x33BE6C63, 0xB250C4E5, 0x89D72335, 0x87C36BA, + 0xB65530CC, 0x2DFAC48C, 0x1663D16F, 0x59B80AA, 0x950274EA, + 0x92532D4A, 0x3CEF802D, 0x492FBDA5, 0xA63A2574, 0xEF8005C2, + 0x94A18651, 0xAF627ABA, 0x6829B238, 0xA698F646, 0xD2598516, + 0x10144D36, 0xD9B1D1B9, 0xAB2ACF05, 0x5395B699, 0xA7851C75, + 0x1806C6F3, 0xAE970306, 0x3284B145, 0x98F4FE8F, 0xECDD35CC, + 0xDDC1EE0E, 0xC4848865, 0x925826BD, 0x4078BE39, 0x68A8561A, + 0x323045DC, 0xA933B37F, 0xBA2AEE2E, 0x4F24F65D, 0x349EE246, + 0xF97B9D0E, 0x46DC5759, 0x4529F425, 0x80D17B42, 0x8E16F709, + 0x1B42206A, 0x4934A526, 0x391BB6DE, 0xB52EF45C, 0x26C30290, + 0xCBA23CAA, 0xA501A8C3, 0xD922C4F8, 0xE8824E53, 0x6F4255DC, + 0x5960B544, 0x58BC69D6, 0xCA936323, 0xFDDF053C, 0xC2E002D6, + 0x7D750755, 0x8A3F9CD1, 0x35F8F6F8, 0xFB7BD154, 0x65CFF94F, + 0x390A58DD, 0xD97C4093, 0x501CA2A3, 0x8EA5DEBC, 0xCA93461F, + 0xE02D984C, 0x126F8517, 0x39FDD887, 0x46241AE9, 0x777E854D, + 0xE2B36349, 0x58E3FA9F, 0x971DEF1E, 0x8E156228, 0xC0E14E9, + 0xA9A01BE6, 0xB318C990, 0x971680D6, 0xA1F359CE, 0x487E23F4, + 0x7DE465B0, 0x4E4C905E, 0x2A652959, 0x116FF167, 0x5C74AAB9, + 0x4FEFC920, 0x28DF4EB8, 0x29EBF45A, 0x1E350CF6, 0x7134F224, + 0x22CCF1B6, 0x3890ACCD, 0x9BC304F0, 0x7A37B14E, 0xF3724F9C, + 0xDAC493BE, 0x504692EB, 0x82A56D75, 0x42BC73F0, 0xADA92177, + 0x2D9D9FD2, 0x41D874F, 0xEFCFD8FE, 0x8E83A5A2, 0xB84AF0DA, + 0x65F9B035, 0x6DF4EEE0, 0x7D403714, 0x1CCB8B3A, 0x25B30F14, + 0x5384B044, 0xD21FB429, 0x2C407A2, 0x88622917, 0x92D49C25, + 0x845AA406, 0x532D7675, 0xC0B7713D, 0x30E6933B, 0xD270DE3B, + 0x78771A87, 0x1949A28, 0xAEC00040, 0x10A092F4, 0xBD9D5066, + 0xDE166CB7, 0xE8ECE4D3, 0x867417C9, 0xCF0657E4, 0xD7D550F7, + 0xCD472B6D, 0x8CD0F002, 0xD7D47B7C, 0xA2E5475F, 0x2B66B40, + 0x397A7C9F, 0x6C4BC024, 0x9FDA402, 0xD981917E, 0xA3A6C8E, + 0xC9A42042, 0xCF0D1D5B, 0x1A96C11B, 0x9271030B, 0x4BD5D13C, + 0xCDA08C03, 0x1E4B3256, 0xDBB263E, 0x94B1E758, 0x5CF0232F, + 0xC76F252E, 0x27FF7F55, 0xA55DC287, 0x72886B75, 0x38AA73C2, + 0xA5759CFB, 0xF0A75C8C, 0x7059CBE3, 0x6519FBE2, 0x8C3B4162, + 0x5A19A4DE, 0x9D93E753, 0xA9EDF8B5, 0xD68126CD, 0xEA6A7399, + 0xA73005B4, 0x45BC5168, 0xABD166BA, 0x4D0CC0DF, 0xE1376FF9, + 0x393FB309, 0xE995744E, 0xD5EF71BE, 0x66C2BF35, 0x88D62A85, + 0x14121E08, 0x7006CE98, 0x7F0A7076, 0x7DB9C751, 0xDC7056CD, + 0xC1517CD, 0x65BCE88, 0x1B0F1E71, 0x54C2DA11, 0x101BFDD8, + 0x28096AAD, 0xC365859F, 0xACE13396, 0x7CB432BC, 0xB19EA011, + 0xAD9BC7D2, 0x3AF387B1, 0xCCE30470, 0x5335FC46, 0x40D13C16, + 0xD548B4CC, 0xC476A7BD, 0x66BC0663, 0xB7C6960F, 0x12D1E821, + 0x9A536C48, 0x42641630, 0x740C9A48, 0xF61664E8, 0x3B11E69A, + 0xBD79E1F1, 0x3F930B7D, 0xD98B085D, 0x2151962F, 0xD4D7F80E, + 0x88975123, 0x5302989, 0x12F5CA2B, 0x37C29573, 0xD1D2A3A6, + 0x46DA55DA, 0x2EC8C098, 0x802A42DF, 0xD07A11E5, 0xD5BF4B16, + 0x171BCB96, 0xB5843001, 0x57BDCAA7, 0xDDD36F33, 0x633D0AA0, + 0x313B7064, 0x68BD30CE, 0xC986B6C3, 0x2271824F, 0x9951E552, + 0x15939472, 0xDC668F83, 0x1D98A441, 0xA4A1676, 0x631C444B, + 0x6EB61C7C, 0x8EEE0B5E, 0x23F82C1F, 0x6C4B53C1, 0x41116D6, + 0xEBC1627A, 0xC8839049, 0x7F07A8F6, 0xD1F74661, 0x7D9892DD, + 0xF010EC90, 0x37C8A4F4, 0x6ABA986E, 0x68B1E4F6, 0x8066EE05, + 0x5E964158, 0x88D477A6, 0x776CF1E1, 0xB7AB3B60, 0x183D58C0, + 0xA7E13F2F, 0xDD435AD0, 0xF37DF46E, 0xD3F3F774, 0xB6B24A9A, + 0xC097D9F2, 0x54EE718C, 0x4469BDB, 0x4F20DAC, 0xB4002AD5, + 0x2E7AB56, 0xCDB4B18C, 0xF2ACE62D, 0x54BD40DE, 0x46DCCA2, + 0x5B7F32F9, 0xA8CB257D, 0xB138C149, 0x71474D19, 0x6F71C293, + 0xD88FBC7D, 0x9E0A7F86, 0x14B92605, 0x1CBACDC, 0x29159263, + 0xBB719E18, 0xD41B37EE, 0xA236E27E, 0xE916BAE3, 0xED34D9DA, + 0xFDDE09B6, 0x4FE72C56, 0x16927460, 0x8CFFF9A, 0xA9465741, + 0x2B1CD6E0, 0x6BA277FD, 0xE06F70EC, 0x7CB2715, 0xFEDC13C8, + 0x7049632E, 0xC6448831, 0xF72CA3A, 0x9B2BE231, 0xC16A8438, + 0x948EB7E, 0x64041803, 0x82A43295, 0x226D95CE, 0x84AFC1EE, + 0xB2EF3B82, 0xAC18A45C, 0x74DE3ADE, 0xD0E6FAD4, 0xE10C242E, + 0x797DF7BA, 0x812CD7B8, 0xED45B681, 0x8F6CCDE8, 0xC2376DFF, + 0xCABE35D6, 0xD450395B, 0x13493CE3, 0x870E1BF5, 0x7B0BF341, + 0xEBD572F2, 0xAE22B3F1, 0x7ED22DF8, 0xEFE826ED, 0xF147F4BD, + 0xA12DA6F2, 0xF3871967, 0xE4423B70, 0x298472D9, 0x45E03E3D, + 0x2BE705AC, 0x41E3AE6C, 0xA29DF92C, 0x54B33739, 0x8EA8F7A9, + 0xDEFF7BC9, 0x77D06961, 0x71981BA1, 0xBA5A5647, 0x4A8E0E2E, + 0x9F519F5D, 0x31BBA940, 0x3D3A0532, 0x7090F0AD, 0x8B47D658, + 0x8D198BAF, 0x9ED929B6, 0x323BB81, 0x97210404, 0x7B8790DA, + 0xD8438C25, 0xDFBB1C93, 0x2C3F415B, 0x14738C42, 0xB46C2C7A, + 0xA3627CAB, 0xFC540D08, 0xE8227979, 0x672B87FE, 0xB257C949, + 0x9C2B31FF, 0x97AAACA8, 0xC662B448, 0x5BFEFC7C, 0xC2FDEDDE, + 0xAD306CED, 0x639A2576, 0x9ECC1378, 0xA72D71B3, 0x94E11CDB, + 0x8BF14832, 0x945C1728, 0x49AE595B, 0x526DD500, 0x40A7D344, + 0x8EB1DA34, 0x731E17C5, 0xA7CF41A4, 0xCB068104, 0xC842B8E, + 0x7F5733E1, 0xAC9CB3B, 0x2E3F58C0, 0xFD8BC4F, 0xFFBCBBAA, + 0x620248F9, 0x27AC344D, 0xF2E5958B, 0x773EBC3A, 0xEA6078F7, + 0x6B32D1D7, 0xC00DF984, 0xE73C86AA, 0x712026DB, 0x2CE271FF, + 0x38578573, 0x816605D0, 0x673509A9, 0x8D693AC8, 0x2533C371, + 0x6783E269, 0xC5731F9, 0xF2A8041E, 0xBB3C008F, 0x2B290D9A, + 0x122A4BA4, 0x645A69B, 0xB86CC256, 0x9369B8C3, 0x90CF4CEB, + 0x573005D0, 0x4F7DB793, 0xD6AC972E, 0x178BFB66, 0xC430DCEE, + 0xD1A8138B, 0xBF6EC4C8, 0x693E6FAF, 0x54119B44, 0x9C904669, + 0x4D95F608, 0xDB59E550, 0xD85DDBBC, 0xD15818AE, 0x680778D8, + 0x3B67A234, 0xEBE9DAF3, 0xEB8E049B, 0xDD9E0EB8, 0x5D4FB1FB, + 0xCEA62C1C, 0x948AF719, 0xA7E58E36, 0x800EAD97, 0xCD895A65, + 0x72E63F92, 0xA9A82DD3, 0x8CC07793, 0xE70EBE82, 0x1F69534, + 0xAB727A31, 0x1582EF9, 0x7247F677, 0x5FFD7E2C, 0x950EA9DF, + 0xFF38A172, 0xDD75DB84, 0x3A416207, 0xD6A23DA7, 0x3BBE70D0, + 0x538C25CA, 0x2958DF9, 0xD7B9C83E, 0x61F35964, 0x1E05B36, + 0xDD57CDCF, 0x997335B, 0x3A65762A, 0xC5836CD0, 0x9EF2B7F1, + 0x5094196, 0x6949A654, 0xB7FD3E5D, 0x6070C271, 0x30364C38, + 0xDCAFFFA5, 0xCD4ED281, 0x9865FE7C, 0x75F665AD, 0x6ABADB10, + 0xAB43129, 0x26B7A5B8, 0xA321DDBD, 0x467AD732, 0x153A1AE, + 0xAD6B1842, 0xBE19B6BE, 0xC1E22C82, 0x73372EA5, 0xF9EF4AD7, + 0x24C81977, 0xD8451807, 0xCD10ADC8, 0x8FBD95E2, 0xE0789969, + 0xC77A80F2, 0xF1165BCE, 0x3488C653, 0x16F3E378, 0x8D71B29A, + 0x628EC98A, 0x40963234, 0xF918E028, 0x9A584D33, 0xC174E2FE, + 0x417C5145, 0x1C751175, 0xB21E0C12, 0x30218ECC, 0x9D7731BD, + 0xA07DBA0F, 0xE7504D39, 0x3E37F16B, 0xD3BAB050, 0x6F3DE64, + 0x1998A7BA, 0xA61A6D07, 0x424FBED7, 0xCD6B3236, 0x68E71248, + 0x58CC3DFB, 0x584FA4F5, 0xFFE8E2BD, 0x9F0E3D75, 0x788DD779, + 0x978ED891, 0x7E1BFFC8, 0xB812A1C9, 0x5CCC1A32, 0xF1A47219, + 0xD6BA6E71, 0xAFA86EB5, 0x28D128E2, 0x9EDD53B, 0x9AAB7E9C, + 0x493B76F2, 0x31C5C89, 0xCE5FC3B6, 0x974CC3F5, 0xCBBD90FB, + 0x61DE988E, 0x99B927CB, 0x972EFCCD, 0x2719AD6, 0xE06E4B29, + 0x48215B1, 0x37EDE8E4, 0xABF9F87F, 0x8BC1C626, 0x5B19EC05, + 0x212A2AE1, 0x28446975, 0x20D04126, 0xFC453267, 0x967D9524, + 0xDF1CDF8, 0xFB17DCA3, 0x11E68AC6, 0x3AD7D667, 0xD133EF43, + 0x5EC41DA3, 0x587AA639, 0x17ADAE3, 0x816DF77A, 0x37D0726A, + 0x49DC33D9, 0x6C9737E, 0xA6A2F950, 0xEC5F352C, 0x50D1E06D, + 0xC10009A6, 0x2F70F8BE, 0x382269B1, 0x4C29E7CB, 0xBD474FF3, + 0xD19A4F6, 0xC3CCE458, 0xE09B348, 0xD15A0DC5, 0x1C10D20E, + 0x4AFDED15, 0x3C109DC1, 0xD8C117F5, 0xB501DDF5, 0x39C92B5F, + 0xE76FCA13, 0x76DBAA1B, 0xB0730EBF, 0x67DD1FBC, 0xD8B87AB6, + 0xA826225B, 0xAB2F7089, 0x499FA36D, 0xF26455B, 0xDC79F8EF, + 0x987E765E, 0xA13E60C7, 0x500C7803, 0x492C871D, 0x970DE4EE, + 0xD1423DC1, 0xB66048A3, 0x804895AB, 0xC079A15F, 0x5E6FD682, + 0xE936476E, 0x8DECE38F, 0x76A011D, 0x53575B91, 0xB263D36A, + 0x8F2624C1, 0x26B34937, 0x75A7EC2F, 0xE33ED24, 0xBF1BE7C7, + 0x8D6BA785, 0x1D9FE802, 0xB8F4EC20, 0xD5C714B2, 0xC1326D06, + 0xFCA78B3F, 0xC0065015, 0xA4B9F286, 0x53F92A8B, 0xF4B02DBB, + 0xEC47E64C, 0xA29FFB12, 0xBA94FFB2, 0xB6980EB2, 0x7415C83F, + 0x93F91A24, 0x4C6F7615, 0x34431174, 0xC7D63B4, 0xB1599158, + 0xA3A01FCE, 0xBD477764, 0x6B16EC41, 0x772D8BF5, 0x90F0A785, + 0x8F72672C, 0x7AD22CDC, 0x70824998, 0x1BED16D5, 0x596E84FF, + 0x48B5B4F4, 0xB20D0B81, 0xF00F7AFF, 0x80F618DA, 0xD10AFE11, + 0xA8EA3109, 0x91BA5E43, 0x31345A01, 0xEB0EF0F8, 0xCC6E7FB5, + 0x3348AE52, 0xEBB124D9, 0x447E58B1, 0xF2A3D592, 0x7F3EE5D8, + 0xD3D7B836, 0x9C98DCD4, 0x27F0B7A0, 0xA9655FD9, 0xAB48E5F8, + 0x7F996D8E, 0xAC13B08B, 0x2530AC6D, 0xAA542552, 0xD4E6B42A, + 0x6432AA64, 0xEAC84F76, 0x41D5F959, 0xCDE91DDF, 0xA0AA485A, + 0x6453698, 0x277C18A4, 0x161A497, 0x66FECAE2, 0x1B64683, + 0x948DD228, 0x1F3C5950, 0xFFC271FB, 0x15C4DF12, 0x7C78252B, + 0x9D4EBB89, 0xE6FA1D49, 0x6B032100, 0xB65DD3CC, 0x106BC9B5, + 0xE0223D45, 0xF7779B03, 0x4B0EA0C2, 0x3CB5AAF2, 0x9A458E5F, + 0x524090ED, 0x3BB1F18F, 0xB4DD065E, 0xA8F13E4F, 0xC4949ABB, + 0xD8142D31, 0x99069DE6, 0x989D2A16, 0xC72D929, 0xA2AC5754, + 0x7E29B714, 0x6E25C15F, 0xE8777078, 0x467DDCEA, 0xF94B2ACB, + 0xDF429476, 0x69AE316, 0x363C664D, 0x85D6AA1E, 0xD727E39E, + 0x5AF440A3, 0x2F0BB16D, 0x461D52D, 0x610559B6, 0xC28066D9, + 0x3C13AE61, 0xA965B865, 0x2BCE3D4A, 0x361C4848, 0x46B94657, + 0xF2AE634D, 0xD7FD4B8B, 0x70C175D8, 0x33128DF, 0xB9718A3B, + 0x8EF80C0F, 0xAB12E738, 0x124B8055, 0x43448325, 0x9F05E427, + 0xA0A9F843, 0x57A9A3FA, 0x492EEA32, 0xE73D2B18, 0xF3113C2C, + 0x2BA9B42D, 0xFF0B320, 0x3A18CD71, 0x59804367, 0xC37F9B87, + 0xB8A990, 0xAFE9F267, 0x1892892B, 0x25B9C66D, 0x52D4056E, + 0xCC1508CA, 0xAD213DB2, 0x8B43F743, 0xAA9705AD, 0x9BC756A2, + 0x43F42526, 0x596FEE87, 0x2B8AFF32, 0x46DEDB48, 0xBF06317C, + 0x876D4CF2, 0x16951456, 0x2B051AFD, 0xFD093E9D, 0x2F113180, + 0x77BFC4C0, 0x29200C52, 0x182D384E, 0x54AE29E0, 0xF90961E8, + 0x6072B8F8, 0x3D346F4E, 0x9AA5DBA4, 0xE5E22EC6, 0x392170DA, + 0x40939B9B, 0x65B89151, 0xC54AB94, 0xAD7280BC, 0xA3D4395E, + 0x3B5754D2, 0x9E77A6A2, 0x9A737F56, 0x9B2D432D, 0x8FDDA7E7, + 0x5958516E, 0x7F52CD74, 0xC1761A50, 0x2B80C01F, 0x5AA99F54, + 0x36FAA395, 0x5DB4B3AD, 0x82024C73, 0x988CEFE0, 0xB44498C0, + 0xF9561A4, 0x280470E6, 0x6966F3A0, 0x47E374F4, 0xF00F4CFF, + 0xBC5C4DB2, 0xE287924F, 0x1ED57369, 0x484FE06D, 0xE92E6564, + 0x7429DAD2, 0x1473AF49, 0x9619E0CD, 0xE6EC2B63, 0xF7A983B5, + 0xEC43C28F, 0x4C98EBE7, 0xA61FDF89, 0xA867E5ED, 0x1088A7C, + 0xCF1CEAE8, 0x223AA207, 0x686F4F7B, 0xEBB013E1, 0xDDC01886, + 0x77478D4E, 0x2FFCEAEB, 0xFCA58846, 0x1208668E, 0x32F8252, + 0x65C9F3ED, 0xC7584B2F, 0xF3EB26B2, 0x90890270, 0x5D97ED04, + 0xF5B5B18A, 0xCF415DF9, 0x4CF4683F, 0xE2E3F29F, 0x850E4BEF, + 0xDBABF6E2, 0xBD183286, 0x2F36215C, 0xD8CA1DD3, 0x4309CC6F, + 0x9FA52446, 0xBD94348E, 0x8693D9B6, 0x61E880C2, 0xA1851D5E, + 0xAAB94F80, 0xF8919C00, 0x74D82ECA, 0x4466A1B6, 0xA0A98E8C, + 0x95B6D1D, 0xE5393A4C, 0x5A40CFFB, 0x67013370, 0x571B0FDA, + 0x9E7E805C, 0x15E32653, 0x2CFE7902, 0xA02E0906, 0xA8883783, + 0x7A68B719, 0x3402833A, 0x68BFD324, 0xE0B43DA3, 0xF9DB0F, + 0xC9510610, 0x690D30B, 0xE79AB417, 0xC917E4C0, 0x7B05CE55, + 0xE116EFDB, 0x69E3B158, 0xF91ED58D, 0x1832D16A, 0x91F4EA17, + 0x3D24C408, 0x76A2C6D0, 0x99B19825, 0x2BF52475, 0xAD49289D, + 0x66238CD7, 0xAC1571F5, 0xA2EABC02, 0x889337AE, 0x3219AFFB, + 0x104B8779, 0x810488A8, 0xAC35416A, 0x2C6DEF85, 0x2ED109F5, + 0xCC8C6732, 0x97CD8E90, 0x339F3E81, 0x91486206, 0x2708D41D, + 0x1F2B19A7, 0x51A60303, 0x5E90E440, 0xB63092C8, 0xF1031823, + 0x971A06, 0xB624F6A2, 0x58AC0181, 0xA983D599, 0xA776D877, + 0xB727FE1, 0x55AC01B1, 0x4298EA17, 0x4D6BB9AA, 0x31C55C65, + 0x6A266780, 0x4FD92256, 0x817DB37A, 0x46A14DF1, 0xEC7D9F14, + 0x98D1C1B7, 0x911DF80D, 0xBFBF24E1, 0x9B4DBC6A, 0xE1F71BA4, + 0x9EE5E44A, 0xD1868C4C, 0x6FB45D76, 0x11EC8672, 0x1CED7F0C, + 0x1524A040, 0xA49DE9D3, 0x99FF328A, 0xC392F619, 0x52A856CC, + 0xDB0B0AE6, 0x67F0162E, 0x2C20D410, 0x4E23C4D, 0x828032EA, + 0xC2E7DFFA, 0x908CF524, 0x919F61EE, 0xF001C6F, 0xA81DDF65, + 0x5EC56647, 0x28385ACF, 0xBDD764C0, 0x75C853AB, 0xDF0ADD73, + 0xEEA9C63D, 0x804949F5, 0x658ACD0A, 0xD12F3F50, 0x1FD4F7EE, + 0x7F023D80, 0xD2CB08B5, 0x477EA9A1, 0x872DB719, 0x7B8B6AE9, + 0x84F6AC4, 0x81634EB4, 0xD1A89CF, 0xB3F4F3B9, 0x3A6B024B, + 0xAA2CA2C5, 0x9C902C0C, 0xC40E4135, 0x3C6E612F, 0x11219414, + 0x1F184277, 0x11B6B30C, 0xDD8A6A5A, 0xA0D21C9D, 0x55377022, + 0xD0708FBD, 0x8D761020, 0x54FCFCFC, 0x477801BD, 0xD6919EB8, + 0x9AD29078, 0x36F8D9B8, 0xAE525B8C, 0xCA7ED140, 0x2D8F8B97, + 0xD1B79EAA, 0x2E26FB2A, 0xFB396E32, 0x399129A3, 0x28B55FA1, + 0x2ECB2CF0, 0xDF1CBF7C, 0xDE57A70D, 0x33410B33, 0x7C5759BF, + 0xF534264B, 0x16C8C221, 0x874A3A63, 0xD05808ED, 0x679674BC, + 0x24B060C9, 0x4B162B53, 0xC7D01208, 0xE753DE61, 0xFA9840E4, + 0xA4FEC439, 0x4143E13F, 0x327E9EE8, 0x319D901E, 0xC40FC209, + 0xB1E1FFFC, 0xE737D52B, 0xD074E058, 0xAD8892EE, 0x86B93396, + 0x49C13F4B, 0x60A5721C, 0xD4C4F599, 0x14B38EBB, 0x86BA655, + 0x95F4E0C, 0x4217E99A, 0xD0CA3861, 0xBDD3617B, 0xB0BDBF4D, + 0x99E3389A, 0x8200DCFA, 0xEC22C8AC, 0xBA8DDB32, 0x3F7DDFC8, + 0xC7DDC171, 0x211CF31, 0xCC31A0C7, 0x99A84F32, 0xC9FFD317, + 0x2267733A, 0xFBD05569, 0x306BC05F, 0x6E2685D5, 0x43FBF7D1, + 0x5A2DB2D3, 0xE6491D4B, 0xAD078066, 0x7CAF7AAD, 0x2B1FEBA5, + 0x3418A0EC, 0xC359E9B7, 0xB024E024, 0x58F22A6B, 0x18EEE710, + 0x4755B9C5, 0x528D3273, 0xC8F9255, 0x635E5F9D, 0xABDF5BAD, + 0x8410F054, 0xEA068528, 0x438345EB, 0x56EF340, 0xBD86A7DE, + 0x543A126A, 0x5F259D83, 0x67EDA87A, 0xFF24F98E, 0x684E6504, + 0xE4EB57B, 0xD2D3B758, 0x4474D10F, 0xA94594B7, 0x3E4BEB07, + 0x95C3F257, 0x478B6FA8, 0xBCC7EFD8, 0x1023D258, 0xB4ACD6C0, + 0x36129B10, 0x16D7D9A3, 0xEA63BE7E, 0x25EC12A1, 0x21B95589, + 0x3A673799, 0xB8E04594, 0xAE98693C, 0x9879B8F9, 0x601A3F62, + 0xCF9897C0, 0x87CD1798, 0x629788F1, 0xC1337B31, 0x59D84E67, + 0xF13FA484, 0x5E8C7B3F, 0x7DEDE9F6, 0x9779F496, 0x74C4EE89, + 0xB3D9AC8F, 0x44118EFC, 0xB4FE8E45, 0xC9934560, 0x93D739E8, + 0xCD013773, 0x102411F1, 0x9DB63EFB, 0x63165875, 0xB8B97E98, + 0x6B4223D0, 0x6F34352B, 0xDB038A46, 0xC187163E, 0x17FE20D8, + 0x82A1BC9F, 0xB6860AAF, 0x11D5F9E0, 0x5371E14E, 0x20BC8445, + 0x607589A0, 0x8DDCCF44, 0xCDCD53C2, 0xCBCB32D8, 0xC512E661, + 0x1EB4E6CE, 0x228E99A0, 0x28EE0177, 0x76ED3F3D, 0xA3DA3300, + 0x17C57F91, 0xA1855C6, 0x3531FA3, 0xA93A8241, 0xC45D540C, + 0x365D42EF, 0x2CA39696, 0xE460F7D1, 0xCA32CCB3, 0xA6D9D934, + 0xAD01079C, 0x9B07D89C, 0x226CE0A5, 0x60D67762, 0xD35A4B7B, + 0xFF0A698F, 0xDB73BF89, 0xF41FBA9A, 0xCACDF26D, 0xBF594213, + 0xCD4D3E90, 0xD12F3EB8, 0xE689D238, 0x8CD4C0CA, 0xEB3E841E, + 0xA513EF0F, 0x2DF4B65D, 0x90161625, 0x9C02AC36, 0x208F328D, + 0x12BF5D93, 0x7C8C355C, 0x3CDFCA22, 0x29381080, 0x3FF6CA14, + 0x9F269C74, 0x8A48070B, 0x3BDF51BD, 0x85932156, 0xA7B6F9FF, + 0x80554507, 0x43820D97, 0x59B7214A, 0xFC3ECC27, 0xED39DB19, + 0x2B9BDB43, 0xABD4E298, 0xC2C5953E, 0xD3DB0C09, 0x66EC81DA, + 0x7F41EDE1, 0x5146E8D7, 0x49171DF2, 0xB334BF9A, 0x3AADC9E6, + 0x56E12468, 0xA2D4B032, 0x662B1F49, 0x9C448B1F, 0xA219526C, + 0x56D66A27, 0x41609345, 0x8E685EFA, 0x392DA3A4, 0xDE58C26B, + 0x9C779FC9, 0xCA834F65, 0xA1E34DC4, 0xEC5BE6EA, 0x3737B7AB, + 0x2E9B7D0A, 0x929E96B9, 0xE38B0019, 0xC1E4115B, 0xD8141740, + 0x66977F67, 0x7D4CE4B3, 0x245AB554, 0x26F98B88, 0xEC78F24D, + 0xE1F34C1A, 0x5737AD34, 0xC1A19AC6, 0x3291E363, 0x4E824FF3, + 0xAC42BDF3, 0x7C2DACE8, 0x8D5C97F6, 0xD120875, 0xC4E5C39D, + 0xE22AE85D, 0x290FF39D, 0xD495E52A, 0x95414374, 0xD65757A6, + 0x1E7657F9, 0xF5073D56, 0xC2AA7589, 0xC166A0B3, 0xA0DF8CDE, + 0x4057EAE5, 0xBAC4DD2F, 0xB51F621F, 0xA96F90E3, 0x392B5D6F, + 0xC31E9CA1, 0xCCC02FD3, 0x5181074, 0x7BC15C18, 0xCA9232A4, + 0xD1D104E9, 0x5F0C5D3, 0x4947F6D2, 0x3C923E97, 0x6B486C35, + 0x9C8ADA96, 0x175C4D87, 0x39A1A0FE, 0x417F201B, 0xD080E114, + 0x4847B147, 0xFD634E49, 0xBC0BF4CA, 0xECABB1DF, 0x869B0263, + 0xCD797C28, 0xD2A4683, 0xD50F6A0B, 0x2CA40138, 0x8DA4EB55, + 0x5D198E5A, 0xA98DB40D, 0x96CA0E68, 0xA8D92294, 0xC4813E60, + 0x81CD6B09, 0xEBBEBF80, 0x6777688, 0xCDAF6EC5, 0xEB85653E, + 0x3BB780DD, 0x73718A21, 0x70E8A324, 0x654DE06A, 0x2CB2494A, + 0xFC1DA829, 0x64059A2F, 0x61CE9D0D, 0x5BC51CAB, 0xDF7DE6AE, + 0x1596B477, 0xB0F9EA86, 0x9D87D85B, 0x877620A7, 0x586F3AD6, + 0x96AE645E, 0x65E9D5D7, 0xDB69CEB, 0x2753EF35, 0xC226F633, + 0xBD373F9D, 0xF2A0E198, 0x4372EEC3, 0xA66F7010, 0xD30E1D18, + 0x152C0DFB, 0xEB86FC75, 0xC208FE7E, 0xB36625A4, 0xBBE2DE8, + 0xEC49F9C9, 0xCE724FFE, 0x2D509471, 0xCA6C24B6, 0x1BA93DDF, + 0xEABE9550, 0xB512D359, 0x83F76766, 0xC8267976, 0x7E50802B, + 0xE3EC2199, 0xD3269B8E, 0xC515B0CE, 0xB5752537, 0x70474BD, + 0x7F50EBE, 0xF9FC0B38, 0xD899D19C, 0x317AA41D, 0x6B706374, + 0x66479538, 0x560455A3, 0xD770DD85, 0x55BB61BD, 0x6DE6723A, + 0x3F89034B, 0x9C9650BC, 0xE569992C, 0x7B8F4D95, 0x3FB7C516, + 0x7C28C04B, 0xA12DE6B9, 0x8CFC5AFE, 0xA734A25A, 0xCF1483E8, + 0x1AB22339, 0xAA94F43F, 0x16319A1E, 0x2C9AA4D0, 0xE9D2618, + 0x790B699B, 0x3AD9C3A1, 0x55A778DA, 0x6517152F, 0x2139AB74, + 0x12F762CC, 0x4BE02E6F, 0xE69400F7, 0xDC48DCD0, 0x563DB028, + 0x32299125, 0x7C9145A9, 0xFB88067B, 0xF070F6FF, 0x3D9A42FF, + 0xC5D20DC, 0xF96F7EE1, 0xA9C209A3, 0x9A192F36, 0x3E158AD, + 0x1265DF79, 0x2E49E297, 0x99D3A002, 0xE6AFDDCB, 0x3B56751D, + 0xB248A31F, 0xE6BE0FFD, 0xBBAB635E, 0xB383C45C, 0xA9DC9F2D, + 0x735CE03F, 0x69992E32, 0xD1E6A77, 0xE38A7F46, 0xC1E59620, + 0xFAE7F99A, 0xBDFB440C, 0x9F53F99C, 0x224EA340, 0xAB5D1AF0, + 0x35F3126D, 0x99430549, 0x83E12C62, 0x6403957B, 0x7B119103, + 0xC8382BAB, 0x99A85991, 0x9BF370AF, 0xDFA83CAF, 0xDBEC2CC3, + 0x416D8EBA, 0x774E58FF, 0x29C222F, 0x3DE60561, 0xDF038931, + 0x8297C377, 0x9867C08, 0x58ADEAED, 0xD88F0856, 0x6E4C2A39, + 0x2599DF28, 0xD7A6D06A, 0x433B35BE, 0xDAD3175B, 0xC358D423, + 0x84BF4580, 0xE7D3BE65, 0x9EC8CDBA, 0xCE901946, 0xC4B4D088, + 0x98B1245D, 0xFBB0CC10, 0xE8CB9C76, 0xDE665AF2, 0x28E46D8B, + 0xF7012A56, 0xE29F8C07, 0x8BF87AFB, 0x2907C051, 0x820923CB, + 0xC3E95542, 0x6AB5559E, 0x314BD068, 0x1CEB5637, 0xD1D830D, + 0xC442D6C2, 0x5F6074F4, 0x37F08A2A, 0x21F782BE, 0xF378B1AE, + 0xB7FC74DA, 0x4ACB450F, 0x365F3092, 0xFB0C842C, 0x5DD80554, + 0x741C4F79, 0x290716E0, 0x76E56BA9, 0x10006310, 0x42A183C7, + 0x5F1FB962, 0x8DE2BA39, 0x6176B6D9, 0xFC059A44, 0x9907DE39, + 0x71A5EA7B, 0x42309616, 0x1DDE34DD, 0xF0DFA4BF, 0xF69B5E2F, + 0xD145268, 0x49A3E7B, 0x90508840, 0x861DE564, 0x904730CB, + 0xC844CD6F, 0xD5A2CEB6, 0xCE895F0D, 0x73EEE4D6, 0xEB4565CF, + 0x533ED4ED, 0xF4AAB655, 0x591BC278, 0xBD1D929D, 0x80AD7DA6, + 0x527B3C51, 0x40F627DD, 0xDA420FFD, 0xB9A6F685, 0x5F6D9BC2, + 0x4F67DE58, 0xFB5F87F0, 0x47540936, 0xB2083BC8, 0xAD48DD69, + 0x63F7CA5A, 0x28D5372D, 0x61DA54B0, 0x7DA88170, 0xA2DA7B83, + 0xE1D70E32, 0xA3ADEA46, 0x97026868, 0x60FA4303, 0xA4104416, + 0x3DB4A8CC, 0x72F0F53B, 0xFF270297, 0xD5600E97, 0xD7D25D62, + 0x46DBCAC5, 0xFD61775D, 0x93E100DB, 0xBFE0E0C0, 0x8CE51426, + 0x8216C272, 0xE7300A56, 0x5A61C30E, 0xA7667C78, 0xBD23D39B, + 0xDC425756, 0x7AE9A42B, 0x249E8C42, 0xABB91D5C, 0xBD1334D5, + 0x8BCE967D, 0x5CF89EEA, 0xDB125339, 0x225E3C4C, 0xC5DDA12, + 0xA92903F8, 0xF2F29634, 0xD2AB3419, 0x396DAE59, 0xA02C965E, + 0x450B8DEF, 0x1E4911B2, 0x4F94BA94, 0x6802E7C0, 0x779671B7, + 0xC0B06A93, 0x65BF0119, 0x3D672B7F, 0xE7E68CA, 0xF173FBF, + 0x503C50F4, 0x3D8CA779, 0xD9BC10B2, 0xE6B89F78, 0xFC04B6F2, + 0x74B0E1B4, 0x3BB8594A, 0x5866C0E6, 0x125FBE40, 0x21239465, + 0xC00E2791, 0xD7957B76, 0x331D18CA, 0x87D0C340, 0x8D7347DF, + 0x296D2AA1, 0x8EAA71DF, 0x1D477388, 0x4F666705, 0x211D2B0D, + 0xA41C0741, 0xD8F7CEEC, 0x4C6EDC5E, 0xFE5DC02A, 0xAA83AED3, + 0x9AE501A6, 0xFF82168C, 0xDC638114, 0x4C345BA0, 0xDD7E0F1D, + 0x4C072ABD, 0xFF606768, 0x3CE74279, 0x93DED13D, 0xAB7A9752, + 0xAF27666, 0x784EDE4F, 0x7F4BE8A7, 0x9A45141D, 0x69E507FF, + 0x78BAC3AC, 0xDB2A62AC, 0x52561515, 0xA9DFA9A8, 0xCC51778C, + 0x886CC6A, 0x5246AD23, 0x68A7480, 0xBC267A85, 0x1FF771F4, + 0x5199BC1E, 0xF8CCD05A, 0x7BD65764, 0xC61A33FA, 0xC9F24B8E, + 0xBC0B1D9F, 0xE43E103, 0xBE3D7AAF, 0x39154AD2, 0x941C2098, + 0x1C26174D, 0xC63D21F1, 0xFBC6D732, 0x8C43AE71, 0x1495C044, + 0x9483EE96, 0x909A94F0, 0xC1B02D9E, 0xDF9A2114, 0x2F4883E9, + 0x4806958A, 0x209A2722, 0xFE514205, 0xEB85D85F, 0xC25BED82, + 0xEB2CEABE, 0x8B2A2EDA, 0x68641725, 0x10570304, 0xE53EE68B, + 0xC43FB1C1, 0x8F763232, 0x41ECC1D0, 0xE3E44CBD, 0xA1A68EC0, + 0xDAFA770A, 0x6996A5A8, 0x38407C06, 0x4FAD77B4, 0xE30E2912, + 0x47EE2FD, 0x2CDA167F, 0x88F915F1, 0xF3DF6195, 0x530FBEDE, + 0x2CFC1C0C, 0x47B21171, 0xDEC1A586, 0x2031A43A, 0xDAAD77AD, + 0x8BE637E6, 0xA6AC1EBB, 0x6AB9F2A3, 0xBFB5ED6C, 0x15792C44, + 0xFD3AB89D, 0x27A7E24E, 0x3E76999F, 0x77EE2E6A, 0xE505F3B7, + 0x429839A6, 0x6BEE7B15, 0xF61F0084, 0xFC20752C, 0x4BF79989, + 0xC8B4F8E8, 0x46B33427, 0x9F4BA3E8, 0x41B9354D, 0xEED27E23, + 0xA7FC575F, 0x279180C5, 0x141C3A06, 0x2C2FCEF9, 0x4403AA1F, + 0xD4496B6C, 0x25C33091, 0x452C754, 0x80534A0, 0x80842F72, + 0x3DB756B1, 0xEFD010BD, 0x1DE7F9EA, 0x5F9B1769, 0x55D9839F, + 0xD5B11F46, 0x941D69AE, 0x8C4F3D35, 0xE710E268, 0x2DFBC983, + 0x5D417C19, 0x7C2561F9, 0x25415FCF, 0xF331B119, 0x235B632F, + 0x9B1463A9, 0x8249E513, 0xB6F14826, 0x1005E62C, 0x2B1B4F3E, + 0xEF793550, 0xA90F6AA2, 0x77BFECE6, 0xA6E1C13E, 0xBCB6E143, + 0x2496D0ED, 0xF4A8D5F0, 0x29C27A0C, 0x7D231D55, 0xB8526623, + 0xDDDCB82C, 0x2A18B465, 0xB5FD564D, 0xA9647CB5, 0x4300919B, + 0x9FB2B27A, 0xDB25B0D9, 0xBB5D5711, 0xAA747FC4, 0xAA831194, + 0x9603ED14, 0xAF921A0E, 0xFA1447D7, 0x8B766768, 0xE8F1C89E, + 0xB7985D4, 0x6C5C1AEE, 0x2EA66EF3, 0xD176E7D9, 0x228CD940, + 0xD90C84B4, 0x36253A66, 0xADD7AE4F, 0xF25D5CA5, 0xD34F702F, + 0xA535AA29, 0xFCF10FB, 0x3D075696, 0x63EF7EF3, 0x81554091, + 0xC7EEFC78, 0xE0DCDB21, 0x62EFF001, 0x9ACFD7CD, 0xAEBA43ED, + 0x371BA99B, 0x508B7A31, 0xFF447B05, 0xA239F5D2, 0xA5620A57, + 0xA16B995A, 0xC334401E, 0x535F51AB, 0xAEA26D82, 0x81D72269, + 0x3C0BA1D2, 0x80590850, 0x818A26AA, 0xC43E6B02, 0xF72DFB63, + 0xE7AE3F6A, 0xD31AB683, 0xB99D787A, 0x691FFB53, 0x37EA1E35, + 0xC2C9FFF8, 0x2A13F6D4, 0x4CC79564, 0x6DD5F2DE, 0xC53560B, + 0x5A562B6F, 0x3F2C49F1, 0x6953F4CC, 0x8BA12AF2, 0x98A08428, + 0xA1EF80B3, 0xA977E388, 0x1A3DD9D1, 0x687A3424, 0x2759B568, + 0xC626A765, 0x7887651E, 0xFC9005E1, 0xE84376A4, 0x387BCF66, + 0xF7AA4980, 0xBAEE372C, 0xE89CF460, 0xA275FC1A, 0xA5EF8668, + 0x899F85CE, 0x9CB086A3, 0xF16158AC, 0x4C49EBC0, 0xDCE10FAA, + 0x4B46ABDA, 0x56947FA1, 0xAD4E7245, 0x54C23373, 0x8B0B6C4D, + 0x82590F05, 0x5E292D4C, 0x277B63C5, 0x9D51D8CF, 0x86D379EF, + 0x52CBEF63, 0x7A62AF4C, 0xAC1FA33E, 0x25D454AE, 0x1CDA792D, + 0x17434813, 0x759F50A7, 0xEEB0D38A, 0xB30964A6, 0x941230A0, + 0xA464FA3C, 0x9F8685AF, 0xB9A018F4, 0x8080362, 0x2D565F63, + 0xAB60790A, 0x67252A3C, 0x1715B01D, 0x5384E7F3, 0x79299519, + 0xA9786ABE, 0x1107A1FC, 0xE0D9B037, 0x4DD34883, 0xA7D476E3, + 0x5B194AE9, 0x89E50FB1, 0xA9676565, 0xC77CF621, 0x93612BF2, + 0xE027B80, 0x359C7FBF, 0x39B166FB, 0x1F3B28DF, 0x2848DE70, + 0xFFE261DD, 0xB78D413C, 0xE011DD7B, 0x286F752B, 0x74A8D775, + 0x5E540B67, 0xFAF973F, 0xC0035501, 0xB0F16059, 0x1C981017, + 0xD4871112, 0x9745C0BC, 0x6D85B805, 0xA40253E8, 0x2B0D55CD, + 0x8FF7EDC4, 0x47EB4ECB, 0xC41A2F17, 0x41C9702F, 0x8549DEE0, + 0x865FD46C, 0x64A1F181, 0x24E64D11, 0x13337A33, 0xE8CB0924, + 0x8A2DC003, 0x113C04C7, 0x1CA62E13, 0xC360E708, 0x57DE03AB, + 0x4D8F2BB5, 0x2CE2E2A1, 0x2580C90D, 0xBF162A7C, 0xEB1490A8, + 0xBCABC2A7, 0xFBC4C25C, 0xBC83AB6A, 0x25C47DCB, 0x8FE447A9, + 0x2C0F77CF, 0x6D896845, 0x63CEF5AE, 0xB2FF0326, 0x14D71520, + 0xA1C15C8E, 0xE53550FB, 0x676B299D, 0xC20A5C14, 0xDB3EC54, + 0x359733CE, 0x8A619B1E, 0xCDB53E, 0xD285EED5, 0xA6E0181E, + 0xB81AA3EF, 0x41F8E1A2, 0xE3DEDC6D, 0x4F7CBE5B, 0x24006857, + 0xACB9B719, 0x4E725B2D, 0x8536AF54, 0x329509E7, 0x72E7C0A7, + 0xBA97CC78, 0xD822798F, 0x9DFC6780, 0x63E263CA, 0x7B2397A5, + 0xA42C0C0B, 0x1D5EC588, 0x292F1E7C, 0x2BF5A75, 0xFCD8786B, + 0x14EB1952, 0x84031982, 0xA0800A40, 0x629C9211, 0x3B17F481, + 0x50861D9D, 0x8371A304, 0xB3D21511, 0x720E2C6C, 0x5A07F87E, + 0x868F95BD, 0x8617E7B, 0xD7762105, 0x90707C5A, 0x777473F4, + 0x67737DC4, 0xC4154562, 0x1840CEB3, 0x373635EE, 0x4E6D4EBA, + 0x1736A5EC, 0x4D3E335B, 0x59FDB9A1, 0x9162B39A, 0x3F9E1502, + 0xF661B3DA, 0x77BE0255, 0x65EC8603, 0x21FCA0B, 0x55291C5C, + 0x69F57B1, 0x5DE1E0D6, 0xA6296E1D, 0x595A45F8, 0x90B166DF, + 0x61ABB34E, 0xC6D48B5B, 0xB05EF88F, 0x368B0C6E, 0x94C36250, + 0xB435D440, 0xEFB62847, 0x1473E647, 0x9A101218, 0xC7AA11BF, + 0x80C241E3, 0xAF648F26, 0xDF48753D, 0x7073509A, 0xAB52665F, + 0xD1ECCFC0, 0x7BE293F1, 0x396CA014, 0x84336AB9, 0xF9B7E448, + 0x9566C90E, 0x239F7C25, 0x91A452B3, 0x1E9A4F1C, 0xCCE286F6, + 0xF46520D6, 0x2943A671, 0xAAA30DCF, 0x28D190CE, 0x88E3D0C9, + 0x423944F0, 0x81E6712, 0x2714B6B2, 0xF927748, 0x59A5430F, + 0xCBA530A9, 0x91E12A0E, 0x92598CBE, 0xE61058F5, 0x2604B4B, + 0x4CB7C3A7, 0x43B5812F, 0xFD90660, 0xD73DF50D, 0xAD3AE409, + 0xF74D721B, 0xCC2A88D1, 0xCED79510, 0xE64714DD, 0x3BDF0A8A, + 0xC2C7B689, 0x25B387D8, 0x968DA1A2, 0x8EA5D185, 0xF05F03E1, + 0xFDDC5B50, 0x78AECEF, 0xE32FBBA2, 0xD512F0AD, 0x5410D1B5, + 0xDBFD9FFF, 0xC0F2DD4E, 0xF66F8DBA, 0xF5EBA3C8, 0x65F96FE3, + 0xF7C8962D, 0x8E48A78, 0x255BEDC7, 0xE8FD3698, 0xFD1C4903, + 0xFDE9830, 0xCDBCF434, 0x16540D39, 0x418EF731, 0xB2F80637, + 0xDFCC0C9D, 0xB53DC5BC, 0x5A68B10C, 0xC4DCB3DD, 0x8B3778F4, + 0x7788B194, 0xECBD4903, 0xFD390223, 0x79598BFB, 0xBDECB9D9, + 0x29576BE3, 0x220F82A5, 0xDBB262F6, 0x1876EF0, 0xE2D9C444, + 0x32D5ADEF, 0x5F8739ED, 0xAF427122, 0x171E7D7D, 0xA5468BB4, + 0x94451936, 0x51565032, 0x3CE3CD5, 0xF231F54, 0x98614C6E, + 0xCE18455D, 0x958D2BD2, 0xA5934FE0, 0x3543931E, 0x77D9C2FB, + 0x3D3ED736, 0x6762E077, 0xF1B052A, 0x88AF353B, 0xB2A38925, + 0x8C919686, 0x715EEAAC, 0x34BA46DD, 0xEB486F1C, 0xDF58D7CA, + 0x90B97BE6, 0x37335293, 0x499414CC, 0x7F725BAF, 0x5ABEBF8, + 0xE9344F69, 0x1C110FD, 0xA937AD4C, 0xA7CDD9C0, 0x750FD5FE, + 0x7A7B6D40, 0x41EA948A, 0xA10EE17C, 0x7689C967, 0x9F411C02, + 0x6C40C3FD, 0xA6FFC648, 0xC6D6F914, 0xA100AF92, 0x4CD97ED5, + 0x17D9CCBF, 0x915833F, 0x788D78C0, 0xC81903A3, 0x6DE5BAF0, + 0x3E4D6DCC, 0x98415810, 0xEC23B7AD, 0x822471B0, 0xD2CF5D5A, + 0xA1BACAD5, 0x40843135, 0x430135A, 0xA7655BAD, 0x7A2472BE, + 0xCC3D44CC, 0xD1BC9E10, 0x7C215C92, 0x717FA7DD, 0x7EF7D128, + 0x1BC85798, 0x7C6E19CA, 0xE3FAB7E4, 0xBC884D38, 0x3E220CA, + 0xE7AE4D8, 0xC8EDD021, 0xF3F05D3E, 0xDE302EB8, 0x40CEFF27, + 0x56C0550A, 0x96162C92, 0xC004EA48, 0xE0C29A65, 0x496AE22B, + 0xC7468E6F, 0x8E31BD1F, 0xA53763CF, 0x166CC258, 0x1A2B9CC4, + 0xDBBADE7B, 0xF8D21AC9, 0xB21CA593, 0xB92F0DEE, 0x9A4391F, + 0xCDB4D373, 0xB687B3F5, 0x877BF0A0, 0xFD7395DD, 0x1C56AA87, + 0xCA146BB9, 0x21A2314B, 0x8207A2AC, 0xAA874DC0, 0x4F404E64, + 0xB69FDE48, 0x324FD456, 0x45F19CF, 0xFC7E6D0E, 0xC8A01C04, + 0x76C63378, 0xC526F7B3, 0xFDCD2EEF, 0xFFB2F9B9, 0x2DDE75AF, + 0x5ADF2F86, 0xC9AC84D3, 0x70FF53A0, 0x3FB077C, 0xC2795B30, + 0xF5438170, 0x557D7080, 0xB784684E, 0xCD089E1D, 0x332B71B0, + 0x493C3C2A, 0x1D1DED89, 0x8240E170, 0xA7D17522, 0x48C542AD, + 0xCB357D8F, 0x21E37C1, 0x3B000B34, 0xAAAE4818, 0xCD1EB4B3, + 0x1736CA0E, 0xDDF8EA2B, 0x76E21C4C, 0x6EE99A3C, 0x27F71B20, + 0xF6AE929C, 0x3C9CAF6C, 0x5CA7DA97, 0x8EF033C5, 0x8C7EC36B, + 0x3CB1CFAD, 0x1C5ABBB7, 0xDEF7A78C, 0x9CBC4A73, 0xB3871393, + 0x8C61DF59, 0x54DF941C, 0xCDD23FE8, 0x758EAD7E, 0x49BE795B, + 0xC960C6B, 0xE9B76479, 0xC88843F7, 0x82DC3137, 0xEDEE1A1E, + 0xC6568A7D, 0x42F7F484, 0xA6115655, 0x494779B5, 0xD95FE16A, + 0xB2AB15F4, 0x64C185B3, 0x9A46066E, 0x8BAE077E, 0xBAAE323F, + 0x79A965C6, 0x764B71F0, 0x3654F6D3, 0x96B4B2AB, 0x15C2B523, + 0x720AF416, 0xE6D0F423, 0xFAE44868, 0x6E776BC2, 0x264D41A8, + 0x3FE4BEE, 0x1598B97B, 0x15A70419, 0xA13CD124, 0x751A09E2, + 0xF7F7C12B, 0x718AC211, 0x11D03CD1, 0x2F9247BE, 0x77C210E1, + 0xA2268AAB, 0x2E99F0DD, 0x949D5CC5, 0xA8A309F2, 0x749EC6BE, + 0x5BD5124A, 0x8BF599E9, 0x3919AD4F, 0xA40901C2, 0xA1D4CC03, + 0x6ADCA36F, 0x9D5CCB0F, 0x870E2A58, 0xCEBC6333, 0xB2FA28A4, + 0x579C76A, 0x444849D0, 0x33887308, 0xB3BE3C75, 0x93745501, + 0xC289F137, 0x89739C7, 0x97C73423, 0xD627FB64, 0x6EE36F05, + 0x1F4B4B98, 0xFBB7A8AC, 0x60941E62, 0xC3A8ABDC, 0x4AC5E7C9, + 0x88ACE940, 0x5AA2AE59, 0x9F10C0B7, 0x8F45920B, 0x5FDE21BE, + 0x1D47779A, 0x3ED27D8B, 0x69FF2BB1, 0xCB1409FB, 0xF27F4FFF, + 0xA19E3DDC, 0x206050FD, 0xAD98C2D5, 0x4DA4BC0C, 0x95D9B019, + 0x556ABBFA, 0xBC78B5A, 0xF0F224F8, 0xA9785F8F, 0xED1CE98C, + 0xD368072E, 0xE212ACE5, 0xBB7F76E0, 0xB02F237F, 0x6D85C5AF, + 0x31539988, 0x4312BA19, 0x1D5023A7, 0x7320504B, 0x70563ABD, + 0x2553791A, 0xE9768150, 0xC1B2AF4B, 0x3AF0FD24, 0x3818D0E8, + 0x7F356F58, 0x98A15B0D, 0xAFA943C4, 0xB2B38831, 0x2E411F37, + 0xE3D5AF87, 0x67BEEC5A, 0x825E60CC, 0x1C44D856, 0x1A59493A, + 0x13BAABCF, 0xAEAA4D44, 0x5CFF2A6E, 0xFB47865B, 0xE778E607, + 0x101500E8, 0x2C17E66A, 0xA0B30350, 0xFC649CDF, 0x8B9802D9, + 0xAB87D61A, 0x21F38439, 0xD3D11051, 0x1FDA9955, 0xCB9313B8, + 0x327D1A94, 0x35293099, 0xB803B298, 0x5B8E6883, 0xFA309C3, + 0xDFDA8B2, 0xDF89211F, 0x9918F18E, 0xF0C05CB1, 0x71D8A4B7, + 0xE681031D, 0x537012F6, 0x4DF822F2, 0x34B75C8C, 0x4429F85E, + 0x5D3C4C4D, 0xFB0FC6C7, 0x25F4ECDD, 0xB19D5EFD, 0xD70FD7CF, + 0xD95C45D5, 0xCDAC06B8, 0x9C3B963B, 0xAB2F2A9C, 0x4D3D4F7D, + 0x12692C03, 0xB1AEF97E, 0xF243EFA7, 0x78C4C8DF, 0x182D9C17, + 0x8D2AF450, 0x7596BD9B, 0xE8E7C9C2, 0x86F617F8, 0x1F37A708, + 0x3F648305, 0x27FF6DF6, 0x4D5FF17D, 0xA9541C2D, 0x9773013, + 0x78B2313C, 0x82C0B20F, 0xD36A4F02, 0x8DB2BC4F, 0x9296D8BF, + 0xA983CC7, 0x31AEE908, 0x48CD7E6F, 0x9CB1DD7F, 0xAB89D57, + 0x5156132E, 0x6345AA59, 0x8D2CB12D, 0x94D3AE56, 0xA4E91B27, + 0xEE58338, 0x8620EA15, 0x5454D04E, 0x1142ACF0, 0xCA059044, + 0x31811D8A, 0xD498290, 0xB65F1B67, 0x462745F3, 0xA899191C, + 0xB9C19F48, 0x824659FE, 0x9A257101, 0xC330F34B, 0x42109127, + 0x9DA8504B, 0x6C3A989F, 0x5F426E6C, 0x2B922D32, 0x373C66FD, + 0xAFE3418B, 0xE3788682, 0x83B46626, 0xD0106A4E, 0xFD10B903, + 0xB0F6531C, 0xC65419E0, 0x3963952B, 0xB8799DF9, 0x3EEB8C1D, + 0x5C4D3C08, 0x6DD028A6, 0xA55678A0, 0xB8247141, 0xC1267586, + 0xF6746B19, 0x46C38465, 0x483D24B, 0x99BF79DC, 0x78F778C3, + 0xAFF40193, 0x58872B07, 0x6DA7F4FA, 0x66B5CEA3, 0xDD2D8C79, + 0x2A8D289B, 0xB5789670, 0x66AEFCE3, 0x56FB52B3, 0x20FE3BE1, + 0xCCDFB492, 0xB0F263E8, 0xD0707433, 0x5E58F5DC, 0x4ABEBE63, + 0x8A45CD95, 0x97037830, 0xBDB1F1B5, 0xA1BE2990, 0x57B718FA, + 0xD50EC023, 0x810DD849, 0xE650D43F, 0x3895C77D, 0xE142C382, + 0x35551E5B, 0x3B94330, 0xE92D8A91, 0x50BC837D, 0x61499A8F, + 0x2639B468, 0xF8FF36E1, 0x74956FC6, 0xFF0F4192, 0x6BBA0C53, + 0x5B44FF85, 0xBBE4A1DF, 0x12D6CB14, 0x6C679A10, 0x3C0F554D, + 0xECBADA32, 0x8A99BA10, 0x738C03C4, 0xB8902AC3, 0x7008D470, + 0x49BC2ED9, 0xFBE19B5A, 0xA1E4879A, 0x36129694, 0x94987C3C, + 0xE54B84D8, 0x9CFAEF1E, 0x527127DC, 0xA8FCAE0, 0x8699252C, + 0xDAAD4629, 0xC41F3866, 0x2559C272, 0xB1C25848, 0x3F9B1702, + 0x7C448BF3, 0x8CCEDF5C, 0x3A37F712, 0xFB9E4F83, 0x5754E801, + 0xB38FD367, 0x780F4825, 0x959330C4, 0xF6276BE5, 0xAE3E2018, + 0x182DC907, 0x88E733F9, 0x6FF870A, 0x79EF2D01, 0x3EAC0D6D, + 0x20D4FF88, 0xAE6EB8C1, 0x80810451, 0xC228E035, 0xBD942803, + 0x3F3733F2, 0x9F8F16F6, 0xAAA65031, 0x55E839BC, 0x7EAD3461, + 0x5F5BEE8A, 0x8668BDBA, 0x399366DB, 0x2A54237E, 0x776789E, + 0x7B171AF5, 0x8C9FCB92, 0xD87465F2, 0xFA3CAAB5, 0xBA5B131E, + 0x1FD2D438, 0xDCAA9DA, 0xE1BF0AAA, 0x1EAEA8AE, 0xEB46A646, + 0x989D1EA2, 0x98E8B45F, 0x12A2415B, 0xD107D293, 0x5F54D087, + 0x95AF5C33, 0x2A12BA88, 0x6381D0FF, 0x688EA1E0, 0xACC60CA2, + 0xF19636C6, 0xD4D465E2, 0x2A50DC57, 0xFB595CCF, 0xF5C63674, + 0xB4965626, 0xB903D3D0, 0xD9581548, 0xBBD9E82E, 0xE22BCEF3, + 0x9FE759D, 0x6E8D8F4E, 0x655325D2, 0xE1986814, 0xEA2B93BF, + 0x88085C18, 0xF82BFCB0, 0x3FCF713F, 0xADE03EDC, 0x2D2DDCBC, + 0xEDE2694E, 0xF6DFB11D, 0x5CF35A5A, 0xD38C82D3, 0x52DE32CF, + 0xB88EA70E, 0xF7FB134F, 0xAEC78D1E, 0x58402C66, 0x54CD1763, + 0x78A7EB4, 0x88F49C30, 0xDC17F8C0, 0x9C49A368, 0x926E18EB, + 0x4DD461E1, 0xA6BD8F3C, 0x6D2E4C31, 0x657506D9, 0x445EF83F, + 0x77E28461, 0xF715400F, 0xBB76D1D, 0x9B670CD2, 0xCEB9EB90, + 0x7F297088, 0xD3929A52, 0x9B62909, 0x46474012, 0x3D74DFDF, + 0x46288EF0, 0xF0C51C07, 0xEC642B66, 0x3C76B83C, 0x1E72D08F, + 0x9F95DC1E, 0x106883C5, 0xB6A867BD, 0xA532C423, 0x95076036, + 0xA9DBEA73, 0xA3F8C65D, 0x799CF6BF, 0xA4508346, 0xB37CACB2, + 0xF6A07B5A, 0xA2C24137, 0x2E1D8DEF, 0xD28C26AD, 0xCE745089, + 0x3B7D9638, 0x7189CE82, 0xBC3F7850, 0x5660A9B8, 0x13895B5C, + 0xFA59A643, 0x9B0FF4AF, 0xFD2B4FD3, 0x4C0C4E52, 0x272631DE, + 0xA52FAE47, 0x65850A25, 0xD51ACF2B, 0xD206E6EB, 0x3CDC96EB, + 0xA6FF9E3A, 0xFC601E27, 0x658EF7F0, 0xB45FF508, 0x36A9A571, + 0xCE75E7E9, 0xC4BF9261, 0x3A261099, 0xF1B1CE3E, 0x3D28A165, + 0x3435D2FF, 0x70830AAE, 0x8DFE14F7, 0x3E27CDC1, 0x97BE4BA1, + 0x33F8D0E2, 0x9B2E7BCD, 0x1923B1C, 0xAA248E78, 0xFDA8AEB9, + 0x7825E511, 0xBF20B777, 0x218E4234, 0x7B5D1181, 0xA08988A0, + 0xD9009231, 0xEB15A567, 0x47E045A0, 0x3C515808, 0x35194ACB, + 0xA476304A, 0xEF738BD6, 0xD035FB8C, 0x3B2013F4, 0x4DE60F26, + 0x361431DC, 0x82ECB228, 0xAB22266, 0x4E056EEE, 0x6642D288, + 0x48D851E3, 0xE05D55D9, 0xDC2D6D4F, 0x158F7F48, 0x5D7F7D5A, + 0xC2835158, 0x793509C5, 0x479DF33C, 0xDEF0696A, 0x9FC2BECD, + 0xF4EFC675, 0xF8D1FF02, 0x493D3BD6, 0x7FA1C10F, 0x641B324D, + 0x996DBDDD, 0x24098529, 0x81CCFC35, 0x47F0BE17, 0x5E241815, + 0xF7F62788, 0x261CDAF5, 0x10CBC4B8, 0x5D6C6A7B, 0xD671AE81, + 0xB2C8DCD9, 0xD215CB7E, 0x3403AB1B, 0xA7C5999, 0x4675A50, + 0x369C560C, 0x32C619D9, 0x4FD2E12E, 0xB4A20359, 0x37E93502, + 0x5EC0CE10, 0xB374340, 0xB0DF0419, 0x5960ED4F, 0xF0A7770E, + 0x7F504F30, 0x54A92972, 0x3E9848B8, 0xCD980ABE, 0xDE69D570, + 0xA9FDFFBD, 0x9812C681, 0xDAFCCF4E, 0x2B636CB5, 0xB2B9FF2D, + 0xB9972800, 0x701231C6, 0x2E1108F8, 0x8C323A3E, 0x20A17A77, + 0xF2C6CC7, 0x44C5FD1C, 0x731622D4, 0x9BF0C91E, 0xB61CD1B1, + 0x61FA9CF2, 0x5E460518, 0xF75A1C06, 0x417CCEE2, 0xB45E0FB5, + 0x53DC30E8, 0x500CBD7F, 0xED61DAE3, 0xEFE91818, 0xB56814BA, + 0xD37D84C8, 0xD5DA9ED7, 0x5F40F92, 0xF1507FAD, 0x2CC74A65, + 0x32AA6279, 0x33731317, 0x30E09F03, 0xE1D9C403, 0xC21E638A, + 0xA7394D05, 0x3879F710, 0xDBB52C37, 0xB7780268, 0xE268E178, + 0x9F8072D3, 0x97CC035A, 0xEE65287D, 0xA197441A, 0x21C8AFA4, + 0xB81B50A9, 0xAF6ACC93, 0x7BB55B77, 0x564A0BD4, 0x17F7A6A9, + 0x36627846, 0xDCE746EA, 0xBB9762DE, 0x47B5B8F0, 0xEF5DA4AD, + 0x1922E420, 0x15F9299D, 0x243DAB0D, 0x953C67A3, 0xF3DA71D8, + 0x57122A3E, 0x423A78B, 0xC4A53000, 0xFBE92583, 0x968F3AE, + 0x61629123, 0x792FA07B, 0xBF45729D, 0x99DDD38E, 0xA14565FC, + 0x268E9E3F, 0x7EC9286, 0xCCA1D92A, 0xF06519DA, 0x22396664, + 0xD5DAC24D, 0x71BB4DD5, 0x7D329BB3, 0x401DAB69, 0x19D3E40A, + 0xB6F40F32, 0xE8D1CAF8, 0x5CD5F35D, 0x6F662316, 0xD38D1A6C, + 0xF86E720F, 0xE165D1B9, 0x1BC14E79, 0xC19FB43D, 0x891C013B, + 0x44AED4DC, 0xA7351AAC, 0x5F707A18, 0x3850148, 0x4A425E1, + 0xF7DD6EBD, 0xE0C3FD0E, 0x8266A425, 0x3BA17650, 0x48753ADB, + 0x679FA015, 0x88771712, 0x2174B185, 0x29F9A85A, 0x1560964A, + 0x198E4FCD, 0xD3410A86, 0x9186793D, 0xDAFC5C35, 0x971F4CC8, + 0x1F8F0E8B, 0x11A884F2, 0x66E6D2AC, 0xE85ECDB0, 0x86C76472, + 0xDF3B3320, 0xEEF446A6, 0x834CF19B, 0xECEA602A, 0x46C680AD, + 0x807BA92F, 0x4B3FC42B, 0xEC229845, 0x3FE389C1, 0x63E042D7, + 0x6C855119, 0x7B1ADF33, 0xE1B9CAE0, 0x62C20BAE, 0xEDF0E919, + 0xA50FC7EB, 0x2399262F, 0xD6F88130, 0xE2ADA5DB, 0x7D07BC3C, + 0x36A922F3, 0x7693B84E, 0x3015CD0C, 0x1D1047A7, 0x5D3A75A5, + 0xEE6F1CA9, 0x734BD19F, 0x3308DD73, 0xCEBBC9FA, 0xF79DD5A6, + 0xA41CF168, 0xED762FD8, 0x6642159, 0xA63C5CD6, 0xCB96A282, + 0xA29D9F5C, 0x45CC6CD4, 0x344611EF, 0xC345FE03, 0xC55ADDE0, + 0xB2B8374C, 0x14F730B1, 0x301D9266, 0xA2D98FD8, 0xBC107DF, + 0x59905EE3, 0xDB3560DF, 0x1D49F4F3, 0x785F8E0B, 0x8B116097, + 0x56154F60, 0xE312D829, 0xE0AFAE9B, 0xEAE3692E, 0x95915B8F, + 0x83BEEE75, 0x48C1C92, 0x8166D95E, 0x697FECA8, 0x135DEBF9, + 0xF83E6507, 0x11570809, 0x4862CBDE, 0x820E288D, 0x6CA59B2B, + 0x49DF6AD5, 0x86F41C43, 0xDD128A28, 0x601198A0, 0x3DDD49CB, + 0x95F3ACCE, 0x500CD9D6, 0xF54A50F2, 0x9936957B, 0x7C881875, + 0x743B055D, 0x44FD7934, 0xAF2253BB, 0xA2F4A27C, 0xBA8E1C2B, + 0xCCFA3259, 0x892FC73F, 0x283E74B4, 0x86119027, 0x87961F02, + 0x1D015187, 0xBA83B762, 0x61948B32, 0xAC741667, 0xFA9E0E39, + 0xD440D9CB, 0xED93F9F, 0x5FA97905, 0x2F5F82D8, 0x92EC7646, + 0xC60B3F9, 0xAA28822A, 0x7BA7CD3D, 0x3E41A20B, 0xDE4441A9, + 0xC75E539B, 0xD9D568C2, 0x2DCAE06, 0x7762550, 0x21C2D5EE, + 0x95CB6C94, 0xE31FC800, 0x3C03C172, 0xE166E564, 0x359C5102, + 0x7F717599, 0xBE301B47, 0xB207FA5C, 0x38B8B24B, 0xE6EFF05D, + 0x9F09D305, 0x31A27808, 0xC56D934F, 0xB440BD60, 0x52B1AAC4, + 0x78654045, 0x106A67B8, 0xF2A861E5, 0xC45D72B0, 0xA8FF8296, + 0x97F475A6, 0xDC222733, 0x7A835D7A, 0x45774E9A, 0x9E558C34, + 0x1124605D, 0x1689FED3, 0x70AB9928, 0xADBF8E55, 0x9C09EE27, + 0xF95A8C49, 0x75CD52D7, 0x4FC7275A, 0xA46C29F6, 0x747D788, + 0xA3347E5, 0x5B08AB02, 0x13CDC08C, 0xEDB65176, 0x6B36600A, + 0x26F5AD2A, 0x39949D1, 0xA1C8F6E5, 0xEBF0CEFF, 0xAB60A06B, + 0x10E522E8, 0x80E056D8, 0x1B301392, 0xDC3E0B07, 0xE10174EE, + 0x25DC4733, 0xB4E5A24A, 0x4B569CFE, 0xCCFE9F0D, 0x19BDC038, + 0xF8A0A718, 0x9944E8E0, 0x9591528, 0xBF27BDF1, 0x2C160255, + 0xF9E2F1B, 0xCE4FD96B, 0x703B2A77, 0xDB6EB2A7, 0xBFC2FA6A, + 0x11D00F81, 0x9540FD8D, 0x75849882, 0x183AC87C, 0x91DD1783, + 0xA3A0CC0D, 0x47F1CED1, 0x4DA4EE62, 0x819BA59E, 0xD5DA1DA5, + 0xDC218BF5, 0x899CC3A1, 0x1DECAD82, 0x77E193A5, 0x9F390C10, + 0xF5FCD674, 0x1E43657A, 0x6B61D25E, 0x99B9140E, 0xFEFB9CF9, + 0x6569445D, 0x14C9A2AF, 0x85A33FB1, 0xE4029ADE, 0x4FABD0FB, + 0xDE02379B, 0x65C8311F, 0x3CF60630, 0xC8B179FF, 0x9D83CE64, + 0xFF683C7E, 0x6D796948, 0x249B0AFA, 0xC5A65FDF, 0x252DA26D, + 0xFE92E52E, 0x90D081E5, 0xC5A8E180, 0xEBDB0943, 0xB0E7C78B, + 0xD5A89E4D, 0x684EE280, 0x8AAB613C, 0x6BD1547, 0xD12F7355, + 0x9C5D1363, 0x91E410A4, 0xDC841FBA, 0x703A9371, 0x79F8663, + 0x553650FC, 0x633CA726, 0x20107BD7, 0x2565F252, 0xCDD93830, + 0x3446CF7, 0x92B6B42A, 0xA070B2D1, 0x5E0384D1, 0x7CC5A19C, + 0x6890558F, 0x10D308AA, 0xDFF3016C, 0x1093AA3B, 0x8927683A, + 0x9259502B, 0x2B544B7C, 0x419B1B1A, 0x22D9E939, 0x568ECCEE, + 0x4F3CE09B, 0x8B990521, 0x8D6906A3, 0xC15DEDC4, 0x98384A4A, + 0x8F2F2652, 0xEDB9D614, 0x1D010AC3, 0xA2CDC134, 0xEEE9A9ED, + 0x241DB9A2, 0xE9DB9AE7, 0x7A788F9E, 0xBD0778B7, 0x27373539, + 0x7C6B4A4B, 0x3C7A6B37, 0xDE1C625, 0xC1256E67, 0xB8E69163, + 0xCC05D09B, 0x728A1427, 0xECAC2530, 0x1DD40BC8, 0xEFE42E56, + 0xB4266BE0, 0x9AD3F869, 0xDDFC2F60, 0xEF29B3F7, 0x7C15F90A, + 0x705C2992, 0x99AC7AEA, 0xCF1F09A0, 0xB41F14D9, 0xBF3C252C, + 0xF3483286, 0xD3AC398E, 0xB84BC93D, 0x6B780D11, 0xF682D379, + 0xB8A062C2, 0x9A003A9E, 0xF18F54FC, 0xDE81BB83, 0xE84C5234, + 0x37CB67FA, 0xDB685C6, 0xBF2BF28D, 0x8CDE583, 0x94CCD0BD, + 0x8BCAF516, 0x31BE93C2, 0x3ED4B623, 0xCD23346E, 0x8254E7A0, + 0x6091EF1F, 0x17A42562, 0xC9821677, 0x447B6623, 0x19D9356C, + 0x4A1C1953, 0xD1F3B7F9, 0x99F8388D, 0x62F22304, 0x5EDF1ECA, + 0xB6C9FC2F, 0x42968E22, 0x531BD76E, 0x25E6A95A, 0xA1669784, + 0x8B915BD2, 0xA5E21483, 0x5ABE3226, 0x605C0E15, 0xFDE713CC, + 0xFAC58D3B, 0x44FAF6E8, 0x41E2D699, 0x8EE11E34, 0xB03BE4F6, + 0x75054C0D, 0x1AF2D37, 0xF38E6829, 0xE7F2A519, 0xC9CF2CFF, + 0x996DDE8, 0x395AC493, 0x42AFF184, 0xB380B71C, 0x11AA0B90, + 0x66DC636, 0x56557CA8, 0xCB8CAA43, 0x9EBF806E, 0x63F66159, + 0xA011191D, 0x17B0AED3, 0xB9621251, 0x2B189E3, 0xD45A5D7, + 0x23009D12, 0x5DEB7918, 0xFDFB1FC8, 0x46808A73, 0x91D29330, + 0xF872C15D, 0x7BE90206, 0x257E9FCB, 0x2E52FF67, 0x1852DDF9, + 0x6A2C5C49, 0x6ACF891B, 0x29FFB0E2, 0x76E32CD2, 0x588799, + 0xD71D970E, 0x9B079EC8, 0xEBD25420, 0xDDB60276, 0x761B106F, + 0x871473C4, 0xBC697CE2, 0x5378E0E9, 0x8DAECE28, 0xE5B275FA, + 0x6E6E332, 0x853884E7, 0xD0FFF1A2, 0x722D372, 0xDD5A754D, + 0x87CDDA3C, 0xA9B629C0, 0xAB2E650D, 0x1709413D, 0xDAE63819, + 0xC60DE8CA, 0x9F344BD6, 0x8E651EF9, 0x3B6A8019, 0x95CC1296, + 0xB12DAEAB, 0x8D550156, 0xF14E85AA, 0xD2547469, 0x6336E320, + 0x223B05B9, 0xB88AD493, 0xEE14916F, 0xC78AF1FE, 0x65FC2787, + 0x778FA85F, 0xBA23A57E, 0x957EA954, 0xAE4F9577, 0x47C38D4F, + 0xDB7BCDC9, 0xBA13E42E, 0x46B01094, 0x1A15F5E4, 0x315AB789, + 0x9E44B54F, 0x8C690B2F, 0xDC4954CD, 0xF176F3FF, 0x9B154C06, + 0x112BD6D0, 0xCB120BBC, 0x11101771, 0x1F29A19D, 0xC3F8193A, + 0x805D6739, 0xE3B00ACB, 0x23DD9494, 0x4F88EBA5, 0xE6F32E0E, + 0x4B76F089, 0x43B66BEB, 0xF2420B12, 0x2CFC5E01, 0x1C68D3DC, + 0x30C1BD38, 0xF3A0FCCA, 0x2AF13CD5, 0x13E38185, 0x2DEE2A21, + 0xFC318E26, 0x1954D4B6, 0x3FB86424, 0x24D698F1, 0x4AB76D48, + 0xA9E87BD9, 0xCE1DD2F2, 0xF5904D9F, 0xF614DB18, 0xF83111D, + 0x1FB56EFD, 0x5CBD08D8, 0x2D8D4884, 0xE388C534, 0x413D5BB8, + 0xEB6D14D6, 0xAE54E361, 0xF73D926B, 0x43F27197, 0x7C50A2E5, + 0x10EDBD6C, 0xD151B569, 0x47C50C06, 0x8FD59E74, 0x551C6841, + 0x2EC2B6DC, 0x5CEAB3A9, 0x1E6A1609, 0x3FB07FED, 0xC0D5849A, + 0x6354A21B, 0xEBF18830, 0x2BB3EBBD, 0x9D4DF510, 0xBBBE1103, + 0x918D6DDF, 0x3FEE7A8B, 0x4FC47254, 0xE0E1EA65, 0xF3DDB31A, + 0xADF8DE67, 0xADA31FAF, 0x2BC0B8A2, 0x184B7432, 0xFDB2E733, + 0x236B014, 0x21062C, 0x8FAAD8D7, 0xA1DA7E44, 0x3EF7F42F, + 0xA67AAB82, 0x9238F0D8, 0x42F93C63, 0xEF0F4BA1, 0xE61DC644, + 0x994EF92C, 0x71A58613, 0x371665E5, 0x82E77BA1, 0x2FFA1DAE, + 0xFE19AAA0, 0x95C72A53, 0x6A21395F, 0xC03F853C, 0xBC7B73BC, + 0xED62A949, 0x4F7D3C52, 0xCACFB353, 0xA1629BE9, 0x16255784, + 0xAE465FC4, 0xE7FC2626, 0x5E9B0FC2, 0xD109084D, 0xE30E7B89, + 0x94CD7424, 0x6127AF6E, 0x7D08ED7, 0xFA0B9293, 0x450A112F, + 0xD0D79344, 0xA204F8B0, 0x5F825780, 0xD681148D, 0x71C6AE83, + 0x1DF62587, 0x99ABC8A6, 0xCFEE8131, 0xFCD11719, 0xD0D48B0E, + 0xCC4A710E, 0x7414791C, 0x22167734, 0xD17FE049, 0x5BF15C46, + 0x30B718E0, 0x6E85104E, 0x52F72575, 0xA17F09E1, 0xCDA7B24E, + 0xDAF7D03B, 0x3632D94B, 0xBAF4E9EE, 0x390CD998, 0x168C055E, + 0xBC2D8D0D, 0x35E9F642, 0x89757E1A, 0x2BB98011, 0xC19BCD15, + 0xEEB73587, 0x6A5194EB, 0xC2C1B4BA, 0x3C8F73FC, 0x8F075D29, + 0x42D39406, 0x6674167A, 0xC0904A73, 0x1158FE6B, 0x4CAD2FAD, + 0x9A7EC8A5, 0x651960A6, 0xD0329ECA, 0xF5130525, 0xCC7C40CD, + 0x259AA3D8, 0x9669412D, 0xB92D39A5, 0x29B217D2, 0x27A07E25, + 0x9AFFD359, 0x7E8F5AC9, 0xCF7C0F61, 0x5B4F8D7D, 0x31C4E97E, + 0xBDB9599C, 0xA85BD7E0, 0x87F0BAAB, 0x2852E628, 0x377BD41D, + 0x4B54844, 0xDABF47AE, 0xA1B7AF6B, 0xCCF57165, 0xA90C4348, + 0xDC1CE2FB, 0x42582D37, 0x2892F4E0, 0xB89AC8E9, 0xB2718E40, + 0x93BCCE08, 0x5606C693, 0x1952D10D, 0x96609D8F, 0xEE3BC3C7, + 0x2DFA50E8, 0x5582FD75, 0xBDC2618C, 0xA3D922EE, 0x8F766106, + 0x184ED901, 0xDAABDE09, 0x40CBD4E2, 0x4A9A2A70, 0x9814D393, + 0xE394A090, 0x9EA06A4F, 0x2EC8C8A2, 0xFD2EAFF0, 0x2F6C96B5, + 0xBB17EF37, 0xDA677FE2, 0x2357E330, 0xA8C9DDED, 0x735A7B2C, + 0x41C2B39C, 0x787E099A, 0xFBF8204F, 0xA56A4B69, 0x7DE2860, + 0x34299BB3, 0xD1CAE881, 0x5F452DDC, 0x700904E8, 0xC3B47017, + 0xF7040305, 0x5C42BE94, 0x88AAAE53, 0x9FCAAD72, 0x2774D420, + 0xDD685357, 0x80499592, 0xC5FB26E7, 0x90BA598F, 0x4A13D60A, + 0xC6D5F72, 0x97C35532, 0x6580493F, 0x9D31E266, 0xEF926A38, + 0xF68CF9C6, 0xF770C570, 0xCA18C06A, 0xFA2BB2, 0xFBA375DC, + 0xC2FE76ED, 0xB91611FA, 0x528A8EA5, 0x360A527, 0xF631D04B, + 0xF0C67ECF, 0x4E490A69, 0x19DB46F0, 0x497DFBF4, 0x58E490FC, + 0x24A51378, 0x186BDC14, 0x90E633A3, 0x6D6F8D95, 0x2FDE02DD, + 0x4B2714A6, 0x6FC87FE0, 0x21569667, 0xDCC31F06, 0xC9D9DFD0, + 0x830AA4A4, 0x78FBFE69, 0xDF17CD55, 0x3952AAA7, 0x9A4B5A7D, + 0xB1EBF3EF, 0x4F3BC1C9, 0xDFEEBF40, 0xAB130CC8, 0x1EB84425, + 0x4625E802, 0x20B990D6, 0x4E36869F, 0x5EEC0472, 0x29194460, + 0xCA425ECA, 0xEB0742C, 0x17D07C02, 0xF38BCA14, 0xBC9D555E, + 0xF15822E7, 0x89CF96E0, 0xAA848F9C, 0x90731AC9, 0x86EECBE3, + 0x308F3257, 0x5FF375DC, 0x1E62C041, 0xFDB6A3E7, 0xDFEBED8E, + 0x8FC77E76, 0x6973E542, 0x2AD1616C, 0x99B549C6, 0xD28CF364, + 0x88C87768, 0xECA2CFB, 0xA0D0B060, 0x42DFFD8, 0xAF80A6DE, + 0xFF323760, 0x1CB2DAAA, 0xD11DE4FC, 0xEEBF565A, 0x9C986CAC, + 0xC1C95B3F, 0x6868BF0, 0xF5604930, 0x316DD9EF, 0x1231D331, + 0x95E38E67, 0x7D30C191, 0x354804BA, 0x265EE5E, 0xC6728C70, + 0xD36F32D0, 0xBBEA0ECA, 0xD055ED76, 0x9135E317, 0x8A7B9770, + 0x4D1344B0, 0xE9F29AE3, 0x7BA303B9, 0x2C38AEC, 0x82ABCBA6, + 0x7729F177, 0x71793932, 0x6FE6E38D, 0x1F8416B, 0x147D8310, + 0x6A962FEC, 0xFE2F100E, 0x4FB1D511, 0x3D38AB33, 0x58ADC416, + 0x64B07504, 0x458CC4B4, 0x584BC93E, 0xDE49B6D1, 0x7347876, + 0x4A2C3EB6, 0xDF5DE09C, 0xBFD376DC, 0xC9F451C5, 0x5F793A0, + 0x892952A2, 0x15060767, 0xE1E3B589, 0x4D513C3F, 0xAF3D2CC7, + 0x289DAA2E, 0x8C711417, 0x62E5E006, 0x3BECED98, 0x99E73ACC, + 0xDE156054, 0x1283655B, 0x5123FC41, 0x3DE21841, 0xC032F050, + 0x94B5151F, 0xA5577757, 0xCC0C8DF, 0xBDB52821, 0xD530FAAD, + 0xD070D8FC, 0x46F5BB68, 0xB02DFF88, 0xD4923EA8, 0xC85A5622, + 0x93E834A3, 0x38E84468, 0x79408C75, 0xCCB635, 0xE76BADA2, + 0xC2296DA1, 0x711543BB, 0xF441F4A2, 0xBD18127C, 0x8385BFB9, + 0xD350D4D, 0x90FAF999, 0xABD1A695, 0xFCEE12C7, 0xF428912A, + 0xC9759F80, 0x6DB6491, 0xD1421D30, 0xBC398DC4, 0xB8E0A889, + 0xC854AA72, 0x82CAAF64, 0xBB6A65BC, 0x6DCB2D0B, 0xD215ADB, + 0xF45033DE, 0xC1300029, 0x665C61DF, 0x756D1875, 0xBD2CF722, + 0xC477E3C7, 0xDDD97C9B, 0x89AE48E4, 0x65000FDC, 0x1FD717CD, + 0xBEEA764A, 0x8FC2DCB7, 0xA162EFB3, 0xD4AC2490, 0xCDA9A72A, + 0xBFB4EE17, 0x66C73CBB, 0x6B7CB021, 0xCC5AF099, 0x5389E8B7, + 0x7668286B, 0x31A223BC, 0xA66475FF, 0x9C3DDA93, 0x2F3171FE, + 0xDB89A7DA, 0x1699616B, 0xA380F010, 0xB05D7388, 0xD774EA44, + 0x64D6091C, 0xF23298F8, 0x71C88081, 0xF90C4A04, 0x2FBEEA4F, + 0x2F9178BB, 0xF8723D8A, 0x1C07FCC8, 0x36D24E08, 0xE02A8B61, + 0xFD6312AE, 0xA7DDCE9B, 0xAE45AC52, 0xCA2EC55C, 0xEEC6BE42, + 0x244F3D79, 0x994FB339, 0x8316CC43, 0xE3CEC898, 0x8D37639, + 0x833D21BB, 0x4333A2F7, 0x95F3B0C0, 0x7258174C, 0xBFCF0EF7, + 0x9A7F4883, 0x71F2406B, 0x16B2BA04, 0xE1BCEA70, 0xE3C6798A, + 0x3FBF481C, 0xF5A8D117, 0xB37ED250, 0x49AB5E0D, 0x2793A7EB, + 0x45DF69A7, 0x4EE4B815, 0x98259530, 0xC223CA40, 0xDB7B208A, + 0x4AD3C0F7, 0xE7C33E50, 0x49FD7631, 0xA228021B, 0x2C27FCB2, + 0x5F77BCF4, 0x65D593D4, 0x7C700797, 0x6E67920A, 0xEABAF033, + 0xBFC8B68B, 0x8835B368, 0x90CACC99, 0x6B90E022, 0xF2466D89, + 0x432DED25, 0xEFC94B45, 0x3116C3E, 0x1BBFBC45, 0x8FBC3D21, + 0xFB2039AA, 0x50679156, 0x450F8837, 0x73C7F87D, 0xC27898A7, + 0x7F48E602, 0x5064FCB3, 0x1EB6F58F, 0xE647C845, 0xBC8E84EC, + 0x5C4B8FFC, 0x440A88B7, 0xA490480E, 0x371DC115, 0xE1F236FE, + 0x4D65A2C5, 0xA965B0B7, 0xD05512FB, 0xDFAB9656, 0x191C627C, + 0x56B7FAC3, 0xF304A2E4, 0xC7ED6DF0, 0xD09B8C49, 0x1A1E777B, + 0xE70746BA, 0xEB582E9C, 0xFA6014DD, 0xB3B67784, 0xD3F64D81, + 0x318872EA, 0x4D241611, 0x134DF119, 0x2EA55DFA, 0x71A8D182, + 0x15AFE856, 0xD5CD885A, 0x5EA2B899, 0xF87BC7FC, 0x25DE8D6, + 0x93837315, 0x341C3698, 0x58534F, 0xF10652DF, 0x18C92AA4, + 0x17E969AB, 0xC12D08D, 0x6B0D0FBD, 0x40ACD3E2, 0x8C3AD43C, + 0xFDE55C9D, 0x25A58094, 0xBBCAB168, 0x2F06ECA1, 0x9D23A101, + 0x6F850449, 0x769C743A, 0xB63FD349, 0x3B3C852F, 0x1EC89061, + 0xFE8C7369, 0xA19C0F73, 0xB682F1D3, 0x48DAE3D4, 0x7F9FD390, + 0xEF784A6E, 0xCB23F15, 0x7BEB1E0E, 0xCBE90203, 0x6979F11D, + 0x251C50A4, 0xDAD9C59F, 0x5E4E5BFD, 0xCCD4DF48, 0x72BD66E, + 0xE7FB1B35, 0x75B4B83B, 0x29E9282A, 0x2590317D, 0x7835F9A1, + 0x25D3602C, 0xCFEC2E4F, 0x9CA2B0E7, 0xA4714302, 0x8F3D53C4, + 0xDE00F109, 0xC26D6273, 0x3E8DC623, 0xE3A972E2, 0xF67DF096, + 0x781682A5, 0x6C16F144, 0x49DC8D17, 0xB2EB82EA, 0x3CB93D91, + 0x44D4D3C4, 0x556040F, 0x1406DD74, 0x55FA83ED, 0x91C35357, + 0xF5A1C63, 0xA64E34D0, 0x7DF58C80, 0x62E97E52, 0xFBA1A2FE, + 0x8CB29D60, 0xDC1AEDE5, 0xB260BBF, 0x1AD9C6A6, 0xC60E9788, + 0xAD9DFA42, 0x2E422C17, 0x51CB5E86, 0xEB840466, 0x2666D5D8, + 0x7A0F7C62, 0xDE052A31, 0x6F0330C4, 0x9142D4AD, 0xDC8578C9, + 0x978F3E76, 0xEE43CB4D, 0x14E7EFC7, 0xB50B064B, 0xD7FB2900, + 0x67C4F4A3, 0x4D1193D7, 0x5091FB73, 0x3EB9C846, 0x960BE069, + 0x88250E7E, 0x94503385, 0x1C1F244A, 0xCFD72CE3, 0x8CD5F105, + 0x2B34131F, 0x60D266E2, 0x16BA806A, 0x25C25A42, 0x5FF6C068, + 0xD23A191F, 0x7AB5C53D, 0x9EA37FBB, 0xD1AD4B07, 0x40BCB39C, + 0xF45C8526, 0x80FEF5BF, 0x197D6D43, 0xD56FD4D0, 0xF39E498B, + 0xFB4F6847, 0x84DF289A, 0x2246F5CF, 0xF979B823, 0x42DCD843, + 0x1AB1BB0C, 0xABEC5FCE, 0x6E7EBC1, 0xE013DB54, 0x73BC8A04, + 0x88D0F71E, 0x4D93B6D8, 0x57B0B7CF, 0x99371728, 0x86B129E9, + 0xF4EB3DD2, 0x6956AA9D, 0x4C84AA0, 0xFD22CA10, 0x36E6915F, + 0xC830D7EA, 0x1EE1666, 0x1036A43F, 0x3FC86E7C, 0xF10F9CD2, + 0xEFF5F21B, 0xBF9082E0, 0xDD0DD00C, 0x80524F27, 0xDD5A3222, + 0xEA53B93F, 0x7FDA09AC, 0x89840C97, 0xC3A9BDCF, 0x1EC26899, + 0xEBCAF99C, 0x2EBB3226, 0x936A3254, 0x2E1E1786, 0x57E4CB9C, + 0xE5CDBE5, 0xFBA2458C, 0x48F3D0EF, 0x74FD06AB, 0x96C30795, + 0x14FEF0E9, 0x2F5FBA0C, 0x3CCEA60E, 0x7BA0354A, 0xCD7329FF, + 0xD4169550, 0x5FAA5E66, 0xF0C25CA2, 0xEBCC8065, 0x3F147D8F, + 0x5ED3293E, 0x6457117D, 0xE4CF4B98, 0x11F1E74E, 0xC13F47EC, + 0xBC7E22DC, 0x22512D19, 0x9140ACBB, 0x490D52F, 0x3E2D54C2, + 0x9FCBBC1B, 0x89646A33, 0x9FE4B65F, 0x92CE9ECC, 0xFBD59FB9, + 0xCE95DAD1, 0xBBCDE794, 0x9C0FA1C6, 0xCFD90F8B, 0x494C1770, + 0x21AD2AAE, 0x58EC00A6, 0xB0848A25, 0xEC4FEB5E, 0xFF1517EC, + 0x52871C07, 0x105E05B0, 0x178B1913, 0x18023805, 0xB16BBC6B, + 0xF8522A7F, 0xB17DEC22, 0x3808ACAC, 0xBC5B9043, 0xBEC01BA4, + 0xBC6CDA0B, 0x17906D50, 0x8422829F, 0x51C9AFB9, 0x54F78CEF, + 0x72CEEA16, 0x76A74B94, 0x7EC063E2, 0x51C65B1D, 0xD97ED9B8, + 0xDE89F034, 0xB5AEEFA0, 0xB88D3E9D, 0x9D4C57AE, 0xC8CEA9C1, + 0x941A74D3, 0x8E2FC33, 0xEDCEB551, 0xB91FA3E4, 0x8BA2261F, + 0xE558E0F2, 0xA4E81979, 0xAAE31455, 0x70B62249, 0xD48D1A67, + 0x11767EB6, 0x823DFECA, 0xC815C538, 0x2AB67EE6, 0x22FA86BA, + 0xD7A1F96C, 0xBA96E382, 0xB75B3FB7, 0xCB705FAF, 0xD1B9D3E2, + 0xD4C8DC2F, 0xF954B0A5, 0xDABE493B, 0xCA3FBB37, 0xBBDC387C, + 0xA30C87D6, 0xB5B493D5, 0x584F5615, 0x90FB6370, 0x5544A92D, + 0x980F7FA2, 0xF1459235, 0x130B11BD, 0xC7A44998, 0xFEBCA776, + 0x7943BE84, 0x72C99B04, 0x353F6042, 0x66F5C2F2, 0x9C5B2CC5, + 0x9FF06E41, 0xAC9E5492, 0xFF9A1CC8, 0x4429DE05, 0x97845307, + 0xDBA36668, 0x40BEBB2F, 0x606DBA6A, 0xDE7A4225, 0x9AF7FB71, + 0xE97A0E6C, 0x99C2AA59, 0xE00C525B, 0x5D4F9521, 0x89C5D7BB, + 0x18481C9F, 0xA27A1F59, 0x2A6267A3, 0xC467981A, 0xE04CE94D, + 0xAAB2AC1D, 0x5FD1AC86, 0x8F33E395, 0xE1FBE285, 0x636C2961, + 0xD838584E, 0x2F845D90, 0xAD52A8ED, 0x8F8C841B, 0x829A3861, + 0xAA0FF413, 0xA079F240, 0xB15D507B, 0x93722B10, 0x833AF929, + 0x4FB5B879, 0xEDD3031D, 0xE22CE740, 0x9ADF835A, 0x13A0C7A3, + 0xD5791B98, 0x99D9409F, 0x9F776A0E, 0x8665EC9F, 0x7301EF7C, + 0x9B341035, 0x59EADE7F, 0x242C1ECA, 0x20FD13FD, 0xE22DAF76, + 0x3859E84D, 0x6ED83DA, 0x54ABF391, 0xC43F4740, 0x4661F86, + 0xC6442213, 0x7FEAF294, 0xC0CAC024, 0x38B9FA9C, 0xFFF33259, + 0x1AD86335, 0xB365445F, 0x54B58378, 0xFD7AE96A, 0xE019B245, + 0xCF51C4EC, 0x604D7EE, 0x7B40C023, 0xA5E168B0, 0xD7B8C643, + 0x91C028D3, 0xCB939A6B, 0x169B0123, 0x96FF8CFA, 0xFCB3E126, + 0xB95C01B1, 0x1758BFB6, 0x50F50968, 0xF774D536, 0xC5A8BFE7, + 0xE2496BE, 0x6FB8D434, 0x3F7FEDB9, 0x9BDEE991, 0x1CBD2009, + 0x2CE74DB4, 0x1CB51025, 0xE965ECE6, 0x89100034, 0xA089E8C0, + 0x5860A65B, 0x9C4D349E, 0x54898852, 0xD07C9738, 0xBC677E89, + 0x75B5D0C1, 0xCFD435AF, 0xED550357, 0xAED9301, 0xDCD1734A, + 0xEDCD21D7, 0x69F6A592, 0xEF8009F7, 0x44374358, 0x9405770D, + 0x668AC4FA, 0x50507E61, 0x2DB19DDC, 0xA9BDD137, 0xFB722699, + 0xBC067E88, 0x88740174, 0x717CCEDC, 0x9F7F1E11, 0x389F4CC, + 0xCF4D0018, 0x24588FF1, 0x25C9F951, 0xDA660468, 0x6C09D91C, + 0xC9F788E, 0xDD4DF43F, 0x8B04484A, 0xC7F67DDB, 0xD2939F8B, + 0x96BCFDE5, 0xF6DD10D8, 0x1124A3BC, 0x7C281FBB, 0x5FAFA71B, + 0x58A9C493, 0x4747793C, 0xD3B79E72, 0x357AA675, 0x8E94A74B, + 0x1994025, 0x95D10FB8, 0x5C64AE63, 0x9E37973F, 0xFCE67009, + 0x8480F94E, 0x34DA26F7, 0x126CFB46, 0x206AAA6B, 0xBA0A6200, + 0x8DF3F67F, 0x4936802F, 0x950F62F8, 0x17E64C44, 0xC70E523E, + 0x2F910727, 0xAF7C5BC, 0x9EA24508, 0x1E945729, 0x55E48FBD, + 0x897CB57, 0x8C134FEB, 0x54E68223, 0x91912044, 0x7A461BDB, + 0xCE91309, 0x72135AF, 0xBF94D484, 0xDD752690, 0x32248D12, + 0xEA092355, 0xC24CA220, 0xE8A95D65, 0xE4E2EAE6, 0x664763E9, + 0x71F1AA47, 0x832550FF, 0xFFA73B6B, 0x96F5DFF6, 0x60CB9B66, + 0x75F29F5C, 0xF863AC8F, 0xF16993FC, 0x3503801C, 0x3D1E8B2, + 0x583CDFF6, 0x62AD49F2, 0x8261843F, 0x826EA9B6, 0x5E2EF3, + 0x8D3848EC, 0x7391A581, 0xDFC466FB, 0xB38DCBD1, 0x4145C3C0, + 0x73F322D7, 0x2B55F284, 0x6B19FBA6, 0xD9446AD1, 0x36C330C5, + 0xB71E4B29, 0xF29F504E, 0xB4FA4CFB, 0x290B6941, 0xA2197E21, + 0xF2AAE27F, 0x1A1728B5, 0xAFF5632, 0x6AEE763B, 0x2962A376, + 0x965D67E7, 0x231A8B76, 0xBD3596FC, 0xD4AE3E8D, 0x58D4D740, + 0x4EA3B6DC, 0x5479A7F5, 0x110A4791, 0x9A772A63, 0x728C4794, + 0x6D6A0801, 0x3F89D9E1, 0x326D1BC4, 0x49B3798, 0x5E2B3CA8, + 0x742C385A, 0x89450FE0, 0x24236A74, 0x81AC9891, 0x7BEF3C66, + 0xACECD674, 0x29009073, 0x94D6BDBF, 0xF2C6CDF4, 0xDBC21EE3, + 0xC65C89A4, 0x35DC5337, 0xBA281430, 0x787521B0, 0xADF8317E, + 0xD5739B77, 0x8567F3A2, 0x374E0CAC, 0x5AFFF50F, 0x9654D41, + 0x4A86EDEF, 0xE16C9A62, 0x59D15E49, 0xA69769C8, 0xA9197100, + 0x1E04CB9F, 0xA926CCB8, 0x5047C429, 0xB7E369C, 0x812F5F0A, + 0xA53EA5BA, 0x9AE5C105, 0xD4C7CC5D, 0xC99E02F9, 0x5BCDFE96, + 0xCDBAA854, 0xCF209B89, 0xBE08E9B, 0x5C73AED2, 0xBD959602, + 0x63C309AB, 0xEE289A4, 0xEDA954C9, 0x5C54F616, 0x3BC34487, + 0x47A3C772, 0xAB0084A4, 0x2CFB8D44, 0xF5F8411D, 0x43F6361D, + 0x12B8467F, 0xCDC437A5, 0xAC96A375, 0x7962CD18, 0x5D728EF4, + 0x66B11DEF, 0x73C87A6, 0xA35AEF9A, 0xC84F12F7, 0xB1EDE9B4, + 0x2F6A1752, 0xCF8DA321, 0x2E37F4E0, 0x4985F516, 0x684E49AF, + 0x56287772, 0xF74F95EF, 0xD994FF05, 0xC1D23E99, 0x81214F78, + 0xA5DF2934, 0xC2B686DB, 0xABC54017, 0x6918D067, 0x737A798C, + 0x3904B21C, 0xD4CB6EFF, 0xC256E4F8, 0x38B0CD4D, 0xE2D27089, + 0x75A00DC2, 0xDC1D5E7B, 0xE2295307, 0x2F0A683C, 0xD00AF450, + 0xE45C3252, 0xD86804C8, 0xF9628DB9, 0xEA011DB9, 0x6A67523A, + 0x488B54B3, 0xA292CDEA, 0xB1D1D89A, 0x17415325, 0x3EAD3D80, + 0x5D092525, 0xB5880E29, 0x1104A8AF, 0xBC177790, 0xEC730159, + 0x11B0A1AD, 0xB809FD7C, 0xB23FE31, 0xCCBED7C8, 0x45B7F7BF, + 0x9491B0EB, 0x1B1A90F9, 0xE34F4317, 0xF060A5B3, 0xF795EF1, + 0x8254A941, 0xC6CC30E4, 0x770FC40C, 0x17EC9C1F, 0x20DA83EF, + 0xF9CCBFC9, 0x9D0675AD, 0xACEA7EB3, 0x56326F5C, 0x74D4DF3A, + 0xA8FF9A9, 0x8F55E3E2, 0x5B0D12F1, 0x12DDB28C, 0x95FADBED, + 0x81F48694, 0xABEE8392, 0x90E96B15, 0x2C44972E, 0x4E2D3A4F, + 0xE8D34D14, 0x83C03E59, 0xDC295E2E, 0xDDEA452F, 0xC2A2A33F, + 0x617210DE, 0x69542DB0, 0x1DD96D24, 0x3E3871D0, 0x9DDDAF6C, + 0xBD326CD5, 0xD87CE143, 0xF3C79B3A, 0x7F811CCD, 0xDE1B1502, + 0x8075EA04, 0x9D09F1DC, 0x8CCBD152, 0x669F35C, 0xC9414276, + 0xA2BFFE0E, 0xF8AAE650, 0x190C1AE7, 0x2DBB4A7D, 0x575B247D, + 0x3A599D3E, 0xB09B4DFC, 0xCE4904A0, 0x63C72670, 0x15A3BD05, + 0x799B50CD, 0x19A2718C, 0x4142750D, 0x9013BE74, 0x21288938, + 0x590BD2BB, 0xE4303149, 0x46B308C0, 0xD2BB7D56, 0x1BFB248, + 0x943B2E72, 0xCAB18644, 0xFCC921C4, 0x5308C4D9, 0x9098CEE2, + 0x435B219F, 0x69F1BBE5, 0x155216D4, 0x83F2A4A5, 0xE177744D, + 0x37DF6FDE, 0x9D9EA50A, 0xDFA8D408, 0x6C72E71E, 0xEA617E3E, + 0xDAD6C13B, 0xB83A850D, 0x45F6BEB5, 0x6AFB346D, 0x400B29FB, + 0xBC8E57DE, 0xC6C1081A, 0x4F6A9545, 0xF878303F, 0xB9E519DC, + 0xCCF25FBA, 0xCAE069A5, 0xB79B082E, 0xF70BB7E7, 0xE6A5535C, + 0xB769EA37, 0xE07CCBCE, 0xA9F04406, 0xBB7E5A7A, 0x10C986, + 0x5EB448A0, 0x3B154163, 0xCB832FD3, 0x50100140, 0x6963216B, + 0xEF480040, 0x75B83F45, 0x4A07D8C5, 0xEFDF39B2, 0xDB139034, + 0x5BE9C8C9, 0x1915F818, 0x852ACD9, 0x58BFF825, 0x64AF5C20, + 0x1F13AFAA, 0x8A5A1E9D, 0x57870533, 0x98A418CB, 0xCEBDAD9D, + 0xFA54CB95, 0x707D0BBA, 0x26EE1F10, 0x428CAAC6, 0x33AC77D0, + 0x6879957E, 0x522DCDE5, 0xE29E9579, 0x4AB0C59C, 0xB5FA1395, + 0x4C0BA116, 0x297A0F00, 0x440CD4CD, 0x63BCFEC0, 0xAC14638B, + 0x3C7DF738, 0xC213D3AE, 0x5CA0779D, 0xB49A3458, 0x678D95A9, + 0x281735D2, 0x1911DA83, 0x3A5EA479, 0x2C1090F6, 0x40C0D5E7, + 0x33AD6433, 0x49B076BB, 0xA1C1D333, 0x80474C82, 0xC62FE221, + 0x87F4E57A, 0x4C5C1506, 0xAD5E1E10, 0xE435A8C6, 0x96D7E0E8, + 0x53E54D01, 0x7EECEA8B, 0x699C41E0, 0x181C6479, 0xAE6E687E, + 0x2FD27BB7, 0xDF60DD39, 0xC38A3AC, 0x5AC51EC3, 0x8F1205E1, + 0xBD71109C, 0xCB2CCA62, 0x236D9D16, 0x45ACA6BD, 0xB33BDCE1, + 0xE1D9134F, 0x410F24FB, 0x3BF34DF6, 0xB799F963, 0x1B2D4C07, + 0x8D92C15, 0x9CA0073, 0x76772A47, 0xFBB63B16, 0x78F3C3B7, + 0xF118B4A6, 0x8E86A34A, 0x56693D7E, 0x381EA186, 0xCB9B430D, + 0xAD11DC36, 0x599B3370, 0x7A6B80C0, 0xF2A282DC, 0xF58F96FF, + 0x97AADB3A, 0x5AA06FD, 0x44A43553, 0xBE8097C6, 0x4CF5002D, + 0xBADE20DD, 0xFEC25B7, 0xC8B50C4E, 0xF0C899D4, 0x815F9958, + 0x77772B46, 0x7413F82A, 0x7203A939, 0xF4623F73, 0x35EE625C, + 0x2723BC68, 0x33790B09, 0xA58391E4, 0xA27C7C25, 0xBC032556, + 0x1D812AD4, 0x301BB65D, 0x22FAF223, 0xDCBB79DE, 0x78CE1CBF, + 0x570C796B, 0x17EF8909, 0x8E2C32E5, 0xB54FF82F, 0x7702F70, + 0x1C0A78C2, 0xCB3078DF, 0x7155531A, 0xEAC77450, 0xB9DC2EDF, + 0xA8B6A1A6, 0x57FC52F0, 0x6B5543E4, 0x40679BEA, 0xE46813E7, + 0x65525695, 0x6C9CD43C, 0x5E5BD786, 0x44212626, 0x847A8357, + 0x7E39813D, 0x9FE22F0E, 0x29EC985A, 0xC91CF47C, 0xB31A26AC, + 0xA4C8B43C, 0x8EAB7865, 0xF6F2F67E, 0x3F73A8DC, 0x4FAF5455, + 0xE1253CAD, 0x3001A083, 0x532DEAE4, 0x6A110DF6, 0x585D0FDE, + 0x19071CC0, 0x1A351A69, 0x2FEAD890, 0x33902499, 0xA218C193, + 0x2294A970, 0xB0544EA1, 0xC54B25F0, 0x6C89048C, 0xC8203390, + 0x237F30DA, 0xE8F10E5F, 0x6B57E331, 0x43744B6E, 0x2EEF4BB4, + 0xEBD13AA, 0xA9024B04, 0x22895C31, 0x321C459A, 0xFCEFD3EE, + 0x94772392, 0xA094B3F3, 0xC070FBB2, 0xF30ADCDF, 0x8D294C6E, + 0x89E4C299, 0x47DE058E, 0x841A807E, 0xDEA7608F, 0x3A45D7AE, + 0xFE08A063, 0xF2C65E08, 0x4C653ADB, 0x8E4BED1C, 0xC85C1323, + 0x63DF1750, 0x4EF4B72F, 0x209903A9, 0x3ECCC1C6, 0x4283795A, + 0x205AC943, 0x38B1ABE3, 0x1241AC5D, 0x7C645871, 0x747695BB, + 0x29206570, 0x31BACE6E, 0xFDEEDAC9, 0x4DEFF536, 0xCD6CFDC0, + 0xEB0FAB42, 0x7DFA5EB6, 0x8363D9BA, 0xCFCD2514, 0x69FEB823, + 0x10BDBDCD, 0xE4C27020, 0x56DCF966, 0x9C97BD95, 0xCDAB9269, + 0x8316F55E, 0xC62F7354, 0x5415281A, 0x31EBDCED, 0xCDF7A05D, + 0x5F674F71, 0xF70EE58B, 0x26037964, 0x584174B4, 0xFEA5520C, + 0xD01A8007, 0x7F2772E8, 0xC2FF1456, 0x7B2CA1FB, 0xE938BBD0, + 0xD96CCCF2, 0x9AE8088B, 0xF3A25E6B, 0x3780417E, 0xB9E2917D, + 0x95872990, 0x12D99C68, 0x2FC5DDB0, 0x55437D2B, 0xDB9C14B7, + 0x6BBE6AF9, 0xFBDC9201, 0xDCB32A70, 0x1CABF45D, 0xD8BCBF4F, + 0x271AE6A5, 0xD34B8953, 0x58BBFB3A, 0x537F049A, 0x55B51226, + 0xCD809DC9, 0x846DB4EB, 0xED476D72, 0xEFC8F8AF, 0x6AA3228D, + 0xA363F656, 0x2207127, 0xA1BBE245, 0x2AB58A00, 0x637810C9, + 0x91F61AD, 0x347D333B, 0x1E9598E3, 0x2E7BD8C6, 0x8DCE469F, + 0x73B82620, 0x9257D4E0, 0xD9580F88, 0xE8EF6D53, 0x2D9FAC45, + 0xB56E2C6, 0x9B369045, 0xB50702C6, 0x955D3700, 0x577CC21E, + 0xED02FCBA, 0x73320B99, 0xB55DE16B, 0x7F578129, 0x3F6FD052, + 0xF211A764, 0x9B7F9204, 0xC61EDC01, 0x1363AA4F, 0xEFAF1CF2, + 0xE5AF97EC, 0xEEAD4FB7, 0xF41B649, 0x373087FB, 0xE81355EB, + 0xE04FF410, 0xFD04F4F7, 0xFA269CEE, 0xBE8D7535, 0x5FC007DE, + 0xCF085F76, 0x94D7201F, 0xAF49F41D, 0x8D6E7F, 0x9D63B6ED, + 0x9A2A0877, 0xF06123D9, 0x6624C891, 0x508266E4, 0x6921EAA4, + 0xD6E69A49, 0xCDA0F920, 0xA5870B5E, 0x1A93A2CF, 0xE3A030C6, + 0x6EC03FE5, 0x37FDBDF6, 0xBEFD0BFF, 0x3D3CBD0E, 0x2DDBFD7D, + 0x8B58AE2B, 0xCAD61AF3, 0x624F4677, 0xC402CF5E, 0x431D2CC1, + 0x5C205AE5, 0xFC3B8ED4, 0x501C36DA, 0xBC9217E5, 0x6752573D, + 0x3BE702E, 0x8E06CF12, 0x81494C86, 0xB2DC2F63, 0x792EC845, + 0xC6BDEDB5, 0xB255BA4B, 0x6C66C28D, 0xD1A16904, 0x93ABFF21, + 0x94827FC4, 0x87825689, 0x314D1F33, 0xC0D8B98A, 0xC84AC57D, + 0xEBDB0F92, 0xBA4F473B, 0x61130498, 0xA534064B, 0x3DC04FBD, + 0xD0A701F2, 0xA671765D, 0x17464B7E, 0x4CCCB84, 0xC297BAED, + 0xAAF8C84A, 0x631313F, 0x8E0FD926, 0x1699F616, 0xD9808C9D, + 0x55BF5BC2, 0x27FD10B0, 0xAE975927, 0x92B3F52F, 0x9025C6B3, + 0x95E5E313, 0x4CB83334, 0xE4A1E7B8, 0x74F7D3D5, 0xDDDC42B9, + 0x5A89BEF1, 0xF66A6AE5, 0x33730C23, 0xEB7F079E, 0x742FEF19, + 0x2C68CAC5, 0x2410679F, 0x9D1632DA, 0x458F4AAD, 0x8889E6AE, + 0xA3B48216, 0xC9AF4AEC, 0xA506C8F6, 0xB6AF9E59, 0xC6340436, + 0xA6B294E, 0xF35CF92B, 0xEB3A4113, 0x98070AD1, 0x9E61E01E, + 0x58C2893A, 0xCC1F8C34, 0xCAD665A0, 0xD0414D39, 0x643BDCD8, + 0x8AF801AD, 0x9ADBB106, 0x2BD02351, 0x8F890436, 0x546747D0, + 0x6DC33C48, 0x95FA7FD6, 0x5F12C5A5, 0x5DF2761D, 0x9A9B2F8A, + 0x8C61276B, 0xACCC7F4, 0x37A5829D, 0xF1A0F1, 0xAAED57E0, + 0x180CD2A3, 0xDC393CA7, 0x504E7405, 0x89DE2F7, 0xA4D8C4EA, + 0xD8BECE01, 0xD664017C, 0xF57FA30, 0x6049928D, 0x9832E166, + 0x176AAC31, 0xA793F88A, 0xCFFA8B54, 0xA30DF1EF, 0x3B6C7611, + 0xDEFC961, 0x9BFB79F1, 0x1483D430, 0xC3A77C0C, 0x42AC1FA0, + 0xFA3605B6, 0x9A2EBDF0, 0x684D414E, 0xD9308E10, 0x64D68C19, + 0xA8A9B67B, 0xF5E7B9D4, 0xC7B70ACE, 0xA6EB6DB8, 0x8A22FBE2, + 0x3AFFDDA1, 0xFB61F7D5, 0xE057717B, 0x846D96CB, 0x20A4B400, + 0x574089BB, 0x9F3D2DBD, 0xEEDDDB4B, 0x5E64EA6B, 0x6781DC90, + 0xCFD86A6, 0xA92441CD, 0xAC5DCCD6, 0xE6BB5582, 0x32FA6B3F, + 0x3ABB8A64, 0xA49D2003, 0xA965E430, 0xEC4053BB, 0x95859D40, + 0x2672832, 0xCAC3E608, 0xF8C13A53, 0xB04EC2A3, 0x87F54941, + 0x62A3A924, 0xE0B48702, 0xE8700446, 0x95BD4B11, 0xCFCFDF9A, + 0x19F67E7D, 0x60853AC6, 0x468F963, 0x298066B9, 0xEE53E89A, + 0xFC63E607, 0x6FA101E5, 0x8B2F1F84, 0x24AE7C1C, 0x385008FF, + 0x96E75EB6, 0xF1175277, 0xE5B4A577, 0xB0C97AC, 0xC21CC45A, + 0x5C680DF8, 0xDEB046DC, 0x1487FC03, 0x1D90CE3C, 0x712563BF, + 0x65A26CD9, 0x4D094F62, 0xB5DFE29C, 0xF58B2A62, 0x9420A9DC, + 0xCEC7537F, 0xC46D1FCA, 0xAD5D7B10, 0x68777A24, 0x6C096D2, + 0xD787D72, 0xC7743F50, 0xB3D05F4D, 0x53E0A7E3, 0x9E627C6D, + 0x1AA0959F, 0xD1E00E47, 0x8874BA26, 0xCEAC0958, 0x10F67BBD, + 0x712C6597, 0x3478BD73, 0x4D6F116, 0xD30BC24B, 0xB98C565A, + 0xD7C5B116, 0xA8CDAC4F, 0x4144673, 0x848F37E3, 0xADD946EE, + 0x6F17EAE3, 0xEA0FA265, 0x41DB99E0, 0x6BCFDA5A, 0xB46ECED5, + 0xAF67610E, 0xC7E9DF2C, 0x5CC6F0C6, 0xAB2C2BA, 0x6BCC3881, + 0xE482C243, 0xD8053417, 0xFFDB6E41, 0xF13EEB84, 0xE8292661, + 0xEB9940A6, 0xF0B45F98, 0x1CA82AF4, 0xCCA7771D, 0xDD5F3CFE, + 0x58BD8E91, 0xDF9E3342, 0xA1003957, 0x4621AF52, 0xF926F465, + 0x209925AD, 0xB1C72F09, 0x3FAB8ED, 0xA15C0A17, 0xDBE73D2C, + 0xF917CE51, 0xED047661, 0x7361B752, 0x1AAA57A8, 0x31445667, + 0xFEC0FD81, 0xE3073574, 0x7D36F720, 0xF418181A, 0x1CB8758E, + 0x8E85AFBA, 0x407E9AD9, 0xF724E308, 0xD030D3ED, 0x4610418E, + 0xE799EA4D, 0xF8B68F92, 0xB84B9ACD, 0x4B8168C0, 0x9888977, + 0x216F3B3E, 0x5C49C1DB, 0x759E718D, 0x7C4309FF, 0xBF6DEE2C, + 0xE566F231, 0x774B0A7A, 0xBE55CCFF, 0x3081B8CD, 0x2284369E, + 0x2FDF7473, 0x3AF68AC7, 0x6047E9B8, 0x3743BA0E, 0x691D261, + 0xADC440E1, 0x24150207, 0xFBFE466C, 0xF767E860, 0x8157332E, + 0xFB54D774, 0x1AF34C22, 0x74E05695, 0x2101FD57, 0x2904274C, + 0xA1294E9A, 0xF43CA18F, 0x4FA79EB5, 0xAFD1C9EE, 0x6EB3953F, + 0xDDFCB3AA, 0xDB48F7BA, 0xE1742183, 0x8A78CEBD, 0x225CD669, + 0xD76B771A, 0x3520113, 0x428B2892, 0x3A5CE8DD, 0xAB4AC42C, + 0x2928BE8D, 0xC34E3031, 0x93F0CB9B, 0xB7A6FDB4, 0xEEB2B85E, + 0xC393597B, 0x9D8457EF, 0x91F0F0FA, 0xC54AEA3C, 0xC639521, + 0xB668AFE4, 0xE4CCE3CD, 0x86223A5D, 0x6A51A2EB, 0x4333C505, + 0x3233B8B7, 0x1D01F51E, 0xF0C691A6, 0x699EBC2C, 0x7FEE8DBC, + 0xCC50E42A, 0x7951DB68, 0x8CF01752, 0x33D33841, 0xB46E353A, + 0x700B65B, 0x59ACA844, 0x38631893, 0xC32D0F92, 0x6897EFDD, + 0x3F93BCDD, 0xD50E33C3, 0xD0075F1D, 0xB3CB6096, 0x875896CB, + 0x5DF6651, 0x8E2D197F, 0xCDF68F10, 0xC74018CE, 0x83E6C42A, + 0x994DEA76, 0xF932D8AF, 0x98775C2D, 0xF79CAAE5, 0xF2BEB839, + 0x7318C6DB, 0x3AFD6D85, 0x37F18BDF, 0x10194867, 0xA73B5205, + 0x3F06A1BD, 0xBC8026DF, 0x531CF753, 0xCAFAED74, 0x817C9E70, + 0x32338A3F, 0xA5177C74, 0x9A3C131F, 0x90F9AF0, 0xE9281B62, + 0xEDD87C1E, 0x16577CB0, 0x5E3F7AC3, 0x4E49E1EA, 0x495C1B67, + 0xC282F5FE, 0xF8993B1, 0x47563C68, 0x49FA0716, 0x26A55B80, + 0xDF870F8D, 0xFBB8DDA5, 0x130EA4E3, 0xB0B66F1A, 0xD7B92F0F, + 0x55FD4759, 0x6D11AC86, 0x8AB0B6F8, 0xD8C8C8B0, 0x758DA8A, + 0x9CD589F, 0xB808C0A0, 0xB2C7A3F3, 0xBA40DA44, 0x937532CF, + 0x279CFDB2, 0x545896EA, 0x387A8F38, 0xB2E5F9D0, 0x7566CA0D, + 0x51B45DC4, 0xA93B6EAE, 0x1C22D8D5, 0xEB96BD1D, 0xB8F40750, + 0xCB7DCF85, 0x188F6018, 0x95BA817E, 0xF7C19E4E, 0xAAF97DDA, + 0xE5BD967B, 0x1604352F, 0x3758C3BB, 0xE2FA13D1, 0xE3666F4E, + 0x218059EA, 0x2F4750EA, 0x2F065B46, 0x8FC4F43F, 0x2F45422F, + 0x45928A5E, 0x77055776, 0xBB8103E1, 0x160EFF29, 0xA704F79B, + 0x6655E735, 0x2C19DC79, 0xE407A7CD, 0x9F4AE1F0, 0xBED7DCE5, + 0xA870A304, 0xDC413709, 0x903181E, 0x7C1F6803, 0x44971A01, + 0xF7A81ED1, 0x5DDFB023, 0x2D90CFBB, 0x7F7A432A, 0x35F3F5B0, + 0x7D935FC5, 0x1D99E7BB, 0x8EFC82B0, 0xAB0DEF56, 0x70702FA1, + 0xCF0064DF, 0xDD9DEAA9, 0xF05F927B, 0xB483A6DD, 0x9B7388B8, + 0x2FD82389, 0xAC982F20, 0xC86AD76F, 0x15C6977C, 0xAB10A137, + 0x1433E4A0, 0x2762D44, 0x1CB5399B, 0x310A54D8, 0xD4B8623A, + 0x40FAB5F3, 0xC2D51618, 0xC1F4AF55, 0x17C18E1C, 0x4F37D33F, + 0x2DC9F168, 0xF5BB9754, 0x716FB1F4, 0x7CFB1CE8, 0x1333224D, + 0x344C13B3, 0x7798CB50, 0xB4278C76, 0xD7CC1B03, 0x168B21E5, + 0xF7D77AAB, 0x3B651846, 0x639EB0CD, 0x68EB3E8B, 0xEC82FE45, + 0x622A71DE, 0xAA05B6CB, 0x878B59B1, 0x3E7FB616, 0x1D650408, + 0xF21F8C64, 0x9BF7BF7A, 0xA0874898, 0xFE4E3C6E, 0xFA36122E, + 0x1BCDF4FB, 0xC371B365, 0x8F791BB3, 0x9833AD98, 0xE84887FC, + 0xF8988AB6, 0x180916E2, 0xB587E39C, 0xD5C884C6, 0x27B6BFEB, + 0xD8868D1E, 0x689DA503, 0x936B4EFC, 0xDE0DB3C, 0x7950FDCB, + 0xA61C81C5, 0x9F1C93B2, 0xC983179A, 0x6F847EB0, 0x6F7F899D, + 0xD270412, 0xCC255717, 0x763112A0, 0x8725C96D, 0x48BC2863, + 0x85F13BF0, 0x6D8E0251, 0xB7E66CC3, 0xA4F5829F, 0x8779F381, + 0x16A5E04F, 0x3DF42C14, 0x367F06A3, 0x3BF8666C, 0xC6649CFB, + 0x4DD9808F, 0xB4F9AFD, 0xC2642410, 0x9740E4F6, 0x8FB667BE, + 0x4D4B0D3E, 0xE9B236F7, 0x6E30550C, 0x79DA7B48, 0xE721889D, + 0x79D9B21A, 0xA06B8C2E, 0x997B1696, 0x4383FC27, 0x8B77D293, + 0x6FAE2A9F, 0xB45ED194, 0xF38E2C59, 0xEAA0D05C, 0xA3BC449A, + 0x6EB0BB4B, 0x6B242CFF, 0x7FCA0B8A, 0x47221D33, 0x4E18FE39, + 0xF4691580, 0x6D03D791, 0x3B937AC5, 0x9CB761C3, 0x42812232, + 0xFB987D6C, 0x86AD164E, 0x5D8CED49, 0x22D6D058, 0x42FADF98, + 0x9363A1B3, 0x83C6DB74, 0x7AF44F4E, 0x20086D60, 0x7A37665E, + 0xC4A29C82, 0x330F278B, 0x8750B539, 0xDD2E83D0, 0xB8E002B1, + 0xF2A9323F, 0x91B60885, 0xDE83F01D, 0xACA126, 0x2F0FADA2, + 0xC0E879A6, 0x7C715655, 0x16642BA2, 0x43B9C083, 0x95F6789D, + 0xE6576886, 0x46BEF133, 0x84199FC3, 0xC45BA082, 0x26489AC1, + 0xA4FE268A, 0x633A25B0, 0x4FCD341D, 0x8E7374B3, 0x7F8A3466, + 0xC82B53F7, 0x2E2114DC, 0x59213BE7, 0xE72A2395, 0xAC5F982B, + 0x8F63E9D8, 0xA68BA42E, 0xF0E30E92, 0x580FD13A, 0xB2FCB7EA, + 0xF3E4C077, 0x2C8588B, 0xC31F5E5, 0x104982D9, 0x2C2F03E3, + 0x8F1791C, 0xCE14310F, 0x1696133B, 0x1BC68D6D, 0xFC488B95, + 0xE0E7FC31, 0xBDF0152B, 0x24F78B82, 0x45BD4367, 0xC89AF4B9, + 0x9698650F, 0xFB2E131A, 0x82B7A451, 0x9F6990FE, 0xB6EDE6BB, + 0x68D5D90, 0x51FE559E, 0x9B54ECE, 0xC09D3AB2, 0xD9BA990B, + 0x4CF02BC, 0x70067D7, 0x3568DF20, 0xFF1D7AE4, 0xF1C67DE3, + 0x5ACC7F95, 0x89ED16EB, 0x6EDCDC94, 0xDF367991, 0xF1D48A79, + 0x21AA30FB, 0xADA2B5B3, 0xC40A5761, 0x5769556B, 0x5E1510A2, + 0x5741566A, 0x25B88D83, 0xFD22574E, 0x6E9B2CD2, 0xF5CE960B, + 0x67F938EF, 0x1A1E3672, 0xFBCE5BDB, 0x756BACAB, 0x2F177A71, + 0x31F3EFC6, 0xB8263FBA, 0x9A1F772A, 0x84DC1FB0, 0xC907ED89, + 0xAD3C6092, 0xC225B6C8, 0x37EE4F54, 0x4BDDACF2, 0xB5E944CB, + 0xDC26F39E, 0x3BCE02DC, 0xC01F2632, 0x89AFE3ED, 0x600757F7, + 0x4804A684, 0xC4F3FCB8, 0xEBCAA904, 0xE0069A2E, 0xA2FBD213, + 0xDB736C4, 0xA6930699, 0x71FB43C0, 0xF66C955C, 0xFBD39B5, + 0xC87D1801, 0xE9D2DD1A, 0x78DA23CE, 0xCADBA5C9, 0x77015761, + 0xF5581BDF, 0xDEB4DAA0, 0xAF7E41B0, 0x71347196, 0xF8A29A93, + 0x8DA3BAE6, 0x73396AAD, 0xD4DF7765, 0x326AFF23, 0x27888A0C, + 0xE48AC062, 0xB9F18047, 0xDE9830DA, 0x8EF78C4D, 0xFBC1896E, + 0x9BB566A6, 0xB640ED13, 0x8B0D9D1E, 0xD84B471D, 0x4040EFB4, + 0xF6DF7908, 0xCB8ACF04, 0x253494DD, 0xA85F6D88, 0x1326822, + 0x61EFDFB8, 0x1C78154F, 0xB13866B1, 0x3ABE5DBB, 0xBB5907BF, + 0xA1A57FDF, 0x410549C8, 0xA9A364F4, 0x2A371B73, 0x24AC7296, + 0xA01C035C, 0xE839029C, 0x6E12051E, 0xE6A549FD, 0x345F10FF, + 0x3BB57347, 0xBDBF3A6A, 0x2A41C3C8, 0x6E0232B0, 0xAE66D42E, + 0x3BE90433, 0xE185FBF2, 0x9BCA91FE, 0xF4FFB74E, 0x142B6971, + 0xA75CD7B, 0x9B900DDD, 0xEC56B79, 0x2FE0CD8D, 0x87BE8237, + 0xB38A7226, 0xB5D8B437, 0xAAADC41D, 0x8014E227, 0x38D84DD1, + 0xEDF5294F, 0x862F0F, 0xD69F77F6, 0x409C3B68, 0x2F12B0FC, + 0x32A670B9, 0x5746EE2, 0x96B4901A, 0x57208639, 0xA282A77D, + 0xE9D9F48E, 0x651ADDA6, 0xFF5E974C, 0x37C833C, 0x41F2BD58, + 0xDFE1D009, 0x32222DA6, 0x22201781, 0x64A06BAF, 0x8F188902, + 0xA9C2A07B, 0x617C7DF7, 0x842DA704, 0x40AFDB72, 0x49625110, + 0x72484F13, 0x7340AC89, 0x6C6A2F36, 0x828EF5F9, 0x20344923, + 0x21D3304F, 0xD6EEB7C3, 0x8F99732F, 0xEBA045D5, 0x5C0065D4, + 0xEEB5E899, 0x1B079C47, 0x6198EE3B, 0x946A805F, 0x7C19F966, + 0x75E8F043, 0xFD9880BE, 0x47BF619, 0x9C001ADB, 0x7438184B, + 0xA3787EF2, 0xA461EF4E, 0xEB515D0E, 0x64EFA69D, 0xD41F3145, + 0xD08A900B, 0x495968AC, 0x746639C9, 0x43E85DCB, 0x62E55B3, + 0x6B913D8E, 0x2685D73B, 0xE4F98C19, 0xB404BD4B, 0xFEA327C5, + 0x1E0CC908, 0x71BC53EA, 0x530AAECB, 0xBD2977B, 0xB661A52, + 0x86560EE2, 0x250E2591, 0xDA57D5B3, 0x347D3C22, 0x6CE15221, + 0x6E5288EB, 0xA79875F3, 0xCA89972F, 0x36E93777, 0x257262E1, + 0xD1D4E5A4, 0xF7ED5D52, 0xECE58036, 0x644ACA69, 0xCA36DFB8, + 0x60EAB44D, 0x46FB8AB3, 0x81E6C199, 0xD5AA5C63, 0x4A7CB01D, + 0xFCC109CD, 0xD999C46B, 0x3FA4C688, 0xC95C0FBE, 0xA1E9DD3, + 0xBE9EAEF6, 0x1A3014D7, 0x729A662, 0xDC8178FD, 0x7FCAA1EF, + 0xD4005420, 0x2A904DAD, 0xEE7E52DB, 0x886C0F23, 0x12D49E10, + 0x2B3F3B39, 0x3373A6C6, 0x5D0759F5, 0x8CF5EF25, 0xCE02371C, + 0x2FFEEFDE, 0x5D9CFD69, 0x2B5BB7D0, 0x5A378EA9, 0x5BED8331, + 0x9C1A37CA, 0x702799F, 0x4D37A8EB, 0x370CEDF8, 0x43B95BE0, + 0xA0C1E534, 0x204130B2, 0x8E4995AC, 0xCF1C3C28, 0x3E901F78, + 0xB0F43C57, 0xED4B7492, 0xABD3C5CD, 0xEA95ABC4, 0xE03B739A, + 0x58388E80, 0xFDF22044, 0xF4379C7E, 0x87CFA0C, 0xAE9CA79E, + 0x41DCB004, 0x8F69512D, 0x73ED4756, 0xE215297A, 0xD931A6AD, + 0x59866B3D, 0x61825B1D, 0x4F5099E1, 0x25AE168B, 0x1272D5C6, + 0xBE071035, 0x24314F71, 0x82F4B23F, 0x6C7F3385, 0x36CF0505, + 0xB71C0E3D, 0xE9F881D0, 0x27F0C290, 0xF4BE30D7, 0x88315CE8, + 0x9E04FD20, 0xDE197591, 0xCF0D2FF4, 0x67A4C473, 0x158447BF, + 0xA4B37C88, 0x27918292, 0x5FDE3DF0, 0xE8A93C3D, 0x886287E8, + 0x746E199B, 0x9A894103, 0x7A529374, 0xA195E2AF, 0xAA3EB0C6, + 0xF70788A9, 0xCE2B7F30, 0x9C4724AA, 0x902EB7A8, 0x2CBBB407, + 0x3799651F, 0x9016E9D0, 0xD1C0ABC8, 0xC7684FDD, 0xE4670051, + 0x25B69E83, 0x1CEC9BBF, 0xD066D2B4, 0x2AD4BF14, 0x7AFBD3CF, + 0xCB8E5EFA, 0x63B67572, 0x89F7E3F3, 0x8E8D39E6, 0x60617ECD, + 0x9EECEA31, 0x59E57FAB, 0x807AFCD6, 0xFD0397B8, 0x3C57D963, + 0x9A972CF5, 0xFC47B628, 0x9CCFAA8B, 0x405869C3, 0x3CC128C1, + 0xE154C33E, 0xBE53F87D, 0xD23C7947, 0x4CBEB3BB, 0x1F068FFA, + 0x8A7D350A, 0xB822F33E, 0xFB3BB431, 0x741D2D0F, 0x81FAFE09, + 0x80B8BA3C, 0x30B4BE94, 0x4B2A2909, 0x31740925, 0xE68C0BC9, + 0x8E7F31D4, 0x29DA2599, 0xB9D267C9, 0xEDE811D2, 0x8BC7CBC3, + 0x69DDA8B6, 0x879E1212, 0xF915F0F1, 0xBBCDB1AD, 0x3A01011A, + 0x7CD005C4, 0x475FC718, 0xF03F454B, 0x7457F264, 0xB22D9DFD, + 0x569DE931, 0xB585EFEB, 0x9A183445, 0x9CB353AC, 0xE3AA9817, + 0x32E0722, 0xF0C7595E, 0x316DBD6A, 0x96D0F65C, 0xA6F0ECCE, + 0xCB8A9494, 0x5B077241, 0xD36BBC7, 0x9C4CD0F9, 0x108F5B32, + 0xC43C599A, 0x7B10108A, 0xA4106EE9, 0x3860CF99, 0x87B782C, + 0xF667524C, 0x129929C, 0xEA85C1D5, 0x1A07973E, 0xB9524891, + 0xBC02BD1F, 0xF378D7F, 0xD0BED4D7, 0x5B782DE2, 0x738681A, + 0x4BA1192C, 0x46DF1224, 0x4529AED7, 0x9B1DB01D, 0x810AA334, + 0x661982C8, 0xD3B32F94, 0xF50AC9D6, 0xCE9107C4, 0x203078BF, + 0x6B0F3B2B, 0xCF63520C, 0xACA9E5BF, 0x7FBE448E, 0x51BD1E2F, + 0xDF958295, 0x114A9693, 0x60FCBB39, 0x6669B642, 0xC490D54, + 0xD19C8DBC, 0x14CC7B2A, 0x7106D506, 0xAFDADD98, 0xAF398DF4, + 0x88AC5400, 0x1912BF0A, 0x5389D050, 0x5AF6233, 0xF10842A3, + 0x94DD7008, 0x93812804, 0xD8111DFD, 0xB7C97490, 0x7748A45E, + 0xE70A47A0, 0xC29B718E, 0x55783AEC, 0xA2789E21, 0x97488EBC, + 0xD9222F6A, 0xBF74BDD2, 0x9A983E5C, 0x6CC067D5, 0xBCFDD3B2, + 0xD7A2A5FE, 0x4733F2F5, 0xC7AA3556, 0x1CDB485D, 0x31755CA0, + 0xB9F8E9A7, 0x1346410D, 0x7D885AD7, 0xA30030D8, 0x9813B41C, + 0x8A64EFD4, 0x273F4CED, 0xFEDDC3FD, 0xF34D9687, 0x6B67F2DC, + 0x13F72B5A, 0x96445DDB, 0xAC94658B, 0x8FBF54BC, 0xA7C13389, + 0x95814EA3, 0x7823E5BC, 0x544C27DB, 0xECE6439B, 0xD1141B27, + 0x7A95ACF4, 0x806E58E7, 0xD07B5422, 0xFD0353AE, 0xC1840431, + 0x1DD89E9, 0xA102016D, 0x3730505, 0x1F91E46A, 0x3279C793, + 0xA060010D, 0x9BF86C80, 0xD0C35484, 0x33E81EF7, 0x1C4D3EA7, + 0x6C2A9935, 0xD65E2FB1, 0xBB1CA42E, 0xEA3E3609, 0x7B478C84, + 0x70C1DF93, 0xA872CA92, 0x7C025178, 0xF3B19C7D, 0x6F2BD89B, + 0x1AD7BBDC, 0x39A48FCC, 0xAB5B72E1, 0x821761B9, 0xD2368C1, + 0x20ABB349, 0x29A3F960, 0xFDB18DF1, 0xC4118A52, 0x5E28E88A, + 0x549A3386, 0xD81024CE, 0x82DAD5E0, 0xB20BCD42, 0x9DEA0D36, + 0x49A4992D, 0xAFCB2026, 0xCE7536E8, 0x2C191A65, 0x24FEE0D6, + 0xA769AB6D, 0xF47E292E, 0xCB501191, 0x6DE13907, 0xF1343277, + 0xB32AA746, 0xB055DB9E, 0x87CB8583, 0xA546A4C3, 0xF06F809C, + 0x8FE7A8AA, 0xD0E4037F, 0xD81FCF88, 0xF85830C2, 0x3D6F4840, + 0x5A43700E, 0xCD300C58, 0x3B81C27C, 0x8AF86EA8, 0xF65935FC, + 0x46367D7, 0x7FB75E63, 0xBB28A406, 0x173F982, 0xCB92DD14, + 0xAAA0B1D1, 0x1BCA8892, 0x64D21, 0xFF081A44, 0x8706E93B, + 0xB7DEFAD9, 0x4A6DEF76, 0xDA1670DF, 0x94ABCEBA, 0x465DA4C6, + 0x2484496C, 0x97BB3321, 0xEFB09CB, 0x2988AA2E, 0x2722344E, + 0x5301B744, 0xC5E16C47, 0xF7E05D01, 0xCBE7C20F, 0x4882A6EA, + 0x7168CF40, 0xA98A2747, 0x35F8E15A, 0x5FAF49F9, 0xD2008D24, + 0xCC45A63, 0x858A3255, 0xE4C095B6, 0x7074F7A5, 0x699C98FD, + 0xF0BFE2EA, 0xBDA35C64, 0xE83B891D, 0x7CD09FEA, 0xE8735FDD, + 0xFEA27F06, 0x631D71D3, 0xA08136CD, 0x42395363, 0xDCBA6E41, + 0x1562897, 0x4B1061A9, 0xB4F9640B, 0x38D24E3E, 0x76DF4423, + 0x94B5ED97, 0xFE6AB3B6, 0x6B329B8B, 0x37AFD275, 0xC9ABA12A, + 0xEC9693B, 0xD49B5585, 0xE0C2BEF7, 0x315D40A8, 0x34FBE3A, + 0xEBE81550, 0x569F6FC8, 0x5A9C8404, 0x9DBA0090, 0xFE985DE8, + 0xFF4209AE, 0x89F9E7AF, 0xF841164C, 0x6B4B8F5D, 0x95CB1085, + 0x1990660C, 0x31263B36, 0xCF8F435C, 0xDEBCF88A, 0xD1EE25C2, + 0x53D80B69, 0x9EB8F01C, 0xD682EA3C, 0xEEE79205, 0xA7EFAC65, + 0xE9AA6899, 0x3C1E197E, 0xC8ABE1E9, 0x7BEFE9CA, 0xE792E7D4, + 0xA955D60F, 0x3FE8A02F, 0xC963FDC1, 0xB3D53E43, 0xE28FFC12, + 0x7D5BECCC, 0x18E9F223, 0xBC8B0465, 0x7ED8EEFE, 0xBB90FFEE, + 0x904A9F3A, 0xBC467FF, 0x8AD43A15, 0xF3FC404A, 0x2492D5F4, + 0xBB3F5025, 0xBED0B8BF, 0x467FE6C2, 0x36E55C77, 0x8E2CAC4F, + 0xD12D325F, 0x68A4D268, 0xB1AA0895, 0x755B98FC, 0x2314C4FF, + 0xC3667346, 0x8003B9E8, 0x1185476D, 0x227B69D8, 0x5BADD019, + 0xB06567BF, 0x2B837581, 0x9E11F7, 0x158E67AE, 0x339AA6FC, + 0x8FE50AD9, 0x65902A97, 0x42917220, 0xF9AD39C, 0x2DAAD225, + 0x9673B896, 0xFAE150D6, 0xBEDE3417, 0xD233D722, 0x7E67F33C, + 0x6E150E30, 0xC856792A, 0x28EF69BA, 0xE2AC7866, 0x928D0A4A, + 0x8032C4A9, 0x3D413533, 0xC1BA5CCA, 0xD2BDAC83, 0x94198A14, + 0x3A25972F, 0x253EC030, 0x42D7A1F5, 0x97C28C1C, 0xBE4D0710, + 0x92F31B62, 0x73CA2F55, 0x15FC5417, 0xEF76B1C6, 0x655A963D, + 0xBC17C3FD, 0xD5BED3BC, 0xAB0E4857, 0x38BAD61A, 0x8C17E47F, + 0xE3C27887, 0x45D2A34, 0x6D48333A, 0xF400B767, 0x6ACF41B0, + 0x88DA15A9, 0x3FA0EAB1, 0xAF7B3786, 0x87F182FF, 0x4112A079, + 0x53360864, 0xDB5CE625, 0x630678D7, 0x63E01F17, 0x7BF658F1, + 0xB5E4F1A3, 0xB30E4393, 0x27454C31, 0x8E7E0E2, 0x2151A5F, + 0x2892E2B2, 0x92B53840, 0x1EB3D483, 0xA4273A65, 0xF0CC632, + 0x99AC2694, 0xE0A19111, 0xC7FBA613, 0x46C8F873, 0x88A27741, + 0x7E9A5972, 0xC2E76F79, 0xA5CA8180, 0xA28FF0EE, 0x2A1F7DE1, + 0xCC130B22, 0x50ECFD8A, 0xF5BAA999, 0x5FA2EC9C, 0xC1B5C5C4, + 0x90EC0E5D, 0x9C26620A, 0xA97D2935, 0xE1C08B89, 0xCB574B80, + 0xB3DE8B61, 0x1AF89CA0, 0xFD4A77DC, 0xED9485E1, 0xAF804C92, + 0x6B8EB167, 0xDCC836B6, 0x85A7FFFD, 0xD4E9A94A, 0x77DDCC31, + 0x8897B5F9, 0xA4FA88D3, 0x8ECB3E82, 0xBC175E89, 0x963A073E, + 0x547520C7, 0xEEB81BFB, 0x1D8B1867, 0x78833A4, 0xE40A0CCB, + 0xF8D5452F, 0x954BDCF6, 0xAC228FFA, 0xE6B32DF3, 0x181ED541, + 0xACE26A73, 0xF1C1440D, 0xA1B93EDD, 0xE90FF70A, 0xF6741843, + 0x4DF581AC, 0xBE785B32, 0x751509B5, 0xC30AD864, 0xC18D8A72, + 0x3BF07FD4, 0x827B4CBA, 0x7DD39A4F, 0x2CFEFE25, 0xE071F371, + 0xC0C3F6CB, 0x1FD70F85, 0xFDABDA88, 0x8F308991, 0x4CD794F9, + 0x5D18B022, 0xC13D5FC2, 0xD84337F, 0xED868BB8, 0x9904CD2, + 0x7551499C, 0x124B262, 0x5139C2A5, 0xEF56F59B, 0xE8B87B40, + 0x2F030010, 0x42D2E271, 0x4E344F3F, 0xC87CDFE1, 0x44A615C7, + 0xC32DB543, 0xCFC889E4, 0x60078825, 0x786F5917, 0x2DF9E82, + 0xEE26DA93, 0x48D0C94, 0xE97D5456, 0xF487F2EB, 0x35A47D65, + 0x183DA0CA, 0x1A7E1218, 0x8D2674C5, 0xB38D0910, 0x5D9C871C, + 0x7B463ED1, 0xBBC90FFD, 0x31DED99F, 0x5171DCFA, 0xF9413D0B, + 0x632A00FD, 0x7B6DA34C, 0xA475C597, 0x8E157360, 0x5911736B, + 0xCA19D544, 0xF487D465, 0x6E749BB9, 0x888BFB52, 0x3FDAD497, + 0xDB5D401A, 0x7015A4EC, 0xC1F571, 0xB2D7671A, 0x8203032F, + 0x5A755E9, 0x24F25BF5, 0x4D2AC51B, 0xE5950FA7, 0x20196F5B, + 0x68E90D90, 0x5D24196C, 0x9CFCD1C0, 0x745C0318, 0xEEB977E8, + 0x14AA16D, 0x80662EE1, 0x7BD55DE3, 0x35EE2B08, 0xD3E8051F, + 0x3D0EA4B5, 0xD551399E, 0x8FF94435, 0xDD4E34ED, 0x9139E4A3, + 0xE6AF7E5E, 0xE1ED4EAF, 0x638D2846, 0x7084F7EB, 0xF9705E17, + 0x2E7A89DC, 0x45855252, 0xBA8E51C7, 0x8510425C, 0xA97AF6D, + 0xF0C27DA, 0x9E00CA15, 0x3BCC0651, 0xEEC38CA9, 0x19597B08, + 0x4C68AB5D, 0x16CA41DB, 0x35EFBEF9, 0x1E441529, 0x25131FA1, + 0xC3D8483C, 0xD8650832, 0x60D271E3, 0x47C92A47, 0x9EFBB554, + 0xBF5DBFBF, 0xFF421FA2, 0x3A38F28, 0xAE4EE06B, 0x819945D1, + 0xC43101, 0xA3EE9278, 0x5BAE3EE4, 0x57ACE55E, 0xC3D95551, + 0xC00717B0, 0x38EC1B28, 0x123597, 0x6314F3F7, 0xB3F99DAB, + 0x7226CE1E, 0xE8350DE6, 0xD7C582CA, 0xBB1D38D, 0x54E656FE, + 0x400B60BD, 0x48291A06, 0x97819179, 0x850BF937, 0x93888A87, + 0xF51E684F, 0x4B111E, 0xC6B37E02, 0x6C923547, 0xEF25AF3B, + 0x8C12CE8E, 0x89296F4F, 0x3BE2C3DA, 0x8A29A35B, 0xBBE2E80C, + 0x79D0188D, 0xBD4320BC, 0xAFF4F0A9, 0x7FAE6C37, 0xCCA1777E, + 0xB06D2AE1, 0x26B6398C, 0x5A3E5876, 0xE814DF4E, 0xC43E9677, + 0x4C962CE8, 0x6C274FF8, 0x8B5A1A03, 0x963E1401, 0xD8CE0DF7, + 0x659190E7, 0x3AD63330, 0x894BFEDB, 0xEB4CF73A, 0x3731BC86, + 0x30FE0433, 0x94F5FD2, 0x8417999C, 0x337E86B8, 0xAFE08EF6, + 0x5B5F05DC, 0x8001C95F, 0x8C8092DC, 0x5EBC7995, 0xDCBE88EE, + 0x9C602950, 0xE3376596, 0x5D80E318, 0xAF3AC8C3, 0x8C7EDCC6, + 0x3E795E7, 0xDA8987AB, 0x7B7B4E3C, 0x3239CD40, 0x1B527DED, + 0xC95DEF29, 0xE40D047D, 0xE53C10C5, 0x5BAF528B, 0xA47921F9, + 0x6DCB9B0A, 0x7EA11040, 0xBBEFCCD5, 0x502F33FA, 0xAB5EBE8F, + 0xD59C448, 0x8C34FF3D, 0x4A3255A2, 0x4CFFDCB1, 0x3880A182, + 0x3499DAAF, 0xA1319450, 0xC550CCE5, 0x51026E2C, 0x73C4F05D, + 0x21F5FAAC, 0xE1C31B7D, 0xA390E6E6, 0x7B1582ED, 0xB92B4C3B, + 0x41C1128E, 0xF728F655, 0x3BC8AE16, 0x8A2A4E57, 0x9A8A7DE, + 0x86065598, 0x4328A574, 0xDBDAFC7D, 0x2C5EE98, 0xEAB5CE80, + 0xF7E8F60C, 0x7B4C3C0E, 0xE4A2F720, 0x90330B1D, 0xB6783BF2, + 0x48A8C26B, 0x847F1AAC, 0x351DB247, 0x43E84AC5, 0xAF726AA3, + 0x5CB4C059, 0x2C5784DE, 0xBA1111FB, 0x9F427968, 0xE41D29D1, + 0x2CAA8CA7, 0x764C8B63, 0xBDAA6F10, 0x280277B6, 0xE4A908B6, + 0xA6A9783, 0xD0643B01, 0x44FE52AD, 0x60B04A5, 0x194C190E, + 0xF73DA669, 0x12EE11C8, 0x2C769D96, 0x694787A4, 0x9FB03623, + 0xAC6F837C, 0xFC1E5935, 0x16246787, 0x4F94B817, 0xA3A4281F, + 0x1535252D, 0x13F8F1CB, 0xAAF6A508, 0xB38E10E, 0x7A4B238, + 0xC6A47410, 0xC864256, 0xF3C25E27, 0x94CE51D4, 0xF4ECAEEA, + 0x32684D74, 0x1AC8765, 0xDE6F6313, 0xF8C09409, 0xFB21FD21, + 0x6DB586BA, 0x241894B5, 0x65806E1F, 0x4B9D0DE7, 0x32DDDD16, + 0x3B16F0B0, 0xB56CAAF0, 0xC533ED5C, 0xADE48431, 0xB5893123, + 0xE977699C, 0xB295808B, 0x7A252898, 0xE3748392, 0x687A8ACD, + 0xB792504E, 0xBF4E2D8A, 0xB5EC4376, 0x754D9C34, 0x17BE53CC, + 0xC817A127, 0x732346E2, 0x29593976, 0x41D6AF89, 0x9072FAEC, + 0xC2B22666, 0x16A150DF, 0x4D379A36, 0xE732017F, 0xA6D12516, + 0xEA3DB9B5, 0x6E4C766B, 0xCA0ADEF5, 0x75E98F68, 0xC31687C3, + 0x62F16F66, 0x6486B129, 0xE237231B, 0xC6653007, 0x2BE06DFC, + 0x2BC32DC4, 0x9E3DD054, 0x47AA701E, 0x7741E537, 0xA09F9CD8, + 0x9D40881, 0x4F02F58, 0x6A5F31BB, 0x32BBBD23, 0x4520EB05, + 0x1DBFDD00, 0x6CCEC7D, 0x48CFC70C, 0xB41FBC13, 0x5B377E90, + 0x3B87923D, 0xC09F6D28, 0xC1CF24FB, 0xDD6BE459, 0x8B8BDD37, + 0xF7B103C8, 0xC1611360, 0xA8B8FCC8, 0xC16D4E2, 0x6AD23606, + 0x951A051, 0x6FC3B984, 0x95876867, 0xA0E1A04C, 0x8267F62C, + 0xC4B69588, 0xF53421DF, 0xC348685B, 0x59769E2B, 0x21F0FF90, + 0x2B978BB4, 0x3FDA987B, 0x216F4FFF, 0x95C68589, 0x2286F5D8, + 0x81E2702D, 0x88E2D01F, 0xE6F6B356, 0x2EA0C31, 0xA5E11CAF, + 0xE17DC578, 0x2115A0EA, 0x8DC2B323, 0xEB86957, 0xF3C7BECB, + 0xBCD805EC, 0x1121C3F5, 0xE6DEF224, 0x8EA2EE24, 0x2703D7B7, + 0x24D73574, 0x4068552C, 0xA85F5B6A, 0x65B563E, 0x4050954C, + 0xC7043820, 0x91E4A088, 0x19084C84, 0x7250FB54, 0xC1EC72, + 0x9FDB2412, 0x3B78E4E9, 0x588C2D17, 0x345C3232, 0xBC7CCB29, + 0xCB5F1F0A, 0x24EDD656, 0x7A9F0605, 0xC2EDB0E5, 0x7F01D20D, + 0x8EB211A2, 0x74AC4C1A, 0x37EDEDDB, 0x55B9AFF2, 0x100C4193, + 0x43CDF2C3, 0x9C75E7C1, 0xC43ABEFF, 0xB9704827, 0xDD4E6376, + 0xEA5FA0D3, 0xC6E14A66, 0xCB163673, 0x9515389, 0x5D3D30C5, + 0xD1FF8777, 0xC1347921, 0x21A5BAC, 0xD6CB5F87, 0xC6CE680B, + 0x46D1E5FB, 0x9B98BC15, 0x8D1446D6, 0x184659E7, 0xAAC79D5A, + 0x773E019E, 0xA1B9F814, 0x933D3D0B, 0x11DB7615, 0xC206A22A, + 0xE4EF5BA1, 0xF0EFA194, 0xDE0E6C2B, 0xBE185B42, 0xC28FDE0C, + 0xE416DD8A, 0xC636753F, 0xAFD119E, 0xB0198B17, 0x94C4115C, + 0x76EDF82A, 0x66818700, 0x6F003485, 0x993DFB2B, 0xF5A1F91E, + 0xDAB0080C, 0x7DF290D2, 0x72F65E9B, 0xBC126473, 0xF6050B10, + 0xB7380CA, 0x3352530, 0x9A403054, 0xB12581C1, 0x6F8E0370, + 0xBB5C1ED1, 0xCE738AFF, 0xE9F605DB, 0xA976BFE4, 0x68C9D107, + 0xA2BD1833, 0x545ACCE2, 0x965FBAF, 0x12D998F, 0x2C16B1CD, + 0xB20788BF, 0x96AADE36, 0xDF821415, 0xF1EBD654, 0x33F3C413, + 0xF2F2A6BF, 0x2DFB0ABA, 0x96845EC5, 0xB24622DD, 0xA83EEE5F, + 0x49DF9AF8, 0xB8DCFB8A, 0x16F7643, 0x436EFD30, 0xD90C9F8, + 0x9C10CD4E, 0x600CB15B, 0xE686606A, 0x5EC0502C, 0x23B2DCE5, + 0xDD5DE18D, 0x235A755C, 0xCB58A693, 0xACBEAFDE, 0xCA201FB5, + 0x2AE90380, 0x4F7455EC, 0xCA923312, 0x1BD202DD, 0x2D92B9E3, + 0xA2670F18, 0x831728C, 0x77D33D8C, 0x12400BDA, 0x9508A626, + 0x9253042B, 0x63C70C8C, 0x5496452F, 0x9237D610, 0x10448F3A, + 0x9303C709, 0x660D7EC, 0xDF6750F0, 0xBC4F14F2, 0x8F59720C, + 0xEE5AB051, 0xD5EC1228, 0xCC3E04CE, 0xE9E4D3B9, 0x8676FA58, + 0xF523860E, 0xF87D9BED, 0x4A6D02C9, 0xC5AD6CF0, 0x65F09045, + 0x8C620984, 0xDC40B4CD, 0x4216C291, 0x7A44C04B, 0x1E2B5D31, + 0xA0E77B7D, 0x12076C51, 0x22262FA1, 0x483B54F1, 0x2A7EF465, + 0xD1395E25, 0xB564369F, 0xC94A47A4, 0xFD678BAA, 0xECEE926A, + 0xE41A06AE, 0xE8F293C1, 0x3EB052BE, 0xD0959EF1, 0x93FF1935, + 0x4D65E4F1, 0xE87FC1F9, 0x3BD4BB2B, 0xD5F24F5B, 0x54FF70D4, + 0x968C7B60, 0x44F9BDE4, 0xF4894BDF, 0x3CFDDF7B, 0xD5CC3F10, + 0xD7F952C2, 0xEA3DCB60, 0xEFDAC96A, 0xBBF8F5EB, 0x41526813, + 0x714E3D51, 0x5E15A386, 0x1286AF4F, 0x5E1E5A3E, 0x676C9938, + 0xA716071B, 0x14D79998, 0x5CB794ED, 0xD815EDED, 0xCB1CA55A, + 0x9D6D74FD, 0xBE032C25, 0xF3FE1425, 0xC0CB5217, 0x3931A93F, + 0x82DB8222, 0xD8FF587F, 0x5AD4E8AC, 0xBCF00442, 0x4298A961, + 0x9F8CC3C2, 0x60E2347F, 0x7E090E, 0x691B735, 0x3D4C4D83, + 0x5612B097, 0x7B8DA321, 0x2C28A057, 0xF8FE8901, 0xDA39D0DD, + 0x465CE561, 0xA78756, 0x3B771E01, 0xE638B09, 0x201853B5, + 0xF934D7D2, 0xBD515A83, 0xC1B5C34E, 0x89159FA9, 0x2DDE3EBE, + 0xE27771DB, 0xB5983F05, 0xA3FD869D, 0x8ABA53CB, 0x55C8606C, + 0xDAB769C3, 0x4C4C2EAC, 0x18EE2A56, 0x88452A07, 0x9767C386, + 0x5C0418D6, 0xF79CA785, 0xF291195D, 0x9B0C286F, 0x68460BED, + 0xBF0079E5, 0x9906D932, 0x2F9E5535, 0x2A3C4947, 0xF0E240C3, + 0xE835A264, 0x43F38C0, 0x82DAADD8, 0x313612B1, 0x560D56FB, + 0x61BD734A, 0x58FD6B36, 0x2C45C40B, 0x55F70159, 0xA21A817D, + 0xAAA6FCE, 0x85BFDFB9, 0x1C71DE25, 0x56CB4C2C, 0x50FD91E5, + 0xF2340E88, 0x72BD5702, 0xB4FFBD3A, 0x1B35B171, 0xE94A34BD, + 0xC4C77575, 0x95B10420, 0x2471BC3F, 0xCB429841, 0x6DC5347F, + 0xC93CF782, 0xF1D26B2C, 0xEB2A260F, 0x67C3AE9, 0x34A56A4, + 0xF1F3D01B, 0xD8295F22, 0x7F9E5D4A, 0xE4DB3DEA, 0xE1531DCB, + 0x2C5FF857, 0x73622A7C, 0xC2691F1, 0xBC622B61, 0xE6A08C89, + 0xBA1807D4, 0x43ADBE43, 0xD90D427C, 0xC7A5C24, 0x613ED316, + 0xEC810B10, 0x1049BF74, 0x9A14C123, 0xA7B24E7E, 0x73254165, + 0x2C54081E, 0x14FF25AA, 0x7A12F3B4, 0xB4DF7C56, 0x89BFE8FC, + 0x5D5A04A6, 0xBE007173, 0x829DF863, 0x63E5E57D, 0x58F64C28, + 0x31A38144, 0xE843289B, 0xB48DFAF1, 0x2B335C2A, 0xEC3C96CE, + 0x255543F6, 0x33F17311, 0x3C60C51A, 0xE5D0D660, 0x5E162559, + 0xA2D9416, 0x9DDE4967, 0x28156A65, 0x71650796, 0x74EE54D1, + 0x3E8C19F7, 0x797C1E42, 0x2C536DFD, 0x2F3EED4D, 0x3BFC7C95, + 0x8EAEF87D, 0x18F5B02A, 0xA3532651, 0x24508E13, 0x280B9049, + 0xE4FC61CB, 0x388BA30F, 0xEC180A43, 0xBFDE77A4, 0x98CDB399, + 0xF82B586D, 0x38525AE7, 0x9D857BE8, 0xDD939D18, 0xD5CA6EBA, + 0xB70DDBA, 0xDFF43867, 0xD06AB2D0, 0xD8C78BB, 0x78F6AE4F, + 0x4C9A58CC, 0x9F9AA50E, 0x7D6A3912, 0xD897C7E4, 0x82F5939D, + 0xA4A9FFF5, 0x2CB56FDE, 0x3E082D4B, 0xB829DC58, 0xE4515CEB, + 0xCE585A33, 0x27901244, 0x68860E95, 0xE156A451, 0x9E351FE0, + 0xC69BD757, 0x4B2C4A2B, 0xD5DE5A91, 0x3557B0DE, 0x99E910B0, + 0x975BE470, 0xDB4DE130, 0xE4C6DA1D, 0xC2BC058F, 0x37544906, + 0x12CC200E, 0x54569133, 0x6586FC03, 0xF183C0CF, 0x642583E, + 0xFBE882CD, 0x8A098C35, 0xE8300988, 0xFE835E55, 0xEA74FD24, + 0xF3127AB2, 0xEE8379F2, 0x3F136FD2, 0x472AA942, 0x3BC1A7D7, + 0x5B6A8A98, 0xF039CCF3, 0x5E55425B, 0x3F801B4, 0x44556FB4, + 0xCC966D37, 0x56E32B90, 0x2BCDA2E5, 0xC70F1125, 0x8C2A015C, + 0x3D37FCA7, 0x2118A4EF, 0xCE051A9C, 0xCB84DCB9, 0x8451C9E0, + 0x4BDB1900, 0x8FC71D5D, 0xF61FD749, 0xA696D2E0, 0x6EED502A, + 0xB345CE8B, 0x76FCDA8E, 0xBE4A45F8, 0x8375E9E7, 0x625FF29B, + 0xCEC61240, 0x3876B21D, 0xBA8C8F59, 0x8CD169C6, 0x9F82251F, + 0x2E6EC495, 0x99319E, 0xB0160B46, 0x8B77EDD8, 0x6217902B, + 0x76FA6AD0, 0xB541F2BC, 0x961EA91C, 0x6F554C1F, 0xBD92328D, + 0xA9C077FD, 0x90A5311C, 0xEFE9B1FB, 0x9C84AA8C, 0x812517C3, + 0xFE71D7F4, 0xC4F6A5BF, 0x8B75A262, 0xC726EB36, 0x5F803035, + 0xCECDE2B7, 0xF61152A8, 0x78557ED1, 0x50F3BB55, 0xDD830290, + 0xB125B524, 0xC8683B0D, 0xE5FD573B, 0x48B13066, 0x62AE556E, + 0x5A637C89, 0x498D69F, 0x3F3A5BE5, 0xB98B86D7, 0x20CF4AF4, + 0xA3E55E7D, 0xEE93FC6F, 0xCCA95763, 0x5B3C5706, 0x8342B013, + 0xA0C7BDB9, 0x83D686E4, 0x6934B64, 0x324D75C3, 0x9A100C81, + 0x72E7E9AE, 0xC729A8AC, 0x9E8489E0, 0xFE5BC233, 0x64709AE9, + 0x113437BC, 0x296DEBC0, 0xC4376603, 0x9F0CD7EE, 0x6412AB97, + 0x3EECEFCD, 0x62DCD50, 0x15DFF1, 0xEEFDCF8E, 0x119849C1, + 0xDAAC93FF, 0xD531AF57, 0x82A10F47, 0xD55B7A97, 0x2F3A268B, + 0x4F1CC181, 0xAE01C1AC, 0xF3CF6F61, 0xE8BDAED5, 0x7397FD99, + 0xDD36A03C, 0x9BAED7C3, 0x51404903, 0xB9867B61, 0x3880A4FD, + 0x42B90A49, 0xA94696C1, 0x546DEA1D, 0xEE73A3DE, 0x1A4BAC37, + 0xBC6AF7AE, 0x7DD5B57B, 0xD2F121F, 0xD2BCCA1E, 0xD5DC4753, + 0xA135C08C, 0x78E97831, 0x9B91C00B, 0xFFF2C044, 0x147B797F, + 0x299CFB60, 0x71083BB, 0xB39A6C4F, 0x4814E3E1, 0xBD246AB0, + 0xBCD61250, 0x2D0870, 0xC660435C, 0xCA11681E, 0xADA4C80E, + 0x790C8875, 0x8C4F0D08, 0x48D90C74, 0xE874E9AA, 0xA8013EE8, + 0xB2D23A7A, 0xAF73A16E, 0x2485512C, 0x698E0CB2, 0x2FF566C9, + 0xC1B0C3C6, 0x2BE17C0E, 0xC42C3907, 0xD8A2EA94, 0x8991D24C, + 0x19B939F1, 0xF936F8B3, 0xA72D7EF1, 0x97EED001, 0xBF9C5156, + 0x75F08A67, 0x9AFD5756, 0x5D9D359C, 0xF905B7EC, 0x2B1553E1, + 0x9E0FD4E1, 0x8DC4814C, 0x89F28E6D, 0x14174915, 0x1F3A4217, + 0xA8F367F9, 0x93EE87C5, 0xAD70C6D8, 0xF04D465C, 0xE403D72B, + 0xA686EC0F, 0xCD3A5728, 0xA1BD007, 0x9E21E401, 0xAE8517CF, + 0x6DDB79FC, 0x8CB2C475, 0x6F71544, 0xBEAC91CF, 0x4739DC4E, + 0x6CF4F788, 0x36BAD9AC, 0xF23568D4, 0x250BAB0A, 0x4633384F, + 0x54F6F251, 0x454F9605, 0xCB1A346, 0x632E207F, 0x3017539C, + 0x174A33ED, 0xBDCFD2DE, 0xC17F3D39, 0x17B8A9A2, 0xC267FB51, + 0x9322387D, 0x348760C, 0x3C14D7E0, 0xE4E4254E, 0xCA72AA41, + 0xB6102ED3, 0x6317A3F, 0xD3B6B9F7, 0xA8C71BB7, 0x6E452957, + 0x3F896E32, 0xE38A4A58, 0x9893F432, 0x110A21D4, 0xE835FEBE, + 0x90F51080, 0xD0AC5AF, 0x4FCB9903, 0xFE547785, 0x144B285D, + 0xD0ECC753, 0xAE503BA4, 0x57CEAABC, 0x95713FE6, 0x5B0F4F86, + 0xD94BD751, 0x4017F139, 0xF60F5E1D, 0xB9A63351, 0xF7F94F6A, + 0x7E556ECC, 0xBFDB8642, 0xB70D07D, 0x351BEA77, 0xD1F3CAD, + 0xA3D7EF4D, 0x1EAA28E3, 0x98A2EA79, 0xD8647392, 0x1B896804, + 0x35CA6A08, 0x305258F, 0xE58BD955, 0xABCB6278, 0x87CF1146, + 0x13145966, 0x45BB55CD, 0x818AA368, 0xA027F11F, 0x64C427A3, + 0xEC831B99, 0xF2BD53F9, 0x7FDA7301, 0x35BE80D4, 0x5256E6FB, + 0xC97D33AE, 0x30921709, 0xC2724BEC, 0x78F5436F, 0x4F5749CD, + 0x9007F551, 0x327C31C0, 0x89782D13, 0x119AD125, 0xB1071A01, + 0x63100C70, 0x83120035, 0xA8E2E403, 0x7E213FA3, 0xBF06AAC4, + 0xBA68C4D9, 0x4B568927, 0x1DDD40F, 0x10FC10E8, 0xBBD7230A, + 0x96475640, 0x8C8E6EC1, 0x44A1134A, 0xEF0F40F0, 0x51E2A5E0, + 0x61AE6D65, 0x9DE72FD6, 0xB1711336, 0x90BEB84, 0xD610EFC6, + 0x3D231F91, 0xB5885164, 0x2CB2112C, 0x36F50789, 0x3DEF2AB9, + 0x1D9DC1DA, 0xA37DB070, 0x2AA92EB, 0x2D57ED6E, 0xD6E2C2CD, + 0xB78FC54C, 0x767A565E, 0x1D1F5AAE, 0x89F256DB, 0x716A97D, + 0x1344431D, 0xFAF015FB, 0xFED59649, 0xC479882A, 0xEEFC3D1E, + 0x840AE162, 0xD963A347, 0x75462C25, 0xDA990E07, 0x9A57DE31, + 0x74A35F20, 0x91852CD6, 0x3F16DE14, 0x5FA6A255, 0x47D00F85, + 0x1B4836C9, 0xC73D0290, 0xE301026B, 0x592068D6, 0x7C32A301, + 0x3A3C04C4, 0xB5BD3BAF, 0xB8C3BF60, 0x76723A1B, 0xD05BC35E, + 0x7679021C, 0x6298096, 0x590BA59C, 0xBB30A2F6, 0xE5F6B06C, + 0x21BD2A9E, 0xAC68D7DA, 0xEDA2ED5A, 0xA10E60FA, 0xABDBF569, + 0x17F5868E, 0x82AA8505, 0x384BD8FC, 0x68DC2746, 0x8F029C0D, + 0x3755EB11, 0xAEF4BB79, 0x453B87BA, 0x9926977F, 0x1FA1B806, + 0xC905618, 0x9BFE8E92, 0xF6F68A5A, 0xAA955D92, 0x44F57A4A, + 0x2186E272, 0x62EB01DA, 0x85A2D502, 0xB087955D, 0x26FF2BA0, + 0x8D462C04, 0xE024573B, 0x609CDBD7, 0xA99B9D19, 0xFEEB3F60, + 0x12903A0D, 0x46480C6, 0xDD0BD1B9, 0x6C60C43, 0x5E11A4FE, + 0x935E9E58, 0x8A7F6D33, 0xA505132D, 0xBB2E3E12, 0xF48633F4, + 0xF3BA8CF7, 0xC25D4EDD, 0x788672B8, 0xB2812608, 0xACB3A62, + 0x2EEB679A, 0x443A71B9, 0xC42F4B12, 0xD28B3482, 0x5571FA8A, + 0x5C0B3D55, 0x8B8619C6, 0xF564F10C, 0xD9A7C914, 0xFBD1EF46, + 0xCEABC573, 0xEC609D28, 0x5839413B, 0x5019E901, 0x248FFF30, + 0x7BFFB801, 0x7FD46584, 0x43702812, 0x3A5A0880, 0x7E3E9EDA, + 0xCA4623E3, 0x2FB87A70, 0xFE70D956, 0xCE9EB3E6, 0x9A2CD2F1, + 0x92EFB0C8, 0xC7E23873, 0x53B63A86, 0xB9D93548, 0x3C022B2, + 0xCF4F22A6, 0x981E70BC, 0x4A05F3AB, 0xD763E93B, 0x6EAF767D, + 0x4162629D, 0xD82A25E7, 0x6CDD19A3, 0x13524F68, 0xE5F23FDC, + 0xB37F311F, 0x35FD43B6, 0x36626469, 0x1E409CF6, 0xE4C04F9D, + 0xC1B58001, 0xD131078F, 0x9DE279A, 0x80B62212, 0x526405DD, + 0xC17777C1, 0x7045FCDC, 0x53862AEC, 0x5D583056, 0xEB532222, + 0x5837EA32, 0x719C06A4, 0x43D4F131, 0x577C6DDB, 0x9E5815A7, + 0x8189DDD9, 0x170F154F, 0xEF813B20, 0x4DD83A53, 0xB09A28FD, + 0x8D0DBED5, 0x1836596D, 0xC5BB2696, 0xA69FC859, 0xD6FF5E0D, + 0xCCC65761, 0xC818C6F7, 0x7A25F980, 0xF949133, 0xC515C093, + 0xA8AD04B5, 0x6768AC1C, 0xB5BE2C4A, 0x4F04616F, 0xBD28E4E3, + 0x4CCA6347, 0x5F61C031 +}; + +/* The source data is random across the q31_t range. Accessing it by word should + remain random. */ +q15_t * transform_fft_q15_inputs = (q15_t *) transform_fft_q31_inputs; + +q15_t dct4_transform_fft_q15_inputs[TRANSFORM_MAX_FFT_LEN * 2] = +{ + 0x0000, 0x2d5c, 0x54d5, 0x714b, 0x7f0d, 0x7c51, 0x6972, 0x48e4, + 0x1edf, 0xf0da, 0xc4cb, 0xa06c, 0x8874, 0x8001, 0x882a, 0x9fe2, + 0xc413, 0xf00c, 0x1e16, 0x4839, 0x68fc, 0x7c1f, 0x7f25, 0x71ab, + 0x5570, 0x2e1e, 0x00cf, 0xd367, 0xabc7, 0x8f16, 0x810d, 0x837e, + 0x9619, 0xb672, 0xe057, 0x0e58, 0x3a7c, 0x5f0a, 0x7741, 0x7ffe, + 0x781e, 0x60a7, 0x3ca4, 0x10c2, 0xe2b4, 0xb873, 0x977b, 0x8415, + 0x80c3, 0x8df6, 0xa9f6, 0xd121, 0xfe61, 0x2bd6, 0x539c, 0x7087, + 0x7ed8, 0x7cb1, 0x6a5c, 0x4a38, 0x2072, 0xf277, 0xc63d, 0xa182, + 0x890b, 0x8005, 0x879b, 0x9ed2, 0xc2a6, 0xee70, 0x1c81, 0x46e0, + 0x680c, 0x7bb7, 0x7f53, 0x7268, 0x56a3, 0x2fa0, 0x026f, 0xd4ed, + 0xad02, 0x8fdc, 0x8145, 0x8321, 0x9531, 0xb51f, 0xdec5, 0x0cba, + 0x390a, 0x5df1, 0x76a8, 0x7ff7, 0x78ab, 0x61b5, 0x3e10, 0x125e, + 0xe449, 0xb9cd, 0x986d, 0x847f, 0x8099, 0x8d3c, 0xa8c4, 0xcf9f, + 0xfcc2, 0x2a4f, 0x5260, 0x6fbf, 0x7e9d, 0x7d0c, 0x6b40, 0x4b89, + 0x2203, 0xf414, 0xc7b1, 0xa29c, 0x89a7, 0x800e, 0x8710, 0x9dc5, + 0xc13a, 0xecd5, 0x1aec, 0x4585, 0x6718, 0x7b4a, 0x7f7b, 0x7320, + 0x57d3, 0x3121, 0x040e, 0xd675, 0xae40, 0x90a7, 0x8182, 0x82c8, + 0x944f, 0xb3d0, 0xdd35, 0x0b1d, 0x3795, 0x5cd5, 0x760a, 0x7fec, + 0x7933, 0x62bf, 0x3f7a, 0x13f8, 0xe5df, 0xbb2a, 0x9964, 0x84ef, + 0x8073, 0x8c86, 0xa796, 0xce20, 0xfb23, 0x28c6, 0x5120, 0x6ef2, + 0x7e5e, 0x7d63, 0x6c21, 0x4cd7, 0x2393, 0xf5b2, 0xc927, 0xa3ba, + 0x8a47, 0x801c, 0x868b, 0x9cbd, 0xbfd1, 0xeb3b, 0x1955, 0x4427, + 0x6620, 0x7ad7, 0x7f9d, 0x73d3, 0x5900, 0x329f, 0x05ad, 0xd7ff, + 0xaf81, 0x9176, 0x81c4, 0x8274, 0x9370, 0xb284, 0xdba6, 0x097f, + 0x361d, 0x5bb5, 0x7566, 0x7fda, 0x79b6, 0x63c6, 0x40e2, 0x1592, + 0xe777, 0xbc8a, 0x9a5e, 0x8564, 0x8053, 0x8bd5, 0xa66b, 0xcca2, + 0xf983, 0x273c, 0x4fdd, 0x6e21, 0x7e19, 0x7db3, 0x6cfd, 0x4e21, + 0x2521, 0xf750, 0xca9f, 0xa4dc, 0x8aed, 0x8030, 0x860a, 0x9bb9, + 0xbe6b, 0xe9a1, 0x17bd, 0x42c6, 0x6523, 0x7a60, 0x7fbb, 0x7481, + 0x5a29, 0x341c, 0x074c, 0xd98a, 0xb0c6, 0x924a, 0x820b, 0x8226, + 0x9297, 0xb13b, 0xda18, 0x07e0, 0x34a4, 0x5a92, 0x74bf, 0x7fc4, + 0x7a34, 0x64c8, 0x4247, 0x172b, 0xe90f, 0xbdec, 0x9b5d, 0x85dd, + 0x8038, 0x8b29, 0xa544, 0xcb27, 0xf7e5, 0x25af, 0x4e97, 0x6d4b, + 0x7dcf, 0x7dff, 0x6dd5, 0x4f69, 0x26ae, 0xf8ef, 0xcc1a, 0xa601, + 0x8b97, 0x8049, 0x858f, 0x9ab9, 0xbd08, 0xe809, 0x1625, 0x4162, + 0x6422, 0x79e4, 0x7fd3, 0x752b, 0x5b4e, 0x3596, 0x08eb, 0xdb17, + 0xb20e, 0x9322, 0x8258, 0x81dd, 0x91c1, 0xaff5, 0xd88c, 0x0641, + 0x3328, 0x596a, 0x7412, 0x7fa8, 0x7aad, 0x65c6, 0x43a9, 0x18c3, + 0xeaa8, 0xbf51, 0x9c5f, 0x865c, 0x8023, 0x8a82, 0xa421, 0xc9ad, + 0xf646, 0x2422, 0x4d4d, 0x6c70, 0x7d80, 0x7e46, 0x6ea8, 0x50ad, + 0x2839, 0xfa8e, 0xcd97, 0xa72b, 0x8c46, 0x8067, 0x8518, 0x99bd, + 0xbba7, 0xe671, 0x148b, 0x3ffb, 0x631e, 0x7963, 0x7fe6, 0x75d0, + 0x5c6f, 0x370f, 0x0a89, 0xdca6, 0xb359, 0x93ff, 0x82a9, 0x8199, + 0x90f0, 0xaeb2, 0xd702, 0x04a2, 0x31aa, 0x583f, 0x7360, 0x7f88, + 0x7b21, 0x66c0, 0x4508, 0x1a5a, 0xec42, 0xc0b9, 0x9d66, 0x86e0, + 0x8012, 0x89e0, 0xa302, 0xc836, 0xf4a8, 0x2292, 0x4c01, 0x6b91, + 0x7d2c, 0x7e87, 0x6f76, 0x51ee, 0x29c3, 0xfc2d, 0xcf16, 0xa858, + 0x8cfa, 0x808b, 0x84a7, 0x98c5, 0xba4a, 0xe4da, 0x12f1, 0x3e92, + 0x6215, 0x78dc, 0x7ff4, 0x7670, 0x5d8c, 0x3884, 0x0c27, 0xde36, + 0xb4a7, 0x94e0, 0x8300, 0x815a, 0x9024, 0xad73, 0xd579, 0x0303, + 0x302a, 0x5711, 0x72aa, 0x7f61, 0x7b90, 0x67b5, 0x4664, 0x1bf0, + 0xeddd, 0xc223, 0x9e71, 0x8769, 0x8007, 0x8942, 0xa1e6, 0xc6c2, + 0xf30b, 0x2102, 0x4ab1, 0x6aae, 0x7cd2, 0x7ec3, 0x7040, 0x532b, + 0x2b4b, 0xfdcc, 0xd097, 0xa988, 0x8db3, 0x80b4, 0x843a, 0x97d1, + 0xb8ef, 0xe345, 0x1155, 0x3d27, 0x6108, 0x7851, 0x7ffc, 0x770b, + 0x5ea6, 0x39f8, 0x0dc4, 0xdfc7, 0xb5f8, 0x95c5, 0x835c, 0x8120, + 0x8f5d, 0xac37, 0xd3f2, 0x0164, 0x2ea8, 0x55de, 0x71ef, 0x7f36, + 0x7bfa, 0x68a7, 0x47be, 0x1d85, 0xef79, 0xc390, 0x9f80, 0x87f6, + 0x8001, 0x88a9, 0xa0cf, 0xc54f, 0xf16e, 0x1f70, 0x495e, 0x69c6, + 0x7c74, 0x7efa, 0x7106, 0x5465, 0x2cd1, 0xff6c, 0xd219, 0xaabc, + 0x8e70, 0x80e2, 0x83d3, 0x96e2, 0xb796, 0xe1b1, 0x0fb9, 0x3bb8, + 0x5ff7, 0x77c1, 0x7fff, 0x77a1, 0x5fbc, 0x3b69, 0x0f61, 0xe15a, + 0xb74d, 0x96af, 0x83bd, 0x80ec, 0x8e9a, 0xaaff, 0xd26d, 0xffc5, + 0x2d24, 0x54a8, 0x712f, 0x7f05, 0x7c5f, 0x6994, 0x4914, 0x1f19, + 0xf115, 0xc500, 0xa093, 0x8889, 0x8001, 0x8816, 0x9fbb, 0xc3df, + 0xefd1, 0x1ddc, 0x4808, 0x68da, 0x7c10, 0x7f2c, 0x71c6, 0x559c, + 0x2e55, 0x010a, 0xd39e, 0xabf4, 0x8f32, 0x8115, 0x8371, 0x95f7, + 0xb641, 0xe01e, 0x0e1d, 0x3a48, 0x5ee2, 0x772c, 0x7ffd, 0x7832, + 0x60cd, 0x3cd8, 0x10fd, 0xe2ee, 0xb8a4, 0x979e, 0x8423, 0x80bd, + 0x8ddb, 0xa9ca, 0xd0ea, 0xfe26, 0x2b9f, 0x536f, 0x706b, 0x7ed0, + 0x7cbf, 0x6a7c, 0x4a68, 0x20ab, 0xf2b2, 0xc672, 0xa1aa, 0x8921, + 0x8006, 0x8787, 0x9eab, 0xc272, 0xee36, 0x1c48, 0x46af, 0x67ea, + 0x7ba8, 0x7f59, 0x7282, 0x56cf, 0x2fd7, 0x02aa, 0xd525, 0xad2f, + 0x8ff9, 0x814d, 0x8314, 0x9511, 0xb4ef, 0xde8c, 0x0c80, 0x38d5, + 0x5dc9, 0x7692, 0x7ff6, 0x78bf, 0x61db, 0x3e44, 0x1298, 0xe483, + 0xb9ff, 0x9890, 0x848f, 0x8093, 0x8d22, 0xa899, 0xcf68, 0xfc87, + 0x2a17, 0x5232, 0x6fa2, 0x7e95, 0x7d19, 0x6b61, 0x4bb8, 0x223c, + 0xf44f, 0xc7e6, 0xa2c5, 0x89bd, 0x8010, 0x86fd, 0x9d9f, 0xc107, + 0xec9b, 0x1ab2, 0x4553, 0x66f5, 0x7b3a, 0x7f80, 0x7339, 0x57fe, + 0x3157, 0x0449, 0xd6ad, 0xae6d, 0x90c4, 0x818b, 0x82bc, 0x942f, + 0xb3a0, 0xdcfc, 0x0ae2, 0x375f, 0x5cad, 0x75f3, 0x7fe9, 0x7946, + 0x62e5, 0x3fae, 0x1433, 0xe619, 0xbb5c, 0x9987, 0x84ff, 0x806f, + 0x8c6d, 0xa76b, 0xcde9, 0xfae7, 0x288e, 0x50f2, 0x6ed5, 0x7e54, + 0x7d6e, 0x6c41, 0x4d06, 0x23cc, 0xf5ed, 0xc95c, 0xa3e3, 0x8a5f, + 0x801f, 0x8678, 0x9c98, 0xbf9e, 0xeb00, 0x191b, 0x43f5, 0x65fc, + 0x7ac7, 0x7fa2, 0x73ec, 0x592a, 0x32d6, 0x05e8, 0xd837, 0xafaf, + 0x9194, 0x81ce, 0x8269, 0x9351, 0xb255, 0xdb6d, 0x0944, 0x35e8, + 0x5b8c, 0x754f, 0x7fd8, 0x79c8, 0x63eb, 0x4115, 0x15cc, 0xe7b1, + 0xbcbc, 0x9a82, 0x8575, 0x804f, 0x8bbd, 0xa641, 0xcc6c, 0xf948, + 0x2703, 0x4faf, 0x6e03, 0x7e0f, 0x7dbf, 0x6d1c, 0x4e50, 0x255a, + 0xf78b, 0xcad5, 0xa505, 0x8b05, 0x8033, 0x85f8, 0x9b94, 0xbe39, + 0xe967, 0x1783, 0x4293, 0x64ff, 0x7a4f, 0x7fbf, 0x749a, 0x5a52, + 0x3452, 0x0787, 0xd9c3, 0xb0f4, 0x9268, 0x8216, 0x821b, 0x9278, + 0xb10c, 0xd9e0, 0x07a5, 0x346e, 0x5a68, 0x74a6, 0x7fc0, 0x7a46, + 0x64ec, 0x4279, 0x1765, 0xe949, 0xbe1f, 0x9b81, 0x85ef, 0x8035, + 0x8b11, 0xa51b, 0xcaf1, 0xf7aa, 0x2577, 0x4e68, 0x6d2c, 0x7dc4, + 0x7e0a, 0x6df3, 0x4f97, 0x26e6, 0xf92a, 0xcc50, 0xa62c, 0x8bb0, + 0x804d, 0x857d, 0x9a95, 0xbcd6, 0xe7cf, 0x15ea, 0x412f, 0x63fe, + 0x79d2, 0x7fd6, 0x7543, 0x5b77, 0x35cc, 0x0925, 0xdb50, 0xb23d, + 0x9341, 0x8263, 0x81d3, 0x91a3, 0xafc7, 0xd854, 0x0606, 0x32f2, + 0x5940, 0x73f9, 0x7fa4, 0x7abe, 0x65ea, 0x43db, 0x18fd, 0xeae2, + 0xbf84, 0x9c85, 0x866f, 0x8020, 0x8a6b, 0xa3f8, 0xc978, 0xf60b, + 0x23e9, 0x4d1e, 0x6c51, 0x7d74, 0x7e4f, 0x6ec5, 0x50db, 0x2871, + 0xfac9, 0xcdcd, 0xa755, 0x8c60, 0x806c, 0x8508, 0x9999, 0xbb75, + 0xe637, 0x1451, 0x3fc8, 0x62f8, 0x7950, 0x7fe8, 0x75e7, 0x5c98, + 0x3744, 0x0ac4, 0xdcdf, 0xb388, 0x941e, 0x82b5, 0x8190, 0x90d3, + 0xae85, 0xd6ca, 0x0467, 0x3173, 0x5814, 0x7347, 0x7f82, 0x7b31, + 0x66e3, 0x453a, 0x1a94, 0xec7d, 0xc0ec, 0x9d8c, 0x86f3, 0x8011, + 0x89c9, 0xa2d9, 0xc801, 0xf46d, 0x2259, 0x4bd1, 0x6b71, 0x7d1f, + 0x7e90, 0x6f93, 0x521b, 0x29fb, 0xfc68, 0xcf4c, 0xa883, 0x8d14, + 0x8090, 0x8497, 0x98a2, 0xba18, 0xe4a1, 0x12b6, 0x3e5f, 0x61ef, + 0x78c9, 0x7ff5, 0x7686, 0x5db5, 0x38b9, 0x0c61, 0xde6f, 0xb4d7, + 0x9500, 0x830d, 0x8152, 0x9007, 0xad46, 0xd541, 0x02c8, 0x2ff3, + 0x56e5, 0x7290, 0x7f5c, 0x7ba0, 0x67d8, 0x4696, 0x1c2a, 0xee17, + 0xc257, 0x9e97, 0x877d, 0x8006, 0x892c, 0xa1be, 0xc68d, 0xf2d0, + 0x20c8, 0x4a81, 0x6a8d, 0x7cc5, 0x7ecc, 0x705d, 0x5358, 0x2b82, + 0xfe08, 0xd0ce, 0xa9b4, 0x8dce, 0x80ba, 0x842b, 0x97af, 0xb8bd, + 0xe30b, 0x111b, 0x3cf3, 0x60e1, 0x783d, 0x7ffd, 0x7721, 0x5ece, + 0x3a2d, 0x0dff, 0xe000, 0xb629, 0x95e6, 0x836a, 0x8119, 0x8f41, + 0xac0b, 0xd3bb, 0x0129, 0x2e71, 0x55b2, 0x71d4, 0x7f2f, 0x7c09, + 0x68c9, 0x47ef, 0x1dbf, 0xefb3, 0xc3c4, 0x9fa7, 0x880b, 0x8001, + 0x8894, 0xa0a7, 0xc51b, 0xf133, 0x1f36, 0x492d, 0x69a5, 0x7c66, + 0x7f02, 0x7121, 0x5492, 0x2d08, 0xffa7, 0xd251, 0xaae8, 0x8e8b, + 0x80e9, 0x83c5, 0x96c1, 0xb766, 0xe177, 0x0f7f, 0x3b84, 0x5fd0, + 0x77ac, 0x7fff, 0x77b6, 0x5fe3, 0x3b9d, 0x0f9b, 0xe193, 0xb77d, + 0x96d1, 0x83cc, 0x80e5, 0x8e7e, 0xaad3, 0xd236, 0xff8a, 0x2ced, + 0x547c, 0x7114, 0x7efe, 0x7c6d, 0x69b5, 0x4945, 0x1f52, 0xf150, + 0xc534, 0xa0ba, 0x889e, 0x8001, 0x8801, 0x9f94, 0xc3ab, 0xef97, + 0x1da3, 0x47d7, 0x68b8, 0x7c02, 0x7f33, 0x71e1, 0x55c8, 0x2e8c, + 0x0145, 0xd3d6, 0xac20, 0x8f4e, 0x811c, 0x8363, 0x95d6, 0xb611, + 0xdfe5, 0x0de2, 0x3a13, 0x5eba, 0x7716, 0x7ffd, 0x7847, 0x60f4, + 0x3d0c, 0x1137, 0xe327, 0xb8d5, 0x97c0, 0x8432, 0x80b7, 0x8dc1, + 0xa99f, 0xd0b3, 0xfdeb, 0x2b67, 0x5342, 0x704f, 0x7ec8, 0x7ccc, + 0x6a9d, 0x4a98, 0x20e4, 0xf2ed, 0xc6a6, 0xa1d2, 0x8937, 0x8007, + 0x8773, 0x9e85, 0xc23e, 0xedfb, 0x1c0e, 0x467e, 0x67c7, 0x7b98, + 0x7f5e, 0x729d, 0x56fa, 0x300e, 0x02e5, 0xd55c, 0xad5c, 0x9015, + 0x8156, 0x8307, 0x94f0, 0xb4c0, 0xde53, 0x0c45, 0x38a0, 0x5da1, + 0x767b, 0x7ff5, 0x78d2, 0x6201, 0x3e78, 0x12d3, 0xe4bd, 0xba30, + 0x98b3, 0x849e, 0x808e, 0x8d08, 0xa86e, 0xcf32, 0xfc4c, 0x29df, + 0x5205, 0x6f85, 0x7e8c, 0x7d25, 0x6b81, 0x4be8, 0x2275, 0xf48a, + 0xc81b, 0xa2ed, 0x89d4, 0x8011, 0x86ea, 0x9d7a, 0xc0d3, 0xec60, + 0x1a78, 0x4522, 0x66d2, 0x7b2a, 0x7f85, 0x7353, 0x5829, 0x318e, + 0x0484, 0xd6e5, 0xae9b, 0x90e1, 0x8194, 0x82b0, 0x940f, 0xb371, + 0xdcc3, 0x0aa7, 0x372a, 0x5c84, 0x75dc, 0x7fe7, 0x7959, 0x630a, + 0x3fe1, 0x146d, 0xe653, 0xbb8e, 0x99aa, 0x8510, 0x806a, 0x8c53, + 0xa741, 0xcdb3, 0xfaac, 0x2856, 0x50c4, 0x6eb7, 0x7e4b, 0x7d7a, + 0x6c60, 0x4d35, 0x2404, 0xf628, 0xc992, 0xa40c, 0x8a76, 0x8021, + 0x8666, 0x9c72, 0xbf6b, 0xeac6, 0x18e1, 0x43c2, 0x65d8, 0x7ab6, + 0x7fa6, 0x7405, 0x5955, 0x330c, 0x0623, 0xd86f, 0xafdd, 0x91b2, + 0x81d8, 0x825e, 0x9332, 0xb226, 0xdb34, 0x0909, 0x35b2, 0x5b63, + 0x7537, 0x7fd5, 0x79db, 0x6410, 0x4148, 0x1607, 0xe7eb, 0xbcee, + 0x9aa6, 0x8586, 0x804b, 0x8ba4, 0xa617, 0xcc36, 0xf90d, 0x26cb, + 0x4f80, 0x6de4, 0x7e05, 0x7dca, 0x6d3b, 0x4e7f, 0x2592, 0xf7c6, + 0xcb0b, 0xa52f, 0x8b1d, 0x8037, 0x85e6, 0x9b6f, 0xbe06, 0xe92d, + 0x1749, 0x4261, 0x64db, 0x7a3d, 0x7fc2, 0x74b2, 0x5a7c, 0x3488, + 0x07c2, 0xd9fb, 0xb123, 0x9287, 0x8220, 0x8211, 0x9259, 0xb0de, + 0xd9a7, 0x076a, 0x3438, 0x5a3e, 0x748e, 0x7fbd, 0x7a57, 0x6511, + 0x42ac, 0x179f, 0xe983, 0xbe51, 0x9ba6, 0x8601, 0x8032, 0x8af9, + 0xa4f1, 0xcabb, 0xf76f, 0x253e, 0x4e39, 0x6d0d, 0x7db9, 0x7e14, + 0x6e11, 0x4fc5, 0x271f, 0xf965, 0xcc86, 0xa656, 0x8bc9, 0x8051, + 0x856c, 0x9a70, 0xbca3, 0xe795, 0x15b0, 0x40fc, 0x63d9, 0x79c0, + 0x7fd9, 0x755a, 0x5ba0, 0x3602, 0x0960, 0xdb89, 0xb26c, 0x9360, + 0x826e, 0x81c9, 0x9185, 0xaf99, 0xd81c, 0x05cb, 0x32bb, 0x5916, + 0x73e0, 0x7fa0, 0x7acf, 0x660d, 0x440d, 0x1937, 0xeb1d, 0xbfb7, + 0x9caa, 0x8681, 0x801e, 0x8a53, 0xa3cf, 0xc942, 0xf5d0, 0x23b0, + 0x4cef, 0x6c31, 0x7d69, 0x7e59, 0x6ee3, 0x5108, 0x28a9, 0xfb04, + 0xce04, 0xa780, 0x8c79, 0x8071, 0x84f7, 0x9976, 0xbb43, 0xe5fd, + 0x1416, 0x3f95, 0x62d3, 0x793d, 0x7feb, 0x75fe, 0x5cc0, 0x3779, + 0x0aff, 0xdd18, 0xb3b8, 0x943e, 0x82c2, 0x8186, 0x90b6, 0xae57, + 0xd692, 0x042c, 0x313d, 0x57ea, 0x732d, 0x7f7d, 0x7b41, 0x6706, + 0x456b, 0x1ace, 0xecb7, 0xc120, 0x9db2, 0x8706, 0x800f, 0x89b2, + 0xa2b1, 0xc7cc, 0xf433, 0x2220, 0x4ba1, 0x6b51, 0x7d13, 0x7e99, + 0x6fb0, 0x5248, 0x2a32, 0xfca3, 0xcf83, 0xa8ae, 0x8d2e, 0x8096, + 0x8487, 0x987f, 0xb9e6, 0xe467, 0x127c, 0x3e2b, 0x61c9, 0x78b5, + 0x7ff7, 0x769c, 0x5ddd, 0x38ee, 0x0c9c, 0xdea8, 0xb507, 0x9521, + 0x831a, 0x8149, 0x8feb, 0xad19, 0xd50a, 0x028d, 0x2fbc, 0x56ba, + 0x7275, 0x7f56, 0x7baf, 0x67fa, 0x46c7, 0x1c64, 0xee52, 0xc28b, + 0x9ebe, 0x8791, 0x8005, 0x8916, 0xa196, 0xc658, 0xf295, 0x208f, + 0x4a51, 0x6a6c, 0x7cb8, 0x7ed4, 0x7079, 0x5385, 0x2bba, 0xfe43, + 0xd104, 0xa9df, 0x8de8, 0x80c0, 0x841c, 0x978d, 0xb88c, 0xe2d2, + 0x10e0, 0x3cbf, 0x60bb, 0x7828, 0x7ffe, 0x7736, 0x5ef5, 0x3a61, + 0x0e39, 0xe03a, 0xb659, 0x9608, 0x8377, 0x8111, 0x8f25, 0xabde, + 0xd383, 0x00ee, 0x2e3a, 0x5586, 0x71b9, 0x7f29, 0x7c17, 0x68eb, + 0x4820, 0x1df8, 0xefee, 0xc3f9, 0x9fce, 0x8820, 0x8001, 0x887f, + 0xa080, 0xc4e6, 0xf0f8, 0x1efd, 0x48fd, 0x6983, 0x7c58, 0x7f09, + 0x713d, 0x54be, 0x2d3f, 0xffe2, 0xd288, 0xab15, 0x8ea7, 0x80f0, + 0x83b6, 0x969f, 0xb735, 0xe13e, 0x0f44, 0x3b50, 0x5fa9, 0x7797, + 0x7fff, 0x77cb, 0x600a, 0x3bd2, 0x0fd6, 0xe1cd, 0xb7ae, 0x96f3, + 0x83da, 0x80de, 0x8e63, 0xaaa7, 0xd1ff, 0xff4f, 0x2cb6, 0x5450, + 0x70f8, 0x7ef7, 0x7c7b, 0x69d6, 0x4975, 0x1f8b, 0xf18a, 0xc569, + 0xa0e2, 0x88b4, 0x8002, 0x87ed, 0x9f6d, 0xc377, 0xef5c, 0x1d69, + 0x47a6, 0x6896, 0x7bf3, 0x7f39, 0x71fc, 0x55f4, 0x2ec3, 0x0181, + 0xd40d, 0xac4d, 0x8f6a, 0x8124, 0x8356, 0x95b5, 0xb5e1, 0xdfab, + 0x0da7, 0x39de, 0x5e93, 0x7700, 0x7ffc, 0x785b, 0x611b, 0x3d40, + 0x1172, 0xe361, 0xb906, 0x97e2, 0x8441, 0x80b1, 0x8da6, 0xa973, + 0xd07c, 0xfdb0, 0x2b30, 0x5315, 0x7032, 0x7ebf, 0x7cd9, 0x6abe, + 0x4ac8, 0x211d, 0xf327, 0xc6db, 0xa1fa, 0x894d, 0x8008, 0x875f, + 0x9e5f, 0xc20a, 0xedc1, 0x1bd4, 0x464c, 0x67a4, 0x7b89, 0x7f64, + 0x72b7, 0x5726, 0x3045, 0x0320, 0xd594, 0xad89, 0x9032, 0x815e, + 0x82fa, 0x94d0, 0xb490, 0xde1a, 0x0c0a, 0x386b, 0x5d79, 0x7665, + 0x7ff3, 0x78e6, 0x6227, 0x3eab, 0x130d, 0xe4f7, 0xba62, 0x98d6, + 0x84ae, 0x8088, 0x8cee, 0xa843, 0xcefb, 0xfc10, 0x29a8, 0x51d8, + 0x6f68, 0x7e83, 0x7d32, 0x6ba1, 0x4c18, 0x22ae, 0xf4c5, 0xc850, + 0xa316, 0x89eb, 0x8013, 0x86d7, 0x9d54, 0xc0a0, 0xec26, 0x1a3e, + 0x44f0, 0x66af, 0x7b19, 0x7f8a, 0x736d, 0x5854, 0x31c4, 0x04bf, + 0xd71d, 0xaec9, 0x90ff, 0x819d, 0x82a4, 0x93ef, 0xb342, 0xdc8a, + 0x0a6c, 0x36f5, 0x5c5b, 0x75c5, 0x7fe5, 0x796c, 0x6330, 0x4014, + 0x14a7, 0xe68d, 0xbbc0, 0x99ce, 0x8520, 0x8065, 0x8c3a, 0xa716, + 0xcd7c, 0xfa71, 0x281e, 0x5097, 0x6e99, 0x7e41, 0x7d86, 0x6c80, + 0x4d64, 0x243d, 0xf663, 0xc9c7, 0xa435, 0x8a8d, 0x8024, 0x8653, + 0x9c4d, 0xbf38, 0xea8c, 0x18a7, 0x4390, 0x65b4, 0x7aa5, 0x7fab, + 0x741e, 0x597f, 0x3342, 0x065e, 0xd8a8, 0xb00b, 0x91d0, 0x81e2, + 0x8252, 0x9313, 0xb1f7, 0xdafc, 0x08ce, 0x357c, 0x5b39, 0x751f, + 0x7fd2, 0x79ed, 0x6434, 0x417b, 0x1641, 0xe825, 0xbd20, 0x9aca, + 0x8597, 0x8047, 0x8b8b, 0xa5ed, 0xcc00, 0xf8d2, 0x2693, 0x4f52, + 0x6dc6, 0x7dfa, 0x7dd4, 0x6d5a, 0x4ead, 0x25cb, 0xf801, 0xcb41, + 0xa559, 0x8b35, 0x803a, 0x85d5, 0x9b4b, 0xbdd3, 0xe8f3, 0x170f, + 0x422e, 0x64b6, 0x7a2c, 0x7fc6, 0x74ca, 0x5aa6, 0x34be, 0x07fd, + 0xda34, 0xb151, 0x92a5, 0x822b, 0x8206, 0x923b, 0xb0af, 0xd96f, + 0x072f, 0x3402, 0x5a14, 0x7475, 0x7fb9, 0x7a69, 0x6535, 0x42de, + 0x17da, 0xe9bd, 0xbe84, 0x9bcb, 0x8613, 0x802f, 0x8ae1, 0xa4c8, + 0xca85, 0xf734, 0x2506, 0x4e0a, 0x6cee, 0x7dae, 0x7e1e, 0x6e2f, + 0x4ff3, 0x2757, 0xf9a0, 0xccbc, 0xa680, 0x8be1, 0x8055, 0x855b, + 0x9a4d, 0xbc71, 0xe75a, 0x1576, 0x40c9, 0x63b4, 0x79ad, 0x7fdc, + 0x7572, 0x5bca, 0x3637, 0x099b, 0xdbc1, 0xb29b, 0x9380, 0x827a, + 0x81bf, 0x9168, 0xaf6b, 0xd7e4, 0x0590, 0x3285, 0x58eb, 0x73c7, + 0x7f9b, 0x7adf, 0x6631, 0x443f, 0x1971, 0xeb57, 0xbfea, 0x9ccf, + 0x8694, 0x801b, 0x8a3c, 0xa3a6, 0xc90d, 0xf596, 0x2377, 0x4cc0, + 0x6c12, 0x7d5d, 0x7e62, 0x6f00, 0x5136, 0x28e1, 0xfb3f, 0xce3a, + 0xa7ab, 0x8c93, 0x8076, 0x84e7, 0x9952, 0xbb12, 0xe5c3, 0x13dc, + 0x3f62, 0x62ad, 0x792a, 0x7fed, 0x7615, 0x5ce9, 0x37ae, 0x0b39, + 0xdd50, 0xb3e7, 0x945e, 0x82ce, 0x817d, 0x9099, 0xae2a, 0xd65a, + 0x03f1, 0x3106, 0x57bf, 0x7313, 0x7f78, 0x7b51, 0x6729, 0x459d, + 0x1b08, 0xecf1, 0xc153, 0x9dd8, 0x871a, 0x800d, 0x899c, 0xa288, + 0xc797, 0xf3f8, 0x21e7, 0x4b72, 0x6b31, 0x7d06, 0x7ea2, 0x6fcd, + 0x5276, 0x2a6a, 0xfcde, 0xcfba, 0xa8d9, 0x8d48, 0x809c, 0x8478, + 0x985c, 0xb9b5, 0xe42d, 0x1241, 0x3df7, 0x61a2, 0x78a1, 0x7ff8, + 0x76b3, 0x5e05, 0x3923, 0x0cd7, 0xdee1, 0xb537, 0x9541, 0x8327, + 0x8141, 0x8fce, 0xacec, 0xd4d2, 0x0252, 0x2f86, 0x568e, 0x725b, + 0x7f50, 0x7bbe, 0x681d, 0x46f8, 0x1c9d, 0xee8d, 0xc2bf, 0x9ee4, + 0x87a5, 0x8004, 0x8900, 0xa16f, 0xc623, 0xf25a, 0x2056, 0x4a20, + 0x6a4c, 0x7cab, 0x7edb, 0x7095, 0x53b2, 0x2bf1, 0xfe7e, 0xd13c, + 0xaa0b, 0x8e03, 0x80c7, 0x840d, 0x976b, 0xb85b, 0xe298, 0x10a6, + 0x3c8b, 0x6094, 0x7814, 0x7ffe, 0x774c, 0x5f1d, 0x3a96, 0x0e74, + 0xe073, 0xb689, 0x9629, 0x8385, 0x810a, 0x8f09, 0xabb2, 0xd34c, + 0x00b2, 0x2e03, 0x555a, 0x719e, 0x7f22, 0x7c26, 0x690c, 0x4850, + 0x1e32, 0xf028, 0xc42d, 0x9ff5, 0x8835, 0x8001, 0x886a, 0xa059, + 0xc4b2, 0xf0be, 0x1ec4, 0x48cc, 0x6962, 0x7c4a, 0x7f10, 0x7158, + 0x54ea, 0x2d77, 0x001c, 0xd2bf, 0xab41, 0x8ec2, 0x80f7, 0x83a8, + 0x967d, 0xb705, 0xe105, 0x0f09, 0x3b1b, 0x5f81, 0x7782, 0x7fff, + 0x77e0, 0x6031, 0x3c06, 0x1011, 0xe206, 0xb7df, 0x9715, 0x83e8, + 0x80d7, 0x8e48, 0xaa7b, 0xd1c7, 0xff14, 0x2c7e, 0x5423, 0x70dc, + 0x7eef, 0x7c88, 0x69f8, 0x49a6, 0x1fc5, 0xf1c5, 0xc59d, 0xa10a, + 0x88c9, 0x8002, 0x87d8, 0x9f46, 0xc343, 0xef21, 0x1d30, 0x4775, + 0x6874, 0x7be4, 0x7f40, 0x7217, 0x561f, 0x2efa, 0x01bc, 0xd445, + 0xac7a, 0x8f86, 0x812c, 0x8348, 0x9594, 0xb5b1, 0xdf72, 0x0d6c, + 0x39aa, 0x5e6b, 0x76ea, 0x7ffb, 0x786f, 0x6141, 0x3d74, 0x11ac, + 0xe39b, 0xb938, 0x9805, 0x8451, 0x80ab, 0x8d8b, 0xa947, 0xd045, + 0xfd75, 0x2af8, 0x52e8, 0x7016, 0x7eb7, 0x7ce6, 0x6ade, 0x4af8, + 0x2156, 0xf362, 0xc710, 0xa222, 0x8963, 0x8009, 0x874b, 0x9e38, + 0xc1d6, 0xed86, 0x1b9b, 0x461b, 0x6782, 0x7b79, 0x7f6a, 0x72d1, + 0x5751, 0x307b, 0x035b, 0xd5cc, 0xadb6, 0x904f, 0x8167, 0x82ed, + 0x94b0, 0xb460, 0xdde1, 0x0bcf, 0x3836, 0x5d50, 0x764e, 0x7ff1, + 0x78f9, 0x624d, 0x3edf, 0x1347, 0xe530, 0xba93, 0x98f9, 0x84be, + 0x8083, 0x8cd4, 0xa818, 0xcec5, 0xfbd5, 0x2970, 0x51aa, 0x6f4b, + 0x7e7a, 0x7d3e, 0x6bc1, 0x4c47, 0x22e7, 0xf500, 0xc885, 0xa33e, + 0x8a02, 0x8015, 0x86c4, 0x9d2e, 0xc06d, 0xebeb, 0x1a04, 0x44be, + 0x668b, 0x7b09, 0x7f8f, 0x7386, 0x587f, 0x31fb, 0x04fa, 0xd755, + 0xaef6, 0x911c, 0x81a7, 0x8298, 0x93d0, 0xb312, 0xdc51, 0x0a31, + 0x36bf, 0x5c32, 0x75ad, 0x7fe2, 0x797e, 0x6355, 0x4047, 0x14e2, + 0xe6c7, 0xbbf2, 0x99f2, 0x8531, 0x8060, 0x8c21, 0xa6ec, 0xcd46, + 0xfa36, 0x27e6, 0x5069, 0x6e7b, 0x7e37, 0x7d91, 0x6c9f, 0x4d93, + 0x2476, 0xf69e, 0xc9fd, 0xa45f, 0x8aa5, 0x8027, 0x8641, 0x9c28, + 0xbf05, 0xea51, 0x186d, 0x435e, 0x6590, 0x7a94, 0x7faf, 0x7437, + 0x59a9, 0x3378, 0x0699, 0xd8e0, 0xb039, 0x91ee, 0x81ec, 0x8247, + 0x92f4, 0xb1c8, 0xdac3, 0x0893, 0x3547, 0x5b10, 0x7507, 0x7fce, + 0x79ff, 0x6459, 0x41ad, 0x167b, 0xe85f, 0xbd53, 0x9aee, 0x85a8, + 0x8043, 0x8b73, 0xa5c3, 0xcbca, 0xf897, 0x265a, 0x4f24, 0x6da7, + 0x7df0, 0x7ddf, 0x6d78, 0x4edc, 0x2603, 0xf83c, 0xcb77, 0xa583, + 0x8b4d, 0x803e, 0x85c3, 0x9b26, 0xbda1, 0xe8b8, 0x16d5, 0x41fb, + 0x6492, 0x7a1a, 0x7fc9, 0x74e2, 0x5ad0, 0x34f4, 0x0838, 0xda6c, + 0xb180, 0x92c4, 0x8236, 0x81fc, 0x921d, 0xb081, 0xd937, 0x06f4, + 0x33cc, 0x59ea, 0x745d, 0x7fb5, 0x7a7a, 0x6559, 0x4311, 0x1814, + 0xe9f8, 0xbeb7, 0x9bef, 0x8625, 0x802b, 0x8ac9, 0xa49e, 0xca50, + 0xf6f9, 0x24cd, 0x4ddc, 0x6ccf, 0x7da3, 0x7e28, 0x6e4d, 0x5022, + 0x278f, 0xf9db, 0xccf3, 0xa6aa, 0x8bfa, 0x805a, 0x854a, 0x9a29, + 0xbc3f, 0xe720, 0x153c, 0x4096, 0x638f, 0x799b, 0x7fdf, 0x7589, + 0x5bf3, 0x366d, 0x09d6, 0xdbfa, 0xb2ca, 0x939f, 0x8286, 0x81b5, + 0x914a, 0xaf3d, 0xd7ab, 0x0555, 0x324f, 0x58c1, 0x73ad, 0x7f96, + 0x7af0, 0x6655, 0x4471, 0x19ab, 0xeb91, 0xc01e, 0x9cf5, 0x86a7, + 0x8019, 0x8a25, 0xa37d, 0xc8d8, 0xf55b, 0x233e, 0x4c90, 0x6bf2, + 0x7d51, 0x7e6c, 0x6f1e, 0x5164, 0x2919, 0xfb7a, 0xce71, 0xa7d6, + 0x8cac, 0x807b, 0x84d7, 0x992f, 0xbae0, 0xe589, 0x13a1, 0x3f2e, + 0x6287, 0x7917, 0x7fef, 0x762b, 0x5d12, 0x37e4, 0x0b74, 0xdd89, + 0xb417, 0x947e, 0x82da, 0x8174, 0x907c, 0xadfc, 0xd622, 0x03b6, + 0x30d0, 0x5793, 0x72f9, 0x7f73, 0x7b61, 0x674c, 0x45cf, 0x1b42, + 0xed2c, 0xc187, 0x9dfe, 0x872d, 0x800b, 0x8985, 0xa260, 0xc762, + 0xf3bd, 0x21ae, 0x4b42, 0x6b10, 0x7cfa, 0x7eaa, 0x6fea, 0x52a3, + 0x2aa2, 0xfd1a, 0xcff1, 0xa905, 0x8d63, 0x80a1, 0x8468, 0x983a, + 0xb984, 0xe3f4, 0x1207, 0x3dc4, 0x617c, 0x788e, 0x7ff9, 0x76c9, + 0x5e2d, 0x3958, 0x0d12, 0xdf1a, 0xb567, 0x9562, 0x8334, 0x8139, + 0x8fb2, 0xacbf, 0xd49a, 0x0217, 0x2f4f, 0x5663, 0x7240, 0x7f49, + 0x7bcd, 0x683f, 0x4729, 0x1cd7, 0xeec7, 0xc2f3, 0x9f0b, 0x87b9, + 0x8003, 0x88eb, 0xa147, 0xc5ee, 0xf220, 0x201d, 0x49f0, 0x6a2b, + 0x7c9d, 0x7ee3, 0x70b1, 0x53de, 0x2c29, 0xfeb9, 0xd173, 0xaa37, + 0x8e1e, 0x80cd, 0x83ff, 0x9749, 0xb82a, 0xe25f, 0x106b, 0x3c56, + 0x606d, 0x7800, 0x7fff, 0x7761, 0x5f44, 0x3aca, 0x0eaf, 0xe0ac, + 0xb6ba, 0x964a, 0x8393, 0x8102, 0x8eed, 0xab85, 0xd314, 0x0077, + 0x2dcc, 0x552e, 0x7183, 0x7f1b, 0x7c34, 0x692e, 0x4881, 0x1e6b, + 0xf063, 0xc461, 0xa01c, 0x8849, 0x8001, 0x8855, 0xa031, 0xc47d, + 0xf083, 0x1e8a, 0x489c, 0x6940, 0x7c3c, 0x7f17, 0x7174, 0x5516, + 0x2dae, 0x0057, 0xd2f6, 0xab6d, 0x8ede, 0x80fe, 0x839a, 0x965c, + 0xb6d4, 0xe0cb, 0x0ecf, 0x3ae7, 0x5f5a, 0x776c, 0x7fff, 0x77f4, + 0x6058, 0x3c3a, 0x104b, 0xe240, 0xb810, 0x9736, 0x83f7, 0x80d1, + 0x8e2d, 0xaa4f, 0xd190, 0xfed9, 0x2c47, 0x53f7, 0x70c0, 0x7ee7, + 0x7c96, 0x6a19, 0x49d6, 0x1ffe, 0xf200, 0xc5d2, 0xa131, 0x88df, + 0x8003, 0x87c4, 0x9f20, 0xc30f, 0xeee7, 0x1cf6, 0x4744, 0x6852, + 0x7bd5, 0x7f46, 0x7232, 0x564b, 0x2f31, 0x01f7, 0xd47c, 0xaca7, + 0x8fa3, 0x8134, 0x833b, 0x9574, 0xb581, 0xdf39, 0x0d32, 0x3975, + 0x5e43, 0x76d5, 0x7ffa, 0x7883, 0x6167, 0x3da8, 0x11e7, 0xe3d4, + 0xb969, 0x9827, 0x8460, 0x80a5, 0x8d71, 0xa91c, 0xd00e, 0xfd3a, + 0x2ac0, 0x52bb, 0x6ff9, 0x7eaf, 0x7cf3, 0x6aff, 0x4b28, 0x2190, + 0xf39d, 0xc745, 0xa24a, 0x8979, 0x800b, 0x8738, 0x9e12, 0xc1a3, + 0xed4c, 0x1b61, 0x45e9, 0x675f, 0x7b6a, 0x7f70, 0x72eb, 0x577c, + 0x30b2, 0x0396, 0xd604, 0xade4, 0x906c, 0x8170, 0x82e1, 0x9490, + 0xb430, 0xdda8, 0x0b94, 0x3800, 0x5d28, 0x7638, 0x7ff0, 0x790c, + 0x6273, 0x3f12, 0x1382, 0xe56a, 0xbac5, 0x991c, 0x84ce, 0x807e, + 0x8cba, 0xa7ed, 0xce8e, 0xfb9a, 0x2938, 0x517d, 0x6f2e, 0x7e71, + 0x7d4a, 0x6be1, 0x4c77, 0x2320, 0xf53b, 0xc8bb, 0xa367, 0x8a19, + 0x8018, 0x86b1, 0x9d09, 0xc039, 0xebb1, 0x19ca, 0x448c, 0x6668, + 0x7af9, 0x7f94, 0x73a0, 0x58aa, 0x3231, 0x0535, 0xd78d, 0xaf24, + 0x913a, 0x81b0, 0x828c, 0x93b0, 0xb2e3, 0xdc19, 0x09f6, 0x368a, + 0x5c09, 0x7596, 0x7fe0, 0x7991, 0x637a, 0x407a, 0x151c, 0xe701, + 0xbc24, 0x9a15, 0x8541, 0x805c, 0x8c08, 0xa6c1, 0xcd10, 0xf9fb, + 0x27ae, 0x503b, 0x6e5e, 0x7e2d, 0x7d9d, 0x6cbe, 0x4dc2, 0x24ae, + 0xf6d9, 0xca33, 0xa488, 0x8abd, 0x802a, 0x862f, 0x9c03, 0xbed2, + 0xea17, 0x1833, 0x432c, 0x656c, 0x7a83, 0x7fb3, 0x744f, 0x59d3, + 0x33ae, 0x06d4, 0xd918, 0xb068, 0x920c, 0x81f6, 0x823c, 0x92d5, + 0xb199, 0xda8b, 0x0858, 0x3511, 0x5ae6, 0x74ef, 0x7fcb, 0x7a10, + 0x647e, 0x41e0, 0x16b5, 0xe899, 0xbd85, 0x9b13, 0x85ba, 0x8040, + 0x8b5a, 0xa599, 0xcb94, 0xf85c, 0x2622, 0x4ef5, 0x6d89, 0x7de5, + 0x7dea, 0x6d97, 0x4f0b, 0x263c, 0xf877, 0xcbad, 0xa5ac, 0x8b66, + 0x8041, 0x85b2, 0x9b02, 0xbd6e, 0xe87e, 0x169b, 0x41c9, 0x646d, + 0x7a08, 0x7fcd, 0x74fa, 0x5af9, 0x3529, 0x0873, 0xdaa5, 0xb1af, + 0x92e3, 0x8241, 0x81f1, 0x91fe, 0xb053, 0xd8fe, 0x06b9, 0x3396, + 0x59c0, 0x7444, 0x7fb1, 0x7a8b, 0x657d, 0x4343, 0x184e, 0xea32, + 0xbeea, 0x9c14, 0x8637, 0x8028, 0x8ab2, 0xa475, 0xca1a, 0xf6be, + 0x2494, 0x4dad, 0x6cb0, 0x7d97, 0x7e32, 0x6e6b, 0x5050, 0x27c7, + 0xfa16, 0xcd29, 0xa6d5, 0x8c13, 0x805e, 0x853a, 0x9a05, 0xbc0d, + 0xe6e7, 0x1501, 0x4063, 0x6369, 0x7988, 0x7fe1, 0x75a1, 0x5c1c, + 0x36a2, 0x0a11, 0xdc33, 0xb2f9, 0x93bf, 0x8291, 0x81ac, 0x912c, + 0xaf0f, 0xd773, 0x051a, 0x3218, 0x5896, 0x7394, 0x7f92, 0x7b00, + 0x6678, 0x44a3, 0x19e5, 0xebcc, 0xc051, 0x9d1a, 0x86b9, 0x8017, + 0x8a0e, 0xa354, 0xc8a2, 0xf520, 0x2306, 0x4c61, 0x6bd2, 0x7d45, + 0x7e75, 0x6f3b, 0x5191, 0x2951, 0xfbb5, 0xcea7, 0xa800, 0x8cc6, + 0x8080, 0x84c7, 0x990c, 0xbaae, 0xe550, 0x1367, 0x3efb, 0x6262, + 0x7904, 0x7ff0, 0x7642, 0x5d3a, 0x3819, 0x0baf, 0xddc2, 0xb446, + 0x949e, 0x82e7, 0x816c, 0x905f, 0xadcf, 0xd5ea, 0x037b, 0x3099, + 0x5768, 0x72df, 0x7f6d, 0x7b71, 0x676f, 0x4600, 0x1b7b, 0xed66, + 0xc1ba, 0x9e24, 0x8741, 0x800a, 0x896f, 0xa238, 0xc72d, 0xf382, + 0x2175, 0x4b12, 0x6af0, 0x7ced, 0x7eb3, 0x7006, 0x52d0, 0x2ada, + 0xfd55, 0xd027, 0xa930, 0x8d7d, 0x80a7, 0x8459, 0x9817, 0xb952, + 0xe3ba, 0x11cc, 0x3d90, 0x6156, 0x787a, 0x7ffa, 0x76df, 0x5e55, + 0x398d, 0x0d4d, 0xdf53, 0xb597, 0x9583, 0x8341, 0x8131, 0x8f96, + 0xac92, 0xd463, 0x01dc, 0x2f18, 0x5637, 0x7226, 0x7f43, 0x7bdc, + 0x6861, 0x475a, 0x1d11, 0xef02, 0xc327, 0x9f32, 0x87cd, 0x8003, + 0x88d5, 0xa11f, 0xc5ba, 0xf1e5, 0x1fe4, 0x49c0, 0x6a0a, 0x7c90, + 0x7eeb, 0x70cd, 0x540b, 0x2c60, 0xfef4, 0xd1aa, 0xaa63, 0x8e39, + 0x80d4, 0x83f0, 0x9727, 0xb7f9, 0xe225, 0x1030, 0x3c22, 0x6046, + 0x77eb, 0x7fff, 0x7776, 0x5f6c, 0x3aff, 0x0eea, 0xe0e6, 0xb6ea, + 0x966b, 0x83a1, 0x80fb, 0x8ed1, 0xab59, 0xd2dd, 0x003c, 0x2d95, + 0x5502, 0x7167, 0x7f14, 0x7c42, 0x6950, 0x48b2, 0x1ea4, 0xf09e, + 0xc495, 0xa043, 0x885e, 0x8001, 0x8840, 0xa00a, 0xc449, 0xf048, + 0x1e51, 0x486b, 0x691f, 0x7c2e, 0x7f1e, 0x718f, 0x5543, 0x2de5, + 0x0092, 0xd32e, 0xab9a, 0x8efa, 0x8105, 0x838c, 0x963b, 0xb6a4, + 0xe092, 0x0e94, 0x3ab2, 0x5f32, 0x7757, 0x7fff, 0x7809, 0x607f, + 0x3c6e, 0x1086, 0xe279, 0xb841, 0x9758, 0x8405, 0x80ca, 0x8e12, + 0xaa23, 0xd159, 0xfe9e, 0x2c0f, 0x53ca, 0x70a4, 0x7ee0, 0x7ca3, + 0x6a3a, 0x4a06, 0x2037, 0xf23b, 0xc607, 0xa159, 0x88f5, 0x8004, + 0x87b0, 0x9ef9, 0xc2db, 0xeeac, 0x1cbd, 0x4713, 0x682f, 0x7bc6, + 0x7f4c, 0x724c, 0x5677, 0x2f68, 0x0232, 0xd4b4, 0xacd4, 0x8fbf, + 0x813c, 0x832e, 0x9553, 0xb551, 0xdf00, 0x0cf7, 0x3940, 0x5e1b, + 0x76bf, 0x7ff9, 0x7897, 0x618e, 0x3ddb, 0x1221, 0xe40e, 0xb99a, + 0x984a, 0x846f, 0x809f, 0x8d57, 0xa8f1, 0xcfd7, 0xfcfe, 0x2a88, + 0x528e, 0x6fdd, 0x7ea6, 0x7cff, 0x6b1f, 0x4b58, 0x21c9, 0xf3d8, + 0xc77a, 0xa273, 0x8990, 0x800c, 0x8724, 0x9dec, 0xc16f, 0xed11, + 0x1b27, 0x45b8, 0x673c, 0x7b5a, 0x7f75, 0x7305, 0x57a7, 0x30e9, + 0x03d1, 0xd63c, 0xae11, 0x9089, 0x8179, 0x82d4, 0x9470, 0xb401, + 0xdd6f, 0x0b59, 0x37cb, 0x5cff, 0x7621, 0x7fee, 0x7920, 0x6299, + 0x3f46, 0x13bc, 0xe5a4, 0xbaf7, 0x993f, 0x84de, 0x8079, 0x8ca0, + 0xa7c2, 0xce58, 0xfb5f, 0x2900, 0x514f, 0x6f10, 0x7e67, 0x7d56, + 0x6c00, 0x4ca6, 0x2359, 0xf576, 0xc8f0, 0xa390, 0x8a30, 0x801a, + 0x869e, 0x9ce3, 0xc006, 0xeb77, 0x1991, 0x445a, 0x6644, 0x7ae8, + 0x7f99, 0x73b9, 0x58d4, 0x3268, 0x0570, 0xd7c5, 0xaf52, 0x9157, + 0x81ba, 0x8280, 0x9391, 0xb2b4, 0xdbe0, 0x09bb, 0x3654, 0x5be0, + 0x757f, 0x7fdd, 0x79a3, 0x63a0, 0x40ae, 0x1556, 0xe73b, 0xbc56, + 0x9a39, 0x8552, 0x8058, 0x8bef, 0xa697, 0xccda, 0xf9c0, 0x2775, + 0x500c, 0x6e40, 0x7e23, 0x7da8, 0x6cdd, 0x4df1, 0x24e7, 0xf714, + 0xca68, 0xa4b1, 0x8ad4, 0x802d, 0x861d, 0x9bdf, 0xbea0, 0xe9dd, + 0x17f9, 0x42f9, 0x6548, 0x7a72, 0x7fb7, 0x7468, 0x59fd, 0x33e4, + 0x070f, 0xd950, 0xb096, 0x922a, 0x8200, 0x8231, 0x92b6, 0xb16b, + 0xda52, 0x081d, 0x34db, 0x5abd, 0x74d7, 0x7fc8, 0x7a22, 0x64a2, + 0x4213, 0x16ef, 0xe8d3, 0xbdb8, 0x9b37, 0x85cb, 0x803c, 0x8b42, + 0xa56f, 0xcb5e, 0xf821, 0x25e9, 0x4ec7, 0x6d6a, 0x7dda, 0x7df4, + 0x6db5, 0x4f39, 0x2674, 0xf8b2, 0xcbe3, 0xa5d6, 0x8b7e, 0x8045, + 0x85a0, 0x9ade, 0xbd3c, 0xe844, 0x1660, 0x4196, 0x6448, 0x79f6, + 0x7fd0, 0x7512, 0x5b23, 0x355f, 0x08ae, 0xdadd, 0xb1dd, 0x9302, + 0x824c, 0x81e7, 0x91e0, 0xb024, 0xd8c6, 0x067e, 0x3360, 0x5996, + 0x742b, 0x7fad, 0x7a9c, 0x65a1, 0x4375, 0x1888, 0xea6c, 0xbf1d, + 0x9c39, 0x8649, 0x8026, 0x8a9a, 0xa44c, 0xc9e4, 0xf683, 0x245c, + 0x4d7e, 0x6c90, 0x7d8c, 0x7e3c, 0x6e89, 0x507e, 0x2800, 0xfa51, + 0xcd5f, 0xa6ff, 0x8c2c, 0x8063, 0x8529, 0x99e1, 0xbbdb, 0xe6ad, + 0x14c7, 0x4030, 0x6344, 0x7976, 0x7fe4, 0x75b8, 0x5c45, 0x36d8, + 0x0a4c, 0xdc6c, 0xb328, 0x93de, 0x829d, 0x81a2, 0x910f, 0xaee1, + 0xd73b, 0x04df, 0x31e2, 0x586b, 0x737b, 0x7f8d, 0x7b11, 0x669b, + 0x44d5, 0x1a1f, 0xec06, 0xc084, 0x9d40, 0x86cc, 0x8014, 0x89f7, + 0xa32c, 0xc86d, 0xf4e5, 0x22cd, 0x4c31, 0x6bb2, 0x7d38, 0x7e7e, + 0x6f58, 0x51bf, 0x2989, 0xfbf0, 0xcede, 0xa82b, 0x8ce0, 0x8085, + 0x84b7, 0x98e9, 0xba7c, 0xe516, 0x132d, 0x3ec7, 0x623c, 0x78f0, + 0x7ff2, 0x7659, 0x5d63, 0x384e, 0x0bea, 0xddfb, 0xb476, 0x94bf, + 0x82f3, 0x8163, 0x9042, 0xada2, 0xd5b2, 0x0340, 0x3062, 0x573d, + 0x72c5, 0x7f67, 0x7b80, 0x6792, 0x4632, 0x1bb5, 0xeda1, 0xc1ee, + 0x9e4a, 0x8754, 0x8009, 0x8959, 0xa210, 0xc6f8, 0xf347, 0x213c, + 0x4ae2, 0x6acf, 0x7ce0, 0x7ebb, 0x7023, 0x52fd, 0x2b11, 0xfd90, + 0xd05e, 0xa95b, 0x8d98, 0x80ad, 0x844a, 0x97f5, 0xb921, 0xe380, + 0x1191, 0x3d5c, 0x612f, 0x7866, 0x7ffb, 0x76f4, 0x5e7d, 0x39c2, + 0x0d87, 0xdf8c, 0xb5c7, 0x95a4, 0x834e, 0x8129, 0x8f79, 0xac65, + 0xd42b, 0x01a1, 0x2ee1, 0x560b, 0x720b, 0x7f3d, 0x7beb, 0x6884, + 0x478c, 0x1d4a, 0xef3c, 0xc35b, 0x9f58, 0x87e1, 0x8002, 0x88bf, + 0xa0f7, 0xc585, 0xf1aa, 0x1faa, 0x4990, 0x69e8, 0x7c82, 0x7ef3, + 0x70e9, 0x5438, 0x2c98, 0xff2f, 0xd1e1, 0xaa8f, 0x8e54, 0x80db, + 0x83e2, 0x9705, 0xb7c9, 0xe1ec, 0x0ff6, 0x3bee, 0x601f, 0x77d6, + 0x7fff, 0x778b, 0x5f93, 0x3b33, 0x0f24, 0xe11f, 0xb71b, 0x968d, + 0x83af, 0x80f3, 0x8eb6, 0xab2c, 0xd2a6, 0x0001, 0x2d5d, 0x54d6, + 0x714c, 0x7f0d, 0x7c50, 0x6971, 0x48e3, 0x1ede, 0xf0d9, 0xc4ca, + 0xa06b, 0x8873, 0x8001, 0x882b, 0x9fe3, 0xc415, 0xf00e, 0x1e17, + 0x483a, 0x68fd, 0x7c1f, 0x7f25, 0x71aa, 0x556f, 0x2e1c, 0x00ce, + 0xd365, 0xabc6, 0x8f16, 0x810d, 0x837f, 0x9619, 0xb673, 0xe059, + 0x0e59, 0x3a7e, 0x5f0b, 0x7742, 0x7ffe, 0x781d, 0x60a6, 0x3ca2, + 0x10c0, 0xe2b3, 0xb872, 0x977a, 0x8414, 0x80c4, 0x8df7, 0xa9f7, + 0xd122, 0xfe63, 0x2bd8, 0x539d, 0x7088, 0x7ed8, 0x7cb1, 0x6a5b, + 0x4a36, 0x2070, 0xf275, 0xc63b, 0xa181, 0x890a, 0x8005, 0x879b, + 0x9ed3, 0xc2a7, 0xee72, 0x1c83, 0x46e2, 0x680d, 0x7bb7, 0x7f52, + 0x7267, 0x56a2, 0x2f9f, 0x026d, 0xd4ec, 0xad01, 0x8fdb, 0x8145, + 0x8321, 0x9532, 0xb521, 0xdec7, 0x0cbc, 0x390b, 0x5df3, 0x76a8, + 0x7ff7, 0x78aa, 0x61b4, 0x3e0f, 0x125c, 0xe448, 0xb9cc, 0x986c, + 0x847f, 0x8099, 0x8d3c, 0xa8c5, 0xcfa1, 0xfcc3, 0x2a51, 0x5261, + 0x6fc0, 0x7e9e, 0x7d0c, 0x6b40, 0x4b87, 0x2202, 0xf413, 0xc7af, + 0xa29b, 0x89a6, 0x800e, 0x8711, 0x9dc6, 0xc13c, 0xecd7, 0x1aed, + 0x4586, 0x6719, 0x7b4a, 0x7f7a, 0x731f, 0x57d2, 0x311f, 0x040c, + 0xd674, 0xae3f, 0x90a6, 0x8182, 0x82c8, 0x9450, 0xb3d1, 0xdd36, + 0x0b1e, 0x3796, 0x5cd7, 0x760a, 0x7fec, 0x7933, 0x62be, 0x3f79, + 0x13f7, 0xe5de, 0xbb28, 0x9963, 0x84ee, 0x8074, 0x8c87, 0xa797, + 0xce21, 0xfb24, 0x28c8, 0x5121, 0x6ef3, 0x7e5e, 0x7d62, 0x6c20, + 0x4cd5, 0x2391, 0xf5b1, 0xc925, 0xa3b9, 0x8a47, 0x801c, 0x868b, + 0x9cbe, 0xbfd3, 0xeb3c, 0x1957, 0x4428, 0x6621, 0x7ad8, 0x7f9d, + 0x73d2, 0x58ff, 0x329e, 0x05ab, 0xd7fd, 0xaf80, 0x9175, 0x81c4, + 0x8275, 0x9371, 0xb285, 0xdba7, 0x0980, 0x361f, 0x5bb7, 0x7567, + 0x7fdb, 0x79b6, 0x63c5, 0x40e1, 0x1591, 0xe775, 0xbc88, 0x9a5d, + 0x8563, 0x8053, 0x8bd6, 0xa66d, 0xcca3, 0xf985, 0x273d, 0x4fde, + 0x6e22, 0x7e19, 0x7db3, 0x6cfc, 0x4e20, 0x2520, 0xf74f, 0xca9e, + 0xa4db, 0x8aec, 0x8030, 0x860b, 0x9bba, 0xbe6d, 0xe9a3, 0x17bf, + 0x42c7, 0x6524, 0x7a61, 0x7fbb, 0x7481, 0x5a27, 0x341b, 0x074a, + 0xd989, 0xb0c4, 0x9249, 0x820b, 0x8226, 0x9297, 0xb13c, 0xda1a, + 0x07e2, 0x34a5, 0x5a93, 0x74bf, 0x7fc4, 0x7a34, 0x64c7, 0x4245, + 0x172a, 0xe90d, 0xbdeb, 0x9b5c, 0x85dd, 0x8038, 0x8b2a, 0xa546, + 0xcb28, 0xf7e6, 0x25b1, 0x4e98, 0x6d4c, 0x7dcf, 0x7dff, 0x6dd4, + 0x4f67, 0x26ac, 0xf8ed, 0xcc19, 0xa600, 0x8b97, 0x8049, 0x858f, + 0x9aba, 0xbd09, 0xe80a, 0x1626, 0x4163, 0x6424, 0x79e4, 0x7fd3, + 0x752a, 0x5b4c, 0x3595, 0x08e9, 0xdb16, 0xb20c, 0x9321, 0x8257, + 0x81dd, 0x91c2, 0xaff6, 0xd88e, 0x0643, 0x3329, 0x596c, 0x7412, + 0x7fa9, 0x7aad, 0x65c5, 0x43a7, 0x18c2, 0xeaa6, 0xbf50, 0x9c5e, + 0x865c, 0x8023, 0x8a83, 0xa422, 0xc9af, 0xf648, 0x2423, 0x4d4f, + 0x6c71, 0x7d80, 0x7e46, 0x6ea7, 0x50ac, 0x2838, 0xfa8c, 0xcd95, + 0xa72a, 0x8c46, 0x8067, 0x8518, 0x99be, 0xbba9, 0xe673, 0x148d, + 0x3ffd, 0x631f, 0x7963, 0x7fe6, 0x75cf, 0x5c6e, 0x370d, 0x0a87, + 0xdca4, 0xb357, 0x93fe, 0x82a9, 0x8199, 0x90f1, 0xaeb4, 0xd703, + 0x04a4, 0x31ab, 0x5840, 0x7361, 0x7f88, 0x7b21, 0x66bf, 0x4507, + 0x1a59, 0xec41, 0xc0b7, 0x9d65, 0x86df, 0x8012, 0x89e0, 0xa303, + 0xc838, 0xf4aa, 0x2294, 0x4c02, 0x6b92, 0x7d2c, 0x7e87, 0x6f75, + 0x51ec, 0x29c1, 0xfc2c, 0xcf14, 0xa856, 0x8cfa, 0x808b, 0x84a7, + 0x98c6, 0xba4b, 0xe4dc, 0x12f2, 0x3e94, 0x6216, 0x78dd, 0x7ff4, + 0x766f, 0x5d8b, 0x3883, 0x0c25, 0xde34, 0xb4a6, 0x94df, 0x8300, + 0x815a, 0x9025, 0xad74, 0xd57b, 0x0305, 0x302c, 0x5712, 0x72ab, + 0x7f62, 0x7b90, 0x67b4, 0x4663, 0x1bef, 0xeddb, 0xc222, 0x9e70, + 0x8768, 0x8007, 0x8943, 0xa1e8, 0xc6c3, 0xf30c, 0x2103, 0x4ab2, + 0x6aaf, 0x7cd3, 0x7ec3, 0x703f, 0x532a, 0x2b49, 0xfdcb, 0xd095, + 0xa987, 0x8db2, 0x80b3, 0x843b, 0x97d2, 0xb8f0, 0xe347, 0x1157, + 0x3d28, 0x6109, 0x7852, 0x7ffc, 0x770a, 0x5ea5, 0x39f7, 0x0dc2, + 0xdfc6, 0xb5f7, 0x95c4, 0x835c, 0x8121, 0x8f5d, 0xac39, 0xd3f4, + 0x0165, 0x2eaa, 0x55df, 0x71f0, 0x7f36, 0x7bfa, 0x68a6, 0x47bd, + 0x1d84, 0xef77, 0xc38f, 0x9f7f, 0x87f6, 0x8001, 0x88aa, 0xa0d0, + 0xc551, 0xf16f, 0x1f71, 0x495f, 0x69c7, 0x7c74, 0x7efa, 0x7105, + 0x5464, 0x2ccf, 0xff6a, 0xd218, 0xaabb, 0x8e6f, 0x80e1, 0x83d3, + 0x96e3, 0xb798, 0xe1b2, 0x0fbb, 0x3bba, 0x5ff8, 0x77c1, 0x7fff, + 0x77a0, 0x5fbb, 0x3b68, 0x0f5f, 0xe158, 0xb74b, 0x96ae, 0x83bd, + 0x80ec, 0x8e9a, 0xab00, 0xd26f, 0xffc7, 0x2d26, 0x54aa, 0x7130, + 0x7f06, 0x7c5e, 0x6993, 0x4913, 0x1f17, 0xf113, 0xc4fe, 0xa092, + 0x8889, 0x8001, 0x8816, 0x9fbc, 0xc3e1, 0xefd3, 0x1dde, 0x4809, + 0x68db, 0x7c11, 0x7f2c, 0x71c5, 0x559b, 0x2e53, 0x0109, 0xd39d, + 0xabf3, 0x8f31, 0x8115, 0x8371, 0x95f8, 0xb643, 0xe01f, 0x0e1e, + 0x3a49, 0x5ee3, 0x772c, 0x7ffd, 0x7832, 0x60cc, 0x3cd6, 0x10fb, + 0xe2ec, 0xb8a3, 0x979d, 0x8423, 0x80bd, 0x8ddc, 0xa9cb, 0xd0eb, + 0xfe28, 0x2ba0, 0x5370, 0x706c, 0x7ed0, 0x7cbe, 0x6a7b, 0x4a67, + 0x20aa, 0xf2b0, 0xc670, 0xa1a9, 0x8920, 0x8006, 0x8787, 0x9eac, + 0xc273, 0xee37, 0x1c49, 0x46b0, 0x67eb, 0x7ba8, 0x7f58, 0x7281, + 0x56ce, 0x2fd6, 0x02a8, 0xd523, 0xad2e, 0x8ff8, 0x814d, 0x8314, + 0x9512, 0xb4f1, 0xde8e, 0x0c81, 0x38d6, 0x5dca, 0x7692, 0x7ff6, + 0x78be, 0x61da, 0x3e43, 0x1296, 0xe481, 0xb9fd, 0x988f, 0x848e, + 0x8093, 0x8d22, 0xa89a, 0xcf6a, 0xfc88, 0x2a19, 0x5234, 0x6fa3, + 0x7e95, 0x7d19, 0x6b60, 0x4bb7, 0x223b, 0xf44e, 0xc7e4, 0xa2c3, + 0x89bd, 0x8010, 0x86fe, 0x9da0, 0xc108, 0xec9c, 0x1ab4, 0x4555 +}; + +float32_t transform_fft_f32_inputs[TRANSFORM_MAX_FFT_LEN * 2] = +{ + 43.0264275639, -17.0525215570, -94.8488973910, -8.1924989580, 7.2830326091, 66.8368719314, 33.9778190671, 117.8652289772, + -129.6077797465, -14.6420815368, 18.0239223278, 20.6760530292, 55.0375037651, 1.8674609862, -85.6534302408, -33.5750364909, + 29.2110949614, 110.4727049460, -94.1914619387, -1.4084169343, 83.5181653041, 47.3073514127, -13.3420621181, 30.3389699104, + 12.1188124277, 100.9730921941, -114.0146362390, -77.5823200409, 37.2019034618, 40.0026301128, -58.3387276630, -34.9472398600, + -5.1169678311, -87.7660091118, -150.5888601131, 56.0349370503, 50.2168884079, -74.2313236767, 22.3648603560, -6.8676387051, + 74.8957303680, -90.1292012823, -55.1436241586, -66.6732976100, -6.7918147615, 7.7612697081, 35.7892605979, -20.0470508830, + 41.8369017546, -143.7378056984, -41.9127158600, -108.3531841158, -57.1917422289, -124.2808828105, 38.9316388820, -77.9212517405, + 37.1990818377, -28.9545952748, -155.6371057564, 45.8088886393, 36.2537018275, -6.5727656016, -104.2070491921, 45.5583813729, + -19.7674717059, -80.4802190947, -1.4444563441, -42.2142256438, 36.6546339194, -57.0866498590, 44.4677067511, 65.7285753407, + -103.8158864647, 25.4348723711, -153.5419639389, 39.3608409474, 49.1658103436, 79.5570602275, 75.2944095996, 58.9394700746, + -53.1018534392, 33.4172444014, 35.6224682287, -64.4353396418, -125.8464291251, -47.6072111617, -26.2177687594, -12.0061322096, + -17.7887967585, -28.2926175090, -62.0691715749, 40.5098573604, -191.1123732593, 119.6750713043, 19.6182375803, -26.7615252921, + 2.2957847015, -108.3436451287, -50.5906164995, -5.6360985100, -11.6772204201, -84.2765293757, -60.9317810068, 82.0446350218, + -70.2048296348, 72.8738253222, 60.2450218115, 114.2741231228, 46.8180775285, 6.9915412654, -8.9909197429, -78.9165936808, + 66.4731535459, -68.4235455651, -79.8254597080, -10.6308477115, -62.6161569330, -55.7744410292, -11.8408366528, 98.1034940997, + 35.8213741877, -54.4694482732, 86.9631830044, -53.0343838122, -47.4898642865, -47.2010929590, -31.3312639685, -23.0908245172, + 12.0258009869, -5.1098204703, -9.8420230737, -107.3328761158, 44.6810431959, -17.9083820345, -60.9753512872, -7.5915088994, + 17.2250813329, 57.9176125648, 124.3004161362, -63.1950908493, 120.5788885640, -44.1734238117, -91.7408095116, -43.5696066595, + -49.9560710099, -167.8513443296, -70.9437505499, -46.4109705355, -64.2264526456, -13.9995803916, -100.9548186356, 9.9101010575, + -50.0615130815, -55.7590145012, -60.3195153388, 61.7913378549, -102.0850899209, 53.2360193126, -25.8997883369, 75.1445512333, + -113.8148602310, 17.8027281119, -19.5006822722, -44.2169628471, 107.5017084384, -113.7909124666, -43.9735396033, 7.6880981388, + 46.7384653508, 9.9047443751, 81.8646964362, 132.3812863877, -95.6959050236, -68.5015813484, 65.8586404494, 18.5039353889, + -30.1786166621, -90.3098515667, -22.9356228552, -20.5778272423, -2.2127786675, -35.4418447703, -51.8722915974, -107.9024439078, + -51.5940748232, -51.7463262677, 74.2795485984, 94.2205022462, 9.7016384049, -47.3556083155, -36.7822314478, -151.6455525363, + -15.7183814485, 78.2063383182, 0.1516414969, 37.9304181609, 20.6185902740, -22.2164106778, 6.1160554677, 2.4061326953, + -111.6681824598, -60.0858917090, 75.1698614693, -76.5787410444, 28.3391655715, -2.4946186443, -68.0378899682, 104.0893199171, + -51.8319647254, 38.8521710524, 75.9114239564, 73.9206172905, -103.2533029987, 6.9002718274, -36.6346436319, -25.1990926265, + 1.5852145953, -50.6438436795, 21.5018844428, -151.9305562846, -51.7326681814, 21.4475994143, 42.2564011921, -74.0520586926, + 49.7370635809, -13.2957534126, 36.6746826778, -31.7005492589, 148.4894964268, 79.7890632353, 16.8856024809, 16.1690460177, + 39.2665169484, 117.2461167794, -37.4827984831, -47.8387803604, -95.7025286193, 34.3058214285, -124.9536456028, 56.1640195764, + 94.3636873606, 35.3992852810, -38.3920852159, -100.5738062016, -29.7837022314, 42.9133913996, -34.2715618187, -14.3589115627, + -16.5935468750, 20.4574192236, -88.7897972666, -38.6285080386, 53.3203422726, 98.5991486746, 122.7305462474, 67.7902817187, + 5.1764117389, 5.0632821624, 21.9288789574, -78.3140512638, -21.2069682335, 23.6342010925, 34.4445769455, 59.1346766615, + 28.9978778000, 39.8121180845, -17.1650033520, -56.9174900874, 17.8157086148, -112.8801457350, -122.4019040408, 140.8669393157, + -65.4664329639, 40.6952775518, 32.7260891658, -43.2565155866, 19.3945751928, -20.1815002000, -67.6601711640, -18.1921178207, + -35.6802153684, 49.9550290306, 131.4925251016, -31.2940938167, -5.2848453344, -109.5580577933, 20.2437599390, -8.8782958734, + 54.1836717264, 7.2555852190, -3.5698316137, -51.9236786262, 6.7861547980, -104.4814551670, 45.8458629668, 70.0890876844, + 38.3572837740, 61.8024165129, 68.0176962024, -12.8193934080, -21.4661610917, -0.9377108815, -74.2100679061, 71.0490808147, + 91.9813889497, -14.5797640164, 3.5036749129, -138.3605478356, -48.1501349794, -16.0636922482, -12.1334197606, 15.0562207637, + -34.0878176054, 55.1075126157, 97.3829871877, 0.2053358099, -94.8713267382, 51.5460954054, 21.2966946363, 58.1331025047, + -23.4599044132, -19.3315856528, -8.4497193577, -1.9594679356, -33.1906549336, -144.6825417978, -57.1218958072, 35.7353406097, + 61.4666549819, 14.6536253128, 82.1632196866, -44.6230161723, -91.1022589278, -18.5737673927, -136.8975612334, 56.9606788003, + 70.7059960183, -68.2829345081, -10.2629800455, -53.6385325047, -68.7928766204, 88.2444688302, 83.1412324801, -102.9206928160, + -68.2329763159, -69.7552955469, 108.2132269009, -28.2582329307, 5.6685898328, -36.0392956840, 43.3269513128, -8.6436416796, + -16.5054886972, 11.5008791788, 39.6923606683, -28.9039554061, 13.5938214364, -23.6296332202, 49.1171161163, 53.1636857935, + -62.9672053166, -54.2594757384, 48.3838956696, 8.0469071555, -33.6472086213, -120.5381752144, 55.0880453111, 17.8990740563, + 144.9402232336, 101.7886229203, -73.3666393712, -16.4721379138, -12.7447935685, 101.8245160983, -49.7026860415, -15.1227790364, + 65.7430288442, -131.8695390036, 10.2750933946, 90.9752774838, -26.5859990591, -95.6962772568, 76.2174589344, 24.8796848060, + -38.8938223046, 54.1687774852, -37.3585968996, -34.6848570502, 33.0151011570, -55.8345877671, -3.9009101671, -31.5024971691, + -9.6863895491, 91.8719195957, -58.9993249744, -25.6887030614, -8.0829472205, 4.6386491741, -71.4019697167, -21.3734669095, + 86.2079144404, 79.6823974266, -0.0910915997, 44.8067718095, 58.7204020766, 72.6856808976, -50.3373732478, -116.1175365534, + -15.0884909384, 5.4593772059, -63.6553527905, 37.3460388205, -32.2399421679, 95.7569350513, -7.3700141964, -56.0370832967, + -41.7377150439, -42.0042856519, 12.5134312941, 93.7845584531, -32.4801087157, -33.3976050318, -24.2252126001, -46.3199064467, + -20.3704610276, 15.8571376404, 88.9127217235, -33.1132582267, -1.0005675836, -28.1780471904, 150.9349379135, 38.0600520828, + 36.4338677563, -3.3709201641, 29.7709773016, 16.5064119077, 21.3147729463, 110.6714300904, 18.8406036507, 14.8963298097, + 50.9975960392, 16.3991140350, -194.0805845907, -41.6723945839, -74.8991127408, -6.4587655805, -0.6883628218, -49.8709647175, + 194.2265120473, 64.3043624521, 16.0040882780, 68.4032551772, -43.4050313128, 84.6826289824, -28.1357565943, 134.6895584120, + -7.9746152680, -95.6692886462, -48.9444370342, 79.4479343188, -50.5345228122, 52.4800633307, -14.7735051703, -20.1510237050, + 22.5049816980, 64.4191999102, 24.8385648232, 99.4265041360, 62.0189508473, -28.3892600378, -109.8842008564, -79.0407483407, + 18.3408112020, 49.1650536089, 31.5419844924, -36.1160722679, -132.9148081329, 10.4053531567, -129.2463715470, -43.4602207151, + -24.2420653292, 91.5388317556, 21.4762248190, -44.3810909139, 18.4098011282, -45.8691164539, -20.9831197962, 16.2076792914, + 66.0224147666, -13.6794615513, 101.2163279622, -62.4462618603, 22.2040981785, -52.3208382802, -24.7909079016, 58.5150375093, + 18.8569705105, -55.6083430939, 131.0273367422, -34.5209015065, 121.4357296573, -77.2590299593, -51.5929566898, 5.0247131098, + -23.8451707592, -4.5912313547, 31.1387246821, 61.7019310824, 49.1912429744, -50.5836913031, -74.8182600630, -21.6209317022, + 20.9409464654, -72.7870824583, -28.3530746820, -45.0794425434, -13.4910629905, -62.0158772255, -34.1421181246, 44.2844972784, + 8.4213193211, 79.9349022793, 60.0160502260, 32.2272994080, -72.2893887746, 17.3063698247, -134.6335742431, 64.6499736261, + 7.1411921919, -37.5517577873, 6.2405670930, 117.1920927305, 128.7420689815, -3.1556854963, -13.4100422909, -11.9336372907, + -8.6022400553, -102.0033506666, -78.4696575074, 15.0765861403, -111.5219718576, -13.4162786508, 38.2437013694, 61.1637732561, + -34.4804160003, 107.4438003830, -79.4193067813, -81.1842853968, -26.2622970331, 132.3205425408, -119.1464268477, 67.3048866598, + 103.3266736715, -58.1865815617, 27.6231908601, -11.2004371750, 26.0340617206, 12.5696123916, 0.6442714420, -30.7393043544, + 1.5314955897, 49.9110088250, -106.1358721920, 51.1608329944, -32.8684239794, -27.7215905745, -11.6450303367, -36.7731678028, + 59.9383486599, -4.6301990580, 5.0361682939, -10.5669407980, 124.0908762205, 35.8305364082, -123.6216777114, -74.2569079167, + -56.7651776816, 16.0736385582, 23.5030632215, -110.6764295938, 44.3086821806, 9.4452708243, 5.3300080251, 39.0483916714, + 151.4550562868, 62.8957092621, -116.8103461233, 5.1129927759, -33.2252515135, -9.4522506046, 22.7026048372, -15.5264414569, + 71.2087620034, 19.1191568332, 50.3019546809, -5.6096922409, 22.9344126462, -7.7591876203, 31.8949515564, -58.4253952381, + 66.4341297173, -19.0583083044, 96.7695087855, 20.4934280047, 4.9544603116, -20.8288135920, -173.2659655408, -62.4883621640, + -48.5528422703, 12.1437504278, 60.2482234666, -19.6072312919, -34.6320214291, 129.0089698963, -50.9042160618, 98.3952661477, + -4.7051792479, -13.1768910826, 69.5138802139, 58.5748201565, -45.9385652563, 151.7952104306, 34.2541941013, -58.0417838381, + 28.1480473670, 46.4006562684, 97.7001828545, 4.0855607626, -32.6097018162, 16.8913949959, 105.7266202978, -89.3978374651, + -60.9338593128, -41.2220734230, 49.9393070783, 95.0974764854, 49.2498366456, 58.6214364590, 34.1113830569, 45.6634098874, + -22.5356086770, -97.1978653617, 86.5565049535, 70.6118545777, -30.6978082909, 118.7238621666, 14.5922386932, 11.3449652072, + 65.6007783405, 82.6369678204, -52.0390492248, -47.0160551227, -95.5142448634, 99.7162626888, -36.5523815090, -42.8042935534, + 68.3566199798, -13.8451547552, -71.1629911780, 36.2989433752, -32.4867163365, 112.4079947071, -75.6295117422, 47.5276421639, + 51.8078250755, -26.8715188457, -9.6291144797, 40.1999849640, -38.4634033246, 40.9764960915, -26.1715730268, 36.5996396515, + -26.9924731886, 53.7879986570, -83.1658398348, 23.6381378489, 43.8794937753, -55.4133836419, 90.0266130838, 14.1036181982, + -18.1225736715, 85.1363181151, -62.5970846379, -18.5291947838, -25.7341986703, -49.7061342931, -59.0442763971, 50.8960636803, + -87.6471123430, -36.7217762531, 22.5952364054, 11.1107885650, -0.5377327229, 160.8145792630, 73.3103441505, 10.1656872354, + -50.4554350397, -57.3478171016, -15.4201715357, -26.9135446491, -4.9891264771, -37.0226770057, -80.9919535641, 50.4418660876, + -25.8517575250, -69.9538258421, -17.5730160671, 15.9405836751, 113.9545230349, -46.1040379057, -94.2458635014, -69.0338522452, + 43.5813790265, 107.1836101171, -55.1012654323, -77.1529555887, -33.1530320656, -94.5582659641, -53.6837586872, 27.0680381378, + 93.9385415207, -61.0955216188, 18.0530957225, 7.9150142320, -12.1218191587, 34.0173961457, 40.0084937565, 9.8119275580, + 44.2065861274, -1.8718514394, 67.4740024215, 46.7391150131, 207.2404815875, 45.1635364462, 43.3580102761, -44.0244218674, + 83.2387206007, -8.6441851856, 12.3993902588, -22.5091685270, -19.8332981376, 97.9196509289, -76.6720306234, 28.9740705859, + 121.9415248016, 9.6656982611, -51.0996453694, 37.3704374740, 74.7589840907, -113.4066752631, 120.0029566342, -105.3786221360, + 81.8152755619, -13.4979932982, -21.4680758393, -85.1088235539, -65.3610798409, -35.0444139470, -48.0220794487, -41.6210317362, + 33.1212995259, -82.1480936443, -10.5479715135, 76.4601917004, 42.1983651157, 92.6104239912, -42.3536237955, -24.5644182272, + 30.4446637772, -90.2899420489, 63.6723540422, 103.0895811428, 64.1706769263, -10.7069812309, 21.8927240409, 6.3571071738, + 57.1457649358, -52.9866276448, 66.0981829072, -29.5372056881, -79.2252039810, -136.2440652798, -57.0106422562, 86.8203548141, + 66.4244149837, 53.3230426111, -66.1283059222, -131.0402660353, 8.0548411081, 122.9088988100, 1.2626894208, -60.5059112373, + -68.8707203082, -6.4747987200, 85.8411327244, 99.9624156733, 90.4197864338, -35.9630441182, -22.9158275507, -17.3660128776, + 16.7845345761, 34.7219749782, -39.3513765878, 1.0460702756, -60.9494500182, 20.0900333387, -85.9636743832, 88.4400782168, + 15.0729628728, 61.5499846243, 11.8579871757, 107.8617581581, -42.9393027864, -62.8422307621, -19.0589600542, 4.0750325807, + -36.0651825425, 55.7638724501, -10.4691736080, -55.5672537178, -61.2061519915, -21.1885348576, -131.2535612498, 24.7463552676, + 22.9426321237, 14.3038202264, -138.0926317438, -59.0892900856, -162.5416439986, 7.1307658250, -141.1236672256, -4.7173618068, + -16.7741532807, -68.2615451173, -2.6608701102, 84.1978109826, -11.3446202072, 59.9630033088, -1.8994925010, -37.9301641959, + -119.4435600954, -11.4587491646, 12.2423215240, -7.3169898616, -67.0373621128, 36.0198843055, 53.9791315249, -134.5885680695, + -83.8330811965, -16.6714816463, -8.8498552035, -24.0513088196, -22.9444328877, -37.7961441531, 25.1975736186, -136.1611637464, + -5.0843464033, -10.3939554694, 20.7422826935, 75.6854136623, 46.4179626736, -57.0052830175, 7.3457235521, -51.5504447254, + -158.4375751701, -200.2426967181, -48.1234996261, 1.6623945527, 21.1746524375, 99.4092980367, -2.3206772903, 45.7989166757, + 2.0181548348, -88.0556010969, -59.1527212096, 47.3607925077, -10.4181140309, 56.3558125650, -8.9799125560, -30.0376711812, + -36.7132904688, 35.7785050392, -13.0763909369, -2.1855594714, 18.1550954005, -28.6711803575, -55.4495172398, -2.8812973198, + -59.9575059158, 40.0588875786, 57.4713686602, -3.2835144853, -36.7193552111, -64.9415131516, -166.9555466445, -23.5556853844, + -54.9408569587, -35.2310451959, 21.3345143458, 65.7590671151, 51.2214538168, 46.1271939944, -42.2235267919, 127.2329928299, + 105.2391778600, 17.6726845966, -129.9021148044, 8.7065613044, -94.0987112511, -3.5375742950, -23.1385452379, 60.6219530633, + 92.5445564235, 48.5111974469, -52.5699309159, -60.0634811685, 25.9034368684, 140.0249495491, 1.5918852392, 38.0266038291, + 17.5588710703, 3.4294066089, -27.6748782173, 59.6182974489, -35.2924781853, -38.6198576115, -13.6119803198, 7.8375587489, + 22.7250686519, -28.3524510951, -34.4269062817, 22.6464817325, -61.6528147860, -5.9782002429, 61.4730771294, 43.5582379527, + 55.6862408270, 87.8745651631, 46.3401042715, -19.8780979663, 74.1272633369, 29.8590452377, -12.8665765140, 34.2931401219, + 53.9279617551, -16.9017895140, -70.1527553166, -79.6367897992, 109.3728271017, -129.2214826835, -53.4644539730, -51.5654458993, + 17.6062148433, 3.5090251835, 74.2615941204, -109.3431097845, 40.1403465151, 28.8714561280, 94.0868659302, -19.0047033845, + -60.0967410050, -19.0998457619, -67.2027075128, 72.0711434846, -17.8737851232, 123.7050551274, 132.6331504104, 25.5018761009, + -36.7817189239, -29.1580893235, -6.5848563828, 90.2868948516, -35.7017258498, -68.5675432955, -52.4888589786, 47.1377730021, + -7.4546621940, -52.0657517138, -49.0404829633, -114.6910280126, -117.6819819437, -32.7856729408, 31.8232065591, 12.1192973039, + 35.2678513420, -1.0336778293, 30.7021249679, 127.0442906046, -84.8457819393, 28.9862843096, -47.3524701726, -126.1094998460, + -2.9700276582, -2.4956545870, -53.8624121141, -85.2114117637, 76.9057985618, 137.1205201755, -19.0830817212, 14.3407526579, + -56.5921994449, -25.6084873186, -44.9470801106, -133.3139496090, 0.3487447576, 33.4499716730, 34.7126257844, -9.3307383323, + 27.2996276947, 10.8765676134, -91.1032360444, -90.9584216222, 1.6981490570, 96.8557438791, 56.7726390913, -44.3246449237, + 52.3260643361, 21.5551140465, 27.4535327381, 2.0072717479, 7.4823125629, 77.1185863870, 16.1372262663, -10.7206012957, + 66.8830091413, 49.3523828287, 54.0855375598, 30.8570349345, -10.9255375390, 62.3910624674, 30.9238561381, 0.3352881853, + 72.1022806197, -28.8319885008, 23.3335288806, 46.8999035980, -67.0984424822, -164.7917209112, 42.5767681360, -92.4668227688, + 43.8491734282, -17.1126540408, 37.4819594334, 69.0774409673, -39.3530526854, -14.0693747124, -60.2520781215, -80.3860105519, + 32.6689956840, 15.3393042576, -18.5529761307, 97.3942151573, -4.4462855745, 13.7614349817, 158.3358780719, -44.7258299667, + -17.7741912819, 116.5136962268, -33.6261057820, 22.8344441288, -155.1423976144, 5.7070117893, -22.7906543902, -45.0633909283, + -13.9329987929, -66.0848932507, 1.1383038109, 123.8386958483, 67.6662401589, 45.9152963554, -27.4397697462, 97.9596747354, + -6.3544655181, 29.0832146722, 96.3468162499, 32.4535976137, -91.0650399301, 2.7293262791, 70.7853483111, -92.3655274571, + 69.0359217256, 83.1530567979, 35.8375091111, 7.3393552348, -95.1770165365, 76.4905790891, 55.6253140577, -29.5315327050, + -19.6571455162, -65.5631159968, -16.1022064890, 105.8715375468, -51.8381429466, 120.1887801783, -12.7792505862, 45.9625293061, + 5.2249771246, -44.2522411781, -49.9151046218, 58.9294840166, -39.5237729290, 7.7590557538, -36.9036719322, -13.3726971638, + 54.3809777660, 71.3070336679, -51.0631236639, -10.0694214486, 15.9743446435, -49.4179644909, 118.7626471706, -53.3128484840, + 13.5615377463, -109.8892656203, -42.4445411536, -66.3623671033, -14.8179688320, 76.6614429072, 11.1173310385, -44.0756061917, + -31.6081137549, -112.6622817309, 32.5091400724, 33.0802101919, -57.4339078738, 56.3466203876, -17.0577340891, -95.3692048341, + -67.3434566840, 13.8207460717, 48.9375767823, 7.9881518802, -33.7163627475, 38.5685408163, 12.1465400224, -107.6320581108, + 4.0618423016, -78.4521092994, -86.1605081811, 76.0528521785, -7.4505556232, -32.6671595550, 28.1668313458, -44.3982773094, + -17.6420279051, -31.0505367972, 21.8444018590, 29.2596019459, -15.0890859227, -13.1393295693, 2.8101074170, -17.7888538827, + 32.0378687652, -74.5375953900, 135.2497294704, -28.0677270675, 73.5721900551, -66.6873287357, -25.1872324027, 66.2043845748, + -94.9847220021, 51.0053667797, 125.6199200698, -97.2966230203, -100.0987757765, 38.7851883798, 20.5509402780, 91.2789361356, + -23.6347319001, 53.4814037964, -27.8226699628, -4.2998301656, -49.0060086613, 57.7107938724, 73.8228091191, 39.2104809606, + -27.3049570759, 78.3558930717, -39.1465109393, -59.6714099634, -71.7254332281, 44.0304489875, 62.4610534699, -47.5531388302, + 62.3692165629, 6.4426089142, 9.0422858718, 23.1735394482, -47.2878667545, 44.2020612249, 109.3032846597, 11.6805260558, + -30.4758154602, -82.4704834090, 38.6561095453, -55.4482370852, 8.5232602822, 133.2611664825, 100.1432731096, 22.9595423699, + -100.1659221126, 38.8223174175, 27.7691674207, 126.7418939874, -91.4494781699, 141.2081002115, 39.0632821221, 63.2623914663, + -30.0221078403, -33.5477169622, 29.1082028625, -3.3848571660, 61.5724672364, -34.9602677014, 110.9349405045, 102.6143795477, + -57.9940910047, -35.2709261901, 16.7143230992, -40.5324218543, 53.9355486697, -64.2634715959, -54.9387762268, -42.9168088882, + -57.5562950128, 37.9068250889, -12.1446003699, -60.1702164080, -20.6508515440, -98.5324628329, 101.4072369572, 129.5400369054, + -81.3566359702, 50.6071670655, -120.4768679404, -42.4978466545, -8.7364843153, 49.6150365421, 122.5389217747, -17.0756316445, + -62.3577228096, -45.0934187476, -32.0622747717, -30.5522096168, 28.4509994932, -38.2485520772, -50.1501458954, 33.6999850082, + -53.8053116265, 5.7733509059, -34.6589594313, 126.1617129527, 20.7567771895, 172.0372861812, 89.0892733767, 100.7503861649, + 7.3378103261, 98.5906415363, 32.0129761463, -41.8886119031, 41.2269067119, 68.3876187817, 138.4871996142, 11.3975797943, + 77.7316432733, -158.5764699010, -73.0154932162, 4.7811847147, -23.2377092445, -15.8949240362, -11.9056513173, -152.0900719578, + 18.2632385344, -54.1998869586, -181.7000796389, 48.1068217262, -32.5550981417, -28.0507229974, -31.8419308387, -25.6072993087, + 19.9544408703, 9.3745877673, -83.7112773954, 69.9469812476, 103.7806121094, 7.5661034347, 19.3961679774, -33.6734450687, + 145.2662801261, 84.6823084936, 3.8883005529, 16.9248666945, -16.9581909221, -89.4228081883, 16.2888634344, 11.1954888184, + 2.5472628157, 18.3389344143, -151.4283735338, -34.4147990116, -25.9480238152, -25.5347276158, -64.8106533195, 50.6575131879, + -7.3028646826, -32.2126924117, 18.1267061221, -16.2075818210, -45.6339941841, -33.6697120217, 49.2624187554, 77.8687058107, + 73.6069588809, -40.8028084671, 18.9768190808, -30.7579639537, 42.1813346527, -83.5367163130, -107.9332971302, 7.6029737222, + 26.9032374575, 49.3843590700, -46.3813865337, 9.1625140590, -66.2444573706, -81.6335790942, 38.1352819102, -26.9099106066, + -73.7453409821, 120.4931605467, 10.3564307049, -106.6178964489, 95.7043175624, 33.5246942332, 47.6828732088, 88.3229069791, + -15.5217019654, -19.5431169450, -3.8342503054, 57.2251891575, -48.5444916144, 71.5434047188, 12.4489765266, -11.7576981068, + -55.3127919285, 17.8351394582, -103.4011502717, -4.0445991564, 15.2952711643, 136.5345440142, -63.7492382166, 36.9305043452, + -1.5952862211, 16.2532277000, -8.2697982122, 59.2373828733, -114.7747262875, -10.3140845306, -30.5291082162, -109.5521180147, + 0.0880047356, -26.2704646488, -5.8324862328, 51.9555476050, 179.0193630333, 35.7565163112, -25.6830342083, -38.6240101524, + 7.1156497155, -38.9184661158, -44.0206559654, -61.9671745846, 49.0909411685, 30.5438751442, 61.5412933030, -24.2114612829, + 5.7471838440, -18.0880708776, 71.7203646740, 86.4088528992, -58.7737324960, -57.5055785792, -95.3936802143, 116.1138906258, + 60.1792035622, 56.3771096083, 49.7396983038, 38.3766351111, 69.8500772704, -49.1498577356, 70.3558567877, 8.6780858427, + 34.1723731409, 15.4734742852, 109.0630331552, -121.1548202826, -48.3994829024, 30.5337026074, 24.7828521521, 42.0584760304, + 75.1343090013, 129.5812051166, 48.4270407054, 26.4055953415, 14.0152471956, -95.9222273011, 90.6485095604, -14.3202487407, + -67.2852187582, -166.6666517028, 40.3833373200, -36.1005828038, 95.8066175560, -35.7716615894, -49.1292761932, -129.7066955214, + 103.7802140124, 1.3540192035, -11.7154031368, -33.6798122030, 38.8567068892, -13.4661723261, 27.7129532179, 11.5232210014, + 23.1346883982, -31.8376649712, 43.7429902892, -6.7521035668, 9.2376550661, 49.7442294743, -11.0442544230, 86.0728321584, + 83.9184836462, -16.1275908347, -18.4328902788, 29.0599791766, -119.8140170048, 6.1015865800, 8.3430418870, -26.4676140800, + -54.4170405827, 65.9500246661, -68.2589172652, -67.8087618276, -32.2785464329, 15.5784741177, -40.7911512889, -30.4549351749, + 65.3973162901, -88.7812378733, -100.7984347025, 33.8660362781, -29.6824618124, 43.1980425632, 28.3570049344, -53.0517620662, + 77.8517167497, -197.3149986900, 39.9412966213, 64.7267960844, 9.0985185643, -48.2516330353, -25.2702193655, 43.5324967389, + 25.2174278973, -143.4955124244, 97.6996202090, -6.8156183641, -24.7105412789, -82.1407130477, -84.2647074618, -31.8474816146, + -18.8364319750, -39.5505715225, -54.5495977905, 17.7158231401, -3.7065472234, 57.0344653317, -88.5539921734, 19.3061972587, + -71.7736386745, -41.9757523004, 44.0839025453, 93.6350283513, 23.9985071911, -82.1811236502, -109.4369907962, 63.5407415232, + 8.4092298502, 28.4295805746, 18.6411321700, -5.3460515491, -67.8392754185, 38.2413165851, -48.3890309482, -84.8999016731, + -96.8897430524, -108.9709380233, 12.6763008215, 0.6495692893, 42.5729352890, -45.4201114101, 178.6503517211, 32.3364256219, + -0.5018953239, 85.4524577539, 31.3821199920, -77.2752461536, -22.5276539124, -73.5513316548, 39.4443099153, -85.5453904099, + -92.8231923388, -40.3971881753, -58.4187011919, 43.8859268482, 8.6368900854, 36.7106300359, 46.0279473438, 98.0046308108, + 141.8908992398, 99.5148913015, -117.8125705364, -39.1830583755, -7.7274169732, -48.2601982254, 62.7987036515, -214.3028855312, + -63.1561162569, -16.8220689219, 25.8725009221, 122.4301600524, -14.0054049372, 34.6312211243, -80.1152116439, 19.5089176613, + -55.4531957952, 50.2925094566, -34.9023849044, 96.5932330242, -23.3903984041, 18.8379347047, -142.5109851060, -26.3638740038, + -45.2635268905, 10.4556800933, -67.2064627051, -82.5693793971, -61.2994401437, -60.8623342608, -49.5256808732, -67.5095279686, + 109.7221898389, 30.3565964773, -3.9295411009, -13.3243471006, 31.5325109517, -42.7881917663, -62.3012601651, 12.8902122674, + -72.4707062966, -1.1385459373, 31.9714183017, 25.4392014670, 5.2034169158, 7.4078411122, 3.9210252522, 5.6054243531, + -13.9283618935, 62.6605467523, 106.2229553720, -108.0346097164, 45.8846468124, 63.6694544818, -10.1426865266, -101.2125032732, + 84.7788854892, -74.9877442652, -90.4102888654, 82.3491489235, 13.4299871406, 8.6923780794, 21.7402751068, 1.3078400943, + -5.3323741070, -40.3811284623, -2.8868770078, 160.0268532699, -25.4997503943, -89.7351898498, 47.6695601274, 134.7207474765, + -28.8772848263, 43.7271906311, 7.3228230169, -96.1850462320, 35.8869106751, -11.4777855539, -25.7781856921, 48.9895273966, + 13.8032764481, 14.5942766183, 5.8336013315, 87.6897796695, -13.6765032835, 3.3883927453, -158.3668079137, 42.2382326860, + 21.2461344076, 15.6945936663, 9.6604677279, -9.5678778930, 123.3597739656, 22.1167117074, -74.9824011460, -95.9807585582, + 63.4915942695, 94.2011376357, 9.1392063086, 11.0696792396, -61.7781744244, 32.4342673236, 47.9943613167, -144.1319767603, + -72.7895423040, -51.0997685900, -1.7995707656, -94.9206104086, 72.7211674226, 58.6708314320, -20.8389738301, -21.1038399946, + -16.3313082354, -9.9622712842, 25.1381713884, -43.3630408732, 95.4208180249, 4.9957713162, 139.7419301257, -78.8102530942, + 18.4468841849, -36.6529768792, 32.8656605850, -13.9061010905, 25.3836067009, 29.3018838146, -3.3243716283, 19.1868542168, + -24.3576227747, 35.5704128749, 9.7305659636, -28.0698496733, 80.9991737110, 44.1711909705, 67.2428623477, -51.3139105230, + -84.1430177559, 48.3068887430, 9.0115749848, 14.7342922983, 69.3129475126, 15.3916339055, 19.1526114590, -36.2384578425, + 36.3072041758, -2.7831098993, -79.5517384898, 2.4496975564, 14.7441805304, 168.3353222077, 6.4042017907, -94.1108499663, + -96.4470728057, 93.2974672034, -25.8910707915, -109.8714867373, 19.6739537972, -25.7283734173, -63.5666504767, -13.2751224909, + -6.8369303742, -44.9757631953, 59.5220216584, -36.6656623877, 100.4234528842, 39.7179675926, 100.4793677526, -86.2364278236, + -92.0288292261, -103.2337376347, 44.2981800782, 19.1367051770, 13.8984402872, 58.8220815831, -77.2361735490, -114.4879467592, + 89.1682762205, 51.2266997372, 81.3502982945, -21.5959593928, -11.6326571964, 8.8353642779, -12.3913359429, -23.1216638844, + 0.3575351650, -18.2903762351, 45.8302612836, 80.6428162262, 59.7892572555, 60.1876610526, -145.2533267974, 106.2800108239, + -18.1569484863, 78.3937893751, -85.6984739674, 25.2366777542, 61.5343531109, 140.8219730338, 47.9603484021, -66.9887369929, + -30.6392044667, 52.9963805955, 62.4415105078, -90.2869564132, -24.2283129464, -99.9584280390, -43.1587468514, 34.3760232029, + 89.0356907077, 22.0053768451, -53.9159785951, -25.1650972100, 8.0202661814, -53.6342885367, -7.1736148465, 109.3934027137, + 33.3102237776, -81.7593644113, -31.4758286552, 37.4778685110, -22.7494345710, 2.0108643659, 46.8251888594, 55.2739450714, + 25.5904497373, 80.2180417943, 60.0712983927, 5.1023725171, -55.3981506793, 92.0411889173, -151.8431761496, -17.8889138320, + 13.8369339480, -98.9537744078, -69.4129195296, -9.4399479020, -4.5486917569, 3.8311487140, 17.2656994939, -25.4507802631, + -42.3325354568, -16.6440745458, -133.8308014681, -25.5109360172, -23.1019754685, -113.2804091682, -14.3636580071, 87.9235056149, + 72.6206212879, -58.7137643393, 167.9006741193, 39.5232107063, -6.3630485808, 71.6621087431, -114.1539708322, 101.7815598753, + 27.2475470378, -54.1505303371, 30.1111783717, -11.9959488516, 19.4405070791, -108.4745463396, 71.0642431926, -19.8129431719, + -15.2954756654, 14.3561030921, -16.5356371988, 52.7783287094, 28.8939941206, -17.2842243626, -133.2248386977, -83.3404111930, + -7.0104157691, 22.1756809435, 3.2730114916, -32.2394014930, 20.3115837303, -17.1488805354, -42.1049764681, 64.9096377499, + 7.1989366097, -54.9327048635, 27.4112784568, 12.8647289850, -47.9584681630, 28.1940916618, -77.7181004478, -39.0254847210, + 14.6762624107, 32.0630508538, 73.0143676987, -22.1015540909, 41.9874345585, -2.8858853990, -88.0645760668, -90.5936909394, + -17.7732180284, 118.5661779332, -66.7797486036, 50.5937256974, -21.9300412969, 32.8513839567, 9.2389232325, 7.6133233529, + 11.4306872743, 86.1899246751, -14.8265560191, 14.3516516628, -81.0949021047, -14.0165322751, 6.4193008532, 91.1325356747, + 136.3161040384, -79.8056934391, 48.3720074062, 184.1908593323, -1.2350224948, 104.8017124353, -70.7660168596, 59.8117635799, + 38.9768188797, -92.6445519451, 38.4757633507, -43.8909508451, -68.7430495433, -33.5503051820, -45.7745564558, 23.1582292853, + -53.0556301244, -84.2076950671, -11.0754062672, 59.8325332450, 115.3577555552, 6.0322991520, -27.2020584628, -11.6601684536, + -19.6192551137, 63.6069935939, -90.5530529832, -65.9660360514, -17.4108821433, -32.2870508580, -18.8912458596, -13.0325547618, + 15.6951179243, 52.5832125410, -5.3522907337, -17.8679842370, -29.6421416058, 54.8215269985, -33.6000150970, -17.9637151319, + 38.7672649613, 15.9768537914, -36.5384968894, -25.8899064866, 143.3564174538, -16.7027387067, 112.4635318759, 60.9380860218, + -12.5989262156, 65.1545135722, 68.4448023234, -26.7853957961, 93.3277464713, 103.6052678753, -67.2083365675, 17.5708362440, + 54.8826954360, 18.1508430942, -39.3842844795, 37.1447880280, 57.6547054454, 9.2814912808, 108.2432242472, 32.8556189396, + 94.3226005359, 5.8586602054, -110.9028458371, -51.1302011664, -16.0219070131, -7.0598649579, -176.6996383318, -49.6407750992, + -66.9977026952, -89.9496950726, -53.1942620674, 34.9304683629, 30.7056949448, -64.8309845749, 73.0371656315, -13.2113288868, + -58.9585474923, -49.8700242642, -6.1582020634, -145.9633036671, 46.6807699026, -9.8057958623, 45.5962806826, 17.8413742472, + -45.1844288752, 51.6533061953, -18.3891326987, 86.2944939973, -88.4475541046, 109.7385814010, 80.2606871510, -6.8687112951, + -40.4305300274, -68.8038418728, 98.8182955892, 45.0578128678, -17.9270836619, -58.9964717416, 11.5983932225, 9.3557201268, + 40.2977049475, 138.6920714505, -107.0950700047, -8.5417944988, 76.5742734827, 99.7719961192, 33.2465872494, -130.9955599444, + -29.2255022084, 35.8580665719, 35.2949239487, 47.8913285775, -23.4340430256, -20.2468230117, -129.2315852983, -43.7204390811, + 18.6427890127, -14.5256762331, -114.5390628737, 83.3822028084, -3.5819486705, -30.4441161689, -112.7352247162, -109.1237973030, + -1.2881432609, 102.3673365896, -56.6529958750, -17.8832422128, -83.7875095740, 27.3286576586, 28.2690336934, 11.4666255287, + 52.7806502871, -32.3964403795, -11.7703336362, -26.4802375579, 1.4830249909, -46.7745447418, -179.0106845682, -46.4060214919, + 13.0495006806, -15.7093018033, -23.0652411102, -46.8891647861, -11.2767379154, 54.4284213870, 61.0257369233, 25.9537772478, + 32.1447676269, -55.7565993845, 16.1980837538, 39.7108201653, 57.5494093425, 25.4753658982, -82.6747317912, 32.8120846114, + 94.3963947400, 115.4928024657, -103.8033683890, 0.5505661357, 17.6017067223, 0.3340989298, 11.4554380855, 60.7715773549, + 47.6023333479, 8.7147095957, -12.4689201501, -38.3317139365, -70.8372336044, 19.8454635262, -32.5311981944, 16.6656528545, + -99.4051451760, 52.1836216170, -36.3751695538, -168.5804600081, -12.4503257083, 20.3254098853, -115.3933821008, 99.5221568068, + -65.3861194417, 28.8829913431, 180.5755173101, -52.4724526473, -17.6810674060, -36.4748431538, -0.5256538571, -55.6217233478, + -21.4129350702, -62.6552175024, 43.7806633668, 68.9822663027, -103.7310445758, 24.8680657731, -23.1804371879, -19.6865562980, + 86.1256756588, 43.1915528025, 64.5202069909, 11.9433963783, 59.3956955884, -136.0065807072, 54.2444425795, -28.2438980841, + 27.6881277816, 3.3966585075, -23.2714416081, 56.2708787997, -104.6936674005, -56.2472159428, -66.3373352615, -79.0727896373, + -19.4338276833, -81.4066241391, -7.2994007916, 104.0111560011, 19.2521825910, 39.6171092266, 8.3114594881, -18.6024599138, + -55.8404695603, 28.7502170881, -35.9621183078, -83.4040376758, 100.9786890719, 43.7353110787, 58.0923223162, 158.0571243490, + -89.5270222788, 35.7263973066, -85.7794526924, -44.9442606374, 52.4649663641, -16.2400821703, -137.0501146883, 33.4104950855, + -66.4055049018, 20.4444710408, -58.9392047771, 93.1083108145, 30.4506487034, 110.0306666973, 9.2409143811, -24.4812544449, + 74.6860947628, 40.3769192483, -16.9497053699, 14.5576684325, 52.3350907389, -25.2007169663, -125.4063020221, 62.8691359335, + 12.3811488011, -49.4397264264, -45.2008829472, -45.9893935646, -51.0423101211, -13.5776298651, -117.3962715914, 20.9725891298, + -31.2377986416, -66.8022452921, -52.2545297076, 36.1808304465, 105.2804289847, -29.7408485717, 35.4936891096, -44.1058624503, + -7.4267543746, 45.9626674865, 43.2586644116, -84.9652227215, 52.2598894211, -27.7731305158, 79.4055411705, 134.9211049595, + -77.7683897577, 38.9772600887, -42.4478182670, 35.7767677279, 120.4883485663, 40.9080290988, -52.2908368677, 10.8332681424, + 103.8755744034, -69.4025590672, 63.1667239359, 51.1565115511, 30.4688205979, -7.2886782047, -18.0942283768, 31.5953801065, + -34.9573251248, -43.3238802424, -20.2265574149, -41.4045853426, -156.8022185924, -20.3378496469, 5.4144969666, -49.4467840461, + -27.8246258947, -36.1553394393, -40.4493178373, 13.5989840626, 69.9757376469, -60.0443280971, 3.4638171519, -141.4361514658, + 93.4118114115, -7.3645097888, 2.0470465032, -54.6478723026, 7.3294655198, -6.8416716006, 9.0045502006, 19.8489919128, + -6.4702933570, 16.4343253942, -10.3891055517, 100.4561542312, 29.1536913142, 53.8464057947, -16.7143417688, -153.3024265390, + 45.0496791201, -0.9943534787, -20.6269990550, -50.6212419282, -24.6576988474, 59.6066172704, 10.2122652005, -40.4195486296, + -29.2714128060, 62.6802622802, -47.4202386064, -34.8309723516, 79.5197299960, -20.0749434197, 169.8665850989, 98.4267485076, + 31.7347164541, 37.2604966566, 6.7605021281, -50.6903490963, 6.6127852698, 151.3469256096, -70.3184827662, 164.9601379841, + 92.6205263551, 69.9026079183, -31.0866155998, -34.9956145613, -9.6578985782, -32.6789267529, 80.3319506579, 91.7685176440, + 5.8995239218, -82.0636944263, 29.2086774264, 14.7724289401, 66.8988379781, -24.7460191895, -114.7525174298, -32.9732857706, + -51.4321208184, -66.2382282862, 21.2981329623, 9.1062826547, 125.8754077125, 51.0615189986, -96.7297998983, 64.9965050494, + -71.5111010300, -180.4535252581, -56.1041777677, -3.3591726481, -74.8271358166, -28.4281456554, -70.1818488305, 35.6835607015, + -13.9275123287, -83.1043490068, 22.2289783248, -95.1448030958, -40.5966123003, 11.8470675380, 106.6983680147, 52.7565554571, + -50.5809140712, 62.1951780988, 92.8998044629, -110.2770489118, -5.7088922157, 13.3095896843, -34.0434382314, 41.5967680846, + 7.1406890165, 49.0800572858, -4.8661130870, 50.1732411845, 21.8791360144, -20.6230498949, 33.2629053316, 34.8156585726, + 7.7974775850, 85.5360926916, -19.6603301120, -13.8088176043, 77.2247366741, 81.7615386790, 29.5025756045, -202.4477185665, + -31.0440373761, 119.6975128752, 46.8351618237, -36.0825651455, 52.3228058699, -61.7212902449, -37.0009190140, -111.1411485112, + 119.3548750790, 7.5570310830, 6.2657871086, 49.2259611245, 49.9691348215, -30.7394519018, -60.1418076104, -59.4870457446, + -111.9152565690, 124.6406880479, -47.4604425483, 13.0533325061, -76.5307924698, -60.2632649204, -28.0947702114, 5.4878397959, + -83.0541772262, -3.3172056420, 20.2732863285, 29.4076349749, 47.3392948241, 55.3208777615, -32.1444489144, -23.6019236678, + 61.9602080076, 41.6812616408, 30.8111928268, 21.8108462337, -24.6948175247, 16.1446229981, -15.8735793778, -24.1870889577, + 27.1864566801, -50.6435004599, -145.1098728714, -75.7531085939, -4.9397756888, 74.0940849050, -53.5740454881, 28.4600455809, + -64.1804054310, -56.5695284341, 45.7257738714, 27.3208227413, -87.4969438966, 96.9999840115, 26.5098283187, 75.3671956291, + -39.9875814398, -71.8080566179, -64.7909433975, 112.6208244120, -57.5455840916, -9.0666084922, 36.9334781097, 69.7260235716, + -47.6511701810, 48.9455812098, -19.7303239899, 34.4780933174, -24.8188130996, 1.7918733164, -51.1027083896, -8.0414842387, + -69.6904961677, 91.4021012418, 143.3158713687, 127.8431865361, -76.2463415340, 77.1863865583, -104.8165933906, -82.0491770730, + -4.2452881018, -29.8857354449, 39.4203383204, -78.4428804183, -67.3737881273, 45.7774162557, 43.1510666403, -38.1227007212, + 48.0367915577, -2.2796749550, -147.5309258951, 59.4609063787, -94.5201743634, -90.2713711080, 83.9499629394, -44.4267785769, + 66.2311395310, -19.8654393787, -40.9657871591, -7.6100345494, -153.4687135715, -24.0528389453, -43.0977703429, -32.4544558717, + 27.4626014725, 61.8263048101, 8.4949142219, -120.4489043103, 9.2738852281, 65.3309688121, 44.8133466197, -37.4373241359, + -83.9640842471, 23.4059670119, -93.9143209007, -55.4183425033, -93.7449781980, 74.3227981579, -11.7471950643, 84.3803942002, + -31.4489037424, -1.8363204298, -55.3456417353, -95.1228021775, -55.4637768242, -17.5611590555, 8.6597790424, 19.5417857682, + -17.2507716259, -5.7889755948, 70.5139270183, -26.9177828140, 39.6037632634, 4.0845034879, -59.7156630403, -55.4689095772, + -58.7669735168, 62.5057414231, 50.1807875376, -49.3189045747, 15.4287355682, -8.0824504769, -47.6198199719, 15.7657690255, + 24.1207871994, 27.9173027164, -12.5261250855, -19.0257872712, -82.0154379577, 76.9194034147, -14.6695769647, 1.4844193915, + -7.9956835409, -55.6156194033, 39.9952855598, 51.1083969228, 48.8829532142, 62.7988625371, 51.9432398511, 2.8722062155, + 156.1476408615, 37.5905889544, 54.7112433550, 80.2943943272, -6.5627640190, 88.6335213431, 112.2792767414, 21.0878200837, + 5.8741152139, -19.6667337723, 33.7905147067, -34.2798965801, -26.4594706418, -15.0765526773, 91.5802201722, 85.4145356413, + -36.4818922051, -147.9028534383, -42.1412753623, -27.3632859684, 44.0453194249, -19.1027467398, 14.3157309983, 4.1768734004, + -68.3022440228, 34.2186781120, -10.1854692365, -173.8586421151, 56.7091031998, 2.6538298634, -93.3821299316, 45.9499799668, + -11.8122305624, 26.1216815300, -61.0880687199, 73.1945783047, 28.9339417573, 42.3531539412, -71.3262502743, 85.4828937399, + -66.7918044637, 5.4192940999, -81.2977956585, 88.4998783552, -8.8973642437, 18.0257683389, 0.2933847454, -87.7509230128, + 1.4360726567, 57.2432970677, 103.3736004675, -33.8595106764, 36.4856625370, 87.6767927437, 45.9257522623, -91.4882358338, + -43.9564432991, 36.8048295224, -155.8735354347, 78.5839166200, 21.7365316114, 2.8251251119, -0.5016069183, 50.9050618615, + 14.1865751800, 53.6974572195, -47.3239324031, -62.3187399635, -109.6783459490, 10.6742758459, 3.0633856847, 170.8292829026, + 22.7107314592, -115.6997421721, 179.4541315127, 36.6353212025, -46.8173506792, 104.9377352185, -62.3839485230, 84.2161407106, + 136.1327139029, -1.7544748630, -86.9030562131, 15.4259753671, 2.5663369046, -116.9292434949, 64.2129157660, 78.7964806182, + 49.6087028507, -23.1282134104, -37.4278940992, -67.9769820701, -32.7546299170, 103.2337703853, 59.7504223629, 147.3485484359, + -3.2598723366, 116.2635358555, -4.3105783057, 99.2160004729, 18.7288916095, 78.2186271384, -32.7460615054, 26.6048168237, + 54.4099899967, -126.6518025639, 17.8377885986, -98.5074167624, 83.5842655157, 63.5608049079, 124.1282700584, 25.0506382513, + 9.0974612270, 10.2387616470, 31.1629214422, -24.4182834051, -15.9351308181, -32.8438279677, 8.8571103031, 3.0977533207, + -23.0359569441, -85.1033133185, 1.2922811622, -69.5278720344, 25.7444385081, -92.0141253702, 35.4374183520, 6.7043276497, + -0.7451513477, 6.4338102885, -75.9673321161, -91.6026967981, 34.9987265356, -83.2890589702, -47.9531745920, 142.7844807861, + 114.2435566703, -26.6531368807, -16.5029393959, 14.8125488050, 16.9592532170, 12.9147547847, 59.7887418020, -39.2528866593, + -15.3658342458, -74.4590980998, 74.3475628113, -48.1780064666, -11.0564355396, 70.9519213138, 110.0516331927, 36.4575879060, + 91.1281495181, -103.0201029342, -58.9865587379, -87.3023951029, -25.5889474724, -80.1022425592, 7.1308546919, 42.2966419390, + 28.1034227718, -110.4992975497, 52.3250451635, -22.1535855498, 12.7339036777, 34.0415435152, -39.0750294825, -30.4963132547, + -53.1808531221, 17.7255575164, -10.9535616620, -95.2135221101, 100.4987819707, -68.9493118541, -82.6099501128, -18.0285171027, + -21.9761772415, -27.5932967659, 91.8124465044, 5.8338598129, -7.0338759021, -45.7406241732, 12.9215890948, -0.0753638964, + 44.7159304680, 26.4654167590, -40.1423667648, -8.7426397748, 31.4700501616, -38.5847107897, -17.3446717482, 33.6461097548, + -107.3520493912, 117.4675224001, 40.6606607876, 7.9719714143, 27.8264722603, 38.7179679154, 1.7705195429, 25.5111272928, + -100.4419129176, 12.0673509113, 83.8410184425, 29.5781971450, 8.1040630143, 4.6727315335, 64.7847825199, 82.6216823615, + -15.1627242063, -22.6182310171, 13.1330997407, 49.5724583221, -46.1716475780, 47.7331801575, 49.7204543255, -85.3529225637, + 44.2195291098, 14.5616345667, 25.1355891397, 40.3146174825, 28.9423346884, -75.1582368771, 57.1913980615, -65.6984554165, + -40.7664709143, 66.4827050221, -37.4060644320, 22.4137979914, -40.0020443101, -50.0281409167, 4.8184431368, 62.4290842324, + -40.0926566688, 44.5774651507, -21.1028032780, 15.1185206565, -16.5265077365, 50.9848497205, -1.0692090929, -10.2392281457, + -73.6134935055, -58.7604124292, -78.9611342584, -22.1438277580, 38.5664728303, 39.8041438227, -43.2409994985, -37.9352795857, + -10.0448204868, -23.8371815139, 3.2897249640, -80.2885168342, 37.9525301994, -75.0706497208, 83.5246116221, -72.9921720117, + -8.2686558506, 3.9598212380, -88.0878393938, 14.7857207938, 37.3105932736, -25.5786314639, -14.2401437401, -131.8844485523, + -83.2051874645, -48.7402478144, -47.1392081390, -140.1935235859, -110.9171286805, 5.6067034386, -61.3508997640, -153.0780126325, + 20.9763880517, 36.9388874884, -0.5023108098, 109.2764166186, -64.7679763308, 27.5264562598, 12.7297402644, 135.9094145156, + 28.8725261600, 107.1985003559, -17.0333242428, 14.6472316711, 79.6550390697, 76.3253602754, -42.1106361443, 101.2937610145, + 29.1345513275, -81.3710305821, -51.6367882642, -75.6657420025, 67.6127817208, -143.1235134075, 63.4083371887, 20.2771663953, + -39.6962975349, 35.4904122251, -21.1761177463, 36.6827629732, 30.2533761253, -100.8244394079, 42.0562320416, -117.0985134680, + 86.9313959966, -68.5862263897, 39.2349791859, -62.0712807646, -4.7999897806, 157.2184386950, 40.1651596554, -130.2861272594, + -21.2745075974, 96.2019047346, 130.4626031799, 47.8121736864, 67.8619386636, -88.5169139565, -15.5429762844, 46.7375894206, + -19.9234556464, 74.2075824091, -146.2816301611, -27.5190709903, -105.4977126735, 82.7567139636, -63.4005073458, -97.8585647602, + 70.7163936702, 40.3196085322, -92.6325452663, -65.4906649632, 14.2362768591, -40.1848110012, -27.7039695490, -100.7942890248, + 31.7082105399, -25.9115041943, -37.2685165720, 12.4301141470, -86.2349812607, 85.4288388492, 61.4326022560, -52.6450593109, + -78.4043996861, 32.7052974812, 1.1786814775, 65.3401420354, 8.4364632653, 148.3052078011, -83.0828330696, 106.6354843068, + -4.3121195655, -44.5526178638, -2.9317305696, 109.9935497492, -18.4045116767, 23.1613955078, 15.6972686340, 128.8746575438, + 29.0629973213, -10.2922631539, -26.9225268881, 78.3939184322, -13.9891592847, -14.3955545921, 56.2259353432, -106.9719383698, + -69.4541718556, 83.7959262767, 118.0020136833, -76.6757480506, 53.0531323252, 20.3374814219, -45.9339005486, 46.3861511953, + -82.7185926581, -51.9983813997, -11.1149096121, -15.7796335925, -14.9611867369, -55.5963996752, 3.4778394189, -63.4371998633, + 28.8327087658, 12.5198672129, 87.7380213704, 18.4911159408, 56.8889056171, -21.9589217680, -93.4663445471, 55.1183878788, + 0.6449948853, 28.6533319776, -14.8059318368, 113.5439226734, 54.8995357737, 109.0924325068, 38.7922835723, -0.1180981319, + 157.7915336564, 81.6839158496, 11.8100964756, -22.1691332044, 9.1777753259, -58.6991331163, 121.9143128888, 123.2714985637, + 28.7886850251, -73.5910923730, -128.7124920003, 55.3579340152, -103.0285920820, -68.0360814429, -41.1894325447, 61.1418052767, + 9.1032579737, -114.7074592848, -35.4778656303, -56.5732437789, 87.7236911508, -34.1313499403, 62.2620712971, -52.3364100999, + -108.5676552169, -88.3757117464, -19.3248782556, -10.6333977657, 11.1531439202, 117.9042736262, -59.5405468137, -29.0685166095, + 84.9970950178, -27.4738785887, -49.4301782076, -23.7375836298, 123.1572277910, -30.7874739051, 20.0070113012, 92.6375682898, + -151.2677413660, -64.5993124352, -6.1931938222, 56.2980662344, -51.0667271974, 3.2590148897, 94.2279629570, -81.3680192851, + -58.2441470779, 136.3043204550, -65.1682000377, -11.6204578273, 82.5051730406, -20.7566312389, 12.9732577973, -3.6631681566, + 5.8870959981, -15.0765851320, 82.0878455090, -35.8669226696, 12.3547961199, -187.4160833910, 134.7486191161, 68.4591403436, + -10.0461433931, 59.1539319574, 43.7723616252, 79.1999168985, -24.1914155320, 38.0293798436, 4.5268241580, 32.8861446301, + 26.8134396608, -32.8357678171, 75.5315658240, -98.3994598766, 27.4380255469, -18.2567928813, -53.8692115445, 43.6445077874, + 41.8403964980, 145.5446940894, -45.1527793517, 36.2478163862, -23.4791069949, 12.4999105154, -39.0947731515, -94.0528129824, + 58.3030733328, -45.3491781120, 73.6529605858, 59.5823230864, -47.4741019188, 16.0307838051, 76.0140317071, 35.1546855136, + -5.8237741703, 8.3668861475, 125.3567506875, 55.2422644949, 22.2611352600, -33.7548647520, 22.9568910221, -35.1162490171, + 34.5901055588, -28.0490543019, -15.6322113695, 23.3610785957, 95.0831229094, -54.6273674257, 89.1750392621, 40.0225575612, + -14.4413587278, 97.6869759465, 14.7675464371, -37.4004765161, 119.4568961628, -26.1920161265, -58.0012410134, -28.7350340564, + -4.7796929865, -19.7344028715, -8.6437248253, 103.9809164360, 11.0043740394, -32.6092633210, -80.6443486297, 49.9986715363, + 105.5490975322, 104.0899701063, 59.5660092301, -17.9484147791, -55.4356343687, 5.6176664765, 147.8940936440, 42.5217478147, + -33.7007685862, 76.2702328206, 17.7168869112, 29.8692838033, 47.9156001099, 78.0087519225, -10.9663921228, 108.3826416455, + -12.7724638181, -84.5882451872, 19.6390498449, 50.9452521435, -10.4676220676, -59.5812635820, -165.2174342507, 52.9034909048, + 4.5103428162, 28.6714188830, 151.2376493891, -15.6519597742, 54.5244070834, 40.6356686042, -51.3633558110, 39.9915724858, + 1.7184423265, -4.3510464817, 6.8579282212, -37.7467707598, 37.4199831388, -44.1415061320, 7.9715921178, 80.9137854559, + -93.3883447881, -70.4226479003, -5.9804507221, -12.7588185792, -12.7748179660, -44.8489354744, -27.7084595447, -9.4696608732, + 57.0454576802, -137.5411295173, 34.0807152122, -82.8428997163, 36.3720183240, 117.5741160380, 91.0621096220, 16.9215804561, + 82.5046757105, -16.3941226525, 21.6412310432, 9.9347818503, 94.4637136289, 40.3883996184, -79.0927933462, -74.1126629254, + -1.8463008698, -11.7303452181, 51.4819690412, -40.9029132628, 79.5478142926, 37.3467151745, 119.3061300476, 81.7656373311, + 40.9995493552, -18.8267671804, -109.2814037436, 110.5826225324, 3.9090047179, -12.7311846356, 50.2434808607, -78.9987938122, + -48.9383950748, -23.2509396875, -67.8816298850, 46.0043667633, -79.5062435328, 3.7149881510, 28.8345576966, -2.4062068420, + 111.7203117517, 0.4410205414, -38.3832527193, -61.3416288539, -102.7939248826, 67.9533675166, 58.2475592529, 10.6035422626, + 37.5730234873, 49.4994673002, -82.1647604961, 65.7885201078, 92.2097983704, -37.3226143066, 135.8561958349, -49.4816302910, + 10.8193370693, -8.1591216625, -124.7982308726, -14.8282684728, 90.0927717376, 33.5256881620, -59.8703916309, 21.7176330197, + 2.1782551834, 114.1382737688, -88.1597739240, 6.5361543045, 97.9695862766, -39.4694065867, 11.5962132886, 33.7697466356, + 58.9764174727, -4.3190513332, 45.4357110166, -39.8718237733, 101.6682995218, 16.6389670713, 0.3598261204, -29.7440968058, + -31.6482054502, -43.8553776977, 67.0772865832, -54.5098535835, 30.0974211944, 45.0867818944, 8.8681839790, -27.6698123459, + 32.5238939056, 115.1771763945, 1.0297629680, -0.1277281381, 53.5989816709, -15.6940765735, 214.0039494923, -3.9607957468, + -28.2459062295, -78.4309884274, -45.1615660948, -56.8373512425, -14.9182469466, -46.6359981712, 10.2436473643, 49.6796044695, + -68.2156643693, -73.6736376702, -25.8482309017, 79.6432993680, 39.8430177404, -48.6865340771, -4.9554892261, -10.8103852199, + -163.6398049355, 34.8129987597, 43.1988001177, 4.6425367549, 71.5136740040, 5.7449295065, -129.5178610564, 23.2851316100, + -28.9856348679, 72.2878496468, 65.5641757637, -22.6995529120, 90.6678161988, 31.9503079809, -38.7957396135, -29.8167763909, + -127.0682245355, -114.5912946274, 95.8998971324, 14.6842186073, 38.6817470857, 53.4220170000, 30.9640386035, -8.7681524726, + 93.2374647164, 167.2548470938, -110.0113841742, 60.7832491969, -10.6378768861, -12.9541979766, 50.4311478762, 14.8581364205, + 36.2771855577, 16.0289680028, -27.1211553672, -27.6119525599, -64.3782858077, -30.6836783175, -11.3104575592, 46.6583470371, + 43.2576688462, 106.2483647125, 35.4221002374, 38.7051612461, 55.2640723227, -64.1159659536, 57.0032601941, -44.6269768244, + 53.7789820032, -157.3514759280, 9.5791816275, 6.2806945793, 18.6705185038, 153.1320561669, -5.5671006976, -3.2946321773, + -13.2024369589, -21.6449448269, -22.1412657716, 70.9673800953, -7.9864874901, 41.7239378937, 71.5984356144, 87.1584519164, + 71.0575050315, -38.5112900717, 41.0828370864, -97.7913314993, 24.9443056744, 71.6995496139, -116.3501231153, 67.3823850840, + 94.1851944844, -41.7993332022, 55.6783133892, 47.5180232694, -25.4261377746, -16.5909249978, -16.5035403522, -31.2504616568, + 38.1070466320, 0.3163573698, 36.1965564905, 54.8579811585, -54.0608838266, -112.2426667925, 184.8017345857, 49.4559933628, + 97.2753525540, -127.3976019425, 56.7945066844, 105.9924251837, -9.7156760373, 44.4969751065, -37.0888563276, -26.7522105798, + -40.8300149353, 52.5243354843, -19.8943377495, 51.1416695022, -70.0108248826, 15.6121585850, 32.5217684217, -90.1820508578, + 39.2513383879, -47.3412998909, -31.3055181623, -56.8173595829, -50.8924569276, -7.5435701646, 64.3413557990, 9.7281927789, + 48.9305305599, 56.5372975126, 26.7417330296, 89.0738343693, -48.5280725684, -31.0853481463, -9.6358615936, 51.4311918344, + -33.9718242925, -15.7470007951, 51.2850467492, -51.4187903682, 33.5815172911, -71.5483298410, -74.6635317137, -82.6284293355, + -19.3084129904, -58.4258965628, -7.7220084872, -50.0589600666, -35.4767663181, 113.1079148915, -10.8113655056, 6.6819361958, + -58.5734954218, -83.7627866065, 26.5302830531, -99.8288161852, 70.6577997609, 105.1602805436, -26.9709761883, 16.7715250364, + 100.4598899749, -12.8354110399, 31.2835111044, -28.1999286002, -71.8821977449, -43.8649368179, -24.4752744590, -13.8122643365, + -13.2937561135, 86.7641539982, -45.7159093571, -13.0092431337, 71.1728457692, -47.6143967182, -18.9549445122, -52.6530519413, + -36.3758751689, 95.3593012050, -13.8106918472, -47.9731072201, -42.5698690212, -33.2874699499, 74.6397905712, 13.2248699532, + 10.5705384630, 53.1572412508, 11.5799356215, 40.3743911825, -30.1315085582, -32.5536377528, -63.4740422506, -8.1108698232, + -39.7653559069, -61.9123876789, 30.2050339534, -13.4902607567, -49.0742542298, 88.5722862352, -22.0924973356, -43.2051228512, + 23.1418263846, -52.0531638851, 61.7042537346, 62.2206170738, 89.7321026525, 16.2048654039, -69.2890753423, 14.8548152449, + -44.7911045647, -2.5487807022, -25.2382987671, -73.1162478241, -6.5637044361, -62.4609072239, 50.2645328426, -127.1218373352, + 35.9901816641, -13.2427957988, -19.1139418128, 11.5763910792, 42.0967727508, 93.8373969941, 48.7578089767, 116.6192984420, + 29.2111912926, 58.1960409947, 45.8425638147, 72.1773323399, 83.8891643331, 17.1974768083, -78.1227071776, -76.1533486330, + -37.0312632710, 25.0291081414, -104.8734413579, 19.7434765416, -23.3082565679, -21.2852819234, -25.2235835223, -93.6817252275, + 2.7146982161, -17.4896953310, 71.2109780985, -59.2294931409, -84.0666862918, -65.3056520242, 120.9838686800, 74.4971556879, + -9.5684703908, 64.8377948685, -66.6770366247, 38.8265471508, -79.6623440265, -39.6171150046, 68.0022918215, 64.9078337860, + 19.6121887994, 7.2244101173, -23.1854400590, 30.4614578804, 46.9242283532, -1.0747268647, 49.2189640668, 44.6411673048, + 86.9687811173, 22.6744479392, -48.5360769344, -66.6164589196, 43.6822611836, 0.0803667092, 22.1251605426, 84.5472356977, + 23.3682917569, -119.0004161504, -77.5731290127, -8.1237991059, -9.8574787289, 8.0923731288, 11.6312746189, 48.8042209908, + -91.5385965138, -51.9417178439, -93.4017678039, -7.6902800177, 42.8038592146, 208.1745748115, -40.2269989314, 35.9946432857, + 14.8799963031, 72.5512530025, -33.4277806899, -3.2314305870, -66.9052809329, 99.7368956670, 19.5081727184, -29.1990516772, + 114.5317858084, -154.9703729745, -14.9584650353, 5.6179621219, 28.6224091068, 33.0426197666, 147.4892869040, -67.9739211942, + -71.7894315626, -107.3389637620, -95.5814122043, -16.2209528572, -32.6673756107, -24.6641235582, -96.2759765479, 42.9819639376, + -45.0775031344, 26.9177278735, 87.2353637167, 58.4214280318, -37.6862314706, -27.9660896146, -16.9115875649, -16.1061688951, + -28.9055343700, 58.1888376313, -38.1213943166, -4.7623621285, 33.9409953615, -85.9445074362, 3.1450686264, -88.4878703313, + -50.0848195592, -22.4167501243, 21.0397901669, 11.4240588629, -16.0956576256, 2.8322646297, -77.6952409905, 38.2576382396, + -53.6616605614, -26.4231916298, -26.3358464547, 81.4694985453, -50.3033670023, -8.2053965822, 19.9636273501, -10.4302918812, + 9.6629338686, 26.0903202845, -37.8068628176, 9.2638853986, -9.6752622225, -55.1704616516, -182.0875653530, -116.3887933434, + 8.5457908424, -29.0590636102, -52.1712423322, -84.2194156867, -17.3343644788, -69.9177944994, 98.4410912043, -5.8653773568, + 14.8287039959, -37.2315894188, -15.8744801467, 55.8855979582, 82.6374695897, -10.3491623457, -13.1871637112, -59.8321884846, + -13.6406794918, -90.9144246870, -39.5280425915, -21.9758399218, -21.0648164072, -37.2225695620, 179.7142651659, -1.6184261744, + -48.1631682332, 83.2309613815, 48.6367549372, -30.7160958486, -133.8419652482, 74.7583916606, 97.1026557281, 49.5481525536, + 33.9337592438, -48.6489706540, -74.5656495945, 11.2027589435, 2.2601440520, -26.1480067313, 14.1051697860, 104.3412840234, + -25.6567602627, 57.3314373931, 6.3330980799, -55.2666198655, -25.4971449454, 12.5333375030, 29.8117352747, -92.8414244156, + -143.2454500203, -7.5931354464, 1.8606525257, -9.6143470754, -56.0408726209, -26.0595448033, 37.1855765550, -21.2097936957, + 40.1996970371, -41.3351177032, 34.1834444638, -186.6269086563, -18.3614205839, -37.9357021641, 135.6670379673, 127.6586855975, + 23.6471207301, 73.4502163408, -73.9251876551, 47.5332209105, 50.1140713450, -5.8704801353, 12.9804536200, 46.7639885850, + -36.7458561449, -33.4506904080, 36.4941161678, 3.4199906571, -41.0407898239, -9.8181030415, 4.7245112428, 96.3687030689, + -28.2365241736, -17.4276379002, -65.7706653413, -96.5485126192, 46.4790636261, 32.1379379931, -70.2471563731, 52.3768573029, + 44.4162811009, -74.8951342613, 5.7318009676, -42.1108472837, -131.1371125092, 121.7221178589, 40.1216742680, 6.4128170610, + -32.2753329082, 36.3368525229, -30.2548033001, 72.6541502245, -33.4706909702, 15.8356670629, -50.4602392965, -4.4743341580, + 46.2418862356, 79.9973168669, -111.2430552953, -41.8285332332, 25.3359175319, 83.0841533978, -16.9581589718, -51.9200860092, + 77.9429675613, -100.4955466280, -16.9528387572, -63.4657485782, -14.2913689634, 20.8998480157, -98.7512394038, 175.0497111959, + 47.0357236193, 137.1821799965, 75.4859204931, 102.0896754000, -74.4319389528, 55.8710604661, 138.7844756707, -23.0214452064, + -44.0374225169, -39.5194006283, 17.6585042519, -83.7726310797, -40.9221184784, 66.2446785328, 61.9460848477, -26.5717761182, + 128.9173728445, -90.0154125585, 30.7220887905, 19.6211869212, 91.6137623259, 31.9401330791, -12.2054969481, -173.4012681649, + -37.8843684762, 2.3280971615, 58.8027265021, 39.6103768351, 45.9231885572, -21.2457868614, -56.1950724310, 93.8767608958, + -20.5075317720, 81.2860077414, -82.0982682957, -17.2313104276, -36.3367685204, 146.3298759474, 83.5645188769, -95.7871128855, + -41.4691805243, -4.4610514276, 76.4605569574, -18.7164073238, 60.5960801248, -55.1266248358, -49.3982202577, 163.4790300050, + 138.0264616472, -15.2636421738, 36.7895684788, 83.0702148363, -93.3437893057, 32.5989066039, -49.2049731278, 117.1479217209, + -35.4644848480, -44.5015630679, 31.3859706395, 5.8693717755, 17.3746859058, 9.9311131323, 6.1022018377, -121.9841205723, + 48.0645606148, -103.1127755426, 20.0433058006, -134.2922130039, 28.5016581997, 101.8535712259, 76.4518488086, -9.2802004844, + 78.1358057662, 3.3099138954, 69.8587685844, 110.6444273503, -59.6931547724, -51.7268303246, 64.0193271761, -15.1660919639, + 78.7207187414, -51.4776928138, 30.8703273062, 67.4488362333, -95.4561768870, -100.0161430296, 198.1825455394, 131.1359211305, + 3.8645077188, -19.1178912788, 30.3260202103, -19.7430200798, 12.7734912557, 74.1885333495, -67.8364659684, -80.8926661663, + 12.2720397333, -22.8440467871, -42.1377912025, 22.2591508655, -94.9559790816, 116.4053256024, 52.9759527067, 108.1630429012, + -82.6415576638, 107.0506710689, -32.4925050747, -134.7178668343, 125.0907581204, -33.0460380391, -37.8115604172, 13.4036941541, + 27.9798939995, -59.6965877877, 54.1339455110, 32.0538788400, 24.4020907468, -74.2815166253, 8.4464964158, -20.3601523468, + 28.5216426135, 54.3051140070, 91.5671757124, 44.5687804478, -50.8430812549, -15.1985800847, 72.6230011188, -63.3817304557, + 31.1651064018, 50.5057736622, -111.8897385947, -2.9491865484, 80.1135762676, -14.0696654619, 52.3521392147, 88.3353740728, + 87.0542702718, 44.9528879964, 24.2675410208, -47.3556425676, 23.6195853690, 61.7358141399, -39.8446197794, -28.6054825449, + -36.0836012134, -73.9089369029, 95.5989535672, 7.9458092374, 21.8693430561, -10.5751898940, -16.1045252653, 44.4127909167, + 18.0851707496, -46.7345019239, -92.6347568314, -15.6603448228, 39.6519674060, 29.9629332247, -24.9622443586, -47.2975561701, + -17.7780218654, 71.7346558516, 1.8999680118, -98.4624329314, 98.2614298645, 15.6787428700, 45.4912030123, 28.2495734475, + 65.7419427030, -99.5295634165, 27.2786047010, 77.8875001753, 16.3977450032, 10.2037888065, 60.8912178592, 82.1708628016, + 48.2506800969, -26.2756011209, -57.2019501999, -91.8180165526, -47.2336309942, -42.1121454516, 68.7279348832, 92.7832491188, + 17.6280339107, 6.7251426316, 25.0819097881, -59.7146158445, -65.8513175770, -41.0602910259, 4.5838916831, 38.8846775235, + 19.3473841098, -105.1434354654, -13.7765844991, 24.1616037866, 93.0893862826, -107.6082978084, -58.7977319447, 58.0759414185, + -89.7901093790, 16.1918835625, -37.2172665357, 123.6960140670, 114.2205895053, 8.7980887529, 22.1354877733, 52.2713979482, + 22.2246402930, 36.6257130653, 74.2884386832, 39.9288008601, 113.0416245079, 26.8047584467, 58.7266876251, -6.4680422666, + -26.7509331673, -38.6312732122, -145.0208923168, -35.9684264419, -117.5381191845, 29.8488196638, -51.1247043830, 112.6915937071, + 31.5277658506, -24.1454178026, 24.0572867542, -15.3632719912, -44.2556311042, 58.2449714174, -76.1363396817, 46.3749067777, + 3.4852275006, -104.6231553696, 30.1977700745, 7.0441446610, -10.0102536523, 120.6615291011, 188.0249410917, 44.3295887206, + -39.4106227621, -42.4924838463, -28.9316859978, 103.0113316106, 51.7061135184, -18.2169052015, 21.6066648209, 50.1453569033, + 12.7421867528, -8.1356008640, 75.2454422748, 64.8694058804, -161.7997182567, -17.1915039219, -41.2383269408, 0.8946812357, + 55.0533498639, 46.8242610223, -5.3780848566, -46.8156157192, 64.2205137708, -25.1479872711, -54.8298550608, 73.6823422266, + 41.9888520352, -83.9419623261, -41.0305214865, -47.4087035362, 33.2268582543, -38.7414663450, -104.9255474057, 38.2157988361, + -22.3790617016, -31.5426215850, 14.8891733573, -64.9019662116, -44.3044057867, -92.3281371013, 63.6669819235, -18.2425819417, + -49.5109487403, -64.0201431562, -70.3061633619, -147.3930233046, 128.8254864954, 7.6978217230, -56.3987238261, 95.5962971177, + 24.9319849141, -1.8305826630, 63.7414243665, -49.9852779582, -25.7389331291, 25.2700519583, 170.5603890165, 9.5266276922, + 13.5399442827, 0.7663023156, 144.5140143737, 75.6602313295, 44.5345480965, 35.8927901197, 59.9952333199, 64.3016125781, + 59.7518716703, 15.8739554628, 57.5686758914, 58.5866845774, 43.8356058096, 7.1335337346, 27.6439212874, -30.0398764928, + 6.2065364457, -79.6476847939, -80.1779260414, -52.2408711631, 9.9023027662, 10.3789070887, -46.6717275791, 57.2822267955, + 73.5763019279, -71.4639042142, -52.0323289026, -80.3692311543, 8.8431925427, -40.3750957204, 12.8573997402, -112.0129690473, + -67.5403575455, -4.9929337525, 131.9313839610, -108.2934624601, 17.2672219445, 48.9942839871, -90.7089806183, 114.9850344553, + 31.5988734490, 59.7636253519, -33.9764105756, 20.7915341567, 94.3558278877, 4.9570378129, 75.5601876581, 33.8799007373, + -90.7302419365, 1.0494275291, -33.5814817284, -50.4328011162, -52.6438122254, 10.3630633870, -90.7790260582, -60.4947106306, + 56.5127910083, 32.1019449106, -8.8885657127, 22.6481300860, -74.6992587301, -137.1086103933, -35.3402671515, 52.0032440119, + 14.9769109018, -23.0406615521, -41.8971596726, -77.3413472134, -46.9910623823, -107.4957490524, -86.8794002198, 52.2329975546, + 72.9424340427, -74.3244971184, 85.7023745145, 60.8778950641, -31.5903542844, -78.0533202133, -73.1733800101, 53.2034137779, + 83.0498994257, 30.2580271740, -56.1035163750, 16.6579677161, 0.2073439761, -5.7906867906, -66.8711603748, 74.0261467640, + -62.2989478643, 107.8399681550, 160.1626153730, -27.1263316346, -79.7784413411, -10.8403444789, -37.3887634955, 5.9808867714, + -10.1978150670, -53.9468869673, -38.2970373675, 16.3168988370, -1.0483342304, -63.6173233903, 87.0866029730, 26.3862156999, + -21.4053546455, -7.8216446996, 90.5994689064, 44.6928873902, -146.7075228500, -62.8122471300, -121.7119840134, -32.8992273432, + -11.9106565965, -104.6076313473, 127.3823687195, 2.4852952522, 8.9975686284, 45.5738431227, 16.8209391951, 26.7216521497, + -54.8776022226, -68.4194899925, 20.3925320149, 4.3453071650, 49.9988757708, -8.6636385971, 0.1191776713, -64.1528259747, + 16.0849193094, -24.1120788064, 40.7655203071, -23.7853262362, 91.6933164270, -54.3376676772, 69.7309190298, 113.1324293560, + 16.9278536871, 123.2439408123, 5.9934209089, -45.6409119369, 17.1842607385, 83.6522464227, -174.5484916836, -4.9414325022, + 52.8768375216, 15.6132102239, 41.1192572000, -81.3594721245, 28.8255333085, -2.0603766865, 6.4061712949, 82.1547586637, + -36.3679383103, -1.0390408940, -13.8483417281, 37.2231178393, -2.5777964710, -157.8382079085, -60.7910508762, 48.7258486830, + 33.1256641954, -54.6346845809, 88.2192196002, 39.9956402036, 3.2010617529, 88.1693658284, 11.7277451767, 32.7636165636, + -68.1591305748, 43.2699890762, 107.2828531104, -36.8225650893, 1.4407313695, 53.5742622795, 103.7597203839, -96.8481119045, + -70.2987605549, -55.2783713624, -6.9864094662, -40.3280834509, 16.8072891922, 24.3756993403, -84.6501745052, -45.3961429485, + -53.9237387431, 29.1708008262, 1.0498758638, 34.2610169651, -9.7905112911, -35.2443111357, 99.4574100554, -82.7243314274, + -12.3112078341, -13.4935295204, -65.0441169373, -1.5707942158, -8.0237289199, 49.5507868185, -13.4811149250, -3.9030733772, + -75.6220602476, -74.1596322041, -5.7789561939, 73.6177769297, -98.9485291892, 117.7192585235, -79.3791252579, 11.3447373614, + -24.5743979438, 33.7169431880, 39.8633765496, -149.5617929692, 141.9104918620, -55.0577810810, 37.2052313138, 6.4852281207, + -51.9122252169, -31.2592720321, -69.3547398856, -78.1122747852, 66.6338044220, 8.6865150501, -67.8354186666, -202.1226264943, + -31.1645341579, 18.2037364021, -64.8577486822, 32.5502423750, 26.0251882844, 5.0986012605, -47.2026094332, -13.9009556603, + 59.4152148554, 101.0702523560, -35.6013874662, 22.1677959258, -26.0857605492, 14.4754773923, -0.6780897798, -25.6530120006, + -25.4546641639, 35.7707567857, 24.5314489446, 20.0344481593, -18.3207572649, -9.7912924757, -11.9552594910, 106.8966283008, + 80.2653334386, -3.6056009570, 77.5441202535, 37.7136483336, -2.3165569778, -15.1111584239, -21.3047579337, 63.3629898072, + 15.4217847395, -48.6546027271, 33.3996963722, -87.5423526700, -18.8955709453, -85.0736444599, -55.2290313813, 37.6993014695, + -1.9420172920, 143.1251237972, -55.5771775185, -41.0289639463, -82.6515627688, 48.5420105013, 10.2288031648, -56.3379070490, + 20.0143954586, -84.8968512309, 127.0283241701, -79.6996444881, -52.6134879057, 22.0561680431, 60.7355377150, 15.4017379435, + -103.3924328801, 54.8459420743, -75.9157921311, -18.5478645340, -120.2337715192, 19.3119533190, 14.2354651926, 49.2411155276, + 178.0946722971, -75.1044338856, -17.7857687140, -44.5847020456, -90.1973261616, 21.4416495288, 51.9825060227, -66.7420817203, + 7.5764658958, -70.5144035274, -58.0645913437, -108.7601823595, 11.3207059592, -71.0204300166, -71.9141786835, -41.1119761277, + -63.1487461134, -7.1948924612, 37.4257273157, -0.3096640281, 22.3859391424, 37.4791977942, 4.7298794262, -33.2974745191, + 31.2867641674, -32.5753321154, 66.5419169580, -60.5202504180, 17.4192217276, -50.5317834280, 95.8748766870, -31.5464032969, + 44.7045552306, 64.5521928874, -23.1461700992, 118.1095509083, 35.1065388893, -27.9857316442, 8.2912382315, 39.7446781812, + 3.3485245256, 56.6810611812, -22.8994983441, 80.3970810489, 22.3086957726, 128.6454657339, 22.4798757743, 49.8362059423, + 22.4019441476, 27.1059712406, 11.4540686475, -10.0764491110, 28.4803668412, 94.7776130875, -36.8737987939, -88.8666428850, + 141.5495956917, -46.9343244046, -58.9586661150, 23.3890221338, 72.3692845286, -27.6356117882, -41.8318324842, 70.9559999727, + -8.0897813375, -78.2950183802, 87.8658917396, -70.5715383399, 22.1972033651, 47.8069266963, 131.7707915958, -23.8938128672, + -33.2047798206, -40.7583820499, 27.0405050078, 19.6445061622, -19.3891108700, -136.1942182249, 8.5255159178, -42.8234719503, + -70.4814202849, -41.0662321022, -9.3910777305, 136.7254609331, -6.7391967243, -68.4796734994, -27.6933664361, 118.5680907562, + 7.1623426945, 6.8386734240, 75.2481710418, 33.2280590090, 50.6011222647, -2.6551190091, -54.6429379954, -15.6441827245, + 34.8192824650, 41.1519964665, -95.5213521044, -7.1466152035, -23.1705143065, 21.8243235569, -26.6493944983, 44.3948925119, + -0.2695887637, -115.9753822388, 10.0551835964, 41.6343978371, 17.7354401036, 3.3862359071, -107.5692389700, 110.8538665943, + -77.0898864044, -18.5513096154, 87.7377015326, -89.7201205553, -21.4828890020, 12.6716787713, 71.2019960218, 37.7530110511, + -111.0886809644, 28.0083327042, 11.6412229475, -14.9061811373, 78.9633564364, -17.2424064978, 78.6411356878, 31.5888916445, + -52.2057754767, -51.8187552856, 12.8069170133, -44.4192811197, -29.6758641711, -39.2862559158, 90.7444415817, 9.9897923810, + -33.0089291278, -79.7506824464, 51.5840713006, -15.3414477161, 55.8773639416, 10.4014931469, -12.0825624913, 30.2487218486, + 13.4626458507, -41.6078761320, -99.0036616160, 97.2413199943, 16.2571104823, -106.6994082721, -42.5507290539, -30.6273488892, + -65.9180047092, -61.6996048814, 57.0455325157, 103.2653865169, 116.3758447306, -74.5041275207, -0.1164162789, -14.3978018054, + 38.0218224919, 127.8971402721, 5.4463615012, 78.8192543895, -25.6140607422, -9.2485898035, -48.8769533605, 34.5460968716, + -75.8820751325, 93.8969485430, -38.5976860109, 7.9177115766, -80.5122708885, 21.2658351542, 67.4252739338, 2.3783155124, + 83.9115322121, -75.0252790111, 37.9405478207, 14.4346316538, -109.9157163206, 108.9078208323, 15.7162891141, -82.1261022291, + -76.1782289525, 74.4747265412, -46.6029184986, -41.2456137340, -80.3895294383, -8.4118305522, -0.1933892651, -145.1576077775, + -15.4312649597, 39.2200199533, -13.6364330998, -25.8182203562, 48.1591475229, 125.4840761759, 15.9990051973, 76.3197750584, + -191.2988456723, 38.9117045838, -115.8653769258, 81.9245653626, -10.1602378212, 54.8635932256, -62.0258658391, 83.1033610875, + -4.8490223558, -54.6097329099, -10.9477363598, 33.0862207616, 52.7148056029, 35.4875411655, 49.1104822038, 55.9764111036, + 19.3458408685, 89.0606670761, -85.0457542002, -78.1726308870, 93.6580344148, -26.7125037520, 15.0835782513, 45.3860435621, + 12.4384130680, 70.5409358400, 9.8929034782, -23.4934005067, 40.6776169075, -65.7911681154, -167.1217168499, -19.4434798044, + 12.5047333259, -106.4886582913, -22.0096224479, -51.4306080664, 70.4101816964, 0.0684774882, -76.2887185579, 75.2064469835, + -63.0584107912, 78.4585282303, -20.2508456707, -55.6679838569, 27.4321350947, 84.1834097135, -10.3659243385, -48.4070302399, + 92.8062051508, -25.5124355326, -84.0473681678, 71.0714983360, 25.6083325312, -45.0808082818, -155.1967735998, 10.6420814804, + 151.0278845436, -44.2955308501, 29.5425559978, -113.6663161729, -36.5169042517, -72.3071551232, -26.8471044056, 15.6848246843, + -34.5750914935, -198.1775254215, 25.4131251136, -21.2604011481, -1.0414028296, -46.7191360308, 2.7446655943, 54.9295292750, + 92.4228624473, 54.8526054625, -58.0708705172, -17.5872514429, -107.1263606314, 3.8705217560, 8.9778481619, -6.0018700075, + 93.9938778953, 20.8072064757, 24.1862680085, -36.6869801034, 80.8573435056, 5.0571862502, 4.9644714449, 47.8862765669, + 35.1164783949, -43.2306708209, -70.4784884015, -22.9691864018, -13.9209248410, -47.9058355842, 69.2014224885, 36.4205028832, + -41.7969907806, 19.3910242176, 46.8411651043, -101.1964790621, 1.7651827600, 2.7058301870, -23.9427647032, -29.9388425668, + -85.3458953742, -28.9877302845, -56.3025916174, -20.8442568667, 52.2658233674, 16.2060641337, 4.4319659648, 114.0813888914, + -28.7002125175, 49.5308227691, -30.0766397744, -61.6828255791, -49.3247835301, -26.4413883089, 5.0971297500, -28.0554103014, + 42.0857897882, -47.9552784036, -42.7903198462, 87.8376670399, -140.5238322306, 101.5731331285, 52.2212327660, -22.4010751415, + 14.4300378085, -51.6886150508, 6.6829221172, 115.9640673493, 0.8066647921, 79.2442610587, -18.0322597688, -93.1043520771, + -72.1150120989, 87.2886742511, -25.4133998112, -7.4831361426, 33.0287073819, -23.1984191566, -23.8078728472, 59.7504642008, + -0.6923320155, -12.4892802407, 38.4436035475, 100.2867176437, -99.6305730687, -108.5810851604, 9.7451186318, -43.0333845061, + -101.8397764566, -50.5229450341, -23.5177624889, -64.5537003712, 174.8259413987, 80.6820828046, 156.0492701171, -28.0432391315, + 54.5458337882, -9.7039186394, 0.3967891057, 37.2171179706, 53.0918819026, 95.5734474731, -0.1572821866, 35.9295265728, + 52.6110638216, 65.4681244336, -58.8893064188, 33.3094740223, 23.7248112965, -86.1001662411, -124.2990486005, -53.0143407367, + 60.7137702328, 16.7099000008, -16.8984625777, 92.9154007512, 19.0020902188, -60.8943449371, 19.8803437206, -45.4933609435, + -37.9759751454, 38.9546342412, 112.6564725638, -20.6282048911, -82.6461566213, 33.1634895891, -14.6466202774, 70.8258934983, + 22.7763755890, -23.8551537513, 38.0027621248, 13.1891619540, -0.2512849813, -22.0294650280, -3.6017925014, -80.9408522816, + 2.1581228675, 35.0316749727, 1.4313916959, 7.6662501879, 95.6789578890, -25.3147779279, -11.1001968711, 133.3263412000, + 57.3919237887, -114.5247973399, 97.7159374781, -25.1589170064, -28.2795559691, -78.0626694271, -25.2625001068, 59.6669532190, + -24.8854138846, 15.9627092698, 52.0951356726, -49.4931272094, 32.2981549802, -45.2155042278, -117.7954359551, 71.9214384433, + -12.0100960200, -85.8922139632, 44.5277402755, 45.7283733108, 153.5133743833, -12.2908386291, -16.7857892861, -34.6184196532, + -56.8327470259, -5.4780874150, -38.8725168650, 4.6060525978, 20.3207039309, -3.0993047411, 10.1132085358, -37.8257661018, + -5.5665784625, -69.5263241776, -38.3990002707, 55.5634953442, 34.1515898646, 25.6046582443, 49.9096070185, 23.8082590350, + -59.5259871997, 53.0128767406, -14.6534382681, 25.3901141454, -20.2689398092, 112.6721308068, -44.3928586231, -46.9200544069, + -102.6597110918, -35.1087345365, -16.4476118027, -56.5493022087, -19.8752899545, 112.5790185345, 13.1594262867, -98.3712667207, + 84.7454129819, -32.0001239970, 33.2615003229, -70.2186017880, 129.5580075545, 14.3022334321, 53.5329352657, 165.1115533783, + 42.9337492453, 3.3467665656, 5.6916538476, 30.9878624742, 43.0083773411, 83.1082949362, -68.6733601131, 129.7158774740, + 0.9829430504, -73.5779156249, -0.2190628113, -66.4832285128, -18.1621332482, 59.5591274811, -47.9030207223, -33.0134331016, + 8.2663047608, 13.5843595697, -124.6750162116, -119.5553229429, 6.7914845141, 17.7380901732, -133.7630184698, 33.7185572623, + -31.1975924142, -55.1798482215, -72.6025491416, -65.3245960982, -8.7224630378, 27.6488501343, -79.6246723592, -12.1515699989, + 84.6626846949, -53.8044373764, -47.3237819756, 58.7153917563, 23.8284036126, 18.5922606945, -41.5094930442, 7.4798082503, + -117.3348631592, 28.0374584580, 17.7205965437, 37.6075060837, 10.5295050958, -10.2113391455, -25.4289536763, 80.7158011723, + 134.2497737713, 107.8649950212, -8.7918461736, -99.0628159937, -28.4975407702, -2.4658161692, -1.0354059017, 3.5152634039, + 34.3665501560, -87.6859371958, 33.3653060530, -45.7175591636, -65.4175088722, -39.9650581770, -57.8964432706, -74.5229831900, + 38.4192570282, -93.0015200930, 102.6189889638, -15.2156059788, 8.6020521359, -40.6649198594, 19.2140495475, 68.7122869639, + 43.8544891050, 31.8559705108, -56.5147934081, -76.4182242061, -20.7528009745, 122.9729619714, 19.3412487106, 119.2231188878, + -61.6916564137, 19.7466881922, 1.9628648319, -30.1476626231, 26.0368611826, -25.8750640673, 126.2461067518, -38.3759348959, + -21.1488548859, 9.5896772329, 60.6570721102, -27.1555851824, -82.6629073502, 104.2859535395, -17.1669088713, -104.6106452933, + -45.0398334945, 43.2080892320, -87.3425077484, 0.2033770682, -25.6876572199, 79.3659499889, 29.0973624285, -23.8554325099, + 25.8594825320, -65.7761031112, -3.5831773610, -7.5912426740, 98.1472561219, 13.1498139916, -13.6564623410, 56.9471294530, + 3.7663518315, -75.6123083481, 44.5806865445, -17.4609911479, -55.6387091480, 44.2177387420, 34.3752520512, 91.9930112408, + -102.4716789145, -40.4480770016, -14.7542706842, 80.9321121716, -67.9012532377, 74.2022584642, -39.2995936367, 95.8528505885, + 107.5716319470, 8.1259867727, 114.9534060173, 96.1080490303, -30.6405288182, 27.3131447051, -22.5066083621, -7.9447818944, + 25.6505787602, -67.1523588791, 65.7872616460, -3.3285011027, -1.1041085569, 74.8921702514, -25.1084011697, -9.7589516985, + 126.3993857146, -70.7299876677, -22.4069284847, 15.4150555050, 6.0494312782, 14.7172132463, -36.2348351724, -63.4858079910, + 8.2207526905, -101.4967633400, 12.1832438786, 49.7125534112, -99.3127122046, 49.9528617888, -7.3125598688, -22.6006580462, + -31.8424104370, 18.8121241410, -89.2005207726, -89.5613310067, 37.7746014303, -33.8940703850, 98.1050260145, 132.6754622940, + 91.4832076657, 48.9724771421, -52.3241324047, 73.9850811745, -139.5294058433, -14.1985477071, 10.6320943394, 32.9842589505, + -117.2355637537, -149.0942826923, 118.8257377105, 78.6561766800, 1.8467003036, 76.7457523519, 35.0575934280, 35.0405067972, + 46.3433191288, 51.5391456892, 43.1210412216, 21.6828221089, -24.7058117089, -83.9863281328, 7.1502359525, -66.4432335170, + -11.8942947461, 27.6420249691, 101.5285396899, -168.7093966612, 38.1892453170, 55.9668521894, 64.4854368465, -32.3167099392, + -37.5824582463, -25.5064561372, 107.2513163415, 9.6344685960, -44.9269370404, 10.4288908869, 46.7640176210, 33.7300219820, + 19.9212664361, 70.0213390428, -62.5237740415, -81.5465118244, -44.0793815204, 92.2566857417, -51.2000490212, 6.0091571611, + 30.8037109068, -44.7595662927, -69.6108606342, 64.6862483343, 33.1742048387, 55.9059849044, 66.4985799238, -48.2816133661, + -22.7185185172, -114.1511261421, 147.5147842854, 9.9781895463, 8.0732325157, -35.8047978931, 75.9079000901, -6.3144641143, + 13.1307658403, 17.7593379387, -68.0746602967, 81.4962779846, -21.2130737883, 4.1881456029, -53.3976620104, 73.0143978370, + -131.1048524173, -34.4396004841, -48.7367342675, 97.0896245872, -153.8743591626, 146.4347629539, -23.2984615872, 62.8412359714, + 12.5390587557, -3.5600971161, -6.8863206565, -43.5270424219, 32.9707655033, -103.0889331877, -64.0535042805, 106.9215904598, + -46.9078727795, -18.2192480137, -8.6225312780, -75.0230233110, 33.5402016456, 63.6373276750, -35.3286634556, -9.7322691960, + -104.9070709198, -44.8063768563, -10.2396474262, -141.5682333490, -41.9856066191, -64.5568181205, -105.7644577258, -34.3266130311, + 18.7442551407, -6.1736131415, -25.1300038952, 45.1470563965, 74.1676313724, -21.5064254542, 70.6267797692, 54.4904113618, + -35.0016926163, -36.8626539144, -36.1085281705, 126.4456731006, -53.4352000664, -42.3833008015, 80.0205785607, -5.8395042605, + -3.7163929006, 99.0418697430, 67.5450923850, -71.2740732169, -57.7639750215, 28.3495782004, -14.9114371149, 68.2395578146, + 19.9391412722, 0.3981730821, -67.6429500835, 99.3355729015, 16.5267218873, -63.2226829304, -18.9357631878, -2.8614372915, + 181.1332468568, 34.7347222636, -16.1060495743, -2.8148621786, -45.8170675798, 43.3943251920, 28.6117124005, -33.2361768688, + -38.5248849741, 49.6677439095, -220.2210251040, 39.4305879349, 66.5483442468, -53.8217192052, 67.6757901350, 33.4240885070, + 85.1809128375, 14.6803329701, -35.7116442076, -45.9462851452, 142.0722968061, 7.3538820438, -74.1993826074, -47.7693348567, + -3.3338017336, 41.8589920225, -27.7802513358, 81.0798842587, -35.2219569758, -22.2714108513, 20.5772883573, 68.4758687172, + 51.7089964364, 25.7997568352, -75.1742154071, 50.1290455164, 14.2169709710, 115.3455403147, 3.0734091132, -24.0080167664, + -30.0430862767, -85.1846499745, 19.4251899965, 66.7660313085, 10.4964191964, 191.8810766140, 44.1684279713, 75.7858859863, + 19.2241630741, -16.1074277656, 30.9051369625, -103.4147225746, -9.9194221597, -13.0669809072, -14.3302540445, 49.1519159556, + -27.2523237365, 127.6868804216, -85.5747904513, -40.1209192492, 178.0522707351, -73.6864713410, -36.6342055327, -99.8126854419, + -41.0696248653, 42.1245867015, -4.3161823048, -13.2747008746, 119.6002869940, -17.1335931288, 62.5993425061, 28.9992320778, + -4.5368180858, 1.2779053761, 27.7084888678, 34.8899603537, -30.6048794059, -93.8465401416, 3.3778313360, 13.8864217937, + -62.3784185879, 27.6165516418, 6.1885364328, -45.2772604479, -56.8928574665, -7.8629078173, 47.5072063672, -47.7279779449, + 116.3659358841, -108.7063603401, 6.8435296791, -4.2310899521, -48.8520623760, -42.6788172675, 28.7598264712, -45.5725981159, + 5.3364646966, -8.8259790870, 53.5478850699, -93.0251963014, 37.5833785601, -5.7207089841, -36.3899380994, 21.9593949993, + 27.8919793663, 50.0242670536, 38.7060750441, 13.4383538753, 24.3284938604, -66.6706972814, -75.0556788531, 46.8080800007, + -76.7685518979, -110.1823907916, 117.3556114385, -11.8794346783, -100.5931552045, -81.1814329321, -11.1946927034, 65.9117165560, + -35.0871947675, 68.9890931402, -10.8170265109, -76.6397320929, 40.0628004769, -13.8876229441, -47.6413458333, -82.9301597006, + 35.3601089866, -27.9439892787, 93.1557477015, -43.0973522277, -28.5635146727, -12.8419650369, -19.2552737753, -104.4730738934, + 51.2133027222, -80.4713372457, 82.8904666296, -32.8693411980, -55.1514350588, -32.3215790447, 15.3586714150, 56.6281953096, + -4.1845768663, -21.6039139687, 37.2300232632, 41.1966104813, -18.1197213904, -43.3281929812, -39.4358705806, -68.0037577582, + 102.7052778200, 1.1074295163, 148.3224324741, -139.1640107475, -33.1782275394, -49.4813361135, 33.6935341991, 57.7540768190, + -50.1484966873, 25.5452659987, -58.4535765464, -124.3028152080, 46.5749355946, 88.3984919306, 18.6343901041, 27.7237147347, + 7.4621558601, -45.2696342528, 6.2181991419, -124.4793150492, -34.3600196858, -17.2893599431, 10.3880081085, -34.6584762030, + 80.4621681009, 42.6698890316, 41.0028635312, 40.4584805162, 12.2993857558, -2.3438124814, -49.4434262439, 67.7382058590, + -172.5728037457, 78.5681808033, 93.0200717559, -34.3893038739, 25.4332764674, -0.3084790746, -47.0942986345, 67.8054627172, + 122.2738316110, -84.4716788862, -15.1596922578, 73.4104827953, -26.5231401219, 53.5433793756, 121.1802722337, -24.9087077008, + 65.6955157778, -100.0325133938, -5.4645525511, 38.8338919462, 38.6764256003, 7.4857563167, -84.0517801108, -38.0837770598, + -35.8795970303, 42.8800471728, 166.4026567891, -45.2596493921, 88.1539836076, -84.1569136898, -44.8705239205, -112.3135915515, + 76.9816499152, 53.5768624176, -106.3408650991, -17.9979586956, 81.7718580719, 144.1648782825, 45.2239065385, -50.2094826104, + -14.6605194110, 57.1970152560, -23.4826391767, -27.1562674435, 110.9001894435, 20.1915788307, 12.1467090660, 16.7983072789, + -34.1257273005, 129.1575417206, 71.4391384766, 32.9596044485, -41.1052127849, -48.0458686558, 0.8731114023, -34.4439480200, + 29.9076993320, 68.5240097999, 78.8047480081, 10.3252970915, 0.3515809390, 73.8823954039, 44.2008862678, 72.6737200450, + -13.3069689810, -25.8971947295, 16.9120909673, 53.2843809510, 49.1074875555, -68.1235965933, 13.6903318056, -14.7046510890, + 1.6746416299, -108.5007545621, -83.0295464360, -3.7524687555, -14.4088682542, -138.1935697707, -19.3679003715, 38.9142288940, + 15.4764570005, -2.9192486908, 43.9598275111, -34.5312517096, 35.8385011650, 4.4981476232, -1.4454488029, 71.1184852411, + 41.7476890934, 37.3368072067, 57.4916368307, -32.2735282446, -27.5080391474, 95.6899861001, 3.3351685514, -111.9822940053, + -12.5463248694, 39.8668835259, -14.9822708781, 66.9305141224, -197.7731587893, 27.4387742251, -25.6710982597, 13.5207634746, + 50.2848552534, -30.0418256053, -14.1615451430, 68.0658302876, -62.0642327357, 4.6615575342, -26.7572433532, 11.5079596851, + -57.9473530742, -26.1405191819, 70.4111692091, -95.7407842078, 11.2517762488, 100.2275069926, 85.3653529140, -24.6494053691, + 123.2413542720, 21.3040690490, -192.3747625981, 215.7057282840, -29.9835524152, -44.6302014167, -66.7559203920, 25.3479943282, + 126.6443711753, -36.7355336011, 29.0095532019, -73.2298015066, -5.8223869363, 11.9451128557, -17.3486371102, 50.0400958000, + 74.7145985867, -5.6976135921, -73.1829497279, -41.0455578170, -3.6001825808, 87.1662509692, -39.1602156793, -41.5727119025, + -18.2071856447, -3.5383471563, 28.3732842092, -39.9931298054, -100.6902365532, 130.2869328357, 3.2473773399, 16.8387727072, + 62.0055283576, 97.3165730637, -40.8530624130, -12.0491532592, 88.5164060609, 71.9344891420, -69.7440181255, -51.2866033193, + -18.4687017548, 55.7346964760, 4.4872782938, -6.8942183136, 8.4263132246, 18.9149616636, 58.8710265459, -17.7415034047, + 5.2927869482, -20.1947447871, -36.6005304743, -67.2193634013, -72.8315856033, 139.7216799221, -2.1966369437, 83.5189402317, + 56.0625496338, 57.0100118287, -9.0542670182, 58.3126231383, -27.9316577822, -125.8146267036, 77.1179593561, 99.1690581411, + 7.9703321651, 77.3501770612, 32.2815633360, -22.9643212257, -19.8653554993, 55.4837678464, 10.8929872542, -1.2452363726, + 83.8477026208, -88.9116003335, -44.6537617432, 11.0099195187, -33.7736999447, 44.2766753802, -27.9436876110, 16.3088473703, + 45.6564921145, 18.9199921114, 77.9125802822, 11.2795611793, 42.8571148149, 32.4846418196, -2.4014655924, 38.0598657284, + 86.5222537258, -3.1333316838, 11.9141807475, -2.4712869557, 47.8938116812, 35.4899843246, 42.7527497689, -31.3225362175, + -6.6842304948, -133.5691427053, -58.7043550030, 73.3503470631, -21.8739658759, 70.3809855428, 54.6113598087, 9.7384709498, + -141.2343505501, 27.9788413890, -11.7574685128, 43.1029141674, -52.0045609619, -83.4803133516, -57.2548505744, 52.8114424452, + -30.3458066567, 39.2081027670, -49.8609769923, 68.8871987820, 45.2005862545, 21.6377482234, -9.7576398020, 6.4878505019, + 32.1853134925, -25.1448500950, -67.2234044003, 103.2446765175, 80.2584971166, -68.8710032588, -4.2141933840, 23.7223935599, + -35.1939439880, 63.5237841071, -34.7833780059, 74.4175406287, 83.0373073374, -28.9674699605, -55.2233708526, 64.2239365944, + 6.0025041292, -22.2149197781, 29.1954442931, -35.5058495139, -76.9452133862, 34.6912996871, -51.1833830895, -49.5201882461, + -7.6144484864, 116.8549382108, -51.5005710672, -20.6783396225, -97.1232859994, -6.8466290384, 59.0410141864, -58.4613374526, + 74.8248237895, 75.2714612487, 23.1797286361, -2.7866665487, 56.4240759131, 60.2417537402, -73.0762506733, -136.8520754748, + 27.3836498800, -29.4294016791, 58.2863141991, -15.7937240880, 12.9792729458, -28.5369095369, -179.3559659693, -99.4879434608, + -61.2402838269, -24.4763496292, -22.6643525306, 24.4590321501, 98.4299041736, -4.5624798871, -59.3191765161, 139.6951240672, + 27.1672202072, -70.9192843433, -18.1408458038, -71.0174628677, -94.0725395768, 36.1985844031, -3.4636448040, -39.1453082944, + 40.5244522827, -70.0489070024, -63.9181488122, -4.7099187837, -33.0844286599, 31.8161456785, 10.7843286816, 10.6387816259, + -76.2043252282, 57.0254136124, 151.4166547223, -50.6728456416, -82.4408455004, -55.4932097322, 15.9101565878, 15.2777050730, + 25.0235583008, 44.4425994137, 36.1343164402, -24.3058262644, 17.6630395266, -62.6364549232, -40.1045046999, -3.8451609954, + -107.1141779059, -50.7347331775, 90.5704587068, -59.5674315899, -23.9371281478, -59.3738147851, -29.5056040676, 26.2990433281, + -33.2953407976, -92.2663237623, -25.5442696217, -81.4532880743, 42.7268859073, 75.7986045911, -31.6772573595, 86.8684653590, + -61.5786934151, 32.6176822340, -23.2321244436, 64.9301578846, -6.9691761031, -51.6553861957, -35.7877314260, -41.7444743167, + 108.3757802905, -29.4164640263, -18.4714648512, -82.4131988957, -52.9499171074, -35.7687451877, -80.5212521683, 40.1558185933, + 80.9139882507, 0.4170638335, -52.4487435334, -69.0227900586, 55.0806458770, 120.0318572894, -11.5435935376, -19.2791170530, + -3.0257623065, 99.3958103659, -19.4539047939, -54.6600691116, 0.3603986276, 9.7863628822, -6.2358897021, -17.1143829423, + 7.9650683489, -27.0465697723, -45.9436029022, -36.3352947671, 138.6511673472, 47.8115852675, -10.9612291181, 3.6500932948, + -19.3477824988, 28.7386285394, 36.0065971791, -43.0822654618, -43.9342369010, -32.1210042559, -70.4441432492, -94.9421856551, + -120.0449164046, -65.9803176675, -55.4329926958, -19.2914305328, -89.4078846739, -30.1962221428, 61.2293835442, 93.7229961578, + -8.3020564344, -6.8386266801, 21.4975406760, -15.0903918291, 94.1044891682, -57.6380884034, 16.2327931770, 1.7957525957, + 74.7073719610, 26.8908104028, 76.5155513347, -9.6822139478, -8.0655893270, -48.1277441855, 9.8408952157, -58.8121626519, + -80.9751650730, -48.3302191201, -27.8207839032, -46.1625778067, -33.5567739103, -109.4477338693, -168.5366005131, 156.7874587017, + 8.5940307118, -21.7826451231, 12.4113841726, 86.7850811554, -77.1019195511, 32.3109085681, 86.8849726762, -41.2571797820, + 19.6006773321, 31.2507123002, 41.8106047980, 101.5445768198, 51.5335715773, -185.1354355374, -11.0825031251, -20.9631685642, + 111.1640505949, 162.0618916128, 3.4498453592, 44.3198102843, 0.3505982148, 21.3783009799, 24.6853218910, -20.3399016930, + 59.5923416012, 79.4334110932, -78.7723219668, -47.0670061218, -128.3114982420, 92.4340029556, 69.1584534808, 114.9437583487, + -64.6124706594, -10.2486262273, -1.6622261589, 50.9747480555, -8.1203432808, 32.4414442459, 84.9091411511, -17.9846748341, + -14.7172591486, -27.4203006303, 167.1594042893, -25.3372000386, -27.9888042652, -3.6956600039, 117.9111608126, -25.4132038904, + -42.2923300579, -95.1602974120, 19.2625367900, -15.8766055664, -8.8117613783, 1.1964763941, -111.4791843369, 81.5745053342, + 8.7527287102, 34.5972180603, 83.9461794412, 50.2350993915, -19.7720255327, 53.8516694944, -104.4119088056, 30.4513918056, + -62.7649123620, -29.9513577664, 7.5719075796, 61.4944149393, 70.5737863978, -40.0358428522, -17.3629194898, -10.7304848224, + -60.1358805635, 46.5402792333, -77.1330673251, -86.7606311649, 22.2000151841, -33.7006112473, -139.9917432329, 138.1567785372, + 18.7396823616, 28.7669927272, 28.4680008506, 7.6199316893, 121.9175024680, 32.1111318802, -58.2808504609, -30.6563801124, + 44.2365370915, -83.4728239003, 64.0531120026, 128.0019381122, -40.3205961091, -62.8035436979, -15.6689887241, -6.6975189783, + -46.1591606362, -42.4253060115, -71.6473279718, -75.5337463898, 87.5058573621, -66.6145644703, 87.4635891068, 123.2852237793, + -0.9887550633, -9.6307226422, -67.4478350330, -86.5892204275, -79.0537798176, -107.7863332665, -8.8330234138, 38.9605563706, + 15.3133829507, -54.4231514572, 26.7406100788, 48.7962706395, 27.1443310148, -2.7894277223, 7.1469114703, -57.1657209995, + -90.4215183139, 76.7797176290, -19.2239853483, -26.6041739391, 139.0298606143, -36.8837362822, -57.7952841108, -135.9897057237, + 4.3453829113, -5.1660378716, -58.7046205842, 58.4176557979, -120.5866252228, 34.2409281832, 105.6219016158, -28.5323871865, + 11.0598518159, -26.3069115094, 87.6681723683, 70.9393661419, 54.7982850455, 4.0477327154, -89.5568838538, -32.8993562613, + -45.6708773935, -52.9428269719, 14.4126898406, 39.2142079784, -92.9447367684, -23.6977408094, 8.2507547267, 77.1071852874, + 24.1675316234, -159.7349628761, -13.9551749672, -67.9761692092, -30.0410317845, -24.6060572570, 52.6662467162, 53.1957816963, + 16.7992222346, 51.7621999618, -9.2959681635, -22.0395789118, 63.9887836127, -15.4794522124, -59.9041019732, 0.5489176194, + 78.6395685166, 134.5366929272, -6.8712023878, -25.4182816023, -94.3014920612, -120.7349462621, 15.0267811895, 64.1156824538, + 72.0730568718, 36.1969392849, 37.8409183719, 23.2904067106, -65.2310984397, -174.2644489990, -19.2228520790, 27.4717232382, + -59.1645079992, -37.9473607579, 49.8799507321, -79.0510884528, -28.3803465367, 20.3721781567, -0.4261835910, -35.8489167205, + 105.4583901558, 59.5722685004, -61.0197468314, 31.9348090719, -71.9443219028, 58.1935525762, 24.2368907755, 11.3281193558, + 73.7442066031, -58.2463274873, 62.2364089748, -22.1662416753, 80.8054311590, 1.1123457543, 65.0742762981, 34.9247990206, + 104.0897515469, -17.1726872127, -55.1967923359, -17.3070263921, -113.2466807440, -34.0273063199, 6.0065175641, -73.2050951521, + -46.9298900117, 42.5522795079, 89.6038769626, -13.3758161339, 20.0379230047, 44.3053936382, 38.7871513797, -96.5643124661, + -164.2750976118, -37.6742328774, -20.7444978754, -57.5075374112, -82.3747950875, -148.0525559565, 23.1385046849, 6.3810748790, + 26.2079771260, -76.0359611120, 49.8590173195, -55.6975098542, 63.1577456002, 131.5982420723, 46.7778921481, -60.9806982634, + 71.7495044841, 4.3127212188, -17.6552774593, -32.8038637189, -77.8751385740, -38.0621029989, -10.6340276560, 16.6596173712, + -67.3032141305, -8.7994716202, 50.9412272541, 49.9717453353, -43.5703597564, -49.6853674924, -95.7205166501, 40.8765465419, + 14.2287448407, -27.0614166095, 38.0714114583, -35.8412172130, -78.5197707657, -25.6825367235, -0.3120778923, -13.1591053910, + -13.3423425539, -88.8689993653, -141.9490353220, 15.3348435554, -1.2351271212, -12.5689032236, 63.2692606259, 92.6940600989, + 30.9761753348, -14.6354581107, 50.0664499041, 22.2230304376, -128.4011635209, 26.1869851104, 8.3304256738, -46.1344839419, + 68.3461812478, 143.4759863425, 163.6742650341, 55.1856555010, -60.1365810845, 74.3895957960, 40.2227984754, -11.7394255168, + 55.5453683738, 15.9202002202, -113.1213822368, -85.7280046039, -39.7263088573, -2.5339105246, 41.0492866970, 45.3079876954, + -99.6701239491, -29.6980232319, 18.5340063985, 51.1922973890, -79.7372970167, -13.2393250851, 14.7419728226, -4.8211133780, + -35.5172595564, 99.3966537203, 20.0590181900, -12.1081446475, -61.9594867060, -72.2256752476, -13.2936631274, 128.5345002108, + -71.9401693778, 31.6533870911, 50.8594991278, 25.1808453324, -33.5538293275, -42.3935228996, -20.8053274690, 16.2131527996, + 118.9172555234, 89.5930952748, -65.8274795934, 47.3384633282, 122.5406901256, -66.7549348343, -54.9185037426, -68.6601805746, + 34.4675543582, 104.9323617738, -57.0880010038, -43.1248502597, -2.0601370211, 44.1682882967, -89.1023577428, -35.5506312941, + -10.5170036504, 9.6779403375, 78.9291026934, -31.5855420521, 92.7949646880, 31.3559964123, 12.3617000392, 69.2326522660, + 3.9119449943, -36.5330788106, -44.5936841393, 45.7052258609, 10.6224387668, -24.1159570162, -21.0651270325, -84.0415379963, + -130.5857682422, 13.6064059568, -33.6699927959, -26.0082360265, 29.6219265142, -47.8318612795, 19.0742065634, -52.3410098996, + 32.2488186667, 8.7112925773, 68.7336792115, 23.7944448682, 99.9050365463, 8.6093548114, 59.7174217811, 23.0796589837, + -113.0722961466, 3.5971633707, -6.7890993972, 30.6764504710, -41.1295367209, -24.9164165484, 99.2386401122, 113.8333026527, + -38.9562599796, -55.4108562109, -94.4601804558, -31.7511549793, 200.3462283262, 12.7517487160, -42.3353937717, -51.1991446233, + 78.8520856510, 20.4131030912, 21.8102532347, -51.7944815361, -21.2191019005, 33.8300001131, 135.8377663961, -31.0221091170, + 65.7730407411, 82.5117419278, 27.7816244812, -10.6724454248, 26.6179164033, 64.9214169340, 44.6475686302, -29.0683019634, + 2.0965746914, -10.0085359932, -29.9021362947, -38.5046703557, -23.5486473509, -44.4560504617, 7.4417079380, 47.2393973843, + 37.7344798725, -13.6323296763, -28.2713540400, -12.2494841889, -113.6616109440, -4.4061813255, -84.4155850685, 18.2000114801, + -37.4375420019, -15.0025190330, 33.1826857536, -7.7672966949, -41.8570537108, -61.9447815201, -20.5430470077, 42.1225812423, + -4.9372231166, 80.1718433860, -21.7502429381, -107.1994683407, 39.0450370860, -13.9605768571, 57.8271065756, 100.7288025395, + 106.0257089013, -94.5099462535, -52.2425831475, 3.4251117300, 37.1163293092, 20.3088713026, 27.9957748777, 55.5881357120, + -49.9425573612, -74.3122437274, -45.4384442770, 28.0519415044, -57.3995353506, -34.0343398092, 39.4842857378, -29.4934441942, + -42.2931922612, 75.5085698437, -9.1579964746, -88.0001960638, 32.2921191297, 130.2295801645, -77.3690707106, -26.5699179687, + -98.7746128367, 15.1111986863, 84.2856839075, -91.3321816766, 75.0539365102, -22.9577135979, -58.2687890669, -16.4158023440, + -143.1190919220, 45.6864012367, -148.7549620241, -87.1075640764, -26.5968533502, -69.7944158144, -34.2978456494, 35.0769663698, + 4.1465107386, 69.0864439105, 22.4789950234, -48.0182401768, -14.5783104039, -61.0550243844, -4.2380948973, -194.8804104528, + 123.0819765947, 48.2017401505, 78.9508457466, -99.9736614294, 32.8340209984, -1.0245301508, -17.0041736706, 35.4641249127, + -33.3575407148, 192.9072183682, -42.9604868802, -51.0374996711, 77.1464797096, 66.0548981845, -61.4282764621, -114.3126571027, + 21.1118181552, 85.5335633765, 27.8488718530, -62.6421354515, -57.3557048619, 41.6670106942, 16.8928119140, -40.2432649132, + 0.6390713008, -10.1237727904, 52.7534146685, 2.9801643945, -11.3804175086, 119.2039503951, 46.6809821778, 84.8768259311, + 29.9865105951, 57.8288066379, 107.2625212828, 28.1456885969, -120.3755566725, -17.3802551503, -40.0564653651, 56.8407045846, + 1.6793816918, -109.5072716396, -52.8897837730, 85.9453300669, -20.0298903469, 52.5871200627, 13.0362762617, 92.2325099999, + -6.5198193020, -83.9036654607, 58.5211535567, 81.1131330707, 57.7324249784, 126.0368845782, -79.8586002513, -127.7584493863, + 64.8736188900, -10.6521288269, -0.9851623286, -92.3945133485, 7.5244215841, 40.5886593287, 18.6445609457, 19.1117310556, + 26.5640714899, 22.8091685027, 94.3470412324, 61.6764800801, 10.8760679684, -7.9240673383, 12.5919458396, 85.0254983280, + -15.7186492832, 30.3331627482, -136.2555384486, 14.2342767573, -52.2232864172, -49.0105238845, 16.4028777072, 13.1934114315, + 67.2005286948, -11.5431941527, -126.8761059118, 28.4325197274, -5.2730565073, -154.2913406142, 83.8362133106, -13.0557850235, + -24.0425722731, -9.3049739156, -91.4408491189, 38.7967852392, -54.4364475655, -50.1728478153, -91.7628978624, -92.4046791871, + 72.6594194204, 36.9149973552, -89.5520370642, -73.4541912166, -83.1026853287, 55.8083893384, -11.3360468605, 8.0892870502, + 21.3963536134, -27.2804196146, -86.1680209134, 11.1581691823, -68.2490961721, 63.5960852067, -40.1782672381, -50.7929323122, + 2.4820154810, 35.6921504427, -75.6795637705, 8.6054661804, -31.1168448045, 109.0955889455, -76.2488069978, 5.0199927782, + 37.8749455521, 5.6982241556, 27.3294929004, -120.2473221866, 7.8826650171, 111.0369524326, -43.8497436507, -66.7312430666, + 97.7440071817, 49.1570048378, -117.8025876335, 168.0477524482, -55.9600221068, 11.1068434425, 14.0513599858, -47.4087780504, + 100.4504374216, 6.1074714956, 53.7678384486, 24.4635321166, -6.0835375669, -64.3592936645, -25.7780083698, -83.3530662624, + -124.9544432106, 37.5615380015, -19.2986773913, -110.0015552689, 121.7589202263, 4.3256928319, -101.6571157133, 85.6785418597, + 16.0474362836, -31.9024530060, -52.6323741801, -3.4440544641, 77.7351607744, -10.1741553840, 48.3997106271, 1.5020725442, + -0.2257709330, 68.9623795901, 9.4286729097, -27.6379770488, -3.9912724152, 44.9954087833, -18.7057514605, -14.7638693232, + -1.7397189655, 68.2217569488, 63.3439223434, 38.9512814941, -25.6642624084, 54.1881119719, -92.4999870174, -11.5788876807, + 69.0279357511, 55.8205676574, -101.8852049100, 30.7429453237, -58.7382928803, 89.3969596003, -44.8903243228, 2.0422419096, + 41.1330103123, -88.6692130110, 25.4298182542, 0.8899898304, -53.5428328048, -11.5755725623, -28.6132997670, -13.0337245663, + 52.8092078154, 0.0517964686, -138.4959804685, 31.6788581756, -16.6154597478, 156.3340569922, 93.3010192905, 32.6407669098, + 112.1297440517, -35.7144834638, 6.5534121327, 128.2382195529, 56.9609192462, -52.8328776011, -65.7950928061, -13.3541979410, + 34.2814367341, 26.0764152312, 52.6477198183, -121.6672795964, 53.8959085384, -64.8464505733, -6.6989481273, -164.9991018529, + -12.9977296783, 92.2198340788, -58.9488062177, -17.3136354080, -15.0065268104, 82.2346850297, -52.0081326057, -31.8754548129, + -36.3987954967, 53.0154983421, 27.4015508471, 32.8268124997, 113.6916804444, 27.8095494681, -55.1665416696, -16.4156645469, + -42.1439424759, 38.5634363918, -64.9312441199, 8.3884871895, 32.9516167667, -0.9395063314, 58.4852381959, 101.7397916741, + -104.2729685077, -14.9331020781, 64.4379817410, -5.6149495442, -69.4590669042, 128.5957740501, 61.9917796337, 0.5819416032, + -69.7790071374, -1.0381159167, 20.1469541660, 13.3351412916, -104.5227876095, 77.5294242919, 38.0641940199, -56.7585742367, + -9.1765854459, 40.3713276531, 72.6358559436, -14.4449566608, 40.7675499413, -93.5568526062, 55.8238199978, -57.5895140577, + -82.1737195067, 14.7561780278, -155.1331660454, -3.4741158421, -90.9790829737, -67.6576031648, 58.4505812875, -127.2647404391, + -52.6551154593, 21.5600272148, 77.4232312163, -100.1093952602, 50.2042564606, 11.9885332900, 34.2641380301, -51.6644779651, + -14.4960161445, 67.8496081597, 25.8195812544, -38.8690931971, -116.1556251224, -68.6610388123, 64.4060064748, -4.5039590319, + 45.4866635009, 60.6472857766, 121.0539185194, 4.8340889914, -37.3668396220, -52.4747123096, 7.6362446201, -39.8862759852, + 8.0139163506, -19.7768070929, 55.9705429761, -77.6639159836, -9.0747973730, 87.1299271010, -56.0307413158, 22.0261066362, + -21.4877846313, 73.7508019333, 90.2727567859, -31.8064851485, 35.5698971534, -123.1337229178, -115.6888113061, 40.8859379019, + -45.9826093754, -55.6481101801, -131.3553753176, 30.0527360996, 21.6632646479, 98.0105924807, -39.4117175619, -101.5958309784, + 2.4560883180, 47.0714688572, -30.5516644873, -123.2193558202, -81.2276105808, -35.2333787774, 131.7553150138, 74.1337100485, + -111.0162621392, -50.1520236082, -176.7180780270, 43.6099370000, -99.0730647751, 100.6783161314, 1.5420581129, 2.5889162904, + 97.2407277690, 5.5204254866, 72.0939017458, -100.0077732933, 30.1572971400, 19.1994437619, -83.8095901131, -67.5983524523, + 75.2270686194, 80.9252084407, 42.4611462166, -75.6376932185, -7.5820680566, -47.2137370820, 13.3547714942, -49.2227272764, + -101.2311839023, -89.9953284490, -59.5627585772, 3.5045401284, 87.8927289585, -45.7826497344, 10.7894222301, -34.2218214372, + 19.0101005894, -79.7412295513, -40.7129535835, 34.9745871635, 98.5275860299, -16.5088968676, 66.3460699225, -133.5365249144, + -41.4407293928, -15.3419046733, 88.7195803357, 5.1871004832, -98.0467809656, -14.1239743026, -1.3510821103, -38.6189020004, + 114.8822422747, 65.5094003215, 88.0532368083, -59.2540330178, 92.9429540023, 21.9133947331, -50.7728654894, -36.7011682133, + -16.9217654808, -110.7749962658, 16.6126865137, 116.3641432033, 51.7192473353, 9.8619033750, 57.3047648863, -21.0275512361, + 66.8618463429, 68.4016463402, 13.1978892272, 36.9294559769, 79.3415169994, -74.4235076906, -105.9928928366, 3.5485737877, + 35.3701917014, 11.0155135724, -42.5279468110, 57.9138782373, 32.4492657117, -2.5260836533, 8.2835364235, -45.2229140182, + 29.4655763679, 20.5830184405, -92.7731928028, -88.2155574314, -13.0181590718, -67.4752432987, 12.2964799268, -134.7795554776, + 132.5177768161, 86.4796490878, -170.6768976365, -53.7059277336, 23.6295211743, 100.0865623366, 134.6726479190, -17.6813528616, + -67.3925719582, -12.1986138778, -58.6920640259, -46.1769630250, 14.0012237071, 105.2386807000, 47.5923010830, -13.0446195549, + 21.4905427079, 89.4924853541, -1.6294776664, 7.0507819885, 88.9962812504, -14.3836298512, -14.5755536250, -158.3719830729, + -71.0421641105, 9.1510759791, 3.8541666430, 46.8853635172, -115.4505016964, 112.1915084832, 60.0579773251, -19.3568210670, + 134.6457467896, -127.7704101409, 96.1687814173, 139.4223376055, -16.4889074247, 8.7407981479, -31.8653460842, -86.1989364296, + 6.3138143769, 29.9691806857, 10.0215115097, 21.7539979367, -10.0119096873, -32.7662562735, -46.7114278488, -32.0468371287, + -104.9863919627, 164.6868132811, 14.2837511902, 103.8122395985, -38.3195610630, -66.2071289114, -42.7348265210, 8.1247796770, + -44.7642634909, -99.5977533202, -62.5669299697, -154.4713244845, -54.2004565831, -21.0505396466, -7.2304668445, -63.1457522254, + 121.1292664630, -41.2451342849, -100.3661302819, -79.7893865863, 2.9782522632, 28.1233518579, -45.4712133921, 102.1080223649, + 64.1668281113, -103.7410276784, 106.7427715753, 79.6231477604, 20.5960195618, 42.6351844699, -8.0432553021, -20.9274320455, + 44.7322739383, -58.6239231825, 21.5430765926, -32.7159508398, 56.5825012360, -99.4275633192, -102.9101109727, -83.9315736318, + 25.8630456141, -52.7504372152, 29.5673565938, 48.9111232224, 41.5578130085, -14.3606917295, -2.2040972437, 94.4661907548, + 132.7457583187, 55.3945646514, -16.7731026022, -46.5710214158, -29.3542289267, -14.2923094674, 23.0425873685, -15.5814746488, + 22.3570974017, -42.0180359242, -20.3430155274, -68.6338886669, -64.8088612108, -24.2988048174, -23.5299375491, 98.0364255786, + 3.9778504115, 65.6849914578, -1.5168129555, -4.8287346639, 142.1453945317, 78.2378704371, -57.3720730586, -19.4585389336, + 76.2735042603, -43.9459949675, 6.9426433355, -43.1451402122, -18.0751403348, -34.1054109171, 55.1204864738, 115.4516445351, + 6.5333541873, 62.4906581904, 29.9692177776, -33.2287635647, -18.9268908378, -63.0926292852, -111.6323734820, -10.8864814281, + 14.4649132510, -25.6871888082, -33.4308400890, 23.9756688469, 52.4567038054, 12.8701945894, -20.5116135858, -17.4241576687, + -11.8606594870, 16.8816614097, -18.7270784248, -6.2425768906, 48.5175154819, 1.7426978337, -99.3023967479, 38.5650914417, + -61.0127172140, 42.7784858845, -7.2257854969, 2.2847466905, -99.0066793854, 60.4060120207, 48.8064141188, -72.4258965295, + -50.7390478551, 95.1299230407, 56.4763356354, 35.4471698843, 60.4632441624, -95.6600449901, 55.9445226564, -28.1942324306, + 26.9826142327, -71.4404566440, 15.9270065277, -86.7110877229, -80.6677402549, 0.5529947734, -39.4989884635, 35.7914768080, + -22.6398243670, -33.2598314085, -25.7467291233, 16.6863716736, 80.3468995127, -22.5068845945, 23.6096621616, -99.4288845571, + 29.0662266127, 3.1265642936, 133.4725188269, 10.5889496669, 78.4289320034, 46.4143031925, 97.1026760967, -60.1768585008, + 75.4045199491, 14.1399143092, -87.6608741602, 96.8571208381, 36.1952990642, 119.9462706822, 51.7941617293, -10.8814477399, + 66.0010885597, 68.6769630212, 70.6032262575, -78.6614013388, -52.6711668148, 29.9772317807, -67.0938602216, -42.3207515671, + -0.0486165038, -15.4758823937, 56.6129710458, -54.2575866392, 111.9253009797, -47.5236184222, -95.6434531533, 24.9411667600, + 35.5636297407, -11.3487509511, 99.6377899302, 16.0125061627, -35.8881400079, 111.1220549938, -2.9395719970, -41.6388550114, + -33.4638181727, 109.8808145106, 28.1021441950, 118.2701610217, 51.8151816796, -19.5803207598, -89.9262515893, -26.6044307189, + 40.7320823989, -19.2602062235, 62.2560193625, 85.9346547334, 49.7871555519, -20.0313162309, -8.1831982988, 69.5820284092, + 49.2993116756, 34.9185452172, 74.7523126024, 145.1939754190, 7.4232669832, -4.5344572697, 34.0472547752, 41.4294110612, + -123.0758971920, -43.7705297332, 121.2820069260, 0.5435048718, 77.7764299214, 59.6928983371, -27.6522675298, -7.1273383508, + 26.7210269180, 4.4630452796, -81.8607570684, -26.3402136551, -95.7197230242, -7.3219091557, -82.4289458596, 77.4381232638, + 65.4006110025, 36.5844708644, 66.3796224839, -11.0118557858, 61.4481921771, 8.0694380153, 59.4652425227, -24.3765004167, + 4.9649042432, -28.5624154309, -78.5623599502, 17.8514494843, -20.9756518143, -10.1916814040, 11.5732283207, 57.9552418906, + -45.7612949110, -20.9482951666, 36.8160063004, -45.0567155877, 63.7098701462, 6.5938197429, 46.9692949757, -83.3299455774, + -88.7653437148, 118.8655843800, 93.1921951705, -18.1354337452, -40.1074391033, 44.0852297241, -41.1588703642, -105.1428083912, + -7.1420535313, 66.5491789931, 28.7643638361, -71.3690563573, 50.9039393300, 93.8257368698, 22.3478174946, -109.6001863096, + 64.0649017243, -29.4574274496, -44.5473845748, -132.8280128599, -52.8587533053, 80.0084510351, 21.4678106815, 48.4383573310, + 56.6158184924, -72.0365616804, 12.9911383411, 162.8295288963, 55.8780535954, 73.1821757559, -100.6826313435, 23.4262138290, + -0.5753332881, -21.5175209047, -138.1106268547, -80.7925993001, -28.1663114958, 0.9831816192, 30.7923417673, -51.9827613979, + -10.8794388756, 54.1022652480, 11.1686073161, -44.0592484786, 21.6987012718, -42.2412255611, -3.4936004646, -51.6421714543, + 15.8711886614, -40.0043968804, -6.1590232957, -65.9457642489, 59.0569838977, 7.4295907490, -12.6833895574, -72.2928299923, + -199.7835511043, -71.1580901042, -12.8895530614, 13.8448156167, 27.4808788351, -46.2542221592, -3.5153348434, -176.2019445127, + -48.6783165219, 70.2296726615, 111.7340160335, -60.7655899218, -138.1081385724, -35.3974788626, -65.7355628000, 57.9555341829, + 13.4670930872, -79.3318328665, 36.5016341422, 27.5574278118, -35.4004898428, -79.3903940148, 243.2421421265, -8.0268453199, + 44.0174931524, 68.8734465340, -80.7502038529, 1.3409036386, -86.0777878831, 37.1475406267, 18.1068167023, -56.9153447361, + -19.5224115764, -78.8474074897, -20.0747255852, 4.5850719720, -191.0686482737, 23.5318026769, -32.6675253287, 27.3087304829, + 31.4351407465, 19.6192337929, -11.8866458644, -48.4661089981, -3.1226120347, 20.0138411382, 29.8813799560, 67.9558437137, + 38.7174108080, -13.3022284820, 27.1121047281, -26.2954327750, 120.9542179193, 11.0555865630, -34.5895364072, 73.4542523467, + -26.6956937208, -108.0235037857, -35.7355716826, -69.8443555160, 33.3578766421, 26.3683815560, 97.2883332520, 133.5510498515, + 35.5415284008, -16.0495119378, -19.5483270675, 93.9985201088, 27.7795159179, -13.1059263368, 34.2311271533, 47.1466381795, + -36.4147469783, 10.4833119779, -5.2292656110, -25.0113244760, -14.0549947152, 199.8348526048, -43.2547698686, 98.4817969474, + 37.0586206693, 33.2121561269, -24.7170470026, -37.1349105091, -30.9578044903, -7.4114930133, -34.4807046142, -27.7773696385, + 29.2740921831, -61.0686554741, -32.4612619459, 6.7160769792, 3.1089599122, 12.2545595923, 62.6999428463, 30.5969686709, + 11.1423411573, -57.6502489731, 60.2408835918, -67.7203861906, -44.4518971003, -5.1109945114, 5.6528645074, -43.3456968092, + 117.8609487802, -24.2034537544, -78.4496201847, 44.5294780988, 85.1475013837, 15.5247701555, 89.7512668950, 54.3013774517, + -186.8510627600, -51.0482727175, -9.0267702018, 48.0681416363, -32.9759681266, -42.4456615266, 36.2738833817, 14.1610476535, + -99.8207994579, -11.5142692827, 50.1825860327, 0.3917737329, 63.3500370315, 111.2878444719, 91.6392406660, 17.6584451589, + -50.7899615175, 12.4221556654, -86.5413087906, 48.0563389410, 29.1384649619, 83.5027000186, 7.5729436929, 22.2136423571, + -60.2741473997, -170.4857658702, 17.0186844162, 136.3581532664, 31.5065683845, -96.2326886411, 72.4014182257, 26.1414887396, + -57.2844089463, -43.9781986370, -95.6611720182, -133.8830434822, 33.4938269182, -23.9156927559, 35.5520154186, -93.2468099373, + -6.2162527113, 4.5642492223, -57.5722591446, 71.8064120226, 45.1768685505, -9.5130102236, 110.5798720279, -41.5641619544, + 0.1835509076, -49.9128593949, 98.0154257393, -46.9365276597, -66.0935141873, 73.1727792846, 41.3353795661, -27.9960128980, + -44.2412816343, 46.9707404231, 12.3575979804, -122.9770710291, -11.9552135499, 31.4591712664, -14.1931325058, -6.8614191170, + -16.9763787814, 36.1520894392, 75.7352320923, -99.5121191729, 17.8024156510, 72.7923924404, 38.2259409765, 1.9325379601, + -11.1978607868, 98.2703853998, -38.0288299607, -41.7008273041, 80.4517499854, -116.8258848759, 30.7289872645, -101.9012423077, + 93.9831977796, 101.4530665010, 9.2763209169, 116.4425755502, 2.9739225298, 45.5019124654, -64.2956140887, 105.7408745662, + -11.3657606620, 6.3069096678, 122.8709609828, -6.3248578668, -60.1760116205, -35.9544630869, -68.0834090495, -34.8224305999, + -31.5069839788, 21.2614258718, -23.5546199906, -128.0293305211, -182.3893947839, -120.7110714918, -65.8822590864, -63.8215221762, + 56.7670203795, -61.2037205962, 3.8122259155, 1.0275735300, -64.6391642695, 75.8652993596, 115.4068637021, 46.8849792653, + -39.5505124775, 33.1187321149, 25.3372286880, -18.5375942960, 30.3953994229, 21.8836680766, 13.9924166006, -109.7038947262, + -24.2899011732, -52.7497505668, 35.3698361783, 34.1056231420, -13.8686663216, -1.7062295227, -97.5362177027, 74.6544677369, + -78.3935767846, 35.6517853160, 51.3830818724, -93.7778131463, 81.6700292143, 126.8070312922, -28.4470816468, -71.2638167545, + -55.2884800428, 9.0861240716, -128.9083303383, -16.3800803508, 34.5467745617, 28.9315662137, 84.3386694814, -1.7523953786, + 69.7727914393, 44.6546611575, 90.9897326057, 121.8059195607, 28.9429876729, -14.8591127934, 29.2818722570, -84.6318423838, + 11.3290830564, 40.7084140001, -50.5878424847, 68.2992258419, -24.7150040711, 41.8365599450, 104.0111319954, 70.6981835472, + 56.4709262168, -20.5343182666, -16.1886023808, 101.3482649415, 108.5356887852, 24.5240870510, -146.5152615985, -24.0194234128, + 18.0331846295, -5.1522407439, 4.9573388243, -34.7877468646, 39.3333900199, 31.8580232326, 111.7915751739, 15.3919610203, + 17.5179415363, -22.2065299595, 31.9496951848, -18.7368015481, -78.3621490938, 45.9954796476, 77.7231064126, 21.7258618723, + 23.3527631711, -136.8686653828, -22.5773174812, 33.6615614603, 4.8540113479, 3.9088571058, -54.7099788715, 85.8089519875, + -86.1460475251, -0.1247811474, -146.1793416666, 124.6659345147, -60.7858975441, 10.3154193265, -29.5514280889, 9.4667237048, + -7.9550953683, 37.5451209024, -27.1735194003, 46.8842847809, 41.9179936640, -23.3158010522, 157.3009890625, 113.2843306932, + -104.1727731788, 123.3854503767, -5.2055501860, 27.9879059133, -13.4163698144, 52.2833141248, -129.0969704337, 46.8881212895, + 131.1080768010, -19.0213767099, 155.5021671973, 20.3698150937, 37.2314029160, 40.8492644144, -35.6880906860, -31.7697839101, + -24.3255617048, -26.5610341544, 11.6187963194, -51.4990517524, 39.7825587179, -54.6696763219, -3.8497258220, -70.2342476864, + 4.9081928390, -71.4654689380, 30.7344594349, 32.7496322701, -90.9126087838, -38.3652430128, 92.4042844207, 47.8082836295, + 145.6802813070, -18.7426859824, 17.6059584845, 36.4864322344, -18.7252161480, 0.9615718128, -100.1282552629, -42.4349083923, + -14.3562238984, -46.8134065357, 39.6360915881, 22.7361846189, -3.2257803075, 37.2350125538, 115.6400099866, -12.7275184486, + -96.1855573652, -10.0276483356, 57.6455407419, 77.4560348751, -22.1178137498, -35.6022362191, -68.4831367839, 2.8390215747, + -52.0573070842, -93.4720169324, -28.9154032611, -76.6074307649, -9.9420438435, -6.1893105222, 29.9369590932, 74.7852614650, + -1.6201087045, -17.3703711090, -98.9790496449, 26.7869734481, 17.1602014711, -15.6928367417, -7.8035969135, 89.7887008279, + -70.6197502665, -8.2854282454, 59.3778733341, 73.2639493915, 25.8370203675, 59.1628124401, -24.8471900591, -25.8194366580, + -6.0751044137, -57.7489484697, 88.6706386657, -84.8771863224, -89.4840617668, 10.9763517990, -54.8378810910, 41.3410088555, + 66.6125927808, -14.1311991812, 29.3005546497, 96.5047091289, -3.3614374997, -25.8108903749, 206.5074424684, -61.4084159691, + -62.4923495769, -13.1959183651, -59.3730978039, -12.7173171637, 16.2427076425, 43.4296534191, -21.7657996669, -28.1531280594, + -69.0302418588, -86.4107750374, 17.1949881709, -41.3078350297, -57.6504646238, -5.0909583836, -8.1631298822, 1.3096980446, + -2.2508953688, 35.1942051704, -3.9027768036, -91.2713667132, 63.6694073039, 41.4248931898, 9.8384382954, -96.0978983961, + 66.1755919288, -36.7372549691, 10.2307178666, 80.7031291631, -38.2719834734, 39.2035878064, -43.1259903655, 93.4819414373, + 89.7247077937, 78.9891448344, 95.0983537363, 36.5774514331, 8.9972120390, -8.5755002664, -102.1337133375, 76.9830915294, + -46.7790015335, 51.0714648600, 29.5170917782, 23.9334813635, 5.2749838346, -15.9842728433, -1.3574532545, -70.2729088611, + -15.8039920242, 15.5313565190, -18.1312003682, -8.0084433716, -27.8087982433, 51.7334750530, 19.3370491919, 29.2520159480, + -68.6735151718, 8.0558008798, -40.2210320066, -40.9920576136, 7.8678303082, -72.3041306508, -10.2175986624, -35.1356797035, + 201.1586117629, 56.4352966867, 46.7221688254, -11.9012413099, -18.9833303926, -86.5023414408, -23.4675063576, -55.5806400666, + 153.4955981228, -10.1092363214, 88.4029573110, -65.9117133686, -5.4919562765, 24.5837979674, -33.5408574701, -4.0004157187, + 56.9848893304, -105.2177018084, 3.4948685307, -19.8452050090, -7.2453079498, 102.6389582052, -8.3246123264, -73.0861922381, + 0.9626940760, -28.3612950785, -11.1533678981, 44.2899763978, -62.6677448146, 22.3906970985, -13.3484872677, 67.0703918899, + 42.4772156970, -18.5244182335, 37.4759091463, 31.3496965213, -61.4436264287, 52.0955155439, 59.1486887940, 170.4906735140, + 46.0617455116, 40.1470772024, -107.3976903570, -105.4116725861, 56.8825181023, 58.5916397550, -58.1729962485, -60.5270235223, + -39.2885519005, 9.5965348817, -25.4354894441, -14.0981625889, -52.7234757042, -83.9105208881, 72.1797338834, -134.9219073856, + 9.6103094318, 9.6768962656, 26.7360474274, 41.7881752284, -15.3952839007, -0.1363655901, -47.0864221556, -8.2427253205, + -57.7373834528, -55.9508702650, -78.5284244100, 0.1655492302, 62.9160705153, 64.1068291282, -2.9136214436, -105.7842253662, + -45.8767944713, -51.7074257000, -98.8568902926, 64.1232083599, 71.1116077196, -30.6630666091, -58.6840707262, -15.9383894413, + -78.6620829271, 60.7529890099, 154.2357488637, 41.3625348402, 120.2872442705, -51.3125389772, 16.7881412988, -70.4938171347, + -79.4147805796, 23.5182282020, -81.0963234264, -59.2244948022, 28.9135530940, 92.5951342446, -96.6396527065, -26.4777264554, + 121.3094449527, -34.5951012470, -127.8255512216, -92.7699064191, -58.4398020189, -117.7542292595, 31.0434596629, 21.5299289765, + -99.9447239591, -16.0626333679, 6.0199864189, 82.4757175357, 22.5970205481, 73.5485760950, 35.7980568403, 72.6857884103, + 28.8479981590, -67.5538339177, 43.4071338656, -25.1893024527, 4.6130159403, -65.2605921685, -91.8752363625, 22.5520067301, + -109.9093500045, 33.9399454761, -13.9115156368, -3.1879928935, 1.3920042271, 43.3324348308, -33.3718525809, -15.9282931008, + 0.7677944075, 78.1072718708, -1.1063828562, -10.5413152425, 37.1290958861, 13.6823396336, -3.4014039018, 89.5388534365, + 37.7089705536, 64.0323076524, 44.7808982777, -13.5604762388, 7.5118173888, 115.2300447558, -9.1561273300, -41.5332100116, + -17.0088418256, 71.2713927804, 68.0422816650, 54.9551164038, 106.8830646917, -6.8316822423, -66.7609967606, -23.3894825625, + -67.4182747661, -28.3219951260, -15.9451114055, -29.7266619746, 16.7419712545, -20.5565859019, -165.5656221846, 116.3242135199, + 64.2626611081, -8.1360214710, -94.2273608282, -62.9983557391, 64.1759043922, 36.5449254036, -51.5697599431, -5.0466305585, + -73.2700815931, 48.7300029897, -35.5929303432, -90.4816448914, 16.8187764590, -27.9347950060, 80.7045416696, -83.6514663068, + -58.4556594913, 3.2348973759, 52.8657910284, 85.7278577109, 37.4138218732, 82.0512145755, 76.4606241856, -109.2162517858, + 96.6683439683, 90.7633843052, -53.1586977972, 34.4033331064, 44.2090456506, 80.1151111552, 2.7514790758, -64.2623287852, + 126.1409018754, -30.2423240636, -156.0079941574, -2.8027393737, 64.2513542782, 69.8534581189, -73.4708875363, 20.2217494242, + 0.5864357659, -104.6195300646, -42.8322649072, 26.3037603855, -40.7129474708, -33.9844594811, -26.3521525879, 109.6645932255, + -106.9356716414, 49.2118962107, 11.7512591870, 68.8969247665, 113.4583578600, -83.3347276867, -36.2485402256, 85.9855241461, + 104.0814868325, 33.5770186573, -1.9661285608, -132.5696804701, 27.6753215958, 21.1243350017, -28.0882593661, 35.2778527631, + 18.9175154387, 83.6190957901, -71.4962755318, 138.3285404575, 97.9134306607, -56.8042150595, -143.3089544841, -2.7340225658, + 17.5776154385, -148.2352087417, 124.9211804787, 59.4231271286, 10.5947124378, 68.5288310273, -67.2703544731, -23.7935515786, + 38.8787769309, 34.5294359419, -73.4536038751, 2.7126504728, 49.6972438051, 62.7223593643, 49.8175933904, -110.1534126143, + -14.6702420578, -84.0773525862, -92.6188033620, -5.5698102323, -47.9128909478, 46.7196485027, -53.6444016449, 98.5014752828, + -94.7519348776, 14.1323076055, -89.2719075396, 47.0296071172, 41.3919626390, -39.1489616034, -135.6499693540, -10.9475781700, + 92.7496269052, 37.4205820588, -51.7237524182, 49.9460461012, 87.5396720347, 32.8710569742, -32.8731769330, -83.4249720632, + 34.5762125072, 13.6808877416, -26.3766683600, -67.8728489559, -29.6073750328, -47.8030427727, -149.0587954245, -119.5774481626, + 35.2806694964, -24.3695409777, 48.7160766560, 8.8288204812, -89.3855803242, 3.1835611015, 51.9474587643, -41.8502161006, + -34.1035165420, 94.0854499359, -84.2224914514, 59.1627371631, -103.1905795588, -18.6082417651, 36.3103092592, 63.1937125568, + -111.1986222065, -32.0863426915, -56.7330383564, 32.5073363806, -7.1087996309, -68.2226145792, -157.6532604957, 45.2078386315, + -2.8603211008, 33.3371110420, 37.7846637198, -18.6405663742, -91.0982111740, 23.2221097945, -24.3522827840, 78.9413600618, + 62.8360928143, -19.9242767252, 56.5032728402, -5.5496240010, 8.6994906960, 83.5527376759, -21.2346885874, 64.0836232315, + 22.9623722574, -87.9578765280, 1.3523030640, 176.4067098705, 67.9036978634, 7.2537723049, -122.2309062335, -63.8632909466, + -38.4903796734, -16.2974411834, 2.3970826418, 64.3700072918, -67.9197915888, -116.4026668750, 67.5231031500, 34.6374455493, + 4.1311157296, -2.9105015532, 70.8086558293, 39.2725441796, 33.8256743917, -3.5843642097, 116.7643833804, 20.1092238787, + -25.9766854190, -51.9950492522, 3.5926636209, -58.7583611171, 3.2768807331, -83.5901878329, 68.7090363388, 31.4832422043, + 72.9380572718, -165.9742811160, 33.9362033271, -10.9519428632, 13.0808211304, 15.6672709051, 31.7224492437, -24.1934977704, + -111.0830116867, 11.6282084172, -66.2259706857, -1.9963673172, 30.0622960183, 53.3456859503, -37.0919419160, 67.5944964290, + 18.5935153812, 48.9664966150, 67.3157768914, -160.7111991618, -25.1223842933, -47.4479071245, -16.7582679230, -13.6039270052, + 1.7293472100, -24.1741877419, -76.9727398203, -56.3783736939, -66.9556303947, -54.3511473684, 30.2542211582, -66.8893229449, + -73.2990092912, 239.3981985262, -64.2850340511, 89.9092075497, -15.3525489059, 53.3827372899, -14.3319916122, -115.0721596412, + -50.4530123160, 44.0976786926, 52.2019557554, 72.6630207131, 27.5803572747, 33.4737730840, -170.7640086205, 152.9204474548, + -44.5872734278, -41.0667502536, 26.6175854758, -13.0179143239, 40.8518134705, 23.2781614140, 22.8861340709, 165.4158655103, + 45.0461105030, -17.0077443894, -2.3871329828, -86.8854944700, -38.5465304439, 51.8040803063, -92.8924802068, -113.2325293603, + 51.3604041632, -18.3429725256, -42.5989033884, -38.9445115750, -85.8273183104, -56.4224331649, 17.4997720376, 89.3766578841, + 23.9239370283, 82.3838988229, 47.4013397563, -28.0666334287, 77.6218433875, -52.2133433307, 89.2938264737, 43.2058195424, + 49.4518987655, -5.6570623864, 19.8577713391, -33.2615393471, 73.6654400011, 27.5602339563, -47.1471825605, -34.0693505588, + 111.0944675938, 57.0173259682, -63.4190502251, 46.5969999331, 49.3458328432, -41.3853156260, 39.2494112424, 40.7148228670, + -20.3911372187, 31.8352000294, -0.9980198147, 22.2804091174, 54.0978218332, -82.3683192993, 85.9892355872, -58.3154306688, + -104.2068911293, 91.0603181519, 32.9518095573, 20.8407188930, 34.7499759595, 81.9688480501, -63.1013763435, 0.0064684915, + -24.5056101811, 69.9306176471, -27.5369930597, -39.0144381716, -14.4923929902, -54.3182594365, -130.3292318388, -48.8158919788, + 53.2734036714, -104.1048090944, -70.0965204183, 3.6382745923, 83.6579656965, 23.1622465812, 126.4691310854, 102.9799547579, + 70.8617976147, -8.1455978101, -28.4590640876, 108.1156467676, -1.9738076313, -75.4909376542, 57.5780163484, 45.3155422582, + -38.1742907476, -52.1803902400, -59.7016262432, -23.3823853194, -45.5457749841, -10.5523915014, -110.6271933849, -32.0113288878, + -86.9215548382, 87.4068451718, 70.9885834348, 25.1206930472, 30.7108505789, 115.6076847444, -40.5697084903, -56.6781054555, + -31.4854227803, -31.9552555012, 25.7938108182, 25.4540472201, 76.7058033375, 2.3905659773, -5.9779298940, -152.8056710400, + -51.7485397077, 28.1462240336, 33.9693389366, -71.9881317816, -105.0496130632, 64.2276458511, 96.2519735406, 48.6822690044, + -19.6594071488, 24.8884631741, -33.0716823639, -69.5612618256, -25.2898319495, 98.8036926982, -24.3703282453, 53.1789051370, + 86.5743876344, 18.0109802577, 68.3663740236, 112.3369755598, -45.4492280850, -151.6437874688, -38.2167192413, 24.2163999975, + -66.3294468430, -150.1009914497, -29.4992082835, -92.1308610284, -1.2762556067, 23.1500238372, 69.3063510487, -69.0471660018, + 42.5150200276, 120.6653379806, -152.6729845687, 48.9591377076, 2.7191539126, 0.2888762146, -3.0784673164, 32.5853754582, + -81.3351116851, 25.2072127071, -36.3659441163, -28.6250561447, 95.3073017008, -75.7486406052, 65.1012680265, -64.6031857772, + 56.1240652498, -10.8517181129, -3.7575141784, 42.9554134355, 32.9784965739, -25.0327158003, -147.2361479829, -122.4898965848, + -64.6526214445, 57.1527521244, 25.3983254376, -74.5887309421, 105.2278400890, 118.4451948788, -10.9195498541, -45.2849091353, + 79.1200975888, -60.8806018590, -12.2957628012, -10.2289743666, 77.2465842566, -19.1618580885, -50.3947630673, 130.5843172047, + 20.1829697245, -24.4247513916, 71.3800655588, -30.9467657000, 1.5373397590, 53.9054414421, -87.7905799212, 58.1774557931, + -154.0660955458, 119.2331706772, 7.0800339615, -83.0564977313, -99.0630549412, 64.4241699198, 27.5103964537, 36.9348345670, + -10.4954521840, -23.2759360131, -167.1583158447, -50.1929188975, -17.1065117999, -86.3978192131, 8.3733101608, -19.6093068970, + 37.0486109491, 45.4922144870, 176.0647013511, -14.1950922727, 16.7968812286, -84.3138225875, -53.2207464331, -14.8171496969, + 65.2824157581, 93.3387940939, -46.2740703075, 92.8129768305, -57.1890439907, 27.2969064938, -67.1547095718, 132.0520323271, + -80.7686358272, 31.4140691769, -52.8148627904, -54.8739580131, -149.8514804755, 56.0153122854, -71.3742949563, 36.6095599948, + 42.3294500451, 1.2055515804, -109.4906983981, -71.9482696076, -21.4390953534, 98.8949510272, 74.3069855376, -35.1569830360, + -34.9626381657, 64.2761847423, 64.7596378221, -28.4775450749, 20.1459803277, -26.5247867780, -32.4734659348, -27.8310906478, + 50.7956581065, 36.0746451268, 22.7531905225, -13.9681530928, 49.5451440618, -13.8510794385, 19.4999565108, 56.8774616945, + -11.9205397259, -71.7174333027, 138.8034243907, -37.8252215401, -38.5743154556, -22.5072374207, 12.6209402643, 69.3207345010, + 70.3534390616, 71.5844311614, 4.0715727994, 25.4390606947, -51.0777668722, 138.3617611366, -34.2478029347, -58.8492260984, + -108.6623124843, 58.3034938571, -36.9304647333, 116.5902412201, -24.4020501110, -74.7544840602, 67.7889120207, -9.1455389450, + -46.4456521441, 83.2551857934, -113.9346066504, 46.2851467498, -17.4102217179, 41.6989724702, -23.8829078702, 76.1395799790, + -27.1608730178, -133.8787483532, -59.9242635982, 120.5266415560, 124.9797395465, 35.5722660007, -20.2412573812, 20.5492611902, + -111.8745990845, 41.7389321101, 44.5758622786, 54.2189628306, -44.4745944890, -75.9761098966, 104.0472151578, 113.7219003284, + 33.0330354214, -6.0923562541, -14.8744671800, 62.5024055272, 3.7922184446, 1.1256712478, -30.2126827228, -83.4988699637, + -103.7060854897, -65.4982917403, 30.8897494352, 66.1124672663, 65.0983461952, -52.5486436649, -4.5556524541, -26.5924272500, + -94.1546367179, -0.3559369287, -45.0649519841, -68.1274094478, -7.0521865275, -5.6612786174, -12.5790011432, 51.2524661231, + -3.6515125298, 92.9598974936, -21.0468658542, -40.8243392179, -7.4342227950, 11.1119231703, 37.3371820746, 21.3179018153, + 50.2932980480, -24.1611515405, -41.7851721122, -24.8691439055, -28.3180388219, 121.1894536511, 15.7968116384, 17.9498027226, + -55.3386005430, -80.6689826830, 31.9394747713, -28.1978017432, -1.5538441529, -4.0360096323, 73.9611531119, 17.7253526010, + -24.8578563772, 18.4583438017, 75.2580204243, -13.6139802015, 24.6918362443, -63.0552815767, -4.0312608443, -14.8879121339, + -2.8237511683, -81.5024576341, -4.2344562157, 107.1587476255, -131.2910041645, -25.6467586377, 0.4733397655, 62.8634326464, + 63.1852609425, 16.5913941858, -96.6896044528, 81.2969911064, 18.2956425408, -81.6677471269, -39.2708721333, -34.3080597347, + 22.5610412882, 57.2574226391, 77.9308780964, -39.9342842346, 58.5581960994, -5.7939281526, 104.9927182940, -99.3837066580, + 25.9917768621, -32.1605915683, -30.4589523848, 64.8295771021, -28.2183758982, -37.9771330859, -178.0772548046, 84.2925125233, + 45.4981954662, 49.2815212900, -45.1224250038, -5.9322404186, -6.1309915876, 76.9070873365, -11.5475730308, 18.2569564924, + -124.4953563688, 53.8646820493, -40.0231506068, -74.3908746450, -63.2011642999, -18.9826189881, 69.7917580387, -34.8403308318, + -36.4625632706, 17.1934091336, -20.8063613141, -1.9067935434, 5.2259139474, 60.8368210348, 81.3087550974, -42.6679999668, + -95.5963552311, -115.2609753741, 11.1809831183, -48.3640194531, 75.1073797772, 30.8228127170, -15.0904157375, 11.0538529673, + 107.4505154927, -66.3486660110, -32.0311111189, 38.4346222125, 8.9422998706, -57.6098106212, 15.9132097612, -132.1845158340, + 36.1916704283, -10.5055186124, -87.5658217149, 107.8931306399, 96.0334082800, 53.7264664477, -72.0623965686, -1.9038197721, + 26.1152808779, 119.6235796272, 48.3325601149, 117.6457486801, 28.0275495741, -11.7030018715, 52.9236279862, 100.1176831736, + -83.2423151898, 7.5280868233, -15.3686195277, -5.3432329923, -27.9181052724, -64.4492860287, 129.7502751613, -82.3246020383, + 37.3256155504, 34.7298938660, -57.0561320806, -44.9581455455, 93.3481469867, -54.3803550243, 26.4501204966, 18.8116878139, + -74.4902220818, 15.4659232518, -49.1948332727, 34.0006040345, 56.7177639954, -28.8367897421, 83.8692564278, 35.6745892475, + -45.7509262432, 30.3970223242, 106.1786129556, -35.7843870107, 7.1339227808, 13.0894885560, 56.4666438735, -23.8687514544, + -111.5694112759, -58.7858061292, -61.2783887765, 44.1738302093, 54.7407844064, 14.3538652267, 108.5956394164, -22.3846808158, + 2.5449431771, 70.3512724427, 29.5403015688, -0.7212818796, 143.3497258886, -17.2553350633, -99.7681623907, 42.6913312311, + 35.7338157369, -54.6728371746, -38.0299088541, 10.1471440532, -124.7095236710, -190.8743243033, 139.7543496645, -42.2528776639, + 39.0975372290, 27.8686903911, 22.7337255980, 42.7990612235, -41.6771094483, -23.0843729437, 49.7020046877, 11.0018909876, + -16.5079644797, -158.2821637063, 42.1950179525, -30.4282660128, 67.9797563487, -53.8121334664, 52.8306609341, -5.2861803454, + 59.3808475761, 158.1836295178, -26.8953096767, 78.8646320997, -113.9365510474, -37.1949934282, 53.6970193167, -9.6523467804, + 7.7358952669, -74.6220593088, 107.4394203873, 17.2364088475, -36.5357935724, -23.9301386540, 17.8174243490, 14.1204969615, + -8.2599377000, 4.2743586584, -46.4363395746, -63.5670279031, 9.6872641411, 21.0630349930, 108.9834586896, -124.7597975398, + 29.4251821664, 23.8313097730, -40.8359610210, 91.9520219869, 95.7936525792, -109.5783337883, -60.1100153384, -19.9591228893, +}; + +/*--------------------------------------------------------------------------------*/ +/* FFT Lengths */ +/*--------------------------------------------------------------------------------*/ + +/* + To change test parameter values add/remove values inside CURLY and update + the preceeding parameter to reflect the number of values inside CURLY. +*/ + +ARR_DESC_DEFINE(uint16_t, + transform_radix2_fftlens, + 7, + CURLY( + 16, 32, 64, 128, 256, + 512, 1024/*, 2048 , 4096 */)); + +ARR_DESC_DEFINE(uint16_t, + transform_radix4_fftlens, + 4, + CURLY( + 16, 64, 256, 1024/* , 4096 */)); + +ARR_DESC_DEFINE(uint16_t, + transform_rfft_fftlens, + 6, + CURLY( + 32, 64, 128, 256, + 512, 1024/*, 2048 , 4096, 8192*/)); + +ARR_DESC_DEFINE(uint16_t, + transform_dct_fftlens, + 3, + CURLY( + 128, 512, 2048/*, 8192*/)); + +ARR_DESC_DEFINE(uint16_t, + transform_rfft_fast_fftlens, + 7, + CURLY( + 32, 64, 128, 256, + 512, 1024, 2048)); + +/*--------------------------------------------------------------------------------*/ +/* CFFT_F32 Structs */ +/*--------------------------------------------------------------------------------*/ + +/* Uses radix2 lengths */ +ARR_DESC_DEFINE(const arm_cfft_instance_f32 *, + transform_cfft_f32_structs, + 5, + CURLY( + &arm_cfft_sR_f32_len16, + &arm_cfft_sR_f32_len32, + &arm_cfft_sR_f32_len64, + &arm_cfft_sR_f32_len128, + &arm_cfft_sR_f32_len256/*, + &arm_cfft_sR_f32_len512, */ + /* &arm_cfft_sR_f32_len1024, */ + /* &arm_cfft_sR_f32_len2048, */ + /* &arm_cfft_sR_f32_len4096 */ + )); + +/*--------------------------------------------------------------------------------*/ +/* CFFT_Q31 Structs */ +/*--------------------------------------------------------------------------------*/ + +/* Uses radix2 lengths */ +ARR_DESC_DEFINE(const arm_cfft_instance_q31 *, + transform_cfft_q31_structs, + 5, + CURLY( + &arm_cfft_sR_q31_len16, + &arm_cfft_sR_q31_len32, + &arm_cfft_sR_q31_len64, + &arm_cfft_sR_q31_len128, + &arm_cfft_sR_q31_len256/*, + &arm_cfft_sR_q31_len512, */ + /* &arm_cfft_sR_q31_len1024, */ + /* &arm_cfft_sR_q31_len2048, */ + /* &arm_cfft_sR_q31_len4096 */ + )); + +/*--------------------------------------------------------------------------------*/ +/* CFFT_q15 Structs */ +/*--------------------------------------------------------------------------------*/ + +/* Uses radix2 lengths */ +ARR_DESC_DEFINE(const arm_cfft_instance_q15 *, + transform_cfft_q15_structs, + 5, + CURLY( + &arm_cfft_sR_q15_len16, + &arm_cfft_sR_q15_len32, + &arm_cfft_sR_q15_len64, + &arm_cfft_sR_q15_len128, + &arm_cfft_sR_q15_len256/*, + &arm_cfft_sR_q15_len512, */ + /* &arm_cfft_sR_q15_len1024, */ + /* &arm_cfft_sR_q15_len2048, */ + /* &arm_cfft_sR_q15_len4096 */ + )); diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM23_config.txt b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM23_config.txt new file mode 100644 index 0000000..eeb9c59 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM23_config.txt @@ -0,0 +1,163 @@ +# Parameters: +# instance.parameter=value #(type, mode) default = 'def value' : description : [min..max] +#---------------------------------------------------------------------------------------------- +cpu0.semihosting-enable=0 # (bool , init-time) default = '1' : Enable semihosting SVC traps. Applications that do not use semihosting must set this parameter to false. +cpu0.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +cpu0.SECEXT=0 # (bool , init-time) default = '1' : Whether the ARMv8-M Security Extensions are included +fvp_mps2.platform_type=0x0 # (int , init-time) default = '0x0' : 0:MPS2 ; 1:IoT Kit ; 2:Castor : [0x0..0x2] +fvp_mps2.extra_psram=0 # (bool , init-time) default = '0' : Increases PSRAM to 32Mb +fvp_mps2.DISABLE_GATING=1 # (bool , init-time) default = '0' : Disable Memory gating logic +fvp_mps2.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +fvp_mps2.UART2.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART2.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART2.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART2.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART2.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART2.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.UART1.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART1.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART1.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART1.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART1.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART1.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.mps2_visualisation.rate_limit-enable=1 # (bool , init-time) default = '1' : Rate limit simulation. +fvp_mps2.mps2_visualisation.disable-visualisation=0 # (bool , init-time) default = '0' : Enable/disable visualisation +fvp_mps2.mps2_visualisation.window_title="CLCD %cpu%" # (string, init-time) default = 'CLCD %cpu%' : Window title (%cpu% is replaced by cpu_name) +fvp_mps2.mps2_visualisation.idler.delay_ms=0x32 # (int , init-time) default = '0x32' : Determines the period, in milliseconds of real time, between gui_callback() calls. +fvp_mps2.telnetterminal0.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal0.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal0.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal0.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal0.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal1.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal1.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal1.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal1.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal1.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal2.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal2.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal2.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal2.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal2.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.PSRAM_M7.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM_M7.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM_M7.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.UART0.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART0.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART0.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART0.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART0.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART0.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.cmsdk_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.s32k_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.secure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.nonsecure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.PSRAM.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.stub.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram0.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram3.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.sys_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.sys_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1core_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.crypto_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.crypto_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cordio_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cordio_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram0_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram0_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram1_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram1_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram2_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram2_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram3_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram3_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.smsc_91c111.enabled=0 # (bool , init-time) default = '0' : Host interface connection enabled +fvp_mps2.smsc_91c111.mac_address="00:02:f7:ef:5d:a2" # (string, init-time) default = '00:02:f7:ef:5d:a2' : Host/model MAC address +fvp_mps2.smsc_91c111.promiscuous=1 # (bool , init-time) default = '1' : Put host into promiscuous mode +fvp_mps2.hostbridge.interfaceName="ARM0" # (string, init-time) default = 'ARM0' : Host Interface +fvp_mps2.hostbridge.userNetworking=0 # (bool , init-time) default = '0' : Enable user-mode networking +fvp_mps2.hostbridge.userNetSubnet="172.20.51.0/24" # (string, init-time) default = '172.20.51.0/24' : Virtual subnet for user-mode networking +fvp_mps2.hostbridge.userNetPorts="" # (string, init-time) default = '' : Listening ports to expose in user-mode networking +fvp_mps2.secure_control_register_block.FLASH_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : Flash Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.SRAM_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : SRAM Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.FLASH_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : Flash Watermark supported +fvp_mps2.secure_control_register_block.SRAM_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : SRAM Watermark supported +fvp_mps2.exclusive_monitor_psram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_psram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_psram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_psram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_psram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_psram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_psram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram1.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram1.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram1.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram1.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram1.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram1.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram1.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram2.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram2.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram2.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram2.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram2.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram2.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram2.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_iotss_internal_sram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_iotss_internal_sram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_iotss_internal_sram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_iotss_internal_sram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_iotss_internal_sram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_iotss_internal_sram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_iotss_internal_sram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.dma0_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma0_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma1_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma1_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma2_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma2_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma3_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma3_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma0.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma0.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma0.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma0.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma1.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma1.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma1.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma1.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma2.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma2.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma2.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma2.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma3.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma3.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma3.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma3.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.iotss_cpuidentity.debugger_master_id=0xFFFFFFFF # (int , init-time) default = '0xFFFFFFFF' : : [0x0..0xFFFFFFFF] +#---------------------------------------------------------------------------------------------- diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_FP_config.txt b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_FP_config.txt new file mode 100644 index 0000000..4438b2e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_FP_config.txt @@ -0,0 +1,183 @@ +# Parameters: +# instance.parameter=value #(type, mode) default = 'def value' : description : [min..max] +#---------------------------------------------------------------------------------------------- +cpu0.FPU=1 # (bool , init-time) default = '1' : Set whether the model has VFP support +cpu0.DSP=1 # (bool , init-time) default = '1' : Set whether the model has the DSP extension +cpu0.semihosting-enable=0 # (bool , init-time) default = '1' : Enable semihosting SVC traps. Applications that do not use semihosting must set this parameter to false. +cpu0.MPU_S=0x8 # (int , init-time) default = '0x8' : Number of regions in the Secure MPU. If Security Extentions are absent, this is ignored : [0x0..0x10] +cpu0.MPU_NS=0x8 # (int , init-time) default = '0x8' : Number of regions in the Non-Secure MPU. If Security Extentions are absent, this is the total number of MPU regions : [0x0..0x10] +cpu0.ITM=0 # (bool , init-time) default = '1' : Level of instrumentation trace supported. false : No ITM trace included, true: ITM trace included +cpu0.IRQLVL=0x3 # (int , init-time) default = '0x3' : Number of bits of interrupt priority : [0x3..0x8] +cpu0.BIGENDINIT=0 # (bool , init-time) default = '0' : Initialize processor to big endian mode +cpu0.INITSVTOR=0x00000000 # (int , init-time) default = '0x10000000' : Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.INITNSVTOR=0x0 # (int , init-time) default = '0x0' : Non-Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.SAU=0x0 # (int , init-time) default = '0x4' : Number of SAU regions (0 => no SAU) : [0x0..0x8] +cpu0.SAU_CTRL.ENABLE=0 # (bool , init-time) default = '0' : Enable SAU at reset +cpu0.SAU_CTRL.ALLNS=0 # (bool , init-time) default = '0' : At reset, the SAU treats entire memory space as NS when the SAU is disabled if this is set +cpu0.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +cpu0.LOCK_SAU=0 # (bool , init-time) default = '0' : Lock down of SAU registers write +cpu0.LOCK_S_MPU=0 # (bool , init-time) default = '0' : Lock down of Secure MPU registers write +cpu0.LOCK_NS_MPU=0 # (bool , init-time) default = '0' : Lock down of Non-Secure MPU registers write +cpu0.CPIF=1 # (bool , init-time) default = '1' : Specifies whether the external coprocessor interface is included +cpu0.SECEXT=0 # (bool , init-time) default = '1' : Whether the ARMv8-M Security Extensions are included +fvp_mps2.DISABLE_GATING=1 # (bool , init-time) default = '0' : Disable Memory gating logic +fvp_mps2.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +fvp_mps2.SCC_ID.Variant=0x0 # (int , init-time) default = '0x0' : SCC_ID[23:20], X in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.SCC_ID.Revision=0x1 # (int , init-time) default = '0x1' : SCC_ID[3:0], Y in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.platform_type=0x0 # (int , init-time) default = '0x0' : 0:MPS2 ; 1:IoT Kit ; 2:Castor : [0x0..0x2] +fvp_mps2.extra_psram=0 # (bool , init-time) default = '0' : Increases PSRAM to 32Mb +fvp_mps2.UART2.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART2.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART2.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART2.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART2.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART2.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.UART1.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART1.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART1.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART1.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART1.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART1.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.mps2_visualisation.rate_limit-enable=1 # (bool , init-time) default = '1' : Rate limit simulation. +fvp_mps2.mps2_visualisation.disable-visualisation=0 # (bool , init-time) default = '0' : Enable/disable visualisation +fvp_mps2.mps2_visualisation.window_title="CLCD %cpu%" # (string, init-time) default = 'CLCD %cpu%' : Window title (%cpu% is replaced by cpu_name) +fvp_mps2.mps2_visualisation.idler.delay_ms=0x32 # (int , init-time) default = '0x32' : Determines the period, in milliseconds of real time, between gui_callback() calls. +fvp_mps2.telnetterminal0.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal0.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal0.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal0.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal0.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal1.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal1.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal1.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal1.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal1.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal2.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal2.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal2.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal2.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal2.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.PSRAM_M7.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM_M7.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM_M7.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.UART0.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART0.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART0.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART0.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART0.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART0.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.cmsdk_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.s32k_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.secure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.nonsecure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.PSRAM.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.stub.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram0.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram3.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.sys_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.sys_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1core_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.crypto_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.crypto_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cordio_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cordio_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram0_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram0_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram1_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram1_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram2_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram2_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram3_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram3_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.smsc_91c111.enabled=0 # (bool , init-time) default = '0' : Host interface connection enabled +fvp_mps2.smsc_91c111.mac_address="00:02:f7:ef:5d:a2" # (string, init-time) default = '00:02:f7:ef:5d:a2' : Host/model MAC address +fvp_mps2.smsc_91c111.promiscuous=1 # (bool , init-time) default = '1' : Put host into promiscuous mode +fvp_mps2.hostbridge.interfaceName="ARM0" # (string, init-time) default = 'ARM0' : Host Interface +fvp_mps2.hostbridge.userNetworking=0 # (bool , init-time) default = '0' : Enable user-mode networking +fvp_mps2.hostbridge.userNetSubnet="172.20.51.0/24" # (string, init-time) default = '172.20.51.0/24' : Virtual subnet for user-mode networking +fvp_mps2.hostbridge.userNetPorts="" # (string, init-time) default = '' : Listening ports to expose in user-mode networking +fvp_mps2.secure_control_register_block.FLASH_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : Flash Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.SRAM_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : SRAM Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.FLASH_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : Flash Watermark supported +fvp_mps2.secure_control_register_block.SRAM_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : SRAM Watermark supported +fvp_mps2.exclusive_monitor_psram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_psram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_psram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_psram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_psram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_psram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_psram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram1.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram1.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram1.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram1.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram1.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram1.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram1.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram2.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram2.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram2.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram2.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram2.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram2.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram2.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_iotss_internal_sram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_iotss_internal_sram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_iotss_internal_sram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_iotss_internal_sram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_iotss_internal_sram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_iotss_internal_sram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_iotss_internal_sram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.dma0_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma0_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma1_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma1_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma2_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma2_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma3_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma3_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma0.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma0.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma0.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma0.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma1.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma1.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma1.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma1.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma2.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma2.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma2.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma2.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma3.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma3.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma3.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma3.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.iotss_systemcontrol.cpu0wait=0 # (bool , init-time) default = '0' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_systemcontrol.cpu1wait=1 # (bool , init-time) default = '1' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_cpuidentity.debugger_master_id=0xFFFFFFFF # (int , init-time) default = '0xFFFFFFFF' : : [0x0..0xFFFFFFFF] +#---------------------------------------------------------------------------------------------- diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_config.txt b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_config.txt new file mode 100644 index 0000000..cb9fd3d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_DSP_config.txt @@ -0,0 +1,183 @@ +# Parameters: +# instance.parameter=value #(type, mode) default = 'def value' : description : [min..max] +#---------------------------------------------------------------------------------------------- +cpu0.FPU=0 # (bool , init-time) default = '1' : Set whether the model has VFP support +cpu0.DSP=1 # (bool , init-time) default = '1' : Set whether the model has the DSP extension +cpu0.semihosting-enable=0 # (bool , init-time) default = '1' : Enable semihosting SVC traps. Applications that do not use semihosting must set this parameter to false. +cpu0.MPU_S=0x8 # (int , init-time) default = '0x8' : Number of regions in the Secure MPU. If Security Extentions are absent, this is ignored : [0x0..0x10] +cpu0.MPU_NS=0x8 # (int , init-time) default = '0x8' : Number of regions in the Non-Secure MPU. If Security Extentions are absent, this is the total number of MPU regions : [0x0..0x10] +cpu0.ITM=0 # (bool , init-time) default = '1' : Level of instrumentation trace supported. false : No ITM trace included, true: ITM trace included +cpu0.IRQLVL=0x3 # (int , init-time) default = '0x3' : Number of bits of interrupt priority : [0x3..0x8] +cpu0.BIGENDINIT=0 # (bool , init-time) default = '0' : Initialize processor to big endian mode +cpu0.INITSVTOR=0x00000000 # (int , init-time) default = '0x10000000' : Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.INITNSVTOR=0x0 # (int , init-time) default = '0x0' : Non-Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.SAU=0x0 # (int , init-time) default = '0x4' : Number of SAU regions (0 => no SAU) : [0x0..0x8] +cpu0.SAU_CTRL.ENABLE=0 # (bool , init-time) default = '0' : Enable SAU at reset +cpu0.SAU_CTRL.ALLNS=0 # (bool , init-time) default = '0' : At reset, the SAU treats entire memory space as NS when the SAU is disabled if this is set +cpu0.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +cpu0.LOCK_SAU=0 # (bool , init-time) default = '0' : Lock down of SAU registers write +cpu0.LOCK_S_MPU=0 # (bool , init-time) default = '0' : Lock down of Secure MPU registers write +cpu0.LOCK_NS_MPU=0 # (bool , init-time) default = '0' : Lock down of Non-Secure MPU registers write +cpu0.CPIF=1 # (bool , init-time) default = '1' : Specifies whether the external coprocessor interface is included +cpu0.SECEXT=0 # (bool , init-time) default = '1' : Whether the ARMv8-M Security Extensions are included +fvp_mps2.DISABLE_GATING=1 # (bool , init-time) default = '0' : Disable Memory gating logic +fvp_mps2.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +fvp_mps2.SCC_ID.Variant=0x0 # (int , init-time) default = '0x0' : SCC_ID[23:20], X in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.SCC_ID.Revision=0x1 # (int , init-time) default = '0x1' : SCC_ID[3:0], Y in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.platform_type=0x0 # (int , init-time) default = '0x0' : 0:MPS2 ; 1:IoT Kit ; 2:Castor : [0x0..0x2] +fvp_mps2.extra_psram=0 # (bool , init-time) default = '0' : Increases PSRAM to 32Mb +fvp_mps2.UART2.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART2.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART2.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART2.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART2.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART2.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.UART1.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART1.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART1.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART1.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART1.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART1.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.mps2_visualisation.rate_limit-enable=1 # (bool , init-time) default = '1' : Rate limit simulation. +fvp_mps2.mps2_visualisation.disable-visualisation=0 # (bool , init-time) default = '0' : Enable/disable visualisation +fvp_mps2.mps2_visualisation.window_title="CLCD %cpu%" # (string, init-time) default = 'CLCD %cpu%' : Window title (%cpu% is replaced by cpu_name) +fvp_mps2.mps2_visualisation.idler.delay_ms=0x32 # (int , init-time) default = '0x32' : Determines the period, in milliseconds of real time, between gui_callback() calls. +fvp_mps2.telnetterminal0.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal0.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal0.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal0.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal0.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal1.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal1.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal1.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal1.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal1.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal2.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal2.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal2.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal2.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal2.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.PSRAM_M7.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM_M7.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM_M7.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.UART0.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART0.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART0.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART0.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART0.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART0.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.cmsdk_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.s32k_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.secure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.nonsecure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.PSRAM.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.stub.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram0.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram3.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.sys_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.sys_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1core_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.crypto_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.crypto_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cordio_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cordio_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram0_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram0_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram1_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram1_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram2_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram2_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram3_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram3_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.smsc_91c111.enabled=0 # (bool , init-time) default = '0' : Host interface connection enabled +fvp_mps2.smsc_91c111.mac_address="00:02:f7:ef:5d:a2" # (string, init-time) default = '00:02:f7:ef:5d:a2' : Host/model MAC address +fvp_mps2.smsc_91c111.promiscuous=1 # (bool , init-time) default = '1' : Put host into promiscuous mode +fvp_mps2.hostbridge.interfaceName="ARM0" # (string, init-time) default = 'ARM0' : Host Interface +fvp_mps2.hostbridge.userNetworking=0 # (bool , init-time) default = '0' : Enable user-mode networking +fvp_mps2.hostbridge.userNetSubnet="172.20.51.0/24" # (string, init-time) default = '172.20.51.0/24' : Virtual subnet for user-mode networking +fvp_mps2.hostbridge.userNetPorts="" # (string, init-time) default = '' : Listening ports to expose in user-mode networking +fvp_mps2.secure_control_register_block.FLASH_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : Flash Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.SRAM_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : SRAM Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.FLASH_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : Flash Watermark supported +fvp_mps2.secure_control_register_block.SRAM_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : SRAM Watermark supported +fvp_mps2.exclusive_monitor_psram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_psram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_psram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_psram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_psram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_psram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_psram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram1.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram1.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram1.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram1.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram1.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram1.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram1.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram2.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram2.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram2.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram2.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram2.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram2.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram2.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_iotss_internal_sram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_iotss_internal_sram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_iotss_internal_sram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_iotss_internal_sram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_iotss_internal_sram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_iotss_internal_sram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_iotss_internal_sram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.dma0_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma0_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma1_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma1_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma2_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma2_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma3_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma3_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma0.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma0.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma0.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma0.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma1.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma1.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma1.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma1.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma2.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma2.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma2.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma2.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma3.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma3.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma3.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma3.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.iotss_systemcontrol.cpu0wait=0 # (bool , init-time) default = '0' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_systemcontrol.cpu1wait=1 # (bool , init-time) default = '1' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_cpuidentity.debugger_master_id=0xFFFFFFFF # (int , init-time) default = '0xFFFFFFFF' : : [0x0..0xFFFFFFFF] +#---------------------------------------------------------------------------------------------- diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_FP_config.txt b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_FP_config.txt new file mode 100644 index 0000000..6812151 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_FP_config.txt @@ -0,0 +1,183 @@ +# Parameters: +# instance.parameter=value #(type, mode) default = 'def value' : description : [min..max] +#---------------------------------------------------------------------------------------------- +cpu0.FPU=1 # (bool , init-time) default = '1' : Set whether the model has VFP support +cpu0.DSP=0 # (bool , init-time) default = '1' : Set whether the model has the DSP extension +cpu0.semihosting-enable=0 # (bool , init-time) default = '1' : Enable semihosting SVC traps. Applications that do not use semihosting must set this parameter to false. +cpu0.MPU_S=0x8 # (int , init-time) default = '0x8' : Number of regions in the Secure MPU. If Security Extentions are absent, this is ignored : [0x0..0x10] +cpu0.MPU_NS=0x8 # (int , init-time) default = '0x8' : Number of regions in the Non-Secure MPU. If Security Extentions are absent, this is the total number of MPU regions : [0x0..0x10] +cpu0.ITM=0 # (bool , init-time) default = '1' : Level of instrumentation trace supported. false : No ITM trace included, true: ITM trace included +cpu0.IRQLVL=0x3 # (int , init-time) default = '0x3' : Number of bits of interrupt priority : [0x3..0x8] +cpu0.BIGENDINIT=0 # (bool , init-time) default = '0' : Initialize processor to big endian mode +cpu0.INITSVTOR=0x00000000 # (int , init-time) default = '0x10000000' : Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.INITNSVTOR=0x0 # (int , init-time) default = '0x0' : Non-Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.SAU=0x0 # (int , init-time) default = '0x4' : Number of SAU regions (0 => no SAU) : [0x0..0x8] +cpu0.SAU_CTRL.ENABLE=0 # (bool , init-time) default = '0' : Enable SAU at reset +cpu0.SAU_CTRL.ALLNS=0 # (bool , init-time) default = '0' : At reset, the SAU treats entire memory space as NS when the SAU is disabled if this is set +cpu0.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +cpu0.LOCK_SAU=0 # (bool , init-time) default = '0' : Lock down of SAU registers write +cpu0.LOCK_S_MPU=0 # (bool , init-time) default = '0' : Lock down of Secure MPU registers write +cpu0.LOCK_NS_MPU=0 # (bool , init-time) default = '0' : Lock down of Non-Secure MPU registers write +cpu0.CPIF=1 # (bool , init-time) default = '1' : Specifies whether the external coprocessor interface is included +cpu0.SECEXT=0 # (bool , init-time) default = '1' : Whether the ARMv8-M Security Extensions are included +fvp_mps2.DISABLE_GATING=1 # (bool , init-time) default = '0' : Disable Memory gating logic +fvp_mps2.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +fvp_mps2.SCC_ID.Variant=0x0 # (int , init-time) default = '0x0' : SCC_ID[23:20], X in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.SCC_ID.Revision=0x1 # (int , init-time) default = '0x1' : SCC_ID[3:0], Y in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.platform_type=0x0 # (int , init-time) default = '0x0' : 0:MPS2 ; 1:IoT Kit ; 2:Castor : [0x0..0x2] +fvp_mps2.extra_psram=0 # (bool , init-time) default = '0' : Increases PSRAM to 32Mb +fvp_mps2.UART2.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART2.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART2.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART2.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART2.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART2.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.UART1.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART1.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART1.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART1.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART1.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART1.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.mps2_visualisation.rate_limit-enable=1 # (bool , init-time) default = '1' : Rate limit simulation. +fvp_mps2.mps2_visualisation.disable-visualisation=0 # (bool , init-time) default = '0' : Enable/disable visualisation +fvp_mps2.mps2_visualisation.window_title="CLCD %cpu%" # (string, init-time) default = 'CLCD %cpu%' : Window title (%cpu% is replaced by cpu_name) +fvp_mps2.mps2_visualisation.idler.delay_ms=0x32 # (int , init-time) default = '0x32' : Determines the period, in milliseconds of real time, between gui_callback() calls. +fvp_mps2.telnetterminal0.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal0.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal0.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal0.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal0.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal1.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal1.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal1.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal1.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal1.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal2.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal2.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal2.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal2.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal2.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.PSRAM_M7.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM_M7.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM_M7.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.UART0.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART0.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART0.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART0.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART0.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART0.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.cmsdk_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.s32k_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.secure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.nonsecure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.PSRAM.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.stub.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram0.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram3.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.sys_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.sys_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1core_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.crypto_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.crypto_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cordio_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cordio_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram0_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram0_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram1_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram1_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram2_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram2_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram3_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram3_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.smsc_91c111.enabled=0 # (bool , init-time) default = '0' : Host interface connection enabled +fvp_mps2.smsc_91c111.mac_address="00:02:f7:ef:5d:a2" # (string, init-time) default = '00:02:f7:ef:5d:a2' : Host/model MAC address +fvp_mps2.smsc_91c111.promiscuous=1 # (bool , init-time) default = '1' : Put host into promiscuous mode +fvp_mps2.hostbridge.interfaceName="ARM0" # (string, init-time) default = 'ARM0' : Host Interface +fvp_mps2.hostbridge.userNetworking=0 # (bool , init-time) default = '0' : Enable user-mode networking +fvp_mps2.hostbridge.userNetSubnet="172.20.51.0/24" # (string, init-time) default = '172.20.51.0/24' : Virtual subnet for user-mode networking +fvp_mps2.hostbridge.userNetPorts="" # (string, init-time) default = '' : Listening ports to expose in user-mode networking +fvp_mps2.secure_control_register_block.FLASH_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : Flash Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.SRAM_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : SRAM Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.FLASH_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : Flash Watermark supported +fvp_mps2.secure_control_register_block.SRAM_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : SRAM Watermark supported +fvp_mps2.exclusive_monitor_psram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_psram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_psram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_psram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_psram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_psram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_psram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram1.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram1.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram1.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram1.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram1.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram1.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram1.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram2.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram2.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram2.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram2.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram2.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram2.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram2.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_iotss_internal_sram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_iotss_internal_sram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_iotss_internal_sram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_iotss_internal_sram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_iotss_internal_sram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_iotss_internal_sram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_iotss_internal_sram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.dma0_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma0_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma1_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma1_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma2_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma2_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma3_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma3_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma0.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma0.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma0.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma0.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma1.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma1.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma1.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma1.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma2.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma2.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma2.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma2.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma3.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma3.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma3.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma3.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.iotss_systemcontrol.cpu0wait=0 # (bool , init-time) default = '0' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_systemcontrol.cpu1wait=1 # (bool , init-time) default = '1' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_cpuidentity.debugger_master_id=0xFFFFFFFF # (int , init-time) default = '0xFFFFFFFF' : : [0x0..0xFFFFFFFF] +#---------------------------------------------------------------------------------------------- diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_config.txt b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_config.txt new file mode 100644 index 0000000..a2d1052 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_FVP/ARMCM33_config.txt @@ -0,0 +1,183 @@ +# Parameters: +# instance.parameter=value #(type, mode) default = 'def value' : description : [min..max] +#---------------------------------------------------------------------------------------------- +cpu0.FPU=0 # (bool , init-time) default = '1' : Set whether the model has VFP support +cpu0.DSP=0 # (bool , init-time) default = '1' : Set whether the model has the DSP extension +cpu0.semihosting-enable=0 # (bool , init-time) default = '1' : Enable semihosting SVC traps. Applications that do not use semihosting must set this parameter to false. +cpu0.MPU_S=0x8 # (int , init-time) default = '0x8' : Number of regions in the Secure MPU. If Security Extentions are absent, this is ignored : [0x0..0x10] +cpu0.MPU_NS=0x8 # (int , init-time) default = '0x8' : Number of regions in the Non-Secure MPU. If Security Extentions are absent, this is the total number of MPU regions : [0x0..0x10] +cpu0.ITM=0 # (bool , init-time) default = '1' : Level of instrumentation trace supported. false : No ITM trace included, true: ITM trace included +cpu0.IRQLVL=0x3 # (int , init-time) default = '0x3' : Number of bits of interrupt priority : [0x3..0x8] +cpu0.BIGENDINIT=0 # (bool , init-time) default = '0' : Initialize processor to big endian mode +cpu0.INITSVTOR=0x00000000 # (int , init-time) default = '0x10000000' : Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.INITNSVTOR=0x0 # (int , init-time) default = '0x0' : Non-Secure vector-table offset at reset : [0x0..0xFFFFFF80] +cpu0.SAU=0x0 # (int , init-time) default = '0x4' : Number of SAU regions (0 => no SAU) : [0x0..0x8] +cpu0.SAU_CTRL.ENABLE=0 # (bool , init-time) default = '0' : Enable SAU at reset +cpu0.SAU_CTRL.ALLNS=0 # (bool , init-time) default = '0' : At reset, the SAU treats entire memory space as NS when the SAU is disabled if this is set +cpu0.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +cpu0.LOCK_SAU=0 # (bool , init-time) default = '0' : Lock down of SAU registers write +cpu0.LOCK_S_MPU=0 # (bool , init-time) default = '0' : Lock down of Secure MPU registers write +cpu0.LOCK_NS_MPU=0 # (bool , init-time) default = '0' : Lock down of Non-Secure MPU registers write +cpu0.CPIF=1 # (bool , init-time) default = '1' : Specifies whether the external coprocessor interface is included +cpu0.SECEXT=0 # (bool , init-time) default = '1' : Whether the ARMv8-M Security Extensions are included +fvp_mps2.DISABLE_GATING=1 # (bool , init-time) default = '0' : Disable Memory gating logic +fvp_mps2.NUM_IDAU_REGION=0x0 # (int , init-time) default = '0xA' : +fvp_mps2.SCC_ID.Variant=0x0 # (int , init-time) default = '0x0' : SCC_ID[23:20], X in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.SCC_ID.Revision=0x1 # (int , init-time) default = '0x1' : SCC_ID[3:0], Y in the FGPA version 'rXpY' : [0x0..0xF] +fvp_mps2.platform_type=0x0 # (int , init-time) default = '0x0' : 0:MPS2 ; 1:IoT Kit ; 2:Castor : [0x0..0x2] +fvp_mps2.extra_psram=0 # (bool , init-time) default = '0' : Increases PSRAM to 32Mb +fvp_mps2.UART2.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART2.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART2.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART2.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART2.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART2.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.UART1.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART1.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART1.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART1.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART1.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART1.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.mps2_visualisation.rate_limit-enable=1 # (bool , init-time) default = '1' : Rate limit simulation. +fvp_mps2.mps2_visualisation.disable-visualisation=0 # (bool , init-time) default = '0' : Enable/disable visualisation +fvp_mps2.mps2_visualisation.window_title="CLCD %cpu%" # (string, init-time) default = 'CLCD %cpu%' : Window title (%cpu% is replaced by cpu_name) +fvp_mps2.mps2_visualisation.idler.delay_ms=0x32 # (int , init-time) default = '0x32' : Determines the period, in milliseconds of real time, between gui_callback() calls. +fvp_mps2.telnetterminal0.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal0.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal0.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal0.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal0.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal1.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal1.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal1.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal1.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal1.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.telnetterminal2.mode="telnet" # (string, init-time) default = 'telnet' : Terminal initialisation mode +fvp_mps2.telnetterminal2.start_telnet=1 # (bool , init-time) default = '1' : Start telnet if nothing connected +fvp_mps2.telnetterminal2.start_port=0x1388 # (int , init-time) default = '0x1388' : Telnet TCP Port Number : [0x0..0xFFFFFFFF] +fvp_mps2.telnetterminal2.quiet=0 # (bool , init-time) default = '0' : Avoid output on stdout/stderr +fvp_mps2.telnetterminal2.terminal_command="" # (string, init-time) default = '' : Commandline to launch a terminal application and connect to the opened TCP port. Keywords %port and %title will be replaced with the opened port number and component name respectively. An empty string (default behaviour) will launch xterm (Linux) or telnet.exe (Windows) +fvp_mps2.PSRAM_M7.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM_M7.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM_M7.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.UART0.out_file="" # (string, init-time) default = '' : Output file to hold data written by the UART (use '-' to send all output to stdout) +fvp_mps2.UART0.in_file="" # (string, init-time) default = '' : Input file for data to be read by the UART +fvp_mps2.UART0.unbuffered_output=0 # (bool , init-time) default = '0' : Unbuffered output +fvp_mps2.UART0.in_file_escape_sequence="##" # (string, init-time) default = '##' : Input file escape sequence +fvp_mps2.UART0.shutdown_on_eot=0 # (bool , init-time) default = '0' : Shutdown simulation when a EOT (ASCII 4) char is transmitted (useful for regression tests when semihosting is not available) +fvp_mps2.UART0.shutdown_tag="" # (string, run-time ) default = '' : Shutdown simulation when a string is transmitted +fvp_mps2.cmsdk_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.s32k_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.secure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.nonsecure_watchdog.simhalt=0 # (bool , run-time ) default = '0' : Halt on reset. +fvp_mps2.PSRAM.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.PSRAM.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.PSRAM.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.ssram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.ssram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.stub.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram0.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram0.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram1.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram1.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram2.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram2.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.size=0x100000000 # (int , init-time) default = '0x100000000' : Memory Size +fvp_mps2.iotss_internal_sram3.fill1=0xDFDFDFCF # (int , init-time) default = '0xDFDFDFCF' : Fill pattern 1, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.iotss_internal_sram3.fill2=0xCFDFDFDF # (int , init-time) default = '0xCFDFDFDF' : Fill pattern 2, initialise memory at start of simulation with alternating fill1, fill2 pattern +fvp_mps2.sys_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.sys_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu0dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1core_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1core_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cpu1dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cpu1dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.crypto_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.crypto_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.cordio_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.cordio_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.dbg_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.dbg_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram0_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram0_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram1_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram1_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram2_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram2_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.ram3_ppu.use_active_signal=0 # (bool , init-time) default = '0' : Use device-active signal +fvp_mps2.ram3_ppu.revision="r0p0" # (string, init-time) default = 'r0p0' : Revision +fvp_mps2.smsc_91c111.enabled=0 # (bool , init-time) default = '0' : Host interface connection enabled +fvp_mps2.smsc_91c111.mac_address="00:02:f7:ef:5d:a2" # (string, init-time) default = '00:02:f7:ef:5d:a2' : Host/model MAC address +fvp_mps2.smsc_91c111.promiscuous=1 # (bool , init-time) default = '1' : Put host into promiscuous mode +fvp_mps2.hostbridge.interfaceName="ARM0" # (string, init-time) default = 'ARM0' : Host Interface +fvp_mps2.hostbridge.userNetworking=0 # (bool , init-time) default = '0' : Enable user-mode networking +fvp_mps2.hostbridge.userNetSubnet="172.20.51.0/24" # (string, init-time) default = '172.20.51.0/24' : Virtual subnet for user-mode networking +fvp_mps2.hostbridge.userNetPorts="" # (string, init-time) default = '' : Listening ports to expose in user-mode networking +fvp_mps2.secure_control_register_block.FLASH_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : Flash Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.SRAM_BLOCK_CFG=0x3 # (int , init-time) default = '0x3' : SRAM Block size configuration : [0x0..0x31] +fvp_mps2.secure_control_register_block.FLASH_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : Flash Watermark supported +fvp_mps2.secure_control_register_block.SRAM_WATERMARK_SUPPORTED=1 # (bool , init-time) default = '1' : SRAM Watermark supported +fvp_mps2.exclusive_monitor_psram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_psram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_psram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_psram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_psram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_psram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_psram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram1.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram1.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram1.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram1.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram1.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram1.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram1.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_zbtsram2.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_zbtsram2.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_zbtsram2.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_zbtsram2.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_zbtsram2.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_zbtsram2.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_zbtsram2.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.exclusive_monitor_iotss_internal_sram.enable_component=1 # (bool , init-time) default = '1' : Enable component +fvp_mps2.exclusive_monitor_iotss_internal_sram.number_of_monitors=0x8 # (int , init-time) default = '0x8' : Number of monitors : [0x1..0xFFFFFFFF] +fvp_mps2.exclusive_monitor_iotss_internal_sram.log2_granule_size=0x0 # (int , init-time) default = '0x0' : log2 of address granule size : [0x0..0xB] +fvp_mps2.exclusive_monitor_iotss_internal_sram.monitor_non_excl_stores=0 # (bool , init-time) default = '0' : Monitor non-exclusive stores from the same master +fvp_mps2.exclusive_monitor_iotss_internal_sram.match_secure_state=1 # (bool , init-time) default = '1' : Treat the secure state like an address bit +fvp_mps2.exclusive_monitor_iotss_internal_sram.shareability_domain=0x3 # (int , init-time) default = '0x3' : Maximum shareability domain of interest, transactions outside of the domain will pass through un-monitored (0-non-shared, 1-inner, 2-outer, 3-system) : [0x0..0x3] +fvp_mps2.exclusive_monitor_iotss_internal_sram.apply_access_width_criteria_to_non_excl_stores=1 # (bool , init-time) default = '1' : Apply the given exclusive store width matching criteria to non-exclusive stores +fvp_mps2.dma0_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma0_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma1_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma1_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma2_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma2_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma3_securitymodifier.behaviour_ns_to_s=0x0 # (int , init-time) default = '0x0' : Behaviour for NS transactions to S space : 0:block 1:transmit 2:convert to S +fvp_mps2.dma3_securitymodifier.behaviour_s_to_ns=0x0 # (int , init-time) default = '0x0' : Behaviour for S transactions to NS space : 0:block 1:transmit 2:convert to NS +fvp_mps2.dma0.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma0.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma0.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma0.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma1.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma1.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma1.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma1.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma2.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma2.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma2.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma2.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.dma3.fifo_size=0x10 # (int , init-time) default = '0x10' : Channel FIFO size in bytes +fvp_mps2.dma3.max_transfer=0x100 # (int , init-time) default = '0x100' : Largest atomic transfer +fvp_mps2.dma3.generate_clear=0 # (bool , init-time) default = '0' : Generate clear response +fvp_mps2.dma3.activate_delay=0x0 # (int , init-time) default = '0x0' : request delay +fvp_mps2.iotss_systemcontrol.cpu0wait=0 # (bool , init-time) default = '0' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_systemcontrol.cpu1wait=1 # (bool , init-time) default = '1' : Whether to hold cpu1 in reset at boot +fvp_mps2.iotss_cpuidentity.debugger_master_id=0xFFFFFFFF # (int , init-time) default = '0xFFFFFFFF' : : [0x0..0xFFFFFFFF] +#---------------------------------------------------------------------------------------------- diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_MPS2/HowTo.txt b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_MPS2/HowTo.txt new file mode 100644 index 0000000..865ac15 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/DspLibTest_MPS2/HowTo.txt @@ -0,0 +1,29 @@ + +Used board: + MPS2+. + +Used BIOS: + mbb_v121.ebf ; use this for ULINKpro + mbb_v220.ebf ; CMSIS-DAP + +Used Images: + AN382\an382_v3.txt ; Cortex-M0 + AN385\an385_v3.txt ; Cortex-M3 + AN386\an386_v3.txt ; Cortex-M4 + AN500\an500_v1.txt ; Cortex-M7 + AN505\an505_v2.txt ; Cortex-M33 (IoT Kit) + AN519\an519_v1.txt ; Cortex-M23 (IoT Kit) + +Used Debugger: + IoT Kit: + ULINKpro, JTAG, 25MHz, HW Reset + other: + ULINKpro, JTAG, 25MHz, Autodetect + +Memory Settings: + IoT Kit: + ROM: 0x10000000 + RAM: 0x38000000 + other: + ROM: 0x00000000 + RAM: 0x20000000 \ No newline at end of file diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/HowTo.txt b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/HowTo.txt new file mode 100644 index 0000000..39147ab --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/HowTo.txt @@ -0,0 +1,144 @@ +HowTo DSP_Lib_TestSuite 16.12.2016 +======================================= + +This file describes the folder structure, content, prerequisites and instructions to validate the +build of the CMSIS-DSP library. This is done by processing input data sets using the DSP Library +functions executing on a target simulator or hardware. The output data sets are then compared +with the reference data set produced by unoptimized DSP functions and a Signal to Noise Ratio (SNR) +is computed. If the SNR is below a defined threshold the test is considered "passed". + + +Folder structure +---------------- + .\DSP_Lib_TestSuite Batch files for building the reference libraries and running the tests. + .\DSP_Lib_TestSuite\Common + .\DSP_Lib_TestSuite\Common\inc DSP_Lib test include files + .\DSP_Lib_TestSuite\Common\JTest JTEST Test Framework + INI files for uVision + .\DSP_Lib_TestSuite\Common\platform ARM/GCC device startup/system files + .\DSP_Lib_TestSuite\Common\src DSP_Lib test source files + .\DSP_Lib_TestSuite\DspLibTest_FVP ARM/GCC DSP_Lib test projects for Fixed Virtual Platforms + .\DSP_Lib_TestSuite\DspLibTest_MPS2 ARM/GCC DSP_Lib test projects for MPS2 + .\DSP_Lib_TestSuite\DspLibTest_Simulator ARM/GCC DSP_Lib test projects for uVision simulator + .\DSP_Lib_TestSuite\RefLibs ARM/GCC DSP_Lib reference libraries (and projects) + + + +Prerequisites +-------------- + - Python (running on Windows). Tested with ActivePython 2.7.8.10. + - Keil MDK-ARM (tested with MDK-ARM 5.22: http://www2.keil.com/mdk5) + - ULINKpro debug adapter (http://www2.keil.com/mdk5/ulink) + - MPS2 (Cortex-M Prototyping System:https://www.arm.com/products/tools/development-boards/versatile-express/cortex-m-prototyping-system.php) + - CMSIS 5.0.0 (https://github.com/ARM-software/CMSIS_5/releases/tag/5.0.0) + + +Setup +------ + - Copy DSP_Lib_TestSuite to the CMSIS installation/pack folder. + ... + .\Keil_v5\ARM\PACK\ARM\CMSIS\DSP_Lib + .\Keil_v5\ARM\PACK\ARM\CMSIS\DSP_Lib_TestSuite <- location of DSP_Lib_TestSuite + .\Keil_v5\ARM\PACK\ARM\CMSIS\Include + ... + + - remove 'read-only' tag from folder ./CMSIS/Lib + (required for rebuild of the DSP_Lib libraries) + + - open a Windows command window in folder .\CMSIS\DSP_Lib_TestSuite. + + + +How to run the tests +--------------------- + +a) build the DSP_Lib libraries: + - batch file: buildDspLibs.bat + Note: only require if the DSP_Lib source code got updated or the desired configuration is missing + buildDspLibs.bat overwrites the prebuild libraries in .\CMSIS\Lib. + Log files of the build process are generated in folder .\CMSIS\DSP_Lib/[ARM|GCC] + - run: buildDspLibs.bat in a Windows command window in folder ./CMSIS/DSP_Lib_TestSuite + buildDspLibs ARM -> builds the ARMCC libraries + buildDspLibs GCC -> builds the GCC libraries + +b) build the reference libraries: + - batch file: buildRefLibs.bat + + Log files of the build process are generated in folder .\CMSIS\DSP_Lib_TestSuite\RefLibs/[ARM|GCC] + - run: buildRefLibs.bat in a Windows command window in folder .\CMSIS\DSP_Lib_TestSuite + buildRefLibs ARM -> builds the ARMCC reference libraries + buildRefLibs GCC -> builds the GCC reference libraries + +c) running an individual test using uVision (MDK-ARM): + - batch file: runTest.bat + - run: runTest.bat in a Windows command window in folder .\CMSIS\DSP_Lib_TestSuite + runTest -> prints usage information + e.g. runTest ARM cortexM4lf Simulator -> runs the test for toolchain ARM, Cortex-M4 littel endian with FPU, uVision Simulator. + + Tests running on MPS2 requires additional steps to setup. See section 'MPS2'. + +d) parsing the test output log file + - script: parseLog.py + - run: parseLog.py python script in a Windows command window in folder .\CMSIS\DSP_Lib_TestSuite + command line options should match the invocation of the runTest executed before. + e.g: runTest ARM cortexM4lf Simulator -> python parseLog.py ARM cortexM4lf Simulator + + - check the test log + depending on your test parameters change into the required folder + .\DSP_Lib_TestSuite\DspLibTest_[FVP|MPS2|Simulator]\[ARM|GCC]\Logs + the folder will contain the following files (e.g. for a 'runTest') : + DspLibTest_Simulator.log raw result of the last test run. + DspLibTest_Simulator_cortexM4lf.log raw result of a cortexM4lf test run + DspLibTest_Simulator_cortexM4lf_build.log build result of cortexM4lf test + DspLibTest_Simulator_cortexM4lf_parsed.log parsed log of raw result of a cortexM4lf test run + DspLibTest_Simulator_cortexM4lf_time.log log how long the test took (some tests e.g. M0 take really a long time!). + 'runTest' produces files of the format: DspLibTest__... + + +Differences between the tests for FVP, MPS2, Simulator +------------------------------------------------------ + - all tests are identical except for: + 'Simulator' uses uVision with uVision simulator and generates also code coverage information + can be used for little/big endian tests + ! do not use 'Simulator' for M7 with FPU -> no uVision simulation available. + ! do not use 'Simulator' for ARMv8-M devices -> no uVision simulation available. + 'MPS2' uses uVision with ULINKpro debugger and MPS2. No code coverage information is generated. + can be used for little endian only (because of the lack of MPS2 FPGA images). + 'FVP' uses uVision with Models debugger. No code coverage information is generated. + can be used for little/big endian tests. + ! config files must be prepared. + ! uVision target for big endianess are not yet prepared. + + +Setup 'MPS2' +------------- + - load the appropriate FPGA image to the MPS2 board matching the CPU of the test builds prior to running the test + - check if ULINKpro can connect with the configured debug connection (JTAG or SWD) as this must + match the protocol implemented in the FPGA image. + + +How to select tests for "run all tests" +---------------------------------------- + - edit .\CMSIS\DSP_Lib_TestSuite\Common\src\all_tests.c + comment out all unwanted test groups. + e.g. // JTEST_GROUP_CALL(complex_math_tests); + + - edit .\CMSIS\DSP_Lib_TestSuite\Common\src\/_group.c + comment out all unwanted sub test groups. + e.g. file .\DSP_Lib_TestSuite\Common\src\basic_math_tests\basic_math_test_group.c -> // JTEST_GROUP_CALL(abs_tests); + + - edit .\CMSIS\DSP_Lib_TestSuite\Common\src\/_tests.c + comment out all unwanted tests. + e.g. file .\DSP_Lib_TestSuite\Common\src\basic_math_tests\abs_tests.c -> // JTEST_TEST_CALL(arm_abs_f32_test); + + +Notes +----- + - How to use ARM Clang (ARM Compiler 6): + in uVision 'Options for Target' tab you can select which compiler to use + by default uVision uses ARMCC V5 for Cortex-M devices and ARMCLANG V6 only for ARMv8M. + Only ARMv8M cores have been tested using ARMCLANG + + - test data used for the tests is used as provided by DSP Concepts. + + - some tests run for a very long time before they finish. This is expected + diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/inc/ref.h b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/inc/ref.h new file mode 100644 index 0000000..4ab5c3c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/inc/ref.h @@ -0,0 +1,1396 @@ + +#ifndef _REF_H +#define _REF_H + +#include +#include +#include "arm_math.h" + +#ifdef __cplusplus +extern "C" +{ +#endif + +#ifndef PI +#define PI 3.14159265358979f +#endif + + /** + * @brief 8-bit fractional data type in 1.7 format. + */ +// typedef int8_t q7_t; + + /** + * @brief 16-bit fractional data type in 1.15 format. + */ +// typedef int16_t q15_t; + + /** + * @brief 32-bit fractional data type in 1.31 format. + */ +// typedef int32_t q31_t; + + /** + * @brief 64-bit fractional data type in 1.63 format. + */ +// typedef int64_t q63_t; + + /** + * @brief 32-bit floating-point type definition. + */ +// typedef float float32_t; + + /** + * @brief 64-bit floating-point type definition. + */ +// typedef double float64_t; + + + /** + * @brief Error status returned by some functions in the library. + */ + + typedef enum + { + REF_Q7 = 0, + REF_Q15, + REF_Q31, + REF_F32, + } dataType; + + +#define FLT_MAX 3.40282347e+38F +#define DBL_MAX 1.79769313486231571e+308 + +#define FLT_MIN 1.175494351e-38F +#define DBL_MIN 2.22507385850720138e-308 + +#define SCHAR_MIN (-128) + /* mimimum value for an object of type signed char */ +#define SCHAR_MAX 127 + /* maximum value for an object of type signed char */ +#define UCHAR_MAX 255 + /* maximum value for an object of type unsigned char */ +#define SHRT_MIN (-0x8000) + /* minimum value for an object of type short int */ +#define SHRT_MAX 0x7fff + /* maximum value for an object of type short int */ +#define USHRT_MAX 65535 + /* maximum value for an object of type unsigned short int */ +#define INT_MIN (~0x7fffffff) /* -2147483648 and 0x80000000 are unsigned */ + /* minimum value for an object of type int */ +#define INT_MAX 0x7fffffff + /* maximum value for an object of type int */ +#define UINT_MAX 0xffffffffU + /* maximum value for an object of type unsigned int */ +#define LONG_MIN (~0x7fffffffL) + /* minimum value for an object of type long int */ +#define LONG_MAX 0x7fffffffL + /* maximum value for an object of type long int */ +#define ULONG_MAX 0xffffffffUL + /* maximum value for an object of type unsigned long int */ + + /* + * Ref Lib Global Variables + */ +extern float32_t scratchArray[]; +extern arm_cfft_instance_f32 ref_cfft_sR_f32_len8192; + + /* + * Ref Lib Functions + */ + + /* + * Helper Functions + */ +q31_t ref_sat_n(q31_t num, uint32_t bits); + +q31_t ref_sat_q31(q63_t num); + +q15_t ref_sat_q15(q31_t num); + +q7_t ref_sat_q7(q15_t num); + +float32_t ref_pow(float32_t a, uint32_t b); + +extern float32_t tempMatrixArray[]; + +float32_t ref_detrm(float32_t *pSrc, float32_t *temp, uint32_t size); + +void ref_cofact(float32_t *pSrc, float32_t *pDst, float32_t *temp, uint32_t size); + +float64_t ref_detrm64(float64_t *pSrc, float64_t *temp, uint32_t size); + +void ref_cofact64(float64_t *pSrc, float64_t *pDst, float64_t *temp, uint32_t size); + + /* + * Basic Math Functions + */ +void ref_abs_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_abs_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_abs_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_abs_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + +void ref_add_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize); + +void ref_add_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize); + +void ref_add_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize); + +void ref_add_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize); + +void ref_dot_prod_f32( + float32_t * pSrcA, + float32_t * pSrcB, + uint32_t blockSize, + float32_t * result); + +void ref_dot_prod_q31( + q31_t * pSrcA, + q31_t * pSrcB, + uint32_t blockSize, + q63_t * result); + +void ref_dot_prod_q15( + q15_t * pSrcA, + q15_t * pSrcB, + uint32_t blockSize, + q63_t * result); + +void ref_dot_prod_q7( + q7_t * pSrcA, + q7_t * pSrcB, + uint32_t blockSize, + q31_t * result); + +void ref_mult_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize); + +void ref_mult_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize); + +void ref_mult_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize); + +void ref_mult_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize); + +void ref_negate_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_negate_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_negate_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_negate_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + +void ref_offset_f32( + float32_t * pSrc, + float32_t offset, + float32_t * pDst, + uint32_t blockSize); + +void ref_offset_q31( + q31_t * pSrc, + q31_t offset, + q31_t * pDst, + uint32_t blockSize); + +void ref_offset_q15( + q15_t * pSrc, + q15_t offset, + q15_t * pDst, + uint32_t blockSize); + +void ref_offset_q7( + q7_t * pSrc, + q7_t offset, + q7_t * pDst, + uint32_t blockSize); + +void ref_scale_f32( + float32_t * pSrc, + float32_t scale, + float32_t * pDst, + uint32_t blockSize); + +void ref_scale_q31( + q31_t * pSrc, + q31_t scaleFract, + int8_t shift, + q31_t * pDst, + uint32_t blockSize); + +void ref_scale_q15( + q15_t * pSrc, + q15_t scaleFract, + int8_t shift, + q15_t * pDst, + uint32_t blockSize); + +void ref_scale_q7( + q7_t * pSrc, + q7_t scaleFract, + int8_t shift, + q7_t * pDst, + uint32_t blockSize); + +void ref_shift_q31( + q31_t * pSrc, + int8_t shiftBits, + q31_t * pDst, + uint32_t blockSize); + +void ref_shift_q15( + q15_t * pSrc, + int8_t shiftBits, + q15_t * pDst, + uint32_t blockSize); + +void ref_shift_q7( + q7_t * pSrc, + int8_t shiftBits, + q7_t * pDst, + uint32_t blockSize); + +void ref_sub_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize); + +void ref_sub_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize); + +void ref_sub_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize); + +void ref_sub_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize); + + /* + * Complex Math Functions + */ +void ref_cmplx_conj_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples); + +void ref_cmplx_conj_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t numSamples); + +void ref_cmplx_conj_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples); + +void ref_cmplx_dot_prod_f32( + float32_t * pSrcA, + float32_t * pSrcB, + uint32_t numSamples, + float32_t * realResult, + float32_t * imagResult); + +void ref_cmplx_dot_prod_q31( + q31_t * pSrcA, + q31_t * pSrcB, + uint32_t numSamples, + q63_t * realResult, + q63_t * imagResult); + +void ref_cmplx_dot_prod_q15( + q15_t * pSrcA, + q15_t * pSrcB, + uint32_t numSamples, + q31_t * realResult, + q31_t * imagResult); + +void ref_cmplx_mag_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mag_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mag_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mag_squared_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mag_squared_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mag_squared_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mult_cmplx_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mult_cmplx_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mult_cmplx_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t numSamples); + +void ref_cmplx_mult_real_f32( + float32_t * pSrcCmplx, + float32_t * pSrcReal, + float32_t * pCmplxDst, + uint32_t numSamples); + +void ref_cmplx_mult_real_q31( + q31_t * pSrcCmplx, + q31_t * pSrcReal, + q31_t * pCmplxDst, + uint32_t numSamples); + +void ref_cmplx_mult_real_q15( + q15_t * pSrcCmplx, + q15_t * pSrcReal, + q15_t * pCmplxDst, + uint32_t numSamples); + + /* + * Controller Functions + */ +void ref_sin_cos_f32( + float32_t theta, + float32_t * pSinVal, + float32_t * pCosVal); + +void ref_sin_cos_q31( + q31_t theta, + q31_t * pSinVal, + q31_t * pCosVal); + +float32_t ref_pid_f32( + arm_pid_instance_f32 * S, + float32_t in); + +q31_t ref_pid_q31( + arm_pid_instance_q31 * S, + q31_t in); + +q15_t ref_pid_q15( + arm_pid_instance_q15 * S, + q15_t in); + + /* + * Fast Math Functions + */ +#define ref_sin_f32(a) sinf(a) + +q31_t ref_sin_q31(q31_t x); + +q15_t ref_sin_q15(q15_t x); + +#define ref_cos_f32(a) cosf(a) + +q31_t ref_cos_q31(q31_t x); + +q15_t ref_cos_q15(q15_t x); + +arm_status ref_sqrt_q31(q31_t in, q31_t * pOut); + +arm_status ref_sqrt_q15(q15_t in, q15_t * pOut); + + /* + * Filtering Functions + */ +void ref_biquad_cascade_df2T_f32( + const arm_biquad_cascade_df2T_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_biquad_cascade_stereo_df2T_f32( + const arm_biquad_cascade_stereo_df2T_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_biquad_cascade_df2T_f64( + const arm_biquad_cascade_df2T_instance_f64 * S, + float64_t * pSrc, + float64_t * pDst, + uint32_t blockSize); + +void ref_biquad_cascade_df1_f32( + const arm_biquad_casd_df1_inst_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_biquad_cas_df1_32x64_q31( + const arm_biquad_cas_df1_32x64_ins_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_biquad_cascade_df1_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_biquad_cascade_df1_fast_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_biquad_cascade_df1_fast_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_biquad_cascade_df1_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_conv_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst); + +arm_status ref_conv_partial_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + +void ref_conv_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + +void ref_conv_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + +arm_status ref_conv_partial_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + +arm_status ref_conv_partial_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + +void ref_conv_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + +#define ref_conv_opt_q15(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + pScratch1, pScratch2) \ + ref_conv_q15(pSrcA, srcALen, pSrcB, srcBLen, pDst) + +void ref_conv_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + +void ref_conv_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2); + +arm_status ref_conv_partial_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + +#define ref_conv_partial_opt_q15(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + firstIndex, numPoints, \ + pScratch1, pScratch2) \ + ref_conv_partial_q15(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + firstIndex, numPoints) + +arm_status ref_conv_partial_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + +arm_status ref_conv_partial_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2); + +void ref_conv_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst); + +#define ref_conv_opt_q7(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + pScratch1, pScratch2) \ + ref_conv_q7(pSrcA, srcALen, pSrcB, srcBLen, pDst) + +arm_status ref_conv_partial_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + +#define ref_conv_partial_opt_q7(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + firstIndex, numPoints, \ + pScratch1, pScratch2) \ + ref_conv_partial_q7(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + firstIndex, numPoints) + +void ref_correlate_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst); + +void ref_correlate_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + +void ref_correlate_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + +void ref_correlate_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + +#define ref_correlate_opt_q15(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + pScratch1) \ + ref_correlate_q15(pSrcA, srcALen, pSrcB, srcBLen, pDst) + +void ref_correlate_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + +void ref_correlate_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch); + +void ref_correlate_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst); + +#define ref_correlate_opt_q7(pSrcA, srcALen, pSrcB, srcBLen, pDst, \ + pScratch1, pScratch2) \ + ref_correlate_q7(pSrcA, srcALen, pSrcB, srcBLen, pDst) + +void ref_fir_f32( + const arm_fir_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_fir_q31( + const arm_fir_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_fir_fast_q31( + const arm_fir_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_fir_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_fir_fast_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_fir_q7( + const arm_fir_instance_q7 * S, + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + +void ref_fir_decimate_f32( + const arm_fir_decimate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_fir_decimate_q31( + const arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_fir_decimate_fast_q31( + const arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_fir_decimate_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_fir_decimate_fast_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_fir_lattice_f32( + const arm_fir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_fir_lattice_q31( + const arm_fir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_fir_lattice_q15( + const arm_fir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_fir_sparse_f32( + arm_fir_sparse_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + float32_t * pScratchIn, + uint32_t blockSize); + +void ref_fir_sparse_q31( + arm_fir_sparse_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + q31_t * pScratchIn, + uint32_t blockSize); + +void ref_fir_sparse_q15( + arm_fir_sparse_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + q15_t * pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize); + +void ref_fir_sparse_q7( + arm_fir_sparse_instance_q7 * S, + q7_t *pSrc, + q7_t *pDst, + q7_t *pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize); + +void ref_iir_lattice_f32( + const arm_iir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_iir_lattice_q31( + const arm_iir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_iir_lattice_q15( + const arm_iir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_lms_f32( + const arm_lms_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize); + +void ref_lms_norm_f32( + arm_lms_norm_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize); + +void ref_lms_q31( + const arm_lms_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize); + +void ref_lms_norm_q31( + arm_lms_norm_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize); + +void ref_lms_q15( + const arm_lms_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize); + +void ref_lms_norm_q15( + arm_lms_norm_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize); + +void ref_fir_interpolate_f32( + const arm_fir_interpolate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_fir_interpolate_q31( + const arm_fir_interpolate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_fir_interpolate_q15( + const arm_fir_interpolate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + /* + * Matrix Functions + */ +arm_status ref_mat_cmplx_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + +arm_status ref_mat_cmplx_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + +arm_status ref_mat_cmplx_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst); + +arm_status ref_mat_inverse_f32( + const arm_matrix_instance_f32 * pSrc, + arm_matrix_instance_f32 * pDst); + +arm_status ref_mat_inverse_f64( + const arm_matrix_instance_f64 * pSrc, + arm_matrix_instance_f64 * pDst); + +arm_status ref_mat_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + +arm_status ref_mat_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + +/* Alias for testing purposes*/ +#define ref_mat_mult_fast_q31 ref_mat_mult_q31 + +arm_status ref_mat_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst); + +/* Alias for testing purposes*/ +#define ref_mat_mult_fast_q15 ref_mat_mult_q15 + +arm_status ref_mat_scale_f32( + const arm_matrix_instance_f32 * pSrc, + float32_t scale, + arm_matrix_instance_f32 * pDst); + +arm_status ref_mat_scale_q31( + const arm_matrix_instance_q31 * pSrc, + q31_t scale, + int32_t shift, + arm_matrix_instance_q31 * pDst); + +arm_status ref_mat_scale_q15( + const arm_matrix_instance_q15 * pSrc, + q15_t scale, + int32_t shift, + arm_matrix_instance_q15 * pDst); + +arm_status ref_mat_sub_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + +arm_status ref_mat_sub_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + +arm_status ref_mat_sub_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst); + +arm_status ref_mat_trans_f64( + const arm_matrix_instance_f64 * pSrc, + arm_matrix_instance_f64 * pDst); + +arm_status ref_mat_trans_f32( + const arm_matrix_instance_f32 * pSrc, + arm_matrix_instance_f32 * pDst); + +arm_status ref_mat_trans_q31( + const arm_matrix_instance_q31 * pSrc, + arm_matrix_instance_q31 * pDst); + +arm_status ref_mat_trans_q15( + const arm_matrix_instance_q15 * pSrc, + arm_matrix_instance_q15 * pDst); + +arm_status ref_mat_add_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + +arm_status ref_mat_add_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + +arm_status ref_mat_add_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst); + + /* + * Statistics Functions + */ +void ref_max_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult, + uint32_t * pIndex); + +void ref_max_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult, + uint32_t * pIndex); + +void ref_max_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult, + uint32_t * pIndex); + +void ref_max_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult, + uint32_t * pIndex); + +void ref_mean_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + +void ref_mean_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + +void ref_mean_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + +void ref_mean_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult); + +void ref_min_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult, + uint32_t * pIndex); + +void ref_min_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult, + uint32_t * pIndex); + +void ref_min_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult, + uint32_t * pIndex); + +void ref_min_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult, + uint32_t * pIndex); + +void ref_power_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + +void ref_power_q31( + q31_t * pSrc, + uint32_t blockSize, + q63_t * pResult); + +void ref_power_q15( + q15_t * pSrc, + uint32_t blockSize, + q63_t * pResult); + +void ref_power_q7( + q7_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + +void ref_rms_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + +void ref_rms_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + +void ref_rms_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + +void ref_std_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + +void ref_std_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + +void ref_std_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + +void ref_var_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + +void ref_var_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + +void ref_var_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + + /* + * Support Functions + */ +void ref_copy_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_copy_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_copy_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_copy_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + +void ref_fill_f32( + float32_t value, + float32_t * pDst, + uint32_t blockSize); + +void ref_fill_q31( + q31_t value, + q31_t * pDst, + uint32_t blockSize); + +void ref_fill_q15( + q15_t value, + q15_t * pDst, + uint32_t blockSize); + +void ref_fill_q7( + q7_t value, + q7_t * pDst, + uint32_t blockSize); + +void ref_q31_to_q15( + q31_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_q31_to_q7( + q31_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + +void ref_q15_to_q31( + q15_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_q15_to_q7( + q15_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + +void ref_q7_to_q31( + q7_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_q7_to_q15( + q7_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_q63_to_float( + q63_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_q31_to_float( + q31_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_q15_to_float( + q15_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_q7_to_float( + q7_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + +void ref_float_to_q31( + float32_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + +void ref_float_to_q15( + float32_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + +void ref_float_to_q7( + float32_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + /* + * Transform Functions + */ +void ref_cfft_f32( + const arm_cfft_instance_f32 * S, + float32_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +void ref_cfft_q31( + const arm_cfft_instance_q31 * S, + q31_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +void ref_cfft_q15( + const arm_cfft_instance_q15 * S, + q15_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +void ref_cfft_radix2_f32( + const arm_cfft_radix2_instance_f32 * S, + float32_t * pSrc); + +void ref_cfft_radix2_q31( + const arm_cfft_radix2_instance_q31 * S, + q31_t * pSrc); + +void ref_cfft_radix2_q15( + const arm_cfft_radix2_instance_q15 * S, + q15_t * pSrc); + +void ref_cfft_radix4_f32( + const arm_cfft_radix4_instance_f32 * S, + float32_t * pSrc); + +void ref_cfft_radix4_q31( + const arm_cfft_radix4_instance_q31 * S, + q31_t * pSrc); + +void ref_cfft_radix4_q15( + const arm_cfft_radix4_instance_q15 * S, + q15_t * pSrc); + +void ref_rfft_f32( + arm_rfft_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst); + +void ref_rfft_fast_f32( + arm_rfft_fast_instance_f32 * S, + float32_t * p, float32_t * pOut, + uint8_t ifftFlag); + +void ref_rfft_q31( + const arm_rfft_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst); + +void ref_rfft_q15( + const arm_rfft_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst); + +void ref_dct4_f32( + const arm_dct4_instance_f32 * S, + float32_t * pState, + float32_t * pInlineBuffer); + +void ref_dct4_q31( + const arm_dct4_instance_q31 * S, + q31_t * pState, + q31_t * pInlineBuffer); + +void ref_dct4_q15( + const arm_dct4_instance_q15 * S, + q15_t * pState, + q15_t * pInlineBuffer); + + /* + * Intrinsics + */ +q31_t ref__QADD8(q31_t x, q31_t y); +q31_t ref__QSUB8(q31_t x, q31_t y); +q31_t ref__QADD16(q31_t x, q31_t y); +q31_t ref__SHADD16(q31_t x, q31_t y); +q31_t ref__QSUB16(q31_t x, q31_t y); +q31_t ref__SHSUB16(q31_t x, q31_t y); +q31_t ref__QASX(q31_t x, q31_t y); +q31_t ref__SHASX(q31_t x, q31_t y); +q31_t ref__QSAX(q31_t x, q31_t y); +q31_t ref__SHSAX(q31_t x, q31_t y); +q31_t ref__SMUSDX(q31_t x, q31_t y); +q31_t ref__SMUADX(q31_t x, q31_t y); +q31_t ref__QADD(q31_t x, q31_t y); +q31_t ref__QSUB(q31_t x, q31_t y); +q31_t ref__SMLAD(q31_t x, q31_t y, q31_t sum); +q31_t ref__SMLADX(q31_t x, q31_t y, q31_t sum); +q31_t ref__SMLSDX(q31_t x, q31_t y, q31_t sum); +q63_t ref__SMLALD(q31_t x, q31_t y, q63_t sum); +q63_t ref__SMLALDX(q31_t x, q31_t y, q63_t sum); +q31_t ref__SMUAD(q31_t x, q31_t y); +q31_t ref__SMUSD(q31_t x, q31_t y); +q31_t ref__SXTB16(q31_t x); + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/abs.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/abs.c new file mode 100644 index 0000000..baca23f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/abs.c @@ -0,0 +1,53 @@ +#include "ref.h" + +void ref_abs_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + for(i=0;i> 14; //16.48 + } + *result = sum; +} + +void ref_dot_prod_q15( + q15_t * pSrcA, + q15_t * pSrcB, + uint32_t blockSize, + q63_t * result) +{ + uint32_t i; + q63_t sum = 0.0f; + + for(i=0;i> 32; + temp = temp << 1; + pDst[i] = ref_sat_q31(temp); + } +} + +void ref_mult_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + q31_t temp; + + for(i=0;i> 15; //this comment is for JD, this is specifically 15 and not 16 like the q31 case might imply. This is because CMSIS DSP lib does it this way. No other reason. + pDst[i] = ref_sat_q15(temp); + } +} + +void ref_mult_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + q15_t temp; + + for(i=0;i> 7; + pDst[i] = ref_sat_q7(temp); + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/negate.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/negate.c new file mode 100644 index 0000000..192da1b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/negate.c @@ -0,0 +1,53 @@ +#include "ref.h" + +void ref_negate_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + for(i=0;i> 32; + if (sign) + pDst[i] = temp >> -kShift; + else + pDst[i] = ref_sat_q31( (q63_t)temp << kShift ); + } +} + +void ref_scale_q15( + q15_t * pSrc, + q15_t scaleFract, + int8_t shift, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + int8_t kShift = 15 - shift; /* Shift to apply after scaling */ + + for(i=0;i> kShift); + } +} + +void ref_scale_q7( + q7_t * pSrc, + q7_t scaleFract, + int8_t shift, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + int8_t kShift = 7 - shift; /* Shift to apply after scaling */ + + for(i=0;i> kShift); + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/shift.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/shift.c new file mode 100644 index 0000000..3bc53ad --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/shift.c @@ -0,0 +1,73 @@ +#include "ref.h" + +void ref_shift_q31( + q31_t * pSrc, + int8_t shiftBits, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + if (shiftBits < 0) + { + for(i=0;i> -shiftBits; + } + } +} + +void ref_shift_q15( + q15_t * pSrc, + int8_t shiftBits, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + if (shiftBits < 0) + { + for(i=0;i> -shiftBits; + } + } +} + +void ref_shift_q7( + q7_t * pSrc, + int8_t shiftBits, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + if (shiftBits < 0) + { + for(i=0;i> -shiftBits; + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/sub.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/sub.c new file mode 100644 index 0000000..da89e95 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/BasicMathFunctions/sub.c @@ -0,0 +1,57 @@ +#include "ref.h" + +void ref_sub_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + for(i=0;i> 14) - (((q63_t)pSrcA[i+1] * pSrcB[i+1]) >> 14); + sumi += (((q63_t)pSrcA[i] * pSrcB[i+1]) >> 14) + (((q63_t)pSrcA[i+1] * pSrcB[i] ) >> 14); + } + + *realResult = sumr; + *imagResult = sumi; +} + +void ref_cmplx_dot_prod_q15( + q15_t * pSrcA, + q15_t * pSrcB, + uint32_t numSamples, + q31_t * realResult, + q31_t * imagResult) +{ + q63_t sumr, sumi; + uint32_t i; + + sumr = 0; + sumi = 0; + + for(i=0;i> 6); + *imagResult = (q31_t)(sumi >> 6); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag.c new file mode 100644 index 0000000..b5ac28d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag.c @@ -0,0 +1,49 @@ +#include "ref.h" + +void ref_cmplx_mag_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples) +{ + uint32_t i; + + for(i=0;i> 33); + acc1 = (q31_t)(((q63_t)pSrc[i+1] * pSrc[i+1]) >> 33); + out = acc0 + acc1; + *pDst++ = (q31_t)(sqrtf((float)out / 2147483648.0f) * 2147483648.0f); + } +} + +void ref_cmplx_mag_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples) +{ + uint32_t i; + q31_t acc0,acc1; + q15_t out; + + for(i=0;i> 17); + *pDst++ = (q15_t)(sqrtf((float)out / 32768.0f) * 32768.0f); + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag_squared.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag_squared.c new file mode 100644 index 0000000..aec7bd5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mag_squared.c @@ -0,0 +1,46 @@ +#include "ref.h" + +void ref_cmplx_mag_squared_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples) +{ + uint32_t i; + + for(i=0;i> 33); + acc1 = (q31_t)(((q63_t)pSrc[i+1] * pSrc[i+1]) >> 33); + *pDst++ = acc0 + acc1; + } +} + +void ref_cmplx_mag_squared_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples) +{ + uint32_t i; + q31_t acc0,acc1; + + for(i=0;i> 17); + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_cmplx.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_cmplx.c new file mode 100644 index 0000000..c7a5409 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_cmplx.c @@ -0,0 +1,56 @@ +#include "ref.h" + +void ref_cmplx_mult_cmplx_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t numSamples) +{ + uint32_t i; + + for(i=0;i> 33; + mul2 = ((q63_t)pSrcA[i+1] * pSrcB[i+1]) >> 33; + mul3 = ((q63_t)pSrcA[i] * pSrcB[i+1]) >> 33; + mul4 = ((q63_t)pSrcA[i+1] * pSrcB[i]) >> 33; + pDst[i] = mul1 - mul2; + pDst[i+1] = mul3 + mul4; + } +} + +void ref_cmplx_mult_cmplx_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t numSamples) +{ + uint32_t i; + q31_t mul1, mul2, mul3, mul4; + + for(i=0;i> 17; + mul2 = ((q31_t)pSrcA[i+1] * pSrcB[i+1]) >> 17; + mul3 = ((q31_t)pSrcA[i] * pSrcB[i+1]) >> 17; + mul4 = ((q31_t)pSrcA[i+1] * pSrcB[i]) >> 17; + pDst[i] = mul1 - mul2; + pDst[i+1] = mul3 + mul4; + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_real.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_real.c new file mode 100644 index 0000000..dc4928e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ComplexMathFunctions/cmplx_mult_real.c @@ -0,0 +1,52 @@ +#include "ref.h" + +void ref_cmplx_mult_real_f32( + float32_t * pSrcCmplx, + float32_t * pSrcReal, + float32_t * pCmplxDst, + uint32_t numSamples) +{ + uint32_t i; + + for(i=0;i> 32; + tempI = ((q63_t) pSrcCmplx[2*i+1] * pSrcReal[i]) >> 32; + pCmplxDst[2*i+0] = ref_sat_n(tempR, 31) << 1; + pCmplxDst[2*i+1] = ref_sat_n(tempI, 31) << 1; + } +} + +void ref_cmplx_mult_real_q15( + q15_t * pSrcCmplx, + q15_t * pSrcReal, + q15_t * pCmplxDst, + uint32_t numSamples) +{ + uint32_t i; + q31_t tempR, tempI; + + for(i=0;i> 15; + tempI = ((q31_t) pSrcCmplx[2*i+1] * pSrcReal[i]) >> 15; + pCmplxDst[2*i+0] = ref_sat_q15(tempR); + pCmplxDst[2*i+1] = ref_sat_q15(tempI); + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/pid.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/pid.c new file mode 100644 index 0000000..51aa633 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/pid.c @@ -0,0 +1,97 @@ +#include "ref.h" + +float32_t ref_pid_f32( + arm_pid_instance_f32 * S, + float32_t in) +{ + float32_t out; + + /* y[n] = y[n-1] + A0 * x[n] + A1 * x[n-1] + A2 * x[n-2] */ + out = S->state[2] + S->A0 * in + S->A1 * S->state[0] + S->A2 * S->state[1]; + + /* Update state */ + S->state[1] = S->state[0]; + S->state[0] = in; + S->state[2] = out; + + /* return to application */ + return (out); +} + +q31_t ref_pid_q31( + arm_pid_instance_q31 * S, + q31_t in) +{ + q63_t acc; + q31_t out; + + /* acc = A0 * x[n] */ + acc = (q63_t) S->A0 * in; + + /* acc += A1 * x[n-1] */ + acc += (q63_t) S->A1 * S->state[0]; + + /* acc += A2 * x[n-2] */ + acc += (q63_t) S->A2 * S->state[1]; + + /* convert output to 1.31 format to add y[n-1] */ + out = (q31_t) (acc >> 31U); + + /* out += y[n-1] */ + out += S->state[2]; + + /* Update state */ + S->state[1] = S->state[0]; + S->state[0] = in; + S->state[2] = out; + + /* return to application */ + return (out); +} + +q15_t ref_pid_q15( + arm_pid_instance_q15 * S, + q15_t in) +{ + q63_t acc; + q15_t out; + q15_t A1, A2; + +#if defined (ARM_MATH_DSP) + +#ifndef ARM_MATH_BIG_ENDIAN + A2 = S->A1 >> 16; + A1 = (q15_t)S->A1; +#else + A1 = S->A1 >> 16; + A2 = (q15_t)S->A1; +#endif + +#else + + A1 = S->A1; + A2 = S->A2; + +#endif + + /* acc = A0 * x[n] */ + acc = ((q31_t) S->A0) * in; + + /* acc += A1 * x[n-1] + A2 * x[n-2] */ + acc += (q31_t) A1 * S->state[0]; + acc += (q31_t) A2 * S->state[1]; + + /* acc += y[n-1] */ + acc += (q31_t) S->state[2] << 15; + + /* saturate the output */ + out = ref_sat_q15(acc >> 15); + + /* Update state */ + S->state[1] = S->state[0]; + S->state[0] = in; + S->state[2] = out; + + /* return to application */ + return (out); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/sin_cos.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/sin_cos.c new file mode 100644 index 0000000..22c91a0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/ControllerFunctions/sin_cos.c @@ -0,0 +1,21 @@ +#include "ref.h" + +void ref_sin_cos_f32( + float32_t theta, + float32_t * pSinVal, + float32_t * pCosVal) +{ + //theta is given in degrees + *pSinVal = sinf(theta * 6.28318530717959f / 360.0f); + *pCosVal = cosf(theta * 6.28318530717959f / 360.0f); +} + +void ref_sin_cos_q31( + q31_t theta, + q31_t * pSinVal, + q31_t * pCosVal) +{ + //theta is given in the range [-1,1) to represent [-pi,pi) + *pSinVal = (q31_t)(sinf((float32_t)theta * 3.14159265358979f / 2147483648.0f) * 2147483648.0f); + *pCosVal = (q31_t)(cosf((float32_t)theta * 3.14159265358979f / 2147483648.0f) * 2147483648.0f); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/cos.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/cos.c new file mode 100644 index 0000000..ab6c98e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/cos.c @@ -0,0 +1,11 @@ +#include "ref.h" + +q31_t ref_cos_q31(q31_t x) +{ + return (q31_t)(cosf((float32_t)x * 6.28318530717959f / 2147483648.0f) * 2147483648.0f); +} + +q15_t ref_cos_q15(q15_t x) +{ + return (q15_t)(cosf((float32_t)x * 6.28318530717959f / 32768.0f) * 32768.0f); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sin.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sin.c new file mode 100644 index 0000000..3f303a5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sin.c @@ -0,0 +1,11 @@ +#include "ref.h" + +q31_t ref_sin_q31(q31_t x) +{ + return (q31_t)(sinf((float32_t)x * 6.28318530717959f / 2147483648.0f) * 2147483648.0f); +} + +q15_t ref_sin_q15(q15_t x) +{ + return (q15_t)(sinf((float32_t)x * 6.28318530717959f / 32768.0f) * 32768.0f); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sqrt.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sqrt.c new file mode 100644 index 0000000..9dc34af --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FastMathFunctions/sqrt.c @@ -0,0 +1,15 @@ +#include "ref.h" + +arm_status ref_sqrt_q31(q31_t in, q31_t * pOut) +{ + *pOut = (q31_t)(sqrtf((float32_t)in / 2147483648.0f) * 2147483648.0f); + + return ARM_MATH_SUCCESS; +} + +arm_status ref_sqrt_q15(q15_t in, q15_t * pOut) +{ + *pOut = (q15_t)(sqrtf((float32_t)in / 32768.0f) * 32768.0f); + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/biquad.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/biquad.c new file mode 100644 index 0000000..1fe7c54 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/biquad.c @@ -0,0 +1,713 @@ +#include "ref.h" + +void ref_biquad_cascade_df2T_f32( + const arm_biquad_cascade_df2T_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pIn = pSrc; /* source pointer */ + float32_t *pOut = pDst; /* destination pointer */ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float32_t acc; /* accumulator */ + float32_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float32_t Xn; /* temporary input */ + float32_t d1, d2; /* state variables */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* y[n] = b0 * x[n] + d1 */ + acc = (b0 * Xn) + d1; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc; + + /* Every time after the output is computed state should be updated. */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + d1 = (b1 * Xn + a1 * acc) + d2; + + /* d2 = b2 * x[n] + a2 * y[n] */ + d2 = (b2 * Xn) + (a2 * acc); + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1; + *pState++ = d2; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); +} + + +void ref_biquad_cascade_stereo_df2T_f32( + const arm_biquad_cascade_stereo_df2T_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pIn = pSrc; /* source pointer */ + float32_t *pOut = pDst; /* destination pointer */ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float32_t acc1a, acc1b; /* accumulator */ + float32_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float32_t Xn1a, Xn1b; /* temporary input */ + float32_t d1a, d2a, d1b, d2b; /* state variables */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /*Reading the state values */ + d1a = pState[0]; + d2a = pState[1]; + d1b = pState[2]; + d2b = pState[3]; + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn1a = *pIn++; //Channel a + Xn1b = *pIn++; //Channel b + + /* y[n] = b0 * x[n] + d1 */ + acc1a = (b0 * Xn1a) + d1a; + acc1b = (b0 * Xn1b) + d1b; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc1a; + *pOut++ = acc1b; + + /* Every time after the output is computed state should be updated. */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + d1a = ((b1 * Xn1a) + (a1 * acc1a)) + d2a; + d1b = ((b1 * Xn1b) + (a1 * acc1b)) + d2b; + + /* d2 = b2 * x[n] + a2 * y[n] */ + d2a = (b2 * Xn1a) + (a2 * acc1a); + d2b = (b2 * Xn1b) + (a2 * acc1b); + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1a; + *pState++ = d2a; + *pState++ = d1b; + *pState++ = d2b; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +} + +void ref_biquad_cascade_df2T_f64( + const arm_biquad_cascade_df2T_instance_f64 * S, + float64_t * pSrc, + float64_t * pDst, + uint32_t blockSize) +{ + float64_t *pIn = pSrc; /* source pointer */ + float64_t *pOut = pDst; /* destination pointer */ + float64_t *pState = S->pState; /* State pointer */ + float64_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float64_t acc; /* accumulator */ + float64_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float64_t Xn; /* temporary input */ + float64_t d1, d2; /* state variables */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* y[n] = b0 * x[n] + d1 */ + acc = (b0 * Xn) + d1; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc; + + /* Every time after the output is computed state should be updated. */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + d1 = (b1 * Xn + a1 * acc) + d2; + + /* d2 = b2 * x[n] + a2 * y[n] */ + d2 = (b2 * Xn) + (a2 * acc); + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1; + *pState++ = d2; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); +} + +void ref_biquad_cascade_df1_f32( + const arm_biquad_casd_df1_inst_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pIn = pSrc; /* source pointer */ + float32_t *pOut = pDst; /* destination pointer */ + float32_t *pState = S->pState; /* pState pointer */ + float32_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float32_t acc; /* Simulates the accumulator */ + float32_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float32_t Xn1, Xn2, Yn1, Yn2; /* Filter pState variables */ + float32_t Xn; /* temporary input */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the pState values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* The variables acc holds the output value that is computed: + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + acc = (b0 * Xn) + (b1 * Xn1) + (b2 * Xn2) + (a1 * Yn1) + (a2 * Yn2); + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = acc; + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent numStages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset the output pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); +} + +void ref_biquad_cas_df1_32x64_q31( + const arm_biquad_cas_df1_32x64_ins_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pIn = pSrc; /* input pointer initialization */ + q31_t *pOut = pDst; /* output pointer initialization */ + q63_t *pState = S->pState; /* state pointer initialization */ + q31_t *pCoeffs = S->pCoeffs; /* coeff pointer initialization */ + q63_t acc; /* accumulator */ + q31_t Xn1, Xn2; /* Input Filter state variables */ + q63_t Yn1, Yn2; /* Output Filter state variables */ + q31_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q31_t Xn; /* temporary input */ + int32_t shift = (int32_t) S->postShift + 1; /* Shift to be applied to the output */ + uint32_t sample, stage = S->numStages; /* loop counters */ + q31_t acc_l, acc_h; /* temporary output */ + uint32_t uShift = ((uint32_t) S->postShift + 1U); + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + acc = (q63_t)Xn*b0 + (q63_t)Xn1*b1 + (q63_t)Xn2*b2; + /* acc += a1 * y[n-1] */ + acc += mult32x64(Yn1, a1); + /* acc += a2 * y[n-2] */ + acc += mult32x64(Yn2, a2); + + /* Every time after the output is computed state should be updated. */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + + /* The result is converted to 1.63, Yn1 variable is reused */ + Yn1 = acc << shift; + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc_h = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer in 1.31 format. */ + *pOut++ = acc_h; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage output is given as input to the second stage. */ + pIn = pDst; + + /* Reset to destination buffer working pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = (q63_t) Xn1; + *pState++ = (q63_t) Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); +} + +void ref_biquad_cascade_df1_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q63_t acc; /* accumulator */ + uint32_t uShift = ((uint32_t) S->postShift + 1U); + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + q31_t *pIn = pSrc; /* input pointer initialization */ + q31_t *pOut = pDst; /* output pointer initialization */ + q31_t *pState = S->pState; /* pState pointer initialization */ + q31_t *pCoeffs = S->pCoeffs; /* coeff pointer initialization */ + q31_t Xn1, Xn2, Yn1, Yn2; /* Filter state variables */ + q31_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q31_t Xn; /* temporary input */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* The variables acc holds the output value that is computed: + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + acc = (q63_t) b0 *Xn; + + /* acc += b1 * x[n-1] */ + acc += (q63_t) b1 *Xn1; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) b2 *Xn2; + /* acc += a1 * y[n-1] */ + acc += (q63_t) a1 *Yn1; + /* acc += a2 * y[n-2] */ + acc += (q63_t) a2 *Yn2; + + /* The result is converted to 1.31 */ + acc = acc >> lShift; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = (q31_t) acc; + + /* Store the output in the destination buffer. */ + *pOut++ = (q31_t) acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); +} + + +void ref_biquad_cascade_df1_fast_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t acc = 0; /* accumulator */ + q31_t Xn1, Xn2, Yn1, Yn2; /* Filter state variables */ + q31_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q31_t *pIn = pSrc; /* input pointer initialization */ + q31_t *pOut = pDst; /* output pointer initialization */ + q31_t *pState = S->pState; /* pState pointer initialization */ + q31_t *pCoeffs = S->pCoeffs; /* coeff pointer initialization */ + q31_t Xn; /* temporary input */ + int32_t shift = (int32_t) S->postShift + 1; /* Shift to be applied to the output */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + mult_32x32_keep32_R(acc, b0, Xn); + multAcc_32x32_keep32_R(acc, b1, Xn1); + multAcc_32x32_keep32_R(acc, b2, Xn2); + multAcc_32x32_keep32_R(acc, a1, Yn1); + multAcc_32x32_keep32_R(acc, a2, Yn2); + + /* The result is converted to 1.31 */ + acc <<= shift; + + /* Every time after the output is computed state should be updated. */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = acc; + + /* Store the output in the destination buffer. */ + *pOut++ = acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); +} + +void ref_biquad_cascade_df1_fast_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pIn = pSrc; /* Source pointer */ + q15_t *pOut = pDst; /* Destination pointer */ + q15_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q15_t Xn1, Xn2, Yn1, Yn2; /* Filter state variables */ + q15_t Xn; /* temporary input */ + q31_t acc; /* Accumulator */ + int32_t shift = (15 - (int32_t) S->postShift); /* Post shift */ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + uint32_t sample, stage = (uint32_t) S->numStages; /* Stage loop counter */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + pCoeffs++; // skip the 0 coefficient + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + acc = (q31_t)b0*Xn + (q31_t)b1*Xn1 + (q31_t)b2*Xn2 + (q31_t)a1*Yn1 + (q31_t)a2*Yn2; + + /* The result is converted to 1.15 */ + acc = ref_sat_q15(acc >> shift); + + /* Every time after the output is computed state should be updated. */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = (q15_t) acc; + + /* Store the output in the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); +} + +void ref_biquad_cascade_df1_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pIn = pSrc; /* Source pointer */ + q15_t *pOut = pDst; /* Destination pointer */ + q15_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q15_t Xn1, Xn2, Yn1, Yn2; /* Filter state variables */ + q15_t Xn; /* temporary input */ + q63_t acc; /* Accumulator */ + int32_t shift = (15 - (int32_t) S->postShift); /* Post shift */ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + uint32_t sample, stage = (uint32_t) S->numStages; /* Stage loop counter */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + pCoeffs++; // skip the 0 coefficient + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + acc = (q31_t)b0*Xn + (q31_t)b1*Xn1 + (q31_t)b2*Xn2 + (q31_t)a1*Yn1 + (q31_t)a2*Yn2; + + /* The result is converted to 1.15 */ + acc = ref_sat_q15(acc >> shift); + + /* Every time after the output is computed state should be updated. */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = (q15_t) acc; + + /* Store the output in the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/conv.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/conv.c new file mode 100644 index 0000000..dc1b103 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/conv.c @@ -0,0 +1,350 @@ +#include "ref.h" + +void ref_conv_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst) +{ + float32_t sum; /* Accumulator */ + uint32_t i, j; /* loop counters */ + + /* Loop to calculate convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry out MAC operations */ + sum = 0.0f; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += pSrcB[i - j] * pSrcA[j]; + } + } + /* Store the output in the destination buffer */ + pDst[i] = sum; + } +} + +arm_status ref_conv_partial_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + ref_conv_f32(pSrcA,srcALen,pSrcB,srcBLen,pDst); + + return ARM_MATH_SUCCESS; +} + +void ref_conv_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + q63_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q63_t) pSrcA[j] * (pSrcB[i - j]); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q31_t)(sum >> 31U); + } +} + +void ref_conv_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + q31_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum = (q31_t) ((((q63_t)sum << 32) + + ((q63_t)pSrcA[j] * pSrcB[i - j])) >> 32); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q31_t)(sum << 1U); + } +} + +arm_status ref_conv_partial_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + ref_conv_q31(pSrcA,srcALen,pSrcB,srcBLen,pDst); + + return ARM_MATH_SUCCESS; +} + +arm_status ref_conv_partial_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + ref_conv_fast_q31(pSrcA,srcALen,pSrcB,srcBLen,pDst); + + return ARM_MATH_SUCCESS; +} + +void ref_conv_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ + q63_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q31_t)pSrcA[j] * pSrcB[i - j]; + } + } + + /* Store the output in the destination buffer */ + pDst[i] = ref_sat_q15(sum >> 15U); + } +} + +arm_status ref_conv_partial_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2) +{ + q31_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q31_t)pSrcA[j] * pSrcB[i - j]; + } + } + + /* Store the output in the destination buffer */ + pDst[i] = ref_sat_q15(sum >> 15U); + } + + return ARM_MATH_SUCCESS; +} + +void ref_conv_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ + q31_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q31_t)pSrcA[j] * pSrcB[i - j]; + } + } + + /* Store the output in the destination buffer */ + pDst[i] = sum >> 15U; + } +} + +void ref_conv_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2) +{ + q31_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q31_t)pSrcA[j] * pSrcB[i - j]; + } + } + + /* Store the output in the destination buffer */ + pDst[i] = ref_sat_q15(sum >> 15U); + } +} + +arm_status ref_conv_partial_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + ref_conv_q15(pSrcA,srcALen,pSrcB,srcBLen,pDst); + + return ARM_MATH_SUCCESS; +} + +arm_status ref_conv_partial_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + ref_conv_fast_q15(pSrcA,srcALen,pSrcB,srcBLen,pDst); + + return ARM_MATH_SUCCESS; +} + + +void ref_conv_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst) +{ + q31_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < srcALen + srcBLen - 1; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q15_t)pSrcA[j] * pSrcB[i - j]; + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q7_t)ref_sat_q7(sum >> 7); + } +} + +arm_status ref_conv_partial_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + ref_conv_q7(pSrcA,srcALen,pSrcB,srcBLen,pDst); + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/correlate.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/correlate.c new file mode 100644 index 0000000..ff1d95b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/correlate.c @@ -0,0 +1,513 @@ +#include "ref.h" + +void ref_correlate_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst) +{ + float32_t *pIn1 = pSrcA; /* inputA pointer */ + float32_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + float32_t sum; /* Accumulator */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* The algorithm implementation is based on the lengths of the inputs. + * srcB is always made to slide across srcA. + * So srcBLen is always considered as shorter or equal to srcALen + * But CORR(x, y) is reverse of CORR(y, x) + * So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer + * and a variable, inv is set to 1 + * If lengths are not equal then zero pad has to be done to make the two + * inputs of same length. But to improve the performance, we include zeroes + * in the output instead of zero padding either of the the inputs + * If srcALen > srcBLen, (srcALen - srcBLen) zeroes has to included in the + * starting of the output buffer + * If srcALen < srcBLen, (srcALen - srcBLen) zeroes has to included in the + * ending of the output buffer + * Once the zero padding is done the remaining of the output is calcualted + * using convolution but with the shorter signal time shifted. + */ + + /* Calculate the length of the remaining sequence */ + tot = srcALen + srcBLen - 2U; + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + /* Initialise the pointer after zero padding */ + pDst += srcALen - srcBLen; + } + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + srcALen - 1U; + + /* Initialisation of the pointer after zero padding */ + pDst += tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0.0f; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((i - j < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += pIn1[j] * pIn2[-((int32_t)i - j)]; + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = sum; + else + *pDst++ = sum; + } +} + +void ref_correlate_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + q31_t *pIn1 = pSrcA; /* inputA pointer */ + q31_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q63_t sum; /* Accumulators */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate correlation for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to correlation equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q63_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q31_t)(sum >> 31U); + else + *pDst++ = (q31_t)(sum >> 31U); + } +} + +void ref_correlate_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + q31_t *pIn1 = pSrcA; /* inputA pointer */ + q31_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q63_t sum; /* Accumulators */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate correlation for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to correlation equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) pIn1[j] * pIn2[-((int32_t) i - j)])) >> 32); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q31_t)(sum << 1U); + else + *pDst++ = (q31_t)(sum << 1U); + } +} + +void ref_correlate_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ + q15_t *pIn1 = pSrcA; /* inputA pointer */ + q15_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q63_t sum; /* Accumulators */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q31_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q15_t) ref_sat_q15(sum >> 15U); + else + *pDst++ = (q15_t) ref_sat_q15(sum >> 15U); + } +} + +void ref_correlate_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ + q15_t *pIn1 = pSrcA; /* inputA pointer */ + q15_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q63_t sum; /* Accumulators */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q31_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q15_t)(sum >> 15U); + else + *pDst++ = (q15_t)(sum >> 15U); + } +} + +void ref_correlate_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch) +{ + q15_t *pIn1 = pSrcA; /* inputA pointer */ + q15_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q31_t sum; /* Accumulators */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q31_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q15_t) ref_sat_q15(sum >> 15U); + else + *pDst++ = (q15_t) ref_sat_q15(sum >> 15U); + } +} + +void ref_correlate_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst) +{ + q7_t *pIn1 = pSrcA; /* inputA pointer */ + q7_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q31_t sum; /* Accumulator */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q15_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q7_t) __SSAT((sum >> 7U), 8U); + else + *pDst++ = (q7_t) __SSAT((sum >> 7U), 8U); + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir.c new file mode 100644 index 0000000..3e72b87 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir.c @@ -0,0 +1,325 @@ +#include "ref.h" + +void ref_fir_f32( + const arm_fir_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i; /* Loop counters */ + float32_t acc; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + while (blockSize > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0.0f; + + for(i=0;ipState; + + /* Copy data */ + for(i=0;ipState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i; /* Loop counters */ + q63_t acc; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + while (blockSize > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0.0f; + + for(i=0;i> 31); + + /* Advance state pointer by 1 for the next sample */ + pState++; + + blockSize--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the starting of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy data */ + for(i=0;ipState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i; /* Loop counters */ + q31_t acc; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + while (blockSize > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0.0f; + + for(i=0;i> 32); + } + + /* The result is store in the destination buffer. */ + *pDst++ = (q31_t)(acc << 1); + + /* Advance state pointer by 1 for the next sample */ + pState++; + + blockSize--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the starting of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy data */ + for(i=0;ipState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i; /* Loop counters */ + q63_t acc; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + while (blockSize > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0.0f; + + for(i=0;i> 15); + + /* Advance state pointer by 1 for the next sample */ + pState++; + + blockSize--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the starting of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy data */ + for(i=0;ipState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i; /* Loop counters */ + q31_t acc; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + while (blockSize > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0.0f; + + for(i=0;i> 15); + + /* Advance state pointer by 1 for the next sample */ + pState++; + + blockSize--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the starting of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy data */ + for(i=0;ipState; /* State pointer */ + q7_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q7_t *pStateCurnt; /* Points to the current sample of the state */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i; /* Loop counters */ + q31_t acc; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + while (blockSize > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0.0f; + + for(i=0;i> 7); + + /* Advance state pointer by 1 for the next sample */ + pState++; + + blockSize--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the starting of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy data */ + for(i=0;ipState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t sum0; /* Accumulator */ + float32_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, blkCnt; /* Loop counters */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + numTaps - 1U; + + /* Total number of output samples to be computed */ + blkCnt = blockSize / S->M; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0.0f; + + for(i=0;iM; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = sum0; + + /* Decrement the loop counter */ + blkCnt--; + } + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy numTaps number of values */ + i = numTaps - 1U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +void ref_fir_decimate_q31( + const arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + q63_t sum0; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt; /* Loop counters */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + numTaps - 1U; + + /* Total number of output samples to be computed */ + blkCnt = blockSize / S->M; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0; + + for(i=0;iM; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (sum0 >> 31); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = numTaps - 1U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +void ref_fir_decimate_fast_q31( + const arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + q31_t sum0; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt; /* Loop counters */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + numTaps - 1U; + + /* Total number of output samples to be computed */ + blkCnt = blockSize / S->M; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0; + + for(i=0;i> 32); + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (sum0 << 1); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = numTaps - 1U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +void ref_fir_decimate_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + q63_t sum0; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt; /* Loop counters */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + numTaps - 1U; + + /* Total number of output samples to be computed */ + blkCnt = blockSize / S->M; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0; + + for(i=0;iM; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = ref_sat_q15(sum0 >> 15); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = numTaps - 1U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +void ref_fir_decimate_fast_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t x0, c0; /* Temporary variables to hold state and coefficient values */ + q31_t sum0; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt; /* Loop counters */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + numTaps - 1U; + + /* Total number of output samples to be computed */ + blkCnt = blockSize / S->M; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0; + + for(i=0;iM; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = ref_sat_q15(sum0 >> 15); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = numTaps - 1U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_interpolate.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_interpolate.c new file mode 100644 index 0000000..8abb089 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_interpolate.c @@ -0,0 +1,291 @@ +#include "ref.h" + +void ref_fir_interpolate_f32( + const arm_fir_interpolate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + float32_t sum; /* Accumulator */ + uint32_t i, blkCnt; /* Loop counters */ + uint16_t phaseLen = S->phaseLength, tapCnt; /* Length of each polyphase filter component */ + + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + phaseLen - 1; + + /* Total number of intput samples */ + blkCnt = blockSize; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Loop over the Interpolation factor. */ + i = S->L; + + while (i > 0U) + { + /* Set accumulator to zero */ + sum = 0.0f; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + i - 1; + + /* Loop over the polyPhase length */ + tapCnt = phaseLen; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += *ptr1++ * *ptr2; + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = sum; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = phaseLen - 1U; + + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +void ref_fir_interpolate_q31( + const arm_fir_interpolate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + + /* Run the below code for Cortex-M0 */ + + q63_t sum; /* Accumulator */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t i, blkCnt; /* Loop counters */ + uint16_t phaseLen = S->phaseLength, tapCnt; /* Length of each polyphase filter component */ + + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (q31_t)phaseLen - 1; + + /* Total number of intput samples */ + blkCnt = blockSize; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Loop over the Interpolation factor. */ + i = S->L; + + while (i > 0U) + { + /* Set accumulator to zero */ + sum = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + i - 1; + + tapCnt = phaseLen; + + while (tapCnt > 0U) + { + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *ptr1++; + + /* Perform the multiply-accumulate */ + sum += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t)(sum >> 31); + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = phaseLen - 1U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +void ref_fir_interpolate_q15( + const arm_fir_interpolate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + q63_t sum; /* Accumulator */ + q15_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t i, blkCnt, tapCnt; /* Loop counters */ + uint16_t phaseLen = S->phaseLength; /* Length of each polyphase filter component */ + + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + phaseLen - 1; + + /* Total number of intput samples */ + blkCnt = blockSize; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Loop over the Interpolation factor. */ + i = S->L; + + while (i > 0U) + { + /* Set accumulator to zero */ + sum = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + i - 1; + + /* Loop over the polyPhase length */ + tapCnt = (uint32_t)phaseLen; + + while (tapCnt > 0U) + { + /* Read the coefficient */ + c0 = *ptr2; + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *ptr1++; + + /* Perform the multiply-accumulate */ + sum += (q31_t) x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Store the result after converting to 1.15 format in the destination buffer */ + *pDst++ = ref_sat_q15(sum >> 15); + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (uint32_t) phaseLen - 1U; + + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_lattice.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_lattice.c new file mode 100644 index 0000000..6466106 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_lattice.c @@ -0,0 +1,241 @@ +#include "ref.h" + +void ref_fir_lattice_f32( + const arm_fir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *px; /* temporary state pointer */ + float32_t *pk; /* temporary coefficient pointer */ + float32_t fcurr, fnext, gcurr, gnext; /* temporary variables */ + uint32_t numStages = S->numStages; /* Length of the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + pState = &S->pState[0]; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize coeff pointer */ + pk = pCoeffs; + + /* Initialize state pointer */ + px = pState; + + /* read g0(n-1) from state buffer */ + gcurr = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext = fcurr + ((*pk) * gcurr); + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext = (fcurr * (*pk++)) + gcurr; + + /* save f0(n) in state buffer */ + *px++ = fcurr; + + /* f1(n) is saved in fcurr + for next stage processing */ + fcurr = fnext; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g2(n) from state buffer */ + gcurr = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext = fcurr + ((*pk) * gcurr); + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext = (fcurr * (*pk++)) + gcurr; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr = fnext; + + stageCnt--; + } + + /* y(n) = fN(n) */ + *pDst++ = fcurr; + + blkCnt--; + } +} + +void ref_fir_lattice_q31( + const arm_fir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *px; /* temporary state pointer */ + q31_t *pk; /* temporary coefficient pointer */ + q31_t fcurr, fnext, gcurr, gnext; /* temporary variables */ + uint32_t numStages = S->numStages; /* Length of the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + pState = &S->pState[0]; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize coeff pointer */ + pk = pCoeffs; + + /* Initialize state pointer */ + px = pState; + + /* read g0(n-1) from state buffer */ + gcurr = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext = (q31_t) (((q63_t) gcurr * (*pk)) >> 31) + fcurr; + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext = (q31_t) (((q63_t) fcurr * (*pk++)) >> 31) + gcurr; + /* save g1(n) in state buffer */ + *px++ = fcurr; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr = fnext; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g2(n) from state buffer */ + gcurr = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext = (q31_t) (((q63_t) gcurr * (*pk)) >> 31) + fcurr; + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext = (q31_t) (((q63_t) fcurr * (*pk++)) >> 31) + gcurr; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr = fnext; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = fcurr; + + blkCnt--; + + } +} + +void ref_fir_lattice_q15( + const arm_fir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *px; /* temporary state pointer */ + q15_t *pk; /* temporary coefficient pointer */ + q31_t fcurnt, fnext, gcurnt, gnext; /* temporary variables */ + uint32_t numStages = S->numStages; /* Length of the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + pState = &S->pState[0]; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurnt = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* read g0(n-1) from state buffer */ + gcurnt = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext = ((gcurnt * (*pk)) >> 15U) + fcurnt; + fnext = ref_sat_q15(fnext); + + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext = ((fcurnt * (*pk++)) >> 15U) + gcurnt; + gnext = ref_sat_q15(gnext); + + /* save f0(n) in state buffer */ + *px++ = (q15_t) fcurnt; + + /* f1(n) is saved in fcurnt + for next stage processing */ + fcurnt = fnext; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g1(n-1) from state buffer */ + gcurnt = *px; + + /* save g0(n-1) in state buffer */ + *px++ = (q15_t) gnext; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext = ((gcurnt * (*pk)) >> 15U) + fcurnt; + fnext = ref_sat_q15(fnext); + + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext = ((fcurnt * (*pk++)) >> 15U) + gcurnt; + gnext = ref_sat_q15(gnext); + + + /* f1(n) is saved in fcurnt + for next stage processing */ + fcurnt = fnext; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = ref_sat_q15(fcurnt); + + + blkCnt--; + + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_sparse.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_sparse.c new file mode 100644 index 0000000..0638313 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/fir_sparse.c @@ -0,0 +1,485 @@ +#include "ref.h" + +void ref_fir_sparse_f32( + arm_fir_sparse_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + float32_t * pScratchIn, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *px; /* Scratch buffer pointer */ + float32_t *py = pState; /* Temporary pointers for state buffer */ + float32_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + float32_t *pOut; /* Destination pointer */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + float32_t coeff = *pCoeffs++; /* Read the first coefficient value */ + + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_f32((int32_t *) py, delaySize, &S->stateIndex, 1, + (int32_t *) pSrc, 1, blockSize); + + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer */ + px = pb; + + /* Working pointer for destination buffer */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in destination buffer */ + *pOut++ = *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 1U; + + while (tapCnt > 0U) + { + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer */ + px = pb; + + /* Working pointer for destination buffer */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pOut++ += *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } +} + +void ref_fir_sparse_q31( + arm_fir_sparse_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + q31_t * pScratchIn, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *px; /* Scratch buffer pointer */ + q31_t *py = pState; /* Temporary pointers for state buffer */ + q31_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + q31_t *pOut; /* Destination pointer */ + q63_t out; /* Temporary output variable */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Filter order */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + q31_t coeff = *pCoeffs++; /* Read the first coefficient value */ + q31_t in; + + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_f32((int32_t *) py, delaySize, &S->stateIndex, 1, + (int32_t *) pSrc, 1, blockSize); + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (int32_t) (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in the destination buffer */ + *pOut++ = (q31_t) (((q63_t) * px++ * coeff) >> 32); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 1U; + + while (tapCnt > 0U) + { + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (int32_t) (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Working output pointer is updated */ + pOut = pDst; + + /* Output is converted into 1.31 format. */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + in = *pOut << 1; + *pOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +void ref_fir_sparse_q15( + arm_fir_sparse_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + q15_t * pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pIn = pSrc; /* Working pointer for input */ + q15_t *pOut = pDst; /* Working pointer for output */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *px; /* Temporary pointers for scratch buffer */ + q15_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + q15_t *py = pState; /* Temporary pointers for state buffer */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Filter order */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + q15_t coeff = *pCoeffs++; /* Read the first coefficient value */ + q31_t *pScr2 = pScratchOut; /* Working pointer for pScratchOut */ + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_q15(py, delaySize, &S->stateIndex, 1, pIn, 1, blockSize); + + /* Loop over the number of taps. */ + tapCnt = numTaps; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 1U; + + while (tapCnt > 0U) + { + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pScratchOut++ += (q31_t) * px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* All the output values are in pScratchOut buffer. + Convert them into 1.15 format, saturate and store in the destination buffer. */ + /* Loop over the blockSize. */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + *pOut++ = (q15_t) __SSAT(*pScr2++ >> 15, 16); + blkCnt--; + } +} + +void ref_fir_sparse_q7( + arm_fir_sparse_instance_q7 * S, + q7_t *pSrc, + q7_t *pDst, + q7_t *pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize) +{ + q7_t *pState = S->pState; /* State pointer */ + q7_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q7_t *px; /* Scratch buffer pointer */ + q7_t *py = pState; /* Temporary pointers for state buffer */ + q7_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + q7_t *pOut = pDst; /* Destination pointer */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Filter order */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + q7_t coeff = *pCoeffs++; /* Read the coefficient value */ + q31_t *pScr2 = pScratchOut; /* Working pointer for scratch buffer of output values */ + q31_t in; + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_q7(py, (int32_t) delaySize, &S->stateIndex, 1, pSrc, 1, + blockSize); + + /* Loop over the number of taps. */ + tapCnt = numTaps; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 1U; + + while (tapCnt > 0U) + { + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* All the output values are in pScratchOut buffer. + Convert them into 1.15 format, saturate and store in the destination buffer. */ + /* Loop over the blockSize. */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + *pOut++ = (q7_t) __SSAT(*pScr2++ >> 7, 8); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/iir_lattice.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/iir_lattice.c new file mode 100644 index 0000000..ab37d5f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/iir_lattice.c @@ -0,0 +1,271 @@ +#include "ref.h" + +void ref_iir_lattice_f32( + const arm_iir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t fcurr, fnext = 0, gcurr, gnext; /* Temporary variables for lattice stages */ + float32_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* temporary variables for counts */ + float32_t *px1, *px2, *pk, *pv; /* temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + float32_t *pState; /* State pointer */ + float32_t *pStateCurnt; /* State current pointer */ + + blkCnt = blockSize; + pState = &S->pState[0]; + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0.0f; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + /* Process sample for numStages */ + tapCnt = numStages; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample for last taps */ + fnext = fcurr - (*pk) * gcurr; + gnext = fnext * (*pk++) + gcurr; + + /* Output samples for last taps */ + acc += gnext * (*pv++); + *px2++ = gnext; + fcurr = fnext; + + /* Decrementing loop counter */ + tapCnt--; + } + + /* y(n) += g0(n) * v0 */ + acc += fnext * (*pv); + + *px2++ = fnext; + + /* write out into pDst */ + *pDst++ = acc; + + /* Advance the state pointer by 1 to process the next group of samples */ + pState = pState + 1U; + blkCnt--; + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + tapCnt = numStages; + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +void ref_iir_lattice_q31( + const arm_iir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t fcurr, fnext = 0, gcurr = 0, gnext; /* Temporary variables for lattice stages */ + q63_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* Temporary variables for counts */ + q31_t *px1, *px2, *pk, *pv; /* Temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + q31_t *pState; /* State pointer */ + q31_t *pStateCurnt; /* State current pointer */ + + blkCnt = blockSize; + pState = &S->pState[0]; + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + tapCnt = numStages; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample */ + /* fN-1(n) = fN(n) - kN * gN-1(n-1) */ + fnext = + ref_sat_q31(((q63_t) fcurr - + ((q31_t) (((q63_t) gcurr * (*pk)) >> 31)))); + /* gN(n) = kN * fN-1(n) + gN-1(n-1) */ + gnext = + ref_sat_q31(((q63_t) gcurr + + ((q31_t) (((q63_t) fnext * (*pk++)) >> 31)))); + /* Output samples */ + /* y(n) += gN(n) * vN */ + acc += ((q63_t) gnext * *pv++); + /* write gN-1(n-1) into state for next sample processing */ + *px2++ = gnext; + /* Update f values for next coefficient processing */ + fcurr = fnext; + + tapCnt--; + } + + /* y(n) += g0(n) * v0 */ + acc += (q63_t) fnext *(*pv++); + + *px2++ = fnext; + + /* write out into pDst */ + *pDst++ = (q31_t) (acc >> 31U); + + /* Advance the state pointer by 1 to process the next group of samples */ + pState = pState + 1U; + blkCnt--; + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + tapCnt = numStages; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +void ref_iir_lattice_q15( + const arm_iir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q31_t fcurr, fnext = 0, gcurr = 0, gnext; /* Temporary variables for lattice stages */ + uint32_t stgCnt; /* Temporary variables for counts */ + q63_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* Temporary variables for counts */ + q15_t *px1, *px2, *pk, *pv; /* temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + q15_t *pState; /* State pointer */ + q15_t *pStateCurnt; /* State current pointer */ + q15_t out; /* Temporary variable for output */ + + blkCnt = blockSize; + pState = &S->pState[0]; + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + tapCnt = numStages; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample */ + /* fN-1(n) = fN(n) - kN * gN-1(n-1) */ + fnext = fcurr - ((gcurr * (*pk)) >> 15); + fnext = ref_sat_q15(fnext); + /* gN(n) = kN * fN-1(n) + gN-1(n-1) */ + gnext = ((fnext * (*pk++)) >> 15) + gcurr; + gnext = ref_sat_q15(gnext); + /* Output samples */ + /* y(n) += gN(n) * vN */ + acc += (q31_t) ((gnext * (*pv++))); + /* write gN(n) into state for next sample processing */ + *px2++ = (q15_t) gnext; + /* Update f values for next coefficient processing */ + fcurr = fnext; + + tapCnt--; + } + + /* y(n) += g0(n) * v0 */ + acc += (q31_t) ((fnext * (*pv++))); + + out = ref_sat_q15(acc >> 15); + *px2++ = (q15_t) fnext; + + /* write out into pDst */ + *pDst++ = out; + + /* Advance the state pointer by 1 to process the next group of samples */ + pState = pState + 1U; + blkCnt--; + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + stgCnt = numStages; + + /* copy data */ + while (stgCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + stgCnt--; + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/lms.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/lms.c new file mode 100644 index 0000000..fee99f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/FilteringFunctions/lms.c @@ -0,0 +1,695 @@ +#include "ref.h" + +void ref_lms_f32( + const arm_lms_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, blkCnt; /* Loop counters */ + float32_t sum, e, d; /* accumulator, error, reference data sample */ + float32_t w = 0.0f; /* weight factor */ + + e = 0.0f; + d = 0.0f; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[numTaps - 1U]); + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + sum = 0.0f; + + for(i=0;ipState[i] = pState[i]; + } +} + +void ref_lms_norm_f32( + arm_lms_norm_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, blkCnt; /* Loop counters */ + float32_t energy; /* Energy of the input */ + float32_t sum, e, d; /* accumulator, error, reference data sample */ + float32_t w, x0, in; /* weight factor, temporary variable to hold input sample and state */ + + /* Initializations of error, difference, Coefficient update */ + e = 0.0f; + d = 0.0f; + w = 0.0f; + + energy = S->energy; + x0 = S->x0; + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[numTaps - 1U]); + + for(blkCnt = blockSize; blkCnt > 0U; blkCnt--) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy -= x0 * x0; + energy += in * in; + + /* Set the accumulator to zero */ + sum = 0.0f; + + for(i=0;ienergy = energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + * start of the state buffer. This prepares the state buffer for the + * next function call. */ + for(i=0;ipState[i] = pState[i]; + } +} + +void ref_lms_q31( + const arm_lms_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t mu = S->mu; /* Adaptive factor */ + q31_t *px; /* Temporary pointer for state */ + q31_t *pb; /* Temporary pointer for coefficient buffer */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q63_t acc; /* Accumulator */ + q31_t e = 0; /* error of data sample */ + q31_t alpha; /* Intermediate constant for taps update */ + q31_t coef; /* Temporary variable for coef */ + q31_t acc_l, acc_h; /* temporary input */ + uint32_t uShift = (uint32_t)S->postShift + 1; + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + for(blkCnt = blockSize; blkCnt > 0U; blkCnt--) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += (q63_t)(*px++) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Converting the result to 1.31 format */ + /* Store the result from accumulator into the destination buffer. */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + acc = (uint32_t)acc_l >> lShift | acc_h << uShift; + + *pOut++ = (q31_t)acc; + + /* Compute and store error */ + e = *pRef++ - (q31_t)acc; + + *pErr++ = (q31_t)e; + + /* Weighting factor for the LMS version */ + alpha = (q31_t)(((q63_t)e * mu) >> 31); + + /* Initialize pState pointer */ + /* Advance state pointer by 1 for the next sample */ + px = pState++; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = (q31_t)(((q63_t) alpha * (*px++)) >> 32); + *pb = ref_sat_q31((q63_t)*pb + (coef << 1)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + } + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + start of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Copy (numTaps - 1U) samples */ + tapCnt = numTaps - 1; + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +void ref_lms_norm_q31( + arm_lms_norm_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + q31_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q63_t energy; /* Energy of the input */ + q63_t acc; /* Accumulator */ + q31_t e = 0, d = 0; /* error, reference data sample */ + q31_t w = 0, in; /* weight factor and state */ + q31_t x0; /* temporary variable to hold input sample */ + q63_t errorXmu; /* Temporary variables to store error and mu product and reciprocal of energy */ + q31_t coef; /* Temporary variable for coef */ + q31_t acc_l, acc_h; /* temporary input */ + uint32_t uShift = ((uint32_t) S->postShift + 1U); + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + + energy = S->energy; + x0 = S->x0; + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + for(blkCnt = blockSize; blkCnt > 0U; blkCnt--) + { + + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy = (q31_t)((((q63_t)energy << 32) - (((q63_t)x0 * x0) << 1)) >> 32) & 0xffffffff; + energy = (q31_t)(((((q63_t)in * in) << 1) + ((q63_t)energy << 32)) >> 32) & 0xffffffff; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Converting the result to 1.31 format */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + acc = (uint32_t)acc_l >> lShift | acc_h << uShift; + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q31_t)acc; + + /* Compute and store error */ + d = *pRef++; + e = d - (q31_t)acc; + *pErr++ = e; + + /* Calculation of product of (e * mu) */ + errorXmu = (q63_t)e * mu; + + /* Weighting factor for the normalized version */ + w = ref_sat_q31(errorXmu / (energy + DELTA_Q31)); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + /* coef is in 2.30 format */ + coef = (q31_t)(((q63_t)w * (*px++)) >> 32); + /* get coef in 1.31 format by left shifting */ + *pb = ref_sat_q31((q63_t)*pb + (coef << 1U)); + /* update coefficient buffer to next coefficient */ + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Read the sample from state buffer */ + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState++; + } + + /* Save energy and x0 values for the next frame */ + S->energy = (q31_t)energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + start of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Loop for (numTaps - 1U) samples copy */ + tapCnt = numTaps - 1; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +void ref_lms_q15( + const arm_lms_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t mu = S->mu; /* Adaptive factor */ + q15_t *px; /* Temporary pointer for state */ + q15_t *pb; /* Temporary pointer for coefficient buffer */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q63_t acc; /* Accumulator */ + q15_t e = 0; /* error of data sample */ + q15_t alpha; /* Intermediate constant for taps update */ + q31_t coef; /* Teporary variable for coefficient */ + q31_t acc_l, acc_h; + int32_t lShift = 15 - (int32_t)S->postShift; /* Post shift */ + int32_t uShift = 32 - lShift; + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + for(blkCnt = blockSize; blkCnt > 0U; blkCnt--) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += (q63_t)((q31_t)(*px++) * (*pb++)); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc = (uint32_t)acc_l >> lShift | acc_h << uShift; + + /* Converting the result to 1.15 format and saturate the output */ + acc = ref_sat_q15(acc); + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q15_t)acc; + + /* Compute and store error */ + e = *pRef++ - (q15_t)acc; + + *pErr++ = (q15_t)e; + + /* Compute alpha i.e. intermediate constant for taps update */ + alpha = (q15_t)(((q31_t)e * mu) >> 15); + + /* Initialize pState pointer */ + /* Advance state pointer by 1 for the next sample */ + px = pState++; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = (q31_t) * pb + (((q31_t) alpha * (*px++)) >> 15); + *pb++ = (q15_t) ref_sat_q15(coef); + + /* Decrement the loop counter */ + tapCnt--; + } + } + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + start of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Copy (numTaps - 1U) samples */ + tapCnt = numTaps - 1; + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +void ref_lms_norm_q15( + arm_lms_norm_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + q15_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q31_t energy; /* Energy of the input */ + q63_t acc; /* Accumulator */ + q15_t e = 0, d = 0; /* error, reference data sample */ + q15_t w = 0, in; /* weight factor and state */ + q15_t x0; /* temporary variable to hold input sample */ + q15_t errorXmu, oneByEnergy; /* Temporary variables to store error and mu product and reciprocal of energy */ + //q31_t errorXmu; /* Temporary variables to store error and mu product and reciprocal of energy */ + q15_t postShift; /* Post shift to be applied to weight after reciprocal calculation */ + q31_t coef; /* Teporary variable for coefficient */ + q31_t acc_l, acc_h; + int32_t lShift = 15 - (int32_t)S->postShift; /* Post shift */ + int32_t uShift = 32 - lShift; + + energy = S->energy; + x0 = S->x0; + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + for(blkCnt = blockSize; blkCnt > 0U; blkCnt--) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy -= (((q31_t)x0 * x0) >> 15) & 0xffff; + energy += (((q31_t)in * in) >> 15) & 0xffff; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += (q31_t)*px++ * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Converting the result to 1.15 format and saturate the output */ + acc = ref_sat_q15(acc); + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* Compute and store error */ + d = *pRef++; + e = d - (q15_t) acc; + *pErr++ = e; + +#if 0 + /* Calculation of e * mu value */ + errorXmu = (q31_t) e * mu; + + /* Calculation of (e * mu) /energy value */ + acc = errorXmu / (energy + DELTA_Q15); +#endif + + /* Calculation of 1/energy */ + postShift = arm_recip_q15((q15_t) energy + DELTA_Q15, + &oneByEnergy, S->recipTable); + + /* Calculation of e * mu value */ + errorXmu = (q15_t) (((q31_t) e * mu) >> 15); + + /* Calculation of (e * mu) * (1/energy) value */ + acc = (((q31_t) errorXmu * oneByEnergy) >> (15 - postShift)); + + /* Weighting factor for the normalized version */ + w = ref_sat_q15((q31_t)acc); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = *pb + (((q31_t)w * (*px++)) >> 15); + *pb++ = ref_sat_q15(coef); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Read the sample from state buffer */ + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1U; + } + + /* Save energy and x0 values for the next frame */ + S->energy = (q15_t)energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* copy (numTaps - 1U) data */ + tapCnt = numTaps - 1; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/mat_helper.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/mat_helper.c new file mode 100644 index 0000000..0174ccf --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/mat_helper.c @@ -0,0 +1,193 @@ +#include "ref.h" + +float32_t ref_detrm(float32_t *pSrc, float32_t *temp, uint32_t size) +{ + float32_t s = 1, det = 0; + int i, j, m, n, c; + + if ( size == 1 ) + { + return ( pSrc[ 0 ] ); + } + else + { + det = 0; + + for ( c = 0;c < size;c++ ) + { + m = 0; + n = 0; + + for ( i = 0;i < size;i++ ) + { + for ( j = 0;j < size;j++ ) + { + temp[ i*size + j ] = 0; + + if ( i != 0 && j != c ) + { + temp[ m*(size-1) + n ] = pSrc[ i*size + j ]; + + if ( n < ( size - 2 ) ) + { + n++; + } + else + { + n = 0; + m++; + } + } + } + } + + det += s * ( pSrc[ c ] * ref_detrm( temp, temp + size*size, size - 1 ) ); + s = -s; + } + } + + return ( det ); +} + + +void ref_cofact(float32_t *pSrc, float32_t *pDst, float32_t *temp, uint32_t size) +{ + int p, q, m, n, i, j; + + if (size == 1) + { + pDst[0] = 1; + return; + } + + for ( q = 0;q < size;q++ ) + { + for ( p = 0;p < size;p++ ) + { + m = 0; + n = 0; + + for ( i = 0;i < size;i++ ) + { + for ( j = 0;j < size;j++ ) + { + temp[ i*size + j ] = 0; + + if ( i != q && j != p ) + { + temp[ m*(size-1) + n ] = pSrc[ i*size + j ]; + + if ( n < ( size - 2 ) ) + { + n++; + } + else + { + n = 0; + m++; + } + } + } + } + + pDst[ q*size + p ] = ref_pow( -1, q + p ) * ref_detrm( temp, temp + (size-1)*(size-1), size - 1 ); + } + } +} + + + +float64_t ref_detrm64(float64_t *pSrc, float64_t *temp, uint32_t size) +{ + float64_t s = 1, det = 0; + int i, j, m, n, c; + + if ( size == 1 ) + { + return ( pSrc[ 0 ] ); + } + else + { + det = 0; + + for ( c = 0;c < size;c++ ) + { + m = 0; + n = 0; + + for ( i = 0;i < size;i++ ) + { + for ( j = 0;j < size;j++ ) + { + temp[ i*size + j ] = 0; + + if ( i != 0 && j != c ) + { + temp[ m*(size-1) + n ] = pSrc[ i*size + j ]; + + if ( n < ( size - 2 ) ) + { + n++; + } + else + { + n = 0; + m++; + } + } + } + } + + det += s * ( pSrc[ c ] * ref_detrm64( temp, temp + size*size, size - 1 ) ); + s = -s; + } + } + + return ( det ); +} + + +void ref_cofact64(float64_t *pSrc, float64_t *pDst, float64_t *temp, uint32_t size) +{ + int p, q, m, n, i, j; + + if (size == 1) + { + pDst[0] = 1; + return; + } + + for ( q = 0;q < size;q++ ) + { + for ( p = 0;p < size;p++ ) + { + m = 0; + n = 0; + + for ( i = 0;i < size;i++ ) + { + for ( j = 0;j < size;j++ ) + { + temp[ i*size + j ] = 0; + + if ( i != q && j != p ) + { + temp[ m*(size-1) + n ] = pSrc[ i*size + j ]; + + if ( n < ( size - 2 ) ) + { + n++; + } + else + { + n = 0; + m++; + } + } + } + } + + pDst[ q*size + p ] = ref_pow( -1, q + p ) * ref_detrm64( temp, temp + (size-1)*(size-1), size - 1 ); + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/ref_helper.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/ref_helper.c new file mode 100644 index 0000000..57ecf1b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/HelperFunctions/ref_helper.c @@ -0,0 +1,103 @@ +#include "ref.h" + +float32_t scratchArray[8192*2]; + +arm_cfft_instance_f32 ref_cfft_sR_f32_len8192 = { 8192, 0, 0, 0 }; + +q31_t ref_sat_n(q31_t num, uint32_t bits) +{ + int32_t posMax, negMin; + uint32_t i; + + posMax = 1; + for (i = 0; i < (bits - 1); i++) + { + posMax = posMax * 2; + } + + if (num > 0) + { + posMax = (posMax - 1); + + if (num > posMax) + { + num = posMax; + } + } + else + { + negMin = -posMax; + + if (num < negMin) + { + num = negMin; + } + } + return (num); +} + +q31_t ref_sat_q31(q63_t num) +{ + if (num > (q63_t)INT_MAX) + { + return INT_MAX; + } + else if (num < (q63_t)0xffffffff80000000ll) + { + return INT_MIN; + } + else + { + return (q31_t)num; + } +} + +q15_t ref_sat_q15(q31_t num) +{ + if (num > (q31_t)SHRT_MAX) + { + return SHRT_MAX; + } + else if (num < (q31_t)0xffff8000) + { + return SHRT_MIN; + } + else + { + return (q15_t)num; + } +} + +q7_t ref_sat_q7(q15_t num) +{ + if (num > (q15_t)SCHAR_MAX) + { + return SCHAR_MAX; + } + else if (num < (q15_t)0xff80) + { + return SCHAR_MIN; + } + else + { + return (q7_t)num; + } +} + +float32_t ref_pow(float32_t a, uint32_t b) +{ + uint32_t i; + float32_t r = a; + + for(i=1;i> 24) + ((y << 16) >> 24))), 8); + t = ref_sat_n(((q31_t) (((x << 8) >> 24) + ((y << 8) >> 24))), 8); + u = ref_sat_n(((q31_t) ((x >> 24) + (y >> 24))), 8); + + sum = + (((q31_t) u << 24) & 0xFF000000) | (((q31_t) t << 16) & 0x00FF0000) | + (((q31_t) s << 8) & 0x0000FF00) | (r & 0x000000FF); + + return sum; + +} + +q31_t ref__QSUB8(q31_t x, q31_t y) +{ + q31_t sum; + q31_t r, s, t, u; + + r = (q7_t) x; + s = (q7_t) y; + + r = ref_sat_n((r - s), 8); + s = ref_sat_n(((q31_t) (((x << 16) >> 24) - ((y << 16) >> 24))), 8) << 8; + t = ref_sat_n(((q31_t) (((x << 8) >> 24) - ((y << 8) >> 24))), 8) << 16; + u = ref_sat_n(((q31_t) ((x >> 24) - (y >> 24))), 8) << 24; + + sum = (u & 0xFF000000) | (t & 0x00FF0000) | (s & 0x0000FF00) | (r & 0x000000FF); + + return sum; +} + +q31_t ref__QADD16(q31_t x, q31_t y) +{ + q31_t sum; + q31_t r, s; + + r = (q15_t) x; + s = (q15_t) y; + + r = ref_sat_q15(r + s); + s = (q31_t)ref_sat_q15(((q31_t) ((x >> 16) + (y >> 16)))) << 16; + + sum = (s & 0xFFFF0000) | (r & 0x0000FFFF); + + return sum; + +} + +q31_t ref__SHADD16(q31_t x, q31_t y) +{ + q31_t sum; + q31_t r, s; + + r = (q15_t) x; + s = (q15_t) y; + + r = (r + s) >> 1; + s = ((q31_t) (((x >> 16) + (y >> 16)) >> 1) << 16); + + sum = (s & 0xFFFF0000) | (r & 0x0000FFFF); + + return sum; + +} + +q31_t ref__QSUB16(q31_t x, q31_t y) +{ + q31_t sum; + q31_t r, s; + + r = (q15_t) x; + s = (q15_t) y; + + r = ref_sat_q15(r - s); + s = (q31_t)ref_sat_q15(((q31_t) ((x >> 16) - (y >> 16)))) << 16; + + sum = (s & 0xFFFF0000) | (r & 0x0000FFFF); + + return sum; +} + +q31_t ref__SHSUB16(q31_t x, q31_t y) +{ + q31_t diff; + q31_t r, s; + + r = (q15_t) x; + s = (q15_t) y; + + r = ((r >> 1) - (s >> 1)); + s = (((x >> 17) - (y >> 17)) << 16); + + diff = (s & 0xFFFF0000) | (r & 0x0000FFFF); + + return diff; +} + +q31_t ref__QASX(q31_t x, q31_t y) +{ + q31_t sum = 0; + q31_t xL, xH, yL, yH; + + // extract bottom halfword and sign extend + xL = (q15_t)(x & 0xffff); + // extract bottom halfword and sign extend + yL = (q15_t)(y & 0xffff); + // extract top halfword and sign extend + xH = (q15_t)(x >> 16); + // extract top halfword and sign extend + yH = (q15_t)(y >> 16); + + sum = (((q31_t)ref_sat_q15(xH + yL )) << 16) | + (((q31_t)ref_sat_q15(xL - yH )) & 0xffff); + + return sum; +} + +q31_t ref__SHASX(q31_t x, q31_t y) +{ + q31_t sum; + q31_t r, s; + + r = (q15_t) x; + s = (q15_t) y; + + r = (r - (y >> 16)) / 2; + s = (((x >> 16) + s) << 15); + + sum = (s & 0xFFFF0000) | (r & 0x0000FFFF); + + return sum; +} + +q31_t ref__QSAX(q31_t x, q31_t y) +{ + q31_t sum = 0; + q31_t xL, xH, yL, yH; + + // extract bottom halfword and sign extend + xL = (q15_t)(x & 0xffff); + // extract bottom halfword and sign extend + yL = (q15_t)(y & 0xffff); + // extract top halfword and sign extend + xH = (q15_t)(x >> 16); + // extract top halfword and sign extend + yH = (q15_t)(y >> 16); + + sum = (((q31_t)ref_sat_q15(xH - yL )) << 16) | + (((q31_t)ref_sat_q15(xL + yH )) & 0xffff); + + return sum; +} + +q31_t ref__SHSAX(q31_t x, q31_t y) +{ + q31_t sum; + q31_t r, s; + + r = (q15_t) x; + s = (q15_t) y; + + r = (r + (y >> 16)) / 2; + s = (((x >> 16) - s) << 15); + + sum = (s & 0xFFFF0000) | (r & 0x0000FFFF); + + return sum; +} + +q31_t ref__SMUSDX(q31_t x, q31_t y) +{ + return ((q31_t) (((q15_t) x * (q15_t) (y >> 16)) - ((q15_t) (x >> 16) * (q15_t) y))); +} + +q31_t ref__SMUADX(q31_t x, q31_t y) +{ + return ((q31_t) (((q15_t) x * (q15_t) (y >> 16)) + ((q15_t) (x >> 16) * (q15_t) y))); +} + +q31_t ref__QADD(q31_t x, q31_t y) +{ + return ref_sat_q31((q63_t) x + y); +} + +q31_t ref__QSUB(q31_t x, q31_t y) +{ + return ref_sat_q31((q63_t) x - y); +} + +q31_t ref__SMLAD(q31_t x, q31_t y, q31_t sum) +{ + return (sum + ((q15_t) (x >> 16) * (q15_t) (y >> 16)) + ((q15_t) x * (q15_t) y)); +} + +q31_t ref__SMLADX(q31_t x, q31_t y, q31_t sum) +{ + return (sum + ((q15_t) (x >> 16) * (q15_t) (y)) + ((q15_t) x * (q15_t) (y >> 16))); +} + +q31_t ref__SMLSDX(q31_t x, q31_t y, q31_t sum) +{ + return (sum - ((q15_t) (x >> 16) * (q15_t) (y)) + ((q15_t) x * (q15_t) (y >> 16))); +} + +q63_t ref__SMLALD(q31_t x, q31_t y, q63_t sum) +{ + return (sum + ((q15_t) (x >> 16) * (q15_t) (y >> 16)) + ((q15_t) x * (q15_t) y)); +} + +q63_t ref__SMLALDX(q31_t x, q31_t y, q63_t sum) +{ + return (sum + ((q15_t) (x >> 16) * (q15_t) y)) + ((q15_t) x * (q15_t) (y >> 16)); +} + +q31_t ref__SMUAD(q31_t x, q31_t y) +{ + return (((x >> 16) * (y >> 16)) + (((x << 16) >> 16) * ((y << 16) >> 16))); +} + +q31_t ref__SMUSD(q31_t x, q31_t y) +{ + return (-((x >> 16) * (y >> 16)) + (((x << 16) >> 16) * ((y << 16) >> 16))); +} + +q31_t ref__SXTB16(q31_t x) +{ + return ((((x << 24) >> 24) & 0x0000FFFF) | (((x << 8) >> 8) & 0xFFFF0000)); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_add.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_add.c new file mode 100644 index 0000000..a6e0067 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_add.c @@ -0,0 +1,58 @@ +#include "ref.h" + +arm_status ref_mat_add_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + + for(i=0;ipData[i] = pSrcA->pData[i] + pSrcB->pData[i]; + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_add_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + + for(i=0;ipData[i] = ref_sat_q31( (q63_t)pSrcA->pData[i] + pSrcB->pData[i]); + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_add_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + + for(i=0;ipData[i] = ref_sat_q15( (q31_t)pSrcA->pData[i] + pSrcB->pData[i]); + } + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_cmplx_mult.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_cmplx_mult.c new file mode 100644 index 0000000..9364619 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_cmplx_mult.c @@ -0,0 +1,118 @@ +#include "ref.h" + +arm_status ref_mat_cmplx_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + uint32_t r,c,i,outR,outC,innerSize; + float32_t sumR,sumI; + float32_t a0,b0,c0,d0; + + outR = pSrcA->numRows; + outC = pSrcB->numCols; + innerSize = pSrcA->numCols; + + for(r=0;rpData[2*(r*innerSize + i) + 0]; + b0 = pSrcA->pData[2*(r*innerSize + i) + 1]; + c0 = pSrcB->pData[2*(i*outC + c) + 0]; + d0 = pSrcB->pData[2*(i*outC + c) + 1]; + + sumR += a0 * c0 - b0 * d0; + sumI += b0 * c0 + a0 * d0; + } + + pDst->pData[2*(r*outC + c) + 0] = sumR; + pDst->pData[2*(r*outC + c) + 1] = sumI; + } + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_cmplx_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + uint32_t r,c,i,outR,outC,innerSize; + q63_t sumR,sumI; + q31_t a0,b0,c0,d0; + + outR = pSrcA->numRows; + outC = pSrcB->numCols; + innerSize = pSrcA->numCols; + + for(r=0;rpData[2*(r*innerSize + i) + 0]; + b0 = pSrcA->pData[2*(r*innerSize + i) + 1]; + c0 = pSrcB->pData[2*(i*outC + c) + 0]; + d0 = pSrcB->pData[2*(i*outC + c) + 1]; + + sumR += (q63_t)a0 * c0 - (q63_t)b0 * d0; + sumI += (q63_t)b0 * c0 + (q63_t)a0 * d0; + } + + pDst->pData[2*(r*outC + c) + 0] = ref_sat_q31(sumR >> 31); + pDst->pData[2*(r*outC + c) + 1] = ref_sat_q31(sumI >> 31); + } + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_cmplx_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst) +{ + uint32_t r,c,i,outR,outC,innerSize; + q63_t sumR,sumI; + q15_t a0,b0,c0,d0; + + outR = pSrcA->numRows; + outC = pSrcB->numCols; + innerSize = pSrcA->numCols; + + for(r=0;rpData[2*(r*innerSize + i) + 0]; + b0 = pSrcA->pData[2*(r*innerSize + i) + 1]; + c0 = pSrcB->pData[2*(i*outC + c) + 0]; + d0 = pSrcB->pData[2*(i*outC + c) + 1]; + + sumR += (q31_t)a0 * c0 - (q31_t)b0 * d0; + sumI += (q31_t)b0 * c0 + (q31_t)a0 * d0; + } + + pDst->pData[2*(r*outC + c) + 0] = ref_sat_q15(sumR >> 15); + pDst->pData[2*(r*outC + c) + 1] = ref_sat_q15(sumI >> 15); + } + } + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_inverse.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_inverse.c new file mode 100644 index 0000000..74d3ccc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_inverse.c @@ -0,0 +1,57 @@ +#include "ref.h" + +arm_status ref_mat_inverse_f32( + const arm_matrix_instance_f32 * pSrc, + arm_matrix_instance_f32 * pDst) +{ + float32_t det; + uint32_t i, size; + arm_matrix_instance_f32 tmp; + + tmp.numCols = pSrc->numCols; + tmp.numRows = pSrc->numRows; + tmp.pData = scratchArray; + + det = ref_detrm(pSrc->pData,scratchArray,pSrc->numCols); + + size = pSrc->numCols * pSrc->numCols; + + ref_cofact(pSrc->pData,scratchArray,scratchArray + size,pSrc->numCols); + + ref_mat_trans_f32(&tmp,pDst); + + for(i=0;ipData[i] /= det; + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_inverse_f64( + const arm_matrix_instance_f64 * pSrc, + arm_matrix_instance_f64 * pDst) +{ + float64_t det; + uint32_t i, size; + arm_matrix_instance_f64 tmp; + + tmp.numCols = pSrc->numCols; + tmp.numRows = pSrc->numRows; + tmp.pData = (float64_t*)scratchArray; + + det = ref_detrm64(pSrc->pData,(float64_t*)scratchArray,pSrc->numCols); + + size = pSrc->numCols * pSrc->numCols; + + ref_cofact64(pSrc->pData,(float64_t*)scratchArray,(float64_t*)scratchArray + size,pSrc->numCols); + + ref_mat_trans_f64(&tmp,pDst); + + for(i=0;ipData[i] /= det; + } + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_mult.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_mult.c new file mode 100644 index 0000000..e9ef432 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_mult.c @@ -0,0 +1,91 @@ +#include "ref.h" + +arm_status ref_mat_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + uint32_t r,c,i,outR,outC,innerSize; + float32_t sum; + + outR = pSrcA->numRows; + outC = pSrcB->numCols; + innerSize = pSrcA->numCols; + + for(r=0;rpData[r*innerSize + i] * pSrcB->pData[i*outC + c]; + } + + pDst->pData[r*outC + c] = sum; + } + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + uint32_t r,c,i,outR,outC,innerSize; + q63_t sum; + + outR = pSrcA->numRows; + outC = pSrcB->numCols; + innerSize = pSrcA->numCols; + + for(r=0;rpData[r*innerSize + i]) * pSrcB->pData[i*outC + c]; + } + + pDst->pData[r*outC + c] = ref_sat_q31(sum >> 31); + } + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst) +{ + uint32_t r,c,i,outR,outC,innerSize; + q63_t sum; + + outR = pSrcA->numRows; + outC = pSrcB->numCols; + innerSize = pSrcA->numCols; + + for(r=0;rpData[r*innerSize + i]) * pSrcB->pData[i*outC + c]; + } + + pDst->pData[r*outC + c] = ref_sat_q15(sum >> 15); + } + } + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_scale.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_scale.c new file mode 100644 index 0000000..d426ad6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_scale.c @@ -0,0 +1,64 @@ +#include "ref.h" + +arm_status ref_mat_scale_f32( + const arm_matrix_instance_f32 * pSrc, + float32_t scale, + arm_matrix_instance_f32 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrc->numRows * pSrc->numCols; + + for(i=0;ipData[i] = pSrc->pData[i] * scale; + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_scale_q31( + const arm_matrix_instance_q31 * pSrc, + q31_t scale, + int32_t shift, + arm_matrix_instance_q31 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + int32_t totShift = shift + 1; + q31_t tmp; + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrc->numRows * pSrc->numCols; + + for(i=0;ipData[i] * scale) >> 32; + pDst->pData[i] = ref_sat_q31((q63_t)tmp << totShift ); + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_scale_q15( + const arm_matrix_instance_q15 * pSrc, + q15_t scale, + int32_t shift, + arm_matrix_instance_q15 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + int32_t totShift = 15 - shift; + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrc->numRows * pSrc->numCols; + + for(i=0;ipData[i] = ref_sat_q15( ((q31_t)pSrc->pData[i] * scale) >> totShift); + } + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_sub.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_sub.c new file mode 100644 index 0000000..bbd23f0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_sub.c @@ -0,0 +1,58 @@ +#include "ref.h" + +arm_status ref_mat_sub_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + + for(i=0;ipData[i] = pSrcA->pData[i] - pSrcB->pData[i]; + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_sub_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + + for(i=0;ipData[i] = ref_sat_q31( (q63_t)pSrcA->pData[i] - pSrcB->pData[i]); + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_sub_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst) +{ + uint32_t i; + uint32_t numSamples; /* total number of elements in the matrix */ + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + + for(i=0;ipData[i] = ref_sat_q15( (q31_t)pSrcA->pData[i] - pSrcB->pData[i]); + } + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_trans.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_trans.c new file mode 100644 index 0000000..8cb9a8d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/MatrixFunctions/mat_trans.c @@ -0,0 +1,77 @@ +#include "ref.h" + +arm_status ref_mat_trans_f64( + const arm_matrix_instance_f64 * pSrc, + arm_matrix_instance_f64 * pDst) +{ + uint64_t r,c; + uint64_t numR = pSrc->numRows; + uint64_t numC = pSrc->numCols; + + for(r=0;rpData[c*numR + r] = pSrc->pData[r*numC + c]; + } + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_trans_f32( + const arm_matrix_instance_f32 * pSrc, + arm_matrix_instance_f32 * pDst) +{ + uint32_t r,c; + uint32_t numR = pSrc->numRows; + uint32_t numC = pSrc->numCols; + + for(r=0;rpData[c*numR + r] = pSrc->pData[r*numC + c]; + } + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_trans_q31( + const arm_matrix_instance_q31 * pSrc, + arm_matrix_instance_q31 * pDst) +{ + uint32_t r,c; + uint32_t numR = pSrc->numRows; + uint32_t numC = pSrc->numCols; + + for(r=0;rpData[c*numR + r] = pSrc->pData[r*numC + c]; + } + } + + return ARM_MATH_SUCCESS; +} + +arm_status ref_mat_trans_q15( + const arm_matrix_instance_q15 * pSrc, + arm_matrix_instance_q15 * pDst) +{ + uint32_t r,c; + uint32_t numR = pSrc->numRows; + uint32_t numC = pSrc->numCols; + + for(r=0;rpData[c*numR + r] = pSrc->pData[r*numC + c]; + } + } + + return ARM_MATH_SUCCESS; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/max.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/max.c new file mode 100644 index 0000000..02b4127 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/max.c @@ -0,0 +1,85 @@ +#include "ref.h" + +void ref_max_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult, + uint32_t * pIndex) +{ + uint32_t i, ind=0; + float32_t max=-FLT_MAX; + + for(i=0;i pSrc[i]) + { + min = pSrc[i]; + ind = i; + } + } + *pResult = min; + *pIndex = ind; +} + +void ref_min_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult, + uint32_t * pIndex) +{ + uint32_t i, ind=0; + q31_t min=INT_MAX; + + for(i=0;i pSrc[i]) + { + min = pSrc[i]; + ind = i; + } + } + *pResult = min; + *pIndex = ind; +} + +void ref_min_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult, + uint32_t * pIndex) +{ + uint32_t i, ind=0; + q15_t min=SHRT_MAX; + + for(i=0;i pSrc[i]) + { + min = pSrc[i]; + ind = i; + } + } + *pResult = min; + *pIndex = ind; +} + +void ref_min_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult, + uint32_t * pIndex) +{ + uint32_t i, ind=0; + q7_t min=SCHAR_MAX; + + for(i=0;i pSrc[i]) + { + min = pSrc[i]; + ind = i; + } + } + *pResult = min; + *pIndex = ind; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/power.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/power.c new file mode 100644 index 0000000..8202e04 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/power.c @@ -0,0 +1,61 @@ +#include "ref.h" + +void ref_power_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + uint32_t i; + float32_t sumsq=0; + + for(i=0;i> 14; + } + *pResult = sumsq; +} + +void ref_power_q15( + q15_t * pSrc, + uint32_t blockSize, + q63_t * pResult) +{ + uint32_t i; + q63_t sumsq=0; + + for(i=0;i> 31; + tmp2 = ref_sat_q31(tmp1); + + /* GCC M0 problem: __aeabi_f2iz(QNAN) returns not 0 */ + help_float = (sqrtf((float)tmp2 / 2147483648.0f) * 2147483648.0f); + /* Checking for a NAN value in help_float */ + if (((*((int *)(&help_float))) & 0x7FC00000) == 0x7FC00000) { + help_float = 0; + } + *pResult = (q31_t)(help_float); + +// *pResult = (q31_t)(sqrtf((float)tmp2 / 2147483648.0f) * 2147483648.0f); +} + +void ref_rms_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult) +{ + uint32_t i; + q63_t sumsq=0; + q31_t tmp1; + q15_t tmp2; + + for(i=0;i> 15; + tmp2 = ref_sat_q15(tmp1); + *pResult = (q15_t)(sqrtf((float)tmp2 / 32768.0f) * 32768.0f); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/std.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/std.c new file mode 100644 index 0000000..c0c1ba3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/std.c @@ -0,0 +1,74 @@ +#include "ref.h" + +void ref_std_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + uint32_t i; + float32_t sum=0, sumsq=0; + + if (blockSize == 1) + { + *pResult = 0; + return; + } + + for(i=0;i> 8; + sum += in; + sumsq += (q63_t)in * in; + } + sumsq /= (q63_t)(blockSize - 1); + sum = sum * sum / (q63_t)(blockSize * (blockSize - 1)); + *pResult = (q31_t)(sqrtf((float)( (sumsq - sum) >> 15) / 2147483648.0f ) * 2147483648.0f); +} + +void ref_std_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult) +{ + uint32_t i; + q31_t sum=0; + q63_t sumsq=0; + + if (blockSize == 1) + { + *pResult = 0; + return; + } + + for(i=0;i> 15) / 32768.0f ) * 32768.0f); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/var.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/var.c new file mode 100644 index 0000000..f5da3a6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/StatisticsFunctions/var.c @@ -0,0 +1,70 @@ +#include "ref.h" + +void ref_var_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + uint32_t i; + float32_t sum=0, sumsq=0; + + if (blockSize == 1) + { + *pResult = 0; + return; + } + + for(i=0;i> 8; + sum += in; + sumsq += (q63_t)in * in; + } + *pResult = (sumsq - sum * sum / (q31_t)blockSize) / ((q31_t)blockSize - 1) >> 15; +} + +void ref_var_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult) +{ + uint32_t i; + q31_t sum=0; + q63_t sumsq=0; + + if (blockSize == 1) + { + *pResult = 0; + return; + } + + for(i=0;i> 15; +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/copy.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/copy.c new file mode 100644 index 0000000..08089f5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/SupportFunctions/copy.c @@ -0,0 +1,53 @@ +#include "ref.h" + +void ref_copy_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + for(i=0;i> 16; + } +} + +void ref_q31_to_q7( + q31_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + for(i=0;i> 24; + } +} + +void ref_q15_to_q31( + q15_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + for(i=0;i> 8; + } +} + +void ref_q7_to_q31( + q7_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + + for(i=0;i 0.0f ? 0.5f : -0.5f; //round + pDst[i] = ref_sat_q31((q63_t)in); //cast and saturate + } +} + +void ref_float_to_q15( + float32_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + float32_t in; + + for(i=0;i 0.0f ? 0.5f : -0.5f; + pDst[i] = ref_sat_q15((q31_t)in); + } +} + +void ref_float_to_q7( + float32_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t i; + float32_t in; + + for(i=0;i 0.0f ? 0.5f : -0.5f; + pDst[i] = ref_sat_q7((q15_t)in); + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/bitreversal.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/bitreversal.c new file mode 100644 index 0000000..4751821 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/bitreversal.c @@ -0,0 +1,30 @@ +#include "ref.h" + + +;/* +;* @brief In-place bit reversal function. +;* @param[in, out] *pSrc points to the in-place buffer of unknown 32-bit data type. +;* @param[in] bitRevLen bit reversal table length +;* @param[in] *pBitRevTab points to bit reversal table. +;* @return none. +;*/ +void arm_bitreversal_32(uint32_t *pSrc, uint32_t bitRevLen, uint32_t *pBitRevTab) +{ + uint32_t a,b,i,tmp; + + for(i=0; ifftLen; + int32_t dir = (ifftFlag) ? -1 : 1; + + // decrement pointer since the original version used fortran style indexing. + data--; + + n = N << 1; + j = 1; + for (i = 1; i < n; i += 2) { + if (j > i) { + tempr = data[j]; data[j] = data[i]; data[i] = tempr; + tempr = data[j+1]; data[j+1] = data[i+1]; data[i+1] = tempr; + } + m = n >> 1; + while (m >= 2 && j > m) { + j -= m; + m >>= 1; + } + j += m; + } + mmax = 2; + while (n > mmax) { + istep = 2*mmax; + theta = -6.283185307179586f/(dir*mmax); + wtemp = sinf(0.5f*theta); + wpr = -2.0f*wtemp*wtemp; + wpi = sinf(theta); + wr = 1.0f; + wi = 0.0f; + for (m = 1; m < mmax; m += 2) { + for (i = m; i <= n; i += istep) { + j =i + mmax; + tempr = wr*data[j] - wi*data[j+1]; + tempi = wr*data[j+1] + wi*data[j]; + data[j] = data[i] - tempr; + data[j+1] = data[i+1] - tempi; + data[i] += tempr; + data[i+1] += tempi; + } + wr = (wtemp = wr)*wpr - wi*wpi + wr; + wi = wi*wpr + wtemp*wpi + wi; + } + mmax = istep; + } + + // Inverse transform is scaled by 1/N + if (ifftFlag) + { + data++; + for(i = 0; i<2*N; i++) + { + data[i] /= N; + } + } +} + +void ref_cfft_q31( + const arm_cfft_instance_q31 * S, + q31_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + uint32_t i; + float32_t *fSrc = (float32_t*)p1; + + for(i=0;ifftLen*2;i++) + { + //read the q31 data, cast to float, scale down for float + fSrc[i] = (float32_t)p1[i] / 2147483648.0f; + } + + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, fSrc, ifftFlag, bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fSrc, ifftFlag, bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fSrc, ifftFlag, bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fSrc, ifftFlag, bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fSrc, ifftFlag, bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fSrc, ifftFlag, bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fSrc, ifftFlag, bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fSrc, ifftFlag, bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fSrc, ifftFlag, bitReverseFlag); + break; + } + + if (ifftFlag) + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q31, cast to q31 + p1[i] = (q31_t)( fSrc[i] * 2147483648.0f ); + } + } + else + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q31, cast to q31 + p1[i] = (q31_t)( fSrc[i] * 2147483648.0f / (float32_t)S->fftLen); + } + } +} + +void ref_cfft_q15( + const arm_cfft_instance_q15 * S, + q15_t * pSrc, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + uint32_t i; + float32_t *fSrc = (float32_t*)pSrc; + + for(i=0;ifftLen*2;i++) + { + //read the q15 data, cast to float, scale down for float, place in temporary buffer + scratchArray[i] = (float32_t)pSrc[i] / 32768.0f; + } + + for(i=0;ifftLen*2;i++) + { + //copy from temp buffer to final buffer + fSrc[i] = scratchArray[i]; + } + + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, fSrc, ifftFlag, bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fSrc, ifftFlag, bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fSrc, ifftFlag, bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fSrc, ifftFlag, bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fSrc, ifftFlag, bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fSrc, ifftFlag, bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fSrc, ifftFlag, bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fSrc, ifftFlag, bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fSrc, ifftFlag, bitReverseFlag); + break; + } + + if (ifftFlag) + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q15, cast to q15 + pSrc[i] = (q15_t)( fSrc[i] * 32768.0f ); + } + } + else + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q15, cast to q15 + pSrc[i] = (q15_t)( fSrc[i] * 32768.0f / (float32_t)S->fftLen); + } + } +} + +void ref_cfft_radix2_f32( + const arm_cfft_radix2_instance_f32 * S, + float32_t * pSrc) +{ + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + } +} + +void ref_cfft_radix2_q31( + const arm_cfft_radix2_instance_q31 * S, + q31_t * pSrc) +{ + uint32_t i; + float32_t *fSrc = (float32_t*)pSrc; + + for(i=0;ifftLen*2;i++) + { + //read the q31 data, cast to float, scale down for float + fSrc[i] = (float32_t)pSrc[i] / 2147483648.0f; + } + + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + } + + if (S->ifftFlag) + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q31, cast to q31 + pSrc[i] = (q31_t)( fSrc[i] * 2147483648.0f ); + } + } + else + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q31, cast to q31 + pSrc[i] = (q31_t)( fSrc[i] * 2147483648.0f / (float32_t)S->fftLen); + } + } +} + +void ref_cfft_radix2_q15( + const arm_cfft_radix2_instance_q15 * S, + q15_t * pSrc) +{ + uint32_t i; + float32_t *fSrc = (float32_t*)pSrc; + + for(i=0;ifftLen*2;i++) + { + //read the q15 data, cast to float, scale down for float, place in temporary buffer + scratchArray[i] = (float32_t)pSrc[i] / 32768.0f; + } + + for(i=0;ifftLen*2;i++) + { + //copy from temp buffer to final buffer + fSrc[i] = scratchArray[i]; + } + + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + } + + if (S->ifftFlag) + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q15, cast to q15 + pSrc[i] = (q15_t)( fSrc[i] * 32768.0f ); + } + } + else + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q15, cast to q15 + pSrc[i] = (q15_t)( fSrc[i] * 32768.0f / (float32_t)S->fftLen); + } + } +} + +void ref_cfft_radix4_f32( + const arm_cfft_radix4_instance_f32 * S, + float32_t * pSrc) +{ + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, pSrc, S->ifftFlag, S->bitReverseFlag); + break; + } +} + +void ref_cfft_radix4_q31( + const arm_cfft_radix4_instance_q31 * S, + q31_t * pSrc) +{ + uint32_t i; + float32_t *fSrc = (float32_t*)pSrc; + + for(i=0;ifftLen*2;i++) + { + //read the q31 data, cast to float, scale down for float + fSrc[i] = (float32_t)pSrc[i] / 2147483648.0f; + } + + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + } + + if (S->ifftFlag) + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q31, cast to q31 + pSrc[i] = (q31_t)( fSrc[i] * 2147483648.0f ); + } + } + else + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q31, cast to q31 + pSrc[i] = (q31_t)( fSrc[i] * 2147483648.0f / (float32_t)S->fftLen); + } + } +} + +void ref_cfft_radix4_q15( + const arm_cfft_radix4_instance_q15 * S, + q15_t * pSrc) +{ + uint32_t i; + float32_t *fSrc = (float32_t*)pSrc; + + for(i=0;ifftLen*2;i++) + { + //read the q15 data, cast to float, scale down for float, place in temporary buffer + scratchArray[i] = (float32_t)pSrc[i] / 32768.0f; + } + + for(i=0;ifftLen*2;i++) + { + //copy from temp buffer to final buffer + fSrc[i] = scratchArray[i]; + } + + switch(S->fftLen) + { + case 16: + ref_cfft_f32(&arm_cfft_sR_f32_len16, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fSrc, S->ifftFlag, S->bitReverseFlag); + break; + } + + if (S->ifftFlag) + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q15, cast to q15 + pSrc[i] = (q15_t)( fSrc[i] * 32768.0f ); + } + } + else + { + for(i=0;ifftLen*2;i++) + { + //read the float data, scale up for q15, cast to q15 + pSrc[i] = (q15_t)( fSrc[i] * 32768.0f / (float32_t)S->fftLen); + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/dct4.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/dct4.c new file mode 100644 index 0000000..9c1f207 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/dct4.c @@ -0,0 +1,89 @@ +#include "ref.h" + +void ref_dct4_f32( + const arm_dct4_instance_f32 * S, + float32_t * pState, + float32_t * pInlineBuffer) +{ + uint32_t n,k; + float32_t sum; + float32_t pi_by_N = 3.14159265358979f / (float32_t)S->N; + float32_t tmp; + float32_t normalize = sqrtf(2.0f / (float32_t)S->N); + + for(k=0;kN;k++) + { + sum=0.0f; + tmp = ((float32_t)k + 0.5f)*pi_by_N; + for(n=0;nN;n++) + { + sum += pInlineBuffer[n] * cosf(tmp * ((float32_t)n + 0.5f)); + } + scratchArray[k] = normalize * sum; + } + + for(k=0;kN;k++) + { + pInlineBuffer[k] = scratchArray[k]; + } +} + +void ref_dct4_q31( + const arm_dct4_instance_q31 * S, + q31_t * pState, + q31_t * pInlineBuffer) +{ + arm_dct4_instance_f32 SS; + float32_t *fSrc = (float32_t*)pInlineBuffer; + uint32_t i; + + SS.N = S->N; + + for(i=0;iN;i++) + { + //read the q31 data, cast to float, scale down for float + fSrc[i] = (float32_t)pInlineBuffer[i] / 2147483648.0f; + } + + ref_dct4_f32(&SS,(float32_t*)0,fSrc); + + for(i=0;iN;i++) + { + fSrc[i] = fSrc[i] * 2147483648.0f / (float32_t)S->N ; + fSrc[i] += (fSrc[i] > 0) ? 0.5f : -0.5f; + pInlineBuffer[i] = (q31_t)fSrc[i]; + } +} + +void ref_dct4_q15( + const arm_dct4_instance_q15 * S, + q15_t * pState, + q15_t * pInlineBuffer) +{ + arm_dct4_instance_f32 SS; + float32_t *fSrc = (float32_t*)pInlineBuffer; + uint32_t i; + + SS.N = S->N; + + for(i=0;iN;i++) + { + //read the q15 data, cast to float, scale down for float, place in temporary buffer + scratchArray[i] = (float32_t)pInlineBuffer[i] / 32768.0f; + } + + for(i=0;iN;i++) + { + //copy from temp buffer to final buffer + fSrc[i] = scratchArray[i]; + } + + ref_dct4_f32(&SS,(float32_t*)0,fSrc); + + for(i=0;iN;i++) + { + fSrc[i] = fSrc[i] * 32768.0f / (float32_t)S->N; + fSrc[i] += (fSrc[i] > 0) ? 0.5f : -0.5f; + pInlineBuffer[i] = (q15_t)fSrc[i]; + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/rfft.c b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/rfft.c new file mode 100644 index 0000000..79738f0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/DSP_Lib_TestSuite/RefLibs/src/TransformFunctions/rfft.c @@ -0,0 +1,302 @@ +#include "ref.h" +#include "arm_const_structs.h" + +void ref_rfft_f32( + arm_rfft_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst) +{ + uint32_t i; + + if (S->ifftFlagR) + { + for(i=0;ifftLenReal*2;i++) + { + pDst[i] = pSrc[i]; + } + } + else + { + for(i=0;ifftLenReal;i++) + { + pDst[2*i+0] = pSrc[i]; + pDst[2*i+1] = 0.0f; + } + } + + switch(S->fftLenReal) + { + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, pDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, pDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, pDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 8192: + ref_cfft_f32(&ref_cfft_sR_f32_len8192, pDst, S->ifftFlagR, S->bitReverseFlagR); + break; + } + + if (S->ifftFlagR) + { + //throw away the imaginary part which should be all zeros + for(i=0;ifftLenReal;i++) + { + pDst[i] = pDst[2*i]; + } + } +} + +void ref_rfft_fast_f32( + arm_rfft_fast_instance_f32 * S, + float32_t * p, float32_t * pOut, + uint8_t ifftFlag) +{ + uint32_t i,j; + + if (ifftFlag) + { + for(i=0;ifftLenRFFT;i++) + { + pOut[i] = p[i]; + } + //unpack first sample's complex part into middle sample's real part + pOut[S->fftLenRFFT] = pOut[1]; + pOut[S->fftLenRFFT+1] = 0; + pOut[1] = 0; + j=4; + for(i = S->fftLenRFFT / 2 + 1;i < S->fftLenRFFT;i++) + { + pOut[2*i+0] = p[2*i+0 - j]; + pOut[2*i+1] = -p[2*i+1 - j]; + j+=4; + } + } + else + { + for(i=0;ifftLenRFFT;i++) + { + pOut[2*i+0] = p[i]; + pOut[2*i+1] = 0.0f; + } + } + + switch(S->fftLenRFFT) + { + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, pOut, ifftFlag, 1); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, pOut, ifftFlag, 1); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, pOut, ifftFlag, 1); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, pOut, ifftFlag, 1); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, pOut, ifftFlag, 1); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, pOut, ifftFlag, 1); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, pOut, ifftFlag, 1); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, pOut, ifftFlag, 1); + break; + } + + if (ifftFlag) + { + //throw away the imaginary part which should be all zeros + for(i=0;ifftLenRFFT;i++) + { + pOut[i] = pOut[2*i]; + } + } + else + { + //pack last sample's real part into first sample's complex part + pOut[1] = pOut[S->fftLenRFFT]; + } +} + +void ref_rfft_q31( + const arm_rfft_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst) +{ + uint32_t i; + float32_t *fDst = (float32_t*)pDst; + + if (S->ifftFlagR) + { + for(i=0;ifftLenReal*2;i++) + { + fDst[i] = (float32_t)pSrc[i] / 2147483648.0f; + } + } + else + { + for(i=0;ifftLenReal;i++) + { + fDst[2*i+0] = (float32_t)pSrc[i] / 2147483648.0f; + fDst[2*i+1] = 0.0f; + } + } + + switch(S->fftLenReal) + { + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 8192: + ref_cfft_f32(&ref_cfft_sR_f32_len8192, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + } + + if (S->ifftFlagR) + { + //throw away the imaginary part which should be all zeros + for(i=0;ifftLenReal;i++) + { + //read the float data, scale up for q31, cast to q31 + pDst[i] = (q31_t)( fDst[2*i] * 2147483648.0f); + } + } + else + { + for(i=0;ifftLenReal;i++) + { + //read the float data, scale up for q31, cast to q31 + pDst[i] = (q31_t)( fDst[i] * 2147483648.0f / (float32_t)S->fftLenReal); + } + } +} + +void ref_rfft_q15( + const arm_rfft_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst) +{ + uint32_t i; + float32_t *fDst = (float32_t*)pDst; + + + if (S->ifftFlagR) + { + for(i=0;ifftLenReal*2;i++) + { + fDst[i] = (float32_t)pSrc[i] / 32768.0f; + } + } + else + { + for(i=0;ifftLenReal;i++) + { + //read the q15 data, cast to float, scale down for float + fDst[2*i+0] = (float32_t)pSrc[i] / 32768.0f; + fDst[2*i+1] = 0.0f; + } + } + + switch(S->fftLenReal) + { + case 32: + ref_cfft_f32(&arm_cfft_sR_f32_len32, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 64: + ref_cfft_f32(&arm_cfft_sR_f32_len64, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 128: + ref_cfft_f32(&arm_cfft_sR_f32_len128, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 256: + ref_cfft_f32(&arm_cfft_sR_f32_len256, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 512: + ref_cfft_f32(&arm_cfft_sR_f32_len512, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 1024: + ref_cfft_f32(&arm_cfft_sR_f32_len1024, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 2048: + ref_cfft_f32(&arm_cfft_sR_f32_len2048, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 4096: + ref_cfft_f32(&arm_cfft_sR_f32_len4096, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + + case 8192: + ref_cfft_f32(&ref_cfft_sR_f32_len8192, fDst, S->ifftFlagR, S->bitReverseFlagR); + break; + } + + if (S->ifftFlagR) + { + //throw away the imaginary part which should be all zeros + for(i=0;ifftLenReal;i++) + { + pDst[i] = (q15_t)( fDst[2*i] * 32768.0f); + } + } + else + { + for(i=0;ifftLenReal;i++) + { + pDst[i] = (q15_t)( fDst[i] * 32768.0f / (float32_t)S->fftLenReal); + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/Abstract.txt new file mode 100644 index 0000000..7ac021f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_class_marks_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/arm_class_marks_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/arm_class_marks_example_f32.c new file mode 100644 index 0000000..e6842de --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_class_marks_example/arm_class_marks_example_f32.c @@ -0,0 +1,211 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_class_marks_example_f32.c +* +* Description: Example code to calculate Minimum, Maximum +* Mean, std and variance of marks obtained in a class +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup ClassMarks Class Marks Example + * + * \par Description: + * \par + * Demonstrates the use the Maximum, Minimum, Mean, Standard Deviation, Variance + * and Matrix functions to calculate statistical values of marks obtained in a class. + * + * \note This example also demonstrates the usage of static initialization. + * + * \par Variables Description: + * \par + * \li \c testMarks_f32 points to the marks scored by 20 students in 4 subjects + * \li \c max_marks Maximum of all marks + * \li \c min_marks Minimum of all marks + * \li \c mean Mean of all marks + * \li \c var Variance of the marks + * \li \c std Standard deviation of the marks + * \li \c numStudents Total number of students in the class + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_mat_init_f32() + * - arm_mat_mult_f32() + * - arm_max_f32() + * - arm_min_f32() + * - arm_mean_f32() + * - arm_std_f32() + * - arm_var_f32() + * + * Refer + * \link arm_class_marks_example_f32.c \endlink + * + */ + + +/** \example arm_class_marks_example_f32.c + */ +#include "arm_math.h" + +#define USE_STATIC_INIT + + /* ---------------------------------------------------------------------- +** Global defines +** ------------------------------------------------------------------- */ + +#define TEST_LENGTH_SAMPLES (20*4) + +/* ---------------------------------------------------------------------- +** List of Marks scored by 20 students for 4 subjects +** ------------------------------------------------------------------- */ +const float32_t testMarks_f32[TEST_LENGTH_SAMPLES] = +{ + 42.000000, 37.000000, 81.000000, 28.000000, + 83.000000, 72.000000, 36.000000, 38.000000, + 32.000000, 51.000000, 63.000000, 64.000000, + 97.000000, 82.000000, 95.000000, 90.000000, + 66.000000, 51.000000, 54.000000, 42.000000, + 67.000000, 56.000000, 45.000000, 57.000000, + 67.000000, 69.000000, 35.000000, 52.000000, + 29.000000, 81.000000, 58.000000, 47.000000, + 38.000000, 76.000000, 100.000000, 29.000000, + 33.000000, 47.000000, 29.000000, 50.000000, + 34.000000, 41.000000, 61.000000, 46.000000, + 52.000000, 50.000000, 48.000000, 36.000000, + 47.000000, 55.000000, 44.000000, 40.000000, + 100.000000, 94.000000, 84.000000, 37.000000, + 32.000000, 71.000000, 47.000000, 77.000000, + 31.000000, 50.000000, 49.000000, 35.000000, + 63.000000, 67.000000, 40.000000, 31.000000, + 29.000000, 68.000000, 61.000000, 38.000000, + 31.000000, 28.000000, 28.000000, 76.000000, + 55.000000, 33.000000, 29.000000, 39.000000 +}; + + +/* ---------------------------------------------------------------------- +* Number of subjects X 1 +* ------------------------------------------------------------------- */ +const float32_t testUnity_f32[4] = +{ + 1.000, 1.000, 1.000, 1.000 +}; + + +/* ---------------------------------------------------------------------- +** f32 Output buffer +** ------------------------------------------------------------------- */ +static float32_t testOutput[TEST_LENGTH_SAMPLES]; + + +/* ------------------------------------------------------------------ +* Global defines +*------------------------------------------------------------------- */ +#define NUMSTUDENTS 20 +#define NUMSUBJECTS 4 + +/* ------------------------------------------------------------------ +* Global variables +*------------------------------------------------------------------- */ + + uint32_t numStudents = 20; + uint32_t numSubjects = 4; +float32_t max_marks, min_marks, mean, std, var; + uint32_t student_num; + +/* ---------------------------------------------------------------------------------- +* Main f32 test function. It returns maximum marks secured and student number +* ------------------------------------------------------------------------------- */ + +int32_t main() +{ + +#ifndef USE_STATIC_INIT + + arm_matrix_instance_f32 srcA; + arm_matrix_instance_f32 srcB; + arm_matrix_instance_f32 dstC; + + /* Input and output matrices initializations */ + arm_mat_init_f32(&srcA, numStudents, numSubjects, (float32_t *)testMarks_f32); + arm_mat_init_f32(&srcB, numSubjects, 1, (float32_t *)testUnity_f32); + arm_mat_init_f32(&dstC, numStudents, 1, testOutput); + +#else + + /* Static Initializations of Input and output matrix sizes and array */ + arm_matrix_instance_f32 srcA = {NUMSTUDENTS, NUMSUBJECTS, (float32_t *)testMarks_f32}; + arm_matrix_instance_f32 srcB = {NUMSUBJECTS, 1, (float32_t *)testUnity_f32}; + arm_matrix_instance_f32 dstC = {NUMSTUDENTS, 1, testOutput}; + +#endif + + + /* ---------------------------------------------------------------------- + *Call the Matrix multiplication process function + * ------------------------------------------------------------------- */ + arm_mat_mult_f32(&srcA, &srcB, &dstC); + + /* ---------------------------------------------------------------------- + ** Call the Max function to calculate max marks among numStudents + ** ------------------------------------------------------------------- */ + arm_max_f32(testOutput, numStudents, &max_marks, &student_num); + + /* ---------------------------------------------------------------------- + ** Call the Min function to calculate min marks among numStudents + ** ------------------------------------------------------------------- */ + arm_min_f32(testOutput, numStudents, &min_marks, &student_num); + + /* ---------------------------------------------------------------------- + ** Call the Mean function to calculate mean + ** ------------------------------------------------------------------- */ + arm_mean_f32(testOutput, numStudents, &mean); + + /* ---------------------------------------------------------------------- + ** Call the std function to calculate standard deviation + ** ------------------------------------------------------------------- */ + arm_std_f32(testOutput, numStudents, &std); + + /* ---------------------------------------------------------------------- + ** Call the var function to calculate variance + ** ------------------------------------------------------------------- */ + arm_var_f32(testOutput, numStudents, &var); + + while (1); /* main function does not return */ +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/Abstract.txt new file mode 100644 index 0000000..7ef79e2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_convolution_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/arm_convolution_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/arm_convolution_example_f32.c new file mode 100644 index 0000000..e4665fe --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/arm_convolution_example_f32.c @@ -0,0 +1,247 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_convolution_example_f32.c +* +* Description: Example code demonstrating Convolution of two input signals using fft. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup ConvolutionExample Convolution Example + * + * \par Description: + * \par + * Demonstrates the convolution theorem with the use of the Complex FFT, Complex-by-Complex + * Multiplication, and Support Functions. + * + * \par Algorithm: + * \par + * The convolution theorem states that convolution in the time domain corresponds to + * multiplication in the frequency domain. Therefore, the Fourier transform of the convoution of + * two signals is equal to the product of their individual Fourier transforms. + * The Fourier transform of a signal can be evaluated efficiently using the Fast Fourier Transform (FFT). + * \par + * Two input signals, a[n] and b[n], with lengths \c n1 and \c n2 respectively, + * are zero padded so that their lengths become \c N, which is greater than or equal to (n1+n2-1) + * and is a power of 4 as FFT implementation is radix-4. + * The convolution of a[n] and b[n] is obtained by taking the FFT of the input + * signals, multiplying the Fourier transforms of the two signals, and taking the inverse FFT of + * the multiplied result. + * \par + * This is denoted by the following equations: + *
 A[k] = FFT(a[n],N)
+ * B[k] = FFT(b[n],N)
+ * conv(a[n], b[n]) = IFFT(A[k] * B[k], N)
+ * where A[k] and B[k] are the N-point FFTs of the signals a[n] + * and b[n] respectively. + * The length of the convolved signal is (n1+n2-1). + * + * \par Block Diagram: + * \par + * \image html Convolution.gif + * + * \par Variables Description: + * \par + * \li \c testInputA_f32 points to the first input sequence + * \li \c srcALen length of the first input sequence + * \li \c testInputB_f32 points to the second input sequence + * \li \c srcBLen length of the second input sequence + * \li \c outLen length of convolution output sequence, (srcALen + srcBLen - 1) + * \li \c AxB points to the output array where the product of individual FFTs of inputs is stored. + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_fill_f32() + * - arm_copy_f32() + * - arm_cfft_radix4_init_f32() + * - arm_cfft_radix4_f32() + * - arm_cmplx_mult_cmplx_f32() + * + * Refer + * \link arm_convolution_example_f32.c \endlink + * + */ + + +/** \example arm_convolution_example_f32.c + */ + +#include "arm_math.h" +#include "math_helper.h" + +/* ---------------------------------------------------------------------- +* Defines each of the tests performed +* ------------------------------------------------------------------- */ +#define MAX_BLOCKSIZE 128 +#define DELTA (0.000001f) +#define SNR_THRESHOLD 90 + +/* ---------------------------------------------------------------------- +* Declare I/O buffers +* ------------------------------------------------------------------- */ +float32_t Ak[MAX_BLOCKSIZE]; /* Input A */ +float32_t Bk[MAX_BLOCKSIZE]; /* Input B */ +float32_t AxB[MAX_BLOCKSIZE * 2]; /* Output */ + +/* ---------------------------------------------------------------------- +* Test input data for Floating point Convolution example for 32-blockSize +* Generated by the MATLAB randn() function +* ------------------------------------------------------------------- */ +float32_t testInputA_f32[64] = +{ + -0.808920, 1.357369, 1.180861, -0.504544, 1.762637, -0.703285, + 1.696966, 0.620571, -0.151093, -0.100235, -0.872382, -0.403579, + -0.860749, -0.382648, -1.052338, 0.128113, -0.646269, 1.093377, + -2.209198, 0.471706, 0.408901, 1.266242, 0.598252, 1.176827, + -0.203421, 0.213596, -0.851964, -0.466958, 0.021841, -0.698938, + -0.604107, 0.461778, -0.318219, 0.942520, 0.577585, 0.417619, + 0.614665, 0.563679, -1.295073, -0.764437, 0.952194, -0.859222, + -0.618554, -2.268542, -1.210592, 1.655853, -2.627219, -0.994249, + -1.374704, 0.343799, 0.025619, 1.227481, -0.708031, 0.069355, + -1.845228, -1.570886, 1.010668, -1.802084, 1.630088, 1.286090, + -0.161050, -0.940794, 0.367961, 0.291907 + +}; + +float32_t testInputB_f32[64] = +{ + 0.933724, 0.046881, 1.316470, 0.438345, 0.332682, 2.094885, + 0.512081, 0.035546, 0.050894, -2.320371, 0.168711, -1.830493, + -0.444834, -1.003242, -0.531494, -1.365600, -0.155420, -0.757692, + -0.431880, -0.380021, 0.096243, -0.695835, 0.558850, -1.648962, + 0.020369, -0.363630, 0.887146, 0.845503, -0.252864, -0.330397, + 1.269131, -1.109295, -1.027876, 0.135940, 0.116721, -0.293399, + -1.349799, 0.166078, -0.802201, 0.369367, -0.964568, -2.266011, + 0.465178, 0.651222, -0.325426, 0.320245, -0.784178, -0.579456, + 0.093374, 0.604778, -0.048225, 0.376297, -0.394412, 0.578182, + -1.218141, -1.387326, 0.692462, -0.631297, 0.153137, -0.638952, + 0.635474, -0.970468, 1.334057, -0.111370 +}; + +const float testRefOutput_f32[127] = +{ + -0.818943, 1.229484, -0.533664, 1.016604, 0.341875, -1.963656, + 5.171476, 3.478033, 7.616361, 6.648384, 0.479069, 1.792012, + -1.295591, -7.447818, 0.315830, -10.657445, -2.483469, -6.524236, + -7.380591, -3.739005, -8.388957, 0.184147, -1.554888, 3.786508, + -1.684421, 5.400610, -1.578126, 7.403361, 8.315999, 2.080267, + 11.077776, 2.749673, 7.138962, 2.748762, 0.660363, 0.981552, + 1.442275, 0.552721, -2.576892, 4.703989, 0.989156, 8.759344, + -0.564825, -3.994680, 0.954710, -5.014144, 6.592329, 1.599488, + -13.979146, -0.391891, -4.453369, -2.311242, -2.948764, 1.761415, + -0.138322, 10.433007, -2.309103, 4.297153, 8.535523, 3.209462, + 8.695819, 5.569919, 2.514304, 5.582029, 2.060199, 0.642280, + 7.024616, 1.686615, -6.481756, 1.343084, -3.526451, 1.099073, + -2.965764, -0.173723, -4.111484, 6.528384, -6.965658, 1.726291, + 1.535172, 11.023435, 2.338401, -4.690188, 1.298210, 3.943885, + 8.407885, 5.168365, 0.684131, 1.559181, 1.859998, 2.852417, + 8.574070, -6.369078, 6.023458, 11.837963, -6.027632, 4.469678, + -6.799093, -2.674048, 6.250367, -6.809971, -3.459360, 9.112410, + -2.711621, -1.336678, 1.564249, -1.564297, -1.296760, 8.904013, + -3.230109, 6.878013, -7.819823, 3.369909, -1.657410, -2.007358, + -4.112825, 1.370685, -3.420525, -6.276605, 3.244873, -3.352638, + 1.545372, 0.902211, 0.197489, -1.408732, 0.523390, 0.348440, 0 +}; + + +/* ---------------------------------------------------------------------- +* Declare Global variables +* ------------------------------------------------------------------- */ +uint32_t srcALen = 64; /* Length of Input A */ +uint32_t srcBLen = 64; /* Length of Input B */ +uint32_t outLen; /* Length of convolution output */ +float32_t snr; /* output SNR */ + +int32_t main(void) +{ + arm_status status; /* Status of the example */ + arm_cfft_radix4_instance_f32 cfft_instance; /* CFFT Structure instance */ + + /* CFFT Structure instance pointer */ + arm_cfft_radix4_instance_f32 *cfft_instance_ptr = + (arm_cfft_radix4_instance_f32*) &cfft_instance; + + /* output length of convolution */ + outLen = srcALen + srcBLen - 1; + + /* Initialise the fft input buffers with all zeros */ + arm_fill_f32(0.0, Ak, MAX_BLOCKSIZE); + arm_fill_f32(0.0, Bk, MAX_BLOCKSIZE); + + /* Copy the input values to the fft input buffers */ + arm_copy_f32(testInputA_f32, Ak, MAX_BLOCKSIZE/2); + arm_copy_f32(testInputB_f32, Bk, MAX_BLOCKSIZE/2); + + /* Initialize the CFFT function to compute 64 point fft */ + status = arm_cfft_radix4_init_f32(cfft_instance_ptr, 64, 0, 1); + + /* Transform input a[n] from time domain to frequency domain A[k] */ + arm_cfft_radix4_f32(cfft_instance_ptr, Ak); + /* Transform input b[n] from time domain to frequency domain B[k] */ + arm_cfft_radix4_f32(cfft_instance_ptr, Bk); + + /* Complex Multiplication of the two input buffers in frequency domain */ + arm_cmplx_mult_cmplx_f32(Ak, Bk, AxB, MAX_BLOCKSIZE/2); + + /* Initialize the CIFFT function to compute 64 point ifft */ + status = arm_cfft_radix4_init_f32(cfft_instance_ptr, 64, 1, 1); + + /* Transform the multiplication output from frequency domain to time domain, + that gives the convolved output */ + arm_cfft_radix4_f32(cfft_instance_ptr, AxB); + + /* SNR Calculation */ + snr = arm_snr_f32((float32_t *)testRefOutput_f32, AxB, srcALen + srcBLen - 1); + + /* Compare the SNR with threshold to test whether the + computed output is matched with the reference output values. */ + if ( snr > SNR_THRESHOLD) + { + status = ARM_MATH_SUCCESS; + } + + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.c new file mode 100644 index 0000000..f615e6f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.c @@ -0,0 +1,466 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 b +* +* Project: CMSIS DSP Library +* +* Title: math_helper.c +* +* Description: Definition of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Include standard header files +* -------------------------------------------------------------------- */ +#include + +/* ---------------------------------------------------------------------- +* Include project header files +* -------------------------------------------------------------------- */ +#include "math_helper.h" + +/** + * @brief Caluclation of SNR + * @param[in] pRef Pointer to the reference buffer + * @param[in] pTest Pointer to the test buffer + * @param[in] buffSize total number of samples + * @return SNR + * The function Caluclates signal to noise ratio for the reference output + * and test output + */ + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize) +{ + float EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + float SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10 (EnergySignal / EnergyError); + + return (SNR); + +} + + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q15 (q15_t * input_buf, uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Converts float to fixed in q12.20 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to outputbuffer + * @param[in] numSamples number of samples in the input buffer + * @return none + * The function converts floating point values to fixed point(q12.20) values + */ + +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1048576.0f corresponds to pow(2, 20) */ + pOut[i] = (q31_t) (pIn[i] * 1048576.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 1.0) + { + pOut[i] = 0x000FFFFF; + } + } +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q31 (q31_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q7 (q7_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + + + +/** + * @brief Caluclates number of guard bits + * @param[in] num_adds number of additions + * @return guard bits + * The function Caluclates the number of guard bits + * depending on the numtaps + */ + +uint32_t arm_calc_guard_bits (uint32_t num_adds) +{ + uint32_t i = 1, j = 0; + + if (num_adds == 1) + { + return (0); + } + + while (i < num_adds) + { + i = i * 2; + j++; + } + + return (j); +} + +/** + * @brief Apply guard bits to buffer + * @param[in,out] pIn pointer to input buffer + * @param[in] numSamples number of samples in the input buffer + * @param[in] guard_bits guard bits + * @return none + */ + +void arm_apply_guard_bits (float32_t *pIn, + uint32_t numSamples, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + pIn[i] = pIn[i] * arm_calc_2pow(guard_bits); + } +} + +/** + * @brief Calculates pow(2, numShifts) + * @param[in] numShifts number of shifts + * @return pow(2, numShifts) + */ +uint32_t arm_calc_2pow(uint32_t numShifts) +{ + + uint32_t i, val = 1; + + for (i = 0; i < numShifts; i++) + { + val = val * 2; + } + + return(val); +} + + + +/** + * @brief Converts float to fixed q14 + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q14 (float *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 16384.0f corresponds to pow(2, 14) */ + pOut[i] = (q15_t) (pIn[i] * 16384.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFF; + } + + } + +} + + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q30 (float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 1073741824.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q29 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 536870912.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 4.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + + +/** + * @brief Converts float to fixed q28 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q28 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 268435456.0f corresponds to pow(2, 28) */ + pOut[i] = (q31_t) (pIn[i] * 268435456.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 8.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Clip the float values to +/- 1 + * @param[in,out] pIn input buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_clip_f32 (float *pIn, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + if (pIn[i] > 1.0f) + { + pIn[i] = 1.0; + } + else if ( pIn[i] < -1.0f) + { + pIn[i] = -1.0; + } + + } +} + + + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.h b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.h new file mode 100644 index 0000000..5a18734 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_convolution_example/math_helper.h @@ -0,0 +1,63 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2013 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* +* Title: math_helper.h +* +* Description: Prototypes of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + + +#include "arm_math.h" + +#ifndef MATH_HELPER_H +#define MATH_HELPER_H + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize); +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples); +void arm_provide_guard_bits_q15(q15_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_provide_guard_bits_q31(q31_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_float_to_q14(float *pIn, q15_t *pOut, uint32_t numSamples); +void arm_float_to_q29(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q28(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q30(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_clip_f32(float *pIn, uint32_t numSamples); +uint32_t arm_calc_guard_bits(uint32_t num_adds); +void arm_apply_guard_bits (float32_t * pIn, uint32_t numSamples, uint32_t guard_bits); +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t * pOut, uint32_t numSamples); +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t *pOut, uint32_t numSamples); +uint32_t arm_calc_2pow(uint32_t guard_bits); +#endif + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/Abstract.txt new file mode 100644 index 0000000..f889251 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_dotproduct_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/arm_dotproduct_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/arm_dotproduct_example_f32.c new file mode 100644 index 0000000..5a05071 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_dotproduct_example/arm_dotproduct_example_f32.c @@ -0,0 +1,178 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_dotproduct_example_f32.c +* +* Description: Example code computing dot product of two vectors. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup DotproductExample Dot Product Example + * + * \par Description: + * \par + * Demonstrates the use of the Multiply and Add functions to perform the dot product. + * The dot product of two vectors is obtained by multiplying corresponding elements + * and summing the products. + + * \par Algorithm: + * \par + * The two input vectors \c A and \c B with length \c n, are multiplied element-by-element + * and then added to obtain dot product. + * \par + * This is denoted by the following equation: + *
  dotProduct = A[0] * B[0] + A[1] * B[1] + ... + A[n-1] * B[n-1]
+ * + * \par Block Diagram: + * \par + * \image html dotProduct.gif + * + * \par Variables Description: + * \par + * \li \c srcA_buf_f32 points to first input vector + * \li \c srcB_buf_f32 points to second input vector + * \li \c testOutput stores dot product of the two input vectors. + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_mult_f32() + * - arm_add_f32() + * + * Refer + * \link arm_dotproduct_example_f32.c \endlink + * + */ + + +/** \example arm_dotproduct_example_f32.c + */ + +#include +#include "arm_math.h" + +/* ---------------------------------------------------------------------- +* Defines each of the tests performed +* ------------------------------------------------------------------- */ +#define MAX_BLOCKSIZE 32 +#define DELTA (0.000001f) + +/* ---------------------------------------------------------------------- +* Test input data for Floating point Dot Product example for 32-blockSize +* Generated by the MATLAB randn() function +* ------------------------------------------------------------------- */ +/* ---------------------------------------------------------------------- +** Test input data of srcA for blockSize 32 +** ------------------------------------------------------------------- */ +float32_t srcA_buf_f32[MAX_BLOCKSIZE] = +{ + -0.4325648115282207, -1.6655843782380970, 0.1253323064748307, + 0.2876764203585489, -1.1464713506814637, 1.1909154656429988, + 1.1891642016521031, -0.0376332765933176, 0.3272923614086541, + 0.1746391428209245, -0.1867085776814394, 0.7257905482933027, + -0.5883165430141887, 2.1831858181971011, -0.1363958830865957, + 0.1139313135208096, 1.0667682113591888, 0.0592814605236053, + -0.0956484054836690, -0.8323494636500225, 0.2944108163926404, + -1.3361818579378040, 0.7143245518189522, 1.6235620644462707, + -0.6917757017022868, 0.8579966728282626, 1.2540014216025324, + -1.5937295764474768, -1.4409644319010200, 0.5711476236581780, + -0.3998855777153632, 0.6899973754643451 +}; + +/* ---------------------------------------------------------------------- +** Test input data of srcB for blockSize 32 +** ------------------------------------------------------------------- */ +float32_t srcB_buf_f32[MAX_BLOCKSIZE] = +{ + 1.7491401329284098, 0.1325982188803279, 0.3252281811989881, + -0.7938091410349637, 0.3149236145048914, -0.5272704888029532, + 0.9322666565031119, 1.1646643544607362, -2.0456694357357357, + -0.6443728590041911, 1.7410657940825480, 0.4867684246821860, + 1.0488288293660140, 1.4885752747099299, 1.2705014969484090, + -1.8561241921210170, 2.1343209047321410, 1.4358467535865909, + -0.9173023332875400, -1.1060770780029008, 0.8105708062681296, + 0.6985430696369063, -0.4015827425012831, 1.2687512030669628, + -0.7836083053674872, 0.2132664971465569, 0.7878984786088954, + 0.8966819356782295, -0.1869172943544062, 1.0131816724341454, + 0.2484350696132857, 0.0596083377937976 +}; + +/* Reference dot product output */ +float32_t refDotProdOut = 5.9273644806352142; + +/* ---------------------------------------------------------------------- +* Declare Global variables +* ------------------------------------------------------------------- */ +float32_t multOutput[MAX_BLOCKSIZE]; /* Intermediate output */ +float32_t testOutput; /* Final ouput */ + +arm_status status; /* Status of the example */ + +int32_t main(void) +{ + uint32_t i; /* Loop counter */ + float32_t diff; /* Difference between reference and test outputs */ + + /* Multiplication of two input buffers */ + arm_mult_f32(srcA_buf_f32, srcB_buf_f32, multOutput, MAX_BLOCKSIZE); + + /* Accumulate the multiplication output values to + get the dot product of the two inputs */ + for(i=0; i< MAX_BLOCKSIZE; i++) + { + arm_add_f32(&testOutput, &multOutput[i], &testOutput, 1); + } + + /* absolute value of difference between ref and test */ + diff = fabsf(refDotProdOut - testOutput); + + /* Comparison of dot product value with reference */ + if (diff > DELTA) + { + status = ARM_MATH_TEST_FAILURE; + } + + if ( status == ARM_MATH_TEST_FAILURE) + { + while (1); + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/Abstract.txt new file mode 100644 index 0000000..37bea21 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_fft_bin_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_data.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_data.c new file mode 100644 index 0000000..10f3e12 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_data.c @@ -0,0 +1,308 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_fft_bin_data.c +* +* Description: Data file used for example code +* +* Target Processor: Cortex-M4/Cortex-M3/Cortex-M0 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +#include "arm_math.h" + +/* ---------------------------------------------------------------------- +Test Input signal contains 10KHz signal + Uniformly distributed white noise +** ------------------------------------------------------------------- */ + +float32_t testInput_f32_10khz[2048] = +{ +-0.865129623056441, 0.000000000000000, -2.655020678073846, 0.000000000000000, 0.600664612949661, 0.000000000000000, 0.080378093886515, 0.000000000000000, +-2.899160484012034, 0.000000000000000, 2.563004262857762, 0.000000000000000, 3.078328403304206, 0.000000000000000, 0.105906778385130, 0.000000000000000, +0.048366940168201, 0.000000000000000, -0.145696461188734, 0.000000000000000, -0.023417155362879, 0.000000000000000, 2.127729174988954, 0.000000000000000, +-1.176633086028377, 0.000000000000000, 3.690223557991855, 0.000000000000000, -0.622791766173194, 0.000000000000000, 0.722837373872203, 0.000000000000000, +2.739754205367484, 0.000000000000000, -0.062610410524552, 0.000000000000000, -0.891296810967338, 0.000000000000000, -1.845872258871811, 0.000000000000000, +1.195039415434387, 0.000000000000000, -2.177388969045026, 0.000000000000000, 1.078649103637905, 0.000000000000000, 2.570976050490193, 0.000000000000000, +-1.383551403404574, 0.000000000000000, 2.392141424058873, 0.000000000000000, 2.858002843205065, 0.000000000000000, -3.682433899725536, 0.000000000000000, +-3.488146646451150, 0.000000000000000, 1.323468578888120, 0.000000000000000, -0.099771155430726, 0.000000000000000, 1.561168082500454, 0.000000000000000, +1.025026795103179, 0.000000000000000, 0.928841900171200, 0.000000000000000, 2.930499509864950, 0.000000000000000, 2.013349089766430, 0.000000000000000, +2.381676148486737, 0.000000000000000, -3.081062307950236, 0.000000000000000, -0.389579115537544, 0.000000000000000, 0.181540149166620, 0.000000000000000, +-2.601953341353208, 0.000000000000000, 0.333435137783218, 0.000000000000000, -2.812945856162965, 0.000000000000000, 2.649109640172910, 0.000000000000000, +-1.003963025744654, 0.000000000000000, 1.552460768755035, 0.000000000000000, 0.088641345335247, 0.000000000000000, -2.519951327113426, 0.000000000000000, +-4.341348988610527, 0.000000000000000, 0.557772429359965, 0.000000000000000, -1.671267412948494, 0.000000000000000, 0.733951350960387, 0.000000000000000, +0.409263788034864, 0.000000000000000, 3.566033071952806, 0.000000000000000, 1.882565173848352, 0.000000000000000, -1.106017073793287, 0.000000000000000, +0.154456720778718, 0.000000000000000, -2.513205795512153, 0.000000000000000, 0.310978660939421, 0.000000000000000, 0.579706500111723, 0.000000000000000, +0.000086383683251, 0.000000000000000, -1.311866980897721, 0.000000000000000, 1.840007477574986, 0.000000000000000, -3.253005768451345, 0.000000000000000, +1.462584328739432, 0.000000000000000, 1.610103610851738, 0.000000000000000, 0.761914676858907, 0.000000000000000, 0.974541361089834, 0.000000000000000, +0.686845845885983, 0.000000000000000, 1.849153122025191, 0.000000000000000, 0.787800410401453, 0.000000000000000, -1.187438909666279, 0.000000000000000, +-0.754937911044720, 0.000000000000000, 0.084373858395232, 0.000000000000000, -2.600269011710521, 0.000000000000000, -0.962982842142644, 0.000000000000000, +-0.369328108540868, 0.000000000000000, 0.810791418361879, 0.000000000000000, 3.587016488699641, 0.000000000000000, -0.520776145083723, 0.000000000000000, +0.640249919627884, 0.000000000000000, 1.103122489464969, 0.000000000000000, 2.231779881455556, 0.000000000000000, -1.308035392685241, 0.000000000000000, +0.424070304330106, 0.000000000000000, -0.200383932651189, 0.000000000000000, -2.365526783356541, 0.000000000000000, -0.989114757436628, 0.000000000000000, +2.770807688959777, 0.000000000000000, -0.444172737462307, 0.000000000000000, 0.079760979374078, 0.000000000000000, -0.005199118412183, 0.000000000000000, +-0.664712668309527, 0.000000000000000, -0.624171857561896, 0.000000000000000, 0.537306979007338, 0.000000000000000, -2.575955675497642, 0.000000000000000, +1.562363235756780, 0.000000000000000, 1.814069369848895, 0.000000000000000, -1.293428583392509, 0.000000000000000, -1.026188449495686, 0.000000000000000, +-2.981771815588717, 0.000000000000000, -4.223468103075124, 0.000000000000000, 2.672674782004045, 0.000000000000000, -0.856096801117735, 0.000000000000000, +0.048517345512563, 0.000000000000000, -0.026860721136222, 0.000000000000000, 0.392932277758187, 0.000000000000000, -1.331740855093099, 0.000000000000000, +-1.894292129477081, 0.000000000000000, -1.425006468460681, 0.000000000000000, -2.721772427617057, 0.000000000000000, -1.616831100216806, 0.000000000000000, +3.551177651488947, 0.000000000000000, -0.069685667896087, 0.000000000000000, -3.134634907409102, 0.000000000000000, -0.263627598944639, 0.000000000000000, +-1.650469945991350, 0.000000000000000, -2.203580339374399, 0.000000000000000, -0.872203246123242, 0.000000000000000, 1.230782812607287, 0.000000000000000, +0.257288860093291, 0.000000000000000, 1.989083106173137, 0.000000000000000, -1.985638729453261, 0.000000000000000, -1.416185105842892, 0.000000000000000, +-1.131097688325772, 0.000000000000000, -2.245130805416057, 0.000000000000000, -1.938873996219074, 0.000000000000000, 2.043608361562645, 0.000000000000000, +-0.583727989880841, 0.000000000000000, -1.785266378212929, 0.000000000000000, 1.961457586224753, 0.000000000000000, 1.139400099963223, 0.000000000000000, +-1.979519343363991, 0.000000000000000, 2.003023322818429, 0.000000000000000, 0.229004069076829, 0.000000000000000, 3.452808862193135, 0.000000000000000, +2.882273808365857, 0.000000000000000, -1.549450501844438, 0.000000000000000, -3.283872089931876, 0.000000000000000, -0.327025884099064, 0.000000000000000, +-0.054979977136430, 0.000000000000000, -1.192280531479012, 0.000000000000000, 0.645539328365578, 0.000000000000000, 2.300832863404618, 0.000000000000000, +-1.092951789535240, 0.000000000000000, -1.017368249363773, 0.000000000000000, -0.142673056169787, 0.000000000000000, 0.831073544881250, 0.000000000000000, +-2.314612531587064, 0.000000000000000, -2.221456299106321, 0.000000000000000, 0.460261143885226, 0.000000000000000, 0.050585301888595, 0.000000000000000, +0.364373329183988, 0.000000000000000, -1.685956552069538, 0.000000000000000, 0.050664512351055, 0.000000000000000, -0.193355783902718, 0.000000000000000, +-0.158660446046828, 0.000000000000000, 2.394156453841953, 0.000000000000000, -1.562965718554525, 0.000000000000000, -2.199750600869900, 0.000000000000000, +1.544984022381773, 0.000000000000000, -1.988307216807315, 0.000000000000000, -0.628240722541046, 0.000000000000000, -1.436235771505429, 0.000000000000000, +1.677013691147313, 0.000000000000000, 1.600741781678228, 0.000000000000000, -0.757380959134706, 0.000000000000000, -4.784797439515566, 0.000000000000000, +0.265121462834569, 0.000000000000000, 3.862029485934378, 0.000000000000000, 2.386823577249430, 0.000000000000000, -3.655779745436893, 0.000000000000000, +-0.763541621368016, 0.000000000000000, -1.182140388432962, 0.000000000000000, -1.349106114858063, 0.000000000000000, -2.287533624396759, 0.000000000000000, +-0.028603745188423, 0.000000000000000, -1.353580755934427, 0.000000000000000, 0.461602380352937, 0.000000000000000, -0.059599055078928, 0.000000000000000, +-0.929946734342228, 0.000000000000000, 0.065773089295561, 0.000000000000000, 1.106565863102982, 0.000000000000000, 4.719295086373593, 0.000000000000000, +-2.108377703544395, 0.000000000000000, -2.226393620240159, 0.000000000000000, 1.375668397437521, 0.000000000000000, -0.960772428525443, 0.000000000000000, +-2.156313465390571, 0.000000000000000, 1.126060012375311, 0.000000000000000, 2.756485137030720, 0.000000000000000, 0.739639690862600, 0.000000000000000, +3.914769510295006, 0.000000000000000, 1.685232785586675, 0.000000000000000, 4.079058040970612, 0.000000000000000, -1.174598301660513, 0.000000000000000, +-2.885776587275580, 0.000000000000000, -0.241073635188767, 0.000000000000000, 3.080489872502403, 0.000000000000000, -2.051244183999421, 0.000000000000000, +0.664330486845139, 0.000000000000000, -1.697798999370016, 0.000000000000000, 1.452369423649782, 0.000000000000000, -1.523532831019280, 0.000000000000000, +0.171981186587481, 0.000000000000000, -4.685274721583927, 0.000000000000000, -1.336175835319380, 0.000000000000000, 1.419070770428945, 0.000000000000000, +-0.035791601713475, 0.000000000000000, 2.291937971632081, 0.000000000000000, -1.962559313450293, 0.000000000000000, -4.831595589339301, 0.000000000000000, +-1.857055284000925, 0.000000000000000, 2.606271522635512, 0.000000000000000, -0.576447978738030, 0.000000000000000, 0.082299166967720, 0.000000000000000, +1.888399453494614, 0.000000000000000, -3.564705298046079, 0.000000000000000, -0.939357831083889, 0.000000000000000, -1.903578203697778, 0.000000000000000, +-2.642492215447250, 0.000000000000000, -0.182990405251017, 0.000000000000000, 3.742026478011174, 0.000000000000000, 0.104295803798333, 0.000000000000000, +1.848678195370347, 0.000000000000000, -1.887384346896369, 0.000000000000000, 0.365048973046045, 0.000000000000000, -0.889638010354219, 0.000000000000000, +1.173877118428863, 0.000000000000000, -1.178562827540109, 0.000000000000000, 0.610271645685184, 0.000000000000000, 1.831284815697871, 0.000000000000000, +0.449575390102283, 0.000000000000000, 1.597171905253443, 0.000000000000000, 3.918574971904773, 0.000000000000000, 0.868104027970404, 0.000000000000000, +0.582643134746494, 0.000000000000000, 2.321256382353331, 0.000000000000000, -0.238118642223180, 0.000000000000000, -2.890287868054370, 0.000000000000000, +0.970995414625622, 0.000000000000000, 0.666137930891283, 0.000000000000000, -0.202435718709502, 0.000000000000000, 2.057930200518194, 0.000000000000000, +3.120583443719949, 0.000000000000000, -0.863945271701041, 0.000000000000000, 0.906848893874630, 0.000000000000000, -1.434124930222570, 0.000000000000000, +0.754659384848783, 0.000000000000000, -5.224154442713778, 0.000000000000000, 2.330229744098967, 0.000000000000000, 1.113946320164698, 0.000000000000000, +0.523324920322840, 0.000000000000000, 1.750740911548348, 0.000000000000000, -0.899333972913577, 0.000000000000000, 0.228705845203506, 0.000000000000000, +-1.934782624767648, 0.000000000000000, -3.508386237231303, 0.000000000000000, -2.107108523073510, 0.000000000000000, 0.380587645474815, 0.000000000000000, +-0.476200877183279, 0.000000000000000, -2.172086712642198, 0.000000000000000, 1.795372535780299, 0.000000000000000, -2.100318983391055, 0.000000000000000, +-0.022571122461405, 0.000000000000000, 0.674514020010955, 0.000000000000000, -0.148872569390857, 0.000000000000000, 0.298175890592737, 0.000000000000000, +-1.134244492493590, 0.000000000000000, -3.146848422289455, 0.000000000000000, -1.357950199087602, 0.000000000000000, 0.667362732020878, 0.000000000000000, +-3.119397998316724, 0.000000000000000, -1.189341126297637, 0.000000000000000, -1.532744386856668, 0.000000000000000, -1.672972484202534, 0.000000000000000, +-2.042283373871558, 0.000000000000000, -1.479481547595924, 0.000000000000000, -0.002668662875396, 0.000000000000000, 0.262737760129546, 0.000000000000000, +2.734456080621830, 0.000000000000000, -0.671945925075102, 0.000000000000000, -3.735078262179111, 0.000000000000000, -0.161705013319883, 0.000000000000000, +0.748963512361001, 0.000000000000000, 1.128046374367600, 0.000000000000000, 0.649651335592966, 0.000000000000000, 1.880020215025867, 0.000000000000000, +-1.095632293842306, 0.000000000000000, 1.197764876160487, 0.000000000000000, 0.323646656252985, 0.000000000000000, -1.655502751114502, 0.000000000000000, +3.666399062961496, 0.000000000000000, -0.334060899735197, 0.000000000000000, -2.119056978738397, 0.000000000000000, 3.721375117275012, 0.000000000000000, +0.044874186872307, 0.000000000000000, -2.733053897593234, 0.000000000000000, 1.590700278891042, 0.000000000000000, 3.215711772781902, 0.000000000000000, +-1.792085012843801, 0.000000000000000, -0.405797188885475, 0.000000000000000, -0.628080020080892, 0.000000000000000, -1.831815840843960, 0.000000000000000, +2.973656862522834, 0.000000000000000, -0.212032655138417, 0.000000000000000, 0.372437389437234, 0.000000000000000, -1.614030579023492, 0.000000000000000, +-0.704900996358698, 0.000000000000000, 1.123700273452105, 0.000000000000000, -0.136371848130819, 0.000000000000000, 3.020284357635585, 0.000000000000000, +-0.550211350877649, 0.000000000000000, 5.101256236381711, 0.000000000000000, 3.367051512192333, 0.000000000000000, -4.385131946669234, 0.000000000000000, +-3.967303337694391, 0.000000000000000, -0.965894936640022, 0.000000000000000, 0.328366945264681, 0.000000000000000, 0.199041562924914, 0.000000000000000, +1.067681999025495, 0.000000000000000, -1.939516091697170, 0.000000000000000, -1.092980954328824, 0.000000000000000, 0.273786079368066, 0.000000000000000, +-0.040928322190265, 0.000000000000000, -0.118368078577437, 0.000000000000000, 1.766589628899997, 0.000000000000000, 1.738321311635393, 0.000000000000000, +-2.895012794321649, 0.000000000000000, 1.213521771395142, 0.000000000000000, 0.922971726633985, 0.000000000000000, 1.091516563636489, 0.000000000000000, +3.226378465469620, 0.000000000000000, 1.149169778666974, 0.000000000000000, -1.695986327709386, 0.000000000000000, -0.974803077355813, 0.000000000000000, +-4.898035507513607, 0.000000000000000, 1.622719302889447, 0.000000000000000, 0.583891313586579, 0.000000000000000, -1.677182424094957, 0.000000000000000, +-1.915633132814685, 0.000000000000000, -1.980150370851616, 0.000000000000000, 0.604538269404190, 0.000000000000000, 0.939862406149365, 0.000000000000000, +-1.266939874246416, 0.000000000000000, -1.494771249200063, 0.000000000000000, 0.278042784093988, 0.000000000000000, 0.326627416008916, 0.000000000000000, +-1.914530157643303, 0.000000000000000, 1.908947721862196, 0.000000000000000, 0.531819285694044, 0.000000000000000, 3.056856632319658, 0.000000000000000, +-0.389241827774643, 0.000000000000000, -2.418606606780420, 0.000000000000000, 0.915299238878703, 0.000000000000000, -0.098774174295283, 0.000000000000000, +-0.906199428444304, 0.000000000000000, 0.316716451217743, 0.000000000000000, -4.367700643578311, 0.000000000000000, 1.491687997515293, 0.000000000000000, +-1.962381126288365, 0.000000000000000, -0.700829196527045, 0.000000000000000, 3.028958963615630, 0.000000000000000, -2.313461067462598, 0.000000000000000, +-1.431933239886712, 0.000000000000000, -0.831153039725342, 0.000000000000000, 3.939495598250743, 0.000000000000000, 0.342974753984771, 0.000000000000000, +-2.768330763002974, 0.000000000000000, -2.744010370019008, 0.000000000000000, 3.821352685212561, 0.000000000000000, 4.551065271455856, 0.000000000000000, +3.270136437041298, 0.000000000000000, -3.188028411950982, 0.000000000000000, -0.777075012417436, 0.000000000000000, 0.097110650265216, 0.000000000000000, +1.221216137608812, 0.000000000000000, -1.325824244541822, 0.000000000000000, -2.655296734084113, 0.000000000000000, -1.074792144885704, 0.000000000000000, +2.770401584439407, 0.000000000000000, 5.240270645610543, 0.000000000000000, 0.108576672208892, 0.000000000000000, -1.209394350650142, 0.000000000000000, +1.403344353838785, 0.000000000000000, -0.299032904177277, 0.000000000000000, 4.074959450638227, 0.000000000000000, 1.718727473952107, 0.000000000000000, +-3.061349227080806, 0.000000000000000, -1.158596888541269, 0.000000000000000, 3.381858904662625, 0.000000000000000, 0.957339964054052, 0.000000000000000, +0.179900074904899, 0.000000000000000, -3.909641902506081, 0.000000000000000, 0.805717289408649, 0.000000000000000, 2.047413793928261, 0.000000000000000, +-1.273580225826614, 0.000000000000000, -2.681359186869971, 0.000000000000000, -0.721241345822093, 0.000000000000000, -1.613090681569475, 0.000000000000000, +0.463138804815955, 0.000000000000000, 0.377223507800954, 0.000000000000000, 2.046550684968141, 0.000000000000000, 0.178508732797712, 0.000000000000000, +-0.477815330358845, 0.000000000000000, 3.763355908332053, 0.000000000000000, 1.300430303035163, 0.000000000000000, -0.214625793857725, 0.000000000000000, +1.343267891864081, 0.000000000000000, -0.340007682433245, 0.000000000000000, 2.062703194680005, 0.000000000000000, 0.042032160234235, 0.000000000000000, +0.643732569732250, 0.000000000000000, -1.913502543857589, 0.000000000000000, 3.771340762937158, 0.000000000000000, 1.050024807363386, 0.000000000000000, +-4.440489488592649, 0.000000000000000, 0.444904302066643, 0.000000000000000, 2.898702265650048, 0.000000000000000, 1.953232980548558, 0.000000000000000, +2.761564952735079, 0.000000000000000, 1.963537633260397, 0.000000000000000, -2.168858472916215, 0.000000000000000, -4.116235357699841, 0.000000000000000, +4.183678271896528, 0.000000000000000, 0.600422284944681, 0.000000000000000, -0.659352647255126, 0.000000000000000, -0.993127338218109, 0.000000000000000, +-2.463571314945747, 0.000000000000000, 0.937720951545881, 0.000000000000000, -3.098957308429730, 0.000000000000000, -2.354719140045463, 0.000000000000000, +-0.417285119323949, 0.000000000000000, 2.187974075975947, 0.000000000000000, 1.101468905172585, 0.000000000000000, -3.185800678152109, 0.000000000000000, +2.357534709345083, 0.000000000000000, 0.246645606729407, 0.000000000000000, 4.440905650784504, 0.000000000000000, -2.236807716637866, 0.000000000000000, +-2.171481518317550, 0.000000000000000, -2.029571795072690, 0.000000000000000, 0.135599790431348, 0.000000000000000, -1.277965265520191, 0.000000000000000, +-1.927976233157507, 0.000000000000000, -5.434492783745394, 0.000000000000000, -2.026375829312657, 0.000000000000000, 1.009666016819321, 0.000000000000000, +0.238549782367247, 0.000000000000000, -0.516403923971309, 0.000000000000000, -0.933977817429352, 0.000000000000000, 0.155803015935614, 0.000000000000000, +-0.396194809997929, 0.000000000000000, -0.915178100253214, 0.000000000000000, 0.666329367985015, 0.000000000000000, -1.517991149945785, 0.000000000000000, +0.458266744144822, 0.000000000000000, -1.242845974381418, 0.000000000000000, 0.057914823556477, 0.000000000000000, 0.994101307476875, 0.000000000000000, +-2.387209849199325, 0.000000000000000, 0.459297048883826, 0.000000000000000, 0.227711405683905, 0.000000000000000, 0.030255073506117, 0.000000000000000, +-1.323361608181337, 0.000000000000000, -4.650244457426706, 0.000000000000000, 0.062908579526021, 0.000000000000000, 3.462831028244432, 0.000000000000000, +1.303608183314856, 0.000000000000000, -1.430415193881612, 0.000000000000000, -1.672886118942142, 0.000000000000000, 0.992890699210099, 0.000000000000000, +-0.160814531784247, 0.000000000000000, -1.238132939350430, 0.000000000000000, -0.589223271459376, 0.000000000000000, 2.326363810561534, 0.000000000000000, +-4.433789496230785, 0.000000000000000, 1.664686987538929, 0.000000000000000, -2.366128834617921, 0.000000000000000, 1.212421570743837, 0.000000000000000, +-4.847914267690055, 0.000000000000000, 0.228485221404712, 0.000000000000000, 0.466139765470957, 0.000000000000000, -1.344202776943546, 0.000000000000000, +-1.012053673330574, 0.000000000000000, -2.844980626424742, 0.000000000000000, -1.552703722026340, 0.000000000000000, -1.448830983885038, 0.000000000000000, +0.127010756753980, 0.000000000000000, -1.667188263752299, 0.000000000000000, 3.424818052085100, 0.000000000000000, 0.956291135453840, 0.000000000000000, +-3.725533331754662, 0.000000000000000, -1.584534272368832, 0.000000000000000, -1.654148210472472, 0.000000000000000, 0.701610500675698, 0.000000000000000, +0.164954538683927, 0.000000000000000, -0.739260064712987, 0.000000000000000, -2.167324026090101, 0.000000000000000, -0.310240491909496, 0.000000000000000, +-2.281790349106906, 0.000000000000000, 1.719655331305361, 0.000000000000000, -2.997005923606441, 0.000000000000000, -1.999301431556852, 0.000000000000000, +-0.292229010068828, 0.000000000000000, 1.172317994855851, 0.000000000000000, 0.196734885241533, 0.000000000000000, 2.981365193477068, 0.000000000000000, +2.637726016926352, 0.000000000000000, 1.434045125217982, 0.000000000000000, 0.883627180451827, 0.000000000000000, -1.434040761445747, 0.000000000000000, +-1.528891971086553, 0.000000000000000, -3.306913135367542, 0.000000000000000, -0.399059265470646, 0.000000000000000, -0.265674394285178, 0.000000000000000, +3.502591252855384, 0.000000000000000, 0.830301156604454, 0.000000000000000, -0.220021317046083, 0.000000000000000, -0.090553770476646, 0.000000000000000, +0.771863477047951, 0.000000000000000, 1.351209629105760, 0.000000000000000, 3.773699756201963, 0.000000000000000, 0.472600118752329, 0.000000000000000, +2.332825668012222, 0.000000000000000, 1.853747950314528, 0.000000000000000, 0.759515251766178, 0.000000000000000, 1.327112776215496, 0.000000000000000, +2.518730296237868, 0.000000000000000, 0.764450208786353, 0.000000000000000, -0.278275349491296, 0.000000000000000, -0.041559465082020, 0.000000000000000, +1.387166083167787, 0.000000000000000, 2.612996769598122, 0.000000000000000, -0.385404831721799, 0.000000000000000, 2.005630016170309, 0.000000000000000, +-0.950500047307998, 0.000000000000000, -1.166884021392492, 0.000000000000000, 1.432973552928162, 0.000000000000000, 2.540370505384567, 0.000000000000000, +-1.140505295054501, 0.000000000000000, -3.673358835201185, 0.000000000000000, -0.450691288038056, 0.000000000000000, 1.601024294408014, 0.000000000000000, +0.773213556014045, 0.000000000000000, 2.973873693246168, 0.000000000000000, -1.361548406382279, 0.000000000000000, 1.409136332424815, 0.000000000000000, +-0.963382518314713, 0.000000000000000, -2.031268227368161, 0.000000000000000, 0.983309972085586, 0.000000000000000, -3.461412488471631, 0.000000000000000, +-2.601124929406039, 0.000000000000000, -0.533896239766343, 0.000000000000000, -2.627129008866350, 0.000000000000000, 0.622111169161305, 0.000000000000000, +-1.160926365580422, 0.000000000000000, -2.406196188132628, 0.000000000000000, -1.076870362758737, 0.000000000000000, -1.791866820937175, 0.000000000000000, +-0.749453071522325, 0.000000000000000, -5.324156615990973, 0.000000000000000, -1.038698022238289, 0.000000000000000, -2.106629944730630, 0.000000000000000, +0.659295598564773, 0.000000000000000, 0.520940881580988, 0.000000000000000, -0.055649203928700, 0.000000000000000, 0.292096765423137, 0.000000000000000, +-4.663743901790872, 0.000000000000000, -0.125066503391666, 0.000000000000000, -2.452620252445380, 0.000000000000000, -0.712128227397468, 0.000000000000000, +-0.048938037970968, 0.000000000000000, -1.821520226003361, 0.000000000000000, 0.810106421304257, 0.000000000000000, -0.196636623956257, 0.000000000000000, +-0.701769836763804, 0.000000000000000, 2.460345045649201, 0.000000000000000, 3.506597671641116, 0.000000000000000, -2.711322611972225, 0.000000000000000, +-0.658079876600542, 0.000000000000000, -2.040082099646173, 0.000000000000000, 2.201668355395807, 0.000000000000000, 1.181507395879711, 0.000000000000000, +-1.640739552179682, 0.000000000000000, -1.613393726467190, 0.000000000000000, -1.156741241731352, 0.000000000000000, 2.527773464519963, 0.000000000000000, +-0.497040638009502, 0.000000000000000, -0.975817112895589, 0.000000000000000, -2.866830755546166, 0.000000000000000, 1.120214498507878, 0.000000000000000, +5.986771654661698, 0.000000000000000, 0.398219252656757, 0.000000000000000, -3.545606013198135, 0.000000000000000, 0.312398099396191, 0.000000000000000, +-2.265327979531788, 0.000000000000000, 0.792121001107366, 0.000000000000000, -3.736145137670100, 0.000000000000000, 0.762228883650802, 0.000000000000000, +2.283545661214646, 0.000000000000000, 3.780020629583529, 0.000000000000000, 3.117260228608810, 0.000000000000000, -2.011159255609613, 0.000000000000000, +0.279107700476072, 0.000000000000000, 2.003369134246936, 0.000000000000000, -1.448171234480257, 0.000000000000000, 0.584697150310140, 0.000000000000000, +0.919508663636197, 0.000000000000000, -3.071349141675388, 0.000000000000000, -1.555923649263667, 0.000000000000000, 2.232497079438850, 0.000000000000000, +-0.012662139119883, 0.000000000000000, 0.372825540734715, 0.000000000000000, 2.378543590847629, 0.000000000000000, 1.459053407813062, 0.000000000000000, +-0.967913907390927, 0.000000000000000, 1.322825200678212, 0.000000000000000, -1.033775820061824, 0.000000000000000, -1.813629552693142, 0.000000000000000, +4.794348161661486, 0.000000000000000, 0.655279811518676, 0.000000000000000, -2.224590138589720, 0.000000000000000, 0.595329481295766, 0.000000000000000, +3.364055988866225, 0.000000000000000, 1.863416422998127, 0.000000000000000, 1.930305751828105, 0.000000000000000, -0.284467053432545, 0.000000000000000, +-0.923374905878938, 0.000000000000000, 1.922988234041399, 0.000000000000000, 0.310482143432719, 0.000000000000000, 0.332122302397134, 0.000000000000000, +-1.659487472408966, 0.000000000000000, -1.865943507877961, 0.000000000000000, -0.186775297569864, 0.000000000000000, -1.700543850628361, 0.000000000000000, +0.497157959366735, 0.000000000000000, -0.471244843957418, 0.000000000000000, -0.432013753969948, 0.000000000000000, -4.000189880113231, 0.000000000000000, +-0.415335170016467, 0.000000000000000, 0.317311950972859, 0.000000000000000, 0.038393428927595, 0.000000000000000, 0.177219909465206, 0.000000000000000, +0.531650958095143, 0.000000000000000, -2.711644985175806, 0.000000000000000, 0.328744077805156, 0.000000000000000, -0.938417707547928, 0.000000000000000, +0.970379584897379, 0.000000000000000, 1.873649473917137, 0.000000000000000, 0.177938226987023, 0.000000000000000, 0.155609346302393, 0.000000000000000, +-1.276504241867208, 0.000000000000000, -0.463725075928807, 0.000000000000000, -0.064748250389500, 0.000000000000000, -1.725568534062385, 0.000000000000000, +-0.139066584804067, 0.000000000000000, 1.975514554117767, 0.000000000000000, -0.807063199499478, 0.000000000000000, -0.326926659682788, 0.000000000000000, +1.445727032487938, 0.000000000000000, -0.597151107739100, 0.000000000000000, 2.732557531709386, 0.000000000000000, -2.907130934109188, 0.000000000000000, +-1.461264832679981, 0.000000000000000, -1.708588604968163, 0.000000000000000, 3.652851925431363, 0.000000000000000, 0.682050868282879, 0.000000000000000, +-0.281312579963294, 0.000000000000000, 0.554966483307825, 0.000000000000000, -0.981341739340932, 0.000000000000000, 1.279543331141603, 0.000000000000000, +0.036589747826856, 0.000000000000000, 2.312073745896073, 0.000000000000000, 1.754682200732425, 0.000000000000000, -0.957515875428627, 0.000000000000000, +-0.833596942819695, 0.000000000000000, 0.437054368791033, 0.000000000000000, -0.898819399360279, 0.000000000000000, -0.296050580896839, 0.000000000000000, +-0.785144257649601, 0.000000000000000, -2.541503089003311, 0.000000000000000, 2.225075846758761, 0.000000000000000, -1.587290487902002, 0.000000000000000, +-1.421404172056462, 0.000000000000000, -3.015149802293631, 0.000000000000000, 1.780874288867949, 0.000000000000000, -0.865812740882613, 0.000000000000000, +-2.845327531197112, 0.000000000000000, 1.445225867774367, 0.000000000000000, 2.183733236584647, 0.000000000000000, 1.163371072749080, 0.000000000000000, +0.883547693520409, 0.000000000000000, -1.224093106684675, 0.000000000000000, -1.854501116331044, 0.000000000000000, 1.783082089255796, 0.000000000000000, +2.301508706196191, 0.000000000000000, -0.539901944139077, 0.000000000000000, 1.962315832319967, 0.000000000000000, -0.060709041870503, 0.000000000000000, +-1.353139923300238, 0.000000000000000, -1.482887537805234, 0.000000000000000, 1.273732601967176, 0.000000000000000, -3.456609915556321, 0.000000000000000, +-3.752320586540873, 0.000000000000000, 3.536356614978951, 0.000000000000000, 0.206035952043233, 0.000000000000000, 5.933966913773842, 0.000000000000000, +-0.486633898075490, 0.000000000000000, -0.329595089863342, 0.000000000000000, 1.496414153905337, 0.000000000000000, 0.137868749388880, 0.000000000000000, +-0.437192030996792, 0.000000000000000, 2.682750615210656, 0.000000000000000, -2.440234892848570, 0.000000000000000, 1.433910252426186, 0.000000000000000, +-0.415051506104074, 0.000000000000000, 1.982003013708649, 0.000000000000000, 1.345796609972435, 0.000000000000000, -2.335949513404370, 0.000000000000000, +1.065988867433025, 0.000000000000000, 2.741844905000464, 0.000000000000000, -1.754047930934362, 0.000000000000000, 0.229252730015575, 0.000000000000000, +-0.679791016408669, 0.000000000000000, -2.274097820043743, 0.000000000000000, 0.149802252231876, 0.000000000000000, -0.139697151364830, 0.000000000000000, +-2.773367420505435, 0.000000000000000, -4.403400246165611, 0.000000000000000, -1.468974515184135, 0.000000000000000, 0.664990623095844, 0.000000000000000, +-3.446979775557143, 0.000000000000000, 1.850006428987618, 0.000000000000000, -1.550866747921936, 0.000000000000000, -3.632874882935257, 0.000000000000000, +0.828039662992464, 0.000000000000000, 2.794055182632816, 0.000000000000000, -0.593995716682633, 0.000000000000000, 0.142788156054200, 0.000000000000000, +0.552461945119668, 0.000000000000000, 0.842127129738758, 0.000000000000000, 1.414335509600077, 0.000000000000000, -0.311559241382430, 0.000000000000000, +1.510590844695250, 0.000000000000000, 1.692217183824300, 0.000000000000000, 0.613760285711957, 0.000000000000000, 0.065233463207770, 0.000000000000000, +-2.571912893711505, 0.000000000000000, -1.707001531141341, 0.000000000000000, 0.673884968382041, 0.000000000000000, 0.889863883420103, 0.000000000000000, +-2.395635435233346, 0.000000000000000, 1.129247296359819, 0.000000000000000, 0.569074704779735, 0.000000000000000, 6.139436017480722, 0.000000000000000, +0.822158309259017, 0.000000000000000, -3.289872016222589, 0.000000000000000, 0.417612988384414, 0.000000000000000, 1.493982103868165, 0.000000000000000, +-0.415353391377005, 0.000000000000000, 0.288670764933155, 0.000000000000000, -1.895650228872272, 0.000000000000000, -0.139631694475020, 0.000000000000000, +1.445103299005436, 0.000000000000000, 2.877182243683429, 0.000000000000000, 1.192428490172580, 0.000000000000000, -5.964591921763842, 0.000000000000000, +0.570859795882959, 0.000000000000000, 2.328333316356666, 0.000000000000000, 0.333755014930026, 0.000000000000000, 1.221901577771909, 0.000000000000000, +0.943358697415568, 0.000000000000000, 2.793063983613067, 0.000000000000000, 3.163005066073616, 0.000000000000000, 2.098300664513867, 0.000000000000000, +-3.915313164333447, 0.000000000000000, -2.475766769064539, 0.000000000000000, 1.720472044894277, 0.000000000000000, -1.273591949275665, 0.000000000000000, +-1.213451272938616, 0.000000000000000, 0.697439404325690, 0.000000000000000, -0.309902287574293, 0.000000000000000, 2.622575852162781, 0.000000000000000, +-2.075881936219060, 0.000000000000000, 0.777847545691770, 0.000000000000000, -3.967947986440650, 0.000000000000000, -3.066503371806472, 0.000000000000000, +1.193780625937845, 0.000000000000000, 0.214246579281311, 0.000000000000000, -2.610681491162162, 0.000000000000000, -1.261224183972745, 0.000000000000000, +-1.165071748544285, 0.000000000000000, -1.116548474834374, 0.000000000000000, 0.847202164846982, 0.000000000000000, -3.474301529532390, 0.000000000000000, +0.020799541946476, 0.000000000000000, -3.868995473288166, 0.000000000000000, 1.757979409638067, 0.000000000000000, 0.868115130183109, 0.000000000000000, +0.910167436737958, 0.000000000000000, -1.878855115563720, 0.000000000000000, 1.710357104174161, 0.000000000000000, -1.468933980990902, 0.000000000000000, +1.799544171601169, 0.000000000000000, -4.922332880027887, 0.000000000000000, 0.219424548939720, 0.000000000000000, -0.971671113451924, 0.000000000000000, +-0.940533475616266, 0.000000000000000, 0.122510114412152, 0.000000000000000, -1.373686254916911, 0.000000000000000, 1.760348103896323, 0.000000000000000, +0.391745067829643, 0.000000000000000, 2.521958505327354, 0.000000000000000, -1.300693516405092, 0.000000000000000, -0.538251788309178, 0.000000000000000, +0.797184135810173, 0.000000000000000, 2.908800548982588, 0.000000000000000, 1.590902251655215, 0.000000000000000, -1.070323714487264, 0.000000000000000, +-3.349764443340999, 0.000000000000000, -1.190563529731447, 0.000000000000000, 1.363369471291963, 0.000000000000000, -1.814270299924576, 0.000000000000000, +-0.023381588315711, 0.000000000000000, 1.719182048679569, 0.000000000000000, 0.839917213252626, 0.000000000000000, 1.006099633839122, 0.000000000000000, +0.812462674381527, 0.000000000000000, 1.755814336346739, 0.000000000000000, 2.546848681206319, 0.000000000000000, -1.555300208869455, 0.000000000000000, +1.017053811631167, 0.000000000000000, 0.996591039170903, 0.000000000000000, -1.228047247924881, 0.000000000000000, 4.809462271463009, 0.000000000000000, +2.318113116151685, 0.000000000000000, -1.206932520679733, 0.000000000000000, 1.273757685623312, 0.000000000000000, 0.724335352481802, 0.000000000000000, +1.519876652073198, 0.000000000000000, -2.749670314714158, 0.000000000000000, 3.424042481847581, 0.000000000000000, -3.714668360421517, 0.000000000000000, +1.612834197004014, 0.000000000000000, -2.038234723985566, 0.000000000000000, 1.470938786562152, 0.000000000000000, 2.111634918450302, 0.000000000000000, +1.030376670151787, 0.000000000000000, -0.420877189003829, 0.000000000000000, -1.502024800532894, 0.000000000000000, 0.452310749163804, 0.000000000000000, +-1.606059382300987, 0.000000000000000, -4.006159967834147, 0.000000000000000, -2.152801208196508, 0.000000000000000, 1.671674089372579, 0.000000000000000, +1.714536333564101, 0.000000000000000, -1.011518543005344, 0.000000000000000, -0.576410282180584, 0.000000000000000, 0.733689809480836, 0.000000000000000, +1.004245602717974, 0.000000000000000, 1.010090391888449, 0.000000000000000, 3.811459513385621, 0.000000000000000, -5.230621089271954, 0.000000000000000, +0.678044861034399, 0.000000000000000, 1.255935859598107, 0.000000000000000, 1.674521701615288, 0.000000000000000, -1.656695216761705, 0.000000000000000, +1.169286028869693, 0.000000000000000, 0.524915416191998, 0.000000000000000, 2.397642885039520, 0.000000000000000, 2.108711400616072, 0.000000000000000, +2.037618211018084, 0.000000000000000, -0.623664553406925, 0.000000000000000, 2.984106170984409, 0.000000000000000, 1.132182737400932, 0.000000000000000, +-2.859274340352130, 0.000000000000000, -0.975550071398723, 0.000000000000000, -1.359935119997407, 0.000000000000000, -2.963308211050121, 0.000000000000000, +-0.228726662781163, 0.000000000000000, -1.411110379682043, 0.000000000000000, 0.741553355734225, 0.000000000000000, 0.497554254758309, 0.000000000000000, +2.371907950598855, 0.000000000000000, 1.063465168988748, 0.000000000000000, -0.641082692081488, 0.000000000000000, -0.855439878540726, 0.000000000000000, +0.578321738578726, 0.000000000000000, 3.005809768796194, 0.000000000000000, 1.961458699064065, 0.000000000000000, -3.206261663772745, 0.000000000000000, +-0.364431989095434, 0.000000000000000, -0.263182496622273, 0.000000000000000, 1.843464680631139, 0.000000000000000, -0.419107530229249, 0.000000000000000, +1.662335873298487, 0.000000000000000, -0.853687563304005, 0.000000000000000, -2.584133404357169, 0.000000000000000, 3.466839568922895, 0.000000000000000, +0.881671345091973, 0.000000000000000, 0.454620014206908, 0.000000000000000, -1.737245187402739, 0.000000000000000, 2.162713238369243, 0.000000000000000, +-3.868539002714486, 0.000000000000000, 2.014114855933826, 0.000000000000000, -0.703233831811006, 0.000000000000000, -3.410319935997574, 0.000000000000000, +-1.851235811006584, 0.000000000000000, 0.909783907894036, 0.000000000000000, 0.091884002136728, 0.000000000000000, -2.688294201131650, 0.000000000000000, +-0.906134178460955, 0.000000000000000, 3.475054609035133, 0.000000000000000, -0.573927964170323, 0.000000000000000, -0.429542937515399, 0.000000000000000, +0.991348618739939, 0.000000000000000, 1.974804904926325, 0.000000000000000, 0.975783450796698, 0.000000000000000, -3.057119549071503, 0.000000000000000, +-3.899429237481194, 0.000000000000000, 0.362439009175350, 0.000000000000000, -1.124461670265618, 0.000000000000000, 1.806000360163583, 0.000000000000000, +-2.768333362600288, 0.000000000000000, 0.244387897900379, 0.000000000000000, 0.908767296720926, 0.000000000000000, 1.254669374391882, 0.000000000000000, +-1.420441929463686, 0.000000000000000, -0.875658895966293, 0.000000000000000, 0.183824603376167, 0.000000000000000, -3.361653917011686, 0.000000000000000, +-0.796615630227952, 0.000000000000000, -1.660226542658673, 0.000000000000000, 1.654439358307226, 0.000000000000000, 2.782812946709771, 0.000000000000000, +1.418064412811531, 0.000000000000000, -0.819645647243761, 0.000000000000000, 0.807724772592699, 0.000000000000000, -0.941967976379298, 0.000000000000000, +-2.312768306047469, 0.000000000000000, 0.872426936477443, 0.000000000000000, 0.919528961530845, 0.000000000000000, -2.084904575264847, 0.000000000000000, +-1.972464868459322, 0.000000000000000, -1.050687203338466, 0.000000000000000, 1.659579707007902, 0.000000000000000, -1.820640014705855, 0.000000000000000, +-1.195078061671045, 0.000000000000000, -1.639773173762048, 0.000000000000000, 1.616744338157063, 0.000000000000000, 4.019216096811563, 0.000000000000000, +3.461021102549681, 0.000000000000000, 1.642352734361484, 0.000000000000000, -0.046354693720813, 0.000000000000000, -0.041936252359677, 0.000000000000000, +-2.393307519480551, 0.000000000000000, -0.341471634615121, 0.000000000000000, -0.392073595257017, 0.000000000000000, -0.219299018372730, 0.000000000000000, +-2.016391579662071, 0.000000000000000, -0.653096251969787, 0.000000000000000, 1.466353155666821, 0.000000000000000, -2.872058864320412, 0.000000000000000, +-2.157180779503830, 0.000000000000000, 0.723257479841560, 0.000000000000000, 3.769951308104384, 0.000000000000000, -1.923392042420024, 0.000000000000000, +0.644899359942840, 0.000000000000000, -2.090226891621437, 0.000000000000000, -0.277043982890403, 0.000000000000000, -0.528271428321112, 0.000000000000000, +2.518120645960652, 0.000000000000000, 1.040820431111488, 0.000000000000000, -4.560583754742486, 0.000000000000000, -0.226899614918836, 0.000000000000000, +1.713331231108959, 0.000000000000000, -3.293941019163642, 0.000000000000000, -1.113331444648290, 0.000000000000000, -1.032308423149906, 0.000000000000000, +1.593774272982443, 0.000000000000000, -1.246840475090529, 0.000000000000000, -0.190344684920137, 0.000000000000000, -1.719386356896355, 0.000000000000000, +-2.827721754659679, 0.000000000000000, -0.092438285279020, 0.000000000000000, -0.565844430675246, 0.000000000000000, -1.077916121691716, 0.000000000000000, +-1.208665809504693, 0.000000000000000, -2.996014266381254, 0.000000000000000, 2.888573323402423, 0.000000000000000, 2.829507048720695, 0.000000000000000, +-0.859177034120755, 0.000000000000000, -1.969302377743254, 0.000000000000000, 0.777437674525362, 0.000000000000000, -0.124910190157646, 0.000000000000000, +0.129875493115290, 0.000000000000000, -4.192139262163992, 0.000000000000000, 3.023496047962126, 0.000000000000000, 1.149775163736637, 0.000000000000000, +2.038151304801731, 0.000000000000000, 3.016122489841263, 0.000000000000000, -4.829481812137012, 0.000000000000000, -1.668436615909279, 0.000000000000000, +0.958586784636918, 0.000000000000000, 1.550652410058678, 0.000000000000000, -1.456305257976716, 0.000000000000000, -0.079588392344731, 0.000000000000000, +-2.453213599392345, 0.000000000000000, 0.296795909127105, 0.000000000000000, -0.253426616607643, 0.000000000000000, 1.418937160028195, 0.000000000000000, +-1.672949529066915, 0.000000000000000, -1.620990298572947, 0.000000000000000, -1.085103073196045, 0.000000000000000, 0.738606361195386, 0.000000000000000, +-2.097831202853255, 0.000000000000000, 2.711952282071310, 0.000000000000000, 1.498539238246888, 0.000000000000000, 1.317457282535915, 0.000000000000000, +-0.302765938349717, 0.000000000000000, -0.044623707947201, 0.000000000000000, 2.337405215062395, 0.000000000000000, -3.980689173859100, 0.000000000000000, + + +}; + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_example_f32.c new file mode 100644 index 0000000..91d15b5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fft_bin_example/arm_fft_bin_example_f32.c @@ -0,0 +1,158 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_fft_bin_example_f32.c +* +* Description: Example code demonstrating calculation of Max energy bin of +* frequency domain of input signal. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup FrequencyBin Frequency Bin Example + * + * \par Description + * \par + * Demonstrates the calculation of the maximum energy bin in the frequency + * domain of the input signal with the use of Complex FFT, Complex + * Magnitude, and Maximum functions. + * + * \par Algorithm: + * \par + * The input test signal contains a 10 kHz signal with uniformly distributed white noise. + * Calculating the FFT of the input signal will give us the maximum energy of the + * bin corresponding to the input frequency of 10 kHz. + * + * \par Block Diagram: + * \image html FFTBin.gif "Block Diagram" + * \par + * The figure below shows the time domain signal of 10 kHz signal with + * uniformly distributed white noise, and the next figure shows the input + * in the frequency domain. The bin with maximum energy corresponds to 10 kHz signal. + * \par + * \image html FFTBinInput.gif "Input signal in Time domain" + * \image html FFTBinOutput.gif "Input signal in Frequency domain" + * + * \par Variables Description: + * \par + * \li \c testInput_f32_10khz points to the input data + * \li \c testOutput points to the output data + * \li \c fftSize length of FFT + * \li \c ifftFlag flag for the selection of CFFT/CIFFT + * \li \c doBitReverse Flag for selection of normal order or bit reversed order + * \li \c refIndex reference index value at which maximum energy of bin ocuurs + * \li \c testIndex calculated index value at which maximum energy of bin ocuurs + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_cfft_f32() + * - arm_cmplx_mag_f32() + * - arm_max_f32() + * + * Refer + * \link arm_fft_bin_example_f32.c \endlink + * + */ + + +/** \example arm_fft_bin_example_f32.c + */ + + +#include "arm_math.h" +#include "arm_const_structs.h" + +#define TEST_LENGTH_SAMPLES 2048 + +/* ------------------------------------------------------------------- +* External Input and Output buffer Declarations for FFT Bin Example +* ------------------------------------------------------------------- */ +extern float32_t testInput_f32_10khz[TEST_LENGTH_SAMPLES]; +static float32_t testOutput[TEST_LENGTH_SAMPLES/2]; + +/* ------------------------------------------------------------------ +* Global variables for FFT Bin Example +* ------------------------------------------------------------------- */ +uint32_t fftSize = 1024; +uint32_t ifftFlag = 0; +uint32_t doBitReverse = 1; + +/* Reference index at which max energy of bin ocuurs */ +uint32_t refIndex = 213, testIndex = 0; + +/* ---------------------------------------------------------------------- +* Max magnitude FFT Bin test +* ------------------------------------------------------------------- */ + +int32_t main(void) +{ + + arm_status status; + float32_t maxValue; + + status = ARM_MATH_SUCCESS; + + /* Process the data through the CFFT/CIFFT module */ + arm_cfft_f32(&arm_cfft_sR_f32_len1024, testInput_f32_10khz, ifftFlag, doBitReverse); + + /* Process the data through the Complex Magnitude Module for + calculating the magnitude at each bin */ + arm_cmplx_mag_f32(testInput_f32_10khz, testOutput, fftSize); + + /* Calculates maxValue and returns corresponding BIN value */ + arm_max_f32(testOutput, fftSize, &maxValue, &testIndex); + + if (testIndex != refIndex) + { + status = ARM_MATH_TEST_FAILURE; + } + + /* ---------------------------------------------------------------------- + ** Loop here if the signals fail the PASS check. + ** This denotes a test failure + ** ------------------------------------------------------------------- */ + + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/Abstract.txt new file mode 100644 index 0000000..9189b7c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_fir_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_data.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_data.c new file mode 100644 index 0000000..3a95fc5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_data.c @@ -0,0 +1,134 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_fir_data.c +* +* Description: Data file used for example code +* +* Target Processor: Cortex-M4/Cortex-M3/Cortex-M0 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +#include "arm_math.h" + +/* ---------------------------------------------------------------------- +** Test input signal contains 1000Hz + 15000 Hz +** ------------------------------------------------------------------- */ + +float32_t testInput_f32_1kHz_15kHz[320] = +{ ++0.0000000000f, +0.5924659585f, -0.0947343455f, +0.1913417162f, +1.0000000000f, +0.4174197128f, +0.3535533906f, +1.2552931065f, ++0.8660254038f, +0.4619397663f, +1.3194792169f, +1.1827865776f, +0.5000000000f, +1.1827865776f, +1.3194792169f, +0.4619397663f, ++0.8660254038f, +1.2552931065f, +0.3535533906f, +0.4174197128f, +1.0000000000f, +0.1913417162f, -0.0947343455f, +0.5924659585f, +-0.0000000000f, -0.5924659585f, +0.0947343455f, -0.1913417162f, -1.0000000000f, -0.4174197128f, -0.3535533906f, -1.2552931065f, +-0.8660254038f, -0.4619397663f, -1.3194792169f, -1.1827865776f, -0.5000000000f, -1.1827865776f, -1.3194792169f, -0.4619397663f, +-0.8660254038f, -1.2552931065f, -0.3535533906f, -0.4174197128f, -1.0000000000f, -0.1913417162f, +0.0947343455f, -0.5924659585f, ++0.0000000000f, +0.5924659585f, -0.0947343455f, +0.1913417162f, +1.0000000000f, +0.4174197128f, +0.3535533906f, +1.2552931065f, ++0.8660254038f, +0.4619397663f, +1.3194792169f, +1.1827865776f, +0.5000000000f, +1.1827865776f, +1.3194792169f, +0.4619397663f, ++0.8660254038f, +1.2552931065f, +0.3535533906f, +0.4174197128f, +1.0000000000f, +0.1913417162f, -0.0947343455f, +0.5924659585f, ++0.0000000000f, -0.5924659585f, +0.0947343455f, -0.1913417162f, -1.0000000000f, -0.4174197128f, -0.3535533906f, -1.2552931065f, +-0.8660254038f, -0.4619397663f, -1.3194792169f, -1.1827865776f, -0.5000000000f, -1.1827865776f, -1.3194792169f, -0.4619397663f, +-0.8660254038f, -1.2552931065f, -0.3535533906f, -0.4174197128f, -1.0000000000f, -0.1913417162f, +0.0947343455f, -0.5924659585f, ++0.0000000000f, +0.5924659585f, -0.0947343455f, +0.1913417162f, +1.0000000000f, +0.4174197128f, +0.3535533906f, +1.2552931065f, ++0.8660254038f, +0.4619397663f, +1.3194792169f, +1.1827865776f, +0.5000000000f, +1.1827865776f, +1.3194792169f, +0.4619397663f, ++0.8660254038f, +1.2552931065f, +0.3535533906f, +0.4174197128f, +1.0000000000f, +0.1913417162f, -0.0947343455f, +0.5924659585f, ++0.0000000000f, -0.5924659585f, +0.0947343455f, -0.1913417162f, -1.0000000000f, -0.4174197128f, -0.3535533906f, -1.2552931065f, +-0.8660254038f, -0.4619397663f, -1.3194792169f, -1.1827865776f, -0.5000000000f, -1.1827865776f, -1.3194792169f, -0.4619397663f, +-0.8660254038f, -1.2552931065f, -0.3535533906f, -0.4174197128f, -1.0000000000f, -0.1913417162f, +0.0947343455f, -0.5924659585f, +-0.0000000000f, +0.5924659585f, -0.0947343455f, +0.1913417162f, +1.0000000000f, +0.4174197128f, +0.3535533906f, +1.2552931065f, ++0.8660254038f, +0.4619397663f, +1.3194792169f, +1.1827865776f, +0.5000000000f, +1.1827865776f, +1.3194792169f, +0.4619397663f, ++0.8660254038f, +1.2552931065f, +0.3535533906f, +0.4174197128f, +1.0000000000f, +0.1913417162f, -0.0947343455f, +0.5924659585f, +-0.0000000000f, -0.5924659585f, +0.0947343455f, -0.1913417162f, -1.0000000000f, -0.4174197128f, -0.3535533906f, -1.2552931065f, +-0.8660254038f, -0.4619397663f, -1.3194792169f, -1.1827865776f, -0.5000000000f, -1.1827865776f, -1.3194792169f, -0.4619397663f, +-0.8660254038f, -1.2552931065f, -0.3535533906f, -0.4174197128f, -1.0000000000f, -0.1913417162f, +0.0947343455f, -0.5924659585f, ++0.0000000000f, +0.5924659585f, -0.0947343455f, +0.1913417162f, +1.0000000000f, +0.4174197128f, +0.3535533906f, +1.2552931065f, ++0.8660254038f, +0.4619397663f, +1.3194792169f, +1.1827865776f, +0.5000000000f, +1.1827865776f, +1.3194792169f, +0.4619397663f, ++0.8660254038f, +1.2552931065f, +0.3535533906f, +0.4174197128f, +1.0000000000f, +0.1913417162f, -0.0947343455f, +0.5924659585f, ++0.0000000000f, -0.5924659585f, +0.0947343455f, -0.1913417162f, -1.0000000000f, -0.4174197128f, -0.3535533906f, -1.2552931065f, +-0.8660254038f, -0.4619397663f, -1.3194792169f, -1.1827865776f, -0.5000000000f, -1.1827865776f, -1.3194792169f, -0.4619397663f, +-0.8660254038f, -1.2552931065f, -0.3535533906f, -0.4174197128f, -1.0000000000f, -0.1913417162f, +0.0947343455f, -0.5924659585f, +-0.0000000000f, +0.5924659585f, -0.0947343455f, +0.1913417162f, +1.0000000000f, +0.4174197128f, +0.3535533906f, +1.2552931065f, ++0.8660254038f, +0.4619397663f, +1.3194792169f, +1.1827865776f, +0.5000000000f, +1.1827865776f, +1.3194792169f, +0.4619397663f, ++0.8660254038f, +1.2552931065f, +0.3535533906f, +0.4174197128f, +1.0000000000f, +0.1913417162f, -0.0947343455f, +0.5924659585f, ++0.0000000000f, -0.5924659585f, +0.0947343455f, -0.1913417162f, -1.0000000000f, -0.4174197128f, -0.3535533906f, -1.2552931065f, +-0.8660254038f, -0.4619397663f, -1.3194792169f, -1.1827865776f, -0.5000000000f, -1.1827865776f, -1.3194792169f, -0.4619397663f, +-0.8660254038f, -1.2552931065f, -0.3535533906f, -0.4174197128f, -1.0000000000f, -0.1913417162f, +0.0947343455f, -0.5924659585f, +-0.0000000000f, +0.5924659585f, -0.0947343455f, +0.1913417162f, +1.0000000000f, +0.4174197128f, +0.3535533906f, +1.2552931065f, ++0.8660254038f, +0.4619397663f, +1.3194792169f, +1.1827865776f, +0.5000000000f, +1.1827865776f, +1.3194792169f, +0.4619397663f, ++0.8660254038f, +1.2552931065f, +0.3535533906f, +0.4174197128f, +1.0000000000f, +0.1913417162f, -0.0947343455f, +0.5924659585f, ++0.0000000000f, -0.5924659585f, +0.0947343455f, -0.1913417162f, -1.0000000000f, -0.4174197128f, -0.3535533906f, -1.2552931065f, +}; + +float32_t refOutput[320] = +{ ++0.0000000000f, -0.0010797829f, -0.0007681386f, -0.0001982932f, +0.0000644313f, +0.0020854271f, +0.0036891871f, +0.0015855941f, +-0.0026280805f, -0.0075907658f, -0.0119390538f, -0.0086665968f, +0.0088981202f, +0.0430539279f, +0.0974468742f, +0.1740405600f, ++0.2681416601f, +0.3747720089f, +0.4893362230f, +0.6024154672f, +0.7058740791f, +0.7968348987f, +0.8715901940f, +0.9277881093f, ++0.9682182661f, +0.9934674267f, +1.0012052245f, +0.9925859371f, +0.9681538347f, +0.9257026822f, +0.8679010068f, +0.7952493046f, ++0.7085021596f, +0.6100062330f, +0.5012752767f, +0.3834386057f, +0.2592435399f, +0.1309866321f, -0.0000000000f, -0.1309866321f, +-0.2592435399f, -0.3834386057f, -0.5012752767f, -0.6100062330f, -0.7085021596f, -0.7952493046f, -0.8679010068f, -0.9257026822f, +-0.9681538347f, -0.9936657199f, -1.0019733630f, -0.9936657199f, -0.9681538347f, -0.9257026822f, -0.8679010068f, -0.7952493046f, +-0.7085021596f, -0.6100062330f, -0.5012752767f, -0.3834386057f, -0.2592435399f, -0.1309866321f, +0.0000000000f, +0.1309866321f, ++0.2592435399f, +0.3834386057f, +0.5012752767f, +0.6100062330f, +0.7085021596f, +0.7952493046f, +0.8679010068f, +0.9257026822f, ++0.9681538347f, +0.9936657199f, +1.0019733630f, +0.9936657199f, +0.9681538347f, +0.9257026822f, +0.8679010068f, +0.7952493046f, ++0.7085021596f, +0.6100062330f, +0.5012752767f, +0.3834386057f, +0.2592435399f, +0.1309866321f, -0.0000000000f, -0.1309866321f, +-0.2592435399f, -0.3834386057f, -0.5012752767f, -0.6100062330f, -0.7085021596f, -0.7952493046f, -0.8679010068f, -0.9257026822f, +-0.9681538347f, -0.9936657199f, -1.0019733630f, -0.9936657199f, -0.9681538347f, -0.9257026822f, -0.8679010068f, -0.7952493046f, +-0.7085021596f, -0.6100062330f, -0.5012752767f, -0.3834386057f, -0.2592435399f, -0.1309866321f, +0.0000000000f, +0.1309866321f, ++0.2592435399f, +0.3834386057f, +0.5012752767f, +0.6100062330f, +0.7085021596f, +0.7952493046f, +0.8679010068f, +0.9257026822f, ++0.9681538347f, +0.9936657199f, +1.0019733630f, +0.9936657199f, +0.9681538347f, +0.9257026822f, +0.8679010068f, +0.7952493046f, ++0.7085021596f, +0.6100062330f, +0.5012752767f, +0.3834386057f, +0.2592435399f, +0.1309866321f, -0.0000000000f, -0.1309866321f, +-0.2592435399f, -0.3834386057f, -0.5012752767f, -0.6100062330f, -0.7085021596f, -0.7952493046f, -0.8679010068f, -0.9257026822f, +-0.9681538347f, -0.9936657199f, -1.0019733630f, -0.9936657199f, -0.9681538347f, -0.9257026822f, -0.8679010068f, -0.7952493046f, +-0.7085021596f, -0.6100062330f, -0.5012752767f, -0.3834386057f, -0.2592435399f, -0.1309866321f, +0.0000000000f, +0.1309866321f, ++0.2592435399f, +0.3834386057f, +0.5012752767f, +0.6100062330f, +0.7085021596f, +0.7952493046f, +0.8679010068f, +0.9257026822f, ++0.9681538347f, +0.9936657199f, +1.0019733630f, +0.9936657199f, +0.9681538347f, +0.9257026822f, +0.8679010068f, +0.7952493046f, ++0.7085021596f, +0.6100062330f, +0.5012752767f, +0.3834386057f, +0.2592435399f, +0.1309866321f, +0.0000000000f, -0.1309866321f, +-0.2592435399f, -0.3834386057f, -0.5012752767f, -0.6100062330f, -0.7085021596f, -0.7952493046f, -0.8679010068f, -0.9257026822f, +-0.9681538347f, -0.9936657199f, -1.0019733630f, -0.9936657199f, -0.9681538347f, -0.9257026822f, -0.8679010068f, -0.7952493046f, +-0.7085021596f, -0.6100062330f, -0.5012752767f, -0.3834386057f, -0.2592435399f, -0.1309866321f, +0.0000000000f, +0.1309866321f, ++0.2592435399f, +0.3834386057f, +0.5012752767f, +0.6100062330f, +0.7085021596f, +0.7952493046f, +0.8679010068f, +0.9257026822f, ++0.9681538347f, +0.9936657199f, +1.0019733630f, +0.9936657199f, +0.9681538347f, +0.9257026822f, +0.8679010068f, +0.7952493046f, ++0.7085021596f, +0.6100062330f, +0.5012752767f, +0.3834386057f, +0.2592435399f, +0.1309866321f, +0.0000000000f, -0.1309866321f, +-0.2592435399f, -0.3834386057f, -0.5012752767f, -0.6100062330f, -0.7085021596f, -0.7952493046f, -0.8679010068f, -0.9257026822f, +-0.9681538347f, -0.9936657199f, -1.0019733630f, -0.9936657199f, -0.9681538347f, -0.9257026822f, -0.8679010068f, -0.7952493046f, +-0.7085021596f, -0.6100062330f, -0.5012752767f, -0.3834386057f, -0.2592435399f, -0.1309866321f, -0.0000000000f, +0.1309866321f, ++0.2592435399f, +0.3834386057f, +0.5012752767f, +0.6100062330f, +0.7085021596f, +0.7952493046f, +0.8679010068f, +0.9257026822f, ++0.9681538347f, +0.9936657199f, +1.0019733630f, +0.9936657199f, +0.9681538347f, +0.9257026822f, +0.8679010068f, +0.7952493046f, ++0.7085021596f, +0.6100062330f, +0.5012752767f, +0.3834386057f, +0.2592435399f, +0.1309866321f, +0.0000000000f, -0.1309866321f, +-0.2592435399f, -0.3834386057f, -0.5012752767f, -0.6100062330f, -0.7085021596f, -0.7952493046f, -0.8679010068f, -0.9257026822f, +-0.9681538347f, -0.9936657199f, -1.0019733630f, -0.9936657199f, -0.9681538347f, -0.9257026822f, -0.8679010068f, -0.7952493046f, +-0.7085021596f, -0.6100062330f, -0.5012752767f, -0.3834386057f, -0.2592435399f, -0.1309866321f, +0.0000000000f, +0.1309866321f, ++0.2592435399f, +0.3834386057f, +0.5012752767f, +0.6100062330f, +0.7085021596f, +0.7952493046f, +0.8679010068f, +0.9257026822f, ++0.9681538347f, +0.9936657199f, +1.0019733630f, +0.9936657199f, +0.9681538347f, +0.9257026822f, +0.8679010068f, +0.7952493046f +}; + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_example_f32.c new file mode 100644 index 0000000..3dd9f5a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/arm_fir_example_f32.c @@ -0,0 +1,233 @@ +/* ---------------------------------------------------------------------- + * Copyright (C) 2010-2012 ARM Limited. All rights reserved. + * +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library + * Title: arm_fir_example_f32.c + * + * Description: Example code demonstrating how an FIR filter can be used + * as a low pass filter. + * + * Target Processor: Cortex-M4/Cortex-M3 + * +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup FIRLPF FIR Lowpass Filter Example + * + * \par Description: + * \par + * Removes high frequency signal components from the input using an FIR lowpass filter. + * The example demonstrates how to configure an FIR filter and then pass data through + * it in a block-by-block fashion. + * \image html FIRLPF_signalflow.gif + * + * \par Algorithm: + * \par + * The input signal is a sum of two sine waves: 1 kHz and 15 kHz. + * This is processed by an FIR lowpass filter with cutoff frequency 6 kHz. + * The lowpass filter eliminates the 15 kHz signal leaving only the 1 kHz sine wave at the output. + * \par + * The lowpass filter was designed using MATLAB with a sample rate of 48 kHz and + * a length of 29 points. + * The MATLAB code to generate the filter coefficients is shown below: + *
+ *     h = fir1(28, 6/24);
+ * 
+ * The first argument is the "order" of the filter and is always one less than the desired length. + * The second argument is the normalized cutoff frequency. This is in the range 0 (DC) to 1.0 (Nyquist). + * A 6 kHz cutoff with a Nyquist frequency of 24 kHz lies at a normalized frequency of 6/24 = 0.25. + * The CMSIS FIR filter function requires the coefficients to be in time reversed order. + *
+ *     fliplr(h)
+ * 
+ * The resulting filter coefficients and are shown below. + * Note that the filter is symmetric (a property of linear phase FIR filters) + * and the point of symmetry is sample 14. Thus the filter will have a delay of + * 14 samples for all frequencies. + * \par + * \image html FIRLPF_coeffs.gif + * \par + * The frequency response of the filter is shown next. + * The passband gain of the filter is 1.0 and it reaches 0.5 at the cutoff frequency 6 kHz. + * \par + * \image html FIRLPF_response.gif + * \par + * The input signal is shown below. + * The left hand side shows the signal in the time domain while the right hand side is a frequency domain representation. + * The two sine wave components can be clearly seen. + * \par + * \image html FIRLPF_input.gif + * \par + * The output of the filter is shown below. The 15 kHz component has been eliminated. + * \par + * \image html FIRLPF_output.gif + * + * \par Variables Description: + * \par + * \li \c testInput_f32_1kHz_15kHz points to the input data + * \li \c refOutput points to the reference output data + * \li \c testOutput points to the test output data + * \li \c firStateF32 points to state buffer + * \li \c firCoeffs32 points to coefficient buffer + * \li \c blockSize number of samples processed at a time + * \li \c numBlocks number of frames + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_fir_init_f32() + * - arm_fir_f32() + * + * Refer + * \link arm_fir_example_f32.c \endlink + * + */ + + +/** \example arm_fir_example_f32.c + */ + +/* ---------------------------------------------------------------------- +** Include Files +** ------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "math_helper.h" + +/* ---------------------------------------------------------------------- +** Macro Defines +** ------------------------------------------------------------------- */ + +#define TEST_LENGTH_SAMPLES 320 +#define SNR_THRESHOLD_F32 140.0f +#define BLOCK_SIZE 32 +#define NUM_TAPS 29 + +/* ------------------------------------------------------------------- + * The input signal and reference output (computed with MATLAB) + * are defined externally in arm_fir_lpf_data.c. + * ------------------------------------------------------------------- */ + +extern float32_t testInput_f32_1kHz_15kHz[TEST_LENGTH_SAMPLES]; +extern float32_t refOutput[TEST_LENGTH_SAMPLES]; + +/* ------------------------------------------------------------------- + * Declare Test output buffer + * ------------------------------------------------------------------- */ + +static float32_t testOutput[TEST_LENGTH_SAMPLES]; + +/* ------------------------------------------------------------------- + * Declare State buffer of size (numTaps + blockSize - 1) + * ------------------------------------------------------------------- */ + +static float32_t firStateF32[BLOCK_SIZE + NUM_TAPS - 1]; + +/* ---------------------------------------------------------------------- +** FIR Coefficients buffer generated using fir1() MATLAB function. +** fir1(28, 6/24) +** ------------------------------------------------------------------- */ + +const float32_t firCoeffs32[NUM_TAPS] = { + -0.0018225230f, -0.0015879294f, +0.0000000000f, +0.0036977508f, +0.0080754303f, +0.0085302217f, -0.0000000000f, -0.0173976984f, + -0.0341458607f, -0.0333591565f, +0.0000000000f, +0.0676308395f, +0.1522061835f, +0.2229246956f, +0.2504960933f, +0.2229246956f, + +0.1522061835f, +0.0676308395f, +0.0000000000f, -0.0333591565f, -0.0341458607f, -0.0173976984f, -0.0000000000f, +0.0085302217f, + +0.0080754303f, +0.0036977508f, +0.0000000000f, -0.0015879294f, -0.0018225230f +}; + +/* ------------------------------------------------------------------ + * Global variables for FIR LPF Example + * ------------------------------------------------------------------- */ + +uint32_t blockSize = BLOCK_SIZE; +uint32_t numBlocks = TEST_LENGTH_SAMPLES/BLOCK_SIZE; + +float32_t snr; + +/* ---------------------------------------------------------------------- + * FIR LPF Example + * ------------------------------------------------------------------- */ + +int32_t main(void) +{ + uint32_t i; + arm_fir_instance_f32 S; + arm_status status; + float32_t *inputF32, *outputF32; + + /* Initialize input and output buffer pointers */ + inputF32 = &testInput_f32_1kHz_15kHz[0]; + outputF32 = &testOutput[0]; + + /* Call FIR init function to initialize the instance structure. */ + arm_fir_init_f32(&S, NUM_TAPS, (float32_t *)&firCoeffs32[0], &firStateF32[0], blockSize); + + /* ---------------------------------------------------------------------- + ** Call the FIR process function for every blockSize samples + ** ------------------------------------------------------------------- */ + + for(i=0; i < numBlocks; i++) + { + arm_fir_f32(&S, inputF32 + (i * blockSize), outputF32 + (i * blockSize), blockSize); + } + + /* ---------------------------------------------------------------------- + ** Compare the generated output against the reference output computed + ** in MATLAB. + ** ------------------------------------------------------------------- */ + + snr = arm_snr_f32(&refOutput[0], &testOutput[0], TEST_LENGTH_SAMPLES); + + if (snr < SNR_THRESHOLD_F32) + { + status = ARM_MATH_TEST_FAILURE; + } + else + { + status = ARM_MATH_SUCCESS; + } + + /* ---------------------------------------------------------------------- + ** Loop here if the signal does not match the reference output. + ** ------------------------------------------------------------------- */ + + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + +/** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.c new file mode 100644 index 0000000..f615e6f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.c @@ -0,0 +1,466 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 b +* +* Project: CMSIS DSP Library +* +* Title: math_helper.c +* +* Description: Definition of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Include standard header files +* -------------------------------------------------------------------- */ +#include + +/* ---------------------------------------------------------------------- +* Include project header files +* -------------------------------------------------------------------- */ +#include "math_helper.h" + +/** + * @brief Caluclation of SNR + * @param[in] pRef Pointer to the reference buffer + * @param[in] pTest Pointer to the test buffer + * @param[in] buffSize total number of samples + * @return SNR + * The function Caluclates signal to noise ratio for the reference output + * and test output + */ + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize) +{ + float EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + float SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10 (EnergySignal / EnergyError); + + return (SNR); + +} + + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q15 (q15_t * input_buf, uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Converts float to fixed in q12.20 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to outputbuffer + * @param[in] numSamples number of samples in the input buffer + * @return none + * The function converts floating point values to fixed point(q12.20) values + */ + +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1048576.0f corresponds to pow(2, 20) */ + pOut[i] = (q31_t) (pIn[i] * 1048576.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 1.0) + { + pOut[i] = 0x000FFFFF; + } + } +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q31 (q31_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q7 (q7_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + + + +/** + * @brief Caluclates number of guard bits + * @param[in] num_adds number of additions + * @return guard bits + * The function Caluclates the number of guard bits + * depending on the numtaps + */ + +uint32_t arm_calc_guard_bits (uint32_t num_adds) +{ + uint32_t i = 1, j = 0; + + if (num_adds == 1) + { + return (0); + } + + while (i < num_adds) + { + i = i * 2; + j++; + } + + return (j); +} + +/** + * @brief Apply guard bits to buffer + * @param[in,out] pIn pointer to input buffer + * @param[in] numSamples number of samples in the input buffer + * @param[in] guard_bits guard bits + * @return none + */ + +void arm_apply_guard_bits (float32_t *pIn, + uint32_t numSamples, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + pIn[i] = pIn[i] * arm_calc_2pow(guard_bits); + } +} + +/** + * @brief Calculates pow(2, numShifts) + * @param[in] numShifts number of shifts + * @return pow(2, numShifts) + */ +uint32_t arm_calc_2pow(uint32_t numShifts) +{ + + uint32_t i, val = 1; + + for (i = 0; i < numShifts; i++) + { + val = val * 2; + } + + return(val); +} + + + +/** + * @brief Converts float to fixed q14 + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q14 (float *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 16384.0f corresponds to pow(2, 14) */ + pOut[i] = (q15_t) (pIn[i] * 16384.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFF; + } + + } + +} + + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q30 (float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 1073741824.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q29 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 536870912.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 4.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + + +/** + * @brief Converts float to fixed q28 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q28 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 268435456.0f corresponds to pow(2, 28) */ + pOut[i] = (q31_t) (pIn[i] * 268435456.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 8.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Clip the float values to +/- 1 + * @param[in,out] pIn input buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_clip_f32 (float *pIn, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + if (pIn[i] > 1.0f) + { + pIn[i] = 1.0; + } + else if ( pIn[i] < -1.0f) + { + pIn[i] = -1.0; + } + + } +} + + + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.h b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.h new file mode 100644 index 0000000..5a18734 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_fir_example/math_helper.h @@ -0,0 +1,63 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2013 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* +* Title: math_helper.h +* +* Description: Prototypes of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + + +#include "arm_math.h" + +#ifndef MATH_HELPER_H +#define MATH_HELPER_H + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize); +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples); +void arm_provide_guard_bits_q15(q15_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_provide_guard_bits_q31(q31_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_float_to_q14(float *pIn, q15_t *pOut, uint32_t numSamples); +void arm_float_to_q29(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q28(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q30(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_clip_f32(float *pIn, uint32_t numSamples); +uint32_t arm_calc_guard_bits(uint32_t num_adds); +void arm_apply_guard_bits (float32_t * pIn, uint32_t numSamples, uint32_t guard_bits); +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t * pOut, uint32_t numSamples); +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t *pOut, uint32_t numSamples); +uint32_t arm_calc_2pow(uint32_t guard_bits); +#endif + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/Abstract.txt new file mode 100644 index 0000000..c2452b6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_graphic_equalizer_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_data.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_data.c new file mode 100644 index 0000000..b6ab8c9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_data.c @@ -0,0 +1,134 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_graphic_equalizer_data.c +* +* Description: Data file used for example code +* +* Target Processor: Cortex-M4/Cortex-M3/Cortex-M0 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +#include "arm_math.h" + +float32_t testRefOutput_f32[320] = { + +0.000000000000000000, 0.001898396760225296, 0.004215449094772339, 0.007432077080011368, 0.010948467999696732, 0.015026375651359558, 0.019191544502973557, 0.023574527353048325, +0.027919445186853409, 0.032277785241603851, 0.036551639437675476, 0.040732793509960175, 0.044799156486988068, 0.048710610717535019, 0.052476800978183746, 0.056059073656797409, +0.059482168406248093, 0.062726479023694992, 0.065821025520563126, 0.068763464689254761, 0.071577839553356171, 0.074270240962505341, 0.076856281608343124, 0.079344697296619415, +0.081745062023401260, 0.084067162126302719, 0.086318407207727432, 0.088509257882833481, 0.090647127479314804, 0.092742368578910828, 0.094802625477313995, 0.096837285906076431, +0.098853722214698792, 0.100859899073839190, 0.102862443774938580, 0.104867763817310330, 0.106881409883499150, 0.108908228576183320, 0.110952425748109820, 0.113017357885837550, +0.115105822682380680, 0.117219865322113040, 0.119361080229282380, 0.121530555188655850, 0.123729091137647630, 0.125957202166318890, 0.128215309232473370, 0.130503740161657330, +0.132822841405868530, 0.135173004120588300, 0.137554679065942760, 0.139968376606702800, 0.142414685338735580, 0.144894234836101530, 0.147407654672861100, 0.149955596774816510, +0.152538605034351350, 0.155157200992107390, 0.157811731100082400, 0.160502441227436070, 0.163229387253522870, 0.165992442518472670, 0.168791320174932480, 0.171625509858131410, +0.174494370818138120, 0.177397061139345170, 0.180332608520984650, 0.183299910277128220, 0.186297744512557980, 0.189324837177991870, 0.192379791289567950, 0.195461250841617580, +0.198567759245634080, 0.201697919517755510, 0.204850304871797560, 0.208023533225059510, 0.211216274648904800, 0.214427210390567780, 0.217655111104249950, 0.220898788422346120, +0.224157124757766720, 0.227429077029228210, 0.230713658034801480, 0.234009962528944020, 0.237317133694887160, 0.240634419023990630, 0.243961080908775330, 0.247296508401632310, +0.250640105456113820, 0.253991369158029560, 0.257349837571382520, 0.260715119540691380, 0.264086868613958360, 0.267464816570281980, 0.270848698914051060, 0.274238351732492450, +0.277633611112833020, 0.281034380197525020, 0.284440591931343080, 0.287852220237255100, 0.291269283741712570, 0.294691801071166990, 0.298119872808456420, 0.301553562283515930, +0.304993014782667160, 0.308438356965780260, 0.311889752745628360, 0.315347377210855480, 0.318811416625976560, 0.322282072156667710, 0.325759567320346830, 0.329244095832109450, +0.332735907286405560, 0.336235217750072480, 0.339742250740528110, 0.343257248401641850, 0.346780419349670410, 0.350311983376741410, 0.353852160274982450, 0.357401121407747270, +0.360959105193614960, 0.364526227116584780, 0.368102725595235820, 0.371688675135374070, 0.375284302979707720, 0.378889638930559160, 0.382504884153604510, 0.386130042374134060, +0.389765247702598570, 0.393410529941320420, 0.397065933793783190, 0.400731507688760760, 0.404407206922769550, 0.408093083649873730, 0.411789052188396450, 0.415495119988918300, +0.419211201369762420, 0.422937240451574330, 0.426673140376806260, 0.430418811738491060, 0.434174135327339170, 0.437938995659351350, 0.441713258624076840, 0.445496778935194020, +0.449289388954639430, 0.453090950846672060, 0.456901267170906070, 0.460720170289278030, 0.464547459036111830, 0.468382950872182850, 0.472226426005363460, 0.476077698171138760, +0.479936532676219940, 0.483802750706672670, 0.487676106393337250, 0.491556398570537570, 0.495443399995565410, 0.499336875975131990, 0.503236617892980580, 0.507142387330532070, +0.511053957045078280, 0.514971107244491580, 0.518893606960773470, 0.522821225225925450, 0.526753749698400500, 0.530690938234329220, 0.534632585942745210, 0.538578454405069350, +0.542528338730335240, 0.546481993049383160, 0.550439231097698210, 0.554399792104959490, 0.558363504707813260, 0.562330115586519240, 0.566299438476562500, 0.570271246135234830, +0.574245333671569820, 0.578221492469310760, 0.582199502736330030, 0.586179181933403020, 0.590160276740789410, 0.594142623245716090, 0.598125983029603960, 0.602110169827938080, +0.606094967573881150, 0.610080175101757050, 0.614065583795309070, 0.618050977587699890, 0.622036151587963100, 0.626020893454551700, 0.630004994571208950, 0.633988231420516970, +0.637970402836799620, 0.641951277852058410, 0.645930647850036620, 0.649908289313316350, 0.653883971273899080, 0.657857488840818410, 0.661828581243753430, 0.665797054767608640, +0.669762641191482540, 0.673725124448537830, 0.677684243768453600, 0.681639779359102250, 0.685591462999582290, 0.689539063721895220, 0.693482317030429840, 0.697420965880155560, +0.701354760676622390, 0.705283410847187040, 0.709206689149141310, 0.713124278932809830, 0.717035952955484390, 0.720941375941038130, 0.724840316921472550, 0.728732451796531680, +0.732617516070604320, 0.736495196819305420, 0.740365199744701390, 0.744227230548858640, 0.748080968856811520, 0.751926124095916750, 0.755762357264757160, 0.759589381515979770, +0.763406842947006230, 0.767214450985193250, 0.771011855453252790, 0.774798732250928880, 0.778574761003255840, 0.782339565455913540, 0.786092851310968400, 0.789834223687648770, +0.793563373386859890, 0.797279909253120420, 0.800983514636754990, 0.804673787206411360, 0.808350402861833570, 0.812012966722249980, 0.815661124885082240, 0.819294504821300510, +0.822912722826004030, 0.826515413820743560, 0.830102190375328060, 0.833672653883695600, 0.837226435542106630, 0.840763118118047710, 0.844282336533069610, 0.847783654928207400, +0.851266715675592420, 0.854731071740388870, 0.858176350593566890, 0.861602116376161580, 0.865007970482110980, 0.868393491953611370, 0.871758259832859040, 0.875101849436759950, +0.878423850983381270, 0.881723806262016300, 0.885001312941312790, 0.888255912810564040, 0.891487173736095430, 0.894694659858942030, 0.897877920418977740, 0.901036512106657030, +0.904169965535402300, 0.907277844846248630, 0.910359673202037810, 0.913415014743804930, 0.916443370282649990, 0.919444311410188670, 0.922417331486940380, 0.925361987203359600, +0.928277771919965740, 0.931164238601922990, 0.934020876884460450, 0.936847217381000520, 0.939642757177352910, 0.942407000809907910, 0.945139460265636440, 0.947839632630348210, +0.950507018715143200, 0.953141096979379650, 0.955741371959447860, 0.958307322114706040, 0.960838429629802700, 0.963334184139966960, 0.965794049203395840, 0.968217510730028150, +0.970604017376899720, 0.972953058779239650, 0.975264083594083790, 0.977536566555500030, 0.979769956320524220, 0.981963708996772770, 0.984117280691862110, 0.986230112612247470, +0.988301653414964680, 0.990331344306468960, 0.992318630218505860, 0.994262944906950000, 0.996163722127676010, 0.998020399361848830, 0.999832402914762500, 1.001599155366420700, +1.003320086747407900, 1.004994612187147100, 1.006622135639190700, 1.008202098309993700, 1.009733878076076500, 1.011216927319765100, 1.012650609016418500, 1.014034371823072400, +1.015367589890956900, 1.016649682074785200, 1.017880033701658200, 1.019058048725128200, 1.020183108747005500, 1.021254621446132700, 1.022271949797868700, 1.023234523832798000, + +}; +/* ---------------------------------------------------------------------- +** Test input - logarithmic chirp signal +** ------------------------------------------------------------------- */ + +float32_t testInput_f32[320] = + { + 0.000000000000000061, 0.002622410992047861, 0.005253663973466970, 0.007893770384930297, 0.010542741395035495, 0.013200587895525877, 0.015867320496454066, 0.018542949521290073, +0.021227485001971542, 0.023920936673895138, 0.026623313970853074, 0.029334626019908643, 0.032054881636210709, 0.034784089317753723, 0.037522257240071598, 0.040269393250875855, +0.043025504864628375, 0.045790599257054837, 0.048564683259595690, 0.051347763353792118, 0.054139845665610427, 0.056940935959702531, 0.059751039633601337, 0.062570161711849828, +0.065398306840066575, 0.068235479278943648, 0.071081682898178900, 0.073936921170339814, 0.076801197164660218, 0.079674513540768196, 0.082556872542344922, 0.085448275990715375, +0.088348725278367082, 0.091258221362398390, 0.094176764757897533, 0.097104355531246703, 0.100040993293358240, 0.102986677192832010, 0.105941405909045980, 0.108905177645166230, +0.111877990121087980, 0.114859840566297130, 0.117850725712659680, 0.120850641787131110, 0.123859584504392860, 0.126877549059407400, 0.129904530119898690, 0.132940521818751430, +0.135985517746334080, 0.139039510942737950, 0.142102493889940090, 0.145174458503884160, 0.148255396126476810, 0.151345297517508140, 0.154444152846483080, 0.157551951684374300, +0.160668682995289720, 0.163794335128054890, 0.166928895807713030, 0.170072352126936720, 0.173224690537355760, 0.176385896840798810, 0.179555956180445340, 0.182734853031894270, +0.185922571194139130, 0.189119093780459800, 0.192324403209221870, 0.195538481194587030, 0.198761308737133020, 0.201992866114384050, 0.205233132871247170, 0.208482087810360570, +0.211739708982344370, 0.215005973675965020, 0.218280858408200220, 0.221564338914212730, 0.224856390137231970, 0.228156986218334190, 0.231466100486134670, 0.234783705446379690, +0.238109772771442410, 0.241444273289723230, 0.244787176974952890, 0.248138452935395580, 0.251498069402956710, 0.254865993722190930, 0.258242192339209860, 0.261626630790492030, +0.265019273691591620, 0.268420084725748410, 0.271829026632395280, 0.275246061195565440, 0.278671149232197430, 0.282104250580339830, 0.285545324087251580, 0.288994327597401960, +0.292451217940364990, 0.295915950918612280, 0.299388481295203350, 0.302868762781368150, 0.306356748023990040, 0.309852388592980640, 0.313355634968552230, 0.316866436528383590, +0.320384741534681720, 0.323910497121136620, 0.327443649279772870, 0.330984142847692230, 0.334531921493712690, 0.338086927704900790, 0.341649102772995210, 0.345218386780727190, +0.348794718588032520, 0.352378035818156910, 0.355968274843654950, 0.359565370772282730, 0.363169257432780890, 0.366779867360555120, 0.370397131783246010, 0.374020980606193880, +0.377651342397795690, 0.381288144374756830, 0.384931312387234990, 0.388580770903877330, 0.392236442996751310, 0.395898250326170650, 0.399566113125414350, 0.403239950185338420, +0.406919678838884410, 0.410605214945482130, 0.414296472875345100, 0.417993365493664670, 0.421695804144698540, 0.425403698635752780, 0.429116957221065130, 0.432835486585582130, +0.436559191828633180, 0.440287976447505720, 0.444021742320914510, 0.447760389692375140, 0.451503817153472210, 0.455251921627031540, 0.459004598350192470, 0.462761740857380200, +0.466523240963184150, 0.470288988745136360, 0.474058872526396560, 0.477832778858340690, 0.481610592503056990, 0.485392196415748600, 0.489177471727042850, 0.492966297725213780, +0.496758551838309250, 0.500554109616195060, 0.504352844712508190, 0.508154628866524960, 0.511959331884944910, 0.515766821623591440, 0.519576963969030530, 0.523389622820107150, +0.527204660069405030, 0.531021935584629400, 0.534841307189911630, 0.538662630647041900, 0.542485759636628150, 0.546310545739186690, 0.550136838416161340, 0.553964484990880020, +0.557793330629441700, 0.561623218321546380, 0.565453988861259300, 0.569285480827721570, 0.573117530565801950, 0.576949972166696630, 0.580782637448476910, 0.584615355936589420, +0.588447954844309340, 0.592280259053150400, 0.596112091093235260, 0.599943271123626440, 0.603773616912622660, 0.607602943818024150, 0.611431064767369080, 0.615257790238142090, +0.619082928237961740, 0.622906284284749700, 0.626727661386881850, 0.630546860023327600, 0.634363678123782030, 0.638177911048790960, 0.641989351569874020, 0.645797789849653410, +0.649603013421986450, 0.653404807172108140, 0.657202953316791350, 0.660997231384523490, 0.664787418195706640, 0.668573287842887610, 0.672354611671016960, 0.676131158257749170, +0.679902693393781730, 0.683668980063242500, 0.687429778424128110, 0.691184845788802130, 0.694933936604551380, 0.698676802434213370, 0.702413191936877570, 0.706142850848662460, +0.709865521963579990, 0.713580945114492330, 0.717288857154159800, 0.720988991936399870, 0.724681080297347790, 0.728364850036839040, 0.732040025899910680, 0.735706329558433620, +0.739363479592880620, 0.743011191474238440, 0.746649177546067850, 0.750277147006723990, 0.753894805891742180, 0.757501857056394940, 0.761098000158428880, 0.764682931640995540, +0.768256344715771980, 0.771817929346292900, 0.775367372231492210, 0.778904356789468790, 0.782428563141483460, 0.785939668096195860, 0.789437345134148760, 0.792921264392515420, +0.796391092650110770, 0.799846493312681210, 0.803287126398485760, 0.806712648524170680, 0.810122712890953390, 0.813516969271127150, 0.816895063994893090, 0.820256639937531280, +0.823601336506926020, 0.826928789631450890, 0.830238631748229430, 0.833530491791779850, 0.836803995183058700, 0.840058763818912760, 0.843294416061954100, 0.846510566730867220, +0.849706827091166740, 0.852882804846411770, 0.856038104129895340, 0.859172325496819990, 0.862285065916973510, 0.865375918767918860, 0.868444473828712590, 0.871490317274166260, +0.874513031669661770, 0.877512195966544280, 0.880487385498096800, 0.883438171976119850, 0.886364123488128100, 0.889264804495180530, 0.892139775830360640, 0.894988594697921020, +0.897810814673113080, 0.900605985702712770, 0.903373654106265470, 0.906113362578062300, 0.908824650189867690, 0.911507052394417540, 0.914160101029702910, 0.916783324324059180, +0.919376246902079860, 0.921938389791372770, 0.924469270430179120, 0.926968402675872660, 0.929435296814361430, 0.931869459570409790, 0.934270394118903560, 0.936637600097074200, +0.938970573617708970, 0.941268807283364040, 0.943531790201601380, 0.945759008001275100, 0.947949942849885320, 0.950104073472023970, 0.952220875168933280, 0.954299819839202090, +0.956340376000621160, 0.958342008813221960, 0.960304180103520260, 0.962226348389994210, 0.964107968909812760, 0.965948493646846980, 0.967747371360983650, 0.969504047618768740, +0.971217964825405680, 0.972888562258134030, 0.974515276101013520, 0.976097539481141750, 0.977634782506330400, 0.979126432304266880, 0.980571913063189360, 0.981970646074102120, +0.983322049774557390, 0.984625539794035220, 0.985880529000944810, 0.987086427551279730, 0.988242642938953360, 0.989348580047844540, 0.990403641205582440, 0.991407226239099710, +0.992358732531984260, 0.993257555083659870, 0.994103086570423680, 0.994894717408374870, 0.995631835818261310, 0.996313827892278070, 0.996940077662846650, 0.997509967173408010, + + }; diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_example_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_example_q31.c new file mode 100644 index 0000000..c263d18 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/arm_graphic_equalizer_example_q31.c @@ -0,0 +1,411 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_graphic_equalizer_example_q31.c +* +* Description: Example showing an audio graphic equalizer constructed +* out of Biquad filters. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup GEQ5Band Graphic Audio Equalizer Example + * + * \par Description: + * \par + * This example demonstrates how a 5-band graphic equalizer can be constructed + * using the Biquad cascade functions. + * A graphic equalizer is used in audio applications to vary the tonal quality + * of the audio. + * + * \par Block Diagram: + * \par + * The design is based on a cascade of 5 filter sections. + * \image html GEQ_signalflow.gif + * Each filter section is 4th order and consists of a cascade of two Biquads. + * Each filter has a nominal gain of 0 dB (1.0 in linear units) and + * boosts or cuts signals within a specific frequency range. + * The edge frequencies between the 5 bands are 100, 500, 2000, and 6000 Hz. + * Each band has an adjustable boost or cut in the range of +/- 9 dB. + * For example, the band that extends from 500 to 2000 Hz has the response shown below: + * \par + * \image html GEQ_bandresponse.gif + * \par + * With 1 dB steps, each filter has a total of 19 different settings. + * The filter coefficients for all possible 19 settings were precomputed + * in MATLAB and stored in a table. With 5 different tables, there are + * a total of 5 x 19 = 95 different 4th order filters. + * All 95 responses are shown below: + * \par + * \image html GEQ_allbandresponse.gif + * \par + * Each 4th order filter has 10 coefficents for a grand total of 950 different filter + * coefficients that must be tabulated. The input and output data is in Q31 format. + * For better noise performance, the two low frequency bands are implemented using the high + * precision 32x64-bit Biquad filters. The remaining 3 high frequency bands use standard + * 32x32-bit Biquad filters. The input signal used in the example is a logarithmic chirp. + * \par + * \image html GEQ_inputchirp.gif + * \par + * The array bandGains specifies the gain in dB to apply in each band. + * For example, if bandGains={0, -3, 6, 4, -6}; then the output signal will be: + * \par + * \image html GEQ_outputchirp.gif + * \par + * \note The output chirp signal follows the gain or boost of each band. + * \par + * + * \par Variables Description: + * \par + * \li \c testInput_f32 points to the input data + * \li \c testRefOutput_f32 points to the reference output data + * \li \c testOutput points to the test output data + * \li \c inputQ31 temporary input buffer + * \li \c outputQ31 temporary output buffer + * \li \c biquadStateBand1Q31 points to state buffer for band1 + * \li \c biquadStateBand2Q31 points to state buffer for band2 + * \li \c biquadStateBand3Q31 points to state buffer for band3 + * \li \c biquadStateBand4Q31 points to state buffer for band4 + * \li \c biquadStateBand5Q31 points to state buffer for band5 + * \li \c coeffTable points to coefficient buffer for all bands + * \li \c gainDB gain buffer which has gains applied for all the bands + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_biquad_cas_df1_32x64_init_q31() + * - arm_biquad_cas_df1_32x64_q31() + * - arm_biquad_cascade_df1_init_q31() + * - arm_biquad_cascade_df1_q31() + * - arm_scale_q31() + * - arm_scale_f32() + * - arm_float_to_q31() + * - arm_q31_to_float() + * + * Refer + * \link arm_graphic_equalizer_example_q31.c \endlink + * + */ + + +/** \example arm_graphic_equalizer_example_q31.c + */ + + +#include "arm_math.h" +#include "math_helper.h" + +/* Length of the overall data in the test */ +#define TESTLENGTH 320 + +/* Block size for the underlying processing */ +#define BLOCKSIZE 32 + +/* Total number of blocks to run */ +#define NUMBLOCKS (TESTLENGTH/BLOCKSIZE) + +/* Number of 2nd order Biquad stages per filter */ +#define NUMSTAGES 2 + +#define SNR_THRESHOLD_F32 98 + +/* ------------------------------------------------------------------- + * External Declarations for Input and Output buffers + * ------------------------------------------------------------------- */ + +extern float32_t testInput_f32[TESTLENGTH]; +static float32_t testOutput[TESTLENGTH]; + +extern float32_t testRefOutput_f32[TESTLENGTH]; + +/* ---------------------------------------------------------------------- +** Q31 state buffers for Band1, Band2, Band3, Band4, Band5 +** ------------------------------------------------------------------- */ + +static q63_t biquadStateBand1Q31[4 * 2]; +static q63_t biquadStateBand2Q31[4 * 2]; +static q31_t biquadStateBand3Q31[4 * 2]; +static q31_t biquadStateBand4Q31[4 * 2]; +static q31_t biquadStateBand5Q31[4 * 2]; + +/* ---------------------------------------------------------------------- +** Q31 input and output buffers +** ------------------------------------------------------------------- */ + +q31_t inputQ31[BLOCKSIZE]; +q31_t outputQ31[BLOCKSIZE]; + +/* ---------------------------------------------------------------------- +** Entire coefficient table. There are 10 coefficients per 4th order Biquad +** cascade filter. The first 10 coefficients correspond to the -9 dB gain +** setting of band 1; the next 10 coefficient correspond to the -8 dB gain +** setting of band 1; and so on. There are 10*19=190 coefficients in total +** for band 1 (gains = -9, -8, -7, ..., 9). After this come the 190 coefficients +** for band 2. +** +** The coefficients are in Q29 format and require a postShift of 2. +** ------------------------------------------------------------------- */ + +const q31_t coeffTable[950] = { + + /* Band 1, -9 dB gain */ + 535576962, -1071153923, 535576962, 1073741824, -536870912, 535576962, -1063501998, 527979313, 1060865294, -524146981, + /* Band 1, -8 dB gain */ + 535723226, -1071446451, 535723226, 1073741824, -536870912, 535723226, -1063568947, 527903217, 1061230578, -524503778, + 535868593, -1071737186, 535868593, 1073741824, -536870912, 535868593, -1063627467, 527819780, 1061585502, -524850686, + 536013181, -1072026363, 536013181, 1073741824, -536870912, 536013181, -1063677598, 527728935, 1061930361, -525187972, + 536157109, -1072314217, 536157109, 1073741824, -536870912, 536157109, -1063719372, 527630607, 1062265438, -525515897, + 536300492, -1072600983, 536300492, 1073741824, -536870912, 536300492, -1063752815, 527524720, 1062591011, -525834716, + 536443447, -1072886894, 536443447, 1073741824, -536870912, 536443447, -1063777945, 527411186, 1062907350, -526144676, + 536586091, -1073172183, 536586091, 1073741824, -536870912, 536586091, -1063794775, 527289917, 1063214717, -526446017, + 536728541, -1073457082, 536728541, 1073741824, -536870912, 536728541, -1063803308, 527160815, 1063513366, -526738975, + 536870912, -1073741824, 536870912, 1073741824, -536870912, 536870912, -1063803543, 527023777, 1063803543, -527023777, + 537013321, -1074026642, 537013321, 1073741824, -536870912, 537013321, -1063795470, 526878696, 1064085490, -527300648, + 537155884, -1074311768, 537155884, 1073741824, -536870912, 537155884, -1063779073, 526725455, 1064359439, -527569803, + 537298718, -1074597435, 537298718, 1073741824, -536870912, 537298718, -1063754328, 526563934, 1064625617, -527831454, + 537441939, -1074883878, 537441939, 1073741824, -536870912, 537441939, -1063721205, 526394005, 1064884245, -528085806, + 537585666, -1075171331, 537585666, 1073741824, -536870912, 537585666, -1063679666, 526215534, 1065135536, -528333059, + 537730015, -1075460030, 537730015, 1073741824, -536870912, 537730015, -1063629666, 526028380, 1065379699, -528573409, + 537875106, -1075750212, 537875106, 1073741824, -536870912, 537875106, -1063571152, 525832396, 1065616936, -528807045, + 538021057, -1076042114, 538021057, 1073741824, -536870912, 538021057, -1063504065, 525627429, 1065847444, -529034151, + 538167989, -1076335977, 538167989, 1073741824, -536870912, 538167989, -1063428338, 525413317, 1066071412, -529254907, + + /* Band 2, -9 dB gain */ + 531784976, -1055497692, 523873415, 1066213307, -529420241, 531784976, -1040357886, 509828014, 1028908252, -494627367, + /* Band 2, -8 dB gain */ + 532357636, -1056601982, 524400080, 1066115844, -529326645, 532357636, -1040623406, 509562600, 1030462237, -496062122, + 532927392, -1057707729, 524931110, 1066024274, -529239070, 532927392, -1040848253, 509262081, 1031969246, -497457090, + 533494678, -1058816094, 525467240, 1065939047, -529157961, 533494678, -1041032161, 508925950, 1033429976, -498812573, + 534059929, -1059928204, 526009170, 1065860582, -529083734, 534059929, -1041174868, 508553717, 1034845124, -500128887, + 534623580, -1061045148, 526557561, 1065789260, -529016764, 534623580, -1041276126, 508144920, 1036215393, -501406373, + 535186068, -1062167969, 527113032, 1065725420, -528957385, 535186068, -1041335703, 507699125, 1037541500, -502645399, + 535747827, -1063297666, 527676151, 1065669351, -528905879, 535747827, -1041353386, 507215934, 1038824183, -503846368, + 536309295, -1064435183, 528247436, 1065621289, -528862476, 536309295, -1041328990, 506694984, 1040064203, -505009724, + 536870912, -1065581413, 528827349, 1065581413, -528827349, 536870912, -1041262354, 506135953, 1041262354, -506135953, + 537433117, -1066737194, 529416295, 1065549847, -528800610, 537433117, -1041153346, 505538564, 1042419457, -507225588, + 537996352, -1067903307, 530014622, 1065526651, -528782316, 537996352, -1041001864, 504902578, 1043536370, -508279208, + 538561061, -1069080480, 530622620, 1065511830, -528772462, 538561061, -1040807833, 504227800, 1044613981, -509297437, + 539127690, -1070269387, 531240527, 1065505333, -528770987, 539127690, -1040571205, 503514074, 1045653211, -510280946, + 539696690, -1071470656, 531868525, 1065507054, -528777778, 539696690, -1040291951, 502761277, 1046655011, -511230450, + 540268512, -1072684867, 532506750, 1065516837, -528792672, 540268512, -1039970063, 501969320, 1047620358, -512146700, + 540843613, -1073912567, 533155297, 1065534483, -528815459, 540843613, -1039605542, 501138139, 1048550251, -513030484, + 541422451, -1075154268, 533814224, 1065559750, -528845892, 541422451, -1039198394, 500267687, 1049445708, -513882621, + 542005489, -1076410460, 534483561, 1065592362, -528883686, 542005489, -1038748624, 499357932, 1050307760, -514703956, + 518903861, -1001986830, 486725277, 1037235801, -502367695, 518903861, -945834422, 446371043, 902366163, -400700571, + 520899989, -1005630916, 488289126, 1036926846, -502147311, 520899989, -946490935, 445581846, 907921945, -404936158, + 522893209, -1009290002, 489869792, 1036650484, -501961419, 522893209, -947006359, 444685310, 913306106, -409075225, + 524884763, -1012968199, 491470256, 1036407567, -501810737, 524884763, -947377809, 443679533, 918521018, -413116221, + 526875910, -1016669649, 493093518, 1036198712, -501695739, 526875910, -947602324, 442562672, 923569247, -417057897, + 528867927, -1020398503, 494742575, 1036024293, -501616651, 528867927, -947676875, 441332970, 928453558, -420899319, + 530862111, -1024158905, 496420407, 1035884447, -501573457, 530862111, -947598385, 439988777, 933176909, -424639872, + 532859778, -1027954970, 498129955, 1035779077, -501565907, 532859778, -947363742, 438528571, 937742446, -428279254, + 534862260, -1031790763, 499874098, 1035707863, -501593525, 534862260, -946969823, 436950987, 942153486, -431817474, + 536870912, -1035670279, 501655630, 1035670279, -501655630, 536870912, -946413508, 435254839, 946413508, -435254839, + 538887107, -1039597419, 503477238, 1035665609, -501751354, 538887107, -945691703, 433439146, 950526127, -438591937, + 540912240, -1043575967, 505341475, 1035692963, -501879659, 540912240, -944801359, 431503152, 954495080, -441829621, + 542947726, -1047609569, 507250741, 1035751307, -502039364, 542947726, -943739490, 429446349, 958324201, -444968987, + 544995000, -1051701717, 509207261, 1035839473, -502229165, 544995000, -942503190, 427268492, 962017400, -448011351, + 547055523, -1055855728, 511213065, 1035956193, -502447657, 547055523, -941089647, 424969617, 965578640, -450958226, + 549130774, -1060074734, 513269973, 1036100110, -502693359, 549130774, -939496155, 422550049, 969011913, -453811298, + 551222259, -1064361672, 515379585, 1036269804, -502964731, 551222259, -937720119, 420010407, 972321228, -456572401, + 553331507, -1068719280, 517543273, 1036463810, -503260192, 553331507, -935759057, 417351601, 975510582, -459243495, + 555460072, -1073150100, 519762181, 1036680633, -503578144, 555460072, -933610600, 414574832, 978583948, -461826644, + 494084017, -851422604, 404056273, 930151631, -423619864, 494084017, -673714108, 339502486, 561843007, -265801750, + 498713542, -859177141, 406587077, 929211656, -423786402, 498713542, -673274906, 338185129, 573719128, -272222942, + 503369016, -867012190, 409148384, 928362985, -424054784, 503369016, -672533059, 336693984, 585290277, -278599028, + 508052536, -874935599, 411746438, 927604291, -424422151, 508052536, -671478538, 335026905, 596558312, -284920289, + 512766286, -882955583, 414387826, 926933782, -424885216, 512766286, -670100998, 333182045, 607525792, -291177811, + 517512534, -891080712, 417079474, 926349262, -425440318, 517512534, -668389789, 331157902, 618195914, -297363485, + 522293635, -899319903, 419828635, 925848177, -426083491, 522293635, -666333963, 328953368, 628572440, -303470012, + 527112032, -907682405, 422642886, 925427679, -426810526, 527112032, -663922286, 326567785, 638659631, -309490882, + 531970251, -916177781, 425530105, 925084675, -427617023, 531970251, -661143261, 324000998, 648462180, -315420352, + 536870912, -924815881, 428498454, 924815881, -428498454, 536870912, -657985147, 321253420, 657985147, -321253420, + 541816719, -933606817, 431556352, 924617870, -429450209, 541816719, -654435997, 318326093, 667233900, -326985786, + 546810467, -942560921, 434712438, 924487114, -430467639, 546810467, -650483688, 315220754, 676214053, -332613816, + 551855042, -951688708, 437975532, 924420027, -431546101, 551855042, -646115970, 311939896, 684931422, -338134495, + 556953421, -961000826, 441354588, 924413001, -432680993, 556953421, -641320513, 308486839, 693391970, -343545389, + 562108672, -970508005, 444858642, 924462435, -433867780, 562108672, -636084967, 304865786, 701601770, -348844597, + 567323959, -980220994, 448496743, 924564764, -435102022, 567323959, -630397020, 301081886, 709566963, -354030710, + 572602539, -990150500, 452277894, 924716482, -436379394, 572602539, -624244471, 297141281, 717293726, -359102767, + 577947763, -1000307125, 456210977, 924914158, -437695705, 577947763, -617615296, 293051155, 724788245, -364060214, + 583363084, -1010701292, 460304674, 925154455, -439046908, 583363084, -610497723, 288819761, 732056685, -368902865, + 387379495, -506912469, 196933274, 840112184, -347208270, 387379495, 506912469, 196933274, -840112184, -347208270, + 401658082, -532275898, 207149427, 833765363, -343175316, 401658082, 532275898, 207149427, -833765363, -343175316, + 416472483, -558722695, 217902617, 827270154, -339107319, 416472483, 558722695, 217902617, -827270154, -339107319, + 431841949, -586290861, 229212798, 820624988, -335007540, 431841949, 586290861, 229212798, -820624988, -335007540, + 447786335, -615019650, 241100489, 813828443, -330879528, 447786335, 615019650, 241100489, -813828443, -330879528, + 464326111, -644949597, 253586805, 806879270, -326727141, 464326111, 644949597, 253586805, -806879270, -326727141, + 481482377, -676122557, 266693475, 799776409, -322554559, 481482377, 676122557, 266693475, -799776409, -322554559, + 499276882, -708581728, 280442865, 792519013, -318366296, 499276882, 708581728, 280442865, -792519013, -318366296, + 517732032, -742371685, 294857996, 785106465, -314167221, 517732032, 742371685, 294857996, -785106465, -314167221, + 536870912, -777538408, 309962566, 777538408, -309962566, 536870912, 777538408, 309962566, -777538408, -309962566, + 556717294, -814129313, 325780968, 769814766, -305757943, 556717294, 814129313, 325780968, -769814766, -305757943, + 577295658, -852193284, 342338310, 761935777, -301559360, 577295658, 852193284, 342338310, -761935777, -301559360, + 598631206, -891780698, 359660433, 753902014, -297373230, 598631206, 891780698, 359660433, -753902014, -297373230, + 620749877, -932943463, 377773927, 745714425, -293206383, 620749877, 932943463, 377773927, -745714425, -293206383, + 643678365, -975735041, 396706151, 737374355, -289066077, 643678365, 975735041, 396706151, -737374355, -289066077, + 667444134, -1020210487, 416485252, 728883588, -284960004, 667444134, 1020210487, 416485252, -728883588, -284960004, + 692075438, -1066426476, 437140179, 720244375, -280896294, 692075438, 1066426476, 437140179, -720244375, -280896294, + 717601336, -1114441339, 458700704, 711459472, -276883515, 717601336, 1114441339, 458700704, -711459472, -276883515, + 744051710, -1164315096, 481197437, 702532174, -272930673, 744051710, 1164315096, 481197437, -702532174, -272930673 + +}; + +/* ---------------------------------------------------------------------- +** Desired gains, in dB, per band +** ------------------------------------------------------------------- */ + +int gainDB[5] = {0, -3, 6, 4, -6}; + +float32_t snr; + + +/* ---------------------------------------------------------------------- + * Graphic equalizer Example + * ------------------------------------------------------------------- */ + +int32_t main(void) +{ + float32_t *inputF32, *outputF32; + arm_biquad_cas_df1_32x64_ins_q31 S1; + arm_biquad_cas_df1_32x64_ins_q31 S2; + arm_biquad_casd_df1_inst_q31 S3; + arm_biquad_casd_df1_inst_q31 S4; + arm_biquad_casd_df1_inst_q31 S5; + int i; + int32_t status; + + inputF32 = &testInput_f32[0]; + outputF32 = &testOutput[0]; + + /* Initialize the state and coefficient buffers for all Biquad sections */ + + arm_biquad_cas_df1_32x64_init_q31(&S1, NUMSTAGES, + (q31_t *) &coeffTable[190*0 + 10*(gainDB[0] + 9)], + &biquadStateBand1Q31[0], 2); + + arm_biquad_cas_df1_32x64_init_q31(&S2, NUMSTAGES, + (q31_t *) &coeffTable[190*1 + 10*(gainDB[1] + 9)], + &biquadStateBand2Q31[0], 2); + + arm_biquad_cascade_df1_init_q31(&S3, NUMSTAGES, + (q31_t *) &coeffTable[190*2 + 10*(gainDB[2] + 9)], + &biquadStateBand3Q31[0], 2); + + arm_biquad_cascade_df1_init_q31(&S4, NUMSTAGES, + (q31_t *) &coeffTable[190*3 + 10*(gainDB[3] + 9)], + &biquadStateBand4Q31[0], 2); + + arm_biquad_cascade_df1_init_q31(&S5, NUMSTAGES, + (q31_t *) &coeffTable[190*4 + 10*(gainDB[4] + 9)], + &biquadStateBand5Q31[0], 2); + + + /* Call the process functions and needs to change filter coefficients + for varying the gain of each band */ + + for(i=0; i < NUMBLOCKS; i++) + { + + /* ---------------------------------------------------------------------- + ** Convert block of input data from float to Q31 + ** ------------------------------------------------------------------- */ + + arm_float_to_q31(inputF32 + (i*BLOCKSIZE), inputQ31, BLOCKSIZE); + + /* ---------------------------------------------------------------------- + ** Scale down by 1/8. This provides additional headroom so that the + ** graphic EQ can apply gain. + ** ------------------------------------------------------------------- */ + + arm_scale_q31(inputQ31, 0x7FFFFFFF, -3, inputQ31, BLOCKSIZE); + + /* ---------------------------------------------------------------------- + ** Call the Q31 Biquad Cascade DF1 32x64 process function for band1, band2 + ** ------------------------------------------------------------------- */ + + arm_biquad_cas_df1_32x64_q31(&S1, inputQ31, outputQ31, BLOCKSIZE); + arm_biquad_cas_df1_32x64_q31(&S2, outputQ31, outputQ31, BLOCKSIZE); + + /* ---------------------------------------------------------------------- + ** Call the Q31 Biquad Cascade DF1 process function for band3, band4, band5 + ** ------------------------------------------------------------------- */ + + arm_biquad_cascade_df1_q31(&S3, outputQ31, outputQ31, BLOCKSIZE); + arm_biquad_cascade_df1_q31(&S4, outputQ31, outputQ31, BLOCKSIZE); + arm_biquad_cascade_df1_q31(&S5, outputQ31, outputQ31, BLOCKSIZE); + + /* ---------------------------------------------------------------------- + ** Convert Q31 result back to float + ** ------------------------------------------------------------------- */ + + arm_q31_to_float(outputQ31, outputF32 + (i * BLOCKSIZE), BLOCKSIZE); + + /* ---------------------------------------------------------------------- + ** Scale back up + ** ------------------------------------------------------------------- */ + + arm_scale_f32(outputF32 + (i * BLOCKSIZE), 8.0f, outputF32 + (i * BLOCKSIZE), BLOCKSIZE); + }; + + snr = arm_snr_f32(testRefOutput_f32, testOutput, TESTLENGTH); + + if (snr < SNR_THRESHOLD_F32) + { + status = ARM_MATH_TEST_FAILURE; + } + else + { + status = ARM_MATH_SUCCESS; + } + + /* ---------------------------------------------------------------------- + ** Loop here if the signal does not match the reference output. + ** ------------------------------------------------------------------- */ + + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + +/** \endlink */ + + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.c new file mode 100644 index 0000000..f615e6f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.c @@ -0,0 +1,466 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 b +* +* Project: CMSIS DSP Library +* +* Title: math_helper.c +* +* Description: Definition of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Include standard header files +* -------------------------------------------------------------------- */ +#include + +/* ---------------------------------------------------------------------- +* Include project header files +* -------------------------------------------------------------------- */ +#include "math_helper.h" + +/** + * @brief Caluclation of SNR + * @param[in] pRef Pointer to the reference buffer + * @param[in] pTest Pointer to the test buffer + * @param[in] buffSize total number of samples + * @return SNR + * The function Caluclates signal to noise ratio for the reference output + * and test output + */ + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize) +{ + float EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + float SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10 (EnergySignal / EnergyError); + + return (SNR); + +} + + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q15 (q15_t * input_buf, uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Converts float to fixed in q12.20 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to outputbuffer + * @param[in] numSamples number of samples in the input buffer + * @return none + * The function converts floating point values to fixed point(q12.20) values + */ + +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1048576.0f corresponds to pow(2, 20) */ + pOut[i] = (q31_t) (pIn[i] * 1048576.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 1.0) + { + pOut[i] = 0x000FFFFF; + } + } +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q31 (q31_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q7 (q7_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + + + +/** + * @brief Caluclates number of guard bits + * @param[in] num_adds number of additions + * @return guard bits + * The function Caluclates the number of guard bits + * depending on the numtaps + */ + +uint32_t arm_calc_guard_bits (uint32_t num_adds) +{ + uint32_t i = 1, j = 0; + + if (num_adds == 1) + { + return (0); + } + + while (i < num_adds) + { + i = i * 2; + j++; + } + + return (j); +} + +/** + * @brief Apply guard bits to buffer + * @param[in,out] pIn pointer to input buffer + * @param[in] numSamples number of samples in the input buffer + * @param[in] guard_bits guard bits + * @return none + */ + +void arm_apply_guard_bits (float32_t *pIn, + uint32_t numSamples, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + pIn[i] = pIn[i] * arm_calc_2pow(guard_bits); + } +} + +/** + * @brief Calculates pow(2, numShifts) + * @param[in] numShifts number of shifts + * @return pow(2, numShifts) + */ +uint32_t arm_calc_2pow(uint32_t numShifts) +{ + + uint32_t i, val = 1; + + for (i = 0; i < numShifts; i++) + { + val = val * 2; + } + + return(val); +} + + + +/** + * @brief Converts float to fixed q14 + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q14 (float *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 16384.0f corresponds to pow(2, 14) */ + pOut[i] = (q15_t) (pIn[i] * 16384.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFF; + } + + } + +} + + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q30 (float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 1073741824.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q29 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 536870912.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 4.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + + +/** + * @brief Converts float to fixed q28 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q28 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 268435456.0f corresponds to pow(2, 28) */ + pOut[i] = (q31_t) (pIn[i] * 268435456.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 8.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Clip the float values to +/- 1 + * @param[in,out] pIn input buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_clip_f32 (float *pIn, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + if (pIn[i] > 1.0f) + { + pIn[i] = 1.0; + } + else if ( pIn[i] < -1.0f) + { + pIn[i] = -1.0; + } + + } +} + + + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.h b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.h new file mode 100644 index 0000000..5a18734 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_graphic_equalizer_example/math_helper.h @@ -0,0 +1,63 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2013 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* +* Title: math_helper.h +* +* Description: Prototypes of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + + +#include "arm_math.h" + +#ifndef MATH_HELPER_H +#define MATH_HELPER_H + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize); +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples); +void arm_provide_guard_bits_q15(q15_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_provide_guard_bits_q31(q31_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_float_to_q14(float *pIn, q15_t *pOut, uint32_t numSamples); +void arm_float_to_q29(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q28(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q30(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_clip_f32(float *pIn, uint32_t numSamples); +uint32_t arm_calc_guard_bits(uint32_t num_adds); +void arm_apply_guard_bits (float32_t * pIn, uint32_t numSamples, uint32_t guard_bits); +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t * pOut, uint32_t numSamples); +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t *pOut, uint32_t numSamples); +uint32_t arm_calc_2pow(uint32_t guard_bits); +#endif + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/Abstract.txt new file mode 100644 index 0000000..9062c48 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_linear_interp_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_data.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_data.c new file mode 100644 index 0000000..309326e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_data.c @@ -0,0 +1,23616 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_linear_interp_data.c +* +* Description: Data file used for example. Generation method described +* below +* +* Target Processor: Cortex-M4/Cortex-M3/Cortex-M0 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Table generated from following MATLAB Command +* x = -pi: 0.00005 : (2*pi - 0.00005); +* y = sin(x); +* where pi value is 3.141592653589793 +* --------------------------------------------------------------------*/ + +float arm_linear_interep_table[188495] = { + + +-0.000000000000000122, -0.000049999999979173, -0.000099999999833667, -0.000149999999437717, -0.000199999998666767, -0.000249999997395817, -0.000299999995500311, -0.000349999992854362, +-0.000399999989333412, -0.000449999984812462, -0.000499999979166956, -0.000549999972271007, -0.000599999964000057, -0.000649999954229107, -0.000699999942833602, -0.000749999929687653, +-0.000799999914666704, -0.000849999897645755, -0.000899999878500250, -0.000949999857104302, -0.000999999833333354, -0.001049999807062851, -0.001099999778166904, -0.001149999746520957, +-0.001199999712000011, -0.001249999674479510, -0.001299999633833566, -0.001349999589937622, -0.001399999542666680, -0.001449999491896183, -0.001499999437500243, -0.001549999379354304, +-0.001599999317333367, -0.001649999251312876, -0.001699999181166942, -0.001749999106771011, -0.001799999028000082, -0.001849998944729599, -0.001899998856833675, -0.001949998764187754, +-0.001999998666666836, -0.002049998564146365, -0.002099998456500453, -0.002149998343604546, -0.002199998225334087, -0.002249998101563188, -0.002299997972167294, -0.002349997837021405, +-0.002399997696000966, -0.002449997548980088, -0.002499997395834216, -0.002549997236438351, -0.002599997070667937, -0.002649996898397086, -0.002699996719501243, -0.002749996533855408, +-0.002799996341335026, -0.002849996141814208, -0.002899995935168401, -0.002949995721272604, -0.002999995500002261, -0.003049995271231486, -0.003099995034835722, -0.003149994790690415, +-0.003199994538669677, -0.003249994278648952, -0.003299994010503243, -0.003349993734107991, -0.003399993449337312, -0.003449993156066649, -0.003499992854171003, -0.003549992543525819, +-0.003599992224005209, -0.003649991895484619, -0.003699991557839049, -0.003749991210943944, -0.003799990854673418, -0.003849990488902914, -0.003899990113507434, -0.003949989728362423, +-0.003999989333341993, -0.004049988928321590, -0.004099988513176658, -0.004149988087781312, -0.004199987652010995, -0.004249987205740709, -0.004299986748845899, -0.004349986281200678, +-0.004399985802680492, -0.004449985313160341, -0.004499984812515671, -0.004549984300620594, -0.004599983777350557, -0.004649983242580561, -0.004699982696186050, -0.004749982138041138, +-0.004799981568021272, -0.004849980986001451, -0.004899980391857122, -0.004949979785462398, -0.004999979166692725, -0.005049978535423547, -0.005099977891528979, -0.005149977234884466, +-0.005199976565365011, -0.005249975882846058, -0.005299975187201721, -0.005349974478307446, -0.005399973756038235, -0.005449973020269535, -0.005499972270875456, -0.005549971507731448, +-0.005599970730712511, -0.005649969939694091, -0.005699969134550302, -0.005749968315156590, -0.005799967481387958, -0.005849966633119851, -0.005899965770226383, -0.005949964892583000, +-0.005999964000064706, -0.006049963092546945, -0.006099962169903833, -0.006149961232010816, -0.006199960278743339, -0.006249959309975518, -0.006299958325582797, -0.006349957325440182, +-0.006399956309423117, -0.006449955277405718, -0.006499954229263430, -0.006549953164871257, -0.006599952084104644, -0.006649950986837708, -0.006699949872945895, -0.006749948742304206, +-0.006799947594788089, -0.006849946430271660, -0.006899945248630365, -0.006949944049739206, -0.006999942833473632, -0.007049941599707755, -0.007099940348317025, -0.007149939079176889, +-0.007199937792161461, -0.007249936487146187, -0.007299935164006074, -0.007349933822616566, -0.007399932462851779, -0.007449931084587162, -0.007499929687697716, -0.007549928272058891, +-0.007599926837544801, -0.007649925384030893, -0.007699923911392173, -0.007749922419504085, -0.007799920908240749, -0.007849919377477610, -0.007899917827089672, -0.007949916256952384, +-0.007999914666939863, -0.008049913056927554, -0.008099911426790906, -0.008149909776404035, -0.008199908105642390, -0.008249906414380975, -0.008299904702495238, -0.008349902969859295, +-0.008399901216348595, -0.008449899441838141, -0.008499897646203384, -0.008549895829318437, -0.008599893991058752, -0.008649892131299332, -0.008699890249915625, -0.008749888346781748, +-0.008799886421773151, -0.008849884474764837, -0.008899882505632256, -0.008949880514249525, -0.008999878500492093, -0.009049876464234965, -0.009099874405353590, -0.009149872323722084, +-0.009199870219215898, -0.009249868091710479, -0.009299865941079948, -0.009349863767199750, -0.009399861569944894, -0.009449859349190827, -0.009499857104811669, -0.009549854836682867, +-0.009599852544679429, -0.009649850228676803, -0.009699847888549109, -0.009749845524171793, -0.009799843135419864, -0.009849840722168771, -0.009899838284292632, -0.009949835821666898, +-0.009999833334166574, -0.010049830821667110, -0.010099828284042626, -0.010149825721168572, -0.010199823132920397, -0.010249820519172219, -0.010299817879799491, -0.010349815214677217, +-0.010399812523680850, -0.010449809806684508, -0.010499807063563642, -0.010549804294193258, -0.010599801498448806, -0.010649798676204407, -0.010699795827335511, -0.010749792951717126, +-0.010799790049224703, -0.010849787119732359, -0.010899784163115548, -0.010949781179249277, -0.010999778168008997, -0.011049775129268828, -0.011099772062904221, -0.011149768968790628, +-0.011199765846802169, -0.011249762696814294, -0.011299759518702013, -0.011349756312340777, -0.011399753077604706, -0.011449749814369253, -0.011499746522509425, -0.011549743201900674, +-0.011599739852417123, -0.011649736473934221, -0.011699733066326979, -0.011749729629470847, -0.011799726163239948, -0.011849722667509732, -0.011899719142155211, -0.011949715587051834, +-0.011999712002073726, -0.012049708387096337, -0.012099704741995123, -0.012149701066644201, -0.012199697360919026, -0.012249693624694609, -0.012299689857846402, -0.012349686060248525, +-0.012399682231776434, -0.012449678372305137, -0.012499674481710089, -0.012549670559865410, -0.012599666606646555, -0.012649662621928532, -0.012699658605586799, -0.012749654557495473, +-0.012799650477530011, -0.012849646365565424, -0.012899642221477166, -0.012949638045139357, -0.012999633836427452, -0.013049629595216463, -0.013099625321381845, -0.013149621014797719, +-0.013199616675339540, -0.013249612302882765, -0.013299607897301514, -0.013349603458471243, -0.013399598986266964, -0.013449594480564131, -0.013499589941236869, -0.013549585368160630, +-0.013599580761210430, -0.013649576120261721, -0.013699571445188626, -0.013749566735866605, -0.013799561992170667, -0.013849557213976266, -0.013899552401157530, -0.013949547553589911, +-0.013999542671148425, -0.014049537753708525, -0.014099532801144338, -0.014149527813331319, -0.014199522790144923, -0.014249517731459277, -0.014299512637149837, -0.014349507507091614, +-0.014399502341160067, -0.014449497139229321, -0.014499491901174831, -0.014549486626871612, -0.014599481316195120, -0.014649475969019481, -0.014699470585220153, -0.014749465164672147, +-0.014799459707250922, -0.014849454212830605, -0.014899448681286651, -0.014949443112494076, -0.014999437506328338, -0.015049431862663561, -0.015099426181375206, -0.015149420462338728, +-0.015199414705428255, -0.015249408910519246, -0.015299403077486715, -0.015349397206206119, -0.015399391296551587, -0.015449385348398575, -0.015499379361622101, -0.015549373336097624, +-0.015599367271699268, -0.015649361168302494, -0.015699355025782315, -0.015749348844014195, -0.015799342622872262, -0.015849336362231969, -0.015899330061968333, -0.015949323721956819, +-0.015999317342071551, -0.016049310922187990, -0.016099304462181149, -0.016149297961926493, -0.016199291421298147, -0.016249284840171574, -0.016299278218422232, -0.016349271555924253, +-0.016399264852553091, -0.016449258108183769, -0.016499251322691748, -0.016549244495951149, -0.016599237627837445, -0.016649230718225643, -0.016699223766991209, -0.016749216774008271, +-0.016799209739152290, -0.016849202662298290, -0.016899195543321723, -0.016949188382096723, -0.016999181178498753, -0.017049173932402829, -0.017099166643684417, -0.017149159312217641, +-0.017199151937877969, -0.017249144520540861, -0.017299137060080447, -0.017349129556372193, -0.017399122009291113, -0.017449114418712670, -0.017499106784510998, -0.017549099106561560, +-0.017599091384739373, -0.017649083618919904, -0.017699075808977279, -0.017749067954786969, -0.017799060056223986, -0.017849052113163795, -0.017899044125480532, -0.017949036093049660, +-0.017999028015746196, -0.018049019893445605, -0.018099011726022022, -0.018149003513350907, -0.018198995255307732, -0.018248986951766622, -0.018298978602603044, -0.018348970207692019, +-0.018398961766909014, -0.018448953280128161, -0.018498944747224924, -0.018548936168074327, -0.018598927542551831, -0.018648918870531574, -0.018698910151889018, -0.018748901386499189, +-0.018798892574237547, -0.018848883714978233, -0.018898874808596710, -0.018948865854967998, -0.018998856853967565, -0.019048847805469546, -0.019098838709349409, -0.019148829565482174, +-0.019198820373743309, -0.019248811134006949, -0.019298801846148562, -0.019348792510043615, -0.019398783125566241, -0.019448773692591910, -0.019498764210995646, -0.019548754680652914, +-0.019598745101437852, -0.019648735473225928, -0.019698725795892161, -0.019748716069312028, -0.019798706293359659, -0.019848696467910525, -0.019898686592839651, -0.019948676668022504, +-0.019998666693333219, -0.020048656668647271, -0.020098646593839677, -0.020148636468785914, -0.020198626293360115, -0.020248616067437750, -0.020298605790894288, -0.020348595463603868, +-0.020398585085441959, -0.020448574656283587, -0.020498564176004225, -0.020548553644478006, -0.020598543061580404, -0.020648532427186443, -0.020698521741171597, -0.020748511003410002, +-0.020798500213777129, -0.020848489372148005, -0.020898478478398104, -0.020948467532401559, -0.020998456534033847, -0.021048445483169996, -0.021098434379685473, -0.021148423223454418, +-0.021198412014352307, -0.021248400752254610, -0.021298389437035468, -0.021348378068570352, -0.021398366646734290, -0.021448355171402755, -0.021498343642449892, -0.021548332059751166, +-0.021598320423181612, -0.021648308732616698, -0.021698296987930570, -0.021748285188998701, -0.021798273335696117, -0.021848261427898294, -0.021898249465479372, -0.021948237448314829, +-0.021998225376279691, -0.022048213249249434, -0.022098201067098200, -0.022148188829701463, -0.022198176536934698, -0.022248164188672048, -0.022298151784788989, -0.022348139325160547, +-0.022398126809662203, -0.022448114238168098, -0.022498101610553708, -0.022548088926694063, -0.022598076186464637, -0.022648063389739580, -0.022698050536394364, -0.022748037626304021, +-0.022798024659344031, -0.022848011635388531, -0.022897998554313004, -0.022947985415992481, -0.022997972220302438, -0.023047958967117019, -0.023097945656311705, -0.023147932287761526, +-0.023197918861341957, -0.023247905376927152, -0.023297891834392580, -0.023347878233613725, -0.023397864574464730, -0.023447850856821072, -0.023497837080557787, -0.023547823245550353, +-0.023597809351672917, -0.023647795398800960, -0.023697781386809513, -0.023747767315574056, -0.023797753184968740, -0.023847738994869038, -0.023897724745149989, -0.023947710435687070, +-0.023997696066354435, -0.024047681637027557, -0.024097667147581475, -0.024147652597891669, -0.024197637987832289, -0.024247623317278814, -0.024297608586106724, -0.024347593794190169, +-0.024397578941404627, -0.024447564027625143, -0.024497549052727188, -0.024547534016584920, -0.024597518919073816, -0.024647503760068912, -0.024697488539445693, -0.024747473257078312, +-0.024797457912842245, -0.024847442506612534, -0.024897427038264662, -0.024947411507672778, -0.024997395914712364, -0.025047380259258463, -0.025097364541186551, -0.025147348760370787, +-0.025197332916686650, -0.025247317010009623, -0.025297301040213861, -0.025347285007174848, -0.025397268910767622, -0.025447252750867667, -0.025497236527349136, -0.025547220240087511, +-0.025597203888957840, -0.025647187473835601, -0.025697170994594950, -0.025747154451111372, -0.025797137843259908, -0.025847121170916042, -0.025897104433953929, -0.025947087632249056, +-0.025997070765676464, -0.026047053834111638, -0.026097036837428735, -0.026147019775503239, -0.026197002648210635, -0.026246985455425084, -0.026296968197022069, -0.026346950872876633, +-0.026396933482864263, -0.026446916026859116, -0.026496898504736681, -0.026546880916371998, -0.026596863261640555, -0.026646845540416509, -0.026696827752575352, -0.026746809897992125, +-0.026796791976542320, -0.026846773988100085, -0.026896755932540921, -0.026946737809739864, -0.026996719619572406, -0.027046701361912708, -0.027096683036636253, -0.027146664643618094, +-0.027196646182733715, -0.027246627653857276, -0.027296609056864270, -0.027346590391630184, -0.027396571658029178, -0.027446552855936744, -0.027496533985227927, -0.027546515045778219, +-0.027596496037461778, -0.027646476960154098, -0.027696457813730226, -0.027746438598065654, -0.027796419313034542, -0.027846399958512381, -0.027896380534374220, -0.027946361040495551, +-0.027996341476750536, -0.028046321843014668, -0.028096302139162994, -0.028146282365071010, -0.028196262520612875, -0.028246242605664086, -0.028296222620100130, -0.028346202563795178, +-0.028396182436624718, -0.028446162238463801, -0.028496141969187923, -0.028546121628671248, -0.028596101216789266, -0.028646080733417033, -0.028696060178430041, -0.028746039551702456, +-0.028796018853109770, -0.028845998082527038, -0.028895977239829753, -0.028945956324892084, -0.028995935337589523, -0.029045914277797125, -0.029095893145390381, -0.029145871940243463, +-0.029195850662231865, -0.029245829311231087, -0.029295807887115288, -0.029345786389759970, -0.029395764819040188, -0.029445743174831437, -0.029495721457007882, -0.029545699665445027, +-0.029595677800017921, -0.029645655860602062, -0.029695633847071624, -0.029745611759302099, -0.029795589597168545, -0.029845567360546461, -0.029895545049310013, -0.029945522663334705, +-0.029995500202495588, -0.030045477666668166, -0.030095455055726604, -0.030145432369546407, -0.030195409608002627, -0.030245386770970769, -0.030295363858325000, -0.030345340869940819, +-0.030395317805693732, -0.030445294665457905, -0.030495271449108841, -0.030545248156521602, -0.030595224787571682, -0.030645201342133260, -0.030695177820081833, -0.030745154221292460, +-0.030795130545640648, -0.030845106793000565, -0.030895082963247715, -0.030945059056257156, -0.030995035071904393, -0.031045011010063600, -0.031094986870610280, -0.031144962653419490, +-0.031194938358366741, -0.031244913985326202, -0.031294889534173378, -0.031344865004783770, -0.031394840397031561, -0.031444815710792245, -0.031494790945940897, -0.031544766102353010, +-0.031594741179902762, -0.031644716178465669, -0.031694691097916783, -0.031744665938131605, -0.031794640698984328, -0.031844615380350445, -0.031894589982105023, -0.031944564504123571, +-0.031994538946280265, -0.032044513308450616, -0.032094487590509674, -0.032144461792332962, -0.032194435913794651, -0.032244409954770251, -0.032294383915135269, -0.032344357794763884, +-0.032394331593531604, -0.032444305311313495, -0.032494278947985067, -0.032544252503420502, -0.032594225977495297, -0.032644199370084531, -0.032694172681063713, -0.032744145910307020, +-0.032794119057689960, -0.032844092123087601, -0.032894065106375457, -0.032944038007427706, -0.032994010826119857, -0.033043983562326990, -0.033093956215924598, -0.033143928786786875, +-0.033193901274789335, -0.033243873679807037, -0.033293846001715498, -0.033343818240388901, -0.033393790395702755, -0.033443762467532584, -0.033493734455752558, -0.033543706360238200, +-0.033593678180864575, -0.033643649917507193, -0.033693621570040251, -0.033743593138339245, -0.033793564622279268, -0.033843536021735815, -0.033893507336583077, -0.033943478566696578, +-0.033993449711951375, -0.034043420772222999, -0.034093391747385619, -0.034143362637314767, -0.034193333441885507, -0.034243304160973355, -0.034293274794452495, -0.034343245342198452, +-0.034393215804086739, -0.034443186179991543, -0.034493156469788386, -0.034543126673352333, -0.034593096790558907, -0.034643066821282299, -0.034693036765398019, -0.034743006622781153, +-0.034792976393307209, -0.034842946076850380, -0.034892915673286187, -0.034942885182489711, -0.034992854604336460, -0.035042823938700625, -0.035092793185457737, -0.035142762344482860, +-0.035192731415651525, -0.035242700398837916, -0.035292669293917563, -0.035342638100765975, -0.035392606819257343, -0.035442575449267197, -0.035492543990670616, -0.035542512443343117, +-0.035592480807158891, -0.035642449081993467, -0.035692417267721918, -0.035742385364219767, -0.035792353371361212, -0.035842321289021775, -0.035892289117076537, -0.035942256855401013, +-0.035992224503869408, -0.036042192062357238, -0.036092159530739590, -0.036142126908891986, -0.036192094196688625, -0.036242061394005022, -0.036292028500716271, -0.036341995516697888, +-0.036391962441824077, -0.036441929275970356, -0.036491896019012260, -0.036541862670823974, -0.036591829231281035, -0.036641795700258523, -0.036691762077631966, -0.036741728363275557, +-0.036791694557064832, -0.036841660658874870, -0.036891626668581194, -0.036941592586058017, -0.036991558411180854, -0.037041524143824792, -0.037091489783865367, -0.037141455331176770, +-0.037191420785634539, -0.037241386147113753, -0.037291351415489948, -0.037341316590637316, -0.037391281672431401, -0.037441246660747718, -0.037491211555460480, -0.037541176356445209, +-0.037591141063576999, -0.037641105676731380, -0.037691070195782550, -0.037741034620606045, -0.037790998951076960, -0.037840963187070815, -0.037890927328461818, -0.037940891375125504, +-0.037990855326936968, -0.038040819183771730, -0.038090782945504005, -0.038140746612009321, -0.038190710183162765, -0.038240673658839881, -0.038290637038914874, -0.038340600323263266, +-0.038390563511760609, -0.038440526604281093, -0.038490489600700263, -0.038540452500893212, -0.038590415304735469, -0.038640378012101247, -0.038690340622866082, -0.038740303136905060, +-0.038790265554093727, -0.038840227874306285, -0.038890190097418273, -0.038940152223304790, -0.038990114251841367, -0.039040076182902214, -0.039090038016362870, -0.039139999752098434, +-0.039189961389984436, -0.039239922929895095, -0.039289884371705948, -0.039339845715292532, -0.039389806960529065, -0.039439768107291072, -0.039489729155453658, -0.039539690104892368, +-0.039589650955481413, -0.039639611707096324, -0.039689572359612207, -0.039739532912904607, -0.039789493366847728, -0.039839453721317121, -0.039889413976187872, -0.039939374131335532, +-0.039989334186634320, -0.040039294141959766, -0.040089253997186977, -0.040139213752191497, -0.040189173406847543, -0.040239132961030655, -0.040289092414616375, -0.040339051767478921, +-0.040389011019493840, -0.040438970170536229, -0.040488929220481633, -0.040538888169204278, -0.040588847016579700, -0.040638805762483000, -0.040688764406789736, -0.040738722949374112, +-0.040788681390111679, -0.040838639728877552, -0.040888597965547259, -0.040938556099995034, -0.040988514132096414, -0.041038472061726512, -0.041088429888760873, -0.041138387613073715, +-0.041188345234540590, -0.041238302753036603, -0.041288260168437299, -0.041338217480616897, -0.041388174689450961, -0.041438131794815029, -0.041488088796583319, -0.041538045694631390, +-0.041588002488834347, -0.041637959179067742, -0.041687915765205794, -0.041737872247124060, -0.041787828624697640, -0.041837784897802099, -0.041887741066311650, -0.041937697130101842, +-0.041987653089047797, -0.042037608943025065, -0.042087564691907858, -0.042137520335571749, -0.042187475873891836, -0.042237431306743671, -0.042287386634001493, -0.042337341855540847, +-0.042387296971237283, -0.042437251980965041, -0.042487206884599664, -0.042537161682016274, -0.042587116373090421, -0.042637070957696331, -0.042687025435709569, -0.042736979807005242, +-0.042786934071458907, -0.042836888228944790, -0.042886842279338457, -0.042936796222515020, -0.042986750058350030, -0.043036703786717728, -0.043086657407493664, -0.043136610920552952, +-0.043186564325771164, -0.043236517623022518, -0.043286470812182579, -0.043336423893126905, -0.043386376865729728, -0.043436329729866607, -0.043486282485412663, -0.043536235132243459, +-0.043586187670233222, -0.043636140099257516, -0.043686092419191462, -0.043736044629910618, -0.043785996731289217, -0.043835948723202824, -0.043885900605526565, -0.043935852378135992, +-0.043985804040905345, -0.044035755593710195, -0.044085707036425649, -0.044135658368927279, -0.044185609591089324, -0.044235560702787342, -0.044285511703896455, -0.044335462594292240, +-0.044385413373848923, -0.044435364042442069, -0.044485314599947250, -0.044535265046238698, -0.044585215381191985, -0.044635165604682239, -0.044685115716585018, -0.044735065716774568, +-0.044785015605126446, -0.044834965381515789, -0.044884915045818166, -0.044934864597907805, -0.044984814037660290, -0.045034763364950735, -0.045084712579654712, -0.045134661681646468, +-0.045184610670801574, -0.045234559546995151, -0.045284508310102771, -0.045334456959998673, -0.045384405496558436, -0.045434353919657632, -0.045484302229170492, -0.045534250424972604, +-0.045584198506939087, -0.045634146474945521, -0.045684094328866137, -0.045734042068576522, -0.045783989693951803, -0.045833937204867552, -0.045883884601198015, -0.045933831882818764, +-0.045983779049604941, -0.046033726101432110, -0.046083673038174518, -0.046133619859707743, -0.046183566565906921, -0.046233513156647622, -0.046283459631804101, -0.046333405991251929, +-0.046383352234866684, -0.046433298362522614, -0.046483244374095303, -0.046533190269459880, -0.046583136048491923, -0.046633081711065685, -0.046683027257056739, -0.046732972686340225, +-0.046782917998791723, -0.046832863194285486, -0.046882808272697092, -0.046932753233901670, -0.046982698077774818, -0.047032642804190769, -0.047082587413025116, -0.047132531904152994, +-0.047182476277449988, -0.047232420532790344, -0.047282364670049655, -0.047332308689103049, -0.047382252589826118, -0.047432196372093109, -0.047482140035779608, -0.047532083580761206, +-0.047582027006912150, -0.047631970314108020, -0.047681913502223970, -0.047731856571135579, -0.047781799520717101, -0.047831742350844128, -0.047881685061391802, -0.047931627652235700, +-0.047981570123250085, -0.048031512474310548, -0.048081454705292230, -0.048131396816070718, -0.048181338806520271, -0.048231280676516476, -0.048281222425934481, -0.048331164054649871, +-0.048381105562536907, -0.048431046949471181, -0.048480988215328286, -0.048530929359982468, -0.048580870383309334, -0.048630811285184018, -0.048680752065482120, -0.048730692724077894, +-0.048780633260846945, -0.048830573675664408, -0.048880513968405877, -0.048930454138945624, -0.048980394187159236, -0.049030334112921854, -0.049080273916109085, -0.049130213596595189, +-0.049180153154255758, -0.049230092588965949, -0.049280031900601345, -0.049329971089036223, -0.049379910154146167, -0.049429849095806784, -0.049479787913892334, -0.049529726608278417, +-0.049579665178840181, -0.049629603625453225, -0.049679541947991818, -0.049729480146331551, -0.049779418220347586, -0.049829356169915524, -0.049879293994909625, -0.049929231695205488, +-0.049979169270678275, -0.050029106721203580, -0.050079044046655675, -0.050128981246910162, -0.050178918321842195, -0.050228855271327380, -0.050278792095239978, -0.050328728793455596, +-0.050378665365849389, -0.050428601812296969, -0.050478538132672598, -0.050528474326851883, -0.050578410394710421, -0.050628346336122496, -0.050678282150963705, -0.050728217839109205, +-0.050778153400434602, -0.050828088834814177, -0.050878024142123529, -0.050927959322237815, -0.050977894375032654, -0.051027829300382306, -0.051077764098162393, -0.051127698768248062, +-0.051177633310514933, -0.051227567724837275, -0.051277502011090700, -0.051327436169150371, -0.051377370198891888, -0.051427304100189544, -0.051477237872918934, -0.051527171516955676, +-0.051577105032174046, -0.051627038418449650, -0.051676971675657664, -0.051726904803673687, -0.051776837802372008, -0.051826770671628226, -0.051876703411317525, -0.051926636021315510, +-0.051976568501496463, -0.052026500851735991, -0.052076433071909262, -0.052126365161891904, -0.052176297121558184, -0.052226228950783722, -0.052276160649443688, -0.052326092217413696, +-0.052376023654568026, -0.052425954960782298, -0.052475886135932133, -0.052525817179891805, -0.052575748092536935, -0.052625678873742691, -0.052675609523384695, -0.052725540041337234, +-0.052775470427475921, -0.052825400681675933, -0.052875330803812882, -0.052925260793761066, -0.052975190651396095, -0.053025120376593154, -0.053075049969227850, -0.053124979429174476, +-0.053174908756308654, -0.053224837950505567, -0.053274767011640821, -0.053324695939588718, -0.053374624734224871, -0.053424553395424908, -0.053474481923063123, -0.053524410317015131, +-0.053574338577156107, -0.053624266703361685, -0.053674194695506154, -0.053724122553465134, -0.053774050277113808, -0.053823977866327796, -0.053873905320981401, -0.053923832640950242, +-0.053973759826109496, -0.054023686876334805, -0.054073613791500441, -0.054123540571482054, -0.054173467216154805, -0.054223393725394337, -0.054273320099074943, -0.054323246337072244, +-0.054373172439261881, -0.054423098405518136, -0.054473024235716642, -0.054522949929732598, -0.054572875487441615, -0.054622800908718003, -0.054672726193437382, -0.054722651341474957, +-0.054772576352706340, -0.054822501227005840, -0.054872425964249086, -0.054922350564311266, -0.054972275027068015, -0.055022199352393636, -0.055072123540163755, -0.055122047590253562, +-0.055171971502538698, -0.055221895276893460, -0.055271818913193486, -0.055321742411313962, -0.055371665771130528, -0.055421588992517486, -0.055471512075350470, -0.055521435019505121, +-0.055571357824855741, -0.055621280491277958, -0.055671203018646982, -0.055721125406838441, -0.055771047655726637, -0.055820969765187224, -0.055870891735095379, -0.055920813565326750, +-0.055970735255755640, -0.056020656806257701, -0.056070578216708113, -0.056120499486982521, -0.056170420616955243, -0.056220341606501911, -0.056270262455497724, -0.056320183163818323, +-0.056370103731338023, -0.056420024157932465, -0.056469944443477291, -0.056519864587846809, -0.056569784590916668, -0.056619704452562064, -0.056669624172658639, -0.056719543751080716, +-0.056769463187703935, -0.056819382482403487, -0.056869301635055033, -0.056919220645532884, -0.056969139513712679, -0.057019058239469622, -0.057068976822679369, -0.057118895263216229, +-0.057168813560955850, -0.057218731715773435, -0.057268649727544640, -0.057318567596143774, -0.057368485321446491, -0.057418402903328433, -0.057468320341663930, -0.057518237636328622, +-0.057568154787197720, -0.057618071794146873, -0.057667988657050410, -0.057717905375783973, -0.057767821950222766, -0.057817738380242456, -0.057867654665717354, -0.057917570806523114, +-0.057967486802534947, -0.058017402653628508, -0.058067318359678120, -0.058117233920559432, -0.058167149336147660, -0.058217064606318460, -0.058266979730946154, -0.058316894709906399, +-0.058366809543074410, -0.058416724230325838, -0.058466638771535011, -0.058516553166577591, -0.058566467415329226, -0.058616381517664254, -0.058666295473458328, -0.058716209282586661, +-0.058766122944924913, -0.058816036460347415, -0.058865949828729829, -0.058915863049947365, -0.058965776123875685, -0.059015689050389127, -0.059065601829363344, -0.059115514460673556, +-0.059165426944195423, -0.059215339279803283, -0.059265251467372798, -0.059315163506779178, -0.059365075397898093, -0.059414987140603878, -0.059464898734772197, -0.059514810180278710, +-0.059564721476997755, -0.059614632624804993, -0.059664543623575657, -0.059714454473185401, -0.059764365173508562, -0.059814275724420815, -0.059864186125797379, -0.059914096377513916, +-0.059964006479444776, -0.060013916431465614, -0.060063826233451661, -0.060113735885278588, -0.060163645386820737, -0.060213554737953763, -0.060263463938552905, -0.060313372988493832, +-0.060363281887650888, -0.060413190635899734, -0.060463099233116047, -0.060513007679174169, -0.060562915973949770, -0.060612824117318082, -0.060662732109154779, -0.060712639949334200, +-0.060762547637732020, -0.060812455174223477, -0.060862362558684234, -0.060912269790988648, -0.060962176871012380, -0.061012083798630670, -0.061061990573719201, -0.061111897196152308, +-0.061161803665805668, -0.061211709982554520, -0.061261616146274546, -0.061311522156840083, -0.061361428014126820, -0.061411333718009983, -0.061461239268365254, -0.061511144665066991, +-0.061561049907990856, -0.061610954997012544, -0.061660859932006401, -0.061710764712848115, -0.061760669339412912, -0.061810573811576473, -0.061860478129213164, -0.061910382292198654, +-0.061960286300408195, -0.062010190153717455, -0.062060093852000807, -0.062109997395133919, -0.062159900782992036, -0.062209804015450842, -0.062259707092384702, -0.062309610013669289, +-0.062359512779179851, -0.062409415388792078, -0.062459317842380319, -0.062509220139820271, -0.062559122280987617, -0.062609024265756708, -0.062658926094003239, -0.062708827765602451, +-0.062758729280430040, -0.062808630638360369, -0.062858531839269122, -0.062908432883031537, -0.062958333769523311, -0.063008234498618809, -0.063058135070193727, -0.063108035484123304, +-0.063157935740283236, -0.063207835838547888, -0.063257735778792956, -0.063307635560893666, -0.063357535184725741, -0.063407434650163547, -0.063457333957082751, -0.063507233105359065, +-0.063557132094866853, -0.063607030925481811, -0.063656929597079193, -0.063706828109534694, -0.063756726462722679, -0.063806624656518859, -0.063856522690798473, -0.063906420565437216, +-0.063956318280309468, -0.064006215835290925, -0.064056113230256839, -0.064106010465082922, -0.064155907539643522, -0.064205804453814366, -0.064255701207470692, -0.064305597800488210, +-0.064355494232741298, -0.064405390504105639, -0.064455286614456500, -0.064505182563669605, -0.064555078351619291, -0.064604973978181296, -0.064654869443231303, -0.064704764746643703, +-0.064754659888294180, -0.064804554868058001, -0.064854449685810889, -0.064904344341427209, -0.064954238834782671, -0.065004133165752528, -0.065054027334212505, -0.065103921340036966, +-0.065153815183101621, -0.065203708863281737, -0.065253602380453024, -0.065303495734489861, -0.065353388925267972, -0.065403281952663039, -0.065453174816549470, -0.065503067516802946, +-0.065552960053298776, -0.065602852425912628, -0.065652744634518923, -0.065702636678993342, -0.065752528559211182, -0.065802420275048137, -0.065852311826378601, -0.065902203213078284, +-0.065952094435022451, -0.066001985492086829, -0.066051876384145808, -0.066101767111075085, -0.066151657672749956, -0.066201548069046129, -0.066251438299837970, -0.066301328365001230, +-0.066351218264411163, -0.066401107997943493, -0.066450997565472611, -0.066500886966874243, -0.066550776202024098, -0.066600665270796555, -0.066650554173067367, -0.066700442908711785, +-0.066750331477605535, -0.066800219879623021, -0.066850108114639956, -0.066899996182531618, -0.066949884083173733, -0.066999771816440706, -0.067049659382208235, -0.067099546780351613, +-0.067149434010746578, -0.067199321073267509, -0.067249207967790145, -0.067299094694189751, -0.067348981252342066, -0.067398867642121496, -0.067448753863403738, -0.067498639916064113, +-0.067548525799978318, -0.067598411515020773, -0.067648297061067189, -0.067698182437993318, -0.067748067645673551, -0.067797952683983601, -0.067847837552798773, -0.067897722251994794, +-0.067947606781446068, -0.067997491141028335, -0.068047375330616861, -0.068097259350087397, -0.068147143199314336, -0.068197026878173431, -0.068246910386539947, -0.068296793724289637, +-0.068346676891296892, -0.068396559887437453, -0.068446442712587069, -0.068496325366620134, -0.068546207849412372, -0.068596090160839104, -0.068645972300776043, -0.068695854269097620, +-0.068745736065679547, -0.068795617690397146, -0.068845499143126140, -0.068895380423740937, -0.068945261532117288, -0.068995142468130488, -0.069045023231656275, -0.069094903822569068, +-0.069144784240744592, -0.069194664486058155, -0.069244544558385496, -0.069294424457601034, -0.069344304183580521, -0.069394183736199239, -0.069444063115332938, -0.069493942320856039, +-0.069543821352644294, -0.069593700210573428, -0.069643578894517874, -0.069693457404353371, -0.069743335739955226, -0.069793213901199178, -0.069843091887959660, -0.069892969700112398, +-0.069942847337532726, -0.069992724800096370, -0.070042602087677777, -0.070092479200152658, -0.070142356137396347, -0.070192232899284598, -0.070242109485691817, -0.070291985896493756, +-0.070341862131565736, -0.070391738190783509, -0.070441614074021483, -0.070491489781155436, -0.070541365312061094, -0.070591240666612903, -0.070641115844686603, -0.070690990846157514, +-0.070740865670901404, -0.070790740318792678, -0.070840614789707101, -0.070890489083519984, -0.070940363200107090, -0.070990237139342854, -0.071040110901103015, -0.071089984485262894, +-0.071139857891698272, -0.071189731120283539, -0.071239604170894505, -0.071289477043406435, -0.071339349737695137, -0.071389222253635004, -0.071439094591101829, -0.071488966749971350, +-0.071538838730118015, -0.071588710531417590, -0.071638582153745384, -0.071688453596977161, -0.071738324860987371, -0.071788195945651764, -0.071838066850845664, -0.071887937576444835, +-0.071937808122323726, -0.071987678488358103, -0.072037548674423274, -0.072087418680395018, -0.072137288506147770, -0.072187158151557310, -0.072237027616498944, -0.072286896900848469, +-0.072336766004480288, -0.072386634927270210, -0.072436503669093530, -0.072486372229826040, -0.072536240609342176, -0.072586108807517716, -0.072635976824228413, -0.072685844659348742, +-0.072735712312754441, -0.072785579784320875, -0.072835447073923795, -0.072885314181437663, -0.072935181106738231, -0.072985047849700863, -0.073034914410201310, -0.073084780788114020, +-0.073134646983314788, -0.073184512995678935, -0.073234378825082241, -0.073284244471399168, -0.073334109934505468, -0.073383975214276503, -0.073433840310588042, -0.073483705223314544, +-0.073533569952331776, -0.073583434497515518, -0.073633298858740245, -0.073683163035881710, -0.073733027028815276, -0.073782890837416723, -0.073832754461560485, -0.073882617901122369, +-0.073932481155977711, -0.073982344226002292, -0.074032207111070572, -0.074082069811058332, -0.074131932325840921, -0.074181794655294106, -0.074231656799292375, -0.074281518757711509, +-0.074331380530426830, -0.074381242117314159, -0.074431103518247929, -0.074480964733103935, -0.074530825761757985, -0.074580686604084512, -0.074630547259959337, -0.074680407729257797, +-0.074730268011855672, -0.074780128107627436, -0.074829988016448870, -0.074879847738195351, -0.074929707272742646, -0.074979566619965229, -0.075029425779738895, -0.075079284751938993, +-0.075129143536441331, -0.075179002133120371, -0.075228860541851891, -0.075278718762511271, -0.075328576794974303, -0.075378434639115435, -0.075428292294810489, -0.075478149761934815, +-0.075528007040364192, -0.075577864129973124, -0.075627721030637390, -0.075677577742232813, -0.075727434264633825, -0.075777290597716263, -0.075827146741355475, -0.075877002695427256, +-0.075926858459806096, -0.075976714034367787, -0.076026569418987694, -0.076076424613541610, -0.076126279617904039, -0.076176134431950759, -0.076225989055557150, -0.076275843488599004, +-0.076325697730950798, -0.076375551782488366, -0.076425405643087044, -0.076475259312622654, -0.076525112790969671, -0.076574966078003903, -0.076624819173601172, -0.076674672077635939, +-0.076724524789984039, -0.076774377310520822, -0.076824229639122096, -0.076874081775662365, -0.076923933720017421, -0.076973785472062642, -0.077023637031673850, -0.077073488398725520, +-0.077123339573093461, -0.077173190554653062, -0.077223041343280133, -0.077272891938849148, -0.077322742341235942, -0.077372592550315866, -0.077422442565964769, -0.077472292388057112, +-0.077522142016468731, -0.077571991451075434, -0.077621840691751709, -0.077671689738373392, -0.077721538590815847, -0.077771387248954896, -0.077821235712665041, -0.077871083981822090, +-0.077920932056301434, -0.077970779935978882, -0.078020627620728950, -0.078070475110427445, -0.078120322404949746, -0.078170169504171688, -0.078220016407967760, -0.078269863116213798, +-0.078319709628785178, -0.078369555945557723, -0.078419402066405935, -0.078469247991205637, -0.078519093719832234, -0.078568939252161518, -0.078618784588068036, -0.078668629727427580, +-0.078718474670115987, -0.078768319416007773, -0.078818163964978760, -0.078868008316904326, -0.078917852471660319, -0.078967696429121242, -0.079017540189162933, -0.079067383751660766, +-0.079117227116490579, -0.079167070283526875, -0.079216913252645516, -0.079266756023721852, -0.079316598596631746, -0.079366440971249716, -0.079416283147451569, -0.079466125125113155, +-0.079515966904108989, -0.079565808484314909, -0.079615649865606306, -0.079665491047859027, -0.079715332030947578, -0.079765172814747792, -0.079815013399135076, -0.079864853783985265, +-0.079914693969172876, -0.079964533954573758, -0.080014373740063302, -0.080064213325517358, -0.080114052710810443, -0.080163891895818393, -0.080213730880416598, -0.080263569664480935, +-0.080313408247885895, -0.080363246630507340, -0.080413084812220675, -0.080462922792901737, -0.080512760572425041, -0.080562598150666451, -0.080612435527501802, -0.080662272702805626, +-0.080712109676453772, -0.080761946448321645, -0.080811783018285080, -0.080861619386218636, -0.080911455551998121, -0.080961291515498982, -0.081011127276597053, -0.081060962835166867, +-0.081110798191084271, -0.081160633344224672, -0.081210468294463947, -0.081260303041676599, -0.081310137585738490, -0.081359971926525040, -0.081409806063912113, -0.081459639997774225, +-0.081509473727987225, -0.081559307254426547, -0.081609140576968053, -0.081658973695486248, -0.081708806609857021, -0.081758639319956222, -0.081808471825658369, -0.081858304126839351, +-0.081908136223374561, -0.081957968115139876, -0.082007799802009840, -0.082057631283860288, -0.082107462560566669, -0.082157293632004830, -0.082207124498049317, -0.082256955158575992, +-0.082306785613460276, -0.082356615862578045, -0.082406445905803830, -0.082456275743013493, -0.082506105374082914, -0.082555934798886635, -0.082605764017300506, -0.082655593029199975, +-0.082705421834460904, -0.082755250432957839, -0.082805078824566655, -0.082854907009162759, -0.082904734986622042, -0.082954562756819047, -0.083004390319629640, -0.083054217674929265, +-0.083104044822593787, -0.083153871762497750, -0.083203698494517031, -0.083253525018527078, -0.083303351334403752, -0.083353177442021600, -0.083403003341256499, -0.083452829031983894, +-0.083502654514079663, -0.083552479787418352, -0.083602304851875850, -0.083652129707328007, -0.083701954353649410, -0.083751778790715936, -0.083801603018403004, -0.083851427036586504, +-0.083901250845141009, -0.083951074443942370, -0.084000897832866059, -0.084050721011787927, -0.084100543980582573, -0.084150366739125848, -0.084200189287293198, -0.084250011624960527, +-0.084299833752002382, -0.084349655668294651, -0.084399477373712783, -0.084449298868132669, -0.084499120151428866, -0.084548941223477253, -0.084598762084153289, -0.084648582733332867, +-0.084698403170890543, -0.084748223396702210, -0.084798043410643759, -0.084847863212589761, -0.084897682802416108, -0.084947502179998247, -0.084997321345212068, -0.085047140297932144, +-0.085096959038034381, -0.085146777565394210, -0.085196595879887538, -0.085246413981388935, -0.085296231869774294, -0.085346049544919075, -0.085395867006699169, -0.085445684254989163, +-0.085495501289664946, -0.085545318110602411, -0.085595134717676144, -0.085644951110762035, -0.085694767289735560, -0.085744583254472595, -0.085794399004847741, -0.085844214540736888, +-0.085894029862015484, -0.085943844968559460, -0.085993659860243390, -0.086043474536943151, -0.086093288998534245, -0.086143103244892549, -0.086192917275892650, -0.086242731091410452, +-0.086292544691321443, -0.086342358075501502, -0.086392171243825228, -0.086441984196168525, -0.086491796932406870, -0.086541609452416152, -0.086591421756070971, -0.086641233843247234, +-0.086691045713820872, -0.086740857367666430, -0.086790668804659854, -0.086840480024676606, -0.086890291027592603, -0.086940101813282433, -0.086989912381622000, -0.087039722732486793, +-0.087089532865752717, -0.087139342781294371, -0.087189152478987661, -0.087238961958708075, -0.087288771220331532, -0.087338580263732604, -0.087388389088787238, -0.087438197695370895, +-0.087488006083359507, -0.087537814252627646, -0.087587622203051260, -0.087637429934506253, -0.087687237446867239, -0.087737044740010137, -0.087786851813810407, -0.087836658668143996, +-0.087886465302885491, -0.087936271717910838, -0.087986077913095498, -0.088035883888315403, -0.088085689643445153, -0.088135495178360682, -0.088185300492937477, -0.088235105587051457, +-0.088284910460577223, -0.088334715113390735, -0.088384519545367440, -0.088434323756383298, -0.088484127746312896, -0.088533931515032194, -0.088583735062417082, -0.088633538388342203, +-0.088683341492683476, -0.088733144375316403, -0.088782947036116902, -0.088832749474959588, -0.088882551691720407, -0.088932353686274848, -0.088982155458498843, -0.089031957008267007, +-0.089081758335455272, -0.089131559439939154, -0.089181360321594572, -0.089231160980296154, -0.089280961415919832, -0.089330761628341096, -0.089380561617435905, -0.089430361383078874, +-0.089480160925145935, -0.089529960243512591, -0.089579759338054787, -0.089629558208647153, -0.089679356855165607, -0.089729155277486122, -0.089778953475483314, -0.089828751449033115, +-0.089878549198011026, -0.089928346722293023, -0.089978144021753706, -0.090027941096269021, -0.090077737945714498, -0.090127534569966056, -0.090177330968898350, -0.090227127142387301, +-0.090276923090308450, -0.090326718812537732, -0.090376514308949760, -0.090426309579420522, -0.090476104623825493, -0.090525899442040647, -0.090575694033940626, -0.090625488399401349, +-0.090675282538298804, -0.090725076450507619, -0.090774870135903726, -0.090824663594362670, -0.090874456825760383, -0.090924249829971521, -0.090974042606872044, -0.091023835156337454, +-0.091073627478243713, -0.091123419572465461, -0.091173211438878660, -0.091223003077358839, -0.091272794487781944, -0.091322585670022619, -0.091372376623956836, -0.091422167349460112, +-0.091471957846408408, -0.091521748114676379, -0.091571538154139959, -0.091621327964675148, -0.091671117546156575, -0.091720906898460214, -0.091770696021461567, -0.091820484915036638, +-0.091870273579060052, -0.091920062013407786, -0.091969850217955354, -0.092019638192578745, -0.092069425937152602, -0.092119213451552884, -0.092169000735655135, -0.092218787789335330, +-0.092268574612468124, -0.092318361204929464, -0.092368147566594908, -0.092417933697340429, -0.092467719597040671, -0.092517505265571606, -0.092567290702808780, -0.092617075908628180, +-0.092666860882904434, -0.092716645625513544, -0.092766430136331485, -0.092816214415232912, -0.092865998462093799, -0.092915782276789677, -0.092965565859196561, -0.093015349209189080, +-0.093065132326643221, -0.093114915211434529, -0.093164697863439005, -0.093214480282531278, -0.093264262468587364, -0.093314044421482792, -0.093363826141093550, -0.093413607627294296, +-0.093463388879961029, -0.093513169898969725, -0.093562950684195054, -0.093612731235513016, -0.093662511552799144, -0.093712291635929437, -0.093762071484778553, -0.093811851099222493, +-0.093861630479136815, -0.093911409624397493, -0.093961188534879211, -0.094010967210457944, -0.094060745651009275, -0.094110523856409167, -0.094160301826532330, -0.094210079561254725, +-0.094259857060451924, -0.094309634323999914, -0.094359411351773378, -0.094409188143648320, -0.094458964699500297, -0.094508741019205297, -0.094558517102638004, -0.094608292949674419, +-0.094658068560190545, -0.094707843934061051, -0.094757619071161953, -0.094807393971368809, -0.094857168634557607, -0.094906943060603058, -0.094956717249381151, -0.095006491200767443, +-0.095056264914637950, -0.095106038390867356, -0.095155811629331663, -0.095205584629906442, -0.095255357392467710, -0.095305129916890136, -0.095354902203049735, -0.095404674250822080, +-0.095454446060083187, -0.095504217630707725, -0.095553988962571723, -0.095603760055550754, -0.095653530909520820, -0.095703301524356618, -0.095753071899934178, -0.095802842036129487, +-0.095852611932817244, -0.095902381589873478, -0.095952151007173761, -0.096001920184594094, -0.096051689122009204, -0.096101457819295077, -0.096151226276327315, -0.096200994492981917, +-0.096250762469133597, -0.096300530204658383, -0.096350297699431819, -0.096400064953329978, -0.096449831966227514, -0.096499598738000486, -0.096549365268524895, -0.096599131557675438, +-0.096648897605328174, -0.096698663411358646, -0.096748428975642911, -0.096798194298055668, -0.096847959378472931, -0.096897724216770301, -0.096947488812823793, -0.096997253166508118, +-0.097047017277699321, -0.097096781146272987, -0.097146544772105131, -0.097196308155070479, -0.097246071295045047, -0.097295834191904434, -0.097345596845524685, -0.097395359255780509, +-0.097445121422547923, -0.097494883345702540, -0.097544645025120391, -0.097594406460676186, -0.097644167652245956, -0.097693928599705757, -0.097743689302930301, -0.097793449761795617, +-0.097843209976177306, -0.097892969945951411, -0.097942729670992656, -0.097992489151177073, -0.098042248386380260, -0.098092007376478274, -0.098141766121345828, -0.098191524620858978, +-0.098241282874893296, -0.098291040883324854, -0.098340798646028377, -0.098390556162879894, -0.098440313433755033, -0.098490070458529824, -0.098539827237078992, -0.098589583769278594, +-0.098639340055004243, -0.098689096094131970, -0.098738851886536527, -0.098788607432093958, -0.098838362730680307, -0.098888117782170298, -0.098937872586440004, -0.098987627143365023, +-0.099037381452821427, -0.099087135514683927, -0.099136889328828595, -0.099186642895131030, -0.099236396213467304, -0.099286149283712141, -0.099335902105741614, -0.099385654679431334, +-0.099435407004657347, -0.099485159081294405, -0.099534910909218566, -0.099584662488305900, -0.099634413818431120, -0.099684164899470323, -0.099733915731299097, -0.099783666313793540, +-0.099833416646828363, -0.099883166730279652, -0.099932916564023019, -0.099982666147934537, -0.100032415481888940, -0.100082164565762330, -0.100131913399430280, -0.100181661982768900, +-0.100231410315652930, -0.100281158397958430, -0.100330906229561020, -0.100380653810336800, -0.100430401140160510, -0.100480148218908200, -0.100529895046455530, -0.100579641622678570, +-0.100629387947452050, -0.100679134020652070, -0.100728879842154700, -0.100778625411834670, -0.100828370729568100, -0.100878115795230590, -0.100927860608698240, -0.100977605169845790, +-0.101027349478549330, -0.101077093534684480, -0.101126837338127360, -0.101176580888752700, -0.101226324186436580, -0.101276067231054660, -0.101325810022483000, -0.101375552560596400, +-0.101425294845270890, -0.101475036876382150, -0.101524778653806270, -0.101574520177418000, -0.101624261447093430, -0.101674002462708630, -0.101723743224138390, -0.101773483731258800, +-0.101823223983945500, -0.101872963982074590, -0.101922703725520810, -0.101972443214160280, -0.102022182447868630, -0.102071921426521980, -0.102121660149995090, -0.102171398618164040, +-0.102221136830904490, -0.102270874788092550, -0.102320612489602970, -0.102370349935311870, -0.102420087125094890, -0.102469824058828120, -0.102519560736386360, -0.102569297157645710, +-0.102619033322482250, -0.102668769230770760, -0.102718504882387360, -0.102768240277207680, -0.102817975415107860, -0.102867710295962640, -0.102917444919648160, -0.102967179286040060, +-0.103016913395014450, -0.103066647246446120, -0.103116380840211170, -0.103166114176185280, -0.103215847254244530, -0.103265580074263730, -0.103315312636118970, -0.103365044939685930, +-0.103414776984840720, -0.103464508771458140, -0.103514240299414280, -0.103563971568584810, -0.103613702578845860, -0.103663433330072220, -0.103713163822139990, -0.103762894054925280, +-0.103812624028302910, -0.103862353742148970, -0.103912083196339160, -0.103961812390749570, -0.104011541325255020, -0.104061269999731600, -0.104110998414055010, -0.104160726568101370, +-0.104210454461745470, -0.104260182094863430, -0.104309909467330940, -0.104359636579024130, -0.104409363429817770, -0.104459090019588000, -0.104508816348210510, -0.104558542415561420, +-0.104608268221515530, -0.104657993765948980, -0.104707719048737880, -0.104757444069757040, -0.104807168828882590, -0.104856893325990230, -0.104906617560956070, -0.104956341533654920, +-0.105006065243962910, -0.105055788691755750, -0.105105511876909560, -0.105155234799299140, -0.105204957458800640, -0.105254679855289730, -0.105304401988642590, -0.105354123858733980, +-0.105403845465440070, -0.105453566808636550, -0.105503287888199540, -0.105553008704003890, -0.105602729255925700, -0.105652449543841150, -0.105702169567625020, -0.105751889327153460, +-0.105801608822302190, -0.105851328052947320, -0.105901047018963700, -0.105950765720227480, -0.106000484156614320, -0.106050202328000400, -0.106099920234260540, -0.106149637875270870, +-0.106199355250907110, -0.106249072361045400, -0.106298789205560570, -0.106348505784328760, -0.106398222097225700, -0.106447938144127520, -0.106497653924909050, -0.106547369439446440, +-0.106597084687615420, -0.106646799669292120, -0.106696514384351390, -0.106746228832669360, -0.106795943014122210, -0.106845656928584750, -0.106895370575933170, -0.106945083956043140, +-0.106994797068790850, -0.107044509914051120, -0.107094222491700130, -0.107143934801613580, -0.107193646843667630, -0.107243358617737110, -0.107293070123698210, -0.107342781361426620, +-0.107392492330798530, -0.107442203031688760, -0.107491913463973490, -0.107541623627528430, -0.107591333522229770, -0.107641043147952320, -0.107690752504572260, -0.107740461591965760, +-0.107790170410007670, -0.107839878958574160, -0.107889587237540940, -0.107939295246784210, -0.107989002986178780, -0.108038710455600860, -0.108088417654926150, -0.108138124584030840, +-0.108187831242789790, -0.108237537631079140, -0.108287243748774660, -0.108336949595752520, -0.108386655171887540, -0.108436360477055950, -0.108486065511133430, -0.108535770273996220, +-0.108585474765519120, -0.108635178985578340, -0.108684882934050060, -0.108734586610809120, -0.108784290015731710, -0.108833993148693590, -0.108883696009570920, -0.108933398598238570, +-0.108983100914572720, -0.109032802958449120, -0.109082504729743970, -0.109132206228332100, -0.109181907454089720, -0.109231608406892570, -0.109281309086616830, -0.109331009493137380, +-0.109380709626330420, -0.109430409486071680, -0.109480109072237350, -0.109529808384702320, -0.109579507423342760, -0.109629206188034430, -0.109678904678653530, -0.109728602895074930, +-0.109778300837174810, -0.109827998504829380, -0.109877695897913520, -0.109927393016303430, -0.109977089859874840, -0.110026786428503970, -0.110076482722065700, -0.110126178740436220, +-0.110175874483491300, -0.110225569951107120, -0.110275265143158580, -0.110324960059521890, -0.110374654700072780, -0.110424349064687480, -0.110474043153240870, -0.110523736965609160, +-0.110573430501668540, -0.110623123761293910, -0.110672816744361450, -0.110722509450746960, -0.110772201880326650, -0.110821894032975390, -0.110871585908569380, -0.110921277506984410, +-0.110970968828096710, -0.111020659871781110, -0.111070350637913890, -0.111120041126370780, -0.111169731337028010, -0.111219421269760480, -0.111269110924444390, -0.111318800300955510, +-0.111368489399170090, -0.111418178218962990, -0.111467866760210450, -0.111517555022788250, -0.111567243006572600, -0.111616930711438400, -0.111666618137261860, -0.111716305283919240, +-0.111765992151285400, -0.111815678739236590, -0.111865365047648570, -0.111915051076397580, -0.111964736825358540, -0.112014422294407640, -0.112064107483420690, -0.112113792392273910, +-0.112163477020842210, -0.112213161369001820, -0.112262845436628520, -0.112312529223598560, -0.112362212729786830, -0.112411895955069560, -0.112461578899322550, -0.112511261562422040, +-0.112560943944242940, -0.112610626044661470, -0.112660307863553450, -0.112709989400795090, -0.112759670656261320, -0.112809351629828370, -0.112859032321372480, -0.112908712730768570, +-0.112958392857892890, -0.113008072702621210, -0.113057752264829790, -0.113107431544393550, -0.113157110541188740, -0.113206789255091160, -0.113256467685977020, -0.113306145833721300, +-0.113355823698200200, -0.113405501279289540, -0.113455178576865570, -0.113504855590803210, -0.113554532320978730, -0.113604208767268340, -0.113653884929546990, -0.113703560807690940, +-0.113753236401575970, -0.113802911711078360, -0.113852586736073030, -0.113902261476436230, -0.113951935932043780, -0.114001610102771930, -0.114051283988495610, -0.114100957589091080, +-0.114150630904434160, -0.114200303934401100, -0.114249976678866840, -0.114299649137707640, -0.114349321310799320, -0.114398993198018130, -0.114448664799239030, -0.114498336114338270, +-0.114548007143191650, -0.114597677885675460, -0.114647348341664640, -0.114697018511035450, -0.114746688393664140, -0.114796357989425680, -0.114846027298196330, -0.114895696319851900, +-0.114945365054268680, -0.114995033501321610, -0.115044701660886940, -0.115094369532840520, -0.115144037117058630, -0.115193704413416200, -0.115243371421789500, -0.115293038142054380, +-0.115342704574087100, -0.115392370717762640, -0.115442036572957220, -0.115491702139546720, -0.115541367417407420, -0.115591032406414250, -0.115640697106443490, -0.115690361517371440, +-0.115740025639073050, -0.115789689471424580, -0.115839353014301900, -0.115889016267581270, -0.115938679231137670, -0.115988341904847360, -0.116038004288586200, -0.116087666382230480, +-0.116137328185655130, -0.116186989698736480, -0.116236650921350340, -0.116286311853373030, -0.116335972494679490, -0.116385632845146010, -0.116435292904648460, -0.116484952673063120, +-0.116534612150264960, -0.116584271336130270, -0.116633930230535320, -0.116683588833355130, -0.116733247144465950, -0.116782905163743660, -0.116832562891064560, -0.116882220326303590, +-0.116931877469337090, -0.116981534320040880, -0.117031190878291280, -0.117080847143963260, -0.117130503116933130, -0.117180158797076740, -0.117229814184270390, -0.117279469278389060, +-0.117329124079309070, -0.117378778586906260, -0.117428432801056940, -0.117478086721636110, -0.117527740348520050, -0.117577393681584650, -0.117627046720706200, -0.117676699465759700, +-0.117726351916621450, -0.117776004073167750, -0.117825655935273610, -0.117875307502815330, -0.117924958775668780, -0.117974609753710270, -0.118024260436814800, -0.118073910824858670, +-0.118123560917717770, -0.118173210715268410, -0.118222860217385580, -0.118272509423945600, -0.118322158334824350, -0.118371806949898140, -0.118421455269041960, -0.118471103292132160, +-0.118520751019044610, -0.118570398449655600, -0.118620045583840160, -0.118669692421474610, -0.118719338962435280, -0.118768985206597150, -0.118818631153836550, -0.118868276804029380, +-0.118917922157051960, -0.118967567212779290, -0.119017211971087710, -0.119066856431853090, -0.119116500594951780, -0.119166144460258780, -0.119215788027650400, -0.119265431297002570, +-0.119315074268191590, -0.119364716941092490, -0.119414359315581590, -0.119464001391534800, -0.119513643168828440, -0.119563284647337540, -0.119612925826938430, -0.119662566707507440, +-0.119712207288919580, -0.119761847571051220, -0.119811487553778240, -0.119861127236976980, -0.119910766620522450, -0.119960405704291020, -0.120010044488158570, -0.120059682972001450, +-0.120109321155694670, -0.120158959039114610, -0.120208596622137130, -0.120258233904638610, -0.120307870886494070, -0.120357507567579850, -0.120407143947771860, -0.120456780026946440, +-0.120506415804978630, -0.120556051281744790, -0.120605686457120830, -0.120655321330983080, -0.120704955903206600, -0.120754590173667710, -0.120804224142242800, -0.120853857808806880, +-0.120903491173236330, -0.120953124235407040, -0.121002756995195390, -0.121052389452476390, -0.121102021607126420, -0.121151653459021420, -0.121201285008037700, -0.121250916254050340, +-0.121300547196935680, -0.121350177836569660, -0.121399808172828640, -0.121449438205587650, -0.121499067934723070, -0.121548697360110810, -0.121598326481627260, -0.121647955299147440, +-0.121697583812547750, -0.121747212021704530, -0.121796839926492840, -0.121846467526789060, -0.121896094822469090, -0.121945721813409350, -0.121995348499484850, -0.122044974880571980, +-0.122094600956546660, -0.122144226727285300, -0.122193852192662920, -0.122243477352555920, -0.122293102206840210, -0.122342726755392190, -0.122392350998086930, -0.122441974934800770, +-0.122491598565409680, -0.122541221889790040, -0.122590844907816910, -0.122640467619366660, -0.122690090024315680, -0.122739712122539040, -0.122789333913913110, -0.122838955398313850, +-0.122888576575617640, -0.122938197445699550, -0.122987818008435970, -0.123037438263702840, -0.123087058211376550, -0.123136677851332190, -0.123186297183446130, -0.123235916207594320, +-0.123285534923653170, -0.123335153331497730, -0.123384771431004420, -0.123434389222049160, -0.123484006704508390, -0.123533623878257160, -0.123583240743171850, -0.123632857299128460, +-0.123682473546003370, -0.123732089483671630, -0.123781705112009700, -0.123831320430893930, -0.123880935440199420, -0.123930550139802560, -0.123980164529579340, -0.124029778609406140, +-0.124079392379158060, -0.124129005838711490, -0.124178618987942410, -0.124228231826727240, -0.124277844354941030, -0.124327456572460210, -0.124377068479160760, -0.124426680074919070, +-0.124476291359610230, -0.124525902333110690, -0.124575512995296820, -0.124625123346043710, -0.124674733385227820, -0.124724343112725080, -0.124773952528411920, -0.124823561632163450, +-0.124873170423856070, -0.124922778903365760, -0.124972387070568940, -0.125021994925340720, -0.125071602467557520, -0.125121209697095310, -0.125170816613830500, -0.125220423217638240, +-0.125270029508394890, -0.125319635485976490, -0.125369241150259410, -0.125418846501118810, -0.125468451538431110, -0.125518056262072240, -0.125567660671918710, -0.125617264767845570, +-0.125666868549729280, -0.125716472017446230, -0.125766075170871570, -0.125815678009881750, -0.125865280534352700, -0.125914882744160910, -0.125964484639181470, -0.126014086219290810, +-0.126063687484364940, -0.126113288434280300, -0.126162889068911990, -0.126212489388136450, -0.126262089391829670, -0.126311689079868140, -0.126361288452126940, -0.126410887508482530, +-0.126460486248810870, -0.126510084672988470, -0.126559682780890390, -0.126609280572393120, -0.126658878047372640, -0.126708475205705410, -0.126758072047266550, -0.126807668571932510, +-0.126857264779579730, -0.126906860670083360, -0.126956456243319830, -0.127006051499165160, -0.127055646437495810, -0.127105241058186910, -0.127154835361114880, -0.127204429346155780, +-0.127254023013186060, -0.127303616362080820, -0.127353209392716550, -0.127402802104969240, -0.127452394498715400, -0.127501986573830110, -0.127551578330189850, -0.127601169767671080, +-0.127650760886148960, -0.127700351685499920, -0.127749942165600040, -0.127799532326325710, -0.127849122167552120, -0.127898711689155730, -0.127948300891012560, -0.127997889772999060, +-0.128047478334990390, -0.128097066576863040, -0.128146654498493050, -0.128196242099756830, -0.128245829380529560, -0.128295416340687750, -0.128345002980107370, -0.128394589298664930, +-0.128444175296235590, -0.128493760972695800, -0.128543346327921610, -0.128592931361789480, -0.128642516074174600, -0.128692100464953410, -0.128741684534002420, -0.128791268281196800, +-0.128840851706412990, -0.128890434809527050, -0.128940017590415460, -0.128989600048953410, -0.129039182185017340, -0.129088763998483290, -0.129138345489227810, -0.129187926657126000, +-0.129237507502054400, -0.129287088023889000, -0.129336668222506330, -0.129386248097781570, -0.129435827649591190, -0.129485406877811210, -0.129534985782318170, -0.129584564362987240, +-0.129634142619694890, -0.129683720552317170, -0.129733298160730590, -0.129782875444810320, -0.129832452404432890, -0.129882029039474740, -0.129931605349811100, -0.129981181335318440, +-0.130030756995872830, -0.130080332331350750, -0.130129907341627410, -0.130179482026579310, -0.130229056386082480, -0.130278630420013470, -0.130328204128247440, -0.130377777510660900, +-0.130427350567129920, -0.130476923297530990, -0.130526495701739330, -0.130576067779631410, -0.130625639531083780, -0.130675210955971590, -0.130724782054171400, -0.130774352825559240, +-0.130823923270011630, -0.130873493387403780, -0.130923063177612210, -0.130972632640512980, -0.131022201775982590, -0.131071770583896270, -0.131121339064130510, -0.131170907216561410, +-0.131220475041065490, -0.131270042537517920, -0.131319609705795260, -0.131369176545773570, -0.131418743057329400, -0.131468309240337890, -0.131517875094675660, -0.131567440620218690, +-0.131617005816843600, -0.131666570684425530, -0.131716135222841040, -0.131765699431966670, -0.131815263311677590, -0.131864826861850360, -0.131914390082361050, -0.131963952973086220, +-0.132013515533901060, -0.132063077764682120, -0.132112639665305480, -0.132162201235647670, -0.132211762475583940, -0.132261323384990780, -0.132310883963744320, -0.132360444211721110, +-0.132410004128796330, -0.132459563714846550, -0.132509122969748290, -0.132558681893376770, -0.132608240485608570, -0.132657798746319750, -0.132707356675386440, -0.132756914272685180, +-0.132806471538091220, -0.132856028471481040, -0.132905585072731260, -0.132955141341717040, -0.133004697278315010, -0.133054252882401220, -0.133103808153852230, -0.133153363092543280, +-0.133202917698350940, -0.133252471971151280, -0.133302025910820880, -0.133351579517235000, -0.133401132790270160, -0.133450685729802480, -0.133500238335708540, -0.133549790607863570, +-0.133599342546144110, -0.133648894150426720, -0.133698445420586680, -0.133747996356500500, -0.133797546958044360, -0.133847097225094770, -0.133896647157527000, -0.133946196755217630, +-0.133995746018042760, -0.134045294945878940, -0.134094843538601460, -0.134144391796086890, -0.134193939718211310, -0.134243487304851330, -0.134293034555882210, -0.134342581471180500, +-0.134392128050622310, -0.134441674294084270, -0.134491220201441580, -0.134540765772570870, -0.134590311007348220, -0.134639855905650250, -0.134689400467352170, -0.134738944692330610, +-0.134788488580462130, -0.134838032131621990, -0.134887575345686770, -0.134937118222532600, -0.134986660762036080, -0.135036202964072480, -0.135085744828518340, -0.135135286355249880, +-0.135184827544143630, -0.135234368395074860, -0.135283908907920160, -0.135333449082555710, -0.135382988918858080, -0.135432528416702530, -0.135482067575965650, -0.135531606396524030, +-0.135581144878252980, -0.135630683021029070, -0.135680220824728440, -0.135729758289227260, -0.135779295414402120, -0.135828832200128310, -0.135878368646282420, -0.135927904752741050, +-0.135977440519379460, -0.136026975946074300, -0.136076511032701660, -0.136126045779138200, -0.136175580185259220, -0.136225114250941250, -0.136274647976060510, -0.136324181360493570, +-0.136373714404115750, -0.136423247106803650, -0.136472779468433420, -0.136522311488881690, -0.136571843168023730, -0.136621374505736190, -0.136670905501895620, -0.136720436156377360, +-0.136769966469058010, -0.136819496439813750, -0.136869026068521190, -0.136918555355055620, -0.136968084299293660, -0.137017612901111500, -0.137067141160385740, -0.137116669076991690, +-0.137166196650805950, -0.137215723881704720, -0.137265250769564640, -0.137314777314260980, -0.137364303515670390, -0.137413829373669030, -0.137463354888133550, -0.137512880058939220, +-0.137562404885962690, -0.137611929369080180, -0.137661453508168250, -0.137710977303102280, -0.137760500753758840, -0.137810023860014590, -0.137859546621744850, -0.137909069038826240, +-0.137958591111134980, -0.138008112838547640, -0.138057634220939610, -0.138107155258187480, -0.138156675950167480, -0.138206196296756210, -0.138255716297829010, -0.138305235953262520, +-0.138354755262932950, -0.138404274226716920, -0.138453792844489780, -0.138503311116128150, -0.138552829041508670, -0.138602346620506690, -0.138651863852998850, -0.138701380738861350, +-0.138750897277970820, -0.138800413470202640, -0.138849929315433380, -0.138899444813539330, -0.138948959964397100, -0.138998474767882020, -0.139047989223870770, -0.139097503332239550, +-0.139147017092865010, -0.139196530505622470, -0.139246043570388610, -0.139295556287039630, -0.139345068655452240, -0.139394580675501700, -0.139444092347064730, -0.139493603670017510, +-0.139543114644236720, -0.139592625269597730, -0.139642135545977150, -0.139691645473251690, -0.139741155051296670, -0.139790664279988760, -0.139840173159204190, -0.139889681688819630, +-0.139939189868710400, -0.139988697698753220, -0.140038205178824320, -0.140087712308800290, -0.140137219088556590, -0.140186725517969820, -0.140236231596916230, -0.140285737325272520, +-0.140335242702914000, -0.140384747729717400, -0.140434252405558930, -0.140483756730315270, -0.140533260703861770, -0.140582764326075110, -0.140632267596831530, -0.140681770516007750, +-0.140731273083479070, -0.140780775299122250, -0.140830277162813900, -0.140879778674429440, -0.140929279833845510, -0.140978780640938380, -0.141028281095584770, -0.141077781197659980, +-0.141127280947040770, -0.141176780343603340, -0.141226279387224400, -0.141275778077779330, -0.141325276415144810, -0.141374774399197070, -0.141424272029812860, -0.141473769306867560, +-0.141523266230237780, -0.141572762799800300, -0.141622259015430490, -0.141671754877005010, -0.141721250384400140, -0.141770745537492610, -0.141820240336157750, -0.141869734780272320, +-0.141919228869712530, -0.141968722604355110, -0.142018215984075440, -0.142067709008750240, -0.142117201678255760, -0.142166693992468700, -0.142216185951264510, -0.142265677554519830, +-0.142315168802110950, -0.142364659693914600, -0.142414150229806140, -0.142463640409662310, -0.142513130233359400, -0.142562619700774080, -0.142612108811781800, -0.142661597566259210, +-0.142711085964083080, -0.142760574005128820, -0.142810061689273100, -0.142859549016392220, -0.142909035986362930, -0.142958522599060610, -0.143008008854361960, -0.143057494752143300, +-0.143106980292281360, -0.143156465474651500, -0.143205950299130500, -0.143255434765594600, -0.143304918873920580, -0.143354402623983800, -0.143403886015661040, -0.143453369048828550, +-0.143502851723363080, -0.143552334039140030, -0.143601815996036160, -0.143651297593927750, -0.143700778832691530, -0.143750259712202900, -0.143799740232338660, -0.143849220392975490, +-0.143898700193988820, -0.143948179635255410, -0.143997658716651540, -0.144047137438054000, -0.144096615799338130, -0.144146093800380760, -0.144195571441058130, -0.144245048721247020, +-0.144294525640822850, -0.144344002199662370, -0.144393478397641880, -0.144442954234638130, -0.144492429710526560, -0.144541904825183890, -0.144591379578486940, -0.144640853970311070, +-0.144690328000533080, -0.144739801669029280, -0.144789274975676400, -0.144838747920349900, -0.144888220502926520, -0.144937692723282580, -0.144987164581294880, -0.145036636076838810, +-0.145086107209791150, -0.145135577980028210, -0.145185048387426800, -0.145234518431862300, -0.145283988113211500, -0.145333457431350730, -0.145382926386156800, -0.145432394977505070, +-0.145481863205272370, -0.145531331069335000, -0.145580798569569740, -0.145630265705852050, -0.145679732478058710, -0.145729198886066470, -0.145778664929750780, -0.145828130608988440, +-0.145877595923655760, -0.145927060873629550, -0.145976525458785260, -0.146025989678999630, -0.146075453534149020, -0.146124917024110230, -0.146174380148758720, -0.146223842907971250, +-0.146273305301624160, -0.146322767329594230, -0.146372228991756980, -0.146421690287989150, -0.146471151218167530, -0.146520611782167580, -0.146570071979866130, -0.146619531811139460, +-0.146668991275864000, -0.146718450373916480, -0.146767909105172400, -0.146817367469508550, -0.146866825466801710, -0.146916283096927360, -0.146965740359762310, -0.147015197255182940, +-0.147064653783065990, -0.147114109943286970, -0.147163565735722670, -0.147213021160249450, -0.147262476216744130, -0.147311930905082180, -0.147361385225140390, -0.147410839176795150, +-0.147460292759923230, -0.147509745974400170, -0.147559198820102740, -0.147608651296907730, -0.147658103404690650, -0.147707555143328340, -0.147757006512697130, -0.147806457512673850, +-0.147855908143133980, -0.147905358403954330, -0.147954808295011290, -0.148004257816181680, -0.148053706967340960, -0.148103155748365990, -0.148152604159133140, -0.148202052199519210, +-0.148251499869399730, -0.148300947168651470, -0.148350394097150840, -0.148399840654774680, -0.148449286841398490, -0.148498732656899060, -0.148548178101152810, -0.148597623174036550, +-0.148647067875425810, -0.148696512205197360, -0.148745956163228110, -0.148795399749393510, -0.148844842963570420, -0.148894285805635210, -0.148943728275464730, -0.148993170372934500, +-0.149042612097921330, -0.149092053450301630, -0.149141494429952250, -0.149190935036748680, -0.149240375270567800, -0.149289815131285950, -0.149339254618780000, -0.149388693732925510, +-0.149438132473599240, -0.149487570840678120, -0.149537008834037620, -0.149586446453554590, -0.149635883699105440, -0.149685320570566580, -0.149734757067814860, -0.149784193190725830, +-0.149833628939176290, -0.149883064313043130, -0.149932499312201870, -0.149981933936529370, -0.150031368185902010, -0.150080802060196690, -0.150130235559288920, -0.150179668683055570, +-0.150229101431373020, -0.150278533804118180, -0.150327965801166560, -0.150377397422395030, -0.150426828667680010, -0.150476259536898360, -0.150525690029925610, -0.150575120146638620, +-0.150624549886914290, -0.150673979250628140, -0.150723408237657060, -0.150772836847877430, -0.150822265081166170, -0.150871692937398800, -0.150921120416452200, -0.150970547518202800, +-0.151019974242527470, -0.151069400589301740, -0.151118826558402530, -0.151168252149706280, -0.151217677363089800, -0.151267102198428700, -0.151316526655599860, -0.151365950734479670, +-0.151415374434945070, -0.151464797756871580, -0.151514220700136090, -0.151563643264615080, -0.151613065450185380, -0.151662487256722570, -0.151711908684103560, -0.151761329732205210, +-0.151810750400903080, -0.151860170690074100, -0.151909590599594690, -0.151959010129341710, -0.152008429279190810, -0.152057848049018810, -0.152107266438702200, -0.152156684448117860, +-0.152206102077141360, -0.152255519325649620, -0.152304936193519090, -0.152354352680626640, -0.152403768786847860, -0.152453184512059690, -0.152502599856138980, -0.152552014818961330, +-0.152601429400403640, -0.152650843600342370, -0.152700257418654450, -0.152749670855215430, -0.152799083909902270, -0.152848496582591360, -0.152897908873159650, -0.152947320781482740, +-0.152996732307437540, -0.153046143450900480, -0.153095554211748530, -0.153144964589857240, -0.153194374585103540, -0.153243784197363900, -0.153293193426515260, -0.153342602272433180, +-0.153392010734994590, -0.153441418814075970, -0.153490826509554260, -0.153540233821305020, -0.153589640749205230, -0.153639047293131740, -0.153688453452960230, -0.153737859228567560, +-0.153787264619830250, -0.153836669626625210, -0.153886074248828050, -0.153935478486315720, -0.153984882338964710, -0.154034285806651900, -0.154083688889252970, -0.154133091586644790, +-0.154182493898703890, -0.154231895825307190, -0.154281297366330340, -0.154330698521650210, -0.154380099291143350, -0.154429499674686670, -0.154478899672155810, -0.154528299283427710, +-0.154577698508378850, -0.154627097346886180, -0.154676495798825340, -0.154725893864073260, -0.154775291542506880, -0.154824688834001830, -0.154874085738435060, -0.154923482255683060, +-0.154972878385622820, -0.155022274128129940, -0.155071669483081350, -0.155121064450353620, -0.155170459029823630, -0.155219853221367080, -0.155269247024860890, -0.155318640440181590, +-0.155368033467206120, -0.155417426105810140, -0.155466818355870590, -0.155516210217264420, -0.155565601689867300, -0.155614992773556170, -0.155664383468207550, -0.155713773773698410, +-0.155763163689904420, -0.155812553216702510, -0.155861942353969190, -0.155911331101581480, -0.155960719459415000, -0.156010107427346720, -0.156059495005253180, -0.156108882193011330, +-0.156158268990496840, -0.156207655397586690, -0.156257041414157390, -0.156306427040085900, -0.156355812275247950, -0.156405197119520440, -0.156454581572779940, -0.156503965634903430, +-0.156553349305766560, -0.156602732585246350, -0.156652115473219690, -0.156701497969562340, -0.156750880074151250, -0.156800261786862930, -0.156849643107574430, -0.156899024036161380, +-0.156948404572500750, -0.156997784716469110, -0.157047164467943450, -0.157096543826799440, -0.157145922792914060, -0.157195301366163890, -0.157244679546425900, -0.157294057333575790, +-0.157343434727490520, -0.157392811728046670, -0.157442188335121220, -0.157491564548589870, -0.157540940368329580, -0.157590315794216980, -0.157639690826129000, -0.157689065463941370, +-0.157738439707531070, -0.157787813556775100, -0.157837187011549170, -0.157886560071730270, -0.157935932737194970, -0.157985305007820290, -0.158034676883481880, -0.158084048364056820, +-0.158133419449421610, -0.158182790139453300, -0.158232160434027550, -0.158281530333021420, -0.158330899836311460, -0.158380268943774720, -0.158429637655286840, -0.158479005970724840, +-0.158528373889965800, -0.158577741412885390, -0.158627108539360600, -0.158676475269268060, -0.158725841602484760, -0.158775207538886440, -0.158824573078350070, -0.158873938220752270, +-0.158923302965970070, -0.158972667313879180, -0.159022031264356630, -0.159071394817279000, -0.159120757972523310, -0.159170120729965280, -0.159219483089481970, -0.159268845050949930, +-0.159318206614246230, -0.159367567779246570, -0.159416928545827980, -0.159466288913867080, -0.159515648883240910, -0.159565008453825150, -0.159614367625496880, -0.159663726398133140, +-0.159713084771609640, -0.159762442745803420, -0.159811800320591110, -0.159861157495849730, -0.159910514271455030, -0.159959870647284040, -0.160009226623213350, -0.160058582199120060, +-0.160107937374879860, -0.160157292150369810, -0.160206646525466540, -0.160256000500047100, -0.160305354073987190, -0.160354707247163940, -0.160404060019454310, -0.160453412390734130, +-0.160502764360880400, -0.160552115929769780, -0.160601467097278850, -0.160650817863284700, -0.160700168227663060, -0.160749518190291010, -0.160798867751045600, -0.160848216909802580, +-0.160897565666439010, -0.160946914020831560, -0.160996261972857210, -0.161045609522391800, -0.161094956669312370, -0.161144303413495530, -0.161193649754818370, -0.161242995693156670, +-0.161292341228387450, -0.161341686360387400, -0.161391031089033580, -0.161440375414201730, -0.161489719335768940, -0.161539062853612280, -0.161588405967607540, -0.161637748677631780, +-0.161687090983561650, -0.161736432885274230, -0.161785774382645300, -0.161835115475551930, -0.161884456163870760, -0.161933796447478880, -0.161983136326252110, -0.162032475800067470, +-0.162081814868801630, -0.162131153532331710, -0.162180491790533450, -0.162229829643284000, -0.162279167090459950, -0.162328504131938420, -0.162377840767595180, -0.162427176997307350, +-0.162476512820951570, -0.162525848238404960, -0.162575183249543290, -0.162624517854243640, -0.162673852052383160, -0.162723185843837600, -0.162772519228484100, -0.162821852206199270, +-0.162871184776860270, -0.162920516940342850, -0.162969848696524140, -0.163019180045280820, -0.163068510986489970, -0.163117841520027420, -0.163167171645770270, -0.163216501363595200, +-0.163265830673379300, -0.163315159574998370, -0.163364488068329570, -0.163413816153249960, -0.163463143829635390, -0.163512471097362940, -0.163561797956309350, -0.163611124406351230, +-0.163660450447365740, -0.163709776079228710, -0.163759101301817230, -0.163808426115008430, -0.163857750518678120, -0.163907074512703450, -0.163956398096961080, -0.164005721271328150, +-0.164055044035680500, -0.164104366389895230, -0.164153688333849020, -0.164203009867419060, -0.164252330990481120, -0.164301651702912360, -0.164350972004589480, -0.164400291895389600, +-0.164449611375188540, -0.164498930443863460, -0.164548249101291480, -0.164597567347348460, -0.164646885181911510, -0.164696202604857370, -0.164745519616063120, -0.164794836215404670, +-0.164844152402759130, -0.164893468178003180, -0.164942783541014020, -0.164992098491667460, -0.165041413029840630, -0.165090727155410290, -0.165140040868253570, -0.165189354168246320, +-0.165238667055265660, -0.165287979529188330, -0.165337291589891520, -0.165386603237251020, -0.165435914471144030, -0.165485225291447240, -0.165534535698037830, -0.165583845690791630, +-0.165633155269585830, -0.165682464434297570, -0.165731773184802730, -0.165781081520978420, -0.165830389442701450, -0.165879696949848910, -0.165929004042296710, -0.165978310719922000, +-0.166027616982601520, -0.166076922830212410, -0.166126228262630570, -0.166175533279733170, -0.166224837881396910, -0.166274142067499020, -0.166323445837915310, -0.166372749192523010, +-0.166422052131199260, -0.166471354653819960, -0.166520656760262260, -0.166569958450402900, -0.166619259724119120, -0.166668560581286730, -0.166717861021782930, -0.166767161045484500, +-0.166816460652268600, -0.166865759842011100, -0.166915058614589190, -0.166964356969879660, -0.167013654907759660, -0.167062952428105090, -0.167112249530793150, -0.167161546215700560, +-0.167210842482704570, -0.167260138331681020, -0.167309433762507120, -0.167358728775059670, -0.167408023369215790, -0.167457317544851440, -0.167506611301843800, -0.167555904640070060, +-0.167605197559406120, -0.167654490059729180, -0.167703782140916020, -0.167753073802843850, -0.167802365045388540, -0.167851655868427350, -0.167900946271836990, -0.167950236255494710, +-0.167999525819276410, -0.168048814963059290, -0.168098103686720120, -0.168147391990136150, -0.168196679873183240, -0.168245967335738660, -0.168295254377679140, -0.168344540998881910, +-0.168393827199222910, -0.168443112978579330, -0.168492398336828000, -0.168541683273846080, -0.168590967789509520, -0.168640251883695550, -0.168689535556281380, -0.168738818807142920, +-0.168788101636157430, -0.168837384043201700, -0.168886666028152920, -0.168935947590887060, -0.168985228731281300, -0.169034509449212500, -0.169083789744557840, -0.169133069617193290, +-0.169182349066996060, -0.169231628093842960, -0.169280906697611230, -0.169330184878176780, -0.169379462635416870, -0.169428739969208740, -0.169478016879428340, -0.169527293365952870, +-0.169576569428659200, -0.169625845067424510, -0.169675120282124810, -0.169724395072637290, -0.169773669438838760, -0.169822943380606520, -0.169872216897816480, -0.169921489990345900, +-0.169970762658071570, -0.170020034900870810, -0.170069306718619500, -0.170118578111194930, -0.170167849078473900, -0.170217119620333700, -0.170266389736650260, -0.170315659427300870, +-0.170364928692162300, -0.170414197531111870, -0.170463465944025480, -0.170512733930780450, -0.170562001491254000, -0.170611268625322140, -0.170660535332862070, -0.170709801613750680, +-0.170759067467865230, -0.170808332895081680, -0.170857597895277270, -0.170906862468328900, -0.170956126614113770, -0.171005390332507920, -0.171054653623388590, -0.171103916486632620, +-0.171153178922117290, -0.171202440929718590, -0.171251702509313790, -0.171300963660779710, -0.171350224383993670, -0.171399484678831650, -0.171448744545170890, -0.171498003982888280, +-0.171547262991861100, -0.171596521571965310, -0.171645779723078230, -0.171695037445077160, -0.171744294737838030, -0.171793551601238160, -0.171842808035154420, -0.171892064039464110, +-0.171941319614043190, -0.171990574758768970, -0.172039829473518310, -0.172089083758168530, -0.172138337612595590, -0.172187591036676800, -0.172236844030289050, -0.172286096593309620, +-0.172335348725614510, -0.172384600427081040, -0.172433851697586490, -0.172483102537006850, -0.172532352945219490, -0.172581602922101260, -0.172630852467529430, -0.172680101581380030, +-0.172729350263530400, -0.172778598513857380, -0.172827846332238300, -0.172877093718549170, -0.172926340672667290, -0.172975587194469590, -0.173024833283833330, -0.173074078940634590, +-0.173123324164750620, -0.173172568956058340, -0.173221813314435090, -0.173271057239756860, -0.173320300731900970, -0.173369543790744350, -0.173418786416164320, -0.173468028608036840, +-0.173517270366239320, -0.173566511690649070, -0.173615752581142090, -0.173664993037595750, -0.173714233059886900, -0.173763472647892910, -0.173812711801489800, -0.173861950520554920, +-0.173911188804965170, -0.173960426654597880, -0.174009664069329080, -0.174058901049036100, -0.174108137593595890, -0.174157373702885780, -0.174206609376781780, -0.174255844615161280, +-0.174305079417901160, -0.174354313784878760, -0.174403547715970160, -0.174452781211052680, -0.174502014270003250, -0.174551246892699240, -0.174600479079016660, -0.174649710828832880, +-0.174698942142025250, -0.174748173018469840, -0.174797403458043980, -0.174846633460624650, -0.174895863026089140, -0.174945092154313560, -0.174994320845175220, -0.175043549098551100, +-0.175092776914318540, -0.175142004292353600, -0.175191231232533630, -0.175240457734735620, -0.175289683798836890, -0.175338909424713500, -0.175388134612242840, -0.175437359361302280, +-0.175486583671767890, -0.175535807543517050, -0.175585030976426660, -0.175634253970374160, -0.175683476525235580, -0.175732698640888310, -0.175781920317209290, -0.175831141554075920, +-0.175880362351364230, -0.175929582708951650, -0.175978802626715110, -0.176028022104532000, -0.176077241142278410, -0.176126459739831710, -0.176175677897068870, -0.176224895613867260, +-0.176274112890102970, -0.176323329725653400, -0.176372546120395520, -0.176421762074206710, -0.176470977586963030, -0.176520192658541940, -0.176569407288820780, -0.176618621477675680, +-0.176667835224984030, -0.176717048530622780, -0.176766261394469350, -0.176815473816399840, -0.176864685796291640, -0.176913897334021710, -0.176963108429467500, -0.177012319082505060, +-0.177061529293011830, -0.177110739060864770, -0.177159948385941320, -0.177209157268117530, -0.177258365707270880, -0.177307573703278740, -0.177356781256017230, -0.177405988365363750, +-0.177455195031195310, -0.177504401253388870, -0.177553607031821880, -0.177602812366370460, -0.177652017256911960, -0.177701221703323890, -0.177750425705482330, -0.177799629263264670, +-0.177848832376547970, -0.177898035045209620, -0.177947237269125730, -0.177996439048173780, -0.178045640382230700, -0.178094841271173950, -0.178144041714879690, -0.178193241713225310, +-0.178242441266087820, -0.178291640373344690, -0.178340839034872000, -0.178390037250547220, -0.178439235020247780, -0.178488432343849810, -0.178537629221230760, -0.178586825652267630, +-0.178636021636837890, -0.178685217174817670, -0.178734412266084390, -0.178783606910515090, -0.178832801107987190, -0.178881994858376860, -0.178931188161561530, -0.178980381017418260, +-0.179029573425824460, -0.179078765386656290, -0.179127956899791190, -0.179177147965106230, -0.179226338582478800, -0.179275528751785120, -0.179324718472902600, -0.179373907745708300, +-0.179423096570079650, -0.179472284945892820, -0.179521472873025280, -0.179570660351354520, -0.179619847380756650, -0.179669033961109170, -0.179718220092289080, -0.179767405774173910, +-0.179816591006639770, -0.179865775789564140, -0.179914960122824100, -0.179964144006297090, -0.180013327439859290, -0.180062510423388140, -0.180111692956760740, -0.180160875039854530, +-0.180210056672545720, -0.180259237854711730, -0.180308418586230120, -0.180357598866977000, -0.180406778696829890, -0.180455958075665860, -0.180505137003362350, -0.180554315479795560, +-0.180603493504842980, -0.180652671078381650, -0.180701848200289120, -0.180751024870441510, -0.180800201088716330, -0.180849376854990640, -0.180898552169141970, -0.180947727031046470, +-0.180996901440581640, -0.181046075397624600, -0.181095248902052780, -0.181144421953742390, -0.181193594552570950, -0.181242766698415550, -0.181291938391153620, -0.181341109630661440, +-0.181390280416816490, -0.181439450749496270, -0.181488620628576990, -0.181537790053936170, -0.181586959025450860, -0.181636127542998570, -0.181685295606455550, -0.181734463215699280, +-0.181783630370606850, -0.181832797071055790, -0.181881963316922300, -0.181931129108083900, -0.181980294444417680, -0.182029459325801170, -0.182078623752110540, -0.182127787723223380, +-0.182176951239016750, -0.182226114299368160, -0.182275276904153880, -0.182324439053251380, -0.182373600746537800, -0.182422761983890620, -0.182471922765186150, -0.182521083090301850, +-0.182570242959115250, -0.182619402371502650, -0.182668561327341520, -0.182717719826509000, -0.182766877868882600, -0.182816035454338580, -0.182865192582754470, -0.182914349254007370, +-0.182963505467974850, -0.183012661224533140, -0.183061816523559740, -0.183110971364931820, -0.183160125748526910, -0.183209279674221260, -0.183258433141892390, -0.183307586151417870, +-0.183356738702673970, -0.183405890795538210, -0.183455042429887720, -0.183504193605600080, -0.183553344322551490, -0.183602494580619560, -0.183651644379681400, -0.183700793719614540, +-0.183749942600295290, -0.183799091021601160, -0.183848238983409300, -0.183897386485597310, -0.183946533528041380, -0.183995680110619150, -0.184044826233207700, -0.184093971895684600, +-0.184143117097926160, -0.184192261839809940, -0.184241406121213040, -0.184290549942013080, -0.184339693302086300, -0.184388836201310270, -0.184437978639562600, -0.184487120616719570, +-0.184536262132658700, -0.184585403187257190, -0.184634543780392620, -0.184683683911941260, -0.184732823581780670, -0.184781962789788030, -0.184831101535840920, -0.184880239819815610, +-0.184929377641589700, -0.184978515001040340, -0.185027651898045150, -0.185076788332480400, -0.185125924304223670, -0.185175059813152100, -0.185224194859143350, -0.185273329442073670, +-0.185322463561820670, -0.185371597218261520, -0.185420730411273800, -0.185469863140733800, -0.185518995406519170, -0.185568127208507460, -0.185617258546575010, -0.185666389420599430, +-0.185715519830457860, -0.185764649776027940, -0.185813779257185950, -0.185862908273809500, -0.185912036825775780, -0.185961164912962440, -0.186010292535245730, -0.186059419692503280, +-0.186108546384612270, -0.186157672611450360, -0.186206798372893810, -0.186255923668820270, -0.186305048499107370, -0.186354172863631400, -0.186403296762269990, -0.186452420194900350, +-0.186501543161400110, -0.186550665661645550, -0.186599787695514360, -0.186648909262883660, -0.186698030363631140, -0.186747150997633120, -0.186796271164767210, -0.186845390864910620, +-0.186894510097941000, -0.186943628863734670, -0.186992747162169240, -0.187041864993121980, -0.187090982356470450, -0.187140099252091070, -0.187189215679861410, -0.187238331639658750, +-0.187287447131360670, -0.187336562154843540, -0.187385676709984990, -0.187434790796662700, -0.187483904414752990, -0.187533017564133540, -0.187582130244681510, -0.187631242456274630, +-0.187680354198789170, -0.187729465472102870, -0.187778576276092870, -0.187827686610636870, -0.187876796475611230, -0.187925905870893580, -0.187975014796361200, -0.188024123251891690, +-0.188073231237361440, -0.188122338752648110, -0.188171445797628960, -0.188220552372181600, -0.188269658476182430, -0.188318764109509120, -0.188367869272038880, -0.188416973963649430, +-0.188466078184217100, -0.188515181933619570, -0.188564285211734520, -0.188613388018438330, -0.188662490353608660, -0.188711592217122780, -0.188760693608858330, -0.188809794528691730, +-0.188858894976500660, -0.188907994952162320, -0.188957094455554450, -0.189006193486553400, -0.189055292045036850, -0.189104390130882090, -0.189153487743966790, -0.189202584884167330, +-0.189251681551361410, -0.189300777745426720, -0.189349873466239630, -0.189398968713677900, -0.189448063487618720, -0.189497157787939820, -0.189546251614517600, -0.189595344967229740, +-0.189644437845953530, -0.189693530250566650, -0.189742622180945510, -0.189791713636967810, -0.189840804618510830, -0.189889895125452260, -0.189938985157668550, -0.189988074715037340, +-0.190037163797435990, -0.190086252404742110, -0.190135340536832200, -0.190184428193583940, -0.190233515374874600, -0.190282602080581900, -0.190331688310582280, -0.190380774064753430, +-0.190429859342973070, -0.190478944145117620, -0.190528028471064840, -0.190577112320691970, -0.190626195693876760, -0.190675278590495630, -0.190724361010426280, -0.190773442953546060, +-0.190822524419732630, -0.190871605408862500, -0.190920685920813320, -0.190969765955462440, -0.191018845512687580, -0.191067924592365160, -0.191117003194372940, -0.191166081318588640, +-0.191215158964888720, -0.191264236133150880, -0.191313312823252450, -0.191362389035070750, -0.191411464768483530, -0.191460540023367180, -0.191509614799599490, -0.191558689097058200, +-0.191607762915619760, -0.191656836255161890, -0.191705909115561960, -0.191754981496697670, -0.191804053398445500, -0.191853124820683200, -0.191902195763288070, -0.191951266226137920, +-0.192000336209109140, -0.192049405712079540, -0.192098474734926420, -0.192147543277527530, -0.192196611339759350, -0.192245678921499660, -0.192294746022626200, -0.192343812643015450, +-0.192392878782545160, -0.192441944441092670, -0.192491009618535740, -0.192540074314750870, -0.192589138529615820, -0.192638202263007900, -0.192687265514804920, -0.192736328284883350, +-0.192785390573120940, -0.192834452379395090, -0.192883513703583500, -0.192932574545562730, -0.192981634905210500, -0.193030694782404200, -0.193079754177021580, -0.193128813088939140, +-0.193177871518034670, -0.193226929464185540, -0.193275986927269490, -0.193325043907163070, -0.193374100403744030, -0.193423156416890170, -0.193472211946477980, -0.193521266992385250, +-0.193570321554489390, -0.193619375632668120, -0.193668429226798000, -0.193717482336756790, -0.193766534962421880, -0.193815587103671080, -0.193864638760380880, -0.193913689932429080, +-0.193962740619693040, -0.194011790822050580, -0.194060840539378220, -0.194109889771553770, -0.194158938518455000, -0.194207986779958490, -0.194257034555941980, -0.194306081846282900, +-0.194355128650858610, -0.194404174969546930, -0.194453220802224380, -0.194502266148768780, -0.194551311009057950, -0.194600355382968410, -0.194649399270377970, -0.194698442671164040, +-0.194747485585204440, -0.194796528012375710, -0.194845569952555640, -0.194894611405621640, -0.194943652371451560, -0.194992692849921910, -0.195041732840910500, -0.195090772344294780, +-0.195139811359952590, -0.195188849887760390, -0.195237887927596110, -0.195286925479337510, -0.195335962542861170, -0.195384999118044940, -0.195434035204766210, -0.195483070802902810, +-0.195532105912331310, -0.195581140532929550, -0.195630174664574910, -0.195679208307145300, -0.195728241460517230, -0.195777274124568550, -0.195826306299176660, -0.195875337984219470, +-0.195924369179573510, -0.195973399885116610, -0.196022430100726200, -0.196071459826280160, -0.196120489061655050, -0.196169517806728700, -0.196218546061378560, -0.196267573825482490, +-0.196316601098917050, -0.196365627881560120, -0.196414654173289540, -0.196463679973981900, -0.196512705283515030, -0.196561730101766420, -0.196610754428613920, -0.196659778263934100, +-0.196708801607604840, -0.196757824459503570, -0.196806846819508160, -0.196855868687495220, -0.196904890063342610, -0.196953910946927770, -0.197002931338128570, -0.197051951236821620, +-0.197100970642884790, -0.197149989556195980, -0.197199007976631730, -0.197248025904070010, -0.197297043338388180, -0.197346060279464190, -0.197395076727174630, -0.197444092681397340, +-0.197493108142009850, -0.197542123108890020, -0.197591137581914460, -0.197640151560961040, -0.197689165045907250, -0.197738178036630960, -0.197787190533008810, -0.197836202534918680, +-0.197885214042238050, -0.197934225054844810, -0.197983235572615570, -0.198032245595428260, -0.198081255123160330, -0.198130264155689680, -0.198179272692892950, -0.198228280734648040, +-0.198277288280832850, -0.198326295331324010, -0.198375301885999440, -0.198424307944736590, -0.198473313507413430, -0.198522318573906560, -0.198571323144093870, -0.198620327217852890, +-0.198669330795061520, -0.198718333875596370, -0.198767336459335420, -0.198816338546156100, -0.198865340135936370, -0.198914341228552870, -0.198963341823883500, -0.199012341921805810, +-0.199061341522197680, -0.199110340624935740, -0.199159339229897980, -0.199208337336961860, -0.199257334946005310, -0.199306332056905010, -0.199355328669538890, -0.199404324783784860, +-0.199453320399519600, -0.199502315516621040, -0.199551310134966690, -0.199600304254434480, -0.199649297874901100, -0.199698290996244480, -0.199747283618342100, -0.199796275741071980, +-0.199845267364310710, -0.199894258487936290, -0.199943249111826200, -0.199992239235858430, -0.200041228859909660, -0.200090217983857790, -0.200139206607580810, -0.200188194730955370, +-0.200237182353859460, -0.200286169476170590, -0.200335156097766730, -0.200384142218524550, -0.200433127838322010, -0.200482112957036630, -0.200531097574546430, -0.200580081690728050, +-0.200629065305459460, -0.200678048418618190, -0.200727031030082270, -0.200776013139728320, -0.200824994747434320, -0.200873975853077870, -0.200922956456536880, -0.200971936557688080, +-0.201020916156409430, -0.201069895252578510, -0.201118873846073270, -0.201167851936770420, -0.201216829524547920, -0.201265806609283810, -0.201314783190854720, -0.201363759269138690, +-0.201412734844013260, -0.201461709915356420, -0.201510684483044880, -0.201559658546956620, -0.201608632106969220, -0.201657605162960690, -0.201706577714807680, -0.201755549762388240, +-0.201804521305579940, -0.201853492344260750, -0.201902462878307400, -0.201951432907597900, -0.202000402432009810, -0.202049371451421160, -0.202098339965708640, -0.202147307974750280, +-0.202196275478423640, -0.202245242476606750, -0.202294208969176300, -0.202343174956010340, -0.202392140436986890, -0.202441105411982650, -0.202490069880875640, -0.202539033843543460, +-0.202587997299864130, -0.202636960249714370, -0.202685922692972200, -0.202734884629515220, -0.202783846059221480, -0.202832806981967710, -0.202881767397631890, -0.202930727306091660, +-0.202979686707225050, -0.203028645600908770, -0.203077603987020900, -0.203126561865439450, -0.203175519236041160, -0.203224476098704060, -0.203273432453305790, -0.203322388299724350, +-0.203371343637836520, -0.203420298467520330, -0.203469252788653380, -0.203518206601113750, -0.203567159904778170, -0.203616112699524680, -0.203665064985230900, -0.203714016761774920, +-0.203762968029033460, -0.203811918786884570, -0.203860869035205870, -0.203909818773875460, -0.203958768002770050, -0.204007716721767710, -0.204056664930746090, -0.204105612629583240, +-0.204154559818155920, -0.204203506496342220, -0.204252452664020170, -0.204301398321066560, -0.204350343467359450, -0.204399288102776490, -0.204448232227195740, -0.204497175840493980, +-0.204546118942549260, -0.204595061533239280, -0.204644003612442060, -0.204692945180034390, -0.204741886235894370, -0.204790826779899630, -0.204839766811928250, -0.204888706331857020, +-0.204937645339564020, -0.204986583834927350, -0.205035521817823780, -0.205084459288131400, -0.205133396245727910, -0.205182332690490880, -0.205231268622298480, -0.205280204041027480, +-0.205329138946555970, -0.205378073338762010, -0.205427007217522470, -0.205475940582715400, -0.205524873434218490, -0.205573805771909810, -0.205622737595666180, -0.205671668905365730, +-0.205720599700886100, -0.205769529982105400, -0.205818459748900450, -0.205867389001149340, -0.205916317738729760, -0.205965245961519800, -0.206014173669396310, -0.206063100862237390, +-0.206112027539921170, -0.206160953702324400, -0.206209879349325280, -0.206258804480801440, -0.206307729096631060, -0.206356653196690890, -0.206405576780859110, -0.206454499849013370, +-0.206503422401031810, -0.206552344436791270, -0.206601265956169870, -0.206650186959045300, -0.206699107445295710, -0.206748027414797920, -0.206796946867430030, -0.206845865803069790, +-0.206894784221595320, -0.206943702122883460, -0.206992619506812360, -0.207041536373259670, -0.207090452722103610, -0.207139368553220990, -0.207188283866489910, -0.207237198661788580, +-0.207286112938993820, -0.207335026697983760, -0.207383939938636160, -0.207432852660829110, -0.207481764864439530, -0.207530676549345510, -0.207579587715424810, -0.207628498362555590, +-0.207677408490614670, -0.207726318099480220, -0.207775227189029990, -0.207824135759142130, -0.207873043809693490, -0.207921951340562240, -0.207970858351626570, -0.208019764842763300, +-0.208068670813850610, -0.208117576264766240, -0.208166481195387940, -0.208215385605593880, -0.208264289495260910, -0.208313192864267220, -0.208362095712490980, -0.208410998039809060, +-0.208459899846099670, -0.208508801131240510, -0.208557701895109780, -0.208606602137584360, -0.208655501858542450, -0.208704401057861750, -0.208753299735420530, -0.208802197891095610, +-0.208851095524765190, -0.208899992636307010, -0.208948889225599320, -0.208997785292518940, -0.209046680836944110, -0.209095575858753020, -0.209144470357822550, -0.209193364334030910, +-0.209242257787255860, -0.209291150717375580, -0.209340043124267020, -0.209388935007808340, -0.209437826367877310, -0.209486717204352160, -0.209535607517109780, -0.209584497306028380, +-0.209633386570985740, -0.209682275311860070, -0.209731163528528270, -0.209780051220868570, -0.209828938388758740, -0.209877825032077000, -0.209926711150700250, -0.209975596744506720, +-0.210024481813374210, -0.210073366357180940, -0.210122250375803820, -0.210171133869121060, -0.210220016837010890, -0.210268899279350270, -0.210317781196017380, -0.210366662586890050, +-0.210415543451846490, -0.210464423790763630, -0.210513303603519750, -0.210562182889992570, -0.210611061650060380, -0.210659939883600100, -0.210708817590489980, -0.210757694770607800, +-0.210806571423831830, -0.210855447550038990, -0.210904323149107540, -0.210953198220915710, -0.211002072765340440, -0.211050946782260000, -0.211099820271552190, -0.211148693233095260, +-0.211197565666766170, -0.211246437572443190, -0.211295308950004090, -0.211344179799327150, -0.211393050120289330, -0.211441919912768870, -0.211490789176643630, -0.211539657911791860, +-0.211588526118090480, -0.211637393795417790, -0.211686260943651640, -0.211735127562670270, -0.211783993652350620, -0.211832859212571000, -0.211881724243209250, -0.211930588744143610, +-0.211979452715251070, -0.212028316156409880, -0.212077179067498340, -0.212126041448393420, -0.212174903298973400, -0.212223764619116130, -0.212272625408699870, -0.212321485667601620, +-0.212370345395699660, -0.212419204592871810, -0.212468063258996390, -0.212516921393950400, -0.212565778997612090, -0.212614636069859340, -0.212663492610570440, -0.212712348619622380, +-0.212761204096893420, -0.212810059042261470, -0.212858913455604790, -0.212907767336800420, -0.212956620685726600, -0.213005473502261260, -0.213054325786282640, -0.213103177537667800, +-0.213152028756294990, -0.213200879442042580, -0.213249729594787500, -0.213298579214408120, -0.213347428300782270, -0.213396276853788290, -0.213445124873303190, -0.213493972359205280, +-0.213542819311372420, -0.213591665729682970, -0.213640511614013930, -0.213689356964243570, -0.213738201780249850, -0.213787046061911040, -0.213835889809104200, -0.213884733021707630, +-0.213933575699599670, -0.213982417842657310, -0.214031259450758930, -0.214080100523782400, -0.214128941061606040, -0.214177781064106900, -0.214226620531163310, -0.214275459462653170, +-0.214324297858454800, -0.214373135718445270, -0.214421973042502880, -0.214470809830505590, -0.214519646082331680, -0.214568481797858230, -0.214617316976963600, -0.214666151619525620, +-0.214714985725422750, -0.214763819294531950, -0.214812652326731630, -0.214861484821899650, -0.214910316779914400, -0.214959148200652930, -0.215007979083993610, -0.215056809429814750, +-0.215105639237993420, -0.215154468508408030, -0.215203297240936430, -0.215252125435457050, -0.215300953091846910, -0.215349780209984380, -0.215398606789747430, -0.215447432831014360, +-0.215496258333662290, -0.215545083297569580, -0.215593907722614160, -0.215642731608674390, -0.215691554955627360, -0.215740377763351480, -0.215789200031724610, -0.215838021760625190, +-0.215886842949930300, -0.215935663599518270, -0.215984483709267090, -0.216033303279055150, -0.216082122308759510, -0.216130940798258560, -0.216179758747430700, -0.216228576156153010, +-0.216277393024303880, -0.216326209351761250, -0.216375025138403540, -0.216423840384107840, -0.216472655088752520, -0.216521469252215580, -0.216570282874375410, -0.216619095955109090, +-0.216667908494295010, -0.216716720491811180, -0.216765531947535980, -0.216814342861346520, -0.216863153233121190, -0.216911963062738440, -0.216960772350075330, -0.217009581095010280, +-0.217058389297421270, -0.217107196957186750, -0.217156004074183780, -0.217204810648290810, -0.217253616679385810, -0.217302422167347210, -0.217351227112052130, -0.217400031513378940, +-0.217448835371205710, -0.217497638685410830, -0.217546441455871400, -0.217595243682465860, -0.217644045365072230, -0.217692846503568900, -0.217741647097833060, -0.217790447147743070, +-0.217839246653176940, -0.217888045614013180, -0.217936844030128830, -0.217985641901402400, -0.218034439227712290, -0.218083236008935640, -0.218132032244950900, -0.218180827935636090, +-0.218229623080869630, -0.218278417680528690, -0.218327211734491710, -0.218376005242636670, -0.218424798204842090, -0.218473590620985060, -0.218522382490944050, -0.218571173814597090, +-0.218619964591822650, -0.218668754822497840, -0.218717544506501160, -0.218766333643711040, -0.218815122234004650, -0.218863910277260460, -0.218912697773356480, -0.218961484722170780, +-0.219010271123581790, -0.219059056977466690, -0.219107842283703950, -0.219156627042172040, -0.219205411252748120, -0.219254194915310670, -0.219302978029737750, -0.219351760595907800, +-0.219400542613698010, -0.219449324082986900, -0.219498105003652440, -0.219546885375573180, -0.219595665198626250, -0.219644444472690160, -0.219693223197642980, -0.219742001373363170, +-0.219790778999727900, -0.219839556076615710, -0.219888332603905030, -0.219937108581473110, -0.219985884009198410, -0.220034658886959030, -0.220083433214633390, -0.220132206992098760, +-0.220180980219233600, -0.220229752895916010, -0.220278525022024470, -0.220327296597436160, -0.220376067622029630, -0.220424838095682920, -0.220473608018274540, -0.220522377389681720, +-0.220571146209782960, -0.220619914478456330, -0.220668682195580330, -0.220717449361032210, -0.220766215974690480, -0.220814982036433180, -0.220863747546138880, -0.220912512503684770, +-0.220961276908949370, -0.221010040761811240, -0.221058804062147530, -0.221107566809836840, -0.221156329004757230, -0.221205090646787230, -0.221253851735804090, -0.221302612271686290, +-0.221351372254311980, -0.221400131683559650, -0.221448890559306580, -0.221497648881431250, -0.221546406649811840, -0.221595163864326820, -0.221643920524853460, -0.221692676631270320, +-0.221741432183455910, -0.221790187181287480, -0.221838941624643570, -0.221887695513402320, -0.221936448847441850, -0.221985201626640680, -0.222033953850876040, -0.222082705520026540, +-0.222131456633970710, -0.222180207192585830, -0.222228957195750390, -0.222277706643342590, -0.222326455535240940, -0.222375203871322730, -0.222423951651466500, -0.222472698875550380, +-0.222521445543452960, -0.222570191655051490, -0.222618937210224550, -0.222667682208850250, -0.222716426650807180, -0.222765170535972640, -0.222813913864225140, -0.222862656635443300, +-0.222911398849504390, -0.222960140506286990, -0.223008881605669200, -0.223057622147529670, -0.223106362131745640, -0.223155101558195730, -0.223203840426758030, -0.223252578737311190, +-0.223301316489732480, -0.223350053683900460, -0.223398790319693290, -0.223447526396989590, -0.223496261915666660, -0.223544996875603060, -0.223593731276676950, -0.223642465118766980, +-0.223691198401750390, -0.223739931125505800, -0.223788663289911400, -0.223837394894845780, -0.223886125940186230, -0.223934856425811350, -0.223983586351599790, -0.224032315717428790, +-0.224081044523177040, -0.224129772768722670, -0.224178500453944300, -0.224227227578719240, -0.224275954142926110, -0.224324680146443110, -0.224373405589148840, -0.224422130470920610, +-0.224470854791637060, -0.224519578551176350, -0.224568301749417170, -0.224617024386236760, -0.224665746461513830, -0.224714467975126950, -0.224763188926953460, -0.224811909316872010, +-0.224860629144760770, -0.224909348410498390, -0.224958067113962240, -0.225006785255030900, -0.225055502833582580, -0.225104219849495970, -0.225152936302648350, -0.225201652192918410, +-0.225250367520184320, -0.225299082284324740, -0.225347796485217050, -0.225396510122739840, -0.225445223196771380, -0.225493935707190260, -0.225542647653873910, -0.225591359036700910, +-0.225640069855549520, -0.225688780110298390, -0.225737489800824890, -0.225786198927007660, -0.225834907488725340, -0.225883615485855340, -0.225932322918276310, -0.225981029785866460, +-0.226029736088504490, -0.226078441826067710, -0.226127146998434860, -0.226175851605484120, -0.226224555647094180, -0.226273259123142450, -0.226321962033507550, -0.226370664378067740, +-0.226419366156701720, -0.226468067369286820, -0.226516768015701780, -0.226565468095824810, -0.226614167609534590, -0.226662866556708560, -0.226711564937225330, -0.226760262750963200, +-0.226808959997800820, -0.226857656677615650, -0.226906352790286310, -0.226955048335691520, -0.227003743313708680, -0.227052437724216490, -0.227101131567093190, -0.227149824842217520, +-0.227198517549466850, -0.227247209688719860, -0.227295901259854880, -0.227344592262750560, -0.227393282697284320, -0.227441972563334870, -0.227490661860780510, -0.227539350589499920, +-0.227588038749370530, -0.227636726340271020, -0.227685413362080150, -0.227734099814675290, -0.227782785697935200, -0.227831471011738150, -0.227880155755962850, -0.227928839930486710, +-0.227977523535188490, -0.228026206569946460, -0.228074889034639350, -0.228123570929144560, -0.228172252253340870, -0.228220933007106550, -0.228269613190320330, -0.228318292802859620, +-0.228366971844603190, -0.228415650315429320, -0.228464328215216780, -0.228513005543842990, -0.228561682301186670, -0.228610358487126130, -0.228659034101540150, -0.228707709144306160, +-0.228756383615302870, -0.228805057514409080, -0.228853730841502210, -0.228902403596461000, -0.228951075779163770, -0.228999747389489310, -0.229048418427315020, -0.229097088892519700, +-0.229145758784981670, -0.229194428104579660, -0.229243096851191150, -0.229291765024694890, -0.229340432624969250, -0.229389099651892940, -0.229437766105343440, -0.229486431985199520, +-0.229535097291339560, -0.229583762023642250, -0.229632426181985120, -0.229681089766246900, -0.229729752776305970, -0.229778415212041120, -0.229827077073329780, -0.229875738360050740, +-0.229924399072082790, -0.229973059209303390, -0.230021718771591360, -0.230070377758825050, -0.230119036170883200, -0.230167694007643340, -0.230216351268984270, -0.230265007954784270, +-0.230313664064922210, -0.230362319599275560, -0.230410974557723110, -0.230459628940143210, -0.230508282746414690, -0.230556935976415020, -0.230605588630023030, -0.230654240707117490, +-0.230702892207575890, -0.230751543131277080, -0.230800193478099410, -0.230848843247921710, -0.230897492440621440, -0.230946141056077440, -0.230994789094168100, -0.231043436554772220, +-0.231092083437767330, -0.231140729743032210, -0.231189375470445270, -0.231238020619885330, -0.231286665191229900, -0.231335309184357800, -0.231383952599147430, -0.231432595435477620, +-0.231481237693225870, -0.231529879372271040, -0.231578520472491530, -0.231627160993766120, -0.231675800935972400, -0.231724440298989170, -0.231773079082695260, -0.231821717286968240, +-0.231870354911686890, -0.231918991956729690, -0.231967628421975440, -0.232016264307301680, -0.232064899612587250, -0.232113534337710590, -0.232162168482550500, -0.232210802046984580, +-0.232259435030891640, -0.232308067434150110, -0.232356699256638850, -0.232405330498235420, -0.232453961158818670, -0.232502591238267000, -0.232551220736459290, -0.232599849653273070, +-0.232648477988587260, -0.232697105742280250, -0.232745732914230900, -0.232794359504316790, -0.232842985512416780, -0.232891610938409740, -0.232940235782173240, -0.232988860043586150, +-0.233037483722526920, -0.233086106818874400, -0.233134729332506170, -0.233183351263301140, -0.233231972611137710, -0.233280593375894800, -0.233329213557449950, -0.233377833155682110, +-0.233426452170469640, -0.233475070601691510, -0.233523688449225250, -0.233572305712949760, -0.233620922392743960, -0.233669538488485430, -0.233718154000053020, -0.233766768927325260, +-0.233815383270180980, -0.233863997028497830, -0.233912610202154670, -0.233961222791029990, -0.234009834795002700, -0.234058446213950390, -0.234107057047751950, -0.234155667296285870, +-0.234204276959431050, -0.234252886037065120, -0.234301494529066960, -0.234350102435315070, -0.234398709755688360, -0.234447316490064450, -0.234495922638322220, -0.234544528200340220, +-0.234593133175997310, -0.234641737565171150, -0.234690341367740610, -0.234738944583584690, -0.234787547212580970, -0.234836149254608360, -0.234884750709545400, -0.234933351577270990, +-0.234981951857662770, -0.235030551550599650, -0.235079150655960160, -0.235127749173623250, -0.235176347103466520, -0.235224944445368900, -0.235273541199208960, -0.235322137364865570, +-0.235370732942216420, -0.235419327931140430, -0.235467922331516530, -0.235516516143222420, -0.235565109366137030, -0.235613702000138840, -0.235662294045106410, -0.235710885500918680, +-0.235759476367453290, -0.235808066644589230, -0.235856656332205400, -0.235905245430179540, -0.235953833938390530, -0.236002421856716970, -0.236051009185037770, -0.236099595923230600, +-0.236148182071174470, -0.236196767628747860, -0.236245352595829770, -0.236293936972297860, -0.236342520758031140, -0.236391103952908080, -0.236439686556807720, -0.236488268569607700, +-0.236536849991187010, -0.236585430821424610, -0.236634011060198210, -0.236682590707386810, -0.236731169762868900, -0.236779748226523510, -0.236828326098228320, -0.236876903377862320, +-0.236925480065304060, -0.236974056160432520, -0.237022631663125400, -0.237071206573261720, -0.237119780890720030, -0.237168354615379300, -0.237216927747117250, -0.237265500285812890, +-0.237314072231344790, -0.237362643583591940, -0.237411214342432040, -0.237459784507744100, -0.237508354079406710, -0.237556923057298860, -0.237605491441298280, -0.237654059231283940, +-0.237702626427134910, -0.237751193028728880, -0.237799759035944860, -0.237848324448661470, -0.237896889266757670, -0.237945453490111230, -0.237994017118601160, -0.238042580152106030, +-0.238091142590504870, -0.238139704433675460, -0.238188265681496760, -0.238236826333847410, -0.238285386390606420, -0.238333945851651550, -0.238382504716861790, -0.238431062986116220, +-0.238479620659292540, -0.238528177736269830, -0.238576734216926660, -0.238625290101142080, -0.238673845388793880, -0.238722400079761030, -0.238770954173922190, -0.238819507671156390, +-0.238868060571341410, -0.238916612874356280, -0.238965164580079600, -0.239013715688390440, -0.239062266199166570, -0.239110816112287020, -0.239159365427630440, -0.239207914145075890, +-0.239256462264501090, -0.239305009785785170, -0.239353556708806700, -0.239402103033444780, -0.239450648759577170, -0.239499193887082930, -0.239547738415841150, -0.239596282345729610, +-0.239644825676627340, -0.239693368408413020, -0.239741910540965690, -0.239790452074163160, -0.239838993007884500, -0.239887533342008350, -0.239936073076413820, -0.239984612210978670, +-0.240033150745581960, -0.240081688680102410, -0.240130226014419050, -0.240178762748409710, -0.240227298881953430, -0.240275834414928950, -0.240324369347215290, -0.240372903678690270, +-0.240421437409233000, -0.240469970538722130, -0.240518503067036760, -0.240567034994054710, -0.240615566319655080, -0.240664097043716970, -0.240712627166118160, -0.240761156686737810, +-0.240809685605454540, -0.240858213922147510, -0.240906741636694510, -0.240955268748974660, -0.241003795258866640, -0.241052321166249560, -0.241100846471001220, -0.241149371173000780, +-0.241197895272126930, -0.241246418768258750, -0.241294941661274100, -0.241343463951052110, -0.241391985637471880, -0.241440506720411260, -0.241489027199749350, -0.241537547075364900, +-0.241586066347137000, -0.241634585014943500, -0.241683103078663560, -0.241731620538175850, -0.241780137393359520, -0.241828653644092400, -0.241877169290253660, -0.241925684331721990, +-0.241974198768376560, -0.242022712600095170, -0.242071225826757020, -0.242119738448240810, -0.242168250464425670, -0.242216761875189480, -0.242265272680411370, -0.242313782879970100, +-0.242362292473744800, -0.242410801461613340, -0.242459309843454870, -0.242507817619148550, -0.242556324788572280, -0.242604831351605180, -0.242653337308125990, -0.242701842658013920, +-0.242750347401146790, -0.242798851537403800, -0.242847355066663660, -0.242895857988805590, -0.242944360303707420, -0.242992862011248370, -0.243041363111307170, -0.243089863603762970, +-0.243138363488493690, -0.243186862765378510, -0.243235361434296170, -0.243283859495125850, -0.243332356947745470, -0.243380853792034170, -0.243429350027870750, -0.243477845655134390, +-0.243526340673702960, -0.243574835083455700, -0.243623328884271790, -0.243671822076029110, -0.243720314658606880, -0.243768806631883880, -0.243817297995739280, -0.243865788750050990, +-0.243914278894698240, -0.243962768429559800, -0.244011257354514870, -0.244059745669441360, -0.244108233374218500, -0.244156720468725050, -0.244205206952840200, -0.244253692826441940, +-0.244302178089409430, -0.244350662741621930, -0.244399146782957290, -0.244447630213294830, -0.244496113032513280, -0.244544595240491880, -0.244593076837108570, -0.244641557822242560, +-0.244690038195772650, -0.244738517957578060, -0.244786997107536760, -0.244835475645527990, -0.244883953571430500, -0.244932430885123560, -0.244980907586485140, -0.245029383675394420, +-0.245077859151730250, -0.245126334015371870, -0.245174808266197230, -0.245223281904085540, -0.245271754928915680, -0.245320227340566850, -0.245368699138917010, -0.245417170323845440, +-0.245465640895231370, -0.245514110852952770, -0.245562580196888870, -0.245611048926918540, -0.245659517042921020, -0.245707984544774270, -0.245756451432357550, -0.245804917705549740, +-0.245853383364230020, -0.245901848408276450, -0.245950312837568240, -0.245998776651984250, -0.246047239851403730, -0.246095702435704690, -0.246144164404766410, -0.246192625758467700, +-0.246241086496687880, -0.246289546619304880, -0.246338006126198050, -0.246386465017246180, -0.246434923292328580, -0.246483380951323240, -0.246531837994109470, -0.246580294420566530, +-0.246628750230572400, -0.246677205424006420, -0.246725660000747420, -0.246774113960674670, -0.246822567303666250, -0.246871020029601370, -0.246919472138358960, -0.246967923629818310, +-0.247016374503857410, -0.247064824760355600, -0.247113274399191700, -0.247161723420245030, -0.247210171823393670, -0.247258619608516830, -0.247307066775493910, -0.247355513324202860, +-0.247403959254523050, -0.247452404566333330, -0.247500849259512600, -0.247549293333940180, -0.247597736789494090, -0.247646179626053680, -0.247694621843498250, -0.247743063441705800, +-0.247791504420555720, -0.247839944779926880, -0.247888384519698610, -0.247936823639748920, -0.247985262139957200, -0.248033700020202750, -0.248082137280363600, -0.248130573920319120, +-0.248179009939948210, -0.248227445339129770, -0.248275880117743150, -0.248324314275666400, -0.248372747812778880, -0.248421180728959880, -0.248469613024087540, -0.248518044698041150, +-0.248566475750699650, -0.248614906181942400, -0.248663335991647440, -0.248711765179694150, -0.248760193745961420, -0.248808621690328660, -0.248857049012673910, -0.248905475712876550, +-0.248953901790815500, -0.249002327246370110, -0.249050752079418490, -0.249099176289839960, -0.249147599877513950, -0.249196022842318510, -0.249244445184133000, -0.249292866902836360, +-0.249341287998307570, -0.249389708470425990, -0.249438128319069720, -0.249486547544118110, -0.249534966145450590, -0.249583384122945200, -0.249631801476481370, -0.249680218205938030, +-0.249728634311194550, -0.249777049792129090, -0.249825464648620960, -0.249873878880549210, -0.249922292487793190, -0.249970705470230980, -0.250019117827742050, -0.250067529560205280, +-0.250115940667500150, -0.250164351149504690, -0.250212761006098410, -0.250261170237160660, -0.250309578842569490, -0.250357986822204450, -0.250406394175944400, -0.250454800903668340, +-0.250503207005255750, -0.250551612480584720, -0.250600017329534630, -0.250648421551984910, -0.250696825147813720, -0.250745228116900480, -0.250793630459124170, -0.250842032174364240, +-0.250890433262498770, -0.250938833723407200, -0.250987233556969000, -0.251035632763062290, -0.251084031341566480, -0.251132429292360630, -0.251180826615323650, -0.251229223310335090, +-0.251277619377273000, -0.251326014816016910, -0.251374409626446140, -0.251422803808438950, -0.251471197361874790, -0.251519590286632570, -0.251567982582591830, -0.251616374249630740, +-0.251664765287628660, -0.251713155696464690, -0.251761545476018260, -0.251809934626167580, -0.251858323146792020, -0.251906711037770630, -0.251955098298982940, -0.252003484930307050, +-0.252051870931622460, -0.252100256302808580, -0.252148641043743680, -0.252197025154307140, -0.252245408634378050, -0.252293791483835460, -0.252342173702558790, -0.252390555290426310, +-0.252438936247317390, -0.252487316573111580, -0.252535696267687020, -0.252584075330923250, -0.252632453762699270, -0.252680831562894610, -0.252729208731387430, -0.252777585268057270, +-0.252825961172783110, -0.252874336445444440, -0.252922711085919520, -0.252971085094087830, -0.253019458469828480, -0.253067831213020840, -0.253116203323543230, -0.253164574801275080, +-0.253212945646095980, -0.253261315857884030, -0.253309685436518830, -0.253358054381879360, -0.253406422693845220, -0.253454790372294620, -0.253503157417106990, -0.253551523828161480, +-0.253599889605337640, -0.253648254748513600, -0.253696619257568920, -0.253744983132382750, -0.253793346372834520, -0.253841708978802430, -0.253890070950166140, -0.253938432286805070, +-0.253986792988597500, -0.254035153055422960, -0.254083512487160550, -0.254131871283689300, -0.254180229444888880, -0.254228586970637380, -0.254276943860814450, -0.254325300115299640, +-0.254373655733971080, -0.254422010716708390, -0.254470365063390660, -0.254518718773897480, -0.254567071848107060, -0.254615424285899010, -0.254663776087152350, -0.254712127251746630, +-0.254760477779560230, -0.254808827670472640, -0.254857176924362940, -0.254905525541110790, -0.254953873520594340, -0.255002220862693200, -0.255050567567286950, -0.255098913634253910, +-0.255147259063473520, -0.255195603854824980, -0.255243948008187450, -0.255292291523440520, -0.255340634400462340, -0.255388976639132630, -0.255437318239330910, -0.255485659200935470, +-0.255533999523825880, -0.255582339207881260, -0.255630678252981250, -0.255679016659004110, -0.255727354425829450, -0.255775691553336350, -0.255824028041404530, -0.255872363889912140, +-0.255920699098738880, -0.255969033667763860, -0.256017367596866660, -0.256065700885925620, -0.256114033534820370, -0.256162365543430410, -0.256210696911634170, -0.256259027639311130, +-0.256307357726340560, -0.256355687172601990, -0.256404015977973800, -0.256452344142335530, -0.256500671665566450, -0.256548998547546090, -0.256597324788152840, -0.256645650387266220, +-0.256693975344765510, -0.256742299660530300, -0.256790623334438920, -0.256838946366370950, -0.256887268756206040, -0.256935590503822590, -0.256983911609100110, -0.257032232071917830, +-0.257080551892155010, -0.257128871069691230, -0.257177189604404830, -0.257225507496175450, -0.257273824744882810, -0.257322141350405100, -0.257370457312622040, -0.257418772631412830, +-0.257467087306657180, -0.257515401338233310, -0.257563714726020960, -0.257612027469899360, -0.257660339569748100, -0.257708651025445550, -0.257756961836871360, -0.257805272003904800, +-0.257853581526425460, -0.257901890404311770, -0.257950198637443340, -0.257998506225699810, -0.258046813168959610, -0.258095119467102400, -0.258143425120007370, -0.258191730127553750, +-0.258240034489621300, -0.258288338206088260, -0.258336641276834420, -0.258384943701739420, -0.258433245480681580, -0.258481546613540670, -0.258529847100195890, -0.258578146940526890, +-0.258626446134412100, -0.258674744681731240, -0.258723042582363500, -0.258771339836188550, -0.258819636443084870, -0.258867932402932040, -0.258916227715609400, -0.258964522380996650, +-0.259012816398972170, -0.259061109769415600, -0.259109402492206710, -0.259157694567223870, -0.259205985994346800, -0.259254276773454810, -0.259302566904427490, -0.259350856387143340, +-0.259399145221482110, -0.259447433407322960, -0.259495720944545650, -0.259544007833028610, -0.259592294072651550, -0.259640579663293790, -0.259688864604834980, -0.259737148897153600, +-0.259785432540129370, -0.259833715533641930, -0.259881997877569830, -0.259930279571792660, -0.259978560616189850, -0.260026841010640610, -0.260075120755024700, -0.260123399849220560, +-0.260171678293107940, -0.260219956086566560, -0.260268233229474840, -0.260316509721712550, -0.260364785563158950, -0.260413060753693860, -0.260461335293195650, -0.260509609181544140, +-0.260557882418618600, -0.260606155004298790, -0.260654426938463140, -0.260702698220991400, -0.260750968851762970, -0.260799238830657530, -0.260847508157553530, -0.260895776832330780, +-0.260944044854869050, -0.260992312225046710, -0.261040578942743630, -0.261088845007839130, -0.261137110420212480, -0.261185375179743500, -0.261233639286310660, -0.261281902739793680, +-0.261330165540072430, -0.261378427687025290, -0.261426689180532080, -0.261474950020472160, -0.261523210206725310, -0.261571469739170000, -0.261619728617686010, -0.261667986842152700, +-0.261716244412449890, -0.261764501328455970, -0.261812757590050850, -0.261861013197113800, -0.261909268149524700, -0.261957522447161920, -0.262005776089905380, -0.262054029077634810, +-0.262102281410228790, -0.262150533087567030, -0.262198784109528900, -0.262247034475994290, -0.262295284186841670, -0.262343533241950810, -0.262391781641201140, -0.262440029384472420, +-0.262488276471643240, -0.262536522902593330, -0.262584768677202100, -0.262633013795349420, -0.262681258256913740, -0.262729502061774920, -0.262777745209812790, -0.262825987700905870, +-0.262874229534934000, -0.262922470711776550, -0.262970711231312880, -0.263018951093422880, -0.263067190297985090, -0.263115428844879320, -0.263163666733985390, -0.263211903965181850, +-0.263260140538348620, -0.263308376453364970, -0.263356611710110820, -0.263404846308464720, -0.263453080248306550, -0.263501313529515610, -0.263549546151971850, -0.263597778115553790, +-0.263646009420141270, -0.263694240065613760, -0.263742470051851030, -0.263790699378731730, -0.263838928046135680, -0.263887156053942750, -0.263935383402031490, -0.263983610090281760, +-0.264031836118573000, -0.264080061486784650, -0.264128286194796610, -0.264176510242487390, -0.264224733629736920, -0.264272956356425060, -0.264321178422430300, -0.264369399827632690, +-0.264417620571911540, -0.264465840655146780, -0.264514060077216950, -0.264562278838001990, -0.264610496937381760, -0.264658714375234860, -0.264706931151441170, -0.264755147265880180, +-0.264803362718431300, -0.264851577508974480, -0.264899791637388250, -0.264948005103552540, -0.264996217907347230, -0.265044430048650970, -0.265092641527343630, -0.265140852343304700, +-0.265189062496414050, -0.265237271986550340, -0.265285480813593430, -0.265333688977422820, -0.265381896477918430, -0.265430103314958870, -0.265478309488423990, -0.265526514998193410, +-0.265574719844146930, -0.265622924026163280, -0.265671127544122250, -0.265719330397903850, -0.265767532587386720, -0.265815734112450740, -0.265863934972975450, -0.265912135168840270, +-0.265960334699925250, -0.266008533566108930, -0.266056731767271240, -0.266104929303292210, -0.266153126174050400, -0.266201322379425730, -0.266249517919297850, -0.266297712793546530, +-0.266345907002050520, -0.266394100544689760, -0.266442293421343730, -0.266490485631892370, -0.266538677176214430, -0.266586868054189740, -0.266635058265697940, -0.266683247810618860, +-0.266731436688831260, -0.266779624900215060, -0.266827812444650260, -0.266875999322015440, -0.266924185532190660, -0.266972371075055450, -0.267020555950489680, -0.267068740158372120, +-0.267116923698582700, -0.267165106571000950, -0.267213288775506930, -0.267261470311979220, -0.267309651180297810, -0.267357831380342300, -0.267406010911992620, -0.267454189775127530, +-0.267502367969626900, -0.267550545495370830, -0.267598722352237970, -0.267646898540108260, -0.267695074058861340, -0.267743248908376750, -0.267791423088534430, -0.267839596599213140, +-0.267887769440292860, -0.267935941611653570, -0.267984113113173990, -0.268032283944734160, -0.268080454106213560, -0.268128623597492340, -0.268176792418449050, -0.268224960568963830, +-0.268273128048916230, -0.268321294858186180, -0.268369460996652490, -0.268417626464195150, -0.268465791260693750, -0.268513955386028290, -0.268562118840077520, -0.268610281622721440, +-0.268658443733840120, -0.268706605173312240, -0.268754765941017830, -0.268802926036836530, -0.268851085460647900, -0.268899244212331970, -0.268947402291767500, -0.268995559698834540, +-0.269043716433413130, -0.269091872495381970, -0.269140027884621160, -0.269188182601010240, -0.269236336644429360, -0.269284490014757130, -0.269332642711873740, -0.269380794735658680, +-0.269428946085992100, -0.269477096762752720, -0.269525246765820630, -0.269573396095075360, -0.269621544750397070, -0.269669692731664470, -0.269717840038757650, -0.269765986671556660, +-0.269814132629940310, -0.269862277913788580, -0.269910422522981140, -0.269958566457398130, -0.270006709716918260, -0.270054852301421570, -0.270102994210787820, -0.270151135444896940, +-0.270199276003627810, -0.270247415886860520, -0.270295555094474670, -0.270343693626350360, -0.270391831482366400, -0.270439968662402890, -0.270488105166339870, -0.270536240994056100, +-0.270584376145431790, -0.270632510620346490, -0.270680644418679950, -0.270728777540312220, -0.270776909985122160, -0.270825041752989770, -0.270873172843795200, -0.270921303257417310, +-0.270969432993736100, -0.271017562052631390, -0.271065690433983150, -0.271113818137670270, -0.271161945163572840, -0.271210071511570560, -0.271258197181543480, -0.271306322173370530, +-0.271354446486931740, -0.271402570122106890, -0.271450693078776010, -0.271498815356817970, -0.271546936956112870, -0.271595057876540870, -0.271643178117980830, -0.271691297680312800, +-0.271739416563416550, -0.271787534767171770, -0.271835652291458560, -0.271883769136155810, -0.271931885301143590, -0.271980000786302130, -0.272028115591510240, -0.272076229716648020, +-0.272124343161595280, -0.272172455926232070, -0.272220568010437310, -0.272268679414091110, -0.272316790137073270, -0.272364900179263850, -0.272413009540541710, -0.272461118220787110, +-0.272509226219879660, -0.272557333537699620, -0.272605440174125800, -0.272653546129038360, -0.272701651402317500, -0.272749755993842050, -0.272797859903492260, -0.272845963131147780, +-0.272894065676688890, -0.272942167539994340, -0.272990268720944400, -0.273038369219418760, -0.273086469035297650, -0.273134568168459930, -0.273182666618785820, -0.273230764386155010, +-0.273278861470447720, -0.273326957871542870, -0.273375053589320570, -0.273423148623661130, -0.273471242974443360, -0.273519336641547480, -0.273567429624853250, -0.273615521924240490, +-0.273663613539589290, -0.273711704470778690, -0.273759794717688800, -0.273807884280199860, -0.273855973158190770, -0.273904061351541770, -0.273952148860132580, -0.274000235683843460, +-0.274048321822553340, -0.274096407276142370, -0.274144492044490430, -0.274192576127477660, -0.274240659524983050, -0.274288742236886760, -0.274336824263068660, -0.274384905603408890, +-0.274432986257786450, -0.274481066226081540, -0.274529145508174370, -0.274577224103943920, -0.274625302013270400, -0.274673379236033630, -0.274721455772113430, -0.274769531621390010, +-0.274817606783742340, -0.274865681259050640, -0.274913755047195170, -0.274961828148054870, -0.275009900561510030, -0.275057972287440390, -0.275106043325726300, -0.275154113676246650, +-0.275202183338881750, -0.275250252313511360, -0.275298320600015740, -0.275346388198273890, -0.275394455108166130, -0.275442521329572200, -0.275490586862372380, -0.275538651706445700, +-0.275586715861672380, -0.275634779327932680, -0.275682842105105630, -0.275730904193071450, -0.275778965591710000, -0.275827026300901610, -0.275875086320525150, -0.275923145650461050, +-0.275971204290589080, -0.276019262240789490, -0.276067319500941320, -0.276115376070924900, -0.276163431950619990, -0.276211487139906950, -0.276259541638664730, -0.276307595446773690, +-0.276355648564114100, -0.276403700990564940, -0.276451752726006530, -0.276499803770318740, -0.276547854123381450, -0.276595903785074930, -0.276643952755278260, -0.276692001033871650, +-0.276740048620735530, -0.276788095515748790, -0.276836141718791890, -0.276884187229744560, -0.276932232048487270, -0.276980276174898900, -0.277028319608859870, -0.277076362350250070, +-0.277124404398949750, -0.277172445754838010, -0.277220486417795120, -0.277268526387701050, -0.277316565664436080, -0.277364604247879290, -0.277412642137910950, -0.277460679334411490, +-0.277508715837259830, -0.277556751646336420, -0.277604786761521170, -0.277652821182693910, -0.277700854909735010, -0.277748887942523560, -0.277796920280939890, -0.277844951924864360, +-0.277892982874176020, -0.277941013128755240, -0.277989042688481900, -0.278037071553236370, -0.278085099722897740, -0.278133127197346400, -0.278181153976462650, -0.278229180060125540, +-0.278277205448215550, -0.278325230140612500, -0.278373254137196380, -0.278421277437847560, -0.278469300042445130, -0.278517321950869420, -0.278565343163000860, -0.278613363678718530, +-0.278661383497902760, -0.278709402620433530, -0.278757421046191220, -0.278805438775054980, -0.278853455806905070, -0.278901472141621590, -0.278949487779084790, -0.278997502719173900, +-0.279045516961769210, -0.279093530506750790, -0.279141543353998880, -0.279189555503392750, -0.279237566954812720, -0.279285577708139220, -0.279333587763251290, -0.279381597120029410, +-0.279429605778353570, -0.279477613738103700, -0.279525620999160230, -0.279573627561402250, -0.279621633424710250, -0.279669638588964540, -0.279717643054044340, -0.279765646819830020, +-0.279813649886201610, -0.279861652253039440, -0.279909653920222770, -0.279957654887631970, -0.280005655155146970, -0.280053654722648320, -0.280101653590015100, -0.280149651757127690, +-0.280197649223866200, -0.280245645990111040, -0.280293642055741310, -0.280341637420637450, -0.280389632084679930, -0.280437626047747910, -0.280485619309721880, -0.280533611870481760, +-0.280581603729907590, -0.280629594887879860, -0.280677585344277670, -0.280725575098981550, -0.280773564151871930, -0.280821552502827980, -0.280869540151730160, -0.280917527098458460, +-0.280965513342893380, -0.281013498884914060, -0.281061483724401040, -0.281109467861234700, -0.281157451295294290, -0.281205434026460200, -0.281253416054612570, -0.281301397379631450, +-0.281349378001397200, -0.281397357919789090, -0.281445337134687560, -0.281493315645973130, -0.281541293453525020, -0.281589270557223600, -0.281637246956949080, -0.281685222652581830, +-0.281733197644001120, -0.281781171931087430, -0.281829145513720740, -0.281877118391781700, -0.281925090565149360, -0.281973062033704310, -0.282021032797326650, -0.282069002855896810, +-0.282116972209294050, -0.282164940857398850, -0.282212908800091700, -0.282260876037251860, -0.282308842568759880, -0.282356808394495730, -0.282404773514339570, -0.282452737928171940, +-0.282500701635871990, -0.282548664637320310, -0.282596626932397400, -0.282644588520982510, -0.282692549402956130, -0.282740509578198350, -0.282788469046589770, -0.282836427808009610, +-0.282884385862338330, -0.282932343209456090, -0.282980299849243440, -0.283028255781579590, -0.283076211006345110, -0.283124165523420070, -0.283172119332685100, -0.283220072434019370, +-0.283268024827303510, -0.283315976512417970, -0.283363927489242050, -0.283411877757656310, -0.283459827317540940, -0.283507776168776370, -0.283555724311241930, -0.283603671744818210, +-0.283651618469385300, -0.283699564484823750, -0.283747509791012880, -0.283795454387833270, -0.283843398275164970, -0.283891341452888630, -0.283939283920883470, -0.283987225679030120, +-0.284035166727209190, -0.284083107065299880, -0.284131046693182790, -0.284178985610738070, -0.284226923817845870, -0.284274861314386840, -0.284322798100240190, -0.284370734175286580, +-0.284418669539406530, -0.284466604192479430, -0.284514538134385760, -0.284562471365005790, -0.284610403884220040, -0.284658335691907850, -0.284706266787949860, -0.284754197172226160, +-0.284802126844617420, -0.284850055805002940, -0.284897984053263280, -0.284945911589278680, -0.284993838412929750, -0.285041764524095800, -0.285089689922657430, -0.285137614608495240, +-0.285185538581488600, -0.285233461841518100, -0.285281384388463950, -0.285329306222206370, -0.285377227342625940, -0.285425147749601980, -0.285473067443015200, -0.285520986422746150, +-0.285568904688674190, -0.285616822240680020, -0.285664739078643760, -0.285712655202446100, -0.285760570611966360, -0.285808485307085190, -0.285856399287682810, -0.285904312553639850, +-0.285952225104835700, -0.286000136941150950, -0.286048048062465920, -0.286095958468661150, -0.286143868159616070, -0.286191777135211320, -0.286239685395327570, -0.286287592939844130, +-0.286335499768641750, -0.286383405881600610, -0.286431311278601390, -0.286479215959523470, -0.286527119924247510, -0.286575023172653710, -0.286622925704622830, -0.286670827520034140, +-0.286718728618768460, -0.286766629000705930, -0.286814528665727260, -0.286862427613711830, -0.286910325844540350, -0.286958223358093460, -0.287006120154250590, -0.287054016232892390, +-0.287101911593899200, -0.287149806237151200, -0.287197700162529160, -0.287245593369912400, -0.287293485859181690, -0.287341377630217610, -0.287389268682899710, -0.287437159017108650, +-0.287485048632724730, -0.287532937529628550, -0.287580825707699610, -0.287628713166818650, -0.287676599906865840, -0.287724485927721980, -0.287772371229266520, -0.287820255811380100, +-0.287868139673943040, -0.287916022816836090, -0.287963905239938590, -0.288011786943131400, -0.288059667926295120, -0.288107548189309230, -0.288155427732054490, -0.288203306554411230, +-0.288251184656259650, -0.288299062037480570, -0.288346938697953360, -0.288394814637558840, -0.288442689856177710, -0.288490564353689420, -0.288538438129974710, -0.288586311184913900, +-0.288634183518387770, -0.288682055130275730, -0.288729926020458550, -0.288777796188816550, -0.288825665635230490, -0.288873534359579850, -0.288921402361745410, -0.288969269641607410, +-0.289017136199046680, -0.289065002033942700, -0.289112867146176180, -0.289160731535627940, -0.289208595202177450, -0.289256458145705440, -0.289304320366092330, -0.289352181863218820, +-0.289400042636964390, -0.289447902687209930, -0.289495762013835700, -0.289543620616722450, -0.289591478495749730, -0.289639335650798360, -0.289687192081748590, -0.289735047788481300, +-0.289782902770875980, -0.289830757028813390, -0.289878610562174290, -0.289926463370838270, -0.289974315454686100, -0.290022166813598160, -0.290070017447454750, -0.290117867356136760, +-0.290165716539523670, -0.290213564997496290, -0.290261412729935440, -0.290309259736720620, -0.290357106017732620, -0.290404951572851900, -0.290452796401959200, -0.290500640504934070, +-0.290548483881657380, -0.290596326532009450, -0.290644168455871150, -0.290692009653121970, -0.290739850123642780, -0.290787689867314010, -0.290835528884016370, -0.290883367173629560, +-0.290931204736034290, -0.290979041571111430, -0.291026877678740530, -0.291074713058802450, -0.291122547711177570, -0.291170381635746320, -0.291218214832389580, -0.291266047300986870, +-0.291313879041419030, -0.291361710053566920, -0.291409540337310090, -0.291457369892529410, -0.291505198719105350, -0.291553026816918690, -0.291600854185849020, -0.291648680825777220, +-0.291696506736584150, -0.291744331918149410, -0.291792156370353830, -0.291839980093077880, -0.291887803086201940, -0.291935625349606930, -0.291983446883172400, -0.292031267686779280, +-0.292079087760308440, -0.292126907103639420, -0.292174725716653150, -0.292222543599230110, -0.292270360751251070, -0.292318177172595730, -0.292365992863144910, -0.292413807822779150, +-0.292461622051379320, -0.292509435548824970, -0.292557248314997020, -0.292605060349775960, -0.292652871653042710, -0.292700682224676820, -0.292748492064559220, -0.292796301172570830, +-0.292844109548591250, -0.292891917192501410, -0.292939724104181790, -0.292987530283512820, -0.293035335730375490, -0.293083140444649340, -0.293130944426215400, -0.293178747674954500, +-0.293226550190746280, -0.293274351973471740, -0.293322153023011290, -0.293369953339245870, -0.293417752922055190, -0.293465551771320050, -0.293513349886921070, -0.293561147268739160, +-0.293608943916653930, -0.293656739830546350, -0.293704535010296920, -0.293752329455786610, -0.293800123166895020, -0.293847916143503090, -0.293895708385491840, -0.293943499892740880, +-0.293991290665131190, -0.294039080702543250, -0.294086870004857610, -0.294134658571955250, -0.294182446403715770, -0.294230233500020200, -0.294278019860749470, -0.294325805485783240, +-0.294373590375002550, -0.294421374528287870, -0.294469157945520140, -0.294516940626579130, -0.294564722571345750, -0.294612503779701000, -0.294660284251524520, -0.294708063986697410, +-0.294755842985100100, -0.294803621246613130, -0.294851398771117600, -0.294899175558493150, -0.294946951608620720, -0.294994726921381340, -0.295042501496654790, -0.295090275334321920, +-0.295138048434263330, -0.295185820796360130, -0.295233592420491910, -0.295281363306539700, -0.295329133454384110, -0.295376902863906050, -0.295424671534985360, -0.295472439467503010, +-0.295520206661339550, -0.295567973116375950, -0.295615738832492040, -0.295663503809568740, -0.295711268047487150, -0.295759031546126930, -0.295806794305369160, -0.295854556325094390, +-0.295902317605183260, -0.295950078145516720, -0.295997837945974560, -0.296045597006437840, -0.296093355326787540, -0.296141112906903430, -0.296188869746666530, -0.296236625845957450, +-0.296284381204657220, -0.296332135822645610, -0.296379889699803670, -0.296427642836012030, -0.296475395231151680, -0.296523146885102450, -0.296570897797745310, -0.296618647968960980, +-0.296666397398630380, -0.296714146086633430, -0.296761894032851080, -0.296809641237164410, -0.296857387699453250, -0.296905133419598620, -0.296952878397481130, -0.297000622632981880, +-0.297048366125980620, -0.297096108876358460, -0.297143850883996030, -0.297191592148774440, -0.297239332670573400, -0.297287072449274050, -0.297334811484756990, -0.297382549776903370, +-0.297430287325592900, -0.297478024130706730, -0.297525760192125950, -0.297573495509730330, -0.297621230083400970, -0.297668963913018500, -0.297716696998463700, -0.297764429339617500, +-0.297812160936359870, -0.297859891788571810, -0.297907621896134400, -0.297955351258927580, -0.298003079876832330, -0.298050807749729420, -0.298098534877499880, -0.298146261260023640, +-0.298193986897181680, -0.298241711788854780, -0.298289435934924020, -0.298337159335269280, -0.298384881989771590, -0.298432603898311720, -0.298480325060770770, -0.298528045477028550, +-0.298575765146966270, -0.298623484070464960, -0.298671202247404510, -0.298718919677666060, -0.298766636361130320, -0.298814352297678000, -0.298862067487190240, -0.298909781929546870, +-0.298957495624629030, -0.299005208572317880, -0.299052920772493290, -0.299100632225036410, -0.299148342929827950, -0.299196052886749000, -0.299243762095679540, -0.299291470556500680, +-0.299339178269093120, -0.299386885233338060, -0.299434591449115380, -0.299482296916306180, -0.299530001634791270, -0.299577705604451740, -0.299625408825167580, -0.299673111296819840, +-0.299720813019289770, -0.299768513992457300, -0.299816214216203470, -0.299863913690409100, -0.299911612414955400, -0.299959310389722230, -0.300007007614590810, -0.300054704089441850, +-0.300102399814156600, -0.300150094788614870, -0.300197789012697950, -0.300245482486286520, -0.300293175209261800, -0.300340867181503710, -0.300388558402893470, -0.300436248873312270, +-0.300483938592640050, -0.300531627560757960, -0.300579315777546760, -0.300627003242887330, -0.300674689956660800, -0.300722375918747060, -0.300770061129027490, -0.300817745587383110, +-0.300865429293693980, -0.300913112247841230, -0.300960794449705750, -0.301008475899168680, -0.301056156596110010, -0.301103836540410950, -0.301151515731952310, -0.301199194170615250, +-0.301246871856279850, -0.301294548788827220, -0.301342224968138230, -0.301389900394094130, -0.301437575066574810, -0.301485248985461580, -0.301532922150635650, -0.301580594561977000, +-0.301628266219366890, -0.301675937122686030, -0.301723607271815410, -0.301771276666636170, -0.301818945307028300, -0.301866613192873060, -0.301914280324051710, -0.301961946700444240, +-0.302009612321931910, -0.302057277188395590, -0.302104941299716430, -0.302152604655774540, -0.302200267256451100, -0.302247929101627070, -0.302295590191183570, -0.302343250525000660, +-0.302390910102959650, -0.302438568924941420, -0.302486226990827110, -0.302533884300496820, -0.302581540853831880, -0.302629196650713470, -0.302676851691021650, -0.302724505974637680, +-0.302772159501442430, -0.302819812271317270, -0.302867464284142130, -0.302915115539798270, -0.302962766038166690, -0.303010415779128630, -0.303058064762564080, -0.303105712988354370, +-0.303153360456380360, -0.303201007166523370, -0.303248653118663450, -0.303296298312681900, -0.303343942748460050, -0.303391586425877880, -0.303439229344816760, -0.303486871505157570, +-0.303534512906781240, -0.303582153549569020, -0.303629793433400960, -0.303677432558158430, -0.303725070923722750, -0.303772708529974010, -0.303820345376793480, -0.303867981464062020, +-0.303915616791661130, -0.303963251359470720, -0.304010885167372180, -0.304058518215246430, -0.304106150502974790, -0.304153782030437360, -0.304201412797515500, -0.304249042804090100, +-0.304296672050042520, -0.304344300535252850, -0.304391928259602370, -0.304439555222972560, -0.304487181425243390, -0.304534806866296300, -0.304582431546012170, -0.304630055464271960, +-0.304677678620957070, -0.304725301015947530, -0.304772922649124760, -0.304820543520370080, -0.304868163629563590, -0.304915782976586780, -0.304963401561320460, -0.305011019383646050, +-0.305058636443443660, -0.305106252740594720, -0.305153868274980530, -0.305201483046481260, -0.305249097054978320, -0.305296710300352600, -0.305344322782485080, -0.305391934501257230, +-0.305439545456549110, -0.305487155648242080, -0.305534765076217630, -0.305582373740355850, -0.305629981640538120, -0.305677588776645410, -0.305725195148559170, -0.305772800756159540, +-0.305820405599327880, -0.305868009677945250, -0.305915612991892960, -0.305963215541051270, -0.306010817325301500, -0.306058418344524740, -0.306106018598602310, -0.306153618087414430, +-0.306201216810842450, -0.306248814768767920, -0.306296411961070880, -0.306344008387632870, -0.306391604048334760, -0.306439198943057710, -0.306486793071683080, -0.306534386434091030, +-0.306581979030162990, -0.306629570859780430, -0.306677161922823570, -0.306724752219173780, -0.306772341748712100, -0.306819930511319950, -0.306867518506877600, -0.306915105735266420, +-0.306962692196367510, -0.307010277890062300, -0.307057862816230930, -0.307105446974754950, -0.307153030365515330, -0.307200612988393570, -0.307248194843269820, -0.307295775930025610, +-0.307343356248542420, -0.307390935798700360, -0.307438514580380960, -0.307486092593465320, -0.307533669837834420, -0.307581246313369750, -0.307628822019951560, -0.307676396957461300, +-0.307723971125780480, -0.307771544524789330, -0.307819117154369270, -0.307866689014401450, -0.307914260104767360, -0.307961830425347140, -0.308009399976022390, -0.308056968756674540, +-0.308104536767183860, -0.308152104007431820, -0.308199670477299510, -0.308247236176668050, -0.308294801105418960, -0.308342365263432390, -0.308389928650589900, -0.308437491266773060, +-0.308485053111862030, -0.308532614185738350, -0.308580174488283180, -0.308627734019377930, -0.308675292778902990, -0.308722850766739780, -0.308770407982769500, -0.308817964426873590, +-0.308865520098932310, -0.308913074998827250, -0.308960629126439510, -0.309008182481650630, -0.309055735064340860, -0.309103286874391760, -0.309150837911684850, -0.309198388176100460, +-0.309245937667520070, -0.309293486385824820, -0.309341034330895880, -0.309388581502614780, -0.309436127900861780, -0.309483673525518480, -0.309531218376466410, -0.309578762453585900, +-0.309626305756758420, -0.309673848285865250, -0.309721390040787860, -0.309768931021406570, -0.309816471227602920, -0.309864010659258120, -0.309911549316253700, -0.309959087198469980, +-0.310006624305788570, -0.310054160638090600, -0.310101696195257630, -0.310149230977170010, -0.310196764983709290, -0.310244298214757130, -0.310291830670193720, -0.310339362349900780, +-0.310386893253759450, -0.310434423381651340, -0.310481952733456690, -0.310529481309057160, -0.310577009108333970, -0.310624536131168640, -0.310672062377441550, -0.310719587847034300, +-0.310767112539828080, -0.310814636455704560, -0.310862159594543940, -0.310909681956227980, -0.310957203540638220, -0.311004724347655030, -0.311052244377160000, -0.311099763629034410, +-0.311147282103159390, -0.311194799799416610, -0.311242316717686370, -0.311289832857850330, -0.311337348219790140, -0.311384862803386180, -0.311432376608520080, -0.311479889635073000, +-0.311527401882926660, -0.311574913351961360, -0.311622424042058750, -0.311669933953100110, -0.311717443084967070, -0.311764951437540020, -0.311812459010700540, -0.311859965804329900, +-0.311907471818309800, -0.311954977052520620, -0.312002481506843950, -0.312049985181161560, -0.312097488075353760, -0.312144990189302200, -0.312192491522888190, -0.312239992075992960, +-0.312287491848498190, -0.312334990840284210, -0.312382489051232840, -0.312429986481225610, -0.312477483130143010, -0.312524978997866690, -0.312572474084277910, -0.312619968389258370, +-0.312667461912688520, -0.312714954654449980, -0.312762446614424090, -0.312809937792492440, -0.312857428188535570, -0.312904917802435180, -0.312952406634072420, -0.312999894683329060, +-0.313047381950085580, -0.313094868434223630, -0.313142354135624970, -0.313189839054169970, -0.313237323189740350, -0.313284806542217460, -0.313332289111482980, -0.313379770897417310, +-0.313427251899902230, -0.313474732118819040, -0.313522211554049410, -0.313569690205473870, -0.313617168072974070, -0.313664645156431390, -0.313712121455727470, -0.313759596970742850, +-0.313807071701359240, -0.313854545647458400, -0.313902018808920710, -0.313949491185628040, -0.313996962777461590, -0.314044433584302730, -0.314091903606033230, -0.314139372842533570, +-0.314186841293685460, -0.314234308959370660, -0.314281775839469700, -0.314329241933864250, -0.314376707242435720, -0.314424171765065820, -0.314471635501635090, -0.314519098452025300, +-0.314566560616117710, -0.314614021993794180, -0.314661482584935150, -0.314708942389422430, -0.314756401407137340, -0.314803859637961700, -0.314851317081775940, -0.314898773738461920, +-0.314946229607901420, -0.314993684689974850, -0.315041138984564100, -0.315088592491550520, -0.315136045210815450, -0.315183497142240700, -0.315230948285706750, -0.315278398641095470, +-0.315325848208288570, -0.315373296987166650, -0.315420744977611520, -0.315468192179504450, -0.315515638592727410, -0.315563084217160780, -0.315610529052686490, -0.315657973099185860, +-0.315705416356540700, -0.315752858824631610, -0.315800300503340350, -0.315847741392548340, -0.315895181492137410, -0.315942620801988090, -0.315990059321982260, -0.316037497052001680, +-0.316084933991926890, -0.316132370141639810, -0.316179805501021820, -0.316227240069954670, -0.316274673848319090, -0.316322106835996760, -0.316369539032869180, -0.316416970438818170, +-0.316464401053724310, -0.316511830877469480, -0.316559259909935050, -0.316606688151002900, -0.316654115600553570, -0.316701542258469030, -0.316748968124630990, -0.316796393198920110, +-0.316843817481218260, -0.316891240971406860, -0.316938663669367400, -0.316986085574981650, -0.317033506688130300, -0.317080927008695170, -0.317128346536558140, -0.317175765271599800, +-0.317223183213702080, -0.317270600362746400, -0.317318016718614650, -0.317365432281187410, -0.317412847050346610, -0.317460261025973690, -0.317507674207950510, -0.317555086596157720, +-0.317602498190477260, -0.317649908990790540, -0.317697318996979450, -0.317744728208924630, -0.317792136626508070, -0.317839544249611530, -0.317886951078115710, -0.317934357111902490, +-0.317981762350853400, -0.318029166794849940, -0.318076570443773910, -0.318123973297506080, -0.318171375355928320, -0.318218776618922510, -0.318266177086369400, -0.318313576758150810, +-0.318360975634148220, -0.318408373714243690, -0.318455770998317790, -0.318503167486252460, -0.318550563177929180, -0.318597958073229990, -0.318645352172035430, -0.318692745474227490, +-0.318740137979687700, -0.318787529688297930, -0.318834920599939010, -0.318882310714492690, -0.318929700031841070, -0.318977088551864800, -0.319024476274445800, -0.319071863199465570, +-0.319119249326806130, -0.319166634656348150, -0.319214019187973540, -0.319261402921563910, -0.319308785857001230, -0.319356167994166110, -0.319403549332940630, -0.319450929873206220, +-0.319498309614844930, -0.319545688557737460, -0.319593066701765740, -0.319640444046811800, -0.319687820592756300, -0.319735196339481280, -0.319782571286868270, -0.319829945434798810, +-0.319877318783154900, -0.319924691331817280, -0.319972063080667950, -0.320019434029588880, -0.320066804178460780, -0.320114173527165700, -0.320161542075585170, -0.320208909823601170, +-0.320256276771094530, -0.320303642917947160, -0.320351008264040730, -0.320398372809257150, -0.320445736553477250, -0.320493099496583000, -0.320540461638456010, -0.320587822978978250, +-0.320635183518030550, -0.320682543255494890, -0.320729902191253300, -0.320777260325186500, -0.320824617657176570, -0.320871974187105110, -0.320919329914853670, -0.320966684840304380, +-0.321014038963337910, -0.321061392283836400, -0.321108744801681780, -0.321156096516754860, -0.321203447428937750, -0.321250797538112030, -0.321298146844159690, -0.321345495346961610, +-0.321392843046399760, -0.321440189942356180, -0.321487536034711750, -0.321534881323348510, -0.321582225808148050, -0.321629569488992020, -0.321676912365762460, -0.321724254438340240, +-0.321771595706607350, -0.321818936170445880, -0.321866275829736700, -0.321913614684361800, -0.321960952734202890, -0.322008289979141990, -0.322055626419059940, -0.322102962053838810, +-0.322150296883360330, -0.322197630907506470, -0.322244964126158160, -0.322292296539197440, -0.322339628146505960, -0.322386958947965820, -0.322434288943457880, -0.322481618132864190, +-0.322528946516066890, -0.322576274092946810, -0.322623600863386040, -0.322670926827266280, -0.322718251984469180, -0.322765576334876900, -0.322812899878370250, -0.322860222614831380, +-0.322907544544142330, -0.322954865666183980, -0.323002185980838520, -0.323049505487987550, -0.323096824187513290, -0.323144142079296480, -0.323191459163219340, -0.323238775439163570, +-0.323286090907011270, -0.323333405566643360, -0.323380719417941890, -0.323428032460788660, -0.323475344695065730, -0.323522656120654010, -0.323569966737435710, -0.323617276545292880, +-0.323664585544106430, -0.323711893733758530, -0.323759201114130870, -0.323806507685105600, -0.323853813446563720, -0.323901118398387260, -0.323948422540458030, -0.323995725872658120, +-0.324043028394868540, -0.324090330106971360, -0.324137631008848350, -0.324184931100381660, -0.324232230381452270, -0.324279528851942280, -0.324326826511733890, -0.324374123360707980, +-0.324421419398746800, -0.324468714625732070, -0.324516009041545540, -0.324563302646069420, -0.324610595439184630, -0.324657887420773340, -0.324705178590717740, -0.324752468948898750, +-0.324799758495198650, -0.324847047229499140, -0.324894335151682420, -0.324941622261629430, -0.324988908559222410, -0.325036194044343090, -0.325083478716873710, -0.325130762576695260, +-0.325178045623689850, -0.325225327857739330, -0.325272609278725920, -0.325319889886530600, -0.325367169681035520, -0.325414448662122930, -0.325461726829673840, -0.325509004183570370, +-0.325556280723694410, -0.325603556449927780, -0.325650831362152670, -0.325698105460250020, -0.325745378744102140, -0.325792651213591240, -0.325839922868598310, -0.325887193709005540, +-0.325934463734694810, -0.325981732945548330, -0.326029001341447080, -0.326076268922273320, -0.326123535687908920, -0.326170801638236090, -0.326218066773135810, -0.326265331092490400, +-0.326312594596181670, -0.326359857284091840, -0.326407119156101930, -0.326454380212094280, -0.326501640451951070, -0.326548899875553360, -0.326596158482783390, -0.326643416273523000, +-0.326690673247654500, -0.326737929405058910, -0.326785184745618460, -0.326832439269215120, -0.326879692975731050, -0.326926945865047340, -0.326974197937046240, -0.327021449191609690, +-0.327068699628619900, -0.327115949247957950, -0.327163198049506110, -0.327210446033146750, -0.327257693198760800, -0.327304939546230630, -0.327352185075438170, -0.327399429786265180, +-0.327446673678594040, -0.327493916752305820, -0.327541159007282810, -0.327588400443407310, -0.327635641060560370, -0.327682880858624350, -0.327730119837481130, -0.327777357997013020, +-0.327824595337101120, -0.327871831857627690, -0.327919067558474720, -0.327966302439524520, -0.328013536500658060, -0.328060769741757850, -0.328108002162705640, -0.328155233763383900, +-0.328202464543673630, -0.328249694503457200, -0.328296923642616980, -0.328344151961034000, -0.328391379458590650, -0.328438606135168840, -0.328485831990650510, -0.328533057024918030, +-0.328580281237852550, -0.328627504629336260, -0.328674727199251670, -0.328721948947479860, -0.328769169873903200, -0.328816389978403570, -0.328863609260863390, -0.328910827721163810, +-0.328958045359187100, -0.329005262174815290, -0.329052478167930760, -0.329099693338414660, -0.329146907686149240, -0.329194121211016600, -0.329241333912899060, -0.329288545791677770, +-0.329335756847235150, -0.329382967079453530, -0.329430176488214040, -0.329477385073399130, -0.329524592834890770, -0.329571799772571340, -0.329619005886322040, -0.329666211176025180, +-0.329713415641562760, -0.329760619282817250, -0.329807822099669800, -0.329855024092002790, -0.329902225259698200, -0.329949425602638460, -0.329996625120704710, -0.330043823813779450, +-0.330091021681745030, -0.330138218724482620, -0.330185414941874700, -0.330232610333803240, -0.330279804900150240, -0.330326998640798120, -0.330374191555628140, -0.330421383644522610, +-0.330468574907364090, -0.330515765344033710, -0.330562954954413960, -0.330610143738386760, -0.330657331695834610, -0.330704518826638760, -0.330751705130681580, -0.330798890607845120, +-0.330846075258011910, -0.330893259081063040, -0.330940442076881060, -0.330987624245347940, -0.331034805586346240, -0.331081986099757030, -0.331129165785462920, -0.331176344643346280, +-0.331223522673288360, -0.331270699875171660, -0.331317876248878150, -0.331365051794289990, -0.331412226511289650, -0.331459400399758300, -0.331506573459578460, -0.331553745690632560, +-0.331600917092801930, -0.331648087665968980, -0.331695257410015760, -0.331742426324824920, -0.331789594410277500, -0.331836761666256140, -0.331883928092642890, -0.331931093689320220, +-0.331978258456169410, -0.332025422393072980, -0.332072585499912920, -0.332119747776571880, -0.332166909222931020, -0.332214069838872860, -0.332261229624280010, -0.332308388579033610, +-0.332355546703016260, -0.332402703996110050, -0.332449860458197520, -0.332497016089159880, -0.332544170888879720, -0.332591324857239130, -0.332638477994120660, -0.332685630299405570, +-0.332732781772976380, -0.332779932414715260, -0.332827082224504740, -0.332874231202226030, -0.332921379347761840, -0.332968526660994520, -0.333015673141805520, -0.333062818790077380, +-0.333109963605692120, -0.333157107588531950, -0.333204250738479480, -0.333251393055415960, -0.333298534539223920, -0.333345675189785970, -0.333392815006983420, -0.333439953990698870, +-0.333487092140814400, -0.333534229457212620, -0.333581365939774830, -0.333628501588383640, -0.333675636402921190, -0.333722770383270080, -0.333769903529311630, -0.333817035840928420, +-0.333864167318002610, -0.333911297960416800, -0.333958427768052350, -0.334005556740791800, -0.334052684878517800, -0.334099812181111620, -0.334146938648455960, -0.334194064280432970, +-0.334241189076924790, -0.334288313037814030, -0.334335436162982110, -0.334382558452311570, -0.334429679905685120, -0.334476800522983950, -0.334523920304090840, -0.334571039248887920, +-0.334618157357257860, -0.334665274629081910, -0.334712391064242830, -0.334759506662623160, -0.334806621424104330, -0.334853735348568940, -0.334900848435899180, -0.334947960685977320, +-0.334995072098686010, -0.335042182673906560, -0.335089292411521690, -0.335136401311413980, -0.335183509373464860, -0.335230616597556930, -0.335277722983572500, -0.335324828531394170, +-0.335371933240903360, -0.335419037111982680, -0.335466140144514480, -0.335513242338381260, -0.335560343693464600, -0.335607444209647000, -0.335654543886810870, -0.335701642724838710, +-0.335748740723612100, -0.335795837883013590, -0.335842934202925940, -0.335890029683230510, -0.335937124323810010, -0.335984218124546760, -0.336031311085322910, -0.336078403206021170, +-0.336125494486523070, -0.336172584926711200, -0.336219674526468280, -0.336266763285675730, -0.336313851204216310, -0.336360938281972280, -0.336408024518826290, -0.336455109914659820, +-0.336502194469355590, -0.336549278182795900, -0.336596361054863400, -0.336643443085439530, -0.336690524274407150, -0.336737604621648370, -0.336784684127046040, -0.336831762790481600, +-0.336878840611837760, -0.336925917590997210, -0.336972993727841450, -0.337020069022253180, -0.337067143474114760, -0.337114217083308520, -0.337161289849717110, -0.337208361773222050, +-0.337255432853706130, -0.337302503091051980, -0.337349572485141190, -0.337396641035856480, -0.337443708743080160, -0.337490775606694990, -0.337537841626582460, -0.337584906802625320, +-0.337631971134706390, -0.337679034622707040, -0.337726097266510090, -0.337773159065997970, -0.337820220021052890, -0.337867280131557700, -0.337914339397393900, -0.337961397818444250, +-0.338008455394591510, -0.338055512125717270, -0.338102568011704190, -0.338149623052434680, -0.338196677247791570, -0.338243730597656330, -0.338290783101911800, -0.338337834760440270, +-0.338384885573124570, -0.338431935539846240, -0.338478984660488090, -0.338526032934932440, -0.338573080363062160, -0.338620126944758790, -0.338667172679905040, -0.338714217568383820, +-0.338761261610076640, -0.338808304804866290, -0.338855347152635160, -0.338902388653265660, -0.338949429306640630, -0.338996469112641640, -0.339043508071151410, -0.339090546182052870, +-0.339137583445227540, -0.339184619860558260, -0.339231655427927440, -0.339278690147217840, -0.339325724018311130, -0.339372757041090160, -0.339419789215437250, -0.339466820541235280, +-0.339513851018365840, -0.339560880646711800, -0.339607909426155540, -0.339654937356579920, -0.339701964437866540, -0.339748990669898280, -0.339796016052557880, -0.339843040585727120, +-0.339890064269288690, -0.339937087103125150, -0.339984109087119290, -0.340031130221152720, -0.340078150505108310, -0.340125169938868600, -0.340172188522316340, -0.340219206255333200, +-0.340266223137802030, -0.340313239169605260, -0.340360254350625890, -0.340407268680745390, -0.340454282159846800, -0.340501294787812880, -0.340548306564525280, -0.340595317489866930, +-0.340642327563720320, -0.340689336785967860, -0.340736345156492480, -0.340783352675175840, -0.340830359341900810, -0.340877365156550320, -0.340924370119005950, -0.340971374229150690, +-0.341018377486866970, -0.341065379892037720, -0.341112381444544640, -0.341159382144270550, -0.341206381991098100, -0.341253380984910040, -0.341300379125588080, -0.341347376413015270, +-0.341394372847073910, -0.341441368427647110, -0.341488363154616450, -0.341535357027864920, -0.341582350047275330, -0.341629342212729500, -0.341676333524110310, -0.341723323981300290, +-0.341770313584181970, -0.341817302332638300, -0.341864290226550900, -0.341911277265802840, -0.341958263450276970, -0.342005248779855000, -0.342052233254419910, -0.342099216873854250, +-0.342146199638040990, -0.342193181546861790, -0.342240162600199630, -0.342287142797937090, -0.342334122139957120, -0.342381100626141410, -0.342428078256372950, -0.342475055030534270, +-0.342522030948508360, -0.342569006010176980, -0.342615980215423110, -0.342662953564129680, -0.342709926056178450, -0.342756897691452400, -0.342803868469834130, -0.342850838391206610, +-0.342897807455451560, -0.342944775662451960, -0.342991743012090460, -0.343038709504250030, -0.343085675138812380, -0.343132639915660560, -0.343179603834677100, -0.343226566895745100, +-0.343273529098746260, -0.343320490443563550, -0.343367450930080090, -0.343414410558177560, -0.343461369327739020, -0.343508327238647050, -0.343555284290784250, -0.343602240484033650, +-0.343649195818277020, -0.343696150293397450, -0.343743103909277870, -0.343790056665800150, -0.343837008562847270, -0.343883959600301880, -0.343930909778047020, -0.343977859095964460, +-0.344024807553937220, -0.344071755151847960, -0.344118701889579770, -0.344165647767014420, -0.344212592784034880, -0.344259536940523910, -0.344306480236364510, -0.344353422671438480, +-0.344400364245628920, -0.344447304958818870, -0.344494244810890080, -0.344541183801725710, -0.344588121931208410, -0.344635059199220770, -0.344681995605645940, -0.344728931150365680, +-0.344775865833263080, -0.344822799654221250, -0.344869732613121980, -0.344916664709848390, -0.344963595944283160, -0.345010526316309350, -0.345057455825808770, -0.345104384472664620, +-0.345151312256759430, -0.345198239177976430, -0.345245165236197420, -0.345292090431305490, -0.345339014763183290, -0.345385938231713980, -0.345432860836779430, -0.345479782578262730, +-0.345526703456047020, -0.345573623470014080, -0.345620542620047100, -0.345667460906028790, -0.345714378327842240, -0.345761294885369270, -0.345808210578493090, -0.345855125407096400, +-0.345902039371062340, -0.345948952470272740, -0.345995864704610740, -0.346042776073959110, -0.346089686578200940, -0.346136596217218100, -0.346183504990893840, -0.346230412899111160, +-0.346277319941752090, -0.346324226118699730, -0.346371131429836780, -0.346418035875045990, -0.346464939454210530, -0.346511842167212310, -0.346558744013934490, -0.346605644994260220, +-0.346652545108071420, -0.346699444355251240, -0.346746342735682500, -0.346793240249248290, -0.346840136895830540, -0.346887032675312460, -0.346933927587576800, -0.346980821632506760, +-0.347027714809984230, -0.347074607119892410, -0.347121498562114110, -0.347168389136532420, -0.347215278843029380, -0.347262167681488150, -0.347309055651791930, -0.347355942753822590, +-0.347402828987463440, -0.347449714352597190, -0.347496598849106720, -0.347543482476875110, -0.347590365235784400, -0.347637247125717750, -0.347684128146558410, -0.347731008298188370, +-0.347777887580490770, -0.347824765993348440, -0.347871643536644630, -0.347918520210261320, -0.347965396014081660, -0.348012270947988980, -0.348059145011865190, -0.348106018205593500, +-0.348152890529056790, -0.348199761982137870, -0.348246632564719940, -0.348293502276684990, -0.348340371117916330, -0.348387239088297160, -0.348434106187709420, -0.348480972416036480, +-0.348527837773161100, -0.348574702258966530, -0.348621565873334760, -0.348668428616149110, -0.348715290487292380, -0.348762151486647850, -0.348809011614097500, -0.348855870869524630, +-0.348902729252812070, -0.348949586763843130, -0.348996443402499800, -0.349043299168665330, -0.349090154062223100, -0.349137008083055030, -0.349183861231044390, -0.349230713506074150, +-0.349277564908027140, -0.349324415436786610, -0.349371265092234650, -0.349418113874254480, -0.349464961782729460, -0.349511808817541620, -0.349558654978574300, -0.349605500265710300, +-0.349652344678832990, -0.349699188217824360, -0.349746030882567780, -0.349792872672946120, -0.349839713588842750, -0.349886553630139600, -0.349933392796720090, -0.349980231088467150, +-0.350027068505263990, -0.350073905046992760, -0.350120740713536770, -0.350167575504779340, -0.350214409420602560, -0.350261242460889740, -0.350308074625523820, -0.350354905914387730, +-0.350401736327364770, -0.350448565864337090, -0.350495394525187960, -0.350542222309800760, -0.350589049218057610, -0.350635875249841860, -0.350682700405036350, -0.350729524683524580, +-0.350776348085188540, -0.350823170609911640, -0.350869992257577200, -0.350916813028067380, -0.350963632921265530, -0.351010451937054660, -0.351057270075317560, -0.351104087335937790, +-0.351150903718797310, -0.351197719223779630, -0.351244533850768040, -0.351291347599644700, -0.351338160470292980, -0.351384972462595870, -0.351431783576436730, -0.351478593811697770, +-0.351525403168262250, -0.351572211646013270, -0.351619019244834190, -0.351665825964607100, -0.351712631805215450, -0.351759436766542260, -0.351806240848470900, -0.351853044050883470, +-0.351899846373663450, -0.351946647816694210, -0.351993448379857960, -0.352040248063038130, -0.352087046866117640, -0.352133844788979520, -0.352180641831507210, -0.352227437993582910, +-0.352274233275090000, -0.352321027675911890, -0.352367821195930800, -0.352414613835030200, -0.352461405593093020, -0.352508196470002750, -0.352554986465641600, -0.352601775579892970, +-0.352648563812639930, -0.352695351163765880, -0.352742137633152990, -0.352788923220684780, -0.352835707926244300, -0.352882491749714920, -0.352929274690978960, -0.352976056749919720, +-0.353022837926420810, -0.353069618220364420, -0.353116397631633940, -0.353163176160112450, -0.353209953805683490, -0.353256730568229150, -0.353303506447633030, -0.353350281443778170, +-0.353397055556547990, -0.353443828785824750, -0.353490601131492000, -0.353537372593432650, -0.353584143171530360, -0.353630912865667280, -0.353677681675726880, -0.353724449601592720, +-0.353771216643147040, -0.353817982800273320, -0.353864748072854620, -0.353911512460774010, -0.353958275963915100, -0.354005038582160040, -0.354051800315392410, -0.354098561163495700, +-0.354145321126352160, -0.354192080203845350, -0.354238838395858290, -0.354285595702274580, -0.354332352122976420, -0.354379107657847410, -0.354425862306770640, -0.354472616069629650, +-0.354519368946306700, -0.354566120936685270, -0.354612872040648560, -0.354659622258080120, -0.354706371588862200, -0.354753120032878340, -0.354799867590012090, -0.354846614260145740, +-0.354893360043162910, -0.354940104938946620, -0.354986848947380140, -0.355033592068346890, -0.355080334301729250, -0.355127075647410810, -0.355173816105275040, -0.355220555675204390, +-0.355267294357082260, -0.355314032150791990, -0.355360769056217000, -0.355407505073239650, -0.355454240201743600, -0.355500974441611880, -0.355547707792728210, -0.355594440254974830, +-0.355641171828235350, -0.355687902512392910, -0.355734632307331160, -0.355781361212932410, -0.355828089229080270, -0.355874816355658260, -0.355921542592548880, -0.355968267939635600, +-0.356014992396801620, -0.356061715963930600, -0.356108438640904910, -0.356155160427608090, -0.356201881323923390, -0.356248601329734400, -0.356295320444923460, -0.356342038669374250, +-0.356388756002969930, -0.356435472445594150, -0.356482187997129220, -0.356528902657458900, -0.356575616426466680, -0.356622329304035040, -0.356669041290047560, -0.356715752384387460, +-0.356762462586938000, -0.356809171897582820, -0.356855880316204240, -0.356902587842686030, -0.356949294476911700, -0.356996000218763760, -0.357042705068125800, -0.357089409024881070, +-0.357136112088913270, -0.357182814260104730, -0.357229515538339200, -0.357276215923499840, -0.357322915415470340, -0.357369614014133200, -0.357416311719371990, -0.357463008531069990, +-0.357509704449110900, -0.357556399473377140, -0.357603093603752360, -0.357649786840120280, -0.357696479182363300, -0.357743170630365150, -0.357789861184009070, -0.357836550843178340, +-0.357883239607756640, -0.357929927477626420, -0.357976614452671370, -0.358023300532775200, -0.358069985717820390, -0.358116670007690600, -0.358163353402269120, -0.358210035901439680, +-0.358256717505084750, -0.358303398213088040, -0.358350078025332810, -0.358396756941702810, -0.358443434962080480, -0.358490112086349570, -0.358536788314393400, -0.358583463646095670, +-0.358630138081338870, -0.358676811620006700, -0.358723484261982920, -0.358770156007150070, -0.358816826855391740, -0.358863496806591410, -0.358910165860632730, -0.358956834017398200, +-0.359003501276771610, -0.359050167638636290, -0.359096833102875930, -0.359143497669373090, -0.359190161338011520, -0.359236824108674520, -0.359283485981245880, -0.359330146955608110, +-0.359376807031644980, -0.359423466209240210, -0.359470124488276420, -0.359516781868637280, -0.359563438350206210, -0.359610093932866530, -0.359656748616501990, -0.359703402400995240, +-0.359750055286229940, -0.359796707272089900, -0.359843358358457710, -0.359890008545217130, -0.359936657832251540, -0.359983306219444690, -0.360029953706679170, -0.360076600293838760, +-0.360123245980806860, -0.360169890767467250, -0.360216534653702460, -0.360263177639396410, -0.360309819724432380, -0.360356460908694220, -0.360403101192064480, -0.360449740574426970, +-0.360496379055665560, -0.360543016635662790, -0.360589653314302430, -0.360636289091468000, -0.360682923967042820, -0.360729557940910720, -0.360776191012954330, -0.360822823183057470, +-0.360869454451103970, -0.360916084816976460, -0.360962714280558650, -0.361009342841734140, -0.361055970500386620, -0.361102597256398760, -0.361149223109654470, -0.361195848060037460, +-0.361242472107430490, -0.361289095251717260, -0.361335717492781370, -0.361382338830506130, -0.361428959264775470, -0.361475578795472040, -0.361522197422479600, -0.361568815145682120, +-0.361615431964962210, -0.361662047880203670, -0.361708662891290060, -0.361755276998105170, -0.361801890200531660, -0.361848502498453460, -0.361895113891753990, -0.361941724380317130, +-0.361988333964025580, -0.362034942642763150, -0.362081550416413430, -0.362128157284860200, -0.362174763247986140, -0.362221368305675250, -0.362267972457811280, -0.362314575704277000, +-0.362361178044956270, -0.362407779479732630, -0.362454380008489510, -0.362500979631110830, -0.362547578347479300, -0.362594176157478850, -0.362640773060993350, -0.362687369057905550, +-0.362733964148099270, -0.362780558331458110, -0.362827151607865940, -0.362873743977205510, -0.362920335439360700, -0.362966925994215090, -0.363013515641652520, -0.363060104381555780, +-0.363106692213808810, -0.363153279138295040, -0.363199865154898550, -0.363246450263501940, -0.363293034463989200, -0.363339617756244350, -0.363386200140150000, -0.363432781615590120, +-0.363479362182448310, -0.363525941840608100, -0.363572520589953490, -0.363619098430367100, -0.363665675361733000, -0.363712251383935090, -0.363758826496856150, -0.363805400700380200, +-0.363851973994390680, -0.363898546378771670, -0.363945117853405890, -0.363991688418177250, -0.364038258072969860, -0.364084826817666410, -0.364131394652150890, -0.364177961576306890, +-0.364224527590018000, -0.364271092693168150, -0.364317656885640220, -0.364364220167318060, -0.364410782538085840, -0.364457343997826260, -0.364503904546423290, -0.364550464183760530, +-0.364597022909722070, -0.364643580724190560, -0.364690137627050210, -0.364736693618184450, -0.364783248697477360, -0.364829802864811760, -0.364876356120071690, -0.364922908463140680, +-0.364969459893902840, -0.365016010412240910, -0.365062560018038940, -0.365109108711181020, -0.365155656491549910, -0.365202203359029640, -0.365248749313503870, -0.365295294354856250, +-0.365341838482970750, -0.365388381697730300, -0.365434923999018890, -0.365481465386720550, -0.365528005860718150, -0.365574545420895740, -0.365621084067137000, -0.365667621799325880, +-0.365714158617345350, -0.365760694521079450, -0.365807229510411780, -0.365853763585226420, -0.365900296745406250, -0.365946828990835360, -0.365993360321397400, -0.366039890736976460, +-0.366086420237455360, -0.366132948822718180, -0.366179476492649090, -0.366226003247130890, -0.366272529086047680, -0.366319054009283110, -0.366365578016721370, -0.366412101108245240, +-0.366458623283738900, -0.366505144543085970, -0.366551664886170580, -0.366598184312875610, -0.366644702823085200, -0.366691220416683060, -0.366737737093553230, -0.366784252853578690, +-0.366830767696643470, -0.366877281622631780, -0.366923794631426440, -0.366970306722911640, -0.367016817896971050, -0.367063328153488470, -0.367109837492347930, -0.367156345913432380, +-0.367202853416626010, -0.367249360001812910, -0.367295865668875950, -0.367342370417699350, -0.367388874248166850, -0.367435377160162560, -0.367481879153569450, -0.367528380228271560, +-0.367574880384152760, -0.367621379621097200, -0.367667877938987750, -0.367714375337708620, -0.367760871817143560, -0.367807367377176730, -0.367853862017691050, -0.367900355738570720, +-0.367946848539699890, -0.367993340420961550, -0.368039831382239890, -0.368086321423418570, -0.368132810544381520, -0.368179298745012820, -0.368225786025195510, -0.368272272384813690, +-0.368318757823751620, -0.368365242341892220, -0.368411725939119750, -0.368458208615317920, -0.368504690370371040, -0.368551171204161980, -0.368597651116575000, -0.368644130107493860, +-0.368690608176802880, -0.368737085324384930, -0.368783561550124260, -0.368830036853904700, -0.368876511235610440, -0.368922984695124470, -0.368969457232331100, -0.369015928847114480, +-0.369062399539357600, -0.369108869308944710, -0.369155338155759680, -0.369201806079686720, -0.369248273080608810, -0.369294739158410270, -0.369341204312974790, -0.369387668544186810, +-0.369434131851929190, -0.369480594236086260, -0.369527055696541820, -0.369573516233180190, -0.369619975845884300, -0.369666434534538510, -0.369712892299027040, -0.369759349139232920, +-0.369805805055040460, -0.369852260046333480, -0.369898714112995800, -0.369945167254911830, -0.369991619471964460, -0.370038070764038050, -0.370084521131016920, -0.370130970572784050, +-0.370177419089223750, -0.370223866680219890, -0.370270313345656740, -0.370316759085417500, -0.370363203899386260, -0.370409647787447060, -0.370456090749484160, -0.370502532785380590, +-0.370548973895020730, -0.370595414078288390, -0.370641853335067940, -0.370688291665242480, -0.370734729068696260, -0.370781165545313650, -0.370827601094977700, -0.370874035717572710, +-0.370920469412982680, -0.370966902181091460, -0.371013334021783440, -0.371059764934941580, -0.371106194920450380, -0.371152623978194100, -0.371199052108055820, -0.371245479309919910, +-0.371291905583670310, -0.371338330929191380, -0.371384755346366220, -0.371431178835079150, -0.371477601395214130, -0.371524023026655490, -0.371570443729286440, -0.371616863502991220, +-0.371663282347653890, -0.371709700263158750, -0.371756117249388950, -0.371802533306228870, -0.371848948433562810, -0.371895362631274040, -0.371941775899246820, -0.371988188237365180, +-0.372034599645513440, -0.372081010123574860, -0.372127419671433700, -0.372173828288974000, -0.372220235976080170, -0.372266642732635320, -0.372313048558523870, -0.372359453453629750, +-0.372405857417837490, -0.372452260451030140, -0.372498662553092110, -0.372545063723907890, -0.372591463963360570, -0.372637863271334580, -0.372684261647713900, -0.372730659092382620, +-0.372777055605225120, -0.372823451186124530, -0.372869845834965300, -0.372916239551631890, -0.372962632336007460, -0.373009024187976490, -0.373055415107422910, -0.373101805094231240, +-0.373148194148284600, -0.373194582269467500, -0.373240969457664000, -0.373287355712758400, -0.373333741034634070, -0.373380125423175340, -0.373426508878266280, -0.373472891399791400, +-0.373519272987633880, -0.373565653641678150, -0.373612033361808700, -0.373658412147908790, -0.373704789999862840, -0.373751166917554890, -0.373797542900869030, -0.373843917949689740, +-0.373890292063900230, -0.373936665243385040, -0.373983037488028520, -0.374029408797714070, -0.374075779172326040, -0.374122148611748580, -0.374168517115866130, -0.374214884684562040, +-0.374261251317720700, -0.374307617015226250, -0.374353981776963110, -0.374400345602814650, -0.374446708492665370, -0.374493070446399230, -0.374539431463900900, -0.374585791545053560, +-0.374632150689741710, -0.374678508897849930, -0.374724866169261430, -0.374771222503860800, -0.374817577901532140, -0.374863932362159870, -0.374910285885627410, -0.374956638471819200, +-0.375002990120619440, -0.375049340831912600, -0.375095690605581960, -0.375142039441512140, -0.375188387339587200, -0.375234734299691730, -0.375281080321708980, -0.375327425405523550, +-0.375373769551019980, -0.375420112758081510, -0.375466455026592820, -0.375512796356437970, -0.375559136747501130, -0.375605476199666890, -0.375651814712818500, -0.375698152286840610, +-0.375744488921617710, -0.375790824617033230, -0.375837159372971630, -0.375883493189317190, -0.375929826065954380, -0.375976158002766630, -0.376022488999638470, -0.376068819056454060, +-0.376115148173098050, -0.376161476349453740, -0.376207803585405790, -0.376254129880838280, -0.376300455235635880, -0.376346779649681880, -0.376393103122861010, -0.376439425655057720, +-0.376485747246155520, -0.376532067896038880, -0.376578387604592110, -0.376624706371699370, -0.376671024197245300, -0.376717341081113210, -0.376763657023187810, -0.376809972023353700, +-0.376856286081494190, -0.376902599197493970, -0.376948911371237260, -0.376995222602608700, -0.377041532891491670, -0.377087842237770810, -0.377134150641330770, -0.377180458102054920, +-0.377226764619827900, -0.377273070194533990, -0.377319374826057430, -0.377365678514282820, -0.377411981259093590, -0.377458283060374430, -0.377504583918009950, -0.377550883831883620, +-0.377597182801880090, -0.377643480827883570, -0.377689777909778810, -0.377736074047449130, -0.377782369240779290, -0.377828663489653550, -0.377874956793956550, -0.377921249153571730, +-0.377967540568383830, -0.378013831038277020, -0.378060120563136090, -0.378106409142844440, -0.378152696777286750, -0.378198983466347730, -0.378245269209910860, -0.378291554007860800, +-0.378337837860081850, -0.378384120766458330, -0.378430402726874890, -0.378476683741215070, -0.378522963809363510, -0.378569242931204970, -0.378615521106622890, -0.378661798335502060, +-0.378708074617726650, -0.378754349953181520, -0.378800624341750100, -0.378846897783317090, -0.378893170277766870, -0.378939441824984120, -0.378985712424852350, -0.379031982077256360, +-0.379078250782080350, -0.379124518539209140, -0.379170785348526220, -0.379217051209916330, -0.379263316123264250, -0.379309580088453450, -0.379355843105368680, -0.379402105173894330, +-0.379448366293915100, -0.379494626465314570, -0.379540885687977450, -0.379587143961788160, -0.379633401286631370, -0.379679657662390700, -0.379725913088950870, -0.379772167566196250, +-0.379818421094011650, -0.379864673672280610, -0.379910925300887830, -0.379957175979718180, -0.380003425708655140, -0.380049674487583590, -0.380095922316387780, -0.380142169194952250, +-0.380188415123161650, -0.380234660100899620, -0.380280904128050930, -0.380327147204500390, -0.380373389330131590, -0.380419630504829350, -0.380465870728477980, -0.380512110000962360, +-0.380558348322166060, -0.380604585691973860, -0.380650822110270240, -0.380697057576939950, -0.380743292091866580, -0.380789525654935010, -0.380835758266029610, -0.380881989925035250, +-0.380928220631835510, -0.380974450386315220, -0.381020679188359190, -0.381066907037851070, -0.381113133934675660, -0.381159359878717410, -0.381205584869860780, -0.381251808907990600, +-0.381298031992990500, -0.381344254124745260, -0.381390475303139850, -0.381436695528057870, -0.381482914799384070, -0.381529133117003040, -0.381575350480799600, -0.381621566890657290, +-0.381667782346461150, -0.381713996848095540, -0.381760210395445330, -0.381806422988394180, -0.381852634626826950, -0.381898845310628180, -0.381945055039682680, -0.381991263813874160, +-0.382037471633087430, -0.382083678497207480, -0.382129884406117950, -0.382176089359703650, -0.382222293357849130, -0.382268496400439310, -0.382314698487357830, -0.382360899618489570, +-0.382407099793719120, -0.382453299012931290, -0.382499497276009850, -0.382545694582839600, -0.382591890933305150, -0.382638086327291400, -0.382684280764682030, -0.382730474245361940, +-0.382776666769216070, -0.382822858336128110, -0.382869048945983000, -0.382915238598665280, -0.382961427294059460, -0.383007615032050500, -0.383053801812522080, -0.383099987635359180, +-0.383146172500446690, -0.383192356407668360, -0.383238539356909160, -0.383284721348053580, -0.383330902380986660, -0.383377082455592040, -0.383423261571754710, -0.383469439729359210, +-0.383515616928290560, -0.383561793168432420, -0.383607968449669820, -0.383654142771887310, -0.383700316134969850, -0.383746488538801170, -0.383792659983266280, -0.383838830468250130, +-0.383884999993636510, -0.383931168559310420, -0.383977336165156390, -0.384023502811058960, -0.384069668496903270, -0.384115833222572980, -0.384161996987953060, -0.384208159792928610, +-0.384254321637383320, -0.384300482521202250, -0.384346642444269910, -0.384392801406471470, -0.384438959407690570, -0.384485116447812250, -0.384531272526721150, -0.384577427644302310, +-0.384623581800439480, -0.384669734995017660, -0.384715887227921550, -0.384762038499036120, -0.384808188808245130, -0.384854338155433740, -0.384900486540486860, -0.384946633963288430, +-0.384992780423723370, -0.385038925921676320, -0.385085070457032440, -0.385131214029675430, -0.385177356639490380, -0.385223498286361930, -0.385269638970175190, -0.385315778690813900, +-0.385361917448163170, -0.385408055242107640, -0.385454192072532400, -0.385500327939321320, -0.385546462842359330, -0.385592596781531630, -0.385638729756722030, -0.385684861767815630, +-0.385730992814697030, -0.385777122897250970, -0.385823252015362550, -0.385869380168915530, -0.385915507357795060, -0.385961633581886290, -0.386007758841072970, -0.386053883135240310, +-0.386100006464272890, -0.386146128828055880, -0.386192250226473130, -0.386238370659409750, -0.386284490126750480, -0.386330608628380370, -0.386376726164183340, -0.386422842734044480, +-0.386468958337848500, -0.386515072975480540, -0.386561186646824540, -0.386607299351765520, -0.386653411090188690, -0.386699521861977870, -0.386745631667018310, -0.386791740505194660, +-0.386837848376391620, -0.386883955280494410, -0.386930061217386880, -0.386976166186954180, -0.387022270189081530, -0.387068373223652730, -0.387114475290553040, -0.387160576389667170, +-0.387206676520880260, -0.387252775684076230, -0.387298873879140250, -0.387344971105957110, -0.387391067364411980, -0.387437162654388710, -0.387483256975772570, -0.387529350328448260, +-0.387575442712301040, -0.387621534127214780, -0.387667624573074630, -0.387713714049765900, -0.387759802557172460, -0.387805890095179460, -0.387851976663671830, -0.387898062262534590, +-0.387944146891651800, -0.387990230550908640, -0.388036313240189950, -0.388082394959380850, -0.388128475708365340, -0.388174555487028670, -0.388220634295255610, -0.388266712132931350, +-0.388312788999939930, -0.388358864896166500, -0.388404939821496320, -0.388451013775813430, -0.388497086759002960, -0.388543158770949800, -0.388589229811538710, -0.388635299880654980, +-0.388681368978182620, -0.388727437104006810, -0.388773504258012770, -0.388819570440084640, -0.388865635650107510, -0.388911699887966370, -0.388957763153546350, -0.389003825446731510, +-0.389049886767407090, -0.389095947115457970, -0.389142006490769410, -0.389188064893225380, -0.389234122322711210, -0.389280178779111750, -0.389326234262312280, -0.389372288772196760, +-0.389418342308650520, -0.389464394871558870, -0.389510446460805790, -0.389556497076276600, -0.389602546717856160, -0.389648595385429400, -0.389694643078881520, -0.389740689798096620, +-0.389786735542960010, -0.389832780313357000, -0.389878824109171570, -0.389924866930289100, -0.389970908776594460, -0.390016949647973010, -0.390062989544308740, -0.390109028465486950, +-0.390155066411393080, -0.390201103381911050, -0.390247139376926340, -0.390293174396323720, -0.390339208439988210, -0.390385241507805070, -0.390431273599658460, -0.390477304715433570, +-0.390523334855015890, -0.390569364018289460, -0.390615392205139630, -0.390661419415451290, -0.390707445649109860, -0.390753470905999380, -0.390799495186005210, -0.390845518489012280, +-0.390891540814906010, -0.390937562163570450, -0.390983582534891020, -0.391029601928752580, -0.391075620345040620, -0.391121637783639120, -0.391167654244433560, -0.391213669727309310, +-0.391259684232150410, -0.391305697758842330, -0.391351710307270010, -0.391397721877318420, -0.391443732468872930, -0.391489742081817690, -0.391535750716038080, -0.391581758371419510, +-0.391627765047846190, -0.391673770745203380, -0.391719775463376220, -0.391765779202249980, -0.391811781961708900, -0.391857783741638320, -0.391903784541923320, -0.391949784362449320, +-0.391995783203100360, -0.392041781063761970, -0.392087777944319150, -0.392133773844657310, -0.392179768764660600, -0.392225762704214440, -0.392271755663204320, -0.392317747641514390, +-0.392363738639030070, -0.392409728655636450, -0.392455717691218450, -0.392501705745661620, -0.392547692818850100, -0.392593678910669320, -0.392639664021004810, -0.392685648149740660, +-0.392731631296762470, -0.392777613461955170, -0.392823594645204220, -0.392869574846393840, -0.392915554065409620, -0.392961532302136870, -0.393007509556459860, -0.393053485828264100, +-0.393099461117434660, -0.393145435423856550, -0.393191408747415210, -0.393237381087995000, -0.393283352445481290, -0.393329322819759630, -0.393375292210714270, -0.393421260618230680, +-0.393467228042193920, -0.393513194482489500, -0.393559159939001700, -0.393605124411615990, -0.393651087900217470, -0.393697050404691610, -0.393743011924922730, -0.393788972460796360, +-0.393834932012197490, -0.393880890579011770, -0.393926848161123390, -0.393972804758417890, -0.394018760370780760, -0.394064714998096370, -0.394110668640250130, -0.394156621297127250, +-0.394202572968612830, -0.394248523654592400, -0.394294473354950210, -0.394340422069571870, -0.394386369798342850, -0.394432316541147520, -0.394478262297871420, -0.394524207068399630, +-0.394570150852617760, -0.394616093650410060, -0.394662035461662180, -0.394707976286259200, -0.394753916124086670, -0.394799854975028900, -0.394845792838971590, -0.394891729715799720, +-0.394937665605398950, -0.394983600507653630, -0.395029534422449310, -0.395075467349671530, -0.395121399289204700, -0.395167330240934370, -0.395213260204745680, -0.395259189180524270, +-0.395305117168154470, -0.395351044167521930, -0.395396970178511720, -0.395442895201009500, -0.395488819234899700, -0.395534742280067800, -0.395580664336399050, -0.395626585403779040, +-0.395672505482092150, -0.395718424571224030, -0.395764342671060200, -0.395810259781485150, -0.395856175902384420, -0.395902091033643270, -0.395948005175146890, -0.395993918326780940, +-0.396039830488429720, -0.396085741659979010, -0.396131651841314270, -0.396177561032320050, -0.396223469232881880, -0.396269376442885070, -0.396315282662215220, -0.396361187890756750, +-0.396407092128395310, -0.396452995375016160, -0.396498897630504940, -0.396544798894746030, -0.396590699167625130, -0.396636598449027490, -0.396682496738838760, -0.396728394036943380, +-0.396774290343227030, -0.396820185657575320, -0.396866079979872780, -0.396911973310005000, -0.396957865647857340, -0.397003756993314970, -0.397049647346263630, -0.397095536706587760, +-0.397141425074173100, -0.397187312448905210, -0.397233198830668650, -0.397279084219349150, -0.397324968614831910, -0.397370852017002620, -0.397416734425745820, -0.397462615840947160, +-0.397508496262492020, -0.397554375690265970, -0.397600254124153620, -0.397646131564040610, -0.397692008009812300, -0.397737883461354360, -0.397783757918551310, -0.397829631381288850, +-0.397875503849452750, -0.397921375322927480, -0.397967245801598760, -0.398013115285351940, -0.398058983774072670, -0.398104851267645610, -0.398150717765956400, -0.398196583268890400, +-0.398242447776333330, -0.398288311288169770, -0.398334173804285370, -0.398380035324565620, -0.398425895848896150, -0.398471755377161510, -0.398517613909247500, -0.398563471445039840, +-0.398609327984423110, -0.398655183527283070, -0.398701038073505100, -0.398746891622974500, -0.398792744175577090, -0.398838595731197400, -0.398884446289721200, -0.398930295851034340, +-0.398976144415021330, -0.399021991981567900, -0.399067838550559550, -0.399113684121881970, -0.399159528695419820, -0.399205372271058790, -0.399251214848684370, -0.399297056428182310, +-0.399342897009437200, -0.399388736592334870, -0.399434575176760680, -0.399480412762600430, -0.399526249349738790, -0.399572084938061510, -0.399617919527454400, -0.399663753117802110, +-0.399709585708990460, -0.399755417300904800, -0.399801247893430630, -0.399847077486453760, -0.399892906079858720, -0.399938733673531500, -0.399984560267357790, -0.400030385861222300, +-0.400076210455010850, -0.400122034048608850, -0.400167856641902190, -0.400213678234775490, -0.400259498827114590, -0.400305318418804900, -0.400351137009732350, -0.400396954599781580, +-0.400442771188838420, -0.400488586776788280, -0.400534401363517150, -0.400580214948909550, -0.400626027532851430, -0.400671839115228630, -0.400717649695925880, -0.400763459274828980, +-0.400809267851823410, -0.400855075426795100, -0.400900881999628700, -0.400946687570210070, -0.400992492138424750, -0.401038295704158610, -0.401084098267296300, -0.401129899827723730, +-0.401175700385326460, -0.401221499939990290, -0.401267298491600030, -0.401313096040041450, -0.401358892585200580, -0.401404688126962060, -0.401450482665211830, -0.401496276199835410, +-0.401542068730718240, -0.401587860257746340, -0.401633650780804430, -0.401679440299778310, -0.401725228814554080, -0.401771016325016330, -0.401816802831051030, -0.401862588332543740, +-0.401908372829380360, -0.401954156321445650, -0.401999938808625560, -0.402045720290805600, -0.402091500767871760, -0.402137280239708790, -0.402183058706202580, -0.402228836167238760, +-0.402274612622703250, -0.402320388072480770, -0.402366162516457350, -0.402411935954518910, -0.402457708386550210, -0.402503479812437280, -0.402549250232065610, -0.402595019645320850, +-0.402640788052088970, -0.402686555452254680, -0.402732321845703960, -0.402778087232322890, -0.402823851611996190, -0.402869614984609880, -0.402915377350049510, -0.402961138708201110, +-0.403006899058949430, -0.403052658402180520, -0.403098416737780410, -0.403144174065633800, -0.403189930385626780, -0.403235685697644900, -0.403281440001573840, -0.403327193297299600, +-0.403372945584706930, -0.403418696863681920, -0.403464447134110560, -0.403510196395877710, -0.403555944648869350, -0.403601691892971130, -0.403647438128069080, -0.403693183354048020, +-0.403738927570793990, -0.403784670778192690, -0.403830412976130090, -0.403876154164491070, -0.403921894343161610, -0.403967633512027470, -0.404013371670974620, -0.404059108819887990, +-0.404104844958653510, -0.404150580087157370, -0.404196314205284400, -0.404242047312920570, -0.404287779409951700, -0.404333510496263320, -0.404379240571741630, -0.404424969636271390, +-0.404470697689738700, -0.404516424732029760, -0.404562150763029260, -0.404607875782623420, -0.404653599790697930, -0.404699322787138770, -0.404745044771830930, -0.404790765744660500, +-0.404836485705513170, -0.404882204654274990, -0.404927922590830880, -0.404973639515066990, -0.405019355426869010, -0.405065070326123040, -0.405110784212713960, -0.405156497086527960, +-0.405202208947451130, -0.405247919795368340, -0.405293629630165740, -0.405339338451729090, -0.405385046259944090, -0.405430753054696890, -0.405476458835872410, -0.405522163603356740, +-0.405567867357036150, -0.405613570096795380, -0.405659271822520760, -0.405704972534097930, -0.405750672231413090, -0.405796370914351170, -0.405842068582798310, -0.405887765236640660, +-0.405933460875763210, -0.405979155500052090, -0.406024849109393130, -0.406070541703672020, -0.406116233282774960, -0.406161923846586890, -0.406207613394994060, -0.406253301927882560, +-0.406298989445137430, -0.406344675946644810, -0.406390361432290510, -0.406436045901960700, -0.406481729355540390, -0.406527411792915740, -0.406573093213972560, -0.406618773618597050, +-0.406664453006674200, -0.406710131378090260, -0.406755808732730930, -0.406801485070482530, -0.406847160391229980, -0.406892834694859540, -0.406938507981257410, -0.406984180250308640, +-0.407029851501899350, -0.407075521735915490, -0.407121190952242810, -0.407166859150767560, -0.407212526331374780, -0.407258192493950620, -0.407303857638381450, -0.407349521764552190, +-0.407395184872349160, -0.407440846961658170, -0.407486508032365410, -0.407532168084356050, -0.407577827117516220, -0.407623485131731800, -0.407669142126889150, -0.407714798102873200, +-0.407760453059570260, -0.407806106996866150, -0.407851759914647230, -0.407897411812798480, -0.407943062691206170, -0.407988712549756660, -0.408034361388334930, -0.408080009206827350, +-0.408125656005119690, -0.408171301783098290, -0.408216946540648270, -0.408262590277655880, -0.408308232994006980, -0.408353874689587950, -0.408399515364283820, -0.408445155017980900, +-0.408490793650565060, -0.408536431261922680, -0.408582067851938790, -0.408627703420499750, -0.408673337967491830, -0.408718971492800180, -0.408764603996311090, -0.408810235477910510, +-0.408855865937484300, -0.408901495374918880, -0.408947123790099290, -0.408992751182911900, -0.409038377553243020, -0.409084002900977790, -0.409129627226002600, -0.409175250528203300, +-0.409220872807466270, -0.409266494063676710, -0.409312114296720870, -0.409357733506484740, -0.409403351692854690, -0.409448968855715860, -0.409494584994954610, -0.409540200110456890, +-0.409585814202109100, -0.409631427269796340, -0.409677039313405040, -0.409722650332821510, -0.409768260327930960, -0.409813869298619790, -0.409859477244773900, -0.409905084166279350, +-0.409950690063022480, -0.409996294934888480, -0.410041898781763780, -0.410087501603534690, -0.410133103400086460, -0.410178704171305470, -0.410224303917077760, -0.410269902637289630, +-0.410315500331826340, -0.410361097000574330, -0.410406692643419610, -0.410452287260248520, -0.410497880850946300, -0.410543473415399370, -0.410589064953493790, -0.410634655465115960, +-0.410680244950151040, -0.410725833408485560, -0.410771420840005840, -0.410817007244597240, -0.410862592622146080, -0.410908176972538450, -0.410953760295660770, -0.410999342591398250, +-0.411044923859637420, -0.411090504100264260, -0.411136083313165260, -0.411181661498225660, -0.411227238655331890, -0.411272814784370060, -0.411318389885226510, -0.411363963957786630, +-0.411409537001936890, -0.411455109017563660, -0.411500680004552260, -0.411546249962789160, -0.411591818892160400, -0.411637386792552130, -0.411682953663850830, -0.411728519505941690, +-0.411774084318711260, -0.411819648102046020, -0.411865210855831280, -0.411910772579953510, -0.411956333274298760, -0.412001892938753670, -0.412047451573203380, -0.412093009177534440, +-0.412138565751633050, -0.412184121295385620, -0.412229675808677480, -0.412275229291395100, -0.412320781743424680, -0.412366333164652770, -0.412411883554964550, -0.412457432914246640, +-0.412502981242385550, -0.412548528539266660, -0.412594074804776390, -0.412639620038800950, -0.412685164241226420, -0.412730707411939460, -0.412776249550825260, -0.412821790657770470, +-0.412867330732661570, -0.412912869775383990, -0.412958407785824210, -0.413003944763868420, -0.413049480709403170, -0.413095015622313820, -0.413140549502486910, -0.413186082349808640, +-0.413231614164165590, -0.413277144945443040, -0.413322674693527680, -0.413368203408305600, -0.413413731089663450, -0.413459257737486600, -0.413504783351661520, -0.413550307932074920, +-0.413595831478612170, -0.413641353991159810, -0.413686875469604090, -0.413732395913831600, -0.413777915323727650, -0.413823433699178960, -0.413868951040071710, -0.413914467346292450, +-0.413959982617726600, -0.414005496854260800, -0.414051010055781320, -0.414096522222174630, -0.414142033353326330, -0.414187543449122840, -0.414233052509450970, -0.414278560534196040, +-0.414324067523244740, -0.414369573476483230, -0.414415078393797760, -0.414460582275075100, -0.414506085120200480, -0.414551586929060690, -0.414597087701542360, -0.414642587437530850, +-0.414688086136912880, -0.414733583799574760, -0.414779080425403010, -0.414824576014283190, -0.414870070566101920, -0.414915564080745480, -0.414961056558100560, -0.415006547998052530, +-0.415052038400488210, -0.415097527765293740, -0.415143016092355880, -0.415188503381560050, -0.415233989632792950, -0.415279474845941350, -0.415324959020890620, -0.415370442157527440, +-0.415415924255738260, -0.415461405315409200, -0.415506885336427050, -0.415552364318677260, -0.415597842262046550, -0.415643319166421670, -0.415688795031688100, -0.415734269857732490, +-0.415779743644441260, -0.415825216391701060, -0.415870688099397420, -0.415916158767417050, -0.415961628395646650, -0.416007096983971870, -0.416052564532279230, -0.416098031040455290, +-0.416143496508386220, -0.416188960935958810, -0.416234424323058570, -0.416279886669572330, -0.416325347975386730, -0.416370808240387360, -0.416416267464460980, -0.416461725647493950, +-0.416507182789372990, -0.416552638889983670, -0.416598093949212770, -0.416643547966946640, -0.416689000943071990, -0.416734452877474460, -0.416779903770040820, -0.416825353620657420, +-0.416870802429211040, -0.416916250195587200, -0.416961696919672780, -0.417007142601354520, -0.417052587240518020, -0.417098030837049990, -0.417143473390836960, -0.417188914901765180, +-0.417234355369721530, -0.417279794794591650, -0.417325233176262190, -0.417370670514620120, -0.417416106809550940, -0.417461542060941490, -0.417506976268678220, -0.417552409432647880, +-0.417597841552736100, -0.417643272628829780, -0.417688702660815200, -0.417734131648579310, -0.417779559592007690, -0.417824986490987150, -0.417870412345404170, -0.417915837155145520, +-0.417961260920096890, -0.418006683640145150, -0.418052105315177060, -0.418097525945078320, -0.418142945529735800, -0.418188364069035870, -0.418233781562865000, -0.418279198011110130, +-0.418324613413656840, -0.418370027770392060, -0.418415441081202600, -0.418460853345974100, -0.418506264564593500, -0.418551674736947210, -0.418597083862922160, -0.418642491942403940, +-0.418687898975279580, -0.418733304961435790, -0.418778709900758380, -0.418824113793134220, -0.418869516638449730, -0.418914918436591450, -0.418960319187446310, -0.419005718890899990, +-0.419051117546839320, -0.419096515155151280, -0.419141911715721520, -0.419187307228437000, -0.419232701693184220, -0.419278095109850090, -0.419323487478320320, -0.419368878798481840, +-0.419414269070221170, -0.419459658293425190, -0.419505046467979700, -0.419550433593771530, -0.419595819670687380, -0.419641204698613990, -0.419686588677437240, -0.419731971607044010, +-0.419777353487321260, -0.419822734318154700, -0.419868114099431310, -0.419913492831037630, -0.419958870512860240, -0.420004247144786070, -0.420049622726700820, -0.420094997258491590, +-0.420140370740045230, -0.420185743171247570, -0.420231114551985530, -0.420276484882145750, -0.420321854161615100, -0.420367222390279460, -0.420412589568025740, -0.420457955694740540, +-0.420503320770310830, -0.420548684794622480, -0.420594047767562370, -0.420639409689017140, -0.420684770558873820, -0.420730130377018170, -0.420775489143337180, -0.420820846857717870, +-0.420866203520046000, -0.420911559130208670, -0.420956913688092460, -0.421002267193584300, -0.421047619646570110, -0.421092971046936880, -0.421138321394571250, -0.421183670689360190, +-0.421229018931189520, -0.421274366119946340, -0.421319712255517230, -0.421365057337789230, -0.421410401366648200, -0.421455744341981190, -0.421501086263675160, -0.421546427131616050, +-0.421591766945690890, -0.421637105705786270, -0.421682443411788950, -0.421727780063585860, -0.421773115661062960, -0.421818450204107240, -0.421863783692605850, -0.421909116126444550, +-0.421954447505510480, -0.421999777829690280, -0.422045107098871000, -0.422090435312938610, -0.422135762471780080, -0.422181088575282190, -0.422226413623331960, -0.422271737615815320, +-0.422317060552619310, -0.422362382433630670, -0.422407703258736440, -0.422453023027822620, -0.422498341740776160, -0.422543659397484280, -0.422588975997832850, -0.422634291541709010, +-0.422679606028999400, -0.422724919459590790, -0.422770231833370260, -0.422815543150223790, -0.422860853410038430, -0.422906162612701360, -0.422951470758098470, -0.422996777846116890, +-0.423042083876643380, -0.423087388849565090, -0.423132692764767890, -0.423177995622138980, -0.423223297421565060, -0.423268598162933330, -0.423313897846129660, -0.423359196471041310, +-0.423404494037554920, -0.423449790545557700, -0.423495085994935570, -0.423540380385575790, -0.423585673717365440, -0.423630965990190460, -0.423676257203938140, -0.423721547358495100, +-0.423766836453748630, -0.423812124489584720, -0.423857411465890400, -0.423902697382552600, -0.423947982239458510, -0.423993266036494010, -0.424038548773546300, -0.424083830450502300, +-0.424129111067249100, -0.424174390623672680, -0.424219669119660300, -0.424264946555099160, -0.424310222929875300, -0.424355498243875810, -0.424400772496987600, -0.424446045689097500, +-0.424491317820092640, -0.424536588889859070, -0.424581858898284090, -0.424627127845254800, -0.424672395730657350, -0.424717662554378870, -0.424762928316306240, -0.424808193016326660, +-0.424853456654326220, -0.424898719230192180, -0.424943980743811290, -0.424989241195070870, -0.425034500583856940, -0.425079758910056780, -0.425125016173557190, -0.425170272374245480, +-0.425215527512007700, -0.425260781586731080, -0.425306034598302910, -0.425351286546609250, -0.425396537431537380, -0.425441787252974160, -0.425487036010806510, -0.425532283704921630, +-0.425577530335205680, -0.425622775901545850, -0.425668020403829510, -0.425713263841942690, -0.425758506215772770, -0.425803747525206560, -0.425848987770131360, -0.425894226950433270, +-0.425939465065999670, -0.425984702116717350, -0.426029938102473750, -0.426075173023154840, -0.426120406878648050, -0.426165639668840190, -0.426210871393618680, -0.426256102052869570, +-0.426301331646480150, -0.426346560174337860, -0.426391787636328790, -0.426437014032340190, -0.426482239362259100, -0.426527463625972820, -0.426572686823367460, -0.426617908954330380, +-0.426663130018748560, -0.426708350016509250, -0.426753568947498720, -0.426798786811604270, -0.426844003608712830, -0.426889219338711770, -0.426934434001487280, -0.426979647596926690, +-0.427024860124917420, -0.427070071585345550, -0.427115281978098500, -0.427160491303063270, -0.427205699560126830, -0.427250906749176540, -0.427296112870098550, -0.427341317922780290, +-0.427386521907109130, -0.427431724822971320, -0.427476926670254110, -0.427522127448844660, -0.427567327158630270, -0.427612525799497160, -0.427657723371332680, -0.427702919874023980, +-0.427748115307458320, -0.427793309671521960, -0.427838502966102370, -0.427883695191086540, -0.427928886346361840, -0.427974076431814510, -0.428019265447331990, -0.428064453392801750, +-0.428109640268109940, -0.428154826073144030, -0.428200010807791080, -0.428245194471938100, -0.428290377065472520, -0.428335558588280600, -0.428380739040249760, -0.428425918421267480, +-0.428471096731220020, -0.428516273969994810, -0.428561450137478930, -0.428606625233559860, -0.428651799258123740, -0.428696972211058180, -0.428742144092250200, -0.428787314901587220, +-0.428832484638955570, -0.428877653304242710, -0.428922820897335690, -0.428967987418122090, -0.429013152866488060, -0.429058317242321130, -0.429103480545508840, -0.429148642775937450, +-0.429193803933494490, -0.429238964018066940, -0.429284123029542440, -0.429329280967807200, -0.429374437832748810, -0.429419593624254250, -0.429464748342211160, -0.429509901986505790, +-0.429555054557025640, -0.429600206053657900, -0.429645356476289990, -0.429690505824808330, -0.429735654099100420, -0.429780801299053720, -0.429825947424554660, -0.429871092475490710, +-0.429916236451749030, -0.429961379353216770, -0.430006521179781440, -0.430051661931329430, -0.430096801607748270, -0.430141940208925490, -0.430187077734747460, -0.430232214185101770, +-0.430277349559875510, -0.430322483858956270, -0.430367617082230420, -0.430412749229585560, -0.430457880300908810, -0.430503010296087730, -0.430548139215008780, -0.430593267057559460, +-0.430638393823626950, -0.430683519513098860, -0.430728644125861590, -0.430773767661802700, -0.430818890120809820, -0.430864011502769260, -0.430909131807568730, -0.430954251035095330, +-0.430999369185236290, -0.431044486257879280, -0.431089602252910600, -0.431134717170217950, -0.431179831009688930, -0.431224943771209900, -0.431270055454668510, -0.431315166059951960, +-0.431360275586947890, -0.431405384035542790, -0.431450491405624190, -0.431495597697079790, -0.431540702909795960, -0.431585807043660400, -0.431630910098560310, -0.431676012074382940, +-0.431721112971015950, -0.431766212788345760, -0.431811311526260070, -0.431856409184646520, -0.431901505763391480, -0.431946601262382710, -0.431991695681507410, -0.432036789020653340, +-0.432081881279706810, -0.432126972458555640, -0.432172062557087010, -0.432217151575188640, -0.432262239512747000, -0.432307326369649750, -0.432352412145784180, -0.432397496841037950, +-0.432442580455297650, -0.432487662988450820, -0.432532744440385310, -0.432577824810987500, -0.432622904100145090, -0.432667982307745500, -0.432713059433675880, -0.432758135477824050, +-0.432803210440076470, -0.432848284320320850, -0.432893357118444950, -0.432938428834335250, -0.432983499467879510, -0.433028569018964970, -0.433073637487479400, -0.433118704873309390, +-0.433163771176342580, -0.433208836396466350, -0.433253900533568440, -0.433298963587535340, -0.433344025558254850, -0.433389086445614360, -0.433434146249501500, -0.433479204969802860, +-0.433524262606406200, -0.433569319159199330, -0.433614374628068730, -0.433659429012902220, -0.433704482313587100, -0.433749534530011190, -0.433794585662061030, -0.433839635709624470, +-0.433884684672588780, -0.433929732550841770, -0.433974779344270030, -0.434019825052761320, -0.434064869676203060, -0.434109913214483060, -0.434154955667487850, -0.434199997035105260, +-0.434245037317223080, -0.434290076513727920, -0.434335114624507520, -0.434380151649449380, -0.434425187588440840, -0.434470222441369740, -0.434515256208122700, -0.434560288888587500, +-0.434605320482651940, -0.434650350990202720, -0.434695380411127650, -0.434740408745314060, -0.434785435992649900, -0.434830462153021740, -0.434875487226317410, -0.434920511212424420, +-0.434965534111230460, -0.435010555922622330, -0.435055576646487810, -0.435100596282714300, -0.435145614831189740, -0.435190632291800720, -0.435235648664435150, -0.435280663948980850, +-0.435325678145324470, -0.435370691253353930, -0.435415703272956640, -0.435460714204020050, -0.435505724046432120, -0.435550732800079500, -0.435595740464850000, -0.435640747040631600, +-0.435685752527310900, -0.435730756924775810, -0.435775760232913870, -0.435820762451612890, -0.435865763580759620, -0.435910763620241950, -0.435955762569947340, -0.436000760429763770, +-0.436045757199577830, -0.436090752879277570, -0.436135747468750390, -0.436180740967884230, -0.436225733376565840, -0.436270724694683140, -0.436315714922124010, -0.436360704058775140, +-0.436405692104524570, -0.436450679059259770, -0.436495664922868620, -0.436540649695237980, -0.436585633376255670, -0.436630615965809320, -0.436675597463786760, -0.436720577870074840, +-0.436765557184561500, -0.436810535407134220, -0.436855512537681070, -0.436900488576088710, -0.436945463522245110, -0.436990437376038270, -0.437035410137354920, -0.437080381806083000, +-0.437125352382110200, -0.437170321865324010, -0.437215290255612400, -0.437260257552862130, -0.437305223756961290, -0.437350188867797750, -0.437395152885258320, -0.437440115809231030, +-0.437485077639603430, -0.437530038376263590, -0.437574998019098220, -0.437619956567995350, -0.437664914022842580, -0.437709870383527930, -0.437754825649938230, -0.437799779821961440, +-0.437844732899485220, -0.437889684882397550, -0.437934635770585280, -0.437979585563936400, -0.438024534262339000, -0.438069481865679840, -0.438114428373846950, -0.438159373786728030, +-0.438204318104210680, -0.438249261326182860, -0.438294203452531560, -0.438339144483144760, -0.438384084417910440, -0.438429023256715570, -0.438473960999448080, -0.438518897645995720, +-0.438563833196246530, -0.438608767650087330, -0.438653701007406250, -0.438698633268090890, -0.438743564432029330, -0.438788494499108510, -0.438833423469216390, -0.438878351342240740, +-0.438923278118069640, -0.438968203796589910, -0.439013128377689690, -0.439058051861257010, -0.439102974247178870, -0.439147895535343220, -0.439192815725637900, -0.439237734817950860, +-0.439282652812169160, -0.439327569708180820, -0.439372485505873490, -0.439417400205135420, -0.439462313805853430, -0.439507226307915610, -0.439552137711209770, -0.439597048015623990, +-0.439641957221045150, -0.439686865327361450, -0.439731772334460980, -0.439776678242230710, -0.439821583050558680, -0.439866486759332760, -0.439911389368440600, -0.439956290877770330, +-0.440001191287208990, -0.440046090596644620, -0.440090988805965480, -0.440135885915058420, -0.440180781923811660, -0.440225676832112940, -0.440270570639850420, -0.440315463346911130, +-0.440360354953183100, -0.440405245458554250, -0.440450134862912620, -0.440495023166145310, -0.440539910368140440, -0.440584796468785790, -0.440629681467969550, -0.440674565365578700, +-0.440719448161501380, -0.440764329855625910, -0.440809210447839220, -0.440854089938029440, -0.440898968326084490, -0.440943845611892150, -0.440988721795340540, -0.441033596876316710, +-0.441078470854708920, -0.441123343730405350, -0.441168215503293050, -0.441213086173260160, -0.441257955740194550, -0.441302824203984480, -0.441347691564516980, -0.441392557821680190, +-0.441437422975362040, -0.441482287025450730, -0.441527149971833290, -0.441572011814397980, -0.441616872553032670, -0.441661732187625560, -0.441706590718063670, -0.441751448144235390, +-0.441796304466028860, -0.441841159683331150, -0.441886013796030540, -0.441930866804014890, -0.441975718707172500, -0.442020569505390370, -0.442065419198556850, -0.442110267786559820, +-0.442155115269287470, -0.442199961646626890, -0.442244806918466460, -0.442289651084694040, -0.442334494145197880, -0.442379336099865070, -0.442424176948583880, -0.442469016691242720, +-0.442513855327728580, -0.442558692857929810, -0.442603529281734300, -0.442648364599029950, -0.442693198809705090, -0.442738031913646910, -0.442782863910743560, -0.442827694800883460, +-0.442872524583953760, -0.442917353259842770, -0.442962180828438360, -0.443007007289628880, -0.443051832643301500, -0.443096656889344580, -0.443141480027645970, -0.443186302058094060, +-0.443231122980575990, -0.443275942794980120, -0.443320761501194430, -0.443365579099107180, -0.443410395588605620, -0.443455210969578070, -0.443500025241912900, -0.443544838405497240, +-0.443589650460219480, -0.443634461405967630, -0.443679271242629570, -0.443724079970093780, -0.443768887588247400, -0.443813694096978790, -0.443858499496176280, -0.443903303785727230, +-0.443948106965519840, -0.443992909035442200, -0.444037709995382720, -0.444082509845228510, -0.444127308584868100, -0.444172106214189790, -0.444216902733080790, -0.444261698141429520, +-0.444306492439124010, -0.444351285626052310, -0.444396077702102770, -0.444440868667162650, -0.444485658521120370, -0.444530447263864310, -0.444575234895281720, -0.444620021415261080, +-0.444664806823690360, -0.444709591120458050, -0.444754374305451390, -0.444799156378558710, -0.444843937339668210, -0.444888717188668240, -0.444933495925446070, -0.444978273549890170, +-0.445023050061888580, -0.445067825461329780, -0.445112599748101020, -0.445157372922090730, -0.445202144983187440, -0.445246915931278350, -0.445291685766252000, -0.445336454487996470, +-0.445381222096399740, -0.445425988591350410, -0.445470753972735670, -0.445515518240444050, -0.445560281394364040, -0.445605043434382900, -0.445649804360389200, -0.445694564172270940, +-0.445739322869916690, -0.445784080453213770, -0.445828836922050610, -0.445873592276315340, -0.445918346515896510, -0.445963099640681430, -0.446007851650558620, -0.446052602545416120, +-0.446097352325142580, -0.446142100989625200, -0.446186848538752570, -0.446231594972413270, -0.446276340290494570, -0.446321084492884990, -0.446365827579472680, -0.446410569550145850, +-0.446455310404792970, -0.446500050143301460, -0.446544788765559750, -0.446589526271456540, -0.446634262660879080, -0.446678997933715960, -0.446723732089855330, -0.446768465129185830, +-0.446813197051594720, -0.446857927856970650, -0.446902657545202090, -0.446947386116176570, -0.446992113569782520, -0.447036839905908200, -0.447081565124441800, -0.447126289225271920, +-0.447171012208285870, -0.447215734073372280, -0.447260454820419760, -0.447305174449315720, -0.447349892959948760, -0.447394610352207070, -0.447439326625979240, -0.447484041781152640, +-0.447528755817616030, -0.447573468735257440, -0.447618180533965630, -0.447662891213627960, -0.447707600774133070, -0.447752309215369180, -0.447797016537224920, -0.447841722739587720, +-0.447886427822346170, -0.447931131785389010, -0.447975834628603580, -0.448020536351878550, -0.448065236955102250, -0.448109936438162770, -0.448154634800948910, -0.448199332043348050, +-0.448244028165248830, -0.448288723166540000, -0.448333417047108940, -0.448378109806844280, -0.448422801445634400, -0.448467491963367940, -0.448512181359932320, -0.448556869635216240, +-0.448601556789107960, -0.448646242821496230, -0.448690927732268490, -0.448735611521313420, -0.448780294188519340, -0.448824975733774890, -0.448869656156967610, -0.448914335457986200, +-0.448959013636719360, -0.449003690693054570, -0.449048366626880580, -0.449093041438085650, -0.449137715126558530, -0.449182387692186710, -0.449227059134858940, -0.449271729454463480, +-0.449316398650889130, -0.449361066724023370, -0.449405733673754970, -0.449450399499972230, -0.449495064202563850, -0.449539727781417490, -0.449584390236421720, -0.449629051567465410, +-0.449673711774436100, -0.449718370857222490, -0.449763028815712950, -0.449807685649795840, -0.449852341359359920, -0.449896995944292720, -0.449941649404483060, -0.449986301739819680, +-0.450030952950190130, -0.450075603035483160, -0.450120251995587250, -0.450164899830391100, -0.450209546539782290, -0.450254192123649590, -0.450298836581881410, -0.450343479914366570, +-0.450388122120992610, -0.450432763201648380, -0.450477403156222200, -0.450522041984602940, -0.450566679686678130, -0.450611316262336690, -0.450655951711467330, -0.450700586033957680, +-0.450745219229696570, -0.450789851298572410, -0.450834482240473620, -0.450879112055289020, -0.450923740742906250, -0.450968368303214130, -0.451012994736101460, -0.451057620041455940, +-0.451102244219166340, -0.451146867269121180, -0.451191489191209220, -0.451236109985318160, -0.451280729651336750, -0.451325348189153600, -0.451369965598657440, -0.451414581879735990, +-0.451459197032278050, -0.451503811056172160, -0.451548423951307120, -0.451593035717570590, -0.451637646354851540, -0.451682255863038730, -0.451726864242019910, -0.451771471491683900, +-0.451816077611919220, -0.451860682602614750, -0.451905286463658130, -0.451949889194938340, -0.451994490796343850, -0.452039091267763480, -0.452083690609084990, -0.452128288820197290, +-0.452172885900988920, -0.452217481851348630, -0.452262076671164300, -0.452306670360324790, -0.452351262918718970, -0.452395854346234580, -0.452440444642760620, -0.452485033808185500, +-0.452529621842397810, -0.452574208745286420, -0.452618794516739200, -0.452663379156644900, -0.452707962664892600, -0.452752545041369970, -0.452797126285966020, -0.452841706398569240, +-0.452886285379068550, -0.452930863227351820, -0.452975439943307860, -0.453020015526825360, -0.453064589977793200, -0.453109163296099130, -0.453153735481632180, -0.453198306534280890, +-0.453242876453934240, -0.453287445240480040, -0.453332012893807150, -0.453376579413804660, -0.453421144800360330, -0.453465709053363140, -0.453510272172701680, -0.453554834158264530, +-0.453599395009940680, -0.453643954727617980, -0.453688513311185370, -0.453733070760531820, -0.453777627075545250, -0.453822182256114650, -0.453866736302128540, -0.453911289213476010, +-0.453955840990044880, -0.454000391631724120, -0.454044941138402380, -0.454089489509968690, -0.454134036746310870, -0.454178582847317940, -0.454223127812878600, -0.454267671642881840, +-0.454312214337215470, -0.454356755895768570, -0.454401296318430180, -0.454445835605088170, -0.454490373755631500, -0.454534910769949010, -0.454579446647929540, -0.454623981389461140, +-0.454668514994432730, -0.454713047462733060, -0.454757578794251160, -0.454802108988874910, -0.454846638046493390, -0.454891165966995250, -0.454935692750269630, -0.454980218396204390, +-0.455024742904688580, -0.455069266275611280, -0.455113788508860470, -0.455158309604325180, -0.455202829561894120, -0.455247348381455970, -0.455291866062899840, -0.455336382606113640, +-0.455380898010986520, -0.455425412277407520, -0.455469925405264600, -0.455514437394446860, -0.455558948244843050, -0.455603457956342270, -0.455647966528832440, -0.455692473962202690, +-0.455736980256341740, -0.455781485411138780, -0.455825989426481670, -0.455870492302259570, -0.455914994038361280, -0.455959494634675890, -0.456003994091091380, -0.456048492407496840, +-0.456092989583781530, -0.456137485619833300, -0.456181980515541370, -0.456226474270794490, -0.456270966885481410, -0.456315458359491330, -0.456359948692712240, -0.456404437885033210, +-0.456448925936343510, -0.456493412846531110, -0.456537898615485160, -0.456582383243094470, -0.456626866729248240, -0.456671349073834440, -0.456715830276742230, -0.456760310337860850, +-0.456804789257078350, -0.456849267034283860, -0.456893743669366190, -0.456938219162214110, -0.456982693512716920, -0.457027166720762660, -0.457071638786240410, -0.457116109709039490, +-0.457160579489047870, -0.457205048126154810, -0.457249515620249130, -0.457293981971220060, -0.457338447178955660, -0.457382911243345120, -0.457427374164277310, -0.457471835941641480, +-0.457516296575325660, -0.457560756065219070, -0.457605214411210600, -0.457649671613189480, -0.457694127671043840, -0.457738582584662820, -0.457783036353935750, -0.457827488978750700, +-0.457871940458996930, -0.457916390794563310, -0.457960839985338760, -0.458005288031212430, -0.458049734932072520, -0.458094180687808270, -0.458138625298308950, -0.458183068763462710, +-0.458227511083158730, -0.458271952257286060, -0.458316392285733840, -0.458360831168390270, -0.458405268905144600, -0.458449705495885820, -0.458494140940503110, -0.458538575238884640, +-0.458583008390919760, -0.458627440396497390, -0.458671871255506790, -0.458716300967836110, -0.458760729533374660, -0.458805156952011790, -0.458849583223635670, -0.458894008348135540, +-0.458938432325400440, -0.458982855155319220, -0.459027276837781270, -0.459071697372674730, -0.459116116759888950, -0.459160534999313310, -0.459204952090835890, -0.459249368034346070, +-0.459293782829732880, -0.459338196476885620, -0.459382608975692440, -0.459427020326042770, -0.459471430527825960, -0.459515839580930120, -0.459560247485244710, -0.459604654240658720, +-0.459649059847061060, -0.459693464304341160, -0.459737867612387160, -0.459782269771088550, -0.459826670780334620, -0.459871070640013650, -0.459915469350014980, -0.459959866910227670, +-0.460004263320541060, -0.460048658580843370, -0.460093052691024070, -0.460137445650972140, -0.460181837460576950, -0.460226228119726850, -0.460270617628311120, -0.460315005986218880, +-0.460359393193339460, -0.460403779249561220, -0.460448164154773520, -0.460492547908865790, -0.460536930511726340, -0.460581311963244480, -0.460625692263309410, -0.460670071411810100, +-0.460714449408635980, -0.460758826253675370, -0.460803201946817680, -0.460847576487952380, -0.460891949876967740, -0.460936322113753240, -0.460980693198197900, -0.461025063130191260, +-0.461069431909621570, -0.461113799536378320, -0.461158166010350530, -0.461202531331427690, -0.461246895499498210, -0.461291258514451410, -0.461335620376176540, -0.461379981084562960, +-0.461424340639499050, -0.461468699040874290, -0.461513056288578140, -0.461557412382499030, -0.461601767322526340, -0.461646121108549250, -0.461690473740457240, -0.461734825218138630, +-0.461779175541482960, -0.461823524710379410, -0.461867872724717410, -0.461912219584385330, -0.461956565289272700, -0.462000909839268610, -0.462045253234262710, -0.462089595474143240, +-0.462133936558799810, -0.462178276488121930, -0.462222615261997980, -0.462266952880317440, -0.462311289342969560, -0.462355624649843480, -0.462399958800828680, -0.462444291795813590, +-0.462488623634687790, -0.462532954317340820, -0.462577283843661090, -0.462621612213538150, -0.462665939426861180, -0.462710265483519730, -0.462754590383402220, -0.462798914126398230, +-0.462843236712397020, -0.462887558141288010, -0.462931878412959800, -0.462976197527301850, -0.463020515484203420, -0.463064832283554110, -0.463109147925242270, -0.463153462409157610, +-0.463197775735189670, -0.463242087903226910, -0.463286398913158930, -0.463330708764874980, -0.463375017458264200, -0.463419324993216310, -0.463463631369619710, -0.463507936587364000, +-0.463552240646338880, -0.463596543546432700, -0.463640845287535240, -0.463685145869535630, -0.463729445292323570, -0.463773743555787490, -0.463818040659817020, -0.463862336604301480, +-0.463906631389130520, -0.463950925014192550, -0.463995217479377280, -0.464039508784573950, -0.464083798929672280, -0.464128087914560670, -0.464172375739128900, -0.464216662403266530, +-0.464260947906862120, -0.464305232249805360, -0.464349515431985550, -0.464393797453292290, -0.464438078313614170, -0.464482358012840820, -0.464526636550861630, -0.464570913927566160, +-0.464615190142843080, -0.464659465196582020, -0.464703739088672300, -0.464748011819003600, -0.464792283387464480, -0.464836553793944670, -0.464880823038333830, -0.464925091120520610, +-0.464969358040394630, -0.465013623797845220, -0.465057888392761800, -0.465102151825034000, -0.465146414094550490, -0.465190675201200890, -0.465234935144875020, -0.465279193925461410, +-0.465323451542849820, -0.465367707996929610, -0.465411963287590490, -0.465456217414721100, -0.465500470378211180, -0.465544722177950070, -0.465588972813827550, -0.465633222285732230, +-0.465677470593553800, -0.465721717737181740, -0.465765963716505750, -0.465810208531414470, -0.465854452181797660, -0.465898694667545080, -0.465942935988545410, -0.465987176144688430, +-0.466031415135863440, -0.466075652961959960, -0.466119889622867770, -0.466164125118475380, -0.466208359448672730, -0.466252592613349560, -0.466296824612394520, -0.466341055445697430, +-0.466385285113147700, -0.466429513614635140, -0.466473740950048400, -0.466517967119277340, -0.466562192122211340, -0.466606415958740250, -0.466650638628752720, -0.466694860132138570, +-0.466739080468787320, -0.466783299638588720, -0.466827517641431490, -0.466871734477205480, -0.466915950145800560, -0.466960164647105320, -0.467004377981009690, -0.467048590147403130, +-0.467092801146175460, -0.467137010977215380, -0.467181219640412810, -0.467225427135657180, -0.467269633462838340, -0.467313838621845060, -0.467358042612567190, -0.467402245434894230, +-0.467446447088716020, -0.467490647573921280, -0.467534846890399920, -0.467579045038041870, -0.467623242016735830, -0.467667437826371660, -0.467711632466838890, -0.467755825938027000, +-0.467800018239826030, -0.467844209372124560, -0.467888399334812580, -0.467932588127779990, -0.467976775750915560, -0.468020962204109160, -0.468065147487250370, -0.468109331600229110, +-0.468153514542934080, -0.468197696315255320, -0.468241876917082300, -0.468286056348305000, -0.468330234608812120, -0.468374411698493700, -0.468418587617239260, -0.468462762364938720, +-0.468506935941480850, -0.468551108346755670, -0.468595279580653110, -0.468639449643061980, -0.468683618533872190, -0.468727786252973400, -0.468771952800255130, -0.468816118175607310, +-0.468860282378918860, -0.468904445410079700, -0.468948607268979800, -0.468992767955508040, -0.469036927469554330, -0.469081085811008270, -0.469125242979759940, -0.469169398975698090, +-0.469213553798712710, -0.469257707448693880, -0.469301859925530360, -0.469346011229112180, -0.469390161359329040, -0.469434310316070410, -0.469478458099226450, -0.469522604708685950, +-0.469566750144338960, -0.469610894406075450, -0.469655037493784290, -0.469699179407355560, -0.469743320146678910, -0.469787459711644320, -0.469831598102140700, -0.469875735318058100, +-0.469919871359286150, -0.469964006225714880, -0.470008139917233230, -0.470052272433731270, -0.470096403775098590, -0.470140533941225290, -0.470184662932000290, -0.470228790747313610, +-0.470272917387055340, -0.470317042851114360, -0.470361167139380810, -0.470405290251744320, -0.470449412188094660, -0.470493532948321800, -0.470537652532314780, -0.470581770939963560, +-0.470625888171158360, -0.470670004225787970, -0.470714119103742670, -0.470758232804912020, -0.470802345329186190, -0.470846456676454080, -0.470890566846605850, -0.470934675839531190, +-0.470978783655120250, -0.471022890293261940, -0.471066995753846420, -0.471111100036763430, -0.471155203141903070, -0.471199305069154250, -0.471243405818407230, -0.471287505389552110, +-0.471331603782477790, -0.471375700997074430, -0.471419797033231890, -0.471463891890839810, -0.471507985569788400, -0.471552078069966680, -0.471596169391264700, -0.471640259533572690, +-0.471684348496779700, -0.471728436280775820, -0.471772522885450800, -0.471816608310694940, -0.471860692556397120, -0.471904775622447540, -0.471948857508736500, -0.471992938215152870, +-0.472037017741586850, -0.472081096087928360, -0.472125173254067110, -0.472169249239893280, -0.472213324045295980, -0.472257397670165390, -0.472301470114391660, -0.472345541377863830, +-0.472389611460472200, -0.472433680362106530, -0.472477748082657080, -0.472521814622012810, -0.472565879980064050, -0.472609944156700550, -0.472654007151812610, -0.472698068965289260, +-0.472742129597020720, -0.472786189046896900, -0.472830247314807940, -0.472874304400642990, -0.472918360304292300, -0.472962415025646070, -0.473006468564593440, -0.473050520921024620, +-0.473094572094829520, -0.473138622085897960, -0.473182670894120250, -0.473226718519385470, -0.473270764961583930, -0.473314810220605840, -0.473358854296340340, -0.473402897188677670, +-0.473446938897507770, -0.473490979422720950, -0.473535018764206280, -0.473579056921854040, -0.473623093895554180, -0.473667129685196920, -0.473711164290671500, -0.473755197711868190, +-0.473799229948676850, -0.473843261000987840, -0.473887290868690250, -0.473931319551674450, -0.473975347049830800, -0.474019373363048340, -0.474063398491217420, -0.474107422434228040, +-0.474151445191970500, -0.474195466764333940, -0.474239487151208730, -0.474283506352484780, -0.474327524368052480, -0.474371541197800950, -0.474415556841620620, -0.474459571299401360, +-0.474503584571033530, -0.474547596656406390, -0.474591607555410240, -0.474635617267935520, -0.474679625793871300, -0.474723633133108060, -0.474767639285535670, -0.474811644251044220, +-0.474855648029524070, -0.474899650620864420, -0.474943652024955590, -0.474987652241688040, -0.475031651270950980, -0.475075649112634830, -0.475119645766629520, -0.475163641232825450, +-0.475207635511111950, -0.475251628601379320, -0.475295620503517650, -0.475339611217417300, -0.475383600742967540, -0.475427589080058780, -0.475471576228580990, -0.475515562188424720, +-0.475559546959479110, -0.475603530541634680, -0.475647512934781800, -0.475691494138809730, -0.475735474153608950, -0.475779452979069430, -0.475823430615081310, -0.475867407061535020, +-0.475911382318319810, -0.475955356385326160, -0.475999329262444480, -0.476043300949564100, -0.476087271446575480, -0.476131240753368660, -0.476175208869834170, -0.476219175795861260, +-0.476263141531340360, -0.476307106076161610, -0.476351069430215550, -0.476395031593391360, -0.476438992565579640, -0.476482952346670430, -0.476526910936554190, -0.476570868335120300, +-0.476614824542259290, -0.476658779557861570, -0.476702733381816510, -0.476746686014014600, -0.476790637454345970, -0.476834587702701150, -0.476878536758969520, -0.476922484623041490, +-0.476966431294807260, -0.477010376774157360, -0.477054321060981110, -0.477098264155169090, -0.477142206056611340, -0.477186146765198550, -0.477230086280819920, -0.477274024603366150, +-0.477317961732727670, -0.477361897668793890, -0.477405832411455400, -0.477449765960602290, -0.477493698316124760, -0.477537629477913450, -0.477581559445857620, -0.477625488219847850, +-0.477669415799774840, -0.477713342185527860, -0.477757267376997470, -0.477801191374074010, -0.477845114176647880, -0.477889035784608620, -0.477932956197846760, -0.477976875416252500, +-0.478020793439716480, -0.478064710268128020, -0.478108625901377820, -0.478152540339356060, -0.478196453581953340, -0.478240365629059080, -0.478284276480563930, -0.478328186136358470, +-0.478372094596332180, -0.478416001860375580, -0.478459907928379060, -0.478503812800232740, -0.478547716475827280, -0.478591618955052090, -0.478635520237797930, -0.478679420323955330, +-0.478723319213413770, -0.478767216906063940, -0.478811113401796050, -0.478855008700500740, -0.478898902802067540, -0.478942795706387090, -0.478986687413349650, -0.479030577922845920, +-0.479074467234765320, -0.479118355348998550, -0.479162242265435860, -0.479206127983968000, -0.479250012504484400, -0.479293895826875820, -0.479337777951032830, -0.479381658876845030, +-0.479425538604203120, -0.479469417132997340, -0.479513294463117970, -0.479557170594455790, -0.479601045526900300, -0.479644919260342200, -0.479688791794672160, -0.479732663129779800, +-0.479776533265555750, -0.479820402201890370, -0.479864269938674370, -0.479908136475797330, -0.479952001813149950, -0.479995865950622940, -0.480039728888105870, -0.480083590625489500, +-0.480127451162664090, -0.480171310499520110, -0.480215168635948260, -0.480259025571838080, -0.480302881307080320, -0.480346735841565730, -0.480390589175183960, -0.480434441307825700, +-0.480478292239381320, -0.480522141969741190, -0.480565990498796110, -0.480609837826435680, -0.480653683952551090, -0.480697528877031820, -0.480741372599768790, -0.480785215120652310, +-0.480829056439572740, -0.480872896556421010, -0.480916735471086600, -0.480960573183460360, -0.481004409693433050, -0.481048245000894330, -0.481092079105735040, -0.481135912007845500, +-0.481179743707116250, -0.481223574203437980, -0.481267403496700390, -0.481311231586794290, -0.481355058473610490, -0.481398884157038690, -0.481442708636969640, -0.481486531913293820, +-0.481530353985902100, -0.481574174854684070, -0.481617994519530630, -0.481661812980332560, -0.481705630236979600, -0.481749446289362560, -0.481793261137371920, -0.481837074780898100, +-0.481880887219831970, -0.481924698454063270, -0.481968508483482770, -0.482012317307981440, -0.482056124927448930, -0.482099931341776090, -0.482143736550853410, -0.482187540554571410, +-0.482231343352820920, -0.482275144945491730, -0.482318945332474600, -0.482362744513660570, -0.482406542488939270, -0.482450339258201580, -0.482494134821338070, -0.482537929178239620, +-0.482581722328795980, -0.482625514272898020, -0.482669305010436640, -0.482713094541301620, -0.482756882865383820, -0.482800669982573870, -0.482844455892762260, -0.482888240595839850, +-0.482932024091696440, -0.482975806380223030, -0.483019587461310460, -0.483063367334848560, -0.483107146000728180, -0.483150923458839980, -0.483194699709074470, -0.483238474751322590, +-0.483282248585474140, -0.483326021211420430, -0.483369792629051330, -0.483413562838257700, -0.483457331838930190, -0.483501099630959390, -0.483544866214236150, -0.483588631588650400, +-0.483632395754093060, -0.483676158710455160, -0.483719920457626410, -0.483763680995497880, -0.483807440323960170, -0.483851198442903860, -0.483894955352219940, -0.483938711051798200, +-0.483982465541529740, -0.484026218821305480, -0.484069970891015280, -0.484113721750550120, -0.484157471399800700, -0.484201219838657990, -0.484244967067011810, -0.484288713084753240, +-0.484332457891773320, -0.484376201487961790, -0.484419943873209800, -0.484463685047407940, -0.484507425010446860, -0.484551163762217630, -0.484594901302610070, -0.484638637631515270, +-0.484682372748824250, -0.484726106654426950, -0.484769839348214330, -0.484813570830077150, -0.484857301099906050, -0.484901030157592060, -0.484944758003025110, -0.484988484636096670, +-0.485032210056696610, -0.485075934264716010, -0.485119657260045630, -0.485163379042576060, -0.485207099612198430, -0.485250818968802730, -0.485294537112279930, -0.485338254042521180, +-0.485381969759416390, -0.485425684262856700, -0.485469397552732770, -0.485513109628935400, -0.485556820491355570, -0.485600530139883360, -0.485644238574409800, -0.485687945794826050, +-0.485731651801022070, -0.485775356592888900, -0.485819060170317400, -0.485862762533198600, -0.485906463681422480, -0.485950163614880250, -0.485993862333462980, -0.486037559837060650, +-0.486081256125564460, -0.486124951198865120, -0.486168645056853370, -0.486212337699420400, -0.486256029126456210, -0.486299719337851990, -0.486343408333498820, -0.486387096113286730, +-0.486430782677106930, -0.486474468024850120, -0.486518152156407200, -0.486561835071669280, -0.486605516770526330, -0.486649197252869650, -0.486692876518590330, -0.486736554567578470, +-0.486780231399725150, -0.486823907014921340, -0.486867581413058080, -0.486911254594025510, -0.486954926557714830, -0.486998597304017180, -0.487042266832822650, -0.487085935144022490, +-0.487129602237507450, -0.487173268113168410, -0.487216932770896620, -0.487260596210582100, -0.487304258432116060, -0.487347919435389800, -0.487391579220293360, -0.487435237786717930, +-0.487478895134554390, -0.487522551263693650, -0.487566206174026960, -0.487609859865444310, -0.487653512337837440, -0.487697163591096330, -0.487740813625112350, -0.487784462439776360, +-0.487828110034979220, -0.487871756410612150, -0.487915401566565320, -0.487959045502730000, -0.488002688218997450, -0.488046329715257740, -0.488089969991402250, -0.488133609047321840, +-0.488177246882907420, -0.488220883498050260, -0.488264518892640500, -0.488308153066569440, -0.488351786019728400, -0.488395417752007450, -0.488439048263297980, -0.488482677553490950, +-0.488526305622477560, -0.488569932470148020, -0.488613558096393670, -0.488657182501105790, -0.488700805684174570, -0.488744427645491360, -0.488788048384947050, -0.488831667902432650, +-0.488875286197839490, -0.488918903271057640, -0.488962519121978580, -0.489006133750493620, -0.489049747156492960, -0.489093359339867860, -0.489136970300509450, -0.489180580038308550, +-0.489224188553156640, -0.489267795844943840, -0.489311401913561540, -0.489355006758901090, -0.489398610380852810, -0.489442212779307990, -0.489485813954157580, -0.489529413905293090, +-0.489573012632604660, -0.489616610135983680, -0.489660206415321540, -0.489703801470508570, -0.489747395301436020, -0.489790987907995020, -0.489834579290076570, -0.489878169447572010, +-0.489921758380371660, -0.489965346088366950, -0.490008932571449230, -0.490052517829508820, -0.490096101862437070, -0.490139684670125090, -0.490183266252463890, -0.490226846609344900, +-0.490270425740658430, -0.490314003646296290, -0.490357580326148730, -0.490401155780107230, -0.490444730008062880, -0.490488303009906650, -0.490531874785530060, -0.490575445334823390, +-0.490619014657678100, -0.490662582753985720, -0.490706149623636460, -0.490749715266521780, -0.490793279682532890, -0.490836842871560760, -0.490880404833496930, -0.490923965568231650, +-0.490967525075656500, -0.491011083355662900, -0.491054640408141230, -0.491098196232982950, -0.491141750830079220, -0.491185304199321440, -0.491228856340600040, -0.491272407253806500, +-0.491315956938832290, -0.491359505395567830, -0.491403052623904660, -0.491446598623733800, -0.491490143394946450, -0.491533686937434100, -0.491577229251087210, -0.491620770335797210, +-0.491664310191455680, -0.491707848817952990, -0.491751386215180660, -0.491794922383029850, -0.491838457321391750, -0.491881991030157950, -0.491925523509218750, -0.491969054758465700, +-0.492012584777790420, -0.492056113567083340, -0.492099641126235940, -0.492143167455139420, -0.492186692553685410, -0.492230216421764230, -0.492273739059267520, -0.492317260466086930, +-0.492360780642112690, -0.492404299587236580, -0.492447817301349680, -0.492491333784343230, -0.492534849036108830, -0.492578363056536960, -0.492621875845519200, -0.492665387402947070, +-0.492708897728711130, -0.492752406822702940, -0.492795914684813710, -0.492839421314934690, -0.492882926712957530, -0.492926430878772640, -0.492969933812272110, -0.493013435513346310, +-0.493056935981886930, -0.493100435217785240, -0.493143933220932420, -0.493187429991220170, -0.493230925528538980, -0.493274419832780480, -0.493317912903836250, -0.493361404741596900, +-0.493404895345954050, -0.493448384716798970, -0.493491872854022910, -0.493535359757517500, -0.493578845427173400, -0.493622329862882130, -0.493665813064535440, -0.493709295032023820, +-0.493752775765238960, -0.493796255264072170, -0.493839733528415150, -0.493883210558158370, -0.493926686353193590, -0.493970160913412450, -0.494013634238705530, -0.494057106328964550, +-0.494100577184080790, -0.494144046803945640, -0.494187515188450670, -0.494230982337486580, -0.494274448250945020, -0.494317912928717740, -0.494361376370695270, -0.494404838576769370, +-0.494448299546831340, -0.494491759280772600, -0.494535217778484860, -0.494578675039858640, -0.494622131064785810, -0.494665585853157950, -0.494709039404865770, -0.494752491719801010, +-0.494795942797855050, -0.494839392638919570, -0.494882841242885230, -0.494926288609643770, -0.494969734739087010, -0.495013179631105530, -0.495056623285591080, -0.495100065702435090, +-0.495143506881528920, -0.495186946822764370, -0.495230385526032050, -0.495273822991223800, -0.495317259218231390, -0.495360694206945400, -0.495404127957257690, -0.495447560469059690, +-0.495490991742242760, -0.495534421776698760, -0.495577850572318290, -0.495621278128993590, -0.495664704446615310, -0.495708129525075260, -0.495751553364264910, -0.495794975964075680, +-0.495838397324399380, -0.495881817445126660, -0.495925236326149430, -0.495968653967359560, -0.496012070368647580, -0.496055485529905470, -0.496098899451024640, -0.496142312131896520, +-0.496185723572413080, -0.496229133772464910, -0.496272542731943880, -0.496315950450741890, -0.496359356928749660, -0.496402762165859050, -0.496446166161961520, -0.496489568916948950, +-0.496532970430712040, -0.496576370703142760, -0.496619769734132910, -0.496663167523573260, -0.496706564071355720, -0.496749959377371710, -0.496793353441512820, -0.496836746263670970, +-0.496880137843736860, -0.496923528181602350, -0.496966917277159470, -0.497010305130298870, -0.497053691740912520, -0.497097077108891950, -0.497140461234128690, -0.497183844116514670, +-0.497227225755940640, -0.497270606152298900, -0.497313985305480320, -0.497357363215376710, -0.497400739881879770, -0.497444115304880920, -0.497487489484272180, -0.497530862419944320, +-0.497574234111789360, -0.497617604559699170, -0.497660973763564550, -0.497704341723277540, -0.497747708438729620, -0.497791073909812480, -0.497834438136418030, -0.497877801118437100, +-0.497921162855761660, -0.497964523348283730, -0.498007882595894070, -0.498051240598484710, -0.498094597355947240, -0.498137952868173690, -0.498181307135054870, -0.498224660156482760, +-0.498268011932349380, -0.498311362462545590, -0.498354711746963440, -0.498398059785494450, -0.498441406578030380, -0.498484752124463140, -0.498528096424683600, -0.498571439478583840, +-0.498614781286055910, -0.498658121846990600, -0.498701461161280000, -0.498744799228815710, -0.498788136049489460, -0.498831471623193250, -0.498874805949817980, -0.498918139029255690, +-0.498961470861398420, -0.499004801446137130, -0.499048130783363800, -0.499091458872970130, -0.499134785714848260, -0.499178111308889010, -0.499221435654984450, -0.499264758753026730, +-0.499308080602906710, -0.499351401204516490, -0.499394720557747750, -0.499438038662492260, -0.499481355518642030, -0.499524671126088000, -0.499567985484722310, -0.499611298594437040, +-0.499654610455123160, -0.499697921066672710, -0.499741230428977500, -0.499784538541929220, -0.499827845405419970, -0.499871151019340710, -0.499914455383583920, -0.499957758498040640, +-0.500001060362602940, -0.500044360977162650, -0.500087660341611450, -0.500130958455841430, -0.500174255319743690, -0.500217550933210300, -0.500260845296133350, -0.500304138408403930, +-0.500347430269914240, -0.500390720880555920, -0.500434010240220830, -0.500477298348801060, -0.500520585206187580, -0.500563870812272830, -0.500607155166948650, -0.500650438270106250, +-0.500693720121637710, -0.500737000721434900, -0.500780280069389900, -0.500823558165393920, -0.500866835009339040, -0.500910110601117450, -0.500953384940620140, -0.500996658027739410, +-0.501039929862367010, -0.501083200444394810, -0.501126469773715000, -0.501169737850218570, -0.501213004673797920, -0.501256270244345050, -0.501299534561751140, -0.501342797625908390, +-0.501386059436708660, -0.501429319994043720, -0.501472579297805980, -0.501515837347886300, -0.501559094144177100, -0.501602349686570470, -0.501645603974957610, -0.501688857009230830, +-0.501732108789281760, -0.501775359315002940, -0.501818608586285240, -0.501861856603021070, -0.501905103365102630, -0.501948348872421010, -0.501991593124868630, -0.502034836122337120, +-0.502078077864718590, -0.502121318351905320, -0.502164557583788310, -0.502207795560259850, -0.502251032281212370, -0.502294267746536850, -0.502337501956125700, -0.502380734909870790, +-0.502423966607664090, -0.502467197049397800, -0.502510426234963110, -0.502553654164252790, -0.502596880837157920, -0.502640106253570920, -0.502683330413383640, -0.502726553316487970, +-0.502769774962776310, -0.502812995352139860, -0.502856214484470930, -0.502899432359661840, -0.502942648977603770, -0.502985864338189040, -0.503029078441309730, -0.503072291286857600, +-0.503115502874725280, -0.503158713204803760, -0.503201922276985460, -0.503245130091162670, -0.503288336647226720, -0.503331541945069900, -0.503374745984584320, -0.503417948765662150, +-0.503461150288194830, -0.503504350552074540, -0.503547549557193830, -0.503590747303443780, -0.503633943790716910, -0.503677139018905210, -0.503720332987900640, -0.503763525697595640, +-0.503806717147881390, -0.503849907338650320, -0.503893096269794950, -0.503936283941206490, -0.503979470352777240, -0.504022655504399290, -0.504065839395964720, -0.504109022027365960, +-0.504152203398494310, -0.504195383509242090, -0.504238562359501820, -0.504281739949164700, -0.504324916278123260, -0.504368091346269590, -0.504411265153495990, -0.504454437699693890, +-0.504497608984755710, -0.504540779008573860, -0.504583947771039760, -0.504627115272045730, -0.504670281511483850, -0.504713446489246320, -0.504756610205225550, -0.504799772659312860, +-0.504842933851400780, -0.504886093781381720, -0.504929252449147100, -0.504972409854589240, -0.505015565997600450, -0.505058720878072690, -0.505101874495898610, -0.505145026850969290, +-0.505188177943177940, -0.505231327772415750, -0.505274476338575140, -0.505317623641548420, -0.505360769681227560, -0.505403914457505210, -0.505447057970272670, -0.505490200219422590, +-0.505533341204847280, -0.505576480926438250, -0.505619619384088060, -0.505662756577688780, -0.505705892507132600, -0.505749027172312180, -0.505792160573118710, -0.505835292709444830, +-0.505878423581183070, -0.505921553188224960, -0.505964681530462920, -0.506007808607789160, -0.506050934420096300, -0.506094058967275770, -0.506137182249220000, -0.506180304265821720, +-0.506223425016972260, -0.506266544502564250, -0.506309662722489890, -0.506352779676641380, -0.506395895364911250, -0.506439009787191030, -0.506482122943373250, -0.506525234833350660, +-0.506568345457014460, -0.506611454814257510, -0.506654562904971790, -0.506697669729049840, -0.506740775286383950, -0.506783879576865770, -0.506826982600387940, -0.506870084356843000, +-0.506913184846122470, -0.506956284068118990, -0.506999382022724880, -0.507042478709832540, -0.507085574129333750, -0.507128668281120910, -0.507171761165086890, -0.507214852781122990, +-0.507257943129121980, -0.507301032208976150, -0.507344120020577720, -0.507387206563819420, -0.507430291838592670, -0.507473375844790240, -0.507516458582304650, -0.507559540051027660, +-0.507602620250851790, -0.507645699181669240, -0.507688776843372550, -0.507731853235854350, -0.507774928359006060, -0.507818002212720890, -0.507861074796890240, -0.507904146111407000, +-0.507947216156163340, -0.507990284931051580, -0.508033352435964590, -0.508076418670793780, -0.508119483635431910, -0.508162547329771840, -0.508205609753704880, -0.508248670907124000, +-0.508291730789921400, -0.508334789401989400, -0.508377846743220840, -0.508420902813507380, -0.508463957612741550, -0.508507011140816310, -0.508550063397623100, -0.508593114383054770, +-0.508636164097003520, -0.508679212539362440, -0.508722259710022830, -0.508765305608877560, -0.508808350235819380, -0.508851393590740050, -0.508894435673532210, -0.508937476484088270, +-0.508980516022300660, -0.509023554288062010, -0.509066591281264190, -0.509109627001799960, -0.509152661449561950, -0.509195694624441920, -0.509238726526332730, -0.509281757155126580, +-0.509324786510716220, -0.509367814592994070, -0.509410841401852110, -0.509453866937183530, -0.509496891198879750, -0.509539914186833750, -0.509582935900938060, -0.509625956341084980, +-0.509668975507167390, -0.509711993399076910, -0.509755010016706530, -0.509798025359949000, -0.509841039428696070, -0.509884052222840390, -0.509927063742274700, -0.509970073986891310, +-0.510013082956583210, -0.510056090651241910, -0.510099097070760400, -0.510142102215031530, -0.510185106083947070, -0.510228108677399870, -0.510271109995282250, -0.510314110037486950, +-0.510357108803906830, -0.510400106294433440, -0.510443102508960190, -0.510486097447378830, -0.510529091109582220, -0.510572083495462900, -0.510615074604913400, -0.510658064437826460, +-0.510701052994094070, -0.510744040273609090, -0.510787026276264380, -0.510830011001951690, -0.510872994450563890, -0.510915976621993730, -0.510958957516133520, -0.511001937132876450, +-0.511044915472114060, -0.511087892533739320, -0.511130868317645310, -0.511173842823723800, -0.511216816051867640, -0.511259788001969360, -0.511302758673922050, -0.511345728067617470, +-0.511388696182948580, -0.511431663019808360, -0.511474628578088450, -0.511517592857682170, -0.511560555858481810, -0.511603517580380030, -0.511646478023269900, -0.511689437187043180, +-0.511732395071592850, -0.511775351676811870, -0.511818307002592230, -0.511861261048826680, -0.511904213815408070, -0.511947165302228950, -0.511990115509182280, -0.512033064436159920, +-0.512076012083055310, -0.512118958449760300, -0.512161903536167860, -0.512204847342170640, -0.512247789867661290, -0.512290731112532870, -0.512333671076677270, -0.512376609759987560, +-0.512419547162356600, -0.512462483283676380, -0.512505418123839980, -0.512548351682740040, -0.512591283960269210, -0.512634214956320670, -0.512677144670786070, -0.512720073103558600, +-0.512763000254531360, -0.512805926123596320, -0.512848850710646340, -0.512891774015574290, -0.512934696038273240, -0.512977616778634960, -0.513020536236552750, -0.513063454411919470, +-0.513106371304627330, -0.513149286914569070, -0.513192201241637780, -0.513235114285725880, -0.513278026046726570, -0.513320936524531810, -0.513363845719034710, -0.513406753630128440, +-0.513449660257704890, -0.513492565601657120, -0.513535469661878020, -0.513578372438260210, -0.513621273930696790, -0.513664174139079830, -0.513707073063302540, -0.513749970703257790, +-0.513792867058837870, -0.513835762129935760, -0.513878655916444220, -0.513921548418256320, -0.513964439635264280, -0.514007329567361170, -0.514050218214440080, -0.514093105576392980, +-0.514135991653113190, -0.514178876444493450, -0.514221759950426520, -0.514264642170805590, -0.514307523105522520, -0.514350402754470860, -0.514393281117543450, -0.514436158194632400, +-0.514479033985631110, -0.514521908490432110, -0.514564781708928390, -0.514607653641013020, -0.514650524286578200, -0.514693393645517470, -0.514736261717722910, -0.514779128503087600, +-0.514821994001504520, -0.514864858212866430, -0.514907721137066620, -0.514950582773997080, -0.514993443123551110, -0.515036302185621910, -0.515079159960101560, -0.515122016446883380, +-0.515164871645860110, -0.515207725556924620, -0.515250578179970220, -0.515293429514888990, -0.515336279561574240, -0.515379128319919060, -0.515421975789815750, -0.515464821971157510, +-0.515507666863837200, -0.515550510467748140, -0.515593352782782400, -0.515636193808833300, -0.515679033545794030, -0.515721871993556790, -0.515764709152015000, -0.515807545021061300, +-0.515850379600588770, -0.515893212890490730, -0.515936044890659250, -0.515978875600987650, -0.516021705021369240, -0.516064533151696200, -0.516107359991861750, -0.516150185541758950, +-0.516193009801280690, -0.516235832770320370, -0.516278654448769970, -0.516321474836523020, -0.516364293933472720, -0.516407111739511260, -0.516449928254532060, -0.516492743478428110, +-0.516535557411092580, -0.516578370052417800, -0.516621181402297180, -0.516663991460623920, -0.516706800227290210, -0.516749607702189580, -0.516792413885215020, -0.516835218776259260, +-0.516878022375215960, -0.516920824681977200, -0.516963625696436390, -0.517006425418486850, -0.517049223848020880, -0.517092020984931900, -0.517134816829112780, -0.517177611380456700, +-0.517220404638856880, -0.517263196604205720, -0.517305987276396980, -0.517348776655322860, -0.517391564740876770, -0.517434351532951810, -0.517477137031440940, -0.517519921236237690, +-0.517562704147234150, -0.517605485764323860, -0.517648266087400330, -0.517691045116355660, -0.517733822851083380, -0.517776599291476570, -0.517819374437428310, -0.517862148288831920, +-0.517904920845579820, -0.517947692107565420, -0.517990462074682250, -0.518033230746822390, -0.518075998123879500, -0.518118764205746650, -0.518161528992317270, -0.518204292483483650, +-0.518247054679139340, -0.518289815579177750, -0.518332575183491300, -0.518375333491973290, -0.518418090504517040, -0.518460846221015510, -0.518503600641362250, -0.518546353765449660, +-0.518589105593171170, -0.518631856124420310, -0.518674605359089380, -0.518717353297071910, -0.518760099938261110, -0.518802845282550160, -0.518845589329832270, -0.518888332080000180, +-0.518931073532947210, -0.518973813688566990, -0.519016552546751720, -0.519059290107395150, -0.519102026370390380, -0.519144761335630920, -0.519187495003009200, -0.519230227372418640, +-0.519272958443752990, -0.519315688216904550, -0.519358416691766860, -0.519401143868233110, -0.519443869746196500, -0.519486594325550670, -0.519529317606187920, -0.519572039588001910, +-0.519614760270886160, -0.519657479654733080, -0.519700197739436320, -0.519742914524889080, -0.519785630010984660, -0.519828344197616370, -0.519871057084676960, -0.519913768672060290, +-0.519956478959658800, -0.519999187947365990, -0.520041895635075300, -0.520084602022679920, -0.520127307110073380, -0.520170010897148210, -0.520212713383797930, -0.520255414569916420, +-0.520298114455395870, -0.520340813040130020, -0.520383510324012200, -0.520426206306935480, -0.520468900988793730, -0.520511594369479360, -0.520554286448886020, -0.520596977226907230, +-0.520639666703435760, -0.520682354878365010, -0.520725041751588400, -0.520767727322999590, -0.520810411592491080, -0.520853094559956540, -0.520895776225289600, -0.520938456588382890, +-0.520981135649130070, -0.521023813407424320, -0.521066489863159070, -0.521109165016228060, -0.521151838866523610, -0.521194511413939690, -0.521237182658369820, -0.521279852599706550, +-0.521322521237843730, -0.521365188572674660, -0.521407854604092560, -0.521450519331991160, -0.521493182756263110, -0.521535844876802050, -0.521578505693501840, -0.521621165206255010, +-0.521663823414955210, -0.521706480319495850, -0.521749135919770680, -0.521791790215672350, -0.521834443207094490, -0.521877094893930860, -0.521919745276074100, -0.521962394353418070, +-0.522005042125855970, -0.522047688593281320, -0.522090333755587890, -0.522132977612668080, -0.522175620164415990, -0.522218261410725140, -0.522260901351488280, -0.522303539986599170, +-0.522346177315951230, -0.522388813339437760, -0.522431448056952740, -0.522474081468388700, -0.522516713573639820, -0.522559344372598770, -0.522601973865159270, -0.522644602051214990, +-0.522687228930659110, -0.522729854503385600, -0.522772478769287010, -0.522815101728257290, -0.522857723380190100, -0.522900343724978290, -0.522942962762515620, -0.522985580492695610, +-0.523028196915411580, -0.523070812030557390, -0.523113425838025780, -0.523156038337710740, -0.523198649529505900, -0.523241259413304020, -0.523283867988999060, -0.523326475256484350, +-0.523369081215653950, -0.523411685866400410, -0.523454289208617580, -0.523496891242199560, -0.523539491967038860, -0.523582091383029360, -0.523624689490064690, -0.523667286288038270, +-0.523709881776844080, -0.523752475956374750, -0.523795068826524270, -0.523837660387186490, -0.523880250638254160, -0.523922839579621160, -0.523965427211181110, -0.524008013532827550, +-0.524050598544454240, -0.524093182245954140, -0.524135764637221340, -0.524178345718148920, -0.524220925488630530, -0.524263503948559810, -0.524306081097830390, -0.524348656936336030, +-0.524391231463969820, -0.524433804680625390, -0.524476376586196950, -0.524518947180577120, -0.524561516463659890, -0.524604084435338900, -0.524646651095507680, -0.524689216444060300, +-0.524731780480889420, -0.524774343205889120, -0.524816904618953250, -0.524859464719974910, -0.524902023508847740, -0.524944580985465590, -0.524987137149722340, -0.525029692001510950, +-0.525072245540725290, -0.525114797767259330, -0.525157348681006050, -0.525199898281859420, -0.525242446569712970, -0.525284993544460450, -0.525327539205995840, -0.525370083554212000, +-0.525412626589002900, -0.525455168310262730, -0.525497708717884150, -0.525540247811761340, -0.525582785591787950, -0.525625322057857500, -0.525667857209864200, -0.525710391047700790, +-0.525752923571261470, -0.525795454780440210, -0.525837984675129990, -0.525880513255224780, -0.525923040520618220, -0.525965566471204520, -0.526008091106876410, -0.526050614427528210, +-0.526093136433053780, -0.526135657123346090, -0.526178176498299340, -0.526220694557807180, -0.526263211301763230, -0.526305726730061600, -0.526348240842595240, -0.526390753639258360, +-0.526433265119944930, -0.526475775284548030, -0.526518284132961640, -0.526560791665079520, -0.526603297880795520, -0.526645802780003500, -0.526688306362596670, -0.526730808628469440, +-0.526773309577514890, -0.526815809209627010, -0.526858307524699530, -0.526900804522626440, -0.526943300203301600, -0.526985794566618200, -0.527028287612470230, -0.527070779340751970, +-0.527113269751356420, -0.527155758844177650, -0.527198246619109410, -0.527240733076045690, -0.527283218214880440, -0.527325702035506770, -0.527368184537818860, -0.527410665721710910, +-0.527453145587075790, -0.527495624133807910, -0.527538101361801020, -0.527580577270949090, -0.527623051861145440, -0.527665525132284150, -0.527707997084259530, -0.527750467716964430, +-0.527792937030293170, -0.527835405024139500, -0.527877871698397390, -0.527920337052961040, -0.527962801087723310, -0.528005263802578730, -0.528047725197421270, -0.528090185272144240, +-0.528132644026641620, -0.528175101460807370, -0.528217557574535480, -0.528260012367720020, -0.528302465840254200, -0.528344917992032200, -0.528387368822948230, -0.528429818332895480, +-0.528472266521768150, -0.528514713389460210, -0.528557158935865860, -0.528599603160878280, -0.528642046064391580, -0.528684487646300270, -0.528726927906497220, -0.528769366844876960, +-0.528811804461333250, -0.528854240755760040, -0.528896675728051550, -0.528939109378101070, -0.528981541705802800, -0.529023972711051060, -0.529066402393738920, -0.529108830753760920, +-0.529151257791010690, -0.529193683505382430, -0.529236107896770340, -0.529278530965067500, -0.529320952710168770, -0.529363373131967350, -0.529405792230357440, -0.529448210005233010, +-0.529490626456488030, -0.529533041584016930, -0.529575455387712890, -0.529617867867470120, -0.529660279023183130, -0.529702688854745030, -0.529745097362050220, -0.529787504544992680, +-0.529829910403466280, -0.529872314937365640, -0.529914718146583750, -0.529957120031015030, -0.529999520590553890, -0.530041919825093630, -0.530084317734528580, -0.530126714318752690, +-0.530169109577660390, -0.530211503511144990, -0.530253896119100790, -0.530296287401422210, -0.530338677358002550, -0.530381065988736240, -0.530423453293517260, -0.530465839272239560, +-0.530508223924797680, -0.530550607251084940, -0.530592989250995630, -0.530635369924424170, -0.530677749271263990, -0.530720127291409380, -0.530762503984754440, -0.530804879351193360, +-0.530847253390620330, -0.530889626102928890, -0.530931997488013340, -0.530974367545768100, -0.531016736276086590, -0.531059103678863330, -0.531101469753992310, -0.531143834501367930, +-0.531186197920883510, -0.531228560012433680, -0.531270920775912870, -0.531313280211214380, -0.531355638318232630, -0.531397995096861810, -0.531440350546996010, -0.531482704668529650, +-0.531525057461356250, -0.531567408925370130, -0.531609759060465930, -0.531652107866536830, -0.531694455343477590, -0.531736801491182190, -0.531779146309544810, -0.531821489798459890, +-0.531863831957820830, -0.531906172787522610, -0.531948512287458650, -0.531990850457523260, -0.532033187297610840, -0.532075522807615500, -0.532117856987431640, -0.532160189836952790, +-0.532202521356073490, -0.532244851544688260, -0.532287180402690520, -0.532329507929974800, -0.532371834126435290, -0.532414158991966200, -0.532456482526462160, -0.532498804729816480, +-0.532541125601923790, -0.532583445142678750, -0.532625763351974650, -0.532668080229706130, -0.532710395775767400, -0.532752709990053090, -0.532795022872456610, -0.532837334422872620, +-0.532879644641195640, -0.532921953527319080, -0.532964261081137810, -0.533006567302545810, -0.533048872191437370, -0.533091175747707150, -0.533133477971248550, -0.533175778861956330, +-0.533218078419725020, -0.533260376644448140, -0.533302673536020230, -0.533344969094335710, -0.533387263319288870, -0.533429556210774150, -0.533471847768685170, -0.533514137992916580, +-0.533556426883363020, -0.533598714439917910, -0.533641000662476110, -0.533683285550931920, -0.533725569105179760, -0.533767851325113290, -0.533810132210627230, -0.533852411761616240, +-0.533894689977973740, -0.533936966859594580, -0.533979242406373070, -0.534021516618203410, -0.534063789494980350, -0.534106061036597410, -0.534148331242949250, -0.534190600113930710, +-0.534232867649435340, -0.534275133849357760, -0.534317398713592300, -0.534359662242033460, -0.534401924434575680, -0.534444185291112820, -0.534486444811539840, -0.534528702995750390, +-0.534570959843639230, -0.534613215355100650, -0.534655469530028960, -0.534697722368319030, -0.534739973869864380, -0.534782224034559770, -0.534824472862300060, -0.534866720352978780, +-0.534908966506490670, -0.534951211322730160, -0.534993454801591550, -0.535035696942969820, -0.535077937746758380, -0.535120177212852100, -0.535162415341145730, -0.535204652131533010, +-0.535246887583908590, -0.535289121698167000, -0.535331354474202990, -0.535373585911910200, -0.535415816011183380, -0.535458044771917500, -0.535500272194006090, -0.535542498277344010, +-0.535584723021825690, -0.535626946427345540, -0.535669168493798420, -0.535711389221077970, -0.535753608609079060, -0.535795826657696540, -0.535838043366824060, -0.535880258736356470, +-0.535922472766188210, -0.535964685456213790, -0.536006896806327960, -0.536049106816424590, -0.536091315486398880, -0.536133522816144460, -0.536175728805556200, -0.536217933454528620, +-0.536260136762956250, -0.536302338730733850, -0.536344539357755280, -0.536386738643915280, -0.536428936589108950, -0.536471133193229810, -0.536513328456172830, -0.536555522377832550, +-0.536597714958103490, -0.536639906196880510, -0.536682096094057370, -0.536724284649529040, -0.536766471863190260, -0.536808657734935020, -0.536850842264658180, -0.536893025452254150, +-0.536935207297617900, -0.536977387800643300, -0.537019566961225210, -0.537061744779258610, -0.537103921254637350, -0.537146096387256190, -0.537188270177009760, -0.537230442623792710, +-0.537272613727499900, -0.537314783488025190, -0.537356951905263560, -0.537399118979109970, -0.537441284709458070, -0.537483449096203050, -0.537525612139239330, -0.537567773838461660, +-0.537609934193764900, -0.537652093205042920, -0.537694250872190690, -0.537736407195103290, -0.537778562173674480, -0.537820715807799220, -0.537862868097372160, -0.537905019042288270, +-0.537947168642441520, -0.537989316897726890, -0.538031463808039230, -0.538073609373272640, -0.538115753593321980, -0.538157896468081990, -0.538200037997447200, -0.538242178181312700, +-0.538284317019572360, -0.538326454512121240, -0.538368590658854340, -0.538410725459665620, -0.538452858914450160, -0.538494991023102390, -0.538537121785517270, -0.538579251201589670, +-0.538621379271213560, -0.538663505994284470, -0.538705631370696160, -0.538747755400343700, -0.538789878083121950, -0.538831999418925460, -0.538874119407649400, -0.538916238049187650, +-0.538958355343435280, -0.539000471290287390, -0.539042585889638050, -0.539084699141382130, -0.539126811045414490, -0.539168921601629770, -0.539211030809923280, -0.539253138670188650, +-0.539295245182321300, -0.539337350346216220, -0.539379454161767250, -0.539421556628869810, -0.539463657747418330, -0.539505757517308230, -0.539547855938433240, -0.539589953010688680, +-0.539632048733969640, -0.539674143108169970, -0.539716236133185090, -0.539758327808909530, -0.539800418135238160, -0.539842507112066160, -0.539884594739287520, -0.539926681016797310, +-0.539968765944490840, -0.540010849522262080, -0.540052931750006240, -0.540095012627617940, -0.540137092154992170, -0.540179170332024120, -0.540221247158607750, -0.540263322634638170, +-0.540305396760010770, -0.540347469534619430, -0.540389540958359450, -0.540431611031125580, -0.540473679752813020, -0.540515747123315960, -0.540557813142529490, -0.540599877810348910, +-0.540641941126668300, -0.540684003091382760, -0.540726063704387250, -0.540768122965576530, -0.540810180874845890, -0.540852237432089430, -0.540894292637202460, -0.540936346490080040, +-0.540978398990616390, -0.541020450138706700, -0.541062499934245930, -0.541104548377128960, -0.541146595467250970, -0.541188641204506050, -0.541230685588789950, -0.541272728619996870, +-0.541314770298021770, -0.541356810622759870, -0.541398849594105890, -0.541440887211955160, -0.541482923476201970, -0.541524958386741310, -0.541566991943468690, -0.541609024146278210, +-0.541651054995065160, -0.541693084489724420, -0.541735112630151060, -0.541777139416240280, -0.541819164847886280, -0.541861188924984360, -0.541903211647429830, -0.541945233015116880, +-0.541987253027940820, -0.542029271685796730, -0.542071288988579700, -0.542113304936184150, -0.542155319528505380, -0.542197332765438690, -0.542239344646878170, -0.542281355172719360, +-0.542323364342857220, -0.542365372157186610, -0.542407378615602950, -0.542449383718000440, -0.542491387464274500, -0.542533389854320540, -0.542575390888032640, -0.542617390565306220, +-0.542659388886036490, -0.542701385850118180, -0.542743381457446720, -0.542785375707916520, -0.542827368601422890, -0.542869360137861130, -0.542911350317125670, -0.542953339139111810, +-0.542995326603714630, -0.543037312710829450, -0.543079297460350660, -0.543121280852173590, -0.543163262886193770, -0.543205243562305370, -0.543247222880403830, -0.543289200840384230, +-0.543331177442141660, -0.543373152685571510, -0.543415126570568120, -0.543457099097026890, -0.543499070264843340, -0.543541040073911690, -0.543583008524127440, -0.543624975615385700, +-0.543666941347581530, -0.543708905720610370, -0.543750868734366510, -0.543792830388745930, -0.543834790683642820, -0.543876749618952830, -0.543918707194570920, -0.543960663410392180, +-0.544002618266312240, -0.544044571762225320, -0.544086523898027030, -0.544128474673612810, -0.544170424088877060, -0.544212372143715100, -0.544254318838022330, -0.544296264171693740, +-0.544338208144624860, -0.544380150756710090, -0.544422092007844970, -0.544464031897924920, -0.544505970426844450, -0.544547907594499110, -0.544589843400783980, -0.544631777845594580, +-0.544673710928825330, -0.544715642650371870, -0.544757573010129610, -0.544799502007993100, -0.544841429643857840, -0.544883355917618940, -0.544925280829171800, -0.544967204378411730, +-0.545009126565233260, -0.545051047389531920, -0.545092966851203450, -0.545134884950142170, -0.545176801686243610, -0.545218717059403170, -0.545260631069515830, -0.545302543716477240, +-0.545344455000182030, -0.545386364920525610, -0.545428273477403750, -0.545470180670710740, -0.545512086500342330, -0.545553990966193610, -0.545595894068160450, -0.545637795806137030, +-0.545679696180019210, -0.545721595189702420, -0.545763492835081410, -0.545805389116051590, -0.545847284032508260, -0.545889177584346850, -0.545931069771462770, -0.545972960593750670, +-0.546014850051106170, -0.546056738143424920, -0.546098624870601350, -0.546140510232531300, -0.546182394229110080, -0.546224276860232780, -0.546266158125795150, -0.546308038025691720, +-0.546349916559818570, -0.546391793728070340, -0.546433669530342560, -0.546475543966530640, -0.546517417036529900, -0.546559288740235850, -0.546601159077543360, -0.546643028048347860, +-0.546684895652545190, -0.546726761890030000, -0.546768626760697820, -0.546810490264444060, -0.546852352401164140, -0.546894213170753600, -0.546936072573107280, -0.546977930608120720, +-0.547019787275689670, -0.547061642575708880, -0.547103496508073880, -0.547145349072680200, -0.547187200269423470, -0.547229050098198440, -0.547270898558900760, -0.547312745651426180, +-0.547354591375669330, -0.547396435731526080, -0.547438278718891720, -0.547480120337661690, -0.547521960587731620, -0.547563799468996360, -0.547605636981351560, -0.547647473124693080, +-0.547689307898915570, -0.547731141303914760, -0.547772973339586080, -0.547814804005825050, -0.547856633302527320, -0.547898461229587630, -0.547940287786902180, -0.547982112974365610, +-0.548023936791873780, -0.548065759239321990, -0.548107580316606000, -0.548149400023621340, -0.548191218360262740, -0.548233035326426200, -0.548274850922007340, -0.548316665146901140, +-0.548358478001003120, -0.548400289484208940, -0.548442099596414100, -0.548483908337514370, -0.548525715707404490, -0.548567521705980220, -0.548609326333137640, -0.548651129588771380, +-0.548692931472777200, -0.548734731985050740, -0.548776531125487850, -0.548818328893983300, -0.548860125290432820, -0.548901920314732390, -0.548943713966776880, -0.548985506246462030, +-0.549027297153683480, -0.549069086688336650, -0.549110874850317400, -0.549152661639520700, -0.549194447055842310, -0.549236231099178180, -0.549278013769423090, -0.549319795066472990, +-0.549361574990223310, -0.549403353540569790, -0.549445130717408190, -0.549486906520633480, -0.549528680950141400, -0.549570454005828050, -0.549612225687588160, -0.549653995995317720, +-0.549695764928912370, -0.549737532488267950, -0.549779298673279240, -0.549821063483842300, -0.549862826919853110, -0.549904588981206530, -0.549946349667798430, -0.549988108979524440, +-0.550029866916280200, -0.550071623477961680, -0.550113378664463640, -0.550155132475682260, -0.550196884911513310, -0.550238635971851850, -0.550280385656593870, -0.550322133965634790, +-0.550363880898870450, -0.550405626456196730, -0.550447370637508700, -0.550489113442702460, -0.550530854871673190, -0.550572594924316650, -0.550614333600528690, -0.550656070900204960, +-0.550697806823241320, -0.550739541369532850, -0.550781274538975520, -0.550823006331465410, -0.550864736746897400, -0.550906465785167440, -0.550948193446171410, -0.550989919729804930, +-0.551031644635963990, -0.551073368164543550, -0.551115090315439700, -0.551156811088548420, -0.551198530483764880, -0.551240248500984850, -0.551281965140104410, -0.551323680401019310, +-0.551365394283624630, -0.551407106787816460, -0.551448817913490870, -0.551490527660542960, -0.551532236028868580, -0.551573943018363710, -0.551615648628924090, -0.551657352860445590, +-0.551699055712823290, -0.551740757185953390, -0.551782457279732070, -0.551824155994054100, -0.551865853328815880, -0.551907549283912950, -0.551949243859241050, -0.551990937054696600, +-0.552032628870174350, -0.552074319305570490, -0.552116008360781230, -0.552157696035701530, -0.552199382330227690, -0.552241067244255370, -0.552282750777680740, -0.552324432930398790, +-0.552366113702305820, -0.552407793093298020, -0.552449471103270250, -0.552491147732118830, -0.552532822979739490, -0.552574496846028220, -0.552616169330880980, -0.552657840434192970, +-0.552699510155860390, -0.552741178495779420, -0.552782845453845040, -0.552824511029953560, -0.552866175224000940, -0.552907838035882730, -0.552949499465495320, -0.552991159512733810, +-0.553032818177494830, -0.553074475459673360, -0.553116131359165820, -0.553157785875867840, -0.553199439009675390, -0.553241090760484780, -0.553282741128190980, -0.553324390112690410, +-0.553366037713879160, -0.553407683931652520, -0.553449328765906690, -0.553490972216537420, -0.553532614283440800, -0.553574254966513020, -0.553615894265649280, -0.553657532180745650, +-0.553699168711698660, -0.553740803858403410, -0.553782437620756070, -0.553824069998652750, -0.553865700991989510, -0.553907330600661660, -0.553948958824565520, -0.553990585663597380, +-0.554032211117652440, -0.554073835186626900, -0.554115457870416720, -0.554157079168917990, -0.554198699082026900, -0.554240317609638660, -0.554281934751649660, -0.554323550507956230, +-0.554365164878453440, -0.554406777863037830, -0.554448389461605240, -0.554489999674051770, -0.554531608500273610, -0.554573215940165950, -0.554614821993625440, -0.554656426660548150, +-0.554698029940829400, -0.554739631834365590, -0.554781232341052700, -0.554822831460787150, -0.554864429193464130, -0.554906025538979940, -0.554947620497231120, -0.554989214068112970, +-0.555030806251521680, -0.555072397047353340, -0.555113986455504140, -0.555155574475870270, -0.555197161108347050, -0.555238746352830990, -0.555280330209218410, -0.555321912677404720, +-0.555363493757286110, -0.555405073448758890, -0.555446651751718920, -0.555488228666062730, -0.555529804191685520, -0.555571378328484240, -0.555612951076354110, -0.555654522435191640, +-0.555696092404892820, -0.555737660985353820, -0.555779228176470960, -0.555820793978139660, -0.555862358390256440, -0.555903921412717720, -0.555945483045418800, -0.555987043288256100, +-0.556028602141125820, -0.556070159603924140, -0.556111715676547270, -0.556153270358890840, -0.556194823650851270, -0.556236375552324970, -0.556277926063207360, -0.556319475183394860, +-0.556361022912783780, -0.556402569251270410, -0.556444114198750390, -0.556485657755119930, -0.556527199920275770, -0.556568740694113330, -0.556610280076528910, -0.556651818067418810, +-0.556693354666679130, -0.556734889874206500, -0.556776423689896330, -0.556817956113645040, -0.556859487145349160, -0.556901016784904330, -0.556942545032206860, -0.556984071887153040, +-0.557025597349639080, -0.557067121419561380, -0.557108644096815600, -0.557150165381298250, -0.557191685272905860, -0.557233203771533850, -0.557274720877078740, -0.557316236589436960, +-0.557357750908504920, -0.557399263834178040, -0.557440775366353170, -0.557482285504926620, -0.557523794249794040, -0.557565301600851940, -0.557606807557996520, -0.557648312121124200, +-0.557689815290131400, -0.557731317064913750, -0.557772817445367770, -0.557814316431390120, -0.557855814022876320, -0.557897310219722890, -0.557938805021826360, -0.557980298429082700, +-0.558021790441388670, -0.558063281058639780, -0.558104770280733130, -0.558146258107564130, -0.558187744539029530, -0.558229229575025520, -0.558270713215448520, -0.558312195460194950, +-0.558353676309160660, -0.558395155762242080, -0.558436633819336060, -0.558478110480338130, -0.558519585745144820, -0.558561059613652540, -0.558602532085757720, -0.558644003161356870, +-0.558685472840345640, -0.558726941122620670, -0.558768408008078810, -0.558809873496615590, -0.558851337588127550, -0.558892800282511320, -0.558934261579663310, -0.558975721479479380, +-0.559017179981856070, -0.559058637086690240, -0.559100092793877510, -0.559141547103314430, -0.559183000014897510, -0.559224451528523180, -0.559265901644087960, -0.559307350361487710, +-0.559348797680619070, -0.559390243601378680, -0.559431688123662510, -0.559473131247366970, -0.559514572972388710, -0.559556013298623920, -0.559597452225969460, -0.559638889754321080, +-0.559680325883575860, -0.559721760613629440, -0.559763193944378570, -0.559804625875719660, -0.559846056407549360, -0.559887485539764200, -0.559928913272259910, -0.559970339604933360, +-0.560011764537681310, -0.560053188070399610, -0.560094610202984790, -0.560136030935333480, -0.560177450267342110, -0.560218868198907540, -0.560260284729925400, -0.560301699860292550, +-0.560343113589905740, -0.560384525918660840, -0.560425936846454590, -0.560467346373183520, -0.560508754498744160, -0.560550161223033140, -0.560591566545946440, -0.560632970467381140, +-0.560674372987233110, -0.560715774105399190, -0.560757173821775700, -0.560798572136259390, -0.560839969048746890, -0.560881364559134180, -0.560922758667318110, -0.560964151373195440, +-0.561005542676662030, -0.561046932577614840, -0.561088321075950190, -0.561129708171564820, -0.561171093864355600, -0.561212478154218150, -0.561253861041049570, -0.561295242524746720, +-0.561336622605205340, -0.561378001282322400, -0.561419378555994550, -0.561460754426118540, -0.561502128892590320, -0.561543501955306780, -0.561584873614164870, -0.561626243869060350, +-0.561667612719890190, -0.561708980166551130, -0.561750346208939490, -0.561791710846952450, -0.561833074080485660, -0.561874435909436310, -0.561915796333701150, -0.561957155353176140, +-0.561998512967758270, -0.562039869177344050, -0.562081223981830250, -0.562122577381113710, -0.562163929375090410, -0.562205279963657540, -0.562246629146711200, -0.562287976924148340, +-0.562329323295865380, -0.562370668261759190, -0.562412011821726730, -0.562453353975663870, -0.562494694723467580, -0.562536034065034940, -0.562577372000261810, -0.562618708529045390, +-0.562660043651282080, -0.562701377366868650, -0.562742709675702170, -0.562784040577678500, -0.562825370072694840, -0.562866698160648050, -0.562908024841434210, -0.562949350114950180, +-0.562990673981092930, -0.563031996439759210, -0.563073317490845220, -0.563114637134247920, -0.563155955369864400, -0.563197272197590640, -0.563238587617323700, -0.563279901628960240, +-0.563321214232397120, -0.563362525427531290, -0.563403835214258740, -0.563445143592476660, -0.563486450562082020, -0.563527756122970900, -0.563569060275040390, -0.563610363018187230, +-0.563651664352308290, -0.563692964277300420, -0.563734262793059830, -0.563775559899483470, -0.563816855596468660, -0.563858149883911360, -0.563899442761708670, -0.563940734229757430, +-0.563982024287954630, -0.564023312936196450, -0.564064600174379980, -0.564105886002402410, -0.564147170420159720, -0.564188453427549090, -0.564229735024467380, -0.564271015210811240, +-0.564312293986477980, -0.564353571351363660, -0.564394847305365380, -0.564436121848380320, -0.564477394980304580, -0.564518666701035450, -0.564559937010469580, -0.564601205908503930, +-0.564642473395035480, -0.564683739469960640, -0.564725004133176720, -0.564766267384580020, -0.564807529224067520, -0.564848789651536290, -0.564890048666883080, -0.564931306270005100, +-0.564972562460798520, -0.565013817239160550, -0.565055070604988270, -0.565096322558178100, -0.565137573098627000, -0.565178822226232060, -0.565220069940890020, -0.565261316242498200, +-0.565302561130952670, -0.565343804606150860, -0.565385046667989830, -0.565426287316365790, -0.565467526551176050, -0.565508764372317450, -0.565550000779687310, -0.565591235773181930, +-0.565632469352698290, -0.565673701518134010, -0.565714932269384960, -0.565756161606348670, -0.565797389528922000, -0.565838616037001810, -0.565879841130485390, -0.565921064809269070, +-0.565962287073250030, -0.566003507922325680, -0.566044727356392220, -0.566085945375346960, -0.566127161979086750, -0.566168377167508670, -0.566209590940510040, -0.566250803297987050, +-0.566292014239837100, -0.566333223765957410, -0.566374431876244370, -0.566415638570595180, -0.566456843848906930, -0.566498047711076920, -0.566539250157001350, -0.566580451186577740, +-0.566621650799703390, -0.566662848996274500, -0.566704045776188490, -0.566745241139342440, -0.566786435085633200, -0.566827627614958200, -0.566868818727213840, -0.566910008422297440, +-0.566951196700106410, -0.566992383560536940, -0.567033569003486560, -0.567074753028852240, -0.567115935636531070, -0.567157116826420450, -0.567198296598416580, -0.567239474952417440, +-0.567280651888319110, -0.567321827406019220, -0.567363001505414850, -0.567404174186402880, -0.567445345448880810, -0.567486515292745080, -0.567527683717893080, -0.567568850724222250, +-0.567610016311628770, -0.567651180480010400, -0.567692343229264100, -0.567733504559286840, -0.567774664469976150, -0.567815822961228570, -0.567856980032941380, -0.567898135685012130, +-0.567939289917337110, -0.567980442729813850, -0.568021594122339550, -0.568062744094811610, -0.568103892647126460, -0.568145039779181520, -0.568186185490874410, -0.568227329782101440, +-0.568268472652760150, -0.568309614102747720, -0.568350754131961230, -0.568391892740298220, -0.568433029927655100, -0.568474165693929390, -0.568515300039018620, -0.568556432962819320, +-0.568597564465228800, -0.568638694546144460, -0.568679823205463400, -0.568720950443083130, -0.568762076258900070, -0.568803200652811870, -0.568844323624716040, -0.568885445174509010, +-0.568926565302088410, -0.568967684007351430, -0.569008801290195490, -0.569049917150517230, -0.569091031588214170, -0.569132144603183950, -0.569173256195323000, -0.569214366364528820, +-0.569255475110698740, -0.569296582433730050, -0.569337688333520160, -0.569378792809965840, -0.569419895862964380, -0.569460997492413630, -0.569502097698210030, -0.569543196480251200, +-0.569584293838434340, -0.569625389772656750, -0.569666484282816080, -0.569707577368808730, -0.569748669030532890, -0.569789759267885000, -0.569830848080762680, -0.569871935469063340, +-0.569913021432684070, -0.569954105971522630, -0.569995189085475530, -0.570036270774440520, -0.570077351038315140, -0.570118429876996120, -0.570159507290380900, -0.570200583278366980, +-0.570241657840851570, -0.570282730977732410, -0.570323802688906030, -0.570364872974270190, -0.570405941833722510, -0.570447009267159630, -0.570488075274479200, -0.570529139855578520, +-0.570570203010355440, -0.570611264738706490, -0.570652325040529320, -0.570693383915721770, -0.570734441364180390, -0.570775497385802800, -0.570816551980486530, -0.570857605148128890, +-0.570898656888627620, -0.570939707201879370, -0.570980756087781760, -0.571021803546232780, -0.571062849577128830, -0.571103894180367670, -0.571144937355846930, -0.571185979103463690, +-0.571227019423115930, -0.571268058314700290, -0.571309095778114510, -0.571350131813256330, -0.571391166420022520, -0.571432199598310710, -0.571473231348018420, -0.571514261669043400, +-0.571555290561282400, -0.571596318024633180, -0.571637344058993580, -0.571678368664260140, -0.571719391840330830, -0.571760413587103060, -0.571801433904474240, -0.571842452792342140, +-0.571883470250603600, -0.571924486279156370, -0.571965500877898330, -0.572006514046726200, -0.572047525785537640, -0.572088536094230380, -0.572129544972701740, -0.572170552420849690, +-0.572211558438570740, -0.572252563025763330, -0.572293566182324190, -0.572334567908151070, -0.572375568203141620, -0.572416567067193240, -0.572457564500203690, -0.572498560502069930, +-0.572539555072689830, -0.572580548211961140, -0.572621539919780710, -0.572662530196046520, -0.572703519040655860, -0.572744506453506500, -0.572785492434496170, -0.572826476983521850, +-0.572867460100481280, -0.572908441785272340, -0.572949422037792090, -0.572990400857938180, -0.573031378245608350, -0.573072354200700350, -0.573113328723111160, -0.573154301812738630, +-0.573195273469480630, -0.573236243693234230, -0.573277212483897070, -0.573318179841367010, -0.573359145765541480, -0.573400110256318430, -0.573441073313594730, -0.573482034937268240, +-0.573522995127237150, -0.573563953883398200, -0.573604911205649380, -0.573645867093888210, -0.573686821548012430, -0.573727774567920010, -0.573768726153507710, -0.573809676304673940, +-0.573850625021315670, -0.573891572303330880, -0.573932518150617080, -0.573973462563072020, -0.574014405540593690, -0.574055347083078930, -0.574096287190425820, -0.574137225862532350, +-0.574178163099295480, -0.574219098900613180, -0.574260033266383090, -0.574300966196502950, -0.574341897690870740, -0.574382827749383540, -0.574423756371939100, -0.574464683558435720, +-0.574505609308770260, -0.574546533622840800, -0.574587456500544990, -0.574628377941780900, -0.574669297946445500, -0.574710216514436880, -0.574751133645653110, -0.574792049339991060, +-0.574832963597348920, -0.574873876417624330, -0.574914787800715140, -0.574955697746519220, -0.574996606254933870, -0.575037513325856840, -0.575078418959186430, -0.575119323154819620, +-0.575160225912654590, -0.575201127232588870, -0.575242027114520440, -0.575282925558347260, -0.575323822563966300, -0.575364718131275880, -0.575405612260174060, -0.575446504950557820, +-0.575487396202325250, -0.575528286015374310, -0.575569174389602980, -0.575610061324908330, -0.575650946821188450, -0.575691830878341640, -0.575732713496264870, -0.575773594674856340, +-0.575814474414013900, -0.575855352713635190, -0.575896229573618410, -0.575937104993860750, -0.575977978974260400, -0.576018851514715320, -0.576059722615122840, -0.576100592275381020, +-0.576141460495387720, -0.576182327275040820, -0.576223192614238490, -0.576264056512877710, -0.576304918970857230, -0.576345779988074010, -0.576386639564426370, -0.576427497699812160, +-0.576468354394129250, -0.576509209647275700, -0.576550063459148830, -0.576590915829646830, -0.576631766758667790, -0.576672616246109100, -0.576713464291868870, -0.576754310895844840, +-0.576795156057935190, -0.576835999778037900, -0.576876842056050280, -0.576917682891870620, -0.576958522285397010, -0.576999360236526870, -0.577040196745158160, -0.577081031811189080, +-0.577121865434517820, -0.577162697615041460, -0.577203528352658310, -0.577244357647266780, -0.577285185498763950, -0.577326011907048130, -0.577366836872017400, -0.577407660393569500, +-0.577448482471602740, -0.577489303106014540, -0.577530122296702970, -0.577570940043566570, -0.577611756346502410, -0.577652571205408800, -0.577693384620183830, -0.577734196590725340, +-0.577775007116931750, -0.577815816198700370, -0.577856623835929280, -0.577897430028517120, -0.577938234776360970, -0.577979038079359240, -0.578019839937410020, -0.578060640350411380, +-0.578101439318260860, -0.578142236840856860, -0.578183032918097470, -0.578223827549880220, -0.578264620736103300, -0.578305412476664890, -0.578346202771462980, -0.578386991620395860, +-0.578427779023360960, -0.578468564980256560, -0.578509349490981210, -0.578550132555432080, -0.578590914173507500, -0.578631694345105750, -0.578672473070124820, -0.578713250348462990, +-0.578754026180017590, -0.578794800564687570, -0.578835573502370250, -0.578876344992963920, -0.578917115036366780, -0.578957883632476800, -0.578998650781192500, -0.579039416482411200, +-0.579080180736031290, -0.579120943541951430, -0.579161704900068800, -0.579202464810281810, -0.579243223272488780, -0.579283980286587670, -0.579324735852476900, -0.579365489970053990, +-0.579406242639217360, -0.579446993859865420, -0.579487743631895700, -0.579528491955206610, -0.579569238829696240, -0.579609984255263220, -0.579650728231804860, -0.579691470759219670, +-0.579732211837406200, -0.579772951466261730, -0.579813689645684920, -0.579854426375573940, -0.579895161655826890, -0.579935895486342280, -0.579976627867017540, -0.580017358797751290, +-0.580058088278441960, -0.580098816308987080, -0.580139542889285040, -0.580180268019234280, -0.580220991698732760, -0.580261713927679220, -0.580302434705970980, -0.580343154033506670, +-0.580383871910184810, -0.580424588335902940, -0.580465303310559570, -0.580506016834053010, -0.580546728906281670, -0.580587439527143200, -0.580628148696536120, -0.580668856414359060, +-0.580709562680509440, -0.580750267494885900, -0.580790970857386730, -0.580831672767910150, -0.580872373226354770, -0.580913072232618120, -0.580953769786598630, -0.580994465888195260, +-0.581035160537305310, -0.581075853733827420, -0.581116545477659900, -0.581157235768701040, -0.581197924606849380, -0.581238611992002660, -0.581279297924059750, -0.581319982402918160, +-0.581360665428476640, -0.581401347000633510, -0.581442027119286940, -0.581482705784335700, -0.581523382995677300, -0.581564058753210490, -0.581604733056833910, -0.581645405906445090, +-0.581686077301942770, -0.581726747243225260, -0.581767415730190860, -0.581808082762738320, -0.581848748340765280, -0.581889412464170250, -0.581930075132852110, -0.581970736346708370, +-0.582011396105637790, -0.582052054409538780, -0.582092711258309970, -0.582133366651849000, -0.582174020590054630, -0.582214673072825590, -0.582255324100059420, -0.582295973671655090, +-0.582336621787510780, -0.582377268447524800, -0.582417913651596120, -0.582458557399622270, -0.582499199691501990, -0.582539840527134150, -0.582580479906416260, -0.582621117829247190, +-0.582661754295525360, -0.582702389305149170, -0.582743022858017270, -0.582783654954027510, -0.582824285593078640, -0.582864914775069410, -0.582905542499897460, -0.582946168767461750, +-0.582986793577660590, -0.583027416930392840, -0.583068038825556020, -0.583108659263049330, -0.583149278242771190, -0.583189895764619550, -0.583230511828493170, -0.583271126434290580, +-0.583311739581910070, -0.583352351271250620, -0.583392961502209870, -0.583433570274686790, -0.583474177588580110, -0.583514783443787710, -0.583555387840208220, -0.583595990777740380, +-0.583636592256282500, -0.583677192275733450, -0.583717790835991070, -0.583758387936954670, -0.583798983578521890, -0.583839577760591590, -0.583880170483062400, -0.583920761745832850, +-0.583961351548801690, -0.584001939891866770, -0.584042526774927070, -0.584083112197881340, -0.584123696160627540, -0.584164278663064420, -0.584204859705090620, -0.584245439286604660, +-0.584286017407505520, -0.584326594067690940, -0.584367169267059890, -0.584407743005511350, -0.584448315282942940, -0.584488886099253870, -0.584529455454342540, -0.584570023348107930, +-0.584610589780447890, -0.584651154751261390, -0.584691718260447300, -0.584732280307903700, -0.584772840893529210, -0.584813400017222820, -0.584853957678882820, -0.584894513878408300, +-0.584935068615697110, -0.584975621890648220, -0.585016173703160720, -0.585056724053132360, -0.585097272940462210, -0.585137820365048910, -0.585178366326791100, -0.585218910825587630, +-0.585259453861336600, -0.585299995433937290, -0.585340535543287580, -0.585381074189286530, -0.585421611371832800, -0.585462147090825110, -0.585502681346162350, -0.585543214137742570, +-0.585583745465464660, -0.585624275329227780, -0.585664803728929930, -0.585705330664470060, -0.585745856135746810, -0.585786380142658940, -0.585826902685105510, -0.585867423762984400, +-0.585907943376194780, -0.585948461524635640, -0.585988978208204950, -0.586029493426801880, -0.586070007180325090, -0.586110519468673540, -0.586151030291745420, -0.586191539649439710, +-0.586232047541655590, -0.586272553968290810, -0.586313058929244790, -0.586353562424416050, -0.586394064453703460, -0.586434565017005970, -0.586475064114221790, -0.586515561745249990, +-0.586556057909989550, -0.586596552608338650, -0.586637045840196380, -0.586677537605461490, -0.586718027904032710, -0.586758516735809250, -0.586799004100689190, -0.586839489998571610, +-0.586879974429355580, -0.586920457392939300, -0.586960938889221960, -0.587001418918102200, -0.587041897479479210, -0.587082374573251190, -0.587122850199317200, -0.587163324357576450, +-0.587203797047927020, -0.587244268270268100, -0.587284738024498430, -0.587325206310516990, -0.587365673128222960, -0.587406138477514330, -0.587446602358290380, -0.587487064770450210, +-0.587527525713892110, -0.587567985188515160, -0.587608443194218230, -0.587648899730900180, -0.587689354798460300, -0.587729808396796560, -0.587770260525808720, -0.587810711185394960, +-0.587851160375454260, -0.587891608095885810, -0.587932054346588240, -0.587972499127460970, -0.588012942438402080, -0.588053384279310750, -0.588093824650086420, -0.588134263550627150, +-0.588174700980832130, -0.588215136940600460, -0.588255571429830870, -0.588296004448422780, -0.588336435996274280, -0.588376866073284650, -0.588417294679353330, -0.588457721814378390, +-0.588498147478259010, -0.588538571670894410, -0.588578994392183750, -0.588619415642025130, -0.588659835420318080, -0.588700253726961660, -0.588740670561854420, -0.588781085924895420, +-0.588821499815983640, -0.588861912235018160, -0.588902323181898280, -0.588942732656522190, -0.588983140658789320, -0.589023547188598950, -0.589063952245849400, -0.589104355830439850, +-0.589144757942269500, -0.589185158581237210, -0.589225557747242500, -0.589265955440183340, -0.589306351659959480, -0.589346746406470000, -0.589387139679613310, -0.589427531479288720, +-0.589467921805395420, -0.589508310657832600, -0.589548698036498560, -0.589589083941292950, -0.589629468372114830, -0.589669851328862850, -0.589710232811436090, -0.589750612819733840, +-0.589790991353654980, -0.589831368413099020, -0.589871743997964380, -0.589912118108150250, -0.589952490743556270, -0.589992861904080620, -0.590033231589622950, -0.590073599800082120, +-0.590113966535357300, -0.590154331795347930, -0.590194695579952300, -0.590235057889070380, -0.590275418722600360, -0.590315778080441890, -0.590356135962493920, -0.590396492368655660, +-0.590436847298826510, -0.590477200752904880, -0.590517552730790210, -0.590557903232382110, -0.590598252257578780, -0.590638599806279860, -0.590678945878384540, -0.590719290473791680, +-0.590759633592401130, -0.590799975234110990, -0.590840315398820980, -0.590880654086430530, -0.590920991296838060, -0.590961327029943200, -0.591001661285644910, -0.591041994063842950, +-0.591082325364435500, -0.591122655187322320, -0.591162983532402930, -0.591203310399575630, -0.591243635788740060, -0.591283959699795410, -0.591324282132640880, -0.591364603087175980, +-0.591404922563299240, -0.591445240560910190, -0.591485557079908350, -0.591525872120192250, -0.591566185681661530, -0.591606497764215370, -0.591646808367752850, -0.591687117492173840, +-0.591727425137376530, -0.591767731303260660, -0.591808035989725870, -0.591848339196670680, -0.591888640923994620, -0.591928941171596890, -0.591969239939377220, -0.592009537227234040, +-0.592049833035067090, -0.592090127362775890, -0.592130420210258970, -0.592170711577416080, -0.592211001464146290, -0.592251289870349140, -0.592291576795924040, -0.592331862240769610, +-0.592372146204785620, -0.592412428687871580, -0.592452709689926140, -0.592492989210848810, -0.592533267250539120, -0.592573543808896260, -0.592613818885819880, -0.592654092481208480, +-0.592694364594962390, -0.592734635226979890, -0.592774904377160960, -0.592815172045404570, -0.592855438231610350, -0.592895702935677950, -0.592935966157505880, -0.592976227896993890, +-0.593016488154041730, -0.593056746928547930, -0.593097004220412230, -0.593137260029534150, -0.593177514355812780, -0.593217767199148090, -0.593258018559438600, -0.593298268436584060, +-0.593338516830484220, -0.593378763741037710, -0.593419009168144270, -0.593459253111703330, -0.593499495571614630, -0.593539736547776810, -0.593579976040089610, -0.593620214048452890, +-0.593660450572765290, -0.593700685612926550, -0.593740919168836090, -0.593781151240393210, -0.593821381827498000, -0.593861610930048860, -0.593901838547945760, -0.593942064681088340, +-0.593982289329375470, -0.594022512492706880, -0.594062734170981990, -0.594102954364100320, -0.594143173071961520, -0.594183390294464430, -0.594223606031508920, -0.594263820282994850, +-0.594304033048820730, -0.594344244328886550, -0.594384454123091820, -0.594424662431336180, -0.594464869253518600, -0.594505074589538940, -0.594545278439296830, -0.594585480802691250, +-0.594625681679621930, -0.594665881069988410, -0.594706078973690100, -0.594746275390627080, -0.594786470320697980, -0.594826663763802670, -0.594866855719841100, -0.594907046188712040, +-0.594947235170315340, -0.594987422664550510, -0.595027608671317210, -0.595067793190515170, -0.595107976222043260, -0.595148157765801880, -0.595188337821689670, -0.595228516389606610, +-0.595268693469452330, -0.595308869061126230, -0.595349043164528410, -0.595389215779557610, -0.595429386906113690, -0.595469556544096720, -0.595509724693405460, -0.595549891353939990, +-0.595590056525599710, -0.595630220208284270, -0.595670382401893630, -0.595710543106326760, -0.595750702321483530, -0.595790860047263780, -0.595831016283566610, -0.595871171030291860, +-0.595911324287339280, -0.595951476054608630, -0.595991626331998980, -0.596031775119410300, -0.596071922416742560, -0.596112068223894510, -0.596152212540766450, -0.596192355367257790, +-0.596232496703268280, -0.596272636548697780, -0.596312774903445360, -0.596352911767411120, -0.596393047140494900, -0.596433181022595680, -0.596473313413613540, -0.596513444313448100, +-0.596553573721999020, -0.596593701639166360, -0.596633828064849100, -0.596673952998947650, -0.596714076441360990, -0.596754198391989070, -0.596794318850731640, -0.596834437817488460, +-0.596874555292159600, -0.596914671274643930, -0.596954785764841620, -0.596994898762652660, -0.597035010267976120, -0.597075120280711970, -0.597115228800760180, -0.597155335828020160, +-0.597195441362392220, -0.597235545403775330, -0.597275647952069550, -0.597315749007175100, -0.597355848568990820, -0.597395946637417020, -0.597436043212353220, -0.597476138293699720, +-0.597516231881355610, -0.597556323975220850, -0.597596414575195630, -0.597636503681178930, -0.597676591293071050, -0.597716677410771720, -0.597756762034180710, -0.597796845163198090, +-0.597836926797723050, -0.597877006937655660, -0.597917085582896140, -0.597957162733343540, -0.597997238388898070, -0.598037312549459470, -0.598077385214927480, -0.598117456385202530, +-0.598157526060183580, -0.598197594239770700, -0.598237660923864320, -0.598277726112363410, -0.598317789805168140, -0.598357852002178390, -0.598397912703294340, -0.598437971908415190, +-0.598478029617441120, -0.598518085830272330, -0.598558140546808000, -0.598598193766948230, -0.598638245490593080, -0.598678295717642310, -0.598718344447996100, -0.598758391681553650, +-0.598798437418215260, -0.598838481657881120, -0.598878524400450420, -0.598918565645823460, -0.598958605393900000, -0.598998643644580110, -0.599038680397763980, -0.599078715653350690, +-0.599118749411240990, -0.599158781671334180, -0.599198812433530350, -0.599238841697729450, -0.599278869463831470, -0.599318895731736580, -0.599358920501344210, -0.599398943772554540, +-0.599438965545267880, -0.599478985819383410, -0.599519004594801450, -0.599559021871421960, -0.599599037649145020, -0.599639051927870700, -0.599679064707498540, -0.599719075987928620, +-0.599759085769061450, -0.599799094050796120, -0.599839100833033050, -0.599879106115672300, -0.599919109898614080, -0.599959112181757790, -0.599999112965003740, -0.600039112248252240, +-0.600079110031402570, -0.600119106314355170, -0.600159101097009870, -0.600199094379267000, -0.600239086161026610, -0.600279076442188250, -0.600319065222652100, -0.600359052502318800, +-0.600399038281087320, -0.600439022558858390, -0.600479005335531890, -0.600518986611007780, -0.600558966385186690, -0.600598944657967700, -0.600638921429251460, -0.600678896698938150, +-0.600718870466927290, -0.600758842733119300, -0.600798813497414150, -0.600838782759712360, -0.600878750519913350, -0.600918716777917310, -0.600958681533624860, -0.600998644786935430, +-0.601038606537749320, -0.601078566785966720, -0.601118525531487700, -0.601158482774212690, -0.601198438514041200, -0.601238392750873540, -0.601278345484610230, -0.601318296715150800, +-0.601358246442395550, -0.601398194666244670, -0.601438141386598350, -0.601478086603357000, -0.601518030316420150, -0.601557972525688540, -0.601597913231061600, -0.601637852432439950, +-0.601677790129723560, -0.601717726322812840, -0.601757661011607990, -0.601797594196008760, -0.601837525875915550, -0.601877456051228780, -0.601917384721848080, -0.601957311887673980, +-0.601997237548606570, -0.602037161704546020, -0.602077084355392870, -0.602117005501046740, -0.602156925141408060, -0.602196843276377460, -0.602236759905854350, -0.602276675029739360, +-0.602316588647932690, -0.602356500760334980, -0.602396411366845520, -0.602436320467365170, -0.602476228061794240, -0.602516134150032470, -0.602556038731980380, -0.602595941807538060, +-0.602635843376606030, -0.602675743439084700, -0.602715641994873600, -0.602755539043873470, -0.602795434585984840, -0.602835328621107220, -0.602875221149141380, -0.602915112169987390, +-0.602955001683545650, -0.602994889689716820, -0.603034776188400290, -0.603074661179496930, -0.603114544662907260, -0.603154426638530810, -0.603194307106268310, -0.603234186066020080, +-0.603274063517686640, -0.603313939461167850, -0.603353813896364110, -0.603393686823176180, -0.603433558241503690, -0.603473428151247380, -0.603513296552307340, -0.603553163444584210, +-0.603593028827978490, -0.603632892702389840, -0.603672755067718890, -0.603712615923866490, -0.603752475270732170, -0.603792333108216670, -0.603832189436220300, -0.603872044254643470, +-0.603911897563386920, -0.603951749362350300, -0.603991599651434560, -0.604031448430539570, -0.604071295699565860, -0.604111141458414050, -0.604150985706984220, -0.604190828445177350, +-0.604230669672893070, -0.604270509390032130, -0.604310347596495270, -0.604350184292182120, -0.604390019476993560, -0.604429853150829980, -0.604469685313591800, -0.604509515965179660, +-0.604549345105493410, -0.604589172734433800, -0.604628998851901580, -0.604668823457796600, -0.604708646552019500, -0.604748468134470700, -0.604788288205051260, -0.604828106763660610, +-0.604867923810199710, -0.604907739344569430, -0.604947553366669390, -0.604987365876400450, -0.605027176873663140, -0.605066986358357870, -0.605106794330385500, -0.605146600789645770, +-0.605186405736039550, -0.605226209169467680, -0.605266011089829910, -0.605305811497027110, -0.605345610390959800, -0.605385407771528490, -0.605425203638634060, -0.605464997992176120, +-0.605504790832055770, -0.605544582158173860, -0.605584371970430020, -0.605624160268725340, -0.605663947052960230, -0.605703732323035540, -0.605743516078851240, -0.605783298320308080, +-0.605823079047307140, -0.605862858259748060, -0.605902635957531910, -0.605942412140559110, -0.605982186808730280, -0.606021959961946300, -0.606061731600107120, -0.606101501723113610, +-0.606141270330866730, -0.606181037423266340, -0.606220803000213300, -0.606260567061608250, -0.606300329607351810, -0.606340090637344840, -0.606379850151487320, -0.606419608149680540, +-0.606459364631824370, -0.606499119597819880, -0.606538873047567480, -0.606578624980967930, -0.606618375397922180, -0.606658124298330100, -0.606697871682092770, -0.606737617549111040, +-0.606777361899284990, -0.606817104732515490, -0.606856846048703270, -0.606896585847748970, -0.606936324129553450, -0.606976060894016790, -0.607015796141040060, -0.607055529870524140, +-0.607095262082368970, -0.607134992776475760, -0.607174721952745020, -0.607214449611077840, -0.607254175751374190, -0.607293900373535030, -0.607333623477461560, -0.607373345063053630, +-0.607413065130212430, -0.607452783678838480, -0.607492500708832540, -0.607532216220095790, -0.607571930212528090, -0.607611642686030520, -0.607651353640504270, -0.607691063075849300, +-0.607730770991966600, -0.607770477388757000, -0.607810182266121270, -0.607849885623960360, -0.607889587462174360, -0.607929287780664800, -0.607968986579331740, -0.608008683858076050, +-0.608048379616798810, -0.608088073855400530, -0.608127766573782420, -0.608167457771844560, -0.608207147449488120, -0.608246835606614080, -0.608286522243122520, -0.608326207358914850, +-0.608365890953891490, -0.608405573027953510, -0.608445253581001880, -0.608484932612936790, -0.608524610123659440, -0.608564286113070900, -0.608603960581071140, -0.608643633527561680, +-0.608683304952442940, -0.608722974855616110, -0.608762643236982150, -0.608802310096441150, -0.608841975433894840, -0.608881639249243210, -0.608921301542387440, -0.608960962313228380, +-0.609000621561667010, -0.609040279287604400, -0.609079935490940750, -0.609119590171577240, -0.609159243329415070, -0.609198894964354530, -0.609238545076296710, -0.609278193665142460, +-0.609317840730792870, -0.609357486273148900, -0.609397130292110960, -0.609436772787580130, -0.609476413759457710, -0.609516053207643900, -0.609555691132040000, -0.609595327532546860, +-0.609634962409065780, -0.609674595761496960, -0.609714227589741590, -0.609753857893700960, -0.609793486673275490, -0.609833113928366140, -0.609872739658874120, -0.609912363864700160, +-0.609951986545745670, -0.609991607701910970, -0.610031227333097110, -0.610070845439205640, -0.610110462020136630, -0.610150077075791500, -0.610189690606071090, -0.610229302610876600, +-0.610268913090109110, -0.610308522043669030, -0.610348129471458000, -0.610387735373376210, -0.610427339749325170, -0.610466942599205750, -0.610506543922918920, -0.610546143720366200, +-0.610585741991447660, -0.610625338736064840, -0.610664933954119030, -0.610704527645510530, -0.610744119810140650, -0.610783710447910470, -0.610823299558721060, -0.610862887142473720, +-0.610902473199068870, -0.610942057728407820, -0.610981640730391960, -0.611021222204921610, -0.611060802151898290, -0.611100380571222850, -0.611139957462796920, -0.611179532826520710, +-0.611219106662295620, -0.611258678970023170, -0.611298249749603670, -0.611337819000938530, -0.611377386723928830, -0.611416952918475640, -0.611456517584480500, -0.611496080721843690, +-0.611535642330466640, -0.611575202410250870, -0.611614760961096680, -0.611654317982905700, -0.611693873475578800, -0.611733427439017370, -0.611772979873122620, -0.611812530777795070, +-0.611852080152936240, -0.611891627998447430, -0.611931174314229390, -0.611970719100183300, -0.612010262356210370, -0.612049804082212210, -0.612089344278089250, -0.612128882943742790, +-0.612168420079074570, -0.612207955683984890, -0.612247489758375400, -0.612287022302147150, -0.612326553315201250, -0.612366082797439430, -0.612405610748762100, -0.612445137169070560, +-0.612484662058266680, -0.612524185416250750, -0.612563707242924300, -0.612603227538188740, -0.612642746301944930, -0.612682263534094720, -0.612721779234538410, -0.612761293403178090, +-0.612800806039914160, -0.612840317144648260, -0.612879826717281470, -0.612919334757715210, -0.612958841265850870, -0.612998346241589110, -0.613037849684831550, -0.613077351595479600, +-0.613116851973434020, -0.613156350818596210, -0.613195848130867580, -0.613235343910149330, -0.613274838156343090, -0.613314330869349390, -0.613353822049069960, -0.613393311695406230, +-0.613432799808258820, -0.613472286387529490, -0.613511771433119410, -0.613551254944930240, -0.613590736922862590, -0.613630217366818110, -0.613669696276698430, -0.613709173652404180, +-0.613748649493837010, -0.613788123800898200, -0.613827596573489060, -0.613867067811511240, -0.613906537514865460, -0.613946005683453370, -0.613985472317176480, -0.614024937415935670, +-0.614064400979632550, -0.614103863008168330, -0.614143323501444520, -0.614182782459362750, -0.614222239881823670, -0.614261695768728910, -0.614301150119980320, -0.614340602935478540, +-0.614380054215125200, -0.614419503958821830, -0.614458952166469950, -0.614498398837970310, -0.614537843973224750, -0.614577287572134920, -0.614616729634601460, -0.614656170160526210, +-0.614695609149810580, -0.614735046602355890, -0.614774482518063990, -0.614813916896835400, -0.614853349738572090, -0.614892781043175800, -0.614932210810547160, -0.614971639040588050, +-0.615011065733199750, -0.615050490888283900, -0.615089914505742020, -0.615129336585475080, -0.615168757127385170, -0.615208176131373020, -0.615247593597340490, -0.615287009525188890, +-0.615326423914819730, -0.615365836766134990, -0.615405248079035180, -0.615444657853422280, -0.615484066089198150, -0.615523472786263400, -0.615562877944520030, -0.615602281563869540, +-0.615641683644213230, -0.615681084185453090, -0.615720483187489950, -0.615759880650225470, -0.615799276573561820, -0.615838670957399530, -0.615878063801640560, -0.615917455106186450, +-0.615956844870938940, -0.615996233095799100, -0.616035619780668680, -0.616075004925449530, -0.616114388530042520, -0.616153770594349500, -0.616193151118272110, -0.616232530101711750, +-0.616271907544570510, -0.616311283446749130, -0.616350657808149570, -0.616390030628673700, -0.616429401908222370, -0.616468771646697560, -0.616508139844000770, -0.616547506500033650, +-0.616586871614698160, -0.616626235187895170, -0.616665597219526520, -0.616704957709494180, -0.616744316657699240, -0.616783674064043440, -0.616823029928428410, -0.616862384250756230, +-0.616901737030927650, -0.616941088268844750, -0.616980437964409600, -0.617019786117522840, -0.617059132728086770, -0.617098477796002800, -0.617137821321172560, -0.617177163303498140, +-0.617216503742880510, -0.617255842639221620, -0.617295179992423560, -0.617334515802387070, -0.617373850069014350, -0.617413182792206920, -0.617452513971866620, -0.617491843607895330, +-0.617531171700194110, -0.617570498248665390, -0.617609823253210010, -0.617649146713730060, -0.617688468630127270, -0.617727789002303300, -0.617767107830160090, -0.617806425113598960, +-0.617845740852521640, -0.617885055046830330, -0.617924367696426110, -0.617963678801210840, -0.618002988361086470, -0.618042296375954650, -0.618081602845717340, -0.618120907770275730, +-0.618160211149531900, -0.618199512983387820, -0.618238813271744570, -0.618278112014504440, -0.618317409211568860, -0.618356704862840220, -0.618395998968219400, -0.618435291527608680, +-0.618474582540910030, -0.618513872008024550, -0.618553159928854400, -0.618592446303301350, -0.618631731131267130, -0.618671014412654040, -0.618710296147362950, -0.618749576335296260, +-0.618788854976355830, -0.618828132070443070, -0.618867407617459840, -0.618906681617308110, -0.618945954069889730, -0.618985224975106770, -0.619024494332860440, -0.619063762143052920, +-0.619103028405586290, -0.619142293120361730, -0.619181556287281440, -0.619220817906247280, -0.619260077977161430, -0.619299336499924970, -0.619338593474440200, -0.619377848900609320, +-0.619417102778333510, -0.619456355107514840, -0.619495605888055300, -0.619534855119856840, -0.619574102802821550, -0.619613348936850610, -0.619652593521846320, -0.619691836557710870, +-0.619731078044345570, -0.619770317981652500, -0.619809556369533610, -0.619848793207890880, -0.619888028496626500, -0.619927262235641650, -0.619966494424839090, -0.620005725064119880, +-0.620044954153386450, -0.620084181692540540, -0.620123407681484220, -0.620162632120119680, -0.620201855008348240, -0.620241076346072170, -0.620280296133193800, -0.620319514369614300, +-0.620358731055235980, -0.620397946189960800, -0.620437159773690850, -0.620476371806328310, -0.620515582287774480, -0.620554791217931780, -0.620593998596702390, -0.620633204423987620, +-0.620672408699689870, -0.620711611423711120, -0.620750812595953660, -0.620790012216318800, -0.620829210284708940, -0.620868406801026400, -0.620907601765172570, -0.620946795177049650, +-0.620985987036559720, -0.621025177343604850, -0.621064366098087460, -0.621103553299908740, -0.621142738948971100, -0.621181923045176940, -0.621221105588427690, -0.621260286578625640, +-0.621299466015672990, -0.621338643899471580, -0.621377820229923940, -0.621416995006931370, -0.621456168230396620, -0.621495339900221210, -0.621534510016307330, -0.621573678578557280, +-0.621612845586873020, -0.621652011041156860, -0.621691174941310430, -0.621730337287236150, -0.621769498078836300, -0.621808657316012310, -0.621847814998666700, -0.621886971126701550, +-0.621926125700019040, -0.621965278718521470, -0.622004430182110380, -0.622043580090688280, -0.622082728444157460, -0.622121875242419580, -0.622161020485377030, -0.622200164172931780, +-0.622239306304986580, -0.622278446881442740, -0.622317585902202760, -0.622356723367169300, -0.622395859276243520, -0.622434993629328190, -0.622474126426325270, -0.622513257667137170, +-0.622552387351666180, -0.622591515479813840, -0.622630642051482770, -0.622669767066575510, -0.622708890524993340, -0.622748012426639130, -0.622787132771414730, -0.622826251559222550, +-0.622865368789965120, -0.622904484463543850, -0.622943598579861370, -0.622982711138820310, -0.623021822140322090, -0.623060931584269340, -0.623100039470564250, -0.623139145799109340, +-0.623178250569806360, -0.623217353782557600, -0.623256455437265930, -0.623295555533832760, -0.623334654072160600, -0.623373751052151870, -0.623412846473708760, -0.623451940336733900, +-0.623491032641128820, -0.623530123386796140, -0.623569212573638510, -0.623608300201557550, -0.623647386270455790, -0.623686470780235540, -0.623725553730799190, -0.623764635122049270, +-0.623803714953887420, -0.623842793226216610, -0.623881869938938460, -0.623920945091955610, -0.623960018685170480, -0.623999090718485250, -0.624038161191802660, -0.624077230105024360, +-0.624116297458052970, -0.624155363250791130, -0.624194427483140580, -0.624233490155003960, -0.624272551266283560, -0.624311610816881800, -0.624350668806701430, -0.624389725235643960, +-0.624428780103612250, -0.624467833410508820, -0.624506885156235540, -0.624545935340695020, -0.624584983963789700, -0.624624031025422300, -0.624663076525494350, -0.624702120463908830, +-0.624741162840568350, -0.624780203655374570, -0.624819242908230320, -0.624858280599037920, -0.624897316727699770, -0.624936351294118730, -0.624975384298196550, -0.625014415739835740, +-0.625053445618939390, -0.625092473935409010, -0.625131500689147470, -0.625170525880057170, -0.625209549508040530, -0.625248571573000400, -0.625287592074838420, -0.625326611013457550, +-0.625365628388760530, -0.625404644200649010, -0.625443658449025830, -0.625482671133793630, -0.625521682254855050, -0.625560691812111940, -0.625599699805467040, -0.625638706234823210, +-0.625677711100082410, -0.625716714401147180, -0.625755716137920250, -0.625794716310304030, -0.625833714918201390, -0.625872711961514060, -0.625911707440144900, -0.625950701353996890, +-0.625989693702971860, -0.626028684486972460, -0.626067673705901440, -0.626106661359661200, -0.626145647448154600, -0.626184631971283600, -0.626223614928951290, -0.626262596321059740, +-0.626301576147511590, -0.626340554408209570, -0.626379531103056110, -0.626418506231954160, -0.626457479794805590, -0.626496451791513360, -0.626535422221980330, -0.626574391086108460, +-0.626613358383800500, -0.626652324114959190, -0.626691288279487170, -0.626730250877287180, -0.626769211908261180, -0.626808171372312260, -0.626847129269343160, -0.626886085599255960, +-0.626925040361953510, -0.626963993557338450, -0.627002945185313740, -0.627041895245781360, -0.627080843738644260, -0.627119790663805300, -0.627158736021166560, -0.627197679810631010, +-0.627236622032101290, -0.627275562685480010, -0.627314501770670050, -0.627353439287573590, -0.627392375236093590, -0.627431309616132920, -0.627470242427593640, -0.627509173670378730, +-0.627548103344390930, -0.627587031449532870, -0.627625957985707530, -0.627664882952816970, -0.627703806350764170, -0.627742728179452310, -0.627781648438783150, -0.627820567128659970, +-0.627859484248985300, -0.627898399799662330, -0.627937313780593030, -0.627976226191680360, -0.628015137032827520, -0.628054046303936460, -0.628092954004910390, -0.628131860135651810, +-0.628170764696063590, -0.628209667686048910, -0.628248569105509640, -0.628287468954348950, -0.628326367232469930, -0.628365263939774650, -0.628404159076166200, -0.628443052641547430, +-0.628481944635820860, -0.628520835058889890, -0.628559723910656510, -0.628598611191024110, -0.628637496899894900, -0.628676381037171940, -0.628715263602757980, -0.628754144596555880, +-0.628793024018468700, -0.628831901868398770, -0.628870778146248920, -0.628909652851922570, -0.628948525985321690, -0.628987397546349580, -0.629026267534908870, -0.629065135950902520, +-0.629104002794233730, -0.629142868064804570, -0.629181731762518240, -0.629220593887277910, -0.629259454438985680, -0.629298313417544940, -0.629337170822858340, -0.629376026654829170, +-0.629414880913359620, -0.629453733598352770, -0.629492584709712030, -0.629531434247339480, -0.629570282211138310, -0.629609128601011480, -0.629647973416861740, -0.629686816658592500, +-0.629725658326105830, -0.629764498419305040, -0.629803336938093320, -0.629842173882372960, -0.629881009252047150, -0.629919843047018760, -0.629958675267190850, -0.629997505912466500, +-0.630036334982748140, -0.630075162477938930, -0.630113988397942080, -0.630152812742660000, -0.630191635511995860, -0.630230456705852540, -0.630269276324133540, -0.630308094366740960, +-0.630346910833578190, -0.630385725724548430, -0.630424539039553980, -0.630463350778498240, -0.630502160941284200, -0.630540969527814580, -0.630579776537993020, -0.630618581971721600, +-0.630657385828903850, -0.630696188109442830, -0.630734988813241080, -0.630773787940201780, -0.630812585490228120, -0.630851381463222950, -0.630890175859089570, -0.630928968677730520, +-0.630967759919049410, -0.631006549582948550, -0.631045337669331240, -0.631084124178100670, -0.631122909109159690, -0.631161692462411830, -0.631200474237759380, -0.631239254435105760, +-0.631278033054354370, -0.631316810095407630, -0.631355585558168730, -0.631394359442540850, -0.631433131748427190, -0.631471902475731040, -0.631510671624354700, -0.631549439194201700, +-0.631588205185175440, -0.631626969597178340, -0.631665732430113810, -0.631704493683885040, -0.631743253358395320, -0.631782011453547070, -0.631820767969243800, -0.631859522905389050, +-0.631898276261885110, -0.631937028038635380, -0.631975778235543180, -0.632014526852511470, -0.632053273889443880, -0.632092019346242710, -0.632130763222811480, -0.632169505519053710, +-0.632208246234871820, -0.632246985370169320, -0.632285722924849300, -0.632324458898815060, -0.632363193291969990, -0.632401926104216530, -0.632440657335458620, -0.632479386985598800, +-0.632518115054540480, -0.632556841542186830, -0.632595566448441170, -0.632634289773206790, -0.632673011516386440, -0.632711731677883530, -0.632750450257601680, -0.632789167255443320, +-0.632827882671312070, -0.632866596505111120, -0.632905308756743670, -0.632944019426113340, -0.632982728513122540, -0.633021436017674910, -0.633060141939674080, -0.633098846279022460, +-0.633137549035623800, -0.633176250209381290, -0.633214949800198550, -0.633253647807977990, -0.633292344232623260, -0.633331039074038090, -0.633369732332125010, -0.633408424006787540, +-0.633447114097929090, -0.633485802605452840, -0.633524489529262320, -0.633563174869260390, -0.633601858625350460, -0.633640540797436150, -0.633679221385420210, -0.633717900389206170, +-0.633756577808697430, -0.633795253643797300, -0.633833927894409290, -0.633872600560436150, -0.633911271641781400, -0.633949941138349020, -0.633988609050041290, -0.634027275376762070, +-0.634065940118414660, -0.634104603274902810, -0.634143264846129040, -0.634181924831997090, -0.634220583232410710, -0.634259240047272520, -0.634297895276486280, -0.634336548919955280, +-0.634375200977582930, -0.634413851449272760, -0.634452500334927840, -0.634491147634451580, -0.634529793347747730, -0.634568437474719140, -0.634607080015269440, -0.634645720969301940, +-0.634684360336720270, -0.634722998117427940, -0.634761634311327820, -0.634800268918323970, -0.634838901938319160, -0.634877533371217000, -0.634916163216921010, -0.634954791475334620, +-0.634993418146361680, -0.635032043229904810, -0.635070666725867760, -0.635109288634154500, -0.635147908954667550, -0.635186527687310990, -0.635225144831988000, -0.635263760388602110, +-0.635302374357057160, -0.635340986737256030, -0.635379597529102450, -0.635418206732500050, -0.635456814347351910, -0.635495420373561770, -0.635534024811033050, -0.635572627659669600, +-0.635611228919374160, -0.635649828590050700, -0.635688426671603080, -0.635727023163934040, -0.635765618066947420, -0.635804211380546660, -0.635842803104635480, -0.635881393239117630, +-0.635919981783895860, -0.635958568738874240, -0.635997154103956520, -0.636035737879045550, -0.636074320064045300, -0.636112900658859170, -0.636151479663390810, -0.636190057077544060, +-0.636228632901221890, -0.636267207134328160, -0.636305779776766720, -0.636344350828440430, -0.636382920289253360, -0.636421488159108930, -0.636460054437911090, -0.636498619125562830, +-0.636537182221967980, -0.636575743727030520, -0.636614303640653410, -0.636652861962740510, -0.636691418693195450, -0.636729973831921870, -0.636768527378823720, -0.636807079333803870, +-0.636845629696766280, -0.636884178467615030, -0.636922725646252960, -0.636961271232584060, -0.636999815226511950, -0.637038357627940370, -0.637076898436773290, -0.637115437652913450, +-0.637153975276265490, -0.637192511306732270, -0.637231045744217740, -0.637269578588625540, -0.637308109839859420, -0.637346639497823330, -0.637385167562420360, -0.637423694033554480, +-0.637462218911129750, -0.637500742195049040, -0.637539263885216530, -0.637577783981535860, -0.637616302483910660, -0.637654819392245110, -0.637693334706442180, -0.637731848426405850, +-0.637770360552040280, -0.637808871083248460, -0.637847380019934460, -0.637885887362002020, -0.637924393109355230, -0.637962897261897030, -0.638001399819531630, -0.638039900782163110, +-0.638078400149694520, -0.638116897922029860, -0.638155394099072960, -0.638193888680727570, -0.638232381666897890, -0.638270873057486750, -0.638309362852398590, -0.638347851051537240, +-0.638386337654806010, -0.638424822662108980, -0.638463306073349780, -0.638501787888432370, -0.638540268107260830, -0.638578746729738240, -0.638617223755768790, -0.638655699185256660, +-0.638694173018104940, -0.638732645254217800, -0.638771115893499000, -0.638809584935852710, -0.638848052381182250, -0.638886518229391580, -0.638924982480384870, -0.638963445134065560, +-0.639001906190337480, -0.639040365649104710, -0.639078823510271010, -0.639117279773740550, -0.639155734439416650, -0.639194187507203360, -0.639232638977004890, -0.639271088848724520, +-0.639309537122266460, -0.639347983797534550, -0.639386428874432640, -0.639424872352865050, -0.639463314232734840, -0.639501754513946750, -0.639540193196403980, -0.639578630280010610, +-0.639617065764670810, -0.639655499650288230, -0.639693931936767270, -0.639732362624011230, -0.639770791711924190, -0.639809219200410560, -0.639847645089373530, -0.639886069378717390, +-0.639924492068346010, -0.639962913158163450, -0.640001332648073910, -0.640039750537980790, -0.640078166827788180, -0.640116581517400580, -0.640154994606721210, -0.640193406095654230, +-0.640231815984103840, -0.640270224271974220, -0.640308630959168680, -0.640347036045591620, -0.640385439531147240, -0.640423841415738940, -0.640462241699271130, -0.640500640381647560, +-0.640539037462772520, -0.640577432942550100, -0.640615826820883920, -0.640654219097678060, -0.640692609772837040, -0.640730998846264050, -0.640769386317863730, -0.640807772187539810, +-0.640846156455196490, -0.640884539120738170, -0.640922920184068160, -0.640961299645090850, -0.640999677503710560, -0.641038053759830810, -0.641076428413355880, -0.641114801464189870, +-0.641153172912237170, -0.641191542757401310, -0.641229910999586480, -0.641268277638697310, -0.641306642674637000, -0.641345006107310160, -0.641383367936620870, -0.641421728162473000, +-0.641460086784771290, -0.641498443803418920, -0.641536799218320520, -0.641575153029380400, -0.641613505236502070, -0.641651855839590060, -0.641690204838548330, -0.641728552233281070, +-0.641766898023692800, -0.641805242209686930, -0.641843584791168320, -0.641881925768040370, -0.641920265140207720, -0.641958602907574340, -0.641996939070044400, -0.642035273627522440, +-0.642073606579912080, -0.642111937927117630, -0.642150267669043600, -0.642188595805593730, -0.642226922336672220, -0.642265247262183480, -0.642303570582031580, -0.642341892296121150, +-0.642380212404355610, -0.642418530906639470, -0.642456847802877480, -0.642495163092972940, -0.642533476776830590, -0.642571788854354400, -0.642610099325449210, -0.642648408190018340, +-0.642686715447966520, -0.642725021099198160, -0.642763325143617000, -0.642801627581127580, -0.642839928411633950, -0.642878227635040540, -0.642916525251251980, -0.642954821260171670, +-0.642993115661704360, -0.643031408455754570, -0.643069699642225930, -0.643107989221023080, -0.643146277192050200, -0.643184563555211700, -0.643222848310411990, -0.643261131457554920, +-0.643299412996545360, -0.643337692927286930, -0.643375971249684260, -0.643414247963641660, -0.643452523069063420, -0.643490796565854280, -0.643529068453917770, -0.643567338733158520, +-0.643605607403481380, -0.643643874464789880, -0.643682139916988530, -0.643720403759981960, -0.643758665993674370, -0.643796926617970500, -0.643835185632773870, -0.643873443037989320, +-0.643911698833521510, -0.643949953019274160, -0.643988205595151910, -0.644026456561059060, -0.644064705916900460, -0.644102953662579750, -0.644141199798001660, -0.644179444323070950, +-0.644217687237691240, -0.644255928541767390, -0.644294168235203690, -0.644332406317904450, -0.644370642789774630, -0.644408877650717860, -0.644447110900638890, -0.644485342539442560, +-0.644523572567032410, -0.644561800983313390, -0.644600027788189920, -0.644638252981566300, -0.644676476563347370, -0.644714698533436990, -0.644752918891739800, -0.644791137638160650, +-0.644829354772603390, -0.644867570294972660, -0.644905784205173080, -0.644943996503109300, -0.644982207188685260, -0.645020416261805620, -0.645058623722375320, -0.645096829570298120, +-0.645135033805478870, -0.645173236427821980, -0.645211437437232080, -0.645249636833613920, -0.645287834616871230, -0.645326030786909090, -0.645364225343632140, -0.645402418286944220, +-0.645440609616750430, -0.645478799332954930, -0.645516987435462490, -0.645555173924178050, -0.645593358799005150, -0.645631542059849290, -0.645669723706614240, -0.645707903739204840, +-0.645746082157525710, -0.645784258961481390, -0.645822434150976730, -0.645860607725915690, -0.645898779686203020, -0.645936950031743900, -0.645975118762441960, -0.646013285878202170, +-0.646051451378929280, -0.646089615264527680, -0.646127777534902470, -0.646165938189957380, -0.646204097229597600, -0.646242254653727750, -0.646280410462252040, -0.646318564655075200, +-0.646356717232101970, -0.646394868193237330, -0.646433017538385220, -0.646471165267450520, -0.646509311380338180, -0.646547455876952280, -0.646585598757197790, -0.646623740020979220, +-0.646661879668201320, -0.646700017698769170, -0.646738154112586510, -0.646776288909558520, -0.646814422089590060, -0.646852553652585320, -0.646890683598449150, -0.646928811927086290, +-0.646966938638401380, -0.647005063732299380, -0.647043187208684480, -0.647081309067461640, -0.647119429308535830, -0.647157547931811130, -0.647195664937192490, -0.647233780324584670, +-0.647271894093892850, -0.647310006245020890, -0.647348116777873960, -0.647386225692357040, -0.647424332988374210, -0.647462438665830530, -0.647500542724630870, -0.647538645164679740, +-0.647576745985882330, -0.647614845188142720, -0.647652942771366090, -0.647691038735457410, -0.647729133080320760, -0.647767225805861320, -0.647805316911983730, -0.647843406398592950, +-0.647881494265593940, -0.647919580512890780, -0.647957665140389110, -0.647995748147992880, -0.648033829535607400, -0.648071909303137180, -0.648109987450487310, -0.648148063977562750, +-0.648186138884267680, -0.648224212170507300, -0.648262283836186780, -0.648300353881210100, -0.648338422305482550, -0.648376489108908990, -0.648414554291394270, -0.648452617852843470, +-0.648490679793160660, -0.648528740112251260, -0.648566798810020330, -0.648604855886372070, -0.648642911341211660, -0.648680965174443960, -0.648719017385974260, -0.648757067975706650, +-0.648795116943546300, -0.648833164289398520, -0.648871210013167500, -0.648909254114758530, -0.648947296594076350, -0.648985337451025930, -0.649023376685512470, -0.649061414297440350, +-0.649099450286714560, -0.649137484653240620, -0.649175517396922470, -0.649213548517665660, -0.649251578015374920, -0.649289605889955210, -0.649327632141311840, -0.649365656769349100, +-0.649403679773972180, -0.649441701155086480, -0.649479720912596090, -0.649517739046406420, -0.649555755556422420, -0.649593770442549290, -0.649631783704691550, -0.649669795342754150, +-0.649707805356642740, -0.649745813746261500, -0.649783820511515620, -0.649821825652310280, -0.649859829168550340, -0.649897831060141210, -0.649935831326987070, -0.649973829968993440, +-0.650011826986065520, -0.650049822378107710, -0.650087816145025420, -0.650125808286723510, -0.650163798803107040, -0.650201787694081430, -0.650239774959551100, -0.650277760599421660, +-0.650315744613597420, -0.650353727001983790, -0.650391707764485850, -0.650429686901008770, -0.650467664411457650, -0.650505640295737100, -0.650543614553752430, -0.650581587185409150, +-0.650619558190611460, -0.650657527569264870, -0.650695495321274580, -0.650733461446545420, -0.650771425944983050, -0.650809388816491640, -0.650847350060976940, -0.650885309678344020, +-0.650923267668497620, -0.650961224031343040, -0.650999178766785370, -0.651037131874730110, -0.651075083355081570, -0.651113033207745500, -0.651150981432627060, -0.651188928029630910, +-0.651226872998662330, -0.651264816339626630, -0.651302758052428880, -0.651340698136974590, -0.651378636593168300, -0.651416573420915300, -0.651454508620121220, -0.651492442190690580, +-0.651530374132528790, -0.651568304445541040, -0.651606233129632620, -0.651644160184708940, -0.651682085610674420, -0.651720009407434800, -0.651757931574895370, -0.651795852112960870, +-0.651833771021536720, -0.651871688300528220, -0.651909603949840650, -0.651947517969378890, -0.651985430359048320, -0.652023341118754480, -0.652061250248402000, -0.652099157747896290, +-0.652137063617142740, -0.652174967856046560, -0.652212870464513260, -0.652250771442447470, -0.652288670789754720, -0.652326568506340630, -0.652364464592109840, -0.652402359046967860, +-0.652440251870819890, -0.652478143063571440, -0.652516032625127920, -0.652553920555393960, -0.652591806854275540, -0.652629691521677270, -0.652667574557504790, -0.652705455961663290, +-0.652743335734058180, -0.652781213874595200, -0.652819090383178760, -0.652856965259714480, -0.652894838504108230, -0.652932710116264640, -0.652970580096089100, -0.653008448443487270, +-0.653046315158364200, -0.653084180240625760, -0.653122043690176460, -0.653159905506922040, -0.653197765690768260, -0.653235624241619740, -0.653273481159382110, -0.653311336443960780, +-0.653349190095261490, -0.653387042113188880, -0.653424892497648570, -0.653462741248546530, -0.653500588365787170, -0.653538433849276350, -0.653576277698919460, -0.653614119914621930, +-0.653651960496289370, -0.653689799443826660, -0.653727636757139410, -0.653765472436133370, -0.653803306480713280, -0.653841138890784990, -0.653878969666253810, -0.653916798807025250, +-0.653954626313005050, -0.653992452184097850, -0.654030276420209940, -0.654068099021245960, -0.654105919987111760, -0.654143739317712750, -0.654181557012954440, -0.654219373072742580, +-0.654257187496981810, -0.654295000285578190, -0.654332811438437360, -0.654370620955464170, -0.654408428836564470, -0.654446235081643680, -0.654484039690607310, -0.654521842663361110, +-0.654559643999810040, -0.654597443699859840, -0.654635241763416360, -0.654673038190384470, -0.654710832980670010, -0.654748626134178390, -0.654786417650815240, -0.654824207530486310, +-0.654861995773096670, -0.654899782378552290, -0.654937567346758120, -0.654975350677620030, -0.655013132371043530, -0.655050912426934250, -0.655088690845198050, -0.655126467625739780, +-0.655164242768465300, -0.655202016273280560, -0.655239788140090430, -0.655277558368800860, -0.655315326959317380, -0.655353093911545610, -0.655390859225391420, -0.655428622900759650, +-0.655466384937556490, -0.655504145335687570, -0.655541904095058080, -0.655579661215573760, -0.655617416697140240, -0.655655170539663600, -0.655692922743048690, -0.655730673307201360, +-0.655768422232027800, -0.655806169517432870, -0.655843915163322410, -0.655881659169602170, -0.655919401536177890, -0.655957142262955430, -0.655994881349839630, -0.656032618796736800, +-0.656070354603552670, -0.656108088770192330, -0.656145821296561740, -0.656183552182566630, -0.656221281428112650, -0.656259009033105740, -0.656296734997451110, -0.656334459321054830, +-0.656372182003822190, -0.656409903045659050, -0.656447622446471150, -0.656485340206164110, -0.656523056324644140, -0.656560770801816180, -0.656598483637586330, -0.656636194831860530, +-0.656673904384543980, -0.656711612295542650, -0.656749318564762260, -0.656787023192108580, -0.656824726177487660, -0.656862427520804590, -0.656900127221965560, -0.656937825280876410, +-0.656975521697442440, -0.657013216471569630, -0.657050909603163810, -0.657088601092131070, -0.657126290938376490, -0.657163979141806130, -0.657201665702326190, -0.657239350619841730, +-0.657277033894258840, -0.657314715525483480, -0.657352395513421280, -0.657390073857978430, -0.657427750559060000, -0.657465425616572290, -0.657503099030421370, -0.657540770800512210, +-0.657578440926751330, -0.657616109409044140, -0.657653776247296820, -0.657691441441415340, -0.657729104991304990, -0.657766766896871750, -0.657804427158022010, -0.657842085774660860, +-0.657879742746694470, -0.657917398074028830, -0.657955051756569990, -0.657992703794223030, -0.658030354186894480, -0.658068002934490300, -0.658105650036915790, -0.658143295494077240, +-0.658180939305880290, -0.658218581472231110, -0.658256221993035790, -0.658293860868199630, -0.658331498097628700, -0.658369133681229400, -0.658406767618907040, -0.658444399910567690, +-0.658482030556117310, -0.658519659555461880, -0.658557286908507570, -0.658594912615159790, -0.658632536675325060, -0.658670159088908580, -0.658707779855816740, -0.658745398975955520, +-0.658783016449230760, -0.658820632275548770, -0.658858246454814830, -0.658895858986935370, -0.658933469871816560, -0.658971079109363700, -0.659008686699483200, -0.659046292642080920, +-0.659083896937062930, -0.659121499584335520, -0.659159100583804110, -0.659196699935374890, -0.659234297638954250, -0.659271893694447500, -0.659309488101761040, -0.659347080860800960, +-0.659384671971473440, -0.659422261433683880, -0.659459849247338690, -0.659497435412344180, -0.659535019928605750, -0.659572602796029810, -0.659610184014522320, -0.659647763583989350, +-0.659685341504337440, -0.659722917775471760, -0.659760492397298730, -0.659798065369724850, -0.659835636692655440, -0.659873206365997000, -0.659910774389655510, -0.659948340763537140, +-0.659985905487548210, -0.660023468561594110, -0.660061029985581470, -0.660098589759416490, -0.660136147883004790, -0.660173704356252670, -0.660211259179066200, -0.660248812351352020, +-0.660286363873015420, -0.660323913743963040, -0.660361461964101060, -0.660399008533335220, -0.660436553451571710, -0.660474096718716930, -0.660511638334676850, -0.660549178299358110, +-0.660586716612665990, -0.660624253274507130, -0.660661788284787940, -0.660699321643413940, -0.660736853350291640, -0.660774383405327240, -0.660811911808426800, -0.660849438559496960, +-0.660886963658443240, -0.660924487105172380, -0.660962008899590000, -0.660999529041602640, -0.661037047531116360, -0.661074564368037580, -0.661112079552272580, -0.661149593083727120, +-0.661187104962307700, -0.661224615187920860, -0.661262123760472110, -0.661299630679868080, -0.661337135946014950, -0.661374639558818920, -0.661412141518186720, -0.661449641824023770, +-0.661487140476236800, -0.661524637474732220, -0.661562132819415780, -0.661599626510193990, -0.661637118546973160, -0.661674608929659790, -0.661712097658159640, -0.661749584732379210, +-0.661787070152225150, -0.661824553917603090, -0.661862036028419640, -0.661899516484581120, -0.661936995285993810, -0.661974472432564240, -0.662011947924198260, -0.662049421760802390, +-0.662086893942283370, -0.662124364468546720, -0.662161833339499180, -0.662199300555046940, -0.662236766115096630, -0.662274230019554650, -0.662311692268326760, -0.662349152861319570, +-0.662386611798439940, -0.662424069079593390, -0.662461524704686670, -0.662498978673626170, -0.662536430986318540, -0.662573881642669500, -0.662611330642585820, -0.662648777985974100, +-0.662686223672740100, -0.662723667702790450, -0.662761110076031780, -0.662798550792370270, -0.662835989851712660, -0.662873427253964810, -0.662910862999033350, -0.662948297086825120, +-0.662985729517245770, -0.663023160290202140, -0.663060589405600530, -0.663098016863347570, -0.663135442663349780, -0.663172866805513130, -0.663210289289744680, -0.663247710115950070, +-0.663285129284036270, -0.663322546793909560, -0.663359962645476590, -0.663397376838643970, -0.663434789373317570, -0.663472200249404230, -0.663509609466810700, -0.663547017025442830, +-0.663584422925207360, -0.663621827166010920, -0.663659229747759930, -0.663696630670361110, -0.663734029933720440, -0.663771427537744650, -0.663808823482340600, -0.663846217767414260, +-0.663883610392872360, -0.663921001358621310, -0.663958390664568190, -0.663995778310618730, -0.664033164296679910, -0.664070548622658350, -0.664107931288460240, -0.664145312293992210, +-0.664182691639160990, -0.664220069323873010, -0.664257445348035100, -0.664294819711553350, -0.664332192414334500, -0.664369563456285510, -0.664406932837312230, -0.664444300557321730, +-0.664481666616220430, -0.664519031013914960, -0.664556393750312170, -0.664593754825318130, -0.664631114238839690, -0.664668471990783830, -0.664705828081056490, -0.664743182509564430, +-0.664780535276214610, -0.664817886380913660, -0.664855235823567650, -0.664892583604083650, -0.664929929722368420, -0.664967274178328130, -0.665004616971869520, -0.665041958102899460, +-0.665079297571324560, -0.665116635377051680, -0.665153971519986900, -0.665191306000037170, -0.665228638817109470, -0.665265969971109870, -0.665303299461945330, -0.665340627289522590, +-0.665377953453748280, -0.665415277954529370, -0.665452600791772040, -0.665489921965383480, -0.665527241475269760, -0.665564559321337960, -0.665601875503494700, -0.665639190021646730, +-0.665676502875701240, -0.665713814065564070, -0.665751123591142410, -0.665788431452343340, -0.665825737649072710, -0.665863042181237820, -0.665900345048745400, -0.665937646251501980, +-0.665974945789414850, -0.666012243662389980, -0.666049539870334550, -0.666086834413155530, -0.666124127290759200, -0.666161418503052440, -0.666198708049942190, -0.666235995931335530, +-0.666273282147138550, -0.666310566697258300, -0.666347849581601980, -0.666385130800075780, -0.666422410352586650, -0.666459688239041560, -0.666496964459347250, -0.666534239013410800, +-0.666571511901138500, -0.666608783122437320, -0.666646052677214660, -0.666683320565376380, -0.666720586786829880, -0.666757851341481910, -0.666795114229239320, -0.666832375450009280, +-0.666869635003698000, -0.666906892890212880, -0.666944149109460200, -0.666981403661347170, -0.667018656545780740, -0.667055907762667540, -0.667093157311914870, -0.667130405193429140, +-0.667167651407117200, -0.667204895952886570, -0.667242138830643430, -0.667279380040294860, -0.667316619581747820, -0.667353857454909270, -0.667391093659686410, -0.667428328195985520, +-0.667465561063713800, -0.667502792262778420, -0.667540021793085800, -0.667577249654543130, -0.667614475847057240, -0.667651700370535670, -0.667688923224884380, -0.667726144410010770, +-0.667763363925822250, -0.667800581772224900, -0.667837797949126120, -0.667875012456432880, -0.667912225294052030, -0.667949436461890980, -0.667986645959856020, -0.668023853787854450, +-0.668061059945793570, -0.668098264433579780, -0.668135467251120160, -0.668172668398322010, -0.668209867875092180, -0.668247065681337960, -0.668284261816965760, -0.668321456281882890, +-0.668358649075996740, -0.668395840199213610, -0.668433029651440910, -0.668470217432585610, -0.668507403542555110, -0.668544587981255820, -0.668581770748595040, -0.668618951844480170, +-0.668656131268817510, -0.668693309021514580, -0.668730485102478340, -0.668767659511615990, -0.668804832248834690, -0.668842003314041090, -0.668879172707142370, -0.668916340428046150, +-0.668953506476658740, -0.668990670852887440, -0.669027833556639640, -0.669064994587822090, -0.669102153946342540, -0.669139311632107160, -0.669176467645023920, -0.669213621984999120, +-0.669250774651940270, -0.669287925645754460, -0.669325074966348850, -0.669362222613630990, -0.669399368587507150, -0.669436512887884860, -0.669473655514671640, -0.669510796467774010, +-0.669547935747099250, -0.669585073352554790, -0.669622209284047590, -0.669659343541485260, -0.669696476124774120, -0.669733607033821900, -0.669770736268536000, -0.669807863828822850, +-0.669844989714590060, -0.669882113925744820, -0.669919236462194640, -0.669956357323845950, -0.669993476510606480, -0.670030594022383630, -0.670067709859083930, -0.670104824020614890, +-0.670141936506883920, -0.670179047317798090, -0.670216156453264930, -0.670253263913191070, -0.670290369697484010, -0.670327473806051290, -0.670364576238799750, -0.670401676995636690, +-0.670438776076469290, -0.670475873481205080, -0.670512969209751560, -0.670550063262015270, -0.670587155637903720, -0.670624246337324650, -0.670661335360184680, -0.670698422706391460, +-0.670735508375852050, -0.670772592368474200, -0.670809674684164530, -0.670846755322830780, -0.670883834284380360, -0.670920911568720140, -0.670957987175757500, -0.670995061105399970, +-0.671032133357554850, -0.671069203932129540, -0.671106272829031130, -0.671143340048166890, -0.671180405589444580, -0.671217469452771050, -0.671254531638053820, -0.671291592145200180, +-0.671328650974117650, -0.671365708124713860, -0.671402763596895320, -0.671439817390570350, -0.671476869505645450, -0.671513919942028360, -0.671550968699626490, -0.671588015778347150, +-0.671625061178098170, -0.671662104898786190, -0.671699146940318850, -0.671736187302604090, -0.671773225985548450, -0.671810262989059880, -0.671847298313045570, -0.671884331957413040, +-0.671921363922069910, -0.671958394206923160, -0.671995422811880290, -0.672032449736849280, -0.672069474981736860, -0.672106498546450770, -0.672143520430898310, -0.672180540634987440, +-0.672217559158624910, -0.672254576001718450, -0.672291591164175920, -0.672328604645904050, -0.672365616446810700, -0.672402626566803270, -0.672439635005789290, -0.672476641763676500, +-0.672513646840371850, -0.672550650235783090, -0.672587651949818070, -0.672624651982383530, -0.672661650333387320, -0.672698647002736960, -0.672735641990340080, -0.672772635296104430, +-0.672809626919936840, -0.672846616861745070, -0.672883605121437300, -0.672920591698920050, -0.672957576594101270, -0.672994559806888600, -0.673031541337189900, -0.673068521184912010, +-0.673105499349962780, -0.673142475832250180, -0.673179450631681050, -0.673216423748163260, -0.673253395181604430, -0.673290364931912190, -0.673327332998994280, -0.673364299382757660, +-0.673401264083110410, -0.673438227099960260, -0.673475188433214190, -0.673512148082780260, -0.673549106048565880, -0.673586062330478690, -0.673623016928426740, -0.673659969842316910, +-0.673696921072057480, -0.673733870617555410, -0.673770818478718670, -0.673807764655454890, -0.673844709147671690, -0.673881651955277050, -0.673918593078177920, -0.673955532516282370, +-0.673992470269498270, -0.674029406337732670, -0.674066340720893550, -0.674103273418888650, -0.674140204431625480, -0.674177133759012230, -0.674214061400955740, -0.674250987357364110, +-0.674287911628145280, -0.674324834213206440, -0.674361755112455440, -0.674398674325800140, -0.674435591853148390, -0.674472507694407360, -0.674509421849485150, -0.674546334318289590, +-0.674583245100727870, -0.674620154196708070, -0.674657061606137920, -0.674693967328925170, -0.674730871364977670, -0.674767773714202820, -0.674804674376508370, -0.674841573351802730, +-0.674878470639992730, -0.674915366240986580, -0.674952260154692010, -0.674989152381016750, -0.675026042919869010, -0.675062931771155840, -0.675099818934785210, -0.675136704410665530, +-0.675173588198703660, -0.675210470298807870, -0.675247350710885820, -0.675284229434845900, -0.675321106470594960, -0.675357981818041190, -0.675394855477092880, -0.675431727447657120, +-0.675468597729641960, -0.675505466322955380, -0.675542333227505120, -0.675579198443199360, -0.675616061969945170, -0.675652923807650960, -0.675689783956224700, -0.675726642415573680, +-0.675763499185606080, -0.675800354266229640, -0.675837207657352450, -0.675874059358882450, -0.675910909370727060, -0.675947757692794690, -0.675984604324992520, -0.676021449267228960, +-0.676058292519411740, -0.676095134081448720, -0.676131973953248310, -0.676168812134717580, -0.676205648625764820, -0.676242483426298220, -0.676279316536225080, -0.676316147955453810, +-0.676352977683892020, -0.676389805721447800, -0.676426632068029440, -0.676463456723544130, -0.676500279687900160, -0.676537100961005940, -0.676573920542768550, -0.676610738433096380, +-0.676647554631897300, -0.676684369139079700, -0.676721181954550890, -0.676757993078219040, -0.676794802509992690, -0.676831610249778890, -0.676868416297486060, -0.676905220653022170, +-0.676942023316295270, -0.676978824287213680, -0.677015623565684680, -0.677052421151616570, -0.677089217044917870, -0.677126011245495650, -0.677162803753258440, -0.677199594568114290, +-0.677236383689971080, -0.677273171118737190, -0.677309956854320160, -0.677346740896628500, -0.677383523245569720, -0.677420303901052120, -0.677457082862983670, -0.677493860131272550, +-0.677530635705827170, -0.677567409586554810, -0.677604181773364010, -0.677640952266163050, -0.677677721064859240, -0.677714488169361310, -0.677751253579577110, -0.677788017295414710, +-0.677824779316782640, -0.677861539643588310, -0.677898298275740220, -0.677935055213146560, -0.677971810455714970, -0.678008564003353850, -0.678045315855971390, -0.678082066013475870, +-0.678118814475774930, -0.678155561242776980, -0.678192306314390430, -0.678229049690522780, -0.678265791371082450, -0.678302531355977620, -0.678339269645116590, -0.678376006238407660, +-0.678412741135758330, -0.678449474337077250, -0.678486205842272700, -0.678522935651252430, -0.678559663763924740, -0.678596390180197910, -0.678633114899980020, -0.678669837923179810, +-0.678706559249704580, -0.678743278879463060, -0.678779996812363560, -0.678816713048313810, -0.678853427587222220, -0.678890140428997090, -0.678926851573546930, -0.678963561020779370, +-0.679000268770602820, -0.679036974822926020, -0.679073679177656380, -0.679110381834702630, -0.679147082793972840, -0.679183782055375330, -0.679220479618818710, -0.679257175484210610, +-0.679293869651459550, -0.679330562120474160, -0.679367252891161950, -0.679403941963431680, -0.679440629337191520, -0.679477315012349870, -0.679513998988815150, -0.679550681266495200, +-0.679587361845298890, -0.679624040725133720, -0.679660717905908540, -0.679697393387531550, -0.679734067169911030, -0.679770739252955720, -0.679807409636573270, -0.679844078320672280, +-0.679880745305161400, -0.679917410589948370, -0.679954074174941690, -0.679990736060049890, -0.680027396245181270, -0.680064054730244560, -0.680100711515147280, -0.680137366599798290, +-0.680174019984106090, -0.680210671667978660, -0.680247321651324510, -0.680283969934051940, -0.680320616516069900, -0.680357261397285920, -0.680393904577608840, -0.680430546056947310, +-0.680467185835209150, -0.680503823912302910, -0.680540460288137190, -0.680577094962620310, -0.680613727935660990, -0.680650359207166990, -0.680686988777047140, -0.680723616645210190, +-0.680760242811563780, -0.680796867276016850, -0.680833490038477710, -0.680870111098854870, -0.680906730457057070, -0.680943348112992060, -0.680979964066568800, -0.681016578317695800, +-0.681053190866281130, -0.681089801712233430, -0.681126410855461330, -0.681163018295873450, -0.681199624033377750, -0.681236228067882870, -0.681272830399297870, -0.681309431027530390, +-0.681346029952489380, -0.681382627174083270, -0.681419222692220660, -0.681455816506810200, -0.681492408617759950, -0.681528999024978650, -0.681565587728375170, -0.681602174727857450, +-0.681638760023334230, -0.681675343614714160, -0.681711925501905740, -0.681748505684817820, -0.681785084163358260, -0.681821660937436350, -0.681858236006959940, -0.681894809371838000, +-0.681931381031979030, -0.681967950987291570, -0.682004519237684570, -0.682041085783065880, -0.682077650623344580, -0.682114213758429400, -0.682150775188228420, -0.682187334912650490, +-0.682223892931604240, -0.682260449244998180, -0.682297003852741390, -0.682333556754741720, -0.682370107950908240, -0.682406657441149810, -0.682443205225374380, -0.682479751303490810, +-0.682516295675408060, -0.682552838341034750, -0.682589379300279080, -0.682625918553049990, -0.682662456099256460, -0.682698991938806340, -0.682735526071608810, -0.682772058497572500, +-0.682808589216606030, -0.682845118228618380, -0.682881645533517600, -0.682918171131212780, -0.682954695021612770, -0.682991217204625740, -0.683027737680160670, -0.683064256448126180, +-0.683100773508431120, -0.683137288860984460, -0.683173802505694260, -0.683210314442469490, -0.683246824671219330, -0.683283333191851750, -0.683319840004275920, -0.683356345108400380, +-0.683392848504134290, -0.683429350191385840, -0.683465850170064000, -0.683502348440077840, -0.683538845001335440, -0.683575339853745970, -0.683611832997218170, -0.683648324431660790, +-0.683684814156982900, -0.683721302173092570, -0.683757788479899100, -0.683794273077311440, -0.683830755965237790, -0.683867237143587210, -0.683903716612268560, -0.683940194371190690, +-0.683976670420262560, -0.684013144759392460, -0.684049617388489910, -0.684086088307462870, -0.684122557516220640, -0.684159025014672070, -0.684195490802725900, -0.684231954880291320, +-0.684268417247276490, -0.684304877903590740, -0.684341336849143000, -0.684377794083841580, -0.684414249607595780, -0.684450703420314330, -0.684487155521906090, -0.684523605912280230, +-0.684560054591345170, -0.684596501559009860, -0.684632946815183720, -0.684669390359774810, -0.684705832192692430, -0.684742272313845430, -0.684778710723143110, -0.684815147420493760, +-0.684851582405806460, -0.684888015678990600, -0.684924447239954270, -0.684960877088606980, -0.684997305224857360, -0.685033731648614590, -0.685070156359787630, -0.685106579358285120, +-0.685143000644016120, -0.685179420216889930, -0.685215838076814850, -0.685252254223700170, -0.685288668657454970, -0.685325081377987980, -0.685361492385208600, -0.685397901679025260, +-0.685434309259347120, -0.685470715126083490, -0.685507119279142760, -0.685543521718434250, -0.685579922443867010, -0.685616321455350230, -0.685652718752792320, -0.685689114336102580, +-0.685725508205190400, -0.685761900359964090, -0.685798290800333050, -0.685834679526206360, -0.685871066537492970, -0.685907451834102180, -0.685943835415942390, -0.685980217282923020, +-0.686016597434953470, -0.686052975871942140, -0.686089352593798330, -0.686125727600431110, -0.686162100891749670, -0.686198472467663190, -0.686234842328080300, -0.686271210472910510, +-0.686307576902062460, -0.686343941615445540, -0.686380304612968620, -0.686416665894540980, -0.686453025460072030, -0.686489383309470180, -0.686525739442644830, -0.686562093859505510, +-0.686598446559960610, -0.686634797543919650, -0.686671146811291600, -0.686707494361985750, -0.686743840195911500, -0.686780184312977270, -0.686816526713092570, -0.686852867396166910, +-0.686889206362108820, -0.686925543610827690, -0.686961879142232610, -0.686998212956233200, -0.687034545052737980, -0.687070875431656350, -0.687107204092897830, -0.687143531036371050, +-0.687179856261985410, -0.687216179769650100, -0.687252501559274420, -0.687288821630767770, -0.687325139984038770, -0.687361456618996840, -0.687397771535551590, -0.687434084733611670, +-0.687470396213086480, -0.687506705973885300, -0.687543014015917440, -0.687579320339092300, -0.687615624943318520, -0.687651927828506040, -0.687688228994563390, -0.687724528441400200, +-0.687760826168925640, -0.687797122177049030, -0.687833416465679970, -0.687869709034726990, -0.687905999884099840, -0.687942289013707910, -0.687978576423459940, -0.688014862113265570, +-0.688051146083034080, -0.688087428332674670, -0.688123708862097060, -0.688159987671209780, -0.688196264759922570, -0.688232540128145050, -0.688268813775785860, -0.688305085702754620, +-0.688341355908960620, -0.688377624394313600, -0.688413891158722090, -0.688450156202096040, -0.688486419524344750, -0.688522681125377180, -0.688558941005102950, -0.688595199163431260, +-0.688631455600271610, -0.688667710315533640, -0.688703963309126090, -0.688740214580958690, -0.688776464130941070, -0.688812711958981860, -0.688848958064990910, -0.688885202448877630, +-0.688921445110551200, -0.688957686049921580, -0.688993925266897510, -0.689030162761388510, -0.689066398533304430, -0.689102632582554110, -0.689138864909047080, -0.689175095512692960, +-0.689211324393401490, -0.689247551551081310, -0.689283776985642250, -0.689320000696994060, -0.689356222685045590, -0.689392442949706590, -0.689428661490886440, -0.689464878308494570, +-0.689501093402440920, -0.689537306772634140, -0.689573518418984180, -0.689609728341400660, -0.689645936539792560, -0.689682143014069600, -0.689718347764141320, -0.689754550789917100, +-0.689790752091306910, -0.689826951668219390, -0.689863149520564930, -0.689899345648252280, -0.689935540051191180, -0.689971732729291240, -0.690007923682462000, -0.690044112910613290, +-0.690080300413653980, -0.690116486191493910, -0.690152670244042920, -0.690188852571209990, -0.690225033172904840, -0.690261212049037120, -0.690297389199516440, -0.690333564624252550, +-0.690369738323154510, -0.690405910296132070, -0.690442080543095190, -0.690478249063952720, -0.690514415858614730, -0.690550580926990620, -0.690586744268990360, -0.690622905884523020, +-0.690659065773498340, -0.690695223935826390, -0.690731380371415900, -0.690767535080177080, -0.690803688062019420, -0.690839839316852560, -0.690875988844586340, -0.690912136645129960, +-0.690948282718393150, -0.690984427064285980, -0.691020569682717410, -0.691056710573597410, -0.691092849736835600, -0.691128987172341720, -0.691165122880025630, -0.691201256859796500, +-0.691237389111564180, -0.691273519635238640, -0.691309648430729060, -0.691345775497945400, -0.691381900836797290, -0.691418024447194690, -0.691454146329046780, -0.691490266482263420, +-0.691526384906754780, -0.691562501602429820, -0.691598616569198630, -0.691634729806970830, -0.691670841315656260, -0.691706951095164890, -0.691743059145405900, -0.691779165466289150, +-0.691815270057724920, -0.691851372919622070, -0.691887474051890880, -0.691923573454441000, -0.691959671127182150, -0.691995767070024530, -0.692031861282877080, -0.692067953765650220, +-0.692104044518253360, -0.692140133540596230, -0.692176220832588780, -0.692212306394140890, -0.692248390225162490, -0.692284472325562780, -0.692320552695251830, -0.692356631334139940, +-0.692392708242136060, -0.692428783419150480, -0.692464856865092850, -0.692500928579873110, -0.692536998563401450, -0.692573066815586950, -0.692609133336339780, -0.692645198125570020, +-0.692681261183186960, -0.692717322509100790, -0.692753382103221350, -0.692789439965458720, -0.692825496095722190, -0.692861550493921950, -0.692897603159968070, -0.692933654093769950, +-0.692969703295237550, -0.693005750764281060, -0.693041796500810100, -0.693077840504734980, -0.693113882775964970, -0.693149923314410280, -0.693185962119981070, -0.693221999192586650, +-0.693258034532137190, -0.693294068138542660, -0.693330100011712910, -0.693366130151558350, -0.693402158557988040, -0.693438185230912390, -0.693474210170241580, -0.693510233375884910, +-0.693546254847752670, -0.693582274585754830, -0.693618292589801570, -0.693654308859802280, -0.693690323395667270, -0.693726336197306730, -0.693762347264629930, -0.693798356597547410, +-0.693834364195968890, -0.693870370059804560, -0.693906374188964500, -0.693942376583358330, -0.693978377242896130, -0.694014376167488290, -0.694050373357044230, -0.694086368811474230, +-0.694122362530688370, -0.694158354514596510, -0.694194344763109150, -0.694230333276135590, -0.694266320053586460, -0.694302305095371270, -0.694338288401400330, -0.694374269971583580, +-0.694410249805831210, -0.694446227904053530, -0.694482204266160030, -0.694518178892060910, -0.694554151781666800, -0.694590122934886870, -0.694626092351631640, -0.694662060031811300, +-0.694698025975335700, -0.694733990182115350, -0.694769952652059760, -0.694805913385079240, -0.694841872381084300, -0.694877829639984230, -0.694913785161689780, -0.694949738946110780, +-0.694985690993157770, -0.695021641302740130, -0.695057589874768510, -0.695093536709153190, -0.695129481805803700, -0.695165425164630420, -0.695201366785543670, -0.695237306668453510, +-0.695273244813270350, -0.695309181219903820, -0.695345115888264310, -0.695381048818262350, -0.695416980009807450, -0.695452909462810130, -0.695488837177180460, -0.695524763152828740, +-0.695560687389665370, -0.695596609887600080, -0.695632530646543180, -0.695668449666405290, -0.695704366947095920, -0.695740282488525710, -0.695776196290604720, -0.695812108353243590, +-0.695848018676351820, -0.695883927259840050, -0.695919834103618800, -0.695955739207597680, -0.695991642571687220, -0.696027544195797490, -0.696063444079839110, -0.696099342223722270, +-0.696135238627356820, -0.696171133290653280, -0.696207026213522260, -0.696242917395873300, -0.696278806837617110, -0.696314694538663790, -0.696350580498923840, -0.696386464718307780, +-0.696422347196725130, -0.696458227934086960, -0.696494106930302890, -0.696529984185283670, -0.696565859698939360, -0.696601733471180480, -0.696637605501917560, -0.696673475791060310, +-0.696709344338519390, -0.696745211144205400, -0.696781076208027980, -0.696816939529897980, -0.696852801109725580, -0.696888660947421300, -0.696924519042895540, -0.696960375396058260, +-0.696996230006819980, -0.697032082875091440, -0.697067934000782370, -0.697103783383803520, -0.697139631024065180, -0.697175476921478080, -0.697211321075951960, -0.697247163487397570, +-0.697283004155725530, -0.697318843080845690, -0.697354680262668780, -0.697390515701105220, -0.697426349396065290, -0.697462181347459740, -0.697498011555198530, -0.697533840019192270, +-0.697569666739351720, -0.697605491715586610, -0.697641314947807900, -0.697677136435925770, -0.697712956179850960, -0.697748774179493990, -0.697784590434764710, -0.697820404945574290, +-0.697856217711832590, -0.697892028733450350, -0.697927838010338090, -0.697963645542406090, -0.697999451329565420, -0.698035255371725730, -0.698071057668797960, -0.698106858220692850, +-0.698142657027320150, -0.698178454088590920, -0.698214249404415570, -0.698250042974704610, -0.698285834799368790, -0.698321624878318170, -0.698357413211463380, -0.698393199798715390, +-0.698428984639984150, -0.698464767735180400, -0.698500549084214770, -0.698536328686997780, -0.698572106543440150, -0.698607882653452080, -0.698643657016944530, -0.698679429633827560, +-0.698715200504012040, -0.698750969627408570, -0.698786737003927570, -0.698822502633480000, -0.698858266515975930, -0.698894028651326330, -0.698929789039441810, -0.698965547680232560, +-0.699001304573609320, -0.699037059719482930, -0.699072813117763920, -0.699108564768363140, -0.699144314671190650, -0.699180062826157300, -0.699215809233174170, -0.699251553892151320, +-0.699287296802999390, -0.699323037965629330, -0.699358777379952000, -0.699394515045877350, -0.699430250963316460, -0.699465985132180170, -0.699501717552378670, -0.699537448223822910, +-0.699573177146423530, -0.699608904320091150, -0.699644629744736850, -0.699680353420270680, -0.699716075346603520, -0.699751795523646640, -0.699787513951309890, -0.699823230629504360, +-0.699858945558140770, -0.699894658737129750, -0.699930370166382380, -0.699966079845808940, -0.700001787775320410, -0.700037493954827280, -0.700073198384240310, -0.700108901063470350, +-0.700144601992428120, -0.700180301171024700, -0.700215998599170280, -0.700251694276775800, -0.700287388203752470, -0.700323080380010340, -0.700358770805460500, -0.700394459480013660, +-0.700430146403580700, -0.700465831576072780, -0.700501514997399880, -0.700537196667473160, -0.700572876586203820, -0.700608554753502030, -0.700644231169278760, -0.700679905833444970, +-0.700715578745911730, -0.700751249906589210, -0.700786919315388610, -0.700822586972220880, -0.700858252876996550, -0.700893917029626450, -0.700929579430021650, -0.700965240078092800, +-0.701000898973751290, -0.701036556116907180, -0.701072211507471680, -0.701107865145355950, -0.701143517030470180, -0.701179167162725660, -0.701214815542033240, -0.701250462168303780, +-0.701286107041448450, -0.701321750161377650, -0.701357391528002360, -0.701393031141233970, -0.701428669000982660, -0.701464305107159620, -0.701499939459675930, -0.701535572058442640, +-0.701571202903370050, -0.701606831994369570, -0.701642459331352280, -0.701678084914228560, -0.701713708742909500, -0.701749330817306280, -0.701784951137329750, -0.701820569702891080, +-0.701856186513900690, -0.701891801570269870, -0.701927414871909790, -0.701963026418730980, -0.701998636210644510, -0.702034244247561560, -0.702069850529392860, -0.702105455056049930, +-0.702141057827442960, -0.702176658843483790, -0.702212258104082610, -0.702247855609150710, -0.702283451358599260, -0.702319045352339130, -0.702354637590281720, -0.702390228072337420, +-0.702425816798417530, -0.702461403768433360, -0.702496988982295510, -0.702532572439915070, -0.702568154141203220, -0.702603734086071020, -0.702639312274429770, -0.702674888706189880, +-0.702710463381262860, -0.702746036299559900, -0.702781607460991610, -0.702817176865469300, -0.702852744512904030, -0.702888310403207210, -0.702923874536289350, -0.702959436912061750, +-0.702994997530435820, -0.703030556391322170, -0.703066113494632110, -0.703101668840276810, -0.703137222428167230, -0.703172774258215010, -0.703208324330330430, -0.703243872644425120, +-0.703279419200410480, -0.703314963998196930, -0.703350507037695970, -0.703386048318818680, -0.703421587841476350, -0.703457125605580380, -0.703492661611041180, -0.703528195857770380, +-0.703563728345679480, -0.703599259074678910, -0.703634788044680160, -0.703670315255594430, -0.703705840707333220, -0.703741364399807170, -0.703776886332927560, -0.703812406506606150, +-0.703847924920753430, -0.703883441575280930, -0.703918956470099720, -0.703954469605121200, -0.703989980980256780, -0.704025490595417080, -0.704060998450513730, -0.704096504545458140, +-0.704132008880160920, -0.704167511454533710, -0.704203012268487800, -0.704238511321934270, -0.704274008614784840, -0.704309504146950040, -0.704344997918341820, -0.704380489928870810, +-0.704415980178448530, -0.704451468666986270, -0.704486955394395430, -0.704522440360587420, -0.704557923565473090, -0.704593405008963840, -0.704628884690971510, -0.704664362611406640, +-0.704699838770180830, -0.704735313167205390, -0.704770785802391720, -0.704806256675651330, -0.704841725786895080, -0.704877193136034360, -0.704912658722981140, -0.704948122547645940, +-0.704983584609940370, -0.705019044909775850, -0.705054503447064000, -0.705089960221715660, -0.705125415233642360, -0.705160868482755830, -0.705196319968966810, -0.705231769692187040, +-0.705267217652327800, -0.705302663849300520, -0.705338108283017020, -0.705373550953387830, -0.705408991860324800, -0.705444431003739550, -0.705479868383542930, -0.705515303999646570, +-0.705550737851962100, -0.705586169940400690, -0.705621600264874190, -0.705657028825293350, -0.705692455621569900, -0.705727880653615690, -0.705763303921341460, -0.705798725424658930, +-0.705834145163479640, -0.705869563137715320, -0.705904979347276810, -0.705940393792075740, -0.705975806472024070, -0.706011217387032540, -0.706046626537013000, -0.706082033921876850, +-0.706117439541535610, -0.706152843395901120, -0.706188245484884240, -0.706223645808396690, -0.706259044366350340, -0.706294441158656030, -0.706329836185225710, -0.706365229445970690, +-0.706400620940802690, -0.706436010669633460, -0.706471398632373850, -0.706506784828936030, -0.706542169259230970, -0.706577551923170510, -0.706612932820666170, -0.706648311951629470, +-0.706683689315972250, -0.706719064913605590, -0.706754438744441220, -0.706789810808391090, -0.706825181105366070, -0.706860549635278220, -0.706895916398038840, -0.706931281393559760, +-0.706966644621752740, -0.707002006082528830, -0.707037365775799900, -0.707072723701477890, -0.707108079859473770, -0.707143434249699390, -0.707178786872066480, -0.707214137726486890, +-0.707249486812871590, -0.707284834131132630, -0.707320179681181880, -0.707355523462930400, -0.707390865476290150, -0.707426205721172650, -0.707461544197489630, -0.707496880905153170, +-0.707532215844074110, -0.707567549014164520, -0.707602880415336370, -0.707638210047500720, -0.707673537910569530, -0.707708864004454540, -0.707744188329067380, -0.707779510884319900, +-0.707814831670123490, -0.707850150686390010, -0.707885467933031420, -0.707920783409958900, -0.707956097117084400, -0.707991409054319680, -0.708026719221576670, -0.708062027618766580, +-0.708097334245801460, -0.708132639102593280, -0.708167942189053210, -0.708203243505093230, -0.708238543050625170, -0.708273840825560770, -0.708309136829812110, -0.708344431063290260, +-0.708379723525907280, -0.708415014217575360, -0.708450303138205670, -0.708485590287710190, -0.708520875666000640, -0.708556159272988980, -0.708591441108587180, -0.708626721172706530, +-0.708661999465259320, -0.708697275986156840, -0.708732550735311160, -0.708767823712634140, -0.708803094918037500, -0.708838364351433440, -0.708873632012733120, -0.708908897901848860, +-0.708944162018692590, -0.708979424363175630, -0.709014684935210030, -0.709049943734707750, -0.709085200761580660, -0.709120456015740810, -0.709155709497099610, -0.709190961205569010, +-0.709226211141061440, -0.709261459303487940, -0.709296705692760820, -0.709331950308791930, -0.709367193151493550, -0.709402434220776760, -0.709437673516553960, -0.709472911038737330, +-0.709508146787237950, -0.709543380761968320, -0.709578612962840300, -0.709613843389765630, -0.709649072042656700, -0.709684298921424820, -0.709719524025982150, -0.709754747356240890, +-0.709789968912112550, -0.709825188693509300, -0.709860406700343120, -0.709895622932525840, -0.709930837389969870, -0.709966050072586510, -0.710001260980288260, -0.710036470112986540, +-0.710071677470593740, -0.710106883053021720, -0.710142086860182430, -0.710177288891988170, -0.710212489148350560, -0.710247687629181670, -0.710282884334393790, -0.710318079263898450, +-0.710353272417607930, -0.710388463795434190, -0.710423653397289300, -0.710458841223085560, -0.710494027272734470, -0.710529211546148340, -0.710564394043239340, -0.710599574763919220, +-0.710634753708100030, -0.710669930875694080, -0.710705106266613540, -0.710740279880769820, -0.710775451718075550, -0.710810621778442900, -0.710845790061783500, -0.710880956568009540, +-0.710916121297033190, -0.710951284248766520, -0.710986445423121950, -0.711021604820010870, -0.711056762439345900, -0.711091918281039350, -0.711127072345002610, -0.711162224631148200, +-0.711197375139388300, -0.711232523869634870, -0.711267670821800540, -0.711302815995796700, -0.711337959391535770, -0.711373101008930250, -0.711408240847891780, -0.711443378908332540, +-0.711478515190165030, -0.711513649693301440, -0.711548782417653400, -0.711583913363133420, -0.711619042529654020, -0.711654169917126600, -0.711689295525463890, -0.711724419354577750, +-0.711759541404380800, -0.711794661674785110, -0.711829780165702530, -0.711864896877045460, -0.711900011808726530, -0.711935124960657250, -0.711970236332750140, -0.712005345924917380, +-0.712040453737071370, -0.712075559769124510, -0.712110664020988440, -0.712145766492575990, -0.712180867183798800, -0.712215966094569500, -0.712251063224800250, -0.712286158574403250, +-0.712321252143291340, -0.712356343931375810, -0.712391433938569520, -0.712426522164784970, -0.712461608609933790, -0.712496693273928620, -0.712531776156681620, -0.712566857258105200, +-0.712601936578111990, -0.712637014116613620, -0.712672089873522710, -0.712707163848751880, -0.712742236042212870, -0.712777306453818320, -0.712812375083480390, -0.712847441931111940, +-0.712882506996624480, -0.712917570279930750, -0.712952631780943370, -0.712987691499574190, -0.713022749435735740, -0.713057805589340510, -0.713092859960300700, -0.713127912548529030, +-0.713162963353937250, -0.713198012376438100, -0.713233059615944190, -0.713268105072367380, -0.713303148745620290, -0.713338190635615320, -0.713373230742264890, -0.713408269065481710, +-0.713443305605177440, -0.713478340361265010, -0.713513373333657050, -0.713548404522265310, -0.713583433927002520, -0.713618461547781190, -0.713653487384513950, -0.713688511437112760, +-0.713723533705490350, -0.713758554189559250, -0.713793572889231620, -0.713828589804419880, -0.713863604935036870, -0.713898618280994770, -0.713933629842206320, -0.713968639618583590, +-0.714003647610039200, -0.714038653816486120, -0.714073658237835970, -0.714108660874001710, -0.714143661724895850, -0.714178660790430800, -0.714213658070519400, -0.714248653565073610, +-0.714283647274006390, -0.714318639197229820, -0.714353629334656630, -0.714388617686199320, -0.714423604251770540, -0.714458589031283120, -0.714493572024648800, -0.714528553231780550, +-0.714563532652591200, -0.714598510286992840, -0.714633486134898080, -0.714668460196219660, -0.714703432470870090, -0.714738402958762230, -0.714773371659808030, -0.714808338573920450, +-0.714843303701012340, -0.714878267040995660, -0.714913228593783370, -0.714948188359287860, -0.714983146337422330, -0.715018102528098500, -0.715053056931229450, -0.715088009546728130, +-0.715122960374506400, -0.715157909414477320, -0.715192856666553520, -0.715227802130647410, -0.715262745806672260, -0.715297687694539830, -0.715332627794163290, -0.715367566105455490, +-0.715402502628328390, -0.715437437362695050, -0.715472370308468110, -0.715507301465560190, -0.715542230833884460, -0.715577158413352790, -0.715612084203878230, -0.715647008205373640, +-0.715681930417751410, -0.715716850840924290, -0.715751769474805010, -0.715786686319306640, -0.715821601374341250, -0.715856514639821810, -0.715891426115661370, -0.715926335801772120, +-0.715961243698067020, -0.715996149804458910, -0.716031054120860320, -0.716065956647184310, -0.716100857383343280, -0.716135756329250080, -0.716170653484817680, -0.716205548849958460, +-0.716240442424585290, -0.716275334208611000, -0.716310224201948450, -0.716345112404510600, -0.716379998816209730, -0.716414883436959030, -0.716449766266670900, -0.716484647305258400, +-0.716519526552634290, -0.716554404008711290, -0.716589279673402580, -0.716624153546620460, -0.716659025628277880, -0.716693895918288030, -0.716728764416563190, -0.716763631123016330, +-0.716798496037560520, -0.716833359160108370, -0.716868220490573190, -0.716903080028867160, -0.716937937774903440, -0.716972793728595130, -0.717007647889854600, -0.717042500258594840, +-0.717077350834728900, -0.717112199618169850, -0.717147046608830110, -0.717181891806622620, -0.717216735211460790, -0.717251576823256800, -0.717286416641923830, -0.717321254667374840, +-0.717356090899522790, -0.717390925338280640, -0.717425757983561010, -0.717460588835276970, -0.717495417893341700, -0.717530245157667610, -0.717565070628167990, -0.717599894304755680, +-0.717634716187343540, -0.717669536275844950, -0.717704354570172230, -0.717739171070238550, -0.717773985775957300, -0.717808798687240790, -0.717843609804002300, -0.717878419126154800, +-0.717913226653611570, -0.717948032386284910, -0.717982836324088210, -0.718017638466934670, -0.718052438814736790, -0.718087237367407760, -0.718122034124860640, -0.718156829087008510, +-0.718191622253764540, -0.718226413625041250, -0.718261203200751930, -0.718295990980809870, -0.718330776965127480, -0.718365561153618270, -0.718400343546195090, -0.718435124142771110, +-0.718469902943259520, -0.718504679947572940, -0.718539455155624900, -0.718574228567328000, -0.718609000182595440, -0.718643770001340500, -0.718678538023476030, -0.718713304248915550, +-0.718748068677571570, -0.718782831309357380, -0.718817592144186390, -0.718852351181971110, -0.718887108422624930, -0.718921863866061050, -0.718956617512192420, -0.718991369360932660, +-0.719026119412194080, -0.719060867665890280, -0.719095614121934570, -0.719130358780239560, -0.719165101640718560, -0.719199842703284850, -0.719234581967851950, -0.719269319434332250, +-0.719304055102639170, -0.719338788972686330, -0.719373521044386120, -0.719408251317652070, -0.719442979792397570, -0.719477706468535480, -0.719512431345979530, -0.719547154424642120, +-0.719581875704436880, -0.719616595185277210, -0.719651312867075840, -0.719686028749745970, -0.719720742833201200, -0.719755455117354610, -0.719790165602119610, -0.719824874287408930, +-0.719859581173136310, -0.719894286259214480, -0.719928989545556950, -0.719963691032076800, -0.719998390718687540, -0.720033088605302680, -0.720067784691834740, -0.720102478978197350, +-0.720137171464304000, -0.720171862150067450, -0.720206551035401210, -0.720241238120218670, -0.720275923404433030, -0.720310606887957890, -0.720345288570705790, -0.720379968452590670, +-0.720414646533525830, -0.720449322813424110, -0.720483997292199030, -0.720518669969763880, -0.720553340846032510, -0.720588009920917430, -0.720622677194332370, -0.720657342666190860, +-0.720692006336405620, -0.720726668204890510, -0.720761328271558700, -0.720795986536323490, -0.720830642999098710, -0.720865297659797010, -0.720899950518332000, -0.720934601574617420, +-0.720969250828566110, -0.721003898280091590, -0.721038543929107380, -0.721073187775526760, -0.721107829819263470, -0.721142470060230470, -0.721177108498341160, -0.721211745133509390, +-0.721246379965647890, -0.721281012994670510, -0.721315644220490660, -0.721350273643021960, -0.721384901262177140, -0.721419527077870270, -0.721454151090014760, -0.721488773298523570, +-0.721523393703310530, -0.721558012304288840, -0.721592629101372230, -0.721627244094474430, -0.721661857283508180, -0.721696468668387210, -0.721731078249025380, -0.721765686025335640, +-0.721800291997231610, -0.721834896164626820, -0.721869498527434870, -0.721904099085569410, -0.721938697838943490, -0.721973294787471080, -0.722007889931065130, -0.722042483269639380, +-0.722077074803107570, -0.722111664531382870, -0.722146252454379580, -0.722180838572010100, -0.722215422884188610, -0.722250005390828950, -0.722284586091843980, -0.722319164987147430, +-0.722353742076653040, -0.722388317360274200, -0.722422890837924990, -0.722457462509518140, -0.722492032374967730, -0.722526600434187590, -0.722561166687090580, -0.722595731133590550, +-0.722630293773601330, -0.722664854607036670, -0.722699413633809410, -0.722733970853833840, -0.722768526267023480, -0.722803079873291620, -0.722837631672551990, -0.722872181664718340, +-0.722906729849704170, -0.722941276227423550, -0.722975820797789330, -0.723010363560715570, -0.723044904516116360, -0.723079443663904420, -0.723113981003993930, -0.723148516536298520, +-0.723183050260731710, -0.723217582177207770, -0.723252112285639350, -0.723286640585940830, -0.723321167078025960, -0.723355691761807810, -0.723390214637200430, -0.723424735704117580, +-0.723459254962473210, -0.723493772412180380, -0.723528288053153060, -0.723562801885305310, -0.723597313908550310, -0.723631824122802030, -0.723666332527974190, -0.723700839123980530, +-0.723735343910735020, -0.723769846888150940, -0.723804348056142130, -0.723838847414622900, -0.723873344963506080, -0.723907840702705970, -0.723942334632136310, -0.723976826751710710, +-0.724011317061343470, -0.724045805560947550, -0.724080292250437460, -0.724114777129726270, -0.724149260198728160, -0.724183741457356980, -0.724218220905526340, -0.724252698543150550, +-0.724287174370142670, -0.724321648386416770, -0.724356120591887140, -0.724390590986466850, -0.724425059570070200, -0.724459526342610790, -0.724493991304002600, -0.724528454454159700, +-0.724562915792995480, -0.724597375320423900, -0.724631833036359140, -0.724666288940714500, -0.724700743033404260, -0.724735195314341940, -0.724769645783442160, -0.724804094440617890, +-0.724838541285783400, -0.724872986318852770, -0.724907429539739410, -0.724941870948357490, -0.724976310544620860, -0.725010748328443590, -0.725045184299739630, -0.725079618458422390, +-0.725114050804406160, -0.725148481337605010, -0.725182910057932450, -0.725217336965302660, -0.725251762059629490, -0.725286185340826780, -0.725320606808809050, -0.725355026463489480, +-0.725389444304782360, -0.725423860332601870, -0.725458274546861510, -0.725492686947475370, -0.725527097534357620, -0.725561506307422330, -0.725595913266583010, -0.725630318411753960, +-0.725664721742849350, -0.725699123259782590, -0.725733522962468180, -0.725767920850819760, -0.725802316924751610, -0.725836711184178030, -0.725871103629012420, -0.725905494259168950, +-0.725939883074562140, -0.725974270075105180, -0.726008655260712680, -0.726043038631298380, -0.726077420186776570, -0.726111799927061650, -0.726146177852066700, -0.726180553961706780, +-0.726214928255895060, -0.726249300734546080, -0.726283671397573770, -0.726318040244892440, -0.726352407276416150, -0.726386772492058630, -0.726421135891734180, -0.726455497475357200, +-0.726489857242841100, -0.726524215194100380, -0.726558571329049220, -0.726592925647601470, -0.726627278149671870, -0.726661628835173710, -0.726695977704021390, -0.726730324756129530, +-0.726764669991411540, -0.726799013409781920, -0.726833355011154650, -0.726867694795444440, -0.726902032762564600, -0.726936368912429630, -0.726970703244954050, -0.727005035760051490, +-0.727039366457636340, -0.727073695337622670, -0.727108022399924890, -0.727142347644457290, -0.727176671071133600, -0.727210992679868110, -0.727245312470575440, -0.727279630443169340, +-0.727313946597563990, -0.727348260933673880, -0.727382573451413110, -0.727416884150696160, -0.727451193031436680, -0.727485500093549290, -0.727519805336948490, -0.727554108761547800, +-0.727588410367261850, -0.727622710154004810, -0.727657008121691320, -0.727691304270235100, -0.727725598599550550, -0.727759891109552300, -0.727794181800154090, -0.727828470671270320, +-0.727862757722815500, -0.727897042954703700, -0.727931326366849650, -0.727965607959166870, -0.727999887731570210, -0.728034165683974050, -0.728068441816292160, -0.728102716128439240, +-0.728136988620329490, -0.728171259291877200, -0.728205528142997220, -0.728239795173603040, -0.728274060383609640, -0.728308323772930870, -0.728342585341481220, -0.728376845089175000, +-0.728411103015926820, -0.728445359121651200, -0.728479613406261880, -0.728513865869673370, -0.728548116511800630, -0.728582365332557380, -0.728616612331858040, -0.728650857509617220, +-0.728685100865749340, -0.728719342400168890, -0.728753582112789840, -0.728787820003526820, -0.728822056072294560, -0.728856290319006890, -0.728890522743578460, -0.728924753345923770, +-0.728958982125957440, -0.728993209083593330, -0.729027434218746270, -0.729061657531330900, -0.729095879021261160, -0.729130098688451690, -0.729164316532816880, -0.729198532554271360, +-0.729232746752729750, -0.729266959128106020, -0.729301169680314890, -0.729335378409271100, -0.729369585314888490, -0.729403790397082140, -0.729437993655766110, -0.729472195090855260, +-0.729506394702264080, -0.729540592489906660, -0.729574788453698050, -0.729608982593552220, -0.729643174909383910, -0.729677365401107720, -0.729711554068637970, -0.729745740911889710, +-0.729779925930776900, -0.729814109125214160, -0.729848290495116460, -0.729882470040397750, -0.729916647760972870, -0.729950823656756340, -0.729984997727662790, -0.730019169973606940, +-0.730053340394502980, -0.730087508990265640, -0.730121675760809890, -0.730155840706049550, -0.730190003825899710, -0.730224165120274770, -0.730258324589089680, -0.730292482232258620, +-0.730326638049696330, -0.730360792041317650, -0.730394944207036770, -0.730429094546768410, -0.730463243060427430, -0.730497389747928330, -0.730531534609186070, -0.730565677644114620, +-0.730599818852629030, -0.730633958234644170, -0.730668095790074080, -0.730702231518833730, -0.730736365420837860, -0.730770497496001090, -0.730804627744238380, -0.730838756165463790, +-0.730872882759592280, -0.730907007526538920, -0.730941130466217670, -0.730975251578543590, -0.731009370863431430, -0.731043488320796130, -0.731077603950551770, -0.731111717752613410, +-0.731145829726896120, -0.731179939873313980, -0.731214048191781930, -0.731248154682214710, -0.731282259344527170, -0.731316362178634270, -0.731350463184450180, -0.731384562361889980, +-0.731418659710868500, -0.731452755231300270, -0.731486848923100010, -0.731520940786182680, -0.731555030820463030, -0.731589119025855990, -0.731623205402275990, -0.731657289949638190, +-0.731691372667856890, -0.731725453556847150, -0.731759532616523820, -0.731793609846801640, -0.731827685247595780, -0.731861758818820320, -0.731895830560390540, -0.731929900472221510, +-0.731963968554227300, -0.731998034806323190, -0.732032099228424050, -0.732066161820444710, -0.732100222582300120, -0.732134281513904810, -0.732168338615173720, -0.732202393886022040, +-0.732236447326364170, -0.732270498936115180, -0.732304548715189910, -0.732338596663503650, -0.732372642780970470, -0.732406687067505780, -0.732440729523024640, -0.732474770147441330, +-0.732508808940671050, -0.732542845902628860, -0.732576881033229600, -0.732610914332388340, -0.732644945800019490, -0.732678975436038330, -0.732713003240359930, -0.732747029212898800, +-0.732781053353570130, -0.732815075662288870, -0.732849096138969760, -0.732883114783528300, -0.732917131595878790, -0.732951146575936410, -0.732985159723616440, -0.733019171038833290, +-0.733053180521502260, -0.733087188171538170, -0.733121193988856560, -0.733155197973371480, -0.733189200124998550, -0.733223200443652860, -0.733257198929248900, -0.733291195581701970, +-0.733325190400927030, -0.733359183386839030, -0.733393174539353490, -0.733427163858384580, -0.733461151343847930, -0.733495136995658600, -0.733529120813731120, -0.733563102797980870, +-0.733597082948322820, -0.733631061264672150, -0.733665037746944030, -0.733699012395053090, -0.733732985208914830, -0.733766956188443900, -0.733800925333555560, -0.733834892644164900, +-0.733868858120186980, -0.733902821761537210, -0.733936783568130190, -0.733970743539881120, -0.734004701676705510, -0.734038657978517860, -0.734072612445233470, -0.734106565076767640, +-0.734140515873035420, -0.734174464833952100, -0.734208411959432430, -0.734242357249391690, -0.734276300703745390, -0.734310242322408050, -0.734344182105295060, -0.734378120052321610, +-0.734412056163403100, -0.734445990438454270, -0.734479922877390390, -0.734513853480126990, -0.734547782246578800, -0.734581709176660990, -0.734615634270288980, -0.734649557527377820, +-0.734683478947843140, -0.734717398531599450, -0.734751316278562270, -0.734785232188647110, -0.734819146261768590, -0.734853058497842100, -0.734886968896783070, -0.734920877458506540, +-0.734954784182928140, -0.734988689069962400, -0.735022592119525030, -0.735056493331531560, -0.735090392705896490, -0.735124290242535450, -0.735158185941363620, -0.735192079802296620, +-0.735225971825249180, -0.735259862010136820, -0.735293750356875050, -0.735327636865378610, -0.735361521535563110, -0.735395404367343850, -0.735429285360636010, -0.735463164515355210, +-0.735497041831416290, -0.735530917308734770, -0.735564790947226270, -0.735598662746805410, -0.735632532707387930, -0.735666400828889120, -0.735700267111224270, -0.735734131554309110, +-0.735767994158058380, -0.735801854922387810, -0.735835713847212360, -0.735869570932447650, -0.735903426178009080, -0.735937279583811830, -0.735971131149771750, -0.736004980875803570, +-0.736038828761822810, -0.736072674807745410, -0.736106519013485890, -0.736140361378960220, -0.736174201904083560, -0.736208040588771430, -0.736241877432939450, -0.736275712436502580, +-0.736309545599376340, -0.736343376921476560, -0.736377206402717980, -0.736411034043016440, -0.736444859842287360, -0.736478683800446340, -0.736512505917408360, -0.736546326193089130, +-0.736580144627404400, -0.736613961220268900, -0.736647775971598580, -0.736681588881308860, -0.736715399949315120, -0.736749209175533220, -0.736783016559877880, -0.736816822102265070, +-0.736850625802610510, -0.736884427660829180, -0.736918227676836680, -0.736952025850548530, -0.736985822181880470, -0.737019616670748110, -0.737053409317066420, -0.737087200120751130, +-0.737120989081718190, -0.737154776199882460, -0.737188561475159760, -0.737222344907465740, -0.737256126496716120, -0.737289906242825870, -0.737323684145710920, -0.737357460205287030, +-0.737391234421469140, -0.737425006794173220, -0.737458777323314770, -0.737492546008809310, -0.737526312850572800, -0.737560077848520290, -0.737593841002567530, -0.737627602312630470, +-0.737661361778624180, -0.737695119400464390, -0.737728875178066850, -0.737762629111347050, -0.737796381200221060, -0.737830131444603850, -0.737863879844411490, -0.737897626399559140, +-0.737931371109962870, -0.737965113975538100, -0.737998854996200440, -0.738032594171866060, -0.738066331502449820, -0.738100066987867900, -0.738133800628036020, -0.738167532422869250, +-0.738201262372283780, -0.738234990476195120, -0.738268716734518990, -0.738302441147171250, -0.738336163714067180, -0.738369884435122750, -0.738403603310253900, -0.738437320339375700, +-0.738471035522404230, -0.738504748859255210, -0.738538460349844610, -0.738572169994087480, -0.738605877791900010, -0.738639583743198050, -0.738673287847896880, -0.738706990105912450, +-0.738740690517160630, -0.738774389081557010, -0.738808085799017800, -0.738841780669458050, -0.738875473692793830, -0.738909164868941200, -0.738942854197815360, -0.738976541679332470, +-0.739010227313408150, -0.739043911099958260, -0.739077593038898860, -0.739111273130145240, -0.739144951373613690, -0.739178627769219500, -0.739212302316878840, -0.739245975016507240, +-0.739279645868020860, -0.739313314871335560, -0.739346982026366620, -0.739380647333030330, -0.739414310791242760, -0.739447972400919080, -0.739481632161975380, -0.739515290074327700, +-0.739548946137891680, -0.739582600352583720, -0.739616252718318990, -0.739649903235013450, -0.739683551902583610, -0.739717198720944550, -0.739750843690012430, -0.739784486809703210, +-0.739818128079932860, -0.739851767500617430, -0.739885405071672330, -0.739919040793013960, -0.739952674664557720, -0.739986306686219790, -0.740019936857916120, -0.740053565179562560, +-0.740087191651075390, -0.740120816272369920, -0.740154439043362420, -0.740188059963969190, -0.740221679034105410, -0.740255296253687580, -0.740288911622631330, -0.740322525140852950, +-0.740356136808268510, -0.740389746624793400, -0.740423354590343920, -0.740456960704836350, -0.740490564968186100, -0.740524167380309460, -0.740557767941122380, -0.740591366650541150, +-0.740624963508481280, -0.740658558514858960, -0.740692151669590570, -0.740725742972591420, -0.740759332423778010, -0.740792920023066180, -0.740826505770372120, -0.740860089665612120, +-0.740893671708701460, -0.740927251899556770, -0.740960830238094230, -0.740994406724229230, -0.741027981357878280, -0.741061554138957360, -0.741095125067382510, -0.741128694143070140, +-0.741162261365935880, -0.741195826735896120, -0.741229390252866600, -0.741262951916763500, -0.741296511727503100, -0.741330069685001370, -0.741363625789174810, -0.741397180039938820, +-0.741430732437210030, -0.741464282980904500, -0.741497831670938080, -0.741531378507227060, -0.741564923489687610, -0.741598466618235810, -0.741632007892788160, -0.741665547313260290, +-0.741699084879568480, -0.741732620591629250, -0.741766154449358120, -0.741799686452671690, -0.741833216601486050, -0.741866744895717580, -0.741900271335282020, -0.741933795920095670, +-0.741967318650075260, -0.742000839525136180, -0.742034358545195060, -0.742067875710167970, -0.742101391019971300, -0.742134904474521350, -0.742168416073733850, -0.742201925817525420, +-0.742235433705812350, -0.742268939738510490, -0.742302443915536130, -0.742335946236805770, -0.742369446702235480, -0.742402945311742000, -0.742436442065240840, -0.742469936962648510, +-0.742503430003881640, -0.742536921188855840, -0.742570410517487840, -0.742603897989693730, -0.742637383605390220, -0.742670867364493060, -0.742704349266918530, -0.742737829312583590, +-0.742771307501403630, -0.742804783833295510, -0.742838258308175400, -0.742871730925959710, -0.742905201686564930, -0.742938670589906810, -0.742972137635902090, -0.743005602824467260, +-0.743039066155518180, -0.743072527628971360, -0.743105987244743300, -0.743139445002750200, -0.743172900902908880, -0.743206354945134870, -0.743239807129345340, -0.743273257455456140, +-0.743306705923383550, -0.743340152533044310, -0.743373597284354700, -0.743407040177231470, -0.743440481211590230, -0.743473920387347720, -0.743507357704420890, -0.743540793162725260, +-0.743574226762177660, -0.743607658502694500, -0.743641088384192180, -0.743674516406587440, -0.743707942569796220, -0.743741366873734930, -0.743774789318320640, -0.743808209903469190, +-0.743841628629097080, -0.743875045495120850, -0.743908460501457420, -0.743941873648022560, -0.743975284934732860, -0.744008694361505410, -0.744042101928255820, -0.744075507634901050, +-0.744108911481357490, -0.744142313467541670, -0.744175713593370200, -0.744209111858759380, -0.744242508263625700, -0.744275902807886030, -0.744309295491456300, -0.744342686314253270, +-0.744376075276193650, -0.744409462377193740, -0.744442847617170500, -0.744476230996039880, -0.744509612513718720, -0.744542992170123650, -0.744576369965170960, -0.744609745898777260, +-0.744643119970859300, -0.744676492181333800, -0.744709862530116730, -0.744743231017125030, -0.744776597642275550, -0.744809962405484250, -0.744843325306668080, -0.744876686345743670, +-0.744910045522627410, -0.744943402837236370, -0.744976758289486510, -0.745010111879294780, -0.745043463606578140, -0.745076813471252430, -0.745110161473234720, -0.745143507612441640, +-0.745176851888789790, -0.745210194302196150, -0.745243534852576660, -0.745276873539848510, -0.745310210363928080, -0.745343545324732020, -0.745376878422177150, -0.745410209656180100, +-0.745443539026657720, -0.745476866533526290, -0.745510192176702670, -0.745543515956103910, -0.745576837871645970, -0.745610157923245920, -0.745643476110820600, -0.745676792434286530, +-0.745710106893560760, -0.745743419488559490, -0.745776730219199660, -0.745810039085398220, -0.745843346087071370, -0.745876651224136270, -0.745909954496509540, -0.745943255904108150, +-0.745976555446848270, -0.746009853124647070, -0.746043148937421520, -0.746076442885087900, -0.746109734967563050, -0.746143025184763940, -0.746176313536607180, -0.746209600023010070, +-0.746242884643888550, -0.746276167399159810, -0.746309448288741020, -0.746342727312548250, -0.746376004470498790, -0.746409279762509150, -0.746442553188496390, -0.746475824748377480, +-0.746509094442068810, -0.746542362269487340, -0.746575628230550240, -0.746608892325173910, -0.746642154553275210, -0.746675414914771180, -0.746708673409578920, -0.746741930037614690, +-0.746775184798795570, -0.746808437693038840, -0.746841688720260690, -0.746874937880378290, -0.746908185173308590, -0.746941430598968450, -0.746974674157275030, -0.747007915848144630, +-0.747041155671494430, -0.747074393627241480, -0.747107629715302420, -0.747140863935594310, -0.747174096288034000, -0.747207326772538430, -0.747240555389024900, -0.747273782137409580, +-0.747307007017610100, -0.747340230029542860, -0.747373451173125040, -0.747406670448273690, -0.747439887854905560, -0.747473103392937930, -0.747506317062287430, -0.747539528862871010, +-0.747572738794606060, -0.747605946857409000, -0.747639153051197100, -0.747672357375887330, -0.747705559831396640, -0.747738760417642310, -0.747771959134540860, -0.747805155982009360, +-0.747838350959965430, -0.747871544068325230, -0.747904735307006190, -0.747937924675925350, -0.747971112175000010, -0.748004297804146570, -0.748037481563282310, -0.748070663452324760, +-0.748103843471190190, -0.748137021619796010, -0.748170197898059270, -0.748203372305897170, -0.748236544843226770, -0.748269715509964680, -0.748302884306028430, -0.748336051231335290, +-0.748369216285801660, -0.748402379469344960, -0.748435540781882350, -0.748468700223330900, -0.748501857793608010, -0.748535013492630070, -0.748568167320314730, -0.748601319276579140, +-0.748634469361340040, -0.748667617574514720, -0.748700763916020470, -0.748733908385774470, -0.748767050983693450, -0.748800191709694810, -0.748833330563695940, -0.748866467545613590, +-0.748899602655364930, -0.748932735892867350, -0.748965867258037930, -0.748998996750794070, -0.749032124371052490, -0.749065250118730490, -0.749098373993745680, -0.749131495996014810, +-0.749164616125455040, -0.749197734381983780, -0.749230850765518100, -0.749263965275975720, -0.749297077913273050, -0.749330188677328040, -0.749363297568057200, -0.749396404585378150, +-0.749429509729208080, -0.749462612999464260, -0.749495714396064220, -0.749528813918924560, -0.749561911567962920, -0.749595007343096700, -0.749628101244242730, -0.749661193271318420, +-0.749694283424241270, -0.749727371702928360, -0.749760458107297300, -0.749793542637264720, -0.749826625292748460, -0.749859706073665810, -0.749892784979933610, -0.749925862011469490, +-0.749958937168190620, -0.749992010450014850, -0.750025081856858680, -0.750058151388639740, -0.750091219045275760, -0.750124284826683470, -0.750157348732780500, -0.750190410763484140, +-0.750223470918711670, -0.750256529198380930, -0.750289585602408550, -0.750322640130712150, -0.750355692783209460, -0.750388743559817220, -0.750421792460453150, -0.750454839485034660, +-0.750487884633478930, -0.750520927905703910, -0.750553969301626210, -0.750587008821163910, -0.750620046464233860, -0.750653082230753550, -0.750686116120640730, -0.750719148133812460, +-0.750752178270186700, -0.750785206529680060, -0.750818232912210610, -0.750851257417695650, -0.750884280046052450, -0.750917300797198430, -0.750950319671051190, -0.750983336667528150, +-0.751016351786547020, -0.751049365028024880, -0.751082376391879250, -0.751115385878027840, -0.751148393486387730, -0.751181399216876770, -0.751214403069412230, -0.751247405043911960, +-0.751280405140292820, -0.751313403358472740, -0.751346399698369470, -0.751379394159899850, -0.751412386742981830, -0.751445377447532700, -0.751478366273470310, -0.751511353220712160, +-0.751544338289175330, -0.751577321478777760, -0.751610302789437080, -0.751643282221070460, -0.751676259773595530, -0.751709235446930020, -0.751742209240991330, -0.751775181155697410, +-0.751808151190965330, -0.751841119346712940, -0.751874085622857850, -0.751907050019317460, -0.751940012536009280, -0.751972973172851170, -0.752005931929760840, -0.752038888806655480, +-0.752071843803452820, -0.752104796920070930, -0.752137748156426640, -0.752170697512438040, -0.752203644988022720, -0.752236590583098220, -0.752269534297582590, -0.752302476131392780, +-0.752335416084446870, -0.752368354156662590, -0.752401290347957220, -0.752434224658248610, -0.752467157087454490, -0.752500087635492370, -0.752533016302280310, -0.752565943087735610, +-0.752598867991776110, -0.752631791014319320, -0.752664712155282970, -0.752697631414584900, -0.752730548792142740, -0.752763464287874440, -0.752796377901697290, -0.752829289633529020, +-0.752862199483287920, -0.752895107450891050, -0.752928013536256380, -0.752960917739301740, -0.752993820059944750, -0.753026720498103490, -0.753059619053695120, -0.753092515726637710, +-0.753125410516849450, -0.753158303424247280, -0.753191194448749270, -0.753224083590273370, -0.753256970848737440, -0.753289856224058860, -0.753322739716155710, -0.753355621324945930, +-0.753388501050346830, -0.753421378892276450, -0.753454254850652650, -0.753487128925393160, -0.753520001116416150, -0.753552871423638910, -0.753585739846979520, -0.753618606386355920, +-0.753651471041685620, -0.753684333812886690, -0.753717194699876750, -0.753750053702573970, -0.753782910820896320, -0.753815766054761080, -0.753848619404086540, -0.753881470868790540, +-0.753914320448790700, -0.753947168144005090, -0.753980013954351440, -0.754012857879748140, -0.754045699920112390, -0.754078540075362350, -0.754111378345416310, -0.754144214730191440, +-0.754177049229606160, -0.754209881843578180, -0.754242712572025460, -0.754275541414866300, -0.754308368372017980, -0.754341193443398780, -0.754374016628926890, -0.754406837928519590, +-0.754439657342095280, -0.754472474869571700, -0.754505290510867120, -0.754538104265899510, -0.754570916134586380, -0.754603726116846120, -0.754636534212596350, -0.754669340421755260, +-0.754702144744240800, -0.754734947179971030, -0.754767747728864120, -0.754800546390837600, -0.754833343165809630, -0.754866138053698620, -0.754898931054422070, -0.754931722167898060, +-0.754964511394044860, -0.754997298732780320, -0.755030084184022840, -0.755062867747689830, -0.755095649423699670, -0.755128429211970760, -0.755161207112420410, -0.755193983124966990, +-0.755226757249528700, -0.755259529486023710, -0.755292299834369740, -0.755325068294484980, -0.755357834866287710, -0.755390599549695670, -0.755423362344627150, -0.755456123251000200, +-0.755488882268732900, -0.755521639397743750, -0.755554394637950160, -0.755587147989270620, -0.755619899451623560, -0.755652649024926350, -0.755685396709097510, -0.755718142504055330, +-0.755750886409717660, -0.755783628426003110, -0.755816368552829190, -0.755849106790114300, -0.755881843137776950, -0.755914577595734770, -0.755947310163906150, -0.755980040842209160, +-0.756012769630562410, -0.756045496528883530, -0.756078221537090810, -0.756110944655102870, -0.756143665882837210, -0.756176385220212350, -0.756209102667146690, -0.756241818223558180, +-0.756274531889365440, -0.756307243664485980, -0.756339953548838540, -0.756372661542341510, -0.756405367644912510, -0.756438071856470050, -0.756470774176932430, -0.756503474606217810, +-0.756536173144244820, -0.756568869790931190, -0.756601564546195650, -0.756634257409955930, -0.756666948382130560, -0.756699637462637800, -0.756732324651395950, -0.756765009948323520, +-0.756797693353338240, -0.756830374866358850, -0.756863054487303840, -0.756895732216090740, -0.756928408052638390, -0.756961081996865070, -0.756993754048689070, -0.757026424208028900, +-0.757059092474802410, -0.757091758848928100, -0.757124423330324810, -0.757157085918910070, -0.757189746614602700, -0.757222405417320890, -0.757255062326983470, -0.757287717343507970, +-0.757320370466813220, -0.757353021696817840, -0.757385671033439680, -0.757418318476597240, -0.757450964026209150, -0.757483607682193470, -0.757516249444469160, -0.757548889312953940, +-0.757581527287566450, -0.757614163368225510, -0.757646797554848870, -0.757679429847355150, -0.757712060245662840, -0.757744688749690480, -0.757777315359356660, -0.757809940074579250, +-0.757842562895276960, -0.757875183821368650, -0.757907802852771930, -0.757940419989405870, -0.757973035231188640, -0.758005648578039090, -0.758038260029875290, -0.758070869586615740, +-0.758103477248179280, -0.758136083014483870, -0.758168686885448250, -0.758201288860990920, -0.758233888941030390, -0.758266487125485390, -0.758299083414273880, -0.758331677807314700, +-0.758364270304526580, -0.758396860905827470, -0.758429449611136340, -0.758462036420371470, -0.758494621333451470, -0.758527204350295300, -0.758559785470820810, -0.758592364694947060, +-0.758624942022592230, -0.758657517453675050, -0.758690090988114020, -0.758722662625827770, -0.758755232366735140, -0.758787800210754090, -0.758820366157803680, -0.758852930207802530, +-0.758885492360668820, -0.758918052616321390, -0.758950610974678750, -0.758983167435659630, -0.759015721999182880, -0.759048274665166560, -0.759080825433529500, -0.759113374304190680, +-0.759145921277068150, -0.759178466352080860, -0.759211009529147330, -0.759243550808186620, -0.759276090189116790, -0.759308627671856580, -0.759341163256325280, -0.759373696942440720, +-0.759406228730121760, -0.759438758619287450, -0.759471286609856080, -0.759503812701746940, -0.759536336894877760, -0.759568859189167940, -0.759601379584536220, -0.759633898080900650, +-0.759666414678180520, -0.759698929376294240, -0.759731442175160530, -0.759763953074698680, -0.759796462074826650, -0.759828969175463610, -0.759861474376527960, -0.759893977677938650, +-0.759926479079614300, -0.759958978581473880, -0.759991476183436210, -0.760023971885419590, -0.760056465687343090, -0.760088957589125650, -0.760121447590685450, -0.760153935691941780, +-0.760186421892813270, -0.760218906193218640, -0.760251388593077060, -0.760283869092306720, -0.760316347690826680, -0.760348824388556110, -0.760381299185413080, -0.760413772081316890, +-0.760446243076186250, -0.760478712169940340, -0.760511179362497240, -0.760543644653776330, -0.760576108043696460, -0.760608569532176150, -0.760641029119134340, -0.760673486804489980, +-0.760705942588161930, -0.760738396470069360, -0.760770848450130430, -0.760803298528264450, -0.760835746704390360, -0.760868192978426780, -0.760900637350292670, -0.760933079819906990, +-0.760965520387188450, -0.760997959052056580, -0.761030395814429440, -0.761062830674226310, -0.761095263631366480, -0.761127694685768130, -0.761160123837350540, -0.761192551086032680, +-0.761224976431733700, -0.761257399874372020, -0.761289821413866810, -0.761322241050137350, -0.761354658783101930, -0.761387074612679960, -0.761419488538790270, -0.761451900561351810, +-0.761484310680283990, -0.761516718895505100, -0.761549125206934300, -0.761581529614490990, -0.761613932118093690, -0.761646332717661470, -0.761678731413113490, -0.761711128204368590, +-0.761743523091346190, -0.761775916073964670, -0.761808307152143650, -0.761840696325801650, -0.761873083594857840, -0.761905468959231390, -0.761937852418841270, -0.761970233973606750, +-0.762002613623446350, -0.762034991368279350, -0.762067367208025260, -0.762099741142602480, -0.762132113171930300, -0.762164483295927900, -0.762196851514514220, -0.762229217827608770, +-0.762261582235129960, -0.762293944736997080, -0.762326305333129730, -0.762358664023446320, -0.762391020807866250, -0.762423375686308690, -0.762455728658692930, -0.762488079724937600, +-0.762520428884961960, -0.762552776138685550, -0.762585121486026970, -0.762617464926905630, -0.762649806461240590, -0.762682146088951020, -0.762714483809956320, -0.762746819624175230, +-0.762779153531527030, -0.762811485531931230, -0.762843815625306450, -0.762876143811572090, -0.762908470090647440, -0.762940794462451550, -0.762973116926904060, -0.763005437483923350, +-0.763037756133429170, -0.763070072875340790, -0.763102387709576950, -0.763134700636057260, -0.763167011654700690, -0.763199320765426960, -0.763231627968154580, -0.763263933262803170, +-0.763296236649292140, -0.763328538127540310, -0.763360837697467210, -0.763393135358991890, -0.763425431112033760, -0.763457724956512320, -0.763490016892346300, -0.763522306919455220, +-0.763554595037758690, -0.763586881247175440, -0.763619165547624880, -0.763651447939026510, -0.763683728421299390, -0.763716006994363370, -0.763748283658136960, -0.763780558412540110, +-0.763812831257491660, -0.763845102192911130, -0.763877371218717790, -0.763909638334831050, -0.763941903541170530, -0.763974166837654840, -0.764006428224203840, -0.764038687700737020, +-0.764070945267173230, -0.764103200923432090, -0.764135454669432890, -0.764167706505095130, -0.764199956430338330, -0.764232204445081330, -0.764264450549243860, -0.764296694742745530, +-0.764328937025505200, -0.764361177397442580, -0.764393415858476870, -0.764425652408528000, -0.764457887047514720, -0.764490119775356750, -0.764522350591973710, -0.764554579497284560, +-0.764586806491208910, -0.764619031573666290, -0.764651254744576070, -0.764683476003858000, -0.764715695351430910, -0.764747912787214550, -0.764780128311128850, -0.764812341923092440, +-0.764844553623025170, -0.764876763410846540, -0.764908971286475950, -0.764941177249833350, -0.764973381300837360, -0.765005583439408050, -0.765037783665465040, -0.765069981978927280, +-0.765102178379714500, -0.765134372867746330, -0.765166565442942480, -0.765198756105221920, -0.765230944854504490, -0.765263131690710030, -0.765295316613757490, -0.765327499623566500, +-0.765359680720056890, -0.765391859903148060, -0.765424037172759860, -0.765456212528811240, -0.765488385971222150, -0.765520557499912320, -0.765552727114800820, -0.765584894815807600, +-0.765617060602852060, -0.765649224475853820, -0.765681386434732940, -0.765713546479408150, -0.765745704609799960, -0.765777860825827110, -0.765810015127409540, -0.765842167514466990, +-0.765874317986919070, -0.765906466544685640, -0.765938613187685750, -0.765970757915839240, -0.766002900729066290, -0.766035041627285640, -0.766067180610417450, -0.766099317678381350, +-0.766131452831096960, -0.766163586068484110, -0.766195717390462110, -0.766227846796950770, -0.766259974287870180, -0.766292099863139290, -0.766324223522678150, -0.766356345266406390, +-0.766388465094244190, -0.766420583006110490, -0.766452699001925360, -0.766484813081608760, -0.766516925245079750, -0.766549035492258500, -0.766581143823064640, -0.766613250237418000, +-0.766645354735238430, -0.766677457316445210, -0.766709557980958410, -0.766741656728697870, -0.766773753559582990, -0.766805848473533720, -0.766837941470469800, -0.766870032550311050, +-0.766902121712977560, -0.766934208958388370, -0.766966294286463680, -0.766998377697123650, -0.767030459190287230, -0.767062538765874820, -0.767094616423805940, -0.767126692164000870, +-0.767158765986378780, -0.767190837890859730, -0.767222907877363910, -0.767254975945810600, -0.767287042096119750, -0.767319106328211320, -0.767351168642005140, -0.767383229037421290, +-0.767415287514379150, -0.767447344072798690, -0.767479398712600290, -0.767511451433703030, -0.767543502236027080, -0.767575551119492490, -0.767607598084018910, -0.767639643129526710, +-0.767671686255935070, -0.767703727463164620, -0.767735766751134420, -0.767767804119764860, -0.767799839568975790, -0.767831873098687060, -0.767863904708819050, -0.767895934399290820, +-0.767927962170022900, -0.767959988020935350, -0.767992011951947550, -0.768024033962979690, -0.768056054053951720, -0.768088072224783590, -0.768120088475395590, -0.768152102805707120, +-0.768184115215638450, -0.768216125705109660, -0.768248134274040370, -0.768280140922350640, -0.768312145649960640, -0.768344148456790550, -0.768376149342759770, -0.768408148307788700, +-0.768440145351797390, -0.768472140474705580, -0.768504133676433330, -0.768536124956900820, -0.768568114316027890, -0.768600101753735050, -0.768632087269941700, -0.768664070864568010, +-0.768696052537534480, -0.768728032288760630, -0.768760010118166530, -0.768791986025672560, -0.768823960011198570, -0.768855932074664960, -0.768887902215991240, -0.768919870435098020, +-0.768951836731904810, -0.768983801106332130, -0.769015763558299810, -0.769047724087728150, -0.769079682694537530, -0.769111639378647350, -0.769143594139978020, -0.769175546978450030, +-0.769207497893982910, -0.769239446886497040, -0.769271393955912600, -0.769303339102149540, -0.769335282325128600, -0.769367223624769060, -0.769399163000991430, -0.769431100453716210, +-0.769463035982863030, -0.769494969588352170, -0.769526901270103920, -0.769558831028038680, -0.769590758862076060, -0.769622684772136580, -0.769654608758140730, -0.769686530820007930, +-0.769718450957658900, -0.769750369171013800, -0.769782285459992720, -0.769814199824516150, -0.769846112264503830, -0.769878022779876270, -0.769909931370553970, -0.769941838036456440, +-0.769973742777504410, -0.770005645593617950, -0.770037546484717450, -0.770069445450723310, -0.770101342491555260, -0.770133237607133920, -0.770165130797379800, -0.770197022062212520, +-0.770228911401552590, -0.770260798815320500, -0.770292684303436670, -0.770324567865820820, -0.770356449502393570, -0.770388329213075540, -0.770420206997786350, -0.770452082856446620, +-0.770483956788976740, -0.770515828795296900, -0.770547698875327810, -0.770579567028989110, -0.770611433256201630, -0.770643297556885760, -0.770675159930961360, -0.770707020378349150, +-0.770738878898969300, -0.770770735492742330, -0.770802590159588740, -0.770834442899428370, -0.770866293712182180, -0.770898142597770120, -0.770929989556112580, -0.770961834587130080, +-0.770993677690742900, -0.771025518866871980, -0.771057358115436850, -0.771089195436358340, -0.771121030829557190, -0.771152864294953220, -0.771184695832466960, -0.771216525442019020, +-0.771248353123529800, -0.771280178876919910, -0.771312002702109420, -0.771343824599018730, -0.771375644567568910, -0.771407462607679670, -0.771439278719271760, -0.771471092902265680, +-0.771502905156582040, -0.771534715482140920, -0.771566523878863040, -0.771598330346669140, -0.771630134885479050, -0.771661937495213720, -0.771693738175793560, -0.771725536927138970, +-0.771757333749170880, -0.771789128641809150, -0.771820921604974620, -0.771852712638588010, -0.771884501742569400, -0.771916288916839500, -0.771948074161318940, -0.771979857475928120, +-0.772011638860587990, -0.772043418315218390, -0.772075195839740270, -0.772106971434074470, -0.772138745098141070, -0.772170516831860660, -0.772202286635154000, -0.772234054507941910, +-0.772265820450144470, -0.772297584461682400, -0.772329346542476650, -0.772361106692447290, -0.772392864911515150, -0.772424621199600760, -0.772456375556624940, -0.772488127982508430, +-0.772519878477171300, -0.772551627040534480, -0.772583373672518950, -0.772615118373044530, -0.772646861142032400, -0.772678601979403190, -0.772710340885077400, -0.772742077858976080, +-0.772773812901019320, -0.772805546011128160, -0.772837277189223020, -0.772869006435224600, -0.772900733749053660, -0.772932459130630910, -0.772964182579877310, -0.772995904096712930, +-0.773027623681058820, -0.773059341332835940, -0.773091057051964350, -0.773122770838365230, -0.773154482691959080, -0.773186192612666860, -0.773217900600409290, -0.773249606655106780, +-0.773281310776680160, -0.773313012965050620, -0.773344713220138310, -0.773376411541864210, -0.773408107930149020, -0.773439802384913830, -0.773471494906078920, -0.773503185493565230, +-0.773534874147293830, -0.773566560867185000, -0.773598245653159710, -0.773629928505138900, -0.773661609423043180, -0.773693288406793860, -0.773724965456310980, -0.773756640571515610, +-0.773788313752328930, -0.773819984998671220, -0.773851654310463540, -0.773883321687626750, -0.773914987130081670, -0.773946650637749260, -0.773978312210550130, -0.774009971848405140, +-0.774041629551235450, -0.774073285318961470, -0.774104939151504360, -0.774136591048784740, -0.774168241010724010, -0.774199889037242350, -0.774231535128261040, -0.774263179283701140, +-0.774294821503482940, -0.774326461787527840, -0.774358100135756460, -0.774389736548089850, -0.774421371024449190, -0.774453003564754880, -0.774484634168927990, -0.774516262836889790, +-0.774547889568560690, -0.774579514363861850, -0.774611137222714240, -0.774642758145038800, -0.774674377130756710, -0.774705994179788360, -0.774737609292055370, -0.774769222467478040, +-0.774800833705977740, -0.774832443007475220, -0.774864050371891660, -0.774895655799148320, -0.774927259289165500, -0.774958860841864490, -0.774990460457166690, -0.775022058134992360, +-0.775053653875263040, -0.775085247677899440, -0.775116839542822730, -0.775148429469954330, -0.775180017459214500, -0.775211603510524540, -0.775243187623805950, -0.775274769798979140, +-0.775306350035965260, -0.775337928334685620, -0.775369504695061500, -0.775401079117013170, -0.775432651600462260, -0.775464222145329950, -0.775495790751536850, -0.775527357419004250, +-0.775558922147653320, -0.775590484937405010, -0.775622045788180730, -0.775653604699901080, -0.775685161672487470, -0.775716716705861180, -0.775748269799942940, -0.775779820954653920, +-0.775811370169915300, -0.775842917445648370, -0.775874462781774410, -0.775906006178213930, -0.775937547634888540, -0.775969087151719530, -0.776000624728627410, -0.776032160365533800, +-0.776063694062359870, -0.776095225819026900, -0.776126755635455630, -0.776158283511567460, -0.776189809447283770, -0.776221333442525420, -0.776252855497213680, -0.776284375611269840, +-0.776315893784614960, -0.776347410017170670, -0.776378924308857580, -0.776410436659597190, -0.776441947069311020, -0.776473455537919690, -0.776504962065344690, -0.776536466651507330, +-0.776567969296328760, -0.776599469999730510, -0.776630968761633400, -0.776662465581959060, -0.776693960460628330, -0.776725453397562720, -0.776756944392683390, -0.776788433445911750, +-0.776819920557169310, -0.776851405726376790, -0.776882888953455810, -0.776914370238327770, -0.776945849580913620, -0.776977326981134750, -0.777008802438912680, -0.777040275954168580, +-0.777071747526824060, -0.777103217156799860, -0.777134684844017600, -0.777166150588398890, -0.777197614389864680, -0.777229076248336260, -0.777260536163735250, -0.777291994135983160, +-0.777323450165000820, -0.777354904250709740, -0.777386356393031770, -0.777417806591887640, -0.777449254847198960, -0.777480701158887230, -0.777512145526873640, -0.777543587951080030, +-0.777575028431427120, -0.777606466967836750, -0.777637903560230330, -0.777669338208529020, -0.777700770912654220, -0.777732201672527660, -0.777763630488070400, -0.777795057359204510, +-0.777826482285850610, -0.777857905267930860, -0.777889326305366000, -0.777920745398077870, -0.777952162545987870, -0.777983577749017390, -0.778014991007088370, -0.778046402320121460, +-0.778077811688038580, -0.778109219110761470, -0.778140624588211090, -0.778172028120309060, -0.778203429706977090, -0.778234829348136480, -0.778266227043708960, -0.778297622793615700, +-0.778329016597778420, -0.778360408456118870, -0.778391798368557990, -0.778423186335017500, -0.778454572355419150, -0.778485956429684430, -0.778517338557734970, -0.778548718739491940, +-0.778580096974877400, -0.778611473263812410, -0.778642847606218710, -0.778674220002017800, -0.778705590451131410, -0.778736958953481270, -0.778768325508988560, -0.778799690117574880, +-0.778831052779162420, -0.778862413493671910, -0.778893772261025410, -0.778925129081144530, -0.778956483953950780, -0.778987836879366120, -0.779019187857311610, -0.779050536887709090, +-0.779081883970480500, -0.779113229105546920, -0.779144572292830300, -0.779175913532252240, -0.779207252823734710, -0.779238590167198760, -0.779269925562566250, -0.779301259009759330, +-0.779332590508698850, -0.779363920059306990, -0.779395247661505360, -0.779426573315215480, -0.779457897020359610, -0.779489218776858620, -0.779520538584634550, -0.779551856443609470, +-0.779583172353704450, -0.779614486314841540, -0.779645798326942360, -0.779677108389928650, -0.779708416503722580, -0.779739722668245090, -0.779771026883418590, -0.779802329149164250, +-0.779833629465404020, -0.779864927832059850, -0.779896224249053250, -0.779927518716306500, -0.779958811233740560, -0.779990101801277590, -0.780021390418839670, -0.780052677086348070, +-0.780083961803724630, -0.780115244570891430, -0.780146525387769960, -0.780177804254282630, -0.780209081170350370, -0.780240356135895490, -0.780271629150840030, -0.780302900215105180, +-0.780334169328612990, -0.780365436491285420, -0.780396701703044650, -0.780427964963811730, -0.780459226273508940, -0.780490485632058360, -0.780521743039381270, -0.780552998495399830, +-0.780584252000036010, -0.780615503553211410, -0.780646753154848330, -0.780678000804868160, -0.780709246503192960, -0.780740490249744900, -0.780771732044445390, -0.780802971887216480, +-0.780834209777980240, -0.780865445716658390, -0.780896679703173220, -0.780927911737446130, -0.780959141819399180, -0.780990369948954770, -0.781021596126034060, -0.781052820350559340, +-0.781084042622452570, -0.781115262941636020, -0.781146481308031100, -0.781177697721559870, -0.781208912182144720, -0.781240124689706940, -0.781271335244168920, -0.781302543845452610, +-0.781333750493479860, -0.781364955188173060, -0.781396157929453490, -0.781427358717243670, -0.781458557551465650, -0.781489754432040940, -0.781520949358891940, -0.781552142331940480, +-0.781583333351108630, -0.781614522416318790, -0.781645709527492350, -0.781676894684551930, -0.781708077887419030, -0.781739259136015830, -0.781770438430264610, -0.781801615770087220, +-0.781832791155406050, -0.781863964586142710, -0.781895136062219390, -0.781926305583558470, -0.781957473150081570, -0.781988638761710990, -0.782019802418368880, -0.782050964119977100, +-0.782082123866458370, -0.782113281657733860, -0.782144437493726310, -0.782175591374357880, -0.782206743299550200, -0.782237893269225660, -0.782269041283306320, -0.782300187341714690, +-0.782331331444372390, -0.782362473591201700, -0.782393613782125130, -0.782424752017064180, -0.782455888295941480, -0.782487022618678970, -0.782518154985198940, -0.782549285395423790, +-0.782580413849275120, -0.782611540346675460, -0.782642664887547190, -0.782673787471811930, -0.782704908099392300, -0.782736026770210370, -0.782767143484188410, -0.782798258241248820, +-0.782829371041313230, -0.782860481884304350, -0.782891590770144470, -0.782922697698755330, -0.782953802670059540, -0.782984905683979160, -0.783016006740436810, -0.783047105839354110, +-0.783078202980653780, -0.783109298164258120, -0.783140391390088950, -0.783171482658068800, -0.783202571968119930, -0.783233659320164640, -0.783264744714125550, -0.783295828149924270, +-0.783326909627483410, -0.783357989146725610, -0.783389066707572470, -0.783420142309946720, -0.783451215953770540, -0.783482287638966430, -0.783513357365456800, -0.783544425133163580, +-0.783575490942009510, -0.783606554791916430, -0.783637616682806960, -0.783668676614603490, -0.783699734587228300, -0.783730790600604020, -0.783761844654652600, -0.783792896749296420, +-0.783823946884458440, -0.783854995060060180, -0.783886041276024460, -0.783917085532273680, -0.783948127828730130, -0.783979168165316650, -0.784010206541954860, -0.784041242958567590, +-0.784072277415077460, -0.784103309911406420, -0.784134340447477100, -0.784165369023211880, -0.784196395638533490, -0.784227420293363900, -0.784258442987625810, -0.784289463721241750, +-0.784320482494133890, -0.784351499306224720, -0.784382514157436870, -0.784413527047692740, -0.784444537976914940, -0.784475546945025640, -0.784506553951947460, -0.784537558997603130, +-0.784568562081914720, -0.784599563204804840, -0.784630562366196100, -0.784661559566010910, -0.784692554804172100, -0.784723548080601630, -0.784754539395222220, -0.784785528747956820, +-0.784816516138727270, -0.784847501567456530, -0.784878485034066880, -0.784909466538481480, -0.784940446080621970, -0.784971423660411500, -0.785002399277772600, -0.785033372932627540, +-0.785064344624899050, -0.785095314354509630, -0.785126282121381910, -0.785157247925438840, -0.785188211766602250, -0.785219173644795210, -0.785250133559940560, -0.785281091511960240, +-0.785312047500777210, -0.785343001526314090, -0.785373953588493380, -0.785404903687238140, -0.785435851822470330, -0.785466797994113230, -0.785497742202088790, -0.785528684446319960, +-0.785559624726729470, -0.785590563043239930, -0.785621499395774300, -0.785652433784254530, -0.785683366208603800, -0.785714296668744820, -0.785745225164599880, -0.785776151696091940, +-0.785807076263143500, -0.785837998865677400, -0.785868919503616590, -0.785899838176883250, -0.785930754885400320, -0.785961669629090750, -0.785992582407876730, -0.786023493221681190, +-0.786054402070426980, -0.786085308954037050, -0.786116213872433580, -0.786147116825539500, -0.786178017813278010, -0.786208916835571150, -0.786239813892341990, -0.786270708983513260, +-0.786301602109007790, -0.786332493268748660, -0.786363382462657910, -0.786394269690658840, -0.786425154952674180, -0.786456038248626530, -0.786486919578438750, -0.786517798942033550, +-0.786548676339334010, -0.786579551770262950, -0.786610425234742780, -0.786641296732696560, -0.786672166264047350, -0.786703033828717420, -0.786733899426629970, -0.786764763057707710, +-0.786795624721873920, -0.786826484419050680, -0.786857342149161370, -0.786888197912128830, -0.786919051707875570, -0.786949903536324660, -0.786980753397399040, -0.787011601291021550, +-0.787042447217115250, -0.787073291175602650, -0.787104133166406710, -0.787134973189450800, -0.787165811244657120, -0.787196647331949050, -0.787227481451249210, -0.787258313602480770, +-0.787289143785566800, -0.787319972000429580, -0.787350798246992830, -0.787381622525178740, -0.787412444834910690, -0.787443265176111410, -0.787474083548704070, -0.787504899952611750, +-0.787535714387756940, -0.787566526854062810, -0.787597337351452650, -0.787628145879848860, -0.787658952439174610, -0.787689757029353180, -0.787720559650307180, -0.787751360301960140, +-0.787782158984234430, -0.787812955697053340, -0.787843750440340050, -0.787874543214017180, -0.787905334018008000, -0.787936122852235350, -0.787966909716622750, -0.787997694611092590, +-0.788028477535568150, -0.788059258489972940, -0.788090037474229230, -0.788120814488260320, -0.788151589531989490, -0.788182362605339690, -0.788213133708234200, -0.788243902840595640, +-0.788274670002347300, -0.788305435193412560, -0.788336198413713940, -0.788366959663174830, -0.788397718941718400, -0.788428476249267600, -0.788459231585745820, -0.788489984951075810, +-0.788520736345181050, -0.788551485767984170, -0.788582233219408680, -0.788612978699377520, -0.788643722207813870, -0.788674463744641230, -0.788705203309782220, -0.788735940903160130, +-0.788766676524698450, -0.788797410174319920, -0.788828141851947720, -0.788858871557505230, -0.788889599290915510, -0.788920325052102190, -0.788951048840987660, -0.788981770657495530, +-0.789012490501549310, -0.789043208373071630, -0.789073924271985750, -0.789104638198215190, -0.789135350151683350, -0.789166060132312720, -0.789196768140027040, -0.789227474174749700, +-0.789258178236403320, -0.789288880324911620, -0.789319580440197680, -0.789350278582184760, -0.789380974750796380, -0.789411668945955380, -0.789442361167585150, -0.789473051415609310, +-0.789503739689950580, -0.789534425990532470, -0.789565110317278270, -0.789595792670111370, -0.789626473048955280, -0.789657151453732610, -0.789687827884367200, -0.789718502340782450, +-0.789749174822901080, -0.789779845330646930, -0.789810513863943080, -0.789841180422713230, -0.789871845006880120, -0.789902507616367380, -0.789933168251098720, -0.789963826910996870, +-0.789994483595985340, -0.790025138305987750, -0.790055791040927160, -0.790086441800727510, -0.790117090585311430, -0.790147737394602650, -0.790178382228524660, -0.790209025087000640, +-0.790239665969953880, -0.790270304877308090, -0.790300941808986470, -0.790331576764912840, -0.790362209745009920, -0.790392840749201800, -0.790423469777411290, -0.790454096829562030, +-0.790484721905577610, -0.790515345005381450, -0.790545966128897050, -0.790576585276047570, -0.790607202446756530, -0.790637817640947870, -0.790668430858544320, -0.790699042099469730, +-0.790729651363647480, -0.790760258651001190, -0.790790863961454480, -0.790821467294930300, -0.790852068651352490, -0.790882668030644780, -0.790913265432730110, -0.790943860857532320, +-0.790974454304974820, -0.791005045774981540, -0.791035635267475330, -0.791066222782380040, -0.791096808319619370, -0.791127391879116510, -0.791157973460795190, -0.791188553064578910, +-0.791219130690391180, -0.791249706338155940, -0.791280280007796270, -0.791310851699235760, -0.791341421412398380, -0.791371989147207300, -0.791402554903586130, -0.791433118681458600, +-0.791463680480748330, -0.791494240301379050, -0.791524798143274030, -0.791555354006356900, -0.791585907890551720, -0.791616459795781440, -0.791647009721970000, -0.791677557669041130, +-0.791708103636918570, -0.791738647625525480, -0.791769189634785820, -0.791799729664623310, -0.791830267714961340, -0.791860803785723650, -0.791891337876833970, -0.791921869988216010, +-0.791952400119793510, -0.791982928271489860, -0.792013454443228900, -0.792043978634934480, -0.792074500846529860, -0.792105021077939010, -0.792135539329085650, -0.792166055599893390, +-0.792196569890286310, -0.792227082200187450, -0.792257592529521220, -0.792288100878210780, -0.792318607246179970, -0.792349111633352750, -0.792379614039652740, -0.792410114465003870, +-0.792440612909329540, -0.792471109372553610, -0.792501603854600220, -0.792532096355392570, -0.792562586874854590, -0.792593075412910240, -0.792623561969483140, -0.792654046544497450, +-0.792684529137876350, -0.792715009749543900, -0.792745488379424270, -0.792775965027440630, -0.792806439693517050, -0.792836912377577360, -0.792867383079545630, -0.792897851799345240, +-0.792928318536900270, -0.792958783292134650, -0.792989246064971900, -0.793019706855335960, -0.793050165663150790, -0.793080622488340210, -0.793111077330828310, -0.793141530190538460, +-0.793171981067394840, -0.793202429961321510, -0.793232876872241750, -0.793263321800079860, -0.793293764744759770, -0.793324205706205100, -0.793354644684340250, -0.793385081679088610, +-0.793415516690374130, -0.793445949718121210, -0.793476380762253130, -0.793506809822694060, -0.793537236899368060, -0.793567661992199080, -0.793598085101110850, -0.793628506226027320, +-0.793658925366872770, -0.793689342523570710, -0.793719757696045190, -0.793750170884220290, -0.793780582088020050, -0.793810991307368650, -0.793841398542189380, -0.793871803792406630, +-0.793902207057944790, -0.793932608338727030, -0.793963007634677750, -0.793993404945721020, -0.794023800271780660, -0.794054193612781180, -0.794084584968645870, -0.794114974339299450, +-0.794145361724665320, -0.794175747124667760, -0.794206130539230730, -0.794236511968278490, -0.794266891411735230, -0.794297268869524450, -0.794327644341570550, -0.794358017827797690, +-0.794388389328129610, -0.794418758842490580, -0.794449126370804560, -0.794479491912995830, -0.794509855468988560, -0.794540217038706480, -0.794570576622073750, -0.794600934219014900, +-0.794631289829453410, -0.794661643453313690, -0.794691995090519910, -0.794722344740996340, -0.794752692404666730, -0.794783038081455340, -0.794813381771286690, -0.794843723474084270, +-0.794874063189772500, -0.794904400918275630, -0.794934736659517640, -0.794965070413423240, -0.794995402179915820, -0.795025731958919900, -0.795056059750359980, -0.795086385554159560, +-0.795116709370243150, -0.795147031198535030, -0.795177351038959260, -0.795207668891440460, -0.795237984755902240, -0.795268298632269000, -0.795298610520465350, -0.795328920420414810, +-0.795359228332041980, -0.795389534255271150, -0.795419838190026710, -0.795450140136232390, -0.795480440093812800, -0.795510738062692350, -0.795541034042794750, -0.795571328034044510, +-0.795601620036366030, -0.795631910049683480, -0.795662198073921470, -0.795692484109003620, -0.795722768154854650, -0.795753050211398970, -0.795783330278560410, -0.795813608356263470, +-0.795843884444432550, -0.795874158542991930, -0.795904430651866220, -0.795934700770979160, -0.795964968900255590, -0.795995235039619220, -0.796025499188994900, -0.796055761348306800, +-0.796086021517479310, -0.796116279696436950, -0.796146535885103760, -0.796176790083404140, -0.796207042291262820, -0.796237292508603640, -0.796267540735351220, -0.796297786971429940, +-0.796328031216764210, -0.796358273471278740, -0.796388513734897160, -0.796418752007544420, -0.796448988289145120, -0.796479222579623000, -0.796509454878902790, -0.796539685186908990, +-0.796569913503566210, -0.796600139828798400, -0.796630364162530190, -0.796660586504686410, -0.796690806855190890, -0.796721025213968370, -0.796751241580943240, -0.796781455956040000, +-0.796811668339183380, -0.796841878730297330, -0.796872087129306680, -0.796902293536135950, -0.796932497950709310, -0.796962700372951360, -0.796992900802786730, -0.797023099240139810, +-0.797053295684935330, -0.797083490137097450, -0.797113682596551130, -0.797143873063220210, -0.797174061537029740, -0.797204248017904020, -0.797234432505767750, -0.797264615000545680, +-0.797294795502161760, -0.797324974010540810, -0.797355150525607790, -0.797385325047286540, -0.797415497575502010, -0.797445668110178700, -0.797475836651241330, -0.797506003198614530, +-0.797536167752222580, -0.797566330311990090, -0.797596490877842010, -0.797626649449702520, -0.797656806027496450, -0.797686960611148300, -0.797717113200583030, -0.797747263795724690, +-0.797777412396498130, -0.797807559002828400, -0.797837703614639460, -0.797867846231856360, -0.797897986854403500, -0.797928125482205820, -0.797958262115187940, -0.797988396753274270, +-0.798018529396389510, -0.798048660044458740, -0.798078788697406120, -0.798108915355156380, -0.798139040017634470, -0.798169162684764900, -0.798199283356472720, -0.798229402032682110, +-0.798259518713317910, -0.798289633398305170, -0.798319746087568170, -0.798349856781031760, -0.798379965478620670, -0.798410072180260060, -0.798440176885873880, -0.798470279595387300, +-0.798500380308725280, -0.798530479025811980, -0.798560575746572580, -0.798590670470931690, -0.798620763198814140, -0.798650853930144900, -0.798680942664848350, -0.798711029402849440, +-0.798741114144073120, -0.798771196888443890, -0.798801277635886600, -0.798831356386326070, -0.798861433139687160, -0.798891507895895030, -0.798921580654873730, -0.798951651416548890, +-0.798981720180844570, -0.799011786947685930, -0.799041851716997820, -0.799071914488705070, -0.799101975262732860, -0.799132034039005460, -0.799162090817447930, -0.799192145597985460, +-0.799222198380542430, -0.799252249165043780, -0.799282297951414590, -0.799312344739579570, -0.799342389529464010, -0.799372432320992200, -0.799402473114089300, -0.799432511908680480, +-0.799462548704690130, -0.799492583502043440, -0.799522616300665230, -0.799552647100480800, -0.799582675901414520, -0.799612702703391460, -0.799642727506336910, -0.799672750310175370, +-0.799702771114831900, -0.799732789920231560, -0.799762806726299180, -0.799792821532960050, -0.799822834340138570, -0.799852845147760010, -0.799882853955749650, -0.799912860764031900, +-0.799942865572531910, -0.799972868381174870, -0.800002869189885610, -0.800032867998589410, -0.800062864807210780, -0.800092859615675000, -0.800122852423907460, -0.800152843231832330, +-0.800182832039375240, -0.800212818846461000, -0.800242803653014920, -0.800272786458961720, -0.800302767264226440, -0.800332746068734500, -0.800362722872410500, -0.800392697675179620, +-0.800422670476967020, -0.800452641277697770, -0.800482610077297150, -0.800512576875689770, -0.800542541672800920, -0.800572504468556100, -0.800602465262879590, -0.800632424055697010, +-0.800662380846933310, -0.800692335636513760, -0.800722288424363550, -0.800752239210407280, -0.800782187994570790, -0.800812134776778590, -0.800842079556955970, -0.800872022335028190, +-0.800901963110920320, -0.800931901884557870, -0.800961838655865450, -0.800991773424768240, -0.801021706191192060, -0.801051636955061210, -0.801081565716301400, -0.801111492474837590, +-0.801141417230595070, -0.801171339983499210, -0.801201260733474860, -0.801231179480447200, -0.801261096224341940, -0.801291010965083710, -0.801320923702597890, -0.801350834436809880, +-0.801380743167644960, -0.801410649895027860, -0.801440554618884190, -0.801470457339139350, -0.801500358055718180, -0.801530256768546170, -0.801560153477548390, -0.801590048182650340, +-0.801619940883777300, -0.801649831580854230, -0.801679720273806520, -0.801709606962559880, -0.801739491647038840, -0.801769374327169220, -0.801799255002876080, -0.801829133674084700, +-0.801859010340720930, -0.801888885002709270, -0.801918757659975450, -0.801948628312444960, -0.801978496960042640, -0.802008363602694010, -0.802038228240324560, -0.802068090872859800, +-0.802097951500224560, -0.802127810122344350, -0.802157666739145010, -0.802187521350551160, -0.802217373956488510, -0.802247224556882470, -0.802277073151658300, -0.802306919740741750, +-0.802336764324057650, -0.802366606901531610, -0.802396447473089360, -0.802426286038655730, -0.802456122598156350, -0.802485957151516600, -0.802515789698662110, -0.802545620239518250, +-0.802575448774010210, -0.802605275302063710, -0.802635099823603810, -0.802664922338556130, -0.802694742846846170, -0.802724561348399420, -0.802754377843141410, -0.802784192330997290, +-0.802814004811892580, -0.802843815285753220, -0.802873623752504040, -0.802903430212070780, -0.802933234664378940, -0.802963037109354020, -0.802992837546921740, -0.803022635977007180, +-0.803052432399535940, -0.803082226814433970, -0.803112019221626120, -0.803141809621038320, -0.803171598012595860, -0.803201384396224680, -0.803231168771849860, -0.803260951139397110, +-0.803290731498792150, -0.803320509849960170, -0.803350286192826890, -0.803380060527317920, -0.803409832853358760, -0.803439603170875370, -0.803469371479792580, -0.803499137780036450, +-0.803528902071532710, -0.803558664354206530, -0.803588424627983630, -0.803618182892789630, -0.803647939148550260, -0.803677693395191130, -0.803707445632637630, -0.803737195860815490, +-0.803766944079650660, -0.803796690289068310, -0.803826434488994050, -0.803856176679353720, -0.803885916860073270, -0.803915655031077760, -0.803945391192293140, -0.803975125343645350, +-0.804004857485059340, -0.804034587616461290, -0.804064315737776700, -0.804094041848931410, -0.804123765949851130, -0.804153488040461270, -0.804183208120687780, -0.804212926190456370, +-0.804242642249692440, -0.804272356298321940, -0.804302068336270600, -0.804331778363463920, -0.804361486379828180, -0.804391192385288440, -0.804420896379770990, -0.804450598363200990, +-0.804480298335504610, -0.804509996296607350, -0.804539692246435180, -0.804569386184914030, -0.804599078111969180, -0.804628768027526590, -0.804658455931512310, -0.804688141823851620, +-0.804717825704470700, -0.804747507573295050, -0.804777187430250730, -0.804806865275263790, -0.804836541108259310, -0.804866214929163440, -0.804895886737902360, -0.804925556534401340, +-0.804955224318586350, -0.804984890090383320, -0.805014553849718320, -0.805044215596516730, -0.805073875330704510, -0.805103533052207940, -0.805133188760952300, -0.805162842456863650, +-0.805192494139867820, -0.805222143809890880, -0.805251791466858770, -0.805281437110697000, -0.805311080741331510, -0.805340722358688700, -0.805370361962693740, -0.805399999553272910, +-0.805429635130352040, -0.805459268693857090, -0.805488900243714220, -0.805518529779848950, -0.805548157302187540, -0.805577782810655510, -0.805607406305178910, -0.805637027785683910, +-0.805666647252096360, -0.805696264704342300, -0.805725880142347470, -0.805755493566037930, -0.805785104975339840, -0.805814714370178710, -0.805844321750480930, -0.805873927116172230, +-0.805903530467178770, -0.805933131803426630, -0.805962731124841510, -0.805992328431349600, -0.806021923722877070, -0.806051516999349400, -0.806081108260693010, -0.806110697506833950, +-0.806140284737698280, -0.806169869953211600, -0.806199453153300330, -0.806229034337890730, -0.806258613506908190, -0.806288190660279120, -0.806317765797929690, -0.806347338919785720, +-0.806376910025773720, -0.806406479115819200, -0.806436046189848430, -0.806465611247787820, -0.806495174289562860, -0.806524735315100050, -0.806554294324325350, -0.806583851317165030, +-0.806613406293545280, -0.806642959253391690, -0.806672510196630780, -0.806702059123188820, -0.806731606032991430, -0.806761150925965010, -0.806790693802035830, -0.806820234661130060, +-0.806849773503173440, -0.806879310328092460, -0.806908845135813510, -0.806938377926262110, -0.806967908699364740, -0.806997437455047590, -0.807026964193236940, -0.807056488913859060, +-0.807086011616839680, -0.807115532302105310, -0.807145050969582440, -0.807174567619196590, -0.807204082250874370, -0.807233594864541940, -0.807263105460125470, -0.807292614037551590, +-0.807322120596745800, -0.807351625137635030, -0.807381127660144910, -0.807410628164202060, -0.807440126649732530, -0.807469623116662700, -0.807499117564919210, -0.807528609994427550, +-0.807558100405114330, -0.807587588796906180, -0.807617075169728800, -0.807646559523508720, -0.807676041858172210, -0.807705522173645550, -0.807735000469855470, -0.807764476746727580, +-0.807793951004188490, -0.807823423242164830, -0.807852893460582310, -0.807882361659367550, -0.807911827838446840, -0.807941291997746890, -0.807970754137193440, -0.808000214256713090, +-0.808029672356232460, -0.808059128435677400, -0.808088582494974510, -0.808118034534050180, -0.808147484552830810, -0.808176932551242900, -0.808206378529212510, -0.808235822486666030, +-0.808265264423530420, -0.808294704339731270, -0.808324142235195330, -0.808353578109849090, -0.808383011963618950, -0.808412443796431510, -0.808441873608212620, -0.808471301398889120, +-0.808500727168387720, -0.808530150916634050, -0.808559572643555160, -0.808588992349077220, -0.808618410033127180, -0.808647825695630760, -0.808677239336514810, -0.808706650955706040, +-0.808736060553130410, -0.808765468128714530, -0.808794873682385010, -0.808824277214068350, -0.808853678723691180, -0.808883078211179660, -0.808912475676460410, -0.808941871119460140, +-0.808971264540105040, -0.809000655938321710, -0.809030045314036880, -0.809059432667176730, -0.809088817997668410, -0.809118201305437770, -0.809147582590411860, -0.809176961852516640, +-0.809206339091679160, -0.809235714307825820, -0.809265087500883110, -0.809294458670777980, -0.809323827817436500, -0.809353194940785390, -0.809382560040751490, -0.809411923117261070, +-0.809441284170240750, -0.809470643199617260, -0.809500000205317090, -0.809529355187267320, -0.809558708145393770, -0.809588059079623500, -0.809617407989883350, -0.809646754876099380, +-0.809676099738198540, -0.809705442576107550, -0.809734783389753130, -0.809764122179061460, -0.809793458943959490, -0.809822793684374150, -0.809852126400231630, -0.809881457091458760, +-0.809910785757982250, -0.809940112399728740, -0.809969437016625160, -0.809998759608597800, -0.810028080175573590, -0.810057398717479390, -0.810086715234241360, -0.810116029725786670, +-0.810145342192041820, -0.810174652632933650, -0.810203961048389100, -0.810233267438334350, -0.810262571802696450, -0.810291874141402470, -0.810321174454378460, -0.810350472741551480, +-0.810379769002848360, -0.810409063238196170, -0.810438355447520960, -0.810467645630749800, -0.810496933787809960, -0.810526219918627390, -0.810555504023129370, -0.810584786101242520, +-0.810614066152893660, -0.810643344178009980, -0.810672620176517640, -0.810701894148343820, -0.810731166093415450, -0.810760436011658920, -0.810789703903001310, -0.810818969767369450, +-0.810848233604690160, -0.810877495414890510, -0.810906755197896900, -0.810936012953636600, -0.810965268682036110, -0.810994522383022390, -0.811023774056522370, -0.811053023702462910, +-0.811082271320771150, -0.811111516911373510, -0.811140760474197030, -0.811170002009168890, -0.811199241516215470, -0.811228478995263960, -0.811257714446241280, -0.811286947869074290, +-0.811316179263690260, -0.811345408630015470, -0.811374635967977210, -0.811403861277502520, -0.811433084558517930, -0.811462305810950690, -0.811491525034727660, -0.811520742229776100, +-0.811549957396022430, -0.811579170533393790, -0.811608381641817590, -0.811637590721220100, -0.811666797771528610, -0.811696002792670180, -0.811725205784571750, -0.811754406747160600, +-0.811783605680363120, -0.811812802584106600, -0.811841997458318420, -0.811871190302924870, -0.811900381117853450, -0.811929569903031000, -0.811958756658384680, -0.811987941383841670, +-0.812017124079328580, -0.812046304744772800, -0.812075483380101380, -0.812104659985240950, -0.812133834560119010, -0.812163007104662380, -0.812192177618798470, -0.812221346102453890, +-0.812250512555556030, -0.812279676978032050, -0.812308839369808690, -0.812337999730813220, -0.812367158060972700, -0.812396314360214310, -0.812425468628465320, -0.812454620865652570, +-0.812483771071703110, -0.812512919246544560, -0.812542065390103430, -0.812571209502307210, -0.812600351583082860, -0.812629491632357650, -0.812658629650058970, -0.812687765636113560, +-0.812716899590448900, -0.812746031512991740, -0.812775161403669570, -0.812804289262409440, -0.812833415089138530, -0.812862538883784350, -0.812891660646273720, -0.812920780376533700, +-0.812949898074492140, -0.812979013740075640, -0.813008127373211490, -0.813037238973827070, -0.813066348541849450, -0.813095456077206350, -0.813124561579824270, -0.813153665049630820, +-0.813182766486553520, -0.813211865890518970, -0.813240963261454790, -0.813270058599288140, -0.813299151903946640, -0.813328243175357010, -0.813357332413446880, -0.813386419618143510, +-0.813415504789373970, -0.813444587927065530, -0.813473669031145710, -0.813502748101541660, -0.813531825138181120, -0.813560900140990580, -0.813589973109897890, -0.813619044044830540, +-0.813648112945715370, -0.813677179812479780, -0.813706244645051370, -0.813735307443357200, -0.813764368207325120, -0.813793426936881840, -0.813822483631955310, -0.813851538292472250, +-0.813880590918360400, -0.813909641509547030, -0.813938690065959540, -0.813967736587525640, -0.813996781074172060, -0.814025823525826530, -0.814054863942416770, -0.814083902323869620, +-0.814112938670112580, -0.814141972981073270, -0.814171005256679070, -0.814200035496857600, -0.814229063701535690, -0.814258089870641190, -0.814287114004101810, -0.814316136101844280, +-0.814345156163796440, -0.814374174189885670, -0.814403190180039480, -0.814432204134185600, -0.814461216052250970, -0.814490225934163540, -0.814519233779850250, -0.814548239589238940, +-0.814577243362257010, -0.814606245098831950, -0.814635244798891490, -0.814664242462362690, -0.814693238089173380, -0.814722231679251170, -0.814751223232523030, -0.814780212748916990, +-0.814809200228360340, -0.814838185670780700, -0.814867169076105790, -0.814896150444262780, -0.814925129775179390, -0.814954107068783350, -0.814983082325001940, -0.815012055543762660, +-0.815041026724993340, -0.815069995868621720, -0.815098962974574850, -0.815127928042780560, -0.815156891073166690, -0.815185852065660300, -0.815214811020189330, -0.815243767936681300, +-0.815272722815063910, -0.815301675655264900, -0.815330626457211440, -0.815359575220831470, -0.815388521946052820, -0.815417466632802570, -0.815446409281008640, -0.815475349890598780, +-0.815504288461500470, -0.815533224993641670, -0.815562159486949660, -0.815591091941352380, -0.815620022356777220, -0.815648950733151910, -0.815677877070404290, -0.815706801368461960, +-0.815735723627252880, -0.815764643846704330, -0.815793562026744020, -0.815822478167300140, -0.815851392268299720, -0.815880304329670960, -0.815909214351341340, -0.815938122333238700, +-0.815967028275291110, -0.815995932177425500, -0.816024834039570270, -0.816053733861653030, -0.816082631643601290, -0.816111527385342980, -0.816140421086805850, -0.816169312747917930, +-0.816198202368606410, -0.816227089948799440, -0.816255975488424990, -0.816284858987410320, -0.816313740445683500, -0.816342619863172360, -0.816371497239804730, -0.816400372575508460, +-0.816429245870211150, -0.816458117123840640, -0.816486986336325100, -0.816515853507591930, -0.816544718637569060, -0.816573581726184330, -0.816602442773365690, -0.816631301779041310, +-0.816660158743138240, -0.816689013665584880, -0.816717866546309180, -0.816746717385238630, -0.816775566182301290, -0.816804412937425010, -0.816833257650537940, -0.816862100321567470, +-0.816890940950441790, -0.816919779537088940, -0.816948616081436430, -0.816977450583412310, -0.817006283042944650, -0.817035113459961270, -0.817063941834390350, -0.817092768166159390, +-0.817121592455196440, -0.817150414701429680, -0.817179234904786720, -0.817208053065195730, -0.817236869182584540, -0.817265683256881200, -0.817294495288013900, -0.817323305275910130, +-0.817352113220498280, -0.817380919121705960, -0.817409722979461240, -0.817438524793692390, -0.817467324564327140, -0.817496122291293760, -0.817524917974519870, -0.817553711613933750, +-0.817582503209463570, -0.817611292761036830, -0.817640080268581930, -0.817668865732026680, -0.817697649151299390, -0.817726430526328320, -0.817755209857040750, -0.817783987143365200, +-0.817812762385229930, -0.817841535582562560, -0.817870306735291370, -0.817899075843344310, -0.817927842906649880, -0.817956607925135580, -0.817985370898729800, -0.818014131827360820, +-0.818042890710956260, -0.818071647549444390, -0.818100402342753500, -0.818129155090811630, -0.818157905793546970, -0.818186654450887450, -0.818215401062761250, -0.818244145629096750, +-0.818272888149821690, -0.818301628624864330, -0.818330367054152960, -0.818359103437615750, -0.818387837775180980, -0.818416570066776260, -0.818445300312330200, -0.818474028511771200, +-0.818502754665026750, -0.818531478772025480, -0.818560200832695540, -0.818588920846965330, -0.818617638814762570, -0.818646354736015660, -0.818675068610653200, -0.818703780438602810, +-0.818732490219792890, -0.818761197954151810, -0.818789903641607750, -0.818818607282089110, -0.818847308875523710, -0.818876008421840050, -0.818904705920966650, -0.818933401372831220, +-0.818962094777362370, -0.818990786134488170, -0.819019475444137000, -0.819048162706237480, -0.819076847920717220, -0.819105531087505170, -0.819134212206528930, -0.819162891277717240, +-0.819191568300998260, -0.819220243276300500, -0.819248916203552220, -0.819277587082681500, -0.819306255913616830, -0.819334922696286720, -0.819363587430618990, -0.819392250116542380, +-0.819420910753985150, -0.819449569342875610, -0.819478225883142340, -0.819506880374713420, -0.819535532817517120, -0.819564183211482390, -0.819592831556536840, -0.819621477852609300, +-0.819650122099627950, -0.819678764297521620, -0.819707404446218150, -0.819736042545646140, -0.819764678595734320, -0.819793312596410530, -0.819821944547603380, -0.819850574449241480, +-0.819879202301253110, -0.819907828103566880, -0.819936451856110970, -0.819965073558813870, -0.819993693211604310, -0.820022310814410350, -0.820050926367160480, -0.820079539869783440, +-0.820108151322207490, -0.820136760724361480, -0.820165368076173240, -0.820193973377571610, -0.820222576628485190, -0.820251177828842160, -0.820279776978571240, -0.820308374077600820, +-0.820336969125859740, -0.820365562123275940, -0.820394153069778250, -0.820422741965295520, -0.820451328809755580, -0.820479913603087360, -0.820508496345219380, -0.820537077036080030, +-0.820565655675598360, -0.820594232263702320, -0.820622806800320630, -0.820651379285382230, -0.820679949718815080, -0.820708518100548120, -0.820737084430509740, -0.820765648708628780, +-0.820794210934833960, -0.820822771109053220, -0.820851329231215950, -0.820879885301250000, -0.820908439319084420, -0.820936991284647700, -0.820965541197868460, -0.820994089058675660, +-0.821022634866997450, -0.821051178622762560, -0.821079720325900040, -0.821108259976337960, -0.821136797574005150, -0.821165333118830440, -0.821193866610742340, -0.821222398049669790, +-0.821250927435541070, -0.821279454768285010, -0.821307980047830570, -0.821336503274106010, -0.821365024447040070, -0.821393543566561580, -0.821422060632599480, -0.821450575645082060, +-0.821479088603938150, -0.821507599509096800, -0.821536108360486180, -0.821564615158035250, -0.821593119901672830, -0.821621622591327540, -0.821650123226928540, -0.821678621808403900, +-0.821707118335682770, -0.821735612808694120, -0.821764105227366090, -0.821792595591627870, -0.821821083901408180, -0.821849570156635730, -0.821878054357239600, -0.821906536503148040, +-0.821935016594290250, -0.821963494630595040, -0.821991970611990920, -0.822020444538406950, -0.822048916409771730, -0.822077386226014560, -0.822105853987063600, -0.822134319692848110, +-0.822162783343297070, -0.822191244938338730, -0.822219704477902270, -0.822248161961916630, -0.822276617390310550, -0.822305070763013180, -0.822333522079952810, -0.822361971341058710, +-0.822390418546259940, -0.822418863695484890, -0.822447306788662620, -0.822475747825722190, -0.822504186806592320, -0.822532623731202170, -0.822561058599480250, -0.822589491411355960, +-0.822617922166757780, -0.822646350865614660, -0.822674777507855670, -0.822703202093409750, -0.822731624622206170, -0.822760045094173220, -0.822788463509240060, -0.822816879867336090, +-0.822845294168389700, -0.822873706412330040, -0.822902116599086080, -0.822930524728586850, -0.822958930800761550, -0.822987334815538650, -0.823015736772847450, -0.823044136672617220, +-0.823072534514776350, -0.823100930299254130, -0.823129324025979600, -0.823157715694881940, -0.823186105305889870, -0.823214492858932450, -0.823242878353939060, -0.823271261790838200, +-0.823299643169559170, -0.823328022490031120, -0.823356399752183000, -0.823384774955944090, -0.823413148101243000, -0.823441519188009010, -0.823469888216171510, -0.823498255185659000, +-0.823526620096400990, -0.823554982948326300, -0.823583343741364100, -0.823611702475443910, -0.823640059150494210, -0.823668413766444620, -0.823696766323223640, -0.823725116820760880, +-0.823753465258985180, -0.823781811637825930, -0.823810155957212410, -0.823838498217073110, -0.823866838417337650, -0.823895176557935430, -0.823923512638794930, -0.823951846659845670, +-0.823980178621016800, -0.824008508522237500, -0.824036836363437160, -0.824065162144544390, -0.824093485865488810, -0.824121807526199790, -0.824150127126605960, -0.824178444666636810, +-0.824206760146221520, -0.824235073565289690, -0.824263384923769830, -0.824291694221591540, -0.824320001458684230, -0.824348306634976710, -0.824376609750398390, -0.824404910804878540, +-0.824433209798346440, -0.824461506730731600, -0.824489801601962610, -0.824518094411969330, -0.824546385160680910, -0.824574673848026300, -0.824602960473935000, -0.824631245038336290, +-0.824659527541159560, -0.824687807982334210, -0.824716086361789060, -0.824744362679453720, -0.824772636935257710, -0.824800909129129840, -0.824829179260999750, -0.824857447330796690, +-0.824885713338450290, -0.824913977283889270, -0.824942239167043350, -0.824970498987842140, -0.824998756746214370, -0.825027012442089650, -0.825055266075397480, -0.825083517646067240, +-0.825111767154028340, -0.825140014599209710, -0.825168259981541200, -0.825196503300952180, -0.825224744557371710, -0.825252983750729310, -0.825281220880954570, -0.825309455947976670, +-0.825337688951725430, -0.825365919892129710, -0.825394148769119430, -0.825422375582623440, -0.825450600332571670, -0.825478823018893300, -0.825507043641517950, -0.825535262200375100, +-0.825563478695394040, -0.825591693126504160, -0.825619905493635290, -0.825648115796716490, -0.825676324035677260, -0.825704530210447320, -0.825732734320956060, -0.825760936367133210, +-0.825789136348907830, -0.825817334266209510, -0.825845530118968110, -0.825873723907112670, -0.825901915630572910, -0.825930105289278350, -0.825958292883158810, -0.825986478412143230, +-0.826014661876161460, -0.826042843275143320, -0.826071022609017880, -0.826099199877714850, -0.826127375081163740, -0.826155548219294270, -0.826183719292036160, -0.826211888299318460, +-0.826240055241071140, -0.826268220117223780, -0.826296382927705800, -0.826324543672446680, -0.826352702351376370, -0.826380858964424150, -0.826409013511520190, -0.826437165992593310, +-0.826465316407573590, -0.826493464756390850, -0.826521611038974150, -0.826549755255253430, -0.826577897405158300, -0.826606037488618720, -0.826634175505563840, -0.826662311455923390, +-0.826690445339627540, -0.826718577156605240, -0.826746706906786530, -0.826774834590101040, -0.826802960206478480, -0.826831083755848790, -0.826859205238141160, -0.826887324653285400, +-0.826915442001211700, -0.826943557281849100, -0.826971670495127540, -0.826999781640976870, -0.827027890719326810, -0.827055997730107180, -0.827084102673247390, -0.827112205548677480, +-0.827140306356326850, -0.827168405096125550, -0.827196501768003080, -0.827224596371889500, -0.827252688907714640, -0.827280779375407670, -0.827308867774898870, -0.827336954106118180, +-0.827365038368994780, -0.827393120563458930, -0.827421200689440140, -0.827449278746868360, -0.827477354735673630, -0.827505428655785360, -0.827533500507133370, -0.827561570289648050, +-0.827589638003258350, -0.827617703647894780, -0.827645767223486820, -0.827673828729964640, -0.827701888167257760, -0.827729945535296110, -0.827758000834009850, -0.827786054063328280, +-0.827814105223181660, -0.827842154313499720, -0.827870201334212520, -0.827898246285249880, -0.827926289166541540, -0.827954329978017320, -0.827982368719607620, -0.828010405391241820, +-0.828038439992849870, -0.828066472524361830, -0.828094502985707640, -0.828122531376817460, -0.828150557697620690, -0.828178581948047610, -0.828206604128028270, -0.828234624237492060, +-0.828262642276369480, -0.828290658244590140, -0.828318672142084430, -0.828346683968781860, -0.828374693724612590, -0.828402701409506780, -0.828430707023393940, -0.828458710566204350, +-0.828486712037868060, -0.828514711438314900, -0.828542708767475160, -0.828570704025278550, -0.828598697211655130, -0.828626688326535190, -0.828654677369848210, -0.828682664341524710, +-0.828710649241494400, -0.828738632069687560, -0.828766612826034250, -0.828794591510464310, -0.828822568122908110, -0.828850542663295160, -0.828878515131555970, -0.828906485527620470, +-0.828934453851418730, -0.828962420102881010, -0.828990384281937160, -0.829018346388517240, -0.829046306422551730, -0.829074264383970250, -0.829102220272703080, -0.829130174088680280, +-0.829158125831832130, -0.829186075502088890, -0.829214023099380300, -0.829241968623636530, -0.829269912074788170, -0.829297853452764630, -0.829325792757496630, -0.829353729988914100, +-0.829381665146947440, -0.829409598231526490, -0.829437529242581410, -0.829465458180042800, -0.829493385043840290, -0.829521309833904370, -0.829549232550165110, -0.829577153192552870, +-0.829605071760997960, -0.829632988255430080, -0.829660902675779740, -0.829688815021977330, -0.829716725293952680, -0.829744633491636300, -0.829772539614958230, -0.829800443663848860, +-0.829828345638238600, -0.829856245538057260, -0.829884143363235350, -0.829912039113703260, -0.829939932789390820, -0.829967824390228540, -0.829995713916146790, -0.830023601367075870, +-0.830051486742945820, -0.830079370043686930, -0.830107251269230020, -0.830135130419504600, -0.830163007494441390, -0.830190882493970770, -0.830218755418022810, -0.830246626266528230, +-0.830274495039416860, -0.830302361736619310, -0.830330226358066080, -0.830358088903686900, -0.830385949373412590, -0.830413807767173440, -0.830441664084899720, -0.830469518326522160, +-0.830497370491970480, -0.830525220581175730, -0.830553068594067520, -0.830580914530576810, -0.830608758390633750, -0.830636600174168740, -0.830664439881112490, -0.830692277511394960, +-0.830720113064946640, -0.830747946541698370, -0.830775777941579970, -0.830803607264522070, -0.830831434510455270, -0.830859259679309740, -0.830887082771016420, -0.830914903785505030, +-0.830942722722706420, -0.830970539582551290, -0.830998354364969600, -0.831026167069891960, -0.831053977697248980, -0.831081786246971270, -0.831109592718988770, -0.831137397113232310, +-0.831165199429632630, -0.831192999668119770, -0.831220797828624350, -0.831248593911076970, -0.831276387915408030, -0.831304179841548360, -0.831331969689428130, -0.831359757458977830, +-0.831387543150128530, -0.831415326762810050, -0.831443108296953230, -0.831470887752488670, -0.831498665129346890, -0.831526440427458600, -0.831554213646754080, -0.831581984787164270, +-0.831609753848619130, -0.831637520831049800, -0.831665285734386470, -0.831693048558560080, -0.831720809303501230, -0.831748567969140100, -0.831776324555407620, -0.831804079062234520, +-0.831831831489551090, -0.831859581837287920, -0.831887330105375860, -0.831915076293745500, -0.831942820402327700, -0.831970562431052500, -0.831998302379851060, -0.832026040248654010, +-0.832053776037391610, -0.832081509745994820, -0.832109241374394240, -0.832136970922520700, -0.832164698390304600, -0.832192423777676770, -0.832220147084568040, -0.832247868310908800, +-0.832275587456629770, -0.832303304521661900, -0.832331019505935690, -0.832358732409382180, -0.832386443231931560, -0.832414151973514870, -0.832441858634063060, -0.832469563213506400, +-0.832497265711775740, -0.832524966128802000, -0.832552664464515810, -0.832580360718848220, -0.832608054891729400, -0.832635746983090510, -0.832663436992862490, -0.832691124920975630, +-0.832718810767360980, -0.832746494531949380, -0.832774176214671650, -0.832801855815458290, -0.832829533334240260, -0.832857208770948710, -0.832884882125513810, -0.832912553397866740, +-0.832940222587938320, -0.832967889695659270, -0.832995554720960760, -0.833023217663773190, -0.833050878524027590, -0.833078537301654930, -0.833106193996585700, -0.833133848608751060, +-0.833161501138081740, -0.833189151584508680, -0.833216799947963050, -0.833244446228375120, -0.833272090425676290, -0.833299732539797060, -0.833327372570668360, -0.833355010518221360, +-0.833382646382386790, -0.833410280163095820, -0.833437911860279050, -0.833465541473867310, -0.833493169003792110, -0.833520794449983620, -0.833548417812373210, -0.833576039090891730, +-0.833603658285470230, -0.833631275396039760, -0.833658890422530830, -0.833686503364874710, -0.833714114223002570, -0.833741722996844900, -0.833769329686332990, -0.833796934291397670, +-0.833824536811970330, -0.833852137247981350, -0.833879735599362020, -0.833907331866043600, -0.833934926047956600, -0.833962518145032420, -0.833990108157201760, -0.834017696084395910, +-0.834045281926546030, -0.834072865683582740, -0.834100447355437310, -0.834128026942040910, -0.834155604443324260, -0.834183179859218640, -0.834210753189654990, -0.834238324434564580, +-0.834265893593878480, -0.834293460667527410, -0.834321025655442750, -0.834348588557555780, -0.834376149373797000, -0.834403708104097920, -0.834431264748389580, -0.834458819306603260, +-0.834486371778669690, -0.834513922164520140, -0.834541470464086110, -0.834569016677298100, -0.834596560804087620, -0.834624102844385710, -0.834651642798123540, -0.834679180665232500, +-0.834706716445643200, -0.834734250139287150, -0.834761781746095720, -0.834789311265999650, -0.834816838698930310, -0.834844364044818770, -0.834871887303596400, -0.834899408475194500, +-0.834926927559543900, -0.834954444556576190, -0.834981959466222110, -0.835009472288413160, -0.835036983023080490, -0.835064491670155400, -0.835091998229569370, -0.835119502701253010, +-0.835147005085137950, -0.835174505381155560, -0.835202003589236690, -0.835229499709312820, -0.835256993741315230, -0.835284485685175100, -0.835311975540824040, -0.835339463308192860, +-0.835366948987212980, -0.835394432577815870, -0.835421914079932600, -0.835449393493494450, -0.835476870818432800, -0.835504346054679160, -0.835531819202164570, -0.835559290260820320, +-0.835586759230578120, -0.835614226111368820, -0.835641690903123900, -0.835669153605774760, -0.835696614219252680, -0.835724072743489480, -0.835751529178415660, -0.835778983523963180, +-0.835806435780063420, -0.835833885946647310, -0.835861334023646490, -0.835888780010992320, -0.835916223908616200, -0.835943665716449850, -0.835971105434423990, -0.835998543062470350, +-0.836025978600520750, -0.836053412048505810, -0.836080843406357350, -0.836108272674006890, -0.836135699851385920, -0.836163124938425480, -0.836190547935057200, -0.836217968841212800, +-0.836245387656823210, -0.836272804381820170, -0.836300219016135160, -0.836327631559699580, -0.836355042012445150, -0.836382450374302920, -0.836409856645204510, -0.836437260825081740, +-0.836464662913865450, -0.836492062911487700, -0.836519460817879650, -0.836546856632973010, -0.836574250356699410, -0.836601641988990010, -0.836629031529776750, -0.836656418978990680, +-0.836683804336563530, -0.836711187602426800, -0.836738568776512200, -0.836765947858751360, -0.836793324849075540, -0.836820699747416240, -0.836848072553705520, -0.836875443267874330, +-0.836902811889854600, -0.836930178419577840, -0.836957542856975540, -0.836984905201979660, -0.837012265454521340, -0.837039623614532320, -0.837066979681944430, -0.837094333656688950, +-0.837121685538697590, -0.837149035327901970, -0.837176383024234030, -0.837203728627624930, -0.837231072138006520, -0.837258413555310610, -0.837285752879468490, -0.837313090110411880, +-0.837340425248072620, -0.837367758292382300, -0.837395089243272770, -0.837422418100675410, -0.837449744864521950, -0.837477069534744320, -0.837504392111273810, -0.837531712594042240, +-0.837559030982981460, -0.837586347278023060, -0.837613661479099100, -0.837640973586140760, -0.837668283599079850, -0.837695591517848560, -0.837722897342378150, -0.837750201072600340, +-0.837777502708447090, -0.837804802249850320, -0.837832099696741330, -0.837859395049052050, -0.837886688306714530, -0.837913979469660060, -0.837941268537820690, -0.837968555511128140, +-0.837995840389514140, -0.838023123172910830, -0.838050403861249400, -0.838077682454462010, -0.838104958952480610, -0.838132233355236680, -0.838159505662662060, -0.838186775874688710, +-0.838214043991248440, -0.838241310012273310, -0.838268573937694610, -0.838295835767444820, -0.838323095501455120, -0.838350353139657670, -0.838377608681984300, -0.838404862128367070, +-0.838432113478737810, -0.838459362733028010, -0.838486609891169850, -0.838513854953095380, -0.838541097918735990, -0.838568338788023950, -0.838595577560890980, -0.838622814237269140, +-0.838650048817090490, -0.838677281300286400, -0.838704511686789170, -0.838731739976530940, -0.838758966169443120, -0.838786190265457860, -0.838813412264507010, -0.838840632166523050, +-0.838867849971437150, -0.838895065679181710, -0.838922279289688770, -0.838949490802889940, -0.838976700218717400, -0.839003907537103080, -0.839031112757978930, -0.839058315881277330, +-0.839085516906929670, -0.839112715834868240, -0.839139912665025190, -0.839167107397332130, -0.839194300031721350, -0.839221490568124890, -0.839248679006474600, -0.839275865346702840, +-0.839303049588741250, -0.839330231732522190, -0.839357411777977400, -0.839384589725039040, -0.839411765573639170, -0.839438939323709940, -0.839466110975183640, -0.839493280527991770, +-0.839520447982066600, -0.839547613337340740, -0.839574776593745460, -0.839601937751213280, -0.839629096809676350, -0.839656253769066610, -0.839683408629316450, -0.839710561390357490, +-0.839737712052122220, -0.839764860614542810, -0.839792007077551080, -0.839819151441079330, -0.839846293705059700, -0.839873433869424590, -0.839900571934105610, -0.839927707899035260, +-0.839954841764145810, -0.839981973529369100, -0.840009103194637400, -0.840036230759882980, -0.840063356225037920, -0.840090479590034690, -0.840117600854805140, -0.840144720019281530, +-0.840171837083396380, -0.840198952047081280, -0.840226064910268970, -0.840253175672891370, -0.840280284334880890, -0.840307390896170010, -0.840334495356690250, -0.840361597716374310, +-0.840388697975154700, -0.840415796132963020, -0.840442892189731890, -0.840469986145393590, -0.840497077999880490, -0.840524167753124440, -0.840551255405058040, -0.840578340955613680, +-0.840605424404723190, -0.840632505752319180, -0.840659584998333930, -0.840686662142699710, -0.840713737185349030, -0.840740810126213820, -0.840767880965226590, -0.840794949702319940, +-0.840822016337425590, -0.840849080870476160, -0.840876143301404140, -0.840903203630141700, -0.840930261856621560, -0.840957317980775440, -0.840984372002536280, -0.841011423921836030, +-0.841038473738607180, -0.841065521452782020, -0.841092567064293250, -0.841119610573073160, -0.841146651979053920, -0.841173691282168010, -0.841200728482348060, -0.841227763579526000, +-0.841254796573634670, -0.841281827464606340, -0.841308856252373390, -0.841335882936868560, -0.841362907518023670, -0.841389929995771670, -0.841416950370045050, -0.841443968640775750, +-0.841470984807896620, -0.841497998871339910, -0.841525010831038260, -0.841552020686924360, -0.841579028438930180, -0.841606034086988640, -0.841633037631031700, -0.841660039070992290, +-0.841687038406802700, -0.841714035638395530, -0.841741030765703280, -0.841768023788658670, -0.841795014707194090, -0.841822003521241590, -0.841848990230734230, -0.841875974835604280, +-0.841902957335784460, -0.841929937731207280, -0.841956916021805450, -0.841983892207511020, -0.842010866288257160, -0.842037838263975940, -0.842064808134600050, -0.842091775900062120, +-0.842118741560294870, -0.842145705115230680, -0.842172666564802500, -0.842199625908942370, -0.842226583147583470, -0.842253538280657850, -0.842280491308098340, -0.842307442229837670, +-0.842334391045808430, -0.842361337755943350, -0.842388282360174710, -0.842415224858435670, -0.842442165250658290, -0.842469103536775510, -0.842496039716719940, -0.842522973790424290, +-0.842549905757821180, -0.842576835618843560, -0.842603763373423580, -0.842630689021494520, -0.842657612562988430, -0.842684533997838270, -0.842711453325976860, -0.842738370547336800, +-0.842765285661850830, -0.842792198669451880, -0.842819109570072110, -0.842846018363644920, -0.842872925050102360, -0.842899829629377480, -0.842926732101403120, -0.842953632466111880, +-0.842980530723436820, -0.843007426873310100, -0.843034320915665210, -0.843061212850434120, -0.843088102677550080, -0.843114990396945820, -0.843141876008553950, -0.843168759512307520, +-0.843195640908139370, -0.843222520195981980, -0.843249397375768430, -0.843276272447431200, -0.843303145410903230, -0.843330016266117370, -0.843356885013006540, -0.843383751651503480, +-0.843410616181541340, -0.843437478603052520, -0.843464338915969840, -0.843491197120226350, -0.843518053215754790, -0.843544907202488200, -0.843571759080359310, -0.843598608849301160, +-0.843625456509246360, -0.843652302060128090, -0.843679145501878950, -0.843705986834431760, -0.843732826057719710, -0.843759663171675610, -0.843786498176232410, -0.843813331071323060, +-0.843840161856880160, -0.843866990532837200, -0.843893817099126480, -0.843920641555681250, -0.843947463902434250, -0.843974284139318740, -0.844001102266267790, -0.844027918283213770, +-0.844054732190090200, -0.844081543986829550, -0.844108353673365120, -0.844135161249629730, -0.844161966715556430, -0.844188770071078290, -0.844215571316128340, -0.844242370450639320, +-0.844269167474544610, -0.844295962387776710, -0.844322755190268890, -0.844349545881954210, -0.844376334462765720, -0.844403120932636360, -0.844429905291499420, -0.844456687539287380, +-0.844483467675933960, -0.844510245701371680, -0.844537021615533680, -0.844563795418353250, -0.844590567109763210, -0.844617336689697070, -0.844644104158087330, -0.844670869514867580, +-0.844697632759970340, -0.844724393893329100, -0.844751152914876900, -0.844777909824546700, -0.844804664622271880, -0.844831417307985500, -0.844858167881620380, -0.844884916343110140, +-0.844911662692387270, -0.844938406929385270, -0.844965149054037300, -0.844991889066276540, -0.845018626966035910, -0.845045362753249040, -0.845072096427848640, -0.845098827989767880, +-0.845125557438940020, -0.845152284775298250, -0.845179009998775820, -0.845205733109305800, -0.845232454106821680, -0.845259172991256190, -0.845285889762543040, -0.845312604420614950, +-0.845339316965405320, -0.845366027396847410, -0.845392735714874390, -0.845419441919419530, -0.845446146010416340, -0.845472847987797650, -0.845499547851496950, -0.845526245601447180, +-0.845552941237581730, -0.845579634759834000, -0.845606326168137130, -0.845633015462424750, -0.845659702642629570, -0.845686387708685320, -0.845713070660524920, -0.845739751498081780, +-0.845766430221289390, -0.845793106830080800, -0.845819781324389510, -0.845846453704149010, -0.845873123969292040, -0.845899792119752640, -0.845926458155463410, -0.845953122076358090, +-0.845979783882369940, -0.846006443573432350, -0.846033101149478610, -0.846059756610442410, -0.846086409956256610, -0.846113061186854920, -0.846139710302170390, -0.846166357302136630, +-0.846193002186686920, -0.846219644955754750, -0.846246285609273620, -0.846272924147176590, -0.846299560569397480, -0.846326194875869240, -0.846352827066525590, -0.846379457141299810, +-0.846406085100125270, -0.846432710942935710, -0.846459334669664500, -0.846485956280244700, -0.846512575774610370, -0.846539193152694210, -0.846565808414430190, -0.846592421559751560, +-0.846619032588591950, -0.846645641500884950, -0.846672248296563620, -0.846698852975561910, -0.846725455537812870, -0.846752055983250100, -0.846778654311807210, -0.846805250523417710, +-0.846831844618015190, -0.846858436595533170, -0.846885026455904800, -0.846911614199064130, -0.846938199824944230, -0.846964783333478800, -0.846991364724601460, -0.847017943998245700, +-0.847044521154345030, -0.847071096192833270, -0.847097669113643590, -0.847124239916709930, -0.847150808601965450, -0.847177375169343990, -0.847203939618779160, -0.847230501950204330, +-0.847257062163553560, -0.847283620258759810, -0.847310176235757330, -0.847336730094479180, -0.847363281834859210, -0.847389831456831000, -0.847416378960328180, -0.847442924345284450, +-0.847469467611633660, -0.847496008759308970, -0.847522547788244540, -0.847549084698373420, -0.847575619489629560, -0.847602152161946790, -0.847628682715258490, -0.847655211149498600, +-0.847681737464600850, -0.847708261660498510, -0.847734783737125850, -0.847761303694415820, -0.847787821532302700, -0.847814337250719970, -0.847840850849601370, -0.847867362328880940, +-0.847893871688491840, -0.847920378928368250, -0.847946884048443540, -0.847973387048651550, -0.847999887928926110, -0.848026386689201050, -0.848052883329409870, -0.848079377849486840, +-0.848105870249365120, -0.848132360528978890, -0.848158848688261520, -0.848185334727147190, -0.848211818645569380, -0.848238300443462050, -0.848264780120759230, -0.848291257677394110, +-0.848317733113301160, -0.848344206428413680, -0.848370677622665600, -0.848397146695990980, -0.848423613648323420, -0.848450078479596750, -0.848476541189745140, -0.848503001778702080, +-0.848529460246401520, -0.848555916592777290, -0.848582370817763110, -0.848608822921293140, -0.848635272903300990, -0.848661720763720710, -0.848688166502486350, -0.848714610119531420, +-0.848741051614790190, -0.848767490988196040, -0.848793928239683140, -0.848820363369185430, -0.848846796376636850, -0.848873227261971450, -0.848899656025122850, -0.848926082666025210, +-0.848952507184612240, -0.848978929580818000, -0.849005349854576320, -0.849031768005821360, -0.849058184034486960, -0.849084597940507390, -0.849111009723816030, -0.849137419384347390, +-0.849163826922034960, -0.849190232336813010, -0.849216635628615490, -0.849243036797376340, -0.849269435843029610, -0.849295832765509460, -0.849322227564749840, -0.849348620240684250, +-0.849375010793247290, -0.849401399222372680, -0.849427785527994690, -0.849454169710047170, -0.849480551768464380, -0.849506931703180150, -0.849533309514128640, -0.849559685201243700, +-0.849586058764459580, -0.849612430203710360, -0.849638799518929950, -0.849665166710052660, -0.849691531777012620, -0.849717894719743460, -0.849744255538179890, -0.849770614232255420, +-0.849796970801904420, -0.849823325247060950, -0.849849677567659170, -0.849876027763633470, -0.849902375834917460, -0.849928721781445740, -0.849955065603152040, -0.849981407299970630, +-0.850007746871835670, -0.850034084318681330, -0.850060419640441770, -0.850086752837051480, -0.850113083908444090, -0.850139412854554080, -0.850165739675315390, -0.850192064370662410, +-0.850218386940529200, -0.850244707384850030, -0.850271025703559060, -0.850297341896590900, -0.850323655963878930, -0.850349967905358220, -0.850376277720962360, -0.850402585410625740, +-0.850428890974282650, -0.850455194411867340, -0.850481495723314330, -0.850507794908557320, -0.850534091967531050, -0.850560386900169330, -0.850586679706406560, -0.850612970386177230, +-0.850639258939415390, -0.850665545366055430, -0.850691829666031850, -0.850718111839278370, -0.850744391885729920, -0.850770669805320230, -0.850796945597983910, -0.850823219263655230, +-0.850849490802268460, -0.850875760213757990, -0.850902027498058320, -0.850928292655103610, -0.850954555684828030, -0.850980816587165960, -0.851007075362051780, -0.851033332009420000, +-0.851059586529204880, -0.851085838921341040, -0.851112089185762310, -0.851138337322403630, -0.851164583331198930, -0.851190827212082720, -0.851217068964989390, -0.851243308589853420, +-0.851269546086609210, -0.851295781455191360, -0.851322014695533810, -0.851348245807571510, -0.851374474791238290, -0.851400701646468970, -0.851426926373197830, -0.851453148971359370, +-0.851479369440888310, -0.851505587781718590, -0.851531803993785030, -0.851558018077021810, -0.851584230031363630, -0.851610439856744780, -0.851636647553099760, -0.851662853120363270, +-0.851689056558469830, -0.851715257867353470, -0.851741457046949260, -0.851767654097191130, -0.851793849018013920, -0.851820041809352000, -0.851846232471140000, -0.851872421003312510, +-0.851898607405804030, -0.851924791678548950, -0.851950973821482100, -0.851977153834537540, -0.852003331717650080, -0.852029507470754340, -0.852055681093784820, -0.852081852586676350, +-0.852108021949362970, -0.852134189181779860, -0.852160354283860940, -0.852186517255541180, -0.852212678096755050, -0.852238836807437390, -0.852264993387522480, -0.852291147836945370, +-0.852317300155640220, -0.852343450343541980, -0.852369598400584900, -0.852395744326703840, -0.852421888121833390, -0.852448029785908280, -0.852474169318863110, -0.852500306720632710, +-0.852526441991151460, -0.852552575130353980, -0.852578706138174990, -0.852604835014549310, -0.852630961759411440, -0.852657086372696220, -0.852683208854338570, -0.852709329204272560, +-0.852735447422433570, -0.852761563508755650, -0.852787677463173850, -0.852813789285622900, -0.852839898976037400, -0.852866006534352180, -0.852892111960502300, -0.852918215254421690, +-0.852944316416045960, -0.852970415445309050, -0.852996512342146240, -0.853022607106492030, -0.853048699738281350, -0.853074790237449250, -0.853100878603929800, -0.853126964837658490, +-0.853153048938569470, -0.853179130906597800, -0.853205210741678320, -0.853231288443745850, -0.853257364012735220, -0.853283437448581370, -0.853309508751218580, -0.853335577920582460, +-0.853361644956607050, -0.853387709859227410, -0.853413772628378700, -0.853439833263995420, -0.853465891766012620, -0.853491948134365350, -0.853518002368987890, -0.853544054469815740, +-0.853570104436783160, -0.853596152269825330, -0.853622197968877170, -0.853648241533873420, -0.853674282964749340, -0.853700322261439330, -0.853726359423878760, -0.853752394452002130, +-0.853778427345744380, -0.853804458105040690, -0.853830486729825750, -0.853856513220034640, -0.853882537575602510, -0.853908559796463740, -0.853934579882553830, -0.853960597833807180, +-0.853986613650159150, -0.854012627331544480, -0.854038638877898330, -0.854064648289155740, -0.854090655565251320, -0.854116660706120580, -0.854142663711697890, -0.854168664581918420, +-0.854194663316717450, -0.854220659916029800, -0.854246654379790420, -0.854272646707934790, -0.854298636900397200, -0.854324624957113250, -0.854350610878017450, -0.854376594663045270, +-0.854402576312131460, -0.854428555825211270, -0.854454533202219760, -0.854480508443092090, -0.854506481547762880, -0.854532452516167720, -0.854558421348241230, -0.854584388043918670, +-0.854610352603135110, -0.854636315025825710, -0.854662275311925730, -0.854688233461369910, -0.854714189474093610, -0.854740143350031680, -0.854766095089119380, -0.854792044691291890, +-0.854817992156484240, -0.854843937484631610, -0.854869880675669380, -0.854895821729532160, -0.854921760646155660, -0.854947697425474500, -0.854973632067424160, -0.854999564571939710, +-0.855025494938956410, -0.855051423168409320, -0.855077349260233820, -0.855103273214364860, -0.855129195030737810, -0.855155114709287620, -0.855181032249949680, -0.855206947652659030, +-0.855232860917351180, -0.855258772043961280, -0.855284681032424280, -0.855310587882675780, -0.855336492594650610, -0.855362395168284160, -0.855388295603511710, -0.855414193900268630, +-0.855440090058489980, -0.855465984078111360, -0.855491875959067620, -0.855517765701294230, -0.855543653304726370, -0.855569538769299310, -0.855595422094948430, -0.855621303281608900, +-0.855647182329216440, -0.855673059237705870, -0.855698934007012690, -0.855724806637072070, -0.855750677127819380, -0.855776545479190130, -0.855802411691119370, -0.855828275763542590, +-0.855854137696395400, -0.855879997489612630, -0.855905855143130110, -0.855931710656882670, -0.855957564030806030, -0.855983415264835350, -0.856009264358906230, -0.856035111312953960, +-0.856060956126914130, -0.856086798800721690, -0.856112639334312480, -0.856138477727621420, -0.856164313980584120, -0.856190148093136090, -0.856215980065212710, -0.856241809896749580, +-0.856267637587681650, -0.856293463137944970, -0.856319286547474360, -0.856345107816205430, -0.856370926944073910, -0.856396743931014950, -0.856422558776964160, -0.856448371481857150, +-0.856474182045629080, -0.856499990468215680, -0.856525796749552200, -0.856551600889574160, -0.856577402888217150, -0.856603202745416570, -0.856629000461108010, -0.856654796035227210, +-0.856680589467709310, -0.856706380758489820, -0.856732169907504340, -0.856757956914688480, -0.856783741779977740, -0.856809524503307610, -0.856835305084613810, -0.856861083523831610, +-0.856886859820896960, -0.856912633975744910, -0.856938405988311280, -0.856964175858531570, -0.856989943586341510, -0.857015709171676470, -0.857041472614472500, -0.857067233914664550, +-0.857092993072188780, -0.857118750086980240, -0.857144504958974980, -0.857170257688108280, -0.857196008274316080, -0.857221756717533980, -0.857247503017697370, -0.857273247174742070, +-0.857298989188603590, -0.857324729059217530, -0.857350466786519720, -0.857376202370445650, -0.857401935810931160, -0.857427667107912070, -0.857453396261323550, -0.857479123271101760, +-0.857504848137181860, -0.857530570859500020, -0.857556291437991610, -0.857582009872592480, -0.857607726163238330, -0.857633440309865210, -0.857659152312408080, -0.857684862170803420, +-0.857710569884986400, -0.857736275454892840, -0.857761978880458690, -0.857787680161619550, -0.857813379298311470, -0.857839076290469630, -0.857864771138030390, -0.857890463840929040, +-0.857916154399101520, -0.857941842812483530, -0.857967529081010930, -0.857993213204619630, -0.858018895183245480, -0.858044575016823850, -0.858070252705290910, -0.858095928248582270, +-0.858121601646633760, -0.858147272899381200, -0.858172942006760420, -0.858198608968707370, -0.858224273785158090, -0.858249936456047970, -0.858275596981312840, -0.858301255360888750, +-0.858326911594711530, -0.858352565682717010, -0.858378217624841120, -0.858403867421019820, -0.858429515071188700, -0.858455160575283930, -0.858480803933241110, -0.858506445144996300, +-0.858532084210485320, -0.858557721129644120, -0.858583355902408640, -0.858608988528715030, -0.858634619008498690, -0.858660247341695990, -0.858685873528242550, -0.858711497568074410, +-0.858737119461127410, -0.858762739207337700, -0.858788356806641340, -0.858813972258973930, -0.858839585564271760, -0.858865196722470410, -0.858890805733506070, -0.858916412597314660, +-0.858942017313832350, -0.858967619882994860, -0.858993220304738680, -0.859018818578999090, -0.859044414705712690, -0.859070008684815090, -0.859095600516242450, -0.859121190199930830, +-0.859146777735816270, -0.859172363123834710, -0.859197946363922440, -0.859223527456015160, -0.859249106400049150, -0.859274683195960230, -0.859300257843684690, -0.859325830343158350, +-0.859351400694317590, -0.859376968897098470, -0.859402534951436700, -0.859428098857268790, -0.859453660614530430, -0.859479220223157920, -0.859504777683087420, -0.859530332994254850, +-0.859555886156596620, -0.859581437170048760, -0.859606986034547100, -0.859632532750028270, -0.859658077316427850, -0.859683619733682240, -0.859709160001727590, -0.859734698120499960, +-0.859760234089935630, -0.859785767909970970, -0.859811299580541920, -0.859836829101584320, -0.859862356473034660, -0.859887881694829210, -0.859913404766903920, -0.859938925689195170, +-0.859964444461639330, -0.859989961084172250, -0.860015475556730300, -0.860040987879249540, -0.860066498051666350, -0.860092006073916890, -0.860117511945937440, -0.860143015667664160, +-0.860168517239033540, -0.860194016659981520, -0.860219513930444490, -0.860245009050358610, -0.860270502019660150, -0.860295992838285510, -0.860321481506170830, -0.860346968023252610, +-0.860372452389466800, -0.860397934604750110, -0.860423414669038380, -0.860448892582267980, -0.860474368344375520, -0.860499841955297050, -0.860525313414968960, -0.860550782723327860, +-0.860576249880309560, -0.860601714885850800, -0.860627177739887620, -0.860652638442356510, -0.860678096993193640, -0.860703553392335730, -0.860729007639718820, -0.860754459735279640, +-0.860779909678954120, -0.860805357470678990, -0.860830803110390290, -0.860856246598024620, -0.860881687933518270, -0.860907127116807720, -0.860932564147829480, -0.860957999026519700, +-0.860983431752815220, -0.861008862326651860, -0.861034290747966340, -0.861059717016695040, -0.861085141132774570, -0.861110563096141090, -0.861135982906731550, -0.861161400564481870, +-0.861186816069328790, -0.861212229421208560, -0.861237640620057700, -0.861263049665812690, -0.861288456558410130, -0.861313861297786310, -0.861339263883878160, -0.861364664316621840, +-0.861390062595953740, -0.861415458721810360, -0.861440852694128290, -0.861466244512844150, -0.861491634177894430, -0.861517021689215850, -0.861542407046744450, -0.861567790250417300, +-0.861593171300170440, -0.861618550195940580, -0.861643926937664450, -0.861669301525278430, -0.861694673958719130, -0.861720044237923480, -0.861745412362827420, -0.861770778333368010, +-0.861796142149481530, -0.861821503811104670, -0.861846863318174060, -0.861872220670626190, -0.861897575868398100, -0.861922928911425860, -0.861948279799646390, -0.861973628532996190, +-0.861998975111411770, -0.862024319534829940, -0.862049661803187320, -0.862075001916420610, -0.862100339874466550, -0.862125675677261390, -0.862151009324742310, -0.862176340816845470, +-0.862201670153507790, -0.862226997334666010, -0.862252322360256620, -0.862277645230216440, -0.862302965944482410, -0.862328284502990710, -0.862353600905678590, -0.862378915152482220, +-0.862404227243338430, -0.862429537178184270, -0.862454844956956120, -0.862480150579591150, -0.862505454046025630, -0.862530755356196610, -0.862556054510040470, -0.862581351507494270, +-0.862606646348494600, -0.862631939032978410, -0.862657229560882310, -0.862682517932143340, -0.862707804146697900, -0.862733088204483240, -0.862758370105435550, -0.862783649849491960, +-0.862808927436589210, -0.862834202866664120, -0.862859476139653860, -0.862884747255494580, -0.862910016214123670, -0.862935283015477510, -0.862960547659493150, -0.862985810146107420, +-0.863011070475257270, -0.863036328646879290, -0.863061584660910760, -0.863086838517288070, -0.863112090215948480, -0.863137339756828490, -0.863162587139865050, -0.863187832364995190, +-0.863213075432155860, -0.863238316341283670, -0.863263555092316000, -0.863288791685189240, -0.863314026119840650, -0.863339258396206840, -0.863364488514224870, -0.863389716473831670, +-0.863414942274964180, -0.863440165917559570, -0.863465387401554320, -0.863490606726885820, -0.863515823893490580, -0.863541038901305740, -0.863566251750268350, -0.863591462440315260, +-0.863616670971383620, -0.863641877343410470, -0.863667081556332430, -0.863692283610086880, -0.863717483504610420, -0.863742681239840220, -0.863767876815713320, -0.863793070232166780, +-0.863818261489137540, -0.863843450586562870, -0.863868637524379590, -0.863893822302524430, -0.863919004920934760, -0.863944185379547540, -0.863969363678299910, -0.863994539817128810, +-0.864019713795971640, -0.864044885614765000, -0.864070055273446270, -0.864095222771952280, -0.864120388110220180, -0.864145551288187150, -0.864170712305790120, -0.864195871162966480, +-0.864221027859653270, -0.864246182395787320, -0.864271334771306020, -0.864296484986146310, -0.864321633040245340, -0.864346778933540280, -0.864371922665968300, -0.864397064237466650, +-0.864422203647972180, -0.864447340897422480, -0.864472475985754050, -0.864497608912904610, -0.864522739678811100, -0.864547868283410680, -0.864572994726640620, -0.864598119008438300, +-0.864623241128740450, -0.864648361087484660, -0.864673478884607880, -0.864698594520047270, -0.864723707993740210, -0.864748819305623970, -0.864773928455635610, -0.864799035443712620, +-0.864824140269791930, -0.864849242933811050, -0.864874343435706790, -0.864899441775416670, -0.864924537952878050, -0.864949631968027990, -0.864974723820804090, -0.864999813511143190, +-0.865024901038983000, -0.865049986404260340, -0.865075069606912610, -0.865100150646877290, -0.865125229524091540, -0.865150306238492760, -0.865175380790018430, -0.865200453178605500, +-0.865225523404191570, -0.865250591466713570, -0.865275657366109120, -0.865300721102315600, -0.865325782675270270, -0.865350842084910420, -0.865375899331173760, -0.865400954413997230, +-0.865426007333318200, -0.865451058089074080, -0.865476106681202450, -0.865501153109640380, -0.865526197374325570, -0.865551239475195410, -0.865576279412186960, -0.865601317185238030, +-0.865626352794285570, -0.865651386239267180, -0.865676417520120370, -0.865701446636782500, -0.865726473589191080, -0.865751498377283710, -0.865776521000997330, -0.865801541460269770, +-0.865826559755038190, -0.865851575885240310, -0.865876589850813390, -0.865901601651695050, -0.865926611287822890, -0.865951618759134070, -0.865976624065566300, -0.866001627207056870, +-0.866026628183543260, -0.866051626994963190, -0.866076623641253930, -0.866101618122353200, -0.866126610438198610, -0.866151600588727310, -0.866176588573877140, -0.866201574393585360, +-0.866226558047789700, -0.866251539536427530, -0.866276518859436570, -0.866301496016754210, -0.866326471008318500, -0.866351443834066260, -0.866376414493935650, -0.866401382987863840, +-0.866426349315788550, -0.866451313477647370, -0.866476275473377910, -0.866501235302918000, -0.866526192966204810, -0.866551148463176270, -0.866576101793769760, -0.866601052957922890, +-0.866626001955573380, -0.866650948786658940, -0.866675893451117170, -0.866700835948885810, -0.866725776279902100, -0.866750714444104230, -0.866775650441429350, -0.866800584271815280, +-0.866825515935199850, -0.866850445431520570, -0.866875372760715250, -0.866900297922721610, -0.866925220917477260, -0.866950141744919690, -0.866975060404986730, -0.866999976897616100, +-0.867024891222745510, -0.867049803380312790, -0.867074713370255660, -0.867099621192511600, -0.867124526847018680, -0.867149430333714280, -0.867174331652536210, -0.867199230803422430, +-0.867224127786310530, -0.867249022601138230, -0.867273915247843700, -0.867298805726364090, -0.867323694036637670, -0.867348580178601950, -0.867373464152194630, -0.867398345957353660, +-0.867423225594016860, -0.867448103062122280, -0.867472978361607080, -0.867497851492409770, -0.867522722454467600, -0.867547591247718520, -0.867572457872100580, -0.867597322327551380, +-0.867622184614008970, -0.867647044731411300, -0.867671902679695850, -0.867696758458800790, -0.867721612068663610, -0.867746463509222470, -0.867771312780415080, -0.867796159882179400, +-0.867821004814453460, -0.867845847577175090, -0.867870688170281900, -0.867895526593712270, -0.867920362847403590, -0.867945196931294020, -0.867970028845321370, -0.867994858589423710, +-0.868019686163539190, -0.868044511567605090, -0.868069334801560010, -0.868094155865341440, -0.868118974758887330, -0.868143791482135940, -0.868168606035024990, -0.868193418417492540, +-0.868218228629476730, -0.868243036670915180, -0.868267842541746270, -0.868292646241907500, -0.868317447771337130, -0.868342247129973100, -0.868367044317753470, -0.868391839334616170, +-0.868416632180499580, -0.868441422855341430, -0.868466211359079420, -0.868490997691651940, -0.868515781852996940, -0.868540563843052560, -0.868565343661756640, -0.868590121309047670, +-0.868614896784863140, -0.868639670089141670, -0.868664441221820630, -0.868689210182838620, -0.868713976972133590, -0.868738741589643590, -0.868763504035306780, -0.868788264309061310, +-0.868813022410845020, -0.868837778340596500, -0.868862532098253150, -0.868887283683753560, -0.868912033097035800, -0.868936780338037900, -0.868961525406698240, -0.868986268302954560, +-0.869011009026745440, -0.869035747578008610, -0.869060483956682450, -0.869085218162705010, -0.869109950196014560, -0.869134680056549150, -0.869159407744247380, -0.869184133259046750, +-0.869208856600886090, -0.869233577769703000, -0.869258296765436090, -0.869283013588023290, -0.869307728237403100, -0.869332440713513450, -0.869357151016293070, -0.869381859145679450, +-0.869406565101611520, -0.869431268884026890, -0.869455970492864050, -0.869480669928061390, -0.869505367189556950, -0.869530062277289350, -0.869554755191196400, -0.869579445931216830, +-0.869604134497288350, -0.869628820889349560, -0.869653505107338630, -0.869678187151194050, -0.869702867020853980, -0.869727544716256910, -0.869752220237340890, -0.869776893584044420, +-0.869801564756305550, -0.869826233754062650, -0.869850900577254340, -0.869875565225818660, -0.869900227699694330, -0.869924887998819170, -0.869949546123132130, -0.869974202072570920, +-0.869998855847074150, -0.870023507446580300, -0.870048156871027660, -0.870072804120354700, -0.870097449194499940, -0.870122092093401190, -0.870146732816997610, -0.870171371365226930, +-0.870196007738027740, -0.870220641935338660, -0.870245273957097830, -0.870269903803243870, -0.870294531473715490, -0.870319156968450410, -0.870343780287387680, -0.870368401430465340, +-0.870393020397622010, -0.870417637188796060, -0.870442251803925980, -0.870466864242950610, -0.870491474505807770, -0.870516082592436510, -0.870540688502774770, -0.870565292236761380, +-0.870589893794334710, -0.870614493175433380, -0.870639090379995760, -0.870663685407960690, -0.870688278259266090, -0.870712868933851030, -0.870737457431653650, -0.870762043752612570, +-0.870786627896666390, -0.870811209863753710, -0.870835789653812920, -0.870860367266782840, -0.870884942702601970, -0.870909515961208470, -0.870934087042541160, -0.870958655946538650, +-0.870983222673139430, -0.871007787222282230, -0.871032349593905740, -0.871056909787948250, -0.871081467804348590, -0.871106023643045120, -0.871130577303976580, -0.871155128787081570, +-0.871179678092298680, -0.871204225219566750, -0.871228770168824380, -0.871253312940009850, -0.871277853533062310, -0.871302391947919920, -0.871326928184521510, -0.871351462242805800, +-0.871375994122711380, -0.871400523824177210, -0.871425051347141540, -0.871449576691543440, -0.871474099857321270, -0.871498620844413760, -0.871523139652759740, -0.871547656282297800, +-0.871572170732966780, -0.871596683004705610, -0.871621193097452450, -0.871645701011146470, -0.871670206745726150, -0.871694710301130220, -0.871719211677297490, -0.871743710874166800, +-0.871768207891676750, -0.871792702729766500, -0.871817195388374210, -0.871841685867439150, -0.871866174166899710, -0.871890660286694820, -0.871915144226763310, -0.871939625987043890, +-0.871964105567475610, -0.871988582967996860, -0.872013058188546910, -0.872037531229064020, -0.872062002089487360, -0.872086470769755650, -0.872110937269807820, -0.872135401589582580, +-0.872159863729019100, -0.872184323688055760, -0.872208781466631830, -0.872233237064685700, -0.872257690482156510, -0.872282141718983110, -0.872306590775104310, -0.872331037650458940, +-0.872355482344986390, -0.872379924858625030, -0.872404365191313590, -0.872428803342991330, -0.872453239313596970, -0.872477673103069670, -0.872502104711348040, -0.872526534138371450, +-0.872550961384078280, -0.872575386448407820, -0.872599809331298880, -0.872624230032690300, -0.872648648552521110, -0.872673064890730380, -0.872697479047256920, -0.872721891022040010, +-0.872746300815018140, -0.872770708426130800, -0.872795113855316380, -0.872819517102514260, -0.872843918167663380, -0.872868317050702560, -0.872892713751571290, -0.872917108270207960, +-0.872941500606552070, -0.872965890760542210, -0.872990278732117650, -0.873014664521217340, -0.873039048127780440, -0.873063429551745980, -0.873087808793053030, -0.873112185851640410, +-0.873136560727447500, -0.873160933420413010, -0.873185303930476220, -0.873209672257576060, -0.873234038401651810, -0.873258402362642410, -0.873282764140487220, -0.873307123735124980, +-0.873331481146495060, -0.873355836374536290, -0.873380189419187940, -0.873404540280389050, -0.873428888958078800, -0.873453235452196550, -0.873477579762681030, -0.873501921889471840, +-0.873526261832507590, -0.873550599591727650, -0.873574935167071190, -0.873599268558477360, -0.873623599765885440, -0.873647928789234810, -0.873672255628463960, -0.873696580283512820, +-0.873720902754320020, -0.873745223040824910, -0.873769541142966680, -0.873793857060684690, -0.873818170793917990, -0.873842482342606200, -0.873866791706688130, -0.873891098886102840, +-0.873915403880789810, -0.873939706690688320, -0.873964007315737530, -0.873988305755876720, -0.874012602011045360, -0.874036896081182290, -0.874061187966227230, -0.874085477666118880, +-0.874109765180796860, -0.874134050510200540, -0.874158333654268980, -0.874182614612941670, -0.874206893386157980, -0.874231169973856860, -0.874255444375978020, -0.874279716592460400, +-0.874303986623243490, -0.874328254468266560, -0.874352520127469000, -0.874376783600790410, -0.874401044888169610, -0.874425303989546320, -0.874449560904859700, -0.874473815634049130, +-0.874498068177054000, -0.874522318533813680, -0.874546566704267560, -0.874570812688355350, -0.874595056486015760, -0.874619298097188860, -0.874643537521813450, -0.874667774759829150, +-0.874692009811175450, -0.874716242675791730, -0.874740473353617490, -0.874764701844592100, -0.874788928148654830, -0.874813152265745520, -0.874837374195803100, -0.874861593938767170, +-0.874885811494577340, -0.874910026863172870, -0.874934240044493610, -0.874958451038478580, -0.874982659845067510, -0.875006866464199670, -0.875031070895814670, -0.875055273139851990, +-0.875079473196251120, -0.875103671064951570, -0.875127866745893050, -0.875152060239014600, -0.875176251544256270, -0.875200440661557110, -0.875224627590856840, -0.875248812332094950, +-0.875272994885211040, -0.875297175250144720, -0.875321353426835590, -0.875345529415223140, -0.875369703215246650, -0.875393874826845830, -0.875418044249960390, -0.875442211484529830, +-0.875466376530493750, -0.875490539387791870, -0.875514700056363560, -0.875538858536148660, -0.875563014827086320, -0.875587168929116480, -0.875611320842178740, -0.875635470566212710, +-0.875659618101158000, -0.875683763446954420, -0.875707906603541250, -0.875732047570858540, -0.875756186348845560, -0.875780322937442010, -0.875804457336587630, -0.875828589546222220, +-0.875852719566285520, -0.875876847396716780, -0.875900973037456070, -0.875925096488442860, -0.875949217749616760, -0.875973336820917710, -0.875997453702285320, -0.876021568393659190, +-0.876045680894979470, -0.876069791206185330, -0.876093899327216820, -0.876118005258013420, -0.876142108998515080, -0.876166210548661390, -0.876190309908392200, -0.876214407077647190, +-0.876238502056366440, -0.876262594844489100, -0.876286685441955650, -0.876310773848705150, -0.876334860064677760, -0.876358944089813190, -0.876383025924051260, -0.876407105567332030, +-0.876431183019594880, -0.876455258280779860, -0.876479331350826560, -0.876503402229674930, -0.876527470917264680, -0.876551537413535860, -0.876575601718428190, -0.876599663831881700, +-0.876623723753835900, -0.876647781484230950, -0.876671837023006330, -0.876695890370102090, -0.876719941525458180, -0.876743990489014410, -0.876768037260710840, -0.876792081840487070, +-0.876816124228283260, -0.876840164424038890, -0.876864202427694140, -0.876888238239188820, -0.876912271858462990, -0.876936303285456350, -0.876960332520109300, -0.876984359562361200, +-0.877008384412152340, -0.877032407069422320, -0.877056427534111280, -0.877080445806159180, -0.877104461885506060, -0.877128475772091630, -0.877152487465856390, -0.877176496966739610, +-0.877200504274681770, -0.877224509389622490, -0.877248512311502030, -0.877272513040260220, -0.877296511575837100, -0.877320507918172950, -0.877344502067207270, -0.877368494022880640, +-0.877392483785132460, -0.877416471353903100, -0.877440456729132620, -0.877464439910760950, -0.877488420898728140, -0.877512399692974570, -0.877536376293439720, -0.877560350700064220, +-0.877584322912787650, -0.877608292931550180, -0.877632260756291970, -0.877656226386953180, -0.877680189823473840, -0.877704151065794140, -0.877728110113853880, -0.877752066967593560, +-0.877776021626952900, -0.877799974091872160, -0.877823924362291510, -0.877847872438151100, -0.877871818319391100, -0.877895762005951430, -0.877919703497772490, -0.877943642794794200, +-0.877967579896956730, -0.877991514804200230, -0.878015447516464990, -0.878039378033691250, -0.878063306355819200, -0.878087232482788640, -0.878111156414540180, -0.878135078151013770, +-0.878158997692149560, -0.878182915037887810, -0.878206830188168810, -0.878230743142933030, -0.878254653902120100, -0.878278562465670710, -0.878302468833524810, -0.878326373005622660, +-0.878350274981904540, -0.878374174762310830, -0.878398072346781690, -0.878421967735257490, -0.878445860927678180, -0.878469751923984470, -0.878493640724116180, -0.878517527328013800, +-0.878541411735617510, -0.878565293946867780, -0.878589173961704770, -0.878613051780069100, -0.878636927401900470, -0.878660800827139820, -0.878684672055726980, -0.878708541087602430, +-0.878732407922706460, -0.878756272560979550, -0.878780135002362180, -0.878803995246794200, -0.878827853294216530, -0.878851709144568890, -0.878875562797792110, -0.878899414253826340, +-0.878923263512612070, -0.878947110574089590, -0.878970955438199590, -0.878994798104882010, -0.879018638574077580, -0.879042476845726450, -0.879066312919769000, -0.879090146796145830, +-0.879113978474797330, -0.879137807955663870, -0.879161635238686070, -0.879185460323804180, -0.879209283210958480, -0.879233103900089460, -0.879256922391137730, -0.879280738684043770, +-0.879304552778747860, -0.879328364675190930, -0.879352174373312700, -0.879375981873054320, -0.879399787174355850, -0.879423590277157770, -0.879447391181400810, -0.879471189887025330, +-0.879494986393971940, -0.879518780702181260, -0.879542572811593430, -0.879566362722149280, -0.879590150433789190, -0.879613935946453540, -0.879637719260083160, -0.879661500374618430, +-0.879685279290000180, -0.879709056006168550, -0.879732830523064500, -0.879756602840628180, -0.879780372958800290, -0.879804140877521460, -0.879827906596732270, -0.879851670116373330, +-0.879875431436385470, -0.879899190556708840, -0.879922947477284390, -0.879946702198052380, -0.879970454718953630, -0.879994205039928650, -0.880017953160918240, -0.880041699081862920, +-0.880065442802703600, -0.880089184323380460, -0.880112923643834530, -0.880136660764006100, -0.880160395683835970, -0.880184128403264990, -0.880207858922233520, -0.880231587240682730, +-0.880255313358552780, -0.880279037275784710, -0.880302758992318800, -0.880326478508095980, -0.880350195823057070, -0.880373910937142570, -0.880397623850293300, -0.880421334562450310, +-0.880445043073553650, -0.880468749383544580, -0.880492453492363490, -0.880516155399951210, -0.880539855106248550, -0.880563552611196340, -0.880587247914735190, -0.880610941016806150, +-0.880634631917349700, -0.880658320616306440, -0.880682007113617440, -0.880705691409223500, -0.880729373503065240, -0.880753053395083580, -0.880776731085219480, -0.880800406573413300, +-0.880824079859606310, -0.880847750943739020, -0.880871419825752230, -0.880895086505587010, -0.880918750983183950, -0.880942413258484100, -0.880966073331428400, -0.880989731201957340, +-0.881013386870012070, -0.881037040335533210, -0.881060691598461680, -0.881084340658738530, -0.881107987516304370, -0.881131632171100580, -0.881155274623067530, -0.881178914872146390, +-0.881202552918277760, -0.881226188761402800, -0.881249822401462430, -0.881273453838397390, -0.881297083072148710, -0.881320710102657670, -0.881344334929864530, -0.881367957553710780, +-0.881391577974136920, -0.881415196191084100, -0.881438812204493380, -0.881462426014305580, -0.881486037620461740, -0.881509647022902910, -0.881533254221569810, -0.881556859216403810, +-0.881580462007345520, -0.881604062594335990, -0.881627660977316260, -0.881651257156227500, -0.881674851131010740, -0.881698442901606590, -0.881722032467956550, -0.881745619830001330, +-0.881769204987681960, -0.881792787940939630, -0.881816368689715360, -0.881839947233950090, -0.881863523573585220, -0.881887097708561220, -0.881910669638819810, -0.881934239364301490, +-0.881957806884947510, -0.881981372200699170, -0.882004935311497260, -0.882028496217283080, -0.882052054917997760, -0.882075611413582370, -0.882099165703977840, -0.882122717789125210, +-0.882146267668965980, -0.882169815343440970, -0.882193360812491440, -0.882216904076058680, -0.882240445134083510, -0.882263983986507410, -0.882287520633271090, -0.882311055074316060, +-0.882334587309583360, -0.882358117339014150, -0.882381645162549690, -0.882405170780131360, -0.882428694191699890, -0.882452215397196760, -0.882475734396563020, -0.882499251189739930, +-0.882522765776668660, -0.882546278157290480, -0.882569788331546870, -0.882593296299378550, -0.882616802060727230, -0.882640305615533640, -0.882663806963739360, -0.882687306105285450, +-0.882710803040113400, -0.882734297768164260, -0.882757790289379620, -0.882781280603700310, -0.882804768711067940, -0.882828254611423450, -0.882851738304708420, -0.882875219790863920, +-0.882898699069831430, -0.882922176141552220, -0.882945651005967780, -0.882969123663018940, -0.882992594112647520, -0.883016062354794460, -0.883039528389401140, -0.883062992216409160, +-0.883086453835759570, -0.883109913247394070, -0.883133370451253620, -0.883156825447279910, -0.883180278235414010, -0.883203728815597280, -0.883227177187771330, -0.883250623351877430, +-0.883274067307856960, -0.883297509055651520, -0.883320948595202160, -0.883344385926450480, -0.883367821049337750, -0.883391253963805470, -0.883414684669795000, -0.883438113167247850, +-0.883461539456105620, -0.883484963536309340, -0.883508385407800860, -0.883531805070521200, -0.883555222524412100, -0.883578637769414920, -0.883602050805471050, -0.883625461632522090, +-0.883648870250509750, -0.883672276659374980, -0.883695680859059700, -0.883719082849505070, -0.883742482630652690, -0.883765880202444070, -0.883789275564820900, -0.883812668717724350, +-0.883836059661096460, -0.883859448394878180, -0.883882834919011540, -0.883906219233437480, -0.883929601338097950, -0.883952981232934420, -0.883976358917888390, -0.883999734392901690, +-0.884023107657915470, -0.884046478712871790, -0.884069847557711560, -0.884093214192376740, -0.884116578616808920, -0.884139940830949600, -0.884163300834740480, -0.884186658628123290, +-0.884210014211039290, -0.884233367583430410, -0.884256718745237920, -0.884280067696403550, -0.884303414436869110, -0.884326758966576200, -0.884350101285466210, -0.884373441393481290, +-0.884396779290562600, -0.884420114976652070, -0.884443448451691090, -0.884466779715621490, -0.884490108768384960, -0.884513435609923130, -0.884536760240177910, -0.884560082659090590, +-0.884583402866603310, -0.884606720862657350, -0.884630036647194420, -0.884653350220156560, -0.884676661581485280, -0.884699970731122280, -0.884723277669009600, -0.884746582395088630, +-0.884769884909301310, -0.884793185211589010, -0.884816483301893890, -0.884839779180157440, -0.884863072846321600, -0.884886364300328300, -0.884909653542118810, -0.884932940571635520, +-0.884956225388819570, -0.884979507993613020, -0.885002788385957810, -0.885026066565795520, -0.885049342533068220, -0.885072616287717610, -0.885095887829685290, -0.885119157158913540, +-0.885142424275343620, -0.885165689178917690, -0.885188951869577470, -0.885212212347264880, -0.885235470611921870, -0.885258726663490260, -0.885281980501911650, -0.885305232127128310, +-0.885328481539081720, -0.885351728737713950, -0.885374973722966810, -0.885398216494782230, -0.885421457053102270, -0.885444695397868520, -0.885467931529023260, -0.885491165446507860, +-0.885514397150264700, -0.885537626640235390, -0.885560853916362080, -0.885584078978586710, -0.885607301826851320, -0.885630522461097410, -0.885653740881267360, -0.885676957087302870, +-0.885700171079145890, -0.885723382856738570, -0.885746592420022740, -0.885769799768940440, -0.885793004903433820, -0.885816207823444720, -0.885839408528914960, -0.885862607019786590, +-0.885885803296001750, -0.885908997357502390, -0.885932189204230450, -0.885955378836128400, -0.885978566253137640, -0.886001751455200550, -0.886024934442259050, -0.886048115214255080, +-0.886071293771130920, -0.886094470112828490, -0.886117644239289850, -0.886140816150457370, -0.886163985846272540, -0.886187153326678080, -0.886210318591615480, -0.886233481641027110, +-0.886256642474854920, -0.886279801093041280, -0.886302957495528230, -0.886326111682257610, -0.886349263653171900, -0.886372413408212930, -0.886395560947322860, -0.886418706270443830, +-0.886441849377518130, -0.886464990268487680, -0.886488128943295100, -0.886511265401881960, -0.886534399644190780, -0.886557531670163490, -0.886580661479742350, -0.886603789072869520, +-0.886626914449487270, -0.886650037609537640, -0.886673158552963250, -0.886696277279705680, -0.886719393789707540, -0.886742508082910890, -0.886765620159257860, -0.886788730018690850, +-0.886811837661151900, -0.886834943086583620, -0.886858046294927820, -0.886881147286127100, -0.886904246060123300, -0.886927342616858900, -0.886950436956276070, -0.886973529078317170, +-0.886996618982924480, -0.887019706670040490, -0.887042792139607020, -0.887065875391566670, -0.887088956425861500, -0.887112035242433980, -0.887135111841226290, -0.887158186222180900, +-0.887181258385239980, -0.887204328330346130, -0.887227396057441500, -0.887250461566468140, -0.887273524857368550, -0.887296585930085310, -0.887319644784560490, -0.887342701420736570, +-0.887365755838556150, -0.887388808037961050, -0.887411858018894220, -0.887434905781297580, -0.887457951325113630, -0.887480994650284740, -0.887504035756753410, -0.887527074644462010, +-0.887550111313353040, -0.887573145763368650, -0.887596177994451670, -0.887619208006543920, -0.887642235799588230, -0.887665261373526970, -0.887688284728302520, -0.887711305863857490, +-0.887734324780134140, -0.887757341477075080, -0.887780355954622460, -0.887803368212718990, -0.887826378251307060, -0.887849386070329260, -0.887872391669727980, -0.887895395049445810, +-0.887918396209425030, -0.887941395149608460, -0.887964391869938250, -0.887987386370357010, -0.888010378650807340, -0.888033368711231620, -0.888056356551572560, -0.888079342171772870, +-0.888102325571774490, -0.888125306751520570, -0.888148285710953170, -0.888171262450015100, -0.888194236968648850, -0.888217209266796930, -0.888240179344402250, -0.888263147201406980, +-0.888286112837753940, -0.888309076253385510, -0.888332037448244290, -0.888354996422273110, -0.888377953175414350, -0.888400907707610710, -0.888423860018805020, -0.888446810108939440, +-0.888469757977957130, -0.888492703625800130, -0.888515647052411370, -0.888538588257733570, -0.888561527241709230, -0.888584464004281150, -0.888607398545392060, -0.888630330864984440, +-0.888653260963000790, -0.888676188839384040, -0.888699114494076790, -0.888722037927021760, -0.888744959138161650, -0.888767878127439290, -0.888790794894797180, -0.888813709440178120, +-0.888836621763524630, -0.888859531864779620, -0.888882439743885810, -0.888905345400785810, -0.888928248835422540, -0.888951150047738840, -0.888974049037676960, -0.888996945805180290, +-0.889019840350190990, -0.889042732672651990, -0.889065622772506340, -0.889088510649696520, -0.889111396304165690, -0.889134279735856130, -0.889157160944711090, -0.889180039930672960, +-0.889202916693684680, -0.889225791233689170, -0.889248663550629040, -0.889271533644447440, -0.889294401515087100, -0.889317267162490600, -0.889340130586601110, -0.889362991787361110, +-0.889385850764713550, -0.889408707518601460, -0.889431562048967560, -0.889454414355754790, -0.889477264438906180, -0.889500112298364230, -0.889522957934072100, -0.889545801345972500, +-0.889568642534008360, -0.889591481498122500, -0.889614318238258090, -0.889637152754358060, -0.889659985046364900, -0.889682815114221980, -0.889705642957871800, -0.889728468577257510, +-0.889751291972322170, -0.889774113143008470, -0.889796932089259580, -0.889819748811018440, -0.889842563308227860, -0.889865375580831010, -0.889888185628770480, -0.889910993451989540, +-0.889933799050431130, -0.889956602424038180, -0.889979403572753740, -0.890002202496521070, -0.890024999195282770, -0.890047793668981790, -0.890070585917561390, -0.890093375940964490, +-0.890116163739134160, -0.890138949312013430, -0.890161732659545460, -0.890184513781673070, -0.890207292678339530, -0.890230069349487560, -0.890252843795060420, -0.890275616015001160, +-0.890298386009252930, -0.890321153777758670, -0.890343919320461750, -0.890366682637304780, -0.890389443728231370, -0.890412202593184100, -0.890434959232106360, -0.890457713644941200, +-0.890480465831631760, -0.890503215792121440, -0.890525963526352720, -0.890548709034269410, -0.890571452315814140, -0.890594193370930150, -0.890616932199560730, -0.890639668801648910, +-0.890662403177138070, -0.890685135325971270, -0.890707865248091530, -0.890730592943442260, -0.890753318411966370, -0.890776041653607130, -0.890798762668307820, -0.890821481456011590, +-0.890844198016661700, -0.890866912350201430, -0.890889624456573710, -0.890912334335722140, -0.890935041987589550, -0.890957747412119420, -0.890980450609254790, -0.891003151578939170, +-0.891025850321115700, -0.891048546835727540, -0.891071241122718180, -0.891093933182030450, -0.891116623013607940, -0.891139310617393930, -0.891161995993331570, -0.891184679141364230, +-0.891207360061435420, -0.891230038753488050, -0.891252715217465740, -0.891275389453311420, -0.891298061460968570, -0.891320731240380690, -0.891343398791490940, -0.891366064114242910, +-0.891388727208579420, -0.891411388074444420, -0.891434046711780730, -0.891456703120531820, -0.891479357300641320, -0.891502009252052360, -0.891524658974708340, -0.891547306468552850, +-0.891569951733528930, -0.891592594769580420, -0.891615235576650120, -0.891637874154681760, -0.891660510503618720, -0.891683144623404370, -0.891705776513982200, -0.891728406175295810, +-0.891751033607288130, -0.891773658809903110, -0.891796281783083790, -0.891818902526773650, -0.891841521040916410, -0.891864137325455220, -0.891886751380333910, -0.891909363205495630, +-0.891931972800884100, -0.891954580166442360, -0.891977185302114230, -0.891999788207843090, -0.892022388883572550, -0.892044987329245980, -0.892067583544807200, -0.892090177530199260, +-0.892112769285365980, -0.892135358810250630, -0.892157946104796930, -0.892180531168948350, -0.892203114002648400, -0.892225694605840670, -0.892248272978468980, -0.892270849120476490, +-0.892293423031806810, -0.892315994712403420, -0.892338564162210130, -0.892361131381170460, -0.892383696369227870, -0.892406259126326320, -0.892428819652408940, -0.892451377947419690, +-0.892473934011301710, -0.892496487843999040, -0.892519039445455080, -0.892541588815613520, -0.892564135954417970, -0.892586680861812250, -0.892609223537739640, -0.892631763982144280, +-0.892654302194969220, -0.892676838176158390, -0.892699371925655520, -0.892721903443404190, -0.892744432729348340, -0.892766959783431120, -0.892789484605596820, -0.892812007195788460, +-0.892834527553950210, -0.892857045680025550, -0.892879561573958420, -0.892902075235692210, -0.892924586665171160, -0.892947095862338340, -0.892969602827138000, -0.892992107559513530, +-0.893014610059408740, -0.893037110326767360, -0.893059608361533310, -0.893082104163650190, -0.893104597733061940, -0.893127089069712170, -0.893149578173544680, -0.893172065044503190, +-0.893194549682531540, -0.893217032087573410, -0.893239512259572770, -0.893261990198473520, -0.893284465904219170, -0.893306939376753760, -0.893329410616020780, -0.893351879621964380, +-0.893374346394528280, -0.893396810933656190, -0.893419273239292160, -0.893441733311380220, -0.893464191149863640, -0.893486646754686810, -0.893509100125793100, -0.893531551263126780, +-0.893554000166631450, -0.893576446836251260, -0.893598891271929820, -0.893621333473611390, -0.893643773441239690, -0.893666211174758310, -0.893688646674111300, -0.893711079939242810, +-0.893733510970096570, -0.893755939766616600, -0.893778366328746960, -0.893800790656431140, -0.893823212749613630, -0.893845632608237790, -0.893868050232248020, -0.893890465621588030, +-0.893912878776201850, -0.893935289696033530, -0.893957698381027120, -0.893980104831126330, -0.894002509046275430, -0.894024911026418120, -0.894047310771498460, -0.894069708281460600, +-0.894092103556248460, -0.894114496595806220, -0.894136887400077570, -0.894159275969006790, -0.894181662302537820, -0.894204046400614570, -0.894226428263181220, -0.894248807890181800, +-0.894271185281560350, -0.894293560437261160, -0.894315933357227810, -0.894338304041404910, -0.894360672489736050, -0.894383038702165400, -0.894405402678637220, -0.894427764419095550, +-0.894450123923484550, -0.894472481191748270, -0.894494836223830750, -0.894517189019676250, -0.894539539579228600, -0.894561887902432070, -0.894584233989230810, -0.894606577839568980, +-0.894628919453390960, -0.894651258830640340, -0.894673595971261840, -0.894695930875199160, -0.894718263542396700, -0.894740593972798480, -0.894762922166348900, -0.894785248122991870, +-0.894807571842672010, -0.894829893325333030, -0.894852212570919400, -0.894874529579375190, -0.894896844350644540, -0.894919156884671830, -0.894941467181401220, -0.894963775240776970, +-0.894986081062743470, -0.895008384647244750, -0.895030685994224860, -0.895052985103628300, -0.895075281975399210, -0.895097576609481970, -0.895119869005820750, -0.895142159164360130, +-0.895164447085043840, -0.895186732767816680, -0.895209016212622500, -0.895231297419405660, -0.895253576388110650, -0.895275853118681740, -0.895298127611063200, -0.895320399865199510, +-0.895342669881034610, -0.895364937658513220, -0.895387203197579360, -0.895409466498177430, -0.895431727560251910, -0.895453986383746960, -0.895476242968607280, -0.895498497314776820, +-0.895520749422200280, -0.895542999290821710, -0.895565246920585700, -0.895587492311436420, -0.895609735463318570, -0.895631976376176310, -0.895654215049954240, -0.895676451484596510, +-0.895698685680047850, -0.895720917636252280, -0.895743147353154410, -0.895765374830698620, -0.895787600068829400, -0.895809823067491240, -0.895832043826628730, -0.895854262346185810, +-0.895876478626107530, -0.895898692666337810, -0.895920904466821380, -0.895943114027502710, -0.895965321348326180, -0.895987526429236620, -0.896009729270178080, -0.896031929871095370, +-0.896054128231932530, -0.896076324352634510, -0.896098518233145680, -0.896120709873410410, -0.896142899273373540, -0.896165086432979540, -0.896187271352172580, -0.896209454030897690, +-0.896231634469099040, -0.896253812666721220, -0.896275988623708830, -0.896298162340006590, -0.896320333815558870, -0.896342503050310490, -0.896364670044205840, -0.896386834797189390, +-0.896408997309205870, -0.896431157580199760, -0.896453315610115880, -0.896475471398898600, -0.896497624946492880, -0.896519776252842850, -0.896541925317893670, -0.896564072141589400, +-0.896586216723875060, -0.896608359064695050, -0.896630499163994180, -0.896652637021717050, -0.896674772637808590, -0.896696906012212970, -0.896719037144875330, -0.896741166035739830, +-0.896763292684751410, -0.896785417091854780, -0.896807539256994630, -0.896829659180115810, -0.896851776861162690, -0.896873892300080190, -0.896896005496812920, -0.896918116451305590, +-0.896940225163502910, -0.896962331633349710, -0.896984435860790690, -0.897006537845770780, -0.897028637588234260, -0.897050735088126380, -0.897072830345391540, -0.897094923359974540, +-0.897117014131820320, -0.897139102660873490, -0.897161188947078970, -0.897183272990381590, -0.897205354790725830, -0.897227434348056960, -0.897249511662319250, -0.897271586733457750, +-0.897293659561417380, -0.897315730146142740, -0.897337798487579000, -0.897359864585670630, -0.897381928440362690, -0.897403990051599880, -0.897426049419327020, -0.897448106543488940, +-0.897470161424030800, -0.897492214060897080, -0.897514264454033040, -0.897536312603383290, -0.897558358508892760, -0.897580402170506280, -0.897602443588168760, -0.897624482761825050, +-0.897646519691420290, -0.897668554376899300, -0.897690586818206790, -0.897712617015287930, -0.897734644968087410, -0.897756670676550290, -0.897778694140621390, -0.897800715360245860, +-0.897822734335368520, -0.897844751065934530, -0.897866765551888490, -0.897888777793175660, -0.897910787789740760, -0.897932795541528830, -0.897954801048485020, -0.897976804310554160, +-0.897998805327681170, -0.898020804099811550, -0.898042800626889570, -0.898064794908860820, -0.898086786945670010, -0.898108776737262080, -0.898130764283582290, -0.898152749584575580, +-0.898174732640187210, -0.898196713450361780, -0.898218692015044670, -0.898240668334180810, -0.898262642407715140, -0.898284614235592920, -0.898306583817759190, -0.898328551154158990, +-0.898350516244737610, -0.898372479089439730, -0.898394439688210870, -0.898416398040995710, -0.898438354147739540, -0.898460308008387500, -0.898482259622884640, -0.898504208991176220, +-0.898526156113207410, -0.898548100988923240, -0.898570043618268530, -0.898591984001188780, -0.898613922137629140, -0.898635858027534650, -0.898657791670850470, -0.898679723067521970, +-0.898701652217494100, -0.898723579120712210, -0.898745503777121150, -0.898767426186666380, -0.898789346349293080, -0.898811264264946400, -0.898833179933571480, -0.898855093355113930, +-0.898877004529518350, -0.898898913456730450, -0.898920820136695160, -0.898942724569357750, -0.898964626754663600, -0.898986526692557740, -0.899008424382985890, -0.899030319825892770, +-0.899052213021223960, -0.899074103968924510, -0.899095992668939800, -0.899117879121215100, -0.899139763325695670, -0.899161645282326890, -0.899183524991054140, -0.899205402451822340, +-0.899227277664577330, -0.899249150629263800, -0.899271021345827480, -0.899292889814213630, -0.899314756034367500, -0.899336620006234600, -0.899358481729760180, -0.899380341204889520, +-0.899402198431568100, -0.899424053409740960, -0.899445906139353820, -0.899467756620351830, -0.899489604852680370, -0.899511450836285250, -0.899533294571111200, -0.899555136057104130, +-0.899576975294208990, -0.899598812282371480, -0.899620647021536990, -0.899642479511650770, -0.899664309752658430, -0.899686137744505450, -0.899707963487136890, -0.899729786980498770, +-0.899751608224535810, -0.899773427219193960, -0.899795243964418570, -0.899817058460154920, -0.899838870706348710, -0.899860680702945560, -0.899882488449890610, -0.899904293947129340, +-0.899926097194607260, -0.899947898192270060, -0.899969696940063010, -0.899991493437931720, -0.900013287685821890, -0.900035079683678680, -0.900056869431447910, -0.900078656929074850, +-0.900100442176505090, -0.900122225173684230, -0.900144005920557880, -0.900165784417071400, -0.900187560663170740, -0.900209334658800930, -0.900231106403908020, -0.900252875898437170, +-0.900274643142334070, -0.900296408135544350, -0.900318170878013690, -0.900339931369687710, -0.900361689610511770, -0.900383445600431820, -0.900405199339393000, -0.900426950827341250, +-0.900448700064222060, -0.900470447049981140, -0.900492191784564080, -0.900513934267916820, -0.900535674499984400, -0.900557412480713080, -0.900579148210048030, -0.900600881687935060, +-0.900622612914320000, -0.900644341889148330, -0.900666068612365760, -0.900687793083918220, -0.900709515303751100, -0.900731235271810320, -0.900752952988041260, -0.900774668452389850, +-0.900796381664801690, -0.900818092625222610, -0.900839801333598530, -0.900861507789874730, -0.900883211993997350, -0.900904913945911770, -0.900926613645563920, -0.900948311092899520, +-0.900970006287864280, -0.900991699230404120, -0.901013389920464870, -0.901035078357991900, -0.901056764542931490, -0.901078448475229000, -0.901100130154830370, -0.901121809581681310, +-0.901143486755727860, -0.901165161676915630, -0.901186834345190760, -0.901208504760498740, -0.901230172922785180, -0.901251838831996330, -0.901273502488077800, -0.901295163890975640, +-0.901316823040635430, -0.901338479937003450, -0.901360134580024950, -0.901381786969646440, -0.901403437105813170, -0.901425084988471400, -0.901446730617566860, -0.901468373993045470, +-0.901490015114853270, -0.901511653982936090, -0.901533290597239630, -0.901554924957710170, -0.901576557064293180, -0.901598186916934720, -0.901619814515580930, -0.901641439860177530, +-0.901663062950670780, -0.901684683787006060, -0.901706302369129960, -0.901727918696987760, -0.901749532770525940, -0.901771144589690210, -0.901792754154426610, -0.901814361464681080, +-0.901835966520399880, -0.901857569321528610, -0.901879169868013530, -0.901900768159800360, -0.901922364196835360, -0.901943957979064350, -0.901965549506433480, -0.901987138778888700, +-0.902008725796376360, -0.902030310558841970, -0.902051893066231900, -0.902073473318491970, -0.902095051315568440, -0.902116627057407250, -0.902138200543954440, -0.902159771775156270, +-0.902181340750958570, -0.902202907471307710, -0.902224471936149300, -0.902246034145429810, -0.902267594099095180, -0.902289151797091570, -0.902310707239365130, -0.902332260425862120, +-0.902353811356528260, -0.902375360031310030, -0.902396906450153140, -0.902418450613004080, -0.902439992519808890, -0.902461532170513720, -0.902483069565064630, -0.902504604703408210, +-0.902526137585490160, -0.902547668211256650, -0.902569196580653930, -0.902590722693628170, -0.902612246550125620, -0.902633768150092550, -0.902655287493475230, -0.902676804580219370, +-0.902698319410271790, -0.902719831983578190, -0.902741342300085070, -0.902762850359738580, -0.902784356162484980, -0.902805859708270430, -0.902827360997041420, -0.902848860028743870, +-0.902870356803324280, -0.902891851320728690, -0.902913343580903470, -0.902934833583794780, -0.902956321329349110, -0.902977806817512830, -0.902999290048231870, -0.903020771021452840, +-0.903042249737121660, -0.903063726195184820, -0.903085200395588710, -0.903106672338279680, -0.903128142023203910, -0.903149609450307870, -0.903171074619537720, -0.903192537530840060, +-0.903213998184160930, -0.903235456579446700, -0.903256912716643880, -0.903278366595698820, -0.903299818216557800, -0.903321267579167420, -0.903342714683473710, -0.903364159529423390, +-0.903385602116962390, -0.903407042446037530, -0.903428480516594970, -0.903449916328581290, -0.903471349881942890, -0.903492781176626010, -0.903514210212577380, -0.903535636989742930, +-0.903557061508069470, -0.903578483767503380, -0.903599903767991040, -0.903621321509478940, -0.903642736991913780, -0.903664150215241600, -0.903685561179409120, -0.903706969884362610, +-0.903728376330048650, -0.903749780516413860, -0.903771182443404490, -0.903792582110967360, -0.903813979519048630, -0.903835374667595230, -0.903856767556553090, -0.903878158185869030, +-0.903899546555489540, -0.903920932665361330, -0.903942316515430670, -0.903963698105644480, -0.903985077435948800, -0.904006454506290580, -0.904027829316616070, -0.904049201866871990, +-0.904070572157004930, -0.904091940186961480, -0.904113305956688150, -0.904134669466131750, -0.904156030715238420, -0.904177389703955230, -0.904198746432228420, -0.904220100900004710, +-0.904241453107230700, -0.904262803053853090, -0.904284150739818720, -0.904305496165073720, -0.904326839329565260, -0.904348180233239480, -0.904369518876043220, -0.904390855257923070, +-0.904412189378825950, -0.904433521238698250, -0.904454850837487000, -0.904476178175138370, -0.904497503251599500, -0.904518826066816770, -0.904540146620736900, -0.904561464913306580, +-0.904582780944472750, -0.904604094714181910, -0.904625406222380970, -0.904646715469016430, -0.904668022454035210, -0.904689327177383820, -0.904710629639009060, -0.904731929838857640, +-0.904753227776876500, -0.904774523453012570, -0.904795816867212000, -0.904817108019422060, -0.904838396909589230, -0.904859683537660440, -0.904880967903582410, -0.904902250007301960, +-0.904923529848765780, -0.904944807427921160, -0.904966082744714130, -0.904987355799092170, -0.905008626591001670, -0.905029895120389670, -0.905051161387202760, -0.905072425391388100, +-0.905093687132892400, -0.905114946611662470, -0.905136203827645260, -0.905157458780787350, -0.905178711471035790, -0.905199961898337510, -0.905221210062639340, -0.905242455963888080, +-0.905263699602030900, -0.905284940977014290, -0.905306180088785490, -0.905327416937291020, -0.905348651522478120, -0.905369883844293510, -0.905391113902684120, -0.905412341697597100, +-0.905433567228979270, -0.905454790496777460, -0.905476011500938820, -0.905497230241409930, -0.905518446718137970, -0.905539660931069970, -0.905560872880152750, -0.905582082565333460, +-0.905603289986558920, -0.905624495143776300, -0.905645698036932180, -0.905666898665973940, -0.905688097030848400, -0.905709293131502500, -0.905730486967883500, -0.905751678539938430, +-0.905772867847614020, -0.905794054890857630, -0.905815239669615860, -0.905836422183836090, -0.905857602433465140, -0.905878780418450270, -0.905899956138738420, -0.905921129594276840, +-0.905942300785012480, -0.905963469710892140, -0.905984636371863110, -0.906005800767872520, -0.906026962898867420, -0.906048122764794960, -0.906069280365602300, -0.906090435701236370, +-0.906111588771644440, -0.906132739576773430, -0.906153888116570490, -0.906175034390982900, -0.906196178399957700, -0.906217320143442030, -0.906238459621383160, -0.906259596833728140, +-0.906280731780424230, -0.906301864461418250, -0.906322994876657680, -0.906344123026089580, -0.906365248909661190, -0.906386372527319910, -0.906407493879012430, -0.906428612964686460, +-0.906449729784288840, -0.906470844337766810, -0.906491956625067650, -0.906513066646138620, -0.906534174400926870, -0.906555279889380010, -0.906576383111444620, -0.906597484067068530, +-0.906618582756198550, -0.906639679178782080, -0.906660773334766470, -0.906681865224098880, -0.906702954846726580, -0.906724042202597170, -0.906745127291657460, -0.906766210113855050, +-0.906787290669136990, -0.906808368957450760, -0.906829444978743520, -0.906850518732962630, -0.906871590220055700, -0.906892659439969550, -0.906913726392652000, -0.906934791078049970, +-0.906955853496110850, -0.906976913646782230, -0.906997971530011270, -0.907019027145745340, -0.907040080493932030, -0.907061131574518400, -0.907082180387452140, -0.907103226932680200, +-0.907124271210150160, -0.907145313219809510, -0.907166352961605530, -0.907187390435485690, -0.907208425641397480, -0.907229458579288270, -0.907250489249105230, -0.907271517650796060, +-0.907292543784308010, -0.907313567649588590, -0.907334589246585280, -0.907355608575245550, -0.907376625635516800, -0.907397640427346610, -0.907418652950682140, -0.907439663205470980, +-0.907460671191660740, -0.907481676909198790, -0.907502680358032610, -0.907523681538109920, -0.907544680449377860, -0.907565677091784260, -0.907586671465276380, -0.907607663569801710, +-0.907628653405307960, -0.907649640971742610, -0.907670626269053260, -0.907691609297187170, -0.907712590056092280, -0.907733568545715630, -0.907754544766005140, -0.907775518716908310, +-0.907796490398372620, -0.907817459810345780, -0.907838426952775390, -0.907859391825608820, -0.907880354428793890, -0.907901314762277980, -0.907922272826008680, -0.907943228619933820, +-0.907964182144000760, -0.907985133398157340, -0.908006082382351250, -0.908027029096529770, -0.908047973540640820, -0.908068915714631890, -0.908089855618450570, -0.908110793252044580, +-0.908131728615361730, -0.908152661708349630, -0.908173592530955750, -0.908194521083128150, -0.908215447364813970, -0.908236371375961140, -0.908257293116517480, -0.908278212586430490, +-0.908299129785647970, -0.908320044714117870, -0.908340957371787440, -0.908361867758604840, -0.908382775874517430, -0.908403681719472940, -0.908424585293419410, -0.908445486596304310, +-0.908466385628075470, -0.908487282388680930, -0.908508176878068170, -0.908529069096184690, -0.908549959042978640, -0.908570846718397610, -0.908591732122389530, -0.908612615254902110, +-0.908633496115883400, -0.908654374705280650, -0.908675251023042250, -0.908696125069115460, -0.908716996843448420, -0.908737866345988850, -0.908758733576684570, -0.908779598535483510, +-0.908800461222333600, -0.908821321637182430, -0.908842179779978050, -0.908863035650668060, -0.908883889249200600, -0.908904740575523280, -0.908925589629584140, -0.908946436411331220, +-0.908967280920712000, -0.908988123157674850, -0.909008963122167170, -0.909029800814136980, -0.909050636233532440, -0.909071469380301140, -0.909092300254391360, -0.909113128855750910, +-0.909133955184327490, -0.909154779240069270, -0.909175601022924050, -0.909196420532839780, -0.909217237769764370, -0.909238052733646000, -0.909258865424432350, -0.909279675842071810, +-0.909300483986511980, -0.909321289857700890, -0.909342093455586700, -0.909362894780117110, -0.909383693831240400, -0.909404490608904270, -0.909425285113057090, -0.909446077343646580, +-0.909466867300621100, -0.909487654983928140, -0.909508440393516300, -0.909529223529333190, -0.909550004391327160, -0.909570782979446050, -0.909591559293638000, -0.909612333333850940, +-0.909633105100033260, -0.909653874592132650, -0.909674641810097380, -0.909695406753875500, -0.909716169423415270, -0.909736929818664500, -0.909757687939571350, -0.909778443786084080, +-0.909799197358150510, -0.909819948655719140, -0.909840697678737760, -0.909861444427154780, -0.909882188900918100, -0.909902931099976000, -0.909923671024276510, -0.909944408673767910, +-0.909965144048398230, -0.909985877148115740, -0.910006607972868480, -0.910027336522604810, -0.910048062797272680, -0.910068786796820460, -0.910089508521196300, -0.910110227970348350, +-0.910130945144224770, -0.910151660042773920, -0.910172372665943970, -0.910193083013682850, -0.910213791085939250, -0.910234496882661000, -0.910255200403796700, -0.910275901649294280, +-0.910296600619102110, -0.910317297313168460, -0.910337991731441590, -0.910358683873869650, -0.910379373740401120, -0.910400061330984060, -0.910420746645566940, -0.910441429684097800, +-0.910462110446525250, -0.910482788932797330, -0.910503465142862510, -0.910524139076668960, -0.910544810734165160, -0.910565480115299140, -0.910586147220019630, -0.910606812048274760, +-0.910627474600012700, -0.910648134875182040, -0.910668792873730930, -0.910689448595608080, -0.910710102040761300, -0.910730753209139540, -0.910751402100690720, -0.910772048715363550, +-0.910792693053106060, -0.910813335113866970, -0.910833974897594540, -0.910854612404237150, -0.910875247633743170, -0.910895880586061190, -0.910916511261139370, -0.910937139658926420, +-0.910957765779370490, -0.910978389622420280, -0.910999011188024070, -0.911019630476130220, -0.911040247486687440, -0.911060862219643890, -0.911081474674948380, -0.911102084852548950, +-0.911122692752394550, -0.911143298374433200, -0.911163901718613720, -0.911184502784884390, -0.911205101573194010, -0.911225698083490630, -0.911246292315723180, -0.911266884269839930, +-0.911287473945789460, -0.911308061343520270, -0.911328646462981060, -0.911349229304120100, -0.911369809866886200, -0.911390388151227640, -0.911410964157093220, -0.911431537884431320, +-0.911452109333190540, -0.911472678503319590, -0.911493245394766840, -0.911513810007481110, -0.911534372341410770, -0.911554932396504540, -0.911575490172710890, -0.911596045669978540, +-0.911616598888256080, -0.911637149827492220, -0.911657698487635340, -0.911678244868634360, -0.911698788970437660, -0.911719330792994050, -0.911739870336252030, -0.911760407600160530, +-0.911780942584667800, -0.911801475289722770, -0.911822005715274160, -0.911842533861270450, -0.911863059727660460, -0.911883583314392680, -0.911904104621416020, -0.911924623648679100, +-0.911945140396130730, -0.911965654863719280, -0.911986167051393900, -0.912006676959102980, -0.912027184586795440, -0.912047689934419870, -0.912068193001925210, -0.912088693789259830, +-0.912109192296372990, -0.912129688523212970, -0.912150182469728790, -0.912170674135869160, -0.912191163521582920, -0.912211650626818640, -0.912232135451525370, -0.912252617995651720, +-0.912273098259146380, -0.912293576241958500, -0.912314051944036470, -0.912334525365329550, -0.912354996505786110, -0.912375465365355300, -0.912395931943985720, -0.912416396241626520, +-0.912436858258226070, -0.912457317993733640, -0.912477775448097830, -0.912498230621267670, -0.912518683513191880, -0.912539134123819370, -0.912559582453099090, -0.912580028500979750, +-0.912600472267410370, -0.912620913752339890, -0.912641352955717020, -0.912661789877490910, -0.912682224517610270, -0.912702656876024030, -0.912723086952681120, -0.912743514747530570, +-0.912763940260521210, -0.912784363491601860, -0.912804784440721770, -0.912825203107829660, -0.912845619492874570, -0.912866033595805430, -0.912886445416571270, -0.912906854955120810, +-0.912927262211403410, -0.912947667185367680, -0.912968069876962880, -0.912988470286137940, -0.913008868412841790, -0.913029264257023470, -0.913049657818632010, -0.913070049097616350, +-0.913090438093925540, -0.913110824807508830, -0.913131209238314810, -0.913151591386292870, -0.913171971251391930, -0.913192348833561150, -0.913212724132749450, -0.913233097148905880, +-0.913253467881979590, -0.913273836331919720, -0.913294202498675210, -0.913314566382195210, -0.913334927982428660, -0.913355287299324910, -0.913375644332832910, -0.913395999082901920, +-0.913416351549480750, -0.913436701732518790, -0.913457049631965060, -0.913477395247768720, -0.913497738579878930, -0.913518079628244720, -0.913538418392815350, -0.913558754873539990, +-0.913579089070367670, -0.913599420983247650, -0.913619750612129080, -0.913640077956961010, -0.913660403017692910, -0.913680725794273730, -0.913701046286652830, -0.913721364494779140, +-0.913741680418602260, -0.913761994058071010, -0.913782305413134770, -0.913802614483742780, -0.913822921269844430, -0.913843225771388550, -0.913863527988324710, -0.913883827920602080, +-0.913904125568169800, -0.913924420930977250, -0.913944714008973700, -0.913965004802108290, -0.913985293310330400, -0.914005579533589300, -0.914025863471834120, -0.914046145125014480, +-0.914066424493079290, -0.914086701575978160, -0.914106976373660230, -0.914127248886074880, -0.914147519113171380, -0.914167787054899090, -0.914188052711207400, -0.914208316082045560, +-0.914228577167362830, -0.914248835967108710, -0.914269092481232450, -0.914289346709683650, -0.914309598652411350, -0.914329848309365030, -0.914350095680494190, -0.914370340765747970, +-0.914390583565075970, -0.914410824078427440, -0.914431062305752000, -0.914451298246998780, -0.914471531902117380, -0.914491763271057080, -0.914511992353767460, -0.914532219150197780, +-0.914552443660297640, -0.914572665884016310, -0.914592885821303380, -0.914613103472108220, -0.914633318836380330, -0.914653531914069060, -0.914673742705124030, -0.914693951209494700, +-0.914714157427130360, -0.914734361357980700, -0.914754563001995090, -0.914774762359123140, -0.914794959429314210, -0.914815154212517910, -0.914835346708683720, -0.914855536917761230, +-0.914875724839699700, -0.914895910474449070, -0.914916093821958600, -0.914936274882177880, -0.914956453655056400, -0.914976630140543980, -0.914996804338589760, -0.915016976249143690, +-0.915037145872155120, -0.915057313207573770, -0.915077478255349020, -0.915097641015430670, -0.915117801487768220, -0.915137959672311150, -0.915158115569009280, -0.915178269177812090, +-0.915198420498669170, -0.915218569531530250, -0.915238716276345010, -0.915258860733062840, -0.915279002901633550, -0.915299142782006750, -0.915319280374132130, -0.915339415677959290, +-0.915359548693437940, -0.915379679420517570, -0.915399807859148210, -0.915419934009279230, -0.915440057870860470, -0.915460179443841390, -0.915480298728172050, -0.915500415723801920, +-0.915520530430680710, -0.915540642848758250, -0.915560752977984120, -0.915580860818308140, -0.915600966369680020, -0.915621069632049480, -0.915641170605366210, -0.915661269289580030, +-0.915681365684640650, -0.915701459790498000, -0.915721551607101560, -0.915741641134401260, -0.915761728372346820, -0.915781813320888150, -0.915801895979974970, -0.915821976349556980, +-0.915842054429584000, -0.915862130220006070, -0.915882203720772560, -0.915902274931833740, -0.915922343853139200, -0.915942410484638760, -0.915962474826282350, -0.915982536878019670, +-0.916002596639800770, -0.916022654111575240, -0.916042709293293120, -0.916062762184904230, -0.916082812786358500, -0.916102861097605640, -0.916122907118595680, -0.916142950849278440, +-0.916162992289603850, -0.916183031439521730, -0.916203068298982130, -0.916223102867934740, -0.916243135146329600, -0.916263165134116650, -0.916283192831245820, -0.916303218237666920, +-0.916323241353330100, -0.916343262178185180, -0.916363280712181980, -0.916383296955270770, -0.916403310907401130, -0.916423322568523320, -0.916443331938587070, -0.916463339017542620, +-0.916483343805339800, -0.916503346301928650, -0.916523346507258970, -0.916543344421281160, -0.916563340043944800, -0.916583333375200260, -0.916603324414997140, -0.916623313163285940, +-0.916643299620016340, -0.916663283785138620, -0.916683265658602480, -0.916703245240358400, -0.916723222530356100, -0.916743197528545720, -0.916763170234877410, -0.916783140649301110, +-0.916803108771767070, -0.916823074602225120, -0.916843038140625620, -0.916862999386918290, -0.916882958341053710, -0.916902915002981600, -0.916922869372652330, -0.916942821450015710, +-0.916962771235022120, -0.916982718727621600, -0.917002663927764420, -0.917022606835400380, -0.917042547450479970, -0.917062485772953020, -0.917082421802770000, -0.917102355539880840, +-0.917122286984235920, -0.917142216135785170, -0.917162142994478960, -0.917182067560267320, -0.917201989833100530, -0.917221909812928730, -0.917241827499702180, -0.917261742893371150, +-0.917281655993885670, -0.917301566801196120, -0.917321475315252540, -0.917341381536005310, -0.917361285463404670, -0.917381187097400800, -0.917401086437943940, -0.917420983484984460, +-0.917440878238472310, -0.917460770698358190, -0.917480660864592010, -0.917500548737124280, -0.917520434315905130, -0.917540317600884950, -0.917560198592013880, -0.917580077289242290, +-0.917599953692520680, -0.917619827801798960, -0.917639699617027850, -0.917659569138157380, -0.917679436365138050, -0.917699301297920100, -0.917719163936453920, -0.917739024280689760, +-0.917758882330578230, -0.917778738086069250, -0.917798591547113630, -0.917818442713661420, -0.917838291585663100, -0.917858138163069050, -0.917877982445829740, -0.917897824433895340, +-0.917917664127216540, -0.917937501525743490, -0.917957336629426690, -0.917977169438216610, -0.917996999952063520, -0.918016828170918010, -0.918036654094730230, -0.918056477723451000, +-0.918076299057030590, -0.918096118095419360, -0.918115934838567790, -0.918135749286426490, -0.918155561438945830, -0.918175371296076180, -0.918195178857768140, -0.918214984123972180, +-0.918234787094638680, -0.918254587769718360, -0.918274386149161350, -0.918294182232918590, -0.918313976020940230, -0.918333767513177080, -0.918353556709579410, -0.918373343610097810, +-0.918393128214682890, -0.918412910523285220, -0.918432690535855190, -0.918452468252343390, -0.918472243672700530, -0.918492016796876980, -0.918511787624823440, -0.918531556156490400, +-0.918551322391828570, -0.918571086330788320, -0.918590847973320360, -0.918610607319375270, -0.918630364368903770, -0.918650119121856230, -0.918669871578183470, -0.918689621737835970, +-0.918709369600764550, -0.918729115166919690, -0.918748858436251870, -0.918768599408712030, -0.918788338084250640, -0.918808074462818420, -0.918827808544366080, -0.918847540328844190, +-0.918867269816203370, -0.918886997006394420, -0.918906721899367950, -0.918926444495074770, -0.918946164793465360, -0.918965882794490650, -0.918985598498101130, -0.919005311904247720, +-0.919025023012880920, -0.919044731823951740, -0.919064438337410470, -0.919084142553208360, -0.919103844471295670, -0.919123544091623560, -0.919143241414142500, -0.919162936438803310, +-0.919182629165556930, -0.919202319594353830, -0.919222007725144950, -0.919241693557880990, -0.919261377092512990, -0.919281058328991320, -0.919300737267267240, -0.919320413907291130, +-0.919340088249014030, -0.919359760292386750, -0.919379430037360110, -0.919399097483884710, -0.919418762631911800, -0.919438425481391760, -0.919458086032275860, -0.919477744284514560, +-0.919497400238059150, -0.919517053892860090, -0.919536705248868320, -0.919556354306034880, -0.919576001064310480, -0.919595645523646250, -0.919615287683992700, -0.919634927545301070, +-0.919654565107521970, -0.919674200370606650, -0.919693833334505720, -0.919713463999170200, -0.919733092364551030, -0.919752718430599250, -0.919772342197265450, -0.919791963664501000, +-0.919811582832256500, -0.919831199700483100, -0.919850814269131730, -0.919870426538153320, -0.919890036507498790, -0.919909644177119180, -0.919929249546965530, -0.919948852616988670, +-0.919968453387139840, -0.919988051857369650, -0.920007648027629470, -0.920027241897870110, -0.920046833468042720, -0.920066422738098130, -0.920086009707987600, -0.920105594377661930, +-0.920125176747072390, -0.920144756816169810, -0.920164334584905430, -0.920183910053230190, -0.920203483221095130, -0.920223054088451400, -0.920242622655250030, -0.920262188921442070, +-0.920281752886978670, -0.920301314551810970, -0.920320873915889790, -0.920340430979166620, -0.920359985741592280, -0.920379538203118020, -0.920399088363694770, -0.920418636223274020, +-0.920438181781806470, -0.920457725039243610, -0.920477265995536360, -0.920496804650635990, -0.920516341004493530, -0.920535875057060360, -0.920555406808287400, -0.920574936258126030, +-0.920594463406527170, -0.920613988253442320, -0.920633510798822270, -0.920653031042618640, -0.920672548984782350, -0.920692064625264760, -0.920711577964016930, -0.920731089000990210, +-0.920750597736135770, -0.920770104169404750, -0.920789608300748520, -0.920809110130118240, -0.920828609657465270, -0.920848106882740660, -0.920867601805895890, -0.920887094426882100, +-0.920906584745650570, -0.920926072762152550, -0.920945558476339410, -0.920965041888162190, -0.920984522997572610, -0.921004001804521580, -0.921023478308960590, -0.921042952510840780, +-0.921062424410113770, -0.921081894006730570, -0.921101361300642800, -0.921120826291801590, -0.921140288980158100, -0.921159749365664140, -0.921179207448270640, -0.921198663227929200, +-0.921218116704591080, -0.921237567878207760, -0.921257016748730400, -0.921276463316110570, -0.921295907580299440, -0.921315349541248720, -0.921334789198909540, -0.921354226553233400, +-0.921373661604171670, -0.921393094351675820, -0.921412524795697240, -0.921431952936187290, -0.921451378773097460, -0.921470802306379340, -0.921490223535984090, -0.921509642461863290, +-0.921529059083968430, -0.921548473402250880, -0.921567885416662120, -0.921587295127153650, -0.921606702533677050, -0.921626107636183580, -0.921645510434624840, -0.921664910928952310, +-0.921684309119117580, -0.921703705005072040, -0.921723098586767260, -0.921742489864154750, -0.921761878837185970, -0.921781265505812520, -0.921800649869985890, -0.921820031929657670, +-0.921839411684779340, -0.921858789135302390, -0.921878164281178640, -0.921897537122359450, -0.921916907658796300, -0.921936275890441030, -0.921955641817244990, -0.921975005439159780, +-0.921994366756137110, -0.922013725768128570, -0.922033082475085640, -0.922052436876960150, -0.922071788973703340, -0.922091138765267270, -0.922110486251603190, -0.922129831432663030, +-0.922149174308398270, -0.922168514878760500, -0.922187853143701440, -0.922207189103172900, -0.922226522757126240, -0.922245854105513300, -0.922265183148285760, -0.922284509885395230, +-0.922303834316793520, -0.922323156442432010, -0.922342476262262840, -0.922361793776237280, -0.922381108984307360, -0.922400421886424680, -0.922419732482540940, -0.922439040772607740, +-0.922458346756577120, -0.922477650434400550, -0.922496951806029860, -0.922516250871416750, -0.922535547630513040, -0.922554842083270430, -0.922574134229640850, -0.922593424069575780, +-0.922612711603027270, -0.922631996829946900, -0.922651279750286600, -0.922670560363998080, -0.922689838671033050, -0.922709114671343640, -0.922728388364881250, -0.922747659751598000, +-0.922766928831445510, -0.922786195604375800, -0.922805460070340480, -0.922824722229291570, -0.922843982081180900, -0.922863239625960290, -0.922882494863581430, -0.922901747793996470, +-0.922920998417157130, -0.922940246733015220, -0.922959492741522780, -0.922978736442631620, -0.922997977836293450, -0.923017216922460530, -0.923036453701084560, -0.923055688172117360, +-0.923074920335510970, -0.923094150191217210, -0.923113377739188220, -0.923132602979375720, -0.923151825911731730, -0.923171046536208070, -0.923190264852756900, -0.923209480861330030, +-0.923228694561879500, -0.923247905954357240, -0.923267115038715170, -0.923286321814905330, -0.923305526282879650, -0.923324728442590170, -0.923343928293988920, -0.923363125837027840, +-0.923382321071658960, -0.923401513997834100, -0.923420704615505630, -0.923439892924625470, -0.923459078925145450, -0.923478262617017710, -0.923497444000194400, -0.923516623074627450, +-0.923535799840268900, -0.923554974297070900, -0.923574146444985370, -0.923593316283964680, -0.923612483813960440, -0.923631649034925230, -0.923650811946810760, -0.923669972549569280, +-0.923689130843152850, -0.923708286827513710, -0.923727440502603690, -0.923746591868375160, -0.923765740924780140, -0.923784887671770800, -0.923804032109299180, -0.923823174237317520, +-0.923842314055777880, -0.923861451564632510, -0.923880586763833560, -0.923899719653332950, -0.923918850233083290, -0.923937978503036270, -0.923957104463144500, -0.923976228113359780, +-0.923995349453634710, -0.924014468483921100, -0.924033585204171340, -0.924052699614337670, -0.924071811714372250, -0.924090921504227230, -0.924110028983854970, -0.924129134153207630, +-0.924148237012237470, -0.924167337560896640, -0.924186435799137620, -0.924205531726912440, -0.924224625344173270, -0.924243716650872790, -0.924262805646962840, -0.924281892332395990, +-0.924300976707124300, -0.924320058771100240, -0.924339138524275960, -0.924358215966603950, -0.924377291098036350, -0.924396363918525530, -0.924415434428023760, -0.924434502626483410, +-0.924453568513856850, -0.924472632090096340, -0.924491693355154240, -0.924510752308982940, -0.924529808951534690, -0.924548863282762090, -0.924567915302617060, -0.924586965011052530, +-0.924606012408020430, -0.924625057493473350, -0.924644100267363540, -0.924663140729643510, -0.924682178880265710, -0.924701214719182430, -0.924720248246346130, -0.924739279461709080, +-0.924758308365223990, -0.924777334956843000, -0.924796359236518820, -0.924815381204203590, -0.924834400859850030, -0.924853418203410380, -0.924872433234837250, -0.924891445954083010, +-0.924910456361100140, -0.924929464455841120, -0.924948470238258440, -0.924967473708304680, -0.924986474865932110, -0.925005473711093540, -0.925024470243741010, -0.925043464463827570, +-0.925062456371305240, -0.925081445966126960, -0.925100433248244980, -0.925119418217611900, -0.925138400874180310, -0.925157381217902700, -0.925176359248731650, -0.925195334966619650, +-0.925214308371519300, -0.925233279463383300, -0.925252248242164010, -0.925271214707814150, -0.925290178860286190, -0.925309140699532850, -0.925328100225506600, -0.925347057438160260, +-0.925366012337446090, -0.925384964923317010, -0.925403915195725400, -0.925422863154624080, -0.925441808799965630, -0.925460752131702540, -0.925479693149787730, -0.925498631854173470, +-0.925517568244812790, -0.925536502321658180, -0.925555434084662340, -0.925574363533777870, -0.925593290668957460, -0.925612215490153820, -0.925631137997319780, -0.925650058190407690, +-0.925668976069370600, -0.925687891634160990, -0.925706804884731780, -0.925725715821035360, -0.925744624443024850, -0.925763530750652760, -0.925782434743871670, -0.925801336422634620, +-0.925820235786894210, -0.925839132836603240, -0.925858027571714310, -0.925876919992180470, -0.925895810097954190, -0.925914697888988500, -0.925933583365236010, -0.925952466526649640, +-0.925971347373181990, -0.925990225904786080, -0.926009102121414520, -0.926027976023020230, -0.926046847609556020, -0.926065716880974720, -0.926084583837229030, -0.926103448478271970, +-0.926122310804056270, -0.926141170814534730, -0.926160028509660390, -0.926178883889385850, -0.926197736953664250, -0.926216587702448080, -0.926235436135690700, -0.926254282253344500, +-0.926273126055362720, -0.926291967541698070, -0.926310806712303590, -0.926329643567131990, -0.926348478106136410, -0.926367310329269440, -0.926386140236484360, -0.926404967827733850, +-0.926423793102971070, -0.926442616062148620, -0.926461436705219740, -0.926480255032137160, -0.926499071042854120, -0.926517884737323330, -0.926536696115497720, -0.926555505177330430, +-0.926574311922774400, -0.926593116351782650, -0.926611918464307900, -0.926630718260303630, -0.926649515739722320, -0.926668310902517440, -0.926687103748641610, -0.926705894278048060, +-0.926724682490689840, -0.926743468386519890, -0.926762251965491220, -0.926781033227557010, -0.926799812172670050, -0.926818588800783720, -0.926837363111850830, -0.926856135105824650, +-0.926874904782658100, -0.926893672142304230, -0.926912437184716160, -0.926931199909846960, -0.926949960317649870, -0.926968718408077820, -0.926987474181084070, -0.927006227636621550, +-0.927024978774643520, -0.927043727595102900, -0.927062474097953060, -0.927081218283147050, -0.927099960150638000, -0.927118699700378970, -0.927137436932323310, -0.927156171846423960, +-0.927174904442634280, -0.927193634720907210, -0.927212362681196110, -0.927231088323454130, -0.927249811647634430, -0.927268532653690250, -0.927287251341574640, -0.927305967711240960, +-0.927324681762642270, -0.927343393495732030, -0.927362102910463170, -0.927380810006789180, -0.927399514784662980, -0.927418217244038170, -0.927436917384867780, -0.927455615207105070, +-0.927474310710703300, -0.927493003895615730, -0.927511694761795740, -0.927530383309196460, -0.927549069537771160, -0.927567753447473330, -0.927586435038256000, -0.927605114310072640, +-0.927623791262876530, -0.927642465896620920, -0.927661138211259060, -0.927679808206744450, -0.927698475883030340, -0.927717141240069880, -0.927735804277816770, -0.927754464996223940, +-0.927773123395245090, -0.927791779474833380, -0.927810433234942280, -0.927829084675525050, -0.927847733796535180, -0.927866380597925810, -0.927885025079650650, -0.927903667241662840, +-0.927922307083915990, -0.927940944606363230, -0.927959579808958160, -0.927978212691654150, -0.927996843254404570, -0.928015471497163010, -0.928034097419882630, -0.928052721022517010, +-0.928071342305019640, -0.928089961267343890, -0.928108577909443230, -0.928127192231271160, -0.928145804232781040, -0.928164413913926570, -0.928183021274660900, -0.928201626314937740, +-0.928220229034710460, -0.928238829433932770, -0.928257427512557800, -0.928276023270539370, -0.928294616707830870, -0.928313207824385870, -0.928331796620157750, -0.928350383095100320, +-0.928368967249166730, -0.928387549082310800, -0.928406128594486120, -0.928424705785645950, -0.928443280655744110, -0.928461853204733960, -0.928480423432569310, -0.928498991339203440, +-0.928517556924590260, -0.928536120188683030, -0.928554681131435690, -0.928573239752801480, -0.928591796052734230, -0.928610350031187530, -0.928628901688114850, -0.928647451023470020, +-0.928665998037206510, -0.928684542729278030, -0.928703085099638170, -0.928721625148240640, -0.928740162875039020, -0.928758698279987030, -0.928777231363038250, -0.928795762124146500, +-0.928814290563265140, -0.928832816680348230, -0.928851340475349120, -0.928869861948221850, -0.928888381098919800, -0.928906897927396780, -0.928925412433606600, -0.928943924617502860, +-0.928962434479039260, -0.928980942018169610, -0.928999447234847620, -0.929017950129026990, -0.929036450700661430, -0.929054948949704860, -0.929073444876110880, -0.929091938479833290, +-0.929110429760825810, -0.929128918719042350, -0.929147405354436520, -0.929165889666962120, -0.929184371656573190, -0.929202851323223110, -0.929221328666866020, -0.929239803687455620, +-0.929258276384945630, -0.929276746759289950, -0.929295214810442530, -0.929313680538356950, -0.929332143942987240, -0.929350605024287120, -0.929369063782210510, -0.929387520216711230, +-0.929405974327743190, -0.929424426115260100, -0.929442875579216120, -0.929461322719564830, -0.929479767536260270, -0.929498210029256370, -0.929516650198506820, -0.929535088043965670, +-0.929553523565586850, -0.929571956763324270, -0.929590387637131640, -0.929608816186963120, -0.929627242412772500, -0.929645666314513950, -0.929664087892141060, -0.929682507145608070, +-0.929700924074868710, -0.929719338679877110, -0.929737750960587080, -0.929756160916952790, -0.929774568548928040, -0.929792973856466860, -0.929811376839523200, -0.929829777498051180, +-0.929848175832004630, -0.929866571841337810, -0.929884965526004410, -0.929903356885958600, -0.929921745921154510, -0.929940132631545960, -0.929958517017087090, -0.929976899077731960, +-0.929995278813434580, -0.930013656224148890, -0.930032031309829250, -0.930050404070429380, -0.930068774505903640, -0.930087142616205840, -0.930105508401290250, -0.930123871861110780, +-0.930142232995621710, -0.930160591804777060, -0.930178948288530980, -0.930197302446837400, -0.930215654279650690, -0.930234003786924890, -0.930252350968613920, -0.930270695824672260, +-0.930289038355053720, -0.930307378559712570, -0.930325716438602960, -0.930344051991679240, -0.930362385218895140, -0.930380716120205340, -0.930399044695563560, -0.930417370944924270, +-0.930435694868241400, -0.930454016465469440, -0.930472335736562410, -0.930490652681474570, -0.930508967300159970, -0.930527279592573090, -0.930545589558667950, -0.930563897198398830, +-0.930582202511719970, -0.930600505498585640, -0.930618806158950100, -0.930637104492767490, -0.930655400499992070, -0.930673694180578100, -0.930691985534480070, -0.930710274561651900, +-0.930728561262048170, -0.930746845635622930, -0.930765127682330770, -0.930783407402125620, -0.930801684794961950, -0.930819959860794130, -0.930838232599576430, -0.930856503011263100, +-0.930874771095808520, -0.930893036853166930, -0.930911300283292940, -0.930929561386140580, -0.930947820161664330, -0.930966076609818450, -0.930984330730557530, -0.931002582523835720, +-0.931020831989607500, -0.931039079127827130, -0.931057323938449090, -0.931075566421427750, -0.931093806576717480, -0.931112044404272640, -0.931130279904047730, -0.931148513075997220, +-0.931166743920075260, -0.931184972436236550, -0.931203198624435350, -0.931221422484626250, -0.931239644016763510, -0.931257863220801730, -0.931276080096695160, -0.931294294644398500, +-0.931312506863866020, -0.931330716755052410, -0.931348924317911940, -0.931367129552399090, -0.931385332458468550, -0.931403533036074590, -0.931421731285171810, -0.931439927205714670, +-0.931458120797657770, -0.931476312060955490, -0.931494500995562520, -0.931512687601433240, -0.931530871878522350, -0.931549053826784100, -0.931567233446173320, -0.931585410736644470, +-0.931603585698152050, -0.931621758330650640, -0.931639928634094950, -0.931658096608439350, -0.931676262253638530, -0.931694425569646990, -0.931712586556419530, -0.931730745213910530, +-0.931748901542074680, -0.931767055540866580, -0.931785207210240830, -0.931803356550152010, -0.931821503560554820, -0.931839648241403970, -0.931857790592653830, -0.931875930614259330, +-0.931894068306174940, -0.931912203668355480, -0.931930336700755420, -0.931948467403329590, -0.931966595776032580, -0.931984721818819080, -0.932002845531643700, -0.932020966914461240, +-0.932039085967226400, -0.932057202689893890, -0.932075317082418310, -0.932093429144754350, -0.932111538876856940, -0.932129646278680670, -0.932147751350180240, -0.932165854091310480, +-0.932183954502026070, -0.932202052582281730, -0.932220148332032370, -0.932238241751232490, -0.932256332839837110, -0.932274421597800830, -0.932292508025078570, -0.932310592121624930, +-0.932328673887394930, -0.932346753322343180, -0.932364830426424600, -0.932382905199593880, -0.932400977641805960, -0.932419047753015540, -0.932437115533177540, -0.932455180982246780, +-0.932473244100178070, -0.932491304886926220, -0.932509363342446050, -0.932527419466692600, -0.932545473259620450, -0.932563524721184640, -0.932581573851340110, -0.932599620650041650, +-0.932617665117243980, -0.932635707252902350, -0.932653747056971350, -0.932671784529406020, -0.932689819670161180, -0.932707852479191860, -0.932725882956452760, -0.932743911101899140, +-0.932761936915485590, -0.932779960397167260, -0.932797981546899080, -0.932816000364635860, -0.932834016850332740, -0.932852031003944540, -0.932870042825426180, -0.932888052314732820, +-0.932906059471819260, -0.932924064296640540, -0.932942066789151810, -0.932960066949307780, -0.932978064777063580, -0.932996060272374250, -0.933014053435194720, -0.933032044265480140, +-0.933050032763185430, -0.933068018928265520, -0.933086002760675770, -0.933103984260370890, -0.933121963427306020, -0.933139940261436320, -0.933157914762716700, -0.933175886931102430, +-0.933193856766548310, -0.933211824269009620, -0.933229789438441260, -0.933247752274798500, -0.933265712778036380, -0.933283670948109930, -0.933301626784974300, -0.933319580288584750, +-0.933337531458896090, -0.933355480295863680, -0.933373426799442460, -0.933391370969587800, -0.933409312806254610, -0.933427252309398270, -0.933445189478973700, -0.933463124314936170, +-0.933481056817240810, -0.933498986985842880, -0.933516914820697430, -0.933534840321759710, -0.933552763488984860, -0.933570684322328150, -0.933588602821744720, -0.933606518987189720, +-0.933624432818618510, -0.933642344315986140, -0.933660253479247970, -0.933678160308359150, -0.933696064803274940, -0.933713966963950480, -0.933731866790341260, -0.933749764282402190, +-0.933767659440088880, -0.933785552263356360, -0.933803442752159980, -0.933821330906454920, -0.933839216726196630, -0.933857100211340160, -0.933874981361841110, -0.933892860177654490, +-0.933910736658735700, -0.933928610805040190, -0.933946482616523020, -0.933964352093139770, -0.933982219234845590, -0.934000084041595850, -0.934017946513345910, -0.934035806650051040, +-0.934053664451666710, -0.934071519918148300, -0.934089373049450940, -0.934107223845530240, -0.934125072306341450, -0.934142918431840050, -0.934160762221981190, -0.934178603676720560, +-0.934196442796013330, -0.934214279579815180, -0.934232114028081150, -0.934249946140766950, -0.934267775917827840, -0.934285603359219170, -0.934303428464896670, -0.934321251234815460, +-0.934339071668931260, -0.934356889767199330, -0.934374705529575130, -0.934392518956014160, -0.934410330046472000, -0.934428138800903920, -0.934445945219265490, -0.934463749301512210, +-0.934481551047599560, -0.934499350457483000, -0.934517147531118250, -0.934534942268460340, -0.934552734669465310, -0.934570524734088300, -0.934588312462285130, -0.934606097854011050, +-0.934623880909221770, -0.934641661627872770, -0.934659440009919630, -0.934677216055317950, -0.934694989764023100, -0.934712761135990890, -0.934730530171176690, -0.934748296869536200, +-0.934766061231025010, -0.934783823255598610, -0.934801582943212690, -0.934819340293822850, -0.934837095307384570, -0.934854847983853540, -0.934872598323185480, -0.934890346325335850, +-0.934908091990260370, -0.934925835317914730, -0.934943576308254420, -0.934961314961235250, -0.934979051276812800, -0.934996785254942560, -0.935014516895580570, -0.935032246198682080, +-0.935049973164203130, -0.935067697792099200, -0.935085420082325980, -0.935103140034839300, -0.935120857649594740, -0.935138572926548010, -0.935156285865654800, -0.935173996466870940, +-0.935191704730152120, -0.935209410655453930, -0.935227114242732300, -0.935244815491942830, -0.935262514403041420, -0.935280210975983680, -0.935297905210725420, -0.935315597107222340, +-0.935333286665430360, -0.935350973885305080, -0.935368658766802420, -0.935386341309878080, -0.935404021514487870, -0.935421699380587610, -0.935439374908133110, -0.935457048097080190, +-0.935474718947384650, -0.935492387459002320, -0.935510053631888990, -0.935527717466000610, -0.935545378961292860, -0.935563038117721680, -0.935580694935242870, -0.935598349413812370, +-0.935616001553385980, -0.935633651353919630, -0.935651298815369010, -0.935668943937690290, -0.935686586720839260, -0.935704227164771640, -0.935721865269443450, -0.935739501034810630, +-0.935757134460829090, -0.935774765547454650, -0.935792394294643340, -0.935810020702350980, -0.935827644770533710, -0.935845266499147230, -0.935862885888147590, -0.935880502937490700, +-0.935898117647132600, -0.935915730017029210, -0.935933340047136460, -0.935950947737410390, -0.935968553087807020, -0.935986156098282060, -0.936003756768791880, -0.936021355099292300, +-0.936038951089739340, -0.936056544740089040, -0.936074136050297210, -0.936091725020320230, -0.936109311650113800, -0.936126895939634160, -0.936144477888837260, -0.936162057497679110, +-0.936179634766115880, -0.936197209694103580, -0.936214782281598160, -0.936232352528555970, -0.936249920434932710, -0.936267486000684770, -0.936285049225768050, -0.936302610110138710, +-0.936320168653752780, -0.936337724856566630, -0.936355278718535970, -0.936372830239617260, -0.936390379419766440, -0.936407926258939540, -0.936425470757093040, -0.936443012914182640, +-0.936460552730164820, -0.936478090204995620, -0.936495625338631290, -0.936513158131027760, -0.936530688582141390, -0.936548216691928230, -0.936565742460344630, -0.936583265887346530, +-0.936600786972890400, -0.936618305716932280, -0.936635822119428420, -0.936653336180334860, -0.936670847899608080, -0.936688357277204120, -0.936705864313079340, -0.936723369007189890, +-0.936740871359492020, -0.936758371369942000, -0.936775869038495970, -0.936793364365110290, -0.936810857349741230, -0.936828347992345050, -0.936845836292877880, -0.936863322251296200, +-0.936880805867556180, -0.936898287141614270, -0.936915766073426530, -0.936933242662949420, -0.936950716910139090, -0.936968188814952140, -0.936985658377344600, -0.937003125597272950, +-0.937020590474693440, -0.937038053009562550, -0.937055513201836440, -0.937072971051471690, -0.937090426558424450, -0.937107879722651080, -0.937125330544108070, -0.937142779022751670, +-0.937160225158538360, -0.937177668951424400, -0.937195110401366380, -0.937212549508320560, -0.937229986272243410, -0.937247420693091190, -0.937264852770820500, -0.937282282505387590, +-0.937299709896749160, -0.937317134944861240, -0.937334557649680660, -0.937351978011163540, -0.937369396029266610, -0.937386811703946000, -0.937404225035158520, -0.937421636022860440, +-0.937439044667008230, -0.937456450967558470, -0.937473854924467550, -0.937491256537692050, -0.937508655807188340, -0.937526052732913010, -0.937543447314822530, -0.937560839552873500, +-0.937578229447022290, -0.937595616997225600, -0.937613002203439790, -0.937630385065621460, -0.937647765583727200, -0.937665143757713590, -0.937682519587537010, -0.937699893073154270, +-0.937717264214521620, -0.937734633011595990, -0.937751999464333630, -0.937769363572691360, -0.937786725336625550, -0.937804084756093110, -0.937821441831050430, -0.937838796561454080, +-0.937856148947260770, -0.937873498988426980, -0.937890846684909630, -0.937908192036664980, -0.937925535043649950, -0.937942875705821020, -0.937960214023135010, -0.937977549995548390, +-0.937994883623017970, -0.938012214905500240, -0.938029543842952010, -0.938046870435329970, -0.938064194682590720, -0.938081516584690860, -0.938098836141587400, -0.938116153353236730, +-0.938133468219595760, -0.938150780740621080, -0.938168090916269510, -0.938185398746497650, -0.938202704231262290, -0.938220007370520140, -0.938237308164228010, -0.938254606612342610, +-0.938271902714820750, -0.938289196471619010, -0.938306487882694330, -0.938323776948003510, -0.938341063667503140, -0.938358348041150260, -0.938375630068901350, -0.938392909750713430, +-0.938410187086543220, -0.938427462076347530, -0.938444734720083160, -0.938462005017707050, -0.938479272969175880, -0.938496538574446590, -0.938513801833475880, -0.938531062746220670, +-0.938548321312637770, -0.938565577532684100, -0.938582831406316600, -0.938600082933491840, -0.938617332114166980, -0.938634578948298710, -0.938651823435844080, -0.938669065576759780, +-0.938686305371002950, -0.938703542818530300, -0.938720777919298750, -0.938738010673265340, -0.938755241080386880, -0.938772469140620290, -0.938789694853922500, -0.938806918220250530, +-0.938824139239561210, -0.938841357911811670, -0.938858574236958620, -0.938875788214959210, -0.938892999845770240, -0.938910209129348750, -0.938927416065651780, -0.938944620654636350, +-0.938961822896259290, -0.938979022790477740, -0.938996220337248500, -0.939013415536528840, -0.939030608388275570, -0.939047798892445830, -0.939064987048996550, -0.939082172857884870, +-0.939099356319067600, -0.939116537432502120, -0.939133716198145120, -0.939150892615953970, -0.939168066685885590, -0.939185238407897030, -0.939202407781945410, -0.939219574807987680, +-0.939236739485981080, -0.939253901815882530, -0.939271061797649300, -0.939288219431238410, -0.939305374716607020, -0.939322527653712050, -0.939339678242510970, -0.939356826482960480, +-0.939373972375018070, -0.939391115918640660, -0.939408257113785510, -0.939425395960409640, -0.939442532458470430, -0.939459666607924680, -0.939476798408729890, -0.939493927860843070, +-0.939511054964221490, -0.939528179718822300, -0.939545302124602520, -0.939562422181519640, -0.939579539889530580, -0.939596655248592820, -0.939613768258663270, -0.939630878919699320, +-0.939647987231658210, -0.939665093194497090, -0.939682196808173330, -0.939699298072643960, -0.939716396987866460, -0.939733493553797870, -0.939750587770395550, -0.939767679637616870, +-0.939784769155418860, -0.939801856323759120, -0.939818941142594570, -0.939836023611882680, -0.939853103731580710, -0.939870181501646140, -0.939887256922036010, -0.939904329992707680, +-0.939921400713618630, -0.939938469084726000, -0.939955535105987280, -0.939972598777359610, -0.939989660098800580, -0.940006719070267230, -0.940023775691717240, -0.940040829963107670, +-0.940057881884396210, -0.940074931455539890, -0.940091978676496300, -0.940109023547222700, -0.940126066067676680, -0.940143106237815380, -0.940160144057596400, -0.940177179526976880, +-0.940194212645914630, -0.940211243414366680, -0.940228271832290740, -0.940245297899644170, -0.940262321616384230, -0.940279342982468510, -0.940296361997854380, -0.940313378662499530, +-0.940330392976361010, -0.940347404939396720, -0.940364414551563720, -0.940381421812819810, -0.940398426723122350, -0.940415429282428830, -0.940432429490696610, -0.940449427347883390, +-0.940466422853946660, -0.940483416008843780, -0.940500406812532440, -0.940517395264970020, -0.940534381366114110, -0.940551365115922300, -0.940568346514352170, -0.940585325561360990, +-0.940602302256906550, -0.940619276600946350, -0.940636248593438080, -0.940653218234339010, -0.940670185523607040, -0.940687150461199440, -0.940704113047074130, -0.940721073281188480, +-0.940738031163500190, -0.940754986693966730, -0.940771939872545810, -0.940788890699195020, -0.940805839173872170, -0.940822785296534510, -0.940839729067140080, -0.940856670485646250, +-0.940873609552010710, -0.940890546266191170, -0.940907480628145330, -0.940924412637830660, -0.940941342295204990, -0.940958269600226100, -0.940975194552851390, -0.940992117153038770, +-0.941009037400745820, -0.941025955295930250, -0.941042870838549870, -0.941059784028562270, -0.941076694865925160, -0.941093603350596440, -0.941110509482533500, -0.941127413261694470, +-0.941144314688036830, -0.941161213761518510, -0.941178110482096990, -0.941195004849730400, -0.941211896864376120, -0.941228786525992180, -0.941245673834536280, -0.941262558789966120, +-0.941279441392239620, -0.941296321641314490, -0.941313199537148650, -0.941330075079699680, -0.941346948268925620, -0.941363819104784170, -0.941380687587233140, -0.941397553716230350, +-0.941414417491733820, -0.941431278913701040, -0.941448137982090260, -0.941464994696859070, -0.941481849057965390, -0.941498701065367040, -0.941515550719022040, -0.941532398018887990, +-0.941549242964923150, -0.941566085557085100, -0.941582925795331870, -0.941599763679621280, -0.941616599209911250, -0.941633432386159820, -0.941650263208324790, -0.941667091676364090, +-0.941683917790235640, -0.941700741549897360, -0.941717562955307290, -0.941734382006423340, -0.941751198703203340, -0.941768013045605420, -0.941784825033587400, -0.941801634667107420, +-0.941818441946123190, -0.941835246870593060, -0.941852049440474630, -0.941868849655726150, -0.941885647516305550, -0.941902443022170850, -0.941919236173280110, -0.941936026969591110, +-0.941952815411062240, -0.941969601497651190, -0.941986385229316210, -0.942003166606015130, -0.942019945627706300, -0.942036722294347540, -0.942053496605896990, -0.942070268562312570, +-0.942087038163552660, -0.942103805409575060, -0.942120570300338020, -0.942137332835799480, -0.942154093015917680, -0.942170850840650550, -0.942187606309956350, -0.942204359423793100, +-0.942221110182119070, -0.942237858584892170, -0.942254604632070670, -0.942271348323612590, -0.942288089659476190, -0.942304828639619510, -0.942321565264000790, -0.942338299532578190, +-0.942355031445309850, -0.942371761002153920, -0.942388488203068530, -0.942405213048011950, -0.942421935536942310, -0.942438655669817880, -0.942455373446596800, -0.942472088867237320, +-0.942488801931697600, -0.942505512639935870, -0.942522220991910300, -0.942538926987579240, -0.942555630626900840, -0.942572331909833360, -0.942589030836335050, -0.942605727406364170, +-0.942622421619879080, -0.942639113476837820, -0.942655802977198750, -0.942672490120920250, -0.942689174907960450, -0.942705857338277720, -0.942722537411830430, -0.942739215128576720, +-0.942755890488475080, -0.942772563491483530, -0.942789234137560770, -0.942805902426664730, -0.942822568358754110, -0.942839231933786940, -0.942855893151721800, -0.942872552012516850, +-0.942889208516130560, -0.942905862662521190, -0.942922514451647210, -0.942939163883466990, -0.942955810957938790, -0.942972455675021080, -0.942989098034672240, -0.943005738036850730, +-0.943022375681514700, -0.943039010968622860, -0.943055643898133460, -0.943072274470004970, -0.943088902684195760, -0.943105528540664320, -0.943122152039369000, -0.943138773180268400, +-0.943155391963320770, -0.943172008388484810, -0.943188622455718660, -0.943205234164981030, -0.943221843516230280, -0.943238450509425010, -0.943255055144523460, -0.943271657421484440, +-0.943288257340266220, -0.943304854900827270, -0.943321450103126290, -0.943338042947121650, -0.943354633432771930, -0.943371221560035610, -0.943387807328871290, -0.943404390739237320, +-0.943420971791092410, -0.943437550484395150, -0.943454126819103900, -0.943470700795177360, -0.943487272412574240, -0.943503841671252670, -0.943520408571171700, -0.943536973112289680, +-0.943553535294565200, -0.943570095117956860, -0.943586652582423250, -0.943603207687923160, -0.943619760434414870, -0.943636310821857280, -0.943652858850208890, -0.943669404519428380, +-0.943685947829474240, -0.943702488780305380, -0.943719027371880180, -0.943735563604157560, -0.943752097477095870, -0.943768628990654060, -0.943785158144790580, -0.943801684939464370, +-0.943818209374633790, -0.943834731450257760, -0.943851251166294760, -0.943867768522703820, -0.943884283519443310, -0.943900796156472270, -0.943917306433749050, -0.943933814351232690, +-0.943950319908881790, -0.943966823106655030, -0.943983323944511230, -0.943999822422409100, -0.944016318540307540, -0.944032812298165050, -0.944049303695940530, -0.944065792733592810, +-0.944082279411080580, -0.944098763728362660, -0.944115245685397840, -0.944131725282144840, -0.944148202518562680, -0.944164677394609850, -0.944181149910245380, -0.944197620065428070, +-0.944214087860116740, -0.944230553294270080, -0.944247016367847140, -0.944263477080806600, -0.944279935433107400, -0.944296391424708340, -0.944312845055568340, -0.944329296325646220, +-0.944345745234900780, -0.944362191783291060, -0.944378635970775760, -0.944395077797314020, -0.944411517262864430, -0.944427954367386250, -0.944444389110837950, -0.944460821493178890, +-0.944477251514367570, -0.944493679174363330, -0.944510104473124780, -0.944526527410610940, -0.944542947986780850, -0.944559366201593310, -0.944575782055007470, -0.944592195546982150, +-0.944608606677476260, -0.944625015446448950, -0.944641421853859020, -0.944657825899665520, -0.944674227583827570, -0.944690626906303900, -0.944707023867053850, -0.944723418466036140, +-0.944739810703209890, -0.944756200578534040, -0.944772588091967850, -0.944788973243470000, -0.944805356032999870, -0.944821736460516260, -0.944838114525978320, -0.944854490229345090, +-0.944870863570575700, -0.944887234549629080, -0.944903603166464490, -0.944919969421040730, -0.944936333313317170, -0.944952694843252840, -0.944969054010806550, -0.944985410815937790, +-0.945001765258605460, -0.945018117338768730, -0.945034467056386610, -0.945050814411418470, -0.945067159403823240, -0.945083502033560060, -0.945099842300588190, -0.945116180204866650, +-0.945132515746354710, -0.945148848925011500, -0.945165179740796170, -0.945181508193667860, -0.945197834283585720, -0.945214158010509120, -0.945230479374396970, -0.945246798375208750, +-0.945263115012903610, -0.945279429287440460, -0.945295741198778900, -0.945312050746877960, -0.945328357931696890, -0.945344662753194840, -0.945360965211331280, -0.945377265306065140, +-0.945393563037356000, -0.945409858405162780, -0.945426151409445080, -0.945442442050161920, -0.945458730327272680, -0.945475016240736600, -0.945491299790512940, -0.945507580976561070, +-0.945523859798840350, -0.945540136257309820, -0.945556410351929060, -0.945572682082657100, -0.945588951449453650, -0.945605218452277740, -0.945621483091088730, -0.945637745365846110, +-0.945654005276509110, -0.945670262823037120, -0.945686518005389280, -0.945702770823525380, -0.945719021277404370, -0.945735269366985930, -0.945751515092229320, -0.945767758453093910, +-0.945783999449539060, -0.945800238081524250, -0.945816474349008730, -0.945832708251952200, -0.945848939790313810, -0.945865168964053040, -0.945881395773129350, -0.945897620217502340, +-0.945913842297131160, -0.945930062011975270, -0.945946279361994380, -0.945962494347147740, -0.945978706967394830, -0.945994917222695240, -0.946011125113008330, -0.946027330638293470, +-0.946043533798510470, -0.946059734593618470, -0.946075933023577290, -0.946092129088346170, -0.946108322787884810, -0.946124514122152590, -0.946140703091109090, -0.946156889694713790, +-0.946173073932926380, -0.946189255805706120, -0.946205435313012930, -0.946221612454805960, -0.946237787231045120, -0.946253959641689790, -0.946270129686699430, -0.946286297366033870, +-0.946302462679652460, -0.946318625627515010, -0.946334786209580890, -0.946350944425809910, -0.946367100276161440, -0.946383253760595400, -0.946399404879071040, -0.946415553631548280, +-0.946431700017986600, -0.946447844038345700, -0.946463985692585160, -0.946480124980664690, -0.946496261902543770, -0.946512396458182410, -0.946528528647539890, -0.946544658470576120, +-0.946560785927250680, -0.946576911017523280, -0.946593033741353730, -0.946609154098701390, -0.946625272089526290, -0.946641387713788030, -0.946657500971446190, -0.946673611862460680, +-0.946689720386791110, -0.946705826544397280, -0.946721930335238880, -0.946738031759275510, -0.946754130816467310, -0.946770227506773530, -0.946786321830154430, -0.946802413786569260, +-0.946818503375978280, -0.946834590598340960, -0.946850675453617120, -0.946866757941766670, -0.946882838062749310, -0.946898915816524860, -0.946914991203053000, -0.946931064222293890, +-0.946947134874206900, -0.946963203158752150, -0.946979269075889360, -0.946995332625578560, -0.947011393807779210, -0.947027452622451580, -0.947043509069555140, -0.947059563149050040, +-0.947075614860895980, -0.947091664205052860, -0.947107711181480630, -0.947123755790139190, -0.947139798030988240, -0.947155837903987830, -0.947171875409097860, -0.947187910546278160, +-0.947203943315488630, -0.947219973716689420, -0.947236001749840130, -0.947252027414900890, -0.947268050711831620, -0.947284071640592140, -0.947300090201142480, -0.947316106393442660, +-0.947332120217452500, -0.947348131673132030, -0.947364140760441400, -0.947380147479340180, -0.947396151829788760, -0.947412153811746930, -0.947428153425174720, -0.947444150670032070, +-0.947460145546279110, -0.947476138053875760, -0.947492128192782060, -0.947508115962958030, -0.947524101364363710, -0.947540084396959250, -0.947556065060704440, -0.947572043355559450, +-0.947588019281484390, -0.947603992838439320, -0.947619964026384260, -0.947635932845279360, -0.947651899295084420, -0.947667863375759920, -0.947683825087265670, -0.947699784429561930, +-0.947715741402608720, -0.947731696006366090, -0.947747648240794270, -0.947763598105853310, -0.947779545601503350, -0.947795490727704530, -0.947811433484416990, -0.947827373871600880, +-0.947843311889216330, -0.947859247537223500, -0.947875180815582640, -0.947891111724253670, -0.947907040263197050, -0.947922966432372730, -0.947938890231741050, -0.947954811661262050, +-0.947970730720896100, -0.947986647410603340, -0.948002561730344030, -0.948018473680078190, -0.948034383259766190, -0.948050290469368170, -0.948066195308844620, -0.948082097778155440, +-0.948097997877261010, -0.948113895606121580, -0.948129790964697520, -0.948145683952948850, -0.948161574570836050, -0.948177462818319380, -0.948193348695358870, -0.948209232201915220, +-0.948225113337948230, -0.948240992103418610, -0.948256868498286500, -0.948272742522512260, -0.948288614176056030, -0.948304483458878410, -0.948320350370939420, -0.948336214912199770, +-0.948352077082619370, -0.948367936882158920, -0.948383794310778570, -0.948399649368438790, -0.948415502055099720, -0.948431352370722070, -0.948447200315265970, -0.948463045888691900, +-0.948478889090960230, -0.948494729922031320, -0.948510568381865650, -0.948526404470423360, -0.948542238187665250, -0.948558069533551480, -0.948573898508042520, -0.948589725111098850, +-0.948605549342680820, -0.948621371202748920, -0.948637190691263730, -0.948653007808185400, -0.948668822553474620, -0.948684634927091760, -0.948700444928997300, -0.948716252559151710, +-0.948732057817515570, -0.948747860704049260, -0.948763661218713250, -0.948779459361468120, -0.948795255132274360, -0.948811048531092440, -0.948826839557882940, -0.948842628212606340, +-0.948858414495223010, -0.948874198405693870, -0.948889979943979060, -0.948905759110039380, -0.948921535903835320, -0.948937310325327470, -0.948953082374476180, -0.948968852051242370, +-0.948984619355586200, -0.949000384287468690, -0.949016146846850090, -0.949031907033691220, -0.949047664847952550, -0.949063420289594780, -0.949079173358578280, -0.949094924054864060, +-0.949110672378412400, -0.949126418329184100, -0.949142161907139740, -0.949157903112240020, -0.949173641944445530, -0.949189378403716870, -0.949205112490014820, -0.949220844203299880, +-0.949236573543532970, -0.949252300510674550, -0.949268025104685440, -0.949283747325526230, -0.949299467173157720, -0.949315184647540390, -0.949330899748635270, -0.949346612476402730, +-0.949362322830803800, -0.949378030811798950, -0.949393736419349210, -0.949409439653414950, -0.949425140513957210, -0.949440839000936450, -0.949456535114313720, -0.949472228854049690, +-0.949487920220104980, -0.949503609212440590, -0.949519295831017130, -0.949534980075795400, -0.949550661946736210, -0.949566341443800370, -0.949582018566948680, -0.949597693316141970, +-0.949613365691341030, -0.949629035692506670, -0.949644703319599710, -0.949660368572580960, -0.949676031451411330, -0.949691691956051630, -0.949707350086462680, -0.949723005842605380, +-0.949738659224440450, -0.949754310231929020, -0.949769958865031790, -0.949785605123709690, -0.949801249007923510, -0.949816890517634180, -0.949832529652802740, -0.949848166413389870, +-0.949863800799356620, -0.949879432810663780, -0.949895062447272510, -0.949910689709143500, -0.949926314596237780, -0.949941937108516270, -0.949957557245940000, -0.949973175008469670, +-0.949988790396066540, -0.950004403408691410, -0.950020014046305320, -0.950035622308869070, -0.950051228196343800, -0.950066831708690440, -0.950082432845870130, -0.950098031607843670, +-0.950113627994572110, -0.950129222006016460, -0.950144813642137760, -0.950160402902897050, -0.950175989788255350, -0.950191574298173690, -0.950207156432613000, -0.950222736191534520, +-0.950238313574899180, -0.950253888582668020, -0.950269461214802160, -0.950285031471262640, -0.950300599352010500, -0.950316164857006980, -0.950331727986212900, -0.950347288739589620, +-0.950362847117098060, -0.950378403118699480, -0.950393956744354780, -0.950409507994025240, -0.950425056867671870, -0.950440603365255930, -0.950456147486738460, -0.950471689232080590, +-0.950487228601243570, -0.950502765594188340, -0.950518300210876350, -0.950533832451268430, -0.950549362315326160, -0.950564889803010350, -0.950580414914282360, -0.950595937649103220, +-0.950611458007434410, -0.950626975989236840, -0.950642491594471890, -0.950658004823100590, -0.950673515675084400, -0.950689024150384370, -0.950704530248961840, -0.950720033970777980, +-0.950735535315794020, -0.950751034283971230, -0.950766530875270740, -0.950782025089654040, -0.950797516927082250, -0.950813006387516650, -0.950828493470918580, -0.950843978177249300, +-0.950859460506469970, -0.950874940458542040, -0.950890418033426780, -0.950905893231085430, -0.950921366051479370, -0.950936836494569950, -0.950952304560318320, -0.950967770248686060, +-0.950983233559634320, -0.950998694493124460, -0.951014153049117850, -0.951029609227575960, -0.951045063028460040, -0.951060514451731340, -0.951075963497351460, -0.951091410165281650, +-0.951106854455483370, -0.951122296367917790, -0.951137735902546690, -0.951153173059331000, -0.951168607838232540, -0.951184040239212550, -0.951199470262232500, -0.951214897907253660, +-0.951230323174237610, -0.951245746063145830, -0.951261166573939550, -0.951276584706580500, -0.951292000461029910, -0.951307413837249260, -0.951322824835200250, -0.951338233454844030, +-0.951353639696142280, -0.951369043559056490, -0.951384445043547910, -0.951399844149578340, -0.951415240877109160, -0.951430635226101940, -0.951446027196518050, -0.951461416788319080, +-0.951476804001466610, -0.951492188835922130, -0.951507571291647090, -0.951522951368603210, -0.951538329066751950, -0.951553704386054910, -0.951569077326473440, -0.951584447887969480, +-0.951599816070504260, -0.951615181874039600, -0.951630545298536860, -0.951645906343957850, -0.951661265010264160, -0.951676621297417150, -0.951691975205378630, -0.951707326734110180, +-0.951722675883573510, -0.951738022653729980, -0.951753367044541500, -0.951768709055969550, -0.951784048687975950, -0.951799385940522050, -0.951814720813569770, -0.951830053307080700, +-0.951845383421016540, -0.951860711155338770, -0.951876036510009400, -0.951891359484989820, -0.951906680080241930, -0.951921998295727210, -0.951937314131407590, -0.951952627587244750, +-0.951967938663200290, -0.951983247359235900, -0.951998553675313500, -0.952013857611394680, -0.952029159167441130, -0.952044458343414780, -0.952059755139277210, -0.952075049554990340, +-0.952090341590515750, -0.952105631245815490, -0.952120918520850900, -0.952136203415584250, -0.952151485929976890, -0.952166766063990980, -0.952182043817588090, -0.952197319190730030, +-0.952212592183378730, -0.952227862795495980, -0.952243131027043500, -0.952258396877983300, -0.952273660348277100, -0.952288921437886680, -0.952304180146773980, -0.952319436474900800, +-0.952334690422229070, -0.952349941988720470, -0.952365191174337270, -0.952380437979040930, -0.952395682402793490, -0.952410924445556860, -0.952426164107292970, -0.952441401387963630, +-0.952456636287530860, -0.952471868805956360, -0.952487098943202270, -0.952502326699230410, -0.952517552074002790, -0.952532775067481240, -0.952547995679627780, -0.952563213910404330, +-0.952578429759772800, -0.952593643227695350, -0.952608854314133560, -0.952624063019049780, -0.952639269342405840, -0.952654473284163750, -0.952669674844285330, -0.952684874022732830, +-0.952700070819468170, -0.952715265234453270, -0.952730457267650270, -0.952745646919021080, -0.952760834188527750, -0.952776019076132410, -0.952791201581796980, -0.952806381705483480, +-0.952821559447154080, -0.952836734806770890, -0.952851907784295740, -0.952867078379690870, -0.952882246592918310, -0.952897412423940100, -0.952912575872718380, -0.952927736939215180, +-0.952942895623392740, -0.952958051925212880, -0.952973205844638070, -0.952988357381630120, -0.953003506536151400, -0.953018653308163820, -0.953033797697629640, -0.953048939704510990, +-0.953064079328769910, -0.953079216570368650, -0.953094351429269460, -0.953109483905434260, -0.953124613998825420, -0.953139741709405080, -0.953154867037135370, -0.953169989981978330, +-0.953185110543896540, -0.953200228722851930, -0.953215344518806630, -0.953230457931723120, -0.953245568961563320, -0.953260677608289700, -0.953275783871864290, -0.953290887752249460, +-0.953305989249407460, -0.953321088363300430, -0.953336185093890730, -0.953351279441140620, -0.953366371405012130, -0.953381460985467830, -0.953396548182469880, -0.953411632995980530, +-0.953426715425962130, -0.953441795472376950, -0.953456873135187230, -0.953471948414355340, -0.953487021309843640, -0.953502091821614380, -0.953517159949629820, -0.953532225693852430, +-0.953547289054244460, -0.953562350030768170, -0.953577408623386140, -0.953592464832060500, -0.953607518656753750, -0.953622570097428120, -0.953637619154046210, -0.953652665826570160, +-0.953667710114962430, -0.953682752019185510, -0.953697791539201640, -0.953712828674973310, -0.953727863426462870, -0.953742895793632810, -0.953757925776445580, -0.953772953374863340, +-0.953787978588848890, -0.953803001418364490, -0.953818021863372500, -0.953833039923835610, -0.953848055599715970, -0.953863068890976270, -0.953878079797578770, -0.953893088319486160, +-0.953908094456660800, -0.953923098209065290, -0.953938099576661980, -0.953953098559413460, -0.953968095157282090, -0.953983089370230570, -0.953998081198221270, -0.954013070641216880, +-0.954028057699179640, -0.954043042372072380, -0.954058024659857450, -0.954073004562497550, -0.954087982079955150, -0.954102957212192630, -0.954117929959172880, -0.954132900320858180, +-0.954147868297211430, -0.954162833888194780, -0.954177797093771150, -0.954192757913903010, -0.954207716348553060, -0.954222672397683660, -0.954237626061257730, -0.954252577339237630, +-0.954267526231586170, -0.954282472738265720, -0.954297416859239300, -0.954312358594469170, -0.954327297943918350, -0.954342234907549100, -0.954357169485324340, -0.954372101677206650, +-0.954387031483158730, -0.954401958903143170, -0.954416883937122760, -0.954431806585060110, -0.954446726846918000, -0.954461644722659040, -0.954476560212245920, -0.954491473315641440, +-0.954506384032808300, -0.954521292363709200, -0.954536198308306830, -0.954551101866564000, -0.954566003038443410, -0.954580901823907760, -0.954595798222919960, -0.954610692235442590, +-0.954625583861438480, -0.954640473100870410, -0.954655359953701210, -0.954670244419893570, -0.954685126499410290, -0.954700006192214290, -0.954714883498268270, -0.954729758417534930, +-0.954744630949977300, -0.954759501095558070, -0.954774368854240050, -0.954789234225986160, -0.954804097210759100, -0.954818957808521880, -0.954833816019237220, -0.954848671842868040, +-0.954863525279377230, -0.954878376328727520, -0.954893224990881920, -0.954908071265803240, -0.954922915153454400, -0.954937756653798210, -0.954952595766797700, -0.954967432492415670, +-0.954982266830615050, -0.954997098781358860, -0.955011928344609800, -0.955026755520331010, -0.955041580308485180, -0.955056402709035580, -0.955071222721944890, -0.955086040347176150, +-0.955100855584692270, -0.955115668434456390, -0.955130478896431100, -0.955145286970579880, -0.955160092656865300, -0.955174895955250510, -0.955189696865698430, -0.955204495388172200, +-0.955219291522634630, -0.955234085269048960, -0.955248876627377900, -0.955263665597584800, -0.955278452179632480, -0.955293236373484070, -0.955308018179102600, -0.955322797596451000, +-0.955337574625492400, -0.955352349266189950, -0.955367121518506560, -0.955381891382405370, -0.955396658857849520, -0.955411423944801940, -0.955426186643225870, -0.955440946953084240, +-0.955455704874340280, -0.955470460406957050, -0.955485213550897770, -0.955499964306125270, -0.955514712672603020, -0.955529458650293930, -0.955544202239161260, -0.955558943439167920, +-0.955573682250277390, -0.955588418672452590, -0.955603152705656770, -0.955617884349853060, -0.955632613605004620, -0.955647340471074690, -0.955662064948026300, -0.955676787035822930, +-0.955691506734427380, -0.955706224043803230, -0.955720938963913410, -0.955735651494721280, -0.955750361636189980, -0.955765069388282870, -0.955779774750963100, -0.955794477724193790, +-0.955809178307938320, -0.955823876502159940, -0.955838572306821900, -0.955853265721887340, -0.955867956747319610, -0.955882645383082100, -0.955897331629137930, -0.955912015485450350, +-0.955926696951982850, -0.955941376028698550, -0.955956052715560830, -0.955970727012532940, -0.955985398919578230, -0.956000068436660080, -0.956014735563741720, -0.956029400300786540, +-0.956044062647757880, -0.956058722604618990, -0.956073380171333360, -0.956088035347864240, -0.956102688134175090, -0.956117338530229070, -0.956131986535989850, -0.956146632151420590, +-0.956161275376484880, -0.956175916211145840, -0.956190554655367060, -0.956205190709111920, -0.956219824372343760, -0.956234455645026070, -0.956249084527122210, -0.956263711018595640, +-0.956278335119409850, -0.956292956829528200, -0.956307576148914150, -0.956322193077531190, -0.956336807615342680, -0.956351419762312190, -0.956366029518403100, -0.956380636883578990, +-0.956395241857803220, -0.956409844441039490, -0.956424444633250940, -0.956439042434401480, -0.956453637844454250, -0.956468230863373070, -0.956482821491121290, -0.956497409727662400, +-0.956511995572960070, -0.956526579026977570, -0.956541160089678820, -0.956555738761027060, -0.956570315040986000, -0.956584888929519090, -0.956599460426590050, -0.956614029532162350, +-0.956628596246199560, -0.956643160568665160, -0.956657722499523080, -0.956672282038736440, -0.956686839186269290, -0.956701393942084980, -0.956715946306147200, -0.956730496278419550, +-0.956745043858865610, -0.956759589047449180, -0.956774131844133620, -0.956788672248882870, -0.956803210261660380, -0.956817745882429850, -0.956832279111154980, -0.956846809947799470, +-0.956861338392326790, -0.956875864444700850, -0.956890388104885250, -0.956904909372843780, -0.956919428248539820, -0.956933944731937490, -0.956948458823000170, -0.956962970521691770, +-0.956977479827975870, -0.956991986741816400, -0.957006491263176830, -0.957020993392021070, -0.957035493128312820, -0.957049990472015890, -0.957064485423093970, -0.957078977981510870, +-0.957093468147230290, -0.957107955920216020, -0.957122441300431890, -0.957136924287841580, -0.957151404882409020, -0.957165883084097890, -0.957180358892872230, -0.957194832308695510, +-0.957209303331531760, -0.957223771961344670, -0.957238238198098280, -0.957252702041756160, -0.957267163492282470, -0.957281622549640670, -0.957296079213795000, -0.957310533484708960, +-0.957324985362346670, -0.957339434846671940, -0.957353881937648590, -0.957368326635240630, -0.957382768939411650, -0.957397208850125910, -0.957411646367347100, -0.957426081491039250, +-0.957440514221166050, -0.957454944557691650, -0.957469372500579840, -0.957483798049794670, -0.957498221205300040, -0.957512641967059760, -0.957527060335037870, -0.957541476309198390, +-0.957555889889505240, -0.957570301075922340, -0.957584709868413600, -0.957599116266943160, -0.957613520271474950, -0.957627921881972880, -0.957642321098401080, -0.957656717920723490, +-0.957671112348904010, -0.957685504382906780, -0.957699894022695840, -0.957714281268235100, -0.957728666119488700, -0.957743048576420560, -0.957757428638994930, -0.957771806307175620, +-0.957786181580926880, -0.957800554460212620, -0.957814924944996980, -0.957829293035244110, -0.957843658730917920, -0.957858022031982560, -0.957872382938402270, -0.957886741450140860, +-0.957901097567162680, -0.957915451289431790, -0.957929802616912300, -0.957944151549568250, -0.957958498087363770, -0.957972842230263130, -0.957987183978230350, -0.958001523331229570, +-0.958015860289225030, -0.958030194852180880, -0.958044527020061150, -0.958058856792830090, -0.958073184170451950, -0.958087509152890870, -0.958101831740110990, -0.958116151932076550, +-0.958130469728751710, -0.958144785130100710, -0.958159098136087680, -0.958173408746677000, -0.958187716961832690, -0.958202022781519220, -0.958216326205700630, -0.958230627234341270, +-0.958244925867405280, -0.958259222104857030, -0.958273515946660660, -0.958287807392780520, -0.958302096443180870, -0.958316383097825960, -0.958330667356680150, -0.958344949219707590, +-0.958359228686872730, -0.958373505758139730, -0.958387780433473060, -0.958402052712836850, -0.958416322596195580, -0.958430590083513500, -0.958444855174754970, -0.958459117869884140, +-0.958473378168865690, -0.958487636071663650, -0.958501891578242730, -0.958516144688566940, -0.958530395402600770, -0.958544643720308680, -0.958558889641654920, -0.958573133166603970, +-0.958587374295120200, -0.958601613027167950, -0.958615849362711710, -0.958630083301715840, -0.958644314844144700, -0.958658543989962860, -0.958672770739134590, -0.958686995091624470, +-0.958701217047396750, -0.958715436606416120, -0.958729653768646830, -0.958743868534053360, -0.958758080902600280, -0.958772290874251980, -0.958786498448973010, -0.958800703626727760, +-0.958814906407480790, -0.958829106791196480, -0.958843304777839410, -0.958857500367374050, -0.958871693559765090, -0.958885884354976680, -0.958900072752973730, -0.958914258753720490, +-0.958928442357181670, -0.958942623563321720, -0.958956802372105230, -0.958970978783496690, -0.958985152797460770, -0.958999324413961960, -0.959013493632964840, -0.959027660454433880, +-0.959041824878333890, -0.959055986904629340, -0.959070146533284820, -0.959084303764264900, -0.959098458597534180, -0.959112611033057340, -0.959126761070798970, -0.959140908710723770, +-0.959155053952796210, -0.959169196796981090, -0.959183337243242900, -0.959197475291546420, -0.959211610941856250, -0.959225744194137090, -0.959239875048353400, -0.959254003504470210, +-0.959268129562451890, -0.959282253222263350, -0.959296374483869060, -0.959310493347233950, -0.959324609812322590, -0.959338723879099690, -0.959352835547529930, -0.959366944817578120, +-0.959381051689208950, -0.959395156162387130, -0.959409258237077460, -0.959423357913244620, -0.959437455190853440, -0.959451550069868600, -0.959465642550254790, -0.959479732631976940, +-0.959493820314999860, -0.959507905599288000, -0.959521988484806520, -0.959536068971520110, -0.959550147059393450, -0.959564222748391480, -0.959578296038478880, -0.959592366929620580, +-0.959606435421781370, -0.959620501514926060, -0.959634565209019570, -0.959648626504026600, -0.959662685399912060, -0.959676741896640760, -0.959690795994177610, -0.959704847692487650, +-0.959718896991535340, -0.959732943891285940, -0.959746988391704140, -0.959761030492754850, -0.959775070194403000, -0.959789107496613390, -0.959803142399351160, -0.959817174902581010, +-0.959831205006267840, -0.959845232710376810, -0.959859258014872600, -0.959873280919720240, -0.959887301424884650, -0.959901319530330980, -0.959915335236023790, -0.959929348541928460, +-0.959943359448009680, -0.959957367954232480, -0.959971374060561880, -0.959985377766962800, -0.959999379073400270, -0.960013377979839320, -0.960027374486244980, -0.960041368592582160, +-0.960055360298816000, -0.960069349604911300, -0.960083336510833330, -0.960097321016546880, -0.960111303122017310, -0.960125282827209330, -0.960139260132088280, -0.960153235036618980, +-0.960167207540766680, -0.960181177644496180, -0.960195145347772950, -0.960209110650561800, -0.960223073552827770, -0.960237034054536200, -0.960250992155651910, -0.960264947856140250, +-0.960278901155966150, -0.960292852055094850, -0.960306800553491380, -0.960320746651120990, -0.960334690347948610, -0.960348631643939580, -0.960362570539058940, -0.960376507033271930, +-0.960390441126543590, -0.960404372818839170, -0.960418302110123800, -0.960432229000362740, -0.960446153489521000, -0.960460075577563970, -0.960473995264456650, -0.960487912550164410, +-0.960501827434652510, -0.960515739917885860, -0.960529649999829930, -0.960543557680449860, -0.960557462959710890, -0.960571365837578290, -0.960585266314017310, -0.960599164388993070, +-0.960613060062470940, -0.960626953334416170, -0.960640844204794120, -0.960654732673569820, -0.960668618740708750, -0.960682502406176140, -0.960696383669937260, -0.960710262531957350, +-0.960724138992201880, -0.960738013050636110, -0.960751884707225170, -0.960765753961934640, -0.960779620814729670, -0.960793485265575730, -0.960807347314437950, -0.960821206961281820, +-0.960835064206072680, -0.960848919048776010, -0.960862771489356840, -0.960876621527780860, -0.960890469164013330, -0.960904314398019600, -0.960918157229765040, -0.960931997659215220, +-0.960945835686335290, -0.960959671311090840, -0.960973504533447100, -0.960987335353369660, -0.961001163770823900, -0.961014989785775260, -0.961028813398189130, -0.961042634608030970, +-0.961056453415266130, -0.961070269819860210, -0.961084083821778680, -0.961097895420986890, -0.961111704617450440, -0.961125511411134560, -0.961139315802005070, -0.961153117790027210, +-0.961166917375166570, -0.961180714557388630, -0.961194509336658950, -0.961208301712942910, -0.961222091686206200, -0.961235879256414180, -0.961249664423532550, -0.961263447187526650, +-0.961277227548362200, -0.961291005506004660, -0.961304781060419720, -0.961318554211572640, -0.961332324959429330, -0.961346093303955150, -0.961359859245115690, -0.961373622782876640, +-0.961387383917203580, -0.961401142648061980, -0.961414898975417540, -0.961428652899235850, -0.961442404419482480, -0.961456153536123240, -0.961469900249123490, -0.961483644558449040, +-0.961497386464065460, -0.961511125965938460, -0.961524863064033620, -0.961538597758316630, -0.961552330048753070, -0.961566059935308750, -0.961579787417949250, -0.961593512496640380, +-0.961607235171347610, -0.961620955442036850, -0.961634673308673690, -0.961648388771223720, -0.961662101829652950, -0.961675812483926750, -0.961689520734011150, -0.961703226579871730, +-0.961716930021474180, -0.961730631058784420, -0.961744329691768040, -0.961758025920390720, -0.961771719744618500, -0.961785411164416850, -0.961799100179751790, -0.961812786790588900, +-0.961826470996894000, -0.961840152798633000, -0.961853832195771590, -0.961867509188275570, -0.961881183776110870, -0.961894855959243290, -0.961908525737638300, -0.961922193111262260, +-0.961935858080080530, -0.961949520644059250, -0.961963180803164120, -0.961976838557361160, -0.961990493906615950, -0.962004146850894640, -0.962017797390162910, -0.962031445524386690, +-0.962045091253531770, -0.962058734577564300, -0.962072375496449860, -0.962086014010154480, -0.962099650118644070, -0.962113283821884660, -0.962126915119841940, -0.962140544012481950, +-0.962154170499770590, -0.962167794581673790, -0.962181416258157560, -0.962195035529187730, -0.962208652394730300, -0.962222266854751320, -0.962235878909216580, -0.962249488558092110, +-0.962263095801344060, -0.962276700638938220, -0.962290303070840620, -0.962303903097017190, -0.962317500717434160, -0.962331095932057230, -0.962344688740852660, -0.962358279143786350, +-0.962371867140824340, -0.962385452731932540, -0.962399035917077320, -0.962412616696224350, -0.962426195069339910, -0.962439771036390000, -0.962453344597340550, -0.962466915752157930, +-0.962480484500807810, -0.962494050843256680, -0.962507614779470220, -0.962521176309414920, -0.962534735433056450, -0.962548292150361310, -0.962561846461295390, -0.962575398365824950, +-0.962588947863915910, -0.962602494955534520, -0.962616039640646900, -0.962629581919219210, -0.962643121791217470, -0.962656659256608040, -0.962670194315356830, -0.962683726967430320, +-0.962697257212794310, -0.962710785051415270, -0.962724310483259240, -0.962737833508292450, -0.962751354126481050, -0.962764872337791290, -0.962778388142189410, -0.962791901539641450, +-0.962805412530113760, -0.962818921113572480, -0.962832427289983970, -0.962845931059314370, -0.962859432421530050, -0.962872931376597020, -0.962886427924481760, -0.962899922065150290, +-0.962913413798569210, -0.962926903124704410, -0.962940390043522500, -0.962953874554989490, -0.962967356659071850, -0.962980836355735840, -0.962994313644947700, -0.963007788526673790, +-0.963021261000880370, -0.963034731067533900, -0.963048198726600520, -0.963061663978046710, -0.963075126821838600, -0.963088587257942890, -0.963102045286325480, -0.963115500906953190, +-0.963128954119791940, -0.963142404924808400, -0.963155853321968850, -0.963169299311239730, -0.963182742892587210, -0.963196184065977960, -0.963209622831378120, -0.963223059188754390, +-0.963236493138072910, -0.963249924679300260, -0.963263353812402800, -0.963276780537346890, -0.963290204854099000, -0.963303626762625600, -0.963317046262893270, -0.963330463354868160, +-0.963343878038517070, -0.963357290313806120, -0.963370700180702030, -0.963384107639171150, -0.963397512689180060, -0.963410915330695120, -0.963424315563682910, -0.963437713388109910, +-0.963451108803942690, -0.963464501811147620, -0.963477892409691390, -0.963491280599540370, -0.963504666380661120, -0.963518049753020240, -0.963531430716584200, -0.963544809271319690, +-0.963558185417193070, -0.963571559154170920, -0.963584930482219940, -0.963598299401306700, -0.963611665911397570, -0.963625030012459470, -0.963638391704458640, -0.963651750987361890, +-0.963665107861135680, -0.963678462325746830, -0.963691814381161690, -0.963705164027347180, -0.963718511264269660, -0.963731856091895820, -0.963745198510192360, -0.963758538519125960, +-0.963771876118663220, -0.963785211308770820, -0.963798544089415340, -0.963811874460563490, -0.963825202422181950, -0.963838527974237410, -0.963851851116696580, -0.963865171849526030, +-0.963878490172692670, -0.963891806086162980, -0.963905119589903880, -0.963918430683881830, -0.963931739368063870, -0.963945045642416450, -0.963958349506906510, -0.963971650961500610, +-0.963984950006165690, -0.963998246640868190, -0.964011540865575280, -0.964024832680253410, -0.964038122084869500, -0.964051409079390240, -0.964064693663782560, -0.964077975838013130, +-0.964091255602048670, -0.964104532955856190, -0.964117807899402270, -0.964131080432653830, -0.964144350555577790, -0.964157618268140840, -0.964170883570309780, -0.964184146462051530, +-0.964197406943332890, -0.964210665014120780, -0.964223920674382010, -0.964237173924083480, -0.964250424763191890, -0.964263673191674390, -0.964276919209497540, -0.964290162816628600, +-0.964303404013034050, -0.964316642798681120, -0.964329879173536630, -0.964343113137567260, -0.964356344690740270, -0.964369573833022240, -0.964382800564380420, -0.964396024884781600, +-0.964409246794192710, -0.964422466292580660, -0.964435683379912480, -0.964448898056155080, -0.964462110321275380, -0.964475320175240510, -0.964488527618017290, -0.964501732649572730, +-0.964514935269873860, -0.964528135478887600, -0.964541333276581090, -0.964554528662921130, -0.964567721637874960, -0.964580912201409510, -0.964594100353491690, -0.964607286094088750, +-0.964620469423167370, -0.964633650340695040, -0.964646828846638440, -0.964660004940964820, -0.964673178623641210, -0.964686349894634640, -0.964699518753912130, -0.964712685201440930, +-0.964725849237187960, -0.964739010861120350, -0.964752170073205240, -0.964765326873409770, -0.964778481261700850, -0.964791633238045840, -0.964804782802411660, -0.964817929954765560, +-0.964831074695074560, -0.964844217023306030, -0.964857356939426870, -0.964870494443404340, -0.964883629535205570, -0.964896762214797700, -0.964909892482147980, -0.964923020337223440, +-0.964936145779991430, -0.964949268810419090, -0.964962389428473570, -0.964975507634121990, -0.964988623427331600, -0.965001736808069780, -0.965014847776303530, -0.965027956332000230, +-0.965041062475127000, -0.965054166205651100, -0.965067267523539880, -0.965080366428760380, -0.965093462921279950, -0.965106557001065960, -0.965119648668085530, -0.965132737922306030, +-0.965145824763694590, -0.965158909192218690, -0.965171991207845470, -0.965185070810542280, -0.965198148000276370, -0.965211222777015100, -0.965224295140725830, -0.965237365091375810, +-0.965250432628932290, -0.965263497753362840, -0.965276560464634500, -0.965289620762714850, -0.965302678647571020, -0.965315734119170710, -0.965328787177480940, -0.965341837822469180, +-0.965354886054102800, -0.965367931872349370, -0.965380975277176030, -0.965394016268550150, -0.965407054846439290, -0.965420091010810830, -0.965433124761632120, -0.965446156098870630, +-0.965459185022493730, -0.965472211532468760, -0.965485235628763430, -0.965498257311344980, -0.965511276580180770, -0.965524293435238490, -0.965537307876485400, -0.965550319903889060, +-0.965563329517416970, -0.965576336717036470, -0.965589341502715250, -0.965602343874420570, -0.965615343832120110, -0.965628341375781240, -0.965641336505371540, -0.965654329220858480, +-0.965667319522209630, -0.965680307409392480, -0.965693292882374490, -0.965706275941123350, -0.965719256585606420, -0.965732234815791510, -0.965745210631645870, -0.965758184033137290, +-0.965771155020233140, -0.965784123592901220, -0.965797089751108890, -0.965810053494823960, -0.965823014824013780, -0.965835973738646160, -0.965848930238688560, -0.965861884324108690, +-0.965874835994874000, -0.965887785250952310, -0.965900732092311090, -0.965913676518918020, -0.965926618530740910, -0.965939558127747120, -0.965952495309904460, -0.965965430077180610, +-0.965978362429543160, -0.965991292366959800, -0.966004219889398220, -0.966017144996826000, -0.966030067689211070, -0.966042987966520770, -0.966055905828723250, -0.966068821275785750, +-0.966081734307676300, -0.966094644924362480, -0.966107553125812090, -0.966120458911992830, -0.966133362282872390, -0.966146263238418460, -0.966159161778599060, -0.966172057903381680, +-0.966184951612734100, -0.966197842906624140, -0.966210731785019590, -0.966223618247888270, -0.966236502295197860, -0.966249383926916170, -0.966262263143011000, -0.966275139943450270, +-0.966288014328201660, -0.966300886297232990, -0.966313755850512050, -0.966326622988006870, -0.966339487709685030, -0.966352350015514450, -0.966365209905463040, -0.966378067379498610, +-0.966390922437588950, -0.966403775079702100, -0.966416625305805630, -0.966429473115867800, -0.966442318509856180, -0.966455161487738800, -0.966468002049483580, -0.966480840195058200, +-0.966493675924430810, -0.966506509237569200, -0.966519340134441410, -0.966532168615015120, -0.966544994679258470, -0.966557818327139380, -0.966570639558625770, -0.966583458373685420, +-0.966596274772286490, -0.966609088754396880, -0.966621900319984630, -0.966634709469017530, -0.966647516201463720, -0.966660320517291010, -0.966673122416467630, -0.966685921898961410, +-0.966698718964740360, -0.966711513613772500, -0.966724305846025870, -0.966737095661468480, -0.966749883060068370, -0.966762668041793560, -0.966775450606611960, -0.966788230754491940, +-0.966801008485401180, -0.966813783799307940, -0.966826556696180230, -0.966839327175986200, -0.966852095238693750, -0.966864860884271150, -0.966877624112686410, -0.966890384923907550, +-0.966903143317902720, -0.966915899294640060, -0.966928652854087690, -0.966941403996213640, -0.966954152720986060, -0.966966899028373180, -0.966979642918343040, -0.966992384390863660, +-0.967005123445903500, -0.967017860083430380, -0.967030594303412650, -0.967043326105818450, -0.967056055490616020, -0.967068782457773280, -0.967081507007258700, -0.967094229139040310, +-0.967106948853086460, -0.967119666149365060, -0.967132381027844600, -0.967145093488493200, -0.967157803531279110, -0.967170511156170360, -0.967183216363135420, -0.967195919152142540, +-0.967208619523159620, -0.967221317476155360, -0.967234013011097680, -0.967246706127955050, -0.967259396826695590, -0.967272085107287790, -0.967284770969699560, -0.967297454413899580, +-0.967310135439855890, -0.967322814047536840, -0.967335490236910790, -0.967348164007945990, -0.967360835360610790, -0.967373504294873570, -0.967386170810702440, -0.967398834908066000, +-0.967411496586932370, -0.967424155847270150, -0.967436812689047470, -0.967449467112232670, -0.967462119116794360, -0.967474768702700660, -0.967487415869920040, -0.967500060618420870, +-0.967512702948171600, -0.967525342859140600, -0.967537980351296230, -0.967550615424606740, -0.967563248079040930, -0.967575878314566930, -0.967588506131153210, -0.967601131528768140, +-0.967613754507380410, -0.967626375066958140, -0.967638993207470040, -0.967651608928884470, -0.967664222231169880, -0.967676833114294640, -0.967689441578227340, -0.967702047622936550, +-0.967714651248390510, -0.967727252454557930, -0.967739851241407160, -0.967752447608906770, -0.967765041557025250, -0.967777633085731170, -0.967790222194993000, -0.967802808884779320, +-0.967815393155058490, -0.967827975005799310, -0.967840554436970040, -0.967853131448539570, -0.967865706040476170, -0.967878278212748520, -0.967890847965325100, -0.967903415298174700, +-0.967915980211265680, -0.967928542704566740, -0.967941102778046350, -0.967953660431673300, -0.967966215665416070, -0.967978768479243360, -0.967991318873123730, -0.968003866847025660, +-0.968016412400918070, -0.968028955534769310, -0.968041496248548290, -0.968054034542223500, -0.968066570415763610, -0.968079103869137310, -0.968091634902313200, -0.968104163515260070, +-0.968116689707946510, -0.968129213480341200, -0.968141734832412840, -0.968154253764130220, -0.968166770275461940, -0.968179284366376680, -0.968191796036843240, -0.968204305286830320, +-0.968216812116306610, -0.968229316525241020, -0.968241818513601920, -0.968254318081358420, -0.968266815228479020, -0.968279309954932720, -0.968291802260688010, -0.968304292145713900, +-0.968316779609978970, -0.968329264653452150, -0.968341747276102120, -0.968354227477897790, -0.968366705258807860, -0.968379180618801130, -0.968391653557846510, -0.968404124075912700, +-0.968416592172968600, -0.968429057848983030, -0.968441521103924790, -0.968453981937762780, -0.968466440350465810, -0.968478896342002790, -0.968491349912342430, -0.968503801061453730, +-0.968516249789305620, -0.968528696095866670, -0.968541139981106140, -0.968553581444992710, -0.968566020487495400, -0.968578457108583040, -0.968590891308224510, -0.968603323086388630, +-0.968615752443044540, -0.968628179378161150, -0.968640603891707250, -0.968653025983651770, -0.968665445653963840, -0.968677862902612150, -0.968690277729565950, -0.968702690134793930, +-0.968715100118265340, -0.968727507679948860, -0.968739912819813640, -0.968752315537828700, -0.968764715833962950, -0.968777113708185420, -0.968789509160465020, -0.968801902190771000, +-0.968814292799072050, -0.968826680985337530, -0.968839066749536130, -0.968851450091637200, -0.968863831011609560, -0.968876209509422440, -0.968888585585044760, -0.968900959238445660, +-0.968913330469594050, -0.968925699278459170, -0.968938065665010060, -0.968950429629215740, -0.968962791171045450, -0.968975150290468100, -0.968987506987452840, -0.968999861261968910, +-0.969012213113985220, -0.969024562543471020, -0.969036909550395560, -0.969049254134727640, -0.969061596296436730, -0.969073936035491750, -0.969086273351861930, -0.969098608245516410, +-0.969110940716424450, -0.969123270764554960, -0.969135598389877510, -0.969147923592360900, -0.969160246371974620, -0.969172566728687570, -0.969184884662469330, -0.969197200173288700, +-0.969209513261115040, -0.969221823925917710, -0.969234132167665740, -0.969246437986328590, -0.969258741381875180, -0.969271042354274970, -0.969283340903497100, -0.969295637029511050, +-0.969307930732285720, -0.969320222011790690, -0.969332510867994990, -0.969344797300868090, -0.969357081310379230, -0.969369362896497560, -0.969381642059192530, -0.969393918798433510, +-0.969406193114189520, -0.969418465006430140, -0.969430734475124510, -0.969443001520242210, -0.969455266141752260, -0.969467528339624240, -0.969479788113827400, -0.969492045464330990, +-0.969504300391104580, -0.969516552894117310, -0.969528802973338650, -0.969541050628738080, -0.969553295860284830, -0.969565538667948370, -0.969577779051698060, -0.969590017011503270, +-0.969602252547333450, -0.969614485659157980, -0.969626716346946420, -0.969638944610667910, -0.969651170450292140, -0.969663393865788370, -0.969675614857126170, -0.969687833424274890, +-0.969700049567204130, -0.969712263285883220, -0.969724474580281550, -0.969736683450368790, -0.969748889896114190, -0.969761093917487550, -0.969773295514458010, -0.969785494686995380, +-0.969797691435068890, -0.969809885758648240, -0.969822077657702790, -0.969834267132202220, -0.969846454182116010, -0.969858638807413630, -0.969870821008064650, -0.969883000784038660, +-0.969895178135305120, -0.969907353061833620, -0.969919525563593730, -0.969931695640555150, -0.969943863292687110, -0.969956028519959660, -0.969968191322342020, -0.969980351699803900, +-0.969992509652314870, -0.970004665179844630, -0.970016818282362750, -0.970028968959838700, -0.970041117212242290, -0.970053263039543090, -0.970065406441710800, -0.970077547418714880, +-0.970089685970525140, -0.970101822097111270, -0.970113955798442730, -0.970126087074489330, -0.970138215925220760, -0.970150342350606600, -0.970162466350616650, -0.970174587925220380, +-0.970186707074387810, -0.970198823798088420, -0.970210938096291890, -0.970223049968968130, -0.970235159416086730, -0.970247266437617380, -0.970259371033529880, -0.970271473203793920, +-0.970283572948379300, -0.970295670267255830, -0.970307765160393080, -0.970319857627760960, -0.970331947669329180, -0.970344035285067630, -0.970356120474945790, -0.970368203238933800, +-0.970380283577001230, -0.970392361489118120, -0.970404436975253910, -0.970416510035378650, -0.970428580669462140, -0.970440648877474170, -0.970452714659384650, -0.970464778015163290, +-0.970476838944779980, -0.970488897448204550, -0.970500953525406880, -0.970513007176356800, -0.970525058401024320, -0.970537107199379130, -0.970549153571391150, -0.970561197517030290, +-0.970573239036266470, -0.970585278129069470, -0.970597314795409340, -0.970609349035255970, -0.970621380848579180, -0.970633410235348880, -0.970645437195535090, -0.970657461729107720, +-0.970669483836036790, -0.970681503516292010, -0.970693520769843500, -0.970705535596661280, -0.970717547996715170, -0.970729557969975180, -0.970741565516411220, -0.970753570635993430, +-0.970765573328691730, -0.970777573594476140, -0.970789571433316460, -0.970801566845182930, -0.970813559830045470, -0.970825550387874210, -0.970837538518638970, -0.970849524222309970, +-0.970861507498857020, -0.970873488348250380, -0.970885466770460060, -0.970897442765455980, -0.970909416333208370, -0.970921387473687280, -0.970933356186862610, -0.970945322472704600, +-0.970957286331183280, -0.970969247762268670, -0.970981206765931030, -0.970993163342140360, -0.971005117490866710, -0.971017069212080310, -0.971029018505751300, -0.971040965371849700, +-0.971052909810345640, -0.971064851821209380, -0.971076791404410940, -0.971088728559920570, -0.971100663287708390, -0.971112595587744430, -0.971124525459999060, -0.971136452904442390, +-0.971148377921044580, -0.971160300509775860, -0.971172220670606380, -0.971184138403506260, -0.971196053708445860, -0.971207966585395430, -0.971219877034324890, -0.971231785055204800, +-0.971243690648005200, -0.971255593812696330, -0.971267494549248540, -0.971279392857631980, -0.971291288737816890, -0.971303182189773630, -0.971315073213472440, -0.971326961808883560, +-0.971338847975977250, -0.971350731714723860, -0.971362613025093640, -0.971374491907056830, -0.971386368360583790, -0.971398242385644870, -0.971410113982210440, -0.971421983150250520, +-0.971433849889735800, -0.971445714200636410, -0.971457576082922710, -0.971469435536565060, -0.971481292561533930, -0.971493147157799440, -0.971504999325332190, -0.971516849064102290, +-0.971528696374080350, -0.971540541255236700, -0.971552383707541710, -0.971564223730965740, -0.971576061325479130, -0.971587896491052480, -0.971599729227656030, -0.971611559535260240, +-0.971623387413835580, -0.971635212863352530, -0.971647035883781320, -0.971658856475092650, -0.971670674637256760, -0.971682490370244230, -0.971694303674025320, -0.971706114548570810, +-0.971717922993850960, -0.971729729009836340, -0.971741532596497310, -0.971753333753804570, -0.971765132481728470, -0.971776928780239470, -0.971788722649308160, -0.971800514088905110, +-0.971812303099000680, -0.971824089679565570, -0.971835873830570240, -0.971847655551985160, -0.971859434843781010, -0.971871211705928270, -0.971882986138397520, -0.971894758141159220, +-0.971906527714184070, -0.971918294857442520, -0.971930059570905390, -0.971941821854543030, -0.971953581708326130, -0.971965339132225160, -0.971977094126211030, -0.971988846690253980, +-0.972000596824324940, -0.972012344528394360, -0.972024089802433040, -0.972035832646411360, -0.972047573060300100, -0.972059311044069950, -0.972071046597691610, -0.972082779721135440, +-0.972094510414372560, -0.972106238677373220, -0.972117964510108350, -0.972129687912548610, -0.972141408884664600, -0.972153127426427120, -0.972164843537806740, -0.972176557218774270, +-0.972188268469300400, -0.972199977289355920, -0.972211683678911420, -0.972223387637937810, -0.972235089166405660, -0.972246788264285900, -0.972258484931548980, -0.972270179168166050, +-0.972281870974107450, -0.972293560349344330, -0.972305247293847260, -0.972316931807587160, -0.972328613890534600, -0.972340293542660610, -0.972351970763935760, -0.972363645554331080, +-0.972375317913817260, -0.972386987842365210, -0.972398655339945630, -0.972410320406529420, -0.972421983042087380, -0.972433643246590430, -0.972445301020009370, -0.972456956362314990, +-0.972468609273478330, -0.972480259753469970, -0.972491907802261140, -0.972503553419822420, -0.972515196606124950, -0.972526837361139320, -0.972538475684836760, -0.972550111577187960, +-0.972561745038163840, -0.972573376067735310, -0.972585004665873500, -0.972596630832549100, -0.972608254567733140, -0.972619875871396530, -0.972631494743510180, -0.972643111184045120, +-0.972654725192972250, -0.972666336770262710, -0.972677945915887190, -0.972689552629816820, -0.972701156912022640, -0.972712758762475540, -0.972724358181146440, -0.972735955168006590, +-0.972747549723026790, -0.972759141846178070, -0.972770731537431540, -0.972782318796758250, -0.972793903624129100, -0.972805486019515220, -0.972817065982887530, -0.972828643514217270, +-0.972840218613475360, -0.972851791280632930, -0.972863361515661110, -0.972874929318530700, -0.972886494689213070, -0.972898057627679220, -0.972909618133900200, -0.972921176207847130, +-0.972932731849491140, -0.972944285058803260, -0.972955835835754730, -0.972967384180316590, -0.972978930092459950, -0.972990473572156070, -0.973002014619375970, -0.973013553234090780, +-0.973025089416271750, -0.973036623165890010, -0.973048154482916710, -0.973059683367323070, -0.973071209819080130, -0.973082733838159240, -0.973094255424531430, -0.973105774578168050, +-0.973117291299040230, -0.973128805587119230, -0.973140317442376060, -0.973151826864782300, -0.973163333854308750, -0.973174838410927000, -0.973186340534608170, -0.973197840225323520, +-0.973209337483044170, -0.973220832307741480, -0.973232324699386700, -0.973243814657951180, -0.973255302183406170, -0.973266787275722800, -0.973278269934872430, -0.973289750160826530, +-0.973301227953556230, -0.973312703313032770, -0.973324176239227620, -0.973335646732111930, -0.973347114791657250, -0.973358580417834630, -0.973370043610615740, -0.973381504369971620, +-0.973392962695873830, -0.973404418588293520, -0.973415872047202260, -0.973427323072571180, -0.973438771664371980, -0.973450217822575680, -0.973461661547153970, -0.973473102838078090, +-0.973484541695319390, -0.973495978118849360, -0.973507412108639450, -0.973518843664661020, -0.973530272786885310, -0.973541699475284130, -0.973553123729828500, -0.973564545550490210, +-0.973575964937240410, -0.973587381890050900, -0.973598796408892800, -0.973610208493737690, -0.973621618144557170, -0.973633025361322570, -0.973644430144005260, -0.973655832492577030, +-0.973667232407009250, -0.973678629887273270, -0.973690024933340780, -0.973701417545183250, -0.973712807722772130, -0.973724195466079020, -0.973735580775075380, -0.973746963649732790, +-0.973758344090022820, -0.973769722095917060, -0.973781097667386850, -0.973792470804404010, -0.973803841506939990, -0.973815209774966270, -0.973826575608454650, -0.973837939007376470, +-0.973849299971703550, -0.973860658501407240, -0.973872014596459450, -0.973883368256831530, -0.973894719482495170, -0.973906068273422080, -0.973917414629583810, -0.973928758550951960, +-0.973940100037498200, -0.973951439089194240, -0.973962775706011750, -0.973974109887922210, -0.973985441634897420, -0.973996770946909060, -0.974008097823928720, -0.974019422265928190, +-0.974030744272879060, -0.974042063844753110, -0.974053380981521940, -0.974064695683157340, -0.974076007949631010, -0.974087317780914730, -0.974098625176980090, -0.974109930137798900, +-0.974121232663342830, -0.974132532753583800, -0.974143830408493280, -0.974155125628043290, -0.974166418412205530, -0.974177708760951670, -0.974188996674253520, -0.974200282152082870, +-0.974211565194411540, -0.974222845801211320, -0.974234123972453900, -0.974245399708111190, -0.974256673008155110, -0.974267943872557220, -0.974279212301289550, -0.974290478294323800, +-0.974301741851631880, -0.974313002973185570, -0.974324261658956800, -0.974335517908917260, -0.974346771723039070, -0.974358023101293820, -0.974369272043653640, -0.974380518550090220, +-0.974391762620575590, -0.974403004255081420, -0.974414243453579740, -0.974425480216042580, -0.974436714542441630, -0.974447946432748900, -0.974459175886936310, -0.974470402904975770, +-0.974481627486839310, -0.974492849632498710, -0.974504069341925900, -0.974515286615093120, -0.974526501451971950, -0.974537713852534630, -0.974548923816752950, -0.974560131344598960, +-0.974571336436044660, -0.974582539091062070, -0.974593739309623120, -0.974604937091699820, -0.974616132437264080, -0.974627325346288150, -0.974638515818743830, -0.974649703854603260, +-0.974660889453838440, -0.974672072616421300, -0.974683253342324090, -0.974694431631518700, -0.974705607483977170, -0.974716780899671730, -0.974727951878574310, -0.974739120420656910, +-0.974750286525891800, -0.974761450194250980, -0.974772611425706590, -0.974783770220230550, -0.974794926577795100, -0.974806080498372360, -0.974817231981934480, -0.974828381028453480, +-0.974839527637901490, -0.974850671810250760, -0.974861813545473300, -0.974872952843541250, -0.974884089704426860, -0.974895224128102370, -0.974906356114539690, -0.974917485663711170, +-0.974928612775588840, -0.974939737450145060, -0.974950859687351960, -0.974961979487181660, -0.974973096849606420, -0.974984211774598490, -0.974995324262129870, -0.975006434312173150, +-0.975017541924700250, -0.975028647099683510, -0.975039749837095070, -0.975050850136907400, -0.975061947999092520, -0.975073043423622780, -0.975084136410470430, -0.975095226959607710, +-0.975106315071006980, -0.975117400744640370, -0.975128483980480350, -0.975139564778499170, -0.975150643138668950, -0.975161719060962160, -0.975172792545351160, -0.975183863591808090, +-0.975194932200305400, -0.975205998370815340, -0.975217062103310270, -0.975228123397762660, -0.975239182254144630, -0.975250238672428660, -0.975261292652587100, -0.975272344194592300, +-0.975283393298416730, -0.975294439964032530, -0.975305484191412390, -0.975316525980528430, -0.975327565331353230, -0.975338602243859040, -0.975349636718018330, -0.975360668753803670, +-0.975371698351187200, -0.975382725510141600, -0.975393750230639010, -0.975404772512652230, -0.975415792356153390, -0.975426809761115180, -0.975437824727509840, -0.975448837255309950, +-0.975459847344487980, -0.975470854995016510, -0.975481860206867780, -0.975492862980014470, -0.975503863314428950, -0.975514861210083790, -0.975525856666951460, -0.975536849685004540, +-0.975547840264215370, -0.975558828404556650, -0.975569814106000970, -0.975580797368520660, -0.975591778192088420, -0.975602756576676610, -0.975613732522258030, -0.975624706028805130, +-0.975635677096290400, -0.975646645724686510, -0.975657611913965940, -0.975668575664101370, -0.975679536975065380, -0.975690495846830540, -0.975701452279369550, -0.975712406272654760, +-0.975723357826659090, -0.975734306941354990, -0.975745253616715160, -0.975756197852712060, -0.975767139649318600, -0.975778079006507260, -0.975789015924250710, -0.975799950402521650, +-0.975810882441292660, -0.975821812040536530, -0.975832739200225840, -0.975843663920333280, -0.975854586200831540, -0.975865506041693420, -0.975876423442891380, -0.975887338404398450, +-0.975898250926187090, -0.975909161008230220, -0.975920068650500290, -0.975930973852970230, -0.975941876615612710, -0.975952776938400660, -0.975963674821306530, -0.975974570264303230, +-0.975985463267363460, -0.975996353830460130, -0.976007241953565920, -0.976018127636653520, -0.976029010879695850, -0.976039891682665580, -0.976050770045535750, -0.976061645968278820, +-0.976072519450867810, -0.976083390493275530, -0.976094259095474870, -0.976105125257438420, -0.976115988979139200, -0.976126850260550020, -0.976137709101643770, -0.976148565502393150, +-0.976159419462771180, -0.976170270982750550, -0.976181120062304400, -0.976191966701405400, -0.976202810900026470, -0.976213652658140530, -0.976224491975720370, -0.976235328852739110, +-0.976246163289169470, -0.976256995284984440, -0.976267824840156840, -0.976278651954659790, -0.976289476628465990, -0.976300298861548680, -0.976311118653880430, -0.976321936005434490, +-0.976332750916183660, -0.976343563386101070, -0.976354373415159400, -0.976365181003331920, -0.976375986150591400, -0.976386788856910990, -0.976397589122263600, -0.976408386946622240, +-0.976419182329959830, -0.976429975272249510, -0.976440765773464390, -0.976451553833577180, -0.976462339452561110, -0.976473122630389210, -0.976483903367034610, -0.976494681662470110, +-0.976505457516668950, -0.976516230929604160, -0.976527001901248750, -0.976537770431575860, -0.976548536520558620, -0.976559300168169940, -0.976570061374383070, -0.976580820139171020, +-0.976591576462506940, -0.976602330344363830, -0.976613081784715060, -0.976623830783533430, -0.976634577340792290, -0.976645321456464770, -0.976656063130523780, -0.976666802362942790, +-0.976677539153694710, -0.976688273502752890, -0.976699005410090250, -0.976709734875680140, -0.976720461899495680, -0.976731186481510140, -0.976741908621696520, -0.976752628320028290, +-0.976763345576478370, -0.976774060391020100, -0.976784772763626740, -0.976795482694271410, -0.976806190182927250, -0.976816895229567830, -0.976827597834166060, -0.976838297996695300, +-0.976848995717128800, -0.976859690995439790, -0.976870383831601630, -0.976881074225587450, -0.976891762177370620, -0.976902447686924250, -0.976913130754221930, -0.976923811379236670, +-0.976934489561941950, -0.976945165302311010, -0.976955838600317210, -0.976966509455933660, -0.976977177869133960, -0.976987843839891230, -0.976998507368178950, -0.977009168453970340, +-0.977019827097238890, -0.977030483297957830, -0.977041137056100630, -0.977051788371640530, -0.977062437244551000, -0.977073083674805280, -0.977083727662376940, -0.977094369207239240, +-0.977105008309365640, -0.977115644968729490, -0.977126279185304260, -0.977136910959063300, -0.977147540289980080, -0.977158167178028060, -0.977168791623180490, -0.977179413625411050, +-0.977190033184693110, -0.977200650301000010, -0.977211264974305330, -0.977221877204582420, -0.977232486991804870, -0.977243094335946140, -0.977253699236979580, -0.977264301694878880, +-0.977274901709617280, -0.977285499281168590, -0.977296094409506040, -0.977306687094603330, -0.977317277336433810, -0.977327865134971160, -0.977338450490188860, -0.977349033402060360, +-0.977359613870559360, -0.977370191895659320, -0.977380767477333710, -0.977391340615556330, -0.977401911310300520, -0.977412479561539870, -0.977423045369248070, -0.977433608733398680, +-0.977444169653965300, -0.977454728130921380, -0.977465284164240720, -0.977475837753896790, -0.977486388899863390, -0.977496937602113980, -0.977507483860622140, -0.977518027675361670, +-0.977528569046306140, -0.977539107973429130, -0.977549644456704340, -0.977560178496105550, -0.977570710091606120, -0.977581239243180080, -0.977591765950800880, -0.977602290214442340, +-0.977612812034078020, -0.977623331409681610, -0.977633848341226910, -0.977644362828687610, -0.977654874872037390, -0.977665384471250070, -0.977675891626299200, -0.977686396337158590, +-0.977696898603802040, -0.977707398426203240, -0.977717895804335880, -0.977728390738173860, -0.977738883227690870, -0.977749373272860600, -0.977759860873656960, -0.977770346030053530, +-0.977780828742024430, -0.977791309009543140, -0.977801786832583560, -0.977812262211119610, -0.977822735145124970, -0.977833205634573430, -0.977843673679438920, -0.977854139279695220, +-0.977864602435316250, -0.977875063146275700, -0.977885521412547480, -0.977895977234105480, -0.977906430610923530, -0.977916881542975510, -0.977927330030235350, -0.977937776072676730, +-0.977948219670273790, -0.977958660823000200, -0.977969099530830000, -0.977979535793737090, -0.977989969611695380, -0.978000400984678660, -0.978010829912660860, -0.978021256395616210, +-0.978031680433518180, -0.978042102026341120, -0.978052521174058720, -0.978062937876645110, -0.978073352134074090, -0.978083763946319680, -0.978094173313355800, -0.978104580235156670, +-0.978114984711695890, -0.978125386742947800, -0.978135786328886090, -0.978146183469485120, -0.978156578164718570, -0.978166970414560580, -0.978177360218985160, -0.978187747577966340, +-0.978198132491478130, -0.978208514959494680, -0.978218894981989880, -0.978229272558937770, -0.978239647690312570, -0.978250020376088210, -0.978260390616238930, -0.978270758410738520, +-0.978281123759561220, -0.978291486662681180, -0.978301847120072400, -0.978312205131709020, -0.978322560697565070, -0.978332913817614780, -0.978343264491832180, -0.978353612720191500, +-0.978363958502666660, -0.978374301839232020, -0.978384642729861590, -0.978394981174529500, -0.978405317173210000, -0.978415650725877220, -0.978425981832505290, -0.978436310493068450, +-0.978446636707540840, -0.978456960475896590, -0.978467281798109930, -0.978477600674155120, -0.978487917104006180, -0.978498231087637560, -0.978508542625023400, -0.978518851716137840, +-0.978529158360955110, -0.978539462559449570, -0.978549764311595240, -0.978560063617366580, -0.978570360476737840, -0.978580654889683150, -0.978590946856176760, -0.978601236376193010, +-0.978611523449706260, -0.978621808076690640, -0.978632090257120500, -0.978642369990970100, -0.978652647278213880, -0.978662922118825880, -0.978673194512780680, -0.978683464460052500, +-0.978693731960615710, -0.978703997014444440, -0.978714259621513260, -0.978724519781796420, -0.978734777495268380, -0.978745032761903280, -0.978755285581675570, -0.978765535954559730, +-0.978775783880530100, -0.978786029359560940, -0.978796272391626700, -0.978806512976701740, -0.978816751114760520, -0.978826986805777510, -0.978837220049726950, -0.978847450846583310, +-0.978857679196321160, -0.978867905098914750, -0.978878128554338530, -0.978888349562566980, -0.978898568123574670, -0.978908784237335850, -0.978918997903825080, -0.978929209123016840, +-0.978939417894885590, -0.978949624219405790, -0.978959828096551910, -0.978970029526298520, -0.978980228508619990, -0.978990425043490880, -0.979000619130885760, -0.979010810770779010, +-0.979020999963145290, -0.979031186707959080, -0.979041371005194950, -0.979051552854827260, -0.979061732256830800, -0.979071909211179920, -0.979082083717849330, -0.979092255776813580, +-0.979102425388047150, -0.979112592551524610, -0.979122757267220640, -0.979132919535109720, -0.979143079355166530, -0.979153236727365650, -0.979163391651681760, -0.979173544128089320, +-0.979183694156562920, -0.979193841737077460, -0.979203986869607300, -0.979214129554127120, -0.979224269790611720, -0.979234407579035570, -0.979244542919373460, -0.979254675811599970, +-0.979264806255689790, -0.979274934251617600, -0.979285059799358090, -0.979295182898885950, -0.979305303550175750, -0.979315421753202410, -0.979325537507940380, -0.979335650814364690, +-0.979345761672449690, -0.979355870082170400, -0.979365976043501400, -0.979376079556417480, -0.979386180620893440, -0.979396279236903760, -0.979406375404423550, -0.979416469123427280, +-0.979426560393889870, -0.979436649215786100, -0.979446735589090680, -0.979456819513778500, -0.979466900989824140, -0.979476980017202630, -0.979487056595888640, -0.979497130725856980, +-0.979507202407082560, -0.979517271639540050, -0.979527338423204390, -0.979537402758050350, -0.979547464644052850, -0.979557524081186680, -0.979567581069426760, -0.979577635608747780, +-0.979587687699124740, -0.979597737340532570, -0.979607784532945950, -0.979617829276340000, -0.979627871570689310, -0.979637911415969010, -0.979647948812154000, -0.979657983759219090, +-0.979668016257139170, -0.979678046305889170, -0.979688073905444100, -0.979698099055778870, -0.979708121756868390, -0.979718142008687680, -0.979728159811211530, -0.979738175164414970, +-0.979748188068273020, -0.979758198522760580, -0.979768206527852570, -0.979778212083524110, -0.979788215189750120, -0.979798215846505620, -0.979808214053765610, -0.979818209811504910, +-0.979828203119698870, -0.979838193978322170, -0.979848182387350050, -0.979858168346757540, -0.979868151856519540, -0.979878132916611080, -0.979888111527007500, -0.979898087687683490, +-0.979908061398614310, -0.979918032659774840, -0.979928001471140450, -0.979937967832686050, -0.979947931744386660, -0.979957893206217510, -0.979967852218153520, -0.979977808780170050, +-0.979987762892241990, -0.979997714554344480, -0.980007663766452760, -0.980017610528541860, -0.980027554840586900, -0.980037496702563020, -0.980047436114445450, -0.980057373076209330, +-0.980067307587829670, -0.980077239649281840, -0.980087169260540850, -0.980097096421581940, -0.980107021132380350, -0.980116943392911220, -0.980126863203149570, -0.980136780563070960, +-0.980146695472650320, -0.980156607931862880, -0.980166517940683990, -0.980176425499088790, -0.980186330607052510, -0.980196233264550410, -0.980206133471557830, -0.980216031228049790, +-0.980225926534001760, -0.980235819389388750, -0.980245709794186350, -0.980255597748369680, -0.980265483251913980, -0.980275366304794500, -0.980285246906986710, -0.980295125058465720, +-0.980305000759207010, -0.980314874009185710, -0.980324744808377280, -0.980334613156756960, -0.980344479054300110, -0.980354342500982080, -0.980364203496778220, -0.980374062041663770, +-0.980383918135614210, -0.980393771778604870, -0.980403622970611120, -0.980413471711608200, -0.980423318001571680, -0.980433161840476910, -0.980443003228299140, -0.980452842165013940, +-0.980462678650596660, -0.980472512685022670, -0.980482344268267300, -0.980492173400306140, -0.980502000081114540, -0.980511824310667970, -0.980521646088941770, -0.980531465415911520, +-0.980541282291552570, -0.980551096715840400, -0.980560908688750570, -0.980570718210258430, -0.980580525280339450, -0.980590329898969220, -0.980600132066123060, -0.980609931781776690, +-0.980619729045905440, -0.980629523858484900, -0.980639316219490520, -0.980649106128897770, -0.980658893586682350, -0.980668678592819700, -0.980678461147285410, -0.980688241250054830, +-0.980698018901103750, -0.980707794100407540, -0.980717566847941870, -0.980727337143682320, -0.980737104987604470, -0.980746870379683780, -0.980756633319895930, -0.980766393808216510, +-0.980776151844621080, -0.980785907429085340, -0.980795660561584740, -0.980805411242095080, -0.980815159470591840, -0.980824905247050680, -0.980834648571447310, -0.980844389443757290, +-0.980854127863956200, -0.980863863832019960, -0.980873597347924010, -0.980883328411644050, -0.980893057023155770, -0.980902783182434850, -0.980912506889456860, -0.980922228144197830, +-0.980931946946632990, -0.980941663296738490, -0.980951377194489660, -0.980961088639862530, -0.980970797632832570, -0.980980504173375790, -0.980990208261467540, -0.980999909897083850, +-0.981009609080200410, -0.981019305810793000, -0.981029000088837200, -0.981038691914308920, -0.981048381287183970, -0.981058068207438130, -0.981067752675046980, -0.981077434689986540, +-0.981087114252232500, -0.981096791361760650, -0.981106466018546790, -0.981116138222566820, -0.981125807973796450, -0.981135475272211570, -0.981145140117788080, -0.981154802510501690, +-0.981164462450328290, -0.981174119937243790, -0.981183774971223890, -0.981193427552244590, -0.981203077680281700, -0.981212725355311230, -0.981222370577308880, -0.981232013346250540, +-0.981241653662112250, -0.981251291524869780, -0.981260926934499070, -0.981270559890976110, -0.981280190394276720, -0.981289818444376790, -0.981299444041252360, -0.981309067184879420, +-0.981318687875233690, -0.981328306112291270, -0.981337921896028090, -0.981347535226420040, -0.981357146103443270, -0.981366754527073560, -0.981376360497287050, -0.981385964014059530, +-0.981395565077367140, -0.981405163687185890, -0.981414759843491690, -0.981424353546260560, -0.981433944795468530, -0.981443533591091710, -0.981453119933106020, -0.981462703821487590, +-0.981472285256212330, -0.981481864237256360, -0.981491440764595710, -0.981501014838206510, -0.981510586458064770, -0.981520155624146520, -0.981529722336427990, -0.981539286594884990, +-0.981548848399493970, -0.981558407750230730, -0.981567964647071410, -0.981577519089992250, -0.981587071078969250, -0.981596620613978570, -0.981606167694996420, -0.981615712321998850, +-0.981625254494961850, -0.981634794213861910, -0.981644331478674800, -0.981653866289377010, -0.981663398645944430, -0.981672928548353420, -0.981682455996580110, -0.981691980990600620, +-0.981701503530391210, -0.981711023615927990, -0.981720541247187330, -0.981730056424145240, -0.981739569146777960, -0.981749079415061840, -0.981758587228973020, -0.981768092588487630, +-0.981777595493582120, -0.981787095944232520, -0.981796593940415300, -0.981806089482106460, -0.981815582569282470, -0.981825073201919580, -0.981834561379993920, -0.981844047103481940, +-0.981853530372359780, -0.981863011186603800, -0.981872489546190330, -0.981881965451095520, -0.981891438901295930, -0.981900909896767700, -0.981910378437487190, -0.981919844523430730, +-0.981929308154574690, -0.981938769330895410, -0.981948228052369140, -0.981957684318972230, -0.981967138130681260, -0.981976589487472350, -0.981986038389321970, -0.981995484836206580, +-0.982004928828102420, -0.982014370364985960, -0.982023809446833430, -0.982033246073621520, -0.982042680245326480, -0.982052111961924770, -0.982061541223392730, -0.982070968029706840, +-0.982080392380843550, -0.982089814276779330, -0.982099233717490420, -0.982108650702953610, -0.982118065233145040, -0.982127477308041400, -0.982136886927619020, -0.982146294091854390, +-0.982155698800724060, -0.982165101054204510, -0.982174500852272200, -0.982183898194903590, -0.982193293082075260, -0.982202685513763660, -0.982212075489945490, -0.982221463010596980, +-0.982230848075694830, -0.982240230685215600, -0.982249610839135870, -0.982258988537431990, -0.982268363780080640, -0.982277736567058410, -0.982287106898341870, -0.982296474773907580, +-0.982305840193732020, -0.982315203157791970, -0.982324563666063800, -0.982333921718524290, -0.982343277315149920, -0.982352630455917470, -0.982361981140803310, -0.982371329369784330, +-0.982380675142836890, -0.982390018459937900, -0.982399359321063700, -0.982408697726191220, -0.982418033675297010, -0.982427367168357660, -0.982436698205349850, -0.982446026786250370, +-0.982455352911035810, -0.982464676579682950, -0.982473997792168260, -0.982483316548468650, -0.982492632848560700, -0.982501946692421190, -0.982511258080026820, -0.982520567011354370, +-0.982529873486380430, -0.982539177505081800, -0.982548479067435250, -0.982557778173417500, -0.982567074823005320, -0.982576369016175400, -0.982585660752904650, -0.982594950033169660, +-0.982604236856947310, -0.982613521224214410, -0.982622803134947650, -0.982632082589123930, -0.982641359586719940, -0.982650634127712590, -0.982659906212078770, -0.982669175839794960, +-0.982678443010838400, -0.982687707725185660, -0.982696969982813640, -0.982706229783699260, -0.982715487127819200, -0.982724742015150590, -0.982733994445669890, -0.982743244419354460, +-0.982752491936180750, -0.982761736996125790, -0.982770979599166590, -0.982780219745279850, -0.982789457434442680, -0.982798692666631780, -0.982807925441824160, -0.982817155759996730, +-0.982826383621126400, -0.982835609025190180, -0.982844831972164880, -0.982854052462027510, -0.982863270494754970, -0.982872486070324290, -0.982881699188712380, -0.982890909849896240, +-0.982900118053852800, -0.982909323800559060, -0.982918527089992170, -0.982927727922128790, -0.982936926296946070, -0.982946122214421130, -0.982955315674530870, -0.982964506677252330, +-0.982973695222562500, -0.982982881310438430, -0.982992064940857110, -0.983001246113795690, -0.983010424829231180, -0.983019601087140480, -0.983028774887500960, -0.983037946230289390, +-0.983047115115482930, -0.983056281543058690, -0.983065445512993800, -0.983074607025265390, -0.983083766079850260, -0.983092922676725880, -0.983102076815869030, -0.983111228497257180, +-0.983120377720867130, -0.983129524486676120, -0.983138668794661390, -0.983147810644799950, -0.983156950037068930, -0.983166086971445590, -0.983175221447907030, -0.983184353466430410, +-0.983193483026992940, -0.983202610129571770, -0.983211734774144030, -0.983220856960686950, -0.983229976689177660, -0.983239093959593520, -0.983248208771911660, -0.983257321126109310, +-0.983266431022163600, -0.983275538460051780, -0.983284643439751190, -0.983293745961238860, -0.983302846024492360, -0.983311943629488590, -0.983321038776205030, -0.983330131464618780, +-0.983339221694707330, -0.983348309466447800, -0.983357394779817430, -0.983366477634793680, -0.983375558031353680, -0.983384635969474670, -0.983393711449134230, -0.983402784470309490, +-0.983411855032977790, -0.983420923137116380, -0.983429988782702710, -0.983439051969714040, -0.983448112698127820, -0.983457170967921290, -0.983466226779071690, -0.983475280131556720, +-0.983484331025353490, -0.983493379460439350, -0.983502425436791780, -0.983511468954388230, -0.983520510013205950, -0.983529548613222500, -0.983538584754415020, -0.983547618436761200, +-0.983556649660238260, -0.983565678424823790, -0.983574704730495020, -0.983583728577229530, -0.983592749965004680, -0.983601768893798020, -0.983610785363586930, -0.983619799374348850, +-0.983628810926061250, -0.983637820018701700, -0.983646826652247560, -0.983655830826676290, -0.983664832541965460, -0.983673831798092650, -0.983682828595035200, -0.983691822932770690, +-0.983700814811276580, -0.983709804230530450, -0.983718791190509870, -0.983727775691192190, -0.983736757732555200, -0.983745737314576260, -0.983754714437232950, -0.983763689100502940, +-0.983772661304363690, -0.983781631048792680, -0.983790598333767700, -0.983799563159266200, -0.983808525525265760, -0.983817485431744080, -0.983826442878678600, -0.983835397866047010, +-0.983844350393827010, -0.983853300461996040, -0.983862248070531910, -0.983871193219412080, -0.983880135908614340, -0.983889076138116270, -0.983898013907895440, -0.983906949217929540, +-0.983915882068196360, -0.983924812458673470, -0.983933740389338450, -0.983942665860169210, -0.983951588871143200, -0.983960509422238340, -0.983969427513432080, -0.983978343144702340, +-0.983987256316026790, -0.983996167027382910, -0.984005075278748810, -0.984013981070101850, -0.984022884401420050, -0.984031785272680980, -0.984040683683862550, -0.984049579634942330, +-0.984058473125898230, -0.984067364156707810, -0.984076252727349110, -0.984085138837799690, -0.984094022488037460, -0.984102903678040210, -0.984111782407785630, -0.984120658677251630, +-0.984129532486415990, -0.984138403835256530, -0.984147272723751020, -0.984156139151877380, -0.984165003119613410, -0.984173864626936900, -0.984182723673825640, -0.984191580260257660, +-0.984200434386210740, -0.984209286051662690, -0.984218135256591520, -0.984226982000974910, -0.984235826284790890, -0.984244668108017250, -0.984253507470632010, -0.984262344372612950, +-0.984271178813938110, -0.984280010794585270, -0.984288840314532340, -0.984297667373757460, -0.984306491972238300, -0.984315314109952880, -0.984324133786879220, -0.984332951002995230, +-0.984341765758278920, -0.984350578052708090, -0.984359387886260980, -0.984368195258915280, -0.984377000170649110, -0.984385802621440380, -0.984394602611267210, -0.984403400140107520, +-0.984412195207939320, -0.984420987814740630, -0.984429777960489470, -0.984438565645163850, -0.984447350868741910, -0.984456133631201550, -0.984464913932520780, -0.984473691772677850, +-0.984482467151650550, -0.984491240069417240, -0.984500010525955700, -0.984508778521244190, -0.984517544055260710, -0.984526307127983390, -0.984535067739390370, -0.984543825889459550, +-0.984552581578169270, -0.984561334805497460, -0.984570085571422340, -0.984578833875922040, -0.984587579718974590, -0.984596323100558220, -0.984605064020651070, -0.984613802479231250, +-0.984622538476276900, -0.984631272011766260, -0.984640003085677340, -0.984648731697988500, -0.984657457848677750, -0.984666181537723450, -0.984674902765103720, -0.984683621530796580, +-0.984692337834780610, -0.984701051677033590, -0.984709763057533990, -0.984718471976260060, -0.984727178433189910, -0.984735882428301790, -0.984744583961573940, -0.984753283032984710, +-0.984761979642512220, -0.984770673790134720, -0.984779365475830670, -0.984788054699578090, -0.984796741461355540, -0.984805425761140940, -0.984814107598912860, -0.984822786974649530, +-0.984831463888329210, -0.984840138339930230, -0.984848810329430950, -0.984857479856809600, -0.984866146922044550, -0.984874811525114140, -0.984883473665996710, -0.984892133344670630, +-0.984900790561114130, -0.984909445315305780, -0.984918097607223710, -0.984926747436846380, -0.984935394804152260, -0.984944039709119590, -0.984952682151726820, -0.984961322131952420, +-0.984969959649774630, -0.984978594705172020, -0.984987227298122820, -0.984995857428605740, -0.985004485096598770, -0.985013110302080830, -0.985021733045029930, -0.985030353325424770, +-0.985038971143243790, -0.985047586498465240, -0.985056199391067810, -0.985064809821029840, -0.985073417788329910, -0.985082023292946360, -0.985090626334857890, -0.985099226914042720, +-0.985107825030479560, -0.985116420684146730, -0.985125013875022940, -0.985133604603086630, -0.985142192868316280, -0.985150778670690450, -0.985159362010187610, -0.985167942886786440, +-0.985176521300465400, -0.985185097251203070, -0.985193670738978010, -0.985202241763768690, -0.985210810325553910, -0.985219376424312010, -0.985227940060021680, -0.985236501232661490, +-0.985245059942210010, -0.985253616188645930, -0.985262169971947820, -0.985270721292094250, -0.985279270149063910, -0.985287816542835370, -0.985296360473387310, -0.985304901940698310, +-0.985313440944747040, -0.985321977485512310, -0.985330511562972470, -0.985339043177106520, -0.985347572327892830, -0.985356099015310180, -0.985364623239337380, -0.985373144999952990, +-0.985381664297135810, -0.985390181130864300, -0.985398695501117470, -0.985407207407873910, -0.985415716851112290, -0.985424223830811300, -0.985432728346949840, -0.985441230399506600, +-0.985449729988460250, -0.985458227113789500, -0.985466721775473230, -0.985475213973490140, -0.985483703707819130, -0.985492190978438760, -0.985500675785327960, -0.985509158128465400, +-0.985517638007829990, -0.985526115423400410, -0.985534590375155670, -0.985543062863074360, -0.985551532887135480, -0.985560000447317730, -0.985568465543599890, -0.985576928175960990, +-0.985585388344379810, -0.985593846048835040, -0.985602301289305700, -0.985610754065770590, -0.985619204378208600, -0.985627652226598650, -0.985636097610919530, -0.985644540531150250, +-0.985652980987269500, -0.985661418979256410, -0.985669854507089660, -0.985678287570748380, -0.985686718170211250, -0.985695146305457400, -0.985703571976465630, -0.985711995183215060, +-0.985720415925684380, -0.985728834203852710, -0.985737250017698960, -0.985745663367202150, -0.985754074252341070, -0.985762482673094850, -0.985770888629442400, -0.985779292121362730, +-0.985787693148834850, -0.985796091711837800, -0.985804487810350460, -0.985812881444351860, -0.985821272613821130, -0.985829661318737170, -0.985838047559079000, -0.985846431334825860, +-0.985854812645956540, -0.985863191492450160, -0.985871567874285870, -0.985879941791442670, -0.985888313243899580, -0.985896682231635730, -0.985905048754630140, -0.985913412812862040, +-0.985921774406310240, -0.985930133534954070, -0.985938490198772670, -0.985946844397744940, -0.985955196131850120, -0.985963545401067230, -0.985971892205375620, -0.985980236544754200, +-0.985988578419182190, -0.985996917828638740, -0.986005254773102970, -0.986013589252554110, -0.986021921266971300, -0.986030250816333660, -0.986038577900620330, -0.986046902519810640, +-0.986055224673883620, -0.986063544362818620, -0.986071861586594770, -0.986080176345191180, -0.986088488638587220, -0.986096798466762010, -0.986105105829694790, -0.986113410727364800, +-0.986121713159751280, -0.986130013126833570, -0.986138310628590700, -0.986146605665002120, -0.986154898236047070, -0.986163188341704690, -0.986171475981954430, -0.986179761156775300, +-0.986188043866147000, -0.986196324110048430, -0.986204601888459150, -0.986212877201358310, -0.986221150048725240, -0.986229420430539410, -0.986237688346779940, -0.986245953797426300, +-0.986254216782457730, -0.986262477301853570, -0.986270735355593290, -0.986278990943656230, -0.986287244066021530, -0.986295494722668860, -0.986303742913577360, -0.986311988638726600, +-0.986320231898095810, -0.986328472691664460, -0.986336711019411890, -0.986344946881317690, -0.986353180277360960, -0.986361411207521300, -0.986369639671778150, -0.986377865670110880, +-0.986386089202498930, -0.986394310268921880, -0.986402528869358970, -0.986410745003789670, -0.986418958672193540, -0.986427169874550040, -0.986435378610838630, -0.986443584881038780, +-0.986451788685129950, -0.986459990023091590, -0.986468188894903400, -0.986476385300544600, -0.986484579239994890, -0.986492770713233710, -0.986500959720240660, -0.986509146260995170, +-0.986517330335476840, -0.986525511943665110, -0.986533691085539680, -0.986541867761079990, -0.986550041970265750, -0.986558213713076280, -0.986566382989491290, -0.986574549799490330, +-0.986582714143052990, -0.986590876020158940, -0.986599035430787640, -0.986607192374918780, -0.986615346852531830, -0.986623498863606670, -0.986631648408122670, -0.986639795486059620, +-0.986647940097396980, -0.986656082242114540, -0.986664221920191880, -0.986672359131608670, -0.986680493876344600, -0.986688626154379360, -0.986696755965692400, -0.986704883310263630, +-0.986713008188072620, -0.986721130599099160, -0.986729250543322830, -0.986737368020723320, -0.986745483031280510, -0.986753595574973890, -0.986761705651783340, -0.986769813261688440, +-0.986777918404669110, -0.986786021080704900, -0.986794121289775730, -0.986802219031861160, -0.986810314306941220, -0.986818407114995240, -0.986826497456003480, -0.986834585329945280, +-0.986842670736800760, -0.986850753676549510, -0.986858834149171420, -0.986866912154646170, -0.986874987692953680, -0.986883060764073620, -0.986891131367986010, -0.986899199504670640, +-0.986907265174107210, -0.986915328376275600, -0.986923389111155620, -0.986931447378727290, -0.986939503178970170, -0.986947556511864500, -0.986955607377389740, -0.986963655775526140, +-0.986971701706253260, -0.986979745169551230, -0.986987786165399730, -0.986995824693778890, -0.987003860754668390, -0.987011894348048260, -0.987019925473898390, -0.987027954132198790, +-0.987035980322929160, -0.987044004046069730, -0.987052025301600190, -0.987060044089500650, -0.987068060409750920, -0.987076074262331130, -0.987084085647221050, -0.987092094564400830, +-0.987100101013850370, -0.987108104995549680, -0.987116106509478670, -0.987124105555617360, -0.987132102133945870, -0.987140096244444100, -0.987148087887092180, -0.987156077061869920, +-0.987164063768757540, -0.987172048007734950, -0.987180029778782280, -0.987188009081879430, -0.987195985917006640, -0.987203960284143920, -0.987211932183271300, -0.987219901614368790, +-0.987227868577416510, -0.987235833072394600, -0.987243795099283170, -0.987251754658062140, -0.987259711748711740, -0.987267666371212100, -0.987275618525543350, -0.987283568211685500, +-0.987291515429618680, -0.987299460179323130, -0.987307402460778860, -0.987315342273966220, -0.987323279618865120, -0.987331214495455800, -0.987339146903718490, -0.987347076843633320, +-0.987355004315180420, -0.987362929318340130, -0.987370851853092370, -0.987378771919417590, -0.987386689517295800, -0.987394604646707360, -0.987402517307632400, -0.987410427500051040, +-0.987418335223943730, -0.987426240479290510, -0.987434143266071710, -0.987442043584267570, -0.987449941433858340, -0.987457836814824130, -0.987465729727145520, -0.987473620170802420, +-0.987481508145775400, -0.987489393652044580, -0.987497276689590200, -0.987505157258392720, -0.987513035358432270, -0.987520910989689300, -0.987528784152143960, -0.987536654845776800, +-0.987544523070567840, -0.987552388826497650, -0.987560252113546590, -0.987568112931694770, -0.987575971280922670, -0.987583827161210740, -0.987591680572539100, -0.987599531514888330, +-0.987607379988238780, -0.987615225992570790, -0.987623069527864610, -0.987630910594100910, -0.987638749191259820, -0.987646585319321920, -0.987654418978267450, -0.987662250168077070, +-0.987670078888730930, -0.987677905140209700, -0.987685728922493730, -0.987693550235563380, -0.987701369079399210, -0.987709185453981560, -0.987716999359290910, -0.987724810795307830, +-0.987732619762012650, -0.987740426259385960, -0.987748230287408320, -0.987756031846059980, -0.987763830935321610, -0.987771627555173560, -0.987779421705596520, -0.987787213386570940, +-0.987795002598077290, -0.987802789340096240, -0.987810573612608160, -0.987818355415593600, -0.987826134749033140, -0.987833911612907340, -0.987841686007196800, -0.987849457931882060, +-0.987857227386943700, -0.987864994372362190, -0.987872758888118210, -0.987880520934192430, -0.987888280510565210, -0.987896037617217450, -0.987903792254129390, -0.987911544421282040, +-0.987919294118655760, -0.987927041346231220, -0.987934786103989100, -0.987942528391909990, -0.987950268209974560, -0.987958005558163490, -0.987965740436457350, -0.987973472844836940, +-0.987981202783282830, -0.987988930251775700, -0.987996655250296230, -0.988004377778825100, -0.988012097837343120, -0.988019815425830840, -0.988027530544269060, -0.988035243192638360, +-0.988042953370919630, -0.988050661079093450, -0.988058366317140720, -0.988066069085042020, -0.988073769382778130, -0.988081467210329740, -0.988089162567677870, -0.988096855454802970, +-0.988104545871685950, -0.988112233818307590, -0.988119919294648600, -0.988127602300689860, -0.988135282836412050, -0.988142960901796100, -0.988150636496822780, -0.988158309621472770, +-0.988165980275727110, -0.988173648459566350, -0.988181314172971610, -0.988188977415923490, -0.988196638188402980, -0.988204296490390880, -0.988211952321867980, -0.988219605682815190, +-0.988227256573213420, -0.988234904993043560, -0.988242550942286300, -0.988250194420922770, -0.988257835428933750, -0.988265473966300160, -0.988273110033002890, -0.988280743629022850, +-0.988288374754340840, -0.988296003408937970, -0.988303629592795050, -0.988311253305893200, -0.988318874548213100, -0.988326493319735770, -0.988334109620442320, -0.988341723450313570, +-0.988349334809330400, -0.988356943697473960, -0.988364550114725240, -0.988372154061065040, -0.988379755536474500, -0.988387354540934630, -0.988394951074426320, -0.988402545136930600, +-0.988410136728428590, -0.988417725848901200, -0.988425312498329430, -0.988432896676694430, -0.988440478383977190, -0.988448057620158750, -0.988455634385220220, -0.988463208679142610, +-0.988470780501906840, -0.988478349853494250, -0.988485916733885750, -0.988493481143062460, -0.988501043081005500, -0.988508602547695900, -0.988516159543114780, -0.988523714067243260, +-0.988531266120062480, -0.988538815701553550, -0.988546362811697500, -0.988553907450475670, -0.988561449617868960, -0.988568989313858610, -0.988576526538425870, -0.988584061291551850, +-0.988591593573217580, -0.988599123383404390, -0.988606650722093310, -0.988614175589265680, -0.988621697984902630, -0.988629217908985280, -0.988636735361494880, -0.988644250342412660, +-0.988651762851719850, -0.988659272889397590, -0.988666780455427110, -0.988674285549789760, -0.988681788172466660, -0.988689288323439050, -0.988696786002688290, -0.988704281210195600, +-0.988711773945942120, -0.988719264209909190, -0.988726752002078160, -0.988734237322430260, -0.988741720170946750, -0.988749200547608950, -0.988756678452398120, -0.988764153885295590, +-0.988771626846282730, -0.988779097335340750, -0.988786565352451020, -0.988794030897594880, -0.988801493970753680, -0.988808954571908760, -0.988816412701041480, -0.988823868358133070, +-0.988831321543165110, -0.988838772256118710, -0.988846220496975460, -0.988853666265716690, -0.988861109562323760, -0.988868550386778010, -0.988875988739060910, -0.988883424619153790, +-0.988890858027038130, -0.988898288962695380, -0.988905717426106780, -0.988913143417254000, -0.988920566936118410, -0.988927987982681220, -0.988935406556924250, -0.988942822658828600, +-0.988950236288375970, -0.988957647445547820, -0.988965056130325480, -0.988972462342690430, -0.988979866082624340, -0.988987267350108560, -0.988994666145124550, -0.989002062467653990, +-0.989009456317678230, -0.989016847695178720, -0.989024236600137270, -0.989031623032535110, -0.989039006992353920, -0.989046388479575160, -0.989053767494180500, -0.989061144036151420, +-0.989068518105469470, -0.989075889702116240, -0.989083258826073290, -0.989090625477322180, -0.989097989655844390, -0.989105351361621810, -0.989112710594635790, -0.989120067354867900, +-0.989127421642299940, -0.989134773456913470, -0.989142122798689960, -0.989149469667611190, -0.989156814063658740, -0.989164155986814290, -0.989171495437059400, -0.989178832414375760, +-0.989186166918745060, -0.989193498950148960, -0.989200828508569160, -0.989208155593987230, -0.989215480206384950, -0.989222802345743890, -0.989230122012045850, -0.989237439205272520, +-0.989244753925405670, -0.989252066172426780, -0.989259375946317850, -0.989266683247060460, -0.989273988074636400, -0.989281290429027240, -0.989288590310214990, -0.989295887718181110, +-0.989303182652907620, -0.989310475114376200, -0.989317765102568520, -0.989325052617466500, -0.989332337659051820, -0.989339620227306260, -0.989346900322211730, -0.989354177943749800, +-0.989361453091902600, -0.989368725766651690, -0.989375995967978980, -0.989383263695866270, -0.989390528950295330, -0.989397791731248200, -0.989405052038706430, -0.989412309872652160, +-0.989419565233067070, -0.989426818119933160, -0.989434068533232010, -0.989441316472945860, -0.989448561939056390, -0.989455804931545500, -0.989463045450395100, -0.989470283495587080, +-0.989477519067103240, -0.989484752164925820, -0.989491982789036380, -0.989499210939416950, -0.989506436616049640, -0.989513659818916150, -0.989520880547998470, -0.989528098803278630, +-0.989535314584738530, -0.989542527892360190, -0.989549738726125510, -0.989556947086016490, -0.989564152972015050, -0.989571356384103320, -0.989578557322263070, -0.989585755786476560, +-0.989592951776725570, -0.989600145292992230, -0.989607336335258550, -0.989614524903506540, -0.989621710997718230, -0.989628894617875510, -0.989636075763960730, -0.989643254435955580, +-0.989650430633842500, -0.989657604357603190, -0.989664775607219880, -0.989671944382674700, -0.989679110683949650, -0.989686274511026750, -0.989693435863888250, -0.989700594742516150, +-0.989707751146892580, -0.989714905076999550, -0.989722056532819310, -0.989729205514333970, -0.989736352021525550, -0.989743496054376280, -0.989750637612868190, -0.989757776696983620, +-0.989764913306704460, -0.989772047442013190, -0.989779179102891700, -0.989786308289322350, -0.989793435001287140, -0.989800559238768420, -0.989807681001748210, -0.989814800290208850, +-0.989821917104132480, -0.989829031443501320, -0.989836143308297610, -0.989843252698503480, -0.989850359614101280, -0.989857464055073240, -0.989864566021401380, -0.989871665513068270, +-0.989878762530055910, -0.989885857072346550, -0.989892949139922760, -0.989900038732766440, -0.989907125850860050, -0.989914210494185820, -0.989921292662726100, -0.989928372356463250, +-0.989935449575379380, -0.989942524319456840, -0.989949596588677980, -0.989956666383025260, -0.989963733702480810, -0.989970798547026960, -0.989977860916646190, -0.989984920811320720, +-0.989991978231033020, -0.989999033175765320, -0.990006085645499970, -0.990013135640219530, -0.990020183159906140, -0.990027228204542480, -0.990034270774110550, -0.990041310868593040, +-0.990048348487972190, -0.990055383632230560, -0.990062416301350390, -0.990069446495314250, -0.990076474214104390, -0.990083499457703460, -0.990090522226093730, -0.990097542519257750, +-0.990104560337177860, -0.990111575679836540, -0.990118588547216350, -0.990125598939299630, -0.990132606856068960, -0.990139612297506690, -0.990146615263595490, -0.990153615754317710, +-0.990160613769655920, -0.990167609309592470, -0.990174602374110150, -0.990181592963191300, -0.990188581076818400, -0.990195566714974110, -0.990202549877640890, -0.990209530564801210, +-0.990216508776437850, -0.990223484512533170, -0.990230457773069730, -0.990237428558030210, -0.990244396867397070, -0.990251362701152880, -0.990258326059280440, -0.990265286941762080, +-0.990272245348580490, -0.990279201279718360, -0.990286154735158130, -0.990293105714882600, -0.990300054218874240, -0.990307000247115820, -0.990313943799589810, -0.990320884876279120, +-0.990327823477165970, -0.990334759602233490, -0.990341693251463930, -0.990348624424840280, -0.990355553122344910, -0.990362479343960820, -0.990369403089670470, -0.990376324359456550, +-0.990383243153301950, -0.990390159471189140, -0.990397073313101010, -0.990403984679020130, -0.990410893568929310, -0.990417799982811210, -0.990424703920648630, -0.990431605382424360, +-0.990438504368120980, -0.990445400877721370, -0.990452294911208340, -0.990459186468564460, -0.990466075549772730, -0.990472962154815730, -0.990479846283676360, -0.990486727936337300, +-0.990493607112781560, -0.990500483812991720, -0.990507358036950670, -0.990514229784641210, -0.990521099056046130, -0.990527965851148440, -0.990534830169930710, -0.990541692012375960, +-0.990548551378466980, -0.990555408268186670, -0.990562262681517700, -0.990569114618443210, -0.990575964078945880, -0.990582811063008720, -0.990589655570614400, -0.990596497601746060, +-0.990603337156386380, -0.990610174234518360, -0.990617008836124910, -0.990623840961189050, -0.990630670609693450, -0.990637497781621250, -0.990644322476955330, -0.990651144695678500, +-0.990657964437773870, -0.990664781703224360, -0.990671596492012860, -0.990678408804122390, -0.990685218639535960, -0.990692025998236360, -0.990698830880206720, -0.990705633285430040, +-0.990712433213889240, -0.990719230665567440, -0.990726025640447430, -0.990732818138512440, -0.990739608159745490, -0.990746395704129370, -0.990753180771647310, -0.990759963362282340, +-0.990766743476017450, -0.990773521112835680, -0.990780296272720020, -0.990787068955653720, -0.990793839161619780, -0.990800606890601230, -0.990807372142581080, -0.990814134917542550, +-0.990820895215468680, -0.990827653036342570, -0.990834408380147360, -0.990841161246866160, -0.990847911636482000, -0.990854659548978000, -0.990861404984337390, -0.990868147942543410, +-0.990874888423578850, -0.990881626427427160, -0.990888361954071480, -0.990895095003494820, -0.990901825575680410, -0.990908553670611480, -0.990915279288271170, -0.990922002428642590, +-0.990928723091709100, -0.990935441277453700, -0.990942156985859750, -0.990948870216910360, -0.990955580970588890, -0.990962289246878350, -0.990968995045762190, -0.990975698367223550, +-0.990982399211245650, -0.990989097577811620, -0.990995793466905030, -0.991002486878508890, -0.991009177812606450, -0.991015866269181140, -0.991022552248216230, -0.991029235749694810, +-0.991035916773600370, -0.991042595319916120, -0.991049271388625420, -0.991055944979711610, -0.991062616093157820, -0.991069284728947510, -0.991075950887064020, -0.991082614567490580, +-0.991089275770210660, -0.991095934495207500, -0.991102590742464540, -0.991109244511965140, -0.991115895803692640, -0.991122544617630390, -0.991129190953761730, -0.991135834812070130, +-0.991142476192538810, -0.991149115095151470, -0.991155751519891330, -0.991162385466741740, -0.991169016935686260, -0.991175645926708150, -0.991182272439790960, -0.991188896474918150, +-0.991195518032073060, -0.991202137111239170, -0.991208753712399910, -0.991215367835538760, -0.991221979480639280, -0.991228588647684710, -0.991235195336658830, -0.991241799547544880, +-0.991248401280326430, -0.991255000534986940, -0.991261597311509980, -0.991268191609879110, -0.991274783430077690, -0.991281372772089280, -0.991287959635897440, -0.991294544021485760, +-0.991301125928837680, -0.991307705357936770, -0.991314282308766730, -0.991320856781310880, -0.991327428775552800, -0.991333998291476280, -0.991340565329064670, -0.991347129888301760, +-0.991353691969171000, -0.991360251571655970, -0.991366808695740230, -0.991373363341407580, -0.991379915508641570, -0.991386465197425680, -0.991393012407743580, -0.991399557139579060, +-0.991406099392915570, -0.991412639167736920, -0.991419176464026550, -0.991425711281768370, -0.991432243620945840, -0.991438773481542750, -0.991445300863542660, -0.991451825766929360, +-0.991458348191686540, -0.991464868137797770, -0.991471385605246840, -0.991477900594017410, -0.991484413104093300, -0.991490923135458170, -0.991497430688095700, -0.991503935761989590, +-0.991510438357123820, -0.991516938473481770, -0.991523436111047430, -0.991529931269804490, -0.991536423949736840, -0.991542914150827960, -0.991549401873061950, -0.991555887116422290, +-0.991562369880892970, -0.991568850166457790, -0.991575327973100440, -0.991581803300804810, -0.991588276149554580, -0.991594746519333660, -0.991601214410125940, -0.991607679821915220, +-0.991614142754685180, -0.991620603208419830, -0.991627061183103060, -0.991633516678718570, -0.991639969695250260, -0.991646420232682010, -0.991652868290997750, -0.991659313870181360, +-0.991665756970216640, -0.991672197591087600, -0.991678635732777920, -0.991685071395271730, -0.991691504578552930, -0.991697935282605300, -0.991704363507412870, -0.991710789252959410, +-0.991717212519229170, -0.991723633306205720, -0.991730051613873290, -0.991736467442215660, -0.991742880791216970, -0.991749291660861010, -0.991755700051131780, -0.991762105962013420, +-0.991768509393489710, -0.991774910345544770, -0.991781308818162510, -0.991787704811326940, -0.991794098325022190, -0.991800489359232150, -0.991806877913940950, -0.991813263989132500, +-0.991819647584790910, -0.991826028700900200, -0.991832407337444380, -0.991838783494407570, -0.991845157171773790, -0.991851528369527170, -0.991857897087651710, -0.991864263326131420, +-0.991870627084950550, -0.991876988364093100, -0.991883347163543210, -0.991889703483284980, -0.991896057323302440, -0.991902408683579710, -0.991908757564101020, -0.991915103964850390, +-0.991921447885812050, -0.991927789326970120, -0.991934128288308630, -0.991940464769811900, -0.991946798771463860, -0.991953130293248940, -0.991959459335151170, -0.991965785897154780, +-0.991972109979244010, -0.991978431581402860, -0.991984750703615580, -0.991991067345866510, -0.991997381508139760, -0.992003693190419590, -0.992010002392690100, -0.992016309114935660, +-0.992022613357140370, -0.992028915119288700, -0.992035214401364660, -0.992041511203352490, -0.992047805525236640, -0.992054097367001340, -0.992060386728630730, -0.992066673610109140, +-0.992072958011420810, -0.992079239932550210, -0.992085519373481440, -0.992091796334198860, -0.992098070814686820, -0.992104342814929650, -0.992110612334911490, -0.992116879374616900, +-0.992123143934030120, -0.992129406013135480, -0.992135665611917240, -0.992141922730359950, -0.992148177368447740, -0.992154429526165170, -0.992160679203496490, -0.992166926400426140, +-0.992173171116938480, -0.992179413353017850, -0.992185653108648700, -0.992191890383815390, -0.992198125178502370, -0.992204357492694090, -0.992210587326374900, -0.992216814679529270, +-0.992223039552141530, -0.992229261944196250, -0.992235481855677780, -0.992241699286570580, -0.992247914236859210, -0.992254126706528020, -0.992260336695561460, -0.992266544203944110, +-0.992272749231660420, -0.992278951778694850, -0.992285151845031850, -0.992291349430656000, -0.992297544535551750, -0.992303737159703660, -0.992309927303096310, -0.992316114965714040, +-0.992322300147541530, -0.992328482848563230, -0.992334663068763720, -0.992340840808127570, -0.992347016066639330, -0.992353188844283580, -0.992359359141044890, -0.992365526956907720, +-0.992371692291856730, -0.992377855145876510, -0.992384015518951720, -0.992390173411066830, -0.992396328822206520, -0.992402481752355350, -0.992408632201498000, -0.992414780169619150, +-0.992420925656703260, -0.992427068662735110, -0.992433209187699280, -0.992439347231580450, -0.992445482794363180, -0.992451615876032260, -0.992457746476572260, -0.992463874595967850, +-0.992470000234203840, -0.992476123391264790, -0.992482244067135480, -0.992488362261800480, -0.992494477975244700, -0.992500591207452600, -0.992506701958409070, -0.992512810228098790, +-0.992518916016506550, -0.992525019323616920, -0.992531120149414800, -0.992537218493884770, -0.992543314357011820, -0.992549407738780530, -0.992555498639175800, -0.992561587058182200, +-0.992567672995784740, -0.992573756451967990, -0.992579837426716960, -0.992585915920016220, -0.992591991931850770, -0.992598065462205410, -0.992604136511064720, -0.992610205078413800, +-0.992616271164237340, -0.992622334768520240, -0.992628395891247180, -0.992634454532403290, -0.992640510691973120, -0.992646564369941810, -0.992652615566294030, -0.992658664281014680, +-0.992664710514088670, -0.992670754265501000, -0.992676795535236360, -0.992682834323279640, -0.992688870629615970, -0.992694904454230030, -0.992700935797106940, -0.992706964658231380, +-0.992712991037588590, -0.992719014935163120, -0.992725036350940230, -0.992731055284904680, -0.992737071737041620, -0.992743085707335720, -0.992749097195772200, -0.992755106202335870, +-0.992761112727011840, -0.992767116769785020, -0.992773118330640410, -0.992779117409563040, -0.992785114006537790, -0.992791108121549800, -0.992797099754584080, -0.992803088905625520, +-0.992809075574659360, -0.992815059761670390, -0.992821041466643850, -0.992827020689564630, -0.992832997430417970, -0.992838971689188780, -0.992844943465862050, -0.992850912760423030, +-0.992856879572856730, -0.992862843903148270, -0.992868805751282670, -0.992874765117245150, -0.992880722001020620, -0.992886676402594310, -0.992892628321951240, -0.992898577759076640, +-0.992904524713955630, -0.992910469186573330, -0.992916411176914760, -0.992922350684965260, -0.992928287710709840, -0.992934222254133750, -0.992940154315221980, -0.992946083893960000, +-0.992952010990332700, -0.992957935604325330, -0.992963857735923220, -0.992969777385111390, -0.992975694551875180, -0.992981609236199710, -0.992987521438070230, -0.992993431157471960, +-0.992999338394390030, -0.993005243148809780, -0.993011145420716450, -0.993017045210095260, -0.993022942516931460, -0.993028837341210280, -0.993034729682917060, -0.993040619542037040, +-0.993046506918555340, -0.993052391812457520, -0.993058274223728610, -0.993064154152354050, -0.993070031598319190, -0.993075906561609160, -0.993081779042209290, -0.993087649040105160, +-0.993093516555281770, -0.993099381587724590, -0.993105244137418960, -0.993111104204350340, -0.993116961788503840, -0.993122816889864920, -0.993128669508419050, -0.993134519644151450, +-0.993140367297047580, -0.993146212467092780, -0.993152055154272410, -0.993157895358572020, -0.993163733079976740, -0.993169568318472250, -0.993175401074043780, -0.993181231346676800, +-0.993187059136356740, -0.993192884443069080, -0.993198707266799150, -0.993204527607532530, -0.993210345465254550, -0.993216160839950680, -0.993221973731606480, -0.993227784140207290, +-0.993233592065738580, -0.993239397508186020, -0.993245200467534840, -0.993251000943770720, -0.993256798936879130, -0.993262594446845500, -0.993268387473655420, -0.993274178017294340, +-0.993279966077747820, -0.993285751655001440, -0.993291534749040640, -0.993297315359851000, -0.993303093487418080, -0.993308869131727330, -0.993314642292764560, -0.993320412970515100, +-0.993326181164964630, -0.993331946876098710, -0.993337710103902930, -0.993343470848362830, -0.993349229109464100, -0.993354984887192320, -0.993360738181533030, -0.993366488992471930, +-0.993372237319994580, -0.993377983164086650, -0.993383726524733720, -0.993389467401921470, -0.993395205795635560, -0.993400941705861680, -0.993406675132585510, -0.993412406075792510, +-0.993418134535468570, -0.993423860511599250, -0.993429584004170360, -0.993435305013167460, -0.993441023538576330, -0.993446739580382650, -0.993452453138572000, -0.993458164213130380, +-0.993463872804043250, -0.993469578911296500, -0.993475282534875710, -0.993480983674766780, -0.993486682330955380, -0.993492378503427310, -0.993498072192168240, -0.993503763397163950, +-0.993509452118400360, -0.993515138355863140, -0.993520822109537960, -0.993526503379410840, -0.993532182165467350, -0.993537858467693490, -0.993543532286074950, -0.993549203620597620, +-0.993554872471247300, -0.993560538838009770, -0.993566202720870820, -0.993571864119816460, -0.993577523034832380, -0.993583179465904460, -0.993588833413018730, -0.993594484876160760, +-0.993600133855316650, -0.993605780350472310, -0.993611424361613320, -0.993617065888725890, -0.993622704931795830, -0.993628341490808920, -0.993633975565751170, -0.993639607156608480, +-0.993645236263366760, -0.993650862886012010, -0.993656487024530130, -0.993662108678906920, -0.993667727849128600, -0.993673344535180750, -0.993678958737049700, -0.993684570454721140, +-0.993690179688181300, -0.993695786437415850, -0.993701390702411040, -0.993706992483152750, -0.993712591779627010, -0.993718188591819710, -0.993723782919716970, -0.993729374763304700, +-0.993734964122569120, -0.993740550997496030, -0.993746135388071660, -0.993751717294281800, -0.993757296716112790, -0.993762873653550540, -0.993768448106581050, -0.993774020075190450, +-0.993779589559364740, -0.993785156559090170, -0.993790721074352620, -0.993796283105138340, -0.993801842651433230, -0.993807399713223630, -0.993812954290495540, -0.993818506383234990, +-0.993824055991428200, -0.993829603115061300, -0.993835147754120410, -0.993840689908591650, -0.993846229578461030, -0.993851766763715010, -0.993857301464339480, -0.993862833680320690, +-0.993868363411644860, -0.993873890658298120, -0.993879415420266590, -0.993884937697536610, -0.993890457490094300, -0.993895974797925800, -0.993901489621017320, -0.993907001959355110, +-0.993912511812925500, -0.993918019181714520, -0.993923524065708500, -0.993929026464893670, -0.993934526379256390, -0.993940023808782660, -0.993945518753458930, -0.993951011213271340, +-0.993956501188206330, -0.993961988678249920, -0.993967473683388670, -0.993972956203608700, -0.993978436238896370, -0.993983913789237890, -0.993989388854619630, -0.993994861435027910, +-0.994000331530449090, -0.994005799140869390, -0.994011264266275170, -0.994016726906652880, -0.994022187061988640, -0.994027644732269010, -0.994033099917480230, -0.994038552617608760, +-0.994044002832640940, -0.994049450562563000, -0.994054895807361500, -0.994060338567022810, -0.994065778841533130, -0.994071216630879160, -0.994076651935047020, -0.994082084754023380, +-0.994087515087794360, -0.994092942936346760, -0.994098368299666690, -0.994103791177740610, -0.994109211570555210, -0.994114629478096700, -0.994120044900351660, -0.994125457837306440, +-0.994130868288947590, -0.994136276255261690, -0.994141681736234960, -0.994147084731854090, -0.994152485242105530, -0.994157883266975630, -0.994163278806451170, -0.994168671860518380, +-0.994174062429164060, -0.994179450512374440, -0.994184836110136310, -0.994190219222436000, -0.994195599849260200, -0.994200977990595370, -0.994206353646428180, -0.994211726816745080, +-0.994217097501532530, -0.994222465700777440, -0.994227831414466020, -0.994233194642585080, -0.994238555385121180, -0.994243913642060880, -0.994249269413390760, -0.994254622699097480, +-0.994259973499167620, -0.994265321813587840, -0.994270667642344840, -0.994276010985425060, -0.994281351842815300, -0.994286690214502220, -0.994292026100472290, -0.994297359500712410, +-0.994302690415209020, -0.994308018843949040, -0.994313344786918910, -0.994318668244105420, -0.994323989215495360, -0.994329307701075190, -0.994334623700831810, -0.994339937214751890, +-0.994345248242822110, -0.994350556785029260, -0.994355862841360020, -0.994361166411801060, -0.994366467496339170, -0.994371766094961140, -0.994377062207653650, -0.994382355834403600, +-0.994387646975197660, -0.994392935630022510, -0.994398221798865060, -0.994403505481712080, -0.994408786678550370, -0.994414065389366610, -0.994419341614147690, -0.994424615352880510, +-0.994429886605551760, -0.994435155372148220, -0.994440421652656780, -0.994445685447064350, -0.994450946755357720, -0.994456205577523790, -0.994461461913549230, -0.994466715763421050, +-0.994471967127126040, -0.994477216004651220, -0.994482462395983260, -0.994487706301109160, -0.994492947720015840, -0.994498186652690070, -0.994503423099118880, -0.994508657059289150, +-0.994513888533187780, -0.994519117520801690, -0.994524344022117760, -0.994529568037123000, -0.994534789565804320, -0.994540008608148730, -0.994545225164143010, -0.994550439233774290, +-0.994555650817029460, -0.994560859913895530, -0.994566066524359420, -0.994571270648408110, -0.994576472286028750, -0.994581671437208100, -0.994586868101933310, -0.994592062280191260, +-0.994597253971969190, -0.994602443177253880, -0.994607629896032570, -0.994612814128292060, -0.994617995874019560, -0.994623175133202090, -0.994628351905826660, -0.994633526191880390, +-0.994638697991350300, -0.994643867304223490, -0.994649034130487000, -0.994654198470127810, -0.994659360323133290, -0.994664519689490320, -0.994669676569185920, -0.994674830962207550, +-0.994679982868541980, -0.994685132288176450, -0.994690279221098090, -0.994695423667294020, -0.994700565626751350, -0.994705705099457440, -0.994710842085399060, -0.994715976584563680, +-0.994721108596938410, -0.994726238122510260, -0.994731365161266590, -0.994736489713194500, -0.994741611778281240, -0.994746731356513810, -0.994751848447879670, -0.994756963052365830, +-0.994762075169959630, -0.994767184800648190, -0.994772291944418850, -0.994777396601258750, -0.994782498771155210, -0.994787598454095370, -0.994792695650066560, -0.994797790359055910, +-0.994802882581050980, -0.994807972316038680, -0.994813059564006560, -0.994818144324941640, -0.994823226598831490, -0.994828306385663220, -0.994833383685424290, -0.994838458498101820, +-0.994843530823683150, -0.994848600662155750, -0.994853668013506720, -0.994858732877723640, -0.994863795254793740, -0.994868855144704240, -0.994873912547442730, -0.994878967462996310, +-0.994884019891352560, -0.994889069832498700, -0.994894117286422300, -0.994899162253110480, -0.994904204732550810, -0.994909244724730520, -0.994914282229637290, -0.994919317247258240, +-0.994924349777580930, -0.994929379820592710, -0.994934407376281140, -0.994939432444633450, -0.994944455025637220, -0.994949475119279780, -0.994954492725548810, -0.994959507844431430, +-0.994964520475915440, -0.994969530619988050, -0.994974538276636840, -0.994979543445849380, -0.994984546127613000, -0.994989546321915160, -0.994994544028743540, -0.994999539248085600, +-0.995004531979928770, -0.995009522224260650, -0.995014509981068660, -0.995019495250340390, -0.995024478032063510, -0.995029458326225250, -0.995034436132813500, -0.995039411451815630, +-0.995044384283219170, -0.995049354627011720, -0.995054322483180930, -0.995059287851714380, -0.995064250732599630, -0.995069211125824140, -0.995074169031375690, -0.995079124449241850, +-0.995084077379410180, -0.995089027821868250, -0.995093975776603860, -0.995098921243604440, -0.995103864222857680, -0.995108804714351370, -0.995113742718073070, -0.995118678234010350, +-0.995123611262150880, -0.995128541802482450, -0.995133469854992620, -0.995138395419669200, -0.995143318496499730, -0.995148239085472010, -0.995153157186573600, -0.995158072799792400, +-0.995162985925115980, -0.995167896562532020, -0.995172804712028400, -0.995177710373592820, -0.995182613547212940, -0.995187514232876440, -0.995192412430571220, -0.995197308140284950, +-0.995202201362005430, -0.995207092095720340, -0.995211980341417560, -0.995216866099084880, -0.995221749368710000, -0.995226630150280680, -0.995231508443784940, -0.995236384249210350, +-0.995241257566544690, -0.995246128395776090, -0.995250996736891990, -0.995255862589880520, -0.995260725954729360, -0.995265586831426300, -0.995270445219959330, -0.995275301120316370, +-0.995280154532484970, -0.995285005456453260, -0.995289853892209030, -0.995294699839740170, -0.995299543299034580, -0.995304384270080170, -0.995309222752864710, -0.995314058747376220, +-0.995318892253602590, -0.995323723271531850, -0.995328551801151650, -0.995333377842450130, -0.995338201395415180, -0.995343022460034590, -0.995347841036296590, -0.995352657124188970, +-0.995357470723699620, -0.995362281834816680, -0.995367090457528030, -0.995371896591821680, -0.995376700237685540, -0.995381501395107620, -0.995386300064076020, -0.995391096244578550, +-0.995395889936603440, -0.995400681140138580, -0.995405469855172090, -0.995410256081691870, -0.995415039819686040, -0.995419821069142510, -0.995424599830049490, -0.995429376102395010, +-0.995434149886167070, -0.995438921181353690, -0.995443689987943080, -0.995448456305923270, -0.995453220135282260, -0.995457981476008170, -0.995462740328089240, -0.995467496691513350, +-0.995472250566268760, -0.995477001952343570, -0.995481750849725790, -0.995486497258403770, -0.995491241178365400, -0.995495982609598930, -0.995500721552092570, -0.995505458005834340, +-0.995510191970812470, -0.995514923447015200, -0.995519652434430520, -0.995524378933046790, -0.995529102942852020, -0.995533824463834540, -0.995538543495982590, -0.995543260039284170, +-0.995547974093727640, -0.995552685659301110, -0.995557394735992920, -0.995562101323791300, -0.995566805422684390, -0.995571507032660400, -0.995576206153707680, -0.995580902785814460, +-0.995585596928969090, -0.995590288583159570, -0.995594977748374350, -0.995599664424601680, -0.995604348611830000, -0.995609030310047330, -0.995613709519242000, -0.995618386239402580, +-0.995623060470517070, -0.995627732212573950, -0.995632401465561420, -0.995637068229468070, -0.995641732504281900, -0.995646394289991470, -0.995651053586585010, -0.995655710394050870, +-0.995660364712377510, -0.995665016541553260, -0.995669665881566470, -0.995674312732405480, -0.995678957094058740, -0.995683598966514590, -0.995688238349761390, -0.995692875243787690, +-0.995697509648581720, -0.995702141564132060, -0.995706770990427040, -0.995711397927455000, -0.995716022375204620, -0.995720644333664030, -0.995725263802821890, -0.995729880782666550, +-0.995734495273186580, -0.995739107274370320, -0.995743716786206320, -0.995748323808683060, -0.995752928341788970, -0.995757530385512510, -0.995762129939842260, -0.995766727004766650, +-0.995771321580274260, -0.995775913666353650, -0.995780503262993170, -0.995785090370181370, -0.995789674987906940, -0.995794257116158320, -0.995798836754923980, -0.995803413904192580, +-0.995807988563952700, -0.995812560734192780, -0.995817130414901500, -0.995821697606067420, -0.995826262307679010, -0.995830824519725040, -0.995835384242193980, -0.995839941475074370, +-0.995844496218355020, -0.995849048472024380, -0.995853598236071110, -0.995858145510483910, -0.995862690295251320, -0.995867232590361920, -0.995871772395804490, -0.995876309711567710, +-0.995880844537640030, -0.995885376874010350, -0.995889906720667130, -0.995894434077599260, -0.995898958944795190, -0.995903481322243820, -0.995908001209933720, -0.995912518607853570, +-0.995917033515992140, -0.995921545934338130, -0.995926055862880300, -0.995930563301607230, -0.995935068250507820, -0.995939570709570730, -0.995944070678784770, -0.995948568158138590, +-0.995953063147621000, -0.995957555647220660, -0.995962045656926590, -0.995966533176727230, -0.995971018206611710, -0.995975500746568490, -0.995979980796586670, -0.995984458356654830, +-0.995988933426761760, -0.995993406006896450, -0.995997876097047600, -0.996002343697204080, -0.996006808807354700, -0.996011271427488350, -0.996015731557593710, -0.996020189197659780, +-0.996024644347675460, -0.996029097007629430, -0.996033547177510690, -0.996037994857308040, -0.996042440047010480, -0.996046882746606800, -0.996051322956085890, -0.996055760675436660, +-0.996060195904648000, -0.996064628643708930, -0.996069058892608330, -0.996073486651334990, -0.996077911919877930, -0.996082334698226160, -0.996086754986368450, -0.996091172784293930, +-0.996095588091991500, -0.996100000909450060, -0.996104411236658600, -0.996108819073606160, -0.996113224420281610, -0.996117627276674080, -0.996122027642772470, -0.996126425518565670, +-0.996130820904042920, -0.996135213799193120, -0.996139604204005270, -0.996143992118468380, -0.996148377542571570, -0.996152760476303740, -0.996157140919654130, -0.996161518872611510, +-0.996165894335165230, -0.996170267307304070, -0.996174637789017380, -0.996179005780294060, -0.996183371281123220, -0.996187734291493880, -0.996192094811395260, -0.996196452840816480, +-0.996200808379746450, -0.996205161428174500, -0.996209511986089540, -0.996213860053480890, -0.996218205630337470, -0.996222548716648730, -0.996226889312403440, -0.996231227417591070, +-0.996235563032200510, -0.996239896156221110, -0.996244226789641970, -0.996248554932452230, -0.996252880584641120, -0.996257203746197750, -0.996261524417111470, -0.996265842597371390, +-0.996270158286966630, -0.996274471485886440, -0.996278782194120140, -0.996283090411656860, -0.996287396138485940, -0.996291699374596380, -0.996296000119977650, -0.996300298374618980, +-0.996304594138509470, -0.996308887411638590, -0.996313178193995340, -0.996317466485569290, -0.996321752286349450, -0.996326035596325270, -0.996330316415486080, -0.996334594743821020, +-0.996338870581319420, -0.996343143927970740, -0.996347414783764210, -0.996351683148689050, -0.996355949022734720, -0.996360212405890570, -0.996364473298145930, -0.996368731699490030, +-0.996372987609912220, -0.996377241029402060, -0.996381491957948780, -0.996385740395541730, -0.996389986342170350, -0.996394229797823990, -0.996398470762492110, -0.996402709236164030, +-0.996406945218829110, -0.996411178710476910, -0.996415409711096770, -0.996419638220678030, -0.996423864239210260, -0.996428087766682790, -0.996432308803085200, -0.996436527348406710, +-0.996440743402637000, -0.996444956965765290, -0.996449168037781270, -0.996453376618674390, -0.996457582708433990, -0.996461786307049740, -0.996465987414510870, -0.996470186030807170, +-0.996474382155927870, -0.996478575789862760, -0.996482766932601070, -0.996486955584132580, -0.996491141744446640, -0.996495325413532920, -0.996499506591380760, -0.996503685277979940, +-0.996507861473319820, -0.996512035177390180, -0.996516206390180350, -0.996520375111680010, -0.996524541341878730, -0.996528705080766190, -0.996532866328331710, -0.996537025084565210, +-0.996541181349456130, -0.996545335122994040, -0.996549486405168610, -0.996553635195969510, -0.996557781495386320, -0.996561925303408700, -0.996566066620026230, -0.996570205445228560, +-0.996574341779005390, -0.996578475621346490, -0.996582606972241210, -0.996586735831679560, -0.996590862199650980, -0.996594986076145380, -0.996599107461152210, -0.996603226354661250, +-0.996607342756662300, -0.996611456667144900, -0.996615568086098860, -0.996619677013513950, -0.996623783449379850, -0.996627887393686350, -0.996631988846423010, -0.996636087807579840, +-0.996640184277146290, -0.996644278255112370, -0.996648369741467750, -0.996652458736202230, -0.996656545239305470, -0.996660629250767480, -0.996664710770577830, -0.996668789798726420, +-0.996672866335203020, -0.996676940379997430, -0.996681011933099550, -0.996685080994499150, -0.996689147564186030, -0.996693211642150080, -0.996697273228380980, -0.996701332322868840, +-0.996705388925603230, -0.996709443036574270, -0.996713494655771640, -0.996717543783185330, -0.996721590418805040, -0.996725634562620870, -0.996729676214622610, -0.996733715374800160, +-0.996737752043143410, -0.996741786219642270, -0.996745817904286620, -0.996749847097066490, -0.996753873797971760, -0.996757898006992330, -0.996761919724118210, -0.996765938949339180, +-0.996769955682645370, -0.996773969924026560, -0.996777981673472980, -0.996781990930974420, -0.996785997696520760, -0.996790001970102260, -0.996794003751708680, -0.996798003041330040, +-0.996801999838956450, -0.996805994144577930, -0.996809985958184370, -0.996813975279765780, -0.996817962109312280, -0.996821946446813880, -0.996825928292260690, -0.996829907645642610, +-0.996833884506949760, -0.996837858876172270, -0.996841830753300020, -0.996845800138323250, -0.996849767031231960, -0.996853731432016280, -0.996857693340666320, -0.996861652757172090, +-0.996865609681523710, -0.996869564113711300, -0.996873516053724980, -0.996877465501554870, -0.996881412457191090, -0.996885356920623860, -0.996889298891843080, -0.996893238370839210, +-0.996897175357602140, -0.996901109852122210, -0.996905041854389440, -0.996908971364394160, -0.996912898382126380, -0.996916822907576330, -0.996920744940734240, -0.996924664481590340, +-0.996928581530134750, -0.996932496086357700, -0.996936408150249420, -0.996940317721800030, -0.996944224800999980, -0.996948129387839280, -0.996952031482308270, -0.996955931084397280, +-0.996959828194096340, -0.996963722811395890, -0.996967614936286160, -0.996971504568757270, -0.996975391708799790, -0.996979276356403710, -0.996983158511559500, -0.996987038174257380, +-0.996990915344487580, -0.996994790022240560, -0.996998662207506550, -0.997002531900275990, -0.997006399100539010, -0.997010263808286060, -0.997014126023507360, -0.997017985746193490, +-0.997021842976334560, -0.997025697713921020, -0.997029549958943220, -0.997033399711391600, -0.997037246971256510, -0.997041091738528280, -0.997044934013197270, -0.997048773795253920, +-0.997052611084688680, -0.997056445881491890, -0.997060278185654010, -0.997064107997165490, -0.997067935316016560, -0.997071760142197890, -0.997075582475699830, -0.997079402316512820, +-0.997083219664627210, -0.997087034520033670, -0.997090846882722430, -0.997094656752684160, -0.997098464129909210, -0.997102269014388030, -0.997106071406111290, -0.997109871305069340, +-0.997113668711252730, -0.997117463624651920, -0.997121256045257480, -0.997125045973059840, -0.997128833408049700, -0.997132618350217380, -0.997136400799553460, -0.997140180756048710, +-0.997143958219693370, -0.997147733190478110, -0.997151505668393610, -0.997155275653430430, -0.997159043145578900, -0.997162808144829830, -0.997166570651173760, -0.997170330664601150, +-0.997174088185102780, -0.997177843212669220, -0.997181595747291040, -0.997185345788958900, -0.997189093337663370, -0.997192838393395120, -0.997196580956144720, -0.997200321025902950, +-0.997204058602660260, -0.997207793686407550, -0.997211526277135270, -0.997215256374834210, -0.997218983979495040, -0.997222709091108330, -0.997226431709664960, -0.997230151835155400, +-0.997233869467570530, -0.997237584606900930, -0.997241297253137370, -0.997245007406270640, -0.997248715066291310, -0.997252420233190270, -0.997256122906958200, -0.997259823087585760, +-0.997263520775063750, -0.997267215969382950, -0.997270908670534140, -0.997274598878508000, -0.997278286593295430, -0.997281971814887090, -0.997285654543273890, -0.997289334778446500, +-0.997293012520395820, -0.997296687769112510, -0.997300360524587590, -0.997304030786811730, -0.997307698555775720, -0.997311363831470570, -0.997315026613886930, -0.997318686903015840, +-0.997322344698847950, -0.997326000001374170, -0.997329652810585500, -0.997333303126472610, -0.997336950949026410, -0.997340596278238010, -0.997344239114097970, -0.997347879456597420, +-0.997351517305727020, -0.997355152661478010, -0.997358785523841050, -0.997362415892807050, -0.997366043768367130, -0.997369669150512060, -0.997373292039232750, -0.997376912434520310, +-0.997380530336365530, -0.997384145744759530, -0.997387758659693090, -0.997391369081157220, -0.997394977009142920, -0.997398582443641210, -0.997402185384643090, -0.997405785832139460, +-0.997409383786121320, -0.997412979246579790, -0.997416572213505770, -0.997420162686890380, -0.997423750666724510, -0.997427336152999280, -0.997430919145705810, -0.997434499644834880, +-0.997438077650377840, -0.997441653162325580, -0.997445226180669110, -0.997448796705399650, -0.997452364736508110, -0.997455930273985820, -0.997459493317823580, -0.997463053868012590, +-0.997466611924544000, -0.997470167487408910, -0.997473720556598440, -0.997477271132103600, -0.997480819213915510, -0.997484364802025510, -0.997487907896424500, -0.997491448497103810, +-0.997494986604054450, -0.997498522217267650, -0.997502055336734530, -0.997505585962446210, -0.997509114094394020, -0.997512639732568980, -0.997516162876962320, -0.997519683527565370, +-0.997523201684369140, -0.997526717347364870, -0.997530230516543880, -0.997533741191897310, -0.997537249373416370, -0.997540755061092300, -0.997544258254916330, -0.997547758954879680, +-0.997551257160973700, -0.997554752873189510, -0.997558246091518550, -0.997561736815951840, -0.997565225046480930, -0.997568710783096830, -0.997572194025791000, -0.997575674774554670, +-0.997579153029379160, -0.997582628790255830, -0.997586102057175910, -0.997589572830130720, -0.997593041109111510, -0.997596506894109840, -0.997599970185116810, -0.997603430982123900, +-0.997606889285122420, -0.997610345094103620, -0.997613798409059060, -0.997617249229979960, -0.997620697556857780, -0.997624143389683860, -0.997627586728449530, -0.997631027573146260, +-0.997634465923765370, -0.997637901780298430, -0.997641335142736560, -0.997644766011071550, -0.997648194385294510, -0.997651620265397000, -0.997655043651370480, -0.997658464543206280, +-0.997661882940895970, -0.997665298844431000, -0.997668712253802710, -0.997672123169002670, -0.997675531590022310, -0.997678937516853100, -0.997682340949486600, -0.997685741887914150, +-0.997689140332127410, -0.997692536282117850, -0.997695929737876910, -0.997699320699396150, -0.997702709166667150, -0.997706095139681340, -0.997709478618430180, -0.997712859602905460, +-0.997716238093098620, -0.997719614089001010, -0.997722987590604520, -0.997726358597900490, -0.997729727110880590, -0.997733093129536400, -0.997736456653859460, -0.997739817683841350, +-0.997743176219473730, -0.997746532260748160, -0.997749885807656220, -0.997753236860189570, -0.997756585418339890, -0.997759931482098740, -0.997763275051457680, -0.997766616126408600, +-0.997769954706942850, -0.997773290793052210, -0.997776624384728360, -0.997779955481962970, -0.997783284084747700, -0.997786610193074130, -0.997789933806934150, -0.997793254926319320, +-0.997796573551221310, -0.997799889681631800, -0.997803203317542690, -0.997806514458945530, -0.997809823105832110, -0.997813129258194100, -0.997816432916023290, -0.997819734079311350, +-0.997823032748050180, -0.997826328922231330, -0.997829622601846600, -0.997832913786887990, -0.997836202477346950, -0.997839488673215480, -0.997842772374485270, -0.997846053581148080, +-0.997849332293195830, -0.997852608510620190, -0.997855882233413150, -0.997859153461566280, -0.997862422195071600, -0.997865688433920760, -0.997868952178105780, -0.997872213427618450, +-0.997875472182450540, -0.997878728442593950, -0.997881982208040470, -0.997885233478782220, -0.997888482254810750, -0.997891728536118070, -0.997894972322696080, -0.997898213614536680, +-0.997901452411631750, -0.997904688713973200, -0.997907922521552910, -0.997911153834362800, -0.997914382652394850, -0.997917608975640970, -0.997920832804092940, -0.997924054137742990, +-0.997927272976582790, -0.997930489320604460, -0.997933703169799900, -0.997936914524161000, -0.997940123383679880, -0.997943329748348430, -0.997946533618158770, -0.997949734993102690, +-0.997952933873172190, -0.997956130258359500, -0.997959324148656400, -0.997962515544055020, -0.997965704444547350, -0.997968890850125410, -0.997972074760781200, -0.997975256176506840, +-0.997978435097294450, -0.997981611523135800, -0.997984785454023250, -0.997987956889948680, -0.997991125830904210, -0.997994292276881970, -0.997997456227873950, -0.998000617683872270, +-0.998003776644869060, -0.998006933110856420, -0.998010087081826480, -0.998013238557771350, -0.998016387538683050, -0.998019534024553790, -0.998022678015375700, -0.998025819511141000, +-0.998028958511841590, -0.998032095017469920, -0.998035229028018000, -0.998038360543477940, -0.998041489563841980, -0.998044616089102330, -0.998047740119251130, -0.998050861654280590, +-0.998053980694182940, -0.998057097238950310, -0.998060211288574920, -0.998063322843048990, -0.998066431902364770, -0.998069538466514470, -0.998072642535490330, -0.998075744109284570, +-0.998078843187889420, -0.998081939771297220, -0.998085033859500200, -0.998088125452490480, -0.998091214550260620, -0.998094301152802510, -0.998097385260108830, -0.998100466872171580, +-0.998103545988983210, -0.998106622610535950, -0.998109696736822150, -0.998112768367834140, -0.998115837503564140, -0.998118904144004620, -0.998121968289147790, -0.998125029938986110, +-0.998128089093511690, -0.998131145752717220, -0.998134199916594800, -0.998137251585136890, -0.998140300758335930, -0.998143347436184160, -0.998146391618673910, -0.998149433305797860, +-0.998152472497548130, -0.998155509193917270, -0.998158543394897620, -0.998161575100481540, -0.998164604310661560, -0.998167631025430160, -0.998170655244779550, -0.998173676968702410, +-0.998176696197191070, -0.998179712930237990, -0.998182727167835520, -0.998185738909976310, -0.998188748156652820, -0.998191754907857390, -0.998194759163582580, -0.998197760923820840, +-0.998200760188564740, -0.998203756957806720, -0.998206751231539350, -0.998209743009755070, -0.998212732292446340, -0.998215719079605930, -0.998218703371226090, -0.998221685167299590, +-0.998224664467818880, -0.998227641272776520, -0.998230615582164970, -0.998233587395976900, -0.998236556714204970, -0.998239523536841530, -0.998242487863879370, -0.998245449695310930, +-0.998248409031128880, -0.998251365871325790, -0.998254320215894330, -0.998257272064827060, -0.998260221418116540, -0.998263168275755560, -0.998266112637736570, -0.998269054504052340, +-0.998271993874695560, -0.998274930749658670, -0.998277865128934460, -0.998280797012515710, -0.998283726400394870, -0.998286653292564720, -0.998289577689017940, -0.998292499589747200, +-0.998295418994745280, -0.998298335904004740, -0.998301250317518480, -0.998304162235278960, -0.998307071657279050, -0.998309978583511560, -0.998312883013969030, -0.998315784948644370, +-0.998318684387530130, -0.998321581330619210, -0.998324475777904400, -0.998327367729378360, -0.998330257185033990, -0.998333144144863850, -0.998336028608860950, -0.998338910577017960, +-0.998341790049327660, -0.998344667025782840, -0.998347541506376390, -0.998350413491101100, -0.998353282979949850, -0.998356149972915330, -0.998359014469990420, -0.998361876471168030, +-0.998364735976440820, -0.998367592985801910, -0.998370447499243970, -0.998373299516759900, -0.998376149038342600, -0.998378996063984840, -0.998381840593679740, -0.998384682627419970, +-0.998387522165198440, -0.998390359207008140, -0.998393193752841970, -0.998396025802692820, -0.998398855356553590, -0.998401682414417180, -0.998404506976276580, -0.998407329042124810, +-0.998410148611954540, -0.998412965685759100, -0.998415780263531170, -0.998418592345263760, -0.998421401930949860, -0.998424209020582490, -0.998427013614154530, -0.998429815711659120, +-0.998432615313089130, -0.998435412418437580, -0.998438207027697590, -0.998440999140862040, -0.998443788757923940, -0.998446575878876420, -0.998449360503712470, -0.998452142632425100, +-0.998454922265007320, -0.998457699401452240, -0.998460474041752980, -0.998463246185902540, -0.998466015833893940, -0.998468782985720280, -0.998471547641374800, -0.998474309800850280, +-0.998477069464140050, -0.998479826631237240, -0.998482581302134740, -0.998485333476825780, -0.998488083155303570, -0.998490830337561140, -0.998493575023591600, -0.998496317213388160, +-0.998499056906943850, -0.998501794104251990, -0.998504528805305600, -0.998507261010097900, -0.998509990718622010, -0.998512717930871150, -0.998515442646838560, -0.998518164866517340, +-0.998520884589900630, -0.998523601816981850, -0.998526316547753920, -0.998529028782210280, -0.998531738520344050, -0.998534445762148560, -0.998537150507616820, -0.998539852756742290, +-0.998542552509518070, -0.998545249765937500, -0.998547944525993820, -0.998550636789680260, -0.998553326556990140, -0.998556013827916700, -0.998558698602453170, -0.998561380880592870, +-0.998564060662329170, -0.998566737947655380, -0.998569412736564630, -0.998572085029050480, -0.998574754825106050, -0.998577422124724670, -0.998580086927899790, -0.998582749234624760, +-0.998585409044892790, -0.998588066358697350, -0.998590721176031650, -0.998593373496889150, -0.998596023321263290, -0.998598670649147310, -0.998601315480534770, -0.998603957815418770, +-0.998606597653793000, -0.998609234995650690, -0.998611869840985380, -0.998614502189790310, -0.998617132042058930, -0.998619759397784800, -0.998622384256961260, -0.998625006619581760, +-0.998627626485639740, -0.998630243855128660, -0.998632858728041970, -0.998635471104373120, -0.998638080984115660, -0.998640688367262940, -0.998643293253808520, -0.998645895643745840, +-0.998648495537068360, -0.998651092933769750, -0.998653687833843340, -0.998656280237282810, -0.998658870144081500, -0.998661457554232970, -0.998664042467730880, -0.998666624884568700, +-0.998669204804739860, -0.998671782228238050, -0.998674357155056810, -0.998676929585189720, -0.998679499518630220, -0.998682066955371980, -0.998684631895408680, -0.998687194338733650, +-0.998689754285340680, -0.998692311735223440, -0.998694866688375260, -0.998697419144790040, -0.998699969104461240, -0.998702516567382400, -0.998705061533547430, -0.998707604002949670, +-0.998710143975583000, -0.998712681451440990, -0.998715216430517190, -0.998717748912805400, -0.998720278898299170, -0.998722806386992400, -0.998725331378878420, -0.998727853873951240, +-0.998730373872204420, -0.998732891373631640, -0.998735406378226550, -0.998737918885983070, -0.998740428896894740, -0.998742936410955350, -0.998745441428158690, -0.998747943948498310, +-0.998750443971968100, -0.998752941498561750, -0.998755436528273140, -0.998757929061095840, -0.998760419097023840, -0.998762906636050720, -0.998765391678170360, -0.998767874223376430, +-0.998770354271662940, -0.998772831823023450, -0.998775306877451970, -0.998777779434942170, -0.998780249495487940, -0.998782717059083060, -0.998785182125721430, -0.998787644695396830, +-0.998790104768103150, -0.998792562343834180, -0.998795017422583810, -0.998797470004345820, -0.998799920089114220, -0.998802367676882910, -0.998804812767645540, -0.998807255361396250, +-0.998809695458128700, -0.998812133057837000, -0.998814568160514950, -0.998817000766156540, -0.998819430874755550, -0.998821858486306000, -0.998824283600801780, -0.998826706218236880, +-0.998829126338605210, -0.998831543961900660, -0.998833959088117340, -0.998836371717249150, -0.998838781849289980, -0.998841189484233840, -0.998843594622074730, -0.998845997262806650, +-0.998848397406423620, -0.998850795052919520, -0.998853190202288470, -0.998855582854524470, -0.998857973009621420, -0.998860360667573550, -0.998862745828374640, -0.998865128492019030, +-0.998867508658500490, -0.998869886327813260, -0.998872261499951230, -0.998874634174908630, -0.998877004352679340, -0.998879372033257610, -0.998881737216637420, -0.998884099902812910, +-0.998886460091778170, -0.998888817783527230, -0.998891172978054300, -0.998893525675353390, -0.998895875875418730, -0.998898223578244320, -0.998900568783824380, -0.998902911492153050, +-0.998905251703224310, -0.998907589417032620, -0.998909924633571870, -0.998912257352836290, -0.998914587574820100, -0.998916915299517430, -0.998919240526922380, -0.998921563257029410, +-0.998923883489832410, -0.998926201225325720, -0.998928516463503560, -0.998930829204360050, -0.998933139447889530, -0.998935447194086110, -0.998937752442944140, -0.998940055194457720, +-0.998942355448621200, -0.998944653205428800, -0.998946948464874750, -0.998949241226953390, -0.998951531491658830, -0.998953819258985520, -0.998956104528927580, -0.998958387301479460, +-0.998960667576635260, -0.998962945354389450, -0.998965220634736360, -0.998967493417670100, -0.998969763703185240, -0.998972031491275890, -0.998974296781936390, -0.998976559575161290, +-0.998978819870944720, -0.998981077669281130, -0.998983332970164730, -0.998985585773590090, -0.998987836079551550, -0.998990083888043330, -0.998992329199059890, -0.998994572012595670, +-0.998996812328645010, -0.998999050147202360, -0.999001285468262060, -0.999003518291818550, -0.999005748617866170, -0.999007976446399490, -0.999010201777412840, -0.999012424610900780, +-0.999014644946857540, -0.999016862785277790, -0.999019078126155760, -0.999021290969486110, -0.999023501315263300, -0.999025709163481550, -0.999027914514135640, -0.999030117367220030, +-0.999032317722729050, -0.999034515580657260, -0.999036710940999110, -0.999038903803749270, -0.999041094168902190, -0.999043282036452320, -0.999045467406394330, -0.999047650278722550, +-0.999049830653431780, -0.999052008530516340, -0.999054183909970920, -0.999056356791789950, -0.999058527175968210, -0.999060695062500060, -0.999062860451380260, -0.999065023342603280, +-0.999067183736163770, -0.999069341632056180, -0.999071497030275310, -0.999073649930815710, -0.999075800333672050, -0.999077948238838780, -0.999080093646310670, -0.999082236556082300, +-0.999084376968148450, -0.999086514882503550, -0.999088650299142400, -0.999090783218059660, -0.999092913639249900, -0.999095041562707900, -0.999097166988428210, -0.999099289916405730, +-0.999101410346634910, -0.999103528279110640, -0.999105643713827480, -0.999107756650780330, -0.999109867089963740, -0.999111975031372390, -0.999114080475001280, -0.999116183420844850, +-0.999118283868897890, -0.999120381819155300, -0.999122477271611850, -0.999124570226262110, -0.999126660683100960, -0.999128748642123090, -0.999130834103323480, -0.999132917066696710, +-0.999134997532237670, -0.999137075499941130, -0.999139150969801880, -0.999141223941814700, -0.999143294415974600, -0.999145362392276140, -0.999147427870714310, -0.999149490851284020, +-0.999151551333979930, -0.999153609318796930, -0.999155664805729930, -0.999157717794773690, -0.999159768285923230, -0.999161816279173330, -0.999163861774518990, -0.999165904771954880, +-0.999167945271476010, -0.999169983273077380, -0.999172018776753660, -0.999174051782499960, -0.999176082290311070, -0.999178110300182110, -0.999180135812107740, -0.999182158826083080, +-0.999184179342103020, -0.999186197360162560, -0.999188212880256610, -0.999190225902380050, -0.999192236426527990, -0.999194244452695330, -0.999196249980876970, -0.999198253011068130, +-0.999200253543263580, -0.999202251577458340, -0.999204247113647530, -0.999206240151826130, -0.999208230691989160, -0.999210218734131520, -0.999212204278248420, -0.999214187324334760, +-0.999216167872385540, -0.999218145922395990, -0.999220121474361120, -0.999222094528275930, -0.999224065084135530, -0.999226033141934810, -0.999227998701669230, -0.999229961763333450, +-0.999231922326922930, -0.999233880392432550, -0.999235835959857430, -0.999237789029192690, -0.999239739600433550, -0.999241687673575020, -0.999243633248612320, -0.999245576325540560, +-0.999247516904354760, -0.999249454985050240, -0.999251390567622020, -0.999253323652065430, -0.999255254238375470, -0.999257182326547370, -0.999259107916576240, -0.999261031008457420, +-0.999262951602186030, -0.999264869697757300, -0.999266785295166330, -0.999268698394408460, -0.999270608995478820, -0.999272517098372610, -0.999274422703085090, -0.999276325809611570, +-0.999278226417947280, -0.999280124528087340, -0.999282020140027090, -0.999283913253761870, -0.999285803869286780, -0.999287691986597280, -0.999289577605688480, -0.999291460726555720, +-0.999293341349194340, -0.999295219473599560, -0.999297095099766830, -0.999298968227691260, -0.999300838857368310, -0.999302706988793310, -0.999304572621961480, -0.999306435756868280, +-0.999308296393508930, -0.999310154531878880, -0.999312010171973350, -0.999313863313787910, -0.999315713957317770, -0.999317562102558400, -0.999319407749505010, -0.999321250898153160, +-0.999323091548498190, -0.999324929700535550, -0.999326765354260460, -0.999328598509668600, -0.999330429166755190, -0.999332257325515670, -0.999334082985945500, -0.999335906148040130, +-0.999337726811795000, -0.999339544977205560, -0.999341360644267260, -0.999343173812975550, -0.999344984483325980, -0.999346792655313900, -0.999348598328934750, -0.999350401504184190, +-0.999352202181057690, -0.999354000359550580, -0.999355796039658520, -0.999357589221376960, -0.999359379904701360, -0.999361168089627380, -0.999362953776150480, -0.999364736964266200, +-0.999366517653970110, -0.999368295845257660, -0.999370071538124520, -0.999371844732566130, -0.999373615428578170, -0.999375383626156190, -0.999377149325295750, -0.999378912525992420, +-0.999380673228241760, -0.999382431432039530, -0.999384187137381090, -0.999385940344262310, -0.999387691052678660, -0.999389439262625690, -0.999391184974099180, -0.999392928187094690, +-0.999394668901607890, -0.999396407117634440, -0.999398142835170030, -0.999399876054210100, -0.999401606774750650, -0.999403334996787130, -0.999405060720315210, -0.999406783945330670, +-0.999408504671829180, -0.999410222899806410, -0.999411938629258150, -0.999413651860179940, -0.999415362592567690, -0.999417070826416950, -0.999418776561723620, -0.999420479798483250, +-0.999422180536691850, -0.999423878776344870, -0.999425574517438190, -0.999427267759967600, -0.999428958503928880, -0.999430646749317700, -0.999432332496129950, -0.999434015744361300, +-0.999435696494007650, -0.999437374745064780, -0.999439050497528460, -0.999440723751394590, -0.999442394506658840, -0.999444062763317100, -0.999445728521365150, -0.999447391780798890, +-0.999449052541614200, -0.999450710803806870, -0.999452366567372800, -0.999454019832307860, -0.999455670598607740, -0.999457318866268540, -0.999458964635285940, -0.999460607905656050, +-0.999462248677374540, -0.999463886950437420, -0.999465522724840680, -0.999467156000580000, -0.999468786777651500, -0.999470415056051050, -0.999472040835774570, -0.999473664116817930, +-0.999475284899177140, -0.999476903182848210, -0.999478518967826910, -0.999480132254109480, -0.999481743041691570, -0.999483351330569310, -0.999484957120738700, -0.999486560412195750, +-0.999488161204936330, -0.999489759498956580, -0.999491355294252370, -0.999492948590819830, -0.999494539388654850, -0.999496127687753530, -0.999497713488111890, -0.999499296789726040, +-0.999500877592591870, -0.999502455896705500, -0.999504031702063030, -0.999505605008660480, -0.999507175816493950, -0.999508744125559460, -0.999510309935853100, -0.999511873247371010, +-0.999513434060109170, -0.999514992374063720, -0.999516548189230860, -0.999518101505606600, -0.999519652323187070, -0.999521200641968480, -0.999522746461946830, -0.999524289783118250, +-0.999525830605479060, -0.999527368929025270, -0.999528904753753000, -0.999530438079658580, -0.999531968906737900, -0.999533497234987410, -0.999535023064403230, -0.999536546394981350, +-0.999538067226718230, -0.999539585559609870, -0.999541101393652600, -0.999542614728842540, -0.999544125565175910, -0.999545633902649060, -0.999547139741258080, -0.999548643080999220, +-0.999550143921868810, -0.999551642263862950, -0.999553138106978100, -0.999554631451210260, -0.999556122296555990, -0.999557610643011300, -0.999559096490572620, -0.999560579839236300, +-0.999562060688998440, -0.999563539039855400, -0.999565014891803600, -0.999566488244839180, -0.999567959098958570, -0.999569427454158000, -0.999570893310434030, -0.999572356667782660, +-0.999573817526200450, -0.999575275885683730, -0.999576731746228850, -0.999578185107832030, -0.999579635970489820, -0.999581084334198570, -0.999582530198954490, -0.999583973564754150, +-0.999585414431593880, -0.999586852799470020, -0.999588288668379120, -0.999589722038317420, -0.999591152909281470, -0.999592581281267600, -0.999594007154272270, -0.999595430528292030, +-0.999596851403323110, -0.999598269779362060, -0.999599685656405330, -0.999601099034449380, -0.999602509913490760, -0.999603918293525790, -0.999605324174551060, -0.999606727556563100, +-0.999608128439558150, -0.999609526823532990, -0.999610922708484060, -0.999612316094407700, -0.999613706981300590, -0.999615095369159270, -0.999616481257980190, -0.999617864647759920, +-0.999619245538494900, -0.999620623930181810, -0.999621999822817190, -0.999623373216397600, -0.999624744110919510, -0.999626112506379560, -0.999627478402774330, -0.999628841800100480, +-0.999630202698354450, -0.999631561097532930, -0.999632916997632570, -0.999634270398649830, -0.999635621300581480, -0.999636969703423970, -0.999638315607174200, -0.999639659011828500, +-0.999640999917383750, -0.999642338323836420, -0.999643674231183280, -0.999645007639420990, -0.999646338548546120, -0.999647666958555450, -0.999648992869445530, -0.999650316281213260, +-0.999651637193855080, -0.999652955607367890, -0.999654271521748240, -0.999655584936993020, -0.999656895853098800, -0.999658204270062250, -0.999659510187880240, -0.999660813606549460, +-0.999662114526066680, -0.999663412946428580, -0.999664708867632030, -0.999666002289673620, -0.999667293212550210, -0.999668581636258600, -0.999669867560795460, -0.999671150986157660, +-0.999672431912342120, -0.999673710339345380, -0.999674986267164440, -0.999676259695795990, -0.999677530625236900, -0.999678799055483960, -0.999680064986533940, -0.999681328418383860, +-0.999682589351030490, -0.999683847784470610, -0.999685103718701120, -0.999686357153718900, -0.999687608089520730, -0.999688856526103510, -0.999690102463464240, -0.999691345901599690, +-0.999692586840506770, -0.999693825280182360, -0.999695061220623350, -0.999696294661826750, -0.999697525603789440, -0.999698754046508320, -0.999699979989980280, -0.999701203434202210, +-0.999702424379171230, -0.999703642824884220, -0.999704858771337970, -0.999706072218529700, -0.999707283166456180, -0.999708491615114550, -0.999709697564501560, -0.999710901014614350, +-0.999712101965450020, -0.999713300417005240, -0.999714496369277340, -0.999715689822263220, -0.999716880775959770, -0.999718069230364210, -0.999719255185473440, -0.999720438641284570, +-0.999721619597794490, -0.999722798055000420, -0.999723974012899360, -0.999725147471488440, -0.999726318430764540, -0.999727486890724990, -0.999728652851366580, -0.999729816312686540, +-0.999730977274682080, -0.999732135737350090, -0.999733291700687810, -0.999734445164692230, -0.999735596129360580, -0.999736744594689860, -0.999737890560677410, -0.999739034027320230, +-0.999740174994615320, -0.999741313462560120, -0.999742449431151540, -0.999743582900386900, -0.999744713870263310, -0.999745842340777900, -0.999746968311927890, -0.999748091783710490, +-0.999749212756122830, -0.999750331229162130, -0.999751447202825600, -0.999752560677110490, -0.999753671652013900, -0.999754780127533270, -0.999755886103665500, -0.999756989580408150, +-0.999758090557758330, -0.999759189035713260, -0.999760285014270170, -0.999761378493426500, -0.999762469473179260, -0.999763557953525890, -0.999764643934463630, -0.999765727415989680, +-0.999766808398101500, -0.999767886880796320, -0.999768962864071350, -0.999770036347924050, -0.999771107332351530, -0.999772175817351340, -0.999773241802920710, -0.999774305289056970, +-0.999775366275757470, -0.999776424763019530, -0.999777480750840610, -0.999778534239217920, -0.999779585228148800, -0.999780633717630930, -0.999781679707661300, -0.999782723198237580, +-0.999783764189356990, -0.999784802681016990, -0.999785838673215020, -0.999786872165948410, -0.999787903159214620, -0.999788931653011080, -0.999789957647335250, -0.999790981142184560, +-0.999792002137556370, -0.999793020633448100, -0.999794036629857330, -0.999795050126781490, -0.999796061124218040, -0.999797069622164410, -0.999798075620618180, -0.999799079119576660, +-0.999800080119037430, -0.999801078618998140, -0.999802074619456030, -0.999803068120408760, -0.999804059121853770, -0.999805047623788750, -0.999806033626211010, -0.999807017129118240, +-0.999807998132507980, -0.999808976636377580, -0.999809952640724810, -0.999810926145547230, -0.999811897150842290, -0.999812865656607540, -0.999813831662840660, -0.999814795169539310, +-0.999815756176700820, -0.999816714684322980, -0.999817670692403460, -0.999818624200939590, -0.999819575209929260, -0.999820523719370020, -0.999821469729259450, -0.999822413239595200, +-0.999823354250374830, -0.999824292761596230, -0.999825228773256750, -0.999826162285354260, -0.999827093297886440, -0.999828021810850840, -0.999828947824245140, -0.999829871338067110, +-0.999830792352314310, -0.999831710866984640, -0.999832626882075640, -0.999833540397585100, -0.999834451413510790, -0.999835359929850180, -0.999836265946601240, -0.999837169463761670, +-0.999838070481329220, -0.999838968999301470, -0.999839865017676410, -0.999840758536451600, -0.999841649555624930, -0.999842538075194190, -0.999843424095157030, -0.999844307615511350, +-0.999845188636254930, -0.999846067157385440, -0.999846943178900880, -0.999847816700798920, -0.999848687723077440, -0.999849556245734240, -0.999850422268767080, -0.999851285792173970, +-0.999852146815952580, -0.999853005340100800, -0.999853861364616510, -0.999854714889497620, -0.999855565914742010, -0.999856414440347340, -0.999857260466311740, -0.999858103992632860, +-0.999858945019308830, -0.999859783546337420, -0.999860619573716520, -0.999861453101444140, -0.999862284129518050, -0.999863112657936370, -0.999863938686696760, -0.999864762215797340, +-0.999865583245236110, -0.999866401775010850, -0.999867217805119560, -0.999868031335560240, -0.999868842366330890, -0.999869650897429410, -0.999870456928853790, -0.999871260460602040, +-0.999872061492672160, -0.999872860025062040, -0.999873656057769900, -0.999874449590793520, -0.999875240624131020, -0.999876029157780510, -0.999876815191739880, -0.999877598726007120, +-0.999878379760580470, -0.999879158295457810, -0.999879934330637270, -0.999880707866116940, -0.999881478901894830, -0.999882247437969050, -0.999883013474337610, -0.999883777010998620, +-0.999884538047950190, -0.999885296585190430, -0.999886052622717350, -0.999886806160529270, -0.999887557198624100, -0.999888305737000050, -0.999889051775655240, -0.999889795314587880, +-0.999890536353795880, -0.999891274893277670, -0.999892010933031260, -0.999892744473054760, -0.999893475513346400, -0.999894204053904390, -0.999894930094726850, -0.999895653635812010, +-0.999896374677157970, -0.999897093218763080, -0.999897809260625440, -0.999898522802743160, -0.999899233845114700, -0.999899942387738160, -0.999900648430611770, -0.999901351973733640, +-0.999902053017102220, -0.999902751560715730, -0.999903447604572280, -0.999904141148670210, -0.999904832193007740, -0.999905520737583320, -0.999906206782394950, -0.999906890327441180, +-0.999907571372720130, -0.999908249918230130, -0.999908925963969630, -0.999909599509936740, -0.999910270556129800, -0.999910939102547250, -0.999911605149187310, -0.999912268696048320, +-0.999912929743128730, -0.999913588290426870, -0.999914244337940960, -0.999914897885669450, -0.999915548933610680, -0.999916197481763080, -0.999916843530124890, -0.999917487078694660, +-0.999918128127470720, -0.999918766676451520, -0.999919402725635290, -0.999920036275020570, -0.999920667324605830, -0.999921295874389380, -0.999921921924369680, -0.999922545474545180, +-0.999923166524914420, -0.999923785075475640, -0.999924401126227380, -0.999925014677168100, -0.999925625728296350, -0.999926234279610580, -0.999926840331109120, -0.999927443882790650, +-0.999928044934653480, -0.999928643486696300, -0.999929239538917440, -0.999929833091315450, -0.999930424143888890, -0.999931012696636310, -0.999931598749556280, -0.999932182302647130, +-0.999932763355907530, -0.999933341909336030, -0.999933917962931180, -0.999934491516691560, -0.999935062570615710, -0.999935631124702300, -0.999936197178949660, -0.999936760733356580, +-0.999937321787921610, -0.999937880342643300, -0.999938436397520340, -0.999938989952551260, -0.999939541007734740, -0.999940089563069350, -0.999940635618553620, -0.999941179174186460, +-0.999941720229966300, -0.999942258785891820, -0.999942794841961690, -0.999943328398174680, -0.999943859454529240, -0.999944388011024140, -0.999944914067658170, -0.999945437624429780, +-0.999945958681337840, -0.999946477238381040, -0.999946993295558140, -0.999947506852867600, -0.999948017910308410, -0.999948526467879020, -0.999949032525578430, -0.999949536083405310, +-0.999950037141358220, -0.999950535699436150, -0.999951031757637670, -0.999951525315961650, -0.999952016374406780, -0.999952504932971830, -0.999952990991655690, -0.999953474550457130, +-0.999953955609374720, -0.999954434168407570, -0.999954910227554230, -0.999955383786813700, -0.999955854846184660, -0.999956323405665980, -0.999956789465256570, -0.999957253024955080, +-0.999957714084760530, -0.999958172644671680, -0.999958628704687440, -0.999959082264806560, -0.999959533325027960, -0.999959981885350510, -0.999960427945773220, -0.999960871506294760, +-0.999961312566914230, -0.999961751127630310, -0.999962187188441990, -0.999962620749348270, -0.999963051810348060, -0.999963480371440120, -0.999963906432623560, -0.999964329993897170, +-0.999964751055259950, -0.999965169616710890, -0.999965585678248890, -0.999965999239872950, -0.999966410301581950, -0.999966818863375020, -0.999967224925250920, -0.999967628487208880, +-0.999968029549247680, -0.999968428111366440, -0.999968824173564140, -0.999969217735839800, -0.999969608798192410, -0.999969997360620980, -0.999970383423124500, -0.999970766985702090, +-0.999971148048352850, -0.999971526611075690, -0.999971902673869710, -0.999972276236733900, -0.999972647299667510, -0.999973015862669400, -0.999973381925738810, -0.999973745488874850, +-0.999974106552076410, -0.999974465115342710, -0.999974821178672870, -0.999975174742065990, -0.999975525805521180, -0.999975874369037570, -0.999976220432614250, -0.999976563996250340, +-0.999976905059945080, -0.999977243623697550, -0.999977579687506890, -0.999977913251372310, -0.999978244315292920, -0.999978572879267950, -0.999978898943296500, -0.999979222507377810, +-0.999979543571511090, -0.999979862135695450, -0.999980178199930240, -0.999980491764214550, -0.999980802828547620, -0.999981111392928670, -0.999981417457357020, -0.999981721021831800, +-0.999982022086352230, -0.999982320650917630, -0.999982616715527240, -0.999982910280180270, -0.999983201344876060, -0.999983489909613830, -0.999983775974392920, -0.999984059539212540, +-0.999984340604071930, -0.999984619168970630, -0.999984895233907660, -0.999985168798882550, -0.999985439863894430, -0.999985708428942740, -0.999985974494026710, -0.999986238059145880, +-0.999986499124299380, -0.999986757689486640, -0.999987013754707000, -0.999987267319959790, -0.999987518385244470, -0.999987766950560350, -0.999988013015906780, -0.999988256581283210, +-0.999988497646689070, -0.999988736212123590, -0.999988972277586320, -0.999989205843076490, -0.999989436908593770, -0.999989665474137480, -0.999989891539706970, -0.999990115105301780, +-0.999990336170921260, -0.999990554736564840, -0.999990770802232090, -0.999990984367922440, -0.999991195433635350, -0.999991403999370140, -0.999991610065126600, -0.999991813630903950, +-0.999992014696701740, -0.999992213262519520, -0.999992409328356760, -0.999992602894212990, -0.999992793960087670, -0.999992982525980460, -0.999993168591890690, -0.999993352157818040, +-0.999993533223762050, -0.999993711789722180, -0.999993887855698090, -0.999994061421689230, -0.999994232487695140, -0.999994401053715620, -0.999994567119749990, -0.999994730685798030, +-0.999994891751859180, -0.999995050317933120, -0.999995206384019400, -0.999995359950117680, -0.999995511016227630, -0.999995659582348710, -0.999995805648480670, -0.999995949214623090, +-0.999996090280775740, -0.999996228846938060, -0.999996364913109840, -0.999996498479290730, -0.999996629545480410, -0.999996758111678430, -0.999996884177884570, -0.999997007744098500, +-0.999997128810319990, -0.999997247376548600, -0.999997363442784120, -0.999997477009026190, -0.999997588075274610, -0.999997696641529040, -0.999997802707789150, -0.999997906274054830, +-0.999998007340325730, -0.999998105906601650, -0.999998201972882250, -0.999998295539167410, -0.999998386605456810, -0.999998475171750220, -0.999998561238047420, -0.999998644804348300, +-0.999998725870652530, -0.999998804436959880, -0.999998880503270350, -0.999998954069583500, -0.999999025135899330, -0.999999093702217620, -0.999999159768538040, -0.999999223334860690, +-0.999999284401185240, -0.999999342967511580, -0.999999399033839610, -0.999999452600169090, -0.999999503666499920, -0.999999552232832100, -0.999999598299165290, -0.999999641865499500, +-0.999999682931834610, -0.999999721498170510, -0.999999757564507100, -0.999999791130844360, -0.999999822197182090, -0.999999850763520270, -0.999999876829858910, -0.999999900396197680, +-0.999999921462536800, -0.999999940028876160, -0.999999956095215640, -0.999999969661555240, -0.999999980727894870, -0.999999989294234610, -0.999999995360574270, -0.999999998926914050, +-0.999999999993253730, -0.999999998559593540, -0.999999994625933250, -0.999999988192273090, -0.999999979258612840, -0.999999967824952710, -0.999999953891292590, -0.999999937457632600, +-0.999999918523972850, -0.999999897090313230, -0.999999873156653950, -0.999999846722994910, -0.999999817789336220, -0.999999786355678100, -0.999999752422020440, -0.999999715988363350, +-0.999999677054707050, -0.999999635621051540, -0.999999591687396940, -0.999999545253743350, -0.999999496320091000, -0.999999444886439770, -0.999999390952790000, -0.999999334519141690, +-0.999999275585495170, -0.999999214151850340, -0.999999150218207510, -0.999999083784566810, -0.999999014850928350, -0.999998943417292450, -0.999998869483659130, -0.999998793050028700, +-0.999998714116401180, -0.999998632682777000, -0.999998548749156170, -0.999998462315538910, -0.999998373381925540, -0.999998281948316300, -0.999998188014711300, -0.999998091581110860, +-0.999997992647515100, -0.999997891213924460, -0.999997787280339060, -0.999997680846759220, -0.999997571913185170, -0.999997460479617130, -0.999997346546055540, -0.999997230112500520, +-0.999997111178952400, -0.999996989745411510, -0.999996865811878190, -0.999996739378352760, -0.999996610444835340, -0.999996479011326490, -0.999996345077826420, -0.999996208644335470, +-0.999996069710853970, -0.999995928277382370, -0.999995784343920890, -0.999995637910470080, -0.999995488977030060, -0.999995337543601260, -0.999995183610184250, -0.999995027176779240, +-0.999994868243386570, -0.999994706810006790, -0.999994542876640360, -0.999994376443287370, -0.999994207509948610, -0.999994036076624290, -0.999993862143314760, -0.999993685710020670, +-0.999993506776742370, -0.999993325343480290, -0.999993141410234990, -0.999992954977006690, -0.999992766043796060, -0.999992574610603540, -0.999992380677429570, -0.999992184244274610, +-0.999991985311139310, -0.999991783878023900, -0.999991579944929150, -0.999991373511855300, -0.999991164578803100, -0.999990953145773020, -0.999990739212765600, -0.999990522779781290, +-0.999990303846820640, -0.999990082413884210, -0.999989858480972550, -0.999989632048086330, -0.999989403115225990, -0.999989171682392210, -0.999988937749585420, -0.999988701316806280, +-0.999988462384055480, -0.999988220951333440, -0.999987977018640840, -0.999987730585978340, -0.999987481653346500, -0.999987230220745980, -0.999986976288177340, -0.999986719855641360, +-0.999986460923138480, -0.999986199490669470, -0.999985935558234900, -0.999985669125835640, -0.999985400193472040, -0.999985128761145090, -0.999984854828855240, -0.999984578396603260, +-0.999984299464389830, -0.999984018032215700, -0.999983734100081460, -0.999983447667987970, -0.999983158735935800, -0.999982867303925720, -0.999982573371958510, -0.999982276940034830, +-0.999981978008155470, -0.999981676576321200, -0.999981372644532680, -0.999981066212790700, -0.999980757281096140, -0.999980445849449670, -0.999980131917852070, -0.999979815486304210, +-0.999979496554806670, -0.999979175123360540, -0.999978851191966390, -0.999978524760625100, -0.999978195829337560, -0.999977864398104430, -0.999977530466926720, -0.999977194035805210, +-0.999976855104740660, -0.999976513673733970, -0.999976169742786030, -0.999975823311897600, -0.999975474381069710, -0.999975122950303110, -0.999974769019598700, -0.999974412588957250, +-0.999974053658379880, -0.999973692227867360, -0.999973328297420690, -0.999972961867040540, -0.999972592936728130, -0.999972221506484130, -0.999971847576309640, -0.999971471146205550, +-0.999971092216172750, -0.999970710786212250, -0.999970326856324920, -0.999969940426511770, -0.999969551496773800, -0.999969160067111900, -0.999968766137527170, -0.999968369708020500, +-0.999967970778592900, -0.999967569349245360, -0.999967165419978990, -0.999966758990794570, -0.999966350061693320, -0.999965938632676240, -0.999965524703744220, -0.999965108274898480, +-0.999964689346139910, -0.999964267917469620, -0.999963843988888710, -0.999963417560398080, -0.999962988631999060, -0.999962557203692430, -0.999962123275479510, -0.999961686847361200, +-0.999961247919338710, -0.999960806491413170, -0.999960362563585560, -0.999959916135857000, -0.999959467208228700, -0.999959015780701680, -0.999958561853277140, -0.999958105425956200, +-0.999957646498740080, -0.999957185071629780, -0.999956721144626530, -0.999956254717731420, -0.999955785790945680, -0.999955314364270540, -0.999954840437707100, -0.999954364011256480, +-0.999953885084920000, -0.999953403658698890, -0.999952919732594150, -0.999952433306607210, -0.999951944380739090, -0.999951452954991220, -0.999950959029364590, -0.999950462603860670, +-0.999949963678480550, -0.999949462253225560, -0.999948958328096830, -0.999948451903095780, -0.999947942978223540, -0.999947431553481540, -0.999946917628870890, -0.999946401204392930, +-0.999945882280048990, -0.999945360855840400, -0.999944836931768390, -0.999944310507834170, -0.999943781584039290, -0.999943250160384990, -0.999942716236872480, -0.999942179813503200, +-0.999941640890278480, -0.999941099467199670, -0.999940555544268080, -0.999940009121485060, -0.999939460198852050, -0.999938908776370480, -0.999938354854041590, -0.999937798431866810, +-0.999937239509847480, -0.999936678087985030, -0.999936114166281030, -0.999935547744736590, -0.999934978823353360, -0.999934407402132690, -0.999933833481076010, -0.999933257060184770, +-0.999932678139460300, -0.999932096718904150, -0.999931512798517770, -0.999930926378302610, -0.999930337458260210, -0.999929746038391910, -0.999929152118699260, -0.999928555699183710, +-0.999927956779846800, -0.999927355360689880, -0.999926751441714720, -0.999926145022922650, -0.999925536104315120, -0.999924924685893890, -0.999924310767660310, -0.999923694349615920, +-0.999923075431762290, -0.999922454014100960, -0.999921830096633490, -0.999921203679361550, -0.999920574762286460, -0.999919943345410010, -0.999919309428733750, -0.999918673012259120, +-0.999918034095987780, -0.999917392679921520, -0.999916748764061670, -0.999916102348409890, -0.999915453432967950, -0.999914802017737410, -0.999914148102719720, -0.999913491687916770, +-0.999912832773330100, -0.999912171358961270, -0.999911507444812050, -0.999910841030884120, -0.999910172117179030, -0.999909500703698550, -0.999908826790444240, -0.999908150377417980, +-0.999907471464621220, -0.999906790052055850, -0.999906106139723530, -0.999905419727625810, -0.999904730815764700, -0.999904039404141740, -0.999903345492758610, -0.999902649081617190, +-0.999901950170719030, -0.999901248760066140, -0.999900544849660070, -0.999899838439502590, -0.999899129529595590, -0.999898418119940740, -0.999897704210539810, -0.999896987801394690, +-0.999896268892507050, -0.999895547483878660, -0.999894823575511520, -0.999894097167407290, -0.999893368259567870, -0.999892636851994920, -0.999891902944690440, -0.999891166537656200, +-0.999890427630894090, -0.999889686224405880, -0.999888942318193360, -0.999888195912258640, -0.999887447006603370, -0.999886695601229450, -0.999885941696138760, -0.999885185291333300, +-0.999884426386814850, -0.999883664982585300, -0.999882901078646640, -0.999882134675000640, -0.999881365771649430, -0.999880594368594780, -0.999879820465838560, -0.999879044063382790, +-0.999878265161229460, -0.999877483759380570, -0.999876699857837780, -0.999875913456603320, -0.999875124555679170, -0.999874333155067130, -0.999873539254769180, -0.999872742854787440, +-0.999871943955123910, -0.999871142555780470, -0.999870338656759120, -0.999869532258061970, -0.999868723359691010, -0.999867911961648260, -0.999867098063935700, -0.999866281666555450, +-0.999865462769509380, -0.999864641372799730, -0.999863817476428500, -0.999862991080397670, -0.999862162184709360, -0.999861330789365680, -0.999860496894368620, -0.999859660499720420, +-0.999858821605422940, -0.999857980211478540, -0.999857136317889080, -0.999856289924656800, -0.999855441031783810, -0.999854589639272210, -0.999853735747124220, -0.999852879355341840, +-0.999852020463927180, -0.999851159072882580, -0.999850295182210020, -0.999849428791911740, -0.999848559901989840, -0.999847688512446650, -0.999846814623284170, -0.999845938234504630, +-0.999845059346110340, -0.999844177958103320, -0.999843294070485890, -0.999842407683260160, -0.999841518796428460, -0.999840627409993020, -0.999839733523955940, -0.999838837138319560, +-0.999837938253086090, -0.999837036868257760, -0.999836132983836780, -0.999835226599825600, -0.999834317716226220, -0.999833406333041070, -0.999832492450272500, -0.999831576067922610, +-0.999830657185993840, -0.999829735804488420, -0.999828811923408560, -0.999827885542756810, -0.999826956662535290, -0.999826025282746330, -0.999825091403392370, -0.999824155024475640, +-0.999823216145998560, -0.999822274767963480, -0.999821330890372620, -0.999820384513228520, -0.999819435636533420, -0.999818484260289630, -0.999817530384499720, -0.999816574009166010, +-0.999815615134290850, -0.999814653759876660, -0.999813689885925780, -0.999812723512440770, -0.999811754639423840, -0.999810783266877670, -0.999809809394804460, -0.999808833023206670, +-0.999807854152086840, -0.999806872781447420, -0.999805888911290740, -0.999804902541619470, -0.999803913672435820, -0.999802922303742460, -0.999801928435541720, -0.999800932067836160, +-0.999799933200628320, -0.999798931833920660, -0.999797927967715610, -0.999796921602015830, -0.999795912736823670, -0.999794901372141780, -0.999793887507972600, -0.999792871144318700, +-0.999791852281182610, -0.999790830918566910, -0.999789807056474130, -0.999788780694906840, -0.999787751833867590, -0.999786720473359040, -0.999785686613383630, -0.999784650253943920, +-0.999783611395042680, -0.999782570036682360, -0.999781526178865730, -0.999780479821595120, -0.999779430964873430, -0.999778379608703190, -0.999777325753086870, -0.999776269398027330, +-0.999775210543527030, -0.999774149189588850, -0.999773085336215120, -0.999772018983408840, -0.999770950131172450, -0.999769878779508630, -0.999768804928420130, -0.999767728577909740, +-0.999766649727979910, -0.999765568378633510, -0.999764484529873100, -0.999763398181701570, -0.999762309334121470, -0.999761217987135690, -0.999760124140746780, -0.999759027794957620, +-0.999757928949770890, -0.999756827605189360, -0.999755723761215690, -0.999754617417852760, -0.999753508575103260, -0.999752397232969940, -0.999751283391455690, -0.999750167050563300, +-0.999749048210295420, -0.999747926870654830, -0.999746803031644540, -0.999745676693267190, -0.999744547855525690, -0.999743416518422800, -0.999742282681961410, -0.999741146346144300, +-0.999740007510974250, -0.999738866176454240, -0.999737722342587070, -0.999736576009375600, -0.999735427176822730, -0.999734275844931240, -0.999733122013704010, -0.999731965683144040, +-0.999730806853254110, -0.999729645524037200, -0.999728481695496220, -0.999727315367633930, -0.999726146540453440, -0.999724975213957530, -0.999723801388149200, -0.999722625063031440, +-0.999721446238607040, -0.999720264914878980, -0.999719081091850370, -0.999717894769524000, -0.999716705947902850, -0.999715514626990040, -0.999714320806788350, -0.999713124487300870, +-0.999711925668530620, -0.999710724350480580, -0.999709520533153650, -0.999708314216552930, -0.999707105400681530, -0.999705894085542220, -0.999704680271138240, -0.999703463957472670, +-0.999702245144548310, -0.999701023832368360, -0.999699800020935840, -0.999698573710253830, -0.999697344900325360, -0.999696113591153620, -0.999694879782741520, -0.999693643475092260, +-0.999692404668208860, -0.999691163362094400, -0.999689919556752130, -0.999688673252185020, -0.999687424448396200, -0.999686173145388880, -0.999684919343166060, -0.999683663041731060, +-0.999682404241086790, -0.999681142941236560, -0.999679879142183370, -0.999678612843930670, -0.999677344046481230, -0.999676072749838610, -0.999674798954005680, -0.999673522658985790, +-0.999672243864782150, -0.999670962571397870, -0.999669678778836170, -0.999668392487100270, -0.999667103696193380, -0.999665812406118850, -0.999664518616879660, -0.999663222328479150, +-0.999661923540920650, -0.999660622254207380, -0.999659318468342440, -0.999658012183329280, -0.999656703399171120, -0.999655392115871180, -0.999654078333432670, -0.999652762051859050, +-0.999651443271153520, -0.999650121991319420, -0.999648798212359970, -0.999647471934278500, -0.999646143157078340, -0.999644811880762930, -0.999643478105335380, -0.999642141830799140, +-0.999640803057157630, -0.999639461784414100, -0.999638118012571850, -0.999636771741634340, -0.999635422971604900, -0.999634071702486860, -0.999632717934283650, -0.999631361666998730, +-0.999630002900635310, -0.999628641635196940, -0.999627277870686950, -0.999625911607108790, -0.999624542844465780, -0.999623171582761480, -0.999621797821999230, -0.999620421562182560, +-0.999619042803314710, -0.999617661545399330, -0.999616277788439760, -0.999614891532439540, -0.999613502777402020, -0.999612111523330850, -0.999610717770229360, -0.999609321518101000, +-0.999607922766949430, -0.999606521516777980, -0.999605117767590310, -0.999603711519389760, -0.999602302772179980, -0.999600891525964430, -0.999599477780746650, -0.999598061536530190, +-0.999596642793318610, -0.999595221551115350, -0.999593797809924080, -0.999592371569748340, -0.999590942830591580, -0.999589511592457570, -0.999588077855349750, -0.999586641619271690, +-0.999585202884227030, -0.999583761650219450, -0.999582317917252380, -0.999580871685329500, -0.999579422954454460, -0.999577971724630920, -0.999576517995862450, -0.999575061768152580, +-0.999573603041505110, -0.999572141815923690, -0.999570678091411870, -0.999569211867973430, -0.999567743145611810, -0.999566271924330900, -0.999564798204134350, -0.999563321985025840, +-0.999561843267008920, -0.999560362050087470, -0.999558878334265040, -0.999557392119545530, -0.999555903405932370, -0.999554412193429550, -0.999552918482040750, -0.999551422271769630, +-0.999549923562619960, -0.999548422354595400, -0.999546918647699840, -0.999545412441936950, -0.999543903737310610, -0.999542392533824490, -0.999540878831482350, -0.999539362630287980, +-0.999537843930245250, -0.999536322731357950, -0.999534799033629740, -0.999533272837064610, -0.999531744141666230, -0.999530212947438600, -0.999528679254385380, -0.999527143062510450, +-0.999525604371817700, -0.999524063182310910, -0.999522519493993960, -0.999520973306870730, -0.999519424620945010, -0.999517873436220780, -0.999516319752701940, -0.999514763570392150, +-0.999513204889295510, -0.999511643709415920, -0.999510080030757140, -0.999508513853323290, -0.999506945177118020, -0.999505374002145450, -0.999503800328409350, -0.999502224155913830, +-0.999500645484662780, -0.999499064314660070, -0.999497480645909710, -0.999495894478415690, -0.999494305812181900, -0.999492714647212340, -0.999491120983511010, -0.999489524821081890, +-0.999487926159928870, -0.999486325000056080, -0.999484721341467490, -0.999483115184167100, -0.999481506528158930, -0.999479895373447060, -0.999478281720035390, -0.999476665567927910, +-0.999475046917128850, -0.999473425767642200, -0.999471802119472060, -0.999470175972622330, -0.999468547327097110, -0.999466916182900620, -0.999465282540036750, -0.999463646398509710, +-0.999462007758323610, -0.999460366619482340, -0.999458722981990340, -0.999457076845851390, -0.999455428211069810, -0.999453777077649710, -0.999452123445595090, -0.999450467314910160, +-0.999448808685599150, -0.999447147557666060, -0.999445483931115100, -0.999443817805950370, -0.999442149182176220, -0.999440478059796520, -0.999438804438815830, -0.999437128319238030, +-0.999435449701067350, -0.999433768584308100, -0.999432084968964520, -0.999430398855040590, -0.999428710242540760, -0.999427019131469140, -0.999425325521829940, -0.999423629413627390, +-0.999421930806865810, -0.999420229701549420, -0.999418526097682450, -0.999416819995269210, -0.999415111394313830, -0.999413400294820730, -0.999411686696794140, -0.999409970600238280, +-0.999408252005157480, -0.999406530911556180, -0.999404807319438370, -0.999403081228808720, -0.999401352639671230, -0.999399621552030440, -0.999397887965890570, -0.999396151881255970, +-0.999394413298131060, -0.999392672216520060, -0.999390928636427310, -0.999389182557857360, -0.999387433980814420, -0.999385682905302830, -0.999383929331327030, -0.999382173258891560, +-0.999380414688000540, -0.999378653618658410, -0.999376890050869830, -0.999375123984638900, -0.999373355419970190, -0.999371584356868130, -0.999369810795337040, -0.999368034735381380, +-0.999366256177005810, -0.999364475120214420, -0.999362691565012010, -0.999360905511402780, -0.999359116959391280, -0.999357325908981960, -0.999355532360179380, -0.999353736312987960, +-0.999351937767412160, -0.999350136723456520, -0.999348333181125590, -0.999346527140423820, -0.999344718601355760, -0.999342907563925850, -0.999341094028138640, -0.999339277993998800, +-0.999337459461510650, -0.999335638430678960, -0.999333814901508080, -0.999331988874002760, -0.999330160348167350, -0.999328329324006610, -0.999326495801525110, -0.999324659780727260, +-0.999322821261617760, -0.999320980244201240, -0.999319136728482270, -0.999317290714465510, -0.999315442202155510, -0.999313591191556830, -0.999311737682674230, -0.999309881675512270, +-0.999308023170075610, -0.999306162166368920, -0.999304298664396850, -0.999302432664163960, -0.999300564165675030, -0.999298693168934600, -0.999296819673947570, -0.999294943680718360, +-0.999293065189251870, -0.999291184199552760, -0.999289300711625690, -0.999287414725475220, -0.999285526241106340, -0.999283635258523590, -0.999281741777731880, -0.999279845798735630, +-0.999277947321539850, -0.999276046346149190, -0.999274142872568440, -0.999272236900802360, -0.999270328430855610, -0.999268417462733090, -0.999266503996439570, -0.999264588031979710, +-0.999262669569358390, -0.999260748608580500, -0.999258825149650590, -0.999256899192573660, -0.999254970737354590, -0.999253039783997930, -0.999251106332508800, -0.999249170382891850, +-0.999247231935151970, -0.999245290989294040, -0.999243347545322850, -0.999241401603243260, -0.999239453163060290, -0.999237502224778580, -0.999235548788403150, -0.999233592853938870, +-0.999231634421390510, -0.999229673490763190, -0.999227710062061570, -0.999225744135290750, -0.999223775710455510, -0.999221804787560950, -0.999219831366611740, -0.999217855447613100, +-0.999215877030569690, -0.999213896115486610, -0.999211912702368870, -0.999209926791221340, -0.999207938382048910, -0.999205947474856690, -0.999203954069649570, -0.999201958166432540, +-0.999199959765210700, -0.999197958865988940, -0.999195955468772270, -0.999193949573565670, -0.999191941180374240, -0.999189930289202890, -0.999187916900056820, -0.999185901012940910, +-0.999183882627860290, -0.999181861744819930, -0.999179838363824850, -0.999177812484880250, -0.999175784107991130, -0.999173753233162490, -0.999171719860399540, -0.999169683989707180, +-0.999167645621090730, -0.999165604754555070, -0.999163561390105540, -0.999161515527747010, -0.999159467167484610, -0.999157416309323640, -0.999155362953269120, -0.999153307099326260, +-0.999151248747500050, -0.999149187897795720, -0.999147124550218370, -0.999145058704773330, -0.999142990361465590, -0.999140919520300370, -0.999138846181282900, -0.999136770344418170, +-0.999134692009711610, -0.999132611177168340, -0.999130527846793570, -0.999128442018592410, -0.999126353692570190, -0.999124262868732020, -0.999122169547083330, -0.999120073727629120, +-0.999117975410374730, -0.999115874595325360, -0.999113771282486350, -0.999111665471862920, -0.999109557163460280, -0.999107446357283880, -0.999105333053338710, -0.999103217251630320, +-0.999101098952163810, -0.999098978154944530, -0.999096854859977900, -0.999094729067269150, -0.999092600776823490, -0.999090469988646370, -0.999088336702743000, -0.999086200919118930, +-0.999084062637779270, -0.999081921858729460, -0.999079778581974830, -0.999077632807520710, -0.999075484535372650, -0.999073333765535750, -0.999071180498015580, -0.999069024732817450, +-0.999066866469946690, -0.999064705709408860, -0.999062542451209290, -0.999060376695353300, -0.999058208441846340, -0.999056037690693950, -0.999053864441901360, -0.999051688695474120, +-0.999049510451417770, -0.999047329709737530, -0.999045146470439070, -0.999042960733527610, -0.999040772499008910, -0.999038581766888200, -0.999036388537171030, -0.999034192809862830, +-0.999031994584969270, -0.999029793862495570, -0.999027590642447500, -0.999025384924830510, -0.999023176709649910, -0.999020965996911480, -0.999018752786620560, -0.999016537078782800, +-0.999014318873403750, -0.999012098170488750, -0.999009874970043680, -0.999007649272073750, -0.999005421076584850, -0.999003190383582320, -0.999000957193071800, -0.998998721505058970, +-0.998996483319549270, -0.998994242636548350, -0.998991999456061870, -0.998989753778095400, -0.998987505602654480, -0.998985254929744880, -0.998983001759372050, -0.998980746091541860, +-0.998978487926259650, -0.998976227263531300, -0.998973964103362370, -0.998971698445758500, -0.998969430290725380, -0.998967159638268760, -0.998964886488394210, -0.998962610841107380, +-0.998960332696414150, -0.998958052054319980, -0.998955768914830730, -0.998953483277951970, -0.998951195143689570, -0.998948904512049210, -0.998946611383036640, -0.998944315756657430, +-0.998942017632917460, -0.998939717011822490, -0.998937413893378200, -0.998935108277590360, -0.998932800164464730, -0.998930489554007090, -0.998928176446223340, -0.998925860841119010, +-0.998923542738700100, -0.998921222138972280, -0.998918899041941530, -0.998916573447613420, -0.998914245355993930, -0.998911914767088850, -0.998909581680903940, -0.998907246097445080, +-0.998904908016718050, -0.998902567438728850, -0.998900224363483140, -0.998897878790986900, -0.998895530721246040, -0.998893180154266200, -0.998890827090053500, -0.998888471528613820, +-0.998886113469952820, -0.998883752914076610, -0.998881389860991060, -0.998879024310701970, -0.998876656263215310, -0.998874285718536980, -0.998871912676672970, -0.998869537137629270, +-0.998867159101411660, -0.998864778568026130, -0.998862395537478690, -0.998860010009775200, -0.998857621984921670, -0.998855231462924210, -0.998852838443788580, -0.998850442927520900, +-0.998848044914127040, -0.998845644403613120, -0.998843241395985130, -0.998840835891248950, -0.998838427889410800, -0.998836017390476450, -0.998833604394452120, -0.998831188901343810, +-0.998828770911157520, -0.998826350423899220, -0.998823927439575040, -0.998821501958191190, -0.998819073979753450, -0.998816643504268130, -0.998814210531741130, -0.998811775062178550, +-0.998809337095586610, -0.998806896631971310, -0.998804453671338850, -0.998802008213695140, -0.998799560259046480, -0.998797109807398890, -0.998794656858758460, -0.998792201413131520, +-0.998789743470523960, -0.998787283030942110, -0.998784820094392070, -0.998782354660879950, -0.998779886730411960, -0.998777416302994210, -0.998774943378632930, -0.998772467957334320, +-0.998769990039104600, -0.998767509623949780, -0.998765026711876280, -0.998762541302890110, -0.998760053396997690, -0.998757562994205150, -0.998755070094518580, -0.998752574697944430, +-0.998750076804488800, -0.998747576414158010, -0.998745073526958290, -0.998742568142895860, -0.998740060261977040, -0.998737549884208040, -0.998735037009595210, -0.998732521638144740, +-0.998730003769862980, -0.998727483404756140, -0.998724960542830660, -0.998722435184092760, -0.998719907328548870, -0.998717376976205110, -0.998714844127067900, -0.998712308781143590, +-0.998709770938438600, -0.998707230598959050, -0.998704687762711480, -0.998702142429702230, -0.998699594599937620, -0.998697044273423980, -0.998694491450167750, -0.998691936130175260, +-0.998689378313452950, -0.998686818000007250, -0.998684255189844490, -0.998681689882971010, -0.998679122079393360, -0.998676551779117960, -0.998673978982151040, -0.998671403688499270, +-0.998668825898168970, -0.998666245611166680, -0.998663662827498740, -0.998661077547171590, -0.998658489770191780, -0.998655899496565750, -0.998653306726299930, -0.998650711459400870, +-0.998648113695875030, -0.998645513435728940, -0.998642910678969040, -0.998640305425601780, -0.998637697675633930, -0.998635087429071700, -0.998632474685921760, -0.998629859446190760, +-0.998627241709884930, -0.998624621477011140, -0.998621998747575730, -0.998619373521585360, -0.998616745799046470, -0.998614115579965820, -0.998611482864349860, -0.998608847652205140, +-0.998606209943538330, -0.998603569738356070, -0.998600927036664810, -0.998598281838471210, -0.998595634143781940, -0.998592983952603650, -0.998590331264942790, -0.998587676080806120, +-0.998585018400200310, -0.998582358223131910, -0.998579695549607680, -0.998577030379634190, -0.998574362713218090, -0.998571692550366040, -0.998569019891084820, -0.998566344735381080, +-0.998563667083261500, -0.998560986934732610, -0.998558304289801410, -0.998555619148474350, -0.998552931510758300, -0.998550241376659820, -0.998547548746185900, -0.998544853619342980, +-0.998542155996137940, -0.998539455876577550, -0.998536753260668600, -0.998534048148417620, -0.998531340539831610, -0.998528630434917130, -0.998525917833681160, -0.998523202736130490, +-0.998520485142271650, -0.998517765052111650, -0.998515042465657250, -0.998512317382915350, -0.998509589803892480, -0.998506859728595760, -0.998504127157031850, -0.998501392089207630, +-0.998498654525129870, -0.998495914464805570, -0.998493171908241380, -0.998490426855444310, -0.998487679306421240, -0.998484929261178930, -0.998482176719724280, -0.998479421682064160, +-0.998476664148205460, -0.998473904118155180, -0.998471141591920070, -0.998468376569507270, -0.998465609050923300, -0.998462839036175500, -0.998460066525270530, -0.998457291518215380, +-0.998454514015016950, -0.998451734015682320, -0.998448951520218290, -0.998446166528631940, -0.998443379040930170, -0.998440589057119960, -0.998437796577208210, -0.998435001601202020, +-0.998432204129108380, -0.998429404160934180, -0.998426601696686400, -0.998423796736372160, -0.998420989279998450, -0.998418179327572260, -0.998415366879100710, -0.998412551934590550, +-0.998409734494049130, -0.998406914557483430, -0.998404092124900330, -0.998401267196307060, -0.998398439771710610, -0.998395609851118080, -0.998392777434536470, -0.998389942521973000, +-0.998387105113434650, -0.998384265208928530, -0.998381422808461650, -0.998378577912041320, -0.998375730519674540, -0.998372880631368420, -0.998370028247130060, -0.998367173366966680, +-0.998364315990885380, -0.998361456118893260, -0.998358593750997450, -0.998355728887205250, -0.998352861527523670, -0.998349991671960040, -0.998347119320521340, -0.998344244473214790, +-0.998341367130047730, -0.998338487291027140, -0.998335604956160470, -0.998332720125454710, -0.998329832798917180, -0.998326942976555000, -0.998324050658375480, -0.998321155844385970, +-0.998318258534593440, -0.998315358729005230, -0.998312456427628780, -0.998309551630471080, -0.998306644337539460, -0.998303734548841360, -0.998300822264383770, -0.998297907484174240, +-0.998294990208219880, -0.998292070436528120, -0.998289148169106080, -0.998286223405961290, -0.998283296147100870, -0.998280366392532150, -0.998277434142262670, -0.998274499396299530, +-0.998271562154650070, -0.998268622417321730, -0.998265680184321940, -0.998262735455657910, -0.998259788231336990, -0.998256838511366600, -0.998253886295754180, -0.998250931584506950, +-0.998247974377632460, -0.998245014675138040, -0.998242052477031020, -0.998239087783318930, -0.998236120594009120, -0.998233150909108910, -0.998230178728625960, -0.998227204052567480, +-0.998224226880941030, -0.998221247213754050, -0.998218265051013850, -0.998215280392728000, -0.998212293238904040, -0.998209303589549290, -0.998206311444671310, -0.998203316804277540, +-0.998200319668375410, -0.998197320036972590, -0.998194317910076400, -0.998191313287694500, -0.998188306169834230, -0.998185296556503230, -0.998182284447708960, -0.998179269843458950, +-0.998176252743760870, -0.998173233148622050, -0.998170211058050260, -0.998167186472052830, -0.998164159390637520, -0.998161129813811780, -0.998158097741583260, -0.998155063173959410, +-0.998152026110948000, -0.998148986552556460, -0.998145944498792460, -0.998142899949663540, -0.998139852905177480, -0.998136803365341720, -0.998133751330164020, -0.998130696799651830, +-0.998127639773813020, -0.998124580252655050, -0.998121518236185670, -0.998118453724412440, -0.998115386717343120, -0.998112317214985280, -0.998109245217346670, -0.998106170724434970, +-0.998103093736257830, -0.998100014252822910, -0.998096932274137980, -0.998093847800210820, -0.998090760831048970, -0.998087671366660210, -0.998084579407052200, -0.998081484952232810, +-0.998078388002209720, -0.998075288556990680, -0.998072186616583370, -0.998069082180995660, -0.998065975250235220, -0.998062865824309810, -0.998059753903227210, -0.998056639486995300, +-0.998053522575621740, -0.998050403169114420, -0.998047281267481100, -0.998044156870729450, -0.998041029978867570, -0.998037900591903000, -0.998034768709843760, -0.998031634332697480, +-0.998028497460472290, -0.998025358093175720, -0.998022216230815770, -0.998019071873400330, -0.998015925020937170, -0.998012775673434270, -0.998009623830899420, -0.998006469493340380, +-0.998003312660765250, -0.998000153333181930, -0.997996991510598060, -0.997993827193021880, -0.997990660380461030, -0.997987491072923500, -0.997984319270417310, -0.997981144972950320, +-0.997977968180530420, -0.997974788893165600, -0.997971607110863860, -0.997968422833633070, -0.997965236061481240, -0.997962046794416360, -0.997958855032446300, -0.997955660775579180, +-0.997952464023822760, -0.997949264777185260, -0.997946063035674680, -0.997942858799298890, -0.997939652068065900, -0.997936442841983800, -0.997933231121060690, -0.997930016905304360, +-0.997926800194723020, -0.997923580989324770, -0.997920359289117490, -0.997917135094109290, -0.997913908404308380, -0.997910679219722540, -0.997907447540360090, -0.997904213366229030, +-0.997900976697337460, -0.997897737533693370, -0.997894495875304990, -0.997891251722180290, -0.997888005074327510, -0.997884755931754740, -0.997881504294470090, -0.997878250162481660, +-0.997874993535797670, -0.997871734414426110, -0.997868472798375210, -0.997865208687653160, -0.997861942082268080, -0.997858672982228190, -0.997855401387541590, -0.997852127298216480, +-0.997848850714260990, -0.997845571635683440, -0.997842290062491920, -0.997839005994694770, -0.997835719432299980, -0.997832430375315990, -0.997829138823750910, -0.997825844777612940, +-0.997822548236910410, -0.997819249201651440, -0.997815947671844450, -0.997812643647497440, -0.997809337128618970, -0.997806028115217130, -0.997802716607300130, -0.997799402604876430, +-0.997796086107954230, -0.997792767116541750, -0.997789445630647310, -0.997786121650279360, -0.997782795175446100, -0.997779466206155760, -0.997776134742416890, -0.997772800784237580, +-0.997769464331626280, -0.997766125384591420, -0.997762783943141110, -0.997759440007283890, -0.997756093577028100, -0.997752744652382060, -0.997749393233354210, -0.997746039319952760, +-0.997742682912186260, -0.997739324010063160, -0.997735962613591650, -0.997732598722780200, -0.997729232337637330, -0.997725863458171380, -0.997722492084390680, -0.997719118216303770, +-0.997715741853919200, -0.997712362997245080, -0.997708981646290180, -0.997705597801062830, -0.997702211461571450, -0.997698822627824500, -0.997695431299830630, -0.997692037477598050, +-0.997688641161135430, -0.997685242350451200, -0.997681841045553910, -0.997678437246451890, -0.997675030953153910, -0.997671622165668290, -0.997668210884003590, -0.997664797108168470, +-0.997661380838171240, -0.997657962074020580, -0.997654540815725130, -0.997651117063293240, -0.997647690816733550, -0.997644262076054610, -0.997640830841264980, -0.997637397112373430, +-0.997633960889388270, -0.997630522172318180, -0.997627080961171920, -0.997623637255957820, -0.997620191056684760, -0.997616742363361060, -0.997613291175995620, -0.997609837494596970, +-0.997606381319173670, -0.997602922649734380, -0.997599461486287860, -0.997595997828842670, -0.997592531677407470, -0.997589063031991020, -0.997585591892601760, -0.997582118259248580, +-0.997578642131940140, -0.997575163510685090, -0.997571682395492100, -0.997568198786369930, -0.997564712683327360, -0.997561224086372820, -0.997557732995515310, -0.997554239410763490, +-0.997550743332126120, -0.997547244759611760, -0.997543743693229400, -0.997540240132987590, -0.997536734078895200, -0.997533225530961020, -0.997529714489193810, -0.997526200953602230, +-0.997522684924195160, -0.997519166400981370, -0.997515645383969750, -0.997512121873168960, -0.997508595868587870, -0.997505067370235250, -0.997501536378120000, -0.997498002892250880, +-0.997494466912636770, -0.997490928439286550, -0.997487387472209000, -0.997483844011412880, -0.997480298056907190, -0.997476749608700810, -0.997473198666802510, -0.997469645231221280, +-0.997466089301965900, -0.997462530879045240, -0.997458969962468300, -0.997455406552243960, -0.997451840648381110, -0.997448272250888610, -0.997444701359775480, -0.997441127975050470, +-0.997437552096722800, -0.997433973724801140, -0.997430392859294580, -0.997426809500212120, -0.997423223647562530, -0.997419635301354910, -0.997416044461598260, -0.997412451128301460, +-0.997408855301473500, -0.997405256981123370, -0.997401656167260180, -0.997398052859892800, -0.997394447059030350, -0.997390838764681710, -0.997387227976856080, -0.997383614695562250, +-0.997379998920809420, -0.997376380652606590, -0.997372759890962860, -0.997369136635887220, -0.997365510887388780, -0.997361882645476430, -0.997358251910159480, -0.997354618681446920, +-0.997350982959347760, -0.997347344743871100, -0.997343704035026150, -0.997340060832821900, -0.997336415137267560, -0.997332766948372140, -0.997329116266144730, -0.997325463090594670, +-0.997321807421730820, -0.997318149259562530, -0.997314488604098880, -0.997310825455348990, -0.997307159813321960, -0.997303491678027120, -0.997299821049473570, -0.997296147927670410, +-0.997292472312626970, -0.997288794204352240, -0.997285113602855540, -0.997281430508146110, -0.997277744920233020, -0.997274056839125620, -0.997270366264833120, -0.997266673197364620, +-0.997262977636729550, -0.997259279582936920, -0.997255579035996150, -0.997251875995916470, -0.997248170462707080, -0.997244462436377210, -0.997240751916936170, -0.997237038904393300, +-0.997233323398757920, -0.997229605400039130, -0.997225884908246260, -0.997222161923388750, -0.997218436445475920, -0.997214708474516880, -0.997210978010521170, -0.997207245053497890, +-0.997203509603456610, -0.997199771660406520, -0.997196031224356960, -0.997192288295317360, -0.997188542873297060, -0.997184794958305360, -0.997181044550351730, -0.997177291649445350, +-0.997173536255595900, -0.997169778368812600, -0.997166017989104760, -0.997162255116481930, -0.997158489750953450, -0.997154721892528740, -0.997150951541217250, -0.997147178697028400, +-0.997143403359971540, -0.997139625530056200, -0.997135845207291820, -0.997132062391687720, -0.997128277083253580, -0.997124489281998700, -0.997120698987932650, -0.997116906201064860, +-0.997113110921404750, -0.997109313148961900, -0.997105512883745710, -0.997101710125765760, -0.997097904875031580, -0.997094097131552610, -0.997090286895338410, -0.997086474166398510, +-0.997082658944742350, -0.997078841230379600, -0.997075021023319690, -0.997071198323572270, -0.997067373131146910, -0.997063545446053020, -0.997059715268300280, -0.997055882597898350, +-0.997052047434856650, -0.997048209779184850, -0.997044369630892490, -0.997040526989989240, -0.997036681856484640, -0.997032834230388350, -0.997028984111709930, -0.997025131500459130, +-0.997021276396645510, -0.997017418800278610, -0.997013558711368210, -0.997009696129923960, -0.997005831055955420, -0.997001963489472340, -0.996998093430484290, -0.996994220879001030, +-0.996990345835032210, -0.996986468298587500, -0.996982588269676670, -0.996978705748309380, -0.996974820734495280, -0.996970933228244150, -0.996967043229565750, -0.996963150738469640, +-0.996959255754965800, -0.996955358279063670, -0.996951458310773140, -0.996947555850104080, -0.996943650897066050, -0.996939743451668910, -0.996935833513922450, -0.996931921083836330, +-0.996928006161420520, -0.996924088746684590, -0.996920168839638520, -0.996916246440291980, -0.996912321548654830, -0.996908394164736870, -0.996904464288547840, -0.996900531920097750, +-0.996896597059396370, -0.996892659706453470, -0.996888719861278920, -0.996884777523882490, -0.996880832694274190, -0.996876885372463770, -0.996872935558461130, -0.996868983252276240, +-0.996865028453918780, -0.996861071163398840, -0.996857111380726190, -0.996853149105910830, -0.996849184338962520, -0.996845217079891270, -0.996841247328706940, -0.996837275085419530, +-0.996833300350038920, -0.996829323122575000, -0.996825343403037860, -0.996821361191437380, -0.996817376487783460, -0.996813389292086070, -0.996809399604355220, -0.996805407424600890, +-0.996801412752832960, -0.996797415589061650, -0.996793415933296730, -0.996789413785548200, -0.996785409145826250, -0.996781402014140670, -0.996777392390501670, -0.996773380274919130, +-0.996769365667403260, -0.996765348567963840, -0.996761328976611070, -0.996757306893355070, -0.996753282318205700, -0.996749255251173190, -0.996745225692267530, -0.996741193641498710, +-0.996737159098877060, -0.996733122064412450, -0.996729082538114990, -0.996725040519994890, -0.996720996010062140, -0.996716949008326970, -0.996712899514799360, -0.996708847529489520, +-0.996704793052407560, -0.996700736083563580, -0.996696676622967790, -0.996692614670630310, -0.996688550226561330, -0.996684483290770970, -0.996680413863269330, -0.996676341944066730, +-0.996672267533173280, -0.996668190630599080, -0.996664111236354460, -0.996660029350449620, -0.996655944972894670, -0.996651858103699830, -0.996647768742875310, -0.996643676890431430, +-0.996639582546378300, -0.996635485710726240, -0.996631386383485470, -0.996627284564666320, -0.996623180254278870, -0.996619073452333470, -0.996614964158840430, -0.996610852373809860, +-0.996606738097252310, -0.996602621329177870, -0.996598502069596880, -0.996594380318519550, -0.996590256075956420, -0.996586129341917480, -0.996582000116413290, -0.996577868399454170, +-0.996573734191050330, -0.996569597491212100, -0.996565458299949910, -0.996561316617274100, -0.996557172443194970, -0.996553025777722980, -0.996548876620868330, -0.996544724972641570, +-0.996540570833052920, -0.996536414202112920, -0.996532255079831900, -0.996528093466220180, -0.996523929361288200, -0.996519762765046500, -0.996515593677505310, -0.996511422098675160, +-0.996507248028566380, -0.996503071467189640, -0.996498892414555030, -0.996494710870673320, -0.996490526835554840, -0.996486340309210020, -0.996482151291649300, -0.996477959782883230, +-0.996473765782922350, -0.996469569291776880, -0.996465370309457700, -0.996461168835974910, -0.996456964871339280, -0.996452758415561250, -0.996448549468651250, -0.996444338030619940, +-0.996440124101477750, -0.996435907681235360, -0.996431688769903070, -0.996427467367491660, -0.996423243474011460, -0.996419017089473220, -0.996414788213887510, -0.996410556847264760, +-0.996406322989615510, -0.996402086640950650, -0.996397847801280490, -0.996393606470615700, -0.996389362648966830, -0.996385116336344630, -0.996380867532759670, -0.996376616238222490, +-0.996372362452743740, -0.996368106176334200, -0.996363847409004300, -0.996359586150764810, -0.996355322401626280, -0.996351056161599580, -0.996346787430695160, -0.996342516208923780, +-0.996338242496296100, -0.996333966292822890, -0.996329687598514700, -0.996325406413382300, -0.996321122737436340, -0.996316836570687590, -0.996312547913146830, -0.996308256764824600, +-0.996303963125731770, -0.996299666995879020, -0.996295368375277210, -0.996291067263936790, -0.996286763661868860, -0.996282457569083960, -0.996278148985592860, -0.996273837911406450, +-0.996269524346535480, -0.996265208290990630, -0.996260889744782880, -0.996256568707922780, -0.996252245180421330, -0.996247919162289160, -0.996243590653537290, -0.996239259654176480, +-0.996234926164217380, -0.996230590183671110, -0.996226251712548310, -0.996221910750859860, -0.996217567298616660, -0.996213221355829460, -0.996208872922509260, -0.996204521998666940, +-0.996200168584313260, -0.996195812679459220, -0.996191454284115600, -0.996187093398293370, -0.996182730022003300, -0.996178364155256510, -0.996173995798063760, -0.996169624950436040, +-0.996165251612384340, -0.996160875783919430, -0.996156497465052300, -0.996152116655793950, -0.996147733356155360, -0.996143347566147420, -0.996138959285781000, -0.996134568515067320, +-0.996130175254017150, -0.996125779502641580, -0.996121381260951620, -0.996116980528958030, -0.996112577306672130, -0.996108171594104810, -0.996103763391266940, -0.996099352698169740, +-0.996094939514824200, -0.996090523841241190, -0.996086105677431940, -0.996081685023407440, -0.996077261879178670, -0.996072836244756840, -0.996068408120152850, -0.996063977505377900, +-0.996059544400442860, -0.996055108805359080, -0.996050670720137530, -0.996046230144789320, -0.996041787079325450, -0.996037341523757220, -0.996032893478095540, -0.996028442942351710, +-0.996023989916536730, -0.996019534400661710, -0.996015076394737960, -0.996010615898776490, -0.996006152912788490, -0.996001687436785080, -0.995997219470777460, -0.995992749014776750, +-0.995988276068794250, -0.995983800632840980, -0.995979322706928240, -0.995974842291067250, -0.995970359385269120, -0.995965873989545060, -0.995961386103906390, -0.995956895728364100, +-0.995952402862929740, -0.995947907507614310, -0.995943409662429110, -0.995938909327385380, -0.995934406502494320, -0.995929901187767360, -0.995925393383215620, -0.995920883088850300, +-0.995916370304682830, -0.995911855030724440, -0.995907337266986440, -0.995902817013480160, -0.995898294270216700, -0.995893769037207610, -0.995889241314463990, -0.995884711101997390, +-0.995880178399818900, -0.995875643207939980, -0.995871105526372040, -0.995866565355126300, -0.995862022694214090, -0.995857477543646840, -0.995852929903435990, -0.995848379773592750, +-0.995843827154128450, -0.995839272045054740, -0.995834714446382830, -0.995830154358124050, -0.995825591780289950, -0.995821026712891850, -0.995816459155941190, -0.995811889109449400, +-0.995807316573427910, -0.995802741547888060, -0.995798164032841380, -0.995793584028299320, -0.995789001534273300, -0.995784416550774760, -0.995779829077815150, -0.995775239115406000, +-0.995770646663558750, -0.995766051722284830, -0.995761454291595900, -0.995756854371503300, -0.995752251962018440, -0.995747647063153110, -0.995743039674918620, -0.995738429797326410, +-0.995733817430388250, -0.995729202574115570, -0.995724585228519810, -0.995719965393612630, -0.995715343069405460, -0.995710718255910070, -0.995706090953137780, -0.995701461161100250, +-0.995696828879809150, -0.995692194109275900, -0.995687556849512160, -0.995682917100529590, -0.995678274862339730, -0.995673630134954140, -0.995668982918384460, -0.995664333212642470, +-0.995659681017739500, -0.995655026333687300, -0.995650369160497650, -0.995645709498181990, -0.995641047346752070, -0.995636382706219570, -0.995631715576596130, -0.995627045957893420, +-0.995622373850122980, -0.995617699253296680, -0.995613022167426090, -0.995608342592523070, -0.995603660528599050, -0.995598975975665930, -0.995594288933735360, -0.995589599402819100, +-0.995584907382928820, -0.995580212874076280, -0.995575515876273240, -0.995570816389531380, -0.995566114413862450, -0.995561409949278220, -0.995556702995790580, -0.995551993553411060, +-0.995547281622151560, -0.995542567202023940, -0.995537850293039870, -0.995533130895211120, -0.995528409008549660, -0.995523684633067060, -0.995518957768775300, -0.995514228415686150, +-0.995509496573811380, -0.995504762243162980, -0.995500025423752600, -0.995495286115592130, -0.995490544318693440, -0.995485800033068520, -0.995481053258728930, -0.995476303995686870, +-0.995471552243953890, -0.995466798003542100, -0.995462041274463360, -0.995457282056729450, -0.995452520350352370, -0.995447756155343980, -0.995442989471716280, -0.995438220299481040, +-0.995433448638650240, -0.995428674489235780, -0.995423897851249630, -0.995419118724703790, -0.995414337109610140, -0.995409553005980660, -0.995404766413827360, -0.995399977333161990, +-0.995395185763996770, -0.995390391706343580, -0.995385595160214410, -0.995380796125621250, -0.995375994602576090, -0.995371190591091030, -0.995366384091177950, -0.995361575102848840, +-0.995356763626115800, -0.995351949660990940, -0.995347133207486130, -0.995342314265613480, -0.995337492835385080, -0.995332668916812930, -0.995327842509909130, -0.995323013614685670, +-0.995318182231154760, -0.995313348359328390, -0.995308511999218550, -0.995303673150837560, -0.995298831814197320, -0.995293987989310010, -0.995289141676187650, -0.995284292874842550, +-0.995279441585286690, -0.995274587807532200, -0.995269731541591260, -0.995264872787476000, -0.995260011545198500, -0.995255147814771090, -0.995250281596205770, -0.995245412889514620, +-0.995240541694710100, -0.995235668011804190, -0.995230791840808980, -0.995225913181736920, -0.995221032034600110, -0.995216148399410640, -0.995211262276180840, -0.995206373664922820, +-0.995201482565648890, -0.995196588978371270, -0.995191692903102280, -0.995186794339853910, -0.995181893288638600, -0.995176989749468550, -0.995172083722356100, -0.995167175207313350, +-0.995162264204352720, -0.995157350713486320, -0.995152434734726700, -0.995147516268085840, -0.995142595313576290, -0.995137671871210270, -0.995132745940999990, -0.995127817522957980, +-0.995122886617096250, -0.995117953223427440, -0.995113017341963670, -0.995108078972717360, -0.995103138115700950, -0.995098194770926540, -0.995093248938406780, -0.995088300618153900, +-0.995083349810180100, -0.995078396514498140, -0.995073440731120030, -0.995068482460058410, -0.995063521701325500, -0.995058558454933850, -0.995053592720895770, -0.995048624499223820, +-0.995043653789930200, -0.995038680593027470, -0.995033704908528050, -0.995028726736444380, -0.995023746076788780, -0.995018762929573920, -0.995013777294812110, -0.995008789172515900, +-0.995003798562697720, -0.994998805465370010, -0.994993809880545310, -0.994988811808236060, -0.994983811248454810, -0.994978808201213980, -0.994973802666526240, -0.994968794644403910, +-0.994963784134859640, -0.994958771137905870, -0.994953755653555150, -0.994948737681820130, -0.994943717222713130, -0.994938694276246930, -0.994933668842434060, -0.994928640921286860, +-0.994923610512818190, -0.994918577617040390, -0.994913542233966220, -0.994908504363608230, -0.994903464005978840, -0.994898421161090950, -0.994893375828956870, -0.994888328009589480, +-0.994883277703001110, -0.994878224909204740, -0.994873169628212590, -0.994868111860037650, -0.994863051604692460, -0.994857988862189570, -0.994852923632541740, -0.994847855915761640, +-0.994842785711861800, -0.994837713020855110, -0.994832637842754110, -0.994827560177571460, -0.994822480025319920, -0.994817397386012160, -0.994812312259660940, -0.994807224646279020, +-0.994802134545878960, -0.994797041958473520, -0.994791946884075570, -0.994786849322697670, -0.994781749274352700, -0.994776646739053310, -0.994771541716812370, -0.994766434207642550, +-0.994761324211556610, -0.994756211728567430, -0.994751096758687670, -0.994745979301930090, -0.994740859358307690, -0.994735736927833130, -0.994730612010519160, -0.994725484606378770, +-0.994720354715424530, -0.994715222337669510, -0.994710087473126390, -0.994704950121808040, -0.994699810283727340, -0.994694667958897160, -0.994689523147330170, -0.994684375849039460, +-0.994679226064037800, -0.994674073792338190, -0.994668919033953270, -0.994663761788896040, -0.994658602057179490, -0.994653439838816380, -0.994648275133819700, -0.994643107942202230, +-0.994637938263977060, -0.994632766099157070, -0.994627591447755140, -0.994622414309784260, -0.994617234685257310, -0.994612052574187390, -0.994606867976587150, -0.994601680892469920, +-0.994596491321848350, -0.994591299264735660, -0.994586104721144610, -0.994580907691088310, -0.994575708174579850, -0.994570506171632010, -0.994565301682257990, -0.994560094706470670, +-0.994554885244283150, -0.994549673295708310, -0.994544458860759480, -0.994539241939449310, -0.994534022531791130, -0.994528800637797920, -0.994523576257482670, -0.994518349390858480, +-0.994513120037938350, -0.994507888198735480, -0.994502653873262870, -0.994497417061533720, -0.994492177763560910, -0.994486935979357780, -0.994481691708937190, -0.994476444952312470, +-0.994471195709496490, -0.994465943980502700, -0.994460689765343960, -0.994455433064033500, -0.994450173876584410, -0.994444912203010010, -0.994439648043323190, -0.994434381397537370, +-0.994429112265665550, -0.994423840647720940, -0.994418566543716740, -0.994413289953666070, -0.994408010877582240, -0.994402729315478350, -0.994397445267367620, -0.994392158733263360, +-0.994386869713178690, -0.994381578207126800, -0.994376284215120920, -0.994370987737174360, -0.994365688773300450, -0.994360387323512170, -0.994355083387822970, -0.994349776966246050, +-0.994344468058794730, -0.994339156665482230, -0.994333842786321860, -0.994328526421326850, -0.994323207570510510, -0.994317886233886170, -0.994312562411467040, -0.994307236103266660, +-0.994301907309298130, -0.994296576029574770, -0.994291242264109920, -0.994285906012917110, -0.994280567276009440, -0.994275226053400460, -0.994269882345103270, -0.994264536151131530, +-0.994259187471498330, -0.994253836306217220, -0.994248482655301520, -0.994243126518764560, -0.994237767896619880, -0.994232406788880700, -0.994227043195560540, -0.994221677116672750, +-0.994216308552230750, -0.994210937502247980, -0.994205563966737870, -0.994200187945713960, -0.994194809439189480, -0.994189428447177950, -0.994184044969692930, -0.994178659006747730, +-0.994173270558355910, -0.994167879624530900, -0.994162486205286240, -0.994157090300635260, -0.994151691910591720, -0.994146291035168830, -0.994140887674380250, -0.994135481828239410, +-0.994130073496759860, -0.994124662679955250, -0.994119249377838910, -0.994113833590424380, -0.994108415317725310, -0.994102994559755260, -0.994097571316527650, -0.994092145588056140, +-0.994086717374354280, -0.994081286675435600, -0.994075853491313670, -0.994070417822002230, -0.994064979667514610, -0.994059539027864590, -0.994054095903065700, -0.994048650293131720, +-0.994043202198075960, -0.994037751617912190, -0.994032298552654070, -0.994026843002315250, -0.994021384966909280, -0.994015924446449930, -0.994010461440950620, -0.994004995950425240, +-0.993999527974887440, -0.993994057514350770, -0.993988584568828880, -0.993983109138335540, -0.993977631222884520, -0.993972150822489350, -0.993966667937163820, -0.993961182566921670, +-0.993955694711776470, -0.993950204371742090, -0.993944711546832280, -0.993939216237060500, -0.993933718442440830, -0.993928218162986820, -0.993922715398712240, -0.993917210149630970, +-0.993911702415756550, -0.993906192197102970, -0.993900679493683880, -0.993895164305513060, -0.993889646632604370, -0.993884126474971490, -0.993878603832628380, -0.993873078705588720, +-0.993867551093866370, -0.993862020997475120, -0.993856488416428930, -0.993850953350741360, -0.993845415800426510, -0.993839875765498150, -0.993834333245969930, -0.993828788241856050, +-0.993823240753170080, -0.993817690779926100, -0.993812138322137880, -0.993806583379819310, -0.993801025952984250, -0.993795466041646700, -0.993789903645820430, -0.993784338765519410, +-0.993778771400757430, -0.993773201551548690, -0.993767629217906840, -0.993762054399846000, -0.993756477097380020, -0.993750897310522800, -0.993745315039288310, -0.993739730283690560, +-0.993734143043743520, -0.993728553319461080, -0.993722961110857340, -0.993717366417946060, -0.993711769240741450, -0.993706169579257390, -0.993700567433507990, -0.993694962803507110, +-0.993689355689268860, -0.993683746090807120, -0.993678134008136090, -0.993672519441269660, -0.993666902390222040, -0.993661282855007100, -0.993655660835638940, -0.993650036332131670, +-0.993644409344499270, -0.993638779872755950, -0.993633147916915590, -0.993627513476992300, -0.993621876553000270, -0.993616237144953620, -0.993610595252866320, -0.993604950876752600, +-0.993599304016626440, -0.993593654672502050, -0.993588002844393410, -0.993582348532314860, -0.993576691736280490, -0.993571032456304290, -0.993565370692400580, -0.993559706444583470, +-0.993554039712867040, -0.993548370497265520, -0.993542698797793000, -0.993537024614463800, -0.993531347947292030, -0.993525668796292010, -0.993519987161477600, -0.993514303042863370, +-0.993508616440463400, -0.993502927354291800, -0.993497235784362890, -0.993491541730690990, -0.993485845193290080, -0.993480146172174730, -0.993474444667358900, -0.993468740678856930, +-0.993463034206683250, -0.993457325250851840, -0.993451613811377250, -0.993445899888273480, -0.993440183481555050, -0.993434464591236190, -0.993428743217331100, -0.993423019359854220, +-0.993417293018819760, -0.993411564194242040, -0.993405832886135380, -0.993400099094514210, -0.993394362819392750, -0.993388624060785430, -0.993382882818706460, -0.993377139093170380, +-0.993371392884191410, -0.993365644191783970, -0.993359893015962390, -0.993354139356741220, -0.993348383214134540, -0.993342624588156920, -0.993336863478822770, -0.993331099886146540, +-0.993325333810142430, -0.993319565250824990, -0.993313794208208760, -0.993308020682307950, -0.993302244673137100, -0.993296466180710660, -0.993290685205043040, -0.993284901746148700, +-0.993279115804042160, -0.993273327378737750, -0.993267536470250010, -0.993261743078593500, -0.993255947203782630, -0.993250148845831850, -0.993244348004755810, -0.993238544680568710, +-0.993232738873285450, -0.993226930582920220, -0.993221119809487680, -0.993215306553002390, -0.993209490813478760, -0.993203672590931450, -0.993197851885374900, -0.993192028696823770, +-0.993186203025292590, -0.993180374870795910, -0.993174544233348280, -0.993168711112964230, -0.993162875509658430, -0.993157037423445520, -0.993151196854339950, -0.993145353802356360, +-0.993139508267509410, -0.993133660249813750, -0.993127809749283830, -0.993121956765934510, -0.993116101299780120, -0.993110243350835640, -0.993104382919115510, -0.993098520004634390, +-0.993092654607407030, -0.993086786727447990, -0.993080916364772030, -0.993075043519393690, -0.993069168191327840, -0.993063290380589050, -0.993057410087191950, -0.993051527311151430, +-0.993045642052482020, -0.993039754311198510, -0.993033864087315640, -0.993027971380848080, -0.993022076191810710, -0.993016178520218060, -0.993010278366084910, -0.993004375729426130, +-0.992998470610256370, -0.992992563008590510, -0.992986652924443210, -0.992980740357829240, -0.992974825308763460, -0.992968907777260550, -0.992962987763335470, -0.992957065267002890, +-0.992951140288277580, -0.992945212827174520, -0.992939282883708360, -0.992933350457893990, -0.992927415549746280, -0.992921478159280000, -0.992915538286510020, -0.992909595931451340, +-0.992903651094118490, -0.992897703774526570, -0.992891753972690360, -0.992885801688624840, -0.992879846922344770, -0.992873889673865140, -0.992867929943200720, -0.992861967730366500, +-0.992856003035377350, -0.992850035858248160, -0.992844066198993900, -0.992838094057629570, -0.992832119434169820, -0.992826142328629980, -0.992820162741024580, -0.992814180671368950, +-0.992808196119677740, -0.992802209085966170, -0.992796219570248990, -0.992790227572541210, -0.992784233092858020, -0.992778236131214080, -0.992772236687624600, -0.992766234762104570, +-0.992760230354668980, -0.992754223465332710, -0.992748214094110960, -0.992742202241018720, -0.992736187906070880, -0.992730171089282630, -0.992724151790668970, -0.992718130010244780, +-0.992712105748025490, -0.992706079004025740, -0.992700049778260870, -0.992694018070745860, -0.992687983881495930, -0.992681947210525830, -0.992675908057851000, -0.992669866423486420, +-0.992663822307447100, -0.992657775709748220, -0.992651726630404910, -0.992645675069432350, -0.992639621026845550, -0.992633564502659720, -0.992627505496889940, -0.992621444009551430, +-0.992615380040659300, -0.992609313590228750, -0.992603244658274870, -0.992597173244812890, -0.992591099349858010, -0.992585022973425320, -0.992578944115530050, -0.992572862776187500, +-0.992566778955412790, -0.992560692653221110, -0.992554603869627680, -0.992548512604647830, -0.992542418858296640, -0.992536322630589330, -0.992530223921541330, -0.992524122731167750, +-0.992518019059483780, -0.992511912906504870, -0.992505804272246110, -0.992499693156722820, -0.992493579559950320, -0.992487463481943940, -0.992481344922718890, -0.992475223882290370, +-0.992469100360673820, -0.992462974357884550, -0.992456845873937900, -0.992450714908849060, -0.992444581462633480, -0.992438445535306470, -0.992432307126883240, -0.992426166237379340, +-0.992420022866809970, -0.992413877015190570, -0.992407728682536460, -0.992401577868863070, -0.992395424574185720, -0.992389268798519740, -0.992383110541880660, -0.992376949804283810, +-0.992370786585744510, -0.992364620886278410, -0.992358452705900620, -0.992352282044626670, -0.992346108902472100, -0.992339933279452250, -0.992333755175582530, -0.992327574590878500, +-0.992321391525355370, -0.992315205979028890, -0.992309017951914400, -0.992302827444027310, -0.992296634455383190, -0.992290438985997450, -0.992284241035885640, -0.992278040605063190, +-0.992271837693545770, -0.992265632301348570, -0.992259424428487470, -0.992253214074977690, -0.992247001240834870, -0.992240785926074560, -0.992234568130712310, -0.992228347854763660, +-0.992222125098244150, -0.992215899861169310, -0.992209672143554710, -0.992203441945415880, -0.992197209266768580, -0.992190974107628130, -0.992184736468010200, -0.992178496347930540, +-0.992172253747404590, -0.992166008666448110, -0.992159761105076530, -0.992153511063305520, -0.992147258541150710, -0.992141003538627890, -0.992134746055752470, -0.992128486092540120, +-0.992122223649006710, -0.992115958725167670, -0.992109691321038660, -0.992103421436635550, -0.992097149071973770, -0.992090874227069210, -0.992084596901937400, -0.992078317096594110, +-0.992072034811054990, -0.992065750045335810, -0.992059462799452340, -0.992053173073420110, -0.992046880867255010, -0.992040586180972680, -0.992034289014588900, -0.992027989368119420, +-0.992021687241579910, -0.992015382634986230, -0.992009075548354050, -0.992002765981699230, -0.991996453935037440, -0.991990139408384540, -0.991983822401756310, -0.991977502915168510, +-0.991971180948637010, -0.991964856502177470, -0.991958529575805880, -0.991952200169537890, -0.991945868283389380, -0.991939533917376210, -0.991933197071514280, -0.991926857745819350, +-0.991920515940307170, -0.991914171654993850, -0.991907824889894930, -0.991901475645026620, -0.991895123920404460, -0.991888769716044670, -0.991882413031962780, -0.991876053868175010, +-0.991869692224697010, -0.991863328101544760, -0.991856961498734260, -0.991850592416281370, -0.991844220854201990, -0.991837846812511970, -0.991831470291227420, -0.991825091290364110, +-0.991818709809938140, -0.991812325849965370, -0.991805939410461800, -0.991799550491443420, -0.991793159092926090, -0.991786765214925920, -0.991780368857458790, -0.991773970020540800, +-0.991767568704187810, -0.991761164908415930, -0.991754758633241250, -0.991748349878679550, -0.991741938644747020, -0.991735524931459560, -0.991729108738833350, -0.991722690066884400, +-0.991716268915628700, -0.991709845285082330, -0.991703419175261280, -0.991696990586181770, -0.991690559517859780, -0.991684125970311300, -0.991677689943552650, -0.991671251437599710, +-0.991664810452468570, -0.991658366988175440, -0.991651921044736430, -0.991645472622167620, -0.991639021720485130, -0.991632568339705030, -0.991626112479843560, -0.991619654140916800, +-0.991613193322940960, -0.991606730025932030, -0.991600264249906330, -0.991593795994879960, -0.991587325260869120, -0.991580852047890040, -0.991574376355958690, -0.991567898185091500, +-0.991561417535304470, -0.991554934406614020, -0.991548448799036140, -0.991541960712587160, -0.991535470147283270, -0.991528977103140700, -0.991522481580175640, -0.991515983578404430, +-0.991509483097843370, -0.991502980138508460, -0.991496474700416130, -0.991489966783582590, -0.991483456388024260, -0.991476943513757150, -0.991470428160797780, -0.991463910329162260, +-0.991457390018867010, -0.991450867229928260, -0.991444341962362310, -0.991437814216185600, -0.991431283991414340, -0.991424751288064840, -0.991418216106153440, -0.991411678445696440, +-0.991405138306710400, -0.991398595689211400, -0.991392050593215890, -0.991385503018740400, -0.991378952965801030, -0.991372400434414320, -0.991365845424596600, -0.991359287936364300, +-0.991352727969733730, -0.991346165524721320, -0.991339600601343630, -0.991333033199616850, -0.991326463319557430, -0.991319890961181890, -0.991313316124506680, -0.991306738809548120, +-0.991300159016322740, -0.991293576744846970, -0.991286991995137260, -0.991280404767210020, -0.991273815061081810, -0.991267222876769050, -0.991260628214288290, -0.991254031073655840, +-0.991247431454888470, -0.991240829358002400, -0.991234224783014260, -0.991227617729940610, -0.991221008198797880, -0.991214396189602610, -0.991207781702371450, -0.991201164737120720, +-0.991194545293867190, -0.991187923372627180, -0.991181298973417450, -0.991174672096254430, -0.991168042741154780, -0.991161410908135030, -0.991154776597211630, -0.991148139808401440, +-0.991141500541720790, -0.991134858797186440, -0.991128214574814930, -0.991121567874622910, -0.991114918696626930, -0.991108267040843650, -0.991101612907289710, -0.991094956295981770, +-0.991088297206936470, -0.991081635640170380, -0.991074971595700130, -0.991068305073542600, -0.991061636073714220, -0.991054964596231770, -0.991048290641111880, -0.991041614208371340, +-0.991034935298026660, -0.991028253910094750, -0.991021570044592130, -0.991014883701535560, -0.991008194880941830, -0.991001503582827570, -0.990994809807209660, -0.990988113554104650, +-0.990981414823529310, -0.990974713615500490, -0.990968009930034870, -0.990961303767149300, -0.990954595126860350, -0.990947884009184990, -0.990941170414139980, -0.990934454341741880, +-0.990927735792007770, -0.990921014764954310, -0.990914291260598270, -0.990907565278956510, -0.990900836820045820, -0.990894105883883050, -0.990887372470485080, -0.990880636579868580, +-0.990873898212050520, -0.990867157367047780, -0.990860414044877120, -0.990853668245555430, -0.990846919969099460, -0.990840169215526310, -0.990833415984852750, -0.990826660277095540, +-0.990819902092271780, -0.990813141430398230, -0.990806378291491870, -0.990799612675569490, -0.990792844582648160, -0.990786074012744660, -0.990779300965875960, -0.990772525442059070, +-0.990765747441310740, -0.990758966963648180, -0.990752184009088150, -0.990745398577647650, -0.990738610669343660, -0.990731820284193150, -0.990725027422213130, -0.990718232083420470, +-0.990711434267832260, -0.990704633975465490, -0.990697831206337140, -0.990691025960464210, -0.990684218237863680, -0.990677408038552640, -0.990670595362547980, -0.990663780209866900, +-0.990656962580526490, -0.990650142474543530, -0.990643319891935210, -0.990636494832718650, -0.990629667296910820, -0.990622837284528820, -0.990616004795589760, -0.990609169830110710, +-0.990602332388108690, -0.990595492469600880, -0.990588650074604280, -0.990581805203136100, -0.990574957855213320, -0.990568108030853270, -0.990561255730072920, -0.990554400952889380, +-0.990547543699319850, -0.990540683969381440, -0.990533821763091350, -0.990526957080466790, -0.990520089921524740, -0.990513220286282530, -0.990506348174757130, -0.990499473586965990, +-0.990492596522926090, -0.990485716982654860, -0.990478834966169170, -0.990471950473486460, -0.990465063504623820, -0.990458174059598570, -0.990451282138427920, -0.990444387741128970, +-0.990437490867719150, -0.990430591518215550, -0.990423689692635500, -0.990416785390996090, -0.990409878613314860, -0.990402969359608920, -0.990396057629895580, -0.990389143424192040, +-0.990382226742515640, -0.990375307584883680, -0.990368385951313490, -0.990361461841822280, -0.990354535256427470, -0.990347606195146280, -0.990340674657996130, -0.990333740644994240, +-0.990326804156158040, -0.990319865191504830, -0.990312923751051840, -0.990305979834816720, -0.990299033442816560, -0.990292084575068790, -0.990285133231590840, -0.990278179412400040, +-0.990271223117513810, -0.990264264346949590, -0.990257303100724570, -0.990250339378856430, -0.990243373181362350, -0.990236404508259890, -0.990229433359566370, -0.990222459735299320, +-0.990215483635476070, -0.990208505060114150, -0.990201524009230890, -0.990194540482843940, -0.990187554480970620, -0.990180566003628360, -0.990173575050834700, -0.990166581622607070, +-0.990159585718963010, -0.990152587339920070, -0.990145586485495550, -0.990138583155707130, -0.990131577350572220, -0.990124569070108370, -0.990117558314333120, -0.990110545083263900, +-0.990103529376918370, -0.990096511195314060, -0.990089490538468400, -0.990082467406399050, -0.990075441799123550, -0.990068413716659430, -0.990061383159024260, -0.990054350126235660, +-0.990047314618311190, -0.990040276635268390, -0.990033236177124910, -0.990026193243898400, -0.990019147835606290, -0.990012099952266470, -0.990005049593896240, -0.989997996760513480, +-0.989990941452135730, -0.989983883668780650, -0.989976823410465780, -0.989969760677208880, -0.989962695469027600, -0.989955627785939600, -0.989948557627962410, -0.989941484995114030, +-0.989934409887411770, -0.989927332304873510, -0.989920252247517010, -0.989913169715359810, -0.989906084708419680, -0.989898997226714370, -0.989891907270261550, -0.989884814839078970, +-0.989877719933184300, -0.989870622552595390, -0.989863522697329910, -0.989856420367405620, -0.989849315562840280, -0.989842208283651660, -0.989835098529857520, -0.989827986301475620, +-0.989820871598523830, -0.989813754421019710, -0.989806634768981340, -0.989799512642426380, -0.989792388041372590, -0.989785260965837850, -0.989778131415839920, -0.989770999391396680, +-0.989763864892525880, -0.989756727919245520, -0.989749588471573350, -0.989742446549527140, -0.989735302153124770, -0.989728155282384340, -0.989721005937323370, -0.989713854117959870, +-0.989706699824311810, -0.989699543056396960, -0.989692383814233300, -0.989685222097838600, -0.989678057907230850, -0.989670891242428020, -0.989663722103448000, -0.989656550490308540, +-0.989649376403027750, -0.989642199841623600, -0.989635020806113870, -0.989627839296516650, -0.989620655312849820, -0.989613468855131240, -0.989606279923379130, -0.989599088517611250, +-0.989591894637845690, -0.989584698284100340, -0.989577499456393280, -0.989570298154742510, -0.989563094379165900, -0.989555888129681650, -0.989548679406307640, -0.989541468209061970, +-0.989534254537962510, -0.989527038393027580, -0.989519819774274940, -0.989512598681722810, -0.989505375115389160, -0.989498149075291990, -0.989490920561449610, -0.989483689573879780, +-0.989476456112600820, -0.989469220177630620, -0.989461981768987480, -0.989454740886689390, -0.989447497530754340, -0.989440251701200650, -0.989433003398046300, -0.989425752621309380, +-0.989418499371008120, -0.989411243647160710, -0.989403985449785030, -0.989396724778899510, -0.989389461634522130, -0.989382196016671100, -0.989374927925364520, -0.989367657360620710, +-0.989360384322457760, -0.989353108810893780, -0.989345830825947070, -0.989338550367635850, -0.989331267435978100, -0.989323982030992250, -0.989316694152696520, -0.989309403801108990, +-0.989302110976247980, -0.989294815678131600, -0.989287517906778270, -0.989280217662206200, -0.989272914944433480, -0.989265609753478550, -0.989258302089359500, -0.989250991952094760, +-0.989243679341702540, -0.989236364258201050, -0.989229046701608830, -0.989221726671943860, -0.989214404169224570, -0.989207079193469290, -0.989199751744696320, -0.989192421822923880, +-0.989185089428170520, -0.989177754560454430, -0.989170417219793820, -0.989163077406207350, -0.989155735119713000, -0.989148390360329420, -0.989141043128074830, -0.989133693422967750, +-0.989126341245026300, -0.989118986594269000, -0.989111629470714290, -0.989104269874380490, -0.989096907805286030, -0.989089543263449330, -0.989082176248888720, -0.989074806761622630, +-0.989067434801669590, -0.989060060369047920, -0.989052683463776170, -0.989045304085872660, -0.989037922235355920, -0.989030537912244270, -0.989023151116556360, -0.989015761848310640, +-0.989008370107525400, -0.989000975894219310, -0.988993579208410690, -0.988986180050118180, -0.988978778419360330, -0.988971374316155340, -0.988963967740522090, -0.988956558692478780, +-0.988949147172044190, -0.988941733179236620, -0.988934316714074830, -0.988926897776577160, -0.988919476366762250, -0.988912052484648640, -0.988904626130254980, -0.988897197303599710, +-0.988889766004701460, -0.988882332233578800, -0.988874895990250250, -0.988867457274734460, -0.988860016087050100, -0.988852572427215690, -0.988845126295249790, -0.988837677691171150, +-0.988830226614998200, -0.988822773066749820, -0.988815317046444430, -0.988807858554100800, -0.988800397589737480, -0.988792934153373220, -0.988785468245026560, -0.988777999864716260, +-0.988770529012460990, -0.988763055688279380, -0.988755579892190100, -0.988748101624211890, -0.988740620884363430, -0.988733137672663350, -0.988725651989130540, -0.988718163833783530, +-0.988710673206641080, -0.988703180107721960, -0.988695684537045040, -0.988688186494628750, -0.988680685980492080, -0.988673182994653570, -0.988665677537132190, -0.988658169607946610, +-0.988650659207115700, -0.988643146334658000, -0.988635630990592480, -0.988628113174937930, -0.988620592887713090, -0.988613070128936730, -0.988605544898627730, -0.988598017196804730, +-0.988590487023486840, -0.988582954378692700, -0.988575419262441190, -0.988567881674751070, -0.988560341615641320, -0.988552799085130610, -0.988545254083238010, -0.988537706609982300, +-0.988530156665382240, -0.988522604249456820, -0.988515049362224900, -0.988507492003705250, -0.988499932173916960, -0.988492369872878920, -0.988484805100609880, -0.988477237857128820, +-0.988469668142454630, -0.988462095956606280, -0.988454521299602760, -0.988446944171462950, -0.988439364572205710, -0.988431782501850040, -0.988424197960414920, -0.988416610947919330, +-0.988409021464382250, -0.988401429509822570, -0.988393835084259380, -0.988386238187711540, -0.988378638820198160, -0.988371036981738120, -0.988363432672350490, -0.988355825892054280, +-0.988348216640868580, -0.988340604918812260, -0.988332990725904410, -0.988325374062164140, -0.988317754927610430, -0.988310133322262360, -0.988302509246138940, -0.988294882699259250, +-0.988287253681642270, -0.988279622193307230, -0.988271988234273090, -0.988264351804559070, -0.988256712904184040, -0.988249071533167320, -0.988241427691527900, -0.988233781379284970, +-0.988226132596457530, -0.988218481343064780, -0.988210827619125820, -0.988203171424659740, -0.988195512759685760, -0.988187851624223070, -0.988180188018290660, -0.988172521941907860, +-0.988164853395093750, -0.988157182377867430, -0.988149508890248220, -0.988141832932255220, -0.988134154503907620, -0.988126473605224650, -0.988118790236225400, -0.988111104396929290, +-0.988103416087355410, -0.988095725307522990, -0.988088032057451220, -0.988080336337159420, -0.988072638146666790, -0.988064937485992440, -0.988057234355155910, -0.988049528754176180, +-0.988041820683072670, -0.988034110141864600, -0.988026397130571280, -0.988018681649211920, -0.988010963697805940, -0.988003243276372460, -0.987995520384930880, -0.987987795023500540, +-0.987980067192100740, -0.987972336890750700, -0.987964604119469850, -0.987956868878277490, -0.987949131167192960, -0.987941390986235680, -0.987933648335424740, -0.987925903214779800, +-0.987918155624320060, -0.987910405564065060, -0.987902653034033910, -0.987894898034246130, -0.987887140564721160, -0.987879380625478310, -0.987871618216537020, -0.987863853337916710, +-0.987856085989636700, -0.987848316171716530, -0.987840543884175530, -0.987832769127033220, -0.987824991900309040, -0.987817212204022300, -0.987809430038192550, -0.987801645402839100, +-0.987793858297981720, -0.987786068723639610, -0.987778276679832310, -0.987770482166579370, -0.987762685183900200, -0.987754885731814360, -0.987747083810341260, -0.987739279419500460, +-0.987731472559311490, -0.987723663229793770, -0.987715851430966960, -0.987708037162850490, -0.987700220425463900, -0.987692401218826840, -0.987684579542958740, -0.987676755397879140, +-0.987668928783607680, -0.987661099700163910, -0.987653268147567380, -0.987645434125837720, -0.987637597634994480, -0.987629758675057200, -0.987621917246045530, -0.987614073347979130, +-0.987606226980877410, -0.987598378144760260, -0.987590526839647100, -0.987582673065557580, -0.987574816822511470, -0.987566958110528300, -0.987559096929627730, -0.987551233279829410, +-0.987543367161152990, -0.987535498573618110, -0.987527627517244540, -0.987519753992051940, -0.987511877998059950, -0.987503999535288220, -0.987496118603756520, -0.987488235203484390, +-0.987480349334491910, -0.987472460996798420, -0.987464570190423770, -0.987456676915387740, -0.987448781171709980, -0.987440882959410240, -0.987432982278508400, -0.987425079129024000, +-0.987417173510977020, -0.987409265424387010, -0.987401354869273830, -0.987393441845657250, -0.987385526353557140, -0.987377608392993160, -0.987369687963985280, -0.987361765066553040, +-0.987353839700716440, -0.987345911866495230, -0.987337981563909170, -0.987330048792978250, -0.987322113553722240, -0.987314175846160880, -0.987306235670314060, -0.987298293026201760, +-0.987290347913843620, -0.987282400333259650, -0.987274450284469700, -0.987266497767493530, -0.987258542782351260, -0.987250585329062510, -0.987242625407647400, -0.987234663018125680, +-0.987226698160517220, -0.987218730834842130, -0.987210761041120160, -0.987202788779371400, -0.987194814049615510, -0.987186836851872700, -0.987178857186162720, -0.987170875052505560, +-0.987162890450921320, -0.987154903381429750, -0.987146913844051070, -0.987138921838805030, -0.987130927365711620, -0.987122930424790930, -0.987114931016062960, -0.987106929139547670, +-0.987098924795264950, -0.987090917983235010, -0.987082908703477810, -0.987074896956013250, -0.987066882740861520, -0.987058866058042490, -0.987050846907576380, -0.987042825289483170, +-0.987034801203782840, -0.987026774650495490, -0.987018745629641310, -0.987010714141240090, -0.987002680185312230, -0.986994643761877620, -0.986986604870956350, -0.986978563512568740, +-0.986970519686734550, -0.986962473393474090, -0.986954424632807470, -0.986946373404754880, -0.986938319709336210, -0.986930263546571870, -0.986922204916481750, -0.986914143819086150, +-0.986906080254405180, -0.986898014222459150, -0.986889945723267940, -0.986881874756851960, -0.986873801323231210, -0.986865725422426010, -0.986857647054456440, -0.986849566219342720, +-0.986841482917105160, -0.986833397147763860, -0.986825308911339130, -0.986817218207851070, -0.986809125037319990, -0.986801029399766110, -0.986792931295209620, -0.986784830723670850, +-0.986776727685170000, -0.986768622179727270, -0.986760514207362990, -0.986752403768097470, -0.986744290861950920, -0.986736175488943660, -0.986728057649095990, -0.986719937342428130, +-0.986711814568960510, -0.986703689328713220, -0.986695561621706800, -0.986687431447961450, -0.986679298807497500, -0.986671163700335250, -0.986663026126495150, -0.986654886085997610, +-0.986646743578862620, -0.986638598605110940, -0.986630451164762780, -0.986622301257838340, -0.986614148884358280, -0.986605994044342790, -0.986597836737812320, -0.986589676964787280, +-0.986581514725288100, -0.986573350019334990, -0.986565182846948610, -0.986557013208149260, -0.986548841102957370, -0.986540666531393380, -0.986532489493477720, -0.986524309989230800, +-0.986516128018673170, -0.986507943581825140, -0.986499756678707370, -0.986491567309340180, -0.986483375473743980, -0.986475181171939440, -0.986466984403946870, -0.986458785169786910, +-0.986450583469479890, -0.986442379303046460, -0.986434172670507150, -0.986425963571882390, -0.986417752007192620, -0.986409537976458580, -0.986401321479700610, -0.986393102516939350, +-0.986384881088195440, -0.986376657193489210, -0.986368430832841430, -0.986360202006272500, -0.986351970713803090, -0.986343736955453740, -0.986335500731244990, -0.986327262041197580, +-0.986319020885331970, -0.986310777263668890, -0.986302531176228790, -0.986294282623032430, -0.986286031604100330, -0.986277778119453160, -0.986269522169111460, -0.986261263753096080, +-0.986253002871427360, -0.986244739524126280, -0.986236473711213370, -0.986228205432709280, -0.986219934688634560, -0.986211661479010070, -0.986203385803856470, -0.986195107663194290, +-0.986186827057044410, -0.986178543985427480, -0.986170258448364260, -0.986161970445875280, -0.986153679977981420, -0.986145387044703340, -0.986137091646061780, -0.986128793782077520, +-0.986120493452771310, -0.986112190658163800, -0.986103885398275760, -0.986095577673128170, -0.986087267482741560, -0.986078954827136700, -0.986070639706334570, -0.986062322120355830, +-0.986054002069221220, -0.986045679552951640, -0.986037354571567830, -0.986029027125090660, -0.986020697213540910, -0.986012364836939440, -0.986004029995307120, -0.985995692688664600, +-0.985987352917032880, -0.985979010680432920, -0.985970665978885270, -0.985962318812411030, -0.985953969181030950, -0.985945617084765910, -0.985937262523636890, -0.985928905497664760, +-0.985920546006870290, -0.985912184051274450, -0.985903819630898240, -0.985895452745762400, -0.985887083395887930, -0.985878711581295810, -0.985870337302006900, -0.985861960558042090, +-0.985853581349422360, -0.985845199676168790, -0.985836815538302160, -0.985828428935843440, -0.985820039868813720, -0.985811648337233890, -0.985803254341124920, -0.985794857880507800, +-0.985786458955403620, -0.985778057565833250, -0.985769653711817680, -0.985761247393378000, -0.985752838610535200, -0.985744427363310360, -0.985736013651724470, -0.985727597475798410, +-0.985719178835553490, -0.985710757731010580, -0.985702334162190770, -0.985693908129115060, -0.985685479631804640, -0.985677048670280500, -0.985668615244563840, -0.985660179354675540, +-0.985651741000636790, -0.985643300182468710, -0.985634856900192370, -0.985626411153828990, -0.985617962943399430, -0.985609512268925010, -0.985601059130426840, -0.985592603527926100, +-0.985584145461443680, -0.985575684931001010, -0.985567221936619050, -0.985558756478319140, -0.985550288556122260, -0.985541818170049710, -0.985533345320122600, -0.985524870006362130, +-0.985516392228789400, -0.985507911987425820, -0.985499429282292390, -0.985490944113410320, -0.985482456480801020, -0.985473966384485480, -0.985465473824485130, -0.985456978800821060, +-0.985448481313514480, -0.985439981362586700, -0.985431478948059050, -0.985422974069952720, -0.985414466728288920, -0.985405956923088850, -0.985397444654373960, -0.985388929922165540, +-0.985380412726484690, -0.985371893067352840, -0.985363370944791210, -0.985354846358821200, -0.985346319309464040, -0.985337789796741140, -0.985329257820673820, -0.985320723381283290, +-0.985312186478590870, -0.985303647112618090, -0.985295105283386150, -0.985286560990916490, -0.985278014235230310, -0.985269465016349270, -0.985260913334294440, -0.985252359189087380, +-0.985243802580749390, -0.985235243509301920, -0.985226681974766370, -0.985218117977164080, -0.985209551516516460, -0.985200982592844940, -0.985192411206171070, -0.985183837356516160, +-0.985175261043901520, -0.985166682268348910, -0.985158101029879440, -0.985149517328514860, -0.985140931164276370, -0.985132342537185620, -0.985123751447264050, -0.985115157894532970, +-0.985106561879014130, -0.985097963400728750, -0.985089362459698580, -0.985080759055944940, -0.985072153189489490, -0.985063544860353520, -0.985054934068558820, -0.985046320814126690, +-0.985037705097078780, -0.985029086917436620, -0.985020466275221770, -0.985011843170455760, -0.985003217603160120, -0.984994589573356390, -0.984985959081066230, -0.984977326126311170, +-0.984968690709112750, -0.984960052829492730, -0.984951412487472420, -0.984942769683073700, -0.984934124416318000, -0.984925476687227070, -0.984916826495822350, -0.984908173842125590, +-0.984899518726158440, -0.984890861147942440, -0.984882201107499240, -0.984873538604850610, -0.984864873640018180, -0.984856206213023500, -0.984847536323888330, -0.984838863972634320, +-0.984830189159283110, -0.984821511883856470, -0.984812832146376050, -0.984804149946863490, -0.984795465285340570, -0.984786778161829020, -0.984778088576350520, -0.984769396528926810, +-0.984760702019579660, -0.984752005048330710, -0.984743305615201740, -0.984734603720214490, -0.984725899363390720, -0.984717192544752210, -0.984708483264320700, -0.984699771522118070, +-0.984691057318165970, -0.984682340652486170, -0.984673621525100630, -0.984664899936030900, -0.984656175885299080, -0.984647449372926700, -0.984638720398935630, -0.984629988963347970, +-0.984621255066185140, -0.984612518707469350, -0.984603779887222140, -0.984595038605465490, -0.984586294862221270, -0.984577548657511350, -0.984568799991357490, -0.984560048863781680, +-0.984551295274805670, -0.984542539224451560, -0.984533780712741000, -0.984525019739695970, -0.984516256305338460, -0.984507490409690320, -0.984498722052773330, -0.984489951234609690, +-0.984481177955221050, -0.984472402214629510, -0.984463624012857030, -0.984454843349925390, -0.984446060225856790, -0.984437274640672880, -0.984428486594395860, -0.984419696087047600, +-0.984410903118650090, -0.984402107689225310, -0.984393309798795360, -0.984384509447382090, -0.984375706635007510, -0.984366901361693690, -0.984358093627462630, -0.984349283432336300, +-0.984340470776336800, -0.984331655659485990, -0.984322838081806210, -0.984314018043319190, -0.984305195544047270, -0.984296370584012310, -0.984287543163236410, -0.984278713281741660, +-0.984269880939550150, -0.984261046136683860, -0.984252208873165000, -0.984243369149015670, -0.984234526964257840, -0.984225682318913720, -0.984216835213005400, -0.984207985646555090, +-0.984199133619584670, -0.984190279132116430, -0.984181422184172590, -0.984172562775775140, -0.984163700906946270, -0.984154836577708190, -0.984145969788082890, -0.984137100538092780, +-0.984128228827759970, -0.984119354657106430, -0.984110478026154590, -0.984101598934926550, -0.984092717383444620, -0.984083833371730780, -0.984074946899807350, -0.984066057967696530, +-0.984057166575420640, -0.984048272723001770, -0.984039376410462350, -0.984030477637824360, -0.984021576405110230, -0.984012672712342160, -0.984003766559542360, -0.983994857946733140, +-0.983985946873936920, -0.983977033341175700, -0.983968117348471890, -0.983959198895847820, -0.983950277983325790, -0.983941354610928020, -0.983932428778676820, -0.983923500486594600, +-0.983914569734703590, -0.983905636523026320, -0.983896700851584760, -0.983887762720401570, -0.983878822129498840, -0.983869879078899220, -0.983860933568624810, -0.983851985598698130, +-0.983843035169141400, -0.983834082279977150, -0.983825126931227590, -0.983816169122915360, -0.983807208855062560, -0.983798246127691840, -0.983789280940825520, -0.983780313294486010, +-0.983771343188695640, -0.983762370623476930, -0.983753395598852220, -0.983744418114844140, -0.983735438171475020, -0.983726455768767270, -0.983717470906743330, -0.983708483585425730, +-0.983699493804837010, -0.983690501564999490, -0.983681506865935700, -0.983672509707668170, -0.983663510090219350, -0.983654508013611760, -0.983645503477867940, -0.983636496483010330, +-0.983627487029061440, -0.983618475116043940, -0.983609460743980150, -0.983600443912892700, -0.983591424622804240, -0.983582402873737220, -0.983573378665714040, -0.983564351998757580, +-0.983555322872890160, -0.983546291288134420, -0.983537257244513020, -0.983528220742048380, -0.983519181780763250, -0.983510140360680190, -0.983501096481821710, -0.983492050144210590, +-0.983483001347869260, -0.983473950092820460, -0.983464896379086740, -0.983455840206690860, -0.983446781575655240, -0.983437720486002860, -0.983428656937756050, -0.983419590930937670, +-0.983410522465570260, -0.983401451541676570, -0.983392378159279160, -0.983383302318400880, -0.983374224019064380, -0.983365143261292320, -0.983356060045107340, -0.983346974370532200, +-0.983337886237589660, -0.983328795646302490, -0.983319702596693210, -0.983310607088784700, -0.983301509122599730, -0.983292408698160920, -0.983283305815491170, -0.983274200474613000, +-0.983265092675549510, -0.983255982418323130, -0.983246869702956940, -0.983237754529473480, -0.983228636897895750, -0.983219516808246260, -0.983210394260548020, -0.983201269254823870, +-0.983192141791096490, -0.983183011869388830, -0.983173879489723570, -0.983164744652123670, -0.983155607356611890, -0.983146467603211010, -0.983137325391943980, -0.983128180722833810, +-0.983119033595903020, -0.983109884011174720, -0.983100731968671650, -0.983091577468416800, -0.983082420510432930, -0.983073261094743130, -0.983064099221370060, -0.983054934890336800, +-0.983045768101666220, -0.983036598855381190, -0.983027427151504600, -0.983018252990059520, -0.983009076371068820, -0.982999897294555390, -0.982990715760542310, -0.982981531769052340, +-0.982972345320108580, -0.982963156413733890, -0.982953965049951470, -0.982944771228783990, -0.982935574950254630, -0.982926376214386280, -0.982917175021202130, -0.982907971370724940, +-0.982898765262977810, -0.982889556697983830, -0.982880345675765880, -0.982871132196347140, -0.982861916259750500, -0.982852697865999160, -0.982843477015115980, -0.982834253707124180, +-0.982825027942046630, -0.982815799719906620, -0.982806569040727160, -0.982797335904531220, -0.982788100311341890, -0.982778862261182380, -0.982769621754075670, -0.982760378790044960, +-0.982751133369113240, -0.982741885491303700, -0.982732635156639440, -0.982723382365143670, -0.982714127116839360, -0.982704869411749730, -0.982695609249897960, -0.982686346631307160, +-0.982677081556000530, -0.982667814024001160, -0.982658544035332260, -0.982649271590016920, -0.982639996688078550, -0.982630719329540050, -0.982621439514424820, -0.982612157242755970, +-0.982602872514556800, -0.982593585329850420, -0.982584295688660010, -0.982575003591008910, -0.982565709036920310, -0.982556412026417410, -0.982547112559523540, -0.982537810636261780, +-0.982528506256655660, -0.982519199420728070, -0.982509890128502650, -0.982500578380002490, -0.982491264175250790, -0.982481947514270980, -0.982472628397086270, -0.982463306823720070, +-0.982453982794195490, -0.982444656308536060, -0.982435327366764870, -0.982425995968905450, -0.982416662114981020, -0.982407325805015000, -0.982397987039030580, -0.982388645817051210, +-0.982379302139100300, -0.982369956005201050, -0.982360607415376900, -0.982351256369651260, -0.982341902868047570, -0.982332546910589020, -0.982323188497299050, -0.982313827628201190, +-0.982304464303318750, -0.982295098522675160, -0.982285730286293850, -0.982276359594198120, -0.982266986446411640, -0.982257610842957600, -0.982248232783859530, -0.982238852269140870, +-0.982229469298825150, -0.982220083872935690, -0.982210695991496020, -0.982201305654529570, -0.982191912862059980, -0.982182517614110460, -0.982173119910704770, -0.982163719751866230, +-0.982154317137618470, -0.982144912067984820, -0.982135504542988920, -0.982126094562654210, -0.982116682127004310, -0.982107267236062790, -0.982097849889852940, -0.982088430088398520, +-0.982079007831723080, -0.982069583119850150, -0.982060155952803160, -0.982050726330605860, -0.982041294253281680, -0.982031859720854270, -0.982022422733347280, -0.982012983290784240, +-0.982003541393188570, -0.981994097040584270, -0.981984650232994530, -0.981975200970443330, -0.981965749252953990, -0.981956295080550380, -0.981946838453256030, -0.981937379371094600, +-0.981927917834089610, -0.981918453842264950, -0.981908987395644030, -0.981899518494250720, -0.981890047138108570, -0.981880573327241320, -0.981871097061672750, -0.981861618341426270, +-0.981852137166525860, -0.981842653536995070, -0.981833167452857650, -0.981823678914137240, -0.981814187920857730, -0.981804694473042750, -0.981795198570715950, -0.981785700213901210, +-0.981776199402622280, -0.981766696136902710, -0.981757190416766570, -0.981747682242237300, -0.981738171613338870, -0.981728658530095060, -0.981719142992529600, -0.981709625000666160, +-0.981700104554528830, -0.981690581654141140, -0.981681056299526960, -0.981671528490710270, -0.981661998227714610, -0.981652465510564070, -0.981642930339282290, -0.981633392713893270, +-0.981623852634420760, -0.981614310100888510, -0.981604765113320620, -0.981595217671740740, -0.981585667776172840, -0.981576115426640810, -0.981566560623168380, -0.981557003365779670, +-0.981547443654498310, -0.981537881489348510, -0.981528316870353910, -0.981518749797538500, -0.981509180270926260, -0.981499608290541060, -0.981490033856406760, -0.981480456968547470, +-0.981470877626987040, -0.981461295831749460, -0.981451711582858490, -0.981442124880338330, -0.981432535724212960, -0.981422944114506040, -0.981413350051241970, -0.981403753534444420, +-0.981394154564137480, -0.981384553140345120, -0.981374949263091430, -0.981365342932400410, -0.981355734148295910, -0.981346122910802140, -0.981336509219943090, -0.981326893075742830, +-0.981317274478225140, -0.981307653427414440, -0.981298029923334590, -0.981288403966009580, -0.981278775555463610, -0.981269144691720660, -0.981259511374804940, -0.981249875604740420, +-0.981240237381551080, -0.981230596705261360, -0.981220953575895010, -0.981211307993476330, -0.981201659958029330, -0.981192009469578190, -0.981182356528147000, -0.981172701133759980, +-0.981163043286441220, -0.981153382986214790, -0.981143720233104920, -0.981134055027135800, -0.981124387368331520, -0.981114717256716170, -0.981105044692314190, -0.981095369675149430, +-0.981085692205246440, -0.981076012282629080, -0.981066329907321680, -0.981056645079348530, -0.981046957798733740, -0.981037268065501510, -0.981027575879676260, -0.981017881241281970, +-0.981008184150342970, -0.980998484606883440, -0.980988782610927810, -0.980979078162500180, -0.980969371261624870, -0.980959661908326170, -0.980949950102628310, -0.980940235844555470, +-0.980930519134132100, -0.980920799971382480, -0.980911078356330850, -0.980901354289001490, -0.980891627769418740, -0.980881898797606900, -0.980872167373590400, -0.980862433497393440, +-0.980852697169040330, -0.980842958388555510, -0.980833217155963390, -0.980823473471288180, -0.980813727334554190, -0.980803978745785950, -0.980794227705007790, -0.980784474212244020, +-0.980774718267519050, -0.980764959870857430, -0.980755199022283250, -0.980745435721821160, -0.980735669969495350, -0.980725901765330480, -0.980716131109350850, -0.980706358001580900, +-0.980696582442045050, -0.980686804430767720, -0.980677023967773340, -0.980667241053086450, -0.980657455686731460, -0.980647667868732810, -0.980637877599115030, -0.980628084877902540, +-0.980618289705119880, -0.980608492080791370, -0.980598692004941760, -0.980588889477595370, -0.980579084498776730, -0.980569277068510380, -0.980559467186820970, -0.980549654853732690, +-0.980539840069270420, -0.980530022833458470, -0.980520203146321490, -0.980510381007884010, -0.980500556418170580, -0.980490729377205830, -0.980480899885014080, -0.980471067941620200, +-0.980461233547048620, -0.980451396701323970, -0.980441557404470920, -0.980431715656513880, -0.980421871457477500, -0.980412024807386540, -0.980402175706265420, -0.980392324154139020, +-0.980382470151031640, -0.980372613696968150, -0.980362754791973100, -0.980352893436071240, -0.980343029629287100, -0.980333163371645330, -0.980323294663170810, -0.980313423503887840, +-0.980303549893821510, -0.980293673832996150, -0.980283795321436720, -0.980273914359167780, -0.980264030946214060, -0.980254145082600110, -0.980244256768351030, -0.980234366003491120, +-0.980224472788045480, -0.980214577122038520, -0.980204679005495130, -0.980194778438440050, -0.980184875420898050, -0.980174969952893880, -0.980165062034452310, -0.980155151665597970, +-0.980145238846355850, -0.980135323576750590, -0.980125405856806960, -0.980115485686549940, -0.980105563066004160, -0.980095637995194500, -0.980085710474145610, -0.980075780502882580, +-0.980065848081430050, -0.980055913209813000, -0.980045975888055980, -0.980036036116184170, -0.980026093894222240, -0.980016149222195040, -0.980006202100127450, -0.979996252528044450, +-0.979986300505970800, -0.979976346033931360, -0.979966389111951000, -0.979956429740054700, -0.979946467918267340, -0.979936503646613890, -0.979926536925119110, -0.979916567753807980, +-0.979906596132705480, -0.979896622061836360, -0.979886645541225840, -0.979876666570898560, -0.979866685150879710, -0.979856701281194180, -0.979846714961866820, -0.979836726192922720, +-0.979826734974386770, -0.979816741306284040, -0.979806745188639420, -0.979796746621477980, -0.979786745604824590, -0.979776742138704360, -0.979766736223142360, -0.979756727858163370, +-0.979746717043792680, -0.979736703780055170, -0.979726688066975940, -0.979716669904579950, -0.979706649292892200, -0.979696626231937980, -0.979686600721742070, -0.979676572762329780, +-0.979666542353725970, -0.979656509495955840, -0.979646474189044380, -0.979636436433016790, -0.979626396227898040, -0.979616353573713460, -0.979606308470487800, -0.979596260918246480, +-0.979586210917014480, -0.979576158466817000, -0.979566103567679040, -0.979556046219625890, -0.979545986422682650, -0.979535924176874300, -0.979525859482226260, -0.979515792338763510, +-0.979505722746511380, -0.979495650705494820, -0.979485576215739280, -0.979475499277269730, -0.979465419890111380, -0.979455338054289530, -0.979445253769829380, -0.979435167036756040, +-0.979425077855094810, -0.979414986224870780, -0.979404892146109370, -0.979394795618835690, -0.979384696643075150, -0.979374595218852730, -0.979364491346193860, -0.979354385025123730, +-0.979344276255667780, -0.979334165037850980, -0.979324051371698760, -0.979313935257236530, -0.979303816694489400, -0.979293695683482790, -0.979283572224241890, -0.979273446316792030, +-0.979263317961158620, -0.979253187157366870, -0.979243053905442080, -0.979232918205409810, -0.979222780057295130, -0.979212639461123580, -0.979202496416920360, -0.979192350924711020, +-0.979182202984520630, -0.979172052596374850, -0.979161899760298880, -0.979151744476318250, -0.979141586744458170, -0.979131426564744170, -0.979121263937201560, -0.979111098861855880, +-0.979100931338732330, -0.979090761367856550, -0.979080588949253870, -0.979070414082949590, -0.979060236768969470, -0.979050057007338600, -0.979039874798082630, -0.979029690141226980, +-0.979019503036797190, -0.979009313484818570, -0.978999121485316650, -0.978988927038316860, -0.978978730143844840, -0.978968530801926030, -0.978958329012585840, -0.978948124775849800, +-0.978937918091743580, -0.978927708960292460, -0.978917497381522010, -0.978907283355457960, -0.978897066882125520, -0.978886847961550570, -0.978876626593758400, -0.978866402778774790, +-0.978856176516625040, -0.978845947807334920, -0.978835716650929940, -0.978825483047435660, -0.978815246996877610, -0.978805008499281540, -0.978794767554672870, -0.978784524163077370, +-0.978774278324520460, -0.978764030039028010, -0.978753779306625330, -0.978743526127338280, -0.978733270501192300, -0.978723012428213250, -0.978712751908426660, -0.978702488941858180, +-0.978692223528533470, -0.978681955668478150, -0.978671685361718110, -0.978661412608278660, -0.978651137408185770, -0.978640859761465090, -0.978630579668142150, -0.978620297128242830, +-0.978610012141792770, -0.978599724708817620, -0.978589434829343240, -0.978579142503395170, -0.978568847730999390, -0.978558550512181440, -0.978548250846967060, -0.978537948735382020, +-0.978527644177452190, -0.978517337173203220, -0.978507027722660960, -0.978496715825851070, -0.978486401482799420, -0.978476084693531760, -0.978465765458073840, -0.978455443776451550, +-0.978445119648690630, -0.978434793074816960, -0.978424464054856280, -0.978414132588834470, -0.978403798676777290, -0.978393462318710600, -0.978383123514660280, -0.978372782264652190, +-0.978362438568712080, -0.978352092426865940, -0.978341743839139410, -0.978331392805558700, -0.978321039326149440, -0.978310683400937630, -0.978300325029949010, -0.978289964213209680, +-0.978279600950745400, -0.978269235242582020, -0.978258867088745760, -0.978248496489262150, -0.978238123444157390, -0.978227747953457350, -0.978217370017187890, -0.978206989635375000, +-0.978196606808044660, -0.978186221535222720, -0.978175833816935290, -0.978165443653208340, -0.978155051044067750, -0.978144655989539480, -0.978134258489649630, -0.978123858544424070, +-0.978113456153888890, -0.978103051318070070, -0.978092644036993590, -0.978082234310685530, -0.978071822139171880, -0.978061407522478720, -0.978050990460632040, -0.978040570953657820, +-0.978030149001582250, -0.978019724604431210, -0.978009297762230890, -0.977998868475007390, -0.977988436742786680, -0.977978002565594860, -0.977967565943458130, -0.977957126876402350, +-0.977946685364453840, -0.977936241407638570, -0.977925795005982760, -0.977915346159512370, -0.977904894868253720, -0.977894441132232780, -0.977883984951475660, -0.977873526326008660, +-0.977863065255857870, -0.977852601741049380, -0.977842135781609390, -0.977831667377564000, -0.977821196528939510, -0.977810723235762010, -0.977800247498057830, -0.977789769315852820, +-0.977779288689173520, -0.977768805618045910, -0.977758320102496410, -0.977747832142551010, -0.977737341738236120, -0.977726848889577730, -0.977716353596602360, -0.977705855859336000, +-0.977695355677805080, -0.977684853052035780, -0.977674347982054210, -0.977663840467886900, -0.977653330509559940, -0.977642818107099740, -0.977632303260532410, -0.977621785969884360, +-0.977611266235181800, -0.977600744056451140, -0.977590219433718600, -0.977579692367010480, -0.977569162856353090, -0.977558630901772860, -0.977548096503296100, -0.977537559660949020, +-0.977527020374758030, -0.977516478644749550, -0.977505934470949800, -0.977495387853385300, -0.977484838792082260, -0.977474287287067200, -0.977463733338366340, -0.977453176946006200, +-0.977442618110013100, -0.977432056830413450, -0.977421493107233700, -0.977410926940500140, -0.977400358330239310, -0.977389787276477630, -0.977379213779241420, -0.977368637838557210, +-0.977358059454451420, -0.977347478626950370, -0.977336895356080700, -0.977326309641868840, -0.977315721484341200, -0.977305130883524110, -0.977294537839444310, -0.977283942352128230, +-0.977273344421602190, -0.977262744047892820, -0.977252141231026660, -0.977241535971030030, -0.977230928267929570, -0.977220318121751810, -0.977209705532523290, -0.977199090500270540, +-0.977188473025019990, -0.977177853106798280, -0.977167230745631940, -0.977156605941547520, -0.977145978694571540, -0.977135349004730760, -0.977124716872051490, -0.977114082296560380, +-0.977103445278284190, -0.977092805817249330, -0.977082163913482460, -0.977071519567010220, -0.977060872777859020, -0.977050223546055860, -0.977039571871627040, -0.977028917754599210, +-0.977018261194999240, -0.977007602192853540, -0.976996940748188770, -0.976986276861031790, -0.976975610531409020, -0.976964941759347230, -0.976954270544873160, -0.976943596888013350, +-0.976932920788794570, -0.976922242247243440, -0.976911561263386740, -0.976900877837251100, -0.976890191968863400, -0.976879503658250050, -0.976868812905438030, -0.976858119710454000, +-0.976847424073324590, -0.976836725994076670, -0.976826025472737000, -0.976815322509332120, -0.976804617103888990, -0.976793909256434390, -0.976783198966994950, -0.976772486235597540, +-0.976761771062268910, -0.976751053447035830, -0.976740333389925160, -0.976729610890963660, -0.976718885950178080, -0.976708158567595410, -0.976697428743242170, -0.976686696477145460, +-0.976675961769331910, -0.976665224619828630, -0.976654485028662140, -0.976643742995859540, -0.976632998521447470, -0.976622251605453020, -0.976611502247902830, -0.976600750448824000, +-0.976589996208243160, -0.976579239526187410, -0.976568480402683630, -0.976557718837758550, -0.976546954831439160, -0.976536188383752450, -0.976525419494725270, -0.976514648164384490, +-0.976503874392757100, -0.976493098179870070, -0.976482319525750260, -0.976471538430424670, -0.976460754893920260, -0.976449968916263900, -0.976439180497482680, -0.976428389637603370, +-0.976417596336653260, -0.976406800594659010, -0.976396002411647920, -0.976385201787646650, -0.976374398722682500, -0.976363593216782340, -0.976352785269973160, -0.976341974882282030, +-0.976331162053735930, -0.976320346784362080, -0.976309529074187220, -0.976298708923238560, -0.976287886331543060, -0.976277061299127950, -0.976266233826020180, -0.976255403912246860, +-0.976244571557834950, -0.976233736762811670, -0.976222899527203980, -0.976212059851039090, -0.976201217734343980, -0.976190373177145960, -0.976179526179471900, -0.976168676741349000, +-0.976157824862804450, -0.976146970543865340, -0.976136113784558890, -0.976125254584912060, -0.976114392944952170, -0.976103528864706190, -0.976092662344201440, -0.976081793383465010, +-0.976070921982524210, -0.976060048141405900, -0.976049171860137620, -0.976038293138746350, -0.976027411977259400, -0.976016528375703960, -0.976005642334107140, -0.975994753852496230, +-0.975983862930898450, -0.975972969569340880, -0.975962073767851050, -0.975951175526455940, -0.975940274845182860, -0.975929371724059250, -0.975918466163112060, -0.975907558162368850, +-0.975896647721856580, -0.975885734841602790, -0.975874819521634680, -0.975863901761979460, -0.975852981562664530, -0.975842058923717110, -0.975831133845164620, -0.975820206327034260, +-0.975809276369353330, -0.975798343972149260, -0.975787409135449260, -0.975776471859280850, -0.975765532143671120, -0.975754589988647720, -0.975743645394237750, -0.975732698360468720, +-0.975721748887367850, -0.975710796974962660, -0.975699842623280470, -0.975688885832348700, -0.975677926602194770, -0.975666964932845880, -0.975656000824329680, -0.975645034276673480, +-0.975634065289904710, -0.975623093864050660, -0.975612119999138990, -0.975601143695197020, -0.975590164952252150, -0.975579183770331810, -0.975568200149463660, -0.975557214089674880, +-0.975546225590993130, -0.975535234653445830, -0.975524241277060390, -0.975513245461864350, -0.975502247207885140, -0.975491246515150510, -0.975480243383687550, -0.975469237813524130, +-0.975458229804687550, -0.975447219357205460, -0.975436206471105180, -0.975425191146414460, -0.975414173383160830, -0.975403153181371720, -0.975392130541074650, -0.975381105462297390, +-0.975370077945067250, -0.975359047989411980, -0.975348015595359110, -0.975336980762936180, -0.975325943492170720, -0.975314903783090490, -0.975303861635723020, -0.975292817050095850, +-0.975281770026236620, -0.975270720564172970, -0.975259668663932540, -0.975248614325543000, -0.975237557549031850, -0.975226498334426760, -0.975215436681755590, -0.975204372591045640, +-0.975193306062324900, -0.975182237095620800, -0.975171165690961180, -0.975160091848373600, -0.975149015567885800, -0.975137936849525430, -0.975126855693320250, -0.975115772099298010, +-0.975104686067486240, -0.975093597597912810, -0.975082506690605370, -0.975071413345591550, -0.975060317562899350, -0.975049219342556280, -0.975038118684590120, -0.975027015589028820, +-0.975015910055899830, -0.975004802085231210, -0.974993691677050410, -0.974982578831385500, -0.974971463548264140, -0.974960345827714070, -0.974949225669763160, -0.974938103074439290, +-0.974926978041769980, -0.974915850571783320, -0.974904720664507060, -0.974893588319968970, -0.974882453538196800, -0.974871316319218640, -0.974860176663062130, -0.974849034569755250, +-0.974837890039325750, -0.974826743071801390, -0.974815593667210380, -0.974804441825580240, -0.974793287546939060, -0.974782130831314710, -0.974770971678734940, -0.974759810089227740, +-0.974748646062821080, -0.974737479599542820, -0.974726310699420840, -0.974715139362483000, -0.974703965588757380, -0.974692789378271860, -0.974681610731054300, -0.974670429647132800, +-0.974659246126535210, -0.974648060169289510, -0.974636871775423570, -0.974625680944965490, -0.974614487677943230, -0.974603291974384780, -0.974592093834318110, -0.974580893257771200, +-0.974569690244771910, -0.974558484795348570, -0.974547276909528910, -0.974536066587341150, -0.974524853828813150, -0.974513638633973110, -0.974502421002848900, -0.974491200935468700, +-0.974479978431860410, -0.974468753492052200, -0.974457526116072170, -0.974446296303948300, -0.974435064055708570, -0.974423829371381390, -0.974412592250994410, -0.974401352694576170, +-0.974390110702154420, -0.974378866273757360, -0.974367619409413190, -0.974356370109149990, -0.974345118372995870, -0.974333864200978890, -0.974322607593127280, -0.974311348549469210, +-0.974300087070032680, -0.974288823154846000, -0.974277556803937240, -0.974266288017334610, -0.974255016795066210, -0.974243743137160330, -0.974232467043645080, -0.974221188514548640, +-0.974209907549899220, -0.974198624149725020, -0.974187338314054350, -0.974176050042915190, -0.974164759336336060, -0.974153466194344950, -0.974142170616970060, -0.974130872604239920, +-0.974119572156182500, -0.974108269272826230, -0.974096963954199200, -0.974085656200329940, -0.974074346011246320, -0.974063033386976970, -0.974051718327550000, -0.974040400832993700, +-0.974029080903336400, -0.974017758538606500, -0.974006433738832110, -0.973995106504041640, -0.973983776834263400, -0.973972444729525820, -0.973961110189856980, -0.973949773215285420, +-0.973938433805839440, -0.973927091961547360, -0.973915747682437600, -0.973904400968538360, -0.973893051819878290, -0.973881700236485460, -0.973870346218388420, -0.973858989765615470, +-0.973847630878195150, -0.973836269556155650, -0.973824905799525520, -0.973813539608333170, -0.973802170982606910, -0.973790799922375270, -0.973779426427666570, -0.973768050498509340, +-0.973756672134932000, -0.973745291336962860, -0.973733908104630670, -0.973722522437963640, -0.973711134336990300, -0.973699743801739070, -0.973688350832238480, -0.973676955428517180, +-0.973665557590603250, -0.973654157318525670, -0.973642754612312530, -0.973631349471992590, -0.973619941897594150, -0.973608531889145980, -0.973597119446676480, -0.973585704570214090, +-0.973574287259787560, -0.973562867515425200, -0.973551445337155760, -0.973540020725007670, -0.973528593679009460, -0.973517164199189880, -0.973505732285577350, -0.973494297938200530, +-0.973482861157087820, -0.973471421942268100, -0.973459980293769790, -0.973448536211621530, -0.973437089695851960, -0.973425640746489520, -0.973414189363563160, -0.973402735547101220, +-0.973391279297132540, -0.973379820613685550, -0.973368359496789130, -0.973356895946471680, -0.973345429962762080, -0.973333961545688850, -0.973322490695280760, -0.973311017411566450, +-0.973299541694574550, -0.973288063544333840, -0.973276582960872940, -0.973265099944220500, -0.973253614494405510, -0.973242126611456370, -0.973230636295401850, -0.973219143546270820, +-0.973207648364091900, -0.973196150748893980, -0.973184650700705480, -0.973173148219555470, -0.973161643305472610, -0.973150135958485650, -0.973138626178623230, -0.973127113965914450, +-0.973115599320387710, -0.973104082242072010, -0.973092562730996090, -0.973081040787188820, -0.973069516410678960, -0.973057989601495250, -0.973046460359666580, -0.973034928685221790, +-0.973023394578189650, -0.973011858038599020, -0.973000319066478770, -0.972988777661857650, -0.972977233824764750, -0.972965687555228610, -0.972954138853278310, -0.972942587718942600, +-0.972931034152250570, -0.972919478153230770, -0.972907919721912480, -0.972896358858324260, -0.972884795562495190, -0.972873229834454010, -0.972861661674229940, -0.972850091081851610, +-0.972838518057348000, -0.972826942600748200, -0.972815364712081080, -0.972803784391375380, -0.972792201638660430, -0.972780616453964740, -0.972769028837317640, -0.972757438788747990, +-0.972745846308284760, -0.972734251395956820, -0.972722654051793260, -0.972711054275823160, -0.972699452068075400, -0.972687847428578940, -0.972676240357362890, -0.972664630854456310, +-0.972653018919888090, -0.972641404553687310, -0.972629787755883050, -0.972618168526504290, -0.972606546865580120, -0.972594922773139640, -0.972583296249211800, -0.972571667293825710, +-0.972560035907010460, -0.972548402088795120, -0.972536765839208780, -0.972525127158280540, -0.972513486046039490, -0.972501842502514700, -0.972490196527735380, -0.972478548121730400, +-0.972466897284529170, -0.972455244016160680, -0.972443588316654120, -0.972431930186038570, -0.972420269624343140, -0.972408606631597120, -0.972396941207829490, -0.972385273353069570, +-0.972373603067346440, -0.972361930350689300, -0.972350255203127340, -0.972338577624689780, -0.972326897615405810, -0.972315215175304500, -0.972303530304415080, -0.972291843002767050, +-0.972280153270389190, -0.972268461107311130, -0.972256766513561850, -0.972245069489170670, -0.972233370034166770, -0.972221668148579470, -0.972209963832437960, -0.972198257085771680, +-0.972186547908609590, -0.972174836300981230, -0.972163122262915790, -0.972151405794442480, -0.972139686895590720, -0.972127965566389700, -0.972116241806868730, -0.972104515617057240, +-0.972092786996984430, -0.972081055946679710, -0.972069322466172170, -0.972057586555491460, -0.972045848214666770, -0.972034107443727420, -0.972022364242702940, -0.972010618611622410, +-0.971998870550515370, -0.971987120059411120, -0.971975367138339100, -0.971963611787328710, -0.971951854006409270, -0.971940093795610080, -0.971928331154960800, -0.971916566084490620, +-0.971904798584229070, -0.971893028654205460, -0.971881256294449440, -0.971869481504990080, -0.971857704285857160, -0.971845924637079860, -0.971834142558687830, -0.971822358050710380, +-0.971810571113177040, -0.971798781746117330, -0.971786989949560700, -0.971775195723536540, -0.971763399068074300, -0.971751599983203710, -0.971739798468954090, -0.971727994525354970, +-0.971716188152435770, -0.971704379350226240, -0.971692568118755710, -0.971680754458053690, -0.971668938368149830, -0.971657119849073660, -0.971645298900854600, -0.971633475523522420, +-0.971621649717106520, -0.971609821481636440, -0.971597990817141820, -0.971586157723652200, -0.971574322201197330, -0.971562484249806510, -0.971550643869509510, -0.971538801060335850, +-0.971526955822315300, -0.971515108155477260, -0.971503258059851600, -0.971491405535467640, -0.971479550582355240, -0.971467693200543940, -0.971455833390063360, -0.971443971150943280, +-0.971432106483213210, -0.971420239386902920, -0.971408369862042040, -0.971396497908660230, -0.971384623526787120, -0.971372746716452460, -0.971360867477686020, -0.971348985810517320, +-0.971337101714976230, -0.971325215191092380, -0.971313326238895440, -0.971301434858415250, -0.971289541049681350, -0.971277644812723720, -0.971265746147571880, -0.971253845054255830, +-0.971241941532804960, -0.971230035583249380, -0.971218127205618620, -0.971206216399942650, -0.971194303166251100, -0.971182387504573750, -0.971170469414940450, -0.971158548897381070, +-0.971146625951925250, -0.971134700578602850, -0.971122772777443630, -0.971110842548477570, -0.971098909891734420, -0.971086974807243930, -0.971075037295036080, -0.971063097355140510, +-0.971051154987587320, -0.971039210192406130, -0.971027262969627050, -0.971015313319279700, -0.971003361241394190, -0.970991406736000150, -0.970979449803127670, -0.970967490442806500, +-0.970955528655066740, -0.970943564439938010, -0.970931597797450530, -0.970919628727633930, -0.970907657230518310, -0.970895683306133410, -0.970883706954509430, -0.970871728175676240, +-0.970859746969663600, -0.970847763336501690, -0.970835777276220280, -0.970823788788849450, -0.970811797874419180, -0.970799804532959440, -0.970787808764500100, -0.970775810569071360, +-0.970763809946703080, -0.970751806897425240, -0.970739801421267810, -0.970727793518261000, -0.970715783188434540, -0.970703770431818770, -0.970691755248443530, -0.970679737638338920, +-0.970667717601534920, -0.970655695138061710, -0.970643670247949180, -0.970631642931227500, -0.970619613187926780, -0.970607581018076870, -0.970595546421708200, -0.970583509398850520, +-0.970571469949534140, -0.970559428073789030, -0.970547383771645400, -0.970535337043133330, -0.970523287888282900, -0.970511236307124210, -0.970499182299687460, -0.970487125866002720, +-0.970475067006100200, -0.970463005720009990, -0.970450942007762270, -0.970438875869387260, -0.970426807304915040, -0.970414736314375690, -0.970402662897799640, -0.970390587055216860, +-0.970378508786657550, -0.970366428092152120, -0.970354344971730450, -0.970342259425423070, -0.970330171453259950, -0.970318081055271510, -0.970305988231487730, -0.970293892981939130, +-0.970281795306655590, -0.970269695205667750, -0.970257592679005580, -0.970245487726699500, -0.970233380348779590, -0.970221270545276400, -0.970209158316219900, -0.970197043661640500, +-0.970184926581568520, -0.970172807076034260, -0.970160685145067920, -0.970148560788699930, -0.970136434006960480, -0.970124304799879990, -0.970112173167488770, -0.970100039109817010, +-0.970087902626895260, -0.970075763718753700, -0.970063622385422760, -0.970051478626932750, -0.970039332443313970, -0.970027183834596960, -0.970015032800811920, -0.970002879341989370, +-0.969990723458159620, -0.969978565149352990, -0.969966404415600000, -0.969954241256930970, -0.969942075673376420, -0.969929907664966560, -0.969917737231732020, -0.969905564373703120, +-0.969893389090910270, -0.969881211383384010, -0.969869031251154650, -0.969856848694252700, -0.969844663712708720, -0.969832476306553000, -0.969820286475816080, -0.969808094220528600, +-0.969795899540720760, -0.969783702436423200, -0.969771502907666340, -0.969759300954480820, -0.969747096576896950, -0.969734889774945370, -0.969722680548656510, -0.969710468898061120, +-0.969698254823189390, -0.969686038324072070, -0.969673819400739600, -0.969661598053222720, -0.969649374281551730, -0.969637148085757290, -0.969624919465870150, -0.969612688421920500, +-0.969600454953939320, -0.969588219061956910, -0.969575980746003930, -0.969563740006111010, -0.969551496842308790, -0.969539251254627700, -0.969527003243098710, -0.969514752807752010, +-0.969502499948618480, -0.969490244665728750, -0.969477986959113360, -0.969465726828802940, -0.969453464274828370, -0.969441199297220060, -0.969428931896008760, -0.969416662071225010, +-0.969404389822899780, -0.969392115151063490, -0.969379838055746900, -0.969367558536980760, -0.969355276594795700, -0.969342992229222490, -0.969330705440291760, -0.969318416228034270, +-0.969306124592480670, -0.969293830533661920, -0.969281534051608440, -0.969269235146351220, -0.969256933817920880, -0.969244630066348200, -0.969232323891664030, -0.969220015293898900, +-0.969207704273083780, -0.969195390829249550, -0.969183074962426620, -0.969170756672646180, -0.969158435959938780, -0.969146112824335160, -0.969133787265866410, -0.969121459284563170, +-0.969109128880456310, -0.969096796053576570, -0.969084460803954940, -0.969072123131622050, -0.969059783036608890, -0.969047440518946200, -0.969035095578665070, -0.969022748215796040, +-0.969010398430370290, -0.968998046222418470, -0.968985691591971570, -0.968973334539060320, -0.968960975063715810, -0.968948613165968920, -0.968936248845850390, -0.968923882103391310, +-0.968911512938622430, -0.968899141351574960, -0.968886767342279520, -0.968874390910767100, -0.968862012057068790, -0.968849630781215440, -0.968837247083238040, -0.968824860963167440, +-0.968812472421034740, -0.968800081456870910, -0.968787688070706810, -0.968775292262573530, -0.968762894032501930, -0.968750493380523210, -0.968738090306668130, -0.968725684810967990, +-0.968713276893453430, -0.968700866554155880, -0.968688453793106090, -0.968676038610335130, -0.968663621005874110, -0.968651200979753990, -0.968638778532005970, -0.968626353662660920, +-0.968613926371750030, -0.968601496659304280, -0.968589064525354760, -0.968576629969932660, -0.968564192993068950, -0.968551753594794730, -0.968539311775141190, -0.968526867534139300, +-0.968514420871820380, -0.968501971788215290, -0.968489520283355220, -0.968477066357271490, -0.968464610009994950, -0.968452151241557040, -0.968439690051988710, -0.968427226441321070, +-0.968414760409585410, -0.968402291956812820, -0.968389821083034510, -0.968377347788281660, -0.968364872072585480, -0.968352393935977160, -0.968339913378487680, -0.968327430400148570, +-0.968314945000990800, -0.968302457181045790, -0.968289966940344530, -0.968277474278918420, -0.968264979196798550, -0.968252481694016230, -0.968239981770602780, -0.968227479426589380, +-0.968214974662007230, -0.968202467476887650, -0.968189957871261830, -0.968177445845161300, -0.968164931398616920, -0.968152414531660340, -0.968139895244322760, -0.968127373536635360, +-0.968114849408629690, -0.968102322860336710, -0.968089793891788060, -0.968077262503014730, -0.968064728694048470, -0.968052192464920250, -0.968039653815661590, -0.968027112746303820, +-0.968014569256878230, -0.968002023347416250, -0.967989475017949190, -0.967976924268508450, -0.967964371099125480, -0.967951815509831450, -0.967939257500657900, -0.967926697071636260, +-0.967914134222797820, -0.967901568954174120, -0.967889001265796470, -0.967876431157696280, -0.967863858629904980, -0.967851283682454210, -0.967838706315375050, -0.967826126528699260, +-0.967813544322458030, -0.967800959696683010, -0.967788372651405490, -0.967775783186657250, -0.967763191302469350, -0.967750596998873560, -0.967738000275901290, -0.967725401133583960, +-0.967712799571953220, -0.967700195591040370, -0.967687589190877160, -0.967674980371494910, -0.967662369132925140, -0.967649755475199490, -0.967637139398349500, -0.967624520902406580, +-0.967611899987402490, -0.967599276653368530, -0.967586650900336460, -0.967574022728337700, -0.967561392137404000, -0.967548759127566660, -0.967536123698857550, -0.967523485851307980, +-0.967510845584949820, -0.967498202899814470, -0.967485557795933700, -0.967472910273339040, -0.967460260332062120, -0.967447607972134360, -0.967434953193587740, -0.967422295996453680, +-0.967409636380763940, -0.967396974346550140, -0.967384309893843830, -0.967371643022676750, -0.967358973733080550, -0.967346302025086980, -0.967333627898727570, -0.967320951354034180, +-0.967308272391038340, -0.967295591009771800, -0.967282907210266330, -0.967270220992553660, -0.967257532356665340, -0.967244841302633220, -0.967232147830488940, -0.967219451940264370, +-0.967206753631991160, -0.967194052905701150, -0.967181349761425890, -0.967168644199197240, -0.967155936219047050, -0.967143225821006870, -0.967130513005108880, -0.967117797771384400, +-0.967105080119865510, -0.967092360050583850, -0.967079637563571400, -0.967066912658859800, -0.967054185336480910, -0.967041455596466590, -0.967028723438848600, -0.967015988863658800, +-0.967003251870929060, -0.966990512460691230, -0.966977770632977070, -0.966965026387818450, -0.966952279725247330, -0.966939530645295480, -0.966926779147994740, -0.966914025233377110, +-0.966901268901474430, -0.966888510152318580, -0.966875748985941420, -0.966862985402374920, -0.966850219401650950, -0.966837450983801470, -0.966824680148858250, -0.966811906896853480, +-0.966799131227818800, -0.966786353141786400, -0.966773572638788050, -0.966760789718855820, -0.966748004382021580, -0.966735216628317300, -0.966722426457775060, -0.966709633870426740, +-0.966696838866304200, -0.966684041445439730, -0.966671241607865110, -0.966658439353612400, -0.966645634682713580, -0.966632827595200640, -0.966620018091105650, -0.966607206170460590, +-0.966594391833297540, -0.966581575079648480, -0.966568755909545610, -0.966555934323020670, -0.966543110320105980, -0.966530283900833510, -0.966517455065235340, -0.966504623813343570, +-0.966491790145190270, -0.966478954060807420, -0.966466115560227210, -0.966453274643481630, -0.966440431310602980, -0.966427585561623110, -0.966414737396574460, -0.966401886815488780, +-0.966389033818398580, -0.966376178405335630, -0.966363320576332230, -0.966350460331420690, -0.966337597670632880, -0.966324732594001090, -0.966311865101557420, -0.966298995193334180, +-0.966286122869363440, -0.966273248129677410, -0.966260370974308170, -0.966247491403288140, -0.966234609416649180, -0.966221725014423940, -0.966208838196644160, -0.966195948963342490, +-0.966183057314550790, -0.966170163250301580, -0.966157266770626850, -0.966144367875559020, -0.966131466565130160, -0.966118562839372810, -0.966105656698318940, -0.966092748142000860, +-0.966079837170451090, -0.966066923783701510, -0.966054007981784870, -0.966041089764733020, -0.966028169132578500, -0.966015246085353610, -0.966002320623090550, -0.965989392745821740, +-0.965976462453579380, -0.965963529746395880, -0.965950594624303660, -0.965937657087334810, -0.965924717135521860, -0.965911774768897110, -0.965898829987492990, -0.965885882791341800, +-0.965872933180475850, -0.965859981154927550, -0.965847026714729330, -0.965834069859913490, -0.965821110590512570, -0.965808148906558860, -0.965795184808084680, -0.965782218295122670, +-0.965769249367705030, -0.965756278025864280, -0.965743304269632840, -0.965730328099043130, -0.965717349514127580, -0.965704368514918700, -0.965691385101448920, -0.965678399273750650, +-0.965665411031856320, -0.965652420375798570, -0.965639427305609700, -0.965626431821322240, -0.965613433922968720, -0.965600433610581680, -0.965587430884193520, -0.965574425743836780, +-0.965561418189544000, -0.965548408221347580, -0.965535395839280270, -0.965522381043374400, -0.965509363833662590, -0.965496344210177380, -0.965483322172951300, -0.965470297722016870, +-0.965457270857406740, -0.965444241579153430, -0.965431209887289590, -0.965418175781847630, -0.965405139262860200, -0.965392100330359940, -0.965379058984379590, -0.965366015224951360, +-0.965352969052108320, -0.965339920465882680, -0.965326869466307300, -0.965313816053414710, -0.965300760227237650, -0.965287701987808670, -0.965274641335160390, -0.965261578269325570, +-0.965248512790336740, -0.965235444898226660, -0.965222374593027950, -0.965209301874773380, -0.965196226743495480, -0.965183149199227100, -0.965170069242000770, -0.965156986871849250, +-0.965143902088805290, -0.965130814892901650, -0.965117725284170840, -0.965104633262645840, -0.965091538828359070, -0.965078441981343630, -0.965065342721632020, -0.965052241049257020, +-0.965039136964251590, -0.965026030466648140, -0.965012921556479660, -0.964999810233778900, -0.964986696498578600, -0.964973580350911520, -0.964960461790810630, -0.964947340818308460, +-0.964934217433437990, -0.964921091636231850, -0.964907963426723140, -0.964894832804944480, -0.964881699770928750, -0.964868564324708690, -0.964855426466317280, -0.964842286195787270, +-0.964829143513151630, -0.964815998418443010, -0.964802850911694490, -0.964789700992938810, -0.964776548662208850, -0.964763393919537580, -0.964750236764957750, -0.964737077198502440, +-0.964723915220204290, -0.964710750830096500, -0.964697584028211710, -0.964684414814583110, -0.964671243189243350, -0.964658069152225520, -0.964644892703562460, -0.964631713843287280, +-0.964618532571432710, -0.964605348888031950, -0.964592162793117660, -0.964578974286723010, -0.964565783368880990, -0.964552590039624460, -0.964539394298986390, -0.964526196146999970, +-0.964512995583697960, -0.964499792609113450, -0.964486587223279510, -0.964473379426229130, -0.964460169217995270, -0.964446956598611020, -0.964433741568109350, -0.964420524126523240, +-0.964407304273885990, -0.964394082010230360, -0.964380857335589540, -0.964367630249996610, -0.964354400753484660, -0.964341168846086560, -0.964327934527835720, -0.964314697798764890, +-0.964301458658907370, -0.964288217108296150, -0.964274973146964530, -0.964261726774945260, -0.964248477992271870, -0.964235226798977220, -0.964221973195094510, -0.964208717180656820, +-0.964195458755697340, -0.964182197920249280, -0.964168934674345720, -0.964155669018019750, -0.964142400951304660, -0.964129130474233540, -0.964115857586839600, -0.964102582289156130, +-0.964089304581216110, -0.964076024463052850, -0.964062741934699430, -0.964049456996189270, -0.964036169647555450, -0.964022879888831170, -0.964009587720049630, -0.963996293141244240, +-0.963982996152448090, -0.963969696753694370, -0.963956394945016500, -0.963943090726447680, -0.963929784098021100, -0.963916475059769960, -0.963903163611727790, -0.963889849753927550, +-0.963876533486402790, -0.963863214809186690, -0.963849893722312560, -0.963836570225813590, -0.963823244319723330, -0.963809916004074840, -0.963796585278901660, -0.963783252144236990, +-0.963769916600114240, -0.963756578646566610, -0.963743238283627510, -0.963729895511330370, -0.963716550329708490, -0.963703202738795280, -0.963689852738623950, -0.963676500329228140, +-0.963663145510640920, -0.963649788282895940, -0.963636428646026500, -0.963623066600065910, -0.963609702145047710, -0.963596335281005300, -0.963582966007972000, -0.963569594325981220, +-0.963556220235066490, -0.963542843735261330, -0.963529464826598850, -0.963516083509112890, -0.963502699782836650, -0.963489313647803660, -0.963475925104047450, -0.963462534151601320, +-0.963449140790498930, -0.963435745020773560, -0.963422346842458980, -0.963408946255588480, -0.963395543260195720, -0.963382137856313880, -0.963368730043976940, -0.963355319823217980, +-0.963341907194070870, -0.963328492156568910, -0.963315074710745730, -0.963301654856634770, -0.963288232594269880, -0.963274807923684250, -0.963261380844911640, -0.963247951357985580, +-0.963234519462939700, -0.963221085159807420, -0.963207648448622500, -0.963194209329418350, -0.963180767802228830, -0.963167323867087250, -0.963153877524027480, -0.963140428773082920, +-0.963126977614287340, -0.963113524047674360, -0.963100068073277530, -0.963086609691130580, -0.963073148901266940, -0.963059685703720580, -0.963046220098525030, -0.963032752085713820, +-0.963019281665320800, -0.963005808837379520, -0.962992333601923710, -0.962978855958987130, -0.962965375908603430, -0.962951893450806230, -0.962938408585629290, -0.962924921313106470, +-0.962911431633271200, -0.962897939546157320, -0.962884445051798710, -0.962870948150228890, -0.962857448841481720, -0.962843947125590960, -0.962830443002590350, -0.962816936472513650, +-0.962803427535394500, -0.962789916191266860, -0.962776402440164490, -0.962762886282121030, -0.962749367717170350, -0.962735846745346290, -0.962722323366682620, -0.962708797581213080, +-0.962695269388971540, -0.962681738789991860, -0.962668205784307900, -0.962654670371953290, -0.962641132552962130, -0.962627592327368050, -0.962614049695205030, -0.962600504656506930, +-0.962586957211307490, -0.962573407359640700, -0.962559855101540410, -0.962546300437040480, -0.962532743366174780, -0.962519183888977280, -0.962505622005481730, -0.962492057715722100, +-0.962478491019732370, -0.962464921917546510, -0.962451350409198270, -0.962437776494721620, -0.962424200174150530, -0.962410621447518990, -0.962397040314860840, -0.962383456776210180, +-0.962369870831600750, -0.962356282481066750, -0.962342691724642040, -0.962329098562360490, -0.962315502994256280, -0.962301905020363280, -0.962288304640715570, -0.962274701855347140, +-0.962261096664291830, -0.962247489067583840, -0.962233879065257150, -0.962220266657345720, -0.962206651843883650, -0.962193034624904910, -0.962179415000443680, -0.962165792970533840, +-0.962152168535209570, -0.962138541694504750, -0.962124912448453770, -0.962111280797090300, -0.962097646740448730, -0.962084010278563050, -0.962070371411467340, -0.962056730139195790, +-0.962043086461782270, -0.962029440379261080, -0.962015791891666310, -0.962002140999032030, -0.961988487701392450, -0.961974831998781640, -0.961961173891233700, -0.961947513378782930, +-0.961933850461463290, -0.961920185139308990, -0.961906517412354330, -0.961892847280633290, -0.961879174744180170, -0.961865499803029160, -0.961851822457214340, -0.961838142706769930, +-0.961824460551730210, -0.961810775992129270, -0.961797089028001540, -0.961783399659380980, -0.961769707886302010, -0.961756013708798600, -0.961742317126905280, -0.961728618140656130, +-0.961714916750085580, -0.961701212955227590, -0.961687506756116580, -0.961673798152786750, -0.961660087145272510, -0.961646373733608060, -0.961632657917827700, -0.961618939697965640, +-0.961605219074056270, -0.961591496046133810, -0.961577770614232550, -0.961564042778386920, -0.961550312538631210, -0.961536579894999740, -0.961522844847526810, -0.961509107396246730, +-0.961495367541193910, -0.961481625282402660, -0.961467880619907290, -0.961454133553742320, -0.961440384083941950, -0.961426632210540700, -0.961412877933572770, -0.961399121253072700, +-0.961385362169074780, -0.961371600681613540, -0.961357836790723290, -0.961344070496438440, -0.961330301798793310, -0.961316530697822520, -0.961302757193560400, -0.961288981286041340, +-0.961275202975299890, -0.961261422261370350, -0.961247639144287350, -0.961233853624085200, -0.961220065700798430, -0.961206275374461460, -0.961192482645108930, -0.961178687512775020, +-0.961164889977494500, -0.961151090039301660, -0.961137287698231260, -0.961123482954317490, -0.961109675807595100, -0.961095866258098400, -0.961082054305862240, -0.961068239950920720, +-0.961054423193308800, -0.961040604033060690, -0.961026782470211120, -0.961012958504794510, -0.960999132136845620, -0.960985303366398870, -0.960971472193488770, -0.960957638618150200, +-0.960943802640417340, -0.960929964260325060, -0.960916123477907780, -0.960902280293200350, -0.960888434706237080, -0.960874586717052840, -0.960860736325682030, -0.960846883532159410, +-0.960833028336519620, -0.960819170738797190, -0.960805310739026860, -0.960791448337243280, -0.960777583533481080, -0.960763716327774910, -0.960749846720159400, -0.960735974710669400, +-0.960722100299339350, -0.960708223486203990, -0.960694344271298300, -0.960680462654656560, -0.960666578636313770, -0.960652692216304450, -0.960638803394663450, -0.960624912171425430, +-0.960611018546625120, -0.960597122520297160, -0.960583224092476540, -0.960569323263197880, -0.960555420032495830, -0.960541514400405250, -0.960527606366960880, -0.960513695932197490, +-0.960499783096149920, -0.960485867858852820, -0.960471950220341150, -0.960458030180649460, -0.960444107739812810, -0.960430182897865860, -0.960416255654843450, -0.960402326010780350, +-0.960388393965711520, -0.960374459519671710, -0.960360522672695670, -0.960346583424818380, -0.960332641776074580, -0.960318697726499250, -0.960304751276127020, -0.960290802424993100, +-0.960276851173132110, -0.960262897520579030, -0.960248941467368610, -0.960234983013535940, -0.960221022159115760, -0.960207058904143040, -0.960193093248652540, -0.960179125192679560, +-0.960165154736258520, -0.960151181879424720, -0.960137206622213020, -0.960123228964658180, -0.960109248906795390, -0.960095266448659390, -0.960081281590285270, -0.960067294331707900, +-0.960053304672962350, -0.960039312614083480, -0.960025318155106390, -0.960011321296065920, -0.959997322036997280, -0.959983320377935210, -0.959969316318914910, -0.959955309859971240, +-0.959941301001139390, -0.959927289742454230, -0.959913276083950830, -0.959899260025664280, -0.959885241567629670, -0.959871220709881840, -0.959857197452455900, -0.959843171795387030, +-0.959829143738710310, -0.959815113282460720, -0.959801080426673230, -0.959787045171383140, -0.959773007516625310, -0.959758967462435160, -0.959744925008847450, -0.959730880155897470, +-0.959716832903620310, -0.959702783252051050, -0.959688731201224780, -0.959674676751176790, -0.959660619901941960, -0.959646560653555800, -0.959632499006052960, -0.959618434959469080, +-0.959604368513839010, -0.959590299669198070, -0.959576228425581430, -0.959562154783024090, -0.959548078741561560, -0.959534000301228600, -0.959519919462060830, -0.959505836224093130, +-0.959491750587360910, -0.959477662551899260, -0.959463572117743580, -0.959449479284928850, -0.959435384053490490, -0.959421286423463580, -0.959407186394883540, -0.959393083967785440, +-0.959378979142204710, -0.959364871918176540, -0.959350762295736240, -0.959336650274918880, -0.959322535855759990, -0.959308419038294780, -0.959294299822558430, -0.959280178208586460, +-0.959266054196413860, -0.959251927786076260, -0.959237798977608860, -0.959223667771046950, -0.959209534166425850, -0.959195398163780850, -0.959181259763147390, -0.959167118964560860, +-0.959152975768056470, -0.959138830173669740, -0.959124682181435760, -0.959110531791390160, -0.959096379003568260, -0.959082223818005450, -0.959068066234736950, -0.959053906253798380, +-0.959039743875224950, -0.959025579099052280, -0.959011411925315580, -0.958997242354050370, -0.958983070385292070, -0.958968896019076090, -0.958954719255437850, -0.958940540094412870, +-0.958926358536036470, -0.958912174580344170, -0.958897988227371600, -0.958883799477153850, -0.958869608329726670, -0.958855414785125480, -0.958841218843385800, -0.958827020504543050, +-0.958812819768632750, -0.958798616635690330, -0.958784411105751410, -0.958770203178851420, -0.958755992855026110, -0.958741780134310550, -0.958727565016740720, -0.958713347502351930, +-0.958699127591179700, -0.958684905283259780, -0.958670680578627590, -0.958656453477318650, -0.958642223979368490, -0.958627992084812970, -0.958613757793687290, -0.958599521106027310, +-0.958585282021868430, -0.958571040541246530, -0.958556796664196800, -0.958542550390755310, -0.958528301720957270, -0.958514050654838520, -0.958499797192434720, -0.958485541333781390, +-0.958471283078914160, -0.958457022427868790, -0.958442759380680690, -0.958428493937385830, -0.958414226098019740, -0.958399955862618060, -0.958385683231216530, -0.958371408203850810, +-0.958357130780556510, -0.958342850961369400, -0.958328568746325220, -0.958314284135459490, -0.958299997128808200, -0.958285707726406750, -0.958271415928291130, -0.958257121734496950, +-0.958242825145059980, -0.958228526160015970, -0.958214224779400660, -0.958199921003249690, -0.958185614831599030, -0.958171306264484210, -0.958156995301941210, -0.958142681944005760, +-0.958128366190713510, -0.958114048042100430, -0.958099727498202160, -0.958085404559054670, -0.958071079224693480, -0.958056751495154790, -0.958042421370474130, -0.958028088850687460, +-0.958013753935830550, -0.957999416625939240, -0.957985076921049390, -0.957970734821196880, -0.957956390326417440, -0.957942043436747160, -0.957927694152221680, -0.957913342472876960, +-0.957898988398748870, -0.957884631929873390, -0.957870273066286250, -0.957855911808023430, -0.957841548155121010, -0.957827182107614530, -0.957812813665540160, -0.957798442828933670, +-0.957784069597831240, -0.957769693972268520, -0.957755315952281580, -0.957740935537906290, -0.957726552729178840, -0.957712167526134860, -0.957697779928810560, -0.957683389937241670, +-0.957668997551464400, -0.957654602771514600, -0.957640205597428350, -0.957625806029241520, -0.957611404066990300, -0.957596999710710440, -0.957582592960438130, -0.957568183816209340, +-0.957553772278060040, -0.957539358346026330, -0.957524942020144270, -0.957510523300449830, -0.957496102186979000, -0.957481678679768080, -0.957467252778852810, -0.957452824484269490, +-0.957438393796054110, -0.957423960714242740, -0.957409525238871460, -0.957395087369976470, -0.957380647107593630, -0.957366204451759240, -0.957351759402509270, -0.957337311959879920, +-0.957322862123907270, -0.957308409894627510, -0.957293955272076720, -0.957279498256290990, -0.957265038847306630, -0.957250577045159590, -0.957236112849886190, -0.957221646261522400, +-0.957207177280104520, -0.957192705905668740, -0.957178232138251150, -0.957163755977888050, -0.957149277424615530, -0.957134796478469770, -0.957120313139487090, -0.957105827407703560, +-0.957091339283155480, -0.957076848765879060, -0.957062355855910600, -0.957047860553286060, -0.957033362858042080, -0.957018862770214530, -0.957004360289839930, -0.956989855416954360, +-0.956975348151594130, -0.956960838493795650, -0.956946326443594900, -0.956931812001028500, -0.956917295166132440, -0.956902775938943240, -0.956888254319497090, -0.956873730307830290, +-0.956859203903979160, -0.956844675107980100, -0.956830143919869200, -0.956815610339683100, -0.956801074367457760, -0.956786536003229940, -0.956771995247035710, -0.956757452098911500, +-0.956742906558893600, -0.956728358627018550, -0.956713808303322530, -0.956699255587841970, -0.956684700480613270, -0.956670142981672860, -0.956655583091057030, -0.956641020808802310, +-0.956626456134945010, -0.956611889069521550, -0.956597319612568440, -0.956582747764122000, -0.956568173524218750, -0.956553596892894880, -0.956539017870187250, -0.956524436456131940, +-0.956509852650765600, -0.956495266454124530, -0.956480677866245350, -0.956466086887164500, -0.956451493516918380, -0.956436897755543520, -0.956422299603076560, -0.956407699059553700, +-0.956393096125011550, -0.956378490799486890, -0.956363883083015790, -0.956349272975635100, -0.956334660477381140, -0.956320045588290650, -0.956305428308399930, -0.956290808637745740, +-0.956276186576364370, -0.956261562124292700, -0.956246935281567010, -0.956232306048224070, -0.956217674424300280, -0.956203040409832390, -0.956188404004856830, -0.956173765209410330, +-0.956159124023529320, -0.956144480447250640, -0.956129834480610620, -0.956115186123646100, -0.956100535376393610, -0.956085882238889680, -0.956071226711171170, -0.956056568793274500, +-0.956041908485236510, -0.956027245787093640, -0.956012580698882840, -0.955997913220640430, -0.955983243352403260, -0.955968571094207960, -0.955953896446091300, -0.955939219408089790, +-0.955924539980240410, -0.955909858162579450, -0.955895173955144010, -0.955880487357970600, -0.955865798371095980, -0.955851106994556890, -0.955836413228389970, -0.955821717072631970, +-0.955807018527319750, -0.955792317592490060, -0.955777614268179420, -0.955762908554424920, -0.955748200451262960, -0.955733489958730640, -0.955718777076864590, -0.955704061805701550, +-0.955689344145278400, -0.955674624095631860, -0.955659901656798700, -0.955645176828815890, -0.955630449611720060, -0.955615720005548170, -0.955600988010336880, -0.955586253626123260, +-0.955571516852943840, -0.955556777690835800, -0.955542036139835680, -0.955527292199980560, -0.955512545871307180, -0.955497797153852410, -0.955483046047653220, -0.955468292552746350, +-0.955453536669168770, -0.955438778396957340, -0.955424017736148930, -0.955409254686780510, -0.955394489248889030, -0.955379721422511260, -0.955364951207684170, -0.955350178604444710, +-0.955335403612829760, -0.955320626232876390, -0.955305846464621470, -0.955291064308101840, -0.955276279763354610, -0.955261492830416610, -0.955246703509324950, -0.955231911800116460, +-0.955217117702828240, -0.955202321217497260, -0.955187522344160490, -0.955172721082854890, -0.955157917433617440, -0.955143111396485220, -0.955128302971495200, -0.955113492158684460, +-0.955098678958089970, -0.955083863369748820, -0.955069045393697970, -0.955054225029974500, -0.955039402278615500, -0.955024577139658050, -0.955009749613139000, -0.954994919699095780, +-0.954980087397565120, -0.954965252708584230, -0.954950415632190300, -0.954935576168420290, -0.954920734317311280, -0.954905890078900480, -0.954891043453224950, -0.954876194440321790, +-0.954861343040228290, -0.954846489252981320, -0.954831633078618070, -0.954816774517175840, -0.954801913568691600, -0.954787050233202650, -0.954772184510746080, -0.954757316401358970, +-0.954742445905078620, -0.954727573021942110, -0.954712697751986750, -0.954697820095249510, -0.954682940051767790, -0.954668057621578800, -0.954653172804719620, -0.954638285601227430, +-0.954623396011139550, -0.954608504034493270, -0.954593609671325670, -0.954578712921674070, -0.954563813785575640, -0.954548912263067710, -0.954534008354187450, -0.954519102058972280, +-0.954504193377459290, -0.954489282309685770, -0.954474368855689040, -0.954459453015506500, -0.954444534789175240, -0.954429614176732780, -0.954414691178216090, -0.954399765793662810, +-0.954384838023110030, -0.954369907866595260, -0.954354975324155590, -0.954340040395828540, -0.954325103081651420, -0.954310163381661410, -0.954295221295896170, -0.954280276824392760, +-0.954265329967188710, -0.954250380724321330, -0.954235429095828040, -0.954220475081746120, -0.954205518682113010, -0.954190559896966110, -0.954175598726342940, -0.954160635170280600, +-0.954145669228816720, -0.954130700901988700, -0.954115730189833870, -0.954100757092389730, -0.954085781609693820, -0.954070803741783320, -0.954055823488695890, -0.954040840850468810, +-0.954025855827139610, -0.954010868418745830, -0.953995878625324870, -0.953980886446914260, -0.953965891883551410, -0.953950894935273850, -0.953935895602119000, -0.953920893884124490, +-0.953905889781327620, -0.953890883293766150, -0.953875874421477370, -0.953860863164499030, -0.953845849522868440, -0.953830833496623230, -0.953815815085800930, -0.953800794290439180, +-0.953785771110575390, -0.953770745546247190, -0.953755717597492000, -0.953740687264347690, -0.953725654546851540, -0.953710619445041320, -0.953695581958954540, -0.953680542088628850, +-0.953665499834101760, -0.953650455195410810, -0.953635408172593960, -0.953620358765688400, -0.953605306974732000, -0.953590252799762280, -0.953575196240817100, -0.953560137297933760, +-0.953545075971150120, -0.953530012260503820, -0.953514946166032500, -0.953499877687773780, -0.953484806825765420, -0.953469733580044940, -0.953454657950650210, -0.953439579937618740, +-0.953424499540988510, -0.953409416760796820, -0.953394331597081650, -0.953379244049880730, -0.953364154119231590, -0.953349061805172200, -0.953333967107740100, -0.953318870026973020, +-0.953303770562908830, -0.953288668715585260, -0.953273564485039860, -0.953258457871310690, -0.953243348874435290, -0.953228237494451620, -0.953213123731397220, -0.953198007585310150, +-0.953182889056227940, -0.953167768144188690, -0.953152644849229790, -0.953137519171389450, -0.953122391110705180, -0.953107260667214960, -0.953092127840956760, -0.953076992631967990, +-0.953061855040286950, -0.953046715065951180, -0.953031572708998630, -0.953016427969467060, -0.953001280847394550, -0.952986131342818730, -0.952970979455777690, -0.952955825186309170, +-0.952940668534451140, -0.952925509500241350, -0.952910348083717770, -0.952895184284918370, -0.952880018103881010, -0.952864849540643540, -0.952849678595244050, -0.952834505267720290, +-0.952819329558110330, -0.952804151466452030, -0.952788970992783260, -0.952773788137142200, -0.952758602899566490, -0.952743415280094430, -0.952728225278763770, -0.952713032895612600, +-0.952697838130678760, -0.952682640984000460, -0.952667441455615440, -0.952652239545561890, -0.952637035253877660, -0.952621828580600960, -0.952606619525769640, -0.952591408089421780, +-0.952576194271595340, -0.952560978072328420, -0.952545759491659090, -0.952530538529625330, -0.952515315186265200, -0.952500089461616790, -0.952484861355718300, -0.952469630868607480, +-0.952454398000322720, -0.952439162750901900, -0.952423925120383210, -0.952408685108804610, -0.952393442716204410, -0.952378197942620460, -0.952362950788091190, -0.952347701252654440, +-0.952332449336348530, -0.952317195039211310, -0.952301938361281300, -0.952286679302596360, -0.952271417863194690, -0.952256154043114480, -0.952240887842394020, -0.952225619261071190, +-0.952210348299184380, -0.952195074956771690, -0.952179799233871300, -0.952164521130521410, -0.952149240646760210, -0.952133957782625990, -0.952118672538156740, -0.952103384913390860, +-0.952088094908366540, -0.952072802523121990, -0.952057507757695380, -0.952042210612125130, -0.952026911086449210, -0.952011609180706150, -0.951996304894933920, -0.951980998229171040, +-0.951965689183455590, -0.951950377757825980, -0.951935063952320410, -0.951919747766977190, -0.951904429201834600, -0.951889108256930850, -0.951873784932304460, -0.951858459227993500, +-0.951843131144036400, -0.951827800680471460, -0.951812467837337190, -0.951797132614671580, -0.951781795012513250, -0.951766455030900290, -0.951751112669871340, -0.951735767929464460, +-0.951720420809718300, -0.951705071310671060, -0.951689719432361140, -0.951674365174826840, -0.951659008538106700, -0.951643649522239010, -0.951628288127262190, -0.951612924353214650, +-0.951597558200134920, -0.951582189668061070, -0.951566818757031860, -0.951551445467085700, -0.951536069798260780, -0.951520691750595840, -0.951505311324128970, -0.951489928518899020, +-0.951474543334944080, -0.951459155772302890, -0.951443765831013750, -0.951428373511115310, -0.951412978812645750, -0.951397581735643930, -0.951382182280148040, -0.951366780446196820, +-0.951351376233828480, -0.951335969643081870, -0.951320560673995170, -0.951305149326607150, -0.951289735600956200, -0.951274319497081080, -0.951258901015019980, -0.951243480154811640, +-0.951228056916494700, -0.951212631300107580, -0.951197203305688910, -0.951181772933277100, -0.951166340182911020, -0.951150905054628960, -0.951135467548469780, -0.951120027664471790, +-0.951104585402673840, -0.951089140763114350, -0.951073693745832060, -0.951058244350865500, -0.951042792578253420, -0.951027338428034220, -0.951011881900246770, -0.950996422994929590, +-0.950980961712121320, -0.950965498051860700, -0.950950032014186260, -0.950934563599136860, -0.950919092806750910, -0.950903619637067380, -0.950888144090124680, -0.950872666165961670, +-0.950857185864616980, -0.950841703186129370, -0.950826218130537360, -0.950810730697880020, -0.950795240888195670, -0.950779748701523380, -0.950764254137901550, -0.950748757197369180, +-0.950733257879964880, -0.950717756185727510, -0.950702252114695720, -0.950686745666908250, -0.950671236842403950, -0.950655725641221580, -0.950640212063399880, -0.950624696108977600, +-0.950609177777993590, -0.950593657070486710, -0.950578133986495600, -0.950562608526059230, -0.950547080689216340, -0.950531550476005680, -0.950516017886466220, -0.950500482920636600, +-0.950484945578555900, -0.950469405860262740, -0.950453863765796210, -0.950438319295194840, -0.950422772448497820, -0.950407223225743780, -0.950391671626971690, -0.950376117652220410, +-0.950360561301528910, -0.950345002574935930, -0.950329441472480440, -0.950313877994201420, -0.950298312140137710, -0.950282743910328190, -0.950267173304811810, -0.950251600323627540, +-0.950236024966814140, -0.950220447234410790, -0.950204867126456240, -0.950189284642989570, -0.950173699784049750, -0.950158112549675640, -0.950142522939906200, -0.950126930954780510, +-0.950111336594337440, -0.950095739858616060, -0.950080140747655340, -0.950064539261494260, -0.950048935400171770, -0.950033329163727070, -0.950017720552198910, -0.950002109565626470, +-0.949986496204048850, -0.949970880467505000, -0.949955262356033890, -0.949939641869674610, -0.949924019008466240, -0.949908393772447850, -0.949892766161658410, -0.949877136176137120, +-0.949861503815922940, -0.949845869081055060, -0.949830231971572460, -0.949814592487514320, -0.949798950628919720, -0.949783306395827640, -0.949767659788277370, -0.949752010806307890, +-0.949736359449958490, -0.949720705719268140, -0.949705049614275930, -0.949689391135021270, -0.949673730281543000, -0.949658067053880450, -0.949642401452072680, -0.949626733476159000, +-0.949611063126178490, -0.949595390402170230, -0.949579715304173510, -0.949564037832227650, -0.949548357986371490, -0.949532675766644570, -0.949516991173085860, -0.949501304205734860, +-0.949485614864630350, -0.949469923149812050, -0.949454229061318710, -0.949438532599189980, -0.949422833763464810, -0.949407132554182630, -0.949391428971382510, -0.949375723015103870, +-0.949360014685386000, -0.949344303982267990, -0.949328590905789360, -0.949312875455989080, -0.949297157632906670, -0.949281437436581440, -0.949265714867052580, -0.949249989924359380, +-0.949234262608541270, -0.949218532919637430, -0.949202800857687380, -0.949187066422730210, -0.949171329614805440, -0.949155590433952260, -0.949139848880210190, -0.949124104953618430, +-0.949108358654216500, -0.949092609982043590, -0.949076858937139220, -0.949061105519542700, -0.949045349729293330, -0.949029591566430740, -0.949013831030994020, -0.948998068123022790, +-0.948982302842556360, -0.948966535189634250, -0.948950765164295770, -0.948934992766580330, -0.948919217996527450, -0.948903440854176550, -0.948887661339566920, -0.948871879452738320, +-0.948856095193729930, -0.948840308562581280, -0.948824519559331890, -0.948808728184021180, -0.948792934436688660, -0.948777138317373870, -0.948761339826116100, -0.948745538962954990, +-0.948729735727930180, -0.948713930121080850, -0.948698122142446860, -0.948682311792067520, -0.948666499069982350, -0.948650683976230980, -0.948634866510852940, -0.948619046673887630, +-0.948603224465374820, -0.948587399885353790, -0.948571572933864400, -0.948555743610945970, -0.948539911916638330, -0.948524077850980700, -0.948508241414013130, -0.948492402605774720, +-0.948476561426305430, -0.948460717875644680, -0.948444871953832200, -0.948429023660907530, -0.948413172996910190, -0.948397319961880040, -0.948381464555856590, -0.948365606778879490, +-0.948349746630988260, -0.948333884112222750, -0.948318019222622490, -0.948302151962227340, -0.948286282331076590, -0.948270410329210220, -0.948254535956667870, -0.948238659213489150, +-0.948222780099713720, -0.948206898615381430, -0.948191014760531800, -0.948175128535204800, -0.948159239939439850, -0.948143348973276790, -0.948127455636755380, -0.948111559929915360, +-0.948095661852796370, -0.948079761405438260, -0.948063858587880780, -0.948047953400163680, -0.948032045842326700, -0.948016135914409470, -0.948000223616452090, -0.947984308948493950, +-0.947968391910575250, -0.947952472502735400, -0.947936550725014480, -0.947920626577452020, -0.947904700060088200, -0.947888771172962440, -0.947872839916114930, -0.947856906289585190, +-0.947840970293413300, -0.947825031927638890, -0.947809091192301940, -0.947793148087442190, -0.947777202613099610, -0.947761254769314170, -0.947745304556125380, -0.947729351973573440, +-0.947713397021698100, -0.947697439700539320, -0.947681480010136860, -0.947665517950530780, -0.947649553521760830, -0.947633586723866990, -0.947617617556889220, -0.947601646020867490, +-0.947585672115841550, -0.947569695841851470, -0.947553717198937000, -0.947537736187138440, -0.947521752806495420, -0.947505767057048140, -0.947489778938836240, -0.947473788451900110, +-0.947457795596279410, -0.947441800372014090, -0.947425802779144450, -0.947409802817710260, -0.947393800487751570, -0.947377795789308360, -0.947361788722420720, -0.947345779287128490, +-0.947329767483471970, -0.947313753311490920, -0.947297736771225530, -0.947281717862715760, -0.947265696586001680, -0.947249672941123390, -0.947233646928120950, -0.947217618547034350, +-0.947201587797903750, -0.947185554680769150, -0.947169519195670720, -0.947153481342648320, -0.947137441121742360, -0.947121398532992820, -0.947105353576439660, -0.947089306252123290, +-0.947073256560083450, -0.947057204500360680, -0.947041150072994720, -0.947025093278025980, -0.947009034115494530, -0.946992972585440460, -0.946976908687903850, -0.946960842422925110, +-0.946944773790544200, -0.946928702790801440, -0.946912629423736880, -0.946896553689390740, -0.946880475587803190, -0.946864395119014430, -0.946848312283064760, -0.946832227079994260, +-0.946816139509843220, -0.946800049572651740, -0.946783957268460320, -0.946767862597308830, -0.946751765559237790, -0.946735666154287280, -0.946719564382497600, -0.946703460243909060, +-0.946687353738561830, -0.946671244866496230, -0.946655133627752550, -0.946639020022370990, -0.946622904050391960, -0.946606785711855530, -0.946590665006802220, -0.946574541935272240, +-0.946558416497305990, -0.946542288692943550, -0.946526158522225550, -0.946510025985191960, -0.946493891081883420, -0.946477753812340120, -0.946461614176602460, -0.946445472174710760, +-0.946429327806705410, -0.946413181072626730, -0.946397031972515010, -0.946380880506410780, -0.946364726674354340, -0.946348570476386100, -0.946332411912546470, -0.946316250982875750, +-0.946300087687414360, -0.946283922026202930, -0.946267753999281540, -0.946251583606690820, -0.946235410848471070, -0.946219235724662930, -0.946203058235306590, -0.946186878380442580, +-0.946170696160111400, -0.946154511574353490, -0.946138324623209350, -0.946122135306719400, -0.946105943624924060, -0.946089749577863850, -0.946073553165579400, -0.946057354388110890, +-0.946041153245499090, -0.946024949737784390, -0.946008743865007330, -0.945992535627208310, -0.945976325024428080, -0.945960112056706940, -0.945943896724085630, -0.945927679026604570, +-0.945911458964304290, -0.945895236537225290, -0.945879011745408230, -0.945862784588893610, -0.945846555067722080, -0.945830323181934160, -0.945814088931570480, -0.945797852316671570, +-0.945781613337277950, -0.945765371993430360, -0.945749128285169330, -0.945732882212535490, -0.945716633775569360, -0.945700382974311690, -0.945684129808803120, -0.945667874279084160, +-0.945651616385195570, -0.945635356127177970, -0.945619093505071890, -0.945602828518918080, -0.945586561168757280, -0.945570291454630010, -0.945554019376577020, -0.945537744934639050, +-0.945521468128856620, -0.945505188959270490, -0.945488907425921510, -0.945472623528850200, -0.945456337268097300, -0.945440048643703570, -0.945423757655709850, -0.945407464304156560, +-0.945391168589084670, -0.945374870510534930, -0.945358570068547950, -0.945342267263164500, -0.945325962094425540, -0.945309654562371480, -0.945293344667043400, -0.945277032408481930, +-0.945260717786727930, -0.945244400801822040, -0.945228081453805210, -0.945211759742718090, -0.945195435668601760, -0.945179109231496620, -0.945162780431443860, -0.945146449268484120, +-0.945130115742658150, -0.945113779854007020, -0.945097441602571360, -0.945081100988392260, -0.945064758011510240, -0.945048412671966380, -0.945032064969801410, -0.945015714905056430, +-0.944999362477772050, -0.944983007687989370, -0.944966650535749020, -0.944950291021092180, -0.944933929144059490, -0.944917564904692140, -0.944901198303030650, -0.944884829339116330, +-0.944868458012989910, -0.944852084324692250, -0.944835708274264550, -0.944819329861747440, -0.944802949087182100, -0.944786565950609390, -0.944770180452070170, -0.944753792591605520, +-0.944737402369256520, -0.944721009785063900, -0.944704614839068760, -0.944688217531312050, -0.944671817861834960, -0.944655415830678140, -0.944639011437882870, -0.944622604683490020, +-0.944606195567540770, -0.944589784090075880, -0.944573370251136630, -0.944556954050763900, -0.944540535488998860, -0.944524114565882480, -0.944507691281455730, -0.944491265635759800, +-0.944474837628835660, -0.944458407260724500, -0.944441974531467280, -0.944425539441105190, -0.944409101989679090, -0.944392662177230390, -0.944376220003799950, -0.944359775469429060, +-0.944343328574158590, -0.944326879318029940, -0.944310427701083980, -0.944293973723361990, -0.944277517384905060, -0.944261058685754380, -0.944244597625951030, -0.944228134205536200, +-0.944211668424551060, -0.944195200283036610, -0.944178729781034340, -0.944162256918585130, -0.944145781695730270, -0.944129304112511060, -0.944112824168968470, -0.944096341865143910, +-0.944079857201078450, -0.944063370176813410, -0.944046880792389850, -0.944030389047849080, -0.944013894943232510, -0.943997398478581000, -0.943980899653936170, -0.943964398469338880, +-0.943947894924830780, -0.943931389020452930, -0.943914880756246520, -0.943898370132252970, -0.943881857148513470, -0.943865341805069310, -0.943848824101961800, -0.943832304039232240, +-0.943815781616921920, -0.943799256835072150, -0.943782729693724230, -0.943766200192919570, -0.943749668332699240, -0.943733134113104890, -0.943716597534177580, -0.943700058595958960, +-0.943683517298489980, -0.943666973641812400, -0.943650427625967180, -0.943633879250996070, -0.943617328516940250, -0.943600775423841020, -0.943584219971739910, -0.943567662160678220, +-0.943551101990697360, -0.943534539461838740, -0.943517974574143880, -0.943501407327653970, -0.943484837722410540, -0.943468265758455100, -0.943451691435828970, -0.943435114754573530, +-0.943418535714730440, -0.943401954316340880, -0.943385370559446490, -0.943368784444088670, -0.943352195970308950, -0.943335605138148630, -0.943319011947649440, -0.943302416398852590, +-0.943285818491799710, -0.943269218226532310, -0.943252615603091930, -0.943236010621519960, -0.943219403281857940, -0.943202793584147380, -0.943186181528429920, -0.943169567114746980, +-0.943152950343140060, -0.943136331213650920, -0.943119709726320750, -0.943103085881191520, -0.943086459678304400, -0.943069831117701260, -0.943053200199423400, -0.943036566923512680, +-0.943019931290010490, -0.943003293298958490, -0.942986652950398190, -0.942970010244371330, -0.942953365180919430, -0.942936717760084140, -0.942920067981906970, -0.942903415846429670, +-0.942886761353693870, -0.942870104503741090, -0.942853445296613080, -0.942836783732351470, -0.942820119810997890, -0.942803453532593980, -0.942786784897181600, -0.942770113904802140, +-0.942753440555497370, -0.942736764849309020, -0.942720086786278830, -0.942703406366448230, -0.942686723589859280, -0.942670038456553510, -0.942653350966572660, -0.942636661119958360, +-0.942619968916752480, -0.942603274356996530, -0.942586577440732600, -0.942569878168002080, -0.942553176538846960, -0.942536472553308860, -0.942519766211429520, -0.942503057513250810, +-0.942486346458814460, -0.942469633048162340, -0.942452917281335960, -0.942436199158377400, -0.942419478679328290, -0.942402755844230500, -0.942386030653125870, -0.942369303106056160, +-0.942352573203063090, -0.942335840944188650, -0.942319106329474690, -0.942302369358962830, -0.942285630032695170, -0.942268888350713320, -0.942252144313059260, -0.942235397919774950, +-0.942218649170902030, -0.942201898066482580, -0.942185144606558330, -0.942168388791171150, -0.942151630620363110, -0.942134870094175960, -0.942118107212651660, -0.942101341975832060, +-0.942084574383759140, -0.942067804436474750, -0.942051032134020860, -0.942034257476439320, -0.942017480463772320, -0.942000701096061380, -0.941983919373348910, -0.941967135295676440, +-0.941950348863086370, -0.941933560075620240, -0.941916768933320330, -0.941899975436228390, -0.941883179584386500, -0.941866381377836740, -0.941849580816620960, -0.941832777900781350, +-0.941815972630359650, -0.941799165005398060, -0.941782355025938540, -0.941765542692023280, -0.941748728003694020, -0.941731910960993070, -0.941715091563962160, -0.941698269812643710, +-0.941681445707079460, -0.941664619247311600, -0.941647790433382200, -0.941630959265333360, -0.941614125743207130, -0.941597289867045610, -0.941580451636890750, -0.941563611052784850, +-0.941546768114769890, -0.941529922822888050, -0.941513075177181300, -0.941496225177691940, -0.941479372824462040, -0.941462518117533680, -0.941445661056949050, -0.941428801642750220, +-0.941411939874979400, -0.941395075753678760, -0.941378209278890490, -0.941361340450656560, -0.941344469269019380, -0.941327595734020920, -0.941310719845703580, -0.941293841604109450, +-0.941276961009280710, -0.941260078061259440, -0.941243192760088050, -0.941226305105808740, -0.941209415098463680, -0.941192522738094950, -0.941175628024744970, -0.941158730958455920, +-0.941141831539270000, -0.941124929767229610, -0.941108025642376830, -0.941091119164754080, -0.941074210334403420, -0.941057299151367270, -0.941040385615687810, -0.941023469727407580, +-0.941006551486568420, -0.940989630893213080, -0.940972707947383520, -0.940955782649122390, -0.940938854998471630, -0.940921924995473780, -0.940904992640171020, -0.940888057932605990, +-0.940871120872820650, -0.940854181460857640, -0.940837239696759030, -0.940820295580567350, -0.940803349112324990, -0.940786400292074170, -0.940769449119857490, -0.940752495595717050, +-0.940735539719695480, -0.940718581491834960, -0.940701620912178130, -0.940684657980767060, -0.940667692697644500, -0.940650725062852630, -0.940633755076434100, -0.940616782738430970, +-0.940599808048885990, -0.940582831007841460, -0.940565851615339900, -0.940548869871423610, -0.940531885776135220, -0.940514899329517150, -0.940497910531611800, -0.940480919382461590, +-0.940463925882109140, -0.940446930030596980, -0.940429931827967300, -0.940412931274262950, -0.940395928369526240, -0.940378923113799670, -0.940361915507125780, -0.940344905549547190, +-0.940327893241106220, -0.940310878581845590, -0.940293861571807720, -0.940276842211035360, -0.940259820499570690, -0.940242796437456560, -0.940225770024735400, -0.940208741261449820, +-0.940191710147642470, -0.940174676683355750, -0.940157640868632290, -0.940140602703514850, -0.940123562188045820, -0.940106519322267960, -0.940089474106223790, -0.940072426539955820, +-0.940055376623507020, -0.940038324356919590, -0.940021269740236360, -0.940004212773499990, -0.939987153456753100, -0.939970091790038320, -0.939953027773398290, -0.939935961406875740, +-0.939918892690513320, -0.939901821624353540, -0.939884748208439260, -0.939867672442813110, -0.939850594327517830, -0.939833513862595950, -0.939816431048090430, -0.939799345884043790, +-0.939782258370498670, -0.939765168507498030, -0.939748076295084390, -0.939730981733300720, -0.939713884822189430, -0.939696785561793480, -0.939679683952155510, -0.939662579993318480, +-0.939645473685324810, -0.939628365028217560, -0.939611254022039380, -0.939594140666833110, -0.939577024962641390, -0.939559906909507300, -0.939542786507473250, -0.939525663756582310, +-0.939508538656877220, -0.939491411208400740, -0.939474281411195710, -0.939457149265304990, -0.939440014770771550, -0.939422877927637900, -0.939405738735947130, -0.939388597195741970, +-0.939371453307065400, -0.939354307069960040, -0.939337158484469080, -0.939320007550635160, -0.939302854268501240, -0.939285698638110070, -0.939268540659504820, -0.939251380332728150, +-0.939234217657823000, -0.939217052634832350, -0.939199885263799050, -0.939182715544765960, -0.939165543477776250, -0.939148369062872580, -0.939131192300098010, -0.939114013189495390, +-0.939096831731107810, -0.939079647924978110, -0.939062461771149270, -0.939045273269664360, -0.939028082420566230, -0.939010889223897970, -0.938993693679702310, -0.938976495788022560, +-0.938959295548901560, -0.938942092962382290, -0.938924888028507710, -0.938907680747321120, -0.938890471118865140, -0.938873259143183090, -0.938856044820317810, -0.938838828150312500, +-0.938821609133210000, -0.938804387769053620, -0.938787164057886090, -0.938769937999750840, -0.938752709594690590, -0.938735478842748660, -0.938718245743968010, -0.938701010298391810, +-0.938683772506063050, -0.938666532367024800, -0.938649289881320240, -0.938632045048992450, -0.938614797870084620, -0.938597548344639710, -0.938580296472701030, -0.938563042254311530, +-0.938545785689514410, -0.938528526778352860, -0.938511265520870050, -0.938494001917108970, -0.938476735967112900, -0.938459467670925030, -0.938442197028588550, -0.938424924040146440, +-0.938407648705642080, -0.938390371025118690, -0.938373090998619210, -0.938355808626187170, -0.938338523907865430, -0.938321236843697500, -0.938303947433726470, -0.938286655677995630, +-0.938269361576547940, -0.938252065129427050, -0.938234766336675910, -0.938217465198337930, -0.938200161714456190, -0.938182855885074110, -0.938165547710234860, -0.938148237189981750, +-0.938130924324358070, -0.938113609113407130, -0.938096291557172000, -0.938078971655696310, -0.938061649409023040, -0.938044324817195680, -0.938026997880257670, -0.938009668598251970, +-0.937992336971222200, -0.937975002999211550, -0.937957666682263440, -0.937940328020421150, -0.937922987013728000, -0.937905643662227400, -0.937888297965962740, -0.937870949924977330, +-0.937853599539314460, -0.937836246809017670, -0.937818891734130240, -0.937801534314695480, -0.937784174550757130, -0.937766812442358160, -0.937749447989542180, -0.937732081192352520, +-0.937714712050832790, -0.937697340565026180, -0.937679966734976220, -0.937662590560726540, -0.937645212042320100, -0.937627831179800860, -0.937610447973211910, -0.937593062422596880, +-0.937575674527999170, -0.937558284289462310, -0.937540891707029700, -0.937523496780744870, -0.937506099510651340, -0.937488699896792620, -0.937471297939212020, -0.937453893637953170, +-0.937436486993059590, -0.937419078004574910, -0.937401666672542430, -0.937384252997005900, -0.937366836978008600, -0.937349418615594290, -0.937331997909806370, -0.937314574860688480, +-0.937297149468284240, -0.937279721732636960, -0.937262291653790490, -0.937244859231788240, -0.937227424466673950, -0.937209987358491040, -0.937192547907283120, -0.937175106113093850, +-0.937157661975966840, -0.937140215495945620, -0.937122766673073930, -0.937105315507395290, -0.937087861998953440, -0.937070406147791800, -0.937052947953954220, -0.937035487417484210, +-0.937018024538425530, -0.937000559316821800, -0.936983091752716660, -0.936965621846153840, -0.936948149597176870, -0.936930675005829610, -0.936913198072155560, -0.936895718796198600, +-0.936878237178002340, -0.936860753217610530, -0.936843266915066700, -0.936825778270414800, -0.936808287283698470, -0.936790793954961340, -0.936773298284247270, -0.936755800271599990, +-0.936738299917063140, -0.936720797220680690, -0.936703292182496040, -0.936685784802553380, -0.936668275080896010, -0.936650763017568110, -0.936633248612613320, -0.936615731866075270, +-0.936598212777998040, -0.936580691348425140, -0.936563167577400660, -0.936545641464968210, -0.936528113011171670, -0.936510582216054770, -0.936493049079661470, -0.936475513602035510, +-0.936457975783220880, -0.936440435623261180, -0.936422893122200510, -0.936405348280082480, -0.936387801096951190, -0.936370251572850250, -0.936352699707823870, -0.936335145501915660, +-0.936317588955169590, -0.936300030067629520, -0.936282468839339300, -0.936264905270343010, -0.936247339360684490, -0.936229771110407620, -0.936212200519556230, -0.936194627588174400, +-0.936177052316305990, -0.936159474703994960, -0.936141894751285180, -0.936124312458220810, -0.936106727824845500, -0.936089140851203430, -0.936071551537338560, -0.936053959883294760, +-0.936036365889115980, -0.936018769554846420, -0.936001170880529920, -0.935983569866210450, -0.935965966511932090, -0.935948360817738690, -0.935930752783674550, -0.935913142409783520, +-0.935895529696109560, -0.935877914642696760, -0.935860297249589300, -0.935842677516830920, -0.935825055444466040, -0.935807431032538380, -0.935789804281092150, -0.935772175190171420, +-0.935754543759820370, -0.935736909990082850, -0.935719273881003070, -0.935701635432625080, -0.935683994644993080, -0.935666351518151030, -0.935648706052143120, -0.935631058247013430, +-0.935613408102806130, -0.935595755619565210, -0.935578100797334940, -0.935560443636159530, -0.935542784136082940, -0.935525122297149460, -0.935507458119403060, -0.935489791602888030, +-0.935472122747648570, -0.935454451553728750, -0.935436778021172870, -0.935419102150024990, -0.935401423940329320, -0.935383743392130260, -0.935366060505471660, -0.935348375280398050, +-0.935330687716953380, -0.935312997815182070, -0.935295305575128190, -0.935277610996836150, -0.935259914080350030, -0.935242214825714010, -0.935224513232972620, -0.935206809302169930, +-0.935189103033350120, -0.935171394426557610, -0.935153683481836700, -0.935135970199231450, -0.935118254578786390, -0.935100536620545600, -0.935082816324553480, -0.935065093690854330, +-0.935047368719492460, -0.935029641410512150, -0.935011911763957810, -0.934994179779873540, -0.934976445458303940, -0.934958708799293210, -0.934940969802885770, -0.934923228469125790, +-0.934905484798057800, -0.934887738789726090, -0.934869990444174960, -0.934852239761448930, -0.934834486741592310, -0.934816731384649380, -0.934798973690664670, -0.934781213659682590, +-0.934763451291747430, -0.934745686586903710, -0.934727919545195630, -0.934710150166667920, -0.934692378451364660, -0.934674604399330590, -0.934656828010610010, -0.934639049285247330, +-0.934621268223286950, -0.934603484824773510, -0.934585699089751310, -0.934567911018264860, -0.934550120610358580, -0.934532327866077090, -0.934514532785464700, -0.934496735368566030, +-0.934478935615425610, -0.934461133526087620, -0.934443329100597020, -0.934425522338998000, -0.934407713241335200, -0.934389901807653130, -0.934372088037996210, -0.934354271932409160, +-0.934336453490936410, -0.934318632713622590, -0.934300809600512090, -0.934282984151649560, -0.934265156367079630, -0.934247326246846810, -0.934229493790995740, -0.934211658999570820, +-0.934193821872616790, -0.934175982410178190, -0.934158140612299630, -0.934140296479025740, -0.934122450010401060, -0.934104601206470320, -0.934086750067278040, -0.934068896592868960, +-0.934051040783287490, -0.934033182638578600, -0.934015322158786580, -0.933997459343956390, -0.933979594194132460, -0.933961726709359620, -0.933943856889682400, -0.933925984735145650, +-0.933908110245793790, -0.933890233421671770, -0.933872354262824110, -0.933854472769295560, -0.933836588941130860, -0.933818702778374750, -0.933800814281071760, -0.933782923449266720, +-0.933765030283004500, -0.933747134782329510, -0.933729236947286930, -0.933711336777921060, -0.933693434274276980, -0.933675529436399200, -0.933657622264332690, -0.933639712758122080, +-0.933621800917812220, -0.933603886743447850, -0.933585970235073730, -0.933568051392734690, -0.933550130216475590, -0.933532206706341070, -0.933514280862376090, -0.933496352684625390, +-0.933478422173133930, -0.933460489327946230, -0.933442554149107370, -0.933424616636662100, -0.933406676790655250, -0.933388734611131920, -0.933370790098136500, -0.933352843251714300, +-0.933334894071909840, -0.933316942558768290, -0.933298988712334300, -0.933281032532652820, -0.933263074019768820, -0.933245113173727160, -0.933227149994572570, -0.933209184482350240, +-0.933191216637104910, -0.933173246458881560, -0.933155273947725020, -0.933137299103680370, -0.933119321926792480, -0.933101342417106290, -0.933083360574666680, -0.933065376399518590, +-0.933047389891707210, -0.933029401051277300, -0.933011409878273910, -0.932993416372742020, -0.932975420534726600, -0.932957422364272480, -0.932939421861424980, -0.932921419026228830, +-0.932903413858729210, -0.932885406358970990, -0.932867396526999240, -0.932849384362859020, -0.932831369866595430, -0.932813353038253300, -0.932795333877877830, -0.932777312385513980, +-0.932759288561206930, -0.932741262405001550, -0.932723233916943010, -0.932705203097076500, -0.932687169945446980, -0.932669134462099540, -0.932651096647079130, -0.932633056500431160, +-0.932615014022200370, -0.932596969212432180, -0.932578922071171550, -0.932560872598463540, -0.932542820794353360, -0.932524766658886280, -0.932506710192107070, -0.932488651394061230, +-0.932470590264793620, -0.932452526804349760, -0.932434461012774380, -0.932416392890112910, -0.932398322436410520, -0.932380249651712290, -0.932362174536063400, -0.932344097089509050, +-0.932326017312094520, -0.932307935203864900, -0.932289850764865480, -0.932271763995141440, -0.932253674894737980, -0.932235583463700280, -0.932217489702073740, -0.932199393609903340, +-0.932181295187234580, -0.932163194434112440, -0.932145091350582430, -0.932126985936689630, -0.932108878192479450, -0.932090768117996960, -0.932072655713287680, -0.932054540978396680, +-0.932036423913369380, -0.932018304518250960, -0.932000182793086720, -0.931982058737922170, -0.931963932352802390, -0.931945803637772800, -0.931927672592878680, -0.931909539218165440, +-0.931891403513678270, -0.931873265479462700, -0.931855125115563900, -0.931836982422027280, -0.931818837398898150, -0.931800690046222010, -0.931782540364044180, -0.931764388352409930, +-0.931746234011364690, -0.931728077340953980, -0.931709918341222960, -0.931691757012217180, -0.931673593353981920, -0.931655427366562820, -0.931637259050005050, -0.931619088404354150, +-0.931600915429655620, -0.931582740125954770, -0.931564562493297000, -0.931546382531727830, -0.931528200241292790, -0.931510015622037170, -0.931491828674006590, -0.931473639397246370, +-0.931455447791802120, -0.931437253857719140, -0.931419057595043180, -0.931400859003819410, -0.931382658084093600, -0.931364454835911130, -0.931346249259317530, -0.931328041354358200, +-0.931309831121078900, -0.931291618559524910, -0.931273403669741980, -0.931255186451775520, -0.931236966905671040, -0.931218745031474170, -0.931200520829230440, -0.931182294298985470, +-0.931164065440784670, -0.931145834254673790, -0.931127600740698220, -0.931109364898903720, -0.931091126729335810, -0.931072886232040100, -0.931054643407062120, -0.931036398254447620, +-0.931018150774241990, -0.930999900966491100, -0.930981648831240350, -0.930963394368535590, -0.930945137578422340, -0.930926878460946240, -0.930908617016152800, -0.930890353244087860, +-0.930872087144797190, -0.930853818718326180, -0.930835547964720680, -0.930817274884026320, -0.930798999476288750, -0.930780721741553570, -0.930762441679866770, -0.930744159291273740, +-0.930725874575820460, -0.930707587533552320, -0.930689298164515290, -0.930671006468755000, -0.930652712446317310, -0.930634416097247620, -0.930616117421592120, -0.930597816419396100, +-0.930579513090705750, -0.930561207435566470, -0.930542899454024240, -0.930524589146124680, -0.930506276511913640, -0.930487961551437090, -0.930469644264740440, -0.930451324651869860, +-0.930433002712870880, -0.930414678447789360, -0.930396351856671130, -0.930378022939562180, -0.930359691696508010, -0.930341358127554700, -0.930323022232747880, -0.930304684012133620, +-0.930286343465757560, -0.930268000593665770, -0.930249655395903870, -0.930231307872517840, -0.930212958023553530, -0.930194605849056890, -0.930176251349073670, -0.930157894523649830, +-0.930139535372831340, -0.930121173896663930, -0.930102810095193580, -0.930084443968466230, -0.930066075516527760, -0.930047704739424110, -0.930029331637201250, -0.930010956209905040, +-0.929992578457581430, -0.929974198380276280, -0.929955815978035780, -0.929937431250905670, -0.929919044198932010, -0.929900654822160670, -0.929882263120637820, -0.929863869094409100, +-0.929845472743520920, -0.929827074068019010, -0.929808673067949340, -0.929790269743357990, -0.929771864094291020, -0.929753456120794410, -0.929735045822914110, -0.929716633200696200, +-0.929698218254186750, -0.929679800983431730, -0.929661381388477200, -0.929642959469369260, -0.929624535226153850, -0.929606108658877160, -0.929587679767585160, -0.929569248552324030, +-0.929550815013139630, -0.929532379150078360, -0.929513940963186070, -0.929495500452508950, -0.929477057618092960, -0.929458612459984510, -0.929440164978229340, -0.929421715172873860, +-0.929403263043964150, -0.929384808591546150, -0.929366351815666290, -0.929347892716370420, -0.929329431293704930, -0.929310967547715690, -0.929292501478449220, -0.929274033085951360, +-0.929255562370268520, -0.929237089331446780, -0.929218613969532200, -0.929200136284571210, -0.929181656276609870, -0.929163173945694250, -0.929144689291870880, -0.929126202315185610, +-0.929107713015684960, -0.929089221393414990, -0.929070727448422010, -0.929052231180752090, -0.929033732590451630, -0.929015231677566940, -0.928996728442144090, -0.928978222884229380, +-0.928959715003869200, -0.928941204801109750, -0.928922692275997220, -0.928904177428578000, -0.928885660258898290, -0.928867140767004500, -0.928848618952942790, -0.928830094816759600, +-0.928811568358501090, -0.928793039578213690, -0.928774508475943670, -0.928755975051737460, -0.928737439305641230, -0.928718901237701510, -0.928700360847964480, -0.928681818136476540, +-0.928663273103284000, -0.928644725748433260, -0.928626176071970840, -0.928607624073942930, -0.928589069754395920, -0.928570513113376240, -0.928551954150930390, -0.928533392867104460, +-0.928514829261945170, -0.928496263335498840, -0.928477695087811860, -0.928459124518930530, -0.928440551628901490, -0.928421976417770910, -0.928403398885585540, -0.928384819032391670, +-0.928366236858235720, -0.928347652363164190, -0.928329065547223500, -0.928310476410460160, -0.928291884952920590, -0.928273291174651400, -0.928254695075698910, -0.928236096656109730, +-0.928217495915930280, -0.928198892855207070, -0.928180287473986620, -0.928161679772315560, -0.928143069750240190, -0.928124457407807250, -0.928105842745063030, -0.928087225762054380, +-0.928068606458827490, -0.928049984835429220, -0.928031360891905850, -0.928012734628304250, -0.927994106044670590, -0.927975475141051830, -0.927956841917494390, -0.927938206374044780, +-0.927919568510749640, -0.927900928327655580, -0.927882285824809250, -0.927863641002257160, -0.927844993860046040, -0.927826344398222420, -0.927807692616832940, -0.927789038515924090, +-0.927770382095542860, -0.927751723355735520, -0.927733062296548950, -0.927714398918029650, -0.927695733220224470, -0.927677065203179830, -0.927658394866942680, -0.927639722211559440, +-0.927621047237076950, -0.927602369943541730, -0.927583690331000630, -0.927565008399500290, -0.927546324149087440, -0.927527637579808830, -0.927508948691711080, -0.927490257484841040, +-0.927471563959245240, -0.927452868114970630, -0.927434169952063850, -0.927415469470571630, -0.927396766670540610, -0.927378061552017850, -0.927359354115049880, -0.927340644359683550, +-0.927321932285965490, -0.927303217893942770, -0.927284501183661790, -0.927265782155169750, -0.927247060808513160, -0.927228337143738980, -0.927209611160893840, -0.927190882860024820, +-0.927172152241178550, -0.927153419304401760, -0.927134684049741640, -0.927115946477244600, -0.927097206586957930, -0.927078464378928050, -0.927059719853202120, -0.927040973009826800, +-0.927022223848849140, -0.927003472370315880, -0.926984718574273890, -0.926965962460770120, -0.926947204029851530, -0.926928443281564870, -0.926909680215957100, -0.926890914833075170, +-0.926872147132965950, -0.926853377115676280, -0.926834604781253240, -0.926815830129743670, -0.926797053161194540, -0.926778273875652700, -0.926759492273165230, -0.926740708353779090, +-0.926721922117541120, -0.926703133564498400, -0.926684342694697680, -0.926665549508186360, -0.926646754005010950, -0.926627956185218760, -0.926609156048856630, -0.926590353595971640, +-0.926571548826610750, -0.926552741740821030, -0.926533932338649450, -0.926515120620143070, -0.926496306585348760, -0.926477490234313810, -0.926458671567085060, -0.926439850583709700, +-0.926421027284234590, -0.926402201668707010, -0.926383373737173940, -0.926364543489682330, -0.926345710926279490, -0.926326876047012250, -0.926308038851927920, -0.926289199341073450, +-0.926270357514496050, -0.926251513372242650, -0.926232666914360570, -0.926213818140896760, -0.926194967051898410, -0.926176113647412700, -0.926157257927486600, -0.926138399892167400, +-0.926119539541502280, -0.926100676875538210, -0.926081811894322480, -0.926062944597902280, -0.926044074986324680, -0.926025203059636760, -0.926006328817885920, -0.925987452261119340, +-0.925968573389384100, -0.925949692202727380, -0.925930808701196480, -0.925911922884838590, -0.925893034753700770, -0.925874144307830440, -0.925855251547274770, -0.925836356472080960, +-0.925817459082296180, -0.925798559377967840, -0.925779657359143030, -0.925760753025869130, -0.925741846378193340, -0.925722937416162960, -0.925704026139825160, -0.925685112549227470, +-0.925666196644416850, -0.925647278425440700, -0.925628357892346430, -0.925609435045181230, -0.925590509883992500, -0.925571582408827420, -0.925552652619733520, -0.925533720516757860, +-0.925514786099947970, -0.925495849369351030, -0.925476910325014560, -0.925457968966985730, -0.925439025295312080, -0.925420079310040780, -0.925401131011219350, -0.925382180398894970, +-0.925363227473115280, -0.925344272233927460, -0.925325314681379020, -0.925306354815517150, -0.925287392636389480, -0.925268428144043310, -0.925249461338526040, -0.925230492219885290, +-0.925211520788168150, -0.925192547043422240, -0.925173570985694970, -0.925154592615033740, -0.925135611931486080, -0.925116628935099380, -0.925097643625921060, -0.925078656003998740, +-0.925059666069379730, -0.925040673822111530, -0.925021679262241660, -0.925002682389817530, -0.924983683204886780, -0.924964681707496790, -0.924945677897695110, -0.924926671775529230, +-0.924907663341046680, -0.924888652594294870, -0.924869639535321530, -0.924850624164174070, -0.924831606480900130, -0.924812586485547090, -0.924793564178162610, -0.924774539558794180, +-0.924755512627489450, -0.924736483384295930, -0.924717451829261240, -0.924698417962432790, -0.924679381783858450, -0.924660343293585480, -0.924641302491661770, -0.924622259378134800, +-0.924603213953052230, -0.924584166216461560, -0.924565116168410530, -0.924546063808946550, -0.924527009138117580, -0.924507952155971040, -0.924488892862554530, -0.924469831257915930, +-0.924450767342102630, -0.924431701115162490, -0.924412632577143010, -0.924393561728092060, -0.924374488568057150, -0.924355413097086130, -0.924336335315226410, -0.924317255222525950, +-0.924298172819032260, -0.924279088104793310, -0.924260001079856510, -0.924240911744269810, -0.924221820098080630, -0.924202726141337140, -0.924183629874086640, -0.924164531296377210, +-0.924145430408256360, -0.924126327209771950, -0.924107221700971700, -0.924088113881903370, -0.924069003752614910, -0.924049891313153850, -0.924030776563568020, -0.924011659503905290, +-0.923992540134213500, -0.923973418454540170, -0.923954294464933490, -0.923935168165440860, -0.923916039556110570, -0.923896908636989920, -0.923877775408127210, -0.923858639869569950, +-0.923839502021366110, -0.923820361863563530, -0.923801219396210070, -0.923782074619353470, -0.923762927533041790, -0.923743778137322670, -0.923724626432244180, -0.923705472417854170, +-0.923686316094200380, -0.923667157461330880, -0.923647996519293410, -0.923628833268136050, -0.923609667707906530, -0.923590499838652930, -0.923571329660422990, -0.923552157173264780, +-0.923532982377226030, -0.923513805272355050, -0.923494625858699350, -0.923475444136307330, -0.923456260105226520, -0.923437073765505100, -0.923417885117190920, -0.923398694160332160, +-0.923379500894976560, -0.923360305321172300, -0.923341107438967250, -0.923321907248409350, -0.923302704749546790, -0.923283499942427310, -0.923264292827099320, -0.923245083403610440, +-0.923225871672008870, -0.923206657632342660, -0.923187441284659790, -0.923168222629008330, -0.923149001665436340, -0.923129778393991680, -0.923110552814722760, -0.923091324927677430, +-0.923072094732903750, -0.923052862230449800, -0.923033627420363770, -0.923014390302693610, -0.922995150877487510, -0.922975909144793550, -0.922956665104659680, -0.922937418757134310, +-0.922918170102265290, -0.922898919140100920, -0.922879665870689260, -0.922860410294078390, -0.922841152410316500, -0.922821892219451770, -0.922802629721532260, -0.922783364916606170, +-0.922764097804721680, -0.922744828385926970, -0.922725556660270230, -0.922706282627799520, -0.922687006288563150, -0.922667727642609290, -0.922648446689986020, -0.922629163430741750, +-0.922609877864924430, -0.922590589992582480, -0.922571299813764070, -0.922552007328517390, -0.922532712536890730, -0.922513415438932170, -0.922494116034690230, -0.922474814324212970, +-0.922455510307548690, -0.922436203984745460, -0.922416895355851920, -0.922397584420916020, -0.922378271179986280, -0.922358955633110770, -0.922339637780337900, -0.922320317621715960, +-0.922300995157293250, -0.922281670387117950, -0.922262343311238570, -0.922243013929703200, -0.922223682242560460, -0.922204348249858310, -0.922185011951645370, -0.922165673347970060, +-0.922146332438880450, -0.922126989224425040, -0.922107643704652040, -0.922088295879610050, -0.922068945749347280, -0.922049593313912230, -0.922030238573353090, -0.922010881527718370, +-0.921991522177056490, -0.921972160521415840, -0.921952796560844610, -0.921933430295391540, -0.921914061725104820, -0.921894690850033060, -0.921875317670224460, -0.921855942185727750, +-0.921836564396590900, -0.921817184302862860, -0.921797801904591820, -0.921778417201826180, -0.921759030194614580, -0.921739640883005310, -0.921720249267047100, -0.921700855346788140, +-0.921681459122277060, -0.921662060593562370, -0.921642659760692480, -0.921623256623716030, -0.921603851182681400, -0.921584443437637010, -0.921565033388631720, -0.921545621035713690, +-0.921526206378931790, -0.921506789418334190, -0.921487370153969750, -0.921467948585886760, -0.921448524714133970, -0.921429098538759870, -0.921409670059813000, -0.921390239277341980, +-0.921370806191395220, -0.921351370802021670, -0.921331933109269530, -0.921312493113187640, -0.921293050813824510, -0.921273606211228780, -0.921254159305448960, -0.921234710096533790, +-0.921215258584531790, -0.921195804769491810, -0.921176348651462140, -0.921156890230491740, -0.921137429506628910, -0.921117966479922720, -0.921098501150421470, -0.921079033518174110, +-0.921059563583229050, -0.921040091345635140, -0.921020616805440890, -0.921001139962695170, -0.920981660817446590, -0.920962179369743890, -0.920942695619635820, -0.920923209567170890, +-0.920903721212397940, -0.920884230555365720, -0.920864737596122970, -0.920845242334718210, -0.920825744771200600, -0.920806244905618350, -0.920786742738020750, -0.920767238268456080, +-0.920747731496973530, -0.920728222423621400, -0.920708711048448980, -0.920689197371504560, -0.920669681392837220, -0.920650163112495700, -0.920630642530528840, -0.920611119646985280, +-0.920591594461913850, -0.920572066975363530, -0.920552537187383060, -0.920533005098021270, -0.920513470707326810, -0.920493934015348850, -0.920474395022136020, -0.920454853727737170, +-0.920435310132201150, -0.920415764235576920, -0.920396216037913220, -0.920376665539259120, -0.920357112739663140, -0.920337557639174570, -0.920318000237841940, -0.920298440535714520, +-0.920278878532840850, -0.920259314229269990, -0.920239747625050790, -0.920220178720232320, -0.920200607514863430, -0.920181034008992870, -0.920161458202669920, -0.920141880095943220, +-0.920122299688861830, -0.920102716981474720, -0.920083131973830740, -0.920063544665978950, -0.920043955057968430, -0.920024363149847810, -0.920004768941666500, -0.919985172433473110, +-0.919965573625316950, -0.919945972517246640, -0.919926369109311580, -0.919906763401560520, -0.919887155394042530, -0.919867545086806680, -0.919847932479902040, -0.919828317573377460, +-0.919808700367282020, -0.919789080861665000, -0.919769459056575140, -0.919749834952061750, -0.919730208548173780, -0.919710579844960300, -0.919690948842470160, -0.919671315540752880, +-0.919651679939857190, -0.919632042039832400, -0.919612401840727340, -0.919592759342591440, -0.919573114545473520, -0.919553467449423010, -0.919533818054488640, -0.919514166360719810, +-0.919494512368165480, -0.919474856076874960, -0.919455197486897300, -0.919435536598281590, -0.919415873411077110, -0.919396207925332830, -0.919376540141098150, -0.919356870058422040, +-0.919337197677353780, -0.919317522997942560, -0.919297846020237560, -0.919278166744287750, -0.919258485170142750, -0.919238801297851400, -0.919219115127463130, -0.919199426659027100, +-0.919179735892592390, -0.919160042828208400, -0.919140347465924320, -0.919120649805789340, -0.919100949847852840, -0.919081247592163810, -0.919061543038771740, -0.919041836187725720, +-0.919022127039075150, -0.919002415592869440, -0.918982701849157420, -0.918962985807988850, -0.918943267469412680, -0.918923546833478540, -0.918903823900235280, -0.918884098669732640, +-0.918864371142019690, -0.918844641317145830, -0.918824909195160360, -0.918805174776112680, -0.918785438060051860, -0.918765699047027650, -0.918745957737089110, -0.918726214130285770, +-0.918706468226666790, -0.918686720026281600, -0.918666969529179700, -0.918647216735410390, -0.918627461645022960, -0.918607704258066930, -0.918587944574591590, -0.918568182594646450, +-0.918548418318280820, -0.918528651745544100, -0.918508882876485910, -0.918489111711155330, -0.918469338249602090, -0.918449562491875480, -0.918429784438024920, -0.918410004088099920, +-0.918390221442149990, -0.918370436500224430, -0.918350649262372750, -0.918330859728644480, -0.918311067899089120, -0.918291273773755970, -0.918271477352694760, -0.918251678635954690, +-0.918231877623585490, -0.918212074315636780, -0.918192268712157640, -0.918172460813198030, -0.918152650618807130, -0.918132838129034680, -0.918113023343930080, -0.918093206263542960, +-0.918073386887922730, -0.918053565217119120, -0.918033741251181650, -0.918013914990159720, -0.917994086434103070, -0.917974255583061230, -0.917954422437083580, -0.917934586996220100, +-0.917914749260519970, -0.917894909230033140, -0.917875066904808910, -0.917855222284897020, -0.917835375370347100, -0.917815526161208760, -0.917795674657531650, -0.917775820859365150, +-0.917755964766759360, -0.917736106379763440, -0.917716245698427470, -0.917696382722800740, -0.917676517452933100, -0.917656649888874080, -0.917636780030673620, -0.917616907878381020, +-0.917597033432046240, -0.917577156691718800, -0.917557277657448660, -0.917537396329285100, -0.917517512707278220, -0.917497626791477510, -0.917477738581932710, -0.917457848078693460, +-0.917437955281809710, -0.917418060191331100, -0.917398162807307240, -0.917378263129788100, -0.917358361158823190, -0.917338456894462470, -0.917318550336755580, -0.917298641485752240, +-0.917278730341502310, -0.917258816904055640, -0.917238901173461850, -0.917218983149770910, -0.917199062833032430, -0.917179140223296390, -0.917159215320612290, -0.917139288125030430, +-0.917119358636600100, -0.917099426855371490, -0.917079492781394330, -0.917059556414718370, -0.917039617755393550, -0.917019676803469630, -0.916999733558996670, -0.916979788022024290, +-0.916959840192602460, -0.916939890070780920, -0.916919937656609840, -0.916899982950138750, -0.916880025951417820, -0.916860066660496690, -0.916840105077425530, -0.916820141202254080, +-0.916800175035032310, -0.916780206575809940, -0.916760235824637280, -0.916740262781563840, -0.916720287446639910, -0.916700309819915130, -0.916680329901439660, -0.916660347691263260, +-0.916640363189436090, -0.916620376396007910, -0.916600387311028890, -0.916580395934548870, -0.916560402266617840, -0.916540406307285840, -0.916520408056602730, -0.916500407514618700, +-0.916480404681383700, -0.916460399556947580, -0.916440392141360530, -0.916420382434672500, -0.916400370436933450, -0.916380356148193580, -0.916360339568502600, -0.916340320697911050, +-0.916320299536468540, -0.916300276084225370, -0.916280250341231390, -0.916260222307536900, -0.916240191983191730, -0.916220159368246080, -0.916200124462750120, -0.916180087266753820, +-0.916160047780307350, -0.916140006003460680, -0.916119961936264100, -0.916099915578767580, -0.916079866931021280, -0.916059815993075180, -0.916039762764979670, -0.916019707246784720, +-0.915999649438540620, -0.915979589340297220, -0.915959526952104920, -0.915939462274013790, -0.915919395306074020, -0.915899326048335680, -0.915879254500849170, -0.915859180663664450, +-0.915839104536831820, -0.915819026120401340, -0.915798945414423300, -0.915778862418948010, -0.915758777134025430, -0.915738689559706050, -0.915718599696039750, -0.915698507543077130, +-0.915678413100868170, -0.915658316369463270, -0.915638217348912490, -0.915618116039266130, -0.915598012440574480, -0.915577906552887950, -0.915557798376256500, -0.915537687910730650, +-0.915517575156360450, -0.915497460113196440, -0.915477342781288780, -0.915457223160687780, -0.915437101251443620, -0.915416977053606700, -0.915396850567227420, -0.915376721792355960, +-0.915356590729042740, -0.915336457377337930, -0.915316321737292160, -0.915296183808955500, -0.915276043592378350, -0.915255901087611120, -0.915235756294704220, -0.915215609213707810, +-0.915195459844672430, -0.915175308187648360, -0.915155154242686120, -0.915134998009835780, -0.915114839489148180, -0.915094678680673400, -0.915074515584461960, -0.915054350200564140, +-0.915034182529030460, -0.915014012569911330, -0.914993840323257150, -0.914973665789118430, -0.914953488967545470, -0.914933309858588890, -0.914913128462299000, -0.914892944778726290, +-0.914872758807921180, -0.914852570549934300, -0.914832380004815810, -0.914812187172616590, -0.914791992053386680, -0.914771794647176950, -0.914751594954037570, -0.914731392974019400, +-0.914711188707172610, -0.914690982153547940, -0.914670773313195680, -0.914650562186166580, -0.914630348772511040, -0.914610133072279560, -0.914589915085522900, -0.914569694812291330, +-0.914549472252635720, -0.914529247406606240, -0.914509020274253740, -0.914488790855628620, -0.914468559150781510, -0.914448325159763040, -0.914428088882623840, -0.914407850319414290, +-0.914387609470185160, -0.914367366334986940, -0.914347120913870490, -0.914326873206886100, -0.914306623214084510, -0.914286370935516350, -0.914266116371232450, -0.914245859521283010, +-0.914225600385719090, -0.914205338964591110, -0.914185075257949680, -0.914164809265845760, -0.914144540988329650, -0.914124270425452300, -0.914103997577264240, -0.914083722443816190, +-0.914063445025158790, -0.914043165321342890, -0.914022883332418990, -0.914002599058437950, -0.913982312499450280, -0.913962023655507050, -0.913941732526658560, -0.913921439112955870, +-0.913901143414449390, -0.913880845431190300, -0.913860545163228900, -0.913840242610616250, -0.913819937773402870, -0.913799630651639830, -0.913779321245377530, -0.913759009554666930, +-0.913738695579559000, -0.913718379320104130, -0.913698060776353520, -0.913677739948357550, -0.913657416836167410, -0.913637091439833520, -0.913616763759407150, -0.913596433794938710, +-0.913576101546479170, -0.913555767014079480, -0.913535430197790270, -0.913515091097662490, -0.913494749713747110, -0.913474406046094760, -0.913454060094756380, -0.913433711859782840, +-0.913413361341225190, -0.913393008539133970, -0.913372653453560220, -0.913352296084554930, -0.913331936432168810, -0.913311574496452840, -0.913291210277457970, -0.913270843775235150, +-0.913250474989835140, -0.913230103921308990, -0.913209730569707560, -0.913189354935081800, -0.913168977017482560, -0.913148596816961030, -0.913128214333567940, -0.913107829567354370, +-0.913087442518371150, -0.913067053186669360, -0.913046661572299970, -0.913026267675313920, -0.913005871495762070, -0.912985473033695700, -0.912965072289165570, -0.912944669262222730, +-0.912924263952918260, -0.912903856361303110, -0.912883446487428360, -0.912863034331344970, -0.912842619893104110, -0.912822203172756530, -0.912801784170353510, -0.912781362885946020, +-0.912760939319585130, -0.912740513471321900, -0.912720085341207410, -0.912699654929292610, -0.912679222235628810, -0.912658787260266830, -0.912638350003257990, -0.912617910464653240, +-0.912597468644503750, -0.912577024542860490, -0.912556578159774650, -0.912536129495297500, -0.912515678549479900, -0.912495225322373150, -0.912474769814028310, -0.912454312024496670, +-0.912433851953829090, -0.912413389602077070, -0.912392924969291360, -0.912372458055523470, -0.912351988860824360, -0.912331517385245430, -0.912311043628837530, -0.912290567591652170, +-0.912270089273740200, -0.912249608675153260, -0.912229125795942060, -0.912208640636158250, -0.912188153195852670, -0.912167663475076830, -0.912147171473881690, -0.912126677192318660, +-0.912106180630439020, -0.912085681788293860, -0.912065180665934560, -0.912044677263412320, -0.912024171580778310, -0.912003663618083940, -0.911983153375380380, -0.911962640852718830, +-0.911942126050150900, -0.911921608967727450, -0.911901089605500090, -0.911880567963520020, -0.911860044041838510, -0.911839517840506870, -0.911818989359576390, -0.911798458599098470, +-0.911777925559124510, -0.911757390239705590, -0.911736852640893210, -0.911716312762738790, -0.911695770605293500, -0.911675226168608850, -0.911654679452736040, -0.911634130457726680, +-0.911613579183631840, -0.911593025630503150, -0.911572469798391900, -0.911551911687349500, -0.911531351297427240, -0.911510788628676630, -0.911490223681149070, -0.911469656454895970, +-0.911449086949968620, -0.911428515166418650, -0.911407941104297350, -0.911387364763656230, -0.911366786144546690, -0.911346205247020260, -0.911325622071128110, -0.911305036616921970, +-0.911284448884453370, -0.911263858873773590, -0.911243266584934150, -0.911222672017986570, -0.911202075172982240, -0.911181476049972790, -0.911160874649009630, -0.911140270970144270, +-0.911119665013428340, -0.911099056778913010, -0.911078446266650240, -0.911057833476691340, -0.911037218409087800, -0.911016601063891260, -0.910995981441153240, -0.910975359540925120, +-0.910954735363258770, -0.910934108908205480, -0.910913480175816970, -0.910892849166144660, -0.910872215879240280, -0.910851580315155450, -0.910830942473941470, -0.910810302355650410, +-0.910789659960333340, -0.910769015288042330, -0.910748368338828660, -0.910727719112744080, -0.910707067609840220, -0.910686413830168680, -0.910665757773781110, -0.910645099440729240, +-0.910624438831064480, -0.910603775944838660, -0.910583110782103410, -0.910562443342910480, -0.910541773627311260, -0.910521101635357710, -0.910500427367101350, -0.910479750822593910, +-0.910459072001887250, -0.910438390905032760, -0.910417707532082400, -0.910397021883087690, -0.910376333958100470, -0.910355643757172370, -0.910334951280355240, -0.910314256527700590, +-0.910293559499260500, -0.910272860195086350, -0.910252158615230120, -0.910231454759743430, -0.910210748628678230, -0.910190040222086050, -0.910169329540018830, -0.910148616582528210, +-0.910127901349666150, -0.910107183841484260, -0.910086464058034390, -0.910065741999368400, -0.910045017665538030, -0.910024291056595210, -0.910003562172591480, -0.909982831013579020, +-0.909962097579609440, -0.909941361870734600, -0.909920623887006340, -0.909899883628476620, -0.909879141095197070, -0.909858396287219760, -0.909837649204596310, -0.909816899847378900, +-0.909796148215619160, -0.909775394309369050, -0.909754638128680520, -0.909733879673605310, -0.909713118944195380, -0.909692355940502790, -0.909671590662579190, -0.909650823110476630, +-0.909630053284247060, -0.909609281183942240, -0.909588506809614450, -0.909567730161315200, -0.909546951239096680, -0.909526170043010730, -0.909505386573109530, -0.909484600829444600, +-0.909463812812068450, -0.909443022521032480, -0.909422229956389220, -0.909401435118190270, -0.909380638006487720, -0.909359838621333520, -0.909339036962779850, -0.909318233030878440, +-0.909297426825681600, -0.909276618347241270, -0.909255807595609090, -0.909234994570837560, -0.909214179272978650, -0.909193361702083980, -0.909172541858206170, -0.909151719741396970, +-0.909130895351708550, -0.909110068689192640, -0.909089239753901770, -0.909068408545887770, -0.909047575065202730, -0.909026739311898590, -0.909005901286027870, -0.908985060987642310, +-0.908964218416794090, -0.908943373573535160, -0.908922526457918050, -0.908901677069994470, -0.908880825409816850, -0.908859971477436910, -0.908839115272907170, -0.908818256796279810, +-0.908797396047606450, -0.908776533026939840, -0.908755667734331920, -0.908734800169834880, -0.908713930333500560, -0.908693058225381710, -0.908672183845530060, -0.908651307193998110, +-0.908630428270837620, -0.908609547076101200, -0.908588663609841030, -0.908567777872109070, -0.908546889862957620, -0.908525999582439070, -0.908505107030605500, -0.908484212207509190, +-0.908463315113202110, -0.908442415747736990, -0.908421514111165780, -0.908400610203540900, -0.908379704024914190, -0.908358795575338500, -0.908337884854865770, -0.908316971863548090, +-0.908296056601438200, -0.908275139068588140, -0.908254219265050340, -0.908233297190876750, -0.908212372846120110, -0.908191446230832480, -0.908170517345066260, -0.908149586188873650, +-0.908128652762307140, -0.908107717065419040, -0.908086779098261740, -0.908065838860887210, -0.908044896353348290, -0.908023951575697040, -0.908003004527985990, -0.907982055210267310, +-0.907961103622593630, -0.907940149765017130, -0.907919193637590110, -0.907898235240365390, -0.907877274573394950, -0.907856311636731310, -0.907835346430426850, -0.907814378954534100, +-0.907793409209105450, -0.907772437194193200, -0.907751462909849760, -0.907730486356127740, -0.907709507533079660, -0.907688526440757700, -0.907667543079214270, -0.907646557448502200, +-0.907625569548673680, -0.907604579379781230, -0.907583586941877240, -0.907562592235014340, -0.907541595259245050, -0.907520596014621540, -0.907499594501196770, -0.907478590719023040, +-0.907457584668152740, -0.907436576348638390, -0.907415565760532730, -0.907394552903888150, -0.907373537778757180, -0.907352520385192210, -0.907331500723246090, -0.907310478792971220, +-0.907289454594420230, -0.907268428127645300, -0.907247399392699600, -0.907226368389635330, -0.907205335118505210, -0.907184299579361530, -0.907163261772257260, -0.907142221697244790, +-0.907121179354376640, -0.907100134743705770, -0.907079087865284570, -0.907058038719165570, -0.907036987305401280, -0.907015933624044760, -0.906994877675148410, -0.906973819458764870, +-0.906952758974946540, -0.906931696223746590, -0.906910631205217310, -0.906889563919411560, -0.906868494366381620, -0.906847422546180670, -0.906826348458861120, -0.906805272104475700, +-0.906784193483077040, -0.906763112594717980, -0.906742029439451150, -0.906720944017329170, -0.906699856328404770, -0.906678766372730820, -0.906657674150360030, -0.906636579661344810, +-0.906615482905738350, -0.906594383883593260, -0.906573282594962060, -0.906552179039897600, -0.906531073218452830, -0.906509965130680270, -0.906488854776632990, -0.906467742156363280, +-0.906446627269924420, -0.906425510117368940, -0.906404390698749780, -0.906383269014119360, -0.906362145063531080, -0.906341018847037330, -0.906319890364691070, -0.906298759616544940, +-0.906277626602651990, -0.906256491323065070, -0.906235353777836710, -0.906214213967020180, -0.906193071890668000, -0.906171927548833240, -0.906150780941568530, -0.906129632068926940, +-0.906108480930961300, -0.906087327527724470, -0.906066171859269190, -0.906045013925648620, -0.906023853726915410, -0.906002691263122720, -0.905981526534323070, -0.905960359540569750, +-0.905939190281915610, -0.905918018758413380, -0.905896844970116020, -0.905875668917076720, -0.905854490599348190, -0.905833310016983310, -0.905812127170035340, -0.905790942058557040, +-0.905769754682601350, -0.905748565042221120, -0.905727373137469650, -0.905706178968399780, -0.905684982535064460, -0.905663783837516450, -0.905642582875809230, -0.905621379649995450, +-0.905600174160128280, -0.905578966406260570, -0.905557756388445490, -0.905536544106736120, -0.905515329561185300, -0.905494112751846100, -0.905472893678771710, -0.905451672342015070, +-0.905430448741629370, -0.905409222877667230, -0.905387994750182280, -0.905366764359227360, -0.905345531704855320, -0.905324296787119560, -0.905303059606073160, -0.905281820161769060, +-0.905260578454260220, -0.905239334483600170, -0.905218088249841850, -0.905196839753038220, -0.905175588993242240, -0.905154335970507540, -0.905133080684887070, -0.905111823136433790, +-0.905090563325200770, -0.905069301251241630, -0.905048036914609110, -0.905026770315356610, -0.905005501453536980, -0.904984230329203720, -0.904962956942409910, -0.904941681293208510, +-0.904920403381653140, -0.904899123207796750, -0.904877840771692530, -0.904856556073393550, -0.904835269112953310, -0.904813979890424890, -0.904792688405861580, -0.904771394659316330, +-0.904750098650842880, -0.904728800380494080, -0.904707499848323330, -0.904686197054383580, -0.904664891998728570, -0.904643584681411260, -0.904622275102485050, -0.904600963262003010, +-0.904579649160018650, -0.904558332796585260, -0.904537014171755800, -0.904515693285584010, -0.904494370138123060, -0.904473044729426020, -0.904451717059546300, -0.904430387128537410, +-0.904409054936452630, -0.904387720483345150, -0.904366383769268260, -0.904345044794275470, -0.904323703558420180, -0.904302360061755570, -0.904281014304334940, -0.904259666286211910, +-0.904238316007439650, -0.904216963468071680, -0.904195608668161180, -0.904174251607761770, -0.904152892286926750, -0.904131530705709290, -0.904110166864163120, -0.904088800762341660, +-0.904067432400298080, -0.904046061778085890, -0.904024688895758600, -0.904003313753369620, -0.903981936350972350, -0.903960556688620080, -0.903939174766366650, -0.903917790584265250, +-0.903896404142369270, -0.903875015440732230, -0.903853624479407760, -0.903832231258449250, -0.903810835777910220, -0.903789438037843840, -0.903768038038304080, -0.903746635779344220, +-0.903725231261017780, -0.903703824483378050, -0.903682415446478980, -0.903661004150373870, -0.903639590595116000, -0.903618174780759340, -0.903596756707357280, -0.903575336374963340, +-0.903553913783630920, -0.903532488933413870, -0.903511061824365580, -0.903489632456539680, -0.903468200829989470, -0.903446766944768890, -0.903425330800931460, -0.903403892398530690, +-0.903382451737620000, -0.903361008818253430, -0.903339563640484290, -0.903318116204366190, -0.903296666509952660, -0.903275214557297650, -0.903253760346454550, -0.903232303877476990, +-0.903210845150418720, -0.903189384165333450, -0.903167920922274710, -0.903146455421295900, -0.903124987662451200, -0.903103517645794000, -0.903082045371378040, -0.903060570839256730, +-0.903039094049484240, -0.903017615002113970, -0.902996133697199670, -0.902974650134794830, -0.902953164314953540, -0.902931676237729410, -0.902910185903176070, -0.902888693311347020, +-0.902867198462296460, -0.902845701356078000, -0.902824201992744930, -0.902802700372351660, -0.902781196494951590, -0.902759690360598550, -0.902738181969346080, -0.902716671321248440, +-0.902695158416359060, -0.902673643254731760, -0.902652125836420070, -0.902630606161478390, -0.902609084229960220, -0.902587560041919200, -0.902566033597409170, -0.902544504896484300, +-0.902522973939198110, -0.902501440725604450, -0.902479905255757050, -0.902458367529710090, -0.902436827547517200, -0.902415285309232210, -0.902393740814908860, -0.902372194064601230, +-0.902350645058363270, -0.902329093796248370, -0.902307540278311060, -0.902285984504604840, -0.902264426475183680, -0.902242866190101190, -0.902221303649411780, -0.902199738853169180, +-0.902178171801427120, -0.902156602494239460, -0.902135030931660590, -0.902113457113744020, -0.902091881040543830, -0.902070302712113750, -0.902048722128508170, -0.902027139289780730, +-0.902005554195985490, -0.901983966847176080, -0.901962377243407000, -0.901940785384731990, -0.901919191271204790, -0.901897594902879800, -0.901875996279810850, -0.901854395402051920, +-0.901832792269656850, -0.901811186882679920, -0.901789579241175090, -0.901767969345196210, -0.901746357194797230, -0.901724742790032670, -0.901703126130956160, -0.901681507217621860, +-0.901659886050083630, -0.901638262628395750, -0.901616636952612290, -0.901595009022787330, -0.901573378838974480, -0.901551746401228480, -0.901530111709603180, -0.901508474764152300, +-0.901486835564930480, -0.901465194111991550, -0.901443550405389590, -0.901421904445178670, -0.901400256231413070, -0.901378605764146860, -0.901356953043434220, -0.901335298069328880, +-0.901313640841885590, -0.901291981361158180, -0.901270319627200720, -0.901248655640067400, -0.901226989399812610, -0.901205320906490300, -0.901183650160154670, -0.901161977160859770, +-0.901140301908660120, -0.901118624403609680, -0.901096944645762510, -0.901075262635173120, -0.901053578371895700, -0.901031891855984200, -0.901010203087492910, -0.900988512066476120, +-0.900966818792988230, -0.900945123267083200, -0.900923425488815210, -0.900901725458238770, -0.900880023175408160, -0.900858318640377350, -0.900836611853200630, -0.900814902813932620, +-0.900793191522627270, -0.900771477979338990, -0.900749762184121730, -0.900728044137030340, -0.900706323838118880, -0.900684601287441540, -0.900662876485052500, -0.900641149431006480, +-0.900619420125357560, -0.900597688568159920, -0.900575954759468280, -0.900554218699336720, -0.900532480387819630, -0.900510739824971100, -0.900488997010845950, -0.900467251945498370, +-0.900445504628982650, -0.900423755061352860, -0.900402003242663950, -0.900380249172969990, -0.900358492852325500, -0.900336734280784530, -0.900314973458401950, -0.900293210385231910, +-0.900271445061328830, -0.900249677486746890, -0.900227907661541040, -0.900206135585765450, -0.900184361259474210, -0.900162584682722370, -0.900140805855564000, -0.900119024778053610, +-0.900097241450245500, -0.900075455872194510, -0.900053668043954810, -0.900031877965581040, -0.900010085637127260, -0.899988291058648530, -0.899966494230199030, -0.899944695151833400, +-0.899922893823605690, -0.899901090245571080, -0.899879284417783640, -0.899857476340298000, -0.899835666013168560, -0.899813853436450040, -0.899792038610196960, -0.899770221534463620, +-0.899748402209304850, -0.899726580634775060, -0.899704756810928870, -0.899682930737820570, -0.899661102415505120, -0.899639271844037030, -0.899617439023470580, -0.899595603953860510, +-0.899573766635261450, -0.899551927067728130, -0.899530085251314950, -0.899508241186076310, -0.899486394872067270, -0.899464546309342360, -0.899442695497955970, -0.899420842437962610, +-0.899398987129417460, -0.899377129572374810, -0.899355269766889290, -0.899333407713015400, -0.899311543410808210, -0.899289676860322130, -0.899267808061611660, -0.899245937014731990, +-0.899224063719737400, -0.899202188176682630, -0.899180310385622180, -0.899158430346611140, -0.899136548059704110, -0.899114663524955620, -0.899092776742420270, -0.899070887712153270, +-0.899048996434208990, -0.899027102908642180, -0.899005207135507470, -0.898983309114860020, -0.898961408846754130, -0.898939506331244860, -0.898917601568386520, -0.898895694558234480, +-0.898873785300843050, -0.898851873796267080, -0.898829960044561620, -0.898808044045781300, -0.898786125799980740, -0.898764205307214790, -0.898742282567538410, -0.898720357581006430, +-0.898698430347673490, -0.898676500867594320, -0.898654569140824090, -0.898632635167417430, -0.898610698947429180, -0.898588760480913960, -0.898566819767927070, -0.898544876808523130, +-0.898522931602756980, -0.898500984150683250, -0.898479034452357330, -0.898457082507833850, -0.898435128317167430, -0.898413171880413360, -0.898391213197626380, -0.898369252268861440, +-0.898347289094173050, -0.898325323673616730, -0.898303356007247090, -0.898281386095118980, -0.898259413937287250, -0.898237439533807190, -0.898215462884733530, -0.898193483990121220, +-0.898171502850025010, -0.898149519464500280, -0.898127533833601670, -0.898105545957384340, -0.898083555835902820, -0.898061563469212620, -0.898039568857368580, -0.898017572000425420, +-0.897995572898438450, -0.897973571551462620, -0.897951567959552890, -0.897929562122763980, -0.897907554041151300, -0.897885543714769810, -0.897863531143674450, -0.897841516327920090, +-0.897819499267562100, -0.897797479962655460, -0.897775458413255010, -0.897753434619415810, -0.897731408581193160, -0.897709380298642000, -0.897687349771817300, -0.897665317000774120, +-0.897643281985567860, -0.897621244726253380, -0.897599205222885830, -0.897577163475519970, -0.897555119484211520, -0.897533073249015210, -0.897511024769986010, -0.897488974047179420, +-0.897466921080650400, -0.897444865870454130, -0.897422808416645460, -0.897400748719279990, -0.897378686778412590, -0.897356622594098540, -0.897334556166392680, -0.897312487495350640, +-0.897290416581027480, -0.897268343423478170, -0.897246268022757860, -0.897224190378922090, -0.897202110492025810, -0.897180028362124180, -0.897157943989272400, -0.897135857373525860, +-0.897113768514939740, -0.897091677413568990, -0.897069584069469240, -0.897047488482695550, -0.897025390653303110, -0.897003290581347090, -0.896981188266883000, -0.896959083709965800, +-0.896936976910651000, -0.896914867868993660, -0.896892756585049190, -0.896870643058872870, -0.896848527290520000, -0.896826409280045530, -0.896804289027505310, -0.896782166532954280, +-0.896760041796447970, -0.896737914818041220, -0.896715785597789970, -0.896693654135749200, -0.896671520431974180, -0.896649384486520430, -0.896627246299443350, -0.896605105870798000, +-0.896582963200639790, -0.896560818289024450, -0.896538671136006940, -0.896516521741642760, -0.896494370105987090, -0.896472216229095790, -0.896450060111023790, -0.896427901751826740, +-0.896405741151559800, -0.896383578310278590, -0.896361413228038420, -0.896339245904894780, -0.896317076340902850, -0.896294904536118380, -0.896272730490596640, -0.896250554204393150, +-0.896228375677562970, -0.896206194910162070, -0.896184011902245730, -0.896161826653869120, -0.896139639165088210, -0.896117449435958170, -0.896095257466534510, -0.896073063256872530, +-0.896050866807028060, -0.896028668117056390, -0.896006467187013040, -0.895984264016953410, -0.895962058606933230, -0.895939850957008010, -0.895917641067233040, -0.895895428937663830, +-0.895873214568356220, -0.895850997959365620, -0.895828779110747540, -0.895806558022557260, -0.895784334694850860, -0.895762109127683500, -0.895739881321110820, -0.895717651275188540, +-0.895695418989972070, -0.895673184465517140, -0.895650947701879030, -0.895628708699113820, -0.895606467457276790, -0.895584223976423570, -0.895561978256609550, -0.895539730297890910, +-0.895517480100322840, -0.895495227663961060, -0.895472972988861080, -0.895450716075078870, -0.895428456922669810, -0.895406195531689650, -0.895383931902193790, -0.895361666034238280, +-0.895339397927878640, -0.895317127583170280, -0.895294855000169370, -0.895272580178931190, -0.895250303119511700, -0.895228023821966200, -0.895205742286350750, -0.895183458512721080, +-0.895161172501132700, -0.895138884251641230, -0.895116593764302640, -0.895094301039172650, -0.895072006076306880, -0.895049708875760960, -0.895027409437590960, -0.895005107761852380, +-0.894982803848601070, -0.894960497697892540, -0.894938189309782970, -0.894915878684327870, -0.894893565821582970, -0.894871250721604230, -0.894848933384447490, -0.894826613810168370, +-0.894804291998822500, -0.894781967950466160, -0.894759641665154760, -0.894737313142944360, -0.894714982383890470, -0.894692649388049380, -0.894670314155476600, -0.894647976686227970, +-0.894625636980359350, -0.894603295037926790, -0.894580950858985920, -0.894558604443592700, -0.894536255791802850, -0.894513904903672440, -0.894491551779257320, -0.894469196418613330, +-0.894446838821796210, -0.894424478988862130, -0.894402116919866820, -0.894379752614866020, -0.894357386073916130, -0.894335017297072650, -0.894312646284391780, -0.894290273035928900, +-0.894267897551740740, -0.894245519831882720, -0.894223139876410890, -0.894200757685381100, -0.894178373258849520, -0.894155986596872010, -0.894133597699504620, -0.894111206566802990, +-0.894088813198823500, -0.894066417595622000, -0.894044019757254560, -0.894021619683776800, -0.893999217375245130, -0.893976812831715480, -0.893954406053243610, -0.893931997039885800, +-0.893909585791698100, -0.893887172308736490, -0.893864756591056690, -0.893842338638715210, -0.893819918451767890, -0.893797496030270700, -0.893775071374279690, -0.893752644483851060, +-0.893730215359040960, -0.893707783999905250, -0.893685350406499880, -0.893662914578881360, -0.893640476517105540, -0.893618036221228600, -0.893595593691306260, -0.893573148927395140, +-0.893550701929551220, -0.893528252697830320, -0.893505801232288950, -0.893483347532983090, -0.893460891599968890, -0.893438433433302310, -0.893415973033039770, -0.893393510399237310, +-0.893371045531951010, -0.893348578431237050, -0.893326109097151710, -0.893303637529751170, -0.893281163729091500, -0.893258687695228760, -0.893236209428219460, -0.893213728928119680, +-0.893191246194985580, -0.893168761228873120, -0.893146274029838930, -0.893123784597939060, -0.893101292933229820, -0.893078799035767150, -0.893056302905607560, -0.893033804542807340, +-0.893011303947422340, -0.892988801119509290, -0.892966296059124250, -0.892943788766323410, -0.892921279241162940, -0.892898767483699560, -0.892876253493989140, -0.892853737272088170, +-0.892831218818052610, -0.892808698131939190, -0.892786175213803990, -0.892763650063703510, -0.892741122681693590, -0.892718593067831080, -0.892696061222172040, -0.892673527144772880, +-0.892650990835689770, -0.892628452294979220, -0.892605911522697750, -0.892583368518901190, -0.892560823283646390, -0.892538275816989520, -0.892515726118987110, -0.892493174189694980, +-0.892470620029170210, -0.892448063637468980, -0.892425505014647460, -0.892402944160762050, -0.892380381075869480, -0.892357815760025820, -0.892335248213287800, -0.892312678435711380, +-0.892290106427353510, -0.892267532188270260, -0.892244955718518360, -0.892222377018153770, -0.892199796087233430, -0.892177212925813530, -0.892154627533950470, -0.892132039911701090, +-0.892109450059121570, -0.892086857976268410, -0.892064263663197910, -0.892041667119967020, -0.892019068346631920, -0.891996467343249110, -0.891973864109874890, -0.891951258646566330, +-0.891928650953379590, -0.891906041030371190, -0.891883428877597530, -0.891860814495115450, -0.891838197882981350, -0.891815579041251750, -0.891792957969983040, -0.891770334669232060, +-0.891747709139055320, -0.891725081379509120, -0.891702451390650300, -0.891679819172535470, -0.891657184725221040, -0.891634548048763410, -0.891611909143219750, -0.891589268008646130, +-0.891566624645099500, -0.891543979052636050, -0.891521331231312830, -0.891498681181186360, -0.891476028902313030, -0.891453374394749590, -0.891430717658552860, -0.891408058693779260, +-0.891385397500485620, -0.891362734078728240, -0.891340068428564280, -0.891317400550050040, -0.891294730443242370, -0.891272058108197650, -0.891249383544973070, -0.891226706753624920, +-0.891204027734209920, -0.891181346486784930, -0.891158663011406670, -0.891135977308131650, -0.891113289377016500, -0.891090599218118400, -0.891067906831493840, -0.891045212217199340, +-0.891022515375291760, -0.890999816305828030, -0.890977115008864780, -0.890954411484458750, -0.890931705732666450, -0.890908997753545150, -0.890886287547151380, -0.890863575113541860, +-0.890840860452773110, -0.890818143564902520, -0.890795424449986490, -0.890772703108081760, -0.890749979539245400, -0.890727253743534230, -0.890704525721004780, -0.890681795471713890, +-0.890659062995718730, -0.890636328293075820, -0.890613591363842220, -0.890590852208074320, -0.890568110825829540, -0.890545367217164490, -0.890522621382136000, -0.890499873320800830, +-0.890477123033216130, -0.890454370519438540, -0.890431615779525120, -0.890408858813532490, -0.890386099621517820, -0.890363338203537970, -0.890340574559649540, -0.890317808689909840, +-0.890295040594375700, -0.890272270273103960, -0.890249497726151250, -0.890226722953575080, -0.890203945955432060, -0.890181166731779160, -0.890158385282673210, -0.890135601608171510, +-0.890112815708330670, -0.890090027583207990, -0.890067237232859850, -0.890044444657343890, -0.890021649856716830, -0.889998852831035640, -0.889976053580357140, -0.889953252104738750, +-0.889930448404237180, -0.889907642478909410, -0.889884834328812380, -0.889862023954003490, -0.889839211354539580, -0.889816396530477390, -0.889793579481874430, -0.889770760208787540, +-0.889747938711273670, -0.889725114989389780, -0.889702289043193370, -0.889679460872741190, -0.889656630478090400, -0.889633797859297750, -0.889610963016420840, -0.889588125949516530, +-0.889565286658641980, -0.889542445143853940, -0.889519601405209910, -0.889496755442766960, -0.889473907256582150, -0.889451056846712330, -0.889428204213215110, -0.889405349356147350, +-0.889382492275565980, -0.889359632971528650, -0.889336771444092180, -0.889313907693313870, -0.889291041719250550, -0.889268173521959750, -0.889245303101498630, -0.889222430457924150, +-0.889199555591293490, -0.889176678501664040, -0.889153799189092990, -0.889130917653637390, -0.889108033895354310, -0.889085147914301270, -0.889062259710535430, -0.889039369284113980, +-0.889016476635093870, -0.888993581763532830, -0.888970684669487700, -0.888947785353015770, -0.888924883814174560, -0.888901980053021120, -0.888879074069612640, -0.888856165864006400, +-0.888833255436259910, -0.888810342786430340, -0.888787427914574880, -0.888764510820750590, -0.888741591505015300, -0.888718669967425990, -0.888695746208039930, -0.888672820226914410, +-0.888649892024107050, -0.888626961599674910, -0.888604028953675410, -0.888581094086165590, -0.888558156997203200, -0.888535217686845510, -0.888512276155149490, -0.888489332402173090, +-0.888466386427973260, -0.888443438232607520, -0.888420487816133030, -0.888397535178607420, -0.888374580320087980, -0.888351623240632100, -0.888328663940296970, -0.888305702419140420, +-0.888282738677219630, -0.888259772714591890, -0.888236804531314590, -0.888213834127445480, -0.888190861503041830, -0.888167886658160930, -0.888144909592860190, -0.888121930307197330, +-0.888098948801229640, -0.888075965075014630, -0.888052979128609480, -0.888029990962072020, -0.888007000575459670, -0.887984007968829590, -0.887961013142239630, -0.887938016095747300, +-0.887915016829409760, -0.887892015343284550, -0.887869011637429480, -0.887846005711901980, -0.887822997566759310, -0.887799987202058990, -0.887776974617858980, -0.887753959814216450, +-0.887730942791189140, -0.887707923548834100, -0.887684902087209630, -0.887661878406372780, -0.887638852506381300, -0.887615824387292470, -0.887592794049164250, -0.887569761492054020, +-0.887546726716019310, -0.887523689721117840, -0.887500650507407230, -0.887477609074945000, -0.887454565423788530, -0.887431519553995800, -0.887408471465624290, -0.887385421158731650, +-0.887362368633375250, -0.887339313889613070, -0.887316256927502710, -0.887293197747101580, -0.887270136348467410, -0.887247072731657930, -0.887224006896730870, -0.887200938843743850, +-0.887177868572754160, -0.887154796083819970, -0.887131721376998920, -0.887108644452348270, -0.887085565309926330, -0.887062483949790370, -0.887039400371998240, -0.887016314576607350, +-0.886993226563675960, -0.886970136333261490, -0.886947043885421670, -0.886923949220214000, -0.886900852337696670, -0.886877753237927280, -0.886854651920963470, -0.886831548386862730, +-0.886808442635683370, -0.886785334667482990, -0.886762224482319230, -0.886739112080249690, -0.886715997461332560, -0.886692880625625460, -0.886669761573186220, -0.886646640304072250, +-0.886623516818341950, -0.886600391116052820, -0.886577263197262600, -0.886554133062029350, -0.886531000710410800, -0.886507866142464680, -0.886484729358248740, -0.886461590357821240, +-0.886438449141239700, -0.886415305708562080, -0.886392160059845890, -0.886369012195149630, -0.886345862114530700, -0.886322709818047280, -0.886299555305756770, -0.886276398577717560, +-0.886253239633987500, -0.886230078474624210, -0.886206915099685520, -0.886183749509229850, -0.886160581703314690, -0.886137411681997890, -0.886114239445337850, -0.886091064993392070, +-0.886067888326218740, -0.886044709443875480, -0.886021528346420670, -0.885998345033911950, -0.885975159506407480, -0.885951971763964790, -0.885928781806642470, -0.885905589634498170, +-0.885882395247589830, -0.885859198645975400, -0.885835999829713060, -0.885812798798860770, -0.885789595553476580, -0.885766390093618130, -0.885743182419343910, -0.885719972530711660, +-0.885696760427779340, -0.885673546110605340, -0.885650329579247500, -0.885627110833763780, -0.885603889874212010, -0.885580666700650830, -0.885557441313137960, -0.885534213711731470, +-0.885510983896489300, -0.885487751867469860, -0.885464517624731000, -0.885441281168330870, -0.885418042498327230, -0.885394801614778790, -0.885371558517743410, -0.885348313207279030, +-0.885325065683443710, -0.885301815946295870, -0.885278563995893550, -0.885255309832294610, -0.885232053455557550, -0.885208794865740440, -0.885185534062901350, -0.885162271047098100, +-0.885139005818389450, -0.885115738376833330, -0.885092468722487810, -0.885069196855410970, -0.885045922775661300, -0.885022646483296760, -0.884999367978375640, -0.884976087260956000, +-0.884952804331096240, -0.884929519188854430, -0.884906231834288960, -0.884882942267457560, -0.884859650488419190, -0.884836356497231580, -0.884813060293953010, -0.884789761878641670, +-0.884766461251356160, -0.884743158412154450, -0.884719853361094710, -0.884696546098235450, -0.884673236623634840, -0.884649924937351170, -0.884626611039442510, -0.884603294929967480, +-0.884579976608984240, -0.884556656076550980, -0.884533333332725990, -0.884510008377567770, -0.884486681211134610, -0.884463351833484680, -0.884440020244676160, -0.884416686444767900, +-0.884393350433817840, -0.884370012211884380, -0.884346671779025820, -0.884323329135300650, -0.884299984280767170, -0.884276637215483550, -0.884253287939508640, -0.884229936452900380, +-0.884206582755717290, -0.884183226848017530, -0.884159868729859970, -0.884136508401302760, -0.884113145862404190, -0.884089781113222670, -0.884066414153816820, -0.884043044984244910, +-0.884019673604565460, -0.883996300014836530, -0.883972924215117080, -0.883949546205465400, -0.883926165985939760, -0.883902783556598570, -0.883879398917500670, -0.883856012068704120, +-0.883832623010267440, -0.883809231742249460, -0.883785838264708250, -0.883762442577702530, -0.883739044681290500, -0.883715644575531090, -0.883692242260482490, -0.883668837736203310, +-0.883645431002751840, -0.883622022060187030, -0.883598610908567170, -0.883575197547950770, -0.883551781978396120, -0.883528364199962280, -0.883504944212707530, -0.883481522016690390, +-0.883458097611969250, -0.883434670998603070, -0.883411242176650240, -0.883387811146169270, -0.883364377907218560, -0.883340942459857060, -0.883317504804143280, -0.883294064940135510, +-0.883270622867892820, -0.883247178587473590, -0.883223732098936340, -0.883200283402339580, -0.883176832497742370, -0.883153379385203000, -0.883129924064780300, -0.883106466536532460, +-0.883083006800518660, -0.883059544856797380, -0.883036080705427270, -0.883012614346466720, -0.882989145779974890, -0.882965675006010200, -0.882942202024631250, -0.882918726835896560, +-0.882895249439865300, -0.882871769836595990, -0.882848288026147010, -0.882824804008577440, -0.882801317783945990, -0.882777829352311190, -0.882754338713731550, -0.882730845868266330, +-0.882707350815973960, -0.882683853556913260, -0.882660354091142630, -0.882636852418721470, -0.882613348539708080, -0.882589842454161280, -0.882566334162139810, -0.882542823663702620, +-0.882519310958908340, -0.882495796047815810, -0.882472278930483630, -0.882448759606970890, -0.882425238077336300, -0.882401714341638390, -0.882378188399936430, -0.882354660252288920, +-0.882331129898754840, -0.882307597339392680, -0.882284062574261730, -0.882260525603420720, -0.882236986426928270, -0.882213445044843230, -0.882189901457224760, -0.882166355664131490, +-0.882142807665622470, -0.882119257461756120, -0.882095705052591830, -0.882072150438188320, -0.882048593618604330, -0.882025034593898800, -0.882001473364130820, -0.881977909929359090, +-0.881954344289642700, -0.881930776445040140, -0.881907206395610930, -0.881883634141413690, -0.881860059682507140, -0.881836483018950680, -0.881812904150802930, -0.881789323078122970, +-0.881765739800969510, -0.881742154319401950, -0.881718566633478920, -0.881694976743259470, -0.881671384648802460, -0.881647790350167160, -0.881624193847412310, -0.881600595140597080, +-0.881576994229780090, -0.881553391115020850, -0.881529785796378080, -0.881506178273910870, -0.881482568547678040, -0.881458956617738990, -0.881435342484152560, -0.881411726146977600, +-0.881388107606273510, -0.881364486862099120, -0.881340863914513490, -0.881317238763575480, -0.881293611409344590, -0.881269981851879770, -0.881246350091239860, -0.881222716127483930, +-0.881199079960671480, -0.881175441590861250, -0.881151801018112410, -0.881128158242483920, -0.881104513264035270, -0.881080866082825210, -0.881057216698913130, -0.881033565112357640, +-0.881009911323218600, -0.880986255331554720, -0.880962597137424970, -0.880938936740888970, -0.880915274142005660, -0.880891609340834100, -0.880867942337433260, -0.880844273131862860, +-0.880820601724181750, -0.880796928114449210, -0.880773252302724070, -0.880749574289065970, -0.880725894073533970, -0.880702211656187230, -0.880678527037084820, -0.880654840216286260, +-0.880631151193850600, -0.880607459969837030, -0.880583766544304590, -0.880560070917313030, -0.880536373088921190, -0.880512673059188230, -0.880488970828173900, -0.880465266395937030, +-0.880441559762537020, -0.880417850928032930, -0.880394139892484380, -0.880370426655950560, -0.880346711218490620, -0.880322993580163640, -0.880299273741029450, -0.880275551701147130, +-0.880251827460575840, -0.880228101019374760, -0.880204372377603740, -0.880180641535321720, -0.880156908492588100, -0.880133173249461940, -0.880109435806003200, -0.880085696162270730, +-0.880061954318324120, -0.880038210274222350, -0.880014464030025260, -0.879990715585792120, -0.879966964941581890, -0.879943212097454410, -0.879919457053468970, -0.879895699809684850, +-0.879871940366161340, -0.879848178722958170, -0.879824414880134520, -0.879800648837749890, -0.879776880595863340, -0.879753110154534830, -0.879729337513823540, -0.879705562673788970, +-0.879681785634490180, -0.879658006395987240, -0.879634224958339210, -0.879610441321605710, -0.879586655485845800, -0.879562867451119450, -0.879539077217486030, -0.879515284785004630, +-0.879491490153735290, -0.879467693323737200, -0.879443894295069860, -0.879420093067792560, -0.879396289641965260, -0.879372484017647230, -0.879348676194897980, -0.879324866173776920, +-0.879301053954343770, -0.879277239536658040, -0.879253422920779240, -0.879229604106766650, -0.879205783094680230, -0.879181959884579370, -0.879158134476523690, -0.879134306870572370, +-0.879110477066785580, -0.879086645065222490, -0.879062810865942620, -0.879038974469005920, -0.879015135874471890, -0.878991295082399930, -0.878967452092849430, -0.878943606905880690, +-0.878919759521552770, -0.878895909939925610, -0.878872058161058400, -0.878848204185011190, -0.878824348011843500, -0.878800489641615060, -0.878776629074385030, -0.878752766310213710, +-0.878728901349160480, -0.878705034191284980, -0.878681164836646710, -0.878657293285305620, -0.878633419537321440, -0.878609543592753670, -0.878585665451661830, -0.878561785114105990, +-0.878537902580145750, -0.878514017849840510, -0.878490130923250460, -0.878466241800435090, -0.878442350481454140, -0.878418456966367000, -0.878394561255233960, -0.878370663348114640, +-0.878346763245068550, -0.878322860946155300, -0.878298956451435190, -0.878275049760967710, -0.878251140874812600, -0.878227229793029360, -0.878203316515678290, -0.878179401042818890, +-0.878155483374511100, -0.878131563510814230, -0.878107641451788770, -0.878083717197494230, -0.878059790747990120, -0.878035862103336730, -0.878011931263593780, -0.877987998228820900, +-0.877964062999077920, -0.877940125574424910, -0.877916185954921600, -0.877892244140627830, -0.877868300131603220, -0.877844353927908160, -0.877820405529602170, -0.877796454936745070, +-0.877772502149396730, -0.877748547167617300, -0.877724589991466520, -0.877700630621004340, -0.877676669056290270, -0.877652705297384710, -0.877628739344347490, -0.877604771197238120, +-0.877580800856117120, -0.877556828321044090, -0.877532853592079000, -0.877508876669281460, -0.877484897552712080, -0.877460916242430390, -0.877436932738496430, -0.877412947040969840, +-0.877388959149911220, -0.877364969065380200, -0.877340976787436720, -0.877316982316140530, -0.877292985651552120, -0.877268986793731330, -0.877244985742737900, -0.877220982498632010, +-0.877196977061473700, -0.877172969431323060, -0.877148959608239800, -0.877124947592284210, -0.877100933383516360, -0.877076916981996190, -0.877052898387783440, -0.877028877600938730, +-0.877004854621521780, -0.876980829449592770, -0.876956802085211320, -0.876932772528438260, -0.876908740779333120, -0.876884706837956270, -0.876860670704367350, -0.876836632378626970, +-0.876812591860794970, -0.876788549150931520, -0.876764504249096580, -0.876740457155350540, -0.876716407869753240, -0.876692356392365090, -0.876668302723245700, -0.876644246862455790, +-0.876620188810055320, -0.876596128566104140, -0.876572066130662850, -0.876548001503791420, -0.876523934685550010, -0.876499865675998470, -0.876475794475197520, -0.876451721083207120, +-0.876427645500087340, -0.876403567725898340, -0.876379487760700520, -0.876355405604554050, -0.876331321257519000, -0.876307234719655550, -0.876283145991024190, -0.876259055071684890, +-0.876234961961698030, -0.876210866661123470, -0.876186769170022030, -0.876162669488453670, -0.876138567616478350, -0.876114463554156900, -0.876090357301549270, -0.876066248858715760, +-0.876042138225716300, -0.876018025402611870, -0.875993910389462280, -0.875969793186327950, -0.875945673793268930, -0.875921552210345960, -0.875897428437619090, -0.875873302475148610, +-0.875849174322994690, -0.875825043981217970, -0.875800911449878820, -0.875776776729037200, -0.875752639818753510, -0.875728500719088480, -0.875704359430102160, -0.875680215951854750, +-0.875656070284406950, -0.875631922427819060, -0.875607772382151260, -0.875583620147463940, -0.875559465723817710, -0.875535309111272750, -0.875511150309889690, -0.875486989319728350, +-0.875462826140849910, -0.875438660773314340, -0.875414493217182120, -0.875390323472513440, -0.875366151539369140, -0.875341977417809500, -0.875317801107894920, -0.875293622609685680, +-0.875269441923242520, -0.875245259048625710, -0.875221073985895880, -0.875196886735113090, -0.875172697296338290, -0.875148505669631760, -0.875124311855053680, -0.875100115852665120, +-0.875075917662526240, -0.875051717284697660, -0.875027514719239450, -0.875003309966212670, -0.874979103025677720, -0.874954893897694870, -0.874930682582324650, -0.874906469079627990, +-0.874882253389665080, -0.874858035512496520, -0.874833815448182730, -0.874809593196784530, -0.874785368758362440, -0.874761142132976950, -0.874736913320688260, -0.874712682321557630, +-0.874688449135645250, -0.874664213763011510, -0.874639976203717360, -0.874615736457823420, -0.874591494525390090, -0.874567250406477760, -0.874543004101147600, -0.874518755609459910, +-0.874494504931475400, -0.874470252067254260, -0.874445997016857770, -0.874421739780346320, -0.874397480357780530, -0.874373218749220800, -0.874348954954728200, -0.874324688974363220, +-0.874300420808186600, -0.874276150456258620, -0.874251877918640450, -0.874227603195392720, -0.874203326286575710, -0.874179047192250590, -0.874154765912477760, -0.874130482447318170, +-0.874106196796832100, -0.874081908961080730, -0.874057618940124570, -0.874033326734024450, -0.874009032342840770, -0.873984735766634710, -0.873960437005466770, -0.873936136059397790, +-0.873911832928488170, -0.873887527612799310, -0.873863220112391590, -0.873838910427325750, -0.873814598557662410, -0.873790284503462970, -0.873765968264787700, -0.873741649841697220, +-0.873717329234252940, -0.873693006442515240, -0.873668681466545080, -0.873644354306403080, -0.873620024962150300, -0.873595693433847460, -0.873571359721555530, -0.873547023825334780, +-0.873522685745246830, -0.873498345481352080, -0.873474003033711590, -0.873449658402385750, -0.873425311587436080, -0.873400962588923080, -0.873376611406907590, -0.873352258041450450, +-0.873327902492612940, -0.873303544760455570, -0.873279184845039300, -0.873254822746424960, -0.873230458464673730, -0.873206091999846330, -0.873181723352003610, -0.873157352521206740, +-0.873132979507516340, -0.873108604310993690, -0.873084226931699180, -0.873059847369694440, -0.873035465625039970, -0.873011081697796950, -0.872986695588025880, -0.872962307295788390, +-0.872937916821145080, -0.872913524164157020, -0.872889129324884830, -0.872864732303390120, -0.872840333099733630, -0.872815931713976200, -0.872791528146178770, -0.872767122396402750, +-0.872742714464708860, -0.872718304351158050, -0.872693892055811720, -0.872669477578730590, -0.872645060919975730, -0.872620642079608100, -0.872596221057688970, -0.872571797854279410, +-0.872547372469440250, -0.872522944903232570, -0.872498515155717640, -0.872474083226956410, -0.872449649117010060, -0.872425212825939320, -0.872400774353805700, -0.872376333700670250, +-0.872351890866593930, -0.872327445851637680, -0.872302998655862920, -0.872278549279330790, -0.872254097722102050, -0.872229643984238300, -0.872205188065800390, -0.872180729966849590, +-0.872156269687446640, -0.872131807227653270, -0.872107342587530420, -0.872082875767139170, -0.872058406766540560, -0.872033935585796120, -0.872009462224966890, -0.871984986684113950, +-0.871960508963298350, -0.871936029062581720, -0.871911546982024890, -0.871887062721689370, -0.871862576281635880, -0.871838087661926160, -0.871813596862621280, -0.871789103883782280, +-0.871764608725470460, -0.871740111387747210, -0.871715611870673810, -0.871691110174311110, -0.871666606298720730, -0.871642100243963940, -0.871617592010101920, -0.871593081597195730, +-0.871568569005306990, -0.871544054234496880, -0.871519537284826560, -0.871495018156357220, -0.871470496849150570, -0.871445973363267680, -0.871421447698769840, -0.871396919855718100, +-0.871372389834174420, -0.871347857634199640, -0.871323323255855260, -0.871298786699202350, -0.871274247964302750, -0.871249707051217400, -0.871225163960007710, -0.871200618690735280, +-0.871176071243461190, -0.871151521618247050, -0.871126969815153920, -0.871102415834243530, -0.871077859675577050, -0.871053301339215990, -0.871028740825221410, -0.871004178133655160, +-0.870979613264578620, -0.870955046218052860, -0.870930476994139390, -0.870905905592899930, -0.870881332014395660, -0.870856756258688080, -0.870832178325838480, -0.870807598215908580, +-0.870783015928959680, -0.870758431465052940, -0.870733844824250420, -0.870709256006613310, -0.870684665012203100, -0.870660071841080960, -0.870635476493308860, -0.870610878968947950, +-0.870586279268059980, -0.870561677390706110, -0.870537073336948190, -0.870512467106847600, -0.870487858700465860, -0.870463248117864350, -0.870438635359104820, -0.870414020424248760, +-0.870389403313357570, -0.870364784026492640, -0.870340162563716050, -0.870315538925089060, -0.870290913110672970, -0.870266285120529840, -0.870241654954720940, -0.870217022613308020, +-0.870192388096352240, -0.870167751403915670, -0.870143112536059800, -0.870118471492846160, -0.870093828274336010, -0.870069182880591650, -0.870044535311674250, -0.870019885567645530, +-0.869995233648566790, -0.869970579554500300, -0.869945923285507350, -0.869921264841649560, -0.869896604222988420, -0.869871941429586020, -0.869847276461503730, -0.869822609318803170, +-0.869797940001545980, -0.869773268509794080, -0.869748594843609110, -0.869723919003052350, -0.869699240988185960, -0.869674560799071570, -0.869649878435770800, -0.869625193898345030, +-0.869600507186856550, -0.869575818301366770, -0.869551127241937500, -0.869526434008630060, -0.869501738601506920, -0.869477041020629280, -0.869452341266059080, -0.869427639337857940, +-0.869402935236087800, -0.869378228960810300, -0.869353520512087250, -0.869328809889980290, -0.869304097094551360, -0.869279382125862310, -0.869254664983974520, -0.869229945668950400, +-0.869205224180851220, -0.869180500519739160, -0.869155774685675510, -0.869131046678722760, -0.869106316498942320, -0.869081584146396020, -0.869056849621145600, -0.869032112923253330, +-0.869007374052780720, -0.868982633009789730, -0.868957889794341850, -0.868933144406499600, -0.868908396846324370, -0.868883647113878220, -0.868858895209222660, -0.868834141132420080, +-0.868809384883532210, -0.868784626462620670, -0.868759865869747740, -0.868735103104975150, -0.868710338168364850, -0.868685571059978460, -0.868660801779878260, -0.868636030328126200, +-0.868611256704784010, -0.868586480909913420, -0.868561702943576930, -0.868536922805836050, -0.868512140496752960, -0.868487356016389270, -0.868462569364807480, -0.868437780542069220, +-0.868412989548236540, -0.868388196383371060, -0.868363401047535400, -0.868338603540791290, -0.868313803863200560, -0.868289002014825170, -0.868264197995727400, -0.868239391805969210, +-0.868214583445612310, -0.868189772914719220, -0.868164960213351660, -0.868140145341571690, -0.868115328299441160, -0.868090509087022450, -0.868065687704377530, -0.868040864151568450, +-0.868016038428656930, -0.867991210535705490, -0.867966380472776080, -0.867941548239930750, -0.867916713837231240, -0.867891877264740260, -0.867867038522519450, -0.867842197610631190, +-0.867817354529137110, -0.867792509278099920, -0.867767661857581470, -0.867742812267643600, -0.867717960508349040, -0.867693106579759400, -0.867668250481937080, -0.867643392214943910, +-0.867618531778842520, -0.867593669173694740, -0.867568804399562850, -0.867543937456508710, -0.867519068344594910, -0.867494197063883420, -0.867469323614436520, -0.867444447996316040, +-0.867419570209584710, -0.867394690254304380, -0.867369808130537320, -0.867344923838345610, -0.867320037377791730, -0.867295148748937760, -0.867270257951845760, -0.867245364986578340, +-0.867220469853197450, -0.867195572551765380, -0.867170673082344190, -0.867145771444996490, -0.867120867639784470, -0.867095961666770170, -0.867071053526015770, -0.867046143217584000, +-0.867021230741536920, -0.866996316097936700, -0.866971399286845410, -0.866946480308325880, -0.866921559162440180, -0.866896635849250590, -0.866871710368819160, -0.866846782721208630, +-0.866821852906481280, -0.866796920924698950, -0.866771986775924600, -0.866747050460220270, -0.866722111977648370, -0.866697171328270840, -0.866672228512150640, -0.866647283529349940, +-0.866622336379931020, -0.866597387063956060, -0.866572435581487780, -0.866547481932588460, -0.866522526117320390, -0.866497568135745740, -0.866472607987927470, -0.866447645673927740, +-0.866422681193808830, -0.866397714547632920, -0.866372745735463080, -0.866347774757361360, -0.866322801613390150, -0.866297826303611630, -0.866272848828088860, -0.866247869186884010, +-0.866222887380059260, -0.866197903407677440, -0.866172917269800950, -0.866147928966492060, -0.866122938497813190, -0.866097945863827160, -0.866072951064596360, -0.866047954100183090, +-0.866022954970649740, -0.865997953676059250, -0.865972950216473800, -0.865947944591956010, -0.865922936802568160, -0.865897926848373190, -0.865872914729433400, -0.865847900445811390, +-0.865822883997569240, -0.865797865384770220, -0.865772844607476610, -0.865747821665750480, -0.865722796559655120, -0.865697769289252790, -0.865672739854606020, -0.865647708255777190, +-0.865622674492829260, -0.865597638565824720, -0.865572600474825980, -0.865547560219895540, -0.865522517801096460, -0.865497473218491130, -0.865472426472142060, -0.865447377562111760, +-0.865422326488463180, -0.865397273251258810, -0.865372217850561180, -0.865347160286432880, -0.865322100558936880, -0.865297038668135570, -0.865271974614091550, -0.865246908396867690, +-0.865221840016526690, -0.865196769473130960, -0.865171696766743210, -0.865146621897426420, -0.865121544865242950, -0.865096465670255780, -0.865071384312527060, -0.865046300792120190, +-0.865021215109097570, -0.864996127263521930, -0.864971037255455770, -0.864945945084962140, -0.864920850752103790, -0.864895754256943210, -0.864870655599543010, -0.864845554779966500, +-0.864820451798275940, -0.864795346654534390, -0.864770239348804150, -0.864745129881148600, -0.864720018251630250, -0.864694904460311610, -0.864669788507255950, -0.864644670392525790, +-0.864619550116183970, -0.864594427678292980, -0.864569303078916220, -0.864544176318116200, -0.864519047395955640, -0.864493916312497390, -0.864468783067804500, -0.864443647661939600, +-0.864418510094965730, -0.864393370366945190, -0.864368228477941590, -0.864343084428017330, -0.864317938217235350, -0.864292789845658380, -0.864267639313349600, -0.864242486620371730, +-0.864217331766787390, -0.864192174752660080, -0.864167015578052200, -0.864141854243026810, -0.864116690747646520, -0.864091525091974840, -0.864066357276074280, -0.864041187300007780, +-0.864016015163838190, -0.863990840867628670, -0.863965664411442180, -0.863940485795341440, -0.863915305019389290, -0.863890122083649130, -0.863864936988183670, -0.863839749733055770, +-0.863814560318328370, -0.863789368744064760, -0.863764175010327650, -0.863738979117180010, -0.863713781064685100, -0.863688580852905790, -0.863663378481904890, -0.863638173951745470, +-0.863612967262490700, -0.863587758414203540, -0.863562547406947050, -0.863537334240783940, -0.863512118915777730, -0.863486901431991250, -0.863461681789487460, -0.863436459988329300, +-0.863411236028580160, -0.863386009910302900, -0.863360781633560670, -0.863335551198416320, -0.863310318604933240, -0.863285083853174370, -0.863259846943202570, -0.863234607875081330, +-0.863209366648873600, -0.863184123264642560, -0.863158877722450920, -0.863133630022362320, -0.863108380164439580, -0.863083128148745880, -0.863057873975344170, -0.863032617644298060, +-0.863007359155670390, -0.862982098509524230, -0.862956835705922630, -0.862931570744929210, -0.862906303626606920, -0.862881034351018820, -0.862855762918227850, -0.862830489328297760, +-0.862805213581291470, -0.862779935677272070, -0.862754655616302600, -0.862729373398446800, -0.862704089023767500, -0.862678802492327760, -0.862653513804191310, -0.862628222959420990, +-0.862602929958080190, -0.862577634800231750, -0.862552337485939510, -0.862527038015266420, -0.862501736388275760, -0.862476432605030490, -0.862451126665594310, -0.862425818570030420, +-0.862400508318401980, -0.862375195910771940, -0.862349881347204250, -0.862324564627761750, -0.862299245752507940, -0.862273924721505770, -0.862248601534818970, -0.862223276192510710, +-0.862197948694644060, -0.862172619041282730, -0.862147287232489790, -0.862121953268328740, -0.862096617148862430, -0.862071278874154910, -0.862045938444269240, -0.862020595859268600, +-0.861995251119216380, -0.861969904224176190, -0.861944555174211200, -0.861919203969384930, -0.861893850609760310, -0.861868495095401310, -0.861843137426371090, -0.861817777602733040, +-0.861792415624550330, -0.861767051491886820, -0.861741685204805650, -0.861716316763370130, -0.861690946167643860, -0.861665573417690340, -0.861640198513572870, -0.861614821455354730, +-0.861589442243099750, -0.861564060876871100, -0.861538677356732290, -0.861513291682746600, -0.861487903854977870, -0.861462513873489490, -0.861437121738344750, -0.861411727449607030, +-0.861386331007340080, -0.861360932411607380, -0.861335531662472450, -0.861310128759998350, -0.861284723704249130, -0.861259316495288200, -0.861233907133178930, -0.861208495617984630, +-0.861183081949769450, -0.861157666128596460, -0.861132248154529050, -0.861106828027631280, -0.861081405747966430, -0.861055981315598130, -0.861030554730589650, -0.861005125993004940, +-0.860979695102907390, -0.860954262060360740, -0.860928826865428040, -0.860903389518173580, -0.860877950018660740, -0.860852508366952930, -0.860827064563113640, -0.860801618607206830, +-0.860776170499296110, -0.860750720239444880, -0.860725267827716630, -0.860699813264175440, -0.860674356548884690, -0.860648897681907890, -0.860623436663309090, -0.860597973493151590, +-0.860572508171499220, -0.860547040698415370, -0.860521571073964210, -0.860496099298209030, -0.860470625371213550, -0.860445149293041390, -0.860419671063756500, -0.860394190683422490, +-0.860368708152102980, -0.860343223469861470, -0.860317736636762140, -0.860292247652868490, -0.860266756518244250, -0.860241263232952800, -0.860215767797058440, -0.860190270210624660, +-0.860164770473714980, -0.860139268586393670, -0.860113764548724120, -0.860088258360770190, -0.860062750022595360, -0.860037239534263920, -0.860011726895839380, -0.859986212107385460, +-0.859960695168965890, -0.859935176080644740, -0.859909654842485600, -0.859884131454552340, -0.859858605916908660, -0.859833078229618520, -0.859807548392745760, -0.859782016406354210, +-0.859756482270507270, -0.859730945985269450, -0.859705407550704130, -0.859679866966875150, -0.859654324233846800, -0.859628779351682470, -0.859603232320446330, -0.859577683140201780, +-0.859552131811013310, -0.859526578332944550, -0.859501022706059330, -0.859475464930421260, -0.859449905006094860, -0.859424342933143630, -0.859398778711631510, -0.859373212341622230, +-0.859347643823180190, -0.859322073156368990, -0.859296500341252710, -0.859270925377894850, -0.859245348266359900, -0.859219769006711600, -0.859194187599014000, -0.859168604043330510, +-0.859143018339725840, -0.859117430488263610, -0.859091840489007550, -0.859066248342022170, -0.859040654047371180, -0.859015057605118540, -0.858989459015327970, -0.858963858278063990, +-0.858938255393390420, -0.858912650361371210, -0.858887043182070100, -0.858861433855551580, -0.858835822381879610, -0.858810208761118020, -0.858784592993330540, -0.858758975078582010, +-0.858733355016935930, -0.858707732808456470, -0.858682108453207470, -0.858656481951253440, -0.858630853302658200, -0.858605222507485610, -0.858579589565800160, -0.858553954477665800, +-0.858528317243146490, -0.858502677862306160, -0.858477036335209440, -0.858451392661920050, -0.858425746842502170, -0.858400098877019730, -0.858374448765537260, -0.858348796508118680, +-0.858323142104828070, -0.858297485555729490, -0.858271826860887320, -0.858246166020365630, -0.858220503034228480, -0.858194837902539920, -0.858169170625364350, -0.858143501202766060, +-0.858117829634808650, -0.858092155921556850, -0.858066480063074730, -0.858040802059426460, -0.858015121910675860, -0.857989439616887780, -0.857963755178126060, -0.857938068594454980, +-0.857912379865938380, -0.857886688992641200, -0.857860995974627280, -0.857835300811960800, -0.857809603504705920, -0.857783904052927150, -0.857758202456688770, -0.857732498716054730, +-0.857706792831089300, -0.857681084801857120, -0.857655374628422230, -0.857629662310848810, -0.857603947849201130, -0.857578231243543710, -0.857552512493940820, -0.857526791600456420, +-0.857501068563155110, -0.857475343382101300, -0.857449616057359030, -0.857423886588992490, -0.857398154977066510, -0.857372421221645140, -0.857346685322792680, -0.857320947280573400, +-0.857295207095051800, -0.857269464766292290, -0.857243720294359140, -0.857217973679316400, -0.857192224921229040, -0.857166474020161000, -0.857140720976176770, -0.857114965789340650, +-0.857089208459717260, -0.857063448987370860, -0.857037687372365520, -0.857011923614766300, -0.856986157714637260, -0.856960389672042800, -0.856934619487047190, -0.856908847159715160, +-0.856883072690111100, -0.856857296078299300, -0.856831517324344150, -0.856805736428310260, -0.856779953390262140, -0.856754168210264070, -0.856728380888380440, -0.856702591424676090, +-0.856676799819215180, -0.856651006072062350, -0.856625210183281640, -0.856599412152938220, -0.856573611981096270, -0.856547809667820070, -0.856522005213174680, -0.856496198617224150, +-0.856470389880033100, -0.856444579001665930, -0.856418765982187470, -0.856392950821662110, -0.856367133520154370, -0.856341314077728620, -0.856315492494449830, -0.856289668770382150, +-0.856263842905590430, -0.856238014900138960, -0.856212184754092550, -0.856186352467515730, -0.856160518040472880, -0.856134681473028740, -0.856108842765248010, -0.856083001917195110, +-0.856057158928934530, -0.856031313800531320, -0.856005466532049790, -0.855979617123554640, -0.855953765575110160, -0.855927911886781520, -0.855902056058633120, -0.855876198090729570, +-0.855850337983135260, -0.855824475735915470, -0.855798611349134370, -0.855772744822856700, -0.855746876157146950, -0.855721005352070410, -0.855695132407691130, -0.855669257324074170, +-0.855643380101283820, -0.855617500739385140, -0.855591619238442850, -0.855565735598521450, -0.855539849819685450, -0.855513961902000130, -0.855488071845529880, -0.855462179650339220, +-0.855436285316493290, -0.855410388844056620, -0.855384490233094040, -0.855358589483670050, -0.855332686595849820, -0.855306781569697750, -0.855280874405278890, -0.855254965102657420, +-0.855229053661898940, -0.855203140083067750, -0.855177224366228780, -0.855151306511446440, -0.855125386518786110, -0.855099464388312190, -0.855073540120089740, -0.855047613714183140, +-0.855021685170657800, -0.854995754489578320, -0.854969821671009100, -0.854943886715015530, -0.854917949621662340, -0.854892010391014150, -0.854866069023135890, -0.854840125518092520, +-0.854814179875948990, -0.854788232096769800, -0.854762282180620000, -0.854736330127564670, -0.854710375937668410, -0.854684419610996390, -0.854658461147612900, -0.854632500547583660, +-0.854606537810973070, -0.854580572937846170, -0.854554605928267600, -0.854528636782302730, -0.854502665500016300, -0.854476692081472920, -0.854450716526738100, -0.854424738835876440, +-0.854398759008953010, -0.854372777046032320, -0.854346792947180080, -0.854320806712460690, -0.854294818341939430, -0.854268827835680810, -0.854242835193750440, -0.854216840416212930, +-0.854190843503133230, -0.854164844454576300, -0.854138843270607520, -0.854112839951291500, -0.854086834496693430, -0.854060826906878120, -0.854034817181910990, -0.854008805321856750, +-0.853982791326780450, -0.853956775196746950, -0.853930756931821740, -0.853904736532069770, -0.853878713997555660, -0.853852689328344900, -0.853826662524502570, -0.853800633586093480, +-0.853774602513182600, -0.853748569305835430, -0.853722533964116790, -0.853696496488091870, -0.853670456877825500, -0.853644415133383290, -0.853618371254829870, -0.853592325242230610, +-0.853566277095650360, -0.853540226815154620, -0.853514174400808230, -0.853488119852676470, -0.853462063170824180, -0.853436004355316970, -0.853409943406219780, -0.853383880323597350, +-0.853357815107515630, -0.853331747758039330, -0.853305678275233630, -0.853279606659163470, -0.853253532909894590, -0.853227457027491810, -0.853201379012020420, -0.853175298863545370, +-0.853149216582132270, -0.853123132167846190, -0.853097045620752280, -0.853070956940915390, -0.853044866128401470, -0.853018773183275350, -0.852992678105602310, -0.852966580895447300, +-0.852940481552876160, -0.852914380077953730, -0.852888276470745170, -0.852862170731316090, -0.852836062859731680, -0.852809952856056990, -0.852783840720357290, -0.852757726452698210, +-0.852731610053144800, -0.852705491521762340, -0.852679370858615890, -0.852653248063771300, -0.852627123137293610, -0.852600996079248000, -0.852574866889699750, -0.852548735568714580, +-0.852522602116357550, -0.852496466532694060, -0.852470328817789060, -0.852444188971708590, -0.852418046994517620, -0.852391902886281530, -0.852365756647065380, -0.852339608276935110, +-0.852313457775955910, -0.852287305144192710, -0.852261150381711570, -0.852234993488577450, -0.852208834464855960, -0.852182673310612150, -0.852156510025911750, -0.852130344610820160, +-0.852104177065402760, -0.852078007389724610, -0.852051835583851780, -0.852025661647849210, -0.851999485581782620, -0.851973307385716970, -0.851947127059718420, -0.851920944603851930, +-0.851894760018183090, -0.851868573302777210, -0.851842384457700000, -0.851816193483016960, -0.851790000378793160, -0.851763805145094530, -0.851737607781986480, -0.851711408289534290, +-0.851685206667803450, -0.851659002916859810, -0.851632797036768640, -0.851606589027595450, -0.851580378889405630, -0.851554166622265130, -0.851527952226239120, -0.851501735701393200, +-0.851475517047792780, -0.851449296265503810, -0.851423073354591550, -0.851396848315121630, -0.851370621147159330, -0.851344391850770820, -0.851318160426021150, -0.851291926872976060, +-0.851265691191701260, -0.851239453382262260, -0.851213213444724560, -0.851186971379153670, -0.851160727185615530, -0.851134480864175650, -0.851108232414899520, -0.851081981837852550, +-0.851055729133100900, -0.851029474300709850, -0.851003217340745240, -0.850976958253272240, -0.850950697038357130, -0.850924433696065300, -0.850898168226462360, -0.850871900629613820, +-0.850845630905585630, -0.850819359054443500, -0.850793085076252620, -0.850766808971079370, -0.850740530738989030, -0.850714250380047440, -0.850687967894319890, -0.850661683281872750, +-0.850635396542771320, -0.850609107677081420, -0.850582816684868570, -0.850556523566198820, -0.850530228321137890, -0.850503930949751300, -0.850477631452104640, -0.850451329828264210, +-0.850425026078295400, -0.850398720202264040, -0.850372412200235630, -0.850346102072276340, -0.850319789818451910, -0.850293475438828050, -0.850267158933470160, -0.850240840302444620, +-0.850214519545817060, -0.850188196663652860, -0.850161871656018530, -0.850135544522979460, -0.850109215264601480, -0.850082883880950320, -0.850056550372092050, -0.850030214738092480, +-0.850003876979017470, -0.849977537094932400, -0.849951195085903780, -0.849924850951997100, -0.849898504693278320, -0.849872156309813160, -0.849845805801667690, -0.849819453168907830, +-0.849793098411599220, -0.849766741529807800, -0.849740382523599620, -0.849714021393040530, -0.849687658138196130, -0.849661292759132820, -0.849634925255916330, -0.849608555628612480, +-0.849582183877287010, -0.849555810002006310, -0.849529434002836090, -0.849503055879842320, -0.849476675633090590, -0.849450293262647430, -0.849423908768578650, -0.849397522150949990, +-0.849371133409827280, -0.849344742545277030, -0.849318349557364850, -0.849291954446156900, -0.849265557211718810, -0.849239157854116970, -0.849212756373417310, -0.849186352769685460, +-0.849159947042988030, -0.849133539193390740, -0.849107129220959660, -0.849080717125760390, -0.849054302907859660, -0.849027886567323090, -0.849001468104216840, -0.848975047518606640, +-0.848948624810559100, -0.848922199980140070, -0.848895773027415480, -0.848869343952451170, -0.848842912755313760, -0.848816479436069080, -0.848790043994783310, -0.848763606431522040, +-0.848737166746352020, -0.848710724939339190, -0.848684281010549380, -0.848657834960048760, -0.848631386787903730, -0.848604936494180230, -0.848578484078944210, -0.848552029542262170, +-0.848525572884200050, -0.848499114104824040, -0.848472653204199960, -0.848446190182394530, -0.848419725039473600, -0.848393257775503340, -0.848366788390549800, -0.848340316884679480, +-0.848313843257958330, -0.848287367510452530, -0.848260889642228120, -0.848234409653351730, -0.848207927543889300, -0.848181443313907100, -0.848154956963470990, -0.848128468492647780, +-0.848101977901503430, -0.848075485190103780, -0.848048990358515780, -0.848022493406805240, -0.847995994335038470, -0.847969493143281410, -0.847942989831600990, -0.847916484400062950, +-0.847889976848733800, -0.847863467177679460, -0.847836955386966680, -0.847810441476661510, -0.847783925446830230, -0.847757407297538900, -0.847730887028854350, -0.847704364640842530, +-0.847677840133569730, -0.847651313507102210, -0.847624784761506600, -0.847598253896848950, -0.847571720913195550, -0.847545185810613000, -0.847518648589167590, -0.847492109248925480, +-0.847465567789952860, -0.847439024212316540, -0.847412478516082700, -0.847385930701317620, -0.847359380768087480, -0.847332828716459210, -0.847306274546498760, -0.847279718258272750, +-0.847253159851847130, -0.847226599327288830, -0.847200036684664040, -0.847173471924039250, -0.847146905045480400, -0.847120336049054570, -0.847093764934828020, -0.847067191702866710, +-0.847040616353237690, -0.847014038886007010, -0.846987459301241420, -0.846960877599006840, -0.846934293779370350, -0.846907707842398110, -0.846881119788156500, -0.846854529616712040, +-0.846827937328131330, -0.846801342922480880, -0.846774746399826970, -0.846748147760236100, -0.846721547003775000, -0.846694944130510050, -0.846668339140507760, -0.846641732033834420, +-0.846615122810556840, -0.846588511470741660, -0.846561898014455030, -0.846535282441763460, -0.846508664752734010, -0.846482044947432840, -0.846455423025926250, -0.846428798988281380, +-0.846402172834564540, -0.846375544564842320, -0.846348914179180900, -0.846322281677647560, -0.846295647060308460, -0.846269010327230120, -0.846242371478479140, -0.846215730514122470, +-0.846189087434226490, -0.846162442238857730, -0.846135794928082660, -0.846109145501968250, -0.846082493960581110, -0.846055840303987730, -0.846029184532254400, -0.846002526645448390, +-0.845975866643636110, -0.845949204526883940, -0.845922540295258930, -0.845895873948827590, -0.845869205487656540, -0.845842534911812270, -0.845815862221361960, -0.845789187416371880, +-0.845762510496908870, -0.845735831463039430, -0.845709150314830630, -0.845682467052348840, -0.845655781675661020, -0.845629094184833340, -0.845602404579933300, -0.845575712861027280, +-0.845549019028181800, -0.845522323081463690, -0.845495625020940000, -0.845468924846677240, -0.845442222558741910, -0.845415518157201170, -0.845388811642121760, -0.845362103013570290, +-0.845335392271613360, -0.845308679416318150, -0.845281964447751170, -0.845255247365979350, -0.845228528171069190, -0.845201806863087990, -0.845175083442102130, -0.845148357908178660, +-0.845121630261384090, -0.845094900501785600, -0.845068168629449890, -0.845041434644443810, -0.845014698546833750, -0.844987960336687330, -0.844961220014071030, -0.844934477579051600, +-0.844907733031695750, -0.844880986372070760, -0.844854237600243470, -0.844827486716280160, -0.844800733720248440, -0.844773978612214930, -0.844747221392246450, -0.844720462060409630, +-0.844693700616771960, -0.844666937061399950, -0.844640171394360650, -0.844613403615720790, -0.844586633725547540, -0.844559861723907730, -0.844533087610868320, -0.844506311386495790, +-0.844479533050857880, -0.844452752604021080, -0.844425970046052350, -0.844399185377018520, -0.844372398596986980, -0.844345609706024460, -0.844318818704197670, -0.844292025591574010, +-0.844265230368220320, -0.844238433034203540, -0.844211633589590390, -0.844184832034448500, -0.844158028368844460, -0.844131222592845450, -0.844104414706517980, -0.844077604709929870, +-0.844050792603147640, -0.844023978386238550, -0.843997162059269110, -0.843970343622307160, -0.843943523075419310, -0.843916700418672620, -0.843889875652133910, -0.843863048775870820, +-0.843836219789950050, -0.843809388694438440, -0.843782555489403730, -0.843755720174912520, -0.843728882751032080, -0.843702043217829270, -0.843675201575371460, -0.843648357823725710, +-0.843621511962958980, -0.843594663993138320, -0.843567813914331220, -0.843540961726604640, -0.843514107430025530, -0.843487251024661040, -0.843460392510578580, -0.843433531887845090, +-0.843406669156527840, -0.843379804316693680, -0.843352937368410330, -0.843326068311744500, -0.843299197146763380, -0.843272323873534460, -0.843245448492124680, -0.843218571002601340, +-0.843191691405031250, -0.843164809699482260, -0.843137925886021210, -0.843111039964715370, -0.843084151935631580, -0.843057261798837780, -0.843030369554400800, -0.843003475202387940, +-0.842976578742866020, -0.842949680175902990, -0.842922779501565690, -0.842895876719921610, -0.842868971831037370, -0.842842064834981140, -0.842815155731819640, -0.842788244521620270, +-0.842761331204450070, -0.842734415780376670, -0.842707498249467330, -0.842680578611789020, -0.842653656867409450, -0.842626733016395790, -0.842599807058815320, -0.842572878994734990, +-0.842545948824222850, -0.842519016547345730, -0.842492082164171040, -0.842465145674766050, -0.842438207079198250, -0.842411266377535050, -0.842384323569843610, -0.842357378656191200, +-0.842330431636645560, -0.842303482511273850, -0.842276531280143460, -0.842249577943321450, -0.842222622500875760, -0.842195664952873460, -0.842168705299381810, -0.842141743540468670, +-0.842114779676201080, -0.842087813706646650, -0.842060845631872330, -0.842033875451946190, -0.842006903166935380, -0.841979928776907300, -0.841952952281929120, -0.841925973682068900, +-0.841898992977393680, -0.841872010167970970, -0.841845025253867950, -0.841818038235152670, -0.841791049111892290, -0.841764057884154320, -0.841737064552005920, -0.841710069115515160, +-0.841683071574749090, -0.841656071929775210, -0.841629070180661350, -0.841602066327474920, -0.841575060370283180, -0.841548052309153640, -0.841521042144154130, -0.841494029875352050, +-0.841467015502815000, -0.841439999026610040, -0.841412980446805350, -0.841385959763468190, -0.841358936976666190, -0.841331912086466630, -0.841304885092937440, -0.841277855996146130, +-0.841250824796160090, -0.841223791493046820, -0.841196756086874280, -0.841169718577709840, -0.841142678965621120, -0.841115637250675400, -0.841088593432940960, -0.841061547512484960, +-0.841034499489374810, -0.841007449363678660, -0.840980397135463910, -0.840953342804798280, -0.840926286371748930, -0.840899227836384040, -0.840872167198771230, -0.840845104458977980, +-0.840818039617071690, -0.840790972673120530, -0.840763903627191890, -0.840736832479353600, -0.840709759229672950, -0.840682683878218100, -0.840655606425056550, -0.840628526870256020, +-0.840601445213883910, -0.840574361456008500, -0.840547275596697060, -0.840520187636017320, -0.840493097574037230, -0.840466005410824500, -0.840438911146446750, -0.840411814780971380, +-0.840384716314466760, -0.840357615747000410, -0.840330513078639930, -0.840303408309453050, -0.840276301439507820, -0.840249192468871750, -0.840222081397612790, -0.840194968225798420, +-0.840167852953496830, -0.840140735580775620, -0.840113616107702520, -0.840086494534345140, -0.840059370860771870, -0.840032245087050100, -0.840005117213247440, -0.839977987239432290, +-0.839950855165672140, -0.839923720992034940, -0.839896584718588080, -0.839869446345400060, -0.839842305872538390, -0.839815163300071000, -0.839788018628065400, -0.839760871856590100, +-0.839733722985712470, -0.839706572015500700, -0.839679418946022160, -0.839652263777345250, -0.839625106509537810, -0.839597947142667560, -0.839570785676802210, -0.839543622112010060, +-0.839516456448358930, -0.839489288685916430, -0.839462118824750860, -0.839434946864930140, -0.839407772806521900, -0.839380596649594080, -0.839353418394214960, -0.839326238040452370, +-0.839299055588374140, -0.839271871038048010, -0.839244684389542470, -0.839217495642925250, -0.839190304798264290, -0.839163111855627200, -0.839135916815082710, -0.839108719676698310, +-0.839081520440542180, -0.839054319106682040, -0.839027115675186290, -0.838999910146122850, -0.838972702519559580, -0.838945492795564180, -0.838918280974205510, -0.838891067055550940, +-0.838863851039668540, -0.838836632926626800, -0.838809412716493450, -0.838782190409336550, -0.838754966005223920, -0.838727739504224190, -0.838700510906405070, -0.838673280211834630, +-0.838646047420580800, -0.838618812532712090, -0.838591575548296330, -0.838564336467401690, -0.838537095290095900, -0.838509852016447680, -0.838482606646524740, -0.838455359180395380, +-0.838428109618127190, -0.838400857959789140, -0.838373604205448930, -0.838346348355174410, -0.838319090409034300, -0.838291830367096540, -0.838264568229429070, -0.838237303996099970, +-0.838210037667177940, -0.838182769242730720, -0.838155498722826690, -0.838128226107533570, -0.838100951396920090, -0.838073674591054310, -0.838046395690004390, -0.838019114693838160, +-0.837991831602624360, -0.837964546416431030, -0.837937259135326350, -0.837909969759378260, -0.837882678288655480, -0.837855384723225960, -0.837828089063157870, -0.837800791308519700, +-0.837773491459379520, -0.837746189515805710, -0.837718885477866100, -0.837691579345629540, -0.837664271119164080, -0.837636960798537890, -0.837609648383819130, -0.837582333875076410, +-0.837555017272377910, -0.837527698575791790, -0.837500377785386220, -0.837473054901230030, -0.837445729923391060, -0.837418402851937920, -0.837391073686938440, -0.837363742428461450, +-0.837336409076575250, -0.837309073631347990, -0.837281736092847730, -0.837254396461143410, -0.837227054736303100, -0.837199710918394960, -0.837172365007487710, -0.837145017003649630, +-0.837117666906948890, -0.837090314717453880, -0.837062960435233210, -0.837035604060355260, -0.837008245592888220, -0.836980885032900250, -0.836953522380460390, -0.836926157635636820, +-0.836898790798497720, -0.836871421869111450, -0.836844050847546870, -0.836816677733872140, -0.836789302528155750, -0.836761925230465780, -0.836734545840871370, -0.836707164359440480, +-0.836679780786241500, -0.836652395121343260, -0.836625007364814040, -0.836597617516722350, -0.836570225577136340, -0.836542831546125080, -0.836515435423756730, -0.836488037210099680, +-0.836460636905222430, -0.836433234509193710, -0.836405830022081910, -0.836378423443955630, -0.836351014774883050, -0.836323604014933110, -0.836296191164174090, -0.836268776222674700, +-0.836241359190503130, -0.836213940067728420, -0.836186518854418750, -0.836159095550642610, -0.836131670156469050, -0.836104242671966260, -0.836076813097202830, -0.836049381432247050, +-0.836021947677168200, -0.835994511832034440, -0.835967073896914380, -0.835939633871876420, -0.835912191756989610, -0.835884747552322340, -0.835857301257943110, -0.835829852873920530, +-0.835802402400323440, -0.835774949837220450, -0.835747495184679940, -0.835720038442770540, -0.835692579611561290, -0.835665118691120590, -0.835637655681516820, -0.835610190582819270, +-0.835582723395096090, -0.835555254118416140, -0.835527782752847890, -0.835500309298460310, -0.835472833755322000, -0.835445356123501680, -0.835417876403067640, -0.835390394594089150, +-0.835362910696634710, -0.835335424710773040, -0.835307936636572550, -0.835280446474102380, -0.835252954223431150, -0.835225459884627490, -0.835197963457759980, -0.835170464942897820, +-0.835142964340109480, -0.835115461649463710, -0.835087956871029100, -0.835060450004874830, -0.835032941051069400, -0.835005430009681300, -0.834977916880780050, -0.834950401664433910, +-0.834922884360711710, -0.834895364969682090, -0.834867843491414300, -0.834840319925976960, -0.834812794273438800, -0.834785266533868420, -0.834757736707335110, -0.834730204793907470, +-0.834702670793654230, -0.834675134706644120, -0.834647596532946510, -0.834620056272629810, -0.834592513925762950, -0.834564969492414650, -0.834537422972654100, -0.834509874366550000, +-0.834482323674170970, -0.834454770895586400, -0.834427216030864890, -0.834399659080075300, -0.834372100043286320, -0.834344538920567480, -0.834316975711987150, -0.834289410417614400, +-0.834261843037517940, -0.834234273571767050, -0.834206702020430460, -0.834179128383577220, -0.834151552661275830, -0.834123974853595800, -0.834096394960605950, -0.834068812982375010, +-0.834041228918971810, -0.834013642770465750, -0.833986054536925540, -0.833958464218420130, -0.833930871815018680, -0.833903277326790040, -0.833875680753803250, -0.833848082096127040, +-0.833820481353830800, -0.833792878526983360, -0.833765273615653780, -0.833737666619910670, -0.833710057539823750, -0.833682446375461630, -0.833654833126893480, -0.833627217794187910, +-0.833599600377414540, -0.833571980876642190, -0.833544359291939930, -0.833516735623376470, -0.833489109871021430, -0.833461482034943630, -0.833433852115212150, -0.833406220111895690, +-0.833378586025063980, -0.833350949854785860, -0.833323311601130160, -0.833295671264166260, -0.833268028843963340, -0.833240384340590220, -0.833212737754115970, -0.833185089084610090, +-0.833157438332141510, -0.833129785496779300, -0.833102130578592500, -0.833074473577650520, -0.833046814494022290, -0.833019153327777100, -0.832991490078983880, -0.832963824747712020, +-0.832936157334030700, -0.832908487838008970, -0.832880816259715660, -0.832853142599220720, -0.832825466856592870, -0.832797789031901050, -0.832770109125215100, -0.832742427136603740, +-0.832714743066136460, -0.832687056913882010, -0.832659368679910080, -0.832631678364289860, -0.832603985967090400, -0.832576291488380750, -0.832548594928230630, -0.832520896286708890, +-0.832493195563885010, -0.832465492759827950, -0.832437787874607320, -0.832410080908292270, -0.832382371860951990, -0.832354660732655520, -0.832326947523472690, -0.832299232233472460, +-0.832271514862723880, -0.832243795411296780, -0.832216073879260220, -0.832188350266683470, -0.832160624573635600, -0.832132896800186430, -0.832105166946405020, -0.832077435012360640, +-0.832049700998122480, -0.832021964903760240, -0.831994226729343200, -0.831966486474940430, -0.831938744140621300, -0.831910999726455550, -0.831883253232512330, -0.831855504658860930, +-0.831827754005570630, -0.831800001272711030, -0.831772246460351530, -0.831744489568561170, -0.831716730597409800, -0.831688969546966580, -0.831661206417300900, -0.831633441208482040, +-0.831605673920579820, -0.831577904553663430, -0.831550133107802240, -0.831522359583065530, -0.831494583979523030, -0.831466806297244230, -0.831439026536298310, -0.831411244696754650, +-0.831383460778683080, -0.831355674782152780, -0.831327886707233450, -0.831300096553994060, -0.831272304322504760, -0.831244510012834610, -0.831216713625053230, -0.831188915159229770, +-0.831161114615434290, -0.831133311993736080, -0.831105507294204290, -0.831077700516908990, -0.831049891661919450, -0.831022080729305170, -0.830994267719135430, -0.830966452631480280, +-0.830938635466409000, -0.830910816223991100, -0.830882994904295960, -0.830855171507393630, -0.830827346033353290, -0.830799518482244650, -0.830771688854136880, -0.830743857149100150, +-0.830716023367203740, -0.830688187508517360, -0.830660349573110300, -0.830632509561052500, -0.830604667472413460, -0.830576823307262570, -0.830548977065669770, -0.830521128747704670, +-0.830493278353436670, -0.830465425882935150, -0.830437571336270390, -0.830409714713511770, -0.830381856014728690, -0.830353995239990870, -0.830326132389368250, -0.830298267462930340, +-0.830270400460746740, -0.830242531382886840, -0.830214660229420920, -0.830186787000418260, -0.830158911695948800, -0.830131034316081710, -0.830103154860887260, -0.830075273330434960, +-0.830047389724794190, -0.830019504044035240, -0.829991616288227490, -0.829963726457440760, -0.829935834551744470, -0.829907940571208760, -0.829880044515903250, -0.829852146385897660, +-0.829824246181261380, -0.829796343902064800, -0.829768439548377310, -0.829740533120268740, -0.829712624617808590, -0.829684714041067140, -0.829656801390113880, -0.829628886665018660, +-0.829600969865850970, -0.829573050992681080, -0.829545130045578500, -0.829517207024613180, -0.829489281929854600, -0.829461354761373060, -0.829433425519238040, -0.829405494203519390, +-0.829377560814287040, -0.829349625351610940, -0.829321687815560700, -0.829293748206206050, -0.829265806523617250, -0.829237862767863930, -0.829209916939016020, -0.829181969037142920, +-0.829154019062315230, -0.829126067014602560, -0.829098112894074650, -0.829070156700801200, -0.829042198434852610, -0.829014238096298590, -0.828986275685208880, -0.828958311201653310, +-0.828930344645702140, -0.828902376017425220, -0.828874405316892050, -0.828846432544173120, -0.828818457699338040, -0.828790480782456870, -0.828762501793599230, -0.828734520732835600, +-0.828706537600235720, -0.828678552395869410, -0.828650565119806500, -0.828622575772117510, -0.828594584352872030, -0.828566590862140020, -0.828538595299991300, -0.828510597666496370, +-0.828482597961724960, -0.828454596185747130, -0.828426592338632470, -0.828398586420451500, -0.828370578431274150, -0.828342568371170150, -0.828314556240209890, -0.828286542038463300, +-0.828258525766000340, -0.828230507422890840, -0.828202487009205290, -0.828174464525013530, -0.828146439970385620, -0.828118413345391380, -0.828090384650101320, -0.828062353884585270, +-0.828034321048913390, -0.828006286143155410, -0.827978249167382050, -0.827950210121662920, -0.827922169006068410, -0.827894125820668240, -0.827866080565532900, -0.827838033240732350, +-0.827809983846336530, -0.827781932382416040, -0.827753878849040610, -0.827725823246280520, -0.827697765574205710, -0.827669705832886680, -0.827641644022393370, -0.827613580142795960, +-0.827585514194164370, -0.827557446176569230, -0.827529376090080370, -0.827501303934768170, -0.827473229710702470, -0.827445153417953990, -0.827417075056592570, -0.827388994626688470, +-0.827360912128311640, -0.827332827561532700, -0.827304740926421810, -0.827276652223049020, -0.827248561451484290, -0.827220468611798430, -0.827192373704061510, -0.827164276728343360, +-0.827136177684714700, -0.827108076573245590, -0.827079973394006410, -0.827051868147066880, -0.827023760832498070, -0.826995651450369800, -0.826967540000752450, -0.826939426483715880, +-0.826911310899331120, -0.826883193247668010, -0.826855073528796950, -0.826826951742787970, -0.826798827889711820, -0.826770701969638640, -0.826742573982638620, -0.826714443928782020, +-0.826686311808139560, -0.826658177620781310, -0.826630041366777310, -0.826601903046198520, -0.826573762659114860, -0.826545620205596960, -0.826517475685714650, -0.826489329099538870, +-0.826461180447139900, -0.826433029728587900, -0.826404876943953040, -0.826376722093306260, -0.826348565176717730, -0.826320406194257730, -0.826292245145996530, -0.826264082032004850, +-0.826235916852353090, -0.826207749607111520, -0.826179580296350300, -0.826151408920140270, -0.826123235478551820, -0.826095059971655110, -0.826066882399520860, -0.826038702762219470, +-0.826010521059821310, -0.825982337292396670, -0.825954151460016380, -0.825925963562750720, -0.825897773600670070, -0.825869581573844820, -0.825841387482345920, -0.825813191326243420, +-0.825784993105608050, -0.825756792820509840, -0.825728590471019990, -0.825700386057208640, -0.825672179579146290, -0.825643971036903350, -0.825615760430550630, -0.825587547760158520, +-0.825559333025797540, -0.825531116227538050, -0.825502897365450910, -0.825474676439606590, -0.825446453450075390, -0.825418228396928130, -0.825390001280235430, -0.825361772100067670, +-0.825333540856495350, -0.825305307549589310, -0.825277072179420030, -0.825248834746058040, -0.825220595249573810, -0.825192353690038290, -0.825164110067521880, -0.825135864382095190, +-0.825107616633828590, -0.825079366822793150, -0.825051114949059360, -0.825022861012697730, -0.824994605013778750, -0.824966346952373470, -0.824938086828552410, -0.824909824642385820, +-0.824881560393944890, -0.824853294083300100, -0.824825025710522080, -0.824796755275681190, -0.824768482778848730, -0.824740208220094970, -0.824711931599490740, -0.824683652917106550, +-0.824655372173013320, -0.824627089367281680, -0.824598804499982350, -0.824570517571185820, -0.824542228580963150, -0.824513937529384950, -0.824485644416521830, -0.824457349242444510, +-0.824429052007223940, -0.824400752710930830, -0.824372451353635460, -0.824344147935409330, -0.824315842456322830, -0.824287534916446680, -0.824259225315851380, -0.824230913654608320, +-0.824202599932787990, -0.824174284150461230, -0.824145966307698430, -0.824117646404570970, -0.824089324441149350, -0.824061000417504520, -0.824032674333706860, -0.824004346189827760, +-0.823976015985937840, -0.823947683722107920, -0.823919349398408500, -0.823891013014910970, -0.823862674571685830, -0.823834334068803800, -0.823805991506336150, -0.823777646884353620, +-0.823749300202926920, -0.823720951462126760, -0.823692600662024430, -0.823664247802690540, -0.823635892884196140, -0.823607535906611730, -0.823579176870008700, -0.823550815774457770, +-0.823522452620029770, -0.823494087406795310, -0.823465720134826000, -0.823437350804192340, -0.823408979414965270, -0.823380605967215520, -0.823352230461014580, -0.823323852896433060, +-0.823295473273541800, -0.823267091592411630, -0.823238707853114040, -0.823210322055719650, -0.823181934200299280, -0.823153544286924220, -0.823125152315665410, -0.823096758286593570, +-0.823068362199779750, -0.823039964055295110, -0.823011563853210730, -0.822983161593597300, -0.822954757276525780, -0.822926350902067560, -0.822897942470293580, -0.822869531981274660, +-0.822841119435081650, -0.822812704831786150, -0.822784288171458880, -0.822755869454170790, -0.822727448679992920, -0.822699025848996570, -0.822670600961252660, -0.822642174016832040, +-0.822613745015806200, -0.822585313958246080, -0.822556880844222630, -0.822528445673806670, -0.822500008447069940, -0.822471569164083150, -0.822443127824917460, -0.822414684429643610, +-0.822386238978333410, -0.822357791471057590, -0.822329341907887200, -0.822300890288893300, -0.822272436614147400, -0.822243980883720420, -0.822215523097683420, -0.822187063256107460, +-0.822158601359064050, -0.822130137406624110, -0.822101671398858700, -0.822073203335839220, -0.822044733217636820, -0.822016261044322460, -0.821987786815967290, -0.821959310532642930, +-0.821930832194420310, -0.821902351801370500, -0.821873869353564660, -0.821845384851074390, -0.821816898293970640, -0.821788409682324580, -0.821759919016207260, -0.821731426295690400, +-0.821702931520845060, -0.821674434691742280, -0.821645935808453240, -0.821617434871049660, -0.821588931879602360, -0.821560426834182840, -0.821531919734861950, -0.821503410581711500, +-0.821474899374802560, -0.821446386114206060, -0.821417870799993950, -0.821389353432237180, -0.821360834011006900, -0.821332312536374290, -0.821303789008411280, -0.821275263427188710, +-0.821246735792777960, -0.821218206105250090, -0.821189674364677050, -0.821161140571129770, -0.821132604724679640, -0.821104066825397830, -0.821075526873356050, -0.821046984868625370, +-0.821018440811277280, -0.820989894701382950, -0.820961346539013980, -0.820932796324241760, -0.820904244057137240, -0.820875689737772360, -0.820847133366218170, -0.820818574942546290, +-0.820790014466827640, -0.820761451939134300, -0.820732887359537310, -0.820704320728107950, -0.820675752044917720, -0.820647181310038220, -0.820618608523540850, -0.820590033685496990, +-0.820561456795977700, -0.820532877855055130, -0.820504296862800240, -0.820475713819284750, -0.820447128724579590, -0.820418541578756930, -0.820389952381887940, -0.820361361134043790, +-0.820332767835296410, -0.820304172485717190, -0.820275575085377520, -0.820246975634348670, -0.820218374132702710, -0.820189770580510680, -0.820161164977844300, -0.820132557324774750, +-0.820103947621374060, -0.820075335867713530, -0.820046722063864530, -0.820018106209898570, -0.819989488305887580, -0.819960868351902960, -0.819932246348016090, -0.819903622294298360, +-0.819874996190821830, -0.819846368037657760, -0.819817737834877770, -0.819789105582553250, -0.819760471280756240, -0.819731834929557920, -0.819703196529029900, -0.819674556079244110, +-0.819645913580271830, -0.819617269032184900, -0.819588622435054480, -0.819559973788952730, -0.819531323093951160, -0.819502670350121140, -0.819474015557534300, -0.819445358716262670, +-0.819416699826377550, -0.819388038887950750, -0.819359375901053570, -0.819330710865758260, -0.819302043782136110, -0.819273374650258850, -0.819244703470197950, -0.819216030242025490, +-0.819187354965812960, -0.819158677641631860, -0.819129998269554240, -0.819101316849651710, -0.819072633381995760, -0.819043947866658130, -0.819015260303710750, -0.818986570693225340, +-0.818957879035273400, -0.818929185329926530, -0.818900489577257030, -0.818871791777336160, -0.818843091930235970, -0.818814390036027740, -0.818785686094783750, -0.818756980106575490, +-0.818728272071474920, -0.818699561989553400, -0.818670849860883120, -0.818642135685535790, -0.818613419463582900, -0.818584701195096630, -0.818555980880148580, -0.818527258518810700, +-0.818498534111154360, -0.818469807657251970, -0.818441079157175010, -0.818412348610995430, -0.818383616018784620, -0.818354881380615070, -0.818326144696558400, -0.818297405966686210, +-0.818268665191070330, -0.818239922369783050, -0.818211177502895960, -0.818182430590481010, -0.818153681632609600, -0.818124930629354320, -0.818096177580786680, -0.818067422486978390, +-0.818038665348001740, -0.818009906163928440, -0.817981144934830320, -0.817952381660779220, -0.817923616341847290, -0.817894848978106380, -0.817866079569628310, -0.817837308116484810, +-0.817808534618748360, -0.817779759076490480, -0.817750981489783200, -0.817722201858698260, -0.817693420183308040, -0.817664636463684370, -0.817635850699898970, -0.817607062892023780, +-0.817578273040131090, -0.817549481144292820, -0.817520687204580820, -0.817491891221066800, -0.817463093193823380, -0.817434293122922150, -0.817405491008434960, -0.817376686850434410, +-0.817347880648992000, -0.817319072404179890, -0.817290262116069920, -0.817261449784734580, -0.817232635410245490, -0.817203818992674910, -0.817175000532094460, -0.817146180028576860, +-0.817117357482193720, -0.817088532893017190, -0.817059706261119120, -0.817030877586572000, -0.817002046869447770, -0.816973214109818380, -0.816944379307755650, -0.816915542463332200, +-0.816886703576619970, -0.816857862647690670, -0.816829019676617030, -0.816800174663470770, -0.816771327608324160, -0.816742478511248930, -0.816713627372317790, -0.816684774191602570, +-0.816655918969175440, -0.816627061705108130, -0.816598202399473560, -0.816569341052343470, -0.816540477663790010, -0.816511612233885020, -0.816482744762701330, -0.816453875250310770, +-0.816425003696785500, -0.816396130102197470, -0.816367254466619400, -0.816338376790123220, -0.816309497072780780, -0.816280615314664890, -0.816251731515847510, -0.816222845676400690, +-0.816193957796396590, -0.816165067875907810, -0.816136175915006310, -0.816107281913764470, -0.816078385872254120, -0.816049487790548090, -0.816020587668718320, -0.815991685506837090, +-0.815962781304976350, -0.815933875063208910, -0.815904966781606840, -0.815876056460242300, -0.815847144099187460, -0.815818229698514920, -0.815789313258296840, -0.815760394778605510, +-0.815731474259512870, -0.815702551701091850, -0.815673627103414400, -0.815644700466552690, -0.815615771790579420, -0.815586841075566780, -0.815557908321587030, -0.815528973528712230, +-0.815500036697015210, -0.815471097826568130, -0.815442156917443370, -0.815413213969712890, -0.815384268983449730, -0.815355321958725730, -0.815326372895613600, -0.815297421794185180, +-0.815268468654513520, -0.815239513476670560, -0.815210556260728910, -0.815181597006760630, -0.815152635714838650, -0.815123672385035030, -0.815094707017421930, -0.815065739612072400, +-0.815036770169058510, -0.815007798688452630, -0.814978825170327050, -0.814949849614754700, -0.814920872021807630, -0.814891892391558350, -0.814862910724079240, -0.814833927019443020, +-0.814804941277721960, -0.814775953498988570, -0.814746963683315120, -0.814717971830774430, -0.814688977941438800, -0.814659982015380810, -0.814630984052672540, -0.814601984053387020, +-0.814572982017596650, -0.814543977945373480, -0.814514971836790670, -0.814485963691920390, -0.814456953510835250, -0.814427941293607520, -0.814398927040310030, -0.814369910751015390, +-0.814340892425795880, -0.814311872064723890, -0.814282849667872570, -0.814253825235313980, -0.814224798767120950, -0.814195770263365540, -0.814166739724121010, -0.814137707149459660, +-0.814108672539454070, -0.814079635894176530, -0.814050597213700100, -0.814021556498097270, -0.813992513747440190, -0.813963468961802160, -0.813934422141255440, -0.813905373285872650, +-0.813876322395726160, -0.813847269470889150, -0.813818214511433880, -0.813789157517433190, -0.813760098488959360, -0.813731037426085440, -0.813701974328884030, -0.813672909197427520, +-0.813643842031788630, -0.813614772832040420, -0.813585701598255160, -0.813556628330505680, -0.813527553028864370, -0.813498475693404500, -0.813469396324198350, -0.813440314921318740, +-0.813411231484838180, -0.813382146014829720, -0.813353058511365860, -0.813323968974519080, -0.813294877404362680, -0.813265783800969140, -0.813236688164411080, -0.813207590494761100, +-0.813178490792092370, -0.813149389056477380, -0.813120285287988960, -0.813091179486699510, -0.813062071652682410, -0.813032961786010140, -0.813003849886755450, -0.812974735954990920, +-0.812945619990789740, -0.812916501994224490, -0.812887381965368140, -0.812858259904292950, -0.812829135811072410, -0.812800009685778920, -0.812770881528485310, -0.812741751339264630, +-0.812712619118189710, -0.812683484865333150, -0.812654348580767570, -0.812625210264566470, -0.812596069916802330, -0.812566927537548000, -0.812537783126876080, -0.812508636684859950, +-0.812479488211572340, -0.812450337707085860, -0.812421185171473330, -0.812392030604808140, -0.812362874007162890, -0.812333715378610320, -0.812304554719223360, -0.812275392029075170, +-0.812246227308238590, -0.812217060556786110, -0.812187891774791230, -0.812158720962326660, -0.812129548119465250, -0.812100373246279710, -0.812071196342843530, -0.812042017409229320, +-0.812012836445510140, -0.811983653451758600, -0.811954468428048080, -0.811925281374451520, -0.811896092291041650, -0.811866901177891400, -0.811837708035074050, -0.811808512862662530, +-0.811779315660729580, -0.811750116429348250, -0.811720915168591790, -0.811691711878533060, -0.811662506559245100, -0.811633299210800520, -0.811604089833273030, -0.811574878426735260, +-0.811545664991260130, -0.811516449526921040, -0.811487232033790810, -0.811458012511942490, -0.811428790961448930, -0.811399567382383610, -0.811370341774819370, -0.811341114138829260, +-0.811311884474486210, -0.811282652781863620, -0.811253419061034430, -0.811224183312071580, -0.811194945535048120, -0.811165705730037550, -0.811136463897112690, -0.811107220036346720, +-0.811077974147812460, -0.811048726231583420, -0.811019476287732630, -0.810990224316332940, -0.810960970317457840, -0.810931714291180380, -0.810902456237573620, -0.810873196156710500, +-0.810843934048664620, -0.810814669913508810, -0.810785403751316470, -0.810756135562160310, -0.810726865346114050, -0.810697593103250620, -0.810668318833643210, -0.810639042537364850, +-0.810609764214488940, -0.810580483865088740, -0.810551201489237320, -0.810521917087007710, -0.810492630658473430, -0.810463342203707750, -0.810434051722783270, -0.810404759215774040, +-0.810375464682752900, -0.810346168123793010, -0.810316869538967530, -0.810287568928350080, -0.810258266292013700, -0.810228961630031770, -0.810199654942477030, -0.810170346229423520, +-0.810141035490944070, -0.810111722727112180, -0.810082407938000570, -0.810053091123683180, -0.810023772284233170, -0.809994451419723700, -0.809965128530227840, -0.809935803615819410, +-0.809906476676571450, -0.809877147712557030, -0.809847816723849980, -0.809818483710523450, -0.809789148672650730, -0.809759811610304860, -0.809730472523559670, -0.809701131412488340, +-0.809671788277164240, -0.809642443117660320, -0.809613095934050620, -0.809583746726408090, -0.809554395494806230, -0.809525042239318090, -0.809495686960017720, -0.809466329656978070, +-0.809436970330272510, -0.809407608979974440, -0.809378245606157450, -0.809348880208894950, -0.809319512788260200, -0.809290143344326360, -0.809260771877167500, -0.809231398386856650, +-0.809202022873467100, -0.809172645337072780, -0.809143265777746760, -0.809113884195562630, -0.809084500590593560, -0.809055114962913490, -0.809025727312595590, -0.808996337639713350, +-0.808966945944340040, -0.808937552226549620, -0.808908156486415340, -0.808878758724010720, -0.808849358939408790, -0.808819957132683840, -0.808790553303909030, -0.808761147453157750, +-0.808731739580503370, -0.808702329686019850, -0.808672917769780560, -0.808643503831858680, -0.808614087872328360, -0.808584669891262760, -0.808555249888735620, -0.808525827864819970, +-0.808496403819589980, -0.808466977753119040, -0.808437549665480650, -0.808408119556748180, -0.808378687426995590, -0.808349253276296360, -0.808319817104723890, -0.808290378912351670, +-0.808260938699253860, -0.808231496465503520, -0.808202052211174580, -0.808172605936340220, -0.808143157641074580, -0.808113707325451070, -0.808084254989542950, -0.808054800633424500, +-0.808025344257169100, -0.807995885860850360, -0.807966425444541560, -0.807936963008316970, -0.807907498552249970, -0.807878032076414290, -0.807848563580883190, -0.807819093065731080, +-0.807789620531031090, -0.807760145976857080, -0.807730669403282530, -0.807701190810381500, -0.807671710198227480, -0.807642227566894190, -0.807612742916455020, -0.807583256246984350, +-0.807553767558555460, -0.807524276851242170, -0.807494784125117990, -0.807465289380257080, -0.807435792616732930, -0.807406293834619040, -0.807376793033989680, -0.807347290214918360, +-0.807317785377478780, -0.807288278521744560, -0.807258769647789750, -0.807229258755688180, -0.807199745845513350, -0.807170230917338970, -0.807140713971239210, -0.807111195007287670, +-0.807081674025558190, -0.807052151026124260, -0.807022626009060160, -0.806993098974439490, -0.806963569922336200, -0.806934038852823550, -0.806904505765976170, -0.806874970661867530, +-0.806845433540571140, -0.806815894402161500, -0.806786353246712110, -0.806756810074296780, -0.806727264884989250, -0.806697717678863780, -0.806668168455993980, -0.806638617216453800, +-0.806609063960316730, -0.806579508687657380, -0.806549951398549240, -0.806520392093066140, -0.806490830771281920, -0.806461267433270850, -0.806431702079106530, -0.806402134708863020, +-0.806372565322613920, -0.806342993920433630, -0.806313420502395850, -0.806283845068574310, -0.806254267619043400, -0.806224688153876820, -0.806195106673148420, -0.806165523176932130, +-0.806135937665302230, -0.806106350138332540, -0.806076760596096900, -0.806047169038669130, -0.806017575466123740, -0.805987979878534320, -0.805958382275975050, -0.805928782658519530, +-0.805899181026242360, -0.805869577379217160, -0.805839971717517980, -0.805810364041218750, -0.805780754350393760, -0.805751142645116940, -0.805721528925462000, -0.805691913191503460, +-0.805662295443315140, -0.805632675680971080, -0.805603053904545120, -0.805573430114111750, -0.805543804309744820, -0.805514176491518350, -0.805484546659506200, -0.805454914813782950, +-0.805425280954422340, -0.805395645081498630, -0.805366007195085550, -0.805336367295257590, -0.805306725382088810, -0.805277081455653240, -0.805247435516024730, -0.805217787563277780, +-0.805188137597486420, -0.805158485618724720, -0.805128831627066500, -0.805099175622586480, -0.805069517605358610, -0.805039857575456600, -0.805010195532955160, -0.804980531477928360, +-0.804950865410450130, -0.804921197330594530, -0.804891527238436160, -0.804861855134048950, -0.804832181017507200, -0.804802504888884720, -0.804772826748256230, -0.804743146595695570, +-0.804713464431277110, -0.804683780255074810, -0.804654094067163150, -0.804624405867616410, -0.804594715656508640, -0.804565023433913670, -0.804535329199906560, -0.804505632954561120, +-0.804475934697951310, -0.804446234430151840, -0.804416532151236870, -0.804386827861280570, -0.804357121560356880, -0.804327413248540730, -0.804297702925905970, -0.804267990592527070, +-0.804238276248477880, -0.804208559893833220, -0.804178841528667140, -0.804149121153054040, -0.804119398767067730, -0.804089674370783380, -0.804059947964274710, -0.804030219547616220, +-0.804000489120881840, -0.803970756684146640, -0.803941022237484430, -0.803911285780969490, -0.803881547314676540, -0.803851806838679740, -0.803822064353053370, -0.803792319857871700, +-0.803762573353209440, -0.803732824839140660, -0.803703074315739950, -0.803673321783081150, -0.803643567241239420, -0.803613810690288810, -0.803584052130303590, -0.803554291561357940, +-0.803524528983526890, -0.803494764396884500, -0.803464997801505270, -0.803435229197463130, -0.803405458584833370, -0.803375685963689800, -0.803345911334107150, -0.803316134696159370, +-0.803286356049921490, -0.803256575395467800, -0.803226792732872340, -0.803197008062210170, -0.803167221383555560, -0.803137432696982790, -0.803107642002566240, -0.803077849300380840, +-0.803048054590500770, -0.803018257873000630, -0.802988459147954580, -0.802958658415437570, -0.802928855675524080, -0.802899050928288280, -0.802869244173804670, -0.802839435412148190, +-0.802809624643393120, -0.802779811867614050, -0.802749997084885040, -0.802720180295281470, -0.802690361498877400, -0.802660540695747100, -0.802630717885965740, -0.802600893069607580, +-0.802571066246747230, -0.802541237417458860, -0.802511406581817740, -0.802481573739898150, -0.802451738891774570, -0.802421902037521280, -0.802392063177213680, -0.802362222310925800, +-0.802332379438732370, -0.802302534560707770, -0.802272687676927050, -0.802242838787464720, -0.802212987892395150, -0.802183134991792950, -0.802153280085733170, -0.802123423174290200, +-0.802093564257538310, -0.802063703335552880, -0.802033840408408080, -0.802003975476178740, -0.801974108538939250, -0.801944239596764640, -0.801914368649729540, -0.801884495697908540, +-0.801854620741375920, -0.801824743780207070, -0.801794864814476370, -0.801764983844258540, -0.801735100869627960, -0.801705215890659790, -0.801675328907428650, -0.801645439920009250, +-0.801615548928475970, -0.801585655932903980, -0.801555760933368000, -0.801525863929942290, -0.801495964922702140, -0.801466063911722150, -0.801436160897076920, -0.801406255878841070, +-0.801376348857089860, -0.801346439831897790, -0.801316528803339480, -0.801286615771489740, -0.801256700736423740, -0.801226783698215870, -0.801196864656941070, -0.801166943612673930, +-0.801137020565489630, -0.801107095515462770, -0.801077168462668190, -0.801047239407180480, -0.801017308349074810, -0.800987375288426010, -0.800957440225308680, -0.800927503159797440, +-0.800897564091967880, -0.800867623021894290, -0.800837679949651380, -0.800807734875314540, -0.800777787798958360, -0.800747838720657690, -0.800717887640487240, -0.800687934558522270, +-0.800657979474837520, -0.800628022389507700, -0.800598063302607740, -0.800568102214212820, -0.800538139124397530, -0.800508174033236930, -0.800478206940805740, -0.800448237847179220, +-0.800418266752432110, -0.800388293656639330, -0.800358318559875600, -0.800328341462216320, -0.800298362363736190, -0.800268381264509830, -0.800238398164612840, -0.800208413064119830, +-0.800178425963105840, -0.800148436861645500, -0.800118445759814280, -0.800088452657686910, -0.800058457555338550, -0.800028460452843700, -0.799998461350277970, -0.799968460247716060, +-0.799938457145233040, -0.799908452042903620, -0.799878444940803290, -0.799848435839006890, -0.799818424737589350, -0.799788411636625510, -0.799758396536190960, -0.799728379436360330, +-0.799698360337208540, -0.799668339238811090, -0.799638316141242810, -0.799608291044578760, -0.799578263948893750, -0.799548234854263300, -0.799518203760762210, -0.799488170668465670, +-0.799458135577448380, -0.799428098487786070, -0.799398059399553550, -0.799368018312825780, -0.799337975227677800, -0.799307930144185110, -0.799277883062422530, -0.799247833982465350, +-0.799217782904388270, -0.799187729828267020, -0.799157674754176430, -0.799127617682191650, -0.799097558612387520, -0.799067497544839860, -0.799037434479623390, -0.799007369416813050, +-0.798977302356484560, -0.798947233298712870, -0.798917162243573010, -0.798887089191140040, -0.798857014141489570, -0.798826937094696650, -0.798796858050836330, -0.798766777009983550, +-0.798736693972214250, -0.798706608937603040, -0.798676521906225400, -0.798646432878156180, -0.798616341853471080, -0.798586248832245270, -0.798556153814553690, -0.798526056800471510, +-0.798495957790074540, -0.798465856783437510, -0.798435753780635690, -0.798405648781744800, -0.798375541786839670, -0.798345432795995680, -0.798315321809287880, -0.798285208826792100, +-0.798255093848583290, -0.798224976874736700, -0.798194857905327400, -0.798164736940431220, -0.798134613980123200, -0.798104489024478610, -0.798074362073572630, -0.798044233127480960, +-0.798014102186278660, -0.797983969250041230, -0.797953834318843480, -0.797923697392761480, -0.797893558471870160, -0.797863417556244790, -0.797833274645961100, -0.797803129741094240, +-0.797772982841719490, -0.797742833947912010, -0.797712683059747850, -0.797682530177301840, -0.797652375300649590, -0.797622218429866030, -0.797592059565027320, -0.797561898706208420, +-0.797531735853484690, -0.797501571006931420, -0.797471404166624540, -0.797441235332639110, -0.797411064505050620, -0.797380891683934110, -0.797350716869365650, -0.797320540061420500, +-0.797290361260173610, -0.797260180465701240, -0.797229997678078340, -0.797199812897380400, -0.797169626123682700, -0.797139437357061160, -0.797109246597591080, -0.797079053845347830, +-0.797048859100406790, -0.797018662362843800, -0.796988463632734120, -0.796958262910153260, -0.796928060195176590, -0.796897855487879950, -0.796867648788338710, -0.796837440096628380, +-0.796807229412824110, -0.796777016737002080, -0.796746802069237430, -0.796716585409605880, -0.796686366758182610, -0.796656146115043650, -0.796625923480264290, -0.796595698853919900, +-0.796565472236086420, -0.796535243626839360, -0.796505013026254200, -0.796474780434406230, -0.796444545851371590, -0.796414309277225560, -0.796384070712043760, -0.796353830155901440, +-0.796323587608874890, -0.796293343071039380, -0.796263096542470520, -0.796232848023243680, -0.796202597513434920, -0.796172345013119730, -0.796142090522373610, -0.796111834041271950, +-0.796081575569891120, -0.796051315108306290, -0.796021052656592840, -0.795990788214827050, -0.795960521783084410, -0.795930253361440300, -0.795899982949970440, -0.795869710548750780, +-0.795839436157856910, -0.795809159777364330, -0.795778881407348760, -0.795748601047886140, -0.795718318699051960, -0.795688034360922170, -0.795657748033571920, -0.795627459717077600, +-0.795597169411514590, -0.795566877116958620, -0.795536582833485270, -0.795506286561170730, -0.795475988300090360, -0.795445688050319900, -0.795415385811935380, -0.795385081585012530, +-0.795354775369626840, -0.795324467165854030, -0.795294156973770260, -0.795263844793451140, -0.795233530624972370, -0.795203214468409470, -0.795172896323838920, -0.795142576191335990, +-0.795112254070976740, -0.795081929962836550, -0.795051603866991810, -0.795021275783518000, -0.794990945712491070, -0.794960613653986510, -0.794930279608080600, -0.794899943574849050, +-0.794869605554367700, -0.794839265546712030, -0.794808923551958420, -0.794778579570182500, -0.794748233601459960, -0.794717885645866980, -0.794687535703479390, -0.794657183774372890, +-0.794626829858623210, -0.794596473956306730, -0.794566116067499050, -0.794535756192276010, -0.794505394330713320, -0.794475030482887480, -0.794444664648874090, -0.794414296828748980, +-0.794383927022587870, -0.794353555230467250, -0.794323181452462720, -0.794292805688650240, -0.794262427939105400, -0.794232048203904810, -0.794201666483124180, -0.794171282776839020, +-0.794140897085125920, -0.794110509408060610, -0.794080119745719020, -0.794049728098176870, -0.794019334465510650, -0.793988938847796090, -0.793958541245109230, -0.793928141657525790, +-0.793897740085122150, -0.793867336527974250, -0.793836930986157930, -0.793806523459749000, -0.793776113948824080, -0.793745702453458880, -0.793715288973729450, -0.793684873509711510, +-0.793654456061481660, -0.793624036629115630, -0.793593615212689230, -0.793563191812279190, -0.793532766427961000, -0.793502339059811050, -0.793471909707904820, -0.793441478372319150, +-0.793411045053129870, -0.793380609750412910, -0.793350172464244110, -0.793319733194700280, -0.793289291941856930, -0.793258848705790550, -0.793228403486576640, -0.793197956284292020, +-0.793167507099012510, -0.793137055930814290, -0.793106602779773180, -0.793076147645965680, -0.793045690529467940, -0.793015231430355680, -0.792984770348705630, -0.792954307284593600, +-0.792923842238095870, -0.792893375209288150, -0.792862906198247400, -0.792832435205049310, -0.792801962229770170, -0.792771487272485810, -0.792741010333272930, -0.792710531412207600, +-0.792680050509366070, -0.792649567624823970, -0.792619082758658330, -0.792588595910944880, -0.792558107081760000, -0.792527616271179620, -0.792497123479280360, -0.792466628706138380, +-0.792436131951829830, -0.792405633216430650, -0.792375132500017680, -0.792344629802666840, -0.792314125124454200, -0.792283618465456470, -0.792253109825749700, -0.792222599205410160, +-0.792192086604513900, -0.792161572023137640, -0.792131055461357540, -0.792100536919249750, -0.792070016396890340, -0.792039493894356130, -0.792008969411723160, -0.791978442949067830, +-0.791947914506466180, -0.791917384083994920, -0.791886851681730230, -0.791856317299748370, -0.791825780938125500, -0.791795242596938450, -0.791764702276263280, -0.791734159976176020, +-0.791703615696753740, -0.791673069438072360, -0.791642521200208280, -0.791611970983237660, -0.791581418787237420, -0.791550864612283630, -0.791520308458452670, -0.791489750325820580, +-0.791459190214464540, -0.791428628124460350, -0.791398064055884750, -0.791367498008813560, -0.791336929983324060, -0.791306359979492170, -0.791275787997394290, -0.791245214037106790, +-0.791214638098706510, -0.791184060182269610, -0.791153480287872250, -0.791122898415591580, -0.791092314565503550, -0.791061728737684770, -0.791031140932211390, -0.791000551149160460, +-0.790969959388608030, -0.790939365650630830, -0.790908769935305010, -0.790878172242707400, -0.790847572572914380, -0.790816970926002450, -0.790786367302047880, -0.790755761701127600, +-0.790725154123317900, -0.790694544568695370, -0.790663933037336180, -0.790633319529317370, -0.790602704044715330, -0.790572086583606560, -0.790541467146067210, -0.790510845732174560, +-0.790480222342004660, -0.790449596975634110, -0.790418969633139730, -0.790388340314597930, -0.790357709020085290, -0.790327075749678090, -0.790296440503453490, -0.790265803281487880, +-0.790235164083857630, -0.790204522910639250, -0.790173879761909780, -0.790143234637745720, -0.790112587538223550, -0.790081938463419560, -0.790051287413411020, -0.790020634388274300, +-0.789989979388086020, -0.789959322412922440, -0.789928663462860840, -0.789898002537977590, -0.789867339638349100, -0.789836674764052500, -0.789806007915164310, -0.789775339091761010, +-0.789744668293919090, -0.789713995521715730, -0.789683320775227400, -0.789652644054530840, -0.789621965359702300, -0.789591284690819300, -0.789560602047957970, -0.789529917431195050, +-0.789499230840607140, -0.789468542276271500, -0.789437851738264420, -0.789407159226662710, -0.789376464741542880, -0.789345768282982090, -0.789315069851056930, -0.789284369445843790, +-0.789253667067420060, -0.789222962715862120, -0.789192256391246790, -0.789161548093650470, -0.789130837823150630, -0.789100125579823670, -0.789069411363746420, -0.789038695174995360, +-0.789007977013647780, -0.788977256879780380, -0.788946534773469770, -0.788915810694792550, -0.788885084643826010, -0.788854356620646850, -0.788823626625331790, -0.788792894657957430, +-0.788762160718600950, -0.788731424807339150, -0.788700686924248550, -0.788669947069406520, -0.788639205242889660, -0.788608461444774700, -0.788577715675138350, -0.788546967934057990, +-0.788516218221610110, -0.788485466537871770, -0.788454712882919460, -0.788423957256830680, -0.788393199659682020, -0.788362440091550320, -0.788331678552512290, -0.788300915042645320, +-0.788270149562026010, -0.788239382110731410, -0.788208612688838020, -0.788177841296423430, -0.788147067933564150, -0.788116292600337220, -0.788085515296819360, -0.788054736023087950, +-0.788023954779219720, -0.787993171565291250, -0.787962386381380160, -0.787931599227563170, -0.787900810103917100, -0.787870019010518790, -0.787839225947445710, -0.787808430914774480, +-0.787777633912582260, -0.787746834940945660, -0.787716033999942280, -0.787685231089648720, -0.787654426210142140, -0.787623619361499160, -0.787592810543797480, -0.787561999757113830, +-0.787531187001525020, -0.787500372277108120, -0.787469555583940490, -0.787438736922098980, -0.787407916291660400, -0.787377093692702260, -0.787346269125301370, -0.787315442589534790, +-0.787284614085479340, -0.787253783613212740, -0.787222951172811490, -0.787192116764353080, -0.787161280387914000, -0.787130442043571970, -0.787099601731403810, -0.787068759451486690, +-0.787037915203897430, -0.787007068988713530, -0.786976220806012150, -0.786945370655870110, -0.786914518538364360, -0.786883664453572610, -0.786852808401571680, -0.786821950382438520, +-0.786791090396250610, -0.786760228443085130, -0.786729364523019000, -0.786698498636129170, -0.786667630782493470, -0.786636760962188600, -0.786605889175291840, -0.786575015421880130, +-0.786544139702031080, -0.786513262015821720, -0.786482382363329240, -0.786451500744630550, -0.786420617159803270, -0.786389731608924560, -0.786358844092071460, -0.786327954609321030, +-0.786297063160750880, -0.786266169746438150, -0.786235274366460010, -0.786204377020893410, -0.786173477709816050, -0.786142576433305100, -0.786111673191437380, -0.786080767984290830, +-0.786049860811942280, -0.786018951674469110, -0.785988040571948270, -0.785957127504457560, -0.785926212472074170, -0.785895295474875130, -0.785864376512937610, -0.785833455586339440, +-0.785802532695157650, -0.785771607839469420, -0.785740681019352020, -0.785709752234883150, -0.785678821486139880, -0.785647888773199580, -0.785616954096139190, -0.785586017455036870, +-0.785555078849969330, -0.785524138281013970, -0.785493195748248390, -0.785462251251749950, -0.785431304791595840, -0.785400356367863210, -0.785369405980629880, -0.785338453629973120, +-0.785307499315970210, -0.785276543038698200, -0.785245584798235250, -0.785214624594658180, -0.785183662428044720, -0.785152698298471670, -0.785121732206017220, -0.785090764150758510, +-0.785059794132772830, -0.785028822152137320, -0.784997848208930150, -0.784966872303228260, -0.784935894435108920, -0.784904914604650170, -0.784873932811929190, -0.784842949057023230, +-0.784811963340009690, -0.784780975660966610, -0.784749986019970920, -0.784718994417100360, -0.784688000852432070, -0.784657005326043990, -0.784626007838013400, -0.784595008388417890, +-0.784564006977334530, -0.784533003604841350, -0.784501998271015740, -0.784470990975935090, -0.784439981719676770, -0.784408970502318610, -0.784377957323938220, -0.784346942184612760, +-0.784315925084419830, -0.784284906023437260, -0.784253885001742420, -0.784222862019412600, -0.784191837076525950, -0.784160810173159750, -0.784129781309391370, -0.784098750485298420, +-0.784067717700958730, -0.784036682956449900, -0.784005646251849210, -0.783974607587234250, -0.783943566962682970, -0.783912524378272750, -0.783881479834081300, -0.783850433330185890, +-0.783819384866664580, -0.783788334443594860, -0.783757282061054330, -0.783726227719120260, -0.783695171417870930, -0.783664113157383600, -0.783633052937735890, -0.783601990759005720, +-0.783570926621270480, -0.783539860524608000, -0.783508792469095660, -0.783477722454811510, -0.783446650481833150, -0.783415576550238080, -0.783384500660103790, -0.783353422811508660, +-0.783322343004529850, -0.783291261239245200, -0.783260177515732070, -0.783229091834068860, -0.783198004194332940, -0.783166914596601930, -0.783135823040953420, -0.783104729527465570, +-0.783073634056215990, -0.783042536627281960, -0.783011437240741850, -0.782980335896673150, -0.782949232595153700, -0.782918127336260870, -0.782887020120072940, -0.782855910946667510, +-0.782824799816122300, -0.782793686728514790, -0.782762571683923270, -0.782731454682425440, -0.782700335724098920, -0.782669214809021300, -0.782638091937270960, -0.782606967108925300, +-0.782575840324062360, -0.782544711582759400, -0.782513580885095040, -0.782482448231146650, -0.782451313620991850, -0.782420177054709120, -0.782389038532375960, -0.782357898054070080, +-0.782326755619869310, -0.782295611229851810, -0.782264464884095400, -0.782233316582677810, -0.782202166325676520, -0.782171014113170250, -0.782139859945236380, -0.782108703821952860, +-0.782077545743397270, -0.782046385709648130, -0.782015223720783030, -0.781984059776879900, -0.781952893878016250, -0.781921726024270790, -0.781890556215720900, -0.781859384452444630, +-0.781828210734519690, -0.781797035062024470, -0.781765857435036570, -0.781734677853633820, -0.781703496317894710, -0.781672312827896840, -0.781641127383718160, -0.781609939985436370, +-0.781578750633129980, -0.781547559326876810, -0.781516366066754680, -0.781485170852841300, -0.781453973685215300, -0.781422774563954480, -0.781391573489136570, -0.781360370460839610, +-0.781329165479141880, -0.781297958544121320, -0.781266749655855740, -0.781235538814423090, -0.781204326019901860, -0.781173111272369880, -0.781141894571904750, -0.781110675918585180, +-0.781079455312488900, -0.781048232753694060, -0.781017008242278380, -0.780985781778320340, -0.780954553361897900, -0.780923322993089090, -0.780892090671971740, -0.780860856398624350, +-0.780829620173124850, -0.780798381995551290, -0.780767141865981510, -0.780735899784494200, -0.780704655751167100, -0.780673409766078350, -0.780642161829305790, -0.780610911940928130, +-0.780579660101023200, -0.780548406309668820, -0.780517150566943710, -0.780485892872925690, -0.780454633227692930, -0.780423371631323360, -0.780392108083895700, -0.780360842585487660, +-0.780329575136177510, -0.780298305736043200, -0.780267034385163430, -0.780235761083616030, -0.780204485831479280, -0.780173208628830990, -0.780141929475749900, -0.780110648372314030, +-0.780079365318601560, -0.780048080314690420, -0.780016793360659320, -0.779985504456586210, -0.779954213602549460, -0.779922920798626800, -0.779891626044897150, -0.779860329341438340, +-0.779829030688328540, -0.779797730085646460, -0.779766427533469920, -0.779735123031877420, -0.779703816580946780, -0.779672508180756950, -0.779641197831385860, -0.779609885532911660, +-0.779578571285412520, -0.779547255088967270, -0.779515936943653840, -0.779484616849550620, -0.779453294806735530, -0.779421970815287410, -0.779390644875284530, -0.779359316986804940, +-0.779327987149926790, -0.779296655364728920, -0.779265321631289480, -0.779233985949686400, -0.779202648319998640, -0.779171308742304340, -0.779139967216681660, -0.779108623743208880, +-0.779077278321964720, -0.779045930953027430, -0.779014581636475300, -0.778983230372386480, -0.778951877160839800, -0.778920522001913420, -0.778889164895685830, -0.778857805842234960, +-0.778826444841639880, -0.778795081893978610, -0.778763716999329780, -0.778732350157771310, -0.778700981369382150, -0.778669610634240670, -0.778638237952424930, -0.778606863324013740, +-0.778575486749085390, -0.778544108227718470, -0.778512727759990810, -0.778481345345981790, -0.778449960985769240, -0.778418574679431870, -0.778387186427047850, -0.778355796228696000, +-0.778324404084454800, -0.778293009994402540, -0.778261613958617480, -0.778230215977178560, -0.778198816050164280, -0.778167414177652890, -0.778136010359722570, -0.778104604596452700, +-0.778073196887921200, -0.778041787234206470, -0.778010375635387440, -0.777978962091542600, -0.777947546602750340, -0.777916129169088920, -0.777884709790637400, -0.777853288467474150, +-0.777821865199677660, -0.777790439987326330, -0.777759012830499090, -0.777727583729274310, -0.777696152683730600, -0.777664719693946240, -0.777633284760000270, -0.777601847881971180, +-0.777570409059937460, -0.777538968293977390, -0.777507525584170240, -0.777476080930594280, -0.777444634333328110, -0.777413185792450000, -0.777381735308039220, -0.777350282880174160, +-0.777318828508933190, -0.777287372194395250, -0.777255913936638950, -0.777224453735742890, -0.777192991591785450, -0.777161527504845790, -0.777130061475002300, -0.777098593502333570, +-0.777067123586918210, -0.777035651728835260, -0.777004177928163120, -0.776972702184980710, -0.776941224499366090, -0.776909744871398740, -0.776878263301157060, -0.776846779788719740, +-0.776815294334165190, -0.776783806937572650, -0.776752317599020530, -0.776720826318587410, -0.776689333096352460, -0.776657837932394290, -0.776626340826791380, -0.776594841779622460, +-0.776563340790966670, -0.776531837860902520, -0.776500332989508710, -0.776468826176863970, -0.776437317423047220, -0.776405806728137300, -0.776374294092212920, -0.776342779515352470, +-0.776311262997635310, -0.776279744539140060, -0.776248224139945320, -0.776216701800129920, -0.776185177519772900, -0.776153651298952970, -0.776122123137748640, -0.776090593036239400, +-0.776059060994503500, -0.776027527012620010, -0.775995991090667530, -0.775964453228725200, -0.775932913426871760, -0.775901371685186140, -0.775869828003746710, -0.775838282382632970, +-0.775806734821923640, -0.775775185321697420, -0.775743633882032930, -0.775712080503009660, -0.775680525184706200, -0.775648967927201390, -0.775617408730573940, -0.775585847594903120, +-0.775554284520267870, -0.775522719506746780, -0.775491152554418580, -0.775459583663362870, -0.775428012833658140, -0.775396440065383220, -0.775364865358617370, -0.775333288713439320, +-0.775301710129928210, -0.775270129608162440, -0.775238547148221600, -0.775206962750184410, -0.775175376414129810, -0.775143788140136510, -0.775112197928284010, -0.775080605778651010, +-0.775049011691316570, -0.775017415666359180, -0.774985817703858660, -0.774954217803893510, -0.774922615966542880, -0.774891012191885390, -0.774859406480000620, -0.774827798830967420, +-0.774796189244864380, -0.774764577721771210, -0.774732964261766520, -0.774701348864929470, -0.774669731531338780, -0.774638112261073930, -0.774606491054213860, -0.774574867910837630, +-0.774543242831023940, -0.774511615814852390, -0.774479986862401710, -0.774448355973751170, -0.774416723148979470, -0.774385088388166220, -0.774353451691390250, -0.774321813058730600, +-0.774290172490266220, -0.774258529986076690, -0.774226885546240750, -0.774195239170837320, -0.774163590859946240, -0.774131940613645990, -0.774100288432015950, -0.774068634315134950, +-0.774036978263082600, -0.774005320275937820, -0.773973660353779680, -0.773941998496687210, -0.773910334704740020, -0.773878668978016940, -0.773847001316597230, -0.773815331720559610, +-0.773783660189984120, -0.773751986724949380, -0.773720311325534650, -0.773688633991818970, -0.773656954723881850, -0.773625273521802440, -0.773593590385659560, -0.773561905315532930, +-0.773530218311501590, -0.773498529373644720, -0.773466838502041230, -0.773435145696770850, -0.773403450957912630, -0.773371754285545940, -0.773340055679749390, -0.773308355140603030, +-0.773276652668185790, -0.773244948262577060, -0.773213241923855540, -0.773181533652101180, -0.773149823447393030, -0.773118111309810230, -0.773086397239431950, -0.773054681236338030, +-0.773022963300607380, -0.772991243432319170, -0.772959521631552680, -0.772927797898387730, -0.772896072232903240, -0.772864344635178280, -0.772832615105292660, -0.772800883643325550, +-0.772769150249356330, -0.772737414923463820, -0.772705677665728170, -0.772673938476228230, -0.772642197355043470, -0.772610454302252950, -0.772578709317936600, -0.772546962402173460, +-0.772515213555042930, -0.772483462776624050, -0.772451710066996760, -0.772419955426240310, -0.772388198854433880, -0.772356440351656740, -0.772324679917988700, -0.772292917553508930, +-0.772261153258296700, -0.772229387032431820, -0.772197618875993470, -0.772165848789061030, -0.772134076771713750, -0.772102302824031580, -0.772070526946093570, -0.772038749137979320, +-0.772006969399767870, -0.771975187731539280, -0.771943404133372810, -0.771911618605347740, -0.771879831147543330, -0.771848041760039630, -0.771816250442915910, -0.771784457196251440, +-0.771752662020125600, -0.771720864914618440, -0.771689065879809010, -0.771657264915776690, -0.771625462022601520, -0.771593657200362770, -0.771561850449139720, -0.771530041769011850, +-0.771498231160059110, -0.771466418622360760, -0.771434604155996410, -0.771402787761045320, -0.771370969437587430, -0.771339149185702230, -0.771307327005469110, -0.771275502896967450, +-0.771243676860277170, -0.771211848895477780, -0.771180019002648760, -0.771148187181869500, -0.771116353433219940, -0.771084517756779550, -0.771052680152627850, -0.771020840620844190, +-0.770988999161508650, -0.770957155774700700, -0.770925310460499500, -0.770893463218985330, -0.770861614050237560, -0.770829762954335700, -0.770797909931359100, -0.770766054981388060, +-0.770734198104501940, -0.770702339300780250, -0.770670478570302460, -0.770638615913148750, -0.770606751329398490, -0.770574884819131390, -0.770543016382426730, -0.770511146019364880, +-0.770479273730025120, -0.770447399514487150, -0.770415523372830480, -0.770383645305135260, -0.770351765311480970, -0.770319883391946900, -0.770287999546613420, -0.770256113775559910, +-0.770224226078866200, -0.770192336456611560, -0.770160444908876470, -0.770128551435740220, -0.770096656037282500, -0.770064758713582930, -0.770032859464721780, -0.770000958290778410, +-0.769969055191832670, -0.769937150167964050, -0.769905243219252800, -0.769873334345778430, -0.769841423547620750, -0.769809510824859270, -0.769777596177574240, -0.769745679605845280, +-0.769713761109751760, -0.769681840689374170, -0.769649918344791910, -0.769617994076085000, -0.769586067883332610, -0.769554139766615460, -0.769522209726013040, -0.769490277761604950, +-0.769458343873470900, -0.769426408061691380, -0.769394470326345780, -0.769362530667513920, -0.769330589085275520, -0.769298645579711060, -0.769266700150899820, -0.769234752798921840, +-0.769202803523856730, -0.769170852325784970, -0.769138899204785950, -0.769106944160939500, -0.769074987194325880, -0.769043028305024910, -0.769011067493116210, -0.768979104758679700, +-0.768947140101795660, -0.768915173522543790, -0.768883205021003930, -0.768851234597255790, -0.768819262251379860, -0.768787287983455860, -0.768755311793563490, -0.768723333681782690, +-0.768691353648193740, -0.768659371692876460, -0.768627387815910780, -0.768595402017376310, -0.768563414297353640, -0.768531424655922390, -0.768499433093162600, -0.768467439609153870, +-0.768435444203976910, -0.768403446877711340, -0.768371447630436850, -0.768339446462234070, -0.768307443373182570, -0.768275438363362540, -0.768243431432853670, -0.768211422581736470, +-0.768179411810090640, -0.768147399117996340, -0.768115384505533290, -0.768083367972781980, -0.768051349519822350, -0.768019329146734320, -0.767987306853597620, -0.767955282640493060, +-0.767923256507500150, -0.767891228454699150, -0.767859198482169880, -0.767827166589992840, -0.767795132778247850, -0.767763097047014730, -0.767731059396374200, -0.767699019826405980, +-0.767666978337190220, -0.767634934928806740, -0.767602889601336270, -0.767570842354858510, -0.767538793189453620, -0.767506742105201530, -0.767474689102182860, -0.767442634180477420, +-0.767410577340165490, -0.767378518581326660, -0.767346457904041990, -0.767314395308391070, -0.767282330794454290, -0.767250264362311250, -0.767218196012042890, -0.767186125743729020, +-0.767154053557449590, -0.767121979453285310, -0.767089903431316110, -0.767057825491622050, -0.767025745634283270, -0.766993663859380280, -0.766961580166993230, -0.766929494557202160, +-0.766897407030087130, -0.766865317585728850, -0.766833226224207240, -0.766801132945602590, -0.766769037749994830, -0.766736940637464780, -0.766704841608092380, -0.766672740661957790, +-0.766640637799141160, -0.766608533019723200, -0.766576426323783870, -0.766544317711403520, -0.766512207182662110, -0.766480094737640340, -0.766447980376418480, -0.766415864099076360, +-0.766383745905694800, -0.766351625796353850, -0.766319503771133890, -0.766287379830114970, -0.766255253973377790, -0.766223126201002410, -0.766190996513069320, -0.766158864909658450, +-0.766126731390850630, -0.766094595956726130, -0.766062458607364990, -0.766030319342847490, -0.765998178163254440, -0.765966035068666010, -0.765933890059162460, -0.765901743134823840, +-0.765869594295731200, -0.765837443541964590, -0.765805290873604050, -0.765773136290730630, -0.765740979793424260, -0.765708821381765550, -0.765676661055834430, -0.765644498815711950, +-0.765612334661478270, -0.765580168593213760, -0.765548000610998480, -0.765515830714913470, -0.765483658905039000, -0.765451485181455340, -0.765419309544242640, -0.765387131993481960, +-0.765354952529253450, -0.765322771151637490, -0.765290587860714470, -0.765258402656565200, -0.765226215539269840, -0.765194026508908780, -0.765161835565562940, -0.765129642709312390, +-0.765097447940237820, -0.765065251258419290, -0.765033052663937950, -0.765000852156874080, -0.764968649737307940, -0.764936445405319910, -0.764904239160991150, -0.764872031004401710, +-0.764839820935632190, -0.764807608954762850, -0.764775395061874750, -0.764743179257048160, -0.764710961540363670, -0.764678741911901440, -0.764646520371742630, -0.764614296919967630, +-0.764582071556656470, -0.764549844281890540, -0.764517615095749890, -0.764485383998315230, -0.764453150989666930, -0.764420916069885940, -0.764388679239052630, -0.764356440497247710, +-0.764324199844551360, -0.764291957281044710, -0.764259712806808270, -0.764227466421922520, -0.764195218126467850, -0.764162967920525400, -0.764130715804175580, -0.764098461777498850, +-0.764066205840575720, -0.764033947993487450, -0.764001688236314200, -0.763969426569136800, -0.763937162992035510, -0.763904897505091610, -0.763872630108385580, -0.763840360801997580, +-0.763808089586008990, -0.763775816460500080, -0.763743541425551790, -0.763711264481244270, -0.763678985627658790, -0.763646704864875960, -0.763614422192976370, -0.763582137612040410, +-0.763549851122149350, -0.763517562723383780, -0.763485272415824200, -0.763452980199551210, -0.763420686074645970, -0.763388390041189080, -0.763356092099261250, -0.763323792248942870, +-0.763291490490315310, -0.763259186823458950, -0.763226881248454390, -0.763194573765382910, -0.763162264374325110, -0.763129953075361470, -0.763097639868572710, -0.763065324754040210, +-0.763033007731844350, -0.763000688802065950, -0.762968367964785620, -0.762936045220084620, -0.762903720568043450, -0.762871394008743040, -0.762839065542263770, -0.762806735168687240, +-0.762774402888093840, -0.762742068700564380, -0.762709732606179470, -0.762677394605020600, -0.762645054697168150, -0.762612712882702830, -0.762580369161705910, -0.762548023534258210, +-0.762515676000440350, -0.762483326560333130, -0.762450975214017830, -0.762418621961575060, -0.762386266803085740, -0.762353909738630490, -0.762321550768290670, -0.762289189892147110, +-0.762256827110280530, -0.762224462422771530, -0.762192095829701710, -0.762159727331151670, -0.762127356927202240, -0.762094984617934120, -0.762062610403428930, -0.762030234283767150, +-0.761997856259029830, -0.761965476329297560, -0.761933094494651850, -0.761900710755173520, -0.761868325110943050, -0.761835937562042040, -0.761803548108551110, -0.761771156750551400, +-0.761738763488123530, -0.761706368321349080, -0.761673971250308560, -0.761641572275083220, -0.761609171395753680, -0.761576768612401420, -0.761544363925107270, -0.761511957333952270, +-0.761479548839017030, -0.761447138440383140, -0.761414726138131550, -0.761382311932343070, -0.761349895823098530, -0.761317477810479540, -0.761285057894566800, -0.761252636075441250, +-0.761220212353184270, -0.761187786727876790, -0.761155359199599870, -0.761122929768434320, -0.761090498434461640, -0.761058065197762760, -0.761025630058418720, -0.760993193016510250, +-0.760960754072119160, -0.760928313225326170, -0.760895870476212430, -0.760863425824858660, -0.760830979271346690, -0.760798530815757210, -0.760766080458171400, -0.760733628198670080, +-0.760701174037335060, -0.760668717974247070, -0.760636260009487030, -0.760603800143136550, -0.760571338375276570, -0.760538874705988350, -0.760506409135352610, -0.760473941663451060, +-0.760441472290364740, -0.760409001016174700, -0.760376527840961880, -0.760344052764807990, -0.760311575787794070, -0.760279096910001170, -0.760246616131510230, -0.760214133452402960, +-0.760181648872760410, -0.760149162392663840, -0.760116674012193960, -0.760084183731432720, -0.760051691550461040, -0.760019197469359750, -0.759986701488210900, -0.759954203607095200, +-0.759921703826093920, -0.759889202145288210, -0.759856698564759790, -0.759824193084589590, -0.759791685704858890, -0.759759176425648720, -0.759726665247040910, -0.759694152169116400, +-0.759661637191956450, -0.759629120315642230, -0.759596601540255430, -0.759564080865877230, -0.759531558292588670, -0.759499033820471010, -0.759466507449606090, -0.759433979180074940, +-0.759401449011958720, -0.759368916945338590, -0.759336382980296490, -0.759303847116913460, -0.759271309355270540, -0.759238769695449680, -0.759206228137531800, -0.759173684681598290, +-0.759141139327730310, -0.759108592076009890, -0.759076042926517980, -0.759043491879335840, -0.759010938934544740, -0.758978384092226620, -0.758945827352462520, -0.758913268715333820, +-0.758880708180921680, -0.758848145749308150, -0.758815581420574150, -0.758783015194801180, -0.758750447072070400, -0.758717877052463850, -0.758685305136062470, -0.758652731322947640, +-0.758620155613201290, -0.758587578006904570, -0.758554998504138880, -0.758522417104985360, -0.758489833809526060, -0.758457248617842250, -0.758424661530015310, -0.758392072546126390, +-0.758359481666257660, -0.758326888890490160, -0.758294294218905480, -0.758261697651584690, -0.758229099188610030, -0.758196498830062570, -0.758163896576023900, -0.758131292426575180, +-0.758098686381798450, -0.758066078441775200, -0.758033468606586270, -0.758000856876314020, -0.757968243251039730, -0.757935627730844660, -0.757903010315810310, -0.757870391006018720, +-0.757837769801551260, -0.757805146702489220, -0.757772521708914070, -0.757739894820907980, -0.757707266038552100, -0.757674635361928030, -0.757642002791117040, -0.757609368326201400, +-0.757576731967262380, -0.757544093714381470, -0.757511453567640050, -0.757478811527120270, -0.757446167592903400, -0.757413521765071260, -0.757380874043704910, -0.757348224428886720, +-0.757315572920697950, -0.757282919519220000, -0.757250264224535010, -0.757217607036724360, -0.757184947955869660, -0.757152286982052390, -0.757119624115354610, -0.757086959355857790, +-0.757054292703643550, -0.757021624158793260, -0.756988953721389300, -0.756956281391512940, -0.756923607169245780, -0.756890931054669420, -0.756858253047866030, -0.756825573148916850, +-0.756792891357903950, -0.756760207674908370, -0.756727522100012600, -0.756694834633298120, -0.756662145274846100, -0.756629454024739130, -0.756596760883058490, -0.756564065849886000, +-0.756531368925303040, -0.756498670109391870, -0.756465969402234100, -0.756433266803911320, -0.756400562314505140, -0.756367855934097830, -0.756335147662770990, -0.756302437500606110, +-0.756269725447684890, -0.756237011504089730, -0.756204295669901990, -0.756171577945203510, -0.756138858330075880, -0.756106136824601260, -0.756073413428861360, -0.756040688142937570, +-0.756007960966912470, -0.755975231900867350, -0.755942500944884130, -0.755909768099044530, -0.755877033363430710, -0.755844296738124250, -0.755811558223207220, -0.755778817818760880, +-0.755746075524867830, -0.755713331341609560, -0.755680585269067890, -0.755647837307324540, -0.755615087456461890, -0.755582335716561530, -0.755549582087705400, -0.755516826569974880, +-0.755484069163452680, -0.755451309868220290, -0.755418548684359310, -0.755385785611952240, -0.755353020651080680, -0.755320253801826660, -0.755287485064271680, -0.755254714438498230, +-0.755221941924588020, -0.755189167522622990, -0.755156391232684740, -0.755123613054855760, -0.755090832989217860, -0.755058051035852770, -0.755025267194842310, -0.754992481466268960, +-0.754959693850214440, -0.754926904346760570, -0.754894112955989180, -0.754861319677982980, -0.754828524512823230, -0.754795727460592310, -0.754762928521371830, -0.754730127695244170, +-0.754697324982291360, -0.754664520382594790, -0.754631713896237290, -0.754598905523300440, -0.754566095263866420, -0.754533283118016820, -0.754500469085834350, -0.754467653167400610, +-0.754434835362797870, -0.754402015672107630, -0.754369194095412700, -0.754336370632794790, -0.754303545284335960, -0.754270718050117920, -0.754237888930223480, -0.754205057924734130, +-0.754172225033732270, -0.754139390257299590, -0.754106553595518700, -0.754073715048471430, -0.754040874616239480, -0.754008032298905780, -0.753975188096551950, -0.753942342009260140, +-0.753909494037112160, -0.753876644180190740, -0.753843792438577690, -0.753810938812355170, -0.753778083301605120, -0.753745225906410020, -0.753712366626851930, -0.753679505463012880, +-0.753646642414974810, -0.753613777482820320, -0.753580910666631460, -0.753548041966490390, -0.753515171382478920, -0.753482298914679770, -0.753449424563174870, -0.753416548328046050, +-0.753383670209376240, -0.753350790207247160, -0.753317908321741170, -0.753285024552940220, -0.753252138900926900, -0.753219251365783160, -0.753186361947591370, -0.753153470646433450, +-0.753120577462392030, -0.753087682395549240, -0.753054785445987250, -0.753021886613787990, -0.752988985899034290, -0.752956083301808080, -0.752923178822191730, -0.752890272460267070, +-0.752857364216117150, -0.752824454089823680, -0.752791542081469260, -0.752758628191135480, -0.752725712418905510, -0.752692794764861280, -0.752659875229084730, -0.752626953811658890, +-0.752594030512665490, -0.752561105332187120, -0.752528178270305710, -0.752495249327104100, -0.752462318502664430, -0.752429385797068860, -0.752396451210399660, -0.752363514742739550, +-0.752330576394170670, -0.752297636164775300, -0.752264694054635590, -0.752231750063834470, -0.752198804192453880, -0.752165856440576430, -0.752132906808283930, -0.752099955295659430, +-0.752067001902785080, -0.752034046629743050, -0.752001089476616040, -0.751968130443486320, -0.751935169530436380, -0.751902206737548150, -0.751869242064904690, -0.751836275512588140, +-0.751803307080680880, -0.751770336769265080, -0.751737364578423770, -0.751704390508239010, -0.751671414558793270, -0.751638436730168720, -0.751605457022448410, -0.751572475435714370, +-0.751539491970049210, -0.751506506625534980, -0.751473519402254820, -0.751440530300290790, -0.751407539319725260, -0.751374546460641060, -0.751341551723120560, -0.751308555107246150, +-0.751275556613100080, -0.751242556240765410, -0.751209553990324300, -0.751176549861859330, -0.751143543855452680, -0.751110535971187600, -0.751077526209146030, -0.751044514569410680, +-0.751011501052063710, -0.750978485657188390, -0.750945468384866750, -0.750912449235181520, -0.750879428208214850, -0.750846405304049780, -0.750813380522768910, -0.750780353864454190, +-0.750747325329188860, -0.750714294917055210, -0.750681262628135840, -0.750648228462513110, -0.750615192420269970, -0.750582154501489020, -0.750549114706252520, -0.750516073034642960, +-0.750483029486743500, -0.750449984062636520, -0.750416936762404620, -0.750383887586129950, -0.750350836533896000, -0.750317783605784940, -0.750284728801879350, -0.750251672122261630, +-0.750218613567015140, -0.750185553136222040, -0.750152490829965050, -0.750119426648326540, -0.750086360591389780, -0.750053292659237150, -0.750020222851950910, -0.749987151169614450, +-0.749954077612310140, -0.749921002180120590, -0.749887924873128280, -0.749854845691416360, -0.749821764635067440, -0.749788681704164130, -0.749755596898788680, -0.749722510219024580, +-0.749689421664954340, -0.749656331236660420, -0.749623238934225330, -0.749590144757732560, -0.749557048707264360, -0.749523950782903570, -0.749490850984732560, -0.749457749312834820, +-0.749424645767292620, -0.749391540348188560, -0.749358433055605900, -0.749325323889627140, -0.749292212850335090, -0.749259099937812260, -0.749225985152141890, -0.749192868493406610, +-0.749159749961689210, -0.749126629557072100, -0.749093507279638640, -0.749060383129471430, -0.749027257106653410, -0.748994129211266850, -0.748960999443395230, -0.748927867803121150, +-0.748894734290527330, -0.748861598905696480, -0.748828461648711860, -0.748795322519656080, -0.748762181518611850, -0.748729038645662200, -0.748695893900890200, -0.748662747284378320, +-0.748629598796209380, -0.748596448436466670, -0.748563296205232880, -0.748530142102590830, -0.748496986128623030, -0.748463828283413180, -0.748430668567043770, -0.748397506979597620, +-0.748364343521157440, -0.748331178191806720, -0.748298010991627960, -0.748264841920704300, -0.748231670979118140, -0.748198498166953160, -0.748165323484291880, -0.748132146931217320, +-0.748098968507812100, -0.748065788214159810, -0.748032606050343050, -0.747999422016444430, -0.747966236112547530, -0.747933048338734970, -0.747899858695089900, -0.747866667181694920, +-0.747833473798633520, -0.747800278545988410, -0.747767081423842630, -0.747733882432278900, -0.747700681571380700, -0.747667478841230750, -0.747634274241912200, -0.747601067773507650, +-0.747567859436100710, -0.747534649229774080, -0.747501437154610810, -0.747468223210693730, -0.747435007398106420, -0.747401789716931500, -0.747368570167251890, -0.747335348749151080, +-0.747302125462711910, -0.747268900308017400, -0.747235673285150390, -0.747202444394194480, -0.747169213635232480, -0.747135981008347440, -0.747102746513622180, -0.747069510151140310, +-0.747036271920984650, -0.747003031823238350, -0.746969789857984120, -0.746936546025305680, -0.746903300325286070, -0.746870052758008110, -0.746836803323554620, -0.746803552022009540, +-0.746770298853455470, -0.746737043817975450, -0.746703786915653090, -0.746670528146571200, -0.746637267510813050, -0.746604005008461470, -0.746570740639600160, -0.746537474404311950, +-0.746504206302680110, -0.746470936334787450, -0.746437664500717690, -0.746404390800553870, -0.746371115234378930, -0.746337837802276030, -0.746304558504328750, -0.746271277340620150, +-0.746237994311233280, -0.746204709416251170, -0.746171422655757640, -0.746138134029835420, -0.746104843538567990, -0.746071551182038050, -0.746038256960329660, -0.746004960873525520, +-0.745971662921708690, -0.745938363104962980, -0.745905061423371430, -0.745871757877017210, -0.745838452465983350, -0.745805145190353570, -0.745771836050210910, -0.745738525045638760, +-0.745705212176719920, -0.745671897443538350, -0.745638580846177070, -0.745605262384719360, -0.745571942059248150, -0.745538619869847370, -0.745505295816600080, -0.745471969899589530, +-0.745438642118898760, -0.745405312474611730, -0.745371980966811340, -0.745338647595580770, -0.745305312361003840, -0.745271975263163580, -0.745238636302143490, -0.745205295478026500, +-0.745171952790896540, -0.745138608240836660, -0.745105261827930240, -0.745071913552260430, -0.745038563413911170, -0.745005211412965500, -0.744971857549506680, -0.744938501823617980, +-0.744905144235383340, -0.744871784784885800, -0.744838423472208970, -0.744805060297435540, -0.744771695260649900, -0.744738328361934990, -0.744704959601373950, -0.744671588979050840, +-0.744638216495048690, -0.744604842149451110, -0.744571465942341030, -0.744538087873802600, -0.744504707943918990, -0.744471326152773560, -0.744437942500449590, -0.744404556987031010, +-0.744371169612601080, -0.744337780377243190, -0.744304389281040480, -0.744270996324077230, -0.744237601506436360, -0.744204204828201600, -0.744170806289455980, -0.744137405890283650, +-0.744104003630767790, -0.744070599510991640, -0.744037193531039250, -0.744003785690994010, -0.743970375990939180, -0.743936964430958140, -0.743903551011135030, -0.743870135731553030, +-0.743836718592295610, -0.743803299593446150, -0.743769878735088710, -0.743736456017306650, -0.743703031440183350, -0.743669605003802190, -0.743636176708247440, -0.743602746553602150, +-0.743569314539950010, -0.743535880667374300, -0.743502444935959180, -0.743469007345787910, -0.743435567896944090, -0.743402126589511210, -0.743368683423573100, -0.743335238399213450, +-0.743301791516515320, -0.743268342775563080, -0.743234892176439900, -0.743201439719229580, -0.743167985404015300, -0.743134529230881300, -0.743101071199911090, -0.743067611311188150, +-0.743034149564795960, -0.743000685960818590, -0.742967220499339610, -0.742933753180442520, -0.742900284004210710, -0.742866812970728540, -0.742833340080079290, -0.742799865332346650, +-0.742766388727614140, -0.742732910265966000, -0.742699429947485500, -0.742665947772256140, -0.742632463740362180, -0.742598977851887110, -0.742565490106914640, -0.742532000505528030, +-0.742498509047811780, -0.742465015733849270, -0.742431520563724190, -0.742398023537520050, -0.742364524655321210, -0.742331023917210950, -0.742297521323273090, -0.742264016873591230, +-0.742230510568249620, -0.742197002407331660, -0.742163492390921280, -0.742129980519101840, -0.742096466791957620, -0.742062951209572440, -0.742029433772029570, -0.741995914479413270, +-0.741962393331807250, -0.741928870329295220, -0.741895345471960790, -0.741861818759888210, -0.741828290193161210, -0.741794759771863380, -0.741761227496078310, -0.741727693365890620, +-0.741694157381383560, -0.741660619542641180, -0.741627079849746960, -0.741593538302785290, -0.741559994901839770, -0.741526449646994320, -0.741492902538332330, -0.741459353575938510, +-0.741425802759896220, -0.741392250090289530, -0.741358695567201800, -0.741325139190717740, -0.741291580960920740, -0.741258020877894610, -0.741224458941723620, -0.741190895152491480, +-0.741157329510282130, -0.741123762015179150, -0.741090192667267060, -0.741056621466629540, -0.741023048413350430, -0.740989473507513320, -0.740955896749202920, -0.740922318138502730, +-0.740888737675496900, -0.740855155360268690, -0.740821571192903040, -0.740787985173483430, -0.740754397302093800, -0.740720807578818090, -0.740687216003740430, -0.740653622576944780, +-0.740620027298514840, -0.740586430168535090, -0.740552831187089260, -0.740519230354261370, -0.740485627670135040, -0.740452023134794970, -0.740418416748324870, -0.740384808510808680, +-0.740351198422330330, -0.740317586482974190, -0.740283972692823980, -0.740250357051963960, -0.740216739560477730, -0.740183120218449900, -0.740149499025964270, -0.740115875983104910, +-0.740082251089955620, -0.740048624346600900, -0.740014995753124680, -0.739981365309610780, -0.739947733016143580, -0.739914098872807120, -0.739880462879685340, -0.739846825036862280, +-0.739813185344422310, -0.739779543802449480, -0.739745900411027720, -0.739712255170240860, -0.739678608080173830, -0.739644959140910110, -0.739611308352533970, -0.739577655715129460, +-0.739544001228780950, -0.739510344893572480, -0.739476686709588100, -0.739443026676911860, -0.739409364795628240, -0.739375701065821180, -0.739342035487574600, -0.739308368060973220, +-0.739274698786100970, -0.739241027663041890, -0.739207354691880040, -0.739173679872700000, -0.739140003205585930, -0.739106324690621760, -0.739072644327891440, -0.739038962117479770, +-0.739005278059470690, -0.738971592153948590, -0.738937904400997050, -0.738904214800701120, -0.738870523353144630, -0.738836830058411830, -0.738803134916586670, -0.738769437927753960, +-0.738735739091997630, -0.738702038409401960, -0.738668335880050990, -0.738634631504029420, -0.738600925281421180, -0.738567217212310450, -0.738533507296781910, -0.738499795534919620, +-0.738466081926807850, -0.738432366472530520, -0.738398649172172680, -0.738364930025818160, -0.738331209033551320, -0.738297486195456100, -0.738263761511617540, -0.738230034982119590, +-0.738196306607046490, -0.738162576386482420, -0.738128844320512070, -0.738095110409219710, -0.738061374652689620, -0.738027637051005710, -0.737993897604252940, -0.737960156312515550, +-0.737926413175877370, -0.737892668194423560, -0.737858921368238050, -0.737825172697405220, -0.737791422182009100, -0.737757669822134750, -0.737723915617866320, -0.737690159569288070, +-0.737656401676484050, -0.737622641939539300, -0.737588880358538090, -0.737555116933564570, -0.737521351664703010, -0.737487584552038330, -0.737453815595654700, -0.737420044795636500, +-0.737386272152068090, -0.737352497665034080, -0.737318721334618840, -0.737284943160906540, -0.737251163143982200, -0.737217381283930000, -0.737183597580834180, -0.737149812034779250, +-0.737116024645849910, -0.737082235414130650, -0.737048444339705840, -0.737014651422659430, -0.736980856663076890, -0.736947060061042160, -0.736913261616639730, -0.736879461329953860, +-0.736845659201069590, -0.736811855230071200, -0.736778049417043170, -0.736744241762069760, -0.736710432265236030, -0.736676620926626220, -0.736642807746324850, -0.736608992724416160, +-0.736575175860985310, -0.736541357156116570, -0.736507536609893990, -0.736473714222402930, -0.736439889993727670, -0.736406063923952580, -0.736372236013162040, -0.736338406261441310, +-0.736304574668874450, -0.736270741235546260, -0.736236905961540790, -0.736203068846943420, -0.736169229891838420, -0.736135389096310270, -0.736101546460443350, -0.736067701984322920, +-0.736033855668033250, -0.736000007511658950, -0.735966157515284270, -0.735932305678994480, -0.735898452002873960, -0.735864596487006970, -0.735830739131478890, -0.735796879936373880, +-0.735763018901776640, -0.735729156027771670, -0.735695291314444000, -0.735661424761878120, -0.735627556370158750, -0.735593686139370150, -0.735559814069597580, -0.735525940160925540, +-0.735492064413438620, -0.735458186827221310, -0.735424307402358760, -0.735390426138935460, -0.735356543037036130, -0.735322658096745130, -0.735288771318147740, -0.735254882701328330, +-0.735220992246371610, -0.735187099953362620, -0.735153205822385860, -0.735119309853526140, -0.735085412046867840, -0.735051512402496220, -0.735017610920496000, -0.734983707600951550, +-0.734949802443947700, -0.734915895449569480, -0.734881986617901720, -0.734848075949028790, -0.734814163443035520, -0.734780249100007050, -0.734746332920028000, -0.734712414903183060, +-0.734678495049556850, -0.734644573359234720, -0.734610649832301180, -0.734576724468840590, -0.734542797268938560, -0.734508868232679580, -0.734474937360148350, -0.734441004651429470, +-0.734407070106608440, -0.734373133725769730, -0.734339195508998180, -0.734305255456378370, -0.734271313567995690, -0.734237369843934730, -0.734203424284280310, -0.734169476889117050, +-0.734135527658530410, -0.734101576592604890, -0.734067623691425530, -0.734033668955076820, -0.733999712383644140, -0.733965753977212200, -0.733931793735865920, -0.733897831659689800, +-0.733863867748769440, -0.733829902003189430, -0.733795934423034370, -0.733761965008389750, -0.733727993759340170, -0.733694020675970670, -0.733660045758365850, -0.733626069006611090, +-0.733592090420791320, -0.733558110000991250, -0.733524127747295580, -0.733490143659789820, -0.733456157738558880, -0.733422169983687370, -0.733388180395260210, -0.733354188973362910, +-0.733320195718080160, -0.733286200629496900, -0.733252203707697840, -0.733218204952768570, -0.733184204364793810, -0.733150201943858270, -0.733116197690047430, -0.733082191603446120, +-0.733048183684139380, -0.733014173932211800, -0.732980162347749100, -0.732946148930836090, -0.732912133681557610, -0.732878116599998570, -0.732844097686244480, -0.732810076940380140, +-0.732776054362490600, -0.732742029952660690, -0.732708003710976000, -0.732673975637521240, -0.732639945732381670, -0.732605913995641790, -0.732571880427387520, -0.732537845027703470, +-0.732503807796674570, -0.732469768734386410, -0.732435727840923810, -0.732401685116371940, -0.732367640560815490, -0.732333594174340410, -0.732299545957031170, -0.732265495908973160, +-0.732231444030251090, -0.732197390320950660, -0.732163334781156800, -0.732129277410954570, -0.732095218210428890, -0.732061157179665470, -0.732027094318749130, -0.731993029627765020, +-0.731958963106798090, -0.731924894755934030, -0.731890824575257780, -0.731856752564854380, -0.731822678724808770, -0.731788603055206880, -0.731754525556133520, -0.731720446227673400, +-0.731686365069912580, -0.731652282082935760, -0.731618197266828310, -0.731584110621675050, -0.731550022147561820, -0.731515931844573420, -0.731481839712795350, -0.731447745752312310, +-0.731413649963210230, -0.731379552345573950, -0.731345452899488820, -0.731311351625039910, -0.731277248522312680, -0.731243143591392530, -0.731209036832364380, -0.731174928245313380, +-0.731140817830325360, -0.731106705587485360, -0.731072591516878310, -0.731038475618589920, -0.731004357892705460, -0.730970238339310190, -0.730936116958488810, -0.730901993750327610, +-0.730867868714911270, -0.730833741852325410, -0.730799613162654850, -0.730765482645985510, -0.730731350302402440, -0.730697216131991120, -0.730663080134836380, -0.730628942311024270, +-0.730594802660639810, -0.730560661183768280, -0.730526517880494830, -0.730492372750905390, -0.730458225795085010, -0.730424077013118840, -0.730389926405092700, -0.730355773971091750, +-0.730321619711201350, -0.730287463625506670, -0.730253305714093640, -0.730219145977047290, -0.730184984414453010, -0.730150821026396060, -0.730116655812962370, -0.730082488774236980, +-0.730048319910305390, -0.730014149221252740, -0.729979976707164970, -0.729945802368127340, -0.729911626204225120, -0.729877448215543570, -0.729843268402168620, -0.729809086764185540, +-0.729774903301679490, -0.729740718014736500, -0.729706530903441620, -0.729672341967880440, -0.729638151208138130, -0.729603958624300830, -0.729569764216453590, -0.729535567984681890, +-0.729501369929070890, -0.729467170049706850, -0.729432968346674930, -0.729398764820060500, -0.729364559469948940, -0.729330352296426290, -0.729296143299577700, -0.729261932479488780, +-0.729227719836244680, -0.729193505369931660, -0.729159289080634760, -0.729125070968439810, -0.729090851033431740, -0.729056629275696920, -0.729022405695320510, -0.728988180292387770, +-0.728953953066984850, -0.728919724019197020, -0.728885493149110000, -0.728851260456808920, -0.728817025942379960, -0.728782789605908370, -0.728748551447479960, -0.728714311467179690, +-0.728680069665094130, -0.728645826041308230, -0.728611580595907920, -0.728577333328978230, -0.728543084240605540, -0.728508833330875130, -0.728474580599872690, -0.728440326047683500, +-0.728406069674393700, -0.728371811480088780, -0.728337551464854020, -0.728303289628775770, -0.728269025971939210, -0.728234760494430140, -0.728200493196333840, -0.728166224077736570, +-0.728131953138723700, -0.728097680379381050, -0.728063405799793890, -0.728029129400048490, -0.727994851180230330, -0.727960571140425010, -0.727926289280717900, -0.727892005601195380, +-0.727857720101942830, -0.727823432783046060, -0.727789143644590350, -0.727754852686662070, -0.727720559909346700, -0.727686265312729620, -0.727651968896897210, -0.727617670661934830, +-0.727583370607928330, -0.727549068734962940, -0.727514765043125400, -0.727480459532500840, -0.727446152203175100, -0.727411843055233760, -0.727377532088762990, -0.727343219303848490, +-0.727308904700575960, -0.727274588279030800, -0.727240270039299470, -0.727205949981467590, -0.727171628105620750, -0.727137304411844540, -0.727102978900225240, -0.727068651570848660, +-0.727034322423800510, -0.726999991459166050, -0.726965658677032000, -0.726931324077483950, -0.726896987660607060, -0.726862649426488150, -0.726828309375212480, -0.726793967506866200, +-0.726759623821534580, -0.726725278319304220, -0.726690931000260720, -0.726656581864489890, -0.726622230912077230, -0.726587878143109320, -0.726553523557671780, -0.726519167155850410, +-0.726484808937730710, -0.726450448903399490, -0.726416087052942030, -0.726381723386444240, -0.726347357903992070, -0.726312990605671670, -0.726278621491568850, -0.726244250561769110, +-0.726209877816359040, -0.726175503255424350, -0.726141126879050860, -0.726106748687324280, -0.726072368680331090, -0.726037986858157010, -0.726003603220887970, -0.725969217768609560, +-0.725934830501408500, -0.725900441419370270, -0.725866050522581020, -0.725831657811126350, -0.725797263285092750, -0.725762866944566040, -0.725728468789632150, -0.725694068820376790, +-0.725659667036886560, -0.725625263439247160, -0.725590858027544310, -0.725556450801864590, -0.725522041762293850, -0.725487630908917880, -0.725453218241822520, -0.725418803761094470, +-0.725384387466819440, -0.725349969359083470, -0.725315549437972160, -0.725281127703572340, -0.725246704155969700, -0.725212278795250300, -0.725177851621499950, -0.725143422634805250, +-0.725108991835251900, -0.725074559222926180, -0.725040124797913690, -0.725005688560301230, -0.724971250510174530, -0.724936810647619390, -0.724902368972722530, -0.724867925485569780, +-0.724833480186247160, -0.724799033074840620, -0.724764584151436740, -0.724730133416121360, -0.724695680868980840, -0.724661226510100680, -0.724626770339567680, -0.724592312357467790, +-0.724557852563887160, -0.724523390958911720, -0.724488927542627950, -0.724454462315121890, -0.724419995276479600, -0.724385526426787110, -0.724351055766131120, -0.724316583294597470, +-0.724282109012272410, -0.724247632919241660, -0.724213155015592250, -0.724178675301409890, -0.724144193776780520, -0.724109710441790950, -0.724075225296527240, -0.724040738341075300, +-0.724006249575521290, -0.723971758999951920, -0.723937266614453230, -0.723902772419111380, -0.723868276414012190, -0.723833778599242690, -0.723799278974888830, -0.723764777541036630, +-0.723730274297772150, -0.723695769245182420, -0.723661262383353150, -0.723626753712370840, -0.723592243232321300, -0.723557730943291460, -0.723523216845367250, -0.723488700938634710, +-0.723454183223180670, -0.723419663699091280, -0.723385142366452680, -0.723350619225350930, -0.723316094275872960, -0.723281567518104680, -0.723247038952132600, -0.723212508578042420, +-0.723177976395921520, -0.723143442405855490, -0.723108906607930920, -0.723074369002233870, -0.723039829588851050, -0.723005288367868700, -0.722970745339373110, -0.722936200503450420, +-0.722901653860187570, -0.722867105409670470, -0.722832555151985410, -0.722798003087219200, -0.722763449215457990, -0.722728893536788150, -0.722694336051295740, -0.722659776759067900, +-0.722625215660190560, -0.722590652754750210, -0.722556088042832780, -0.722521521524525650, -0.722486953199914520, -0.722452383069086100, -0.722417811132126440, -0.722383237389122580, +-0.722348661840160560, -0.722314084485326970, -0.722279505324707750, -0.722244924358390160, -0.722210341586460250, -0.722175757009004380, -0.722141170626108940, -0.722106582437860740, +-0.722071992444346280, -0.722037400645651360, -0.722002807041863370, -0.721968211633068240, -0.721933614419352660, -0.721899015400802810, -0.721864414577505610, -0.721829811949547430, +-0.721795207517014650, -0.721760601279993640, -0.721725993238571340, -0.721691383392834120, -0.721656771742868460, -0.721622158288760530, -0.721587543030597470, -0.721552925968465650, +-0.721518307102451460, -0.721483686432641160, -0.721449063959122010, -0.721414439681980160, -0.721379813601301880, -0.721345185717174430, -0.721310556029684080, -0.721275924538917200, +-0.721241291244960280, -0.721206656147900470, -0.721172019247823930, -0.721137380544817350, -0.721102740038967130, -0.721068097730360290, -0.721033453619083110, -0.720998807705222510, +-0.720964159988864430, -0.720929510470096350, -0.720894859149004310, -0.720860206025675240, -0.720825551100195420, -0.720790894372651980, -0.720756235843131310, -0.720721575511719670, +-0.720686913378504430, -0.720652249443571980, -0.720617583707008790, -0.720582916168901470, -0.720548246829337050, -0.720513575688402130, -0.720478902746183090, -0.720444228002766640, +-0.720409551458239930, -0.720374873112689220, -0.720340192966201440, -0.720305511018862870, -0.720270827270760750, -0.720236141721981580, -0.720201454372612180, -0.720166765222738700, +-0.720132074272448630, -0.720097381521828450, -0.720062686970964430, -0.720027990619944050, -0.719993292468853690, -0.719958592517780050, -0.719923890766809630, -0.719889187216029900, +-0.719854481865527030, -0.719819774715388050, -0.719785065765699340, -0.719750355016548270, -0.719715642468021330, -0.719680928120205230, -0.719646211973186460, -0.719611494027052600, +-0.719576774281889930, -0.719542052737785260, -0.719507329394825310, -0.719472604253097230, -0.719437877312687600, -0.719403148573683370, -0.719368418036170910, -0.719333685700237810, +-0.719298951565970460, -0.719264215633455330, -0.719229477902780020, -0.719194738374031030, -0.719159997047295160, -0.719125253922659020, -0.719090509000209990, -0.719055762280034760, +-0.719021013762220160, -0.718986263446852680, -0.718951511334019800, -0.718916757423808230, -0.718882001716304670, -0.718847244211595850, -0.718812484909769230, -0.718777723810911430, +-0.718742960915109250, -0.718708196222449410, -0.718673429733019290, -0.718638661446905800, -0.718603891364195220, -0.718569119484975150, -0.718534345809332400, -0.718499570337353680, +-0.718464793069125810, -0.718430014004736270, -0.718395233144271670, -0.718360450487819050, -0.718325666035464880, -0.718290879787296890, -0.718256091743401770, -0.718221301903866350, +-0.718186510268777330, -0.718151716838222430, -0.718116921612288240, -0.718082124591061690, -0.718047325774629600, -0.718012525163079340, -0.717977722756497960, -0.717942918554971830, +-0.717908112558588770, -0.717873304767435490, -0.717838495181598810, -0.717803683801165660, -0.717768870626223630, -0.717734055656859440, -0.717699238893160010, -0.717664420335212270, +-0.717629599983103720, -0.717594777836921270, -0.717559953896751760, -0.717525128162682100, -0.717490300634799900, -0.717455471313191980, -0.717420640197945380, -0.717385807289146920, +-0.717350972586884180, -0.717316136091244120, -0.717281297802313640, -0.717246457720179590, -0.717211615844929650, -0.717176772176650770, -0.717141926715429650, -0.717107079461353990, +-0.717072230414510630, -0.717037379574986700, -0.717002526942868920, -0.716967672518245340, -0.716932816301202420, -0.716897958291827450, -0.716863098490207350, -0.716828236896429830, +-0.716793373510581700, -0.716758508332750010, -0.716723641363021910, -0.716688772601485000, -0.716653902048226100, -0.716619029703332470, -0.716584155566890920, -0.716549279638989290, +-0.716514401919714490, -0.716479522409153360, -0.716444641107393700, -0.716409758014522560, -0.716374873130626980, -0.716339986455793780, -0.716305097990111110, -0.716270207733665560, +-0.716235315686544530, -0.716200421848834920, -0.716165526220624570, -0.716130628802000400, -0.716095729593049680, -0.716060828593859220, -0.716025925804517070, -0.715991021225110160, +-0.715956114855725630, -0.715921206696450430, -0.715886296747372700, -0.715851385008579140, -0.715816471480156810, -0.715781556162193630, -0.715746639054776530, -0.715711720157992780, +-0.715676799471929530, -0.715641876996674590, -0.715606952732314780, -0.715572026678937820, -0.715537098836630300, -0.715502169205480490, -0.715467237785575190, -0.715432304577001800, +-0.715397369579847340, -0.715362432794199750, -0.715327494220146080, -0.715292553857773680, -0.715257611707169620, -0.715222667768421800, -0.715187722041617400, -0.715152774526843340, +-0.715117825224187540, -0.715082874133737280, -0.715047921255579810, -0.715012966589802180, -0.714978010136492540, -0.714943051895737810, -0.714908091867625490, -0.714873130052242620, +-0.714838166449677240, -0.714803201060016490, -0.714768233883347650, -0.714733264919757970, -0.714698294169335390, -0.714663321632167060, -0.714628347308340460, -0.714593371197942750, +-0.714558393301061860, -0.714523413617784930, -0.714488432148199570, -0.714453448892392820, -0.714418463850452710, -0.714383477022466410, -0.714348488408521170, -0.714313498008705030, +-0.714278505823105040, -0.714243511851808900, -0.714208516094903540, -0.714173518552477350, -0.714138519224617240, -0.714103518111410930, -0.714068515212945450, -0.714033510529309080, +-0.713998504060588850, -0.713963495806872350, -0.713928485768246860, -0.713893473944800410, -0.713858460336620370, -0.713823444943794130, -0.713788427766408830, -0.713753408804552960, +-0.713718388058313450, -0.713683365527777780, -0.713648341213033890, -0.713613315114169260, -0.713578287231271260, -0.713543257564427270, -0.713508226113725440, -0.713473192879253040, +-0.713438157861097650, -0.713403121059346560, -0.713368082474087890, -0.713333042105409150, -0.713297999953397710, -0.713262956018141050, -0.713227910299727320, -0.713192862798243680, +-0.713157813513777940, -0.713122762446417370, -0.713087709596250230, -0.713052654963363790, -0.713017598547845410, -0.712982540349783370, -0.712947480369264920, -0.712912418606377880, +-0.712877355061209420, -0.712842289733847780, -0.712807222624380570, -0.712772153732895260, -0.712737083059479250, -0.712702010604220780, -0.712666936367207350, -0.712631860348526550, +-0.712596782548265860, -0.712561702966513440, -0.712526621603356780, -0.712491538458883580, -0.712456453533181210, -0.712421366826338050, -0.712386278338441370, -0.712351188069579200, +-0.712316096019838580, -0.712281002189308010, -0.712245906578075070, -0.712210809186226920, -0.712175710013852160, -0.712140609061038040, -0.712105506327872510, -0.712070401814442810, +-0.712035295520837440, -0.712000187447143770, -0.711965077593449850, -0.711929965959842700, -0.711894852546411050, -0.711859737353242260, -0.711824620380424040, -0.711789501628044110, +-0.711754381096190600, -0.711719258784951240, -0.711684134694413610, -0.711649008824665420, -0.711613881175795050, -0.711578751747889870, -0.711543620541037590, -0.711508487555326590, +-0.711473352790844230, -0.711438216247678670, -0.711403077925917170, -0.711367937825648220, -0.711332795946959530, -0.711297652289938800, -0.711262506854673630, -0.711227359641252500, +-0.711192210649763010, -0.711157059880292990, -0.711121907332930010, -0.711086753007762580, -0.711051596904878180, -0.711016439024364840, -0.710981279366310170, -0.710946117930802530, +-0.710910954717929530, -0.710875789727778980, -0.710840622960439150, -0.710805454415997850, -0.710770284094542900, -0.710735111996161910, -0.710699938120943450, -0.710664762468975140, +-0.710629585040344900, -0.710594405835140440, -0.710559224853450240, -0.710524042095362020, -0.710488857560963690, -0.710453671250342870, -0.710418483163588130, -0.710383293300787310, +-0.710348101662028110, -0.710312908247398460, -0.710277713056986840, -0.710242516090880960, -0.710207317349168310, -0.710172116831937930, -0.710136914539277080, -0.710101710471274020, +-0.710066504628016350, -0.710031297009592670, -0.709996087616090790, -0.709960876447598750, -0.709925663504204160, -0.709890448785995720, -0.709855232293061240, -0.709820014025488550, +-0.709784793983365580, -0.709749572166780920, -0.709714348575822380, -0.709679123210577910, -0.709643896071135320, -0.709608667157583310, -0.709573436470009700, -0.709538204008502430, +-0.709502969773149310, -0.709467733764039150, -0.709432495981259570, -0.709397256424898480, -0.709362015095044600, -0.709326771991785730, -0.709291527115209820, -0.709256280465404790, +-0.709221032042459450, -0.709185781846461420, -0.709150529877499050, -0.709115276135659940, -0.709080020621033040, -0.709044763333706030, -0.709009504273767190, -0.708974243441304110, +-0.708938980836405830, -0.708903716459160170, -0.708868450309655170, -0.708833182387978660, -0.708797912694219660, -0.708762641228465770, -0.708727367990804940, -0.708692092981326070, +-0.708656816200117000, -0.708621537647265760, -0.708586257322860400, -0.708550975226989730, -0.708515691359741680, -0.708480405721204410, -0.708445118311465730, -0.708409829130614680, +-0.708374538178738970, -0.708339245455926860, -0.708303950962266390, -0.708268654697846390, -0.708233356662754670, -0.708198056857079590, -0.708162755280909110, -0.708127451934332020, +-0.708092146817436260, -0.708056839930309880, -0.708021531273041680, -0.707986220845719720, -0.707950908648432130, -0.707915594681266970, -0.707880278944313050, -0.707844961437658630, +-0.707809642161391750, -0.707774321115600350, -0.707738998300373460, -0.707703673715799120, -0.707668347361965600, -0.707633019238960940, -0.707597689346874060, -0.707562357685792900, +-0.707527024255805830, -0.707491689057000880, -0.707456352089467110, -0.707421013353292330, -0.707385672848565130, -0.707350330575373440, -0.707314986533806200, -0.707279640723951440, +-0.707244293145897320, -0.707208943799732760, -0.707173592685545800, -0.707138239803424940, -0.707102885153458200, -0.707067528735734420, -0.707032170550341950, -0.706996810597368960, +-0.706961448876903710, -0.706926085389035120, -0.706890720133851240, -0.706855353111440650, -0.706819984321891410, -0.706784613765292450, -0.706749241441731900, -0.706713867351298370, +-0.706678491494079800, -0.706643113870165320, -0.706607734479642980, -0.706572353322601040, -0.706536970399128660, -0.706501585709313650, -0.706466199253244830, -0.706430811031010130, +-0.706395421042698700, -0.706360029288398810, -0.706324635768198710, -0.706289240482186780, -0.706253843430452060, -0.706218444613082810, -0.706183044030167300, -0.706147641681794000, +-0.706112237568051750, -0.706076831689029020, -0.706041424044814180, -0.706006014635495500, -0.705970603461162140, -0.705935190521902230, -0.705899775817803940, -0.705864359348956640, +-0.705828941115448360, -0.705793521117367820, -0.705758099354803050, -0.705722675827843430, -0.705687250536577100, -0.705651823481092680, -0.705616394661478300, -0.705580964077823340, +-0.705545531730215950, -0.705510097618744610, -0.705474661743497820, -0.705439224104564720, -0.705403784702033580, -0.705368343535992870, -0.705332900606530980, -0.705297455913737270, +-0.705262009457699790, -0.705226561238507350, -0.705191111256248230, -0.705155659511011670, -0.705120206002885830, -0.705084750731959310, -0.705049293698321140, -0.705013834902059710, +-0.704978374343263820, -0.704942912022021530, -0.704907447938422300, -0.704871982092554530, -0.704836514484506790, -0.704801045114367360, -0.704765573982225720, -0.704730101088170140, +-0.704694626432289310, -0.704659150014671610, -0.704623671835406310, -0.704588191894581770, -0.704552710192286820, -0.704517226728609840, -0.704481741503640070, -0.704446254517465900, +-0.704410765770175810, -0.704375275261859170, -0.704339782992604250, -0.704304288962499860, -0.704268793171634490, -0.704233295620097510, -0.704197796307977190, -0.704162295235362450, +-0.704126792402341550, -0.704091287809004100, -0.704055781455438350, -0.704020273341733230, -0.703984763467977110, -0.703949251834259270, -0.703913738440668400, -0.703878223287293210, +-0.703842706374222080, -0.703807187701544600, -0.703771667269349030, -0.703736145077724080, -0.703700621126759020, -0.703665095416542430, -0.703629567947163030, -0.703594038718709400, +-0.703558507731271150, -0.703522974984936430, -0.703487440479794390, -0.703451904215933400, -0.703416366193443050, -0.703380826412411730, -0.703345284872928240, -0.703309741575081300, +-0.703274196518960390, -0.703238649704653880, -0.703203101132250820, -0.703167550801839680, -0.703131998713509950, -0.703096444867350230, -0.703060889263449120, -0.703025331901896090, +-0.702989772782779630, -0.702954211906188900, -0.702918649272212150, -0.702883084880939310, -0.702847518732458540, -0.702811950826859100, -0.702776381164229470, -0.702740809744659130, +-0.702705236568236800, -0.702669661635051400, -0.702634084945191530, -0.702598506498746780, -0.702562926295805750, -0.702527344336457360, -0.702491760620790330, -0.702456175148894250, +-0.702420587920857710, -0.702384998936769640, -0.702349408196718760, -0.702313815700794760, -0.702278221449086140, -0.702242625441681700, -0.702207027678671050, -0.702171428160142770, +-0.702135826886185920, -0.702100223856889190, -0.702064619072342190, -0.702029012532633720, -0.701993404237852610, -0.701957794188087790, -0.701922182383428740, -0.701886568823964270, +-0.701850953509783330, -0.701815336440974710, -0.701779717617628140, -0.701744097039832200, -0.701708474707675940, -0.701672850621248290, -0.701637224780638840, -0.701601597185936290, +-0.701565967837229460, -0.701530336734607960, -0.701494703878160710, -0.701459069267976630, -0.701423432904144550, -0.701387794786754170, -0.701352154915894420, -0.701316513291654230, +-0.701280869914122420, -0.701245224783388800, -0.701209577899542080, -0.701173929262671410, -0.701138278872865620, -0.701102626730214510, -0.701066972834806680, -0.701031317186731510, +-0.700995659786077810, -0.700960000632935180, -0.700924339727392540, -0.700888677069538720, -0.700853012659463650, -0.700817346497255910, -0.700781678583004890, -0.700746008916799280, +-0.700710337498729020, -0.700674664328882920, -0.700638989407350140, -0.700603312734219610, -0.700567634309581020, -0.700531954133523430, -0.700496272206135970, -0.700460588527507480, +-0.700424903097727760, -0.700389215916885850, -0.700353526985070920, -0.700317836302371880, -0.700282143868878440, -0.700246449684679750, -0.700210753749864970, -0.700175056064522900, +-0.700139356628743490, -0.700103655442615770, -0.700067952506228550, -0.700032247819671770, -0.699996541383034470, -0.699960833196405670, -0.699925123259874550, -0.699889411573530910, +-0.699853698137463680, -0.699817982951762340, -0.699782266016515610, -0.699746547331813630, -0.699710826897745220, -0.699675104714399750, -0.699639380781866160, -0.699603655100234480, +-0.699567927669593750, -0.699532198490033120, -0.699496467561641630, -0.699460734884509330, -0.699425000458725240, -0.699389264284378200, -0.699353526361558450, -0.699317786690354830, +-0.699282045270856800, -0.699246302103153190, -0.699210557187334270, -0.699174810523488950, -0.699139062111706620, -0.699103311952076200, -0.699067560044687950, -0.699031806389630810, +-0.698996050986994020, -0.698960293836866860, -0.698924534939339260, -0.698888774294500360, -0.698853011902439540, -0.698817247763245830, -0.698781481877009390, -0.698745714243819150, +-0.698709944863764370, -0.698674173736934970, -0.698638400863420220, -0.698602626243309490, -0.698566849876691710, -0.698531071763657250, -0.698495291904295160, -0.698459510298694800, +-0.698423726946945320, -0.698387941849136770, -0.698352155005358520, -0.698316366415699830, -0.698280576080249850, -0.698244783999098730, -0.698208990172335730, -0.698173194600050230, +-0.698137397282331370, -0.698101598219269430, -0.698065797410953430, -0.698029994857472640, -0.697994190558917200, -0.697958384515376280, -0.697922576726939360, -0.697886767193695690, +-0.697850955915735430, -0.697815142893147830, -0.697779328126022280, -0.697743511614448140, -0.697707693358515570, -0.697671873358313710, -0.697636051613932270, -0.697600228125460300, +-0.697564402892988040, -0.697528575916604780, -0.697492747196400200, -0.697456916732463350, -0.697421084524884490, -0.697385250573753000, -0.697349414879158250, -0.697313577441189820, +-0.697277738259937660, -0.697241897335491130, -0.697206054667939610, -0.697170210257373250, -0.697134364103881410, -0.697098516207553590, -0.697062666568479150, -0.697026815186748470, +-0.696990962062450590, -0.696955107195675440, -0.696919250586512160, -0.696883392235051020, -0.696847532141381510, -0.696811670305593100, -0.696775806727775170, -0.696739941408018090, +-0.696704074346411130, -0.696668205543043980, -0.696632334998006030, -0.696596462711387530, -0.696560588683277970, -0.696524712913766500, -0.696488835402943600, -0.696452956150898640, +-0.696417075157721220, -0.696381192423500940, -0.696345307948327830, -0.696309421732291600, -0.696273533775481730, -0.696237644077987720, -0.696201752639899920, -0.696165859461307710, +-0.696129964542300920, -0.696094067882968790, -0.696058169483401820, -0.696022269343689490, -0.695986367463921510, -0.695950463844187240, -0.695914558484577170, -0.695878651385180680, +-0.695842742546087250, -0.695806831967387350, -0.695770919649170260, -0.695735005591525900, -0.695699089794543760, -0.695663172258314200, -0.695627252982926600, -0.695591331968471000, +-0.695555409215036670, -0.695519484722714190, -0.695483558491593050, -0.695447630521762950, -0.695411700813313380, -0.695375769366334940, -0.695339836180917100, -0.695303901257149690, +-0.695267964595122080, -0.695232026194924970, -0.695196086056647840, -0.695160144180380520, -0.695124200566212380, -0.695088255214234120, -0.695052308124535220, -0.695016359297205290, +-0.694980408732334690, -0.694944456430013120, -0.694908502390330420, -0.694872546613376050, -0.694836589099240730, -0.694800629848013940, -0.694764668859785610, -0.694728706134645210, +-0.694692741672683360, -0.694656775473989740, -0.694620807538654070, -0.694584837866766060, -0.694548866458416400, -0.694512893313694480, -0.694476918432690330, -0.694440941815493650, +-0.694404963462194820, -0.694368983372883660, -0.694333001547649650, -0.694297017986583500, -0.694261032689774900, -0.694225045657313580, -0.694189056889289340, -0.694153066385792880, +-0.694117074146913590, -0.694081080172741730, -0.694045084463366880, -0.694009087018879530, -0.693973087839369620, -0.693937086924926840, -0.693901084275641120, -0.693865079891602950, +-0.693829073772902040, -0.693793065919628530, -0.693757056331872010, -0.693721045009723200, -0.693685031953271690, -0.693649017162607300, -0.693613000637820720, -0.693576982379001670, +-0.693540962386240190, -0.693504940659625870, -0.693468917199249630, -0.693432892005201080, -0.693396865077570260, -0.693360836416446970, -0.693324806021921810, -0.693288773894084830, +-0.693252740033025730, -0.693216704438834540, -0.693180667111601980, -0.693144628051417630, -0.693108587258371770, -0.693072544732554200, -0.693036500474055520, -0.693000454482965540, +-0.692964406759374100, -0.692928357303371990, -0.692892306115049040, -0.692856253194495290, -0.692820198541800550, -0.692784142157055640, -0.692748084040350490, -0.692712024191775020, +-0.692675962611419170, -0.692639899299373750, -0.692603834255728580, -0.692567767480573800, -0.692531698973999350, -0.692495628736095940, -0.692459556766953480, -0.692423483066662130, +-0.692387407635311700, -0.692351330472993130, -0.692315251579796120, -0.692279170955811150, -0.692243088601127820, -0.692207004515837170, -0.692170918700028890, -0.692134831153793040, +-0.692098741877220420, -0.692062650870401090, -0.692026558133424950, -0.691990463666382170, -0.691954367469363560, -0.691918269542459050, -0.691882169885758790, -0.691846068499352820, +-0.691809965383332060, -0.691773860537786330, -0.691737753962805900, -0.691701645658480910, -0.691665535624901960, -0.691629423862159310, -0.691593310370343000, -0.691557195149543170, +-0.691521078199850650, -0.691484959521355360, -0.691448839114147450, -0.691412716978317740, -0.691376593113956160, -0.691340467521153190, -0.691304340199998760, -0.691268211150583680, +-0.691232080372998100, -0.691195947867332410, -0.691159813633676510, -0.691123677672121350, -0.691087539982756960, -0.691051400565673820, -0.691015259420961760, -0.690979116548711910, +-0.690942971949014330, -0.690906825621959260, -0.690870677567636760, -0.690834527786137960, -0.690798376277552810, -0.690762223041971430, -0.690726068079484780, -0.690689911390182990, +-0.690653752974156430, -0.690617592831495150, -0.690581430962290190, -0.690545267366631690, -0.690509102044609910, -0.690472934996315240, -0.690436766221838360, -0.690400595721269660, +-0.690364423494699510, -0.690328249542217940, -0.690292073863916110, -0.690255896459884060, -0.690219717330212260, -0.690183536474990870, -0.690147353894310920, -0.690111169588262570, +-0.690074983556936310, -0.690038795800422380, -0.690002606318811610, -0.689966415112194480, -0.689930222180660910, -0.689894027524302070, -0.689857831143208200, -0.689821633037469790, +-0.689785433207176890, -0.689749231652420860, -0.689713028373291630, -0.689676823369879900, -0.689640616642275830, -0.689604408190570450, -0.689568198014854030, -0.689531986115217150, +-0.689495772491750090, -0.689459557144543770, -0.689423340073688660, -0.689387121279275150, -0.689350900761393490, -0.689314678520134950, -0.689278454555589670, -0.689242228867847920, +-0.689206001457000950, -0.689169772323139030, -0.689133541466352640, -0.689097308886732040, -0.689061074584368600, -0.689024838559352370, -0.688988600811774040, -0.688952361341723880, +-0.688916120149293150, -0.688879877234572220, -0.688843632597651470, -0.688807386238621370, -0.688771138157573180, -0.688734888354597060, -0.688698636829783720, -0.688662383583223510, +-0.688626128615007600, -0.688589871925226470, -0.688553613513970260, -0.688517353381330350, -0.688481091527397120, -0.688444827952261030, -0.688408562656012690, -0.688372295638743140, +-0.688336026900542960, -0.688299756441502650, -0.688263484261712690, -0.688227210361264220, -0.688190934740247840, -0.688154657398754140, -0.688118378336873390, -0.688082097554697070, +-0.688045815052315430, -0.688009530829819300, -0.687973244887299050, -0.687936957224845940, -0.687900667842550550, -0.687864376740503050, -0.687828083918795020, -0.687791789377516730, +-0.687755493116758990, -0.687719195136612170, -0.687682895437167760, -0.687646594018516020, -0.687610290880747880, -0.687573986023953590, -0.687537679448224750, -0.687501371153651620, +-0.687465061140325130, -0.687428749408335650, -0.687392435957774550, -0.687356120788732540, -0.687319803901300100, -0.687283485295567820, -0.687247164971627190, -0.687210842929568580, +-0.687174519169482910, -0.687138193691460670, -0.687101866495593240, -0.687065537581971090, -0.687029206950684810, -0.686992874601825900, -0.686956540535484720, -0.686920204751752190, +-0.686883867250718820, -0.686847528032476170, -0.686811187097114640, -0.686774844444725140, -0.686738500075398270, -0.686702153989225410, -0.686665806186297130, -0.686629456666704390, +-0.686593105430537750, -0.686556752477888610, -0.686520397808847550, -0.686484041423505500, -0.686447683321953050, -0.686411323504281800, -0.686374961970582120, -0.686338598720944710, +-0.686302233755461290, -0.686265867074222100, -0.686229498677318310, -0.686193128564840490, -0.686156756736880150, -0.686120383193527860, -0.686084007934874670, -0.686047630961011070, +-0.686011252272028860, -0.685974871868018420, -0.685938489749070790, -0.685902105915276560, -0.685865720366727550, -0.685829333103514130, -0.685792944125727330, -0.685756553433457980, +-0.685720161026797450, -0.685683766905836660, -0.685647371070665980, -0.685610973521377230, -0.685574574258061120, -0.685538173280808570, -0.685501770589710180, -0.685465366184857760, +-0.685428960066341910, -0.685392552234253550, -0.685356142688683610, -0.685319731429723580, -0.685283318457464260, -0.685246903771996710, -0.685210487373411500, -0.685174069261800360, +-0.685137649437254080, -0.685101227899863720, -0.685064804649719860, -0.685028379686914430, -0.684991953011538040, -0.684955524623681700, -0.684919094523436240, -0.684882662710893380, +-0.684846229186143800, -0.684809793949278430, -0.684773357000388880, -0.684736918339565960, -0.684700477966900700, -0.684664035882483810, -0.684627592086407330, -0.684591146578761740, +-0.684554699359638420, -0.684518250429127950, -0.684481799787322150, -0.684445347434311960, -0.684408893370188290, -0.684372437595042070, -0.684335980108965130, -0.684299520912048260, +-0.684263060004382530, -0.684226597386058840, -0.684190133057169030, -0.684153667017803780, -0.684117199268054140, -0.684080729808011820, -0.684044258637767630, -0.684007785757412830, +-0.683971311167038240, -0.683934834866735670, -0.683898356856595950, -0.683861877136710430, -0.683825395707169940, -0.683788912568066180, -0.683752427719490190, -0.683715941161533110, +-0.683679452894285890, -0.683642962917840320, -0.683606471232287350, -0.683569977837718220, -0.683533482734223760, -0.683496985921896010, -0.683460487400825770, -0.683423987171103970, +-0.683387485232822560, -0.683350981586072330, -0.683314476230944770, -0.683277969167530590, -0.683241460395921930, -0.683204949916209500, -0.683168437728484790, -0.683131923832838610, +-0.683095408229362990, -0.683058890918148750, -0.683022371899287380, -0.682985851172869700, -0.682949328738987840, -0.682912804597732510, -0.682876278749195210, -0.682839751193466960, +-0.682803221930639580, -0.682766690960804220, -0.682730158284051700, -0.682693623900474170, -0.682657087810162540, -0.682620550013208320, -0.682584010509702300, -0.682547469299736530, +-0.682510926383402160, -0.682474381760790450, -0.682437835431992430, -0.682401287397100260, -0.682364737656204760, -0.682328186209397500, -0.682291633056769320, -0.682255078198412470, +-0.682218521634417980, -0.682181963364877130, -0.682145403389881060, -0.682108841709521800, -0.682072278323890390, -0.682035713233078320, -0.681999146437176630, -0.681962577936277460, +-0.681926007730471740, -0.681889435819850730, -0.681852862204506470, -0.681816286884530110, -0.681779709860012910, -0.681743131131046230, -0.681706550697721900, -0.681669968560131290, +-0.681633384718365760, -0.681596799172516480, -0.681560211922675460, -0.681523622968933870, -0.681487032311383300, -0.681450439950114780, -0.681413845885220580, -0.681377250116791620, +-0.681340652644919720, -0.681304053469695690, -0.681267452591211910, -0.681230850009559520, -0.681194245724829670, -0.681157639737114520, -0.681121032046505310, -0.681084422653093440, +-0.681047811556970250, -0.681011198758227910, -0.680974584256957450, -0.680937968053250580, -0.680901350147198550, -0.680864730538893290, -0.680828109228426400, -0.680791486215889140, +-0.680754861501372770, -0.680718235084969650, -0.680681606966770940, -0.680644977146868340, -0.680608345625352770, -0.680571712402316730, -0.680535077477851470, -0.680498440852048030, +-0.680461802524998990, -0.680425162496795410, -0.680388520767528870, -0.680351877337290740, -0.680315232206173180, -0.680278585374267550, -0.680241936841665560, -0.680205286608458250, +-0.680168634674738200, -0.680131981040596470, -0.680095325706124850, -0.680058668671414510, -0.680022009936557930, -0.679985349501646240, -0.679948687366771170, -0.679912023532024070, +-0.679875357997497320, -0.679838690763282070, -0.679802021829470140, -0.679765351196152780, -0.679728678863422480, -0.679692004831370380, -0.679655329100087970, -0.679618651669667620, +-0.679581972540200590, -0.679545291711778580, -0.679508609184493070, -0.679471924958436340, -0.679435239033699840, -0.679398551410375200, -0.679361862088553870, -0.679325171068328240, +-0.679288478349789670, -0.679251783933029870, -0.679215087818140330, -0.679178390005213410, -0.679141690494340480, -0.679104989285613360, -0.679068286379123310, -0.679031581774963030, +-0.678994875473223680, -0.678958167473996950, -0.678921457777375000, -0.678884746383449420, -0.678848033292312030, -0.678811318504054180, -0.678774602018768380, -0.678737883836546100, +-0.678701163957479150, -0.678664442381658910, -0.678627719109177850, -0.678590994140127580, -0.678554267474599680, -0.678517539112685970, -0.678480809054478610, -0.678444077300069280, +-0.678407343849549700, -0.678370608703011470, -0.678333871860547170, -0.678297133322248060, -0.678260393088205740, -0.678223651158512910, -0.678186907533260830, -0.678150162212541540, +-0.678113415196446410, -0.678076666485068260, -0.678039916078498340, -0.678003163976828580, -0.677966410180150690, -0.677929654688557040, -0.677892897502139210, -0.677856138620989260, +-0.677819378045198540, -0.677782615774859760, -0.677745851810064410, -0.677709086150904420, -0.677672318797471360, -0.677635549749857850, -0.677598779008155570, -0.677562006572455910, +-0.677525232442851570, -0.677488456619434130, -0.677451679102295650, -0.677414899891527480, -0.677378118987222550, -0.677341336389472250, -0.677304552098368600, -0.677267766114003300, +-0.677230978436468840, -0.677194189065856930, -0.677157398002259600, -0.677120605245768450, -0.677083810796476060, -0.677047014654474260, -0.677010216819854850, -0.676973417292709550, +-0.676936616073131050, -0.676899813161210950, -0.676863008557041400, -0.676826202260713990, -0.676789394272321320, -0.676752584591955310, -0.676715773219707440, -0.676678960155670420, +-0.676642145399936060, -0.676605328952596290, -0.676568510813742920, -0.676531690983468550, -0.676494869461864990, -0.676458046249024280, -0.676421221345038130, -0.676384394749999230, +-0.676347566463999290, -0.676310736487130470, -0.676273904819484460, -0.676237071461154080, -0.676200236412231040, -0.676163399672807360, -0.676126561242974770, -0.676089721122826170, +-0.676052879312453280, -0.676016035811947910, -0.675979190621402770, -0.675942343740909560, -0.675905495170560530, -0.675868644910447510, -0.675831792960663200, -0.675794939321299300, +-0.675758083992448080, -0.675721226974201450, -0.675684368266651900, -0.675647507869891580, -0.675610645784012420, -0.675573782009106340, -0.675536916545266040, -0.675500049392583570, +-0.675463180551150840, -0.675426310021060020, -0.675389437802403680, -0.675352563895273650, -0.675315688299761960, -0.675278811015961430, -0.675241932043963770, -0.675205051383861330, +-0.675168169035745950, -0.675131284999710420, -0.675094399275846690, -0.675057511864247010, -0.675020622765003190, -0.674983731978208160, -0.674946839503953730, -0.674909945342332280, +-0.674873049493435630, -0.674836151957356690, -0.674799252734187390, -0.674762351824019890, -0.674725449226946220, -0.674688544943059300, -0.674651638972450950, -0.674614731315213540, +-0.674577821971438900, -0.674540910941220150, -0.674503998224649020, -0.674467083821817640, -0.674430167732818830, -0.674393249957744630, -0.674356330496687310, -0.674319409349738770, +-0.674282486516992070, -0.674245561998539240, -0.674208635794472430, -0.674171707904883680, -0.674134778329866010, -0.674097847069511370, -0.674060914123912220, -0.674023979493160400, +-0.673987043177348920, -0.673950105176569840, -0.673913165490915510, -0.673876224120477870, -0.673839281065350070, -0.673802336325624030, -0.673765389901391900, -0.673728441792746600, +-0.673691491999780180, -0.673654540522585000, -0.673617587361253210, -0.673580632515877740, -0.673543675986550630, -0.673506717773364460, -0.673469757876411060, -0.673432796295783560, +-0.673395833031574240, -0.673358868083875240, -0.673321901452778700, -0.673284933138377780, -0.673247963140764520, -0.673210991460031380, -0.673174018096270420, -0.673137043049574670, +-0.673100066320036380, -0.673063087907747600, -0.673026107812801480, -0.672989126035289930, -0.672952142575305670, -0.672915157432940720, -0.672878170608288250, -0.672841182101440280, +-0.672804191912489410, -0.672767200041527680, -0.672730206488648340, -0.672693211253943430, -0.672656214337505440, -0.672619215739426730, -0.672582215459800240, -0.672545213498718210, +-0.672508209856273130, -0.672471204532557150, -0.672434197527663650, -0.672397188841684530, -0.672360178474712080, -0.672323166426839650, -0.672286152698159170, -0.672249137288763340, +-0.672212120198744320, -0.672175101428195370, -0.672138080977208730, -0.672101058845876790, -0.672064035034291910, -0.672027009542547350, -0.671989982370735150, -0.671952953518948020, +-0.671915922987278200, -0.671878890775818860, -0.671841856884662360, -0.671804821313901180, -0.671767784063627580, -0.671730745133934830, -0.671693704524915390, -0.671656662236661540, +-0.671619618269265750, -0.671582572622821170, -0.671545525297420290, -0.671508476293155130, -0.671471425610119190, -0.671434373248404710, -0.671397319208104190, -0.671360263489310220, +-0.671323206092115820, -0.671286147016613380, -0.671249086262895590, -0.671212023831054720, -0.671174959721184130, -0.671137893933376200, -0.671100826467723510, -0.671063757324318440, +-0.671026686503254250, -0.670989614004623420, -0.670952539828518550, -0.670915463975031880, -0.670878386444257010, -0.670841307236286100, -0.670804226351211730, -0.670767143789126940, +-0.670730059550124440, -0.670692973634296700, -0.670655886041736200, -0.670618796772536330, -0.670581705826789440, -0.670544613204588360, -0.670507518906025330, -0.670470422931193850, +-0.670433325280186400, -0.670396225953095560, -0.670359124950013820, -0.670322022271034660, -0.670284917916250440, -0.670247811885753890, -0.670210704179637460, -0.670173594797994650, +-0.670136483740917830, -0.670099371008499480, -0.670062256600832960, -0.670025140518010880, -0.669988022760125920, -0.669950903327270590, -0.669913782219538230, -0.669876659437021570, +-0.669839534979813190, -0.669802408848005680, -0.669765281041692420, -0.669728151560965990, -0.669691020405919210, -0.669653887576644460, -0.669616753073235430, -0.669579616895784490, +-0.669542479044384460, -0.669505339519127940, -0.669468198320108400, -0.669431055447418320, -0.669393910901150630, -0.669356764681397820, -0.669319616788253470, -0.669282467221810060, +-0.669245315982160190, -0.669208163069397340, -0.669171008483613990, -0.669133852224903180, -0.669096694293357500, -0.669059534689070310, -0.669022373412134330, -0.668985210462642370, +-0.668948045840687120, -0.668910879546361970, -0.668873711579759720, -0.668836541940973190, -0.668799370630094980, -0.668762197647218670, -0.668725022992436750, -0.668687846665842360, +-0.668650668667528090, -0.668613488997587440, -0.668576307656112980, -0.668539124643197540, -0.668501939958934590, -0.668464753603416730, -0.668427565576736990, -0.668390375878988090, +-0.668353184510263490, -0.668315991470656010, -0.668278796760258480, -0.668241600379163690, -0.668204402327465250, -0.668167202605255750, -0.668130001212628220, -0.668092798149675370, +-0.668055593416490900, -0.668018387013167400, -0.667981178939797910, -0.667943969196475250, -0.667906757783292890, -0.667869544700343650, -0.667832329947720240, -0.667795113525516350, +-0.667757895433824690, -0.667720675672738300, -0.667683454242349870, -0.667646231142753120, -0.667609006374040750, -0.667571779936305900, -0.667534551829641280, -0.667497322054140700, +-0.667460090609896640, -0.667422857497002480, -0.667385622715550800, -0.667348386265635420, -0.667311148147349040, -0.667273908360784820, -0.667236666906035450, -0.667199423783194740, +-0.667162178992355530, -0.667124932533610600, -0.667087684407053570, -0.667050434612777350, -0.667013183150874990, -0.666975930021439400, -0.666938675224564290, -0.666901418760342590, +-0.666864160628867220, -0.666826900830231220, -0.666789639364528290, -0.666752376231851130, -0.666715111432293120, -0.666677844965947060, -0.666640576832906670, -0.666603307033264760, +-0.666566035567114690, -0.666528762434549170, -0.666491487635662020, -0.666454211170546260, -0.666416933039294830, -0.666379653242000880, -0.666342371778757990, -0.666305088649659320, +-0.666267803854797450, -0.666230517394266530, -0.666193229268159270, -0.666155939476568930, -0.666118648019588420, -0.666081354897311570, -0.666044060109831420, -0.666006763657240990, +-0.665969465539633430, -0.665932165757102460, -0.665894864309741210, -0.665857561197642720, -0.665820256420899930, -0.665782949979606960, -0.665745641873856540, -0.665708332103742030, +-0.665671020669356350, -0.665633707570793430, -0.665596392808146310, -0.665559076381507800, -0.665521758290971930, -0.665484438536631750, -0.665447117118580400, -0.665409794036910920, +-0.665372469291717340, -0.665335142883092480, -0.665297814811129930, -0.665260485075922390, -0.665223153677564020, -0.665185820616147730, -0.665148485891766890, -0.665111149504514550, +-0.665073811454484630, -0.665036471741770160, -0.664999130366464630, -0.664961787328660850, -0.664924442628452850, -0.664887096265933900, -0.664849748241196800, -0.664812398554335720, +-0.664775047205443560, -0.664737694194613820, -0.664700339521939520, -0.664662983187514710, -0.664625625191432420, -0.664588265533786030, -0.664550904214668670, -0.664513541234174500, +-0.664476176592396330, -0.664438810289427750, -0.664401442325361800, -0.664364072700292630, -0.664326701414313270, -0.664289328467517090, -0.664251953859997360, -0.664214577591847990, +-0.664177199663162240, -0.664139820074033490, -0.664102438824554890, -0.664065055914820460, -0.664027671344923350, -0.663990285114956840, -0.663952897225014830, -0.663915507675190590, +-0.663878116465577710, -0.663840723596269110, -0.663803329067359060, -0.663765932878940700, -0.663728535031107400, -0.663691135523952540, -0.663653734357570140, -0.663616331532053460, +-0.663578927047495880, -0.663541520903990660, -0.663504113101632040, -0.663466703640513080, -0.663429292520727350, -0.663391879742368020, -0.663354465305529440, -0.663317049210304540, +-0.663279631456786810, -0.663242212045070280, -0.663204790975248320, -0.663167368247414290, -0.663129943861661460, -0.663092517818084200, -0.663055090116775550, -0.663017660757829310, +-0.662980229741338520, -0.662942797067397450, -0.662905362736099460, -0.662867926747538030, -0.662830489101806420, -0.662793049798998890, -0.662755608839208810, -0.662718166222529660, +-0.662680721949054810, -0.662643276018878510, -0.662605828432093920, -0.662568379188794520, -0.662530928289074450, -0.662493475733027080, -0.662456021520746010, -0.662418565652324600, +-0.662381108127857000, -0.662343648947436690, -0.662306188111157270, -0.662268725619112100, -0.662231261471395330, -0.662193795668100550, -0.662156328209321130, -0.662118859095150670, +-0.662081388325683310, -0.662043915901012530, -0.662006441821232030, -0.661968966086434960, -0.661931488696715920, -0.661894009652168050, -0.661856528952885270, -0.661819046598960740, +-0.661781562590489040, -0.661744076927563320, -0.661706589610277060, -0.661669100638724750, -0.661631610012999640, -0.661594117733195540, -0.661556623799405720, -0.661519128211724760, +-0.661481630970246040, -0.661444132075063140, -0.661406631526269550, -0.661369129323959860, -0.661331625468227210, -0.661294119959165540, -0.661256612796868200, -0.661219103981429690, +-0.661181593512943480, -0.661144081391503160, -0.661106567617202430, -0.661069052190135560, -0.661031535110396030, -0.660994016378077420, -0.660956495993274000, -0.660918973956079460, +-0.660881450266587400, -0.660843924924891410, -0.660806397931085860, -0.660768869285264350, -0.660731338987520790, -0.660693807037948440, -0.660656273436641910, -0.660618738183694650, +-0.660581201279200610, -0.660543662723253270, -0.660506122515947090, -0.660468580657375570, -0.660431037147632630, -0.660393491986811740, -0.660355945175007400, -0.660318396712313290, +-0.660280846598822800, -0.660243294834630510, -0.660205741419830130, -0.660168186354515240, -0.660130629638779550, -0.660093071272717660, -0.660055511256423140, -0.660017949589989830, +-0.659980386273511300, -0.659942821307082040, -0.659905254690795860, -0.659867686424746470, -0.659830116509027560, -0.659792544943733740, -0.659754971728958470, -0.659717396864795800, +-0.659679820351339320, -0.659642242188683610, -0.659604662376922280, -0.659567080916149020, -0.659529497806458310, -0.659491913047943860, -0.659454326640699700, -0.659416738584819310, +-0.659379148880397500, -0.659341557527527770, -0.659303964526304130, -0.659266369876820300, -0.659228773579170870, -0.659191175633449420, -0.659153576039750110, -0.659115974798166530, +-0.659078371908793260, -0.659040767371724120, -0.659003161187053040, -0.658965553354873830, -0.658927943875280970, -0.658890332748368280, -0.658852719974229670, -0.658815105552959080, +-0.658777489484650980, -0.658739871769399080, -0.658702252407297300, -0.658664631398440230, -0.658627008742921460, -0.658589384440835260, -0.658551758492275210, -0.658514130897336130, +-0.658476501656111710, -0.658438870768696120, -0.658401238235182930, -0.658363604055666960, -0.658325968230242030, -0.658288330759002170, -0.658250691642041090, -0.658213050879453700, +-0.658175408471333600, -0.658137764417775050, -0.658100118718871750, -0.658062471374718520, -0.658024822385409050, -0.657987171751037160, -0.657949519471697770, -0.657911865547484490, +-0.657874209978491550, -0.657836552764812790, -0.657798893906543000, -0.657761233403776010, -0.657723571256605850, -0.657685907465126450, -0.657648242029432620, -0.657610574949618280, +-0.657572906225777350, -0.657535235858003890, -0.657497563846392690, -0.657459890191037570, -0.657422214892032670, -0.657384537949471940, -0.657346859363450280, -0.657309179134061390, +-0.657271497261399220, -0.657233813745558670, -0.657196128586633570, -0.657158441784718050, -0.657120753339906270, -0.657083063252292820, -0.657045371521971730, -0.657007678149037270, +-0.656969983133583240, -0.656932286475704560, -0.656894588175495180, -0.656856888233049330, -0.656819186648460950, -0.656781483421824960, -0.656743778553235180, -0.656706072042785970, +-0.656668363890571370, -0.656630654096686080, -0.656592942661224140, -0.656555229584279920, -0.656517514865947230, -0.656479798506321100, -0.656442080505495460, -0.656404360863564350, +-0.656366639580622580, -0.656328916656764290, -0.656291192092083750, -0.656253465886674770, -0.656215738040632490, -0.656178008554050950, -0.656140277427024300, -0.656102544659646680, +-0.656064810252013020, -0.656027074204217240, -0.655989336516353940, -0.655951597188516810, -0.655913856220801120, -0.655876113613300780, -0.655838369366110060, -0.655800623479323220, +-0.655762875953035060, -0.655725126787339740, -0.655687375982331290, -0.655649623538104740, -0.655611869454754140, -0.655574113732373840, -0.655536356371057890, -0.655498597370901440, +-0.655460836731998510, -0.655423074454443370, -0.655385310538330270, -0.655347544983754250, -0.655309777790809460, -0.655272008959590040, -0.655234238490190360, -0.655196466382705460, +-0.655158692637229370, -0.655120917253856460, -0.655083140232680990, -0.655045361573798000, -0.655007581277301630, -0.654969799343285920, -0.654932015771846120, -0.654894230563076270, +-0.654856443717070860, -0.654818655233923910, -0.654780865113730680, -0.654743073356585330, -0.654705279962582320, -0.654667484931815700, -0.654629688264380730, -0.654591889960371540, +-0.654554090019882630, -0.654516288443008240, -0.654478485229843420, -0.654440680380482310, -0.654402873895019500, -0.654365065773549250, -0.654327256016166590, -0.654289444622965900, +-0.654251631594041210, -0.654213816929487770, -0.654176000629399730, -0.654138182693871810, -0.654100363122998020, -0.654062541916873630, -0.654024719075593010, -0.653986894599250410, +-0.653949068487940430, -0.653911240741757990, -0.653873411360797460, -0.653835580345153430, -0.653797747694920160, -0.653759913410192790, -0.653722077491065590, -0.653684239937633250, +-0.653646400749990030, -0.653608559928231080, -0.653570717472450770, -0.653532873382743680, -0.653495027659203980, -0.653457180301927120, -0.653419331311007270, -0.653381480686538780, +-0.653343628428616930, -0.653305774537335960, -0.653267919012790690, -0.653230061855075150, -0.653192203064284830, -0.653154342640513970, -0.653116480583857300, -0.653078616894409160, +-0.653040751572264710, -0.653002884617518430, -0.652965016030264910, -0.652927145810598520, -0.652889273958614620, -0.652851400474407480, -0.652813525358071910, -0.652775648609702160, +-0.652737770229393610, -0.652699890217240620, -0.652662008573337560, -0.652624125297779910, -0.652586240390661930, -0.652548353852078210, -0.652510465682123450, -0.652472575880892800, +-0.652434684448480630, -0.652396791384981860, -0.652358896690490740, -0.652321000365102650, -0.652283102408912070, -0.652245202822013810, -0.652207301604502130, -0.652169398756472620, +-0.652131494278019530, -0.652093588169237790, -0.652055680430221660, -0.652017771061066730, -0.651979860061867370, -0.651941947432717940, -0.651904033173714040, -0.651866117284950140, +-0.651828199766520840, -0.651790280618520730, -0.651752359841045180, -0.651714437434188890, -0.651676513398046330, -0.651638587732712220, -0.651600660438282020, -0.651562731514850220, +-0.651524800962511420, -0.651486868781360420, -0.651448934971492590, -0.651410999533002300, -0.651373062465984590, -0.651335123770533930, -0.651297183446745700, -0.651259241494714590, +-0.651221297914535420, -0.651183352706302570, -0.651145405870111720, -0.651107457406057350, -0.651069507314233960, -0.651031555594737130, -0.650993602247661450, -0.650955647273101850, +-0.650917690671152680, -0.650879732441909660, -0.650841772585467270, -0.650803811101920540, -0.650765847991363830, -0.650727883253892860, -0.650689916889602200, -0.650651948898586800, +-0.650613979280941110, -0.650576008036760970, -0.650538035166140620, -0.650500060669175320, -0.650462084545959440, -0.650424106796588690, -0.650386127421157760, -0.650348146419761020, +-0.650310163792494400, -0.650272179539452270, -0.650234193660729760, -0.650196206156421370, -0.650158217026622910, -0.650120226271428850, -0.650082233890934110, -0.650044239885233630, +-0.650006244254422770, -0.649968246998596340, -0.649930248117849270, -0.649892247612276260, -0.649854245481973010, -0.649816241727034120, -0.649778236347554610, -0.649740229343629180, +-0.649702220715353440, -0.649664210462822190, -0.649626198586130130, -0.649588185085372860, -0.649550169960645190, -0.649512153212042030, -0.649474134839658210, -0.649436114843589430, +-0.649398093223930270, -0.649360069980775890, -0.649322045114220980, -0.649284018624361360, -0.649245990511291620, -0.649207960775106900, -0.649169929415902010, -0.649131896433772560, +-0.649093861828813460, -0.649055825601119630, -0.649017787750786000, -0.648979748277908160, -0.648941707182580930, -0.648903664464899110, -0.648865620124958520, -0.648827574162853860, +-0.648789526578680160, -0.648751477372532470, -0.648713426544506260, -0.648675374094696670, -0.648637320023198520, -0.648599264330106730, -0.648561207015517120, -0.648523148079524490, +-0.648485087522224110, -0.648447025343710570, -0.648408961544079790, -0.648370896123426580, -0.648332829081846200, -0.648294760419433460, -0.648256690136284060, -0.648218618232492940, +-0.648180544708155340, -0.648142469563365960, -0.648104392798220740, -0.648066314412814590, -0.648028234407242330, -0.647990152781599770, -0.647952069535981940, -0.647913984670483780, +-0.647875898185200420, -0.647837810080227670, -0.647799720355660360, -0.647761629011593730, -0.647723536048122720, -0.647685441465343130, -0.647647345263349990, -0.647609247442238580, +-0.647571148002103580, -0.647533046943041150, -0.647494944265145980, -0.647456839968513550, -0.647418734053238690, -0.647380626519417300, -0.647342517367144320, -0.647304406596514670, +-0.647266294207624380, -0.647228180200568380, -0.647190064575441930, -0.647151947332340050, -0.647113828471358570, -0.647075707992592510, -0.647037585896137140, -0.646999462182087480, +-0.646961336850539580, -0.646923209901588250, -0.646885081335328960, -0.646846951151856640, -0.646808819351267220, -0.646770685933655830, -0.646732550899117630, -0.646694414247747760, +-0.646656275979642260, -0.646618136094895930, -0.646579994593604050, -0.646541851475862410, -0.646503706741766270, -0.646465560391410790, -0.646427412424890990, -0.646389262842303140, +-0.646351111643742040, -0.646312958829303290, -0.646274804399081690, -0.646236648353173400, -0.646198490691673570, -0.646160331414677440, -0.646122170522280160, -0.646084008014577770, +-0.646045843891665420, -0.646007678153638460, -0.645969510800591950, -0.645931341832622020, -0.645893171249823710, -0.645854999052292490, -0.645816825240123400, -0.645778649813412600, +-0.645740472772255210, -0.645702294116746290, -0.645664113846981860, -0.645625931963057290, -0.645587748465067830, -0.645549563353108650, -0.645511376627275980, -0.645473188287664760, +-0.645434998334370680, -0.645396806767488670, -0.645358613587114990, -0.645320418793344790, -0.645282222386273640, -0.645244024365996480, -0.645205824732609680, -0.645167623486208260, +-0.645129420626887720, -0.645091216154743410, -0.645053010069871370, -0.645014802372366750, -0.644976593062324800, -0.644938382139841780, -0.644900169605012730, -0.644861955457933230, +-0.644823739698698550, -0.644785522327404940, -0.644747303344147430, -0.644709082749021610, -0.644670860542122860, -0.644632636723547310, -0.644594411293390010, -0.644556184251746880, +-0.644517955598712830, -0.644479725334384250, -0.644441493458856370, -0.644403259972224700, -0.644365024874584580, -0.644326788166032280, -0.644288549846662950, -0.644250309916571950, +-0.644212068375855430, -0.644173825224608860, -0.644135580462927630, -0.644097334090907190, -0.644059086108643710, -0.644020836516232540, -0.643982585313769280, -0.643944332501349190, +-0.643906078079068630, -0.643867822047022860, -0.643829564405307480, -0.643791305154017950, -0.643753044293250420, -0.643714781823100380, -0.643676517743663300, -0.643638252055034550, +-0.643599984757310620, -0.643561715850586640, -0.643523445334958090, -0.643485173210521230, -0.643446899477371440, -0.643408624135604400, -0.643370347185315490, -0.643332068626601080, +-0.643293788459556430, -0.643255506684277330, -0.643217223300859060, -0.643178938309398210, -0.643140651709989910, -0.643102363502729980, -0.643064073687713900, -0.643025782265037930, +-0.642987489234797430, -0.642949194597088320, -0.642910898352005770, -0.642872600499646450, -0.642834301040105530, -0.642795999973478800, -0.642757697299861870, -0.642719393019350990, +-0.642681087132041640, -0.642642779638029180, -0.642604470537410100, -0.642566159830279870, -0.642527847516734310, -0.642489533596868670, -0.642451218070779650, -0.642412900938562510, +-0.642374582200313180, -0.642336261856127020, -0.642297939906100510, -0.642259616350329130, -0.642221291188908800, -0.642182964421934900, -0.642144636049503890, -0.642106306071711260, +-0.642067974488652940, -0.642029641300424280, -0.641991306507121880, -0.641952970108841230, -0.641914632105677780, -0.641876292497728150, -0.641837951285087690, -0.641799608467852440, +-0.641761264046117770, -0.641722918019980380, -0.641684570389535640, -0.641646221154879460, -0.641607870316107330, -0.641569517873315950, -0.641531163826600690, -0.641492808176057580, +-0.641454450921782100, -0.641416092063870850, -0.641377731602419400, -0.641339369537523570, -0.641301005869278960, -0.641262640597782260, -0.641224273723128960, -0.641185905245414520, +-0.641147535164735770, -0.641109163481188070, -0.641070790194867570, -0.641032415305869630, -0.640994038814291070, -0.640955660720227470, -0.640917281023774650, -0.640878899725028320, +-0.640840516824085050, -0.640802132321040440, -0.640763746215990640, -0.640725358509031010, -0.640686969200258360, -0.640648578289768290, -0.640610185777656830, -0.640571791664019450, +-0.640533395948952980, -0.640494998632553100, -0.640456599714915640, -0.640418199196136410, -0.640379797076311870, -0.640341393355537970, -0.640302988033910280, -0.640264581111525400, +-0.640226172588479030, -0.640187762464867300, -0.640149350740785720, -0.640110937416331180, -0.640072522491599290, -0.640034105966686080, -0.639995687841687260, -0.639957268116699620, +-0.639918846791818760, -0.639880423867140840, -0.639841999342761420, -0.639803573218777450, -0.639765145495284400, -0.639726716172378640, -0.639688285250155640, -0.639649852728712330, +-0.639611418608144410, -0.639572982888547580, -0.639534545570018540, -0.639496106652653330, -0.639457666136547640, -0.639419224021797630, -0.639380780308499760, -0.639342334996749970, +-0.639303888086644400, -0.639265439578278750, -0.639226989471749830, -0.639188537767153450, -0.639150084464585650, -0.639111629564142470, -0.639073173065920370, -0.639034714970015410, +-0.638996255276523710, -0.638957793985540980, -0.638919331097164140, -0.638880866611488910, -0.638842400528611190, -0.638803932848627910, -0.638765463571634660, -0.638726992697727810, +-0.638688520227003180, -0.638650046159557560, -0.638611570495486780, -0.638573093234887090, -0.638534614377854410, -0.638496133924485450, -0.638457651874876130, -0.638419168229122810, +-0.638380682987321090, -0.638342196149568110, -0.638303707715959570, -0.638265217686591720, -0.638226726061560610, -0.638188232840962930, -0.638149738024894720, -0.638111241613451790, +-0.638072743606731160, -0.638034244004828550, -0.637995742807840440, -0.637957240015862630, -0.637918735628992040, -0.637880229647324490, -0.637841722070956570, -0.637803212899983870, +-0.637764702134503540, -0.637726189774611370, -0.637687675820403870, -0.637649160271976710, -0.637610643129427060, -0.637572124392850830, -0.637533604062344160, -0.637495082138003210, +-0.637456558619924900, -0.637418033508205250, -0.637379506802940420, -0.637340978504226550, -0.637302448612160570, -0.637263917126838500, -0.637225384048356160, -0.637186849376810800, +-0.637148313112298360, -0.637109775254915080, -0.637071235804757000, -0.637032694761921260, -0.636994152126503680, -0.636955607898600730, -0.636917062078308450, -0.636878514665723870, +-0.636839965660943030, -0.636801415064062180, -0.636762862875177580, -0.636724309094386040, -0.636685753721783820, -0.636647196757467170, -0.636608638201532130, -0.636570078054075950, +-0.636531516315194560, -0.636492952984983980, -0.636454388063541380, -0.636415821550962770, -0.636377253447344640, -0.636338683752783130, -0.636300112467375170, -0.636261539591216900, +-0.636222965124404790, -0.636184389067034890, -0.636145811419204450, -0.636107232181009510, -0.636068651352546420, -0.636030068933911340, -0.635991484925201410, -0.635952899326512890, +-0.635914312137942030, -0.635875723359584980, -0.635837132991539100, -0.635798541033900320, -0.635759947486764900, -0.635721352350229860, -0.635682755624391470, -0.635644157309346200, +-0.635605557405190200, -0.635566955912020730, -0.635528352829933810, -0.635489748159025920, -0.635451141899393450, -0.635412534051133400, -0.635373924614342060, -0.635335313589115880, +-0.635296700975551020, -0.635258086773744850, -0.635219470983793390, -0.635180853605793240, -0.635142234639840650, -0.635103614086032890, -0.635064991944465970, -0.635026368215236610, +-0.634987742898441070, -0.634949115994176360, -0.634910487502538980, -0.634871857423625060, -0.634833225757531760, -0.634794592504355440, -0.634755957664192570, -0.634717321237139530, +-0.634678683223293460, -0.634640043622750840, -0.634601402435607920, -0.634562759661961300, -0.634524115301908000, -0.634485469355544510, -0.634446821822967300, -0.634408172704272740, +-0.634369521999557980, -0.634330869708919500, -0.634292215832453880, -0.634253560370257260, -0.634214903322427250, -0.634176244689059860, -0.634137584470251590, -0.634098922666099570, +-0.634060259276700400, -0.634021594302150440, -0.633982927742546280, -0.633944259597985060, -0.633905589868563270, -0.633866918554377380, -0.633828245655523980, -0.633789571172100220, +-0.633750895104202570, -0.633712217451927740, -0.633673538215371870, -0.633634857394632660, -0.633596174989806250, -0.633557491000989350, -0.633518805428278430, -0.633480118271770860, +-0.633441429531562910, -0.633402739207751140, -0.633364047300432830, -0.633325353809704340, -0.633286658735662590, -0.633247962078403730, -0.633209263838025340, -0.633170564014623900, +-0.633131862608295900, -0.633093159619138040, -0.633054455047247440, -0.633015748892720830, -0.632977041155654900, -0.632938331836145900, -0.632899620934291420, -0.632860908450187940, +-0.632822194383932280, -0.632783478735620690, -0.632744761505350750, -0.632706042693218840, -0.632667322299321540, -0.632628600323756340, -0.632589876766619600, -0.632551151628008120, +-0.632512424908018400, -0.632473696606748010, -0.632434966724293450, -0.632396235260751390, -0.632357502216218450, -0.632318767590791970, -0.632280031384568670, -0.632241293597645360, +-0.632202554230118400, -0.632163813282085370, -0.632125070753642880, -0.632086326644887620, -0.632047580955916290, -0.632008833686826250, -0.631970084837714220, -0.631931334408676880, +-0.631892582399810940, -0.631853828811213880, -0.631815073642982280, -0.631776316895212630, -0.631737558568002510, -0.631698798661448510, -0.631660037175647450, -0.631621274110696020, +-0.631582509466691700, -0.631543743243731190, -0.631504975441911200, -0.631466206061328530, -0.631427435102080660, -0.631388662564264180, -0.631349888447976130, -0.631311112753312980, +-0.631272335480372320, -0.631233556629250850, -0.631194776200045490, -0.631155994192852840, -0.631117210607770600, -0.631078425444895340, -0.631039638704323560, -0.631000850386153170, +-0.630962060490480540, -0.630923269017402810, -0.630884475967016580, -0.630845681339419540, -0.630806885134708170, -0.630768087352979730, -0.630729287994330590, -0.630690487058858660, +-0.630651684546660540, -0.630612880457833150, -0.630574074792473180, -0.630535267550678460, -0.630496458732545560, -0.630457648338171420, -0.630418836367652840, -0.630380022821087630, +-0.630341207698572270, -0.630302391000203580, -0.630263572726079250, -0.630224752876295870, -0.630185931450950810, -0.630147108450140440, -0.630108283873962670, -0.630069457722514210, +-0.630030629995892100, -0.629991800694193140, -0.629952969817514920, -0.629914137365954250, -0.629875303339608280, -0.629836467738573820, -0.629797630562948350, -0.629758791812828900, +-0.629719951488312500, -0.629681109589495860, -0.629642266116476780, -0.629603421069352080, -0.629564574448218670, -0.629525726253173600, -0.629486876484314560, -0.629448025141738370, +-0.629409172225541710, -0.629370317735822420, -0.629331461672677390, -0.629292604036203680, -0.629253744826498210, -0.629214884043658660, -0.629176021687781860, -0.629137157758965060, +-0.629098292257304960, -0.629059425182899590, -0.629020556535845540, -0.628981686316240070, -0.628942814524180220, -0.628903941159763560, -0.628865066223087020, -0.628826189714247860, +-0.628787311633342890, -0.628748431980469920, -0.628709550755725880, -0.628670667959207670, -0.628631783591013130, -0.628592897651239160, -0.628554010139982910, -0.628515121057341310, +-0.628476230403412270, -0.628437338178292610, -0.628398444382079590, -0.628359549014870120, -0.628320652076762130, -0.628281753567852540, -0.628242853488238500, -0.628203951838017030, +-0.628165048617286060, -0.628126143826142400, -0.628087237464683420, -0.628048329533006040, -0.628009420031208080, -0.627970508959386660, -0.627931596317638620, -0.627892682106061860, +-0.627853766324753430, -0.627814848973810570, -0.627775930053330320, -0.627737009563410500, -0.627698087504148240, -0.627659163875640690, -0.627620238677984890, -0.627581311911278860, +-0.627542383575619530, -0.627503453671104270, -0.627464522197830110, -0.627425589155894860, -0.627386654545395660, -0.627347718366429890, -0.627308780619094340, -0.627269841303487290, +-0.627230900419705640, -0.627191957967846440, -0.627153013948007600, -0.627114068360286270, -0.627075121204779710, -0.627036172481585050, -0.626997222190800340, -0.626958270332522490, +-0.626919316906848990, -0.626880361913876860, -0.626841405353704250, -0.626802447226428080, -0.626763487532145720, -0.626724526270954320, -0.626685563442952010, -0.626646599048235720, +-0.626607633086903040, -0.626568665559050890, -0.626529696464777300, -0.626490725804179640, -0.626451753577355050, -0.626412779784400800, -0.626373804425414900, -0.626334827500494520, +-0.626295849009736670, -0.626256868953239620, -0.626217887331100400, -0.626178904143416370, -0.626139919390284790, -0.626100933071803810, -0.626061945188070460, -0.626022955739182210, +-0.625983964725236210, -0.625944972146330710, -0.625905978002562760, -0.625866982294029820, -0.625827985020829150, -0.625788986183058780, -0.625749985780816090, -0.625710983814198320, +-0.625671980283302730, -0.625632975188227580, -0.625593968529070010, -0.625554960305927170, -0.625515950518897190, -0.625476939168077450, -0.625437926253565310, -0.625398911775458030, +-0.625359895733853750, -0.625320878128849730, -0.625281858960543560, -0.625242838229032480, -0.625203815934414540, -0.625164792076787100, -0.625125766656247640, -0.625086739672893410, +-0.625047711126822780, -0.625008681018132780, -0.624969649346921120, -0.624930616113284930, -0.624891581317322590, -0.624852544959131340, -0.624813507038808340, -0.624774467556451940, +-0.624735426512159300, -0.624696383906028220, -0.624657339738155740, -0.624618294008640220, -0.624579246717579030, -0.624540197865069760, -0.624501147451209550, -0.624462095476096880, +-0.624423041939829000, -0.624383986842503510, -0.624344930184217660, -0.624305871965069810, -0.624266812185157340, -0.624227750844577820, -0.624188687943428630, -0.624149623481807910, +-0.624110557459813250, -0.624071489877542240, -0.624032420735092020, -0.623993350032561180, -0.623954277770046970, -0.623915203947646770, -0.623876128565458820, -0.623837051623580610, +-0.623797973122109720, -0.623758893061143520, -0.623719811440780480, -0.623680728261117980, -0.623641643522253600, -0.623602557224284700, -0.623563469367309780, -0.623524379951426290, +-0.623485288976731720, -0.623446196443323660, -0.623407102351300480, -0.623368006700759420, -0.623328909491798420, -0.623289810724514840, -0.623250710399007040, -0.623211608515372490, +-0.623172505073708580, -0.623133400074113660, -0.623094293516685330, -0.623055185401521270, -0.623016075728718870, -0.622976964498376580, -0.622937851710591910, -0.622898737365462640, +-0.622859621463086150, -0.622820504003561040, -0.622781384986984540, -0.622742264413454700, -0.622703142283068780, -0.622664018595925350, -0.622624893352121900, -0.622585766551756240, +-0.622546638194925730, -0.622507508281729070, -0.622468376812263640, -0.622429243786626780, -0.622390109204917330, -0.622350973067232530, -0.622311835373670300, -0.622272696124328120, +-0.622233555319304580, -0.622194412958697150, -0.622155269042603650, -0.622116123571121670, -0.622076976544349680, -0.622037827962385270, -0.621998677825326250, -0.621959526133270320, +-0.621920372886315740, -0.621881218084560430, -0.621842061728101970, -0.621802903817037960, -0.621763744351467080, -0.621724583331486840, -0.621685420757194800, -0.621646256628689550, +-0.621607090946068700, -0.621567923709430150, -0.621528754918871380, -0.621489584574490990, -0.621450412676386790, -0.621411239224656460, -0.621372064219397720, -0.621332887660709150, +-0.621293709548688340, -0.621254529883433330, -0.621215348665041580, -0.621176165893611910, -0.621136981569241690, -0.621097795692029160, -0.621058608262071710, -0.621019419279468020, +-0.620980228744315910, -0.620941036656713190, -0.620901843016757440, -0.620862647824547590, -0.620823451080181000, -0.620784252783755490, -0.620745052935369630, -0.620705851535121140, +-0.620666648583108050, -0.620627444079428050, -0.620588238024179730, -0.620549030417460790, -0.620509821259369380, -0.620470610550002970, -0.620431398289460480, -0.620392184477839390, +-0.620352969115237850, -0.620313752201753550, -0.620274533737485310, -0.620235313722530600, -0.620196092156987680, -0.620156869040954130, -0.620117644374528880, -0.620078418157809400, +-0.620039190390893500, -0.619999961073880110, -0.619960730206866710, -0.619921497789951540, -0.619882263823232190, -0.619843028306807600, -0.619803791240775450, -0.619764552625233780, +-0.619725312460280400, -0.619686070746014120, -0.619646827482532640, -0.619607582669934100, -0.619568336308316200, -0.619529088397777870, -0.619489838938416800, -0.619450587930331140, +-0.619411335373618700, -0.619372081268378170, -0.619332825614707480, -0.619293568412704440, -0.619254309662467750, -0.619215049364095330, -0.619175787517685210, -0.619136524123335420, +-0.619097259181144550, -0.619057992691210530, -0.619018724653631610, -0.618979455068505490, -0.618940183935931090, -0.618900911256006210, -0.618861637028829010, -0.618822361254497410, +-0.618783083933110320, -0.618743805064765450, -0.618704524649561050, -0.618665242687595040, -0.618625959178966230, -0.618586674123772550, -0.618547387522112140, -0.618508099374083020, +-0.618468809679783900, -0.618429518439312820, -0.618390225652767580, -0.618350931320247100, -0.618311635441849190, -0.618272338017672340, -0.618233039047814240, -0.618193738532373920, +-0.618154436471449300, -0.618115132865138530, -0.618075827713539530, -0.618036521016751440, -0.617997212774871960, -0.617957902987999460, -0.617918591656231860, -0.617879278779668080, +-0.617839964358406160, -0.617800648392544340, -0.617761330882180550, -0.617722011827413710, -0.617682691228341850, -0.617643369085063010, -0.617604045397675990, -0.617564720166278950, +-0.617525393390970010, -0.617486065071847330, -0.617446735209009830, -0.617407403802555430, -0.617368070852582610, -0.617328736359189170, -0.617289400322474260, -0.617250062742535910, +-0.617210723619472380, -0.617171382953381590, -0.617132040744362790, -0.617092696992513900, -0.617053351697933180, -0.617014004860718890, -0.616974656480969830, -0.616935306558784150, +-0.616895955094259760, -0.616856602087495930, -0.616817247538590570, -0.616777891447642170, -0.616738533814748520, -0.616699174640009010, -0.616659813923521540, -0.616620451665384590, +-0.616581087865696100, -0.616541722524555300, -0.616502355642060130, -0.616462987218309060, -0.616423617253400220, -0.616384245747432670, -0.616344872700504420, -0.616305498112714070, +-0.616266121984159640, -0.616226744314940290, -0.616187365105154040, -0.616147984354899370, -0.616108602064274310, -0.616069218233378240, -0.616029832862309060, -0.615990445951164920, +-0.615951057500044970, -0.615911667509047470, -0.615872275978270770, -0.615832882907813130, -0.615793488297773470, -0.615754092148250170, -0.615714694459341680, -0.615675295231146060, +-0.615635894463762550, -0.615596492157289290, -0.615557088311824760, -0.615517682927467220, -0.615478276004315820, -0.615438867542468680, -0.615399457542024520, -0.615360046003081250, +-0.615320632925738130, -0.615281218310093530, -0.615241802156245580, -0.615202384464293430, -0.615162965234335330, -0.615123544466469770, -0.615084122160795000, -0.615044698317410380, +-0.615005272936413940, -0.614965846017904270, -0.614926417561979740, -0.614886987568739380, -0.614847556038281670, -0.614808122970704970, -0.614768688366107760, -0.614729252224589070, +-0.614689814546247270, -0.614650375331180940, -0.614610934579488340, -0.614571492291268730, -0.614532048466620350, -0.614492603105641580, -0.614453156208431550, -0.614413707775088750, +-0.614374257805711640, -0.614334806300398490, -0.614295353259248670, -0.614255898682360520, -0.614216442569832650, -0.614176984921763310, -0.614137525738251750, -0.614098065019396460, +-0.614058602765296000, -0.614019138976048760, -0.613979673651753880, -0.613940206792509930, -0.613900738398415410, -0.613861268469568680, -0.613821797006069200, -0.613782324008015130, +-0.613742849475504950, -0.613703373408638010, -0.613663895807512570, -0.613624416672227450, -0.613584936002881000, -0.613545453799572480, -0.613505970062400370, -0.613466484791463260, +-0.613426997986859620, -0.613387509648688820, -0.613348019777049340, -0.613308528372039750, -0.613269035433758440, -0.613229540962304980, -0.613190044957777620, -0.613150547420275080, +-0.613111048349895940, -0.613071547746739440, -0.613032045610904190, -0.612992541942488760, -0.612953036741591520, -0.612913530008312170, -0.612874021742748960, -0.612834511945000380, +-0.612795000615165790, -0.612755487753343760, -0.612715973359633010, -0.612676457434131900, -0.612636939976940130, -0.612597420988155950, -0.612557900467878170, -0.612518378416205380, +-0.612478854833236940, -0.612439329719071330, -0.612399803073807370, -0.612360274897543630, -0.612320745190379600, -0.612281213952413640, -0.612241681183744670, -0.612202146884471050, +-0.612162611054692500, -0.612123073694507470, -0.612083534804014340, -0.612043994383312700, -0.612004452432501120, -0.611964908951678320, -0.611925363940942990, -0.611885817400394600, +-0.611846269330131640, -0.611806719730253020, -0.611767168600857230, -0.611727615942043950, -0.611688061753911550, -0.611648506036558960, -0.611608948790084870, -0.611569390014588650, +-0.611529829710169000, -0.611490267876924840, -0.611450704514954540, -0.611411139624357890, -0.611371573205233390, -0.611332005257679610, -0.611292435781796150, -0.611252864777681590, +-0.611213292245434970, -0.611173718185154650, -0.611134142596940430, -0.611094565480890810, -0.611054986837104910, -0.611015406665681100, -0.610975824966719090, -0.610936241740317580, +-0.610896656986575360, -0.610857070705591250, -0.610817482897464850, -0.610777893562294620, -0.610738302700179700, -0.610698710311218700, -0.610659116395511290, -0.610619520953156080, +-0.610579923984252090, -0.610540325488897920, -0.610500725467193250, -0.610461123919236790, -0.610421520845127130, -0.610381916244964070, -0.610342310118846210, -0.610302702466872570, +-0.610263093289141860, -0.610223482585753650, -0.610183870356806880, -0.610144256602400350, -0.610104641322632870, -0.610065024517604030, -0.610025406187412740, -0.609985786332157940, +-0.609946164951938320, -0.609906542046853570, -0.609866917617002510, -0.609827291662484170, -0.609787664183397250, -0.609748035179841440, -0.609708404651915670, -0.609668772599718410, +-0.609629139023349700, -0.609589503922908120, -0.609549867298492700, -0.609510229150202250, -0.609470589478136700, -0.609430948282394520, -0.609391305563075080, -0.609351661320277070, +-0.609312015554100080, -0.609272368264643260, -0.609232719452005410, -0.609193069116285350, -0.609153417257583100, -0.609113763875997250, -0.609074108971626950, -0.609034452544571110, +-0.608994794594929440, -0.608955135122800750, -0.608915474128283950, -0.608875811611478750, -0.608836147572484050, -0.608796482011398910, -0.608756814928322340, -0.608717146323354050, +-0.608677476196592850, -0.608637804548137980, -0.608598131378088270, -0.608558456686543510, -0.608518780473602640, -0.608479102739364900, -0.608439423483928990, -0.608399742707394830, +-0.608360060409861350, -0.608320376591427790, -0.608280691252192860, -0.608241004392256590, -0.608201316011717790, -0.608161626110675260, -0.608121934689229150, -0.608082241747478160, +-0.608042547285521540, -0.608002851303458210, -0.607963153801388100, -0.607923454779410120, -0.607883754237623530, -0.607844052176127140, -0.607804348595021080, -0.607764643494404070, +-0.607724936874375450, -0.607685228735034170, -0.607645519076480120, -0.607605807898812240, -0.607566095202130010, -0.607526380986532000, -0.607486665252118470, -0.607446947998988350, +-0.607407229227240770, -0.607367508936974780, -0.607327787128290390, -0.607288063801286530, -0.607248338956062120, -0.607208612592717190, -0.607168884711350780, -0.607129155312062130, +-0.607089424394950280, -0.607049691960115270, -0.607009958007655890, -0.606970222537671740, -0.606930485550261630, -0.606890747045525700, -0.606851007023562870, -0.606811265484472510, +-0.606771522428353640, -0.606731777855306300, -0.606692031765429520, -0.606652284158822660, -0.606612535035584770, -0.606572784395815860, -0.606533032239615080, -0.606493278567081240, +-0.606453523378314600, -0.606413766673414180, -0.606374008452479350, -0.606334248715609150, -0.606294487462903600, -0.606254724694461840, -0.606214960410383360, -0.606175194610767080, +-0.606135427295713240, -0.606095658465320760, -0.606055888119689130, -0.606016116258917380, -0.605976342883105760, -0.605936567992353290, -0.605896791586759350, -0.605857013666423080, +-0.605817234231444730, -0.605777453281923120, -0.605737670817957710, -0.605697886839648310, -0.605658101347094300, -0.605618314340395040, -0.605578525819649550, -0.605538735784958200, +-0.605498944236420030, -0.605459151174134400, -0.605419356598200560, -0.605379560508718770, -0.605339762905787950, -0.605299963789507790, -0.605260163159977330, -0.605220361017296930, +-0.605180557361565510, -0.605140752192882770, -0.605100945511347740, -0.605061137317060680, -0.605021327610120840, -0.604981516390627690, -0.604941703658680390, -0.604901889414379060, +-0.604862073657823180, -0.604822256389111690, -0.604782437608344830, -0.604742617315621960, -0.604702795511042560, -0.604662972194705770, -0.604623147366711970, -0.604583321027160280, +-0.604543493176150300, -0.604503663813781180, -0.604463832940153270, -0.604424000555365830, -0.604384166659518330, -0.604344331252710030, -0.604304494335041410, -0.604264655906611380, +-0.604224815967519760, -0.604184974517865790, -0.604145131557749740, -0.604105287087270850, -0.604065441106528380, -0.604025593615622690, -0.603985744614652930, -0.603945894103718910, +-0.603906042082919760, -0.603866188552355740, -0.603826333512126450, -0.603786476962331230, -0.603746618903069470, -0.603706759334441510, -0.603666898256546620, -0.603627035669484500, +-0.603587171573354510, -0.603547305968256900, -0.603507438854291030, -0.603467570231556620, -0.603427700100152790, -0.603387828460180130, -0.603347955311737900, -0.603308080654925470, +-0.603268204489843200, -0.603228326816590330, -0.603188447635266690, -0.603148566945971630, -0.603108684748805410, -0.603068801043867510, -0.603028915831257620, -0.602989029111075100, +-0.602949140883420330, -0.602909251148392780, -0.602869359906092030, -0.602829467156617560, -0.602789572900069740, -0.602749677136548030, -0.602709779866152150, -0.602669881088981450, +-0.602629980805136300, -0.602590079014716280, -0.602550175717820770, -0.602510270914550120, -0.602470364605003810, -0.602430456789281530, -0.602390547467482770, -0.602350636639708000, +-0.602310724306056700, -0.602270810466628450, -0.602230895121522950, -0.602190978270840560, -0.602151059914680650, -0.602111140053143150, -0.602071218686327400, -0.602031295814334010, +-0.601991371437262330, -0.601951445555212290, -0.601911518168283250, -0.601871589276575800, -0.601831658880189300, -0.601791726979223670, -0.601751793573778390, -0.601711858663954050, +-0.601671922249849890, -0.601631984331565730, -0.601592044909201930, -0.601552103982857970, -0.601512161552633760, -0.601472217618628790, -0.601432272180943640, -0.601392325239677890, +-0.601352376794931250, -0.601312426846803310, -0.601272475395394630, -0.601232522440804830, -0.601192567983133700, -0.601152612022480830, -0.601112654558946690, -0.601072695592630990, +-0.601032735123633530, -0.600992773152053910, -0.600952809677992580, -0.600912844701549380, -0.600872878222823650, -0.600832910241916100, -0.600792940758926310, -0.600752969773954090, +-0.600712997287099150, -0.600673023298462060, -0.600633047808142310, -0.600593070816240030, -0.600553092322854810, -0.600513112328087020, -0.600473130832036570, -0.600433147834803280, +-0.600393163336486730, -0.600353177337187740, -0.600313189837005660, -0.600273200836040740, -0.600233210334392360, -0.600193218332161330, -0.600153224829447220, -0.600113229826349740, +-0.600073233322969580, -0.600033235319406330, -0.599993235815759920, -0.599953234812130140, -0.599913232308617590, -0.599873228305321970, -0.599833222802343300, -0.599793215799781180, +-0.599753207297736290, -0.599713197296308560, -0.599673185795597700, -0.599633172795703610, -0.599593158296726880, -0.599553142298767330, -0.599513124801924870, -0.599473105806299200, +-0.599433085311991240, -0.599393063319100470, -0.599353039827727030, -0.599313014837970730, -0.599272988349932150, -0.599232960363711210, -0.599192930879407390, -0.599152899897121730, +-0.599112867416953690, -0.599072833439003530, -0.599032797963370940, -0.598992760990156750, -0.598952722519460630, -0.598912682551382640, -0.598872641086022670, -0.598832598123481440, +-0.598792553663858750, -0.598752507707254630, -0.598712460253768790, -0.598672411303502350, -0.598632360856554690, -0.598592308913026280, -0.598552255473016710, -0.598512200536626790, +-0.598472144103956440, -0.598432086175105350, -0.598392026750174330, -0.598351965829263310, -0.598311903412472420, -0.598271839499901370, -0.598231774091651070, -0.598191707187821330, +-0.598151638788512300, -0.598111568893823890, -0.598071497503856800, -0.598031424618711060, -0.597991350238486710, -0.597951274363283660, -0.597911196993202830, -0.597871118128343930, +-0.597831037768807310, -0.597790955914692670, -0.597750872566101040, -0.597710787723132130, -0.597670701385885960, -0.597630613554463450, -0.597590524228964410, -0.597550433409488990, +-0.597510341096137100, -0.597470247289009770, -0.597430151988206810, -0.597390055193828480, -0.597349956905974700, -0.597309857124746270, -0.597269755850243330, -0.597229653082565930, +-0.597189548821814080, -0.597149443068088590, -0.597109335821489620, -0.597069227082117290, -0.597029116850071540, -0.596989005125453280, -0.596948891908362530, -0.596908777198899230, +-0.596868660997164400, -0.596828543303257850, -0.596788424117279950, -0.596748303439330610, -0.596708181269510970, -0.596668057607920740, -0.596627932454660390, -0.596587805809829950, +-0.596547677673530230, -0.596507548045861480, -0.596467416926923730, -0.596427284316817020, -0.596387150215642590, -0.596347014623500260, -0.596306877540490390, -0.596266738966712890, +-0.596226598902269030, -0.596186457347258610, -0.596146314301782000, -0.596106169765939330, -0.596066023739831530, -0.596025876223558740, -0.595985727217220760, -0.595945576720918970, +-0.595905424734753160, -0.595865271258823830, -0.595825116293230980, -0.595784959838075670, -0.595744801893457910, -0.595704642459478180, -0.595664481536236520, -0.595624319123833960, +-0.595584155222370630, -0.595543989831947010, -0.595503822952662910, -0.595463654584619690, -0.595423484727917280, -0.595383313382656150, -0.595343140548936440, -0.595302966226859190, +-0.595262790416524630, -0.595222613118032600, -0.595182434331484430, -0.595142254056980180, -0.595102072294620310, -0.595061889044504970, -0.595021704306735180, -0.594981518081411090, +-0.594941330368633280, -0.594901141168501790, -0.594860950481117760, -0.594820758306581430, -0.594780564644993180, -0.594740369496453040, -0.594700172861062470, -0.594659974738921400, +-0.594619775130130420, -0.594579574034789670, -0.594539371453000290, -0.594499167384862530, -0.594458961830476530, -0.594418754789943330, -0.594378546263363390, -0.594338336250836980, +-0.594298124752464460, -0.594257911768346970, -0.594217697298584650, -0.594177481343278190, -0.594137263902527520, -0.594097044976434230, -0.594056824565098120, -0.594016602668620110, +-0.593976379287100120, -0.593936154420639630, -0.593895928069338770, -0.593855700233298030, -0.593815470912617660, -0.593775240107399020, -0.593735007817742240, -0.593694774043748040, +-0.593654538785516440, -0.593614302043148910, -0.593574063816745600, -0.593533824106406760, -0.593493582912233750, -0.593453340234326720, -0.593413096072786360, -0.593372850427712930, +-0.593332603299207780, -0.593292354687371070, -0.593252104592303490, -0.593211853014105280, -0.593171599952877720, -0.593131345408721260, -0.593091089381736380, -0.593050831872023450, +-0.593010572879683840, -0.592970312404817790, -0.592930050447525890, -0.592889787007908510, -0.592849522086067120, -0.592809255682101850, -0.592768987796113090, -0.592728718428202180, +-0.592688447578469500, -0.592648175247015740, -0.592607901433941150, -0.592567626139347210, -0.592527349363334180, -0.592487071106002740, -0.592446791367453260, -0.592406510147787220, +-0.592366227447104880, -0.592325943265506920, -0.592285657603093820, -0.592245370459966840, -0.592205081836226550, -0.592164791731973450, -0.592124500147308110, -0.592084207082331890, +-0.592043912537145060, -0.592003616511848070, -0.591963319006542530, -0.591923020021328570, -0.591882719556307110, -0.591842417611578520, -0.591802114187244150, -0.591761809283404610, +-0.591721502900160460, -0.591681195037612300, -0.591640885695861370, -0.591600574875008390, -0.591560262575153820, -0.591519948796398350, -0.591479633538843250, -0.591439316802589210, +-0.591398998587736810, -0.591358678894386540, -0.591318357722639850, -0.591278035072597350, -0.591237710944359510, -0.591197385338027570, -0.591157058253702240, -0.591116729691484320, +-0.591076399651474180, -0.591036068133773410, -0.590995735138482360, -0.590955400665702070, -0.590915064715532900, -0.590874727288076440, -0.590834388383433160, -0.590794048001703990, +-0.590753706142989170, -0.590713362807390620, -0.590673017995008490, -0.590632671705943910, -0.590592323940297260, -0.590551974698170220, -0.590511623979663170, -0.590471271784877130, +-0.590430918113912570, -0.590390562966870980, -0.590350206343853050, -0.590309848244959250, -0.590269488670291160, -0.590229127619949280, -0.590188765094034730, -0.590148401092647770, +-0.590108035615890200, -0.590067668663862620, -0.590027300236665830, -0.589986930334400420, -0.589946558957167970, -0.589906186105069290, -0.589865811778204960, -0.589825435976675800, +-0.589785058700583510, -0.589744679950028550, -0.589704299725111740, -0.589663918025933990, -0.589623534852596660, -0.589583150205200580, -0.589542764083846320, -0.589502376488635460, +-0.589461987419668600, -0.589421596877046870, -0.589381204860870760, -0.589340811371241950, -0.589300416408261140, -0.589260019972029260, -0.589219622062647000, -0.589179222680216050, +-0.589138821824837010, -0.589098419496610900, -0.589058015695638430, -0.589017610422021280, -0.588977203675860150, -0.588936795457255970, -0.588896385766309430, -0.588855974603122220, +-0.588815561967795160, -0.588775147860428840, -0.588734732281124940, -0.588694315229984280, -0.588653896707107770, -0.588613476712596230, -0.588573055246551350, -0.588532632309073820, +-0.588492207900264690, -0.588451782020224630, -0.588411354669055590, -0.588370925846858130, -0.588330495553733290, -0.588290063789781880, -0.588249630555105710, -0.588209195849805470, +-0.588168759673982190, -0.588128322027736680, -0.588087882911170650, -0.588047442324384990, -0.588007000267480760, -0.587966556740558640, -0.587926111743720450, -0.587885665277066980, +-0.587845217340699060, -0.587804767934718360, -0.587764317059225830, -0.587723864714322360, -0.587683410900109000, -0.587642955616687450, -0.587602498864158500, -0.587562040642623300, +-0.587521580952182650, -0.587481119792938490, -0.587440657164991390, -0.587400193068442710, -0.587359727503393160, -0.587319260469944760, -0.587278791968198100, -0.587238321998254430, +-0.587197850560214670, -0.587157377654180630, -0.587116903280253120, -0.587076427438533060, -0.587035950129122240, -0.586995471352121490, -0.586954991107632160, -0.586914509395754960, +-0.586874026216591790, -0.586833541570243590, -0.586793055456811600, -0.586752567876396510, -0.586712078829100480, -0.586671588315024200, -0.586631096334268910, -0.586590602886935540, +-0.586550107973126010, -0.586509611592941240, -0.586469113746482470, -0.586428614433850410, -0.586388113655147310, -0.586347611410473980, -0.586307107699931110, -0.586266602523620950, +-0.586226095881644200, -0.586185587774102230, -0.586145078201095960, -0.586104567162727300, -0.586064054659097280, -0.586023540690307150, -0.585983025256457730, -0.585942508357651160, +-0.585901989993988240, -0.585861470165570440, -0.585820948872498580, -0.585780426114874690, -0.585739901892799790, -0.585699376206375020, -0.585658849055701540, -0.585618320440881250, +-0.585577790362015180, -0.585537258819204260, -0.585496725812550630, -0.585456191342155100, -0.585415655408119130, -0.585375118010543650, -0.585334579149530800, -0.585294038825181380, +-0.585253497037596990, -0.585212953786878430, -0.585172409073127840, -0.585131862896446140, -0.585091315256934920, -0.585050766154694980, -0.585010215589828570, -0.584969663562436510, +-0.584929110072620380, -0.584888555120481100, -0.584847998706120810, -0.584807440829640420, -0.584766881491141530, -0.584726320690725050, -0.584685758428493130, -0.584645194704546790, +-0.584604629518987170, -0.584564062871916200, -0.584523494763435240, -0.584482925193645420, -0.584442354162648000, -0.584401781670545020, -0.584361207717437600, -0.584320632303427120, +-0.584280055428614720, -0.584239477093102530, -0.584198897296991700, -0.584158316040383600, -0.584117733323379350, -0.584077149146081110, -0.584036563508590010, -0.583995976411007530, +-0.583955387853434700, -0.583914797835973780, -0.583874206358725890, -0.583833613421792070, -0.583793019025274700, -0.583752423169274670, -0.583711825853893580, -0.583671227079232580, +-0.583630626845393910, -0.583590025152478600, -0.583549422000588350, -0.583508817389824070, -0.583468211320288140, -0.583427603792081690, -0.583386994805306200, -0.583346384360062920, +-0.583305772456453990, -0.583265159094580650, -0.583224544274544400, -0.583183927996446470, -0.583143310260389120, -0.583102691066473390, -0.583062070414800630, -0.583021448305472980, +-0.582980824738591810, -0.582940199714258480, -0.582899573232574350, -0.582858945293641680, -0.582818315897561610, -0.582777685044435720, -0.582737052734365270, -0.582696418967452610, +-0.582655783743798890, -0.582615147063505700, -0.582574508926674170, -0.582533869333406900, -0.582493228283804900, -0.582452585777969770, -0.582411941816002860, -0.582371296398006440, +-0.582330649524081760, -0.582290001194330500, -0.582249351408853810, -0.582208700167754170, -0.582168047471132820, -0.582127393319090910, -0.582086737711730920, -0.582046080649154090, +-0.582005422131462000, -0.581964762158756030, -0.581924100731138540, -0.581883437848710770, -0.581842773511574430, -0.581802107719830760, -0.581761440473582140, -0.581720771772930020, +-0.581680101617975900, -0.581639430008821230, -0.581598756945568280, -0.581558082428318520, -0.581517406457173420, -0.581476729032234570, -0.581436050153604220, -0.581395369821383730, +-0.581354688035674470, -0.581314004796578910, -0.581273320104198190, -0.581232633958634230, -0.581191946359988390, -0.581151257308363030, -0.581110566803859530, -0.581069874846579570, +-0.581029181436624520, -0.580988486574096960, -0.580947790259098150, -0.580907092491729890, -0.580866393272093550, -0.580825692600291490, -0.580784990476425290, -0.580744286900596540, +-0.580703581872906830, -0.580662875393458400, -0.580622167462352850, -0.580581458079691530, -0.580540747245576920, -0.580500034960110490, -0.580459321223393830, -0.580418606035528640, +-0.580377889396617270, -0.580337171306761100, -0.580296451766062040, -0.580255730774621560, -0.580215008332542030, -0.580174284439925030, -0.580133559096872250, -0.580092832303485300, +-0.580052104059866620, -0.580011374366117600, -0.579970643222340150, -0.579929910628635860, -0.579889176585107080, -0.579848441091855290, -0.579807704148982080, -0.579766965756590040, +-0.579726225914780510, -0.579685484623655430, -0.579644741883316270, -0.579603997693865610, -0.579563252055405040, -0.579522504968036260, -0.579481756431860840, -0.579441006446981490, +-0.579400255013499570, -0.579359502131516990, -0.579318747801135240, -0.579277992022457110, -0.579237234795583980, -0.579196476120617640, -0.579155715997659910, -0.579114954426813160, +-0.579074191408178950, -0.579033426941859440, -0.578992661027955880, -0.578951893666571070, -0.578911124857806490, -0.578870354601763730, -0.578829582898545470, -0.578788809748253310, +-0.578748035150989050, -0.578707259106854390, -0.578666481615951910, -0.578625702678383200, -0.578584922294250290, -0.578544140463654770, -0.578503357186699100, -0.578462572463485200, +-0.578421786294114780, -0.578380998678689530, -0.578340209617312140, -0.578299419110084310, -0.578258627157107850, -0.578217833758484460, -0.578177038914316820, -0.578136242624706640, +-0.578095444889755510, -0.578054645709566110, -0.578013845084240030, -0.577973043013879420, -0.577932239498585850, -0.577891434538462030, -0.577850628133609550, -0.577809820284130530, +-0.577769010990126670, -0.577728200251700570, -0.577687388068954030, -0.577646574441988970, -0.577605759370907080, -0.577564942855811280, -0.577524124896803050, -0.577483305493984410, +-0.577442484647457290, -0.577401662357324260, -0.577360838623687030, -0.577320013446647410, -0.577279186826308190, -0.577238358762770850, -0.577197529256137650, -0.577156698306510400, +-0.577115865913991670, -0.577075032078683270, -0.577034196800687240, -0.576993360080105380, -0.576952521917040500, -0.576911682311594290, -0.576870841263869010, -0.576829998773966120, +-0.576789154841988560, -0.576748309468038230, -0.576707462652217060, -0.576666614394626960, -0.576625764695370640, -0.576584913554549880, -0.576544060972266850, -0.576503206948623340, +-0.576462351483722050, -0.576421494577665010, -0.576380636230553800, -0.576339776442491460, -0.576298915213579570, -0.576258052543920480, -0.576217188433615800, -0.576176322882768540, +-0.576135455891480520, -0.576094587459853870, -0.576053717587990290, -0.576012846275992920, -0.575971973523963340, -0.575931099332003820, -0.575890223700216250, -0.575849346628703460, +-0.575808468117567250, -0.575767588166909980, -0.575726706776833240, -0.575685823947440170, -0.575644939678832570, -0.575604053971112250, -0.575563166824382130, -0.575522278238744130, +-0.575481388214300390, -0.575440496751152830, -0.575399603849404360, -0.575358709509156910, -0.575317813730512720, -0.575276916513573600, -0.575236017858442470, -0.575195117765221480, +-0.575154216234012530, -0.575113313264917770, -0.575072408858040010, -0.575031503013481270, -0.574990595731343810, -0.574949687011729440, -0.574908776854741290, -0.574867865260481170, +-0.574826952229051000, -0.574786037760553810, -0.574745121855091520, -0.574704204512766490, -0.574663285733680530, -0.574622365517936660, -0.574581443865637030, -0.574540520776883670, +-0.574499596251778710, -0.574458670290425080, -0.574417742892924800, -0.574376814059380130, -0.574335883789893090, -0.574294952084566710, -0.574254018943502920, -0.574213084366804070, +-0.574172148354572200, -0.574131210906910330, -0.574090272023920380, -0.574049331705704380, -0.574008389952365470, -0.573967446764005460, -0.573926502140726940, -0.573885556082631810, +-0.573844608589823110, -0.573803659662402990, -0.573762709300473570, -0.573721757504137120, -0.573680804273496660, -0.573639849608654110, -0.573598893509711940, -0.573557935976772180, +-0.573516977009937980, -0.573476016609311360, -0.573435054774994680, -0.573394091507089980, -0.573353126805700390, -0.573312160670928050, -0.573271193102875220, -0.573230224101644040, +-0.573189253667337750, -0.573148281800058280, -0.573107308499907760, -0.573066333766989340, -0.573025357601405050, -0.572984380003257350, -0.572943400972648400, -0.572902420509681320, +-0.572861438614458150, -0.572820455287081360, -0.572779470527653100, -0.572738484336276500, -0.572697496713053810, -0.572656507658087180, -0.572615517171479070, -0.572574525253332520, +-0.572533531903749560, -0.572492537122832880, -0.572451540910684400, -0.572410543267407480, -0.572369544193104150, -0.572328543687876670, -0.572287541751828170, -0.572246538385060790, +-0.572205533587677120, -0.572164527359779180, -0.572123519701470350, -0.572082510612852760, -0.572041500094028770, -0.572000488145100740, -0.571959474766171820, -0.571918459957344250, +-0.571877443718720510, -0.571836426050402750, -0.571795406952494420, -0.571754386425097460, -0.571713364468314560, -0.571672341082247960, -0.571631316267000700, -0.571590290022675250, +-0.571549262349373750, -0.571508233247199460, -0.571467202716254510, -0.571426170756641590, -0.571385137368462860, -0.571344102551821780, -0.571303066306820260, -0.571262028633561130, +-0.571220989532146620, -0.571179949002679990, -0.571138907045263490, -0.571097863659999700, -0.571056818846990890, -0.571015772606340290, -0.570974724938150380, -0.570933675842523640, +-0.570892625319562420, -0.570851573369369870, -0.570810519992048460, -0.570769465187700780, -0.570728408956428960, -0.570687351298336590, -0.570646292213525810, -0.570605231702098870, +-0.570564169764159250, -0.570523106399809300, -0.570482041609151500, -0.570440975392288220, -0.570399907749322920, -0.570358838680357750, -0.570317768185495620, -0.570276696264838680, +-0.570235622918490280, -0.570194548146552900, -0.570153471949129020, -0.570112394326321210, -0.570071315278232850, -0.570030234804966060, -0.569989152906623770, -0.569948069583308130, +-0.569906984835122810, -0.569865898662169970, -0.569824811064551960, -0.569783722042372380, -0.569742631595733460, -0.569701539724738030, -0.569660446429488320, -0.569619351710087820, +-0.569578255566638990, -0.569537157999244540, -0.569496059008006710, -0.569454958593029190, -0.569413856754414250, -0.569372753492264790, -0.569331648806682970, -0.569290542697772350, +-0.569249435165635420, -0.569208326210374980, -0.569167215832093290, -0.569126104030893920, -0.569084990806879240, -0.569043876160151840, -0.569002760090814960, -0.568961642598971310, +-0.568920523684723570, -0.568879403348174110, -0.568838281589426400, -0.568797158408583140, -0.568756033805746910, -0.568714907781020300, -0.568673780334506660, -0.568632651466308700, +-0.568591521176529000, -0.568550389465270260, -0.568509256332635830, -0.568468121778728190, -0.568426985803650360, -0.568385848407504720, -0.568344709590394740, -0.568303569352422990, +-0.568262427693692400, -0.568221284614305320, -0.568180140114365350, -0.568138994193975070, -0.568097846853236940, -0.568056698092254560, -0.568015547911130400, -0.567974396309967490, +-0.567933243288868070, -0.567892088847935960, -0.567850932987273740, -0.567809775706984100, -0.567768617007169630, -0.567727456887934020, -0.567686295349379750, -0.567645132391609740, +-0.567603968014726460, -0.567562802218833710, -0.567521635004033960, -0.567480466370430150, -0.567439296318124730, -0.567398124847221520, -0.567356951957822990, -0.567315777650031610, +-0.567274601923951180, -0.567233424779684300, -0.567192246217333880, -0.567151066237002400, -0.567109884838793650, -0.567068702022810230, -0.567027517789155060, -0.566986332137930700, +-0.566945145069240870, -0.566903956583188150, -0.566862766679875560, -0.566821575359405690, -0.566780382621882240, -0.566739188467407900, -0.566697992896085580, -0.566656795908017760, +-0.566615597503308480, -0.566574397682060190, -0.566533196444375500, -0.566491993790358190, -0.566450789720110870, -0.566409584233736550, -0.566368377331337940, -0.566327169013018830, +-0.566285959278881700, -0.566244748129029700, -0.566203535563565510, -0.566162321582592830, -0.566121106186214250, -0.566079889374533020, -0.566038671147651610, -0.565997451505673930, +-0.565956230448702690, -0.565915007976840800, -0.565873784090191070, -0.565832558788857190, -0.565791332072941970, -0.565750103942547990, -0.565708874397779170, -0.565667643438738100, +-0.565626411065527910, -0.565585177278251420, -0.565543942077012310, -0.565502705461913390, -0.565461467433057590, -0.565420227990547920, -0.565378987134487860, -0.565337744864980450, +-0.565296501182128710, -0.565255256086035330, -0.565214009576804120, -0.565172761654537890, -0.565131512319339780, -0.565090261571312480, -0.565049009410559910, -0.565007755837184880, +-0.564966500851290410, -0.564925244452979310, -0.564883986642355510, -0.564842727419521680, -0.564801466784580760, -0.564760204737636550, -0.564718941278791740, -0.564677676408149590, +-0.564636410125812890, -0.564595142431885580, -0.564553873326470330, -0.564512602809670420, -0.564471330881588630, -0.564430057542328890, -0.564388782791994110, -0.564347506630687220, +-0.564306229058511240, -0.564264950075570090, -0.564223669681966580, -0.564182387877803840, -0.564141104663184790, -0.564099820038213350, -0.564058534002992330, -0.564017246557624640, +-0.563975957702214200, -0.563934667436863930, -0.563893375761676860, -0.563852082676756130, -0.563810788182205420, -0.563769492278127780, -0.563728194964626450, -0.563686896241804240, +-0.563645596109765170, -0.563604294568612050, -0.563562991618448250, -0.563521687259376680, -0.563480381491501150, -0.563439074314924680, -0.563397765729750530, -0.563356455736081620, +-0.563315144334021860, -0.563273831523674380, -0.563232517305141790, -0.563191201678528430, -0.563149884643937000, -0.563108566201470870, -0.563067246351232950, -0.563025925093327270, +-0.562984602427856750, -0.562943278354924750, -0.562901952874634180, -0.562860625987089190, -0.562819297692392470, -0.562777967990647610, -0.562736636881957520, -0.562695304366426120, +-0.562653970444156440, -0.562612635115251840, -0.562571298379815340, -0.562529960237950880, -0.562488620689761580, -0.562447279735350690, -0.562405937374821360, -0.562364593608277400, +-0.562323248435822040, -0.562281901857558110, -0.562240553873589840, -0.562199204484020280, -0.562157853688952550, -0.562116501488489910, -0.562075147882736380, -0.562033792871795000, +-0.561992436455769130, -0.561951078634761680, -0.561909719408877020, -0.561868358778218060, -0.561826996742888160, -0.561785633302990470, -0.561744268458629010, -0.561702902209906820, +-0.561661534556927470, -0.561620165499793880, -0.561578795038610300, -0.561537423173479660, -0.561496049904505080, -0.561454675231790820, -0.561413299155439800, -0.561371921675555610, +-0.561330542792241150, -0.561289162505600790, -0.561247780815737450, -0.561206397722754710, -0.561165013226755600, -0.561123627327844380, -0.561082240026124060, -0.561040851321698120, +-0.560999461214669590, -0.560958069705142950, -0.560916676793220990, -0.560875282479007420, -0.560833886762605260, -0.560792489644118760, -0.560751091123650960, -0.560709691201305200, +-0.560668289877185530, -0.560626887151395080, -0.560585483024037430, -0.560544077495215730, -0.560502670565034220, -0.560461262233595940, -0.560419852501004570, -0.560378441367363260, +-0.560337028832776140, -0.560295614897346470, -0.560254199561177720, -0.560212782824373150, -0.560171364687036990, -0.560129945149272390, -0.560088524211182940, -0.560047101872871880, +-0.560005678134443350, -0.559964252996000610, -0.559922826457647020, -0.559881398519486590, -0.559839969181622710, -0.559798538444158830, -0.559757106307198330, -0.559715672770845440, +-0.559674237835203310, -0.559632801500375530, -0.559591363766465570, -0.559549924633577440, -0.559508484101814420, -0.559467042171280290, -0.559425598842078210, -0.559384154114312530, +-0.559342707988086390, -0.559301260463503480, -0.559259811540667060, -0.559218361219681490, -0.559176909500650020, -0.559135456383676230, -0.559094001868863490, -0.559052545956316150, +-0.559011088646137360, -0.558969629938430470, -0.558928169833299960, -0.558886708330848970, -0.558845245431181190, -0.558803781134399990, -0.558762315440609610, -0.558720848349913530, +-0.558679379862415340, -0.558637909978218270, -0.558596438697426810, -0.558554966020144320, -0.558513491946474370, -0.558472016476520230, -0.558430539610386580, -0.558389061348176450, +-0.558347581689993770, -0.558306100635941660, -0.558264618186124720, -0.558223134340646300, -0.558181649099609540, -0.558140162463119150, -0.558098674431278250, -0.558057185004190770, +-0.558015694181959840, -0.557974201964690160, -0.557932708352484990, -0.557891213345447890, -0.557849716943682570, -0.557808219147293170, -0.557766719956383270, -0.557725219371056680, +-0.557683717391416530, -0.557642214017567530, -0.557600709249613020, -0.557559203087656610, -0.557517695531801970, -0.557476186582153370, -0.557434676238814380, -0.557393164501888250, +-0.557351651371479570, -0.557310136847691820, -0.557268620930628680, -0.557227103620393740, -0.557185584917091250, -0.557144064820824900, -0.557102543331698400, -0.557061020449815090, +-0.557019496175279680, -0.556977970508195420, -0.556936443448666330, -0.556894914996795660, -0.556853385152688230, -0.556811853916447270, -0.556770321288176610, -0.556728787267979810, +-0.556687251855961460, -0.556645715052224930, -0.556604176856874130, -0.556562637270012540, -0.556521096291744730, -0.556479553922174070, -0.556438010161404260, -0.556396465009539760, +-0.556354918466684170, -0.556313370532941280, -0.556271821208414450, -0.556230270493208610, -0.556188718387427010, -0.556147164891173550, -0.556105610004551940, -0.556064053727666540, +-0.556022496060621150, -0.555980937003519360, -0.555939376556464970, -0.555897814719562570, -0.555856251492915510, -0.555814686876627830, -0.555773120870803110, -0.555731553475545930, +-0.555689984690959870, -0.555648414517148530, -0.555606842954216470, -0.555565270002267300, -0.555523695661404910, -0.555482119931733020, -0.555440542813356200, -0.555398964306377920, +-0.555357384410902320, -0.555315803127032770, -0.555274220454874180, -0.555232636394530020, -0.555191050946104330, -0.555149464109700560, -0.555107875885423540, -0.555066286273376840, +-0.555024695273664380, -0.554983102886389860, -0.554941509111657850, -0.554899913949572170, -0.554858317400236280, -0.554816719463754990, -0.554775120140231890, -0.554733519429771120, +-0.554691917332476030, -0.554650313848451540, -0.554608708977801230, -0.554567102720629260, -0.554525495077039080, -0.554483886047135610, -0.554442275631022330, -0.554400663828803380, +-0.554359050640582440, -0.554317436066464220, -0.554275820106552410, -0.554234202760951030, -0.554192584029763790, -0.554150963913095480, -0.554109342411049810, -0.554067719523730350, +-0.554026095251241910, -0.553984469593688300, -0.553942842551173540, -0.553901214123801220, -0.553859584311676370, -0.553817953114902450, -0.553776320533583610, -0.553734686567823650, +-0.553693051217727380, -0.553651414483398500, -0.553609776364941020, -0.553568136862458760, -0.553526495976056520, -0.553484853705838000, -0.553443210051907440, -0.553401565014368440, +-0.553359918593325780, -0.553318270788883520, -0.553276621601145440, -0.553234971030215460, -0.553193319076198510, -0.553151665739198160, -0.553110011019318340, -0.553068354916663840, +-0.553026697431338480, -0.552985038563446380, -0.552943378313091260, -0.552901716680378130, -0.552860053665410580, -0.552818389268293080, -0.552776723489129100, -0.552735056328023780, +-0.552693387785080700, -0.552651717860404230, -0.552610046554098070, -0.552568373866267230, -0.552526699797015410, -0.552485024346446750, -0.552443347514665280, -0.552401669301775810, +-0.552359989707882140, -0.552318308733088070, -0.552276626377498640, -0.552234942641217640, -0.552193257524349330, -0.552151571026997410, -0.552109883149267010, -0.552068193891261830, +-0.552026503253086220, -0.551984811234844000, -0.551943117836640180, -0.551901423058578480, -0.551859726900763240, -0.551818029363298270, -0.551776330446288600, -0.551734630149838150, +-0.551692928474051160, -0.551651225419031330, -0.551609520984883920, -0.551567815171712720, -0.551526107979621650, -0.551484399408715520, -0.551442689459098580, -0.551400978130874740, +-0.551359265424148260, -0.551317551339023830, -0.551275835875605580, -0.551234119033997770, -0.551192400814304320, -0.551150681216630130, -0.551108960241079360, -0.551067237887756130, +-0.551025514156764370, -0.550983789048209330, -0.550942062562194690, -0.550900334698824930, -0.550858605458203980, -0.550816874840436950, -0.550775142845627670, -0.550733409473880500, +-0.550691674725299450, -0.550649938599989670, -0.550608201098054970, -0.550566462219599370, -0.550524721964728010, -0.550482980333544920, -0.550441237326154240, -0.550399492942660220, +-0.550357747183167770, -0.550316000047781030, -0.550274251536604250, -0.550232501649741360, -0.550190750387297700, -0.550148997749377200, -0.550107243736084110, -0.550065488347522560, +-0.550023731583797690, -0.549981973445013540, -0.549940213931274350, -0.549898453042684370, -0.549856690779348510, -0.549814927141371030, -0.549773162128855740, -0.549731395741907990, +-0.549689627980631810, -0.549647858845131450, -0.549606088335511170, -0.549564316451875980, -0.549522543194330030, -0.549480768562977670, -0.549438992557923060, -0.549397215179271310, +-0.549355436427126590, -0.549313656301593120, -0.549271874802775280, -0.549230091930778100, -0.549188307685705700, -0.549146522067662460, -0.549104735076752610, -0.549062946713081310, +-0.549021156976752580, -0.548979365867870660, -0.548937573386540700, -0.548895779532866720, -0.548853984306953310, -0.548812187708904610, -0.548770389738825860, -0.548728590396820980, +-0.548686789682994780, -0.548644987597451170, -0.548603184140295410, -0.548561379311631850, -0.548519573111564630, -0.548477765540198230, -0.548435956597637770, -0.548394146283987420, +-0.548352334599351730, -0.548310521543834860, -0.548268707117541940, -0.548226891320577340, -0.548185074153045070, -0.548143255615050620, -0.548101435706697890, -0.548059614428091590, +-0.548017791779335960, -0.547975967760536140, -0.547934142371796500, -0.547892315613221380, -0.547850487484915270, -0.547808657986983190, -0.547766827119529510, -0.547724994882658690, +-0.547683161276475090, -0.547641326301083860, -0.547599489956589470, -0.547557652243096270, -0.547515813160708520, -0.547473972709531690, -0.547432130889669800, -0.547390287701227770, +-0.547348443144309530, -0.547306597219020530, -0.547264749925465140, -0.547222901263747400, -0.547181051233972870, -0.547139199836245700, -0.547097347070670480, -0.547055492937351560, +-0.547013637436394200, -0.546971780567902850, -0.546929922331982010, -0.546888062728736020, -0.546846201758270150, -0.546804339420688850, -0.546762475716096710, -0.546720610644597980, +-0.546678744206298140, -0.546636876401301430, -0.546595007229712440, -0.546553136691635630, -0.546511264787176380, -0.546469391516438920, -0.546427516879527620, -0.546385640876547950, +-0.546343763507604050, -0.546301884772800840, -0.546260004672242560, -0.546218123206034580, -0.546176240374281360, -0.546134356177087500, -0.546092470614557350, -0.546050583686796490, +-0.546008695393909060, -0.545966805735999980, -0.545924914713173500, -0.545883022325535090, -0.545841128573189120, -0.545799233456240260, -0.545757336974793010, -0.545715439128952820, +-0.545673539918823950, -0.545631639344510980, -0.545589737406119160, -0.545547834103753070, -0.545505929437517410, -0.545464023407516540, -0.545422116013855930, -0.545380207256640050, +-0.545338297135973700, -0.545296385651961150, -0.545254472804708070, -0.545212558594318830, -0.545170643020898130, -0.545128726084550430, -0.545086807785381430, -0.545044888123495270, +-0.545002967098996980, -0.544961044711990810, -0.544919120962582440, -0.544877195850876350, -0.544835269376977130, -0.544793341540989460, -0.544751412343018830, -0.544709481783169580, +-0.544667549861546310, -0.544625616578254480, -0.544583681933398680, -0.544541745927083600, -0.544499808559413930, -0.544457869830494930, -0.544415929740431400, -0.544373988289327930, +-0.544332045477289190, -0.544290101304420680, -0.544248155770826970, -0.544206208876612750, -0.544164260621882720, -0.544122311006742470, -0.544080360031296340, -0.544038407695649370, +-0.543996453999906040, -0.543954498944171800, -0.543912542528551480, -0.543870584753149310, -0.543828625618071100, -0.543786665123421330, -0.543744703269304910, -0.543702740055826310, +-0.543660775483091330, -0.543618809551204340, -0.543576842260270250, -0.543534873610393770, -0.543492903601680570, -0.543450932234235020, -0.543408959508162040, -0.543366985423566430, +-0.543325009980553660, -0.543283033179228440, -0.543241055019695550, -0.543199075502059700, -0.543157094626426470, -0.543115112392900560, -0.543073128801586540, -0.543031143852589990, +-0.542989157546015620, -0.542947169881968340, -0.542905180860552840, -0.542863190481874590, -0.542821198746038510, -0.542779205653149410, -0.542737211203311860, -0.542695215396631790, +-0.542653218233213550, -0.542611219713162280, -0.542569219836582570, -0.542527218603580330, -0.542485216014259920, -0.542443212068726480, -0.542401206767084590, -0.542359200109440160, +-0.542317192095897680, -0.542275182726561830, -0.542233172001538420, -0.542191159920932140, -0.542149146484847800, -0.542107131693390420, -0.542065115546665480, -0.542023098044777660, +-0.541981079187832230, -0.541939058975933750, -0.541897037409187930, -0.541855014487699460, -0.541812990211573590, -0.541770964580914780, -0.541728937595828960, -0.541686909256420710, +-0.541644879562795280, -0.541602848515057240, -0.541560816113312530, -0.541518782357665710, -0.541476747248221920, -0.541434710785085980, -0.541392672968363580, -0.541350633798159400, +-0.541308593274578360, -0.541266551397726280, -0.541224508167707730, -0.541182463584627960, -0.541140417648591550, -0.541098370359704540, -0.541056321718071610, -0.541014271723797900, +-0.540972220376988110, -0.540930167677748150, -0.540888113626182720, -0.540846058222397060, -0.540804001466495880, -0.540761943358585070, -0.540719883898769460, -0.540677823087154060, +-0.540635760923843690, -0.540593697408944360, -0.540551632542560780, -0.540509566324797740, -0.540467498755761170, -0.540425429835555860, -0.540383359564286960, -0.540341287942059270, +-0.540299214968978700, -0.540257140645150180, -0.540215064970678730, -0.540172987945669260, -0.540130909570227800, -0.540088829844458940, -0.540046748768468030, -0.540004666342359880, +-0.539962582566240520, -0.539920497440214640, -0.539878410964387490, -0.539836323138863980, -0.539794233963749930, -0.539752143439150460, -0.539710051565170160, -0.539667958341915170, +-0.539625863769490180, -0.539583767848000550, -0.539541670577551200, -0.539499571958248050, -0.539457471990195890, -0.539415370673500090, -0.539373268008265570, -0.539331163994598130, +-0.539289058632602790, -0.539246951922384920, -0.539204843864049210, -0.539162734457701800, -0.539120623703447490, -0.539078511601391640, -0.539036398151639170, -0.538994283354296110, +-0.538952167209467260, -0.538910049717258090, -0.538867930877773290, -0.538825810691119120, -0.538783689157400380, -0.538741566276722090, -0.538699442049190290, -0.538657316474909780, +-0.538615189553986130, -0.538573061286524050, -0.538530931672629660, -0.538488800712407900, -0.538446668405964220, -0.538404534753403440, -0.538362399754831800, -0.538320263410354110, +-0.538278125720075720, -0.538235986684101660, -0.538193846302537970, -0.538151704575489780, -0.538109561503062220, -0.538067417085360430, -0.538025271322490450, -0.537983124214557300, +-0.537940975761666000, -0.537898825963922580, -0.537856674821432180, -0.537814522334300050, -0.537772368502631220, -0.537730213326531810, -0.537688056806106870, -0.537645898941461860, +-0.537603739732701700, -0.537561579179932520, -0.537519417283259470, -0.537477254042787900, -0.537435089458622730, -0.537392923530870200, -0.537350756259635460, -0.537308587645023760, +-0.537266417687140230, -0.537224246386091010, -0.537182073741981240, -0.537139899754915830, -0.537097724425001030, -0.537055547752341990, -0.537013369737044060, -0.536971190379212370, +-0.536929009678952960, -0.536886827636371190, -0.536844644251572190, -0.536802459524661320, -0.536760273455744620, -0.536718086044927320, -0.536675897292314690, -0.536633707198011960, +-0.536591515762125380, -0.536549322984759990, -0.536507128866021370, -0.536464933406014420, -0.536422736604845630, -0.536380538462619900, -0.536338338979442500, -0.536296138155419650, +-0.536253935990656410, -0.536211732485258330, -0.536169527639330570, -0.536127321452979370, -0.536085113926309860, -0.536042905059427640, -0.536000694852437620, -0.535958483305446380, +-0.535916270418558830, -0.535874056191880670, -0.535831840625516920, -0.535789623719574060, -0.535747405474157110, -0.535705185889371550, -0.535662964965322730, -0.535620742702116900, +-0.535578519099859100, -0.535536294158655110, -0.535494067878609980, -0.535451840259830060, -0.535409611302420490, -0.535367381006486620, -0.535325149372134600, -0.535282916399469680, +-0.535240682088597540, -0.535198446439623220, -0.535156209452653300, -0.535113971127792690, -0.535071731465147300, -0.535029490464822180, -0.534987248126923660, -0.534945004451557020, +-0.534902759438827920, -0.534860513088841530, -0.534818265401704180, -0.534776016377521150, -0.534733766016398220, -0.534691514318440420, -0.534649261283754120, -0.534607006912444780, +-0.534564751204617550, -0.534522494160378780, -0.534480235779833720, -0.534437976063088180, -0.534395715010247300, -0.534353452621417420, -0.534311188896704040, -0.534268923836212610, +-0.534226657440048490, -0.534184389708318160, -0.534142120641126760, -0.534099850238580090, -0.534057578500783500, -0.534015305427843260, -0.533973031019864820, -0.533930755276953770, +-0.533888478199215370, -0.533846199786756290, -0.533803920039681580, -0.533761638958096810, -0.533719356542108230, -0.533677072791821310, -0.533634787707341740, -0.533592501288774780, +-0.533550213536226890, -0.533507924449803550, -0.533465634029610340, -0.533423342275752720, -0.533381049188337180, -0.533338754767468840, -0.533296459013253730, -0.533254161925797110, +-0.533211863505205440, -0.533169563751584090, -0.533127262665038850, -0.533084960245675090, -0.533042656493599280, -0.533000351408916770, -0.532958044991733490, -0.532915737242154690, +-0.532873428160286930, -0.532831117746235590, -0.532788806000106030, -0.532746492922004930, -0.532704178512037550, -0.532661862770309690, -0.532619545696926820, -0.532577227291995410, +-0.532534907555621050, -0.532492586487909310, -0.532450264088965790, -0.532407940358897050, -0.532365615297808350, -0.532323288905805600, -0.532280961182994280, -0.532238632129480970, +-0.532196301745371030, -0.532153970030770360, -0.532111636985784450, -0.532069302610519770, -0.532026966905081890, -0.531984629869576060, -0.531942291504109210, -0.531899951808786460, +-0.531857610783713960, -0.531815268428997070, -0.531772924744742360, -0.531730579731055310, -0.531688233388041720, -0.531645885715807290, -0.531603536714458480, -0.531561186384100880, +-0.531518834724840290, -0.531476481736782190, -0.531434127420033380, -0.531391771774699100, -0.531349414800885490, -0.531307056498697920, -0.531264696868243070, -0.531222335909626530, +-0.531179973622953770, -0.531137610008331480, -0.531095245065865140, -0.531052878795660650, -0.531010511197823610, -0.530968142272460700, -0.530925772019677390, -0.530883400439579600, +-0.530841027532273020, -0.530798653297864240, -0.530756277736458840, -0.530713900848162720, -0.530671522633081480, -0.530629143091321810, -0.530586762222989170, -0.530544380028189820, +-0.530501996507029010, -0.530459611659613640, -0.530417225486049190, -0.530374837986441360, -0.530332449160896720, -0.530290059009521090, -0.530247667532420250, -0.530205274729699920, +-0.530162880601466660, -0.530120485147826280, -0.530078088368884700, -0.530035690264747390, -0.529993290835521380, -0.529950890081312130, -0.529908488002225560, -0.529866084598367480, +-0.529823679869844580, -0.529781273816762430, -0.529738866439227070, -0.529696457737344200, -0.529654047711220600, -0.529611636360961870, -0.529569223686674030, -0.529526809688462770, +-0.529484394366434800, -0.529441977720695900, -0.529399559751351670, -0.529357140458508900, -0.529314719842273300, -0.529272297902750880, -0.529229874640047340, -0.529187450054269480, +-0.529145024145523110, -0.529102596913914040, -0.529060168359548170, -0.529017738482532200, -0.528975307282971930, -0.528932874760973390, -0.528890440916642280, -0.528848005750085500, +-0.528805569261408650, -0.528763131450717850, -0.528720692318118910, -0.528678251863718530, -0.528635810087622620, -0.528593366989936750, -0.528550922570767860, -0.528508476830221620, +-0.528466029768404180, -0.528423581385421340, -0.528381131681379900, -0.528338680656385670, -0.528296228310544680, -0.528253774643962840, -0.528211319656746840, -0.528168863349002590, +-0.528126405720836130, -0.528083946772353370, -0.528041486503661010, -0.527999024914865060, -0.527956562006071440, -0.527914097777386070, -0.527871632228915870, -0.527829165360766520, +-0.527786697173043940, -0.527744227665854940, -0.527701756839305420, -0.527659284693501540, -0.527616811228548980, -0.527574336444554870, -0.527531860341624800, -0.527489382919865140, +-0.527446904179381670, -0.527404424120281320, -0.527361942742669900, -0.527319460046653530, -0.527276976032338250, -0.527234490699830860, -0.527192004049237270, -0.527149516080663630, +-0.527107026794215840, -0.527064536190000930, -0.527022044268124600, -0.526979551028693200, -0.526937056471812440, -0.526894560597589550, -0.526852063406130220, -0.526809564897540270, +-0.526767065071926940, -0.526724563929395820, -0.526682061470053360, -0.526639557694005280, -0.526597052601358810, -0.526554546192219640, -0.526512038466694140, -0.526469529424888120, +-0.526427019066908700, -0.526384507392861690, -0.526341994402853340, -0.526299480096989790, -0.526256964475377840, -0.526214447538123410, -0.526171929285332960, -0.526129409717112310, +-0.526086888833568470, -0.526044366634807470, -0.526001843120935120, -0.525959318292058550, -0.525916792148283680, -0.525874264689716760, -0.525831735916463930, -0.525789205828632090, +-0.525746674426327170, -0.525704141709655630, -0.525661607678723390, -0.525619072333637470, -0.525576535674503910, -0.525533997701428950, -0.525491458414518610, -0.525448917813880030, +-0.525406375899619140, -0.525363832671842280, -0.525321288130655590, -0.525278742276165890, -0.525236195108479410, -0.525193646627702180, -0.525151096833941010, -0.525108545727302260, +-0.525065993307892050, -0.525023439575816540, -0.524980884531182750, -0.524938328174096800, -0.524895770504664960, -0.524853211522993360, -0.524810651229189130, -0.524768089623358300, +-0.524725526705607130, -0.524682962476041850, -0.524640396934769600, -0.524597830081896200, -0.524555261917528330, -0.524512692441771900, -0.524470121654734170, -0.524427549556521040, +-0.524384976147238780, -0.524342401426994400, -0.524299825395893930, -0.524257248054044060, -0.524214669401550590, -0.524172089438520780, -0.524129508165060880, -0.524086925581277120, +-0.524044341687275650, -0.524001756483163720, -0.523959169969047460, -0.523916582145033230, -0.523873993011227170, -0.523831402567736410, -0.523788810814667330, -0.523746217752126150, +-0.523703623380219030, -0.523661027699053210, -0.523618430708734820, -0.523575832409370330, -0.523533232801066010, -0.523490631883928860, -0.523448029658065140, -0.523405426123580990, +-0.523362821280583650, -0.523320215129179370, -0.523277607669474400, -0.523234998901575100, -0.523192388825588610, -0.523149777441621280, -0.523107164749779360, -0.523064550750169220, +-0.523021935442898100, -0.522979318828072140, -0.522936700905797910, -0.522894081676181450, -0.522851461139330230, -0.522808839295350380, -0.522766216144348370, -0.522723591686430460, +-0.522680965921703990, -0.522638338850275110, -0.522595710472249950, -0.522553080787735880, -0.522510449796839140, -0.522467817499666310, -0.522425183896323530, -0.522382548986918160, +-0.522339912771556450, -0.522297275250344860, -0.522254636423389870, -0.522211996290798510, -0.522169354852677240, -0.522126712109132530, -0.522084068060270750, -0.522041422706199130, +-0.521998776047023940, -0.521956128082851860, -0.521913478813789020, -0.521870828239942910, -0.521828176361419650, -0.521785523178325610, -0.521742868690768140, -0.521700212898853600, +-0.521657555802688360, -0.521614897402378990, -0.521572237698032740, -0.521529576689755750, -0.521486914377654930, -0.521444250761836540, -0.521401585842407700, -0.521358919619475000, +-0.521316252093145030, -0.521273583263524020, -0.521230913130719450, -0.521188241694837570, -0.521145568955985070, -0.521102894914268310, -0.521060219569794650, -0.521017542922670550, +-0.520974864973002490, -0.520932185720896830, -0.520889505166461260, -0.520846823309801810, -0.520804140151024940, -0.520761455690238020, -0.520718769927547620, -0.520676082863060220, +-0.520633394496882170, -0.520590704829121180, -0.520548013859883250, -0.520505321589275430, -0.520462628017403840, -0.520419933144376070, -0.520377236970298470, -0.520334539495277750, +-0.520291840719420360, -0.520249140642833670, -0.520206439265624150, -0.520163736587898610, -0.520121032609763280, -0.520078327331325860, -0.520035620752692500, -0.519992912873969760, +-0.519950203695265010, -0.519907493216684950, -0.519864781438336030, -0.519822068360324740, -0.519779353982758760, -0.519736638305744350, -0.519693921329388300, -0.519651203053797080, +-0.519608483479078290, -0.519565762605338270, -0.519523040432683820, -0.519480316961221430, -0.519437592191058560, -0.519394866122301790, -0.519352138755057810, -0.519309410089433100, +-0.519266680125535230, -0.519223948863470790, -0.519181216303345900, -0.519138482445268500, -0.519095747289344820, -0.519053010835681780, -0.519010273084385850, -0.518967534035564610, +-0.518924793689324540, -0.518882052045772530, -0.518839309105014970, -0.518796564867159530, -0.518753819332312570, -0.518711072500581240, -0.518668324372071670, -0.518625574946891770, +-0.518582824225148010, -0.518540072206947090, -0.518497318892395590, -0.518454564281601190, -0.518411808374670380, -0.518369051171710060, -0.518326292672826710, -0.518283532878128120, +-0.518240771787720540, -0.518198009401710790, -0.518155245720206330, -0.518112480743313730, -0.518069714471139920, -0.518026946903791470, -0.517984178041376090, -0.517941407884000230, +-0.517898636431770810, -0.517855863684794420, -0.517813089643178850, -0.517770314307030470, -0.517727537676456300, -0.517684759751562920, -0.517641980532458020, -0.517599200019248200, +-0.517556418212040350, -0.517513635110941060, -0.517470850716058140, -0.517428065027498050, -0.517385278045367380, -0.517342489769773930, -0.517299700200824160, -0.517256909338625230, +-0.517214117183283690, -0.517171323734907150, -0.517128528993602400, -0.517085732959476240, -0.517042935632635370, -0.517000137013187590, -0.516957337101239480, -0.516914535896897950, +-0.516871733400269710, -0.516828929611462540, -0.516786124530583150, -0.516743318157738330, -0.516700510493034780, -0.516657701536580420, -0.516614891288481810, -0.516572079748845560, +-0.516529266917779560, -0.516486452795390290, -0.516443637381785000, -0.516400820677070160, -0.516358002681353680, -0.516315183394742140, -0.516272362817342790, -0.516229540949261990, +-0.516186717790607760, -0.516143893341486800, -0.516101067602006030, -0.516058240572272230, -0.516015412252393220, -0.515972582642475700, -0.515929751742626670, -0.515886919552952960, +-0.515844086073562250, -0.515801251304561340, -0.515758415246056920, -0.515715577898156920, -0.515672739260967910, -0.515629899334597020, -0.515587058119151060, -0.515544215614737840, +-0.515501371821464050, -0.515458526739436820, -0.515415680368762950, -0.515372832709550250, -0.515329983761905420, -0.515287133525935580, -0.515244282001747660, -0.515201429189449330, +-0.515158575089147420, -0.515115719700949160, -0.515072863024961140, -0.515030005061291370, -0.514987145810046560, -0.514944285271333960, -0.514901423445260240, -0.514858560331933330, +-0.514815695931459930, -0.514772830243947040, -0.514729963269502380, -0.514687095008232840, -0.514644225460245570, -0.514601354625647380, -0.514558482504546060, -0.514515609097048630, +-0.514472734403262240, -0.514429858423293580, -0.514386981157250570, -0.514344102605240220, -0.514301222767369560, -0.514258341643745400, -0.514215459234475870, -0.514172575539667660, +-0.514129690559428030, -0.514086804293863770, -0.514043916743082920, -0.514001027907192260, -0.513958137786298620, -0.513915246380510000, -0.513872353689933340, -0.513829459714675750, +-0.513786564454844050, -0.513743667910546490, -0.513700770081889630, -0.513657870968980860, -0.513614970571927070, -0.513572068890836290, -0.513529165925815210, -0.513486261676971310, +-0.513443356144411280, -0.513400449328243360, -0.513357541228574240, -0.513314631845511290, -0.513271721179161420, -0.513228809229632540, -0.513185895997031680, -0.513142981481465750, +-0.513100065683042670, -0.513057148601869460, -0.513014230238053370, -0.512971310591701310, -0.512928389662921420, -0.512885467451820510, -0.512842543958505930, -0.512799619183084590, +-0.512756693125664630, -0.512713765786352860, -0.512670837165256740, -0.512627907262483080, -0.512584976078140130, -0.512542043612334690, -0.512499109865174220, -0.512456174836765420, +-0.512413238527216760, -0.512370300936634830, -0.512327362065127300, -0.512284421912800880, -0.512241480479763810, -0.512198537766123010, -0.512155593771985610, -0.512112648497459520, +-0.512069701942651780, -0.512026754107669850, -0.511983804992620530, -0.511940854597612180, -0.511897902922751720, -0.511854949968146400, -0.511811995733903460, -0.511769040220130810, +-0.511726083426935600, -0.511683125354425170, -0.511640166002706560, -0.511597205371887910, -0.511554243462076230, -0.511511280273378890, -0.511468315805903020, -0.511425350059756760, +-0.511382383035047130, -0.511339414731881160, -0.511296445150366980, -0.511253474290611740, -0.511210502152722900, -0.511167528736807260, -0.511124554042973300, -0.511081578071327920, +-0.511038600821978490, -0.510995622295032260, -0.510952642490597460, -0.510909661408780910, -0.510866679049690300, -0.510823695413432530, -0.510780710500115980, -0.510737724309847540, +-0.510694736842734920, -0.510651748098885030, -0.510608758078406110, -0.510565766781405310, -0.510522774207989750, -0.510479780358267580, -0.510436785232345920, -0.510393788830332480, +-0.510350791152334060, -0.510307792198459010, -0.510264791968814580, -0.510221790463508130, -0.510178787682646790, -0.510135783626338820, -0.510092778294691460, -0.510049771687812180, +-0.510006763805808010, -0.509963754648787400, -0.509920744216857400, -0.509877732510125470, -0.509834719528698850, -0.509791705272685800, -0.509748689742193560, -0.509705672937329160, +-0.509662654858200950, -0.509619635504916180, -0.509576614877582210, -0.509533592976306400, -0.509490569801197000, -0.509447545352361030, -0.509404519629906400, -0.509361492633939930, +-0.509318464364570180, -0.509275434821904290, -0.509232404006049740, -0.509189371917113890, -0.509146338555204970, -0.509103303920430130, -0.509060268012897050, -0.509017230832713000, +-0.508974192379986200, -0.508931152654823920, -0.508888111657333830, -0.508845069387622970, -0.508802025845799810, -0.508758981031971700, -0.508715934946245670, -0.508672887588730190, +-0.508629838959532510, -0.508586789058760200, -0.508543737886520630, -0.508500685442922040, -0.508457631728071680, -0.508414576742077350, -0.508371520485046080, -0.508328462957086450, +-0.508285404158305700, -0.508242344088811420, -0.508199282748710850, -0.508156220138112460, -0.508113156257123610, -0.508070091105851770, -0.508027024684404420, -0.507983956992889780, +-0.507940888031415240, -0.507897817800088250, -0.507854746299016950, -0.507811673528308800, -0.507768599488071510, -0.507725524178412320, -0.507682447599439700, -0.507639369751261000, +-0.507596290633983930, -0.507553210247715600, -0.507510128592564720, -0.507467045668638540, -0.507423961476044630, -0.507380876014890570, -0.507337789285284610, -0.507294701287334230, +-0.507251612021146990, -0.507208521486830490, -0.507165429684492960, -0.507122336614241890, -0.507079242276184620, -0.507036146670429620, -0.506993049797084260, -0.506949951656256230, +-0.506906852248052990, -0.506863751572583010, -0.506820649629953550, -0.506777546420272620, -0.506734441943647360, -0.506691336200186360, -0.506648229189996970, -0.506605120913187100, +-0.506562011369864010, -0.506518900560136260, -0.506475788484111340, -0.506432675141896940, -0.506389560533600400, -0.506346444659330320, -0.506303327519194160, -0.506260209113299720, +-0.506217089441754360, -0.506173968504666670, -0.506130846302144000, -0.506087722834293820, -0.506044598101224820, -0.506001472103044250, -0.505958344839860020, -0.505915216311779600, +-0.505872086518911470, -0.505828955461363080, -0.505785823139242360, -0.505742689552656670, -0.505699554701714680, -0.505656418586523770, -0.505613281207191730, -0.505570142563826260, +-0.505527002656535720, -0.505483861485427680, -0.505440719050610050, -0.505397575352190210, -0.505354430390276830, -0.505311284164977280, -0.505268136676399250, -0.505224987924651200, +-0.505181837909840730, -0.505138686632075620, -0.505095534091463460, -0.505052380288112720, -0.505009225222131210, -0.504966068893626500, -0.504922911302706280, -0.504879752449479140, +-0.504836592334052650, -0.504793430956534730, -0.504750268317032740, -0.504707104415655580, -0.504663939252510630, -0.504620772827705790, -0.504577605141348640, -0.504534436193547870, +-0.504491265984410960, -0.504448094514045600, -0.504404921782560360, -0.504361747790062710, -0.504318572536660790, -0.504275396022462070, -0.504232218247575140, -0.504189039212107780, +-0.504145858916167810, -0.504102677359862690, -0.504059494543301460, -0.504016310466591340, -0.503973125129840490, -0.503929938533156370, -0.503886750676647900, -0.503843561560422540, +-0.503800371184588200, -0.503757179549252590, -0.503713986654524490, -0.503670792500511280, -0.503627597087320860, -0.503584400415061690, -0.503541202483841600, -0.503498003293768480, +-0.503454802844950030, -0.503411601137494840, -0.503368398171510690, -0.503325193947105620, -0.503281988464387100, -0.503238781723464030, -0.503195573724444010, -0.503152364467435050, +-0.503109153952544740, -0.503065942179881990, -0.503022729149554370, -0.502979514861669920, -0.502936299316336320, -0.502893082513662270, -0.502849864453755680, -0.502806645136724240, +-0.502763424562675980, -0.502720202731719470, -0.502676979643962410, -0.502633755299512490, -0.502590529698478730, -0.502547302840968490, -0.502504074727090020, -0.502460845356951010, +-0.502417614730660270, -0.502374382848325470, -0.502331149710054770, -0.502287915315955740, -0.502244679666137390, -0.502201442760707330, -0.502158204599773560, -0.502114965183444010, +-0.502071724511827360, -0.502028482585031410, -0.501985239403164310, -0.501941994966333630, -0.501898749274648390, -0.501855502328216300, -0.501812254127145030, -0.501769004671543510, +-0.501725753961519530, -0.501682501997181120, -0.501639248778636080, -0.501595994305993330, -0.501552738579360560, -0.501509481598846010, -0.501466223364557260, -0.501422963876603460, +-0.501379703135092170, -0.501336441140131650, -0.501293177891829590, -0.501249913390295010, -0.501206647635635720, -0.501163380627959730, -0.501120112367374970, -0.501076842853990230, +-0.501033572087913440, -0.500990300069252270, -0.500947026798115760, -0.500903752274611700, -0.500860476498848240, -0.500817199470933280, -0.500773921190975630, -0.500730641659083210, +-0.500687360875364140, -0.500644078839926340, -0.500600795552878620, -0.500557511014328990, -0.500514225224385600, -0.500470938183156240, -0.500427649890749950, -0.500384360347274510, +-0.500341069552838190, -0.500297777507548780, -0.500254484211515300, -0.500211189664845680, -0.500167893867648040, -0.500124596820030300, -0.500081298522101480, -0.500037998973969280, +-0.499994698175741830, -0.499951396127527980, -0.499908092829435660, -0.499864788281573050, -0.499821482484048120, -0.499778175436969900, -0.499734867140446180, -0.499691557594585330, +-0.499648246799495210, -0.499604934755284840, -0.499561621462062120, -0.499518306919935370, -0.499474991129012450, -0.499431674089402480, -0.499388355801213270, -0.499345036264553180, +-0.499301715479530170, -0.499258393446253170, -0.499215070164830240, -0.499171745635369260, -0.499128419857979290, -0.499085092832768250, -0.499041764559844500, -0.498998435039315960, +-0.498955104271291690, -0.498911772255879680, -0.498868438993188220, -0.498825104483325290, -0.498781768726400010, -0.498738431722520250, -0.498695093471794470, -0.498651753974330540, +-0.498608413230237580, -0.498565071239623630, -0.498521728002597030, -0.498478383519265660, -0.498435037789738740, -0.498391690814124270, -0.498348342592530140, -0.498304993125065540, +-0.498261642411838460, -0.498218290452957290, -0.498174937248530010, -0.498131582798665760, -0.498088227103472560, -0.498044870163058760, -0.498001511977532450, -0.497958152547002710, +-0.497914791871577610, -0.497871429951365520, -0.497828066786474450, -0.497784702377013670, -0.497741336723091070, -0.497697969824815120, -0.497654601682293920, -0.497611232295636530, +-0.497567861664951090, -0.497524489790345640, -0.497481116671929350, -0.497437742309810190, -0.497394366704096760, -0.497350989854897010, -0.497307611762320130, -0.497264232426474270, +-0.497220851847467840, -0.497177470025408850, -0.497134086960406560, -0.497090702652569110, -0.497047317102004840, -0.497003930308821950, -0.496960542273129580, -0.496917152995035860, +-0.496873762474649260, -0.496830370712077920, -0.496786977707430970, -0.496743583460816600, -0.496700187972343280, -0.496656791242119090, -0.496613393270253280, -0.496569994056854040, +-0.496526593602029440, -0.496483191905888690, -0.496439788968539960, -0.496396384790091790, -0.496352979370652260, -0.496309572710330660, -0.496266164809235130, -0.496222755667474260, +-0.496179345285156000, -0.496135933662389840, -0.496092520799283840, -0.496049106695946480, -0.496005691352486010, -0.495962274769011720, -0.495918856945631700, -0.495875437882454580, +-0.495832017579588450, -0.495788596037142650, -0.495745173255225380, -0.495701749233944830, -0.495658323973410250, -0.495614897473729830, -0.495571469735012200, -0.495528040757365510, +-0.495484610540899100, -0.495441179085721160, -0.495397746391940290, -0.495354312459664660, -0.495310877289003640, -0.495267440880065410, -0.495224003232958620, -0.495180564347791400, +-0.495137124224673150, -0.495093682863712080, -0.495050240265016870, -0.495006796428695610, -0.494963351354857750, -0.494919905043611550, -0.494876457495065150, -0.494833008709328000, +-0.494789558686508370, -0.494746107426714820, -0.494702654930055610, -0.494659201196640200, -0.494615746226576720, -0.494572290019973880, -0.494528832576939970, -0.494485373897584350, +-0.494441913982015260, -0.494398452830341400, -0.494354990442671060, -0.494311526819113610, -0.494268061959777350, -0.494224595864770910, -0.494181128534202600, -0.494137659968181870, +-0.494094190166816990, -0.494050719130216590, -0.494007246858489070, -0.493963773351743800, -0.493920298610089070, -0.493876822633633250, -0.493833345422485690, -0.493789866976754870, +-0.493746387296549290, -0.493702906381977390, -0.493659424233148620, -0.493615940850171300, -0.493572456233154100, -0.493528970382205390, -0.493485483297434640, -0.493441994978950140, +-0.493398505426860700, -0.493355014641274630, -0.493311522622301380, -0.493268029370049320, -0.493224534884627200, -0.493181039166143310, -0.493137542214707240, -0.493094044030427340, +-0.493050544613411910, -0.493007043963770540, -0.492963542081611530, -0.492920038967043670, -0.492876534620175330, -0.492833029041116030, -0.492789522229974190, -0.492746014186858540, +-0.492702504911877450, -0.492658994405140490, -0.492615482666756030, -0.492571969696832870, -0.492528455495479410, -0.492484940062805190, -0.492441423398918610, -0.492397905503928480, +-0.492354386377943210, -0.492310866021072380, -0.492267344433424350, -0.492223821615107580, -0.492180297566231660, -0.492136772286904940, -0.492093245777236340, -0.492049718037334270, +-0.492006189067308250, -0.491962658867266760, -0.491919127437318580, -0.491875594777572260, -0.491832060888137300, -0.491788525769122240, -0.491744989420635830, -0.491701451842786570, +-0.491657913035684010, -0.491614372999436720, -0.491570831734153500, -0.491527289239942820, -0.491483745516914320, -0.491440200565176400, -0.491396654384837650, -0.491353106976007590, +-0.491309558338794810, -0.491266008473308150, -0.491222457379656030, -0.491178905057948150, -0.491135351508293070, -0.491091796730799560, -0.491048240725576180, -0.491004683492732570, +-0.490961125032377320, -0.490917565344619170, -0.490874004429566800, -0.490830442287329750, -0.490786878918016590, -0.490743314321736290, -0.490699748498597270, -0.490656181448709260, +-0.490612613172180800, -0.490569043669120850, -0.490525472939637890, -0.490481900983841590, -0.490438327801840600, -0.490394753393743330, -0.490351177759659640, -0.490307600899697940, +-0.490264022813967300, -0.490220443502576150, -0.490176862965634340, -0.490133281203250340, -0.490089698215533160, -0.490046114002591350, -0.490002528564534580, -0.489958941901471550, +-0.489915354013511160, -0.489871764900761950, -0.489828174563333770, -0.489784583001335150, -0.489740990214875050, -0.489697396204062110, -0.489653800969006070, -0.489610204509815460, +-0.489566606826599030, -0.489523007919466460, -0.489479407788526330, -0.489435806433887730, -0.489392203855659180, -0.489348600053950530, -0.489304995028870370, -0.489261388780527720, +-0.489217781309031260, -0.489174172614490700, -0.489130562697014710, -0.489086951556712280, -0.489043339193692140, -0.488999725608063980, -0.488956110799936560, -0.488912494769418840, +-0.488868877516619500, -0.488825259041648360, -0.488781639344614050, -0.488738018425625250, -0.488694396284791830, -0.488650772922222420, -0.488607148338026040, -0.488563522532311450, +-0.488519895505188370, -0.488476267256765630, -0.488432637787152180, -0.488389007096456720, -0.488345375184789150, -0.488301742052258180, -0.488258107698972820, -0.488214472125041820, +-0.488170835330575040, -0.488127197315681160, -0.488083558080469270, -0.488039917625048110, -0.487996275949527550, -0.487952633054016320, -0.487908988938623440, -0.487865343603457740, +-0.487821697048629100, -0.487778049274246170, -0.487734400280417760, -0.487690750067253710, -0.487647098634862770, -0.487603445983354140, -0.487559792112836510, -0.487516137023419730, +-0.487472480715212650, -0.487428823188324370, -0.487385164442863620, -0.487341504478940310, -0.487297843296663310, -0.487254180896141700, -0.487210517277484210, -0.487166852440800820, +-0.487123186386200340, -0.487079519113791830, -0.487035850623684210, -0.486992180915987280, -0.486948509990809960, -0.486904837848260940, -0.486861164488450180, -0.486817489911486550, +-0.486773814117479220, -0.486730137106536950, -0.486686458878769710, -0.486642779434286350, -0.486599098773196010, -0.486555416895607550, -0.486511733801630930, -0.486468049491374950, +-0.486424363964948870, -0.486380677222461530, -0.486336989264022860, -0.486293300089741700, -0.486249609699727300, -0.486205918094088470, -0.486162225272935290, -0.486118531236376490, +-0.486074835984521000, -0.486031139517478780, -0.485987441835358750, -0.485943742938270080, -0.485900042826321710, -0.485856341499623590, -0.485812638958284580, -0.485768935202414040, +-0.485725230232120770, -0.485681524047514750, -0.485637816648704980, -0.485594108035800660, -0.485550398208910660, -0.485506687168145050, -0.485462974913612730, -0.485419261445423020, +-0.485375546763684720, -0.485331830868507950, -0.485288113760001580, -0.485244395438274580, -0.485200675903436960, -0.485156955155597650, -0.485113233194865930, -0.485069510021350790, +-0.485025785635162240, -0.484982060036409200, -0.484938333225201020, -0.484894605201646620, -0.484850875965856130, -0.484807145517938410, -0.484763413858002870, -0.484719680986158360, +-0.484675946902515090, -0.484632211607181900, -0.484588475100268200, -0.484544737381882920, -0.484500998452136180, -0.484457258311136950, -0.484413516958994590, -0.484369774395818020, +-0.484326030621717420, -0.484282285636801760, -0.484238539441180000, -0.484194792034962240, -0.484151043418257540, -0.484107293591175210, -0.484063542553824280, -0.484019790306314810, +-0.483976036848755950, -0.483932282181256950, -0.483888526303926870, -0.483844769216875860, -0.483801010920212940, -0.483757251414047520, -0.483713490698488510, -0.483669728773646220, +-0.483625965639629560, -0.483582201296548050, -0.483538435744510610, -0.483494668983627470, -0.483450901014007670, -0.483407131835760230, -0.483363361448995330, -0.483319589853822060, +-0.483275817050349780, -0.483232043038687550, -0.483188267818945640, -0.483144491391233060, -0.483100713755659270, -0.483056934912333260, -0.483013154861365310, -0.482969373602864520, +-0.482925591136940220, -0.482881807463701630, -0.482838022583258860, -0.482794236495721060, -0.482750449201197640, -0.482706660699797730, -0.482662870991631580, -0.482619080076808200, +-0.482575287955436800, -0.482531494627627510, -0.482487700093489510, -0.482443904353132220, -0.482400107406664840, -0.482356309254197540, -0.482312509895839510, -0.482268709331700180, +-0.482224907561888680, -0.482181104586515310, -0.482137300405689140, -0.482093495019519760, -0.482049688428116240, -0.482005880631588890, -0.481962071630046840, -0.481918261423599610, +-0.481874450012356350, -0.481830637396427400, -0.481786823575921790, -0.481743008550949090, -0.481699192321618560, -0.481655374888040390, -0.481611556250323810, -0.481567736408577920, +-0.481523915362913110, -0.481480093113438480, -0.481436269660263650, -0.481392445003497700, -0.481348619143251110, -0.481304792079632890, -0.481260963812752740, -0.481217134342719790, +-0.481173303669644390, -0.481129471793635740, -0.481085638714803370, -0.481041804433256560, -0.480997968949105630, -0.480954132262459750, -0.480910294373428530, -0.480866455282121190, +-0.480822614988648140, -0.480778773493118540, -0.480734930795641560, -0.480691086896327720, -0.480647241795286120, -0.480603395492626430, -0.480559547988457850, -0.480515699282890780, +-0.480471849376034490, -0.480427998267998590, -0.480384145958892230, -0.480340292448825980, -0.480296437737908980, -0.480252581826250860, -0.480208724713960920, -0.480164866401149530, +-0.480121006887925970, -0.480077146174399950, -0.480033284260680590, -0.479989421146878480, -0.479945556833102800, -0.479901691319462810, -0.479857824606069020, -0.479813956693030620, +-0.479770087580457420, -0.479726217268458540, -0.479682345757144520, -0.479638473046624600, -0.479594599137008530, -0.479550724028405590, -0.479506847720926220, -0.479462970214679710, +-0.479419091509775800, -0.479375211606323790, -0.479331330504434110, -0.479287448204216090, -0.479243564705779500, -0.479199680009233580, -0.479155794114688840, -0.479111907022254590, +-0.479068018732040250, -0.479024129244156220, -0.478980238558711860, -0.478936346675816860, -0.478892453595580690, -0.478848559318113710, -0.478804663843525380, -0.478760767171925390, +-0.478716869303423050, -0.478672970238128940, -0.478629069976152450, -0.478585168517603240, -0.478541265862590710, -0.478497362011225450, -0.478453456963616740, -0.478409550719874400, +-0.478365643280107830, -0.478321734644427510, -0.478277824812942840, -0.478233913785763630, -0.478190001562999230, -0.478146088144760230, -0.478102173531156030, -0.478058257722295990, +-0.478014340718290690, -0.477970422519249540, -0.477926503125282290, -0.477882582536498460, -0.477838660753008520, -0.477794737774921980, -0.477750813602348560, -0.477706888235397700, +-0.477662961674180040, -0.477619033918804950, -0.477575104969382270, -0.477531174826021480, -0.477487243488833150, -0.477443310957926640, -0.477399377233411910, -0.477355442315398340, +-0.477311506203996540, -0.477267568899315990, -0.477223630401466090, -0.477179690710557550, -0.477135749826699760, -0.477091807750002590, -0.477047864480575570, -0.477003920018529200, +-0.476959974363973080, -0.476916027517017000, -0.476872079477770490, -0.476828130246344130, -0.476784179822847490, -0.476740228207390370, -0.476696275400082300, -0.476652321401033920, +-0.476608366210354740, -0.476564409828154620, -0.476520452254543150, -0.476476493489630890, -0.476432533533527440, -0.476388572386342250, -0.476344610048185960, -0.476300646519168200, +-0.476256681799398840, -0.476212715888987340, -0.476168748788044440, -0.476124780496679720, -0.476080811015002990, -0.476036840343123880, -0.475992868481153080, -0.475948895429200050, +-0.475904921187374820, -0.475860945755786910, -0.475816969134547020, -0.475772991323764660, -0.475729012323549860, -0.475685032134012140, -0.475641050755262200, -0.475597068187409660, +-0.475553084430564430, -0.475509099484836160, -0.475465113350335480, -0.475421126027172010, -0.475377137515455350, -0.475333147815296230, -0.475289156926804290, -0.475245164850089390, +-0.475201171585261210, -0.475157177132430500, -0.475113181491706840, -0.475069184663200250, -0.475025186647020260, -0.474981187443277720, -0.474937187052082210, -0.474893185473543760, +-0.474849182707771930, -0.474805178754877490, -0.474761173614970170, -0.474717167288159880, -0.474673159774556320, -0.474629151074270230, -0.474585141187411240, -0.474541130114089050, +-0.474497117854414400, -0.474453104408496970, -0.474409089776446750, -0.474365073958373410, -0.474321056954387810, -0.474277038764599530, -0.474233019389118720, -0.474188998828054930, +-0.474144977081519040, -0.474100954149620670, -0.474056930032469960, -0.474012904730176540, -0.473968878242851220, -0.473924850570603680, -0.473880821713544060, -0.473836791671782000, +-0.473792760445428340, -0.473748728034592780, -0.473704694439385010, -0.473660659659915880, -0.473616623696295090, -0.473572586548632770, -0.473528548217038600, -0.473484508701623400, +-0.473440468002497010, -0.473396426119769400, -0.473352383053550320, -0.473308338803950680, -0.473264293371080220, -0.473220246755049030, -0.473176198955966800, -0.473132149973944480, +-0.473088099809091780, -0.473044048461518820, -0.472999995931335350, -0.472955942218652340, -0.472911887323579420, -0.472867831246226390, -0.472823773986704170, -0.472779715545122550, +-0.472735655921591610, -0.472691595116221110, -0.472647533129122050, -0.472603469960404200, -0.472559405610177620, -0.472515340078552120, -0.472471273365638710, -0.472427205471547100, +-0.472383136396387460, -0.472339066140269600, -0.472294994703304490, -0.472250922085601880, -0.472206848287271940, -0.472162773308424490, -0.472118697149170540, -0.472074619809619790, +-0.472030541289882530, -0.471986461590068520, -0.471942380710288770, -0.471898298650653030, -0.471854215411271150, -0.471810130992254160, -0.471766045393711810, -0.471721958615754390, +-0.471677870658491650, -0.471633781522034610, -0.471589691206493130, -0.471545599711977400, -0.471501507038597330, -0.471457413186463840, -0.471413318155686820, -0.471369221946376540, +-0.471325124558642780, -0.471281025992596640, -0.471236926248347900, -0.471192825326006870, -0.471148723225683350, -0.471104619947488420, -0.471060515491531940, -0.471016409857923810, +-0.470972303046775010, -0.470928195058195500, -0.470884085892295470, -0.470839975549184830, -0.470795864028974660, -0.470751751331774830, -0.470707637457695620, -0.470663522406846890, +-0.470619406179339780, -0.470575288775284150, -0.470531170194790290, -0.470487050437968120, -0.470442929504928720, -0.470398807395781990, -0.470354684110638300, -0.470310559649607440, +-0.470266434012800550, -0.470222307200327650, -0.470178179212298540, -0.470134050048824360, -0.470089919710015120, -0.470045788195981030, -0.470001655506832090, -0.469957521642679400, +-0.469913386603632910, -0.469869250389802980, -0.469825113001299480, -0.469780974438233630, -0.469736834700715310, -0.469692693788854920, -0.469648551702762430, -0.469604408442548920, +-0.469560264008324400, -0.469516118400199240, -0.469471971618283360, -0.469427823662687930, -0.469383674533522980, -0.469339524230898810, -0.469295372754925500, -0.469251220105714070, +-0.469207066283374660, -0.469162911288017130, -0.469118755119752760, -0.469074597778691480, -0.469030439264943700, -0.468986279578619440, -0.468942118719829880, -0.468897956688685060, +-0.468853793485295270, -0.468809629109770640, -0.468765463562222370, -0.468721296842760370, -0.468677128951495160, -0.468632959888536760, -0.468588789653996310, -0.468544618247983930, +-0.468500445670609940, -0.468456271921984520, -0.468412097002218750, -0.468367920911422760, -0.468323743649706580, -0.468279565217181450, -0.468235385613957390, -0.468191204840144870, +-0.468147022895853970, -0.468102839781195880, -0.468058655496280670, -0.468014470041218820, -0.467970283416120460, -0.467926095621096720, -0.467881906656257780, -0.467837716521714080, +-0.467793525217575670, -0.467749332743953860, -0.467705139100958680, -0.467660944288700700, -0.467616748307289940, -0.467572551156837710, -0.467528352837454090, -0.467484153349249200, +-0.467439952692334350, -0.467395750866819560, -0.467351547872815460, -0.467307343710432030, -0.467263138379780670, -0.467218931880971470, -0.467174724214114930, -0.467130515379321210, +-0.467086305376701590, -0.467042094206366170, -0.466997881868425560, -0.466953668362989790, -0.466909453690170280, -0.466865237850077160, -0.466821020842820960, -0.466776802668511740, +-0.466732583327260970, -0.466688362819178690, -0.466644141144375520, -0.466599918302961660, -0.466555694295048340, -0.466511469120745760, -0.466467242780164160, -0.466423015273414840, +-0.466378786600608000, -0.466334556761854150, -0.466290325757263540, -0.466246093586947520, -0.466201860251016230, -0.466157625749580360, -0.466113390082749990, -0.466069153250636530, +-0.466024915253350160, -0.465980676091001520, -0.465936435763700860, -0.465892194271559420, -0.465847951614687560, -0.465803707793195800, -0.465759462807194320, -0.465715216656794660, +-0.465670969342106890, -0.465626720863241360, -0.465582471220309380, -0.465538220413421240, -0.465493968442687530, -0.465449715308218550, -0.465405461010125640, -0.465361205548519120, +-0.465316948923509550, -0.465272691135207190, -0.465228432183723560, -0.465184172069168790, -0.465139910791653620, -0.465095648351288250, -0.465051384748184190, -0.465007119982451640, +-0.464962854054201350, -0.464918586963543490, -0.464874318710589540, -0.464830049295449800, -0.464785778718234570, -0.464741506979055250, -0.464697234078022160, -0.464652960015246030, +-0.464608684790837060, -0.464564408404906810, -0.464520130857565550, -0.464475852148923900, -0.464431572279092260, -0.464387291248182120, -0.464343009056303710, -0.464298725703567780, +-0.464254441190084630, -0.464210155515965780, -0.464165868681321590, -0.464121580686262690, -0.464077291530899440, -0.464033001215343350, -0.463988709739704740, -0.463944417104094010, +-0.463900123308622630, -0.463855828353400890, -0.463811532238539600, -0.463767234964149120, -0.463722936530340910, -0.463678636937225390, -0.463634336184913230, -0.463590034273514860, +-0.463545731203141850, -0.463501426973904450, -0.463457121585913510, -0.463412815039279340, -0.463368507334113560, -0.463324198470526470, -0.463279888448628940, -0.463235577268531260, +-0.463191264930345070, -0.463146951434180660, -0.463102636780148900, -0.463058320968360190, -0.463014003998926000, -0.462969685871956860, -0.462925366587563060, -0.462881046145856290, +-0.462836724546946850, -0.462792401790945660, -0.462748077877963020, -0.462703752808110600, -0.462659426581498830, -0.462615099198238460, -0.462570770658439930, -0.462526440962214900, +-0.462482110109673770, -0.462437778100927340, -0.462393444936086080, -0.462349110615261630, -0.462304775138564330, -0.462260438506105150, -0.462216100717994460, -0.462171761774343940, +-0.462127421675263990, -0.462083080420865100, -0.462038738011258940, -0.461994394446555880, -0.461950049726866820, -0.461905703852302290, -0.461861356822973910, -0.461817008638992110, +-0.461772659300467790, -0.461728308807511420, -0.461683957160234640, -0.461639604358748010, -0.461595250403162400, -0.461550895293588230, -0.461506539030137220, -0.461462181612919850, +-0.461417823042047040, -0.461373463317629300, -0.461329102439778260, -0.461284740408604450, -0.461240377224218460, -0.461196012886731840, -0.461151647396255250, -0.461107280752899530, +-0.461062912956775210, -0.461018544007993970, -0.460974173906666400, -0.460929802652903400, -0.460885430246815500, -0.460841056688514440, -0.460796681978110690, -0.460752306115715270, +-0.460707929101438650, -0.460663550935392630, -0.460619171617687730, -0.460574791148434910, -0.460530409527744710, -0.460486026755728920, -0.460441642832498000, -0.460397257758163040, +-0.460352871532834500, -0.460308484156624120, -0.460264095629642600, -0.460219705952000460, -0.460175315123809440, -0.460130923145180060, -0.460086530016223460, -0.460042135737050110, +-0.459997740307771800, -0.459953343728499160, -0.459908945999343180, -0.459864547120414410, -0.459820147091824670, -0.459775745913684530, -0.459731343586105070, -0.459686940109196860, +-0.459642535483071660, -0.459598129707840140, -0.459553722783613340, -0.459509314710501770, -0.459464905488617350, -0.459420495118070650, -0.459376083598972310, -0.459331670931434180, +-0.459287257115566840, -0.459242842151481370, -0.459198426039288400, -0.459154008779099790, -0.459109590371026110, -0.459065170815178500, -0.459020750111667540, -0.458976328260605080, +-0.458931905262101870, -0.458887481116268810, -0.458843055823216720, -0.458798629383057380, -0.458754201795901430, -0.458709773061860000, -0.458665343181043740, -0.458620912153564490, +-0.458576479979532990, -0.458532046659059890, -0.458487612192257090, -0.458443176579235220, -0.458398739820105430, -0.458354301914978390, -0.458309862863966020, -0.458265422667178960, +-0.458220981324728330, -0.458176538836724880, -0.458132095203280460, -0.458087650424505830, -0.458043204500512060, -0.457998757431409890, -0.457954309217311170, -0.457909859858326720, +-0.457865409354567650, -0.457820957706144620, -0.457776504913169620, -0.457732050975753310, -0.457687595894006540, -0.457643139668041100, -0.457598682297967850, -0.457554223783897930, +-0.457509764125942020, -0.457465303324212090, -0.457420841378818890, -0.457376378289873650, -0.457331914057487020, -0.457287448681771010, -0.457242982162836380, -0.457198514500794300, +-0.457154045695755520, -0.457109575747832010, -0.457065104657134570, -0.457020632423774390, -0.456976159047862260, -0.456931684529510050, -0.456887208868828660, -0.456842732065929290, +-0.456798254120922680, -0.456753775033920780, -0.456709294805034470, -0.456664813434374540, -0.456620330922053010, -0.456575847268180570, -0.456531362472868570, -0.456486876536227770, +-0.456442389458370120, -0.456397901239406540, -0.456353411879448220, -0.456308921378605960, -0.456264429736991770, -0.456219936954716520, -0.456175443031891450, -0.456130947968627350, +-0.456086451765036260, -0.456041954421229080, -0.455997455937317000, -0.455952956313410870, -0.455908455549622780, -0.455863953646063520, -0.455819450602843960, -0.455774946420076210, +-0.455730441097871090, -0.455685934636339880, -0.455641427035593400, -0.455596918295743780, -0.455552408416901810, -0.455507897399178910, -0.455463385242685810, -0.455418871947534660, +-0.455374357513836310, -0.455329841941702060, -0.455285325231242880, -0.455240807382570720, -0.455196288395796570, -0.455151768271031650, -0.455107247008386950, -0.455062724607974530, +-0.455018201069905310, -0.454973676394290150, -0.454929150581241230, -0.454884623630869460, -0.454840095543286080, -0.454795566318602070, -0.454751035956929560, -0.454706504458379460, +-0.454661971823063060, -0.454617438051091390, -0.454572903142576480, -0.454528367097629340, -0.454483829916361270, -0.454439291598883240, -0.454394752145307390, -0.454350211555744620, +-0.454305669830306350, -0.454261126969103480, -0.454216582972248260, -0.454172037839851490, -0.454127491572024700, -0.454082944168878730, -0.454038395630525840, -0.453993845957076920, +-0.453949295148643020, -0.453904743205336250, -0.453860190127267640, -0.453815635914548600, -0.453771080567289990, -0.453726524085604150, -0.453681966469601960, -0.453637407719394870, +-0.453592847835093850, -0.453548286816811090, -0.453503724664657600, -0.453459161378744870, -0.453414596959183790, -0.453370031406086620, -0.453325464719564420, -0.453280896899728500, +-0.453236327946689940, -0.453191757860560980, -0.453147186641452650, -0.453102614289475900, -0.453058040804743050, -0.453013466187365100, -0.452968890437453480, -0.452924313555119200, +-0.452879735540474560, -0.452835156393630590, -0.452790576114698750, -0.452745994703790010, -0.452701412161016730, -0.452656828486489910, -0.452612243680320990, -0.452567657742621090, +-0.452523070673502450, -0.452478482473076150, -0.452433893141453600, -0.452389302678745940, -0.452344711085065410, -0.452300118360523140, -0.452255524505230160, -0.452210929519298750, +-0.452166333402840010, -0.452121736155965460, -0.452077137778786160, -0.452032538271414430, -0.451987937633961330, -0.451943335866538400, -0.451898732969256700, -0.451854128942228590, +-0.451809523785565210, -0.451764917499377970, -0.451720310083778000, -0.451675701538877710, -0.451631091864788170, -0.451586481061620860, -0.451541869129486960, -0.451497256068498830, +-0.451452641878767550, -0.451408026560404240, -0.451363410113521270, -0.451318792538229760, -0.451274173834641250, -0.451229554002866960, -0.451184933043019150, -0.451140310955209010, +-0.451095687739548110, -0.451051063396147590, -0.451006437925119800, -0.450961811326575920, -0.450917183600627490, -0.450872554747385750, -0.450827924766962980, -0.450783293659470450, +-0.450738661425019620, -0.450694028063721770, -0.450649393575689280, -0.450604757961033280, -0.450560121219865330, -0.450515483352296740, -0.450470844358439870, -0.450426204238405850, +-0.450381562992305920, -0.450336920620252430, -0.450292277122356700, -0.450247632498730290, -0.450202986749484390, -0.450158339874731360, -0.450113691874582560, -0.450069042749149490, +-0.450024392498543420, -0.449979741122876750, -0.449935088622260780, -0.449890434996807030, -0.449845780246626860, -0.449801124371832620, -0.449756467372535500, -0.449711809248847290, +-0.449667150000879150, -0.449622489628743460, -0.449577828132551650, -0.449533165512414790, -0.449488501768445460, -0.449443836900754850, -0.449399170909454690, -0.449354503794656130, +-0.449309835556471750, -0.449265166195012830, -0.449220495710390910, -0.449175824102717390, -0.449131151372104740, -0.449086477518664150, -0.449041802542507420, -0.448997126443745790, +-0.448952449222491720, -0.448907770878856530, -0.448863091412951890, -0.448818410824889160, -0.448773729114780750, -0.448729046282738080, -0.448684362328872320, -0.448639677253296120, +-0.448594991056120720, -0.448550303737457800, -0.448505615297418780, -0.448460925736116070, -0.448416235053661070, -0.448371543250165480, -0.448326850325740660, -0.448282156280499060, +-0.448237461114552090, -0.448192764828011460, -0.448148067420988560, -0.448103368893595870, -0.448058669245944730, -0.448013968478146950, -0.447969266590313830, -0.447924563582557940, +-0.447879859454990650, -0.447835154207723740, -0.447790447840868520, -0.447745740354537570, -0.447701031748842290, -0.447656322023893990, -0.447611611179805360, -0.447566899216687630, +-0.447522186134652670, -0.447477471933811880, -0.447432756614277780, -0.447388040176161790, -0.447343322619575710, -0.447298603944630890, -0.447253884151440020, -0.447209163240114390, +-0.447164441210765870, -0.447119718063505870, -0.447074993798446950, -0.447030268415700540, -0.446985541915378480, -0.446940814297592140, -0.446896085562454190, -0.446851355710076000, +-0.446806624740569040, -0.446761892654045870, -0.446717159450618020, -0.446672425130397290, -0.446627689693495030, -0.446582953140024000, -0.446538215470095590, -0.446493476683821610, +-0.446448736781313580, -0.446403995762684080, -0.446359253628044570, -0.446314510377506970, -0.446269766011182680, -0.446225020529184340, -0.446180273931623460, -0.446135526218611910, +-0.446090777390261150, -0.446046027446683870, -0.446001276387991470, -0.445956524214295550, -0.445911770925708660, -0.445867016522342340, -0.445822261004308500, -0.445777504371718590, +-0.445732746624685370, -0.445687987763320250, -0.445643227787735130, -0.445598466698041600, -0.445553704494352280, -0.445508941176778640, -0.445464176745432710, -0.445419411200425940, +-0.445374644541871030, -0.445329876769879510, -0.445285107884563270, -0.445240337886033900, -0.445195566774404080, -0.445150794549785340, -0.445106021212289200, -0.445061246762028410, +-0.445016471199114530, -0.444971694523659420, -0.444926916735774720, -0.444882137835573120, -0.444837357823166190, -0.444792576698665840, -0.444747794462183650, -0.444703011113832370, +-0.444658226653723570, -0.444613441081969210, -0.444568654398680820, -0.444523866603971250, -0.444479077697951970, -0.444434287680735010, -0.444389496552431930, -0.444344704313155480, +-0.444299910963017300, -0.444255116502129340, -0.444210320930603200, -0.444165524248551660, -0.444120726456086250, -0.444075927553318710, -0.444031127540361670, -0.443986326417326880, +-0.443941524184326250, -0.443896720841471360, -0.443851916388875170, -0.443807110826649090, -0.443762304154905310, -0.443717496373755290, -0.443672687483312010, -0.443627877483686980, +-0.443583066374992230, -0.443538254157339440, -0.443493440830841410, -0.443448626395609780, -0.443403810851756620, -0.443358994199393450, -0.443314176438633250, -0.443269357569587630, +-0.443224537592368180, -0.443179716507087760, -0.443134894313858110, -0.443090071012791190, -0.443045246603998690, -0.443000421087593520, -0.442955594463687260, -0.442910766732391990, +-0.442865937893819450, -0.442821107948082440, -0.442776276895292640, -0.442731444735562200, -0.442686611469002730, -0.442641777095727110, -0.442596941615847060, -0.442552105029474670, +-0.442507267336721580, -0.442462428537700740, -0.442417588632523840, -0.442372747621302580, -0.442327905504149800, -0.442283062281177310, -0.442238217952497130, -0.442193372518221050, +-0.442148525978461880, -0.442103678333331420, -0.442058829582941790, -0.442013979727404640, -0.441969128766832970, -0.441924276701338490, -0.441879423531033320, -0.441834569256029150, +-0.441789713876439010, -0.441744857392374570, -0.441699999803947970, -0.441655141111270970, -0.441610281314456510, -0.441565420413616350, -0.441520558408862670, -0.441475695300307170, +-0.441430831088062800, -0.441385965772241430, -0.441341099352954680, -0.441296231830315630, -0.441251363204435980, -0.441206493475427900, -0.441161622643403200, -0.441116750708474840, +-0.441071877670754620, -0.441027003530354680, -0.440982128287386870, -0.440937251941964090, -0.440892374494198210, -0.440847495944201420, -0.440802616292085450, -0.440757735537963380, +-0.440712853681946900, -0.440667970724148370, -0.440623086664679480, -0.440578201503653230, -0.440533315241181500, -0.440488427877376130, -0.440443539412350040, -0.440398649846215130, +-0.440353759179083590, -0.440308867411067230, -0.440263974542279110, -0.440219080572831100, -0.440174185502835320, -0.440129289332403690, -0.440084392061649290, -0.440039493690683850, +-0.439994594219619730, -0.439949693648568670, -0.439904791977643820, -0.439859889206956960, -0.439814985336620390, -0.439770080366745920, -0.439725174297446730, -0.439680267128834510, +-0.439635358861021290, -0.439590449494120070, -0.439545539028242730, -0.439500627463501490, -0.439455714800008330, -0.439410801037876280, -0.439365886177217170, -0.439320970218143430, +-0.439276053160766790, -0.439231135005200450, -0.439186215751556310, -0.439141295399946560, -0.439096373950483230, -0.439051451403279340, -0.439006527758446840, -0.438961603016097990, +-0.438916677176344750, -0.438871750239300200, -0.438826822205076290, -0.438781893073784960, -0.438736962845539260, -0.438692031520451160, -0.438647099098632980, -0.438602165580196600, +-0.438557230965255280, -0.438512295253920880, -0.438467358446305690, -0.438422420542521730, -0.438377481542682130, -0.438332541446898820, -0.438287600255284180, -0.438242657967950090, +-0.438197714585009780, -0.438152770106575220, -0.438107824532758650, -0.438062877863672210, -0.438017930099428910, -0.437972981240140840, -0.437928031285920280, -0.437883080236879220, +-0.437838128093130880, -0.437793174854787250, -0.437748220521960270, -0.437703265094763150, -0.437658308573307840, -0.437613350957706760, -0.437568392248071920, -0.437523432444516470, +-0.437478471547152470, -0.437433509556092280, -0.437388546471447930, -0.437343582293332590, -0.437298617021858290, -0.437253650657137450, -0.437208683199282130, -0.437163714648405420, +-0.437118745004619500, -0.437073774268036670, -0.437028802438769020, -0.436983829516929770, -0.436938855502630950, -0.436893880395984590, -0.436848904197103930, -0.436803926906101040, +-0.436758948523088280, -0.436713969048177770, -0.436668988481482720, -0.436624006823115200, -0.436579024073187720, -0.436534040231812190, -0.436489055299102040, -0.436444069275169210, +-0.436399082160126180, -0.436354093954085090, -0.436309104657159160, -0.436264114269460490, -0.436219122791101480, -0.436174130222194310, -0.436129136562852180, -0.436084141813187220, +-0.436039145973311500, -0.435994149043338330, -0.435949151023379830, -0.435904151913548370, -0.435859151713956170, -0.435814150424716500, -0.435769148045941470, -0.435724144577743500, +-0.435679140020234830, -0.435634134373528710, -0.435589127637737220, -0.435544119812972920, -0.435499110899347950, -0.435454100896975560, -0.435409089805967930, -0.435364077626437580, +-0.435319064358496650, -0.435274050002258440, -0.435229034557835130, -0.435184018025339240, -0.435139000404882850, -0.435093981696579420, -0.435048961900540990, -0.435003941016879780, +-0.434958919045709100, -0.434913895987141140, -0.434868871841288420, -0.434823846608263180, -0.434778820288178660, -0.434733792881147110, -0.434688764387281050, -0.434643734806692720, +-0.434598704139495420, -0.434553672385801390, -0.434508639545723160, -0.434463605619372970, -0.434418570606864120, -0.434373534508308850, -0.434328497323819780, -0.434283459053509010, +-0.434238419697490050, -0.434193379255874980, -0.434148337728776150, -0.434103295116306800, -0.434058251418579230, -0.434013206635706030, -0.433968160767799430, -0.433923113814972840, +-0.433878065777338400, -0.433833016655008840, -0.433787966448096360, -0.433742915156714310, -0.433697862780975050, -0.433652809320991100, -0.433607754776874690, -0.433562699148739290, +-0.433517642436697210, -0.433472584640860970, -0.433427525761342860, -0.433382465798256400, -0.433337404751713730, -0.433292342621827140, -0.433247279408710110, -0.433202215112474860, +-0.433157149733234100, -0.433112083271100070, -0.433067015726186220, -0.433021947098604810, -0.432976877388468570, -0.432931806595889700, -0.432886734720981770, -0.432841661763856970, +-0.432796587724627980, -0.432751512603407160, -0.432706436400307930, -0.432661359115442680, -0.432616280748923940, -0.432571201300864130, -0.432526120771376750, -0.432481039160574070, +-0.432435956468568360, -0.432390872695473160, -0.432345787841400760, -0.432300701906463970, -0.432255614890774960, -0.432210526794447330, -0.432165437617593350, -0.432120347360325840, +-0.432075256022756980, -0.432030163605000460, -0.431985070107168470, -0.431939975529373850, -0.431894879871728870, -0.431849783134347130, -0.431804685317340900, -0.431759586420822910, +-0.431714486444905620, -0.431669385389702510, -0.431624283255325920, -0.431579180041888610, -0.431534075749502980, -0.431488970378282490, -0.431443863928339670, -0.431398756399786750, +-0.431353647792737330, -0.431308538107303800, -0.431263427343598900, -0.431218315501735060, -0.431173202581825840, -0.431128088583983600, -0.431082973508321140, -0.431037857354950820, +-0.430992740123986310, -0.430947621815539920, -0.430902502429724440, -0.430857381966652350, -0.430812260426437220, -0.430767137809191400, -0.430722014115027750, -0.430676889344058680, +-0.430631763496397760, -0.430586636572157460, -0.430541508571450130, -0.430496379494389460, -0.430451249341087860, -0.430406118111658080, -0.430360985806212630, -0.430315852424865140, +-0.430270717967727980, -0.430225582434914040, -0.430180445826535750, -0.430135308142706780, -0.430090169383539500, -0.430045029549146810, -0.429999888639641110, -0.429954746655136110, +-0.429909603595744260, -0.429864459461578420, -0.429819314252750990, -0.429774167969375680, -0.429729020611564980, -0.429683872179431270, -0.429638722673088340, -0.429593572092648590, +-0.429548420438224890, -0.429503267709929750, -0.429458113907876860, -0.429412959032178630, -0.429367803082948090, -0.429322646060297570, -0.429277487964340840, -0.429232328795190410, +-0.429187168552959190, -0.429142007237759580, -0.429096844849705390, -0.429051681388909090, -0.429006516855483580, -0.428961351249541380, -0.428916184571196180, -0.428871016820560560, +-0.428825847997747370, -0.428780678102869180, -0.428735507136039700, -0.428690335097371420, -0.428645161986976890, -0.428599987804969880, -0.428554812551462940, -0.428509636226568900, +-0.428464458830400410, -0.428419280363071200, -0.428374100824693740, -0.428328920215381050, -0.428283738535245650, -0.428238555784401290, -0.428193371962960530, -0.428148187071036410, +-0.428103001108741390, -0.428057814076189260, -0.428012625973492540, -0.427967436800764320, -0.427922246558117110, -0.427877055245664660, -0.427831862863519600, -0.427786669411794440, +-0.427741474890603050, -0.427696279300057940, -0.427651082640272180, -0.427605884911358260, -0.427560686113430070, -0.427515486246600130, -0.427470285310981470, -0.427425083306686720, +-0.427379880233829670, -0.427334676092522900, -0.427289470882879440, -0.427244264605011910, -0.427199057259034120, -0.427153848845058690, -0.427108639363198650, -0.427063428813566570, +-0.427018217196276360, -0.426973004511440600, -0.426927790759171920, -0.426882575939584120, -0.426837360052789940, -0.426792143098902340, -0.426746925078034020, -0.426701705990298720, +-0.426656485835809170, -0.426611264614678460, -0.426566042327019170, -0.426520818972945140, -0.426475594552569060, -0.426430369066004010, -0.426385142513362680, -0.426339914894758860, +-0.426294686210305250, -0.426249456460114920, -0.426204225644300550, -0.426158993762976000, -0.426113760816253960, -0.426068526804247170, -0.426023291727069430, -0.425978055584833480, +-0.425932818377652340, -0.425887580105638820, -0.425842340768906700, -0.425797100367568790, -0.425751858901738060, -0.425706616371527350, -0.425661372777050410, -0.425616128118420090, +-0.425570882395749470, -0.425525635609151240, -0.425480387758739310, -0.425435138844626410, -0.425389888866925640, -0.425344637825749770, -0.425299385721212670, -0.425254132553427140, +-0.425208878322506310, -0.425163623028562860, -0.425118366671710710, -0.425073109252062710, -0.425027850769731490, -0.424982591224831060, -0.424937330617474180, -0.424892068947773930, +-0.424846806215843140, -0.424801542421795690, -0.424756277565744410, -0.424711011647802450, -0.424665744668082550, -0.424620476626698660, -0.424575207523763600, -0.424529937359390540, +-0.424484666133692230, -0.424439393846782640, -0.424394120498774560, -0.424348846089781240, -0.424303570619915360, -0.424258294089290940, -0.424213016498020790, -0.424167737846217700, +-0.424122458133995680, -0.424077177361467490, -0.424031895528746370, -0.423986612635945110, -0.423941328683177740, -0.423896043670557050, -0.423850757598196240, -0.423805470466208090, +-0.423760182274706740, -0.423714893023804880, -0.423669602713615810, -0.423624311344252320, -0.423579018915828500, -0.423533725428457080, -0.423488430882251350, -0.423443135277324130, +-0.423397838613789490, -0.423352540891760280, -0.423307242111349290, -0.423261942272670610, -0.423216641375837090, -0.423171339420961910, -0.423126036408158050, -0.423080732337539460, +-0.423035427209219050, -0.422990121023310070, -0.422944813779925380, -0.422899505479179040, -0.422854196121183970, -0.422808885706053410, -0.422763574233900210, -0.422718261704838450, +-0.422672948118981100, -0.422627633476441330, -0.422582317777332130, -0.422537001021767500, -0.422491683209860360, -0.422446364341724000, -0.422401044417471390, -0.422355723437216500, +-0.422310401401072340, -0.422265078309151780, -0.422219754161568930, -0.422174428958436650, -0.422129102699868360, -0.422083775385976860, -0.422038447016876370, -0.421993117592679710, +-0.421947787113500280, -0.421902455579451000, -0.421857122990645980, -0.421811789347198150, -0.421766454649220800, -0.421721118896826950, -0.421675782090130740, -0.421630444229245000, +-0.421585105314283230, -0.421539765345358200, -0.421494424322584220, -0.421449082246074190, -0.421403739115941030, -0.421358394932298930, -0.421313049695260840, -0.421267703404940130, +-0.421222356061449750, -0.421177007664903900, -0.421131658215415540, -0.421086307713097960, -0.421040956158064310, -0.420995603550428590, -0.420950249890303880, -0.420904895177803610, +-0.420859539413040660, -0.420814182596129240, -0.420768824727182360, -0.420723465806313420, -0.420678105833635460, -0.420632744809262600, -0.420587382733307870, -0.420542019605884330, +-0.420496655427106130, -0.420451290197086270, -0.420405923915938170, -0.420360556583774860, -0.420315188200710620, -0.420269818766858320, -0.420224448282331520, -0.420179076747243200, +-0.420133704161707590, -0.420088330525837720, -0.420042955839747050, -0.419997580103548540, -0.419952203317356500, -0.419906825481284000, -0.419861446595444390, -0.419816066659950750, +-0.419770685674917320, -0.419725303640457240, -0.419679920556683460, -0.419634536423710290, -0.419589151241650800, -0.419543765010618410, -0.419498377730726240, -0.419452989402088470, +-0.419407600024818250, -0.419362209599029030, -0.419316818124833900, -0.419271425602347150, -0.419226032031681790, -0.419180637412951360, -0.419135241746268930, -0.419089845031748790, +-0.419044447269504070, -0.418999048459648190, -0.418953648602294340, -0.418908247697556750, -0.418862845745548550, -0.418817442746383220, -0.418772038700173880, -0.418726633607034830, +-0.418681227467079200, -0.418635820280420120, -0.418590412047171900, -0.418545002767447600, -0.418499592441360870, -0.418454181069024710, -0.418408768650553490, -0.418363355186060380, +-0.418317940675658860, -0.418272525119462110, -0.418227108517584380, -0.418181690870138960, -0.418136272177239250, -0.418090852438998520, -0.418045431655531040, -0.418000009826949960, +-0.417954586953368900, -0.417909163034900940, -0.417863738071660440, -0.417818312063760630, -0.417772885011314650, -0.417727456914436860, -0.417682027773240430, -0.417636597587838890, +-0.417591166358345480, -0.417545734084874550, -0.417500300767539300, -0.417454866406453300, -0.417409431001729720, -0.417363994553482940, -0.417318557061826250, -0.417273118526873100, +-0.417227678948736750, -0.417182238327531650, -0.417136796663370890, -0.417091353956368200, -0.417045910206636730, -0.417000465414290810, -0.416955019579443810, -0.416909572702208800, +-0.416864124782700300, -0.416818675821031490, -0.416773225817315960, -0.416727774771666950, -0.416682322684198970, -0.416636869555025100, -0.416591415384259140, -0.416545960172014170, +-0.416500503918404760, -0.416455046623544050, -0.416409588287545760, -0.416364128910523050, -0.416318668492590470, -0.416273207033861170, -0.416227744534448880, -0.416182280994466800, +-0.416136816414029500, -0.416091350793250050, -0.416045884132242310, -0.416000416431119400, -0.415954947689995910, -0.415909477908984970, -0.415864007088199980, -0.415818535227755410, +-0.415773062327764450, -0.415727588388340840, -0.415682113409597880, -0.415636637391650020, -0.415591160334610580, -0.415545682238593230, -0.415500203103711270, -0.415454722930079230, +-0.415409241717810350, -0.415363759467018370, -0.415318276177816580, -0.415272791850319570, -0.415227306484640510, -0.415181820080893220, -0.415136332639190920, -0.415090844159648250, +-0.415045354642378460, -0.414999864087494900, -0.414954372495112020, -0.414908879865343250, -0.414863386198302260, -0.414817891494102420, -0.414772395752858290, -0.414726898974683120, +-0.414681401159690710, -0.414635902307994410, -0.414590402419708740, -0.414544901494947050, -0.414499399533823140, -0.414453896536450320, -0.414408392502943150, -0.414362887433415040, +-0.414317381327979680, -0.414271874186750430, -0.414226366009841920, -0.414180856797367550, -0.414135346549440560, -0.414089835266175650, -0.414044322947686120, -0.413998809594085800, +-0.413953295205488070, -0.413907779782007490, -0.413862263323757470, -0.413816745830851760, -0.413771227303403820, -0.413725707741528230, -0.413680187145338330, -0.413634665514947990, +-0.413589142850470550, -0.413543619152020650, -0.413498094419711750, -0.413452568653657590, -0.413407041853971590, -0.413361514020768430, -0.413315985154161460, -0.413270455254264530, +-0.413224924321191070, -0.413179392355055690, -0.413133859355971800, -0.413088325324052870, -0.413042790259413590, -0.412997254162167260, -0.412951717032427830, -0.412906178870308730, +-0.412860639675924510, -0.412815099449388770, -0.412769558190815230, -0.412724015900317430, -0.412678472578009990, -0.412632928224006320, -0.412587382838420390, -0.412541836421365550, +-0.412496288972956540, -0.412450740493306820, -0.412405190982530260, -0.412359640440740300, -0.412314088868051650, -0.412268536264577770, -0.412222982630432170, -0.412177427965729480, +-0.412131872270583230, -0.412086315545107270, -0.412040757789415180, -0.411995199003621580, -0.411949639187839940, -0.411904078342184290, -0.411858516466767970, -0.411812953561705770, +-0.411767389627111180, -0.411721824663098150, -0.411676258669780140, -0.411630691647271900, -0.411585123595686890, -0.411539554515139130, -0.411493984405742030, -0.411448413267610390, +-0.411402841100857730, -0.411357267905597570, -0.411311693681944590, -0.411266118430012430, -0.411220542149914940, -0.411174964841765690, -0.411129386505679480, -0.411083807141769790, +-0.411038226750150560, -0.410992645330935320, -0.410947062884238930, -0.410901479410174850, -0.410855894908857100, -0.410810309380399200, -0.410764722824915940, -0.410719135242520850, +-0.410673546633327950, -0.410627956997450750, -0.410582366335004110, -0.410536774646101500, -0.410491181930856600, -0.410445588189384090, -0.410399993421797670, -0.410354397628211240, +-0.410308800808738380, -0.410263202963493940, -0.410217604092591500, -0.410172004196145080, -0.410126403274268190, -0.410080801327075750, -0.410035198354681270, -0.409989594357198840, +-0.409943989334741970, -0.409898383287425560, -0.409852776215363150, -0.409807168118668850, -0.409761558997456200, -0.409715948851840040, -0.409670337681934060, -0.409624725487852230, +-0.409579112269708110, -0.409533498027616680, -0.409487882761691510, -0.409442266472046180, -0.409396649158795590, -0.409351030822053430, -0.409305411461933670, -0.409259791078549980, +-0.409214169672017180, -0.409168547242449000, -0.409122923789959460, -0.409077299314662190, -0.409031673816672050, -0.408986047296102720, -0.408940419753068330, -0.408894791187682460, +-0.408849161600060020, -0.408803530990314630, -0.408757899358560440, -0.408712266704911120, -0.408666633029481530, -0.408620998332385350, -0.408575362613736280, -0.408529725873649220, +-0.408484088112237800, -0.408438449329616200, -0.408392809525898070, -0.408347168701198300, -0.408301526855630590, -0.408255883989309120, -0.408210240102347520, -0.408164595194860700, +-0.408118949266962410, -0.408073302318766710, -0.408027654350387400, -0.407982005361939350, -0.407936355353536230, -0.407890704325292290, -0.407845052277321150, -0.407799399209737790, +-0.407753745122655940, -0.407708090016189350, -0.407662433890452920, -0.407616776745560410, -0.407571118581625920, -0.407525459398763280, -0.407479799197087320, -0.407434137976711960, +-0.407388475737751170, -0.407342812480318840, -0.407297148204529890, -0.407251482910498010, -0.407205816598337490, -0.407160149268161960, -0.407114480920086510, -0.407068811554224860, +-0.407023141170691160, -0.406977469769599200, -0.406931797351064000, -0.406886123915199290, -0.406840449462119280, -0.406794773991937700, -0.406749097504769620, -0.406703420000728790, +-0.406657741479929000, -0.406612061942485280, -0.406566381388511420, -0.406520699818121560, -0.406475017231429590, -0.406429333628550440, -0.406383649009598000, -0.406337963374686420, +-0.406292276723929480, -0.406246589057442320, -0.406200900375338620, -0.406155210677732750, -0.406109519964738430, -0.406063828236470690, -0.406018135493043390, -0.405972441734570700, +-0.405926746961166600, -0.405881051172945980, -0.405835354370022720, -0.405789656552510700, -0.405743957720524910, -0.405698257874179240, -0.405652557013587930, -0.405606855138864850, +-0.405561152250125010, -0.405515448347482270, -0.405469743431050970, -0.405424037500944860, -0.405378330557279070, -0.405332622600167450, -0.405286913629724240, -0.405241203646063420, +-0.405195492649299940, -0.405149780639547760, -0.405104067616921080, -0.405058353581533860, -0.405012638533501170, -0.404966922472936860, -0.404921205399954850, -0.404875487314670270, +-0.404829768217196910, -0.404784048107649170, -0.404738326986140870, -0.404692604852787190, -0.404646881707701970, -0.404601157550999570, -0.404555432382793840, -0.404509706203199980, +-0.404463979012331830, -0.404418250810303750, -0.404372521597229640, -0.404326791373224580, -0.404281060138402590, -0.404235327892877920, -0.404189594636764570, -0.404143860370177580, +-0.404098125093230950, -0.404052388806038660, -0.404006651508715730, -0.403960913201376230, -0.403915173884134450, -0.403869433557104310, -0.403823692220400930, -0.403777949874138400, +-0.403732206518430950, -0.403686462153392600, -0.403640716779138540, -0.403594970395782630, -0.403549223003439320, -0.403503474602222520, -0.403457725192247480, -0.403411974773628110, +-0.403366223346478760, -0.403320470910913500, -0.403274717467047460, -0.403228963014994610, -0.403183207554869360, -0.403137451086785730, -0.403091693610858840, -0.403045935127202660, +-0.403000175635931320, -0.402954415137159900, -0.402908653631002480, -0.402862891117573400, -0.402817127596986680, -0.402771363069357570, -0.402725597534800030, -0.402679830993428520, +-0.402634063445357020, -0.402588294890700750, -0.402542525329573740, -0.402496754762090460, -0.402450983188364860, -0.402405210608512200, -0.402359437022646540, -0.402313662430882240, +-0.402267886833333420, -0.402222110230115280, -0.402176332621341840, -0.402130554007127160, -0.402084774387586550, -0.402038993762833970, -0.401993212132983950, -0.401947429498150430, +-0.401901645858448790, -0.401855861213992970, -0.401810075564897560, -0.401764288911276580, -0.401718501253245210, -0.401672712590917640, -0.401626922924408270, -0.401581132253831190, +-0.401535340579301680, -0.401489547900933770, -0.401443754218842040, -0.401397959533140560, -0.401352163843944510, -0.401306367151368140, -0.401260569455525350, -0.401214770756531610, +-0.401168971054500890, -0.401123170349547810, -0.401077368641786340, -0.401031565931331880, -0.400985762218298510, -0.400939957502800700, -0.400894151784952630, -0.400848345064869550, +-0.400802537342665630, -0.400756728618455400, -0.400710918892352890, -0.400665108164473480, -0.400619296434931380, -0.400573483703840940, -0.400527669971316450, -0.400481855237473150, +-0.400436039502425290, -0.400390222766287270, -0.400344405029173290, -0.400298586291198690, -0.400252766552477660, -0.400206945813124270, -0.400161124073253940, -0.400115301332980790, +-0.400069477592419400, -0.400023652851683900, -0.399977827110889690, -0.399932000370150920, -0.399886172629582150, -0.399840343889297510, -0.399794514149412420, -0.399748683410041050, +-0.399702851671297990, -0.399657018933297410, -0.399611185196154680, -0.399565350459983930, -0.399519514724899880, -0.399473677991016570, -0.399427840258449520, -0.399382001527312850, +-0.399336161797720750, -0.399290321069788680, -0.399244479343630830, -0.399198636619361720, -0.399152792897095650, -0.399106948176948030, -0.399061102459033030, -0.399015255743465250, +-0.398969408030358910, -0.398923559319829480, -0.398877709611991150, -0.398831858906958550, -0.398786007204845860, -0.398740154505768610, -0.398694300809840970, -0.398648446117177540, +-0.398602590427892640, -0.398556733742101600, -0.398510876059918810, -0.398465017381458340, -0.398419157706835780, -0.398373297036165310, -0.398327435369561610, -0.398281572707138930, +-0.398235709049012730, -0.398189844395297200, -0.398143978746107070, -0.398098112101556660, -0.398052244461761300, -0.398006375826835350, -0.397960506196893490, -0.397914635572049920, +-0.397868763952420210, -0.397822891338118540, -0.397777017729259660, -0.397731143125957860, -0.397685267528328560, -0.397639390936486150, -0.397593513350544770, -0.397547634770620110, +-0.397501755196826290, -0.397455874629278120, -0.397409993068089830, -0.397364110513377000, -0.397318226965253870, -0.397272342423835190, -0.397226456889235250, -0.397180570361569560, +-0.397134682840952440, -0.397088794327498610, -0.397042904821322370, -0.396997014322539310, -0.396951122831263710, -0.396905230347610270, -0.396859336871693390, -0.396813442403628590, +-0.396767546943530110, -0.396721650491512810, -0.396675753047690980, -0.396629854612180200, -0.396583955185094760, -0.396538054766549020, -0.396492153356658550, -0.396446250955537650, +-0.396400347563301170, -0.396354443180063410, -0.396308537805940000, -0.396262631441045180, -0.396216724085493800, -0.396170815739400160, -0.396124906402879950, -0.396078996076047460, +-0.396033084759017500, -0.395987172451904350, -0.395941259154823750, -0.395895344867889960, -0.395849429591217830, -0.395803513324921700, -0.395757596069117200, -0.395711677823918750, +-0.395665758589440640, -0.395619838365798560, -0.395573917153106910, -0.395527994951480440, -0.395482071761033560, -0.395436147581881950, -0.395390222414139960, -0.395344296257922390, +-0.395298369113343650, -0.395252440980519480, -0.395206511859564120, -0.395160581750592540, -0.395114650653719090, -0.395068718569059400, -0.395022785496727920, -0.394976851436839470, +-0.394930916389508500, -0.394884980354850650, -0.394839043332980310, -0.394793105324012020, -0.394747166328061340, -0.394701226345242740, -0.394655285375671070, -0.394609343419460800, +-0.394563400476727550, -0.394517456547585800, -0.394471511632150440, -0.394425565730535890, -0.394379618842857830, -0.394333670969230670, -0.394287722109769370, -0.394241772264588400, +-0.394195821433803330, -0.394149869617528790, -0.394103916815879530, -0.394057963028970060, -0.394012008256916120, -0.393966052499832130, -0.393920095757833040, -0.393874138031033270, +-0.393828179319548550, -0.393782219623493410, -0.393736258942982360, -0.393690297278130990, -0.393644334629053900, -0.393598370995866030, -0.393552406378681770, -0.393506440777616930, +-0.393460474192785960, -0.393414506624303830, -0.393368538072285000, -0.393322568536845220, -0.393276598018099060, -0.393230626516161360, -0.393184654031146720, -0.393138680563170860, +-0.393092706112348310, -0.393046730678793920, -0.393000754262622380, -0.392954776863949310, -0.392908798482889340, -0.392862819119556950, -0.392816838774067920, -0.392770857446536780, +-0.392724875137078490, -0.392678891845807620, -0.392632907572839920, -0.392586922318289950, -0.392540936082272700, -0.392494948864902660, -0.392448960666295700, -0.392402971486566330, +-0.392356981325829520, -0.392310990184199850, -0.392264998061793100, -0.392219004958723860, -0.392173010875107090, -0.392127015811057410, -0.392081019766690630, -0.392035022742121260, +-0.391989024737463940, -0.391943025752834460, -0.391897025788347400, -0.391851024844117820, -0.391805022920260200, -0.391759020016890500, -0.391713016134123240, -0.391667011272073430, +-0.391621005430855650, -0.391574998610585810, -0.391528990811378430, -0.391482982033348580, -0.391436972276610890, -0.391390961541281220, -0.391344949827474090, -0.391298937135304560, +-0.391252923464887330, -0.391206908816338180, -0.391160893189771760, -0.391114876585302700, -0.391068859003046890, -0.391022840443118860, -0.390976820905633790, -0.390930800390706270, +-0.390884778898452080, -0.390838756428986020, -0.390792732982423010, -0.390746708558877830, -0.390700683158466230, -0.390654656781302960, -0.390608629427503020, -0.390562601097181110, +-0.390516571790453070, -0.390470541507433650, -0.390424510248237820, -0.390378478012980370, -0.390332444801777090, -0.390286410614742730, -0.390240375451992360, -0.390194339313640610, +-0.390148302199803400, -0.390102264110595450, -0.390056225046131470, -0.390010185006527290, -0.389964143991897660, -0.389918102002357660, -0.389872059038022020, -0.389826015099006610, +-0.389779970185426210, -0.389733924297395840, -0.389687877435030310, -0.389641829598445400, -0.389595780787755970, -0.389549731003077100, -0.389503680244523480, -0.389457628512211110, +-0.389411575806254630, -0.389365522126769170, -0.389319467473869530, -0.389273411847671670, -0.389227355248290220, -0.389181297675840030, -0.389135239130436960, -0.389089179612195800, +-0.389043119121231740, -0.388997057657659410, -0.388950995221594880, -0.388904931813152830, -0.388858867432448460, -0.388812802079596560, -0.388766735754712990, -0.388720668457912640, +-0.388674600189310600, -0.388628530949021610, -0.388582460737161790, -0.388536389553845730, -0.388490317399188770, -0.388444244273305540, -0.388398170176312170, -0.388352095108323300, +-0.388306019069453830, -0.388259942059819730, -0.388213864079535790, -0.388167785128717140, -0.388121705207478680, -0.388075624315936340, -0.388029542454204900, -0.387983459622399660, +-0.387937375820635310, -0.387891291049027980, -0.387845205307692400, -0.387799118596743760, -0.387753030916296980, -0.387706942266468010, -0.387660852647371710, -0.387614762059123210, +-0.387568670501837460, -0.387522577975630440, -0.387476484480616950, -0.387430390016912260, -0.387384294584631190, -0.387338198183889760, -0.387292100814802860, -0.387246002477485310, +-0.387199903172053160, -0.387153802898621220, -0.387107701657304850, -0.387061599448218720, -0.387015496271479080, -0.386969392127200660, -0.386923287015498770, -0.386877180936488260, +-0.386831073890285150, -0.386784965877004390, -0.386738856896761240, -0.386692746949670540, -0.386646636035848370, -0.386600524155409630, -0.386554411308469570, -0.386508297495143040, +-0.386462182715546170, -0.386416066969793910, -0.386369950258001030, -0.386323832580283690, -0.386277713936756750, -0.386231594327535510, -0.386185473752734930, -0.386139352212471030, +-0.386093229706858780, -0.386047106236013460, -0.386000981800049940, -0.385954856399084390, -0.385908730033231730, -0.385862602702607190, -0.385816474407325750, -0.385770345147503520, +-0.385724214923255480, -0.385678083734696860, -0.385631951581942630, -0.385585818465108920, -0.385539684384310690, -0.385493549339662840, -0.385447413331281520, -0.385401276359281620, +-0.385355138423778610, -0.385308999524887290, -0.385262859662723890, -0.385216718837403330, -0.385170577049041010, -0.385124434297751780, -0.385078290583651950, -0.385032145906856360, +-0.384986000267480370, -0.384939853665638990, -0.384893706101448410, -0.384847557575023540, -0.384801408086479780, -0.384755257635932100, -0.384709106223496690, -0.384662953849288500, +-0.384616800513422510, -0.384570646216014940, -0.384524490957180780, -0.384478334737035350, -0.384432177555693700, -0.384386019413272000, -0.384339860309885260, -0.384293700245648910, +-0.384247539220677840, -0.384201377235088350, -0.384155214288995410, -0.384109050382514470, -0.384062885515760450, -0.384016719688849650, -0.383970552901897020, -0.383924385155018030, +-0.383878216448327700, -0.383832046781942220, -0.383785876155976590, -0.383739704570546290, -0.383693532025766340, -0.383647358521752910, -0.383601184058621150, -0.383555008636486010, +-0.383508832255463730, -0.383462654915669390, -0.383416476617218390, -0.383370297360225820, -0.383324117144807910, -0.383277935971079680, -0.383231753839156640, -0.383185570749153770, +-0.383139386701187410, -0.383093201695372590, -0.383047015731824760, -0.383000828810658940, -0.382954640931991550, -0.382908452095937490, -0.382862262302612280, -0.382816071552131040, +-0.382769879844610030, -0.382723687180164360, -0.382677493558909010, -0.382631298980960320, -0.382585103446433430, -0.382538906955443790, -0.382492709508106430, -0.382446511104537700, +-0.382400311744852730, -0.382354111429166980, -0.382307910157595520, -0.382261707930254710, -0.382215504747259630, -0.382169300608725780, -0.382123095514768250, -0.382076889465503390, +-0.382030682461046320, -0.381984474501512570, -0.381938265587017210, -0.381892055717676590, -0.381845844893605850, -0.381799633114920050, -0.381753420381735600, -0.381707206694167580, +-0.381660992052331560, -0.381614776456342670, -0.381568559906317220, -0.381522342402370370, -0.381476123944617720, -0.381429904533174270, -0.381383684168156490, -0.381337462849679560, +-0.381291240577858900, -0.381245017352809750, -0.381198793174648500, -0.381152568043490240, -0.381106341959450530, -0.381060114922644580, -0.381013886933188770, -0.380967657991198250, +-0.380921428096788530, -0.380875197250074900, -0.380828965451173620, -0.380782732700199970, -0.380736498997269080, -0.380690264342497360, -0.380644028735999950, -0.380597792177892470, +-0.380551554668290100, -0.380505316207309260, -0.380459076795065130, -0.380412836431673340, -0.380366595117249020, -0.380320352851908570, -0.380274109635767300, -0.380227865468940770, +-0.380181620351544130, -0.380135374283693870, -0.380089127265505140, -0.380042879297093630, -0.379996630378574510, -0.379950380510064190, -0.379904129691677970, -0.379857877923530980, +-0.379811625205739690, -0.379765371538419380, -0.379719116921685640, -0.379672861355653650, -0.379626604840439970, -0.379580347376159750, -0.379534088962928670, -0.379487829600861970, +-0.379441569290076050, -0.379395308030686270, -0.379349045822808210, -0.379302782666557090, -0.379256518562049450, -0.379210253509400520, -0.379163987508725930, -0.379117720560140980, +-0.379071452663762130, -0.379025183819704680, -0.378978914028083810, -0.378932643289016100, -0.378886371602616790, -0.378840098969001560, -0.378793825388285600, -0.378747550860585540, +-0.378701275386016610, -0.378654998964694510, -0.378608721596734420, -0.378562443282253020, -0.378516164021365450, -0.378469883814187500, -0.378423602660834470, -0.378377320561422810, +-0.378331037516067840, -0.378284753524885280, -0.378238468587990430, -0.378192182705499810, -0.378145895877528730, -0.378099608104192520, -0.378053319385607660, -0.378007029721889540, +-0.377960739113153870, -0.377914447559515860, -0.377868155061092230, -0.377821861617998130, -0.377775567230349440, -0.377729271898261390, -0.377682975621850600, -0.377636678401232330, +-0.377590380236522420, -0.377544081127836110, -0.377497781075290030, -0.377451480078999480, -0.377405178139080200, -0.377358875255647600, -0.377312571428818240, -0.377266266658707440, +-0.377219960945430920, -0.377173654289104150, -0.377127346689843660, -0.377081038147764720, -0.377034728662982880, -0.376988418235614580, -0.376942106865775230, -0.376895794553580630, +-0.376849481299146080, -0.376803167102588320, -0.376756851964022590, -0.376710535883564730, -0.376664218861330170, -0.376617900897435410, -0.376571581991995920, -0.376525262145127490, +-0.376478941356945480, -0.376432619627566520, -0.376386296957106070, -0.376339973345679810, -0.376293648793403210, -0.376247323300392960, -0.376200996866764340, -0.376154669492632820, +-0.376108341178115040, -0.376062011923326440, -0.376015681728382790, -0.375969350593399530, -0.375923018518493300, -0.375876685503779510, -0.375830351549374050, -0.375784016655392240, +-0.375737680821950860, -0.375691344049165210, -0.375645006337151250, -0.375598667686024350, -0.375552328095901220, -0.375505987566897240, -0.375459646099128300, -0.375413303692709810, +-0.375366960347758460, -0.375320616064389770, -0.375274270842719080, -0.375227924682863150, -0.375181577584937420, -0.375135229549057700, -0.375088880575339570, -0.375042530663899590, +-0.374996179814853280, -0.374949828028316560, -0.374903475304404820, -0.374857121643234810, -0.374810767044922000, -0.374764411509582280, -0.374718055037331130, -0.374671697628285230, +-0.374625339282560090, -0.374578980000271620, -0.374532619781535290, -0.374486258626467780, -0.374439896535184670, -0.374393533507801800, -0.374347169544434700, -0.374300804645200100, +-0.374254438810213470, -0.374208072039590280, -0.374161704333447360, -0.374115335691900200, -0.374068966115064680, -0.374022595603056400, -0.373976224155991970, -0.373929851773986970, +-0.373883478457157360, -0.373837104205618660, -0.373790729019487620, -0.373744352898879690, -0.373697975843910960, -0.373651597854696820, -0.373605218931354120, -0.373558839073998390, +-0.373512458282745540, -0.373466076557711140, -0.373419693899011970, -0.373373310306763570, -0.373326925781081450, -0.373280540322082470, -0.373234153929882070, -0.373187766604596350, +-0.373141378346340760, -0.373094989155232200, -0.373048599031386100, -0.373002207974918510, -0.372955815985945020, -0.372909423064582410, -0.372863029210946220, -0.372816634425152450, +-0.372770238707316680, -0.372723842057555770, -0.372677444475985160, -0.372631045962721010, -0.372584646517878810, -0.372538246141575440, -0.372491844833926440, -0.372445442595047420, +-0.372399039425055200, -0.372352635324065370, -0.372306230292193950, -0.372259824329556570, -0.372213417436270010, -0.372167009612449920, -0.372120600858212300, -0.372074191173672800, +-0.372027780558948200, -0.371981369014154130, -0.371934956539406670, -0.371888543134821390, -0.371842128800515200, -0.371795713536603620, -0.371749297343202830, -0.371702880220428360, +-0.371656462168397090, -0.371610043187224680, -0.371563623277026740, -0.371517202437920140, -0.371470780670020540, -0.371424357973443970, -0.371377934348306130, -0.371331509794723850, +-0.371285084312812820, -0.371238657902689060, -0.371192230564468260, -0.371145802298267270, -0.371099373104201770, -0.371052942982387890, -0.371006511932941150, -0.370960079955978630, +-0.370913647051615890, -0.370867213219969020, -0.370820778461153690, -0.370774342775286810, -0.370727906162484130, -0.370681468622861670, -0.370635030156535090, -0.370588590763621380, +-0.370542150444236160, -0.370495709198495170, -0.370449267026515370, -0.370402823928412340, -0.370356379904302260, -0.370309934954300810, -0.370263489078524970, -0.370217042277090400, +-0.370170594550113200, -0.370124145897709140, -0.370077696319995100, -0.370031245817086800, -0.369984794389100420, -0.369938342036151610, -0.369891888758357380, -0.369845434555833410, +-0.369798979428695880, -0.369752523377060490, -0.369706066401044200, -0.369659608500762740, -0.369613149676331850, -0.369566689927868450, -0.369520229255488390, -0.369473767659307730, +-0.369427305139442270, -0.369380841696008930, -0.369334377329123500, -0.369287912038902100, -0.369241445825460530, -0.369194978688915710, -0.369148510629383530, -0.369102041646980020, +-0.369055571741820960, -0.369009100914023450, -0.368962629163703150, -0.368916156490976310, -0.368869682895958670, -0.368823208378767200, -0.368776732939517680, -0.368730256578325980, +-0.368683779295309040, -0.368637301090582630, -0.368590821964262960, -0.368544341916465850, -0.368497860947308300, -0.368451379056906060, -0.368404896245375420, -0.368358412512832130, +-0.368311927859393150, -0.368265442285174440, -0.368218955790292070, -0.368172468374861890, -0.368125980039000990, -0.368079490782825090, -0.368033000606450500, -0.367986509509993010, +-0.367940017493569640, -0.367893524557296240, -0.367847030701288990, -0.367800535925663810, -0.367754040230537650, -0.367707543616026420, -0.367661046082245920, -0.367614547629313170, +-0.367568048257344130, -0.367521547966454920, -0.367475046756761400, -0.367428544628380700, -0.367382041581428680, -0.367335537616021500, -0.367289032732275090, -0.367242526930306510, +-0.367196020210231620, -0.367149512572166660, -0.367103004016227530, -0.367056494542531310, -0.367009984151193790, -0.366963472842331380, -0.366916960616059830, -0.366870447472496310, +-0.366823933411756680, -0.366777418433956840, -0.366730902539213810, -0.366684385727643500, -0.366637867999362270, -0.366591349354485950, -0.366544829793131690, -0.366498309315415330, +-0.366451787921453220, -0.366405265611361220, -0.366358742385256450, -0.366312218243254830, -0.366265693185472640, -0.366219167212025850, -0.366172640323031540, -0.366126112518605610, +-0.366079583798864410, -0.366033054163923840, -0.365986523613901050, -0.365939992148911990, -0.365893459769072500, -0.365846926474499730, -0.365800392265309690, -0.365753857141618680, +-0.365707321103542590, -0.365660784151198630, -0.365614246284702680, -0.365567707504171170, -0.365521167809719940, -0.365474627201466230, -0.365428085679525890, -0.365381543244015390, +-0.365334999895050580, -0.365288455632748750, -0.365241910457225700, -0.365195364368597950, -0.365148817366981350, -0.365102269452493080, -0.365055720625249160, -0.365009170885365550, +-0.364962620232959390, -0.364916068668146690, -0.364869516191043850, -0.364822962801766790, -0.364776408500432690, -0.364729853287157620, -0.364683297162057940, -0.364636740125249550, +-0.364590182176849740, -0.364543623316974490, -0.364497063545740130, -0.364450502863262750, -0.364403941269659530, -0.364357378765046420, -0.364310815349539910, -0.364264251023255880, +-0.364217685786311700, -0.364171119638823260, -0.364124552580907090, -0.364077984612679040, -0.364031415734256510, -0.363984845945755420, -0.363938275247291780, -0.363891703638982880, +-0.363845131120944740, -0.363798557693293720, -0.363751983356145950, -0.363705408109618600, -0.363658831953827750, -0.363612254888889820, -0.363565676914920810, -0.363519098032038020, +-0.363472518240357530, -0.363425937539995750, -0.363379355931068680, -0.363332773413693630, -0.363286189987986620, -0.363239605654064210, -0.363193020412042320, -0.363146434262038300, +-0.363099847204168210, -0.363053259238548090, -0.363006670365295210, -0.362960080584525670, -0.362913489896355910, -0.362866898300902020, -0.362820305798281340, -0.362773712388609840, +-0.362727118072004080, -0.362680522848580100, -0.362633926718455290, -0.362587329681745560, -0.362540731738567600, -0.362494132889037370, -0.362447533133272160, -0.362400932471388220, +-0.362354330903501890, -0.362307728429729300, -0.362261125050187820, -0.362214520764993550, -0.362167915574262530, -0.362121309478112160, -0.362074702476658520, -0.362028094570018110, +-0.361981485758307080, -0.361934876041642710, -0.361888265420141130, -0.361841653893918920, -0.361795041463092160, -0.361748428127778240, -0.361701813888093250, -0.361655198744153690, +-0.361608582696075710, -0.361561965743976700, -0.361515347887972790, -0.361468729128180510, -0.361422109464715980, -0.361375488897696610, -0.361328867427238460, -0.361282245053458180, +-0.361235621776471890, -0.361188997596396940, -0.361142372513349520, -0.361095746527445750, -0.361049119638803040, -0.361002491847537470, -0.360955863153765710, -0.360909233557603900, +-0.360862603059169400, -0.360815971658578370, -0.360769339355947460, -0.360722706151392740, -0.360676072045031660, -0.360629437036980470, -0.360582801127355630, -0.360536164316273390, +-0.360489526603851140, -0.360442887990205070, -0.360396248475451820, -0.360349608059707500, -0.360302966743089590, -0.360256324525714270, -0.360209681407697710, -0.360163037389157340, +-0.360116392470209430, -0.360069746650970470, -0.360023099931556790, -0.359976452312085750, -0.359929803792673590, -0.359883154373436930, -0.359836504054491910, -0.359789852835956100, +-0.359743200717945690, -0.359696547700577180, -0.359649893783966950, -0.359603238968232430, -0.359556583253489770, -0.359509926639855650, -0.359463269127446310, -0.359416610716379200, +-0.359369951406770580, -0.359323291198736630, -0.359276630092394910, -0.359229968087861620, -0.359183305185253380, -0.359136641384686430, -0.359089976686278340, -0.359043311090145310, +-0.358996644596404010, -0.358949977205170630, -0.358903308916562800, -0.358856639730696650, -0.358809969647688910, -0.358763298667655830, -0.358716626790714920, -0.358669954016982430, +-0.358623280346575090, -0.358576605779609090, -0.358529930316202010, -0.358483253956470130, -0.358436576700530090, -0.358389898548498180, -0.358343219500491970, -0.358296539556627660, +-0.358249858717021640, -0.358203176981791380, -0.358156494351053180, -0.358109810824923710, -0.358063126403519340, -0.358016441086957520, -0.357969754875354650, -0.357923067768827370, +-0.357876379767491980, -0.357829690871466100, -0.357783001080865970, -0.357736310395808330, -0.357689618816409540, -0.357642926342787050, -0.357596232975057330, -0.357549538713336950, +-0.357502843557742370, -0.357456147508391050, -0.357409450565399360, -0.357362752728883630, -0.357316053998961490, -0.357269354375749140, -0.357222653859363470, -0.357175952449920680, +-0.357129250147538490, -0.357082546952333160, -0.357035842864421420, -0.356989137883919730, -0.356942432010945550, -0.356895725245615300, -0.356849017588045770, -0.356802309038353250, +-0.356755599596655370, -0.356708889263068480, -0.356662178037709390, -0.356615465920694430, -0.356568752912141240, -0.356522039012166170, -0.356475324220885570, -0.356428608538417070, +-0.356381891964877070, -0.356335174500382320, -0.356288456145049230, -0.356241736898995410, -0.356195016762337280, -0.356148295735191580, -0.356101573817674710, -0.356054851009904310, +-0.356008127311996820, -0.355961402724069010, -0.355914677246237270, -0.355867950878619220, -0.355821223621331340, -0.355774495474490420, -0.355727766438212800, -0.355681036512616180, +-0.355634305697816950, -0.355587573993931590, -0.355540841401077670, -0.355494107919371690, -0.355447373548930410, -0.355400638289870290, -0.355353902142309000, -0.355307165106362950, +-0.355260427182148950, -0.355213688369783510, -0.355166948669384250, -0.355120208081067650, -0.355073466604950480, -0.355026724241149230, -0.354979980989781620, -0.354933236850964010, +-0.354886491824813350, -0.354839745911446070, -0.354792999110979780, -0.354746251423531000, -0.354699502849216640, -0.354652753388153050, -0.354606003040458030, -0.354559251806247980, +-0.354512499685639420, -0.354465746678749970, -0.354418992785696220, -0.354372238006594950, -0.354325482341562690, -0.354278725790717120, -0.354231968354174700, -0.354185210032052440, +-0.354138450824466710, -0.354091690731535240, -0.354044929753374540, -0.353998167890101520, -0.353951405141832710, -0.353904641508685780, -0.353857876990777250, -0.353811111588223980, +-0.353764345301142590, -0.353717578129650710, -0.353670810073864860, -0.353624041133901610, -0.353577271309878700, -0.353530500601912550, -0.353483729010120210, -0.353436956534618040, +-0.353390183175523950, -0.353343408932954410, -0.353296633807026360, -0.353249857797856280, -0.353203080905562020, -0.353156303130259970, -0.353109524472067230, -0.353062744931100240, +-0.353015964507476800, -0.352969183201313490, -0.352922401012727200, -0.352875617941834470, -0.352828833988753140, -0.352782049153599670, -0.352735263436490700, -0.352688476837544010, +-0.352641689356876120, -0.352594900994604000, -0.352548111750844160, -0.352501321625714510, -0.352454530619331570, -0.352407738731812250, -0.352360945963273220, -0.352314152313832230, +-0.352267357783605850, -0.352220562372711040, -0.352173766081264440, -0.352126968909383890, -0.352080170857185850, -0.352033371924787400, -0.351986572112305110, -0.351939771419856830, +-0.351892969847559080, -0.351846167395528930, -0.351799364063882900, -0.351752559852738960, -0.351705754762213550, -0.351658948792423380, -0.351612141943486220, -0.351565334215518720, +-0.351518525608637890, -0.351471716122960350, -0.351424905758603910, -0.351378094515685190, -0.351331282394321260, -0.351284469394628710, -0.351237655516725370, -0.351190840760727930, +-0.351144025126753360, -0.351097208614918330, -0.351050391225340710, -0.351003572958137060, -0.350956753813424500, -0.350909933791319680, -0.350863112891940390, -0.350816291115403360, +-0.350769468461825160, -0.350722644931323710, -0.350675820524015640, -0.350628995240018000, -0.350582169079447500, -0.350535342042421980, -0.350488514129058070, -0.350441685339472950, +-0.350394855673783150, -0.350348025132106610, -0.350301193714560030, -0.350254361421260480, -0.350207528252324600, -0.350160694207870330, -0.350113859288014310, -0.350067023492873610, +-0.350020186822564970, -0.349973349277206250, -0.349926510856914170, -0.349879671561805440, -0.349832831391997890, -0.349785990347608320, -0.349739148428753750, -0.349692305635550870, +-0.349645461968117630, -0.349598617426570780, -0.349551772011027380, -0.349504925721604130, -0.349458078558418930, -0.349411230521588620, -0.349364381611230180, -0.349317531827460390, +-0.349270681170397170, -0.349223829640157250, -0.349176977236857760, -0.349130123960615430, -0.349083269811548190, -0.349036414789772760, -0.348989558895405890, -0.348942702128565540, +-0.348895844489368450, -0.348848985977931740, -0.348802126594372150, -0.348755266338807660, -0.348708405211354990, -0.348661543212131280, -0.348614680341253370, -0.348567816598839120, +-0.348520951985005320, -0.348474086499869160, -0.348427220143547380, -0.348380352916157990, -0.348333484817817670, -0.348286615848643680, -0.348239746008752680, -0.348192875298262760, +-0.348146003717290650, -0.348099131265953540, -0.348052257944368170, -0.348005383752652610, -0.347958508690923540, -0.347911632759297820, -0.347864755957893400, -0.347817878286827140, +-0.347770999746216170, -0.347724120336177220, -0.347677240056828430, -0.347630358908286590, -0.347583476890668760, -0.347536594004091870, -0.347489710248673920, -0.347442825624531710, +-0.347395940131782380, -0.347349053770542810, -0.347302166540931050, -0.347255278443063860, -0.347208389477058450, -0.347161499643031670, -0.347114608941101580, -0.347067717371384920, +-0.347020824933998550, -0.346973931629060540, -0.346927037456687740, -0.346880142416997330, -0.346833246510106110, -0.346786349736132260, -0.346739452095192470, -0.346692553587404080, +-0.346645654212883900, -0.346598753971750000, -0.346551852864119160, -0.346504950890108740, -0.346458048049835540, -0.346411144343417580, -0.346364239770971800, -0.346317334332615410, +-0.346270428028465300, -0.346223520858639500, -0.346176612823254900, -0.346129703922428370, -0.346082794156277960, -0.346035883524920600, -0.345988972028473510, -0.345942059667053600, +-0.345895146440778960, -0.345848232349766420, -0.345801317394133280, -0.345754401573996510, -0.345707484889474060, -0.345660567340682960, -0.345613648927740440, -0.345566729650763350, +-0.345519809509869880, -0.345472888505176880, -0.345425966636801640, -0.345379043904861130, -0.345332120309473360, -0.345285195850755290, -0.345238270528824280, -0.345191344343797110, +-0.345144417295792040, -0.345097489384925960, -0.345050560611315670, -0.345003630975079410, -0.344956700476334090, -0.344909769115197050, -0.344862836891785150, -0.344815903806216520, +-0.344768969858608220, -0.344722035049077450, -0.344675099377741160, -0.344628162844717530, -0.344581225450123540, -0.344534287194076470, -0.344487348076693230, -0.344440408098092070, +-0.344393467258389870, -0.344346525557704060, -0.344299582996151430, -0.344252639573850330, -0.344205695290917600, -0.344158750147470220, -0.344111804143626410, -0.344064857279503030, +-0.344017909555217550, -0.343970960970886860, -0.343924011526629210, -0.343877061222561510, -0.343830110058801150, -0.343783158035465160, -0.343736205152671610, -0.343689251410537580, +-0.343642296809180460, -0.343595341348717110, -0.343548385029265880, -0.343501427850943670, -0.343454469813867850, -0.343407510918155520, -0.343360551163924780, -0.343313590551292620, +-0.343266629080376140, -0.343219666751293510, -0.343172703564161630, -0.343125739519098080, -0.343078774616219720, -0.343031808855644830, -0.342984842237490430, -0.342937874761873930, +-0.342890906428912350, -0.342843937238723860, -0.342796967191425610, -0.342749996287134870, -0.342703024525968740, -0.342656051908045490, -0.342609078433482090, -0.342562104102396010, +-0.342515128914904270, -0.342468152871125090, -0.342421175971175500, -0.342374198215172620, -0.342327219603234590, -0.342280240135478590, -0.342233259812021960, -0.342186278632981730, +-0.342139296598476250, -0.342092313708622530, -0.342045329963538040, -0.341998345363339780, -0.341951359908146070, -0.341904373598073960, -0.341857386433240930, -0.341810398413764040, +-0.341763409539761530, -0.341716419811350540, -0.341669429228648460, -0.341622437791772370, -0.341575445500840680, -0.341528452355970290, -0.341481458357278830, -0.341434463504883270, +-0.341387467798902000, -0.341340471239452050, -0.341293473826650540, -0.341246475560615710, -0.341199476441464700, -0.341152476469315010, -0.341105475644283730, -0.341058473966489140, +-0.341011471436048370, -0.340964468053078950, -0.340917463817697940, -0.340870458730023640, -0.340823452790173230, -0.340776445998264180, -0.340729438354413610, -0.340682429858739870, +-0.340635420511360030, -0.340588410312391680, -0.340541399261951820, -0.340494387360158910, -0.340447374607130040, -0.340400361002982320, -0.340353346547834110, -0.340306331241802540, +-0.340259315085005120, -0.340212298077559040, -0.340165280219582590, -0.340118261511192950, -0.340071241952507650, -0.340024221543643870, -0.339977200284719890, -0.339930178175852970, +-0.339883155217160560, -0.339836131408759850, -0.339789106750769230, -0.339742081243305850, -0.339695054886487270, -0.339648027680430680, -0.339600999625254360, -0.339553970721075570, +-0.339506940968011480, -0.339459910366180400, -0.339412878915699550, -0.339365846616686510, -0.339318813469258460, -0.339271779473533760, -0.339224744629629590, -0.339177708937663640, +-0.339130672397752910, -0.339083635010015980, -0.339036596774569930, -0.338989557691532440, -0.338942517761020580, -0.338895476983152870, -0.338848435358046430, -0.338801392885818950, +-0.338754349566587560, -0.338707305400470730, -0.338660260387585570, -0.338613214528049820, -0.338566167821980570, -0.338519120269496380, -0.338472071870714320, -0.338425022625751750, +-0.338377972534726960, -0.338330921597757290, -0.338283869814960280, -0.338236817186453210, -0.338189763712354490, -0.338142709392781350, -0.338095654227851480, -0.338048598217682020, +-0.338001541362391470, -0.337954483662097130, -0.337907425116916520, -0.337860365726966980, -0.337813305492366880, -0.337766244413233550, -0.337719182489684630, -0.337672119721837300, +-0.337625056109810140, -0.337577991653720270, -0.337530926353685030, -0.337483860209822910, -0.337436793222251170, -0.337389725391087360, -0.337342656716448920, -0.337295587198454150, +-0.337248516837220510, -0.337201445632865530, -0.337154373585506480, -0.337107300695261960, -0.337060226962249190, -0.337013152386585860, -0.336966076968389210, -0.336919000707777800, +-0.336871923604868890, -0.336824845659780160, -0.336777766872628890, -0.336730687243533670, -0.336683606772611670, -0.336636525459980240, -0.336589443305757960, -0.336542360310062020, +-0.336495276473010250, -0.336448191794719800, -0.336401106275309340, -0.336354019914896050, -0.336306932713597790, -0.336259844671531750, -0.336212755788816490, -0.336165666065569360, +-0.336118575501908050, -0.336071484097949900, -0.336024391853813440, -0.335977298769616020, -0.335930204845475370, -0.335883110081508730, -0.335836014477834790, -0.335788918034570780, +-0.335741820751834120, -0.335694722629743260, -0.335647623668415610, -0.335600523867968900, -0.335553423228520440, -0.335506321750188910, -0.335459219433091540, -0.335412116277346070, +-0.335365012283069970, -0.335317907450381700, -0.335270801779398660, -0.335223695270238650, -0.335176587923018960, -0.335129479737858280, -0.335082370714873850, -0.335035260854183500, +-0.334988150155904550, -0.334941038620155670, -0.334893926247054220, -0.334846813036717930, -0.334799698989264150, -0.334752584104811570, -0.334705468383477530, -0.334658351825379450, +-0.334611234430635840, -0.334564116199364160, -0.334516997131682200, -0.334469877227707320, -0.334422756487558200, -0.334375634911352190, -0.334328512499207030, -0.334281389251240240, +-0.334234265167570320, -0.334187140248314810, -0.334140014493591430, -0.334092887903517600, -0.334045760478211940, -0.333998632217791860, -0.333951503122375260, -0.333904373192079440, +-0.333857242427023140, -0.333810110827323700, -0.333762978393098600, -0.333715845124466450, -0.333668711021544660, -0.333621576084451140, -0.333574440313303240, -0.333527303708219700, +-0.333480166269317870, -0.333433027996715590, -0.333385888890530340, -0.333338748950880780, -0.333291608177884390, -0.333244466571658960, -0.333197324132321950, -0.333150180859992040, +-0.333103036754786640, -0.333055891816823710, -0.333008746046220610, -0.332961599443096060, -0.332914452007567530, -0.332867303739752430, -0.332820154639769440, -0.332773004707736130, +-0.332725853943770300, -0.332678702347989410, -0.332631549920512190, -0.332584396661456120, -0.332537242570938970, -0.332490087649078390, -0.332442931895992940, -0.332395775311800200, +-0.332348617896618010, -0.332301459650563900, -0.332254300573756490, -0.332207140666313410, -0.332159979928352390, -0.332112818359991070, -0.332065655961348070, -0.332018492732540970, +-0.331971328673687620, -0.331924163784905520, -0.331876998066313430, -0.331829831518028860, -0.331782664140169270, -0.331735495932853510, -0.331688326896198930, -0.331641157030323540, +-0.331593986335344870, -0.331546814811381650, -0.331499642458551400, -0.331452469276972030, -0.331405295266761050, -0.331358120428037250, -0.331310944760918210, -0.331263768265521730, +-0.331216590941965480, -0.331169412790368100, -0.331122233810847270, -0.331075054003520770, -0.331027873368506310, -0.330980691905922500, -0.330933509615887020, -0.330886326498517290, +-0.330839142553932210, -0.330791957782249240, -0.330744772183586390, -0.330697585758061240, -0.330650398505792480, -0.330603210426897720, -0.330556021521494990, -0.330508831789701750, +-0.330461641231636850, -0.330414449847417860, -0.330367257637162740, -0.330320064600989060, -0.330272870739015620, -0.330225676051360000, -0.330178480538140200, -0.330131284199473800, +-0.330084087035479590, -0.330036889046275150, -0.329989690231978110, -0.329942490592707250, -0.329895290128580150, -0.329848088839714840, -0.329800886726228870, -0.329753683788241100, +-0.329706480025869110, -0.329659275439230960, -0.329612070028444170, -0.329564863793627650, -0.329517656734898970, -0.329470448852376090, -0.329423240146176740, -0.329376030616419680, +-0.329328820263222520, -0.329281609086703340, -0.329234397086979710, -0.329187184264170540, -0.329139970618393400, -0.329092756149765850, -0.329045540858406930, -0.328998324744434080, +-0.328951107807965440, -0.328903890049118630, -0.328856671468012450, -0.328809452064764640, -0.328762231839493210, -0.328715010792315800, -0.328667788923351250, -0.328620566232717180, +-0.328573342720531790, -0.328526118386912540, -0.328478893231978490, -0.328431667255847160, -0.328384440458636680, -0.328337212840464630, -0.328289984401450020, -0.328242755141710420, +-0.328195525061363960, -0.328148294160528260, -0.328101062439322240, -0.328053829897863580, -0.328006596536269900, -0.327959362354660170, -0.327912127353152010, -0.327864891531863540, +-0.327817654890912470, -0.327770417430417630, -0.327723179150496760, -0.327675940051267930, -0.327628700132848840, -0.327581459395358430, -0.327534217838914340, -0.327486975463634760, +-0.327439732269637240, -0.327392488257040870, -0.327345243425963270, -0.327297997776522580, -0.327250751308836460, -0.327203504023023840, -0.327156255919202500, -0.327109006997490130, +-0.327061757258005630, -0.327014506700866740, -0.326967255326191530, -0.326920003134097860, -0.326872750124704510, -0.326825496298129350, -0.326778241654490430, -0.326730986193905500, +-0.326683729916493470, -0.326636472822372180, -0.326589214911659650, -0.326541956184473740, -0.326494696640933280, -0.326447436281156130, -0.326400175105260370, -0.326352913113363790, +-0.326305650305585280, -0.326258386682042660, -0.326211122242853700, -0.326163856988137320, -0.326116590918011320, -0.326069324032593810, -0.326022056332002600, -0.325974787816356640, +-0.325927518485773730, -0.325880248340371990, -0.325832977380269280, -0.325785705605584510, -0.325738433016435460, -0.325691159612940320, -0.325643885395216880, -0.325596610363384160, +-0.325549334517559910, -0.325502057857862290, -0.325454780384409170, -0.325407502097319450, -0.325360222996711020, -0.325312943082702030, -0.325265662355410210, -0.325218380814954740, +-0.325171098461453260, -0.325123815295023600, -0.325076531315784840, -0.325029246523854790, -0.324981960919351610, -0.324934674502393050, -0.324887387273098290, -0.324840099231585020, +-0.324792810377971530, -0.324745520712375610, -0.324698230234916290, -0.324650938945711340, -0.324603646844879130, -0.324556353932537340, -0.324509060208805100, -0.324461765673800200, +-0.324414470327640870, -0.324367174170444970, -0.324319877202331520, -0.324272579423418420, -0.324225280833823400, -0.324177981433665660, -0.324130681223062930, -0.324083380202133510, +-0.324036078370995180, -0.323988775729767140, -0.323941472278567120, -0.323894168017513420, -0.323846862946723880, -0.323799557066317630, -0.323752250376412480, -0.323704942877126700, +-0.323657634568578100, -0.323610325450885860, -0.323563015524167830, -0.323515704788542250, -0.323468393244127020, -0.323421080891041160, -0.323373767729402630, -0.323326453759329280, +-0.323279138980940180, -0.323231823394353250, -0.323184506999686760, -0.323137189797058580, -0.323089871786587880, -0.323042552968392460, -0.322995233342590670, -0.322947912909300360, +-0.322900591668640710, -0.322853269620729580, -0.322805946765685250, -0.322758623103625690, -0.322711298634669960, -0.322663973358935980, -0.322616647276542050, -0.322569320387606110, +-0.322521992692247240, -0.322474664190583460, -0.322427334882732560, -0.322380004768813730, -0.322332673848944930, -0.322285342123244390, -0.322238009591830130, -0.322190676254821230, +-0.322143342112335640, -0.322096007164491720, -0.322048671411407360, -0.322001334853201760, -0.321953997489992760, -0.321906659321898820, -0.321859320349037800, -0.321811980571528880, +-0.321764639989490010, -0.321717298603039550, -0.321669956412295450, -0.321622613417376860, -0.321575269618401720, -0.321527925015488440, -0.321480579608754870, -0.321433233398320310, +-0.321385886384302650, -0.321338538566819880, -0.321291189945991150, -0.321243840521934500, -0.321196490294768210, -0.321149139264610250, -0.321101787431579910, -0.321054434795795100, +-0.321007081357374160, -0.320959727116435110, -0.320912372073097200, -0.320865016227478320, -0.320817659579696930, -0.320770302129870950, -0.320722943878119670, -0.320675584824560990, +-0.320628224969313370, -0.320580864312494720, -0.320533502854224380, -0.320486140594620270, -0.320438777533800400, -0.320391413671884010, -0.320344049008989050, -0.320296683545234000, +-0.320249317280736800, -0.320201950215616700, -0.320154582349991780, -0.320107213683980370, -0.320059844217700560, -0.320012473951271530, -0.319965102884811280, -0.319917731018438290, +-0.319870358352270570, -0.319822984886427350, -0.319775610621026720, -0.319728235556187010, -0.319680859692026310, -0.319633483028663900, -0.319586105566217750, -0.319538727304805930, +-0.319491348244547720, -0.319443968385561110, -0.319396587727964590, -0.319349206271876180, -0.319301824017415190, -0.319254440964699630, -0.319207057113848000, -0.319159672464978280, +-0.319112287018209760, -0.319064900773660560, -0.319017513731449150, -0.318970125891693490, -0.318922737254512920, -0.318875347820025520, -0.318827957588349810, -0.318780566559603680, +-0.318733174733906610, -0.318685782111376600, -0.318638388692132180, -0.318590994476291300, -0.318543599463973370, -0.318496203655296460, -0.318448807050378590, -0.318401409649339160, +-0.318354011452296190, -0.318306612459368200, -0.318259212670673250, -0.318211812086330700, -0.318164410706458620, -0.318117008531175470, -0.318069605560599430, -0.318022201794849800, +-0.317974797234044650, -0.317927391878302490, -0.317879985727741400, -0.317832578782480830, -0.317785171042638810, -0.317737762508333800, -0.317690353179684030, -0.317642943056808790, +-0.317595532139826160, -0.317548120428854270, -0.317500707924012530, -0.317453294625419050, -0.317405880533192300, -0.317358465647450410, -0.317311049968312770, -0.317263633495897530, +-0.317216216230323260, -0.317168798171707960, -0.317121379320171090, -0.317073959675830800, -0.317026539238805580, -0.316979118009213580, -0.316931695987174240, -0.316884273172805650, +-0.316836849566226380, -0.316789425167554590, -0.316741999976909610, -0.316694573994409640, -0.316647147220172840, -0.316599719654318600, -0.316552291296964990, -0.316504862148230700, +-0.316457432208233860, -0.316410001477093860, -0.316362569954928790, -0.316315137641857370, -0.316267704537997630, -0.316220270643469080, -0.316172835958389850, -0.316125400482878520, +-0.316077964217053250, -0.316030527161033530, -0.315983089314937520, -0.315935650678883740, -0.315888211252990380, -0.315840771037376960, -0.315793330032161590, -0.315745888237462520, +-0.315698445653399110, -0.315651002280089580, -0.315603558117652560, -0.315556113166206240, -0.315508667425870030, -0.315461220896762150, -0.315413773579001240, -0.315366325472705430, +-0.315318876577994290, -0.315271426894985940, -0.315223976423799010, -0.315176525164551690, -0.315129073117363550, -0.315081620282352650, -0.315034166659637740, -0.314986712249337000, +-0.314939257051569890, -0.314891801066454650, -0.314844344294109900, -0.314796886734653840, -0.314749428388206020, -0.314701969254884640, -0.314654509334807870, -0.314607048628095300, +-0.314559587134865040, -0.314512124855235890, -0.314464661789325920, -0.314417197937254810, -0.314369733299140640, -0.314322267875102150, -0.314274801665257560, -0.314227334669726410, +-0.314179866888626920, -0.314132398322077790, -0.314084928970197190, -0.314037458833104740, -0.313989987910918590, -0.313942516203757520, -0.313895043711739710, -0.313847570434984680, +-0.313800096373610780, -0.313752621527736200, -0.313705145897480500, -0.313657669482961920, -0.313610192284299150, -0.313562714301610480, -0.313515235535015480, -0.313467755984632390, +-0.313420275650579890, -0.313372794532976280, -0.313325312631941080, -0.313277829947592680, -0.313230346480049600, -0.313182862229430310, -0.313135377195854270, -0.313087891379439760, +-0.313040404780305540, -0.312992917398569880, -0.312945429234352370, -0.312897940287771290, -0.312850450558944890, -0.312802960047992800, -0.312755468755033350, -0.312707976680185180, +-0.312660483823566700, -0.312612990185297370, -0.312565495765495640, -0.312518000564280090, -0.312470504581769170, -0.312423007818082410, -0.312375510273338100, -0.312328011947655030, +-0.312280512841151490, -0.312233012953947120, -0.312185512286160200, -0.312138010837909540, -0.312090508609313370, -0.312043005600491360, -0.311995501811561880, -0.311947997242643600, +-0.311900491893854940, -0.311852985765315450, -0.311805478857143490, -0.311757971169457470, -0.311710462702376900, -0.311662953456020130, -0.311615443430506070, -0.311567932625952890, +-0.311520421042480340, -0.311472908680206720, -0.311425395539250860, -0.311377881619731070, -0.311330366921767020, -0.311282851445477020, -0.311235335190979900, -0.311187818158394030, +-0.311140300347839020, -0.311092781759433280, -0.311045262393295610, -0.310997742249544300, -0.310950221328299080, -0.310902699629678310, -0.310855177153800400, -0.310807653900784910, +-0.310760129870750360, -0.310712605063815430, -0.310665079480098580, -0.310617553119719450, -0.310570025982796430, -0.310522498069448370, -0.310474969379793630, -0.310427439913951890, +-0.310379909672041540, -0.310332378654181400, -0.310284846860489900, -0.310237314291086750, -0.310189780946090290, -0.310142246825619360, -0.310094711929792380, -0.310047176258729070, +-0.309999639812547800, -0.309952102591367070, -0.309904564595306460, -0.309857025824484430, -0.309809486279019830, -0.309761945959031120, -0.309714404864637920, -0.309666862995958750, +-0.309619320353112400, -0.309571776936217350, -0.309524232745393260, -0.309476687780758600, -0.309429142042432210, -0.309381595530532570, -0.309334048245179350, -0.309286500186491010, +-0.309238951354586400, -0.309191401749584040, -0.309143851371603550, -0.309096300220763450, -0.309048748297182150, -0.309001195600979440, -0.308953642132273720, -0.308906087891183900, +-0.308858532877828440, -0.308810977092327080, -0.308763420534798270, -0.308715863205360870, -0.308668305104133460, -0.308620746231235640, -0.308573186586786010, -0.308525626170903400, +-0.308478064983706280, -0.308430503025314440, -0.308382940295846340, -0.308335376795420890, -0.308287812524156550, -0.308240247482173100, -0.308192681669589070, -0.308145115086523310, +-0.308097547733094390, -0.308049979609421990, -0.308002410715624620, -0.307954841051820800, -0.307907270618130340, -0.307859699414671670, -0.307812127441563780, -0.307764554698925110, +-0.307716981186875460, -0.307669406905533400, -0.307621831855017850, -0.307574256035447250, -0.307526679446941450, -0.307479102089618930, -0.307431523963598690, -0.307383945068999190, +-0.307336365405940280, -0.307288784974540430, -0.307241203774918650, -0.307193621807193400, -0.307146039071484520, -0.307098455567910540, -0.307050871296590030, -0.307003286257642730, +-0.306955700451187250, -0.306908113877342510, -0.306860526536227030, -0.306812938427960700, -0.306765349552661990, -0.306717759910449920, -0.306670169501443050, -0.306622578325761120, +-0.306574986383522820, -0.306527393674846990, -0.306479800199852270, -0.306432205958658500, -0.306384610951384200, -0.306337015178148380, -0.306289418639069560, -0.306241821334267640, +-0.306194223263861200, -0.306146624427968750, -0.306099024826710140, -0.306051424460204000, -0.306003823328569290, -0.305956221431924640, -0.305908618770389770, -0.305861015344083440, +-0.305813411153124490, -0.305765806197631660, -0.305718200477724690, -0.305670593993522250, -0.305622986745143320, -0.305575378732706520, -0.305527769956331630, -0.305480160416137400, +-0.305432550112242680, -0.305384939044766210, -0.305337327213827840, -0.305289714619546130, -0.305242101262040100, -0.305194487141428440, -0.305146872257830990, -0.305099256611366330, +-0.305051640202153080, -0.305004023030311210, -0.304956405095959280, -0.304908786399216310, -0.304861166940200930, -0.304813546719033100, -0.304765925735831390, -0.304718303990714870, +-0.304670681483802160, -0.304623058215213180, -0.304575434185066500, -0.304527809393481290, -0.304480183840576120, -0.304432557526470910, -0.304384930451284340, -0.304337302615135420, +-0.304289674018142780, -0.304242044660426430, -0.304194414542104940, -0.304146783663297000, -0.304099152024122580, -0.304051519624700230, -0.304003886465149030, -0.303956252545587780, +-0.303908617866136270, -0.303860982426913230, -0.303813346228037740, -0.303765709269628430, -0.303718071551805300, -0.303670433074687000, -0.303622793838392580, -0.303575153843040790, +-0.303527513088751530, -0.303479871575643490, -0.303432229303835730, -0.303384586273447000, -0.303336942484597250, -0.303289297937405110, -0.303241652631989320, -0.303194006568469840, +-0.303146359746965300, -0.303098712167594870, -0.303051063830477310, -0.303003414735732450, -0.302955764883479030, -0.302908114273836240, -0.302860462906922700, -0.302812810782858490, +-0.302765157901762230, -0.302717504263753050, -0.302669849868949680, -0.302622194717472150, -0.302574538809439080, -0.302526882144969700, -0.302479224724182700, -0.302431566547198050, +-0.302383907614134470, -0.302336247925111160, -0.302288587480246780, -0.302240926279661310, -0.302193264323473600, -0.302145601611802260, -0.302097938144767380, -0.302050273922487620, +-0.302002608945082180, -0.301954943212669800, -0.301907276725370490, -0.301859609483302980, -0.301811941486586470, -0.301764272735339620, -0.301716603229682580, -0.301668932969734020, +-0.301621261955613120, -0.301573590187438620, -0.301525917665330550, -0.301478244389407730, -0.301430570359789320, -0.301382895576594030, -0.301335220039941900, -0.301287543749951760, +-0.301239866706742300, -0.301192188910433640, -0.301144510361144480, -0.301096831058994040, -0.301049151004101120, -0.301001470196585740, -0.300953788636566690, -0.300906106324163150, +-0.300858423259493910, -0.300810739442679050, -0.300763054873837370, -0.300715369553088030, -0.300667683480549840, -0.300619996656342870, -0.300572309080585910, -0.300524620753398140, +-0.300476931674898470, -0.300429241845206860, -0.300381551264442100, -0.300333859932723100, -0.300286167850169870, -0.300238475016901150, -0.300190781433036350, -0.300143087098694080, +-0.300095392013994540, -0.300047696179056580, -0.299999999593999310, -0.299952302258941650, -0.299904604174003660, -0.299856905339304150, -0.299809205754962340, -0.299761505421097140, +-0.299713804337828570, -0.299666102505275530, -0.299618399923557210, -0.299570696592792450, -0.299522992513101380, -0.299475287684602850, -0.299427582107415660, -0.299379875781659980, +-0.299332168707454550, -0.299284460884918720, -0.299236752314171350, -0.299189042995332440, -0.299141332928521020, -0.299093622113856210, -0.299045910551456910, -0.298998198241443300, +-0.298950485183934190, -0.298902771379048800, -0.298855056826906160, -0.298807341527626220, -0.298759625481327950, -0.298711908688130630, -0.298664191148153120, -0.298616472861515550, +-0.298568753828336810, -0.298521034048736140, -0.298473313522832520, -0.298425592250746000, -0.298377870232595490, -0.298330147468499900, -0.298282423958579400, -0.298234699702952800, +-0.298186974701739440, -0.298139248955058220, -0.298091522463029330, -0.298043795225771620, -0.297996067243404440, -0.297948338516046630, -0.297900609043818430, -0.297852878826838700, +-0.297805147865226770, -0.297757416159101560, -0.297709683708583190, -0.297661950513790690, -0.297614216574843220, -0.297566481891859860, -0.297518746464960680, -0.297471010294264650, +-0.297423273379890660, -0.297375535721958910, -0.297327797320588340, -0.297280058175898250, -0.297232318288007610, -0.297184577657036600, -0.297136836283104110, -0.297089094166329560, +-0.297041351306831850, -0.296993607704731210, -0.296945863360146500, -0.296898118273197180, -0.296850372444002090, -0.296802625872681520, -0.296754878559354400, -0.296707130504140050, +-0.296659381707157500, -0.296611632168526870, -0.296563881888367190, -0.296516130866797340, -0.296468379103937640, -0.296420626599906980, -0.296372873354824710, -0.296325119368809900, +-0.296277364641982680, -0.296229609174462060, -0.296181852966367400, -0.296134096017817650, -0.296086338328933160, -0.296038579899832790, -0.295990820730635980, -0.295943060821461660, +-0.295895300172430150, -0.295847538783660380, -0.295799776655271740, -0.295752013787383250, -0.295704250180115150, -0.295656485833586450, -0.295608720747916500, -0.295560954923224370, +-0.295513188359630200, -0.295465421057253150, -0.295417653016212030, -0.295369884236627240, -0.295322114718617800, -0.295274344462303000, -0.295226573467801960, -0.295178801735234860, +-0.295131029264720790, -0.295083256056379140, -0.295035482110328930, -0.294987707426690450, -0.294939932005582660, -0.294892155847125080, -0.294844378951436670, -0.294796601318637720, +-0.294748822948847300, -0.294701043842184820, -0.294653263998769290, -0.294605483418721060, -0.294557702102159090, -0.294509920049202400, -0.294462137259971390, -0.294414353734585020, +-0.294366569473162810, -0.294318784475823710, -0.294270998742688080, -0.294223212273874930, -0.294175425069503780, -0.294127637129693640, -0.294079848454564810, -0.294032059044236350, +-0.293984268898827780, -0.293936478018458070, -0.293888686403247670, -0.293840894053315480, -0.293793100968781080, -0.293745307149763490, -0.293697512596383050, -0.293649717308758880, +-0.293601921287009960, -0.293554124531256620, -0.293506327041618050, -0.293458528818213600, -0.293410729861162460, -0.293362930170584850, -0.293315129746599960, -0.293267328589327250, +-0.293219526698885740, -0.293171724075395880, -0.293123920718976750, -0.293076116629747750, -0.293028311807828070, -0.292980506253337990, -0.292932699966396700, -0.292884892947123670, +-0.292837085195637950, -0.292789276712059900, -0.292741467496508700, -0.292693657549103430, -0.292645846869964420, -0.292598035459210810, -0.292550223316962070, -0.292502410443337360, +-0.292454596838457090, -0.292406782502440290, -0.292358967435406570, -0.292311151637474950, -0.292263335108765900, -0.292215517849398530, -0.292167699859492370, -0.292119881139166480, +-0.292072061688541380, -0.292024241507736090, -0.291976420596870180, -0.291928598956062820, -0.291880776585434430, -0.291832953485104020, -0.291785129655191270, -0.291737305095815250, +-0.291689479807096420, -0.291641653789153850, -0.291593827042106790, -0.291545999566075520, -0.291498171361179280, -0.291450342427537590, -0.291402512765269630, -0.291354682374495800, +-0.291306851255335290, -0.291259019407907660, -0.291211186832332050, -0.291163353528728910, -0.291115519497217310, -0.291067684737917000, -0.291019849250947040, -0.290972013036427830, +-0.290924176094478630, -0.290876338425218980, -0.290828500028768030, -0.290780660905246290, -0.290732821054772880, -0.290684980477467050, -0.290637139173449130, -0.290589297142838380, +-0.290541454385754410, -0.290493610902316350, -0.290445766692644660, -0.290397921756858580, -0.290350076095077740, -0.290302229707421260, -0.290254382594009600, -0.290206534754962000, +-0.290158686190398090, -0.290110836900436990, -0.290062986885199270, -0.290015136144804060, -0.289967284679371000, -0.289919432489019300, -0.289871579573869440, -0.289823725934040650, +-0.289775871569652120, -0.289728016480824360, -0.289680160667676550, -0.289632304130328310, -0.289584446868898890, -0.289536588883508810, -0.289488730174277230, -0.289440870741323850, +-0.289393010584767800, -0.289345149704729740, -0.289297288101328760, -0.289249425774684540, -0.289201562724916370, -0.289153698952144710, -0.289105834456488800, -0.289057969238068260, +-0.289010103297002440, -0.288962236633411750, -0.288914369247415480, -0.288866501139133260, -0.288818632308684380, -0.288770762756189350, -0.288722892481767410, -0.288675021485537810, +-0.288627149767621110, -0.288579277328136540, -0.288531404167203740, -0.288483530284942000, -0.288435655681471890, -0.288387780356912590, -0.288339904311383900, -0.288292027545004990, +-0.288244150057896440, -0.288196271850177540, -0.288148392921967920, -0.288100513273386930, -0.288052632904555070, -0.288004751815591600, -0.287956870006616290, -0.287908987477748350, +-0.287861104229108380, -0.287813220260815680, -0.287765335572989440, -0.287717450165750340, -0.287669564039217620, -0.287621677193510950, -0.287573789628749690, -0.287525901345054350, +-0.287478012342544280, -0.287430122621339160, -0.287382232181558340, -0.287334341023322340, -0.287286449146750500, -0.287238556551962560, -0.287190663239077770, -0.287142769208216740, +-0.287094874459498830, -0.287046978993043660, -0.286999082808970680, -0.286951185907400430, -0.286903288288452190, -0.286855389952245300, -0.286807490898900340, -0.286759591128536660, +-0.286711690641274000, -0.286663789437231750, -0.286615887516530390, -0.286567984879289310, -0.286520081525628300, -0.286472177455666670, -0.286424272669524970, -0.286376367167322620, +-0.286328460949179350, -0.286280554015214520, -0.286232646365548680, -0.286184738000301250, -0.286136828919592020, -0.286088919123540230, -0.286041008612266610, -0.285993097385890460, +-0.285945185444531120, -0.285897272788309230, -0.285849359417344180, -0.285801445331755780, -0.285753530531663300, -0.285705615017187390, -0.285657698788447490, -0.285609781845563290, +-0.285561864188654260, -0.285513945817840950, -0.285466026733242840, -0.285418106934979600, -0.285370186423170690, -0.285322265197936740, -0.285274343259397160, -0.285226420607671670, +-0.285178497242879690, -0.285130573165141950, -0.285082648374577750, -0.285034722871306930, -0.284986796655448900, -0.284938869727124290, -0.284890942086452490, -0.284843013733552920, +-0.284795084668546250, -0.284747154891551830, -0.284699224402689580, -0.284651293202078830, -0.284603361289840210, -0.284555428666093240, -0.284507495330957700, -0.284459561284553020, +-0.284411626526999810, -0.284363691058417580, -0.284315754878926070, -0.284267817988644760, -0.284219880387694360, -0.284171942076194230, -0.284124003054264270, -0.284076063322023900, +-0.284028122879593730, -0.283980181727093330, -0.283932239864642000, -0.283884297292360480, -0.283836354010368270, -0.283788410018785130, -0.283740465317730560, -0.283692519907325250, +-0.283644573787688650, -0.283596626958940610, -0.283548679421200540, -0.283500731174589240, -0.283452782219226100, -0.283404832555231020, -0.283356882182723420, -0.283308931101824040, +-0.283260979312652320, -0.283213026815328170, -0.283165073609971010, -0.283117119696701610, -0.283069165075639400, -0.283021209746903870, -0.282973253710615710, -0.282925296966894450, +-0.282877339515859920, -0.282829381357631640, -0.282781422492330290, -0.282733462920075450, -0.282685502640986910, -0.282637541655184180, -0.282589579962788050, -0.282541617563917940, +-0.282493654458693790, -0.282445690647235070, -0.282397726129662570, -0.282349760906095760, -0.282301794976654590, -0.282253828341458400, -0.282205861000628170, -0.282157892954283230, +-0.282109924202543550, -0.282061954745528640, -0.282013984583359300, -0.281966013716154980, -0.281918042144035210, -0.281870069867120760, -0.281822096885531110, -0.281774123199386270, +-0.281726148808805640, -0.281678173713910070, -0.281630197914819080, -0.281582221411652620, -0.281534244204530160, -0.281486266293572480, -0.281438287678899170, -0.281390308360630170, +-0.281342328338884950, -0.281294347613784300, -0.281246366185447790, -0.281198384053995390, -0.281150401219546600, -0.281102417682222220, -0.281054433442141820, -0.281006448499424910, +-0.280958462854192290, -0.280910476506563530, -0.280862489456658540, -0.280814501704596930, -0.280766513250499450, -0.280718524094485720, -0.280670534236675710, -0.280622543677188920, +-0.280574552416146210, -0.280526560453667080, -0.280478567789871570, -0.280430574424879180, -0.280382580358810810, -0.280334585591785980, -0.280286590123924710, -0.280238593955346560, +-0.280190597086172280, -0.280142599516521540, -0.280094601246513920, -0.280046602276270150, -0.279998602605909920, -0.279950602235553180, -0.279902601165319450, -0.279854599395329700, +-0.279806596925703480, -0.279758593756560700, -0.279710589888021060, -0.279662585320205330, -0.279614580053233200, -0.279566574087224570, -0.279518567422299080, -0.279470560058577620, +-0.279422551996179710, -0.279374543235225480, -0.279326533775834440, -0.279278523618127490, -0.279230512762224210, -0.279182501208244280, -0.279134488956308490, -0.279086476006536470, +-0.279038462359048280, -0.278990448013963500, -0.278942432971403030, -0.278894417231486450, -0.278846400794333870, -0.278798383660064820, -0.278750365828800250, -0.278702347300659790, +-0.278654328075763400, -0.278606308154230820, -0.278558287536182890, -0.278510266221739240, -0.278462244211019890, -0.278414221504144580, -0.278366198101234090, -0.278318174002408100, +-0.278270149207786700, -0.278222123717489440, -0.278174097531637350, -0.278126070650350050, -0.278078043073747120, -0.278030014801949440, -0.277981985835076830, -0.277933956173249170, +-0.277885925816586220, -0.277837894765208930, -0.277789863019236860, -0.277741830578790090, -0.277693797443988370, -0.277645763614952580, -0.277597729091802410, -0.277549693874657890, +-0.277501657963638680, -0.277453621358865750, -0.277405584060458840, -0.277357546068537910, -0.277309507383222690, -0.277261468004634140, -0.277213427932891940, -0.277165387168115670, +-0.277117345710426450, -0.277069303559943800, -0.277021260716787950, -0.276973217181078480, -0.276925172952936390, -0.276877128032481380, -0.276829082419833560, -0.276781036115112620, +-0.276732989118439470, -0.276684941429933880, -0.276636893049715950, -0.276588843977905340, -0.276540794214623020, -0.276492743759988780, -0.276444692614122630, -0.276396640777144320, +-0.276348588249174850, -0.276300535030333920, -0.276252481120741190, -0.276204426520517740, -0.276156371229783150, -0.276108315248657700, -0.276060258577261020, -0.276012201215714130, +-0.275964143164136700, -0.275916084422648920, -0.275868024991370530, -0.275819964870422480, -0.275771904059924520, -0.275723842559996820, -0.275675780370759070, -0.275627717492332280, +-0.275579653924836190, -0.275531589668391030, -0.275483524723116380, -0.275435459089133420, -0.275387392766561770, -0.275339325755521670, -0.275291258056132800, -0.275243189668516240, +-0.275195120592791660, -0.275147050829078920, -0.275098980377498910, -0.275050909238171490, -0.275002837411216780, -0.274954764896754580, -0.274906691694905890, -0.274858617805790460, +-0.274810543229528470, -0.274762467966239710, -0.274714392016045190, -0.274666315379064720, -0.274618238055418410, -0.274570160045226110, -0.274522081348608840, -0.274474001965686390, +-0.274425921896578880, -0.274377841141406180, -0.274329759700289330, -0.274281677573348040, -0.274233594760702140, -0.274185511262472650, -0.274137427078779420, -0.274089342209742630, +-0.274041256655482010, -0.273993170416118700, -0.273945083491772490, -0.273896995882563500, -0.273848907588611690, -0.273800818610037970, -0.273752728946962230, -0.273704638599504670, +-0.273656547567785070, -0.273608455851924500, -0.273560363452042820, -0.273512270368260260, -0.273464176600696550, -0.273416082149472880, -0.273367987014708990, -0.273319891196524670, +-0.273271794695041090, -0.273223697510378010, -0.273175599642655640, -0.273127501091993910, -0.273079401858513810, -0.273031301942335210, -0.272983201343578400, -0.272935100062363100, +-0.272886998098810510, -0.272838895453040410, -0.272790792125173100, -0.272742688115328370, -0.272694583423627350, -0.272646478050189880, -0.272598371995136150, -0.272550265258586110, +-0.272502157840660840, -0.272454049741480190, -0.272405940961163940, -0.272357831499833340, -0.272309721357608110, -0.272261610534608570, -0.272213499030954600, -0.272165386846767280, +-0.272117273982166510, -0.272069160437272580, -0.272021046212205300, -0.271972931307085830, -0.271924815722034030, -0.271876699457170190, -0.271828582512614160, -0.271780464888487120, +-0.271732346584908910, -0.271684227601999840, -0.271636107939879800, -0.271587987598669870, -0.271539866578490000, -0.271491744879460480, -0.271443622501701120, -0.271395499445333140, +-0.271347375710476460, -0.271299251297250850, -0.271251126205777630, -0.271203000436176510, -0.271154873988567910, -0.271106746863071730, -0.271058619059809050, -0.271010490578899870, +-0.270962361420464480, -0.270914231584622690, -0.270866101071495780, -0.270817969881203660, -0.270769838013866560, -0.270721705469604450, -0.270673572248538550, -0.270625438350788670, +-0.270577303776475210, -0.270529168525718070, -0.270481032598638430, -0.270432895995356190, -0.270384758715991270, -0.270336620760664950, -0.270288482129497020, -0.270240342822607890, +-0.270192202840117470, -0.270144062182147040, -0.270095920848816400, -0.270047778840245940, -0.269999636156555640, -0.269951492797866620, -0.269903348764298940, -0.269855204055972850, +-0.269807058673008360, -0.269758912615526590, -0.269710765883647560, -0.269662618477491680, -0.269614470397178730, -0.269566321642830060, -0.269518172214565640, -0.269470022112505310, +-0.269421871336770370, -0.269373719887480770, -0.269325567764756800, -0.269277414968718540, -0.269229261499487170, -0.269181107357182650, -0.269132952541925370, -0.269084797053835260, +-0.269036640893033590, -0.268988484059640260, -0.268940326553775810, -0.268892168375560070, -0.268844009525114340, -0.268795850002558620, -0.268747689808013220, -0.268699528941598210, +-0.268651367403434760, -0.268603205193642950, -0.268555042312343120, -0.268506878759655230, -0.268458714535700580, -0.268410549640599130, -0.268362384074470880, -0.268314217837437140, +-0.268266050929617810, -0.268217883351133330, -0.268169715102103800, -0.268121546182650330, -0.268073376592893040, -0.268025206332952290, -0.267977035402948090, -0.267928863803001740, +-0.267880691533233240, -0.267832518593763000, -0.267784344984711040, -0.267736170706198650, -0.267687995758345790, -0.267639820141273020, -0.267591643855100200, -0.267543466899948730, +-0.267495289275938570, -0.267447110983189800, -0.267398932021823690, -0.267350752391960210, -0.267302572093719830, -0.267254391127222660, -0.267206209492589890, -0.267158027189941580, +-0.267109844219398260, -0.267061660581079830, -0.267013476275107740, -0.266965291301601960, -0.266917105660682890, -0.266868919352470700, -0.266820732377086590, -0.266772544734650670, +-0.266724356425283360, -0.266676167449104770, -0.266627977806236200, -0.266579787496797670, -0.266531596520909190, -0.266483404878692210, -0.266435212570266700, -0.266387019595753170, +-0.266338825955271640, -0.266290631648943510, -0.266242436676888740, -0.266194241039227950, -0.266146044736081060, -0.266097847767569510, -0.266049650133813380, -0.266001451834933070, +-0.265953252871048760, -0.265905053242281700, -0.265856852948752000, -0.265808651990580180, -0.265760450367886310, -0.265712248080791750, -0.265664045129416600, -0.265615841513880850, +-0.265567637234305930, -0.265519432290811930, -0.265471226683519360, -0.265423020412548280, -0.265374813478020110, -0.265326605880054860, -0.265278397618773140, -0.265230188694294990, +-0.265181979106741740, -0.265133768856233630, -0.265085557942891010, -0.265037346366834130, -0.264989134128184310, -0.264940921227061640, -0.264892707663586640, -0.264844493437879470, +-0.264796278550061490, -0.264748063000252830, -0.264699846788574000, -0.264651629915145130, -0.264603412380087550, -0.264555194183521520, -0.264506975325567050, -0.264458755806345590, +-0.264410535625977220, -0.264362314784582500, -0.264314093282281560, -0.264265871119195860, -0.264217648295445470, -0.264169424811150910, -0.264121200666432410, -0.264072975861411320, +-0.264024750396207820, -0.263976524270942370, -0.263928297485735260, -0.263880070040707790, -0.263831841935980140, -0.263783613171672930, -0.263735383747906230, -0.263687153664801500, +-0.263638922922478870, -0.263590691521058520, -0.263542459460661900, -0.263494226741409100, -0.263445993363420730, -0.263397759326816970, -0.263349524631719180, -0.263301289278247640, +-0.263253053266522870, -0.263204816596665000, -0.263156579268795540, -0.263108341283034670, -0.263060102639502910, -0.263011863338320440, -0.262963623379608770, -0.262915382763488080, +-0.262867141490078890, -0.262818899559501440, -0.262770656971877130, -0.262722413727326190, -0.262674169825968810, -0.262625925267926390, -0.262577680053319220, -0.262529434182267820, +-0.262481187654892370, -0.262432940471314440, -0.262384692631654150, -0.262336444136032080, -0.262288194984568510, -0.262239945177384860, -0.262191694714601350, -0.262143443596338620, +-0.262095191822716840, -0.262046939393857540, -0.261998686309880880, -0.261950432570907500, -0.261902178177057580, -0.261853923128452680, -0.261805667425212940, -0.261757411067459090, +-0.261709154055311200, -0.261660896388890900, -0.261612638068318360, -0.261564379093713770, -0.261516119465198700, -0.261467859182893340, -0.261419598246918290, -0.261371336657393820, +-0.261323074414441470, -0.261274811518181440, -0.261226547968734350, -0.261178283766220430, -0.261130018910761260, -0.261081753402477080, -0.261033487241488500, -0.260985220427915720, +-0.260936952961880350, -0.260888684843502640, -0.260840416072903150, -0.260792146650202230, -0.260743876575521390, -0.260695605848980830, -0.260647334470700820, -0.260599062440802940, +-0.260550789759407380, -0.260502516426634800, -0.260454242442605570, -0.260405967807441130, -0.260357692521261790, -0.260309416584188210, -0.260261139996340650, -0.260212862757840670, +-0.260164584868808560, -0.260116306329364940, -0.260068027139630180, -0.260019747299725710, -0.259971466809771960, -0.259923185669889480, -0.259874903880198630, -0.259826621440820920, +-0.259778338351876690, -0.259730054613486190, -0.259681770225770990, -0.259633485188851320, -0.259585199502847970, -0.259536913167881190, -0.259488626184072530, -0.259440338551542300, +-0.259392050270411290, -0.259343761340799670, -0.259295471762829080, -0.259247181536619850, -0.259198890662292620, -0.259150599139967740, -0.259102306969766830, -0.259054014151810120, +-0.259005720686218350, -0.258957426573111880, -0.258909131812612270, -0.258860836404839870, -0.258812540349914910, -0.258764243647959020, -0.258715946299092500, -0.258667648303436190, +-0.258619349661110280, -0.258571050372236430, -0.258522750436934960, -0.258474449855326580, -0.258426148627531660, -0.258377846753671810, -0.258329544233867390, -0.258281241068239080, +-0.258232937256907210, -0.258184632799993430, -0.258136327697618070, -0.258088021949901940, -0.258039715556965250, -0.257991408518929770, -0.257943100835915710, -0.257894792508043920, +-0.257846483535434710, -0.257798173918209750, -0.257749863656489330, -0.257701552750393860, -0.257653241200044900, -0.257604929005562810, -0.257556616167068430, -0.257508302684682110, +-0.257459988558525420, -0.257411673788718760, -0.257363358375382930, -0.257315042318638280, -0.257266725618606470, -0.257218408275407820, -0.257170090289163160, -0.257121771659992840, +-0.257073452388018540, -0.257025132473360560, -0.256976811916139800, -0.256928490716476550, -0.256880168874492500, -0.256831846390308040, -0.256783523264043520, -0.256735199495820690, +-0.256686875085759770, -0.256638550033981730, -0.256590224340606850, -0.256541898005756830, -0.256493571029552060, -0.256445243412113390, -0.256396915153561170, -0.256348586254017130, +-0.256300256713601570, -0.256251926532435390, -0.256203595710638940, -0.256155264248333960, -0.256106932145640840, -0.256058599402680330, -0.256010266019572940, -0.255961931996440300, +-0.255913597333402850, -0.255865262030580910, -0.255816926088096310, -0.255768589506069400, -0.255720252284620970, -0.255671914423871490, -0.255623575923942690, -0.255575236784954920, +-0.255526897007029070, -0.255478556590285510, -0.255430215534846070, -0.255381873840831000, -0.255333531508361300, -0.255285188537557330, -0.255236844928540820, -0.255188500681432170, +-0.255140155796352300, -0.255091810273421650, -0.255043464112761850, -0.254995117314493370, -0.254946769878737160, -0.254898421805613560, -0.254850073095244320, -0.254801723747749900, +-0.254753373763250750, -0.254705023141868600, -0.254656671883723930, -0.254608319988937510, -0.254559967457629930, -0.254511614289922810, -0.254463260485936650, -0.254414906045792370, +-0.254366550969610360, -0.254318195257512420, -0.254269838909619020, -0.254221481926050990, -0.254173124306928840, -0.254124766052374330, -0.254076407162507840, -0.254028047637450400, +-0.253979687477322410, -0.253931326682245610, -0.253882965252340440, -0.253834603187727490, -0.253786240488528440, -0.253737877154863790, -0.253689513186854450, -0.253641148584620950, +-0.253592783348284940, -0.253544417477966970, -0.253496050973788020, -0.253447683835868460, -0.253399316064330140, -0.253350947659293500, -0.253302578620879510, -0.253254208949208640, +-0.253205838644402710, -0.253157467706582150, -0.253109096135867910, -0.253060723932380550, -0.253012351096241760, -0.252963977627572110, -0.252915603526492060, -0.252867228793123460, +-0.252818853427586810, -0.252770477430002970, -0.252722100800492570, -0.252673723539177330, -0.252625345646177780, -0.252576967121614810, -0.252528587965609060, -0.252480208178282260, +-0.252431827759754920, -0.252383446710148010, -0.252335065029582030, -0.252286682718178890, -0.252238299776058990, -0.252189916203343360, -0.252141532000152490, -0.252093147166608240, +-0.252044761702831130, -0.251996375608941670, -0.251947988885061700, -0.251899601531311750, -0.251851213547812810, -0.251802824934685370, -0.251754435692051360, -0.251706045820031200, +-0.251657655318745950, -0.251609264188316140, -0.251560872428863600, -0.251512480040508910, -0.251464087023372970, -0.251415693377576410, -0.251367299103241020, -0.251318904200487410, +-0.251270508669436510, -0.251222112510208930, -0.251173715722926520, -0.251125318307709790, -0.251076920264679760, -0.251028521593957000, -0.250980122295663410, -0.250931722369919450, +-0.250883321816845810, -0.250834920636564260, -0.250786518829195390, -0.250738116394860270, -0.250689713333679400, -0.250641309645774690, -0.250592905331266710, -0.250544500390276480, +-0.250496094822924560, -0.250447688629332810, -0.250399281809621840, -0.250350874363912680, -0.250302466292325890, -0.250254057594983370, -0.250205648272005750, -0.250157238323513940, +-0.250108827749628670, -0.250060416550471680, -0.250012004726163690, -0.249963592276825300, -0.249915179202578300, -0.249866765503543390, -0.249818351179841550, -0.249769936231593410, +-0.249721520658920840, -0.249673104461944490, -0.249624687640785350, -0.249576270195564110, -0.249527852126402580, -0.249479433433421440, -0.249431014116741710, -0.249382594176484010, +-0.249334173612770270, -0.249285752425721100, -0.249237330615457530, -0.249188908182100210, -0.249140485125771060, -0.249092061446590680, -0.249043637144679720, -0.248995212220160110, +-0.248946786673152450, -0.248898360503777840, -0.248849933712156880, -0.248801506298411550, -0.248753078262662440, -0.248704649605030610, -0.248656220325636750, -0.248607790424602760, +-0.248559359902049300, -0.248510928758097440, -0.248462496992867820, -0.248414064606482410, -0.248365631599061800, -0.248317197970727150, -0.248268763721599060, -0.248220328851799480, +-0.248171893361449100, -0.248123457250668980, -0.248075020519579780, -0.248026583168303450, -0.247978145196960680, -0.247929706605672100, -0.247881267394559710, -0.247832827563744110, +-0.247784387113346470, -0.247735946043487420, -0.247687504354288960, -0.247639062045871720, -0.247590619118356840, -0.247542175571864950, -0.247493731406518090, -0.247445286622436870, +-0.247396841219742450, -0.247348395198555500, -0.247299948558997980, -0.247251501301190580, -0.247203053425254450, -0.247154604931310250, -0.247106155819479980, -0.247057706089884280, +-0.247009255742643930, -0.246960804777880850, -0.246912353195715750, -0.246863900996269790, -0.246815448179663640, -0.246766994746019290, -0.246718540695457460, -0.246670086028099260, +-0.246621630744065430, -0.246573174843477960, -0.246524718326457560, -0.246476261193125350, -0.246427803443602040, -0.246379345078009680, -0.246330886096468940, -0.246282426499101010, +-0.246233966286026560, -0.246185505457367640, -0.246137044013244930, -0.246088581953779200, -0.246040119279092450, -0.245991655989305390, -0.245943192084539190, -0.245894727564914590, +-0.245846262430553600, -0.245797796681576950, -0.245749330318105810, -0.245700863340260920, -0.245652395748164280, -0.245603927541936660, -0.245555458721699230, -0.245506989287572720, +-0.245458519239679180, -0.245410048578139330, -0.245361577303074340, -0.245313105414605020, -0.245264632912853330, -0.245216159797940060, -0.245167686069986400, -0.245119211729113110, +-0.245070736775442190, -0.245022261209094460, -0.244973785030190630, -0.244925308238852750, -0.244876830835201620, -0.244828352819358410, -0.244779874191443900, -0.244731394951580110, +-0.244682915099887850, -0.244634434636488320, -0.244585953561502230, -0.244537471875051700, -0.244488989577257510, -0.244440506668240850, -0.244392023148122470, -0.244343539017024460, +-0.244295054275067620, -0.244246568922373150, -0.244198082959061810, -0.244149596385255680, -0.244101109201075580, -0.244052621406642300, -0.244004133002077850, -0.243955643987503110, +-0.243907154363039220, -0.243858664128807050, -0.243810173284928630, -0.243761681831524770, -0.243713189768716730, -0.243664697096625250, -0.243616203815372500, -0.243567709925079200, +-0.243519215425866660, -0.243470720317855630, -0.243422224601168250, -0.243373728275925270, -0.243325231342248010, -0.243276733800257220, -0.243228235650075040, -0.243179736891822260, +-0.243131237525619710, -0.243082737551589490, -0.243034236969852440, -0.242985735780529790, -0.242937233983742370, -0.242888731579612300, -0.242840228568260370, -0.242791724949807910, +-0.242743220724375680, -0.242694715892085850, -0.242646210453059230, -0.242597704407417070, -0.242549197755280220, -0.242500690496770810, -0.242452182632009680, -0.242403674161118100, +-0.242355165084216890, -0.242306655401428210, -0.242258145112872860, -0.242209634218671750, -0.242161122718946960, -0.242112610613819390, -0.242064097903410270, -0.242015584587840500, +-0.241967070667232190, -0.241918556141706180, -0.241870041011383820, -0.241821525276385900, -0.241773008936834590, -0.241724491992850790, -0.241675974444555740, -0.241627456292070300, +-0.241578937535516680, -0.241530418175015720, -0.241481898210688720, -0.241433377642656520, -0.241384856471041300, -0.241336334695963970, -0.241287812317545790, -0.241239289335907630, +-0.241190765751171710, -0.241142241563458870, -0.241093716772889960, -0.241045191379587210, -0.240996665383671510, -0.240948138785264110, -0.240899611584485950, -0.240851083781459200, +-0.240802555376304710, -0.240754026369143860, -0.240705496760097500, -0.240656966549287840, -0.240608435736835740, -0.240559904322862560, -0.240511372307489200, -0.240462839690837840, +-0.240414306473029390, -0.240365772654185160, -0.240317238234426050, -0.240268703213874310, -0.240220167592650800, -0.240171631370876440, -0.240123094548673420, -0.240074557126162660, +-0.240026019103465520, -0.239977480480702910, -0.239928941257997020, -0.239880401435468770, -0.239831861013239530, -0.239783319991430180, -0.239734778370162990, -0.239686236149558860, +-0.239637693329739110, -0.239589149910824720, -0.239540605892937880, -0.239492061276199510, -0.239443516060731030, -0.239394970246653290, -0.239346423834088550, -0.239297876823157780, +-0.239249329213981870, -0.239200781006683070, -0.239152232201382320, -0.239103682798200990, -0.239055132797260010, -0.239006582198681650, -0.238958031002586810, -0.238909479209096910, +-0.238860926818332870, -0.238812373830416950, -0.238763820245470100, -0.238715266063613710, -0.238666711284968690, -0.238618155909657350, -0.238569599937800610, -0.238521043369519880, +-0.238472486204936110, -0.238423928444171540, -0.238375370087347160, -0.238326811134584370, -0.238278251586004100, -0.238229691441728620, -0.238181130701878930, -0.238132569366575980, +-0.238084007435942050, -0.238035444910098090, -0.237986881789165520, -0.237938318073265320, -0.237889753762519750, -0.237841188857049800, -0.237792623356976870, -0.237744057262421950, +-0.237695490573507310, -0.237646923290353970, -0.237598355413083300, -0.237549786941816300, -0.237501217876675300, -0.237452648217781230, -0.237404077965255560, -0.237355507119219240, +-0.237306935679794610, -0.237258363647102620, -0.237209791021264300, -0.237161217802401900, -0.237112643990636500, -0.237064069586089470, -0.237015494588881850, -0.236966918999135910, +-0.236918342816972660, -0.236869766042513590, -0.236821188675879650, -0.236772610717193160, -0.236724032166575170, -0.236675453024147080, -0.236626873290029930, -0.236578292964346040, +-0.236529712047216400, -0.236481130538762490, -0.236432548439105330, -0.236383965748367230, -0.236335382466669190, -0.236286798594132290, -0.236238214130878810, -0.236189629077029810, +-0.236141043432706730, -0.236092457198030600, -0.236043870373123770, -0.235995282958107260, -0.235946694953102530, -0.235898106358230640, -0.235849517173613910, -0.235800927399373420, +-0.235752337035630590, -0.235703746082506470, -0.235655154540123420, -0.235606562408602500, -0.235557969688065170, -0.235509376378632480, -0.235460782480426790, -0.235412187993569140, +-0.235363592918180600, -0.235314997254383480, -0.235266401002298900, -0.235217804162048290, -0.235169206733752740, -0.235120608717534620, -0.235072010113514970, -0.235023410921815310, +-0.234974811142556670, -0.234926210775861430, -0.234877609821850690, -0.234829008280645900, -0.234780406152368170, -0.234731803437139840, -0.234683200135082040, -0.234634596246316220, +-0.234585991770963450, -0.234537386709146170, -0.234488781060985390, -0.234440174826602680, -0.234391568006119100, -0.234342960599657040, -0.234294352607337550, -0.234245744029281780, +-0.234197134865612060, -0.234148525116449510, -0.234099914781915660, -0.234051303862131580, -0.234002692357219650, -0.233954080267301020, -0.233905467592497200, -0.233856854332929240, +-0.233808240488719590, -0.233759626059989340, -0.233711011046860040, -0.233662395449452780, -0.233613779267889950, -0.233565162502292670, -0.233516545152782500, -0.233467927219480510, +-0.233419308702509150, -0.233370689601989530, -0.233322069918042750, -0.233273449650791190, -0.233224828800356050, -0.233176207366858820, -0.233127585350420640, -0.233078962751163940, +-0.233030339569209820, -0.232981715804679860, -0.232933091457695170, -0.232884466528378190, -0.232835841016850040, -0.232787214923232290, -0.232738588247646070, -0.232689960990213800, +-0.232641333151056650, -0.232592704730296140, -0.232544075728053470, -0.232495446144451000, -0.232446815979609950, -0.232398185233651410, -0.232349553906697870, -0.232300921998870400, +-0.232252289510290640, -0.232203656441079740, -0.232155022791360130, -0.232106388561252960, -0.232057753750879810, -0.232009118360361840, -0.231960482389821530, -0.231911845839379990, +-0.231863208709158860, -0.231814570999279240, -0.231765932709863650, -0.231717293841033230, -0.231668654392909570, -0.231620014365613830, -0.231571373759268510, -0.231522732573994750, +-0.231474090809914130, -0.231425448467147880, -0.231376805545818440, -0.231328162046046980, -0.231279517967954680, -0.231230873311664030, -0.231182228077296190, -0.231133582264972770, +-0.231084935874814960, -0.231036288906945250, -0.230987641361484840, -0.230938993238555300, -0.230890344538277840, -0.230841695260774970, -0.230793045406167850, -0.230744394974578130, +-0.230695743966126960, -0.230647092380936890, -0.230598440219129090, -0.230549787480825190, -0.230501134166146370, -0.230452480275215170, -0.230403825808152750, -0.230355170765080330, +-0.230306515146120440, -0.230257858951394250, -0.230209202181023420, -0.230160544835129130, -0.230111886913833940, -0.230063228417259010, -0.230014569345526030, -0.229965909698756160, +-0.229917249477071980, -0.229868588680594650, -0.229819927309445870, -0.229771265363746840, -0.229722602843620060, -0.229673939749186790, -0.229625276080568680, -0.229576611837886910, +-0.229527947021264080, -0.229479281630821370, -0.229430615666680020, -0.229381949128962560, -0.229333282017790240, -0.229284614333284700, -0.229235946075567220, -0.229187277244760290, +-0.229138607840985160, -0.229089937864363520, -0.229041267315016590, -0.228992596193066940, -0.228943924498635790, -0.228895252231844840, -0.228846579392815300, -0.228797905981669770, +-0.228749231998529480, -0.228700557443516080, -0.228651882316750880, -0.228603206618356400, -0.228554530348453910, -0.228505853507164650, -0.228457176094611190, -0.228408498110914790, +-0.228359819556197140, -0.228311140430579510, -0.228262460734184490, -0.228213780467133280, -0.228165099629547650, -0.228116418221548820, -0.228067736243259380, -0.228019053694800610, +-0.227970370576294180, -0.227921686887861410, -0.227873002629624840, -0.227824317801705780, -0.227775632404225940, -0.227726946437306570, -0.227678259901070240, -0.227629572795638310, +-0.227580885121132420, -0.227532196877673870, -0.227483508065385280, -0.227434818684387920, -0.227386128734803100, -0.227337438216753370, -0.227288747130360040, -0.227240055475744830, +-0.227191363253029080, -0.227142670462335330, -0.227093977103784930, -0.227045283177499560, -0.226996588683600560, -0.226947893622210520, -0.226899197993450760, -0.226850501797442980, +-0.226801805034308520, -0.226753107704170010, -0.226704409807148700, -0.226655711343366370, -0.226607012312944330, -0.226558312716005210, -0.226509612552670270, -0.226460911823060910, +-0.226412210527299680, -0.226363508665507920, -0.226314806237807390, -0.226266103244319420, -0.226217399685166630, -0.226168695560470310, -0.226119990870352280, -0.226071285614933840, +-0.226022579794337620, -0.225973873408684940, -0.225925166458097570, -0.225876458942696870, -0.225827750862605450, -0.225779042217944650, -0.225730333008836240, -0.225681623235401560, +-0.225632912897763270, -0.225584201996042680, -0.225535490530361180, -0.225486778500841370, -0.225438065907604600, -0.225389352750772680, -0.225340639030466940, -0.225291924746810030, +-0.225243209899923330, -0.225194494489928590, -0.225145778516947200, -0.225097061981101770, -0.225048344882513710, -0.224999627221304760, -0.224950908997596320, -0.224902190211511060, +-0.224853470863170310, -0.224804750952695860, -0.224756030480209150, -0.224707309445832750, -0.224658587849688090, -0.224609865691896980, -0.224561142972580760, -0.224512419691862110, +-0.224463695849862420, -0.224414971446703050, -0.224366246482506660, -0.224317520957394710, -0.224268794871488930, -0.224220068224910720, -0.224171341017782770, -0.224122613250226480, +-0.224073884922363660, -0.224025156034315690, -0.223976426586205260, -0.223927696578153780, -0.223878966010283040, -0.223830234882714450, -0.223781503195570720, -0.223732770948973230, +-0.223684038143043800, -0.223635304777903860, -0.223586570853676090, -0.223537836370481860, -0.223489101328442630, -0.223440365727681080, -0.223391629568318620, -0.223342892850477090, +-0.223294155574277900, -0.223245417739843720, -0.223196679347296030, -0.223147940396756620, -0.223099200888346950, -0.223050460822189680, -0.223001720198406280, -0.222952979017118580, +-0.222904237278447990, -0.222855494982517250, -0.222806752129447750, -0.222758008719361380, -0.222709264752379570, -0.222660520228625040, -0.222611775148219170, -0.222563029511283460, +-0.222514283317940600, -0.222465536568312030, -0.222416789262519620, -0.222368041400684810, -0.222319292982930320, -0.222270544009377600, -0.222221794480148530, -0.222173044395364530, +-0.222124293755148360, -0.222075542559621450, -0.222026790808905670, -0.221978038503122500, -0.221929285642394670, -0.221880532226843620, -0.221831778256591230, -0.221783023731758950, +-0.221734268652469590, -0.221685513018844510, -0.221636756831005250, -0.221588000089074500, -0.221539242793173770, -0.221490484943424940, -0.221441726539949450, -0.221392967582870080, +-0.221344208072308280, -0.221295448008385990, -0.221246687391224630, -0.221197926220946970, -0.221149164497674520, -0.221100402221529160, -0.221051639392632340, -0.221002876011106850, +-0.220954112077074190, -0.220905347590656250, -0.220856582551974490, -0.220807816961151730, -0.220759050818309400, -0.220710284123569470, -0.220661516877053400, -0.220612749078883950, +-0.220563980729182620, -0.220515211828070930, -0.220466442375671650, -0.220417672372106240, -0.220368901817496660, -0.220320130711964380, -0.220271359055632220, -0.220222586848621640, +-0.220173814091054630, -0.220125040783052620, -0.220076266924738470, -0.220027492516233630, -0.219978717557660080, -0.219929942049139270, -0.219881165990794050, -0.219832389382745940, +-0.219783612225116830, -0.219734834518028280, -0.219686056261603040, -0.219637277455962680, -0.219588498101228710, -0.219539718197523910, -0.219490937744969810, -0.219442156743688390, +-0.219393375193801120, -0.219344593095430830, -0.219295810448699090, -0.219247027253727830, -0.219198243510638550, -0.219149459219554090, -0.219100674380595990, -0.219051888993886220, +-0.219003103059546260, -0.218954316577699010, -0.218905529548465950, -0.218856741971969050, -0.218807953848329910, -0.218759165177671270, -0.218710375960114750, -0.218661586195781830, +-0.218612795884795400, -0.218564005027276960, -0.218515213623348530, -0.218466421673131630, -0.218417629176749090, -0.218368836134322510, -0.218320042545973810, -0.218271248411824580, +-0.218222453731997670, -0.218173658506614600, -0.218124862735797400, -0.218076066419667620, -0.218027269558348110, -0.217978472151960400, -0.217929674200626530, -0.217880875704468040, +-0.217832076663607790, -0.217783277078167360, -0.217734476948268720, -0.217685676274033460, -0.217636875055584430, -0.217588073293043220, -0.217539270986531420, -0.217490468136171840, +-0.217441664742086120, -0.217392860804396210, -0.217344056323223730, -0.217295251298691540, -0.217246445730921220, -0.217197639620034800, -0.217148832966153840, -0.217100025769401210, +-0.217051218029898550, -0.217002409747767830, -0.216953600923130650, -0.216904791556109890, -0.216855981646827150, -0.216807171195404490, -0.216758360201963430, -0.216709548666626920, +-0.216660736589516540, -0.216611923970753910, -0.216563110810461870, -0.216514297108762050, -0.216465482865776490, -0.216416668081626800, -0.216367852756435890, -0.216319036890325310, +-0.216270220483417150, -0.216221403535833020, -0.216172586047695820, -0.216123768019127140, -0.216074949450249050, -0.216026130341183150, -0.215977310692052340, -0.215928490502978270, +-0.215879669774082960, -0.215830848505488060, -0.215782026697316470, -0.215733204349689790, -0.215684381462729700, -0.215635558036559070, -0.215586734071299550, -0.215537909567073190, +-0.215489084524001620, -0.215440258942207780, -0.215391432821813310, -0.215342606162940240, -0.215293778965710200, -0.215244951230246170, -0.215196122956669760, -0.215147294145103060, +-0.215098464795667660, -0.215049634908486550, -0.215000804483681330, -0.214951973521374130, -0.214903142021686560, -0.214854309984741560, -0.214805477410660780, -0.214756644299565870, +-0.214707810651579790, -0.214658976466824190, -0.214610141745421120, -0.214561306487492300, -0.214512470693160620, -0.214463634362547780, -0.214414797495775860, -0.214365960092966490, +-0.214317122154242670, -0.214268283679726030, -0.214219444669538680, -0.214170605123802320, -0.214121765042639860, -0.214072924426172980, -0.214024083274523800, -0.213975241587813950, +-0.213926399366166450, -0.213877556609702950, -0.213828713318545580, -0.213779869492815970, -0.213731025132637110, -0.213682180238130710, -0.213633334809418430, -0.213584488846623230, +-0.213535642349866800, -0.213486795319271280, -0.213437947754958330, -0.213389099657050970, -0.213340251025670840, -0.213291401860940060, -0.213242552162980380, -0.213193701931914730, +-0.213144851167864830, -0.213095999870952820, -0.213047148041300340, -0.212998295679030450, -0.212949442784264810, -0.212900589357125580, -0.212851735397734440, -0.212802880906214380, +-0.212754025882687130, -0.212705170327274370, -0.212656314240099120, -0.212607457621283110, -0.212558600470948430, -0.212509742789216830, -0.212460884576211290, -0.212412025832053540, +-0.212363166556865740, -0.212314306750769570, -0.212265446413888090, -0.212216585546342980, -0.212167724148256410, -0.212118862219750100, -0.212069999760947060, -0.212021136771969020, +-0.211972273252938160, -0.211923409203976150, -0.211874544625206080, -0.211825679516749630, -0.211776813878728540, -0.211727947711265880, -0.211679081014483320, -0.211630213788503080, +-0.211581346033446860, -0.211532477749437700, -0.211483608936597370, -0.211434739595047990, -0.211385869724911360, -0.211336999326310480, -0.211288128399367090, -0.211239256944203370, +-0.211190384960941090, -0.211141512449703280, -0.211092639410611680, -0.211043765843788510, -0.210994891749355460, -0.210946017127435630, -0.210897141978150740, -0.210848266301623010, +-0.210799390097974190, -0.210750513367327310, -0.210701636109804140, -0.210652758325526460, -0.210603880014617330, -0.210555001177198470, -0.210506121813392150, -0.210457241923320050, +-0.210408361507105290, -0.210359480564869640, -0.210310599096735270, -0.210261717102823990, -0.210212834583258850, -0.210163951538161610, -0.210115067967654500, -0.210066183871859270, +-0.210017299250899010, -0.209968414104895530, -0.209919528433971020, -0.209870642238247220, -0.209821755517847260, -0.209772868272892930, -0.209723980503505990, -0.209675092209809510, +-0.209626203391925340, -0.209577314049975620, -0.209528424184082210, -0.209479533794368150, -0.209430642880955280, -0.209381751443965790, -0.209332859483521480, -0.209283966999745470, +-0.209235073992759530, -0.209186180462685920, -0.209137286409646410, -0.209088391833764130, -0.209039496735160840, -0.208990601113958840, -0.208941704970279890, -0.208892808304247140, +-0.208843911115982330, -0.208795013405607330, -0.208746115173245230, -0.208697216419017840, -0.208648317143047410, -0.208599417345455730, -0.208550517026365980, -0.208501616185899910, +-0.208452714824179820, -0.208403812941327480, -0.208354910537466080, -0.208306007612717360, -0.208257104167203670, -0.208208200201046740, -0.208159295714369780, -0.208110390707294560, +-0.208061485179943360, -0.208012579132438010, -0.207963672564901670, -0.207914765477456130, -0.207865857870223240, -0.207816949743326150, -0.207768041096886680, -0.207719131931027120, +-0.207670222245869280, -0.207621312041536330, -0.207572401318150110, -0.207523490075832870, -0.207474578314706480, -0.207425666034894070, -0.207376753236517470, -0.207327839919699030, +-0.207278926084560530, -0.207230011731225160, -0.207181096859814760, -0.207132181470451620, -0.207083265563257600, -0.207034349138355830, -0.206985432195868210, -0.206936514735916980, +-0.206887596758624060, -0.206838678264112560, -0.206789759252504370, -0.206740839723921350, -0.206691919678486660, -0.206642999116322200, -0.206594078037550200, -0.206545156442292600, +-0.206496234330672520, -0.206447311702811890, -0.206398388558832940, -0.206349464898857610, -0.206300540723009050, -0.206251616031409120, -0.206202690824180160, -0.206153765101444040, +-0.206104838863323950, -0.206055912109941760, -0.206006984841419770, -0.205958057057879920, -0.205909128759445340, -0.205860199946237940, -0.205811270618379590, -0.205762340775993540, +-0.205713410419201600, -0.205664479548126140, -0.205615548162889040, -0.205566616263613530, -0.205517683850421460, -0.205468750923435190, -0.205419817482776600, -0.205370883528568910, +-0.205321949060934010, -0.205273014079994240, -0.205224078585871490, -0.205175142578688990, -0.205126206058568630, -0.205077269025632750, -0.205028331480003270, -0.204979393421803380, +-0.204930454851155020, -0.204881515768180090, -0.204832576173001800, -0.204783636065742070, -0.204734695446523260, -0.204685754315467260, -0.204636812672697320, -0.204587870518335320, +-0.204538927852503690, -0.204489984675324280, -0.204441040986920340, -0.204392096787413820, -0.204343152076927050, -0.204294206855581940, -0.204245261123501780, -0.204196314880808440, +-0.204147368127624320, -0.204098420864071370, -0.204049473090272770, -0.204000524806350500, -0.203951576012426920, -0.203902626708623970, -0.203853676895064890, -0.203804726571871600, +-0.203755775739166090, -0.203706824397071550, -0.203657872545709940, -0.203608920185203680, -0.203559967315674660, -0.203511013937246160, -0.203462060050040140, -0.203413105654178940, +-0.203364150749784590, -0.203315195336980250, -0.203266239415887950, -0.203217282986630030, -0.203168326049328500, -0.203119368604106560, -0.203070410651086220, -0.203021452190389830, +-0.202972493222139390, -0.202923533746458130, -0.202874573763468070, -0.202825613273291130, -0.202776652276050570, -0.202727690771868420, -0.202678728760867010, -0.202629766243168360, +-0.202580803218895710, -0.202531839688171070, -0.202482875651116830, -0.202433911107854970, -0.202384946058508740, -0.202335980503200170, -0.202287014442051630, -0.202238047875185150, +-0.202189080802723960, -0.202140113224790090, -0.202091145141505920, -0.202042176552993450, -0.201993207459375960, -0.201944237860775480, -0.201895267757313950, -0.201846297149114700, +-0.201797326036299710, -0.201748354418991390, -0.201699382297311770, -0.201650409671384120, -0.201601436541330450, -0.201552462907273160, -0.201503488769334300, -0.201454514127637150, +-0.201405538982303730, -0.201356563333456450, -0.201307587181217330, -0.201258610525709670, -0.201209633367055500, -0.201160655705377220, -0.201111677540796870, -0.201062698873437780, +-0.201013719703421940, -0.200964740030871360, -0.200915759855909370, -0.200866779178657970, -0.200817797999239630, -0.200768816317776350, -0.200719834134391480, -0.200670851449207020, +-0.200621868262345400, -0.200572884573928720, -0.200523900384080240, -0.200474915692922030, -0.200425930500576500, -0.200376944807165720, -0.200327958612813020, -0.200278971917640440, +-0.200229984721770390, -0.200180997025324990, -0.200132008828427490, -0.200083020131200000, -0.200034030933764930, -0.199985041236244360, -0.199936051038761640, -0.199887060341438770, +-0.199838069144397830, -0.199789077447762140, -0.199740085251653770, -0.199691092556195160, -0.199642099361508420, -0.199593105667716850, -0.199544111474942500, -0.199495116783307890, +-0.199446121592935070, -0.199397125903947340, -0.199348129716466820, -0.199299133030615970, -0.199250135846516850, -0.199201138164292830, -0.199152139984065970, -0.199103141305958740, +-0.199054142130093260, -0.199005142456592820, -0.198956142285579530, -0.198907141617175460, -0.198858140451503990, -0.198809138788687140, -0.198760136628847450, -0.198711133972106990, +-0.198662130818589130, -0.198613127168415950, -0.198564123021709920, -0.198515118378593170, -0.198466113239189060, -0.198417107603619660, -0.198368101472007510, -0.198319094844474660, +-0.198270087721144490, -0.198221080102139120, -0.198172071987581050, -0.198123063377592360, -0.198074054272296430, -0.198025044671815390, -0.197976034576271300, -0.197927023985787570, +-0.197878012900486260, -0.197829001320489920, -0.197779989245920630, -0.197730976676901820, -0.197681963613555580, -0.197632950056004400, -0.197583936004370440, -0.197534921458777050, +-0.197485906419346380, -0.197436890886200920, -0.197387874859462800, -0.197338858339255440, -0.197289841325700930, -0.197240823818921830, -0.197191805819040220, -0.197142787326179540, +-0.197093768340461880, -0.197044748862009820, -0.196995728890945440, -0.196946708427392150, -0.196897687471472130, -0.196848666023307420, -0.196799644083021500, -0.196750621650736480, +-0.196701598726574890, -0.196652575310658860, -0.196603551403111840, -0.196554527004055930, -0.196505502113613730, -0.196456476731907300, -0.196407450859060140, -0.196358424495194360, +-0.196309397640432510, -0.196260370294896710, -0.196211342458710440, -0.196162314131995810, -0.196113285314875400, -0.196064256007471350, -0.196015226209907080, -0.195966195922304740, +-0.195917165144786490, -0.195868133877475760, -0.195819102120494660, -0.195770069873965860, -0.195721037138011420, -0.195672003912754830, -0.195622970198318230, -0.195573935994824200, +-0.195524901302394890, -0.195475866121153780, -0.195426830451222970, -0.195377794292725120, -0.195328757645782340, -0.195279720510518090, -0.195230682887054560, -0.195181644775514310, +-0.195132606176019520, -0.195083567088693620, -0.195034527513658850, -0.194985487451037300, -0.194936446900952460, -0.194887405863526510, -0.194838364338882050, -0.194789322327141250, +-0.194740279828427560, -0.194691236842863190, -0.194642193370570700, -0.194593149411672330, -0.194544104966291490, -0.194495060034550390, -0.194446014616571660, -0.194396968712477440, +-0.194347922322391260, -0.194298875446435260, -0.194249828084732040, -0.194200780237403860, -0.194151731904574130, -0.194102683086365110, -0.194053633782898920, -0.194004583994299070, +-0.193955533720687770, -0.193906482962187650, -0.193857431718920890, -0.193808379991010970, -0.193759327778580100, -0.193710275081750930, -0.193661221900645610, -0.193612168235387680, +-0.193563114086099330, -0.193514059452903200, -0.193465004335921480, -0.193415948735277700, -0.193366892651094020, -0.193317836083493150, -0.193268779032597200, -0.193219721498529780, +-0.193170663481413040, -0.193121604981369650, -0.193072545998521810, -0.193023486532993030, -0.192974426584905550, -0.192925366154381550, -0.192876305241544590, -0.192827243846516870, +-0.192778181969421010, -0.192729119610379280, -0.192680056769515190, -0.192630993446950950, -0.192581929642809240, -0.192532865357212260, -0.192483800590283530, -0.192434735342145340, +-0.192385669612920280, -0.192336603402730620, -0.192287536711699900, -0.192238469539950330, -0.192189401887604580, -0.192140333754784900, -0.192091265141614790, -0.192042196048216540, +-0.191993126474712370, -0.191944056421225830, -0.191894985887879120, -0.191845914874794960, -0.191796843382095600, -0.191747771409904540, -0.191698698958344040, -0.191649626027536820, +-0.191600552617605090, -0.191551478728672400, -0.191502404360861020, -0.191453329514293640, -0.191404254189092520, -0.191355178385381160, -0.191306102103281860, -0.191257025342917330, +-0.191207948104409780, -0.191158870387882820, -0.191109792193458670, -0.191060713521259580, -0.191011634371409170, -0.190962554744029650, -0.190913474639243770, -0.190864394057173760, +-0.190815312997943190, -0.190766231461674350, -0.190717149448489910, -0.190668066958512180, -0.190618983991864720, -0.190569900548669820, -0.190520816629050130, -0.190471732233127970, +-0.190422647361026930, -0.190373562012869260, -0.190324476188777710, -0.190275389888874490, -0.190226303113283260, -0.190177215862126270, -0.190128128135526240, -0.190079039933605450, +-0.190029951256487500, -0.189980862104294660, -0.189931772477149240, -0.189882682375174830, -0.189833591798493710, -0.189784500747228610, -0.189735409221501810, -0.189686317221436950, +-0.189637224747156270, -0.189588131798782530, -0.189539038376438040, -0.189489944480246390, -0.189440850110329880, -0.189391755266811230, -0.189342659949812750, -0.189293564159458080, +-0.189244467895869490, -0.189195371159169730, -0.189146273949481110, -0.189097176266927240, -0.189048078111630410, -0.188998979483712970, -0.188949880383298520, -0.188900780810509340, +-0.188851680765468240, -0.188802580248297490, -0.188753479259120730, -0.188704377798060260, -0.188655275865238860, -0.188606173460778820, -0.188557070584803810, -0.188507967237436100, +-0.188458863418798470, -0.188409759129013250, -0.188360654368204070, -0.188311549136493260, -0.188262443434003580, -0.188213337260857340, -0.188164230617178210, -0.188115123503088480, +-0.188066015918710530, -0.188016907864167970, -0.187967799339583130, -0.187918690345078800, -0.187869580880777320, -0.187820470946802290, -0.187771360543276120, -0.187722249670321530, +-0.187673138328060870, -0.187624026516617830, -0.187574914236114690, -0.187525801486674280, -0.187476688268418930, -0.187427574581472300, -0.187378460425956740, -0.187329345801995010, +-0.187280230709709480, -0.187231115149223830, -0.187181999120660390, -0.187132882624141930, -0.187083765659790850, -0.187034648227730780, -0.186985530328084070, -0.186936411960973130, +-0.186887293126521580, -0.186838173824851820, -0.186789054056086590, -0.186739933820348310, -0.186690813117760650, -0.186641691948445930, -0.186592570312526990, -0.186543448210126170, +-0.186494325641367200, -0.186445202606372370, -0.186396079105264570, -0.186346955138166130, -0.186297830705200730, -0.186248705806490750, -0.186199580442159040, -0.186150454612327900, +-0.186101328317121090, -0.186052201556660940, -0.186003074331069860, -0.185953946640471520, -0.185904818484988330, -0.185855689864743070, -0.185806560779858160, -0.185757431230457290, +-0.185708301216662850, -0.185659170738597640, -0.185610039796384070, -0.185560908390145830, -0.185511776520005330, -0.185462644186085410, -0.185413511388508400, -0.185364378127398090, +-0.185315244402876810, -0.185266110215067420, -0.185216975564092310, -0.185167840450075200, -0.185118704873138500, -0.185069568833404610, -0.185020432330997210, -0.184971295366038760, +-0.184922157938652050, -0.184873020048959500, -0.184823881697084860, -0.184774742883150520, -0.184725603607279300, -0.184676463869593630, -0.184627323670217250, -0.184578183009272560, +-0.184529041886882430, -0.184479900303169240, -0.184430758258256750, -0.184381615752267330, -0.184332472785323910, -0.184283329357548850, -0.184234185469065920, -0.184185041119997510, +-0.184135896310466060, -0.184086751040595300, -0.184037605310507700, -0.183988459120326050, -0.183939312470172810, -0.183890165360171750, -0.183841017790445260, -0.183791869761116250, +-0.183742721272307120, -0.183693572324141600, -0.183644422916742180, -0.183595273050231680, -0.183546122724732560, -0.183496971940368600, -0.183447820697262180, -0.183398668995536220, +-0.183349516835313140, -0.183300364216716720, -0.183251211139869390, -0.183202057604894030, -0.183152903611913080, -0.183103749161050320, -0.183054594252428180, -0.183005438886169100, +-0.182956283062396890, -0.182907126781233940, -0.182857970042803210, -0.182808812847227110, -0.182759655194629390, -0.182710497085132570, -0.182661338518859460, -0.182612179495932610, +-0.182563020016475730, -0.182513860080611300, -0.182464699688462210, -0.182415538840150940, -0.182366377535801260, -0.182317215775535640, -0.182268053559477010, -0.182218890887747760, +-0.182169727760471740, -0.182120564177771390, -0.182071400139769220, -0.182022235646588980, -0.181973070698353140, -0.181923905295184620, -0.181874739437205890, -0.181825573124540780, +-0.181776406357311710, -0.181727239135641650, -0.181678071459653030, -0.181628903329469680, -0.181579734745214080, -0.181530565707009120, -0.181481396214977330, -0.181432226269242460, +-0.181383055869927060, -0.181333885017154000, -0.181284713711045790, -0.181235541951726250, -0.181186369739317840, -0.181137197073943070, -0.181088023955725740, -0.181038850384788370, +-0.180989676361253850, -0.180940501885244710, -0.180891326956884760, -0.180842151576296490, -0.180792975743602840, -0.180743799458926300, -0.180694622722390700, -0.180645445534118570, +-0.180596267894232800, -0.180547089802855940, -0.180497911260111780, -0.180448732266122850, -0.180399552821012080, -0.180350372924902000, -0.180301192577916440, -0.180252011780177880, +-0.180202830531809270, -0.180153648832933190, -0.180104466683673390, -0.180055284084152440, -0.180006101034492850, -0.179956917534818430, -0.179907733585251720, -0.179858549185915680, +-0.179809364336932810, -0.179760179038427000, -0.179710993290520730, -0.179661807093336980, -0.179612620446998270, -0.179563433351628440, -0.179514245807350040, -0.179465057814286010, +-0.179415869372558910, -0.179366680482292570, -0.179317491143609510, -0.179268301356632740, -0.179219111121484780, -0.179169920438289470, -0.179120729307169380, -0.179071537728247020, +-0.179022345701646240, -0.178973153227489610, -0.178923960305900100, -0.178874766937000250, -0.178825573120913910, -0.178776378857763650, -0.178727184147672440, -0.178677988990762810, +-0.178628793387158670, -0.178579597336982530, -0.178530400840357430, -0.178481203897405850, -0.178432006508251720, -0.178382808673017560, -0.178333610391826380, -0.178284411664800750, +-0.178235212492064530, -0.178186012873740280, -0.178136812809950560, -0.178087612300819210, -0.178038411346468860, -0.177989209947022500, -0.177940008102602630, -0.177890805813333220, +-0.177841603079336770, -0.177792399900736340, -0.177743196277654450, -0.177693992210215010, -0.177644787698540580, -0.177595582742754190, -0.177546377342978400, -0.177497171499337110, +-0.177447965211952910, -0.177398758480948770, -0.177349551306447310, -0.177300343688572390, -0.177251135627446630, -0.177201927123192600, -0.177152718175934170, -0.177103508785793950, +-0.177054298952894980, -0.177005088677359810, -0.176955877959312340, -0.176906666798875210, -0.176857455196171380, -0.176808243151323490, -0.176759030664455420, -0.176709817735689780, +-0.176660604365149600, -0.176611390552957460, -0.176562176299237290, -0.176512961604111670, -0.176463746467703660, -0.176414530890135840, -0.176365314871532120, -0.176316098412015120, +-0.176266881511707880, -0.176217664170733010, -0.176168446389214390, -0.176119228167274680, -0.176070009505036460, -0.176020790402623640, -0.175971570860158830, -0.175922350877765120, +-0.175873130455565070, -0.175823909593682660, -0.175774688292240470, -0.175725466551361540, -0.175676244371168520, -0.175627021751785320, -0.175577798693334590, -0.175528575195939340, +-0.175479351259722220, -0.175430126884807160, -0.175380902071316790, -0.175331676819374140, -0.175282451129101870, -0.175233225000623940, -0.175183998434062900, -0.175134771429541450, +-0.175085543987183540, -0.175036316107111730, -0.174987087789449130, -0.174937859034318380, -0.174888629841843450, -0.174839400212146890, -0.174790170145351860, -0.174740939641580970, +-0.174691708700958180, -0.174642477323606080, -0.174593245509647830, -0.174544013259205990, -0.174494780572404580, -0.174445547449366220, -0.174396313890213980, -0.174347079895070510, +-0.174297845464059800, -0.174248610597304450, -0.174199375294927160, -0.174150139557051860, -0.174100903383801210, -0.174051666775298290, -0.174002429731665800, -0.173953192253027630, +-0.173903954339506510, -0.173854715991225480, -0.173805477208307250, -0.173756237990875750, -0.173706998339053680, -0.173657758252964090, -0.173608517732729640, -0.173559276778474380, +-0.173510035390320920, -0.173460793568392360, -0.173411551312811360, -0.173362308623701940, -0.173313065501186750, -0.173263821945388890, -0.173214577956431050, -0.173165333534437190, +-0.173116088679530020, -0.173066843391832180, -0.173017597671467650, -0.172968351518559130, -0.172919104933229730, -0.172869857915602170, -0.172820610465800360, -0.172771362583947040, +-0.172722114270165290, -0.172672865524577830, -0.172623616347308660, -0.172574366738480450, -0.172525116698216300, -0.172475866226638940, -0.172426615323872350, -0.172377363990039220, +-0.172328112225262680, -0.172278860029665410, -0.172229607403371430, -0.172180354346503440, -0.172131100859184120, -0.172081846941537500, -0.172032592593686250, -0.171983337815753530, +-0.171934082607862030, -0.171884826970135740, -0.171835570902697380, -0.171786314405670100, -0.171737057479176610, -0.171687800123340920, -0.171638542338285710, -0.171589284124134160, +-0.171540025481008940, -0.171490766409034100, -0.171441506908332380, -0.171392246979026860, -0.171342986621240280, -0.171293725835096670, -0.171244464620718770, -0.171195202978229240, +-0.171145940907752180, -0.171096678409410230, -0.171047415483326610, -0.170998152129623990, -0.170948888348426450, -0.170899624139856680, -0.170850359504037850, -0.170801094441092680, +-0.170751828951145210, -0.170702563034318160, -0.170653296690734730, -0.170604029920517600, -0.170554762723790830, -0.170505495100677170, -0.170456227051299760, -0.170406958575781340, +-0.170357689674245970, -0.170308420346816400, -0.170259150593615290, -0.170209880414766780, -0.170160609810393550, -0.170111338780618820, -0.170062067325565280, -0.170012795445357020, +-0.169963523140116760, -0.169914250409967720, -0.169864977255032580, -0.169815703675435470, -0.169766429671299070, -0.169717155242746610, -0.169667880389900830, -0.169618605112885790, +-0.169569329411824200, -0.169520053286839330, -0.169470776738053890, -0.169421499765591930, -0.169372222369576190, -0.169322944550129940, -0.169273666307375860, -0.169224387641438070, +-0.169175108552439310, -0.169125829040502360, -0.169076549105751230, -0.169027268748308760, -0.168977987968298100, -0.168928706765842070, -0.168879425141064660, -0.168830143094088720, +-0.168780860625037420, -0.168731577734033520, -0.168682294421201110, -0.168633010686662980, -0.168583726530542320, -0.168534441952961880, -0.168485156954045810, -0.168435871533916840, +-0.168386585692698180, -0.168337299430512620, -0.168288012747484260, -0.168238725643735850, -0.168189438119390190, -0.168140150174571370, -0.168090861809402190, -0.168041573024005850, +-0.167992283818505140, -0.167942994193024160, -0.167893704147685700, -0.167844413682612960, -0.167795122797928770, -0.167745831493757190, -0.167696539770221030, -0.167647247627443540, +-0.167597955065547500, -0.167548662084656990, -0.167499368684894820, -0.167450074866384250, -0.167400780629248040, -0.167351485973610330, -0.167302190899593890, -0.167252895407321550, +-0.167203599496917400, -0.167154303168504240, -0.167105006422205330, -0.167055709258143480, -0.167006411676442780, -0.166957113677226070, -0.166907815260616540, -0.166858516426737070, +-0.166809217175711730, -0.166759917507663340, -0.166710617422715170, -0.166661316920990010, -0.166612016002612020, -0.166562714667703950, -0.166513412916389130, -0.166464110748790310, +-0.166414808165031680, -0.166365505165236020, -0.166316201749526580, -0.166266897918026210, -0.166217593670859030, -0.166168289008147870, -0.166118983930015560, -0.166069678436586210, +-0.166020372527982660, -0.165971066204328190, -0.165921759465745610, -0.165872452312359090, -0.165823144744291410, -0.165773836761665900, -0.165724528364605330, -0.165675219553233890, +-0.165625910327674400, -0.165576600688050140, -0.165527290634483930, -0.165477980167099940, -0.165428669286021010, -0.165379357991370380, -0.165330046283270940, -0.165280734161846830, +-0.165231421627220850, -0.165182108679515910, -0.165132795318856110, -0.165083481545364340, -0.165034167359163850, -0.164984852760377530, -0.164935537749129500, -0.164886222325542620, +-0.164836906489740200, -0.164787590241845060, -0.164738273581981400, -0.164688956510272020, -0.164639639026840280, -0.164590321131808990, -0.164541002825302350, -0.164491684107443190, +-0.164442364978354850, -0.164393045438160130, -0.164343725486983230, -0.164294405124947030, -0.164245084352174390, -0.164195763168789450, -0.164146441574915120, -0.164097119570674690, +-0.164047797156191000, -0.163998474331588260, -0.163949151096989350, -0.163899827452517580, -0.163850503398295770, -0.163801178934448150, -0.163751854061097570, -0.163702528778367380, +-0.163653203086380400, -0.163603876985260880, -0.163554550475131650, -0.163505223556116050, -0.163455896228336950, -0.163406568491918560, -0.163357240346983730, -0.163307911793655390, +-0.163258582832057690, -0.163209253462313520, -0.163159923684546240, -0.163110593498878690, -0.163061262905435100, -0.163011931904338350, -0.162962600495711790, -0.162913268679678290, +-0.162863936456362050, -0.162814603825885950, -0.162765270788373360, -0.162715937343947150, -0.162666603492731540, -0.162617269234849400, -0.162567934570424120, -0.162518599499578530, +-0.162469264022436920, -0.162419928139122120, -0.162370591849757500, -0.162321255154465970, -0.162271918053371740, -0.162222580546597720, -0.162173242634266800, -0.162123904316503230, +-0.162074565593429890, -0.162025226465170120, -0.161975886931846860, -0.161926546993584330, -0.161877206650505420, -0.161827865902733490, -0.161778524750391480, -0.161729183193603580, +-0.161679841232492710, -0.161630498867182250, -0.161581156097795110, -0.161531812924455510, -0.161482469347286380, -0.161433125366411080, -0.161383780981952520, -0.161334436194034950, +-0.161285091002781290, -0.161235745408314450, -0.161186399410758710, -0.161137053010236950, -0.161087706206872570, -0.161038359000788500, -0.160989011392108940, -0.160939663380956890, +-0.160890314967455650, -0.160840966151728190, -0.160791616933898760, -0.160742267314090280, -0.160692917292426130, -0.160643566869029250, -0.160594216044023910, -0.160544864817533020, +-0.160495513189679940, -0.160446161160587690, -0.160396808730380420, -0.160347455899181170, -0.160298102667112840, -0.160248749034299670, -0.160199395000864640, -0.160150040566931110, +-0.160100685732622070, -0.160051330498061720, -0.160001974863373060, -0.159952618828679450, -0.159903262394103880, -0.159853905559770580, -0.159804548325802510, -0.159755190692323080, +-0.159705832659455200, -0.159656474227323240, -0.159607115396050050, -0.159557756165759070, -0.159508396536573280, -0.159459036508616920, -0.159409676082012980, -0.159360315256884850, +-0.159310954033355490, -0.159261592411549190, -0.159212230391588910, -0.159162867973597600, -0.159113505157699560, -0.159064141944017770, -0.159014778332675630, -0.158965414323796100, +-0.158916049917503470, -0.158866685113920710, -0.158817319913171250, -0.158767954315378050, -0.158718588320665380, -0.158669221929156250, -0.158619855140974100, -0.158570487956241820, +-0.158521120375083780, -0.158471752397622960, -0.158422384023982730, -0.158373015254286130, -0.158323646088657400, -0.158274276527219570, -0.158224906570095610, -0.158175536217409820, +-0.158126165469285210, -0.158076794325845150, -0.158027422787212680, -0.157978050853512100, -0.157928678524866390, -0.157879305801398970, -0.157829932683232870, -0.157780559170492360, +-0.157731185263300460, -0.157681810961780610, -0.157632436266055780, -0.157583061176250290, -0.157533685692487160, -0.157484309814889780, -0.157434933543581230, -0.157385556878685770, +-0.157336179820326410, -0.157286802368626190, -0.157237424523709370, -0.157188046285699020, -0.157138667654718540, -0.157089288630890940, -0.157039909214340580, -0.156990529405190430, +-0.156941149203563950, -0.156891768609584180, -0.156842387623375410, -0.156793006245060680, -0.156743624474763420, -0.156694242312606670, -0.156644859758714760, -0.156595476813210700, +-0.156546093476217920, -0.156496709747859510, -0.156447325628259750, -0.156397941117541660, -0.156348556215828300, -0.156299170923243970, -0.156249785239911730, -0.156200399165955020, +-0.156151012701496870, -0.156101625846661620, -0.156052238601572300, -0.156002850966352410, -0.155953462941124940, -0.155904074526014260, -0.155854685721143390, -0.155805296526635800, +-0.155755906942614510, -0.155706516969203930, -0.155657126606527030, -0.155607735854707330, -0.155558344713867840, -0.155508953184132940, -0.155459561265625660, -0.155410168958469460, +-0.155360776262787410, -0.155311383178703850, -0.155261989706341840, -0.155212595845824420, -0.155163201597275950, -0.155113806960819470, -0.155064411936578470, -0.155015016524676000, +-0.154965620725236420, -0.154916224538382800, -0.154866827964238620, -0.154817431002926940, -0.154768033654572120, -0.154718635919297190, -0.154669237797225690, -0.154619839288480660, +-0.154570440393186460, -0.154521041111466170, -0.154471641443443270, -0.154422241389240820, -0.154372840948983210, -0.154323440122793500, -0.154274038910794780, -0.154224637313111370, +-0.154175235329866350, -0.154125832961183260, -0.154076430207185170, -0.154027027067996420, -0.153977623543740120, -0.153928219634539730, -0.153878815340518370, -0.153829410661800420, +-0.153780005598508930, -0.153730600150767420, -0.153681194318699000, -0.153631788102428000, -0.153582381502077560, -0.153532974517771150, -0.153483567149631850, -0.153434159397784100, +-0.153384751262350930, -0.153335342743455450, -0.153285933841222080, -0.153236524555773830, -0.153187114887234300, -0.153137704835726530, -0.153088294401374920, -0.153038883584302590, +-0.152989472384633060, -0.152940060802489420, -0.152890648837996050, -0.152841236491276070, -0.152791823762452980, -0.152742410651649900, -0.152692997158991230, -0.152643583284600070, +-0.152594169028599960, -0.152544754391113980, -0.152495339372266530, -0.152445923972180760, -0.152396508190980190, -0.152347092028787880, -0.152297675485728280, -0.152248258561924530, +-0.152198841257499660, -0.152149423572578130, -0.152100005507283060, -0.152050587061737960, -0.152001168236065960, -0.151951749030391460, -0.151902329444837610, -0.151852909479527930, +-0.151803489134585550, -0.151754068410134860, -0.151704647306299010, -0.151655225823201570, -0.151605803960965600, -0.151556381719715550, -0.151506959099574540, -0.151457536100666150, +-0.151408112723113500, -0.151358688967040970, -0.151309264832571730, -0.151259840319828890, -0.151210415428936900, -0.151160990160018850, -0.151111564513198350, -0.151062138488598480, +-0.151012712086343730, -0.150963285306557170, -0.150913858149362400, -0.150864430614882560, -0.150815002703242080, -0.150765574414564090, -0.150716145748972160, -0.150666716706589430, +-0.150617287287540340, -0.150567857491948040, -0.150518427319936090, -0.150468996771627640, -0.150419565847147140, -0.150370134546617710, -0.150320702870162530, -0.150271270817906010, +-0.150221838389971300, -0.150172405586482010, -0.150122972407561280, -0.150073538853333550, -0.150024104923921990, -0.149974670619450130, -0.149925235940041170, -0.149875800885819560, +-0.149826365456908470, -0.149776929653431450, -0.149727493475511650, -0.149678056923273570, -0.149628619996840350, -0.149579182696335580, -0.149529745021882400, -0.149480306973605310, +-0.149430868551627460, -0.149381429756071990, -0.149331990587063400, -0.149282551044724790, -0.149233111129179840, -0.149183670840551670, -0.149134230178964770, -0.149084789144542260, +-0.149035347737407810, -0.148985905957684540, -0.148936463805496940, -0.148887021280968200, -0.148837578384221870, -0.148788135115381190, -0.148738691474570610, -0.148689247461913280, +-0.148639803077532830, -0.148590358321552460, -0.148540913194096620, -0.148491467695288480, -0.148442021825251680, -0.148392575584109400, -0.148343128971986120, -0.148293681989005000, +-0.148244234635289240, -0.148194786910963360, -0.148145338816150500, -0.148095890350974260, -0.148046441515557880, -0.147996992310025830, -0.147947542734501310, -0.147898092789107930, +-0.147848642473968890, -0.147799191789208670, -0.147749740734950450, -0.147700289311317900, -0.147650837518434190, -0.147601385356423840, -0.147551932825409990, -0.147502479925516320, +-0.147453026656866020, -0.147403573019583590, -0.147354119013792250, -0.147304664639615140, -0.147255209897176800, -0.147205754786600470, -0.147156299308009750, -0.147106843461527830, +-0.147057387247279240, -0.147007930665387170, -0.146958473715975290, -0.146909016399166790, -0.146859558715086160, -0.146810100663856660, -0.146760642245601900, -0.146711183460445090, +-0.146661724308510770, -0.146612264789922150, -0.146562804904802860, -0.146513344653276120, -0.146463884035466420, -0.146414423051497070, -0.146364961701491190, -0.146315499985573330, +-0.146266037903866750, -0.146216575456495080, -0.146167112643581510, -0.146117649465250600, -0.146068185921625570, -0.146018722012830090, -0.145969257738987330, -0.145919793100221910, +-0.145870328096656980, -0.145820862728416240, -0.145771396995622890, -0.145721930898401490, -0.145672464436875290, -0.145622997611167900, -0.145573530421402590, -0.145524062867703860, +-0.145474594950195020, -0.145425126668999680, -0.145375658024241070, -0.145326189016043740, -0.145276719644530980, -0.145227249909825970, -0.145177779812053260, -0.145128309351336110, +-0.145078838527798180, -0.145029367341562710, -0.144979895792754280, -0.144930423881496070, -0.144880951607911840, -0.144831478972124780, -0.144782005974259470, -0.144732532614439140, +-0.144683058892787490, -0.144633584809427730, -0.144584110364484460, -0.144534635558080910, -0.144485160390340760, -0.144435684861387280, -0.144386208971345050, -0.144336732720337260, +-0.144287256108487220, -0.144237779135919480, -0.144188301802757300, -0.144138824109124350, -0.144089346055143900, -0.144039867640940510, -0.143990388866637480, -0.143940909732358460, +-0.143891430238226730, -0.143841950384366870, -0.143792470170902130, -0.143742989597956230, -0.143693508665652390, -0.143644027374115250, -0.143594545723468000, -0.143545063713834410, +-0.143495581345337710, -0.143446098618102510, -0.143396615532252080, -0.143347132087909640, -0.143297648285199810, -0.143248164124245870, -0.143198679605171520, -0.143149194728100030, +-0.143099709493156010, -0.143050223900462680, -0.143000737950143810, -0.142951251642322670, -0.142901764977123810, -0.142852277954670560, -0.142802790575086630, -0.142753302838495240, +-0.142703814745021060, -0.142654326294787360, -0.142604837487917800, -0.142555348324535730, -0.142505858804765740, -0.142456368928731090, -0.142406878696555080, -0.142357388108362320, +-0.142307897164276080, -0.142258405864420100, -0.142208914208917650, -0.142159422197893380, -0.142109929831470560, -0.142060437109772900, -0.142010944032923690, -0.141961450601047590, +-0.141911956814267850, -0.141862462672708220, -0.141812968176491970, -0.141763473325743770, -0.141713978120586890, -0.141664482561145060, -0.141614986647541570, -0.141565490379901040, +-0.141515993758346810, -0.141466496783002600, -0.141416999453991690, -0.141367501771438750, -0.141318003735467020, -0.141268505346199860, -0.141219006603761880, -0.141169507508276370, +-0.141120008059867100, -0.141070508258657360, -0.141021008104771810, -0.140971507598333710, -0.140922006739466870, -0.140872505528294560, -0.140823003964941430, -0.140773502049530790, +-0.140723999782186390, -0.140674497163031570, -0.140624994192190910, -0.140575490869787790, -0.140525987195945950, -0.140476483170788670, -0.140426978794440660, -0.140377474067025170, +-0.140327968988665590, -0.140278463559486500, -0.140228957779611250, -0.140179451649163620, -0.140129945168266910, -0.140080438337045780, -0.140030931155623570, -0.139981423624124020, +-0.139931915742670470, -0.139882407511387560, -0.139832898930398660, -0.139783389999827480, -0.139733880719797390, -0.139684371090433050, -0.139634861111857800, -0.139585350784195370, +-0.139535840107569140, -0.139486329082103730, -0.139436817707922520, -0.139387305985148810, -0.139337793913907270, -0.139288281494321260, -0.139238768726514530, -0.139189255610610460, +-0.139139742146733690, -0.139090228335007530, -0.139040714175555830, -0.138991199668501900, -0.138941684813970430, -0.138892169612084730, -0.138842654062968580, -0.138793138166745380, +-0.138743621923539780, -0.138694105333475120, -0.138644588396675210, -0.138595071113263360, -0.138545553483364280, -0.138496035507101320, -0.138446517184598270, -0.138396998515978500, +-0.138347479501366670, -0.138297960140886130, -0.138248440434660250, -0.138198920382813730, -0.138149399985469910, -0.138099879242752550, -0.138050358154785090, -0.138000836721692170, +-0.137951314943597140, -0.137901792820623810, -0.137852270352895600, -0.137802747540537120, -0.137753224383671800, -0.137703700882423400, -0.137654177036915320, -0.137604652847272220, +-0.137555128313617490, -0.137505603436074960, -0.137456078214767960, -0.137406552649821210, -0.137357026741358080, -0.137307500489501970, -0.137257973894377520, -0.137208446956108120, +-0.137158919674817640, -0.137109392050629390, -0.137059864083668100, -0.137010335774057190, -0.136960807121920410, -0.136911278127381160, -0.136861748790564170, -0.136812219111592800, +-0.136762689090590920, -0.136713158727681830, -0.136663628022990310, -0.136614096976639700, -0.136564565588753880, -0.136515033859456180, -0.136465501788871320, -0.136415969377122750, +-0.136366436624333790, -0.136316903530629170, -0.136267370096132300, -0.136217836320967010, -0.136168302205256690, -0.136118767749126040, -0.136069232952698490, -0.136019697816097850, +-0.135970162339447530, -0.135920626522872230, -0.135871090366495360, -0.135821553870440790, -0.135772017034831880, -0.135722479859793380, -0.135672942345448660, -0.135623404491921590, +-0.135573866299335570, -0.135524327767815340, -0.135474788897484270, -0.135425249688465810, -0.135375710140884650, -0.135326170254864210, -0.135276630030528370, -0.135227089468000490, +-0.135177548567405330, -0.135128007328866290, -0.135078465752507260, -0.135028923838451610, -0.134979381586824070, -0.134929838997748100, -0.134880296071347520, -0.134830752807745790, +-0.134781209207067570, -0.134731665269436360, -0.134682120994975980, -0.134632576383809850, -0.134583031436062730, -0.134533486151858030, -0.134483940531319620, -0.134434394574570900, +-0.134384848281736660, -0.134335301652940280, -0.134285754688305200, -0.134236207387956190, -0.134186659752016660, -0.134137111780610470, -0.134087563473861080, -0.134038014831893200, +-0.133988465854830290, -0.133938916542796220, -0.133889366895914410, -0.133839816914309630, -0.133790266598105310, -0.133740715947425310, -0.133691164962393080, -0.133641613643133400, +-0.133592061989769670, -0.133542510002425780, -0.133492957681225180, -0.133443405026292650, -0.133393852037751590, -0.133344298715725450, -0.133294745060339000, -0.133245191071715700, +-0.133195636749979420, -0.133146082095253610, -0.133096527107663040, -0.133046971787331130, -0.132997416134381820, -0.132947860148938500, -0.132898303831126000, -0.132848747181067710, +-0.132799190198887580, -0.132749632884709010, -0.132700075238656820, -0.132650517260854420, -0.132600958951425730, -0.132551400310494230, -0.132501841338184660, -0.132452282034620480, +-0.132402722399925150, -0.132353162434223460, -0.132303602137638840, -0.132254041510295240, -0.132204480552316090, -0.132154919263826190, -0.132105357644948990, -0.132055795695808390, +-0.132006233416527840, -0.131956670807232170, -0.131907107868044830, -0.131857544599089690, -0.131807981000490270, -0.131758417072371350, -0.131708852814856360, -0.131659288228069240, +-0.131609723312133470, -0.131560158067173830, -0.131510592493313820, -0.131461026590677290, -0.131411460359387780, -0.131361893799570060, -0.131312326911347590, -0.131262759694843860, +-0.131213192150183680, -0.131163624277490510, -0.131114056076888280, -0.131064487548500470, -0.131014918692451910, -0.130965349508866010, -0.130915779997866770, -0.130866210159577640, +-0.130816639994123410, -0.130767069501627560, -0.130717498682214080, -0.130667927536006370, -0.130618356063129330, -0.130568784263706360, -0.130519212137861440, -0.130469639685718060, +-0.130420066907401020, -0.130370493803033780, -0.130320920372739900, -0.130271346616644160, -0.130221772534870020, -0.130172198127541490, -0.130122623394782010, -0.130073048336716400, +-0.130023472953468190, -0.129973897245161290, -0.129924321211919190, -0.129874744853866740, -0.129825168171127440, -0.129775591163825200, -0.129726013832083540, -0.129676436176027310, +-0.129626858195779960, -0.129577279891465470, -0.129527701263207370, -0.129478122311130430, -0.129428543035358200, -0.129378963436014150, -0.129329383513223150, -0.129279803267108690, +-0.129230222697794720, -0.129180641805404760, -0.129131060590063600, -0.129081479051894820, -0.129031897191022340, -0.128982315007569680, -0.128932732501661680, -0.128883149673421820, +-0.128833566522974120, -0.128783983050442030, -0.128734399255950450, -0.128684815139622850, -0.128635230701583230, -0.128585645941955070, -0.128536060860863250, -0.128486475458431280, +-0.128436889734783120, -0.128387303690042310, -0.128337717324333660, -0.128288130637780720, -0.128238543630507020, -0.128188956302637410, -0.128139368654295400, -0.128089780685604950, +-0.128040192396689620, -0.127990603787674270, -0.127941014858682390, -0.127891425609837990, -0.127841836041264560, -0.127792246153086990, -0.127742655945428800, -0.127693065418413990, +-0.127643474572166070, -0.127593883406809880, -0.127544291922469020, -0.127494700119267390, -0.127445107997328610, -0.127395515556777470, -0.127345922797737540, -0.127296329720332390, +-0.127246736324686830, -0.127197142610924440, -0.127147548579169180, -0.127097954229544650, -0.127048359562175640, -0.126998764577185730, -0.126949169274698900, -0.126899573654838730, +-0.126849977717730070, -0.126800381463496450, -0.126750784892261880, -0.126701188004149900, -0.126651590799285400, -0.126601993277791920, -0.126552395439793460, -0.126502797285413580, +-0.126453198814777120, -0.126403600028007680, -0.126354000925228800, -0.126304401506565360, -0.126254801772140910, -0.126205201722079470, -0.126155601356504580, -0.126106000675541120, +-0.126056399679312650, -0.126006798367943210, -0.125957196741556310, -0.125907594800276860, -0.125857992544228410, -0.125808389973535000, -0.125758787088320170, -0.125709183888708830, +-0.125659580374824500, -0.125609976546791240, -0.125560372404732580, -0.125510767948773440, -0.125461163179037380, -0.125411558095647970, -0.125361952698730100, -0.125312346988407370, +-0.125262740964803750, -0.125213134628042840, -0.125163527978249560, -0.125113921015547440, -0.125064313740060500, -0.125014706151912350, -0.124965098251227880, -0.124915490038130670, +-0.124865881512744720, -0.124816272675193630, -0.124766663525602310, -0.124717054064094320, -0.124667444290793700, -0.124617834205824020, -0.124568223809310210, -0.124518613101375820, +-0.124469002082144910, -0.124419390751741060, -0.124369779110289170, -0.124320167157912820, -0.124270554894735620, -0.124220942320882470, -0.124171329436476980, -0.124121716241643160, +-0.124072102736504600, -0.124022488921186220, -0.123972874795811640, -0.123923260360504860, -0.123873645615389480, -0.123824030560590420, -0.123774415196231310, -0.123724799522436150, +-0.123675183539328550, -0.123625567247033430, -0.123575950645674390, -0.123526333735375480, -0.123476716516260300, -0.123427098988453750, -0.123377481152079470, -0.123327863007261030, +-0.123278244554123400, -0.123228625792790130, -0.123179006723385320, -0.123129387346032540, -0.123079767660856740, -0.123030147667981510, -0.122980527367530910, -0.122930906759628560, +-0.122881285844399380, -0.122831664621966980, -0.122782043092455430, -0.122732421255988320, -0.122682799112690600, -0.122633176662685890, -0.122583553906098240, -0.122533930843051250, +-0.122484307473669880, -0.122434683798077750, -0.122385059816398470, -0.122335435528756980, -0.122285810935276880, -0.122236186036082270, -0.122186560831296750, -0.122136935321045280, +-0.122087309505451460, -0.122037683384639370, -0.121988056958732630, -0.121938430227856190, -0.121888803192133670, -0.121839175851689140, -0.121789548206646240, -0.121739920257129920, +-0.121690292003263770, -0.121640663445171910, -0.121591034582977940, -0.121541405416806830, -0.121491775946782220, -0.121442146173028150, -0.121392516095668280, -0.121342885714827560, +-0.121293255030629630, -0.121243624043198120, -0.121193992752657990, -0.121144361159132880, -0.121094729262746860, -0.121045097063623580, -0.120995464561888010, -0.120945831757663750, +-0.120896198651074940, -0.120846565242245170, -0.120796931531299450, -0.120747297518361390, -0.120697663203555090, -0.120648028587004190, -0.120598393668833650, -0.120548758449167130, +-0.120499122928128710, -0.120449487105842050, -0.120399850982432120, -0.120350214558022560, -0.120300577832737010, -0.120250940806700470, -0.120201303480036560, -0.120151665852869400, +-0.120102027925322650, -0.120052389697521260, -0.120002751169588890, -0.119953112341649650, -0.119903473213827190, -0.119853833786246480, -0.119804194059031190, -0.119754554032305410, +-0.119704913706192810, -0.119655273080818360, -0.119605632156305740, -0.119555990932779020, -0.119506349410361900, -0.119456707589179340, -0.119407065469355010, -0.119357423051012570, +-0.119307780334277020, -0.119258137319272030, -0.119208494006121680, -0.119158850394949670, -0.119109206485880960, -0.119059562279039230, -0.119009917774548610, -0.118960272972532750, +-0.118910627873116640, -0.118860982476423970, -0.118811336782578840, -0.118761690791704930, -0.118712044503927240, -0.118662397919369430, -0.118612751038155620, -0.118563103860409500, +-0.118513456386256060, -0.118463808615818980, -0.118414160549221940, -0.118364512186589930, -0.118314863528046640, -0.118265214573716210, -0.118215565323722280, -0.118165915778189880, +-0.118116265937242710, -0.118066615801004860, -0.118016965369600030, -0.117967314643153230, -0.117917663621788140, -0.117868012305628910, -0.117818360694799190, -0.117768708789424010, +-0.117719056589627060, -0.117669404095532460, -0.117619751307263920, -0.117570098224946450, -0.117520444848703720, -0.117470791178659880, -0.117421137214938620, -0.117371482957664960, +-0.117321828406962610, -0.117272173562955220, -0.117222518425767850, -0.117172862995524190, -0.117123207272348360, -0.117073551256364080, -0.117023894947696360, -0.116974238346468900, +-0.116924581452805850, -0.116874924266830910, -0.116825266788669090, -0.116775609018444100, -0.116725950956280090, -0.116676292602300770, -0.116626633956631160, -0.116576975019394960, +-0.116527315790716320, -0.116477656270718950, -0.116427996459527880, -0.116378336357266830, -0.116328675964059480, -0.116279015280030900, -0.116229354305304760, -0.116179693040005250, +-0.116130031484256060, -0.116080369638182250, -0.116030707501907500, -0.115981045075555980, -0.115931382359251410, -0.115881719353118820, -0.115832056057281930, -0.115782392471864910, +-0.115732728596991460, -0.115683064432786640, -0.115633399979374150, -0.115583735236878160, -0.115534070205422400, -0.115484404885131900, -0.115434739276130390, -0.115385073378541580, +-0.115335407192490540, -0.115285740718100980, -0.115236073955497060, -0.115186406904802520, -0.115136739566142400, -0.115087071939640430, -0.115037404025420800, -0.114987735823607200, +-0.114938067334324700, -0.114888398557697040, -0.114838729493848380, -0.114789060142902450, -0.114739390504984330, -0.114689720580217720, -0.114640050368726810, -0.114590379870635330, +-0.114540709086068340, -0.114491038015149580, -0.114441366658003220, -0.114391695014753020, -0.114342023085524010, -0.114292350870439940, -0.114242678369624570, -0.114193005583202920, +-0.114143332511298770, -0.114093659154036280, -0.114043985511539210, -0.113994311583932630, -0.113944637371340250, -0.113894962873886270, -0.113845288091694460, -0.113795613024889870, +-0.113745937673596240, -0.113696262037937770, -0.113646586118038200, -0.113596909914022600, -0.113547233426014750, -0.113497556654138800, -0.113447879598518510, -0.113398202259278980, +-0.113348524636543920, -0.113298846730437120, -0.113249168541083650, -0.113199490068607260, -0.113149811313132130, -0.113100132274782050, -0.113050452953682070, -0.113000773349955950, +-0.112951093463727910, -0.112901413295121700, -0.112851732844262380, -0.112802052111273740, -0.112752371096279960, -0.112702689799404810, -0.112653008220773380, -0.112603326360509450, +-0.112553644218737180, -0.112503961795580370, -0.112454279091164090, -0.112404596105612110, -0.112354912839048210, -0.112305229291597460, -0.112255545463383640, -0.112205861354530950, +-0.112156176965163180, -0.112106492295405400, -0.112056807345381380, -0.112007122115215350, -0.111957436605031090, -0.111907750814953660, -0.111858064745106860, -0.111808378395614890, +-0.111758691766601540, -0.111709004858191890, -0.111659317670509750, -0.111609630203679300, -0.111559942457824340, -0.111510254433069960, -0.111460566129539950, -0.111410877547358080, +-0.111361188686649460, -0.111311499547537860, -0.111261810130147520, -0.111212120434602210, -0.111162430461027040, -0.111112740209545800, -0.111063049680282700, -0.111013358873361540, +-0.110963667788907430, -0.110913976427044130, -0.110864284787895910, -0.110814592871586530, -0.110764900678241100, -0.110715208207983430, -0.110665515460937740, -0.110615822437227810, +-0.110566129136978770, -0.110516435560314420, -0.110466741707358970, -0.110417047578236230, -0.110367353173071290, -0.110317658491987990, -0.110267963535110110, -0.110218268302562730, +-0.110168572794469700, -0.110118877010955240, -0.110069180952143140, -0.110019484618158540, -0.109969788009125210, -0.109920091125167430, -0.109870393966408980, -0.109820696532974970, +-0.109770998824989220, -0.109721300842575990, -0.109671602585859050, -0.109621904054963550, -0.109572205250013290, -0.109522506171132520, -0.109472806818445040, -0.109423107192075990, +-0.109373407292149170, -0.109323707118788390, -0.109274006672118770, -0.109224305952264150, -0.109174604959348760, -0.109124903693496420, -0.109075202154832250, -0.109025500343480090, +-0.108975798259564170, -0.108926095903208310, -0.108876393274537660, -0.108826690373676020, -0.108776987200747670, -0.108727283755876400, -0.108677580039187360, -0.108627876050804370, +-0.108578171790851690, -0.108528467259453140, -0.108478762456733870, -0.108429057382817680, -0.108379352037828420, -0.108329646421891200, -0.108279940535129890, -0.108230234377668710, +-0.108180527949631510, -0.108130821251143430, -0.108081114282328310, -0.108031407043310380, -0.107981699534213510, -0.107931991755162830, -0.107882283706282150, -0.107832575387695780, +-0.107782866799527530, -0.107733157941902550, -0.107683448814944680, -0.107633739418778180, -0.107584029753526910, -0.107534319819315980, -0.107484609616269270, -0.107434899144511030, +-0.107385188404165100, -0.107335477395356630, -0.107285766118209490, -0.107236054572847480, -0.107186342759395770, -0.107136630677978210, -0.107086918328719070, -0.107037205711742190, +-0.106987492827172740, -0.106937779675134560, -0.106888066255751940, -0.106838352569148700, -0.106788638615450020, -0.106738924394779750, -0.106689209907262160, -0.106639495153021110, +-0.106589780132181760, -0.106540064844867970, -0.106490349291204020, -0.106440633471313730, -0.106390917385322320, -0.106341201033353610, -0.106291484415531460, -0.106241767531981040, +-0.106192050382826200, -0.106142332968191230, -0.106092615288199990, -0.106042897342977660, -0.105993179132648070, -0.105943460657335540, -0.105893741917163910, -0.105844022912258390, +-0.105794303642742800, -0.105744584108741440, -0.105694864310378180, -0.105645144247778210, -0.105595423921065380, -0.105545703330363990, -0.105495982475797900, -0.105446261357492290, +-0.105396539975571020, -0.105346818330157980, -0.105297096421378330, -0.105247374249355930, -0.105197651814215090, -0.105147929116079690, -0.105098206155074900, -0.105048482931324600, +-0.104998759444953100, -0.104949035696084240, -0.104899311684843250, -0.104849587411353970, -0.104799862875740740, -0.104750138078127400, -0.104700413018639150, -0.104650687697399870, +-0.104600962114533870, -0.104551236270165030, -0.104501510164418540, -0.104451783797418280, -0.104402057169288100, -0.104352330280153230, -0.104302603130137530, -0.104252875719365340, +-0.104203148047960490, -0.104153420116048240, -0.104103691923752420, -0.104053963471197390, -0.104004234758506980, -0.103954505785806450, -0.103904776553219640, -0.103855047060870900, +-0.103805317308884090, -0.103755587297384450, -0.103705857026495820, -0.103656126496342550, -0.103606395707048530, -0.103556664658738960, -0.103506933351537720, -0.103457201785569160, +-0.103407469960957150, -0.103357737877826900, -0.103308005536302320, -0.103258272936507270, -0.103208540078566990, -0.103158806962605350, -0.103109073588746700, -0.103059339957114910, +-0.103009606067835230, -0.102959871921031520, -0.102910137516828150, -0.102860402855348980, -0.102810667936719240, -0.102760932761062840, -0.102711197328504100, -0.102661461639166940, +-0.102611725693176560, -0.102561989490656850, -0.102512253031732180, -0.102462516316526450, -0.102412779345164850, -0.102363042117771310, -0.102313304634469720, -0.102263566895385310, +-0.102213828900641980, -0.102164090650364090, -0.102114352144675530, -0.102064613383701530, -0.102014874367565980, -0.101965135096393270, -0.101915395570307250, -0.101865655789433210, +-0.101815915753895020, -0.101766175463817040, -0.101716434919323180, -0.101666694120538680, -0.101616953067587430, -0.101567211760593810, -0.101517470199681710, -0.101467728384976390, +-0.101417986316601750, -0.101368243994681680, -0.101318501419341470, -0.101268758590704990, -0.101219015508896610, -0.101169272174040260, -0.101119528586261160, -0.101069784745683250, +-0.101020040652430880, -0.100970296306627960, -0.100920551708399740, -0.100870806857870140, -0.100821061755163520, -0.100771316400403810, -0.100721570793716260, -0.100671824935224770, +-0.100622078825053710, -0.100572332463327030, -0.100522585850169950, -0.100472838985706410, -0.100423091870060770, -0.100373344503356960, -0.100323596885720230, -0.100273849017274500, +-0.100224100898143720, -0.100174352528453120, -0.100124603908326640, -0.100074855037888650, -0.100025105917263090, -0.099975356546575203, -0.099925606925948915, -0.099875857055508624, +-0.099826106935378231, -0.099776356565683025, -0.099726605946546920, -0.099676855078094304, -0.099627103960449118, -0.099577352593736609, -0.099527600978080707, -0.099477849113605812, +-0.099428097000435853, -0.099378344638696089, -0.099328592028510465, -0.099278839170002922, -0.099229086063298721, -0.099179332708521806, -0.099129579105796561, -0.099079825255246917, +-0.099030071156998162, -0.098980316811174224, -0.098930562217899504, -0.098880807377297916, -0.098831052289494764, -0.098781296954613990, -0.098731541372779966, -0.098681785544116635, +-0.098632029468749299, -0.098582273146801888, -0.098532516578398788, -0.098482759763663955, -0.098433002702722663, -0.098383245395698871, -0.098333487842716519, -0.098283730043900883, +-0.098233971999375932, -0.098184213709266041, -0.098134455173695193, -0.098084696392788634, -0.098034937366670336, -0.097985178095464698, -0.097935418579295663, -0.097885658818288535, +-0.097835898812567254, -0.097786138562256222, -0.097736378067479410, -0.097686617328362091, -0.097636856345028236, -0.097587095117602232, -0.097537333646208049, -0.097487571930970976, +-0.097437809972014969, -0.097388047769463998, -0.097338285323443352, -0.097288522634076988, -0.097238759701489333, -0.097188996525804316, -0.097139233107147255, -0.097089469445642118, +-0.097039705541413307, -0.096989941394584792, -0.096940177005281861, -0.096890412373628484, -0.096840647499749077, -0.096790882383767610, -0.096741117025809384, -0.096691351425998356, +-0.096641585584458956, -0.096591819501315151, -0.096542053176692233, -0.096492286610714198, -0.096442519803505433, -0.096392752755189923, -0.096342985465892983, -0.096293217935738570, +-0.096243450164850683, -0.096193682153354609, -0.096143913901374320, -0.096094145409034257, -0.096044376676458376, -0.095994607703772009, -0.095944838491099110, -0.095895069038564124, +-0.095845299346291032, -0.095795529414405112, -0.095745759243030387, -0.095695988832291259, -0.095646218182311712, -0.095596447293217063, -0.095546676165131295, -0.095496904798178836, +-0.095447133192483685, -0.095397361348171131, -0.095347589265365171, -0.095297816944189803, -0.095248044384770331, -0.095198271587230751, -0.095148498551695493, -0.095098725278288540, +-0.095048951767135223, -0.094999178018359526, -0.094949404032085891, -0.094899629808438288, -0.094849855347542061, -0.094800080649521196, -0.094750305714500133, -0.094700530542602857, +-0.094650755133954698, -0.094600979488679640, -0.094551203606902154, -0.094501427488746209, -0.094451651134337136, -0.094401874543798933, -0.094352097717255598, -0.094302320654832475, +-0.094252543356653534, -0.094202765822843246, -0.094152988053525608, -0.094103210048825922, -0.094053431808868229, -0.094003653333776943, -0.093953874623676090, -0.093904095678690985, +-0.093854316498945656, -0.093804537084564515, -0.093754757435671604, -0.093704977552392238, -0.093655197434850429, -0.093605417083170619, -0.093555636497476835, -0.093505855677894406, +-0.093456074624547317, -0.093406293337560065, -0.093356511817056620, -0.093306730063162341, -0.093256948076001239, -0.093207165855697327, -0.093157383402375948, -0.093107600716161101, +-0.093057817797177256, -0.093008034645548424, -0.092958251261399949, -0.092908467644855844, -0.092858683796040564, -0.092808899715078136, -0.092759115402093903, -0.092709330857211877, +-0.092659546080556529, -0.092609761072251884, -0.092559975832423258, -0.092510190361194705, -0.092460404658690681, -0.092410618725035185, -0.092360832560353601, -0.092311046164769928, +-0.092261259538408205, -0.092211472681393764, -0.092161685593850642, -0.092111898275903312, -0.092062110727675797, -0.092012322949293443, -0.091962534940880289, -0.091912746702560791, +-0.091862958234458975, -0.091813169536700212, -0.091763380609408529, -0.091713591452708396, -0.091663802066723837, -0.091614012451580226, -0.091564222607401574, -0.091514432534312365, +-0.091464642232436638, -0.091414851701899738, -0.091365060942825718, -0.091315269955338604, -0.091265478739563755, -0.091215687295625208, -0.091165895623647436, -0.091116103723754491, +-0.091066311596071731, -0.091016519240723182, -0.090966726657833341, -0.090916933847526249, -0.090867140809927249, -0.090817347545160410, -0.090767554053350200, -0.090717760334620659, +-0.090667966389097160, -0.090618172216903742, -0.090568377818164902, -0.090518583193004667, -0.090468788341548423, -0.090418993263920208, -0.090369197960244063, -0.090319402430645360, +-0.090269606675248165, -0.090219810694176950, -0.090170014487555752, -0.090120218055509974, -0.090070421398163653, -0.090020624515641273, -0.089970827408066889, -0.089921030075565872, +-0.089871232518262290, -0.089821434736280625, -0.089771636729744933, -0.089721838498780584, -0.089672040043511647, -0.089622241364062605, -0.089572442460557511, -0.089522643333121765, +-0.089472843981879407, -0.089423044406954935, -0.089373244608472416, -0.089323444586557221, -0.089273644341333419, -0.089223843872925063, -0.089174043181457552, -0.089124242267054912, +-0.089074441129841683, -0.089024639769941905, -0.088974838187480962, -0.088925036382582923, -0.088875234355372298, -0.088825432105973143, -0.088775629634510855, -0.088725826941109490, +-0.088676024025893557, -0.088626220888987126, -0.088576417530515580, -0.088526613950602989, -0.088476810149373863, -0.088427006126952284, -0.088377201883463610, -0.088327397419031950, +-0.088277592733781343, -0.088227787827837204, -0.088177982701323585, -0.088128177354365012, -0.088078371787085566, -0.088028565999610620, -0.087978759992064254, -0.087928953764571008, +-0.087879147317254921, -0.087829340650241408, -0.087779533763654549, -0.087729726657618856, -0.087679919332258396, -0.087630111787698584, -0.087580304024063499, -0.087530496041477640, +-0.087480687840065116, -0.087430879419951299, -0.087381070781260298, -0.087331261924116166, -0.087281452848644331, -0.087231643554968846, -0.087181834043214265, -0.087132024313504669, +-0.087082214365965430, -0.087032404200720670, -0.086982593817894902, -0.086932783217612206, -0.086882972399997982, -0.086833161365176340, -0.086783350113271790, -0.086733538644408414, +-0.086683726958711654, -0.086633915056305563, -0.086584102937314680, -0.086534290601863101, -0.086484478050076252, -0.086434665282078188, -0.086384852297993475, -0.086335039097946181, +-0.086285225682061734, -0.086235412050464227, -0.086185598203277744, -0.086135784140627697, -0.086085969862638209, -0.086036155369433778, -0.085986340661138527, -0.085936525737877870, +-0.085886710599775887, -0.085836895246957146, -0.085787079679545700, -0.085737263897667018, -0.085687447901445168, -0.085637631691004704, -0.085587815266469705, -0.085537998627965614, +-0.085488181775616540, -0.085438364709546993, -0.085388547429881112, -0.085338729936744295, -0.085288912230260652, -0.085239094310554278, -0.085189276177750628, -0.085139457831973769, +-0.085089639273348283, -0.085039820501998251, -0.084990001518049099, -0.084940182321624952, -0.084890362912850362, -0.084840543291849396, -0.084790723458747538, -0.084740903413668855, +-0.084691083156737929, -0.084641262688078839, -0.084591442007817041, -0.084541621116076632, -0.084491800012982177, -0.084441978698657771, -0.084392157173228871, -0.084342335436819571, +-0.084292513489553994, -0.084242691331557581, -0.084192868962954429, -0.084143046383869116, -0.084093223594425739, -0.084043400594749740, -0.083993577384965240, -0.083943753965196807, +-0.083893930335568537, -0.083844106496205884, -0.083794282447232971, -0.083744458188774351, -0.083694633720954134, -0.083644809043897789, -0.083594984157729410, -0.083545159062573579, +-0.083495333758554405, -0.083445508245797342, -0.083395682524426501, -0.083345856594566017, -0.083296030456341333, -0.083246204109876570, -0.083196377555296297, -0.083146550792724636, +-0.083096723822287041, -0.083046896644107637, -0.082997069258311004, -0.082947241665021237, -0.082897413864363820, -0.082847585856462860, -0.082797757641442940, -0.082747929219428182, +-0.082698100590544055, -0.082648271754914668, -0.082598442712664588, -0.082548613463917980, -0.082498784008800272, -0.082448954347435599, -0.082399124479948543, -0.082349294406463242, +-0.082299464127105135, -0.082249633641998374, -0.082199802951267095, -0.082149972055036741, -0.082100140953431461, -0.082050309646575822, -0.082000478134593963, -0.081950646417611364, +-0.081900814495752150, -0.081850982369140887, -0.081801150037901726, -0.081751317502160151, -0.081701484762040269, -0.081651651817666676, -0.081601818669163509, -0.081551985316656236, +-0.081502151760269009, -0.081452318000126395, -0.081402484036352543, -0.081352649869072924, -0.081302815498411687, -0.081252980924492957, -0.081203146147442229, -0.081153311167383627, +-0.081103475984441759, -0.081053640598740748, -0.081003805010406077, -0.080953969219561897, -0.080904133226332803, -0.080854297030842917, -0.080804460633217737, -0.080754624033581413, +-0.080704787232058525, -0.080654950228773226, -0.080605113023850983, -0.080555275617415975, -0.080505438009592770, -0.080455600200505531, -0.080405762190279728, -0.080355923979039526, +-0.080306085566909061, -0.080256246954013830, -0.080206408140477983, -0.080156569126426117, -0.080106729911982380, -0.080056890497272271, -0.080007050882419925, -0.079957211067549966, +-0.079907371052786530, -0.079857530838255100, -0.079807690424079855, -0.079757849810385376, -0.079708008997295826, -0.079658167984936704, -0.079608326773432159, -0.079558485362906800, +-0.079508643753484792, -0.079458801945291604, -0.079408959938451415, -0.079359117733088833, -0.079309275329328008, -0.079259432727294438, -0.079209589927112287, -0.079159746928905719, +-0.079109903732800219, -0.079060060338919977, -0.079010216747389561, -0.078960372958333178, -0.078910528971876295, -0.078860684788143107, -0.078810840407258193, -0.078760995829345731, +-0.078711151054531234, -0.078661306082938851, -0.078611460914693204, -0.078561615549918459, -0.078511769988740127, -0.078461924231282371, -0.078412078277669786, -0.078362232128026579, +-0.078312385782478233, -0.078262539241148926, -0.078212692504162823, -0.078162845571645420, -0.078112998443720924, -0.078063151120513916, -0.078013303602148601, -0.077963455888750463, +-0.077913607980443680, -0.077863759877352876, -0.077813911579602241, -0.077764063087317259, -0.077714214400622136, -0.077664365519641454, -0.077614516444499432, -0.077564667175321553, +-0.077514817712232009, -0.077464968055355424, -0.077415118204815975, -0.077365268160739173, -0.077315417923249197, -0.077265567492470238, -0.077215716868527809, -0.077165866051546073, +-0.077116015041649680, -0.077066163838962809, -0.077016312443610971, -0.076966460855718344, -0.076916609075409578, -0.076866757102808839, -0.076816904938041650, -0.076767052581232190, +-0.076717200032505109, -0.076667347291984586, -0.076617494359796132, -0.076567641236063938, -0.076517787920912655, -0.076467934414466449, -0.076418080716850856, -0.076368226828190056, +-0.076318372748608254, -0.076268518478230948, -0.076218664017182358, -0.076168809365587106, -0.076118954523569385, -0.076069099491254732, -0.076019244268767314, -0.075969388856231793, +-0.075919533253772362, -0.075869677461514531, -0.075819821479582508, -0.075769965308100928, -0.075720108947193998, -0.075670252396987242, -0.075620395657604852, -0.075570538729171480, +-0.075520681611811302, -0.075470824305649872, -0.075420966810811382, -0.075371109127420469, -0.075321251255601351, -0.075271393195479541, -0.075221534947179244, -0.075171676510824681, +-0.075121817886541362, -0.075071959074453493, -0.075022100074685724, -0.074972240887362276, -0.074922381512608660, -0.074872521950549081, -0.074822662201308218, -0.074772802265010235, +-0.074722942141780699, -0.074673081831743815, -0.074623221335024220, -0.074573360651746134, -0.074523499782035083, -0.074473638726015284, -0.074423777483811390, -0.074373916055547606, +-0.074324054441349471, -0.074274192641341205, -0.074224330655647014, -0.074174468484392436, -0.074124606127701692, -0.074074743585699432, -0.074024880858509876, -0.073975017946258548, +-0.073925154849069682, -0.073875291567067930, -0.073825428100377510, -0.073775564449123948, -0.073725700613431491, -0.073675836593424776, -0.073625972389228023, -0.073576108000966783, +-0.073526243428765278, -0.073476378672748172, -0.073426513733039656, -0.073376648609765310, -0.073326783303049342, -0.073276917813015971, -0.073227052139790749, -0.073177186283497897, +-0.073127320244262092, -0.073077454022207528, -0.073027587617459769, -0.072977721030143050, -0.072927854260382022, -0.072877987308300932, -0.072828120174025290, -0.072778252857679374, +-0.072728385359387804, -0.072678517679274843, -0.072628649817466029, -0.072578781774085582, -0.072528913549258181, -0.072479045143108059, -0.072429176555760769, -0.072379307787340530, +-0.072329438837972021, -0.072279569707779476, -0.072229700396888460, -0.072179830905423181, -0.072129961233507886, -0.072080091381268127, -0.072030221348828138, -0.071980351136312598, +-0.071930480743845740, -0.071880610171553130, -0.071830739419558975, -0.071780868487987995, -0.071730997376964381, -0.071681126086613728, -0.071631254617060255, -0.071581382968428642, +-0.071531511140843135, -0.071481639134429287, -0.071431766949311346, -0.071381894585613989, -0.071332022043461452, -0.071282149322979299, -0.071232276424291779, -0.071182403347523127, +-0.071132530092798907, -0.071082656660243354, -0.071032783049981160, -0.070982909262136573, -0.070933035296835159, -0.070883161154201138, -0.070833286834359230, -0.070783412337433654, +-0.070733537663550006, -0.070683662812832504, -0.070633787785405841, -0.070583912581394265, -0.070534037200923355, -0.070484161644117346, -0.070434285911100944, -0.070384410001998368, +-0.070334533916935227, -0.070284657656035740, -0.070234781219424169, -0.070184904607226095, -0.070135027819565751, -0.070085150856567843, -0.070035273718356605, -0.069985396405057645, +-0.069935518916795170, -0.069885641253693911, -0.069835763415878105, -0.069785885403473330, -0.069736007216603849, -0.069686128855394353, -0.069636250319969076, -0.069586371610453626, +-0.069536492726972252, -0.069486613669649630, -0.069436734438610051, -0.069386855033979067, -0.069336975455880939, -0.069287095704440388, -0.069237215779781647, -0.069187335682030310, +-0.069137455411310625, -0.069087574967746868, -0.069037694351464618, -0.068987813562588138, -0.068937932601242105, -0.068888051467550809, -0.068838170161639831, -0.068788288683633431, +-0.068738407033656301, -0.068688525211832704, -0.068638643218288248, -0.068588761053147179, -0.068538878716534204, -0.068488996208573599, -0.068439113529390944, -0.068389230679110499, +-0.068339347657856986, -0.068289464465754651, -0.068239581102929103, -0.068189697569504604, -0.068139813865605414, -0.068089929991357129, -0.068040045946884037, -0.067990161732310817, +-0.067940277347761743, -0.067890392793362425, -0.067840508069237124, -0.067790623175510559, -0.067740738112306992, -0.067690852879752017, -0.067640967477969910, -0.067591081907085390, +-0.067541196167222720, -0.067491310258507506, -0.067441424181064011, -0.067391537935016954, -0.067341651520490611, -0.067291764937610590, -0.067241878186501153, -0.067191991267286574, +-0.067142104180092449, -0.067092216925043080, -0.067042329502263159, -0.066992441911876977, -0.066942554154010139, -0.066892666228786909, -0.066842778136332007, -0.066792889876769734, +-0.066743001450225659, -0.066693112856824097, -0.066643224096689740, -0.066593335169946893, -0.066543446076721136, -0.066493556817136770, -0.066443667391318517, -0.066393777799390652, +-0.066343888041478782, -0.066293998117707184, -0.066244108028200160, -0.066194217773083305, -0.066144327352480908, -0.066094436766517689, -0.066044546015317937, -0.065994655099007260, +-0.065944764017709948, -0.065894872771550733, -0.065844981360653879, -0.065795089785145033, -0.065745198045148445, -0.065695306140788862, -0.065645414072190586, -0.065595521839479212, +-0.065545629442779030, -0.065495736882214772, -0.065445844157910729, -0.065395951269992522, -0.065346058218584441, -0.065296165003811205, -0.065246271625797117, -0.065196378084667786, +-0.065146484380547529, -0.065096590513560607, -0.065046696483832642, -0.064996802291487951, -0.064946907936651241, -0.064897013419446828, -0.064847118740000320, -0.064797223898436021, +-0.064747328894878664, -0.064697433729452539, -0.064647538402283267, -0.064597642913495151, -0.064547747263212926, -0.064497851451560895, -0.064447955478664679, -0.064398059344648567, +-0.064348163049637322, -0.064298266593755204, -0.064248369977127878, -0.064198473199879619, -0.064148576262134743, -0.064098679164018860, -0.064048781905656285, -0.063998884487171753, +-0.063948986908689567, -0.063899089170335363, -0.063849191272233430, -0.063799293214508529, -0.063749394997284936, -0.063699496620688301, -0.063649598084842940, -0.063599699389873560, +-0.063549800535904505, -0.063499901523061397, -0.063450002351468526, -0.063400103021250639, -0.063350203532532068, -0.063300303885438419, -0.063250404080094025, -0.063200504116623160, +-0.063150603995151489, -0.063100703715803313, -0.063050803278703368, -0.063000902683975971, -0.062951001931746770, -0.062901101022140055, -0.062851199955280587, -0.062801298731292685, +-0.062751397350301968, -0.062701495812432770, -0.062651594117809822, -0.062601692266557443, -0.062551790258801282, -0.062501888094665656, -0.062451985774275298, -0.062402083297754533, +-0.062352180665229004, -0.062302277876823027, -0.062252374932661350, -0.062202471832868297, -0.062152568577569504, -0.062102665166889288, -0.062052761600951974, -0.062002857879883196, +-0.061952954003807272, -0.061903049972848963, -0.061853145787132580, -0.061803241446783785, -0.061753336951926883, -0.061703432302686635, -0.061653527499187365, -0.061603622541554721, +-0.061553717429913023, -0.061503812164387030, -0.061453906745101060, -0.061404001172180769, -0.061354095445750476, -0.061304189565934947, -0.061254283532858493, -0.061204377346646778, +-0.061154471007424119, -0.061104564515314840, -0.061054657870444597, -0.061004751072937700, -0.060954844122918933, -0.060904937020512612, -0.060855029765844386, -0.060805122359038587, +-0.060755214800219989, -0.060705307089512904, -0.060655399227042994, -0.060605491212934591, -0.060555583047312456, -0.060505674730300926, -0.060455766262025645, -0.060405857642610951, +-0.060355948872181618, -0.060306039950861964, -0.060256130878777653, -0.060206221656053015, -0.060156312282812381, -0.060106402759181408, -0.060056493085284435, -0.060006583261246221, +-0.059956673287191106, -0.059906763163244760, -0.059856852889531499, -0.059806942466176106, -0.059757031893302913, -0.059707121171037582, -0.059657210299504451, -0.059607299278828296, +-0.059557388109133448, -0.059507476790545570, -0.059457565323189007, -0.059407653707188528, -0.059357741942668470, -0.059307830029754496, -0.059257917968570953, -0.059208005759242170, +-0.059158093401893819, -0.059108180896650230, -0.059058268243636192, -0.059008355442976036, -0.058958442494795441, -0.058908529399218736, -0.058858616156370704, -0.058808702766375689, +-0.058758789229359371, -0.058708875545446071, -0.058658961714760580, -0.058609047737427249, -0.058559133613571734, -0.058509219343318389, -0.058459304926791994, -0.058409390364116895, +-0.058359475655418769, -0.058309560800821947, -0.058259645800451225, -0.058209730654430941, -0.058159815362886780, -0.058109899925943079, -0.058059984343724183, -0.058010068616355770, +-0.057960152743962184, -0.057910236726668222, -0.057860320564598215, -0.057810404257877861, -0.057760487806631490, -0.057710571210983899, -0.057660654471059440, -0.057610737586983783, +-0.057560820558881287, -0.057510903386876741, -0.057460986071094490, -0.057411068611660218, -0.057361151008698277, -0.057311233262333450, -0.057261315372690108, -0.057211397339893909, +-0.057161479164069225, -0.057111560845340401, -0.057061642383833114, -0.057011723779671723, -0.056961805032981018, -0.056911886143885364, -0.056861967112510431, -0.056812047938980585, +-0.056762128623420616, -0.056712209165954888, -0.056662289566709073, -0.056612369825807543, -0.056562449943375080, -0.056512529919536050, -0.056462609754416145, -0.056412689448139708, +-0.056362769000831550, -0.056312848412616030, -0.056262927683618826, -0.056213006813964309, -0.056163085803776831, -0.056113164653182078, -0.056063243362304414, -0.056013321931268643, +-0.055963400360199124, -0.055913478649221547, -0.055863556798460272, -0.055813634808040108, -0.055763712678085414, -0.055713790408721875, -0.055663868000073870, -0.055613945452266188, +-0.055564022765423202, -0.055514099939670596, -0.055464176975132749, -0.055414253871934452, -0.055364330630200083, -0.055314407250055327, -0.055264483731624556, -0.055214560075032573, +-0.055164636280403752, -0.055114712347863776, -0.055064788277537025, -0.055014864069547857, -0.054964939724021972, -0.054915015241083741, -0.054865090620857968, -0.054815165863469031, +-0.054765240969042617, -0.054715315937703103, -0.054665390769575294, -0.054615465464783568, -0.054565540023453624, -0.054515614445709834, -0.054465688731677002, -0.054415762881479500, +-0.054365836895243040, -0.054315910773091988, -0.054265984515151161, -0.054216058121544924, -0.054166131592398990, -0.054116204927837724, -0.054066278127985506, -0.054016351192968035, +-0.053966424122909681, -0.053916496917935271, -0.053866569578169175, -0.053816642103737100, -0.053766714494763418, -0.053716786751372946, -0.053666858873690070, -0.053616930861840488, +-0.053567002715948574, -0.053517074436139157, -0.053467146022536612, -0.053417217475266648, -0.053367288794453634, -0.053317359980222405, -0.053267431032697328, -0.053217501952004115, +-0.053167572738267152, -0.053117643391610812, -0.053067713912160808, -0.053017784300041511, -0.052967854555377766, -0.052917924678293933, -0.052867994668915730, -0.052818064527367550, +-0.052768134253774197, -0.052718203848260071, -0.052668273310950885, -0.052618342641971010, -0.052568411841445277, -0.052518480909498066, -0.052468549846255104, -0.052418618651840769, +-0.052368687326379885, -0.052318755869996833, -0.052268824282817344, -0.052218892564965785, -0.052168960716566563, -0.052119028737745376, -0.052069096628626611, -0.052019164389335112, +-0.051969232019995260, -0.051919299520732771, -0.051869366891672028, -0.051819434132937874, -0.051769501244654688, -0.051719568226948190, -0.051669635079942773, -0.051619701803763268, +-0.051569768398534069, -0.051519834864380887, -0.051469901201428123, -0.051419967409800607, -0.051370033489622720, -0.051320099441020200, -0.051270165264117429, -0.051220230959039249, +-0.051170296525910042, -0.051120361964855539, -0.051070427276000134, -0.051020492459468214, -0.050970557515385512, -0.050920622443876414, -0.050870687245065757, -0.050820751919077936, +-0.050770816466038683, -0.050720880886072392, -0.050670945179303893, -0.050621009345857587, -0.050571073385859207, -0.050521137299433139, -0.050471201086704227, -0.050421264747796873, +-0.050371328282836796, -0.050321391691948401, -0.050271454975256528, -0.050221518132885570, -0.050171581164961267, -0.050121644071608004, -0.050071706852950190, -0.050021769509113558, +-0.049971832040222493, -0.049921894446401854, -0.049871956727776029, -0.049822018884470763, -0.049772080916610451, -0.049722142824319929, -0.049672204607723612, -0.049622266266947226, +-0.049572327802115172, -0.049522389213352301, -0.049472450500783006, -0.049422511664533035, -0.049372572704726787, -0.049322633621489108, -0.049272694414944397, -0.049222755085218395, +-0.049172815632435501, -0.049122876056720131, -0.049072936358198010, -0.049022996536993553, -0.048973056593231604, -0.048923116527036563, -0.048873176338534184, -0.048823236027848854, +-0.048773295595105438, -0.048723355040428344, -0.048673414363943304, -0.048623473565774726, -0.048573532646047461, -0.048523591604885931, -0.048473650442415854, -0.048423709158761659, +-0.048373767754048190, -0.048323826228399855, -0.048273884581942400, -0.048223942814800233, -0.048174000927098205, -0.048124058918960738, -0.048074116790513564, -0.048024174541881098, +-0.047974232173187754, -0.047924289684559272, -0.047874347076120066, -0.047824404347994988, -0.047774461500308459, -0.047724518533186225, -0.047674575446752687, -0.047624632241132711, +-0.047574688916450718, -0.047524745472832440, -0.047474801910402299, -0.047424858229285154, -0.047374914429605418, -0.047324970511488845, -0.047275026475059843, -0.047225082320443271, +-0.047175138047763555, -0.047125193657146437, -0.047075249148716330, -0.047025304522597663, -0.046975359778916176, -0.046925414917796282, -0.046875469939362861, -0.046825524843740321, +-0.046775579631054408, -0.046725634301429543, -0.046675688854990599, -0.046625743291861990, -0.046575797612169463, -0.046525851816037439, -0.046475905903590790, -0.046425959874953932, +-0.046376013730252616, -0.046326067469611265, -0.046276121093154751, -0.046226174601007489, -0.046176227993295231, -0.046126281270142400, -0.046076334431673430, -0.046026387478014061, +-0.045976440409288728, -0.045926493225622290, -0.045876545927139183, -0.045826598513965144, -0.045776650986224618, -0.045726703344042462, -0.045676755587543104, -0.045626807716852298, +-0.045576859732094473, -0.045526911633394500, -0.045476963420876808, -0.045427015094667143, -0.045377066654889948, -0.045327118101670082, -0.045277169435131978, -0.045227220655401391, +-0.045177271762602757, -0.045127322756860502, -0.045077373638300375, -0.045027424407046823, -0.044977475063224706, -0.044927525606958459, -0.044877576038373841, -0.044827626357595282, +-0.044777676564747661, -0.044727726659955398, -0.044677776643344269, -0.044627826515038695, -0.044577876275163554, -0.044527925923843276, -0.044477975461203634, -0.044428024887369050, +-0.044378074202464403, -0.044328123406614128, -0.044278172499943987, -0.044228221482578413, -0.044178270354642286, -0.044128319116260042, -0.044078367767557448, -0.044028416308658926, +-0.043978464739688923, -0.043928513060773201, -0.043878561272036203, -0.043828609373602792, -0.043778657365597419, -0.043728705248145844, -0.043678753021372509, -0.043628800685402293, +-0.043578848240359624, -0.043528895686370285, -0.043478943023558703, -0.043428990252049771, -0.043379037371967910, -0.043329084383438903, -0.043279131286587183, -0.043229178081537638, +-0.043179224768414702, -0.043129271347344150, -0.043079317818450417, -0.043029364181857946, -0.042979410437692510, -0.042929456586078552, -0.042879502627140943, -0.042829548561004141, +-0.042779594387793912, -0.042729640107634692, -0.042679685720651374, -0.042629731226968400, -0.042579776626711537, -0.042529821920005234, -0.042479867106974378, -0.042429912187743411, +-0.042379957162438107, -0.042330002031182909, -0.042280046794102702, -0.042230091451321942, -0.042180136002966391, -0.042130180449160504, -0.042080224790028722, -0.042030269025696815, +-0.041980313156289244, -0.041930357181930888, -0.041880401102746191, -0.041830444918860940, -0.041780488630399577, -0.041730532237486989, -0.041680575740247632, -0.041630619138807272, +-0.041580662433290366, -0.041530705623821808, -0.041480748710526039, -0.041430791693528847, -0.041380834572954668, -0.041330877348928409, -0.041280920021574505, -0.041230962591018751, +-0.041181005057385589, -0.041131047420799920, -0.041081089681386178, -0.041031131839270166, -0.040981173894576318, -0.040931215847429092, -0.040881257697954275, -0.040831299446276309, +-0.040781341092520094, -0.040731382636810080, -0.040681424079272062, -0.040631465420030481, -0.040581506659210231, -0.040531547796935775, -0.040481588833332895, -0.040431629768526038, +-0.040381670602640106, -0.040331711335799561, -0.040281751968130178, -0.040231792499756412, -0.040181832930803164, -0.040131873261394897, -0.040081913491657385, -0.040031953621715091, +-0.039981993651692471, -0.039932033581715307, -0.039882073411908060, -0.039832113142395632, -0.039782152773302472, -0.039732192304754381, -0.039682231736875802, -0.039632271069791648, +-0.039582310303626377, -0.039532349438505768, -0.039482388474554285, -0.039432427411896828, -0.039382466250657867, -0.039332504990963177, -0.039282543632937234, -0.039232582176704923, +-0.039182620622390717, -0.039132658970120401, -0.039082697220018434, -0.039032735372209290, -0.038982773426818745, -0.038932811383971262, -0.038882849243791762, -0.038832887006404686, +-0.038782924671935837, -0.038732962240509677, -0.038682999712251115, -0.038633037087284612, -0.038583074365735957, -0.038533111547729613, -0.038483148633390495, -0.038433185622843057, +-0.038383222516213102, -0.038333259313625086, -0.038283296015203923, -0.038233332621074083, -0.038183369131361347, -0.038133405546190192, -0.038083441865685082, -0.038033478089971810, +-0.037983514219174841, -0.037933550253419088, -0.037883586192829014, -0.037833622037530414, -0.037783657787647765, -0.037733693443305967, -0.037683729004629497, -0.037633764471744144, +-0.037583799844774383, -0.037533835123845123, -0.037483870309080826, -0.037433905400607301, -0.037383940398549018, -0.037333975303030877, -0.037284010114177354, -0.037234044832114253, +-0.037184079456966036, -0.037134113988857617, -0.037084148427913480, -0.037034182774259405, -0.036984217028019878, -0.036934251189319367, -0.036884285258283668, -0.036834319235037258, +-0.036784353119705050, -0.036734386912411515, -0.036684420613282455, -0.036634454222442346, -0.036584487740016103, -0.036534521166128195, -0.036484554500904424, -0.036434587744469268, +-0.036384620896947648, -0.036334653958464025, -0.036284686929144216, -0.036234719809112692, -0.036184752598494359, -0.036134785297413707, -0.036084817905996540, -0.036034850424367319, +-0.035984882852650536, -0.035934915190971986, -0.035884947439456145, -0.035834979598227942, -0.035785011667411840, -0.035735043647133653, -0.035685075537517860, -0.035635107338689381, +-0.035585139050772686, -0.035535170673893585, -0.035485202208176560, -0.035435233653746533, -0.035385265010727973, -0.035335296279246690, -0.035285327459427175, -0.035235358551394341, +-0.035185389555272659, -0.035135420471187957, -0.035085451299264700, -0.035035482039627364, -0.034985512692401778, -0.034935543257712399, -0.034885573735684169, -0.034835604126441565, +-0.034785634430110388, -0.034735664646815122, -0.034685694776680702, -0.034635724819831598, -0.034585754776393626, -0.034535784646491263, -0.034485814430249444, -0.034435844127792645, +-0.034385873739246675, -0.034335903264736026, -0.034285932704385617, -0.034235962058319927, -0.034185991326664784, -0.034136020509544659, -0.034086049607084480, -0.034036078619408737, +-0.033986107546643239, -0.033936136388912477, -0.033886165146340928, -0.033836193819054408, -0.033786222407177401, -0.033736250910834840, -0.033686279330151211, -0.033636307665252323, +-0.033586335916262672, -0.033536364083307180, -0.033486392166510330, -0.033436420165997946, -0.033386448081894511, -0.033336475914324953, -0.033286503663413763, -0.033236531329286757, +-0.033186558912068426, -0.033136586411883696, -0.033086613828857053, -0.033036641163114326, -0.032986668414779992, -0.032936695583978541, -0.032886722670835804, -0.032836749675476250, +-0.032786776598024828, -0.032736803438606014, -0.032686830197345640, -0.032636856874368195, -0.032586883469798600, -0.032536909983761353, -0.032486936416382277, -0.032436962767785862, +-0.032386989038097037, -0.032337015227440299, -0.032287041335941465, -0.032237067363725030, -0.032187093310915925, -0.032137119177638639, -0.032087144964019002, -0.032037170670181504, +-0.031987196296250631, -0.031937221842352218, -0.031887247308610742, -0.031837272695151159, -0.031787298002097938, -0.031737323229576925, -0.031687348377712601, -0.031637373446629903, +-0.031587398436453334, -0.031537423347308705, -0.031487448179320525, -0.031437472932613716, -0.031387497607312791, -0.031337522203543557, -0.031287546721430526, -0.031237571161098619, +-0.031187595522672348, -0.031137619806277529, -0.031087644012038659, -0.031037668140080237, -0.030987692190528087, -0.030937716163506709, -0.030887740059141040, -0.030837763877555574, +-0.030787787618876145, -0.030737811283227248, -0.030687834870733819, -0.030637858381520361, -0.030587881815712703, -0.030537905173435336, -0.030487928454813209, -0.030437951659970819, +-0.030387974789033989, -0.030337997842127224, -0.030288020819375466, -0.030238043720903211, -0.030188066546836291, -0.030138089297299202, -0.030088111972416894, -0.030038134572313861, +-0.029988157097115935, -0.029938179546947614, -0.029888201921933404, -0.029838224222199131, -0.029788246447869298, -0.029738268599068848, -0.029688290675922283, -0.029638312678555434, +-0.029588334607092807, -0.029538356461659341, -0.029488378242379539, -0.029438399949379235, -0.029388421582782934, -0.029338443142715578, -0.029288464629301670, -0.029238486042667045, +-0.029188507382936203, -0.029138528650234096, -0.029088549844685219, -0.029038570966415416, -0.028988592015549181, -0.028938612992211024, -0.028888633896526780, -0.028838654728620950, +-0.028788675488618482, -0.028738696176643885, -0.028688716792822987, -0.028638737337280298, -0.028588757810140770, -0.028538778211528899, -0.028488798541570527, -0.028438818800390162, +-0.028388838988112744, -0.028338859104862790, -0.028288879150766128, -0.028238899125947271, -0.028188919030531168, -0.028138938864642318, -0.028088958628406571, -0.028038978321948422, +-0.027988997945392387, -0.027939017498864301, -0.027889036982488669, -0.027839056396390446, -0.027789075740694134, -0.027739095015525583, -0.027689114221009292, -0.027639133357270213, +-0.027589152424432859, -0.027539171422623070, -0.027489190351965349, -0.027439209212584654, -0.027389228004605491, -0.027339246728153702, -0.027289265383353797, -0.027239283970330725, +-0.027189302489209005, -0.027139320940114467, -0.027089339323171632, -0.027039357638505446, -0.026989375886240421, -0.026939394066502403, -0.026889412179415897, -0.026839430225105418, +-0.026789448203696806, -0.026739466115314577, -0.026689483960083679, -0.026639501738128631, -0.026589519449575268, -0.026539537094548111, -0.026489554673172107, -0.026439572185571775, +-0.026389589631872955, -0.026339607012200162, -0.026289624326678352, -0.026239641575432036, -0.026189658758587062, -0.026139675876267938, -0.026089692928599625, -0.026039709915706640, +-0.025989726837714819, -0.025939743694748683, -0.025889760486932745, -0.025839777214392848, -0.025789793877253508, -0.025739810475639682, -0.025689827009675890, -0.025639843479487973, +-0.025589859885200444, -0.025539876226938270, -0.025489892504825959, -0.025439908718989358, -0.025389924869552990, -0.025339940956641806, -0.025289956980380328, -0.025239972940894403, +-0.025189988838308544, -0.025140004672747712, -0.025090020444336423, -0.025040036153200530, -0.024990051799464546, -0.024940067383252988, -0.024890082904691704, -0.024840098363905216, +-0.024790113761018480, -0.024740129096156017, -0.024690144369443674, -0.024640159581005971, -0.024590174730967869, -0.024540189819453884, -0.024490204846589869, -0.024440219812500344, +-0.024390234717310270, -0.024340249561144164, -0.024290264344127878, -0.024240279066385931, -0.024190293728043284, -0.024140308329224463, -0.024090322870055313, -0.024040337350660357, +-0.023990351771164112, -0.023940366131692432, -0.023890380432369837, -0.023840394673321292, -0.023790408854671315, -0.023740422976545758, -0.023690437039069145, -0.023640451042366440, +-0.023590464986562164, -0.023540478871782171, -0.023490492698150980, -0.023440506465793553, -0.023390520174834419, -0.023340533825399429, -0.023290547417613106, -0.023240560951600410, +-0.023190574427485872, -0.023140587845395338, -0.023090601205453337, -0.023040614507784832, -0.022990627752514349, -0.022940640939767738, -0.022890654069669527, -0.022840667142344236, +-0.022790680157917718, -0.022740693116514502, -0.022690706018259555, -0.022640718863277398, -0.022590731651693886, -0.022540744383633547, -0.022490757059221343, -0.022440769678581808, +-0.022390782241840788, -0.022340794749122816, -0.022290807200552855, -0.022240819596255432, -0.022190831936356407, -0.022140844220980300, -0.022090856450252081, -0.022040868624296280, +-0.021990880743238749, -0.021940892807204019, -0.021890904816316611, -0.021840916770702382, -0.021790928670485866, -0.021740940515792024, -0.021690952306745389, -0.021640964043471819, +-0.021590975726095838, -0.021540987354742417, -0.021490998929536084, -0.021441010450602697, -0.021391021918066782, -0.021341033332053314, -0.021291044692686820, -0.021241056000093156, +-0.021191067254396855, -0.021141078455722884, -0.021091089604195774, -0.021041100699941383, -0.020991111743084240, -0.020941122733748874, -0.020891133672061146, -0.020841144558145581, +-0.020791155392127156, -0.020741166174130399, -0.020691176904281173, -0.020641187582704001, -0.020591198209523862, -0.020541208784865282, -0.020491219308854124, -0.020441229781614920, +-0.020391240203272640, -0.020341250573951818, -0.020291260893778310, -0.020241271162876651, -0.020191281381371814, -0.020141291549388329, -0.020091301667052062, -0.020041311734487539, +-0.019991321751819734, -0.019941331719173186, -0.019891341636673748, -0.019841351504445957, -0.019791361322614345, -0.019741371091304773, -0.019691380810641774, -0.019641390480750320, +-0.019591400101754950, -0.019541409673781519, -0.019491419196954567, -0.019441428671399068, -0.019391438097239550, -0.019341447474601883, -0.019291456803610597, -0.019241466084390670, +-0.019191475317066633, -0.019141484501764349, -0.019091493638608358, -0.019041502727723630, -0.018991511769234703, -0.018941520763267439, -0.018891529709946373, -0.018841538609396039, +-0.018791547461742303, -0.018741556267109698, -0.018691565025623205, -0.018641573737407352, -0.018591582402588010, -0.018541591021289713, -0.018491599593637435, -0.018441608119755717, +-0.018391616599770424, -0.018341625033806087, -0.018291633421987689, -0.018241641764439761, -0.018191650061288176, -0.018141658312657464, -0.018091666518672604, -0.018041674679458136, +-0.017991682795139925, -0.017941690865842509, -0.017891698891690420, -0.017841706872809528, -0.017791714809324368, -0.017741722701359919, -0.017691730549040725, -0.017641738352492643, +-0.017591746111840219, -0.017541753827208427, -0.017491761498721808, -0.017441769126506232, -0.017391776710686230, -0.017341784251386785, -0.017291791748732438, -0.017241799202849052, +-0.017191806613861171, -0.017141813981893773, -0.017091821307071396, -0.017041828589519911, -0.016991835829363852, -0.016941843026727764, -0.016891850181737507, -0.016841857294517627, +-0.016791864365193105, -0.016741871393888476, -0.016691878380729611, -0.016641885325841054, -0.016591892229347781, -0.016541899091374334, -0.016491905912046585, -0.016441912691489070, +-0.016391919429826773, -0.016341926127184235, -0.016291932783687322, -0.016241939399460580, -0.016191945974628988, -0.016141952509317090, -0.016091959003650753, -0.016041965457754517, +-0.015991971871753368, -0.015941978245771846, -0.015891984579935823, -0.015841990874369837, -0.015791997129198432, -0.015742003344547475, -0.015692009520541512, -0.015642015657305525, +-0.015592021754964054, -0.015542027813642972, -0.015492033833466822, -0.015442039814560587, -0.015392045757048809, -0.015342051661057361, -0.015292057526710782, -0.015242063354134061, +-0.015192069143451736, -0.015142074894789683, -0.015092080608272444, -0.015042086284025001, -0.014992091922171899, -0.014942097522839011, -0.014892103086150882, -0.014842108612232048, +-0.014792114101208387, -0.014742119553204442, -0.014692124968345198, -0.014642130346755197, -0.014592135688560314, -0.014542140993885093, -0.014492146262854519, -0.014442151495593135, +-0.014392156692226815, -0.014342161852880104, -0.014292166977677989, -0.014242172066745013, -0.014192177120207049, -0.014142182138188644, -0.014092187120814784, -0.014042192068210011, +-0.013992196980500202, -0.013942201857809901, -0.013892206700263652, -0.013842211507987328, -0.013792216281105477, -0.013742221019743085, -0.013692225724024697, -0.013642230394076187, +-0.013592235030022102, -0.013542239631987430, -0.013492244200096714, -0.013442248734475831, -0.013392253235249328, -0.013342257702542191, -0.013292262136478966, -0.013242266537185529, +-0.013192270904786427, -0.013142275239406646, -0.013092279541170733, -0.013042283810204567, -0.012992288046632690, -0.012942292250580094, -0.012892296422171321, -0.012842300561532254, +-0.012792304668787434, -0.012742308744061409, -0.012692312787480056, -0.012642316799167920, -0.012592320779249993, -0.012542324727850820, -0.012492328645096279, -0.012442332531110916, +-0.012392336386019722, -0.012342340209947242, -0.012292344003019358, -0.012242347765360612, -0.012192351497095997, -0.012142355198350059, -0.012092358869248677, -0.012042362509916400, +-0.011992366120478215, -0.011942369701058671, -0.011892373251783646, -0.011842376772777687, -0.011792380264165344, -0.011742383726072494, -0.011692387158623684, -0.011642390561943907, +-0.011592393936157710, -0.011542397281390971, -0.011492400597768239, -0.011442403885414506, -0.011392407144454319, -0.011342410375013557, -0.011292413577216770, -0.011242416751188949, +-0.011192419897054643, -0.011142423014939730, -0.011092426104968760, -0.011042429167266726, -0.010992432201958174, -0.010942435209168985, -0.010892438189023709, -0.010842441141646892, +-0.010792444067164416, -0.010742446965700833, -0.010692449837381129, -0.010642452682329858, -0.010592455500672900, -0.010542458292534803, -0.010492461058040558, -0.010442463797314719, +-0.010392466510483164, -0.010342469197670442, -0.010292471859001548, -0.010242474494601028, -0.010192477104594769, -0.010142479689107316, -0.010092482248263663, -0.010042484782188360, +-0.009992487291007291, -0.009942489774845003, -0.009892492233826490, -0.009842494668076303, -0.009792497077720322, -0.009742499462883100, -0.009692501823689184, -0.009642504160264459, +-0.009592506472733473, -0.009542508761221220, -0.009492511025852251, -0.009442513266752450, -0.009392515484046364, -0.009342517677858991, -0.009292519848314879, -0.009242521995539911, +-0.009192524119658639, -0.009142526220796057, -0.009092528299076714, -0.009042530354626495, -0.008992532387569949, -0.008942534398032073, -0.008892536386137417, -0.008842538352011865, +-0.008792540295779966, -0.008742542217566273, -0.008692544117496667, -0.008642545995695701, -0.008592547852288371, -0.008542549687399228, -0.008492551501154154, -0.008442553293677700, +-0.008392555065094865, -0.008342556815530196, -0.008292558545109581, -0.008242560253957568, -0.008192561942199155, -0.008142563609958894, -0.008092565257362667, -0.008042566884535028, +-0.007992568491600970, -0.007942570078685048, -0.007892571645913145, -0.007842573193409811, -0.007792574721299603, -0.007742576229708400, -0.007692577718760757, -0.007642579188581669, +-0.007592580639295690, -0.007542582071028704, -0.007492583483905262, -0.007442584878050361, -0.007392586253588554, -0.007342587610645725, -0.007292588949346428, -0.007242590269815658, +-0.007192591572177969, -0.007142592856559244, -0.007092594123084038, -0.007042595371877345, -0.006992596603063722, -0.006942597816769049, -0.006892599013117883, -0.006842600192234775, +-0.006792601354245611, -0.006742602499274943, -0.006692603627447769, -0.006642604738888642, -0.006592605833723447, -0.006542606912076737, -0.006492607974073510, -0.006442609019838320, +-0.006392610049497051, -0.006342611063174256, -0.006292612060994934, -0.006242613043083638, -0.006192614009566253, -0.006142614960567333, -0.006092615896211876, -0.006042616816624435, +-0.005992617721930896, -0.005942618612255812, -0.005892619487724183, -0.005842620348460561, -0.005792621194590831, -0.005742622026239549, -0.005692622843531267, -0.005642623646591872, +-0.005592624435545919, -0.005542625210518404, -0.005492625971633882, -0.005442626719018240, -0.005392627452796030, -0.005342628173092252, -0.005292628880031459, -0.005242629573739539, +-0.005192630254341044, -0.005142630921960973, -0.005092631576723882, -0.005042632218755655, -0.004992632848180848, -0.004942633465124459, -0.004892634069711042, -0.004842634662066484, +-0.004792635242315340, -0.004742635810582162, -0.004692636366992840, -0.004642636911671927, -0.004592637444744421, -0.004542637966334878, -0.004492638476569184, -0.004442638975571894, +-0.004392639463468006, -0.004342639940382076, -0.004292640406439990, -0.004242640861766302, -0.004192641306486013, -0.004142641740723677, -0.004092642164605180, -0.004042642578255077, +-0.003992642981798369, -0.003942643375359608, -0.003892643759064683, -0.003842644133038149, -0.003792644497404561, -0.003742644852289805, -0.003692645197818437, -0.003642645534115456, +-0.003592645861305418, -0.003542646179514209, -0.003492646488866384, -0.003442646789486943, -0.003392647081500441, -0.003342647365032765, -0.003292647640208471, -0.003242647907152558, +-0.003192648165989581, -0.003142648416845428, -0.003092648659844654, -0.003042648895112258, -0.002992649122772795, -0.002942649342952154, -0.002892649555774890, -0.002842649761366002, +-0.002792649959850045, -0.002742650151352907, -0.002692650335999144, -0.002642650513913312, -0.002592650685221296, -0.002542650850047655, -0.002492651008517386, -0.002442651160755045, +-0.002392651306886521, -0.002342651447036368, -0.002292651581329587, -0.002242651709890733, -0.002192651832845693, -0.002142651950319024, -0.002092652062435725, -0.002042652169320352, +-0.001992652271098793, -0.001942652367895603, -0.001892652459835782, -0.001842652547043885, -0.001792652629645802, -0.001742652707766087, -0.001692652781529296, -0.001642652851061317, +-0.001592652916486706, -0.001542652977930462, -0.001492653035517143, -0.001442653089372634, -0.001392653139621493, -0.001342653186388719, -0.001292653229798869, -0.001242653269977829, +-0.001192653307050155, -0.001142653341140849, -0.001092653372374465, -0.001042653400876892, -0.000992653426772685, -0.000942653450186845, -0.000892653471243927, -0.000842653490069820, +-0.000792653506789079, -0.000742653521526259, -0.000692653534407251, -0.000642653545556608, -0.000592653555099331, -0.000542653563159977, -0.000492653569864433, -0.000442653575337254, +-0.000392653579703442, -0.000342653583087552, -0.000292653585615472, -0.000242653587411758, -0.000192653588601410, -0.000142653589308984, -0.000092653589660368, -0.000042653589780118, +0.000007346410206766, 0.000057346410175728, 0.000107346410000880, 0.000157346409557666, 0.000207346408721530, 0.000257346407366583, 0.000307346405368271, 0.000357346402601593, +0.000407346398941993, 0.000457346394263583, 0.000507346388441806, 0.000557346381351664, 0.000607346372868600, 0.000657346362866726, 0.000707346351221486, 0.000757346337807880, +0.000807346322501352, 0.000857346305176015, 0.000907346285707312, 0.000957346263970243, 0.001007346239840252, 0.001057346213191452, 0.001107346183899286, 0.001157346151838755, +0.001207346116885302, 0.001257346078913040, 0.001307346037797413, 0.001357345993413865, 0.001407345945636508, 0.001457345894340786, 0.001507345839401699, 0.001557345780694692, +0.001607345718093876, 0.001657345651474696, 0.001707345580712151, 0.001757345505681687, 0.001807345426257415, 0.001857345342314780, 0.001907345253728781, 0.001957345160374863, +0.002007345062127138, 0.002057344958861051, 0.002107344850451600, 0.002157344736774233, 0.002207344617703058, 0.002257344493113523, 0.002307344362881071, 0.002357344226879813, +0.002407344084985194, 0.002457343937072216, 0.002507343783016322, 0.002557343622691624, 0.002607343455973567, 0.002657343282737152, 0.002707343102857823, 0.002757342916209691, +0.002807342722668203, 0.002857342522108357, 0.002907342314405600, 0.002957342099434042, 0.003007341877069129, 0.003057341647185862, 0.003107341409659684, 0.003157341164364709, +0.003207340911176381, 0.003257340649970145, 0.003307340380620113, 0.003357340103001730, 0.003407339816989997, 0.003457339522460358, 0.003507339219286927, 0.003557338907345147, +0.003607338586510021, 0.003657338256656991, 0.003707337917660173, 0.003757337569395009, 0.003807337211736501, 0.003857336844560094, 0.003907336467739902, 0.003957336081151368, +0.004007335684669494, 0.004057335278169725, 0.004107334861526173, 0.004157334434614284, 0.004207333997309060, 0.004257333549485944, 0.004307333091019050, 0.004357332621783824, +0.004407332141655711, 0.004457331650508822, 0.004507331148218605, 0.004557330634660059, 0.004607330109708632, 0.004657329573238434, 0.004707329025124913, 0.004757328465243070, +0.004807327893468349, 0.004857327309674865, 0.004907326713738062, 0.004957326105532942, 0.005007325484934952, 0.005057324851818203, 0.005107324206058143, 0.005157323547529772, +0.005207322876108536, 0.005257322191668548, 0.005307321494085256, 0.005357320783234103, 0.005407320058989205, 0.005457319321226006, 0.005507318569819510, 0.005557317804645160, +0.005607317025577073, 0.005657316232490692, 0.005707315425261022, 0.005757314603763507, 0.005807313767872260, 0.005857312917462730, 0.005907312052409917, 0.005957311172589269, +0.006007310277874899, 0.006057309368142251, 0.006107308443266332, 0.006157307503122585, 0.006207306547585126, 0.006257305576529399, 0.006307304589830853, 0.006357303587363602, +0.006407302569003091, 0.006457301534624325, 0.006507300484102748, 0.006557299417312476, 0.006607298334128956, 0.006657297234427190, 0.006707296118082624, 0.006757294984969375, +0.006807293834962888, 0.006857292667938166, 0.006907291483770657, 0.006957290282334475, 0.007007289063505067, 0.007057287827157437, 0.007107286573167031, 0.007157285301407965, +0.007207284011755685, 0.007257282704085639, 0.007307281378271943, 0.007357280034190043, 0.007407278671714943, 0.007457277290722091, 0.007507275891085601, 0.007557274472680921, +0.007607273035383055, 0.007657271579067451, 0.007707270103608224, 0.007757268608880821, 0.007807267094760247, 0.007857265561121950, 0.007907264007840044, 0.007957262434789978, +0.008007260841846756, 0.008057259228885828, 0.008107257595781304, 0.008157255942408639, 0.008207254268642833, 0.008257252574359336, 0.008307250859432264, 0.008357249123737063, +0.008407247367149184, 0.008457245589542743, 0.008507243790793187, 0.008557241970775523, 0.008607240129365198, 0.008657238266436327, 0.008707236381864362, 0.008757234475524305, +0.008807232547291606, 0.008857230597040383, 0.008907228624646083, 0.008957226629983710, 0.009007224612928716, 0.009057222573355216, 0.009107220511138658, 0.009157218426154051, +0.009207216318276841, 0.009257214187381147, 0.009307212033342416, 0.009357209856036100, 0.009407207655336316, 0.009457205431118511, 0.009507203183257693, 0.009557200911629312, +0.009607198616107484, 0.009657196296567659, 0.009707193952884843, 0.009757191584934488, 0.009807189192590708, 0.009857186775728957, 0.009907184334224238, 0.009957181867952003, +0.010007179376786367, 0.010057176860602784, 0.010107174319276260, 0.010157171752682244, 0.010207169160694854, 0.010257166543189540, 0.010307163900041756, 0.010357161231125615, +0.010407158536316574, 0.010457155815489635, 0.010507153068520252, 0.010557150295282541, 0.010607147495651954, 0.010657144669503498, 0.010707141816712626, 0.010757138937153455, +0.010807136030701436, 0.010857133097231577, 0.010907130136619330, 0.010957127148738812, 0.011007124133465478, 0.011057121090674332, 0.011107118020240829, 0.011157114922039087, +0.011207111795944556, 0.011257108641832247, 0.011307105459577610, 0.011357102249054764, 0.011407099010139164, 0.011457095742706260, 0.011507092446630172, 0.011557089121786353, +0.011607085768049813, 0.011657082385296001, 0.011707078973399039, 0.011757075532234380, 0.011807072061677032, 0.011857068561602449, 0.011907065031884750, 0.011957061472399387, +0.012007057883021371, 0.012057054263626155, 0.012107050614087858, 0.012157046934281936, 0.012207043224083397, 0.012257039483367692, 0.012307035712008946, 0.012357031909882609, +0.012407028076864139, 0.012457024212827652, 0.012507020317648606, 0.012557016391202009, 0.012607012433363315, 0.012657008444006645, 0.012707004423007455, 0.012757000370240754, +0.012806996285581995, 0.012856992168905302, 0.012906988020086128, 0.012956983838999486, 0.013006979625520826, 0.013056975379524275, 0.013106971100885283, 0.013156966789478865, +0.013206962445180475, 0.013256958067864233, 0.013306953657405597, 0.013356949213680020, 0.013406944736561626, 0.013456940225925871, 0.013506935681647764, 0.013556931103602763, +0.013606926491664990, 0.013656921845709900, 0.013706917165612507, 0.013756912451248264, 0.013806907702491296, 0.013856902919217059, 0.013906898101300564, 0.013956893248617269, +0.014006888361041296, 0.014056883438448102, 0.014106878480712700, 0.014156873487710546, 0.014206868459315763, 0.014256863395403810, 0.014306858295850142, 0.014356853160528885, +0.014406847989315495, 0.014456842782084983, 0.014506837538712810, 0.014556832259073098, 0.014606826943041308, 0.014656821590492449, 0.014706816201301980, 0.014756810775344026, +0.014806805312494044, 0.014856799812627051, 0.014906794275618501, 0.014956788701342523, 0.015006783089674571, 0.015056777440489662, 0.015106771753663255, 0.015156766029069473, +0.015206760266583777, 0.015256754466081180, 0.015306748627437141, 0.015356742750525785, 0.015406736835222574, 0.015456730881402963, 0.015506724888941083, 0.015556718857712390, +0.015606712787591900, 0.015656706678455069, 0.015706700530176032, 0.015756694342630242, 0.015806688115692715, 0.015856681849238913, 0.015906675543142960, 0.015956669197280320, +0.016006662811526007, 0.016056656385755482, 0.016106649919842873, 0.016156643413663636, 0.016206636867092790, 0.016256630280005797, 0.016306623652276787, 0.016356616983781214, +0.016406610274394547, 0.016456603523990906, 0.016506596732445759, 0.016556589899634117, 0.016606583025431446, 0.016656576109711874, 0.016706569152350862, 0.016756562153223426, +0.016806555112205031, 0.016856548029169801, 0.016906540903993204, 0.016956533736550251, 0.017006526526716411, 0.017056519274365810, 0.017106511979373910, 0.017156504641615729, +0.017206497260966732, 0.017256489837301048, 0.017306482370494140, 0.017356474860421470, 0.017406467306957166, 0.017456459709976696, 0.017506452069355076, 0.017556444384967770, +0.017606436656688911, 0.017656428884393959, 0.017706421067957934, 0.017756413207256301, 0.017806405302163191, 0.017856397352554065, 0.017906389358303951, 0.017956381319288305, +0.018006373235381259, 0.018056365106458284, 0.018106356932394395, 0.018156348713065058, 0.018206340448344405, 0.018256332138107900, 0.018306323782230564, 0.018356315380587865, +0.018406306933053930, 0.018456298439504231, 0.018506289899814229, 0.018556281313858058, 0.018606272681511184, 0.018656264002648627, 0.018706255277145856, 0.018756246504877002, +0.018806237685717531, 0.018856228819542468, 0.018906219906227276, 0.018956210945646090, 0.019006201937674376, 0.019056192882187156, 0.019106183779059899, 0.019156174628166739, +0.019206165429383144, 0.019256156182584132, 0.019306146887645176, 0.019356137544440408, 0.019406128152845297, 0.019456118712735310, 0.019506109223984578, 0.019556099686468577, +0.019606090100062326, 0.019656080464641294, 0.019706070780079618, 0.019756061046252764, 0.019806051263035755, 0.019856041430304065, 0.019906031547931826, 0.019956021615794507, +0.020006011633767137, 0.020056001601725180, 0.020105991519542774, 0.020155981387095390, 0.020205971204258055, 0.020255960970906234, 0.020305950686914067, 0.020355940352157022, +0.020405929966510569, 0.020455919529848852, 0.020505909042047330, 0.020555898502981042, 0.020605887912525447, 0.020655877270554689, 0.020705866576944239, 0.020755855831569123, +0.020805845034304809, 0.020855834185025440, 0.020905823283606486, 0.020955812329922975, 0.021005801323850375, 0.021055790265262827, 0.021105779154035803, 0.021155767990044334, +0.021205756773163886, 0.021255745503268607, 0.021305734180233959, 0.021355722803935422, 0.021405711374247134, 0.021455699891044566, 0.021505688354202749, 0.021555676763597157, +0.021605665119101929, 0.021655653420592537, 0.021705641667944010, 0.021755629861031824, 0.021805617999730121, 0.021855606083914372, 0.021905594113459607, 0.021955582088241301, +0.022005570008133593, 0.022055557873011965, 0.022105545682751439, 0.022155533437227495, 0.022205521136314271, 0.022255508779887245, 0.022305496367821448, 0.022355483899992354, +0.022405471376274109, 0.022455458796542180, 0.022505446160672050, 0.022555433468537861, 0.022605420720015090, 0.022655407914978765, 0.022705395053304368, 0.022755382134866033, +0.022805369159539249, 0.022855356127199036, 0.022905343037720880, 0.022955329890978923, 0.023005316686848642, 0.023055303425205068, 0.023105290105923677, 0.023155276728878620, +0.023205263293945372, 0.023255249800998964, 0.023305236249914874, 0.023355222640567250, 0.023405208972831573, 0.023455195246583314, 0.023505181461696622, 0.023555167618046980, +0.023605153715509416, 0.023655139753959414, 0.023705125733271118, 0.023755111653320005, 0.023805097513981115, 0.023855083315129925, 0.023905069056640586, 0.023955054738388569, +0.024005040360248919, 0.024055025922097111, 0.024105011423807294, 0.024154996865254946, 0.024204982246315107, 0.024254967566863260, 0.024304952826773547, 0.024354938025921452, +0.024404923164182458, 0.024454908241430710, 0.024504893257541693, 0.024554878212390441, 0.024604863105852439, 0.024654847937801833, 0.024704832708114109, 0.024754817416664302, +0.024804802063327899, 0.024854786647979042, 0.024904771170493223, 0.024954755630745472, 0.025004740028611278, 0.025054724363964789, 0.025104708636681492, 0.025154692846636420, +0.025204676993705061, 0.025254661077761566, 0.025304645098681418, 0.025354629056339659, 0.025404612950611770, 0.025454596781371904, 0.025504580548495547, 0.025554564251858179, +0.025604547891333960, 0.025654531466798372, 0.025704514978126453, 0.025754498425193690, 0.025804481807874240, 0.025854465126043585, 0.025904448379576766, 0.025954431568349270, +0.026004414692235252, 0.026054397751110195, 0.026104380744849144, 0.026154363673327588, 0.026204346536419676, 0.026254329334000900, 0.026304312065946300, 0.026354294732131363, +0.026404277332430247, 0.026454259866718434, 0.026504242334871420, 0.026554224736763353, 0.026604207072269726, 0.026654189341265580, 0.026704171543626403, 0.026754153679226355, +0.026804135747940924, 0.026854117749645152, 0.026904099684214530, 0.026954081551523217, 0.027004063351446696, 0.027054045083860022, 0.027104026748638675, 0.027154008345656819, +0.027203989874789940, 0.027253971335913087, 0.027303952728901751, 0.027353934053630090, 0.027403915309973593, 0.027453896497807748, 0.027503877617006723, 0.027553858667446002, +0.027603839649000633, 0.027653820561546111, 0.027703801404956593, 0.027753782179107570, 0.027803762883874095, 0.027853743519131655, 0.027903724084754410, 0.027953704580617859, +0.028003685006597043, 0.028053665362567461, 0.028103645648403269, 0.028153625863979966, 0.028203606009172596, 0.028253586083856655, 0.028303566087906306, 0.028353546021197041, +0.028403525883604355, 0.028453505675002412, 0.028503485395266703, 0.028553465044272280, 0.028603444621894639, 0.028653424128007941, 0.028703403562487687, 0.028753382925208921, +0.028803362216047141, 0.028853341434876514, 0.028903320581572533, 0.028953299656010248, 0.029003278658065158, 0.029053257587611431, 0.029103236444524557, 0.029153215228679592, +0.029203193939952035, 0.029253172578216049, 0.029303151143347129, 0.029353129635220333, 0.029403108053711158, 0.029453086398693769, 0.029503064670043662, 0.029553042867636336, +0.029603020991345961, 0.029652999041048032, 0.029702977016617609, 0.029752954917930185, 0.029802932744859928, 0.029852910497282344, 0.029902888175072480, 0.029952865778105839, +0.030002843306256591, 0.030052820759400235, 0.030102798137411828, 0.030152775440166868, 0.030202752667539527, 0.030252729819405303, 0.030302706895639252, 0.030352683896116880, +0.030402660820712357, 0.030452637669301178, 0.030502614441758853, 0.030552591137959544, 0.030602567757778761, 0.030652544301091555, 0.030702520767773432, 0.030752497157698566, +0.030802473470742456, 0.030852449706780163, 0.030902425865687186, 0.030952401947337706, 0.031002377951607218, 0.031052353878370784, 0.031102329727503913, 0.031152305498880772, +0.031202281192376866, 0.031252256807867258, 0.031302232345227450, 0.031352207804331622, 0.031402183185055270, 0.031452158487273903, 0.031502133710861698, 0.031552108855694164, +0.031602083921646353, 0.031652058908593773, 0.031702033816410603, 0.031752008644972352, 0.031801983394154076, 0.031851958063831287, 0.031901932653878161, 0.031951907164170200, +0.032001881594582476, 0.032051855944990486, 0.032101830215268419, 0.032151804405291771, 0.032201778514935615, 0.032251752544075453, 0.032301726492585468, 0.032351700360341164, +0.032401674147217611, 0.032451647853090321, 0.032501621477833462, 0.032551595021322551, 0.032601568483433097, 0.032651541864039277, 0.032701515163016601, 0.032751488380240140, +0.032801461515585398, 0.032851434568926564, 0.032901407540139142, 0.032951380429098197, 0.033001353235679251, 0.033051325959756475, 0.033101298601205378, 0.033151271159901040, +0.033201243635718969, 0.033251216028533349, 0.033301188338219684, 0.033351160564653044, 0.033401132707708954, 0.033451104767261583, 0.033501076743186455, 0.033551048635359078, +0.033601020443653630, 0.033650992167945634, 0.033700963808110163, 0.033750935364022717, 0.033800906835557497, 0.033850878222590003, 0.033900849524995322, 0.033950820742648956, +0.034000791875425096, 0.034050762923199251, 0.034100733885846501, 0.034150704763242362, 0.034200675555261018, 0.034250646261777984, 0.034300616882668333, 0.034350587417807589, +0.034400557867069928, 0.034450528230330874, 0.034500498507465942, 0.034550468698349317, 0.034600438802856522, 0.034650408820862635, 0.034700378752243168, 0.034750348596872302, +0.034800318354625576, 0.034850288025378047, 0.034900257609005246, 0.034950227105381357, 0.035000196514381895, 0.035050165835881948, 0.035100135069757024, 0.035150104215881321, +0.035200073274130363, 0.035250042244379214, 0.035300011126503404, 0.035349979920377125, 0.035399948625875900, 0.035449917242875238, 0.035499885771249351, 0.035549854210873741, +0.035599822561623494, 0.035649790823374140, 0.035699758995999864, 0.035749727079376188, 0.035799695073378199, 0.035849662977881412, 0.035899630792760026, 0.035949598517889557, +0.035999566153145098, 0.036049533698402164, 0.036099501153534955, 0.036149468518418992, 0.036199435792929363, 0.036249402976941583, 0.036299370070329851, 0.036349337072969695, +0.036399303984736196, 0.036449270805504877, 0.036499237535149942, 0.036549204173546915, 0.036599170720571318, 0.036649137176097350, 0.036699103540000541, 0.036749069812155970, +0.036799035992439173, 0.036849002080724343, 0.036898968076887001, 0.036948933980802241, 0.036998899792345594, 0.037048865511391249, 0.037098831137814745, 0.037148796671491159, +0.037198762112296030, 0.037248727460103548, 0.037298692714789250, 0.037348657876228215, 0.037398622944295981, 0.037448587918866752, 0.037498552799816044, 0.037548517587019402, +0.037598482280351023, 0.037648446879686437, 0.037698411384900737, 0.037748375795869447, 0.037798340112466779, 0.037848304334568261, 0.037898268462048981, 0.037948232494784469, +0.037998196432648935, 0.038048160275517912, 0.038098124023266490, 0.038148087675770194, 0.038198051232903242, 0.038248014694541158, 0.038297978060559040, 0.038347941330832420, +0.038397904505235503, 0.038447867583643824, 0.038497830565932915, 0.038547793451976994, 0.038597756241651585, 0.038647718934831786, 0.038697681531393135, 0.038747644031209838, +0.038797606434157424, 0.038847568740110999, 0.038897530948946095, 0.038947493060536922, 0.038997455074759012, 0.039047416991487470, 0.039097378810597820, 0.039147340531964288, +0.039197302155462403, 0.039247263680967259, 0.039297225108354407, 0.039347186437498044, 0.039397147668273715, 0.039447108800556512, 0.039497069834221986, 0.039547030769144342, +0.039596991605199118, 0.039646952342261864, 0.039696912980206778, 0.039746873518909417, 0.039796833958244869, 0.039846794298088677, 0.039896754538315059, 0.039946714678799553, +0.039996674719417265, 0.040046634660043733, 0.040096594500553161, 0.040146554240821114, 0.040196513880722679, 0.040246473420133398, 0.040296432858927492, 0.040346392196980503, +0.040396351434167539, 0.040446310570364137, 0.040496269605444515, 0.040546228539284218, 0.040596187371758789, 0.040646146102742454, 0.040696104732110758, 0.040746063259738792, +0.040796021685502115, 0.040845980009274939, 0.040895938230932814, 0.040945896350350841, 0.040995854367404570, 0.041045812281968228, 0.041095770093917343, 0.041145727803127044, +0.041195685409472861, 0.041245642912829027, 0.041295600313071078, 0.041345557610074135, 0.041395514803713743, 0.041445471893864112, 0.041495428880400809, 0.041545385763199376, +0.041595342542134033, 0.041645299217080337, 0.041695255787913388, 0.041745212254508744, 0.041795168616740631, 0.041845124874484593, 0.041895081027615744, 0.041945037076009634, +0.041994993019540489, 0.042044948858083860, 0.042094904591514860, 0.042144860219709042, 0.042194815742540630, 0.042244771159885175, 0.042294726471617798, 0.042344681677614043, +0.042394636777748143, 0.042444591771895655, 0.042494546659932124, 0.042544501441731788, 0.042594456117170200, 0.042644410686122465, 0.042694365148464149, 0.042744319504069483, +0.042794273752814013, 0.042844227894572859, 0.042894181929221578, 0.042944135856634397, 0.042994089676686879, 0.043044043389254140, 0.043093996994211729, 0.043143950491433887, +0.043193903880796164, 0.043243857162173688, 0.043293810335442010, 0.043343763400475362, 0.043393716357149302, 0.043443669205338958, 0.043493621944919882, 0.043543574575766304, +0.043593527097753798, 0.043643479510757907, 0.043693431814652885, 0.043743384009314275, 0.043793336094617205, 0.043843288070437240, 0.043893239936648613, 0.043943191693126889, +0.043993143339747180, 0.044043094876385060, 0.044093046302914753, 0.044142997619211838, 0.044192948825151422, 0.044242899920609084, 0.044292850905459050, 0.044342801779576890, +0.044392752542837727, 0.044442703195117124, 0.044492653736289314, 0.044542604166229877, 0.044592554484814369, 0.044642504691917037, 0.044692454787413440, 0.044742404771178704, +0.044792354643088401, 0.044842304403016765, 0.044892254050839374, 0.044942203586431341, 0.044992153009668252, 0.045042102320424326, 0.045092051518575156, 0.045142000603995848, +0.045191949576561988, 0.045241898436147801, 0.045291847182628880, 0.045341795815880333, 0.045391744335777744, 0.045441692742195346, 0.045491641035008724, 0.045541589214093438, +0.045591537279323732, 0.045641485230575186, 0.045691433067722928, 0.045741380790642536, 0.045791328399208242, 0.045841275893295626, 0.045891223272779821, 0.045941170537536401, +0.045991117687439617, 0.046041064722365035, 0.046091011642187790, 0.046140958446783460, 0.046190905136026292, 0.046240851709791857, 0.046290798167955297, 0.046340744510392183, +0.046390690736976763, 0.046440636847584621, 0.046490582842090886, 0.046540528720371135, 0.046590474482299617, 0.046640420127751915, 0.046690365656603609, 0.046740311068728939, +0.046790256364003496, 0.046840201542302409, 0.046890146603501263, 0.046940091547474312, 0.046990036374097127, 0.047039981083244850, 0.047089925674793066, 0.047139870148616023, +0.047189814504589311, 0.047239758742588053, 0.047289702862487848, 0.047339646864162942, 0.047389590747488913, 0.047439534512340918, 0.047489478158594521, 0.047539421686123989, +0.047589365094804902, 0.047639308384512843, 0.047689251555122075, 0.047739194606508176, 0.047789137538546286, 0.047839080351112000, 0.047889023044079569, 0.047938965617324580, +0.047988908070722182, 0.048038850404147952, 0.048088792617476152, 0.048138734710582373, 0.048188676683341758, 0.048238618535629892, 0.048288560267321035, 0.048338501878290779, +0.048388443368414268, 0.048438384737567092, 0.048488325985623512, 0.048538267112459121, 0.048588208117949498, 0.048638149001968917, 0.048688089764392962, 0.048738030405096777, +0.048787970923955967, 0.048837911320844786, 0.048887851595638819, 0.048937791748213229, 0.048987731778443601, 0.049037671686204203, 0.049087611471370626, 0.049137551133818021, +0.049187490673421978, 0.049237430090056766, 0.049287369383597977, 0.049337308553920767, 0.049387247600900727, 0.049437186524412126, 0.049487125324330562, 0.049537064000531178, +0.049587002552889586, 0.049636940981280041, 0.049686879285578141, 0.049736817465659486, 0.049786755521398343, 0.049836693452670312, 0.049886631259350549, 0.049936568941314652, +0.049986506498436889, 0.050036443930592860, 0.050086381237657719, 0.050136318419507067, 0.050186255476015185, 0.050236192407057650, 0.050286129212509648, 0.050336065892246755, +0.050386002446143260, 0.050435938874074757, 0.050485875175916406, 0.050535811351543815, 0.050585747400831250, 0.050635683323654312, 0.050685619119888614, 0.050735554789408423, +0.050785490332089352, 0.050835425747806542, 0.050885361036435622, 0.050935296197850852, 0.050985231231927844, 0.051035166138541754, 0.051085100917568189, 0.051135035568881437, +0.051184970092357090, 0.051234904487870318, 0.051284838755296734, 0.051334772894510605, 0.051384706905387545, 0.051434640787802716, 0.051484574541631731, 0.051534508166748864, +0.051584441663029730, 0.051634375030349934, 0.051684308268583758, 0.051734241377606807, 0.051784174357294252, 0.051834107207521712, 0.051884039928163456, 0.051933972519095095, +0.051983904980191807, 0.052033837311329205, 0.052083769512381563, 0.052133701583224494, 0.052183633523733175, 0.052233565333783212, 0.052283497013248900, 0.052333428562005839, +0.052383359979929205, 0.052433291266894617, 0.052483222422776359, 0.052533153447450041, 0.052583084340791286, 0.052633015102674381, 0.052682945732974933, 0.052732876231568117, +0.052782806598329561, 0.052832736833133540, 0.052882666935855679, 0.052932596906371150, 0.052982526744555572, 0.053032456450283240, 0.053082386023429760, 0.053132315463870317, +0.053182244771480529, 0.053232173946134685, 0.053282102987708406, 0.053332031896076867, 0.053381960671115697, 0.053431889312699175, 0.053481817820702937, 0.053531746195002151, +0.053581674435472446, 0.053631602541988108, 0.053681530514424765, 0.053731458352658037, 0.053781386056562221, 0.053831313626012942, 0.053881241060885376, 0.053931168361055153, +0.053981095526396565, 0.054031022556785241, 0.054080949452096357, 0.054130876212205546, 0.054180802836987098, 0.054230729326316639, 0.054280655680069366, 0.054330581898120893, +0.054380507980345522, 0.054430433926618879, 0.054480359736816149, 0.054530285410812972, 0.054580210948483629, 0.054630136349703762, 0.054680061614348997, 0.054729986742293638, +0.054779911733413310, 0.054829836587583204, 0.054879761304678948, 0.054929685884574850, 0.054979610327146530, 0.055029534632269186, 0.055079458799818452, 0.055129382829668623, +0.055179306721695340, 0.055229230475773793, 0.055279154091779609, 0.055329077569587097, 0.055379000909071892, 0.055428924110109190, 0.055478847172574612, 0.055528770096342474, +0.055578692881288416, 0.055628615527288067, 0.055678538034215734, 0.055728460401947059, 0.055778382630357233, 0.055828304719321889, 0.055878226668715343, 0.055928148478413230, +0.055978070148290746, 0.056027991678223532, 0.056077913068085891, 0.056127834317753471, 0.056177755427101468, 0.056227676396005517, 0.056277597224339927, 0.056327517911980346, +0.056377438458801978, 0.056427358864680449, 0.056477279129490084, 0.056527199253106515, 0.056577119235404955, 0.056627039076261036, 0.056676958775549076, 0.056726878333144722, +0.056776797748923614, 0.056826717022760063, 0.056876636154529731, 0.056926555144107799, 0.056976473991369923, 0.057026392696190427, 0.057076311258444944, 0.057126229678008678, +0.057176147954757291, 0.057226066088565085, 0.057275984079307708, 0.057325901926860379, 0.057375819631098737, 0.057425737191897107, 0.057475654609131129, 0.057525571882676013, +0.057575489012407409, 0.057625405998199646, 0.057675322839928364, 0.057725239537469220, 0.057775156090696535, 0.057825072499485958, 0.057874988763712699, 0.057924904883252408, +0.057974820857979420, 0.058024736687769370, 0.058074652372497489, 0.058124567912039411, 0.058174483306269474, 0.058224398555063332, 0.058274313658296190, 0.058324228615843708, +0.058374143427580211, 0.058424058093381352, 0.058473972613122351, 0.058523886986678861, 0.058573801213925213, 0.058623715294737061, 0.058673629228990061, 0.058723543016558549, +0.058773456657318174, 0.058823370151144166, 0.058873283497912168, 0.058923196697496523, 0.058973109749772878, 0.059023022654616467, 0.059072935411902942, 0.059122848021506635, +0.059172760483303208, 0.059222672797167877, 0.059272584962976306, 0.059322496980602830, 0.059372408849923120, 0.059422320570812377, 0.059472232143146279, 0.059522143566799163, +0.059572054841646682, 0.059621965967564507, 0.059671876944426980, 0.059721787772109756, 0.059771698450488062, 0.059821608979437564, 0.059871519358832608, 0.059921429588548847, +0.059971339668461514, 0.060021249598446270, 0.060071159378377467, 0.060121069008130759, 0.060170978487581385, 0.060220887816605000, 0.060270796995075961, 0.060320706022869923, +0.060370614899862118, 0.060420523625928230, 0.060470432200942580, 0.060520340624780851, 0.060570248897318275, 0.060620157018430515, 0.060670064987991920, 0.060719972805878167, +0.060769880471964917, 0.060819787986126528, 0.060869695348238669, 0.060919602558176571, 0.060969509615815910, 0.061019416521031038, 0.061069323273697615, 0.061119229873690888, +0.061169136320886532, 0.061219042615158883, 0.061268948756383640, 0.061318854744436012, 0.061368760579191703, 0.061418666260525043, 0.061468571788311714, 0.061518477162426963, +0.061568382382746457, 0.061618287449144556, 0.061668192361496933, 0.061718097119679273, 0.061768001723565925, 0.061817906173032580, 0.061867810467954462, 0.061917714608207261, +0.061967618593665334, 0.062017522424204365, 0.062067426099699584, 0.062117329620026682, 0.062167232985060009, 0.062217136194675254, 0.062267039248747665, 0.062316942147152915, +0.062366844889765370, 0.062416747476460713, 0.062466649907114188, 0.062516552181601473, 0.062566454299796945, 0.062616356261576273, 0.062666258066815167, 0.062716159715387965, +0.062766061207170362, 0.062815962542037598, 0.062865863719865384, 0.062915764740528068, 0.062965665603901336, 0.063015566309860438, 0.063065466858281058, 0.063115367249037588, +0.063165267482005683, 0.063215167557060623, 0.063265067474078077, 0.063314967232932423, 0.063364866833499345, 0.063414766275654108, 0.063464665559272396, 0.063514564684228586, +0.063564463650398348, 0.063614362457656962, 0.063664261105880110, 0.063714159594942157, 0.063764057924718814, 0.063813956095085764, 0.063863854105917384, 0.063913751957089357, +0.063963649648476964, 0.064013547179955888, 0.064063444551400492, 0.064113341762686502, 0.064163238813689141, 0.064213135704284136, 0.064263032434345849, 0.064312929003749963, +0.064362825412371774, 0.064412721660086963, 0.064462617746769896, 0.064512513672296296, 0.064562409436541401, 0.064612305039380924, 0.064662200480689255, 0.064712095760342078, +0.064761990878215103, 0.064811885834182709, 0.064861780628120591, 0.064911675259904031, 0.064961569729408725, 0.065011464036509051, 0.065061358181080720, 0.065111252162998998, +0.065161145982139582, 0.065211039638376850, 0.065260933131586527, 0.065310826461643878, 0.065360719628424602, 0.065410612631803075, 0.065460505471655023, 0.065510398147855711, +0.065560290660280837, 0.065610183008804793, 0.065660075193303302, 0.065709967213652062, 0.065759859069725465, 0.065809750761399208, 0.065859642288548584, 0.065909533651049290, +0.065959424848775733, 0.066009315881603609, 0.066059206749408184, 0.066109097452065196, 0.066158987989449011, 0.066208878361435367, 0.066258768567899529, 0.066308658608717208, +0.066358548483762783, 0.066408438192912006, 0.066458327736040129, 0.066508217113022877, 0.066558106323734628, 0.066607995368051121, 0.066657884245848079, 0.066707772956999867, +0.066757661501382237, 0.066807549878870442, 0.066857438089340221, 0.066907326132665965, 0.066957214008723384, 0.067007101717387774, 0.067056989258534844, 0.067106876632039014, +0.067156763837775982, 0.067206650875621041, 0.067256537745449915, 0.067306424447136998, 0.067356310980558026, 0.067406197345588281, 0.067456083542103487, 0.067505969569978022, +0.067555855429087652, 0.067605741119307644, 0.067655626640513708, 0.067705511992580278, 0.067755397175383064, 0.067805282188797805, 0.067855167032698893, 0.067905051706962066, +0.067954936211462605, 0.068004820546076247, 0.068054704710677399, 0.068104588705141786, 0.068154472529344701, 0.068204356183161882, 0.068254239666467723, 0.068304122979137960, +0.068354006121047903, 0.068403889092073275, 0.068453771892088469, 0.068503654520969237, 0.068553536978590873, 0.068603419264829102, 0.068653301379558357, 0.068703183322654335, +0.068753065093992816, 0.068802946693448178, 0.068852828120896187, 0.068902709376212123, 0.068952590459271726, 0.069002471369949400, 0.069052352108120912, 0.069102232673661529, +0.069152113066447016, 0.069201993286351779, 0.069251873333251557, 0.069301753207021644, 0.069351632907537791, 0.069401512434674420, 0.069451391788307268, 0.069501270968311643, +0.069551149974563270, 0.069601028806936582, 0.069650907465307332, 0.069700785949551244, 0.069750664259542752, 0.069800542395157608, 0.069850420356271092, 0.069900298142758985, +0.069950175754495678, 0.070000053191356937, 0.070049930453218057, 0.070099807539954803, 0.070149684451441582, 0.070199561187554146, 0.070249437748167817, 0.070299314133158333, +0.070349190342400114, 0.070399066375768926, 0.070448942233140077, 0.070498817914389306, 0.070548693419391045, 0.070598568748021062, 0.070648443900154650, 0.070698318875667562, +0.070748193674434245, 0.070798068296330452, 0.070847942741231920, 0.070897817009013084, 0.070947691099549709, 0.070997565012717118, 0.071047438748391048, 0.071097312306445934, +0.071147185686757541, 0.071197058889201192, 0.071246931913652625, 0.071296804759986301, 0.071346677428077959, 0.071396549917802921, 0.071446422229036952, 0.071496294361654486, +0.071546166315531276, 0.071596038090542657, 0.071645909686564396, 0.071695781103470899, 0.071745652341137958, 0.071795523399441341, 0.071845394278255453, 0.071895264977456089, +0.071945135496918555, 0.071995005836518633, 0.072044875996130756, 0.072094745975630689, 0.072144615774893756, 0.072194485393795721, 0.072244354832211033, 0.072294224090015458, +0.072344093167084317, 0.072393962063293391, 0.072443830778517113, 0.072493699312631263, 0.072543567665511163, 0.072593435837032594, 0.072643303827069974, 0.072693171635499113, +0.072743039262195761, 0.072792906707034366, 0.072842773969890709, 0.072892641050640111, 0.072942507949158353, 0.072992374665319881, 0.073042241199000477, 0.073092107550075461, +0.073141973718420628, 0.073191839703910425, 0.073241705506420604, 0.073291571125826530, 0.073341436562003981, 0.073391301814827378, 0.073441166884172529, 0.073491031769914769, +0.073540896471929865, 0.073590760990092277, 0.073640625324277800, 0.073690489474362186, 0.073740353440219911, 0.073790217221726753, 0.073840080818758050, 0.073889944231189594, +0.073939807458895820, 0.073989670501752536, 0.074039533359635090, 0.074089396032419236, 0.074139258519979448, 0.074189120822191520, 0.074238982938930789, 0.074288844870073048, +0.074338706615492745, 0.074388568175065686, 0.074438429548667195, 0.074488290736173079, 0.074538151737457786, 0.074588012552397123, 0.074637873180866426, 0.074687733622741490, +0.074737593877896774, 0.074787453946208074, 0.074837313827551169, 0.074887173521800562, 0.074937033028832006, 0.074986892348520864, 0.075036751480742944, 0.075086610425372693, +0.075136469182285934, 0.075186327751357987, 0.075236186132464661, 0.075286044325480431, 0.075335902330281090, 0.075385760146742004, 0.075435617774738950, 0.075485475214146405, +0.075535332464840177, 0.075585189526695615, 0.075635046399588526, 0.075684903083393387, 0.075734759577985977, 0.075784615883242118, 0.075834471999036271, 0.075884327925244244, +0.075934183661741400, 0.075984039208403534, 0.076033894565105134, 0.076083749731721995, 0.076133604708129479, 0.076183459494203395, 0.076233314089818233, 0.076283168494849771, +0.076333022709173387, 0.076382876732664903, 0.076432730565198767, 0.076482584206650814, 0.076532437656896407, 0.076582290915811341, 0.076632143983270104, 0.076681996859148505, +0.076731849543322364, 0.076781702035666144, 0.076831554336055680, 0.076881406444366321, 0.076931258360473903, 0.076981110084252888, 0.077030961615579097, 0.077080812954327907, +0.077130664100375113, 0.077180515053595231, 0.077230365813864055, 0.077280216381056963, 0.077330066755049789, 0.077379916935716983, 0.077429766922934393, 0.077479616716577396, +0.077529466316521786, 0.077579315722642067, 0.077629164934814074, 0.077679013952913156, 0.077728862776815150, 0.077778711406394543, 0.077828559841527159, 0.077878408082088818, +0.077928256127954010, 0.077978103978998570, 0.078027951635097861, 0.078077799096127720, 0.078127646361962635, 0.078177493432478443, 0.078227340307550505, 0.078277186987054673, +0.078327033470865420, 0.078376879758858584, 0.078426725850909554, 0.078476571746894153, 0.078526417446686869, 0.078576262950163553, 0.078626108257199581, 0.078675953367670776, +0.078725798281451639, 0.078775642998418008, 0.078825487518445717, 0.078875331841409269, 0.078925175967184485, 0.078975019895646759, 0.079024863626671937, 0.079074707160134511, +0.079124550495910301, 0.079174393633874726, 0.079224236573903609, 0.079274079315871465, 0.079323921859654117, 0.079373764205126957, 0.079423606352165846, 0.079473448300645261, +0.079523290050441064, 0.079573131601428634, 0.079622972953483820, 0.079672814106481138, 0.079722655060296410, 0.079772495814805500, 0.079822336369882896, 0.079872176725404462, +0.079922016881245575, 0.079971856837282099, 0.080021696593388522, 0.080071536149440722, 0.080121375505314077, 0.080171214660884421, 0.080221053616026300, 0.080270892370615549, +0.080320730924527559, 0.080370569277638179, 0.080420407429821941, 0.080470245380954694, 0.080520083130911815, 0.080569920679569182, 0.080619758026801311, 0.080669595172484024, +0.080719432116493212, 0.080769268858703364, 0.080819105398990357, 0.080868941737229569, 0.080918777873296877, 0.080968613807066811, 0.081018449538415194, 0.081068285067217458, +0.081118120393349452, 0.081167955516685708, 0.081217790437102061, 0.081267625154473944, 0.081317459668677219, 0.081367293979586391, 0.081417128087077323, 0.081466961991025447, +0.081516795691306598, 0.081566629187795323, 0.081616462480367483, 0.081666295568898470, 0.081716128453264175, 0.081765961133339116, 0.081815793608999141, 0.081865625880120127, +0.081915457946576620, 0.081965289808244454, 0.082015121464999077, 0.082064952916716324, 0.082114784163270754, 0.082164615204538216, 0.082214446040394157, 0.082264276670714412, +0.082314107095373540, 0.082363937314247390, 0.082413767327211410, 0.082463597134141448, 0.082513426734912049, 0.082563256129399076, 0.082613085317477977, 0.082662914299024601, +0.082712743073913492, 0.082762571642020527, 0.082812400003221584, 0.082862228157391193, 0.082912056104405232, 0.082961883844139134, 0.083011711376468761, 0.083061538701268672, +0.083111365818414731, 0.083161192727782385, 0.083211019429247496, 0.083260845922684623, 0.083310672207969616, 0.083360498284977949, 0.083410324153585472, 0.083460149813666729, +0.083509975265097625, 0.083559800507753579, 0.083609625541510482, 0.083659450366242866, 0.083709274981826634, 0.083759099388137651, 0.083808923585050488, 0.083858747572441009, +0.083908571350184646, 0.083958394918157320, 0.084008218276233559, 0.084058041424289243, 0.084107864362199830, 0.084157687089841199, 0.084207509607087908, 0.084257331913815833, +0.084307154009900437, 0.084356975895217609, 0.084406797569641881, 0.084456619033049171, 0.084506440285314899, 0.084556261326314983, 0.084606082155923967, 0.084655902774017744, +0.084705723180471773, 0.084755543375161918, 0.084805363357962779, 0.084855183128750220, 0.084905002687400158, 0.084954822033787139, 0.085004641167787068, 0.085054460089275391, +0.085104278798128014, 0.085154097294219480, 0.085203915577425723, 0.085253733647622162, 0.085303551504684716, 0.085353369148487956, 0.085403186578907761, 0.085453003795819604, +0.085502820799099377, 0.085552637588621666, 0.085602454164262348, 0.085652270525896898, 0.085702086673401220, 0.085751902606649888, 0.085801718325518792, 0.085851533829883836, +0.085901349119619608, 0.085951164194602012, 0.086000979054706495, 0.086050793699808989, 0.086100608129784040, 0.086150422344507580, 0.086200236343855055, 0.086250050127702399, +0.086299863695924156, 0.086349677048396259, 0.086399490184994182, 0.086449303105593817, 0.086499115810069735, 0.086548928298297884, 0.086598740570153709, 0.086648552625513117, +0.086698364464250707, 0.086748176086242385, 0.086797987491364054, 0.086847798679490329, 0.086897609650497101, 0.086947420404259845, 0.086997230940654480, 0.087047041259555605, +0.087096851360839111, 0.087146661244380502, 0.087196470910055682, 0.087246280357739237, 0.087296089587307099, 0.087345898598634730, 0.087395707391598049, 0.087445515966071669, +0.087495324321931495, 0.087545132459053016, 0.087594940377312150, 0.087644748076583484, 0.087694555556742937, 0.087744362817666469, 0.087794169859228624, 0.087843976681305377, +0.087893783283772176, 0.087943589666504965, 0.087993395829378332, 0.088043201772268209, 0.088093007495050085, 0.088142812997599893, 0.088192618279792218, 0.088242423341502993, +0.088292228182607721, 0.088342032802982307, 0.088391837202501378, 0.088441641381040853, 0.088491445338476221, 0.088541249074683429, 0.088591052589537062, 0.088640855882913067, +0.088690658954686932, 0.088740461804734591, 0.088790264432930657, 0.088840066839151063, 0.088889869023271742, 0.088939670985167307, 0.088989472724713692, 0.089039274241786398, +0.089089075536261358, 0.089138876608013187, 0.089188677456917817, 0.089238478082850764, 0.089288278485687961, 0.089338078665304008, 0.089387878621574865, 0.089437678354376021, +0.089487477863583437, 0.089537277149071698, 0.089587076210716779, 0.089636875048394168, 0.089686673661979813, 0.089736472051348326, 0.089786270216375655, 0.089836068156937759, +0.089885865872909240, 0.089935663364166071, 0.089985460630583741, 0.090035257672038196, 0.090085054488404065, 0.090134851079557293, 0.090184647445373398, 0.090234443585728324, +0.090284239500496716, 0.090334035189554490, 0.090383830652777178, 0.090433625890040739, 0.090483420901219788, 0.090533215686190285, 0.090583010244827747, 0.090632804577008119, +0.090682598682606044, 0.090732392561497469, 0.090782186213558352, 0.090831979638663338, 0.090881772836688371, 0.090931565807508968, 0.090981358551001090, 0.091031151067039379, +0.091080943355499794, 0.091130735416257838, 0.091180527249189500, 0.091230318854169393, 0.091280110231073491, 0.091329901379777312, 0.091379692300156815, 0.091429482992086655, +0.091479273455442781, 0.091529063690100734, 0.091578853695936463, 0.091628643472824622, 0.091678433020641159, 0.091728222339261617, 0.091778011428561970, 0.091827800288416847, +0.091877588918702222, 0.091927377319294068, 0.091977165490067042, 0.092026953430897090, 0.092076741141659743, 0.092126528622231002, 0.092176315872485495, 0.092226102892299197, +0.092275889681547638, 0.092325676240106805, 0.092375462567851327, 0.092425248664657206, 0.092475034530399958, 0.092524820164955557, 0.092574605568198673, 0.092624390740005266, +0.092674175680250895, 0.092723960388811519, 0.092773744865561808, 0.092823529110377723, 0.092873313123135265, 0.092923096903709076, 0.092972880451975159, 0.093022663767809030, +0.093072446851086690, 0.093122229701682782, 0.093172012319473307, 0.093221794704333796, 0.093271576856140237, 0.093321358774767299, 0.093371140460090971, 0.093420921911986782, +0.093470703130330735, 0.093520484114997485, 0.093570264865863020, 0.093620045382802899, 0.093669825665693110, 0.093719605714408322, 0.093769385528824509, 0.093819165108817673, +0.093868944454262485, 0.093918723565034931, 0.093968502441010571, 0.094018281082065405, 0.094068059488074077, 0.094117837658912615, 0.094167615594456550, 0.094217393294581897, +0.094267170759163313, 0.094316947988076813, 0.094366724981197928, 0.094416501738402672, 0.094466278259565731, 0.094516054544563091, 0.094565830593270311, 0.094615606405563407, +0.094665381981317034, 0.094715157320407209, 0.094764932422709933, 0.094814707288099875, 0.094864481916453067, 0.094914256307645037, 0.094964030461551815, 0.095013804378048086, +0.095063578057009823, 0.095113351498312640, 0.095163124701832497, 0.095212897667444119, 0.095262670395023494, 0.095312442884446180, 0.095362215135588208, 0.095411987148324259, +0.095461758922530338, 0.095511530458082028, 0.095561301754855332, 0.095611072812724934, 0.095660843631566850, 0.095710614211256664, 0.095760384551670394, 0.095810154652682708, +0.095859924514169637, 0.095909694136007195, 0.095959463518070082, 0.096009232660234298, 0.096059001562375443, 0.096108770224369519, 0.096158538646091238, 0.096208306827416601, +0.096258074768221208, 0.096307842468381061, 0.096357609927770871, 0.096407377146266654, 0.096457144123743982, 0.096506910860078912, 0.096556677355146114, 0.096606443608821618, +0.096656209620981023, 0.096705975391500332, 0.096755740920254268, 0.096805506207118863, 0.096855271251970118, 0.096905036054682758, 0.096954800615132813, 0.097004564933195855, +0.097054329008747942, 0.097104092841663756, 0.097153856431819341, 0.097203619779090283, 0.097253382883352613, 0.097303145744481054, 0.097352908362351623, 0.097402670736839919, +0.097452432867821986, 0.097502194755172536, 0.097551956398767584, 0.097601717798482743, 0.097651478954194057, 0.097701239865776224, 0.097751000533105301, 0.097800760956057317, +0.097850521134506985, 0.097900281068330347, 0.097950040757403017, 0.097999800201601012, 0.098049559400799083, 0.098099318354873233, 0.098149077063699103, 0.098198835527152722, +0.098248593745108803, 0.098298351717443402, 0.098348109444032134, 0.098397866924751012, 0.098447624159474806, 0.098497381148079516, 0.098547137890440784, 0.098596894386434653, +0.098646650635935834, 0.098696406638820400, 0.098746162394963949, 0.098795917904242525, 0.098845673166530867, 0.098895428181705033, 0.098945182949641067, 0.098994937470213692, +0.099044691743298982, 0.099094445768772535, 0.099144199546510423, 0.099193953076387370, 0.099243706358279435, 0.099293459392062244, 0.099343212177611828, 0.099392964714802953, +0.099442717003511663, 0.099492469043613571, 0.099542220834984763, 0.099591972377499949, 0.099641723671035201, 0.099691474715466161, 0.099741225510668857, 0.099790976056518058, +0.099840726352889819, 0.099890476399660214, 0.099940226196703966, 0.099989975743897147, 0.100039725041115400, 0.100089474088234780, 0.100139222885130020, 0.100188971431677220, +0.100238719727751990, 0.100288467773230390, 0.100338215567987190, 0.100387963111898450, 0.100437710404839800, 0.100487457446687310, 0.100537204237315740, 0.100586950776601170, +0.100636697064419200, 0.100686443100645950, 0.100736188885156130, 0.100785934417825860, 0.100835679698531190, 0.100885424727146870, 0.100935169503549000, 0.100984914027613200, +0.101034658299215550, 0.101084402318230820, 0.101134146084535080, 0.101183889598003980, 0.101233632858513600, 0.101283375865938690, 0.101333118620155340, 0.101382861121039200, +0.101432603368466340, 0.101482345362311540, 0.101532087102450870, 0.101581828588759980, 0.101631569821114970, 0.101681310799390580, 0.101731051523462930, 0.101780791993208080, +0.101830532208500820, 0.101880272169217220, 0.101930011875232930, 0.101979751326424060, 0.102029490522665380, 0.102079229463832970, 0.102128968149802480, 0.102178706580450020, +0.102228444755650350, 0.102278182675279560, 0.102327920339213310, 0.102377657747327720, 0.102427394899497540, 0.102477131795598860, 0.102526868435507360, 0.102576604819099120, +0.102626340946248940, 0.102676076816832900, 0.102725812430726660, 0.102775547787806340, 0.102825282887946720, 0.102875017731023880, 0.102924752316913930, 0.102974486645491680, +0.103024220716633200, 0.103073954530214160, 0.103123688086110680, 0.103173421384197550, 0.103223154424350860, 0.103272887206446280, 0.103322619730359930, 0.103372351995966570, +0.103422084003142360, 0.103471815751762920, 0.103521547241704380, 0.103571278472841550, 0.103621009445050510, 0.103670740158206940, 0.103720470612186980, 0.103770200806865390, +0.103819930742118300, 0.103869660417821820, 0.103919389833850750, 0.103969118990081210, 0.104018847886388880, 0.104068576522649850, 0.104118304898738950, 0.104168033014532290, +0.104217760869905540, 0.104267488464734840, 0.104317215798894970, 0.104366942872262060, 0.104416669684711790, 0.104466396236120290, 0.104516122526362370, 0.104565848555314130, +0.104615574322851280, 0.104665299828849920, 0.104715025073184880, 0.104764750055732270, 0.104814474776368240, 0.104864199234967560, 0.104913923431406400, 0.104963647365560420, +0.105013371037305780, 0.105063094446517260, 0.105112817593071010, 0.105162540476842700, 0.105212263097708490, 0.105261985455543190, 0.105311707550222910, 0.105361429381623360, +0.105411150949620700, 0.105460872254089700, 0.105510593294906530, 0.105560314071946880, 0.105610034585086870, 0.105659754834201360, 0.105709474819166440, 0.105759194539857840, +0.105808913996151690, 0.105858633187922810, 0.105908352115047360, 0.105958070777401460, 0.106007789174859950, 0.106057507307298970, 0.106107225174594210, 0.106156942776621840, +0.106206660113256660, 0.106256377184374850, 0.106306093989852080, 0.106355810529564510, 0.106405526803386980, 0.106455242811195640, 0.106504958552866190, 0.106554674028274790, +0.106604389237296250, 0.106654104179806750, 0.106703818855681980, 0.106753533264798110, 0.106803247407029960, 0.106852961282253690, 0.106902674890345470, 0.106952388231180110, +0.107002101304633790, 0.107051814110582210, 0.107101526648901530, 0.107151238919466610, 0.107200950922153580, 0.107250662656838180, 0.107300374123396550, 0.107350085321703550, +0.107399796251635340, 0.107449506913067640, 0.107499217305876610, 0.107548927429937100, 0.107598637285125270, 0.107648346871316840, 0.107698056188388000, 0.107747765236213570, +0.107797474014669730, 0.107847182523632640, 0.107896890762977150, 0.107946598732579450, 0.107996306432315240, 0.108046013862060700, 0.108095721021690700, 0.108145427911081380, +0.108195134530108500, 0.108244840878648220, 0.108294546956575410, 0.108344252763766220, 0.108393958300096390, 0.108443663565442120, 0.108493368559678250, 0.108543073282680950, +0.108592777734325980, 0.108642481914489500, 0.108692185823046360, 0.108741889459872770, 0.108791592824844460, 0.108841295917837600, 0.108890998738727070, 0.108940701287389030, +0.108990403563699680, 0.109040105567533890, 0.109089807298767840, 0.109139508757277250, 0.109189209942938350, 0.109238910855625980, 0.109288611495216320, 0.109338311861585140, +0.109388011954608620, 0.109437711774161630, 0.109487411320120370, 0.109537110592360570, 0.109586809590758440, 0.109636508315188840, 0.109686206765527970, 0.109735904941651590, +0.109785602843435890, 0.109835300470755720, 0.109884997823487320, 0.109934694901506850, 0.109984391704689220, 0.110034088232910610, 0.110083784486046780, 0.110133480463973910, +0.110183176166566920, 0.110232871593701970, 0.110282566745254860, 0.110332261621101770, 0.110381956221117570, 0.110431650545178490, 0.110481344593160280, 0.110531038364939160, +0.110580731860390000, 0.110630425079389000, 0.110680118021811950, 0.110729810687535040, 0.110779503076433170, 0.110829195188382520, 0.110878887023259350, 0.110928578580938510, +0.110978269861296220, 0.111027960864208260, 0.111077651589550840, 0.111127342037198850, 0.111177032207028500, 0.111226722098915570, 0.111276411712736280, 0.111326101048365520, +0.111375790105679500, 0.111425478884554010, 0.111475167384865260, 0.111524855606488160, 0.111574543549298910, 0.111624231213173300, 0.111673918597987570, 0.111723605703616590, +0.111773292529936600, 0.111822979076823810, 0.111872665344153150, 0.111922351331800810, 0.111972037039642610, 0.112021722467554740, 0.112071407615412120, 0.112121092483090990, +0.112170777070467130, 0.112220461377416770, 0.112270145403814820, 0.112319829149537490, 0.112369512614460600, 0.112419195798460370, 0.112468878701411700, 0.112518561323190840, +0.112568243663673570, 0.112617925722736140, 0.112667607500253450, 0.112717288996101740, 0.112766970210156820, 0.112816651142294900, 0.112866331792390930, 0.112916012160321110, +0.112965692245961720, 0.113015372049187640, 0.113065051569875130, 0.113114730807900010, 0.113164409763138490, 0.113214088435465500, 0.113263766824757310, 0.113313444930889680, +0.113363122753738890, 0.113412800293179850, 0.113462477549088810, 0.113512154521341570, 0.113561831209814390, 0.113611507614382200, 0.113661183734921230, 0.113710859571307300, +0.113760535123416680, 0.113810210391124250, 0.113859885374306320, 0.113909560072839100, 0.113959234486597550, 0.114008908615457910, 0.114058582459296010, 0.114108256017988070, +0.114157929291409070, 0.114207602279435240, 0.114257274981942410, 0.114306947398806830, 0.114356619529903430, 0.114406291375108490, 0.114455962934297830, 0.114505634207347690, +0.114555305194133030, 0.114604975894530100, 0.114654646308414740, 0.114704316435663200, 0.114753986276150440, 0.114803655829752700, 0.114853325096346270, 0.114902994075806080, +0.114952662768008400, 0.115002331172829070, 0.115051999290144360, 0.115101667119829190, 0.115151334661759880, 0.115201001915812220, 0.115250668881862490, 0.115300335559785650, +0.115350001949457980, 0.115399668050755300, 0.115449333863553880, 0.115498999387728700, 0.115548664623156020, 0.115598329569711670, 0.115647994227271940, 0.115697658595711790, +0.115747322674907490, 0.115796986464734880, 0.115846649965070240, 0.115896313175788550, 0.115945976096766060, 0.115995638727879090, 0.116045301069002570, 0.116094963120012790, +0.116144624880785610, 0.116194286351197320, 0.116243947531122850, 0.116293608420438520, 0.116343269019020190, 0.116392929326744110, 0.116442589343485270, 0.116492249069119950, +0.116541908503524010, 0.116591567646573750, 0.116641226498144110, 0.116690885058111410, 0.116740543326351500, 0.116790201302740690, 0.116839858987153920, 0.116889516379467500, +0.116939173479557730, 0.116988830287299590, 0.117038486802569370, 0.117088143025242940, 0.117137798955196590, 0.117187454592305300, 0.117237109936445370, 0.117286764987492670, +0.117336419745323510, 0.117386074209812840, 0.117435728380837000, 0.117485382258271830, 0.117535035841993650, 0.117584689131877430, 0.117634342127799500, 0.117683994829635710, +0.117733647237262370, 0.117783299350554480, 0.117832951169388330, 0.117882602693640260, 0.117932253923185220, 0.117981904857899560, 0.118031555497659130, 0.118081205842340260, +0.118130855891817930, 0.118180505645968460, 0.118230155104667740, 0.118279804267792050, 0.118329453135216420, 0.118379101706817160, 0.118428749982470150, 0.118478397962051690, +0.118528045645436800, 0.118577693032501800, 0.118627340123122570, 0.118676986917175420, 0.118726633414535380, 0.118776279615078740, 0.118825925518681850, 0.118875571125219700, +0.118925216434568620, 0.118974861446604500, 0.119024506161203680, 0.119074150578241140, 0.119123794697593220, 0.119173438519135820, 0.119223082042745270, 0.119272725268296580, +0.119322368195666060, 0.119372010824729630, 0.119421653155363610, 0.119471295187443020, 0.119520936920844190, 0.119570578355443020, 0.119620219491115840, 0.119669860327737670, +0.119719500865184850, 0.119769141103333280, 0.119818781042059300, 0.119868420681237920, 0.119918060020745500, 0.119967699060458360, 0.120017337800251530, 0.120066976240001360, +0.120116614379583750, 0.120166252218875040, 0.120215889757750270, 0.120265526996085770, 0.120315163933757450, 0.120364800570641670, 0.120414436906613440, 0.120464072941549120, +0.120513708675324610, 0.120563344107816270, 0.120612979238899150, 0.120662614068449550, 0.120712248596343440, 0.120761882822457150, 0.120811516746665700, 0.120861150368845450, +0.120910783688872790, 0.120960416706622710, 0.121010049421971590, 0.121059681834795350, 0.121109313944970350, 0.121158945752371610, 0.121208577256875530, 0.121258208458358000, +0.121307839356695370, 0.121357469951762720, 0.121407100243436390, 0.121456730231592310, 0.121506359916106840, 0.121555989296855040, 0.121605618373713250, 0.121655247146557440, +0.121704875615263930, 0.121754503779707800, 0.121804131639765400, 0.121853759195313130, 0.121903386446226020, 0.121953013392380430, 0.122002640033652310, 0.122052266369918030, +0.122101892401052650, 0.122151518126932530, 0.122201143547433620, 0.122250768662432300, 0.122300393471803600, 0.122350017975423940, 0.122399642173169220, 0.122449266064915840, +0.122498889650538840, 0.122548512929914630, 0.122598135902919140, 0.122647758569428740, 0.122697380929318510, 0.122747002982464830, 0.122796624728743640, 0.122846246168031330, +0.122895867300202950, 0.122945488125134920, 0.122995108642703600, 0.123044728852784070, 0.123094348755252730, 0.123143968349985510, 0.123193587636858810, 0.123243206615747700, +0.123292825286528560, 0.123342443649077370, 0.123392061703270510, 0.123441679448983060, 0.123491296886091410, 0.123540914014471510, 0.123590530833999760, 0.123640147344551250, +0.123689763546002390, 0.123739379438229100, 0.123788995021107810, 0.123838610294513580, 0.123888225258322840, 0.123937839912411970, 0.123987454256656070, 0.124037068290931520, +0.124086682015114300, 0.124136295429080820, 0.124185908532706170, 0.124235521325866740, 0.124285133808438500, 0.124334745980297880, 0.124384357841319950, 0.124433969391381110, +0.124483580630357370, 0.124533191558125100, 0.124582802174559430, 0.124632412479536740, 0.124682022472933020, 0.124731632154624680, 0.124781241524486830, 0.124830850582395870, +0.124880459328228240, 0.124930067761859000, 0.124979675883164600, 0.125029283692021010, 0.125078891188304650, 0.125128498371890630, 0.125178105242655350, 0.125227711800474820, +0.125277318045225430, 0.125326923976782330, 0.125376529595021910, 0.125426134899820160, 0.125475739891053510, 0.125525344568597070, 0.125574948932327290, 0.125624552982120140, +0.125674156717852010, 0.125723760139398070, 0.125773363246634740, 0.125822966039438430, 0.125872568517684270, 0.125922170681248670, 0.125971772530007660, 0.126021374063837680, +0.126070975282613800, 0.126120576186212470, 0.126170176774509730, 0.126219777047381960, 0.126269377004704310, 0.126318976646353250, 0.126368575972204720, 0.126418174982135200, +0.126467773676019770, 0.126517372053734950, 0.126566970115156690, 0.126616567860161430, 0.126666165288624320, 0.126715762400421790, 0.126765359195429860, 0.126814955673524990, +0.126864551834582260, 0.126914147678478170, 0.126963743205089160, 0.127013338414290330, 0.127062933305958160, 0.127112527879968660, 0.127162122136198260, 0.127211716074522140, +0.127261309694816720, 0.127310902996958020, 0.127360495980822520, 0.127410088646285340, 0.127459680993222910, 0.127509273021511300, 0.127558864731026960, 0.127608456121645010, +0.127658047193241890, 0.127707637945693670, 0.127757228378876820, 0.127806818492666420, 0.127856408286939010, 0.127905997761570990, 0.127955586916437550, 0.128005175751415150, +0.128054764266379790, 0.128104352461207970, 0.128153940335774850, 0.128203527889956840, 0.128253115123630020, 0.128302702036670880, 0.128352288628954540, 0.128401874900357450, +0.128451460850755680, 0.128501046480025720, 0.128550631788042690, 0.128600216774683060, 0.128649801439822910, 0.128699385783338700, 0.128748969805105580, 0.128798553505000050, +0.128848136882898560, 0.128897719938676270, 0.128947302672209720, 0.128996885083374900, 0.129046467172048290, 0.129096048938105080, 0.129145630381421740, 0.129195211501874350, +0.129244792299339360, 0.129294372773691930, 0.129343952924808600, 0.129393532752565380, 0.129443112256838740, 0.129492691437503920, 0.129542270294437320, 0.129591848827515090, +0.129641427036613660, 0.129691004921608230, 0.129740582482375270, 0.129790159718790880, 0.129839736630731510, 0.129889313218072370, 0.129938889480689930, 0.129988465418460740, +0.130038041031259930, 0.130087616318964010, 0.130137191281449040, 0.130186765918591550, 0.130236340230266700, 0.130285914216351000, 0.130335487876720500, 0.130385061211251760, +0.130434634219819880, 0.130484206902301450, 0.130533779258572490, 0.130583351288509510, 0.130632922991987730, 0.130682494368883630, 0.130732065419073310, 0.130781636142433240, +0.130831206538838670, 0.130880776608166080, 0.130930346350291970, 0.130979915765091550, 0.131029484852441370, 0.131079053612217440, 0.131128622044296340, 0.131178190148553250, +0.131227757924864690, 0.131277325373106710, 0.131326892493155850, 0.131376459284887340, 0.131426025748177690, 0.131475591882902950, 0.131525157688939690, 0.131574723166163090, +0.131624288314449690, 0.131673853133675550, 0.131723417623717250, 0.131772981784449930, 0.131822545615750190, 0.131872109117494500, 0.131921672289558090, 0.131971235131817520, +0.132020797644148870, 0.132070359826428650, 0.132119921678532090, 0.132169483200335720, 0.132219044391715640, 0.132268605252548410, 0.132318165782709220, 0.132367725982074610, +0.132417285850520680, 0.132466845387924000, 0.132516404594159750, 0.132565963469104490, 0.132615522012634300, 0.132665080224625780, 0.132714638104954100, 0.132764195653495810, +0.132813752870127500, 0.132863309754724350, 0.132912866307162950, 0.132962422527319350, 0.133011978415070150, 0.133061533970290580, 0.133111089192857160, 0.133160644082646020, +0.133210198639533710, 0.133259752863395450, 0.133309306754107820, 0.133358860311546920, 0.133408413535589330, 0.133457966426110240, 0.133507518982986240, 0.133557071206093450, +0.133606623095308410, 0.133656174650506360, 0.133705725871563900, 0.133755276758357110, 0.133804827310762600, 0.133854377528655530, 0.133903927411912570, 0.133953476960410180, +0.134003026174023680, 0.134052575052629630, 0.134102123596104130, 0.134151671804323750, 0.134201219677163780, 0.134250767214500740, 0.134300314416210760, 0.134349861282170470, +0.134399407812255070, 0.134448954006341160, 0.134498499864304870, 0.134548045386022750, 0.134597590571370110, 0.134647135420223470, 0.134696679932458980, 0.134746224107953260, +0.134795767946581520, 0.134845311448220350, 0.134894854612746360, 0.134944397440034780, 0.134993939929962230, 0.135043482082404800, 0.135093023897239120, 0.135142565374340440, +0.135192106513585350, 0.135241647314850000, 0.135291187778010940, 0.135340727902943490, 0.135390267689524220, 0.135439807137629290, 0.135489346247135290, 0.135538885017917470, +0.135588423449852450, 0.135637961542816350, 0.135687499296685780, 0.135737036711336050, 0.135786573786643720, 0.135836110522485400, 0.135885646918736340, 0.135935182975273180, +0.135984718691972070, 0.136034254068709590, 0.136083789105361040, 0.136133323801803010, 0.136182858157911670, 0.136232392173563640, 0.136281925848634190, 0.136331459182999910, +0.136380992176536990, 0.136430524829122020, 0.136480057140630300, 0.136529589110938460, 0.136579120739922620, 0.136628652027459440, 0.136678182973424180, 0.136727713577693450, +0.136777243840143450, 0.136826773760650780, 0.136876303339090730, 0.136925832575339940, 0.136975361469274970, 0.137024890020771200, 0.137074418229705170, 0.137123946095953130, +0.137173473619391640, 0.137223000799896020, 0.137272527637342910, 0.137322054131608470, 0.137371580282569350, 0.137421106090100830, 0.137470631554079570, 0.137520156674381690, +0.137569681450883880, 0.137619205883461440, 0.137668729971990980, 0.137718253716348660, 0.137767777116411190, 0.137817300172053820, 0.137866822883153190, 0.137916345249585960, +0.137965867271227420, 0.138015388947954200, 0.138064910279642520, 0.138114431266169010, 0.138163951907408960, 0.138213472203239040, 0.138262992153535460, 0.138312511758174830, +0.138362031017032460, 0.138411549929985030, 0.138461068496908730, 0.138510586717680180, 0.138560104592174740, 0.138609622120269030, 0.138659139301839260, 0.138708656136762090, +0.138758172624912860, 0.138807688766168170, 0.138857204560404710, 0.138906720007497790, 0.138956235107324080, 0.139005749859759780, 0.139055264264681510, 0.139104778321964690, +0.139154292031485910, 0.139203805393121380, 0.139253318406747790, 0.139302831072240480, 0.139352343389476080, 0.139401855358330830, 0.139451366978681350, 0.139500878250403050, +0.139550389173372540, 0.139599899747466060, 0.139649409972560260, 0.139698919848530500, 0.139748429375253450, 0.139797938552605750, 0.139847447380462790, 0.139896955858701180, +0.139946463987197180, 0.139995971765827480, 0.140045479194467410, 0.140094986272993630, 0.140144493001282400, 0.140193999379210370, 0.140243505406652900, 0.140293011083486690, +0.140342516409587920, 0.140392021384833310, 0.140441526009098210, 0.140491030282259290, 0.140540534204192800, 0.140590037774775380, 0.140639540993882480, 0.140689043861390690, +0.140738546377176310, 0.140788048541115980, 0.140837550353085120, 0.140887051812960380, 0.140936552920618440, 0.140986053675934670, 0.141035554078785790, 0.141085054129048010, +0.141134553826598010, 0.141184053171311220, 0.141233552163064300, 0.141283050801733480, 0.141332549087195470, 0.141382047019325660, 0.141431544598000720, 0.141481041823096950, +0.141530538694490980, 0.141580035212058250, 0.141629531375675410, 0.141679027185218740, 0.141728522640564960, 0.141778017741589430, 0.141827512488168860, 0.141877006880179930, +0.141926500917498060, 0.141975994599999930, 0.142025487927561810, 0.142074980900060430, 0.142124473517371150, 0.142173965779370660, 0.142223457685935280, 0.142272949236941700, +0.142322440432265300, 0.142371931271782800, 0.142421421755370450, 0.142470911882905000, 0.142520401654261860, 0.142569891069317670, 0.142619380127948780, 0.142668868830031880, +0.142718357175442350, 0.142767845164056940, 0.142817332795752370, 0.142866820070403990, 0.142916306987888600, 0.142965793548082420, 0.143015279750862200, 0.143064765596103340, +0.143114251083682590, 0.143163736213476170, 0.143213220985360880, 0.143262705399212100, 0.143312189454906540, 0.143361673152320510, 0.143411156491330740, 0.143460639471812620, +0.143510122093642920, 0.143559604356697930, 0.143609086260854340, 0.143658567805987620, 0.143708048991974450, 0.143757529818691190, 0.143807010286014530, 0.143856490393819900, +0.143905970141984060, 0.143955449530383720, 0.144004928558894320, 0.144054407227392600, 0.144103885535754870, 0.144153363483857850, 0.144202841071576990, 0.144252318298789010, +0.144301795165370260, 0.144351271671197460, 0.144400747816146040, 0.144450223600092740, 0.144499699022913870, 0.144549174084486230, 0.144598648784685170, 0.144648123123387510, +0.144697597100469560, 0.144747070715808030, 0.144796543969278410, 0.144846016860757400, 0.144895489390121810, 0.144944961557247040, 0.144994433362009870, 0.145043904804286610, +0.145093375883954050, 0.145142846600887610, 0.145192316954964040, 0.145241786946059690, 0.145291256574051290, 0.145340725838814330, 0.145390194740225550, 0.145439663278161270, +0.145489131452498280, 0.145538599263112020, 0.145588066709879280, 0.145637533792676350, 0.145687000511380030, 0.145736466865865780, 0.145785932856010350, 0.145835398481690550, +0.145884863742781780, 0.145934328639160890, 0.145983793170704150, 0.146033257337288360, 0.146082721138789010, 0.146132184575082870, 0.146181647646046240, 0.146231110351555920, +0.146280572691487420, 0.146330034665717450, 0.146379496274122420, 0.146428957516579080, 0.146478418392962910, 0.146527878903150690, 0.146577339047018810, 0.146626798824443960, +0.146676258235301730, 0.146725717279468810, 0.146775175956822050, 0.146824634267236910, 0.146874092210590200, 0.146923549786758260, 0.146973006995617860, 0.147022463837044510, +0.147071920310915010, 0.147121376417105710, 0.147170832155493400, 0.147220287525953590, 0.147269742528363030, 0.147319197162598140, 0.147368651428535670, 0.147418105326051150, +0.147467558855021390, 0.147517012015322690, 0.147566464806831920, 0.147615917229424550, 0.147665369282977380, 0.147714820967366790, 0.147764272282469580, 0.147813723228161280, +0.147863173804318630, 0.147912624010818510, 0.147962073847536370, 0.148011523314349080, 0.148060972411132950, 0.148110421137764850, 0.148159869494120240, 0.148209317480075960, +0.148258765095508390, 0.148308212340294370, 0.148357659214309350, 0.148407105717430180, 0.148456551849533270, 0.148505997610495400, 0.148555443000192110, 0.148604888018500190, +0.148654332665296070, 0.148703776940456560, 0.148753220843857140, 0.148802664375374700, 0.148852107534886040, 0.148901550322266650, 0.148950992737393400, 0.149000434780142660, +0.149049876450391280, 0.149099317748014740, 0.149148758672889930, 0.149198199224893220, 0.149247639403901460, 0.149297079209790160, 0.149346518642436170, 0.149395957701715880, +0.149445396387506120, 0.149494834699682420, 0.149544272638121640, 0.149593710202700210, 0.149643147393294930, 0.149692584209781320, 0.149742020652036260, 0.149791456719936600, +0.149840892413357850, 0.149890327732176860, 0.149939762676270070, 0.149989197245514290, 0.150038631439785100, 0.150088065258959320, 0.150137498702913370, 0.150186931771524150, +0.150236364464667120, 0.150285796782219210, 0.150335228724056770, 0.150384660290056730, 0.150434091480094590, 0.150483522294047210, 0.150532952731791040, 0.150582382793202910, +0.150631812478158410, 0.150681241786534360, 0.150730670718207200, 0.150780099273053830, 0.150829527450949740, 0.150878955251771860, 0.150928382675397020, 0.150977809721700770, +0.151027236390560010, 0.151076662681851160, 0.151126088595451100, 0.151175514131235370, 0.151224939289080850, 0.151274364068863960, 0.151323788470461630, 0.151373212493749380, +0.151422636138604130, 0.151472059404902240, 0.151521482292520660, 0.151570904801334950, 0.151620326931221960, 0.151669748682058150, 0.151719170053720430, 0.151768591046084340, +0.151818011659026750, 0.151867431892424600, 0.151916851746153410, 0.151966271220090100, 0.152015690314111110, 0.152065109028093340, 0.152114527361912330, 0.152163945315445030, +0.152213362888567880, 0.152262780081157730, 0.152312196893090200, 0.152361613324242170, 0.152411029374490140, 0.152460445043710920, 0.152509860331780210, 0.152559275238574820, +0.152608689763971240, 0.152658103907846370, 0.152707517670075820, 0.152756931050536450, 0.152806344049105200, 0.152855756665657650, 0.152905168900070720, 0.152954580752220880, +0.153003992221984990, 0.153053403309238720, 0.153102814013858920, 0.153152224335722090, 0.153201634274705120, 0.153251043830683640, 0.153300453003534560, 0.153349861793134340, +0.153399270199359890, 0.153448678222086850, 0.153498085861192100, 0.153547493116552140, 0.153596899988043880, 0.153646306475542950, 0.153695712578926220, 0.153745118298070690, +0.153794523632851900, 0.153843928583146800, 0.153893333148831880, 0.153942737329784090, 0.153992141125878970, 0.154041544536993540, 0.154090947563004230, 0.154140350203788000, +0.154189752459220450, 0.154239154329178510, 0.154288555813538700, 0.154337956912177910, 0.154387357624971830, 0.154436757951797320, 0.154486157892530950, 0.154535557447049580, +0.154584956615228920, 0.154634355396945840, 0.154683753792076880, 0.154733151800498990, 0.154782549422087770, 0.154831946656720180, 0.154881343504273160, 0.154930739964622340, +0.154980136037644660, 0.155029531723216650, 0.155078927021215260, 0.155128321931516100, 0.155177716453996140, 0.155227110588531890, 0.155276504335000310, 0.155325897693277010, +0.155375290663238990, 0.155424683244762720, 0.155474075437725210, 0.155523467242002030, 0.155572858657470230, 0.155622249684006260, 0.155671640321487090, 0.155721030569788390, +0.155770420428787110, 0.155819809898360250, 0.155869198978383390, 0.155918587668733540, 0.155967975969287240, 0.156017363879921410, 0.156066751400511770, 0.156116138530935230, +0.156165525271068330, 0.156214911620788070, 0.156264297579970100, 0.156313683148491370, 0.156363068326228430, 0.156412453113058260, 0.156461837508856530, 0.156511221513500190, +0.156560605126865810, 0.156609988348830360, 0.156659371179269510, 0.156708753618060190, 0.156758135665079460, 0.156807517320202950, 0.156856898583307650, 0.156906279454270080, +0.156955659932967260, 0.157005040019274870, 0.157054419713069850, 0.157103799014228800, 0.157153177922628700, 0.157202556438145210, 0.157251934560655310, 0.157301312290035580, +0.157350689626163030, 0.157400066568913280, 0.157449443118163390, 0.157498819273789890, 0.157548195035669770, 0.157597570403678750, 0.157646945377693780, 0.157696319957591450, +0.157745694143248770, 0.157795067934541400, 0.157844441331346370, 0.157893814333540690, 0.157943186941000010, 0.157992559153601360, 0.158041930971221320, 0.158091302393736920, +0.158140673421023780, 0.158190044052958970, 0.158239414289419070, 0.158288784130281050, 0.158338153575420660, 0.158387522624714870, 0.158436891278040250, 0.158486259535273870, +0.158535627396291400, 0.158584994860969860, 0.158634361929185810, 0.158683728600816340, 0.158733094875737060, 0.158782460753825070, 0.158831826234957370, 0.158881191319009660, +0.158930556005858980, 0.158979920295381880, 0.159029284187455430, 0.159078647681955340, 0.159128010778758660, 0.159177373477741910, 0.159226735778782190, 0.159276097681755160, +0.159325459186537900, 0.159374820293007010, 0.159424181001039500, 0.159473541310511090, 0.159522901221298840, 0.159572260733279320, 0.159621619846329610, 0.159670978560325390, +0.159720336875143730, 0.159769694790661660, 0.159819052306754920, 0.159868409423300550, 0.159917766140175170, 0.159967122457255810, 0.160016478374418180, 0.160065833891539390, +0.160115189008495970, 0.160164543725165060, 0.160213898041422330, 0.160263251957144860, 0.160312605472209270, 0.160361958586492580, 0.160411311299870570, 0.160460663612220280, +0.160510015523418340, 0.160559367033341780, 0.160608718141866390, 0.160658068848869180, 0.160707419154227260, 0.160756769057816330, 0.160806118559513490, 0.160855467659195370, +0.160904816356738980, 0.160954164652020140, 0.161003512544915880, 0.161052860035302840, 0.161102207123058090, 0.161151553808057370, 0.161200900090177790, 0.161250245969295960, +0.161299591445288940, 0.161348936518032500, 0.161398281187403710, 0.161447625453279230, 0.161496969315536140, 0.161546312774050150, 0.161595655828698420, 0.161644998479357540, +0.161694340725904580, 0.161743682568215340, 0.161793024006166910, 0.161842365039636340, 0.161891705668499420, 0.161941045892633250, 0.161990385711914460, 0.162039725126220140, +0.162089064135426060, 0.162138402739409330, 0.162187740938046610, 0.162237078731214960, 0.162286416118790160, 0.162335753100649320, 0.162385089676669120, 0.162434425846726630, +0.162483761610697640, 0.162533096968459220, 0.162582431919888080, 0.162631766464861300, 0.162681100603254660, 0.162730434334945270, 0.162779767659810230, 0.162829100577725340, +0.162878433088567700, 0.162927765192213970, 0.162977096888541260, 0.163026428177425380, 0.163075759058743410, 0.163125089532372060, 0.163174419598188430, 0.163223749256068310, +0.163273078505888790, 0.163322407347526590, 0.163371735780858840, 0.163421063805761270, 0.163470391422111060, 0.163519718629784870, 0.163569045428659830, 0.163618371818611720, +0.163667697799517700, 0.163717023371254850, 0.163766348533699040, 0.163815673286727330, 0.163864997630216420, 0.163914321564043480, 0.163963645088084310, 0.164012968202216000, +0.164062290906315300, 0.164111613200259270, 0.164160935083923790, 0.164210256557185990, 0.164259577619922520, 0.164308898272010560, 0.164358218513325910, 0.164407538343745720, +0.164456857763146700, 0.164506176771405940, 0.164555495368399330, 0.164604813554003970, 0.164654131328096560, 0.164703448690554280, 0.164752765641252940, 0.164802082180069670, +0.164851398306881640, 0.164900714021564670, 0.164950029323995940, 0.164999344214052100, 0.165048658691610370, 0.165097972756546560, 0.165147286408737800, 0.165196599648060800, +0.165245912474392770, 0.165295224887609530, 0.165344536887588210, 0.165393848474205550, 0.165443159647338690, 0.165492470406863520, 0.165541780752657160, 0.165591090684596350, +0.165640400202558270, 0.165689709306418740, 0.165739017996054920, 0.165788326271344020, 0.165837634132161850, 0.165886941578385600, 0.165936248609891980, 0.165985555226558200, +0.166034861428260070, 0.166084167214874820, 0.166133472586279110, 0.166182777542350200, 0.166232082082963860, 0.166281386207997340, 0.166330689917327380, 0.166379993210831110, +0.166429296088384420, 0.166478598549864490, 0.166527900595148050, 0.166577202224112320, 0.166626503436633130, 0.166675804232587680, 0.166725104611853160, 0.166774404574305450, +0.166823704119821730, 0.166873003248278750, 0.166922301959553680, 0.166971600253522450, 0.167020898130062180, 0.167070195589049700, 0.167119492630362160, 0.167168789253875430, +0.167218085459466730, 0.167267381247012850, 0.167316676616390940, 0.167365971567476870, 0.167415266100147900, 0.167464560214280770, 0.167513853909752650, 0.167563147186439500, +0.167612440044218440, 0.167661732482966290, 0.167711024502560260, 0.167760316102876230, 0.167809607283791410, 0.167858898045183000, 0.167908188386926890, 0.167957478308900340, +0.168006767810980090, 0.168056056893043340, 0.168105345554966030, 0.168154633796625350, 0.168203921617898100, 0.168253209018661450, 0.168302495998791380, 0.168351782558165050, +0.168401068696659250, 0.168450354414151240, 0.168499639710516870, 0.168548924585633450, 0.168598209039377670, 0.168647493071626830, 0.168696776682256830, 0.168746059871144880, +0.168795342638168200, 0.168844624983202740, 0.168893906906125740, 0.168943188406813940, 0.168992469485144630, 0.169041750140993680, 0.169091030374238370, 0.169140310184755500, +0.169189589572422280, 0.169238868537114650, 0.169288147078709840, 0.169337425197084670, 0.169386702892116350, 0.169435980163680860, 0.169485257011655430, 0.169534533435916850, +0.169583809436342350, 0.169633085012807910, 0.169682360165190750, 0.169731634893368150, 0.169780909197216000, 0.169830183076611600, 0.169879456531431720, 0.169928729561553640, +0.169978002166853300, 0.170027274347207960, 0.170076546102494420, 0.170125817432589980, 0.170175088337370550, 0.170224358816713380, 0.170273628870495320, 0.170322898498593640, +0.170372167700884260, 0.170421436477244480, 0.170470704827551080, 0.170519972751681380, 0.170569240249511310, 0.170618507320918130, 0.170667773965779120, 0.170717040183970240, +0.170766305975368770, 0.170815571339851510, 0.170864836277295790, 0.170914100787577520, 0.170963364870574010, 0.171012628526162060, 0.171061891754219010, 0.171111154554620780, +0.171160416927244650, 0.171209678871967500, 0.171258940388666570, 0.171308201477217870, 0.171357462137498670, 0.171406722369385810, 0.171455982172756570, 0.171505241547486950, +0.171554500493454220, 0.171603759010535230, 0.171653017098607280, 0.171702274757546370, 0.171751531987229760, 0.171800788787534770, 0.171850045158337350, 0.171899301099514850, +0.171948556610944050, 0.171997811692502330, 0.172047066344065640, 0.172096320565511270, 0.172145574356716100, 0.172194827717557450, 0.172244080647911270, 0.172293333147654910, +0.172342585216665210, 0.172391836854819490, 0.172441088061993740, 0.172490338838065250, 0.172539589182910930, 0.172588839096408070, 0.172638088578432660, 0.172687337628862040, +0.172736586247573540, 0.172785834434443120, 0.172835082189348090, 0.172884329512165370, 0.172933576402772270, 0.172982822861044800, 0.173032068886860260, 0.173081314480095530, +0.173130559640627980, 0.173179804368333580, 0.173229048663089690, 0.173278292524773170, 0.173327535953261340, 0.173376778948430230, 0.173426021510157180, 0.173475263638319080, +0.173524505332793260, 0.173573746593455760, 0.173622987420183870, 0.173672227812854930, 0.173721467771345010, 0.173770707295531400, 0.173819946385291050, 0.173869185040501250, +0.173918423261038070, 0.173967661046778830, 0.174016898397600400, 0.174066135313380190, 0.174115371793994220, 0.174164607839319810, 0.174213843449233850, 0.174263078623613760, +0.174312313362335520, 0.174361547665276480, 0.174410781532313600, 0.174460014963324190, 0.174509247958184290, 0.174558480516771310, 0.174607712638962100, 0.174656944324634050, +0.174706175573663190, 0.174755406385926900, 0.174804636761302530, 0.174853866699666160, 0.174903096200895090, 0.174952325264866290, 0.175001553891457110, 0.175050782080543620, +0.175100009832003160, 0.175149237145712680, 0.175198464021549540, 0.175247690459389820, 0.175296916459110860, 0.175346142020589600, 0.175395367143703430, 0.175444591828328420, +0.175493816074341920, 0.175543039881620870, 0.175592263250042680, 0.175641486179483390, 0.175690708669820370, 0.175739930720931030, 0.175789152332691410, 0.175838373504978910, +0.175887594237670470, 0.175936814530643500, 0.175986034383774050, 0.176035253796939520, 0.176084472770016850, 0.176133691302883450, 0.176182909395415370, 0.176232127047490030, +0.176281344258984340, 0.176330561029775760, 0.176379777359740310, 0.176428993248755440, 0.176478208696698090, 0.176527423703445650, 0.176576638268874210, 0.176625852392861160, +0.176675066075283940, 0.176724279316018610, 0.176773492114942590, 0.176822704471932820, 0.176871916386866720, 0.176921127859620410, 0.176970338890071300, 0.177019549478096310, +0.177068759623572910, 0.177117969326377160, 0.177167178586386480, 0.177216387403477870, 0.177265595777528710, 0.177314803708415130, 0.177364011196014530, 0.177413218240203920, +0.177462424840860690, 0.177511630997860990, 0.177560836711082170, 0.177610041980401730, 0.177659246805695730, 0.177708451186841620, 0.177757655123716380, 0.177806858616197440, +0.177856061664160900, 0.177905264267484240, 0.177954466426044370, 0.178003668139718820, 0.178052869408383630, 0.178102070231916290, 0.178151270610193760, 0.178200470543093490, +0.178249670030491610, 0.178298869072265580, 0.178348067668292340, 0.178397265818449390, 0.178446463522612810, 0.178495660780660120, 0.178544857592468240, 0.178594053957914670, +0.178643249876875520, 0.178692445349228230, 0.178741640374850300, 0.178790834953617810, 0.178840029085408220, 0.178889222770098580, 0.178938416007566330, 0.178987608797687580, +0.179036801140339820, 0.179085993035400040, 0.179135184482745740, 0.179184375482253020, 0.179233566033799360, 0.179282756137261800, 0.179331945792517770, 0.179381134999443470, +0.179430323757916290, 0.179479512067813350, 0.179528699929012020, 0.179577887341388520, 0.179627074304820310, 0.179676260819184840, 0.179725446884358290, 0.179774632500218130, +0.179823817666641380, 0.179873002383505510, 0.179922186650686710, 0.179971370468062440, 0.180020553835509740, 0.180069736752906110, 0.180118919220127680, 0.180168101237051990, +0.180217282803556010, 0.180266463919517260, 0.180315644584811920, 0.180364824799317480, 0.180414004562910960, 0.180463183875469890, 0.180512362736870410, 0.180561541146990020, +0.180610719105706200, 0.180659896612895170, 0.180709073668434390, 0.180758250272200940, 0.180807426424072270, 0.180856602123924630, 0.180905777371635460, 0.180954952167081850, +0.181004126510141310, 0.181053300400690010, 0.181102473838605450, 0.181151646823764720, 0.181200819356045290, 0.181249991435323390, 0.181299163061476530, 0.181348334234381740, +0.181397504953916540, 0.181446675219957170, 0.181495845032381090, 0.181545014391065410, 0.181594183295887610, 0.181643351746723940, 0.181692519743451880, 0.181741687285948940, +0.181790854374091370, 0.181840021007756670, 0.181889187186821900, 0.181938352911164610, 0.181987518180661000, 0.182036682995188580, 0.182085847354624460, 0.182135011258846150, +0.182184174707729910, 0.182233337701153190, 0.182282500238993140, 0.182331662321127300, 0.182380823947431850, 0.182429985117784330, 0.182479145832061870, 0.182528306090141950, +0.182577465891900850, 0.182626625237216090, 0.182675784125965190, 0.182724942558024410, 0.182774100533271260, 0.182823258051582870, 0.182872415112836750, 0.182921571716909180, +0.182970727863677660, 0.183019883553019320, 0.183069038784811730, 0.183118193558931110, 0.183167347875254990, 0.183216501733660500, 0.183265655134025180, 0.183314808076225300, +0.183363960560138400, 0.183413112585641610, 0.183462264152612440, 0.183511415260927210, 0.183560565910463440, 0.183609716101098660, 0.183658865832709180, 0.183708015105172540, +0.183757163918365830, 0.183806312272166680, 0.183855460166451300, 0.183904607601097250, 0.183953754575981730, 0.184002901090982220, 0.184052047145975030, 0.184101192740837720, +0.184150337875447430, 0.184199482549681740, 0.184248626763416910, 0.184297770516530510, 0.184346913808899670, 0.184396056640401980, 0.184445199010913750, 0.184494340920312470, +0.184543482368475810, 0.184592623355280010, 0.184641763880602630, 0.184690903944320860, 0.184740043546312240, 0.184789182686453090, 0.184838321364621000, 0.184887459580693080, +0.184936597334546950, 0.184985734626058910, 0.185034871455106530, 0.185084007821566950, 0.185133143725317810, 0.185182279166235360, 0.185231414144197220, 0.185280548659080560, +0.185329682710762940, 0.185378816299120670, 0.185427949424031370, 0.185477082085372220, 0.185526214283020770, 0.185575346016853350, 0.185624477286747580, 0.185673608092581040, +0.185722738434230070, 0.185771868311572250, 0.185820997724484740, 0.185870126672845170, 0.185919255156529850, 0.185968383175416390, 0.186017510729382000, 0.186066637818304240, +0.186115764442059460, 0.186164890600525270, 0.186214016293578840, 0.186263141521097800, 0.186312266282958490, 0.186361390579038530, 0.186410514409215050, 0.186459637773365740, +0.186508760671366900, 0.186557883103096180, 0.186607005068431170, 0.186656126567248200, 0.186705247599424940, 0.186754368164838540, 0.186803488263366650, 0.186852607894885610, +0.186901727059273080, 0.186950845756406190, 0.186999963986162640, 0.187049081748418750, 0.187098199043052170, 0.187147315869940050, 0.187196432228960100, 0.187245548119988640, +0.187294663542903310, 0.187343778497581300, 0.187392892983900300, 0.187442007001736630, 0.187491120550967920, 0.187540233631471880, 0.187589346243124790, 0.187638458385804340, +0.187687570059387770, 0.187736681263752670, 0.187785791998775460, 0.187834902264333780, 0.187884012060304810, 0.187933121386566260, 0.187982230242994490, 0.188031338629467110, +0.188080446545861400, 0.188129553992055030, 0.188178660967924320, 0.188227767473346940, 0.188276873508200160, 0.188325979072361650, 0.188375084165707720, 0.188424188788116090, +0.188473292939464020, 0.188522396619629110, 0.188571499828487810, 0.188620602565917730, 0.188669704831796600, 0.188718806626000770, 0.188767907948407920, 0.188817008798895290, +0.188866109177340590, 0.188915209083620170, 0.188964308517611730, 0.189013407479192510, 0.189062505968240230, 0.189111603984631230, 0.189160701528243210, 0.189209798598953480, +0.189258895196639660, 0.189307991321178150, 0.189357086972446690, 0.189406182150322510, 0.189455276854683300, 0.189504371085405470, 0.189553464842366710, 0.189602558125444710, +0.189651650934515890, 0.189700743269457960, 0.189749835130148150, 0.189798926516464180, 0.189848017428282470, 0.189897107865480720, 0.189946197827936200, 0.189995287315526620, +0.190044376328128400, 0.190093464865619200, 0.190142552927876380, 0.190191640514777600, 0.190240727626199290, 0.190289814262019130, 0.190338900422114460, 0.190387986106362980, +0.190437071314641080, 0.190486156046826500, 0.190535240302796980, 0.190584324082428920, 0.190633407385600060, 0.190682490212187670, 0.190731572562069490, 0.190780654435121960, +0.190829735831222760, 0.190878816750249260, 0.190927897192079120, 0.190976977156588820, 0.191026056643656070, 0.191075135653158170, 0.191124214184972880, 0.191173292238976610, +0.191222369815047120, 0.191271446913061720, 0.191320523532898110, 0.191369599674432760, 0.191418675337543420, 0.191467750522107820, 0.191516825228002420, 0.191565899455104940, +0.191614973203292740, 0.191664046472443510, 0.191713119262433730, 0.191762191573141170, 0.191811263404443130, 0.191860334756217360, 0.191909405628340330, 0.191958476020689770, +0.192007545933143010, 0.192056615365577860, 0.192105684317870700, 0.192154752789899350, 0.192203820781541110, 0.192252888292673760, 0.192301955323173730, 0.192351021872918830, +0.192400087941786370, 0.192449153529654140, 0.192498218636398570, 0.192547283261897460, 0.192596347406028600, 0.192645411068668420, 0.192694474249694710, 0.192743536948984800, +0.192792599166416500, 0.192841660901866270, 0.192890722155211890, 0.192939782926330680, 0.192988843215100490, 0.193037903021397730, 0.193086962345100200, 0.193136021186085280, +0.193185079544230750, 0.193234137419413060, 0.193283194811510050, 0.193332251720399060, 0.193381308145957860, 0.193430364088062970, 0.193479419546592150, 0.193528474521423220, +0.193577529012432660, 0.193626583019498310, 0.193675636542497480, 0.193724689581307980, 0.193773742135806340, 0.193822794205870340, 0.193871845791377370, 0.193920896892205210, +0.193969947508230350, 0.194018997639330640, 0.194068047285383460, 0.194117096446266570, 0.194166145121856510, 0.194215193312031080, 0.194264241016667670, 0.194313288235644090, +0.194362334968836870, 0.194411381216123810, 0.194460426977382720, 0.194509472252490130, 0.194558517041323880, 0.194607561343761310, 0.194656605159680280, 0.194705648488957300, +0.194754691331470190, 0.194803733687096360, 0.194852775555713650, 0.194901816937198550, 0.194950857831428900, 0.194999898238282120, 0.195048938157636020, 0.195097977589367140, +0.195147016533353340, 0.195196054989471960, 0.195245092957600900, 0.195294130437616680, 0.195343167429397110, 0.195392203932819640, 0.195441239947762080, 0.195490275474101000, +0.195539310511714220, 0.195588345060479620, 0.195637379120273710, 0.195686412690974340, 0.195735445772458940, 0.195784478364605390, 0.195833510467290170, 0.195882542080391190, +0.195931573203785870, 0.195980603837352020, 0.196029633980966260, 0.196078663634506410, 0.196127692797849890, 0.196176721470874560, 0.196225749653457020, 0.196274777345475080, +0.196323804546806200, 0.196372831257328270, 0.196421857476917790, 0.196470883205452700, 0.196519908442810810, 0.196568933188868730, 0.196617957443504300, 0.196666981206595010, +0.196716004478018680, 0.196765027257651910, 0.196814049545372540, 0.196863071341058100, 0.196912092644586370, 0.196961113455834000, 0.197010133774678850, 0.197059153600998350, +0.197108172934670390, 0.197157191775571590, 0.197206210123579810, 0.197255227978572510, 0.197304245340427540, 0.197353262209021550, 0.197402278584232400, 0.197451294465937980, +0.197500309854014900, 0.197549324748341030, 0.197598339148793850, 0.197647353055251270, 0.197696366467589870, 0.197745379385687560, 0.197794391809421790, 0.197843403738670490, +0.197892415173310220, 0.197941426113218940, 0.197990436558274090, 0.198039446508353560, 0.198088455963333990, 0.198137464923093280, 0.198186473387508920, 0.198235481356458800, +0.198284488829819560, 0.198333495807469060, 0.198382502289285310, 0.198431508275144830, 0.198480513764925590, 0.198529518758505050, 0.198578523255761170, 0.198627527256570540, +0.198676530760811100, 0.198725533768360300, 0.198774536279096140, 0.198823538292895170, 0.198872539809635400, 0.198921540829194250, 0.198970541351449680, 0.199019541376278340, +0.199068540903558130, 0.199117539933166580, 0.199166538464981590, 0.199215536498879850, 0.199264534034739260, 0.199313531072437320, 0.199362527611852000, 0.199411523652859940, +0.199460519195339050, 0.199509514239167300, 0.199558508784221320, 0.199607502830379090, 0.199656496377518090, 0.199705489425516300, 0.199754481974250330, 0.199803474023598160, +0.199852465573437300, 0.199901456623645720, 0.199950447174100070, 0.199999437224678310, 0.200048426775257940, 0.200097415825716940, 0.200146404375931980, 0.200195392425780990, +0.200244379975141520, 0.200293367023891560, 0.200342353571907720, 0.200391339619067990, 0.200440325165250370, 0.200489310210331480, 0.200538294754189330, 0.200587278796701430, +0.200636262337745790, 0.200685245377199060, 0.200734227914939200, 0.200783209950843780, 0.200832191484790760, 0.200881172516656830, 0.200930153046319980, 0.200979133073657720, +0.201028112598548080, 0.201077091620867730, 0.201126070140494630, 0.201175048157306390, 0.201224025671180940, 0.201273002681994990, 0.201321979189626550, 0.201370955193953590, +0.201419930694852780, 0.201468905692202190, 0.201517880185879290, 0.201566854175762170, 0.201615827661727450, 0.201664800643653160, 0.201713773121416890, 0.201762745094896580, +0.201811716563969010, 0.201860687528512130, 0.201909657988403550, 0.201958627943521260, 0.202007597393741970, 0.202056566338943640, 0.202105534779003950, 0.202154502713800840, +0.202203470143211020, 0.202252437067112540, 0.202301403485382970, 0.202350369397900330, 0.202399334804541310, 0.202448299705183970, 0.202497264099706310, 0.202546227987985050, +0.202595191369898230, 0.202644154245323420, 0.202693116614138690, 0.202742078476220690, 0.202791039831447530, 0.202840000679696760, 0.202888961020846410, 0.202937920854773250, +0.202986880181355270, 0.203035839000470090, 0.203084797311995750, 0.203133755115808970, 0.203182712411787810, 0.203231669199809870, 0.203280625479753200, 0.203329581251494530, +0.203378536514911890, 0.203427491269883350, 0.203476445516285660, 0.203525399253996850, 0.203574352482894540, 0.203623305202856790, 0.203672257413760330, 0.203721209115483220, +0.203770160307903100, 0.203819110990898030, 0.203868061164344720, 0.203917010828121280, 0.203965959982105290, 0.204014908626174860, 0.204063856760206720, 0.204112804384078920, +0.204161751497669130, 0.204210698100855380, 0.204259644193514440, 0.204308589775524410, 0.204357534846763330, 0.204406479407107990, 0.204455423456436440, 0.204504366994626350, +0.204553310021555750, 0.204602252537101460, 0.204651194541141530, 0.204700136033553610, 0.204749077014215800, 0.204798017483004860, 0.204846957439798860, 0.204895896884475490, +0.204944835816912780, 0.204993774236987590, 0.205042712144577920, 0.205091649539561490, 0.205140586421816370, 0.205189522791219350, 0.205238458647648530, 0.205287393990982000, +0.205336328821096540, 0.205385263137870260, 0.205434196941180810, 0.205483130230906310, 0.205532063006923560, 0.205580995269110640, 0.205629927017345250, 0.205678858251505480, +0.205727788971468100, 0.205776719177111270, 0.205825648868312620, 0.205874578044950300, 0.205923506706901100, 0.205972434854043150, 0.206021362486254080, 0.206070289603412060, +0.206119216205393860, 0.206168142292077640, 0.206217067863341070, 0.206265992919062250, 0.206314917459118010, 0.206363841483386490, 0.206412764991745800, 0.206461687984072740, +0.206510610460245490, 0.206559532420141690, 0.206608453863639520, 0.206657374790615770, 0.206706295200948580, 0.206755215094515640, 0.206804134471195110, 0.206853053330863820, +0.206901971673399880, 0.206950889498681010, 0.206999806806585360, 0.207048723596989750, 0.207097639869772340, 0.207146555624810820, 0.207195470861983370, 0.207244385581166780, +0.207293299782239230, 0.207342213465078890, 0.207391126629562550, 0.207440039275568420, 0.207488951402974160, 0.207537863011658000, 0.207586774101496700, 0.207635684672368510, +0.207684594724151070, 0.207733504256722600, 0.207782413269959910, 0.207831321763741220, 0.207880229737944210, 0.207929137192447070, 0.207978044127126640, 0.208026950541861100, +0.208075856436528210, 0.208124761811006090, 0.208173666665171620, 0.208222570998903010, 0.208271474812078390, 0.208320378104574650, 0.208369280876269960, 0.208418183127042080, +0.208467084856769180, 0.208515986065328120, 0.208564886752597100, 0.208613786918453860, 0.208662686562776590, 0.208711585685442180, 0.208760484286328790, 0.208809382365314180, +0.208858279922276570, 0.208907176957092820, 0.208956073469641120, 0.209004969459799270, 0.209053864927445400, 0.209102759872456440, 0.209151654294710580, 0.209200548194085570, +0.209249441570459630, 0.209298334423709650, 0.209347226753713870, 0.209396118560350420, 0.209445009843496260, 0.209493900603029550, 0.209542790838828100, 0.209591680550770130, +0.209640569738732490, 0.209689458402593450, 0.209738346542230750, 0.209787234157522620, 0.209836121248345970, 0.209885007814579030, 0.209933893856099560, 0.209982779372785780, +0.210031664364514650, 0.210080548831164340, 0.210129432772612650, 0.210178316188737810, 0.210227199079416750, 0.210276081444527700, 0.210324963283948900, 0.210373844597557230, +0.210422725385230940, 0.210471605646847860, 0.210520485382286180, 0.210569364591422860, 0.210618243274136140, 0.210667121430303810, 0.210715999059804090, 0.210764876162513960, +0.210813752738311630, 0.210862628787074930, 0.210911504308682080, 0.210960379303010040, 0.211009253769937040, 0.211058127709340900, 0.211107001121099900, 0.211155874005090950, +0.211204746361192320, 0.211253618189282260, 0.211302489489237720, 0.211351360260936950, 0.211400230504257800, 0.211449100219078480, 0.211497969405275990, 0.211546838062728560, +0.211595706191314040, 0.211644573790910700, 0.211693440861395490, 0.211742307402646680, 0.211791173414542090, 0.211840038896960010, 0.211888903849777400, 0.211937768272872530, +0.211986632166123230, 0.212035495529407810, 0.212084358362603200, 0.212133220665587680, 0.212182082438239550, 0.212230943680435800, 0.212279804392054660, 0.212328664572974030, +0.212377524223072180, 0.212426383342226080, 0.212475241930314000, 0.212524099987213830, 0.212572957512803830, 0.212621814506961020, 0.212670670969563690, 0.212719526900489650, +0.212768382299617250, 0.212817237166823440, 0.212866091501986540, 0.212914945304984420, 0.212963798575695390, 0.213012651313996410, 0.213061503519765800, 0.213110355192881430, +0.213159206333221610, 0.213208056940663330, 0.213256907015084930, 0.213305756556364660, 0.213354605564379600, 0.213403454039008010, 0.213452301980127800, 0.213501149387617250, +0.213549996261353400, 0.213598842601214560, 0.213647688407078620, 0.213696533678823880, 0.213745378416327380, 0.213794222619467430, 0.213843066288121940, 0.213891909422169210, +0.213940752021486270, 0.213989594085951450, 0.214038435615442640, 0.214087276609838170, 0.214136117069015090, 0.214184956992851700, 0.214233796381226360, 0.214282635234016080, +0.214331473551099240, 0.214380311332353720, 0.214429148577657820, 0.214477985286888630, 0.214526821459924490, 0.214575657096643310, 0.214624492196923390, 0.214673326760641820, +0.214722160787676920, 0.214770994277906630, 0.214819827231209290, 0.214868659647461930, 0.214917491526542940, 0.214966322868330230, 0.215015153672702130, 0.215063983939535710, +0.215112813668709320, 0.215161642860101370, 0.215210471513588820, 0.215259299629050130, 0.215308127206363190, 0.215356954245406380, 0.215405780746056740, 0.215454606708192640, +0.215503432131692010, 0.215552257016433240, 0.215601081362293420, 0.215649905169150860, 0.215698728436883560, 0.215747551165369870, 0.215796373354486870, 0.215845195004112920, +0.215894016114126010, 0.215942836684404480, 0.215991656714825430, 0.216040476205267230, 0.216089295155607850, 0.216138113565725650, 0.216186931435497750, 0.216235748764802500, +0.216284565553518330, 0.216333381801522310, 0.216382197508692810, 0.216431012674907860, 0.216479827300045780, 0.216528641383983700, 0.216577454926600050, 0.216626267927772730, +0.216675080387380180, 0.216723892305299480, 0.216772703681409080, 0.216821514515586900, 0.216870324807711370, 0.216919134557659630, 0.216967943765310010, 0.217016752430540550, +0.217065560553229620, 0.217114368133254380, 0.217163175170493220, 0.217211981664824550, 0.217260787616125490, 0.217309593024274470, 0.217358397889149430, 0.217407202210628870, +0.217456005988589860, 0.217504809222910820, 0.217553611913469780, 0.217602414060145130, 0.217651215662814030, 0.217700016721354860, 0.217748817235645680, 0.217797617205564870, +0.217846416630989580, 0.217895215511798270, 0.217944013847868910, 0.217992811639079940, 0.218041608885308520, 0.218090405586433080, 0.218139201742332060, 0.218187997352882580, +0.218236792417963120, 0.218285586937451700, 0.218334380911226730, 0.218383174339165380, 0.218431967221146080, 0.218480759557046850, 0.218529551346746180, 0.218578342590121180, +0.218627133287050360, 0.218675923437411680, 0.218724713041083620, 0.218773502097943360, 0.218822290607869310, 0.218871078570739560, 0.218919865986432570, 0.218968652854825450, +0.219017439175796720, 0.219066224949224790, 0.219115010174986890, 0.219163794852961470, 0.219212578983026540, 0.219261362565060620, 0.219310145598940850, 0.219358928084545710, +0.219407710021753270, 0.219456491410441960, 0.219505272250489020, 0.219554052541772880, 0.219602832284171600, 0.219651611477563680, 0.219700390121826320, 0.219749168216837960, +0.219797945762476690, 0.219846722758620970, 0.219895499205148030, 0.219944275101936340, 0.219993050448863970, 0.220041825245809400, 0.220090599492649810, 0.220139373189263740, +0.220188146335529690, 0.220236918931324830, 0.220285690976527640, 0.220334462471016260, 0.220383233414669140, 0.220432003807363520, 0.220480773648977890, 0.220529542939390310, +0.220578311678479300, 0.220627079866122090, 0.220675847502197180, 0.220724614586582660, 0.220773381119157040, 0.220822147099797500, 0.220870912528382620, 0.220919677404790460, +0.220968441728899540, 0.221017205500587070, 0.221065968719731580, 0.221114731386211630, 0.221163493499904410, 0.221212255060688450, 0.221261016068441840, 0.221309776523043120, +0.221358536424369560, 0.221407295772299640, 0.221456054566711470, 0.221504812807483600, 0.221553570494493280, 0.221602327627619030, 0.221651084206738960, 0.221699840231731620, +0.221748595702474210, 0.221797350618845340, 0.221846104980723100, 0.221894858787986010, 0.221943612040511360, 0.221992364738177680, 0.222041116880863500, 0.222089868468446110, +0.222138619500804050, 0.222187369977815440, 0.222236119899358820, 0.222284869265311490, 0.222333618075551990, 0.222382366329958420, 0.222431114028409400, 0.222479861170782140, +0.222528607756955240, 0.222577353786806790, 0.222626099260215430, 0.222674844177058350, 0.222723588537214190, 0.222772332340561040, 0.222821075586977500, 0.222869818276340840, +0.222918560408529640, 0.222967301983422040, 0.223016043000896610, 0.223064783460830640, 0.223113523363102690, 0.223162262707591400, 0.223211001494174000, 0.223259739722729110, +0.223308477393134860, 0.223357214505269850, 0.223405951059011370, 0.223454687054238020, 0.223503422490827970, 0.223552157368659770, 0.223600891687610740, 0.223649625447559510, +0.223698358648384190, 0.223747091289963400, 0.223795823372174460, 0.223844554894895960, 0.223893285858006080, 0.223942016261383440, 0.223990746104905300, 0.224039475388450290, +0.224088204111897030, 0.224136932275122820, 0.224185659878006290, 0.224234386920425600, 0.224283113402259400, 0.224331839323384960, 0.224380564683680920, 0.224429289483025480, +0.224478013721297250, 0.224526737398373560, 0.224575460514133020, 0.224624183068453830, 0.224672905061214600, 0.224721626492292690, 0.224770347361566700, 0.224819067668914850, +0.224867787414215760, 0.224916506597346770, 0.224965225218186540, 0.225013943276613640, 0.225062660772505470, 0.225111377705740660, 0.225160094076197390, 0.225208809883754300, +0.225257525128288780, 0.225306239809679430, 0.225354953927804500, 0.225403667482542590, 0.225452380473771110, 0.225501092901368660, 0.225549804765213470, 0.225598516065184220, +0.225647226801158260, 0.225695936973014210, 0.225744646580630310, 0.225793355623885250, 0.225842064102656340, 0.225890772016822280, 0.225939479366261300, 0.225988186150852060, +0.226036892370471890, 0.226085598024999530, 0.226134303114313600, 0.226183007638291470, 0.226231711596811800, 0.226280414989752880, 0.226329117816993330, 0.226377820078410590, +0.226426521773883280, 0.226475222903289640, 0.226523923466508400, 0.226572623463416940, 0.226621322893893890, 0.226670021757817560, 0.226718720055066570, 0.226767417785518370, +0.226816114949051630, 0.226864811545544610, 0.226913507574875970, 0.226962203036923130, 0.227010897931564810, 0.227059592258679670, 0.227108286018145090, 0.227156979209839820, +0.227205671833642100, 0.227254363889430630, 0.227303055377082790, 0.227351746296477340, 0.227400436647492520, 0.227449126430007060, 0.227497815643898320, 0.227546504289045050, +0.227595192365325520, 0.227643879872618470, 0.227692566810801240, 0.227741253179752630, 0.227789938979350880, 0.227838624209474700, 0.227887308870001550, 0.227935992960810100, +0.227984676481779110, 0.228033359432786020, 0.228082041813709500, 0.228130723624427880, 0.228179404864819910, 0.228228085534762980, 0.228276765634135820, 0.228325445162816780, +0.228374124120684530, 0.228422802507616540, 0.228471480323491540, 0.228520157568187860, 0.228568834241584200, 0.228617510343558040, 0.228666185873988100, 0.228714860832752690, +0.228763535219730560, 0.228812209034799150, 0.228860882277837240, 0.228909554948723530, 0.228958227047335510, 0.229006898573551940, 0.229055569527251120, 0.229104239908311800, +0.229152909716611420, 0.229201578952028810, 0.229250247614442240, 0.229298915703730480, 0.229347583219771000, 0.229396250162442560, 0.229444916531623490, 0.229493582327192550, +0.229542247549027250, 0.229590912197006340, 0.229639576271008120, 0.229688239770911410, 0.229736902696593640, 0.229785565047933630, 0.229834226824809720, 0.229882888027100660, +0.229931548654683960, 0.229980208707438380, 0.230028868185242710, 0.230077527087974440, 0.230126185415512360, 0.230174843167734790, 0.230223500344520580, 0.230272156945747150, +0.230320812971293360, 0.230369468421037530, 0.230418123294858450, 0.230466777592633650, 0.230515431314241880, 0.230564084459561560, 0.230612737028471430, 0.230661389020849040, +0.230710040436573170, 0.230758691275522200, 0.230807341537574960, 0.230855991222608910, 0.230904640330502900, 0.230953288861135700, 0.231001936814384860, 0.231050584190129170, +0.231099230988247030, 0.231147877208617240, 0.231196522851117300, 0.231245167915626080, 0.231293812402021960, 0.231342456310183710, 0.231391099639988880, 0.231439742391316320, +0.231488384564044410, 0.231537026158051940, 0.231585667173216490, 0.231634307609416890, 0.231682947466531510, 0.231731586744439190, 0.231780225443017460, 0.231828863562145190, +0.231877501101701190, 0.231926138061562980, 0.231974774441609440, 0.232023410241718960, 0.232072045461770400, 0.232120680101641270, 0.232169314161210480, 0.232217947640356360, +0.232266580538957820, 0.232315212856892410, 0.232363844594038970, 0.232412475750275900, 0.232461106325482090, 0.232509736319535060, 0.232558365732313700, 0.232606994563696430, +0.232655622813562110, 0.232704250481788280, 0.232752877568253860, 0.232801504072837200, 0.232850129995417240, 0.232898755335871540, 0.232947380094078920, 0.232996004269918290, +0.233044627863267210, 0.233093250874004590, 0.233141873302008810, 0.233190495147158810, 0.233239116409332120, 0.233287737088407640, 0.233336357184263820, 0.233384976696779540, +0.233433595625832380, 0.233482213971301230, 0.233530831733064550, 0.233579448911001240, 0.233628065504988850, 0.233676681514906310, 0.233725296940632040, 0.233773911782044990, +0.233822526039022730, 0.233871139711444130, 0.233919752799188140, 0.233968365302132330, 0.234016977220155600, 0.234065588553136420, 0.234114199300953730, 0.234162809463485080, +0.234211419040609410, 0.234260028032205190, 0.234308636438151360, 0.234357244258325490, 0.234405851492606510, 0.234454458140872870, 0.234503064203003570, 0.234551669678876140, +0.234600274568369540, 0.234648878871362270, 0.234697482587733240, 0.234746085717360050, 0.234794688260121650, 0.234843290215896980, 0.234891891584563640, 0.234940492366000560, +0.234989092560086270, 0.235037692166699670, 0.235086291185718390, 0.235134889617021420, 0.235183487460487200, 0.235232084715994690, 0.235280681383421560, 0.235329277462646700, +0.235377872953548670, 0.235426467856006380, 0.235475062169897470, 0.235523655895100940, 0.235572249031495230, 0.235620841578959350, 0.235669433537370940, 0.235718024906608950, +0.235766615686552330, 0.235815205877078720, 0.235863795478067100, 0.235912384489396000, 0.235960972910944370, 0.236009560742589890, 0.236058147984211490, 0.236106734635687710, +0.236155320696897540, 0.236203906167718640, 0.236252491048029980, 0.236301075337710080, 0.236349659036637900, 0.236398242144691180, 0.236446824661748850, 0.236495406587689440, +0.236543987922391950, 0.236592568665734080, 0.236641148817594770, 0.236689728377852600, 0.236738307346386510, 0.236786885723074240, 0.236835463507794770, 0.236884040700427070, +0.236932617300848800, 0.236981193308939020, 0.237029768724576260, 0.237078343547639490, 0.237126917778006460, 0.237175491415556110, 0.237224064460167030, 0.237272636911718240, +0.237321208770087390, 0.237369780035153550, 0.237418350706795260, 0.237466920784891510, 0.237515490269320030, 0.237564059159959850, 0.237612627456689480, 0.237661195159387990, +0.237709762267933080, 0.237758328782203790, 0.237806894702079080, 0.237855460027436710, 0.237904024758155700, 0.237952588894114610, 0.238001152435192490, 0.238049715381267040, +0.238098277732217340, 0.238146839487921920, 0.238195400648259840, 0.238243961213108810, 0.238292521182347890, 0.238341080555855680, 0.238389639333511180, 0.238438197515192160, +0.238486755100777630, 0.238535312090146220, 0.238583868483176980, 0.238632424279747620, 0.238680979479737210, 0.238729534083024770, 0.238778088089488080, 0.238826641499006150, +0.238875194311457650, 0.238923746526721550, 0.238972298144675690, 0.239020849165199060, 0.239069399588170330, 0.239117949413468510, 0.239166498640971390, 0.239215047270558030, +0.239263595302107060, 0.239312142735497530, 0.239360689570607190, 0.239409235807315160, 0.239457781445500010, 0.239506326485040860, 0.239554870925815460, 0.239603414767702860, +0.239651958010581730, 0.239700500654331160, 0.239749042698828880, 0.239797584143954020, 0.239846124989585600, 0.239894665235601460, 0.239943204881880650, 0.239991743928301830, +0.240040282374744090, 0.240088820221085190, 0.240137357467204240, 0.240185894112979910, 0.240234430158291300, 0.240282965603016150, 0.240331500447033580, 0.240380034690222290, +0.240428568332461320, 0.240477101373628520, 0.240525633813602950, 0.240574165652263310, 0.240622696889488650, 0.240671227525156850, 0.240719757559146990, 0.240768286991338150, +0.240816815821608160, 0.240865344049836120, 0.240913871675900730, 0.240962398699681110, 0.241010925121055040, 0.241059450939901660, 0.241107976156099660, 0.241156500769528160, +0.241205024780064950, 0.241253548187589210, 0.241302070991979560, 0.241350593193115190, 0.241399114790873920, 0.241447635785134840, 0.241496156175776660, 0.241544675962678560, +0.241593195145718310, 0.241641713724775080, 0.241690231699728000, 0.241738749070454890, 0.241787265836834940, 0.241835781998746810, 0.241884297556069630, 0.241932812508681320, +0.241981326856460950, 0.242029840599287280, 0.242078353737039430, 0.242126866269595260, 0.242175378196833930, 0.242223889518634160, 0.242272400234875090, 0.242320910345434600, +0.242369419850191840, 0.242417928749025490, 0.242466437041814780, 0.242514944728437540, 0.242563451808772950, 0.242611958282700160, 0.242660464150097010, 0.242708969410842750, +0.242757474064816040, 0.242805978111896080, 0.242854481551960740, 0.242902984384889190, 0.242951486610560180, 0.242999988228852880, 0.243048489239645200, 0.243096989642816290, +0.243145489438244910, 0.243193988625810240, 0.243242487205390160, 0.243290985176863840, 0.243339482540110090, 0.243387979295008050, 0.243436475441435620, 0.243484970979272020, +0.243533465908396000, 0.243581960228686720, 0.243630453940022110, 0.243678947042281380, 0.243727439535343730, 0.243775931419087020, 0.243824422693390500, 0.243872913358132910, +0.243921403413193490, 0.243969892858450110, 0.244018381693781980, 0.244066869919067920, 0.244115357534187120, 0.244163844539017490, 0.244212330933438250, 0.244260816717328190, +0.244309301890566520, 0.244357786453031130, 0.244406270404601310, 0.244454753745155800, 0.244503236474573840, 0.244551718592733360, 0.244600200099513580, 0.244648680994793750, +0.244697161278451760, 0.244745640950366880, 0.244794120010417890, 0.244842598458484020, 0.244891076294443260, 0.244939553518174790, 0.244988030129557420, 0.245036506128470420, +0.245084981514791720, 0.245133456288400580, 0.245181930449175800, 0.245230403996996610, 0.245278876931740970, 0.245327349253288170, 0.245375820961516970, 0.245424292056306640, +0.245472762537535170, 0.245521232405081810, 0.245569701658825770, 0.245618170298645050, 0.245666638324418900, 0.245715105736026170, 0.245763572533346100, 0.245812038716256680, +0.245860504284637150, 0.245908969238366360, 0.245957433577323580, 0.246005897301386780, 0.246054360410435240, 0.246102822904347790, 0.246151284783003740, 0.246199746046281030, +0.246248206694058950, 0.246296666726216360, 0.246345126142632540, 0.246393584943185470, 0.246442043127754420, 0.246490500696218280, 0.246538957648456320, 0.246587413984346530, +0.246635869703768220, 0.246684324806600630, 0.246732779292721830, 0.246781233162011090, 0.246829686414347240, 0.246878139049609620, 0.246926591067676200, 0.246975042468426330, +0.247023493251738830, 0.247071943417493060, 0.247120392965566980, 0.247168841895839900, 0.247217290208190750, 0.247265737902498780, 0.247314184978642050, 0.247362631436499860, +0.247411077275951070, 0.247459522496875060, 0.247507967099149770, 0.247556411082654580, 0.247604854447268790, 0.247653297192870440, 0.247701739319338840, 0.247750180826552900, +0.247798621714391900, 0.247847061982733960, 0.247895501631458350, 0.247943940660444010, 0.247992379069570220, 0.248040816858715040, 0.248089254027757860, 0.248137690576577500, +0.248186126505053370, 0.248234561813063500, 0.248282996500487210, 0.248331430567203440, 0.248379864013091510, 0.248428296838029500, 0.248476729041896740, 0.248525160624572610, +0.248573591585935120, 0.248622021925863660, 0.248670451644237150, 0.248718880740934960, 0.248767309215835090, 0.248815737068816990, 0.248864164299759520, 0.248912590908542090, +0.248961016895042740, 0.249009442259140850, 0.249057867000715360, 0.249106291119645630, 0.249154714615809740, 0.249203137489087070, 0.249251559739356560, 0.249299981366497560, +0.249348402370388190, 0.249396822750907830, 0.249445242507935820, 0.249493661641350280, 0.249542080151030580, 0.249590498036855680, 0.249638915298704990, 0.249687331936456560, +0.249735747949989790, 0.249784163339183680, 0.249832578103917570, 0.249880992244069590, 0.249929405759519140, 0.249977818650145150, 0.250026230915827040, 0.250074642556442960, +0.250123053571872260, 0.250171463961993910, 0.250219873726687360, 0.250268282865830690, 0.250316691379303290, 0.250365099266984190, 0.250413506528752720, 0.250461913164487130, +0.250510319174066690, 0.250558724557370880, 0.250607129314277870, 0.250655533444667070, 0.250703936948417360, 0.250752339825408290, 0.250800742075517890, 0.250849143698625650, +0.250897544694610560, 0.250945945063352050, 0.250994344804728260, 0.251042743918618580, 0.251091142404902050, 0.251139540263458080, 0.251187937494164850, 0.251236334096901770, +0.251284730071547830, 0.251333125417982530, 0.251381520136084000, 0.251429914225731630, 0.251478307686804900, 0.251526700519182020, 0.251575092722742370, 0.251623484297364970, +0.251671875242929280, 0.251720265559313480, 0.251768655246397020, 0.251817044304058930, 0.251865432732178710, 0.251913820530634380, 0.251962207699305550, 0.252010594238071210, +0.252058980146810770, 0.252107365425402520, 0.252155750073725820, 0.252204134091659700, 0.252252517479083730, 0.252300900235876040, 0.252349282361916060, 0.252397663857083340, +0.252446044721256040, 0.252494424954313570, 0.252542804556135090, 0.252591183526599980, 0.252639561865586500, 0.252687939572974140, 0.252736316648641930, 0.252784693092469370, +0.252833068904334600, 0.252881444084117170, 0.252929818631696170, 0.252978192546951030, 0.253026565829759960, 0.253074938480002510, 0.253123310497557650, 0.253171681882304990, +0.253220052634122730, 0.253268422752890300, 0.253316792238486800, 0.253365161090791770, 0.253413529309683420, 0.253461896895041230, 0.253510263846744690, 0.253558630164672120, +0.253606995848702940, 0.253655360898716260, 0.253703725314591680, 0.253752089096207280, 0.253800452243442720, 0.253848814756176990, 0.253897176634289620, 0.253945537877658940, +0.253993898486164380, 0.254042258459685090, 0.254090617798100600, 0.254138976501289080, 0.254187334569130170, 0.254235692001502920, 0.254284048798286870, 0.254332404959360210, +0.254380760484602620, 0.254429115373893510, 0.254477469627111210, 0.254525823244135200, 0.254574176224844630, 0.254622528569119100, 0.254670880276836760, 0.254719231347877270, +0.254767581782119670, 0.254815931579443600, 0.254864280739727220, 0.254912629262850130, 0.254960977148691480, 0.255009324397130810, 0.255057671008046440, 0.255106016981317850, +0.255154362316824260, 0.255202707014445140, 0.255251051074058820, 0.255299394495544950, 0.255347737278782960, 0.255396079423651220, 0.255444420930029280, 0.255492761797796230, +0.255541102026831780, 0.255589441617014130, 0.255637780568222840, 0.255686118880337150, 0.255734456553236570, 0.255782793586799400, 0.255831129980905290, 0.255879465735433300, +0.255927800850263120, 0.255976135325272970, 0.256024469160342550, 0.256072802355350900, 0.256121134910177680, 0.256169466824701210, 0.256217798098801020, 0.256266128732356820, +0.256314458725246890, 0.256362788077350750, 0.256411116788547670, 0.256459444858717240, 0.256507772287737750, 0.256556099075488820, 0.256604425221849670, 0.256652750726699850, +0.256701075589917780, 0.256749399811382950, 0.256797723390974670, 0.256846046328572500, 0.256894368624054790, 0.256942690277301160, 0.256991011288190800, 0.257039331656603360, +0.257087651382417130, 0.257135970465511790, 0.257184288905766500, 0.257232606703060920, 0.257280923857273410, 0.257329240368283580, 0.257377556235971080, 0.257425871460214280, +0.257474186040892780, 0.257522499977885840, 0.257570813271073060, 0.257619125920332810, 0.257667437925544750, 0.257715749286588140, 0.257764060003342510, 0.257812370075686360, +0.257860679503499280, 0.257908988286660480, 0.257957296425049610, 0.258005603918545100, 0.258053910767026610, 0.258102216970373330, 0.258150522528464930, 0.258198827441179780, +0.258247131708397530, 0.258295435329997940, 0.258343738305859330, 0.258392040635861350, 0.258440342319883280, 0.258488643357804750, 0.258536943749504200, 0.258585243494861340, +0.258633542593755320, 0.258681841046065900, 0.258730138851671400, 0.258778436010451580, 0.258826732522285720, 0.258875028387053400, 0.258923323604633100, 0.258971618174904490, +0.259019912097746830, 0.259068205373039820, 0.259116498000661890, 0.259164789980492690, 0.259213081312411940, 0.259261371996298060, 0.259309662032030760, 0.259357951419489310, +0.259406240158553400, 0.259454528249101420, 0.259502815691013190, 0.259551102484167910, 0.259599388628445280, 0.259647674123723750, 0.259695958969883010, 0.259744243166802390, +0.259792526714361650, 0.259840809612439110, 0.259889091860914520, 0.259937373459667280, 0.259985654408576960, 0.260033934707522120, 0.260082214356382400, 0.260130493355037180, +0.260178771703366170, 0.260227049401247750, 0.260275326448561770, 0.260323602845187850, 0.260371878591004520, 0.260420153685891500, 0.260468428129728090, 0.260516701922394010, +0.260564975063767800, 0.260613247553729110, 0.260661519392157310, 0.260709790578932120, 0.260758061113932070, 0.260806330997036820, 0.260854600228125790, 0.260902868807078640, +0.260951136733773960, 0.260999404008091350, 0.261047670629910300, 0.261095936599110460, 0.261144201915570360, 0.261192466579169780, 0.261240730589788420, 0.261288993947304870, +0.261337256651598790, 0.261385518702549560, 0.261433780100036980, 0.261482040843939500, 0.261530300934136930, 0.261578560370508640, 0.261626819152934340, 0.261675077281292580, +0.261723334755463110, 0.261771591575325310, 0.261819847740758950, 0.261868103251642560, 0.261916358107855910, 0.261964612309278370, 0.262012865855789700, 0.262061118747268450, +0.262109370983594440, 0.262157622564647420, 0.262205873490305890, 0.262254123760449650, 0.262302373374958150, 0.262350622333711150, 0.262398870636587120, 0.262447118283465950, +0.262495365274226950, 0.262543611608750000, 0.262591857286913590, 0.262640102308597520, 0.262688346673681180, 0.262736590382044440, 0.262784833433565790, 0.262833075828125040, +0.262881317565601620, 0.262929558645875310, 0.262977799068824680, 0.263026038834329570, 0.263074277942269790, 0.263122516392523880, 0.263170754184971660, 0.263218991319492560, +0.263267227795966450, 0.263315463614271830, 0.263363698774288500, 0.263411933275895960, 0.263460167118974020, 0.263508400303401220, 0.263556632829057450, 0.263604864695822060, +0.263653095903574940, 0.263701326452194680, 0.263749556341561050, 0.263797785571553590, 0.263846014142052050, 0.263894242052935100, 0.263942469304082490, 0.263990695895373770, +0.264038921826688700, 0.264087147097905870, 0.264135371708905220, 0.264183595659566510, 0.264231818949768440, 0.264280041579390780, 0.264328263548313070, 0.264376484856415070, +0.264424705503575500, 0.264472925489674100, 0.264521144814590440, 0.264569363478204310, 0.264617581480394330, 0.264665798821040410, 0.264714015500021990, 0.264762231517219000, +0.264810446872509990, 0.264858661565774810, 0.264906875596893020, 0.264955088965744490, 0.265003301672207760, 0.265051513716162810, 0.265099725097489470, 0.265147935816066440, +0.265196145871773540, 0.265244355264490250, 0.265292563994096510, 0.265340772060470960, 0.265388979463493490, 0.265437186203043520, 0.265485392279001030, 0.265533597691244680, +0.265581802439654290, 0.265630006524109400, 0.265678209944489930, 0.265726412700674490, 0.265774614792543050, 0.265822816219975060, 0.265871016982850430, 0.265919217081047880, +0.265967416514447220, 0.266015615282928500, 0.266063813386370310, 0.266112010824652580, 0.266160207597654800, 0.266208403705256950, 0.266256599147337680, 0.266304793923776870, +0.266352988034454120, 0.266401181479249290, 0.266449374258041110, 0.266497566370709480, 0.266545757817133910, 0.266593948597194430, 0.266642138710769640, 0.266690328157739460, +0.266738516937983510, 0.266786705051381630, 0.266834892497812610, 0.266883079277156320, 0.266931265389292400, 0.266979450834100680, 0.267027635611459920, 0.267075819721250110, +0.267124003163351110, 0.267172185937641750, 0.267220368044001840, 0.267268549482311100, 0.267316730252449340, 0.267364910354295380, 0.267413089787729100, 0.267461268552630140, +0.267509446648878440, 0.267557624076352640, 0.267605800834932790, 0.267653976924498490, 0.267702152344929610, 0.267750327096104970, 0.267798501177904490, 0.267846674590207780, +0.267894847332894810, 0.267943019405844250, 0.267991190808936190, 0.268039361542050550, 0.268087531605066100, 0.268135700997862820, 0.268183869720320270, 0.268232037772318470, +0.268280205153736180, 0.268328371864453350, 0.268376537904349620, 0.268424703273304920, 0.268472867971198070, 0.268521031997909050, 0.268569195353317470, 0.268617358037303300, +0.268665520049745310, 0.268713681390523540, 0.268761842059517530, 0.268810002056607380, 0.268858161381671790, 0.268906320034590750, 0.268954478015244410, 0.269002635323511430, +0.269050791959271840, 0.269098947922405240, 0.269147103212791730, 0.269195257830310060, 0.269243411774840240, 0.269291565046261840, 0.269339717644455020, 0.269387869569298440, +0.269436020820672200, 0.269484171398455870, 0.269532321302529580, 0.269580470532772070, 0.269628619089063330, 0.269676766971283120, 0.269724914179311330, 0.269773060713026870, +0.269821206572309790, 0.269869351757040080, 0.269917496267096600, 0.269965640102359350, 0.270013783262707970, 0.270061925748022620, 0.270110067558182010, 0.270158208693066230, +0.270206349152554930, 0.270254488936528150, 0.270302628044864770, 0.270350766477444770, 0.270398904234147920, 0.270447041314854200, 0.270495177719442430, 0.270543313447792750, +0.270591448499784780, 0.270639582875298600, 0.270687716574213030, 0.270735849596408170, 0.270783981941763730, 0.270832113610159690, 0.270880244601474970, 0.270928374915589690, +0.270976504552383870, 0.271024633511736330, 0.271072761793527240, 0.271120889397636230, 0.271169016323943410, 0.271217142572327650, 0.271265268142668990, 0.271313393034847190, +0.271361517248742360, 0.271409640784233300, 0.271457763641200110, 0.271505885819522510, 0.271554007319080640, 0.271602128139753320, 0.271650248281420700, 0.271698367743962440, +0.271746486527258690, 0.271794604631188260, 0.271842722055631370, 0.271890838800468100, 0.271938954865577290, 0.271987070250839070, 0.272035184956133210, 0.272083298981339820, +0.272131412326337750, 0.272179524991007120, 0.272227636975227730, 0.272275748278879630, 0.272323858901841740, 0.272371968843994230, 0.272420078105216730, 0.272468186685389520, +0.272516294584391420, 0.272564401802102560, 0.272612508338402730, 0.272660614193172000, 0.272708719366289320, 0.272756823857634890, 0.272804927667088800, 0.272853030794529940, +0.272901133239838500, 0.272949235002894250, 0.272997336083577350, 0.273045436481766710, 0.273093536197342450, 0.273141635230184310, 0.273189733580172570, 0.273237831247186040, +0.273285928231104920, 0.273334024531808990, 0.273382120149178400, 0.273430215083092120, 0.273478309333430310, 0.273526402900072680, 0.273574495782899500, 0.273622587981789680, +0.273670679496623380, 0.273718770327280370, 0.273766860473640850, 0.273814949935583750, 0.273863038712989280, 0.273911126805737650, 0.273959214213707780, 0.274007300936779830, +0.274055386974833670, 0.274103472327749450, 0.274151556995406160, 0.274199640977683960, 0.274247724274462650, 0.274295806885622440, 0.274343888811042270, 0.274391970050602450, +0.274440050604182640, 0.274488130471663150, 0.274536209652922910, 0.274584288147842190, 0.274632365956300690, 0.274680443078178740, 0.274728519513355200, 0.274776595261710390, +0.274824670323124580, 0.274872744697476580, 0.274920818384646770, 0.274968891384514860, 0.275016963696961210, 0.275065035321864710, 0.275113106259105620, 0.275161176508563750, +0.275209246070119370, 0.275257314943651410, 0.275305383129040240, 0.275353450626165560, 0.275401517434907710, 0.275449583555145590, 0.275497648986759550, 0.275545713729629380, +0.275593777783635360, 0.275641841148656470, 0.275689903824572980, 0.275737965811265140, 0.275786027108612000, 0.275834087716493760, 0.275882147634790300, 0.275930206863381880, +0.275978265402147540, 0.276026323250967540, 0.276074380409721710, 0.276122436878290360, 0.276170492656552520, 0.276218547744388420, 0.276266602141677970, 0.276314655848301450, +0.276362708864137830, 0.276410761189067430, 0.276458812822970190, 0.276506863765726310, 0.276554914017214830, 0.276602963577316060, 0.276651012445910340, 0.276699060622876640, +0.276747108108095270, 0.276795154901446180, 0.276843201002809570, 0.276891246412064580, 0.276939291129091440, 0.276987335153770110, 0.277035378485980870, 0.277083421125602750, +0.277131463072516020, 0.277179504326600710, 0.277227544887737040, 0.277275584755804050, 0.277323623930682110, 0.277371662412251140, 0.277419700200391420, 0.277467737294982030, +0.277515773695903300, 0.277563809403035100, 0.277611844416257860, 0.277659878735450560, 0.277707912360493530, 0.277755945291267180, 0.277803977527650510, 0.277852009069523950, +0.277900039916767320, 0.277948070069261030, 0.277996099526884140, 0.278044128289517020, 0.278092156357039600, 0.278140183729332140, 0.278188210406273840, 0.278236236387745030, +0.278284261673625580, 0.278332286263795970, 0.278380310158135140, 0.278428333356523620, 0.278476355858841170, 0.278524377664968350, 0.278572398774784070, 0.278620419188168880, +0.278668438905003040, 0.278716457925165640, 0.278764476248537120, 0.278812493874997400, 0.278860510804426860, 0.278908527036704660, 0.278956542571711100, 0.279004557409326230, +0.279052571549430360, 0.279100584991902660, 0.279148597736623480, 0.279196609783472770, 0.279244621132331010, 0.279292631783077280, 0.279340641735591920, 0.279388650989755020, +0.279436659545446890, 0.279484667402546630, 0.279532674560934780, 0.279580681020491660, 0.279628686781096370, 0.279676691842629390, 0.279724696204970650, 0.279772699868000630, +0.279820702831598430, 0.279868705095644490, 0.279916706660018780, 0.279964707524601670, 0.280012707689272440, 0.280060707153911400, 0.280108705918398590, 0.280156703982614500, +0.280204701346438160, 0.280252698009750060, 0.280300693972430240, 0.280348689234359130, 0.280396683795415880, 0.280444677655480870, 0.280492670814434190, 0.280540663272156270, +0.280588655028526260, 0.280636646083424590, 0.280684636436731750, 0.280732626088326890, 0.280780615038090490, 0.280828603285902530, 0.280876590831643460, 0.280924577675192520, +0.280972563816430150, 0.281020549255236340, 0.281068533991491560, 0.281116518025075090, 0.281164501355867290, 0.281212483983748210, 0.281260465908598380, 0.281308447130296960, +0.281356427648724430, 0.281404407463760780, 0.281452386575286590, 0.281500364983180980, 0.281548342687324480, 0.281596319687597520, 0.281644295983879360, 0.281692271576050480, +0.281740246463990870, 0.281788220647581080, 0.281836194126700360, 0.281884166901229080, 0.281932138971047460, 0.281980110336035870, 0.282028080996073570, 0.282076050951041100, +0.282124020200818500, 0.282171988745286260, 0.282219956584323640, 0.282267923717811120, 0.282315890145628800, 0.282363855867657170, 0.282411820883775420, 0.282459785193864220, +0.282507748797803940, 0.282555711695473830, 0.282603673886754450, 0.282651635371525930, 0.282699596149668720, 0.282747556221062070, 0.282795515585586580, 0.282843474243122280, +0.282891432193549670, 0.282939389436748120, 0.282987345972598060, 0.283035301800979690, 0.283083256921773440, 0.283131211334858630, 0.283179165040115810, 0.283227118037425060, +0.283275070326666930, 0.283323021907720740, 0.283370972780466970, 0.283418922944785770, 0.283466872400557680, 0.283514821147661970, 0.283562769185979220, 0.283610716515389990, +0.283658663135773540, 0.283706609047010390, 0.283754554248980770, 0.283802498741565160, 0.283850442524642920, 0.283898385598094550, 0.283946327961800190, 0.283994269615640450, +0.284042210559494630, 0.284090150793243290, 0.284138090316766510, 0.284186029129945010, 0.284233967232657980, 0.284281904624786030, 0.284329841306209310, 0.284377777276808410, +0.284425712536462650, 0.284473647085052570, 0.284521580922458880, 0.284569514048560730, 0.284617446463238830, 0.284665378166373330, 0.284713309157844820, 0.284761239437532570, +0.284809169005317280, 0.284857097861078990, 0.284905026004698410, 0.284952953436054870, 0.285000880155028950, 0.285048806161500800, 0.285096731455351030, 0.285144656036459050, +0.285192579904705420, 0.285240503059970340, 0.285288425502134460, 0.285336347231077040, 0.285384268246678790, 0.285432188548820240, 0.285480108137380840, 0.285528027012241170, +0.285575945173281440, 0.285623862620382250, 0.285671779353422970, 0.285719695372284250, 0.285767610676846310, 0.285815525266989780, 0.285863439142593990, 0.285911352303539590, +0.285959264749706840, 0.286007176480976290, 0.286055087497227470, 0.286102997798340860, 0.286150907384196740, 0.286198816254675860, 0.286246724409657430, 0.286294631849022260, +0.286342538572650910, 0.286390444580422730, 0.286438349872218500, 0.286486254447918360, 0.286534158307403090, 0.286582061450551930, 0.286629963877245600, 0.286677865587364410, +0.286725766580788970, 0.286773666857398690, 0.286821566417074180, 0.286869465259695810, 0.286917363385144230, 0.286965260793298760, 0.287013157484040160, 0.287061053457248690, +0.287108948712805010, 0.287156843250588490, 0.287204737070479890, 0.287252630172359470, 0.287300522556107830, 0.287348414221604510, 0.287396305168730160, 0.287444195397365430, +0.287492084907389810, 0.287539973698684000, 0.287587861771128270, 0.287635749124603270, 0.287683635758988480, 0.287731521674164600, 0.287779406870011910, 0.287827291346411160, +0.287875175103241730, 0.287923058140384380, 0.287970940457719370, 0.288018822055127410, 0.288066702932487980, 0.288114583089681800, 0.288162462526589170, 0.288210341243090810, +0.288258219239066190, 0.288306096514395980, 0.288353973068960990, 0.288401848902640650, 0.288449724015315660, 0.288497598406866400, 0.288545472077173510, 0.288593345026116550, +0.288641217253576220, 0.288689088759432830, 0.288736959543567150, 0.288784829605858660, 0.288832698946188130, 0.288880567564435810, 0.288928435460482470, 0.288976302634207650, +0.289024169085492060, 0.289072034814216060, 0.289119899820260430, 0.289167764103504590, 0.289215627663829360, 0.289263490501115440, 0.289311352615242380, 0.289359214006090990, +0.289407074673541490, 0.289454934617474790, 0.289502793837770330, 0.289550652334308820, 0.289598510106970740, 0.289646367155636800, 0.289694223480186530, 0.289742079080500650, +0.289789933956459630, 0.289837788107944140, 0.289885641534833820, 0.289933494237009370, 0.289981346214351180, 0.290029197466740050, 0.290077047994055480, 0.290124897796178340, +0.290172746872988880, 0.290220595224368050, 0.290268442850195260, 0.290316289750351400, 0.290364135924717210, 0.290411981373172310, 0.290459826095597400, 0.290507670091872950, +0.290555513361879740, 0.290603355905497300, 0.290651197722606500, 0.290699038813087730, 0.290746879176821740, 0.290794718813688120, 0.290842557723567760, 0.290890395906340970, +0.290938233361888620, 0.290986070090090250, 0.291033906090826740, 0.291081741363978410, 0.291129575909426170, 0.291177409727049590, 0.291225242816729510, 0.291273075178346720, +0.291320906811780800, 0.291368737716912630, 0.291416567893622580, 0.291464397341791580, 0.291512226061299120, 0.291560054052026120, 0.291607881313853010, 0.291655707846660620, +0.291703533650328470, 0.291751358724737560, 0.291799183069768210, 0.291847006685301340, 0.291894829571216540, 0.291942651727394640, 0.291990473153716120, 0.292038293850061860, +0.292086113816311440, 0.292133933052345700, 0.292181751558045600, 0.292229569333290640, 0.292277386377961800, 0.292325202691939510, 0.292373018275104590, 0.292420833127336740, +0.292468647248516790, 0.292516460638525210, 0.292564273297242940, 0.292612085224549510, 0.292659896420325920, 0.292707706884452520, 0.292755516616810320, 0.292803325617278950, +0.292851133885739190, 0.292898941422071620, 0.292946748226157130, 0.292994554297875350, 0.293042359637107170, 0.293090164243733520, 0.293137968117634040, 0.293185771258689660, +0.293233573666780820, 0.293281375341788500, 0.293329176283592290, 0.293376976492073120, 0.293424775967111530, 0.293472574708588450, 0.293520372716383480, 0.293568169990377600, +0.293615966530451300, 0.293663762336485450, 0.293711557408359860, 0.293759351745955300, 0.293807145349152370, 0.293854938217832040, 0.293902730351873920, 0.293950521751158990, +0.293998312415567730, 0.294046102344981130, 0.294093891539278840, 0.294141679998341790, 0.294189467722051010, 0.294237254710286110, 0.294285040962928120, 0.294332826479857480, +0.294380611260955220, 0.294428395306100990, 0.294476178615175830, 0.294523961188060180, 0.294571743024635010, 0.294619524124780100, 0.294667304488376410, 0.294715084115304390, +0.294762863005445130, 0.294810641158678280, 0.294858418574884820, 0.294906195253945350, 0.294953971195740790, 0.295001746400150870, 0.295049520867056550, 0.295097294596338930, +0.295145067587877620, 0.295192839841553590, 0.295240611357247500, 0.295288382134840320, 0.295336152174211770, 0.295383921475242780, 0.295431690037814050, 0.295479457861806460, +0.295527224947099880, 0.295574991293575170, 0.295622756901113000, 0.295670521769594350, 0.295718285898899040, 0.295766049288907930, 0.295813811939501740, 0.295861573850561440, +0.295909335021966760, 0.295957095453598770, 0.296004855145338470, 0.296052614097065570, 0.296100372308661150, 0.296148129780005820, 0.296195886510980610, 0.296243642501465180, +0.296291397751340720, 0.296339152260487740, 0.296386906028787310, 0.296434659056119150, 0.296482411342364360, 0.296530162887403580, 0.296577913691117800, 0.296625663753386780, +0.296673413074091620, 0.296721161653112960, 0.296768909490331800, 0.296816656585627950, 0.296864402938882390, 0.296912148549975890, 0.296959893418789420, 0.297007637545202820, +0.297055380929097110, 0.297103123570353400, 0.297150865468851390, 0.297198606624472280, 0.297246347037096630, 0.297294086706605510, 0.297341825632878750, 0.297389563815797450, +0.297437301255242260, 0.297485037951094210, 0.297532773903233180, 0.297580509111540160, 0.297628243575895900, 0.297675977296181450, 0.297723710272276620, 0.297771442504062570, +0.297819173991419880, 0.297866904734229660, 0.297914634732371730, 0.297962363985727290, 0.298010092494177310, 0.298057820257601690, 0.298105547275881510, 0.298153273548897480, +0.298200999076530690, 0.298248723858660970, 0.298296447895169400, 0.298344171185936760, 0.298391893730844130, 0.298439615529771270, 0.298487336582599460, 0.298535056889209230, +0.298582776449481830, 0.298630495263297050, 0.298678213330536070, 0.298725930651079500, 0.298773647224808540, 0.298821363051603060, 0.298869078131344170, 0.298916792463913010, +0.298964506049189390, 0.299012218887054590, 0.299059930977389200, 0.299107642320074420, 0.299155352914990070, 0.299203062762017360, 0.299250771861036990, 0.299298480211930170, +0.299346187814576670, 0.299393894668857690, 0.299441600774653980, 0.299489306131846710, 0.299537010740315750, 0.299584714599942290, 0.299632417710607000, 0.299680120072191140, +0.299727821684574510, 0.299775522547638340, 0.299823222661263770, 0.299870922025330720, 0.299918620639720410, 0.299966318504313490, 0.300014015618991210, 0.300061711983633520, +0.300109407598121490, 0.300157102462335960, 0.300204796576158120, 0.300252489939467850, 0.300300182552146360, 0.300347874414074400, 0.300395565525133190, 0.300443255885202600, +0.300490945494163940, 0.300538634351897870, 0.300586322458285650, 0.300634009813207200, 0.300681696416543740, 0.300729382268176030, 0.300777067367985260, 0.300824751715851440, +0.300872435311655690, 0.300920118155279360, 0.300967800246602250, 0.301015481585505620, 0.301063162171870350, 0.301110842005577530, 0.301158521086507200, 0.301206199414540630, +0.301253876989558520, 0.301301553811442140, 0.301349229880071400, 0.301396905195327640, 0.301444579757091600, 0.301492253565244560, 0.301539926619666440, 0.301587598920238510, +0.301635270466841580, 0.301682941259356910, 0.301730611297664490, 0.301778280581645460, 0.301825949111181210, 0.301873616886151660, 0.301921283906438080, 0.301968950171921270, +0.302016615682482500, 0.302064280438001760, 0.302111944438360370, 0.302159607683439080, 0.302207270173119210, 0.302254931907280700, 0.302302592885804910, 0.302350253108572610, +0.302397912575465110, 0.302445571286362400, 0.302493229241145800, 0.302540886439696070, 0.302588542881894570, 0.302636198567621310, 0.302683853496757530, 0.302731507669184550, +0.302779161084782370, 0.302826813743432290, 0.302874465645015130, 0.302922116789412330, 0.302969767176503760, 0.303017416806170730, 0.303065065678294220, 0.303112713792755450, +0.303160361149434450, 0.303208007748212600, 0.303255653588970660, 0.303303298671590060, 0.303350942995950780, 0.303398586561934140, 0.303446229369421060, 0.303493871418292820, +0.303541512708429440, 0.303589153239712310, 0.303636793012022290, 0.303684432025240700, 0.303732070279247650, 0.303779707773924380, 0.303827344509152280, 0.303874980484811370, +0.303922615700783050, 0.303970250156948170, 0.304017883853188060, 0.304065516789382870, 0.304113148965413860, 0.304160780381162010, 0.304208411036508590, 0.304256040931333740, +0.304303670065518780, 0.304351298438944650, 0.304398926051492660, 0.304446552903043010, 0.304494178993476920, 0.304541804322675410, 0.304589428890519760, 0.304637052696890180, +0.304684675741667970, 0.304732298024734450, 0.304779919545969780, 0.304827540305255270, 0.304875160302471970, 0.304922779537501190, 0.304970398010223020, 0.305018015720518840, +0.305065632668269640, 0.305113248853356780, 0.305160864275660360, 0.305208478935061810, 0.305256092831442060, 0.305303705964682480, 0.305351318334663220, 0.305398929941265660, +0.305446540784370780, 0.305494150863859950, 0.305541760179613320, 0.305589368731512320, 0.305636976519438330, 0.305684583543271440, 0.305732189802893130, 0.305779795298184330, +0.305827400029026420, 0.305875003995299650, 0.305922607196885350, 0.305970209633664500, 0.306017811305518580, 0.306065412212327690, 0.306113012353973310, 0.306160611730336370, +0.306208210341298300, 0.306255808186739360, 0.306303405266540820, 0.306351001580583810, 0.306398597128749730, 0.306446191910918650, 0.306493785926972180, 0.306541379176791640, +0.306588971660257230, 0.306636563377250370, 0.306684154327652110, 0.306731744511343940, 0.306779333928205940, 0.306826922578119610, 0.306874510460965980, 0.306922097576626470, +0.306969683924981310, 0.307017269505911960, 0.307064854319299420, 0.307112438365025160, 0.307160021642969350, 0.307207604153013570, 0.307255185895038700, 0.307302766868926320, +0.307350347074556610, 0.307397926511811030, 0.307445505180570620, 0.307493083080716880, 0.307540660212130000, 0.307588236574691480, 0.307635812168282790, 0.307683386992784190, +0.307730961048077070, 0.307778534334042560, 0.307826106850562110, 0.307873678597516020, 0.307921249574785670, 0.307968819782252270, 0.308016389219797180, 0.308063957887300730, +0.308111525784644400, 0.308159092911709230, 0.308206659268376760, 0.308254224854527190, 0.308301789670042070, 0.308349353714802490, 0.308396916988689930, 0.308444479491584710, +0.308492041223368210, 0.308539602183922070, 0.308587162373126560, 0.308634721790863040, 0.308682280437012790, 0.308729838311457230, 0.308777395414076670, 0.308824951744752610, +0.308872507303366130, 0.308920062089798890, 0.308967616103930980, 0.309015169345644100, 0.309062721814819250, 0.309110273511338070, 0.309157824435080720, 0.309205374585928890, +0.309252923963763580, 0.309300472568466380, 0.309348020399917540, 0.309395567457998680, 0.309443113742591370, 0.309490659253575770, 0.309538203990833590, 0.309585747954245870, +0.309633291143694200, 0.309680833559058900, 0.309728375200221510, 0.309775916067063170, 0.309823456159465490, 0.309870995477308730, 0.309918534020474480, 0.309966071788843890, +0.310013608782298500, 0.310061145000718740, 0.310108680443986100, 0.310156215111981710, 0.310203749004587250, 0.310251282121683010, 0.310298814463150550, 0.310346346028871010, +0.310393876818726100, 0.310441406832596020, 0.310488936070362430, 0.310536464531906970, 0.310583992217109860, 0.310631519125852850, 0.310679045258016980, 0.310726570613483910, +0.310774095192134060, 0.310821618993848910, 0.310869142018509740, 0.310916664265998120, 0.310964185736194390, 0.311011706428980240, 0.311059226344236830, 0.311106745481845750, +0.311154263841687430, 0.311201781423643410, 0.311249298227594890, 0.311296814253423650, 0.311344329501009880, 0.311391843970235280, 0.311439357660981580, 0.311486870573128960, +0.311534382706559200, 0.311581894061153500, 0.311629404636793510, 0.311676914433359540, 0.311724423450733310, 0.311771931688796020, 0.311819439147429270, 0.311866945826513590, +0.311914451725930460, 0.311961956845561270, 0.312009461185287550, 0.312056964744989780, 0.312104467524549620, 0.312151969523848270, 0.312199470742767440, 0.312246971181187490, +0.312294470838990090, 0.312341969716056990, 0.312389467812268510, 0.312436965127506350, 0.312484461661651840, 0.312531957414586500, 0.312579452386190890, 0.312626946576346710, +0.312674439984935100, 0.312721932611837780, 0.312769424456935290, 0.312816915520109210, 0.312864405801240810, 0.312911895300211850, 0.312959384016902710, 0.313006871951195090, +0.313054359102970300, 0.313101845472110060, 0.313149331058494800, 0.313196815862006210, 0.313244299882525950, 0.313291783119934550, 0.313339265574113680, 0.313386747244944700, +0.313434228132309200, 0.313481708236087730, 0.313529187556161990, 0.313576666092413300, 0.313624143844723370, 0.313671620812972620, 0.313719096997042870, 0.313766572396815320, +0.313814047012171800, 0.313861520842992740, 0.313908993889159880, 0.313956466150554560, 0.314003937627058420, 0.314051408318552050, 0.314098878224917220, 0.314146347346035140, +0.314193815681787610, 0.314241283232055080, 0.314288749996719410, 0.314336215975662250, 0.314383681168764140, 0.314431145575906850, 0.314478609196971680, 0.314526072031840410, +0.314573534080393510, 0.314620995342512810, 0.314668455818079620, 0.314715915506975700, 0.314763374409081590, 0.314810832524278990, 0.314858289852449350, 0.314905746393474410, +0.314953202147234660, 0.315000657113611910, 0.315048111292487550, 0.315095564683743280, 0.315143017287259740, 0.315190469102918590, 0.315237920130601760, 0.315285370370189670, +0.315332819821564140, 0.315380268484606600, 0.315427716359198750, 0.315475163445221250, 0.315522609742555800, 0.315570055251083840, 0.315617499970687170, 0.315664943901246330, +0.315712387042643150, 0.315759829394758940, 0.315807270957475630, 0.315854711730673700, 0.315902151714235020, 0.315949590908040920, 0.315997029311973270, 0.316044466925912650, +0.316091903749740830, 0.316139339783339690, 0.316186775026589820, 0.316234209479372970, 0.316281643141570590, 0.316329076013064540, 0.316376508093735350, 0.316423939383464910, +0.316471369882134650, 0.316518799589626370, 0.316566228505820670, 0.316613656630599370, 0.316661083963843960, 0.316708510505436250, 0.316755936255256830, 0.316803361213187580, +0.316850785379109930, 0.316898208752905750, 0.316945631334455640, 0.316993053123641400, 0.317040474120344530, 0.317087894324446950, 0.317135313735829210, 0.317182732354373110, +0.317230150179960650, 0.317277567212472410, 0.317324983451790220, 0.317372398897795620, 0.317419813550370410, 0.317467227409395260, 0.317514640474751970, 0.317562052746322150, +0.317609464223987610, 0.317656874907629010, 0.317704284797128200, 0.317751693892366680, 0.317799102193226320, 0.317846509699587830, 0.317893916411333020, 0.317941322328343430, +0.317988727450501000, 0.318036131777686300, 0.318083535309781230, 0.318130938046667810, 0.318178339988226590, 0.318225741134339490, 0.318273141484888110, 0.318320541039754270, +0.318367939798818610, 0.318415337761963180, 0.318462734929069350, 0.318510131300019090, 0.318557526874693130, 0.318604921652973330, 0.318652315634741220, 0.318699708819878750, +0.318747101208266600, 0.318794492799786670, 0.318841883594320530, 0.318889273591750070, 0.318936662791956040, 0.318984051194820320, 0.319031438800224940, 0.319078825608050510, +0.319126211618179000, 0.319173596830492010, 0.319220981244871420, 0.319268364861197970, 0.319315747679353610, 0.319363129699219870, 0.319410510920678680, 0.319457891343610860, +0.319505270967898270, 0.319552649793422520, 0.319600027820065580, 0.319647405047708170, 0.319694781476232200, 0.319742157105519290, 0.319789531935451400, 0.319836905965909250, +0.319884279196774870, 0.319931651627930190, 0.319979023259255980, 0.320026394090634210, 0.320073764121946440, 0.320121133353074680, 0.320168501783899660, 0.320215869414303410, +0.320263236244167470, 0.320310602273373880, 0.320357967501803340, 0.320405331929337900, 0.320452695555859090, 0.320500058381249010, 0.320547420405388360, 0.320594781628159130, +0.320642142049442970, 0.320689501669121860, 0.320736860487076560, 0.320784218503189170, 0.320831575717341170, 0.320878932129414710, 0.320926287739290440, 0.320973642546850460, +0.321020996551976800, 0.321068349754550290, 0.321115702154452840, 0.321163053751566120, 0.321210404545772210, 0.321257754536951880, 0.321305103724987160, 0.321352452109759710, +0.321399799691151510, 0.321447146469043380, 0.321494492443317400, 0.321541837613855190, 0.321589181980538820, 0.321636525543249060, 0.321683868301868010, 0.321731210256277270, +0.321778551406358910, 0.321825891751993780, 0.321873231293063890, 0.321920570029451350, 0.321967907961036970, 0.322015245087702850, 0.322062581409330580, 0.322109916925802320, +0.322157251636998820, 0.322204585542802180, 0.322251918643094050, 0.322299250937756580, 0.322346582426670580, 0.322393913109718100, 0.322441242986780840, 0.322488572057740900, +0.322535900322479090, 0.322583227780877560, 0.322630554432817910, 0.322677880278182340, 0.322725205316851670, 0.322772529548707940, 0.322819852973633300, 0.322867175591508630, +0.322914497402216010, 0.322961818405637200, 0.323009138601654200, 0.323056457990147930, 0.323103776571000530, 0.323151094344093730, 0.323198411309309600, 0.323245727466528960, +0.323293042815634090, 0.323340357356506570, 0.323387671089028550, 0.323434984013080960, 0.323482296128545900, 0.323529607435305120, 0.323576917933240730, 0.323624227622233640, +0.323671536502165960, 0.323718844572919440, 0.323766151834376240, 0.323813458286417220, 0.323860763928924600, 0.323908068761780410, 0.323955372784865690, 0.324002675998062540, +0.324049978401252660, 0.324097279994318310, 0.324144580777140310, 0.324191880749600870, 0.324239179911581690, 0.324286478262965030, 0.324333775803631710, 0.324381072533463990, +0.324428368452343570, 0.324475663560152620, 0.324522957856772150, 0.324570251342084230, 0.324617544015970700, 0.324664835878313740, 0.324712126928994320, 0.324759417167894530, +0.324806706594896580, 0.324853995209881510, 0.324901283012731410, 0.324948570003328110, 0.324995856181553850, 0.325043141547289470, 0.325090426100417270, 0.325137709840818970, +0.325184992768376870, 0.325232274882971790, 0.325279556184486120, 0.325326836672801490, 0.325374116347800220, 0.325421395209363200, 0.325468673257372720, 0.325515950491710560, +0.325563226912258970, 0.325610502518898840, 0.325657777311512460, 0.325705051289982120, 0.325752324454188670, 0.325799596804014440, 0.325846868339341180, 0.325894139060051210, +0.325941408966025470, 0.325988678057146150, 0.326035946333295190, 0.326083213794354790, 0.326130480440205930, 0.326177746270730870, 0.326225011285811380, 0.326272275485329890, +0.326319538869167200, 0.326366801437205700, 0.326414063189327200, 0.326461324125413950, 0.326508584245347010, 0.326555843549008570, 0.326603102036280960, 0.326650359707045150, +0.326697616561183460, 0.326744872598577710, 0.326792127819110210, 0.326839382222661960, 0.326886635809115260, 0.326933888578351980, 0.326981140530254400, 0.327028391664703540, +0.327075641981581730, 0.327122891480770780, 0.327170140162153010, 0.327217388025609510, 0.327264635071022550, 0.327311881298273930, 0.327359126707246100, 0.327406371297820020, +0.327453615069877970, 0.327500858023301920, 0.327548100157974140, 0.327595341473775670, 0.327642581970588880, 0.327689821648296020, 0.327737060506778200, 0.327784298545917730, +0.327831535765596540, 0.327878772165696890, 0.327926007746099920, 0.327973242506687910, 0.328020476447342780, 0.328067709567946900, 0.328114941868381360, 0.328162173348528430, +0.328209404008270030, 0.328256633847488600, 0.328303862866065170, 0.328351091063882050, 0.328398318440821180, 0.328445544996764980, 0.328492770731594500, 0.328539995645192040, +0.328587219737440040, 0.328634443008219590, 0.328681665457413010, 0.328728887084902280, 0.328776107890569770, 0.328823327874296520, 0.328870547035965020, 0.328917765375457080, +0.328964982892655190, 0.329012199587440380, 0.329059415459695140, 0.329106630509301330, 0.329153844736141340, 0.329201058140096310, 0.329248270721048670, 0.329295482478880350, +0.329342693413473770, 0.329389903524709980, 0.329437112812471460, 0.329484321276640570, 0.329531528917098470, 0.329578735733727530, 0.329625941726409740, 0.329673146895027580, +0.329720351239462080, 0.329767554759595680, 0.329814757455310470, 0.329861959326488710, 0.329909160373011660, 0.329956360594761740, 0.330003559991620900, 0.330050758563471550, +0.330097956310194900, 0.330145153231673370, 0.330192349327788960, 0.330239544598424080, 0.330286739043459900, 0.330333932662778940, 0.330381125456263080, 0.330428317423794860, +0.330475508565255430, 0.330522698880527210, 0.330569888369492690, 0.330617077032032970, 0.330664264868030630, 0.330711451877367610, 0.330758638059926340, 0.330805823415588120, +0.330853007944235280, 0.330900191645749960, 0.330947374520014550, 0.330994556566910290, 0.331041737786319680, 0.331088918178124690, 0.331136097742207810, 0.331183276478450310, +0.331230454386734540, 0.331277631466942720, 0.331324807718957230, 0.331371983142659250, 0.331419157737931350, 0.331466331504655990, 0.331513504442714320, 0.331560676551988950, +0.331607847832361860, 0.331655018283715570, 0.331702187905931310, 0.331749356698891610, 0.331796524662478500, 0.331843691796574520, 0.331890858101060840, 0.331938023575820080, +0.331985188220734200, 0.332032352035685820, 0.332079515020556100, 0.332126677175227590, 0.332173838499582430, 0.332220998993503050, 0.332268158656870820, 0.332315317489568110, +0.332362475491477570, 0.332409632662480410, 0.332456789002459170, 0.332503944511296000, 0.332551099188873320, 0.332598253035072510, 0.332645406049776050, 0.332692558232866090, +0.332739709584225160, 0.332786860103734540, 0.332834009791276750, 0.332881158646733900, 0.332928306669988630, 0.332975453860922140, 0.333022600219417040, 0.333069745745355470, +0.333116890438619920, 0.333164034299091690, 0.333211177326653400, 0.333258319521187620, 0.333305460882575570, 0.333352601410699890, 0.333399741105442740, 0.333446879966686590, +0.333494017994312890, 0.333541155188204100, 0.333588291548242430, 0.333635427074310490, 0.333682561766289520, 0.333729695624062130, 0.333776828647510570, 0.333823960836517280, +0.333871092190963730, 0.333918222710732400, 0.333965352395705520, 0.334012481245765710, 0.334059609260794250, 0.334106736440673790, 0.334153862785286470, 0.334200988294514940, +0.334248112968240470, 0.334295236806345760, 0.334342359808713350, 0.334389481975224670, 0.334436603305762250, 0.334483723800208300, 0.334530843458445530, 0.334577962280355190, +0.334625080265819940, 0.334672197414721980, 0.334719313726943970, 0.334766429202367210, 0.334813543840874420, 0.334860657642347740, 0.334907770606669870, 0.334954882733722150, +0.335001994023387210, 0.335049104475547310, 0.335096214090085050, 0.335143322866881810, 0.335190430805820280, 0.335237537906783120, 0.335284644169651650, 0.335331749594308610, +0.335378854180636180, 0.335425957928517040, 0.335473060837832570, 0.335520162908465480, 0.335567264140297920, 0.335614364533212690, 0.335661464087091080, 0.335708562801815820, +0.335755660677269200, 0.335802757713333790, 0.335849853909891080, 0.335896949266823790, 0.335944043784014050, 0.335991137461344620, 0.336038230298697000, 0.336085322295953730, +0.336132413452997600, 0.336179503769710060, 0.336226593245973700, 0.336273681881670890, 0.336320769676684280, 0.336367856630895360, 0.336414942744186760, 0.336462028016440820, +0.336509112447540230, 0.336556196037366420, 0.336603278785802150, 0.336650360692729630, 0.336697441758031680, 0.336744521981589660, 0.336791601363286400, 0.336838679903004090, +0.336885757600625500, 0.336932834456032120, 0.336979910469106640, 0.337026985639731380, 0.337074059967789110, 0.337121133453161250, 0.337168206095730560, 0.337215277895379750, +0.337262348851990360, 0.337309418965445030, 0.337356488235626200, 0.337403556662416610, 0.337450624245697660, 0.337497690985352150, 0.337544756881262400, 0.337591821933311220, +0.337638886141380050, 0.337685949505351630, 0.337733012025108410, 0.337780073700533030, 0.337827134531507030, 0.337874194517913230, 0.337921253659633940, 0.337968311956551910, +0.338015369408548700, 0.338062426015507070, 0.338109481777309760, 0.338156536693838380, 0.338203590764975640, 0.338250643990603890, 0.338297696370605970, 0.338344747904863410, +0.338391798593258960, 0.338438848435675010, 0.338485897431994360, 0.338532945582098570, 0.338579992885870430, 0.338627039343192270, 0.338674084953946910, 0.338721129718015990, +0.338768173635282170, 0.338815216705627980, 0.338862258928936120, 0.338909300305088200, 0.338956340833967080, 0.339003380515455480, 0.339050419349435030, 0.339097457335788500, +0.339144494474398320, 0.339191530765147350, 0.339238566207917150, 0.339285600802590510, 0.339332634549049880, 0.339379667447178070, 0.339426699496856720, 0.339473730697968550, +0.339520761050396080, 0.339567790554022140, 0.339614819208728320, 0.339661847014397440, 0.339708873970911930, 0.339755900078154650, 0.339802925336007200, 0.339849949744352450, +0.339896973303072840, 0.339943996012051160, 0.339991017871169140, 0.340038038880309530, 0.340085059039355260, 0.340132078348187930, 0.340179096806690400, 0.340226114414745100, +0.340273131172234950, 0.340320147079041570, 0.340367162135047810, 0.340414176340136150, 0.340461189694189480, 0.340508202197089380, 0.340555213848718790, 0.340602224648960170, +0.340649234597696420, 0.340696243694809160, 0.340743251940181290, 0.340790259333695280, 0.340837265875234050, 0.340884271564679210, 0.340931276401913730, 0.340978280386820430, +0.341025283519281070, 0.341072285799178480, 0.341119287226395170, 0.341166287800814040, 0.341213287522316780, 0.341260286390786320, 0.341307284406105140, 0.341354281568156170, +0.341401277876821060, 0.341448273331982800, 0.341495267933523810, 0.341542261681327060, 0.341589254575274280, 0.341636246615248330, 0.341683237801131800, 0.341730228132807570, +0.341777217610157340, 0.341824206233064090, 0.341871194001410750, 0.341918180915078970, 0.341965166973951800, 0.342012152177911640, 0.342059136526841560, 0.342106120020623180, +0.342153102659139560, 0.342200084442273120, 0.342247065369906960, 0.342294045441922660, 0.342341024658203260, 0.342388003018631320, 0.342434980523089790, 0.342481957171460350, +0.342528932963626020, 0.342575907899469400, 0.342622881978873420, 0.342669855201719780, 0.342716827567891570, 0.342763799077271670, 0.342810769729741840, 0.342857739525185110, +0.342904708463483980, 0.342951676544521580, 0.342998643768179510, 0.343045610134340820, 0.343092575642888140, 0.343139540293704470, 0.343186504086671450, 0.343233467021672230, +0.343280429098589300, 0.343327390317305750, 0.343374350677703330, 0.343421310179664980, 0.343468268823073410, 0.343515226607811530, 0.343562183533761170, 0.343609139600805360, +0.343656094808826750, 0.343703049157708270, 0.343750002647331740, 0.343796955277580250, 0.343843907048336730, 0.343890857959483100, 0.343937808010902290, 0.343984757202476950, +0.344031705534090130, 0.344078653005623620, 0.344125599616960490, 0.344172545367983360, 0.344219490258575290, 0.344266434288618080, 0.344313377457994780, 0.344360319766588040, +0.344407261214280950, 0.344454201800955260, 0.344501141526494030, 0.344548080390780000, 0.344595018393696160, 0.344641955535124390, 0.344688891814947660, 0.344735827233049190, +0.344782761789310720, 0.344829695483615310, 0.344876628315845700, 0.344923560285884890, 0.344970491393614800, 0.345017421638918460, 0.345064351021678590, 0.345111279541778280, +0.345158207199099290, 0.345205133993524820, 0.345252059924937520, 0.345298984993220480, 0.345345909198255590, 0.345392832539925860, 0.345439755018114080, 0.345486676632703330, +0.345533597383575470, 0.345580517270613670, 0.345627436293700910, 0.345674354452719210, 0.345721271747551570, 0.345768188178080800, 0.345815103744189940, 0.345862018445760920, +0.345908932282676830, 0.345955845254820430, 0.346002757362074860, 0.346049668604321960, 0.346096578981444860, 0.346143488493326320, 0.346190397139849500, 0.346237304920896270, +0.346284211836349780, 0.346331117886092720, 0.346378023070008310, 0.346424927387978420, 0.346471830839886250, 0.346518733425614460, 0.346565635145046290, 0.346612535998063580, +0.346659435984549510, 0.346706335104387310, 0.346753233357458830, 0.346800130743647290, 0.346847027262835450, 0.346893922914906390, 0.346940817699742170, 0.346987711617225860, +0.347034604667240290, 0.347081496849668600, 0.347128388164392790, 0.347175278611295990, 0.347222168190260970, 0.347269056901170990, 0.347315944743907920, 0.347362831718355030, +0.347409717824395000, 0.347456603061911170, 0.347503487430785350, 0.347550370930900850, 0.347597253562140830, 0.347644135324387200, 0.347691016217523300, 0.347737896241431870, +0.347784775395996060, 0.347831653681097920, 0.347878531096620650, 0.347925407642447060, 0.347972283318460360, 0.348019158124542540, 0.348066032060576850, 0.348112905126446050, +0.348159777322033400, 0.348206648647220900, 0.348253519101891730, 0.348300388685928830, 0.348347257399215350, 0.348394125241633320, 0.348440992213065960, 0.348487858313396510, +0.348534723542507090, 0.348581587900280760, 0.348628451386600540, 0.348675314001349550, 0.348722175744409890, 0.348769036615664770, 0.348815896614997070, 0.348862755742290030, +0.348909613997425700, 0.348956471380287350, 0.349003327890757830, 0.349050183528720360, 0.349097038294057030, 0.349143892186651150, 0.349190745206385490, 0.349237597353143360, +0.349284448626806850, 0.349331299027259230, 0.349378148554383820, 0.349424997208062580, 0.349471844988178850, 0.349518691894615490, 0.349565537927255810, 0.349612383085981910, +0.349659227370677010, 0.349706070781224070, 0.349752913317506350, 0.349799754979405960, 0.349846595766806160, 0.349893435679589860, 0.349940274717640390, 0.349987112880839830, +0.350033950169071520, 0.350080786582218310, 0.350127622120163520, 0.350174456782789300, 0.350221290569978920, 0.350268123481615290, 0.350314955517581790, 0.350361786677760470, +0.350408616962034740, 0.350455446370287800, 0.350502274902401880, 0.350549102558260270, 0.350595929337745920, 0.350642755240742120, 0.350689580267131040, 0.350736404416795990, +0.350783227689619950, 0.350830050085486290, 0.350876871604277050, 0.350923692245875610, 0.350970512010164940, 0.351017330897028470, 0.351064148906348180, 0.351110966038007570, +0.351157782291889540, 0.351204597667877430, 0.351251412165853430, 0.351298225785700910, 0.351345038527303260, 0.351391850390542600, 0.351438661375302270, 0.351485471481465310, +0.351532280708915070, 0.351579089057533770, 0.351625896527204660, 0.351672703117810900, 0.351719508829235750, 0.351766313661361410, 0.351813117614071300, 0.351859920687248360, +0.351906722880776070, 0.351953524194536570, 0.352000324628413240, 0.352047124182289060, 0.352093922856047570, 0.352140720649570800, 0.352187517562742250, 0.352234313595445270, +0.352281108747562130, 0.352327903018976260, 0.352374696409570590, 0.352421488919228590, 0.352468280547832470, 0.352515071295265600, 0.352561861161411080, 0.352608650146152340, +0.352655438249371570, 0.352702225470952200, 0.352749011810777220, 0.352795797268730170, 0.352842581844693190, 0.352889365538549770, 0.352936148350182940, 0.352982930279476140, +0.353029711326311610, 0.353076491490572800, 0.353123270772142780, 0.353170049170905000, 0.353216826686741650, 0.353263603319536210, 0.353310379069172230, 0.353357153935531850, +0.353403927918498620, 0.353450701017955560, 0.353497473233786160, 0.353544244565872630, 0.353591015014098560, 0.353637784578346880, 0.353684553258501230, 0.353731321054443710, +0.353778087966057920, 0.353824853993226880, 0.353871619135834150, 0.353918383393761970, 0.353965146766893830, 0.354011909255112780, 0.354058670858302390, 0.354105431576344940, +0.354152191409123910, 0.354198950356522770, 0.354245708418423840, 0.354292465594710670, 0.354339221885266340, 0.354385977289974340, 0.354432731808717040, 0.354479485441377860, +0.354526238187839960, 0.354572990047986920, 0.354619741021700960, 0.354666491108865670, 0.354713240309364130, 0.354759988623079890, 0.354806736049895320, 0.354853482589693850, +0.354900228242358730, 0.354946973007773390, 0.354993716885820270, 0.355040459876382830, 0.355087201979344620, 0.355133943194588020, 0.355180683521996610, 0.355227422961453430, +0.355274161512842130, 0.355320899176044980, 0.355367635950945620, 0.355414371837427130, 0.355461106835373190, 0.355507840944666030, 0.355554574165189260, 0.355601306496826090, +0.355648037939460040, 0.355694768492973430, 0.355741498157249980, 0.355788226932172770, 0.355834954817625390, 0.355881681813490220, 0.355928407919650800, 0.355975133135990830, +0.356021857462392620, 0.356068580898739720, 0.356115303444915380, 0.356162025100803190, 0.356208745866285590, 0.356255465741246060, 0.356302184725567850, 0.356348902819134670, +0.356395620021828730, 0.356442336333533780, 0.356489051754133040, 0.356535766283510020, 0.356582479921547180, 0.356629192668128150, 0.356675904523136130, 0.356722615486454790, +0.356769325557966480, 0.356816034737554850, 0.356862743025103120, 0.356909450420494930, 0.356956156923612770, 0.357002862534340160, 0.357049567252560820, 0.357096271078157170, +0.357142974011012860, 0.357189676051011040, 0.357236377198035530, 0.357283077451968580, 0.357329776812694010, 0.357376475280094970, 0.357423172854055120, 0.357469869534456970, +0.357516565321184140, 0.357563260214119880, 0.357609954213147900, 0.357656647318150610, 0.357703339529011730, 0.357750030845614460, 0.357796721267842570, 0.357843410795578410, +0.357890099428705750, 0.357936787167108250, 0.357983474010668380, 0.358030159959269840, 0.358076845012795850, 0.358123529171130220, 0.358170212434155310, 0.358216894801754890, +0.358263576273812220, 0.358310256850211010, 0.358356936530833780, 0.358403615315564190, 0.358450293204285560, 0.358496970196881650, 0.358543646293234820, 0.358590321493228950, +0.358636995796747240, 0.358683669203673450, 0.358730341713890120, 0.358777013327280900, 0.358823684043729550, 0.358870353863118610, 0.358917022785331720, 0.358963690810252310, +0.359010357937764090, 0.359057024167749590, 0.359103689500092530, 0.359150353934676200, 0.359197017471384440, 0.359243680110099660, 0.359290341850705740, 0.359337002693085940, +0.359383662637124070, 0.359430321682702610, 0.359476979829705390, 0.359523637078015660, 0.359570293427517280, 0.359616948878092760, 0.359663603429625830, 0.359710257081999940, +0.359756909835098780, 0.359803561688804950, 0.359850212643002210, 0.359896862697574370, 0.359943511852403920, 0.359990160107374720, 0.360036807462370160, 0.360083453917273920, +0.360130099471968670, 0.360176744126338160, 0.360223387880265810, 0.360270030733635390, 0.360316672686329500, 0.360363313738231880, 0.360409953889226030, 0.360456593139195650, +0.360503231488023430, 0.360549868935593100, 0.360596505481788120, 0.360643141126492260, 0.360689775869588170, 0.360736409710959600, 0.360783042650490440, 0.360829674688063260, +0.360876305823561890, 0.360922936056869760, 0.360969565387870730, 0.361016193816447340, 0.361062821342483460, 0.361109447965862530, 0.361156073686468400, 0.361202698504183680, +0.361249322418892240, 0.361295945430477440, 0.361342567538823210, 0.361389188743812150, 0.361435809045328130, 0.361482428443254570, 0.361529046937475400, 0.361575664527873150, +0.361622281214331760, 0.361668896996735050, 0.361715511874965700, 0.361762125848907600, 0.361808738918444120, 0.361855351083459230, 0.361901962343835590, 0.361948572699457020, +0.361995182150207040, 0.362041790695969480, 0.362088398336627040, 0.362135005072063590, 0.362181610902162670, 0.362228215826808090, 0.362274819845882610, 0.362321422959270060, +0.362368025166853960, 0.362414626468518190, 0.362461226864145390, 0.362507826353619610, 0.362554424936824660, 0.362601022613643190, 0.362647619383959230, 0.362694215247656160, +0.362740810204618010, 0.362787404254727390, 0.362833997397868260, 0.362880589633924170, 0.362927180962778980, 0.362973771384315470, 0.363020360898417490, 0.363066949504968650, +0.363113537203852810, 0.363160123994952730, 0.363206709878152290, 0.363253294853335130, 0.363299878920385180, 0.363346462079185080, 0.363393044329618780, 0.363439625671569950, +0.363486206104922440, 0.363532785629558990, 0.363579364245363580, 0.363625941952220140, 0.363672518750011500, 0.363719094638621510, 0.363765669617933770, 0.363812243687832330, +0.363858816848199820, 0.363905389098920280, 0.363951960439877260, 0.363998530870954800, 0.364045100392035580, 0.364091669003003600, 0.364138236703742400, 0.364184803494136070, +0.364231369374067300, 0.364277934343420150, 0.364324498402078150, 0.364371061549925270, 0.364417623786844390, 0.364464185112719390, 0.364510745527434340, 0.364557305030872080, +0.364603863622916520, 0.364650421303451270, 0.364696978072360400, 0.364743533929526690, 0.364790088874834160, 0.364836642908166360, 0.364883196029407390, 0.364929748238440040, +0.364976299535148260, 0.365022849919415800, 0.365069399391126590, 0.365115947950163440, 0.365162495596410450, 0.365209042329751270, 0.365255588150069810, 0.365302133057249010, +0.365348677051172910, 0.365395220131725480, 0.365441762298789610, 0.365488303552249320, 0.365534843891988310, 0.365581383317890580, 0.365627921829838940, 0.365674459427717540, +0.365720996111409960, 0.365767531880800360, 0.365814066735771440, 0.365860600676207400, 0.365907133701991850, 0.365953665813008920, 0.366000197009141380, 0.366046727290273320, +0.366093256656288450, 0.366139785107070900, 0.366186312642503400, 0.366232839262470190, 0.366279364966854810, 0.366325889755541480, 0.366372413628413000, 0.366418936585353520, +0.366465458626247080, 0.366511979750976550, 0.366558499959426130, 0.366605019251479420, 0.366651537627020570, 0.366698055085932510, 0.366744571628099260, 0.366791087253404650, +0.366837601961732650, 0.366884115752966310, 0.366930628626989610, 0.366977140583686410, 0.367023651622940710, 0.367070161744635470, 0.367116670948654860, 0.367163179234882560, +0.367209686603202750, 0.367256193053498270, 0.367302698585653340, 0.367349203199552050, 0.367395706895077330, 0.367442209672113380, 0.367488711530543910, 0.367535212470253000, +0.367581712491123700, 0.367628211593040160, 0.367674709775886010, 0.367721207039545580, 0.367767703383901630, 0.367814198808838480, 0.367860693314239820, 0.367907186899989860, +0.367953679565971530, 0.368000171312068970, 0.368046662138165950, 0.368093152044146720, 0.368139641029894220, 0.368186129095292580, 0.368232616240226070, 0.368279102464577570, +0.368325587768231320, 0.368372072151071150, 0.368418555612981150, 0.368465038153844350, 0.368511519773545020, 0.368558000471966850, 0.368604480248994060, 0.368650959104509680, +0.368697437038397910, 0.368743914050542580, 0.368790390140827820, 0.368836865309136670, 0.368883339555353410, 0.368929812879361770, 0.368976285281045980, 0.369022756760289120, +0.369069227316975330, 0.369115696950988950, 0.369162165662212830, 0.369208633450531340, 0.369255100315828260, 0.369301566257987820, 0.369348031276893090, 0.369394495372428240, +0.369440958544477230, 0.369487420792924180, 0.369533882117652150, 0.369580342518545430, 0.369626801995487860, 0.369673260548363690, 0.369719718177055960, 0.369766174881448920, +0.369812630661426500, 0.369859085516872850, 0.369905539447671130, 0.369951992453705520, 0.369998444534859920, 0.370044895691018620, 0.370091345922064720, 0.370137795227882430, +0.370184243608356060, 0.370230691063368640, 0.370277137592804560, 0.370323583196547570, 0.370370027874482090, 0.370416471626491050, 0.370462914452458880, 0.370509356352269450, +0.370555797325807010, 0.370602237372954670, 0.370648676493596730, 0.370695114687617120, 0.370741551954900110, 0.370787988295328830, 0.370834423708787550, 0.370880858195160260, +0.370927291754331200, 0.370973724386183530, 0.371020156090601520, 0.371066586867469520, 0.371113016716670690, 0.371159445638089280, 0.371205873631609230, 0.371252300697114960, +0.371298726834489500, 0.371345152043617230, 0.371391576324382080, 0.371437999676668410, 0.371484422100359310, 0.371530843595339170, 0.371577264161491950, 0.371623683798701920, +0.371670102506852280, 0.371716520285827410, 0.371762937135511230, 0.371809353055788160, 0.371855768046541250, 0.371902182107654910, 0.371948595239013520, 0.371995007440500290, +0.372041418711999470, 0.372087829053395160, 0.372134238464571660, 0.372180646945412140, 0.372227054495801070, 0.372273461115622320, 0.372319866804760310, 0.372366271563098210, +0.372412675390520480, 0.372459078286911050, 0.372505480252154300, 0.372551881286133480, 0.372598281388732970, 0.372644680559836680, 0.372691078799329170, 0.372737476107093510, +0.372783872483014200, 0.372830267926975210, 0.372876662438860920, 0.372923056018554580, 0.372969448665940620, 0.373015840380903410, 0.373062231163326210, 0.373108621013093440, +0.373155009930089100, 0.373201397914197650, 0.373247784965302310, 0.373294171083287500, 0.373340556268037300, 0.373386940519436050, 0.373433323837367100, 0.373479706221714780, +0.373526087672363230, 0.373572468189196870, 0.373618847772098920, 0.373665226420953900, 0.373711604135645750, 0.373757980916059050, 0.373804356762076910, 0.373850731673583960, +0.373897105650464520, 0.373943478692601970, 0.373989850799880730, 0.374036221972184780, 0.374082592209398770, 0.374128961511405840, 0.374175329878090490, 0.374221697309336850, +0.374268063805029360, 0.374314429365051270, 0.374360793989287120, 0.374407157677621010, 0.374453520429937400, 0.374499882246119580, 0.374546243126052060, 0.374592603069618950, +0.374638962076704720, 0.374685320147192690, 0.374731677280967350, 0.374778033477913220, 0.374824388737913570, 0.374870743060853000, 0.374917096446615530, 0.374963448895085760, +0.375009800406146950, 0.375056150979683640, 0.375102500615579980, 0.375148849313720440, 0.375195197073988350, 0.375241543896268290, 0.375287889780444420, 0.375334234726401150, +0.375380578734021920, 0.375426921803191260, 0.375473263933793320, 0.375519605125712590, 0.375565945378832420, 0.375612284693037420, 0.375658623068212070, 0.375704960504239790, +0.375751297001005120, 0.375797632558392210, 0.375843967176285600, 0.375890300854568700, 0.375936633593126010, 0.375982965391841730, 0.376029296250600500, 0.376075626169285580, +0.376121955147781570, 0.376168283185972730, 0.376214610283743590, 0.376260936440977470, 0.376307261657559010, 0.376353585933372430, 0.376399909268302300, 0.376446231662231960, +0.376492553115046040, 0.376538873626628750, 0.376585193196864680, 0.376631511825637200, 0.376677829512830960, 0.376724146258330560, 0.376770462062019420, 0.376816776923782070, +0.376863090843502780, 0.376909403821066190, 0.376955715856355680, 0.377002026949255890, 0.377048337099651020, 0.377094646307425730, 0.377140954572463380, 0.377187261894648680, +0.377233568273865780, 0.377279873709999440, 0.377326178202932960, 0.377372481752551060, 0.377418784358737940, 0.377465086021378240, 0.377511386740355450, 0.377557686515554160, +0.377603985346859130, 0.377650283234153670, 0.377696580177322550, 0.377742876176249910, 0.377789171230820560, 0.377835465340917830, 0.377881758506426410, 0.377928050727230680, +0.377974342003215170, 0.378020632334263420, 0.378066921720260070, 0.378113210161089400, 0.378159497656636150, 0.378205784206783750, 0.378252069811416850, 0.378298354470419820, +0.378344638183677310, 0.378390920951072740, 0.378437202772490930, 0.378483483647816530, 0.378529763576932960, 0.378576042559724990, 0.378622320596076920, 0.378668597685873460, +0.378714873828998160, 0.378761149025335590, 0.378807423274770180, 0.378853696577186590, 0.378899968932468410, 0.378946240340500280, 0.378992510801166530, 0.379038780314351900, +0.379085048879939930, 0.379131316497815400, 0.379177583167862490, 0.379223848889966080, 0.379270113664009590, 0.379316377489877900, 0.379362640367455210, 0.379408902296626330, +0.379455163277274800, 0.379501423309285320, 0.379547682392542720, 0.379593940526930520, 0.379640197712333430, 0.379686453948635870, 0.379732709235722610, 0.379778963573477120, +0.379825216961784280, 0.379871469400528350, 0.379917720889594190, 0.379963971428865290, 0.380010221018226460, 0.380056469657562120, 0.380102717346756940, 0.380148964085694600, +0.380195209874259870, 0.380241454712337110, 0.380287698599811100, 0.380333941536565470, 0.380380183522484930, 0.380426424557454400, 0.380472664641357320, 0.380518903774078650, +0.380565141955502730, 0.380611379185514300, 0.380657615463997070, 0.380703850790835740, 0.380750085165914850, 0.380796318589119110, 0.380842551060332210, 0.380888782579438870, +0.380935013146323610, 0.380981242760871250, 0.381027471422965340, 0.381073699132490780, 0.381119925889331970, 0.381166151693373700, 0.381212376544499690, 0.381258600442594740, +0.381304823387543680, 0.381351045379230150, 0.381397266417539020, 0.381443486502354710, 0.381489705633562100, 0.381535923811044840, 0.381582141034687740, 0.381628357304375330, +0.381674572619992380, 0.381720786981422640, 0.381767000388550880, 0.381813212841261630, 0.381859424339439810, 0.381905634882968970, 0.381951844471734080, 0.381998053105619520, +0.382044260784510310, 0.382090467508289950, 0.382136673276843530, 0.382182878090055740, 0.382229081947810410, 0.382275284849992350, 0.382321486796486090, 0.382367687787176500, +0.382413887821947300, 0.382460086900683340, 0.382506285023269220, 0.382552482189589760, 0.382598678399528710, 0.382644873652970950, 0.382691067949801010, 0.382737261289903820, +0.382783453673163020, 0.382829645099463660, 0.382875835568690150, 0.382922025080727420, 0.382968213635459300, 0.383014401232770580, 0.383060587872545880, 0.383106773554670100, +0.383152958279027010, 0.383199142045501540, 0.383245324853978610, 0.383291506704341920, 0.383337687596476460, 0.383383867530266820, 0.383430046505597920, 0.383476224522353530, +0.383522401580418500, 0.383568577679677500, 0.383614752820015450, 0.383660927001316150, 0.383707100223464490, 0.383753272486345110, 0.383799443789842930, 0.383845614133841770, +0.383891783518226560, 0.383937951942881880, 0.383984119407692730, 0.384030285912542850, 0.384076451457317280, 0.384122616041901010, 0.384168779666177800, 0.384214942330032620, +0.384261104033350060, 0.384307264776015180, 0.384353424557911720, 0.384399583378924660, 0.384445741238938710, 0.384491898137838740, 0.384538054075508670, 0.384584209051833440, +0.384630363066697730, 0.384676516119986490, 0.384722668211583570, 0.384768819341373970, 0.384814969509242270, 0.384861118715073610, 0.384907266958751770, 0.384953414240161720, +0.384999560559188550, 0.385045705915716070, 0.385091850309629340, 0.385137993740812920, 0.385184136209151980, 0.385230277714530330, 0.385276418256832900, 0.385322557835944490, +0.385368696451750090, 0.385414834104133520, 0.385460970792979860, 0.385507106518173770, 0.385553241279600330, 0.385599375077143370, 0.385645507910688020, 0.385691639780118830, +0.385737770685321000, 0.385783900626178290, 0.385830029602575900, 0.385876157614398360, 0.385922284661530890, 0.385968410743857290, 0.386014535861262610, 0.386060660013632040, +0.386106783200849460, 0.386152905422799840, 0.386199026679368010, 0.386245146970438990, 0.386291266295896720, 0.386337384655626280, 0.386383502049512330, 0.386429618477440120, +0.386475733939293410, 0.386521848434957350, 0.386567961964316700, 0.386614074527256490, 0.386660186123660770, 0.386706296753414560, 0.386752406416402570, 0.386798515112510010, +0.386844622841620740, 0.386890729603619920, 0.386936835398392690, 0.386982940225822910, 0.387029044085795860, 0.387075146978196170, 0.387121248902909000, 0.387167349859818320, +0.387213449848809230, 0.387259548869766550, 0.387305646922575410, 0.387351744007119750, 0.387397840123284710, 0.387443935270955050, 0.387490029450016040, 0.387536122660351480, +0.387582214901846630, 0.387628306174386210, 0.387674396477855450, 0.387720485812138360, 0.387766574177119960, 0.387812661572685570, 0.387858747998719170, 0.387904833455105850, +0.387950917941730420, 0.387997001458478150, 0.388043084005232960, 0.388089165581880000, 0.388135246188304190, 0.388181325824390690, 0.388227404490023410, 0.388273482185087670, +0.388319558909468180, 0.388365634663050240, 0.388411709445717790, 0.388457783257356030, 0.388503856097849880, 0.388549927967084430, 0.388595998864943840, 0.388642068791313190, +0.388688137746077740, 0.388734205729121600, 0.388780272740329950, 0.388826338779587610, 0.388872403846779790, 0.388918467941790580, 0.388964531064505240, 0.389010593214808520, +0.389056654392585740, 0.389102714597720890, 0.389148773830099270, 0.389194832089605760, 0.389240889376125550, 0.389286945689542700, 0.389333001029742440, 0.389379055396609770, +0.389425108790029780, 0.389471161209886670, 0.389517212656065650, 0.389563263128451580, 0.389609312626929770, 0.389655361151384270, 0.389701408701700390, 0.389747455277763390, +0.389793500879457300, 0.389839545506667500, 0.389885589159278840, 0.389931631837176610, 0.389977673540244870, 0.390023714268368960, 0.390069754021433730, 0.390115792799324570, +0.390161830601925500, 0.390207867429121890, 0.390253903280798560, 0.390299938156840940, 0.390345972057133010, 0.390392004981560180, 0.390438036930007340, 0.390484067902359790, +0.390530097898501680, 0.390576126918318280, 0.390622154961695060, 0.390668182028515940, 0.390714208118666470, 0.390760233232031410, 0.390806257368496170, 0.390852280527944910, +0.390898302710262990, 0.390944323915335230, 0.390990344143047120, 0.391036363393282740, 0.391082381665927400, 0.391128398960866150, 0.391174415277984360, 0.391220430617166050, +0.391266444978296660, 0.391312458361261220, 0.391358470765944990, 0.391404482192232170, 0.391450492640008200, 0.391496502109158320, 0.391542510599566850, 0.391588518111119050, +0.391634524643700020, 0.391680530197195060, 0.391726534771488330, 0.391772538366465310, 0.391818540982010910, 0.391864542618010630, 0.391910543274348490, 0.391956542950910040, +0.392002541647580250, 0.392048539364244500, 0.392094536100786980, 0.392140531857093130, 0.392186526633047980, 0.392232520428536900, 0.392278513243444090, 0.392324505077654980, +0.392370495931054660, 0.392416485803528500, 0.392462474694960710, 0.392508462605236700, 0.392554449534242010, 0.392600435481860740, 0.392646420447978370, 0.392692404432479990, +0.392738387435250970, 0.392784369456175560, 0.392830350495139260, 0.392876330552027090, 0.392922309626724530, 0.392968287719115740, 0.393014264829086250, 0.393060240956521090, +0.393106216101305690, 0.393152190263324430, 0.393198163442462610, 0.393244135638605440, 0.393290106851638340, 0.393336077081445520, 0.393382046327912570, 0.393428014590924860, +0.393473981870366750, 0.393519948166123620, 0.393565913478080680, 0.393611877806123330, 0.393657841150135910, 0.393703803510003840, 0.393749764885612310, 0.393795725276846750, +0.393841684683591490, 0.393887643105731990, 0.393933600543153410, 0.393979556995741220, 0.394025512463379690, 0.394071466945954460, 0.394117420443350520, 0.394163372955453450, +0.394209324482147520, 0.394255275023318310, 0.394301224578851250, 0.394347173148630770, 0.394393120732542400, 0.394439067330471180, 0.394485012942302700, 0.394530957567921280, +0.394576901207212450, 0.394622843860061410, 0.394668785526353650, 0.394714726205973530, 0.394760665898806600, 0.394806604604737930, 0.394852542323653240, 0.394898479055436790, +0.394944414799974110, 0.394990349557150400, 0.395036283326851200, 0.395082216108960880, 0.395128147903365090, 0.395174078709948860, 0.395220008528597840, 0.395265937359196460, +0.395311865201630200, 0.395357792055784640, 0.395403717921544220, 0.395449642798794520, 0.395495566687420750, 0.395541489587308390, 0.395587411498341980, 0.395633332420406990, +0.395679252353388690, 0.395725171297172660, 0.395771089251643280, 0.395817006216686200, 0.395862922192186550, 0.395908837178030050, 0.395954751174101060, 0.396000664180285180, +0.396046576196467660, 0.396092487222534040, 0.396138397258368860, 0.396184306303857650, 0.396230214358886110, 0.396276121423338620, 0.396322027497100830, 0.396367932580057980, +0.396413836672095680, 0.396459739773098400, 0.396505641882951730, 0.396551543001541000, 0.396597443128751780, 0.396643342264468570, 0.396689240408577000, 0.396735137560962350, +0.396781033721510250, 0.396826928890105180, 0.396872823066632740, 0.396918716250978300, 0.396964608443027440, 0.397010499642664660, 0.397056389849775590, 0.397102279064246000, +0.397148167285960310, 0.397194054514804160, 0.397239940750662930, 0.397285825993422210, 0.397331710242966540, 0.397377593499181610, 0.397423475761952690, 0.397469357031165480, +0.397515237306704460, 0.397561116588455330, 0.397606994876303410, 0.397652872170134450, 0.397698748469832890, 0.397744623775284470, 0.397790498086374460, 0.397836371402988610, +0.397882243725011460, 0.397928115052328670, 0.397973985384825980, 0.398019854722387990, 0.398065723064900290, 0.398111590412248360, 0.398157456764317800, 0.398203322120993190, +0.398249186482160290, 0.398295049847704420, 0.398340912217511390, 0.398386773591465570, 0.398432633969452890, 0.398478493351358600, 0.398524351737068520, 0.398570209126467120, +0.398616065519440180, 0.398661920915873100, 0.398707775315651600, 0.398753628718660270, 0.398799481124784920, 0.398845332533910800, 0.398891182945923790, 0.398937032360708380, +0.398982880778150420, 0.399028728198135670, 0.399074574620548680, 0.399120420045275260, 0.399166264472200770, 0.399212107901211030, 0.399257950332190640, 0.399303791765025340, +0.399349632199600570, 0.399395471635802140, 0.399441310073514630, 0.399487147512623820, 0.399532983953015170, 0.399578819394574460, 0.399624653837186260, 0.399670487280736510, +0.399716319725110460, 0.399762151170194040, 0.399807981615871830, 0.399853811062029660, 0.399899639508553400, 0.399945466955327620, 0.399991293402238160, 0.400037118849170480, +0.400082943296010410, 0.400128766742642580, 0.400174589188952820, 0.400220410634826610, 0.400266231080149750, 0.400312050524806950, 0.400357868968683970, 0.400403686411666350, +0.400449502853639890, 0.400495318294489310, 0.400541132734100410, 0.400586946172358680, 0.400632758609149990, 0.400678570044359030, 0.400724380477871620, 0.400770189909573640, +0.400815998339349780, 0.400861805767085970, 0.400907612192667630, 0.400953417615980630, 0.400999222036909740, 0.401045025455340760, 0.401090827871159180, 0.401136629284250980, +0.401182429694500800, 0.401228229101794560, 0.401274027506017710, 0.401319824907056260, 0.401365621304794750, 0.401411416699119280, 0.401457211089915220, 0.401503004477068550, +0.401548796860463910, 0.401594588239987340, 0.401640378615524260, 0.401686167986960660, 0.401731956354181240, 0.401777743717071980, 0.401823530075518690, 0.401869315429406180, +0.401915099778620390, 0.401960883123046840, 0.402006665462571520, 0.402052446797079130, 0.402098227126455600, 0.402144006450586510, 0.402189784769357790, 0.402235562082654260, +0.402281338390361790, 0.402327113692365960, 0.402372887988552750, 0.402418661278806930, 0.402464433563014480, 0.402510204841060870, 0.402555975112832250, 0.402601744378213220, +0.402647512637089870, 0.402693279889348110, 0.402739046134872770, 0.402784811373549770, 0.402830575605264810, 0.402876338829903760, 0.402922101047351490, 0.402967862257493980, +0.403013622460216770, 0.403059381655405950, 0.403105139842946210, 0.403150897022723660, 0.403196653194623890, 0.403242408358532870, 0.403288162514335410, 0.403333915661917560, +0.403379667801164970, 0.403425418931963540, 0.403471169054198220, 0.403516918167754920, 0.403562666272519740, 0.403608413368377490, 0.403654159455214270, 0.403699904532915600, +0.403745648601367580, 0.403791391660455020, 0.403837133710063970, 0.403882874750080110, 0.403928614780389440, 0.403974353800876870, 0.404020091811428390, 0.404065828811929710, +0.404111564802266840, 0.404157299782324670, 0.404203033751989240, 0.404248766711146180, 0.404294498659681640, 0.404340229597480500, 0.404385959524428740, 0.404431688440412500, +0.404477416345316590, 0.404523143239027220, 0.404568869121429920, 0.404614593992410900, 0.404660317851854970, 0.404706040699648220, 0.404751762535676410, 0.404797483359825570, +0.404843203171980640, 0.404888921972027690, 0.404934639759852440, 0.404980356535340980, 0.405026072298378230, 0.405071787048850330, 0.405117500786642940, 0.405163213511642200, +0.405208925223733030, 0.405254635922801530, 0.405300345608733460, 0.405346054281414900, 0.405391761940730840, 0.405437468586567370, 0.405483174218810580, 0.405528878837345510, +0.405574582442058240, 0.405620285032834480, 0.405665986609560440, 0.405711687172121030, 0.405757386720402350, 0.405803085254290260, 0.405848782773670870, 0.405894479278429090, +0.405940174768451120, 0.405985869243622680, 0.406031562703830010, 0.406077255148958040, 0.406122946578892920, 0.406168636993520400, 0.406214326392726750, 0.406260014776396840, +0.406305702144416910, 0.406351388496673130, 0.406397073833050460, 0.406442758153435110, 0.406488441457712850, 0.406534123745769920, 0.406579805017491250, 0.406625485272763100, +0.406671164511471170, 0.406716842733501840, 0.406762519938739910, 0.406808196127071700, 0.406853871298383020, 0.406899545452560070, 0.406945218589487840, 0.406990890709052530, +0.407036561811140060, 0.407082231895636580, 0.407127900962427070, 0.407173569011397840, 0.407219236042435100, 0.407264902055423820, 0.407310567050250320, 0.407356231026800410, +0.407401893984960290, 0.407447555924615070, 0.407493216845650930, 0.407538876747953750, 0.407584535631409840, 0.407630193495904130, 0.407675850341322920, 0.407721506167552150, +0.407767160974477960, 0.407812814761985500, 0.407858467529960970, 0.407904119278290290, 0.407949770006859720, 0.407995419715554310, 0.408041068404260350, 0.408086716072863730, +0.408132362721250750, 0.408178008349306400, 0.408223652956917090, 0.408269296543968980, 0.408314939110347270, 0.408360580655938220, 0.408406221180627750, 0.408451860684302060, +0.408497499166846360, 0.408543136628146900, 0.408588773068089610, 0.408634408486560740, 0.408680042883445500, 0.408725676258630100, 0.408771308612000560, 0.408816939943443150, +0.408862570252842950, 0.408908199540086390, 0.408953827805059290, 0.408999455047648010, 0.409045081267737700, 0.409090706465214670, 0.409136330639965300, 0.409181953791874720, +0.409227575920829200, 0.409273197026714770, 0.409318817109417750, 0.409364436168823340, 0.409410054204817800, 0.409455671217287100, 0.409501287206117610, 0.409546902171194550, +0.409592516112404210, 0.409638129029632590, 0.409683740922766050, 0.409729351791689730, 0.409774961636290070, 0.409820570456452980, 0.409866178252064840, 0.409911785023010900, +0.409957390769177480, 0.410002995490450990, 0.410048599186716600, 0.410094201857860720, 0.410139803503769330, 0.410185404124328860, 0.410231003719424450, 0.410276602288942530, +0.410322199832769070, 0.410367796350790570, 0.410413391842892160, 0.410458986308960270, 0.410504579748880940, 0.410550172162540530, 0.410595763549824300, 0.410641353910618680, +0.410686943244809640, 0.410732531552283620, 0.410778118832925920, 0.410823705086622910, 0.410869290313261030, 0.410914874512725570, 0.410960457684902860, 0.411006039829679040, +0.411051620946940530, 0.411097201036572550, 0.411142780098461560, 0.411188358132493600, 0.411233935138555220, 0.411279511116531550, 0.411325086066309080, 0.411370659987773950, +0.411416232880812530, 0.411461804745310130, 0.411507375581153250, 0.411552945388227900, 0.411598514166420570, 0.411644081915616580, 0.411689648635702400, 0.411735214326564070, +0.411780778988088130, 0.411826342620159820, 0.411871905222665700, 0.411917466795492180, 0.411963027338524580, 0.412008586851649430, 0.412054145334752820, 0.412099702787721230, +0.412145259210439980, 0.412190814602795610, 0.412236368964674190, 0.412281922295962280, 0.412327474596545120, 0.412373025866309250, 0.412418576105140880, 0.412464125312926420, +0.412509673489551250, 0.412555220634901960, 0.412600766748864530, 0.412646311831325660, 0.412691855882170560, 0.412737398901285860, 0.412782940888558050, 0.412828481843872440, +0.412874021767115680, 0.412919560658173870, 0.412965098516933530, 0.413010635343280030, 0.413056171137099970, 0.413101705898279490, 0.413147239626705130, 0.413192772322262260, +0.413238303984837460, 0.413283834614316890, 0.413329364210587190, 0.413374892773533620, 0.413420420303042880, 0.413465946799001060, 0.413511472261294750, 0.413556996689809390, +0.413602520084431490, 0.413648042445047710, 0.413693563771543480, 0.413739084063805270, 0.413784603321719400, 0.413830121545172400, 0.413875638734049700, 0.413921154888237890, +0.413966670007623220, 0.414012184092092230, 0.414057697141530400, 0.414103209155824380, 0.414148720134860260, 0.414194230078524790, 0.414239738986703300, 0.414285246859282530, +0.414330753696148580, 0.414376259497188200, 0.414421764262286720, 0.414467267991330880, 0.414512770684206830, 0.414558272340801230, 0.414603772960999590, 0.414649272544688530, +0.414694771091754680, 0.414740268602083460, 0.414785765075561640, 0.414831260512075360, 0.414876754911511330, 0.414922248273755010, 0.414967740598693120, 0.415013231886211810, +0.415058722136197880, 0.415104211348536700, 0.415149699523114980, 0.415195186659819080, 0.415240672758535550, 0.415286157819149960, 0.415331641841548970, 0.415377124825618890, +0.415422606771246370, 0.415468087678317000, 0.415513567546717310, 0.415559046376334170, 0.415604524167053010, 0.415650000918760530, 0.415695476631343040, 0.415740951304687300, +0.415786424938678730, 0.415831897533204100, 0.415877369088149760, 0.415922839603402370, 0.415968309078847520, 0.416013777514371850, 0.416059244909861740, 0.416104711265203930, +0.416150176580283970, 0.416195640854988560, 0.416241104089204010, 0.416286566282817130, 0.416332027435713400, 0.416377487547779650, 0.416422946618902560, 0.416468404648967670, +0.416513861637861800, 0.416559317585471320, 0.416604772491682870, 0.416650226356382160, 0.416695679179455820, 0.416741130960790300, 0.416786581700272380, 0.416832031397787570, +0.416877480053222730, 0.416922927666464160, 0.416968374237398690, 0.417013819765911840, 0.417059264251890440, 0.417104707695220960, 0.417150150095790040, 0.417195591453483340, +0.417241031768187720, 0.417286471039789890, 0.417331909268175430, 0.417377346453231270, 0.417422782594843720, 0.417468217692899600, 0.417513651747284550, 0.417559084757885390, +0.417604516724588480, 0.417649947647280690, 0.417695377525847620, 0.417740806360176130, 0.417786234150152650, 0.417831660895663930, 0.417877086596595670, 0.417922511252834690, +0.417967934864267480, 0.418013357430780770, 0.418058778952260290, 0.418104199428592890, 0.418149618859664950, 0.418195037245363390, 0.418240454585573850, 0.418285870880183150, +0.418331286129078160, 0.418376700332144580, 0.418422113489269280, 0.418467525600338620, 0.418512936665239590, 0.418558346683857830, 0.418603755656080160, 0.418649163581793160, +0.418694570460883600, 0.418739976293237230, 0.418785381078740910, 0.418830784817281140, 0.418876187508744830, 0.418921589153017640, 0.418966989749986470, 0.419012389299537880, +0.419057787801558670, 0.419103185255934540, 0.419148581662552530, 0.419193977021299400, 0.419239371332060960, 0.419284764594724140, 0.419330156809175350, 0.419375547975301580, +0.419420938092988530, 0.419466327162123120, 0.419511715182591950, 0.419557102154281880, 0.419602488077078620, 0.419647872950869140, 0.419693256775539980, 0.419738639550978120, +0.419784021277069210, 0.419829401953700280, 0.419874781580757810, 0.419920160158128830, 0.419965537685699050, 0.420010914163355400, 0.420056289590984840, 0.420101663968473200, +0.420147037295707400, 0.420192409572573980, 0.420237780798959960, 0.420283150974751110, 0.420328520099834350, 0.420373888174096270, 0.420419255197423900, 0.420464621169702960, +0.420509986090820520, 0.420555349960663070, 0.420600712779117650, 0.420646074546070060, 0.420691435261407290, 0.420736794925015920, 0.420782153536783000, 0.420827511096594220, +0.420872867604336730, 0.420918223059897070, 0.420963577463162210, 0.421008930814018020, 0.421054283112351550, 0.421099634358049700, 0.421144984550998410, 0.421190333691084660, +0.421235681778195040, 0.421281028812216630, 0.421326374793035250, 0.421371719720537940, 0.421417063594611340, 0.421462406415142490, 0.421507748182017190, 0.421553088895122550, +0.421598428554345150, 0.421643767159572140, 0.421689104710689270, 0.421734441207583630, 0.421779776650141880, 0.421825111038251150, 0.421870444371797160, 0.421915776650667150, +0.421961107874748000, 0.422006438043925740, 0.422051767158087400, 0.422097095217119630, 0.422142422220909470, 0.422187748169342900, 0.422233073062306950, 0.422278396899688320, +0.422323719681374110, 0.422369041407250180, 0.422414362077203680, 0.422459681691121250, 0.422505000248890040, 0.422550317750395870, 0.422595634195525980, 0.422640949584166980, +0.422686263916205950, 0.422731577191528930, 0.422776889410022950, 0.422822200571575100, 0.422867510676071420, 0.422912819723398950, 0.422958127713444380, 0.423003434646094910, +0.423048740521236480, 0.423094045338756220, 0.423139349098540780, 0.423184651800477430, 0.423229953444452020, 0.423275254030351710, 0.423320553558063310, 0.423365852027473900, +0.423411149438469410, 0.423456445790937110, 0.423501741084763680, 0.423547035319836280, 0.423592328496040950, 0.423637620613264760, 0.423682911671394940, 0.423728201670317380, +0.423773490609919370, 0.423818778490087640, 0.423864065310709300, 0.423909351071670440, 0.423954635772858250, 0.423999919414159380, 0.424045201995461200, 0.424090483516649570, +0.424135763977611710, 0.424181043378234480, 0.424226321718405020, 0.424271598998009370, 0.424316875216934670, 0.424362150375067860, 0.424407424472296010, 0.424452697508505230, +0.424497969483582700, 0.424543240397415260, 0.424588510249890140, 0.424633779040893280, 0.424679046770312040, 0.424724313438033520, 0.424769579043943860, 0.424814843587930260, +0.424860107069879530, 0.424905369489678940, 0.424950630847214520, 0.424995891142373520, 0.425041150375042810, 0.425086408545109600, 0.425131665652459970, 0.425176921696981180, +0.425222176678560100, 0.425267430597083940, 0.425312683452438830, 0.425357935244512040, 0.425403185973190380, 0.425448435638361160, 0.425493684239910460, 0.425538931777725560, +0.425584178251693700, 0.425629423661701030, 0.425674668007634760, 0.425719911289381860, 0.425765153506829530, 0.425810394659863980, 0.425855634748372400, 0.425900873772241730, +0.425946111731359320, 0.425991348625611170, 0.426036584454884680, 0.426081819219066740, 0.426127052918044650, 0.426172285551704500, 0.426217517119933660, 0.426262747622619060, +0.426307977059647960, 0.426353205430906490, 0.426398432736282030, 0.426443658975661890, 0.426488884148932210, 0.426534108255980320, 0.426579331296693120, 0.426624553270958050, +0.426669774178661140, 0.426714994019689820, 0.426760212793931000, 0.426805430501272120, 0.426850647141599200, 0.426895862714799680, 0.426941077220760470, 0.426986290659368990, +0.427031503030511410, 0.427076714334075010, 0.427121924569946910, 0.427167133738014350, 0.427212341838163530, 0.427257548870281890, 0.427302754834256390, 0.427347959729974360, +0.427393163557322100, 0.427438366316186870, 0.427483568006456150, 0.427528768628016090, 0.427573968180754100, 0.427619166664557240, 0.427664364079312850, 0.427709560424907100, +0.427754755701227510, 0.427799949908161000, 0.427845143045595010, 0.427890335113415790, 0.427935526111510700, 0.427980716039766840, 0.428025904898071520, 0.428071092686311110, +0.428116279404372910, 0.428161465052144030, 0.428206649629511940, 0.428251833136362780, 0.428297015572584040, 0.428342196938063140, 0.428387377232686380, 0.428432556456341150, +0.428477734608914530, 0.428522911690293990, 0.428568087700365810, 0.428613262639017330, 0.428658436506135780, 0.428703609301608450, 0.428748781025321770, 0.428793951677163110, +0.428839121257019560, 0.428884289764778600, 0.428929457200326550, 0.428974623563550820, 0.429019788854338560, 0.429064953072577250, 0.429110116218153090, 0.429155278290953680, +0.429200439290866490, 0.429245599217777770, 0.429290758071575070, 0.429335915852145480, 0.429381072559376460, 0.429426228193154400, 0.429471382753366770, 0.429516536239900660, +0.429561688652643660, 0.429606839991481970, 0.429651990256303180, 0.429697139446994500, 0.429742287563443290, 0.429787434605535980, 0.429832580573160090, 0.429877725466202790, +0.429922869284551530, 0.429968012028092710, 0.430013153696713830, 0.430058294290302510, 0.430103433808744990, 0.430148572251928930, 0.430193709619741460, 0.430238845912070120, +0.430283981128801230, 0.430329115269822370, 0.430374248335020800, 0.430419380324283950, 0.430464511237498240, 0.430509641074551250, 0.430554769835330200, 0.430599897519722610, +0.430645024127614850, 0.430690149658894570, 0.430735274113448920, 0.430780397491165420, 0.430825519791930620, 0.430870641015631940, 0.430915761162156690, 0.430960880231392450, +0.431005998223225610, 0.431051115137543740, 0.431096230974234500, 0.431141345733184300, 0.431186459414280690, 0.431231572017410970, 0.431276683542462740, 0.431321793989322360, +0.431366903357877470, 0.431412011648015400, 0.431457118859623620, 0.431502224992588720, 0.431547330046798240, 0.431592434022139370, 0.431637536918499880, 0.431682638735766120, +0.431727739473825810, 0.431772839132566090, 0.431817937711874710, 0.431863035211638050, 0.431908131631743850, 0.431953226972079720, 0.431998321232532070, 0.432043414412988660, +0.432088506513336690, 0.432133597533463860, 0.432178687473256660, 0.432223776332602730, 0.432268864111389320, 0.432313950809504190, 0.432359036426833760, 0.432404120963265800, +0.432449204418687510, 0.432494286792986570, 0.432539368086049540, 0.432584448297764050, 0.432629527428017470, 0.432674605476697500, 0.432719682443690580, 0.432764758328884500, +0.432809833132166870, 0.432854906853424260, 0.432899979492544440, 0.432945051049414610, 0.432990121523922580, 0.433035190915954830, 0.433080259225399110, 0.433125326452142740, +0.433170392596073480, 0.433215457657077810, 0.433260521635043530, 0.433305584529857900, 0.433350646341408740, 0.433395707069582580, 0.433440766714267120, 0.433485825275349730, +0.433530882752718230, 0.433575939146259080, 0.433620994455860110, 0.433666048681408620, 0.433711101822792430, 0.433756153879898080, 0.433801204852613360, 0.433846254740826000, +0.433891303544422620, 0.433936351263291000, 0.433981397897318490, 0.434026443446392850, 0.434071487910400730, 0.434116531289229890, 0.434161573582767750, 0.434206614790902060, +0.434251654913519410, 0.434296693950507630, 0.434341731901754120, 0.434386768767146660, 0.434431804546571930, 0.434476839239917640, 0.434521872847071280, 0.434566905367920640, +0.434611936802352330, 0.434656967150254150, 0.434701996411513970, 0.434747024586018440, 0.434792051673655310, 0.434837077674312010, 0.434882102587876460, 0.434927126414235250, +0.434972149153276260, 0.435017170804886890, 0.435062191368954960, 0.435107210845367130, 0.435152229234011310, 0.435197246534774930, 0.435242262747545790, 0.435287277872210670, +0.435332291908657300, 0.435377304856773170, 0.435422316716446210, 0.435467327487563060, 0.435512337170011590, 0.435557345763679720, 0.435602353268454030, 0.435647359684222470, +0.435692365010872500, 0.435737369248292040, 0.435782372396367750, 0.435827374454987540, 0.435872375424038890, 0.435917375303409680, 0.435962374092986660, 0.436007371792657690, +0.436052368402310260, 0.436097363921832350, 0.436142358351110650, 0.436187351690032980, 0.436232343938486980, 0.436277335096360520, 0.436322325163540300, 0.436367314139914310, +0.436412302025370400, 0.436457288819795340, 0.436502274523077110, 0.436547259135103120, 0.436592242655761410, 0.436637225084938680, 0.436682206422522920, 0.436727186668401660, +0.436772165822462750, 0.436817143884593080, 0.436862120854680570, 0.436907096732612740, 0.436952071518277580, 0.436997045211561800, 0.437042017812353410, 0.437086989320540020, +0.437131959736009550, 0.437176929058648740, 0.437221897288345650, 0.437266864424987800, 0.437311830468463170, 0.437356795418658570, 0.437401759275462040, 0.437446722038761450, +0.437491683708443660, 0.437536644284396700, 0.437581603766508060, 0.437626562154665890, 0.437671519448756870, 0.437716475648669060, 0.437761430754290030, 0.437806384765507870, +0.437851337682209350, 0.437896289504282440, 0.437941240231614850, 0.437986189864094540, 0.438031138401608340, 0.438076085844044340, 0.438121032191290120, 0.438165977443233660, +0.438210921599761940, 0.438255864660762830, 0.438300806626124530, 0.438345747495733800, 0.438390687269478660, 0.438435625947246830, 0.438480563528926340, 0.438525500014404050, +0.438570435403567990, 0.438615369696305820, 0.438660302892505680, 0.438705234992054330, 0.438750165994839900, 0.438795095900750110, 0.438840024709672930, 0.438884952421495280, +0.438929879036105310, 0.438974804553390610, 0.439019728973239260, 0.439064652295538260, 0.439109574520175570, 0.439154495647039340, 0.439199415676016500, 0.439244334606995130, +0.439289252439862890, 0.439334169174507960, 0.439379084810817170, 0.439423999348678710, 0.439468912787980230, 0.439513825128609870, 0.439558736370454510, 0.439603646513402340, +0.439648555557341060, 0.439693463502158820, 0.439738370347742490, 0.439783276093980210, 0.439828180740759740, 0.439873084287969280, 0.439917986735495650, 0.439962888083227090, +0.440007788331051310, 0.440052687478856400, 0.440097585526529440, 0.440142482473958490, 0.440187378321031720, 0.440232273067636130, 0.440277166713659850, 0.440322059258990650, +0.440366950703516720, 0.440411841047125000, 0.440456730289703670, 0.440501618431140500, 0.440546505471323730, 0.440591391410140250, 0.440636276247478310, 0.440681159983225660, +0.440726042617270550, 0.440770924149499920, 0.440815804579801960, 0.440860683908064540, 0.440905562134175750, 0.440950439258022690, 0.440995315279493540, 0.441040190198476460, +0.441085064014858530, 0.441129936728527900, 0.441174808339372500, 0.441219678847280420, 0.441264548252138790, 0.441309416553835760, 0.441354283752259210, 0.441399149847297330, +0.441444014838837160, 0.441488878726767010, 0.441533741510974630, 0.441578603191348280, 0.441623463767775060, 0.441668323240143160, 0.441713181608340440, 0.441758038872255180, +0.441802895031774390, 0.441847750086786450, 0.441892604037179450, 0.441937456882840580, 0.441982308623658060, 0.442027159259519740, 0.442072008790313940, 0.442116857215927750, +0.442161704536249370, 0.442206550751166770, 0.442251395860568160, 0.442296239864340690, 0.442341082762372610, 0.442385924554551830, 0.442430765240766630, 0.442475604820904090, +0.442520443294852570, 0.442565280662499950, 0.442610116923734530, 0.442654952078443350, 0.442699786126514890, 0.442744619067837300, 0.442789450902297770, 0.442834281629784610, +0.442879111250185750, 0.442923939763389560, 0.442968767169283070, 0.443013593467754650, 0.443058418658692280, 0.443103242741984260, 0.443148065717517750, 0.443192887585181050, +0.443237708344862150, 0.443282527996449350, 0.443327346539829860, 0.443372163974891990, 0.443416980301523660, 0.443461795519613340, 0.443506609629048140, 0.443551422629716360, +0.443596234521506090, 0.443641045304305590, 0.443685854978002110, 0.443730663542483970, 0.443775470997639590, 0.443820277343356110, 0.443865082579521950, 0.443909886706025050, +0.443954689722753870, 0.443999491629595570, 0.444044292426438500, 0.444089092113170770, 0.444133890689680620, 0.444178688155855430, 0.444223484511583440, 0.444268279756752820, +0.444313073891251850, 0.444357866914967810, 0.444402658827789070, 0.444447449629603750, 0.444492239320300130, 0.444537027899765570, 0.444581815367888430, 0.444626601724557150, +0.444671386969658970, 0.444716171103082260, 0.444760954124715220, 0.444805736034446120, 0.444850516832162310, 0.444895296517752230, 0.444940075091103890, 0.444984852552105740, +0.445029628900645070, 0.445074404136610370, 0.445119178259889610, 0.445163951270371280, 0.445208723167942740, 0.445253493952492360, 0.445298263623908230, 0.445343032182078880, +0.445387799626891510, 0.445432565958234660, 0.445477331175996800, 0.445522095280065260, 0.445566858270328380, 0.445611620146674440, 0.445656380908991790, 0.445701140557167810, +0.445745899091091020, 0.445790656510649420, 0.445835412815731640, 0.445880168006224880, 0.445924922082017670, 0.445969675042998230, 0.446014426889054960, 0.446059177620075240, +0.446103927235947550, 0.446148675736560090, 0.446193423121801320, 0.446238169391558580, 0.446282914545720390, 0.446327658584174950, 0.446372401506810790, 0.446417143313515170, +0.446461884004176750, 0.446506623578683980, 0.446551362036924250, 0.446596099378786140, 0.446640835604157740, 0.446685570712927690, 0.446730304704983320, 0.446775037580213140, +0.446819769338505420, 0.446864499979748640, 0.446909229503830220, 0.446953957910638740, 0.446998685200062360, 0.447043411371989610, 0.447088136426308010, 0.447132860362906060, +0.447177583181671940, 0.447222304882494260, 0.447267025465260430, 0.447311744929859030, 0.447356463276178620, 0.447401180504106710, 0.447445896613531850, 0.447490611604342230, +0.447535325476426490, 0.447580038229672020, 0.447624749863967500, 0.447669460379201080, 0.447714169775261410, 0.447758878052035900, 0.447803585209413210, 0.447848291247281540, +0.447892996165529580, 0.447937699964044640, 0.447982402642715550, 0.448027104201430440, 0.448071804640077900, 0.448116503958545520, 0.448161202156721840, 0.448205899234495610, +0.448250595191754140, 0.448295290028386250, 0.448339983744280140, 0.448384676339324440, 0.448429367813406700, 0.448474058166415500, 0.448518747398239160, 0.448563435508766320, +0.448608122497884510, 0.448652808365482440, 0.448697493111448300, 0.448742176735670850, 0.448786859238037520, 0.448831540618437110, 0.448876220876757770, 0.448920900012888310, +0.448965578026716220, 0.449010254918130180, 0.449054930687018520, 0.449099605333269870, 0.449144278856771880, 0.449188951257413150, 0.449233622535082420, 0.449278292689667290, +0.449322961721056400, 0.449367629629138120, 0.449412296413801150, 0.449456962074933020, 0.449501626612422540, 0.449546290026157980, 0.449590952316028080, 0.449635613481920380, +0.449680273523723640, 0.449724932441326270, 0.449769590234616930, 0.449814246903483210, 0.449858902447813900, 0.449903556867497330, 0.449948210162422260, 0.449992862332476260, +0.450037513377548100, 0.450082163297526590, 0.450126812092299270, 0.450171459761754880, 0.450216106305781850, 0.450260751724268990, 0.450305396017103790, 0.450350039184175150, +0.450394681225371410, 0.450439322140581360, 0.450483961929692590, 0.450528600592593920, 0.450573238129173770, 0.450617874539320900, 0.450662509822922940, 0.450707143979868720, +0.450751777010046650, 0.450796408913345490, 0.450841039689652940, 0.450885669338857820, 0.450930297860848930, 0.450974925255513860, 0.451019551522741480, 0.451064176662420210, +0.451108800674438930, 0.451153423558685210, 0.451198045315047980, 0.451242665943415610, 0.451287285443676970, 0.451331903815719690, 0.451376521059432710, 0.451421137174704390, +0.451465752161423650, 0.451510366019478140, 0.451554978748756660, 0.451599590349147760, 0.451644200820540300, 0.451688810162821920, 0.451733418375881550, 0.451778025459607990, +0.451822631413889010, 0.451867236238613410, 0.451911839933669730, 0.451956442498946900, 0.452001043934332490, 0.452045644239715490, 0.452090243414984440, 0.452134841460028080, +0.452179438374734290, 0.452224034158991870, 0.452268628812689420, 0.452313222335715750, 0.452357814727958610, 0.452402405989306980, 0.452446996119649280, 0.452491585118874550, +0.452536172986870430, 0.452580759723525850, 0.452625345328729390, 0.452669929802369970, 0.452714513144335360, 0.452759095354514420, 0.452803676432796180, 0.452848256379068340, +0.452892835193219820, 0.452937412875139220, 0.452981989424715510, 0.453026564841836450, 0.453071139126390960, 0.453115712278267580, 0.453160284297355390, 0.453204855183542030, +0.453249424936716550, 0.453293993556767530, 0.453338561043583890, 0.453383127397053500, 0.453427692617065230, 0.453472256703507770, 0.453516819656270050, 0.453561381475239890, +0.453605942160306250, 0.453650501711358180, 0.453695060128283480, 0.453739617410971070, 0.453784173559309670, 0.453828728573188230, 0.453873282452494530, 0.453917835197117650, +0.453962386806946230, 0.454006937281869190, 0.454051486621774410, 0.454096034826550920, 0.454140581896087300, 0.454185127830272710, 0.454229672628994830, 0.454274216292142820, +0.454318758819605210, 0.454363300211271140, 0.454407840467028420, 0.454452379586766100, 0.454496917570373250, 0.454541454417737630, 0.454585990128748450, 0.454630524703294290, +0.454675058141264190, 0.454719590442546060, 0.454764121607028950, 0.454808651634601550, 0.454853180525152890, 0.454897708278570900, 0.454942234894744610, 0.454986760373562780, +0.455031284714914440, 0.455075807918687460, 0.455120329984770980, 0.455164850913053700, 0.455209370703424650, 0.455253889355771770, 0.455298406869984180, 0.455342923245950600, +0.455387438483560110, 0.455431952582700580, 0.455476465543261210, 0.455520977365131030, 0.455565488048198080, 0.455609997592351320, 0.455654505997479640, 0.455699013263472060, +0.455743519390216570, 0.455788024377602240, 0.455832528225517900, 0.455877030933852620, 0.455921532502494340, 0.455966032931332250, 0.456010532220255120, 0.456055030369151960, +0.456099527377910930, 0.456144023246421000, 0.456188517974571050, 0.456233011562250210, 0.456277504009346410, 0.456321995315748910, 0.456366485481346780, 0.456410974506028020, +0.456455462389681820, 0.456499949132196990, 0.456544434733462730, 0.456588919193366920, 0.456633402511798850, 0.456677884688647230, 0.456722365723801320, 0.456766845617149090, +0.456811324368579800, 0.456855801977982150, 0.456900278445245390, 0.456944753770257510, 0.456989227952907810, 0.457033700993084990, 0.457078172890678370, 0.457122643645575870, +0.457167113257666790, 0.457211581726840290, 0.457256049052984450, 0.457300515235988530, 0.457344980275741280, 0.457389444172132010, 0.457433906925048710, 0.457478368534380620, +0.457522829000016620, 0.457567288321845960, 0.457611746499756670, 0.457656203533638060, 0.457700659423378900, 0.457745114168868480, 0.457789567769994910, 0.457834020226647380, +0.457878471538714800, 0.457922921706086510, 0.457967370728650460, 0.458011818606295970, 0.458056265338912360, 0.458100710926387660, 0.458145155368611220, 0.458189598665471880, +0.458234040816858920, 0.458278481822660510, 0.458322921682765840, 0.458367360397063940, 0.458411797965443960, 0.458456234387794090, 0.458500669664003660, 0.458545103793961570, +0.458589536777557090, 0.458633968614678420, 0.458678399305214760, 0.458722828849055130, 0.458767257246088860, 0.458811684496204020, 0.458856110599289990, 0.458900535555235630, +0.458944959363930370, 0.458989382025262290, 0.459033803539120820, 0.459078223905395160, 0.459122643123973610, 0.459167061194745370, 0.459211478117599550, 0.459255893892425380, +0.459300308519111130, 0.459344721997546060, 0.459389134327619240, 0.459433545509219940, 0.459477955542236360, 0.459522364426557920, 0.459566772162073590, 0.459611178748672690, +0.459655584186243470, 0.459699988474675300, 0.459744391613857160, 0.459788793603678410, 0.459833194444027260, 0.459877594134793180, 0.459921992675865480, 0.459966390067132410, +0.460010786308483350, 0.460055181399807330, 0.460099575340993770, 0.460143968131930870, 0.460188359772508050, 0.460232750262614340, 0.460277139602139120, 0.460321527790970690, +0.460365914828998410, 0.460410300716111330, 0.460454685452198920, 0.460499069037149430, 0.460543451470852240, 0.460587832753196420, 0.460632212884071410, 0.460676591863365460, +0.460720969690968040, 0.460765346366768640, 0.460809721890655390, 0.460854096262517890, 0.460898469482245170, 0.460942841549726650, 0.460987212464850580, 0.461031582227506560, +0.461075950837583510, 0.461120318294971020, 0.461164684599557340, 0.461209049751231950, 0.461253413749883930, 0.461297776595402780, 0.461342138287676780, 0.461386498826595440, +0.461430858212047880, 0.461475216443923530, 0.461519573522110760, 0.461563929446499040, 0.461608284216977530, 0.461652637833435690, 0.461696990295761830, 0.461741341603845560, +0.461785691757576280, 0.461830040756842360, 0.461874388601533400, 0.461918735291538430, 0.461963080826747030, 0.462007425207047520, 0.462051768432329420, 0.462096110502481950, +0.462140451417394570, 0.462184791176955710, 0.462229129781054790, 0.462273467229581130, 0.462317803522424130, 0.462362138659472290, 0.462406472640615070, 0.462450805465741690, +0.462495137134741660, 0.462539467647503420, 0.462583797003916500, 0.462628125203870480, 0.462672452247253730, 0.462716778133955840, 0.462761102863866070, 0.462805426436873890, +0.462849748852867780, 0.462894070111737280, 0.462938390213371580, 0.462982709157660320, 0.463027026944491940, 0.463071343573755900, 0.463115659045341580, 0.463159973359138500, +0.463204286515035040, 0.463248598512920880, 0.463292909352685240, 0.463337219034217760, 0.463381527557406800, 0.463425834922142010, 0.463470141128313030, 0.463514446175808340, +0.463558750064517470, 0.463603052794329780, 0.463647354365134820, 0.463691654776821120, 0.463735954029278250, 0.463780252122395490, 0.463824549056062520, 0.463868844830167770, +0.463913139444600890, 0.463957432899251180, 0.464001725194008290, 0.464046016328760690, 0.464090306303398040, 0.464134595117809630, 0.464178882771885130, 0.464223169265512990, +0.464267454598582980, 0.464311738770984690, 0.464356021782606710, 0.464400303633338620, 0.464444584323069790, 0.464488863851689910, 0.464533142219087480, 0.464577419425152180, +0.464621695469773330, 0.464665970352840630, 0.464710244074242610, 0.464754516633869020, 0.464798788031609070, 0.464843058267352620, 0.464887327340988090, 0.464931595252405240, +0.464975862001493380, 0.465020127588142260, 0.465064392012240480, 0.465108655273677670, 0.465152917372343270, 0.465197178308126960, 0.465241438080917280, 0.465285696690603990, +0.465329954137076900, 0.465374210420224530, 0.465418465539936600, 0.465462719496102520, 0.465506972288612040, 0.465551223917353760, 0.465595474382217380, 0.465639723683092310, +0.465683971819868370, 0.465728218792434090, 0.465772464600679230, 0.465816709244493250, 0.465860952723765880, 0.465905195038385730, 0.465949436188242580, 0.465993676173225850, +0.466037914993225330, 0.466082152648129630, 0.466126389137828560, 0.466170624462211860, 0.466214858621168240, 0.466259091614587510, 0.466303323442358970, 0.466347554104372560, +0.466391783600516860, 0.466436011930681740, 0.466480239094756550, 0.466524465092631180, 0.466568689924194260, 0.466612913589335600, 0.466657136087944620, 0.466701357419911260, +0.466745577585124080, 0.466789796583472970, 0.466834014414847340, 0.466878231079137060, 0.466922446576230830, 0.466966660906018520, 0.467010874068389930, 0.467055086063233700, +0.467099296890439830, 0.467143506549897670, 0.467187715041497200, 0.467231922365127010, 0.467276128520677010, 0.467320333508036700, 0.467364537327095930, 0.467408739977743400, +0.467452941459869100, 0.467497141773362380, 0.467541340918113220, 0.467585538894010330, 0.467629735700943570, 0.467673931338802470, 0.467718125807476960, 0.467762319106855730, +0.467806511236828700, 0.467850702197285420, 0.467894891988115740, 0.467939080609208410, 0.467983268060453430, 0.468027454341740650, 0.468071639452958880, 0.468115823393997990, +0.468160006164747510, 0.468204187765097420, 0.468248368194936480, 0.468292547454154660, 0.468336725542641390, 0.468380902460286740, 0.468425078206979480, 0.468469252782609480, +0.468513426187066370, 0.468557598420240030, 0.468601769482019370, 0.468645939372294260, 0.468690108090954290, 0.468734275637889440, 0.468778442012988570, 0.468822607216141550, +0.468866771247238360, 0.468910934106167910, 0.468955095792820130, 0.468999256307084560, 0.469043415648851270, 0.469087573818009030, 0.469131730814447920, 0.469175886638057430, +0.469220041288727630, 0.469264194766347340, 0.469308347070806540, 0.469352498201994870, 0.469396648159802370, 0.469440796944117830, 0.469484944554831360, 0.469529090991832490, +0.469573236255011240, 0.469617380344256540, 0.469661523259458420, 0.469705665000506870, 0.469749805567290730, 0.469793944959700120, 0.469838083177624650, 0.469882220220954330, +0.469926356089578110, 0.469970490783385930, 0.470014624302267590, 0.470058756646113070, 0.470102887814811240, 0.470147017808252190, 0.470191146626325660, 0.470235274268921590, +0.470279400735928940, 0.470323526027237810, 0.470367650142737900, 0.470411773082319180, 0.470455894845870690, 0.470500015433282460, 0.470544134844444570, 0.470588253079245960, +0.470632370137576690, 0.470676486019326550, 0.470720600724385540, 0.470764714252642660, 0.470808826603987980, 0.470852937778311220, 0.470897047775502560, 0.470941156595450830, +0.470985264238046260, 0.471029370703178460, 0.471073475990737680, 0.471117580100612830, 0.471161683032694010, 0.471205784786870970, 0.471249885363033860, 0.471293984761071650, +0.471338082980874480, 0.471382180022332120, 0.471426275885334700, 0.471470370569771200, 0.471514464075531770, 0.471558556402506550, 0.471602647550584560, 0.471646737519655910, +0.471690826309610460, 0.471734913920338340, 0.471779000351728540, 0.471823085603671260, 0.471867169676056240, 0.471911252568773700, 0.471955334281712600, 0.471999414814763210, +0.472043494167815270, 0.472087572340758990, 0.472131649333483390, 0.472175725145878630, 0.472219799777834570, 0.472263873229241460, 0.472307945499988220, 0.472352016589965120, +0.472396086499062400, 0.472440155227169030, 0.472484222774175290, 0.472528289139971030, 0.472572354324446390, 0.472616418327490460, 0.472660481148993510, 0.472704542788845380, +0.472748603246936290, 0.472792662523155270, 0.472836720617392570, 0.472880777529538110, 0.472924833259482090, 0.472968887807113600, 0.473012941172322900, 0.473056993354999840, +0.473101044355034640, 0.473145094172316480, 0.473189142806735570, 0.473233190258182220, 0.473277236526545520, 0.473321281611715660, 0.473365325513582680, 0.473409368232036720, +0.473453409766966930, 0.473497450118263660, 0.473541489285816740, 0.473585527269516530, 0.473629564069252050, 0.473673599684913740, 0.473717634116391340, 0.473761667363575280, +0.473805699426354700, 0.473849730304619850, 0.473893759998260670, 0.473937788507167450, 0.473981815831229390, 0.474025841970336810, 0.474069866924379580, 0.474113890693248110, +0.474157913276831540, 0.474201934675020140, 0.474245954887704320, 0.474289973914773230, 0.474333991756117180, 0.474378008411626200, 0.474422023881190540, 0.474466038164699460, +0.474510051262043260, 0.474554063173111940, 0.474598073897795850, 0.474642083435984190, 0.474686091787567320, 0.474730098952435230, 0.474774104930478280, 0.474818109721585670, +0.474862113325647820, 0.474906115742554650, 0.474950116972196580, 0.474994117014462810, 0.475038115869243830, 0.475082113536429870, 0.475126110015910260, 0.475170105307575360, +0.475214099411315210, 0.475258092327020210, 0.475302084054579580, 0.475346074593883780, 0.475390063944822750, 0.475434052107286950, 0.475478039081165650, 0.475522024866349200, +0.475566009462727760, 0.475609992870191680, 0.475653975088630170, 0.475697956117933750, 0.475741935957992470, 0.475785914608696680, 0.475829892069935760, 0.475873868341600110, +0.475917843423580180, 0.475961817315765260, 0.476005790018045770, 0.476049761530311810, 0.476093731852453850, 0.476137700984361150, 0.476181668925924170, 0.476225635677033080, +0.476269601237578280, 0.476313565607449090, 0.476357528786535980, 0.476401490774728990, 0.476445451571918750, 0.476489411177994430, 0.476533369592846650, 0.476577326816365390, +0.476621282848441190, 0.476665237688963410, 0.476709191337822580, 0.476753143794909070, 0.476797095060112420, 0.476841045133322980, 0.476884994014430910, 0.476928941703326780, +0.476972888199899860, 0.477016833504040780, 0.477060777615639590, 0.477104720534586800, 0.477148662260771850, 0.477192602794085260, 0.477236542134417190, 0.477280480281658090, +0.477324417235697460, 0.477368352996425770, 0.477412287563733160, 0.477456220937510280, 0.477500153117646430, 0.477544084104032150, 0.477588013896557750, 0.477631942495113650, +0.477675869899589320, 0.477719796109875310, 0.477763721125862180, 0.477807644947439380, 0.477851567574497430, 0.477895489006926630, 0.477939409244617470, 0.477983328287459370, +0.478027246135342980, 0.478071162788158480, 0.478115078245796410, 0.478158992508146310, 0.478202905575098700, 0.478246817446543850, 0.478290728122372330, 0.478334637602473630, +0.478378545886738280, 0.478422452975056590, 0.478466358867319200, 0.478510263563415470, 0.478554167063236110, 0.478598069366671710, 0.478641970473611730, 0.478685870383946830, +0.478729769097567260, 0.478773666614363710, 0.478817562934225560, 0.478861458057043500, 0.478905351982707780, 0.478949244711109060, 0.478993136242136910, 0.479037026575681870, +0.479080915711634250, 0.479124803649884750, 0.479168690390322840, 0.479212575932839220, 0.479256460277324160, 0.479300343423668340, 0.479344225371761250, 0.479388106121493630, +0.479431985672756130, 0.479475864025438240, 0.479519741179430690, 0.479563617134623810, 0.479607491890908290, 0.479651365448173660, 0.479695237806310570, 0.479739108965209440, +0.479782978924760910, 0.479826847684854510, 0.479870715245381000, 0.479914581606230740, 0.479958446767294380, 0.480002310728461560, 0.480046173489622920, 0.480090035050668830, +0.480133895411490100, 0.480177754571976200, 0.480221612532017890, 0.480265469291505600, 0.480309324850330010, 0.480353179208380720, 0.480397032365548480, 0.480440884321724050, +0.480484735076797010, 0.480528584630658120, 0.480572432983197790, 0.480616280134306790, 0.480660126083874650, 0.480703970831792230, 0.480747814377949890, 0.480791656722238390, +0.480835497864547380, 0.480879337804767600, 0.480923176542789490, 0.480967014078503790, 0.481010850411800190, 0.481054685542569470, 0.481098519470702040, 0.481142352196088700, +0.481186183718619100, 0.481230014038184000, 0.481273843154674310, 0.481317671067979570, 0.481361497777990700, 0.481405323284598060, 0.481449147587692470, 0.481492970687163680, +0.481536792582902440, 0.481580613274799230, 0.481624432762744860, 0.481668251046629030, 0.481712068126342540, 0.481755884001775940, 0.481799698672819960, 0.481843512139364380, +0.481887324401300000, 0.481931135458517290, 0.481974945310907180, 0.482018753958359300, 0.482062561400764530, 0.482106367638013730, 0.482150172669996660, 0.482193976496604120, +0.482237779117726690, 0.482281580533255150, 0.482325380743079290, 0.482369179747089980, 0.482412977545177760, 0.482456774137233420, 0.482500569523146790, 0.482544363702808730, +0.482588156676109710, 0.482631948442940770, 0.482675739003191550, 0.482719528356752970, 0.482763316503515560, 0.482807103443370240, 0.482850889176206780, 0.482894673701916130, +0.482938457020389120, 0.482982239131515670, 0.483026020035186520, 0.483069799731292380, 0.483113578219724120, 0.483157355500371530, 0.483201131573125550, 0.483244906437876760, +0.483288680094516090, 0.483332452542933280, 0.483376223783019370, 0.483419993814664940, 0.483463762637760860, 0.483507530252197000, 0.483551296657864340, 0.483595061854653400, +0.483638825842455210, 0.483682588621159590, 0.483726350190657460, 0.483770110550839460, 0.483813869701596620, 0.483857627642818640, 0.483901384374396670, 0.483945139896221570, +0.483988894208183250, 0.484032647310172700, 0.484076399202080510, 0.484120149883797760, 0.484163899355214200, 0.484207647616220930, 0.484251394666708520, 0.484295140506568020, +0.484338885135689230, 0.484382628553963300, 0.484426370761280760, 0.484470111757532680, 0.484513851542608950, 0.484557590116400590, 0.484601327478798250, 0.484645063629693010, +0.484688798568974680, 0.484732532296534350, 0.484776264812263100, 0.484819996116050810, 0.484863726207788500, 0.484907455087366880, 0.484951182754677020, 0.484994909209608800, +0.485038634452053310, 0.485082358481901290, 0.485126081299043720, 0.485169802903370530, 0.485213523294772850, 0.485257242473141390, 0.485300960438367180, 0.485344677190340190, +0.485388392728951510, 0.485432107054091900, 0.485475820165652330, 0.485519532063522830, 0.485563242747594550, 0.485606952217758510, 0.485650660473904710, 0.485694367515924260, +0.485738073343707940, 0.485781777957146780, 0.485825481356130790, 0.485869183540551090, 0.485912884510298460, 0.485956584265263950, 0.486000282805337640, 0.486043980130410610, +0.486087676240373630, 0.486131371135117840, 0.486175064814533260, 0.486218757278510990, 0.486262448526941840, 0.486306138559716940, 0.486349827376726330, 0.486393514977861150, +0.486437201363012160, 0.486480886532070560, 0.486524570484926370, 0.486568253221470740, 0.486611934741594860, 0.486655615045188780, 0.486699294132143630, 0.486742972002350280, +0.486786648655699870, 0.486830324092082490, 0.486873998311389280, 0.486917671313511050, 0.486961343098339050, 0.487005013665763260, 0.487048683015675000, 0.487092351147965010, +0.487136018062524490, 0.487179683759243590, 0.487223348238013440, 0.487267011498724980, 0.487310673541269330, 0.487354334365536600, 0.487397993971418090, 0.487441652358804930, +0.487485309527587280, 0.487528965477656340, 0.487572620208902960, 0.487616273721218460, 0.487659926014492870, 0.487703577088617500, 0.487747226943483160, 0.487790875578981150, +0.487834522995001520, 0.487878169191435620, 0.487921814168174320, 0.487965457925108810, 0.488009100462129310, 0.488052741779127050, 0.488096381875992970, 0.488140020752618310, +0.488183658408893160, 0.488227294844708890, 0.488270930059956810, 0.488314564054526950, 0.488358196828310720, 0.488401828381199000, 0.488445458713083090, 0.488489087823853140, +0.488532715713400510, 0.488576342381616070, 0.488619967828391120, 0.488663592053615870, 0.488707215057181680, 0.488750836838979460, 0.488794457398900480, 0.488838076736835050, +0.488881694852674350, 0.488925311746309430, 0.488968927417631650, 0.489012541866531150, 0.489056155092899290, 0.489099767096627390, 0.489143377877605760, 0.489186987435725640, +0.489230595770878070, 0.489274202882954420, 0.489317808771844830, 0.489361413437440720, 0.489405016879633110, 0.489448619098313330, 0.489492220093371620, 0.489535819864699350, +0.489579418412187550, 0.489623015735727530, 0.489666611835209650, 0.489710206710525230, 0.489753800361565240, 0.489797392788221210, 0.489840983990383280, 0.489884573967942880, +0.489928162720791040, 0.489971750248819230, 0.490015336551917590, 0.490058921629977660, 0.490102505482890800, 0.490146088110547270, 0.490189669512838540, 0.490233249689655650, +0.490276828640890010, 0.490320406366431930, 0.490363982866172780, 0.490407558140003700, 0.490451132187816110, 0.490494705009500320, 0.490538276604947750, 0.490581846974049500, +0.490625416116697020, 0.490668984032780590, 0.490712550722191720, 0.490756116184821510, 0.490799680420561320, 0.490843243429301580, 0.490886805210933750, 0.490930365765349260, +0.490973925092438530, 0.491017483192092930, 0.491061040064203650, 0.491104595708662110, 0.491148150125358730, 0.491191703314184990, 0.491235255275031980, 0.491278806007791170, +0.491322355512353040, 0.491365903788608950, 0.491409450836450160, 0.491452996655768080, 0.491496541246453140, 0.491540084608396880, 0.491583626741490360, 0.491627167645625200, +0.491670707320691740, 0.491714245766581460, 0.491757782983185950, 0.491801318970395640, 0.491844853728102050, 0.491888387256196270, 0.491931919554569940, 0.491975450623113430, +0.492018980461718270, 0.492062509070275660, 0.492106036448677180, 0.492149562596813190, 0.492193087514575360, 0.492236611201854750, 0.492280133658543060, 0.492323654884530560, +0.492367174879708990, 0.492410693643969500, 0.492454211177203620, 0.492497727479301820, 0.492541242550155740, 0.492584756389656540, 0.492628268997695800, 0.492671780374164040, +0.492715290518952800, 0.492758799431953720, 0.492802307113057280, 0.492845813562155070, 0.492889318779138330, 0.492932822763898660, 0.492976325516326590, 0.493019827036313640, +0.493063327323751190, 0.493106826378530760, 0.493150324200542890, 0.493193820789679220, 0.493237316145831000, 0.493280810268889870, 0.493324303158746310, 0.493367794815292030, +0.493411285238418260, 0.493454774428016610, 0.493498262383977700, 0.493541749106193080, 0.493585234594554500, 0.493628718848952490, 0.493672201869278630, 0.493715683655424290, +0.493759164207281110, 0.493802643524739630, 0.493846121607691530, 0.493889598456028140, 0.493933074069641150, 0.493976548448421090, 0.494020021592259660, 0.494063493501048170, +0.494106964174678360, 0.494150433613040730, 0.494193901816027010, 0.494237368783528530, 0.494280834515437030, 0.494324299011643040, 0.494367762272038320, 0.494411224296514570, +0.494454685084962380, 0.494498144637273480, 0.494541602953339210, 0.494585060033051300, 0.494628515876300410, 0.494671970482978170, 0.494715423852976070, 0.494758875986185730, +0.494802326882497870, 0.494845776541804170, 0.494889224963996010, 0.494932672148965190, 0.494976118096602300, 0.495019562806799100, 0.495063006279447050, 0.495106448514437800, +0.495149889511662060, 0.495193329271011620, 0.495236767792378240, 0.495280205075652570, 0.495323641120726350, 0.495367075927491070, 0.495410509495838420, 0.495453941825659160, +0.495497372916845040, 0.495540802769287470, 0.495584231382878330, 0.495627658757508190, 0.495671084893068880, 0.495714509789451860, 0.495757933446549000, 0.495801355864250890, +0.495844777042449390, 0.495888196981035980, 0.495931615679902400, 0.495975033138939430, 0.496018449358038900, 0.496061864337092210, 0.496105278075991250, 0.496148690574626740, +0.496192101832890480, 0.496235511850674380, 0.496278920627869100, 0.496322328164366500, 0.496365734460058050, 0.496409139514835730, 0.496452543328590120, 0.496495945901213150, +0.496539347232596350, 0.496582747322631520, 0.496626146171209480, 0.496669543778222090, 0.496712940143560770, 0.496756335267117540, 0.496799729148783060, 0.496843121788449300, +0.496886513186007680, 0.496929903341350230, 0.496973292254367590, 0.497016679924951690, 0.497060066352994550, 0.497103451538386810, 0.497146835481020450, 0.497190218180787010, +0.497233599637578410, 0.497276979851285380, 0.497320358821799920, 0.497363736549013610, 0.497407113032818320, 0.497450488273104840, 0.497493862269765160, 0.497537235022690870, +0.497580606531773830, 0.497623976796904840, 0.497667345817976000, 0.497710713594878730, 0.497754080127505110, 0.497797445415745890, 0.497840809459493050, 0.497884172258638570, +0.497927533813073250, 0.497970894122689130, 0.498014253187377740, 0.498057611007031160, 0.498100967581540100, 0.498144322910796690, 0.498187676994692410, 0.498231029833119340, +0.498274381425968360, 0.498317731773131380, 0.498361080874500100, 0.498404428729966430, 0.498447775339421360, 0.498491120702756860, 0.498534464819864580, 0.498577807690636480, +0.498621149314963490, 0.498664489692737580, 0.498707828823850510, 0.498751166708194250, 0.498794503345659670, 0.498837838736138790, 0.498881172879523770, 0.498924505775705410, +0.498967837424575730, 0.499011167826026560, 0.499054496979949800, 0.499097824886236390, 0.499141151544778450, 0.499184476955467640, 0.499227801118195980, 0.499271124032854450, +0.499314445699335140, 0.499357766117529690, 0.499401085287330240, 0.499444403208627650, 0.499487719881314070, 0.499531035305281200, 0.499574349480421120, 0.499617662406624750, +0.499660974083784290, 0.499704284511791720, 0.499747593690538060, 0.499790901619915460, 0.499834208299815560, 0.499877513730130560, 0.499920817910751380, 0.499964120841570160, +0.500007422522478650, 0.500050722953368940, 0.500094022134132010, 0.500137320064660050, 0.500180616744844820, 0.500223912174578400, 0.500267206353751880, 0.500310499282257240, +0.500353790959986440, 0.500397081386831480, 0.500440370562683420, 0.500483658487434480, 0.500526945160976840, 0.500570230583201380, 0.500613514754000400, 0.500656797673265540, +0.500700079340889110, 0.500743359756762100, 0.500786638920776680, 0.500829916832824740, 0.500873193492798350, 0.500916468900588500, 0.500959743056087590, 0.501003015959187280, +0.501046287609779870, 0.501089558007756230, 0.501132827153008780, 0.501176095045429260, 0.501219361684909880, 0.501262627071341730, 0.501305891204616990, 0.501349154084627550, +0.501392415711265580, 0.501435676084422190, 0.501478935203989560, 0.501522193069860120, 0.501565449681924620, 0.501608705040075710, 0.501651959144204910, 0.501695211994204530, +0.501738463589965880, 0.501781713931380930, 0.501824963018341790, 0.501868210850740630, 0.501911457428468540, 0.501954702751417850, 0.501997946819480400, 0.502041189632548400, +0.502084431190513050, 0.502127671493266650, 0.502170910540701070, 0.502214148332708610, 0.502257384869180370, 0.502300620150008650, 0.502343854175085760, 0.502387086944302900, +0.502430318457552370, 0.502473548714725940, 0.502516777715716010, 0.502560005460413910, 0.502603231948711590, 0.502646457180501380, 0.502689681155675250, 0.502732903874124610, +0.502776125335741670, 0.502819345540418520, 0.502862564488047340, 0.502905782178519330, 0.502948998611726930, 0.502992213787561980, 0.503035427705916800, 0.503078640366682820, +0.503121851769752100, 0.503165061915017200, 0.503208270802369300, 0.503251478431700710, 0.503294684802903400, 0.503337889915869810, 0.503381093770491010, 0.503424296366659530, +0.503467497704267350, 0.503510697783206780, 0.503553896603369020, 0.503597094164646600, 0.503640290466931480, 0.503683485510115880, 0.503726679294091320, 0.503769871818749990, +0.503813063083983990, 0.503856253089685730, 0.503899441835746420, 0.503942629322058580, 0.503985815548514520, 0.504029000515005430, 0.504072184221423970, 0.504115366667661990, +0.504158547853612030, 0.504201727779165280, 0.504244906444214160, 0.504288083848650870, 0.504331259992367720, 0.504374434875256020, 0.504417608497208180, 0.504460780858116410, +0.504503951957873010, 0.504547121796369400, 0.504590290373498010, 0.504633457689150800, 0.504676623743220420, 0.504719788535598070, 0.504762952066176160, 0.504806114334847010, +0.504849275341502810, 0.504892435086035210, 0.504935593568336390, 0.504978750788299010, 0.505021906745814380, 0.505065061440775010, 0.505108214873072890, 0.505151367042600660, +0.505194517949249630, 0.505237667592912330, 0.505280815973480960, 0.505323963090847820, 0.505367108944904330, 0.505410253535543140, 0.505453396862656330, 0.505496538926136440, +0.505539679725874770, 0.505582819261763850, 0.505625957533695990, 0.505669094541563500, 0.505712230285258020, 0.505755364764671870, 0.505798497979697670, 0.505841629930226970, +0.505884760616152060, 0.505927890037365380, 0.505971018193759230, 0.506014145085225240, 0.506057270711655850, 0.506100395072943240, 0.506143518168980070, 0.506186639999657740, +0.506229760564868790, 0.506272879864505530, 0.506315997898460380, 0.506359114666624750, 0.506402230168891410, 0.506445344405152540, 0.506488457375300680, 0.506531569079227250, +0.506574679516825000, 0.506617788687986350, 0.506660896592602830, 0.506704003230567080, 0.506747108601771300, 0.506790212706108250, 0.506833315543469110, 0.506876417113746870, +0.506919517416833500, 0.506962616452621640, 0.507005714221002930, 0.507048810721869910, 0.507091905955114890, 0.507134999920630490, 0.507178092618308260, 0.507221184048040730, +0.507264274209720200, 0.507307363103239430, 0.507350450728489830, 0.507393537085364170, 0.507436622173754630, 0.507479705993553960, 0.507522788544653600, 0.507565869826946180, +0.507608949840324560, 0.507652028584680170, 0.507695106059905750, 0.507738182265893510, 0.507781257202536310, 0.507824330869725450, 0.507867403267353800, 0.507910474395313670, +0.507953544253497700, 0.507996612841797530, 0.508039680160105810, 0.508082746208314840, 0.508125810986317480, 0.508168874494005160, 0.508211936731270630, 0.508254997698006310, +0.508298057394104830, 0.508341115819457840, 0.508384172973957990, 0.508427228857498250, 0.508470283469969920, 0.508513336811265980, 0.508556388881278630, 0.508599439679900730, +0.508642489207023820, 0.508685537462540640, 0.508728584446343720, 0.508771630158325720, 0.508814674598378150, 0.508857717766393990, 0.508900759662265450, 0.508943800285885480, +0.508986839637145640, 0.509029877715938660, 0.509072914522156970, 0.509115950055693430, 0.509158984316439580, 0.509202017304288270, 0.509245049019132260, 0.509288079460863300, +0.509331108629374140, 0.509374136524557210, 0.509417163146305360, 0.509460188494510140, 0.509503212569064500, 0.509546235369860880, 0.509589256896791910, 0.509632277149749570, +0.509675296128626500, 0.509718313833315120, 0.509761330263708400, 0.509804345419697880, 0.509847359301176640, 0.509890371908036880, 0.509933383240171570, 0.509976393297472460, +0.510019402079832430, 0.510062409587144220, 0.510105415819299580, 0.510148420776191490, 0.510191424457712260, 0.510234426863754860, 0.510277427994211050, 0.510320427848973580, +0.510363426427935200, 0.510406423730988550, 0.510449419758025380, 0.510492414508938790, 0.510535407983621070, 0.510578400181965210, 0.510621391103863060, 0.510664380749207390, +0.510707369117890720, 0.510750356209806020, 0.510793342024845170, 0.510836326562900790, 0.510879309823865760, 0.510922291807632710, 0.510965272514093630, 0.511008251943141260, +0.511051230094668680, 0.511094206968567780, 0.511137182564731170, 0.511180156883051740, 0.511223129923422230, 0.511266101685734500, 0.511309072169881640, 0.511352041375755960, +0.511395009303250660, 0.511437975952257370, 0.511480941322669190, 0.511523905414378640, 0.511566868227278700, 0.511609829761261240, 0.511652790016219220, 0.511695748992045170, +0.511738706688632080, 0.511781663105871920, 0.511824618243657660, 0.511867572101882160, 0.511910524680437300, 0.511953475979216250, 0.511996425998111460, 0.512039374737016000, +0.512082322195821620, 0.512125268374421520, 0.512168213272708230, 0.512211156890574840, 0.512254099227913100, 0.512297040284616200, 0.512339980060576570, 0.512382918555687520, +0.512425855769840680, 0.512468791702929250, 0.512511726354845880, 0.512554659725483530, 0.512597591814734080, 0.512640522622490710, 0.512683452148646520, 0.512726380393093150, +0.512769307355723900, 0.512812233036431420, 0.512855157435108680, 0.512898080551647760, 0.512941002385941540, 0.512983922937882860, 0.513026842207364720, 0.513069760194279080, +0.513112676898519030, 0.513155592319977320, 0.513198506458547030, 0.513241419314120150, 0.513284330886589650, 0.513327241175848270, 0.513370150181789220, 0.513413057904304470, +0.513455964343287000, 0.513498869498629660, 0.513541773370225550, 0.513584675957966530, 0.513627577261745900, 0.513670477281456650, 0.513713376016990850, 0.513756273468241710, +0.513799169635101750, 0.513842064517464280, 0.513884958115221280, 0.513927850428265940, 0.513970741456490910, 0.514013631199789380, 0.514056519658053430, 0.514099406831176160, +0.514142292719050430, 0.514185177321569320, 0.514228060638624920, 0.514270942670110310, 0.514313823415918360, 0.514356702875942260, 0.514399581050074000, 0.514442457938206750, +0.514485333540233740, 0.514528207856047140, 0.514571080885539820, 0.514613952628604990, 0.514656823085135610, 0.514699692255023660, 0.514742560138162660, 0.514785426734445160, +0.514828292043764460, 0.514871156066012640, 0.514914018801083010, 0.514956880248868320, 0.514999740409261770, 0.515042599282155460, 0.515085456867442780, 0.515128313165016280, +0.515171168174769490, 0.515214021896594380, 0.515256874330384250, 0.515299725476032310, 0.515342575333430640, 0.515385423902472550, 0.515428271183050900, 0.515471117175058890, +0.515513961878388720, 0.515556805292933680, 0.515599647418586660, 0.515642488255240950, 0.515685327802788530, 0.515728166061122820, 0.515771003030136680, 0.515813838709723420, +0.515856673099775230, 0.515899506200185320, 0.515942338010846660, 0.515985168531652550, 0.516027997762495080, 0.516070825703267680, 0.516113652353863530, 0.516156477714174940, +0.516199301784095010, 0.516242124563517040, 0.516284946052333990, 0.516327766250438190, 0.516370585157723050, 0.516413402774081430, 0.516456219099406640, 0.516499034133591000, +0.516541847876527680, 0.516584660328109790, 0.516627471488230740, 0.516670281356782500, 0.516713089933658500, 0.516755897218751930, 0.516798703211955870, 0.516841507913162750, +0.516884311322265870, 0.516927113439158090, 0.516969914263733070, 0.517012713795882760, 0.517055512035500710, 0.517098308982480330, 0.517141104636713700, 0.517183898998094360, +0.517226692066515280, 0.517269483841869770, 0.517312274324050250, 0.517355063512950020, 0.517397851408462060, 0.517440638010480010, 0.517483423318895850, 0.517526207333603220, +0.517568990054494970, 0.517611771481464760, 0.517654551614404660, 0.517697330453208200, 0.517740107997768370, 0.517782884247978690, 0.517825659203731360, 0.517868432864920010, +0.517911205231437850, 0.517953976303177300, 0.517996746080031880, 0.518039514561894570, 0.518082281748658780, 0.518125047640217050, 0.518167812236462580, 0.518210575537288660, +0.518253337542588620, 0.518296098252254870, 0.518338857666180820, 0.518381615784259680, 0.518424372606384960, 0.518467128132448770, 0.518509882362344850, 0.518552635295966290, +0.518595386933206390, 0.518638137273957690, 0.518680886318113710, 0.518723634065567870, 0.518766380516212490, 0.518809125669941200, 0.518851869526647190, 0.518894612086223780, +0.518937353348563500, 0.518980093313559760, 0.519022831981105880, 0.519065569351095270, 0.519108305423420350, 0.519151040197974640, 0.519193773674651360, 0.519236505853344020, +0.519279236733945050, 0.519321966316347970, 0.519364694600445990, 0.519407421586132620, 0.519450147273300410, 0.519492871661842770, 0.519535594751652900, 0.519578316542624540, +0.519621037034649900, 0.519663756227622730, 0.519706474121436560, 0.519749190715983690, 0.519791906011157990, 0.519834620006852430, 0.519877332702960770, 0.519920044099375420, +0.519962754195989920, 0.520005462992697560, 0.520048170489391890, 0.520090876685965430, 0.520133581582311710, 0.520176285178324150, 0.520218987473896170, 0.520261688468920400, +0.520304388163290390, 0.520347086556899430, 0.520389783649641060, 0.520432479441407910, 0.520475173932093530, 0.520517867121591650, 0.520560559009794700, 0.520603249596596320, +0.520645938881889810, 0.520688626865568830, 0.520731313547526000, 0.520773998927654750, 0.520816683005848600, 0.520859365782001090, 0.520902047256004860, 0.520944727427753440, +0.520987406297140130, 0.521030083864058800, 0.521072760128401870, 0.521115435090062970, 0.521158108748935530, 0.521200781104913190, 0.521243452157888590, 0.521286121907755250, +0.521328790354407050, 0.521371457497736390, 0.521414123337637150, 0.521456787874002630, 0.521499451106726570, 0.521542113035701420, 0.521584773660821010, 0.521627432981978670, +0.521670090999068140, 0.521712747711981950, 0.521755403120613970, 0.521798057224857390, 0.521840710024606080, 0.521883361519752680, 0.521926011710190820, 0.521968660595813930, +0.522011308176515750, 0.522053954452188940, 0.522096599422727240, 0.522139243088024510, 0.522181885447973170, 0.522224526502467200, 0.522267166251399790, 0.522309804694665040, +0.522352441832155230, 0.522395077663764360, 0.522437712189385840, 0.522480345408913420, 0.522522977322239730, 0.522565607929258550, 0.522608237229863380, 0.522650865223947990, +0.522693491911405130, 0.522736117292128430, 0.522778741366011550, 0.522821364132948110, 0.522863985592830980, 0.522906605745553810, 0.522949224591010120, 0.522991842129093780, +0.523034458359697420, 0.523077073282714910, 0.523119686898040110, 0.523162299205565780, 0.523204910205185670, 0.523247519896793190, 0.523290128280282430, 0.523332735355545810, +0.523375341122477520, 0.523417945580970770, 0.523460548730919630, 0.523503150572216640, 0.523545751104755760, 0.523588350328430540, 0.523630948243134830, 0.523673544848761390, +0.523716140145204070, 0.523758734132356410, 0.523801326810112270, 0.523843918178364510, 0.523886508237006890, 0.523929096985933370, 0.523971684425036720, 0.524014270554210900, +0.524056855373349450, 0.524099438882346110, 0.524142021081093870, 0.524184601969486570, 0.524227181547417760, 0.524269759814781410, 0.524312336771470270, 0.524354912417378300, +0.524397486752398940, 0.524440059776426380, 0.524482631489353260, 0.524525201891073430, 0.524567770981480770, 0.524610338760469030, 0.524652905227930950, 0.524695470383760740, +0.524738034227852150, 0.524780596760098140, 0.524823157980392590, 0.524865717888629240, 0.524908276484701840, 0.524950833768503490, 0.524993389739928040, 0.525035944398869030, +0.525078497745220640, 0.525121049778875530, 0.525163600499727880, 0.525206149907671120, 0.525248698002599430, 0.525291244784405700, 0.525333790252983770, 0.525376334408227400, +0.525418877250030560, 0.525461418778286120, 0.525503958992888150, 0.525546497893730310, 0.525589035480706570, 0.525631571753709890, 0.525674106712634260, 0.525716640357373750, +0.525759172687821240, 0.525801703703870800, 0.525844233405416080, 0.525886761792351170, 0.525929288864569020, 0.525971814621963630, 0.526014339064428740, 0.526056862191858320, +0.526099384004145350, 0.526141904501184030, 0.526184423682867890, 0.526226941549091000, 0.526269458099746460, 0.526311973334728230, 0.526354487253930080, 0.526396999857246080, +0.526439511144569220, 0.526482021115793560, 0.526524529770813320, 0.526567037109521240, 0.526609543131811630, 0.526652047837578240, 0.526694551226715050, 0.526737053299115020, +0.526779554054672470, 0.526822053493280930, 0.526864551614834700, 0.526907048419226750, 0.526949543906351180, 0.526992038076101620, 0.527034530928372490, 0.527077022463056540, +0.527119512680048090, 0.527162001579240870, 0.527204489160529090, 0.527246975423805610, 0.527289460368964740, 0.527331943995900550, 0.527374426304506150, 0.527416907294675610, +0.527459386966302900, 0.527501865319282110, 0.527544342353506220, 0.527586818068869420, 0.527629292465265690, 0.527671765542589100, 0.527714237300732640, 0.527756707739590600, +0.527799176859056860, 0.527841644659025500, 0.527884111139389710, 0.527926576300043580, 0.527969040140881090, 0.528011502661796310, 0.528053963862682330, 0.528096423743433570, +0.528138882303944010, 0.528181339544106950, 0.528223795463816590, 0.528266250062966680, 0.528308703341451520, 0.528351155299164210, 0.528393605935999040, 0.528436055251849780, +0.528478503246610830, 0.528520949920175290, 0.528563395272437230, 0.528605839303290860, 0.528648282012630140, 0.528690723400348390, 0.528733163466339810, 0.528775602210498350, +0.528818039632718230, 0.528860475732892630, 0.528902910510915870, 0.528945343966681800, 0.528987776100084740, 0.529030206911017880, 0.529072636399375520, 0.529115064565051970, +0.529157491407940330, 0.529199916927935000, 0.529242341124929850, 0.529284763998819300, 0.529327185549496430, 0.529369605776855550, 0.529412024680790630, 0.529454442261196090, +0.529496858517965020, 0.529539273450991830, 0.529581687060170500, 0.529624099345395230, 0.529666510306559420, 0.529708919943557290, 0.529751328256282910, 0.529793735244630580, +0.529836140908493510, 0.529878545247766010, 0.529920948262342590, 0.529963349952116470, 0.530005750316981940, 0.530048149356833090, 0.530090547071564110, 0.530132943461068540, +0.530175338525240460, 0.530217732263974170, 0.530260124677163880, 0.530302515764702890, 0.530344905526485500, 0.530387293962406030, 0.530429681072358550, 0.530472066856236600, +0.530514451313934490, 0.530556834445346180, 0.530599216250366210, 0.530641596728887780, 0.530683975880805400, 0.530726353706013400, 0.530768730204405180, 0.530811105375875170, +0.530853479220317340, 0.530895851737626210, 0.530938222927695100, 0.530980592790418430, 0.531022961325690270, 0.531065328533405050, 0.531107694413456180, 0.531150058965737970, +0.531192422190144730, 0.531234784086570770, 0.531277144654909490, 0.531319503895055330, 0.531361861806902370, 0.531404218390345240, 0.531446573645277140, 0.531488927571592610, +0.531531280169185720, 0.531573631437951000, 0.531615981377781880, 0.531658329988572760, 0.531700677270218190, 0.531743023222611580, 0.531785367845647450, 0.531827711139219780, +0.531870053103223330, 0.531912393737551280, 0.531954733042098280, 0.531997071016758530, 0.532039407661426320, 0.532081742975995420, 0.532124076960360020, 0.532166409614414420, +0.532208740938053260, 0.532251070931169750, 0.532293399593658620, 0.532335726925413980, 0.532378052926330450, 0.532420377596301450, 0.532462700935221410, 0.532505022942984960, +0.532547343619485640, 0.532589662964617960, 0.532631980978276130, 0.532674297660354790, 0.532716613010747240, 0.532758927029348130, 0.532801239716051760, 0.532843551070752650, +0.532885861093344350, 0.532928169783721260, 0.532970477141777920, 0.533012783167408630, 0.533055087860507040, 0.533097391220967780, 0.533139693248684930, 0.533181993943553370, +0.533224293305466280, 0.533266591334318530, 0.533308888030004760, 0.533351183392418270, 0.533393477421453930, 0.533435770117005830, 0.533478061478968700, 0.533520351507236090, +0.533562640201702520, 0.533604927562262410, 0.533647213588810290, 0.533689498281239790, 0.533731781639445570, 0.533774063663321920, 0.533816344352763370, 0.533858623707663680, +0.533900901727917490, 0.533943178413418870, 0.533985453764062810, 0.534027727779742720, 0.534070000460353240, 0.534112271805789240, 0.534154541815944130, 0.534196810490712660, +0.534239077829989250, 0.534281343833668430, 0.534323608501643840, 0.534365871833810350, 0.534408133830062030, 0.534450394490293860, 0.534492653814399370, 0.534534911802273080, +0.534577168453809650, 0.534619423768903700, 0.534661677747448660, 0.534703930389339610, 0.534746181694470630, 0.534788431662736490, 0.534830680294031020, 0.534872927588248780, +0.534915173545284280, 0.534957418165032280, 0.534999661447386200, 0.535041903392241110, 0.535084143999491560, 0.535126383269031280, 0.535168621200755030, 0.535210857794557240, +0.535253093050332750, 0.535295326967975100, 0.535337559547379050, 0.535379790788439220, 0.535422020691050270, 0.535464249255105830, 0.535506476480500760, 0.535548702367129590, +0.535590926914886970, 0.535633150123666750, 0.535675371993363570, 0.535717592523871970, 0.535759811715086690, 0.535802029566901590, 0.535844246079211440, 0.535886461251911080, +0.535928675084894060, 0.535970887578055440, 0.536013098731289660, 0.536055308544491350, 0.536097517017554480, 0.536139724150373810, 0.536181929942843860, 0.536224134394859500, +0.536266337506314360, 0.536308539277103310, 0.536350739707120990, 0.536392938796262260, 0.536435136544420770, 0.536477332951491360, 0.536519528017368690, 0.536561721741947490, +0.536603914125121760, 0.536646105166786120, 0.536688294866835670, 0.536730483225164030, 0.536772670241666190, 0.536814855916236790, 0.536857040248770460, 0.536899223239161280, +0.536941404887304020, 0.536983585193093190, 0.537025764156423780, 0.537067941777189640, 0.537110118055285630, 0.537152292990606290, 0.537194466583046590, 0.537236638832500390, +0.537278809738862660, 0.537320979302027820, 0.537363147521890850, 0.537405314398345710, 0.537447479931287280, 0.537489644120610180, 0.537531806966209280, 0.537573968467978560, +0.537616128625812870, 0.537658287439607200, 0.537700444909255500, 0.537742601034652660, 0.537784755815693290, 0.537826909252272500, 0.537869061344283920, 0.537911212091622850, +0.537953361494183600, 0.537995509551861370, 0.538037656264550020, 0.538079801632144530, 0.538121945654539520, 0.538164088331630100, 0.538206229663310000, 0.538248369649474310, +0.538290508290017680, 0.538332645584835290, 0.538374781533820790, 0.538416916136869370, 0.538459049393876010, 0.538501181304734680, 0.538543311869340350, 0.538585441087587770, +0.538627568959372030, 0.538669695484586870, 0.538711820663127620, 0.538753944494888670, 0.538796066979765340, 0.538838188117651380, 0.538880307908442100, 0.538922426352031910, +0.538964543448316010, 0.539006659197188490, 0.539048773598544310, 0.539090886652278110, 0.539132998358285100, 0.539175108716459240, 0.539217217726695620, 0.539259325388889320, +0.539301431702934320, 0.539343536668725700, 0.539385640286158320, 0.539427742555127150, 0.539469843475526290, 0.539511943047250810, 0.539554041270195460, 0.539596138144255330, +0.539638233669324620, 0.539680327845298180, 0.539722420672070990, 0.539764512149538130, 0.539806602277593690, 0.539848691056132650, 0.539890778485049850, 0.539932864564240500, +0.539974949293598680, 0.540017032673019480, 0.540059114702397980, 0.540101195381628370, 0.540143274710605750, 0.540185352689225070, 0.540227429317381210, 0.540269504594968470, +0.540311578521882050, 0.540353651098016590, 0.540395722323267380, 0.540437792197528520, 0.540479860720695200, 0.540521927892662180, 0.540563993713324640, 0.540606058182576900, +0.540648121300313920, 0.540690183066430690, 0.540732243480822380, 0.540774302543382990, 0.540816360254007920, 0.540858416612591930, 0.540900471619030320, 0.540942525273217180, +0.540984577575047590, 0.541026628524417070, 0.541068678121219500, 0.541110726365350290, 0.541152773256704300, 0.541194818795176610, 0.541236862980661650, 0.541278905813054490, +0.541320947292250000, 0.541362987418143590, 0.541405026190629360, 0.541447063609602490, 0.541489099674957950, 0.541531134386591170, 0.541573167744396010, 0.541615199748267990, +0.541657230398101990, 0.541699259693793290, 0.541741287635236100, 0.541783314222325620, 0.541825339454957260, 0.541867363333025210, 0.541909385856424790, 0.541951407025050850, +0.541993426838798700, 0.542035445297562650, 0.542077462401238000, 0.542119478149719720, 0.542161492542903130, 0.542203505580682310, 0.542245517262952890, 0.542287527589609630, +0.542329536560547830, 0.542371544175661910, 0.542413550434847070, 0.542455555337998390, 0.542497558885011280, 0.542539561075779720, 0.542581561910199350, 0.542623561388165480, +0.542665559509572290, 0.542707556274315220, 0.542749551682289330, 0.542791545733389840, 0.542833538427511140, 0.542875529764548560, 0.542917519744397170, 0.542959508366952390, +0.543001495632108420, 0.543043481539760790, 0.543085466089804350, 0.543127449282134630, 0.543169431116645950, 0.543211411593233720, 0.543253390711792910, 0.543295368472219040, +0.543337344874406440, 0.543379319918250280, 0.543421293603645990, 0.543463265930488770, 0.543505236898673030, 0.543547206508094180, 0.543589174758647760, 0.543631141650227970, +0.543673107182730320, 0.543715071356049910, 0.543757034170082250, 0.543798995624721560, 0.543840955719863350, 0.543882914455402820, 0.543924871831235390, 0.543966827847255360, +0.544008782503358270, 0.544050735799439190, 0.544092687735393770, 0.544134638311116080, 0.544176587526501890, 0.544218535381446270, 0.544260481875844640, 0.544302427009591420, +0.544344370782582130, 0.544386313194712310, 0.544428254245876380, 0.544470193935969740, 0.544512132264887700, 0.544554069232525580, 0.544596004838778010, 0.544637939083540410, +0.544679871966707860, 0.544721803488176120, 0.544763733647839480, 0.544805662445593470, 0.544847589881333420, 0.544889515954954610, 0.544931440666351690, 0.544973364015420180, +0.545015286002055290, 0.545057206626152540, 0.545099125887606450, 0.545141043786312450, 0.545182960322166290, 0.545224875495062270, 0.545266789304896140, 0.545308701751562990, +0.545350612834958450, 0.545392522554977060, 0.545434430911514330, 0.545476337904465590, 0.545518243533726240, 0.545560147799191040, 0.545602050700755400, 0.545643952238314630, +0.545685852411764370, 0.545727751220999150, 0.545769648665914490, 0.545811544746405700, 0.545853439462368420, 0.545895332813697290, 0.545937224800287720, 0.545979115422035480, +0.546021004678835080, 0.546062892570582160, 0.546104779097172030, 0.546146664258500230, 0.546188548054461490, 0.546230430484951460, 0.546272311549865220, 0.546314191249098640, +0.546356069582546120, 0.546397946550103540, 0.546439822151666090, 0.546481696387129400, 0.546523569256388120, 0.546565440759337880, 0.546607310895874000, 0.546649179665892330, +0.546691047069287280, 0.546732913105954620, 0.546774777775789640, 0.546816641078688210, 0.546858503014544750, 0.546900363583255000, 0.546942222784714720, 0.546984080618818420, +0.547025937085462100, 0.547067792184540820, 0.547109645915950460, 0.547151498279585650, 0.547193349275342020, 0.547235198903115010, 0.547277047162800460, 0.547318894054292900, +0.547360739577488100, 0.547402583732281340, 0.547444426518568620, 0.547486267936244440, 0.547528107985204570, 0.547569946665344420, 0.547611783976559850, 0.547653619918745390, +0.547695454491796910, 0.547737287695610140, 0.547779119530079740, 0.547820949995101560, 0.547862779090571020, 0.547904606816383980, 0.547946433172434970, 0.547988258158619850, +0.548030081774834140, 0.548071904020973610, 0.548113724896932890, 0.548155544402607940, 0.548197362537894080, 0.548239179302687170, 0.548280994696881960, 0.548322808720374310, +0.548364621373059520, 0.548406432654833690, 0.548448242565591330, 0.548490051105228300, 0.548531858273640590, 0.548573664070722830, 0.548615468496370990, 0.548657271550480390, +0.548699073232947090, 0.548740873543665630, 0.548782672482531990, 0.548824470049441680, 0.548866266244290580, 0.548908061066973430, 0.548949854517386200, 0.548991646595424320, +0.549033437300983640, 0.549075226633959020, 0.549117014594246330, 0.549158801181741100, 0.549200586396339170, 0.549242370237935430, 0.549284152706425830, 0.549325933801705800, +0.549367713523671420, 0.549409491872217210, 0.549451268847239380, 0.549493044448633780, 0.549534818676295170, 0.549576591530119400, 0.549618363010002220, 0.549660133115839610, +0.549701901847526210, 0.549743669204957990, 0.549785435188030690, 0.549827199796640190, 0.549868963030681220, 0.549910724890049880, 0.549952485374641810, 0.549994244484352750, +0.550036002219077780, 0.550077758578712880, 0.550119513563153470, 0.550161267172295740, 0.550203019406034440, 0.550244770264265550, 0.550286519746885140, 0.550328267853788080, +0.550370014584870340, 0.550411759940027560, 0.550453503919155710, 0.550495246522149760, 0.550536987748905690, 0.550578727599319140, 0.550620466073286190, 0.550662203170701690, +0.550703938891461630, 0.550745673235461750, 0.550787406202598030, 0.550829137792765540, 0.550870868005860050, 0.550912596841777510, 0.550954324300413800, 0.550996050381663880, +0.551037775085423950, 0.551079498411589870, 0.551121220360056620, 0.551162940930720380, 0.551204660123476800, 0.551246377938221950, 0.551288094374850710, 0.551329809433259270, +0.551371523113343360, 0.551413235414998980, 0.551454946338121090, 0.551496655882605880, 0.551538364048348990, 0.551580070835246630, 0.551621776243193750, 0.551663480272086340, +0.551705182921820250, 0.551746884192291560, 0.551788584083395370, 0.551830282595027640, 0.551871979727084240, 0.551913675479461240, 0.551955369852053620, 0.551997062844757690, +0.552038754457469420, 0.552080444690083880, 0.552122133542497280, 0.552163821014605370, 0.552205507106304230, 0.552247191817488940, 0.552288875148055690, 0.552330557097900240, +0.552372237666918680, 0.552413916855006290, 0.552455594662059070, 0.552497271087972860, 0.552538946132643870, 0.552580619795967070, 0.552622292077838750, 0.552663962978154680, +0.552705632496811150, 0.552747300633703140, 0.552788967388726850, 0.552830632761778570, 0.552872296752753290, 0.552913959361547300, 0.552955620588056360, 0.552997280432176770, +0.553038938893803620, 0.553080595972833100, 0.553122251669161070, 0.553163905982683830, 0.553205558913296370, 0.553247210460895090, 0.553288860625375860, 0.553330509406634750, +0.553372156804566970, 0.553413802819068820, 0.553455447450036160, 0.553497090697365300, 0.553538732560951320, 0.553580373040690520, 0.553622012136479100, 0.553663649848212370, +0.553705286175786400, 0.553746921119097290, 0.553788554678041220, 0.553830186852513400, 0.553871817642410220, 0.553913447047627350, 0.553955075068061300, 0.553996701703607150, +0.554038326954161330, 0.554079950819619580, 0.554121573299878430, 0.554163194394832860, 0.554204814104379380, 0.554246432428413870, 0.554288049366832620, 0.554329664919530950, +0.554371279086405040, 0.554412891867351320, 0.554454503262264970, 0.554496113271042420, 0.554537721893579530, 0.554579329129772700, 0.554620934979517250, 0.554662539442709490, +0.554704142519245270, 0.554745744209021120, 0.554787344511932230, 0.554828943427874920, 0.554870540956745370, 0.554912137098439780, 0.554953731852853460, 0.554995325219882820, +0.555036917199423940, 0.555078507791373020, 0.555120096995625590, 0.555161684812077730, 0.555203271240625850, 0.555244856281166040, 0.555286439933593830, 0.555328022197805420, +0.555369603073697320, 0.555411182561164950, 0.555452760660104520, 0.555494337370412210, 0.555535912691984430, 0.555577486624716510, 0.555619059168504850, 0.555660630323245640, +0.555702200088835090, 0.555743768465168710, 0.555785335452142930, 0.555826901049653820, 0.555868465257597810, 0.555910028075870310, 0.555951589504367740, 0.555993149542986180, +0.556034708191622040, 0.556076265450170860, 0.556117821318528940, 0.556159375796592910, 0.556200928884257980, 0.556242480581420780, 0.556284030887977400, 0.556325579803824240, +0.556367127328856850, 0.556408673462971630, 0.556450218206064660, 0.556491761558032590, 0.556533303518770730, 0.556574844088175590, 0.556616383266143270, 0.556657921052570500, +0.556699457447352500, 0.556740992450385770, 0.556782526061566640, 0.556824058280791620, 0.556865589107956030, 0.556907118542956490, 0.556948646585689430, 0.556990173236050490, +0.557031698493936080, 0.557073222359242390, 0.557114744831866070, 0.557156265911702530, 0.557197785598648300, 0.557239303892599570, 0.557280820793452980, 0.557322336301103950, +0.557363850415449110, 0.557405363136384670, 0.557446874463807140, 0.557488384397612060, 0.557529892937696060, 0.557571400083955340, 0.557612905836286420, 0.557654410194584840, +0.557695913158747340, 0.557737414728670000, 0.557778914904249470, 0.557820413685381270, 0.557861911071962150, 0.557903407063888520, 0.557944901661056040, 0.557986394863361320, +0.558027886670700580, 0.558069377082970550, 0.558110866100066660, 0.558152353721885540, 0.558193839948323610, 0.558235324779277510, 0.558276808214642650, 0.558318290254315790, +0.558359770898193110, 0.558401250146171480, 0.558442727998146320, 0.558484204454014370, 0.558525679513671940, 0.558567153177015660, 0.558608625443941080, 0.558650096314344920, +0.558691565788123960, 0.558733033865173700, 0.558774500545390800, 0.558815965828671770, 0.558857429714913030, 0.558898892204010460, 0.558940353295860670, 0.558981812990359870, +0.559023271287405030, 0.559064728186891570, 0.559106183688716340, 0.559147637792775650, 0.559189090498966260, 0.559230541807183680, 0.559271991717324890, 0.559313440229285970, +0.559354887342963900, 0.559396333058254200, 0.559437777375053740, 0.559479220293259140, 0.559520661812766160, 0.559562101933471560, 0.559603540655271630, 0.559644977978063230, +0.559686413901742010, 0.559727848426204820, 0.559769281551347970, 0.559810713277068220, 0.559852143603261410, 0.559893572529824190, 0.559935000056653090, 0.559976426183644740, +0.560017850910695110, 0.560059274237700740, 0.560100696164558260, 0.560142116691164430, 0.560183535817414870, 0.560224953543206450, 0.560266369868436030, 0.560307784792999360, +0.560349198316793200, 0.560390610439714050, 0.560432021161658800, 0.560473430482523070, 0.560514838402203730, 0.560556244920597300, 0.560597650037600650, 0.560639053753109520, +0.560680456067020770, 0.560721856979230830, 0.560763256489636650, 0.560804654598134000, 0.560846051304619620, 0.560887446608990260, 0.560928840511142560, 0.560970233010972370, +0.561011624108376570, 0.561053013803251790, 0.561094402095494770, 0.561135788985001490, 0.561177174471668590, 0.561218558555393270, 0.561259941236071040, 0.561301322513599100, +0.561342702387873760, 0.561384080858791990, 0.561425457926249760, 0.561466833590143820, 0.561508207850370810, 0.561549580706827700, 0.561590952159410240, 0.561632322208015400, +0.561673690852539710, 0.561715058092880250, 0.561756423928932660, 0.561797788360594020, 0.561839151387760970, 0.561880513010330370, 0.561921873228198200, 0.561963232041261310, +0.562004589449416670, 0.562045945452560260, 0.562087300050588930, 0.562128653243399330, 0.562170005030888540, 0.562211355412952310, 0.562252704389487710, 0.562294051960391280, +0.562335398125560220, 0.562376742884890260, 0.562418086238278380, 0.562459428185621340, 0.562500768726816090, 0.562542107861758510, 0.562583445590345680, 0.562624781912474230, +0.562666116828041240, 0.562707450336942580, 0.562748782439075220, 0.562790113134336360, 0.562831442422621730, 0.562872770303828650, 0.562914096777853530, 0.562955421844593570, +0.562996745503944740, 0.563038067755804010, 0.563079388600068120, 0.563120708036634050, 0.563162026065397890, 0.563203342686256710, 0.563244657899107160, 0.563285971703846310, +0.563327284100370140, 0.563368595088575840, 0.563409904668359940, 0.563451212839619740, 0.563492519602251110, 0.563533824956151230, 0.563575128901216750, 0.563616431437344740, +0.563657732564431410, 0.563699032282373610, 0.563740330591068650, 0.563781627490412610, 0.563822922980302340, 0.563864217060634830, 0.563905509731307150, 0.563946800992215390, +0.563988090843256520, 0.564029379284327500, 0.564070666315325320, 0.564111951936146160, 0.564153236146687110, 0.564194518946845030, 0.564235800336516880, 0.564277080315598980, +0.564318358883988400, 0.564359636041581900, 0.564400911788276560, 0.564442186123968680, 0.564483459048555350, 0.564524730561933640, 0.564566000663999870, 0.564607269354651000, +0.564648536633784000, 0.564689802501295970, 0.564731066957083190, 0.564772330001042660, 0.564813591633071320, 0.564854851853066280, 0.564896110660923820, 0.564937368056541160, +0.564978624039815020, 0.565019878610642620, 0.565061131768920260, 0.565102383514545000, 0.565143633847413730, 0.565184882767423850, 0.565226130274471330, 0.565267376368453590, +0.565308621049267710, 0.565349864316809890, 0.565391106170977430, 0.565432346611667190, 0.565473585638776480, 0.565514823252201370, 0.565556059451839290, 0.565597294237586980, +0.565638527609341860, 0.565679759567000010, 0.565720990110458730, 0.565762219239615120, 0.565803446954366240, 0.565844673254608300, 0.565885898140238820, 0.565927121611154550, +0.565968343667252790, 0.566009564308429860, 0.566050783534582940, 0.566092001345609550, 0.566133217741405680, 0.566174432721868850, 0.566215646286895910, 0.566256858436384180, +0.566298069170229960, 0.566339278488330540, 0.566380486390583030, 0.566421692876884600, 0.566462897947131560, 0.566504101601221330, 0.566545303839050770, 0.566586504660517300, +0.566627704065517320, 0.566668902053947930, 0.566710098625706430, 0.566751293780690000, 0.566792487518794960, 0.566833679839918720, 0.566874870743958260, 0.566916060230810980, +0.566957248300373200, 0.566998434952542210, 0.567039620187215650, 0.567080804004289620, 0.567121986403661520, 0.567163167385228540, 0.567204346948887990, 0.567245525094536180, +0.567286701822070530, 0.567327877131388100, 0.567369051022386440, 0.567410223494961730, 0.567451394549011500, 0.567492564184432840, 0.567533732401123040, 0.567574899198978520, +0.567616064577896820, 0.567657228537774890, 0.567698391078510280, 0.567739552199999390, 0.567780711902139630, 0.567821870184828330, 0.567863027047962100, 0.567904182491438260, +0.567945336515154000, 0.567986489119006730, 0.568027640302892880, 0.568068790066709850, 0.568109938410354950, 0.568151085333725490, 0.568192230836717990, 0.568233374919229980, +0.568274517581158430, 0.568315658822401090, 0.568356798642854160, 0.568397937042415150, 0.568439074020981370, 0.568480209578450250, 0.568521343714718300, 0.568562476429682940, +0.568603607723241810, 0.568644737595291220, 0.568685866045728790, 0.568726993074451740, 0.568768118681357570, 0.568809242866342710, 0.568850365629304800, 0.568891486970140910, +0.568932606888748690, 0.568973725385024550, 0.569014842458866130, 0.569055958110170620, 0.569097072338835550, 0.569138185144757450, 0.569179296527833940, 0.569220406487962130, +0.569261515025039630, 0.569302622138963100, 0.569343727829629940, 0.569384832096937470, 0.569425934940783310, 0.569467036361063880, 0.569508136357676830, 0.569549234930519900, +0.569590332079489500, 0.569631427804483280, 0.569672522105398430, 0.569713614982132690, 0.569754706434582590, 0.569795796462645670, 0.569836885066219210, 0.569877972245200980, +0.569919057999487390, 0.569960142328976180, 0.570001225233564670, 0.570042306713150370, 0.570083386767630040, 0.570124465396901200, 0.570165542600861160, 0.570206618379407670, +0.570247692732437250, 0.570288765659847650, 0.570329837161536400, 0.570370907237400250, 0.570411975887336830, 0.570453043111243450, 0.570494108909017860, 0.570535173280556700, +0.570576236225757480, 0.570617297744517750, 0.570658357836735020, 0.570699416502306160, 0.570740473741128680, 0.570781529553100130, 0.570822583938118020, 0.570863636896079110, +0.570904688426881140, 0.570945738530421410, 0.570986787206597680, 0.571027834455306690, 0.571068880276446090, 0.571109924669913620, 0.571150967635605910, 0.571192009173420940, +0.571233049283255800, 0.571274087965008450, 0.571315125218575530, 0.571356161043854890, 0.571397195440743740, 0.571438228409139940, 0.571479259948940220, 0.571520290060042460, +0.571561318742343840, 0.571602345995742330, 0.571643371820134690, 0.571684396215418560, 0.571725419181491330, 0.571766440718251000, 0.571807460825594190, 0.571848479503418770, +0.571889496751622480, 0.571930512570102080, 0.571971526958755420, 0.572012539917479910, 0.572053551446173540, 0.572094561544732820, 0.572135570213055720, 0.572176577451039670, +0.572217583258582520, 0.572258587635581020, 0.572299590581933140, 0.572340592097536290, 0.572381592182288230, 0.572422590836085930, 0.572463588058827130, 0.572504583850409250, +0.572545578210730380, 0.572586571139687250, 0.572627562637177620, 0.572668552703099020, 0.572709541337349530, 0.572750528539825780, 0.572791514310425630, 0.572832498649047170, +0.572873481555587040, 0.572914463029943200, 0.572955443072013180, 0.572996421681694960, 0.573037398858885380, 0.573078374603482210, 0.573119348915383190, 0.573160321794486060, +0.573201293240687800, 0.573242263253886280, 0.573283231833979220, 0.573324198980864290, 0.573365164694438660, 0.573406128974599970, 0.573447091821245980, 0.573488053234274760, +0.573529013213582850, 0.573569971759068540, 0.573610928870629590, 0.573651884548163070, 0.573692838791566740, 0.573733791600738340, 0.573774742975575850, 0.573815692915976120, +0.573856641421837120, 0.573897588493056500, 0.573938534129532330, 0.573979478331161470, 0.574020421097841900, 0.574061362429471260, 0.574102302325947610, 0.574143240787167830, +0.574184177813029880, 0.574225113403431520, 0.574266047558270820, 0.574306980277444530, 0.574347911560850850, 0.574388841408387750, 0.574429769819952200, 0.574470696795442160, +0.574511622334755500, 0.574552546437790080, 0.574593469104442870, 0.574634390334612060, 0.574675310128195280, 0.574716228485090520, 0.574757145405194850, 0.574798060888406350, +0.574838974934622660, 0.574879887543741970, 0.574920798715661150, 0.574961708450278270, 0.575002616747491200, 0.575043523607197900, 0.575084429029295460, 0.575125333013681960, +0.575166235560255150, 0.575207136668913100, 0.575248036339552790, 0.575288934572072420, 0.575329831366370060, 0.575370726722342800, 0.575411620639888710, 0.575452513118905550, +0.575493404159291510, 0.575534293760943560, 0.575575181923759890, 0.575616068647638260, 0.575656953932476840, 0.575697837778172630, 0.575738720184623910, 0.575779601151728330, +0.575820480679384070, 0.575861358767488340, 0.575902235415939100, 0.575943110624634320, 0.575983984393472200, 0.576024856722349600, 0.576065727611165030, 0.576106597059816370, +0.576147465068200910, 0.576188331636216860, 0.576229196763761830, 0.576270060450734260, 0.576310922697031210, 0.576351783502550790, 0.576392642867190940, 0.576433500790849870, +0.576474357273424660, 0.576515212314813510, 0.576556065914914370, 0.576596918073625450, 0.576637768790843830, 0.576678618066467810, 0.576719465900395250, 0.576760312292524450, +0.576801157242752380, 0.576842000750977470, 0.576882842817098010, 0.576923683441010970, 0.576964522622614770, 0.577005360361807270, 0.577046196658486670, 0.577087031512550250, +0.577127864923896230, 0.577168696892422560, 0.577209527418027560, 0.577250356500608300, 0.577291184140063200, 0.577332010336290110, 0.577372835089187460, 0.577413658398652220, +0.577454480264582900, 0.577495300686877380, 0.577536119665433940, 0.577576937200149910, 0.577617753290923460, 0.577658567937653020, 0.577699381140235780, 0.577740192898570150, +0.577781003212553990, 0.577821812082085720, 0.577862619507062520, 0.577903425487382720, 0.577944230022944480, 0.577985033113645910, 0.578025834759384520, 0.578066634960058390, +0.578107433715565830, 0.578148231025804930, 0.578189026890673090, 0.578229821310068730, 0.578270614283889820, 0.578311405812034770, 0.578352195894400790, 0.578392984530886280, +0.578433771721389430, 0.578474557465808450, 0.578515341764040620, 0.578556124615984600, 0.578596906021538570, 0.578637685980599840, 0.578678464493066920, 0.578719241558837920, +0.578760017177811110, 0.578800791349883940, 0.578841564074954800, 0.578882335352921660, 0.578923105183683170, 0.578963873567136410, 0.579004640503180120, 0.579045405991712170, +0.579086170032630960, 0.579126932625834150, 0.579167693771219900, 0.579208453468686430, 0.579249211718132150, 0.579289968519454580, 0.579330723872552020, 0.579371477777323010, +0.579412230233664950, 0.579452981241476260, 0.579493730800655140, 0.579534478911100100, 0.579575225572708570, 0.579615970785378850, 0.579656714549009240, 0.579697456863498270, +0.579738197728743240, 0.579778937144642680, 0.579819675111094780, 0.579860411627998170, 0.579901146695250060, 0.579941880312749070, 0.579982612480393510, 0.580023343198081690, +0.580064072465711120, 0.580104800283180340, 0.580145526650387990, 0.580186251567231470, 0.580226975033609320, 0.580267697049419720, 0.580308417614561310, 0.580349136728931400, +0.580389854392428630, 0.580430570604951290, 0.580471285366397920, 0.580511998676665810, 0.580552710535653830, 0.580593420943260050, 0.580634129899383120, 0.580674837403920450, +0.580715543456770790, 0.580756248057832100, 0.580796951207003250, 0.580837652904181660, 0.580878353149265950, 0.580919051942154320, 0.580959749282745410, 0.581000445170936850, +0.581041139606627070, 0.581081832589714910, 0.581122524120097680, 0.581163214197674250, 0.581203902822342800, 0.581244589994001860, 0.581285275712549070, 0.581325959977883170, +0.581366642789902350, 0.581407324148505270, 0.581448004053589540, 0.581488682505053810, 0.581529359502796380, 0.581570035046715890, 0.581610709136709870, 0.581651381772677170, +0.581692052954515980, 0.581732722682125060, 0.581773390955401930, 0.581814057774245440, 0.581854723138554020, 0.581895387048225520, 0.581936049503158470, 0.581976710503251390, +0.582017370048402820, 0.582058028138510490, 0.582098684773473040, 0.582139339953189010, 0.582179993677556910, 0.582220645946474490, 0.582261296759840400, 0.582301946117553040, +0.582342594019511270, 0.582383240465612630, 0.582423885455755850, 0.582464528989839360, 0.582505171067762010, 0.582545811689421320, 0.582586450854716050, 0.582627088563545060, +0.582667724815805980, 0.582708359611397550, 0.582748992950218200, 0.582789624832166790, 0.582830255257140940, 0.582870884225039520, 0.582911511735760830, 0.582952137789203630, +0.582992762385265870, 0.583033385523846090, 0.583074007204842930, 0.583114627428155120, 0.583155246193680310, 0.583195863501317470, 0.583236479350964900, 0.583277093742521570, +0.583317706675885010, 0.583358318150954290, 0.583398928167628170, 0.583439536725804290, 0.583480143825381600, 0.583520749466258540, 0.583561353648333950, 0.583601956371505690, +0.583642557635672410, 0.583683157440732850, 0.583723755786585750, 0.583764352673128760, 0.583804948100261070, 0.583845542067880970, 0.583886134575887230, 0.583926725624178020, +0.583967315212651880, 0.584007903341207450, 0.584048490009743570, 0.584089075218158120, 0.584129658966350050, 0.584170241254217790, 0.584210822081660310, 0.584251401448575460, +0.584291979354861990, 0.584332555800419100, 0.584373130785144300, 0.584413704308936690, 0.584454276371694890, 0.584494846973317770, 0.584535416113703080, 0.584575983792749890, +0.584616550010356840, 0.584657114766422680, 0.584697678060845380, 0.584738239893523800, 0.584778800264356800, 0.584819359173243010, 0.584859916620080520, 0.584900472604768300, +0.584941027127204750, 0.584981580187289070, 0.585022131784919130, 0.585062681919993890, 0.585103230592412200, 0.585143777802072050, 0.585184323548872510, 0.585224867832712210, +0.585265410653490030, 0.585305952011104020, 0.585346491905453070, 0.585387030336435910, 0.585427567303951620, 0.585468102807897960, 0.585508636848174110, 0.585549169424678610, +0.585589700537310520, 0.585630230185967830, 0.585670758370549600, 0.585711285090954490, 0.585751810347081460, 0.585792334138828590, 0.585832856466094950, 0.585873377328779420, +0.585913896726780180, 0.585954414659996090, 0.585994931128326010, 0.586035446131669020, 0.586075959669922990, 0.586116471742987090, 0.586156982350759970, 0.586197491493140820, +0.586237999170027500, 0.586278505381319200, 0.586319010126914670, 0.586359513406713000, 0.586400015220612140, 0.586440515568511290, 0.586481014450309090, 0.586521511865904840, +0.586562007815196300, 0.586602502298082750, 0.586642995314463070, 0.586683486864236100, 0.586723976947300160, 0.586764465563554330, 0.586804952712897570, 0.586845438395228070, +0.586885922610445030, 0.586926405358447200, 0.586966886639133770, 0.587007366452402590, 0.587047844798153080, 0.587088321676284000, 0.587128797086694520, 0.587169271029282620, +0.587209743503947500, 0.587250214510588010, 0.587290684049103450, 0.587331152119391800, 0.587371618721352130, 0.587412083854883530, 0.587452547519885070, 0.587493009716254950, +0.587533470443892150, 0.587573929702696170, 0.587614387492564890, 0.587654843813397720, 0.587695298665093510, 0.587735752047551240, 0.587776203960669320, 0.587816654404346940, +0.587857103378482850, 0.587897550882976460, 0.587937996917725750, 0.587978441482630010, 0.588018884577588220, 0.588059326202499570, 0.588099766357262240, 0.588140205041775550, +0.588180642255938250, 0.588221077999649730, 0.588261512272808210, 0.588301945075312860, 0.588342376407063110, 0.588382806267956910, 0.588423234657893810, 0.588463661576772550, +0.588504087024492530, 0.588544511000951950, 0.588584933506050010, 0.588625354539685790, 0.588665774101758580, 0.588706192192166580, 0.588746608810808980, 0.588787023957584980, +0.588827437632393760, 0.588867849835133520, 0.588908260565703780, 0.588948669824003290, 0.588989077609931470, 0.589029483923386610, 0.589069888764268130, 0.589110292132475230, +0.589150694027906210, 0.589191094450460470, 0.589231493400037000, 0.589271890876535200, 0.589312286879853260, 0.589352681409890610, 0.589393074466546210, 0.589433466049719580, +0.589473856159308920, 0.589514244795213530, 0.589554631957332600, 0.589595017645565430, 0.589635401859810340, 0.589675784599966720, 0.589716165865933780, 0.589756545657610600, +0.589796923974895800, 0.589837300817688700, 0.589877676185888270, 0.589918050079394130, 0.589958422498104370, 0.589998793441918630, 0.590039162910736330, 0.590079530904455640, +0.590119897422976210, 0.590160262466197020, 0.590200626034017460, 0.590240988126336070, 0.590281348743052160, 0.590321707884064910, 0.590362065549273620, 0.590402421738576930, +0.590442776451874260, 0.590483129689064470, 0.590523481450047290, 0.590563831734721160, 0.590604180542985360, 0.590644527874739090, 0.590684873729881880, 0.590725218108312020, +0.590765561009929270, 0.590805902434632930, 0.590846242382321420, 0.590886580852894360, 0.590926917846250840, 0.590967253362290390, 0.591007587400911530, 0.591047919962013560, +0.591088251045495780, 0.591128580651257840, 0.591168908779198030, 0.591209235429216000, 0.591249560601210810, 0.591289884295082110, 0.591330206510728430, 0.591370527248049060, +0.591410846506943530, 0.591451164287311150, 0.591491480589050540, 0.591531795412061130, 0.591572108756242780, 0.591612420621493660, 0.591652731007713540, 0.591693039914801490, +0.591733347342657370, 0.591773653291179370, 0.591813957760267350, 0.591854260749820390, 0.591894562259738130, 0.591934862289919090, 0.591975160840262920, 0.592015457910668900, +0.592055753501036450, 0.592096047611264440, 0.592136340241252170, 0.592176631390899040, 0.592216921060104820, 0.592257209248767900, 0.592297495956787930, 0.592337781184064220, +0.592378064930496380, 0.592418347195983070, 0.592458627980423810, 0.592498907283718460, 0.592539185105765420, 0.592579461446464340, 0.592619736305714740, 0.592660009683416140, +0.592700281579467080, 0.592740551993767410, 0.592780820926216310, 0.592821088376713550, 0.592861354345157630, 0.592901618831448430, 0.592941881835485020, 0.592982143357167370, +0.593022403396394000, 0.593062661953064670, 0.593102919027078680, 0.593143174618335660, 0.593183428726734460, 0.593223681352174630, 0.593263932494555890, 0.593304182153777000, +0.593344430329737720, 0.593384677022337330, 0.593424922231475580, 0.593465165957051230, 0.593505408198963910, 0.593545648957113040, 0.593585888231398460, 0.593626126021718830, +0.593666362327973870, 0.593706597150062910, 0.593746830487885900, 0.593787062341341490, 0.593827292710329300, 0.593867521594748980, 0.593907748994500160, 0.593947974909481700, +0.593988199339593240, 0.594028422284734630, 0.594068643744804610, 0.594108863719702950, 0.594149082209329160, 0.594189299213583100, 0.594229514732363300, 0.594269728765569830, +0.594309941313102000, 0.594350152374859660, 0.594390361950741570, 0.594430570040647590, 0.594470776644477120, 0.594510981762130130, 0.594551185393505380, 0.594591387538502600, +0.594631588197021330, 0.594671787368961540, 0.594711985054221850, 0.594752181252702240, 0.594792375964302460, 0.594832569188921470, 0.594872760926459020, 0.594912951176814640, +0.594953139939888300, 0.594993327215578740, 0.595033513003785820, 0.595073697304409180, 0.595113880117348560, 0.595154061442502940, 0.595194241279772160, 0.595234419629055770, +0.595274596490253720, 0.595314771863264870, 0.595354945747988970, 0.595395118144325770, 0.595435289052175130, 0.595475458471435900, 0.595515626402008060, 0.595555792843791120, +0.595595957796685060, 0.595636121260588740, 0.595676283235402120, 0.595716443721025170, 0.595756602717356640, 0.595796760224296730, 0.595836916241744950, 0.595877070769601170, +0.595917223807764350, 0.595957375356134470, 0.595997525414611150, 0.596037673983094370, 0.596077821061483100, 0.596117966649677200, 0.596158110747576410, 0.596198253355080810, +0.596238394472089040, 0.596278534098501400, 0.596318672234217420, 0.596358808879137060, 0.596398944033159410, 0.596439077696184320, 0.596479209868111980, 0.596519340548841150, +0.596559469738272010, 0.596599597436304200, 0.596639723642837790, 0.596679848357771660, 0.596719971581005870, 0.596760093312440290, 0.596800213551974770, 0.596840332299508280, +0.596880449554941020, 0.596920565318172720, 0.596960679589103260, 0.597000792367631710, 0.597040903653658250, 0.597081013447082530, 0.597121121747804630, 0.597161228555723620, +0.597201333870739480, 0.597241437692752290, 0.597281540021661230, 0.597321640857366280, 0.597361740199767290, 0.597401838048764340, 0.597441934404256300, 0.597482029266143580, +0.597522122634325690, 0.597562214508702840, 0.597602304889174100, 0.597642393775639660, 0.597682481167999160, 0.597722567066152900, 0.597762651469999850, 0.597802734379440090, +0.597842815794373590, 0.597882895714700320, 0.597922974140319470, 0.597963051071131240, 0.598003126507035350, 0.598043200447932020, 0.598083272893720320, 0.598123343844300440, +0.598163413299572570, 0.598203481259435790, 0.598243547723790290, 0.598283612692535940, 0.598323676165572920, 0.598363738142800310, 0.598403798624118410, 0.598443857609427090, +0.598483915098626310, 0.598523971091615480, 0.598564025588294690, 0.598604078588563900, 0.598644130092323200, 0.598684180099471890, 0.598724228609910040, 0.598764275623537730, +0.598804321140254950, 0.598844365159961090, 0.598884407682556350, 0.598924448707940930, 0.598964488236014000, 0.599004526266675890, 0.599044562799826430, 0.599084597835365830, +0.599124631373193490, 0.599164663413209620, 0.599204693955313950, 0.599244722999407010, 0.599284750545387880, 0.599324776593156860, 0.599364801142613920, 0.599404824193659370, +0.599444845746192280, 0.599484865800113180, 0.599524884355321920, 0.599564901411718810, 0.599604916969203040, 0.599644931027674910, 0.599684943587034950, 0.599724954647182230, +0.599764964208017060, 0.599804972269439520, 0.599844978831349910, 0.599884983893647530, 0.599924987456232680, 0.599964989519005340, 0.600004990081865920, 0.600044989144713600, +0.600084986707448810, 0.600124982769971620, 0.600164977332182330, 0.600204970393980240, 0.600244961955265670, 0.600284952015938680, 0.600324940575899690, 0.600364927635048010, +0.600404913193284040, 0.600444897250507760, 0.600484879806619580, 0.600524860861518790, 0.600564840415105940, 0.600604818467281310, 0.600644795017944320, 0.600684770066995280, +0.600724743614334370, 0.600764715659861890, 0.600804686203477380, 0.600844655245081020, 0.600884622784573110, 0.600924588821853960, 0.600964553356822970, 0.601004516389380680, +0.601044477919427060, 0.601084437946862500, 0.601124396471586550, 0.601164353493499730, 0.601204309012501880, 0.601244263028493650, 0.601284215541374460, 0.601324166551044700, +0.601364116057404810, 0.601404064060354400, 0.601444010559793680, 0.601483955555623060, 0.601523899047742840, 0.601563841036052540, 0.601603781520452690, 0.601643720500843250, +0.601683657977124970, 0.601723593949197170, 0.601763528416960460, 0.601803461380314820, 0.601843392839160880, 0.601883322793398180, 0.601923251242927120, 0.601963178187648000, +0.602003103627461230, 0.602043027562266350, 0.602082949991963880, 0.602122870916454330, 0.602162790335637350, 0.602202708249413470, 0.602242624657682630, 0.602282539560345720, +0.602322452957302020, 0.602362364848452290, 0.602402275233696600, 0.602442184112935600, 0.602482091486068680, 0.602521997352996610, 0.602561901713619560, 0.602601804567838070, +0.602641705915551770, 0.602681605756661190, 0.602721504091066510, 0.602761400918668590, 0.602801296239366620, 0.602841190053061580, 0.602881082359653760, 0.602920973159043030, +0.602960862451129790, 0.603000750235814450, 0.603040636512997550, 0.603080521282578720, 0.603120404544458480, 0.603160286298537350, 0.603200166544715870, 0.603240045282893540, +0.603279922512971130, 0.603319798234848940, 0.603359672448427590, 0.603399545153606720, 0.603439416350286970, 0.603479286038368650, 0.603519154217752480, 0.603559020888338130, +0.603598886050026100, 0.603638749702717030, 0.603678611846311330, 0.603718472480708760, 0.603758331605810050, 0.603798189221515850, 0.603838045327725780, 0.603877899924340600, +0.603917753011260720, 0.603957604588386760, 0.603997454655618490, 0.604037303212856540, 0.604077150260001310, 0.604116995796953550, 0.604156839823613010, 0.604196682339880330, +0.604236523345656030, 0.604276362840840740, 0.604316200825334100, 0.604356037299037090, 0.604395872261849880, 0.604435705713673330, 0.604475537654407310, 0.604515368083952340, +0.604555197002209280, 0.604595024409077860, 0.604634850304458960, 0.604674674688252870, 0.604714497560360550, 0.604754318920681540, 0.604794138769116700, 0.604833957105566640, +0.604873773929931910, 0.604913589242112470, 0.604953403042009060, 0.604993215329522100, 0.605033026104552450, 0.605072835366999960, 0.605112643116765270, 0.605152449353749010, +0.605192254077852040, 0.605232057288974110, 0.605271858987015960, 0.605311659171878460, 0.605351457843461560, 0.605391255001666020, 0.605431050646392240, 0.605470844777541320, +0.605510637395012870, 0.605550428498707770, 0.605590218088526640, 0.605630006164370350, 0.605669792726138630, 0.605709577773732470, 0.605749361307052370, 0.605789143325999310, +0.605828923830472930, 0.605868702820374190, 0.605908480295603850, 0.605948256256062520, 0.605988030701650300, 0.606027803632267940, 0.606067575047816050, 0.606107344948195630, +0.606147113333306510, 0.606186880203049560, 0.606226645557325750, 0.606266409396035040, 0.606306171719078190, 0.606345932526356050, 0.606385691817769360, 0.606425449593218090, +0.606465205852603220, 0.606504960595825260, 0.606544713822785300, 0.606584465533383190, 0.606624215727520010, 0.606663964405096180, 0.606703711566012880, 0.606743457210169870, +0.606783201337468210, 0.606822943947808670, 0.606862685041091980, 0.606902424617218330, 0.606942162676088580, 0.606981899217603700, 0.607021634241663780, 0.607061367748169770, +0.607101099737022420, 0.607140830208122590, 0.607180559161370370, 0.607220286596666710, 0.607260012513912370, 0.607299736913008310, 0.607339459793854620, 0.607379181156352250, +0.607418901000401860, 0.607458619325904610, 0.607498336132760500, 0.607538051420870580, 0.607577765190135510, 0.607617477440456350, 0.607657188171733090, 0.607696897383866900, +0.607736605076758860, 0.607776311250308950, 0.607816015904418250, 0.607855719038987500, 0.607895420653917770, 0.607935120749109160, 0.607974819324462850, 0.608014516379879360, +0.608054211915259990, 0.608093905930504720, 0.608133598425514620, 0.608173289400190660, 0.608212978854433710, 0.608252666788144050, 0.608292353201222660, 0.608332038093570390, +0.608371721465088440, 0.608411403315676780, 0.608451083645236700, 0.608490762453669180, 0.608530439740874400, 0.608570115506753550, 0.608609789751207390, 0.608649462474137090, +0.608689133675442860, 0.608728803355025770, 0.608768471512786570, 0.608808138148626670, 0.608847803262446030, 0.608887466854145850, 0.608927128923626990, 0.608966789470790750, +0.609006448495537090, 0.609046105997767430, 0.609085761977382400, 0.609125416434283310, 0.609165069368370340, 0.609204720779544790, 0.609244370667707310, 0.609284019032759310, +0.609323665874600960, 0.609363311193133360, 0.609402954988257920, 0.609442597259874600, 0.609482238007884920, 0.609521877232189650, 0.609561514932689950, 0.609601151109286140, +0.609640785761879520, 0.609680418890370830, 0.609720050494661490, 0.609759680574651690, 0.609799309130242720, 0.609838936161335440, 0.609878561667831160, 0.609918185649630070, +0.609957808106633690, 0.609997429038742660, 0.610037048445858380, 0.610076666327881160, 0.610116282684712300, 0.610155897516253100, 0.610195510822403750, 0.610235122603065670, +0.610274732858139820, 0.610314341587527400, 0.610353948791128810, 0.610393554468845360, 0.610433158620578010, 0.610472761246228180, 0.610512362345696060, 0.610551961918882950, +0.610591559965690030, 0.610631156486018510, 0.610670751479768790, 0.610710344946842180, 0.610749936887139630, 0.610789527300562680, 0.610829116187011520, 0.610868703546387560, +0.610908289378592210, 0.610947873683525880, 0.610987456461089760, 0.611027037711185050, 0.611066617433713040, 0.611106195628574160, 0.611145772295669800, 0.611185347434900940, +0.611224921046169210, 0.611264493129374700, 0.611304063684419030, 0.611343632711203180, 0.611383200209628550, 0.611422766179595680, 0.611462330621005750, 0.611501893533760050, +0.611541454917760020, 0.611581014772905940, 0.611620573099099340, 0.611660129896241410, 0.611699685164233340, 0.611739238902975770, 0.611778791112370100, 0.611818341792317870, +0.611857890942719360, 0.611897438563476110, 0.611936984654489310, 0.611976529215660480, 0.612016072246889810, 0.612055613748079040, 0.612095153719129260, 0.612134692159941980, +0.612174229070417520, 0.612213764450457500, 0.612253298299963110, 0.612292830618835770, 0.612332361406976110, 0.612371890664285430, 0.612411418390665040, 0.612450944586016570, +0.612490469250240310, 0.612529992383237800, 0.612569513984910770, 0.612609034055159540, 0.612648552593885840, 0.612688069600990650, 0.612727585076375590, 0.612767099019941310, +0.612806611431589320, 0.612846122311220710, 0.612885631658737220, 0.612925139474039150, 0.612964645757028360, 0.613004150507605930, 0.613043653725673490, 0.613083155411131560, +0.613122655563881790, 0.613162154183825250, 0.613201651270863790, 0.613241146824897830, 0.613280640845829010, 0.613320133333558950, 0.613359624287988070, 0.613399113709018230, +0.613438601596550610, 0.613478087950486860, 0.613517572770727490, 0.613557056057174250, 0.613596537809728340, 0.613636018028291490, 0.613675496712764110, 0.613714973863048070, +0.613754449479044560, 0.613793923560655320, 0.613833396107780980, 0.613872867120323070, 0.613912336598183010, 0.613951804541262410, 0.613991270949461930, 0.614030735822683420, +0.614070199160828280, 0.614109660963797380, 0.614149121231492230, 0.614188579963814370, 0.614228037160665430, 0.614267492821945930, 0.614306946947557830, 0.614346399537402220, +0.614385850591381070, 0.614425300109394890, 0.614464748091345550, 0.614504194537134230, 0.614543639446662790, 0.614583082819831980, 0.614622524656543430, 0.614661964956698560, +0.614701403720199100, 0.614740840946945810, 0.614780276636840430, 0.614819710789784260, 0.614859143405679260, 0.614898574484426090, 0.614938004025926350, 0.614977432030082040, +0.615016858496793770, 0.615056283425963410, 0.615095706817492260, 0.615135128671282280, 0.615174548987234120, 0.615213967765249500, 0.615253385005230080, 0.615292800707077480, +0.615332214870692450, 0.615371627495976960, 0.615411038582832410, 0.615450448131160680, 0.615489856140862380, 0.615529262611839490, 0.615568667543993420, 0.615608070937226030, +0.615647472791438060, 0.615686873106531470, 0.615726271882408030, 0.615765669118968570, 0.615805064816114970, 0.615844458973748730, 0.615883851591771610, 0.615923242670084580, +0.615962632208589380, 0.616002020207187640, 0.616041406665781110, 0.616080791584270870, 0.616120174962558550, 0.616159556800545790, 0.616198937098134560, 0.616238315855225590, +0.616277693071720760, 0.616317068747521790, 0.616356442882530550, 0.616395815476647680, 0.616435186529775470, 0.616474556041815450, 0.616513924012668800, 0.616553290442237390, +0.616592655330422620, 0.616632018677126690, 0.616671380482250340, 0.616710740745695430, 0.616750099467363810, 0.616789456647157230, 0.616828812284976660, 0.616868166380723950, +0.616907518934300960, 0.616946869945609540, 0.616986219414550560, 0.617025567341025980, 0.617064913724937550, 0.617104258566187110, 0.617143601864675760, 0.617182943620305350, +0.617222283832977610, 0.617261622502594420, 0.617300959629056960, 0.617340295212267080, 0.617379629252126750, 0.617418961748537050, 0.617458292701399850, 0.617497622110616980, +0.617536949976090430, 0.617576276297721160, 0.617615601075411140, 0.617654924309062210, 0.617694245998576250, 0.617733566143854330, 0.617772884744798520, 0.617812201801310470, +0.617851517313292240, 0.617890831280644930, 0.617930143703270480, 0.617969454581070780, 0.618008763913947660, 0.618048071701802430, 0.618087377944536830, 0.618126682642053280, +0.618165985794252640, 0.618205287401037080, 0.618244587462308150, 0.618283885977968240, 0.618323182947918220, 0.618362478372060260, 0.618401772250296130, 0.618441064582527900, +0.618480355368656640, 0.618519644608584440, 0.618558932302213260, 0.618598218449444960, 0.618637503050180840, 0.618676786104322970, 0.618716067611773110, 0.618755347572433450, +0.618794625986205050, 0.618833902852990110, 0.618873178172690720, 0.618912451945208050, 0.618951724170444310, 0.618990994848301220, 0.619030263978680990, 0.619069531561484700, +0.619108797596614640, 0.619148062083972550, 0.619187325023460740, 0.619226586414980180, 0.619265846258433170, 0.619305104553721560, 0.619344361300747550, 0.619383616499412320, +0.619422870149617940, 0.619462122251266400, 0.619501372804259990, 0.619540621808499780, 0.619579869263887970, 0.619619115170326860, 0.619658359527717640, 0.619697602335962490, +0.619736843594963280, 0.619776083304622420, 0.619815321464840970, 0.619854558075521140, 0.619893793136565010, 0.619933026647874750, 0.619972258609351570, 0.620011489020897640, +0.620050717882415060, 0.620089945193806000, 0.620129170954971780, 0.620168395165814680, 0.620207617826236460, 0.620246838936139630, 0.620286058495425400, 0.620325276503995940, +0.620364492961753330, 0.620403707868599770, 0.620442921224436670, 0.620482133029166220, 0.620521343282690820, 0.620560551984911670, 0.620599759135731180, 0.620638964735051200, +0.620678168782774260, 0.620717371278801560, 0.620756572223035370, 0.620795771615377800, 0.620834969455731130, 0.620874165743996680, 0.620913360480076840, 0.620952553663873590, +0.620991745295289220, 0.621030935374225270, 0.621070123900583910, 0.621109310874267240, 0.621148496295177650, 0.621187680163216460, 0.621226862478286180, 0.621266043240289000, +0.621305222449126340, 0.621344400104700600, 0.621383576206913980, 0.621422750755668660, 0.621461923750866170, 0.621501095192408810, 0.621540265080198770, 0.621579433414138350, +0.621618600194129070, 0.621657765420073340, 0.621696929091873020, 0.621736091209430850, 0.621775251772648140, 0.621814410781427180, 0.621853568235670280, 0.621892724135279850, +0.621931878480157190, 0.621971031270204810, 0.622010182505325250, 0.622049332185419910, 0.622088480310391210, 0.622127626880141230, 0.622166771894572590, 0.622205915353586710, +0.622245057257086010, 0.622284197604972670, 0.622323336397149210, 0.622362473633517040, 0.622401609313978700, 0.622440743438436250, 0.622479876006792440, 0.622519007018948470, +0.622558136474807070, 0.622597264374270210, 0.622636390717240640, 0.622675515503619770, 0.622714638733310010, 0.622753760406213660, 0.622792880522233360, 0.622831999081270400, +0.622871116083227540, 0.622910231528007170, 0.622949345415510950, 0.622988457745641270, 0.623027568518300550, 0.623066677733391190, 0.623105785390814740, 0.623144891490473920, +0.623183996032270810, 0.623223099016108060, 0.623262200441887290, 0.623301300309510920, 0.623340398618881350, 0.623379495369901120, 0.623418590562471840, 0.623457684196496050, +0.623496776271876050, 0.623535866788514470, 0.623574955746312830, 0.623614043145173880, 0.623653128985000140, 0.623692213265693130, 0.623731295987155710, 0.623770377149290070, +0.623809456751998730, 0.623848534795183430, 0.623887611278746810, 0.623926686202591170, 0.623965759566619150, 0.624004831370732480, 0.624043901614833580, 0.624082970298824980, +0.624122037422609300, 0.624161102986088290, 0.624200166989164360, 0.624239229431740040, 0.624278290313718070, 0.624317349634999960, 0.624356407395488590, 0.624395463595086350, +0.624434518233695330, 0.624473571311217830, 0.624512622827556490, 0.624551672782613920, 0.624590721176291890, 0.624629768008492900, 0.624668813279119610, 0.624707856988074630, +0.624746899135259600, 0.624785939720577390, 0.624824978743930280, 0.624864016205221140, 0.624903052104351600, 0.624942086441224400, 0.624981119215741950, 0.625020150427807120, +0.625059180077321530, 0.625098208164187930, 0.625137234688309170, 0.625176259649587120, 0.625215283047924290, 0.625254304883223310, 0.625293325155386830, 0.625332343864316800, +0.625371361009915860, 0.625410376592086540, 0.625449390610731570, 0.625488403065752820, 0.625527413957053020, 0.625566423284534710, 0.625605431048100740, 0.625644437247652840, +0.625683441883093770, 0.625722444954326160, 0.625761446461252760, 0.625800446403775410, 0.625839444781796870, 0.625878441595219770, 0.625917436843946960, 0.625956430527880190, +0.625995422646922320, 0.626034413200976300, 0.626073402189943780, 0.626112389613727840, 0.626151375472230990, 0.626190359765355970, 0.626229342493004660, 0.626268323655080010, +0.626307303251484540, 0.626346281282121220, 0.626385257746891910, 0.626424232645699350, 0.626463205978446180, 0.626502177745035470, 0.626541147945368860, 0.626580116579349420, +0.626619083646879680, 0.626658049147862610, 0.626697013082200050, 0.626735975449794980, 0.626774936250550250, 0.626813895484367830, 0.626852853151150800, 0.626891809250801460, +0.626930763783223100, 0.626969716748317360, 0.627008668145987440, 0.627047617976135840, 0.627086566238665430, 0.627125512933478290, 0.627164458060477490, 0.627203401619565450, +0.627242343610645240, 0.627281284033618820, 0.627320222888389290, 0.627359160174859150, 0.627398095892931380, 0.627437030042508060, 0.627475962623492260, 0.627514893635786830, +0.627553823079293750, 0.627592750953916200, 0.627631677259556820, 0.627670601996118460, 0.627709525163503310, 0.627748446761614340, 0.627787366790354300, 0.627826285249626140, +0.627865202139331950, 0.627904117459374800, 0.627943031209657220, 0.627981943390082510, 0.628020854000552630, 0.628059763040970550, 0.628098670511239020, 0.628137576411261220, +0.628176480740939120, 0.628215383500175810, 0.628254284688874120, 0.628293184306937040, 0.628332082354266520, 0.628370978830765870, 0.628409873736338160, 0.628448767070885370, +0.628487658834310790, 0.628526549026516950, 0.628565437647407020, 0.628604324696883320, 0.628643210174848700, 0.628682094081206010, 0.628720976415858560, 0.628759857178708190, +0.628798736369658330, 0.628837613988611490, 0.628876490035470970, 0.628915364510138960, 0.628954237412518550, 0.628993108742512460, 0.629031978500024010, 0.629070846684955160, +0.629109713297209330, 0.629148578336689470, 0.629187441803297890, 0.629226303696937660, 0.629265164017511760, 0.629304022764923140, 0.629342879939074230, 0.629381735539868090, +0.629420589567207590, 0.629459442020996020, 0.629498292901135460, 0.629537142207529100, 0.629575989940080020, 0.629614836098691180, 0.629653680683264990, 0.629692523693704540, +0.629731365129912900, 0.629770204991793040, 0.629809043279247470, 0.629847879992179170, 0.629886715130491550, 0.629925548694086790, 0.629964380682868200, 0.630003211096738620, +0.630042039935601370, 0.630080867199358740, 0.630119692887913920, 0.630158517001169760, 0.630197339539029790, 0.630236160501395970, 0.630274979888171830, 0.630313797699260330, +0.630352613934564540, 0.630391428593986890, 0.630430241677430780, 0.630469053184798960, 0.630507863115994940, 0.630546671470920810, 0.630585478249480080, 0.630624283451575950, +0.630663087077110830, 0.630701889125987900, 0.630740689598110360, 0.630779488493381390, 0.630818285811703290, 0.630857081552979590, 0.630895875717113140, 0.630934668304007350, +0.630973459313564520, 0.631012248745688060, 0.631051036600280950, 0.631089822877246580, 0.631128607576487370, 0.631167390697906620, 0.631206172241407400, 0.631244952206893030, +0.631283730594266010, 0.631322507403429660, 0.631361282634287040, 0.631400056286741560, 0.631438828360695540, 0.631477598856052480, 0.631516367772715800, 0.631555135110587810, +0.631593900869572010, 0.631632665049571500, 0.631671427650489560, 0.631710188672228830, 0.631748948114692510, 0.631787705977783890, 0.631826462261406370, 0.631865216965462270, +0.631903970089855220, 0.631942721634488170, 0.631981471599264770, 0.632020219984087190, 0.632058966788859200, 0.632097712013483750, 0.632136455657864360, 0.632175197721903450, +0.632213938205504530, 0.632252677108571250, 0.632291414431005780, 0.632330150172711880, 0.632368884333592510, 0.632407616913551300, 0.632446347912490770, 0.632485077330314230, +0.632523805166925080, 0.632562531422226850, 0.632601256096121830, 0.632639979188513670, 0.632678700699305650, 0.632717420628401190, 0.632756138975702820, 0.632794855741114050, +0.632833570924538180, 0.632872284525878740, 0.632910996545038240, 0.632949706981920320, 0.632988415836428400, 0.633027123108465100, 0.633065828797934050, 0.633104532904738340, +0.633143235428781700, 0.633181936369966560, 0.633220635728196650, 0.633259333503375150, 0.633298029695405610, 0.633336724304190630, 0.633375417329633980, 0.633414108771638620, +0.633452798630108390, 0.633491486904945830, 0.633530173596054570, 0.633568858703337900, 0.633607542226699350, 0.633646224166041660, 0.633684904521268470, 0.633723583292282950, +0.633762260478988760, 0.633800936081288620, 0.633839610099086180, 0.633878282532285060, 0.633916953380787800, 0.633955622644498230, 0.633994290323319550, 0.634032956417155510, +0.634071620925908740, 0.634110283849482980, 0.634148945187781420, 0.634187604940707920, 0.634226263108164990, 0.634264919690056490, 0.634303574686285620, 0.634342228096756220, +0.634380879921370820, 0.634419530160033270, 0.634458178812646880, 0.634496825879115380, 0.634535471359341520, 0.634574115253228930, 0.634612757560681360, 0.634651398281601660, +0.634690037415893360, 0.634728674963460080, 0.634767310924205350, 0.634805945298032030, 0.634844578084843960, 0.634883209284544340, 0.634921838897037020, 0.634960466922224740, +0.634999093360011370, 0.635037718210300190, 0.635076341472995190, 0.635114963147998870, 0.635153583235215200, 0.635192201734547490, 0.635230818645899700, 0.635269433969174570, +0.635308047704275740, 0.635346659851107170, 0.635385270409571600, 0.635423879379572900, 0.635462486761014470, 0.635501092553800160, 0.635539696757832840, 0.635578299373016240, +0.635616900399253780, 0.635655499836449530, 0.635694097684506240, 0.635732693943327650, 0.635771288612817290, 0.635809881692879000, 0.635848473183415750, 0.635887063084331290, +0.635925651395529260, 0.635964238116913380, 0.636002823248386530, 0.636041406789852660, 0.636079988741215630, 0.636118569102378180, 0.636157147873244400, 0.636195725053717690, +0.636234300643702120, 0.636272874643100340, 0.636311447051816410, 0.636350017869753870, 0.636388587096816670, 0.636427154732907670, 0.636465720777930730, 0.636504285231789480, +0.636542848094387880, 0.636581409365628790, 0.636619969045416180, 0.636658527133653670, 0.636697083630245240, 0.636735638535093740, 0.636774191848103020, 0.636812743569176940, +0.636851293698219360, 0.636889842235133120, 0.636928389179822310, 0.636966934532190890, 0.637005478292141710, 0.637044020459578970, 0.637082561034406080, 0.637121100016527110, +0.637159637405845140, 0.637198173202264020, 0.637236707405687500, 0.637275240016019540, 0.637313771033163110, 0.637352300457022290, 0.637390828287500710, 0.637429354524502330, +0.637467879167930350, 0.637506402217688510, 0.637544923673680760, 0.637583443535811090, 0.637621961803982450, 0.637660478478098810, 0.637698993558064480, 0.637737507043782180, +0.637776018935156230, 0.637814529232090140, 0.637853037934488110, 0.637891545042253090, 0.637930050555289290, 0.637968554473500320, 0.638007056796790260, 0.638045557525062310, +0.638084056658220430, 0.638122554196168370, 0.638161050138810300, 0.638199544486049210, 0.638238037237789380, 0.638276528393934340, 0.638315017954388390, 0.638353505919054490, +0.638391992287836940, 0.638430477060639600, 0.638468960237365880, 0.638507441817919630, 0.638545921802204820, 0.638584400190125520, 0.638622876981584930, 0.638661352176487120, +0.638699825774735940, 0.638738297776235590, 0.638776768180889130, 0.638815236988600650, 0.638853704199274230, 0.638892169812813830, 0.638930633829122630, 0.638969096248104830, +0.639007557069664280, 0.639046016293705280, 0.639084473920130790, 0.639122929948845230, 0.639161384379752230, 0.639199837212756190, 0.639238288447760210, 0.639276738084668450, +0.639315186123385230, 0.639353632563813720, 0.639392077405858130, 0.639430520649422300, 0.639468962294410530, 0.639507402340726010, 0.639545840788272920, 0.639584277636955360, +0.639622712886677380, 0.639661146537342300, 0.639699578588854290, 0.639738009041117440, 0.639776437894035820, 0.639814865147512850, 0.639853290801452590, 0.639891714855759240, +0.639930137310336880, 0.639968558165088800, 0.640006977419919300, 0.640045395074732790, 0.640083811129432470, 0.640122225583922510, 0.640160638438107110, 0.640199049691890340, +0.640237459345175730, 0.640275867397867350, 0.640314273849869390, 0.640352678701086030, 0.640391081951420690, 0.640429483600777560, 0.640467883649060710, 0.640506282096174660, +0.640544678942022380, 0.640583074186508510, 0.640621467829536880, 0.640659859871012040, 0.640698250310837050, 0.640736639148916540, 0.640775026385154820, 0.640813412019455080, +0.640851796051721820, 0.640890178481859140, 0.640928559309771330, 0.640966938535361800, 0.641005316158534840, 0.641043692179194660, 0.641082066597245650, 0.641120439412591000, +0.641158810625135360, 0.641197180234782560, 0.641235548241437250, 0.641273914645002720, 0.641312279445383380, 0.641350642642483430, 0.641389004236207150, 0.641427364226457960, +0.641465722613140390, 0.641504079396158940, 0.641542434575416820, 0.641580788150818760, 0.641619140122268620, 0.641657490489671020, 0.641695839252929280, 0.641734186411948020, +0.641772531966631310, 0.641810875916883570, 0.641849218262608320, 0.641887559003709970, 0.641925898140092820, 0.641964235671661170, 0.642002571598318640, 0.642040905919969650, +0.642079238636518390, 0.642117569747869490, 0.642155899253926240, 0.642194227154593180, 0.642232553449774590, 0.642270878139375000, 0.642309201223297820, 0.642347522701447680, +0.642385842573729100, 0.642424160840045500, 0.642462477500301610, 0.642500792554401400, 0.642539106002249620, 0.642577417843749670, 0.642615728078806290, 0.642654036707323460, +0.642692343729205920, 0.642730649144357290, 0.642768952952681880, 0.642807255154084210, 0.642845555748468690, 0.642883854735738950, 0.642922152115799510, 0.642960447888554780, +0.642998742053909170, 0.643037034611766420, 0.643075325562031170, 0.643113614904607830, 0.643151902639400140, 0.643190188766312730, 0.643228473285249790, 0.643266756196116060, +0.643305037498815070, 0.643343317193251550, 0.643381595279329700, 0.643419871756954140, 0.643458146626028630, 0.643496419886457780, 0.643534691538145800, 0.643572961580997420, +0.643611230014916380, 0.643649496839807210, 0.643687762055574320, 0.643726025662122340, 0.643764287659355010, 0.643802548047176960, 0.643840806825492830, 0.643879063994206360, +0.643917319553222180, 0.643955573502444810, 0.643993825841778780, 0.644032076571127820, 0.644070325690396680, 0.644108573199489780, 0.644146819098311730, 0.644185063386766400, +0.644223306064758310, 0.644261547132191970, 0.644299786588972130, 0.644338024435002430, 0.644376260670187720, 0.644414495294432290, 0.644452728307641000, 0.644490959709717590, +0.644529189500566810, 0.644567417680092960, 0.644605644248200990, 0.644643869204794440, 0.644682092549778370, 0.644720314283057320, 0.644758534404535230, 0.644796752914116640, +0.644834969811706290, 0.644873185097208920, 0.644911398770528050, 0.644949610831568880, 0.644987821280235570, 0.645026030116433110, 0.645064237340065130, 0.645102442951036690, +0.645140646949252110, 0.645178849334616220, 0.645217050107032790, 0.645255249266406870, 0.645293446812642780, 0.645331642745645360, 0.645369837065318590, 0.645408029771567190, +0.645446220864296040, 0.645484410343408980, 0.645522598208810860, 0.645560784460406320, 0.645598969098100220, 0.645637152121796290, 0.645675333531399390, 0.645713513326814260, +0.645751691507945650, 0.645789868074697520, 0.645828043026974720, 0.645866216364681670, 0.645904388087723550, 0.645942558196004100, 0.645980726689428300, 0.646018893567900650, +0.646057058831326030, 0.646095222479608490, 0.646133384512652900, 0.646171544930364220, 0.646209703732646300, 0.646247860919404000, 0.646286016490542180, 0.646324170445965680, +0.646362322785578370, 0.646400473509285310, 0.646438622616991030, 0.646476770108600500, 0.646514915984017670, 0.646553060243147630, 0.646591202885894890, 0.646629343912164530, +0.646667483321860530, 0.646705621114887720, 0.646743757291150860, 0.646781891850555010, 0.646820024793004040, 0.646858156118403030, 0.646896285826656590, 0.646934413917669810, +0.646972540391346660, 0.647010665247592100, 0.647048788486311200, 0.647086910107408150, 0.647125030110787700, 0.647163148496354700, 0.647201265264014220, 0.647239380413670130, +0.647277493945227710, 0.647315605858591490, 0.647353716153666550, 0.647391824830357070, 0.647429931888567900, 0.647468037328204020, 0.647506141149170380, 0.647544243351371060, +0.647582343934711040, 0.647620442899095260, 0.647658540244428590, 0.647696635970615330, 0.647734730077560440, 0.647772822565169100, 0.647810913433345400, 0.647849002681994300, +0.647887090311020760, 0.647925176320329870, 0.647963260709825680, 0.648001343479413290, 0.648039424628997550, 0.648077504158483640, 0.648115582067775640, 0.648153658356778630, +0.648191733025397450, 0.648229806073537420, 0.648267877501102370, 0.648305947307997730, 0.648344015494128120, 0.648382082059398850, 0.648420147003714090, 0.648458210326978920, +0.648496272029098650, 0.648534332109977240, 0.648572390569520100, 0.648610447407631850, 0.648648502624217920, 0.648686556219182360, 0.648724608192430500, 0.648762658543867050, +0.648800707273397230, 0.648838754380925420, 0.648876799866356600, 0.648914843729595850, 0.648952885970548340, 0.648990926589118280, 0.649028965585210840, 0.649067002958731100, +0.649105038709584140, 0.649143072837674250, 0.649181105342906630, 0.649219136225186570, 0.649257165484418360, 0.649295193120507320, 0.649333219133358170, 0.649371243522876450, +0.649409266288966220, 0.649447287431532790, 0.649485306950481120, 0.649523324845716620, 0.649561341117143360, 0.649599355764666760, 0.649637368788191890, 0.649675380187623830, +0.649713389962866980, 0.649751398113826650, 0.649789404640407910, 0.649827409542515940, 0.649865412820055170, 0.649903414472930760, 0.649941414501047920, 0.649979412904311830, +0.650017409682626780, 0.650055404835898300, 0.650093398364031680, 0.650131390266931230, 0.650169380544502240, 0.650207369196649790, 0.650245356223279280, 0.650283341624295020, +0.650321325399602520, 0.650359307549106540, 0.650397288072712800, 0.650435266970325390, 0.650473244241849820, 0.650511219887191180, 0.650549193906254760, 0.650587166298945090, +0.650625137065167450, 0.650663106204827040, 0.650701073717829150, 0.650739039604078200, 0.650777003863479700, 0.650814966495939060, 0.650852927501360590, 0.650890886879649910, +0.650928844630711880, 0.650966800754452120, 0.651004755250775060, 0.651042708119586090, 0.651080659360790400, 0.651118608974293300, 0.651156556959999410, 0.651194503317814140, +0.651232448047642580, 0.651270391149390230, 0.651308332622961620, 0.651346272468262160, 0.651384210685197030, 0.651422147273671650, 0.651460082233590530, 0.651498015564859310, +0.651535947267383290, 0.651573877341067200, 0.651611805785816230, 0.651649732601535910, 0.651687657788131540, 0.651725581345507730, 0.651763503273569910, 0.651801423572223370, +0.651839342241373520, 0.651877259280925100, 0.651915174690783420, 0.651953088470853870, 0.651991000621041980, 0.652028911141252170, 0.652066820031390050, 0.652104727291360930, +0.652142632921070440, 0.652180536920422880, 0.652218439289323990, 0.652256340027679070, 0.652294239135393640, 0.652332136612372220, 0.652370032458520430, 0.652407926673744030, +0.652445819257947420, 0.652483710211036130, 0.652521599532915660, 0.652559487223491660, 0.652597373282668420, 0.652635257710351800, 0.652673140506447090, 0.652711021670859810, +0.652748901203494600, 0.652786779104257200, 0.652824655373052900, 0.652862530009787220, 0.652900403014364920, 0.652938274386691610, 0.652976144126672600, 0.653014012234213510, +0.653051878709219100, 0.653089743551594990, 0.653127606761246930, 0.653165468338079420, 0.653203328281998340, 0.653241186592908860, 0.653279043270716730, 0.653316898315326690, +0.653354751726644480, 0.653392603504575290, 0.653430453649024970, 0.653468302159898150, 0.653506149037100580, 0.653543994280537670, 0.653581837890115040, 0.653619679865737550, +0.653657520207310830, 0.653695358914740290, 0.653733195987931780, 0.653771031426789830, 0.653808865231220390, 0.653846697401129110, 0.653884527936420710, 0.653922356837000950, +0.653960184102775340, 0.653998009733649630, 0.654035833729528560, 0.654073656090317980, 0.654111476815923080, 0.654149295906249930, 0.654187113361203280, 0.654224929180688750, +0.654262743364611880, 0.654300555912878500, 0.654338366825393480, 0.654376176102062450, 0.654413983742791030, 0.654451789747484970, 0.654489594116049120, 0.654527396848389230, +0.654565197944411150, 0.654602997404019840, 0.654640795227121040, 0.654678591413620170, 0.654716385963423190, 0.654754178876434940, 0.654791970152561190, 0.654829759791707540, +0.654867547793779870, 0.654905334158682910, 0.654943118886322730, 0.654980901976604630, 0.655018683429434700, 0.655056463244717670, 0.655094241422359500, 0.655132017962265830, +0.655169792864342290, 0.655207566128494070, 0.655245337754626790, 0.655283107742646200, 0.655320876092458260, 0.655358642803967720, 0.655396407877080640, 0.655434171311702900, +0.655471933107739320, 0.655509693265095890, 0.655547451783678240, 0.655585208663392320, 0.655622963904143100, 0.655660717505836320, 0.655698469468377840, 0.655736219791673510, +0.655773968475628300, 0.655811715520148280, 0.655849460925138850, 0.655887204690506100, 0.655924946816154990, 0.655962687301991590, 0.656000426147921420, 0.656038163353850460, +0.656075898919683880, 0.656113632845327530, 0.656151365130687390, 0.656189095775668530, 0.656226824780176910, 0.656264552144118160, 0.656302277867398480, 0.656340001949922700, +0.656377724391596920, 0.656415445192326860, 0.656453164352018610, 0.656490881870576910, 0.656528597747908170, 0.656566311983917910, 0.656604024578512190, 0.656641735531595990, +0.656679444843075500, 0.656717152512856450, 0.656754858540844810, 0.656792562926945770, 0.656830265671065280, 0.656867966773109440, 0.656905666232983300, 0.656943364050593060, +0.656981060225844350, 0.657018754758643350, 0.657056447648895150, 0.657094138896505810, 0.657131828501381190, 0.657169516463427250, 0.657207202782549290, 0.657244887458653170, +0.657282570491644960, 0.657320251881430620, 0.657357931627915230, 0.657395609731005190, 0.657433286190605930, 0.657470961006623940, 0.657508634178964100, 0.657546305707532810, +0.657583975592235690, 0.657621643832978940, 0.657659310429667740, 0.657696975382208280, 0.657734638690506750, 0.657772300354468210, 0.657809960373998970, 0.657847618749004880, +0.657885275479392020, 0.657922930565065570, 0.657960584005931940, 0.657998235801896760, 0.658035885952866330, 0.658073534458745830, 0.658111181319441570, 0.658148826534859290, +0.658186470104905390, 0.658224112029484830, 0.658261752308504030, 0.658299390941868960, 0.658337027929485560, 0.658374663271259370, 0.658412296967096580, 0.658449929016903250, +0.658487559420584900, 0.658525188178047500, 0.658562815289197250, 0.658600440753940310, 0.658638064572181770, 0.658675686743828260, 0.658713307268785410, 0.658750926146959740, +0.658788543378256320, 0.658826158962581570, 0.658863772899841440, 0.658901385189942120, 0.658938995832789140, 0.658976604828288570, 0.659014212176346480, 0.659051817876869280, +0.659089421929762160, 0.659127024334931530, 0.659164625092283570, 0.659202224201723810, 0.659239821663158420, 0.659277417476493600, 0.659315011641635420, 0.659352604158489400, +0.659390195026961940, 0.659427784246959030, 0.659465371818386830, 0.659502957741150970, 0.659540542015157770, 0.659578124640313180, 0.659615705616523500, 0.659653284943694350, +0.659690862621731930, 0.659728438650542430, 0.659766013030032020, 0.659803585760106340, 0.659841156840671680, 0.659878726271634570, 0.659916294052900200, 0.659953860184375070, +0.659991424665965280, 0.660028987497577320, 0.660066548679116630, 0.660104108210489480, 0.660141666091601960, 0.660179222322360810, 0.660216776902671110, 0.660254329832439590, +0.660291881111572110, 0.660329430739975410, 0.660366978717554680, 0.660404525044216540, 0.660442069719867190, 0.660479612744412910, 0.660517154117759240, 0.660554693839812690, +0.660592231910479440, 0.660629768329665910, 0.660667303097277610, 0.660704836213221180, 0.660742367677402910, 0.660779897489728320, 0.660817425650104040, 0.660854952158436260, +0.660892477014631390, 0.660930000218594940, 0.660967521770233550, 0.661005041669453290, 0.661042559916160790, 0.661080076510261570, 0.661117591451662160, 0.661155104740268840, +0.661192616375988030, 0.661230126358725360, 0.661267634688387340, 0.661305141364880170, 0.661342646388110580, 0.661380149757984090, 0.661417651474407120, 0.661455151537286400, +0.661492649946527460, 0.661530146702036910, 0.661567641803720960, 0.661605135251486230, 0.661642627045238350, 0.661680117184883950, 0.661717605670329220, 0.661755092501480790, +0.661792577678244290, 0.661830061200526340, 0.661867543068233370, 0.661905023281271650, 0.661942501839547280, 0.661979978742966440, 0.662017453991435740, 0.662054927584861840, +0.662092399523150130, 0.662129869806207470, 0.662167338433940600, 0.662204805406254930, 0.662242270723057190, 0.662279734384253800, 0.662317196389751510, 0.662354656739455820, +0.662392115433273480, 0.662429572471110890, 0.662467027852874700, 0.662504481578470640, 0.662541933647805230, 0.662579384060785090, 0.662616832817316870, 0.662654279917306190, +0.662691725360659790, 0.662729169147284080, 0.662766611277085800, 0.662804051749970700, 0.662841490565845400, 0.662878927724616320, 0.662916363226190410, 0.662953797070473190, +0.662991229257371420, 0.663028659786791930, 0.663066088658640580, 0.663103515872823900, 0.663140941429248400, 0.663178365327820930, 0.663215787568447230, 0.663253208151034060, +0.663290627075487800, 0.663328044341715330, 0.663365459949622480, 0.663402873899115900, 0.663440286190102200, 0.663477696822488140, 0.663515105796179450, 0.663552513111082990, +0.663589918767105270, 0.663627322764153040, 0.663664725102132260, 0.663702125780949560, 0.663739524800512020, 0.663776922160725260, 0.663814317861496140, 0.663851711902731290, +0.663889104284337450, 0.663926495006220590, 0.663963884068287440, 0.664001271470444520, 0.664038657212598920, 0.664076041294656140, 0.664113423716523380, 0.664150804478107040, +0.664188183579314080, 0.664225561020050260, 0.664262936800222530, 0.664300310919737510, 0.664337683378501960, 0.664375054176421950, 0.664412423313404330, 0.664449790789355950, +0.664487156604182670, 0.664524520757791670, 0.664561883250089250, 0.664599244080982480, 0.664636603250377210, 0.664673960758180530, 0.664711316604298940, 0.664748670788639310, +0.664786023311107700, 0.664823374171611080, 0.664860723370055970, 0.664898070906349450, 0.664935416780397360, 0.664972760992106780, 0.665010103541384230, 0.665047444428136790, +0.665084783652270420, 0.665122121213692070, 0.665159457112308730, 0.665196791348026450, 0.665234123920752210, 0.665271454830392630, 0.665308784076854790, 0.665346111660044540, +0.665383437579869170, 0.665420761836235110, 0.665458084429049520, 0.665495405358218270, 0.665532724623648650, 0.665570042225247180, 0.665607358162920940, 0.665644672436575880, +0.665681985046119310, 0.665719295991457630, 0.665756605272498140, 0.665793912889146800, 0.665831218841310580, 0.665868523128896330, 0.665905825751811230, 0.665943126709961140, +0.665980426003253250, 0.666017723631594620, 0.666055019594891330, 0.666092313893050570, 0.666129606525978970, 0.666166897493583600, 0.666204186795770760, 0.666241474432447410, +0.666278760403520410, 0.666316044708896830, 0.666353327348482850, 0.666390608322185440, 0.666427887629911670, 0.666465165271568400, 0.666502441247061930, 0.666539715556299320, +0.666576988199187430, 0.666614259175633330, 0.666651528485543430, 0.666688796128824590, 0.666726062105384100, 0.666763326415128140, 0.666800589057963800, 0.666837850033798030, +0.666875109342538020, 0.666912366984089840, 0.666949622958360800, 0.666986877265257630, 0.667024129904687620, 0.667061380876557090, 0.667098630180772870, 0.667135877817242260, +0.667173123785872240, 0.667210368086569080, 0.667247610719239990, 0.667284851683791810, 0.667322090980131840, 0.667359328608166380, 0.667396564567802610, 0.667433798858947710, +0.667471031481507990, 0.667508262435390740, 0.667545491720502810, 0.667582719336751510, 0.667619945284043000, 0.667657169562284710, 0.667694392171383380, 0.667731613111246510, +0.667768832381780310, 0.667806049982891950, 0.667843265914488390, 0.667880480176477050, 0.667917692768764340, 0.667954903691257210, 0.667992112943862850, 0.668029320526488670, +0.668066526439040740, 0.668103730681426480, 0.668140933253552950, 0.668178134155327340, 0.668215333386656170, 0.668252530947446630, 0.668289726837606010, 0.668326921057040830, +0.668364113605658390, 0.668401304483365540, 0.668438493690069800, 0.668475681225677580, 0.668512867090096050, 0.668550051283232420, 0.668587233804993960, 0.668624414655287100, +0.668661593834019240, 0.668698771341097340, 0.668735947176428920, 0.668773121339920170, 0.668810293831478720, 0.668847464651011530, 0.668884633798426000, 0.668921801273628550, +0.668958967076526580, 0.668996131207027500, 0.669033293665037830, 0.669070454450464870, 0.669107613563215800, 0.669144771003198020, 0.669181926770317960, 0.669219080864483120, +0.669256233285600580, 0.669293384033577740, 0.669330533108321140, 0.669367680509738160, 0.669404826237736120, 0.669441970292222190, 0.669479112673103120, 0.669516253380286200, +0.669553392413678620, 0.669590529773188000, 0.669627665458720660, 0.669664799470184090, 0.669701931807485940, 0.669739062470532610, 0.669776191459231620, 0.669813318773490150, +0.669850444413215730, 0.669887568378314870, 0.669924690668695090, 0.669961811284263580, 0.669998930224927850, 0.670036047490594420, 0.670073163081170930, 0.670110276996564560, +0.670147389236682820, 0.670184499801432240, 0.670221608690720450, 0.670258715904454630, 0.670295821442542290, 0.670332925304890080, 0.670370027491405620, 0.670407128001996420, +0.670444226836569010, 0.670481323995031130, 0.670518419477289850, 0.670555513283252800, 0.670592605412826730, 0.670629695865919140, 0.670666784642437340, 0.670703871742288850, +0.670740957165380400, 0.670778040911619520, 0.670815122980913610, 0.670852203373170090, 0.670889282088295790, 0.670926359126198360, 0.670963434486784970, 0.671000508169963260, +0.671037580175640080, 0.671074650503722840, 0.671111719154119050, 0.671148786126736230, 0.671185851421481130, 0.671222915038261370, 0.671259976976984700, 0.671297037237557850, +0.671334095819888230, 0.671371152723883480, 0.671408207949451220, 0.671445261496497970, 0.671482313364931690, 0.671519363554659580, 0.671556412065589360, 0.671593458897627780, +0.671630504050682590, 0.671667547524661180, 0.671704589319471190, 0.671741629435019360, 0.671778667871213540, 0.671815704627960920, 0.671852739705169450, 0.671889773102745890, +0.671926804820597750, 0.671963834858632980, 0.672000863216758340, 0.672037889894881450, 0.672074914892909940, 0.672111938210751440, 0.672148959848312690, 0.672185979805501650, +0.672222998082225520, 0.672260014678392360, 0.672297029593908800, 0.672334042828682590, 0.672371054382621350, 0.672408064255632820, 0.672445072447623750, 0.672482078958501980, +0.672519083788175040, 0.672556086936550780, 0.672593088403535930, 0.672630088189038360, 0.672667086292965900, 0.672704082715225300, 0.672741077455724650, 0.672778070514371220, +0.672815061891072990, 0.672852051585736800, 0.672889039598270400, 0.672926025928581420, 0.672963010576577700, 0.672999993542166110, 0.673036974825254600, 0.673073954425750580, +0.673110932343562120, 0.673147908578595850, 0.673184883130759970, 0.673221855999961760, 0.673258827186109300, 0.673295796689109330, 0.673332764508870030, 0.673369730645298700, +0.673406695098303420, 0.673443657867791030, 0.673480618953669620, 0.673517578355846910, 0.673554536074229880, 0.673591492108726600, 0.673628446459244580, 0.673665399125691680, +0.673702350107975080, 0.673739299406002520, 0.673776247019681640, 0.673813192948920610, 0.673850137193626190, 0.673887079753706430, 0.673924020629069090, 0.673960959819621900, +0.673997897325272040, 0.674034833145927380, 0.674071767281495650, 0.674108699731884920, 0.674145630497002050, 0.674182559576755100, 0.674219486971052050, 0.674256412679799970, +0.674293336702906920, 0.674330259040280430, 0.674367179691828690, 0.674404098657458650, 0.674441015937078390, 0.674477931530595540, 0.674514845437918180, 0.674551757658953480, +0.674588668193609300, 0.674625577041793490, 0.674662484203414010, 0.674699389678378060, 0.674736293466593580, 0.674773195567968440, 0.674810095982410600, 0.674846994709827120, +0.674883891750126310, 0.674920787103216010, 0.674957680769003420, 0.674994572747396600, 0.675031463038303300, 0.675068351641631810, 0.675105238557288990, 0.675142123785183120, +0.675179007325221960, 0.675215889177313680, 0.675252769341365240, 0.675289647817284840, 0.675326524604980440, 0.675363399704359990, 0.675400273115330680, 0.675437144837800820, +0.675474014871678020, 0.675510883216870470, 0.675547749873285360, 0.675584614840830990, 0.675621478119415310, 0.675658339708945730, 0.675695199609330220, 0.675732057820476630, +0.675768914342293360, 0.675805769174687490, 0.675842622317567090, 0.675879473770840120, 0.675916323534414890, 0.675953171608198460, 0.675990017992099120, 0.676026862686024740, +0.676063705689883500, 0.676100547003582800, 0.676137386627030600, 0.676174224560134980, 0.676211060802804020, 0.676247895354945230, 0.676284728216466680, 0.676321559387276230, +0.676358388867282280, 0.676395216656392020, 0.676432042754513630, 0.676468867161555630, 0.676505689877424990, 0.676542510902030210, 0.676579330235279050, 0.676616147877080020, +0.676652963827340190, 0.676689778085967970, 0.676726590652871440, 0.676763401527958660, 0.676800210711136940, 0.676837018202314900, 0.676873824001400170, 0.676910628108301270, +0.676947430522925390, 0.676984231245181030, 0.677021030274976070, 0.677057827612218780, 0.677094623256816690, 0.677131417208677980, 0.677168209467711170, 0.677205000033823450, +0.677241788906923100, 0.677278576086918440, 0.677315361573717630, 0.677352145367228100, 0.677388927467358130, 0.677425707874015900, 0.677462486587109720, 0.677499263606547000, +0.677536038932236130, 0.677572812564085190, 0.677609584502002480, 0.677646354745895520, 0.677683123295672600, 0.677719890151242010, 0.677756655312511840, 0.677793418779389920, +0.677830180551784340, 0.677866940629603620, 0.677903699012755160, 0.677940455701147580, 0.677977210694688860, 0.678013963993287390, 0.678050715596850710, 0.678087465505287200, +0.678124213718505060, 0.678160960236412700, 0.678197705058917630, 0.678234448185928260, 0.678271189617352780, 0.678307929353099690, 0.678344667393076420, 0.678381403737191470, +0.678418138385353030, 0.678454871337469510, 0.678491602593448540, 0.678528332153198630, 0.678565060016627860, 0.678601786183644750, 0.678638510654156810, 0.678675233428072570, +0.678711954505300640, 0.678748673885748440, 0.678785391569324600, 0.678822107555937300, 0.678858821845495060, 0.678895534437905400, 0.678932245333076940, 0.678968954530917770, +0.679005662031336720, 0.679042367834240990, 0.679079071939539420, 0.679115774347140210, 0.679152475056951870, 0.679189174068882020, 0.679225871382839190, 0.679262566998731780, +0.679299260916468190, 0.679335953135956180, 0.679372643657104260, 0.679409332479821050, 0.679446019604014180, 0.679482705029592290, 0.679519388756463560, 0.679556070784536730, +0.679592751113719420, 0.679629429743920270, 0.679666106675047450, 0.679702781907009830, 0.679739455439714810, 0.679776127273071130, 0.679812797406987190, 0.679849465841371630, +0.679886132576131950, 0.679922797611177020, 0.679959460946415130, 0.679996122581754790, 0.680032782517103970, 0.680069440752371080, 0.680106097287464960, 0.680142752122293250, +0.680179405256764680, 0.680216056690787660, 0.680252706424270710, 0.680289354457121800, 0.680326000789249320, 0.680362645420562020, 0.680399288350968300, 0.680435929580376130, +0.680472569108694140, 0.680509206935830610, 0.680545843061694520, 0.680582477486193380, 0.680619110209236160, 0.680655741230731030, 0.680692370550586960, 0.680728998168711690, +0.680765624085013840, 0.680802248299402280, 0.680838870811784850, 0.680875491622070060, 0.680912110730166660, 0.680948728135983390, 0.680985343839427880, 0.681021957840408980, +0.681058570138835200, 0.681095180734615390, 0.681131789627657190, 0.681168396817869670, 0.681205002305161010, 0.681241606089440290, 0.681278208170615130, 0.681314808548594500, +0.681351407223286800, 0.681388004194600990, 0.681424599462444820, 0.681461193026727140, 0.681497784887356460, 0.681534375044241640, 0.681570963497290520, 0.681607550246412060, +0.681644135291515020, 0.681680718632507340, 0.681717300269297890, 0.681753880201795060, 0.681790458429908040, 0.681827034953544460, 0.681863609772613290, 0.681900182887023030, +0.681936754296682770, 0.681973324001500240, 0.682009892001384400, 0.682046458296243770, 0.682083022885987320, 0.682119585770523120, 0.682156146949759900, 0.682192706423606190, +0.682229264191971160, 0.682265820254762680, 0.682302374611889580, 0.682338927263260840, 0.682375478208784520, 0.682412027448369480, 0.682448574981924350, 0.682485120809358190, +0.682521664930578860, 0.682558207345495330, 0.682594748054016320, 0.682631287056050700, 0.682667824351506640, 0.682704359940292990, 0.682740893822318400, 0.682777425997491920, +0.682813956465721520, 0.682850485226916270, 0.682887012280984810, 0.682923537627836200, 0.682960061267378290, 0.682996583199520280, 0.683033103424171230, 0.683069621941238990, +0.683106138750632750, 0.683142653852261140, 0.683179167246033110, 0.683215678931856970, 0.683252188909641680, 0.683288697179295750, 0.683325203740728580, 0.683361708593847930, +0.683398211738563080, 0.683434713174782660, 0.683471212902415860, 0.683507710921370640, 0.683544207231556180, 0.683580701832881220, 0.683617194725254730, 0.683653685908585000, +0.683690175382781100, 0.683726663147751660, 0.683763149203405970, 0.683799633549652010, 0.683836116186399060, 0.683872597113556080, 0.683909076331031260, 0.683945553838733790, +0.683982029636572400, 0.684018503724456270, 0.684054976102293600, 0.684091446769993450, 0.684127915727464790, 0.684164382974616570, 0.684200848511356980, 0.684237312337595440, +0.684273774453240560, 0.684310234858201530, 0.684346693552386530, 0.684383150535704980, 0.684419605808065380, 0.684456059369377150, 0.684492511219548460, 0.684528961358488510, +0.684565409786106470, 0.684601856502310540, 0.684638301507010110, 0.684674744800113810, 0.684711186381530950, 0.684747626251169810, 0.684784064408939570, 0.684820500854749330, +0.684856935588508020, 0.684893368610124060, 0.684929799919506750, 0.684966229516564830, 0.685002657401207800, 0.685039083573343750, 0.685075508032881860, 0.685111930779731430, +0.685148351813801290, 0.685184771135000090, 0.685221188743236900, 0.685257604638421000, 0.685294018820460930, 0.685330431289265630, 0.685366842044744410, 0.685403251086806330, +0.685439658415359810, 0.685476064030314140, 0.685512467931578270, 0.685548870119061630, 0.685585270592672490, 0.685621669352320050, 0.685658066397913600, 0.685694461729362210, +0.685730855346574410, 0.685767247249459370, 0.685803637437926270, 0.685840025911884420, 0.685876412671242220, 0.685912797715908850, 0.685949181045793940, 0.685985562660805680, +0.686021942560853580, 0.686058320745846610, 0.686094697215694050, 0.686131071970304540, 0.686167445009587370, 0.686203816333451510, 0.686240185941806470, 0.686276553834560650, +0.686312920011623360, 0.686349284472903890, 0.686385647218311520, 0.686422008247754680, 0.686458367561142760, 0.686494725158384940, 0.686531081039390760, 0.686567435204068380, +0.686603787652327550, 0.686640138384077230, 0.686676487399226820, 0.686712834697684850, 0.686749180279360830, 0.686785524144164160, 0.686821866292003480, 0.686858206722787970, +0.686894545436427030, 0.686930882432830070, 0.686967217711905500, 0.687003551273563050, 0.687039883117711580, 0.687076213244260710, 0.687112541653119080, 0.687148868344195970, +0.687185193317400800, 0.687221516572642970, 0.687257838109830990, 0.687294157928874380, 0.687330476029682450, 0.687366792412164580, 0.687403107076229420, 0.687439420021786600, +0.687475731248745390, 0.687512040757014660, 0.687548348546503710, 0.687584654617122040, 0.687620958968778950, 0.687657261601383190, 0.687693562514844150, 0.687729861709071360, +0.687766159183974100, 0.687802454939461240, 0.687838748975442280, 0.687875041291826310, 0.687911331888523160, 0.687947620765441250, 0.687983907922490420, 0.688020193359579760, +0.688056477076618880, 0.688092759073516640, 0.688129039350182330, 0.688165317906525800, 0.688201594742455680, 0.688237869857881600, 0.688274143252712860, 0.688310414926858960, +0.688346684880228770, 0.688382953112731900, 0.688419219624277660, 0.688455484414775660, 0.688491747484134550, 0.688528008832264170, 0.688564268459073700, 0.688600526364473000, +0.688636782548370570, 0.688673037010676170, 0.688709289751299190, 0.688745540770149380, 0.688781790067135360, 0.688818037642166870, 0.688854283495153210, 0.688890527626004220, +0.688926770034628540, 0.688963010720936020, 0.688999249684836280, 0.689035486926238060, 0.689071722445051100, 0.689107956241184930, 0.689144188314549040, 0.689180418665052530, +0.689216647292604900, 0.689252874197115670, 0.689289099378494470, 0.689325322836650270, 0.689361544571492790, 0.689397764582931450, 0.689433982870875980, 0.689470199435235240, +0.689506414275919080, 0.689542627392836780, 0.689578838785898320, 0.689615048455012420, 0.689651256400088840, 0.689687462621037530, 0.689723667117767110, 0.689759869890187670, +0.689796070938208490, 0.689832270261739430, 0.689868467860689450, 0.689904663734968170, 0.689940857884485340, 0.689977050309150690, 0.690013241008872960, 0.690049429983562220, +0.690085617233128000, 0.690121802757479920, 0.690157986556527050, 0.690194168630179240, 0.690230348978346010, 0.690266527600937210, 0.690302704497861800, 0.690338879669029630, +0.690375053114350550, 0.690411224833733520, 0.690447394827088390, 0.690483563094324790, 0.690519729635352690, 0.690555894450080810, 0.690592057538419350, 0.690628218900277590, +0.690664378535565730, 0.690700536444192490, 0.690736692626067960, 0.690772847081101760, 0.690808999809203740, 0.690845150810282860, 0.690881300084249080, 0.690917447631012040, +0.690953593450481800, 0.690989737542567210, 0.691025879907178230, 0.691062020544224610, 0.691098159453616300, 0.691134296635262160, 0.691170432089072360, 0.691206565814956760, +0.691242697812824440, 0.691278828082585340, 0.691314956624149210, 0.691351083437426020, 0.691387208522324830, 0.691423331878755490, 0.691459453506627960, 0.691495573405851990, +0.691531691576336870, 0.691567808017992560, 0.691603922730728570, 0.691640035714455200, 0.691676146969081420, 0.691712256494517290, 0.691748364290672440, 0.691784470357457050, +0.691820574694780090, 0.691856677302551850, 0.691892778180682070, 0.691928877329080150, 0.691964974747655950, 0.692001070436319420, 0.692037164394980420, 0.692073256623548240, +0.692109347121932950, 0.692145435890044290, 0.692181522927792340, 0.692217608235086160, 0.692253691811836050, 0.692289773657951750, 0.692325853773343320, 0.692361932157919970, +0.692398008811591750, 0.692434083734268400, 0.692470156925860340, 0.692506228386276400, 0.692542298115427000, 0.692578366113222100, 0.692614432379571100, 0.692650496914383850, +0.692686559717570540, 0.692722620789041010, 0.692758680128704670, 0.692794737736471600, 0.692830793612251640, 0.692866847755955080, 0.692902900167491120, 0.692938950846769820, +0.692974999793701250, 0.693011047008195380, 0.693047092490161610, 0.693083136239510230, 0.693119178256150880, 0.693155218539993840, 0.693191257090948640, 0.693227293908925120, +0.693263328993833810, 0.693299362345583760, 0.693335393964085390, 0.693371423849248440, 0.693407452000983300, 0.693443478419199180, 0.693479503103806460, 0.693515526054714890, +0.693551547271834880, 0.693587566755075600, 0.693623584504347470, 0.693659600519560330, 0.693695614800624580, 0.693731627347449420, 0.693767638159945240, 0.693803647238021900, +0.693839654581589800, 0.693875660190558240, 0.693911664064837620, 0.693947666204337680, 0.693983666608969040, 0.694019665278640780, 0.694055662213263420, 0.694091657412747250, +0.694127650877001570, 0.694163642605936770, 0.694199632599462930, 0.694235620857490240, 0.694271607379928210, 0.694307592166687140, 0.694343575217677200, 0.694379556532808470, +0.694415536111990690, 0.694451513955133940, 0.694487490062148490, 0.694523464432944550, 0.694559437067431730, 0.694595407965520330, 0.694631377127120310, 0.694667344552142190, +0.694703310240495480, 0.694739274192090360, 0.694775236406837470, 0.694811196884646100, 0.694847155625426760, 0.694883112629089640, 0.694919067895544920, 0.694955021424702220, +0.694990973216472070, 0.695026923270764430, 0.695062871587489810, 0.695098818166557610, 0.695134763007878460, 0.695170706111362340, 0.695206647476919850, 0.695242587104460410, +0.695278524993894420, 0.695314461145132180, 0.695350395558084090, 0.695386328232659780, 0.695422259168769540, 0.695458188366324000, 0.695494115825232680, 0.695530041545405990, +0.695565965526754320, 0.695601887769188080, 0.695637808272616680, 0.695673727036950850, 0.695709644062100560, 0.695745559347976660, 0.695781472894488440, 0.695817384701546530, +0.695853294769061210, 0.695889203096943020, 0.695925109685101350, 0.695961014533447050, 0.695996917641890090, 0.696032819010341310, 0.696068718638710000, 0.696104616526906920, +0.696140512674842450, 0.696176407082426900, 0.696212299749570000, 0.696248190676182380, 0.696284079862174550, 0.696319967307456270, 0.696355853011938140, 0.696391736975530250, +0.696427619198143440, 0.696463499679687130, 0.696499378420072150, 0.696535255419208800, 0.696571130677007490, 0.696607004193378070, 0.696642875968231160, 0.696678746001477170, +0.696714614293026500, 0.696750480842789010, 0.696786345650675320, 0.696822208716595730, 0.696858070040460960, 0.696893929622180660, 0.696929787461665560, 0.696965643558826400, +0.697001497913572690, 0.697037350525815390, 0.697073201395464580, 0.697109050522431110, 0.697144897906624710, 0.697180743547956010, 0.697216587446335520, 0.697252429601673880, +0.697288270013880830, 0.697324108682867090, 0.697359945608543090, 0.697395780790819540, 0.697431614229606200, 0.697467445924813910, 0.697503275876352970, 0.697539104084134110, +0.697574930548067180, 0.697610755268062930, 0.697646578244032200, 0.697682399475884620, 0.697718218963531030, 0.697754036706881850, 0.697789852705848030, 0.697825666960339210, +0.697861479470266220, 0.697897290235539480, 0.697933099256069830, 0.697968906531767130, 0.698004712062542220, 0.698040515848305510, 0.698076317888967850, 0.698112118184438970, +0.698147916734629950, 0.698183713539451080, 0.698219508598813210, 0.698255301912626300, 0.698291093480801090, 0.698326883303248440, 0.698362671379878290, 0.698398457710601490, +0.698434242295328470, 0.698470025133970270, 0.698505806226436650, 0.698541585572638460, 0.698577363172486310, 0.698613139025891170, 0.698648913132762780, 0.698684685493012100, +0.698720456106549760, 0.698756224973286600, 0.698791992093132590, 0.698827757465998460, 0.698863521091795060, 0.698899282970433130, 0.698935043101822640, 0.698970801485874650, +0.699006558122499570, 0.699042313011608460, 0.699078066153111190, 0.699113817546918810, 0.699149567192942190, 0.699185315091091280, 0.699221061241277140, 0.699256805643410420, +0.699292548297401950, 0.699328289203161700, 0.699364028360600740, 0.699399765769629810, 0.699435501430159760, 0.699471235342100650, 0.699506967505363340, 0.699542697919858680, +0.699578426585497630, 0.699614153502190140, 0.699649878669847290, 0.699685602088379820, 0.699721323757698580, 0.699757043677713740, 0.699792761848336280, 0.699828478269477250, +0.699864192941046630, 0.699899905862955580, 0.699935617035114750, 0.699971326457435210, 0.700007034129827010, 0.700042740052201350, 0.700078444224468740, 0.700114146646540370, +0.700149847318326300, 0.700185546239737500, 0.700221243410684920, 0.700256938831079640, 0.700292632500831620, 0.700328324419852040, 0.700364014588051640, 0.700399703005341490, +0.700435389671631770, 0.700471074586833550, 0.700506757750858020, 0.700542439163615250, 0.700578118825016420, 0.700613796734972260, 0.700649472893393970, 0.700685147300191600, +0.700720819955276460, 0.700756490858559180, 0.700792160009951040, 0.700827827409362230, 0.700863493056703810, 0.700899156951886650, 0.700934819094821910, 0.700970479485419800, +0.701006138123591470, 0.701041795009247790, 0.701077450142299940, 0.701113103522658210, 0.701148755150233670, 0.701184405024937290, 0.701220053146680230, 0.701255699515372700, +0.701291344130925860, 0.701326986993251020, 0.701362628102258360, 0.701398267457859160, 0.701433905059964280, 0.701469540908485010, 0.701505175003331540, 0.701540807344415040, +0.701576437931646700, 0.701612066764937480, 0.701647693844197780, 0.701683319169338790, 0.701718942740271580, 0.701754564556907320, 0.701790184619156320, 0.701825802926929860, +0.701861419480138920, 0.701897034278694760, 0.701932647322507600, 0.701968258611488930, 0.702003868145549830, 0.702039475924600810, 0.702075081948553060, 0.702110686217317650, +0.702146288730805870, 0.702181889488928010, 0.702217488491595380, 0.702253085738719140, 0.702288681230210380, 0.702324274965979710, 0.702359866945938220, 0.702395457169997180, +0.702431045638067800, 0.702466632350060460, 0.702502217305886580, 0.702537800505457110, 0.702573381948683460, 0.702608961635476040, 0.702644539565746240, 0.702680115739405360, +0.702715690156363930, 0.702751262816533220, 0.702786833719824420, 0.702822402866148830, 0.702857970255416850, 0.702893535887540000, 0.702929099762429340, 0.702964661879996180, +0.703000222240151130, 0.703035780842805490, 0.703071337687870330, 0.703106892775257180, 0.703142446104876530, 0.703177997676639690, 0.703213547490457950, 0.703249095546242600, +0.703284641843904270, 0.703320186383354250, 0.703355729164504060, 0.703391270187264330, 0.703426809451546340, 0.703462346957261400, 0.703497882704320790, 0.703533416692635250, +0.703568948922116190, 0.703604479392674680, 0.703640008104222340, 0.703675535056669690, 0.703711060249928130, 0.703746583683908970, 0.703782105358523700, 0.703817625273682750, +0.703853143429297830, 0.703888659825280040, 0.703924174461540760, 0.703959687337990970, 0.703995198454541840, 0.704030707811104660, 0.704066215407591070, 0.704101721243911680, +0.704137225319978020, 0.704172727635701490, 0.704208228190992940, 0.704243726985763760, 0.704279224019925150, 0.704314719293388960, 0.704350212806065690, 0.704385704557866750, +0.704421194548703560, 0.704456682778487830, 0.704492169247129980, 0.704527653954541640, 0.704563136900634320, 0.704598618085319430, 0.704634097508507580, 0.704669575170110530, +0.704705051070039560, 0.704740525208206290, 0.704775997584521360, 0.704811468198896510, 0.704846937051243240, 0.704882404141472410, 0.704917869469495420, 0.704953333035223890, +0.704988794838569240, 0.705024254879442310, 0.705059713157754730, 0.705095169673417900, 0.705130624426343560, 0.705166077416442220, 0.705201528643625730, 0.705236978107805390, +0.705272425808892930, 0.705307871746799100, 0.705343315921435510, 0.705378758332713800, 0.705414198980545360, 0.705449637864841160, 0.705485074985512830, 0.705520510342472210, +0.705555943935629930, 0.705591375764897830, 0.705626805830187220, 0.705662234131410050, 0.705697660668476830, 0.705733085441299530, 0.705768508449789560, 0.705803929693858520, +0.705839349173417400, 0.705874766888377910, 0.705910182838651590, 0.705945597024150050, 0.705981009444784150, 0.706016420100465720, 0.706051828991106410, 0.706087236116617720, +0.706122641476910620, 0.706158045071896940, 0.706193446901488110, 0.706228846965595960, 0.706264245264131450, 0.706299641797006330, 0.706335036564132320, 0.706370429565420510, +0.706405820800782620, 0.706441210270130180, 0.706476597973374920, 0.706511983910427910, 0.706547368081201000, 0.706582750485605700, 0.706618131123553760, 0.706653509994956130, +0.706688887099724770, 0.706724262437771200, 0.706759636009007370, 0.706795007813344030, 0.706830377850693250, 0.706865746120966420, 0.706901112624075620, 0.706936477359931700, +0.706971840328446620, 0.707007201529532110, 0.707042560963099480, 0.707077918629060330, 0.707113274527326420, 0.707148628657809700, 0.707183981020421020, 0.707219331615072330, +0.707254680441675390, 0.707290027500142030, 0.707325372790383320, 0.707360716312311120, 0.707396058065837270, 0.707431398050873520, 0.707466736267330920, 0.707502072715121440, +0.707537407394156830, 0.707572740304349020, 0.707608071445609110, 0.707643400817848930, 0.707678728420980560, 0.707714054254915180, 0.707749378319564530, 0.707784700614840450, +0.707820021140655010, 0.707855339896919180, 0.707890656883544910, 0.707925972100444060, 0.707961285547528570, 0.707996597224709530, 0.708031907131899120, 0.708067215269008840, +0.708102521635950890, 0.708137826232636210, 0.708173129058977110, 0.708208430114885100, 0.708243729400272470, 0.708279026915049960, 0.708314322659130080, 0.708349616632424570, +0.708384908834844840, 0.708420199266302730, 0.708455487926710200, 0.708490774815979220, 0.708526059934020960, 0.708561343280747600, 0.708596624856070890, 0.708631904659902890, +0.708667182692154900, 0.708702458952738870, 0.708737733441566760, 0.708773006158550540, 0.708808277103601610, 0.708843546276631930, 0.708878813677553340, 0.708914079306278030, +0.708949343162717290, 0.708984605246783080, 0.709019865558387470, 0.709055124097442420, 0.709090380863859230, 0.709125635857550280, 0.709160889078427340, 0.709196140526401900, +0.709231390201386260, 0.709266638103291940, 0.709301884232031440, 0.709337128587515960, 0.709372371169657570, 0.709407611978368320, 0.709442851013560300, 0.709478088275144910, +0.709513323763034220, 0.709548557477140300, 0.709583789417375210, 0.709619019583650370, 0.709654247975877950, 0.709689474593970030, 0.709724699437838670, 0.709759922507395170, +0.709795143802551930, 0.709830363323221140, 0.709865581069314190, 0.709900797040743270, 0.709936011237420230, 0.709971223659257580, 0.710006434306166610, 0.710041643178059510, +0.710076850274848240, 0.710112055596445190, 0.710147259142761670, 0.710182460913710070, 0.710217660909202240, 0.710252859129150590, 0.710288055573466530, 0.710323250242062330, +0.710358443134849970, 0.710393634251741850, 0.710428823592649250, 0.710464011157484700, 0.710499196946160260, 0.710534380958587670, 0.710569563194679120, 0.710604743654346560, +0.710639922337502620, 0.710675099244058470, 0.710710274373926530, 0.710745447727018980, 0.710780619303248100, 0.710815789102525300, 0.710850957124763090, 0.710886123369873450, +0.710921287837768870, 0.710956450528360760, 0.710991611441561420, 0.711026770577283140, 0.711061927935438210, 0.711097083515938260, 0.711132237318695460, 0.711167389343622110, +0.711202539590630620, 0.711237688059632390, 0.711272834750540040, 0.711307979663265870, 0.711343122797721490, 0.711378264153819220, 0.711413403731471330, 0.711448541530590230, +0.711483677551087550, 0.711518811792875570, 0.711553944255866600, 0.711589074939973030, 0.711624203845106610, 0.711659330971179500, 0.711694456318104240, 0.711729579885793000, +0.711764701674157510, 0.711799821683110400, 0.711834939912563640, 0.711870056362429840, 0.711905171032620520, 0.711940283923048420, 0.711975395033625840, 0.712010504364264500, +0.712045611914876810, 0.712080717685375180, 0.712115821675672000, 0.712150923885679020, 0.712186024315308640, 0.712221122964473370, 0.712256219833085510, 0.712291314921056680, +0.712326408228299730, 0.712361499754726620, 0.712396589500250200, 0.712431677464781980, 0.712466763648234470, 0.712501848050520080, 0.712536930671551440, 0.712572011511240170, +0.712607090569498780, 0.712642167846240020, 0.712677243341375610, 0.712712317054817970, 0.712747388986479600, 0.712782459136273030, 0.712817527504110090, 0.712852594089903310, +0.712887658893564870, 0.712922721915007830, 0.712957783154143600, 0.712992842610884800, 0.713027900285144070, 0.713062956176833800, 0.713098010285865840, 0.713133062612152810, +0.713168113155607130, 0.713203161916141530, 0.713238208893667740, 0.713273254088098390, 0.713308297499346210, 0.713343339127322950, 0.713378378971941450, 0.713413417033113890, +0.713448453310753130, 0.713483487804770890, 0.713518520515080020, 0.713553551441592830, 0.713588580584222030, 0.713623607942879490, 0.713658633517477940, 0.713693657307929770, +0.713728679314147740, 0.713763699536043680, 0.713798717973530560, 0.713833734626520440, 0.713868749494926400, 0.713903762578660170, 0.713938773877634600, 0.713973783391761980, +0.714008791120955280, 0.714043797065126220, 0.714078801224187650, 0.714113803598052540, 0.714148804186632510, 0.714183802989840410, 0.714218800007588860, 0.714253795239790600, +0.714288788686357590, 0.714323780347202670, 0.714358770222238150, 0.714393758311377080, 0.714428744614531320, 0.714463729131613710, 0.714498711862536770, 0.714533692807213350, +0.714568671965555290, 0.714603649337475780, 0.714638624922886990, 0.714673598721701890, 0.714708570733832650, 0.714743540959191790, 0.714778509397692610, 0.714813476049246610, +0.714848440913767090, 0.714883403991166460, 0.714918365281357550, 0.714953324784252440, 0.714988282499764090, 0.715023238427805020, 0.715058192568288060, 0.715093144921125410, +0.715128095486229800, 0.715163044263514070, 0.715197991252890960, 0.715232936454272660, 0.715267879867571900, 0.715302821492701520, 0.715337761329574270, 0.715372699378102440, +0.715407635638198870, 0.715442570109776410, 0.715477502792747240, 0.715512433687024440, 0.715547362792520400, 0.715582290109148420, 0.715617215636820240, 0.715652139375449140, +0.715687061324947640, 0.715721981485228810, 0.715756899856204720, 0.715791816437788330, 0.715826731229892490, 0.715861644232430040, 0.715896555445313170, 0.715931464868455050, +0.715966372501768090, 0.716001278345165690, 0.716036182398559600, 0.716071084661863200, 0.716105985134989020, 0.716140883817850240, 0.716175780710358810, 0.716210675812428030, +0.716245569123970970, 0.716280460644899470, 0.716315350375126950, 0.716350238314566010, 0.716385124463129850, 0.716420008820730430, 0.716454891387281130, 0.716489772162694490, +0.716524651146883800, 0.716559528339761220, 0.716594403741239730, 0.716629277351232270, 0.716664149169651930, 0.716699019196410880, 0.716733887431422190, 0.716768753874598930, +0.716803618525854060, 0.716838481385099870, 0.716873342452249430, 0.716908201727215920, 0.716943059209911640, 0.716977914900249650, 0.717012768798142910, 0.717047620903504600, +0.717082471216246910, 0.717117319736283010, 0.717152166463525860, 0.717187011397888540, 0.717221854539283440, 0.717256695887623640, 0.717291535442822090, 0.717326373204792090, +0.717361209173445920, 0.717396043348696550, 0.717430875730457160, 0.717465706318640930, 0.717500535113160030, 0.717535362113927880, 0.717570187320857530, 0.717605010733861400, +0.717639832352852890, 0.717674652177744620, 0.717709470208450220, 0.717744286444881750, 0.717779100886952510, 0.717813913534575580, 0.717848724387664230, 0.717883533446130650, +0.717918340709888250, 0.717953146178849980, 0.717987949852929240, 0.718022751732038330, 0.718057551816090430, 0.718092350104998720, 0.718127146598676490, 0.718161941297035920, +0.718196734199990640, 0.718231525307453820, 0.718266314619337760, 0.718301102135556090, 0.718335887856021540, 0.718370671780647620, 0.718405453909346740, 0.718440234242032180, +0.718475012778617030, 0.718509789519014790, 0.718544564463137640, 0.718579337610899090, 0.718614108962212230, 0.718648878516990330, 0.718683646275146030, 0.718718412236592610, +0.718753176401243030, 0.718787938769010930, 0.718822699339808580, 0.718857458113549620, 0.718892215090146890, 0.718926970269514020, 0.718961723651563410, 0.718996475236208470, +0.719031225023362590, 0.719065973012938400, 0.719100719204849300, 0.719135463599008370, 0.719170206195329120, 0.719204946993724060, 0.719239685994106480, 0.719274423196389790, +0.719309158600487390, 0.719343892206311790, 0.719378624013776390, 0.719413354022794490, 0.719448082233279500, 0.719482808645143910, 0.719517533258301370, 0.719552256072665040, +0.719586977088148340, 0.719621696304663880, 0.719656413722125190, 0.719691129340445770, 0.719725843159538250, 0.719760555179316030, 0.719795265399692520, 0.719829973820581110, +0.719864680441894440, 0.719899385263546130, 0.719934088285449360, 0.719968789507517530, 0.720003488929663590, 0.720038186551800850, 0.720072882373842700, 0.720107576395702550, +0.720142268617293250, 0.720176959038528300, 0.720211647659320890, 0.720246334479584640, 0.720281019499232290, 0.720315702718177350, 0.720350384136333570, 0.720385063753613440, +0.720419741569930610, 0.720454417585198570, 0.720489091799330630, 0.720523764212239740, 0.720558434823839410, 0.720593103634042940, 0.720627770642764180, 0.720662435849915630, +0.720697099255410920, 0.720731760859163460, 0.720766420661086980, 0.720801078661094110, 0.720835734859098460, 0.720870389255013570, 0.720905041848753040, 0.720939692640229500, +0.720974341629356810, 0.721008988816048250, 0.721043634200217550, 0.721078277781777350, 0.721112919560641610, 0.721147559536723710, 0.721182197709936750, 0.721216834080194210, +0.721251468647409520, 0.721286101411496630, 0.721320732372368050, 0.721355361529937730, 0.721389988884118980, 0.721424614434825530, 0.721459238181970220, 0.721493860125466900, +0.721528480265228870, 0.721563098601169960, 0.721597715133203030, 0.721632329861241820, 0.721666942785199720, 0.721701553904990690, 0.721736163220527250, 0.721770770731723580, +0.721805376438493300, 0.721839980340749140, 0.721874582438405190, 0.721909182731374610, 0.721943781219571480, 0.721978377902908640, 0.722012972781299830, 0.722047565854658460, +0.722082157122898580, 0.722116746585933060, 0.722151334243675610, 0.722185920096039770, 0.722220504142939480, 0.722255086384287700, 0.722289666819998070, 0.722324245449984410, +0.722358822274160370, 0.722393397292438900, 0.722427970504734060, 0.722462541910959600, 0.722497111511028360, 0.722531679304854510, 0.722566245292351250, 0.722600809473432860, +0.722635371848012080, 0.722669932416002860, 0.722704491177318830, 0.722739048131873840, 0.722773603279580960, 0.722808156620354140, 0.722842708154106780, 0.722877257880753080, +0.722911805800205860, 0.722946351912379100, 0.722980896217186530, 0.723015438714541990, 0.723049979404358560, 0.723084518286550180, 0.723119055361030830, 0.723153590627713560, +0.723188124086512230, 0.723222655737340680, 0.723257185580112650, 0.723291713614741430, 0.723326239841140970, 0.723360764259224910, 0.723395286868907190, 0.723429807670101010, +0.723464326662720310, 0.723498843846678730, 0.723533359221890440, 0.723567872788268280, 0.723602384545726670, 0.723636894494178890, 0.723671402633539350, 0.723705908963720780, +0.723740413484637690, 0.723774916196203380, 0.723809417098332130, 0.723843916190937130, 0.723878413473932230, 0.723912908947231700, 0.723947402610748410, 0.723981894464396760, +0.724016384508090360, 0.724050872741743400, 0.724085359165268730, 0.724119843778580850, 0.724154326581593290, 0.724188807574220220, 0.724223286756374820, 0.724257764127971160, +0.724292239688923090, 0.724326713439144790, 0.724361185378549430, 0.724395655507050980, 0.724430123824563510, 0.724464590331000970, 0.724499055026276760, 0.724533517910304850, +0.724567978982999410, 0.724602438244273730, 0.724636895694041990, 0.724671351332217940, 0.724705805158715850, 0.724740257173449030, 0.724774707376331430, 0.724809155767277110, +0.724843602346200270, 0.724878047113014070, 0.724912490067632700, 0.724946931209970220, 0.724981370539940610, 0.725015808057457360, 0.725050243762434540, 0.725084677654786120, +0.725119109734426280, 0.725153540001268420, 0.725187968455226710, 0.725222395096215330, 0.725256819924147590, 0.725291242938937990, 0.725325664140500150, 0.725360083528748480, +0.725394501103596380, 0.725428916864957920, 0.725463330812747160, 0.725497742946878410, 0.725532153267265060, 0.725566561773821280, 0.725600968466461050, 0.725635373345098760, +0.725669776409647690, 0.725704177660022260, 0.725738577096136320, 0.725772974717904250, 0.725807370525239470, 0.725841764518056150, 0.725876156696268590, 0.725910547059790860, +0.725944935608536460, 0.725979322342419690, 0.726013707261354950, 0.726048090365255640, 0.726082471654036170, 0.726116851127610370, 0.726151228785892890, 0.726185604628796890, +0.726219978656237000, 0.726254350868127170, 0.726288721264381600, 0.726323089844914120, 0.726357456609638800, 0.726391821558469930, 0.726426184691321810, 0.726460546008107830, +0.726494905508742520, 0.726529263193139930, 0.726563619061214580, 0.726597973112879770, 0.726632325348050110, 0.726666675766639900, 0.726701024368562650, 0.726735371153732880, +0.726769716122064760, 0.726804059273472580, 0.726838400607869970, 0.726872740125171330, 0.726907077825290850, 0.726941413708142910, 0.726975747773641270, 0.727010080021700200, +0.727044410452233890, 0.727078739065156960, 0.727113065860382820, 0.727147390837825980, 0.727181713997400610, 0.727216035339021350, 0.727250354862601700, 0.727284672568056180, +0.727318988455299300, 0.727353302524244570, 0.727387614774806620, 0.727421925206899630, 0.727456233820438110, 0.727490540615335800, 0.727524845591506990, 0.727559148748866180, +0.727593450087327680, 0.727627749606805320, 0.727662047307213620, 0.727696343188466770, 0.727730637250479370, 0.727764929493165070, 0.727799219916438480, 0.727833508520213890, +0.727867795304405710, 0.727902080268927780, 0.727936363413694610, 0.727970644738620940, 0.728004924243620290, 0.728039201928607270, 0.728073477793496400, 0.728107751838201980, +0.728142024062637950, 0.728176294466718830, 0.728210563050359030, 0.728244829813473160, 0.728279094755974850, 0.728313357877778840, 0.728347619178799420, 0.728381878658951100, +0.728416136318148060, 0.728450392156304470, 0.728484646173334970, 0.728518898369154180, 0.728553148743675830, 0.728587397296814540, 0.728621644028484840, 0.728655888938601230, +0.728690132027077660, 0.728724373293828780, 0.728758612738769300, 0.728792850361812960, 0.728827086162874500, 0.728861320141868330, 0.728895552298709060, 0.728929782633310760, +0.728964011145587950, 0.728998237835455030, 0.729032462702826840, 0.729066685747617240, 0.729100906969740950, 0.729135126369112370, 0.729169343945646250, 0.729203559699256540, +0.729237773629857870, 0.729271985737364740, 0.729306196021692000, 0.729340404482753390, 0.729374611120463870, 0.729408815934738050, 0.729443018925489910, 0.729477220092634270, +0.729511419436085550, 0.729545616955758590, 0.729579812651567240, 0.729614006523426450, 0.729648198571250520, 0.729682388794954510, 0.729716577194452150, 0.729750763769658420, +0.729784948520487700, 0.729819131446854950, 0.729853312548674030, 0.729887491825859880, 0.729921669278327020, 0.729955844905990190, 0.729990018708763570, 0.730024190686561880, +0.730058360839299980, 0.730092529166891820, 0.730126695669252480, 0.730160860346296350, 0.730195023197938280, 0.730229184224092330, 0.730263343424673580, 0.730297500799596320, +0.730331656348775730, 0.730365810072125640, 0.730399961969561030, 0.730434112040996510, 0.730468260286347040, 0.730502406705526570, 0.730536551298450190, 0.730570694065032390, +0.730604835005188020, 0.730638974118831390, 0.730673111405877320, 0.730707246866240450, 0.730741380499835720, 0.730775512306577340, 0.730809642286380120, 0.730843770439159050, +0.730877896764828390, 0.730912021263302790, 0.730946143934497310, 0.730980264778326670, 0.731014383794705180, 0.731048500983547570, 0.731082616344768790, 0.731116729878283800, +0.731150841584006670, 0.731184951461852470, 0.731219059511735820, 0.731253165733571910, 0.731287270127274680, 0.731321372692759320, 0.731355473429940560, 0.731389572338733360, +0.731423669419051900, 0.731457764670811360, 0.731491858093926690, 0.731525949688312080, 0.731560039453882590, 0.731594127390552960, 0.731628213498238370, 0.731662297776852880, +0.731696380226311670, 0.731730460846529480, 0.731764539637421500, 0.731798616598901890, 0.731832691730885610, 0.731866765033287740, 0.731900836506023220, 0.731934906149006360, +0.731968973962152100, 0.732003039945375520, 0.732037104098591570, 0.732071166421714550, 0.732105226914659620, 0.732139285577342090, 0.732173342409675800, 0.732207397411576370, +0.732241450582958310, 0.732275501923736920, 0.732309551433826480, 0.732343599113142170, 0.732377644961598960, 0.732411688979111910, 0.732445731165595190, 0.732479771520964330, +0.732513810045133940, 0.732547846738019310, 0.732581881599534750, 0.732615914629595630, 0.732649945828116600, 0.732683975195013050, 0.732718002730199160, 0.732752028433590440, +0.732786052305101520, 0.732820074344647800, 0.732854094552143560, 0.732888112927504220, 0.732922129470644720, 0.732956144181479700, 0.732990157059924320, 0.733024168105893550, +0.733058177319302560, 0.733092184700065990, 0.733126190248098770, 0.733160193963316220, 0.733194195845633390, 0.733228195894964910, 0.733262194111225840, 0.733296190494331260, +0.733330185044196560, 0.733364177760736040, 0.733398168643865200, 0.733432157693498790, 0.733466144909552420, 0.733500130291940280, 0.733534113840577870, 0.733568095555380490, +0.733602075436262440, 0.733636053483139430, 0.733670029695926100, 0.733704004074538060, 0.733737976618889620, 0.733771947328896390, 0.733805916204473220, 0.733839883245535620, +0.733873848451997880, 0.733907811823775620, 0.733941773360783810, 0.733975733062937950, 0.734009690930152340, 0.734043646962342590, 0.734077601159423660, 0.734111553521310970, +0.734145504047919230, 0.734179452739163630, 0.734213399594959790, 0.734247344615222010, 0.734281287799865900, 0.734315229148806650, 0.734349168661959650, 0.734383106339239310, +0.734417042180561360, 0.734450976185840760, 0.734484908354992920, 0.734518838687932550, 0.734552767184575180, 0.734586693844835770, 0.734620618668629930, 0.734654541655872300, +0.734688462806478260, 0.734722382120363230, 0.734756299597442370, 0.734790215237630440, 0.734824129040843040, 0.734858041006995700, 0.734891951136002810, 0.734925859427780100, +0.734959765882242880, 0.734993670499306310, 0.735027573278885460, 0.735061474220895630, 0.735095373325251990, 0.735129270591870390, 0.735163166020665120, 0.735197059611552130, +0.735230951364446380, 0.735264841279263500, 0.735298729355918330, 0.735332615594326280, 0.735366499994402730, 0.735400382556063210, 0.735434263279222460, 0.735468142163796080, +0.735502019209699260, 0.735535894416847640, 0.735569767785156150, 0.735603639314540200, 0.735637509004915310, 0.735671376856196440, 0.735705242868299190, 0.735739107041138760, +0.735772969374630880, 0.735806829868690280, 0.735840688523232590, 0.735874545338173200, 0.735908400313427750, 0.735942253448911070, 0.735976104744538560, 0.736009954200225970, +0.736043801815888690, 0.736077647591441670, 0.736111491526800550, 0.736145333621880620, 0.736179173876597700, 0.736213012290866550, 0.736246848864602900, 0.736280683597722360, +0.736314516490139900, 0.736348347541771030, 0.736382176752531370, 0.736416004122336540, 0.736449829651101400, 0.736483653338741770, 0.736517475185172850, 0.736551295190310710, +0.736585113354069950, 0.736618929676366330, 0.736652744157115460, 0.736686556796233070, 0.736720367593633910, 0.736754176549233920, 0.736787983662948510, 0.736821788934693300, +0.736855592364383360, 0.736889393951934530, 0.736923193697262450, 0.736956991600282050, 0.736990787660909200, 0.737024581879059390, 0.737058374254648490, 0.737092164787591320, +0.737125953477803740, 0.737159740325201260, 0.737193525329699620, 0.737227308491213980, 0.737261089809660100, 0.737294869284953470, 0.737328646917009940, 0.737362422705744480, +0.737396196651073030, 0.737429968752911000, 0.737463739011174350, 0.737497507425778130, 0.737531273996638090, 0.737565038723669850, 0.737598801606789370, 0.737632562645911590, +0.737666321840952380, 0.737700079191827670, 0.737733834698452440, 0.737767588360742630, 0.737801340178613870, 0.737835090151982120, 0.737868838280762220, 0.737902584564870230, +0.737936329004221900, 0.737970071598732960, 0.738003812348318580, 0.738037551252894610, 0.738071288312376780, 0.738105023526681060, 0.738138756895722500, 0.738172488419416960, +0.738206218097680280, 0.738239945930428300, 0.738273671917576200, 0.738307396059039940, 0.738341118354735480, 0.738374838804577880, 0.738408557408483210, 0.738442274166367100, +0.738475989078145710, 0.738509702143734010, 0.738543413363047960, 0.738577122736003510, 0.738610830262516500, 0.738644535942502010, 0.738678239775876320, 0.738711941762554950, +0.738745641902454060, 0.738779340195488850, 0.738813036641575160, 0.738846731240628940, 0.738880423992566150, 0.738914114897302080, 0.738947803954752680, 0.738981491164834030, +0.739015176527461400, 0.739048860042550770, 0.739082541710018080, 0.739116221529779290, 0.739149899501749590, 0.739183575625845250, 0.739217249901981900, 0.739250922330075830, +0.739284592910042000, 0.739318261641796810, 0.739351928525255890, 0.739385593560335510, 0.739419256746950750, 0.739452918085018010, 0.739486577574452800, 0.739520235215171520, +0.739553891007089350, 0.739587544950122470, 0.739621197044187050, 0.739654847289198280, 0.739688495685072440, 0.739722142231725280, 0.739755786929073180, 0.739789429777031220, +0.739823070775515790, 0.739856709924442520, 0.739890347223727930, 0.739923982673287070, 0.739957616273036360, 0.739991248022891510, 0.740024877922768830, 0.740058505972583710, +0.740092132172252340, 0.740125756521690660, 0.740159379020814740, 0.740192999669540220, 0.740226618467783150, 0.740260235415459600, 0.740293850512485640, 0.740327463758776780, +0.740361075154249320, 0.740394684698819530, 0.740428292392402600, 0.740461898234915040, 0.740495502226272690, 0.740529104366391850, 0.740562704655188030, 0.740596303092577400, +0.740629899678476030, 0.740663494412800110, 0.740697087295465240, 0.740730678326387610, 0.740764267505483410, 0.740797854832668690, 0.740831440307859190, 0.740865023930970870, +0.740898605701920230, 0.740932185620623240, 0.740965763686995520, 0.740999339900953350, 0.741032914262413240, 0.741066486771290390, 0.741100057427501400, 0.741133626230962240, +0.741167193181589410, 0.741200758279298210, 0.741234321524005150, 0.741267882915626290, 0.741301442454078030, 0.741335000139275780, 0.741368555971136050, 0.741402109949575010, +0.741435662074508950, 0.741469212345853390, 0.741502760763524950, 0.741536307327439470, 0.741569852037513580, 0.741603394893662670, 0.741636935895803370, 0.741670475043851970, +0.741704012337724090, 0.741737547777336250, 0.741771081362604500, 0.741804613093445360, 0.741838142969774350, 0.741871670991508080, 0.741905197158562510, 0.741938721470854270, +0.741972243928298970, 0.742005764530813130, 0.742039283278312700, 0.742072800170714530, 0.742106315207933910, 0.742139828389887570, 0.742173339716491690, 0.742206849187662780, +0.742240356803316350, 0.742273862563369140, 0.742307366467737100, 0.742340868516337070, 0.742374368709084690, 0.742407867045896230, 0.742441363526688440, 0.742474858151376930, +0.742508350919878210, 0.742541841832108700, 0.742575330887984890, 0.742608818087422410, 0.742642303430337880, 0.742675786916647710, 0.742709268546268180, 0.742742748319115350, +0.742776226235105530, 0.742809702294155220, 0.742843176496180920, 0.742876648841098390, 0.742910119328824230, 0.742943587959274840, 0.742977054732366640, 0.743010519648015680, +0.743043982706138250, 0.743077443906651200, 0.743110903249470270, 0.743144360734512070, 0.743177816361693000, 0.743211270130929690, 0.743244722042137870, 0.743278172095234390, +0.743311620290135310, 0.743345066626757480, 0.743378511105016740, 0.743411953724829820, 0.743445394486112800, 0.743478833388782730, 0.743512270432755250, 0.743545705617947080, +0.743579138944274740, 0.743612570411654740, 0.743646000020003030, 0.743679427769236350, 0.743712853659271420, 0.743746277690023990, 0.743779699861410900, 0.743813120173348550, +0.743846538625753780, 0.743879955218542220, 0.743913369951630930, 0.743946782824936090, 0.743980193838374660, 0.744013602991862370, 0.744047010285316170, 0.744080415718652350, +0.744113819291787880, 0.744147221004638480, 0.744180620857121110, 0.744214018849152170, 0.744247414980648500, 0.744280809251525950, 0.744314201661701370, 0.744347592211091590, +0.744380980899612580, 0.744414367727181060, 0.744447752693713550, 0.744481135799127110, 0.744514517043337490, 0.744547896426261510, 0.744581273947815920, 0.744614649607917340, +0.744648023406481840, 0.744681395343426260, 0.744714765418667210, 0.744748133632121560, 0.744781499983705350, 0.744814864473335340, 0.744848227100928130, 0.744881587866400690, +0.744914946769668960, 0.744948303810649910, 0.744981658989260050, 0.745015012305416340, 0.745048363759034830, 0.745081713350032370, 0.745115061078325920, 0.745148406943831660, +0.745181750946466210, 0.745215093086146420, 0.745248433362789230, 0.745281771776310720, 0.745315108326627730, 0.745348443013656880, 0.745381775837315350, 0.745415106797518990, +0.745448435894184860, 0.745481763127229690, 0.745515088496570440, 0.745548412002123070, 0.745581733643804760, 0.745615053421532110, 0.745648371335222100, 0.745681687384790900, +0.745715001570155470, 0.745748313891232750, 0.745781624347939040, 0.745814932940191190, 0.745848239667906030, 0.745881544531000640, 0.745914847529391080, 0.745948148662994410, +0.745981447931727270, 0.746014745335506820, 0.746048040874249360, 0.746081334547871620, 0.746114626356290670, 0.746147916299423450, 0.746181204377186050, 0.746214490589495630, +0.746247774936269040, 0.746281057417423340, 0.746314338032874720, 0.746347616782540140, 0.746380893666336860, 0.746414168684181090, 0.746447441835989880, 0.746480713121680070, +0.746513982541168850, 0.746547250094372170, 0.746580515781207540, 0.746613779601591590, 0.746647041555441370, 0.746680301642673410, 0.746713559863204650, 0.746746816216951940, +0.746780070703832570, 0.746813323323762710, 0.746846574076659440, 0.746879822962439820, 0.746913069981020920, 0.746946315132319020, 0.746979558416251410, 0.747012799832734830, +0.747046039381686570, 0.747079277063022910, 0.747112512876661140, 0.747145746822518330, 0.747178978900510880, 0.747212209110555970, 0.747245437452570440, 0.747278663926471690, +0.747311888532176010, 0.747345111269600570, 0.747378332138662340, 0.747411551139278600, 0.747444768271365630, 0.747477983534840850, 0.747511196929621090, 0.747544408455623530, +0.747577618112764800, 0.747610825900961950, 0.747644031820131950, 0.747677235870192300, 0.747710438051059190, 0.747743638362650010, 0.747776836804882050, 0.747810033377671710, +0.747843228080936170, 0.747876420914592720, 0.747909611878558420, 0.747942800972749900, 0.747975988197084220, 0.748009173551478670, 0.748042357035850420, 0.748075538650116110, +0.748108718394192800, 0.748141896267997760, 0.748175072271448300, 0.748208246404460820, 0.748241418666952820, 0.748274589058841140, 0.748307757580043310, 0.748340924230475930, +0.748374089010056090, 0.748407251918701390, 0.748440412956328240, 0.748473572122854040, 0.748506729418195850, 0.748539884842271300, 0.748573038394996670, 0.748606190076289370, +0.748639339886066680, 0.748672487824245890, 0.748705633890743630, 0.748738778085477170, 0.748771920408363930, 0.748805060859321080, 0.748838199438265350, 0.748871336145114030, +0.748904470979784410, 0.748937603942194000, 0.748970735032259190, 0.749003864249897510, 0.749036991595026570, 0.749070117067562770, 0.749103240667423730, 0.749136362394526520, +0.749169482248788770, 0.749202600230126970, 0.749235716338458760, 0.749268830573701190, 0.749301942935771900, 0.749335053424587280, 0.749368162040065290, 0.749401268782122650, +0.749434373650677330, 0.749467476645645610, 0.749500577766945340, 0.749533677014493580, 0.749566774388207850, 0.749599869888004980, 0.749632963513802380, 0.749666055265517440, +0.749699145143067570, 0.749732233146369610, 0.749765319275341070, 0.749798403529899460, 0.749831485909961630, 0.749864566415444970, 0.749897645046266990, 0.749930721802345210, +0.749963796683596250, 0.749996869689937840, 0.750029940821287270, 0.750063010077562150, 0.750096077458679120, 0.750129142964556020, 0.750162206595110010, 0.750195268350258740, +0.750228328229919030, 0.750261386234008510, 0.750294442362444580, 0.750327496615144750, 0.750360548992025980, 0.750393599493005770, 0.750426648118001860, 0.750459694866930980, +0.750492739739710980, 0.750525782736259030, 0.750558823856492970, 0.750591863100329550, 0.750624900467686480, 0.750657935958481070, 0.750690969572631260, 0.750724001310053680, +0.750757031170666060, 0.750790059154385900, 0.750823085261130840, 0.750856109490817820, 0.750889131843364590, 0.750922152318688420, 0.750955170916707160, 0.750988187637337660, +0.751021202480497860, 0.751054215446105180, 0.751087226534076780, 0.751120235744330180, 0.751153243076783110, 0.751186248531353180, 0.751219252107957370, 0.751252253806513390, +0.751285253626938760, 0.751318251569151330, 0.751351247633067930, 0.751384241818606520, 0.751417234125684400, 0.751450224554219500, 0.751483213104128800, 0.751516199775330020, +0.751549184567740780, 0.751582167481278820, 0.751615148515861200, 0.751648127671405650, 0.751681104947829800, 0.751714080345051490, 0.751747053862987680, 0.751780025501556310, +0.751812995260675130, 0.751845963140261090, 0.751878929140232240, 0.751911893260506000, 0.751944855501000430, 0.751977815861632260, 0.752010774342319670, 0.752043730942980160, +0.752076685663531470, 0.752109638503890900, 0.752142589463976270, 0.752175538543705110, 0.752208485742995370, 0.752241431061764110, 0.752274374499929290, 0.752307316057408530, +0.752340255734119780, 0.752373193529980220, 0.752406129444907480, 0.752439063478819840, 0.752471995631634140, 0.752504925903268560, 0.752537854293640620, 0.752570780802668370, +0.752603705430268780, 0.752636628176360010, 0.752669549040859700, 0.752702468023685680, 0.752735385124755350, 0.752768300343986450, 0.752801213681296820, 0.752834125136604530, +0.752867034709826520, 0.752899942400880980, 0.752932848209685650, 0.752965752136158350, 0.752998654180216500, 0.753031554341777930, 0.753064452620760830, 0.753097349017082250, +0.753130243530660270, 0.753163136161412840, 0.753196026909257690, 0.753228915774112330, 0.753261802755894600, 0.753294687854522360, 0.753327571069913660, 0.753360452401985790, +0.753393331850656820, 0.753426209415844370, 0.753459085097466840, 0.753491958895441290, 0.753524830809685800, 0.753557700840118190, 0.753590568986656770, 0.753623435249218490, +0.753656299627721630, 0.753689162122084370, 0.753722022732223880, 0.753754881458058470, 0.753787738299505740, 0.753820593256483980, 0.753853446328910380, 0.753886297516703220, +0.753919146819780340, 0.753951994238059810, 0.753984839771459030, 0.754017683419896170, 0.754050525183289080, 0.754083365061556040, 0.754116203054614240, 0.754149039162381960, +0.754181873384777050, 0.754214705721717780, 0.754247536173121350, 0.754280364738906250, 0.754313191418990110, 0.754346016213291340, 0.754378839121727210, 0.754411660144215900, +0.754444479280675930, 0.754477296531024360, 0.754510111895179580, 0.754542925373059450, 0.754575736964582360, 0.754608546669665590, 0.754641354488227560, 0.754674160420185980, +0.754706964465459370, 0.754739766623965140, 0.754772566895621440, 0.754805365280346250, 0.754838161778057960, 0.754870956388674070, 0.754903749112112780, 0.754936539948292020, +0.754969328897130200, 0.755002115958544830, 0.755034901132454190, 0.755067684418776590, 0.755100465817429400, 0.755133245328331150, 0.755166022951399670, 0.755198798686553490, +0.755231572533710090, 0.755264344492787680, 0.755297114563704410, 0.755329882746378580, 0.755362649040727810, 0.755395413446670490, 0.755428175964124590, 0.755460936593008500, +0.755493695333239850, 0.755526452184736910, 0.755559207147417870, 0.755591960221201010, 0.755624711406004070, 0.755657460701745330, 0.755690208108343200, 0.755722953625715290, +0.755755697253780000, 0.755788438992455400, 0.755821178841660110, 0.755853916801311530, 0.755886652871328060, 0.755919387051628090, 0.755952119342129910, 0.755984849742751040, +0.756017578253410210, 0.756050304874025360, 0.756083029604515010, 0.756115752444796780, 0.756148473394789300, 0.756181192454410510, 0.756213909623579040, 0.756246624902212620, +0.756279338290229530, 0.756312049787548070, 0.756344759394086850, 0.756377467109763390, 0.756410172934496310, 0.756442876868204110, 0.756475578910804410, 0.756508279062215630, +0.756540977322356260, 0.756573673691144810, 0.756606368168498800, 0.756639060754336850, 0.756671751448577350, 0.756704440251138700, 0.756737127161938640, 0.756769812180895670, +0.756802495307928310, 0.756835176542954740, 0.756867855885893110, 0.756900533336662520, 0.756933208895179900, 0.756965882561364320, 0.756998554335134080, 0.757031224216407450, +0.757063892205102730, 0.757096558301138310, 0.757129222504433040, 0.757161884814904100, 0.757194545232470540, 0.757227203757050550, 0.757259860388562520, 0.757292515126924970, +0.757325167972055960, 0.757357818923874220, 0.757390467982298370, 0.757423115147245810, 0.757455760418635380, 0.757488403796385710, 0.757521045280414970, 0.757553684870641560, +0.757586322566983990, 0.757618958369360550, 0.757651592277690410, 0.757684224291890640, 0.757716854411880410, 0.757749482637577910, 0.757782108968901750, 0.757814733405770320, +0.757847355948102040, 0.757879976595815960, 0.757912595348829270, 0.757945212207061240, 0.757977827170430050, 0.758010440238854440, 0.758043051412252700, 0.758075660690543220, +0.758108268073644620, 0.758140873561476080, 0.758173477153954670, 0.758206078850999440, 0.758238678652529140, 0.758271276558462160, 0.758303872568717010, 0.758336466683212200, +0.758369058901866680, 0.758401649224597960, 0.758434237651325120, 0.758466824181966760, 0.758499408816441290, 0.758531991554667330, 0.758564572396563270, 0.758597151342047970, +0.758629728391040260, 0.758662303543457650, 0.758694876799219320, 0.758727448158243780, 0.758760017620449530, 0.758792585185755430, 0.758825150854079760, 0.758857714625341130, +0.758890276499458950, 0.758922836476350390, 0.758955394555934750, 0.758987950738130630, 0.759020505022856670, 0.759053057410031480, 0.759085607899573580, 0.759118156491402240, +0.759150703185434980, 0.759183247981590980, 0.759215790879788740, 0.759248331879947110, 0.759280870981984600, 0.759313408185819940, 0.759345943491371740, 0.759378476898559310, +0.759411008407300140, 0.759443538017513410, 0.759476065729117740, 0.759508591542031990, 0.759541115456174860, 0.759573637471464780, 0.759606157587820690, 0.759638675805161760, +0.759671192123405610, 0.759703706542471440, 0.759736219062277950, 0.759768729682744000, 0.759801238403788100, 0.759833745225329200, 0.759866250147286590, 0.759898753169577670, +0.759931254292121830, 0.759963753514838030, 0.759996250837644660, 0.760028746260460690, 0.760061239783204940, 0.760093731405796060, 0.760126221128153420, 0.760158708950194660, +0.760191194871839170, 0.760223678893005570, 0.760256161013612820, 0.760288641233579750, 0.760321119552825000, 0.760353595971268060, 0.760386070488826560, 0.760418543105419900, +0.760451013820966800, 0.760483482635386230, 0.760515949548596910, 0.760548414560517800, 0.760580877671067520, 0.760613338880165690, 0.760645798187730040, 0.760678255593679740, +0.760710711097933870, 0.760743164700411260, 0.760775616401030640, 0.760808066199711090, 0.760840514096371320, 0.760872960090930860, 0.760905404183307430, 0.760937846373420430, +0.760970286661188820, 0.761002725046531550, 0.761035161529367450, 0.761067596109615390, 0.761100028787194960, 0.761132459562023910, 0.761164888434021750, 0.761197315403107310, +0.761229740469199560, 0.761262163632217440, 0.761294584892080020, 0.761327004248706030, 0.761359421702015090, 0.761391837251925160, 0.761424250898355530, 0.761456662641225250, +0.761489072480453390, 0.761521480415958800, 0.761553886447660530, 0.761586290575478220, 0.761618692799329480, 0.761651093119134040, 0.761683491534810850, 0.761715888046278880, +0.761748282653457290, 0.761780675356264920, 0.761813066154620970, 0.761845455048444810, 0.761877842037654520, 0.761910227122169600, 0.761942610301909130, 0.761974991576792050, +0.762007370946737540, 0.762039748411664660, 0.762072123971492380, 0.762104497626140300, 0.762136869375526490, 0.762169239219570470, 0.762201607158191300, 0.762233973191308150, +0.762266337318840080, 0.762298699540706170, 0.762331059856826140, 0.762363418267117840, 0.762395774771501000, 0.762428129369894680, 0.762460482062218060, 0.762492832848390200, +0.762525181728330280, 0.762557528701957480, 0.762589873769191410, 0.762622216929950030, 0.762654558184153180, 0.762686897531719810, 0.762719234972569330, 0.762751570506620680, +0.762783904133793160, 0.762816235854005820, 0.762848565667178510, 0.762880893573229190, 0.762913219572077580, 0.762945543663642980, 0.762977865847844550, 0.763010186124601360, +0.763042504493832820, 0.763074820955458530, 0.763107135509396680, 0.763139448155566890, 0.763171758893888550, 0.763204067724280840, 0.763236374646662830, 0.763268679660954020, +0.763300982767073480, 0.763333283964941050, 0.763365583254474790, 0.763397880635594660, 0.763430176108219730, 0.763462469672269380, 0.763494761327662920, 0.763527051074319510, +0.763559338912159100, 0.763591624841099660, 0.763623908861061240, 0.763656190971963020, 0.763688471173724400, 0.763720749466264560, 0.763753025849502780, 0.763785300323358450, +0.763817572887751430, 0.763849843542599990, 0.763882112287823880, 0.763914379123342590, 0.763946644049075200, 0.763978907064941310, 0.764011168170860120, 0.764043427366751020, +0.764075684652533840, 0.764107940028126990, 0.764140193493450190, 0.764172445048422970, 0.764204694692964700, 0.764236942426994580, 0.764269188250432220, 0.764301432163197350, +0.764333674165208370, 0.764365914256385230, 0.764398152436647220, 0.764430388705913950, 0.764462623064104620, 0.764494855511138720, 0.764527086046935760, 0.764559314671415580, +0.764591541384496590, 0.764623766186098730, 0.764655989076141520, 0.764688210054544240, 0.764720429121226510, 0.764752646276107620, 0.764784861519107180, 0.764817074850145160, +0.764849286269139840, 0.764881495776011390, 0.764913703370679100, 0.764945909053062590, 0.764978112823081370, 0.765010314680654720, 0.765042514625702940, 0.765074712658144310, +0.765106908777898890, 0.765139102984886190, 0.765171295279025830, 0.765203485660237100, 0.765235674128439740, 0.765267860683553120, 0.765300045325497450, 0.765332228054191100, +0.765364408869554260, 0.765396587771506320, 0.765428764759966910, 0.765460939834855520, 0.765493112996091910, 0.765525284243596000, 0.765557453577286440, 0.765589620997083050, +0.765621786502905800, 0.765653950094673960, 0.765686111772307280, 0.765718271535725360, 0.765750429384847720, 0.765782585319594530, 0.765814739339884310, 0.765846891445637330, +0.765879041636773120, 0.765911189913211170, 0.765943336274871430, 0.765975480721673210, 0.766007623253536330, 0.766039763870380970, 0.766071902572125650, 0.766104039358690540, +0.766136174229995360, 0.766168307185959740, 0.766200438226503300, 0.766232567351545880, 0.766264694561007540, 0.766296819854806910, 0.766328943232864160, 0.766361064695099130, +0.766393184241431440, 0.766425301871780710, 0.766457417586066780, 0.766489531384209280, 0.766521643266128590, 0.766553753231743240, 0.766585861280973390, 0.766617967413739000, +0.766650071629959570, 0.766682173929555070, 0.766714274312445100, 0.766746372778549400, 0.766778469327788370, 0.766810563960080630, 0.766842656675346460, 0.766874747473505700, +0.766906836354477980, 0.766938923318183250, 0.766971008364541130, 0.767003091493472120, 0.767035172704894740, 0.767067251998729490, 0.767099329374896110, 0.767131404833314430, +0.767163478373904200, 0.767195549996585240, 0.767227619701277510, 0.767259687487901190, 0.767291753356375120, 0.767323817306619690, 0.767355879338554650, 0.767387939452100040, +0.767419997647175500, 0.767452053923700970, 0.767484108281596860, 0.767516160720781880, 0.767548211241176560, 0.767580259842700730, 0.767612306525274240, 0.767644351288816920, +0.767676394133248730, 0.767708435058489620, 0.767740474064460000, 0.767772511151078580, 0.767804546318265890, 0.767836579565941870, 0.767868610894026360, 0.767900640302439320, +0.767932667791100700, 0.767964693359930340, 0.767996717008848860, 0.768028738737775110, 0.768060758546629360, 0.768092776435331800, 0.768124792403802380, 0.768156806451960830, +0.768188818579727320, 0.768220828787022360, 0.768252837073764680, 0.768284843439875020, 0.768316847885273210, 0.768348850409879210, 0.768380851013613200, 0.768412849696395010, +0.768444846458144700, 0.768476841298782800, 0.768508834218228240, 0.768540825216401660, 0.768572814293222990, 0.768604801448612210, 0.768636786682489580, 0.768668769994774850, +0.768700751385388180, 0.768732730854250310, 0.768764708401279970, 0.768796684026397890, 0.768828657729524020, 0.768860629510578650, 0.768892599369481620, 0.768924567306153110, +0.768956533320513720, 0.768988497412482540, 0.769020459581979950, 0.769052419828926360, 0.769084378153241600, 0.769116334554845960, 0.769148289033659500, 0.769180241589602300, +0.769212192222595070, 0.769244140932556770, 0.769276087719408030, 0.769308032583069230, 0.769339975523460230, 0.769371916540501410, 0.769403855634112730, 0.769435792804214920, +0.769467728050727160, 0.769499661373570070, 0.769531592772663810, 0.769563522247928570, 0.769595449799284510, 0.769627375426651830, 0.769659299129950680, 0.769691220909101910, +0.769723140764024480, 0.769755058694639230, 0.769786974700866320, 0.769818888782625940, 0.769850800939838380, 0.769882711172423790, 0.769914619480302490, 0.769946525863395070, +0.769978430321620940, 0.770010332854900610, 0.770042233463154480, 0.770074132146302830, 0.770106028904265830, 0.770137923736963660, 0.770169816644317380, 0.770201707626245850, +0.770233596682670110, 0.770265483813510450, 0.770297369018686950, 0.770329252298120220, 0.770361133651730200, 0.770393013079437420, 0.770424890581162590, 0.770456766156825010, +0.770488639806345520, 0.770520511529644400, 0.770552381326642060, 0.770584249197258760, 0.770616115141414810, 0.770647979159031160, 0.770679841250026980, 0.770711701414323210, +0.770743559651840270, 0.770775415962498320, 0.770807270346217770, 0.770839122802919220, 0.770870973332522750, 0.770902821934949410, 0.770934668610118500, 0.770966513357950860, +0.770998356178366980, 0.771030197071287170, 0.771062036036631930, 0.771093873074321530, 0.771125708184276500, 0.771157541366417790, 0.771189372620664670, 0.771221201946938000, +0.771253029345158380, 0.771284854815246220, 0.771316678357121920, 0.771348499970705870, 0.771380319655919240, 0.771412137412681220, 0.771443953240912750, 0.771475767140534450, +0.771507579111466830, 0.771539389153630180, 0.771571197266945010, 0.771603003451331930, 0.771634807706711890, 0.771666610033004190, 0.771698410430130100, 0.771730208898009920, +0.771762005436564150, 0.771793800045713410, 0.771825592725378210, 0.771857383475478940, 0.771889172295936900, 0.771920959186671360, 0.771952744147603290, 0.771984527178653510, +0.772016308279742320, 0.772048087450790340, 0.772079864691718190, 0.772111640002446920, 0.772143413382896050, 0.772175184832986530, 0.772206954352639200, 0.772238721941774340, +0.772270487600312800, 0.772302251328174980, 0.772334013125281490, 0.772365772991553620, 0.772397530926910660, 0.772429286931273880, 0.772461041004563920, 0.772492793146701380, +0.772524543357606900, 0.772556291637200960, 0.772588037985404870, 0.772619782402138130, 0.772651524887322030, 0.772683265440876950, 0.772715004062723860, 0.772746740752783160, +0.772778475510975670, 0.772810208337221920, 0.772841939231443290, 0.772873668193559290, 0.772905395223491000, 0.772937120321159240, 0.772968843486484760, 0.773000564719388050, +0.773032284019790070, 0.773064001387611330, 0.773095716822773120, 0.773127430325195040, 0.773159141894798400, 0.773190851531503910, 0.773222559235232310, 0.773254265005904330, +0.773285968843440590, 0.773317670747762590, 0.773349370718789840, 0.773381068756443630, 0.773412764860644810, 0.773444459031313980, 0.773476151268372100, 0.773507841571739800, +0.773539529941337790, 0.773571216377087700, 0.773602900878908930, 0.773634583446722870, 0.773666264080450360, 0.773697942780012250, 0.773729619545329260, 0.773761294376322130, +0.773792967272911910, 0.773824638235019790, 0.773856307262565490, 0.773887974355470410, 0.773919639513655390, 0.773951302737041270, 0.773982964025549000, 0.774014623379099210, +0.774046280797613400, 0.774077936281011400, 0.774109589829214520, 0.774141241442143690, 0.774172891119719760, 0.774204538861863580, 0.774236184668496090, 0.774267828539538130, +0.774299470474911100, 0.774331110474534840, 0.774362748538330870, 0.774394384666220010, 0.774426018858123230, 0.774457651113961370, 0.774489281433655360, 0.774520909817126620, +0.774552536264295210, 0.774584160775082300, 0.774615783349409170, 0.774647403987196450, 0.774679022688365300, 0.774710639452836470, 0.774742254280531120, 0.774773867171370760, +0.774805478125275120, 0.774837087142165700, 0.774868694221963690, 0.774900299364589930, 0.774931902569965360, 0.774963503838011050, 0.774995103168647950, 0.775026700561797680, +0.775058296017380190, 0.775089889535316880, 0.775121481115528810, 0.775153070757937050, 0.775184658462462650, 0.775216244229026570, 0.775247828057550550, 0.775279409947954300, +0.775310989900159450, 0.775342567914087290, 0.775374143989658650, 0.775405718126794600, 0.775437290325416310, 0.775468860585444730, 0.775500428906801600, 0.775531995289406860, +0.775563559733182140, 0.775595122238048500, 0.775626682803926990, 0.775658241430738920, 0.775689798118405100, 0.775721352866846850, 0.775752905675985760, 0.775784456545741910, +0.775816005476036800, 0.775847552466791820, 0.775879097517927830, 0.775910640629366210, 0.775942181801027920, 0.775973721032834800, 0.776005258324706680, 0.776036793676565530, +0.776068327088332400, 0.776099858559928360, 0.776131388091274800, 0.776162915682292680, 0.776194441332903270, 0.776225965043028320, 0.776257486812587880, 0.776289006641503800, +0.776320524529697130, 0.776352040477089280, 0.776383554483601190, 0.776415066549154260, 0.776446576673670230, 0.776478084857069150, 0.776509591099272870, 0.776541095400202660, +0.776572597759779710, 0.776604098177925310, 0.776635596654560610, 0.776667093189606920, 0.776698587782986060, 0.776730080434618110, 0.776761571144425010, 0.776793059912327940, +0.776824546738248300, 0.776856031622107260, 0.776887514563826100, 0.776918995563326220, 0.776950474620529350, 0.776981951735355780, 0.777013426907727340, 0.777044900137565330, +0.777076371424791020, 0.777107840769325820, 0.777139308171091000, 0.777170773630008530, 0.777202237145998450, 0.777233698718982850, 0.777265158348883100, 0.777296616035620280, +0.777328071779116000, 0.777359525579291550, 0.777390977436068330, 0.777422427349368170, 0.777453875319111360, 0.777485321345219860, 0.777516765427615050, 0.777548207566218340, +0.777579647760951230, 0.777611086011734900, 0.777642522318490850, 0.777673956681141030, 0.777705389099605740, 0.777736819573807030, 0.777768248103666290, 0.777799674689104940, +0.777831099330044350, 0.777862522026406040, 0.777893942778111970, 0.777925361585082520, 0.777956778447239650, 0.777988193364504750, 0.778019606336799450, 0.778051017364045140, +0.778082426446163320, 0.778113833583075400, 0.778145238774703430, 0.778176642020967810, 0.778208043321790610, 0.778239442677093220, 0.778270840086797260, 0.778302235550824230, +0.778333629069095640, 0.778365020641533460, 0.778396410268058280, 0.778427797948591960, 0.778459183683056220, 0.778490567471372460, 0.778521949313462410, 0.778553329209247360, +0.778584707158649030, 0.778616083161589480, 0.778647457217989110, 0.778678829327770220, 0.778710199490854180, 0.778741567707162630, 0.778772933976617180, 0.778804298299139440, +0.778835660674650930, 0.778867021103073820, 0.778898379584328500, 0.778929736118337380, 0.778961090705021840, 0.778992443344303620, 0.779023794036104220, 0.779055142780345380, +0.779086489576949370, 0.779117834425836380, 0.779149177326928900, 0.779180518280148450, 0.779211857285416750, 0.779243194342655320, 0.779274529451785990, 0.779305862612730270, +0.779337193825410450, 0.779368523089747130, 0.779399850405662510, 0.779431175773078300, 0.779462499191916010, 0.779493820662097600, 0.779525140183544570, 0.779556457756179320, +0.779587773379922360, 0.779619087054695850, 0.779650398780421750, 0.779681708557021570, 0.779713016384417150, 0.779744322262530210, 0.779775626191282490, 0.779806928170596160, +0.779838228200392060, 0.779869526280592360, 0.779900822411118800, 0.779932116591893210, 0.779963408822837320, 0.779994699103872980, 0.780025987434921800, 0.780057273815906280, +0.780088558246746940, 0.780119840727366290, 0.780151121257685930, 0.780182399837627830, 0.780213676467113700, 0.780244951146065510, 0.780276223874405320, 0.780307494652054180, +0.780338763478934160, 0.780370030354967330, 0.780401295280075400, 0.780432558254180230, 0.780463819277203650, 0.780495078349067510, 0.780526335469694190, 0.780557590639004540, +0.780588843856920960, 0.780620095123365170, 0.780651344438259230, 0.780682591801524880, 0.780713837213084070, 0.780745080672858640, 0.780776322180771090, 0.780807561736742150, +0.780838799340694330, 0.780870034992549480, 0.780901268692229640, 0.780932500439656560, 0.780963730234752180, 0.780994958077439130, 0.781026183967638010, 0.781057407905271560, +0.781088629890261510, 0.781119849922529920, 0.781151068001998630, 0.781182284128589810, 0.781213498302225200, 0.781244710522827400, 0.781275920790317270, 0.781307129104617300, +0.781338335465649570, 0.781369539873335910, 0.781400742327598490, 0.781431942828359260, 0.781463141375540630, 0.781494337969063650, 0.781525532608850830, 0.781556725294824120, +0.781587916026905580, 0.781619104805017280, 0.781650291629081280, 0.781681476499019530, 0.781712659414754540, 0.781743840376207480, 0.781775019383300740, 0.781806196435956500, +0.781837371534096710, 0.781868544677643550, 0.781899715866518960, 0.781930885100645230, 0.781962052379944650, 0.781993217704338490, 0.782024381073749280, 0.782055542488099160, +0.782086701947310110, 0.782117859451304300, 0.782149015000003890, 0.782180168593331500, 0.782211320231208100, 0.782242469913556390, 0.782273617640298570, 0.782304763411356690, +0.782335907226652800, 0.782367049086109210, 0.782398188989648080, 0.782429326937191920, 0.782460462928662000, 0.782491596963980740, 0.782522729043070630, 0.782553859165853630, +0.782584987332252120, 0.782616113542187960, 0.782647237795583650, 0.782678360092361690, 0.782709480432443370, 0.782740598815751310, 0.782771715242207790, 0.782802829711734980, +0.782833942224255060, 0.782865052779690210, 0.782896161377963360, 0.782927268018995590, 0.782958372702709630, 0.782989475429027750, 0.783020576197872130, 0.783051675009165060, +0.783082771862828820, 0.783113866758785690, 0.783144959696958410, 0.783176050677268250, 0.783207139699637840, 0.783238226763989690, 0.783269311870245950, 0.783300395018328930, +0.783331476208160900, 0.783362555439664710, 0.783393632712761630, 0.783424708027374410, 0.783455781383425530, 0.783486852780837070, 0.783517922219531540, 0.783548989699431210, +0.783580055220458370, 0.783611118782535980, 0.783642180385585200, 0.783673240029528980, 0.783704297714289730, 0.783735353439789730, 0.783766407205951250, 0.783797459012696820, +0.783828508859948700, 0.783859556747629860, 0.783890602675661690, 0.783921646643966910, 0.783952688652468030, 0.783983728701087460, 0.784014766789747460, 0.784045802918370670, +0.784076837086879920, 0.784107869295196380, 0.784138899543243340, 0.784169927830942970, 0.784200954158217780, 0.784231978524990270, 0.784263000931182730, 0.784294021376717780, +0.784325039861518250, 0.784356056385505540, 0.784387070948602720, 0.784418083550732280, 0.784449094191816520, 0.784480102871778160, 0.784511109590539490, 0.784542114348023010, +0.784573117144151900, 0.784604117978847330, 0.784635116852032470, 0.784666113763629820, 0.784697108713561910, 0.784728101701751330, 0.784759092728120390, 0.784790081792592240, +0.784821068895088400, 0.784852054035531820, 0.784883037213845220, 0.784914018429950900, 0.784944997683771570, 0.784975974975229860, 0.785006950304248050, 0.785037923670749540, +0.785068895074655600, 0.785099864515889420, 0.785130831994373610, 0.785161797510030680, 0.785192761062783350, 0.785223722652554020, 0.785254682279265980, 0.785285639942840620, +0.785316595643201330, 0.785347549380270400, 0.785378501153970570, 0.785409450964224540, 0.785440398810954950, 0.785471344694084310, 0.785502288613535880, 0.785533230569231080, +0.785564170561093290, 0.785595108589045130, 0.785626044653009110, 0.785656978752907960, 0.785687910888664410, 0.785718841060201070, 0.785749769267441220, 0.785780695510306380, +0.785811619788719720, 0.785842542102604070, 0.785873462451882050, 0.785904380836476400, 0.785935297256309840, 0.785966211711305540, 0.785997124201385120, 0.786028034726471980, +0.786058943286488620, 0.786089849881357990, 0.786120754511002830, 0.786151657175345630, 0.786182557874309350, 0.786213456607817160, 0.786244353375790910, 0.786275248178153750, +0.786306141014828320, 0.786337031885737670, 0.786367920790804420, 0.786398807729951410, 0.786429692703101260, 0.786460575710177580, 0.786491456751101770, 0.786522335825797450, +0.786553212934187230, 0.786584088076193950, 0.786614961251740460, 0.786645832460749590, 0.786676701703144630, 0.786707568978847420, 0.786738434287781230, 0.786769297629869020, +0.786800159005033640, 0.786831018413197690, 0.786861875854284350, 0.786892731328216240, 0.786923584834916870, 0.786954436374307950, 0.786985285946313010, 0.787016133550854760, +0.787046979187856270, 0.787077822857240260, 0.787108664558929690, 0.787139504292848070, 0.787170342058917120, 0.787201177857060340, 0.787232011687200580, 0.787262843549260790, +0.787293673443163920, 0.787324501368832810, 0.787355327326190510, 0.787386151315160430, 0.787416973335664410, 0.787447793387625940, 0.787478611470967980, 0.787509427585613490, +0.787540241731485510, 0.787571053908506900, 0.787601864116600600, 0.787632672355690230, 0.787663478625697520, 0.787694282926546310, 0.787725085258159210, 0.787755885620459510, +0.787786684013370040, 0.787817480436813990, 0.787848274890714630, 0.787879067374994020, 0.787909857889575900, 0.787940646434383000, 0.787971433009338580, 0.788002217614365510, +0.788033000249386940, 0.788063780914325830, 0.788094559609105790, 0.788125336333648900, 0.788156111087878640, 0.788186883871717980, 0.788217654685090310, 0.788248423527918350, +0.788279190400125400, 0.788309955301634950, 0.788340718232369180, 0.788371479192251590, 0.788402238181205250, 0.788432995199153330, 0.788463750246018890, 0.788494503321725100, +0.788525254426195030, 0.788556003559352400, 0.788586750721119280, 0.788617495911419280, 0.788648239130175450, 0.788678980377310990, 0.788709719652749160, 0.788740456956413040, +0.788771192288225790, 0.788801925648111020, 0.788832657035990930, 0.788863386451789220, 0.788894113895429070, 0.788924839366833550, 0.788955562865925940, 0.788986284392629520, +0.789017003946867910, 0.789047721528563170, 0.789078437137639140, 0.789109150774019110, 0.789139862437626130, 0.789170572128383490, 0.789201279846214470, 0.789231985591042130, +0.789262689362790540, 0.789293391161381530, 0.789324090986739170, 0.789354788838786510, 0.789385484717446850, 0.789416178622643570, 0.789446870554299740, 0.789477560512338860, +0.789508248496684550, 0.789538934507259090, 0.789569618543986220, 0.789600300606789430, 0.789630980695591790, 0.789661658810316690, 0.789692334950887530, 0.789723009117228040, +0.789753681309260490, 0.789784351526908730, 0.789815019770096050, 0.789845686038745830, 0.789876350332781470, 0.789907012652126150, 0.789937672996703370, 0.789968331366436960, +0.789998987761249110, 0.790029642181063750, 0.790060294625804400, 0.790090945095394240, 0.790121593589756750, 0.790152240108815240, 0.790182884652493760, 0.790213527220714470, +0.790244167813401340, 0.790274806430477870, 0.790305443071867230, 0.790336077737493150, 0.790366710427278800, 0.790397341141147680, 0.790427969879023750, 0.790458596640829290, +0.790489221426488480, 0.790519844235924470, 0.790550465069060900, 0.790581083925821270, 0.790611700806128860, 0.790642315709907170, 0.790672928637080160, 0.790703539587570450, +0.790734148561301750, 0.790764755558197810, 0.790795360578181890, 0.790825963621177630, 0.790856564687108410, 0.790887163775898290, 0.790917760887469790, 0.790948356021746850, +0.790978949178653080, 0.791009540358111880, 0.791040129560046880, 0.791070716784381460, 0.791101302031039340, 0.791131885299944490, 0.791162466591019410, 0.791193045904188040, +0.791223623239374120, 0.791254198596501150, 0.791284771975492740, 0.791315343376272410, 0.791345912798763650, 0.791376480242890650, 0.791407045708575900, 0.791437609195743570, +0.791468170704317190, 0.791498730234220460, 0.791529287785376790, 0.791559843357710010, 0.791590396951144080, 0.791620948565601610, 0.791651498201006890, 0.791682045857283300, +0.791712591534354690, 0.791743135232144570, 0.791773676950576540, 0.791804216689574350, 0.791834754449062260, 0.791865290228962570, 0.791895824029199780, 0.791926355849697390, +0.791956885690379140, 0.791987413551168640, 0.792017939431989610, 0.792048463332766350, 0.792078985253421350, 0.792109505193878790, 0.792140023154062510, 0.792170539133896230, +0.792201053133303580, 0.792231565152208270, 0.792262075190534150, 0.792292583248205280, 0.792323089325144390, 0.792353593421275870, 0.792384095536523340, 0.792414595670810520, +0.792445093824061250, 0.792475589996199270, 0.792506084187148300, 0.792536576396832610, 0.792567066625174950, 0.792597554872099600, 0.792628041137530490, 0.792658525421391150, +0.792689007723605620, 0.792719488044097420, 0.792749966382791160, 0.792780442739609460, 0.792810917114476490, 0.792841389507316420, 0.792871859918052760, 0.792902328346609450, +0.792932794792910340, 0.792963259256879270, 0.792993721738440630, 0.793024182237517030, 0.793054640754033090, 0.793085097287912430, 0.793115551839079110, 0.793146004407456860, +0.793176454992969630, 0.793206903595541360, 0.793237350215096230, 0.793267794851557180, 0.793298237504848740, 0.793328678174894610, 0.793359116861618860, 0.793389553564945340, +0.793419988284797870, 0.793450421021100970, 0.793480851773777470, 0.793511280542751880, 0.793541707327948150, 0.793572132129290010, 0.793602554946701620, 0.793632975780106830, +0.793663394629429590, 0.793693811494594500, 0.793724226375524200, 0.793754639272143400, 0.793785050184376060, 0.793815459112146020, 0.793845866055377320, 0.793876271013993940, +0.793906673987920470, 0.793937074977079770, 0.793967473981396440, 0.793997871000794330, 0.794028266035197610, 0.794058659084530220, 0.794089050148716110, 0.794119439227679360, +0.794149826321344680, 0.794180211429634800, 0.794210594552474450, 0.794240975689787580, 0.794271354841498240, 0.794301732007530630, 0.794332107187808560, 0.794362480382256320, +0.794392851590798310, 0.794423220813357700, 0.794453588049858990, 0.794483953300226360, 0.794514316564383870, 0.794544677842255580, 0.794575037133765540, 0.794605394438838490, +0.794635749757397480, 0.794666103089366920, 0.794696454434671300, 0.794726803793234460, 0.794757151164980580, 0.794787496549833830, 0.794817839947718370, 0.794848181358558840, +0.794878520782278280, 0.794908858218801420, 0.794939193668052440, 0.794969527129955500, 0.794999858604434670, 0.795030188091414350, 0.795060515590818360, 0.795090841102571780, +0.795121164626597430, 0.795151486162820280, 0.795181805711164370, 0.795212123271553880, 0.795242438843913210, 0.795272752428166420, 0.795303064024238230, 0.795333373632051810, +0.795363681251532010, 0.795393986882602990, 0.795424290525189040, 0.795454592179214330, 0.795484891844603140, 0.795515189521279750, 0.795545485209168900, 0.795575778908193860, +0.795606070618279260, 0.795636360339349590, 0.795666648071328920, 0.795696933814141750, 0.795727217567712140, 0.795757499331965050, 0.795787779106823740, 0.795818056892212860, +0.795848332688056990, 0.795878606494280110, 0.795908878310806810, 0.795939148137561390, 0.795969415974468020, 0.795999681821451640, 0.796029945678435550, 0.796060207545344570, +0.796090467422103100, 0.796120725308635420, 0.796150981204865940, 0.796181235110719030, 0.796211487026118990, 0.796241736950990760, 0.796271984885257740, 0.796302230828844660, +0.796332474781676130, 0.796362716743676310, 0.796392956714769730, 0.796423194694880760, 0.796453430683934260, 0.796483664681853720, 0.796513896688564090, 0.796544126703989660, +0.796574354728054820, 0.796604580760684190, 0.796634804801802150, 0.796665026851333000, 0.796695246909201900, 0.796725464975332030, 0.796755681049648670, 0.796785895132075980, +0.796816107222538590, 0.796846317320960900, 0.796876525427267390, 0.796906731541382700, 0.796936935663231650, 0.796967137792737650, 0.796997337929825860, 0.797027536074420780, +0.797057732226446820, 0.797087926385828480, 0.797118118552490370, 0.797148308726357560, 0.797178496907353320, 0.797208683095402940, 0.797238867290430810, 0.797269049492361550, +0.797299229701119660, 0.797329407916629650, 0.797359584138816140, 0.797389758367604170, 0.797419930602917380, 0.797450100844680600, 0.797480269092818660, 0.797510435347256070, +0.797540599607917340, 0.797570761874727200, 0.797600922147610580, 0.797631080426491220, 0.797661236711294070, 0.797691391001943860, 0.797721543298365200, 0.797751693600482700, +0.797781841908220880, 0.797811988221504450, 0.797842132540258710, 0.797872274864407040, 0.797902415193874610, 0.797932553528586270, 0.797962689868466410, 0.797992824213439980, +0.798022956563431360, 0.798053086918365410, 0.798083215278167280, 0.798113341642760600, 0.798143466012070530, 0.798173588386021820, 0.798203708764539050, 0.798233827147547090, +0.798263943534970540, 0.798294057926734690, 0.798324170322763150, 0.798354280722981200, 0.798384389127313470, 0.798414495535684890, 0.798444599948019970, 0.798474702364243560, +0.798504802784280490, 0.798534901208055810, 0.798564997635493490, 0.798595092066518570, 0.798625184501055910, 0.798655274939030320, 0.798685363380366550, 0.798715449824989430, +0.798745534272824130, 0.798775616723794490, 0.798805697177825790, 0.798835775634842870, 0.798865852094770570, 0.798895926557533500, 0.798925999023056720, 0.798956069491264960, +0.798986137962083510, 0.799016204435436190, 0.799046268911248300, 0.799076331389444890, 0.799106391869950580, 0.799136450352690210, 0.799166506837588830, 0.799196561324571060, +0.799226613813562530, 0.799256664304486830, 0.799286712797269590, 0.799316759291835540, 0.799346803788109520, 0.799376846286016460, 0.799406886785481440, 0.799436925286429620, +0.799466961788785070, 0.799496996292472950, 0.799527028797418440, 0.799557059303546370, 0.799587087810781580, 0.799617114319049140, 0.799647138828273870, 0.799677161338381290, +0.799707181849295350, 0.799737200360941420, 0.799767216873244480, 0.799797231386129460, 0.799827243899521310, 0.799857254413345210, 0.799887262927525880, 0.799917269441988930, +0.799947273956658320, 0.799977276471459440, 0.800007276986317350, 0.800037275501157220, 0.800067272015903770, 0.800097266530482190, 0.800127259044817960, 0.800157249558835160, +0.800187238072459060, 0.800217224585614950, 0.800247209098227770, 0.800277191610222590, 0.800307172121524470, 0.800337150632058240, 0.800367127141749850, 0.800397101650523020, +0.800427074158303500, 0.800457044665016220, 0.800487013170586350, 0.800516979674939070, 0.800546944177999210, 0.800576906679692500, 0.800606867179943120, 0.800636825678676440, +0.800666782175817770, 0.800696736671292040, 0.800726689165024650, 0.800756639656940440, 0.800786588146964570, 0.800816534635022890, 0.800846479121039230, 0.800876421604939440, +0.800906362086648560, 0.800936300566091770, 0.800966237043194250, 0.800996171517881160, 0.801026103990077680, 0.801056034459709410, 0.801085962926700420, 0.801115889390976670, +0.801145813852463200, 0.801175736311085070, 0.801205656766767690, 0.801235575219436220, 0.801265491669016280, 0.801295406115432040, 0.801325318558609330, 0.801355228998473330, +0.801385137434949210, 0.801415043867962360, 0.801444948297437840, 0.801474850723300940, 0.801504751145477370, 0.801534649563891530, 0.801564545978468930, 0.801594440389135080, +0.801624332795815020, 0.801654223198434270, 0.801684111596917880, 0.801713997991191140, 0.801743882381180110, 0.801773764766808730, 0.801803645148002950, 0.801833523524688060, +0.801863399896789340, 0.801893274264232180, 0.801923146626941750, 0.801953016984844000, 0.801982885337863220, 0.802012751685925230, 0.802042616028955440, 0.802072478366878890, +0.802102338699621330, 0.802132197027107920, 0.802162053349263940, 0.802191907666015340, 0.802221759977286510, 0.802251610283003290, 0.802281458583090970, 0.802311304877475040, +0.802341149166080900, 0.802370991448833840, 0.802400831725659790, 0.802430669996483160, 0.802460506261229890, 0.802490340519825260, 0.802520172772194900, 0.802550003018264070, +0.802579831257958180, 0.802609657491202830, 0.802639481717923760, 0.802669303938045480, 0.802699124151493910, 0.802728942358194590, 0.802758758558072880, 0.802788572751054310, +0.802818384937064260, 0.802848195116028340, 0.802878003287872400, 0.802907809452520830, 0.802937613609899900, 0.802967415759934800, 0.802997215902551240, 0.803027014037674620, +0.803056810165230450, 0.803086604285144890, 0.803116396397342220, 0.803146186501748520, 0.803175974598289380, 0.803205760686890200, 0.803235544767476830, 0.803265326839974430, +0.803295106904308830, 0.803324884960405880, 0.803354661008190310, 0.803384435047587940, 0.803414207078524620, 0.803443977100925630, 0.803473745114716810, 0.803503511119823650, +0.803533275116171670, 0.803563037103687040, 0.803592797082294250, 0.803622555051919480, 0.803652311012488350, 0.803682064963926470, 0.803711816906159450, 0.803741566839112800, +0.803771314762712800, 0.803801060676883950, 0.803830804581552540, 0.803860546476644070, 0.803890286362084150, 0.803920024237798620, 0.803949760103713000, 0.803979493959752990, +0.804009225805844770, 0.804038955641912860, 0.804068683467883740, 0.804098409283682810, 0.804128133089235810, 0.804157854884468560, 0.804187574669306680, 0.804217292443676350, +0.804247008207502280, 0.804276721960710650, 0.804306433703227300, 0.804336143434977830, 0.804365851155887880, 0.804395556865883490, 0.804425260564890050, 0.804454962252834080, +0.804484661929640190, 0.804514359595234650, 0.804544055249543090, 0.804573748892491560, 0.804603440524005560, 0.804633130144010940, 0.804662817752433530, 0.804692503349199620, +0.804722186934233920, 0.804751868507462720, 0.804781548068811860, 0.804811225618207170, 0.804840901155574380, 0.804870574680839330, 0.804900246193928410, 0.804929915694766350, +0.804959583183279430, 0.804989248659393590, 0.805018912123034670, 0.805048573574128400, 0.805078233012600840, 0.805107890438377490, 0.805137545851385080, 0.805167199251548230, +0.805196850638793430, 0.805226500013046410, 0.805256147374233230, 0.805285792722279630, 0.805315436057111640, 0.805345077378654910, 0.805374716686836130, 0.805404353981580060, +0.805433989262812950, 0.805463622530461000, 0.805493253784449910, 0.805522883024705760, 0.805552510251154370, 0.805582135463722260, 0.805611758662334250, 0.805641379846916860, +0.805670999017396030, 0.805700616173697700, 0.805730231315747720, 0.805759844443472260, 0.805789455556797260, 0.805819064655649010, 0.805848671739952670, 0.805878276809634640, +0.805907879864620870, 0.805937480904837410, 0.805967079930210330, 0.805996676940665460, 0.806026271936129410, 0.806055864916527250, 0.806085455881785370, 0.806115044831829830, +0.806144631766586680, 0.806174216685981990, 0.806203799589941710, 0.806233380478391990, 0.806262959351259360, 0.806292536208468750, 0.806322111049946780, 0.806351683875619510, +0.806381254685413110, 0.806410823479253640, 0.806440390257066930, 0.806469955018779380, 0.806499517764317500, 0.806529078493606110, 0.806558637206572170, 0.806588193903141630, +0.806617748583240530, 0.806647301246795180, 0.806676851893731510, 0.806706400523976240, 0.806735947137454450, 0.806765491734092730, 0.806795034313817380, 0.806824574876554350, +0.806854113422230010, 0.806883649950770220, 0.806913184462101470, 0.806942716956150160, 0.806972247432841570, 0.807001775892102420, 0.807031302333858780, 0.807060826758036810, +0.807090349164562900, 0.807119869553363120, 0.807149387924364080, 0.807178904277491170, 0.807208418612670900, 0.807237930929829650, 0.807267441228893490, 0.807296949509788810, +0.807326455772441660, 0.807355960016778450, 0.807385462242725890, 0.807414962450209160, 0.807444460639154980, 0.807473956809489630, 0.807503450961139400, 0.807532943094030560, +0.807562433208089290, 0.807591921303241980, 0.807621407379415460, 0.807650891436534900, 0.807680373474527040, 0.807709853493318250, 0.807739331492834830, 0.807768807473003060, +0.807798281433749320, 0.807827753375000350, 0.807857223296681530, 0.807886691198719700, 0.807916157081041030, 0.807945620943572030, 0.807975082786238970, 0.808004542608968150, +0.808034000411686050, 0.808063456194319410, 0.808092909956793730, 0.808122361699035620, 0.808151811420971700, 0.808181259122528140, 0.808210704803631550, 0.808240148464208110, +0.808269590104184420, 0.808299029723487220, 0.808328467322041890, 0.808357902899775380, 0.808387336456614200, 0.808416767992484630, 0.808446197507313170, 0.808475625001026100, +0.808505050473550590, 0.808534473924811930, 0.808563895354737050, 0.808593314763252470, 0.808622732150284570, 0.808652147515759870, 0.808681560859604850, 0.808710972181745810, +0.808740381482109920, 0.808769788760622550, 0.808799194017210790, 0.808828597251800900, 0.808857998464319610, 0.808887397654693310, 0.808916794822848510, 0.808946189968712260, +0.808975583092209960, 0.809004974193268780, 0.809034363271815100, 0.809063750327775550, 0.809093135361076520, 0.809122518371644730, 0.809151899359406680, 0.809181278324289430, +0.809210655266218380, 0.809240030185120700, 0.809269403080922990, 0.809298773953551760, 0.809328142802933530, 0.809357509628995000, 0.809386874431662800, 0.809416237210863750, +0.809445597966523710, 0.809474956698569610, 0.809504313406928190, 0.809533668091525940, 0.809563020752289480, 0.809592371389145530, 0.809621720002021150, 0.809651066590841960, +0.809680411155535130, 0.809709753696027160, 0.809739094212244880, 0.809768432704114920, 0.809797769171563870, 0.809827103614518260, 0.809856436032905580, 0.809885766426651220, +0.809915094795682470, 0.809944421139925930, 0.809973745459308340, 0.810003067753756410, 0.810032388023196770, 0.810061706267556250, 0.810091022486761900, 0.810120336680739570, +0.810149648849416320, 0.810178958992718970, 0.810208267110574140, 0.810237573202908790, 0.810266877269649410, 0.810296179310723400, 0.810325479326056360, 0.810354777315575700, +0.810384073279208030, 0.810413367216880290, 0.810442659128519090, 0.810471949014051170, 0.810501236873403360, 0.810530522706503050, 0.810559806513275970, 0.810589088293649280, +0.810618368047549830, 0.810647645774904560, 0.810676921475640190, 0.810706195149683450, 0.810735466796961730, 0.810764736417400880, 0.810794004010928160, 0.810823269577470420, +0.810852533116954490, 0.810881794629307320, 0.810911054114455520, 0.810940311572326160, 0.810969567002846610, 0.810998820405942510, 0.811028071781541460, 0.811057321129570190, +0.811086568449955530, 0.811115813742624650, 0.811145057007504060, 0.811174298244520920, 0.811203537453602520, 0.811232774634674690, 0.811262009787664940, 0.811291242912500320, +0.811320474009107450, 0.811349703077413390, 0.811378930117345190, 0.811408155128830020, 0.811437378111794060, 0.811466599066164700, 0.811495817991868760, 0.811525034888833210, +0.811554249756985200, 0.811583462596251470, 0.811612673406559180, 0.811641882187835620, 0.811671088940006950, 0.811700293663000450, 0.811729496356743300, 0.811758697021162320, +0.811787895656184700, 0.811817092261737260, 0.811846286837747180, 0.811875479384141840, 0.811904669900847310, 0.811933858387791090, 0.811963044844900230, 0.811992229272101680, +0.812021411669322620, 0.812050592036489990, 0.812079770373531520, 0.812108946680373030, 0.812138120956942160, 0.812167293203166050, 0.812196463418971560, 0.812225631604286070, +0.812254797759036420, 0.812283961883149770, 0.812313123976553750, 0.812342284039174410, 0.812371442070939360, 0.812400598071775780, 0.812429752041610610, 0.812458903980371130, +0.812488053887984290, 0.812517201764377920, 0.812546347609477970, 0.812575491423212170, 0.812604633205507690, 0.812633772956291580, 0.812662910675491010, 0.812692046363033270, +0.812721180018845300, 0.812750311642854940, 0.812779441234988350, 0.812808568795173050, 0.812837694323336410, 0.812866817819405510, 0.812895939283307500, 0.812925058714969670, +0.812954176114319300, 0.812983291481283900, 0.813012404815789740, 0.813041516117764650, 0.813070625387135700, 0.813099732623830170, 0.813128837827775450, 0.813157940998898490, +0.813187042137127230, 0.813216141242387950, 0.813245238314608150, 0.813274333353715350, 0.813303426359636710, 0.813332517332299500, 0.813361606271631010, 0.813390693177558520, +0.813419778050009760, 0.813448860888911000, 0.813477941694190190, 0.813507020465774500, 0.813536097203591210, 0.813565171907567720, 0.813594244577631300, 0.813623315213709230, +0.813652383815729460, 0.813681450383618170, 0.813710514917303280, 0.813739577416712100, 0.813768637881771890, 0.813797696312410170, 0.813826752708554200, 0.813855807070131940, +0.813884859397069560, 0.813913909689295000, 0.813942957946735660, 0.813972004169319030, 0.814001048356972290, 0.814030090509623050, 0.814059130627198480, 0.814088168709626640, +0.814117204756833800, 0.814146238768748030, 0.814175270745296610, 0.814204300686407030, 0.814233328592006700, 0.814262354462023110, 0.814291378296384090, 0.814320400095016050, +0.814349419857847150, 0.814378437584804550, 0.814407453275815870, 0.814436466930808620, 0.814465478549710300, 0.814494488132448180, 0.814523495678950330, 0.814552501189143240, +0.814581504662954870, 0.814610506100312830, 0.814639505501144500, 0.814668502865377290, 0.814697498192938910, 0.814726491483756870, 0.814755482737759000, 0.814784471954871910, +0.814813459135023680, 0.814842444278141790, 0.814871427384153860, 0.814900408452987280, 0.814929387484569670, 0.814958364478829190, 0.814987339435692240, 0.815016312355086870, +0.815045283236940810, 0.815074252081181560, 0.815103218887736620, 0.815132183656533620, 0.815161146387500150, 0.815190107080564390, 0.815219065735652840, 0.815248022352693560, +0.815276976931614270, 0.815305929472342590, 0.815334879974806030, 0.815363828438932290, 0.815392774864649450, 0.815421719251884220, 0.815450661600564670, 0.815479601910618520, +0.815508540181973270, 0.815537476414556650, 0.815566410608296490, 0.815595342763120180, 0.815624272878956110, 0.815653200955730790, 0.815682126993372390, 0.815711050991808740, +0.815739972950967560, 0.815768892870776360, 0.815797810751162870, 0.815826726592054910, 0.815855640393380650, 0.815884552155066830, 0.815913461877041610, 0.815942369559232720, +0.815971275201567870, 0.816000178803974800, 0.816029080366381330, 0.816057979888715760, 0.816086877370904570, 0.816115772812876280, 0.816144666214558610, 0.816173557575879170, +0.816202446896765910, 0.816231334177146440, 0.816260219416948710, 0.816289102616100990, 0.816317983774529910, 0.816346862892163850, 0.816375739968930760, 0.816404615004758250, +0.816433487999574160, 0.816462358953306320, 0.816491227865882680, 0.816520094737231420, 0.816548959567279460, 0.816577822355955110, 0.816606683103186180, 0.816635541808900520, +0.816664398473026080, 0.816693253095490570, 0.816722105676222500, 0.816750956215148590, 0.816779804712197350, 0.816808651167296510, 0.816837495580374110, 0.816866337951357990, +0.816895178280175990, 0.816924016566756060, 0.816952852811026590, 0.816981687012914510, 0.817010519172348130, 0.817039349289255480, 0.817068177363564520, 0.817097003395203080, +0.817125827384099110, 0.817154649330181120, 0.817183469233375930, 0.817212287093612160, 0.817241102910817640, 0.817269916684920330, 0.817298728415848270, 0.817327538103529430, +0.817356345747891620, 0.817385151348863470, 0.817413954906372030, 0.817442756420345700, 0.817471555890712410, 0.817500353317400230, 0.817529148700337220, 0.817557942039451310, +0.817586733334670580, 0.817615522585923520, 0.817644309793137070, 0.817673094956239850, 0.817701878075159930, 0.817730659149825350, 0.817759438180164170, 0.817788215166104230, +0.817816990107574360, 0.817845763004501510, 0.817874533856814300, 0.817903302664440670, 0.817932069427308780, 0.817960834145346700, 0.817989596818482600, 0.818018357446644530, +0.818047116029760990, 0.818075872567759270, 0.818104627060567750, 0.818133379508114710, 0.818162129910328220, 0.818190878267136430, 0.818219624578467420, 0.818248368844249340, +0.818277111064410920, 0.818305851238879110, 0.818334589367582740, 0.818363325450449870, 0.818392059487408670, 0.818420791478387310, 0.818449521423314060, 0.818478249322117430, +0.818506975174724700, 0.818535698981064490, 0.818564420741065170, 0.818593140454654590, 0.818621858121761360, 0.818650573742313310, 0.818679287316238960, 0.818707998843466900, +0.818736708323924200, 0.818765415757539810, 0.818794121144241880, 0.818822824483958710, 0.818851525776618460, 0.818880225022149300, 0.818908922220480170, 0.818937617371538140, +0.818966310475252150, 0.818995001531550360, 0.819023690540361060, 0.819052377501612640, 0.819081062415233150, 0.819109745281150990, 0.819138426099294990, 0.819167104869592540, +0.819195781591972150, 0.819224456266362420, 0.819253128892691530, 0.819281799470887860, 0.819310468000879590, 0.819339134482595210, 0.819367798915963560, 0.819396461300911820, +0.819425121637368910, 0.819453779925263250, 0.819482436164523100, 0.819511090355076850, 0.819539742496852910, 0.819568392589780200, 0.819597040633785910, 0.819625686628798980, +0.819654330574747900, 0.819682972471560970, 0.819711612319166670, 0.819740250117493300, 0.819768885866469230, 0.819797519566023540, 0.819826151216083490, 0.819854780816578140, +0.819883408367435780, 0.819912033868584910, 0.819940657319953910, 0.819969278721471300, 0.819997898073065560, 0.820026515374665530, 0.820055130626198720, 0.820083743827594080, +0.820112354978779990, 0.820140964079685180, 0.820169571130237810, 0.820198176130366610, 0.820226779080000410, 0.820255379979066830, 0.820283978827494710, 0.820312575625212760, +0.820341170372149260, 0.820369763068232840, 0.820398353713392090, 0.820426942307555420, 0.820455528850651870, 0.820484113342609070, 0.820512695783355840, 0.820541276172821020, +0.820569854510933010, 0.820598430797620290, 0.820627005032811500, 0.820655577216435670, 0.820684147348420430, 0.820712715428694840, 0.820741281457187500, 0.820769845433826920, +0.820798407358541700, 0.820826967231260470, 0.820855525051911840, 0.820884080820424860, 0.820912634536727250, 0.820941186200747960, 0.820969735812415720, 0.820998283371659250, +0.821026828878406940, 0.821055372332587630, 0.821083913734129920, 0.821112453082962880, 0.821140990379014220, 0.821169525622213130, 0.821198058812488090, 0.821226589949768050, +0.821255119033981410, 0.821283646065057100, 0.821312171042924090, 0.821340693967510190, 0.821369214838744480, 0.821397733656555770, 0.821426250420872810, 0.821454765131624190, +0.821483277788738640, 0.821511788392144780, 0.821540296941772110, 0.821568803437548120, 0.821597307879402110, 0.821625810267262890, 0.821654310601059200, 0.821682808880719650, +0.821711305106173070, 0.821739799277348190, 0.821768291394174400, 0.821796781456579310, 0.821825269464492300, 0.821853755417842110, 0.821882239316557570, 0.821910721160567400, +0.821939200949800440, 0.821967678684185970, 0.821996154363651810, 0.822024627988127250, 0.822053099557541130, 0.822081569071822280, 0.822110036530899420, 0.822138501934701500, +0.822166965283157470, 0.822195426576196380, 0.822223885813746280, 0.822252342995736460, 0.822280798122095760, 0.822309251192753000, 0.822337702207637240, 0.822366151166677220, +0.822394598069802200, 0.822423042916940240, 0.822451485708020740, 0.822479926442972520, 0.822508365121724430, 0.822536801744205400, 0.822565236310344390, 0.822593668820070350, +0.822622099273312650, 0.822650527669999130, 0.822678954010059300, 0.822707378293422000, 0.822735800520016380, 0.822764220689771290, 0.822792638802615550, 0.822821054858478230, +0.822849468857288820, 0.822877880798975280, 0.822906290683466880, 0.822934698510692900, 0.822963104280582060, 0.822991507993063530, 0.823019909648066260, 0.823048309245519640, +0.823076706785351830, 0.823105102267492230, 0.823133495691869780, 0.823161887058413640, 0.823190276367052890, 0.823218663617716340, 0.823247048810333170, 0.823275431944832880, +0.823303813021143420, 0.823332192039194500, 0.823360568998915190, 0.823388943900234320, 0.823417316743081160, 0.823445687527384670, 0.823474056253074460, 0.823502422920078690, +0.823530787528326760, 0.823559150077747940, 0.823587510568271170, 0.823615868999825640, 0.823644225372340500, 0.823672579685744810, 0.823700931939968070, 0.823729282134938570, +0.823757630270585790, 0.823785976346839030, 0.823814320363627340, 0.823842662320879770, 0.823871002218525610, 0.823899340056493900, 0.823927675834714270, 0.823956009553115100, +0.823984341211625780, 0.824012670810175710, 0.824040998348693930, 0.824069323827109620, 0.824097647245352060, 0.824125968603350860, 0.824154287901034180, 0.824182605138331860, +0.824210920315172960, 0.824239233431486750, 0.824267544487202520, 0.824295853482249430, 0.824324160416556650, 0.824352465290054020, 0.824380768102669690, 0.824409068854333520, +0.824437367544974650, 0.824465664174522270, 0.824493958742905870, 0.824522251250054410, 0.824550541695897480, 0.824578830080364590, 0.824607116403384130, 0.824635400664885940, +0.824663682864799190, 0.824691963003053250, 0.824720241079577420, 0.824748517094300970, 0.824776791047153850, 0.824805062938064100, 0.824833332766961690, 0.824861600533776000, +0.824889866238436300, 0.824918129880871990, 0.824946391461012340, 0.824974650978786640, 0.825002908434124830, 0.825031163826955290, 0.825059417157207760, 0.825087668424811850, +0.825115917629696600, 0.825144164771791640, 0.825172409851026250, 0.825200652867330350, 0.825228893820632250, 0.825257132710861980, 0.825285369537948840, 0.825313604301822320, +0.825341837002411820, 0.825370067639646710, 0.825398296213456390, 0.825426522723770820, 0.825454747170518480, 0.825482969553629210, 0.825511189873032620, 0.825539408128658000, +0.825567624320434850, 0.825595838448292650, 0.825624050512160810, 0.825652260511969490, 0.825680468447646860, 0.825708674319123090, 0.825736878126327680, 0.825765079869190120, +0.825793279547639810, 0.825821477161606250, 0.825849672711019500, 0.825877866195808160, 0.825906057615902080, 0.825934246971230860, 0.825962434261724110, 0.825990619487311120, +0.826018802647921710, 0.826046983743485290, 0.826075162773931890, 0.826103339739190030, 0.826131514639189880, 0.826159687473860930, 0.826187858243132790, 0.826216026946934860, +0.826244193585196960, 0.826272358157848610, 0.826300520664819850, 0.826328681106039300, 0.826356839481437010, 0.826384995790942710, 0.826413150034485790, 0.826441302211996080, +0.826469452323403080, 0.826497600368636950, 0.826525746347626320, 0.826553890260301350, 0.826582032106591650, 0.826610171886426940, 0.826638309599736720, 0.826666445246450720, +0.826694578826498550, 0.826722710339810480, 0.826750839786315250, 0.826778967165942790, 0.826807092478622940, 0.826835215724285310, 0.826863336902859740, 0.826891456014275830, +0.826919573058463750, 0.826947688035352120, 0.826975800944871440, 0.827003911786951210, 0.827032020561521140, 0.827060127268511080, 0.827088231907850640, 0.827116334479469640, +0.827144434983298370, 0.827172533419265440, 0.827200629787301240, 0.827228724087335500, 0.827256816319297820, 0.827284906483118140, 0.827312994578726310, 0.827341080606051830, +0.827369164565025290, 0.827397246455575220, 0.827425326277632100, 0.827453404031125660, 0.827481479715985730, 0.827509553332142040, 0.827537624879524540, 0.827565694358063380, +0.827593761767687620, 0.827621827108327320, 0.827649890379912550, 0.827677951582373010, 0.827706010715638540, 0.827734067779639090, 0.827762122774304500, 0.827790175699565140, +0.827818226555349760, 0.827846275341588830, 0.827874322058212210, 0.827902366705149830, 0.827930409282331530, 0.827958449789687130, 0.827986488227146710, 0.828014524594640420, +0.828042558892097440, 0.828070591119448030, 0.828098621276622150, 0.828126649363549740, 0.828154675380160630, 0.828182699326384890, 0.828210721202153000, 0.828238741007393700, +0.828266758742037480, 0.828294774406014400, 0.828322787999254520, 0.828350799521687550, 0.828378808973243560, 0.828406816353852600, 0.828434821663445060, 0.828462824901950000, +0.828490826069297910, 0.828518825165418750, 0.828546822190242450, 0.828574817143699180, 0.828602810025718780, 0.828630800836231860, 0.828658789575167590, 0.828686776242456240, +0.828714760838027860, 0.828742743361812750, 0.828770723813740730, 0.828798702193741850, 0.828826678501746180, 0.828854652737684440, 0.828882624901485450, 0.828910594993079950, +0.828938563012397990, 0.828966528959369510, 0.828994492833924790, 0.829022454635993890, 0.829050414365506750, 0.829078372022394210, 0.829106327606585090, 0.829134281118010240, +0.829162232556599710, 0.829190181922283550, 0.829218129214991940, 0.829246074434655030, 0.829274017581203340, 0.829301958654566240, 0.829329897654674130, 0.829357834581457400, +0.829385769434845990, 0.829413702214770180, 0.829441632921160130, 0.829469561553945910, 0.829497488113058350, 0.829525412598426600, 0.829553335009981300, 0.829581255347652700, +0.829609173611370880, 0.829637089801066210, 0.829665003916668750, 0.829692915958108790, 0.829720825925317150, 0.829748733818222780, 0.829776639636756630, 0.829804543380848970, +0.829832445050429860, 0.829860344645429680, 0.829888242165778610, 0.829916137611407480, 0.829944030982245450, 0.829971922278223360, 0.829999811499271490, 0.830027698645320000, +0.830055583716299390, 0.830083466712139730, 0.830111347632771500, 0.830139226478125320, 0.830167103248130590, 0.830194977942718020, 0.830222850561818100, 0.830250721105361130, +0.830278589573277270, 0.830306455965496900, 0.830334320281950980, 0.830362182522568660, 0.830390042687281000, 0.830417900776018070, 0.830445756788710580, 0.830473610725288580, +0.830501462585682580, 0.830529312369822970, 0.830557160077640470, 0.830585005709064570, 0.830612849264026230, 0.830640690742455830, 0.830668530144283660, 0.830696367469440090, +0.830724202717855630, 0.830752035889460670, 0.830779866984186150, 0.830807696001961470, 0.830835522942717450, 0.830863347806384710, 0.830891170592893640, 0.830918991302174610, +0.830946809934158040, 0.830974626488774960, 0.831002440965954880, 0.831030253365628640, 0.831058063687726830, 0.831085871932179750, 0.831113678098918120, 0.831141482187872200, +0.831169284198972620, 0.831197084132150320, 0.831224881987334800, 0.831252677764457100, 0.831280471463447750, 0.831308263084237110, 0.831336052626755920, 0.831363840090934560, +0.831391625476703530, 0.831419408783994010, 0.831447190012735480, 0.831474969162858900, 0.831502746234294990, 0.831530521226974130, 0.831558294140827050, 0.831586064975784130, +0.831613833731776660, 0.831641600408734030, 0.831669365006587390, 0.831697127525267370, 0.831724887964704560, 0.831752646324829480, 0.831780402605572840, 0.831808156806865150, +0.831835908928637570, 0.831863658970819820, 0.831891406933342740, 0.831919152816137260, 0.831946896619133900, 0.831974638342263260, 0.832002377985456070, 0.832030115548643370, +0.832057851031754890, 0.832085584434721800, 0.832113315757474830, 0.832141044999944460, 0.832168772162061530, 0.832196497243756660, 0.832224220244960570, 0.832251941165604410, +0.832279660005617820, 0.832307376764932160, 0.832335091443478060, 0.832362804041186230, 0.832390514557987400, 0.832418222993812300, 0.832445929348591520, 0.832473633622256570, +0.832501335814736950, 0.832529035925964060, 0.832556733955868490, 0.832584429904381080, 0.832612123771432680, 0.832639815556953990, 0.832667505260876180, 0.832695192883129100, +0.832722878423644120, 0.832750561882351860, 0.832778243259183260, 0.832805922554069040, 0.832833599766939940, 0.832861274897726990, 0.832888947946361260, 0.832916618912772690, +0.832944287796892450, 0.832971954598651590, 0.832999619317980830, 0.833027281954811130, 0.833054942509073080, 0.833082600980698200, 0.833110257369616410, 0.833137911675758900, +0.833165563899056600, 0.833193214039440360, 0.833220862096841210, 0.833248508071189780, 0.833276151962417110, 0.833303793770454600, 0.833331433495232090, 0.833359071136681060, +0.833386706694732250, 0.833414340169316700, 0.833441971560365370, 0.833469600867809080, 0.833497228091578670, 0.833524853231605740, 0.833552476287820250, 0.833580097260153590, +0.833607716148536570, 0.833635332952900380, 0.833662947673175840, 0.833690560309293890, 0.833718170861186050, 0.833745779328782240, 0.833773385712013980, 0.833800990010812320, +0.833828592225108190, 0.833856192354832550, 0.833883790399916450, 0.833911386360290830, 0.833938980235887310, 0.833966572026635710, 0.833994161732467880, 0.834021749353314520, +0.834049334889106710, 0.834076918339775710, 0.834104499705252360, 0.834132078985467820, 0.834159656180353480, 0.834187231289839510, 0.834214804313857530, 0.834242375252338460, +0.834269944105213490, 0.834297510872413770, 0.834325075553870140, 0.834352638149514330, 0.834380198659276480, 0.834407757083088120, 0.834435313420880290, 0.834462867672584260, +0.834490419838131100, 0.834517969917451750, 0.834545517910477600, 0.834573063817140140, 0.834600607637369430, 0.834628149371097310, 0.834655689018254710, 0.834683226578773030, +0.834710762052583210, 0.834738295439616420, 0.834765826739804480, 0.834793355953077460, 0.834820883079366970, 0.834848408118604390, 0.834875931070720670, 0.834903451935647300, +0.834930970713315120, 0.834958487403655640, 0.834986002006600340, 0.835013514522079610, 0.835041024950025080, 0.835068533290367900, 0.835096039543039460, 0.835123543707970930, +0.835151045785093580, 0.835178545774338590, 0.835206043675637670, 0.835233539488921210, 0.835261033214120820, 0.835288524851167890, 0.835316014399993700, 0.835343501860529410, +0.835370987232706420, 0.835398470516456440, 0.835425951711709750, 0.835453430818398290, 0.835480907836453120, 0.835508382765805750, 0.835535855606387430, 0.835563326358129470, +0.835590795020963120, 0.835618261594820330, 0.835645726079631390, 0.835673188475328230, 0.835700648781841910, 0.835728106999104160, 0.835755563127046020, 0.835783017165599000, +0.835810469114694480, 0.835837918974264180, 0.835865366744238720, 0.835892812424549710, 0.835920256015128760, 0.835947697515907140, 0.835975136926816240, 0.836002574247787570, +0.836030009478752940, 0.836057442619642770, 0.836084873670388970, 0.836112302630923070, 0.836139729501176430, 0.836167154281080350, 0.836194576970566430, 0.836221997569566060, +0.836249416078011290, 0.836276832495832290, 0.836304246822961340, 0.836331659059329820, 0.836359069204869020, 0.836386477259510650, 0.836413883223186110, 0.836441287095827210, +0.836468688877364700, 0.836496088567730500, 0.836523486166856010, 0.836550881674672840, 0.836578275091112490, 0.836605666416106340, 0.836633055649586120, 0.836660442791483770, +0.836687827841729790, 0.836715210800256240, 0.836742591666994720, 0.836769970441876620, 0.836797347124833670, 0.836824721715797250, 0.836852094214699080, 0.836879464621471230, +0.836906832936044180, 0.836934199158350100, 0.836961563288320390, 0.836988925325886870, 0.837016285270981040, 0.837043643123534520, 0.837070998883479240, 0.837098352550746160, +0.837125704125267100, 0.837153053606973780, 0.837180400995797820, 0.837207746291670940, 0.837235089494524630, 0.837262430604290510, 0.837289769620900960, 0.837317106544286370, +0.837344441374379130, 0.837371774111110740, 0.837399104754412930, 0.837426433304217290, 0.837453759760455550, 0.837481084123059550, 0.837508406391961220, 0.837535726567091410, +0.837563044648382270, 0.837590360635765530, 0.837617674529172910, 0.837644986328536120, 0.837672296033786900, 0.837699603644857290, 0.837726909161678250, 0.837754212584181920, +0.837781513912300160, 0.837808813145964560, 0.837836110285106850, 0.837863405329658970, 0.837890698279552540, 0.837917989134719820, 0.837945277895091660, 0.837972564560600320, +0.837999849131177530, 0.838027131606755130, 0.838054411987264940, 0.838081690272638680, 0.838108966462808750, 0.838136240557705860, 0.838163512557262400, 0.838190782461410100, +0.838218050270080890, 0.838245315983206510, 0.838272579600718880, 0.838299841122549850, 0.838327100548631580, 0.838354357878895120, 0.838381613113272860, 0.838408866251696530, +0.838436117294097950, 0.838463366240409070, 0.838490613090561940, 0.838517857844488070, 0.838545100502120170, 0.838572341063389070, 0.838599579528227060, 0.838626815896566070, +0.838654050168338050, 0.838681282343474940, 0.838708512421908580, 0.838735740403571460, 0.838762966288394530, 0.838790190076310060, 0.838817411767250220, 0.838844631361146840, +0.838871848857931870, 0.838899064257537350, 0.838926277559895020, 0.838953488764937580, 0.838980697872595990, 0.839007904882802520, 0.839035109795489340, 0.839062312610588390, +0.839089513328031720, 0.839116711947751170, 0.839143908469678900, 0.839171102893747410, 0.839198295219887540, 0.839225485448031990, 0.839252673578112730, 0.839279859610061800, +0.839307043543811250, 0.839334225379293030, 0.839361405116439750, 0.839388582755182470, 0.839415758295453670, 0.839442931737185650, 0.839470103080310110, 0.839497272324759460, +0.839524439470465510, 0.839551604517360550, 0.839578767465376960, 0.839605928314446140, 0.839633087064500350, 0.839660243715471880, 0.839687398267292770, 0.839714550719895200, +0.839741701073211330, 0.839768849327173550, 0.839795995481713240, 0.839823139536763020, 0.839850281492254820, 0.839877421348120930, 0.839904559104293510, 0.839931694760704730, +0.839958828317286740, 0.839985959773972060, 0.840013089130692060, 0.840040216387379360, 0.840067341543966120, 0.840094464600384390, 0.840121585556566690, 0.840148704412444940, +0.840175821167951420, 0.840202935823018750, 0.840230048377578420, 0.840257158831562820, 0.840284267184904450, 0.840311373437535370, 0.840338477589387840, 0.840365579640394160, +0.840392679590486910, 0.840419777439597620, 0.840446873187658760, 0.840473966834602740, 0.840501058380361820, 0.840528147824868290, 0.840555235168054420, 0.840582320409852370, +0.840609403550195090, 0.840636484589013740, 0.840663563526241160, 0.840690640361809740, 0.840717715095651740, 0.840744787727699450, 0.840771858257885140, 0.840798926686141650, +0.840825993012400460, 0.840853057236594200, 0.840880119358655250, 0.840907179378516110, 0.840934237296109060, 0.840961293111366250, 0.840988346824220300, 0.841015398434603930, +0.841042447942448650, 0.841069495347687270, 0.841096540650252080, 0.841123583850075570, 0.841150624947090030, 0.841177663941228060, 0.841204700832421830, 0.841231735620604380, +0.841258768305707120, 0.841285798887662860, 0.841312827366404110, 0.841339853741863370, 0.841366878013972920, 0.841393900182665360, 0.841420920247873520, 0.841447938209528790, +0.841474954067564340, 0.841501967821912440, 0.841528979472505600, 0.841555989019276420, 0.841582996462157170, 0.841610001801080480, 0.841637005035979160, 0.841664006166784940, +0.841691005193430760, 0.841718002115849020, 0.841744996933972200, 0.841771989647732920, 0.841798980257063680, 0.841825968761897080, 0.841852955162165960, 0.841879939457801930, +0.841906921648738150, 0.841933901734906900, 0.841960879716241010, 0.841987855592672970, 0.842014829364135190, 0.842041801030560920, 0.842068770591881570, 0.842095738048030400, +0.842122703398939800, 0.842149666644542490, 0.842176627784770980, 0.842203586819557870, 0.842230543748835880, 0.842257498572537950, 0.842284451290595810, 0.842311401902942510, +0.842338350409510770, 0.842365296810233090, 0.842392241105042180, 0.842419183293870670, 0.842446123376651700, 0.842473061353317010, 0.842499997223799530, 0.842526930988032220, +0.842553862645947450, 0.842580792197478060, 0.842607719642556650, 0.842634644981116070, 0.842661568213089240, 0.842688489338408010, 0.842715408357005540, 0.842742325268814650, +0.842769240073767860, 0.842796152771797980, 0.842823063362837850, 0.842849971846819870, 0.842876878223677520, 0.842903782493342520, 0.842930684655748050, 0.842957584710826820, +0.842984482658511780, 0.843011378498735310, 0.843038272231430570, 0.843065163856530630, 0.843092053373967200, 0.843118940783673660, 0.843145826085582750, 0.843172709279627400, +0.843199590365740100, 0.843226469343853920, 0.843253346213901580, 0.843280220975816340, 0.843307093629530050, 0.843333964174976080, 0.843360832612087160, 0.843387698940796130, +0.843414563161035910, 0.843441425272739240, 0.843468285275839060, 0.843495143170268520, 0.843521998955959810, 0.843548852632845960, 0.843575704200860030, 0.843602553659934860, +0.843629401010003390, 0.843656246250998330, 0.843683089382853080, 0.843709930405499690, 0.843736769318871430, 0.843763606122901360, 0.843790440817522190, 0.843817273402666880, +0.843844103878268470, 0.843870932244259690, 0.843897758500574140, 0.843924582647143760, 0.843951404683901840, 0.843978224610781420, 0.844005042427715460, 0.844031858134636880, +0.844058671731478750, 0.844085483218174340, 0.844112292594655700, 0.844139099860856330, 0.844165905016709290, 0.844192708062147410, 0.844219508997103850, 0.844246307821511440, +0.844273104535303350, 0.844299899138412860, 0.844326691630772230, 0.844353482012314860, 0.844380270282973690, 0.844407056442681990, 0.844433840491372490, 0.844460622428978570, +0.844487402255432950, 0.844514179970669350, 0.844540955574619830, 0.844567729067217890, 0.844594500448396680, 0.844621269718089260, 0.844648036876228580, 0.844674801922747800, +0.844701564857580520, 0.844728325680658920, 0.844755084391916380, 0.844781840991286170, 0.844808595478701460, 0.844835347854095090, 0.844862098117400540, 0.844888846268550650, +0.844915592307479040, 0.844942336234118070, 0.844969078048401270, 0.844995817750261780, 0.845022555339632660, 0.845049290816447200, 0.845076024180638540, 0.845102755432139750, +0.845129484570884660, 0.845156211596805320, 0.845182936509835450, 0.845209659309908210, 0.845236379996956890, 0.845263098570914530, 0.845289815031714520, 0.845316529379290360, +0.845343241613574440, 0.845369951734500470, 0.845396659742001510, 0.845423365636011060, 0.845450069416462060, 0.845476771083287890, 0.845503470636421840, 0.845530168075797620, +0.845556863401347500, 0.845583556613005110, 0.845610247710703920, 0.845636936694377120, 0.845663623563957970, 0.845690308319379750, 0.845716990960576180, 0.845743671487479750, +0.845770349900024090, 0.845797026198142570, 0.845823700381768460, 0.845850372450835160, 0.845877042405275840, 0.845903710245023980, 0.845930375970013300, 0.845957039580176210, +0.845983701075446510, 0.846010360455757620, 0.846037017721042780, 0.846063672871235410, 0.846090325906268870, 0.846116976826076450, 0.846143625630592090, 0.846170272319748170, +0.846196916893478650, 0.846223559351716780, 0.846250199694396080, 0.846276837921449810, 0.846303474032811480, 0.846330108028414910, 0.846356739908192600, 0.846383369672078390, +0.846409997320005880, 0.846436622851908240, 0.846463246267719180, 0.846489867567371880, 0.846516486750800050, 0.846543103817937400, 0.846569718768716450, 0.846596331603071350, +0.846622942320935270, 0.846649550922241920, 0.846676157406924700, 0.846702761774916990, 0.846729364026152510, 0.846755964160565090, 0.846782562178087120, 0.846809158078652870, +0.846835751862195730, 0.846862343528649200, 0.846888933077946770, 0.846915520510022060, 0.846942105824809000, 0.846968689022240210, 0.846995270102249730, 0.847021849064771070, +0.847048425909737720, 0.847075000637083410, 0.847101573246741510, 0.847128143738645640, 0.847154712112729970, 0.847181278368926980, 0.847207842507170850, 0.847234404527395180, +0.847260964429533360, 0.847287522213519220, 0.847314077879286250, 0.847340631426768520, 0.847367182855898740, 0.847393732166611070, 0.847420279358839010, 0.847446824432516290, +0.847473367387576500, 0.847499908223953270, 0.847526446941580300, 0.847552983540391660, 0.847579518020320170, 0.847606050381299770, 0.847632580623264300, 0.847659108746147360, +0.847685634749882680, 0.847712158634403860, 0.847738680399644730, 0.847765200045539240, 0.847791717572020430, 0.847818232979022260, 0.847844746266478430, 0.847871257434322790, +0.847897766482489050, 0.847924273410910920, 0.847950778219522470, 0.847977280908256640, 0.848003781477047690, 0.848030279925829240, 0.848056776254535020, 0.848083270463098950, +0.848109762551454650, 0.848136252519535950, 0.848162740367277120, 0.848189226094610890, 0.848215709701471750, 0.848242191187793200, 0.848268670553509190, 0.848295147798553530, +0.848321622922860060, 0.848348095926362960, 0.848374566808995030, 0.848401035570690800, 0.848427502211383970, 0.848453966731008480, 0.848480429129497950, 0.848506889406786310, +0.848533347562807520, 0.848559803597495830, 0.848586257510784200, 0.848612709302606900, 0.848639158972897770, 0.848665606521590730, 0.848692051948619740, 0.848718495253918630, +0.848744936437421330, 0.848771375499062010, 0.848797812438773950, 0.848824247256491190, 0.848850679952147910, 0.848877110525677940, 0.848903538977015090, 0.848929965306093550, +0.848956389512847460, 0.848982811597209900, 0.849009231559115450, 0.849035649398497850, 0.849062065115291030, 0.849088478709429160, 0.849114890180846070, 0.849141299529475700, +0.849167706755252660, 0.849194111858109780, 0.849220514837981670, 0.849246915694802260, 0.849273314428505620, 0.849299711039025680, 0.849326105526296390, 0.849352497890251910, +0.849378888130826630, 0.849405276247953590, 0.849431662241567410, 0.849458046111602140, 0.849484427857991610, 0.849510807480670200, 0.849537184979571650, 0.849563560354630540, +0.849589933605780170, 0.849616304732955020, 0.849642673736089040, 0.849669040615116280, 0.849695405369971010, 0.849721768000587300, 0.849748128506899070, 0.849774486888841050, +0.849800843146346300, 0.849827197279349410, 0.849853549287784560, 0.849879899171585910, 0.849906246930687390, 0.849932592565023400, 0.849958936074528220, 0.849985277459135320, +0.850011616718779230, 0.850037953853394090, 0.850064288862914070, 0.850090621747273350, 0.850116952506406070, 0.850143281140246400, 0.850169607648728950, 0.850195932031787120, +0.850222254289355380, 0.850248574421368030, 0.850274892427759220, 0.850301208308463230, 0.850327522063414110, 0.850353833692546250, 0.850380143195794360, 0.850406450573091500, +0.850432755824372610, 0.850459058949571860, 0.850485359948623400, 0.850511658821461510, 0.850537955568020480, 0.850564250188235120, 0.850590542682038600, 0.850616833049365750, +0.850643121290150740, 0.850669407404327950, 0.850695691391831770, 0.850721973252596240, 0.850748252986555760, 0.850774530593645160, 0.850800806073797820, 0.850827079426948350, +0.850853350653031250, 0.850879619751980790, 0.850905886723731240, 0.850932151568217000, 0.850958414285372440, 0.850984674875132190, 0.851010933337429830, 0.851037189672200210, +0.851063443879377490, 0.851089695958896280, 0.851115945910690730, 0.851142193734695460, 0.851168439430844970, 0.851194682999073080, 0.851220924439314410, 0.851247163751503440, +0.851273400935574580, 0.851299635991462190, 0.851325868919100780, 0.851352099718424630, 0.851378328389368670, 0.851404554931866510, 0.851430779345852870, 0.851457001631262370, +0.851483221788029270, 0.851509439816088180, 0.851535655715373490, 0.851561869485820130, 0.851588081127361620, 0.851614290639932880, 0.851640498023468420, 0.851666703277902730, +0.851692906403170300, 0.851719107399205640, 0.851745306265943140, 0.851771503003317830, 0.851797697611263340, 0.851823890089714600, 0.851850080438606220, 0.851876268657872470, +0.851902454747448190, 0.851928638707267650, 0.851954820537265680, 0.851981000237377000, 0.852007177807535320, 0.852033353247675820, 0.852059526557732870, 0.852085697737641090, +0.852111866787335080, 0.852138033706749340, 0.852164198495819040, 0.852190361154477770, 0.852216521682660710, 0.852242680080302240, 0.852268836347337080, 0.852294990483699830, +0.852321142489325110, 0.852347292364147520, 0.852373440108102120, 0.852399585721122730, 0.852425729203144300, 0.852451870554101650, 0.852478009773929290, 0.852504146862561930, +0.852530281819934180, 0.852556414645980640, 0.852582545340636600, 0.852608673903835770, 0.852634800335513200, 0.852660924635603610, 0.852687046804041730, 0.852713166840762260, +0.852739284745699930, 0.852765400518789800, 0.852791514159965680, 0.852817625669162750, 0.852843735046315830, 0.852869842291359540, 0.852895947404228580, 0.852922050384857800, +0.852948151233181910, 0.852974249949136070, 0.853000346532654220, 0.853026440983671420, 0.853052533302122610, 0.853078623487942390, 0.853104711541065600, 0.853130797461427060, +0.853156881248962050, 0.853182962903604290, 0.853209042425289170, 0.853235119813951390, 0.853261195069525910, 0.853287268191947330, 0.853313339181150710, 0.853339408037070650, +0.853365474759642530, 0.853391539348800300, 0.853417601804479120, 0.853443662126614040, 0.853469720315139790, 0.853495776369991190, 0.853521830291103180, 0.853547882078410700, +0.853573931731848810, 0.853599979251351780, 0.853626024636854660, 0.853652067888292510, 0.853678109005600260, 0.853704147988712750, 0.853730184837564800, 0.853756219552091800, +0.853782252132227910, 0.853808282577908310, 0.853834310889068140, 0.853860337065642020, 0.853886361107565110, 0.853912383014772350, 0.853938402787198570, 0.853964420424779270, +0.853990435927448500, 0.854016449295141530, 0.854042460527793530, 0.854068469625339330, 0.854094476587713980, 0.854120481414852530, 0.854146484106689810, 0.854172484663161310, +0.854198483084201100, 0.854224479369744770, 0.854250473519727160, 0.854276465534083430, 0.854302455412748520, 0.854328443155657480, 0.854354428762745700, 0.854380412233947560, +0.854406393569198230, 0.854432372768432980, 0.854458349831586860, 0.854484324758594820, 0.854510297549391900, 0.854536268203913370, 0.854562236722094530, 0.854588203103869630, +0.854614167349174280, 0.854640129457943430, 0.854666089430112350, 0.854692047265615980, 0.854718002964389600, 0.854743956526368590, 0.854769907951487220, 0.854795857239681100, +0.854821804390885290, 0.854847749405035050, 0.854873692282065440, 0.854899633021911520, 0.854925571624508550, 0.854951508089792140, 0.854977442417696460, 0.855003374608157230, +0.855029304661109490, 0.855055232576488520, 0.855081158354229490, 0.855107081994267550, 0.855133003496537870, 0.855158922860976280, 0.855184840087516720, 0.855210755176095240, +0.855236668126646780, 0.855262578939106620, 0.855288487613410030, 0.855314394149492290, 0.855340298547288990, 0.855366200806734530, 0.855392100927764520, 0.855417998910314230, +0.855443894754318920, 0.855469788459713890, 0.855495680026434500, 0.855521569454415820, 0.855547456743593670, 0.855573341893902440, 0.855599224905277840, 0.855625105777655160, +0.855650984510969770, 0.855676861105156950, 0.855702735560151860, 0.855728607875890450, 0.855754478052307090, 0.855780346089337510, 0.855806211986917090, 0.855832075744981100, +0.855857937363464940, 0.855883796842303870, 0.855909654181433390, 0.855935509380789220, 0.855961362440305850, 0.855987213359919010, 0.856013062139564180, 0.856038908779176650, +0.856064753278691910, 0.856090595638045240, 0.856116435857172120, 0.856142273936008390, 0.856168109874488440, 0.856193943672548310, 0.856219775330123170, 0.856245604847148730, +0.856271432223560170, 0.856297257459293190, 0.856323080554283410, 0.856348901508465430, 0.856374720321775310, 0.856400536994148310, 0.856426351525520050, 0.856452163915825790, +0.856477974165001150, 0.856503782272981630, 0.856529588239703150, 0.856555392065100120, 0.856581193749108680, 0.856606993291664230, 0.856632790692702370, 0.856658585952158490, +0.856684379069968080, 0.856710170046066870, 0.856735958880390560, 0.856761745572873990, 0.856787530123452990, 0.856813312532063160, 0.856839092798640010, 0.856864870923119250, +0.856890646905436260, 0.856916420745527100, 0.856942192443326370, 0.856967961998770230, 0.856993729411794190, 0.857019494682333850, 0.857045257810324700, 0.857071018795702470, +0.857096777638402640, 0.857122534338361390, 0.857148288895513310, 0.857174041309794470, 0.857199791581140570, 0.857225539709487230, 0.857251285694769940, 0.857277029536924530, +0.857302771235886940, 0.857328510791592000, 0.857354248203975770, 0.857379983472973950, 0.857405716598522160, 0.857431447580556010, 0.857457176419011310, 0.857482903113823690, +0.857508627664929190, 0.857534350072262750, 0.857560070335760430, 0.857585788455357820, 0.857611504430990880, 0.857637218262595090, 0.857662929950106290, 0.857688639493460190, +0.857714346892592850, 0.857740052147439310, 0.857765755257935520, 0.857791456224017420, 0.857817155045620730, 0.857842851722681040, 0.857868546255134310, 0.857894238642916580, +0.857919928885962910, 0.857945616984209350, 0.857971302937591720, 0.857996986746045850, 0.858022668409507580, 0.858048347927912620, 0.858074025301196700, 0.858099700529296290, +0.858125373612146140, 0.858151044549682500, 0.858176713341841310, 0.858202379988558310, 0.858228044489769300, 0.858253706845410250, 0.858279367055416960, 0.858305025119725620, +0.858330681038271370, 0.858356334810990380, 0.858381986437818490, 0.858407635918691740, 0.858433283253545730, 0.858458928442316640, 0.858484571484940730, 0.858510212381352830, +0.858535851131489450, 0.858561487735286510, 0.858587122192679740, 0.858612754503605190, 0.858638384667998800, 0.858664012685796400, 0.858689638556934360, 0.858715262281347870, +0.858740883858973290, 0.858766503289746350, 0.858792120573603210, 0.858817735710479810, 0.858843348700311980, 0.858868959543036330, 0.858894568238587790, 0.858920174786902860, +0.858945779187917480, 0.858971381441567590, 0.858996981547789250, 0.859022579506518500, 0.859048175317691290, 0.859073768981244100, 0.859099360497112110, 0.859124949865231580, +0.859150537085538790, 0.859176122157969570, 0.859201705082460080, 0.859227285858946370, 0.859252864487364380, 0.859278440967650710, 0.859304015299740540, 0.859329587483570250, +0.859355157519075990, 0.859380725406193920, 0.859406291144860000, 0.859431854735010270, 0.859457416176581450, 0.859482975469508580, 0.859508532613728280, 0.859534087609176710, +0.859559640455789920, 0.859585191153503960, 0.859610739702255100, 0.859636286101979290, 0.859661830352613340, 0.859687372454092210, 0.859712912406352730, 0.859738450209331040, +0.859763985862963100, 0.859789519367185280, 0.859815050721933650, 0.859840579927144360, 0.859866106982754120, 0.859891631888698100, 0.859917154644913030, 0.859942675251335160, +0.859968193707900450, 0.859993710014545390, 0.860019224171205910, 0.860044736177818960, 0.860070246034319700, 0.860095753740644730, 0.860121259296730440, 0.860146762702513000, +0.860172263957928670, 0.860197763062913620, 0.860223260017404230, 0.860248754821337110, 0.860274247474647650, 0.860299737977272550, 0.860325226329148210, 0.860350712530210670, +0.860376196580396440, 0.860401678479641660, 0.860427158227883180, 0.860452635825056380, 0.860478111271097970, 0.860503584565944220, 0.860529055709531530, 0.860554524701796280, +0.860579991542674620, 0.860605456232103050, 0.860630918770018180, 0.860656379156355620, 0.860681837391052200, 0.860707293474044180, 0.860732747405267840, 0.860758199184659680, +0.860783648812155970, 0.860809096287693200, 0.860834541611208090, 0.860859984782636150, 0.860885425801914290, 0.860910864668978930, 0.860936301383766310, 0.860961735946212950, +0.860987168356255330, 0.861012598613830170, 0.861038026718873080, 0.861063452671321010, 0.861088876471110210, 0.861114298118177190, 0.861139717612458440, 0.861165134953890470, +0.861190550142409640, 0.861215963177952790, 0.861241374060455640, 0.861266782789855130, 0.861292189366087650, 0.861317593789089560, 0.861342996058797610, 0.861368396175148150, +0.861393794138077710, 0.861419189947523200, 0.861444583603420240, 0.861469975105705890, 0.861495364454316630, 0.861520751649188840, 0.861546136690259260, 0.861571519577464360, +0.861596900310740990, 0.861622278890025070, 0.861647655315253340, 0.861673029586362490, 0.861698401703289150, 0.861723771665969700, 0.861749139474340840, 0.861774505128339200, +0.861799868627901700, 0.861825229972964070, 0.861850589163463350, 0.861875946199336160, 0.861901301080519210, 0.861926653806948880, 0.861952004378562010, 0.861977352795295530, +0.862002699057085150, 0.862028043163868160, 0.862053385115580940, 0.862078724912160310, 0.862104062553542880, 0.862129398039665260, 0.862154731370464280, 0.862180062545876760, +0.862205391565838640, 0.862230718430287090, 0.862256043139158820, 0.862281365692390330, 0.862306686089918450, 0.862332004331679890, 0.862357320417611260, 0.862382634347649830, +0.862407946121731330, 0.862433255739793010, 0.862458563201771610, 0.862483868507603610, 0.862509171657226070, 0.862534472650575590, 0.862559771487589440, 0.862585068168203350, +0.862610362692354580, 0.862635655059979860, 0.862660945271016110, 0.862686233325399840, 0.862711519223068100, 0.862736802963957610, 0.862762084548005400, 0.862787363975147660, +0.862812641245321530, 0.862837916358463740, 0.862863189314511110, 0.862888460113400590, 0.862913728755068890, 0.862938995239452830, 0.862964259566489810, 0.862989521736115650, +0.863014781748267730, 0.863040039602882780, 0.863065295299897840, 0.863090548839249520, 0.863115800220874860, 0.863141049444711260, 0.863166296510694540, 0.863191541418761980, +0.863216784168850610, 0.863242024760897400, 0.863267263194839040, 0.863292499470612480, 0.863317733588154780, 0.863342965547403090, 0.863368195348293570, 0.863393422990763600, +0.863418648474750030, 0.863443871800189780, 0.863469092967020010, 0.863494311975177340, 0.863519528824599480, 0.863544743515222260, 0.863569956046983280, 0.863595166419819260, +0.863620374633667480, 0.863645580688464640, 0.863670784584147920, 0.863695986320654250, 0.863721185897921020, 0.863746383315884380, 0.863771578574481720, 0.863796771673650210, +0.863821962613326780, 0.863847151393448360, 0.863872338013952130, 0.863897522474775030, 0.863922704775854530, 0.863947884917126930, 0.863973062898529600, 0.863998238719999480, +0.864023412381473950, 0.864048583882889740, 0.864073753224184120, 0.864098920405294570, 0.864124085426157260, 0.864149248286709800, 0.864174408986889130, 0.864199567526632520, +0.864224723905876900, 0.864249878124559560, 0.864275030182617420, 0.864300180079988320, 0.864325327816608200, 0.864350473392414780, 0.864375616807345090, 0.864400758061336540, +0.864425897154325940, 0.864451034086250680, 0.864476168857048250, 0.864501301466654940, 0.864526431915008440, 0.864551560202045820, 0.864576686327704240, 0.864601810291921070, +0.864626932094633260, 0.864652051735778190, 0.864677169215293470, 0.864702284533115260, 0.864727397689181390, 0.864752508683429120, 0.864777617515795400, 0.864802724186217840, +0.864827828694633370, 0.864852931040979270, 0.864878031225193360, 0.864903129247211910, 0.864928225106972650, 0.864953318804412840, 0.864978410339469650, 0.865003499712080570, +0.865028586922182650, 0.865053671969713720, 0.865078754854610170, 0.865103835576809700, 0.865128914136249700, 0.865153990532867350, 0.865179064766600110, 0.865204136837385170, +0.865229206745159910, 0.865254274489862030, 0.865279340071428040, 0.865304403489795650, 0.865329464744902350, 0.865354523836685320, 0.865379580765082030, 0.865404635530029780, +0.865429688131465810, 0.865454738569328200, 0.865479786843553310, 0.865504832954078870, 0.865529876900842490, 0.865554918683781200, 0.865579958302832850, 0.865604995757934480, +0.865630031049024030, 0.865655064176038100, 0.865680095138914530, 0.865705123937590690, 0.865730150572004090, 0.865755175042092100, 0.865780197347792100, 0.865805217489041710, +0.865830235465778640, 0.865855251277939610, 0.865880264925462440, 0.865905276408284520, 0.865930285726343450, 0.865955292879576730, 0.865980297867921740, 0.866005300691316430, +0.866030301349697500, 0.866055299843002780, 0.866080296171169770, 0.866105290334135970, 0.866130282331839090, 0.866155272164216390, 0.866180259831205610, 0.866205245332744460, +0.866230228668769860, 0.866255209839219660, 0.866280188844031570, 0.866305165683142860, 0.866330140356491250, 0.866355112864014340, 0.866380083205649630, 0.866405051381335170, +0.866430017391007560, 0.866454981234604960, 0.866479942912064980, 0.866504902423325010, 0.866529859768322860, 0.866554814946996040, 0.866579767959282710, 0.866604718805119360, +0.866629667484444370, 0.866654613997195120, 0.866679558343309340, 0.866704500522724740, 0.866729440535378810, 0.866754378381209280, 0.866779314060154290, 0.866804247572150470, +0.866829178917136180, 0.866854108095048810, 0.866879035105826310, 0.866903959949406170, 0.866928882625725980, 0.866953803134723810, 0.866978721476337480, 0.867003637650503810, +0.867028551657161200, 0.867053463496247120, 0.867078373167699420, 0.867103280671455810, 0.867128186007453890, 0.867153089175632050, 0.867177990175927000, 0.867202889008277020, +0.867227785672619820, 0.867252680168893120, 0.867277572497034740, 0.867302462656982410, 0.867327350648673940, 0.867352236472047510, 0.867377120127040050, 0.867402001613589820, +0.867426880931634560, 0.867451758081112080, 0.867476633061960210, 0.867501505874116790, 0.867526376517520070, 0.867551244992106900, 0.867576111297815640, 0.867600975434584140, +0.867625837402350220, 0.867650697201051700, 0.867675554830626310, 0.867700410291012190, 0.867725263582147410, 0.867750114703969010, 0.867774963656415380, 0.867799810439424340, +0.867824655052933710, 0.867849497496881450, 0.867874337771205480, 0.867899175875843750, 0.867924011810734420, 0.867948845575814640, 0.867973677171022700, 0.867998506596296630, +0.868023333851574260, 0.868048158936793660, 0.868072981851892520, 0.868097802596809460, 0.868122621171481420, 0.868147437575846780, 0.868172251809843590, 0.868197063873409780, +0.868221873766483300, 0.868246681489002080, 0.868271487040904290, 0.868296290422128080, 0.868321091632610840, 0.868345890672290730, 0.868370687541106020, 0.868395482238994540, +0.868420274765894340, 0.868445065121743460, 0.868469853306479970, 0.868494639320042230, 0.868519423162367410, 0.868544204833394120, 0.868568984333060290, 0.868593761661303980, +0.868618536818063340, 0.868643309803276200, 0.868668080616881390, 0.868692849258815850, 0.868717615729018180, 0.868742380027426540, 0.868767142153978880, 0.868791902108613460, +0.868816659891268220, 0.868841415501881320, 0.868866168940391370, 0.868890920206735530, 0.868915669300852290, 0.868940416222680030, 0.868965160972156700, 0.868989903549220340, +0.869014643953809340, 0.869039382185862190, 0.869064118245316040, 0.869088852132109730, 0.869113583846181200, 0.869138313387468720, 0.869163040755910440, 0.869187765951444650, +0.869212488974009380, 0.869237209823543360, 0.869261928499983850, 0.869286645003269460, 0.869311359333338470, 0.869336071490129150, 0.869360781473579650, 0.869385489283628130, +0.869410194920212990, 0.869434898383272700, 0.869459599672744780, 0.869484298788567920, 0.869508995730680190, 0.869533690499020070, 0.869558383093525620, 0.869583073514135330, +0.869607761760787690, 0.869632447833420310, 0.869657131731971680, 0.869681813456380290, 0.869706493006584420, 0.869731170382522230, 0.869755845584132210, 0.869780518611352530, +0.869805189464122000, 0.869829858142378010, 0.869854524646059390, 0.869879188975104520, 0.869903851129451570, 0.869928511109039130, 0.869953168913805360, 0.869977824543688550, +0.870002477998627730, 0.870027129278560300, 0.870051778383424960, 0.870076425313160210, 0.870101070067704430, 0.870125712646996010, 0.870150353050973210, 0.870174991279574980, +0.870199627332738920, 0.870224261210403750, 0.870248892912507950, 0.870273522438989810, 0.870298149789787920, 0.870322774964840780, 0.870347397964086560, 0.870372018787464290, +0.870396637434911580, 0.870421253906367260, 0.870445868201769830, 0.870470480321057670, 0.870495090264169380, 0.870519698031043340, 0.870544303621618500, 0.870568907035832450, +0.870593508273624140, 0.870618107334932060, 0.870642704219694700, 0.870667298927850550, 0.870691891459338230, 0.870716481814096110, 0.870741069992063240, 0.870765655993177230, +0.870790239817377130, 0.870814821464601430, 0.870839400934788730, 0.870863978227877420, 0.870888553343806220, 0.870913126282513610, 0.870937697043938640, 0.870962265628019040, +0.870986832034693740, 0.871011396263901340, 0.871035958315580450, 0.871060518189669670, 0.871085075886107620, 0.871109631404833220, 0.871134184745784410, 0.871158735908900140, +0.871183284894119000, 0.871207831701379610, 0.871232376330620670, 0.871256918781780800, 0.871281459054798700, 0.871305997149613320, 0.871330533066162480, 0.871355066804385350, +0.871379598364220520, 0.871404127745606720, 0.871428654948482650, 0.871453179972786820, 0.871477702818458600, 0.871502223485435600, 0.871526741973657090, 0.871551258283061680, +0.871575772413588190, 0.871600284365175230, 0.871624794137761620, 0.871649301731285960, 0.871673807145687430, 0.871698310380904060, 0.871722811436874910, 0.871747310313538690, +0.871771807010834120, 0.871796301528700130, 0.871820793867075340, 0.871845284025898670, 0.871869772005109070, 0.871894257804644690, 0.871918741424444700, 0.871943222864447810, +0.871967702124592850, 0.871992179204818640, 0.872016654105064020, 0.872041126825268130, 0.872065597365369040, 0.872090065725305900, 0.872114531905017750, 0.872138995904443100, +0.872163457723521000, 0.872187917362190370, 0.872212374820389820, 0.872236830098058860, 0.872261283195135300, 0.872285734111558520, 0.872310182847267470, 0.872334629402200970, +0.872359073776297840, 0.872383515969497150, 0.872407955981737480, 0.872432393812958450, 0.872456829463098100, 0.872481262932095600, 0.872505694219889880, 0.872530123326419990, +0.872554550251624760, 0.872578974995443120, 0.872603397557814580, 0.872627817938677050, 0.872652236137970050, 0.872676652155632390, 0.872701065991603020, 0.872725477645821090, +0.872749887118225430, 0.872774294408755090, 0.872798699517349450, 0.872823102443946560, 0.872847503188486030, 0.872871901750906680, 0.872896298131147550, 0.872920692329147710, +0.872945084344846080, 0.872969474178182270, 0.872993861829094220, 0.873018247297521640, 0.873042630583403370, 0.873067011686678550, 0.873091390607286130, 0.873115767345165380, +0.873140141900255130, 0.873164514272494970, 0.873188884461822970, 0.873213252468178940, 0.873237618291501700, 0.873261981931730440, 0.873286343388804180, 0.873310702662662090, +0.873335059753243210, 0.873359414660487170, 0.873383767384332210, 0.873408117924717730, 0.873432466281583000, 0.873456812454867060, 0.873481156444509080, 0.873505498250448320, +0.873529837872624170, 0.873554175310975010, 0.873578510565440340, 0.873602843635959530, 0.873627174522471520, 0.873651503224915580, 0.873675829743230880, 0.873700154077356570, +0.873724476227232370, 0.873748796192796550, 0.873773113973988710, 0.873797429570748130, 0.873821742983013960, 0.873846054210725360, 0.873870363253821720, 0.873894670112242200, +0.873918974785926280, 0.873943277274812690, 0.873967577578840800, 0.873991875697949890, 0.874016171632079450, 0.874040465381168420, 0.874064756945156400, 0.874089046323982770, +0.874113333517586130, 0.874137618525906210, 0.874161901348882160, 0.874186181986453480, 0.874210460438559210, 0.874234736705138850, 0.874259010786131660, 0.874283282681477370, +0.874307552391114460, 0.874331819914982660, 0.874356085253021330, 0.874380348405169760, 0.874404609371367330, 0.874428868151553300, 0.874453124745667610, 0.874477379153648650, +0.874501631375436350, 0.874525881410969870, 0.874550129260188710, 0.874574374923032140, 0.874598618399439750, 0.874622859689350720, 0.874647098792705080, 0.874671335709441220, +0.874695570439498970, 0.874719802982817820, 0.874744033339337150, 0.874768261508996450, 0.874792487491735100, 0.874816711287492500, 0.874840932896208460, 0.874865152317821800, +0.874889369552272260, 0.874913584599499190, 0.874937797459442220, 0.874962008132040720, 0.874986216617234300, 0.875010422914962670, 0.875034627025164550, 0.875058828947779980, +0.875083028682748230, 0.875107226230008920, 0.875131421589501520, 0.875155614761165660, 0.875179805744940700, 0.875203994540766690, 0.875228181148582140, 0.875252365568327310, +0.875276547799941460, 0.875300727843364320, 0.875324905698535270, 0.875349081365394020, 0.875373254843880070, 0.875397426133933340, 0.875421595235492680, 0.875445762148498010, +0.875469926872888940, 0.875494089408605070, 0.875518249755586010, 0.875542407913771250, 0.875566563883100950, 0.875590717663513820, 0.875614869254949800, 0.875639018657348720, +0.875663165870650070, 0.875687310894793460, 0.875711453729718590, 0.875735594375365080, 0.875759732831673080, 0.875783869098581190, 0.875808003176029690, 0.875832135063958180, +0.875856264762306380, 0.875880392271013890, 0.875904517590020410, 0.875928640719266130, 0.875952761658689740, 0.875976880408231520, 0.876000996967830960, 0.876025111337428000, +0.876049223516962350, 0.876073333506373510, 0.876097441305601410, 0.876121546914586100, 0.876145650333266410, 0.876169751561582720, 0.876193850599474630, 0.876217947446881860, +0.876242042103744350, 0.876266134570001580, 0.876290224845593600, 0.876314312930460360, 0.876338398824541010, 0.876362482527775600, 0.876386564040104070, 0.876410643361466010, +0.876434720491801490, 0.876458795431049990, 0.876482868179152110, 0.876506938736046460, 0.876531007101673640, 0.876555073275973150, 0.876579137258885030, 0.876603199050349110, +0.876627258650305220, 0.876651316058693060, 0.876675371275453140, 0.876699424300524280, 0.876723475133846960, 0.876747523775360800, 0.876771570225005960, 0.876795614482722140, +0.876819656548449400, 0.876843696422127450, 0.876867734103696670, 0.876891769593096120, 0.876915802890266050, 0.876939833995146630, 0.876963862907677580, 0.876987889627798830, +0.877011914155450430, 0.877035936490572650, 0.877059956633104540, 0.877083974582986590, 0.877107990340158740, 0.877132003904560810, 0.877156015276132960, 0.877180024454815020, +0.877204031440547040, 0.877228036233269390, 0.877252038832921240, 0.877276039239443080, 0.877300037452774740, 0.877324033472856260, 0.877348027299627690, 0.877372018933029190, +0.877396008373000910, 0.877419995619482250, 0.877443980672413690, 0.877467963531735060, 0.877491944197386520, 0.877515922669308220, 0.877539898947440000, 0.877563873031722120, +0.877587844922094960, 0.877611814618497800, 0.877635782120871010, 0.877659747429154760, 0.877683710543289200, 0.877707671463214380, 0.877731630188870350, 0.877755586720197270, +0.877779541057135630, 0.877803493199624700, 0.877827443147605080, 0.877851390901016830, 0.877875336459800090, 0.877899279823895040, 0.877923220993241720, 0.877947159967780830, +0.877971096747451660, 0.877995031332194700, 0.878018963721950210, 0.878042893916658240, 0.878066821916258950, 0.878090747720692730, 0.878114671329899620, 0.878138592743820330, +0.878162511962394030, 0.878186428985561540, 0.878210343813262910, 0.878234256445438400, 0.878258166882028290, 0.878282075122972740, 0.878305981168212460, 0.878329885017686830, +0.878353786671336350, 0.878377686129101500, 0.878401583390922450, 0.878425478456739460, 0.878449371326492700, 0.878473262000122550, 0.878497150477569710, 0.878521036758773580, +0.878544920843674750, 0.878568802732213720, 0.878592682424330640, 0.878616559919965790, 0.878640435219059660, 0.878664308321552400, 0.878688179227384740, 0.878712047936496270, +0.878735914448827700, 0.878759778764319210, 0.878783640882911390, 0.878807500804544510, 0.878831358529158830, 0.878855214056695090, 0.878879067387092980, 0.878902918520293230, +0.878926767456236100, 0.878950614194862090, 0.878974458736111570, 0.878998301079924830, 0.879022141226242450, 0.879045979175005040, 0.879069814926152330, 0.879093648479625010, +0.879117479835363700, 0.879141308993308560, 0.879165135953400180, 0.879188960715578950, 0.879212783279785360, 0.879236603645960240, 0.879260421814043180, 0.879284237783975020, +0.879308051555696360, 0.879331863129147460, 0.879355672504268940, 0.879379479681001270, 0.879403284659285300, 0.879427087439060730, 0.879450888020268380, 0.879474686402848870, +0.879498482586742570, 0.879522276571890080, 0.879546068358232010, 0.879569857945708630, 0.879593645334261100, 0.879617430523829010, 0.879641213514353320, 0.879664994305774720, +0.879688772898033490, 0.879712549291070340, 0.879736323484825890, 0.879760095479241060, 0.879783865274255560, 0.879807632869810340, 0.879831398265846110, 0.879855161462303360, +0.879878922459122690, 0.879902681256244710, 0.879926437853610020, 0.879950192251159670, 0.879973944448833370, 0.879997694446572280, 0.880021442244317000, 0.880045187842008030, +0.880068931239586070, 0.880092672436991850, 0.880116411434165860, 0.880140148231049360, 0.880163882827582070, 0.880187615223705030, 0.880211345419358970, 0.880235073414484480, +0.880258799209022390, 0.880282522802913300, 0.880306244196098260, 0.880329963388517210, 0.880353680380111300, 0.880377395170821140, 0.880401107760587550, 0.880424818149351140, +0.880448526337052730, 0.880472232323632920, 0.880495936109033090, 0.880519637693192860, 0.880543337076053590, 0.880567034257556000, 0.880590729237640810, 0.880614422016248730, +0.880638112593320700, 0.880661800968797310, 0.880685487142619850, 0.880709171114728350, 0.880732852885063870, 0.880756532453567220, 0.880780209820179240, 0.880803884984840750, +0.880827557947492570, 0.880851228708075860, 0.880874897266530680, 0.880898563622798280, 0.880922227776819500, 0.880945889728535050, 0.880969549477885970, 0.880993207024812990, +0.881016862369257030, 0.881040515511159250, 0.881064166450459820, 0.881087815187099890, 0.881111461721020510, 0.881135106052162500, 0.881158748180466690, 0.881182388105874010, +0.881206025828325750, 0.881229661347762040, 0.881253294664124160, 0.881276925777353060, 0.881300554687389660, 0.881324181394174790, 0.881347805897649490, 0.881371428197754710, +0.881395048294431830, 0.881418666187620880, 0.881442281877263260, 0.881465895363299890, 0.881489506645671830, 0.881513115724320010, 0.881536722599185360, 0.881560327270208940, +0.881583929737332130, 0.881607530000494970, 0.881631128059639170, 0.881654723914705450, 0.881678317565634860, 0.881701909012368560, 0.881725498254847470, 0.881749085293012990, +0.881772670126805490, 0.881796252756166240, 0.881819833181036410, 0.881843411401356910, 0.881866987417068930, 0.881890561228113490, 0.881914132834431650, 0.881937702235964900, +0.881961269432653520, 0.881984834424438870, 0.882008397211262230, 0.882031957793064540, 0.882055516169786950, 0.882079072341370620, 0.882102626307756600, 0.882126178068886380, +0.882149727624700340, 0.882173274975139980, 0.882196820120146330, 0.882220363059660780, 0.882243903793624270, 0.882267442321977960, 0.882290978644663550, 0.882314512761621210, +0.882338044672792530, 0.882361574378118910, 0.882385101877541160, 0.882408627171000770, 0.882432150258438800, 0.882455671139796500, 0.882479189815015390, 0.882502706284035820, +0.882526220546799630, 0.882549732603247760, 0.882573242453321580, 0.882596750096962370, 0.882620255534111280, 0.882643758764709910, 0.882667259788698750, 0.882690758606019420, +0.882714255216613180, 0.882737749620421290, 0.882761241817385130, 0.882784731807445770, 0.882808219590544670, 0.882831705166623350, 0.882855188535622390, 0.882878669697483410, +0.882902148652147780, 0.882925625399556880, 0.882949099939651760, 0.882972572272374020, 0.882996042397664830, 0.883019510315465880, 0.883042976025717800, 0.883066439528362170, +0.883089900823340600, 0.883113359910594140, 0.883136816790064390, 0.883160271461692510, 0.883183723925420440, 0.883207174181188660, 0.883230622228938890, 0.883254068068612510, +0.883277511700151120, 0.883300953123495770, 0.883324392338588170, 0.883347829345369480, 0.883371264143781750, 0.883394696733765360, 0.883418127115262350, 0.883441555288213890, +0.883464981252561570, 0.883488405008246770, 0.883511826555211100, 0.883535245893395720, 0.883558663022742660, 0.883582077943192550, 0.883605490654687300, 0.883628901157168300, +0.883652309450576930, 0.883675715534854910, 0.883699119409943610, 0.883722521075784860, 0.883745920532319370, 0.883769317779489190, 0.883792712817235590, 0.883816105645500280, +0.883839496264224760, 0.883862884673350390, 0.883886270872818900, 0.883909654862572110, 0.883933036642550740, 0.883956416212696830, 0.883979793572951870, 0.884003168723257350, +0.884026541663554990, 0.884049912393786270, 0.884073280913893140, 0.884096647223816420, 0.884120011323498160, 0.884143373212879720, 0.884166732891902950, 0.884190090360509330, +0.884213445618640460, 0.884236798666238060, 0.884260149503243940, 0.884283498129599170, 0.884306844545245550, 0.884330188750124810, 0.884353530744178660, 0.884376870527348700, +0.884400208099576530, 0.884423543460803870, 0.884446876610972770, 0.884470207550023920, 0.884493536277899730, 0.884516862794541670, 0.884540187099891350, 0.884563509193890710, +0.884586829076481120, 0.884610146747605080, 0.884633462207203070, 0.884656775455217480, 0.884680086491590020, 0.884703395316262300, 0.884726701929176020, 0.884750006330273010, +0.884773308519495090, 0.884796608496784210, 0.884819906262081400, 0.884843201815328830, 0.884866495156468310, 0.884889786285441570, 0.884913075202190310, 0.884936361906656370, +0.884959646398781890, 0.884982928678507920, 0.885006208745776620, 0.885029486600529820, 0.885052762242709350, 0.885076035672256900, 0.885099306889114310, 0.885122575893223520, +0.885145842684526780, 0.885169107262964940, 0.885192369628480360, 0.885215629781014760, 0.885238887720510180, 0.885262143446908350, 0.885285396960151180, 0.885308648260180520, +0.885331897346938730, 0.885355144220366650, 0.885378388880406760, 0.885401631327000890, 0.885424871560090980, 0.885448109579618840, 0.885471345385526520, 0.885494578977756190, +0.885517810356248880, 0.885541039520947200, 0.885564266471792870, 0.885587491208727930, 0.885610713731694200, 0.885633934040633730, 0.885657152135488350, 0.885680368016200540, +0.885703581682711460, 0.885726793134963280, 0.885750002372898250, 0.885773209396458210, 0.885796414205585080, 0.885819616800220920, 0.885842817180307770, 0.885866015345788020, +0.885889211296602700, 0.885912405032694420, 0.885935596554005110, 0.885958785860476830, 0.885981972952051610, 0.886005157828671400, 0.886028340490278790, 0.886051520936814830, +0.886074699168222120, 0.886097875184442610, 0.886121048985418440, 0.886144220571091660, 0.886167389941404320, 0.886190557096298460, 0.886213722035716690, 0.886236884759600160, +0.886260045267891480, 0.886283203560532700, 0.886306359637465850, 0.886329513498633090, 0.886352665143976590, 0.886375814573438840, 0.886398961786961090, 0.886422106784485960, +0.886445249565955500, 0.886468390131312070, 0.886491528480497500, 0.886514664613454180, 0.886537798530124270, 0.886560930230450240, 0.886584059714373370, 0.886607186981836490, +0.886630312032781530, 0.886653434867150870, 0.886676555484886550, 0.886699673885930960, 0.886722790070226030, 0.886745904037714690, 0.886769015788338110, 0.886792125322038990, +0.886815232638759500, 0.886838337738442010, 0.886861440621028670, 0.886884541286461660, 0.886907639734683780, 0.886930735965636430, 0.886953829979262090, 0.886976921775503360, +0.887000011354302180, 0.887023098715601030, 0.887046183859342090, 0.887069266785467710, 0.887092347493920630, 0.887115425984642210, 0.887138502257575290, 0.887161576312662010, +0.887184648149844880, 0.887207717769066150, 0.887230785170268100, 0.887253850353392990, 0.887276913318383760, 0.887299974065181800, 0.887323032593729910, 0.887346088903970490, +0.887369142995845790, 0.887392194869298320, 0.887415244524270230, 0.887438291960704560, 0.887461337178542700, 0.887484380177727460, 0.887507420958201340, 0.887530459519906610, +0.887553495862785760, 0.887576529986781160, 0.887599561891835200, 0.887622591577890810, 0.887645619044889480, 0.887668644292774140, 0.887691667321487190, 0.887714688130971100, +0.887737706721168250, 0.887760723092021140, 0.887783737243472590, 0.887806749175464320, 0.887829758887939250, 0.887852766380839650, 0.887875771654108250, 0.887898774707687300, +0.887921775541519520, 0.887944774155547290, 0.887967770549713540, 0.887990764723959880, 0.888013756678229350, 0.888036746412464440, 0.888059733926607640, 0.888082719220601560, +0.888105702294388680, 0.888128683147911490, 0.888151661781113040, 0.888174638193934940, 0.888197612386320330, 0.888220584358211720, 0.888243554109551580, 0.888266521640282520, +0.888289486950347260, 0.888312450039688620, 0.888335410908248520, 0.888358369555969810, 0.888381325982795180, 0.888404280188667350, 0.888427232173528700, 0.888450181937322060, +0.888473129479989910, 0.888496074801475300, 0.888519017901720170, 0.888541958780667440, 0.888564897438259840, 0.888587833874440070, 0.888610768089150630, 0.888633700082334220, +0.888656629853933680, 0.888679557403891930, 0.888702482732150910, 0.888725405838653560, 0.888748326723342810, 0.888771245386161260, 0.888794161827051510, 0.888817076045956390, +0.888839988042818940, 0.888862897817581210, 0.888885805370186240, 0.888908710700576640, 0.888931613808695340, 0.888954514694485050, 0.888977413357888380, 0.889000309798848250, +0.889023204017307720, 0.889046096013208720, 0.889068985786494630, 0.889091873337107930, 0.889114758664991570, 0.889137641770088360, 0.889160522652341020, 0.889183401311692820, +0.889206277748085690, 0.889229151961462900, 0.889252023951767170, 0.889274893718941420, 0.889297761262928370, 0.889320626583670950, 0.889343489681111990, 0.889366350555194750, +0.889389209205861180, 0.889412065633054530, 0.889434919836717740, 0.889457771816793750, 0.889480621573225270, 0.889503469105955240, 0.889526314414926470, 0.889549157500082340, +0.889571998361365020, 0.889594836998717660, 0.889617673412083090, 0.889640507601404450, 0.889663339566624580, 0.889686169307686290, 0.889708996824532970, 0.889731822117106770, +0.889754645185350970, 0.889777466029208600, 0.889800284648622600, 0.889823101043535900, 0.889845915213891450, 0.889868727159632170, 0.889891536880701440, 0.889914344377041530, +0.889937149648595720, 0.889959952695307030, 0.889982753517118530, 0.890005552113973030, 0.890028348485813690, 0.890051142632583560, 0.890073934554225900, 0.890096724250682980, +0.890119511721898290, 0.890142296967814880, 0.890165079988375680, 0.890187860783523740, 0.890210639353202220, 0.890233415697354480, 0.890256189815922800, 0.890278961708850570, +0.890301731376081040, 0.890324498817557150, 0.890347264033221950, 0.890370027023018710, 0.890392787786890240, 0.890415546324780370, 0.890438302636631150, 0.890461056722386180, +0.890483808581988610, 0.890506558215381380, 0.890529305622507870, 0.890552050803311120, 0.890574793757734630, 0.890597534485720770, 0.890620272987213020, 0.890643009262154560, +0.890665743310488640, 0.890688475132158320, 0.890711204727106850, 0.890733932095277400, 0.890756657236613460, 0.890779380151057510, 0.890802100838553050, 0.890824819299043340, +0.890847535532471650, 0.890870249538781130, 0.890892961317914960, 0.890915670869816380, 0.890938378194429000, 0.890961083291695320, 0.890983786161558930, 0.891006486803962990, +0.891029185218850880, 0.891051881406165870, 0.891074575365851110, 0.891097267097850310, 0.891119956602105970, 0.891142643878561680, 0.891165328927160830, 0.891188011747846680, +0.891210692340562490, 0.891233370705251550, 0.891256046841857110, 0.891278720750323110, 0.891301392430591810, 0.891324061882607040, 0.891346729106312070, 0.891369394101650280, +0.891392056868565150, 0.891414717406999730, 0.891437375716897520, 0.891460031798202320, 0.891482685650856640, 0.891505337274804300, 0.891527986669988560, 0.891550633836352800, +0.891573278773840520, 0.891595921482395080, 0.891618561961960210, 0.891641200212478500, 0.891663836233893780, 0.891686470026149540, 0.891709101589189030, 0.891731730922955880, +0.891754358027393330, 0.891776982902444890, 0.891799605548054370, 0.891822225964164490, 0.891844844150719070, 0.891867460107661490, 0.891890073834935240, 0.891912685332483800, +0.891935294600250670, 0.891957901638179670, 0.891980506446213630, 0.892003109024296250, 0.892025709372371130, 0.892048307490381660, 0.892070903378271440, 0.892093497035984060, +0.892116088463462800, 0.892138677660651800, 0.892161264627493680, 0.892183849363932470, 0.892206431869911550, 0.892229012145374530, 0.892251590190265120, 0.892274166004526580, +0.892296739588102740, 0.892319310940937300, 0.892341880062973320, 0.892364446954154620, 0.892387011614424800, 0.892409574043727450, 0.892432134242006180, 0.892454692209204480, +0.892477247945266510, 0.892499801450135080, 0.892522352723754130, 0.892544901766067270, 0.892567448577018090, 0.892589993156550410, 0.892612535504607620, 0.892635075621133640, +0.892657613506072200, 0.892680149159366440, 0.892702682580960310, 0.892725213770797500, 0.892747742728821510, 0.892770269454976280, 0.892792793949205410, 0.892815316211452940, +0.892837836241661690, 0.892860354039775930, 0.892882869605739260, 0.892905382939495400, 0.892927894040988050, 0.892950402910161030, 0.892972909546957960, 0.892995413951323090, +0.893017916123199250, 0.893040416062530600, 0.893062913769260950, 0.893085409243333910, 0.893107902484693410, 0.893130393493283160, 0.893152882269046990, 0.893175368811928940, +0.893197853121872050, 0.893220335198820600, 0.893242815042718300, 0.893265292653508960, 0.893287768031136300, 0.893310241175544250, 0.893332712086677080, 0.893355180764477730, +0.893377647208890350, 0.893400111419858870, 0.893422573397327110, 0.893445033141239020, 0.893467490651538190, 0.893489945928168770, 0.893512398971074820, 0.893534849780199480, +0.893557298355486920, 0.893579744696881280, 0.893602188804326180, 0.893624630677765650, 0.893647070317143520, 0.893669507722403720, 0.893691942893490520, 0.893714375830347070, +0.893736806532917760, 0.893759235001146400, 0.893781661234976930, 0.893804085234353280, 0.893826506999219510, 0.893848926529519750, 0.893871343825197400, 0.893893758886196600, +0.893916171712461400, 0.893938582303935860, 0.893960990660563780, 0.893983396782289220, 0.894005800669056220, 0.894028202320809040, 0.894050601737491070, 0.894072998919046570, +0.894095393865419470, 0.894117786576553940, 0.894140177052394010, 0.894162565292883630, 0.894184951297967160, 0.894207335067587980, 0.894229716601690370, 0.894252095900218590, +0.894274472963116460, 0.894296847790328250, 0.894319220381797790, 0.894341590737469440, 0.894363958857287370, 0.894386324741195060, 0.894408688389137010, 0.894431049801057140, +0.894453408976899620, 0.894475765916608710, 0.894498120620128350, 0.894520473087402570, 0.894542823318376090, 0.894565171312992180, 0.894587517071195330, 0.894609860592929680, +0.894632201878139300, 0.894654540926768550, 0.894676877738761370, 0.894699212314062460, 0.894721544652615000, 0.894743874754363790, 0.894766202619252880, 0.894788528247226430, +0.894810851638228600, 0.894833172792203760, 0.894855491709095950, 0.894877808388849780, 0.894900122831408740, 0.894922435036717310, 0.894944745004719880, 0.894967052735360590, +0.894989358228583610, 0.895011661484333200, 0.895033962502553740, 0.895056261283189710, 0.895078557826184620, 0.895100852131483160, 0.895123144199029610, 0.895145434028768120, +0.895167721620643060, 0.895190006974598720, 0.895212290090579790, 0.895234570968529760, 0.895256849608393250, 0.895279126010114610, 0.895301400173638130, 0.895323672098908170, +0.895345941785869130, 0.895368209234465140, 0.895390474444641040, 0.895412737416340310, 0.895434998149507780, 0.895457256644087820, 0.895479512900024590, 0.895501766917262690, +0.895524018695746270, 0.895546268235420270, 0.895568515536228180, 0.895590760598114820, 0.895613003421024570, 0.895635244004901800, 0.895657482349690890, 0.895679718455336340, +0.895701952321782400, 0.895724183948974020, 0.895746413336854790, 0.895768640485369530, 0.895790865394462730, 0.895813088064078670, 0.895835308494161930, 0.895857526684656900, +0.895879742635508070, 0.895901956346660260, 0.895924167818057170, 0.895946377049643750, 0.895968584041364260, 0.895990788793163410, 0.896012991304985460, 0.896035191576775140, +0.896057389608477250, 0.896079585400035410, 0.896101778951394650, 0.896123970262499460, 0.896146159333294330, 0.896168346163723760, 0.896190530753732340, 0.896212713103264670, +0.896234893212265570, 0.896257071080678760, 0.896279246708449380, 0.896301420095521830, 0.896323591241840800, 0.896345760147350680, 0.896367926811996290, 0.896390091235722000, +0.896412253418472860, 0.896434413360192690, 0.896456571060826550, 0.896478726520318900, 0.896500879738614590, 0.896523030715657980, 0.896545179451393780, 0.896567325945767050, +0.896589470198721590, 0.896611612210202470, 0.896633751980154270, 0.896655889508521710, 0.896678024795249500, 0.896700157840282120, 0.896722288643564400, 0.896744417205041390, +0.896766543524656900, 0.896788667602356090, 0.896810789438083570, 0.896832909031784140, 0.896855026383402310, 0.896877141492883000, 0.896899254360171260, 0.896921364985210910, +0.896943473367947220, 0.896965579508324780, 0.896987683406288540, 0.897009785061782970, 0.897031884474752910, 0.897053981645143160, 0.897076076572898900, 0.897098169257964040, +0.897120259700283750, 0.897142347899802740, 0.897164433856465940, 0.897186517570218060, 0.897208599041003920, 0.897230678268768230, 0.897252755253456160, 0.897274829995011960, +0.897296902493380570, 0.897318972748507030, 0.897341040760335940, 0.897363106528812350, 0.897385170053880850, 0.897407231335486940, 0.897429290373574550, 0.897451347168088940, +0.897473401718974940, 0.897495454026177470, 0.897517504089641370, 0.897539551909311450, 0.897561597485132650, 0.897583640817050220, 0.897605681905008450, 0.897627720748952360, +0.897649757348826900, 0.897671791704577230, 0.897693823816147930, 0.897715853683484170, 0.897737881306530760, 0.897759906685232980, 0.897781929819535090, 0.897803950709382350, +0.897825969354719700, 0.897847985755492180, 0.897869999911644730, 0.897892011823122170, 0.897914021489870100, 0.897936028911832440, 0.897958034088954800, 0.897980037021182120, +0.898002037708459320, 0.898024036150731340, 0.898046032347943330, 0.898068026300040230, 0.898090018006967530, 0.898112007468669260, 0.898133994685091030, 0.898155979656177880, +0.898177962381874750, 0.898199942862126680, 0.898221921096878710, 0.898243897086076440, 0.898265870829664030, 0.898287842327586850, 0.898309811579790060, 0.898331778586218820, +0.898353743346818060, 0.898375705861533040, 0.898397666130308690, 0.898419624153090620, 0.898441579929822990, 0.898463533460451490, 0.898485484744921180, 0.898507433783177100, +0.898529380575164520, 0.898551325120828360, 0.898573267420114010, 0.898595207472966840, 0.898617145279331230, 0.898639080839152780, 0.898661014152376650, 0.898682945218947870, +0.898704874038811830, 0.898726800611913570, 0.898748724938198800, 0.898770647017611780, 0.898792566850098120, 0.898814484435602970, 0.898836399774071700, 0.898858312865449370, +0.898880223709681350, 0.898902132306712680, 0.898924038656489180, 0.898945942758955010, 0.898967844614056100, 0.898989744221737610, 0.899011641581944690, 0.899033536694622710, +0.899055429559716960, 0.899077320177172900, 0.899099208546935150, 0.899121094668949410, 0.899142978543161050, 0.899164860169515130, 0.899186739547957030, 0.899208616678432100, +0.899230491560885640, 0.899252364195263440, 0.899274234581509790, 0.899296102719570610, 0.899317968609391170, 0.899339832250916850, 0.899361693644092910, 0.899383552788864730, +0.899405409685177680, 0.899427264332977590, 0.899449116732208840, 0.899470966882817250, 0.899492814784748410, 0.899514660437947370, 0.899536503842359720, 0.899558344997930860, +0.899580183904606480, 0.899602020562331290, 0.899623854971051130, 0.899645687130711140, 0.899667517041257030, 0.899689344702634180, 0.899711170114787850, 0.899732993277663760, +0.899754814191207400, 0.899776632855363690, 0.899798449270078460, 0.899820263435297090, 0.899842075350964940, 0.899863885017027740, 0.899885692433430750, 0.899907497600119570, +0.899929300517040010, 0.899951101184136790, 0.899972899601355850, 0.899994695768642660, 0.900016489685942720, 0.900038281353201520, 0.900060070770364760, 0.900081857937378050, +0.900103642854186430, 0.900125425520735600, 0.900147205936971280, 0.900168984102838850, 0.900190760018284020, 0.900212533683252380, 0.900234305097689310, 0.900256074261540860, +0.900277841174751850, 0.900299605837268200, 0.900321368249035640, 0.900343128409999530, 0.900364886320105700, 0.900386641979299630, 0.900408395387527370, 0.900430146544733630, +0.900451895450864570, 0.900473642105865890, 0.900495386509682970, 0.900517128662261630, 0.900538868563547480, 0.900560606213486100, 0.900582341612023660, 0.900604074759104980, +0.900625805654676090, 0.900647534298682610, 0.900669260691070450, 0.900690984831785000, 0.900712706720772190, 0.900734426357977510, 0.900756143743347230, 0.900777858876826150, +0.900799571758360560, 0.900821282387895940, 0.900842990765378100, 0.900864696890752770, 0.900886400763965760, 0.900908102384963110, 0.900929801753689750, 0.900951498870091960, +0.900973193734115440, 0.900994886345705900, 0.901016576704809170, 0.901038264811370950, 0.901059950665337060, 0.901081634266653770, 0.901103315615265910, 0.901124994711119840, +0.901146671554161170, 0.901168346144335940, 0.901190018481589860, 0.901211688565868640, 0.901233356397118210, 0.901255021975284840, 0.901276685300313460, 0.901298346372150450, +0.901320005190741510, 0.901341661756032590, 0.901363316067969490, 0.901384968126498150, 0.901406617931564740, 0.901428265483114390, 0.901449910781093380, 0.901471553825447520, +0.901493194616122870, 0.901514833153065240, 0.901536469436220570, 0.901558103465534670, 0.901579735240953810, 0.901601364762423360, 0.901622992029889380, 0.901644617043298010, +0.901666239802595080, 0.901687860307726520, 0.901709478558638370, 0.901731094555276890, 0.901752708297587250, 0.901774319785515810, 0.901795929019008620, 0.901817535998011620, +0.901839140722470840, 0.901860743192332110, 0.901882343407541590, 0.901903941368045530, 0.901925537073789200, 0.901947130524719090, 0.901968721720781240, 0.901990310661921480, +0.902011897348085960, 0.902033481779220710, 0.902055063955271690, 0.902076643876185470, 0.902098221541907220, 0.902119796952383420, 0.902141370107560130, 0.902162941007383480, +0.902184509651799420, 0.902206076040754090, 0.902227640174193990, 0.902249202052064380, 0.902270761674311750, 0.902292319040882140, 0.902313874151721820, 0.902335427006776820, +0.902356977605993320, 0.902378525949317220, 0.902400072036695260, 0.902421615868072790, 0.902443157443396200, 0.902464696762611760, 0.902486233825665620, 0.902507768632503820, +0.902529301183072620, 0.902550831477318180, 0.902572359515187110, 0.902593885296624650, 0.902615408821577540, 0.902636930089991910, 0.902658449101813920, 0.902679965856989730, +0.902701480355465710, 0.902722992597188470, 0.902744502582103260, 0.902766010310156800, 0.902787515781295240, 0.902809018995465060, 0.902830519952612210, 0.902852018652683050, +0.902873515095623970, 0.902895009281381330, 0.902916501209900860, 0.902937990881129140, 0.902959478295012440, 0.902980963451497030, 0.903002446350529290, 0.903023926992055360, +0.903045405376021960, 0.903066881502374800, 0.903088355371060250, 0.903109826982024910, 0.903131296335215050, 0.903152763430576930, 0.903174228268056820, 0.903195690847601210, +0.903217151169156680, 0.903238609232668970, 0.903260065038084760, 0.903281518585350330, 0.903302969874412160, 0.903324418905216530, 0.903345865677709800, 0.903367310191838470, +0.903388752447549240, 0.903410192444787710, 0.903431630183500810, 0.903453065663634700, 0.903474498885135980, 0.903495929847951020, 0.903517358552026200, 0.903538784997308440, +0.903560209183743250, 0.903581631111277540, 0.903603050779857810, 0.903624468189430430, 0.903645883339941890, 0.903667296231338680, 0.903688706863567170, 0.903710115236574300, +0.903731521350305770, 0.903752925204708400, 0.903774326799728690, 0.903795726135313230, 0.903817123211408500, 0.903838518027960890, 0.903859910584916990, 0.903881300882223630, +0.903902688919826720, 0.903924074697673110, 0.903945458215709260, 0.903966839473881790, 0.903988218472137170, 0.904009595210422120, 0.904030969688683350, 0.904052341906866790, +0.904073711864919470, 0.904095079562787780, 0.904116445000418430, 0.904137808177757910, 0.904159169094752910, 0.904180527751350050, 0.904201884147496140, 0.904223238283137220, +0.904244590158220230, 0.904265939772691650, 0.904287287126498310, 0.904308632219586680, 0.904329975051903600, 0.904351315623395770, 0.904372653934009450, 0.904393989983691360, +0.904415323772388420, 0.904436655300047130, 0.904457984566614190, 0.904479311572036200, 0.904500636316260100, 0.904521958799232690, 0.904543279020900040, 0.904564596981209170, +0.904585912680106800, 0.904607226117539630, 0.904628537293454380, 0.904649846207797870, 0.904671152860516690, 0.904692457251558000, 0.904713759380867840, 0.904735059248393260, +0.904756356854081070, 0.904777652197877870, 0.904798945279730700, 0.904820236099586060, 0.904841524657391210, 0.904862810953092180, 0.904884094986636130, 0.904905376757969890, +0.904926656267040160, 0.904947933513793770, 0.904969208498177520, 0.904990481220138370, 0.905011751679623330, 0.905033019876578470, 0.905054285810951150, 0.905075549482688090, +0.905096810891736100, 0.905118070038042230, 0.905139326921553080, 0.905160581542215900, 0.905181833899977080, 0.905203083994783550, 0.905224331826582350, 0.905245577395320300, +0.905266820700944330, 0.905288061743401370, 0.905309300522638140, 0.905330537038602110, 0.905351771291239340, 0.905373003280497080, 0.905394233006322380, 0.905415460468662170, +0.905436685667463160, 0.905457908602672500, 0.905479129274237130, 0.905500347682104190, 0.905521563826220070, 0.905542777706532130, 0.905563989322987100, 0.905585198675532220, +0.905606405764114220, 0.905627610588680240, 0.905648813149177670, 0.905670013445552650, 0.905691211477752670, 0.905712407245724550, 0.905733600749415450, 0.905754791988772400, +0.905775980963742340, 0.905797167674272320, 0.905818352120309700, 0.905839534301800860, 0.905860714218693190, 0.905881891870933820, 0.905903067258469590, 0.905924240381247750, +0.905945411239215350, 0.905966579832319320, 0.905987746160507370, 0.906008910223725540, 0.906030072021921540, 0.906051231555042300, 0.906072388823034980, 0.906093543825846610, +0.906114696563424470, 0.906135847035716040, 0.906156995242667460, 0.906178141184226460, 0.906199284860340180, 0.906220426270955560, 0.906241565416019970, 0.906262702295480450, +0.906283836909284160, 0.906304969257378690, 0.906326099339710310, 0.906347227156226840, 0.906368352706875210, 0.906389475991602690, 0.906410597010356530, 0.906431715763083790, +0.906452832249732280, 0.906473946470248150, 0.906495058424579230, 0.906516168112672660, 0.906537275534475720, 0.906558380689935550, 0.906579483578999420, 0.906600584201614600, +0.906621682557728680, 0.906642778647288150, 0.906663872470240720, 0.906684964026533650, 0.906706053316114090, 0.906727140338929430, 0.906748225094926920, 0.906769307584053830, +0.906790387806257870, 0.906811465761485520, 0.906832541449684610, 0.906853614870802290, 0.906874686024785830, 0.906895754911582810, 0.906916821531140280, 0.906937885883406180, +0.906958947968326990, 0.906980007785850310, 0.907001065335923730, 0.907022120618494410, 0.907043173633509840, 0.907064224380917270, 0.907085272860664200, 0.907106319072698340, +0.907127363016966280, 0.907148404693415840, 0.907169444101994290, 0.907190481242649230, 0.907211516115327910, 0.907232548719977830, 0.907253579056546360, 0.907274607124981420, +0.907295632925229410, 0.907316656457238470, 0.907337677720955860, 0.907358696716328960, 0.907379713443305370, 0.907400727901832570, 0.907421740091858280, 0.907442750013329190, +0.907463757666193360, 0.907484763050398050, 0.907505766165890850, 0.907526767012619140, 0.907547765590530630, 0.907568761899572700, 0.907589755939693270, 0.907610747710838940, +0.907631737212957870, 0.907652724445997430, 0.907673709409905220, 0.907694692104628610, 0.907715672530115310, 0.907736650686313260, 0.907757626573169160, 0.907778600190631060, +0.907799571538646430, 0.907820540617162890, 0.907841507426127900, 0.907862471965489190, 0.907883434235194350, 0.907904394235191310, 0.907925351965426900, 0.907946307425849030, +0.907967260616405420, 0.907988211537043680, 0.908009160187711490, 0.908030106568356250, 0.908051050678925890, 0.908071992519368210, 0.908092932089630160, 0.908113869389659770, +0.908134804419404750, 0.908155737178812710, 0.908176667667831230, 0.908197595886408250, 0.908218521834491590, 0.908239445512028180, 0.908260366918966170, 0.908281286055253380, +0.908302202920837190, 0.908323117515665630, 0.908344029839686210, 0.908364939892846720, 0.908385847675095340, 0.908406753186378870, 0.908427656426645470, 0.908448557395843070, +0.908469456093919160, 0.908490352520821660, 0.908511246676498300, 0.908532138560896870, 0.908553028173965330, 0.908573915515650920, 0.908594800585901700, 0.908615683384665580, +0.908636563911890070, 0.908657442167523310, 0.908678318151512900, 0.908699191863806990, 0.908720063304352840, 0.908740932473098510, 0.908761799369991800, 0.908782663994980640, +0.908803526348012760, 0.908824386429036070, 0.908845244237998510, 0.908866099774848110, 0.908886953039532150, 0.908907804031998780, 0.908928652752195920, 0.908949499200071400, +0.908970343375573140, 0.908991185278649080, 0.909012024909247370, 0.909032862267315170, 0.909053697352800950, 0.909074530165652320, 0.909095360705817530, 0.909116188973244200, +0.909137014967880460, 0.909157838689674260, 0.909178660138573740, 0.909199479314526270, 0.909220296217480020, 0.909241110847383020, 0.909261923204183310, 0.909282733287828830, +0.909303541098267390, 0.909324346635447260, 0.909345149899316470, 0.909365950889822530, 0.909386749606913680, 0.909407546050537970, 0.909428340220643340, 0.909449132117177930, +0.909469921740089670, 0.909490709089327050, 0.909511494164837230, 0.909532276966568580, 0.909553057494469350, 0.909573835748487490, 0.909594611728570920, 0.909615385434667910, +0.909636156866726500, 0.909656926024694950, 0.909677692908520740, 0.909698457518152370, 0.909719219853537760, 0.909739979914625190, 0.909760737701362570, 0.909781493213698170, +0.909802246451580030, 0.909822997414956650, 0.909843746103775390, 0.909864492517984740, 0.909885236657532960, 0.909905978522367990, 0.909926718112438080, 0.909947455427691400, +0.909968190468076530, 0.909988923233540750, 0.910009653724032640, 0.910030381939500370, 0.910051107879892180, 0.910071831545156250, 0.910092552935240720, 0.910113272050093740, +0.910133988889664010, 0.910154703453898930, 0.910175415742747180, 0.910196125756156830, 0.910216833494076120, 0.910237538956453320, 0.910258242143236700, 0.910278943054374850, +0.910299641689815360, 0.910320338049506630, 0.910341032133397120, 0.910361723941435000, 0.910382413473568630, 0.910403100729746170, 0.910423785709916000, 0.910444468414026710, +0.910465148842025900, 0.910485826993862160, 0.910506502869483870, 0.910527176468839410, 0.910547847791876920, 0.910568516838544780, 0.910589183608791490, 0.910609848102565510, +0.910630510319814570, 0.910651170260487360, 0.910671827924532160, 0.910692483311897450, 0.910713136422531490, 0.910733787256382770, 0.910754435813399880, 0.910775082093530530, +0.910795726096723550, 0.910816367822927190, 0.910837007272089940, 0.910857644444160060, 0.910878279339086270, 0.910898911956816600, 0.910919542297300100, 0.910940170360484360, +0.910960796146318200, 0.910981419654750100, 0.911002040885728450, 0.911022659839201610, 0.911043276515118180, 0.911063890913426880, 0.911084503034075510, 0.911105112877012900, +0.911125720442187540, 0.911146325729547790, 0.911166928739042370, 0.911187529470619540, 0.911208127924227900, 0.911228724099816260, 0.911249317997332440, 0.911269909616725380, +0.911290498957943560, 0.911311086020935360, 0.911331670805649590, 0.911352253312034620, 0.911372833540038950, 0.911393411489611620, 0.911413987160700430, 0.911434560553254220, +0.911455131667221590, 0.911475700502551110, 0.911496267059191510, 0.911516831337091160, 0.911537393336199100, 0.911557953056463140, 0.911578510497832340, 0.911599065660255280, +0.911619618543680570, 0.911640169148056790, 0.911660717473332550, 0.911681263519456550, 0.911701807286377730, 0.911722348774044120, 0.911742887982404550, 0.911763424911407830, +0.911783959561002440, 0.911804491931137220, 0.911825022021760860, 0.911845549832821840, 0.911866075364269220, 0.911886598616051260, 0.911907119588116650, 0.911927638280414230, +0.911948154692892810, 0.911968668825500980, 0.911989180678187460, 0.912009690250901390, 0.912030197543590710, 0.912050702556204460, 0.912071205288691570, 0.912091705741000620, +0.912112203913080340, 0.912132699804879650, 0.912153193416347150, 0.912173684747432100, 0.912194173798082430, 0.912214660568247290, 0.912235145057875510, 0.912255627266915890, +0.912276107195317270, 0.912296584843028340, 0.912317060209998250, 0.912337533296175170, 0.912358004101508250, 0.912378472625946400, 0.912398938869438240, 0.912419402831932790, +0.912439864513378880, 0.912460323913725340, 0.912480781032921300, 0.912501235870914920, 0.912521688427655460, 0.912542138703091750, 0.912562586697172720, 0.912583032409847280, +0.912603475841064160, 0.912623916990772390, 0.912644355858921230, 0.912664792445458840, 0.912685226750334370, 0.912705658773496850, 0.912726088514895230, 0.912746515974478420, +0.912766941152195250, 0.912787364047995100, 0.912807784661826220, 0.912828202993637870, 0.912848619043378990, 0.912869032810998630, 0.912889444296445580, 0.912909853499669020, +0.912930260420617760, 0.912950665059241160, 0.912971067415487610, 0.912991467489306370, 0.913011865280646480, 0.913032260789456980, 0.913052654015686800, 0.913073044959284870, +0.913093433620200460, 0.913113819998382810, 0.913134204093780210, 0.913154585906342130, 0.913174965436017510, 0.913195342682755600, 0.913215717646505220, 0.913236090327215640, +0.913256460724836130, 0.913276828839315160, 0.913297194670602110, 0.913317558218646020, 0.913337919483396040, 0.913358278464801330, 0.913378635162810810, 0.913398989577373870, +0.913419341708439640, 0.913439691555956830, 0.913460039119874720, 0.913480384400142560, 0.913500727396709400, 0.913521068109524380, 0.913541406538536770, 0.913561742683696050, +0.913582076544950490, 0.913602408122249800, 0.913622737415543120, 0.913643064424779490, 0.913663389149908300, 0.913683711590878580, 0.913704031747639590, 0.913724349620140930, +0.913744665208330980, 0.913764978512159430, 0.913785289531575450, 0.913805598266528070, 0.913825904716966900, 0.913846208882840850, 0.913866510764099300, 0.913886810360691860, +0.913907107672567000, 0.913927402699674430, 0.913947695441963300, 0.913967985899383000, 0.913988274071882660, 0.914008559959411660, 0.914028843561919600, 0.914049124879355080, +0.914069403911667800, 0.914089680658807020, 0.914109955120721910, 0.914130227297362040, 0.914150497188676580, 0.914170764794614790, 0.914191030115126480, 0.914211293150160360, +0.914231553899665930, 0.914251812363592540, 0.914272068541889690, 0.914292322434506640, 0.914312574041392880, 0.914332823362497550, 0.914353070397770580, 0.914373315147160580, +0.914393557610617250, 0.914413797788090070, 0.914434035679528410, 0.914454271284881660, 0.914474504604099180, 0.914494735637130910, 0.914514964383925320, 0.914535190844432360, +0.914555415018601380, 0.914575636906381990, 0.914595856507723350, 0.914616073822575150, 0.914636288850886770, 0.914656501592608030, 0.914676712047687750, 0.914696920216075520, +0.914717126097721160, 0.914737329692573820, 0.914757531000583320, 0.914777730021698820, 0.914797926755870460, 0.914818121203046950, 0.914838313363178110, 0.914858503236213430, +0.914878690822102600, 0.914898876120794900, 0.914919059132240140, 0.914939239856387700, 0.914959418293187500, 0.914979594442588360, 0.914999768304540330, 0.915019939878992770, +0.915040109165895510, 0.915060276165197810, 0.915080440876849480, 0.915100603300800120, 0.915120763436999550, 0.915140921285396700, 0.915161076845941500, 0.915181230118583770, +0.915201381103272870, 0.915221529799958410, 0.915241676208590320, 0.915261820329118290, 0.915281962161491380, 0.915302101705659510, 0.915322238961572500, 0.915342373929179720, +0.915362506608431210, 0.915382636999276240, 0.915402765101664850, 0.915422890915546850, 0.915443014440871170, 0.915463135677588080, 0.915483254625647060, 0.915503371284997920, +0.915523485655590390, 0.915543597737374150, 0.915563707530298920, 0.915583815034314740, 0.915603920249370650, 0.915624023175416800, 0.915644123812402900, 0.915664222160278650, +0.915684318218993880, 0.915704411988498280, 0.915724503468742010, 0.915744592659674230, 0.915764679561244850, 0.915784764173403820, 0.915804846496100830, 0.915824926529285820, +0.915845004272908380, 0.915865079726918550, 0.915885152891266260, 0.915905223765900780, 0.915925292350772250, 0.915945358645830490, 0.915965422651025320, 0.915985484366306670, +0.916005543791624240, 0.916025600926928310, 0.916045655772168010, 0.916065708327293620, 0.916085758592254830, 0.916105806567001800, 0.916125852251484130, 0.916145895645651960, +0.916165936749455010, 0.916185975562843540, 0.916206012085766690, 0.916226046318174950, 0.916246078260018030, 0.916266107911245960, 0.916286135271808580, 0.916306160341655910, +0.916326183120737770, 0.916346203609004540, 0.916366221806405480, 0.916386237712890850, 0.916406251328410690, 0.916426262652914820, 0.916446271686353290, 0.916466278428676120, +0.916486282879833580, 0.916506285039775050, 0.916526284908450780, 0.916546282485810710, 0.916566277771804990, 0.916586270766383660, 0.916606261469496530, 0.916626249881093760, +0.916646236001125820, 0.916666219829541880, 0.916686201366292310, 0.916706180611327360, 0.916726157564596860, 0.916746132226051060, 0.916766104595639900, 0.916786074673313410, +0.916806042459022200, 0.916826007952715400, 0.916845971154343630, 0.916865932063857030, 0.916885890681205520, 0.916905847006339260, 0.916925801039208400, 0.916945752779763420, +0.916965702227953710, 0.916985649383729730, 0.917005594247041530, 0.917025536817839490, 0.917045477096073540, 0.917065415081693920, 0.917085350774650700, 0.917105284174894560, +0.917125215282374780, 0.917145144097041950, 0.917165070618846330, 0.917184994847738080, 0.917204916783667220, 0.917224836426584140, 0.917244753776439210, 0.917264668833182140, +0.917284581596763400, 0.917304492067133270, 0.917324400244241780, 0.917344306128039410, 0.917364209718476210, 0.917384111015502430, 0.917404010019068790, 0.917423906729124770, +0.917443801145620960, 0.917463693268507630, 0.917483583097735140, 0.917503470633253660, 0.917523355875013550, 0.917543238822964960, 0.917563119477058710, 0.917582997837244170, +0.917602873903472280, 0.917622747675693180, 0.917642619153857140, 0.917662488337914640, 0.917682355227815830, 0.917702219823511630, 0.917722082124951430, 0.917741942132086040, +0.917761799844865720, 0.917781655263240960, 0.917801508387162120, 0.917821359216579370, 0.917841207751443400, 0.917861053991704590, 0.917880897937312870, 0.917900739588218940, +0.917920578944373180, 0.917940416005725960, 0.917960250772227650, 0.917980083243828740, 0.917999913420479930, 0.918019741302131040, 0.918039566888732780, 0.918059390180235520, +0.918079211176589860, 0.918099029877746280, 0.918118846283654920, 0.918138660394266610, 0.918158472209531950, 0.918178281729400750, 0.918198088953823820, 0.918217893882751660, +0.918237696516134850, 0.918257496853923770, 0.918277294896068910, 0.918297090642520850, 0.918316884093230310, 0.918336675248147330, 0.918356464107222600, 0.918376250670406740, +0.918396034937650320, 0.918415816908903730, 0.918435596584117550, 0.918455373963242840, 0.918475149046229290, 0.918494921833027830, 0.918514692323589180, 0.918534460517863690, +0.918554226415802090, 0.918573990017354960, 0.918593751322472780, 0.918613510331106610, 0.918633267043206360, 0.918653021458722850, 0.918672773577606790, 0.918692523399808890, +0.918712270925279630, 0.918732016153969710, 0.918751759085829730, 0.918771499720810740, 0.918791238058862540, 0.918810974099936400, 0.918830707843982690, 0.918850439290952340, +0.918870168440795830, 0.918889895293463880, 0.918909619848907510, 0.918929342107076770, 0.918949062067922710, 0.918968779731396010, 0.918988495097447290, 0.919008208166027350, +0.919027918937086910, 0.919047627410576770, 0.919067333586447770, 0.919087037464650150, 0.919106739045134850, 0.919126438327852790, 0.919146135312754690, 0.919165829999791130, +0.919185522388913050, 0.919205212480071480, 0.919224900273216570, 0.919244585768299370, 0.919264268965270800, 0.919283949864081460, 0.919303628464682280, 0.919323304767024060, +0.919342978771057530, 0.919362650476733930, 0.919382319884003320, 0.919401986992816940, 0.919421651803125630, 0.919441314314880080, 0.919460974528031330, 0.919480632442530200, +0.919500288058327400, 0.919519941375374180, 0.919539592393620820, 0.919559241113018570, 0.919578887533518130, 0.919598531655070440, 0.919618173477626420, 0.919637813001137010, +0.919657450225553450, 0.919677085150825800, 0.919696717776905540, 0.919716348103743480, 0.919735976131290540, 0.919755601859497670, 0.919775225288315790, 0.919794846417695820, +0.919814465247589030, 0.919834081777945790, 0.919853696008717360, 0.919873307939854670, 0.919892917571308750, 0.919912524903030550, 0.919932129934970980, 0.919951732667081080, +0.919971333099312230, 0.919990931231614680, 0.920010527063939820, 0.920030120596238570, 0.920049711828462070, 0.920069300760561370, 0.920088887392487290, 0.920108471724191410, +0.920128053755624010, 0.920147633486736450, 0.920167210917479880, 0.920186786047805240, 0.920206358877663550, 0.920225929407006090, 0.920245497635783670, 0.920265063563947990, +0.920284627191449210, 0.920304188518238920, 0.920323747544268160, 0.920343304269487960, 0.920362858693849480, 0.920382410817303990, 0.920401960639802730, 0.920421508161296310, +0.920441053381735990, 0.920460596301073130, 0.920480136919258780, 0.920499675236243990, 0.920519211251980110, 0.920538744966418190, 0.920558276379509710, 0.920577805491205270, +0.920597332301456240, 0.920616856810213880, 0.920636379017429450, 0.920655898923053990, 0.920675416527038770, 0.920694931829335150, 0.920714444829894400, 0.920733955528667320, +0.920753463925605200, 0.920772970020659500, 0.920792473813781380, 0.920811975304922090, 0.920831474494032910, 0.920850971381065310, 0.920870465965969890, 0.920889958248698460, +0.920909448229201950, 0.920928935907431970, 0.920948421283339540, 0.920967904356876140, 0.920987385127992940, 0.921006863596641630, 0.921026339762772820, 0.921045813626338190, +0.921065285187289030, 0.921084754445576580, 0.921104221401152330, 0.921123686053967440, 0.921143148403973380, 0.921162608451121860, 0.921182066195363360, 0.921201521636649700, +0.921220974774932370, 0.921240425610162510, 0.921259874142291490, 0.921279320371270920, 0.921298764297052370, 0.921318205919586570, 0.921337645238825220, 0.921357082254719790, +0.921376516967221670, 0.921395949376282220, 0.921415379481852930, 0.921434807283885160, 0.921454232782330740, 0.921473655977140370, 0.921493076868265870, 0.921512495455658720, +0.921531911739270290, 0.921551325719052070, 0.921570737394955540, 0.921590146766932520, 0.921609553834933810, 0.921628958598911140, 0.921648361058816090, 0.921667761214600260, +0.921687159066214900, 0.921706554613611730, 0.921725947856742110, 0.921745338795557980, 0.921764727430010140, 0.921784113760050540, 0.921803497785630640, 0.921822879506701940, +0.921842258923216140, 0.921861636035124610, 0.921881010842379060, 0.921900383344931180, 0.921919753542732150, 0.921939121435733640, 0.921958487023887390, 0.921977850307144960, +0.921997211285457860, 0.922016569958777680, 0.922035926327056440, 0.922055280390245090, 0.922074632148295550, 0.922093981601159410, 0.922113328748788260, 0.922132673591133820, +0.922152016128147680, 0.922171356359781540, 0.922190694285987320, 0.922210029906716080, 0.922229363221919730, 0.922248694231549980, 0.922268022935558430, 0.922287349333896890, +0.922306673426516950, 0.922325995213370330, 0.922345314694409170, 0.922364631869584280, 0.922383946738847830, 0.922403259302151500, 0.922422569559447010, 0.922441877510686070, +0.922461183155820490, 0.922480486494802300, 0.922499787527582550, 0.922519086254113270, 0.922538382674346290, 0.922557676788233420, 0.922576968595726350, 0.922596258096776810, +0.922615545291336600, 0.922634830179357990, 0.922654112760791900, 0.922673393035590480, 0.922692671003705670, 0.922711946665089040, 0.922731220019692660, 0.922750491067468200, +0.922769759808367840, 0.922789026242342820, 0.922808290369345090, 0.922827552189326770, 0.922846811702239480, 0.922866068908035240, 0.922885323806665770, 0.922904576398082990, +0.922923826682239160, 0.922943074659085430, 0.922962320328573950, 0.922981563690656650, 0.923000804745285450, 0.923020043492412290, 0.923039279931989090, 0.923058514063967550, +0.923077745888300160, 0.923096975404937960, 0.923116202613833430, 0.923135427514938380, 0.923154650108204740, 0.923173870393584450, 0.923193088371029540, 0.923212304040492150, +0.923231517401923770, 0.923250728455276560, 0.923269937200502430, 0.923289143637553540, 0.923308347766381820, 0.923327549586939190, 0.923346749099177800, 0.923365946303049690, +0.923385141198506560, 0.923404333785500460, 0.923423524063983540, 0.923442712033907820, 0.923461897695225350, 0.923481081047888060, 0.923500262091848430, 0.923519440827057840, +0.923538617253468640, 0.923557791371033000, 0.923576963179702730, 0.923596132679430080, 0.923615299870167110, 0.923634464751865950, 0.923653627324478870, 0.923672787587957460, +0.923691945542254090, 0.923711101187320800, 0.923730254523109750, 0.923749405549573080, 0.923768554266662930, 0.923787700674331360, 0.923806844772530940, 0.923825986561213060, +0.923845126040330090, 0.923864263209834390, 0.923883398069678120, 0.923902530619813200, 0.923921660860192010, 0.923940788790767020, 0.923959914411489720, 0.923979037722312710, +0.923998158723188020, 0.924017277414067920, 0.924036393794904650, 0.924055507865650380, 0.924074619626257370, 0.924093729076678190, 0.924112836216864240, 0.924131941046768320, +0.924151043566342480, 0.924170143775538970, 0.924189241674310160, 0.924208337262608310, 0.924227430540385590, 0.924246521507594570, 0.924265610164186960, 0.924284696510115240, +0.924303780545331910, 0.924322862269788990, 0.924341941683439080, 0.924361018786234220, 0.924380093578127120, 0.924399166059069470, 0.924418236229013980, 0.924437304087912800, +0.924456369635718420, 0.924475432872383100, 0.924494493797859200, 0.924513552412099090, 0.924532608715055380, 0.924551662706679880, 0.924570714386925170, 0.924589763755743640, +0.924608810813087770, 0.924627855558909810, 0.924646897993162350, 0.924665938115797780, 0.924684975926768240, 0.924704011426026100, 0.924723044613523950, 0.924742075489214280, +0.924761104053049340, 0.924780130304981740, 0.924799154244963730, 0.924818175872948120, 0.924837195188886850, 0.924856212192732510, 0.924875226884437680, 0.924894239263954750, +0.924913249331236310, 0.924932257086234720, 0.924951262528902360, 0.924970265659192270, 0.924989266477056260, 0.925008264982447040, 0.925027261175317080, 0.925046255055618990, +0.925065246623305360, 0.925084235878328440, 0.925103222820641390, 0.925122207450195910, 0.925141189766944930, 0.925160169770841030, 0.925179147461836600, 0.925198122839884340, +0.925217095904936840, 0.925236066656946580, 0.925255035095866370, 0.925274001221648380, 0.925292965034245300, 0.925311926533609830, 0.925330885719694570, 0.925349842592452120, +0.925368797151834950, 0.925387749397795890, 0.925406699330287740, 0.925425646949262550, 0.925444592254673240, 0.925463535246472400, 0.925482475924612750, 0.925501414289046860, +0.925520350339727570, 0.925539284076607680, 0.925558215499639240, 0.925577144608775160, 0.925596071403968380, 0.925614995885171270, 0.925633918052336750, 0.925652837905417410, +0.925671755444366080, 0.925690670669135570, 0.925709583579678140, 0.925728494175946710, 0.925747402457894000, 0.925766308425472810, 0.925785212078635840, 0.925804113417335930, +0.925823012441525980, 0.925841909151158160, 0.925860803546185610, 0.925879695626561030, 0.925898585392237240, 0.925917472843166940, 0.925936357979303070, 0.925955240800598210, +0.925974121307005520, 0.925992999498477350, 0.926011875374966540, 0.926030748936426120, 0.926049620182808790, 0.926068489114067470, 0.926087355730154880, 0.926106220031023940, +0.926125082016627690, 0.926143941686918490, 0.926162799041849390, 0.926181654081373320, 0.926200506805443080, 0.926219357214011610, 0.926238205307031830, 0.926257051084456770, +0.926275894546238710, 0.926294735692331010, 0.926313574522686370, 0.926332411037257830, 0.926351245235998320, 0.926370077118860660, 0.926388906685797870, 0.926407733936763010, +0.926426558871708550, 0.926445381490587750, 0.926464201793353430, 0.926483019779958620, 0.926501835450356250, 0.926520648804499360, 0.926539459842340760, 0.926558268563833830, +0.926577074968931050, 0.926595879057585450, 0.926614680829750180, 0.926633480285378170, 0.926652277424422470, 0.926671072246836090, 0.926689864752572420, 0.926708654941583720, +0.926727442813823350, 0.926746228369244470, 0.926765011607799890, 0.926783792529442870, 0.926802571134126340, 0.926821347421803440, 0.926840121392427440, 0.926858893045950820, +0.926877662382326940, 0.926896429401508850, 0.926915194103449800, 0.926933956488102730, 0.926952716555420770, 0.926971474305357310, 0.926990229737864930, 0.927008982852896900, +0.927027733650406470, 0.927046482130346570, 0.927065228292670570, 0.927083972137331510, 0.927102713664282540, 0.927121452873477030, 0.927140189764867670, 0.927158924338407740, +0.927177656594050490, 0.927196386531749180, 0.927215114151456850, 0.927233839453126760, 0.927252562436712060, 0.927271283102166330, 0.927290001449441960, 0.927308717478492640, +0.927327431189271520, 0.927346142581731870, 0.927364851655826830, 0.927383558411509660, 0.927402262848733950, 0.927420964967452190, 0.927439664767618080, 0.927458362249184760, +0.927477057412105620, 0.927495750256333800, 0.927514440781822550, 0.927533128988525250, 0.927551814876395380, 0.927570498445385750, 0.927589179695449740, 0.927607858626540940, +0.927626535238612380, 0.927645209531617550, 0.927663881505509710, 0.927682551160242120, 0.927701218495768480, 0.927719883512041490, 0.927738546209014750, 0.927757206586641630, +0.927775864644875600, 0.927794520383669830, 0.927813173802977790, 0.927831824902753070, 0.927850473682948480, 0.927869120143517740, 0.927887764284414220, 0.927906406105591270, +0.927925045607002400, 0.927943682788600730, 0.927962317650339990, 0.927980950192173750, 0.927999580414054840, 0.928018208315936840, 0.928036833897773470, 0.928055457159517980, +0.928074078101123860, 0.928092696722544460, 0.928111313023733730, 0.928129927004644360, 0.928148538665230170, 0.928167148005444640, 0.928185755025241250, 0.928204359724573490, +0.928222962103394830, 0.928241562161658650, 0.928260159899318980, 0.928278755316328640, 0.928297348412641330, 0.928315939188210650, 0.928334527642990180, 0.928353113776933410, +0.928371697589993830, 0.928390279082124900, 0.928408858253280680, 0.928427435103414080, 0.928446009632478700, 0.928464581840428460, 0.928483151727216740, 0.928501719292797120, +0.928520284537123100, 0.928538847460148810, 0.928557408061827070, 0.928575966342111810, 0.928594522300956630, 0.928613075938315100, 0.928631627254140950, 0.928650176248387640, +0.928668722921008990, 0.928687267271958830, 0.928705809301190070, 0.928724349008656970, 0.928742886394312910, 0.928761421458111580, 0.928779954200006700, 0.928798484619952070, +0.928817012717901400, 0.928835538493807960, 0.928854061947625650, 0.928872583079308200, 0.928891101888809300, 0.928909618376082550, 0.928928132541081860, 0.928946644383760840, +0.928965153904073530, 0.928983661101972950, 0.929002165977413250, 0.929020668530348150, 0.929039168760731340, 0.929057666668516640, 0.929076162253657860, 0.929094655516108590, +0.929113146455822990, 0.929131635072754200, 0.929150121366856260, 0.929168605338083100, 0.929187086986388410, 0.929205566311726020, 0.929224043314049730, 0.929242517993313700, +0.929260990349470960, 0.929279460382475770, 0.929297928092281960, 0.929316393478843210, 0.929334856542113560, 0.929353317282046840, 0.929371775698596750, 0.929390231791717540, +0.929408685561362470, 0.929427137007485690, 0.929445586130041020, 0.929464032928982390, 0.929482477404263710, 0.929500919555838800, 0.929519359383661590, 0.929537796887686340, +0.929556232067866310, 0.929574664924155640, 0.929593095456508260, 0.929611523664878200, 0.929629949549219400, 0.929648373109485560, 0.929666794345631260, 0.929685213257609670, +0.929703629845374910, 0.929722044108881150, 0.929740456048082310, 0.929758865662932310, 0.929777272953385080, 0.929795677919394770, 0.929814080560915520, 0.929832480877900710, +0.929850878870304820, 0.929869274538081660, 0.929887667881185260, 0.929906058899569790, 0.929924447593189150, 0.929942833961997730, 0.929961218005948780, 0.929979599724996890, +0.929997979119095990, 0.930016356188200220, 0.930034730932263410, 0.930053103351239810, 0.930071473445083560, 0.930089841213748820, 0.930108206657189300, 0.930126569775359120, +0.930144930568212570, 0.930163289035703670, 0.930181645177786560, 0.930199998994415410, 0.930218350485544130, 0.930236699651127430, 0.930255046491118560, 0.930273391005472130, +0.930291733194142270, 0.930310073057083020, 0.930328410594248530, 0.930346745805593070, 0.930365078691071100, 0.930383409250636010, 0.930401737484242490, 0.930420063391844580, +0.930438386973396540, 0.930456708228852510, 0.930475027158166770, 0.930493343761293450, 0.930511658038187030, 0.930529969988801110, 0.930548279613090390, 0.930566586911008910, +0.930584891882510920, 0.930603194527550800, 0.930621494846082590, 0.930639792838060750, 0.930658088503439670, 0.930676381842173050, 0.930694672854215480, 0.930712961539521210, +0.930731247898044620, 0.930749531929739860, 0.930767813634561290, 0.930786093012463510, 0.930804370063400110, 0.930822644787325790, 0.930840917184194930, 0.930859187253961770, +0.930877454996580590, 0.930895720412005860, 0.930913983500191720, 0.930932244261093000, 0.930950502694663400, 0.930968758800857500, 0.930987012579629680, 0.931005264030934310, +0.931023513154725760, 0.931041759950958500, 0.931060004419587140, 0.931078246560565480, 0.931096486373848120, 0.931114723859389650, 0.931132959017144320, 0.931151191847066630, +0.931169422349110820, 0.931187650523231600, 0.931205876369383570, 0.931224099887520420, 0.931242321077597190, 0.931260539939568030, 0.931278756473387540, 0.931296970679010180, +0.931315182556390340, 0.931333392105482600, 0.931351599326241670, 0.931369804218621480, 0.931388006782576720, 0.931406207018061980, 0.931424404925031650, 0.931442600503440410, +0.931460793753242640, 0.931478984674393160, 0.931497173266845890, 0.931515359530555750, 0.931533543465477230, 0.931551725071564810, 0.931569904348773070, 0.931588081297056500, +0.931606255916369810, 0.931624428206667800, 0.931642598167904400, 0.931660765800034540, 0.931678931103012700, 0.931697094076793570, 0.931715254721331650, 0.931733413036581640, +0.931751569022498120, 0.931769722679036020, 0.931787874006149150, 0.931806023003792780, 0.931824169671921280, 0.931842314010489340, 0.931860456019451560, 0.931878595698762750, +0.931896733048377720, 0.931914868068250520, 0.931933000758336180, 0.931951131118589290, 0.931969259148964560, 0.931987384849416790, 0.932005508219900470, 0.932023629260370410, +0.932041747970781650, 0.932059864351088120, 0.932077978401244960, 0.932096090121206870, 0.932114199510928550, 0.932132306570364720, 0.932150411299470070, 0.932168513698199750, +0.932186613766507800, 0.932204711504349360, 0.932222806911679140, 0.932240899988451940, 0.932258990734622480, 0.932277079150145460, 0.932295165234975800, 0.932313248989068530, +0.932331330412377920, 0.932349409504858890, 0.932367486266466260, 0.932385560697155060, 0.932403632796879880, 0.932421702565595640, 0.932439770003257170, 0.932457835109819500, +0.932475897885236990, 0.932493958329464800, 0.932512016442457630, 0.932530072224170390, 0.932548125674558030, 0.932566176793575340, 0.932584225581177590, 0.932602272037318820, +0.932620316161954510, 0.932638357955039350, 0.932656397416528280, 0.932674434546376220, 0.932692469344538090, 0.932710501810968820, 0.932728531945623550, 0.932746559748456660, +0.932764585219423400, 0.932782608358478590, 0.932800629165577380, 0.932818647640674570, 0.932836663783725100, 0.932854677594683880, 0.932872689073506400, 0.932890698220146920, +0.932908705034560580, 0.932926709516702530, 0.932944711666527820, 0.932962711483991130, 0.932980708969047830, 0.932998704121652980, 0.933016696941761040, 0.933034687429327380, +0.933052675584307050, 0.933070661406654960, 0.933088644896326260, 0.933106626053275990, 0.933124604877459070, 0.933142581368830990, 0.933160555527346110, 0.933178527352959920, +0.933196496845627330, 0.933214464005303610, 0.933232428831943570, 0.933250391325502580, 0.933268351485935900, 0.933286309313198000, 0.933304264807244380, 0.933322217968030050, +0.933340168795510180, 0.933358117289639910, 0.933376063450374270, 0.933394007277668520, 0.933411948771478150, 0.933429887931757520, 0.933447824758462220, 0.933465759251547290, +0.933483691410967990, 0.933501621236679460, 0.933519548728636850, 0.933537473886795420, 0.933555396711110540, 0.933573317201536910, 0.933591235358030010, 0.933609151180544990, +0.933627064669037110, 0.933644975823461620, 0.933662884643773560, 0.933680791129928740, 0.933698695281881540, 0.933716597099587650, 0.933734496583002230, 0.933752393732080520, +0.933770288546777900, 0.933788181027049640, 0.933806071172850750, 0.933823958984137170, 0.933841844460863270, 0.933859727602984750, 0.933877608410456970, 0.933895486883235090, +0.933913363021274590, 0.933931236824530610, 0.933949108292958850, 0.933966977426514020, 0.933984844225151820, 0.934002708688827400, 0.934020570817496340, 0.934038430611113800, +0.934056288069635140, 0.934074143193015740, 0.934091995981211400, 0.934109846434176610, 0.934127694551867280, 0.934145540334238800, 0.934163383781246300, 0.934181224892845500, +0.934199063668991530, 0.934216900109639980, 0.934234734214746450, 0.934252565984265760, 0.934270395418153710, 0.934288222516365560, 0.934306047278857020, 0.934323869705583230, +0.934341689796499790, 0.934359507551562500, 0.934377322970726070, 0.934395136053946310, 0.934412946801178810, 0.934430755212378840, 0.934448561287501980, 0.934466365026503820, +0.934484166429339740, 0.934501965495965430, 0.934519762226336040, 0.934537556620407160, 0.934555348678134390, 0.934573138399473200, 0.934590925784379300, 0.934608710832807940, +0.934626493544714940, 0.934644273920055890, 0.934662051958785930, 0.934679827660860880, 0.934697601026236110, 0.934715372054867540, 0.934733140746710320, 0.934750907101720370, +0.934768671119853510, 0.934786432801064550, 0.934804192145309630, 0.934821949152544130, 0.934839703822723740, 0.934857456155804180, 0.934875206151740910, 0.934892953810489760, +0.934910699132006420, 0.934928442116246040, 0.934946182763164550, 0.934963921072717530, 0.934981657044860800, 0.934999390679549960, 0.935017121976740580, 0.935034850936388720, +0.935052577558449390, 0.935070301842878650, 0.935088023789632180, 0.935105743398665590, 0.935123460669934680, 0.935141175603395160, 0.935158888199002610, 0.935176598456713190, +0.935194306376482040, 0.935212011958264980, 0.935229715202018030, 0.935247416107696680, 0.935265114675256860, 0.935282810904654260, 0.935300504795844590, 0.935318196348783990, +0.935335885563427620, 0.935353572439731500, 0.935371256977651440, 0.935388939177143160, 0.935406619038162690, 0.935424296560665610, 0.935441971744608080, 0.935459644589945350, +0.935477315096633450, 0.935494983264628320, 0.935512649093885650, 0.935530312584361480, 0.935547973736011400, 0.935565632548791440, 0.935583289022657750, 0.935600943157565480, +0.935618594953470880, 0.935636244410329780, 0.935653891528098080, 0.935671536306731720, 0.935689178746186400, 0.935706818846418150, 0.935724456607383240, 0.935742092029036800, +0.935759725111335210, 0.935777355854234270, 0.935794984257689920, 0.935812610321658080, 0.935830234046094780, 0.935847855430956170, 0.935865474476197610, 0.935883091181775370, +0.935900705547645370, 0.935918317573763650, 0.935935927260086120, 0.935953534606568830, 0.935971139613167690, 0.935988742279838970, 0.936006342606538030, 0.936023940593221360, +0.936041536239844760, 0.936059129546364390, 0.936076720512736050, 0.936094309138916000, 0.936111895424860510, 0.936129479370524930, 0.936147060975865750, 0.936164640240838790, +0.936182217165400290, 0.936199791749506290, 0.936217363993112730, 0.936234933896175740, 0.936252501458651800, 0.936270066680496280, 0.936287629561665670, 0.936305190102115880, +0.936322748301803070, 0.936340304160683480, 0.936357857678713160, 0.936375408855848130, 0.936392957692044890, 0.936410504187259020, 0.936428048341446770, 0.936445590154564410, +0.936463129626568190, 0.936480666757414040, 0.936498201547058320, 0.936515733995457290, 0.936533264102566760, 0.936550791868342890, 0.936568317292742150, 0.936585840375720680, +0.936603361117234520, 0.936620879517239930, 0.936638395575693170, 0.936655909292550830, 0.936673420667768260, 0.936690929701302190, 0.936708436393108860, 0.936725940743144410, +0.936743442751365010, 0.936760942417727120, 0.936778439742186890, 0.936795934724700800, 0.936813427365224550, 0.936830917663714740, 0.936848405620127720, 0.936865891234419550, +0.936883374506546800, 0.936900855436465510, 0.936918334024132380, 0.936935810269503230, 0.936953284172534430, 0.936970755733182450, 0.936988224951403550, 0.937005691827154210, +0.937023156360390570, 0.937040618551069020, 0.937058078399146230, 0.937075535904577930, 0.937092991067320800, 0.937110443887331220, 0.937127894364565560, 0.937145342498980070, +0.937162788290531350, 0.937180231739175860, 0.937197672844869540, 0.937215111607568980, 0.937232548027230660, 0.937249982103810940, 0.937267413837266420, 0.937284843227553230, +0.937302270274627980, 0.937319694978447360, 0.937337117338967070, 0.937354537356144160, 0.937371955029934870, 0.937389370360295570, 0.937406783347182970, 0.937424193990553430, +0.937441602290363330, 0.937459008246569580, 0.937476411859128000, 0.937493813127995290, 0.937511212053128150, 0.937528608634482950, 0.937546002872016280, 0.937563394765684510, +0.937580784315444670, 0.937598171521252470, 0.937615556383064930, 0.937632938900838430, 0.937650319074529560, 0.937667696904095020, 0.937685072389491060, 0.937702445530674610, +0.937719816327602150, 0.937737184780230050, 0.937754550888514780, 0.937771914652413270, 0.937789276071882010, 0.937806635146877450, 0.937823991877356320, 0.937841346263275310, +0.937858698304591120, 0.937876048001259900, 0.937893395353238570, 0.937910740360483830, 0.937928083022952160, 0.937945423340600270, 0.937962761313384850, 0.937980096941262830, +0.937997430224190350, 0.938014761162124230, 0.938032089755021170, 0.938049416002837870, 0.938066739905531130, 0.938084061463057450, 0.938101380675373630, 0.938118697542436710, +0.938136012064202720, 0.938153324240628690, 0.938170634071671340, 0.938187941557287350, 0.938205246697433660, 0.938222549492066740, 0.938239849941143730, 0.938257148044620900, +0.938274443802455060, 0.938291737214603240, 0.938309028281022030, 0.938326317001668240, 0.938343603376498690, 0.938360887405470080, 0.938378169088539550, 0.938395448425663360, +0.938412725416798540, 0.938430000061901910, 0.938447272360930170, 0.938464542313840360, 0.938481809920589160, 0.938499075181133510, 0.938516338095430340, 0.938533598663436110, +0.938550856885107860, 0.938568112760402530, 0.938585366289276800, 0.938602617471687720, 0.938619866307592090, 0.938637112796947170, 0.938654356939709110, 0.938671598735835170, +0.938688838185282150, 0.938706075288007090, 0.938723310043966810, 0.938740542453118330, 0.938757772515418480, 0.938775000230824500, 0.938792225599292650, 0.938809448620780310, +0.938826669295244280, 0.938843887622641700, 0.938861103602929290, 0.938878317236064190, 0.938895528522003200, 0.938912737460703810, 0.938929944052122160, 0.938947148296215730, +0.938964350192941330, 0.938981549742256230, 0.938998746944117110, 0.939015941798481140, 0.939033134305305660, 0.939050324464547060, 0.939067512276162590, 0.939084697740109390, +0.939101880856344380, 0.939119061624824720, 0.939136240045507440, 0.939153416118349570, 0.939170589843308370, 0.939187761220340420, 0.939204930249403100, 0.939222096930453440, +0.939239261263448480, 0.939256423248345460, 0.939273582885101320, 0.939290740173673640, 0.939307895114018690, 0.939325047706094040, 0.939342197949856740, 0.939359345845263930, +0.939376491392272860, 0.939393634590840470, 0.939410775440924000, 0.939427913942480930, 0.939445050095467750, 0.939462183899841930, 0.939479315355560730, 0.939496444462581180, +0.939513571220860540, 0.939530695630355960, 0.939547817691024580, 0.939564937402824100, 0.939582054765710880, 0.939599169779642530, 0.939616282444576290, 0.939633392760469310, +0.939650500727278850, 0.939667606344962160, 0.939684709613476720, 0.939701810532779240, 0.939718909102827180, 0.939736005323577930, 0.939753099194988620, 0.939770190717016510, +0.939787279889618970, 0.939804366712753250, 0.939821451186376940, 0.939838533310446640, 0.939855613084920050, 0.939872690509754420, 0.939889765584907110, 0.939906838310335280, +0.939923908685996400, 0.939940976711848060, 0.939958042387846970, 0.939975105713950820, 0.939992166690116870, 0.940009225316302490, 0.940026281592465040, 0.940043335518561900, +0.940060387094550420, 0.940077436320388320, 0.940094483196032280, 0.940111527721440020, 0.940128569896569010, 0.940145609721376510, 0.940162647195819990, 0.940179682319856940, +0.940196715093444600, 0.940213745516540690, 0.940230773589102230, 0.940247799311086820, 0.940264822682451930, 0.940281843703154930, 0.940298862373153410, 0.940315878692404630, +0.940332892660866500, 0.940349904278495850, 0.940366913545250480, 0.940383920461087760, 0.940400925025965280, 0.940417927239840410, 0.940434927102670850, 0.940451924614413850, +0.940468919775027450, 0.940485912584468340, 0.940502903042694460, 0.940519891149663390, 0.940536876905332610, 0.940553860309659600, 0.940570841362601940, 0.940587820064117120, +0.940604796414163060, 0.940621770412696790, 0.940638742059676130, 0.940655711355058430, 0.940672678298801630, 0.940689642890863100, 0.940706605131200410, 0.940723565019771500, +0.940740522556533400, 0.940757477741444030, 0.940774430574460860, 0.940791381055541720, 0.940808329184644080, 0.940825274961725630, 0.940842218386744090, 0.940859159459657150, +0.940876098180422060, 0.940893034548996750, 0.940909968565338820, 0.940926900229406060, 0.940943829541155960, 0.940960756500546340, 0.940977681107535100, 0.940994603362079300, +0.941011523264137060, 0.941028440813665990, 0.941045356010623890, 0.941062268854968350, 0.941079179346657080, 0.941096087485647880, 0.941112993271898790, 0.941129896705366950, +0.941146797786010400, 0.941163696513786730, 0.941180592888653860, 0.941197486910569590, 0.941214378579491530, 0.941231267895377590, 0.941248154858185690, 0.941265039467873100, +0.941281921724397950, 0.941298801627718060, 0.941315679177791130, 0.941332554374574970, 0.941349427218027390, 0.941366297708106650, 0.941383165844769780, 0.941400031627975030, +0.941416895057680110, 0.941433756133843060, 0.941450614856421560, 0.941467471225373550, 0.941484325240656950, 0.941501176902229680, 0.941518026210049320, 0.941534873164073800, +0.941551717764261160, 0.941568560010569100, 0.941585399902955760, 0.941602237441378940, 0.941619072625796470, 0.941635905456166600, 0.941652735932446690, 0.941669564054594900, +0.941686389822569250, 0.941703213236327660, 0.941720034295827960, 0.941736853001028160, 0.941753669351886650, 0.941770483348360550, 0.941787294990408250, 0.941804104277987770, +0.941820911211057040, 0.941837715789573980, 0.941854518013496620, 0.941871317882783000, 0.941888115397391370, 0.941904910557279210, 0.941921703362404770, 0.941938493812725990, +0.941955281908200990, 0.941972067648787830, 0.941988851034444520, 0.942005632065129330, 0.942022410740799730, 0.942039187061414210, 0.942055961026930570, 0.942072732637307180, +0.942089501892501850, 0.942106268792472830, 0.942123033337178170, 0.942139795526576120, 0.942156555360624370, 0.942173312839281190, 0.942190067962504820, 0.942206820730253190, +0.942223571142484450, 0.942240319199156850, 0.942257064900228540, 0.942273808245657760, 0.942290549235402120, 0.942307287869420200, 0.942324024147670030, 0.942340758070109860, +0.942357489636697740, 0.942374218847391810, 0.942390945702150760, 0.942407670200931970, 0.942424392343694130, 0.942441112130395160, 0.942457829560993440, 0.942474544635447220, +0.942491257353714640, 0.942507967715753850, 0.942524675721523430, 0.942541381370981090, 0.942558084664085190, 0.942574785600794220, 0.942591484181066200, 0.942608180404859500, +0.942624874272132370, 0.942641565782842970, 0.942658254936949990, 0.942674941734411130, 0.942691626175184870, 0.942708308259229580, 0.942724987986503500, 0.942741665356964910, +0.942758340370572160, 0.942775013027283950, 0.942791683327057760, 0.942808351269852520, 0.942825016855626250, 0.942841680084337550, 0.942858340955944670, 0.942874999470405870, +0.942891655627679630, 0.942908309427724410, 0.942924960870498260, 0.942941609955959660, 0.942958256684067080, 0.942974901054778770, 0.942991543068053330, 0.943008182723848900, +0.943024820022124400, 0.943041454962837530, 0.943058087545947000, 0.943074717771411280, 0.943091345639188730, 0.943107971149237830, 0.943124594301517070, 0.943141215095984810, +0.943157833532599740, 0.943174449611319800, 0.943191063332103790, 0.943207674694910070, 0.943224283699697130, 0.943240890346423560, 0.943257494635047710, 0.943274096565528190, +0.943290696137823680, 0.943307293351892120, 0.943323888207692420, 0.943340480705182840, 0.943357070844322190, 0.943373658625068830, 0.943390244047381370, 0.943406827111218480, +0.943423407816538330, 0.943439986163299600, 0.943456562151460900, 0.943473135780980800, 0.943489707051817890, 0.943506275963930660, 0.943522842517277800, 0.943539406711818130, +0.943555968547509670, 0.943572528024311240, 0.943589085142181540, 0.943605639901079040, 0.943622192300962450, 0.943638742341790460, 0.943655290023521550, 0.943671835346114760, +0.943688378309528010, 0.943704918913720440, 0.943721457158650520, 0.943737993044276860, 0.943754526570558360, 0.943771057737453400, 0.943787586544921230, 0.943804112992919770, +0.943820637081407950, 0.943837158810344580, 0.943853678179688350, 0.943870195189397850, 0.943886709839431900, 0.943903222129749200, 0.943919732060308770, 0.943936239631068650, +0.943952744841987880, 0.943969247693025370, 0.943985748184139720, 0.944002246315289620, 0.944018742086433990, 0.944035235497531770, 0.944051726548541080, 0.944068215239421190, +0.944084701570130690, 0.944101185540628500, 0.944117667150873310, 0.944134146400824050, 0.944150623290439310, 0.944167097819678340, 0.944183569988499280, 0.944200039796861290, +0.944216507244723280, 0.944232972332043950, 0.944249435058782230, 0.944265895424896920, 0.944282353430346830, 0.944298809075091230, 0.944315262359088250, 0.944331713282297150, +0.944348161844676740, 0.944364608046185940, 0.944381051886783560, 0.944397493366428640, 0.944413932485080210, 0.944430369242696740, 0.944446803639237280, 0.944463235674660840, +0.944479665348926250, 0.944496092661992640, 0.944512517613818600, 0.944528940204363400, 0.944545360433586170, 0.944561778301445170, 0.944578193807899760, 0.944594606952908870, +0.944611017736431410, 0.944627426158426430, 0.944643832218852840, 0.944660235917670120, 0.944676637254836420, 0.944693036230311090, 0.944709432844053180, 0.944725827096021710, +0.944742218986175720, 0.944758608514474130, 0.944774995680875970, 0.944791380485340730, 0.944807762927826640, 0.944824143008293200, 0.944840520726699440, 0.944856896083004270, +0.944873269077166960, 0.944889639709146410, 0.944906007978901790, 0.944922373886392440, 0.944938737431576860, 0.944955098614414510, 0.944971457434864330, 0.944987813892885550, +0.945004167988437230, 0.945020519721478380, 0.945036869091968600, 0.945053216099866370, 0.945069560745131150, 0.945085903027722000, 0.945102242947598040, 0.945118580504718530, +0.945134915699042510, 0.945151248530529230, 0.945167578999138170, 0.945183907104827800, 0.945200232847557720, 0.945216556227287060, 0.945232877243974980, 0.945249195897580720, +0.945265512188063430, 0.945281826115382360, 0.945298137679497000, 0.945314446880366140, 0.945330753717949060, 0.945347058192205100, 0.945363360303093540, 0.945379660050573500, +0.945395957434604360, 0.945412252455145600, 0.945428545112155900, 0.945444835405594870, 0.945461123335421760, 0.945477408901595820, 0.945493692104076410, 0.945509972942822690, +0.945526251417794120, 0.945542527528950180, 0.945558801276249580, 0.945575072659652020, 0.945591341679116850, 0.945607608334603220, 0.945623872626070620, 0.945640134553478280, +0.945656394116785930, 0.945672651315952350, 0.945688906150937040, 0.945705158621699570, 0.945721408728199210, 0.945737656470395200, 0.945753901848247150, 0.945770144861714400, +0.945786385510756440, 0.945802623795332310, 0.945818859715401580, 0.945835093270923740, 0.945851324461858160, 0.945867553288164300, 0.945883779749801530, 0.945900003846729230, +0.945916225578907310, 0.945932444946294470, 0.945948661948850630, 0.945964876586535050, 0.945981088859307320, 0.945997298767126790, 0.946013506309953070, 0.946029711487745840, +0.946045914300464030, 0.946062114748067560, 0.946078312830515690, 0.946094508547768110, 0.946110701899784190, 0.946126892886523520, 0.946143081507945680, 0.946159267764010380, +0.946175451654676540, 0.946191633179904180, 0.946207812339652790, 0.946223989133881730, 0.946240163562550810, 0.946256335625619390, 0.946272505323047190, 0.946288672654793990, +0.946304837620818850, 0.946321000221081570, 0.946337160455541840, 0.946353318324159140, 0.946369473826893290, 0.946385626963703650, 0.946401777734550140, 0.946417926139392020, +0.946434072178189090, 0.946450215850900940, 0.946466357157487280, 0.946482496097907690, 0.946498632672121860, 0.946514766880089510, 0.946530898721770540, 0.946547028197124000, +0.946563155306109790, 0.946579280048687850, 0.946595402424817660, 0.946611522434458900, 0.946627640077571390, 0.946643755354115050, 0.946659868264049020, 0.946675978807333340, +0.946692086983927710, 0.946708192793791930, 0.946724296236885590, 0.946740397313168500, 0.946756496022600480, 0.946772592365141440, 0.946788686340750640, 0.946804777949388110, +0.946820867191013770, 0.946836954065587100, 0.946853038573068130, 0.946869120713416560, 0.946885200486592190, 0.946901277892555070, 0.946917352931264440, 0.946933425602680570, +0.946949495906763030, 0.946965563843471750, 0.946981629412766530, 0.946997692614607310, 0.947013753448954110, 0.947029811915766300, 0.947045868015003900, 0.947061921746626840, +0.947077973110594940, 0.947094022106868110, 0.947110068735406260, 0.947126112996169220, 0.947142154889117240, 0.947158194414209560, 0.947174231571406340, 0.947190266360667610, +0.947206298781953170, 0.947222328835223060, 0.947238356520437090, 0.947254381837555170, 0.947270404786537570, 0.947286425367343750, 0.947302443579933870, 0.947318459424267840, +0.947334472900305700, 0.947350484008007370, 0.947366492747332760, 0.947382499118242240, 0.947398503120695290, 0.947414504754651940, 0.947430504020072450, 0.947446500916916620, +0.947462495445144490, 0.947478487604716200, 0.947494477395591670, 0.947510464817731270, 0.947526449871094360, 0.947542432555641410, 0.947558412871332360, 0.947574390818127220, +0.947590366395986150, 0.947606339604869060, 0.947622310444736550, 0.947638278915547860, 0.947654245017263590, 0.947670208749843650, 0.947686170113248180, 0.947702129107437340, +0.947718085732371150, 0.947734039988009650, 0.947749991874313410, 0.947765941391241930, 0.947781888538755560, 0.947797833316814550, 0.947813775725378840, 0.947829715764408780, +0.947845653433864400, 0.947861588733705850, 0.947877521663893720, 0.947893452224387370, 0.947909380415147500, 0.947925306236134140, 0.947941229687307430, 0.947957150768627740, +0.947973069480055110, 0.947988985821550220, 0.948004899793072450, 0.948020811394582500, 0.948036720626040500, 0.948052627487406710, 0.948068531978641270, 0.948084434099704660, +0.948100333850556810, 0.948116231231158510, 0.948132126241469250, 0.948148018881449840, 0.948163909151060190, 0.948179797050260900, 0.948195682579012100, 0.948211565737274050, +0.948227446525007120, 0.948243324942171780, 0.948259200988727960, 0.948275074664636120, 0.948290945969856520, 0.948306814904349650, 0.948322681468075630, 0.948338545660994960, +0.948354407483068210, 0.948370266934255190, 0.948386124014516500, 0.948401978723812490, 0.948417831062103530, 0.948433681029350000, 0.948449528625512240, 0.948465373850550630, +0.948481216704425980, 0.948497057187097870, 0.948512895298527230, 0.948528731038674300, 0.948544564407499570, 0.948560395404963400, 0.948576224031026260, 0.948592050285648750, +0.948607874168791000, 0.948623695680413490, 0.948639514820476700, 0.948655331588941110, 0.948671145985767290, 0.948686958010915520, 0.948702767664346360, 0.948718574946020630, +0.948734379855898150, 0.948750182393939710, 0.948765982560105800, 0.948781780354357010, 0.948797575776653690, 0.948813368826956440, 0.948829159505225840, 0.948844947811422480, +0.948860733745506610, 0.948876517307438830, 0.948892298497179820, 0.948908077314689960, 0.948923853759929940, 0.948939627832860340, 0.948955399533441990, 0.948971168861634800, +0.948986935817399680, 0.949002700400697230, 0.949018462611488030, 0.949034222449732680, 0.949049979915391750, 0.949065735008425840, 0.949081487728795970, 0.949097238076462070, +0.949112986051385050, 0.949128731653525510, 0.949144474882844260, 0.949160215739301760, 0.949175954222858720, 0.949191690333476060, 0.949207424071113910, 0.949223155435733210, +0.949238884427294650, 0.949254611045758810, 0.949270335291086510, 0.949286057163238330, 0.949301776662174970, 0.949317493787857570, 0.949333208540246050, 0.949348920919301560, +0.949364630924984800, 0.949380338557256340, 0.949396043816077120, 0.949411746701407820, 0.949427447213209040, 0.949443145351442030, 0.949458841116066820, 0.949474534507044550, +0.949490225524335930, 0.949505914167901750, 0.949521600437702840, 0.949537284333699770, 0.949552965855853910, 0.949568645004125300, 0.949584321778475070, 0.949599996178864150, +0.949615668205253120, 0.949631337857602900, 0.949647005135874410, 0.949662670040028360, 0.949678332570025980, 0.949693992725827440, 0.949709650507393870, 0.949725305914686290, +0.949740958947665300, 0.949756609606292050, 0.949772257890527220, 0.949787903800331730, 0.949803547335666850, 0.949819188496492720, 0.949834827282770690, 0.949850463694461470, +0.949866097731526190, 0.949881729393925680, 0.949897358681620840, 0.949912985594572820, 0.949928610132742100, 0.949944232296089820, 0.949959852084577010, 0.949975469498164580, +0.949991084536813470, 0.950006697200484580, 0.950022307489139070, 0.950037915402737960, 0.950053520941241850, 0.950069124104611860, 0.950084724892809150, 0.950100323305794530, +0.950115919343529240, 0.950131513005973980, 0.950147104293090350, 0.950162693204838700, 0.950178279741180190, 0.950193863902076050, 0.950209445687487220, 0.950225025097374830, +0.950240602131699920, 0.950256176790423400, 0.950271749073506760, 0.950287318980910460, 0.950302886512595870, 0.950318451668524020, 0.950334014448656170, 0.950349574852953130, +0.950365132881376250, 0.950380688533886460, 0.950396241810445350, 0.950411792711013280, 0.950427341235551730, 0.950442887384021830, 0.950458431156384730, 0.950473972552601460, +0.950489511572633390, 0.950505048216441770, 0.950520582483987190, 0.950536114375231220, 0.950551643890135020, 0.950567171028659620, 0.950582695790766260, 0.950598218176416320, +0.950613738185570710, 0.950629255818191020, 0.950644771074237950, 0.950660283953672970, 0.950675794456457220, 0.950691302582552080, 0.950706808331918560, 0.950722311704518150, +0.950737812700311880, 0.950753311319261440, 0.950768807561327310, 0.950784301426471300, 0.950799792914654440, 0.950815282025838090, 0.950830768759983620, 0.950846253117052180, +0.950861735097005440, 0.950877214699804020, 0.950892691925409590, 0.950908166773783430, 0.950923639244886760, 0.950939109338681090, 0.950954577055127650, 0.950970042394187810, +0.950985505355823050, 0.951000965939994280, 0.951016424146663100, 0.951031879975790860, 0.951047333427338940, 0.951062784501268690, 0.951078233197541370, 0.951093679516118900, +0.951109123456961860, 0.951124565020032060, 0.951140004205290770, 0.951155441012699550, 0.951170875442219680, 0.951186307493812610, 0.951201737167439830, 0.951217164463062930, +0.951232589380642920, 0.951248011920141410, 0.951263432081519870, 0.951278849864739650, 0.951294265269762460, 0.951309678296549550, 0.951325088945062400, 0.951340497215262810, +0.951355903107111710, 0.951371306620570900, 0.951386707755601750, 0.951402106512165950, 0.951417502890224750, 0.951432896889739870, 0.951448288510672980, 0.951463677752985130, +0.951479064616638110, 0.951494449101593310, 0.951509831207812520, 0.951525210935257100, 0.951540588283888660, 0.951555963253668760, 0.951571335844559220, 0.951586706056521070, +0.951602073889516120, 0.951617439343505960, 0.951632802418452270, 0.951648163114316550, 0.951663521431060480, 0.951678877368645540, 0.951694230927033650, 0.951709582106185950, +0.951724930906064360, 0.951740277326630360, 0.951755621367845750, 0.951770963029672010, 0.951786302312070840, 0.951801639215004270, 0.951816973738433210, 0.951832305882319820, +0.951847635646625670, 0.951862963031312460, 0.951878288036341670, 0.951893610661675330, 0.951908930907274910, 0.951924248773102440, 0.951939564259119080, 0.951954877365286830, +0.951970188091567300, 0.951985496437922410, 0.952000802404313730, 0.952016105990702970, 0.952031407197052370, 0.952046706023322860, 0.952062002469476590, 0.952077296535475350, +0.952092588221280960, 0.952107877526855000, 0.952123164452159280, 0.952138448997155720, 0.952153731161806350, 0.952169010946072310, 0.952184288349915860, 0.952199563373298590, +0.952214836016182400, 0.952230106278529220, 0.952245374160300640, 0.952260639661458690, 0.952275902781965390, 0.952291163521782110, 0.952306421880870890, 0.952321677859193640, +0.952336931456712170, 0.952352182673388390, 0.952367431509184130, 0.952382677964061620, 0.952397922037982130, 0.952413163730907790, 0.952428403042800520, 0.952443639973622250, +0.952458874523335000, 0.952474106691900470, 0.952489336479280690, 0.952504563885437800, 0.952519788910333290, 0.952535011553929280, 0.952550231816187700, 0.952565449697070580, +0.952580665196539830, 0.952595878314557390, 0.952611089051085380, 0.952626297406085840, 0.952641503379520250, 0.952656706971350850, 0.952671908181539790, 0.952687107010048990, +0.952702303456840370, 0.952717497521875960, 0.952732689205118110, 0.952747878506528200, 0.952763065426068700, 0.952778249963701530, 0.952793432119388610, 0.952808611893092180, +0.952823789284774290, 0.952838964294396850, 0.952854136921922330, 0.952869307167312110, 0.952884475030528750, 0.952899640511534090, 0.952914803610290350, 0.952929964326759690, +0.952945122660904030, 0.952960278612685840, 0.952975432182066710, 0.952990583369008990, 0.953005732173474730, 0.953020878595426280, 0.953036022634825560, 0.953051164291634830, +0.953066303565816120, 0.953081440457331900, 0.953096574966143860, 0.953111707092214490, 0.953126836835505700, 0.953141964195979850, 0.953157089173599090, 0.953172211768325670, +0.953187331980121730, 0.953202449808949640, 0.953217565254771190, 0.953232678317548880, 0.953247788997244830, 0.953262897293821300, 0.953278003207240540, 0.953293106737464700, +0.953308207884456470, 0.953323306648177440, 0.953338403028590080, 0.953353497025656750, 0.953368588639339710, 0.953383677869601100, 0.953398764716403390, 0.953413849179708730, +0.953428931259479700, 0.953444010955678100, 0.953459088268266530, 0.953474163197207130, 0.953489235742462360, 0.953504305903994600, 0.953519373681765980, 0.953534439075739200, +0.953549502085875970, 0.953564562712139070, 0.953579620954490780, 0.953594676812893450, 0.953609730287309440, 0.953624781377701010, 0.953639830084030750, 0.953654876406261120, +0.953669920344354050, 0.953684961898272120, 0.953700001067977810, 0.953715037853433590, 0.953730072254601600, 0.953745104271444540, 0.953760133903924780, 0.953775161152004890, +0.953790186015646800, 0.953805208494813320, 0.953820228589466690, 0.953835246299569620, 0.953850261625084350, 0.953865274565973480, 0.953880285122199690, 0.953895293293724910, +0.953910299080511840, 0.953925302482523050, 0.953940303499721030, 0.953955302132068250, 0.953970298379527290, 0.953985292242060410, 0.954000283719630750, 0.954015272812200000, +0.954030259519731080, 0.954045243842186470, 0.954060225779528870, 0.954075205331720630, 0.954090182498724460, 0.954105157280502710, 0.954120129677018420, 0.954135099688233510, +0.954150067314110780, 0.954165032554613050, 0.954179995409702550, 0.954194955879342220, 0.954209913963494420, 0.954224869662122170, 0.954239822975187390, 0.954254773902653120, +0.954269722444481830, 0.954284668600636320, 0.954299612371079080, 0.954314553755772900, 0.954329492754680260, 0.954344429367764090, 0.954359363594986740, 0.954374295436310920, +0.954389224891699310, 0.954404151961114610, 0.954419076644519640, 0.954433998941876970, 0.954448918853149530, 0.954463836378299460, 0.954478751517289890, 0.954493664270083420, +0.954508574636642850, 0.954523482616930760, 0.954538388210909970, 0.954553291418543280, 0.954568192239793500, 0.954583090674623100, 0.954597986722994900, 0.954612880384871800, +0.954627771660216400, 0.954642660548991610, 0.954657547051160240, 0.954672431166684880, 0.954687312895528770, 0.954702192237654180, 0.954717069193024010, 0.954731943761601200, +0.954746815943348540, 0.954761685738228840, 0.954776553146205020, 0.954791418167239890, 0.954806280801296150, 0.954821141048336600, 0.954835998908324160, 0.954850854381221750, +0.954865707466992290, 0.954880558165598470, 0.954895406477003220, 0.954910252401169780, 0.954925095938060520, 0.954939937087638360, 0.954954775849866540, 0.954969612224707660, +0.954984446212124750, 0.954999277812080720, 0.955014107024538590, 0.955028933849461300, 0.955043758286811540, 0.955058580336552330, 0.955073399998646710, 0.955088217273057590, +0.955103032159747900, 0.955117844658680660, 0.955132654769819010, 0.955147462493125540, 0.955162267828563280, 0.955177070776095480, 0.955191871335684950, 0.955206669507294830, +0.955221465290887920, 0.955236258686427360, 0.955251049693876530, 0.955265838313197670, 0.955280624544354360, 0.955295408387309310, 0.955310189842025870, 0.955324968908466960, +0.955339745586595510, 0.955354519876375100, 0.955369291777768080, 0.955384061290737830, 0.955398828415247370, 0.955413593151259950, 0.955428355498738390, 0.955443115457646040, +0.955457873027945940, 0.955472628209601330, 0.955487381002575020, 0.955502131406830160, 0.955516879422329990, 0.955531625049037550, 0.955546368286916190, 0.955561109135928840, +0.955575847596038640, 0.955590583667209170, 0.955605317349403020, 0.955620048642583430, 0.955634777546713890, 0.955649504061757300, 0.955664228187676930, 0.955678949924436030, +0.955693669271998060, 0.955708386230325610, 0.955723100799382270, 0.955737812979131070, 0.955752522769535370, 0.955767230170558420, 0.955781935182163370, 0.955796637804313450, +0.955811338036972160, 0.955826035880102290, 0.955840731333667430, 0.955855424397630600, 0.955870115071955300, 0.955884803356604750, 0.955899489251542110, 0.955914172756730740, +0.955928853872134220, 0.955943532597715360, 0.955958208933437640, 0.955972882879264300, 0.955987554435158930, 0.956002223601084560, 0.956016890377004660, 0.956031554762882710, +0.956046216758681730, 0.956060876364365210, 0.956075533579896390, 0.956090188405238850, 0.956104840840355740, 0.956119490885210640, 0.956134138539766700, 0.956148783803987710, +0.956163426677836600, 0.956178067161276850, 0.956192705254271910, 0.956207340956785170, 0.956221974268780190, 0.956236605190220130, 0.956251233721068910, 0.956265859861289420, +0.956280483610845170, 0.956295104969699720, 0.956309723937816550, 0.956324340515159020, 0.956338954701690720, 0.956353566497375020, 0.956368175902175600, 0.956382782916055500, +0.956397387538978410, 0.956411989770907910, 0.956426589611807380, 0.956441187061640500, 0.956455782120370520, 0.956470374787961150, 0.956484965064376080, 0.956499552949578340, +0.956514138443531730, 0.956528721546199830, 0.956543302257546020, 0.956557880577533990, 0.956572456506127320, 0.956587030043289710, 0.956601601188984190, 0.956616169943174780, +0.956630736305824960, 0.956645300276898200, 0.956659861856358320, 0.956674421044168670, 0.956688977840293050, 0.956703532244695180, 0.956718084257338290, 0.956732633878186080, +0.956747181107202360, 0.956761725944350720, 0.956776268389594730, 0.956790808442897990, 0.956805346104224300, 0.956819881373537570, 0.956834414250800850, 0.956848944735978040, +0.956863472829032840, 0.956877998529929050, 0.956892521838630160, 0.956907042755100080, 0.956921561279302610, 0.956936077411200900, 0.956950591150759090, 0.956965102497940760, +0.956979611452709710, 0.956994118015029650, 0.957008622184864270, 0.957023123962177260, 0.957037623346932760, 0.957052120339094040, 0.957066614938624880, 0.957081107145489220, +0.957095596959650850, 0.957110084381073370, 0.957124569409720790, 0.957139052045557050, 0.957153532288545380, 0.957168010138649830, 0.957182485595834300, 0.957196958660062600, +0.957211429331298440, 0.957225897609505720, 0.957240363494648250, 0.957254826986690180, 0.957269288085594750, 0.957283746791326110, 0.957298203103848060, 0.957312657023124510, +0.957327108549119400, 0.957341557681796520, 0.957356004421119680, 0.957370448767053020, 0.957384890719560120, 0.957399330278604910, 0.957413767444151410, 0.957428202216163540, +0.957442634594604990, 0.957457064579440020, 0.957471492170632650, 0.957485917368146140, 0.957500340171944960, 0.957514760581992920, 0.957529178598253930, 0.957543594220692020, +0.957558007449271220, 0.957572418283955340, 0.957586826724708630, 0.957601232771494560, 0.957615636424277490, 0.957630037683021350, 0.957644436547690050, 0.957658833018247610, +0.957673227094658190, 0.957687618776885690, 0.957702008064894360, 0.957716394958647800, 0.957730779458110250, 0.957745161563245630, 0.957759541274018300, 0.957773918590391960, +0.957788293512330860, 0.957802666039799360, 0.957817036172760930, 0.957831403911179820, 0.957845769255020190, 0.957860132204246260, 0.957874492758821970, 0.957888850918711340, +0.957903206683878630, 0.957917560054288190, 0.957931911029903600, 0.957946259610689240, 0.957960605796609240, 0.957974949587627740, 0.957989290983708770, 0.958003629984816700, +0.958017966590915650, 0.958032300801969550, 0.958046632617942650, 0.958060962038799200, 0.958075289064503340, 0.958089613695019330, 0.958103935930311180, 0.958118255770343150, +0.958132573215079830, 0.958146888264484800, 0.958161200918522530, 0.958175511177157270, 0.958189819040353270, 0.958204124508074680, 0.958218427580285860, 0.958232728256950830, +0.958247026538034290, 0.958261322423500040, 0.958275615913312340, 0.958289907007435660, 0.958304195705834250, 0.958318482008472250, 0.958332765915314130, 0.958347047426324260, +0.958361326541466660, 0.958375603260705590, 0.958389877584005620, 0.958404149511330910, 0.958418419042645800, 0.958432686177914770, 0.958446950917101860, 0.958461213260171970, +0.958475473207088700, 0.958489730757816740, 0.958503985912320560, 0.958518238670564290, 0.958532489032512540, 0.958546736998129420, 0.958560982567379870, 0.958575225740227470, +0.958589466516637120, 0.958603704896572980, 0.958617940879999740, 0.958632174466881540, 0.958646405657182950, 0.958660634450868350, 0.958674860847902320, 0.958689084848249000, +0.958703306451872960, 0.958717525658738580, 0.958731742468810430, 0.958745956882052890, 0.958760168898430520, 0.958774378517907700, 0.958788585740449120, 0.958802790566018910, +0.958816992994581780, 0.958831193026102090, 0.958845390660544420, 0.958859585897873230, 0.958873778738053130, 0.958887969181048790, 0.958902157226824370, 0.958916342875344440, +0.958930526126573700, 0.958944706980476620, 0.958958885437017900, 0.958973061496161790, 0.958987235157873210, 0.959001406422116620, 0.959015575288856390, 0.959029741758057110, +0.959043905829683570, 0.959058067503700260, 0.959072226780071760, 0.959086383658762640, 0.959100538139737610, 0.959114690222961470, 0.959128839908398370, 0.959142987196013210, +0.959157132085770580, 0.959171274577635070, 0.959185414671571370, 0.959199552367544170, 0.959213687665518290, 0.959227820565457970, 0.959241951067328120, 0.959256079171093350, +0.959270204876718440, 0.959284328184167980, 0.959298449093406670, 0.959312567604399310, 0.959326683717110720, 0.959340797431505240, 0.959354908747547700, 0.959369017665202880, +0.959383124184435610, 0.959397228305210460, 0.959411330027492240, 0.959425429351245970, 0.959439526276435810, 0.959453620803026870, 0.959467712930983870, 0.959481802660271610, +0.959495889990854890, 0.959509974922698410, 0.959524057455766970, 0.959538137590025710, 0.959552215325438770, 0.959566290661971300, 0.959580363599588090, 0.959594434138254070, +0.959608502277933930, 0.959622568018592470, 0.959636631360194610, 0.959650692302705390, 0.959664750846089270, 0.959678806990311270, 0.959692860735336220, 0.959706912081129020, +0.959720961027654470, 0.959735007574877620, 0.959749051722763480, 0.959763093471276530, 0.959777132820381680, 0.959791169770044080, 0.959805204320228640, 0.959819236470900060, +0.959833266222023470, 0.959847293573563690, 0.959861318525485950, 0.959875341077754630, 0.959889361230334970, 0.959903378983191890, 0.959917394336290420, 0.959931407289595360, +0.959945417843071860, 0.959959425996684820, 0.959973431750399400, 0.959987435104180160, 0.960001436057992490, 0.960015434611801060, 0.960029430765571120, 0.960043424519267500, +0.960057415872855420, 0.960071404826300050, 0.960085391379565940, 0.960099375532618260, 0.960113357285422240, 0.960127336637942700, 0.960141313590144870, 0.960155288141993800, +0.960169260293454510, 0.960183230044492350, 0.960197197395071810, 0.960211162345158240, 0.960225124894716900, 0.960239085043712580, 0.960253042792110660, 0.960266998139876040, +0.960280951086974310, 0.960294901633369840, 0.960308849779028200, 0.960322795523914310, 0.960336738867993530, 0.960350679811230900, 0.960364618353591550, 0.960378554495040730, +0.960392488235543680, 0.960406419575065120, 0.960420348513570610, 0.960434275051025190, 0.960448199187394100, 0.960462120922642490, 0.960476040256735610, 0.960489957189638590, +0.960503871721316900, 0.960517783851735360, 0.960531693580859320, 0.960545600908654040, 0.960559505835084760, 0.960573408360116730, 0.960587308483715210, 0.960601206205845660, +0.960615101526472780, 0.960628994445562270, 0.960642884963079150, 0.960656773078988890, 0.960670658793256640, 0.960684542105847750, 0.960698423016727590, 0.960712301525861510, +0.960726177633214550, 0.960740051338752070, 0.960753922642439420, 0.960767791544241970, 0.960781658044125080, 0.960795522142054100, 0.960809383837994300, 0.960823243131911250, +0.960837100023769760, 0.960850954513535640, 0.960864806601174130, 0.960878656286650590, 0.960892503569930390, 0.960906348450978890, 0.960920190929761890, 0.960934031006244080, +0.960947868680391170, 0.960961703952168620, 0.960975536821541800, 0.960989367288476170, 0.961003195352937100, 0.961017021014890060, 0.961030844274300630, 0.961044665131133960, +0.961058483585355620, 0.961072299636930970, 0.961086113285825610, 0.961099924532004990, 0.961113733375434600, 0.961127539816080120, 0.961141343853906480, 0.961155145488879480, +0.961168944720964700, 0.961182741550127510, 0.961196535976333480, 0.961210327999547980, 0.961224117619736810, 0.961237904836865550, 0.961251689650899350, 0.961265472061803790, +0.961279252069544680, 0.961293029674087360, 0.961306804875397440, 0.961320577673440590, 0.961334348068182300, 0.961348116059588360, 0.961361881647623820, 0.961375644832254680, +0.961389405613446320, 0.961403163991164540, 0.961416919965374820, 0.961430673536042830, 0.961444424703134290, 0.961458173466614550, 0.961471919826449420, 0.961485663782604360, +0.961499405335045190, 0.961513144483737480, 0.961526881228647050, 0.961540615569739240, 0.961554347506980210, 0.961568077040335090, 0.961581804169769790, 0.961595528895249910, +0.961609251216741230, 0.961622971134209470, 0.961636688647620310, 0.961650403756939330, 0.961664116462132570, 0.961677826763165380, 0.961691534660003570, 0.961705240152612940, +0.961718943240959190, 0.961732643925008120, 0.961746342204725320, 0.961760038080077040, 0.961773731551028410, 0.961787422617545350, 0.961801111279593890, 0.961814797537139500, +0.961828481390148200, 0.961842162838585700, 0.961855841882417790, 0.961869518521610510, 0.961883192756129210, 0.961896864585939810, 0.961910534011008340, 0.961924201031300610, +0.961937865646782300, 0.961951527857419330, 0.961965187663177850, 0.961978845064022980, 0.961992500059921210, 0.962006152650838110, 0.962019802836739600, 0.962033450617591600, +0.962047095993359910, 0.962060738964010560, 0.962074379529509580, 0.962088017689822440, 0.962101653444915160, 0.962115286794753890, 0.962128917739304310, 0.962142546278532460, +0.962156172412404250, 0.962169796140885600, 0.962183417463942650, 0.962197036381540970, 0.962210652893646710, 0.962224267000225900, 0.962237878701244220, 0.962251487996668040, +0.962265094886463060, 0.962278699370595510, 0.962292301449031110, 0.962305901121735860, 0.962319498388675920, 0.962333093249817200, 0.962346685705125720, 0.962360275754567510, +0.962373863398108710, 0.962387448635715460, 0.962401031467353230, 0.962414611892988600, 0.962428189912587270, 0.962441765526115600, 0.962455338733539500, 0.962468909534825000, +0.962482477929938460, 0.962496043918845580, 0.962509607501512490, 0.962523168677905440, 0.962536727447990460, 0.962550283811733580, 0.962563837769101040, 0.962577389320058980, +0.962590938464573660, 0.962604485202610660, 0.962618029534136550, 0.962631571459117370, 0.962645110977519150, 0.962658648089308230, 0.962672182794450770, 0.962685715092912670, +0.962699244984660640, 0.962712772469660250, 0.962726297547877970, 0.962739820219279840, 0.962753340483832210, 0.962766858341501330, 0.962780373792253120, 0.962793886836054380, +0.962807397472870590, 0.962820905702668320, 0.962834411525413820, 0.962847914941073250, 0.962861415949612940, 0.962874914550999050, 0.962888410745197820, 0.962901904532175950, +0.962915395911899010, 0.962928884884333480, 0.962942371449445830, 0.962955855607202320, 0.962969337357569070, 0.962982816700512450, 0.962996293635998920, 0.963009768163994750, +0.963023240284466060, 0.963036709997379110, 0.963050177302700480, 0.963063642200396420, 0.963077104690433280, 0.963090564772777320, 0.963104022447395240, 0.963117477714252820, +0.963130930573316670, 0.963144381024553240, 0.963157829067928910, 0.963171274703409910, 0.963184717930962830, 0.963198158750553810, 0.963211597162149770, 0.963225033165716390, +0.963238466761220490, 0.963251897948628420, 0.963265326727906660, 0.963278753099021560, 0.963292177061939480, 0.963305598616627230, 0.963319017763050840, 0.963332434501176890, +0.963345848830971740, 0.963359260752402080, 0.963372670265434160, 0.963386077370034680, 0.963399482066169990, 0.963412884353806790, 0.963426284232911100, 0.963439681703449740, +0.963453076765389270, 0.963466469418695960, 0.963479859663336600, 0.963493247499277450, 0.963506632926485310, 0.963520015944926760, 0.963533396554567930, 0.963546774755375650, +0.963560150547316470, 0.963573523930356890, 0.963586894904463480, 0.963600263469602810, 0.963613629625741710, 0.963626993372846300, 0.963640354710883380, 0.963653713639819660, +0.963667070159621610, 0.963680424270255910, 0.963693775971689150, 0.963707125263887910, 0.963720472146819110, 0.963733816620448990, 0.963747158684744250, 0.963760498339671590, +0.963773835585197690, 0.963787170421289250, 0.963800502847912850, 0.963813832865035190, 0.963827160472623180, 0.963840485670642950, 0.963853808459061660, 0.963867128837845750, +0.963880446806962050, 0.963893762366377250, 0.963907075516058030, 0.963920386255971320, 0.963933694586083470, 0.963947000506361400, 0.963960304016771800, 0.963973605117281360, +0.963986903807857010, 0.964000200088465430, 0.964013493959073210, 0.964026785419647590, 0.964040074470154720, 0.964053361110561720, 0.964066645340835300, 0.964079927160942260, +0.964093206570849400, 0.964106483570523530, 0.964119758159931670, 0.964133030339040300, 0.964146300107816210, 0.964159567466226440, 0.964172832414237680, 0.964186094951816840, +0.964199355078930840, 0.964212612795546380, 0.964225868101630690, 0.964239120997150030, 0.964252371482071660, 0.964265619556362360, 0.964278865219988960, 0.964292108472918350, +0.964305349315117470, 0.964318587746553320, 0.964331823767192840, 0.964345057377002600, 0.964358288575949740, 0.964371517364001170, 0.964384743741123710, 0.964397967707284480, +0.964411189262450290, 0.964424408406588380, 0.964437625139665240, 0.964450839461648000, 0.964464051372503680, 0.964477260872199200, 0.964490467960701700, 0.964503672637977870, +0.964516874903994960, 0.964530074758719990, 0.964543272202119660, 0.964556467234161220, 0.964569659854811470, 0.964582850064037660, 0.964596037861806700, 0.964609223248085730, +0.964622406222841570, 0.964635586786041670, 0.964648764937652610, 0.964661940677641660, 0.964675114005975830, 0.964688284922622150, 0.964701453427547870, 0.964714619520719910, +0.964727783202105620, 0.964740944471671580, 0.964754103329385270, 0.964767259775213600, 0.964780413809123940, 0.964793565431083080, 0.964806714641058380, 0.964819861439016990, +0.964833005824926040, 0.964846147798752440, 0.964859287360463340, 0.964872424510026190, 0.964885559247407820, 0.964898691572575680, 0.964911821485496700, 0.964924948986138450, +0.964938074074467630, 0.964951196750451600, 0.964964317014057600, 0.964977434865252780, 0.964990550304004380, 0.965003663330279650, 0.965016773944045610, 0.965029882145270080, +0.965042987933919520, 0.965056091309961390, 0.965069192273363190, 0.965082290824091920, 0.965095386962114940, 0.965108480687399520, 0.965121571999912890, 0.965134660899622520, +0.965147747386495230, 0.965160831460498690, 0.965173913121599950, 0.965186992369766570, 0.965200069204965590, 0.965213143627164480, 0.965226215636330710, 0.965239285232431300, +0.965252352415433500, 0.965265417185304900, 0.965278479542012850, 0.965291539485524490, 0.965304597015807290, 0.965317652132828610, 0.965330704836556030, 0.965343755126956470, +0.965356803003997510, 0.965369848467646510, 0.965382891517870930, 0.965395932154638150, 0.965408970377915510, 0.965422006187670380, 0.965435039583870560, 0.965448070566482850, +0.965461099135475060, 0.965474125290814440, 0.965487149032468460, 0.965500170360404700, 0.965513189274590510, 0.965526205774993600, 0.965539219861580870, 0.965552231534320130, +0.965565240793178740, 0.965578247638124280, 0.965591252069124220, 0.965604254086146140, 0.965617253689157300, 0.965630250878125600, 0.965643245653017960, 0.965656238013802290, +0.965669227960445960, 0.965682215492916660, 0.965695200611181750, 0.965708183315208910, 0.965721163604965740, 0.965734141480419470, 0.965747116941537920, 0.965760089988288440, +0.965773060620638830, 0.965786028838556580, 0.965798994642009250, 0.965811958030964420, 0.965824919005389910, 0.965837877565252860, 0.965850833710521160, 0.965863787441162300, +0.965876738757144080, 0.965889687658433970, 0.965902634144999660, 0.965915578216808730, 0.965928519873828990, 0.965941459116027910, 0.965954395943373070, 0.965967330355832270, +0.965980262353373090, 0.965993191935963340, 0.966006119103570590, 0.966019043856162770, 0.966031966193707130, 0.966044886116171450, 0.966057803623523670, 0.966070718715731360, +0.966083631392762320, 0.966096541654584140, 0.966109449501164620, 0.966122354932471670, 0.966135257948472550, 0.966148158549135380, 0.966161056734427870, 0.966173952504317590, +0.966186845858772460, 0.966199736797760280, 0.966212625321248960, 0.966225511429205760, 0.966238395121598930, 0.966251276398396030, 0.966264155259564880, 0.966277031705073400, +0.966289905734889380, 0.966302777348980620, 0.966315646547315050, 0.966328513329860140, 0.966341377696584010, 0.966354239647454480, 0.966367099182439240, 0.966379956301506300, +0.966392811004623490, 0.966405663291758590, 0.966418513162879740, 0.966431360617954540, 0.966444205656950770, 0.966457048279836580, 0.966469888486579780, 0.966482726277148150, +0.966495561651509850, 0.966508394609632780, 0.966521225151484530, 0.966534053277033230, 0.966546878986246690, 0.966559702279093050, 0.966572523155540210, 0.966585341615555980, +0.966598157659108390, 0.966610971286165690, 0.966623782496695230, 0.966636591290665370, 0.966649397668044030, 0.966662201628799230, 0.966675003172898890, 0.966687802300311150, +0.966700599011003800, 0.966713393304945210, 0.966726185182102850, 0.966738974642445070, 0.966751761685939790, 0.966764546312555260, 0.966777328522259280, 0.966790108315019990, +0.966802885690805640, 0.966815660649583800, 0.966828433191322830, 0.966841203315990880, 0.966853971023555860, 0.966866736313985900, 0.966879499187249030, 0.966892259643313490, +0.966905017682147540, 0.966917773303718860, 0.966930526507995710, 0.966943277294946220, 0.966956025664538530, 0.966968771616740770, 0.966981515151521090, 0.966994256268847830, +0.967006994968688800, 0.967019731251012150, 0.967032465115786220, 0.967045196562979160, 0.967057925592559100, 0.967070652204494290, 0.967083376398752750, 0.967096098175303060, +0.967108817534112820, 0.967121534475150590, 0.967134248998384520, 0.967146961103782840, 0.967159670791313710, 0.967172378060945470, 0.967185082912646270, 0.967197785346384560, +0.967210485362128170, 0.967223182959845550, 0.967235878139504960, 0.967248570901074740, 0.967261261244523050, 0.967273949169818240, 0.967286634676928770, 0.967299317765822450, +0.967311998436467870, 0.967324676688833260, 0.967337352522887000, 0.967350025938597420, 0.967362696935932690, 0.967375365514861250, 0.967388031675351590, 0.967400695417371610, +0.967413356740889910, 0.967426015645874830, 0.967438672132294730, 0.967451326200117980, 0.967463977849312820, 0.967476627079847830, 0.967489273891691370, 0.967501918284811580, +0.967514560259176930, 0.967527199814755990, 0.967539836951516910, 0.967552471669428370, 0.967565103968458630, 0.967577733848576260, 0.967590361309749400, 0.967602986351946640, +0.967615608975136430, 0.967628229179287150, 0.967640846964367360, 0.967653462330345440, 0.967666075277189730, 0.967678685804869270, 0.967691293913351740, 0.967703899602605940, +0.967716502872600470, 0.967729103723303790, 0.967741702154684250, 0.967754298166710550, 0.967766891759351270, 0.967779482932574540, 0.967792071686349060, 0.967804658020643420, +0.967817241935426180, 0.967829823430665810, 0.967842402506330910, 0.967854979162389940, 0.967867553398811810, 0.967880125215564550, 0.967892694612616960, 0.967905261589937730, +0.967917826147495220, 0.967930388285258240, 0.967942948003195250, 0.967955505301274830, 0.967968060179465910, 0.967980612637736600, 0.967993162676055840, 0.968005710294392090, +0.968018255492714140, 0.968030798270990480, 0.968043338629189900, 0.968055876567281090, 0.968068412085232530, 0.968080945183012800, 0.968093475860590800, 0.968106004117935020, +0.968118529955014240, 0.968131053371797170, 0.968143574368252490, 0.968156092944349010, 0.968168609100055200, 0.968181122835339750, 0.968193634150171570, 0.968206143044519240, +0.968218649518351680, 0.968231153571637360, 0.968243655204345190, 0.968256154416444190, 0.968268651207902510, 0.968281145578689160, 0.968293637528772950, 0.968306127058122690, +0.968318614166707170, 0.968331098854495090, 0.968343581121455350, 0.968356060967556550, 0.968368538392767600, 0.968381013397057290, 0.968393485980394430, 0.968405956142747940, +0.968418423884086500, 0.968430889204378920, 0.968443352103594450, 0.968455812581701330, 0.968468270638668690, 0.968480726274465460, 0.968493179489060330, 0.968505630282422200, +0.968518078654520000, 0.968530524605322960, 0.968542968134799230, 0.968555409242918160, 0.968567847929648560, 0.968580284194959340, 0.968592718038819410, 0.968605149461197690, +0.968617578462063090, 0.968630005041384750, 0.968642429199131240, 0.968654850935271590, 0.968667270249774840, 0.968679687142609880, 0.968692101613745750, 0.968704513663151360, +0.968716923290795620, 0.968729330496647890, 0.968741735280676530, 0.968754137642850900, 0.968766537583139910, 0.968778935101512580, 0.968791330197937840, 0.968803722872384920, +0.968816113124822740, 0.968828500955220220, 0.968840886363546370, 0.968853269349770230, 0.968865649913861040, 0.968878028055787710, 0.968890403775519270, 0.968902777073024860, +0.968915147948273600, 0.968927516401234420, 0.968939882431876340, 0.968952246040168610, 0.968964607226080240, 0.968976965989580390, 0.968989322330638060, 0.969001676249222510, +0.969014027745302870, 0.969026376818848070, 0.969038723469827220, 0.969051067698209700, 0.969063409503964410, 0.969075748887060610, 0.969088085847467420, 0.969100420385154200, +0.969112752500089770, 0.969125082192243470, 0.969137409461584440, 0.969149734308081930, 0.969162056731705080, 0.969174376732423020, 0.969186694310205100, 0.969199009465020580, +0.969211322196838370, 0.969223632505627820, 0.969235940391358190, 0.969248245853998820, 0.969260548893518650, 0.969272849509887240, 0.969285147703073950, 0.969297443473047470, +0.969309736819777390, 0.969322027743233060, 0.969334316243383620, 0.969346602320198310, 0.969358885973646610, 0.969371167203697650, 0.969383446010321000, 0.969395722393485480, +0.969407996353160660, 0.969420267889315900, 0.969432537001920450, 0.969444803690943660, 0.969457067956354780, 0.969469329798123390, 0.969481589216218740, 0.969493846210609970, +0.969506100781266640, 0.969518352928157910, 0.969530602651253460, 0.969542849950522420, 0.969555094825934270, 0.969567337277458590, 0.969579577305064280, 0.969591814908721150, +0.969604050088398450, 0.969616282844065650, 0.969628513175692100, 0.969640741083247270, 0.969652966566700520, 0.969665189626021660, 0.969677410261179600, 0.969689628472144020, +0.969701844258884280, 0.969714057621370080, 0.969726268559570670, 0.969738477073455510, 0.969750683162994510, 0.969762886828156480, 0.969775088068911330, 0.969787286885228420, +0.969799483277077210, 0.969811677244427410, 0.969823868787248360, 0.969836057905509640, 0.969848244599180950, 0.969860428868231540, 0.969872610712630980, 0.969884790132348850, +0.969896967127354850, 0.969909141697618440, 0.969921313843109090, 0.969933483563796490, 0.969945650859650340, 0.969957815730639990, 0.969969978176735030, 0.969982138197905130, +0.969994295794119780, 0.970006450965348770, 0.970018603711561680, 0.970030754032728320, 0.970042901928817700, 0.970055047399799970, 0.970067190445644600, 0.970079331066321160, +0.970091469261799570, 0.970103605032049180, 0.970115738377039790, 0.970127869296741220, 0.970139997791122920, 0.970152123860154480, 0.970164247503805810, 0.970176368722046490, +0.970188487514846210, 0.970200603882174770, 0.970212717824001760, 0.970224829340297190, 0.970236938431030430, 0.970249045096171270, 0.970261149335689410, 0.970273251149554760, +0.970285350537737010, 0.970297447500205750, 0.970309542036931210, 0.970321634147882640, 0.970333723833029850, 0.970345811092342860, 0.970357895925791250, 0.970369978333344930, +0.970382058314973710, 0.970394135870647380, 0.970406211000335750, 0.970418283704008510, 0.970430353981635570, 0.970442421833186740, 0.970454487258631810, 0.970466550257940710, +0.970478610831083220, 0.970490668978029380, 0.970502724698748650, 0.970514777993211180, 0.970526828861386750, 0.970538877303245170, 0.970550923318756480, 0.970562966907890460, +0.970575008070617030, 0.970587046806906220, 0.970599083116727710, 0.970611117000051430, 0.970623148456847270, 0.970635177487085390, 0.970647204090735460, 0.970659228267767630, +0.970671250018151580, 0.970683269341857780, 0.970695286238855480, 0.970707300709114930, 0.970719312752606260, 0.970731322369299270, 0.970743329559163870, 0.970755334322170200, +0.970767336658288520, 0.970779336567488160, 0.970791334049739500, 0.970803329105012550, 0.970815321733277230, 0.970827311934503560, 0.970839299708661670, 0.970851285055721490, +0.970863267975653370, 0.970875248468426880, 0.970887226534012160, 0.970899202172379460, 0.970911175383498690, 0.970923146167340100, 0.970935114523873600, 0.970947080453069210, +0.970959043954897410, 0.970971005029327760, 0.970982963676330630, 0.970994919895876160, 0.971006873687934260, 0.971018825052475280, 0.971030773989469130, 0.971042720498886400, +0.971054664580696560, 0.971066606234870070, 0.971078545461377060, 0.971090482260187680, 0.971102416631272170, 0.971114348574600550, 0.971126278090143070, 0.971138205177870080, +0.971150129837751400, 0.971162052069757360, 0.971173971873858230, 0.971185889250024140, 0.971197804198225320, 0.971209716718432040, 0.971221626810614640, 0.971233534474743030, +0.971245439710787470, 0.971257342518718430, 0.971269242898506020, 0.971281140850120410, 0.971293036373532040, 0.971304929468711050, 0.971316820135627920, 0.971328708374252560, +0.971340594184555430, 0.971352477566506780, 0.971364358520076960, 0.971376237045236230, 0.971388113141954950, 0.971399986810203340, 0.971411858049952000, 0.971423726861170730, +0.971435593243830220, 0.971447457197900710, 0.971459318723352560, 0.971471177820156130, 0.971483034488281770, 0.971494888727700070, 0.971506740538380820, 0.971518589920294830, +0.971530436873412230, 0.971542281397703710, 0.971554123493139300, 0.971565963159689680, 0.971577800397325220, 0.971589635206016380, 0.971601467585733290, 0.971613297536446430, +0.971625125058126480, 0.971636950150743580, 0.971648772814268420, 0.971660593048671250, 0.971672410853922640, 0.971684226229993180, 0.971696039176852990, 0.971707849694472660, +0.971719657782822770, 0.971731463441873670, 0.971743266671595940, 0.971755067471959940, 0.971766865842936590, 0.971778661784495900, 0.971790455296608460, 0.971802246379244950, +0.971814035032375840, 0.971825821255971610, 0.971837605050002720, 0.971849386414439960, 0.971861165349253930, 0.971872941854414750, 0.971884715929893230, 0.971896487575659940, +0.971908256791685350, 0.971920023577940160, 0.971931787934394940, 0.971943549861020380, 0.971955309357786850, 0.971967066424665020, 0.971978821061625480, 0.971990573268638910, +0.972002323045675910, 0.972014070392707040, 0.972025815309703110, 0.972037557796634810, 0.972049297853472380, 0.972061035480186630, 0.972072770676748470, 0.972084503443128240, +0.972096233779296770, 0.972107961685224730, 0.972119687160882820, 0.972131410206241940, 0.972143130821272240, 0.972154849005944730, 0.972166564760230110, 0.972178278084099070, +0.972189988977522400, 0.972201697440470690, 0.972213403472914960, 0.972225107074825570, 0.972236808246173310, 0.972248506986929110, 0.972260203297063530, 0.972271897176547610, +0.972283588625351800, 0.972295277643447140, 0.972306964230804430, 0.972318648387394120, 0.972330330113187150, 0.972342009408154410, 0.972353686272266590, 0.972365360705494510, +0.972377032707809170, 0.972388702279181170, 0.972400369419581630, 0.972412034128980920, 0.972423696407350160, 0.972435356254660150, 0.972447013670881820, 0.972458668655985850, +0.972470321209943260, 0.972481971332725070, 0.972493619024301760, 0.972505264284644460, 0.972516907113723960, 0.972528547511511080, 0.972540185477976940, 0.972551821013092340, +0.972563454116828210, 0.972575084789155550, 0.972586713030045070, 0.972598338839467670, 0.972609962217394600, 0.972621583163796540, 0.972633201678644530, 0.972644817761909470, +0.972656431413562620, 0.972668042633574540, 0.972679651421916260, 0.972691257778558920, 0.972702861703473310, 0.972714463196630690, 0.972726062258001840, 0.972737658887557810, +0.972749253085269940, 0.972760844851108700, 0.972772434185045330, 0.972784021087050870, 0.972795605557096320, 0.972807187595152830, 0.972818767201191310, 0.972830344375182900, +0.972841919117098830, 0.972853491426909800, 0.972865061304586940, 0.972876628750101500, 0.972888193763424500, 0.972899756344526970, 0.972911316493380140, 0.972922874209955160, +0.972934429494222710, 0.972945982346154260, 0.972957532765720940, 0.972969080752893680, 0.972980626307643700, 0.972992169429942270, 0.973003710119760280, 0.973015248377069320, +0.973026784201839970, 0.973038317594043690, 0.973049848553651620, 0.973061377080635000, 0.973072903174964860, 0.973084426836612450, 0.973095948065549000, 0.973107466861745870, +0.973118983225173870, 0.973130497155804460, 0.973142008653608670, 0.973153517718557960, 0.973165024350623460, 0.973176528549776430, 0.973188030315988220, 0.973199529649229730, +0.973211026549472450, 0.973222521016687600, 0.973234013050846450, 0.973245502651920340, 0.973256989819880400, 0.973268474554697890, 0.973279956856344500, 0.973291436724791010, +0.973302914160008910, 0.973314389161969550, 0.973325861730644280, 0.973337331866004240, 0.973348799568020890, 0.973360264836665820, 0.973371727671909830, 0.973383188073724480, +0.973394646042081260, 0.973406101576951290, 0.973417554678306150, 0.973429005346117200, 0.973440453580355580, 0.973451899380993190, 0.973463342748000730, 0.973474783681349990, +0.973486222181012220, 0.973497658246958890, 0.973509091879161460, 0.973520523077591290, 0.973531951842219860, 0.973543378173018730, 0.973554802069958920, 0.973566223533012030, +0.973577642562149740, 0.973589059157343280, 0.973600473318564140, 0.973611885045783780, 0.973623294338973990, 0.973634701198105800, 0.973646105623150790, 0.973657507614080540, +0.973668907170866520, 0.973680304293480180, 0.973691698981893120, 0.973703091236076790, 0.973714481056003000, 0.973725868441642770, 0.973737253392967790, 0.973748635909949760, +0.973760015992560120, 0.973771393640770480, 0.973782768854552390, 0.973794141633877450, 0.973805511978717010, 0.973816879889042860, 0.973828245364826480, 0.973839608406039450, +0.973850969012653440, 0.973862327184639940, 0.973873682921970630, 0.973885036224617420, 0.973896387092551330, 0.973907735525744280, 0.973919081524167840, 0.973930425087793820, +0.973941766216593670, 0.973953104910539100, 0.973964441169601790, 0.973975774993753540, 0.973987106382965710, 0.973998435337210090, 0.974009761856458380, 0.974021085940682260, +0.974032407589853430, 0.974043726803943580, 0.974055043582924610, 0.974066357926767770, 0.974077669835445080, 0.974088979308928240, 0.974100286347189040, 0.974111590950198950, +0.974122893117929990, 0.974134192850353740, 0.974145490147442230, 0.974156785009166910, 0.974168077435499490, 0.974179367426411870, 0.974190654981875850, 0.974201940101863230, +0.974213222786345810, 0.974224503035295290, 0.974235780848683670, 0.974247056226482440, 0.974258329168663510, 0.974269599675198770, 0.974280867746060040, 0.974292133381219230, +0.974303396580648020, 0.974314657344318550, 0.974325915672202170, 0.974337171564271020, 0.974348425020496900, 0.974359676040851830, 0.974370924625307500, 0.974382170773835930, +0.974393414486408820, 0.974404655762998400, 0.974415894603576250, 0.974427131008114290, 0.974438364976584430, 0.974449596508958790, 0.974460825605209080, 0.974472052265307310, +0.974483276489225610, 0.974494498276935570, 0.974505717628409210, 0.974516934543618650, 0.974528149022535710, 0.974539361065132390, 0.974550570671380620, 0.974561777841252530, +0.974572982574720030, 0.974584184871755020, 0.974595384732329540, 0.974606582156415490, 0.974617777143985120, 0.974628969695010230, 0.974640159809462950, 0.974651347487315300, +0.974662532728539420, 0.974673715533107000, 0.974684895900990280, 0.974696073832161390, 0.974707249326592250, 0.974718422384255100, 0.974729593005121740, 0.974740761189164750, +0.974751926936355590, 0.974763090246666520, 0.974774251120069880, 0.974785409556537470, 0.974796565556041660, 0.974807719118554350, 0.974818870244047790, 0.974830018932494210, +0.974841165183865430, 0.974852308998133800, 0.974863450375271330, 0.974874589315250170, 0.974885725818042560, 0.974896859883620740, 0.974907991511956730, 0.974919120703022890, +0.974930247456791020, 0.974941371773233590, 0.974952493652322730, 0.974963613094030680, 0.974974730098329470, 0.974985844665191560, 0.974996956794589200, 0.975008066486494180, +0.975019173740879100, 0.975030278557716070, 0.975041380936977230, 0.975052480878635050, 0.975063578382661670, 0.975074673449029320, 0.975085766077710470, 0.975096856268677040, +0.975107944021901480, 0.975119029337355950, 0.975130112215013000, 0.975141192654844670, 0.975152270656823420, 0.975163346220921600, 0.975174419347111240, 0.975185490035364920, +0.975196558285654770, 0.975207624097953360, 0.975218687472232730, 0.975229748408465550, 0.975240806906623850, 0.975251862966680430, 0.975262916588607090, 0.975273967772376520, +0.975285016517960960, 0.975296062825332880, 0.975307106694464630, 0.975318148125328690, 0.975329187117897290, 0.975340223672143130, 0.975351257788038330, 0.975362289465555250, +0.975373318704666480, 0.975384345505344470, 0.975395369867561590, 0.975406391791290180, 0.975417411276503050, 0.975428428323172230, 0.975439442931270380, 0.975450455100769780, +0.975461464831643200, 0.975472472123862900, 0.975483476977401340, 0.975494479392231220, 0.975505479368324990, 0.975516476905654910, 0.975527472004193650, 0.975538464663913700, +0.975549454884787500, 0.975560442666787760, 0.975571428009886940, 0.975582410914057510, 0.975593391379272260, 0.975604369405503320, 0.975615344992723400, 0.975626318140905170, +0.975637288850021210, 0.975648257120043990, 0.975659222950946090, 0.975670186342700310, 0.975681147295278990, 0.975692105808654620, 0.975703061882800090, 0.975714015517687990, +0.975724966713290790, 0.975735915469581050, 0.975746861786531690, 0.975757805664115300, 0.975768747102304210, 0.975779686101071240, 0.975790622660389070, 0.975801556780230280, +0.975812488460567670, 0.975823417701373820, 0.975834344502621630, 0.975845268864283360, 0.975856190786331900, 0.975867110268740070, 0.975878027311480320, 0.975888941914525580, +0.975899854077848520, 0.975910763801421830, 0.975921671085218320, 0.975932575929210570, 0.975943478333371250, 0.975954378297673290, 0.975965275822089470, 0.975976170906592390, +0.975987063551154830, 0.975997953755749600, 0.976008841520349830, 0.976019726844927660, 0.976030609729456210, 0.976041490173908180, 0.976052368178256470, 0.976063243742473770, +0.976074116866533000, 0.976084987550407180, 0.976095855794068660, 0.976106721597490570, 0.976117584960645600, 0.976128445883506670, 0.976139304366046570, 0.976150160408238320, +0.976161014010054620, 0.976171865171468590, 0.976182713892452700, 0.976193560172980090, 0.976204404013023440, 0.976215245412555890, 0.976226084371550230, 0.976236920889979260, +0.976247754967816020, 0.976258586605033620, 0.976269415801604650, 0.976280242557502010, 0.976291066872698840, 0.976301888747167950, 0.976312708180882340, 0.976323525173814930, +0.976334339725938970, 0.976345151837226920, 0.976355961507652030, 0.976366768737187200, 0.976377573525805560, 0.976388375873479820, 0.976399175780183200, 0.976409973245888740, +0.976420768270569450, 0.976431560854198020, 0.976442350996747700, 0.976453138698191610, 0.976463923958502570, 0.976474706777653690, 0.976485487155618110, 0.976496265092368980, +0.976507040587879070, 0.976517813642121420, 0.976528584255069390, 0.976539352426695760, 0.976550118156973790, 0.976560881445876610, 0.976571642293377120, 0.976582400699448790, +0.976593156664064210, 0.976603910187196830, 0.976614661268819570, 0.976625409908905670, 0.976636156107428270, 0.976646899864360480, 0.976657641179675460, 0.976668380053346550, +0.976679116485346440, 0.976689850475648600, 0.976700582024226050, 0.976711311131052140, 0.976722037796099900, 0.976732762019342560, 0.976743483800753490, 0.976754203140305590, +0.976764920037972110, 0.976775634493726400, 0.976786346507541480, 0.976797056079390820, 0.976807763209247450, 0.976818467897084710, 0.976829170142875960, 0.976839869946594110, +0.976850567308212630, 0.976861262227704750, 0.976871954705043620, 0.976882644740202700, 0.976893332333155010, 0.976904017483874340, 0.976914700192333400, 0.976925380458505630, +0.976936058282364520, 0.976946733663883180, 0.976957406603035090, 0.976968077099793390, 0.976978745154131520, 0.976989410766023080, 0.977000073935440750, 0.977010734662358330, +0.977021392946749060, 0.977032048788586400, 0.977042702187843500, 0.977053353144493930, 0.977064001658510930, 0.977074647729868070, 0.977085291358538500, 0.977095932544495670, +0.977106571287712940, 0.977117207588163780, 0.977127841445821650, 0.977138472860660020, 0.977149101832652240, 0.977159728361771560, 0.977170352447991550, 0.977180974091285790, +0.977191593291627410, 0.977202210048990110, 0.977212824363347330, 0.977223436234672450, 0.977234045662939250, 0.977244652648120660, 0.977255257190190460, 0.977265859289122130, +0.977276458944889130, 0.977287056157464920, 0.977297650926823190, 0.977308243252937300, 0.977318833135780940, 0.977329420575327350, 0.977340005571550210, 0.977350588124422990, +0.977361168233919390, 0.977371745900012860, 0.977382321122676980, 0.977392893901885440, 0.977403464237611490, 0.977414032129828800, 0.977424597578511190, 0.977435160583632000, +0.977445721145164930, 0.977456279263083540, 0.977466834937361420, 0.977477388167972470, 0.977487938954889830, 0.977498487298087300, 0.977509033197538570, 0.977519576653217310, +0.977530117665097120, 0.977540656233151560, 0.977551192357354550, 0.977561726037679430, 0.977572257274100020, 0.977582786066589880, 0.977593312415122820, 0.977603836319672510, +0.977614357780212550, 0.977624876796716720, 0.977635393369158830, 0.977645907497512350, 0.977656419181751060, 0.977666928421848770, 0.977677435217779170, 0.977687939569515940, +0.977698441477032780, 0.977708940940303580, 0.977719437959302270, 0.977729932534002200, 0.977740424664377160, 0.977750914350401180, 0.977761401592047830, 0.977771886389291020, +0.977782368742104560, 0.977792848650462230, 0.977803326114337730, 0.977813801133704860, 0.977824273708537420, 0.977834743838809420, 0.977845211524494440, 0.977855676765566510, +0.977866139561999410, 0.977876599913767080, 0.977887057820843060, 0.977897513283201400, 0.977907966300816000, 0.977918416873660660, 0.977928865001709280, 0.977939310684935780, +0.977949753923313960, 0.977960194716817940, 0.977970633065421200, 0.977981068969097980, 0.977991502427822070, 0.978001933441567380, 0.978012362010307830, 0.978022788134017330, +0.978033211812670110, 0.978043633046239760, 0.978054051834700180, 0.978064468178025610, 0.978074882076189760, 0.978085293529166730, 0.978095702536930460, 0.978106109099454950, +0.978116513216714440, 0.978126914888682310, 0.978137314115333000, 0.978147710896640320, 0.978158105232578400, 0.978168497123121260, 0.978178886568242810, 0.978189273567917410, +0.978199658122118620, 0.978210040230820590, 0.978220419893997550, 0.978230797111623530, 0.978241171883672320, 0.978251544210118400, 0.978261914090935440, 0.978272281526098020, +0.978282646515579610, 0.978293009059354570, 0.978303369157397130, 0.978313726809681090, 0.978324082016180930, 0.978334434776870430, 0.978344785091723850, 0.978355132960715520, +0.978365478383819260, 0.978375821361009200, 0.978386161892259580, 0.978396499977544630, 0.978406835616838390, 0.978417168810115090, 0.978427499557348980, 0.978437827858513960, +0.978448153713584400, 0.978458477122534420, 0.978468798085338260, 0.978479116601970180, 0.978489432672404290, 0.978499746296614740, 0.978510057474576090, 0.978520366206262040, +0.978530672491647050, 0.978540976330705470, 0.978551277723411440, 0.978561576669739200, 0.978571873169662990, 0.978582167223157050, 0.978592458830195970, 0.978602747990753530, +0.978613034704804210, 0.978623318972322350, 0.978633600793282210, 0.978643880167658020, 0.978654157095424030, 0.978664431576555030, 0.978674703611024600, 0.978684973198807540, +0.978695240339877980, 0.978705505034210280, 0.978715767281778890, 0.978726027082558070, 0.978736284436522160, 0.978746539343645750, 0.978756791803902740, 0.978767041817267810, +0.978777289383715220, 0.978787534503219540, 0.978797777175754890, 0.978808017401295860, 0.978818255179817020, 0.978828490511292280, 0.978838723395696330, 0.978848953833003520, +0.978859181823188430, 0.978869407366225300, 0.978879630462088700, 0.978889851110753000, 0.978900069312192870, 0.978910285066382340, 0.978920498373296200, 0.978930709232908700, +0.978940917645194530, 0.978951123610128040, 0.978961327127683690, 0.978971528197836060, 0.978981726820559730, 0.978991922995828930, 0.979002116723618370, 0.979012308003902490, +0.979022496836655880, 0.979032683221853000, 0.979042867159468420, 0.979053048649476840, 0.979063227691852500, 0.979073404286569970, 0.979083578433604050, 0.979093750132929100, +0.979103919384519910, 0.979114086188350830, 0.979124250544396450, 0.979134412452631770, 0.979144571913030840, 0.979154728925568430, 0.979164883490219240, 0.979175035606957840, +0.979185185275758820, 0.979195332496596850, 0.979205477269446620, 0.979215619594282830, 0.979225759471079700, 0.979235896899812270, 0.979246031880455110, 0.979256164412982910, +0.979266294497370240, 0.979276422133591900, 0.979286547321622570, 0.979296670061436720, 0.979306790353009270, 0.979316908196314780, 0.979327023591328060, 0.979337136538023790, +0.979347247036376660, 0.979357355086361350, 0.979367460687952880, 0.979377563841125620, 0.979387664545854350, 0.979397762802113990, 0.979407858609879220, 0.979417951969124840, +0.979428042879825540, 0.979438131341956340, 0.979448217355491590, 0.979458300920406310, 0.979468382036675300, 0.979478460704273360, 0.979488536923175170, 0.979498610693355750, +0.979508682014789690, 0.979518750887452220, 0.979528817311317580, 0.979538881286361020, 0.979548942812557220, 0.979559001889880990, 0.979569058518307330, 0.979579112697810950, +0.979589164428366850, 0.979599213709950070, 0.979609260542534940, 0.979619304926096720, 0.979629346860610320, 0.979639386346050410, 0.979649423382392140, 0.979659457969610290, +0.979669490107680010, 0.979679519796575750, 0.979689547036272760, 0.979699571826745830, 0.979709594167969990, 0.979719614059920140, 0.979729631502571310, 0.979739646495898400, +0.979749659039876540, 0.979759669134480320, 0.979769676779684960, 0.979779681975465500, 0.979789684721796730, 0.979799685018653780, 0.979809682866011560, 0.979819678263845310, +0.979829671212129830, 0.979839661710840030, 0.979849649759951150, 0.979859635359438100, 0.979869618509276010, 0.979879599209439790, 0.979889577459904680, 0.979899553260645710, +0.979909526611637660, 0.979919497512855900, 0.979929465964275330, 0.979939431965871190, 0.979949395517618390, 0.979959356619492070, 0.979969315271467360, 0.979979271473519600, +0.979989225225623480, 0.979999176527754260, 0.980009125379887160, 0.980019071781997210, 0.980029015734059540, 0.980038957236049390, 0.980048896287942010, 0.980058832889712180, +0.980068767041335280, 0.980078698742786520, 0.980088627994040950, 0.980098554795073800, 0.980108479145860300, 0.980118401046375600, 0.980128320496595040, 0.980138237496493540, +0.980148152046046440, 0.980158064145228990, 0.980167973794016320, 0.980177880992383790, 0.980187785740306520, 0.980197688037759750, 0.980207587884718960, 0.980217485281159040, +0.980227380227055470, 0.980237272722383370, 0.980247162767118100, 0.980257050361234890, 0.980266935504709110, 0.980276818197516110, 0.980286698439630900, 0.980296576231028950, +0.980306451571685610, 0.980316324461576130, 0.980326194900675850, 0.980336062888960020, 0.980345928426404110, 0.980355791512983470, 0.980365652148673220, 0.980375510333448830, +0.980385366067285660, 0.980395219350159050, 0.980405070182044480, 0.980414918562917180, 0.980424764492752730, 0.980434607971526260, 0.980444448999213240, 0.980454287575789120, +0.980464123701229260, 0.980473957375509020, 0.980483788598603970, 0.980493617370489460, 0.980503443691141060, 0.980513267560533810, 0.980523088978643490, 0.980532907945445450, +0.980542724460915060, 0.980552538525027880, 0.980562350137759390, 0.980572159299085030, 0.980581966008980400, 0.980591770267420730, 0.980601572074381590, 0.980611371429838560, +0.980621168333767110, 0.980630962786142700, 0.980640754786940900, 0.980650544336137410, 0.980660331433707340, 0.980670116079626510, 0.980679898273870370, 0.980689678016414380, +0.980699455307234350, 0.980709230146305620, 0.980719002533603780, 0.980728772469104610, 0.980738539952783370, 0.980748304984615740, 0.980758067564577400, 0.980767827692643810, +0.980777585368790780, 0.980787340592993660, 0.980797093365228250, 0.980806843685470330, 0.980816591553695050, 0.980826336969878310, 0.980836079933995690, 0.980845820446022980, +0.980855558505935640, 0.980865294113709370, 0.980875027269320080, 0.980884757972743100, 0.980894486223954140, 0.980904212022928990, 0.980913935369643330, 0.980923656264072850, +0.980933374706193240, 0.980943090695980180, 0.980952804233409580, 0.980962515318456680, 0.980972223951097620, 0.980981930131307970, 0.980991633859063520, 0.981001335134339850, +0.981011033957112980, 0.981020730327358700, 0.981030424245052380, 0.981040115710170020, 0.981049804722687320, 0.981059491282580080, 0.981069175389824190, 0.981078857044395350, +0.981088536246269350, 0.981098212995422210, 0.981107887291829410, 0.981117559135466830, 0.981127228526310290, 0.981136895464335800, 0.981146559949519050, 0.981156221981835830, +0.981165881561262050, 0.981175538687773850, 0.981185193361346570, 0.981194845581956240, 0.981204495349578880, 0.981214142664190270, 0.981223787525766330, 0.981233429934282860, +0.981243069889715990, 0.981252707392041290, 0.981262342441234890, 0.981271975037272480, 0.981281605180130300, 0.981291232869784040, 0.981300858106209710, 0.981310480889383220, +0.981320101219280700, 0.981329719095877740, 0.981339334519150450, 0.981348947489074860, 0.981358558005626990, 0.981368166068782630, 0.981377771678517810, 0.981387374834808650, +0.981396975537631170, 0.981406573786961170, 0.981416169582774670, 0.981425762925047680, 0.981435353813756460, 0.981444942248876680, 0.981454528230384590, 0.981464111758256430, +0.981473692832467770, 0.981483271452994850, 0.981492847619813810, 0.981502421332900670, 0.981511992592231320, 0.981521561397782130, 0.981531127749529000, 0.981540691647448280, +0.981550253091515560, 0.981559812081707280, 0.981569368617999370, 0.981578922700368170, 0.981588474328789600, 0.981598023503239880, 0.981607570223695160, 0.981617114490131450, +0.981626656302524990, 0.981636195660851810, 0.981645732565088140, 0.981655267015210220, 0.981664799011194080, 0.981674328553015840, 0.981683855640652080, 0.981693380274078490, +0.981702902453271410, 0.981712422178207090, 0.981721939448861770, 0.981731454265211580, 0.981740966627232760, 0.981750476534901440, 0.981759983988194200, 0.981769488987086710, +0.981778991531555680, 0.981788491621577000, 0.981797989257127130, 0.981807484438182330, 0.981816977164718830, 0.981826467436713090, 0.981835955254140910, 0.981845440616978870, +0.981854923525203320, 0.981864403978790380, 0.981873881977716410, 0.981883357521957770, 0.981892830611490690, 0.981902301246291740, 0.981911769426336840, 0.981921235151602570, +0.981930698422065260, 0.981940159237701060, 0.981949617598486530, 0.981959073504398040, 0.981968526955411810, 0.981977977951504430, 0.981987426492651920, 0.981996872578830840, +0.982006316210017550, 0.982015757386188510, 0.982025196107320090, 0.982034632373388620, 0.982044066184370790, 0.982053497540242630, 0.982062926440980700, 0.982072352886561470, +0.982081776876961410, 0.982091198412156750, 0.982100617492124290, 0.982110034116840170, 0.982119448286281170, 0.982128860000423320, 0.982138269259243410, 0.982147676062717800, +0.982157080410822950, 0.982166482303535430, 0.982175881740831700, 0.982185278722688460, 0.982194673249081830, 0.982204065319988610, 0.982213454935385140, 0.982222842095248020, +0.982232226799553800, 0.982241609048279060, 0.982250988841400270, 0.982260366178894120, 0.982269741060736950, 0.982279113486905440, 0.982288483457376180, 0.982297850972125630, +0.982307216031130470, 0.982316578634367280, 0.982325938781812620, 0.982335296473443310, 0.982344651709235570, 0.982354004489166210, 0.982363354813211910, 0.982372702681349130, +0.982382048093554670, 0.982391391049805000, 0.982400731550077120, 0.982410069594347180, 0.982419405182592080, 0.982428738314788390, 0.982438068990913020, 0.982447397210942320, +0.982456722974853200, 0.982466046282622240, 0.982475367134226450, 0.982484685529641970, 0.982494001468845800, 0.982503314951814530, 0.982512625978525070, 0.982521934548954090, +0.982531240663078180, 0.982540544320874450, 0.982549845522319050, 0.982559144267389110, 0.982568440556061300, 0.982577734388312420, 0.982587025764119160, 0.982596314683458430, +0.982605601146306800, 0.982614885152641390, 0.982624166702438570, 0.982633445795675350, 0.982642722432328530, 0.982651996612374900, 0.982661268335791260, 0.982670537602554410, +0.982679804412641240, 0.982689068766028790, 0.982698330662693520, 0.982707590102612330, 0.982716847085762240, 0.982726101612119930, 0.982735353681662430, 0.982744603294366530, +0.982753850450209350, 0.982763095149167380, 0.982772337391217610, 0.982781577176336960, 0.982790814504502450, 0.982800049375690880, 0.982809281789879140, 0.982818511747044270, +0.982827739247163270, 0.982836964290212720, 0.982846186876169760, 0.982855407005011390, 0.982864624676714540, 0.982873839891255980, 0.982883052648612980, 0.982892262948762200, +0.982901470791681000, 0.982910676177345950, 0.982919879105734200, 0.982929079576822740, 0.982938277590588600, 0.982947473147008810, 0.982956666246060370, 0.982965856887720310, +0.982975045071965540, 0.982984230798773060, 0.982993414068120130, 0.983002594879983540, 0.983011773234340520, 0.983020949131168110, 0.983030122570443200, 0.983039293552143260, +0.983048462076244860, 0.983057628142725350, 0.983066791751561750, 0.983075952902731200, 0.983085111596210700, 0.983094267831977510, 0.983103421610008740, 0.983112572930281310, +0.983121721792772460, 0.983130868197459210, 0.983140012144318900, 0.983149153633328550, 0.983158292664465190, 0.983167429237706280, 0.983176563353028830, 0.983185695010409870, +0.983194824209826620, 0.983203950951256340, 0.983213075234676160, 0.983222197060063310, 0.983231316427395030, 0.983240433336648350, 0.983249547787800830, 0.983258659780829270, +0.983267769315711030, 0.983276876392423340, 0.983285981010943550, 0.983295083171248700, 0.983304182873316220, 0.983313280117123380, 0.983322374902647290, 0.983331467229865200, +0.983340557098754340, 0.983349644509292190, 0.983358729461455970, 0.983367811955222940, 0.983376891990570320, 0.983385969567475590, 0.983395044685915760, 0.983404117345868410, +0.983413187547310770, 0.983422255290220090, 0.983431320574573830, 0.983440383400349230, 0.983449443767523750, 0.983458501676074740, 0.983467557125979330, 0.983476610117214990, +0.983485660649759170, 0.983494708723589240, 0.983503754338682530, 0.983512797495016410, 0.983521838192568440, 0.983530876431315650, 0.983539912211235820, 0.983548945532306100, +0.983557976394504040, 0.983567004797807010, 0.983576030742192580, 0.983585054227637980, 0.983594075254120900, 0.983603093821618480, 0.983612109930108390, 0.983621123579567990, +0.983630134769974740, 0.983639143501306210, 0.983648149773539760, 0.983657153586653180, 0.983666154940623480, 0.983675153835428470, 0.983684150271045500, 0.983693144247452130, +0.983702135764626060, 0.983711124822544520, 0.983720111421185210, 0.983729095560525680, 0.983738077240543410, 0.983747056461215850, 0.983756033222520700, 0.983765007524435410, +0.983773979366937670, 0.983782948750004940, 0.983791915673614790, 0.983800880137745140, 0.983809842142372990, 0.983818801687476370, 0.983827758773032630, 0.983836713399019570, +0.983845665565414640, 0.983854615272195640, 0.983863562519340260, 0.983872507306825740, 0.983881449634629980, 0.983890389502730670, 0.983899326911105270, 0.983908261859731570, +0.983917194348587270, 0.983926124377650040, 0.983935051946897570, 0.983943977056307320, 0.983952899705857090, 0.983961819895524670, 0.983970737625287750, 0.983979652895123900, +0.983988565705010920, 0.983997476054926600, 0.984006383944848630, 0.984015289374754690, 0.984024192344622460, 0.984033092854429750, 0.984041990904154230, 0.984050886493773810, +0.984059779623266180, 0.984068670292609250, 0.984077558501780470, 0.984086444250757750, 0.984095327539519000, 0.984104208368041910, 0.984113086736304380, 0.984121962644283980, +0.984130836091958730, 0.984139707079306540, 0.984148575606304980, 0.984157441672931950, 0.984166305279165380, 0.984175166424982930, 0.984184025110362630, 0.984192881335282270, +0.984201735099719870, 0.984210586403652890, 0.984219435247059570, 0.984228281629917600, 0.984237125552204880, 0.984245967013899440, 0.984254806014979060, 0.984263642555421540, +0.984272476635205230, 0.984281308254307490, 0.984290137412706550, 0.984298964110380200, 0.984307788347306480, 0.984316610123463280, 0.984325429438828500, 0.984334246293380180, +0.984343060687096430, 0.984351872619954940, 0.984360682091933610, 0.984369489103010700, 0.984378293653163980, 0.984387095742371600, 0.984395895370611450, 0.984404692537861670, +0.984413487244100050, 0.984422279489304720, 0.984431069273453700, 0.984439856596525000, 0.984448641458496640, 0.984457423859346650, 0.984466203799053140, 0.984474981277594360, +0.984483756294947890, 0.984492528851091950, 0.984501298946004800, 0.984510066579664330, 0.984518831752048800, 0.984527594463136090, 0.984536354712904460, 0.984545112501332030, +0.984553867828396710, 0.984562620694076740, 0.984571371098350130, 0.984580119041195130, 0.984588864522589870, 0.984597607542512470, 0.984606348100941160, 0.984615086197853870, +0.984623821833228830, 0.984632555007044160, 0.984641285719278230, 0.984650013969909030, 0.984658739758914820, 0.984667463086273730, 0.984676183951964210, 0.984684902355963950, +0.984693618298251530, 0.984702331778805060, 0.984711042797602690, 0.984719751354622750, 0.984728457449843500, 0.984737161083243160, 0.984745862254799760, 0.984754560964491770, +0.984763257212297400, 0.984771950998194810, 0.984780642322162450, 0.984789331184178440, 0.984798017584221030, 0.984806701522268790, 0.984815382998299630, 0.984824062012292000, +0.984832738564224260, 0.984841412654074650, 0.984850084281821530, 0.984858753447443110, 0.984867420150917880, 0.984876084392224290, 0.984884746171340250, 0.984893405488244330, +0.984902062342915000, 0.984910716735330480, 0.984919368665469140, 0.984928018133309440, 0.984936665138829710, 0.984945309682008330, 0.984953951762823520, 0.984962591381253970, +0.984971228537277920, 0.984979863230873720, 0.984988495462019940, 0.984997125230694830, 0.985005752536877170, 0.985014377380544870, 0.985022999761676730, 0.985031619680250990, +0.985040237136246330, 0.985048852129640990, 0.985057464660413550, 0.985066074728542460, 0.985074682334006300, 0.985083287476783200, 0.985091890156852060, 0.985100490374191120, +0.985109088128778840, 0.985117683420594030, 0.985126276249614910, 0.985134866615820280, 0.985143454519188280, 0.985152039959697690, 0.985160622937326980, 0.985169203452054720, +0.985177781503859480, 0.985186357092719730, 0.985194930218614150, 0.985203500881521420, 0.985212069081419670, 0.985220634818287810, 0.985229198092104410, 0.985237758902847930, +0.985246317250497160, 0.985254873135030460, 0.985263426556426850, 0.985271977514664440, 0.985280526009722160, 0.985289072041578560, 0.985297615610212230, 0.985306156715601840, +0.985314695357726090, 0.985323231536563650, 0.985331765252093210, 0.985340296504293220, 0.985348825293142490, 0.985357351618619810, 0.985365875480703650, 0.985374396879372780, +0.985382915814605910, 0.985391432286381820, 0.985399946294679310, 0.985408457839476730, 0.985416966920752980, 0.985425473538486860, 0.985433977692657060, 0.985442479383242250, +0.985450978610221350, 0.985459475373573150, 0.985467969673275990, 0.985476461509309010, 0.985484950881650890, 0.985493437790280310, 0.985501922235176190, 0.985510404216317190, +0.985518883733682240, 0.985527360787250230, 0.985535835376999740, 0.985544307502909560, 0.985552777164958590, 0.985561244363125750, 0.985569709097389830, 0.985578171367729630, +0.985586631174124040, 0.985595088516551860, 0.985603543394991900, 0.985611995809423050, 0.985620445759824220, 0.985628893246174310, 0.985637338268452120, 0.985645780826636560, +0.985654220920706760, 0.985662658550641280, 0.985671093716419140, 0.985679526418019260, 0.985687956655420530, 0.985696384428601970, 0.985704809737542380, 0.985713232582220880, +0.985721652962616270, 0.985730070878707560, 0.985738486330473560, 0.985746899317893390, 0.985755309840945950, 0.985763717899610260, 0.985772123493865230, 0.985780526623690090, +0.985788927289063420, 0.985797325489964460, 0.985805721226372220, 0.985814114498265730, 0.985822505305623880, 0.985830893648425690, 0.985839279526650400, 0.985847662940277040, +0.985856043889284270, 0.985864422373651460, 0.985872798393357620, 0.985881171948381760, 0.985889543038703020, 0.985897911664300410, 0.985906277825152940, 0.985914641521239980, +0.985923002752540300, 0.985931361519033040, 0.985939717820697450, 0.985948071657512530, 0.985956423029457410, 0.985964771936511220, 0.985973118378653310, 0.985981462355862370, +0.985989803868117850, 0.985998142915398890, 0.986006479497684380, 0.986014813614953800, 0.986023145267186150, 0.986031474454360680, 0.986039801176456620, 0.986048125433452990, +0.986056447225329040, 0.986064766552063880, 0.986073083413636860, 0.986081397810027130, 0.986089709741213900, 0.986098019207176550, 0.986106326207893960, 0.986114630743345600, +0.986122932813510600, 0.986131232418368310, 0.986139529557897960, 0.986147824232078810, 0.986156116440890070, 0.986164406184311230, 0.986172693462321170, 0.986180978274899370, +0.986189260622025170, 0.986197540503677690, 0.986205817919836520, 0.986214092870480790, 0.986222365355589710, 0.986230635375142990, 0.986238902929119420, 0.986247168017498680, +0.986255430640260000, 0.986263690797382740, 0.986271948488846250, 0.986280203714629990, 0.986288456474713190, 0.986296706769075220, 0.986304954597695400, 0.986313199960553330, +0.986321442857628130, 0.986329683288899360, 0.986337921254346380, 0.986346156753948660, 0.986354389787685640, 0.986362620355536460, 0.986370848457480800, 0.986379074093498010, +0.986387297263567440, 0.986395517967668780, 0.986403736205781260, 0.986411951977884340, 0.986420165283957710, 0.986428376123980600, 0.986436584497932480, 0.986444790405792920, +0.986452993847541370, 0.986461194823157310, 0.986469393332620400, 0.986477589375910010, 0.986485782953005490, 0.986493974063886610, 0.986502162708532750, 0.986510348886923460, +0.986518532599038320, 0.986526713844856910, 0.986534892624358670, 0.986543068937523300, 0.986551242784330150, 0.986559414164758900, 0.986567583078789110, 0.986575749526400370, +0.986583913507572240, 0.986592075022284300, 0.986600234070516340, 0.986608390652247700, 0.986616544767458080, 0.986624696416127040, 0.986632845598234280, 0.986640992313759460, +0.986649136562682050, 0.986657278344981850, 0.986665417660638640, 0.986673554509631680, 0.986681688891940860, 0.986689820807545860, 0.986697950256426260, 0.986706077238561740, +0.986714201753932100, 0.986722323802517010, 0.986730443384296160, 0.986738560499249020, 0.986746675147355590, 0.986754787328595450, 0.986762897042948280, 0.986771004290393880, +0.986779109070912040, 0.986787211384482550, 0.986795311231084770, 0.986803408610698820, 0.986811503523304380, 0.986819595968881140, 0.986827685947408880, 0.986835773458867420, +0.986843858503236530, 0.986851941080496230, 0.986860021190625770, 0.986868098833605380, 0.986876174009414740, 0.986884246718033540, 0.986892316959441910, 0.986900384733619300, +0.986908450040545840, 0.986916512880201440, 0.986924573252565550, 0.986932631157618200, 0.986940686595339290, 0.986948739565708720, 0.986956790068706180, 0.986964838104311790, +0.986972883672505350, 0.986980926773266650, 0.986988967406575600, 0.986997005572412100, 0.987005041270756170, 0.987013074501587600, 0.987021105264886290, 0.987029133560632270, +0.987037159388805540, 0.987045182749385690, 0.987053203642353050, 0.987061222067687320, 0.987069238025368500, 0.987077251515376620, 0.987085262537691580, 0.987093271092293610, +0.987101277179162180, 0.987109280798277640, 0.987117281949619900, 0.987125280633168960, 0.987133276848904840, 0.987141270596807560, 0.987149261876857030, 0.987157250689033480, +0.987165237033316710, 0.987173220909686840, 0.987181202318123900, 0.987189181258607880, 0.987197157731119050, 0.987205131735637290, 0.987213103272142620, 0.987221072340615400, +0.987229038941035310, 0.987237003073382690, 0.987244964737637560, 0.987252923933779950, 0.987260880661790070, 0.987268834921647960, 0.987276786713333960, 0.987284736036827870, +0.987292682892109920, 0.987300627279160240, 0.987308569197958950, 0.987316508648486300, 0.987324445630722300, 0.987332380144647300, 0.987340312190241430, 0.987348241767484590, +0.987356168876357240, 0.987364093516839400, 0.987372015688911420, 0.987379935392553310, 0.987387852627745420, 0.987395767394467880, 0.987403679692701040, 0.987411589522424800, +0.987419496883619740, 0.987427401776265870, 0.987435304200343420, 0.987443204155832750, 0.987451101642714100, 0.987458996660967810, 0.987466889210573910, 0.987474779291512840, +0.987482666903764740, 0.987490552047310070, 0.987498434722128950, 0.987506314928201730, 0.987514192665508660, 0.987522067934030410, 0.987529940733746780, 0.987537811064638230, +0.987545678926685210, 0.987553544319867970, 0.987561407244166970, 0.987569267699562330, 0.987577125686034730, 0.987584981203564080, 0.987592834252131070, 0.987600684831716040, +0.987608532942299110, 0.987616378583860980, 0.987624221756381870, 0.987632062459842250, 0.987639900694222580, 0.987647736459502990, 0.987655569755664150, 0.987663400582686310, +0.987671228940549930, 0.987679054829235570, 0.987686878248723480, 0.987694699198994220, 0.987702517680028480, 0.987710333691806160, 0.987718147234308060, 0.987725958307514530, +0.987733766911406240, 0.987741573045963440, 0.987749376711166690, 0.987757177906996690, 0.987764976633433540, 0.987772772890458060, 0.987780566678050590, 0.987788357996191690, +0.987796146844861830, 0.987803933224041700, 0.987811717133711740, 0.987819498573852540, 0.987827277544444550, 0.987835054045468340, 0.987842828076904490, 0.987850599638733560, +0.987858368730936130, 0.987866135353492770, 0.987873899506384270, 0.987881661189590750, 0.987889420403093240, 0.987897177146872090, 0.987904931420908070, 0.987912683225181660, +0.987920432559673540, 0.987928179424364280, 0.987935923819234780, 0.987943665744265400, 0.987951405199436690, 0.987959142184729580, 0.987966876700124620, 0.987974608745602500, +0.987982338321143790, 0.987990065426729290, 0.987997790062339680, 0.988005512227955520, 0.988013231923557500, 0.988020949149126530, 0.988028663904643060, 0.988036376190087990, +0.988044086005442020, 0.988051793350685940, 0.988059498225800190, 0.988067200630765810, 0.988074900565563350, 0.988082598030173620, 0.988090293024577400, 0.988097985548755500, +0.988105675602688580, 0.988113363186357670, 0.988121048299743230, 0.988128730942826050, 0.988136411115587140, 0.988144088818007190, 0.988151764050066990, 0.988159436811747450, +0.988167107103029240, 0.988174774923893380, 0.988182440274320560, 0.988190103154291570, 0.988197763563787300, 0.988205421502788670, 0.988213076971276470, 0.988220729969231600, +0.988228380496634970, 0.988236028553467260, 0.988243674139709590, 0.988251317255342650, 0.988258957900347350, 0.988266596074704800, 0.988274231778395680, 0.988281865011401030, +0.988289495773701730, 0.988297124065278700, 0.988304749886112830, 0.988312373236185040, 0.988319994115476330, 0.988327612523967610, 0.988335228461639900, 0.988342841928474210, +0.988350452924451340, 0.988358061449552410, 0.988365667503758210, 0.988373271087049870, 0.988380872199408290, 0.988388470840814600, 0.988396067011249710, 0.988403660710694850, +0.988411251939130600, 0.988418840696538290, 0.988426426982898840, 0.988434010798193370, 0.988441592142402790, 0.988449171015508330, 0.988456747417490900, 0.988464321348331730, +0.988471892808011620, 0.988479461796511800, 0.988487028313813300, 0.988494592359897230, 0.988502153934744720, 0.988509713038336790, 0.988517269670654790, 0.988524823831679390, +0.988532375521391950, 0.988539924739773590, 0.988547471486805440, 0.988555015762468510, 0.988562557566744160, 0.988570096899613280, 0.988577633761057450, 0.988585168151057350, +0.988592700069594210, 0.988600229516649500, 0.988607756492204110, 0.988615280996239410, 0.988622803028736400, 0.988630322589676420, 0.988637839679040840, 0.988645354296810440, +0.988652866442966680, 0.988660376117490800, 0.988667883320363930, 0.988675388051567290, 0.988682890311082250, 0.988690390098890150, 0.988697887414971890, 0.988705382259309040, +0.988712874631882620, 0.988720364532673980, 0.988727851961664460, 0.988735336918835310, 0.988742819404167860, 0.988750299417643470, 0.988757776959243160, 0.988765252028948490, +0.988772724626740600, 0.988780194752601040, 0.988787662406510840, 0.988795127588451560, 0.988802590298404560, 0.988810050536350960, 0.988817508302272220, 0.988824963596149800, +0.988832416417964930, 0.988839866767698970, 0.988847314645333380, 0.988854760050849490, 0.988862202984228780, 0.988869643445452470, 0.988877081434502150, 0.988884516951359040, +0.988891949996004600, 0.988899380568420310, 0.988906808668587600, 0.988914234296487840, 0.988921657452102700, 0.988929078135413200, 0.988936496346401020, 0.988943912085047620, +0.988951325351334450, 0.988958736145242880, 0.988966144466754570, 0.988973550315850990, 0.988980953692513490, 0.988988354596723520, 0.988995753028462650, 0.989003148987712350, +0.989010542474454300, 0.989017933488669840, 0.989025322030340550, 0.989032708099448100, 0.989040091695973730, 0.989047472819899130, 0.989054851471205860, 0.989062227649875500, +0.989069601355889510, 0.989076972589229550, 0.989084341349877110, 0.989091707637813950, 0.989099071453021450, 0.989106432795481270, 0.989113791665174990, 0.989121148062084180, +0.989128501986190620, 0.989135853437475680, 0.989143202415921350, 0.989150548921508780, 0.989157892954219850, 0.989165234514036260, 0.989172573600939580, 0.989179910214911360, +0.989187244355933410, 0.989194576023987420, 0.989201905219055040, 0.989209231941117870, 0.989216556190157580, 0.989223877966155850, 0.989231197269094480, 0.989238514098955020, +0.989245828455719400, 0.989253140339369290, 0.989260449749886140, 0.989267756687251980, 0.989275061151448360, 0.989282363142456990, 0.989289662660259860, 0.989296959704838550, +0.989304254276174850, 0.989311546374250560, 0.989318835999047350, 0.989326123150547020, 0.989333407828731360, 0.989340690033582270, 0.989347969765081440, 0.989355247023210650, +0.989362521807951700, 0.989369794119286610, 0.989377063957196930, 0.989384331321664590, 0.989391596212671360, 0.989398858630199160, 0.989406118574229890, 0.989413376044745220, +0.989420631041727280, 0.989427883565157650, 0.989435133615018340, 0.989442381191291130, 0.989449626293958050, 0.989456868923000890, 0.989464109078401430, 0.989471346760141810, +0.989478581968203930, 0.989485814702569470, 0.989493044963220550, 0.989500272750138850, 0.989507498063306620, 0.989514720902705540, 0.989521941268317720, 0.989529159160125070, +0.989536374578109610, 0.989543587522253130, 0.989550797992537650, 0.989558005988945060, 0.989565211511457600, 0.989572414560057070, 0.989579615134725480, 0.989586813235445060, +0.989594008862197390, 0.989601202014964710, 0.989608392693729130, 0.989615580898472460, 0.989622766629176920, 0.989629949885824420, 0.989637130668396980, 0.989644308976876940, +0.989651484811245870, 0.989658658171486240, 0.989665829057579940, 0.989672997469508990, 0.989680163407255620, 0.989687326870801740, 0.989694487860129810, 0.989701646375221400, +0.989708802416058960, 0.989715955982624520, 0.989723107074900190, 0.989730255692867990, 0.989737401836510270, 0.989744545505809040, 0.989751686700746540, 0.989758825421304670, +0.989765961667465780, 0.989773095439211990, 0.989780226736525440, 0.989787355559388240, 0.989794481907782740, 0.989801605781691070, 0.989808727181095470, 0.989815846105977950, +0.989822962556320740, 0.989830076532106200, 0.989837188033316440, 0.989844297059933710, 0.989851403611940240, 0.989858507689318490, 0.989865609292050250, 0.989872708420117990, +0.989879805073503930, 0.989886899252190310, 0.989893990956159600, 0.989901080185393800, 0.989908166939875380, 0.989915251219586570, 0.989922333024509600, 0.989929412354626730, +0.989936489209920280, 0.989943563590372720, 0.989950635495966180, 0.989957704926683110, 0.989964771882505870, 0.989971836363416570, 0.989978898369397790, 0.989985957900431650, +0.989993014956500610, 0.990000069537587010, 0.990007121643673330, 0.990014171274741780, 0.990021218430774950, 0.990028263111754960, 0.990035305317664260, 0.990042345048485320, +0.990049382304200590, 0.990056417084792310, 0.990063449390243040, 0.990070479220535150, 0.990077506575651190, 0.990084531455573290, 0.990091553860284130, 0.990098573789766070, +0.990105591244001550, 0.990112606222973040, 0.990119618726662990, 0.990126628755054080, 0.990133636308128450, 0.990140641385868770, 0.990147643988257390, 0.990154644115276980, +0.990161641766909910, 0.990168636943138840, 0.990175629643946010, 0.990182619869314330, 0.990189607619226030, 0.990196592893663690, 0.990203575692609750, 0.990210556016047020, +0.990217533863957830, 0.990224509236324770, 0.990231482133130500, 0.990238452554357610, 0.990245420499988540, 0.990252385970005870, 0.990259348964392160, 0.990266309483130100, +0.990273267526202370, 0.990280223093591430, 0.990287176185280060, 0.990294126801250620, 0.990301074941485780, 0.990308020605968340, 0.990314963794680870, 0.990321904507605930, +0.990328842744726210, 0.990335778506024500, 0.990342711791483370, 0.990349642601085380, 0.990356570934813220, 0.990363496792649680, 0.990370420174577440, 0.990377341080579070, +0.990384259510637350, 0.990391175464735210, 0.990398088942854860, 0.990404999944979440, 0.990411908471091400, 0.990418814521173640, 0.990425718095208850, 0.990432619193179710, +0.990439517815069110, 0.990446413960859750, 0.990453307630534300, 0.990460198824075540, 0.990467087541466400, 0.990473973782689420, 0.990480857547727520, 0.990487738836563490, +0.990494617649180120, 0.990501493985560310, 0.990508367845686630, 0.990515239229542100, 0.990522108137109390, 0.990528974568371520, 0.990535838523311060, 0.990542700001911140, +0.990549559004154530, 0.990556415530023940, 0.990563269579502250, 0.990570121152572370, 0.990576970249217310, 0.990583816869419760, 0.990590661013162620, 0.990597502680428900, +0.990604341871201500, 0.990611178585463100, 0.990618012823196840, 0.990624844584385490, 0.990631673869011960, 0.990638500677059390, 0.990645325008510550, 0.990652146863348350, +0.990658966241555810, 0.990665783143115930, 0.990672597568011400, 0.990679409516225460, 0.990686218987741010, 0.990693025982541050, 0.990699830500608500, 0.990706632541926480, +0.990713432106477780, 0.990720229194245410, 0.990727023805212600, 0.990733815939362160, 0.990740605596677200, 0.990747392777140630, 0.990754177480735690, 0.990760959707445380, +0.990767739457252610, 0.990774516730140500, 0.990781291526091960, 0.990788063845090330, 0.990794833687118510, 0.990801601052159530, 0.990808365940196720, 0.990815128351212880, +0.990821888285191240, 0.990828645742114930, 0.990835400721966850, 0.990842153224730460, 0.990848903250388550, 0.990855650798924460, 0.990862395870321320, 0.990869138464562040, +0.990875878581629950, 0.990882616221508080, 0.990889351384179770, 0.990896084069628150, 0.990902814277836220, 0.990909542008787230, 0.990916267262464510, 0.990922990038851090, +0.990929710337930090, 0.990936428159684860, 0.990943143504098620, 0.990949856371154400, 0.990956566760835660, 0.990963274673125620, 0.990969980108007190, 0.990976683065463830, +0.990983383545478770, 0.990990081548035250, 0.990996777073116510, 0.991003470120705890, 0.991010160690786510, 0.991016848783341950, 0.991023534398355110, 0.991030217535809440, +0.991036898195688190, 0.991043576377974690, 0.991050252082652290, 0.991056925309704240, 0.991063596059113870, 0.991070264330864650, 0.991076930124939580, 0.991083593441322240, +0.991090254279995970, 0.991096912640944020, 0.991103568524149820, 0.991110221929596640, 0.991116872857268020, 0.991123521307147200, 0.991130167279217430, 0.991136810773462380, +0.991143451789865180, 0.991150090328409390, 0.991156726389078480, 0.991163359971855670, 0.991169991076724540, 0.991176619703668330, 0.991183245852670590, 0.991189869523714790, +0.991196490716784280, 0.991203109431862520, 0.991209725668933060, 0.991216339427979260, 0.991222950708984580, 0.991229559511932590, 0.991236165836806630, 0.991242769683590260, +0.991249371052266960, 0.991255969942820170, 0.991262566355233580, 0.991269160289490640, 0.991275751745574700, 0.991282340723469320, 0.991288927223158090, 0.991295511244624670, +0.991302092787852310, 0.991308671852824790, 0.991315248439525680, 0.991321822547938440, 0.991328394178046520, 0.991334963329833730, 0.991341530003283400, 0.991348094198379330, +0.991354655915104970, 0.991361215153444110, 0.991367771913380210, 0.991374326194896740, 0.991380877997977470, 0.991387427322606100, 0.991393974168766070, 0.991400518536441070, +0.991407060425614880, 0.991413599836270980, 0.991420136768393250, 0.991426671221964930, 0.991433203196970040, 0.991439732693392140, 0.991446259711214920, 0.991452784250422050, +0.991459306310997100, 0.991465825892924090, 0.991472342996186470, 0.991478857620767930, 0.991485369766652250, 0.991491879433823110, 0.991498386622264300, 0.991504891331959510, +0.991511393562892530, 0.991517893315047140, 0.991524390588407020, 0.991530885382955750, 0.991537377698677340, 0.991543867535555570, 0.991550354893574020, 0.991556839772716580, +0.991563322172967050, 0.991569802094309450, 0.991576279536727110, 0.991582754500204060, 0.991589226984724180, 0.991595696990271170, 0.991602164516829030, 0.991608629564381450, +0.991615092132912320, 0.991621552222405440, 0.991628009832844600, 0.991634464964213810, 0.991640917616496750, 0.991647367789677550, 0.991653815483739760, 0.991660260698667530, +0.991666703434444850, 0.991673143691055190, 0.991679581468482670, 0.991686016766711200, 0.991692449585724670, 0.991698879925507090, 0.991705307786042270, 0.991711733167314200, +0.991718156069306910, 0.991724576492004070, 0.991730994435389810, 0.991737409899448030, 0.991743822884162740, 0.991750233389517950, 0.991756641415497580, 0.991763046962085730, +0.991769450029266090, 0.991775850617022780, 0.991782248725339930, 0.991788644354201440, 0.991795037503591330, 0.991801428173493590, 0.991807816363892370, 0.991814202074771670, +0.991820585306115390, 0.991826966057907540, 0.991833344330132370, 0.991839720122773880, 0.991846093435815980, 0.991852464269242890, 0.991858832623038760, 0.991865198497187460, +0.991871561891673140, 0.991877922806479910, 0.991884281241591890, 0.991890637196993110, 0.991896990672667790, 0.991903341668600060, 0.991909690184773930, 0.991916036221173640, +0.991922379777783080, 0.991928720854586720, 0.991935059451568460, 0.991941395568712640, 0.991947729206003270, 0.991954060363424590, 0.991960389040960840, 0.991966715238596030, +0.991973038956314500, 0.991979360194100270, 0.991985678951937680, 0.991991995229810850, 0.991998309027704140, 0.992004620345601660, 0.992010929183487540, 0.992017235541346130, +0.992023539419161660, 0.992029840816918360, 0.992036139734600360, 0.992042436172192010, 0.992048730129677650, 0.992055021607041620, 0.992061310604267830, 0.992067597121340740, +0.992073881158244690, 0.992080162714964020, 0.992086441791482860, 0.992092718387785570, 0.992098992503856470, 0.992105264139680140, 0.992111533295240380, 0.992117799970521850, +0.992124064165508910, 0.992130325880185680, 0.992136585114536730, 0.992142841868546290, 0.992149096142198820, 0.992155347935478440, 0.992161597248369830, 0.992167844080857120, +0.992174088432924870, 0.992180330304557430, 0.992186569695739040, 0.992192806606454370, 0.992199041036687660, 0.992205272986423360, 0.992211502455645820, 0.992217729444339500, +0.992223953952488860, 0.992230175980078340, 0.992236395527092420, 0.992242612593515540, 0.992248827179332160, 0.992255039284526630, 0.992261248909083520, 0.992267456052987160, +0.992273660716222360, 0.992279862898773240, 0.992286062600624570, 0.992292259821760840, 0.992298454562166370, 0.992304646821825730, 0.992310836600723390, 0.992317023898844130, +0.992323208716172190, 0.992329391052692240, 0.992335570908388860, 0.992341748283246620, 0.992347923177249960, 0.992354095590383460, 0.992360265522631680, 0.992366432973979310, +0.992372597944410790, 0.992378760433910820, 0.992384920442463960, 0.992391077970054770, 0.992397233016667930, 0.992403385582288020, 0.992409535666899600, 0.992415683270487240, +0.992421828393035830, 0.992427971034529730, 0.992434111194953950, 0.992440248874292610, 0.992446384072530830, 0.992452516789652960, 0.992458647025643790, 0.992464774780488110, +0.992470900054170380, 0.992477022846675490, 0.992483143157988130, 0.992489260988092760, 0.992495376336974270, 0.992501489204617340, 0.992507599591006760, 0.992513707496127110, +0.992519812919963160, 0.992525915862499830, 0.992532016323721570, 0.992538114303613270, 0.992544209802159740, 0.992550302819345640, 0.992556393355155770, 0.992562481409574930, +0.992568566982587890, 0.992574650074179550, 0.992580730684334500, 0.992586808813037620, 0.992592884460273720, 0.992598957626027570, 0.992605028310283970, 0.992611096513027920, +0.992617162234244230, 0.992623225473917460, 0.992629286232032610, 0.992635344508574600, 0.992641400303528210, 0.992647453616878340, 0.992653504448609780, 0.992659552798707550, +0.992665598667156530, 0.992671642053941320, 0.992677682959047130, 0.992683721382458640, 0.992689757324160870, 0.992695790784138720, 0.992701821762377090, 0.992707850258860880, +0.992713876273575210, 0.992719899806504660, 0.992725920857634450, 0.992731939426949370, 0.992737955514434440, 0.992743969120074680, 0.992749980243854970, 0.992755988885760330, +0.992761995045775780, 0.992767998723886100, 0.992773999920076530, 0.992779998634331860, 0.992785994866637210, 0.992791988616977710, 0.992797979885338130, 0.992803968671703620, +0.992809954976059170, 0.992815938798389920, 0.992821920138680760, 0.992827898996916700, 0.992833875373082990, 0.992839849267164620, 0.992845820679146620, 0.992851789609014100, +0.992857756056751970, 0.992863720022345570, 0.992869681505779810, 0.992875640507039910, 0.992881597026110780, 0.992887551062977770, 0.992893502617625990, 0.992899451690040240, +0.992905398280205960, 0.992911342388108190, 0.992917284013732030, 0.992923223157062610, 0.992929159818085270, 0.992935093996784920, 0.992941025693146910, 0.992946954907156340, +0.992952881638798360, 0.992958805888058070, 0.992964727654920940, 0.992970646939371870, 0.992976563741396200, 0.992982478060979170, 0.992988389898106010, 0.992994299252761730, +0.993000206124931780, 0.993006110514601190, 0.993012012421755410, 0.993017911846379660, 0.993023808788459080, 0.993029703247979010, 0.993035595224924680, 0.993041484719281330, +0.993047371731034300, 0.993053256260168830, 0.993059138306670140, 0.993065017870523700, 0.993070894951714630, 0.993076769550228500, 0.993082641666050310, 0.993088511299165530, +0.993094378449559500, 0.993100243117217450, 0.993106105302124840, 0.993111965004266910, 0.993117822223629210, 0.993123676960196880, 0.993129529213955360, 0.993135378984890020, +0.993141226272986180, 0.993147071078229300, 0.993152913400604740, 0.993158753240097950, 0.993164590596694370, 0.993170425470379150, 0.993176257861137830, 0.993182087768956000, +0.993187915193818880, 0.993193740135711930, 0.993199562594620720, 0.993205382570530590, 0.993211200063427000, 0.993217015073295410, 0.993222827600121260, 0.993228637643890020, +0.993234445204587260, 0.993240250282198310, 0.993246052876708750, 0.993251852988104140, 0.993257650616369840, 0.993263445761491390, 0.993269238423454380, 0.993275028602244150, +0.993280816297846480, 0.993286601510246720, 0.993292384239430450, 0.993298164485383330, 0.993303942248090710, 0.993309717527538160, 0.993315490323711360, 0.993321260636595870, +0.993327028466177260, 0.993332793812441000, 0.993338556675372850, 0.993344317054958290, 0.993350074951182880, 0.993355830364032300, 0.993361583293492110, 0.993367333739548000, +0.993373081702185520, 0.993378827181390370, 0.993384570177148210, 0.993390310689444610, 0.993396048718265150, 0.993401784263595600, 0.993407517325421650, 0.993413247903728760, +0.993418975998502930, 0.993424701609729510, 0.993430424737394510, 0.993436145381483390, 0.993441863541981830, 0.993447579218875610, 0.993453292412150410, 0.993459003121792140, +0.993464711347786240, 0.993470417090118630, 0.993476120348774970, 0.993481821123740950, 0.993487519415002350, 0.993493215222545080, 0.993498908546354700, 0.993504599386417000, +0.993510287742717880, 0.993515973615243020, 0.993521657003978210, 0.993527337908909350, 0.993533016330022000, 0.993538692267302180, 0.993544365720735570, 0.993550036690308170, +0.993555705176005550, 0.993561371177813850, 0.993567034695718500, 0.993572695729705750, 0.993578354279761160, 0.993584010345870630, 0.993589663928020170, 0.993595315026195470, +0.993600963640382640, 0.993606609770567250, 0.993612253416735420, 0.993617894578872950, 0.993623533256965620, 0.993629169450999550, 0.993634803160960530, 0.993640434386834580, +0.993646063128607590, 0.993651689386265360, 0.993657313159793890, 0.993662934449179080, 0.993668553254406950, 0.993674169575463510, 0.993679783412334650, 0.993685394765006390, +0.993691003633464520, 0.993696610017695160, 0.993702213917684320, 0.993707815333417900, 0.993713414264881910, 0.993719010712062480, 0.993724604674945500, 0.993730196153516990, +0.993735785147763060, 0.993741371657669510, 0.993746955683222690, 0.993752537224408370, 0.993758116281212690, 0.993763692853621760, 0.993769266941621600, 0.993774838545198440, +0.993780407664338060, 0.993785974299026600, 0.993791538449250170, 0.993797100114995000, 0.993802659296247000, 0.993808215992992410, 0.993813770205217330, 0.993819321932907780, +0.993824871176049900, 0.993830417934629780, 0.993835962208633680, 0.993841503998047720, 0.993847043302858000, 0.993852580123050560, 0.993858114458611830, 0.993863646309527730, +0.993869175675784480, 0.993874702557368320, 0.993880226954265370, 0.993885748866461970, 0.993891268293944030, 0.993896785236698110, 0.993902299694710110, 0.993907811667966380, +0.993913321156453140, 0.993918828160156530, 0.993924332679062880, 0.993929834713158430, 0.993935334262429420, 0.993940831326862060, 0.993946325906442610, 0.993951818001157280, +0.993957307610992550, 0.993962794735934410, 0.993968279375969320, 0.993973761531083520, 0.993979241201263350, 0.993984718386495160, 0.993990193086765060, 0.993995665302059520, +0.994001135032364760, 0.994006602277667240, 0.994012067037953080, 0.994017529313208860, 0.994022989103420910, 0.994028446408575350, 0.994033901228658760, 0.994039353563657360, +0.994044803413557500, 0.994050250778345750, 0.994055695658008330, 0.994061138052531710, 0.994066577961902230, 0.994072015386106340, 0.994077450325130290, 0.994082882778960730, +0.994088312747583910, 0.994093740230986290, 0.994099165229154310, 0.994104587742074440, 0.994110007769733240, 0.994115425312116940, 0.994120840369212000, 0.994126252941004980, +0.994131663027482350, 0.994137070628630550, 0.994142475744436040, 0.994147878374885500, 0.994153278519965160, 0.994158676179661580, 0.994164071353961340, 0.994169464042850890, +0.994174854246316800, 0.994180241964345620, 0.994185627196923720, 0.994191009944037970, 0.994196390205674520, 0.994201767981820140, 0.994207143272461290, 0.994212516077584650, +0.994217886397176680, 0.994223254231224040, 0.994228619579713310, 0.994233982442630950, 0.994239342819963620, 0.994244700711698020, 0.994250056117820580, 0.994255409038317990, +0.994260759473176940, 0.994266107422383970, 0.994271452885925780, 0.994276795863788920, 0.994282136355960080, 0.994287474362425820, 0.994292809883172920, 0.994298142918188080, +0.994303473467457730, 0.994308801530968790, 0.994314127108707920, 0.994319450200661590, 0.994324770806816690, 0.994330088927159910, 0.994335404561677900, 0.994340717710357260, +0.994346028373184980, 0.994351336550147620, 0.994356642241231770, 0.994361945446424420, 0.994367246165712260, 0.994372544399081850, 0.994377840146520200, 0.994383133408013880, +0.994388424183549670, 0.994393712473114590, 0.994398998276695090, 0.994404281594278070, 0.994409562425850440, 0.994414840771398860, 0.994420116630910120, 0.994425390004371130, +0.994430660891768680, 0.994435929293089660, 0.994441195208320750, 0.994446458637448850, 0.994451719580460750, 0.994456978037343450, 0.994462234008083650, 0.994467487492668220, +0.994472738491084200, 0.994477987003318240, 0.994483233029357370, 0.994488476569188260, 0.994493717622798150, 0.994498956190173590, 0.994504192271301710, 0.994509425866169420, +0.994514656974763600, 0.994519885597070940, 0.994525111733078670, 0.994530335382773690, 0.994535556546142780, 0.994540775223172970, 0.994545991413851250, 0.994551205118164640, +0.994556416336099920, 0.994561625067644120, 0.994566831312784340, 0.994572035071507490, 0.994577236343800460, 0.994582435129650390, 0.994587631429044270, 0.994592825241969130, +0.994598016568411850, 0.994603205408359450, 0.994608391761799050, 0.994613575628717770, 0.994618757009102520, 0.994623935902940290, 0.994629112310218330, 0.994634286230923650, +0.994639457665043140, 0.994644626612564030, 0.994649793073473230, 0.994654957047758080, 0.994660118535405480, 0.994665277536402660, 0.994670434050736630, 0.994675588078394510, +0.994680739619363320, 0.994685888673630390, 0.994691035241182740, 0.994696179322007380, 0.994701320916091650, 0.994706460023422670, 0.994711596643987560, 0.994716730777773340, +0.994721862424767340, 0.994726991584956700, 0.994732118258328630, 0.994737242444870160, 0.994742364144568620, 0.994747483357411140, 0.994752600083385170, 0.994757714322477500, +0.994762826074675590, 0.994767935339966550, 0.994773042118337720, 0.994778146409776240, 0.994783248214269440, 0.994788347531804560, 0.994793444362368830, 0.994798538705949360, +0.994803630562533630, 0.994808719932108840, 0.994813806814662250, 0.994818891210181080, 0.994823973118652670, 0.994829052540064480, 0.994834129474403530, 0.994839203921657260, +0.994844275881813010, 0.994849345354858030, 0.994854412340779760, 0.994859476839565330, 0.994864538851202410, 0.994869598375678010, 0.994874655412979590, 0.994879709963094610, +0.994884762026010280, 0.994889811601714080, 0.994894858690193340, 0.994899903291435520, 0.994904945405427950, 0.994909985032158000, 0.994915022171612980, 0.994920056823780490, +0.994925088988647840, 0.994930118666202400, 0.994935145856431720, 0.994940170559323270, 0.994945192774864370, 0.994950212503042390, 0.994955229743844980, 0.994960244497259390, +0.994965256763273190, 0.994970266541873930, 0.994975273833048960, 0.994980278636785840, 0.994985280953072040, 0.994990280781895000, 0.994995278123242290, 0.995000272977101250, +0.995005265343459680, 0.995010255222304910, 0.995015242613624510, 0.995020227517406040, 0.995025209933636860, 0.995030189862304740, 0.995035167303397140, 0.995040142256901630, +0.995045114722805770, 0.995050084701097130, 0.995055052191763270, 0.995060017194791870, 0.995064979710170270, 0.995069939737886270, 0.995074897277927420, 0.995079852330281400, +0.995084804894935670, 0.995089754971877900, 0.995094702561095890, 0.995099647662577080, 0.995104590276309040, 0.995109530402279560, 0.995114468040476320, 0.995119403190886880, +0.995124335853498910, 0.995129266028300100, 0.995134193715278230, 0.995139118914420750, 0.995144041625715460, 0.995148961849150140, 0.995153879584712350, 0.995158794832389890, +0.995163707592170430, 0.995168617864041870, 0.995173525647991550, 0.995178430944007490, 0.995183333752077350, 0.995188234072188930, 0.995193131904329900, 0.995198027248487940, +0.995202920104650950, 0.995207810472806820, 0.995212698352943010, 0.995217583745047540, 0.995222466649107960, 0.995227347065112400, 0.995232224993048310, 0.995237100432903700, +0.995241973384666360, 0.995246843848324180, 0.995251711823864850, 0.995256577311276150, 0.995261440310546090, 0.995266300821662340, 0.995271158844612920, 0.995276014379385620, +0.995280867425968330, 0.995285717984348730, 0.995290566054514940, 0.995295411636454630, 0.995300254730155820, 0.995305095335606400, 0.995309933452794280, 0.995314769081707240, +0.995319602222333400, 0.995324432874660550, 0.995329261038676470, 0.995334086714369290, 0.995338909901727020, 0.995343730600737330, 0.995348548811388350, 0.995353364533668070, +0.995358177767564300, 0.995362988513065150, 0.995367796770158410, 0.995372602538832310, 0.995377405819074630, 0.995382206610873400, 0.995387004914216720, 0.995391800729092610, +0.995396594055488970, 0.995401384893393690, 0.995406173242795010, 0.995410959103680940, 0.995415742476039480, 0.995420523359858640, 0.995425301755126450, 0.995430077661831230, +0.995434851079960550, 0.995439622009502870, 0.995444390450446080, 0.995449156402778310, 0.995453919866487680, 0.995458680841562190, 0.995463439327990200, 0.995468195325759360, +0.995472948834858150, 0.995477699855274570, 0.995482448386996730, 0.995487194430012770, 0.995491937984310790, 0.995496679049879040, 0.995501417626705520, 0.995506153714778570, +0.995510887314086100, 0.995515618424616440, 0.995520347046357720, 0.995525073179298170, 0.995529796823426020, 0.995534517978729270, 0.995539236645196280, 0.995543952822815160, +0.995548666511574140, 0.995553377711461460, 0.995558086422465350, 0.995562792644574030, 0.995567496377775750, 0.995572197622058840, 0.995576896377411310, 0.995581592643821510, +0.995586286421277780, 0.995590977709768230, 0.995595666509281330, 0.995600352819805190, 0.995605036641328270, 0.995609717973838790, 0.995614396817325000, 0.995619073171775120, +0.995623747037177600, 0.995628418413520680, 0.995633087300792700, 0.995637753698982110, 0.995642417608077150, 0.995647079028066040, 0.995651737958937240, 0.995656394400679100, +0.995661048353280060, 0.995665699816728260, 0.995670348791012350, 0.995674995276120470, 0.995679639272041170, 0.995684280778762810, 0.995688919796273610, 0.995693556324562130, +0.995698190363616840, 0.995702821913426070, 0.995707450973978170, 0.995712077545261700, 0.995716701627265110, 0.995721323219976640, 0.995725942323384960, 0.995730558937478310, +0.995735173062245350, 0.995739784697674430, 0.995744393843754020, 0.995749000500472770, 0.995753604667818930, 0.995758206345781050, 0.995762805534347590, 0.995767402233507240, +0.995771996443248320, 0.995776588163559410, 0.995781177394429060, 0.995785764135845740, 0.995790348387798010, 0.995794930150274430, 0.995799509423263560, 0.995804086206753870, +0.995808660500733910, 0.995813232305192360, 0.995817801620117680, 0.995822368445498650, 0.995826932781323610, 0.995831494627581250, 0.995836053984260120, 0.995840610851348780, +0.995845165228836040, 0.995849717116710330, 0.995854266514960340, 0.995858813423574740, 0.995863357842541990, 0.995867899771850970, 0.995872439211490050, 0.995876976161448100, +0.995881510621713820, 0.995886042592275640, 0.995890572073122480, 0.995895099064242780, 0.995899623565625340, 0.995904145577258810, 0.995908665099132010, 0.995913182131233480, +0.995917696673551900, 0.995922208726076290, 0.995926718288795090, 0.995931225361697090, 0.995935729944770980, 0.995940232038005520, 0.995944731641389520, 0.995949228754911650, +0.995953723378560810, 0.995958215512325660, 0.995962705156194890, 0.995967192310157400, 0.995971676974201970, 0.995976159148317270, 0.995980638832492220, 0.995985116026715470, +0.995989590730976040, 0.995994062945262710, 0.995998532669564060, 0.996002999903869090, 0.996007464648166700, 0.996011926902445670, 0.996016386666694680, 0.996020843940902840, +0.996025298725058960, 0.996029751019151700, 0.996034200823170070, 0.996038648137102970, 0.996043092960939290, 0.996047535294667830, 0.996051975138277480, 0.996056412491757250, +0.996060847355096150, 0.996065279728282740, 0.996069709611306140, 0.996074137004155260, 0.996078561906819090, 0.996082984319286550, 0.996087404241546400, 0.996091821673587900, +0.996096236615399810, 0.996100649066971160, 0.996105059028290720, 0.996109466499347730, 0.996113871480131090, 0.996118273970629800, 0.996122673970832760, 0.996127071480729210, +0.996131466500307820, 0.996135859029557810, 0.996140249068468100, 0.996144636617027790, 0.996149021675225900, 0.996153404243051430, 0.996157784320493400, 0.996162161907541140, +0.996166537004183230, 0.996170909610409110, 0.996175279726207670, 0.996179647351568050, 0.996184012486479250, 0.996188375130930500, 0.996192735284910810, 0.996197092948409190, +0.996201448121414980, 0.996205800803916960, 0.996210150995904600, 0.996214498697366780, 0.996218843908292740, 0.996223186628671600, 0.996227526858492580, 0.996231864597744600, +0.996236199846416980, 0.996240532604498960, 0.996244862871979550, 0.996249190648847870, 0.996253515935093370, 0.996257838730705060, 0.996262159035672170, 0.996266476849983820, +0.996270792173629240, 0.996275105006597770, 0.996279415348878540, 0.996283723200460660, 0.996288028561333580, 0.996292331431486430, 0.996296631810908440, 0.996300929699588830, +0.996305225097516840, 0.996309518004681930, 0.996313808421073090, 0.996318096346679780, 0.996322381781491240, 0.996326664725496910, 0.996330945178685700, 0.996335223141047170, +0.996339498612570650, 0.996343771593245280, 0.996348042083060600, 0.996352310082005750, 0.996356575590070070, 0.996360838607243120, 0.996365099133513900, 0.996369357168871980, +0.996373612713306710, 0.996377865766807420, 0.996382116329363350, 0.996386364400964060, 0.996390609981599010, 0.996394853071257190, 0.996399093669928400, 0.996403331777601760, +0.996407567394266840, 0.996411800519913070, 0.996416031154529700, 0.996420259298106290, 0.996424484950632290, 0.996428708112097050, 0.996432928782490010, 0.996437146961800630, +0.996441362650018370, 0.996445575847132780, 0.996449786553133210, 0.996453994768009220, 0.996458200491750160, 0.996462403724345690, 0.996466604465785170, 0.996470802716058040, +0.996474998475153970, 0.996479191743062430, 0.996483382519772980, 0.996487570805275060, 0.996491756599558130, 0.996495939902611760, 0.996500120714425620, 0.996504299034989160, +0.996508474864291950, 0.996512648202323660, 0.996516819049073630, 0.996520987404531660, 0.996525153268687070, 0.996529316641529660, 0.996533477523048990, 0.996537635913234630, +0.996541791812076140, 0.996545945219563190, 0.996550096135685460, 0.996554244560432400, 0.996558390493793690, 0.996562533935759000, 0.996566674886318120, 0.996570813345460380, +0.996574949313175700, 0.996579082789453620, 0.996583213774283940, 0.996587342267656110, 0.996591468269559910, 0.996595591779985130, 0.996599712798921230, 0.996603831326358210, +0.996607947362285530, 0.996612060906693080, 0.996616171959570310, 0.996620280520907230, 0.996624386590693410, 0.996628490168918630, 0.996632591255572580, 0.996636689850645130, +0.996640785954125860, 0.996644879566004780, 0.996648970686271340, 0.996653059314915550, 0.996657145451927070, 0.996661229097295820, 0.996665310251011350, 0.996669388913063670, +0.996673465083442570, 0.996677538762137830, 0.996681609949139240, 0.996685678644436580, 0.996689744848019640, 0.996693808559878440, 0.996697869780002740, 0.996701928508382240, +0.996705984745007050, 0.996710038489866830, 0.996714089742951610, 0.996718138504251060, 0.996722184773755180, 0.996726228551453870, 0.996730269837336920, 0.996734308631394340, +0.996738344933616130, 0.996742378743991850, 0.996746410062511750, 0.996750438889165590, 0.996754465223943290, 0.996758489066834840, 0.996762510417830150, 0.996766529276919220, +0.996770545644092070, 0.996774559519338470, 0.996778570902648430, 0.996782579794011970, 0.996786586193419090, 0.996790590100859690, 0.996794591516323880, 0.996798590439801570, +0.996802586871282760, 0.996806580810757570, 0.996810572258215900, 0.996814561213647750, 0.996818547677043140, 0.996822531648392300, 0.996826513127685000, 0.996830492114911590, +0.996834468610061750, 0.996838442613125930, 0.996842414124093800, 0.996846383142955820, 0.996850349669701760, 0.996854313704321870, 0.996858275246806260, 0.996862234297144930, +0.996866190855327900, 0.996870144921345510, 0.996874096495187770, 0.996878045576844670, 0.996881992166306570, 0.996885936263563480, 0.996889877868605500, 0.996893816981422880, +0.996897753602005720, 0.996901687730344150, 0.996905619366428300, 0.996909548510248490, 0.996913475161794740, 0.996917399321057270, 0.996921320988026440, 0.996925240162692240, +0.996929156845045020, 0.996933071035074780, 0.996936982732771870, 0.996940891938126520, 0.996944798651128950, 0.996948702871769510, 0.996952604600038210, 0.996956503835925380, +0.996960400579421260, 0.996964294830516180, 0.996968186589200390, 0.996972075855464100, 0.996975962629297660, 0.996979846910691300, 0.996983728699635250, 0.996987607996119960, +0.996991484800135660, 0.996995359111672590, 0.996999230930721180, 0.997003100257271570, 0.997006967091314310, 0.997010831432839750, 0.997014693281837890, 0.997018552638299420, +0.997022409502214550, 0.997026263873573630, 0.997030115752367110, 0.997033965138585220, 0.997037812032218530, 0.997041656433257260, 0.997045498341691760, 0.997049337757512590, +0.997053174680710090, 0.997057009111274590, 0.997060841049196570, 0.997064670494466570, 0.997068497447074820, 0.997072321907011780, 0.997076143874268020, 0.997079963348833860, +0.997083780330699780, 0.997087594819856200, 0.997091406816293710, 0.997095216320002750, 0.997099023330973670, 0.997102827849197020, 0.997106629874663360, 0.997110429407363050, +0.997114226447286760, 0.997118020994424810, 0.997121813048767790, 0.997125602610306360, 0.997129389679030860, 0.997133174254931980, 0.997136956338000040, 0.997140735928225720, +0.997144513025599590, 0.997148287630112210, 0.997152059741754030, 0.997155829360515830, 0.997159596486387970, 0.997163361119361100, 0.997167123259425800, 0.997170882906572740, +0.997174640060792480, 0.997178394722075590, 0.997182146890412850, 0.997185896565794590, 0.997189643748211620, 0.997193388437654590, 0.997197130634113970, 0.997200870337580650, +0.997204607548045070, 0.997208342265498040, 0.997212074489930210, 0.997215804221332050, 0.997219531459694440, 0.997223256205008070, 0.997226978457263490, 0.997230698216451380, +0.997234415482562640, 0.997238130255587830, 0.997241842535517730, 0.997245552322343020, 0.997249259616054370, 0.997252964416642680, 0.997256666724098410, 0.997260366538412660, +0.997264063859575890, 0.997267758687579000, 0.997271451022412660, 0.997275140864067770, 0.997278828212534880, 0.997282513067805020, 0.997286195429868960, 0.997289875298717270, +0.997293552674340940, 0.997297227556730780, 0.997300899945877560, 0.997304569841771960, 0.997308237244405090, 0.997311902153767530, 0.997315564569850270, 0.997319224492643990, +0.997322881922139800, 0.997326536858328390, 0.997330189301200540, 0.997333839250747260, 0.997337486706959320, 0.997341131669827740, 0.997344774139343300, 0.997348414115497020, +0.997352051598279670, 0.997355686587682140, 0.997359319083695350, 0.997362949086310290, 0.997366576595517970, 0.997370201611309070, 0.997373824133674700, 0.997377444162605760, +0.997381061698093370, 0.997384676740128210, 0.997388289288701270, 0.997391899343803680, 0.997395506905426330, 0.997399111973560240, 0.997402714548196400, 0.997406314629325720, +0.997409912216939310, 0.997413507311028070, 0.997417099911583000, 0.997420690018595240, 0.997424277632055770, 0.997427862751955610, 0.997431445378285760, 0.997435025511037470, +0.997438603150201390, 0.997442178295768870, 0.997445750947730910, 0.997449321106078650, 0.997452888770802960, 0.997456453941895080, 0.997460016619346130, 0.997463576803147120, +0.997467134493289160, 0.997470689689763380, 0.997474242392560770, 0.997477792601672690, 0.997481340317090020, 0.997484885538804100, 0.997488428266805950, 0.997491968501086680, +0.997495506241637520, 0.997499041488449590, 0.997502574241514010, 0.997506104500822000, 0.997509632266364800, 0.997513157538133520, 0.997516680316119290, 0.997520200600313430, +0.997523718390706970, 0.997527233687291350, 0.997530746490057460, 0.997534256798996880, 0.997537764614100490, 0.997541269935359850, 0.997544772762765990, 0.997548273096310220, +0.997551770935983680, 0.997555266281777710, 0.997558759133683640, 0.997562249491692700, 0.997565737355796010, 0.997569222725985140, 0.997572705602251200, 0.997576185984585420, +0.997579663872979140, 0.997583139267423700, 0.997586612167910450, 0.997590082574430710, 0.997593550486975730, 0.997597015905536950, 0.997600478830105500, 0.997603939260672920, +0.997607397197230460, 0.997610852639769560, 0.997614305588281460, 0.997617756042757710, 0.997621204003189540, 0.997624649469568300, 0.997628092441885440, 0.997631532920132290, +0.997634970904300420, 0.997638406394381060, 0.997641839390365770, 0.997645269892245780, 0.997648697900012760, 0.997652123413657830, 0.997655546433172670, 0.997658966958548610, +0.997662384989777110, 0.997665800526849720, 0.997669213569757800, 0.997672624118492890, 0.997676032173046350, 0.997679437733409720, 0.997682840799574590, 0.997686241371532280, +0.997689639449274360, 0.997693035032792390, 0.997696428122077820, 0.997699818717122210, 0.997703206817917020, 0.997706592424453810, 0.997709975536724140, 0.997713356154719460, +0.997716734278431440, 0.997720109907851650, 0.997723483042971430, 0.997726853683782670, 0.997730221830276710, 0.997733587482445230, 0.997736950640279670, 0.997740311303771830, +0.997743669472913150, 0.997747025147695310, 0.997750378328109980, 0.997753729014148720, 0.997757077205803090, 0.997760422903064660, 0.997763766105925320, 0.997767106814376530, +0.997770445028409950, 0.997773780748017150, 0.997777113973190130, 0.997780444703920130, 0.997783772940199150, 0.997787098682018650, 0.997790421929370400, 0.997793742682246190, +0.997797060940637580, 0.997800376704536250, 0.997803689973934090, 0.997807000748822670, 0.997810309029193650, 0.997813614815038940, 0.997816918106350200, 0.997820218903119120, +0.997823517205337570, 0.997826813012997250, 0.997830106326089820, 0.997833397144607170, 0.997836685468540980, 0.997839971297883040, 0.997843254632625240, 0.997846535472759260, +0.997849813818276980, 0.997853089669170190, 0.997856363025430680, 0.997859633887050120, 0.997862902254020630, 0.997866168126333890, 0.997869431503981660, 0.997872692386955860, +0.997875950775248380, 0.997879206668850880, 0.997882460067755490, 0.997885710971953890, 0.997888959381438070, 0.997892205296199820, 0.997895448716231040, 0.997898689641523730, +0.997901928072069680, 0.997905164007860780, 0.997908397448888930, 0.997911628395146130, 0.997914856846624180, 0.997918082803315180, 0.997921306265210920, 0.997924527232303400, +0.997927745704584650, 0.997930961682046420, 0.997934175164680860, 0.997937386152479840, 0.997940594645435270, 0.997943800643539380, 0.997947004146783830, 0.997950205155160860, +0.997953403668662360, 0.997956599687280340, 0.997959793211006920, 0.997962984239833870, 0.997966172773753430, 0.997969358812757500, 0.997972542356838300, 0.997975723405987610, +0.997978901960197670, 0.997982078019460480, 0.997985251583768160, 0.997988422653112610, 0.997991591227486040, 0.997994757306880480, 0.997997920891288030, 0.998001081980700810, +0.998004240575110830, 0.998007396674510330, 0.998010550278891300, 0.998013701388245860, 0.998016850002566120, 0.998019996121844330, 0.998023139746072600, 0.998026280875242920, +0.998029419509347650, 0.998032555648378780, 0.998035689292328440, 0.998038820441188970, 0.998041949094952360, 0.998045075253610970, 0.998048198917156900, 0.998051320085582280, +0.998054438758879450, 0.998057554937040400, 0.998060668620057490, 0.998063779807922940, 0.998066888500628970, 0.998069994698167710, 0.998073098400531490, 0.998076199607712540, +0.998079298319703100, 0.998082394536495390, 0.998085488258081740, 0.998088579484454290, 0.998091668215605470, 0.998094754451527510, 0.998097838192212540, 0.998100919437653000, +0.998103998187841230, 0.998107074442769360, 0.998110148202429940, 0.998113219466815080, 0.998116288235917140, 0.998119354509728550, 0.998122418288241550, 0.998125479571448480, +0.998128538359341790, 0.998131594651913590, 0.998134648449156560, 0.998137699751062810, 0.998140748557624910, 0.998143794868835090, 0.998146838684685790, 0.998149880005169350, +0.998152918830278240, 0.998155955160004880, 0.998158988994341520, 0.998162020333280830, 0.998165049176815030, 0.998168075524936580, 0.998171099377637930, 0.998174120734911520, +0.998177139596749920, 0.998180155963145350, 0.998183169834090500, 0.998186181209577580, 0.998189190089599390, 0.998192196474148140, 0.998195200363216300, 0.998198201756796630, +0.998201200654881270, 0.998204197057463110, 0.998207190964534250, 0.998210182376087610, 0.998213171292115400, 0.998216157712610300, 0.998219141637564760, 0.998222123066971450, +0.998225102000822820, 0.998228078439111320, 0.998231052381829740, 0.998234023828970530, 0.998236992780526240, 0.998239959236489450, 0.998242923196852710, 0.998245884661608680, +0.998248843630750060, 0.998251800104269170, 0.998254754082158910, 0.998257705564411730, 0.998260654551020310, 0.998263601041977200, 0.998266545037275080, 0.998269486536906610, +0.998272425540864480, 0.998275362049141250, 0.998278296061729580, 0.998281227578622250, 0.998284156599811730, 0.998287083125290910, 0.998290007155052340, 0.998292928689088810, +0.998295847727392880, 0.998298764269957340, 0.998301678316774970, 0.998304589867838430, 0.998307498923140300, 0.998310405482673470, 0.998313309546430610, 0.998316211114404490, +0.998319110186587810, 0.998322006762973450, 0.998324900843554080, 0.998327792428322370, 0.998330681517271110, 0.998333568110393310, 0.998336452207681520, 0.998339333809128540, +0.998342212914727250, 0.998345089524470540, 0.998347963638350990, 0.998350835256361590, 0.998353704378495130, 0.998356571004744290, 0.998359435135102060, 0.998362296769561340, +0.998365155908114810, 0.998368012550755470, 0.998370866697475990, 0.998373718348269380, 0.998376567503128420, 0.998379414162046120, 0.998382258325015260, 0.998385099992028740, +0.998387939163079550, 0.998390775838160380, 0.998393610017264340, 0.998396441700384330, 0.998399270887513120, 0.998402097578643840, 0.998404921773769160, 0.998407743472882300, +0.998410562675976050, 0.998413379383043420, 0.998416193594077290, 0.998419005309070680, 0.998421814528016590, 0.998424621250908030, 0.998427425477737770, 0.998430227208499050, +0.998433026443184770, 0.998435823181787920, 0.998438617424301400, 0.998441409170718440, 0.998444198421031940, 0.998446985175234890, 0.998449769433320420, 0.998452551195281530, +0.998455330461111350, 0.998458107230802750, 0.998460881504348860, 0.998463653281742800, 0.998466422562977570, 0.998469189348046290, 0.998471953636942080, 0.998474715429658040, +0.998477474726187090, 0.998480231526522540, 0.998482985830657420, 0.998485737638584720, 0.998488486950297790, 0.998491233765789630, 0.998493978085053360, 0.998496719908082090, +0.998499459234869160, 0.998502196065407470, 0.998504930399690350, 0.998507662237710810, 0.998510391579462200, 0.998513118424937620, 0.998515842774130190, 0.998518564627033140, +0.998521283983639710, 0.998524000843943100, 0.998526715207936450, 0.998529427075613100, 0.998532136446966030, 0.998534843321988720, 0.998537547700674380, 0.998540249583016020, +0.998542948969007080, 0.998545645858640810, 0.998548340251910420, 0.998551032148809140, 0.998553721549330200, 0.998556408453467160, 0.998559092861213030, 0.998561774772561030, +0.998564454187504720, 0.998567131106037230, 0.998569805528152000, 0.998572477453842140, 0.998575146883101120, 0.998577813815922260, 0.998580478252298900, 0.998583140192224270, +0.998585799635691830, 0.998588456582694910, 0.998591111033226730, 0.998593762987280860, 0.998596412444850650, 0.998599059405929300, 0.998601703870510390, 0.998604345838587150, +0.998606985310153130, 0.998609622285201560, 0.998612256763726000, 0.998614888745719690, 0.998617518231176280, 0.998620145220089020, 0.998622769712451450, 0.998625391708256930, +0.998628011207498890, 0.998630628210170790, 0.998633242716266190, 0.998635854725778430, 0.998638464238701170, 0.998641071255027660, 0.998643675774751440, 0.998646277797866080, +0.998648877324364910, 0.998651474354241620, 0.998654068887489750, 0.998656660924102660, 0.998659250464073890, 0.998661837507396900, 0.998664422054065470, 0.998667004104072830, +0.998669583657412760, 0.998672160714078830, 0.998674735274064360, 0.998677307337363150, 0.998679876903968640, 0.998682443973874400, 0.998685008547074090, 0.998687570623561170, +0.998690130203329420, 0.998692687286372280, 0.998695241872683550, 0.998697793962256550, 0.998700343555085190, 0.998702890651162910, 0.998705435250483390, 0.998707977353040290, +0.998710516958827290, 0.998713054067837950, 0.998715588680066050, 0.998718120795505150, 0.998720650414148920, 0.998723177535991050, 0.998725702161025300, 0.998728224289245240, +0.998730743920644650, 0.998733261055217200, 0.998735775692956570, 0.998738287833856540, 0.998740797477910780, 0.998743304625112960, 0.998745809275456970, 0.998748311428936390, +0.998750811085545090, 0.998753308245276750, 0.998755802908125050, 0.998758295074083980, 0.998760784743147110, 0.998763271915308230, 0.998765756590561220, 0.998768238768899860, +0.998770718450317840, 0.998773195634809040, 0.998775670322367250, 0.998778142512986360, 0.998780612206660030, 0.998783079403382180, 0.998785544103146570, 0.998788006305947220, +0.998790466011777790, 0.998792923220632180, 0.998795377932504280, 0.998797830147387990, 0.998800279865277090, 0.998802727086165460, 0.998805171810047020, 0.998807614036915650, +0.998810053766765350, 0.998812490999589800, 0.998814925735383110, 0.998817357974138950, 0.998819787715851560, 0.998822214960514600, 0.998824639708122080, 0.998827061958668110, +0.998829481712146360, 0.998831898968550960, 0.998834313727875790, 0.998836725990114860, 0.998839135755262060, 0.998841543023311410, 0.998843947794257000, 0.998846350068092750, +0.998848749844812530, 0.998851147124410370, 0.998853541906880470, 0.998855934192216630, 0.998858323980412970, 0.998860711271463590, 0.998863096065362390, 0.998865478362103380, +0.998867858161680780, 0.998870235464088490, 0.998872610269320500, 0.998874982577371170, 0.998877352388234270, 0.998879719701904030, 0.998882084518374460, 0.998884446837639770, +0.998886806659693870, 0.998889163984530980, 0.998891518812145110, 0.998893871142530590, 0.998896220975681200, 0.998898568311591410, 0.998900913150255200, 0.998903255491666700, +0.998905595335820020, 0.998907932682709390, 0.998910267532328810, 0.998912599884672740, 0.998914929739735060, 0.998917257097510000, 0.998919581957991910, 0.998921904321174890, +0.998924224187053070, 0.998926541555620660, 0.998928856426871900, 0.998931168800801020, 0.998933478677402120, 0.998935786056669660, 0.998938090938597760, 0.998940393323180520, +0.998942693210412290, 0.998944990600287410, 0.998947285492799990, 0.998949577887944360, 0.998951867785714880, 0.998954155186105640, 0.998956440089111110, 0.998958722494725390, +0.998961002402942830, 0.998963279813757770, 0.998965554727164640, 0.998967827143157460, 0.998970097061730790, 0.998972364482878960, 0.998974629406596090, 0.998976891832876750, +0.998979151761715150, 0.998981409193105630, 0.998983664127042540, 0.998985916563520430, 0.998988166502533410, 0.998990413944076060, 0.998992658888142590, 0.998994901334727570, +0.998997141283825220, 0.998999378735429990, 0.999001613689536440, 0.999003846146138690, 0.999006076105231510, 0.999008303566809030, 0.999010528530865800, 0.999012750997396280, +0.999014970966394800, 0.999017188437856030, 0.999019403411774200, 0.999021615888143870, 0.999023825866959480, 0.999026033348215600, 0.999028238331906570, 0.999030440818026940, +0.999032640806571280, 0.999034838297533920, 0.999037033290909540, 0.999039225786692580, 0.999041415784877480, 0.999043603285458940, 0.999045788288431270, 0.999047970793789260, +0.999050150801527260, 0.999052328311639930, 0.999054503324121710, 0.999056675838967290, 0.999058845856171110, 0.999061013375727840, 0.999063178397632030, 0.999065340921878380, +0.999067500948461310, 0.999069658477375390, 0.999071813508615400, 0.999073966042176020, 0.999076116078051580, 0.999078263616236860, 0.999080408656726430, 0.999082551199515060, +0.999084691244597310, 0.999086828791967750, 0.999088963841621270, 0.999091096393552200, 0.999093226447755560, 0.999095354004225670, 0.999097479062957540, 0.999099601623945620, +0.999101721687184810, 0.999103839252669660, 0.999105954320394840, 0.999108066890355250, 0.999110176962545340, 0.999112284536960100, 0.999114389613594110, 0.999116492192442140, +0.999118592273498970, 0.999120689856759390, 0.999122784942217960, 0.999124877529869560, 0.999126967619709090, 0.999129055211731120, 0.999131140305930530, 0.999133222902302000, +0.999135303000840520, 0.999137380601540780, 0.999139455704397550, 0.999141528309405720, 0.999143598416560090, 0.999145666025855420, 0.999147731137286500, 0.999149793750848340, +0.999151853866535710, 0.999153911484343520, 0.999155966604266420, 0.999158019226299430, 0.999160069350437440, 0.999162116976675230, 0.999164162105007800, 0.999166204735429830, +0.999168244867936540, 0.999170282502522490, 0.999172317639182790, 0.999174350277912240, 0.999176380418705820, 0.999178408061558550, 0.999180433206465100, 0.999182455853420690, +0.999184476002420220, 0.999186493653458350, 0.999188508806530430, 0.999190521461631120, 0.999192531618755540, 0.999194539277898590, 0.999196544439055370, 0.999198547102220780, +0.999200547267389830, 0.999202544934557510, 0.999204540103718730, 0.999206532774868710, 0.999208522948002330, 0.999210510623114610, 0.999212495800200660, 0.999214478479255490, +0.999216458660273980, 0.999218436343251470, 0.999220411528182860, 0.999222384215063150, 0.999224354403887460, 0.999226322094651010, 0.999228287287348690, 0.999230249981975630, +0.999232210178526930, 0.999234167876997810, 0.999236123077383190, 0.999238075779678270, 0.999240025983878180, 0.999241973689978020, 0.999243918897972930, 0.999245861607858000, +0.999247801819628470, 0.999249739533279340, 0.999251674748805940, 0.999253607466203400, 0.999255537685466710, 0.999257465406591330, 0.999259390629572250, 0.999261313354404600, +0.999263233581083710, 0.999265151309604800, 0.999267066539962890, 0.999268979272153410, 0.999270889506171490, 0.999272797242012350, 0.999274702479671210, 0.999276605219143190, +0.999278505460423850, 0.999280403203508080, 0.999282298448391450, 0.999284191195068950, 0.999286081443536030, 0.999287969193787930, 0.999289854445819860, 0.999291737199627160, +0.999293617455205170, 0.999295495212549010, 0.999297370471654230, 0.999299243232515950, 0.999301113495129620, 0.999302981259490570, 0.999304846525593930, 0.999306709293435240, +0.999308569563009730, 0.999310427334312860, 0.999312282607339950, 0.999314135382086240, 0.999315985658547290, 0.999317833436718320, 0.999319678716594770, 0.999321521498171990, +0.999323361781445430, 0.999325199566410530, 0.999327034853062510, 0.999328867641396950, 0.999330697931409270, 0.999332525723094830, 0.999334351016449070, 0.999336173811467440, +0.999337994108145390, 0.999339811906478250, 0.999341627206461690, 0.999343440008091060, 0.999345250311361790, 0.999347058116269450, 0.999348863422809370, 0.999350666230977240, +0.999352466540768370, 0.999354264352178330, 0.999356059665202580, 0.999357852479836880, 0.999359642796076360, 0.999361430613916800, 0.999363215933353640, 0.999364998754382450, +0.999366779076998780, 0.999368556901198190, 0.999370332226976130, 0.999372105054328390, 0.999373875383250180, 0.999375643213737400, 0.999377408545785490, 0.999379171379390140, +0.999380931714546780, 0.999382689551251090, 0.999384444889498620, 0.999386197729285160, 0.999387948070606160, 0.999389695913457280, 0.999391441257834190, 0.999393184103732460, +0.999394924451147750, 0.999396662300075730, 0.999398397650512080, 0.999400130502452470, 0.999401860855892550, 0.999403588710827910, 0.999405314067254300, 0.999407036925167410, +0.999408757284563020, 0.999410475145436570, 0.999412190507784070, 0.999413903371601080, 0.999415613736883260, 0.999417321603626510, 0.999419026971826390, 0.999420729841478670, +0.999422430212579150, 0.999424128085123600, 0.999425823459107690, 0.999427516334527200, 0.999429206711378030, 0.999430894589655730, 0.999432579969356190, 0.999434262850475210, +0.999435943233008660, 0.999437621116952220, 0.999439296502301680, 0.999440969389052910, 0.999442639777201710, 0.999444307666743970, 0.999445973057675460, 0.999447635949991970, +0.999449296343689400, 0.999450954238763620, 0.999452609635210320, 0.999454262533025610, 0.999455912932205260, 0.999457560832745060, 0.999459206234641020, 0.999460849137889020, +0.999462489542484840, 0.999464127448424390, 0.999465762855703650, 0.999467395764318530, 0.999469026174264810, 0.999470654085538700, 0.999472279498135770, 0.999473902412052250, +0.999475522827284020, 0.999477140743826990, 0.999478756161677030, 0.999480369080830160, 0.999481979501282370, 0.999483587423029670, 0.999485192846067960, 0.999486795770393340, +0.999488396196001720, 0.999489994122889080, 0.999491589551051440, 0.999493182480484910, 0.999494772911185380, 0.999496360843148860, 0.999497946276371450, 0.999499529210849280, +0.999501109646578230, 0.999502687583554320, 0.999504263021773750, 0.999505835961232550, 0.999507406401926700, 0.999508974343852440, 0.999510539787005660, 0.999512102731382580, +0.999513663176979210, 0.999515221123791650, 0.999516776571816150, 0.999518329521048580, 0.999519879971485280, 0.999521427923122260, 0.999522973375955640, 0.999524516329981630, +0.999526056785196240, 0.999527594741595800, 0.999529130199176330, 0.999530663157934040, 0.999532193617865160, 0.999533721578965690, 0.999535247041231980, 0.999536770004660120, +0.999538290469246360, 0.999539808434986910, 0.999541323901877890, 0.999542836869915520, 0.999544347339096140, 0.999545855309415860, 0.999547360780870920, 0.999548863753457640, +0.999550364227172140, 0.999551862202010750, 0.999553357677969710, 0.999554850655045240, 0.999556341133233660, 0.999557829112531330, 0.999559314592934340, 0.999560797574439050, +0.999562278057041790, 0.999563756040738770, 0.999565231525526450, 0.999566704511401060, 0.999568174998358820, 0.999569642986396170, 0.999571108475509450, 0.999572571465695000, +0.999574031956949050, 0.999575489949268040, 0.999576945442648300, 0.999578398437086180, 0.999579848932578120, 0.999581296929120340, 0.999582742426709410, 0.999584185425341550, +0.999585625925013320, 0.999587063925720940, 0.999588499427460970, 0.999589932430229760, 0.999591362934023620, 0.999592790938839130, 0.999594216444672720, 0.999595639451520630, +0.999597059959379530, 0.999598477968245860, 0.999599893478115840, 0.999601306488986150, 0.999602717000853240, 0.999604125013713540, 0.999605530527563510, 0.999606933542399600, +0.999608334058218360, 0.999609732075016360, 0.999611127592789920, 0.999612520611535830, 0.999613911131250310, 0.999615299151930040, 0.999616684673571450, 0.999618067696171230, +0.999619448219725930, 0.999620826244231870, 0.999622201769685750, 0.999623574796084210, 0.999624945323423720, 0.999626313351700820, 0.999627678880912090, 0.999629041911054280, +0.999630402442123760, 0.999631760474117280, 0.999633116007031420, 0.999634469040862840, 0.999635819575607990, 0.999637167611263530, 0.999638513147826260, 0.999639856185292610, +0.999641196723659480, 0.999642534762923200, 0.999643870303080660, 0.999645203344128430, 0.999646533886063170, 0.999647861928881660, 0.999649187472580360, 0.999650510517156250, +0.999651831062605690, 0.999653149108925660, 0.999654464656112740, 0.999655777704163690, 0.999657088253075200, 0.999658396302843920, 0.999659701853466750, 0.999661004904940250, +0.999662305457261200, 0.999663603510426490, 0.999664899064432680, 0.999666192119276650, 0.999667482674955200, 0.999668770731464980, 0.999670056288802790, 0.999671339346965500, +0.999672619905949910, 0.999673897965752790, 0.999675173526370920, 0.999676446587800970, 0.999677717150040060, 0.999678985213084850, 0.999680250776932120, 0.999681513841578770, +0.999682774407021580, 0.999684032473257540, 0.999685288040283450, 0.999686541108096070, 0.999687791676692310, 0.999689039746069150, 0.999690285316223390, 0.999691528387151810, +0.999692768958851510, 0.999694007031319280, 0.999695242604552000, 0.999696475678546690, 0.999697706253300120, 0.999698934328809300, 0.999700159905071110, 0.999701382982082550, +0.999702603559840530, 0.999703821638342040, 0.999705037217583970, 0.999706250297563210, 0.999707460878277000, 0.999708668959721990, 0.999709874541895420, 0.999711077624794050, +0.999712278208415130, 0.999713476292755420, 0.999714671877812040, 0.999715864963582000, 0.999717055550062180, 0.999718243637249810, 0.999719429225141900, 0.999720612313735320, +0.999721792903027320, 0.999722970993014770, 0.999724146583694680, 0.999725319675064390, 0.999726490267120680, 0.999727658359860880, 0.999728823953281890, 0.999729987047380810, +0.999731147642154760, 0.999732305737600860, 0.999733461333716100, 0.999734614430497830, 0.999735765027942920, 0.999736913126048620, 0.999738058724812140, 0.999739201824230370, +0.999740342424300650, 0.999741480525020100, 0.999742616126385820, 0.999743749228395040, 0.999744879831044870, 0.999746007934332440, 0.999747133538255060, 0.999748256642809860, +0.999749377247993950, 0.999750495353804670, 0.999751610960239120, 0.999752724067294540, 0.999753834674968140, 0.999754942783257160, 0.999756048392158920, 0.999757151501670440, +0.999758252111789040, 0.999759350222512170, 0.999760445833836830, 0.999761538945760360, 0.999762629558279990, 0.999763717671393160, 0.999764803285096980, 0.999765886399388900, +0.999766967014265930, 0.999768045129725610, 0.999769120745765290, 0.999770193862381970, 0.999771264479573320, 0.999772332597336440, 0.999773398215668800, 0.999774461334567600, +0.999775521954030300, 0.999776580074054120, 0.999777635694636510, 0.999778688815774810, 0.999779739437466450, 0.999780787559708670, 0.999781833182498910, 0.999782876305834620, +0.999783916929713130, 0.999784955054131900, 0.999785990679088240, 0.999787023804579510, 0.999788054430603370, 0.999789082557157040, 0.999790108184237970, 0.999791131311843610, +0.999792151939971510, 0.999793170068619010, 0.999794185697783560, 0.999795198827462590, 0.999796209457653680, 0.999797217588354270, 0.999798223219561800, 0.999799226351273720, +0.999800226983487580, 0.999801225116200950, 0.999802220749411270, 0.999803213883115990, 0.999804204517312670, 0.999805192651998850, 0.999806178287172000, 0.999807161422829770, +0.999808142058969620, 0.999809120195589100, 0.999810095832685760, 0.999811068970257290, 0.999812039608301010, 0.999813007746814700, 0.999813973385795920, 0.999814936525242120, +0.999815897165150960, 0.999816855305520110, 0.999817810946347140, 0.999818764087629600, 0.999819714729365150, 0.999820662871551470, 0.999821608514186110, 0.999822551657266740, +0.999823492300790930, 0.999824430444756440, 0.999825366089160840, 0.999826299234001900, 0.999827229879277190, 0.999828158024984370, 0.999829083671121110, 0.999830006817685190, +0.999830927464674280, 0.999831845612086050, 0.999832761259918160, 0.999833674408168390, 0.999834585056834420, 0.999835493205914030, 0.999836398855404870, 0.999837302005304740, +0.999838202655611300, 0.999839100806322430, 0.999839996457435820, 0.999840889608949120, 0.999841780260860240, 0.999842668413166940, 0.999843554065866890, 0.999844437218958100, +0.999845317872438130, 0.999846196026304870, 0.999847071680556090, 0.999847944835189680, 0.999848815490203320, 0.999849683645595010, 0.999850549301362520, 0.999851412457503530, +0.999852273114016140, 0.999853131270898030, 0.999853986928147090, 0.999854840085761200, 0.999855690743738150, 0.999856538902075930, 0.999857384560772330, 0.999858227719825240, +0.999859068379232660, 0.999859906538992370, 0.999860742199102260, 0.999861575359560330, 0.999862406020364470, 0.999863234181512680, 0.999864059843002640, 0.999864883004832560, +0.999865703667000340, 0.999866521829503750, 0.999867337492340910, 0.999868150655509600, 0.999868961319008040, 0.999869769482834010, 0.999870575146985630, 0.999871378311460780, +0.999872178976257460, 0.999872977141373800, 0.999873772806807560, 0.999874565972556970, 0.999875356638619930, 0.999876144804994540, 0.999876930471678690, 0.999877713638670620, +0.999878494305968200, 0.999879272473569560, 0.999880048141472800, 0.999880821309675820, 0.999881591978176830, 0.999882360146973960, 0.999883125816065090, 0.999883888985448440, +0.999884649655122030, 0.999885407825083950, 0.999886163495332440, 0.999886916665865490, 0.999887667336681220, 0.999888415507777850, 0.999889161179153390, 0.999889904350806050, +0.999890645022733950, 0.999891383194935200, 0.999892118867408030, 0.999892852040150550, 0.999893582713160980, 0.999894310886437430, 0.999895036559978020, 0.999895759733781090, +0.999896480407844850, 0.999897198582167300, 0.999897914256746790, 0.999898627431581420, 0.999899338106669530, 0.999900046282009350, 0.999900751957598980, 0.999901455133436760, +0.999902155809520910, 0.999902853985849660, 0.999903549662421340, 0.999904242839234070, 0.999904933516286180, 0.999905621693576000, 0.999906307371101750, 0.999906990548861780, +0.999907671226854310, 0.999908349405077670, 0.999909025083530080, 0.999909698262209990, 0.999910368941115620, 0.999911037120245430, 0.999911702799597510, 0.999912365979170440, +0.999913026658962420, 0.999913684838971810, 0.999914340519197030, 0.999914993699636320, 0.999915644380288130, 0.999916292561150890, 0.999916938242222940, 0.999917581423502620, +0.999918222104988370, 0.999918860286678530, 0.999919495968571550, 0.999920129150665750, 0.999920759832959800, 0.999921388015451830, 0.999922013698140380, 0.999922636881023900, +0.999923257564100940, 0.999923875747369740, 0.999924491430828840, 0.999925104614476700, 0.999925715298311870, 0.999926323482332680, 0.999926929166537800, 0.999927532350925460, +0.999928133035494330, 0.999928731220242950, 0.999929326905169670, 0.999929920090273040, 0.999930510775551620, 0.999931098961003960, 0.999931684646628630, 0.999932267832423950, +0.999932848518388710, 0.999933426704521230, 0.999934002390820310, 0.999934575577284270, 0.999935146263911890, 0.999935714450701620, 0.999936280137652010, 0.999936843324761740, +0.999937404012029350, 0.999937962199453520, 0.999938517887032700, 0.999939071074765650, 0.999939621762650830, 0.999940169950687020, 0.999940715638872770, 0.999941258827206750, +0.999941799515687510, 0.999942337704313840, 0.999942873393084410, 0.999943406581997650, 0.999943937271052460, 0.999944465460247400, 0.999944991149581130, 0.999945514339052430, +0.999946035028659970, 0.999946553218402310, 0.999947068908278450, 0.999947582098286820, 0.999948092788426220, 0.999948600978695420, 0.999949106669093090, 0.999949609859618000, +0.999950110550268830, 0.999950608741044470, 0.999951104431943570, 0.999951597622964930, 0.999952088314107200, 0.999952576505369390, 0.999953062196750060, 0.999953545388248100, +0.999954026079862280, 0.999954504271591380, 0.999954979963434190, 0.999955453155389580, 0.999955923847456350, 0.999956392039633270, 0.999956857731919220, 0.999957320924313000, +0.999957781616813590, 0.999958239809419670, 0.999958695502130120, 0.999959148694943840, 0.999959599387859720, 0.999960047580876530, 0.999960493273993280, 0.999960936467208740, +0.999961377160521910, 0.999961815353931690, 0.999962251047436860, 0.999962684241036400, 0.999963114934729220, 0.999963543128514320, 0.999963968822390580, 0.999964392016356780, +0.999964812710412150, 0.999965230904555470, 0.999965646598785620, 0.999966059793101710, 0.999966470487502650, 0.999966878681987410, 0.999967284376554910, 0.999967687571204240, +0.999968088265934420, 0.999968486460744320, 0.999968882155633070, 0.999969275350599540, 0.999969666045642860, 0.999970054240762020, 0.999970439935956020, 0.999970823131223870, +0.999971203826564680, 0.999971582021977560, 0.999971957717461500, 0.999972330913015410, 0.999972701608638600, 0.999973069804329980, 0.999973435500088770, 0.999973798695913850, +0.999974159391804560, 0.999974517587759790, 0.999974873283778760, 0.999975226479860590, 0.999975577176004270, 0.999975925372209030, 0.999976271068473980, 0.999976614264798220, +0.999976954961181000, 0.999977293157621410, 0.999977628854118450, 0.999977962050671580, 0.999978292747279670, 0.999978620943942080, 0.999978946640658010, 0.999979269837426470, +0.999979590534246790, 0.999979908731118080, 0.999980224428039690, 0.999980537625010710, 0.999980848322030380, 0.999981156519097910, 0.999981462216212650, 0.999981765413373580, +0.999982066110580270, 0.999982364307831610, 0.999982660005127140, 0.999982953202466000, 0.999983243899847500, 0.999983532097270870, 0.999983817794735440, 0.999984100992240440, +0.999984381689785210, 0.999984659887369070, 0.999984935584991130, 0.999985208782650960, 0.999985479480347770, 0.999985747678080910, 0.999986013375849580, 0.999986276573653240, +0.999986537271491230, 0.999986795469362980, 0.999987051167267600, 0.999987304365204670, 0.999987555063173380, 0.999987803261173310, 0.999988048959203680, 0.999988292157263920, +0.999988532855353500, 0.999988771053471730, 0.999989006751617950, 0.999989239949791720, 0.999989470647992370, 0.999989698846219350, 0.999989924544472110, 0.999990147742750080, +0.999990368441052600, 0.999990586639379230, 0.999990802337729410, 0.999991015536102590, 0.999991226234498210, 0.999991434432915720, 0.999991640131354780, 0.999991843329814610, +0.999992044028294890, 0.999992242226795060, 0.999992437925314560, 0.999992631123853060, 0.999992821822409890, 0.999993010020984730, 0.999993195719577120, 0.999993378918186400, +0.999993559616812240, 0.999993737815454200, 0.999993913514111820, 0.999994086712784670, 0.999994257411472300, 0.999994425610174260, 0.999994591308890230, 0.999994754507619650, +0.999994915206362190, 0.999995073405117510, 0.999995229103885050, 0.999995382302664600, 0.999995533001455610, 0.999995681200257840, 0.999995826899070850, 0.999995970097894320, +0.999996110796727900, 0.999996248995571160, 0.999996384694423760, 0.999996517893285470, 0.999996648592155870, 0.999996776791034600, 0.999996902489921460, 0.999997025688815990, +0.999997146387717970, 0.999997264586627080, 0.999997380285543080, 0.999997493484465540, 0.999997604183394340, 0.999997712382329150, 0.999997818081269640, 0.999997921280215580, +0.999998021979166760, 0.999998120178122840, 0.999998215877083600, 0.999998309076048920, 0.999998399775018370, 0.999998487973991820, 0.999998573672969180, 0.999998656871950000, +0.999998737570934160, 0.999998815769921560, 0.999998891468911850, 0.999998964667904940, 0.999999035366900600, 0.999999103565898610, 0.999999169264898960, 0.999999232463901320, +0.999999293162905700, 0.999999351361911760, 0.999999407060919500, 0.999999460259928700, 0.999999510958939240, 0.999999559157951020, 0.999999604856963820, 0.999999648055977740, +0.999999688754992460, 0.999999726954007960, 0.999999762653024150, 0.999999795852040910, 0.999999826551058240, 0.999999854750076020, 0.999999880449094050, 0.999999903648112530, +0.999999924347131140, 0.999999942546149990, 0.999999958245168960, 0.999999971444187950, 0.999999982143207180, 0.999999990342226310, 0.999999996041245560, 0.999999999240264840, +0.999999999939284010, 0.999999998138303310, 0.999999993837322520, 0.999999987036341740, 0.999999977735361090, 0.999999965934380450, 0.999999951633399830, 0.999999934832419330, +0.999999915531439080, 0.999999893730459060, 0.999999869429479270, 0.999999842628499720, 0.999999813327520640, 0.999999781526542010, 0.999999747225563950, 0.999999710424586570, +0.999999671123609770, 0.999999629322633980, 0.999999585021658980, 0.999999538220684990, 0.999999488919712240, 0.999999437118740730, 0.999999382817770680, 0.999999326016802190, +0.999999266715835280, 0.999999204914870270, 0.999999140613907270, 0.999999073812946390, 0.999999004511987750, 0.999998932711031690, 0.999998858410078300, 0.999998781609127700, +0.999998702308180220, 0.999998620507235980, 0.999998536206295090, 0.999998449405357980, 0.999998360104424670, 0.999998268303495470, 0.999998174002570630, 0.999998077201650350, +0.999997977900734860, 0.999997876099824490, 0.999997771798919350, 0.999997664998019790, 0.999997555697126120, 0.999997443896238570, 0.999997329595357360, 0.999997212794482840, +0.999997093493615210, 0.999996971692754920, 0.999996847391902310, 0.999996720591057380, 0.999996591290220780, 0.999996459489392640, 0.999996325188573400, 0.999996188387763390, +0.999996049086962820, 0.999995907286172160, 0.999995762985391720, 0.999995616184621850, 0.999995466883862980, 0.999995315083115450, 0.999995160782379600, 0.999995003981655860, +0.999994844680944570, 0.999994682880246290, 0.999994518579561230, 0.999994351778889850, 0.999994182478232570, 0.999994010677589860, 0.999993836376962150, 0.999993659576349890, +0.999993480275753410, 0.999993298475173260, 0.999993114174609790, 0.999992927374063640, 0.999992738073535170, 0.999992546273024810, 0.999992351972533110, 0.999992155172060530, +0.999991955871607500, 0.999991754071174580, 0.999991549770762320, 0.999991342970371180, 0.999991133670001700, 0.999990921869654440, 0.999990707569329840, 0.999990490769028350, +0.999990271468750750, 0.999990049668497470, 0.999989825368269080, 0.999989598568066020, 0.999989369267889060, 0.999989137467738650, 0.999988903167615460, 0.999988666367519930, +0.999988427067452720, 0.999988185267414510, 0.999987940967405840, 0.999987694167427280, 0.999987444867479480, 0.999987193067563120, 0.999986938767678750, 0.999986681967826920, +0.999986422668008520, 0.999986160868224010, 0.999985896568474140, 0.999985629768759490, 0.999985360469080820, 0.999985088669438690, 0.999984814369833890, 0.999984537570267060, +0.999984258270738780, 0.999983976471249920, 0.999983692171801160, 0.999983405372393160, 0.999983116073026590, 0.999982824273702330, 0.999982529974420940, 0.999982233175183200, +0.999981933875989880, 0.999981632076841760, 0.999981327777739630, 0.999981020978684020, 0.999980711679675950, 0.999980399880716190, 0.999980085581805290, 0.999979768782944260, +0.999979449484133750, 0.999979127685374560, 0.999978803386667670, 0.999978476588013750, 0.999978147289413590, 0.999977815490868170, 0.999977481192378060, 0.999977144393944360, +0.999976805095567740, 0.999976463297249100, 0.999976118998989420, 0.999975772200789260, 0.999975422902649850, 0.999975071104571730, 0.999974716806556030, 0.999974360008603510, +0.999974000710715070, 0.999973638912891700, 0.999973274615134190, 0.999972907817443410, 0.999972538519820490, 0.999972166722266190, 0.999971792424781400, 0.999971415627367240, +0.999971036330024490, 0.999970654532754130, 0.999970270235557180, 0.999969883438434510, 0.999969494141387140, 0.999969102344416050, 0.999968708047522140, 0.999968311250706510, +0.999967911953970170, 0.999967510157314000, 0.999967105860739000, 0.999966699064246290, 0.999966289767836860, 0.999965877971511600, 0.999965463675271730, 0.999965046879118250, +0.999964627583052050, 0.999964205787074350, 0.999963781491186030, 0.999963354695388440, 0.999962925399682350, 0.999962493604068970, 0.999962059308549310, 0.999961622513124480, +0.999961183217795700, 0.999960741422563860, 0.999960297127430290, 0.999959850332395870, 0.999959401037461840, 0.999958949242629290, 0.999958494947899460, 0.999958038153273330, +0.999957578858752140, 0.999957117064336990, 0.999956652770028990, 0.999956185975829470, 0.999955716681739330, 0.999955244887760000, 0.999954770593892590, 0.999954293800138230, +0.999953814506498120, 0.999953332712973490, 0.999952848419565440, 0.999952361626275320, 0.999951872333104340, 0.999951380540053610, 0.999950886247124470, 0.999950389454318130, +0.999949890161635820, 0.999949388369078760, 0.999948884076648280, 0.999948377284345600, 0.999947867992171830, 0.999947356200128530, 0.999946841908216810, 0.999946325116438000, +0.999945805824793310, 0.999945284033284200, 0.999944759741911770, 0.999944232950677580, 0.999943703659582630, 0.999943171868628580, 0.999942637577816540, 0.999942100787147850, +0.999941561496624050, 0.999941019706246270, 0.999940475416015940, 0.999939928625934390, 0.999939379336002960, 0.999938827546223210, 0.999938273256596340, 0.999937716467123820, +0.999937157177806960, 0.999936595388647210, 0.999936031099646020, 0.999935464310804710, 0.999934895022124850, 0.999934323233607650, 0.999933748945254660, 0.999933172157067230, +0.999932592869046900, 0.999932011081195120, 0.999931426793513320, 0.999930840006002960, 0.999930250718665480, 0.999929658931502430, 0.999929064644515140, 0.999928467857705280, +0.999927868571074190, 0.999927266784623400, 0.999926662498354490, 0.999926055712268890, 0.999925446426368270, 0.999924834640653960, 0.999924220355127510, 0.999923603569790490, +0.999922984284644540, 0.999922362499691130, 0.999921738214931800, 0.999921111430368100, 0.999920482146001710, 0.999919850361833950, 0.999919216077866710, 0.999918579294101440, +0.999917940010539570, 0.999917298227183000, 0.999916653944033060, 0.999916007161091640, 0.999915357878360060, 0.999914706095840210, 0.999914051813533540, 0.999913395031441720, +0.999912735749566410, 0.999912073967909270, 0.999911409686471960, 0.999910742905256060, 0.999910073624263430, 0.999909401843495530, 0.999908727562954120, 0.999908050782640890, +0.999907371502557600, 0.999906689722705800, 0.999906005443087280, 0.999905318663703800, 0.999904629384557040, 0.999903937605648660, 0.999903243326980440, 0.999902546548554150, +0.999901847270371460, 0.999901145492434140, 0.999900441214743970, 0.999899734437302730, 0.999899025160112090, 0.999898313383173920, 0.999897599106490010, 0.999896882330062020, +0.999896163053891950, 0.999895441277981360, 0.999894717002332230, 0.999893990226946250, 0.999893260951825290, 0.999892529176971250, 0.999891794902385780, 0.999891058128070890, +0.999890318854028350, 0.999889577080260050, 0.999888832806767770, 0.999888086033553390, 0.999887336760618920, 0.999886584987966010, 0.999885830715596560, 0.999885073943512670, +0.999884314671716010, 0.999883552900208580, 0.999882788628992270, 0.999882021858069070, 0.999881252587440650, 0.999880480817109230, 0.999879706547076590, 0.999878929777344600, +0.999878150507915400, 0.999877368738790740, 0.999876584469972740, 0.999875797701463180, 0.999875008433264270, 0.999874216665377680, 0.999873422397805630, 0.999872625630550020, +0.999871826363612830, 0.999871024596996060, 0.999870220330701830, 0.999869413564731910, 0.999868604299088530, 0.999867792533773670, 0.999866978268789230, 0.999866161504137430, +0.999865342239820270, 0.999864520475839620, 0.999863696212197730, 0.999862869448896570, 0.999862040185938270, 0.999861208423324930, 0.999860374161058550, 0.999859537399141130, +0.999858698137575000, 0.999857856376362040, 0.999857012115504480, 0.999856165355004320, 0.999855316094863780, 0.999854464335084960, 0.999853610075669970, 0.999852753316621050, +0.999851894057940170, 0.999851032299629460, 0.999850168041691360, 0.999849301284127740, 0.999848432026940850, 0.999847560270132880, 0.999846686013705970, 0.999845809257662420, +0.999844930002004360, 0.999844048246734010, 0.999843163991853470, 0.999842277237364960, 0.999841387983270820, 0.999840496229573270, 0.999839601976274420, 0.999838705223376590, +0.999837805970882010, 0.999836904218792790, 0.999835999967111480, 0.999835093215840080, 0.999834183964980920, 0.999833272214536330, 0.999832357964508640, 0.999831441214899970, +0.999830521965712760, 0.999829600216949220, 0.999828675968611580, 0.999827749220702390, 0.999826819973223760, 0.999825888226178020, 0.999824953979567720, 0.999824017233394870, +0.999823077987662120, 0.999822136242371600, 0.999821191997525730, 0.999820245253126960, 0.999819296009177520, 0.999818344265679840, 0.999817390022636250, 0.999816433280049210, +0.999815474037921150, 0.999814512296254400, 0.999813548055051290, 0.999812581314314390, 0.999811612074046010, 0.999810640334248600, 0.999809666094924500, 0.999808689356076360, +0.999807710117706420, 0.999806728379817320, 0.999805744142411300, 0.999804757405490910, 0.999803768169058690, 0.999802776433116990, 0.999801782197668350, 0.999800785462715340, +0.999799786228260270, 0.999798784494305810, 0.999797780260854310, 0.999796773527908410, 0.999795764295470570, 0.999794752563543330, 0.999793738332129260, 0.999792721601230780, +0.999791702370850470, 0.999790680640990970, 0.999789656411654740, 0.999788629682844320, 0.999787600454562390, 0.999786568726811380, 0.999785534499594060, 0.999784497772912890, +0.999783458546770420, 0.999782416821169310, 0.999781372596112110, 0.999780325871601590, 0.999779276647640210, 0.999778224924230630, 0.999777170701375510, 0.999776113979077400, +0.999775054757339080, 0.999773993036163100, 0.999772928815552130, 0.999771862095508830, 0.999770792876035870, 0.999769721157136030, 0.999768646938811730, 0.999767570221065880, +0.999766491003901140, 0.999765409287320160, 0.999764325071325620, 0.999763238355920290, 0.999762149141106840, 0.999761057426888140, 0.999759963213266660, 0.999758866500245260, +0.999757767287826840, 0.999756665576013840, 0.999755561364809250, 0.999754454654215750, 0.999753345444236110, 0.999752233734873100, 0.999751119526129610, 0.999750002818008190, +0.999748883610511840, 0.999747761903643230, 0.999746637697405240, 0.999745510991800650, 0.999744381786832230, 0.999743250082502980, 0.999742115878815450, 0.999740979175772760, +0.999739839973377560, 0.999738698271632750, 0.999737554070541210, 0.999736407370105830, 0.999735258170329380, 0.999734106471214860, 0.999732952272764930, 0.999731795574982820, +0.999730636377871070, 0.999729474681432690, 0.999728310485670790, 0.999727143790588020, 0.999725974596187390, 0.999724802902471790, 0.999723628709444310, 0.999722452017107630, +0.999721272825464860, 0.999720091134518870, 0.999718906944272680, 0.999717720254729270, 0.999716531065891530, 0.999715339377762470, 0.999714145190345070, 0.999712948503642230, +0.999711749317657160, 0.999710547632392640, 0.999709343447851780, 0.999708136764037470, 0.999706927580952920, 0.999705715898601020, 0.999704501716984770, 0.999703285036107280, +0.999702065855971660, 0.999700844176580890, 0.999699619997937880, 0.999698393320045950, 0.999697164142907990, 0.999695932466527100, 0.999694698290906400, 0.999693461616048880, +0.999692222441957770, 0.999690980768636160, 0.999689736596087060, 0.999688489924313580, 0.999687240753318940, 0.999685989083106130, 0.999684734913678370, 0.999683478245038780, +0.999682219077190460, 0.999680957410136630, 0.999679693243880400, 0.999678426578424980, 0.999677157413773390, 0.999675885749929050, 0.999674611586894860, 0.999673334924674250, +0.999672055763270230, 0.999670774102686120, 0.999669489942925040, 0.999668203283990200, 0.999666914125884930, 0.999665622468612350, 0.999664328312175670, 0.999663031656578220, +0.999661732501823220, 0.999660430847913780, 0.999659126694853350, 0.999657820042645140, 0.999656510891292260, 0.999655199240798150, 0.999653885091166040, 0.999652568442399250, +0.999651249294501110, 0.999649927647474730, 0.999648603501323560, 0.999647276856050930, 0.999645947711660040, 0.999644616068154250, 0.999643281925536980, 0.999641945283811560, +0.999640606142981230, 0.999639264503049300, 0.999637920364019330, 0.999636573725894540, 0.999635224588678260, 0.999633872952373940, 0.999632518816985010, 0.999631162182514690, +0.999629803048966540, 0.999628441416343770, 0.999627077284649950, 0.999625710653888500, 0.999624341524062650, 0.999622969895176070, 0.999621595767232090, 0.999620219140234020, +0.999618840014185440, 0.999617458389089770, 0.999616074264950360, 0.999614687641770860, 0.999613298519554610, 0.999611906898305150, 0.999610512778025930, 0.999609116158720390, +0.999607717040392090, 0.999606315423044460, 0.999604911306681050, 0.999603504691305430, 0.999602095576920920, 0.999600683963531300, 0.999599269851139890, 0.999597853239750370, +0.999596434129366160, 0.999595012519990830, 0.999593588411628040, 0.999592161804281230, 0.999590732697954070, 0.999589301092650100, 0.999587866988372880, 0.999586430385125850, +0.999584991282912890, 0.999583549681737460, 0.999582105581602990, 0.999580658982513360, 0.999579209884472130, 0.999577758287482850, 0.999576304191549190, 0.999574847596674700, +0.999573388502863150, 0.999571926910118090, 0.999570462818443200, 0.999568996227842230, 0.999567527138318760, 0.999566055549876430, 0.999564581462518920, 0.999563104876250110, +0.999561625791073440, 0.999560144206992680, 0.999558660124011510, 0.999557173542133800, 0.999555684461363110, 0.999554192881703220, 0.999552698803157890, 0.999551202225730790, +0.999549703149425590, 0.999548201574246290, 0.999546697500196310, 0.999545190927279780, 0.999543681855500130, 0.999542170284861360, 0.999540656215367140, 0.999539139647021240, +0.999537620579827530, 0.999536099013789700, 0.999534574948911740, 0.999533048385197300, 0.999531519322650160, 0.999529987761274330, 0.999528453701073460, 0.999526917142051440, +0.999525378084212270, 0.999523836527559490, 0.999522292472097230, 0.999520745917829130, 0.999519196864759210, 0.999517645312891330, 0.999516091262229400, 0.999514534712777180, +0.999512975664538560, 0.999511414117517540, 0.999509850071718000, 0.999508283527143830, 0.999506714483799020, 0.999505142941687350, 0.999503568900812820, 0.999501992361179430, +0.999500413322790940, 0.999498831785651460, 0.999497247749765010, 0.999495661215135330, 0.999494072181766560, 0.999492480649662560, 0.999490886618827350, 0.999489290089264900, +0.999487691060979340, 0.999486089533974440, 0.999484485508254420, 0.999482878983823150, 0.999481269960684650, 0.999479658438843010, 0.999478044418302130, 0.999476427899066210, +0.999474808881139270, 0.999473187364525280, 0.999471563349228260, 0.999469936835252430, 0.999468307822601650, 0.999466676311280170, 0.999465042301291960, 0.999463405792641150, +0.999461766785331940, 0.999460125279368230, 0.999458481274754120, 0.999456834771493940, 0.999455185769591580, 0.999453534269051370, 0.999451880269877190, 0.999450223772073380, +0.999448564775644030, 0.999446903280593270, 0.999445239286925190, 0.999443572794644020, 0.999441903803753970, 0.999440232314259160, 0.999438558326163680, 0.999436881839471880, +0.999435202854187850, 0.999433521370315820, 0.999431837387860010, 0.999430150906824630, 0.999428461927213800, 0.999426770449031830, 0.999425076472282960, 0.999423379996971390, +0.999421681023101360, 0.999419979550677180, 0.999418275579703090, 0.999416569110183170, 0.999414860142121890, 0.999413148675523440, 0.999411434710392180, 0.999409718246732300, +0.999407999284548150, 0.999406277823843950, 0.999404553864624120, 0.999402827406892790, 0.999401098450654500, 0.999399366995913470, 0.999397633042673930, 0.999395896590940410, +0.999394157640717040, 0.999392416192008360, 0.999390672244818590, 0.999388925799152170, 0.999387176855013440, 0.999385425412406820, 0.999383671471336550, 0.999381915031807180, +0.999380156093822910, 0.999378394657388310, 0.999376630722507820, 0.999374864289185650, 0.999373095357426240, 0.999371323927234270, 0.999369549998613830, 0.999367773571569580, +0.999365994646105980, 0.999364213222227350, 0.999362429299938130, 0.999360642879242870, 0.999358853960146010, 0.999357062542652000, 0.999355268626765270, 0.999353472212490490, +0.999351673299831990, 0.999349871888794320, 0.999348067979381920, 0.999346261571599340, 0.999344452665451130, 0.999342641260941860, 0.999340827358075940, 0.999339010956857950, +0.999337192057292430, 0.999335370659383940, 0.999333546763137020, 0.999331720368556110, 0.999329891475646100, 0.999328060084411220, 0.999326226194856230, 0.999324389806985680, +0.999322550920804240, 0.999320709536316350, 0.999318865653526680, 0.999317019272439770, 0.999315170393060390, 0.999313319015393110, 0.999311465139442580, 0.999309608765213350, +0.999307749892709980, 0.999305888521937360, 0.999304024652899910, 0.999302158285602540, 0.999300289420049670, 0.999298418056246200, 0.999296544194196560, 0.999294667833905640, +0.999292788975377990, 0.999290907618618380, 0.999289023763631490, 0.999287137410422080, 0.999285248558994810, 0.999283357209354350, 0.999281463361505580, 0.999279567015453170, +0.999277668171201780, 0.999275766828756300, 0.999273862988121380, 0.999271956649301680, 0.999270047812302220, 0.999268136477127640, 0.999266222643782620, 0.999264306312272140, +0.999262387482600880, 0.999260466154773600, 0.999258542328795190, 0.999256616004670420, 0.999254687182404180, 0.999252755862001130, 0.999250822043466270, 0.999248885726804260, +0.999246946912020100, 0.999245005599118550, 0.999243061788104510, 0.999241115478982760, 0.999239166671758270, 0.999237215366435840, 0.999235261563020450, 0.999233305261516770, +0.999231346461929900, 0.999229385164264630, 0.999227421368525940, 0.999225455074718720, 0.999223486282847850, 0.999221514992918220, 0.999219541204934840, 0.999217564918902570, +0.999215586134826420, 0.999213604852711270, 0.999211621072562230, 0.999209634794383960, 0.999207646018181790, 0.999205654743960390, 0.999203660971724860, 0.999201664701480200, +0.999199665933231280, 0.999197664666983340, 0.999195660902741150, 0.999193654640509910, 0.999191645880294410, 0.999189634622099860, 0.999187620865931270, 0.999185604611793510, +0.999183585859691800, 0.999181564609631150, 0.999179540861616530, 0.999177514615653070, 0.999175485871745870, 0.999173454629899930, 0.999171420890120340, 0.999169384652412230, +0.999167345916780690, 0.999165304683230730, 0.999163260951767440, 0.999161214722396160, 0.999159165995121780, 0.999157114769949390, 0.999155061046884340, 0.999153004825931500, +0.999150946107096320, 0.999148884890383670, 0.999146821175798780, 0.999144754963346980, 0.999142686253033150, 0.999140615044862620, 0.999138541338840610, 0.999136465134972230, +0.999134386433262690, 0.999132305233717210, 0.999130221536340900, 0.999128135341139090, 0.999126046648116880, 0.999123955457279610, 0.999121861768632380, 0.999119765582180630, +0.999117666897929360, 0.999115565715884000, 0.999113462036049670, 0.999111355858431690, 0.999109247183035290, 0.999107136009865780, 0.999105022338928510, 0.999102906170228680, +0.999100787503771510, 0.999098666339562350, 0.999096542677606610, 0.999094416517909530, 0.999092287860476320, 0.999090156705312430, 0.999088023052423170, 0.999085886901813770, +0.999083748253489780, 0.999081607107456300, 0.999079463463718900, 0.999077317322282780, 0.999075168683153380, 0.999073017546336040, 0.999070863911836190, 0.999068707779659170, +0.999066549149810410, 0.999064388022295250, 0.999062224397119110, 0.999060058274287450, 0.999057889653805600, 0.999055718535679090, 0.999053544919913160, 0.999051368806513460, +0.999049190195485330, 0.999047009086834300, 0.999044825480565610, 0.999042639376684920, 0.999040450775197650, 0.999038259676109150, 0.999036066079425080, 0.999033869985150870, +0.999031671393291960, 0.999029470303853920, 0.999027266716842170, 0.999025060632262150, 0.999022852050119650, 0.999020640970419870, 0.999018427393168600, 0.999016211318371260, +0.999013992746033310, 0.999011771676160510, 0.999009548108758190, 0.999007322043831910, 0.999005093481387440, 0.999002862421430220, 0.999000628863965900, 0.998998392808999940, +0.998996154256537980, 0.998993913206585700, 0.998991669659148540, 0.998989423614232260, 0.998987175071842430, 0.998984924031984690, 0.998982670494664600, 0.998980414459887830, +0.998978155927660040, 0.998975894897986880, 0.998973631370873920, 0.998971365346326910, 0.998969096824351530, 0.998966825804953440, 0.998964552288138190, 0.998962276273911650, +0.998959997762279280, 0.998957716753247070, 0.998955433246820460, 0.998953147243005320, 0.998950858741807330, 0.998948567743232150, 0.998946274247285550, 0.998943978253973300, +0.998941679763301060, 0.998939378775274610, 0.998937075289899830, 0.998934769307182280, 0.998932460827127830, 0.998930149849742150, 0.998927836375031130, 0.998925520403000640, +0.998923201933656250, 0.998920880967003820, 0.998918557503049250, 0.998916231541798210, 0.998913903083256670, 0.998911572127430310, 0.998909238674325130, 0.998906902723946780, +0.998904564276301140, 0.998902223331394110, 0.998899879889231570, 0.998897533949819280, 0.998895185513163140, 0.998892834579269140, 0.998890481148142940, 0.998888125219790650, +0.998885766794217920, 0.998883405871430870, 0.998881042451435270, 0.998878676534237010, 0.998876308119842180, 0.998873937208256460, 0.998871563799486050, 0.998869187893536630, +0.998866809490414180, 0.998864428590124810, 0.998862045192674300, 0.998859659298068750, 0.998857270906313930, 0.998854880017416070, 0.998852486631380930, 0.998850090748214630, +0.998847692367923030, 0.998845291490512270, 0.998842888115988200, 0.998840482244356950, 0.998838073875624510, 0.998835663009796980, 0.998833249646880140, 0.998830833786880200, +0.998828415429803270, 0.998825994575655240, 0.998823571224442210, 0.998821145376170280, 0.998818717030845460, 0.998816286188473850, 0.998813852849061550, 0.998811417012614560, +0.998808978679139090, 0.998806537848641150, 0.998804094521126840, 0.998801648696602370, 0.998799200375073750, 0.998796749556547180, 0.998794296241028560, 0.998791840428524310, +0.998789382119040450, 0.998786921312583180, 0.998784458009158600, 0.998781992208772840, 0.998779523911432100, 0.998777053117142600, 0.998774579825910340, 0.998772104037741750, +0.998769625752642940, 0.998767144970619910, 0.998764661691679210, 0.998762175915826720, 0.998759687643068770, 0.998757196873411690, 0.998754703606861580, 0.998752207843424670, +0.998749709583107270, 0.998747208825915610, 0.998744705571856020, 0.998742199820934600, 0.998739691573157560, 0.998737180828531360, 0.998734667587062310, 0.998732151848756520, +0.998729633613620330, 0.998727112881660050, 0.998724589652882020, 0.998722063927292570, 0.998719535704897910, 0.998717004985704370, 0.998714471769718280, 0.998711936056946080, +0.998709397847394100, 0.998706857141068550, 0.998704313937975870, 0.998701768238122400, 0.998699220041514570, 0.998696669348158590, 0.998694116158061030, 0.998691560471228090, +0.998689002287666330, 0.998686441607382070, 0.998683878430381640, 0.998681312756671490, 0.998678744586258160, 0.998676173919147870, 0.998673600755347170, 0.998671025094862500, +0.998668446937700290, 0.998665866283867000, 0.998663283133368940, 0.998660697486212780, 0.998658109342404730, 0.998655518701951460, 0.998652925564859410, 0.998650329931135120, +0.998647731800784920, 0.998645131173815480, 0.998642528050233120, 0.998639922430044400, 0.998637314313255970, 0.998634703699874170, 0.998632090589905760, 0.998629474983356970, +0.998626856880234560, 0.998624236280545090, 0.998621613184294880, 0.998618987591490700, 0.998616359502139010, 0.998613728916246560, 0.998611095833819680, 0.998608460254865050, +0.998605822179389310, 0.998603181607399030, 0.998600538538900740, 0.998597892973901110, 0.998595244912406700, 0.998592594354424270, 0.998589941299960370, 0.998587285749021560, +0.998584627701614600, 0.998581967157745940, 0.998579304117422460, 0.998576638580650710, 0.998573970547437350, 0.998571300017789150, 0.998568626991712560, 0.998565951469214450, +0.998563273450301490, 0.998560592934980340, 0.998557909923257770, 0.998555224415140330, 0.998552536410634790, 0.998549845909748050, 0.998547152912486640, 0.998544457418857330, +0.998541759428866920, 0.998539058942522040, 0.998536355959829480, 0.998533650480796120, 0.998530942505428620, 0.998528232033733750, 0.998525519065718290, 0.998522803601389120, +0.998520085640752900, 0.998517365183816400, 0.998514642230586500, 0.998511916781069990, 0.998509188835273730, 0.998506458393204510, 0.998503725454869100, 0.998500990020274480, +0.998498252089427220, 0.998495511662334410, 0.998492768739002830, 0.998490023319439370, 0.998487275403650790, 0.998484524991643970, 0.998481772083425920, 0.998479016679003520, +0.998476258778383420, 0.998473498381572730, 0.998470735488578340, 0.998467970099407020, 0.998465202214065870, 0.998462431832561670, 0.998459658954901410, 0.998456883581091970, +0.998454105711140350, 0.998451325345053430, 0.998448542482838210, 0.998445757124501680, 0.998442969270050720, 0.998440178919492330, 0.998437386072833500, 0.998434590730081230, +0.998431792891242510, 0.998428992556324220, 0.998426189725333480, 0.998423384398277270, 0.998420576575162700, 0.998417766255996540, 0.998414953440786010, 0.998412138129538110, +0.998409320322259820, 0.998406500018958360, 0.998403677219640520, 0.998400851924313600, 0.998398024132984400, 0.998395193845660330, 0.998392361062348080, 0.998389525783055070, +0.998386688007788180, 0.998383847736554530, 0.998381004969361330, 0.998378159706215680, 0.998375311947124480, 0.998372461692095150, 0.998369608941134470, 0.998366753694249990, +0.998363895951448480, 0.998361035712737270, 0.998358172978123460, 0.998355307747614270, 0.998352440021216810, 0.998349569798938190, 0.998346697080785610, 0.998343821866766400, +0.998340944156887570, 0.998338063951156430, 0.998335181249580090, 0.998332296052165780, 0.998329408358920810, 0.998326518169852290, 0.998323625484967340, 0.998320730304273480, +0.998317832627777730, 0.998314932455487410, 0.998312029787409850, 0.998309124623552150, 0.998306216963921630, 0.998303306808525530, 0.998300394157371150, 0.998297479010465840, +0.998294561367816800, 0.998291641229431480, 0.998288718595316870, 0.998285793465480630, 0.998282865839929870, 0.998279935718671800, 0.998277003101713970, 0.998274067989063710, +0.998271130380728230, 0.998268190276714980, 0.998265247677031180, 0.998262302581684250, 0.998259354990681640, 0.998256404904030560, 0.998253452321738450, 0.998250497243812870, +0.998247539670260920, 0.998244579601090140, 0.998241617036307870, 0.998238651975921650, 0.998235684419938710, 0.998232714368366580, 0.998229741821212710, 0.998226766778484540, +0.998223789240189400, 0.998220809206334710, 0.998217826676928040, 0.998214841651976830, 0.998211854131488500, 0.998208864115470500, 0.998205871603930370, 0.998202876596875680, +0.998199879094313620, 0.998196879096251990, 0.998193876602698090, 0.998190871613659490, 0.998187864129143730, 0.998184854149158360, 0.998181841673710820, 0.998178826702808660, +0.998175809236459430, 0.998172789274670680, 0.998169766817449950, 0.998166741864804810, 0.998163714416742790, 0.998160684473271550, 0.998157652034398550, 0.998154617100131540, +0.998151579670477850, 0.998148539745445260, 0.998145497325041320, 0.998142452409273570, 0.998139404998149790, 0.998136355091677420, 0.998133302689864220, 0.998130247792717750, +0.998127190400245670, 0.998124130512455630, 0.998121068129355080, 0.998118003250952120, 0.998114935877253970, 0.998111866008268620, 0.998108793644003510, 0.998105718784466520, +0.998102641429665090, 0.998099561579607110, 0.998096479234300230, 0.998093394393752220, 0.998090307057970640, 0.998087217226963360, 0.998084124900737950, 0.998081030079302380, +0.998077932762664100, 0.998074832950830990, 0.998071730643810830, 0.998068625841611380, 0.998065518544240300, 0.998062408751705490, 0.998059296464014590, 0.998056181681175490, +0.998053064403195970, 0.998049944630083670, 0.998046822361846610, 0.998043697598492430, 0.998040570340029130, 0.998037440586464260, 0.998034308337805930, 0.998031173594061680, +0.998028036355239620, 0.998024896621347410, 0.998021754392392930, 0.998018609668384070, 0.998015462449328820, 0.998012312735234830, 0.998009160526110000, 0.998006005821962310, +0.998002848622799530, 0.997999688928629780, 0.997996526739460710, 0.997993362055300310, 0.997990194876156590, 0.997987025202037300, 0.997983853032950560, 0.997980678368904140, +0.997977501209905920, 0.997974321555963990, 0.997971139407086370, 0.997967954763280820, 0.997964767624555330, 0.997961577990918000, 0.997958385862376730, 0.997955191238939500, +0.997951994120614190, 0.997948794507409030, 0.997945592399331780, 0.997942387796390550, 0.997939180698593440, 0.997935971105948340, 0.997932759018463340, 0.997929544436146340, +0.997926327359005550, 0.997923107787048960, 0.997919885720284560, 0.997916661158720460, 0.997913434102364770, 0.997910204551225370, 0.997906972505310570, 0.997903737964628280, +0.997900500929186700, 0.997897261398993820, 0.997894019374057750, 0.997890774854386710, 0.997887527839988690, 0.997884278330871900, 0.997881026327044340, 0.997877771828514230, +0.997874514835289770, 0.997871255347378970, 0.997867993364790040, 0.997864728887531080, 0.997861461915610310, 0.997858192449035950, 0.997854920487815990, 0.997851646031958860, +0.997848369081472560, 0.997845089636365310, 0.997841807696645430, 0.997838523262320920, 0.997835236333400210, 0.997831946909891410, 0.997828654991802620, 0.997825360579142170, +0.997822063671918500, 0.997818764270139600, 0.997815462373813690, 0.997812157982949310, 0.997808851097554350, 0.997805541717637360, 0.997802229843206430, 0.997798915474270020, +0.997795598610836330, 0.997792279252913580, 0.997788957400510210, 0.997785633053634440, 0.997782306212294470, 0.997778976876498860, 0.997775645046255710, 0.997772310721573460, +0.997768973902460550, 0.997765634588925090, 0.997762292780975610, 0.997758948478620340, 0.997755601681867830, 0.997752252390726070, 0.997748900605203830, 0.997745546325309430, +0.997742189551050980, 0.997738830282437260, 0.997735468519476370, 0.997732104262176730, 0.997728737510546800, 0.997725368264595120, 0.997721996524330020, 0.997718622289759940, +0.997715245560893300, 0.997711866337738560, 0.997708484620304150, 0.997705100408598500, 0.997701713702630060, 0.997698324502407470, 0.997694932807938970, 0.997691538619233100, +0.997688141936298510, 0.997684742759143540, 0.997681341087776620, 0.997677936922206410, 0.997674530262441240, 0.997671121108489880, 0.997667709460360760, 0.997664295318062220, +0.997660878681603020, 0.997657459550991720, 0.997654037926236640, 0.997650613807346430, 0.997647187194329770, 0.997643758087195080, 0.997640326485951130, 0.997636892390606270, +0.997633455801169130, 0.997630016717648390, 0.997626575140052710, 0.997623131068390400, 0.997619684502670360, 0.997616235442901120, 0.997612783889091360, 0.997609329841249610, +0.997605873299384440, 0.997602414263504710, 0.997598952733618760, 0.997595488709735580, 0.997592022191863710, 0.997588553180011720, 0.997585081674188360, 0.997581607674402290, +0.997578131180662190, 0.997574652192976810, 0.997571170711354700, 0.997567686735804650, 0.997564200266335520, 0.997560711302955870, 0.997557219845674360, 0.997553725894499870, +0.997550229449441050, 0.997546730510506570, 0.997543229077705320, 0.997539725151046050, 0.997536218730537440, 0.997532709816188250, 0.997529198408007360, 0.997525684506003430, +0.997522168110185240, 0.997518649220561660, 0.997515127837141470, 0.997511603959933430, 0.997508077588946440, 0.997504548724189260, 0.997501017365670760, 0.997497483513399620, +0.997493947167384820, 0.997490408327635030, 0.997486866994159340, 0.997483323166966420, 0.997479776846065260, 0.997476228031464630, 0.997472676723173410, 0.997469122921200490, +0.997465566625554740, 0.997462007836245170, 0.997458446553280530, 0.997454882776669830, 0.997451316506421830, 0.997447747742545630, 0.997444176485050020, 0.997440602733943970, +0.997437026489236380, 0.997433447750936230, 0.997429866519052410, 0.997426282793594020, 0.997422696574569940, 0.997419107861989060, 0.997415516655860480, 0.997411922956193080, +0.997408326762995730, 0.997404728076277670, 0.997401126896047870, 0.997397523222315230, 0.997393917055088730, 0.997390308394377480, 0.997386697240190360, 0.997383083592536580, +0.997379467451425030, 0.997375848816864920, 0.997372227688865130, 0.997368604067434770, 0.997364977952582830, 0.997361349344318530, 0.997357718242650850, 0.997354084647588790, +0.997350448559141680, 0.997346809977318280, 0.997343168902128040, 0.997339525333579720, 0.997335879271682660, 0.997332230716445940, 0.997328579667878580, 0.997324926125989660, +0.997321270090788640, 0.997317611562284380, 0.997313950540485990, 0.997310287025402810, 0.997306621017043930, 0.997302952515418450, 0.997299281520535600, 0.997295608032404580, +0.997291932051034500, 0.997288253576434580, 0.997284572608614140, 0.997280889147582170, 0.997277203193348010, 0.997273514745920740, 0.997269823805309710, 0.997266130371524230, +0.997262434444573410, 0.997258736024466460, 0.997255035111212720, 0.997251331704821280, 0.997247625805301570, 0.997243917412662830, 0.997240206526914250, 0.997236493148065170, +0.997232777276124920, 0.997229058911102580, 0.997225338053007730, 0.997221614701849560, 0.997217888857637290, 0.997214160520380140, 0.997210429690087770, 0.997206696366769400, +0.997202960550434110, 0.997199222241091590, 0.997195481438750920, 0.997191738143421550, 0.997187992355112800, 0.997184244073834100, 0.997180493299594790, 0.997176740032404200, +0.997172984272271860, 0.997169226019206990, 0.997165465273219140, 0.997161702034317530, 0.997157936302511590, 0.997154168077810990, 0.997150397360224930, 0.997146624149762850, +0.997142848446434190, 0.997139070250248390, 0.997135289561215000, 0.997131506379343340, 0.997127720704642840, 0.997123932537123170, 0.997120141876793540, 0.997116348723663730, +0.997112553077742940, 0.997108754939040720, 0.997104954307566740, 0.997101151183330310, 0.997097345566340890, 0.997093537456608230, 0.997089726854141660, 0.997085913758950840, +0.997082098171045320, 0.997078280090434420, 0.997074459517127810, 0.997070636451135030, 0.997066810892465740, 0.997062982841129490, 0.997059152297135710, 0.997055319260493960, +0.997051483731213990, 0.997047645709305370, 0.997043805194777530, 0.997039962187640240, 0.997036116687903040, 0.997032268695575490, 0.997028418210667340, 0.997024565233188160, +0.997020709763147490, 0.997016851800555100, 0.997012991345420540, 0.997009128397753570, 0.997005262957563750, 0.997001395024860740, 0.996997524599654290, 0.996993651681953970, +0.996989776271769660, 0.996985898369110780, 0.996982017973987110, 0.996978135086408420, 0.996974249706384490, 0.996970361833924960, 0.996966471469039380, 0.996962578611737760, +0.996958683262029630, 0.996954785419924770, 0.996950885085432950, 0.996946982258563930, 0.996943076939327490, 0.996939169127733280, 0.996935258823791190, 0.996931346027510990, +0.996927430738902440, 0.996923512957975210, 0.996919592684739180, 0.996915669919204330, 0.996911744661380220, 0.996907816911276720, 0.996903886668903730, 0.996899953934271000, +0.996896018707388420, 0.996892080988265650, 0.996888140776912790, 0.996884198073339610, 0.996880252877555990, 0.996876305189571600, 0.996872355009396530, 0.996868402337040550, +0.996864447172513550, 0.996860489515825400, 0.996856529366986100, 0.996852566726005420, 0.996848601592893350, 0.996844633967659770, 0.996840663850314670, 0.996836691240867820, +0.996832716139329220, 0.996828738545708860, 0.996824758460016720, 0.996820775882262590, 0.996816790812456670, 0.996812803250608610, 0.996808813196728650, 0.996804820650826650, +0.996800825612912500, 0.996796828082996300, 0.996792828061088150, 0.996788825547197830, 0.996784820541335550, 0.996780813043511070, 0.996776803053734730, 0.996772790572016180, +0.996768775598365740, 0.996764758132793420, 0.996760738175309190, 0.996756715725923060, 0.996752690784645230, 0.996748663351485600, 0.996744633426454360, 0.996740601009561410, +0.996736566100817070, 0.996732528700231320, 0.996728488807814280, 0.996724446423575940, 0.996720401547526500, 0.996716354179676080, 0.996712304320034770, 0.996708251968612680, +0.996704197125419910, 0.996700139790466790, 0.996696079963763190, 0.996692017645319450, 0.996687952835145660, 0.996683885533252050, 0.996679815739648590, 0.996675743454345730, +0.996671668677353460, 0.996667591408682000, 0.996663511648341550, 0.996659429396342330, 0.996655344652694560, 0.996651257417408450, 0.996647167690494110, 0.996643075471961850, +0.996638980761822000, 0.996634883560084670, 0.996630783866760180, 0.996626681681858640, 0.996622577005390480, 0.996618469837365790, 0.996614360177794920, 0.996610248026688180, +0.996606133384055790, 0.996602016249908180, 0.996597896624255460, 0.996593774507107950, 0.996589649898476090, 0.996585522798369980, 0.996581393206800170, 0.996577261123776870, +0.996573126549310410, 0.996568989483411110, 0.996564849926089400, 0.996560707877355510, 0.996556563337219870, 0.996552416305692800, 0.996548266782784630, 0.996544114768505910, +0.996539960262866840, 0.996535803265877980, 0.996531643777549440, 0.996527481797891970, 0.996523317326915570, 0.996519150364631010, 0.996514980911048620, 0.996510808966178720, +0.996506634530031850, 0.996502457602618350, 0.996498278183948650, 0.996494096274033400, 0.996489911872882720, 0.996485724980507360, 0.996481535596917770, 0.996477343722124260, +0.996473149356137400, 0.996468952498967610, 0.996464753150625550, 0.996460551311121550, 0.996456346980466150, 0.996452140158669900, 0.996447930845743230, 0.996443719041696820, +0.996439504746541190, 0.996435287960286690, 0.996431068682943950, 0.996426846914523550, 0.996422622655036120, 0.996418395904491990, 0.996414166662902060, 0.996409934930276520, +0.996405700706626260, 0.996401463991961720, 0.996397224786293560, 0.996392983089632200, 0.996388738901988540, 0.996384492223373000, 0.996380243053796240, 0.996375991393268820, +0.996371737241801500, 0.996367480599404720, 0.996363221466089240, 0.996358959841865840, 0.996354695726744950, 0.996350429120737350, 0.996346160023853680, 0.996341888436104610, +0.996337614357500790, 0.996333337788053000, 0.996329058727771670, 0.996324777176667900, 0.996320493134752130, 0.996316206602035130, 0.996311917578527550, 0.996307626064240280, +0.996303332059183980, 0.996299035563369180, 0.996294736576806890, 0.996290435099507770, 0.996286131131482570, 0.996281824672741960, 0.996277515723296920, 0.996273204283158020, +0.996268890352336120, 0.996264573930841890, 0.996260255018686310, 0.996255933615880160, 0.996251609722434090, 0.996247283338358990, 0.996242954463665730, 0.996238623098365080, +0.996234289242467930, 0.996229952895984930, 0.996225614058927070, 0.996221272731305230, 0.996216928913130180, 0.996212582604412810, 0.996208233805164100, 0.996203882515394710, +0.996199528735115520, 0.996195172464337530, 0.996190813703071720, 0.996186452451328860, 0.996182088709119840, 0.996177722476455640, 0.996173353753347040, 0.996168982539805130, +0.996164608835840680, 0.996160232641464800, 0.996155853956688260, 0.996151472781522160, 0.996147089115977380, 0.996142702960064910, 0.996138314313795630, 0.996133923177180520, +0.996129529550230600, 0.996125133432956830, 0.996120734825370340, 0.996116333727481980, 0.996111930139302770, 0.996107524060843800, 0.996103115492115940, 0.996098704433130310, +0.996094290883897890, 0.996089874844429790, 0.996085456314736990, 0.996081035294830500, 0.996076611784721510, 0.996072185784421030, 0.996067757293939930, 0.996063326313289530, +0.996058892842480730, 0.996054456881524830, 0.996050018430432730, 0.996045577489215630, 0.996041134057884530, 0.996036688136450630, 0.996032239724924940, 0.996027788823318660, +0.996023335431642900, 0.996018879549908860, 0.996014421178127660, 0.996009960316310280, 0.996005496964468160, 0.996001031122612180, 0.995996562790753550, 0.995992091968903700, +0.995987618657073530, 0.995983142855274340, 0.995978664563517250, 0.995974183781813570, 0.995969700510174420, 0.995965214748610990, 0.995960726497134410, 0.995956235755756090, +0.995951742524487260, 0.995947246803339010, 0.995942748592322680, 0.995938247891449470, 0.995933744700730710, 0.995929239020177490, 0.995924730849801150, 0.995920220189613010, +0.995915707039624400, 0.995911191399846410, 0.995906673270290480, 0.995902152650967930, 0.995897629541889980, 0.995893103943067850, 0.995888575854513070, 0.995884045276236750, +0.995879512208250440, 0.995874976650565240, 0.995870438603192690, 0.995865898066144010, 0.995861355039430630, 0.995856809523063770, 0.995852261517054860, 0.995847711021415450, +0.995843158036156640, 0.995838602561289980, 0.995834044596826900, 0.995829484142778610, 0.995824921199156550, 0.995820355765972280, 0.995815787843237100, 0.995811217430962460, +0.995806644529159790, 0.995802069137840420, 0.995797491257016000, 0.995792910886697750, 0.995788328026897210, 0.995783742677625930, 0.995779154838895340, 0.995774564510716780, +0.995769971693101770, 0.995765376386062000, 0.995760778589608650, 0.995756178303753400, 0.995751575528507570, 0.995746970263882920, 0.995742362509890900, 0.995737752266542930, +0.995733139533850560, 0.995728524311825350, 0.995723906600478830, 0.995719286399822430, 0.995714663709867940, 0.995710038530626780, 0.995705410862110620, 0.995700780704330770, +0.995696148057299110, 0.995691512921026980, 0.995686875295526130, 0.995682235180808010, 0.995677592576884260, 0.995672947483766670, 0.995668299901466660, 0.995663649829995890, +0.995658997269366020, 0.995654342219588710, 0.995649684680675500, 0.995645024652637930, 0.995640362135487900, 0.995635697129237050, 0.995631029633896940, 0.995626359649479210, +0.995621687175995530, 0.995617012213457770, 0.995612334761877270, 0.995607654821266120, 0.995602972391635750, 0.995598287472997940, 0.995593600065364570, 0.995588910168747070, +0.995584217783157310, 0.995579522908606960, 0.995574825545107790, 0.995570125692671560, 0.995565423351310150, 0.995560718521035120, 0.995556011201858220, 0.995551301393791330, +0.995546589096846240, 0.995541874311034580, 0.995537157036368360, 0.995532437272859120, 0.995527715020518840, 0.995522990279359310, 0.995518263049392280, 0.995513533330629640, +0.995508801123083150, 0.995504066426764480, 0.995499329241685830, 0.995494589567858860, 0.995489847405295340, 0.995485102754007260, 0.995480355614006380, 0.995475605985304600, +0.995470853867913900, 0.995466099261845930, 0.995461342167112790, 0.995456582583726270, 0.995451820511698340, 0.995447055951040880, 0.995442288901765670, 0.995437519363884800, +0.995432747337410160, 0.995427972822353620, 0.995423195818727180, 0.995418416326542710, 0.995413634345812200, 0.995408849876547650, 0.995404062918760930, 0.995399273472464040, +0.995394481537668960, 0.995389687114387690, 0.995384890202632320, 0.995380090802414630, 0.995375288913746710, 0.995370484536640570, 0.995365677671108170, 0.995360868317161640, +0.995356056474812840, 0.995351242144074000, 0.995346425324957100, 0.995341606017474120, 0.995336784221637070, 0.995331959937458040, 0.995327133164949140, 0.995322303904122350, +0.995317472154989890, 0.995312637917563750, 0.995307801191856020, 0.995302961977878710, 0.995298120275644130, 0.995293276085164160, 0.995288429406451010, 0.995283580239516690, +0.995278728584373500, 0.995273874441033550, 0.995269017809508830, 0.995264158689811550, 0.995259297081953930, 0.995254432985948070, 0.995249566401806060, 0.995244697329540240, +0.995239825769162590, 0.995234951720685430, 0.995230075184120880, 0.995225196159481240, 0.995220314646778510, 0.995215430646025020, 0.995210544157232760, 0.995205655180414370, +0.995200763715581750, 0.995195869762747320, 0.995190973321923080, 0.995186074393121570, 0.995181172976354780, 0.995176269071635030, 0.995171362678974550, 0.995166453798385750, +0.995161542429880860, 0.995156628573472090, 0.995151712229171760, 0.995146793396992080, 0.995141872076945490, 0.995136948269044090, 0.995132021973300420, 0.995127093189726700, +0.995122161918335250, 0.995117228159138390, 0.995112291912148450, 0.995107353177377860, 0.995102411954838730, 0.995097468244543590, 0.995092522046504890, 0.995087573360734830, +0.995082622187245860, 0.995077668526050400, 0.995072712377160660, 0.995067753740589200, 0.995062792616348220, 0.995057829004450390, 0.995052862904907910, 0.995047894317733330, +0.995042923242939080, 0.995037949680537490, 0.995032973630541000, 0.995027995092962030, 0.995023014067813020, 0.995018030555106630, 0.995013044554855060, 0.995008056067070880, +0.995003065091766610, 0.994998071628954710, 0.994993075678647590, 0.994988077240857800, 0.994983076315597680, 0.994978072902880100, 0.994973067002717150, 0.994968058615121610, +0.994963047740106020, 0.994958034377682710, 0.994953018527864330, 0.994948000190663320, 0.994942979366092330, 0.994937956054163910, 0.994932930254890710, 0.994927901968285070, +0.994922871194359740, 0.994917837933127270, 0.994912802184600100, 0.994907763948790880, 0.994902723225712380, 0.994897680015377040, 0.994892634317797510, 0.994887586132986330, +0.994882535460956290, 0.994877482301719910, 0.994872426655289740, 0.994867368521678450, 0.994862307900898800, 0.994857244792963450, 0.994852179197884930, 0.994847111115675920, +0.994842040546349280, 0.994836967489917460, 0.994831891946393100, 0.994826813915789090, 0.994821733398118080, 0.994816650393392730, 0.994811564901625810, 0.994806476922829970, +0.994801386457017880, 0.994796293504202290, 0.994791198064395980, 0.994786100137611710, 0.994780999723862140, 0.994775896823160140, 0.994770791435518390, 0.994765683560949630, +0.994760573199466760, 0.994755460351082310, 0.994750345015809280, 0.994745227193660430, 0.994740106884648420, 0.994734984088786240, 0.994729858806086550, 0.994724731036562230, +0.994719600780226030, 0.994714468037090850, 0.994709332807169440, 0.994704195090474810, 0.994699054887019710, 0.994693912196816910, 0.994688767019879410, 0.994683619356219850, +0.994678469205851350, 0.994673316568786550, 0.994668161445038560, 0.994663003834620140, 0.994657843737544290, 0.994652681153823770, 0.994647516083471570, 0.994642348526500570, +0.994637178482923660, 0.994632005952753810, 0.994626830936004010, 0.994621653432687050, 0.994616473442816010, 0.994611290966403770, 0.994606106003463330, 0.994600918554007670, +0.994595728618049570, 0.994590536195602230, 0.994585341286678530, 0.994580143891291460, 0.994574944009454120, 0.994569741641179390, 0.994564536786480270, 0.994559329445369840, +0.994554119617861000, 0.994548907303966940, 0.994543692503700560, 0.994538475217075060, 0.994533255444103310, 0.994528033184798430, 0.994522808439173400, 0.994517581207241320, +0.994512351489015400, 0.994507119284508630, 0.994501884593734010, 0.994496647416704630, 0.994491407753433700, 0.994486165603934210, 0.994480920968219380, 0.994475673846302090, +0.994470424238195760, 0.994465172143913280, 0.994459917563467970, 0.994454660496872810, 0.994449400944141030, 0.994444138905285710, 0.994438874380319970, 0.994433607369257120, +0.994428337872110270, 0.994423065888892620, 0.994417791419617280, 0.994412514464297460, 0.994407235022946260, 0.994401953095577110, 0.994396668682202890, 0.994391381782837150, +0.994386092397492980, 0.994380800526183490, 0.994375506168922010, 0.994370209325721840, 0.994364909996596100, 0.994359608181558110, 0.994354303880620960, 0.994348997093798200, +0.994343687821102940, 0.994338376062548380, 0.994333061818147960, 0.994327745087914880, 0.994322425871862480, 0.994317104170003850, 0.994311779982352540, 0.994306453308921760, +0.994301124149724940, 0.994295792504775290, 0.994290458374086140, 0.994285121757670810, 0.994279782655542730, 0.994274441067715120, 0.994269096994201410, 0.994263750435015030, +0.994258401390169190, 0.994253049859677440, 0.994247695843553100, 0.994242339341809390, 0.994236980354459950, 0.994231618881517900, 0.994226254922996880, 0.994220888478910330, +0.994215519549271450, 0.994210148134093810, 0.994204774233390820, 0.994199397847175810, 0.994194018975462330, 0.994188637618263820, 0.994183253775593690, 0.994177867447465500, +0.994172478633892580, 0.994167087334888570, 0.994161693550466800, 0.994156297280640700, 0.994150898525423820, 0.994145497284829820, 0.994140093558872010, 0.994134687347564050, +0.994129278650919380, 0.994123867468951430, 0.994118453801673850, 0.994113037649100080, 0.994107619011243780, 0.994102197888118380, 0.994096774279737530, 0.994091348186114780, +0.994085919607263560, 0.994080488543197640, 0.994075054993930450, 0.994069618959475540, 0.994064180439846680, 0.994058739435057400, 0.994053295945121260, 0.994047849970051910, +0.994042401509862890, 0.994036950564567870, 0.994031497134180490, 0.994026041218714180, 0.994020582818182950, 0.994015121932600220, 0.994009658561979760, 0.994004192706335110, +0.993998724365679930, 0.993993253540027990, 0.993987780229392830, 0.993982304433788320, 0.993976826153228020, 0.993971345387725690, 0.993965862137294990, 0.993960376401949670, +0.993954888181703300, 0.993949397476569850, 0.993943904286562650, 0.993938408611695910, 0.993932910451983060, 0.993927409807437990, 0.993921906678074450, 0.993916401063906110, +0.993910892964946720, 0.993905382381210070, 0.993899869312709900, 0.993894353759460230, 0.993888835721474570, 0.993883315198766940, 0.993877792191350860, 0.993872266699240450, +0.993866738722449240, 0.993861208260991220, 0.993855675314880170, 0.993850139884130070, 0.993844601968754460, 0.993839061568767450, 0.993833518684182790, 0.993827973315014270, +0.993822425461275860, 0.993816875122981220, 0.993811322300144570, 0.993805766992779560, 0.993800209200900180, 0.993794648924520300, 0.993789086163653690, 0.993783520918314460, +0.993777953188516250, 0.993772382974273390, 0.993766810275599430, 0.993761235092508580, 0.993755657425014480, 0.993750077273131360, 0.993744494636872980, 0.993738909516253430, +0.993733321911286490, 0.993727731821986370, 0.993722139248366830, 0.993716544190441970, 0.993710946648225790, 0.993705346621732270, 0.993699744110975280, 0.993694139115969040, +0.993688531636727320, 0.993682921673264330, 0.993677309225594050, 0.993671694293730480, 0.993666076877687710, 0.993660456977479730, 0.993654834593120650, 0.993649209724624340, +0.993643582372005120, 0.993637952535276980, 0.993632320214453910, 0.993626685409550010, 0.993621048120579500, 0.993615408347556350, 0.993609766090494560, 0.993604121349408340, +0.993598474124311900, 0.993592824415219340, 0.993587172222144650, 0.993581517545102040, 0.993575860384105610, 0.993570200739169570, 0.993564538610307910, 0.993558873997535060, +0.993553206900865020, 0.993547537320311870, 0.993541865255889940, 0.993536190707613340, 0.993530513675496270, 0.993524834159552950, 0.993519152159797360, 0.993513467676244040, +0.993507780708907110, 0.993502091257800650, 0.993496399322938980, 0.993490704904336330, 0.993485008002006900, 0.993479308615964900, 0.993473606746224540, 0.993467902392800360, +0.993462195555706360, 0.993456486234956860, 0.993450774430566170, 0.993445060142548520, 0.993439343370918220, 0.993433624115689470, 0.993427902376876840, 0.993422178154494410, +0.993416451448556500, 0.993410722259077450, 0.993404990586071570, 0.993399256429553290, 0.993393519789536830, 0.993387780666036500, 0.993382039059066750, 0.993376294968641990, +0.993370548394776450, 0.993364799337484560, 0.993359047796780640, 0.993353293772679110, 0.993347537265194420, 0.993341778274340670, 0.993336016800132620, 0.993330252842584580, +0.993324486401710780, 0.993318717477525870, 0.993312946070044170, 0.993307172179280110, 0.993301395805248010, 0.993295616947962420, 0.993289835607437890, 0.993284051783688730, +0.993278265476729480, 0.993272476686574590, 0.993266685413238480, 0.993260891656735590, 0.993255095417080460, 0.993249296694287630, 0.993243495488371650, 0.993237691799346840, +0.993231885627227860, 0.993226076972029140, 0.993220265833765210, 0.993214452212450530, 0.993208636108099730, 0.993202817520727480, 0.993196996450348090, 0.993191172896976340, +0.993185346860626540, 0.993179518341313460, 0.993173687339051540, 0.993167853853855200, 0.993162017885739430, 0.993156179434718680, 0.993150338500807360, 0.993144495084020250, +0.993138649184371890, 0.993132800801876940, 0.993126949936549930, 0.993121096588405530, 0.993115240757458380, 0.993109382443723150, 0.993103521647214490, 0.993097658367947060, +0.993091792605935500, 0.993085924361194360, 0.993080053633738410, 0.993074180423582420, 0.993068304730740930, 0.993062426555228690, 0.993056545897060380, 0.993050662756250760, +0.993044777132814360, 0.993038889026766180, 0.993032998438120540, 0.993027105366892540, 0.993021209813096830, 0.993015311776748070, 0.993009411257861020, 0.993003508256450450, +0.992997602772531020, 0.992991694806117710, 0.992985784357225070, 0.992979871425867970, 0.992973956012061290, 0.992968038115819680, 0.992962117737157920, 0.992956194876090880, +0.992950269532633430, 0.992944341706800130, 0.992938411398606170, 0.992932478608066100, 0.992926543335194810, 0.992920605580007280, 0.992914665342518150, 0.992908722622742320, +0.992902777420694770, 0.992896829736390150, 0.992890879569843570, 0.992884926921069780, 0.992878971790083660, 0.992873014176900100, 0.992867054081533970, 0.992861091504000260, +0.992855126444313730, 0.992849158902489480, 0.992843188878542280, 0.992837216372487230, 0.992831241384339090, 0.992825263914112740, 0.992819283961823280, 0.992813301527485700, +0.992807316611114650, 0.992801329212725570, 0.992795339332332990, 0.992789346969952140, 0.992783352125597980, 0.992777354799285310, 0.992771354991029310, 0.992765352700844980, +0.992759347928747090, 0.992753340674750960, 0.992747330938871570, 0.992741318721123700, 0.992735304021522660, 0.992729286840083320, 0.992723267176820690, 0.992717245031749850, +0.992711220404886020, 0.992705193296244070, 0.992699163705839220, 0.992693131633686440, 0.992687097079800850, 0.992681060044197430, 0.992675020526891380, 0.992668978527897710, +0.992662934047231720, 0.992656887084908400, 0.992650837640942860, 0.992644785715350200, 0.992638731308145510, 0.992632674419344110, 0.992626615048960990, 0.992620553197011150, +0.992614488863510110, 0.992608422048472880, 0.992602352751914550, 0.992596280973850330, 0.992590206714295430, 0.992584129973264950, 0.992578050750774100, 0.992571969046838200, +0.992565884861472460, 0.992559798194691870, 0.992553709046511860, 0.992547617416947640, 0.992541523306014310, 0.992535426713727190, 0.992529327640101380, 0.992523226085152310, +0.992517122048895310, 0.992511015531345350, 0.992504906532517990, 0.992498795052428220, 0.992492681091091570, 0.992486564648523140, 0.992480445724738260, 0.992474324319752350, +0.992468200433580640, 0.992462074066238430, 0.992455945217741050, 0.992449813888103830, 0.992443680077341960, 0.992437543785470890, 0.992431405012506040, 0.992425263758462740, +0.992419120023356190, 0.992412973807201840, 0.992406825110015100, 0.992400673931811310, 0.992394520272605770, 0.992388364132413820, 0.992382205511251110, 0.992376044409132850, +0.992369880826074580, 0.992363714762091510, 0.992357546217199180, 0.992351375191413030, 0.992345201684748270, 0.992339025697220660, 0.992332847228845400, 0.992326666279638060, +0.992320482849614160, 0.992314296938788920, 0.992308108547177990, 0.992301917674796810, 0.992295724321660690, 0.992289528487785400, 0.992283330173186260, 0.992277129377878820, +0.992270926101878500, 0.992264720345200970, 0.992258512107861530, 0.992252301389875860, 0.992246088191259370, 0.992239872512027720, 0.992233654352196460, 0.992227433711781020, +0.992221210590796930, 0.992214984989259860, 0.992208756907185350, 0.992202526344588830, 0.992196293301486070, 0.992190057777892600, 0.992183819773823970, 0.992177579289295840, +0.992171336324323750, 0.992165090878923240, 0.992158842953110080, 0.992152592546899690, 0.992146339660307960, 0.992140084293350320, 0.992133826446042530, 0.992127566118400140, +0.992121303310438800, 0.992115038022174270, 0.992108770253621990, 0.992102500004797940, 0.992096227275717560, 0.992089952066396720, 0.992083674376850970, 0.992077394207095950, +0.992071111557147560, 0.992064826427021320, 0.992058538816732890, 0.992052248726298270, 0.992045956155732990, 0.992039661105052820, 0.992033363574273520, 0.992027063563410860, +0.992020761072480490, 0.992014456101498190, 0.992008148650479700, 0.992001838719440920, 0.991995526308397490, 0.991989211417365290, 0.991982894046360090, 0.991976574195397640, +0.991970251864493720, 0.991963927053664100, 0.991957599762924750, 0.991951269992291440, 0.991944937741779940, 0.991938603011406130, 0.991932265801185760, 0.991925926111134730, +0.991919583941268890, 0.991913239291604020, 0.991906892162156110, 0.991900542552940910, 0.991894190463974420, 0.991887835895272520, 0.991881478846850960, 0.991875119318725740, +0.991868757310912730, 0.991862392823427590, 0.991856025856286740, 0.991849656409505730, 0.991843284483100660, 0.991836910077087300, 0.991830533191481730, 0.991824153826299740, +0.991817771981557290, 0.991811387657270620, 0.991805000853455350, 0.991798611570127610, 0.991792219807303370, 0.991785825564998610, 0.991779428843229230, 0.991773029642011310, +0.991766627961360610, 0.991760223801293580, 0.991753817161825980, 0.991747408042973790, 0.991740996444753110, 0.991734582367179930, 0.991728165810270230, 0.991721746774040120, +0.991715325258505700, 0.991708901263682940, 0.991702474789587950, 0.991696045836236720, 0.991689614403645450, 0.991683180491830130, 0.991676744100806860, 0.991670305230591630, +0.991663863881200760, 0.991657420052650120, 0.991650973744956030, 0.991644524958134490, 0.991638073692201690, 0.991631619947173640, 0.991625163723066530, 0.991618705019896460, +0.991612243837679650, 0.991605780176432310, 0.991599314036170520, 0.991592845416910400, 0.991586374318668140, 0.991579900741460070, 0.991573424685302070, 0.991566946150210570, +0.991560465136201770, 0.991553981643291780, 0.991547495671496800, 0.991541007220833160, 0.991534516291316950, 0.991528022882964490, 0.991521526995791770, 0.991515028629815440, +0.991508527785051500, 0.991502024461516250, 0.991495518659225920, 0.991489010378196810, 0.991482499618445150, 0.991475986379987240, 0.991469470662839300, 0.991462952467017880, +0.991456431792538950, 0.991449908639418950, 0.991443383007674210, 0.991436854897320920, 0.991430324308375630, 0.991423791240854340, 0.991417255694773680, 0.991410717670149990, +0.991404177166999360, 0.991397634185338330, 0.991391088725183220, 0.991384540786550470, 0.991377990369456290, 0.991371437473916980, 0.991364882099949330, 0.991358324247569310, +0.991351763916793580, 0.991345201107638460, 0.991338635820120270, 0.991332068054255560, 0.991325497810060520, 0.991318925087551820, 0.991312349886745880, 0.991305772207659030, +0.991299192050307700, 0.991292609414708430, 0.991286024300877640, 0.991279436708831780, 0.991272846638587280, 0.991266254090160670, 0.991259659063568500, 0.991253061558827200, +0.991246461575953200, 0.991239859114963040, 0.991233254175873270, 0.991226646758700310, 0.991220036863460720, 0.991213424490171020, 0.991206809638847890, 0.991200192309507620, +0.991193572502167000, 0.991186950216842330, 0.991180325453550280, 0.991173698212307390, 0.991167068493130300, 0.991160436296035560, 0.991153801621039830, 0.991147164468159430, +0.991140524837411220, 0.991133882728811640, 0.991127238142377460, 0.991120591078125000, 0.991113941536071130, 0.991107289516232500, 0.991100635018625550, 0.991093978043267040, +0.991087318590173630, 0.991080656659361960, 0.991073992250848470, 0.991067325364650030, 0.991060656000783410, 0.991053984159265160, 0.991047309840111800, 0.991040633043340340, +0.991033953768967190, 0.991027272017009240, 0.991020587787482920, 0.991013901080405210, 0.991007211895792880, 0.991000520233662360, 0.990993826094030640, 0.990987129476914360, +0.990980430382330300, 0.990973728810295110, 0.990967024760825430, 0.990960318233938380, 0.990953609229650480, 0.990946897747978620, 0.990940183788939440, 0.990933467352549830, +0.990926748438826550, 0.990920027047786370, 0.990913303179446150, 0.990906576833822660, 0.990899848010932780, 0.990893116710793280, 0.990886382933420910, 0.990879646678832660, +0.990872907947045300, 0.990866166738075480, 0.990859423051940410, 0.990852676888656750, 0.990845928248241470, 0.990839177130711350, 0.990832423536083250, 0.990825667464374060, +0.990818908915600760, 0.990812147889780110, 0.990805384386929110, 0.990798618407064740, 0.990791849950203750, 0.990785079016363150, 0.990778305605559910, 0.990771529717810790, +0.990764751353132910, 0.990757970511543130, 0.990751187193058440, 0.990744401397695820, 0.990737613125472150, 0.990730822376404530, 0.990724029150509720, 0.990717233447804930, +0.990710435268306930, 0.990703634612033040, 0.990696831478999900, 0.990690025869224830, 0.990683217782724610, 0.990676407219516330, 0.990669594179617090, 0.990662778663043750, +0.990655960669813540, 0.990649140199943430, 0.990642317253450530, 0.990635491830351820, 0.990628663930664290, 0.990621833554405140, 0.990615000701591470, 0.990608165372240170, +0.990601327566368540, 0.990594487283993570, 0.990587644525132480, 0.990580799289802140, 0.990573951578019860, 0.990567101389802750, 0.990560248725167900, 0.990553393584132190, +0.990546535966713270, 0.990539675872927900, 0.990532813302793300, 0.990525948256326780, 0.990519080733545330, 0.990512210734466160, 0.990505338259106470, 0.990498463307483480, +0.990491585879614280, 0.990484705975516190, 0.990477823595206200, 0.990470938738701840, 0.990464051406020010, 0.990457161597178120, 0.990450269312193150, 0.990443374551082670, +0.990436477313863640, 0.990429577600553500, 0.990422675411169460, 0.990415770745728730, 0.990408863604248510, 0.990401953986746130, 0.990395041893238790, 0.990388127323744040, +0.990381210278278860, 0.990374290756860680, 0.990367368759506710, 0.990360444286234380, 0.990353517337061010, 0.990346587912003700, 0.990339656011079980, 0.990332721634307080, +0.990325784781702410, 0.990318845453283410, 0.990311903649067180, 0.990304959369071150, 0.990298012613312850, 0.990291063381809280, 0.990284111674578190, 0.990277157491636920, +0.990270200833002660, 0.990263241698692950, 0.990256280088725130, 0.990249316003116500, 0.990242349441884610, 0.990235380405046880, 0.990228408892620760, 0.990221434904623550, +0.990214458441072810, 0.990207479501985840, 0.990200498087380310, 0.990193514197273420, 0.990186527831682710, 0.990179538990625720, 0.990172547674119890, 0.990165553882182750, +0.990158557614831740, 0.990151558872084280, 0.990144557653957920, 0.990137553960470210, 0.990130547791638450, 0.990123539147480410, 0.990116528028013640, 0.990109514433255460, +0.990102498363223500, 0.990095479817935330, 0.990088458797408480, 0.990081435301660260, 0.990074409330708670, 0.990067380884571020, 0.990060349963264970, 0.990053316566807950, +0.990046280695217720, 0.990039242348511710, 0.990032201526707680, 0.990025158229822950, 0.990018112457875520, 0.990011064210882810, 0.990004013488862360, 0.989996960291831930, +0.989989904619809070, 0.989982846472811540, 0.989975785850856770, 0.989968722753962530, 0.989961657182146460, 0.989954589135426330, 0.989947518613819800, 0.989940445617344400, +0.989933370146017900, 0.989926292199857950, 0.989919211778882090, 0.989912128883108420, 0.989905043512554370, 0.989897955667237820, 0.989890865347176300, 0.989883772552387580, +0.989876677282889530, 0.989869579538699700, 0.989862479319835840, 0.989855376626315840, 0.989848271458157460, 0.989841163815378460, 0.989834053697996490, 0.989826941106029310, +0.989819826039494920, 0.989812708498410740, 0.989805588482794980, 0.989798465992665190, 0.989791341028039230, 0.989784213588934980, 0.989777083675370210, 0.989769951287362670, +0.989762816424930250, 0.989755679088090700, 0.989748539276862020, 0.989741396991262070, 0.989734252231308620, 0.989727104997019440, 0.989719955288412610, 0.989712803105505800, +0.989705648448317100, 0.989698491316864050, 0.989691331711164970, 0.989684169631237510, 0.989677005077099660, 0.989669838048769290, 0.989662668546264280, 0.989655496569602610, +0.989648322118802160, 0.989641145193880910, 0.989633965794856850, 0.989626783921747850, 0.989619599574572020, 0.989612412753347100, 0.989605223458091100, 0.989598031688822100, +0.989590837445557870, 0.989583640728316730, 0.989576441537116440, 0.989569239871974980, 0.989562035732910570, 0.989554829119940970, 0.989547620033084270, 0.989540408472358470, +0.989533194437781760, 0.989525977929372020, 0.989518758947147360, 0.989511537491125860, 0.989504313561325400, 0.989497087157764300, 0.989489858280460430, 0.989482626929431670, +0.989475393104696680, 0.989468156806273090, 0.989460918034179020, 0.989453676788432770, 0.989446433069052330, 0.989439186876055810, 0.989431938209461290, 0.989424687069286770, +0.989417433455550670, 0.989410177368271080, 0.989402918807466000, 0.989395657773153530, 0.989388394265351970, 0.989381128284079540, 0.989373859829354000, 0.989366588901194000, +0.989359315499617530, 0.989352039624642800, 0.989344761276287900, 0.989337480454571150, 0.989330197159510760, 0.989322911391124830, 0.989315623149431440, 0.989308332434449160, +0.989301039246196060, 0.989293743584690350, 0.989286445449950260, 0.989279144841994080, 0.989271841760840040, 0.989264536206506340, 0.989257228179011290, 0.989249917678373230, +0.989242604704610340, 0.989235289257740960, 0.989227971337783400, 0.989220650944755860, 0.989213328078676790, 0.989206002739564160, 0.989198674927436630, 0.989191344642312510, +0.989184011884210010, 0.989176676653147460, 0.989169338949143270, 0.989161998772215670, 0.989154656122383070, 0.989147310999663690, 0.989139963404076280, 0.989132613335638840, +0.989125260794369910, 0.989117905780287800, 0.989110548293410940, 0.989103188333757770, 0.989095825901346370, 0.989088460996195630, 0.989081093618323750, 0.989073723767749050, +0.989066351444490180, 0.989058976648565350, 0.989051599379993100, 0.989044219638791740, 0.989036837424979830, 0.989029452738575900, 0.989022065579598380, 0.989014675948065690, +0.989007283843996280, 0.988999889267408670, 0.988992492218321310, 0.988985092696752830, 0.988977690702721350, 0.988970286236245830, 0.988962879297344610, 0.988955469886036220, +0.988948058002339090, 0.988940643646271880, 0.988933226817853010, 0.988925807517101020, 0.988918385744034570, 0.988910961498672080, 0.988903534781032320, 0.988896105591133720, +0.988888673928994820, 0.988881239794634160, 0.988873803188070500, 0.988866364109322160, 0.988858922558408130, 0.988851478535346610, 0.988844032040156580, 0.988836583072856380, +0.988829131633464750, 0.988821677722000250, 0.988814221338481620, 0.988806762482927200, 0.988799301155356080, 0.988791837355786680, 0.988784371084237780, 0.988776902340727900, +0.988769431125275710, 0.988761957437899960, 0.988754481278619200, 0.988747002647452410, 0.988739521544418020, 0.988732037969534900, 0.988724551922821710, 0.988717063404297100, +0.988709572413979830, 0.988702078951888660, 0.988694583018042140, 0.988687084612459240, 0.988679583735158740, 0.988672080386159170, 0.988664574565479400, 0.988657066273138320, +0.988649555509154450, 0.988642042273546680, 0.988634526566333770, 0.988627008387534700, 0.988619487737168010, 0.988611964615252690, 0.988604439021807390, 0.988596910956850980, +0.988589380420402340, 0.988581847412480120, 0.988574311933103410, 0.988566773982290870, 0.988559233560061480, 0.988551690666433890, 0.988544145301427200, 0.988536597465060060, +0.988529047157351460, 0.988521494378320150, 0.988513939127985130, 0.988506381406365380, 0.988498821213479540, 0.988491258549346830, 0.988483693413985790, 0.988476125807415620, +0.988468555729654970, 0.988460983180723060, 0.988453408160638760, 0.988445830669420930, 0.988438250707088460, 0.988430668273660440, 0.988423083369155630, 0.988415495993593240, +0.988407906146991920, 0.988400313829370880, 0.988392719040749210, 0.988385121781145680, 0.988377522050579270, 0.988369919849069190, 0.988362315176634200, 0.988354708033293510, +0.988347098419065870, 0.988339486333970620, 0.988331871778026620, 0.988324254751253070, 0.988316635253668750, 0.988309013285292860, 0.988301388846144490, 0.988293761936242520, +0.988286132555606270, 0.988278500704254600, 0.988270866382206740, 0.988263229589481760, 0.988255590326098670, 0.988247948592076540, 0.988240304387434710, 0.988232657712191820, +0.988225008566367520, 0.988217356949980590, 0.988209702863050320, 0.988202046305595830, 0.988194387277636200, 0.988186725779190640, 0.988179061810278040, 0.988171395370918030, +0.988163726461129490, 0.988156055080931630, 0.988148381230343650, 0.988140704909384660, 0.988133026118073960, 0.988125344856430670, 0.988117661124473860, 0.988109974922223080, +0.988102286249697310, 0.988094595106915890, 0.988086901493898000, 0.988079205410662740, 0.988071506857229550, 0.988063805833617640, 0.988056102339845980, 0.988048396375934220, +0.988040687941901470, 0.988032977037767050, 0.988025263663550150, 0.988017547819270090, 0.988009829504946200, 0.988002108720597570, 0.987994385466243850, 0.987986659741904140, +0.987978931547597750, 0.987971200883344000, 0.987963467749162330, 0.987955732145071930, 0.987947994071092240, 0.987940253527242460, 0.987932510513542140, 0.987924765030010480, +0.987917017076667010, 0.987909266653530960, 0.987901513760621740, 0.987893758397958680, 0.987886000565561310, 0.987878240263448840, 0.987870477491640810, 0.987862712250156650, +0.987854944539015680, 0.987847174358237320, 0.987839401707841010, 0.987831626587846290, 0.987823848998272360, 0.987816068939138870, 0.987808286410465250, 0.987800501412270830, +0.987792713944575240, 0.987784924007397920, 0.987777131600758200, 0.987769336724675710, 0.987761539379169660, 0.987753739564259940, 0.987745937279965960, 0.987738132526307040, +0.987730325303302740, 0.987722515610972680, 0.987714703449336430, 0.987706888818413180, 0.987699071718222910, 0.987691252148784840, 0.987683430110118720, 0.987675605602244100, +0.987667778625180290, 0.987659949178947170, 0.987652117263564170, 0.987644282879050710, 0.987636446025426660, 0.987628606702711580, 0.987620764910924880, 0.987612920650086320, +0.987605073920215460, 0.987597224721331820, 0.987589373053455290, 0.987581518916605060, 0.987573662310801240, 0.987565803236063240, 0.987557941692410730, 0.987550077679863360, +0.987542211198440770, 0.987534342248162720, 0.987526470829048650, 0.987518596941118540, 0.987510720584391930, 0.987502841758888470, 0.987494960464628040, 0.987487076701630050, +0.987479190469914500, 0.987471301769500930, 0.987463410600408990, 0.987455516962658540, 0.987447620856269470, 0.987439722281261200, 0.987431821237653720, 0.987423917725466670, +0.987416011744719820, 0.987408103295432830, 0.987400192377625660, 0.987392278991317980, 0.987384363136529660, 0.987376444813280460, 0.987368524021590140, 0.987360600761478470, +0.987352675032965310, 0.987344746836070320, 0.987336816170813700, 0.987328883037214890, 0.987320947435293970, 0.987313009365070720, 0.987305068826564880, 0.987297125819796340, +0.987289180344784970, 0.987281232401550520, 0.987273281990113220, 0.987265329110492700, 0.987257373762708830, 0.987249415946781510, 0.987241455662730580, 0.987233492910576160, +0.987225527690337780, 0.987217560002035750, 0.987209589845689740, 0.987201617221319830, 0.987193642128945890, 0.987185664568587810, 0.987177684540265550, 0.987169702043999120, +0.987161717079808270, 0.987153729647713310, 0.987145739747734010, 0.987137747379890350, 0.987129752544202320, 0.987121755240689900, 0.987113755469373190, 0.987105753230271940, +0.987097748523406260, 0.987089741348796350, 0.987081731706462070, 0.987073719596423430, 0.987065705018700500, 0.987057687973313280, 0.987049668460281970, 0.987041646479626220, +0.987033622031366580, 0.987025595115522790, 0.987017565732115080, 0.987009533881163410, 0.987001499562688010, 0.986993462776708740, 0.986985423523245920, 0.986977381802319310, +0.986969337613949450, 0.986961290958156210, 0.986953241834959690, 0.986945190244380210, 0.986937136186437640, 0.986929079661152290, 0.986921020668544040, 0.986912959208633420, +0.986904895281440320, 0.986896828886985160, 0.986888760025287800, 0.986880688696368580, 0.986872614900247580, 0.986864538636945120, 0.986856459906481080, 0.986848378708876100, +0.986840295044150160, 0.986832208912323480, 0.986824120313416380, 0.986816029247448820, 0.986807935714441250, 0.986799839714413870, 0.986791741247386670, 0.986783640313380390, +0.986775536912414930, 0.986767431044510590, 0.986759322709687690, 0.986751211907966550, 0.986743098639367380, 0.986734982903910260, 0.986726864701615860, 0.986718744032504260, +0.986710620896595780, 0.986702495293910850, 0.986694367224469570, 0.986686236688292470, 0.986678103685399770, 0.986669968215811540, 0.986661830279548680, 0.986653689876631160, +0.986645547007079520, 0.986637401670913960, 0.986629253868154810, 0.986621103598822600, 0.986612950862937650, 0.986604795660520170, 0.986596637991590810, 0.986588477856169880, +0.986580315254277700, 0.986572150185934800, 0.986563982651161520, 0.986555812649978270, 0.986547640182405370, 0.986539465248463480, 0.986531287848172900, 0.986523107981554180, +0.986514925648627640, 0.986506740849413810, 0.986498553583933120, 0.986490363852206010, 0.986482171654252890, 0.986473976990094540, 0.986465779859751150, 0.986457580263243370, +0.986449378200591640, 0.986441173671816380, 0.986432966676938250, 0.986424757215977550, 0.986416545288955060, 0.986408330895891310, 0.986400114036806720, 0.986391894711721730, +0.986383672920657100, 0.986375448663633250, 0.986367221940670840, 0.986358992751790180, 0.986350761097012140, 0.986342526976357270, 0.986334290389846100, 0.986326051337499180, +0.986317809819337030, 0.986309565835380430, 0.986301319385650020, 0.986293070470166010, 0.986284819088949490, 0.986276565242021010, 0.986268308929401090, 0.986260050151110400, +0.986251788907169580, 0.986243525197599280, 0.986235259022419930, 0.986226990381652730, 0.986218719275318010, 0.986210445703436410, 0.986202169666028810, 0.986193891163115730, +0.986185610194717950, 0.986177326760856120, 0.986169040861550770, 0.986160752496823000, 0.986152461666693460, 0.986144168371182680, 0.986135872610311440, 0.986127574384100590, +0.986119273692570800, 0.986110970535742700, 0.986102664913637180, 0.986094356826275110, 0.986086046273677130, 0.986077733255864010, 0.986069417772856620, 0.986061099824675600, +0.986052779411341840, 0.986044456532876090, 0.986036131189299230, 0.986027803380632120, 0.986019473106895530, 0.986011140368110220, 0.986002805164296950, 0.985994467495476810, +0.985986127361670460, 0.985977784762898660, 0.985969439699182490, 0.985961092170542730, 0.985952742177000240, 0.985944389718576010, 0.985936034795290680, 0.985927677407165250, +0.985919317554220580, 0.985910955236477650, 0.985902590453957450, 0.985894223206680740, 0.985885853494668400, 0.985877481317941510, 0.985869106676520830, 0.985860729570427470, +0.985852349999682190, 0.985843967964306070, 0.985835583464319990, 0.985827196499745040, 0.985818807070602100, 0.985810415176912150, 0.985802020818696170, 0.985793623995975030, +0.985785224708769840, 0.985776822957101670, 0.985768418740991410, 0.985760012060460040, 0.985751602915528770, 0.985743191306218460, 0.985734777232550210, 0.985726360694544780, +0.985717941692223600, 0.985709520225607650, 0.985701096294717800, 0.985692669899575270, 0.985684241040201140, 0.985675809716616280, 0.985667375928841900, 0.985658939676898990, +0.985650500960808860, 0.985642059780592490, 0.985633616136270980, 0.985625170027865430, 0.985616721455396920, 0.985608270418886660, 0.985599816918355630, 0.985591360953824940, +0.985582902525316110, 0.985574441632849910, 0.985565978276447650, 0.985557512456130440, 0.985549044171919460, 0.985540573423835830, 0.985532100211900630, 0.985523624536135290, +0.985515146396561010, 0.985506665793198790, 0.985498182726069930, 0.985489697195195520, 0.985481209200597010, 0.985472718742295360, 0.985464225820311790, 0.985455730434667830, +0.985447232585384580, 0.985438732272483130, 0.985430229495985020, 0.985421724255911240, 0.985413216552283090, 0.985404706385121900, 0.985396193754448980, 0.985387678660285650, +0.985379161102653000, 0.985370641081572570, 0.985362118597065460, 0.985353593649153090, 0.985345066237856780, 0.985336536363197620, 0.985328004025197270, 0.985319469223876810, +0.985310931959257790, 0.985302392231361400, 0.985293850040209080, 0.985285305385822150, 0.985276758268221920, 0.985268208687429590, 0.985259656643466930, 0.985251102136355140, +0.985242545166115650, 0.985233985732769660, 0.985225423836338820, 0.985216859476844340, 0.985208292654307650, 0.985199723368750280, 0.985191151620193660, 0.985182577408659220, +0.985174000734168280, 0.985165421596742360, 0.985156839996402800, 0.985148255933171240, 0.985139669407068870, 0.985131080418117370, 0.985122488966338250, 0.985113895051752950, +0.985105298674382900, 0.985096699834249630, 0.985088098531374470, 0.985079494765779050, 0.985070888537485030, 0.985062279846513730, 0.985053668692886800, 0.985045055076625650, +0.985036438997751840, 0.985027820456287010, 0.985019199452252580, 0.985010575985669990, 0.985001950056561100, 0.984993321664947350, 0.984984690810850380, 0.984976057494291620, +0.984967421715292720, 0.984958783473875220, 0.984950142770060770, 0.984941499603870900, 0.984932853975327370, 0.984924205884451620, 0.984915555331265510, 0.984906902315790480, +0.984898246838048160, 0.984889588898060220, 0.984880928495848070, 0.984872265631433930, 0.984863600304838990, 0.984854932516085140, 0.984846262265193890, 0.984837589552187030, +0.984828914377086200, 0.984820236739913040, 0.984811556640689200, 0.984802874079436560, 0.984794189056176770, 0.984785501570931480, 0.984776811623722440, 0.984768119214571410, +0.984759424343500060, 0.984750727010530120, 0.984742027215683270, 0.984733324958981470, 0.984724620240446270, 0.984715913060099650, 0.984707203417963250, 0.984698491314058730, +0.984689776748408070, 0.984681059721032810, 0.984672340231955050, 0.984663618281196420, 0.984654893868778800, 0.984646166994723850, 0.984637437659053540, 0.984628705861789630, +0.984619971602954000, 0.984611234882568190, 0.984602495700654500, 0.984593754057234590, 0.984585009952330230, 0.984576263385963490, 0.984567514358155930, 0.984558762868929630, +0.984550008918306350, 0.984541252506308080, 0.984532493632956810, 0.984523732298274170, 0.984514968502282260, 0.984506202245002960, 0.984497433526458130, 0.984488662346669760, +0.984479888705659500, 0.984471112603449770, 0.984462334040062110, 0.984453553015518730, 0.984444769529841500, 0.984435983583052290, 0.984427195175173080, 0.984418404306225960, +0.984409610976232590, 0.984400815185215380, 0.984392016933196220, 0.984383216220196980, 0.984374413046239630, 0.984365607411346270, 0.984356799315538880, 0.984347988758839440, +0.984339175741270060, 0.984330360262852810, 0.984321542323609580, 0.984312721923562560, 0.984303899062733740, 0.984295073741145220, 0.984286245958818970, 0.984277415715776870, +0.984268583012041450, 0.984259747847634590, 0.984250910222578380, 0.984242070136894910, 0.984233227590606160, 0.984224382583734460, 0.984215535116301670, 0.984206685188329990, +0.984197832799841740, 0.984188977950858910, 0.984180120641403590, 0.984171260871497980, 0.984162398641164280, 0.984153533950424600, 0.984144666799300790, 0.984135797187815520, +0.984126925115990870, 0.984118050583848820, 0.984109173591411590, 0.984100294138701480, 0.984091412225740700, 0.984082527852551350, 0.984073641019155510, 0.984064751725575730, +0.984055859971833980, 0.984046965757952700, 0.984038069083953970, 0.984029169949860120, 0.984020268355693230, 0.984011364301475620, 0.984002457787229720, 0.983993548812977630, +0.983984637378741760, 0.983975723484544210, 0.983966807130407410, 0.983957888316353560, 0.983948967042404980, 0.983940043308583870, 0.983931117114912770, 0.983922188461413880, +0.983913257348109530, 0.983904323775022020, 0.983895387742173670, 0.983886449249586900, 0.983877508297284040, 0.983868564885287180, 0.983859619013619180, 0.983850670682302030, +0.983841719891358270, 0.983832766640810100, 0.983823810930680160, 0.983814852760990570, 0.983805892131763730, 0.983796929043022290, 0.983787963494788590, 0.983778995487085030, +0.983770025019933820, 0.983761052093357740, 0.983752076707378850, 0.983743098862019830, 0.983734118557302970, 0.983725135793250940, 0.983716150569886040, 0.983707162887230810, +0.983698172745307580, 0.983689180144138970, 0.983680185083747440, 0.983671187564155500, 0.983662187585385260, 0.983653185147459920, 0.983644180250401460, 0.983635172894232630, +0.983626163078975770, 0.983617150804653620, 0.983608136071288500, 0.983599118878902940, 0.983590099227519720, 0.983581077117161250, 0.983572052547850180, 0.983563025519608840, +0.983553996032459970, 0.983544964086426220, 0.983535929681529920, 0.983526892817793710, 0.983517853495240350, 0.983508811713892480, 0.983499767473772550, 0.983490720774903070, +0.983481671617306930, 0.983472620001006550, 0.983463565926024460, 0.983454509392383660, 0.983445450400106560, 0.983436388949215920, 0.983427325039734180, 0.983418258671684200, +0.983409189845088520, 0.983400118559969890, 0.983391044816350760, 0.983381968614254310, 0.983372889953702870, 0.983363808834719190, 0.983354725257325920, 0.983345639221545940, +0.983336550727401780, 0.983327459774916310, 0.983318366364112070, 0.983309270495011930, 0.983300172167638760, 0.983291071382015100, 0.983281968138163710, 0.983272862436107450, +0.983263754275869100, 0.983254643657471170, 0.983245530580936780, 0.983236415046288450, 0.983227297053549280, 0.983218176602741690, 0.983209053693888780, 0.983199928327013200, +0.983190800502137810, 0.983181670219285260, 0.983172537478478660, 0.983163402279740750, 0.983154264623094300, 0.983145124508562170, 0.983135981936167250, 0.983126836905932390, +0.983117689417880470, 0.983108539472034140, 0.983099387068416600, 0.983090232207050610, 0.983081074887959040, 0.983071915111164870, 0.983062752876690760, 0.983053588184559900, +0.983044421034794840, 0.983035251427418880, 0.983026079362454790, 0.983016904839925540, 0.983007727859854020, 0.982998548422263200, 0.982989366527175950, 0.982980182174615360, +0.982970995364604080, 0.982961806097165440, 0.982952614372322400, 0.982943420190097730, 0.982934223550514630, 0.982925024453595860, 0.982915822899364520, 0.982906618887843480, +0.982897412419056150, 0.982888203493025190, 0.982878992109773810, 0.982869778269324870, 0.982860561971701460, 0.982851343216926690, 0.982842122005023630, 0.982832898336014950, +0.982823672209924280, 0.982814443626774500, 0.982805212586588480, 0.982795979089389540, 0.982786743135200540, 0.982777504724044790, 0.982768263855945180, 0.982759020530924790, +0.982749774749007040, 0.982740526510214820, 0.982731275814571310, 0.982722022662099630, 0.982712767052822840, 0.982703508986764170, 0.982694248463946480, 0.982684985484393430, +0.982675720048127870, 0.982666452155173010, 0.982657181805552060, 0.982647908999288110, 0.982638633736404480, 0.982629356016924140, 0.982620075840870300, 0.982610793208266500, +0.982601508119135600, 0.982592220573501040, 0.982582930571385900, 0.982573638112813400, 0.982564343197806830, 0.982555045826389310, 0.982545745998584130, 0.982536443714414730, +0.982527138973904200, 0.982517831777075860, 0.982508522123952900, 0.982499210014558640, 0.982489895448916290, 0.982480578427049170, 0.982471258948980690, 0.982461937014734050, +0.982452612624332590, 0.982443285777799600, 0.982433956475158410, 0.982424624716432330, 0.982415290501644670, 0.982405953830818630, 0.982396614703977880, 0.982387273121145600, +0.982377929082345110, 0.982368582587599740, 0.982359233636933000, 0.982349882230368120, 0.982340528367928400, 0.982331172049637600, 0.982321813275518820, 0.982312452045595470, +0.982303088359891000, 0.982293722218428810, 0.982284353621232340, 0.982274982568324910, 0.982265609059729930, 0.982256233095471170, 0.982246854675571710, 0.982237473800055110, +0.982228090468944880, 0.982218704682264350, 0.982209316440037170, 0.982199925742286650, 0.982190532589036100, 0.982181136980309510, 0.982171738916129970, 0.982162338396521120, +0.982152935421506390, 0.982143529991109320, 0.982134122105353450, 0.982124711764262080, 0.982115298967859210, 0.982105883716168030, 0.982096466009212080, 0.982087045847015010, +0.982077623229600350, 0.982068198156991530, 0.982058770629212320, 0.982049340646286020, 0.982039908208236500, 0.982030473315087190, 0.982021035966861740, 0.982011596163583690, +0.982002153905276560, 0.981992709191964240, 0.981983262023669810, 0.981973812400417480, 0.981964360322230560, 0.981954905789132800, 0.981945448801147760, 0.981935989358299070, +0.981926527460610380, 0.981917063108105450, 0.981907596300807590, 0.981898127038741020, 0.981888655321929040, 0.981879181150395520, 0.981869704524164000, 0.981860225443258240, +0.981850743907701880, 0.981841259917518690, 0.981831773472732210, 0.981822284573366400, 0.981812793219444810, 0.981803299410991430, 0.981793803148029660, 0.981784304430583400, +0.981774803258676390, 0.981765299632332280, 0.981755793551575050, 0.981746285016428240, 0.981736774026915840, 0.981727260583061480, 0.981717744684888930, 0.981708226332422050, +0.981698705525684500, 0.981689182264700140, 0.981679656549492960, 0.981670128380086600, 0.981660597756505050, 0.981651064678771830, 0.981641529146911050, 0.981631991160946460, +0.981622450720901930, 0.981612907826801000, 0.981603362478667970, 0.981593814676526620, 0.981584264420400700, 0.981574711710314070, 0.981565156546290730, 0.981555598928354420, +0.981546038856529020, 0.981536476330838630, 0.981526911351307100, 0.981517343917958310, 0.981507774030816130, 0.981498201689904540, 0.981488626895247410, 0.981479049646868720, +0.981469469944792230, 0.981459887789042250, 0.981450303179642550, 0.981440716116617100, 0.981431126599989770, 0.981421534629784760, 0.981411940206025850, 0.981402343328736880, +0.981392743997942300, 0.981383142213665850, 0.981373537975931520, 0.981363931284763290, 0.981354322140185360, 0.981344710542221500, 0.981335096490896010, 0.981325479986232430, +0.981315861028255410, 0.981306239616988820, 0.981296615752456520, 0.981286989434682730, 0.981277360663691420, 0.981267729439506690, 0.981258095762152730, 0.981248459631653300, +0.981238821048032950, 0.981229180011315430, 0.981219536521525050, 0.981209890578685790, 0.981200242182821870, 0.981190591333957360, 0.981180938032116150, 0.981171282277322750, +0.981161624069601170, 0.981151963408975480, 0.981142300295469890, 0.981132634729108610, 0.981122966709915720, 0.981113296237915430, 0.981103623313131610, 0.981093947935589020, +0.981084270105311520, 0.981074589822323430, 0.981064907086648730, 0.981055221898311850, 0.981045534257336980, 0.981035844163748120, 0.981026151617569560, 0.981016456618825750, +0.981006759167540880, 0.980997059263739040, 0.980987356907444650, 0.980977652098681710, 0.980967944837474740, 0.980958235123847720, 0.980948522957825310, 0.980938808339431590, +0.980929091268690770, 0.980919371745627380, 0.980909649770265400, 0.980899925342629380, 0.980890198462743500, 0.980880469130631980, 0.980870737346319470, 0.980861003109830150, +0.980851266421188250, 0.980841527280418180, 0.980831785687544370, 0.980822041642591010, 0.980812295145582440, 0.980802546196543280, 0.980792794795497750, 0.980783040942470260, +0.980773284637485140, 0.980763525880566810, 0.980753764671739690, 0.980744001011028100, 0.980734234898456460, 0.980724466334049310, 0.980714695317830950, 0.980704921849825940, +0.980695145930058580, 0.980685367558553400, 0.980675586735334730, 0.980665803460427200, 0.980656017733854910, 0.980646229555642730, 0.980636438925815090, 0.980626645844396180, +0.980616850311410770, 0.980607052326883280, 0.980597251890838020, 0.980587449003299530, 0.980577643664292680, 0.980567835873841550, 0.980558025631970920, 0.980548212938705310, +0.980538397794069040, 0.980528580198086750, 0.980518760150783100, 0.980508937652182390, 0.980499112702309490, 0.980489285301188730, 0.980479455448844850, 0.980469623145302280, +0.980459788390585670, 0.980449951184719670, 0.980440111527728700, 0.980430269419637290, 0.980420424860470320, 0.980410577850252430, 0.980400728389007940, 0.980390876476761710, +0.980381022113538390, 0.980371165299362410, 0.980361306034258310, 0.980351444318251160, 0.980341580151365410, 0.980331713533625690, 0.980321844465056660, 0.980311972945683060, +0.980302098975529560, 0.980292222554620780, 0.980282343682981170, 0.980272462360636030, 0.980262578587609680, 0.980252692363926870, 0.980242803689612360, 0.980232912564690810, +0.980223018989186960, 0.980213122963125460, 0.980203224486531190, 0.980193323559429010, 0.980183420181843460, 0.980173514353799400, 0.980163606075321490, 0.980153695346434590, +0.980143782167163470, 0.980133866537532650, 0.980123948457567450, 0.980114027927292300, 0.980104104946732060, 0.980094179515911600, 0.980084251634855800, 0.980074321303589180, +0.980064388522136840, 0.980054453290523430, 0.980044515608773930, 0.980034575476913190, 0.980024632894966110, 0.980014687862957310, 0.980004740380911900, 0.979994790448854510, +0.979984838066810030, 0.979974883234803640, 0.979964925952860110, 0.979954966221004200, 0.979945004039260880, 0.979935039407655030, 0.979925072326211620, 0.979915102794955530, +0.979905130813911400, 0.979895156383104760, 0.979885179502560160, 0.979875200172302560, 0.979865218392357070, 0.979855234162748450, 0.979845247483501880, 0.979835258354642020, +0.979825266776193970, 0.979815272748182810, 0.979805276270633630, 0.979795277343571080, 0.979785275967020470, 0.979775272141006570, 0.979765265865554570, 0.979755257140689230, +0.979745245966435860, 0.979735232342819450, 0.979725216269864860, 0.979715197747597300, 0.979705176776041740, 0.979695153355223280, 0.979685127485166900, 0.979675099165897460, +0.979665068397440500, 0.979655035179820890, 0.979644999513063720, 0.979634961397193970, 0.979624920832236850, 0.979614877818217430, 0.979604832355160720, 0.979594784443092000, +0.979584734082036390, 0.979574681272018850, 0.979564626013064710, 0.979554568305198940, 0.979544508148446740, 0.979534445542833310, 0.979524380488383640, 0.979514312985123040, +0.979504243033076820, 0.979494170632269960, 0.979484095782727550, 0.979474018484475020, 0.979463938737537450, 0.979453856541939950, 0.979443771897707700, 0.979433684804866140, +0.979423595263440470, 0.979413503273455780, 0.979403408834937260, 0.979393311947910240, 0.979383212612400020, 0.979373110828431480, 0.979363006596030370, 0.979352899915221790, +0.979342790786030930, 0.979332679208483100, 0.979322565182603630, 0.979312448708417600, 0.979302329785950550, 0.979292208415227570, 0.979282084596274080, 0.979271958329115510, +0.979261829613777060, 0.979251698450283930, 0.979241564838661650, 0.979231428778935320, 0.979221290271130360, 0.979211149315272310, 0.979201005911386370, 0.979190860059497960, +0.979180711759632390, 0.979170561011815100, 0.979160407816071280, 0.979150252172426570, 0.979140094080905960, 0.979129933541535320, 0.979119770554339850, 0.979109605119344970, +0.979099437236576000, 0.979089266906058580, 0.979079094127817910, 0.979068918901879410, 0.979058741228268530, 0.979048561107011000, 0.979038378538132030, 0.979028193521657150, +0.979018006057611800, 0.979007816146021390, 0.978997623786911460, 0.978987428980307330, 0.978977231726234740, 0.978967032024719020, 0.978956829875785810, 0.978946625279460520, +0.978936418235768710, 0.978926208744735790, 0.978915996806387300, 0.978905782420748770, 0.978895565587845850, 0.978885346307704070, 0.978875124580348870, 0.978864900405805870, +0.978854673784100740, 0.978844444715258780, 0.978834213199305750, 0.978823979236267070, 0.978813742826168510, 0.978803503969035700, 0.978793262664894080, 0.978783018913769290, +0.978772772715687080, 0.978762524070672770, 0.978752272978752000, 0.978742019439950760, 0.978731763454294580, 0.978721505021808880, 0.978711244142519420, 0.978700980816451850, +0.978690715043631810, 0.978680446824084950, 0.978670176157836910, 0.978659903044913570, 0.978649627485340460, 0.978639349479143220, 0.978629069026347720, 0.978618786126979500, +0.978608500781064210, 0.978598212988627590, 0.978587922749695640, 0.978577630064293880, 0.978567334932447960, 0.978557037354183870, 0.978546737329527020, 0.978536434858503390, +0.978526129941138630, 0.978515822577458510, 0.978505512767488870, 0.978495200511255490, 0.978484885808784120, 0.978474568660100520, 0.978464249065230440, 0.978453927024199870, +0.978443602537034440, 0.978433275603759700, 0.978422946224402070, 0.978412614398987080, 0.978402280127540490, 0.978391943410088280, 0.978381604246656210, 0.978371262637270030, +0.978360918581955620, 0.978350572080739060, 0.978340223133645990, 0.978329871740702520, 0.978319517901934280, 0.978309161617367250, 0.978298802887027310, 0.978288441710940320, +0.978278078089132140, 0.978267712021628880, 0.978257343508456390, 0.978246972549640550, 0.978236599145207220, 0.978226223295182380, 0.978215844999592020, 0.978205464258462000, +0.978195081071818180, 0.978184695439686890, 0.978174307362093880, 0.978163916839065010, 0.978153523870626370, 0.978143128456803960, 0.978132730597623620, 0.978122330293111350, +0.978111927543293460, 0.978101522348195700, 0.978091114707844160, 0.978080704622264820, 0.978070292091483770, 0.978059877115527000, 0.978049459694420480, 0.978039039828190070, +0.978028617516862320, 0.978018192760463090, 0.978007765559018250, 0.977997335912554110, 0.977986903821096540, 0.977976469284671750, 0.977966032303305590, 0.977955592877024600, +0.977945151005854550, 0.977934706689821630, 0.977924259928951930, 0.977913810723271660, 0.977903359072806790, 0.977892904977583520, 0.977882448437627840, 0.977871989452966270, +0.977861528023624690, 0.977851064149629190, 0.977840597831006190, 0.977830129067781550, 0.977819657859981710, 0.977809184207632630, 0.977798708110760420, 0.977788229569391710, +0.977777748583552380, 0.977767265153268620, 0.977756779278566750, 0.977746290959472960, 0.977735800196013360, 0.977725306988214140, 0.977714811336101830, 0.977704313239702530, +0.977693812699042430, 0.977683309714147740, 0.977672804285044770, 0.977662296411759830, 0.977651786094319130, 0.977641273332748860, 0.977630758127075560, 0.977620240477325320, +0.977609720383524450, 0.977599197845699370, 0.977588672863876180, 0.977578145438081410, 0.977567615568341260, 0.977557083254681820, 0.977546548497129960, 0.977536011295711660, +0.977525471650453340, 0.977514929561381420, 0.977504385028522100, 0.977493838051901820, 0.977483288631546770, 0.977472736767483700, 0.977462182459738700, 0.977451625708338320, +0.977441066513308860, 0.977430504874676750, 0.977419940792468410, 0.977409374266710150, 0.977398805297428290, 0.977388233884649680, 0.977377660028400430, 0.977367083728706950, +0.977356504985595900, 0.977345923799093460, 0.977335340169226300, 0.977324754096020600, 0.977314165579503120, 0.977303574619700300, 0.977292981216638550, 0.977282385370344290, +0.977271787080844170, 0.977261186348164500, 0.977250583172331820, 0.977239977553372550, 0.977229369491313560, 0.977218758986181160, 0.977208146038001770, 0.977197530646802040, +0.977186912812608500, 0.977176292535447690, 0.977165669815346140, 0.977155044652330270, 0.977144417046426960, 0.977133786997662510, 0.977123154506063680, 0.977112519571657010, +0.977101882194468920, 0.977091242374526270, 0.977080600111855270, 0.977069955406482890, 0.977059308258435680, 0.977048658667740160, 0.977038006634422970, 0.977027352158510890, +0.977016695240030320, 0.977006035879008030, 0.976995374075470550, 0.976984709829444740, 0.976974043140957150, 0.976963374010034520, 0.976952702436703400, 0.976942028420990540, +0.976931351962922580, 0.976920673062526280, 0.976909991719828060, 0.976899307934855130, 0.976888621707633800, 0.976877933038191040, 0.976867241926553390, 0.976856548372747710, +0.976845852376800550, 0.976835153938738650, 0.976824453058589000, 0.976813749736378250, 0.976803043972133130, 0.976792335765880430, 0.976781625117646770, 0.976770912027459140, +0.976760196495344290, 0.976749478521328650, 0.976738758105439530, 0.976728035247703570, 0.976717309948147430, 0.976706582206798070, 0.976695852023682250, 0.976685119398826850, +0.976674384332258390, 0.976663646824004190, 0.976652906874090900, 0.976642164482545260, 0.976631419649394260, 0.976620672374664770, 0.976609922658383530, 0.976599170500577430, +0.976588415901273320, 0.976577658860498300, 0.976566899378279230, 0.976556137454642760, 0.976545373089616090, 0.976534606283225860, 0.976523837035499160, 0.976513065346462870, +0.976502291216143850, 0.976491514644569180, 0.976480735631765630, 0.976469954177760390, 0.976459170282580220, 0.976448383946252110, 0.976437595168803020, 0.976426803950259830, +0.976416010290649730, 0.976405214189999700, 0.976394415648336510, 0.976383614665687350, 0.976372811242079200, 0.976362005377539030, 0.976351197072093720, 0.976340386325770360, +0.976329573138596140, 0.976318757510598050, 0.976307939441803050, 0.976297118932238140, 0.976286295981930510, 0.976275470590907140, 0.976264642759194780, 0.976253812486821080, +0.976242979773812910, 0.976232144620197250, 0.976221307026001180, 0.976210466991251910, 0.976199624515976530, 0.976188779600202010, 0.976177932243955330, 0.976167082447264020, +0.976156230210154960, 0.976145375532655460, 0.976134518414792370, 0.976123658856593130, 0.976112796858084610, 0.976101932419294220, 0.976091065540248710, 0.976080196220975750, +0.976069324461502410, 0.976058450261855560, 0.976047573622062740, 0.976036694542150920, 0.976025813022147410, 0.976014929062079100, 0.976004042661973710, 0.975993153821858250, +0.975982262541759900, 0.975971368821705880, 0.975960472661723370, 0.975949574061839690, 0.975938673022082150, 0.975927769542477730, 0.975916863623053970, 0.975905955263838170, +0.975895044464857420, 0.975884131226139150, 0.975873215547710450, 0.975862297429598740, 0.975851376871831320, 0.975840453874435190, 0.975829528437438200, 0.975818600560867330, +0.975807670244750010, 0.975796737489113440, 0.975785802293985150, 0.975774864659392230, 0.975763924585361990, 0.975752982071922180, 0.975742037119099900, 0.975731089726922460, +0.975720139895417390, 0.975709187624611900, 0.975698232914533500, 0.975687275765209530, 0.975676316176667060, 0.975665354148934070, 0.975654389682037770, 0.975643422776005350, +0.975632453430864470, 0.975621481646642420, 0.975610507423366750, 0.975599530761064540, 0.975588551659763660, 0.975577570119491420, 0.975566586140275360, 0.975555599722142670, +0.975544610865121120, 0.975533619569238010, 0.975522625834520760, 0.975511629660996920, 0.975500631048694110, 0.975489629997639660, 0.975478626507861210, 0.975467620579386190, +0.975456612212242110, 0.975445601406456530, 0.975434588162056860, 0.975423572479070630, 0.975412554357525610, 0.975401533797449210, 0.975390510798868960, 0.975379485361812400, +0.975368457486307180, 0.975357427172380830, 0.975346394420060660, 0.975335359229374750, 0.975324321600350430, 0.975313281533015330, 0.975302239027396990, 0.975291194083523050, +0.975280146701421160, 0.975269096881118850, 0.975258044622643650, 0.975246989926023540, 0.975235932791285950, 0.975224873218458520, 0.975213811207568890, 0.975202746758644820, +0.975191679871713730, 0.975180610546803490, 0.975169538783941640, 0.975158464583156030, 0.975147387944474310, 0.975136308867924130, 0.975125227353533130, 0.975114143401329070, +0.975103057011339700, 0.975091968183592450, 0.975080876918115400, 0.975069783214936310, 0.975058687074082610, 0.975047588495582260, 0.975036487479463030, 0.975025384025752450, +0.975014278134478500, 0.975003169805668590, 0.974992059039351040, 0.974980945835553280, 0.974969830194303170, 0.974958712115628460, 0.974947591599557020, 0.974936468646116490, +0.974925343255334750, 0.974914215427239770, 0.974903085161859200, 0.974891952459221000, 0.974880817319352940, 0.974869679742282780, 0.974858539728038380, 0.974847397276647710, +0.974836252388138310, 0.974825105062538500, 0.974813955299875910, 0.974802803100178420, 0.974791648463473990, 0.974780491389790390, 0.974769331879155490, 0.974758169931597360, +0.974747005547143550, 0.974735838725822480, 0.974724669467661790, 0.974713497772689450, 0.974702323640933340, 0.974691147072421440, 0.974679968067181600, 0.974668786625241700, +0.974657602746630050, 0.974646416431374400, 0.974635227679502720, 0.974624036491042900, 0.974612842866023010, 0.974601646804471030, 0.974590448306414950, 0.974579247371882510, +0.974568044000902130, 0.974556838193501700, 0.974545629949709170, 0.974534419269552530, 0.974523206153059870, 0.974511990600259280, 0.974500772611178620, 0.974489552185845760, +0.974478329324289350, 0.974467104026537020, 0.974455876292616980, 0.974444646122557210, 0.974433413516385900, 0.974422178474131040, 0.974410940995820480, 0.974399701081482770, +0.974388458731145880, 0.974377213944837780, 0.974365966722586680, 0.974354717064420670, 0.974343464970367830, 0.974332210440456370, 0.974320953474714150, 0.974309694073169700, +0.974298432235851110, 0.974287167962786360, 0.974275901254003760, 0.974264632109531400, 0.974253360529397370, 0.974242086513629870, 0.974230810062257310, 0.974219531175307680, +0.974208249852809290, 0.974196966094790230, 0.974185679901278690, 0.974174391272303100, 0.974163100207891430, 0.974151806708071780, 0.974140510772872890, 0.974129212402322750, +0.974117911596449450, 0.974106608355281510, 0.974095302678846920, 0.974083994567174210, 0.974072684020291460, 0.974061371038226760, 0.974050055621008880, 0.974038737768665790, +0.974027417481225900, 0.974016094758717530, 0.974004769601168880, 0.973993442008608270, 0.973982111981063880, 0.973970779518564480, 0.973959444621138040, 0.973948107288812980, +0.973936767521617730, 0.973925425319580480, 0.973914080682729670, 0.973902733611093700, 0.973891384104700770, 0.973880032163579430, 0.973868677787758100, 0.973857320977265070, +0.973845961732128670, 0.973834600052377430, 0.973823235938039770, 0.973811869389143880, 0.973800500405718190, 0.973789128987791460, 0.973777755135391890, 0.973766378848547890, +0.973755000127288000, 0.973743618971640520, 0.973732235381634110, 0.973720849357296860, 0.973709460898657620, 0.973698070005744820, 0.973686676678586770, 0.973675280917212120, +0.973663882721649280, 0.973652482091926670, 0.973641079028072840, 0.973629673530116090, 0.973618265598085400, 0.973606855232009070, 0.973595442431915650, 0.973584027197833550, +0.973572609529791300, 0.973561189427817660, 0.973549766891940840, 0.973538341922189690, 0.973526914518592860, 0.973515484681178660, 0.973504052409975620, 0.973492617705012610, +0.973481180566318050, 0.973469740993920470, 0.973458298987848410, 0.973446854548130740, 0.973435407674795970, 0.973423958367872650, 0.973412506627389430, 0.973401052453374940, +0.973389595845857940, 0.973378136804866840, 0.973366675330430200, 0.973355211422577080, 0.973343745081335920, 0.973332276306735470, 0.973320805098804250, 0.973309331457571040, +0.973297855383064460, 0.973286376875313050, 0.973274895934346020, 0.973263412560191670, 0.973251926752878750, 0.973240438512436020, 0.973228947838892240, 0.973217454732276050, +0.973205959192616320, 0.973194461219941350, 0.973182960814280570, 0.973171457975662290, 0.973159952704115370, 0.973148444999668570, 0.973136934862350760, 0.973125422292190460, +0.973113907289216540, 0.973102389853457980, 0.973090869984943430, 0.973079347683701750, 0.973067822949761680, 0.973056295783152110, 0.973044766183901680, 0.973033234152039460, +0.973021699687593890, 0.973010162790594270, 0.972998623461069250, 0.972987081699047680, 0.972975537504558340, 0.972963990877630190, 0.972952441818292100, 0.972940890326572940, +0.972929336402501340, 0.972917780046106520, 0.972906221257417330, 0.972894660036462520, 0.972883096383271080, 0.972871530297871990, 0.972859961780293990, 0.972848390830565850, +0.972836817448716970, 0.972825241634776130, 0.972813663388772070, 0.972802082710733870, 0.972790499600690530, 0.972778914058670900, 0.972767326084703950, 0.972755735678818570, +0.972744142841044050, 0.972732547571409030, 0.972720949869942840, 0.972709349736674110, 0.972697747171632040, 0.972686142174845720, 0.972674534746343910, 0.972662924886155580, +0.972651312594310260, 0.972639697870836480, 0.972628080715763570, 0.972616461129120480, 0.972604839110936200, 0.972593214661239820, 0.972581587780060210, 0.972569958467426780, +0.972558326723368500, 0.972546692547914370, 0.972535055941093570, 0.972523416902935090, 0.972511775433468120, 0.972500131532721630, 0.972488485200724620, 0.972476836437506600, +0.972465185243096550, 0.972453531617523570, 0.972441875560816630, 0.972430217073005030, 0.972418556154117990, 0.972406892804184240, 0.972395227023233550, 0.972383558811294790, +0.972371888168397040, 0.972360215094569710, 0.972348539589841690, 0.972336861654242380, 0.972325181287800990, 0.972313498490546380, 0.972301813262508200, 0.972290125603715530, +0.972278435514197570, 0.972266742993983520, 0.972255048043102480, 0.972243350661583960, 0.972231650849457060, 0.972219948606750760, 0.972208243933494810, 0.972196536829718290, +0.972184827295450420, 0.972173115330720480, 0.972161400935557700, 0.972149684109991470, 0.972137964854050800, 0.972126243167765520, 0.972114519051164530, 0.972102792504277220, +0.972091063527133040, 0.972079332119761050, 0.972067598282190800, 0.972055862014451600, 0.972044123316572530, 0.972032382188583340, 0.972020638630513130, 0.972008892642391430, +0.971997144224247430, 0.971985393376110670, 0.971973640098010350, 0.971961884389975880, 0.971950126252036580, 0.971938365684222090, 0.971926602686561720, 0.971914837259084900, +0.971903069401820920, 0.971891299114799320, 0.971879526398049420, 0.971867751251600520, 0.971855973675482490, 0.971844193669724520, 0.971832411234356040, 0.971820626369406470, +0.971808839074905450, 0.971797049350882180, 0.971785257197366410, 0.971773462614387240, 0.971761665601974630, 0.971749866160157900, 0.971738064288966470, 0.971726259988429870, +0.971714453258577640, 0.971702644099439290, 0.971690832511044160, 0.971679018493422090, 0.971667202046602510, 0.971655383170614840, 0.971643561865488840, 0.971631738131253810, +0.971619911967939510, 0.971608083375575360, 0.971596252354190890, 0.971584418903815970, 0.971572583024480020, 0.971560744716212570, 0.971548903979043250, 0.971537060813001730, +0.971525215218117520, 0.971513367194420270, 0.971501516741939410, 0.971489663860704900, 0.971477808550746280, 0.971465950812093190, 0.971454090644775170, 0.971442228048821850, +0.971430363024263110, 0.971418495571128140, 0.971406625689447250, 0.971394753379249740, 0.971382878640565270, 0.971371001473423700, 0.971359121877854560, 0.971347239853887710, +0.971335355401552690, 0.971323468520879140, 0.971311579211897040, 0.971299687474636020, 0.971287793309125850, 0.971275896715396050, 0.971263997693476600, 0.971252096243397260, +0.971240192365187550, 0.971228286058877120, 0.971216377324496280, 0.971204466162074450, 0.971192552571641500, 0.971180636553227060, 0.971168718106861120, 0.971156797232573420, +0.971144873930393390, 0.971132948200351450, 0.971121020042477130, 0.971109089456800300, 0.971097156443350820, 0.971085221002158330, 0.971073283133252810, 0.971061342836664010, +0.971049400112421800, 0.971037454960556160, 0.971025507381096940, 0.971013557374074020, 0.971001604939517150, 0.970989650077456190, 0.970977692787921230, 0.970965733070941810, +0.970953770926548220, 0.970941806354770120, 0.970929839355637700, 0.970917869929180500, 0.970905898075428710, 0.970893923794412190, 0.970881947086160820, 0.970869967950704460, +0.970857986388073300, 0.970846002398297210, 0.970834015981406060, 0.970822027137429930, 0.970810035866398800, 0.970798042168342420, 0.970786046043291000, 0.970774047491274270, +0.970762046512322670, 0.970750043106465950, 0.970738037273734090, 0.970726029014157170, 0.970714018327765050, 0.970702005214588050, 0.970689989674655700, 0.970677971707998630, +0.970665951314646720, 0.970653928494629840, 0.970641903247978170, 0.970629875574721690, 0.970617845474890610, 0.970605812948514780, 0.970593777995624300, 0.970581740616249580, +0.970569700810420600, 0.970557658578167230, 0.970545613919519770, 0.970533566834508310, 0.970521517323162830, 0.970509465385513640, 0.970497411021590590, 0.970485354231424120, +0.970473295015044310, 0.970461233372481360, 0.970449169303765240, 0.970437102808926260, 0.970425033887994390, 0.970412962540999850, 0.970400888767973040, 0.970388812568944050, +0.970376733943943080, 0.970364652893000220, 0.970352569416145670, 0.970340483513409740, 0.970328395184822610, 0.970316304430414280, 0.970304211250215490, 0.970292115644255990, +0.970280017612566330, 0.970267917155176570, 0.970255814272117050, 0.970243708963418050, 0.970231601229109450, 0.970219491069222120, 0.970207378483786130, 0.970195263472831580, +0.970183146036388890, 0.970171026174488360, 0.970158903887160310, 0.970146779174434930, 0.970134652036342420, 0.970122522472913530, 0.970110390484178240, 0.970098256070167090, +0.970086119230910150, 0.970073979966438070, 0.970061838276780940, 0.970049694161969290, 0.970037547622033090, 0.970025398657003320, 0.970013247266909960, 0.970001093451783650, +0.969988937211654470, 0.969976778546552950, 0.969964617456509530, 0.969952453941554380, 0.969940288001718280, 0.969928119637031410, 0.969915948847524300, 0.969903775633227270, +0.969891599994170850, 0.969879421930385340, 0.969867241441901400, 0.969855058528749090, 0.969842873190959300, 0.969830685428562430, 0.969818495241588810, 0.969806302630068950, +0.969794107594033280, 0.969781910133512340, 0.969769710248536750, 0.969757507939136510, 0.969745303205342800, 0.969733096047185830, 0.969720886464696120, 0.969708674457904210, +0.969696460026840620, 0.969684243171535790, 0.969672023892020230, 0.969659802188324820, 0.969647578060479850, 0.969635351508515990, 0.969623122532463740, 0.969610891132353660, +0.969598657308216370, 0.969586421060082420, 0.969574182387982210, 0.969561941291946730, 0.969549697772006500, 0.969537451828191950, 0.969525203460533720, 0.969512952669062570, +0.969500699453809010, 0.969488443814803480, 0.969476185752077060, 0.969463925265660160, 0.969451662355583550, 0.969439397021877650, 0.969427129264573310, 0.969414859083701170, +0.969402586479291890, 0.969390311451375890, 0.969378033999984230, 0.969365754125147690, 0.969353471826896570, 0.969341187105261960, 0.969328899960274270, 0.969316610391964370, +0.969304318400362910, 0.969292023985500410, 0.969279727147408180, 0.969267427886116530, 0.969255126201656330, 0.969242822094058320, 0.969230515563353270, 0.969218206609571920, +0.969205895232744810, 0.969193581432903240, 0.969181265210077750, 0.969168946564298970, 0.969156625495597890, 0.969144302004005250, 0.969131976089551820, 0.969119647752268550, +0.969107316992185890, 0.969094983809335120, 0.969082648203746900, 0.969070310175452090, 0.969057969724481440, 0.969045626850865930, 0.969033281554636310, 0.969020933835823330, +0.969008583694458190, 0.968996231130571650, 0.968983876144194460, 0.968971518735357580, 0.968959158904091900, 0.968946796650428380, 0.968934431974397880, 0.968922064876031050, +0.968909695355359200, 0.968897323412413190, 0.968884949047223890, 0.968872572259822150, 0.968860193050239070, 0.968847811418505510, 0.968835427364652340, 0.968823040888710410, +0.968810651990711040, 0.968798260670685200, 0.968785866928663530, 0.968773470764677350, 0.968761072178757400, 0.968748671170934770, 0.968736267741240220, 0.968723861889705270, +0.968711453616360680, 0.968699042921237430, 0.968686629804366590, 0.968674214265779150, 0.968661796305506200, 0.968649375923578690, 0.968636953120027620, 0.968624527894884400, +0.968612100248179790, 0.968599670179944860, 0.968587237690210930, 0.968574802779008760, 0.968562365446369640, 0.968549925692324680, 0.968537483516904610, 0.968525038920140970, +0.968512591902064850, 0.968500142462707210, 0.968487690602099270, 0.968475236320271990, 0.968462779617256690, 0.968450320493084220, 0.968437858947786220, 0.968425394981393460, +0.968412928593937350, 0.968400459785448860, 0.968387988555959200, 0.968375514905499560, 0.968363038834101130, 0.968350560341794900, 0.968338079428612500, 0.968325596094584910, +0.968313110339743320, 0.968300622164118940, 0.968288131567742960, 0.968275638550646690, 0.968263143112861210, 0.968250645254417950, 0.968238144975348100, 0.968225642275682970, +0.968213137155453650, 0.968200629614691550, 0.968188119653427880, 0.968175607271693830, 0.968163092469520590, 0.968150575246939820, 0.968138055603982580, 0.968125533540680320, +0.968113009057064100, 0.968100482153165460, 0.968087952829015610, 0.968075421084645840, 0.968062886920087240, 0.968050350335371680, 0.968037811330530350, 0.968025269905594340, +0.968012726060595300, 0.968000179795564300, 0.967987631110532990, 0.967975080005532230, 0.967962526480594110, 0.967949970535749600, 0.967937412171030240, 0.967924851386467330, +0.967912288182092300, 0.967899722557936440, 0.967887154514031400, 0.967874584050408160, 0.967862011167098800, 0.967849435864134300, 0.967836858141546300, 0.967824277999366100, +0.967811695437625240, 0.967799110456355140, 0.967786523055587210, 0.967773933235352770, 0.967761340995683780, 0.967748746336611340, 0.967736149258167090, 0.967723549760382440, +0.967710947843288930, 0.967698343506918080, 0.967685736751301100, 0.967673127576470060, 0.967660515982456170, 0.967647901969290960, 0.967635285537006060, 0.967622666685632900, +0.967610045415203120, 0.967597421725748250, 0.967584795617299490, 0.967572167089889020, 0.967559536143548170, 0.967546902778308460, 0.967534266994201420, 0.967521628791258800, +0.967508988169512140, 0.967496345128992630, 0.967483699669732580, 0.967471051791763290, 0.967458401495116420, 0.967445748779823480, 0.967433093645916120, 0.967420436093426090, +0.967407776122385040, 0.967395113732824160, 0.967382448924775870, 0.967369781698271370, 0.967357112053342520, 0.967344439990020730, 0.967331765508337990, 0.967319088608325720, +0.967306409290015770, 0.967293727553439680, 0.967281043398629300, 0.967268356825616400, 0.967255667834432620, 0.967242976425109700, 0.967230282597679290, 0.967217586352173250, +0.967204887688623010, 0.967192186607060630, 0.967179483107517890, 0.967166777190026530, 0.967154068854618080, 0.967141358101324510, 0.967128644930177580, 0.967115929341208940, +0.967103211334450320, 0.967090490909933930, 0.967077768067691300, 0.967065042807754180, 0.967052315130154550, 0.967039585034924040, 0.967026852522094640, 0.967014117591698090, +0.967001380243766030, 0.966988640478330770, 0.966975898295423850, 0.966963153695077130, 0.966950406677322680, 0.966937657242192160, 0.966924905389717430, 0.966912151119930230, +0.966899394432862880, 0.966886635328547130, 0.966873873807014730, 0.966861109868297650, 0.966848343512427770, 0.966835574739437040, 0.966822803549357350, 0.966810029942220430, +0.966797253918058710, 0.966784475476903940, 0.966771694618787870, 0.966758911343742480, 0.966746125651799960, 0.966733337542992070, 0.966720547017350550, 0.966707754074908050, +0.966694958715696000, 0.966682160939746680, 0.966669360747091870, 0.966656558137763740, 0.966643753111794070, 0.966630945669215150, 0.966618135810058620, 0.966605323534356910, +0.966592508842141980, 0.966579691733445710, 0.966566872208300290, 0.966554050266737570, 0.966541225908789880, 0.966528399134488960, 0.966515569943866890, 0.966502738336956210, +0.966489904313788560, 0.966477067874396130, 0.966464229018811130, 0.966451387747065520, 0.966438544059191500, 0.966425697955220820, 0.966412849435186130, 0.966399998499119280, +0.966387145147052480, 0.966374289379017810, 0.966361431195047470, 0.966348570595173540, 0.966335707579428100, 0.966322842147843250, 0.966309974300451510, 0.966297104037284750, +0.966284231358375270, 0.966271356263755270, 0.966258478753456830, 0.966245598827512260, 0.966232716485953660, 0.966219831728812980, 0.966206944556122990, 0.966194054967915660, +0.966181162964223180, 0.966168268545077760, 0.966155371710511690, 0.966142472460557180, 0.966129570795246310, 0.966116666714611720, 0.966103760218685490, 0.966090851307499830, +0.966077939981087040, 0.966065026239479320, 0.966052110082709080, 0.966039191510808640, 0.966026270523809960, 0.966013347121745800, 0.966000421304648360, 0.965987493072549720, +0.965974562425482520, 0.965961629363478740, 0.965948693886571010, 0.965935755994791310, 0.965922815688172400, 0.965909872966746460, 0.965896927830545820, 0.965883980279602870, +0.965871030313950050, 0.965858077933619550, 0.965845123138643900, 0.965832165929055300, 0.965819206304886380, 0.965806244266169460, 0.965793279812936940, 0.965780312945221260, +0.965767343663054830, 0.965754371966469960, 0.965741397855499170, 0.965728421330174780, 0.965715442390529420, 0.965702461036595520, 0.965689477268405480, 0.965676491085991630, +0.965663502489386700, 0.965650511478622910, 0.965637518053732660, 0.965624522214748810, 0.965611523961703690, 0.965598523294629810, 0.965585520213559590, 0.965572514718525570, +0.965559506809560150, 0.965546496486696100, 0.965533483749965500, 0.965520468599401440, 0.965507451035036320, 0.965494431056902470, 0.965481408665032510, 0.965468383859459100, +0.965455356640214650, 0.965442327007331680, 0.965429294960843070, 0.965416260500781220, 0.965403223627178670, 0.965390184340068180, 0.965377142639482160, 0.965364098525453240, +0.965351051998014190, 0.965338003057197190, 0.965324951703035450, 0.965311897935561270, 0.965298841754807400, 0.965285783160806490, 0.965272722153591060, 0.965259658733193750, +0.965246592899647430, 0.965233524652984290, 0.965220453993237640, 0.965207380920439780, 0.965194305434623480, 0.965181227535821470, 0.965168147224066410, 0.965155064499390920, +0.965141979361827550, 0.965128891811409480, 0.965115801848169140, 0.965102709472139390, 0.965089614683352750, 0.965076517481842200, 0.965063417867640270, 0.965050315840779830, +0.965037211401293280, 0.965024104549214060, 0.965010995284574570, 0.964997883607407460, 0.964984769517745810, 0.964971653015622160, 0.964958534101069350, 0.964945412774120270, +0.964932289034807320, 0.964919162883163930, 0.964906034319222730, 0.964892903343016360, 0.964879769954577690, 0.964866634153939700, 0.964853495941135010, 0.964840355316196390, +0.964827212279157130, 0.964814066830049890, 0.964800918968907410, 0.964787768695762660, 0.964774616010648510, 0.964761460913597820, 0.964748303404643460, 0.964735143483818060, +0.964721981151155040, 0.964708816406687150, 0.964695649250447150, 0.964682479682468120, 0.964669307702782810, 0.964656133311424190, 0.964642956508425130, 0.964629777293818820, +0.964616595667638020, 0.964603411629915810, 0.964590225180685160, 0.964577036319978820, 0.964563845047829880, 0.964550651364271430, 0.964537455269335990, 0.964524256763057200, +0.964511055845467810, 0.964497852516600810, 0.964484646776489040, 0.964471438625165820, 0.964458228062663900, 0.964445015089016370, 0.964431799704256190, 0.964418581908416670, +0.964405361701530680, 0.964392139083631310, 0.964378914054751620, 0.964365686614924610, 0.964352456764183350, 0.964339224502560820, 0.964325989830090440, 0.964312752746805060, +0.964299513252737770, 0.964286271347921660, 0.964273027032389930, 0.964259780306175650, 0.964246531169311920, 0.964233279621831580, 0.964220025663768300, 0.964206769295155030, +0.964193510516024750, 0.964180249326410670, 0.964166985726346070, 0.964153719715863940, 0.964140451294997480, 0.964127180463779650, 0.964113907222244220, 0.964100631570423920, +0.964087353508352060, 0.964074073036061850, 0.964060790153586480, 0.964047504860959030, 0.964034217158212690, 0.964020927045381000, 0.964007634522496940, 0.963994339589593910, +0.963981042246704890, 0.963967742493863410, 0.963954440331102450, 0.963941135758455530, 0.963927828775955400, 0.963914519383636040, 0.963901207581530310, 0.963887893369671510, +0.963874576748093070, 0.963861257716828180, 0.963847936275910140, 0.963834612425372050, 0.963821286165247650, 0.963807957495570020, 0.963794626416372480, 0.963781292927688330, +0.963767957029550980, 0.963754618721993860, 0.963741278005050050, 0.963727934878752860, 0.963714589343136030, 0.963701241398232770, 0.963687891044076480, 0.963674538280700380, +0.963661183108137860, 0.963647825526422470, 0.963634465535587510, 0.963621103135666180, 0.963607738326692330, 0.963594371108699050, 0.963581001481719880, 0.963567629445788220, +0.963554255000937500, 0.963540878147201130, 0.963527498884612310, 0.963514117213205010, 0.963500733133012430, 0.963487346644067990, 0.963473957746405210, 0.963460566440057510, +0.963447172725058420, 0.963433776601441360, 0.963420378069239640, 0.963406977128487220, 0.963393573779217300, 0.963380168021463530, 0.963366759855259320, 0.963353349280638200, +0.963339936297633700, 0.963326520906279350, 0.963313103106608450, 0.963299682898655090, 0.963286260282452460, 0.963272835258034200, 0.963259407825433840, 0.963245977984685030, +0.963232545735821180, 0.963219111078875810, 0.963205674013882910, 0.963192234540875770, 0.963178792659888040, 0.963165348370953360, 0.963151901674105250, 0.963138452569377470, +0.963125001056803540, 0.963111547136416780, 0.963098090808251480, 0.963084632072340960, 0.963071170928718860, 0.963057707377418800, 0.963044241418474440, 0.963030773051919530, +0.963017302277787480, 0.963003829096112260, 0.962990353506927630, 0.962976875510267120, 0.962963395106164350, 0.962949912294653100, 0.962936427075767100, 0.962922939449539990, +0.962909449416005310, 0.962895956975197250, 0.962882462127149230, 0.962868964871895110, 0.962855465209468630, 0.962841963139903450, 0.962828458663233410, 0.962814951779492170, +0.962801442488713240, 0.962787930790931060, 0.962774416686179020, 0.962760900174490900, 0.962747381255900650, 0.962733859930441800, 0.962720336198148340, 0.962706810059053900, +0.962693281513192560, 0.962679750560598070, 0.962666217201304190, 0.962652681435344770, 0.962639143262753570, 0.962625602683564670, 0.962612059697811610, 0.962598514305528230, +0.962584966506748850, 0.962571416301507000, 0.962557863689836650, 0.962544308671771540, 0.962530751247345770, 0.962517191416593090, 0.962503629179547350, 0.962490064536242420, +0.962476497486712490, 0.962462928030991320, 0.962449356169112870, 0.962435781901111010, 0.962422205227019710, 0.962408626146872950, 0.962395044660704250, 0.962381460768548250, +0.962367874470438590, 0.962354285766409360, 0.962340694656494300, 0.962327101140727500, 0.962313505219142940, 0.962299906891774580, 0.962286306158656290, 0.962272703019822480, +0.962259097475306910, 0.962245489525143550, 0.962231879169366480, 0.962218266408009780, 0.962204651241107320, 0.962191033668693070, 0.962177413690801450, 0.962163791307466320, +0.962150166518721650, 0.962136539324601640, 0.962122909725140140, 0.962109277720371470, 0.962095643310329600, 0.962082006495048380, 0.962068367274562460, 0.962054725648905480, +0.962041081618111750, 0.962027435182215340, 0.962013786341250340, 0.962000135095250840, 0.961986481444251030, 0.961972825388284770, 0.961959166927386700, 0.961945506061590680, +0.961931842790930910, 0.961918177115441590, 0.961904509035156790, 0.961890838550110590, 0.961877165660337210, 0.961863490365871150, 0.961849812666746300, 0.961836132562996940, +0.961822450054657270, 0.961808765141761500, 0.961795077824343700, 0.961781388102438290, 0.961767695976079250, 0.961754001445301100, 0.961740304510137920, 0.961726605170624030, +0.961712903426793610, 0.961699199278680970, 0.961685492726320310, 0.961671783769745710, 0.961658072408991820, 0.961644358644092810, 0.961630642475082900, 0.961616923901996380, +0.961603202924867560, 0.961589479543730750, 0.961575753758620140, 0.961562025569569930, 0.961548294976614980, 0.961534561979789260, 0.961520826579127070, 0.961507088774662950, +0.961493348566430980, 0.961479605954465690, 0.961465860938801380, 0.961452113519472240, 0.961438363696512920, 0.961424611469957830, 0.961410856839841180, 0.961397099806197360, +0.961383340369060810, 0.961369578528465830, 0.961355814284446720, 0.961342047637038340, 0.961328278586274790, 0.961314507132190580, 0.961300733274820130, 0.961286957014197860, +0.961273178350358080, 0.961259397283335430, 0.961245613813164090, 0.961231827939878940, 0.961218039663514160, 0.961204248984104280, 0.961190455901683840, 0.961176660416287240, +0.961162862527948910, 0.961149062236703600, 0.961135259542585270, 0.961121454445629020, 0.961107646945869140, 0.961093837043340170, 0.961080024738076630, 0.961066210030113060, +0.961052392919483860, 0.961038573406223450, 0.961024751490366920, 0.961010927171948470, 0.960997100451002730, 0.960983271327564230, 0.960969439801667490, 0.960955605873347270, +0.960941769542637990, 0.960927930809573950, 0.960914089674190450, 0.960900246136521700, 0.960886400196602320, 0.960872551854466850, 0.960858701110150150, 0.960844847963686630, +0.960830992415110720, 0.960817134464457600, 0.960803274111761700, 0.960789411357057530, 0.960775546200379860, 0.960761678641763320, 0.960747808681242540, 0.960733936318852290, +0.960720061554626970, 0.960706184388601780, 0.960692304820811030, 0.960678422851289570, 0.960664538480072050, 0.960650651707193210, 0.960636762532687700, 0.960622870956590270, +0.960608976978935440, 0.960595080599758510, 0.960581181819093690, 0.960567280636976050, 0.960553377053440240, 0.960539471068520890, 0.960525562682252860, 0.960511651894670690, +0.960497738705809680, 0.960483823115704350, 0.960469905124389340, 0.960455984731899640, 0.960442061938269980, 0.960428136743535220, 0.960414209147730010, 0.960400279150889100, +0.960386346753047790, 0.960372411954240500, 0.960358474754502200, 0.960344535153867750, 0.960330593152372010, 0.960316648750049740, 0.960302701946935790, 0.960288752743064910, +0.960274801138472410, 0.960260847133192820, 0.960246890727261220, 0.960232931920712350, 0.960218970713581090, 0.960205007105902510, 0.960191041097711030, 0.960177072689042290, +0.960163101879930920, 0.960149128670411690, 0.960135153060519660, 0.960121175050289820, 0.960107194639756910, 0.960093211828956130, 0.960079226617922000, 0.960065239006690160, +0.960051248995295150, 0.960037256583772040, 0.960023261772155690, 0.960009264560481300, 0.959995264948783730, 0.959981262937097730, 0.959967258525458830, 0.959953251713901780, +0.959939242502461540, 0.959925230891173320, 0.959911216880071970, 0.959897200469192580, 0.959883181658570120, 0.959869160448239560, 0.959855136838236200, 0.959841110828595130, +0.959827082419351330, 0.959813051610539650, 0.959799018402195500, 0.959784982794353760, 0.959770944787049500, 0.959756904380317690, 0.959742861574193860, 0.959728816368712880, +0.959714768763909820, 0.959700718759819880, 0.959686666356478150, 0.959672611553919700, 0.959658554352179500, 0.959644494751293210, 0.959630432751295670, 0.959616368352221970, +0.959602301554107420, 0.959588232356987090, 0.959574160760896190, 0.959560086765869900, 0.959546010371943200, 0.959531931579151620, 0.959517850387530240, 0.959503766797114240, +0.959489680807938840, 0.959475592420039210, 0.959461501633450680, 0.959447408448208310, 0.959433312864347190, 0.959419214881903070, 0.959405114500910820, 0.959391011721405840, +0.959376906543423340, 0.959362798966998610, 0.959348688992166850, 0.959334576618963150, 0.959320461847423140, 0.959306344677582130, 0.959292225109475210, 0.959278103143137660, +0.959263978778604920, 0.959249852015912170, 0.959235722855094840, 0.959221591296188000, 0.959207457339227300, 0.959193320984248030, 0.959179182231285510, 0.959165041080375040, +0.959150897531551920, 0.959136751584851450, 0.959122603240309070, 0.959108452497960280, 0.959094299357840410, 0.959080143819984740, 0.959065985884428710, 0.959051825551207830, +0.959037662820357300, 0.959023497691912640, 0.959009330165908950, 0.958995160242382180, 0.958980987921367540, 0.958966813202900450, 0.958952636087016310, 0.958938456573750540, +0.958924274663138680, 0.958910090355216130, 0.958895903650018090, 0.958881714547580530, 0.958867523047938650, 0.958853329151128090, 0.958839132857184140, 0.958824934166142340, +0.958810733078038210, 0.958796529592906950, 0.958782323710784650, 0.958768115431706590, 0.958753904755708210, 0.958739691682825020, 0.958725476213092680, 0.958711258346546690, +0.958697038083222490, 0.958682815423155370, 0.958668590366381520, 0.958654362912936260, 0.958640133062855000, 0.958625900816173490, 0.958611666172927150, 0.958597429133151710, +0.958583189696882610, 0.958568947864155360, 0.958554703635005940, 0.958540457009469880, 0.958526207987582590, 0.958511956569379820, 0.958497702754897100, 0.958483446544170170, +0.958469187937234350, 0.958454926934125710, 0.958440663534879890, 0.958426397739532420, 0.958412129548118940, 0.958397858960675090, 0.958383585977236610, 0.958369310597839140, +0.958355032822518220, 0.958340752651309910, 0.958326470084249650, 0.958312185121373390, 0.958297897762716570, 0.958283608008315020, 0.958269315858204410, 0.958255021312420240, +0.958240724370998830, 0.958226425033975590, 0.958212123301386280, 0.958197819173266740, 0.958183512649652510, 0.958169203730579680, 0.958154892416083650, 0.958140578706200290, +0.958126262600965670, 0.958111944100415340, 0.958097623204585250, 0.958083299913511040, 0.958068974227228590, 0.958054646145773740, 0.958040315669182240, 0.958025982797489740, +0.958011647530732540, 0.957997309868946160, 0.957982969812166460, 0.957968627360429430, 0.957954282513770790, 0.957939935272226540, 0.957925585635832080, 0.957911233604623940, +0.957896879178637750, 0.957882522357909380, 0.957868163142474690, 0.957853801532369540, 0.957839437527629900, 0.957825071128291740, 0.957810702334390580, 0.957796331145962850, +0.957781957563044410, 0.957767581585671100, 0.957753203213878690, 0.957738822447703360, 0.957724439287180980, 0.957710053732347300, 0.957695665783238730, 0.957681275439890900, +0.957666882702339910, 0.957652487570621710, 0.957638090044772290, 0.957623690124827730, 0.957609287810823880, 0.957594883102796610, 0.957580476000782330, 0.957566066504816790, +0.957551654614936190, 0.957537240331176490, 0.957522823653573550, 0.957508404582163690, 0.957493983116982750, 0.957479559258066600, 0.957465133005451770, 0.957450704359174230, +0.957436273319269840, 0.957421839885774780, 0.957407404058725040, 0.957392965838156920, 0.957378525224106050, 0.957364082216609180, 0.957349636815702070, 0.957335189021420900, +0.957320738833801750, 0.957306286252880720, 0.957291831278693990, 0.957277373911277650, 0.957262914150667670, 0.957248451996900670, 0.957233987450012540, 0.957219520510039450, +0.957205051177017490, 0.957190579450982960, 0.957176105331971950, 0.957161628820020650, 0.957147149915165030, 0.957132668617441840, 0.957118184926887050, 0.957103698843536630, +0.957089210367427110, 0.957074719498594460, 0.957060226237075100, 0.957045730582904870, 0.957031232536120550, 0.957016732096758190, 0.957002229264853900, 0.956987724040444190, +0.956973216423565030, 0.956958706414252960, 0.956944194012544050, 0.956929679218474380, 0.956915162032080820, 0.956900642453399340, 0.956886120482466240, 0.956871596119317820, +0.956857069363990400, 0.956842540216520380, 0.956828008676943730, 0.956813474745297320, 0.956798938421617230, 0.956784399705939760, 0.956769858598301330, 0.956755315098738120, +0.956740769207286790, 0.956726220923983520, 0.956711670248864390, 0.956697117181966260, 0.956682561723325440, 0.956668003872978230, 0.956653443630961050, 0.956638880997310090, +0.956624315972062100, 0.956609748555253270, 0.956595178746919790, 0.956580606547098640, 0.956566031955825900, 0.956551454973138200, 0.956536875599071750, 0.956522293833663160, +0.956507709676948870, 0.956493123128965060, 0.956478534189748600, 0.956463942859335890, 0.956449349137763250, 0.956434753025067310, 0.956420154521284480, 0.956405553626451300, +0.956390950340604170, 0.956376344663779410, 0.956361736596014090, 0.956347126137344410, 0.956332513287806880, 0.956317898047438050, 0.956303280416274550, 0.956288660394352790, +0.956274037981709400, 0.956259413178380700, 0.956244785984403660, 0.956230156399814680, 0.956215524424650300, 0.956200890058947150, 0.956186253302741760, 0.956171614156070770, +0.956156972618970370, 0.956142328691477860, 0.956127682373629550, 0.956113033665462080, 0.956098382567011960, 0.956083729078315850, 0.956069073199410480, 0.956054414930332390, +0.956039754271118090, 0.956025091221804570, 0.956010425782428340, 0.955995757953026050, 0.955981087733634330, 0.955966415124289930, 0.955951740125029590, 0.955937062735889520, +0.955922382956907010, 0.955907700788118710, 0.955893016229561020, 0.955878329281270810, 0.955863639943284830, 0.955848948215639700, 0.955834254098372190, 0.955819557591518820, +0.955804858695116890, 0.955790157409202700, 0.955775453733813120, 0.955760747668984890, 0.955746039214754870, 0.955731328371159710, 0.955716615138236250, 0.955701899516021030, +0.955687181504551230, 0.955672461103863500, 0.955657738313994700, 0.955643013134981460, 0.955628285566860750, 0.955613555609669320, 0.955598823263443700, 0.955584088528221300, +0.955569351404038650, 0.955554611890932710, 0.955539869988940140, 0.955525125698098000, 0.955510379018442930, 0.955495629950012030, 0.955480878492841690, 0.955466124646969450, +0.955451368412431950, 0.955436609789265920, 0.955421848777508460, 0.955407085377196320, 0.955392319588366570, 0.955377551411055960, 0.955362780845301130, 0.955348007891139720, +0.955333232548608250, 0.955318454817743690, 0.955303674698583020, 0.955288892191163090, 0.955274107295520980, 0.955259320011693450, 0.955244530339717680, 0.955229738279630760, +0.955214943831469430, 0.955200146995270670, 0.955185347771071670, 0.955170546158909170, 0.955155742158820380, 0.955140935770842030, 0.955126126995011540, 0.955111315831365660, +0.955096502279941580, 0.955081686340776170, 0.955066868013906610, 0.955052047299369880, 0.955037224197202830, 0.955022398707442880, 0.955007570830126990, 0.954992740565292150, +0.954977907912975430, 0.954963072873213910, 0.954948235446044790, 0.954933395631505140, 0.954918553429631610, 0.954903708840462050, 0.954888861864033100, 0.954874012500382060, +0.954859160749546020, 0.954844306611562050, 0.954829450086467360, 0.954814591174299010, 0.954799729875093870, 0.954784866188889800, 0.954770000115723440, 0.954755131655632190, +0.954740260808653040, 0.954725387574823170, 0.954710511954179890, 0.954695633946760160, 0.954680753552601510, 0.954665870771741030, 0.954650985604215800, 0.954636098050063110, +0.954621208109320270, 0.954606315782024370, 0.954591421068212600, 0.954576523967922140, 0.954561624481190530, 0.954546722608054950, 0.954531818348552500, 0.954516911702720460, +0.954502002670596260, 0.954487091252216980, 0.954472177447620030, 0.954457261256842270, 0.954442342679921670, 0.954427421716895210, 0.954412498367800290, 0.954397572632674000, +0.954382644511553860, 0.954367714004477060, 0.954352781111480700, 0.954337845832602730, 0.954322908167880010, 0.954307968117350190, 0.954293025681050340, 0.954278080859017890, +0.954263133651290340, 0.954248184057904900, 0.954233232078898760, 0.954218277714309780, 0.954203320964175150, 0.954188361828532170, 0.954173400307418370, 0.954158436400870950, +0.954143470108927530, 0.954128501431625090, 0.954113530369001710, 0.954098556921094580, 0.954083581087940890, 0.954068602869578400, 0.954053622266044290, 0.954038639277376200, +0.954023653903611550, 0.954008666144787410, 0.953993676000941870, 0.953978683472112120, 0.953963688558335800, 0.953948691259650090, 0.953933691576092760, 0.953918689507701200, +0.953903685054512840, 0.953888678216565090, 0.953873668993895920, 0.953858657386542520, 0.953843643394542420, 0.953828627017933360, 0.953813608256752650, 0.953798587111037930, +0.953783563580826390, 0.953768537666156320, 0.953753509367064930, 0.953738478683589630, 0.953723445615768270, 0.953708410163638280, 0.953693372327237170, 0.953678332106602690, +0.953663289501772150, 0.953648244512783630, 0.953633197139674430, 0.953618147382482300, 0.953603095241244760, 0.953588040715999560, 0.953572983806784240, 0.953557924513636410, +0.953542862836593510, 0.953527798775693710, 0.953512732330974440, 0.953497663502473340, 0.953482592290228140, 0.953467518694276370, 0.953452442714655790, 0.953437364351403920, +0.953422283604558940, 0.953407200474158170, 0.953392114960239350, 0.953377027062840330, 0.953361936781998760, 0.953346844117752280, 0.953331749070138730, 0.953316651639195540, +0.953301551824960900, 0.953286449627472440, 0.953271345046767920, 0.953256238082884950, 0.953241128735861420, 0.953226017005735060, 0.953210902892543400, 0.953195786396324850, +0.953180667517116720, 0.953165546254956860, 0.953150422609883250, 0.953135296581933520, 0.953120168171145640, 0.953105037377557250, 0.953089904201206100, 0.953074768642130370, +0.953059630700367700, 0.953044490375955950, 0.953029347668933100, 0.953014202579336780, 0.952999055107204950, 0.952983905252575480, 0.952968753015486000, 0.952953598395974930, +0.952938441394079790, 0.952923282009838670, 0.952908120243289190, 0.952892956094469560, 0.952877789563417510, 0.952862620650170580, 0.952847449354767510, 0.952832275677245820, +0.952817099617643380, 0.952801921175998160, 0.952786740352348230, 0.952771557146731340, 0.952756371559185690, 0.952741183589748800, 0.952725993238459190, 0.952710800505354620, +0.952695605390473040, 0.952680407893852440, 0.952665208015530780, 0.952650005755546150, 0.952634801113936170, 0.952619594090739600, 0.952604384685993950, 0.952589172899737320, +0.952573958732007790, 0.952558742182843420, 0.952543523252282090, 0.952528301940361980, 0.952513078247120840, 0.952497852172597300, 0.952482623716829120, 0.952467392879854380, +0.952452159661711260, 0.952436924062437630, 0.952421686082071670, 0.952406445720651580, 0.952391202978215000, 0.952375957854800780, 0.952360710350446670, 0.952345460465190750, +0.952330208199071100, 0.952314953552126030, 0.952299696524393610, 0.952284437115911600, 0.952269175326718730, 0.952253911156852980, 0.952238644606352550, 0.952223375675255390, +0.952208104363599820, 0.952192830671423910, 0.952177554598766070, 0.952162276145663950, 0.952146995312156520, 0.952131712098281510, 0.952116426504077240, 0.952101138529581890, +0.952085848174833770, 0.952070555439870960, 0.952055260324731760, 0.952039962829454240, 0.952024662954076950, 0.952009360698638060, 0.951994056063175780, 0.951978749047728390, +0.951963439652334100, 0.951948127877031200, 0.951932813721857670, 0.951917497186852370, 0.951902178272053370, 0.951886856977498970, 0.951871533303227380, 0.951856207249277000, +0.951840878815686020, 0.951825548002492860, 0.951810214809735600, 0.951794879237453100, 0.951779541285683320, 0.951764200954464790, 0.951748858243835700, 0.951733513153834480, +0.951718165684499410, 0.951702815835868800, 0.951687463607981290, 0.951672109000875180, 0.951656752014588770, 0.951641392649160480, 0.951626030904628720, 0.951610666781031900, +0.951595300278408330, 0.951579931396796310, 0.951564560136234800, 0.951549186496761790, 0.951533810478415790, 0.951518432081235320, 0.951503051305258810, 0.951487668150524660, +0.951472282617071290, 0.951456894704937000, 0.951441504414160640, 0.951426111744780640, 0.951410716696835300, 0.951395319270363140, 0.951379919465402680, 0.951364517281992560, +0.951349112720170750, 0.951333705779976450, 0.951318296461447830, 0.951302884764623550, 0.951287470689542110, 0.951272054236241840, 0.951256635404761570, 0.951241214195139630, +0.951225790607414410, 0.951210364641625010, 0.951194936297809710, 0.951179505576007060, 0.951164072476255560, 0.951148636998593980, 0.951133199143060830, 0.951117758909694520, +0.951102316298533700, 0.951086871309617330, 0.951071423942983720, 0.951055974198671610, 0.951040522076719520, 0.951025067577166210, 0.951009610700050190, 0.950994151445409770, +0.950978689813284370, 0.950963225803712180, 0.950947759416731930, 0.950932290652382380, 0.950916819510701950, 0.950901345991729600, 0.950885870095503850, 0.950870391822063120, +0.950854911171446720, 0.950839428143693040, 0.950823942738840740, 0.950808454956928560, 0.950792964797995350, 0.950777472262079650, 0.950761977349220080, 0.950746480059455720, +0.950730980392825220, 0.950715478349367320, 0.950699973929120650, 0.950684467132124070, 0.950668957958416330, 0.950653446408036170, 0.950637932481022240, 0.950622416177413610, +0.950606897497249030, 0.950591376440567130, 0.950575853007406880, 0.950560327197806920, 0.950544799011806110, 0.950529268449443410, 0.950513735510757130, 0.950498200195786900, +0.950482662504571140, 0.950467122437148700, 0.950451579993558560, 0.950436035173839340, 0.950420487978030140, 0.950404938406169350, 0.950389386458296510, 0.950373832134450260, +0.950358275434669330, 0.950342716358992810, 0.950327154907459450, 0.950311591080108210, 0.950296024876977950, 0.950280456298107420, 0.950264885343536040, 0.950249312013302430, +0.950233736307445450, 0.950218158226004190, 0.950202577769017620, 0.950186994936524480, 0.950171409728563950, 0.950155822145174580, 0.950140232186395870, 0.950124639852266690, +0.950109045142825900, 0.950093448058112470, 0.950077848598165350, 0.950062246763023640, 0.950046642552726080, 0.950031035967312200, 0.950015427006820730, 0.949999815671290660, +0.949984201960761050, 0.949968585875270890, 0.949952967414859350, 0.949937346579565410, 0.949921723369427710, 0.949906097784486090, 0.949890469824779200, 0.949874839490346120, +0.949859206781225930, 0.949843571697457700, 0.949827934239080630, 0.949812294406133350, 0.949796652198655610, 0.949781007616686380, 0.949765360660264510, 0.949749711329429200, +0.949734059624219750, 0.949718405544675020, 0.949702749090834410, 0.949687090262736570, 0.949671429060421230, 0.949655765483927380, 0.949640099533294200, 0.949624431208560660, +0.949608760509766060, 0.949593087436949590, 0.949577411990150330, 0.949561734169407370, 0.949546053974760220, 0.949530371406248070, 0.949514686463909910, 0.949498999147785020, +0.949483309457912710, 0.949467617394332050, 0.949451922957082140, 0.949436226146202600, 0.949420526961732620, 0.949404825403711290, 0.949389121472177800, 0.949373415167171660, +0.949357706488731860, 0.949341995436897790, 0.949326282011708540, 0.949310566213203870, 0.949294848041422720, 0.949279127496404420, 0.949263404578188360, 0.949247679286813750, +0.949231951622319990, 0.949216221584746390, 0.949200489174131910, 0.949184754390516420, 0.949169017233939090, 0.949153277704439250, 0.949137535802056180, 0.949121791526829290, +0.949106044878797910, 0.949090295858001200, 0.949074544464478920, 0.949058790698270370, 0.949043034559414860, 0.949027276047951670, 0.949011515163920350, 0.948995751907360190, +0.948979986278310710, 0.948964218276810990, 0.948948447902900890, 0.948932675156619830, 0.948916900038006990, 0.948901122547101910, 0.948885342683944090, 0.948869560448572850, +0.948853775841027370, 0.948837988861347850, 0.948822199509573250, 0.948806407785743210, 0.948790613689897140, 0.948774817222074570, 0.948759018382314910, 0.948743217170657790, +0.948727413587142300, 0.948711607631808510, 0.948695799304695720, 0.948679988605843460, 0.948664175535291250, 0.948648360093078510, 0.948632542279244980, 0.948616722093829970, +0.948600899536872990, 0.948585074608414010, 0.948569247308492350, 0.948553417637147510, 0.948537585594419250, 0.948521751180346870, 0.948505914394970230, 0.948490075238328510, +0.948474233710461800, 0.948458389811409620, 0.948442543541211380, 0.948426694899906830, 0.948410843887535490, 0.948394990504137110, 0.948379134749751220, 0.948363276624417220, +0.948347416128175300, 0.948331553261064770, 0.948315688023125490, 0.948299820414396870, 0.948283950434918750, 0.948268078084730790, 0.948252203363872390, 0.948236326272383630, +0.948220446810304150, 0.948204564977673580, 0.948188680774531560, 0.948172794200917820, 0.948156905256872020, 0.948141013942434110, 0.948125120257643280, 0.948109224202539960, +0.948093325777163540, 0.948077424981553900, 0.948061521815750650, 0.948045616279793560, 0.948029708373722470, 0.948013798097577130, 0.947997885451396960, 0.947981970435222370, +0.947966053049092870, 0.947950133293048340, 0.947934211167128280, 0.947918286671372790, 0.947902359805821600, 0.947886430570514250, 0.947870498965491030, 0.947854564990791570, +0.947838628646455740, 0.947822689932523390, 0.947806748849034260, 0.947790805396028220, 0.947774859573545240, 0.947758911381624710, 0.947742960820307290, 0.947727007889632490, +0.947711052589640060, 0.947695094920370070, 0.947679134881862280, 0.947663172474156770, 0.947647207697293270, 0.947631240551311430, 0.947615271036251870, 0.947599299152154020, +0.947583324899057940, 0.947567348277003620, 0.947551369286030900, 0.947535387926179750, 0.947519404197489810, 0.947503418100001720, 0.947487429633754990, 0.947471438798789810, +0.947455445595145940, 0.947439450022863450, 0.947423452081982420, 0.947407451772542710, 0.947391449094584060, 0.947375444048147110, 0.947359436633271490, 0.947343426849997280, +0.947327414698364570, 0.947311400178413310, 0.947295383290183590, 0.947279364033715040, 0.947263342409048410, 0.947247318416223450, 0.947231292055280120, 0.947215263326258610, +0.947199232229198880, 0.947183198764141140, 0.947167162931125460, 0.947151124730191470, 0.947135084161380040, 0.947119041224730780, 0.947102995920284020, 0.947086948248079820, +0.947070898208158150, 0.947054845800559210, 0.947038791025323290, 0.947022733882490030, 0.947006674372100180, 0.946990612494193700, 0.946974548248810670, 0.946958481635991280, +0.946942412655775610, 0.946926341308203970, 0.946910267593316200, 0.946894191511153060, 0.946878113061754400, 0.946862032245160520, 0.946845949061411510, 0.946829863510547650, +0.946813775592609150, 0.946797685307636190, 0.946781592655668750, 0.946765497636747550, 0.946749400250912700, 0.946733300498204260, 0.946717198378662640, 0.946701093892327930, +0.946684987039240530, 0.946668877819440760, 0.946652766232968460, 0.946636652279864490, 0.946620535960168820, 0.946604417273921970, 0.946588296221163920, 0.946572172801935290, +0.946556047016276050, 0.946539918864226500, 0.946523788345827510, 0.946507655461118920, 0.946491520210141270, 0.946475382592934840, 0.946459242609539950, 0.946443100259996890, +0.946426955544346080, 0.946410808462627710, 0.946394659014882510, 0.946378507201150690, 0.946362353021472540, 0.946346196475888580, 0.946330037564439120, 0.946313876287164570, +0.946297712644105000, 0.946281546635301400, 0.946265378260794040, 0.946249207520623250, 0.946233034414829310, 0.946216858943452870, 0.946200681106534320, 0.946184500904113990, +0.946168318336232160, 0.946152133402929810, 0.946135946104247120, 0.946119756440224500, 0.946103564410902600, 0.946087370016321820, 0.946071173256522460, 0.946054974131545270, +0.946038772641430330, 0.946022568786218820, 0.946006362565950830, 0.945990153980666880, 0.945973943030407600, 0.945957729715213520, 0.945941514035125050, 0.945925295990182490, +0.945909075580427030, 0.945892852805898850, 0.945876627666638490, 0.945860400162686690, 0.945844170294083740, 0.945827938060870510, 0.945811703463087290, 0.945795466500774620, +0.945779227173973560, 0.945762985482724420, 0.945746741427067830, 0.945730495007044310, 0.945714246222694620, 0.945697995074059380, 0.945681741561179010, 0.945665485684094140, +0.945649227442845740, 0.945632966837474330, 0.945616703868020550, 0.945600438534524910, 0.945584170837028170, 0.945567900775571070, 0.945551628350193910, 0.945535353560937990, +0.945519076407843610, 0.945502796890951620, 0.945486515010302560, 0.945470230765937280, 0.945453944157896410, 0.945437655186220690, 0.945421363850950550, 0.945405070152127270, +0.945388774089791270, 0.945372475663983410, 0.945356174874744330, 0.945339871722114760, 0.945323566206135560, 0.945307258326847140, 0.945290948084290930, 0.945274635478507320, +0.945258320509537060, 0.945242003177421020, 0.945225683482200040, 0.945209361423914760, 0.945193037002606150, 0.945176710218314620, 0.945160381071081580, 0.945144049560947660, +0.945127715687953620, 0.945111379452140190, 0.945095040853548450, 0.945078699892219040, 0.945062356568192820, 0.945046010881510520, 0.945029662832213460, 0.945013312420342140, +0.944996959645937660, 0.944980604509040760, 0.944964247009692280, 0.944947887147933210, 0.944931524923804170, 0.944915160337346570, 0.944898793388601170, 0.944882424077608700, +0.944866052404410130, 0.944849678369046540, 0.944833301971558680, 0.944816923211987510, 0.944800542090373900, 0.944784158606759130, 0.944767772761183950, 0.944751384553689340, +0.944734993984316260, 0.944718601053105790, 0.944702205760098780, 0.944685808105336200, 0.944669408088858800, 0.944653005710708200, 0.944636600970925170, 0.944620193869550540, +0.944603784406625400, 0.944587372582190940, 0.944570958396287910, 0.944554541848957260, 0.944538122940240530, 0.944521701670178460, 0.944505278038812120, 0.944488852046182710, +0.944472423692331090, 0.944455992977298430, 0.944439559901125710, 0.944423124463853900, 0.944406686665524520, 0.944390246506178420, 0.944373803985856800, 0.944357359104600500, +0.944340911862450950, 0.944324462259449100, 0.944308010295635710, 0.944291555971052630, 0.944275099285740720, 0.944258640239741040, 0.944242178833094690, 0.944225715065842960, +0.944209248938026930, 0.944192780449687800, 0.944176309600866400, 0.944159836391604500, 0.944143360821942950, 0.944126882891923150, 0.944110402601586070, 0.944093919950972920, +0.944077434940125080, 0.944060947569083650, 0.944044457837889480, 0.944027965746584430, 0.944011471295209570, 0.943994974483805980, 0.943978475312414970, 0.943961973781077820, +0.943945469889835630, 0.943928963638729580, 0.943912455027801300, 0.943895944057091980, 0.943879430726642820, 0.943862915036495000, 0.943846396986689930, 0.943829876577268800, +0.943813353808273030, 0.943796828679743680, 0.943780301191722400, 0.943763771344250490, 0.943747239137369020, 0.943730704571119520, 0.943714167645543280, 0.943697628360681610, +0.943681086716575580, 0.943664542713267160, 0.943647996350797320, 0.943631447629207480, 0.943614896548539140, 0.943598343108833390, 0.943581787310131870, 0.943565229152475870, +0.943548668635906580, 0.943532105760465870, 0.943515540526194800, 0.943498972933135010, 0.943482402981327680, 0.943465830670814460, 0.943449256001636540, 0.943432678973835540, +0.943416099587452540, 0.943399517842529620, 0.943382933739107870, 0.943366347277228790, 0.943349758456933810, 0.943333167278264550, 0.943316573741262210, 0.943299977845968310, +0.943283379592424590, 0.943266778980672570, 0.943250176010753560, 0.943233570682709080, 0.943216962996580640, 0.943200352952409890, 0.943183740550238130, 0.943167125790106860, +0.943150508672057960, 0.943133889196132840, 0.943117267362373000, 0.943100643170819990, 0.943084016621515420, 0.943067387714500720, 0.943050756449817620, 0.943034122827507320, +0.943017486847612000, 0.943000848510172850, 0.942984207815231730, 0.942967564762830060, 0.942950919353009450, 0.942934271585811560, 0.942917621461277670, 0.942900968979450080, +0.942884314140369990, 0.942867656944079150, 0.942850997390619170, 0.942834335480031700, 0.942817671212358490, 0.942801004587640930, 0.942784335605920680, 0.942767664267239900, +0.942750990571639910, 0.942734314519162450, 0.942717636109849160, 0.942700955343741760, 0.942684272220882020, 0.942667586741311350, 0.942650898905072030, 0.942634208712205380, +0.942617516162753240, 0.942600821256757260, 0.942584123994259280, 0.942567424375301060, 0.942550722399924100, 0.942534018068170170, 0.942517311380081440, 0.942500602335699540, +0.942483890935066020, 0.942467177178222810, 0.942450461065211580, 0.942433742596074260, 0.942417021770852630, 0.942400298589588070, 0.942383573052323120, 0.942366845159099300, +0.942350114909958240, 0.942333382304941900, 0.942316647344092150, 0.942299910027450840, 0.942283170355059370, 0.942266428326960280, 0.942249683943195190, 0.942232937203805850, +0.942216188108834120, 0.942199436658321950, 0.942182682852311220, 0.942165926690843760, 0.942149168173961100, 0.942132407301706000, 0.942115644074119740, 0.942098878491244410, +0.942082110553121850, 0.942065340259794050, 0.942048567611302960, 0.942031792607690430, 0.942015015248998000, 0.941998235535268400, 0.941981453466543270, 0.941964669042864470, +0.941947882264273950, 0.941931093130813800, 0.941914301642525880, 0.941897507799451920, 0.941880711601634450, 0.941863913049115320, 0.941847112141936280, 0.941830308880139520, +0.941813503263766890, 0.941796695292860590, 0.941779884967462570, 0.941763072287614580, 0.941746257253359140, 0.941729439864738000, 0.941712620121793350, 0.941695798024567150, +0.941678973573101370, 0.941662146767438200, 0.941645317607619380, 0.941628486093687540, 0.941611652225684550, 0.941594816003652360, 0.941577977427633160, 0.941561136497669040, +0.941544293213802060, 0.941527447576074320, 0.941510599584527650, 0.941493749239204810, 0.941476896540147660, 0.941460041487398150, 0.941443184080998700, 0.941426324320991160, +0.941409462207417840, 0.941392597740320800, 0.941375730919742030, 0.941358861745724250, 0.941341990218309330, 0.941325116337539350, 0.941308240103456710, 0.941291361516103380, +0.941274480575521650, 0.941257597281753400, 0.941240711634841460, 0.941223823634827820, 0.941206933281754530, 0.941190040575664020, 0.941173145516598250, 0.941156248104599750, +0.941139348339710580, 0.941122446221972720, 0.941105541751429130, 0.941088634928121560, 0.941071725752092520, 0.941054814223384110, 0.941037900342038600, 0.941020984108098420, +0.941004065521605760, 0.940987144582602690, 0.940970221291131950, 0.940953295647235730, 0.940936367650956340, 0.940919437302335960, 0.940902504601416890, 0.940885569548241650, +0.940868632142852210, 0.940851692385291430, 0.940834750275601480, 0.940817805813824680, 0.940800859000003320, 0.940783909834179810, 0.940766958316396450, 0.940750004446695760, +0.940733048225119830, 0.940716089651711500, 0.940699128726512960, 0.940682165449566620, 0.940665199820914900, 0.940648231840600090, 0.940631261508664720, 0.940614288825150970, +0.940597313790101700, 0.940580336403559200, 0.940563356665565900, 0.940546374576164080, 0.940529390135396490, 0.940512403343305330, 0.940495414199933100, 0.940478422705322110, +0.940461428859515450, 0.940444432662555060, 0.940427434114483710, 0.940410433215343680, 0.940393429965177610, 0.940376424364028020, 0.940359416411937320, 0.940342406108947700, +0.940325393455102470, 0.940308378450443790, 0.940291361095014100, 0.940274341388856020, 0.940257319332012060, 0.940240294924524770, 0.940223268166436530, 0.940206239057790330, +0.940189207598628670, 0.940172173788993870, 0.940155137628928660, 0.940138099118475570, 0.940121058257677330, 0.940104015046576370, 0.940086969485215080, 0.940069921573636780, +0.940052871311883530, 0.940035818699998190, 0.940018763738023290, 0.940001706426001450, 0.939984646763975310, 0.939967584751987610, 0.939950520390080650, 0.939933453678297610, +0.939916384616681030, 0.939899313205273530, 0.939882239444117640, 0.939865163333256200, 0.939848084872731860, 0.939831004062587020, 0.939813920902864860, 0.939796835393608030, +0.939779747534859040, 0.939762657326660760, 0.939745564769055690, 0.939728469862086800, 0.939711372605796740, 0.939694273000228010, 0.939677171045423810, 0.939660066741426660, +0.939642960088279410, 0.939625851086024810, 0.939608739734705490, 0.939591626034364300, 0.939574509985043770, 0.939557391586787300, 0.939540270839637310, 0.939523147743636770, +0.939506022298828180, 0.939488894505254630, 0.939471764362958870, 0.939454631871983640, 0.939437497032371560, 0.939420359844166050, 0.939403220307409530, 0.939386078422145050, +0.939368934188415380, 0.939351787606263370, 0.939334638675731970, 0.939317487396863830, 0.939300333769701790, 0.939283177794289160, 0.939266019470668570, 0.939248858798882870, +0.939231695778975140, 0.939214530410988120, 0.939197362694964790, 0.939180192630947760, 0.939163020218980570, 0.939145845459105840, 0.939128668351366440, 0.939111488895805310, +0.939094307092465550, 0.939077122941390010, 0.939059936442621650, 0.939042747596203210, 0.939025556402178110, 0.939008362860589200, 0.938991166971479330, 0.938973968734891580, +0.938956768150868930, 0.938939565219454210, 0.938922359940690400, 0.938905152314621020, 0.938887942341288690, 0.938870730020736510, 0.938853515353007540, 0.938836298338144750, +0.938819078976191210, 0.938801857267190010, 0.938784633211183880, 0.938767406808216460, 0.938750178058330500, 0.938732946961569060, 0.938715713517975340, 0.938698477727592300, +0.938681239590463010, 0.938663999106630680, 0.938646756276138030, 0.938629511099028810, 0.938612263575345770, 0.938595013705132100, 0.938577761488430970, 0.938560506925285360, +0.938543250015738460, 0.938525990759833120, 0.938508729157613190, 0.938491465209121410, 0.938474198914400980, 0.938456930273494970, 0.938439659286446680, 0.938422385953299300, +0.938405110274095900, 0.938387832248879450, 0.938370551877693690, 0.938353269160581480, 0.938335984097586230, 0.938318696688751010, 0.938301406934119010, 0.938284114833733420, +0.938266820387637650, 0.938249523595874550, 0.938232224458487860, 0.938214922975520560, 0.938197619147016050, 0.938180312973017520, 0.938163004453568150, 0.938145693588711250, +0.938128380378489890, 0.938111064822947820, 0.938093746922128100, 0.938076426676074050, 0.938059104084828840, 0.938041779148436010, 0.938024451866938610, 0.938007122240380190, +0.937989790268803580, 0.937972455952252760, 0.937955119290770910, 0.937937780284401220, 0.937920438933187000, 0.937903095237171750, 0.937885749196398780, 0.937868400810911160, +0.937851050080752760, 0.937833697005966750, 0.937816341586596550, 0.937798983822685450, 0.937781623714276980, 0.937764261261414320, 0.937746896464141110, 0.937729529322500310, +0.937712159836536000, 0.937694788006291250, 0.937677413831809580, 0.937660037313134410, 0.937642658450309030, 0.937625277243377080, 0.937607893692381960, 0.937590507797366750, +0.937573119558375630, 0.937555728975451700, 0.937538336048638450, 0.937520940777979320, 0.937503543163517810, 0.937486143205297550, 0.937468740903361520, 0.937451336257754010, +0.937433929268518100, 0.937416519935697410, 0.937399108259335480, 0.937381694239475700, 0.937364277876161720, 0.937346859169436940, 0.937329438119344880, 0.937312014725929400, +0.937294588989233900, 0.937277160909302020, 0.937259730486177170, 0.937242297719902970, 0.937224862610523070, 0.937207425158080980, 0.937189985362620100, 0.937172543224184530, +0.937155098742817550, 0.937137651918562800, 0.937120202751464020, 0.937102751241564720, 0.937085297388908440, 0.937067841193538700, 0.937050382655499670, 0.937032921774834660, +0.937015458551587300, 0.936997992985801330, 0.936980525077520390, 0.936963054826788210, 0.936945582233648320, 0.936928107298144130, 0.936910630020320050, 0.936893150400219250, +0.936875668437885720, 0.936858184133362970, 0.936840697486694850, 0.936823208497924890, 0.936805717167096600, 0.936788223494254390, 0.936770727479441570, 0.936753229122701870, +0.936735728424079150, 0.936718225383617150, 0.936700720001359620, 0.936683212277350190, 0.936665702211632480, 0.936648189804250800, 0.936630675055248660, 0.936613157964669820, +0.936595638532558120, 0.936578116758957300, 0.936560592643911230, 0.936543066187463640, 0.936525537389658050, 0.936508006250538980, 0.936490472770149850, 0.936472936948534510, +0.936455398785736910, 0.936437858281800710, 0.936420315436769960, 0.936402770250688080, 0.936385222723599590, 0.936367672855548010, 0.936350120646577300, 0.936332566096731210, +0.936315009206053820, 0.936297449974588860, 0.936279888402380190, 0.936262324489471660, 0.936244758235907470, 0.936227189641731460, 0.936209618706987490, 0.936192045431719410, +0.936174469815971300, 0.936156891859786900, 0.936139311563210400, 0.936121728926285200, 0.936104143949056060, 0.936086556631566590, 0.936068966973860660, 0.936051374975982340, +0.936033780637975600, 0.936016183959884400, 0.935998584941752370, 0.935980983583624250, 0.935963379885543680, 0.935945773847554620, 0.935928165469701150, 0.935910554752027220, +0.935892941694576930, 0.935875326297394340, 0.935857708560523080, 0.935840088484007900, 0.935822466067892430, 0.935804841312220860, 0.935787214217037140, 0.935769584782385370, +0.935751953008309710, 0.935734318894853810, 0.935716682442062410, 0.935699043649979360, 0.935681402518648620, 0.935663759048114390, 0.935646113238420840, 0.935628465089611950, +0.935610814601731900, 0.935593161774824540, 0.935575506608934520, 0.935557849104105780, 0.935540189260382400, 0.935522527077808590, 0.935504862556428400, 0.935487195696286130, +0.935469526497425760, 0.935451854959891360, 0.935434181083727560, 0.935416504868978430, 0.935398826315687940, 0.935381145423900380, 0.935363462193659960, 0.935345776625010950, +0.935328088717997110, 0.935310398472663400, 0.935292705889053670, 0.935275010967212220, 0.935257313707183240, 0.935239614109010910, 0.935221912172739640, 0.935204207898413520, +0.935186501286076610, 0.935168792335773660, 0.935151081047548850, 0.935133367421446260, 0.935115651457510300, 0.935097933155785150, 0.935080212516315230, 0.935062489539144840, +0.935044764224317810, 0.935027036571879240, 0.935009306581872980, 0.934991574254343540, 0.934973839589335110, 0.934956102586892210, 0.934938363247058920, 0.934920621569879430, +0.934902877555398800, 0.934885131203660900, 0.934867382514710130, 0.934849631488590900, 0.934831878125347630, 0.934814122425024710, 0.934796364387666450, 0.934778604013317030, +0.934760841302021310, 0.934743076253823470, 0.934725308868768030, 0.934707539146899300, 0.934689767088261680, 0.934671992692899690, 0.934654215960857400, 0.934636436892179790, +0.934618655486911250, 0.934600871745095980, 0.934583085666778500, 0.934565297252003320, 0.934547506500814970, 0.934529713413257750, 0.934511917989376050, 0.934494120229214740, +0.934476320132818230, 0.934458517700230920, 0.934440712931497220, 0.934422905826661880, 0.934405096385769180, 0.934387284608863780, 0.934369470495989840, 0.934351654047192560, +0.934333835262516010, 0.934316014142005050, 0.934298190685703970, 0.934280364893657400, 0.934262536765909980, 0.934244706302505890, 0.934226873503490320, 0.934209038368907560, +0.934191200898802250, 0.934173361093218910, 0.934155518952202170, 0.934137674475796650, 0.934119827664046890, 0.934101978516997280, 0.934084127034693010, 0.934066273217178500, +0.934048417064498260, 0.934030558576696920, 0.934012697753819230, 0.933994834595909820, 0.933976969103013310, 0.933959101275174120, 0.933941231112437430, 0.933923358614847650, +0.933905483782449530, 0.933887606615287690, 0.933869727113406770, 0.933851845276851610, 0.933833961105666410, 0.933816074599896680, 0.933798185759586840, 0.933780294584781510, +0.933762401075525330, 0.933744505231863250, 0.933726607053839920, 0.933708706541500070, 0.933690803694888110, 0.933672898514049440, 0.933654990999028490, 0.933637081149870100, +0.933619168966619010, 0.933601254449320070, 0.933583337598017930, 0.933565418412757090, 0.933547496893583070, 0.933529573040540290, 0.933511646853673600, 0.933493718333027860, +0.933475787478647680, 0.933457854290578150, 0.933439918768863900, 0.933421980913549550, 0.933404040724680640, 0.933386098202301560, 0.933368153346457290, 0.933350206157192550, +0.933332256634552330, 0.933314304778581460, 0.933296350589324810, 0.933278394066827110, 0.933260435211133550, 0.933242474022288990, 0.933224510500338280, 0.933206544645326260, +0.933188576457297910, 0.933170605936298080, 0.933152633082371400, 0.933134657895563490, 0.933116680375918990, 0.933098700523482650, 0.933080718338299640, 0.933062733820414820, +0.933044746969873160, 0.933026757786719730, 0.933008766270998930, 0.932990772422756630, 0.932972776242037450, 0.932954777728886240, 0.932936776883348080, 0.932918773705468050, +0.932900768195291000, 0.932882760352861770, 0.932864750178225900, 0.932846737671428230, 0.932828722832513720, 0.932810705661527350, 0.932792686158514180, 0.932774664323519410, +0.932756640156587880, 0.932738613657764450, 0.932720584827094860, 0.932702553664623730, 0.932684520170396270, 0.932666484344457540, 0.932648446186852500, 0.932630405697626450, +0.932612362876824360, 0.932594317724490970, 0.932576270240672130, 0.932558220425412700, 0.932540168278757630, 0.932522113800752230, 0.932504056991441450, 0.932485997850870610, +0.932467936379084430, 0.932449872576128660, 0.932431806442048260, 0.932413737976888310, 0.932395667180694110, 0.932377594053510620, 0.932359518595383240, 0.932341440806357060, +0.932323360686476920, 0.932305278235788680, 0.932287193454337300, 0.932269106342167860, 0.932251016899325770, 0.932232925125856090, 0.932214831021804020, 0.932196734587214970, +0.932178635822133780, 0.932160534726606200, 0.932142431300677420, 0.932124325544392510, 0.932106217457796760, 0.932088107040935480, 0.932069994293853840, 0.932051879216597050, +0.932033761809210830, 0.932015642071740150, 0.931997520004230420, 0.931979395606726930, 0.931961268879274880, 0.931943139821919670, 0.931925008434706600, 0.931906874717680740, +0.931888738670887950, 0.931870600294373410, 0.931852459588182300, 0.931834316552360040, 0.931816171186952040, 0.931798023492003580, 0.931779873467559640, 0.931761721113666510, +0.931743566430368930, 0.931725409417712540, 0.931707250075742620, 0.931689088404504480, 0.931670924404043750, 0.931652758074405620, 0.931634589415635260, 0.931616418427778760, +0.931598245110881300, 0.931580069464988170, 0.931561891490144900, 0.931543711186396780, 0.931525528553789560, 0.931507343592368420, 0.931489156302178540, 0.931470966683266230, +0.931452774735676340, 0.931434580459454710, 0.931416383854646420, 0.931398184921297330, 0.931379983659452740, 0.931361780069157820, 0.931343574150458870, 0.931325365903400870, +0.931307155328029550, 0.931288942424390310, 0.931270727192528680, 0.931252509632490290, 0.931234289744320540, 0.931216067528064850, 0.931197842983769180, 0.931179616111479040, +0.931161386911239840, 0.931143155383097110, 0.931124921527096470, 0.931106685343283560, 0.931088446831704000, 0.931070205992402980, 0.931051962825426680, 0.931033717330820520, +0.931015469508630120, 0.930997219358901010, 0.930978966881678920, 0.930960712077009260, 0.930942454944937660, 0.930924195485510090, 0.930905933698772170, 0.930887669584769320, +0.930869403143547380, 0.930851134375151880, 0.930832863279628550, 0.930814589857023030, 0.930796314107380730, 0.930778036030748050, 0.930759755627170170, 0.930741472896692960, +0.930723187839362030, 0.930704900455223140, 0.930686610744322020, 0.930668318706704080, 0.930650024342415620, 0.930631727651502150, 0.930613428634009310, 0.930595127289982840, +0.930576823619468700, 0.930558517622512400, 0.930540209299159820, 0.930521898649456450, 0.930503585673448600, 0.930485270371181780, 0.930466952742701860, 0.930448632788054450, +0.930430310507285530, 0.930411985900440830, 0.930393658967566100, 0.930375329708706960, 0.930356998123909820, 0.930338664213220200, 0.930320327976683850, 0.930301989414346720, +0.930283648526254670, 0.930265305312453440, 0.930246959772988660, 0.930228611907906730, 0.930210261717253300, 0.930191909201074310, 0.930173554359415400, 0.930155197192322760, +0.930136837699842010, 0.930118475882019120, 0.930100111738899840, 0.930081745270530560, 0.930063376476956920, 0.930045005358224870, 0.930026631914380290, 0.930008256145469110, +0.929989878051537320, 0.929971497632630760, 0.929953114888795170, 0.929934729820077190, 0.929916342426522320, 0.929897952708176660, 0.929879560665086040, 0.929861166297296540, +0.929842769604854120, 0.929824370587804430, 0.929805969246194190, 0.929787565580069030, 0.929769159589474930, 0.929750751274457940, 0.929732340635064050, 0.929713927671339310, +0.929695512383329810, 0.929677094771081070, 0.929658674834640040, 0.929640252574052250, 0.929621827989363880, 0.929603401080621010, 0.929584971847869480, 0.929566540291155600, +0.929548106410525100, 0.929529670206024620, 0.929511231677699890, 0.929492790825597210, 0.929474347649762440, 0.929455902150241870, 0.929437454327081470, 0.929419004180327520, +0.929400551710025670, 0.929382096916222870, 0.929363639798964750, 0.929345180358297500, 0.929326718594267300, 0.929308254506920340, 0.929289788096302800, 0.929271319362460660, +0.929252848305439970, 0.929234374925287490, 0.929215899222049170, 0.929197421195770980, 0.929178940846499210, 0.929160458174280170, 0.929141973179159920, 0.929123485861184430, +0.929104996220400550, 0.929086504256854240, 0.929068009970591580, 0.929049513361658970, 0.929031014430102610, 0.929012513175968560, 0.928994009599303340, 0.928975503700152800, +0.928956995478563700, 0.928938484934582200, 0.928919972068254500, 0.928901456879626890, 0.928882939368745550, 0.928864419535656900, 0.928845897380407240, 0.928827372903042510, +0.928808846103609590, 0.928790316982154640, 0.928771785538723860, 0.928753251773363650, 0.928734715686120320, 0.928716177277040140, 0.928697636546169210, 0.928679093493554490, +0.928660548119242040, 0.928642000423278270, 0.928623450405709480, 0.928604898066582090, 0.928586343405942480, 0.928567786423836970, 0.928549227120311630, 0.928530665495413520, +0.928512101549188840, 0.928493535281683880, 0.928474966692945050, 0.928456395783018860, 0.928437822551951620, 0.928419246999789500, 0.928400669126579590, 0.928382088932368070, +0.928363506417201330, 0.928344921581125800, 0.928326334424187880, 0.928307744946434200, 0.928289153147911160, 0.928270559028664950, 0.928251962588742650, 0.928233363828190440, +0.928214762747054720, 0.928196159345382240, 0.928177553623219300, 0.928158945580612400, 0.928140335217608300, 0.928121722534252850, 0.928103107530593550, 0.928084490206676490, +0.928065870562548190, 0.928047248598255160, 0.928028624313844030, 0.928009997709361320, 0.927991368784853330, 0.927972737540367240, 0.927954103975949240, 0.927935468091646070, +0.927916829887504240, 0.927898189363570270, 0.927879546519890800, 0.927860901356512560, 0.927842253873481740, 0.927823604070845520, 0.927804951948650310, 0.927786297506942750, +0.927767640745769450, 0.927748981665177050, 0.927730320265212180, 0.927711656545921250, 0.927692990507351430, 0.927674322149549150, 0.927655651472561020, 0.927636978476433890, +0.927618303161214190, 0.927599625526948750, 0.927580945573684310, 0.927562263301467180, 0.927543578710344650, 0.927524891800363240, 0.927506202571569570, 0.927487511024010390, +0.927468817157732440, 0.927450120972782450, 0.927431422469207070, 0.927412721647052910, 0.927394018506367270, 0.927375313047196560, 0.927356605269587630, 0.927337895173587110, +0.927319182759241860, 0.927300468026598600, 0.927281750975703980, 0.927263031606605170, 0.927244309919348920, 0.927225585913981850, 0.927206859590550710, 0.927188130949102570, +0.927169399989684060, 0.927150666712342030, 0.927131931117123000, 0.927113193204074370, 0.927094452973242890, 0.927075710424675290, 0.927056965558418320, 0.927038218374519050, +0.927019468873024110, 0.927000717053980570, 0.926981962917434950, 0.926963206463434660, 0.926944447692026440, 0.926925686603257030, 0.926906923197173490, 0.926888157473822580, +0.926869389433251260, 0.926850619075506140, 0.926831846400634870, 0.926813071408683960, 0.926794294099700270, 0.926775514473730970, 0.926756732530822800, 0.926737948271022850, +0.926719161694378070, 0.926700372800934980, 0.926681581590741320, 0.926662788063843720, 0.926643992220289150, 0.926625194060124560, 0.926606393583397030, 0.926587590790153400, +0.926568785680440540, 0.926549978254306070, 0.926531168511796730, 0.926512356452959370, 0.926493542077841070, 0.926474725386489010, 0.926455906378950140, 0.926437085055271450, +0.926418261415499770, 0.926399435459682730, 0.926380607187867080, 0.926361776600100000, 0.926342943696428330, 0.926324108476899390, 0.926305270941560230, 0.926286431090457830, +0.926267588923639030, 0.926248744441151570, 0.926229897643042310, 0.926211048529358320, 0.926192197100146660, 0.926173343355454430, 0.926154487295328900, 0.926135628919816930, +0.926116768228966050, 0.926097905222823310, 0.926079039901435920, 0.926060172264850820, 0.926041302313115320, 0.926022430046276490, 0.926003555464381730, 0.925984678567477680, +0.925965799355612180, 0.925946917828832320, 0.925928033987185040, 0.925909147830717760, 0.925890259359477550, 0.925871368573511820, 0.925852475472867530, 0.925833580057591750, +0.925814682327732340, 0.925795782283336250, 0.925776879924450790, 0.925757975251123020, 0.925739068263400360, 0.925720158961329980, 0.925701247344958960, 0.925682333414335030, +0.925663417169505400, 0.925644498610517120, 0.925625577737417600, 0.925606654550254260, 0.925587729049074160, 0.925568801233924820, 0.925549871104853090, 0.925530938661907050, +0.925512003905133550, 0.925493066834580210, 0.925474127450294120, 0.925455185752322660, 0.925436241740713370, 0.925417295415512990, 0.925398346776769800, 0.925379395824530770, +0.925360442558843200, 0.925341486979754490, 0.925322529087312050, 0.925303568881563400, 0.925284606362555720, 0.925265641530336300, 0.925246674384953010, 0.925227704926453120, +0.925208733154883830, 0.925189759070292880, 0.925170782672727450, 0.925151803962235060, 0.925132822938863120, 0.925113839602658920, 0.925094853953670300, 0.925075865991944580, +0.925056875717529260, 0.925037883130471750, 0.925018888230819460, 0.924999891018620010, 0.924980891493920490, 0.924961889656769070, 0.924942885507212930, 0.924923879045299600, +0.924904870271076600, 0.924885859184591320, 0.924866845785891400, 0.924847830075024470, 0.924828812052037600, 0.924809791716978970, 0.924790769069895880, 0.924771744110835850, +0.924752716839846500, 0.924733687256975360, 0.924714655362270040, 0.924695621155777970, 0.924676584637546650, 0.924657545807624160, 0.924638504666057680, 0.924619461212895070, +0.924600415448183830, 0.924581367371971500, 0.924562316984305690, 0.924543264285233810, 0.924524209274804170, 0.924505151953063930, 0.924486092320060850, 0.924467030375842440, +0.924447966120456540, 0.924428899553950690, 0.924409830676372610, 0.924390759487769720, 0.924371685988190080, 0.924352610177681330, 0.924333532056291100, 0.924314451624067000, +0.924295368881056680, 0.924276283827308090, 0.924257196462868300, 0.924238106787785950, 0.924219014802108330, 0.924199920505883180, 0.924180823899158230, 0.924161724981981240, +0.924142623754399820, 0.924123520216461940, 0.924104414368214890, 0.924085306209707190, 0.924066195740986140, 0.924047082962099700, 0.924027967873095490, 0.924008850474021370, +0.923989730764925080, 0.923970608745854570, 0.923951484416857150, 0.923932357777981330, 0.923913228829274620, 0.923894097570784890, 0.923874964002559860, 0.923855828124647390, +0.923836689937095450, 0.923817549439951420, 0.923798406633263850, 0.923779261517080230, 0.923760114091448430, 0.923740964356416390, 0.923721812312031990, 0.923702657958342940, +0.923683501295397340, 0.923664342323242680, 0.923645181041927390, 0.923626017451499190, 0.923606851552005950, 0.923587683343495610, 0.923568512826016040, 0.923549339999615190, +0.923530164864341030, 0.923510987420241070, 0.923491807667364050, 0.923472625605757380, 0.923453441235469240, 0.923434254556547480, 0.923415065569040070, 0.923395874272995080, +0.923376680668460010, 0.923357484755483520, 0.923338286534113320, 0.923319086004397490, 0.923299883166383890, 0.923280678020120590, 0.923261470565655660, 0.923242260803036950, +0.923223048732312310, 0.923203834353530370, 0.923184617666738870, 0.923165398671985770, 0.923146177369319140, 0.923126953758787170, 0.923107727840437820, 0.923088499614318710, +0.923069269080478820, 0.923050036238965640, 0.923030801089827490, 0.923011563633112210, 0.922992323868868090, 0.922973081797143100, 0.922953837417985530, 0.922934590731442910, +0.922915341737564180, 0.922896090436397200, 0.922876836827989820, 0.922857580912390450, 0.922838322689647160, 0.922819062159808020, 0.922799799322921220, 0.922780534179034610, +0.922761266728196920, 0.922741996970456110, 0.922722724905860380, 0.922703450534457680, 0.922684173856296530, 0.922664894871424890, 0.922645613579890610, 0.922626329981742650, +0.922607044077028870, 0.922587755865797550, 0.922568465348096780, 0.922549172523974840, 0.922529877393480020, 0.922510579956660530, 0.922491280213564190, 0.922471978164239980, +0.922452673808735860, 0.922433367147100000, 0.922414058179380820, 0.922394746905626390, 0.922375433325885120, 0.922356117440204960, 0.922336799248634880, 0.922317478751222720, +0.922298155948016900, 0.922278830839065700, 0.922259503424417430, 0.922240173704120370, 0.922220841678222940, 0.922201507346772980, 0.922182170709819670, 0.922162831767410870, +0.922143490519594990, 0.922124146966420420, 0.922104801107935470, 0.922085452944188530, 0.922066102475227910, 0.922046749701101790, 0.922027394621859120, 0.922008037237547870, +0.921988677548216560, 0.921969315553913590, 0.921949951254687370, 0.921930584650586190, 0.921911215741658240, 0.921891844527952590, 0.921872471009517300, 0.921853095186400910, +0.921833717058651690, 0.921814336626318290, 0.921794953889448990, 0.921775568848092200, 0.921756181502296320, 0.921736791852110220, 0.921717399897582170, 0.921698005638760700, +0.921678609075694100, 0.921659210208431000, 0.921639809037019920, 0.921620405561509260, 0.921600999781947320, 0.921581591698383160, 0.921562181310865090, 0.921542768619441510, +0.921523353624160930, 0.921503936325072100, 0.921484516722223420, 0.921465094815663080, 0.921445670605440250, 0.921426244091603340, 0.921406815274200870, 0.921387384153281250, +0.921367950728893210, 0.921348515001085390, 0.921329076969906180, 0.921309636635403880, 0.921290193997627900, 0.921270749056626540, 0.921251301812448190, 0.921231852265141590, +0.921212400414755380, 0.921192946261338190, 0.921173489804938180, 0.921154031045604890, 0.921134569983386500, 0.921115106618331740, 0.921095640950489130, 0.921076172979907510, +0.921056702706635420, 0.921037230130721470, 0.921017755252214300, 0.920998278071162970, 0.920978798587615890, 0.920959316801621910, 0.920939832713229540, 0.920920346322487650, +0.920900857629444960, 0.920881366634150100, 0.920861873336651370, 0.920842377736998400, 0.920822879835239470, 0.920803379631423340, 0.920783877125598730, 0.920764372317814490, +0.920744865208119270, 0.920725355796561560, 0.920705844083190780, 0.920686330068055340, 0.920666813751204180, 0.920647295132685950, 0.920627774212549490, 0.920608250990843540, +0.920588725467617050, 0.920569197642918340, 0.920549667516797010, 0.920530135089301590, 0.920510600360480710, 0.920491063330383330, 0.920471523999058410, 0.920451982366554570, +0.920432438432920770, 0.920412892198205550, 0.920393343662458510, 0.920373792825728070, 0.920354239688063070, 0.920334684249512590, 0.920315126510125370, 0.920295566469950250, +0.920276004129035980, 0.920256439487431970, 0.920236872545186930, 0.920217303302349630, 0.920197731758969130, 0.920178157915094270, 0.920158581770774030, 0.920139003326057360, +0.920119422580992770, 0.920099839535630020, 0.920080254190017710, 0.920060666544204710, 0.920041076598240080, 0.920021484352172680, 0.920001889806051580, 0.919982292959925510, +0.919962693813843990, 0.919943092367855760, 0.919923488622009790, 0.919903882576355030, 0.919884274230940660, 0.919864663585815530, 0.919845050641028840, 0.919825435396629090, +0.919805817852666130, 0.919786198009188590, 0.919766575866245550, 0.919746951423886180, 0.919727324682159340, 0.919707695641114210, 0.919688064300799860, 0.919668430661264910, +0.919648794722559340, 0.919629156484731760, 0.919609515947831250, 0.919589873111906990, 0.919570227977008050, 0.919550580543183500, 0.919530930810482210, 0.919511278778953890, +0.919491624448647400, 0.919471967819611820, 0.919452308891896330, 0.919432647665550110, 0.919412984140622220, 0.919393318317161980, 0.919373650195218000, 0.919353979774840240, +0.919334307056077550, 0.919314632038979010, 0.919294954723594020, 0.919275275109971530, 0.919255593198160970, 0.919235908988211390, 0.919216222480171650, 0.919196533674091710, +0.919176842570020410, 0.919157149168007060, 0.919137453468100830, 0.919117755470350910, 0.919098055174806690, 0.919078352581516930, 0.919058647690531690, 0.919038940501899710, +0.919019231015670510, 0.918999519231893160, 0.918979805150617060, 0.918960088771891390, 0.918940370095765570, 0.918920649122288440, 0.918900925851510060, 0.918881200283479300, +0.918861472418245560, 0.918841742255858240, 0.918822009796366410, 0.918802275039819700, 0.918782537986266860, 0.918762798635758050, 0.918743056988342240, 0.918723313044068730, +0.918703566802987040, 0.918683818265146450, 0.918664067430596250, 0.918644314299385870, 0.918624558871564360, 0.918604801147181790, 0.918585041126287250, 0.918565278808930130, +0.918545514195159730, 0.918525747285025670, 0.918505978078577150, 0.918486206575863660, 0.918466432776934400, 0.918446656681839340, 0.918426878290627640, 0.918407097603348820, +0.918387314620052190, 0.918367529340787250, 0.918347741765603520, 0.918327951894550080, 0.918308159727677100, 0.918288365265033770, 0.918268568506669490, 0.918248769452633780, +0.918228968102976160, 0.918209164457746140, 0.918189358516993240, 0.918169550280766520, 0.918149739749116290, 0.918129926922091720, 0.918110111799742330, 0.918090294382117640, +0.918070474669267280, 0.918050652661240750, 0.918030828358087470, 0.918011001759856840, 0.917991172866599040, 0.917971341678363360, 0.917951508195199220, 0.917931672417156450, +0.917911834344284360, 0.917891993976632790, 0.917872151314250820, 0.917852306357188840, 0.917832459105496160, 0.917812609559222280, 0.917792757718416840, 0.917772903583129570, +0.917753047153410000, 0.917733188429307840, 0.917713327410872300, 0.917693464098153780, 0.917673598491201670, 0.917653730590065610, 0.917633860394795110, 0.917613987905440020, +0.917594113122049970, 0.917574236044674250, 0.917554356673363270, 0.917534475008166430, 0.917514591049133470, 0.917494704796314010, 0.917474816249757690, 0.917454925409514340, +0.917435032275633830, 0.917415136848165220, 0.917395239127159260, 0.917375339112665110, 0.917355436804732640, 0.917335532203411570, 0.917315625308751660, 0.917295716120802630, +0.917275804639614440, 0.917255890865236290, 0.917235974797718790, 0.917216056437111350, 0.917196135783463820, 0.917176212836825930, 0.917156287597247430, 0.917136360064778280, +0.917116430239467870, 0.917096498121366730, 0.917076563710524370, 0.917056627006990640, 0.917036688010815280, 0.917016746722048250, 0.916996803140739280, 0.916976857266938340, +0.916956909100694830, 0.916936958642059490, 0.916917005891081720, 0.916897050847811480, 0.916877093512298620, 0.916857133884593000, 0.916837171964744460, 0.916817207752802730, +0.916797241248818340, 0.916777272452840800, 0.916757301364920170, 0.916737327985106210, 0.916717352313448970, 0.916697374349998320, 0.916677394094804200, 0.916657411547916250, +0.916637426709385190, 0.916617439579260450, 0.916597450157592200, 0.916577458444430390, 0.916557464439824780, 0.916537468143825640, 0.916517469556482720, 0.916497468677845870, +0.916477465507965720, 0.916457460046891770, 0.916437452294674330, 0.916417442251363120, 0.916397429917008340, 0.916377415291660060, 0.916357398375367780, 0.916337379168182480, +0.916317357670153650, 0.916297333881331390, 0.916277307801765860, 0.916257279431507140, 0.916237248770605080, 0.916217215819109980, 0.916197180577071450, 0.916177143044540340, +0.916157103221566290, 0.916137061108199590, 0.916117016704490190, 0.916096970010488290, 0.916076921026243940, 0.916056869751807330, 0.916036816187228100, 0.916016760332557300, +0.915996702187844460, 0.915976641753139980, 0.915956579028493810, 0.915936514013956260, 0.915916446709577390, 0.915896377115407060, 0.915876305231496210, 0.915856231057894490, +0.915836154594652290, 0.915816075841819570, 0.915795994799446730, 0.915775911467583970, 0.915755825846281350, 0.915735737935588820, 0.915715647735557360, 0.915695555246236690, +0.915675460467677230, 0.915655363399929030, 0.915635264043042520, 0.915615162397067750, 0.915595058462054800, 0.915574952238054520, 0.915554843725116860, 0.915534732923292020, +0.915514619832630490, 0.915494504453182260, 0.915474386784997930, 0.915454266828127470, 0.915434144582621070, 0.915414020048529680, 0.915393893225903250, 0.915373764114792100, +0.915353632715246500, 0.915333499027316750, 0.915313363051053370, 0.915293224786506540, 0.915273084233726330, 0.915252941392763700, 0.915232796263668710, 0.915212648846491780, +0.915192499141283200, 0.915172347148093370, 0.915152192866972690, 0.915132036297971240, 0.915111877441139980, 0.915091716296528970, 0.915071552864188730, 0.915051387144169670, +0.915031219136522080, 0.915011048841296470, 0.914990876258543140, 0.914970701388312380, 0.914950524230655150, 0.914930344785621630, 0.914910163053262340, 0.914889979033627570, +0.914869792726767830, 0.914849604132733530, 0.914829413251575410, 0.914809220083343200, 0.914789024628088420, 0.914768826885861140, 0.914748626856711660, 0.914728424540690700, +0.914708219937848680, 0.914688013048235990, 0.914667803871903050, 0.914647592408900920, 0.914627378659279790, 0.914607162623090160, 0.914586944300382680, 0.914566723691207840, +0.914546500795616170, 0.914526275613658290, 0.914506048145384390, 0.914485818390845640, 0.914465586350092450, 0.914445352023175230, 0.914425115410144600, 0.914404876511051180, +0.914384635325945610, 0.914364391854878170, 0.914344146097899930, 0.914323898055061420, 0.914303647726413260, 0.914283395112005850, 0.914263140211890040, 0.914242883026116230, +0.914222623554735380, 0.914202361797797570, 0.914182097755354190, 0.914161831427455550, 0.914141562814152380, 0.914121291915495180, 0.914101018731534930, 0.914080743262322030, +0.914060465507907200, 0.914040185468340980, 0.914019903143674650, 0.913999618533958500, 0.913979331639243390, 0.913959042459579820, 0.913938750995018760, 0.913918457245610720, +0.913898161211406320, 0.913877862892456760, 0.913857562288812540, 0.913837259400524520, 0.913816954227643200, 0.913796646770219660, 0.913776337028304410, 0.913756025001948300, +0.913735710691201850, 0.913715394096116350, 0.913695075216742540, 0.913674754053130920, 0.913654430605332470, 0.913634104873397910, 0.913613776857378100, 0.913593446557323770, +0.913573113973285560, 0.913552779105314960, 0.913532441953462280, 0.913512102517778590, 0.913491760798314620, 0.913471416795121230, 0.913451070508249360, 0.913430721937749430, +0.913410371083673070, 0.913390017946070780, 0.913369662524993410, 0.913349304820491930, 0.913328944832617060, 0.913308582561420000, 0.913288218006951370, 0.913267851169261900, +0.913247482048403110, 0.913227110644425630, 0.913206736957380420, 0.913186360987318310, 0.913165982734290280, 0.913145602198347390, 0.913125219379540050, 0.913104834277920110, +0.913084446893537960, 0.913064057226444790, 0.913043665276691450, 0.913023271044328900, 0.913002874529408310, 0.912982475731980440, 0.912962074652096000, 0.912941671289806740, +0.912921265645163290, 0.912900857718216720, 0.912880447509017980, 0.912860035017618140, 0.912839620244068170, 0.912819203188419250, 0.912798783850721880, 0.912778362231027930, +0.912757938329388120, 0.912737512145853410, 0.912717083680474880, 0.912696652933303710, 0.912676219904390850, 0.912655784593787160, 0.912635347001544360, 0.912614907127713090, +0.912594464972344640, 0.912574020535489970, 0.912553573817200370, 0.912533124817526690, 0.912512673536520320, 0.912492219974231800, 0.912471764130713180, 0.912451306006015090, +0.912430845600188830, 0.912410382913285360, 0.912389917945355950, 0.912369450696451700, 0.912348981166623880, 0.912328509355923250, 0.912308035264401740, 0.912287558892110110, +0.912267080239099530, 0.912246599305421290, 0.912226116091126580, 0.912205630596266580, 0.912185142820892140, 0.912164652765055210, 0.912144160428806640, 0.912123665812197610, +0.912103168915279430, 0.912082669738103370, 0.912062168280720620, 0.912041664543182470, 0.912021158525539780, 0.912000650227844600, 0.911980139650147680, 0.911959626792500530, +0.911939111654954230, 0.911918594237560280, 0.911898074540369750, 0.911877552563433610, 0.911857028306804040, 0.911836501770531880, 0.911815972954668430, 0.911795441859265090, +0.911774908484373150, 0.911754372830043900, 0.911733834896328750, 0.911713294683278660, 0.911692752190945700, 0.911672207419380820, 0.911651660368635430, 0.911631111038760930, +0.911610559429808620, 0.911590005541829900, 0.911569449374876270, 0.911548890928998490, 0.911528330204248950, 0.911507767200678610, 0.911487201918338760, 0.911466634357280920, +0.911446064517556500, 0.911425492399217000, 0.911404918002313380, 0.911384341326897720, 0.911363762373021300, 0.911343181140735430, 0.911322597630091710, 0.911302011841141350, +0.911281423773936060, 0.911260833428527260, 0.911240240804965910, 0.911219645903304290, 0.911199048723593700, 0.911178449265885320, 0.911157847530230990, 0.911137243516681910, +0.911116637225289790, 0.911096028656106060, 0.911075417809181890, 0.911054804684569450, 0.911034189282320160, 0.911013571602485310, 0.910992951645116510, 0.910972329410265400, +0.910951704897983380, 0.910931078108321860, 0.910910449041332890, 0.910889817697067890, 0.910869184075578260, 0.910848548176915740, 0.910827910001131840, 0.910807269548278060, +0.910786626818406280, 0.910765981811567430, 0.910745334527814030, 0.910724684967197380, 0.910704033129768890, 0.910683379015580390, 0.910662722624683400, 0.910642063957129650, +0.910621403012970340, 0.910600739792257970, 0.910580074295043620, 0.910559406521379120, 0.910538736471316220, 0.910518064144906330, 0.910497389542201390, 0.910476712663252920, +0.910456033508112330, 0.910435352076832020, 0.910414668369463280, 0.910393982386057840, 0.910373294126667560, 0.910352603591343960, 0.910331910780138860, 0.910311215693104030, +0.910290518330290840, 0.910269818691751610, 0.910249116777537840, 0.910228412587701370, 0.910207706122293850, 0.910186997381366990, 0.910166286364972650, 0.910145573073162240, +0.910124857505988370, 0.910104139663502230, 0.910083419545755780, 0.910062697152800750, 0.910041972484688990, 0.910021245541472350, 0.910000516323202560, 0.909979784829931140, +0.909959051061710600, 0.909938315018592460, 0.909917576700628450, 0.909896836107870530, 0.909876093240370660, 0.909855348098180360, 0.909834600681351470, 0.909813850989936390, +0.909793099023986640, 0.909772344783554180, 0.909751588268690850, 0.909730829479448610, 0.909710068415879200, 0.909689305078034690, 0.909668539465966490, 0.909647771579727320, +0.909627001419368810, 0.909606228984942700, 0.909585454276501060, 0.909564677294095740, 0.909543898037778800, 0.909523116507602090, 0.909502332703617130, 0.909481546625876880, +0.909460758274432620, 0.909439967649336540, 0.909419174750640490, 0.909398379578396530, 0.909377582132656630, 0.909356782413472400, 0.909335980420896580, 0.909315176154980810, +0.909294369615777140, 0.909273560803337430, 0.909252749717713860, 0.909231936358958490, 0.909211120727123290, 0.909190302822259880, 0.909169482644420990, 0.909148660193658480, +0.909127835470024290, 0.909107008473570620, 0.909086179204349310, 0.909065347662412650, 0.909044513847812490, 0.909023677760600780, 0.909002839400830150, 0.908981998768552570, +0.908961155863819870, 0.908940310686684350, 0.908919463237197970, 0.908898613515413010, 0.908877761521381110, 0.908856907255155220, 0.908836050716786970, 0.908815191906328760, +0.908794330823832430, 0.908773467469350280, 0.908752601842934490, 0.908731733944637240, 0.908710863774510160, 0.908689991332606420, 0.908669116618977650, 0.908648239633676140, +0.908627360376753960, 0.908606478848263400, 0.908585595048256640, 0.908564708976785540, 0.908543820633903040, 0.908522930019661000, 0.908502037134111600, 0.908481141977307120, +0.908460244549299740, 0.908439344850141770, 0.908418442879885490, 0.908397538638582750, 0.908376632126286500, 0.908355723343048590, 0.908334812288921540, 0.908313898963957310, +0.908292983368208410, 0.908272065501727010, 0.908251145364565420, 0.908230222956775690, 0.908209298278410680, 0.908188371329522460, 0.908167442110163430, 0.908146510620385650, +0.908125576860241650, 0.908104640829783700, 0.908083702529063790, 0.908062761958134960, 0.908041819117049180, 0.908020874005858960, 0.907999926624616480, 0.907978976973374150, +0.907958025052184480, 0.907937070861099760, 0.907916114400171840, 0.907895155669454110, 0.907874194668998550, 0.907853231398857430, 0.907832265859083280, 0.907811298049728380, +0.907790327970845250, 0.907769355622486400, 0.907748381004703670, 0.907727404117550370, 0.907706424961078670, 0.907685443535340860, 0.907664459840389350, 0.907643473876276750, +0.907622485643055590, 0.907601495140777700, 0.907580502369496500, 0.907559507329263940, 0.907538510020132750, 0.907517510442155230, 0.907496508595383890, 0.907475504479871350, +0.907454498095670030, 0.907433489442832090, 0.907412478521410830, 0.907391465331458310, 0.907370449873027170, 0.907349432146169810, 0.907328412150938960, 0.907307389887387130, +0.907286365355566390, 0.907265338555530150, 0.907244309487330480, 0.907223278151020110, 0.907202244546651440, 0.907181208674277320, 0.907160170533950040, 0.907139130125722450, +0.907118087449646620, 0.907097042505775830, 0.907075995294162610, 0.907054945814859350, 0.907033894067918680, 0.907012840053393220, 0.906991783771335820, 0.906970725221798890, +0.906949664404834710, 0.906928601320496800, 0.906907535968837440, 0.906886468349909160, 0.906865398463764680, 0.906844326310456750, 0.906823251890038100, 0.906802175202560790, +0.906781096248078460, 0.906760015026643500, 0.906738931538308420, 0.906717845783125980, 0.906696757761149000, 0.906675667472430000, 0.906654574917021950, 0.906633480094977020, +0.906612383006348830, 0.906591283651189680, 0.906570182029552310, 0.906549078141489440, 0.906527971987053930, 0.906506863566298390, 0.906485752879275800, 0.906464639926038430, +0.906443524706639800, 0.906422407221132430, 0.906401287469568940, 0.906380165452002280, 0.906359041168485200, 0.906337914619070540, 0.906316785803810700, 0.906295654722759300, +0.906274521375968760, 0.906253385763491900, 0.906232247885381590, 0.906211107741690670, 0.906189965332471870, 0.906168820657778260, 0.906147673717662250, 0.906126524512177340, +0.906105373041376170, 0.906084219305311580, 0.906063063304036410, 0.906041905037603620, 0.906020744506066070, 0.905999581709476250, 0.905978416647887920, 0.905957249321353460, +0.905936079729925960, 0.905914907873658140, 0.905893733752603180, 0.905872557366813820, 0.905851378716343030, 0.905830197801243520, 0.905809014621568820, 0.905787829177371550, +0.905766641468704780, 0.905745451495621360, 0.905724259258174350, 0.905703064756416710, 0.905681867990401400, 0.905660668960181050, 0.905639467665809380, 0.905618264107339030, +0.905597058284822950, 0.905575850198314320, 0.905554639847866110, 0.905533427233531140, 0.905512212355362390, 0.905490995213413360, 0.905469775807736910, 0.905448554138386100, +0.905427330205413770, 0.905406104008873220, 0.905384875548817300, 0.905363644825299300, 0.905342411838371720, 0.905321176588088530, 0.905299939074502350, 0.905278699297666360, +0.905257457257633620, 0.905236212954457330, 0.905214966388190430, 0.905193717558886110, 0.905172466466597100, 0.905151213111377250, 0.905129957493279510, 0.905108699612356740, +0.905087439468662320, 0.905066177062249230, 0.905044912393170750, 0.905023645461479620, 0.905002376267229680, 0.904981104810473890, 0.904959831091265320, 0.904938555109657150, +0.904917276865702560, 0.904895996359454840, 0.904874713590967160, 0.904853428560292270, 0.904832141267484120, 0.904810851712595680, 0.904789559895680110, 0.904768265816790600, +0.904746969475980540, 0.904725670873302910, 0.904704370008810880, 0.904683066882558170, 0.904661761494597870, 0.904640453844983150, 0.904619143933767190, 0.904597831761003500, +0.904576517326745270, 0.904555200631045660, 0.904533881673957650, 0.904512560455535300, 0.904491236975831670, 0.904469911234899840, 0.904448583232793310, 0.904427252969565280, +0.904405920445269130, 0.904384585659958160, 0.904363248613685330, 0.904341909306504820, 0.904320567738469470, 0.904299223909632690, 0.904277877820047980, 0.904256529469768420, +0.904235178858847630, 0.904213825987338460, 0.904192470855295190, 0.904171113462770680, 0.904149753809818320, 0.904128391896491750, 0.904107027722844010, 0.904085661288928870, +0.904064292594799480, 0.904042921640509030, 0.904021548426111600, 0.904000172951660350, 0.903978795217208590, 0.903957415222809920, 0.903936032968517660, 0.903914648454385410, +0.903893261680466020, 0.903871872646814010, 0.903850481353482230, 0.903829087800524180, 0.903807691987993490, 0.903786293915943670, 0.903764893584427910, 0.903743490993500040, +0.903722086143213030, 0.903700679033621280, 0.903679269664777740, 0.903657858036736040, 0.903636444149549690, 0.903615028003272200, 0.903593609597957200, 0.903572188933658090, +0.903550766010428270, 0.903529340828321810, 0.903507913387392000, 0.903486483687692470, 0.903465051729276710, 0.903443617512198260, 0.903422181036510840, 0.903400742302267520, +0.903379301309522820, 0.903357858058329800, 0.903336412548742080, 0.903314964780813410, 0.903293514754597290, 0.903272062470147460, 0.903250607927517430, 0.903229151126760500, +0.903207692067931060, 0.903186230751082400, 0.903164767176268150, 0.903143301343541930, 0.903121833252957580, 0.903100362904568520, 0.903078890298428690, 0.903057415434591170, +0.903035938313110460, 0.903014458934039980, 0.902992977297433330, 0.902971493403344150, 0.902950007251826390, 0.902928518842933460, 0.902907028176718970, 0.902885535253237230, +0.902864040072541730, 0.902842542634686000, 0.902821042939723980, 0.902799540987709430, 0.902778036778695950, 0.902756530312737390, 0.902735021589887170, 0.902713510610199670, +0.902691997373728410, 0.902670481880527230, 0.902648964130649880, 0.902627444124149970, 0.902605921861081570, 0.902584397341497980, 0.902562870565453700, 0.902541341533002360, +0.902519810244197580, 0.902498276699093220, 0.902476740897743320, 0.902455202840201420, 0.902433662526521680, 0.902412119956757300, 0.902390575130962990, 0.902369028049192280, +0.902347478711498900, 0.902325927117936910, 0.902304373268560170, 0.902282817163422400, 0.902261258802577570, 0.902239698186079300, 0.902218135313982090, 0.902196570186339590, +0.902175002803205620, 0.902153433164634260, 0.902131861270679240, 0.902110287121394520, 0.902088710716833720, 0.902067132057051580, 0.902045551142101500, 0.902023967972037650, +0.902002382546913890, 0.901980794866784060, 0.901959204931702340, 0.901937612741722570, 0.901916018296898380, 0.901894421597284610, 0.901872822642934670, 0.901851221433902730, +0.901829617970242750, 0.901808012252008680, 0.901786404279254720, 0.901764794052034580, 0.901743181570402120, 0.901721566834412070, 0.901699949844118160, 0.901678330599574360, +0.901656709100834730, 0.901635085347953340, 0.901613459340984250, 0.901591831079981090, 0.901570200564998700, 0.901548567796090830, 0.901526932773311640, 0.901505295496714990, +0.901483655966355160, 0.901462014182286220, 0.901440370144562130, 0.901418723853236850, 0.901397075308365100, 0.901375424510000630, 0.901353771458197730, 0.901332116153010230, +0.901310458594492550, 0.901288798782698740, 0.901267136717682440, 0.901245472399498810, 0.901223805828201390, 0.901202137003844550, 0.901180465926482270, 0.901158792596168820, +0.901137117012958510, 0.901115439176905290, 0.901093759088063220, 0.901072076746487040, 0.901050392152230710, 0.901028705305348290, 0.901007016205894180, 0.900985324853922580, +0.900963631249487640, 0.900941935392643670, 0.900920237283444390, 0.900898536921944880, 0.900876834308199090, 0.900855129442261200, 0.900833422324185510, 0.900811712954026290, +0.900790001331837730, 0.900768287457673790, 0.900746571331589530, 0.900724852953638800, 0.900703132323876000, 0.900681409442355310, 0.900659684309131130, 0.900637956924257740, +0.900616227287789450, 0.900594495399780200, 0.900572761260285180, 0.900551024869358120, 0.900529286227053640, 0.900507545333425810, 0.900485802188529250, 0.900464056792418140, +0.900442309145146780, 0.900420559246769340, 0.900398807097340990, 0.900377052696915480, 0.900355296045547430, 0.900333537143291010, 0.900311775990200850, 0.900290012586331230, +0.900268246931736240, 0.900246479026470920, 0.900224708870589470, 0.900202936464146290, 0.900181161807195650, 0.900159384899792190, 0.900137605741990310, 0.900115824333844290, +0.900094040675408440, 0.900072254766737800, 0.900050466607886570, 0.900028676198909140, 0.900006883539860030, 0.899985088630793740, 0.899963291471764680, 0.899941492062827030, +0.899919690404036080, 0.899897886495445780, 0.899876080337110860, 0.899854271929085740, 0.899832461271424910, 0.899810648364183010, 0.899788833207414320, 0.899767015801173350, +0.899745196145515070, 0.899723374240493870, 0.899701550086164260, 0.899679723682580760, 0.899657895029797980, 0.899636064127870340, 0.899614230976852670, 0.899592395576798930, +0.899570557927764750, 0.899548718029804070, 0.899526875882971530, 0.899505031487321860, 0.899483184842909680, 0.899461335949789500, 0.899439484808015500, 0.899417631417643300, +0.899395775778726980, 0.899373917891321150, 0.899352057755480660, 0.899330195371259910, 0.899308330738713750, 0.899286463857896680, 0.899264594728863110, 0.899242723351668440, +0.899220849726366960, 0.899198973853013390, 0.899177095731662380, 0.899155215362368640, 0.899133332745186810, 0.899111447880171610, 0.899089560767377560, 0.899067671406859840, +0.899045779798673060, 0.899023885942871750, 0.899001989839510740, 0.898980091488644770, 0.898958190890328580, 0.898936288044616450, 0.898914382951564120, 0.898892475611225760, +0.898870566023656110, 0.898848654188910250, 0.898826740107042670, 0.898804823778108220, 0.898782905202161640, 0.898760984379257550, 0.898739061309451250, 0.898717135992797460, +0.898695208429350690, 0.898673278619165910, 0.898651346562298060, 0.898629412258801660, 0.898607475708731450, 0.898585536912142930, 0.898563595869090630, 0.898541652579629260, +0.898519707043813790, 0.898497759261699060, 0.898475809233339920, 0.898453856958791210, 0.898431902438107550, 0.898409945671344470, 0.898387986658556460, 0.898366025399798600, +0.898344061895125610, 0.898322096144592570, 0.898300128148254220, 0.898278157906165500, 0.898256185418381040, 0.898234210684956460, 0.898212233705946490, 0.898190254481405770, +0.898168273011389570, 0.898146289295952530, 0.898124303335149920, 0.898102315129036040, 0.898080324677666850, 0.898058331981096750, 0.898036337039380910, 0.898014339852574170, +0.897992340420731620, 0.897970338743908190, 0.897948334822158970, 0.897926328655538450, 0.897904320244102610, 0.897882309587905820, 0.897860296687003400, 0.897838281541450180, +0.897816264151301220, 0.897794244516611610, 0.897772222637436060, 0.897750198513830310, 0.897728172145848990, 0.897706143533547270, 0.897684112676980340, 0.897662079576202920, +0.897640044231270420, 0.897618006642237790, 0.897595966809159760, 0.897573924732092190, 0.897551880411089800, 0.897529833846207770, 0.897507785037501060, 0.897485733985024960, +0.897463680688834530, 0.897441625148984850, 0.897419567365530750, 0.897397507338528080, 0.897375445068031690, 0.897353380554096640, 0.897331313796778220, 0.897309244796131390, +0.897287173552211550, 0.897265100065073320, 0.897243024334772770, 0.897220946361364740, 0.897198866144904180, 0.897176783685446620, 0.897154698983047010, 0.897132612037760620, +0.897110522849642770, 0.897088431418748170, 0.897066337745132890, 0.897044241828851780, 0.897022143669960140, 0.897000043268513010, 0.896977940624565930, 0.896955835738173830, +0.896933728609392240, 0.896911619238275890, 0.896889507624880960, 0.896867393769262170, 0.896845277671474930, 0.896823159331574530, 0.896801038749616140, 0.896778915925655280, +0.896756790859746690, 0.896734663551946420, 0.896712534002309550, 0.896690402210891470, 0.896668268177747250, 0.896646131902932410, 0.896623993386502230, 0.896601852628512000, +0.896579709629016790, 0.896557564388072770, 0.896535416905734790, 0.896513267182058260, 0.896491115217098570, 0.896468961010911000, 0.896446804563551190, 0.896424645875073870, +0.896402484945535320, 0.896380321774990610, 0.896358156363495140, 0.896335988711104200, 0.896313818817873310, 0.896291646683857860, 0.896269472309113360, 0.896247295693694660, +0.896225116837658260, 0.896202935741059030, 0.896180752403952340, 0.896158566826393940, 0.896136379008439010, 0.896114188950143160, 0.896091996651561810, 0.896069802112750110, +0.896047605333764370, 0.896025406314659540, 0.896003205055491140, 0.895981001556314770, 0.895958795817185960, 0.895936587838160100, 0.895914377619292380, 0.895892165160639190, +0.895869950462255480, 0.895847733524196890, 0.895825514346519030, 0.895803292929277410, 0.895781069272527430, 0.895758843376324940, 0.895736615240724790, 0.895714384865783590, +0.895692152251556410, 0.895669917398098870, 0.895647680305466600, 0.895625440973714990, 0.895603199402899900, 0.895580955593076710, 0.895558709544300720, 0.895536461256628450, +0.895514210730114950, 0.895491957964815950, 0.895469702960787100, 0.895447445718083990, 0.895425186236762260, 0.895402924516877090, 0.895380660558485090, 0.895358394361641330, +0.895336125926401660, 0.895313855252821700, 0.895291582340957070, 0.895269307190863510, 0.895247029802596740, 0.895224750176211840, 0.895202468311765640, 0.895180184209313110, +0.895157897868910200, 0.895135609290612530, 0.895113318474475840, 0.895091025420555850, 0.895068730128907860, 0.895046432599588600, 0.895024132832653140, 0.895001830828157320, +0.894979526586156980, 0.894957220106707750, 0.894934911389865580, 0.894912600435685990, 0.894890287244224590, 0.894867971815537900, 0.894845654149681200, 0.894823334246710460, +0.894801012106681390, 0.894778687729649750, 0.894756361115671360, 0.894734032264802080, 0.894711701177097310, 0.894689367852613660, 0.894667032291406650, 0.894644694493532010, +0.894622354459045700, 0.894600012188003450, 0.894577667680461210, 0.894555320936474390, 0.894532971956099710, 0.894510620739392470, 0.894488267286408840, 0.894465911597204450, +0.894443553671835260, 0.894421193510357200, 0.894398831112826250, 0.894376466479297690, 0.894354099609828480, 0.894331730504473900, 0.894309359163290130, 0.894286985586332910, +0.894264609773658180, 0.894242231725321910, 0.894219851441380160, 0.894197468921888340, 0.894175084166903170, 0.894152697176480380, 0.894130307950675830, 0.894107916489545460, +0.894085522793145350, 0.894063126861531440, 0.894040728694759370, 0.894018328292885740, 0.893995925655966420, 0.893973520784057230, 0.893951113677214140, 0.893928704335493430, +0.893906292758950840, 0.893883878947642540, 0.893861462901624270, 0.893839044620952650, 0.893816624105683410, 0.893794201355872620, 0.893771776371576230, 0.893749349152850540, +0.893726919699751380, 0.893704488012334600, 0.893682054090656930, 0.893659617934774220, 0.893637179544742420, 0.893614738920617710, 0.893592296062456050, 0.893569850970313720, +0.893547403644246670, 0.893524954084310870, 0.893502502290562940, 0.893480048263058820, 0.893457592001854590, 0.893435133507006430, 0.893412672778570390, 0.893390209816602670, +0.893367744621159420, 0.893345277192296390, 0.893322807530070540, 0.893300335634537700, 0.893277861505754060, 0.893255385143775670, 0.893232906548658940, 0.893210425720459830, +0.893187942659234400, 0.893165457365039380, 0.893142969837930730, 0.893120480077964740, 0.893097988085197470, 0.893075493859685320, 0.893052997401484360, 0.893030498710650880, +0.893007997787240830, 0.892985494631311160, 0.892962989242917730, 0.892940481622116920, 0.892917971768964810, 0.892895459683517800, 0.892872945365832060, 0.892850428815964100, +0.892827910033969550, 0.892805389019905690, 0.892782865773828370, 0.892760340295793870, 0.892737812585858490, 0.892715282644078620, 0.892692750470510550, 0.892670216065210130, +0.892647679428234640, 0.892625140559639930, 0.892602599459482390, 0.892580056127818320, 0.892557510564704120, 0.892534962770196060, 0.892512412744350670, 0.892489860487223900, +0.892467305998872810, 0.892444749279353470, 0.892422190328722280, 0.892399629147035630, 0.892377065734349940, 0.892354500090721480, 0.892331932216206440, 0.892309362110861870, +0.892286789774744070, 0.892264215207909110, 0.892241638410413710, 0.892219059382314270, 0.892196478123667090, 0.892173894634528790, 0.892151308914955310, 0.892128720965003950, +0.892106130784730780, 0.892083538374192300, 0.892060943733444910, 0.892038346862545240, 0.892015747761549680, 0.891993146430514750, 0.891970542869496620, 0.891947937078552470, +0.891925329057738470, 0.891902718807111140, 0.891880106326726980, 0.891857491616642630, 0.891834874676914580, 0.891812255507598910, 0.891789634108752890, 0.891767010480432940, +0.891744384622695340, 0.891721756535596930, 0.891699126219194000, 0.891676493673543290, 0.891653858898701300, 0.891631221894724320, 0.891608582661669760, 0.891585941199593670, +0.891563297508552680, 0.891540651588603520, 0.891518003439802700, 0.891495353062206840, 0.891472700455872240, 0.891450045620856280, 0.891427388557215260, 0.891404729265005690, +0.891382067744284300, 0.891359403995107710, 0.891336738017532770, 0.891314069811615870, 0.891291399377413310, 0.891268726714982810, 0.891246051824380440, 0.891223374705662930, +0.891200695358887020, 0.891178013784109320, 0.891155329981386580, 0.891132643950775520, 0.891109955692332530, 0.891087265206114920, 0.891064572492179190, 0.891041877550582060, +0.891019180381380280, 0.890996480984630470, 0.890973779360389570, 0.890951075508713660, 0.890928369429660580, 0.890905661123286510, 0.890882950589648390, 0.890860237828802860, +0.890837522840806640, 0.890814805625716690, 0.890792086183589740, 0.890769364514482080, 0.890746640618451550, 0.890723914495554330, 0.890701186145847260, 0.890678455569387300, +0.890655722766231280, 0.890632987736435840, 0.890610250480057930, 0.890587510997154050, 0.890564769287781830, 0.890542025351997560, 0.890519279189858290, 0.890496530801420880, +0.890473780186742060, 0.890451027345878890, 0.890428272278887660, 0.890405514985826210, 0.890382755466750940, 0.890359993721718810, 0.890337229750786660, 0.890314463554011450, +0.890291695131450010, 0.890268924483159420, 0.890246151609196070, 0.890223376509617800, 0.890200599184481020, 0.890177819633842790, 0.890155037857760070, 0.890132253856289690, +0.890109467629488620, 0.890086679177413580, 0.890063888500122190, 0.890041095597671080, 0.890018300470117210, 0.889995503117517630, 0.889972703539929300, 0.889949901737409180, +0.889927097710014330, 0.889904291457801370, 0.889881482980828030, 0.889858672279150940, 0.889835859352827270, 0.889813044201913870, 0.889790226826467910, 0.889767407226546350, +0.889744585402206250, 0.889721761353504340, 0.889698935080498470, 0.889676106583245140, 0.889653275861801650, 0.889630442916224950, 0.889607607746572100, 0.889584770352900290, +0.889561930735266020, 0.889539088893727460, 0.889516244828341130, 0.889493398539164200, 0.889470550026253750, 0.889447699289666940, 0.889424846329460950, 0.889401991145692740, +0.889379133738419260, 0.889356274107698240, 0.889333412253586640, 0.889310548176141410, 0.889287681875419840, 0.889264813351479110, 0.889241942604376280, 0.889219069634168640, +0.889196194440912910, 0.889173317024667060, 0.889150437385487940, 0.889127555523432810, 0.889104671438558650, 0.889081785130922950, 0.889058896600582680, 0.889036005847594790, +0.889013112872017340, 0.888990217673907070, 0.888967320253321260, 0.888944420610317200, 0.888921518744951960, 0.888898614657283040, 0.888875708347367510, 0.888852799815262440, +0.888829889061025670, 0.888806976084714150, 0.888784060886385170, 0.888761143466096140, 0.888738223823904220, 0.888715301959866700, 0.888692377874040540, 0.888669451566483910, +0.888646523037253560, 0.888623592286406970, 0.888600659314001340, 0.888577724120094060, 0.888554786704742530, 0.888531847068004030, 0.888508905209935420, 0.888485961130594970, +0.888463014830039750, 0.888440066308326840, 0.888417115565513840, 0.888394162601658040, 0.888371207416816850, 0.888348250011047560, 0.888325290384407330, 0.888302328536954230, +0.888279364468745340, 0.888256398179838040, 0.888233429670289730, 0.888210458940157930, 0.888187485989499810, 0.888164510818372670, 0.888141533426834660, 0.888118553814942870, +0.888095571982754570, 0.888072587930327510, 0.888049601657718850, 0.888026613164986210, 0.888003622452187000, 0.887980629519378390, 0.887957634366618560, 0.887934636993964690, +0.887911637401474270, 0.887888635589204720, 0.887865631557213540, 0.887842625305558240, 0.887819616834296440, 0.887796606143485210, 0.887773593233182940, 0.887750578103446600, +0.887727560754333790, 0.887704541185902140, 0.887681519398209050, 0.887658495391312250, 0.887635469165268810, 0.887612440720137010, 0.887589410055974140, 0.887566377172837820, +0.887543342070785450, 0.887520304749874870, 0.887497265210163370, 0.887474223451708790, 0.887451179474568310, 0.887428133278800100, 0.887405084864461680, 0.887382034231610550, +0.887358981380304330, 0.887335926310600650, 0.887312869022557240, 0.887289809516231150, 0.887266747791680910, 0.887243683848963900, 0.887220617688137540, 0.887197549309259760, +0.887174478712388080, 0.887151405897580240, 0.887128330864893840, 0.887105253614386190, 0.887082174146115790, 0.887059092460140030, 0.887036008556516540, 0.887012922435302940, +0.886989834096557180, 0.886966743540336670, 0.886943650766699450, 0.886920555775702610, 0.886897458567404760, 0.886874359141863300, 0.886851257499135960, 0.886828153639280470, +0.886805047562354680, 0.886781939268416090, 0.886758828757522320, 0.886735716029732000, 0.886712601085102300, 0.886689483923691070, 0.886666364545556140, 0.886643242950755360, +0.886620119139346350, 0.886596993111387180, 0.886573864866935010, 0.886550734406048590, 0.886527601728785420, 0.886504466835203230, 0.886481329725359870, 0.886458190399313170, +0.886435048857120990, 0.886411905098841160, 0.886388759124531190, 0.886365610934249700, 0.886342460528054210, 0.886319307906002550, 0.886296153068152680, 0.886272996014562440, +0.886249836745289680, 0.886226675260391890, 0.886203511559927830, 0.886180345643954980, 0.886157177512531200, 0.886134007165714550, 0.886110834603562990, 0.886087659826134240, +0.886064482833486270, 0.886041303625676790, 0.886018122202764440, 0.885994938564806710, 0.885971752711861790, 0.885948564643987300, 0.885925374361241520, 0.885902181863682300, +0.885878987151367260, 0.885855790224355010, 0.885832591082703400, 0.885809389726470280, 0.885786186155713700, 0.885762980370491610, 0.885739772370862100, 0.885716562156883210, +0.885693349728612470, 0.885670135086108700, 0.885646918229429650, 0.885623699158633370, 0.885600477873777710, 0.885577254374920960, 0.885554028662121070, 0.885530800735436000, +0.885507570594923690, 0.885484338240642770, 0.885461103672650960, 0.885437866891006450, 0.885414627895767190, 0.885391386686991470, 0.885368143264737230, 0.885344897629062210, +0.885321649780025480, 0.885298399717684430, 0.885275147442097570, 0.885251892953322740, 0.885228636251418120, 0.885205377336442000, 0.885182116208452440, 0.885158852867507170, +0.885135587313665150, 0.885112319546984220, 0.885089049567522430, 0.885065777375337980, 0.885042502970489140, 0.885019226353034090, 0.884995947523030900, 0.884972666480537410, +0.884949383225612780, 0.884926097758314660, 0.884902810078701200, 0.884879520186830800, 0.884856228082761540, 0.884832933766551810, 0.884809637238259230, 0.884786338497942970, +0.884763037545660990, 0.884739734381471240, 0.884716429005432350, 0.884693121417602260, 0.884669811618039370, 0.884646499606801970, 0.884623185383947910, 0.884599868949536350, +0.884576550303625030, 0.884553229446272350, 0.884529906377536700, 0.884506581097476150, 0.884483253606149210, 0.884459923903613720, 0.884436591989928860, 0.884413257865152460, +0.884389921529342930, 0.884366582982558660, 0.884343242224857830, 0.884319899256298950, 0.884296554076940410, 0.884273206686839950, 0.884249857086056860, 0.884226505274649190, +0.884203151252675350, 0.884179795020193500, 0.884156436577262170, 0.884133075923939860, 0.884109713060284740, 0.884086347986354990, 0.884062980702209790, 0.884039611207907080, +0.884016239503505390, 0.883992865589063090, 0.883969489464638600, 0.883946111130290420, 0.883922730586076510, 0.883899347832056260, 0.883875962868287510, 0.883852575694829000, +0.883829186311739010, 0.883805794719075940, 0.883782400916898530, 0.883759004905265040, 0.883735606684233680, 0.883712206253863710, 0.883688803614213200, 0.883665398765340670, +0.883641991707304620, 0.883618582440163670, 0.883595170963976220, 0.883571757278800440, 0.883548341384695620, 0.883524923281720050, 0.883501502969932130, 0.883478080449390470, +0.883454655720153580, 0.883431228782279980, 0.883407799635828380, 0.883384368280856870, 0.883360934717424940, 0.883337498945590550, 0.883314060965412430, 0.883290620776949200, +0.883267178380259370, 0.883243733775401660, 0.883220286962434600, 0.883196837941416350, 0.883173386712406530, 0.883149933275463090, 0.883126477630644890, 0.883103019778010530, +0.883079559717618650, 0.883056097449527840, 0.883032632973796310, 0.883009166290483650, 0.882985697399648050, 0.882962226301348240, 0.882938752995642840, 0.882915277482590580, +0.882891799762250180, 0.882868319834680170, 0.882844837699939040, 0.882821353358086200, 0.882797866809179930, 0.882774378053279070, 0.882750887090442250, 0.882727393920728190, +0.882703898544195620, 0.882680400960903280, 0.882656901170909670, 0.882633399174274080, 0.882609894971055020, 0.882586388561311220, 0.882562879945101520, 0.882539369122484540, +0.882515856093519240, 0.882492340858263780, 0.882468823416777900, 0.882445303769120000, 0.882421781915348810, 0.882398257855523170, 0.882374731589701920, 0.882351203117943790, +0.882327672440307630, 0.882304139556851940, 0.882280604467636340, 0.882257067172719120, 0.882233527672159350, 0.882209985966015740, 0.882186442054347150, 0.882162895937212420, +0.882139347614670060, 0.882115797086779670, 0.882092244353599900, 0.882068689415189460, 0.882045132271607300, 0.882021572922912390, 0.881998011369163450, 0.881974447610419540, +0.881950881646739070, 0.881927313478181870, 0.881903743104806240, 0.881880170526671340, 0.881856595743836010, 0.881833018756359220, 0.881809439564299910, 0.881785858167716930, +0.881762274566668890, 0.881738688761215640, 0.881715100751415680, 0.881691510537327860, 0.881667918119011350, 0.881644323496525000, 0.881620726669927860, 0.881597127639278550, +0.881573526404636710, 0.881549922966061160, 0.881526317323610750, 0.881502709477344550, 0.881479099427321610, 0.881455487173600890, 0.881431872716241460, 0.881408256055301930, +0.881384637190842150, 0.881361016122920840, 0.881337392851596960, 0.881313767376929570, 0.881290139698977850, 0.881266509817800750, 0.881242877733457330, 0.881219243446006330, +0.881195606955507580, 0.881171968262019820, 0.881148327365602220, 0.881124684266313740, 0.881101038964213660, 0.881077391459360810, 0.881053741751814170, 0.881030089841633560, +0.881006435728877710, 0.880982779413605810, 0.880959120895877020, 0.880935460175750310, 0.880911797253285060, 0.880888132128540220, 0.880864464801574650, 0.880840795272448410, +0.880817123541220100, 0.880793449607949030, 0.880769773472694250, 0.880746095135515160, 0.880722414596470720, 0.880698731855619870, 0.880675046913022670, 0.880651359768737760, +0.880627670422824530, 0.880603978875342030, 0.880580285126349670, 0.880556589175906620, 0.880532891024072060, 0.880509190670904830, 0.880485488116464990, 0.880461783360811490, +0.880438076404003510, 0.880414367246100450, 0.880390655887161370, 0.880366942327245660, 0.880343226566412620, 0.880319508604721080, 0.880295788442231110, 0.880272066079001770, +0.880248341515092240, 0.880224614750561910, 0.880200885785469960, 0.880177154619875780, 0.880153421253838330, 0.880129685687417780, 0.880105947920672980, 0.880082207953663430, +0.880058465786448200, 0.880034721419086900, 0.880010974851638710, 0.879987226084163130, 0.879963475116719020, 0.879939721949366760, 0.879915966582165090, 0.879892209015173510, +0.879868449248451530, 0.879844687282058340, 0.879820923116053420, 0.879797156750496190, 0.879773388185445590, 0.879749617420962030, 0.879725844457104440, 0.879702069293932130, +0.879678291931504820, 0.879654512369881680, 0.879630730609122220, 0.879606946649285510, 0.879583160490431950, 0.879559372132620480, 0.879535581575910500, 0.879511788820361630, +0.879487993866033270, 0.879464196712984920, 0.879440397361275990, 0.879416595810965760, 0.879392792062114400, 0.879368986114781090, 0.879345177969025340, 0.879321367624906650, +0.879297555082484530, 0.879273740341818490, 0.879249923402967700, 0.879226104265992570, 0.879202282930952150, 0.879178459397905950, 0.879154633666913710, 0.879130805738034820, +0.879106975611328890, 0.879083143286855550, 0.879059308764673970, 0.879035472044844560, 0.879011633127426360, 0.878987792012479120, 0.878963948700062450, 0.878940103190235860, +0.878916255483059070, 0.878892405578591610, 0.878868553476892630, 0.878844699178022770, 0.878820842682041190, 0.878796983989007520, 0.878773123098981370, 0.878749260012022360, +0.878725394728190220, 0.878701527247544130, 0.878677657570144710, 0.878653785696051130, 0.878629911625323110, 0.878606035358020290, 0.878582156894202380, 0.878558276233929010, +0.878534393377260030, 0.878510508324254700, 0.878486621074973440, 0.878462731629475630, 0.878438839987821020, 0.878414946150069320, 0.878391050116280160, 0.878367151886513490, +0.878343251460828920, 0.878319348839285750, 0.878295444021944590, 0.878271537008864960, 0.878247627800106350, 0.878223716395728720, 0.878199802795791800, 0.878175887000355430, +0.878151969009478890, 0.878128048823222820, 0.878104126441646700, 0.878080201864810170, 0.878056275092773180, 0.878032346125595440, 0.878008414963336930, 0.877984481606057350, +0.877960546053816130, 0.877936608306673970, 0.877912668364690290, 0.877888726227925020, 0.877864781896437800, 0.877840835370288670, 0.877816886649537500, 0.877792935734243660, +0.877768982624467900, 0.877745027320269710, 0.877721069821708940, 0.877697110128845550, 0.877673148241739250, 0.877649184160450120, 0.877625217885038110, 0.877601249415562610, +0.877577278752084360, 0.877553305894662960, 0.877529330843358270, 0.877505353598230230, 0.877481374159338800, 0.877457392526744040, 0.877433408700505680, 0.877409422680683450, +0.877385434467338080, 0.877361444060529070, 0.877337451460316500, 0.877313456666760310, 0.877289459679920450, 0.877265460499856990, 0.877241459126629320, 0.877217455560298510, +0.877193449800924060, 0.877169441848566040, 0.877145431703284410, 0.877121419365139100, 0.877097404834190300, 0.877073388110498060, 0.877049369194121800, 0.877025348085122670, +0.877001324783560080, 0.876977299289494190, 0.876953271602985080, 0.876929241724092810, 0.876905209652877330, 0.876881175389398470, 0.876857138933717200, 0.876833100285892900, +0.876809059445985970, 0.876785016414056370, 0.876760971190164160, 0.876736923774369630, 0.876712874166732710, 0.876688822367313160, 0.876664768376172020, 0.876640712193369030, +0.876616653818964140, 0.876592593253017750, 0.876568530495589690, 0.876544465546740480, 0.876520398406530070, 0.876496329075018180, 0.876472257552265880, 0.876448183838333010, +0.876424107933279630, 0.876400029837166030, 0.876375949550052380, 0.876351867071998750, 0.876327782403065080, 0.876303695543312440, 0.876279606492800460, 0.876255515251589510, +0.876231421819739790, 0.876207326197311450, 0.876183228384364800, 0.876159128380960220, 0.876135026187157220, 0.876110921803017200, 0.876086815228599770, 0.876062706463965330, +0.876038595509174180, 0.876014482364286580, 0.875990367029362730, 0.875966249504462890, 0.875942129789647030, 0.875918007884976310, 0.875893883790510590, 0.875869757506310130, +0.875845629032435240, 0.875821498368946290, 0.875797365515903700, 0.875773230473367190, 0.875749093241398050, 0.875724953820056110, 0.875700812209401770, 0.875676668409495540, +0.875652522420397480, 0.875628374242168220, 0.875604223874868030, 0.875580071318556860, 0.875555916573295900, 0.875531759639145090, 0.875507600516164940, 0.875483439204415850, +0.875459275703958100, 0.875435110014852190, 0.875410942137157980, 0.875386772070936960, 0.875362599816248980, 0.875338425373154540, 0.875314248741713930, 0.875290069921987770, +0.875265888914036450, 0.875241705717920370, 0.875217520333699590, 0.875193332761435410, 0.875169143001187980, 0.875144951053017710, 0.875120756916984990, 0.875096560593150330, +0.875072362081574350, 0.875048161382317450, 0.875023958495439680, 0.874999753421002560, 0.874975546159065920, 0.874951336709690500, 0.874927125072936680, 0.874902911248865100, +0.874878695237536250, 0.874854477039010200, 0.874830256653348350, 0.874806034080610970, 0.874781809320858360, 0.874757582374151350, 0.874733353240550350, 0.874709121920115960, +0.874684888412908700, 0.874660652718988850, 0.874636414838417810, 0.874612174771255750, 0.874587932517563280, 0.874563688077400920, 0.874539441450829290, 0.874515192637909110, +0.874490941638701000, 0.874466688453265030, 0.874442433081662810, 0.874418175523954510, 0.874393915780200760, 0.874369653850462170, 0.874345389734799580, 0.874321123433273390, +0.874296854945944000, 0.874272584272872910, 0.874248311414120290, 0.874224036369746990, 0.874199759139813630, 0.874175479724380810, 0.874151198123509280, 0.874126914337259750, +0.874102628365692520, 0.874078340208869100, 0.874054049866849870, 0.874029757339695570, 0.874005462627466810, 0.873981165730224440, 0.873956866648029180, 0.873932565380941220, +0.873908261929022380, 0.873883956292332840, 0.873859648470933340, 0.873835338464884810, 0.873811026274247890, 0.873786711899083410, 0.873762395339452210, 0.873738076595414580, +0.873713755667032130, 0.873689432554365260, 0.873665107257474930, 0.873640779776421740, 0.873616450111266650, 0.873592118262070390, 0.873567784228893920, 0.873543448011797510, +0.873519109610842890, 0.873494769026090470, 0.873470426257601180, 0.873446081305435880, 0.873421734169655290, 0.873397384850320370, 0.873373033347491500, 0.873348679661230640, +0.873324323791597970, 0.873299965738654540, 0.873275605502461080, 0.873251243083078780, 0.873226878480568240, 0.873202511694990520, 0.873178142726406150, 0.873153771574876840, +0.873129398240463090, 0.873105022723225880, 0.873080645023226020, 0.873056265140524590, 0.873031883075182540, 0.873007498827260810, 0.872983112396819800, 0.872958723783921480, +0.872934332988626330, 0.872909940010995420, 0.872885544851089600, 0.872861147508969930, 0.872836747984697460, 0.872812346278332600, 0.872787942389937290, 0.872763536319572150, +0.872739128067298250, 0.872714717633176430, 0.872690305017267850, 0.872665890219633480, 0.872641473240334480, 0.872617054079431240, 0.872592632736985950, 0.872568209213059000, +0.872543783507711450, 0.872519355621004580, 0.872494925552999230, 0.872470493303756590, 0.872446058873337260, 0.872421622261803200, 0.872397183469215130, 0.872372742495634120, +0.872348299341121240, 0.872323854005737530, 0.872299406489544290, 0.872274956792602470, 0.872250504914972910, 0.872226050856717450, 0.872201594617896810, 0.872177136198572290, +0.872152675598804940, 0.872128212818655820, 0.872103747858186230, 0.872079280717457220, 0.872054811396529630, 0.872030339895465410, 0.872005866214325300, 0.871981390353170570, +0.871956912312062400, 0.871932432091061860, 0.871907949690230330, 0.871883465109628440, 0.871858978349318360, 0.871834489409360810, 0.871809998289816980, 0.871785504990748250, +0.871761009512215690, 0.871736511854280690, 0.871712012017004320, 0.871687510000447530, 0.871663005804672380, 0.871638499429739700, 0.871613990875710900, 0.871589480142646920, +0.871564967230609390, 0.871540452139659360, 0.871515934869858230, 0.871491415421266850, 0.871466893793947370, 0.871442369987960650, 0.871417844003367970, 0.871393315840230720, +0.871368785498610190, 0.871344252978567660, 0.871319718280164080, 0.871295181403461630, 0.871270642348521250, 0.871246101115404240, 0.871221557704171980, 0.871197012114885870, +0.871172464347607200, 0.871147914402397360, 0.871123362279317300, 0.871098807978429200, 0.871074251499794230, 0.871049692843473560, 0.871025132009528580, 0.871000568998020810, +0.870976003809011750, 0.870951436442562120, 0.870926866898734330, 0.870902295177589440, 0.870877721279188720, 0.870853145203593800, 0.870828566950865970, 0.870803986521066720, +0.870779403914257450, 0.870754819130499350, 0.870730232169854570, 0.870705643032384180, 0.870681051718149690, 0.870656458227212600, 0.870631862559634430, 0.870607264715476560, +0.870582664694800500, 0.870558062497667320, 0.870533458124139510, 0.870508851574277930, 0.870484242848144300, 0.870459631945800120, 0.870435018867306790, 0.870410403612725920, +0.870385786182118590, 0.870361166575547300, 0.870336544793072990, 0.870311920834757390, 0.870287294700661910, 0.870262666390848260, 0.870238035905377960, 0.870213403244312510, +0.870188768407713200, 0.870164131395642300, 0.870139492208161110, 0.870114850845331240, 0.870090207307214200, 0.870065561593871720, 0.870040913705365180, 0.870016263641756100, +0.869991611403106660, 0.869966956989478240, 0.869942300400932460, 0.869917641637530940, 0.869892980699335180, 0.869868317586407150, 0.869843652298808220, 0.869818984836599700, +0.869794315199844180, 0.869769643388602850, 0.869744969402937550, 0.869720293242909670, 0.869695614908581160, 0.869670934400013530, 0.869646251717268610, 0.869621566860407590, +0.869596879829493190, 0.869572190624586460, 0.869547499245749370, 0.869522805693043410, 0.869498109966530540, 0.869473412066272380, 0.869448711992330200, 0.869424009744766750, +0.869399305323643180, 0.869374598729021450, 0.869349889960963180, 0.869325179019530100, 0.869300465904784160, 0.869275750616787080, 0.869251033155600150, 0.869226313521286100, +0.869201591713906210, 0.869176867733522430, 0.869152141580196380, 0.869127413253990010, 0.869102682754965160, 0.869077950083183560, 0.869053215238706710, 0.869028478221597120, +0.869003739031916410, 0.868978997669726420, 0.868954254135088870, 0.868929508428065710, 0.868904760548718790, 0.868880010497109500, 0.868855258273300570, 0.868830503877353610, +0.868805747309330250, 0.868780988569292640, 0.868756227657302540, 0.868731464573421870, 0.868706699317712490, 0.868681931890236010, 0.868657162291055050, 0.868632390520231220, +0.868607616577826370, 0.868582840463902550, 0.868558062178521610, 0.868533281721745490, 0.868508499093635700, 0.868483714294255190, 0.868458927323665360, 0.868434138181928270, +0.868409346869105760, 0.868384553385259880, 0.868359757730452600, 0.868334959904745960, 0.868310159908201480, 0.868285357740882000, 0.868260553402849130, 0.868235746894164940, +0.868210938214891370, 0.868186127365090490, 0.868161314344824240, 0.868136499154154690, 0.868111681793143460, 0.868086862261853500, 0.868062040560346300, 0.868037216688684050, +0.868012390646928810, 0.867987562435142520, 0.867962732053387360, 0.867937899501724950, 0.867913064780218240, 0.867888227888928830, 0.867863388827918800, 0.867838547597250320, +0.867813704196985560, 0.867788858627186470, 0.867764010887915220, 0.867739160979233540, 0.867714308901204380, 0.867689454653889470, 0.867664598237350980, 0.867639739651650870, +0.867614878896851520, 0.867590015973014880, 0.867565150880203250, 0.867540283618478240, 0.867515414187903120, 0.867490542588539300, 0.867465668820449180, 0.867440792883694910, +0.867415914778338680, 0.867391034504442550, 0.867366152062068460, 0.867341267451279490, 0.867316380672137340, 0.867291491724704100, 0.867266600609042260, 0.867241707325213880, +0.867216811873281260, 0.867191914253306660, 0.867167014465351720, 0.867142112509479700, 0.867117208385752460, 0.867092302094232160, 0.867067393634981200, 0.867042483008061640, +0.867017570213535870, 0.866992655251465740, 0.866967738121914520, 0.866942818824943840, 0.866917897360616200, 0.866892973728993770, 0.866868047930138830, 0.866843119964113900, +0.866818189830981130, 0.866793257530802390, 0.866768323063641040, 0.866743386429558840, 0.866718447628618160, 0.866693506660881300, 0.866668563526410750, 0.866643618225268810, +0.866618670757517750, 0.866593721123219640, 0.866568769322437650, 0.866543815355233730, 0.866518859221670270, 0.866493900921809670, 0.866468940455714320, 0.866443977823446620, +0.866419013025068520, 0.866394046060643410, 0.866369076930233130, 0.866344105633900070, 0.866319132171706860, 0.866294156543715780, 0.866269178749989320, 0.866244198790589890, +0.866219216665579550, 0.866194232375021580, 0.866169245918978040, 0.866144257297511430, 0.866119266510684160, 0.866094273558558610, 0.866069278441197520, 0.866044281158663170, +0.866019281711017720, 0.865994280098324460, 0.865969276320645580, 0.865944270378043450, 0.865919262270580580, 0.865894251998319600, 0.865869239561323000, 0.865844224959652850, +0.865819208193372660, 0.865794189262544370, 0.865769168167230600, 0.865744144907493960, 0.865719119483396970, 0.865694091895002130, 0.865669062142372050, 0.865644030225568910, +0.865618996144656090, 0.865593959899695900, 0.865568921490750710, 0.865543880917883150, 0.865518838181156050, 0.865493793280631700, 0.865468746216372490, 0.865443696988441920, +0.865418645596902070, 0.865393592041815540, 0.865368536323245170, 0.865343478441253370, 0.865318418395902840, 0.865293356187256220, 0.865268291815375900, 0.865243225280325270, +0.865218156582166500, 0.865193085720962430, 0.865168012696775570, 0.865142937509668750, 0.865117860159704600, 0.865092780646945720, 0.865067698971454410, 0.865042615133294390, +0.865017529132527830, 0.864992440969217460, 0.864967350643425890, 0.864942258155215970, 0.864917163504650530, 0.864892066691791640, 0.864866967716703020, 0.864841866579446950, +0.864816763280086280, 0.864791657818683720, 0.864766550195301910, 0.864741440410003780, 0.864716328462852070, 0.864691214353909170, 0.864666098083238580, 0.864640979650902700, +0.864615859056964480, 0.864590736301486530, 0.864565611384531810, 0.864540484306163040, 0.864515355066443060, 0.864490223665434150, 0.864465090103200270, 0.864439954379803590, +0.864414816495307050, 0.864389676449773490, 0.864364534243265650, 0.864339389875846580, 0.864314243347578560, 0.864289094658525330, 0.864263943808749380, 0.864238790798313560, +0.864213635627280820, 0.864188478295713990, 0.864163318803675920, 0.864138157151229550, 0.864112993338437390, 0.864087827365363160, 0.864062659232069370, 0.864037488938618870, +0.864012316485074710, 0.863987141871499830, 0.863961965097956970, 0.863936786164508860, 0.863911605071219110, 0.863886421818150450, 0.863861236405365720, 0.863836048832927860, +0.863810859100899940, 0.863785667209344800, 0.863760473158325490, 0.863735276947904640, 0.863710078578145970, 0.863684878049112090, 0.863659675360866070, 0.863634470513470860, +0.863609263506989410, 0.863584054341484890, 0.863558843017020130, 0.863533629533657860, 0.863508413891462050, 0.863483196090495060, 0.863457976130820200, 0.863432754012500300, +0.863407529735598640, 0.863382303300178070, 0.863357074706301300, 0.863331843954032290, 0.863306611043433650, 0.863281375974568550, 0.863256138747499960, 0.863230899362291030, +0.863205657819004930, 0.863180414117704630, 0.863155168258452840, 0.863129920241313520, 0.863104670066349500, 0.863079417733623730, 0.863054163243199390, 0.863028906595139760, +0.863003647789507780, 0.862978386826366290, 0.862953123705779260, 0.862927858427809390, 0.862902590992519870, 0.862877321399973860, 0.862852049650234540, 0.862826775743365190, +0.862801499679428870, 0.862776221458488310, 0.862750941080607680, 0.862725658545849710, 0.862700373854277560, 0.862675087005954410, 0.862649798000943660, 0.862624506839308360, +0.862599213521111800, 0.862573918046416810, 0.862548620415287350, 0.862523320627786470, 0.862498018683977240, 0.862472714583922940, 0.862447408327686850, 0.862422099915332250, +0.862396789346921990, 0.862371476622520230, 0.862346161742189700, 0.862320844705993790, 0.862295525513995800, 0.862270204166258880, 0.862244880662846550, 0.862219555003822080, +0.862194227189248210, 0.862168897219189210, 0.862143565093707930, 0.862118230812867760, 0.862092894376732090, 0.862067555785364090, 0.862042215038827280, 0.862016872137184920, +0.861991527080499860, 0.861966179868836500, 0.861940830502257670, 0.861915478980826770, 0.861890125304607070, 0.861864769473662200, 0.861839411488055320, 0.861814051347849500, +0.861788689053109010, 0.861763324603896820, 0.861737958000276310, 0.861712589242310870, 0.861687218330063900, 0.861661845263599010, 0.861636470042979500, 0.861611092668268300, +0.861585713139529810, 0.861560331456827090, 0.861534947620223530, 0.861509561629782540, 0.861484173485567720, 0.861458783187642460, 0.861433390736069730, 0.861407996130914010, +0.861382599372238270, 0.861357200460106110, 0.861331799394580930, 0.861306396175726240, 0.861280990803605540, 0.861255583278282330, 0.861230173599819790, 0.861204761768282200, +0.861179347783732730, 0.861153931646234880, 0.861128513355852280, 0.861103092912648300, 0.861077670316686690, 0.861052245568030840, 0.861026818666743910, 0.861001389612890410, +0.860975958406533400, 0.860950525047736500, 0.860925089536563330, 0.860899651873077380, 0.860874212057342380, 0.860848770089421400, 0.860823325969378830, 0.860797879697278060, +0.860772431273182480, 0.860746980697155940, 0.860721527969261930, 0.860696073089563970, 0.860670616058126000, 0.860645156875010970, 0.860619695540283500, 0.860594232054006760, +0.860568766416244470, 0.860543298627060250, 0.860517828686517830, 0.860492356594680820, 0.860466882351612840, 0.860441405957377280, 0.860415927412038650, 0.860390446715660230, +0.860364963868305630, 0.860339478870038700, 0.860313991720923040, 0.860288502421022280, 0.860263010970399920, 0.860237517369120570, 0.860212021617247300, 0.860186523714844050, +0.860161023661974440, 0.860135521458702310, 0.860110017105091270, 0.860084510601205390, 0.860059001947107600, 0.860033491142862760, 0.860007978188534360, 0.859982463084185910, +0.859956945829881250, 0.859931426425684320, 0.859905904871658740, 0.859880381167868020, 0.859854855314376780, 0.859829327311248390, 0.859803797158546710, 0.859778264856335460, +0.859752730404678590, 0.859727193803639930, 0.859701655053283220, 0.859676114153671960, 0.859650571104870860, 0.859625025906943340, 0.859599478559953330, 0.859573929063964460, +0.859548377419040890, 0.859522823625246350, 0.859497267682644780, 0.859471709591299480, 0.859446149351275500, 0.859420586962636010, 0.859395022425445190, 0.859369455739766750, +0.859343886905664660, 0.859318315923202850, 0.859292742792444830, 0.859267167513455330, 0.859241590086297970, 0.859216010511036690, 0.859190428787735330, 0.859164844916457840, +0.859139258897268280, 0.859113670730230710, 0.859088080415408300, 0.859062487952866220, 0.859036893342667970, 0.859011296584877400, 0.858985697679558680, 0.858960096626775640, +0.858934493426592450, 0.858908888079072950, 0.858883280584280760, 0.858857670942280940, 0.858832059153136760, 0.858806445216912630, 0.858780829133672260, 0.858755210903479840, +0.858729590526399410, 0.858703968002494490, 0.858678343331830240, 0.858652716514469950, 0.858627087550478010, 0.858601456439918360, 0.858575823182854970, 0.858550187779352100, +0.858524550229473720, 0.858498910533283530, 0.858473268690846500, 0.858447624702226350, 0.858421978567487030, 0.858396330286692820, 0.858370679859907890, 0.858345027287196080, +0.858319372568621340, 0.858293715704248620, 0.858268056694141630, 0.858242395538364460, 0.858216732236981360, 0.858191066790056410, 0.858165399197653780, 0.858139729459837630, +0.858114057576671700, 0.858088383548221150, 0.858062707374549590, 0.858037029055721210, 0.858011348591800390, 0.857985665982851090, 0.857959981228937680, 0.857934294330124250, +0.857908605286474720, 0.857882914098054060, 0.857857220764926100, 0.857831525287155120, 0.857805827664805400, 0.857780127897941000, 0.857754425986626320, 0.857728721930925090, +0.857703015730902570, 0.857677307386622510, 0.857651596898149180, 0.857625884265546870, 0.857600169488879850, 0.857574452568212300, 0.857548733503608720, 0.857523012295132840, +0.857497288942849820, 0.857471563446823630, 0.857445835807118530, 0.857420106023798920, 0.857394374096928980, 0.857368640026573090, 0.857342903812795540, 0.857317165455660390, +0.857291424955232690, 0.857265682311576520, 0.857239937524756020, 0.857214190594835830, 0.857188441521880010, 0.857162690305953160, 0.857136936947119120, 0.857111181445443290, +0.857085423800989400, 0.857059664013821940, 0.857033902084005430, 0.857008138011604030, 0.856982371796682350, 0.856956603439304800, 0.856930832939535200, 0.856905060297438960, +0.856879285513080120, 0.856853508586522980, 0.856827729517832150, 0.856801948307072010, 0.856776164954306970, 0.856750379459601090, 0.856724591823019740, 0.856698802044626780, +0.856673010124486930, 0.856647216062664580, 0.856621419859224130, 0.856595621514230080, 0.856569821027747040, 0.856544018399839070, 0.856518213630571350, 0.856492406720008260, +0.856466597668213980, 0.856440786475253350, 0.856414973141190640, 0.856389157666090580, 0.856363340050017570, 0.856337520293035780, 0.856311698395210710, 0.856285874356606300, +0.856260048177287290, 0.856234219857318070, 0.856208389396763360, 0.856182556795687670, 0.856156722054155160, 0.856130885172231240, 0.856105046149980060, 0.856079204987466370, +0.856053361684754650, 0.856027516241909540, 0.856001668658995520, 0.855975818936077440, 0.855949967073219350, 0.855924113070486770, 0.855898256927943970, 0.855872398645655450, +0.855846538223685950, 0.855820675662100180, 0.855794810960962660, 0.855768944120338100, 0.855743075140290690, 0.855717204020886140, 0.855691330762188510, 0.855665455364262640, +0.855639577827173040, 0.855613698150984540, 0.855587816335761750, 0.855561932381568970, 0.855536046288471910, 0.855510158056534630, 0.855484267685821980, 0.855458375176398670, +0.855432480528329430, 0.855406583741678990, 0.855380684816512080, 0.855354783752893090, 0.855328880550887400, 0.855302975210559650, 0.855277067731974430, 0.855251158115196590, +0.855225246360290850, 0.855199332467321940, 0.855173416436354250, 0.855147498267453510, 0.855121577960684000, 0.855095655516110550, 0.855069730933797900, 0.855043804213810990, +0.855017875356214540, 0.854991944361073510, 0.854966011228452060, 0.854940075958416030, 0.854914138551029820, 0.854888199006358260, 0.854862257324466300, 0.854836313505418550, +0.854810367549280080, 0.854784419456115720, 0.854758469225989860, 0.854732516858968230, 0.854706562355115330, 0.854680605714496000, 0.854654646937175190, 0.854628686023217840, +0.854602722972688690, 0.854576757785652230, 0.854550790462174410, 0.854524821002319630, 0.854498849406152730, 0.854472875673738750, 0.854446899805142550, 0.854420921800429060, +0.854394941659663340, 0.854368959382909800, 0.854342974970234260, 0.854316988421701340, 0.854290999737375990, 0.854265008917323150, 0.854239015961607670, 0.854213020870294710, +0.854187023643448780, 0.854161024281135720, 0.854135022783420020, 0.854109019150366850, 0.854083013382041180, 0.854057005478507820, 0.854030995439832070, 0.854004983266078880, +0.853978968957312620, 0.853952952513599480, 0.853926933935003960, 0.853900913221591120, 0.853874890373426010, 0.853848865390573590, 0.853822838273099020, 0.853796809021067470, +0.853770777634543340, 0.853744744113592690, 0.853718708458280240, 0.853692670668671050, 0.853666630744830180, 0.853640588686822690, 0.853614544494713750, 0.853588498168567970, +0.853562449708451410, 0.853536399114428690, 0.853510346386565090, 0.853484291524925550, 0.853458234529575250, 0.853432175400579360, 0.853406114138003160, 0.853380050741911030, +0.853353985212369380, 0.853327917549442700, 0.853301847753196290, 0.853275775823695180, 0.853249701761004680, 0.853223625565189820, 0.853197547236316020, 0.853171466774447880, +0.853145384179651470, 0.853119299451991610, 0.853093212591533590, 0.853067123598342470, 0.853041032472483530, 0.853014939214022050, 0.852988843823022760, 0.852962746299551820, +0.852936646643673970, 0.852910544855454590, 0.852884440934958740, 0.852858334882251820, 0.852832226697399110, 0.852806116380465770, 0.852780003931516760, 0.852753889350618130, +0.852727772637834840, 0.852701653793232040, 0.852675532816875140, 0.852649409708829410, 0.852623284469160250, 0.852597157097932270, 0.852571027595211970, 0.852544895961063980, +0.852518762195553890, 0.852492626298746780, 0.852466488270708140, 0.852440348111503270, 0.852414205821197650, 0.852388061399855900, 0.852361914847544530, 0.852335766164328380, +0.852309615350272720, 0.852283462405443170, 0.852257307329904900, 0.852231150123723300, 0.852204990786963880, 0.852178829319691580, 0.852152665721972570, 0.852126499993871910, +0.852100332135455000, 0.852074162146787330, 0.852047990027934190, 0.852021815778961080, 0.851995639399932950, 0.851969460890916300, 0.851943280251975850, 0.851917097483177340, +0.851890912584585940, 0.851864725556267350, 0.851838536398286990, 0.851812345110710250, 0.851786151693602060, 0.851759956147029150, 0.851733758471056150, 0.851707558665748880, +0.851681356731172730, 0.851655152667393220, 0.851628946474475730, 0.851602738152485880, 0.851576527701488730, 0.851550315121550770, 0.851524100412736960, 0.851497883575113020, +0.851471664608744240, 0.851445443513696330, 0.851419220290034810, 0.851392994937824830, 0.851366767457132800, 0.851340537848023770, 0.851314306110563470, 0.851288072244817400, +0.851261836250851170, 0.851235598128730400, 0.851209357878520480, 0.851183115500286800, 0.851156870994095870, 0.851130624360012630, 0.851104375598102810, 0.851078124708432140, +0.851051871691066220, 0.851025616546070450, 0.850999359273510340, 0.850973099873452150, 0.850946838345961300, 0.850920574691103380, 0.850894308908944020, 0.850868040999548820, +0.850841770962983520, 0.850815498799313840, 0.850789224508604840, 0.850762948090923340, 0.850736669546334530, 0.850710388874903910, 0.850684106076697420, 0.850657821151780680, +0.850631534100219300, 0.850605244922079120, 0.850578953617425300, 0.850552660186324690, 0.850526364628842350, 0.850500066945044100, 0.850473767134995780, 0.850447465198762910, +0.850421161136411420, 0.850394854948006600, 0.850368546633615050, 0.850342236193302180, 0.850315923627133710, 0.850289608935175470, 0.850263292117493190, 0.850236973174152590, +0.850210652105219620, 0.850184328910759570, 0.850158003590839150, 0.850131676145523760, 0.850105346574879130, 0.850079014878971080, 0.850052681057865580, 0.850026345111628330, +0.850000007040325300, 0.849973666844021760, 0.849947324522784430, 0.849920980076678930, 0.849894633505770880, 0.849868284810126220, 0.849841933989810890, 0.849815581044890740, +0.849789225975431160, 0.849762868781498980, 0.849736509463159590, 0.849710148020479060, 0.849683784453522990, 0.849657418762357560, 0.849631050947048600, 0.849604681007661950, +0.849578308944263120, 0.849551934756919040, 0.849525558445695110, 0.849499180010657270, 0.849472799451871490, 0.849446416769403800, 0.849420031963319940, 0.849393645033685530, +0.849367255980567610, 0.849340864804031370, 0.849314471504143080, 0.849288076080968570, 0.849261678534573900, 0.849235278865025030, 0.849208877072388010, 0.849182473156728230, +0.849156067118112760, 0.849129658956607190, 0.849103248672277380, 0.849076836265189480, 0.849050421735409570, 0.849024005083003570, 0.848997586308037460, 0.848971165410577040, +0.848944742390689070, 0.848918317248439360, 0.848891889983893750, 0.848865460597118540, 0.848839029088179540, 0.848812595457143050, 0.848786159704074560, 0.848759721829041140, +0.848733281832108500, 0.848706839713342600, 0.848680395472809490, 0.848653949110575570, 0.848627500626706670, 0.848601050021269070, 0.848574597294328380, 0.848548142445951560, +0.848521685476204550, 0.848495226385153180, 0.848468765172863850, 0.848442301839402500, 0.848415836384835530, 0.848389368809228880, 0.848362899112648390, 0.848336427295161010, +0.848309953356832680, 0.848283477297729460, 0.848256999117917520, 0.848230518817463030, 0.848204036396432380, 0.848177551854891080, 0.848151065192906390, 0.848124576410543950, +0.848098085507870140, 0.848071592484951120, 0.848045097341853180, 0.848018600078642380, 0.847992100695385110, 0.847965599192147200, 0.847939095568995720, 0.847912589825996490, +0.847886081963215800, 0.847859571980719820, 0.847833059878575050, 0.847806545656847540, 0.847780029315603150, 0.847753510854909240, 0.847726990274831560, 0.847700467575436380, +0.847673942756790090, 0.847647415818958860, 0.847620886762009080, 0.847594355586007150, 0.847567822291018790, 0.847541286877111390, 0.847514749344350780, 0.847488209692803360, +0.847461667922535300, 0.847435124033613100, 0.847408578026103140, 0.847382029900071720, 0.847355479655584660, 0.847328927292709480, 0.847302372811511990, 0.847275816212058500, +0.847249257494415490, 0.847222696658649350, 0.847196133704826490, 0.847169568633012740, 0.847143001443275590, 0.847116432135681000, 0.847089860710295240, 0.847063287167184930, +0.847036711506416240, 0.847010133728055890, 0.846983553832170280, 0.846956971818825120, 0.846930387688088150, 0.846903801440025190, 0.846877213074702650, 0.846850622592187130, +0.846824029992545020, 0.846797435275842950, 0.846770838442146730, 0.846744239491523890, 0.846717638424040460, 0.846691035239762860, 0.846664429938757790, 0.846637822521091540, +0.846611212986830840, 0.846584601336042080, 0.846557987568791300, 0.846531371685146030, 0.846504753685172420, 0.846478133568936860, 0.846451511336505870, 0.846424886987946270, +0.846398260523324340, 0.846371631942706810, 0.846345001246159740, 0.846318368433750630, 0.846291733505545540, 0.846265096461611190, 0.846238457302014080, 0.846211816026820830, +0.846185172636097940, 0.846158527129911800, 0.846131879508329690, 0.846105229771418000, 0.846078577919243120, 0.846051923951871900, 0.846025267869370820, 0.845998609671806510, +0.845971949359245800, 0.845945286931754640, 0.845918622389400850, 0.845891955732250400, 0.845865286960370110, 0.845838616073826600, 0.845811943072686480, 0.845785267957016580, +0.845758590726883530, 0.845731911382353490, 0.845705229923494060, 0.845678546350371760, 0.845651860663052870, 0.845625172861604430, 0.845598482946093190, 0.845571790916585520, +0.845545096773148040, 0.845518400515848260, 0.845491702144752440, 0.845465001659927440, 0.845438299061439860, 0.845411594349356530, 0.845384887523744300, 0.845358178584669770, +0.845331467532199340, 0.845304754366400730, 0.845278039087340230, 0.845251321695084660, 0.845224602189700750, 0.845197880571255330, 0.845171156839815250, 0.845144430995446780, +0.845117703038217650, 0.845090972968194350, 0.845064240785443620, 0.845037506490032180, 0.845010770082027070, 0.844984031561495040, 0.844957290928502910, 0.844930548183117080, +0.844903803325405380, 0.844877056355434090, 0.844850307273270260, 0.844823556078980520, 0.844796802772632030, 0.844770047354291510, 0.844743289824025800, 0.844716530181901510, +0.844689768427986270, 0.844663004562346660, 0.844636238585049440, 0.844609470496161750, 0.844582700295750330, 0.844555927983882130, 0.844529153560623640, 0.844502377026042810, +0.844475598380206030, 0.844448817623180140, 0.844422034755032300, 0.844395249775829470, 0.844368462685638370, 0.844341673484526160, 0.844314882172559230, 0.844288088749805650, +0.844261293216331810, 0.844234495572204760, 0.844207695817491440, 0.844180893952258930, 0.844154089976574150, 0.844127283890504180, 0.844100475694115500, 0.844073665387476080, +0.844046852970652520, 0.844020038443711870, 0.843993221806721090, 0.843966403059747240, 0.843939582202857360, 0.843912759236118080, 0.843885934159597450, 0.843859106973361860, +0.843832277677478590, 0.843805446272014590, 0.843778612757037030, 0.843751777132612850, 0.843724939398809210, 0.843698099555692860, 0.843671257603331610, 0.843644413541792320, +0.843617567371142020, 0.843590719091447780, 0.843563868702776660, 0.843537016205195940, 0.843510161598772120, 0.843483304883573480, 0.843456446059666520, 0.843429585127118410, +0.843402722085996430, 0.843375856936367630, 0.843348989678299080, 0.843322120311858160, 0.843295248837111490, 0.843268375254127120, 0.843241499562971790, 0.843214621763712760, +0.843187741856417090, 0.843160859841152190, 0.843133975717984980, 0.843107089486982990, 0.843080201148212800, 0.843053310701742500, 0.843026418147638900, 0.842999523485969290, +0.842972626716800950, 0.842945727840200940, 0.842918826856236650, 0.842891923764974790, 0.842865018566483660, 0.842838111260829970, 0.842811201848081000, 0.842784290328303930, +0.842757376701566250, 0.842730460967935020, 0.842703543127477750, 0.842676623180261150, 0.842649701126353400, 0.842622776965821440, 0.842595850698732440, 0.842568922325153900, +0.842541991845153100, 0.842515059258797220, 0.842488124566153740, 0.842461187767289510, 0.842434248862272690, 0.842407307851170350, 0.842380364734049760, 0.842353419510978090, +0.842326472182023060, 0.842299522747251730, 0.842272571206731160, 0.842245617560529620, 0.842218661808714080, 0.842191703951351900, 0.842164743988510380, 0.842137781920257010, +0.842110817746659190, 0.842083851467784420, 0.842056883083699410, 0.842029912594472800, 0.842002940000171280, 0.841975965300862490, 0.841948988496613810, 0.841922009587492640, +0.841895028573566350, 0.841868045454902130, 0.841841060231568240, 0.841814072903631640, 0.841787083471159940, 0.841760091934220520, 0.841733098292880790, 0.841706102547208460, +0.841679104697270810, 0.841652104743134900, 0.841625102684869120, 0.841598098522540750, 0.841571092256217070, 0.841544083885965580, 0.841517073411854000, 0.841490060833949620, +0.841463046152320150, 0.841436029367032660, 0.841409010478155420, 0.841381989485755820, 0.841354966389901150, 0.841327941190659010, 0.841300913888097130, 0.841273884482282910, +0.841246852973283500, 0.841219819361167520, 0.841192783646001920, 0.841165745827854310, 0.841138705906792410, 0.841111663882883720, 0.841084619756195860, 0.841057573526796440, +0.841030525194752740, 0.841003474760133040, 0.840976422223004730, 0.840949367583435300, 0.840922310841492490, 0.840895251997244020, 0.840868191050757270, 0.840841128002100090, +0.840814062851339640, 0.840786995598544420, 0.840759926243781820, 0.840732854787119340, 0.840705781228624720, 0.840678705568365660, 0.840651627806409900, 0.840624547942824480, +0.840597465977678260, 0.840570381911038390, 0.840543295742972480, 0.840516207473548380, 0.840489117102833690, 0.840462024630896360, 0.840434930057803790, 0.840407833383623570, +0.840380734608424110, 0.840353633732272900, 0.840326530755237560, 0.840299425677386020, 0.840272318498785810, 0.840245209219504740, 0.840218097839610320, 0.840190984359171060, +0.840163868778254330, 0.840136751096927870, 0.840109631315259620, 0.840082509433317300, 0.840055385451168650, 0.840028259368881590, 0.840001131186523310, 0.839974000904162740, +0.839946868521867170, 0.839919734039704440, 0.839892597457742470, 0.839865458776048900, 0.839838317994691660, 0.839811175113738590, 0.839784030133257200, 0.839756883053316190, +0.839729733873982980, 0.839702582595325380, 0.839675429217411450, 0.839648273740308810, 0.839621116164085520, 0.839593956488808970, 0.839566794714548090, 0.839539630841370070, +0.839512464869343060, 0.839485296798534900, 0.839458126629013530, 0.839430954360846800, 0.839403779994102650, 0.839376603528848570, 0.839349424965153520, 0.839322244303084890, +0.839295061542710610, 0.839267876684098750, 0.839240689727317140, 0.839213500672433830, 0.839186309519516340, 0.839159116268633490, 0.839131920919852780, 0.839104723473242390, +0.839077523928870140, 0.839050322286804100, 0.839023118547112200, 0.838995912709862620, 0.838968704775122640, 0.838941494742961420, 0.838914282613446580, 0.838887068386645950, +0.838859852062627590, 0.838832633641459660, 0.838805413123210110, 0.838778190507947110, 0.838750965795738050, 0.838723738986652090, 0.838696510080756850, 0.838669279078120280, +0.838642045978810540, 0.838614810782895680, 0.838587573490443770, 0.838560334101522420, 0.838533092616200680, 0.838505849034546280, 0.838478603356627270, 0.838451355582511830, +0.838424105712267890, 0.838396853745963620, 0.838369599683667310, 0.838342343525446560, 0.838315085271370330, 0.838287824921506440, 0.838260562475923070, 0.838233297934688150, +0.838206031297870080, 0.838178762565536920, 0.838151491737756830, 0.838124218814597530, 0.838096943796128090, 0.838069666682416450, 0.838042387473530550, 0.838015106169538670, +0.837987822770509090, 0.837960537276509880, 0.837933249687608850, 0.837905960003875180, 0.837878668225376710, 0.837851374352181490, 0.837824078384357800, 0.837796780321974020, +0.837769480165098220, 0.837742177913798680, 0.837714873568143230, 0.837687567128201140, 0.837660258594040140, 0.837632947965728400, 0.837605635243334420, 0.837578320426926260, +0.837551003516572300, 0.837523684512340380, 0.837496363414299670, 0.837469040222518110, 0.837441714937063990, 0.837414387558005460, 0.837387058085411030, 0.837359726519348980, +0.837332392859887590, 0.837305057107094800, 0.837277719261039780, 0.837250379321790470, 0.837223037289415160, 0.837195693163982350, 0.837168346945560300, 0.837140998634217310, +0.837113648230021880, 0.837086295733041830, 0.837058941143346560, 0.837031584461003900, 0.837004225686082240, 0.836976864818650080, 0.836949501858775700, 0.836922136806527610, +0.836894769661973740, 0.836867400425183370, 0.836840029096224460, 0.836812655675165610, 0.836785280162074980, 0.836757902557021200, 0.836730522860072660, 0.836703141071297840, +0.836675757190764700, 0.836648371218542630, 0.836620983154699570, 0.836593592999304140, 0.836566200752424720, 0.836538806414129700, 0.836511409984487810, 0.836484011463567320, +0.836456610851436300, 0.836429208148164240, 0.836401803353819200, 0.836374396468469560, 0.836346987492184060, 0.836319576425031070, 0.836292163267079000, 0.836264748018396230, +0.836237330679051930, 0.836209911249114370, 0.836182489728652060, 0.836155066117733490, 0.836127640416427180, 0.836100212624801830, 0.836072782742925960, 0.836045350770867610, +0.836017916708696410, 0.835990480556480400, 0.835963042314288310, 0.835935601982188410, 0.835908159560249660, 0.835880715048540450, 0.835853268447128930, 0.835825819756084830, +0.835798368975476100, 0.835770916105371460, 0.835743461145839530, 0.835716004096948910, 0.835688544958768320, 0.835661083731366380, 0.835633620414811260, 0.835606155009172570, +0.835578687514518470, 0.835551217930917690, 0.835523746258438840, 0.835496272497150530, 0.835468796647121700, 0.835441318708420750, 0.835413838681116070, 0.835386356565277270, +0.835358872360972620, 0.835331386068270730, 0.835303897687240450, 0.835276407217950380, 0.835248914660469240, 0.835221420014865430, 0.835193923281208450, 0.835166424459566790, +0.835138923550008960, 0.835111420552603900, 0.835083915467420220, 0.835056408294526760, 0.835028899033992360, 0.835001387685885170, 0.834973874250275030, 0.834946358727230110, +0.834918841116819350, 0.834891321419111490, 0.834863799634175340, 0.834836275762079640, 0.834808749802893320, 0.834781221756684570, 0.834753691623523310, 0.834726159403477830, +0.834698625096616960, 0.834671088703009430, 0.834643550222724300, 0.834616009655830270, 0.834588467002395640, 0.834560922262490460, 0.834533375436182890, 0.834505826523541880, +0.834478275524636270, 0.834450722439535000, 0.834423167268307010, 0.834395610011021030, 0.834368050667745550, 0.834340489238550420, 0.834312925723504020, 0.834285360122675400, +0.834257792436133290, 0.834230222663946750, 0.834202650806184720, 0.834175076862915480, 0.834147500834209080, 0.834119922720133910, 0.834092342520758920, 0.834064760236153060, +0.834037175866385370, 0.834009589411524700, 0.833982000871639980, 0.833954410246799950, 0.833926817537074210, 0.833899222742531480, 0.833871625863240820, 0.833844026899270950, +0.833816425850691050, 0.833788822717570040, 0.833761217499977000, 0.833733610197980420, 0.833706000811650360, 0.833678389341055310, 0.833650775786264230, 0.833623160147346280, +0.833595542424370280, 0.833567922617405640, 0.833540300726520520, 0.833512676751785200, 0.833485050693268170, 0.833457422551038610, 0.833429792325165340, 0.833402160015717760, +0.833374525622764590, 0.833346889146375220, 0.833319250586618150, 0.833291609943563440, 0.833263967217279690, 0.833236322407835960, 0.833208675515301530, 0.833181026539745350, +0.833153375481236580, 0.833125722339844500, 0.833098067115637500, 0.833070409808685850, 0.833042750419058180, 0.833015088946823630, 0.832987425392051390, 0.832959759754810510, +0.832932092035170270, 0.832904422233199380, 0.832876750348967800, 0.832849076382544460, 0.832821400333998430, 0.832793722203398760, 0.832766041990814940, 0.832738359696315930, +0.832710675319971010, 0.832682988861848990, 0.832655300322019950, 0.832627609700552610, 0.832599916997516340, 0.832572222212980220, 0.832544525347013510, 0.832516826399685490, +0.832489125371065010, 0.832461422261222110, 0.832433717070225730, 0.832406009798145050, 0.832378300445049350, 0.832350589011007780, 0.832322875496089850, 0.832295159900364730, +0.832267442223901140, 0.832239722466769580, 0.832212000629038550, 0.832184276710777660, 0.832156550712055960, 0.832128822632942970, 0.832101092473507940, 0.832073360233820060, +0.832045625913948370, 0.832017889513963160, 0.831990151033933150, 0.831962410473927720, 0.831934667834016370, 0.831906923114268280, 0.831879176314752940, 0.831851427435539080, +0.831823676476697190, 0.831795923438296110, 0.831768168320405230, 0.831740411123093940, 0.831712651846431620, 0.831684890490487660, 0.831657127055331460, 0.831629361541031950, +0.831601593947659530, 0.831573824275283150, 0.831546052523972290, 0.831518278693796130, 0.831490502784824390, 0.831462724797126350, 0.831434944730770950, 0.831407162585828810, +0.831379378362368640, 0.831351592060460170, 0.831323803680172560, 0.831296013221575540, 0.831268220684738490, 0.831240426069730810, 0.831212629376621660, 0.831184830605481430, +0.831157029756379060, 0.831129226829384060, 0.831101421824566140, 0.831073614741994590, 0.831045805581739020, 0.831017994343868920, 0.830990181028453350, 0.830962365635562810, +0.830934548165266350, 0.830906728617633590, 0.830878906992733920, 0.830851083290637060, 0.830823257511412390, 0.830795429655129200, 0.830767599721857870, 0.830739767711667580, +0.830711933624627810, 0.830684097460808180, 0.830656259220278410, 0.830628418903107900, 0.830600576509366470, 0.830572732039122960, 0.830544885492448200, 0.830517036869411250, +0.830489186170081610, 0.830461333394529100, 0.830433478542823120, 0.830405621615033620, 0.830377762611229970, 0.830349901531481470, 0.830322038375858610, 0.830294173144430770, +0.830266305837267460, 0.830238436454438290, 0.830210564996013090, 0.830182691462061580, 0.830154815852652720, 0.830126938167857430, 0.830099058407744670, 0.830071176572384380, +0.830043292661846070, 0.830015406676199550, 0.829987518615514450, 0.829959628479860710, 0.829931736269307270, 0.829903841983924970, 0.829875945623783200, 0.829848047188951440, +0.829820146679499660, 0.829792244095497460, 0.829764339437014660, 0.829736432704120450, 0.829708523896885760, 0.829680613015379650, 0.829652700059672070, 0.829624785029832830, +0.829596867925931460, 0.829568948748037990, 0.829541027496222160, 0.829513104170553350, 0.829485178771102170, 0.829457251297938010, 0.829429321751130820, 0.829401390130750320, +0.829373456436866330, 0.829345520669548590, 0.829317582828867140, 0.829289642914891270, 0.829261700927691800, 0.829233756867338020, 0.829205810733899870, 0.829177862527447180, +0.829149912248049790, 0.829121959895777750, 0.829094005470700220, 0.829066048972888160, 0.829038090402410940, 0.829010129759338630, 0.828982167043740840, 0.828954202255687720, +0.828926235395249120, 0.828898266462494980, 0.828870295457494580, 0.828842322380318960, 0.828814347231037530, 0.828786370009720220, 0.828758390716436980, 0.828730409351257750, +0.828702425914252580, 0.828674440405491320, 0.828646452825043460, 0.828618463172979940, 0.828590471449370260, 0.828562477654284370, 0.828534481787792320, 0.828506483849964060, +0.828478483840869640, 0.828450481760578450, 0.828422477609161540, 0.828394471386688540, 0.828366463093229250, 0.828338452728853870, 0.828310440293632320, 0.828282425787634780, +0.828254409210931080, 0.828226390563590820, 0.828198369845685180, 0.828170347057283540, 0.828142322198456070, 0.828114295269272720, 0.828086266269803750, 0.828058235200119010, +0.828030202060288210, 0.828002166850382420, 0.827974129570471230, 0.827946090220624710, 0.827918048800913020, 0.827890005311406110, 0.827861959752174250, 0.827833912123287500, +0.827805862424815350, 0.827777810656829200, 0.827749756819398440, 0.827721700912593230, 0.827693642936483950, 0.827665582891140450, 0.827637520776632880, 0.827609456593031640, +0.827581390340406340, 0.827553322018827920, 0.827525251628366210, 0.827497179169091490, 0.827469104641073700, 0.827441028044383240, 0.827412949379090160, 0.827384868645264170, +0.827356785842976560, 0.827328700972296940, 0.827300614033295580, 0.827272525026042760, 0.827244433950608540, 0.827216340807063300, 0.827188245595477100, 0.827160148315919890, +0.827132048968462820, 0.827103947553175510, 0.827075844070128460, 0.827047738519391730, 0.827019630901035700, 0.826991521215130530, 0.826963409461746620, 0.826935295640953690, +0.826907179752823020, 0.826879061797424320, 0.826850941774827990, 0.826822819685104400, 0.826794695528323630, 0.826766569304556280, 0.826738441013871840, 0.826710310656341930, +0.826682178232036160, 0.826654043741025020, 0.826625907183378690, 0.826597768559167670, 0.826569627868462110, 0.826541485111332630, 0.826513340287848840, 0.826485193398082240, +0.826457044442102660, 0.826428893419980380, 0.826400740331786010, 0.826372585177589710, 0.826344427957461880, 0.826316268671472560, 0.826288107319693040, 0.826259943902193370, +0.826231778419043720, 0.826203610870314690, 0.826175441256076560, 0.826147269576399830, 0.826119095831355010, 0.826090920021011810, 0.826062742145441950, 0.826034562204715160, +0.826006380198902050, 0.825978196128072880, 0.825950009992298280, 0.825921821791648640, 0.825893631526194440, 0.825865439196005640, 0.825837244801153840, 0.825809048341708870, +0.825780849817741250, 0.825752649229321570, 0.825724446576520220, 0.825696241859407710, 0.825668035078054200, 0.825639826232530960, 0.825611615322908280, 0.825583402349256530, +0.825555187311646230, 0.825526970210148090, 0.825498751044832390, 0.825470529815769850, 0.825442306523030520, 0.825414081166685910, 0.825385853746806060, 0.825357624263461600, +0.825329392716723120, 0.825301159106661130, 0.825272923433346240, 0.825244685696848950, 0.825216445897239640, 0.825188204034589590, 0.825159960108968970, 0.825131714120448610, +0.825103466069098790, 0.825075215954990450, 0.825046963778193980, 0.825018709538779650, 0.824990453236819080, 0.824962194872382320, 0.824933934445540080, 0.824905671956363000, +0.824877407404921770, 0.824849140791287020, 0.824820872115529350, 0.824792601377719150, 0.824764328577927810, 0.824736053716225710, 0.824707776792683370, 0.824679497807371710, +0.824651216760361240, 0.824622933651722790, 0.824594648481526530, 0.824566361249844060, 0.824538071956745780, 0.824509780602302180, 0.824481487186584210, 0.824453191709662580, +0.824424894171607910, 0.824396594572490930, 0.824368292912382120, 0.824339989191352980, 0.824311683409473920, 0.824283375566815520, 0.824255065663448860, 0.824226753699444430, +0.824198439674873160, 0.824170123589805790, 0.824141805444312590, 0.824113485238465390, 0.824085162972334470, 0.824056838645990660, 0.824028512259504690, 0.824000183812947480, +0.823971853306389890, 0.823943520739902070, 0.823915186113555960, 0.823886849427421850, 0.823858510681570680, 0.823830169876073270, 0.823801827011000350, 0.823773482086422870, +0.823745135102411760, 0.823716786059037310, 0.823688434956371340, 0.823660081794484240, 0.823631726573446970, 0.823603369293330450, 0.823575009954205410, 0.823546648556142900, +0.823518285099213760, 0.823489919583488490, 0.823461552009038810, 0.823433182375935320, 0.823404810684248870, 0.823376436934050270, 0.823348061125410700, 0.823319683258400990, +0.823291303333091530, 0.823262921349554260, 0.823234537307859780, 0.823206151208078940, 0.823177763050282670, 0.823149372834542040, 0.823120980560927970, 0.823092586229511420, +0.823064189840363000, 0.823035791393554430, 0.823007390889156530, 0.822978988327240150, 0.822950583707876220, 0.822922177031135900, 0.822893768297090040, 0.822865357505809360, +0.822836944657365790, 0.822808529751829720, 0.822780112789272540, 0.822751693769764870, 0.822723272693378080, 0.822694849560183130, 0.822666424370250950, 0.822637997123652260, +0.822609567820459130, 0.822581136460742050, 0.822552703044572180, 0.822524267572020460, 0.822495830043158070, 0.822467390458056170, 0.822438948816785810, 0.822410505119417490, +0.822382059366023490, 0.822353611556674300, 0.822325161691441100, 0.822296709770394930, 0.822268255793607070, 0.822239799761148580, 0.822211341673090070, 0.822182881529503580, +0.822154419330460070, 0.822125955076030370, 0.822097488766285970, 0.822069020401297700, 0.822040549981136850, 0.822012077505874680, 0.821983602975581820, 0.821955126390330530, +0.821926647750191310, 0.821898167055235440, 0.821869684305534310, 0.821841199501158860, 0.821812712642180370, 0.821784223728669660, 0.821755732760698910, 0.821727239738338830, +0.821698744661660600, 0.821670247530735590, 0.821641748345634860, 0.821613247106429910, 0.821584743813191690, 0.821556238465991130, 0.821527731064900510, 0.821499221609990560, +0.821470710101332550, 0.821442196538997860, 0.821413680923057550, 0.821385163253583130, 0.821356643530645750, 0.821328121754316240, 0.821299597924666890, 0.821271072041768630, +0.821242544105692640, 0.821214014116510400, 0.821185482074292980, 0.821156947979111980, 0.821128411831038020, 0.821099873630143580, 0.821071333376499400, 0.821042791070176970, +0.821014246711247450, 0.820985700299782460, 0.820957151835853050, 0.820928601319530940, 0.820900048750886620, 0.820871494129992830, 0.820842937456920270, 0.820814378731740350, +0.820785817954524540, 0.820757255125344140, 0.820728690244270640, 0.820700123311375320, 0.820671554326729340, 0.820642983290404860, 0.820614410202472940, 0.820585835063004980, +0.820557257872072450, 0.820528678629746770, 0.820500097336099410, 0.820471513991201330, 0.820442928595124910, 0.820414341147941210, 0.820385751649721720, 0.820357160100537720, +0.820328566500460930, 0.820299970849562630, 0.820271373147914430, 0.820242773395587380, 0.820214171592653860, 0.820185567739184830, 0.820156961835252000, 0.820128353880926640, +0.820099743876280480, 0.820071131821384910, 0.820042517716311090, 0.820013901561131410, 0.819985283355916920, 0.819956663100739340, 0.819928040795670050, 0.819899416440780680, +0.819870790036142720, 0.819842161581827880, 0.819813531077907000, 0.819784898524452910, 0.819756263921536550, 0.819727627269229430, 0.819698988567603370, 0.819670347816729760, +0.819641705016680320, 0.819613060167526660, 0.819584413269339840, 0.819555764322192350, 0.819527113326155580, 0.819498460281301020, 0.819469805187700300, 0.819441148045425010, +0.819412488854546870, 0.819383827615137060, 0.819355164327268180, 0.819326498991011400, 0.819297831606438320, 0.819269162173620670, 0.819240490692630050, 0.819211817163538300, +0.819183141586417030, 0.819154463961337290, 0.819125784288372020, 0.819097102567592160, 0.819068418799069660, 0.819039732982876020, 0.819011045119083180, 0.818982355207762640, +0.818953663248986220, 0.818924969242825100, 0.818896273189352100, 0.818867575088638390, 0.818838874940755800, 0.818810172745775940, 0.818781468503770760, 0.818752762214811860, +0.818724053878970510, 0.818695343496319560, 0.818666631066930270, 0.818637916590874370, 0.818609200068223690, 0.818580481499050050, 0.818551760883425070, 0.818523038221420810, +0.818494313513108420, 0.818465586758560740, 0.818436857957849150, 0.818408127111045380, 0.818379394218221260, 0.818350659279448720, 0.818321922294799500, 0.818293183264344970, +0.818264442188157970, 0.818235699066309890, 0.818206953898872550, 0.818178206685917790, 0.818149457427517550, 0.818120706123743660, 0.818091952774668060, 0.818063197380362040, +0.818034439940898530, 0.818005680456348920, 0.817976918926785030, 0.817948155352278940, 0.817919389732902460, 0.817890622068727420, 0.817861852359825890, 0.817833080606269250, +0.817804306808130320, 0.817775530965480720, 0.817746753078392290, 0.817717973146936950, 0.817689191171186660, 0.817660407151213350, 0.817631621087088640, 0.817602832978885250, +0.817574042826674900, 0.817545250630529410, 0.817516456390520730, 0.817487660106720910, 0.817458861779202020, 0.817430061408035980, 0.817401258993294190, 0.817372454535049810, +0.817343648033374340, 0.817314839488339720, 0.817286028900017890, 0.817257216268481130, 0.817228401593801280, 0.817199584876050490, 0.817170766115300150, 0.817141945311623430, +0.817113122465091820, 0.817084297575777390, 0.817055470643752280, 0.817026641669088450, 0.816997810651858060, 0.816968977592132610, 0.816940142489985140, 0.816911305345487390, +0.816882466158711410, 0.816853624929729240, 0.816824781658613050, 0.816795936345434790, 0.816767088990266840, 0.816738239593180590, 0.816709388154249210, 0.816680534673544400, +0.816651679151138230, 0.816622821587102870, 0.816593961981510460, 0.816565100334433190, 0.816536236645942550, 0.816507370916111920, 0.816478503145012800, 0.816449633332717470, +0.816420761479298100, 0.816391887584826730, 0.816363011649375750, 0.816334133673017100, 0.816305253655822740, 0.816276371597865700, 0.816247487499217720, 0.816218601359951060, +0.816189713180137890, 0.816160822959850370, 0.816131930699160900, 0.816103036398141520, 0.816074140056864070, 0.816045241675401710, 0.816016341253826380, 0.815987438792210140, +0.815958534290625260, 0.815929627749144130, 0.815900719167838790, 0.815871808546781320, 0.815842895886044750, 0.815813981185700920, 0.815785064445822110, 0.815756145666480690, +0.815727224847748960, 0.815698301989699060, 0.815669377092403500, 0.815640450155933890, 0.815611521180363730, 0.815582590165764730, 0.815553657112209280, 0.815524722019769670, +0.815495784888518370, 0.815466845718527460, 0.815437904509869530, 0.815408961262616310, 0.815380015976841070, 0.815351068652615970, 0.815322119290013080, 0.815293167889105000, +0.815264214449963890, 0.815235258972662360, 0.815206301457272020, 0.815177341903866590, 0.815148380312517680, 0.815119416683297900, 0.815090451016279530, 0.815061483311535050, +0.815032513569136860, 0.815003541789157460, 0.814974567971668560, 0.814945592116743890, 0.814916614224455160, 0.814887634294874870, 0.814858652328075530, 0.814829668324129620, +0.814800682283109530, 0.814771694205087100, 0.814742704090136050, 0.814713711938328200, 0.814684717749736160, 0.814655721524432220, 0.814626723262488970, 0.814597722963978920, +0.814568720628974670, 0.814539716257547950, 0.814510709849772590, 0.814481701405720400, 0.814452690925463910, 0.814423678409075810, 0.814394663856628400, 0.814365647268194380, +0.814336628643846260, 0.814307607983655980, 0.814278585287697250, 0.814249560556042030, 0.814220533788762910, 0.814191504985932510, 0.814162474147623330, 0.814133441273907970, +0.814104406364858480, 0.814075369420548480, 0.814046330441050010, 0.814017289426435810, 0.813988246376778360, 0.813959201292150160, 0.813930154172624150, 0.813901105018272620, +0.813872053829167940, 0.813843000605383500, 0.813813945346991700, 0.813784888054064900, 0.813755828726675960, 0.813726767364897460, 0.813697703968802030, 0.813668638538461720, +0.813639571073950460, 0.813610501575340320, 0.813581430042703780, 0.813552356476113680, 0.813523280875642740, 0.813494203241363680, 0.813465123573348990, 0.813436041871670960, +0.813406958136403400, 0.813377872367618490, 0.813348784565388840, 0.813319694729787270, 0.813290602860886390, 0.813261508958759040, 0.813232413023477930, 0.813203315055115230, +0.813174215053744760, 0.813145113019438810, 0.813116008952270100, 0.813086902852311330, 0.813057794719635240, 0.813028684554314760, 0.812999572356421950, 0.812970458126030860, +0.812941341863213540, 0.812912223568042820, 0.812883103240591650, 0.812853980880932640, 0.812824856489138710, 0.812795730065282610, 0.812766601609436700, 0.812737471121674830, +0.812708338602069260, 0.812679204050692830, 0.812650067467618360, 0.812620928852918810, 0.812591788206666890, 0.812562645528935420, 0.812533500819796920, 0.812504354079325200, +0.812475205307592540, 0.812446054504671890, 0.812416901670636070, 0.812387746805558030, 0.812358589909510600, 0.812329430982566160, 0.812300270024798770, 0.812271107036280580, +0.812241942017084770, 0.812212774967283950, 0.812183605886951270, 0.812154434776159560, 0.812125261634981780, 0.812096086463490300, 0.812066909261759060, 0.812037730029860680, +0.812008548767867880, 0.811979365475853810, 0.811950180153891200, 0.811920992802053210, 0.811891803420412230, 0.811862612009042190, 0.811833418568015720, 0.811804223097405630, +0.811775025597284980, 0.811745826067726830, 0.811716624508804110, 0.811687420920589760, 0.811658215303156410, 0.811629007656577970, 0.811599797980927070, 0.811570586276276650, +0.811541372542699760, 0.811512156780269440, 0.811482938989058770, 0.811453719169140770, 0.811424497320587860, 0.811395273443474290, 0.811366047537872560, 0.811336819603855620, +0.811307589641496630, 0.811278357650868750, 0.811249123632044930, 0.811219887585097780, 0.811190649510101450, 0.811161409407128550, 0.811132167276252040, 0.811102923117545170, +0.811073676931080900, 0.811044428716932500, 0.811015178475173130, 0.810985926205875170, 0.810956671909112910, 0.810927415584958950, 0.810898157233486570, 0.810868896854768710, +0.810839634448878630, 0.810810370015889510, 0.810781103555874410, 0.810751835068906020, 0.810722564555058530, 0.810693292014404760, 0.810664017447017660, 0.810634740852970490, +0.810605462232336540, 0.810576181585188960, 0.810546898911600370, 0.810517614211644920, 0.810488327485395570, 0.810459038732925460, 0.810429747954307670, 0.810400455149615560, +0.810371160318922200, 0.810341863462300970, 0.810312564579824700, 0.810283263671567440, 0.810253960737602030, 0.810224655778001730, 0.810195348792839720, 0.810166039782189370, +0.810136728746123970, 0.810107415684716230, 0.810078100598040420, 0.810048783486169380, 0.810019464349176380, 0.809990143187134690, 0.809960820000117710, 0.809931494788198700, +0.809902167551450840, 0.809872838289947160, 0.809843507003761840, 0.809814173692967710, 0.809784838357638260, 0.809755500997846660, 0.809726161613666280, 0.809696820205170530, +0.809667476772432670, 0.809638131315525640, 0.809608783834523840, 0.809579434329499970, 0.809550082800527650, 0.809520729247680040, 0.809491373671030630, 0.809462016070652820, +0.809432656446619440, 0.809403294799004860, 0.809373931127882140, 0.809344565433324560, 0.809315197715405500, 0.809285827974198570, 0.809256456209776930, 0.809227082422214310, +0.809197706611583300, 0.809168328777958630, 0.809138948921413140, 0.809109567042020310, 0.809080183139853530, 0.809050797214986290, 0.809021409267492110, 0.808992019297444240, +0.808962627304915970, 0.808933233289981570, 0.808903837252714200, 0.808874439193187130, 0.808845039111473980, 0.808815637007648250, 0.808786232881783420, 0.808756826733952440, +0.808727418564229920, 0.808698008372688900, 0.808668596159402900, 0.808639181924445280, 0.808609765667889780, 0.808580347389809880, 0.808550927090279090, 0.808521504769370570, +0.808492080427158700, 0.808462654063716650, 0.808433225679117910, 0.808403795273436200, 0.808374362846744910, 0.808344928399117760, 0.808315491930627790, 0.808286053441349630, +0.808256612931356200, 0.808227170400721340, 0.808197725849518540, 0.808168279277821530, 0.808138830685703690, 0.808109380073238850, 0.808079927440499950, 0.808050472787561810, +0.808021016114497500, 0.807991557421380620, 0.807962096708284890, 0.807932633975283810, 0.807903169222451310, 0.807873702449860790, 0.807844233657585510, 0.807814762845700200, +0.807785290014277900, 0.807755815163392340, 0.807726338293117350, 0.807696859403526530, 0.807667378494693500, 0.807637895566691520, 0.807608410619595320, 0.807578923653478050, +0.807549434668413560, 0.807519943664475440, 0.807490450641737520, 0.807460955600273420, 0.807431458540156850, 0.807401959461461200, 0.807372458364261190, 0.807342955248629980, +0.807313450114641510, 0.807283942962369270, 0.807254433791887220, 0.807224922603269060, 0.807195409396588630, 0.807165894171919200, 0.807136376929335490, 0.807106857668910880, +0.807077336390719100, 0.807047813094833980, 0.807018287781329220, 0.806988760450278900, 0.806959231101756050, 0.806929699735835730, 0.806900166352591100, 0.806870630952096100, +0.806841093534424570, 0.806811554099650220, 0.806782012647846990, 0.806752469179088720, 0.806722923693448780, 0.806693376191002120, 0.806663826671821900, 0.806634275135982180, +0.806604721583556780, 0.806575166014619540, 0.806545608429244390, 0.806516048827504720, 0.806486487209475470, 0.806456923575229910, 0.806427357924842100, 0.806397790258385980, +0.806368220575935270, 0.806338648877564010, 0.806309075163346160, 0.806279499433355080, 0.806249921687665850, 0.806220341926351840, 0.806190760149486870, 0.806161176357145020, +0.806131590549400200, 0.806102002726326480, 0.806072412887997690, 0.806042821034487320, 0.806013227165870540, 0.805983631282220610, 0.805954033383611600, 0.805924433470117550, +0.805894831541812410, 0.805865227598770110, 0.805835621641064370, 0.805806013668769920, 0.805776403681960570, 0.805746791680710170, 0.805717177665092770, 0.805687561635182400, +0.805657943591053250, 0.805628323532779130, 0.805598701460433770, 0.805569077374092110, 0.805539451273827760, 0.805509823159714760, 0.805480193031827160, 0.805450560890239250, +0.805420926735024860, 0.805391290566257580, 0.805361652384012580, 0.805332012188363480, 0.805302369979384420, 0.805272725757149370, 0.805243079521732460, 0.805213431273207990, +0.805183781011649780, 0.805154128737131770, 0.805124474449728790, 0.805094818149514780, 0.805065159836563570, 0.805035499510949550, 0.805005837172746760, 0.804976172822029380, +0.804946506458871560, 0.804916838083347020, 0.804887167695530810, 0.804857495295496770, 0.804827820883318950, 0.804798144459071610, 0.804768466022828810, 0.804738785574664940, +0.804709103114653600, 0.804679418642869960, 0.804649732159387730, 0.804620043664281300, 0.804590353157624620, 0.804560660639492160, 0.804530966109958000, 0.804501269569096510, +0.804471571016981190, 0.804441870453687540, 0.804412167879289260, 0.804382463293860540, 0.804352756697475630, 0.804323048090208830, 0.804293337472134380, 0.804263624843326590, +0.804233910203859260, 0.804204193553807680, 0.804174474893245560, 0.804144754222247290, 0.804115031540887150, 0.804085306849239400, 0.804055580147378430, 0.804025851435377970, +0.803996120713313390, 0.803966387981258520, 0.803936653239287650, 0.803906916487475140, 0.803877177725895400, 0.803847436954622680, 0.803817694173731390, 0.803787949383295340, +0.803758202583389920, 0.803728453774088970, 0.803698702955466970, 0.803668950127598090, 0.803639195290556940, 0.803609438444417790, 0.803579679589254470, 0.803549918725142480, +0.803520155852155750, 0.803490390970368560, 0.803460624079855410, 0.803430855180690790, 0.803401084272948870, 0.803371311356704370, 0.803341536432031100, 0.803311759499004350, +0.803281980557698280, 0.803252199608187280, 0.803222416650545830, 0.803192631684848220, 0.803162844711169170, 0.803133055729582930, 0.803103264740163470, 0.803073471742986490, +0.803043676738125710, 0.803013879725655850, 0.802984080705651190, 0.802954279678186440, 0.802924476643335880, 0.802894671601173670, 0.802864864551775300, 0.802835055495214830, +0.802805244431566640, 0.802775431360905340, 0.802745616283305430, 0.802715799198841510, 0.802685980107588180, 0.802656159009619290, 0.802626335905010540, 0.802596510793835980, +0.802566683676170120, 0.802536854552087450, 0.802507023421662800, 0.802477190284970550, 0.802447355142085320, 0.802417517993081140, 0.802387678838033750, 0.802357837677017070, +0.802327994510105840, 0.802298149337374640, 0.802268302158898110, 0.802238452974750720, 0.802208601785006750, 0.802178748589741810, 0.802148893389029950, 0.802119036182945890, +0.802089176971564230, 0.802059315754959590, 0.802029452533206790, 0.801999587306380210, 0.801969720074554250, 0.801939850837804390, 0.801909979596205020, 0.801880106349830650, +0.801850231098755970, 0.801820353843055830, 0.801790474582804720, 0.801760593318076920, 0.801730710048948140, 0.801700824775492650, 0.801670937497785060, 0.801641048215900100, +0.801611156929912580, 0.801581263639897120, 0.801551368345928440, 0.801521471048080910, 0.801491571746430150, 0.801461670441050540, 0.801431767132016800, 0.801401861819403540, +0.801371954503285580, 0.801342045183737860, 0.801312133860835000, 0.801282220534651260, 0.801252305205262470, 0.801222387872742910, 0.801192468537167410, 0.801162547198610800, +0.801132623857147670, 0.801102698512853100, 0.801072771165801220, 0.801042841816068000, 0.801012910463727580, 0.800982977108855020, 0.800953041751524930, 0.800923104391812140, +0.800893165029791690, 0.800863223665538300, 0.800833280299126370, 0.800803334930631720, 0.800773387560128840, 0.800743438187692340, 0.800713486813397380, 0.800683533437318570, +0.800653578059530970, 0.800623620680109500, 0.800593661299128350, 0.800563699916663650, 0.800533736532789700, 0.800503771147581420, 0.800473803761113660, 0.800443834373461340, +0.800413862984699520, 0.800383889594902480, 0.800353914204146260, 0.800323936812505240, 0.800293957420054380, 0.800263976026868720, 0.800233992633022970, 0.800204007238592310, +0.800174019843651660, 0.800144030448275420, 0.800114039052539640, 0.800084045656518690, 0.800054050260287640, 0.800024052863921530, 0.799994053467495300, 0.799964052071083900, +0.799934048674761810, 0.799904043278605200, 0.799874035882688350, 0.799844026487086520, 0.799814015091874660, 0.799784001697127600, 0.799753986302920720, 0.799723968909328730, +0.799693949516426360, 0.799663928124289660, 0.799633904732993120, 0.799603879342611790, 0.799573851953220840, 0.799543822564895200, 0.799513791177710040, 0.799483757791740410, +0.799453722407060810, 0.799423685023747390, 0.799393645641874870, 0.799363604261518200, 0.799333560882752430, 0.799303515505652820, 0.799273468130294430, 0.799243418756751870, +0.799213367385101290, 0.799183314015417200, 0.799153258647774980, 0.799123201282249450, 0.799093141918916010, 0.799063080557849690, 0.799033017199125670, 0.799002951842818670, +0.798972884489004720, 0.798942815137758560, 0.798912743789155330, 0.798882670443270330, 0.798852595100178590, 0.798822517759955390, 0.798792438422675890, 0.798762357088414810, +0.798732273757248310, 0.798702188429251110, 0.798672101104498490, 0.798642011783065600, 0.798611920465027710, 0.798581827150460000, 0.798551731839437170, 0.798521634532035510, +0.798491535228329830, 0.798461433928395300, 0.798431330632307090, 0.798401225340140690, 0.798371118051971140, 0.798341008767873840, 0.798310897487923500, 0.798280784212196390, +0.798250668940767350, 0.798220551673711640, 0.798190432411104540, 0.798160311153021440, 0.798130187899537490, 0.798100062650727530, 0.798069935406667930, 0.798039806167433530, +0.798009674933099600, 0.797979541703741520, 0.797949406479434580, 0.797919269260254030, 0.797889130046275490, 0.797858988837573450, 0.797828845634224510, 0.797798700436303410, +0.797768553243885630, 0.797738404057046440, 0.797708252875861220, 0.797678099700405370, 0.797647944530754270, 0.797617787366982740, 0.797587628209167400, 0.797557467057382840, +0.797527303911704790, 0.797497138772208290, 0.797466971638969070, 0.797436802512062390, 0.797406631391563200, 0.797376458277547880, 0.797346283170091490, 0.797316106069269390, +0.797285926975156990, 0.797255745887829770, 0.797225562807363230, 0.797195377733832760, 0.797165190667313280, 0.797135001607881420, 0.797104810555612000, 0.797074617510580510, +0.797044422472862560, 0.797014225442533530, 0.796984026419668920, 0.796953825404343790, 0.796923622396634500, 0.796893417396616230, 0.796863210404364470, 0.796833001419954610, +0.796802790443462250, 0.796772577474963000, 0.796742362514532230, 0.796712145562245010, 0.796681926618177940, 0.796651705682406060, 0.796621482755004990, 0.796591257836050120, +0.796561030925617250, 0.796530802023781680, 0.796500571130619120, 0.796470338246204610, 0.796440103370614770, 0.796409866503924760, 0.796379627646209950, 0.796349386797546190, +0.796319143958008850, 0.796288899127673750, 0.796258652306615860, 0.796228403494911860, 0.796198152692636830, 0.796167899899866470, 0.796137645116676280, 0.796107388343141990, +0.796077129579339290, 0.796046868825343700, 0.796016606081230480, 0.795986341347076130, 0.795956074622956140, 0.795925805908945790, 0.795895535205121020, 0.795865262511557310, +0.795834987828330620, 0.795804711155516320, 0.795774432493189690, 0.795744151841427660, 0.795713869200305180, 0.795683584569897960, 0.795653297950281830, 0.795623009341532410, +0.795592718743725500, 0.795562426156936290, 0.795532131581241590, 0.795501835016716450, 0.795471536463436820, 0.795441235921478310, 0.795410933390916620, 0.795380628871827700, +0.795350322364287270, 0.795320013868370370, 0.795289703384154060, 0.795259390911713380, 0.795229076451124280, 0.795198760002462590, 0.795168441565803910, 0.795138121141224060, +0.795107798728798440, 0.795077474328603870, 0.795047147940715630, 0.795016819565209420, 0.794986489202161310, 0.794956156851646890, 0.794925822513742110, 0.794895486188522790, +0.794865147876064100, 0.794834807576443200, 0.794804465289735250, 0.794774121016016080, 0.794743774755361730, 0.794713426507847820, 0.794683076273550390, 0.794652724052545280, +0.794622369844907860, 0.794592013650714970, 0.794561655470042090, 0.794531295302965070, 0.794500933149559830, 0.794470569009902320, 0.794440202884068250, 0.794409834772133230, +0.794379464674174090, 0.794349092590266310, 0.794318718520485860, 0.794288342464908540, 0.794257964423610410, 0.794227584396667300, 0.794197202384155250, 0.794166818386149780, +0.794136432402727690, 0.794106044433964490, 0.794075654479936220, 0.794045262540718830, 0.794014868616388260, 0.793984472707020550, 0.793954074812691650, 0.793923674933477040, +0.793893273069453790, 0.793862869220697260, 0.793832463387283640, 0.793802055569288840, 0.793771645766788940, 0.793741233979859960, 0.793710820208577190, 0.793680404453018020, +0.793649986713257930, 0.793619566989372750, 0.793589145281438650, 0.793558721589531670, 0.793528295913727980, 0.793497868254103510, 0.793467438610733770, 0.793437006983696010, +0.793406573373065750, 0.793376137778919130, 0.793345700201332100, 0.793315260640380830, 0.793284819096141350, 0.793254375568689270, 0.793223930058101880, 0.793193482564454650, +0.793163033087823650, 0.793132581628285150, 0.793102128185915080, 0.793071672760789830, 0.793041215352985330, 0.793010755962577200, 0.792980294589642810, 0.792949831234257660, +0.792919365896497920, 0.792888898576439740, 0.792858429274159390, 0.792827957989732930, 0.792797484723236520, 0.792767009474745880, 0.792736532244338270, 0.792706053032089410, +0.792675571838075350, 0.792645088662372380, 0.792614603505056640, 0.792584116366204410, 0.792553627245891400, 0.792523136144194780, 0.792492643061190380, 0.792462147996954360, +0.792431650951562980, 0.792401151925092420, 0.792370650917619050, 0.792340147929219030, 0.792309642959968090, 0.792279136009943600, 0.792248627079221170, 0.792218116167877300, +0.792187603275988140, 0.792157088403629860, 0.792126571550878960, 0.792096052717811580, 0.792065531904503570, 0.792035009111032310, 0.792004484337473390, 0.791973957583903320, +0.791943428850398480, 0.791912898137034920, 0.791882365443889120, 0.791851830771036940, 0.791821294118555730, 0.791790755486521220, 0.791760214875009800, 0.791729672284097850, +0.791699127713861860, 0.791668581164377880, 0.791638032635722520, 0.791607482127971610, 0.791576929641202410, 0.791546375175490980, 0.791515818730913480, 0.791485260307546510, +0.791454699905466460, 0.791424137524749600, 0.791393573165471880, 0.791363006827710660, 0.791332438511542110, 0.791301868217042290, 0.791271295944287910, 0.791240721693355240, +0.791210145464320780, 0.791179567257261020, 0.791148987072251670, 0.791118404909370470, 0.791087820768693330, 0.791057234650296540, 0.791026646554256700, 0.790996056480650190, +0.790965464429553620, 0.790934870401043270, 0.790904274395195280, 0.790873676412087170, 0.790843076451794860, 0.790812474514394850, 0.790781870599963630, 0.790751264708577710, +0.790720656840313670, 0.790690046995247480, 0.790659435173456710, 0.790628821375017330, 0.790598205600005820, 0.790567587848498900, 0.790536968120572950, 0.790506346416304680, +0.790475722735770380, 0.790445097079046420, 0.790414469446210080, 0.790383839837337730, 0.790353208252505660, 0.790322574691790570, 0.790291939155269190, 0.790261301643017780, +0.790230662155113170, 0.790200020691631420, 0.790169377252650130, 0.790138731838245460, 0.790108084448493790, 0.790077435083472060, 0.790046783743256650, 0.790016130427924400, +0.789985475137551240, 0.789954817872214890, 0.789924158631991500, 0.789893497416957690, 0.789862834227190170, 0.789832169062765540, 0.789801501923760530, 0.789770832810251730, +0.789740161722315430, 0.789709488660029100, 0.789678813623469140, 0.789648136612712160, 0.789617457627834750, 0.789586776668913750, 0.789556093736025750, 0.789525408829247040, +0.789494721948655330, 0.789464033094326890, 0.789433342266338320, 0.789402649464766350, 0.789371954689687790, 0.789341257941179380, 0.789310559219317700, 0.789279858524179150, +0.789249155855841540, 0.789218451214381060, 0.789187744599874400, 0.789157036012398390, 0.789126325452029760, 0.789095612918845330, 0.789064898412921820, 0.789034181934335610, +0.789003463483164410, 0.788972743059484620, 0.788942020663372930, 0.788911296294906310, 0.788880569954161340, 0.788849841641214860, 0.788819111356143350, 0.788788379099024660, +0.788757644869934940, 0.788726908668951120, 0.788696170496149930, 0.788665430351608520, 0.788634688235403390, 0.788603944147611590, 0.788573198088309280, 0.788542450057574620, +0.788511700055483880, 0.788480948082113780, 0.788450194137541360, 0.788419438221843460, 0.788388680335097010, 0.788357920477378740, 0.788327158648765240, 0.788296394849334340, +0.788265629079162420, 0.788234861338326540, 0.788204091626903410, 0.788173319944970090, 0.788142546292603500, 0.788111770669879920, 0.788080993076877510, 0.788050213513672550, +0.788019431980342080, 0.787988648476963040, 0.787957863003612480, 0.787927075560367120, 0.787896286147304230, 0.787865494764499960, 0.787834701412032490, 0.787803906089978300, +0.787773108798414330, 0.787742309537417640, 0.787711508307065040, 0.787680705107433820, 0.787649899938600240, 0.787619092800642460, 0.787588283693636980, 0.787557472617660740, +0.787526659572790780, 0.787495844559104260, 0.787465027576678130, 0.787434208625589330, 0.787403387705914560, 0.787372564817731880, 0.787341739961117670, 0.787310913136149200, +0.787280084342903420, 0.787249253581457480, 0.787218420851888310, 0.787187586154273200, 0.787156749488688520, 0.787125910855212440, 0.787095070253921670, 0.787064227684893260, +0.787033383148204260, 0.787002536643931830, 0.786971688172152910, 0.786940837732944320, 0.786909985326384230, 0.786879130952549130, 0.786848274611516190, 0.786817416303362550, +0.786786556028165500, 0.786755693786001850, 0.786724829576949110, 0.786693963401083770, 0.786663095258483990, 0.786632225149226480, 0.786601353073388410, 0.786570479031047040, +0.786539603022279320, 0.786508725047162740, 0.786477845105773680, 0.786446963198190630, 0.786416079324490200, 0.786385193484749450, 0.786354305679045850, 0.786323415907456360, +0.786292524170058460, 0.786261630466929210, 0.786230734798145310, 0.786199837163785050, 0.786168937563925360, 0.786138035998643180, 0.786107132468016000, 0.786076226972120980, +0.786045319511035400, 0.786014410084836410, 0.785983498693600960, 0.785952585337407310, 0.785921670016332170, 0.785890752730452840, 0.785859833479846670, 0.785828912264590950, +0.785797989084762840, 0.785767063940439270, 0.785736136831698520, 0.785705207758617520, 0.785674276721273430, 0.785643343719743760, 0.785612408754105650, 0.785581471824436490, +0.785550532930813670, 0.785519592073314010, 0.785488649252015890, 0.785457704466996140, 0.785426757718332260, 0.785395809006101290, 0.785364858330380830, 0.785333905691248390, +0.785302951088781010, 0.785271994523055740, 0.785241035994151070, 0.785210075502143830, 0.785179113047111300, 0.785148148629131070, 0.785117182248280530, 0.785086213904636950, +0.785055243598277270, 0.785024271329279990, 0.784993297097722140, 0.784962320903681010, 0.784931342747234080, 0.784900362628458750, 0.784869380547432600, 0.784838396504232930, +0.784807410498936760, 0.784776422531622610, 0.784745432602367400, 0.784714440711248520, 0.784683446858343680, 0.784652451043730160, 0.784621453267485450, 0.784590453529686700, +0.784559451830412200, 0.784528448169739210, 0.784497442547745010, 0.784466434964507300, 0.784435425420103360, 0.784404413914611020, 0.784373400448107550, 0.784342385020670000, +0.784311367632377080, 0.784280348283305730, 0.784249326973533560, 0.784218303703138050, 0.784187278472196710, 0.784156251280787250, 0.784125222128987160, 0.784094191016873500, +0.784063157944524860, 0.784032122912018290, 0.784001085919431520, 0.783970046966841920, 0.783939006054327200, 0.783907963181965100, 0.783876918349832420, 0.783845871558008000, +0.783814822806569000, 0.783783772095592800, 0.783752719425157230, 0.783721664795339890, 0.783690608206218390, 0.783659549657870440, 0.783628489150372980, 0.783597426683804830, +0.783566362258243050, 0.783535295873765470, 0.783504227530449680, 0.783473157228373300, 0.783442084967613920, 0.783411010748249480, 0.783379934570356820, 0.783348856434014970, +0.783317776339301000, 0.783286694286292500, 0.783255610275067290, 0.783224524305703110, 0.783193436378277540, 0.783162346492867870, 0.783131254649552910, 0.783100160848409830, +0.783069065089516240, 0.783037967372950060, 0.783006867698789020, 0.782975766067110720, 0.782944662477992990, 0.782913556931513100, 0.782882449427749870, 0.782851339966780580, +0.782820228548682830, 0.782789115173534560, 0.782757999841413480, 0.782726882552397420, 0.782695763306563650, 0.782664642103991000, 0.782633518944756630, 0.782602393828938590, +0.782571266756614480, 0.782540137727862350, 0.782509006742759690, 0.782477873801384670, 0.782446738903814330, 0.782415602050127720, 0.782384463240402010, 0.782353322474715230, +0.782322179753145220, 0.782291035075769690, 0.782259888442666470, 0.782228739853913610, 0.782197589309588380, 0.782166436809769720, 0.782135282354535000, 0.782104125943962060, +0.782072967578128720, 0.782041807257113030, 0.782010644980992820, 0.781979480749845470, 0.781948314563749910, 0.781917146422783650, 0.781885976327024390, 0.781854804276550300, +0.781823630271439200, 0.781792454311769030, 0.781761276397617610, 0.781730096529062560, 0.781698914706182800, 0.781667730929055730, 0.781636545197759270, 0.781605357512371590, +0.781574167872970400, 0.781542976279633870, 0.781511782732439820, 0.781480587231465850, 0.781449389776790900, 0.781418190368492470, 0.781386989006648710, 0.781355785691337350, +0.781324580422636530, 0.781293373200624200, 0.781262164025377960, 0.781230952896976860, 0.781199739815498400, 0.781168524781020500, 0.781137307793621450, 0.781106088853378950, +0.781074867960371400, 0.781043645114676500, 0.781012420316372080, 0.780981193565537080, 0.780949964862249100, 0.780918734206586310, 0.780887501598626520, 0.780856267038448130, +0.780825030526128950, 0.780793792061746710, 0.780762551645380550, 0.780731309277107990, 0.780700064957007170, 0.780668818685156250, 0.780637570461633180, 0.780606320286516220, +0.780575068159883420, 0.780543814081812390, 0.780512558052382510, 0.780481300071671160, 0.780450040139756500, 0.780418778256716790, 0.780387514422630100, 0.780356248637574690, +0.780324980901628610, 0.780293711214869570, 0.780262439577376730, 0.780231165989227820, 0.780199890450501090, 0.780168612961274490, 0.780137333521626400, 0.780106052131635090, +0.780074768791377940, 0.780043483500934550, 0.780012196260382320, 0.779980907069799720, 0.779949615929264820, 0.779918322838855870, 0.779887027798651040, 0.779855730808728720, +0.779824431869166500, 0.779793130980043770, 0.779761828141438240, 0.779730523353428070, 0.779699216616091650, 0.779667907929507240, 0.779636597293752900, 0.779605284708907220, +0.779573970175047700, 0.779542653692253840, 0.779511335260603230, 0.779480014880174380, 0.779448692551045540, 0.779417368273294890, 0.779386042047000900, 0.779354713872241200, +0.779323383749095270, 0.779292051677640820, 0.779260717657956350, 0.779229381690120020, 0.779198043774210310, 0.779166703910305400, 0.779135362098483770, 0.779104018338823150, +0.779072672631403120, 0.779041324976301300, 0.779009975373596290, 0.778978623823366250, 0.778947270325689670, 0.778915914880644930, 0.778884557488309760, 0.778853198148763860, +0.778821836862084950, 0.778790473628351410, 0.778759108447641730, 0.778727741320034310, 0.778696372245607390, 0.778665001224439710, 0.778633628256608870, 0.778602253342194570, +0.778570876481274540, 0.778539497673927490, 0.778508116920231590, 0.778476734220265420, 0.778445349574107380, 0.778413962981835960, 0.778382574443529100, 0.778351183959266390, +0.778319791529125670, 0.778288397153185430, 0.778257000831524270, 0.778225602564220690, 0.778194202351352950, 0.778162800192999220, 0.778131396089239090, 0.778099990040150400, +0.778068582045811750, 0.778037172106301630, 0.778005760221698540, 0.777974346392081180, 0.777942930617527840, 0.777911512898116660, 0.777880093233927260, 0.777848671625037680, +0.777817248071526300, 0.777785822573471840, 0.777754395130952900, 0.777722965744047980, 0.777691534412835010, 0.777660101137393700, 0.777628665917802220, 0.777597228754139060, +0.777565789646482930, 0.777534348594912220, 0.777502905599505630, 0.777471460660341900, 0.777440013777498830, 0.777408564951056260, 0.777377114181092340, 0.777345661467685690, +0.777314206810914790, 0.777282750210858460, 0.777251291667595210, 0.777219831181203750, 0.777188368751762120, 0.777156904379350140, 0.777125438064045880, 0.777093969805928040, +0.777062499605075230, 0.777031027461566270, 0.776999553375479660, 0.776968077346893660, 0.776936599375887990, 0.776905119462540820, 0.776873637606930960, 0.776842153809136900, +0.776810668069237490, 0.776779180387311310, 0.776747690763437300, 0.776716199197693520, 0.776684705690159680, 0.776653210240914160, 0.776621712850035560, 0.776590213517602820, +0.776558712243694440, 0.776527209028389230, 0.776495703871766030, 0.776464196773903100, 0.776432687734880170, 0.776401176754775490, 0.776369663833667900, 0.776338148971636110, +0.776306632168759060, 0.776275113425115350, 0.776243592740783250, 0.776212070115842810, 0.776180545550372190, 0.776149019044450220, 0.776117490598155600, 0.776085960211567390, +0.776054427884764200, 0.776022893617824950, 0.775991357410827920, 0.775959819263853050, 0.775928279176978600, 0.775896737150283510, 0.775865193183846500, 0.775833647277746620, +0.775802099432062580, 0.775770549646872640, 0.775738997922256980, 0.775707444258293850, 0.775675888655061980, 0.775644331112640530, 0.775612771631108200, 0.775581210210543940, +0.775549646851026670, 0.775518081552634690, 0.775486514315448020, 0.775454945139545160, 0.775423374025004940, 0.775391800971906190, 0.775360225980328050, 0.775328649050349260, +0.775297070182048850, 0.775265489375505210, 0.775233906630798500, 0.775202321948006980, 0.775170735327209590, 0.775139146768485390, 0.775107556271913300, 0.775075963837572380, +0.775044369465541010, 0.775012773155899230, 0.774981174908725530, 0.774949574724098870, 0.774917972602098270, 0.774886368542802790, 0.774854762546291380, 0.774823154612642950, +0.774791544741936230, 0.774759932934251160, 0.774728319189666230, 0.774696703508260480, 0.774665085890112960, 0.774633466335302830, 0.774601844843908930, 0.774570221416010510, +0.774538596051685960, 0.774506968751015430, 0.774475339514077430, 0.774443708340951220, 0.774412075231715620, 0.774380440186449910, 0.774348803205233030, 0.774317164288143680, +0.774285523435261910, 0.774253880646666340, 0.774222235922436110, 0.774190589262650270, 0.774158940667387880, 0.774127290136728210, 0.774095637670750290, 0.774063983269532740, +0.774032326933155820, 0.774000668661698030, 0.773969008455238640, 0.773937346313856580, 0.773905682237631340, 0.773874016226641760, 0.773842348280966650, 0.773810678400686180, +0.773779006585879060, 0.773747332836624450, 0.773715657153001390, 0.773683979535089270, 0.773652299982967250, 0.773620618496714370, 0.773588935076409470, 0.773557249722132690, +0.773525562433962870, 0.773493873211979150, 0.773462182056260720, 0.773430488966886820, 0.773398793943936740, 0.773367096987489620, 0.773335398097624300, 0.773303697274420940, +0.773271994517958360, 0.773240289828315830, 0.773208583205572510, 0.773176874649807780, 0.773145164161100910, 0.773113451739530500, 0.773081737385177050, 0.773050021098119270, +0.773018302878436430, 0.772986582726207790, 0.772954860641512750, 0.772923136624430570, 0.772891410675040410, 0.772859682793421320, 0.772827952979653570, 0.772796221233815860, +0.772764487555987590, 0.772732751946248130, 0.772701014404676870, 0.772669274931352960, 0.772637533526356000, 0.772605790189764500, 0.772574044921659150, 0.772542297722118690, +0.772510548591222480, 0.772478797529049910, 0.772447044535680360, 0.772415289611193100, 0.772383532755667180, 0.772351773969182980, 0.772320013251819200, 0.772288250603655580, +0.772256486024771150, 0.772224719515245630, 0.772192951075158280, 0.772161180704588610, 0.772129408403615320, 0.772097634172319140, 0.772065858010778870, 0.772034079919073910, +0.772002299897283860, 0.771970517945487880, 0.771938734063765790, 0.771906948252196190, 0.771875160510859800, 0.771843370839835560, 0.771811579239202850, 0.771779785709041160, +0.771747990249430080, 0.771716192860449010, 0.771684393542177440, 0.771652592294694300, 0.771620789118080300, 0.771588984012414270, 0.771557176977775820, 0.771525368014244430, +0.771493557121899600, 0.771461744300820820, 0.771429929551087800, 0.771398112872779260, 0.771366294265976140, 0.771334473730757140, 0.771302651267202100, 0.771270826875390390, +0.771239000555401510, 0.771207172307315280, 0.771175342131210420, 0.771143510027167860, 0.771111675995266530, 0.771079840035585940, 0.771048002148205790, 0.771016162333205690, +0.770984320590665130, 0.770952476920663710, 0.770920631323280590, 0.770888783798596490, 0.770856934346690450, 0.770825082967641960, 0.770793229661530850, 0.770761374428436620, +0.770729517268438970, 0.770697658181617510, 0.770665797168051390, 0.770633934227821340, 0.770602069361006390, 0.770570202567686380, 0.770538333847940790, 0.770506463201849350, +0.770474590629491750, 0.770442716130947170, 0.770410839706296310, 0.770378961355618340, 0.770347081078992970, 0.770315198876499910, 0.770283314748218870, 0.770251428694229580, +0.770219540714611630, 0.770187650809444290, 0.770155758978808500, 0.770123865222783200, 0.770091969541448210, 0.770060071934883350, 0.770028172403168340, 0.769996270946382790, +0.769964367564606180, 0.769932462257919110, 0.769900555026400870, 0.769868645870131260, 0.769836734789190010, 0.769804821783656950, 0.769772906853611880, 0.769740989999134430, +0.769709071220303960, 0.769677150517201540, 0.769645227889906080, 0.769613303338497530, 0.769581376863055830, 0.769549448463660690, 0.769517518140391930, 0.769485585893329270, +0.769453651722552090, 0.769421715628141430, 0.769389777610176460, 0.769357837668737000, 0.769325895803902980, 0.769293952015754230, 0.769262006304370580, 0.769230058669831410, +0.769198109112217640, 0.769166157631608560, 0.769134204228084100, 0.769102248901724070, 0.769070291652608540, 0.769038332480817210, 0.769006371386430020, 0.768974408369526460, +0.768942443430187250, 0.768910476568492100, 0.768878507784520710, 0.768846537078353040, 0.768814564450069020, 0.768782589899748570, 0.768750613427471090, 0.768718635033317720, +0.768686654717367630, 0.768654672479700980, 0.768622688320397710, 0.768590702239537630, 0.768558714237200790, 0.768526724313467250, 0.768494732468416260, 0.768462738702129000, +0.768430743014684950, 0.768398745406163930, 0.768366745876646220, 0.768334744426211520, 0.768302741054940010, 0.768270735762911610, 0.768238728550205810, 0.768206719416903770, +0.768174708363084880, 0.768142695388829290, 0.768110680494216940, 0.768078663679327870, 0.768046644944242240, 0.768014624289039330, 0.767982601713800390, 0.767950577218605050, +0.767918550803533220, 0.767886522468665070, 0.767854492214080530, 0.767822460039859770, 0.767790425946082930, 0.767758389932829300, 0.767726352000180470, 0.767694312148215600, +0.767662270377015070, 0.767630226686658810, 0.767598181077226990, 0.767566133548799660, 0.767534084101457070, 0.767502032735278620, 0.767469979450345790, 0.767437924246737960, +0.767405867124535180, 0.767373808083817940, 0.767341747124666070, 0.767309684247159840, 0.767277619451378850, 0.767245552737404360, 0.767213484105315980, 0.767181413555193980, +0.767149341087118300, 0.767117266701169420, 0.767085190397427290, 0.767053112175972160, 0.767021032036883770, 0.766988949980243250, 0.766956866006130440, 0.766924780114625390, +0.766892692305808480, 0.766860602579759850, 0.766828510936559680, 0.766796417376287560, 0.766764321899025100, 0.766732224504851790, 0.766700125193847890, 0.766668023966093680, +0.766635920821669540, 0.766603815760655500, 0.766571708783131860, 0.766539599889178410, 0.766507489078876560, 0.766475376352306000, 0.766443261709547020, 0.766411145150679870, +0.766379026675784840, 0.766346906284942180, 0.766314783978232380, 0.766282659755734950, 0.766250533617531480, 0.766218405563701690, 0.766186275594325950, 0.766154143709484430, +0.766122009909257500, 0.766089874193725650, 0.766057736562968490, 0.766025597017067630, 0.765993455556102650, 0.765961312180154060, 0.765929166889302240, 0.765897019683627560, +0.765864870563210290, 0.765832719528130810, 0.765800566578468960, 0.765768411714306320, 0.765736254935722620, 0.765704096242798230, 0.765671935635613640, 0.765639773114249240, +0.765607608678785300, 0.765575442329302520, 0.765543274065880410, 0.765511103888600770, 0.765478931797543340, 0.765446757792788590, 0.765414581874416910, 0.765382404042508790, +0.765350224297144610, 0.765318042638404420, 0.765285859066369590, 0.765253673581120180, 0.765221486182736670, 0.765189296871299220, 0.765157105646888660, 0.765124912509585360, +0.765092717459469720, 0.765060520496621770, 0.765028321621123110, 0.764996120833053570, 0.764963918132493760, 0.764931713519524160, 0.764899506994225260, 0.764867298556677570, +0.764835088206961110, 0.764802875945157500, 0.764770661771346670, 0.764738445685609220, 0.764706227688025650, 0.764674007778676450, 0.764641785957642320, 0.764609562225003650, +0.764577336580840480, 0.764545109025234650, 0.764512879558265970, 0.764480648180015150, 0.764448414890562700, 0.764416179689989210, 0.764383942578375160, 0.764351703555801400, +0.764319462622347730, 0.764287219778095990, 0.764254975023126230, 0.764222728357519030, 0.764190479781355010, 0.764158229294714770, 0.764125976897678920, 0.764093722590327600, +0.764061466372742530, 0.764029208245003870, 0.763996948207192110, 0.763964686259387960, 0.763932422401672140, 0.763900156634125250, 0.763867888956828000, 0.763835619369860440, +0.763803347873304390, 0.763771074467239910, 0.763738799151747920, 0.763706521926908800, 0.763674242792803380, 0.763641961749512380, 0.763609678797116500, 0.763577393935695790, +0.763545107165332190, 0.763512818486105860, 0.763480527898097390, 0.763448235401387730, 0.763415940996057360, 0.763383644682187220, 0.763351346459857360, 0.763319046329149710, +0.763286744290144540, 0.763254440342922340, 0.763222134487564150, 0.763189826724150590, 0.763157517052762470, 0.763125205473480510, 0.763092891986385080, 0.763060576591557900, +0.763028259289079360, 0.762995940079030040, 0.762963618961490900, 0.762931295936542850, 0.762898971004266400, 0.762866644164742040, 0.762834315418051690, 0.762801984764275410, +0.762769652203494240, 0.762737317735789010, 0.762704981361240320, 0.762672643079929320, 0.762640302891936630, 0.762607960797342720, 0.762575616796229430, 0.762543270888677020, +0.762510923074766530, 0.762478573354578690, 0.762446221728194430, 0.762413868195694570, 0.762381512757160040, 0.762349155412671230, 0.762316796162310070, 0.762284435006156950, +0.762252071944292680, 0.762219706976798190, 0.762187340103754550, 0.762154971325242570, 0.762122600641342520, 0.762090228052136550, 0.762057853557704950, 0.762025477158128850, +0.761993098853488980, 0.761960718643866390, 0.761928336529342000, 0.761895952509996640, 0.761863566585911030, 0.761831178757166990, 0.761798789023845010, 0.761766397386026030, +0.761734003843791090, 0.761701608397221120, 0.761669211046397180, 0.761636811791400080, 0.761604410632310550, 0.761572007569210400, 0.761539602602180340, 0.761507195731301320, +0.761474786956654160, 0.761442376278320120, 0.761409963696380140, 0.761377549210914720, 0.761345132822005890, 0.761312714529734260, 0.761280294334180980, 0.761247872235426780, +0.761215448233553030, 0.761183022328640550, 0.761150594520770610, 0.761118164810023590, 0.761085733196481650, 0.761053299680225500, 0.761020864261336080, 0.760988426939894440, +0.760955987715981720, 0.760923546589679090, 0.760891103561067040, 0.760858658630227720, 0.760826211797241750, 0.760793763062190380, 0.760761312425154430, 0.760728859886215300, +0.760696405445454030, 0.760663949102951760, 0.760631490858789010, 0.760599030713048130, 0.760566568665809630, 0.760534104717154770, 0.760501638867164600, 0.760469171115920270, +0.760436701463503170, 0.760404229909994230, 0.760371756455474060, 0.760339281100025130, 0.760306803843728060, 0.760274324686664000, 0.760241843628914000, 0.760209360670559550, +0.760176875811681580, 0.760144389052360920, 0.760111900392679730, 0.760079409832718930, 0.760046917372559580, 0.760014423012282950, 0.759981926751970180, 0.759949428591702670, +0.759916928531561560, 0.759884426571627470, 0.759851922711982990, 0.759819416952708710, 0.759786909293885810, 0.759754399735595780, 0.759721888277919640, 0.759689374920938800, +0.759656859664733950, 0.759624342509387480, 0.759591823454980220, 0.759559302501593430, 0.759526779649308370, 0.759494254898206210, 0.759461728248368550, 0.759429199699876540, +0.759396669252811020, 0.759364136907254350, 0.759331602663287360, 0.759299066520991330, 0.759266528480447620, 0.759233988541737630, 0.759201446704942610, 0.759168902970144050, +0.759136357337422680, 0.759103809806860870, 0.759071260378539670, 0.759038709052540230, 0.759006155828944040, 0.758973600707832490, 0.758941043689286830, 0.758908484773388130, +0.758875923960218750, 0.758843361249859520, 0.758810796642391930, 0.758778230137897250, 0.758745661736457080, 0.758713091438152800, 0.758680519243065680, 0.758647945151276760, +0.758615369162868540, 0.758582791277921940, 0.758550211496518360, 0.758517629818739160, 0.758485046244665950, 0.758452460774380110, 0.758419873407963130, 0.758387284145495830, +0.758354692987060930, 0.758322099932739360, 0.758289504982612490, 0.758256908136761830, 0.758224309395268970, 0.758191708758215290, 0.758159106225681720, 0.758126501797750980, +0.758093895474504120, 0.758061287256022400, 0.758028677142387530, 0.757996065133680900, 0.757963451229984100, 0.757930835431378740, 0.757898217737945630, 0.757865598149767620, +0.757832976666925620, 0.757800353289501130, 0.757767728017575750, 0.757735100851231080, 0.757702471790548620, 0.757669840835609510, 0.757637207986496250, 0.757604573243290110, +0.757571936606072470, 0.757539298074924930, 0.757506657649929190, 0.757474015331166760, 0.757441371118719340, 0.757408725012667980, 0.757376077013095280, 0.757343427120082400, +0.757310775333711050, 0.757278121654062720, 0.757245466081219010, 0.757212808615261630, 0.757180149256272310, 0.757147488004331960, 0.757114824859523640, 0.757082159821928060, +0.757049492891627150, 0.757016824068702520, 0.756984153353235770, 0.756951480745308710, 0.756918806245002410, 0.756886129852399670, 0.756853451567581550, 0.756820771390629750, +0.756788089321626110, 0.756755405360652110, 0.756722719507789470, 0.756690031763120220, 0.756657342126725970, 0.756624650598688330, 0.756591957179088780, 0.756559261868009590, +0.756526564665532360, 0.756493865571738590, 0.756461164586709870, 0.756428461710528580, 0.756395756943276100, 0.756363050285034030, 0.756330341735884540, 0.756297631295909210, +0.756264918965189770, 0.756232204743807810, 0.756199488631845610, 0.756166770629384640, 0.756134050736506860, 0.756101328953293520, 0.756068605279827220, 0.756035879716189460, +0.756003152262461840, 0.755970422918726180, 0.755937691685064750, 0.755904958561559040, 0.755872223548290980, 0.755839486645341950, 0.755806747852794670, 0.755774007170730400, +0.755741264599231190, 0.755708520138378530, 0.755675773788254790, 0.755643025548941690, 0.755610275420520620, 0.755577523403074270, 0.755544769496684140, 0.755512013701431950, +0.755479256017399510, 0.755446496444669210, 0.755413734983322760, 0.755380971633441870, 0.755348206395108250, 0.755315439268404390, 0.755282670253412000, 0.755249899350212920, +0.755217126558888730, 0.755184351879522150, 0.755151575312194570, 0.755118796856988130, 0.755086016513984330, 0.755053234283265870, 0.755020450164914260, 0.754987664159011200, +0.754954876265639400, 0.754922086484880350, 0.754889294816815990, 0.754856501261528260, 0.754823705819099410, 0.754790908489611390, 0.754758109273146130, 0.754725308169785230, +0.754692505179611390, 0.754659700302706240, 0.754626893539151910, 0.754594084889030010, 0.754561274352423260, 0.754528461929413250, 0.754495647620082140, 0.754462831424511540, +0.754430013342784140, 0.754397193374981790, 0.754364371521186180, 0.754331547781479930, 0.754298722155944730, 0.754265894644662760, 0.754233065247715830, 0.754200233965186430, +0.754167400797156500, 0.754134565743708070, 0.754101728804922880, 0.754068889980883730, 0.754036049271672340, 0.754003206677370750, 0.753970362198060910, 0.753937515833825510, +0.753904667584746280, 0.753871817450905370, 0.753838965432384600, 0.753806111529266690, 0.753773255741633560, 0.753740398069567270, 0.753707538513149760, 0.753674677072463610, +0.753641813747590760, 0.753608948538613150, 0.753576081445613500, 0.753543212468673510, 0.753510341607875560, 0.753477468863301470, 0.753444594235033960, 0.753411717723155070, +0.753378839327746740, 0.753345959048891120, 0.753313076886670820, 0.753280192841167870, 0.753247306912464440, 0.753214419100642460, 0.753181529405784760, 0.753148637827973140, +0.753115744367290010, 0.753082849023817280, 0.753049951797637560, 0.753017052688833120, 0.752984151697485670, 0.752951248823678140, 0.752918344067492470, 0.752885437429010930, +0.752852528908315550, 0.752819618505489060, 0.752786706220613610, 0.752753792053771350, 0.752720876005044340, 0.752687958074515500, 0.752655038262266650, 0.752622116568380290, +0.752589192992938250, 0.752556267536023670, 0.752523340197718270, 0.752490410978104650, 0.752457479877264630, 0.752424546895281150, 0.752391612032236370, 0.752358675288212320, +0.752325736663291830, 0.752292796157556950, 0.752259853771090060, 0.752226909503973310, 0.752193963356289630, 0.752161015328120960, 0.752128065419549800, 0.752095113630658170, +0.752062159961529030, 0.752029204412244520, 0.751996246982886920, 0.751963287673538480, 0.751930326484282150, 0.751897363415199970, 0.751864398466374320, 0.751831431637887460, +0.751798462929822220, 0.751765492342260980, 0.751732519875285550, 0.751699545528979220, 0.751666569303424010, 0.751633591198702320, 0.751600611214896410, 0.751567629352089320, +0.751534645610363090, 0.751501659989800120, 0.751468672490482880, 0.751435683112494200, 0.751402691855916350, 0.751369698720831810, 0.751336703707322640, 0.751303706815471980, +0.751270708045362110, 0.751237707397075520, 0.751204704870694240, 0.751171700466301660, 0.751138694183979600, 0.751105686023811000, 0.751072675985877790, 0.751039664070263240, +0.751006650277049490, 0.750973634606318940, 0.750940617058154510, 0.750907597632638480, 0.750874576329853440, 0.750841553149881770, 0.750808528092806520, 0.750775501158709830, +0.750742472347674550, 0.750709441659782590, 0.750676409095117460, 0.750643374653761300, 0.750610338335796710, 0.750577300141305860, 0.750544260070372230, 0.750511218123077860, +0.750478174299505470, 0.750445128599737330, 0.750412081023856700, 0.750379031571945740, 0.750345980244087050, 0.750312927040363680, 0.750279871960857990, 0.750246815005652600, +0.750213756174829880, 0.750180695468473100, 0.750147632886664530, 0.750114568429486870, 0.750081502097022510, 0.750048433889354720, 0.750015363806565860, 0.749982291848738440, +0.749949218015955150, 0.749916142308299060, 0.749883064725852640, 0.749849985268698500, 0.749816903936919240, 0.749783820730597910, 0.749750735649816980, 0.749717648694659070, +0.749684559865207210, 0.749651469161543900, 0.749618376583752080, 0.749585282131914000, 0.749552185806112830, 0.749519087606431380, 0.749485987532952150, 0.749452885585757620, +0.749419781764931290, 0.749386676070555310, 0.749353568502712840, 0.749320459061486030, 0.749287347746958490, 0.749254234559212470, 0.749221119498330920, 0.749188002564396220, +0.749154883757491840, 0.749121763077700180, 0.749088640525104270, 0.749055516099786270, 0.749022389801830000, 0.748989261631317630, 0.748956131588331740, 0.748922999672955950, +0.748889865885272510, 0.748856730225364590, 0.748823592693314440, 0.748790453289205570, 0.748757312013120680, 0.748724168865142480, 0.748691023845353460, 0.748657876953837230, +0.748624728190676380, 0.748591577555953620, 0.748558425049751670, 0.748525270672153910, 0.748492114423243040, 0.748458956303101890, 0.748425796311813050, 0.748392634449459910, +0.748359470716125300, 0.748326305111891690, 0.748293137636842580, 0.748259968291060670, 0.748226797074628800, 0.748193623987629670, 0.748160449030146670, 0.748127272202262720, +0.748094093504060530, 0.748060912935622710, 0.748027730497032970, 0.747994546188373910, 0.747961360009728570, 0.747928171961179440, 0.747894982042810240, 0.747861790254703450, +0.747828596596942340, 0.747795401069609290, 0.747762203672788120, 0.747729004406561430, 0.747695803271012040, 0.747662600266223330, 0.747629395392278130, 0.747596188649259360, +0.747562980037249970, 0.747529769556333320, 0.747496557206592360, 0.747463342988109900, 0.747430126900968880, 0.747396908945252790, 0.747363689121044340, 0.747330467428426680, +0.747297243867482750, 0.747264018438295820, 0.747230791140948920, 0.747197561975525000, 0.747164330942106880, 0.747131098040778370, 0.747097863271621980, 0.747064626634720620, +0.747031388130158010, 0.746998147758016980, 0.746964905518380570, 0.746931661411331490, 0.746898415436953680, 0.746865167595329730, 0.746831917886543020, 0.746798666310676150, +0.746765412867812840, 0.746732157558036120, 0.746698900381428830, 0.746665641338074120, 0.746632380428055580, 0.746599117651456030, 0.746565853008358760, 0.746532586498846570, +0.746499318123003190, 0.746466047880911530, 0.746432775772654770, 0.746399501798315710, 0.746366225957978190, 0.746332948251725140, 0.746299668679639370, 0.746266387241804830, +0.746233103938304220, 0.746199818769220920, 0.746166531734637760, 0.746133242834638550, 0.746099952069306240, 0.746066659438724080, 0.746033364942974900, 0.746000068582142630, +0.745966770356310200, 0.745933470265560890, 0.745900168309977630, 0.745866864489644120, 0.745833558804643530, 0.745800251255059000, 0.745766941840973590, 0.745733630562471110, +0.745700317419634610, 0.745667002412546910, 0.745633685541292060, 0.745600366805952990, 0.745567046206613070, 0.745533723743355140, 0.745500399416263230, 0.745467073225420270, +0.745433745170909770, 0.745400415252814420, 0.745367083471218490, 0.745333749826204710, 0.745300414317856760, 0.745267076946257270, 0.745233737711490480, 0.745200396613639350, +0.745167053652787240, 0.745133708829017190, 0.745100362142413150, 0.745067013593058160, 0.745033663181035370, 0.745000310906428710, 0.744966956769321340, 0.744933600769796530, +0.744900242907937440, 0.744866883183827990, 0.744833521597551450, 0.744800158149190980, 0.744766792838829850, 0.744733425666552100, 0.744700056632440770, 0.744666685736579240, +0.744633312979050670, 0.744599938359939210, 0.744566561879327790, 0.744533183537300140, 0.744499803333939060, 0.744466421269328830, 0.744433037343552590, 0.744399651556693740, +0.744366263908835420, 0.744332874400061790, 0.744299483030455900, 0.744266089800101120, 0.744232694709081380, 0.744199297757479840, 0.744165898945380100, 0.744132498272865320, +0.744099095740019530, 0.744065691346926020, 0.744032285093668370, 0.743998876980329630, 0.743965467006994060, 0.743932055173744720, 0.743898641480665310, 0.743865225927838990, +0.743831808515349910, 0.743798389243281340, 0.743764968111716660, 0.743731545120739470, 0.743698120270433580, 0.743664693560882380, 0.743631264992169250, 0.743597834564378110, +0.743564402277592570, 0.743530968131895900, 0.743497532127371570, 0.743464094264103540, 0.743430654542175500, 0.743397212961670720, 0.743363769522672580, 0.743330324225265350, +0.743296877069532290, 0.743263428055557120, 0.743229977183422990, 0.743196524453214270, 0.743163069865014240, 0.743129613418906490, 0.743096155114974510, 0.743062694953302350, +0.743029232933973380, 0.742995769057071210, 0.742962303322679760, 0.742928835730882640, 0.742895366281763340, 0.742861894975405450, 0.742828421811893010, 0.742794946791309640, +0.742761469913738810, 0.742727991179264020, 0.742694510587969540, 0.742661028139938840, 0.742627543835255530, 0.742594057674003110, 0.742560569656265710, 0.742527079782127060, +0.742493588051670650, 0.742460094464979850, 0.742426599022139260, 0.742393101723232140, 0.742359602568341990, 0.742326101557553080, 0.742292598690948880, 0.742259093968613340, +0.742225587390629600, 0.742192078957082280, 0.742158568668054740, 0.742125056523630810, 0.742091542523893870, 0.742058026668928390, 0.742024508958817890, 0.741990989393646050, +0.741957467973496490, 0.741923944698453570, 0.741890419568600800, 0.741856892584021880, 0.741823363744800510, 0.741789833051020970, 0.741756300502766970, 0.741722766100122110, +0.741689229843170090, 0.741655691731995300, 0.741622151766681230, 0.741588609947311460, 0.741555066273970610, 0.741521520746741940, 0.741487973365709600, 0.741454424130956860, +0.741420873042568430, 0.741387320100627910, 0.741353765305219010, 0.741320208656425450, 0.741286650154331590, 0.741253089799021160, 0.741219527590577960, 0.741185963529085720, +0.741152397614628810, 0.741118829847290940, 0.741085260227155930, 0.741051688754307490, 0.741018115428830230, 0.740984540250807620, 0.740950963220323280, 0.740917384337461900, +0.740883803602307100, 0.740850221014942690, 0.740816636575452490, 0.740783050283921000, 0.740749462140431910, 0.740715872145069070, 0.740682280297916380, 0.740648686599058250, +0.740615091048578260, 0.740581493646560670, 0.740547894393089100, 0.740514293288248030, 0.740480690332121270, 0.740447085524792660, 0.740413478866346120, 0.740379870356866250, +0.740346259996436550, 0.740312647785141050, 0.740279033723064140, 0.740245417810289740, 0.740211800046901680, 0.740178180432983890, 0.740144558968620970, 0.740110935653896520, +0.740077310488894910, 0.740043683473699640, 0.740010054608395420, 0.739976423893066060, 0.739942791327795720, 0.739909156912668120, 0.739875520647767850, 0.739841882533178730, +0.739808242568985030, 0.739774600755270350, 0.739740957092119510, 0.739707311579616220, 0.739673664217844750, 0.739640015006888700, 0.739606363946832990, 0.739572711037761340, +0.739539056279757690, 0.739505399672906630, 0.739471741217291980, 0.739438080912998120, 0.739404418760108760, 0.739370754758708500, 0.739337088908881500, 0.739303421210711800, +0.739269751664283100, 0.739236080269680460, 0.739202407026987580, 0.739168731936288630, 0.739135054997667630, 0.739101376211209190, 0.739067695576997470, 0.739034013095116290, +0.739000328765649920, 0.738966642588683050, 0.738932954564299530, 0.738899264692583270, 0.738865572973619210, 0.738831879407491290, 0.738798183994283540, 0.738764486734080130, +0.738730787626965760, 0.738697086673024470, 0.738663383872340320, 0.738629679224997560, 0.738595972731080800, 0.738562264390674180, 0.738528554203861880, 0.738494842170727810, +0.738461128291357130, 0.738427412565833440, 0.738393694994241350, 0.738359975576664660, 0.738326254313188320, 0.738292531203896370, 0.738258806248872750, 0.738225079448202480, +0.738191350801969510, 0.738157620310258110, 0.738123887973152430, 0.738090153790737280, 0.738056417763096720, 0.738022679890315110, 0.737988940172476520, 0.737955198609665960, +0.737921455201967280, 0.737887709949465060, 0.737853962852243250, 0.737820213910386770, 0.737786463123979770, 0.737752710493106640, 0.737718956017851420, 0.737685199698299150, +0.737651441534533880, 0.737617681526639650, 0.737583919674701600, 0.737550155978803690, 0.737516390439030390, 0.737482623055465860, 0.737448853828195030, 0.737415082757302050, +0.737381309842871420, 0.737347535084987180, 0.737313758483734370, 0.737279980039197150, 0.737246199751460110, 0.737212417620607190, 0.737178633646723420, 0.737144847829893310, +0.737111060170200890, 0.737077270667730540, 0.737043479322567420, 0.737009686134795450, 0.736975891104499350, 0.736942094231763270, 0.736908295516672250, 0.736874494959310460, +0.736840692559762030, 0.736806888318112250, 0.736773082234445260, 0.736739274308845560, 0.736705464541397400, 0.736671652932185840, 0.736637839481295130, 0.736604024188809880, +0.736570207054814240, 0.736536388079393370, 0.736502567262631520, 0.736468744604613420, 0.736434920105423000, 0.736401093765145510, 0.736367265583865450, 0.736333435561667080, +0.736299603698634900, 0.736265769994854050, 0.736231934450408690, 0.736198097065383190, 0.736164257839862830, 0.736130416773931760, 0.736096573867674690, 0.736062729121175870, +0.736028882534520480, 0.735995034107792990, 0.735961183841077780, 0.735927331734459460, 0.735893477788023050, 0.735859622001852950, 0.735825764376033750, 0.735791904910649830, +0.735758043605786560, 0.735724180461528100, 0.735690315477959160, 0.735656448655164220, 0.735622579993228440, 0.735588709492236090, 0.735554837152271770, 0.735520962973420730, +0.735487086955767140, 0.735453209099395930, 0.735419329404391360, 0.735385447870838700, 0.735351564498822440, 0.735317679288427390, 0.735283792239737720, 0.735249903352839020, +0.735216012627815330, 0.735182120064751810, 0.735148225663732610, 0.735114329424843120, 0.735080431348167920, 0.735046531433791510, 0.735012629681798480, 0.734978726092274210, +0.734944820665303090, 0.734910913400970030, 0.734877004299359320, 0.734843093360556420, 0.734809180584645730, 0.734775265971711830, 0.734741349521840110, 0.734707431235114950, +0.734673511111621160, 0.734639589151443450, 0.734605665354666980, 0.734571739721376350, 0.734537812251656370, 0.734503882945591550, 0.734469951803267350, 0.734436018824768280, +0.734402084010179150, 0.734368147359584440, 0.734334208873069770, 0.734300268550719500, 0.734266326392618570, 0.734232382398851470, 0.734198436569503790, 0.734164488904660130, +0.734130539404404760, 0.734096588068823390, 0.734062634898000610, 0.734028679892021140, 0.733994723050969800, 0.733960764374931850, 0.733926803863992010, 0.733892841518235190, +0.733858877337746020, 0.733824911322609850, 0.733790943472911410, 0.733756973788735720, 0.733723002270167180, 0.733689028917291490, 0.733655053730193240, 0.733621076708957260, +0.733587097853668380, 0.733553117164412070, 0.733519134641272940, 0.733485150284335700, 0.733451164093685830, 0.733417176069408040, 0.733383186211587380, 0.733349194520308330, +0.733315200995656720, 0.733281205637717040, 0.733247208446574430, 0.733213209422313380, 0.733179208565019720, 0.733145205874777940, 0.733111201351673290, 0.733077194995790160, +0.733043186807214480, 0.733009176786030730, 0.732975164932324060, 0.732941151246179310, 0.732907135727681850, 0.732873118376916600, 0.732839099193968170, 0.732805078178922380, +0.732771055331863820, 0.732737030652877760, 0.732703004142048700, 0.732668975799462440, 0.732634945625203820, 0.732600913619357750, 0.732566879782009180, 0.732532844113243600, +0.732498806613146040, 0.732464767281801320, 0.732430726119294500, 0.732396683125711160, 0.732362638301136020, 0.732328591645654340, 0.732294543159350830, 0.732260492842311430, +0.732226440694620620, 0.732192386716363770, 0.732158330907625610, 0.732124273268492050, 0.732090213799047710, 0.732056152499377500, 0.732022089369567250, 0.731988024409701900, +0.731953957619866370, 0.731919889000145600, 0.731885818550625510, 0.731851746271390710, 0.731817672162526690, 0.731783596224118150, 0.731749518456251020, 0.731715438859009910, +0.731681357432480310, 0.731647274176747020, 0.731613189091895770, 0.731579102178011700, 0.731545013435179750, 0.731510922863484960, 0.731476830463013260, 0.731442736233849370, +0.731408640176078430, 0.731374542289786160, 0.731340442575057480, 0.731306341031977780, 0.731272237660631870, 0.731238132461105690, 0.731204025433484170, 0.731169916577852570, +0.731135805894295940, 0.731101693382900100, 0.731067579043749970, 0.731033462876930830, 0.730999344882527820, 0.730965225060626780, 0.730931103411312620, 0.730896979934670730, +0.730862854630786040, 0.730828727499744590, 0.730794598541631310, 0.730760467756531140, 0.730726335144530230, 0.730692200705713390, 0.730658064440166120, 0.730623926347973350, +0.730589786429221010, 0.730555644683994250, 0.730521501112378460, 0.730487355714458550, 0.730453208490320470, 0.730419059440049480, 0.730384908563730840, 0.730350755861449600, +0.730316601333291790, 0.730282444979342360, 0.730248286799686900, 0.730214126794410450, 0.730179964963598940, 0.730145801307337640, 0.730111635825711700, 0.730077468518806390, +0.730043299386707760, 0.730009128429500830, 0.729974955647270880, 0.729940781040103740, 0.729906604608084650, 0.729872426351299010, 0.729838246269832180, 0.729804064363769880, +0.729769880633197480, 0.729735695078200350, 0.729701507698863660, 0.729667318495273550, 0.729633127467515070, 0.729598934615673930, 0.729564739939835060, 0.729530543440084610, +0.729496345116507740, 0.729462144969190150, 0.729427942998216890, 0.729393739203674010, 0.729359533585646760, 0.729325326144220410, 0.729291116879481120, 0.729256905791513920, +0.729222692880404530, 0.729188478146237990, 0.729154261589100680, 0.729120043209077640, 0.729085823006254570, 0.729051600980716640, 0.729017377132549880, 0.728983151461839900, +0.728948923968671840, 0.728914694653131300, 0.728880463515304220, 0.728846230555276090, 0.728811995773132270, 0.728777759168958150, 0.728743520742840100, 0.728709280494863050, +0.728675038425112610, 0.728640794533674920, 0.728606548820635140, 0.728572301286078970, 0.728538051930091910, 0.728503800752759890, 0.728469547754168390, 0.728435292934403010, +0.728401036293549130, 0.728366777831693010, 0.728332517548919810, 0.728298255445315460, 0.728263991520964990, 0.728229725775955020, 0.728195458210370680, 0.728161188824297700, +0.728126917617821330, 0.728092644591028180, 0.728058369744003290, 0.728024093076832470, 0.727989814589601100, 0.727955534282395570, 0.727921252155301120, 0.727886968208403370, +0.727852682441788360, 0.727818394855541670, 0.727784105449749030, 0.727749814224495920, 0.727715521179868490, 0.727681226315952220, 0.727646929632832840, 0.727612631130595930, +0.727578330809327770, 0.727544028669113720, 0.727509724710039610, 0.727475418932190920, 0.727441111335653920, 0.727406801920514210, 0.727372490686857390, 0.727338177634769160, +0.727303862764335670, 0.727269546075642650, 0.727235227568775460, 0.727200907243820360, 0.727166585100863070, 0.727132261139989410, 0.727097935361284640, 0.727063607764835470, +0.727029278350727170, 0.726994947119045780, 0.726960614069876660, 0.726926279203306320, 0.726891942519420240, 0.726857604018304350, 0.726823263700044130, 0.726788921564726080, +0.726754577612435670, 0.726720231843258850, 0.726685884257281200, 0.726651534854589000, 0.726617183635268060, 0.726582830599403980, 0.726548475747082920, 0.726514119078390700, +0.726479760593413350, 0.726445400292236140, 0.726411038174945790, 0.726376674241627770, 0.726342308492368140, 0.726307940927252480, 0.726273571546367180, 0.726239200349797940, +0.726204827337630810, 0.726170452509951270, 0.726136075866845810, 0.726101697408400250, 0.726067317134700410, 0.726032935045832000, 0.725998551141881610, 0.725964165422934740, +0.725929777889077200, 0.725895388540395480, 0.725860997376975290, 0.725826604398902680, 0.725792209606263120, 0.725757812999143440, 0.725723414577629230, 0.725689014341806440, +0.725654612291760870, 0.725620208427579020, 0.725585802749346700, 0.725551395257149840, 0.725516985951074170, 0.725482574831206370, 0.725448161897632170, 0.725413747150437490, +0.725379330589708160, 0.725344912215530880, 0.725310492027991250, 0.725276070027175420, 0.725241646213169110, 0.725207220586058910, 0.725172793145930750, 0.725138363892870230, +0.725103932826964170, 0.725069499948298280, 0.725035065256958600, 0.725000628753030950, 0.724966190436602040, 0.724931750307757690, 0.724897308366583950, 0.724862864613166620, +0.724828419047592430, 0.724793971669947190, 0.724759522480317050, 0.724725071478787840, 0.724690618665446150, 0.724656164040377910, 0.724621707603669400, 0.724587249355406190, +0.724552789295675240, 0.724518327424562240, 0.724483863742153120, 0.724449398248534710, 0.724414930943792830, 0.724380461828013520, 0.724345990901282820, 0.724311518163687440, +0.724277043615313310, 0.724242567256246470, 0.724208089086572970, 0.724173609106379510, 0.724139127315752030, 0.724104643714776790, 0.724070158303539600, 0.724035671082127300, +0.724001182050625800, 0.723966691209121490, 0.723932198557699970, 0.723897704096448380, 0.723863207825452550, 0.723828709744798290, 0.723794209854572550, 0.723759708154861350, +0.723725204645750850, 0.723690699327327100, 0.723656192199676810, 0.723621683262886120, 0.723587172517041190, 0.723552659962227950, 0.723518145598533560, 0.723483629426043610, +0.723449111444844690, 0.723414591655022640, 0.723380070056664380, 0.723345546649856060, 0.723311021434683840, 0.723276494411233760, 0.723241965579592640, 0.723207434939846740, +0.723172902492082210, 0.723138368236385110, 0.723103832172842460, 0.723069294301540100, 0.723034754622564280, 0.723000213136001820, 0.722965669841938880, 0.722931124740461840, +0.722896577831656620, 0.722862029115610150, 0.722827478592408700, 0.722792926262138650, 0.722758372124885810, 0.722723816180737440, 0.722689258429779490, 0.722654698872098430, +0.722620137507780310, 0.722585574336912170, 0.722551009359580050, 0.722516442575870440, 0.722481873985869380, 0.722447303589664020, 0.722412731387340300, 0.722378157378984480, +0.722343581564683590, 0.722309003944523800, 0.722274424518591470, 0.722239843286972660, 0.722205260249754620, 0.722170675407023510, 0.722136088758865590, 0.722101500305367240, +0.722066910046615380, 0.722032317982696290, 0.721997724113696340, 0.721963128439701900, 0.721928530960799790, 0.721893931677076490, 0.721859330588618290, 0.721824727695511430, +0.721790122997843180, 0.721755516495699470, 0.721720908189166680, 0.721686298078332070, 0.721651686163281570, 0.721617072444102000, 0.721582456920879300, 0.721547839593700830, +0.721513220462652760, 0.721478599527821560, 0.721443976789293620, 0.721409352247156080, 0.721374725901495100, 0.721340097752397380, 0.721305467799948970, 0.721270836044237360, +0.721236202485348590, 0.721201567123369250, 0.721166929958385830, 0.721132290990485260, 0.721097650219754030, 0.721063007646278290, 0.721028363270145410, 0.720993717091441550, +0.720959069110253540, 0.720924419326667510, 0.720889767740770630, 0.720855114352649370, 0.720820459162390460, 0.720785802170079930, 0.720751143375805260, 0.720716482779652720, +0.720681820381709030, 0.720647156182060430, 0.720612490180794210, 0.720577822377996840, 0.720543152773754910, 0.720508481368154820, 0.720473808161283700, 0.720439133153228160, +0.720404456344074800, 0.720369777733909870, 0.720335097322820970, 0.720300415110894270, 0.720265731098216120, 0.720231045284874140, 0.720196357670954360, 0.720161668256543820, +0.720126977041728680, 0.720092284026596530, 0.720057589211233640, 0.720022892595726720, 0.719988194180162240, 0.719953493964627710, 0.719918791949209380, 0.719884088133994070, +0.719849382519068160, 0.719814675104519130, 0.719779965890433580, 0.719745254876897890, 0.719710542063998870, 0.719675827451823790, 0.719641111040459140, 0.719606392829991390, +0.719571672820508050, 0.719536951012095470, 0.719502227404840490, 0.719467501998829580, 0.719432774794150240, 0.719398045790889060, 0.719363314989132750, 0.719328582388967800, +0.719293847990481680, 0.719259111793761010, 0.719224373798892480, 0.719189634005962810, 0.719154892415059250, 0.719120149026268530, 0.719085403839677450, 0.719050656855372510, +0.719015908073441290, 0.718981157493970180, 0.718946405117045990, 0.718911650942756110, 0.718876894971187010, 0.718842137202425730, 0.718807377636558780, 0.718772616273673610, +0.718737853113857070, 0.718703088157195750, 0.718668321403776460, 0.718633552853686690, 0.718598782507013030, 0.718564010363842430, 0.718529236424261470, 0.718494460688357760, +0.718459683156217890, 0.718424903827928780, 0.718390122703577050, 0.718355339783250500, 0.718320555067035400, 0.718285768555019020, 0.718250980247287950, 0.718216190143929680, +0.718181398245030910, 0.718146604550678360, 0.718111809060959620, 0.718077011775961390, 0.718042212695770620, 0.718007411820473900, 0.717972609150159040, 0.717937804684912750, +0.717902998424821750, 0.717868190369973070, 0.717833380520454200, 0.717798568876351960, 0.717763755437753170, 0.717728940204744760, 0.717694123177414320, 0.717659304355848460, +0.717624483740134430, 0.717589661330358840, 0.717554837126609500, 0.717520011128973010, 0.717485183337536190, 0.717450353752386640, 0.717415522373611280, 0.717380689201297050, +0.717345854235530880, 0.717311017476400360, 0.717276178923992310, 0.717241338578393780, 0.717206496439691590, 0.717171652507973540, 0.717136806783326250, 0.717101959265836970, +0.717067109955592530, 0.717032258852680630, 0.716997405957188080, 0.716962551269201940, 0.716927694788809130, 0.716892836516097480, 0.716857976451153680, 0.716823114594064670, +0.716788250944918160, 0.716753385503800970, 0.716718518270800350, 0.716683649246003140, 0.716648778429497150, 0.716613905821369190, 0.716579031421706420, 0.716544155230595780, +0.716509277248125080, 0.716474397474381130, 0.716439515909451210, 0.716404632553422350, 0.716369747406382040, 0.716334860468417430, 0.716299971739615680, 0.716265081220063600, +0.716230188909849240, 0.716195294809059300, 0.716160398917780940, 0.716125501236101750, 0.716090601764108880, 0.716055700501889490, 0.716020797449530620, 0.715985892607119980, +0.715950985974744600, 0.715916077552491760, 0.715881167340448490, 0.715846255338702610, 0.715811341547341050, 0.715776425966451080, 0.715741508596119740, 0.715706589436435060, +0.715671668487483760, 0.715636745749353430, 0.715601821222130900, 0.715566894905903970, 0.715531966800759920, 0.715497036906786010, 0.715462105224069170, 0.715427171752697320, +0.715392236492757630, 0.715357299444336900, 0.715322360607523300, 0.715287419982403860, 0.715252477569065850, 0.715217533367596300, 0.715182587378083160, 0.715147639600613670, +0.715112690035275000, 0.715077738682154410, 0.715042785541339710, 0.715007830612917950, 0.714972873896976720, 0.714937915393603070, 0.714902955102884820, 0.714867993024909220, +0.714833029159763540, 0.714798063507535050, 0.714763096068311790, 0.714728126842180790, 0.714693155829229100, 0.714658183029544760, 0.714623208443215030, 0.714588232070327400, +0.714553253910968690, 0.714518273965227270, 0.714483292233190070, 0.714448308714944800, 0.714413323410578280, 0.714378336320178890, 0.714343347443833540, 0.714308356781629960, +0.714273364333655070, 0.714238370099997130, 0.714203374080743190, 0.714168376275980840, 0.714133376685797350, 0.714098375310280640, 0.714063372149517980, 0.714028367203596640, +0.713993360472604640, 0.713958351956629160, 0.713923341655757990, 0.713888329570077970, 0.713853315699677580, 0.713818300044643860, 0.713783282605064410, 0.713748263381026370, +0.713713242372618020, 0.713678219579926610, 0.713643195003039520, 0.713608168642044240, 0.713573140497028800, 0.713538110568080590, 0.713503078855287080, 0.713468045358735540, +0.713433010078514120, 0.713397973014710310, 0.713362934167411480, 0.713327893536705000, 0.713292851122679150, 0.713257806925421180, 0.713222760945018350, 0.713187713181558940, +0.713152663635130190, 0.713117612305819830, 0.713082559193715100, 0.713047504298904400, 0.713012447621474750, 0.712977389161514100, 0.712942328919109690, 0.712907266894349690, +0.712872203087321580, 0.712837137498112950, 0.712802070126811180, 0.712767000973504540, 0.712731930038280390, 0.712696857321226340, 0.712661782822429980, 0.712626706541979350, +0.712591628479962050, 0.712556548636465340, 0.712521467011577480, 0.712486383605386080, 0.712451298417978610, 0.712416211449442670, 0.712381122699866530, 0.712346032169337450, +0.712310939857943470, 0.712275845765771630, 0.712240749892910640, 0.712205652239447760, 0.712170552805470700, 0.712135451591066950, 0.712100348596324870, 0.712065243821331960, +0.712030137266175920, 0.711995028930944240, 0.711959918815725290, 0.711924806920606560, 0.711889693245675530, 0.711854577791020460, 0.711819460556729070, 0.711784341542888940, +0.711749220749587690, 0.711714098176913670, 0.711678973824954490, 0.711643847693797850, 0.711608719783531240, 0.711573590094243150, 0.711538458626021050, 0.711503325378952890, +0.711468190353126030, 0.711433053548629070, 0.711397914965549380, 0.711362774603975010, 0.711327632463993330, 0.711292488545692820, 0.711257342849161200, 0.711222195374485830, +0.711187046121755320, 0.711151895091057250, 0.711116742282479340, 0.711081587696109410, 0.711046431332035710, 0.711011273190345960, 0.710976113271127970, 0.710940951574469460, +0.710905788100458900, 0.710870622849183790, 0.710835455820732150, 0.710800287015191600, 0.710765116432650500, 0.710729944073196780, 0.710694769936918160, 0.710659594023902330, +0.710624416334237790, 0.710589236868012120, 0.710554055625313490, 0.710518872606229370, 0.710483687810848360, 0.710448501239258180, 0.710413312891546410, 0.710378122767801660, +0.710342930868111510, 0.710307737192564130, 0.710272541741247100, 0.710237344514249140, 0.710202145511657610, 0.710166944733560790, 0.710131742180046380, 0.710096537851202750, +0.710061331747117940, 0.710026123867879780, 0.709990914213575960, 0.709955702784295210, 0.709920489580125100, 0.709885274601153800, 0.709850057847469020, 0.709814839319159450, +0.709779619016312810, 0.709744396939016700, 0.709709173087359920, 0.709673947461430310, 0.709638720061315790, 0.709603490887104060, 0.709568259938884060, 0.709533027216743380, +0.709497792720770070, 0.709462556451051940, 0.709427318407677810, 0.709392078590735390, 0.709356837000312710, 0.709321593636497720, 0.709286348499378990, 0.709251101589044360, +0.709215852905581980, 0.709180602449079770, 0.709145350219626320, 0.709110096217309360, 0.709074840442217020, 0.709039582894437800, 0.709004323574059630, 0.708969062481170640, +0.708933799615858780, 0.708898534978212650, 0.708863268568320160, 0.708828000386269590, 0.708792730432148630, 0.708757458706046120, 0.708722185208050080, 0.708686909938248450, +0.708651632896729280, 0.708616354083581370, 0.708581073498892660, 0.708545791142751070, 0.708510507015244870, 0.708475221116462550, 0.708439933446492360, 0.708404644005422250, +0.708369352793340120, 0.708334059810335040, 0.708298765056494810, 0.708263468531907250, 0.708228170236661400, 0.708192870170845200, 0.708157568334546790, 0.708122264727854110, +0.708086959350856080, 0.708051652203640640, 0.708016343286296150, 0.707981032598910430, 0.707945720141572420, 0.707910405914370040, 0.707875089917391790, 0.707839772150725470, +0.707804452614460010, 0.707769131308683350, 0.707733808233483970, 0.707698483388949700, 0.707663156775169560, 0.707627828392231480, 0.707592498240223630, 0.707557166319234820, +0.707521832629352980, 0.707486497170666690, 0.707451159943263800, 0.707415820947233210, 0.707380480182663200, 0.707345137649641910, 0.707309793348257500, 0.707274447278599010, +0.707239099440754250, 0.707203749834811820, 0.707168398460859770, 0.707133045318986910, 0.707097690409281500, 0.707062333731831800, 0.707026975286726090, 0.706991615074053170, +0.706956253093901200, 0.706920889346358330, 0.706885523831513480, 0.706850156549454820, 0.706814787500270820, 0.706779416684049530, 0.706744044100880100, 0.706708669750850450, +0.706673293634049070, 0.706637915750564230, 0.706602536100484960, 0.706567154683899300, 0.706531771500895630, 0.706496386551562440, 0.706460999835988420, 0.706425611354261960, +0.706390221106471540, 0.706354829092705190, 0.706319435313052080, 0.706284039767600460, 0.706248642456438260, 0.706213243379654960, 0.706177842537338400, 0.706142439929577260, +0.706107035556459820, 0.706071629418075000, 0.706036221514511180, 0.706000811845856720, 0.705965400412199910, 0.705929987213629980, 0.705894572250235110, 0.705859155522103770, +0.705823737029324220, 0.705788316771985610, 0.705752894750176220, 0.705717470963984630, 0.705682045413498990, 0.705646618098808580, 0.705611189020001640, 0.705575758177166780, +0.705540325570392150, 0.705504891199767000, 0.705469455065379720, 0.705434017167318350, 0.705398577505672360, 0.705363136080529920, 0.705327692891979500, 0.705292247940109700, +0.705256801225009560, 0.705221352746767340, 0.705185902505471750, 0.705150450501211170, 0.705114996734074740, 0.705079541204150840, 0.705044083911528060, 0.705008624856294790, +0.704973164038540160, 0.704937701458352770, 0.704902237115821010, 0.704866771011033450, 0.704831303144079160, 0.704795833515046710, 0.704760362124024380, 0.704724888971101300, +0.704689414056366200, 0.704653937379907450, 0.704618458941813520, 0.704582978742173790, 0.704547496781076640, 0.704512013058610660, 0.704476527574864450, 0.704441040329927160, +0.704405551323887380, 0.704370060556833600, 0.704334568028854410, 0.704299073740039080, 0.704263577690476090, 0.704228079880254150, 0.704192580309461750, 0.704157078978188130, +0.704121575886521800, 0.704086071034551340, 0.704050564422365910, 0.704015056050054100, 0.703979545917704620, 0.703944034025405950, 0.703908520373247580, 0.703873004961317880, +0.703837487789705670, 0.703801968858499440, 0.703766448167788550, 0.703730925717661600, 0.703695401508207310, 0.703659875539514260, 0.703624347811671710, 0.703588818324768380, +0.703553287078892970, 0.703517754074134080, 0.703482219310581080, 0.703446682788322560, 0.703411144507447240, 0.703375604468043810, 0.703340062670201660, 0.703304519114009490, +0.703268973799555550, 0.703233426726929570, 0.703197877896220010, 0.703162327307515710, 0.703126774960905250, 0.703091220856478240, 0.703055664994323150, 0.703020107374528910, +0.702984547997184130, 0.702948986862378280, 0.702913423970199850, 0.702877859320737990, 0.702842292914081180, 0.702806724750318800, 0.702771154829539670, 0.702735583151832710, +0.702700009717286520, 0.702664434525990590, 0.702628857578033510, 0.702593278873503980, 0.702557698412491600, 0.702522116195084980, 0.702486532221373030, 0.702450946491444460, +0.702415359005388870, 0.702379769763294860, 0.702344178765251350, 0.702308586011347160, 0.702272991501671770, 0.702237395236314010, 0.702201797215362690, 0.702166197438906510, +0.702130595907035190, 0.702094992619837430, 0.702059387577402160, 0.702023780779818090, 0.701988172227174910, 0.701952561919561240, 0.701916949857065870, 0.701881336039778540, +0.701845720467787700, 0.701810103141182750, 0.701774484060052050, 0.701738863224485640, 0.701703240634571900, 0.701667616290400090, 0.701631990192059020, 0.701596362339638180, +0.701560732733226500, 0.701525101372913020, 0.701489468258786440, 0.701453833390936480, 0.701418196769451940, 0.701382558394421870, 0.701346918265935200, 0.701311276384081420, +0.701275632748949550, 0.701239987360628200, 0.701204340219207300, 0.701168691324775440, 0.701133040677421990, 0.701097388277235560, 0.701061734124305950, 0.701026078218721980, +0.700990420560572810, 0.700954761149947370, 0.700919099986935250, 0.700883437071625370, 0.700847772404107010, 0.700812105984468750, 0.700776437812800630, 0.700740767889191480, +0.700705096213730340, 0.700669422786506120, 0.700633747607608660, 0.700598070677126870, 0.700562391995149910, 0.700526711561766600, 0.700491029377066870, 0.700455345441139520, +0.700419659754073610, 0.700383972315958720, 0.700348283126884020, 0.700312592186938530, 0.700276899496211300, 0.700241205054792150, 0.700205508862769890, 0.700169810920233890, +0.700134111227273090, 0.700098409783977300, 0.700062706590435460, 0.700027001646736920, 0.699991294952970520, 0.699955586509226290, 0.699919876315592940, 0.699884164372160060, +0.699848450679016350, 0.699812735236251760, 0.699777018043955420, 0.699741299102216270, 0.699705578411124130, 0.699669855970768030, 0.699634131781237350, 0.699598405842621010, +0.699562678155008940, 0.699526948718490190, 0.699491217533154020, 0.699455484599089570, 0.699419749916386670, 0.699384013485134350, 0.699348275305422100, 0.699312535377338840, +0.699276793700974510, 0.699241050276418140, 0.699205305103759220, 0.699169558183086790, 0.699133809514490670, 0.699098059098060110, 0.699062306933884050, 0.699026553022052520, +0.698990797362654570, 0.698955039955779680, 0.698919280801516880, 0.698883519899956230, 0.698847757251186640, 0.698811992855297830, 0.698776226712378600, 0.698740458822519230, +0.698704689185808640, 0.698668917802336310, 0.698633144672191400, 0.698597369795463940, 0.698561593172242980, 0.698525814802618110, 0.698490034686678470, 0.698454252824513900, +0.698418469216213870, 0.698382683861867530, 0.698346896761564250, 0.698311107915393970, 0.698275317323445940, 0.698239524985809320, 0.698203730902574150, 0.698167935073829680, +0.698132137499665410, 0.698096338180170470, 0.698060537115435030, 0.698024734305548230, 0.697988929750599560, 0.697953123450678280, 0.697917315405874430, 0.697881505616277380, +0.697845694081976610, 0.697809880803061170, 0.697774065779621420, 0.697738249011746530, 0.697702430499525960, 0.697666610243048990, 0.697630788242405760, 0.697594964497685650, +0.697559139008977810, 0.697523311776372390, 0.697487482799958760, 0.697451652079826400, 0.697415819616064580, 0.697379985408763560, 0.697344149458012490, 0.697308311763901180, +0.697272472326518680, 0.697236631145955240, 0.697200788222300360, 0.697164943555643510, 0.697129097146073850, 0.697093248993681860, 0.697057399098556800, 0.697021547460788150, +0.696985694080465400, 0.696949838957678590, 0.696913982092517310, 0.696878123485070720, 0.696842263135429190, 0.696806401043681970, 0.696770537209918660, 0.696734671634228750, +0.696698804316702500, 0.696662935257429280, 0.696627064456498690, 0.696591191913999990, 0.696555317630023760, 0.696519441604659280, 0.696483563837996140, 0.696447684330123720, +0.696411803081132490, 0.696375920091111710, 0.696340035360151100, 0.696304148888340140, 0.696268260675769080, 0.696232370722527420, 0.696196479028704520, 0.696160585594390650, +0.696124690419675400, 0.696088793504648470, 0.696052894849399140, 0.696016994454017880, 0.695981092318594170, 0.695945188443217730, 0.695909282827978040, 0.695873375472965460, +0.695837466378269380, 0.695801555543979710, 0.695765642970185730, 0.695729728656978020, 0.695693812604445960, 0.695657894812679480, 0.695621975281767830, 0.695586054011801620, +0.695550131002870220, 0.695514206255063550, 0.695478279768470990, 0.695442351543183120, 0.695406421579289220, 0.695370489876879110, 0.695334556436043030, 0.695298621256870590, +0.695262684339451600, 0.695226745683875550, 0.695190805290232920, 0.695154863158613300, 0.695118919289106520, 0.695082973681802160, 0.695047026336790720, 0.695011077254161670, +0.694975126434004940, 0.694939173876410020, 0.694903219581467500, 0.694867263549266980, 0.694831305779898270, 0.694795346273450960, 0.694759385030015660, 0.694723422049681850, +0.694687457332539230, 0.694651490878678170, 0.694615522688188490, 0.694579552761159900, 0.694543581097682220, 0.694507607697845810, 0.694471632561740490, 0.694435655689455980, +0.694399677081082080, 0.694363696736709280, 0.694327714656427290, 0.694291730840325920, 0.694255745288494990, 0.694219758001024980, 0.694183768978005490, 0.694147778219526670, +0.694111785725678110, 0.694075791496550410, 0.694039795532233160, 0.694003797832816180, 0.693967798398389960, 0.693931797229044300, 0.693895794324869030, 0.693859789685954080, +0.693823783312389920, 0.693787775204266380, 0.693751765361673380, 0.693715753784700520, 0.693679740473438720, 0.693643725427977480, 0.693607708648407040, 0.693571690134816900, +0.693535669887297870, 0.693499647905939760, 0.693463624190832410, 0.693427598742065830, 0.693391571559730410, 0.693355542643916190, 0.693319511994712980, 0.693283479612210820, +0.693247445496500190, 0.693211409647670920, 0.693175372065812920, 0.693139332751016690, 0.693103291703372150, 0.693067248922969450, 0.693031204409898290, 0.692995158164249390, +0.692959110186112670, 0.692923060475578060, 0.692887009032735590, 0.692850955857675870, 0.692814900950488810, 0.692778844311264350, 0.692742785940092640, 0.692706725837064160, +0.692670664002268950, 0.692634600435797050, 0.692598535137738390, 0.692562468108183560, 0.692526399347222710, 0.692490328854945440, 0.692454256631442670, 0.692418182676804330, +0.692382106991120460, 0.692346029574481100, 0.692309950426976960, 0.692273869548697850, 0.692237786939734150, 0.692201702600175660, 0.692165616530113210, 0.692129528729636730, +0.692093439198836370, 0.692057347937802160, 0.692021254946624920, 0.691985160225394470, 0.691949063774201180, 0.691912965593134870, 0.691876865682286570, 0.691840764041745990, +0.691804660671603180, 0.691768555571949050, 0.691732448742873540, 0.691696340184467020, 0.691660229896819190, 0.691624117880021090, 0.691588004134162770, 0.691551888659334480, +0.691515771455626040, 0.691479652523128600, 0.691443531861931970, 0.691407409472126530, 0.691371285353802210, 0.691335159507050050, 0.691299031931959960, 0.691262902628622220, +0.691226771597126980, 0.691190638837565150, 0.691154504350026680, 0.691118368134601700, 0.691082230191381040, 0.691046090520454850, 0.691009949121913380, 0.690973805995846790, +0.690937661142345890, 0.690901514561500950, 0.690865366253402220, 0.690829216218139750, 0.690793064455804460, 0.690756910966486610, 0.690720755750276470, 0.690684598807264070, +0.690648440137540560, 0.690612279741195990, 0.690576117618320610, 0.690539953769004680, 0.690503788193339130, 0.690467620891414220, 0.690431451863320110, 0.690395281109147160, +0.690359108628986310, 0.690322934422927580, 0.690286758491061360, 0.690250580833478460, 0.690214401450269130, 0.690178220341523870, 0.690142037507332610, 0.690105852947786590, +0.690069666662976090, 0.690033478652991250, 0.689997288917922450, 0.689961097457860830, 0.689924904272896430, 0.689888709363119630, 0.689852512728620910, 0.689816314369491200, +0.689780114285820640, 0.689743912477699840, 0.689707708945218930, 0.689671503688469080, 0.689635296707540420, 0.689599088002523230, 0.689562877573508650, 0.689526665420586830, +0.689490451543848470, 0.689454235943383510, 0.689418018619283310, 0.689381799571638140, 0.689345578800538480, 0.689309356306074480, 0.689273132088337400, 0.689236906147417510, +0.689200678483405380, 0.689164449096391300, 0.689128217986466280, 0.689091985153720720, 0.689055750598245310, 0.689019514320130200, 0.688983276319466540, 0.688947036596344710, +0.688910795150854960, 0.688874551983088560, 0.688838307093135760, 0.688802060481087270, 0.688765812147033250, 0.688729562091065060, 0.688693310313272860, 0.688657056813747560, +0.688620801592579100, 0.688584544649859080, 0.688548285985677630, 0.688512025600125590, 0.688475763493292980, 0.688439499665271400, 0.688403234116151120, 0.688366966846022610, +0.688330697854976470, 0.688294427143103850, 0.688258154710495230, 0.688221880557241210, 0.688185604683432150, 0.688149327089159320, 0.688113047774513320, 0.688076766739584290, +0.688040483984463710, 0.688004199509241850, 0.687967913314009530, 0.687931625398857110, 0.687895335763875960, 0.687859044409156460, 0.687822751334789320, 0.687786456540865010, +0.687750160027474910, 0.687713861794709390, 0.687677561842659160, 0.687641260171414800, 0.687604956781067480, 0.687568651671707890, 0.687532344843426620, 0.687496036296314170, +0.687459726030461900, 0.687423414045960410, 0.687387100342900070, 0.687350784921372250, 0.687314467781467430, 0.687278148923276540, 0.687241828346889850, 0.687205506052398940, +0.687169182039894300, 0.687132856309466740, 0.687096528861206650, 0.687060199695205600, 0.687023868811553970, 0.686987536210342810, 0.686951201891662370, 0.686914865855604240, +0.686878528102259020, 0.686842188631717420, 0.686805847444070140, 0.686769504539408440, 0.686733159917823020, 0.686696813579404370, 0.686660465524244090, 0.686624115752432540, +0.686587764264060760, 0.686551411059219240, 0.686515056137999460, 0.686478699500492010, 0.686442341146787930, 0.686405981076977590, 0.686369619291152700, 0.686333255789403740, +0.686296890571821640, 0.686260523638496880, 0.686224154989521270, 0.686187784624985200, 0.686151412544979690, 0.686115038749595340, 0.686078663238923750, 0.686042286013055390, +0.686005907072081420, 0.685969526416092320, 0.685933144045179690, 0.685896759959434330, 0.685860374158946630, 0.685823986643808280, 0.685787597414110110, 0.685751206469942810, +0.685714813811397320, 0.685678419438565000, 0.685642023351536570, 0.685605625550403270, 0.685569226035255500, 0.685532824806184940, 0.685496421863282300, 0.685460017206638740, +0.685423610836344730, 0.685387202752491990, 0.685350792955171210, 0.685314381444473540, 0.685277968220489590, 0.685241553283310930, 0.685205136633028510, 0.685168718269732910, +0.685132298193515840, 0.685095876404468010, 0.685059452902680440, 0.685023027688243970, 0.684986600761250290, 0.684950172121789990, 0.684913741769954340, 0.684877309705834050, +0.684840875929520700, 0.684804440441105220, 0.684768003240678660, 0.684731564328331820, 0.684695123704156310, 0.684658681368242930, 0.684622237320682950, 0.684585791561566960, +0.684549344090986890, 0.684512894909033550, 0.684476444015797550, 0.684439991411370690, 0.684403537095843890, 0.684367081069308330, 0.684330623331854680, 0.684294163883574890, +0.684257702724559550, 0.684221239854900020, 0.684184775274687020, 0.684148308984012470, 0.684111840982967180, 0.684075371271642200, 0.684038899850128560, 0.684002426718517850, +0.683965951876901230, 0.683929475325369630, 0.683892997064014070, 0.683856517092926270, 0.683820035412197270, 0.683783552021917760, 0.683747066922179790, 0.683710580113074170, +0.683674091594691950, 0.683637601367124370, 0.683601109430462930, 0.683564615784798880, 0.683528120430223150, 0.683491623366826890, 0.683455124594701810, 0.683418624113939050, +0.683382121924629660, 0.683345618026864550, 0.683309112420735780, 0.683272605106334250, 0.683236096083751240, 0.683199585353077680, 0.683163072914405370, 0.683126558767825460, +0.683090042913429120, 0.683053525351307370, 0.683017006081552140, 0.682980485104254350, 0.682943962419505060, 0.682907438027396290, 0.682870911928018740, 0.682834384121464020, +0.682797854607822940, 0.682761323387187650, 0.682724790459648960, 0.682688255825298350, 0.682651719484226760, 0.682615181436526220, 0.682578641682287660, 0.682542100221602550, +0.682505557054561840, 0.682469012181257550, 0.682432465601780840, 0.682395917316222840, 0.682359367324674730, 0.682322815627228520, 0.682286262223975370, 0.682249707115006210, +0.682213150300412960, 0.682176591780287000, 0.682140031554719580, 0.682103469623801640, 0.682066905987625430, 0.682030340646281870, 0.681993773599862570, 0.681957204848458450, +0.681920634392161660, 0.681884062231063240, 0.681847488365254770, 0.681810912794827080, 0.681774335519872540, 0.681737756540482190, 0.681701175856747390, 0.681664593468759410, +0.681628009376610170, 0.681591423580390930, 0.681554836080192850, 0.681518246876107960, 0.681481655968227520, 0.681445063356642900, 0.681408469041445250, 0.681371873022726840, +0.681335275300578690, 0.681298675875092410, 0.681262074746359030, 0.681225471914470800, 0.681188867379519000, 0.681152261141594880, 0.681115653200789820, 0.681079043557196060, +0.681042432210904660, 0.681005819162007090, 0.680969204410594720, 0.680932587956759590, 0.680895969800593080, 0.680859349942186550, 0.680822728381631380, 0.680786105119019710, +0.680749480154442810, 0.680712853487991820, 0.680676225119759120, 0.680639595049835730, 0.680602963278313490, 0.680566329805283420, 0.680529694630837900, 0.680493057755068080, +0.680456419178065650, 0.680419778899921890, 0.680383136920728940, 0.680346493240578170, 0.680309847859561170, 0.680273200777769200, 0.680236551995294650, 0.680199901512228640, +0.680163249328662900, 0.680126595444688680, 0.680089939860398340, 0.680053282575883160, 0.680016623591234380, 0.679979962906544390, 0.679943300521904550, 0.679906636437406340, +0.679869970653141360, 0.679833303169201650, 0.679796633985678800, 0.679759963102664290, 0.679723290520249600, 0.679686616238526890, 0.679649940257587740, 0.679613262577523750, +0.679576583198426290, 0.679539902120387620, 0.679503219343499220, 0.679466534867852800, 0.679429848693539730, 0.679393160820652380, 0.679356471249282000, 0.679319779979520200, +0.679283087011459340, 0.679246392345190690, 0.679209695980806050, 0.679172997918396910, 0.679136298158055540, 0.679099596699873410, 0.679062893543942340, 0.679026188690353690, +0.678989482139199960, 0.678952773890572400, 0.678916063944562940, 0.678879352301263060, 0.678842638960765130, 0.678805923923160530, 0.678769207188541170, 0.678732488756998430, +0.678695768628624800, 0.678659046803511750, 0.678622323281750760, 0.678585598063434330, 0.678548871148653810, 0.678512142537501250, 0.678475412230067910, 0.678438680226446380, +0.678401946526728140, 0.678365211131005120, 0.678328474039368690, 0.678291735251911330, 0.678254994768724640, 0.678218252589900540, 0.678181508715530510, 0.678144763145706930, +0.678108015880521500, 0.678071266920066030, 0.678034516264432120, 0.677997763913712140, 0.677961009867997790, 0.677924254127381000, 0.677887496691953140, 0.677850737561806920, +0.677813976737033810, 0.677777214217725410, 0.677740450003974430, 0.677703684095872230, 0.677666916493510850, 0.677630147196981780, 0.677593376206377720, 0.677556603521790260, +0.677519829143311210, 0.677483053071032290, 0.677446275305046090, 0.677409495845444190, 0.677372714692318630, 0.677335931845760800, 0.677299147305863600, 0.677262361072718530, +0.677225573146417400, 0.677188783527052250, 0.677151992214715340, 0.677115199209498360, 0.677078404511493150, 0.677041608120792280, 0.677004810037487360, 0.676968010261670420, +0.676931208793433160, 0.676894405632868070, 0.676857600780067070, 0.676820794235122090, 0.676783985998124840, 0.676747176069167790, 0.676710364448342980, 0.676673551135742120, +0.676636736131457140, 0.676599919435580620, 0.676563101048204270, 0.676526280969420140, 0.676489459199320020, 0.676452635737996630, 0.676415810585541680, 0.676378983742046750, +0.676342155207604770, 0.676305324982307330, 0.676268493066246700, 0.676231659459514470, 0.676194824162203330, 0.676157987174405230, 0.676121148496212080, 0.676084308127715810, +0.676047466069009010, 0.676010622320183610, 0.675973776881331640, 0.675936929752544930, 0.675900080933916180, 0.675863230425537200, 0.675826378227500250, 0.675789524339896920, +0.675752668762820140, 0.675715811496361730, 0.675678952540613830, 0.675642091895668040, 0.675605229561617500, 0.675568365538553820, 0.675531499826569020, 0.675494632425755690, +0.675457763336205770, 0.675420892558011410, 0.675384020091264640, 0.675347145936058050, 0.675310270092483570, 0.675273392560633460, 0.675236513340599530, 0.675199632432474610, +0.675162749836350720, 0.675125865552319790, 0.675088979580473980, 0.675052091920905980, 0.675015202573707840, 0.674978311538971700, 0.674941418816789370, 0.674904524407253790, +0.674867628310456990, 0.674830730526490790, 0.674793831055448100, 0.674756929897420750, 0.674720027052501110, 0.674683122520781110, 0.674646216302353660, 0.674609308397310590, +0.674572398805744270, 0.674535487527746720, 0.674498574563410670, 0.674461659912828140, 0.674424743576091500, 0.674387825553292800, 0.674350905844524730, 0.674313984449879440, +0.674277061369449200, 0.674240136603325930, 0.674203210151602670, 0.674166282014371450, 0.674129352191724100, 0.674092420683753750, 0.674055487490552330, 0.674018552612212220, +0.673981616048825340, 0.673944677800484840, 0.673907737867282640, 0.673870796249311010, 0.673833852946662090, 0.673796907959428930, 0.673759961287703430, 0.673723012931577990, +0.673686062891144740, 0.673649111166496730, 0.673612157757725870, 0.673575202664924650, 0.673538245888185010, 0.673501287427600180, 0.673464327283262110, 0.673427365455262830, +0.673390401943695590, 0.673353436748652220, 0.673316469870225310, 0.673279501308506890, 0.673242531063590110, 0.673205559135566900, 0.673168585524529850, 0.673131610230571000, +0.673094633253783380, 0.673057654594259260, 0.673020674252091000, 0.672983692227370760, 0.672946708520191560, 0.672909723130645570, 0.672872736058825360, 0.672835747304822870, +0.672798756868731470, 0.672761764750643090, 0.672724770950650310, 0.672687775468845280, 0.672650778305321160, 0.672613779460170090, 0.672576778933484220, 0.672539776725356700, +0.672502772835879780, 0.672465767265145950, 0.672428760013247250, 0.672391751080277160, 0.672354740466327590, 0.672317728171491160, 0.672280714195860110, 0.672243698539527590, +0.672206681202585870, 0.672169662185127410, 0.672132641487244500, 0.672095619109030260, 0.672058595050576970, 0.672021569311977320, 0.671984541893323240, 0.671947512794708210, +0.671910482016224500, 0.671873449557964130, 0.671836415420020480, 0.671799379602485810, 0.671762342105452710, 0.671725302929013330, 0.671688262073261160, 0.671651219538288210, +0.671614175324187320, 0.671577129431050630, 0.671540081858971400, 0.671503032608042010, 0.671465981678355030, 0.671428929070002730, 0.671391874783078490, 0.671354818817674560, +0.671317761173883530, 0.671280701851797890, 0.671243640851510670, 0.671206578173114470, 0.671169513816701420, 0.671132447782364920, 0.671095380070197310, 0.671058310680291310, +0.671021239612739070, 0.670984166867634180, 0.670947092445068890, 0.670910016345135810, 0.670872938567927400, 0.670835859113536940, 0.670798777982056780, 0.670761695173579750, +0.670724610688198110, 0.670687524526005330, 0.670650436687093680, 0.670613347171555960, 0.670576255979484560, 0.670539163110972840, 0.670502068566113160, 0.670464972344998470, +0.670427874447720900, 0.670390774874373930, 0.670353673625050050, 0.670316570699841740, 0.670279466098842260, 0.670242359822144080, 0.670205251869840040, 0.670168142242022590, +0.670131030938785120, 0.670093917960220000, 0.670056803306420150, 0.670019686977477820, 0.669982568973486740, 0.669945449294539250, 0.669908327940728080, 0.669871204912145800, +0.669834080208885800, 0.669796953831040650, 0.669759825778703080, 0.669722696051965550, 0.669685564650921660, 0.669648431575663890, 0.669611296826284730, 0.669574160402877540, +0.669537022305535130, 0.669499882534350000, 0.669462741089414950, 0.669425597970823350, 0.669388453178667690, 0.669351306713040990, 0.669314158574035640, 0.669277008761745230, +0.669239857276262230, 0.669202704117679680, 0.669165549286090070, 0.669128392781586760, 0.669091234604262670, 0.669054074754210410, 0.669016913231522570, 0.668979750036292840, +0.668942585168613710, 0.668905418628577770, 0.668868250416278620, 0.668831080531808840, 0.668793908975261480, 0.668756735746728890, 0.668719560846304790, 0.668682384274081890, +0.668645206030152870, 0.668608026114610680, 0.668570844527548670, 0.668533661269059550, 0.668496476339236260, 0.668459289738171480, 0.668422101465958820, 0.668384911522690860, +0.668347719908460650, 0.668310526623360770, 0.668273331667484930, 0.668236135040925830, 0.668198936743775950, 0.668161736776129110, 0.668124535138077900, 0.668087331829715360, +0.668050126851134190, 0.668012920202428080, 0.667975711883689540, 0.667938501895011800, 0.667901290236487480, 0.667864076908210260, 0.667826861910272850, 0.667789645242768290, +0.667752426905789290, 0.667715206899429540, 0.667677985223781740, 0.667640761878939060, 0.667603536864994070, 0.667566310182040600, 0.667529081830171340, 0.667491851809479340, +0.667454620120057520, 0.667417386761999350, 0.667380151735397660, 0.667342915040345370, 0.667305676676936080, 0.667268436645262700, 0.667231194945418160, 0.667193951577495280, +0.667156706541587870, 0.667119459837788640, 0.667082211466190840, 0.667044961426887180, 0.667007709719971360, 0.666970456345536310, 0.666933201303675170, 0.666895944594480650, +0.666858686218046560, 0.666821426174465830, 0.666784164463831490, 0.666746901086236470, 0.666709636041774470, 0.666672369330538420, 0.666635100952621020, 0.666597830908116310, +0.666560559197116990, 0.666523285819716320, 0.666486010776007000, 0.666448734066083070, 0.666411455690037240, 0.666374175647962750, 0.666336893939952550, 0.666299610566100430, +0.666262325526499330, 0.666225038821242400, 0.666187750450422560, 0.666150460414133620, 0.666113168712468510, 0.666075875345520490, 0.666038580313382480, 0.666001283616148300, +0.665963985253910980, 0.665926685226763350, 0.665889383534799320, 0.665852080178111820, 0.665814775156794210, 0.665777468470939220, 0.665740160120640970, 0.665702850105992280, +0.665665538427086420, 0.665628225084016420, 0.665590910076876210, 0.665553593405758810, 0.665516275070757280, 0.665478955071964750, 0.665441633409475260, 0.665404310083381630, +0.665366985093777230, 0.665329658440754980, 0.665292330124408910, 0.665255000144832080, 0.665217668502117830, 0.665180335196358890, 0.665143000227649610, 0.665105663596082700, +0.665068325301751420, 0.665030985344749580, 0.664993643725170220, 0.664956300443106940, 0.664918955498652430, 0.664881608891900840, 0.664844260622945330, 0.664806910691879140, +0.664769559098795320, 0.664732205843787890, 0.664694850926950020, 0.664657494348374960, 0.664620136108155850, 0.664582776206386840, 0.664545414643160750, 0.664508051418571170, +0.664470686532711130, 0.664433319985674790, 0.664395951777555060, 0.664358581908445100, 0.664321210378439050, 0.664283837187629960, 0.664246462336111290, 0.664209085823976090, +0.664171707651318610, 0.664134327818231780, 0.664096946324809200, 0.664059563171143900, 0.664022178357329910, 0.663984791883460600, 0.663947403749629240, 0.663910013955929080, +0.663872622502454270, 0.663835229389297840, 0.663797834616553280, 0.663760438184313850, 0.663723040092673690, 0.663685640341725950, 0.663648238931563660, 0.663610835862281200, +0.663573431133971710, 0.663536024746728570, 0.663498616700645030, 0.663461206995815230, 0.663423795632332450, 0.663386382610290260, 0.663348967929781710, 0.663311551590901050, +0.663274133593741540, 0.663236713938396670, 0.663199292624959800, 0.663161869653524970, 0.663124445024185330, 0.663087018737034790, 0.663049590792166190, 0.663012161189674100, +0.662974729929651450, 0.662937297012191730, 0.662899862437389080, 0.662862426205336860, 0.662824988316128460, 0.662787548769857350, 0.662750107566617560, 0.662712664706502700, +0.662675220189606010, 0.662637774016020980, 0.662600326185841860, 0.662562876699162030, 0.662525425556074850, 0.662487972756673820, 0.662450518301053280, 0.662413062189306290, +0.662375604421526760, 0.662338144997807850, 0.662300683918243930, 0.662263221182928240, 0.662225756791954610, 0.662188290745416190, 0.662150823043407330, 0.662113353686021420, +0.662075882673351820, 0.662038410005492910, 0.662000935682537930, 0.661963459704580590, 0.661925982071714270, 0.661888502784033330, 0.661851021841631140, 0.661813539244601400, +0.661776054993037490, 0.661738569087033770, 0.661701081526683610, 0.661663592312080720, 0.661626101443318570, 0.661588608920491540, 0.661551114743692880, 0.661513618913016520, +0.661476121428555720, 0.661438622290404950, 0.661401121498657710, 0.661363619053407240, 0.661326114954748020, 0.661288609202773660, 0.661251101797577730, 0.661213592739253620, +0.661176082027895910, 0.661138569663597960, 0.661101055646453720, 0.661063539976556420, 0.661026022654000570, 0.660988503678879740, 0.660950983051287630, 0.660913460771317630, +0.660875936839064430, 0.660838411254621390, 0.660800884018082240, 0.660763355129540650, 0.660725824589090900, 0.660688292396826580, 0.660650758552841280, 0.660613223057229360, +0.660575685910084420, 0.660538147111500270, 0.660500606661570400, 0.660463064560389390, 0.660425520808050610, 0.660387975404648110, 0.660350428350275350, 0.660312879645026830, +0.660275329288996130, 0.660237777282277060, 0.660200223624963220, 0.660162668317149200, 0.660125111358928480, 0.660087552750394990, 0.660049992491642310, 0.660012430582764930, +0.659974867023856550, 0.659937301815010980, 0.659899734956321820, 0.659862166447883540, 0.659824596289789960, 0.659787024482134550, 0.659749451025011920, 0.659711875918515540, +0.659674299162739560, 0.659636720757777570, 0.659599140703724050, 0.659561559000672700, 0.659523975648717450, 0.659486390647951890, 0.659448803998470720, 0.659411215700367540, +0.659373625753736260, 0.659336034158670590, 0.659298440915265240, 0.659260846023613790, 0.659223249483810170, 0.659185651295948080, 0.659148051460122230, 0.659110449976426320, +0.659072846844953820, 0.659035242065799660, 0.658997635639057330, 0.658960027564820860, 0.658922417843184060, 0.658884806474241520, 0.658847193458086950, 0.658809578794814500, +0.658771962484517640, 0.658734344527291290, 0.658696724923229060, 0.658659103672424970, 0.658621480774972850, 0.658583856230967380, 0.658546230040502170, 0.658508602203671470, +0.658470972720568870, 0.658433341591289190, 0.658395708815926240, 0.658358074394573610, 0.658320438327326120, 0.658282800614277570, 0.658245161255522020, 0.658207520251153140, +0.658169877601265880, 0.658132233305953940, 0.658094587365311350, 0.658056939779432030, 0.658019290548410680, 0.657981639672341020, 0.657943987151317410, 0.657906332985433330, +0.657868677174783920, 0.657831019719462670, 0.657793360619563950, 0.657755699875181450, 0.657718037486410110, 0.657680373453343630, 0.657642707776075920, 0.657605040454701690, +0.657567371489314880, 0.657529700880009730, 0.657492028626879940, 0.657454354730020450, 0.657416679189524960, 0.657379002005487820, 0.657341323178002870, 0.657303642707165010, +0.657265960593067970, 0.657228276835805980, 0.657190591435473090, 0.657152904392163890, 0.657115215705972530, 0.657077525376993150, 0.657039833405319570, 0.657002139791046820, +0.656964444534268610, 0.656926747635079410, 0.656889049093572930, 0.656851348909844200, 0.656813647083987040, 0.656775943616095480, 0.656738238506264340, 0.656700531754587650, +0.656662823361159660, 0.656625113326074210, 0.656587401649426420, 0.656549688331310000, 0.656511973371819440, 0.656474256771048540, 0.656436538529092340, 0.656398818646044880, +0.656361097122000300, 0.656323373957052650, 0.656285649151296950, 0.656247922704827120, 0.656210194617737440, 0.656172464890121930, 0.656134733522075630, 0.656097000513692460, +0.656059265865066470, 0.656021529576292670, 0.655983791647465010, 0.655946052078677950, 0.655908310870025320, 0.655870568021602370, 0.655832823533502920, 0.655795077405821440, +0.655757329638651850, 0.655719580232089320, 0.655681829186227860, 0.655644076501161850, 0.655606322176985330, 0.655568566213793220, 0.655530808611679780, 0.655493049370739380, +0.655455288491065930, 0.655417525972754600, 0.655379761815899520, 0.655341996020594620, 0.655304228586935040, 0.655266459515014940, 0.655228688804928790, 0.655190916456770410, +0.655153142470635160, 0.655115366846617090, 0.655077589584810550, 0.655039810685309700, 0.655002030148209680, 0.654964247973604640, 0.654926464161588840, 0.654888678712256640, +0.654850891625703090, 0.654813102902022210, 0.654775312541308720, 0.654737520543656530, 0.654699726909160900, 0.654661931637915860, 0.654624134730016130, 0.654586336185555620, +0.654548536004629700, 0.654510734187332410, 0.654472930733757900, 0.654435125644001410, 0.654397318918157110, 0.654359510556319580, 0.654321700558582850, 0.654283888925042300, +0.654246075655791960, 0.654208260750926420, 0.654170444210539940, 0.654132626034727660, 0.654094806223583850, 0.654056984777202980, 0.654019161695679310, 0.653981336979108100, +0.653943510627583490, 0.653905682641200190, 0.653867853020052240, 0.653830021764235100, 0.653792188873842830, 0.653754354348969780, 0.653716518189711220, 0.653678680396161280, +0.653640840968414680, 0.653602999906565670, 0.653565157210709510, 0.653527312880940460, 0.653489466917352990, 0.653451619320041700, 0.653413770089101620, 0.653375919224627120, +0.653338066726712800, 0.653300212595453010, 0.653262356830943030, 0.653224499433277090, 0.653186640402549920, 0.653148779738855880, 0.653110917442290220, 0.653073053512947200, +0.653035187950921300, 0.652997320756307680, 0.652959451929200800, 0.652921581469695260, 0.652883709377885420, 0.652845835653866670, 0.652807960297733360, 0.652770083309580080, +0.652732204689501330, 0.652694324437592450, 0.652656442553947610, 0.652618559038661730, 0.652580673891829170, 0.652542787113545190, 0.652504898703904270, 0.652467008663001110, +0.652429116990930090, 0.652391223687786680, 0.652353328753665140, 0.652315432188659950, 0.652277533992866480, 0.652239634166379200, 0.652201732709292830, 0.652163829621701830, +0.652125924903701580, 0.652088018555386450, 0.652050110576851360, 0.652012200968190570, 0.651974289729499670, 0.651936376860873130, 0.651898462362405560, 0.651860546234191430, +0.651822628476326440, 0.651784709088904730, 0.651746788072021350, 0.651708865425770560, 0.651670941150248040, 0.651633015245548060, 0.651595087711765660, 0.651557158548995100, +0.651519227757332060, 0.651481295336870940, 0.651443361287706190, 0.651405425609933420, 0.651367488303647100, 0.651329549368942050, 0.651291608805912750, 0.651253666614654780, +0.651215722795262630, 0.651177777347831220, 0.651139830272455030, 0.651101881569229550, 0.651063931238249460, 0.651025979279609480, 0.650988025693404190, 0.650950070479729190, +0.650912113638679070, 0.650874155170348630, 0.650836195074832480, 0.650798233352226090, 0.650760270002624150, 0.650722305026121270, 0.650684338422812920, 0.650646370192793700, +0.650608400336158630, 0.650570428853002090, 0.650532455743420000, 0.650494481007506620, 0.650456504645357090, 0.650418526657066010, 0.650380547042728850, 0.650342565802440430, +0.650304582936295450, 0.650266598444388830, 0.650228612326815950, 0.650190624583671610, 0.650152635215050620, 0.650114644221047810, 0.650076651601758650, 0.650038657357277950, +0.650000661487700190, 0.649962663993121080, 0.649924664873635430, 0.649886664129338040, 0.649848661760323630, 0.649810657766688000, 0.649772652148525640, 0.649734644905931690, +0.649696636039000740, 0.649658625547828610, 0.649620613432509870, 0.649582599693139580, 0.649544584329812550, 0.649506567342624240, 0.649468548731669590, 0.649430528497043640, +0.649392506638840960, 0.649354483157157380, 0.649316458052087600, 0.649278431323726530, 0.649240402972169230, 0.649202372997511160, 0.649164341399847240, 0.649126308179272080, +0.649088273335881480, 0.649050236869770150, 0.649012198781033330, 0.648974159069765630, 0.648936117736062860, 0.648898074780019820, 0.648860030201731550, 0.648821984001292870, +0.648783936178799590, 0.648745886734346520, 0.648707835668028700, 0.648669782979940930, 0.648631728670179040, 0.648593672738837830, 0.648555615186012460, 0.648517556011797720, +0.648479495216289340, 0.648441432799582330, 0.648403368761771400, 0.648365303102952370, 0.648327235823220050, 0.648289166922669580, 0.648251096401396000, 0.648213024259494900, +0.648174950497061310, 0.648136875114190270, 0.648098798110976810, 0.648060719487516650, 0.648022639243904690, 0.647984557380236080, 0.647946473896605760, 0.647908388793109640, +0.647870302069842530, 0.647832213726899590, 0.647794123764375840, 0.647756032182367210, 0.647717938980968410, 0.647679844160274350, 0.647641747720381080, 0.647603649661383510, +0.647565549983376790, 0.647527448686455840, 0.647489345770716600, 0.647451241236253970, 0.647413135083163230, 0.647375027311539400, 0.647336917921478290, 0.647298806913074840, +0.647260694286424410, 0.647222580041621920, 0.647184464178763300, 0.647146346697943580, 0.647108227599257900, 0.647070106882801310, 0.647031984548669840, 0.646993860596958400, +0.646955735027762050, 0.646917607841176580, 0.646879479037297140, 0.646841348616219000, 0.646803216578037190, 0.646765082922847620, 0.646726947650745340, 0.646688810761825720, +0.646650672256183780, 0.646612532133915340, 0.646574390395115770, 0.646536247039880110, 0.646498102068303490, 0.646459955480481960, 0.646421807276510550, 0.646383657456484630, +0.646345506020499230, 0.646307352968650490, 0.646269198301033240, 0.646231042017743060, 0.646192884118874880, 0.646154724604524830, 0.646116563474788070, 0.646078400729759420, +0.646040236369535230, 0.646002070394210430, 0.645963902803880390, 0.645925733598640250, 0.645887562778586170, 0.645849390343813170, 0.645811216294416730, 0.645773040630491790, +0.645734863352134700, 0.645696684459440400, 0.645658503952504460, 0.645620321831421820, 0.645582138096288840, 0.645543952747200440, 0.645505765784252120, 0.645467577207539110, +0.645429387017157460, 0.645391195213202320, 0.645353001795768930, 0.645314806764953340, 0.645276610120850690, 0.645238411863556570, 0.645200211993166130, 0.645162010509775400, +0.645123807413479630, 0.645085602704374430, 0.645047396382554820, 0.645009188448117170, 0.644970978901156400, 0.644932767741768220, 0.644894554970047880, 0.644856340586091430, +0.644818124589994100, 0.644779906981851390, 0.644741687761758660, 0.644703466929812060, 0.644665244486106850, 0.644627020430738050, 0.644588794763802150, 0.644550567485394190, +0.644512338595609860, 0.644474108094544420, 0.644435875982293900, 0.644397642258953800, 0.644359406924619460, 0.644321169979386380, 0.644282931423350690, 0.644244691256607660, +0.644206449479252980, 0.644168206091381700, 0.644129961093090400, 0.644091714484474000, 0.644053466265628430, 0.644015216436648830, 0.643976964997631570, 0.643938711948671920, +0.643900457289865450, 0.643862201021307420, 0.643823943143094320, 0.643785683655321410, 0.643747422558083810, 0.643709159851478140, 0.643670895535599420, 0.643632629610543570, +0.643594362076405750, 0.643556092933282420, 0.643517822181268850, 0.643479549820460740, 0.643441275850953340, 0.643403000272843140, 0.643364723086225390, 0.643326444291195900, +0.643288163887849930, 0.643249881876283850, 0.643211598256593130, 0.643173313028873370, 0.643135026193220050, 0.643096737749729530, 0.643058447698497070, 0.643020156039618150, +0.642981862773189250, 0.642943567899305620, 0.642905271418063080, 0.642866973329557110, 0.642828673633883960, 0.642790372331139110, 0.642752069421418380, 0.642713764904817130, +0.642675458781431840, 0.642637151051357880, 0.642598841714691060, 0.642560530771526750, 0.642522218221961430, 0.642483904066090680, 0.642445588304010110, 0.642407270935815180, +0.642368951961602490, 0.642330631381467290, 0.642292309195505280, 0.642253985403812840, 0.642215660006485440, 0.642177333003618900, 0.642139004395308580, 0.642100674181651180, +0.642062342362742070, 0.642024008938677060, 0.641985673909551750, 0.641947337275462600, 0.641908999036505110, 0.641870659192775080, 0.641832317744368110, 0.641793974691380660, +0.641755630033908340, 0.641717283772046840, 0.641678935905891870, 0.641640586435539890, 0.641602235361086400, 0.641563882682627320, 0.641525528400258230, 0.641487172514075610, +0.641448815024175060, 0.641410455930652160, 0.641372095233603500, 0.641333732933124570, 0.641295369029311280, 0.641257003522259340, 0.641218636412065110, 0.641180267698824300, +0.641141897382632830, 0.641103525463586290, 0.641065151941781370, 0.641026776817313460, 0.640988400090278580, 0.640950021760772430, 0.640911641828891600, 0.640873260294731570, +0.640834877158388380, 0.640796492419957730, 0.640758106079536200, 0.640719718137219400, 0.640681328593102890, 0.640642937447283400, 0.640604544699856620, 0.640566150350918460, +0.640527754400564640, 0.640489356848891740, 0.640450957695995470, 0.640412556941971740, 0.640374154586916270, 0.640335750630925850, 0.640297345074095970, 0.640258937916522770, +0.640220529158301850, 0.640182118799530020, 0.640143706840302860, 0.640105293280716410, 0.640066878120866380, 0.640028461360849450, 0.639990043000761450, 0.639951623040697970, +0.639913201480755810, 0.639874778321030570, 0.639836353561618500, 0.639797927202615080, 0.639759499244117350, 0.639721069686220670, 0.639682638529021410, 0.639644205772615270, +0.639605771417098850, 0.639567335462568050, 0.639528897909118930, 0.639490458756847180, 0.639452018005849720, 0.639413575656222140, 0.639375131708060600, 0.639336686161460890, +0.639298239016519830, 0.639259790273333240, 0.639221339931996700, 0.639182887992607250, 0.639144434455260590, 0.639105979320052750, 0.639067522587079660, 0.639029064256438240, +0.638990604328223970, 0.638952142802533320, 0.638913679679461890, 0.638875214959106600, 0.638836748641563370, 0.638798280726928120, 0.638759811215296900, 0.638721340106766510, +0.638682867401432760, 0.638644393099391920, 0.638605917200739670, 0.638567439705572950, 0.638528960613987670, 0.638490479926079990, 0.638451997641945710, 0.638413513761681870, +0.638375028285384170, 0.638336541213148530, 0.638298052545071990, 0.638259562281250250, 0.638221070421779670, 0.638182576966755950, 0.638144081916276250, 0.638105585270436260, +0.638067087029332350, 0.638028587193060440, 0.637990085761717340, 0.637951582735398980, 0.637913078114201730, 0.637874571898221390, 0.637836064087555000, 0.637797554682298480, +0.637759043682547990, 0.637720531088399660, 0.637682016899950190, 0.637643501117295840, 0.637604983740532320, 0.637566464769756650, 0.637527944205064870, 0.637489422046553230, +0.637450898294317670, 0.637412372948455210, 0.637373846009061880, 0.637335317476233840, 0.637296787350067230, 0.637258255630658970, 0.637219722318105090, 0.637181187412501850, +0.637142650913945290, 0.637104112822532540, 0.637065573138359430, 0.637027031861522430, 0.636988488992117460, 0.636949944530241670, 0.636911398475990990, 0.636872850829461430, +0.636834301590750160, 0.636795750759953090, 0.636757198337166710, 0.636718644322486930, 0.636680088716010890, 0.636641531517834650, 0.636602972728054550, 0.636564412346766640, +0.636525850374068170, 0.636487286810054950, 0.636448721654823580, 0.636410154908470080, 0.636371586571091500, 0.636333016642783970, 0.636294445123643860, 0.636255872013767320, +0.636217297313251380, 0.636178721022192310, 0.636140143140686340, 0.636101563668829750, 0.636062982606719560, 0.636024399954451920, 0.635985815712122870, 0.635947229879829660, +0.635908642457668430, 0.635870053445735550, 0.635831462844127280, 0.635792870652940540, 0.635754276872271710, 0.635715681502217240, 0.635677084542873190, 0.635638485994336700, +0.635599885856704020, 0.635561284130071740, 0.635522680814535780, 0.635484075910193510, 0.635445469417140970, 0.635406861335474860, 0.635368251665291210, 0.635329640406687270, +0.635291027559759300, 0.635252413124603340, 0.635213797101316760, 0.635175179489995580, 0.635136560290736510, 0.635097939503635690, 0.635059317128790380, 0.635020693166296830, +0.634982067616251420, 0.634943440478750620, 0.634904811753891460, 0.634866181441770430, 0.634827549542483770, 0.634788916056127970, 0.634750280982800170, 0.634711644322596750, +0.634673006075614170, 0.634634366241948800, 0.634595724821697790, 0.634557081814957400, 0.634518437221824110, 0.634479791042394940, 0.634441143276766370, 0.634402493925035000, +0.634363842987296980, 0.634325190463649660, 0.634286536354189410, 0.634247880659012830, 0.634209223378216170, 0.634170564511896790, 0.634131904060150960, 0.634093242023075490, +0.634054578400766510, 0.634015913193321400, 0.633977246400836520, 0.633938578023408580, 0.633899908061133830, 0.633861236514109640, 0.633822563382432370, 0.633783888666198280, +0.633745212365504850, 0.633706534480448450, 0.633667855011125660, 0.633629173957632850, 0.633590491320067510, 0.633551807098525990, 0.633513121293104890, 0.633474433903900680, +0.633435744931010620, 0.633397054374531310, 0.633358362234559320, 0.633319668511191040, 0.633280973204524030, 0.633242276314654570, 0.633203577841679350, 0.633164877785694860, +0.633126176146798560, 0.633087472925086820, 0.633048768120656360, 0.633010061733603640, 0.632971353764026130, 0.632932644212020220, 0.632893933077682380, 0.632855220361109970, +0.632816506062399590, 0.632777790181648040, 0.632739072718951470, 0.632700353674407690, 0.632661633048112960, 0.632622910840164200, 0.632584187050657780, 0.632545461679691280, +0.632506734727361080, 0.632468006193764090, 0.632429276078996680, 0.632390544383156450, 0.632351811106339870, 0.632313076248643750, 0.632274339810164680, 0.632235601791000020, +0.632196862191246380, 0.632158121011000220, 0.632119378250359130, 0.632080633909419490, 0.632041887988278430, 0.632003140487032210, 0.631964391405778540, 0.631925640744613770, +0.631886888503635060, 0.631848134682938660, 0.631809379282622260, 0.631770622302782470, 0.631731863743516200, 0.631693103604919810, 0.631654341887091020, 0.631615578590126400, +0.631576813714122890, 0.631538047259176950, 0.631499279225386180, 0.631460509612847280, 0.631421738421656720, 0.631382965651912210, 0.631344191303710220, 0.631305415377147790, +0.631266637872321510, 0.631227858789328970, 0.631189078128266750, 0.631150295889231770, 0.631111512072320860, 0.631072726677631370, 0.631033939705260230, 0.630995151155304130, +0.630956361027859790, 0.630917569323024900, 0.630878776040896150, 0.630839981181570360, 0.630801184745144350, 0.630762386731715700, 0.630723587141381100, 0.630684785974237490, +0.630645983230381680, 0.630607178909911140, 0.630568373012922680, 0.630529565539513000, 0.630490756489779700, 0.630451945863819470, 0.630413133661729460, 0.630374319883606260, +0.630335504529547560, 0.630296687599650070, 0.630257869094010940, 0.630219049012726740, 0.630180227355895290, 0.630141404123613300, 0.630102579315977680, 0.630063752933085360, +0.630024924975034040, 0.629986095441920410, 0.629947264333841410, 0.629908431650894050, 0.629869597393175830, 0.629830761560783770, 0.629791924153814350, 0.629753085172365500, +0.629714244616533910, 0.629675402486416740, 0.629636558782110670, 0.629597713503713630, 0.629558866651322210, 0.629520018225033670, 0.629481168224944710, 0.629442316651153240, +0.629403463503755980, 0.629364608782850050, 0.629325752488532180, 0.629286894620900370, 0.629248035180051240, 0.629209174166082020, 0.629170311579089650, 0.629131447419171710, +0.629092581686425230, 0.629053714380946930, 0.629014845502834600, 0.628975975052185280, 0.628937103029096000, 0.628898229433663580, 0.628859354265985940, 0.628820477526159880, +0.628781599214282670, 0.628742719330451120, 0.628703837874763140, 0.628664954847315550, 0.628626070248205600, 0.628587184077530110, 0.628548296335387000, 0.628509407021873080, +0.628470516137085710, 0.628431623681121710, 0.628392729654079000, 0.628353834056054380, 0.628314936887144900, 0.628276038147448480, 0.628237137837061920, 0.628198235956082480, +0.628159332504607090, 0.628120427482733780, 0.628081520890559350, 0.628042612728181180, 0.628003702995696080, 0.627964791693202070, 0.627925878820796090, 0.627886964378575390, +0.627848048366636990, 0.627809130785078830, 0.627770211633997710, 0.627731290913491220, 0.627692368623656070, 0.627653444764590400, 0.627614519336391010, 0.627575592339155390, +0.627536663772980450, 0.627497733637964240, 0.627458801934203670, 0.627419868661795670, 0.627380933820838370, 0.627341997411428820, 0.627303059433664270, 0.627264119887641640, +0.627225178773459070, 0.627186236091213600, 0.627147291841002490, 0.627108346022922870, 0.627069398637072670, 0.627030449683549040, 0.626991499162449230, 0.626952547073870380, +0.626913593417910420, 0.626874638194666600, 0.626835681404236070, 0.626796723046716080, 0.626757763122204550, 0.626718801630798630, 0.626679838572595350, 0.626640873947692860, +0.626601907756188180, 0.626562939998178690, 0.626523970673761530, 0.626484999783034850, 0.626446027326095670, 0.626407053303041360, 0.626368077713969070, 0.626329100558976950, +0.626290121838162020, 0.626251141551621870, 0.626212159699453430, 0.626173176281755060, 0.626134191298623690, 0.626095204750156790, 0.626056216636451610, 0.626017226957606200, +0.625978235713717690, 0.625939242904883340, 0.625900248531201080, 0.625861252592768370, 0.625822255089682480, 0.625783256022040550, 0.625744255389940830, 0.625705253193480470, +0.625666249432757060, 0.625627244107867630, 0.625588237218910330, 0.625549228765982620, 0.625510218749181670, 0.625471207168604940, 0.625432194024350570, 0.625393179316515610, +0.625354163045197750, 0.625315145210494140, 0.625276125812503030, 0.625237104851321560, 0.625198082327047320, 0.625159058239777580, 0.625120032589610460, 0.625081005376643350, +0.625041976600973380, 0.625002946262698810, 0.624963914361916780, 0.624924880898725110, 0.624885845873220820, 0.624846809285502180, 0.624807771135666660, 0.624768731423811620, +0.624729690150034430, 0.624690647314433360, 0.624651602917105640, 0.624612556958148990, 0.624573509437660550, 0.624534460355738670, 0.624495409712480740, 0.624456357507984120, +0.624417303742346390, 0.624378248415665690, 0.624339191528039410, 0.624300133079564780, 0.624261073070340180, 0.624222011500462860, 0.624182948370030520, 0.624143883679140530, +0.624104817427891030, 0.624065749616379620, 0.624026680244703760, 0.623987609312960930, 0.623948536821249400, 0.623909462769666520, 0.623870387158310000, 0.623831309987277090, +0.623792231256666270, 0.623753150966574910, 0.623714069117100700, 0.623674985708340900, 0.623635900740394100, 0.623596814213357440, 0.623557726127328400, 0.623518636482405460, +0.623479545278685880, 0.623440452516267450, 0.623401358195247560, 0.623362262315724560, 0.623323164877795930, 0.623284065881559490, 0.623244965327112380, 0.623205863214553290, +0.623166759543979490, 0.623127654315488890, 0.623088547529178750, 0.623049439185147550, 0.623010329283492760, 0.622971217824312200, 0.622932104807703220, 0.622892990233764320, +0.622853874102592960, 0.622814756414286630, 0.622775637168943690, 0.622736516366661610, 0.622697394007538320, 0.622658270091671180, 0.622619144619158680, 0.622580017590098290, +0.622540889004587930, 0.622501758862724960, 0.622462627164607980, 0.622423493910334360, 0.622384359100002120, 0.622345222733708510, 0.622306084811552250, 0.622266945333630810, +0.622227804300041990, 0.622188661710883270, 0.622149517566253250, 0.622110371866249400, 0.622071224610969750, 0.622032075800511560, 0.621992925434973640, 0.621953773514453360, +0.621914620039048180, 0.621875465008856930, 0.621836308423977080, 0.621797150284506330, 0.621757990590542380, 0.621718829342183810, 0.621679666539528220, 0.621640502182673420, +0.621601336271716990, 0.621562168806757630, 0.621522999787892830, 0.621483829215220500, 0.621444657088838230, 0.621405483408844720, 0.621366308175337560, 0.621327131388414560, +0.621287953048173300, 0.621248773154712610, 0.621209591708129950, 0.621170408708523030, 0.621131224155990310, 0.621092038050629620, 0.621052850392538770, 0.621013661181815560, +0.620974470418558470, 0.620935278102865200, 0.620896084234833780, 0.620856888814561690, 0.620817691842147860, 0.620778493317689750, 0.620739293241285410, 0.620700091613032410, +0.620660888433029690, 0.620621683701374600, 0.620582477418165410, 0.620543269583499590, 0.620504060197475950, 0.620464849260192190, 0.620425636771746000, 0.620386422732235990, +0.620347207141759950, 0.620307990000415920, 0.620268771308301600, 0.620229551065515690, 0.620190329272155780, 0.620151105928320230, 0.620111881034106420, 0.620072654589613360, +0.620033426594938540, 0.619994197050180220, 0.619954965955436090, 0.619915733310804850, 0.619876499116384320, 0.619837263372272520, 0.619798026078567150, 0.619758787235367150, +0.619719546842770200, 0.619680304900874330, 0.619641061409777370, 0.619601816369578120, 0.619562569780374270, 0.619523321642263650, 0.619484071955345160, 0.619444820719716400, +0.619405567935475630, 0.619366313602720540, 0.619327057721550060, 0.619287800292061990, 0.619248541314354360, 0.619209280788525000, 0.619170018714672810, 0.619130755092895610, +0.619091489923291550, 0.619052223205958320, 0.619012954940994950, 0.618973685128499150, 0.618934413768569170, 0.618895140861302820, 0.618855866406798900, 0.618816590405155350, +0.618777312856469970, 0.618738033760841690, 0.618698753118368310, 0.618659470929148080, 0.618620187193278710, 0.618580901910859350, 0.618541615081987680, 0.618502326706761970, +0.618463036785280140, 0.618423745317640990, 0.618384452303942460, 0.618345157744282890, 0.618305861638760000, 0.618266563987472930, 0.618227264790519370, 0.618187964047997580, +0.618148661760005600, 0.618109357926642340, 0.618070052548005620, 0.618030745624193470, 0.617991437155304800, 0.617952127141437550, 0.617912815582689960, 0.617873502479159950, +0.617834187830946570, 0.617794871638147720, 0.617755553900861680, 0.617716234619186460, 0.617676913793220870, 0.617637591423063180, 0.617598267508811420, 0.617558942050563610, +0.617519615048418790, 0.617480286502475000, 0.617440956412830480, 0.617401624779583160, 0.617362291602832180, 0.617322956882675470, 0.617283620619210940, 0.617244282812537850, +0.617204943462753900, 0.617165602569957670, 0.617126260134247100, 0.617086916155721200, 0.617047570634478020, 0.617008223570615910, 0.616968874964232920, 0.616929524815428070, +0.616890173124299390, 0.616850819890945370, 0.616811465115463810, 0.616772108797954080, 0.616732750938513980, 0.616693391537242010, 0.616654030594236290, 0.616614668109595750, +0.616575304083418540, 0.616535938515803130, 0.616496571406847440, 0.616457202756650720, 0.616417832565311020, 0.616378460832926360, 0.616339087559595990, 0.616299712745417730, +0.616260336390490380, 0.616220958494911650, 0.616181579058781010, 0.616142198082196390, 0.616102815565256260, 0.616063431508058650, 0.616024045910702920, 0.615984658773287120, +0.615945270095909600, 0.615905879878668520, 0.615866488121663220, 0.615827094824991540, 0.615787699988752270, 0.615748303613043340, 0.615708905697963990, 0.615669506243612390, +0.615630105250086660, 0.615590702717485950, 0.615551298645908630, 0.615511893035452950, 0.615472485886217170, 0.615433077198300650, 0.615393666971801310, 0.615354255206817860, +0.615314841903448430, 0.615275427061792280, 0.615236010681947550, 0.615196592764012730, 0.615157173308086060, 0.615117752314266910, 0.615078329782653310, 0.615038905713343960, +0.614999480106436900, 0.614960052962031490, 0.614920624280226090, 0.614881194061118630, 0.614841762304808580, 0.614802329011394090, 0.614762894180973850, 0.614723457813646010, +0.614684019909509830, 0.614644580468663660, 0.614605139491205990, 0.614565696977235180, 0.614526252926850370, 0.614486807340150040, 0.614447360217232670, 0.614407911558196520, +0.614368461363140940, 0.614329009632164190, 0.614289556365364970, 0.614250101562841430, 0.614210645224693040, 0.614171187351018060, 0.614131727941915060, 0.614092266997482430, +0.614052804517819520, 0.614013340503024470, 0.613973874953195890, 0.613934407868432790, 0.613894939248833760, 0.613855469094497400, 0.613815997405522060, 0.613776524182007010, +0.613737049424050610, 0.613697573131751660, 0.613658095305208430, 0.613618615944520270, 0.613579135049785560, 0.613539652621102990, 0.613500168658571040, 0.613460683162288970, +0.613421196132355240, 0.613381707568868450, 0.613342217471926960, 0.613302725841630480, 0.613263232678077030, 0.613223737981365200, 0.613184241751594360, 0.613144743988862980, +0.613105244693269660, 0.613065743864912970, 0.613026241503892180, 0.612986737610305750, 0.612947232184252620, 0.612907725225830920, 0.612868216735140360, 0.612828706712279180, +0.612789195157346310, 0.612749682070440000, 0.612710167451659960, 0.612670651301104430, 0.612631133618872340, 0.612591614405061930, 0.612552093659772920, 0.612512571383103670, +0.612473047575152640, 0.612433522236019320, 0.612393995365802300, 0.612354466964600160, 0.612314937032511610, 0.612275405569636000, 0.612235872576071930, 0.612196338051918090, +0.612156801997273070, 0.612117264412236460, 0.612077725296906630, 0.612038184651382490, 0.611998642475762630, 0.611959098770146430, 0.611919553534632450, 0.611880006769319640, +0.611840458474306460, 0.611800908649692500, 0.611761357295576240, 0.611721804412056260, 0.611682249999232150, 0.611642694057202400, 0.611603136586065800, 0.611563577585921170, +0.611524017056867870, 0.611484454999004500, 0.611444891412429970, 0.611405326297242980, 0.611365759653542900, 0.611326191481428530, 0.611286621780998680, 0.611247050552351840, +0.611207477795587710, 0.611167903510804970, 0.611128327698102440, 0.611088750357578810, 0.611049171489333580, 0.611009591093465420, 0.610970009170073270, 0.610930425719255710, +0.610890840741112550, 0.610851254235742270, 0.610811666203243450, 0.610772076643715800, 0.610732485557258010, 0.610692892943969000, 0.610653298803947360, 0.610613703137292910, +0.610574105944104110, 0.610534507224480110, 0.610494906978519490, 0.610455305206321850, 0.610415701907986110, 0.610376097083610960, 0.610336490733295320, 0.610296882857138790, +0.610257273455240060, 0.610217662527698050, 0.610178050074611680, 0.610138436096080430, 0.610098820592203110, 0.610059203563078410, 0.610019585008806040, 0.609979964929484700, +0.609940343325213520, 0.609900720196091100, 0.609861095542217120, 0.609821469363690530, 0.609781841660610220, 0.609742212433074910, 0.609702581681184520, 0.609662949405037620, +0.609623315604733370, 0.609583680280370470, 0.609544043432048600, 0.609504405059866810, 0.609464765163923890, 0.609425123744318790, 0.609385480801151180, 0.609345836334519890, +0.609306190344523600, 0.609266542831262250, 0.609226893794834520, 0.609187243235339570, 0.609147591152876090, 0.609107937547544110, 0.609068282419442220, 0.609028625768669560, +0.608988967595325060, 0.608949307899508520, 0.608909646681318640, 0.608869983940854680, 0.608830319678215440, 0.608790653893500730, 0.608750986586809370, 0.608711317758240500, +0.608671647407893040, 0.608631975535866790, 0.608592302142260680, 0.608552627227173740, 0.608512950790704890, 0.608473272832954050, 0.608433593354019920, 0.608393912354001530, +0.608354229832998690, 0.608314545791110330, 0.608274860228435580, 0.608235173145073360, 0.608195484541123490, 0.608155794416684990, 0.608116102771856900, 0.608076409606738260, +0.608036714921428970, 0.607997018716027850, 0.607957320990634150, 0.607917621745346910, 0.607877920980265940, 0.607838218695490040, 0.607798514891118690, 0.607758809567250700, +0.607719102723986100, 0.607679394361423600, 0.607639684479662430, 0.607599973078802310, 0.607560260158942270, 0.607520545720181550, 0.607480829762619080, 0.607441112286355000, +0.607401393291488010, 0.607361672778117590, 0.607321950746342760, 0.607282227196263240, 0.607242502127978260, 0.607202775541586970, 0.607163047437188410, 0.607123317814882490, +0.607083586674768360, 0.607043854016945270, 0.607004119841512150, 0.606964384148569120, 0.606924646938215130, 0.606884908210549190, 0.606845167965671340, 0.606805426203680500, +0.606765682924676140, 0.606725938128757190, 0.606686191816023790, 0.606646443986574970, 0.606606694640509870, 0.606566943777927860, 0.606527191398928740, 0.606487437503611670, +0.606447682092076000, 0.606407925164420770, 0.606368166720746000, 0.606328406761150960, 0.606288645285734780, 0.606248882294596720, 0.606209117787836820, 0.606169351765553980, +0.606129584227847570, 0.606089815174817530, 0.606050044606562870, 0.606010272523183180, 0.605970498924777390, 0.605930723811445750, 0.605890947183287290, 0.605851169040401480, +0.605811389382887370, 0.605771608210845080, 0.605731825524373880, 0.605692041323573020, 0.605652255608541750, 0.605612468379380210, 0.605572679636187550, 0.605532889379063130, +0.605493097608106100, 0.605453304323416710, 0.605413509525094100, 0.605373713213237630, 0.605333915387946560, 0.605294116049321040, 0.605254315197460310, 0.605214512832463410, +0.605174708954430600, 0.605134903563460890, 0.605095096659654000, 0.605055288243109060, 0.605015478313926210, 0.604975666872204720, 0.604935853918043940, 0.604896039451543240, +0.604856223472802880, 0.604816405981921880, 0.604776586978999830, 0.604736766464135990, 0.604696944437430610, 0.604657120898982820, 0.604617295848892340, 0.604577469287258200, +0.604537641214180630, 0.604497811629759130, 0.604457980534092610, 0.604418147927281660, 0.604378313809425190, 0.604338478180622920, 0.604298641040974190, 0.604258802390579160, +0.604218962229537190, 0.604179120557947760, 0.604139277375910220, 0.604099432683524840, 0.604059586480890860, 0.604019738768107880, 0.603979889545275260, 0.603940038812493140, +0.603900186569861110, 0.603860332817478530, 0.603820477555444660, 0.603780620783860080, 0.603740762502823940, 0.603700902712435480, 0.603661041412795200, 0.603621178604002220, +0.603581314286156360, 0.603541448459356870, 0.603501581123704110, 0.603461712279297350, 0.603421841926236270, 0.603381970064620350, 0.603342096694549750, 0.603302221816124030, +0.603262345429442680, 0.603222467534605070, 0.603182588131711770, 0.603142707220861940, 0.603102824802155270, 0.603062940875691230, 0.603023055441570200, 0.602983168499891530, +0.602943280050754930, 0.602903390094259860, 0.602863498630506590, 0.602823605659594590, 0.602783711181623220, 0.602743815196692960, 0.602703917704903060, 0.602664018706353440, +0.602624118201143370, 0.602584216189373410, 0.602544312671142950, 0.602504407646551670, 0.602464501115698940, 0.602424593078685460, 0.602384683535610370, 0.602344772486573590, +0.602304859931674600, 0.602264945871013760, 0.602225030304690550, 0.602185113232804770, 0.602145194655455910, 0.602105274572744320, 0.602065352984769600, 0.602025429891631100, +0.601985505293429420, 0.601945579190264040, 0.601905651582234640, 0.601865722469440700, 0.601825791851982930, 0.601785859729960570, 0.601745926103473660, 0.601705990972621560, +0.601666054337504750, 0.601626116198222820, 0.601586176554875670, 0.601546235407562690, 0.601506292756384560, 0.601466348601440550, 0.601426402942830780, 0.601386455780654640, +0.601346507115012700, 0.601306556946004430, 0.601266605273729440, 0.601226652098288290, 0.601186697419780590, 0.601146741238306030, 0.601106783553964410, 0.601066824366856100, +0.601026863677080690, 0.600986901484738210, 0.600946937789928030, 0.600906972592750940, 0.600867005893306330, 0.600827037691694210, 0.600787067988014290, 0.600747096782366930, +0.600707124074851830, 0.600667149865568910, 0.600627174154617860, 0.600587196942099170, 0.600547218228112410, 0.600507238012757290, 0.600467256296134510, 0.600427273078343540, +0.600387288359484410, 0.600347302139656700, 0.600307314418961010, 0.600267325197497150, 0.600227334475364920, 0.600187342252664010, 0.600147348529495030, 0.600107353305957770, +0.600067356582152040, 0.600027358358177660, 0.599987358634135210, 0.599947357410124390, 0.599907354686245120, 0.599867350462597090, 0.599827344739281120, 0.599787337516396680, +0.599747328794044020, 0.599707318572322620, 0.599667306851333290, 0.599627293631175730, 0.599587278911949520, 0.599547262693755470, 0.599507244976693280, 0.599467225760862980, +0.599427205046364260, 0.599387182833297840, 0.599347159121763510, 0.599307133911861300, 0.599267107203690920, 0.599227078997353060, 0.599187049292947530, 0.599147018090574360, +0.599106985390333360, 0.599066951192325230, 0.599026915496649660, 0.598986878303406800, 0.598946839612696460, 0.598906799424619330, 0.598866757739275220, 0.598826714556763840, +0.598786669877185980, 0.598746623700641580, 0.598706576027230540, 0.598666526857052680, 0.598626476190208920, 0.598586424026798960, 0.598546370366922930, 0.598506315210680540, +0.598466258558172810, 0.598426200409499450, 0.598386140764760490, 0.598346079624055950, 0.598306016987486420, 0.598265952855151940, 0.598225887227152640, 0.598185820103588120, +0.598145751484559510, 0.598105681370166510, 0.598065609760508930, 0.598025536655687700, 0.597985462055802610, 0.597945385960953810, 0.597905308371241230, 0.597865229286765780, +0.597825148707627260, 0.597785066633925830, 0.597744983065761400, 0.597704898003234790, 0.597664811446446010, 0.597624723395495220, 0.597584633850482220, 0.597544542811508040, +0.597504450278672490, 0.597464356252075720, 0.597424260731817870, 0.597384163717999630, 0.597344065210720920, 0.597303965210082110, 0.597263863716183120, 0.597223760729124640, +0.597183656249006930, 0.597143550275929580, 0.597103442809993830, 0.597063333851299390, 0.597023223399946730, 0.596983111456035550, 0.596942998019666990, 0.596902883090940860, +0.596862766669957630, 0.596822648756817120, 0.596782529351620240, 0.596742408454467130, 0.596702286065457940, 0.596662162184692700, 0.596622036812272440, 0.596581909948297070, +0.596541781592866970, 0.596501651746081940, 0.596461520408043230, 0.596421387578850770, 0.596381253258604360, 0.596341117447405260, 0.596300980145353380, 0.596260841352548980, +0.596220701069092080, 0.596180559295083960, 0.596140416030624290, 0.596100271275813660, 0.596060125030751900, 0.596019977295540240, 0.595979828070278720, 0.595939677355067480, +0.595899525150006770, 0.595859371455197630, 0.595819216270739970, 0.595779059596734380, 0.595738901433280680, 0.595698741780480210, 0.595658580638432800, 0.595618418007238580, +0.595578253886998700, 0.595538088277813180, 0.595497921179782400, 0.595457752593006480, 0.595417582517586590, 0.595377410953622620, 0.595337237901215290, 0.595297063360464400, +0.595256887331471200, 0.595216709814335830, 0.595176530809158670, 0.595136350316039840, 0.595096168335080500, 0.595055984866380670, 0.595015799910040940, 0.594975613466161350, +0.594935425534843020, 0.594895236116186220, 0.594855045210291310, 0.594814852817258320, 0.594774658937188730, 0.594734463570182340, 0.594694266716339510, 0.594654068375761400, +0.594613868548548030, 0.594573667234800100, 0.594533464434617520, 0.594493260148101780, 0.594453054375352790, 0.594412847116471130, 0.594372638371557070, 0.594332428140711740, +0.594292216424035400, 0.594252003221628520, 0.594211788533591130, 0.594171572360024710, 0.594131354701029400, 0.594091135556705670, 0.594050914927153780, 0.594010692812474980, +0.593970469212769410, 0.593930244128137220, 0.593890017558679870, 0.593849789504497520, 0.593809559965690630, 0.593769328942359450, 0.593729096434605360, 0.593688862442528500, +0.593648626966229550, 0.593608390005808560, 0.593568151561367000, 0.593527911633005110, 0.593487670220823380, 0.593447427324922170, 0.593407182945402730, 0.593366937082365320, +0.593326689735910630, 0.593286440906138800, 0.593246190593151200, 0.593205938797048190, 0.593165685517929920, 0.593125430755897850, 0.593085174511052140, 0.593044916783493580, +0.593004657573322320, 0.592964396880639730, 0.592924134705546170, 0.592883871048142330, 0.592843605908528360, 0.592803339286805840, 0.592763071183074920, 0.592722801597436290, +0.592682530529990310, 0.592642257980838360, 0.592601983950080900, 0.592561708437818300, 0.592521431444151150, 0.592481152969180800, 0.592440873013007520, 0.592400591575731660, +0.592360308657454810, 0.592320024258277120, 0.592279738378299390, 0.592239451017621880, 0.592199162176346160, 0.592158871854572500, 0.592118580052401700, 0.592078286769934130, +0.592037992007271140, 0.591997695764513110, 0.591957398041760950, 0.591917098839114920, 0.591876798156676490, 0.591836495994546020, 0.591796192352824320, 0.591755887231611880, +0.591715580631009930, 0.591675272551119180, 0.591634962992040100, 0.591594651953873400, 0.591554339436720310, 0.591514025440681430, 0.591473709965857130, 0.591433393012348870, +0.591393074580257250, 0.591352754669682850, 0.591312433280726140, 0.591272110413488820, 0.591231786068071140, 0.591191460244574030, 0.591151132943097960, 0.591110804163744400, +0.591070473906613710, 0.591030142171806940, 0.590989808959424550, 0.590949474269567790, 0.590909138102337470, 0.590868800457834300, 0.590828461336158740, 0.590788120737412380, +0.590747778661695810, 0.590707435109109280, 0.590667090079754600, 0.590626743573732240, 0.590586395591143010, 0.590546046132087390, 0.590505695196666960, 0.590465342784982420, +0.590424988897134460, 0.590384633533223680, 0.590344276693351660, 0.590303918377618860, 0.590263558586126450, 0.590223197318974660, 0.590182834576265300, 0.590142470358098750, +0.590102104664576130, 0.590061737495797820, 0.590021368851865620, 0.589980998732879900, 0.589940627138941350, 0.589900254070151680, 0.589859879526611230, 0.589819503508421160, +0.589779126015681940, 0.589738747048495380, 0.589698366606961840, 0.589657984691182360, 0.589617601301257620, 0.589577216437289220, 0.589536830099377740, 0.589496442287624320, +0.589456053002129330, 0.589415662242994580, 0.589375270010320640, 0.589334876304208550, 0.589294481124758910, 0.589254084472073500, 0.589213686346252820, 0.589173286747397880, +0.589132885675609400, 0.589092483130989050, 0.589052079113637550, 0.589011673623655470, 0.588971266661144520, 0.588930858226205390, 0.588890448318939220, 0.588850036939446490, +0.588809624087829000, 0.588769209764187560, 0.588728793968622990, 0.588688376701236080, 0.588647957962128650, 0.588607537751401290, 0.588567116069155130, 0.588526692915490760, +0.588486268290510100, 0.588445842194313730, 0.588405414627002690, 0.588364985588677780, 0.588324555079440810, 0.588284123099392490, 0.588243689648633380, 0.588203254727265530, +0.588162818335389410, 0.588122380473106390, 0.588081941140516930, 0.588041500337723070, 0.588001058064825390, 0.587960614321925150, 0.587920169109122930, 0.587879722426520650, +0.587839274274219110, 0.587798824652319360, 0.587758373560922200, 0.587717921000129540, 0.587677466970041970, 0.587637011470760750, 0.587596554502386680, 0.587556096065021570, +0.587515636158766230, 0.587475174783721350, 0.587434711939988970, 0.587394247627669900, 0.587353781846865040, 0.587313314597675440, 0.587272845880202900, 0.587232375694548340, +0.587191904040812670, 0.587151430919097050, 0.587110956329503160, 0.587070480272131820, 0.587030002747084280, 0.586989523754461450, 0.586949043294365150, 0.586908561366896180, +0.586868077972155900, 0.586827593110245020, 0.586787106781265440, 0.586746618985318210, 0.586706129722504020, 0.586665638992924900, 0.586625146796681650, 0.586584653133875530, +0.586544158004607460, 0.586503661408979250, 0.586463163347092030, 0.586422663819046840, 0.586382162824944600, 0.586341660364887330, 0.586301156438975850, 0.586260651047311620, +0.586220144189995240, 0.586179635867128960, 0.586139126078813580, 0.586098614825150470, 0.586058102106240320, 0.586017587922185390, 0.585977072273086370, 0.585936555159044750, +0.585896036580161320, 0.585855516536538220, 0.585814995028276390, 0.585774472055476610, 0.585733947618241050, 0.585693421716670600, 0.585652894350866540, 0.585612365520929990, +0.585571835226962770, 0.585531303469066120, 0.585490770247341090, 0.585450235561888800, 0.585409699412811290, 0.585369161800209590, 0.585328622724184840, 0.585288082184838300, +0.585247540182271870, 0.585206996716586600, 0.585166451787883850, 0.585125905396264630, 0.585085357541831000, 0.585044808224683850, 0.585004257444924460, 0.584963705202654730, +0.584923151497975800, 0.584882596330988940, 0.584842039701795270, 0.584801481610496720, 0.584760922057194650, 0.584720361041990210, 0.584679798564984420, 0.584639234626279650, +0.584598669225976700, 0.584558102364177050, 0.584517534040981830, 0.584476964256493090, 0.584436393010812070, 0.584395820304039910, 0.584355246136277980, 0.584314670507628200, +0.584274093418191810, 0.584233514868069740, 0.584192934857364230, 0.584152353386176440, 0.584111770454607830, 0.584071186062759320, 0.584030600210733280, 0.583990012898630730, +0.583949424126553150, 0.583908833894601580, 0.583868242202878360, 0.583827649051484540, 0.583787054440521590, 0.583746458370090540, 0.583705860840293860, 0.583665261851232460, +0.583624661403007840, 0.583584059495721340, 0.583543456129475000, 0.583502851304369960, 0.583462245020507810, 0.583421637277989680, 0.583381028076917940, 0.583340417417393510, +0.583299805299517750, 0.583259191723392690, 0.583218576689119810, 0.583177960196800460, 0.583137342246535790, 0.583096722838428170, 0.583056101972578730, 0.583015479649089060, +0.582974855868060300, 0.582934230629594710, 0.582893603933793640, 0.582852975780758560, 0.582812346170590630, 0.582771715103392210, 0.582731082579264430, 0.582690448598309100, +0.582649813160627140, 0.582609176266321030, 0.582568537915492010, 0.582527898108241350, 0.582487256844671290, 0.582446614124882970, 0.582405969948978200, 0.582365324317058120, +0.582324677229225210, 0.582284028685580490, 0.582243378686225670, 0.582202727231262100, 0.582162074320792030, 0.582121419954916840, 0.582080764133738100, 0.582040106857356960, +0.581999448125876010, 0.581958787939396480, 0.581918126298019980, 0.581877463201847740, 0.581836798650982260, 0.581796132645524660, 0.581755465185576530, 0.581714796271240010, +0.581674125902616470, 0.581633454079807710, 0.581592780802914880, 0.581552106072040440, 0.581511429887285880, 0.581470752248752550, 0.581430073156542160, 0.581389392610756840, +0.581348710611498070, 0.581308027158867540, 0.581267342252966500, 0.581226655893897550, 0.581185968081761930, 0.581145278816661340, 0.581104588098697250, 0.581063895927972030, +0.581023202304587150, 0.580982507228643860, 0.580941810700244640, 0.580901112719490850, 0.580860413286484300, 0.580819712401326350, 0.580779010064119580, 0.580738306274965250, +0.580697601033965060, 0.580656894341220590, 0.580616186196834190, 0.580575476600907360, 0.580534765553541890, 0.580494053054839030, 0.580453339104901490, 0.580412623703830620, +0.580371906851728130, 0.580331188548695480, 0.580290468794835260, 0.580249747590248940, 0.580209024935038120, 0.580168300829304480, 0.580127575273150400, 0.580086848266677450, +0.580046119809986880, 0.580005389903181510, 0.579964658546362590, 0.579923925739632030, 0.579883191483091310, 0.579842455776843010, 0.579801718620988500, 0.579760980015629700, +0.579720239960868080, 0.579679498456806330, 0.579638755503545710, 0.579598011101188250, 0.579557265249835420, 0.579516517949589800, 0.579475769200552880, 0.579435019002826460, +0.579394267356512230, 0.579353514261712670, 0.579312759718529250, 0.579272003727063670, 0.579231246287418400, 0.579190487399695030, 0.579149727063995370, 0.579108965280421110, +0.579068202049074720, 0.579027437370057910, 0.578986671243472470, 0.578945903669420000, 0.578905134648003080, 0.578864364179323410, 0.578823592263482790, 0.578782818900582810, +0.578742044090726160, 0.578701267834014430, 0.578660490130549540, 0.578619710980432970, 0.578578930383767620, 0.578538148340654870, 0.578497364851196290, 0.578456579915494820, +0.578415793533651800, 0.578375005705769380, 0.578334216431949040, 0.578293425712293470, 0.578252633546904370, 0.578211839935883760, 0.578171044879333130, 0.578130248377355160, +0.578089450430051670, 0.578048651037524560, 0.578007850199875440, 0.577967047917207100, 0.577926244189621130, 0.577885439017219450, 0.577844632400103860, 0.577803824338377070, +0.577763014832140760, 0.577722203881496870, 0.577681391486547180, 0.577640577647394290, 0.577599762364139900, 0.577558945636885810, 0.577518127465734830, 0.577477307850788320, +0.577436486792148650, 0.577395664289917400, 0.577354840344197370, 0.577314014955090270, 0.577273188122698010, 0.577232359847122510, 0.577191530128466470, 0.577150698966831580, +0.577109866362319980, 0.577069032315033260, 0.577028196825074450, 0.576987359892545020, 0.576946521517547330, 0.576905681700182860, 0.576864840440554530, 0.576823997738764250, +0.576783153594913500, 0.576742308009105200, 0.576701460981441150, 0.576660612512023500, 0.576619762600953930, 0.576578911248335380, 0.576538058454269420, 0.576497204218858420, +0.576456348542203960, 0.576415491424409070, 0.576374632865575440, 0.576333772865805230, 0.576292911425200230, 0.576252048543863250, 0.576211184221896210, 0.576170318459401140, +0.576129451256479960, 0.576088582613235590, 0.576047712529769610, 0.576006841006184160, 0.575965968042581820, 0.575925093639064630, 0.575884217795734730, 0.575843340512693810, +0.575802461790045020, 0.575761581627890040, 0.575720700026331130, 0.575679816985469990, 0.575638932505409760, 0.575598046586252240, 0.575557159228099580, 0.575516270431053580, +0.575475380195217380, 0.575434488520692680, 0.575393595407581730, 0.575352700855986440, 0.575311804866009860, 0.575270907437753660, 0.575230008571319780, 0.575189108266811360, +0.575148206524330070, 0.575107303343978420, 0.575066398725857960, 0.575025492670071970, 0.574984585176722240, 0.574943676245911030, 0.574902765877740360, 0.574861854072313050, +0.574820940829731120, 0.574780026150096820, 0.574739110033512080, 0.574698192480079920, 0.574657273489902360, 0.574616353063081560, 0.574575431199719540, 0.574534507899919220, +0.574493583163782740, 0.574452656991412240, 0.574411729382909740, 0.574370800338378280, 0.574329869857919890, 0.574288937941636380, 0.574248004589630880, 0.574207069802005420, +0.574166133578862260, 0.574125195920303420, 0.574084256826431940, 0.574043316297349840, 0.574002374333159480, 0.573961430933962680, 0.573920486099862790, 0.573879539830961630, +0.573838592127361660, 0.573797642989164910, 0.573756692416474310, 0.573715740409391990, 0.573674786968020320, 0.573633832092461330, 0.573592875782818150, 0.573551918039192810, +0.573510958861687240, 0.573469998250404680, 0.573429036205447050, 0.573388072726916940, 0.573347107814916160, 0.573306141469548060, 0.573265173690914560, 0.573224204479118150, +0.573183233834260950, 0.573142261756445890, 0.573101288245775220, 0.573060313302351410, 0.573019336926276380, 0.572978359117653380, 0.572937379876584440, 0.572896399203172150, +0.572855417097518420, 0.572814433559726500, 0.572773448589898540, 0.572732462188136560, 0.572691474354543820, 0.572650485089222450, 0.572609494392274820, 0.572568502263803070, +0.572527508703910450, 0.572486513712698990, 0.572445517290271270, 0.572404519436729430, 0.572363520152176730, 0.572322519436715080, 0.572281517290447180, 0.572240513713475170, +0.572199508705902190, 0.572158502267830490, 0.572117494399362550, 0.572076485100600380, 0.572035474371647480, 0.571994462212605860, 0.571953448623578110, 0.571912433604666370, +0.571871417155973890, 0.571830399277602820, 0.571789379969655510, 0.571748359232234990, 0.571707337065443630, 0.571666313469383900, 0.571625288444158050, 0.571584261989869340, +0.571543234106620000, 0.571502204794512520, 0.571461174053649270, 0.571420141884133370, 0.571379108286067080, 0.571338073259553100, 0.571297036804693460, 0.571255998921591730, +0.571214959610349850, 0.571173918871070720, 0.571132876703856370, 0.571091833108810180, 0.571050788086034380, 0.571009741635631340, 0.570968693757704200, 0.570927644452355440, +0.570886593719687420, 0.570845541559802720, 0.570804487972804480, 0.570763432958794950, 0.570722376517876830, 0.570681318650152480, 0.570640259355725150, 0.570599198634697210, +0.570558136487171240, 0.570517072913249600, 0.570476007913035650, 0.570434941486631650, 0.570393873634140290, 0.570352804355663820, 0.570311733651305830, 0.570270661521168450, +0.570229587965354060, 0.570188512983966110, 0.570147436577106760, 0.570106358744878920, 0.570065279487384720, 0.570024198804727770, 0.569983116697010290, 0.569942033164335120, +0.569900948206804370, 0.569859861824521640, 0.569818774017589290, 0.569777684786110020, 0.569736594130186180, 0.569695502049921140, 0.569654408545417380, 0.569613313616777580, +0.569572217264104230, 0.569531119487500570, 0.569490020287069190, 0.569448919662912330, 0.569407817615133590, 0.569366714143835330, 0.569325609249120230, 0.569284502931090790, +0.569243395189850450, 0.569202286025501600, 0.569161175438147040, 0.569120063427889230, 0.569078949994831550, 0.569037835139076580, 0.568996718860726890, 0.568955601159885080, +0.568914482036654730, 0.568873361491138100, 0.568832239523438090, 0.568791116133657070, 0.568749991321898630, 0.568708865088265240, 0.568667737432859700, 0.568626608355784490, +0.568585477857143080, 0.568544345937037950, 0.568503212595571570, 0.568462077832847630, 0.568420941648968390, 0.568379804044036870, 0.568338665018155440, 0.568297524571427680, +0.568256382703956180, 0.568215239415843620, 0.568174094707192710, 0.568132948578106810, 0.568091801028688610, 0.568050652059040930, 0.568009501669266230, 0.567968349859468200, +0.567927196629749220, 0.567886041980212310, 0.567844885910959830, 0.567803728422095590, 0.567762569513721950, 0.567721409185941610, 0.567680247438858030, 0.567639084272573920, +0.567597919687192090, 0.567556753682815000, 0.567515586259546460, 0.567474417417488940, 0.567433247156745370, 0.567392075477418320, 0.567350902379611500, 0.567309727863427370, +0.567268551928968970, 0.567227374576338760, 0.567186195805640450, 0.567145015616976720, 0.567103834010450500, 0.567062650986164260, 0.567021466544221700, 0.566980280684725610, +0.566939093407778370, 0.566897904713483780, 0.566856714601944420, 0.566815523073263220, 0.566774330127542970, 0.566733135764887150, 0.566691939985398570, 0.566650742789180040, +0.566609544176334360, 0.566568344146965220, 0.566527142701175210, 0.566485939839067250, 0.566444735560744150, 0.566403529866309600, 0.566362322755866180, 0.566321114229517030, +0.566279904287364630, 0.566238692929512900, 0.566197480156064300, 0.566156265967122210, 0.566115050362788970, 0.566073833343168410, 0.566032614908363430, 0.565991395058476400, +0.565950173793611340, 0.565908951113870850, 0.565867727019357950, 0.565826501510175330, 0.565785274586426800, 0.565744046248215170, 0.565702816495643360, 0.565661585328814280, +0.565620352747831400, 0.565579118752797760, 0.565537883343816270, 0.565496646520989740, 0.565455408284421980, 0.565414168634215670, 0.565372927570473970, 0.565331685093299560, +0.565290441202796370, 0.565249195899066970, 0.565207949182214290, 0.565166701052342010, 0.565125451509553070, 0.565084200553950480, 0.565042948185636940, 0.565001694404716480, +0.564960439211291800, 0.564919182605466030, 0.564877924587341870, 0.564836665157023350, 0.564795404314613060, 0.564754142060214350, 0.564712878393929920, 0.564671613315863570, +0.564630346826118230, 0.564589078924797040, 0.564547809612002790, 0.564506538887839420, 0.564465266752409600, 0.564423993205816270, 0.564382718248163440, 0.564341441879553710, +0.564300164100090430, 0.564258884909876300, 0.564217604309015350, 0.564176322297610390, 0.564135038875764660, 0.564093754043580970, 0.564052467801163250, 0.564011180148614290, +0.563969891086037460, 0.563928600613535560, 0.563887308731212400, 0.563846015439171120, 0.563804720737514750, 0.563763424626346100, 0.563722127105769410, 0.563680828175887380, +0.563639527836802820, 0.563598226088619870, 0.563556922931441330, 0.563515618365370560, 0.563474312390510270, 0.563433005006964580, 0.563391696214836420, 0.563350386014229040, +0.563309074405245250, 0.563267761387989290, 0.563226446962563740, 0.563185131129072200, 0.563143813887617360, 0.563102495238303470, 0.563061175181233330, 0.563019853716510200, +0.562978530844237100, 0.562937206564517960, 0.562895880877455900, 0.562854553783154080, 0.562813225281715510, 0.562771895373244350, 0.562730564057843270, 0.562689231335615550, +0.562647897206665080, 0.562606561671094910, 0.562565224729008270, 0.562523886380508210, 0.562482546625698850, 0.562441205464683010, 0.562399862897564270, 0.562358518924445440, +0.562317173545430760, 0.562275826760623150, 0.562234478570125870, 0.562193128974042060, 0.562151777972475840, 0.562110425565530150, 0.562069071753308340, 0.562027716535913550, +0.561986359913449920, 0.561945001886020260, 0.561903642453727700, 0.561862281616676510, 0.561820919374969590, 0.561779555728710300, 0.561738190678001900, 0.561696824222948200, +0.561655456363652550, 0.561614087100218320, 0.561572716432748420, 0.561531344361347110, 0.561489970886117410, 0.561448596007162790, 0.561407219724586400, 0.561365842038492270, +0.561324462948983530, 0.561283082456163650, 0.561241700560135670, 0.561200317261003720, 0.561158932558871170, 0.561117546453840820, 0.561076158946016920, 0.561034770035502730, +0.560993379722401490, 0.560951988006816560, 0.560910594888851980, 0.560869200368610880, 0.560827804446196840, 0.560786407121712790, 0.560745008395263200, 0.560703608266951090, +0.560662206736879940, 0.560620803805153000, 0.560579399471874300, 0.560537993737147080, 0.560496586601074930, 0.560455178063760990, 0.560413768125309410, 0.560372356785823420, +0.560330944045406620, 0.560289529904161920, 0.560248114362193910, 0.560206697419605600, 0.560165279076500160, 0.560123859332981810, 0.560082438189153930, 0.560041015645119880, +0.559999591700982900, 0.559958166356847360, 0.559916739612816410, 0.559875311468993610, 0.559833881925482220, 0.559792450982386390, 0.559751018639809470, 0.559709584897855050, +0.559668149756626150, 0.559626713216227370, 0.559585275276761830, 0.559543835938333010, 0.559502395201044280, 0.559460953064999990, 0.559419509530303170, 0.559378064597057410, +0.559336618265366740, 0.559295170535334510, 0.559253721407064310, 0.559212270880659500, 0.559170818956224450, 0.559129365633862290, 0.559087910913676710, 0.559046454795770980, +0.559004997280249440, 0.558963538367215460, 0.558922078056772630, 0.558880616349024200, 0.558839153244074630, 0.558797688742027180, 0.558756222842985540, 0.558714755547052970, +0.558673286854333820, 0.558631816764931450, 0.558590345278949240, 0.558548872396491540, 0.558507398117661590, 0.558465922442563210, 0.558424445371299650, 0.558382966903975260, +0.558341487040693530, 0.558300005781558030, 0.558258523126672230, 0.558217039076140400, 0.558175553630065990, 0.558134066788552820, 0.558092578551703910, 0.558051088919624070, +0.558009597892416440, 0.557968105470184830, 0.557926611653032590, 0.557885116441064310, 0.557843619834383020, 0.557802121833092410, 0.557760622437296960, 0.557719121647099800, +0.557677619462604970, 0.557636115883915600, 0.557594610911136380, 0.557553104544370680, 0.557511596783722090, 0.557470087629294290, 0.557428577081191530, 0.557387065139517300, +0.557345551804375510, 0.557304037075869400, 0.557262520954103560, 0.557221003439181460, 0.557179484531206910, 0.557137964230283170, 0.557096442536514910, 0.557054919450005630, +0.557013394970858890, 0.556971869099178510, 0.556930341835068620, 0.556888813178633040, 0.556847283129974890, 0.556805751689198990, 0.556764218856408810, 0.556722684631707930, +0.556681149015200050, 0.556639612006989640, 0.556598073607180170, 0.556556533815875550, 0.556514992633179270, 0.556473450059195800, 0.556431906094028710, 0.556390360737781920, +0.556348813990558800, 0.556307265852464040, 0.556265716323601110, 0.556224165404073930, 0.556182613093985870, 0.556141059393441720, 0.556099504302544960, 0.556057947821398950, +0.556016389950108600, 0.555974830688777180, 0.555933270037508700, 0.555891707996406640, 0.555850144565575690, 0.555808579745119320, 0.555767013535141690, 0.555725445935746020, +0.555683876947037140, 0.555642306569118500, 0.555600734802094150, 0.555559161646067560, 0.555517587101143520, 0.555476011167425400, 0.555434433845017340, 0.555392855134022810, +0.555351275034546510, 0.555309693546692020, 0.555268110670562920, 0.555226526406263910, 0.555184940753898570, 0.555143353713570930, 0.555101765285384460, 0.555060175469443970, +0.555018584265853040, 0.554976991674715700, 0.554935397696135540, 0.554893802330217120, 0.554852205577064270, 0.554810607436780900, 0.554769007909470700, 0.554727406995238260, +0.554685804694187380, 0.554644201006421980, 0.554602595932045640, 0.554560989471163170, 0.554519381623878370, 0.554477772390294940, 0.554436161770516800, 0.554394549764648640, +0.554352936372794040, 0.554311321595056810, 0.554269705431541640, 0.554228087882352120, 0.554186468947592490, 0.554144848627366240, 0.554103226921778270, 0.554061603830932280, +0.554019979354932190, 0.553978353493881800, 0.553936726247885920, 0.553895097617048250, 0.553853467601472800, 0.553811836201263290, 0.553770203416524610, 0.553728569247360360, +0.553686933693874780, 0.553645296756171360, 0.553603658434355220, 0.553562018728529840, 0.553520377638799020, 0.553478735165267690, 0.553437091308039530, 0.553395446067218580, +0.553353799442908740, 0.553312151435214730, 0.553270502044240330, 0.553228851270089580, 0.553187199112866510, 0.553145545572675700, 0.553103890649621070, 0.553062234343806640, +0.553020576655336330, 0.552978917584314940, 0.552937257130846290, 0.552895595295034400, 0.552853932076983190, 0.552812267476797570, 0.552770601494581240, 0.552728934130438110, +0.552687265384472880, 0.552645595256789580, 0.552603923747492230, 0.552562250856684760, 0.552520576584472070, 0.552478900930957860, 0.552437223896246390, 0.552395545480441560, +0.552353865683648190, 0.552312184505970080, 0.552270501947511590, 0.552228818008376530, 0.552187132688669700, 0.552145445988495130, 0.552103757907956850, 0.552062068447158880, +0.552020377606206040, 0.551978685385202340, 0.551936991784251480, 0.551895296803458610, 0.551853600442927420, 0.551811902702762260, 0.551770203583066940, 0.551728503083946500, +0.551686801205504730, 0.551645097947846110, 0.551603393311074220, 0.551561687295294310, 0.551519979900610190, 0.551478271127126110, 0.551436560974945980, 0.551394849444174720, +0.551353136534916470, 0.551311422247275250, 0.551269706581355210, 0.551227989537261260, 0.551186271115097330, 0.551144551314967760, 0.551102830136976360, 0.551061107581228280, +0.551019383647827430, 0.550977658336877730, 0.550935931648484310, 0.550894203582751100, 0.550852474139782330, 0.550810743319681940, 0.550769011122555160, 0.550727277548505810, +0.550685542597638240, 0.550643806270056490, 0.550602068565865580, 0.550560329485169530, 0.550518589028072600, 0.550476847194678820, 0.550435103985093320, 0.550393359399420020, +0.550351613437763400, 0.550309866100227360, 0.550268117386916940, 0.550226367297936390, 0.550184615833389400, 0.550142862993381330, 0.550101108778015990, 0.550059353187397960, +0.550017596221631160, 0.549975837880820830, 0.549934078165070780, 0.549892317074485600, 0.549850554609169210, 0.549808790769226840, 0.549767025554762530, 0.549725258965880650, +0.549683491002685210, 0.549641721665281360, 0.549599950953773230, 0.549558178868265300, 0.549516405408861490, 0.549474630575667140, 0.549432854368786080, 0.549391076788322550, +0.549349297834381690, 0.549307517507067630, 0.549265735806484750, 0.549223952732737160, 0.549182168285930140, 0.549140382466167590, 0.549098595273554090, 0.549056806708193790, +0.549015016770191820, 0.548973225459652330, 0.548931432776679770, 0.548889638721378190, 0.548847843293852940, 0.548806046494208060, 0.548764248322548110, 0.548722448778977130, +0.548680647863600380, 0.548638845576522090, 0.548597041917846640, 0.548555236887678150, 0.548513430486122000, 0.548471622713282310, 0.548429813569263120, 0.548388003054169790, +0.548346191168106460, 0.548304377911177700, 0.548262563283487550, 0.548220747285141470, 0.548178929916243400, 0.548137111176898010, 0.548095291067209560, 0.548053469587283180, +0.548011646737223130, 0.547969822517134000, 0.547927996927119910, 0.547886169967286230, 0.547844341637737100, 0.547802511938577210, 0.547760680869910590, 0.547718848431842600, +0.547677014624477490, 0.547635179447919510, 0.547593342902274020, 0.547551504987645040, 0.547509665704137390, 0.547467825051855210, 0.547425983030903840, 0.547384139641387430, +0.547342294883410680, 0.547300448757077950, 0.547258601262494370, 0.547216752399764310, 0.547174902168992340, 0.547133050570282720, 0.547091197603740920, 0.547049343269471080, +0.547007487567577890, 0.546965630498165600, 0.546923772061339690, 0.546881912257204280, 0.546840051085863640, 0.546798188547423350, 0.546756324641987530, 0.546714459369661010, +0.546672592730547910, 0.546630724724753600, 0.546588855352382550, 0.546546984613539450, 0.546505112508328450, 0.546463239036855010, 0.546421364199223490, 0.546379487995538590, +0.546337610425904560, 0.546295731490426870, 0.546253851189209880, 0.546211969522358180, 0.546170086489976340, 0.546128202092169500, 0.546086316329042250, 0.546044429200699180, +0.546002540707244630, 0.545960650848784200, 0.545918759625422020, 0.545876867037262680, 0.545834973084411530, 0.545793077766972940, 0.545751181085051610, 0.545709283038751990, +0.545667383628179460, 0.545625482853438590, 0.545583580714633980, 0.545541677211869970, 0.545499772345252150, 0.545457866114885000, 0.545415958520873100, 0.545374049563321030, +0.545332139242334040, 0.545290227558016820, 0.545248314510474060, 0.545206400099810030, 0.545164484326130520, 0.545122567189539660, 0.545080648690142060, 0.545038728828043270, +0.544996807603347570, 0.544954885016159850, 0.544912961066584600, 0.544871035754727280, 0.544829109080692490, 0.544787181044584790, 0.544745251646508780, 0.544703320886570030, +0.544661388764873020, 0.544619455281522450, 0.544577520436623000, 0.544535584230280030, 0.544493646662598030, 0.544451707733682010, 0.544409767443636340, 0.544367825792566710, +0.544325882780577360, 0.544283938407773000, 0.544241992674259210, 0.544200045580140350, 0.544158097125521430, 0.544116147310506950, 0.544074196135202360, 0.544032243599712360, +0.543990289704141650, 0.543948334448594920, 0.543906377833177750, 0.543864419857994610, 0.543822460523150420, 0.543780499828749650, 0.543738537774898110, 0.543696574361700160, +0.543654609589260820, 0.543612643457684560, 0.543570675967076980, 0.543528707117542860, 0.543486736909186470, 0.543444765342113720, 0.543402792416428970, 0.543360818132237240, +0.543318842489643130, 0.543276865488752310, 0.543234887129669270, 0.543192907412499040, 0.543150926337346180, 0.543108943904316410, 0.543066960113514190, 0.543024974965044650, +0.542982988459012270, 0.542941000595522750, 0.542899011374680770, 0.542857020796591260, 0.542815028861358790, 0.542773035569089180, 0.542731040919887000, 0.542689044913857170, +0.542647047551104380, 0.542605048831734330, 0.542563048755851600, 0.542521047323560990, 0.542479044534968090, 0.542437040390177480, 0.542395034889294410, 0.542353028032423250, +0.542311019819670000, 0.542269010251139160, 0.542226999326935850, 0.542184987047164560, 0.542142973411931290, 0.542100958421340540, 0.542058942075497320, 0.542016924374506440, +0.541974905318473700, 0.541932884907503580, 0.541890863141701320, 0.541848840021171400, 0.541806815546019840, 0.541764789716351340, 0.541722762532270360, 0.541680733993882950, +0.541638704101293560, 0.541596672854607550, 0.541554640253929410, 0.541512606299365040, 0.541470570991019140, 0.541428534328996850, 0.541386496313402850, 0.541344456944343080, +0.541302416221921990, 0.541260374146244950, 0.541218330717416650, 0.541176285935542790, 0.541134239800728280, 0.541092192313078150, 0.541050143472697200, 0.541008093279691240, +0.540966041734165070, 0.540923988836223390, 0.540881934585972110, 0.540839878983515930, 0.540797822028960210, 0.540755763722409410, 0.540713704063969680, 0.540671643053745600, +0.540629580691842530, 0.540587516978365050, 0.540545451913419180, 0.540503385497109630, 0.540461317729541650, 0.540419248610820020, 0.540377178141050680, 0.540335106320338320, +0.540293033148788180, 0.540250958626505180, 0.540208882753595130, 0.540166805530162830, 0.540124726956313530, 0.540082647032152030, 0.540040565757784250, 0.539998483133315110, +0.539956399158849410, 0.539914313834493060, 0.539872227160350880, 0.539830139136528220, 0.539788049763129770, 0.539745959040261680, 0.539703866968028520, 0.539661773546535770, +0.539619678775888230, 0.539577582656191930, 0.539535485187551570, 0.539493386370072490, 0.539451286203859630, 0.539409184689018990, 0.539367081825655290, 0.539324977613873880, +0.539282872053779670, 0.539240765145478700, 0.539198656889075760, 0.539156547284675770, 0.539114436332384870, 0.539072324032307870, 0.539030210384550010, 0.538988095389216330, +0.538945979046412730, 0.538903861356244130, 0.538861742318816010, 0.538819621934233050, 0.538777500202601400, 0.538735377124026080, 0.538693252698612230, 0.538651126926465000, +0.538608999807690280, 0.538566871342393010, 0.538524741530678530, 0.538482610372651880, 0.538440477868419090, 0.538398344018085060, 0.538356208821754830, 0.538314072279534540, +0.538271934391528980, 0.538229795157843530, 0.538187654578583310, 0.538145512653854240, 0.538103369383761470, 0.538061224768410230, 0.538019078807905560, 0.537976931502353590, +0.537934782851859250, 0.537892632856528000, 0.537850481516464750, 0.537808328831775760, 0.537766174802565830, 0.537724019428940550, 0.537681862711004820, 0.537639704648864790, +0.537597545242625490, 0.537555384492392040, 0.537513222398270370, 0.537471058960365730, 0.537428894178783480, 0.537386728053628530, 0.537344560585007120, 0.537302391773024410, +0.537260221617785640, 0.537218050119396050, 0.537175877277961570, 0.537133703093587430, 0.537091527566379120, 0.537049350696441550, 0.537007172483880970, 0.536964992928802510, +0.536922812031311540, 0.536880629791513190, 0.536838446209513600, 0.536796261285417910, 0.536754075019331480, 0.536711887411359560, 0.536669698461608390, 0.536627508170182900, +0.536585316537188220, 0.536543123562730600, 0.536500929246915280, 0.536458733589847530, 0.536416536591632690, 0.536374338252376790, 0.536332138572185090, 0.536289937551163050, +0.536247735189415710, 0.536205531487049520, 0.536163326444169420, 0.536121120060881080, 0.536078912337289550, 0.536036703273501060, 0.535994492869620860, 0.535952281125754330, +0.535910068042006800, 0.535867853618484550, 0.535825637855292580, 0.535783420752536150, 0.535741202310321520, 0.535698982528753920, 0.535656761407938830, 0.535614538947981500, +0.535572315148988180, 0.535530090011064000, 0.535487863534314770, 0.535445635718845400, 0.535403406564762260, 0.535361176072170710, 0.535318944241176100, 0.535276711071883900, +0.535234476564400150, 0.535192240718830310, 0.535150003535279860, 0.535107765013854040, 0.535065525154659110, 0.535023283957800410, 0.534981041423383210, 0.534938797551513630, +0.534896552342297160, 0.534854305795839260, 0.534812057912245290, 0.534769808691621380, 0.534727558134073130, 0.534685306239705890, 0.534643053008625020, 0.534600798440937000, +0.534558542536746840, 0.534516285296160350, 0.534474026719282790, 0.534431766806220620, 0.534389505557078980, 0.534347242971963570, 0.534304979050979620, 0.534262713794233620, +0.534220447201830930, 0.534178179273877010, 0.534135910010477330, 0.534093639411738260, 0.534051367477765050, 0.534009094208663050, 0.533966819604538620, 0.533924543665497240, +0.533882266391644490, 0.533839987783085720, 0.533797707839927300, 0.533755426562274700, 0.533713143950233390, 0.533670860003908950, 0.533628574723407740, 0.533586288108835020, +0.533544000160296680, 0.533501710877897880, 0.533459420261745200, 0.533417128311943990, 0.533374835028599950, 0.533332540411818430, 0.533290244461705920, 0.533247947178367880, +0.533205648561909550, 0.533163348612437420, 0.533121047330057050, 0.533078744714873930, 0.533036440766993640, 0.532994135486522640, 0.532951828873566180, 0.532909520928230300, +0.532867211650620120, 0.532824901040842350, 0.532782589099002330, 0.532740275825205890, 0.532697961219558260, 0.532655645282166250, 0.532613328013134990, 0.532571009412570520, +0.532528689480578080, 0.532486368217264250, 0.532444045622734620, 0.532401721697094430, 0.532359396440450270, 0.532317069852907720, 0.532274741934572470, 0.532232412685549880, +0.532190082105946760, 0.532147750195868460, 0.532105416955420680, 0.532063082384709010, 0.532020746483840010, 0.531978409252919170, 0.531936070692052290, 0.531893730801344830, +0.531851389580903500, 0.531809047030833650, 0.531766703151241190, 0.531724357942231500, 0.531682011403911470, 0.531639663536386250, 0.531597314339761540, 0.531554963814144020, +0.531512611959638950, 0.531470258776352460, 0.531427904264389910, 0.531385548423857990, 0.531343191254862180, 0.531300832757508390, 0.531258472931902090, 0.531216111778150090, +0.531173749296357740, 0.531131385486631080, 0.531089020349075460, 0.531046653883797790, 0.531004286090903440, 0.530961916970498330, 0.530919546522688130, 0.530877174747579340, +0.530834801645277740, 0.530792427215889040, 0.530750051459518920, 0.530707674376274090, 0.530665295966260000, 0.530622916229582350, 0.530580535166347730, 0.530538152776661830, +0.530495769060630560, 0.530453384018359510, 0.530410997649955250, 0.530368609955523600, 0.530326220935170460, 0.530283830589001300, 0.530241438917122940, 0.530199045919641070, +0.530156651596661480, 0.530114255948289980, 0.530071858974633160, 0.530029460675796700, 0.529987061051886530, 0.529944660103008450, 0.529902257829269030, 0.529859854230773970, +0.529817449307628970, 0.529775043059940610, 0.529732635487814680, 0.529690226591357230, 0.529647816370673710, 0.529605404825871150, 0.529562991957055030, 0.529520577764331370, +0.529478162247805970, 0.529435745407585530, 0.529393327243775750, 0.529350907756482520, 0.529308486945811780, 0.529266064811870220, 0.529223641354763410, 0.529181216574597490, +0.529138790471478160, 0.529096363045512330, 0.529053934296805470, 0.529011504225463500, 0.528969072831593000, 0.528926640115300000, 0.528884206076690290, 0.528841770715869690, +0.528799334032945100, 0.528756896028022120, 0.528714456701206870, 0.528672016052605160, 0.528629574082323810, 0.528587130790468480, 0.528544686177145340, 0.528502240242460060, +0.528459792986519570, 0.528417344409429670, 0.528374894511296380, 0.528332443292225510, 0.528289990752323750, 0.528247536891697230, 0.528205081710451660, 0.528162625208693170, +0.528120167386528450, 0.528077708244063300, 0.528035247781403430, 0.527992785998655960, 0.527950322895926470, 0.527907858473321110, 0.527865392730945790, 0.527822925668907320, +0.527780457287311600, 0.527737987586264670, 0.527695516565872440, 0.527653044226241820, 0.527610570567478510, 0.527568095589688870, 0.527525619292978480, 0.527483141677454470, +0.527440662743222650, 0.527398182490389170, 0.527355700919059810, 0.527313218029341610, 0.527270733821340380, 0.527228248295162020, 0.527185761450913230, 0.527143273288700140, +0.527100783808628900, 0.527058293010805310, 0.527015800895336280, 0.526973307462327840, 0.526930812711886020, 0.526888316644116950, 0.526845819259127320, 0.526803320557023170, +0.526760820537910850, 0.526718319201895930, 0.526675816549085680, 0.526633312579585900, 0.526590807293502830, 0.526548300690942270, 0.526505792772011480, 0.526463283536816040, +0.526420772985462190, 0.526378261118056630, 0.526335747934705500, 0.526293233435515040, 0.526250717620591060, 0.526208200490040690, 0.526165682043969850, 0.526123162282484680, +0.526080641205691310, 0.526038118813696780, 0.525995595106606870, 0.525953070084527960, 0.525910543747566070, 0.525868016095828120, 0.525825487129420230, 0.525782956848448560, +0.525740425253019120, 0.525697892343238940, 0.525655358119214040, 0.525612822581050470, 0.525570285728855110, 0.525527747562734130, 0.525485208082793750, 0.525442667289140020, +0.525400125181879840, 0.525357581761119460, 0.525315037026965140, 0.525272490979522780, 0.525229943618899630, 0.525187394945201610, 0.525144844958535080, 0.525102293659006180, +0.525059741046721820, 0.525017187121788020, 0.524974631884311370, 0.524932075334397790, 0.524889517472154290, 0.524846958297687130, 0.524804397811102440, 0.524761836012506480, +0.524719272902006260, 0.524676708479707820, 0.524634142745717290, 0.524591575700141810, 0.524549007343087290, 0.524506437674660320, 0.524463866694966810, 0.524421294404114110, +0.524378720802208150, 0.524336145889355400, 0.524293569665661870, 0.524250992131234720, 0.524208413286180170, 0.524165833130604610, 0.524123251664614040, 0.524080668888315840, +0.524038084801815800, 0.523995499405220610, 0.523952912698636310, 0.523910324682170140, 0.523867735355928120, 0.523825144720016400, 0.523782552774542220, 0.523739959519611610, +0.523697364955331040, 0.523654769081806750, 0.523612171899146000, 0.523569573407454690, 0.523526973606839530, 0.523484372497406540, 0.523441770079262960, 0.523399166352514930, +0.523356561317269040, 0.523313954973631310, 0.523271347321709210, 0.523228738361608660, 0.523186128093436230, 0.523143516517298070, 0.523100903633301640, 0.523058289441552860, +0.523015673942157980, 0.522973057135224240, 0.522930439020857900, 0.522887819599165530, 0.522845198870253160, 0.522802576834228150, 0.522759953491196750, 0.522717328841265540, +0.522674702884540540, 0.522632075621129120, 0.522589447051137520, 0.522546817174672330, 0.522504185991839790, 0.522461553502747140, 0.522418919707500540, 0.522376284606206660, +0.522333648198971660, 0.522291010485902980, 0.522248371467106790, 0.522205731142689640, 0.522163089512757810, 0.522120446577418520, 0.522077802336778250, 0.522035156790943030, +0.521992509940020330, 0.521949861784116290, 0.521907212323337700, 0.521864561557790600, 0.521821909487582560, 0.521779256112819720, 0.521736601433608670, 0.521693945450055870, +0.521651288162268470, 0.521608629570352920, 0.521565969674415710, 0.521523308474563300, 0.521480645970902930, 0.521437982163540980, 0.521395317052584020, 0.521352650638138400, +0.521309982920311610, 0.521267313899209770, 0.521224643574939360, 0.521181971947607630, 0.521139299017321030, 0.521096624784186170, 0.521053949248309390, 0.521011272409798050, +0.520968594268758630, 0.520925914825297600, 0.520883234079521530, 0.520840552031537670, 0.520797868681452500, 0.520755184029372600, 0.520712498075404320, 0.520669810819655240, +0.520627122262231620, 0.520584432403240150, 0.520541741242787290, 0.520499048780980410, 0.520456355017925980, 0.520413659953730230, 0.520370963588500660, 0.520328265922343820, +0.520285566955366210, 0.520242866687674280, 0.520200165119375610, 0.520157462250576570, 0.520114758081383740, 0.520072052611903810, 0.520029345842244030, 0.519986637772510860, +0.519943928402811120, 0.519901217733251260, 0.519858505763938660, 0.519815792494979780, 0.519773077926481420, 0.519730362058550050, 0.519687644891293040, 0.519644926424817080, +0.519602206659228290, 0.519559485594634380, 0.519516763231141820, 0.519474039568857290, 0.519431314607887380, 0.519388588348339450, 0.519345860790320080, 0.519303131933936070, +0.519260401779293890, 0.519217670326501010, 0.519174937575664020, 0.519132203526889600, 0.519089468180284340, 0.519046731535955820, 0.519003993594010500, 0.518961254354555090, +0.518918513817696270, 0.518875771983541510, 0.518833028852197290, 0.518790284423770510, 0.518747538698367650, 0.518704791676096290, 0.518662043357063010, 0.518619293741374170, +0.518576542829137570, 0.518533790620459570, 0.518491037115447080, 0.518448282314206590, 0.518405526216845770, 0.518362768823471210, 0.518320010134189710, 0.518277250149107750, +0.518234488868333120, 0.518191726291972190, 0.518148962420131980, 0.518106197252918950, 0.518063430790440930, 0.518020663032804250, 0.517977893980115840, 0.517935123632482400, +0.517892351990011490, 0.517849579052809820, 0.517806804820983620, 0.517764029294640940, 0.517721252473888120, 0.517678474358832190, 0.517635694949579730, 0.517592914246238430, +0.517550132248914770, 0.517507348957715770, 0.517464564372748010, 0.517421778494119300, 0.517378991321936100, 0.517336202856305440, 0.517293413097333900, 0.517250622045129170, +0.517207829699797950, 0.517165036061447040, 0.517122241130183240, 0.517079444906114240, 0.517036647389346630, 0.516993848579986980, 0.516951048478143100, 0.516908247083921580, +0.516865444397429430, 0.516822640418773350, 0.516779835148061030, 0.516737028585399050, 0.516694220730894550, 0.516651411584654110, 0.516608601146785530, 0.516565789417395500, +0.516522976396590950, 0.516480162084478560, 0.516437346481166130, 0.516394529586760460, 0.516351711401368370, 0.516308891925096550, 0.516266071158053010, 0.516223249100344230, +0.516180425752077340, 0.516137601113358930, 0.516094775184297030, 0.516051947964998090, 0.516009119455569040, 0.515966289656117460, 0.515923458566750150, 0.515880626187574240, +0.515837792518696330, 0.515794957560224310, 0.515752121312265000, 0.515709283774925310, 0.515666444948312040, 0.515623604832533000, 0.515580763427694990, 0.515537920733905140, +0.515495076751270040, 0.515452231479897600, 0.515409384919894630, 0.515366537071368150, 0.515323687934424960, 0.515280837509172970, 0.515237985795718890, 0.515195132794169400, +0.515152278504632520, 0.515109422927214840, 0.515066566062023720, 0.515023707909165740, 0.514980848468748920, 0.514937987740879950, 0.514895125725665980, 0.514852262423213910, +0.514809397833631550, 0.514766531957025600, 0.514723664793503400, 0.514680796343171650, 0.514637926606138270, 0.514595055582510060, 0.514552183272394270, 0.514509309675897590, +0.514466434793128040, 0.514423558624192310, 0.514380681169197440, 0.514337802428251110, 0.514294922401460350, 0.514252041088932300, 0.514209158490773750, 0.514166274607092740, +0.514123389437995960, 0.514080502983590760, 0.514037615243983950, 0.513994726219283440, 0.513951835909596030, 0.513908944315029090, 0.513866051435689530, 0.513823157271685040, +0.513780261823122750, 0.513737365090109810, 0.513694467072753010, 0.513651567771160500, 0.513608667185439070, 0.513565765315695530, 0.513522862162038020, 0.513479957724573330, +0.513437052003408720, 0.513394144998651210, 0.513351236710408610, 0.513308327138787930, 0.513265416283896440, 0.513222504145841030, 0.513179590724729740, 0.513136676020669480, +0.513093760033767500, 0.513050842764130820, 0.513007924211867360, 0.512965004377084030, 0.512922083259888310, 0.512879160860386870, 0.512836237178687980, 0.512793312214898540, +0.512750385969125810, 0.512707458441476690, 0.512664529632059330, 0.512621599540980630, 0.512578668168347520, 0.512535735514268120, 0.512492801578849470, 0.512449866362198800, +0.512406929864423040, 0.512363992085630330, 0.512321053025927680, 0.512278112685422340, 0.512235171064221340, 0.512192228162432820, 0.512149283980163790, 0.512106338517521410, +0.512063391774612910, 0.512020443751546320, 0.511977494448428550, 0.511934543865367080, 0.511891592002468920, 0.511848638859842110, 0.511805684437593670, 0.511762728735830730, +0.511719771754661210, 0.511676813494192360, 0.511633853954531430, 0.511590893135785540, 0.511547931038062840, 0.511504967661470240, 0.511462003006115220, 0.511419037072104790, +0.511376069859547200, 0.511333101368549370, 0.511290131599218880, 0.511247160551662640, 0.511204188225988790, 0.511161214622304570, 0.511118239740717350, 0.511075263581334040, +0.511032286144262990, 0.510989307429611240, 0.510946327437485910, 0.510903346167995040, 0.510860363621245870, 0.510817379797345760, 0.510774394696401730, 0.510731408318522260, +0.510688420663814150, 0.510645431732385080, 0.510602441524341980, 0.510559450039793190, 0.510516457278845760, 0.510473463241607140, 0.510430467928184580, 0.510387471338686230, +0.510344473473219100, 0.510301474331890880, 0.510258473914808500, 0.510215472222080410, 0.510172469253813540, 0.510129465010115580, 0.510086459491093550, 0.510043452696855800, +0.510000444627509380, 0.509957435283161510, 0.509914424663920340, 0.509871412769893120, 0.509828399601187420, 0.509785385157910390, 0.509742369440170150, 0.509699352448074070, +0.509656334181729620, 0.509613314641243930, 0.509570293826725250, 0.509527271738280940, 0.509484248376018470, 0.509441223740044970, 0.509398197830468690, 0.509355170647396990, +0.509312142190937460, 0.509269112461197100, 0.509226081458284300, 0.509183049182306390, 0.509140015633370410, 0.509096980811584830, 0.509053944717056670, 0.509010907349893740, +0.508967868710203160, 0.508924828798093310, 0.508881787613671420, 0.508838745157044970, 0.508795701428321310, 0.508752656427608810, 0.508709610155014590, 0.508666562610646470, +0.508623513794611460, 0.508580463707018040, 0.508537412347973560, 0.508494359717585500, 0.508451305815961100, 0.508408250643208940, 0.508365194199436040, 0.508322136484749780, +0.508279077499258600, 0.508236017243069770, 0.508192955716290750, 0.508149892919029120, 0.508106828851393020, 0.508063763513489920, 0.508020696905427390, 0.507977629027312800, +0.507934559879254400, 0.507891489461359650, 0.507848417773736240, 0.507805344816491310, 0.507762270589733440, 0.507719195093569890, 0.507676118328108440, 0.507633040293456240, +0.507589960989721760, 0.507546880417012460, 0.507503798575435480, 0.507460715465099520, 0.507417631086111710, 0.507374545438579740, 0.507331458522611190, 0.507288370338314200, +0.507245280885796460, 0.507202190165165430, 0.507159098176528490, 0.507116004919994200, 0.507072910395669930, 0.507029814603663480, 0.506986717544081980, 0.506943619217034120, +0.506900519622627170, 0.506857418760969010, 0.506814316632166810, 0.506771213236329340, 0.506728108573563760, 0.506685002643977870, 0.506641895447679120, 0.506598786984776010, +0.506555677255375980, 0.506512566259586290, 0.506469453997515640, 0.506426340469271260, 0.506383225674961190, 0.506340109614692560, 0.506296992288574050, 0.506253873696713040, +0.506210753839217430, 0.506167632716194470, 0.506124510327752850, 0.506081386673999930, 0.506038261755043520, 0.505995135570991180, 0.505952008121951290, 0.505908879408031420, +0.505865749429339260, 0.505822618185982510, 0.505779485678069520, 0.505736351905707760, 0.505693216869004810, 0.505650080568069150, 0.505606943003008350, 0.505563804173930100, +0.505520664080941980, 0.505477522724152690, 0.505434380103669480, 0.505391236219600360, 0.505348091072052810, 0.505304944661135290, 0.505261796986955500, 0.505218648049621240, +0.505175497849239990, 0.505132346385920310, 0.505089193659769790, 0.505046039670896230, 0.505002884419407220, 0.504959727905411440, 0.504916570129016250, 0.504873411090329350, +0.504830250789459310, 0.504787089226513610, 0.504743926401600150, 0.504700762314826520, 0.504657596966301300, 0.504614430356132180, 0.504571262484426960, 0.504528093351293230, +0.504484922956839550, 0.504441751301173640, 0.504398578384403380, 0.504355404206636160, 0.504312228767980990, 0.504269052068545110, 0.504225874108436670, 0.504182694887763130, +0.504139514406633290, 0.504096332665154630, 0.504053149663435060, 0.504009965401582380, 0.503966779879705060, 0.503923593097910790, 0.503880405056307160, 0.503837215755002950, +0.503794025194105770, 0.503750833373723390, 0.503707640293963530, 0.503664445954935090, 0.503621250356745430, 0.503578053499502690, 0.503534855383314440, 0.503491656008289380, +0.503448455374535200, 0.503405253482159920, 0.503362050331271130, 0.503318845921977510, 0.503275640254386870, 0.503232433328607120, 0.503189225144745840, 0.503146015702911840, +0.503102805003212920, 0.503059593045756540, 0.503016379830651620, 0.502973165358005740, 0.502929949627926920, 0.502886732640522860, 0.502843514395902250, 0.502800294894172990, +0.502757074135442910, 0.502713852119819780, 0.502670628847412430, 0.502627404318328530, 0.502584178532676010, 0.502540951490562770, 0.502497723192097510, 0.502454493637387920, +0.502411262826542140, 0.502368030759667740, 0.502324797436873750, 0.502281562858267750, 0.502238327023957320, 0.502195089934051600, 0.502151851588658160, 0.502108611987885030, +0.502065371131839910, 0.502022129020631920, 0.501978885654368550, 0.501935641033157910, 0.501892395157107820, 0.501849148026327070, 0.501805899640923480, 0.501762650001005170, +0.501719399106679840, 0.501676146958056400, 0.501632893555242650, 0.501589638898346620, 0.501546382987476110, 0.501503125822739930, 0.501459867404246080, 0.501416607732102060, +0.501373346806416990, 0.501330084627298560, 0.501286821194854900, 0.501243556509193720, 0.501200290570424150, 0.501157023378653750, 0.501113754933990910, 0.501070485236543180, +0.501027214286419720, 0.500983942083728210, 0.500940668628576780, 0.500897393921073350, 0.500854117961326840, 0.500810840749444930, 0.500767562285535980, 0.500724282569707800, +0.500681001602069190, 0.500637719382728160, 0.500594435911792760, 0.500551151189370990, 0.500507865215571670, 0.500464577990502590, 0.500421289514271780, 0.500377999786988160, +0.500334708808759520, 0.500291416579694110, 0.500248123099899740, 0.500204828369485430, 0.500161532388559090, 0.500118235157228860, 0.500074936675602770, 0.500031636943789600, +0.499988335961897460, 0.499945033730034400, 0.499901730248308420, 0.499858425516828460, 0.499815119535702460, 0.499771812305038640, 0.499728503824944940, 0.499685194095530310, +0.499641883116902720, 0.499598570889170030, 0.499555257412441330, 0.499511942686824470, 0.499468626712427750, 0.499425309489359090, 0.499381991017727510, 0.499338671297640980, +0.499295350329207800, 0.499252028112535770, 0.499208704647734150, 0.499165379934910720, 0.499122053974173860, 0.499078726765631480, 0.499035398309392640, 0.498992068605565330, +0.498948737654257850, 0.498905405455578100, 0.498862072009635280, 0.498818737316537250, 0.498775401376391980, 0.498732064189308600, 0.498688725755395080, 0.498645386074759720, +0.498602045147510550, 0.498558702973756600, 0.498515359553605930, 0.498472014887166860, 0.498428668974547350, 0.498385321815856540, 0.498341973411202450, 0.498298623760693450, +0.498255272864437440, 0.498211920722543720, 0.498168567335120100, 0.498125212702275110, 0.498081856824116710, 0.498038499700754090, 0.497995141332295170, 0.497951781718848410, +0.497908420860521780, 0.497865058757424540, 0.497821695409664590, 0.497778330817350070, 0.497734964980590110, 0.497691597899492690, 0.497648229574166320, 0.497604860004718990, +0.497561489191259860, 0.497518117133897040, 0.497474743832738870, 0.497431369287893550, 0.497387993499470100, 0.497344616467576720, 0.497301238192321800, 0.497257858673813390, +0.497214477912160720, 0.497171095907471830, 0.497127712659855230, 0.497084328169418940, 0.497040942436272230, 0.496997555460523210, 0.496954167242279870, 0.496910777781651490, +0.496867387078746170, 0.496823995133672370, 0.496780601946538230, 0.496737207517452930, 0.496693811846524670, 0.496650414933861810, 0.496607016779572590, 0.496563617383766200, +0.496520216746550720, 0.496476814868034740, 0.496433411748326340, 0.496390007387534800, 0.496346601785768230, 0.496303194943135130, 0.496259786859743700, 0.496216377535703130, +0.496172966971121680, 0.496129555166107410, 0.496086142120769620, 0.496042727835216520, 0.495999312309556570, 0.495955895543897910, 0.495912477538349940, 0.495869058293020800, +0.495825637808018970, 0.495782216083452690, 0.495738793119431250, 0.495695368916062810, 0.495651943473455980, 0.495608516791718860, 0.495565088870960900, 0.495521659711290140, +0.495478229312815270, 0.495434797675644470, 0.495391364799886990, 0.495347930685651190, 0.495304495333045490, 0.495261058742178180, 0.495217620913158630, 0.495174181846095020, +0.495130741541095600, 0.495087299998269670, 0.495043857217725480, 0.495000413199571660, 0.494956967943916410, 0.494913521450869200, 0.494870073720538100, 0.494826624753031850, +0.494783174548458660, 0.494739723106927930, 0.494696270428547860, 0.494652816513427130, 0.494609361361673940, 0.494565904973397750, 0.494522447348706820, 0.494478988487709770, +0.494435528390514860, 0.494392067057231540, 0.494348604487968020, 0.494305140682832600, 0.494261675641934680, 0.494218209365382630, 0.494174741853285030, 0.494131273105750220, +0.494087803122887580, 0.494044331904805460, 0.494000859451612480, 0.493957385763416970, 0.493913910840328430, 0.493870434682455060, 0.493826957289905610, 0.493783478662788380, +0.493739998801212890, 0.493696517705287330, 0.493653035375120510, 0.493609551810820720, 0.493566067012497440, 0.493522580980258970, 0.493479093714213670, 0.493435605214471050, +0.493392115481139370, 0.493348624514327430, 0.493305132314143520, 0.493261638880697240, 0.493218144214096770, 0.493174648314451010, 0.493131151181868180, 0.493087652816457890, +0.493044153218328510, 0.493000652387588670, 0.492957150324346840, 0.492913647028712540, 0.492870142500794140, 0.492826636740700320, 0.492783129748539550, 0.492739621524421360, +0.492696112068454100, 0.492652601380746180, 0.492609089461407130, 0.492565576310545430, 0.492522061928269690, 0.492478546314688460, 0.492435029469911250, 0.492391511394046470, +0.492347992087202870, 0.492304471549488920, 0.492260949781014200, 0.492217426781887070, 0.492173902552216440, 0.492130377092110600, 0.492086850401679210, 0.492043322481030720, +0.491999793330273940, 0.491956262949517280, 0.491912731338870310, 0.491869198498441570, 0.491825664428339800, 0.491782129128673470, 0.491738592599552220, 0.491695054841084500, +0.491651515853378740, 0.491607975636544570, 0.491564434190690510, 0.491520891515925320, 0.491477347612357510, 0.491433802480096720, 0.491390256119251470, 0.491346708529930510, +0.491303159712242420, 0.491259609666296840, 0.491216058392202230, 0.491172505890067450, 0.491128952160001080, 0.491085397202112640, 0.491041841016510720, 0.490998283603304220, +0.490954724962601620, 0.490911165094512600, 0.490867603999145700, 0.490824041676609310, 0.490780478127013310, 0.490736913350466040, 0.490693347347076540, 0.490649780116953260, +0.490606211660205900, 0.490562641976942990, 0.490519071067273550, 0.490475498931305990, 0.490431925569150050, 0.490388350980914380, 0.490344775166707770, 0.490301198126638860, +0.490257619860817280, 0.490214040369351730, 0.490170459652351060, 0.490126877709923860, 0.490083294542179800, 0.490039710149227540, 0.489996124531175640, 0.489952537688133790, +0.489908949620210590, 0.489865360327515040, 0.489821769810155680, 0.489778178068242310, 0.489734585101883500, 0.489690990911188170, 0.489647395496265010, 0.489603798857223770, +0.489560200994173020, 0.489516601907221740, 0.489473001596478610, 0.489429400062053320, 0.489385797304054570, 0.489342193322591320, 0.489298588117772160, 0.489254981689706940, +0.489211374038504290, 0.489167765164273180, 0.489124155067122310, 0.489080543747161370, 0.489036931204499150, 0.488993317439244120, 0.488949702451506260, 0.488906086241394140, +0.488862468809016790, 0.488818850154482840, 0.488775230277902210, 0.488731609179383520, 0.488687986859035750, 0.488644363316967640, 0.488600738553289000, 0.488557112568108520, +0.488513485361535270, 0.488469856933677950, 0.488426227284646350, 0.488382596414549170, 0.488338964323495490, 0.488295331011594060, 0.488251696478954610, 0.488208060725686010, +0.488164423751896840, 0.488120785557696950, 0.488077146143195140, 0.488033505508500440, 0.487989863653721660, 0.487946220578968530, 0.487902576284349850, 0.487858930769974770, +0.487815284035951980, 0.487771636082391320, 0.487727986909401610, 0.487684336517091920, 0.487640684905571000, 0.487597032074948760, 0.487553378025333940, 0.487509722756835680, +0.487466066269562680, 0.487422408563624950, 0.487378749639131190, 0.487335089496190140, 0.487291428134911830, 0.487247765555404890, 0.487204101757778560, 0.487160436742141540, +0.487116770508603860, 0.487073103057274250, 0.487029434388261910, 0.486985764501675520, 0.486942093397625180, 0.486898421076219560, 0.486854747537567910, 0.486811072781778990, +0.486767396808962800, 0.486723719619228110, 0.486680041212684100, 0.486636361589439630, 0.486592680749604660, 0.486548998693287940, 0.486505315420598330, 0.486461630931645850, +0.486417945226539310, 0.486374258305387890, 0.486330570168300390, 0.486286880815386900, 0.486243190246756220, 0.486199498462517530, 0.486155805462779700, 0.486112111247652800, +0.486068415817245580, 0.486024719171667340, 0.485981021311026880, 0.485937322235434290, 0.485893621944998360, 0.485849920439828390, 0.485806217720033240, 0.485762513785722940, +0.485718808637006340, 0.485675102273992740, 0.485631394696791010, 0.485587685905511160, 0.485543975900262050, 0.485500264681152650, 0.485456552248292980, 0.485412838601791960, +0.485369123741758830, 0.485325407668302460, 0.485281690381533020, 0.485237971881559260, 0.485194252168490660, 0.485150531242436010, 0.485106809103505400, 0.485063085751807790, +0.485019361187452480, 0.484975635410548390, 0.484931908421205540, 0.484888180219532950, 0.484844450805639930, 0.484800720179635380, 0.484756988341629450, 0.484713255291730980, +0.484669521030049010, 0.484625785556693670, 0.484582048871773810, 0.484538310975398840, 0.484494571867677750, 0.484450831548720540, 0.484407090018636300, 0.484363347277534330, +0.484319603325523600, 0.484275858162714290, 0.484232111789215270, 0.484188364205136000, 0.484144615410585450, 0.484100865405673710, 0.484057114190509840, 0.484013361765203150, +0.483969608129862730, 0.483925853284598640, 0.483882097229519910, 0.483838339964735520, 0.483794581490355700, 0.483750821806489480, 0.483707060913246110, 0.483663298810734780, +0.483619535499065560, 0.483575770978347470, 0.483532005248690000, 0.483488238310202100, 0.483444470162994020, 0.483400700807174730, 0.483356930242853700, 0.483313158470139950, +0.483269385489143720, 0.483225611299973990, 0.483181835902740280, 0.483138059297551550, 0.483094281484518110, 0.483050502463748920, 0.483006722235353460, 0.482962940799440850, +0.482919158156121240, 0.482875374305503760, 0.482831589247697480, 0.482787802982812540, 0.482744015510958190, 0.482700226832243730, 0.482656436946778340, 0.482612645854672230, +0.482568853556034520, 0.482525060050974670, 0.482481265339601780, 0.482437469422026140, 0.482393672298356780, 0.482349873968703270, 0.482306074433174690, 0.482262273691881290, +0.482218471744932260, 0.482174668592436960, 0.482130864234504690, 0.482087058671245570, 0.482043251902768870, 0.481999443929183650, 0.481955634750600160, 0.481911824367127590, +0.481868012778875480, 0.481824199985952940, 0.481780385988470340, 0.481736570786536700, 0.481692754380261660, 0.481648936769754400, 0.481605117955125120, 0.481561297936483060, +0.481517476713937740, 0.481473654287598360, 0.481429830657575220, 0.481386005823977560, 0.481342179786914850, 0.481298352546496280, 0.481254524102832200, 0.481210694456031870, +0.481166863606204360, 0.481123031553460090, 0.481079198297908290, 0.481035363839658450, 0.480991528178819850, 0.480947691315502750, 0.480903853249816490, 0.480860013981870560, +0.480816173511774190, 0.480772331839637860, 0.480728488965570630, 0.480684644889682160, 0.480640799612081730, 0.480596953132879700, 0.480553105452185270, 0.480509256570108070, +0.480465406486757340, 0.480421555202243500, 0.480377702716675740, 0.480333849030163350, 0.480289994142816760, 0.480246138054745140, 0.480202280766058200, 0.480158422276865170, +0.480114562587276470, 0.480070701697401350, 0.480026839607349490, 0.479982976317230140, 0.479939111827153710, 0.479895246137229500, 0.479851379247567210, 0.479807511158276080, +0.479763641869466570, 0.479719771381247940, 0.479675899693729870, 0.479632026807021660, 0.479588152721233780, 0.479544277436475540, 0.479500400952856620, 0.479456523270486270, +0.479412644389475010, 0.479368764309932140, 0.479324883031966960, 0.479281000555689950, 0.479237116881210510, 0.479193232008638230, 0.479149345938082450, 0.479105458669653710, +0.479061570203461350, 0.479017680539615080, 0.478973789678224180, 0.478929897619399190, 0.478886004363249460, 0.478842109909884740, 0.478798214259414380, 0.478754317411948850, +0.478710419367597510, 0.478666520126470150, 0.478622619688676090, 0.478578718054325840, 0.478534815223528810, 0.478490911196394360, 0.478447005973033020, 0.478403099553554200, +0.478359191938067580, 0.478315283126682590, 0.478271373119509850, 0.478227461916658600, 0.478183549518238720, 0.478139635924359600, 0.478095721135131770, 0.478051805150664590, +0.478007887971067970, 0.477963969596451210, 0.477920050026924890, 0.477876129262598480, 0.477832207303581720, 0.477788284149984090, 0.477744359801916100, 0.477700434259487270, +0.477656507522806920, 0.477612579591985660, 0.477568650467132980, 0.477524720148358670, 0.477480788635772200, 0.477436855929484150, 0.477392922029603930, 0.477348986936241390, +0.477305050649506010, 0.477261113169508420, 0.477217174496358030, 0.477173234630164700, 0.477129293571037890, 0.477085351319088250, 0.477041407874425230, 0.476997463237158690, +0.476953517407398110, 0.476909570385254110, 0.476865622170836170, 0.476821672764254190, 0.476777722165617650, 0.476733770375037170, 0.476689817392622280, 0.476645863218482460, +0.476601907852728380, 0.476557951295469520, 0.476513993546815780, 0.476470034606876650, 0.476426074475762850, 0.476382113153583860, 0.476338150640449600, 0.476294186936469580, +0.476250222041754430, 0.476206255956413750, 0.476162288680557430, 0.476118320214295010, 0.476074350557737170, 0.476030379710993490, 0.475986407674173830, 0.475942434447387760, +0.475898460030745980, 0.475854484424358070, 0.475810507628333550, 0.475766529642783150, 0.475722550467816420, 0.475678570103543310, 0.475634588550073400, 0.475590605807517440, +0.475546621875984900, 0.475502636755585850, 0.475458650446429820, 0.475414662948627550, 0.475370674262288630, 0.475326684387523010, 0.475282693324440290, 0.475238701073151190, +0.475194707633765370, 0.475150713006392780, 0.475106717191143060, 0.475062720188126900, 0.475018721997453930, 0.474974722619233790, 0.474930722053577170, 0.474886720300593810, +0.474842717360393630, 0.474798713233086260, 0.474754707918782550, 0.474710701417591970, 0.474666693729624720, 0.474622684854990320, 0.474578674793799620, 0.474534663546162190, +0.474490651112188130, 0.474446637491987070, 0.474402622685669740, 0.474358606693345900, 0.474314589515125560, 0.474270571151118310, 0.474226551601435060, 0.474182530866185450, +0.474138508945479040, 0.474094485839426820, 0.474050461548138350, 0.474006436071723770, 0.473962409410292660, 0.473918381563955940, 0.473874352532823280, 0.473830322317004730, +0.473786290916609950, 0.473742258331749880, 0.473698224562534130, 0.473654189609072850, 0.473610153471475670, 0.473566116149853560, 0.473522077644316090, 0.473478037954973450, +0.473433997081935340, 0.473389955025312610, 0.473345911785215010, 0.473301867361752620, 0.473257821755035170, 0.473213774965173530, 0.473169726992277500, 0.473125677836456760, +0.473081627497822180, 0.473037575976483550, 0.472993523272551010, 0.472949469386134190, 0.472905414317344170, 0.472861358066290590, 0.472817300633083580, 0.472773242017833000, +0.472729182220649640, 0.472685121241643360, 0.472641059080924240, 0.472596995738602140, 0.472552931214787860, 0.472508865509591310, 0.472464798623122630, 0.472420730555491500, +0.472376661306808940, 0.472332590877184770, 0.472288519266728660, 0.472244446475551690, 0.472200372503763620, 0.472156297351474570, 0.472112221018794460, 0.472068143505834150, +0.472024064812703480, 0.471979984939512600, 0.471935903886371410, 0.471891821653390890, 0.471847738240680770, 0.471803653648351310, 0.471759567876512300, 0.471715480925274820, +0.471671392794748620, 0.471627303485043890, 0.471583212996270540, 0.471539121328539590, 0.471495028481960790, 0.471450934456644040, 0.471406839252700330, 0.471362742870239550, +0.471318645309371900, 0.471274546570207230, 0.471230446652856630, 0.471186345557429890, 0.471142243284037250, 0.471098139832788640, 0.471054035203795070, 0.471009929397166460, +0.470965822413012990, 0.470921714251444520, 0.470877604912572250, 0.470833494396505900, 0.470789382703355800, 0.470745269833231890, 0.470701155786245220, 0.470657040562505620, +0.470612924162123410, 0.470568806585208550, 0.470524687831872070, 0.470480567902223810, 0.470436446796373750, 0.470392324514432970, 0.470348201056511430, 0.470304076422719320, +0.470259950613166670, 0.470215823627964550, 0.470171695467222820, 0.470127566131051890, 0.470083435619561620, 0.470039303932863140, 0.469995171071066480, 0.469951037034281820, +0.469906901822619180, 0.469862765436189710, 0.469818627875103310, 0.469774489139470340, 0.469730349229400770, 0.469686208145005670, 0.469642065886395120, 0.469597922453678980, +0.469553777846968450, 0.469509632066373420, 0.469465485112004370, 0.469421336983971150, 0.469377187682385010, 0.469333037207355920, 0.469288885558994230, 0.469244732737409960, +0.469200578742714200, 0.469156423575017020, 0.469112267234428780, 0.469068109721059450, 0.469023951035020260, 0.468979791176421190, 0.468935630145372650, 0.468891467941984660, +0.468847304566368360, 0.468803140018633820, 0.468758974298891020, 0.468714807407251190, 0.468670639343824360, 0.468626470108720940, 0.468582299702050900, 0.468538128123925530, +0.468493955374454820, 0.468449781453749270, 0.468405606361918800, 0.468361430099074770, 0.468317252665327140, 0.468273074060786390, 0.468228894285562580, 0.468184713339766860, +0.468140531223509400, 0.468096347936900640, 0.468052163480050580, 0.468007977853070520, 0.467963791056070500, 0.467919603089160640, 0.467875413952452130, 0.467831223646055120, +0.467787032170080000, 0.467742839524636970, 0.467698645709837210, 0.467654450725790820, 0.467610254572608300, 0.467566057250399740, 0.467521858759276490, 0.467477659099348520, +0.467433458270726470, 0.467389256273520350, 0.467345053107841470, 0.467300848773799960, 0.467256643271506340, 0.467212436601070700, 0.467168228762604390, 0.467124019756217530, +0.467079809582020560, 0.467035598240123690, 0.466991385730638250, 0.466947172053674310, 0.466902957209342110, 0.466858741197752840, 0.466814524019016740, 0.466770305673244350, +0.466726086160545780, 0.466681865481032350, 0.466637643634814300, 0.466593420622002150, 0.466549196442706040, 0.466504971097037370, 0.466460744585106220, 0.466416516907023240, +0.466372288062898540, 0.466328058052843550, 0.466283826876968400, 0.466239594535383660, 0.466195361028199580, 0.466151126355527470, 0.466106890517477560, 0.466062653514160040, +0.466018415345686220, 0.465974176012166450, 0.465929935513711200, 0.465885693850430660, 0.465841451022436350, 0.465797207029838400, 0.465752961872747400, 0.465708715551273630, +0.465664468065528470, 0.465620219415622150, 0.465575969601665250, 0.465531718623768080, 0.465487466482041980, 0.465443213176597200, 0.465398958707544390, 0.465354703074993770, +0.465310446279056820, 0.465266188319843730, 0.465221929197464800, 0.465177668912031440, 0.465133407463653890, 0.465089144852442850, 0.465044881078508550, 0.465000616141962420, +0.464956350042914750, 0.464912082781476220, 0.464867814357757090, 0.464823544771868770, 0.464779274023921660, 0.464735002114026300, 0.464690729042293080, 0.464646454808833430, +0.464602179413757640, 0.464557902857176410, 0.464513625139200030, 0.464469346259939960, 0.464425066219506520, 0.464380785018010440, 0.464336502655562030, 0.464292219132272700, +0.464247934448252850, 0.464203648603612740, 0.464159361598463940, 0.464115073432916750, 0.464070784107081860, 0.464026493621069570, 0.463982201974991510, 0.463937909168957880, +0.463893615203079530, 0.463849320077466710, 0.463805023792230990, 0.463760726347482780, 0.463716427743332660, 0.463672127979891100, 0.463627827057269630, 0.463583524975578590, +0.463539221734928730, 0.463494917335430470, 0.463450611777195260, 0.463406305060333530, 0.463361997184955630, 0.463317688151173190, 0.463273377959096460, 0.463229066608836340, +0.463184754100503080, 0.463140440434208430, 0.463096125610062580, 0.463051809628176490, 0.463007492488660470, 0.462963174191626080, 0.462918854737183800, 0.462874534125444330, +0.462830212356518170, 0.462785889430516850, 0.462741565347550840, 0.462697240107730890, 0.462652913711167460, 0.462608586157972120, 0.462564257448255360, 0.462519927582127510, +0.462475596559700270, 0.462431264381084010, 0.462386931046389620, 0.462342596555727510, 0.462298260909209280, 0.462253924106945380, 0.462209586149046730, 0.462165247035623670, +0.462120906766787910, 0.462076565342649850, 0.462032222763320400, 0.461987879028910030, 0.461943534139530320, 0.461899188095291740, 0.461854840896305240, 0.461810492542681250, +0.461766143034531400, 0.461721792371966200, 0.461677440555096130, 0.461633087584032880, 0.461588733458886850, 0.461544378179769010, 0.461500021746789830, 0.461455664160061010, +0.461411305419693050, 0.461366945525796770, 0.461322584478482790, 0.461278222277862690, 0.461233858924047060, 0.461189494417146790, 0.461145128757272370, 0.461100761944535530, +0.461056393979046800, 0.461012024860917020, 0.460967654590256850, 0.460923283167177960, 0.460878910591790810, 0.460834536864206390, 0.460790161984535260, 0.460745785952889060, +0.460701408769378480, 0.460657030434113930, 0.460612650947207210, 0.460568270308768850, 0.460523888518909850, 0.460479505577740700, 0.460435121485373190, 0.460390736241917900, +0.460346349847485740, 0.460301962302187340, 0.460257573606134400, 0.460213183759437540, 0.460168792762207680, 0.460124400614555510, 0.460080007316592710, 0.460035612868429870, +0.459991217270178000, 0.459946820521947740, 0.459902422623850780, 0.459858023575997750, 0.459813623378499290, 0.459769222031467200, 0.459724819535011990, 0.459680415889244800, +0.459636011094276100, 0.459591605150217800, 0.459547198057180530, 0.459502789815275200, 0.459458380424612510, 0.459413969885304310, 0.459369558197461170, 0.459325145361194120, +0.459280731376613790, 0.459236316243832100, 0.459191899962959560, 0.459147482534107250, 0.459103063957385870, 0.459058644232907260, 0.459014223360782010, 0.458969801341120750, +0.458925378174035450, 0.458880953859636730, 0.458836528398035570, 0.458792101789342710, 0.458747674033670010, 0.458703245131128090, 0.458658815081828040, 0.458614383885880610, +0.458569951543397580, 0.458525518054489710, 0.458481083419268020, 0.458436647637843200, 0.458392210710327210, 0.458347772636830690, 0.458303333417464710, 0.458258893052340020, +0.458214451541568480, 0.458170008885260770, 0.458125565083528090, 0.458081120136481110, 0.458036674044231710, 0.457992226806890610, 0.457947778424568570, 0.457903328897377450, +0.457858878225428030, 0.457814426408831410, 0.457769973447698380, 0.457725519342140730, 0.457681064092269330, 0.457636607698195250, 0.457592150160029240, 0.457547691477883320, +0.457503231651868130, 0.457458770682094840, 0.457414308568674210, 0.457369845311718260, 0.457325380911337680, 0.457280915367643650, 0.457236448680746920, 0.457191980850759460, +0.457147511877792070, 0.457103041761955490, 0.457058570503361740, 0.457014098102121510, 0.456969624558346050, 0.456925149872146160, 0.456880674043633750, 0.456836197072919670, +0.456791718960115110, 0.456747239705330820, 0.456702759308678870, 0.456658277770270020, 0.456613795090215490, 0.456569311268626040, 0.456524826305613700, 0.456480340201289300, +0.456435852955764110, 0.456391364569148810, 0.456346875041555520, 0.456302384373095060, 0.456257892563878280, 0.456213399614017080, 0.456168905523622440, 0.456124410292805480, +0.456079913921677180, 0.456035416410349450, 0.455990917758933190, 0.455946417967539600, 0.455901917036279580, 0.455857414965265220, 0.455812911754607250, 0.455768407404417040, +0.455723901914805380, 0.455679395285884410, 0.455634887517764930, 0.455590378610558230, 0.455545868564375180, 0.455501357379327840, 0.455456845055527140, 0.455412331593083920, +0.455367816992110260, 0.455323301252717080, 0.455278784375015620, 0.455234266359116850, 0.455189747205132780, 0.455145226913174330, 0.455100705483352850, 0.455056182915779150, +0.455011659210565410, 0.454967134367822550, 0.454922608387661850, 0.454878081270194250, 0.454833553015531800, 0.454789023623785480, 0.454744493095066590, 0.454699961429486100, +0.454655428627156080, 0.454610894688187490, 0.454566359612691650, 0.454521823400779570, 0.454477286052563270, 0.454432747568153770, 0.454388207947662050, 0.454343667191200170, +0.454299125298879110, 0.454254582270810230, 0.454210038107104530, 0.454165492807874100, 0.454120946373229970, 0.454076398803283490, 0.454031850098145560, 0.453987300257928440, +0.453942749282743030, 0.453898197172700800, 0.453853643927912660, 0.453809089548490810, 0.453764534034546250, 0.453719977386190300, 0.453675419603534080, 0.453630860686689670, +0.453586300635768100, 0.453541739450880390, 0.453497177132138720, 0.453452613679654120, 0.453408049093537990, 0.453363483373901370, 0.453318916520856370, 0.453274348534514090, +0.453229779414985990, 0.453185209162383030, 0.453140637776817400, 0.453096065258400240, 0.453051491607242900, 0.453006916823456400, 0.452962340907153040, 0.452917763858443790, +0.452873185677440170, 0.452828606364253150, 0.452784025918995030, 0.452739444341776880, 0.452694861632709670, 0.452650277791905750, 0.452605692819476100, 0.452561106715532240, +0.452516519480185180, 0.452471931113547220, 0.452427341615729510, 0.452382750986843380, 0.452338159226999990, 0.452293566336311570, 0.452248972314889250, 0.452204377162844510, +0.452159780880288460, 0.452115183467333310, 0.452070584924090250, 0.452025985250670670, 0.451981384447185770, 0.451936782513747800, 0.451892179450467830, 0.451847575257457450, +0.451802969934827710, 0.451758363482690990, 0.451713755901158360, 0.451669147190340900, 0.451624537350351020, 0.451579926381299730, 0.451535314283298680, 0.451490701056458940, +0.451446086700892810, 0.451401471216711480, 0.451356854604026470, 0.451312236862948970, 0.451267617993591220, 0.451222997996064470, 0.451178376870480180, 0.451133754616949540, +0.451089131235584970, 0.451044506726497540, 0.450999881089798830, 0.450955254325600070, 0.450910626434013530, 0.450865997415150430, 0.450821367269121920, 0.450776735996040460, +0.450732103596017120, 0.450687470069163490, 0.450642835415590800, 0.450598199635411420, 0.450553562728736590, 0.450508924695677770, 0.450464285536346320, 0.450419645250854540, +0.450375003839313610, 0.450330361301835180, 0.450285717638530420, 0.450241072849511810, 0.450196426934890540, 0.450151779894778170, 0.450107131729285960, 0.450062482438526310, +0.450017832022610480, 0.449973180481649640, 0.449928527815756260, 0.449883874025041540, 0.449839219109617160, 0.449794563069594310, 0.449749905905085460, 0.449705247616201900, +0.449660588203055160, 0.449615927665756530, 0.449571266004418550, 0.449526603219152390, 0.449481939310069690, 0.449437274277281750, 0.449392608120901040, 0.449347940841038800, +0.449303272437806660, 0.449258602911316030, 0.449213932261679220, 0.449169260489007630, 0.449124587593412450, 0.449079913575006210, 0.449035238433900200, 0.448990562170206110, +0.448945884784035190, 0.448901206275499950, 0.448856526644711710, 0.448811845891782140, 0.448767164016822600, 0.448722481019945500, 0.448677796901262250, 0.448633111660884430, +0.448588425298923510, 0.448543737815491890, 0.448499049210700880, 0.448454359484662330, 0.448409668637487440, 0.448364976669288760, 0.448320283580177670, 0.448275589370265900, +0.448230894039664710, 0.448186197588486710, 0.448141500016843160, 0.448096801324845530, 0.448052101512606270, 0.448007400580236750, 0.447962698527848760, 0.447917995355553540, +0.447873291063463800, 0.447828585651690810, 0.447783879120346400, 0.447739171469541840, 0.447694462699389780, 0.447649752810001580, 0.447605041801488970, 0.447560329673963360, +0.447515616427537340, 0.447470902062322260, 0.447426186578429920, 0.447381469975971720, 0.447336752255060250, 0.447292033415806920, 0.447247313458323080, 0.447202592382721360, +0.447157870189113130, 0.447113146877610280, 0.447068422448324120, 0.447023696901367340, 0.446978970236851290, 0.446934242454887830, 0.446889513555588370, 0.446844783539065540, +0.446800052405430690, 0.446755320154795740, 0.446710586787272100, 0.446665852302972400, 0.446621116702008050, 0.446576379984490960, 0.446531642150532480, 0.446486903200245260, +0.446442163133740800, 0.446397421951130580, 0.446352679652527170, 0.446307936238042050, 0.446263191707787110, 0.446218446061873770, 0.446173699300414730, 0.446128951423521490, +0.446084202431305810, 0.446039452323879200, 0.445994701101354420, 0.445949948763842860, 0.445905195311456450, 0.445860440744306640, 0.445815685062506130, 0.445770928266166380, +0.445726170355399350, 0.445681411330316470, 0.445636651191030460, 0.445591889937652810, 0.445547127570295460, 0.445502364089069900, 0.445457599494088810, 0.445412833785463700, +0.445368066963306160, 0.445323299027728830, 0.445278529978843260, 0.445233759816761330, 0.445188988541594610, 0.445144216153455840, 0.445099442652456550, 0.445054668038708630, +0.445009892312323630, 0.444965115473414330, 0.444920337522092200, 0.444875558458469210, 0.444830778282656990, 0.444785996994768170, 0.444741214594914390, 0.444696431083207560, +0.444651646459759300, 0.444606860724682250, 0.444562073878088100, 0.444517285920088320, 0.444472496850795760, 0.444427706670321940, 0.444382915378778890, 0.444338122976278120, +0.444293329462932430, 0.444248534838853460, 0.444203739104153120, 0.444158942258943030, 0.444114144303335960, 0.444069345237443570, 0.444024545061377840, 0.443979743775250290, +0.443934941379173830, 0.443890137873259980, 0.443845333257620820, 0.443800527532367930, 0.443755720697614040, 0.443710912753470970, 0.443666103700050110, 0.443621293537464430, +0.443576482265825580, 0.443531669885245450, 0.443486856395835740, 0.443442041797709300, 0.443397226090977810, 0.443352409275753200, 0.443307591352147200, 0.443262772320272560, +0.443217952180241070, 0.443173130932164650, 0.443128308576155040, 0.443083485112324980, 0.443038660540786280, 0.442993834861650890, 0.442949008075030570, 0.442904180181038050, +0.442859351179785140, 0.442814521071383860, 0.442769689855945840, 0.442724857533583980, 0.442680024104410040, 0.442635189568535590, 0.442590353926073600, 0.442545517177135690, +0.442500679321834010, 0.442455840360280240, 0.442411000292587230, 0.442366159118866730, 0.442321316839230870, 0.442276473453791290, 0.442231628962660940, 0.442186783365951520, +0.442141936663775100, 0.442097088856243490, 0.442052239943469540, 0.442007389925564990, 0.441962538802641970, 0.441917686574812170, 0.441872833242188620, 0.441827978804882950, +0.441783123263006890, 0.441738266616673480, 0.441693408865994400, 0.441648550011081780, 0.441603690052047360, 0.441558828989004170, 0.441513966822063900, 0.441469103551338670, +0.441424239176940290, 0.441379373698981730, 0.441334507117574770, 0.441289639432831500, 0.441244770644863730, 0.441199900753784460, 0.441155029759705390, 0.441110157662738810, +0.441065284462996370, 0.441020410160591180, 0.440975534755634950, 0.440930658248239460, 0.440885780638517740, 0.440840901926581540, 0.440796022112543100, 0.440751141196514260, +0.440706259178607900, 0.440661376058935910, 0.440616491837610480, 0.440571606514743420, 0.440526720090447740, 0.440481832564835310, 0.440436943938018240, 0.440392054210108410, +0.440347163381218880, 0.440302271451461450, 0.440257378420948310, 0.440212484289791320, 0.440167589058103490, 0.440122692725996740, 0.440077795293582870, 0.440032896760974900, +0.439987997128284620, 0.439943096395624460, 0.439898194563106080, 0.439853291630842640, 0.439808387598945970, 0.439763482467528330, 0.439718576236701570, 0.439673668906578770, +0.439628760477271840, 0.439583850948892960, 0.439538940321554050, 0.439494028595368240, 0.439449115770447320, 0.439404201846903650, 0.439359286824849040, 0.439314370704396610, +0.439269453485658270, 0.439224535168746270, 0.439179615753772570, 0.439134695240850190, 0.439089773630091110, 0.439044850921607170, 0.438999927115511560, 0.438955002211916080, +0.438910076210933090, 0.438865149112674490, 0.438820220917253480, 0.438775291624781900, 0.438730361235372070, 0.438685429749135940, 0.438640497166186640, 0.438595563486636090, +0.438550628710596630, 0.438505692838180190, 0.438460755869499950, 0.438415817804667820, 0.438370878643796150, 0.438325938386996850, 0.438280997034383110, 0.438236054586066900, +0.438191111042160130, 0.438146166402775980, 0.438101220668026430, 0.438056273838023870, 0.438011325912880170, 0.437966376892708560, 0.437921426777621030, 0.437876475567729910, +0.437831523263147230, 0.437786569863986120, 0.437741615370358550, 0.437696659782376980, 0.437651703100153390, 0.437606745323800890, 0.437561786453431580, 0.437516826489157740, +0.437471865431091510, 0.437426903279345970, 0.437381940034033130, 0.437336975695265140, 0.437292010263155060, 0.437247043737814920, 0.437202076119357190, 0.437157107407893930, +0.437112137603538230, 0.437067166706402220, 0.437022194716598260, 0.436977221634238470, 0.436932247459435990, 0.436887272192302890, 0.436842295832951640, 0.436797318381494220, +0.436752339838043900, 0.436707360202712720, 0.436662379475613150, 0.436617397656857250, 0.436572414746558280, 0.436527430744828250, 0.436482445651779630, 0.436437459467524490, +0.436392472192176080, 0.436347483825846540, 0.436302494368647880, 0.436257503820693390, 0.436212512182095110, 0.436167519452965560, 0.436122525633416860, 0.436077530723562200, +0.436032534723513720, 0.435987537633383880, 0.435942539453284820, 0.435897540183329820, 0.435852539823630980, 0.435807538374300750, 0.435762535835451330, 0.435717532207195890, +0.435672527489646690, 0.435627521682916130, 0.435582514787116400, 0.435537506802360750, 0.435492497728761360, 0.435447487566430310, 0.435402476315480960, 0.435357463976025370, +0.435312450548176190, 0.435267436032045430, 0.435222420427746500, 0.435177403735391540, 0.435132385955093070, 0.435087367086963220, 0.435042347131115340, 0.434997326087661560, +0.434952303956714530, 0.434907280738386300, 0.434862256432790310, 0.434817231040038670, 0.434772204560243900, 0.434727176993518260, 0.434682148339975090, 0.434637118599726540, +0.434592087772884770, 0.434547055859563210, 0.434502022859873990, 0.434456988773929690, 0.434411953601842590, 0.434366917343725960, 0.434321879999692020, 0.434276841569853410, +0.434231802054322270, 0.434186761453212060, 0.434141719766634960, 0.434096676994703500, 0.434051633137529980, 0.434006588195227800, 0.433961542167909110, 0.433916495055686580, +0.433871446858672400, 0.433826397576980050, 0.433781347210721650, 0.433736295760009490, 0.433691243224957000, 0.433646189605676410, 0.433601134902280360, 0.433556079114881090, +0.433511022243591950, 0.433465964288525300, 0.433420905249793760, 0.433375845127509480, 0.433330783921786090, 0.433285721632735650, 0.433240658260470980, 0.433195593805104200, +0.433150528266748880, 0.433105461645517220, 0.433060393941521900, 0.433015325154875230, 0.432970255285690610, 0.432925184334080390, 0.432880112300157160, 0.432835039184033270, +0.432789964985822170, 0.432744889705636180, 0.432699813343587590, 0.432654735899789810, 0.432609657374355250, 0.432564577767396490, 0.432519497079025930, 0.432474415309356990, +0.432429332458502010, 0.432384248526573760, 0.432339163513684450, 0.432294077419947630, 0.432248990245475580, 0.432203901990381110, 0.432158812654776460, 0.432113722238775200, +0.432068630742489630, 0.432023538166032450, 0.431978444509516060, 0.431933349773053920, 0.431888253956758450, 0.431843157060741940, 0.431798059085117920, 0.431752960029998740, +0.431707859895497200, 0.431662758681725540, 0.431617656388797450, 0.431572553016825230, 0.431527448565921570, 0.431482343036198920, 0.431437236427770820, 0.431392128740749610, +0.431347019975248100, 0.431301910131378640, 0.431256799209254750, 0.431211687208988950, 0.431166574130693870, 0.431121459974481980, 0.431076344740466800, 0.431031228428760790, +0.430986111039476320, 0.430940992572726940, 0.430895873028625140, 0.430850752407283600, 0.430805630708814780, 0.430760507933332320, 0.430715384080948560, 0.430670259151776370, +0.430625133145928100, 0.430580006063517430, 0.430534877904656720, 0.430489748669458830, 0.430444618358036160, 0.430399486970502340, 0.430354354506969790, 0.430309220967551360, +0.430264086352359520, 0.430218950661507840, 0.430173813895108780, 0.430128676053275150, 0.430083537136119460, 0.430038397143755360, 0.429993256076295240, 0.429948113933851570, +0.429902970716538050, 0.429857826424467070, 0.429812681057751500, 0.429767534616503850, 0.429722387100837770, 0.429677238510865760, 0.429632088846700620, 0.429586938108454830, +0.429541786296242120, 0.429496633410174970, 0.429451479450366210, 0.429406324416928330, 0.429361168309975060, 0.429316011129618870, 0.429270852875972660, 0.429225693549148910, +0.429180533149261360, 0.429135371676422460, 0.429090209130744690, 0.429045045512341850, 0.428999880821326340, 0.428954715057811190, 0.428909548221908800, 0.428864380313732970, +0.428819211333396180, 0.428774041281011380, 0.428728870156691030, 0.428683697960548950, 0.428638524692697590, 0.428593350353249970, 0.428548174942318560, 0.428502998460017050, +0.428457820906458120, 0.428412642281754570, 0.428367462586019100, 0.428322281819365320, 0.428277099981905830, 0.428231917073753190, 0.428186733095021200, 0.428141548045822330, +0.428096361926269600, 0.428051174736475580, 0.428005986476554020, 0.427960797146617500, 0.427915606746778980, 0.427870415277151030, 0.427825222737847450, 0.427780029128980830, +0.427734834450664130, 0.427689638703009910, 0.427644441886132040, 0.427599244000143040, 0.427554045045155930, 0.427508845021283330, 0.427463643928639000, 0.427418441767335570, +0.427373238537485600, 0.427328034239202960, 0.427282828872600270, 0.427237622437790450, 0.427192414934886190, 0.427147206364001330, 0.427101996725248400, 0.427056786018740530, +0.427011574244590240, 0.426966361402911500, 0.426921147493816770, 0.426875932517419230, 0.426830716473831420, 0.426785499363167230, 0.426740281185539310, 0.426695061941060660, +0.426649841629843930, 0.426604620252003080, 0.426559397807650620, 0.426514174296899640, 0.426468949719862880, 0.426423724076654130, 0.426378497367386090, 0.426333269592171380, +0.426288040751123860, 0.426242810844356280, 0.426197579871981700, 0.426152347834112710, 0.426107114730863320, 0.426061880562346120, 0.426016645328674170, 0.425971409029960280, +0.425926171666318190, 0.425880933237860750, 0.425835693744700930, 0.425790453186951470, 0.425745211564726280, 0.425699968878138100, 0.425654725127299960, 0.425609480312324600, +0.425564234433325970, 0.425518987490416720, 0.425473739483709650, 0.425428490413318590, 0.425383240279356310, 0.425337989081935930, 0.425292736821170190, 0.425247483497173010, +0.425202229110057120, 0.425156973659935660, 0.425111717146921360, 0.425066459571128150, 0.425021200932668820, 0.424975941231656500, 0.424930680468203870, 0.424885418642424960, +0.424840155754432570, 0.424794891804339710, 0.424749626792259250, 0.424704360718305090, 0.424659093582590070, 0.424613825385226910, 0.424568556126329600, 0.424523285806010840, +0.424478014424383930, 0.424432741981561560, 0.424387468477657740, 0.424342193912785270, 0.424296918287057290, 0.424251641600586590, 0.424206363853487200, 0.424161085045871910, +0.424115805177853910, 0.424070524249546000, 0.424025242261062200, 0.423979959212515240, 0.423934675104018440, 0.423889389935684540, 0.423844103707627540, 0.423798816419960310, +0.423753528072795980, 0.423708238666247520, 0.423662948200428770, 0.423617656675452700, 0.423572364091432120, 0.423527070448480980, 0.423481775746712140, 0.423436479986238900, +0.423391183167174060, 0.423345885289631680, 0.423300586353724580, 0.423255286359566000, 0.423209985307268780, 0.423164683196947060, 0.423119380028713580, 0.423074075802681690, +0.423028770518964150, 0.422983464177675130, 0.422938156778927430, 0.422892848322834360, 0.422847538809508760, 0.422802228239064710, 0.422756916611615070, 0.422711603927272810, +0.422666290186151870, 0.422620975388365240, 0.422575659534026150, 0.422530342623247510, 0.422485024656143400, 0.422439705632826790, 0.422394385553410860, 0.422349064418008570, +0.422303742226734060, 0.422258418979700120, 0.422213094677020230, 0.422167769318807120, 0.422122442905175030, 0.422077115436236830, 0.422031786912105800, 0.421986457332894970, +0.421941126698718360, 0.421895795009688930, 0.421850462265919600, 0.421805128467524550, 0.421759793614616680, 0.421714457707309310, 0.421669120745715390, 0.421623782729949050, +0.421578443660123310, 0.421533103536351430, 0.421487762358746350, 0.421442420127422330, 0.421397076842492220, 0.421351732504069430, 0.421306387112266920, 0.421261040667198830, +0.421215693168978170, 0.421170344617718240, 0.421124995013532070, 0.421079644356533780, 0.421034292646836390, 0.420988939884552880, 0.420943586069797430, 0.420898231202682990, +0.420852875283322990, 0.420807518311830390, 0.420762160288319420, 0.420716801212903060, 0.420671441085694650, 0.420626079906807230, 0.420580717676355080, 0.420535354394451060, +0.420489990061208680, 0.420444624676740930, 0.420399258241162030, 0.420353890754585010, 0.420308522217123230, 0.420263152628889750, 0.420217781989998760, 0.420172410300563350, +0.420127037560696910, 0.420081663770512430, 0.420036288930124240, 0.419990913039645310, 0.419945536099188720, 0.419900158108868660, 0.419854779068798260, 0.419809398979090860, +0.419764017839859560, 0.419718635651218640, 0.419673252413281130, 0.419627868126160490, 0.419582482789969740, 0.419537096404823230, 0.419491708970833990, 0.419446320488115420, +0.419400930956780660, 0.419355540376944000, 0.419310148748718530, 0.419264756072217640, 0.419219362347554410, 0.419173967574843260, 0.419128571754197150, 0.419083174885729210, +0.419037776969553740, 0.418992378005783820, 0.418946977994532950, 0.418901576935914290, 0.418856174830042010, 0.418810771677029350, 0.418765367476989720, 0.418719962230036320, +0.418674555936283390, 0.418629148595844050, 0.418583740208831880, 0.418538330775359900, 0.418492920295542530, 0.418447508769492880, 0.418402096197324440, 0.418356682579150370, +0.418311267915084940, 0.418265852205241370, 0.418220435449732810, 0.418175017648673540, 0.418129598802176710, 0.418084178910355870, 0.418038757973324240, 0.417993335991196040, +0.417947912964084570, 0.417902488892103300, 0.417857063775365360, 0.417811637613985210, 0.417766210408075930, 0.417720782157751160, 0.417675352863124020, 0.417629922524308920, +0.417584491141418990, 0.417539058714567810, 0.417493625243868630, 0.417448190729435790, 0.417402755171382420, 0.417357318569822220, 0.417311880924868260, 0.417266442236635060, +0.417221002505235690, 0.417175561730783460, 0.417130119913392720, 0.417084677053176700, 0.417039233150248990, 0.416993788204722770, 0.416948342216712450, 0.416902895186331330, +0.416857447113692940, 0.416811997998910560, 0.416766547842098540, 0.416721096643370200, 0.416675644402839110, 0.416630191120618500, 0.416584736796822790, 0.416539281431565270, +0.416493825024959520, 0.416448367577118840, 0.416402909088157580, 0.416357449558189100, 0.416311988987326580, 0.416266527375684480, 0.416221064723376110, 0.416175601030515040, +0.416130136297214570, 0.416084670523589160, 0.416039203709752060, 0.415993735855817000, 0.415948266961897130, 0.415902797028107060, 0.415857326054559940, 0.415811854041369560, +0.415766380988649100, 0.415720906896513090, 0.415675431765074880, 0.415629955594448040, 0.415584478384745880, 0.415539000136082970, 0.415493520848572550, 0.415448040522327920, +0.415402559157463550, 0.415357076754092840, 0.415311593312329420, 0.415266108832286650, 0.415220623314078940, 0.415175136757819700, 0.415129649163622660, 0.415084160531601080, +0.415038670861869460, 0.414993180154541170, 0.414947688409729950, 0.414902195627549100, 0.414856701808113180, 0.414811206951535500, 0.414765711057929810, 0.414720214127409390, +0.414674716160088890, 0.414629217156081590, 0.414583717115500850, 0.414538216038461190, 0.414492713925076030, 0.414447210775459040, 0.414401706589723640, 0.414356201367984400, +0.414310695110354620, 0.414265187816948100, 0.414219679487878250, 0.414174170123259580, 0.414128659723205510, 0.414083148287829770, 0.414037635817245730, 0.413992122311568010, +0.413946607770910020, 0.413901092195385510, 0.413855575585107830, 0.413810057940191660, 0.413764539260750300, 0.413719019546897600, 0.413673498798746990, 0.413627977016413020, +0.413582454200009050, 0.413536930349648610, 0.413491405465446220, 0.413445879547515330, 0.413400352595969740, 0.413354824610922820, 0.413309295592489300, 0.413263765540782540, +0.413218234455916320, 0.413172702338004130, 0.413127169187160580, 0.413081635003499150, 0.413036099787133570, 0.412990563538177420, 0.412945026256745170, 0.412899487942950450, +0.412853948596906940, 0.412808408218728160, 0.412762866808528810, 0.412717324366422220, 0.412671780892521990, 0.412626236386942680, 0.412580690849797760, 0.412535144281201140, +0.412489596681266280, 0.412444048050107760, 0.412398498387839150, 0.412352947694574310, 0.412307395970426700, 0.412261843215511010, 0.412216289429940710, 0.412170734613829690, +0.412125178767291380, 0.412079621890440560, 0.412034063983390710, 0.411988505046255670, 0.411942945079148970, 0.411897384082185290, 0.411851822055478210, 0.411806258999141140, +0.411760694913288820, 0.411715129798034760, 0.411669563653492890, 0.411623996479776650, 0.411578428277000920, 0.411532859045279030, 0.411487288784725070, 0.411441717495452440, +0.411396145177575890, 0.411350571831209040, 0.411304997456465700, 0.411259422053459500, 0.411213845622305170, 0.411168268163116190, 0.411122689676006570, 0.411077110161089780, +0.411031529618480660, 0.410985948048292690, 0.410940365450639890, 0.410894781825635710, 0.410849197173395020, 0.410803611494031330, 0.410758024787658220, 0.410712437054390420, +0.410666848294341520, 0.410621258507625540, 0.410575667694355990, 0.410530075854647680, 0.410484482988614170, 0.410438889096369500, 0.410393294178027170, 0.410347698233701990, +0.410302101263507580, 0.410256503267557910, 0.410210904245966620, 0.410165304198848450, 0.410119703126316960, 0.410074101028486290, 0.410028497905469910, 0.409982893757382730, +0.409937288584338310, 0.409891682386450240, 0.409846075163833370, 0.409800466916601320, 0.409754857644868130, 0.409709247348747360, 0.409663636028353870, 0.409618023683801350, +0.409572410315203690, 0.409526795922674660, 0.409481180506329030, 0.409435564066280460, 0.409389946602642940, 0.409344328115530180, 0.409298708605056960, 0.409253088071337030, +0.409207466514484360, 0.409161843934612630, 0.409116220331836640, 0.409070595706270130, 0.409024970058026740, 0.408979343387221360, 0.408933715693967580, 0.408888086978379530, +0.408842457240570830, 0.408796826480656410, 0.408751194698749880, 0.408705561894965430, 0.408659928069416640, 0.408614293222218430, 0.408568657353484520, 0.408523020463328950, +0.408477382551865390, 0.408431743619208810, 0.408386103665472840, 0.408340462690771680, 0.408294820695218890, 0.408249177678929490, 0.408203533642017170, 0.408157888584595560, +0.408112242506779630, 0.408066595408683120, 0.408020947290420100, 0.407975298152104370, 0.407929647993850730, 0.407883996815772980, 0.407838344617985290, 0.407792691400601260, +0.407747037163735950, 0.407701381907503050, 0.407655725632016690, 0.407610068337390610, 0.407564410023739780, 0.407518750691177880, 0.407473090339819100, 0.407427428969777240, +0.407381766581167200, 0.407336103174102740, 0.407290438748698020, 0.407244773305066810, 0.407199106843324050, 0.407153439363583500, 0.407107770865959010, 0.407062101350565420, +0.407016430817516650, 0.406970759266926770, 0.406925086698909590, 0.406879413113580110, 0.406833738511052090, 0.406788062891439710, 0.406742386254856810, 0.406696708601418320, +0.406651029931238030, 0.406605350244430230, 0.406559669541108560, 0.406513987821388200, 0.406468305085382840, 0.406422621333206720, 0.406376936564973650, 0.406331250780798630, +0.406285563980795520, 0.406239876165078060, 0.406194187333761340, 0.406148497486959140, 0.406102806624785650, 0.406057114747354790, 0.406011421854781560, 0.405965727947179720, +0.405920033024663620, 0.405874337087346990, 0.405828640135344920, 0.405782942168771310, 0.405737243187740290, 0.405691543192365780, 0.405645842182762780, 0.405600140159045220, +0.405554437121327270, 0.405508733069722850, 0.405463028004347030, 0.405417321925313600, 0.405371614832736480, 0.405325906726730690, 0.405280197607410190, 0.405234487474889160, +0.405188776329281520, 0.405143064170702340, 0.405097350999265470, 0.405051636815085270, 0.405005921618275530, 0.404960205408951390, 0.404914488187226810, 0.404868769953215910, +0.404823050707032730, 0.404777330448792330, 0.404731609178608620, 0.404685886896595900, 0.404640163602868030, 0.404594439297540130, 0.404548713980726170, 0.404502987652540390, +0.404457260313096760, 0.404411531962510400, 0.404365802600895160, 0.404320072228365080, 0.404274340845035160, 0.404228608451019430, 0.404182875046432130, 0.404137140631387280, +0.404091405206000010, 0.404045668770384170, 0.403999931324654170, 0.403954192868923980, 0.403908453403308660, 0.403862712927922200, 0.403816971442878980, 0.403771228948292980, +0.403725485444279220, 0.403679740930951820, 0.403633995408425040, 0.403588248876812830, 0.403542501336230490, 0.403496752786791810, 0.403451003228610880, 0.403405252661802830, +0.403359501086481660, 0.403313748502761750, 0.403267994910757040, 0.403222240310582790, 0.403176484702352900, 0.403130728086181830, 0.403084970462183500, 0.403039211830473200, +0.402993452191164780, 0.402947691544372820, 0.402901929890211170, 0.402856167228795140, 0.402810403560238670, 0.402764638884656190, 0.402718873202161710, 0.402673106512870470, +0.402627338816896440, 0.402581570114353690, 0.402535800405357360, 0.402490029690021570, 0.402444257968460730, 0.402398485240788810, 0.402352711507121100, 0.402306936767571570, +0.402261161022254730, 0.402215384271284560, 0.402169606514776400, 0.402123827752844170, 0.402078047985602370, 0.402032267213165040, 0.401986485435647470, 0.401940702653163670, +0.401894918865828120, 0.401849134073754890, 0.401803348277059160, 0.401757561475855120, 0.401711773670256790, 0.401665984860379350, 0.401620195046337000, 0.401574404228244200, +0.401528612406214900, 0.401482819580364520, 0.401437025750807140, 0.401391230917657100, 0.401345435081028660, 0.401299638241036980, 0.401253840397796210, 0.401208041551420870, +0.401162241702025020, 0.401116440849723980, 0.401070638994631800, 0.401024836136863020, 0.400979032276531750, 0.400933227413753370, 0.400887421548641820, 0.400841614681311800, +0.400795806811877320, 0.400749997940453680, 0.400704188067155080, 0.400658377192095630, 0.400612565315390580, 0.400566752437154170, 0.400520938557500870, 0.400475123676544810, +0.400429307794401330, 0.400383490911184580, 0.400337673027009120, 0.400291854141989090, 0.400246034256239840, 0.400200213369875430, 0.400154391483010570, 0.400108568595759270, +0.400062744708236990, 0.400016919820557810, 0.399971093932836360, 0.399925267045186770, 0.399879439157724390, 0.399833610270563470, 0.399787780383818070, 0.399741949497603610, +0.399696117612034330, 0.399650284727224750, 0.399604450843288990, 0.399558615960342590, 0.399512780078499610, 0.399466943197874680, 0.399421105318581990, 0.399375266440736900, +0.399329426564453690, 0.399283585689846950, 0.399237743817030750, 0.399191900946120670, 0.399146057077230830, 0.399100212210475810, 0.399054366345969860, 0.399008519483828430, +0.398962671624165710, 0.398916822767095840, 0.398870972912734380, 0.398825122061195470, 0.398779270212593740, 0.398733417367043490, 0.398687563524660000, 0.398641708685557710, +0.398595852849851050, 0.398549996017654400, 0.398504138189083200, 0.398458279364251600, 0.398412419543274330, 0.398366558726265580, 0.398320696913340880, 0.398274834104614390, +0.398228970300200820, 0.398183105500214460, 0.398137239704770720, 0.398091372913983890, 0.398045505127968600, 0.397999636346839160, 0.397953766570711020, 0.397907895799698490, +0.397862024033915800, 0.397816151273478470, 0.397770277518500750, 0.397724402769097320, 0.397678527025382480, 0.397632650287471750, 0.397586772555479420, 0.397540893829520130, +0.397495014109708170, 0.397449133396159120, 0.397403251688987210, 0.397357368988307200, 0.397311485294233320, 0.397265600606881150, 0.397219714926364990, 0.397173828252799570, +0.397127940586299130, 0.397082051926979260, 0.397036162274954250, 0.396990271630338450, 0.396944379993247390, 0.396898487363795350, 0.396852593742097080, 0.396806699128266940, +0.396760803522420440, 0.396714906924671980, 0.396669009335136210, 0.396623110753927530, 0.396577211181161460, 0.396531310616952350, 0.396485409061415000, 0.396439506514663700, +0.396393602976814030, 0.396347698447980400, 0.396301792928277500, 0.396255886417819670, 0.396209978916722600, 0.396164070425100550, 0.396118160943067900, 0.396072250470740290, +0.396026339008232030, 0.395980426555657910, 0.395934513113132320, 0.395888598680770920, 0.395842683258687930, 0.395796766846998270, 0.395750849445816290, 0.395704931055257610, +0.395659011675436600, 0.395613091306468050, 0.395567169948466360, 0.395521247601547170, 0.395475324265824820, 0.395429399941414180, 0.395383474628429650, 0.395337548326986870, +0.395291621037200170, 0.395245692759183980, 0.395199763493054020, 0.395153833238924670, 0.395107901996910650, 0.395061969767126540, 0.395016036549687920, 0.394970102344709200, +0.394924167152305160, 0.394878230972590340, 0.394832293805680360, 0.394786355651689620, 0.394740416510733050, 0.394694476382924990, 0.394648535268381120, 0.394602593167215960, +0.394556650079544320, 0.394510706005480600, 0.394464760945140550, 0.394418814898638610, 0.394372867866089600, 0.394326919847608040, 0.394280970843309600, 0.394235020853308690, +0.394189069877719840, 0.394143117916658740, 0.394097164970239830, 0.394051211038577990, 0.394005256121787770, 0.393959300219984760, 0.393913343333283540, 0.393867385461798950, +0.393821426605645450, 0.393775466764938850, 0.393729505939793560, 0.393683544130324470, 0.393637581336646170, 0.393591617558874280, 0.393545652797123390, 0.393499687051508340, +0.393453720322143650, 0.393407752609145070, 0.393361783912627160, 0.393315814232704340, 0.393269843569492410, 0.393223871923105870, 0.393177899293659590, 0.393131925681268260, +0.393085951086047440, 0.393039975508111760, 0.392993998947576200, 0.392948021404555150, 0.392902042879164530, 0.392856063371518740, 0.392810082881732800, 0.392764101409921300, +0.392718118956199900, 0.392672135520683200, 0.392626151103486200, 0.392580165704723370, 0.392534179324510570, 0.392488191962962310, 0.392442203620193160, 0.392396214296318930, +0.392350223991454140, 0.392304232705713800, 0.392258240439212480, 0.392212247192065930, 0.392166252964388780, 0.392120257756296050, 0.392074261567902200, 0.392028264399323150, +0.391982266250673390, 0.391936267122068030, 0.391890267013621510, 0.391844265925449800, 0.391798263857667420, 0.391752260810389330, 0.391706256783730220, 0.391660251777805890, +0.391614245792730910, 0.391568238828620300, 0.391522230885588680, 0.391476221963751920, 0.391430212063224590, 0.391384201184121370, 0.391338189326558010, 0.391292176490649180, +0.391246162676509910, 0.391200147884254830, 0.391154132113999740, 0.391108115365859380, 0.391062097639948700, 0.391016078936382410, 0.390970059255276280, 0.390924038596745070, +0.390878016960903680, 0.390831994347866920, 0.390785970757750510, 0.390739946190669210, 0.390693920646738020, 0.390647894126071650, 0.390601866628785930, 0.390555838154995620, +0.390509808704815220, 0.390463778278360710, 0.390417746875746760, 0.390371714497088520, 0.390325681142500490, 0.390279646812098700, 0.390233611505997780, 0.390187575224312850, +0.390141537967158560, 0.390095499734650850, 0.390049460526904370, 0.390003420344034290, 0.389957379186155200, 0.389911337053383100, 0.389865293945832640, 0.389819249863618930, +0.389773204806856680, 0.389727158775661890, 0.389681111770149140, 0.389635063790433220, 0.389589014836630050, 0.389542964908854370, 0.389496914007221250, 0.389450862131845430, +0.389404809282842880, 0.389358755460328330, 0.389312700664416870, 0.389266644895223220, 0.389220588152863370, 0.389174530437452090, 0.389128471749104480, 0.389082412087935260, +0.389036351454060400, 0.388990289847594710, 0.388944227268653300, 0.388898163717350860, 0.388852099193803420, 0.388806033698125770, 0.388759967230433050, 0.388713899790839980, +0.388667831379462540, 0.388621761996415570, 0.388575691641813770, 0.388529620315773150, 0.388483548018408450, 0.388437474749834920, 0.388391400510167240, 0.388345325299521540, +0.388299249118012500, 0.388253171965755320, 0.388207093842864780, 0.388161014749456970, 0.388114934685646620, 0.388068853651548920, 0.388022771647278660, 0.387976688672951870, +0.387930604728683400, 0.387884519814588380, 0.387838433930781660, 0.387792347077379310, 0.387746259254496020, 0.387700170462246750, 0.387654080700747420, 0.387607989970112870, +0.387561898270458390, 0.387515805601898690, 0.387469711964549930, 0.387423617358526930, 0.387377521783944800, 0.387331425240918510, 0.387285327729564090, 0.387239229249996320, +0.387193129802330450, 0.387147029386681380, 0.387100928003165150, 0.387054825651896580, 0.387008722332990940, 0.386962618046563070, 0.386916512792729090, 0.386870406571603880, +0.386824299383302150, 0.386778191227940160, 0.386732082105632650, 0.386685972016494960, 0.386639860960641900, 0.386593748938189600, 0.386547635949252950, 0.386501521993947220, +0.386455407072387240, 0.386409291184689140, 0.386363174330967840, 0.386317056511338630, 0.386270937725916360, 0.386224817974817110, 0.386178697258155850, 0.386132575576047850, +0.386086452928607990, 0.386040329315952390, 0.385994204738196010, 0.385948079195453710, 0.385901952687841550, 0.385855825215474570, 0.385809696778468050, 0.385763567376936840, +0.385717437010997090, 0.385671305680763800, 0.385625173386352220, 0.385579040127877300, 0.385532905905455190, 0.385486770719200840, 0.385440634569229560, 0.385394497455656240, +0.385348359378597130, 0.385302220338167080, 0.385256080334481500, 0.385209939367655350, 0.385163797437804710, 0.385117654545044600, 0.385071510689490300, 0.385025365871256910, +0.384979220090460430, 0.384933073347215940, 0.384886925641638340, 0.384840776973843890, 0.384794627343947430, 0.384748476752064420, 0.384702325198309820, 0.384656172682799840, +0.384610019205649410, 0.384563864766973910, 0.384517709366888340, 0.384471553005508950, 0.384425395682950640, 0.384379237399328830, 0.384333078154758530, 0.384286917949355930, +0.384240756783236050, 0.384194594656514290, 0.384148431569305670, 0.384102267521726330, 0.384056102513891330, 0.384009936545915640, 0.383963769617915560, 0.383917601730006000, +0.383871432882302520, 0.383825263074919990, 0.383779092307974690, 0.383732920581581700, 0.383686747895856440, 0.383640574250913860, 0.383594399646870250, 0.383548224083840650, +0.383502047561940450, 0.383455870081284790, 0.383409691641989850, 0.383363512244170650, 0.383317331887942700, 0.383271150573420980, 0.383224968300721780, 0.383178785069960230, +0.383132600881251230, 0.383086415734711190, 0.383040229630455090, 0.382994042568598430, 0.382947854549256230, 0.382901665572544850, 0.382855475638579250, 0.382809284747475000, +0.382763092899347120, 0.382716900094311920, 0.382670706332484460, 0.382624511613980260, 0.382578315938914340, 0.382532119307403050, 0.382485921719561420, 0.382439723175505060, +0.382393523675348960, 0.382347323219209450, 0.382301121807201600, 0.382254919439441010, 0.382208716116042620, 0.382162511837122960, 0.382116306602796940, 0.382070100413179790, +0.382023893268387760, 0.381977685168536030, 0.381931476113740060, 0.381885266104115050, 0.381839055139777230, 0.381792843220841780, 0.381746630347424230, 0.381700416519639710, +0.381654201737604500, 0.381607986001433860, 0.381561769311243190, 0.381515551667147730, 0.381469333069263780, 0.381423113517706520, 0.381376893012591480, 0.381330671554033770, +0.381284449142149760, 0.381238225777054680, 0.381192001458863620, 0.381145776187692960, 0.381099549963657860, 0.381053322786873870, 0.381007094657456190, 0.380960865575521170, +0.380914635541183990, 0.380868404554560220, 0.380822172615765060, 0.380775939724914860, 0.380729705882124790, 0.380683471087510440, 0.380637235341187040, 0.380590998643270950, +0.380544760993877350, 0.380498522393121870, 0.380452282841119650, 0.380406042337987140, 0.380359800883839530, 0.380313558478792000, 0.380267315122961020, 0.380221070816461730, +0.380174825559409730, 0.380128579351920290, 0.380082332194109810, 0.380036084086093520, 0.379989835027987000, 0.379943585019905490, 0.379897334061965410, 0.379851082154281980, +0.379804829296970900, 0.379758575490147300, 0.379712320733927690, 0.379666065028427260, 0.379619808373761640, 0.379573550770046120, 0.379527292217397120, 0.379481032715929920, +0.379434772265759720, 0.379388510867002980, 0.379342248519774990, 0.379295985224191330, 0.379249720980367360, 0.379203455788419460, 0.379157189648462960, 0.379110922560613410, +0.379064654524986220, 0.379018385541697760, 0.378972115610863360, 0.378925844732598660, 0.378879572907018960, 0.378833300134240710, 0.378787026414379220, 0.378740751747550120, +0.378694476133868810, 0.378648199573451640, 0.378601922066414020, 0.378555643612871580, 0.378509364212939680, 0.378463083866734720, 0.378416802574372050, 0.378370520335966960, +0.378324237151635990, 0.378277953021494420, 0.378231667945657990, 0.378185381924241950, 0.378139094957362920, 0.378092807045136090, 0.378046518187677260, 0.378000228385101720, +0.377953937637526050, 0.377907645945065540, 0.377861353307835880, 0.377815059725952420, 0.377768765199531790, 0.377722469728689170, 0.377676173313540420, 0.377629875954200780, +0.377583577650786930, 0.377537278403414060, 0.377490978212197630, 0.377444677077254150, 0.377398374998698990, 0.377352071976647880, 0.377305768011216180, 0.377259463102520510, +0.377213157250676170, 0.377166850455798900, 0.377120542718004100, 0.377074234037408360, 0.377027924414127020, 0.376981613848275890, 0.376935302339970360, 0.376888989889326900, +0.376842676496461030, 0.376796362161488430, 0.376750046884524510, 0.376703730665685910, 0.376657413505087970, 0.376611095402846100, 0.376564776359076920, 0.376518456373895750, +0.376472135447418480, 0.376425813579760400, 0.376379490771038270, 0.376333167021367380, 0.376286842330863570, 0.376240516699642260, 0.376194190127820070, 0.376147862615512360, +0.376101534162835040, 0.376055204769903450, 0.376008874436834280, 0.375962543163742890, 0.375916210950745180, 0.375869877797956550, 0.375823543705493590, 0.375777208673471750, +0.375730872702006950, 0.375684535791214520, 0.375638197941211170, 0.375591859152112350, 0.375545519424033410, 0.375499178757091160, 0.375452837151400930, 0.375406494607078590, +0.375360151124239590, 0.375313806703000690, 0.375267461343477220, 0.375221115045785090, 0.375174767810039780, 0.375128419636357960, 0.375082070524855090, 0.375035720475647090, +0.374989369488849310, 0.374943017564578540, 0.374896664702950240, 0.374850310904080270, 0.374803956168084100, 0.374757600495078450, 0.374711243885178850, 0.374664886338500650, +0.374618527855160700, 0.374572168435274410, 0.374525808078957690, 0.374479446786326050, 0.374433084557496240, 0.374386721392583670, 0.374340357291704340, 0.374293992254973670, +0.374247626282508410, 0.374201259374424110, 0.374154891530836700, 0.374108522751861570, 0.374062153037615640, 0.374015782388214260, 0.373969410803773440, 0.373923038284408700, +0.373876664830236740, 0.373830290441373110, 0.373783915117933410, 0.373737538860034300, 0.373691161667791320, 0.373644783541320470, 0.373598404480737220, 0.373552024486158370, +0.373505643557699500, 0.373459261695476500, 0.373412878899604890, 0.373366495170201540, 0.373320110507381950, 0.373273724911262090, 0.373227338381957490, 0.373180950919584980, +0.373134562524260030, 0.373088173196098720, 0.373041782935216560, 0.372995391741730350, 0.372948999615755670, 0.372902606557408090, 0.372856212566804400, 0.372809817644060180, +0.372763421789291390, 0.372717025002613670, 0.372670627284143800, 0.372624228633997360, 0.372577829052290310, 0.372531428539138290, 0.372485027094658140, 0.372438624718965380, +0.372392221412176090, 0.372345817174405850, 0.372299412005771440, 0.372253005906388490, 0.372206598876373080, 0.372160190915840680, 0.372113782024908300, 0.372067372203691400, +0.372020961452306120, 0.371974549770868020, 0.371928137159493910, 0.371881723618299520, 0.371835309147400370, 0.371788893746913370, 0.371742477416954150, 0.371696060157638730, +0.371649641969082730, 0.371603222851403010, 0.371556802804715260, 0.371510381829135540, 0.371463959924779430, 0.371417537091763840, 0.371371113330204390, 0.371324688640217170, +0.371278263021917800, 0.371231836475423180, 0.371185409000849010, 0.371138980598311240, 0.371092551267925670, 0.371046121009809160, 0.370999689824077270, 0.370953257710845810, +0.370906824670231560, 0.370860390702350270, 0.370813955807318020, 0.370767519985250480, 0.370721083236264510, 0.370674645560475860, 0.370628206958000580, 0.370581767428954430, +0.370535326973454200, 0.370488885591615690, 0.370442443283554970, 0.370396000049387720, 0.370349555889230850, 0.370303110803200110, 0.370256664791411620, 0.370210217853981010, +0.370163769991025290, 0.370117321202660170, 0.370070871489001310, 0.370024420850165680, 0.369977969286269030, 0.369931516797427420, 0.369885063383756650, 0.369838609045373580, +0.369792153782394000, 0.369745697594934030, 0.369699240483109430, 0.369652782447037140, 0.369606323486832920, 0.369559863602612840, 0.369513402794492680, 0.369466941062589480, +0.369420478407018920, 0.369374014827897110, 0.369327550325339870, 0.369281084899464210, 0.369234618550385810, 0.369188151278220860, 0.369141683083085090, 0.369095213965095590, +0.369048743924368040, 0.369002272961018170, 0.368955801075163070, 0.368909328266918470, 0.368862854536400550, 0.368816379883725070, 0.368769904309009020, 0.368723427812368220, +0.368676950393918900, 0.368630472053776750, 0.368583992792058830, 0.368537512608880960, 0.368491031504359300, 0.368444549478609660, 0.368398066531749060, 0.368351582663893230, +0.368305097875158530, 0.368258612165660580, 0.368212125535516580, 0.368165637984842250, 0.368119149513753410, 0.368072660122367110, 0.368026169810799160, 0.367979678579165800, +0.367933186427582830, 0.367886693356167300, 0.367840199365035040, 0.367793704454302260, 0.367747208624084830, 0.367700711874499760, 0.367654214205662970, 0.367607715617690570, +0.367561216110698530, 0.367514715684803820, 0.367468214340122330, 0.367421712076770320, 0.367375208894863640, 0.367328704794519290, 0.367282199775853190, 0.367235693838981250, +0.367189186984020420, 0.367142679211086620, 0.367096170520296140, 0.367049660911764830, 0.367003150385609770, 0.366956638941946860, 0.366910126580892280, 0.366863613302562060, +0.366817099107073160, 0.366770583994541540, 0.366724067965083440, 0.366677551018814770, 0.366631033155852660, 0.366584514376312950, 0.366537994680311950, 0.366491474067965510, +0.366444952539390860, 0.366398430094703800, 0.366351906734020240, 0.366305382457457360, 0.366258857265131020, 0.366212331157157510, 0.366165804133652790, 0.366119276194733940, +0.366072747340516920, 0.366026217571118030, 0.365979686886653170, 0.365933155287239520, 0.365886622772993000, 0.365840089344029900, 0.365793555000466180, 0.365747019742418970, +0.365700483570004180, 0.365653946483338210, 0.365607408482536980, 0.365560869567717610, 0.365514329738996110, 0.365467788996488740, 0.365421247340311510, 0.365374704770581590, +0.365328161287414850, 0.365281616890927360, 0.365235071581236190, 0.365188525358457360, 0.365141978222707220, 0.365095430174101730, 0.365048881212758080, 0.365002331338792230, +0.364955780552320530, 0.364909228853458940, 0.364862676242324770, 0.364816122719033850, 0.364769568283702610, 0.364723012936447100, 0.364676456677384410, 0.364629899506630610, +0.364583341424302040, 0.364536782430514740, 0.364490222525385880, 0.364443661709031470, 0.364397099981567440, 0.364350537343111120, 0.364303973793778490, 0.364257409333685890, +0.364210843962949340, 0.364164277681686080, 0.364117710490012180, 0.364071142388043940, 0.364024573375897500, 0.363978003453690020, 0.363931432621537490, 0.363884860879556400, +0.363838288227862790, 0.363791714666573780, 0.363745140195805560, 0.363698564815674470, 0.363651988526296540, 0.363605411327789060, 0.363558833220268110, 0.363512254203849580, +0.363465674278650840, 0.363419093444787960, 0.363372511702377330, 0.363325929051534990, 0.363279345492378230, 0.363232761025023110, 0.363186175649586110, 0.363139589366183290, +0.363093002174931840, 0.363046414075947900, 0.362999825069347970, 0.362953235155248020, 0.362906644333765400, 0.362860052605016190, 0.362813459969116850, 0.362766866426183440, +0.362720271976333270, 0.362673676619682420, 0.362627080356347390, 0.362580483186444200, 0.362533885110090270, 0.362487286127401610, 0.362440686238494290, 0.362394085443485730, +0.362347483742491930, 0.362300881135629420, 0.362254277623014260, 0.362207673204763880, 0.362161067880994280, 0.362114461651822040, 0.362067854517363170, 0.362021246477735150, +0.361974637533053980, 0.361928027683436180, 0.361881416928997950, 0.361834805269856560, 0.361788192706128220, 0.361741579237929320, 0.361694964865376110, 0.361648349588585880, +0.361601733407674760, 0.361555116322758940, 0.361508498333955710, 0.361461879441381250, 0.361415259645152090, 0.361368638945384350, 0.361322017342195430, 0.361275394835701480, +0.361228771426019000, 0.361182147113264240, 0.361135521897554490, 0.361088895779005940, 0.361042268757735150, 0.360995640833858270, 0.360949012007492740, 0.360902382278754650, +0.360855751647760570, 0.360809120114626740, 0.360762487679470560, 0.360715854342408100, 0.360669220103555620, 0.360622584963030460, 0.360575948920948850, 0.360529311977427440, +0.360482674132582280, 0.360436035386530850, 0.360389395739389330, 0.360342755191274290, 0.360296113742302030, 0.360249471392589840, 0.360202828142253960, 0.360156183991411030, +0.360109538940177280, 0.360062892988670000, 0.360016246137005560, 0.359969598385300460, 0.359922949733671000, 0.359876300182234540, 0.359829649731107310, 0.359782998380405620, +0.359736346130246800, 0.359689692980747100, 0.359643038932023210, 0.359596383984191250, 0.359549728137368800, 0.359503071391671980, 0.359456413747217540, 0.359409755204121610, +0.359363095762501690, 0.359316435422474050, 0.359269774184155340, 0.359223112047661770, 0.359176449013110850, 0.359129785080618770, 0.359083120250302260, 0.359036454522277500, +0.358989787896662080, 0.358943120373572120, 0.358896451953124420, 0.358849782635435150, 0.358803112420621790, 0.358756441308800740, 0.358709769300088130, 0.358663096394601480, +0.358616422592457130, 0.358569747893771720, 0.358523072298661480, 0.358476395807244050, 0.358429718419635560, 0.358383040135952850, 0.358336360956312050, 0.358289680880830800, +0.358242999909625330, 0.358196318042812380, 0.358149635280508190, 0.358102951622830350, 0.358056267069895130, 0.358009581621819280, 0.357962895278719000, 0.357916208040711950, +0.357869519907914320, 0.357822830880442530, 0.357776140958414040, 0.357729450141945240, 0.357682758431152770, 0.357636065826152980, 0.357589372327063500, 0.357542677934000520, +0.357495982647080880, 0.357449286466420880, 0.357402589392138090, 0.357355891424348810, 0.357309192563169790, 0.357262492808717360, 0.357215792161109160, 0.357169090620461430, +0.357122388186891020, 0.357075684860514220, 0.357028980641448560, 0.356982275529810540, 0.356935569525716370, 0.356888862629283650, 0.356842154840628810, 0.356795446159868630, +0.356748736587119360, 0.356702026122498680, 0.356655314766122940, 0.356608602518108890, 0.356561889378572970, 0.356515175347632720, 0.356468460425404480, 0.356421744612005150, +0.356375027907551050, 0.356328310312159720, 0.356281591825947710, 0.356234872449031680, 0.356188152181528050, 0.356141431023554440, 0.356094708975227270, 0.356047986036663320, +0.356001262207979010, 0.355954537489291960, 0.355907811880718520, 0.355861085382375150, 0.355814357994379490, 0.355767629716847940, 0.355720900549897360, 0.355674170493644080, +0.355627439548205750, 0.355580707713698870, 0.355533974990240200, 0.355487241377946180, 0.355440506876934460, 0.355393771487321490, 0.355347035209224120, 0.355300298042758700, +0.355253559988042980, 0.355206821045193350, 0.355160081214326630, 0.355113340495559320, 0.355066598889009100, 0.355019856394792390, 0.354973113013025590, 0.354926368743826440, +0.354879623587311340, 0.354832877543597160, 0.354786130612800450, 0.354739382795038750, 0.354692634090428670, 0.354645884499086960, 0.354599134021130140, 0.354552382656675880, +0.354505630405840650, 0.354458877268741370, 0.354412123245494480, 0.354365368336217730, 0.354318612541027530, 0.354271855860040790, 0.354225098293374010, 0.354178339841144880, +0.354131580503469930, 0.354084820280465560, 0.354038059172249620, 0.353991297178938460, 0.353944534300649150, 0.353897770537497990, 0.353851005889602890, 0.353804240357080250, +0.353757473940047030, 0.353710706638619700, 0.353663938452915990, 0.353617169383052430, 0.353570399429145980, 0.353523628591313140, 0.353476856869671620, 0.353430084264337920, +0.353383310775429060, 0.353336536403061510, 0.353289761147353000, 0.353242985008420110, 0.353196207986379300, 0.353149430081348410, 0.353102651293443980, 0.353055871622782900, +0.353009091069481700, 0.352962309633658210, 0.352915527315428970, 0.352868744114910870, 0.352821960032220490, 0.352775175067475630, 0.352728389220792860, 0.352681602492289140, +0.352634814882080930, 0.352588026390286140, 0.352541237017021280, 0.352494446762403320, 0.352447655626548840, 0.352400863609575620, 0.352354070711600240, 0.352307276932739720, +0.352260482273110580, 0.352213686732830600, 0.352166890312016480, 0.352120093010784670, 0.352073294829253040, 0.352026495767538190, 0.351979695825757110, 0.351932895004026360, +0.351886093302463790, 0.351839290721185970, 0.351792487260309930, 0.351745682919952280, 0.351698877700230840, 0.351652071601262160, 0.351605264623163330, 0.351558456766050910, +0.351511648030042810, 0.351464838415255550, 0.351418027921806210, 0.351371216549811350, 0.351324404299388880, 0.351277591170655430, 0.351230777163727580, 0.351183962278723170, +0.351137146515758890, 0.351090329874951760, 0.351043512356418340, 0.350996693960276550, 0.350949874686643070, 0.350903054535634860, 0.350856233507368610, 0.350809411601962220, +0.350762588819532320, 0.350715765160195870, 0.350668940624069670, 0.350622115211271460, 0.350575288921918030, 0.350528461756126340, 0.350481633714013090, 0.350434804795696160, +0.350387975001292210, 0.350341144330917950, 0.350294312784691200, 0.350247480362728680, 0.350200647065147470, 0.350153812892064260, 0.350106977843596900, 0.350060141919862070, +0.350013305120976890, 0.349966467447058060, 0.349919628898223480, 0.349872789474589830, 0.349825949176274190, 0.349779108003393240, 0.349732265956064990, 0.349685423034406030, +0.349638579238533530, 0.349591734568564180, 0.349544889024615890, 0.349498042606805340, 0.349451195315249760, 0.349404347150065740, 0.349357498111371230, 0.349310648199283040, +0.349263797413917780, 0.349216945755393470, 0.349170093223826750, 0.349123239819334850, 0.349076385542034410, 0.349029530392043430, 0.348982674369478610, 0.348935817474457070, +0.348888959707095600, 0.348842101067512180, 0.348795241555823480, 0.348748381172146680, 0.348701519916598530, 0.348654657789296940, 0.348607794790358750, 0.348560930919901090, +0.348514066178040650, 0.348467200564895500, 0.348420334080582320, 0.348373466725217850, 0.348326598498920170, 0.348279729401806020, 0.348232859433992510, 0.348185988595596460, +0.348139116886735820, 0.348092244307527440, 0.348045370858088400, 0.347998496538535540, 0.347951621348986880, 0.347904745289559110, 0.347857868360369530, 0.347810990561534810, +0.347764111893173080, 0.347717232355401030, 0.347670351948335900, 0.347623470672094540, 0.347576588526794850, 0.347529705512553690, 0.347482821629487900, 0.347435936877715460, +0.347389051257353140, 0.347342164768518200, 0.347295277411327430, 0.347248389185898900, 0.347201500092349400, 0.347154610130796130, 0.347107719301355980, 0.347060827604146860, +0.347013935039285740, 0.346967041606889740, 0.346920147307075770, 0.346873252139961790, 0.346826356105664700, 0.346779459204301700, 0.346732561435989680, 0.346685662800846670, +0.346638763298989460, 0.346591862930534960, 0.346544961695601230, 0.346498059594305070, 0.346451156626763730, 0.346404252793094170, 0.346357348093414340, 0.346310442527841100, +0.346263536096491800, 0.346216628799483280, 0.346169720636933520, 0.346122811608959520, 0.346075901715678480, 0.346028990957207290, 0.345982079333663980, 0.345935166845165510, +0.345888253491829110, 0.345841339273771700, 0.345794424191111340, 0.345747508243964890, 0.345700591432449690, 0.345653673756682600, 0.345606755216781750, 0.345559835812863980, +0.345512915545046210, 0.345465994413446550, 0.345419072418181980, 0.345372149559369680, 0.345325225837126550, 0.345278301251570830, 0.345231375802819370, 0.345184449490989420, +0.345137522316197930, 0.345090594278563090, 0.345043665378201750, 0.344996735615231250, 0.344949804989768460, 0.344902873501931610, 0.344855941151837600, 0.344809007939603670, +0.344762073865346850, 0.344715138929185260, 0.344668203131235810, 0.344621266471615450, 0.344574328950442320, 0.344527390567833380, 0.344480451323905980, 0.344433511218777020, +0.344386570252564690, 0.344339628425385960, 0.344292685737358110, 0.344245742188598160, 0.344198797779224300, 0.344151852509353370, 0.344104906379102900, 0.344057959388589680, +0.344011011537932010, 0.343964062827246790, 0.343917113256651420, 0.343870162826262870, 0.343823211536199320, 0.343776259386577740, 0.343729306377515090, 0.343682352509129600, +0.343635397781538230, 0.343588442194858350, 0.343541485749206950, 0.343494528444702240, 0.343447570281461220, 0.343400611259601310, 0.343353651379239400, 0.343306690640493850, +0.343259729043481510, 0.343212766588319840, 0.343165803275125860, 0.343118839104017800, 0.343071874075112640, 0.343024908188527820, 0.342977941444380260, 0.342930973842788310, +0.342884005383868870, 0.342837036067739460, 0.342790065894517050, 0.342743094864319860, 0.342696122977264930, 0.342649150233469310, 0.342602176633051200, 0.342555202176127670, +0.342508226862816120, 0.342461250693233630, 0.342414273667498380, 0.342367295785727440, 0.342320317048038280, 0.342273337454547910, 0.342226357005374630, 0.342179375700635450, +0.342132393540447830, 0.342085410524928800, 0.342038426654196650, 0.341991441928368440, 0.341944456347561650, 0.341897469911893290, 0.341850482621481650, 0.341803494476443810, +0.341756505476896840, 0.341709515622959040, 0.341662524914747410, 0.341615533352379490, 0.341568540935972280, 0.341521547665644190, 0.341474553541512180, 0.341427558563693830, +0.341380562732306160, 0.341333566047467450, 0.341286568509294900, 0.341239570117905900, 0.341192570873417530, 0.341145570775948200, 0.341098569825614870, 0.341051568022535170, +0.341004565366826160, 0.340957561858606100, 0.340910557497992150, 0.340863552285101400, 0.340816546220052140, 0.340769539302961550, 0.340722531533947160, 0.340675522913125970, +0.340628513440616400, 0.340581503116535570, 0.340534491941000940, 0.340487479914129700, 0.340440467036040140, 0.340393453306849450, 0.340346438726675080, 0.340299423295634230, +0.340252407013845240, 0.340205389881425240, 0.340158371898491740, 0.340111353065161880, 0.340064333381554120, 0.340017312847785470, 0.339970291463973120, 0.339923269230235470, +0.339876246146689650, 0.339829222213453240, 0.339782197430643310, 0.339735171798378370, 0.339688145316775440, 0.339641117985952150, 0.339594089806025680, 0.339547060777114380, +0.339500030899335450, 0.339453000172806440, 0.339405968597644490, 0.339358936173968060, 0.339311902901894280, 0.339264868781540720, 0.339217833813024620, 0.339170797996464320, +0.339123761331977020, 0.339076723819680290, 0.339029685459691420, 0.338982646252128710, 0.338935606197109330, 0.338888565294750590, 0.338841523545170830, 0.338794480948487240, +0.338747437504817510, 0.338700393214278690, 0.338653348076989320, 0.338606302093066640, 0.338559255262628140, 0.338512207585791150, 0.338465159062673990, 0.338418109693393980, +0.338371059478068670, 0.338324008416815310, 0.338276956509752310, 0.338229903756996960, 0.338182850158666840, 0.338135795714879170, 0.338088740425752430, 0.338041684291403850, +0.337994627311950680, 0.337947569487511310, 0.337900510818202990, 0.337853451304143460, 0.337806390945449840, 0.337759329742240650, 0.337712267694633140, 0.337665204802744980, +0.337618141066693410, 0.337571076486596900, 0.337524011062572680, 0.337476944794738390, 0.337429877683211370, 0.337382809728110080, 0.337335740929551760, 0.337288671287654050, +0.337241600802534290, 0.337194529474310940, 0.337147457303101250, 0.337100384289022500, 0.337053310432193220, 0.337006235732730700, 0.336959160190752500, 0.336912083806376050, +0.336865006579719790, 0.336817928510901030, 0.336770849600037450, 0.336723769847246280, 0.336676689252646160, 0.336629607816354260, 0.336582525538488390, 0.336535442419165780, +0.336488358458504940, 0.336441273656623240, 0.336394188013638350, 0.336347101529667570, 0.336300014204829470, 0.336252926039241340, 0.336205837033020870, 0.336158747186285410, +0.336111656499153480, 0.336064564971742420, 0.336017472604169530, 0.335970379396553390, 0.335923285349011280, 0.335876190461660950, 0.335829094734619750, 0.335781998168006190, +0.335734900761937680, 0.335687802516531910, 0.335640703431906220, 0.335593603508179130, 0.335546502745468100, 0.335499401143890820, 0.335452298703564580, 0.335405195424608000, +0.335358091307138450, 0.335310986351273710, 0.335263880557131020, 0.335216773924829070, 0.335169666454485200, 0.335122558146216780, 0.335075449000142300, 0.335028339016379240, +0.334981228195045390, 0.334934116536257990, 0.334887004040135720, 0.334839890706795930, 0.334792776536356420, 0.334745661528934530, 0.334698545684648960, 0.334651429003617000, +0.334604311485956480, 0.334557193131784720, 0.334510073941220450, 0.334462953914380970, 0.334415833051384110, 0.334368711352347250, 0.334321588817388990, 0.334274465446626810, +0.334227341240178000, 0.334180216198161300, 0.334133090320694050, 0.334085963607894050, 0.334038836059878770, 0.333991707676766780, 0.333944578458675530, 0.333897448405722830, +0.333850317518026130, 0.333803185795704000, 0.333756053238873920, 0.333708919847653720, 0.333661785622160810, 0.333614650562513830, 0.333567514668830220, 0.333520377941227850, +0.333473240379824120, 0.333426101984737710, 0.333378962756086030, 0.333331822693986920, 0.333284681798557860, 0.333237540069917510, 0.333190397508183300, 0.333143254113472680, +0.333096109885904380, 0.333048964825595760, 0.333001818932664730, 0.332954672207228800, 0.332907524649406540, 0.332860376259315470, 0.332813227037073500, 0.332766076982798030, +0.332718926096607750, 0.332671774378620170, 0.332624621828953190, 0.332577468447724180, 0.332530314235051970, 0.332483159191053980, 0.332436003315848050, 0.332388846609551700, +0.332341689072283670, 0.332294530704161430, 0.332247371505302420, 0.332200211475825400, 0.332153050615847820, 0.332105888925487650, 0.332058726404862340, 0.332011563054090630, +0.331964398873290050, 0.331917233862578430, 0.331870068022073310, 0.331822901351893460, 0.331775733852156310, 0.331728565522979860, 0.331681396364481570, 0.331634226376780250, +0.331587055559993290, 0.331539883914238720, 0.331492711439634050, 0.331445538136298010, 0.331398364004348080, 0.331351189043901870, 0.331304013255078080, 0.331256836637994270, +0.331209659192768400, 0.331162480919517890, 0.331115301818361680, 0.331068121889417140, 0.331020941132802340, 0.330973759548634730, 0.330926577137033220, 0.330879393898115160, +0.330832209831998680, 0.330785024938801240, 0.330737839218641690, 0.330690652671637500, 0.330643465297906720, 0.330596277097566840, 0.330549088070736630, 0.330501898217533780, +0.330454707538075710, 0.330407516032481310, 0.330360323700868150, 0.330313130543354150, 0.330265936560056930, 0.330218741751095220, 0.330171546116586720, 0.330124349656649330, +0.330077152371400670, 0.330029954260959550, 0.329982755325443520, 0.329935555564970620, 0.329888354979658400, 0.329841153569625680, 0.329793951334990120, 0.329746748275869690, +0.329699544392381970, 0.329652339684645750, 0.329605134152778760, 0.329557927796898850, 0.329510720617123780, 0.329463512613572260, 0.329416303786362000, 0.329369094135610550, +0.329321883661436830, 0.329274672363958350, 0.329227460243293190, 0.329180247299558970, 0.329133033532874540, 0.329085818943357530, 0.329038603531126020, 0.328991387296297510, +0.328944170238991030, 0.328896952359324040, 0.328849733657414710, 0.328802514133380630, 0.328755293787340700, 0.328708072619412480, 0.328660850629714120, 0.328613627818363230, +0.328566404185478670, 0.328519179731178060, 0.328471954455579140, 0.328424728358800710, 0.328377501440960510, 0.328330273702176540, 0.328283045142566450, 0.328235815762249140, +0.328188585561342340, 0.328141354539964070, 0.328094122698231960, 0.328046890036264970, 0.327999656554180790, 0.327952422252097480, 0.327905187130132610, 0.327857951188405270, +0.327810714427033020, 0.327763476846133990, 0.327716238445825870, 0.327668999226227550, 0.327621759187456730, 0.327574518329631080, 0.327527276652869630, 0.327480034157289880, +0.327432790843010140, 0.327385546710147970, 0.327338301758822340, 0.327291055989150930, 0.327243809401251920, 0.327196561995242940, 0.327149313771243010, 0.327102064729369760, +0.327054814869741360, 0.327007564192475510, 0.326960312697691160, 0.326913060385506050, 0.326865807256038250, 0.326818553309405570, 0.326771298545726900, 0.326724042965119980, +0.326676786567702940, 0.326629529353593520, 0.326582271322910680, 0.326535012475772210, 0.326487752812295750, 0.326440492332600360, 0.326393231036803730, 0.326345968925023990, +0.326298705997378920, 0.326251442253987500, 0.326204177694967510, 0.326156912320437090, 0.326109646130513910, 0.326062379125317050, 0.326015111304964240, 0.325967842669573680, +0.325920573219263100, 0.325873302954151460, 0.325826031874356600, 0.325778759979996610, 0.325731487271189390, 0.325684213748053790, 0.325636939410707700, 0.325589664259268830, +0.325542388293856230, 0.325495111514587600, 0.325447833921581280, 0.325400555514954890, 0.325353276294827580, 0.325305996261317010, 0.325258715414541540, 0.325211433754618810, +0.325164151281667920, 0.325116867995806640, 0.325069583897153180, 0.325022298985825410, 0.324975013261942220, 0.324927726725621590, 0.324880439376981580, 0.324833151216140040, +0.324785862243216090, 0.324738572458327490, 0.324691281861592020, 0.324643990453128750, 0.324596698233055480, 0.324549405201490500, 0.324502111358551610, 0.324454816704357830, +0.324407521239027000, 0.324360224962677410, 0.324312927875426820, 0.324265629977394280, 0.324218331268697700, 0.324171031749455330, 0.324123731419784900, 0.324076430279805590, +0.324029128329635210, 0.323981825569392030, 0.323934521999193810, 0.323887217619159780, 0.323839912429407630, 0.323792606430055310, 0.323745299621221890, 0.323697992003025240, +0.323650683575583580, 0.323603374339014820, 0.323556064293438030, 0.323508753438971060, 0.323461441775732270, 0.323414129303839390, 0.323366816023411660, 0.323319501934566820, +0.323272187037423280, 0.323224871332098870, 0.323177554818712630, 0.323130237497382570, 0.323082919368226860, 0.323035600431363480, 0.322988280686911490, 0.322940960134988850, +0.322893638775713750, 0.322846316609204150, 0.322798993635579180, 0.322751669854956740, 0.322704345267454670, 0.322657019873192170, 0.322609693672287150, 0.322562366664857880, +0.322515038851022280, 0.322467710230899480, 0.322420380804607390, 0.322373050572264400, 0.322325719533988360, 0.322278387689898420, 0.322231055040112510, 0.322183721584748950, +0.322136387323925690, 0.322089052257761850, 0.322041716386375410, 0.321994379709884650, 0.321947042228407590, 0.321899703942063240, 0.321852364850969740, 0.321805024955244820, +0.321757684255007780, 0.321710342750376580, 0.321663000441469450, 0.321615657328404470, 0.321568313411300710, 0.321520968690276190, 0.321473623165449250, 0.321426276836937810, +0.321378929704861150, 0.321331581769337130, 0.321284233030484150, 0.321236883488420170, 0.321189533143264430, 0.321142181995134830, 0.321094830044149740, 0.321047477290427210, +0.321000123734086370, 0.320952769375245250, 0.320905414214021800, 0.320858058250535210, 0.320810701484903480, 0.320763343917244980, 0.320715985547677720, 0.320668626376320930, +0.320621266403292530, 0.320573905628711020, 0.320526544052694260, 0.320479181675361600, 0.320431818496831000, 0.320384454517220860, 0.320337089736649090, 0.320289724155235100, +0.320242357773096790, 0.320194990590352560, 0.320147622607120430, 0.320100253823519640, 0.320052884239668270, 0.320005513855684650, 0.319958142671686820, 0.319910770687794110, +0.319863397904124440, 0.319816024320795810, 0.319768649937927580, 0.319721274755637720, 0.319673898774044730, 0.319626521993266470, 0.319579144413422390, 0.319531766034630460, +0.319484386857009080, 0.319437006880676330, 0.319389626105751500, 0.319342244532352550, 0.319294862160598050, 0.319247478990605900, 0.319200095022495520, 0.319152710256384920, +0.319105324692392560, 0.319057938330636390, 0.319010551171235830, 0.318963163214308950, 0.318915774459973660, 0.318868384908349400, 0.318820994559554150, 0.318773603413706470, +0.318726211470924280, 0.318678818731327030, 0.318631425195032740, 0.318584030862159860, 0.318536635732826480, 0.318489239807151990, 0.318441843085254360, 0.318394445567252100, +0.318347047253263350, 0.318299648143407330, 0.318252248237802240, 0.318204847536566530, 0.318157446039818330, 0.318110043747676870, 0.318062640660260300, 0.318015236777686730, +0.317967832100075450, 0.317920426627544660, 0.317873020360212750, 0.317825613298197860, 0.317778205441619390, 0.317730796790595400, 0.317683387345244430, 0.317635977105684530, +0.317588566072035170, 0.317541154244414370, 0.317493741622940640, 0.317446328207732160, 0.317398913998908290, 0.317351498996587160, 0.317304083200887270, 0.317256666611926750, +0.317209249229824960, 0.317161831054700080, 0.317114412086670180, 0.317066992325854670, 0.317019571772371670, 0.316972150426339750, 0.316924728287877040, 0.316877305357102900, +0.316829881634135560, 0.316782457119093470, 0.316735031812094840, 0.316687605713259050, 0.316640178822704230, 0.316592751140548970, 0.316545322666911380, 0.316497893401910920, +0.316450463345665730, 0.316403032498294430, 0.316355600859915100, 0.316308168430647190, 0.316260735210608820, 0.316213301199918640, 0.316165866398694760, 0.316118430807056710, +0.316070994425122490, 0.316023557253010400, 0.315976119290839850, 0.315928680538729020, 0.315881240996796490, 0.315833800665160370, 0.315786359543940240, 0.315738917633254180, +0.315691474933220810, 0.315644031443958360, 0.315596587165586250, 0.315549142098222660, 0.315501696241986210, 0.315454249596995140, 0.315406802163368800, 0.315359353941225500, +0.315311904930683840, 0.315264455131861960, 0.315217004544879330, 0.315169553169854230, 0.315122101006904850, 0.315074648056150600, 0.315027194317709760, 0.314979739791700910, +0.314932284478242290, 0.314884828377453410, 0.314837371489452400, 0.314789913814358000, 0.314742455352288400, 0.314694996103363040, 0.314647536067700240, 0.314600075245418610, +0.314552613636636340, 0.314505151241472940, 0.314457688060046700, 0.314410224092476210, 0.314362759338879750, 0.314315293799376840, 0.314267827474085660, 0.314220360363124510, +0.314172892466612840, 0.314125423784669010, 0.314077954317411530, 0.314030484064958810, 0.313983013027430310, 0.313935541204944210, 0.313888068597619310, 0.313840595205573840, +0.313793121028927260, 0.313745646067797870, 0.313698170322304400, 0.313650693792565050, 0.313603216478699430, 0.313555738380825730, 0.313508259499062690, 0.313460779833528600, +0.313413299384342980, 0.313365818151624060, 0.313318336135490650, 0.313270853336060970, 0.313223369753454550, 0.313175885387789730, 0.313128400239184810, 0.313080914307759250, +0.313033427593631450, 0.312985940096920050, 0.312938451817743380, 0.312890962756221020, 0.312843472912471220, 0.312795982286612760, 0.312748490878763940, 0.312700998689044330, +0.312653505717572170, 0.312606011964466250, 0.312558517429844920, 0.312511022113827700, 0.312463526016532930, 0.312416029138079310, 0.312368531478585230, 0.312321033038170210, +0.312273533816952660, 0.312226033815050820, 0.312178533032584300, 0.312131031469671470, 0.312083529126431060, 0.312036026002981410, 0.311988522099442110, 0.311941017415931550, +0.311893511952568370, 0.311846005709471020, 0.311798498686759130, 0.311750990884550940, 0.311703482302965240, 0.311655972942120440, 0.311608462802136170, 0.311560951883130710, +0.311513440185222870, 0.311465927708531040, 0.311418414453174750, 0.311370900419272460, 0.311323385606942500, 0.311275870016304520, 0.311228353647476810, 0.311180836500578260, +0.311133318575727180, 0.311085799873043240, 0.311038280392644750, 0.310990760134650600, 0.310943239099179150, 0.310895717286350020, 0.310848194696281550, 0.310800671329092610, +0.310753147184901600, 0.310705622263828140, 0.310658096565990580, 0.310610570091507830, 0.310563042840498180, 0.310515514813081370, 0.310467986009375810, 0.310420456429499840, +0.310372926073573140, 0.310325394941714130, 0.310277863034041590, 0.310230330350674040, 0.310182796891731060, 0.310135262657331050, 0.310087727647592960, 0.310040191862635090, +0.309992655302577140, 0.309945117967537600, 0.309897579857635220, 0.309850040972988460, 0.309802501313717060, 0.309754960879939370, 0.309707419671774340, 0.309659877689340280, +0.309612334932756970, 0.309564791402142820, 0.309517247097616690, 0.309469702019297020, 0.309422156167303510, 0.309374609541754660, 0.309327062142768780, 0.309279513970465710, +0.309231965024963860, 0.309184415306382130, 0.309136864814838870, 0.309089313550453940, 0.309041761513345670, 0.308994208703633030, 0.308946655121434430, 0.308899100766869610, +0.308851545640057010, 0.308803989741115610, 0.308756433070163760, 0.308708875627321300, 0.308661317412706640, 0.308613758426438680, 0.308566198668635880, 0.308518638139417990, +0.308471076838903570, 0.308423514767210970, 0.308375951924460050, 0.308328388310769250, 0.308280823926257440, 0.308233258771043180, 0.308185692845246220, 0.308138126148984950, +0.308090558682378450, 0.308042990445545060, 0.307995421438604640, 0.307947851661675710, 0.307900281114877110, 0.307852709798327410, 0.307805137712146290, 0.307757564856452390, +0.307709991231364550, 0.307662416837001350, 0.307614841673482520, 0.307567265740926580, 0.307519689039452040, 0.307472111569178700, 0.307424533330225070, 0.307376954322710120, +0.307329374546752350, 0.307281794002471580, 0.307234212689986350, 0.307186630609415530, 0.307139047760877750, 0.307091464144492790, 0.307043879760379110, 0.306996294608655800, +0.306948708689441300, 0.306901122002855460, 0.306853534549016820, 0.306805946328044310, 0.306758357340056520, 0.306710767585173290, 0.306663177063513090, 0.306615585775194990, +0.306567993720337490, 0.306520400899060460, 0.306472807311482350, 0.306425212957721850, 0.306377617837898740, 0.306330021952131600, 0.306282425300539400, 0.306234827883240690, +0.306187229700355330, 0.306139630752001960, 0.306092031038299460, 0.306044430559366420, 0.305996829315322790, 0.305949227306287100, 0.305901624532378290, 0.305854020993715000, +0.305806416690417140, 0.305758811622603150, 0.305711205790392180, 0.305663599193902790, 0.305615991833254770, 0.305568383708566820, 0.305520774819957490, 0.305473165167546630, +0.305425554751452830, 0.305377943571795210, 0.305330331628692280, 0.305282718922263880, 0.305235105452628770, 0.305187491219905850, 0.305139876224213790, 0.305092260465672450, +0.305044643944400510, 0.304997026660516920, 0.304949408614140330, 0.304901789805390620, 0.304854170234386490, 0.304806549901246950, 0.304758928806090570, 0.304711306949037250, +0.304663684330205740, 0.304616060949714550, 0.304568436807683640, 0.304520811904231690, 0.304473186239477670, 0.304425559813540250, 0.304377932626539340, 0.304330304678593620, +0.304282675969822170, 0.304235046500343550, 0.304187416270277790, 0.304139785279743450, 0.304092153528859650, 0.304044521017745040, 0.303996887746519560, 0.303949253715301900, +0.303901618924211080, 0.303853983373365780, 0.303806347062885900, 0.303758709992890230, 0.303711072163497300, 0.303663433574827170, 0.303615794226998410, 0.303568154120130160, +0.303520513254341150, 0.303472871629751280, 0.303425229246479190, 0.303377586104644050, 0.303329942204364490, 0.303282297545760530, 0.303234652128950840, 0.303187005954054460, +0.303139359021190210, 0.303091711330477960, 0.303044062882036450, 0.302996413675984730, 0.302948763712441560, 0.302901112991526940, 0.302853461513359570, 0.302805809278058450, +0.302758156285742490, 0.302710502536531480, 0.302662848030544220, 0.302615192767899440, 0.302567536748717110, 0.302519879973115910, 0.302472222441215080, 0.302424564153133180, +0.302376905108990350, 0.302329245308905260, 0.302281584752997050, 0.302233923441384390, 0.302186261374187410, 0.302138598551524750, 0.302090934973515630, 0.302043270640278750, +0.301995605551934050, 0.301947939708600400, 0.301900273110396910, 0.301852605757442270, 0.301804937649856550, 0.301757268787758490, 0.301709599171266830, 0.301661928800501580, +0.301614257675581530, 0.301566585796625870, 0.301518913163753290, 0.301471239777083840, 0.301423565636736280, 0.301375890742829830, 0.301328215095483240, 0.301280538694816520, +0.301232861540948470, 0.301185183633998210, 0.301137504974084650, 0.301089825561327680, 0.301042145395846170, 0.300994464477759290, 0.300946782807185840, 0.300899100384245890, +0.300851417209058110, 0.300803733281741430, 0.300756048602415840, 0.300708363171200090, 0.300660676988213470, 0.300612990053574670, 0.300565302367403860, 0.300517613929819790, +0.300469924740941700, 0.300422234800888370, 0.300374544109779870, 0.300326852667735010, 0.300279160474873020, 0.300231467531312750, 0.300183773837174150, 0.300136079392576140, +0.300088384197637950, 0.300040688252478370, 0.299992991557217540, 0.299945294111974180, 0.299897595916867600, 0.299849896972016580, 0.299802197277541260, 0.299754496833560480, +0.299706795640192980, 0.299659093697558940, 0.299611391005777160, 0.299563687564966930, 0.299515983375246990, 0.299468278436737570, 0.299420572749557470, 0.299372866313825870, +0.299325159129661730, 0.299277451197185130, 0.299229742516514850, 0.299182033087770250, 0.299134322911070170, 0.299086611986534630, 0.299038900314282650, 0.298991187894433350, +0.298943474727105700, 0.298895760812419750, 0.298848046150494430, 0.298800330741448570, 0.298752614585402250, 0.298704897682474440, 0.298657180032784410, 0.298609461636450970, +0.298561742493594300, 0.298514022604333300, 0.298466301968787210, 0.298418580587074990, 0.298370858459316710, 0.298323135585631280, 0.298275411966137990, 0.298227687600955800, +0.298179962490204790, 0.298132236634003840, 0.298084510032472330, 0.298036782685729140, 0.297989054593894410, 0.297941325757087040, 0.297893596175425880, 0.297845865849031220, +0.297798134778021860, 0.297750402962517200, 0.297702670402636090, 0.297654937098498720, 0.297607203050223980, 0.297559468257931280, 0.297511732721739470, 0.297463996441768740, +0.297416259418138040, 0.297368521650966670, 0.297320783140373580, 0.297273043886478960, 0.297225303889401770, 0.297177563149261250, 0.297129821666176460, 0.297082079440267490, +0.297034336471653340, 0.296986592760452920, 0.296938848306786460, 0.296891103110772880, 0.296843357172531520, 0.296795610492181340, 0.296747863069842580, 0.296700114905634140, +0.296652365999675430, 0.296604616352085400, 0.296556865962984200, 0.296509114832490870, 0.296461362960724780, 0.296413610347804830, 0.296365856993851260, 0.296318102898983080, +0.296270348063319590, 0.296222592486979850, 0.296174836170084050, 0.296127079112751160, 0.296079321315100560, 0.296031562777251230, 0.295983803499323460, 0.295936043481436150, +0.295888282723708320, 0.295840521226260200, 0.295792758989210760, 0.295744996012679400, 0.295697232296785180, 0.295649467841648310, 0.295601702647387720, 0.295553936714122890, +0.295506170041972830, 0.295458402631057710, 0.295410634481496630, 0.295362865593408960, 0.295315095966913690, 0.295267325602131090, 0.295219554499180190, 0.295171782658180390, +0.295124010079250760, 0.295076236762511490, 0.295028462708081640, 0.294980687916080180, 0.294932912386627440, 0.294885136119842410, 0.294837359115844580, 0.294789581374752920, +0.294741802896687670, 0.294694023681768000, 0.294646243730113220, 0.294598463041842400, 0.294550681617075870, 0.294502899455932610, 0.294455116558532130, 0.294407332924993440, +0.294359548555436780, 0.294311763449981330, 0.294263977608746400, 0.294216191031851150, 0.294168403719415830, 0.294120615671559500, 0.294072826888401250, 0.294025037370061300, +0.293977247116658790, 0.293929456128313120, 0.293881664405143410, 0.293833871947270010, 0.293786078754811890, 0.293738284827888550, 0.293690490166619080, 0.293642694771123810, +0.293594898641521830, 0.293547101777932580, 0.293499304180475150, 0.293451505849269930, 0.293403706784435890, 0.293355906986092600, 0.293308106454359120, 0.293260305189355810, +0.293212503191201730, 0.293164700460016410, 0.293116896995918860, 0.293069092799029540, 0.293021287869467460, 0.292973482207351750, 0.292925675812802770, 0.292877868685939620, +0.292830060826881730, 0.292782252235748330, 0.292734442912659710, 0.292686632857734940, 0.292638822071093650, 0.292591010552854860, 0.292543198303138910, 0.292495385322065040, +0.292447571609752650, 0.292399757166320940, 0.292351941991890300, 0.292304126086579740, 0.292256309450508900, 0.292208492083796840, 0.292160673986563980, 0.292112855158929430, +0.292065035601012320, 0.292017215312933060, 0.291969394294810720, 0.291921572546764980, 0.291873750068914810, 0.291825926861380700, 0.291778102924281800, 0.291730278257737620, +0.291682452861867340, 0.291634626736791300, 0.291586799882628760, 0.291538972299499210, 0.291491143987521790, 0.291443314946816910, 0.291395485177503800, 0.291347654679701920, +0.291299823453530500, 0.291251991499109960, 0.291204158816559420, 0.291156325405998060, 0.291108491267546340, 0.291060656401323340, 0.291012820807448720, 0.290964984486041690, +0.290917147437222520, 0.290869309661110520, 0.290821471157825310, 0.290773631927485900, 0.290725791970212870, 0.290677951286125390, 0.290630109875342990, 0.290582267737984960, +0.290534424874171580, 0.290486581284022220, 0.290438736967656370, 0.290390891925193300, 0.290343046156753380, 0.290295199662455820, 0.290247352442419890, 0.290199504496765960, +0.290151655825613310, 0.290103806429081510, 0.290055956307289750, 0.290008105460358550, 0.289960253888407070, 0.289912401591554960, 0.289864548569921440, 0.289816694823626930, +0.289768840352790710, 0.289720985157532360, 0.289673129237971170, 0.289625272594227550, 0.289577415226420780, 0.289529557134670430, 0.289481698319095810, 0.289433838779817320, +0.289385978516954250, 0.289338117530626270, 0.289290255820952520, 0.289242393388053580, 0.289194530232048660, 0.289146666353056970, 0.289098801751199060, 0.289050936426594130, +0.289003070379361900, 0.288955203609621510, 0.288907336117493590, 0.288859467903097300, 0.288811598966552340, 0.288763729307977950, 0.288715858927494680, 0.288667987825221740, +0.288620116001278850, 0.288572243455785250, 0.288524370188861460, 0.288476496200626710, 0.288428621491200800, 0.288380746060702850, 0.288332869909253440, 0.288284993036971910, +0.288237115443977450, 0.288189237130390630, 0.288141358096330740, 0.288093478341917400, 0.288045597867269960, 0.287997716672508950, 0.287949834757753650, 0.287901952123123810, +0.287854068768738590, 0.287806184694718690, 0.287758299901183290, 0.287710414388252180, 0.287662528156044540, 0.287614641204681050, 0.287566753534280960, 0.287518865144963940, +0.287470976036849400, 0.287423086210057800, 0.287375195664708480, 0.287327304400920800, 0.287279412418815220, 0.287231519718511130, 0.287183626300128280, 0.287135732163785910, +0.287087837309604630, 0.287039941737703750, 0.286992045448203000, 0.286944148441221740, 0.286896250716880570, 0.286848352275298700, 0.286800453116596020, 0.286752553240891720, +0.286704652648306470, 0.286656751338959630, 0.286608849312970870, 0.286560946570459610, 0.286513043111546350, 0.286465138936350510, 0.286417234044991860, 0.286369328437589670, +0.286321422114264530, 0.286273515075135880, 0.286225607320323040, 0.286177698849946590, 0.286129789664125890, 0.286081879762980720, 0.286033969146630430, 0.285986057815195590, +0.285938145768795670, 0.285890233007550400, 0.285842319531579070, 0.285794405341002370, 0.285746490435939690, 0.285698574816510730, 0.285650658482834940, 0.285602741435032950, +0.285554823673224100, 0.285506905197528190, 0.285458986008064570, 0.285411066104953930, 0.285363145488315590, 0.285315224158268990, 0.285267302114934780, 0.285219379358432280, +0.285171455888881320, 0.285123531706401310, 0.285075606811112940, 0.285027681203135490, 0.284979754882588860, 0.284931827849592420, 0.284883900104266840, 0.284835971646731520, +0.284788042477106260, 0.284740112595510460, 0.284692182002064810, 0.284644250696888700, 0.284596318680101930, 0.284548385951823970, 0.284500452512175480, 0.284452518361275890, +0.284404583499244520, 0.284356647926202130, 0.284308711642268120, 0.284260774647562390, 0.284212836942204230, 0.284164898526314440, 0.284116959400012360, 0.284069019563417900, +0.284021079016650470, 0.283973137759830800, 0.283925195793078230, 0.283877253116512740, 0.283829309730253610, 0.283781365634421690, 0.283733420829136330, 0.283685475314517430, +0.283637529090684400, 0.283589582157757980, 0.283541634515857620, 0.283493686165102730, 0.283445737105614050, 0.283397787337511090, 0.283349836860913580, 0.283301885675941060, +0.283253933782714300, 0.283205981181352650, 0.283158027871976080, 0.283110073854704050, 0.283062119129657170, 0.283014163696955090, 0.282966207556717530, 0.282918250709064070, +0.282870293154115380, 0.282822334891990930, 0.282774375922810680, 0.282726416246694090, 0.282678455863761830, 0.282630494774133490, 0.282582532977928850, 0.282534570475267530, +0.282486607266270120, 0.282438643351056230, 0.282390678729745330, 0.282342713402458150, 0.282294747369314150, 0.282246780630433350, 0.282198813185935090, 0.282150845035940290, +0.282102876180568340, 0.282054906619939210, 0.282006936354172400, 0.281958965383388660, 0.281910993707707500, 0.281863021327248890, 0.281815048242132270, 0.281767074452478450, +0.281719099958406990, 0.281671124760037750, 0.281623148857490240, 0.281575172250885350, 0.281527194940342450, 0.281479216925981210, 0.281431238207922320, 0.281383258786285340, +0.281335278661190240, 0.281287297832756470, 0.281239316301104880, 0.281191334066355050, 0.281143351128626820, 0.281095367488039870, 0.281047383144714840, 0.280999398098771390, +0.280951412350329440, 0.280903425899508560, 0.280855438746429540, 0.280807450891211900, 0.280759462333975640, 0.280711473074840290, 0.280663483113926690, 0.280615492451354360, +0.280567501087242930, 0.280519509021713130, 0.280471516254884530, 0.280423522786877210, 0.280375528617810620, 0.280327533747805610, 0.280279538176981810, 0.280231541905459130, +0.280183544933357230, 0.280135547260796810, 0.280087548887897550, 0.280039549814779460, 0.279991550041562070, 0.279943549568366150, 0.279895548395311440, 0.279847546522517810, +0.279799543950104920, 0.279751540678193580, 0.279703536706903400, 0.279655532036354350, 0.279607526666666050, 0.279559520597959410, 0.279511513830353890, 0.279463506363969220, +0.279415498198926190, 0.279367489335344390, 0.279319479773343930, 0.279271469513044270, 0.279223458554566430, 0.279175446898029870, 0.279127434543554760, 0.279079421491260640, +0.279031407741268330, 0.278983393293697530, 0.278935378148668260, 0.278887362306300120, 0.278839345766713990, 0.278791328530029470, 0.278743310596366700, 0.278695291965845190, +0.278647272638585850, 0.278599252614708360, 0.278551231894332290, 0.278503210477578590, 0.278455188364566840, 0.278407165555417110, 0.278359142050249090, 0.278311117849183610, +0.278263092952340310, 0.278215067359839310, 0.278167041071800240, 0.278119014088343940, 0.278070986409590160, 0.278022958035658850, 0.277974928966669750, 0.277926899202743770, +0.277878868744000530, 0.277830837590560100, 0.277782805742542220, 0.277734773200067670, 0.277686739963256210, 0.277638706032227510, 0.277590671407102420, 0.277542636088000670, +0.277494600075042340, 0.277446563368347050, 0.277398525968035830, 0.277350487874228280, 0.277302449087044490, 0.277254409606604140, 0.277206369433028230, 0.277158328566436410, +0.277110287006948730, 0.277062244754684880, 0.277014201809765880, 0.276966158172311410, 0.276918113842441470, 0.276870068820275870, 0.276822023105935510, 0.276773976699540130, +0.276725929601209790, 0.276677881811064170, 0.276629833329224250, 0.276581784155809810, 0.276533734290940470, 0.276485683734737200, 0.276437632487319730, 0.276389580548808190, +0.276341527919322260, 0.276293474598982900, 0.276245420587909910, 0.276197365886223340, 0.276149310494042950, 0.276101254411489690, 0.276053197638683300, 0.276005140175743900, +0.275957082022791230, 0.275909023179946310, 0.275860963647328820, 0.275812903425058930, 0.275764842513256340, 0.275716780912042050, 0.275668718621535860, 0.275620655641857390, +0.275572591973127780, 0.275524527615466640, 0.275476462568994160, 0.275428396833830140, 0.275380330410095520, 0.275332263297910110, 0.275284195497394020, 0.275236127008667010, +0.275188057831850130, 0.275139987967063070, 0.275091917414426070, 0.275043846174058860, 0.274995774246082400, 0.274947701630616600, 0.274899628327781480, 0.274851554337696870, +0.274803479660483800, 0.274755404296262050, 0.274707328245151370, 0.274659251507272770, 0.274611174082746050, 0.274563095971691370, 0.274515017174228550, 0.274466937690478640, +0.274418857520561330, 0.274370776664596920, 0.274322695122705130, 0.274274612895007040, 0.274226529981622390, 0.274178446382671410, 0.274130362098273910, 0.274082277128550930, +0.274034191473622290, 0.273986105133608100, 0.273938018108628280, 0.273889930398803830, 0.273841842004254540, 0.273793752925100220, 0.273745663161461930, 0.273697572713459510, +0.273649481581213110, 0.273601389764842660, 0.273553297264469090, 0.273505204080212340, 0.273457110212192540, 0.273409015660529500, 0.273360920425344430, 0.273312824506756980, +0.273264727904887540, 0.273216630619855790, 0.273168532651782920, 0.273120434000788730, 0.273072334666993490, 0.273024234650516890, 0.272976133951480240, 0.272928032570003140, +0.272879930506206070, 0.272831827760208650, 0.272783724332132160, 0.272735620222096350, 0.272687515430221020, 0.272639409956627330, 0.272591303801435150, 0.272543196964764700, +0.272495089446735840, 0.272446981247469690, 0.272398872367086040, 0.272350762805705250, 0.272302652563447100, 0.272254541640432780, 0.272206430036782080, 0.272158317752615340, +0.272110204788052310, 0.272062091143214280, 0.272013976818220930, 0.271965861813192710, 0.271917746128249370, 0.271869629763512140, 0.271821512719100770, 0.271773394995135250, +0.271725276591736620, 0.271677157509024820, 0.271629037747120160, 0.271580917306142420, 0.271532796186212840, 0.271484674387451270, 0.271436551909978010, 0.271388428753912950, +0.271340304919377270, 0.271292180406490780, 0.271244055215373870, 0.271195929346146390, 0.271147802798929530, 0.271099675573843120, 0.271051547671007530, 0.271003419090542650, +0.270955289832569670, 0.270907159897208480, 0.270859029284578890, 0.270810897994802240, 0.270762766027998310, 0.270714633384287420, 0.270666500063789560, 0.270618366066625870, +0.270570231392916300, 0.270522096042781100, 0.270473960016340280, 0.270425823313714950, 0.270377685935025090, 0.270329547880390990, 0.270281409149932590, 0.270233269743771150, +0.270185129662026460, 0.270136988904819020, 0.270088847472268630, 0.270040705364496540, 0.269992562581622740, 0.269944419123767490, 0.269896274991050730, 0.269848130183593770, +0.269799984701516500, 0.269751838544938780, 0.269703691713981950, 0.269655544208765860, 0.269607396029410920, 0.269559247176037020, 0.269511097648765460, 0.269462947447716210, +0.269414796573009540, 0.269366645024765430, 0.269318492803105160, 0.269270339908148640, 0.269222186340016320, 0.269174032098828060, 0.269125877184705150, 0.269077721597767550, +0.269029565338135660, 0.268981408405929430, 0.268933250801270120, 0.268885092524277670, 0.268836933575072050, 0.268788773953774540, 0.268740613660505060, 0.268692452695384050, +0.268644291058531490, 0.268596128750068660, 0.268547965770115530, 0.268499802118792430, 0.268451637796219390, 0.268403472802517700, 0.268355307137807360, 0.268307140802208690, +0.268258973795841790, 0.268210806118827860, 0.268162637771286960, 0.268114468753339390, 0.268066299065105260, 0.268018128706705830, 0.267969957678261040, 0.267921785979890970, +0.267873613611716850, 0.267825440573858650, 0.267777266866436940, 0.267729092489571550, 0.267680917443383900, 0.267632741727993950, 0.267584565343522150, 0.267536388290088470, +0.267488210567814300, 0.267440032176819550, 0.267391853117224740, 0.267343673389149880, 0.267295492992716270, 0.267247311928043910, 0.267199130195253320, 0.267150947794464410, +0.267102764725798580, 0.267054580989375840, 0.267006396585316220, 0.266958211513741050, 0.266910025774770350, 0.266861839368524590, 0.266813652295123770, 0.266765464554689300, +0.266717276147341140, 0.266669087073199750, 0.266620897332385250, 0.266572706925018940, 0.266524515851220890, 0.266476324111111500, 0.266428131704810890, 0.266379938632440420, +0.266331744894120040, 0.266283550489970320, 0.266235355420111290, 0.266187159684664330, 0.266138963283749420, 0.266090766217487170, 0.266042568485997500, 0.265994370089401910, +0.265946171027820370, 0.265897971301372940, 0.265849770910181030, 0.265801569854364710, 0.265753368134044430, 0.265705165749340330, 0.265656962700373760, 0.265608758987264770, +0.265560554610133840, 0.265512349569101140, 0.265464143864287960, 0.265415937495814490, 0.265367730463801130, 0.265319522768368010, 0.265271314409636530, 0.265223105387726700, +0.265174895702759210, 0.265126685354853950, 0.265078474344132450, 0.265030262670714780, 0.264982050334721050, 0.264933837336272570, 0.264885623675489510, 0.264837409352492390, +0.264789194367401340, 0.264740978720337690, 0.264692762411421640, 0.264644545440773650, 0.264596327808513890, 0.264548109514763760, 0.264499890559643290, 0.264451670943273150, +0.264403450665773370, 0.264355229727265440, 0.264307008127869390, 0.264258785867705850, 0.264210562946894880, 0.264162339365557940, 0.264114115123815160, 0.264065890221786670, +0.264017664659593920, 0.263969438437356930, 0.263921211555196380, 0.263872984013232390, 0.263824755811586380, 0.263776526950378450, 0.263728297429729200, 0.263680067249758790, +0.263631836410588630, 0.263583604912338900, 0.263535372755130120, 0.263487139939082520, 0.263438906464317450, 0.263390672330955140, 0.263342437539116180, 0.263294202088920680, +0.263245965980490100, 0.263197729213944580, 0.263149491789404780, 0.263101253706990780, 0.263053014966824090, 0.263004775569024910, 0.262956535513713290, 0.262908294801010800, +0.262860053431037580, 0.262811811403914190, 0.262763568719760860, 0.262715325378699070, 0.262667081380848930, 0.262618836726331070, 0.262570591415265730, 0.262522345447774310, +0.262474098823977040, 0.262425851543994500, 0.262377603607946930, 0.262329355015955780, 0.262281105768141230, 0.262232855864623970, 0.262184605305524070, 0.262136354090963140, +0.262088102221061270, 0.262039849695938740, 0.261991596515717020, 0.261943342680516330, 0.261895088190457260, 0.261846833045660030, 0.261798577246246170, 0.261750320792335840, +0.261702063684049690, 0.261653805921508000, 0.261605547504832230, 0.261557288434142550, 0.261509028709559670, 0.261460768331203800, 0.261412507299196410, 0.261364245613657790, +0.261315983274708510, 0.261267720282468860, 0.261219456637060370, 0.261171192338603200, 0.261122927387217650, 0.261074661783025190, 0.261026395526146040, 0.260978128616700940, +0.260929861054810090, 0.260881592840595030, 0.260833323974175970, 0.260785054455673630, 0.260736784285208190, 0.260688513462901230, 0.260640241988872980, 0.260591969863244120, +0.260543697086134950, 0.260495423657666920, 0.260447149577960340, 0.260398874847135920, 0.260350599465313800, 0.260302323432615720, 0.260254046749161750, 0.260205769415072290, +0.260157491430468790, 0.260109212795471560, 0.260060933510201320, 0.260012653574778320, 0.259964372989324120, 0.259916091753958970, 0.259867809868803590, 0.259819527333978280, +0.259771244149604560, 0.259722960315802720, 0.259674675832693490, 0.259626390700397170, 0.259578104919035270, 0.259529818488728140, 0.259481531409596400, 0.259433243681760460, +0.259384955305341840, 0.259336666280460810, 0.259288376607238080, 0.259240086285794040, 0.259191795316250200, 0.259143503698726850, 0.259095211433344350, 0.259046918520224210, +0.258998624959486780, 0.258950330751252790, 0.258902035895642530, 0.258853740392777640, 0.258805444242778400, 0.258757147445765560, 0.258708850001859390, 0.258660551911181540, +0.258612253173852280, 0.258563953789992420, 0.258515653759722240, 0.258467353083163380, 0.258419051760436110, 0.258370749791661190, 0.258322447176959010, 0.258274143916451150, +0.258225840010257890, 0.258177535458499590, 0.258129230261297920, 0.258080924418773170, 0.258032617931046090, 0.257984310798237030, 0.257936003020467650, 0.257887694597858210, +0.257839385530529600, 0.257791075818602060, 0.257742765462197270, 0.257694454461435570, 0.257646142816437720, 0.257597830527324100, 0.257549517594216350, 0.257501204017234750, +0.257452889796500160, 0.257404574932132920, 0.257356259424254720, 0.257307943272985840, 0.257259626478446630, 0.257211309040758840, 0.257162990960042750, 0.257114672236419210, +0.257066352870008510, 0.257018032860932390, 0.256969712209311200, 0.256921390915265670, 0.256873068978916320, 0.256824746400384660, 0.256776423179791160, 0.256728099317256600, +0.256679774812901380, 0.256631449666847140, 0.256583123879214230, 0.256534797450123590, 0.256486470379695460, 0.256438142668051650, 0.256389814315312440, 0.256341485321598670, +0.256293155687030820, 0.256244825411730440, 0.256196494495818050, 0.256148162939414000, 0.256099830742639920, 0.256051497905616320, 0.256003164428463940, 0.255954830311303230, +0.255906495554255880, 0.255858160157442280, 0.255809824120983300, 0.255761487444999270, 0.255713150129611990, 0.255664812174941860, 0.255616473581109670, 0.255568134348235890, +0.255519794476442190, 0.255471453965849030, 0.255423112816577200, 0.255374771028747170, 0.255326428602480620, 0.255278085537898050, 0.255229741835119760, 0.255181397494267600, +0.255133052515461920, 0.255084706898823680, 0.255036360644473160, 0.254988013752532220, 0.254939666223121200, 0.254891318056361060, 0.254842969252372150, 0.254794619811276270, +0.254746269733193860, 0.254697919018245730, 0.254649567666552390, 0.254601215678235570, 0.254552863053415730, 0.254504509792213730, 0.254456155894750010, 0.254407801361146320, +0.254359446191523120, 0.254311090386000920, 0.254262733944701390, 0.254214376867745010, 0.254166019155252720, 0.254117660807344940, 0.254069301824143450, 0.254020942205768650, +0.253972581952341570, 0.253924221063982550, 0.253875859540813430, 0.253827497382954680, 0.253779134590527140, 0.253730771163651390, 0.253682407102449100, 0.253634042407040850, +0.253585677077547420, 0.253537311114089390, 0.253488944516788550, 0.253440577285765300, 0.253392209421140210, 0.253343840923035020, 0.253295471791570190, 0.253247102026866730, +0.253198731629045050, 0.253150360598226990, 0.253101988934533060, 0.253053616638084120, 0.253005243709000680, 0.252956870147404640, 0.252908495953416360, 0.252860121127156830, +0.252811745668746650, 0.252763369578307470, 0.252714992855959890, 0.252666615501824790, 0.252618237516022750, 0.252569858898675560, 0.252521479649903680, 0.252473099769828120, +0.252424719258569410, 0.252376338116249320, 0.252327956342988380, 0.252279573938907100, 0.252231190904127320, 0.252182807238769570, 0.252134422942954790, 0.252086038016803570, +0.252037652460437630, 0.251989266273977610, 0.251940879457544400, 0.251892492011258520, 0.251844103935241930, 0.251795715229615020, 0.251747325894498830, 0.251698935930013860, +0.251650545336282060, 0.251602154113423850, 0.251553762261560230, 0.251505369780811780, 0.251456976671300400, 0.251408582933146500, 0.251360188566470740, 0.251311793571394990, +0.251263397948039700, 0.251215001696525940, 0.251166604816974230, 0.251118207309506460, 0.251069809174243150, 0.251021410411305320, 0.250973011020813540, 0.250924611002889650, +0.250876210357654230, 0.250827809085228280, 0.250779407185732440, 0.250731004659288440, 0.250682601506016960, 0.250634197726038950, 0.250585793319475060, 0.250537388286447060, +0.250488982627075640, 0.250440576341481310, 0.250392169429785980, 0.250343761892110220, 0.250295353728575090, 0.250246944939301110, 0.250198535524410180, 0.250150125484022930, +0.250101714818260380, 0.250053303527243090, 0.250004891611092960, 0.249956479069930650, 0.249908065903877120, 0.249859652113053000, 0.249811237697580150, 0.249762822657579240, +0.249714406993171270, 0.249665990704476840, 0.249617573791617860, 0.249569156254714960, 0.249520738093889170, 0.249472319309261090, 0.249423899900952650, 0.249375479869084450, +0.249327059213777120, 0.249278637935152590, 0.249230216033331450, 0.249181793508434780, 0.249133370360583200, 0.249084946589898630, 0.249036522196501660, 0.248988097180513430, +0.248939671542054490, 0.248891245281246810, 0.248842818398211040, 0.248794390893068210, 0.248745962765938940, 0.248697534016945220, 0.248649104646207680, 0.248600674653847360, +0.248552244039984940, 0.248503812804742320, 0.248455380948240180, 0.248406948470599160, 0.248358515371941200, 0.248310081652386940, 0.248261647312057470, 0.248213212351073460, +0.248164776769556870, 0.248116340567628320, 0.248067903745408910, 0.248019466303019330, 0.247971028240581510, 0.247922589558216110, 0.247874150256044230, 0.247825710334186540, +0.247777269792765040, 0.247728828631900350, 0.247680386851713560, 0.247631944452325420, 0.247583501433857820, 0.247535057796431480, 0.247486613540167040, 0.247438168665186530, +0.247389723171610560, 0.247341277059560330, 0.247292830329156440, 0.247244382980520930, 0.247195935013774430, 0.247147486429038110, 0.247099037226432640, 0.247050587406080020, +0.247002136968100920, 0.246953685912616490, 0.246905234239747420, 0.246856781949615660, 0.246808329042341980, 0.246759875518047460, 0.246711421376852810, 0.246662966618880070, +0.246614511244249910, 0.246566055253083010, 0.246517598645501430, 0.246469141421625850, 0.246420683581577400, 0.246372225125476820, 0.246323766053446110, 0.246275306365605990, +0.246226846062077590, 0.246178385142981650, 0.246129923608440190, 0.246081461458573900, 0.246032998693503980, 0.245984535313351130, 0.245936071318237360, 0.245887606708283410, +0.245839141483610440, 0.245790675644339210, 0.245742209190591700, 0.245693742122488650, 0.245645274440151270, 0.245596806143700270, 0.245548337233257700, 0.245499867708944270, +0.245451397570880750, 0.245402926819189150, 0.245354455453990260, 0.245305983475405220, 0.245257510883554770, 0.245209037678561000, 0.245160563860544630, 0.245112089429626840, +0.245063614385928390, 0.245015138729571340, 0.244966662460676470, 0.244918185579364930, 0.244869708085757480, 0.244821229979976180, 0.244772751262141850, 0.244724271932375610, +0.244675791990798280, 0.244627311437531890, 0.244578830272697200, 0.244530348496415030, 0.244481866108807400, 0.244433383109995130, 0.244384899500099400, 0.244336415279240960, +0.244287930447541930, 0.244239445005123100, 0.244190958952105630, 0.244142472288610330, 0.244093985014759290, 0.244045497130673280, 0.243997008636473530, 0.243948519532280830, +0.243900029818217260, 0.243851539494403640, 0.243803048560961130, 0.243754557018010580, 0.243706064865674090, 0.243657572104072410, 0.243609078733326380, 0.243560584753558100, +0.243512090164888340, 0.243463594967438360, 0.243415099161328970, 0.243366602746682230, 0.243318105723619030, 0.243269608092260530, 0.243221109852727600, 0.243172611005142310, +0.243124111549625520, 0.243075611486298420, 0.243027110815281860, 0.242978609536697980, 0.242930107650667550, 0.242881605157311890, 0.242833102056751740, 0.242784598349109290, +0.242736094034505360, 0.242687589113061150, 0.242639083584897580, 0.242590577450136710, 0.242542070708899380, 0.242493563361306480, 0.242445055407480100, 0.242396546847541060, +0.242348037681610650, 0.242299527909809710, 0.242251017532260420, 0.242202506549083570, 0.242153994960400440, 0.242105482766331900, 0.242056969967000070, 0.242008456562525840, +0.241959942553030440, 0.241911427938634790, 0.241862912719460980, 0.241814396895629890, 0.241765880467262800, 0.241717363434480580, 0.241668845797405380, 0.241620327556158090, +0.241571808710859540, 0.241523289261631880, 0.241474769208596010, 0.241426248551873220, 0.241377727291584350, 0.241329205427851630, 0.241280682960795880, 0.241232159890538420, +0.241183636217200150, 0.241135111940903200, 0.241086587061768500, 0.241038061579917310, 0.240989535495470530, 0.240941008808550320, 0.240892481519277640, 0.240843953627773720, +0.240795425134159500, 0.240746896038557150, 0.240698366341087540, 0.240649836041871600, 0.240601305141031510, 0.240552773638688130, 0.240504241534962830, 0.240455708829976520, +0.240407175523851320, 0.240358641616708220, 0.240310107108668510, 0.240261571999853100, 0.240213036290384180, 0.240164499980382670, 0.240115963069969930, 0.240067425559266830, +0.240018887448395610, 0.239970348737477160, 0.239921809426632850, 0.239873269515983560, 0.239824729005651550, 0.239776187895757720, 0.239727646186423000, 0.239679103877769580, +0.239630560969918390, 0.239582017462990820, 0.239533473357107760, 0.239484928652391430, 0.239436383348962810, 0.239387837446943220, 0.239339290946453620, 0.239290743847616200, +0.239242196150551920, 0.239193647855382160, 0.239145098962227850, 0.239096549471211230, 0.239047999382453250, 0.238999448696075260, 0.238950897412198190, 0.238902345530944330, +0.238853793052434590, 0.238805239976790400, 0.238756686304132660, 0.238708132034583630, 0.238659577168264280, 0.238611021705295550, 0.238562465645799690, 0.238513908989897690, +0.238465351737710880, 0.238416793889360300, 0.238368235444968160, 0.238319676404655400, 0.238271116768543480, 0.238222556536753340, 0.238173995709407200, 0.238125434286626110, +0.238076872268531410, 0.238028309655244130, 0.237979746446886460, 0.237931182643579460, 0.237882618245444520, 0.237834053252602570, 0.237785487665175900, 0.237736921483285540, +0.237688354707052460, 0.237639787336598910, 0.237591219372045890, 0.237542650813514810, 0.237494081661126680, 0.237445511915003790, 0.237396941575267110, 0.237348370642038060, +0.237299799115437670, 0.237251226995588200, 0.237202654282610700, 0.237154080976626520, 0.237105507077756740, 0.237056932586123590, 0.237008357501848150, 0.236959781825051790, +0.236911205555855540, 0.236862628694381710, 0.236814051240751330, 0.236765473195085370, 0.236716894557506160, 0.236668315328134730, 0.236619735507092480, 0.236571155094500500, +0.236522574090481020, 0.236473992495155130, 0.236425410308644250, 0.236376827531069420, 0.236328244162552960, 0.236279660203215890, 0.236231075653179660, 0.236182490512565320, +0.236133904781495180, 0.236085318460090260, 0.236036731548472050, 0.235988144046761610, 0.235939555955081200, 0.235890967273551940, 0.235842378002295240, 0.235793788141432150, +0.235745197691085040, 0.235696606651374930, 0.235648015022422890, 0.235599422804351230, 0.235550829997281000, 0.235502236601333710, 0.235453642616630380, 0.235405048043293400, +0.235356452881443800, 0.235307857131203060, 0.235259260792692220, 0.235210663866033680, 0.235162066351348480, 0.235113468248758120, 0.235064869558383650, 0.235016270280347470, +0.234967670414770570, 0.234919069961774530, 0.234870468921480360, 0.234821867294010440, 0.234773265079485870, 0.234724662278027710, 0.234676058889758320, 0.234627454914798780, +0.234578850353270580, 0.234530245205294860, 0.234481639470993960, 0.234433033150488940, 0.234384426243901350, 0.234335818751352260, 0.234287210672964040, 0.234238602008857790, +0.234189992759155060, 0.234141382923976900, 0.234092772503445730, 0.234044161497682620, 0.233995549906809100, 0.233946937730946300, 0.233898324970216560, 0.233849711624741020, +0.233801097694640750, 0.233752483180038190, 0.233703868081054420, 0.233655252397810960, 0.233606636130428950, 0.233558019279030800, 0.233509401843737590, 0.233460783824670860, +0.233412165221951740, 0.233363546035702670, 0.233314926266044690, 0.233266305913099440, 0.233217684976987970, 0.233169063457832700, 0.233120441355754800, 0.233071818670875790, +0.233023195403316810, 0.232974571553200250, 0.232925947120647290, 0.232877322105779020, 0.232828696508717880, 0.232780070329584980, 0.232731443568501920, 0.232682816225589810, +0.232634188300971100, 0.232585559794766920, 0.232536930707098830, 0.232488301038087990, 0.232439670787856820, 0.232391039956526490, 0.232342408544218530, 0.232293776551054150, +0.232245143977155730, 0.232196510822644480, 0.232147877087641950, 0.232099242772269290, 0.232050607876648940, 0.232001972400902090, 0.231953336345150310, 0.231904699709514740, +0.231856062494117860, 0.231807424699080830, 0.231758786324524790, 0.231710147370572240, 0.231661507837344290, 0.231612867724962620, 0.231564227033548310, 0.231515585763223870, +0.231466943914110460, 0.231418301486329720, 0.231369658480002770, 0.231321014895252110, 0.231272370732198920, 0.231223725990964770, 0.231175080671670920, 0.231126434774439780, +0.231077788299392540, 0.231029141246650860, 0.230980493616335880, 0.230931845408570090, 0.230883196623474670, 0.230834547261170860, 0.230785897321781120, 0.230737246805426620, +0.230688595712228990, 0.230639944042309450, 0.230591291795790490, 0.230542638972793280, 0.230493985573439500, 0.230445331597850300, 0.230396677046148220, 0.230348021918454440, +0.230299366214890610, 0.230250709935577920, 0.230202053080638900, 0.230153395650194740, 0.230104737644367120, 0.230056079063277190, 0.230007419907047510, 0.229958760175799280, +0.229910099869653690, 0.229861438988733320, 0.229812777533159320, 0.229764115503053400, 0.229715452898536760, 0.229666789719731900, 0.229618125966760090, 0.229569461639742960, +0.229520796738801710, 0.229472131264058940, 0.229423465215635840, 0.229374798593654060, 0.229326131398234850, 0.229277463629500770, 0.229228795287573010, 0.229180126372573260, +0.229131456884622780, 0.229082786823844060, 0.229034116190358410, 0.228985444984287440, 0.228936773205752430, 0.228888100854875930, 0.228839427931779170, 0.228790754436583420, +0.228742080369411180, 0.228693405730383770, 0.228644730519622860, 0.228596054737249670, 0.228547378383386760, 0.228498701458155430, 0.228450023961677350, 0.228401345894073770, +0.228352667255467240, 0.228303988045979070, 0.228255308265730930, 0.228206627914844060, 0.228157946993441080, 0.228109265501643200, 0.228060583439572200, 0.228011900807349260, +0.227963217605097020, 0.227914533832936750, 0.227865849490989700, 0.227817164579378480, 0.227768479098224340, 0.227719793047648970, 0.227671106427773720, 0.227622419238721120, +0.227573731480612500, 0.227525043153569530, 0.227476354257713510, 0.227427664793167030, 0.227378974760051420, 0.227330284158488350, 0.227281592988599150, 0.227232901250506410, +0.227184208944331390, 0.227135516070195860, 0.227086822628221110, 0.227038128618529730, 0.226989434041243030, 0.226940738896482310, 0.226892043184370170, 0.226843346905027940, +0.226794650058577350, 0.226745952645139690, 0.226697254664837560, 0.226648556117792330, 0.226599857004125690, 0.226551157323958970, 0.226502457077414790, 0.226453756264614480, +0.226405054885679770, 0.226356352940732000, 0.226307650429893760, 0.226258947353286420, 0.226210243711031680, 0.226161539503250940, 0.226112834730066740, 0.226064129391600480, +0.226015423487973460, 0.225966717019308320, 0.225918009985726390, 0.225869302387349420, 0.225820594224298760, 0.225771885496697050, 0.225723176204665640, 0.225674466348326270, +0.225625755927800320, 0.225577044943210400, 0.225528333394677870, 0.225479621282324520, 0.225430908606271680, 0.225382195366642000, 0.225333481563556810, 0.225284767197137940, +0.225236052267506700, 0.225187336774785780, 0.225138620719096520, 0.225089904100560710, 0.225041186919299700, 0.224992469175436140, 0.224943750869091410, 0.224895032000386880, +0.224846312569445210, 0.224797592576387760, 0.224748872021336310, 0.224700150904412250, 0.224651429225738270, 0.224602706985435690, 0.224553984183626380, 0.224505260820431650, +0.224456536895974200, 0.224407812410375410, 0.224359087363757060, 0.224310361756240610, 0.224261635587948650, 0.224212908859002640, 0.224164181569524330, 0.224115453719635120, +0.224066725309457730, 0.224017996339113540, 0.223969266808723890, 0.223920536718411530, 0.223871806068297850, 0.223823074858504610, 0.223774343089153280, 0.223725610760366510, +0.223676877872265730, 0.223628144424972720, 0.223579410418608960, 0.223530675853297080, 0.223481940729158500, 0.223433205046315090, 0.223384468804888240, 0.223335732005000650, +0.223286994646773710, 0.223238256730329290, 0.223189518255788810, 0.223140779223274970, 0.223092039632909160, 0.223043299484812830, 0.222994558779108680, 0.222945817515918130, +0.222897075695363040, 0.222848333317564820, 0.222799590382646210, 0.222750846890728630, 0.222702102841933920, 0.222653358236383550, 0.222604613074200180, 0.222555867355505280, +0.222507121080420730, 0.222458374249067950, 0.222409626861569650, 0.222360878918047290, 0.222312130418622720, 0.222263381363417420, 0.222214631752554070, 0.222165881586154160, +0.222117130864339540, 0.222068379587231630, 0.222019627754953240, 0.221970875367625780, 0.221922122425370680, 0.221873368928310720, 0.221824614876567350, 0.221775860270262410, +0.221727105109517430, 0.221678349394455080, 0.221629593125196890, 0.221580836301864700, 0.221532078924579990, 0.221483320993465520, 0.221434562508642710, 0.221385803470233540, +0.221337043878359400, 0.221288283733143100, 0.221239523034706090, 0.221190761783170260, 0.221141999978657110, 0.221093237621289380, 0.221044474711188570, 0.220995711248476140, +0.220946947233274850, 0.220898182665706180, 0.220849417545892070, 0.220800651873954010, 0.220751885650014720, 0.220703118874195720, 0.220654351546618940, 0.220605583667405820, +0.220556815236679190, 0.220508046254560520, 0.220459276721171740, 0.220410506636634330, 0.220361736001071090, 0.220312964814603520, 0.220264193077353510, 0.220215420789442620, +0.220166647950993580, 0.220117874562127950, 0.220069100622967170, 0.220020326133634090, 0.219971551094250180, 0.219922775504937410, 0.219873999365817250, 0.219825222677012540, +0.219776445438644770, 0.219727667650835870, 0.219678889313707380, 0.219630110427382120, 0.219581330991981540, 0.219532551007627670, 0.219483770474441980, 0.219434989392547300, +0.219386207762065130, 0.219337425583117470, 0.219288642855825780, 0.219239859580312950, 0.219191075756700440, 0.219142291385110270, 0.219093506465663920, 0.219044720998484240, +0.218995934983692740, 0.218947148421411000, 0.218898361311761800, 0.218849573654866710, 0.218800785450847690, 0.218751996699826260, 0.218703207401925280, 0.218654417557266280, +0.218605627165971230, 0.218556836228161690, 0.218508044743960460, 0.218459252713489150, 0.218410460136869710, 0.218361667014223690, 0.218312873345673920, 0.218264079131341960, +0.218215284371349820, 0.218166489065819040, 0.218117693214872450, 0.218068896818631650, 0.218020099877218150, 0.217971302390754850, 0.217922504359363280, 0.217873705783165480, +0.217824906662282940, 0.217776106996838610, 0.217727306786953980, 0.217678506032751100, 0.217629704734351500, 0.217580902891878090, 0.217532100505452440, 0.217483297575196490, +0.217434494101231920, 0.217385690083681500, 0.217336885522666890, 0.217288080418310050, 0.217239274770732570, 0.217190468580057330, 0.217141661846405960, 0.217092854569899960, +0.217044046750662270, 0.216995238388814460, 0.216946429484478560, 0.216897620037776160, 0.216848810048830140, 0.216799999517762080, 0.216751188444694040, 0.216702376829747580, +0.216653564673045640, 0.216604751974709740, 0.216555938734862010, 0.216507124953623980, 0.216458310631118560, 0.216409495767467370, 0.216360680362792430, 0.216311864417215390, +0.216263047930859100, 0.216214230903845170, 0.216165413336295270, 0.216116595228332240, 0.216067776580077730, 0.216018957391653780, 0.215970137663182020, 0.215921317394785320, +0.215872496586585360, 0.215823675238704130, 0.215774853351263280, 0.215726030924385750, 0.215677207958193120, 0.215628384452807490, 0.215579560408350470, 0.215530735824944950, +0.215481910702712610, 0.215433085041775500, 0.215384258842255230, 0.215335432104274750, 0.215286604827955700, 0.215237777013420150, 0.215188948660789690, 0.215140119770187320, +0.215091290341734630, 0.215042460375553270, 0.214993629871766230, 0.214944798830495080, 0.214895967251861970, 0.214847135135988490, 0.214798302482997610, 0.214749469293010950, +0.214700635566150650, 0.214651801302538300, 0.214602966502296900, 0.214554131165548080, 0.214505295292413940, 0.214456458883016090, 0.214407621937477560, 0.214358784455919970, +0.214309946438465430, 0.214261107885235590, 0.214212268796353380, 0.214163429171940530, 0.214114589012118660, 0.214065748317010750, 0.214016907086738480, 0.213968065321423960, +0.213919223021188790, 0.213870380186156030, 0.213821536816447330, 0.213772692912184760, 0.213723848473490050, 0.213675003500486150, 0.213626157993294740, 0.213577311952037910, +0.213528465376837400, 0.213479618267816140, 0.213430770625095830, 0.213381922448798610, 0.213333073739046140, 0.213284224495961410, 0.213235374719666140, 0.213186524410281990, +0.213137673567931950, 0.213088822192737750, 0.213039970284821490, 0.212991117844304860, 0.212942264871310880, 0.212893411365961240, 0.212844557328378060, 0.212795702758683060, +0.212746847656999220, 0.212697992023448270, 0.212649135858152370, 0.212600279161233170, 0.212551421932813710, 0.212502564173015690, 0.212453705881961250, 0.212404847059772140, +0.212355987706571330, 0.212307127822480540, 0.212258267407621940, 0.212209406462117250, 0.212160544986089470, 0.212111682979660320, 0.212062820442951520, 0.212013957376086140, +0.211965093779185820, 0.211916229652372810, 0.211867364995768750, 0.211818499809496740, 0.211769634093678470, 0.211720767848436130, 0.211671901073891420, 0.211623033770167390, +0.211574165937385790, 0.211525297575668760, 0.211476428685138080, 0.211427559265916720, 0.211378689318126480, 0.211329818841889530, 0.211280947837327590, 0.211232076304563730, +0.211183204243719640, 0.211134331654917130, 0.211085458538279230, 0.211036584893927680, 0.210987710721984660, 0.210938836022571930, 0.210889960795812570, 0.210841085041828270, +0.210792208760741280, 0.210743331952673340, 0.210694454617747500, 0.210645576756085500, 0.210596698367809590, 0.210547819453041460, 0.210498940011904250, 0.210450060044519690, +0.210401179551009950, 0.210352298531496870, 0.210303416986103440, 0.210254534914951500, 0.210205652318162770, 0.210156769195860320, 0.210107885548165980, 0.210059001375201920, +0.210010116677089940, 0.209961231453953070, 0.209912345705913130, 0.209863459433092340, 0.209814572635612460, 0.209765685313596570, 0.209716797467166480, 0.209667909096444390, +0.209619020201552100, 0.209570130782612690, 0.209521240839747960, 0.209472350373080120, 0.209423459382730990, 0.209374567868823610, 0.209325675831479850, 0.209276783270821440, +0.209227890186971490, 0.209178996580051850, 0.209130102450184710, 0.209081207797491870, 0.209032312622096460, 0.208983416924120260, 0.208934520703685510, 0.208885623960914010, +0.208836726695928930, 0.208787828908852000, 0.208738930599805500, 0.208690031768911240, 0.208641132416292340, 0.208592232542070600, 0.208543332146368300, 0.208494431229307220, +0.208445529791010500, 0.208396627831599960, 0.208347725351197830, 0.208298822349925970, 0.208249918827907500, 0.208201014785264200, 0.208152110222117960, 0.208103205138591870, +0.208054299534807750, 0.208005393410887920, 0.207956486766954140, 0.207907579603129580, 0.207858671919536080, 0.207809763716295890, 0.207760854993530860, 0.207711945751364150, +0.207663035989917530, 0.207614125709313370, 0.207565214909673420, 0.207516303591120890, 0.207467391753777600, 0.207418479397765840, 0.207369566523207430, 0.207320653130225550, +0.207271739218942010, 0.207222824789478700, 0.207173909841958770, 0.207124994376504080, 0.207076078393236880, 0.207027161892279070, 0.206978244873753770, 0.206929327337782850, +0.206880409284488640, 0.206831490713992950, 0.206782571626419000, 0.206733652021888590, 0.206684731900524050, 0.206635811262447260, 0.206586890107781390, 0.206537968436648260, +0.206489046249170250, 0.206440123545469150, 0.206391200325668180, 0.206342276589889240, 0.206293352338254160, 0.206244427570886120, 0.206195502287907010, 0.206146576489439150, +0.206097650175604440, 0.206048723346526020, 0.205999796002325790, 0.205950868143126050, 0.205901939769048750, 0.205853010880216990, 0.205804081476752720, 0.205755151558778240, +0.205706221126415480, 0.205657290179787570, 0.205608358719016450, 0.205559426744224420, 0.205510494255533390, 0.205461561253066580, 0.205412627736945850, 0.205363693707293540, +0.205314759164231590, 0.205265824107883130, 0.205216888538370140, 0.205167952455814510, 0.205119015860339430, 0.205070078752066790, 0.205021141131118940, 0.204972202997617840, +0.204923264351686650, 0.204874325193447280, 0.204825385523022120, 0.204776445340533080, 0.204727504646103340, 0.204678563439854830, 0.204629621721909930, 0.204580679492390530, +0.204531736751419860, 0.204482793499119850, 0.204433849735612880, 0.204384905461020810, 0.204335960675466940, 0.204287015379073180, 0.204238069571961420, 0.204189123254254920, +0.204140176426075630, 0.204091229087545900, 0.204042281238787650, 0.203993332879924130, 0.203944384011077280, 0.203895434632369480, 0.203846484743922640, 0.203797534345860040, +0.203748583438303600, 0.203699632021375700, 0.203650680095198290, 0.203601727659894620, 0.203552774715586610, 0.203503821262396690, 0.203454867300446760, 0.203405912829860090, +0.203356957850758660, 0.203308002363264410, 0.203259046367500560, 0.203210089863589100, 0.203161132851652440, 0.203112175331812470, 0.203063217304192520, 0.203014258768914550, +0.202965299726100920, 0.202916340175873590, 0.202867380118355840, 0.202818419553669670, 0.202769458481937420, 0.202720496903281090, 0.202671534817823960, 0.202622572225688020, +0.202573609126995620, 0.202524645521868770, 0.202475681410430740, 0.202426716792803500, 0.202377751669109040, 0.202328786039470660, 0.202279819904010280, 0.202230853262850370, +0.202181886116112870, 0.202132918463921120, 0.202083950306397030, 0.202034981643663100, 0.201986012475841280, 0.201937042803054860, 0.201888072625425820, 0.201839101943076610, +0.201790130756129230, 0.201741159064706910, 0.201692186868931730, 0.201643214168926080, 0.201594240964811930, 0.201545267256712650, 0.201496293044750200, 0.201447318329047000, +0.201398343109725070, 0.201349367386907700, 0.201300391160716930, 0.201251414431274760, 0.201202437198704480, 0.201153459463128100, 0.201104481224668090, 0.201055502483446420, +0.201006523239586450, 0.200957543493210160, 0.200908563244440010, 0.200859582493398030, 0.200810601240207500, 0.200761619484990490, 0.200712637227869420, 0.200663654468966330, +0.200614671208404540, 0.200565687446306070, 0.200516703182793380, 0.200467718417988490, 0.200418733152014750, 0.200369747384994160, 0.200320761117048800, 0.200271774348301960, +0.200222787078875670, 0.200173799308892430, 0.200124811038474240, 0.200075822267744450, 0.200026832996825110, 0.199977843225838700, 0.199928852954907250, 0.199879862184154100, +0.199830870913701280, 0.199781879143671290, 0.199732886874186170, 0.199683894105369270, 0.199634900837342640, 0.199585907070228750, 0.199536912804149650, 0.199487918039228720, +0.199438922775588000, 0.199389927013349510, 0.199340930752636650, 0.199291933993571480, 0.199242936736276440, 0.199193938980873650, 0.199144940727486450, 0.199095941976236900, +0.199046942727247460, 0.198997942980640270, 0.198948942736538630, 0.198899941995064640, 0.198850940756340800, 0.198801939020489180, 0.198752936787633140, 0.198703934057894770, +0.198654930831396540, 0.198605927108260550, 0.198556922888610210, 0.198507918172567520, 0.198458912960255060, 0.198409907251794890, 0.198360901047310380, 0.198311894346923620, +0.198262887150756660, 0.198213879458932960, 0.198164871271574530, 0.198115862588803930, 0.198066853410743230, 0.198017843737515850, 0.197968833569243860, 0.197919822906049790, +0.197870811748055710, 0.197821800095385050, 0.197772787948159890, 0.197723775306502730, 0.197674762170535730, 0.197625748540382260, 0.197576734416164410, 0.197527719798004710, +0.197478704686025300, 0.197429689080349550, 0.197380672981099570, 0.197331656388397480, 0.197282639302366700, 0.197233621723129300, 0.197184603650807870, 0.197135585085524480, +0.197086566027402540, 0.197037546476564210, 0.196988526433132030, 0.196939505897228060, 0.196890484868975780, 0.196841463348497310, 0.196792441335915140, 0.196743418831351460, +0.196694395834929650, 0.196645372346771870, 0.196596348367000660, 0.196547323895738120, 0.196498298933107720, 0.196449273479231580, 0.196400247534231800, 0.196351221098231860, +0.196302194171353860, 0.196253166753720370, 0.196204138845453540, 0.196155110446676770, 0.196106081557512250, 0.196057052178082500, 0.196008022308509720, 0.195958991948917300, +0.195909961099427400, 0.195860929760162620, 0.195811897931245040, 0.195762865612798180, 0.195713832804944140, 0.195664799507805520, 0.195615765721504490, 0.195566731446164460, +0.195517696681907600, 0.195468661428856050, 0.195419625687133310, 0.195370589456861500, 0.195321552738163210, 0.195272515531160600, 0.195223477835977130, 0.195174439652734980, +0.195125400981556730, 0.195076361822564550, 0.195027322175881900, 0.194978282041630920, 0.194929241419934260, 0.194880200310914050, 0.194831158714693750, 0.194782116631395580, +0.194733074061142130, 0.194684031004055540, 0.194634987460259310, 0.194585943429875620, 0.194536898913027080, 0.194487853909835830, 0.194438808420425410, 0.194389762444917960, +0.194340715983435660, 0.194291669036102010, 0.194242621603039180, 0.194193573684369820, 0.194144525280216060, 0.194095476390701430, 0.194046427015948130, 0.193997377156078730, +0.193948326811215490, 0.193899275981481850, 0.193850224667000000, 0.193801172867892610, 0.193752120584281850, 0.193703067816291240, 0.193654014564042940, 0.193604960827659600, +0.193555906607263430, 0.193506851902977920, 0.193457796714925300, 0.193408741043227720, 0.193359684888008750, 0.193310628249390580, 0.193261571127495810, 0.193212513522446700, +0.193163455434366720, 0.193114396863378110, 0.193065337809603530, 0.193016278273165140, 0.192967218254186500, 0.192918157752789810, 0.192869096769097720, 0.192820035303232470, +0.192770973355317570, 0.192721910925475220, 0.192672848013828110, 0.192623784620498420, 0.192574720745609720, 0.192525656389284230, 0.192476591551644150, 0.192427526232813030, +0.192378460432913100, 0.192329394152066980, 0.192280327390396990, 0.192231260148026580, 0.192182192425078060, 0.192133124221674030, 0.192084055537936750, 0.192034986373989770, +0.191985916729955350, 0.191936846605956110, 0.191887776002114320, 0.191838704918553540, 0.191789633355396010, 0.191740561312764350, 0.191691488790780880, 0.191642415789569140, +0.191593342309251350, 0.191544268349950170, 0.191495193911787930, 0.191446118994888110, 0.191397043599373010, 0.191347967725364860, 0.191298891372987220, 0.191249814542362370, +0.191200737233612970, 0.191151659446861300, 0.191102581182230890, 0.191053502439844060, 0.191004423219823440, 0.190955343522291380, 0.190906263347371350, 0.190857182695185670, +0.190808101565857040, 0.190759019959507730, 0.190709937876261280, 0.190660855316240020, 0.190611772279566600, 0.190562688766363310, 0.190513604776753750, 0.190464520310860170, +0.190415435368804840, 0.190366349950711390, 0.190317264056702020, 0.190268177686899520, 0.190219090841426130, 0.190170003520405470, 0.190120915723959780, 0.190071827452211820, +0.190022738705283830, 0.189973649483299450, 0.189924559786380930, 0.189875469614651020, 0.189826378968231980, 0.189777287847247460, 0.189728196251819720, 0.189679104182071460, +0.189630011638125040, 0.189580918620103980, 0.189531825128130660, 0.189482731162327330, 0.189433636722817630, 0.189384541809723810, 0.189335446423168630, 0.189286350563274420, +0.189237254230164770, 0.189188157423961970, 0.189139060144788790, 0.189089962392767510, 0.189040864168021770, 0.188991765470673870, 0.188942666300846550, 0.188893566658662140, +0.188844466544244220, 0.188795365957715180, 0.188746264899197690, 0.188697163368814120, 0.188648061366688050, 0.188598958892941840, 0.188549855947697830, 0.188500752531079590, +0.188451648643209460, 0.188402544284210220, 0.188353439454204190, 0.188304334153314960, 0.188255228381664920, 0.188206122139376820, 0.188157015426572980, 0.188107908243377030, +0.188058800589911280, 0.188009692466298560, 0.187960583872661180, 0.187911474809122760, 0.187862365275805660, 0.187813255272832660, 0.187764144800326050, 0.187715033858409540, +0.187665922447205450, 0.187616810566836540, 0.187567698217425170, 0.187518585399094990, 0.187469472111968350, 0.187420358356167600, 0.187371244131816380, 0.187322129439037060, +0.187273014277952400, 0.187223898648684770, 0.187174782551357860, 0.187125665986093950, 0.187076548953015900, 0.187027431452246040, 0.186978313483908030, 0.186929195048124250, +0.186880076145017480, 0.186830956774710070, 0.186781836937325720, 0.186732716632986770, 0.186683595861816020, 0.186634474623935870, 0.186585352919469930, 0.186536230748540640, +0.186487108111270340, 0.186437985007782690, 0.186388861438200080, 0.186339737402645310, 0.186290612901240770, 0.186241487934110130, 0.186192362501375770, 0.186143236603160510, +0.186094110239586720, 0.186044983410778080, 0.185995856116856980, 0.185946728357946260, 0.185897600134168280, 0.185848471445646730, 0.185799342292504000, 0.185750212674862910, +0.185701082592845870, 0.185651952046576530, 0.185602821036177340, 0.185553689561770650, 0.185504557623480170, 0.185455425221428300, 0.185406292355737860, 0.185357159026531240, +0.185308025233932190, 0.185258890978063060, 0.185209756259046700, 0.185160621077005540, 0.185111485432063240, 0.185062349324342210, 0.185013212753965340, 0.184964075721054970, +0.184914938225734880, 0.184865800268127430, 0.184816661848355460, 0.184767522966541420, 0.184718383622809010, 0.184669243817280640, 0.184620103550079160, 0.184570962821326980, +0.184521821631147830, 0.184472679979664130, 0.184423537866998300, 0.184374395293274040, 0.184325252258613820, 0.184276108763140460, 0.184226964806976370, 0.184177820390245330, +0.184128675513069750, 0.184079530175572440, 0.184030384377875890, 0.183981238120103830, 0.183932091402378650, 0.183882944224823260, 0.183833796587560050, 0.183784648490712800, +0.183735499934403940, 0.183686350918756320, 0.183637201443892390, 0.183588051509935870, 0.183538901117009270, 0.183489750265234920, 0.183440598954736690, 0.183391447185636940, +0.183342294958058540, 0.183293142272124010, 0.183243989127957030, 0.183194835525680110, 0.183145681465416070, 0.183096526947287400, 0.183047371971417850, 0.182998216537929890, +0.182949060646946350, 0.182899904298589740, 0.182850747492983830, 0.182801590230251030, 0.182752432510514230, 0.182703274333895940, 0.182654115700519900, 0.182604956610508570, +0.182555797063984420, 0.182506637061071200, 0.182457476601891410, 0.182408315686567900, 0.182359154315223180, 0.182309992487980990, 0.182260830204963840, 0.182211667466294610, +0.182162504272095770, 0.182113340622491100, 0.182064176517603090, 0.182015011957554650, 0.181965846942468230, 0.181916681472467620, 0.181867515547675330, 0.181818349168214240, +0.181769182334206830, 0.181720015045776890, 0.181670847303046950, 0.181621679106139440, 0.181572510455178170, 0.181523341350285610, 0.181474171791584700, 0.181425001779197930, +0.181375831313249110, 0.181326660393860690, 0.181277489021155620, 0.181228317195256390, 0.181179144916286810, 0.181129972184369380, 0.181080798999627010, 0.181031625362182170, +0.180982451272158760, 0.180933276729679180, 0.180884101734866440, 0.180834926287842980, 0.180785750388732650, 0.180736574037657970, 0.180687397234741840, 0.180638219980106760, +0.180589042273876590, 0.180539864116173790, 0.180490685507120910, 0.180441506446841760, 0.180392326935458840, 0.180343146973095090, 0.180293966559873040, 0.180244785695916540, +0.180195604381348050, 0.180146422616290550, 0.180097240400866550, 0.180048057735199880, 0.179998874619413080, 0.179949691053629100, 0.179900507037970450, 0.179851322572560950, +0.179802137657523180, 0.179752952292980050, 0.179703766479054090, 0.179654580215869160, 0.179605393503547790, 0.179556206342212480, 0.179507018731987100, 0.179457830672994170, +0.179408642165356680, 0.179359453209197130, 0.179310263804639380, 0.179261073951805990, 0.179211883650819890, 0.179162692901803670, 0.179113501704881130, 0.179064310060174870, +0.179015117967807810, 0.178965925427902520, 0.178916732440582840, 0.178867539005971350, 0.178818345124191010, 0.178769150795364370, 0.178719956019615290, 0.178670760797066310, +0.178621565127840000, 0.178572369012060220, 0.178523172449849500, 0.178473975441330870, 0.178424777986626840, 0.178375580085861320, 0.178326381739156850, 0.178277182946636410, +0.178227983708422600, 0.178178784024639270, 0.178129583895408950, 0.178080383320854680, 0.178031182301099020, 0.177981980836265850, 0.177932778926477710, 0.177883576571857630, +0.177834373772528200, 0.177785170528613230, 0.177735966840235350, 0.177686762707517570, 0.177637558130582430, 0.177588353109553810, 0.177539147644554330, 0.177489941735706560, +0.177440735383134350, 0.177391528586960310, 0.177342321347307460, 0.177293113664298340, 0.177243905538056880, 0.177194696968705680, 0.177145487956367730, 0.177096278501165600, +0.177047068603223220, 0.176997858262663180, 0.176948647479608510, 0.176899436254181750, 0.176850224586506840, 0.176801012476706400, 0.176751799924903390, 0.176702586931220460, +0.176653373495781500, 0.176604159618709120, 0.176554945300125890, 0.176505730540155730, 0.176456515338921260, 0.176407299696545480, 0.176358083613151030, 0.176308867088861810, +0.176259650123800400, 0.176210432718089890, 0.176161214871852850, 0.176111996585213200, 0.176062777858293580, 0.176013558691217010, 0.175964339084106110, 0.175915119037084790, +0.175865898550275650, 0.175816677623801790, 0.175767456257785810, 0.175718234452351600, 0.175669012207621820, 0.175619789523719070, 0.175570566400767290, 0.175521342838889090, +0.175472118838207510, 0.175422894398845230, 0.175373669520926150, 0.175324444204572880, 0.175275218449908480, 0.175225992257055620, 0.175176765626138240, 0.175127538557278920, +0.175078311050600760, 0.175029083106226360, 0.174979854724279710, 0.174930625904883420, 0.174881396648160580, 0.174832166954233810, 0.174782936823227040, 0.174733706255262940, +0.174684475250464130, 0.174635243808954590, 0.174586011930856900, 0.174536779616294210, 0.174487546865389140, 0.174438313678265620, 0.174389080055046330, 0.174339845995854340, +0.174290611500812290, 0.174241376570044150, 0.174192141203672570, 0.174142905401820650, 0.174093669164611030, 0.174044432492167640, 0.173995195384613190, 0.173945957842070760, +0.173896719864662990, 0.173847481452513860, 0.173798242605746030, 0.173749003324482560, 0.173699763608846200, 0.173650523458960840, 0.173601282874949160, 0.173552041856933850, +0.173502800405038880, 0.173453558519386900, 0.173404316200101020, 0.173355073447303910, 0.173305830261119560, 0.173256586641670620, 0.173207342589080240, 0.173158098103471050, +0.173108853184967050, 0.173059607833690930, 0.173010362049765780, 0.172961115833314310, 0.172911869184460470, 0.172862622103326950, 0.172813374590036870, 0.172764126644712940, +0.172714878267479110, 0.172665629458458090, 0.172616380217772560, 0.172567130545546510, 0.172517880441902670, 0.172468629906964100, 0.172419378940853520, 0.172370127543694910, +0.172320875715611000, 0.172271623456724890, 0.172222370767159320, 0.172173117647038220, 0.172123864096484340, 0.172074610115620810, 0.172025355704570310, 0.171976100863456850, +0.171926845592403150, 0.171877589891532350, 0.171828333760967090, 0.171779077200831460, 0.171729820211248160, 0.171680562792339840, 0.171631304944230570, 0.171582046667043020, +0.171532787960900380, 0.171483528825925300, 0.171434269262241870, 0.171385009269972740, 0.171335748849241100, 0.171286488000169630, 0.171237226722882410, 0.171187965017502110, +0.171138702884151890, 0.171089440322954480, 0.171040177334033900, 0.170990913917512890, 0.170941650073514580, 0.170892385802161710, 0.170843121103578330, 0.170793855977887130, +0.170744590425211310, 0.170695324445673560, 0.170646058039397950, 0.170596791206507170, 0.170547523947124000, 0.170498256261372440, 0.170448988149375230, 0.170399719611255580, +0.170350450647136160, 0.170301181257141080, 0.170251911441393040, 0.170202641200015210, 0.170153370533130370, 0.170104099440862520, 0.170054827923334400, 0.170005555980669240, +0.169956283612989760, 0.169907010820419980, 0.169857737603082680, 0.169808463961101050, 0.169759189894597820, 0.169709915403697040, 0.169660640488521470, 0.169611365149193870, +0.169562089385838300, 0.169512813198577500, 0.169463536587534690, 0.169414259552832570, 0.169364982094595250, 0.169315704212945480, 0.169266425908006420, 0.169217147179900880, +0.169167868028752920, 0.169118588454685280, 0.169069308457821170, 0.169020028038283340, 0.168970747196195900, 0.168921465931681590, 0.168872184244863580, 0.168822902135864710, +0.168773619604809020, 0.168724336651819270, 0.168675053277018230, 0.168625769480530010, 0.168576485262477370, 0.168527200622983510, 0.168477915562171200, 0.168428630080164570, +0.168379344177086330, 0.168330057853059740, 0.168280771108207580, 0.168231483942653910, 0.168182196356521540, 0.168132908349933690, 0.168083619923013130, 0.168034331075883950, +0.167985041808668940, 0.167935752121491310, 0.167886462014473880, 0.167837171487740740, 0.167787880541414660, 0.167738589175618460, 0.167689297390476220, 0.167640005186110720, +0.167590712562645210, 0.167541419520202490, 0.167492126058906650, 0.167442832178880510, 0.167393537880247270, 0.167344243163129760, 0.167294948027652070, 0.167245652473937020, +0.167196356502107850, 0.167147060112287330, 0.167097763304599610, 0.167048466079167460, 0.166999168436114150, 0.166949870375562500, 0.166900571897636600, 0.166851273002459280, +0.166801973690153760, 0.166752673960842900, 0.166703373814650780, 0.166654073251700200, 0.166604772272114010, 0.166555470876016350, 0.166506169063530000, 0.166456866834778230, +0.166407564189883840, 0.166358261128970980, 0.166308957652162470, 0.166259653759581570, 0.166210349451351100, 0.166161044727595210, 0.166111739588436700, 0.166062434033998810, +0.166013128064404440, 0.165963821679777660, 0.165914514880241340, 0.165865207665918720, 0.165815900036932640, 0.165766591993407260, 0.165717283535465390, 0.165667974663229880, +0.165618665376824880, 0.165569355676373210, 0.165520045561998150, 0.165470735033822540, 0.165421424091970530, 0.165372112736564960, 0.165322800967729110, 0.165273488785585810, +0.165224176190259230, 0.165174863181872220, 0.165125549760548020, 0.165076235926409550, 0.165026921679580910, 0.164977607020184960, 0.164928291948344990, 0.164878976464183870, +0.164829660567825750, 0.164780344259393450, 0.164731027539009870, 0.164681710406799160, 0.164632392862884170, 0.164583074907388190, 0.164533756540434090, 0.164484437762146050, +0.164435118572646920, 0.164385798972059960, 0.164336478960508100, 0.164287158538115460, 0.164237837705004910, 0.164188516461299810, 0.164139194807122940, 0.164089872742598540, +0.164040550267849440, 0.163991227382998980, 0.163941904088170030, 0.163892580383486720, 0.163843256269072010, 0.163793931745049110, 0.163744606811540960, 0.163695281468671740, +0.163645955716564320, 0.163596629555341540, 0.163547302985127650, 0.163497976006045510, 0.163448648618218420, 0.163399320821769280, 0.163349992616822260, 0.163300664003500270, +0.163251334981926590, 0.163202005552224170, 0.163152675714517160, 0.163103345468928460, 0.163054014815581410, 0.163004683754598870, 0.162955352286105050, 0.162906020410222870, +0.162856688127075660, 0.162807355436786260, 0.162758022339478890, 0.162708688835276500, 0.162659354924301950, 0.162610020606679420, 0.162560685882531860, 0.162511350751982590, +0.162462015215154490, 0.162412679272171790, 0.162363342923157410, 0.162314006168234660, 0.162264669007526450, 0.162215331441157020, 0.162165993469249260, 0.162116655091926520, +0.162067316309311700, 0.162017977121529020, 0.161968637528701390, 0.161919297530952190, 0.161869957128404300, 0.161820616321181940, 0.161771275109408060, 0.161721933493205540, +0.161672591472698630, 0.161623249048010230, 0.161573906219263740, 0.161524562986582020, 0.161475219350089320, 0.161425875309908600, 0.161376530866163190, 0.161327186018976000, +0.161277840768471260, 0.161228495114771970, 0.161179149058001400, 0.161129802598282550, 0.161080455735739620, 0.161031108470495540, 0.160981760802673710, 0.160932412732397030, +0.160883064259789740, 0.160833715384974820, 0.160784366108075590, 0.160735016429215010, 0.160685666348517330, 0.160636315866105470, 0.160586964982102400, 0.160537613696632360, +0.160488262009818280, 0.160438909921783530, 0.160389557432651100, 0.160340204542545190, 0.160290851251588760, 0.160241497559905220, 0.160192143467617480, 0.160142788974849850, +0.160093434081725220, 0.160044078788367020, 0.159994723094898180, 0.159945367001442960, 0.159896010508124350, 0.159846653615065700, 0.159797296322389950, 0.159747938630221440, +0.159698580538683050, 0.159649222047897800, 0.159599863157989910, 0.159550503869082370, 0.159501144181298570, 0.159451784094761490, 0.159402423609595360, 0.159353062725923200, +0.159303701443868350, 0.159254339763553830, 0.159204977685103890, 0.159155615208641520, 0.159106252334290100, 0.159056889062172610, 0.159007525392413330, 0.158958161325135240, +0.158908796860461750, 0.158859431998515820, 0.158810066739421770, 0.158760701083302540, 0.158711335030281120, 0.158661968580481820, 0.158612601734027580, 0.158563234491041820, +0.158513866851647560, 0.158464498815969050, 0.158415130384129330, 0.158365761556251760, 0.158316392332459340, 0.158267022712876380, 0.158217652697625860, 0.158168282286831220, +0.158118911480615440, 0.158069540279102800, 0.158020168682416330, 0.157970796690679430, 0.157921424304015120, 0.157872051522547660, 0.157822678346400070, 0.157773304775695370, +0.157723930810557830, 0.157674556451110480, 0.157625181697476720, 0.157575806549779570, 0.157526431008143340, 0.157477055072691020, 0.157427678743546100, 0.157378302020831500, +0.157328924904671620, 0.157279547395189400, 0.157230169492508340, 0.157180791196751410, 0.157131412508042940, 0.157082033426505920, 0.157032653952263850, 0.156983274085439660, +0.156933893826157770, 0.156884513174541110, 0.156835132130713180, 0.156785750694797000, 0.156736368866916860, 0.156686986647195800, 0.156637604035756860, 0.156588221032724320, +0.156538837638221240, 0.156489453852371040, 0.156440069675296810, 0.156390685107122810, 0.156341300147972100, 0.156291914797968170, 0.156242529057233990, 0.156193142925893920, +0.156143756404070990, 0.156094369491888710, 0.156044982189470020, 0.155995594496939340, 0.155946206414419670, 0.155896817942034470, 0.155847429079906810, 0.155798039828160980, +0.155748650186920080, 0.155699260156307110, 0.155649869736446430, 0.155600478927461090, 0.155551087729474540, 0.155501696142609810, 0.155452304166991300, 0.155402911802742040, +0.155353519049985480, 0.155304125908844680, 0.155254732379444040, 0.155205338461906540, 0.155155944156355700, 0.155106549462914550, 0.155057154381707470, 0.155007758912857510, +0.154958363056488160, 0.154908966812722450, 0.154859570181684750, 0.154810173163498150, 0.154760775758285670, 0.154711377966171680, 0.154661979787279270, 0.154612581221731880, +0.154563182269652630, 0.154513782931165830, 0.154464383206394610, 0.154414983095462390, 0.154365582598492310, 0.154316181715608680, 0.154266780446934620, 0.154217378792593620, +0.154167976752708710, 0.154118574327404310, 0.154069171516803470, 0.154019768321029680, 0.153970364740206060, 0.153920960774456940, 0.153871556423905430, 0.153822151688675050, +0.153772746568888840, 0.153723341064671200, 0.153673935176145190, 0.153624528903433920, 0.153575122246661780, 0.153525715205951820, 0.153476307781427570, 0.153426899973212100, +0.153377491781429840, 0.153328083206203840, 0.153278674247657650, 0.153229264905914320, 0.153179855181098250, 0.153130445073332570, 0.153081034582740750, 0.153031623709445920, +0.152982212453572490, 0.152932800815243490, 0.152883388794582520, 0.152833976391712620, 0.152784563606758240, 0.152735150439842430, 0.152685736891088300, 0.152636322960620300, +0.152586908648561480, 0.152537493955035350, 0.152488078880165080, 0.152438663424075050, 0.152389247586888380, 0.152339831368728560, 0.152290414769718720, 0.152240997789983320, +0.152191580429645400, 0.152142162688828520, 0.152092744567655810, 0.152043326066251680, 0.151993907184739210, 0.151944487923242000, 0.151895068281883120, 0.151845648260787000, +0.151796227860076770, 0.151746807079875530, 0.151697385920307710, 0.151647964381496410, 0.151598542463565220, 0.151549120166637240, 0.151499697490836890, 0.151450274436287280, +0.151400851003112010, 0.151351427191434160, 0.151302003001378190, 0.151252578433067190, 0.151203153486624780, 0.151153728162174010, 0.151104302459839380, 0.151054876379743990, +0.151005449922011430, 0.150956023086764780, 0.150906595874128520, 0.150857168284225770, 0.150807740317179640, 0.150758311973114620, 0.150708883252153810, 0.150659454154420810, +0.150610024680038730, 0.150560594829132010, 0.150511164601823820, 0.150461733998237700, 0.150412303018496840, 0.150362871662725630, 0.150313439931047260, 0.150264007823585260, +0.150214575340462840, 0.150165142481804400, 0.150115709247733100, 0.150066275638372550, 0.150016841653845850, 0.149967407294277490, 0.149917972559790610, 0.149868537450508820, +0.149819101966555210, 0.149769666108054310, 0.149720229875129230, 0.149670793267903170, 0.149621356286500530, 0.149571918931044520, 0.149522481201658700, 0.149473043098466240, +0.149423604621591600, 0.149374165771157970, 0.149324726547288900, 0.149275286950107610, 0.149225846979738510, 0.149176406636304800, 0.149126965919930080, 0.149077524830737520, +0.149028083368851570, 0.148978641534395410, 0.148929199327492660, 0.148879756748266450, 0.148830313796841310, 0.148780870473340380, 0.148731426777886810, 0.148681982710605150, +0.148632538271618510, 0.148583093461050530, 0.148533648279024380, 0.148484202725664540, 0.148434756801094190, 0.148385310505436960, 0.148335863838816030, 0.148286416801355850, +0.148236969393179650, 0.148187521614411010, 0.148138073465173130, 0.148088624945590520, 0.148039176055786340, 0.147989726795884210, 0.147940277166007330, 0.147890827166280190, +0.147841376796825990, 0.147791926057767920, 0.147742474949230460, 0.147693023471336810, 0.147643571624210600, 0.147594119407975040, 0.147544666822754610, 0.147495213868672510, +0.147445760545852370, 0.147396306854417400, 0.147346852794492110, 0.147297398366199680, 0.147247943569663750, 0.147198488405007520, 0.147149032872355510, 0.147099576971830900, +0.147050120703557390, 0.147000664067658100, 0.146951207064257630, 0.146901749693479110, 0.146852291955446220, 0.146802833850282170, 0.146753375378111450, 0.146703916539057320, +0.146654457333242950, 0.146604997760792890, 0.146555537821830310, 0.146506077516478900, 0.146456616844861860, 0.146407155807103700, 0.146357694403327660, 0.146308232633657390, +0.146258770498216090, 0.146209307997128310, 0.146159845130517270, 0.146110381898506610, 0.146060918301219530, 0.146011454338780630, 0.145961990011313080, 0.145912525318940560, +0.145863060261786280, 0.145813594839974770, 0.145764129053629320, 0.145714662902873080, 0.145665196387830630, 0.145615729508625170, 0.145566262265380410, 0.145516794658219540, +0.145467326687267110, 0.145417858352646400, 0.145368389654481010, 0.145318920592894220, 0.145269451168010570, 0.145219981379953320, 0.145170511228846080, 0.145121040714812130, +0.145071569837976010, 0.145022098598460990, 0.144972626996390690, 0.144923155031888410, 0.144873682705078670, 0.144824210016084730, 0.144774736965029820, 0.144725263552038520, +0.144675789777234030, 0.144626315640740110, 0.144576841142679910, 0.144527366283178080, 0.144477891062357840, 0.144428415480342850, 0.144378939537256390, 0.144329463233223040, +0.144279986568365990, 0.144230509542809030, 0.144181032156675300, 0.144131554410089460, 0.144082076303174740, 0.144032597836054820, 0.143983119008852970, 0.143933639821693740, +0.143884160274700440, 0.143834680367996260, 0.143785200101705870, 0.143735719475952460, 0.143686238490859740, 0.143636757146551000, 0.143587275443150780, 0.143537793380782400, +0.143488310959569510, 0.143438828179635440, 0.143389345041104700, 0.143339861544100610, 0.143290377688746890, 0.143240893475166750, 0.143191408903484830, 0.143141923973824410, +0.143092438686309160, 0.143042953041062380, 0.142993467038208640, 0.142943980677871260, 0.142894493960173900, 0.142845006885239880, 0.142795519453193800, 0.142746031664158890, +0.142696543518258470, 0.142647055015617140, 0.142597566156358160, 0.142548076940605280, 0.142498587368481760, 0.142449097440112220, 0.142399607155619920, 0.142350116515128610, +0.142300625518761580, 0.142251134166643390, 0.142201642458897410, 0.142152150395647300, 0.142102657977016380, 0.142053165203129240, 0.142003672074109220, 0.141954178590080000, +0.141904684751164880, 0.141855190557488520, 0.141805696009174170, 0.141756201106345130, 0.141706705849126040, 0.141657210237640160, 0.141607714272011270, 0.141558217952362670, +0.141508721278818940, 0.141459224251503420, 0.141409726870539850, 0.141360229136051510, 0.141310731048163050, 0.141261232606997740, 0.141211733812679370, 0.141162234665331200, +0.141112735165077910, 0.141063235312042760, 0.141013735106349540, 0.140964234548121540, 0.140914733637483390, 0.140865232374558390, 0.140815730759469900, 0.140766228792342520, +0.140716726473299550, 0.140667223802464770, 0.140617720779961490, 0.140568217405914350, 0.140518713680446660, 0.140469209603682200, 0.140419705175744260, 0.140370200396757490, +0.140320695266845240, 0.140271189786131230, 0.140221683954738830, 0.140172177772792640, 0.140122671240416020, 0.140073164357732730, 0.140023657124866090, 0.139974149541940730, +0.139924641609080000, 0.139875133326407660, 0.139825624694047050, 0.139776115712122840, 0.139726606380758320, 0.139677096700076830, 0.139627586670203060, 0.139578076291260320, +0.139528565563372400, 0.139479054486662590, 0.139429543061255630, 0.139380031287274770, 0.139330519164843870, 0.139281006694086220, 0.139231493875126480, 0.139181980708088020, +0.139132467193094580, 0.139082953330269570, 0.139033439119737590, 0.138983924561622040, 0.138934409656046640, 0.138884894403134810, 0.138835378803011170, 0.138785862855799080, +0.138736346561621900, 0.138686829920604300, 0.138637312932869600, 0.138587795598541650, 0.138538277917743760, 0.138488759890600580, 0.138439241517235550, 0.138389722797772400, +0.138340203732334490, 0.138290684321046520, 0.138241164564031850, 0.138191644461414240, 0.138142124013317100, 0.138092603219865110, 0.138043082081181570, 0.137993560597390350, +0.137944038768614770, 0.137894516594979560, 0.137844994076608050, 0.137795471213623590, 0.137745948006150920, 0.137696424454313380, 0.137646900558234780, 0.137597376318038480, +0.137547851733849170, 0.137498326805790240, 0.137448801533985500, 0.137399275918558300, 0.137349749959633370, 0.137300223657334050, 0.137250697011784160, 0.137201170023107110, +0.137151642691427570, 0.137102115016868920, 0.137052586999554970, 0.137003058639609130, 0.136953529937156090, 0.136904000892319220, 0.136854471505221900, 0.136804941775988840, +0.136755411704743420, 0.136705881291609490, 0.136656350536710410, 0.136606819440170890, 0.136557288002114310, 0.136507756222664530, 0.136458224101944910, 0.136408691640080180, +0.136359158837193710, 0.136309625693409350, 0.136260092208850490, 0.136210558383641820, 0.136161024217906770, 0.136111489711769150, 0.136061954865352360, 0.136012419678781140, +0.135962884152178860, 0.135913348285669390, 0.135863812079376090, 0.135814275533423710, 0.135764738647935620, 0.135715201423035250, 0.135665663858847350, 0.135616125955495240, +0.135566587713102840, 0.135517049131793550, 0.135467510211692040, 0.135417970952921800, 0.135368431355606580, 0.135318891419869890, 0.135269351145836380, 0.135219810533629500, +0.135170269583373080, 0.135120728295190560, 0.135071186669206670, 0.135021644705544810, 0.134972102404328830, 0.134922559765682150, 0.134873016789729520, 0.134823473476594350, +0.134773929826400050, 0.134724385839271350, 0.134674841515331710, 0.134625296854704950, 0.134575751857514530, 0.134526206523885140, 0.134476660853940250, 0.134427114847803730, +0.134377568505598950, 0.134328021827450710, 0.134278474813482400, 0.134228927463817900, 0.134179379778580660, 0.134129831757895390, 0.134080283401885550, 0.134030734710675000, +0.133981185684387190, 0.133931636323146840, 0.133882086627077400, 0.133832536596302320, 0.133782986230946310, 0.133733435531132840, 0.133683884496985790, 0.133634333128628600, +0.133584781426185990, 0.133535229389781460, 0.133485677019538840, 0.133436124315581580, 0.133386571278034440, 0.133337017907020900, 0.133287464202664800, 0.133237910165089600, +0.133188355794420070, 0.133138801090779630, 0.133089246054292200, 0.133039690685081230, 0.132990134983271470, 0.132940578948986370, 0.132891022582349800, 0.132841465883485250, +0.132791908852517490, 0.132742351489569950, 0.132692793794766090, 0.132643235768230670, 0.132593677410087180, 0.132544118720459490, 0.132494559699471050, 0.132445000347246660, +0.132395440663909790, 0.132345880649584300, 0.132296320304393670, 0.132246759628462660, 0.132197198621914790, 0.132147637284873890, 0.132098075617463480, 0.132048513619808290, +0.131998951292031850, 0.131949388634258010, 0.131899825646610260, 0.131850262329213400, 0.131800698682190880, 0.131751134705666180, 0.131701570399764070, 0.131652005764608030, +0.131602440800321990, 0.131552875507029400, 0.131503309884855060, 0.131453743933922450, 0.131404177654355470, 0.131354611046277630, 0.131305044109813700, 0.131255476845087120, +0.131205909252221890, 0.131156341331341440, 0.131106773082570540, 0.131057204506032750, 0.131007635601851940, 0.130958066370151590, 0.130908496811056510, 0.130858926924690200, +0.130809356711176130, 0.130759786170639130, 0.130710215303202620, 0.130660644108990610, 0.130611072588126540, 0.130561500740735220, 0.130511928566940160, 0.130462356066865260, +0.130412783240634040, 0.130363210088371290, 0.130313636610200540, 0.130264062806245700, 0.130214488676630240, 0.130164914221478990, 0.130115339440915500, 0.130065764335063620, +0.130016188904046900, 0.129966613147990160, 0.129917037067016880, 0.129867460661250540, 0.129817883930816030, 0.129768306875836790, 0.129718729496436790, 0.129669151792739520, +0.129619573764869820, 0.129569995412951170, 0.129520416737107540, 0.129470837737462430, 0.129421258414140680, 0.129371678767265770, 0.129322098796961660, 0.129272518503351860, +0.129222937886561200, 0.129173356946713200, 0.129123775683931820, 0.129074194098340560, 0.129024612190064230, 0.128975029959226380, 0.128925447405950970, 0.128875864530361510, +0.128826281332582810, 0.128776697812738400, 0.128727113970951820, 0.128677529807347900, 0.128627945322050130, 0.128578360515182510, 0.128528775386868550, 0.128479189937233090, +0.128429604166399670, 0.128380018074492230, 0.128330431661634300, 0.128280844927950720, 0.128231257873565040, 0.128181670498601210, 0.128132082803182780, 0.128082494787434580, +0.128032906451480130, 0.127983317795443420, 0.127933728819447980, 0.127884139523618660, 0.127834549908078960, 0.127784959972952500, 0.127735369718364050, 0.127685779144437160, +0.127636188251295830, 0.127586597039063610, 0.127537005507865310, 0.127487413657824540, 0.127437821489065180, 0.127388229001710870, 0.127338636195886420, 0.127289043071715370, +0.127239449629321710, 0.127189855868828970, 0.127140261790362060, 0.127090667394044480, 0.127041072680000260, 0.126991477648352890, 0.126941882299227260, 0.126892286632746930, +0.126842690649035440, 0.126793094348217700, 0.126743497730417180, 0.126693900795757930, 0.126644303544363510, 0.126594705976358750, 0.126545108091867230, 0.126495509891012940, +0.126445911373919420, 0.126396312540711570, 0.126346713391512930, 0.126297113926447550, 0.126247514145638890, 0.126197914049211910, 0.126148313637290150, 0.126098712909997610, +0.126049111867457820, 0.125999510509795710, 0.125949908837134830, 0.125900306849599160, 0.125850704547312290, 0.125801101930399120, 0.125751498998983160, 0.125701895753188050, +0.125652292193138610, 0.125602688318958460, 0.125553084130771570, 0.125503479628701540, 0.125453874812873230, 0.125404269683410260, 0.125354664240436620, 0.125305058484075860, +0.125255452414452910, 0.125205846031691330, 0.125156239335915100, 0.125106632327247860, 0.125057025005814480, 0.125007417371738540, 0.124957809425144050, 0.124908201166154600, +0.124858592594895080, 0.124808983711489090, 0.124759374516060190, 0.124709765008733290, 0.124660155189632000, 0.124610545058880310, 0.124560934616601810, 0.124511323862921410, +0.124461712797962710, 0.124412101421849730, 0.124362489734706050, 0.124312877736656590, 0.124263265427824940, 0.124213652808335110, 0.124164039878310720, 0.124114426637876680, +0.124064813087156560, 0.124015199226274410, 0.123965585055353820, 0.123915970574519710, 0.123866355783895680, 0.123816740683605310, 0.123767125273773540, 0.123717509554523940, +0.123667893525980580, 0.123618277188267040, 0.123568660541508250, 0.123519043585827810, 0.123469426321349760, 0.123419808748197690, 0.123370190866496560, 0.123320572676369940, +0.123270954177941900, 0.123221335371336020, 0.123171716256677250, 0.123122096834089190, 0.123072477103695880, 0.123022857065620950, 0.122973236719989300, 0.122923616066924580, +0.122873995106550370, 0.122824373838991610, 0.122774752264371910, 0.122725130382815340, 0.122675508194445500, 0.122625885699387330, 0.122576262897764450, 0.122526639789700910, +0.122477016375320320, 0.122427392654747640, 0.122377768628106480, 0.122328144295520900, 0.122278519657114500, 0.122228894713012260, 0.122179269463337780, 0.122129643908215120, +0.122080018047767930, 0.122030391882121110, 0.121980765411398320, 0.121931138635723620, 0.121881511555220630, 0.121831884170014300, 0.121782256480228270, 0.121732628485986150, +0.121683000187412890, 0.121633371584632140, 0.121583742677767960, 0.121534113466943980, 0.121484483952285160, 0.121434854133915140, 0.121385224011957960, 0.121335593586537300, +0.121285962857778100, 0.121236331825803980, 0.121186700490739030, 0.121137068852706890, 0.121087436911832520, 0.121037804668239560, 0.120988172122052100, 0.120938539273393750, +0.120888906122389490, 0.120839272669162970, 0.120789638913837840, 0.120740004856539050, 0.120690370497390230, 0.120640735836515510, 0.120591100874038490, 0.120541465610084160, +0.120491830044776180, 0.120442194178238610, 0.120392558010595120, 0.120342921541970680, 0.120293284772488930, 0.120243647702273970, 0.120194010331449460, 0.120144372660140340, +0.120094734688470300, 0.120045096416563440, 0.119995457844543380, 0.119945818972535120, 0.119896179800662320, 0.119846540329048620, 0.119796900557819010, 0.119747260487097150, +0.119697620117007140, 0.119647979447672640, 0.119598338479218640, 0.119548697211768780, 0.119499055645447190, 0.119449413780377500, 0.119399771616684730, 0.119350129154492540, +0.119300486393925010, 0.119250843335105840, 0.119201199978159990, 0.119151556323211140, 0.119101912370383410, 0.119052268119800450, 0.119002623571587270, 0.118952978725867520, +0.118903333582765320, 0.118853688142404350, 0.118804042404909600, 0.118754396370404750, 0.118704750039013470, 0.118655103410860750, 0.118605456486070270, 0.118555809264766150, +0.118506161747072070, 0.118456513933113020, 0.118406865823012690, 0.118357217416895190, 0.118307568714884210, 0.118257919717104750, 0.118208270423680480, 0.118158620834735550, +0.118108970950393620, 0.118059320770779710, 0.118009670296017490, 0.117960019526231100, 0.117910368461544220, 0.117860717102081850, 0.117811065447967700, 0.117761413499325440, +0.117711761256280080, 0.117662108718955330, 0.117612455887475290, 0.117562802761963690, 0.117513149342545520, 0.117463495629344470, 0.117413841622484680, 0.117364187322089850, +0.117314532728284990, 0.117264877841193800, 0.117215222660940420, 0.117165567187648530, 0.117115911421443180, 0.117066255362448040, 0.117016599010787260, 0.116966942366584540, +0.116917285429964910, 0.116867628201052070, 0.116817970679969710, 0.116768312866842870, 0.116718654761795260, 0.116668996364951000, 0.116619337676433800, 0.116569678696368710, +0.116520019424879410, 0.116470359862090080, 0.116420700008124390, 0.116371039863107400, 0.116321379427162820, 0.116271718700414780, 0.116222057682987000, 0.116172396375004520, +0.116122734776591060, 0.116073072887870750, 0.116023410708967320, 0.115973748240005810, 0.115924085481109930, 0.115874422432403380, 0.115824759094011230, 0.115775095466057170, +0.115725431548665380, 0.115675767341959570, 0.115626102846064780, 0.115576438061104740, 0.115526772987203600, 0.115477107624485080, 0.115427441973074240, 0.115377776033094790, +0.115328109804670910, 0.115278443287926300, 0.115228776482986050, 0.115179109389973830, 0.115129442009013840, 0.115079774340229810, 0.115030106383746790, 0.114980438139688500, +0.114930769608179120, 0.114881100789342370, 0.114831431683303300, 0.114781762290185660, 0.114732092610113180, 0.114682422643210890, 0.114632752389602560, 0.114583081849412350, +0.114533411022763990, 0.114483739909782540, 0.114434068510591740, 0.114384396825315770, 0.114334724854078380, 0.114285052597004600, 0.114235380054218200, 0.114185707225843340, +0.114136034112003780, 0.114086360712824570, 0.114036687028429460, 0.113987013058942630, 0.113937338804487840, 0.113887664265190130, 0.113837989441173270, 0.113788314332560980, +0.113738638939478360, 0.113688963262049140, 0.113639287300397500, 0.113589611054647210, 0.113539934524923340, 0.113490257711349620, 0.113440580614050250, 0.113390903233149020, +0.113341225568770940, 0.113291547621039810, 0.113241869390079810, 0.113192190876014700, 0.113142512078969550, 0.113092832999068110, 0.113043153636434610, 0.112993473991192760, +0.112943794063467690, 0.112894113853383120, 0.112844433361062830, 0.112794752586631890, 0.112745071530214070, 0.112695390191933570, 0.112645708571914170, 0.112596026670280930, +0.112546344487157610, 0.112496662022668450, 0.112446979276937180, 0.112397296250088900, 0.112347612942247390, 0.112297929353536840, 0.112248245484081040, 0.112198561334005050, +0.112148876903432670, 0.112099192192488100, 0.112049507201295080, 0.111999821929978760, 0.111950136378662880, 0.111900450547471660, 0.111850764436528870, 0.111801078045959610, +0.111751391375887660, 0.111701704426436790, 0.111652017197732090, 0.111602329689897350, 0.111552641903056790, 0.111502953837334190, 0.111453265492854630, 0.111403576869741920, +0.111353887968120260, 0.111304198788113440, 0.111254509329846570, 0.111204819593443430, 0.111155129579028230, 0.111105439286724770, 0.111055748716658160, 0.111006057868952170, +0.110956366743731040, 0.110906675341118550, 0.110856983661239810, 0.110807291704218600, 0.110757599470178740, 0.110707906959245320, 0.110658214171542120, 0.110608521107193390, +0.110558827766322920, 0.110509134149055820, 0.110459440255515880, 0.110409746085827350, 0.110360051640114000, 0.110310356918500970, 0.110260661921112040, 0.110210966648071480, +0.110161271099503040, 0.110111575275531860, 0.110061879176281750, 0.110012182801876950, 0.109962486152441240, 0.109912789228099760, 0.109863092028976300, 0.109813394555194690, +0.109763696806880020, 0.109713998784156110, 0.109664300487147200, 0.109614601915977090, 0.109564903070770940, 0.109515203951652510, 0.109465504558746080, 0.109415804892175450, +0.109366104952065740, 0.109316404738540780, 0.109266704251724800, 0.109217003491741610, 0.109167302458716360, 0.109117601152772860, 0.109067899574035360, 0.109018197722627650, +0.108968495598674900, 0.108918793202300910, 0.108869090533629500, 0.108819387592785810, 0.108769684379893640, 0.108719980895077260, 0.108670277138460490, 0.108620573110168470, +0.108570868810325000, 0.108521164239054380, 0.108471459396480400, 0.108421754282728210, 0.108372048897921640, 0.108322343242184940, 0.108272637315641950, 0.108222931118417810, +0.108173224650636330, 0.108123517912421790, 0.108073810903898020, 0.108024103625190170, 0.107974396076422050, 0.107924688257717950, 0.107874980169201680, 0.107825271810998390, +0.107775563183231950, 0.107725854286026130, 0.107676145119506140, 0.107626435683795780, 0.107576725979019320, 0.107527016005300610, 0.107477305762764800, 0.107427595251535740, +0.107377884471737670, 0.107328173423494460, 0.107278462106931260, 0.107228750522171900, 0.107179038669340660, 0.107129326548561390, 0.107079614159959240, 0.107029901503658060, +0.106980188579782120, 0.106930475388455270, 0.106880761929802670, 0.106831048203948160, 0.106781334211015600, 0.106731619951130150, 0.106681905424415640, 0.106632190630996370, +0.106582475570996180, 0.106532760244540240, 0.106483044651752400, 0.106433328792756950, 0.106383612667677730, 0.106333896276639940, 0.106284179619767400, 0.106234462697184410, +0.106184745509014810, 0.106135028055383800, 0.106085310336415220, 0.106035592352233370, 0.105985874102962080, 0.105936155588726560, 0.105886436809650640, 0.105836717765858190, +0.105786998457474400, 0.105737278884623100, 0.105687559047428600, 0.105637838946014780, 0.105588118580506790, 0.105538397951028500, 0.105488677057704220, 0.105438955900657810, +0.105389234480014440, 0.105339512795898000, 0.105289790848432780, 0.105240068637742630, 0.105190346163952740, 0.105140623427187000, 0.105090900427569700, 0.105041177165224710, +0.104991453640277200, 0.104941729852851080, 0.104892005803070620, 0.104842281491059720, 0.104792556916943540, 0.104742832080845980, 0.104693106982890890, 0.104643381623203480, +0.104593656001907610, 0.104543930119127600, 0.104494203974987330, 0.104444477569611990, 0.104394750903125460, 0.104345023975652040, 0.104295296787315630, 0.104245569338241420, +0.104195841628553280, 0.104146113658375530, 0.104096385427832070, 0.104046656937048080, 0.103996928186147450, 0.103947199175254500, 0.103897469904493110, 0.103847740373988490, +0.103798010583864510, 0.103748280534245060, 0.103698550225255360, 0.103648819657019280, 0.103599088829661150, 0.103549357743304860, 0.103499626398075630, 0.103449894794097300, +0.103400162931494260, 0.103350430810390370, 0.103300698430910830, 0.103250965793179560, 0.103201232897320860, 0.103151499743458650, 0.103101766331718120, 0.103052032662223190, +0.103002298735098170, 0.102952564550466960, 0.102902830108454790, 0.102853095409185520, 0.102803360452783100, 0.102753625239372700, 0.102703889769078250, 0.102654154042024060, +0.102604418058334060, 0.102554681818133440, 0.102504945321546140, 0.102455208568696460, 0.102405471559708310, 0.102355734294706930, 0.102305996773816220, 0.102256258997160510, +0.102206520964863710, 0.102156782677051060, 0.102107044133846440, 0.102057305335374230, 0.102007566281758290, 0.101957826973123890, 0.101908087409594920, 0.101858347591295740, +0.101808607518350230, 0.101758867190883660, 0.101709126609019910, 0.101659385772882920, 0.101609644682597890, 0.101559903338288770, 0.101510161740079860, 0.101460419888095120, +0.101410677782459780, 0.101360935423297730, 0.101311192810733350, 0.101261449944890540, 0.101211706825894560, 0.101161963453869310, 0.101112219828939140, 0.101062475951227980, +0.101012731820861080, 0.100962987437962350, 0.100913242802656150, 0.100863497915066410, 0.100813752775318340, 0.100764007383535910, 0.100714261739843020, 0.100664515844364910, +0.100614769697225520, 0.100565023298549190, 0.100515276648459870, 0.100465529747082810, 0.100415782594541910, 0.100366035190961560, 0.100316287536465680, 0.100266539631179510, +0.100216791475227010, 0.100167043068732530, 0.100117294411819990, 0.100067545504614660, 0.100017796347240460, 0.099968046939821781, 0.099918297282482541, 0.099868547375348005, +0.099818797218542088, 0.099769046812188733, 0.099719296156413215, 0.099669545251339448, 0.099619794097091832, 0.099570042693794270, 0.099520291041572048, 0.099470539140549111, +0.099420786990849816, 0.099371034592598120, 0.099321281945919271, 0.099271529050937210, 0.099221775907776338, 0.099172022516560585, 0.099122268877415209, 0.099072514990464169, +0.099022760855831837, 0.098973006473642169, 0.098923251844020413, 0.098873496967090538, 0.098823741842976473, 0.098773986471803507, 0.098724230853695569, 0.098674474988777044, +0.098624718877171905, 0.098574962519005396, 0.098525205914401490, 0.098475449063484558, 0.098425691966378570, 0.098375934623208802, 0.098326177034099183, 0.098276419199174125, +0.098226661118557587, 0.098176902792374829, 0.098127144220749821, 0.098077385403806949, 0.098027626341670171, 0.097977867034464761, 0.097928107482314689, 0.097878347685344355, +0.097828587643677703, 0.097778827357440035, 0.097729066826755279, 0.097679306051747433, 0.097629545032541759, 0.097579783769262213, 0.097530022262033209, 0.097480260510978717, +0.097430498516224012, 0.097380736277893065, 0.097330973796110262, 0.097281211070999601, 0.097231448102686344, 0.097181684891294473, 0.097131921436948376, 0.097082157739772051, +0.097032393799890759, 0.096982629617428498, 0.096932865192509654, 0.096883100525258198, 0.096833335615799446, 0.096783570464257340, 0.096733805070755879, 0.096684039435420352, +0.096634273558374714, 0.096584507439743394, 0.096534741079650363, 0.096484974478220922, 0.096435207635579057, 0.096385440551849152, 0.096335673227155222, 0.096285905661622539, +0.096236137855375103, 0.096186369808537314, 0.096136601521233156, 0.096086832993587945, 0.096037064225725638, 0.095987295217770691, 0.095937525969847046, 0.095887756482080033, +0.095837986754593638, 0.095788216787511829, 0.095738446580959910, 0.095688676135061879, 0.095638905449942163, 0.095589134525724748, 0.095539363362534921, 0.095489591960496695, +0.095439820319734497, 0.095390048440372299, 0.095340276322535417, 0.095290503966347848, 0.095240731371934020, 0.095190958539417919, 0.095141185468924860, 0.095091412160578856, +0.095041638614504306, 0.094991864830825223, 0.094942090809666910, 0.094892316551153377, 0.094842542055409054, 0.094792767322557939, 0.094742992352725333, 0.094693217146035263, +0.094643441702611700, 0.094593666022579972, 0.094543890106064080, 0.094494113953188463, 0.094444337564077122, 0.094394560938855385, 0.094344784077647237, 0.094295006980577134, +0.094245229647769060, 0.094195452079348360, 0.094145674275439031, 0.094095896236165516, 0.094046117961651826, 0.093996339452023278, 0.093946560707403884, 0.093896781727918086, +0.093847002513689881, 0.093797223064844629, 0.093747443381506312, 0.093697663463798944, 0.093647883311847854, 0.093598102925777069, 0.093548322305711015, 0.093498541451773720, +0.093448760364090500, 0.093398979042785393, 0.093349197487982843, 0.093299415699806848, 0.093249633678382751, 0.093199851423834579, 0.093150068936286773, 0.093100286215863359, +0.093050503262689668, 0.093000720076889712, 0.092950936658587974, 0.092901153007908438, 0.092851369124976463, 0.092801585009916060, 0.092751800662851269, 0.092702016083907407, +0.092652231273208499, 0.092602446230879029, 0.092552660957042995, 0.092502875451825742, 0.092453089715351308, 0.092403303747744150, 0.092353517549128294, 0.092303731119629071, +0.092253944459370532, 0.092204157568477135, 0.092154370447072892, 0.092104583095283174, 0.092054795513231993, 0.092005007701043834, 0.091955219658842707, 0.091905431386753972, +0.091855642884901653, 0.091805854153409791, 0.091756065192403730, 0.091706276002007509, 0.091656486582345598, 0.091606696933542037, 0.091556907055722170, 0.091507116949010023, +0.091457326613530107, 0.091407536049406421, 0.091357745256764336, 0.091307954235727878, 0.091258162986421545, 0.091208371508969363, 0.091158579803496689, 0.091108787870127578, +0.091058995708986484, 0.091009203320197463, 0.090959410703885885, 0.090909617860175762, 0.090859824789191607, 0.090810031491057444, 0.090760237965898646, 0.090710444213839253, +0.090660650235003318, 0.090610856029516185, 0.090561061597501921, 0.090511266939084997, 0.090461472054389466, 0.090411676943540686, 0.090361881606662725, 0.090312086043880066, +0.090262290255316735, 0.090212494241098132, 0.090162698001348282, 0.090112901536191697, 0.090063104845752417, 0.090013307930155814, 0.089963510789525941, 0.089913713423987282, +0.089863915833663918, 0.089814118018681194, 0.089764319979163176, 0.089714521715233905, 0.089664723227018781, 0.089614924514641855, 0.089565125578227614, 0.089515326417900110, +0.089465527033784742, 0.089415727426005551, 0.089365927594687047, 0.089316127539953286, 0.089266327261929637, 0.089216526760740170, 0.089166726036509394, 0.089116925089361351, +0.089067123919421440, 0.089017322526813727, 0.088967520911662698, 0.088917719074092433, 0.088867917014228304, 0.088818114732194392, 0.088768312228114751, 0.088718509502114767, +0.088668706554318508, 0.088618903384850484, 0.088569099993834763, 0.088519296381396731, 0.088469492547660455, 0.088419688492750448, 0.088369884216790776, 0.088320079719906838, +0.088270275002222703, 0.088220470063862882, 0.088170664904951443, 0.088120859525613784, 0.088071053925973974, 0.088021248106156524, 0.087971442066285530, 0.087921635806486362, +0.087871829326883102, 0.087822022627600263, 0.087772215708761939, 0.087722408570493501, 0.087672601212919060, 0.087622793636162669, 0.087572985840349726, 0.087523177825604329, +0.087473369592050987, 0.087423561139813769, 0.087373752469018101, 0.087323943579788052, 0.087274134472248133, 0.087224325146522438, 0.087174515602736383, 0.087124705841014033, +0.087074895861479915, 0.087025085664258123, 0.086975275249474057, 0.086925464617251799, 0.086875653767715888, 0.086825842700990391, 0.086776031417200722, 0.086726219916470990, +0.086676408198925262, 0.086626596264688951, 0.086576784113886154, 0.086526971746641396, 0.086477159163078771, 0.086427346363323679, 0.086377533347500229, 0.086327720115732948, +0.086277906668145915, 0.086228093004864573, 0.086178279126012988, 0.086128465031715701, 0.086078650722096819, 0.086028836197281744, 0.085979021457394583, 0.085929206502559863, +0.085879391332901692, 0.085829575948545483, 0.085779760349615333, 0.085729944536235350, 0.085680128508530934, 0.085630312266626193, 0.085580495810645682, 0.085530679140713495, +0.085480862256955045, 0.085431045159494429, 0.085381227848456212, 0.085331410323964491, 0.085281592586144664, 0.085231774635120869, 0.085181956471017645, 0.085132138093959073, +0.085082319504070608, 0.085032500701476346, 0.084982681686300826, 0.084932862458668157, 0.084883043018703780, 0.084833223366531790, 0.084783403502276297, 0.084733583426062742, +0.084683763138015233, 0.084633942638258311, 0.084584121926916098, 0.084534301004114007, 0.084484479869976176, 0.084434658524627143, 0.084384836968191018, 0.084335015200793256, +0.084285193222557939, 0.084235371033609646, 0.084185548634072488, 0.084135726024071891, 0.084085903203731979, 0.084036080173177319, 0.083986256932532005, 0.083936433481921507, +0.083886609821469907, 0.083836785951301798, 0.083786961871541277, 0.083737137582313784, 0.083687313083743456, 0.083637488375954402, 0.083587663459072065, 0.083537838333220579, +0.083488012998524486, 0.083438187455107921, 0.083388361703096339, 0.083338535742613851, 0.083288709573785008, 0.083238883196733962, 0.083189056611586154, 0.083139229818465693, +0.083089402817497160, 0.083039575608804692, 0.082989748192513715, 0.082939920568748368, 0.082890092737633217, 0.082840264699292399, 0.082790436453851354, 0.082740608001434221, +0.082690779342165122, 0.082640950476169525, 0.082591121403571541, 0.082541292124495763, 0.082491462639066315, 0.082441632947408652, 0.082391803049646897, 0.082341972945905645, +0.082292142636309004, 0.082242312120982458, 0.082192481400050130, 0.082142650473636614, 0.082092819341866005, 0.082042988004863801, 0.081993156462754124, 0.081943324715661570, +0.081893492763710246, 0.081843660607025637, 0.081793828245731878, 0.081743995679953108, 0.081694162909814780, 0.081644329935441060, 0.081594496756956500, 0.081544663374485266, +0.081494829788152812, 0.081444995998083289, 0.081395162004401278, 0.081345327807230916, 0.081295493406697672, 0.081245658802925697, 0.081195823996039571, 0.081145988986163445, +0.081096153773422788, 0.081046318357941752, 0.080996482739844916, 0.080946646919256432, 0.080896810896301782, 0.080846974671105090, 0.080797138243790978, 0.080747301614483569, +0.080697464783308345, 0.080647627750389458, 0.080597790515851059, 0.080547953079818629, 0.080498115442416321, 0.080448277603768728, 0.080398439563999988, 0.080348601323235597, +0.080298762881599692, 0.080248924239216896, 0.080199085396211331, 0.080149246352708509, 0.080099407108832565, 0.080049567664708110, 0.079999728020459279, 0.079949888176211584, +0.079900048132089160, 0.079850207888216618, 0.079800367444718120, 0.079750526801719138, 0.079700685959343848, 0.079650844917716387, 0.079601003676962268, 0.079551162237205639, +0.079501320598571096, 0.079451478761182817, 0.079401636725166272, 0.079351794490645652, 0.079301952057745539, 0.079252109426590098, 0.079202266597304824, 0.079152423570013897, +0.079102580344841897, 0.079052736921913017, 0.079002893301352725, 0.078953049483285215, 0.078903205467835066, 0.078853361255126472, 0.078803516845284902, 0.078753672238434561, +0.078703827434699586, 0.078653982434205474, 0.078604137237076419, 0.078554291843437027, 0.078504446253411450, 0.078454600467125199, 0.078404754484702452, 0.078354908306267831, +0.078305061931945474, 0.078255215361860919, 0.078205368596138330, 0.078155521634902303, 0.078105674478277043, 0.078055827126388033, 0.078005979579359452, 0.077956131837315937, +0.077906283900381637, 0.077856435768682078, 0.077806587442341424, 0.077756738921483853, 0.077706890206234891, 0.077657041296718687, 0.077607192193059893, 0.077557342895382672, +0.077507493403812536, 0.077457643718473662, 0.077407793839490688, 0.077357943766987777, 0.077308093501090455, 0.077258243041922900, 0.077208392389609748, 0.077158541544275150, +0.077108690506044658, 0.077058839275042437, 0.077008987851393110, 0.076959136235220882, 0.076909284426651237, 0.076859432425808394, 0.076809580232816976, 0.076759727847801162, +0.076709875270886463, 0.076660022502197084, 0.076610169541857190, 0.076560316389992333, 0.076510463046726679, 0.076460609512184863, 0.076410755786491091, 0.076360901869770861, +0.076311047762148379, 0.076261193463748281, 0.076211338974694759, 0.076161484295113338, 0.076111629425128197, 0.076061774364863971, 0.076011919114444881, 0.075962063673996438, +0.075912208043642834, 0.075862352223508706, 0.075812496213718258, 0.075762640014397004, 0.075712783625669161, 0.075662927047658909, 0.075613070280491787, 0.075563213324291986, +0.075513356179184157, 0.075463498845292479, 0.075413641322742517, 0.075363783611658436, 0.075313925712164900, 0.075264067624386116, 0.075214209348447594, 0.075164350884473555, +0.075114492232588648, 0.075064633392917052, 0.075014774365584319, 0.074964915150714656, 0.074915055748432699, 0.074865196158862668, 0.074815336382130074, 0.074765476418359150, +0.074715616267674090, 0.074665755930200445, 0.074615895406062394, 0.074566034695384600, 0.074516173798291299, 0.074466312714907987, 0.074416451445358897, 0.074366589989768681, +0.074316728348261543, 0.074266866520963037, 0.074217004507997356, 0.074167142309489162, 0.074117279925562676, 0.074067417356343437, 0.074017554601955651, 0.073967691662523968, +0.073917828538172622, 0.073867965229027152, 0.073818101735211764, 0.073768238056851121, 0.073718374194069430, 0.073668510146992258, 0.073618645915743811, 0.073568781500448308, +0.073518916901231288, 0.073469052118216985, 0.073419187151530035, 0.073369322001294687, 0.073319456667636479, 0.073269591150679617, 0.073219725450548792, 0.073169859567368198, +0.073119993501263414, 0.073070127252358633, 0.073020260820778532, 0.072970394206647346, 0.072920527410090613, 0.072870660431232553, 0.072820793270197859, 0.072770925927110722, +0.072721058402096722, 0.072671190695280080, 0.072621322806785016, 0.072571454736737082, 0.072521586485260511, 0.072471718052479983, 0.072421849438519703, 0.072371980643505252, +0.072322111667560848, 0.072272242510811172, 0.072222373173380428, 0.072172503655394210, 0.072122633956976726, 0.072072764078252666, 0.072022894019346237, 0.071973023780383033, +0.071923153361487260, 0.071873282762783611, 0.071823411984396304, 0.071773541026450907, 0.071723669889071667, 0.071673798572382805, 0.071623927076509900, 0.071574055401577158, +0.071524183547709286, 0.071474311515030517, 0.071424439303666404, 0.071374566913741208, 0.071324694345379580, 0.071274821598705781, 0.071224948673845365, 0.071175075570922577, +0.071125202290062098, 0.071075328831388188, 0.071025455195026385, 0.070975581381100938, 0.070925707389736553, 0.070875833221057435, 0.070825958875189193, 0.070776084352256061, +0.070726209652382258, 0.070676334775693378, 0.070626459722313670, 0.070576584492367811, 0.070526709085980036, 0.070476833503275937, 0.070426957744379765, 0.070377081809416195, +0.070327205698509462, 0.070277329411785175, 0.070227452949367553, 0.070177576311381301, 0.070127699497950668, 0.070077822509201235, 0.070027945345257234, 0.069978068006243385, +0.069928190492283909, 0.069878312803504400, 0.069828434940029119, 0.069778556901982744, 0.069728678689489537, 0.069678800302675079, 0.069628921741663616, 0.069579043006579397, +0.069529164097548030, 0.069479285014693734, 0.069429405758141244, 0.069379526328014779, 0.069329646724439961, 0.069279766947541011, 0.069229886997442647, 0.069180006874269132, +0.069130126578146031, 0.069080246109197621, 0.069030365467548593, 0.068980484653323210, 0.068930603666647050, 0.068880722507644390, 0.068830841176439922, 0.068780959673157907, +0.068731077997923939, 0.068681196150862267, 0.068631314132097165, 0.068581431941754228, 0.068531549579957704, 0.068481667046832312, 0.068431784342502300, 0.068381901467093276, +0.068332018420729501, 0.068282135203535682, 0.068232251815636080, 0.068182368257156289, 0.068132484528220572, 0.068082600628953646, 0.068032716559479775, 0.067982832319924566, +0.067932947910412267, 0.067883063331067597, 0.067833178582014833, 0.067783293663379568, 0.067733408575286064, 0.067683523317858596, 0.067633637891222759, 0.067583752295502827, +0.067533866530823522, 0.067483980597309090, 0.067434094495085167, 0.067384208224276002, 0.067334321785006326, 0.067284435177400390, 0.067234548401583813, 0.067184661457680858, +0.067134774345816259, 0.067084887066114277, 0.067034999618700519, 0.066985112003699276, 0.066935224221235240, 0.066885336271432699, 0.066835448154417262, 0.066785559870313205, +0.066735671419245260, 0.066685782801337676, 0.066635894016716088, 0.066586005065504758, 0.066536115947827976, 0.066486226663811349, 0.066436337213579152, 0.066386447597256121, +0.066336557814966515, 0.066286667866835972, 0.066236777752988751, 0.066186887473549588, 0.066136997028642758, 0.066087106418393882, 0.066037215642927236, 0.065987324702367553, +0.065937433596839123, 0.065887542326467541, 0.065837650891377109, 0.065787759291692546, 0.065737867527538144, 0.065687975599039522, 0.065638083506320957, 0.065588191249506739, +0.065538298828722488, 0.065488406244092481, 0.065438513495741465, 0.065388620583793730, 0.065338727508374883, 0.065288834269609214, 0.065238940867621456, 0.065189047302535899, +0.065139153574478179, 0.065089259683572570, 0.065039365629943807, 0.064989471413716193, 0.064939577035015350, 0.064889682493965553, 0.064839787790691550, 0.064789892925317644, +0.064739997897969442, 0.064690102708771235, 0.064640207357847340, 0.064590311845323378, 0.064540416171323625, 0.064490520335972829, 0.064440624339395292, 0.064390728181716650, +0.064340831863061165, 0.064290935383553613, 0.064241038743318282, 0.064191141942480795, 0.064141244981165454, 0.064091347859496994, 0.064041450577599732, 0.063991553135599274, +0.063941655533619940, 0.063891757771786475, 0.063841859850223157, 0.063791961769055647, 0.063742063528408222, 0.063692165128405198, 0.063642266569172212, 0.063592367850833553, +0.063542468973513969, 0.063492569937337776, 0.063442670742430596, 0.063392771388916747, 0.063342871876920961, 0.063292972206567558, 0.063243072377982171, 0.063193172391289090, +0.063143272246613091, 0.063093371944078463, 0.063043471483810856, 0.062993570865934559, 0.062943670090574347, 0.062893769157854496, 0.062843868067900682, 0.062793966820837196, +0.062744065416788786, 0.062694163855879781, 0.062644262138235804, 0.062594360263981172, 0.062544458233240188, 0.062494556046138516, 0.062444653702800446, 0.062394751203350737, +0.062344848547913716, 0.062294945736615009, 0.062245042769578943, 0.062195139646930270, 0.062145236368793301, 0.062095332935293693, 0.062045429346555742, 0.061995525602704223, +0.061945621703863446, 0.061895717650159061, 0.061845813441715379, 0.061795909078657160, 0.061746004561108729, 0.061696099889195728, 0.061646195063042482, 0.061596290082773300, +0.061546384948513840, 0.061496479660388410, 0.061446574218521788, 0.061396668623038289, 0.061346762874063557, 0.061296856971721922, 0.061246950916138139, 0.061197044707436539, +0.061147138345742771, 0.061097231831181154, 0.061047325163876461, 0.060997418343953010, 0.060947511371536457, 0.060897604246751121, 0.060847696969721782, 0.060797789540572751, +0.060747881959429692, 0.060697974226416929, 0.060648066341658792, 0.060598158305280925, 0.060548250117407665, 0.060498341778163781, 0.060448433287673596, 0.060398524646062775, +0.060348615853455634, 0.060298706909976962, 0.060248797815751078, 0.060198888570903643, 0.060148979175558982, 0.060099069629841878, 0.060049159933876654, 0.059999250087788975, +0.059949340091703170, 0.059899429945744015, 0.059849519650035841, 0.059799609204704313, 0.059749698609873760, 0.059699787865668964, 0.059649876972214251, 0.059599965929635290, +0.059550054738056420, 0.059500143397601964, 0.059450231908397592, 0.059400320270567644, 0.059350408484236894, 0.059300496549529680, 0.059250584466571665, 0.059200672235487188, +0.059150759856401038, 0.059100847329437538, 0.059050934654722366, 0.059001021832379853, 0.058951108862534789, 0.058901195745311510, 0.058851282480835689, 0.058801369069231654, +0.058751455510624204, 0.058701541805137661, 0.058651627952897717, 0.058601713954028696, 0.058551799808654957, 0.058501885516902150, 0.058451971078894639, 0.058402056494757194, +0.058352141764614167, 0.058302226888591227, 0.058252311866812720, 0.058202396699403434, 0.058152481386487716, 0.058102565928191234, 0.058052650324638341, 0.058002734575953820, +0.057952818682262014, 0.057902902643688615, 0.057852986460357955, 0.057803070132394822, 0.057753153659923583, 0.057703237043069892, 0.057653320281958118, 0.057603403376712589, +0.057553486327459005, 0.057503569134321697, 0.057453651797425474, 0.057403734316894675, 0.057353816692854984, 0.057303898925430745, 0.057253981014746769, 0.057204062960927393, +0.057154144764098302, 0.057104226424383848, 0.057054307941908827, 0.057004389316797598, 0.056954470549175837, 0.056904551639167897, 0.056854632586898581, 0.056804713392492240, +0.056754794056074552, 0.056704874577769890, 0.056654954957702591, 0.056605035195998347, 0.056555115292781524, 0.056505195248176904, 0.056455275062308859, 0.056405354735303059, +0.056355434267283885, 0.056305513658376119, 0.056255592908704126, 0.056205672018393590, 0.056155750987568885, 0.056105829816354792, 0.056055908504875684, 0.056005987053257253, +0.055956065461623850, 0.055906143730100284, 0.055856221858810916, 0.055806299847881435, 0.055756377697436202, 0.055706455407600032, 0.055656532978497278, 0.055606610410253630, +0.055556687702993462, 0.055506764856841126, 0.055456841871922326, 0.055406918748361414, 0.055356995486283214, 0.055307072085812078, 0.055257148547073705, 0.055207224870192459, +0.055157301055293158, 0.055107377102500153, 0.055057453011939150, 0.055007528783734522, 0.054957604418011063, 0.054907679914893155, 0.054857755274506488, 0.054807830496975435, +0.054757905582424805, 0.054707980530978965, 0.054658055342763620, 0.054608130017903135, 0.054558204556521883, 0.054508278958745562, 0.054458353224698539, 0.054408427354505642, +0.054358501348291226, 0.054308575206181008, 0.054258648928299347, 0.054208722514771060, 0.054158795965720527, 0.054108869281273446, 0.054058942461554196, 0.054009015506687588, +0.053959088416797994, 0.053909161192011126, 0.053859233832451357, 0.053809306338243504, 0.053759378709511939, 0.053709450946382367, 0.053659523048979176, 0.053609595017426730, +0.053559666851850735, 0.053509738552375577, 0.053459810119126074, 0.053409881552226597, 0.053359952851802867, 0.053310024017979254, 0.053260095050880578, 0.053210165950631216, +0.053160236717356889, 0.053110307351181975, 0.053060377852231284, 0.053010448220629211, 0.052960518456501453, 0.052910588559972403, 0.052860658531166886, 0.052810728370209274, +0.052760798077225286, 0.052710867652339302, 0.052660937095676152, 0.052611006407360210, 0.052561075587517200, 0.052511144636271503, 0.052461213553747499, 0.052411282340070905, +0.052361350995366103, 0.052311419519757922, 0.052261487913370749, 0.052211556176330304, 0.052161624308760965, 0.052111692310787570, 0.052061760182534500, 0.052011827924127466, +0.051961895535690868, 0.051911963017349530, 0.051862030369227839, 0.051812097591451521, 0.051762164684144955, 0.051712231647432980, 0.051662298481439980, 0.051612365186291677, +0.051562431762112462, 0.051512498209026723, 0.051462564527160186, 0.051412630716637230, 0.051362696777582706, 0.051312762710120988, 0.051262828514377815, 0.051212894190477566, +0.051162959738545080, 0.051113025158704757, 0.051063090451082309, 0.051013155615802136, 0.050963220652989076, 0.050913285562767523, 0.050863350345263195, 0.050813415000600493, +0.050763479528904254, 0.050713543930298872, 0.050663608204910074, 0.050613672352862252, 0.050563736374279813, 0.050513800269288471, 0.050463864038012632, 0.050413927680577127, +0.050363991197106363, 0.050314054587726066, 0.050264117852560630, 0.050214180991734900, 0.050164244005373275, 0.050114306893601482, 0.050064369656543928, 0.050014432294325444, +0.049964494807070436, 0.049914557194904632, 0.049864619457952439, 0.049814681596338700, 0.049764743610187810, 0.049714805499625501, 0.049664867264776182, 0.049614928905764251, +0.049564990422715442, 0.049515051815754156, 0.049465113085005244, 0.049415174230593099, 0.049365235252643469, 0.049315296151280746, 0.049265356926629783, 0.049215417578814986, +0.049165478107962089, 0.049115538514195499, 0.049065598797640060, 0.049015658958420180, 0.048965718996661592, 0.048915778912488717, 0.048865838706026385, 0.048815898377399018, +0.048765957926732342, 0.048716017354150778, 0.048666076659779171, 0.048616135843741928, 0.048566194906164782, 0.048516253847172154, 0.048466312666888452, 0.048416371365439408, +0.048366429942949436, 0.048316488399543389, 0.048266546735345674, 0.048216604950482043, 0.048166663045076892, 0.048116721019255092, 0.048066778873141036, 0.048016836606860486, +0.047966894220537841, 0.047916951714297953, 0.047867009088265251, 0.047817066342565467, 0.047767123477323016, 0.047717180492662763, 0.047667237388709108, 0.047617294165587805, +0.047567350823423268, 0.047517407362339906, 0.047467463782463477, 0.047417520083918384, 0.047367576266829491, 0.047317632331321212, 0.047267688277519294, 0.047217744105548159, +0.047167799815532666, 0.047117855407597227, 0.047067910881867597, 0.047017966238468184, 0.046968021477523859, 0.046918076599159031, 0.046868131603499459, 0.046818186490669565, +0.046768241260794194, 0.046718295913997780, 0.046668350450406071, 0.046618404870143487, 0.046568459173334444, 0.046518513360104700, 0.046468567430578672, 0.046418621384881224, +0.046368675223136778, 0.046318728945471087, 0.046268782552008579, 0.046218836042874113, 0.046168889418192111, 0.046118942678088332, 0.046068995822687191, 0.046019048852113560, +0.045969101766491868, 0.045919154565947869, 0.045869207250605976, 0.045819259820591068, 0.045769312276027561, 0.045719364617041229, 0.045669416843756479, 0.045619468956298183, +0.045569520954790776, 0.045519572839360006, 0.045469624610130308, 0.045419676267226108, 0.045369727810773156, 0.045319779240895884, 0.045269830557719166, 0.045219881761367424, +0.045169932851966424, 0.045119983829640595, 0.045070034694514802, 0.045020085446713480, 0.044970136086362390, 0.044920186613585961, 0.044870237028509057, 0.044820287331256127, +0.044770337521952919, 0.044720387600723860, 0.044670437567693844, 0.044620487422987284, 0.044570537166729950, 0.044520586799046268, 0.044470636320060680, 0.044420685729898948, +0.044370735028685500, 0.044320784216545214, 0.044270833293602520, 0.044220882259983191, 0.044170931115811655, 0.044120979861212793, 0.044071028496311032, 0.044021077021232147, +0.043971125436100572, 0.043921173741041181, 0.043871221936178414, 0.043821270021638034, 0.043771317997544475, 0.043721365864022629, 0.043671413621196919, 0.043621461269193119, +0.043571508808135664, 0.043521556238149003, 0.043471603559358883, 0.043421650771889760, 0.043371697875866512, 0.043321744871413576, 0.043271791758656718, 0.043221838537720381, +0.043171885208729451, 0.043121931771808356, 0.043071978227082884, 0.043022024574677464, 0.042972070814716982, 0.042922116947325881, 0.042872162972629926, 0.042822208890753569, +0.042772254701821687, 0.042722300405958723, 0.042672346003290458, 0.042622391493941321, 0.042572436878036211, 0.042522482155699565, 0.042472527327057155, 0.042422572392233425, +0.042372617351352823, 0.042322662204541117, 0.042272706951922763, 0.042222751593622633, 0.042172796129765183, 0.042122840560476195, 0.042072884885880096, 0.042022929106101788, +0.041972973221265711, 0.041923017231497647, 0.041873061136922039, 0.041823104937663780, 0.041773148633847318, 0.041723192225598421, 0.041673235713041545, 0.041623279096301584, +0.041573322375502979, 0.041523365550771511, 0.041473408622231631, 0.041423451590007786, 0.041373494454225751, 0.041323537215009983, 0.041273579872485373, 0.041223622426776373, +0.041173664878008755, 0.041123707226306976, 0.041073749471795928, 0.041023791614600062, 0.040973833654845165, 0.040923875592655680, 0.040873917428156506, 0.040823959161472100, +0.040774000792728235, 0.040724042322049368, 0.040674083749560400, 0.040624125075385771, 0.040574166299651278, 0.040524207422481369, 0.040474248444000500, 0.040424289364334454, +0.040374330183607678, 0.040324370901945079, 0.040274411519471115, 0.040224452036311559, 0.040174492452590874, 0.040124532768433960, 0.040074572983965266, 0.040024613099310588, +0.039974653114594375, 0.039924693029941533, 0.039874732845476511, 0.039824772561325099, 0.039774812177611758, 0.039724851694461390, 0.039674891111998449, 0.039624930430348718, +0.039574969649636665, 0.039525008769986741, 0.039475047791524741, 0.039425086714375120, 0.039375125538662785, 0.039325164264512193, 0.039275202892049131, 0.039225241421398063, +0.039175279852683889, 0.039125318186031072, 0.039075356421565406, 0.039025394559411349, 0.038975432599693806, 0.038925470542537234, 0.038875508388067435, 0.038825546136408859, +0.038775583787686425, 0.038725621342024584, 0.038675658799549130, 0.038625696160384533, 0.038575733424655693, 0.038525770592487081, 0.038475807664004477, 0.038425844639332365, +0.038375881518595188, 0.038325918301918754, 0.038275954989427527, 0.038225991581246413, 0.038176028077499875, 0.038126064478313709, 0.038076100783812385, 0.038026136994120802, +0.037976173109363437, 0.037926209129666086, 0.037876245055153211, 0.037826280885949720, 0.037776316622180083, 0.037726352263970100, 0.037676387811444237, 0.037626423264727406, +0.037576458623944070, 0.037526493889220032, 0.037476529060679761, 0.037426564138447721, 0.037376599122649720, 0.037326634013410215, 0.037276668810854126, 0.037226703515105923, +0.037176738126291402, 0.037126772644535039, 0.037076807069961748, 0.037026841402695986, 0.036976875642863574, 0.036926909790588963, 0.036876943845997087, 0.036826977809212402, +0.036777011680360717, 0.036727045459566503, 0.036677079146954679, 0.036627112742649709, 0.036577146246777402, 0.036527179659462228, 0.036477212980828663, 0.036427246211002511, +0.036377279350108239, 0.036327312398270771, 0.036277345355614575, 0.036227378222265468, 0.036177410998347904, 0.036127443683986821, 0.036077476279306686, 0.036027508784433296, +0.035977541199491141, 0.035927573524605134, 0.035877605759899747, 0.035827637905500788, 0.035777669961532733, 0.035727701928120505, 0.035677733805388578, 0.035627765593462764, +0.035577797292467531, 0.035527828902527807, 0.035477860423768062, 0.035427891856314120, 0.035377923200290443, 0.035327954455821514, 0.035277985623033137, 0.035228016702049801, +0.035178047692996428, 0.035128078595997488, 0.035078109411178796, 0.035028140138664829, 0.034978170778580508, 0.034928201331050325, 0.034878231796200074, 0.034828262174154252, +0.034778292465037768, 0.034728322668975110, 0.034678352786092090, 0.034628382816513190, 0.034578412760363331, 0.034528442617766997, 0.034478472388850004, 0.034428502073736822, +0.034378531672551949, 0.034328561185421186, 0.034278590612469018, 0.034228619953820379, 0.034178649209599739, 0.034128678379932928, 0.034078707464944416, 0.034028736464759138, +0.033978765379501570, 0.033928794209297543, 0.033878822954271519, 0.033828851614548447, 0.033778880190252797, 0.033728908681510385, 0.033678937088445708, 0.033628965411183688, +0.033578993649848815, 0.033529021804566891, 0.033479049875462422, 0.033429077862659883, 0.033379105766285090, 0.033329133586462535, 0.033279161323317138, 0.033229188976973405, +0.033179216547557136, 0.033129244035192830, 0.033079271440005414, 0.033029298762119373, 0.032979326001660529, 0.032929353158753373, 0.032879380233522833, 0.032829407226093399, +0.032779434136590888, 0.032729460965139796, 0.032679487711865046, 0.032629514376891135, 0.032579540960343885, 0.032529567462347780, 0.032479593883027312, 0.032429620222508303, +0.032379646480915243, 0.032329672658373068, 0.032279698755006268, 0.032229724770940667, 0.032179750706300754, 0.032129776561211458, 0.032079802335797283, 0.032029828030184046, +0.031979853644496237, 0.031929879178858790, 0.031879904633396204, 0.031829930008234301, 0.031779955303497580, 0.031729980519310960, 0.031680005655798947, 0.031630030713087370, +0.031580055691300707, 0.031530080590563912, 0.031480105411001470, 0.031430130152739211, 0.031380154815901617, 0.031330179400613202, 0.031280203906999780, 0.031230228335185847, +0.031180252685296343, 0.031130276957455762, 0.031080301151789936, 0.031030325268423354, 0.030980349307480962, 0.030930373269087250, 0.030880397153368048, 0.030830420960447857, +0.030780444690451610, 0.030730468343503809, 0.030680491919730282, 0.030630515419255523, 0.030580538842204477, 0.030530562188701638, 0.030480585458872840, 0.030430608652842576, +0.030380631770735349, 0.030330654812676987, 0.030280677778791985, 0.030230700669205291, 0.030180723484041400, 0.030130746223426146, 0.030080768887484025, 0.030030791476339982, +0.029980813990118517, 0.029930836428945458, 0.029880858792945310, 0.029830881082243015, 0.029780903296963073, 0.029730925437231319, 0.029680947503172250, 0.029630969494910810, +0.029580991412571506, 0.029531013256280166, 0.029481035026161291, 0.029431056722339387, 0.029381078344940286, 0.029331099894088487, 0.029281121369908937, 0.029231142772526142, +0.029181164102065935, 0.029131185358652816, 0.029081206542411732, 0.029031227653467190, 0.028981248691945023, 0.028931269657969733, 0.028881290551666269, 0.028831311373159137, +0.028781332122574169, 0.028731352800035869, 0.028681373405669189, 0.028631393939598630, 0.028581414401950032, 0.028531434792847896, 0.028481455112417176, 0.028431475360782370, +0.028381495538069325, 0.028331515644402536, 0.028281535679906517, 0.028231555644707102, 0.028181575538928798, 0.028131595362696556, 0.028081615116134880, 0.028031634799369608, +0.027981654412525252, 0.027931673955726762, 0.027881693429098641, 0.027831712832766729, 0.027781732166855536, 0.027731751431490013, 0.027681770626794666, 0.027631789752895340, +0.027581808809916536, 0.027531827797983213, 0.027481846717219875, 0.027431865567752362, 0.027381884349705187, 0.027331903063202857, 0.027281921708371216, 0.027231940285334769, +0.027181958794218471, 0.027131977235146831, 0.027081995608245691, 0.027032013913639564, 0.026982032151453401, 0.026932050321811715, 0.026882068424840349, 0.026832086460663811, +0.026782104429407053, 0.026732122331194593, 0.026682140166152273, 0.026632157934404599, 0.026582175636076531, 0.026532193271292581, 0.026482210840178589, 0.026432228342859073, +0.026382245779458541, 0.026332263150102841, 0.026282280454916481, 0.026232297694024419, 0.026182314867551168, 0.026132331975622577, 0.026082349018363156, 0.026032365995897859, +0.025982382908351205, 0.025932399755849038, 0.025882416538515873, 0.025832433256476665, 0.025782449909855929, 0.025732466498779513, 0.025682483023371932, 0.025632499483758141, +0.025582515880062658, 0.025532532212411332, 0.025482548480928673, 0.025432564685739199, 0.025382580826968759, 0.025332596904741864, 0.025282612919183479, 0.025232628870418116, +0.025182644758571626, 0.025132660583768524, 0.025082676346133773, 0.025032692045791883, 0.024982707682868709, 0.024932723257488767, 0.024882738769777014, 0.024832754219857971, +0.024782769607857486, 0.024732784933900080, 0.024682800198110710, 0.024632815400613895, 0.024582830541535483, 0.024532845620999999, 0.024482860639132398, 0.024432875596057203, +0.024382890491900264, 0.024332905326786097, 0.024282920100839222, 0.024232934814185494, 0.024182949466949426, 0.024132964059255985, 0.024082978591229692, 0.024032993062996392, +0.023983007474680611, 0.023933021826407313, 0.023883036118301018, 0.023833050350487574, 0.023783064523091504, 0.023733078636237772, 0.023683092690050901, 0.023633106684656742, +0.023583120620179816, 0.023533134496745090, 0.023483148314477082, 0.023433162073501646, 0.023383175773943308, 0.023333189415926586, 0.023283202999577333, 0.023233216525020074, +0.023183229992379772, 0.023133243401780954, 0.023083256753349466, 0.023033270047209842, 0.022983283283487040, 0.022933296462305585, 0.022883309583791336, 0.022833322648068810, +0.022783335655262978, 0.022733348605498364, 0.022683361498900823, 0.022633374335594876, 0.022583387115705494, 0.022533399839357201, 0.022483412506675852, 0.022433425117785972, +0.022383437672812083, 0.022333450171880046, 0.022283462615114383, 0.022233475002640064, 0.022183487334581614, 0.022133499611064887, 0.022083511832214416, 0.022033523998155162, +0.021983536109011652, 0.021933548164909750, 0.021883560165973974, 0.021833572112329301, 0.021783584004100253, 0.021733595841412687, 0.021683607624391133, 0.021633619353160560, +0.021583631027845492, 0.021533642648571792, 0.021483654215463988, 0.021433665728647047, 0.021383677188245496, 0.021333688594385197, 0.021283699947190676, 0.021233711246786462, +0.021183722493298415, 0.021133733686851060, 0.021083744827569369, 0.021033755915577875, 0.020983766951002434, 0.020933777933967578, 0.020883788864598275, 0.020833799743019056, +0.020783810569355781, 0.020733821343732979, 0.020683832066275627, 0.020633842737108249, 0.020583853356356707, 0.020533863924145534, 0.020483874440599698, 0.020433884905843733, +0.020383895320003502, 0.020333905683203531, 0.020283915995568353, 0.020233926257223825, 0.020183936468294486, 0.020133946628905303, 0.020083956739180810, 0.020033966799246870, +0.019983976809228015, 0.019933986769249214, 0.019883996679435006, 0.019834006539911245, 0.019784016350802472, 0.019734026112233658, 0.019684035824329333, 0.019634045487215365, +0.019584055101016278, 0.019534064665857057, 0.019484074181862231, 0.019434083649157663, 0.019384093067867886, 0.019334102438117430, 0.019284111760032165, 0.019234121033736621, +0.019184130259355770, 0.019134139437014152, 0.019084148566837631, 0.019034157648950736, 0.018984166683478448, 0.018934175670545301, 0.018884184610277157, 0.018834193502798552, +0.018784202348234462, 0.018734211146709423, 0.018684219898349300, 0.018634228603278628, 0.018584237261622383, 0.018534245873505103, 0.018484254439052650, 0.018434262958389562, +0.018384271431640373, 0.018334279858930949, 0.018284288240385825, 0.018234296576129981, 0.018184304866287953, 0.018134313110985605, 0.018084321310347474, 0.018034329464498539, +0.017984337573563339, 0.017934345637667739, 0.017884353656936271, 0.017834361631493923, 0.017784369561465226, 0.017734377446976046, 0.017684385288150927, 0.017634393085114840, +0.017584400837992332, 0.017534408546909262, 0.017484416211990171, 0.017434423833360042, 0.017384431411143406, 0.017334438945466137, 0.017284446436452772, 0.017234453884227844, +0.017184461288917225, 0.017134468650645454, 0.017084475969537515, 0.017034483245717939, 0.016984490479312598, 0.016934497670446032, 0.016884504819243220, 0.016834511925828705, +0.016784518990328352, 0.016734526012866704, 0.016684532993568736, 0.016634539932558996, 0.016584546829963350, 0.016534553685906336, 0.016484560500512935, 0.016434567273907692, +0.016384574006216474, 0.016334580697563824, 0.016284587348074274, 0.016234593957873703, 0.016184600527086642, 0.016134607055838083, 0.016084613544252564, 0.016034619992455954, +0.015984626400572792, 0.015934632768728065, 0.015884639097046314, 0.015834645385653406, 0.015784651634673887, 0.015734657844232738, 0.015684664014454501, 0.015634670145465050, +0.015584676237388920, 0.015534682290351100, 0.015484688304476132, 0.015434694279889886, 0.015384700216716904, 0.015334706115081729, 0.015284711975110232, 0.015234717796926953, +0.015184723580656883, 0.015134729326424557, 0.015084735034355853, 0.015034740704575313, 0.014984746337207918, 0.014934751932378216, 0.014884757490212076, 0.014834763010834045, +0.014784768494369103, 0.014734773940941798, 0.014684779350678002, 0.014634784723702257, 0.014584790060139552, 0.014534795360114426, 0.014484800623752755, 0.014434805851179084, +0.014384811042518398, 0.014334816197895240, 0.014284821317435487, 0.014234826401263679, 0.014184831449504361, 0.014134836462283409, 0.014084841439725366, 0.014034846381955219, +0.013984851289097513, 0.013934856161278122, 0.013884860998621591, 0.013834865801252906, 0.013784870569296614, 0.013734875302878589, 0.013684880002123376, 0.013634884667155962, +0.013584889298100894, 0.013534893895084046, 0.013484898458229963, 0.013434902987663635, 0.013384907483509605, 0.013334911945893750, 0.013284916374940616, 0.013234920770774745, +0.013184925133522018, 0.013134929463306978, 0.013084933760254613, 0.013034938024489471, 0.012984942256137427, 0.012934946455323027, 0.012884950622171262, 0.012834954756806675, +0.012784958859355147, 0.012734962929941222, 0.012684966968689888, 0.012634970975725694, 0.012584974951174515, 0.012534978895160901, 0.012484982807809837, 0.012434986689245874, +0.012384990539594886, 0.012334994358981425, 0.012284998147530032, 0.012235001905366588, 0.012185005632615639, 0.012135009329402176, 0.012085012995850746, 0.012035016632087227, +0.011985020238236168, 0.011935023814422557, 0.011885027360770942, 0.011835030877407202, 0.011785034364455887, 0.011735037822041985, 0.011685041250290044, 0.011635044649325946, +0.011585048019274234, 0.011535051360259903, 0.011485054672407499, 0.011435057955842903, 0.011385061210690661, 0.011335064437075324, 0.011285067635122768, 0.011235070804957545, +0.011185073946704644, 0.011135077060488613, 0.011085080146435333, 0.011035083204669355, 0.010985086235315668, 0.010935089238498820, 0.010885092214344695, 0.010835095162977839, +0.010785098084523244, 0.010735100979105461, 0.010685103846850369, 0.010635106687882517, 0.010585109502326899, 0.010535112290308063, 0.010485115051951890, 0.010435117787382930, +0.010385120496726175, 0.010335123180106175, 0.010285125837648811, 0.010235128469478633, 0.010185131075720189, 0.010135133656499361, 0.010085136211940699, 0.010035138742169197, +0.009985141247309405, 0.009935143727487203, 0.009885146182827142, 0.009835148613454215, 0.009785151019492972, 0.009735153401069296, 0.009685155758307737, 0.009635158091333288, +0.009585160400270500, 0.009535162685245254, 0.009485164946382102, 0.009435167183806039, 0.009385169397641613, 0.009335171588014706, 0.009285173755049872, 0.009235175898871659, +0.009185178019605951, 0.009135180117377297, 0.009085182192310694, 0.009035184244530689, 0.008985186274163171, 0.008935188281332685, 0.008885190266164227, 0.008835192228782351, +0.008785194169312938, 0.008735196087880540, 0.008685197984610153, 0.008635199859626325, 0.008585201713054942, 0.008535203545020555, 0.008485205355648159, 0.008435207145062306, +0.008385208913388878, 0.008335210660752429, 0.008285212387277509, 0.008235214093090002, 0.008185215778314459, 0.008135217443075878, 0.008085219087498808, 0.008035220711709135, +0.007985222315831410, 0.007935223899990629, 0.007885225464311346, 0.007835227008919440, 0.007785228533939469, 0.007735230039496426, 0.007685231525714864, 0.007635232992720667, +0.007585234440638388, 0.007535235869593022, 0.007485237279709124, 0.007435238671112575, 0.007385240043927930, 0.007335241398280185, 0.007285242734293892, 0.007235244052094937, +0.007185245351807872, 0.007135246633557249, 0.007085247897468953, 0.007035249143667537, 0.006985250372277999, 0.006935251583424892, 0.006885252777234099, 0.006835253953830174, +0.006785255113338114, 0.006735256255882473, 0.006685257381589134, 0.006635258490582652, 0.006585259582988025, 0.006535260658929804, 0.006485261718533876, 0.006435262761924793, +0.006385263789227553, 0.006335264800566710, 0.006285265796068149, 0.006235266775856423, 0.006185267740056086, 0.006135268688793025, 0.006085269622191791, 0.006035270540377383, +0.005985271443474355, 0.005935272331608592, 0.005885273204904649, 0.005835274063487523, 0.005785274907481767, 0.005735275737013268, 0.005685276552206580, 0.005635277353186701, +0.005585278140078183, 0.005535278913006915, 0.005485279672097450, 0.005435280417474785, 0.005385281149263474, 0.005335281867589406, 0.005285282572577133, 0.005235283264351209, +0.005185283943037521, 0.005135284608760623, 0.005085285261645514, 0.005035285901816748, 0.004985286529400210, 0.004935287144520456, 0.004885287747302485, 0.004835288337870850, +0.004785288916351439, 0.004735289482868805, 0.004685290037547947, 0.004635290580513421, 0.004585291111891111, 0.004535291631805574, 0.004485292140381809, 0.004435292637744368, +0.004385293124019140, 0.004335293599330679, 0.004285294063803541, 0.004235294517563611, 0.004185294960735444, 0.004135295393444041, 0.004085295815813955, 0.004035296227971073, +0.003985296630039951, 0.003935297022145587, 0.003885297404412537, 0.003835297776966687, 0.003785298139932593, 0.003735298493435253, 0.003685298837599223, 0.003635299172550391, +0.003585299498413309, 0.003535299815312980, 0.003485300123373957, 0.003435300422722127, 0.003385300713482047, 0.003335300995778715, 0.003285301269736686, 0.003235301535481848, +0.003185301793138756, 0.003135302042831966, 0.003085302284687364, 0.003035302518829507, 0.002985302745383394, 0.002935302964473579, 0.002885303176225952, 0.002835303380765067, +0.002785303578215922, 0.002735303768703075, 0.002685303952352413, 0.002635304129288491, 0.002585304299636308, 0.002535304463520421, 0.002485304621066716, 0.002435304772399750, +0.002385304917644522, 0.002335305056925588, 0.002285305190368835, 0.002235305318098819, 0.002185305440240096, 0.002135305556918553, 0.002085305668258747, 0.002035305774385676, +0.001985305875423896, 0.001935305971499296, 0.001885306062736431, 0.001835306149260301, 0.001785306231195462, 0.001735306308667801, 0.001685306381801874, 0.001635306450722681, +0.001585306515554778, 0.001535306576424053, 0.001485306633455062, 0.001435306686772804, 0.001385306736501835, 0.001335306782768043, 0.001285306825695984, 0.001235306865410214, +0.001185306902036622, 0.001135306935699761, 0.001085306966524634, 0.001035306994635795, 0.000985307020159133, 0.000935307043219203, 0.000885307063941005, 0.000835307082449096, +0.000785307098869363, 0.000735307113326362, 0.000685307125945094, 0.000635307136850113, 0.000585307146167309, 0.000535307154021237, 0.000485307160536898, 0.000435307165838846, +0.000385307170052970, 0.000335307173303827, 0.000285307175716415, 0.000235307177415291, 0.000185307178526344, 0.000135307179174129, 0.000085307179483201, 0.000035307179579450, +-0.000014692820412569, -0.000064692820367856, -0.000114692820161855, -0.000164692819668678, -0.000214692818763769, -0.000264692817322128, -0.000314692815219199, -0.000364692812329094, +-0.000414692808527257, -0.000464692803688688, -0.000514692797688831, -0.000564692790401798, -0.000614692781703032, -0.000664692771467535, -0.000714692759570750, -0.000764692745886789, +-0.000814692730291096, -0.000864692712659116, -0.000914692692864960, -0.000964692670784071, -0.001014692646291452, -0.001064692619262544, -0.001114692589571461, -0.001164692557093647, +-0.001214692521704101, -0.001264692483278268, -0.001314692441690259, -0.001364692396815520, -0.001414692348529050, -0.001464692296706292, -0.001514692241221360, -0.001564692181949697, +-0.001614692118766304, -0.001664692051546625, -0.001714691980164771, -0.001764691904496188, -0.001814691824416319, -0.001864691739799276, -0.001914691650520504, -0.001964691556455003, +-0.002014691457478216, -0.002064691353464257, -0.002114691244288570, -0.002164691129826155, -0.002214691009952456, -0.002264690884541585, -0.002314690753468987, -0.002364690616609663, +-0.002414690473839055, -0.002464690325031278, -0.002514690170061775, -0.002564690008805546, -0.002614689841138036, -0.002664689666933358, -0.002714689486066956, -0.002764689298414273, +-0.002814689103849424, -0.002864688902247852, -0.002914688693484557, -0.002964688477434985, -0.003014688253973248, -0.003064688022974790, -0.003114687784314611, -0.003164687537868158, +-0.003214687283509542, -0.003264687021114207, -0.003314686750557155, -0.003364686471713830, -0.003414686184458345, -0.003464685888666144, -0.003514685584212229, -0.003564685270972043, +-0.003614684948819701, -0.003664684617630646, -0.003714684277279879, -0.003764683927642846, -0.003814683568593659, -0.003864683200007764, -0.003914682821760604, -0.003964682433726293, +-0.004014682035780276, -0.004064681627797554, -0.004114681209653572, -0.004164680781222442, -0.004214680342379612, -0.004264679893000080, -0.004314679432959292, -0.004364678962131362, +-0.004414678480391734, -0.004464677987615410, -0.004514677483677836, -0.004564676968453123, -0.004614676441816718, -0.004664675903643622, -0.004714675353809280, -0.004764674792187806, +-0.004814674218654644, -0.004864673633085242, -0.004914673035353711, -0.004964672425335498, -0.005014671802905603, -0.005064671167939473, -0.005114670520311221, -0.005164669859896293, +-0.005214669186569690, -0.005264668500206859, -0.005314667800681912, -0.005364667087870295, -0.005414666361647010, -0.005464665621887505, -0.005514664868465890, -0.005564664101257614, +-0.005614663320137677, -0.005664662524981526, -0.005714661715663275, -0.005764660892058370, -0.005814660054042256, -0.005864659201489048, -0.005914658334274192, -0.005964657452272691, +-0.006014656555359989, -0.006064655643410202, -0.006114654716298777, -0.006164653773900714, -0.006214652816091461, -0.006264651842745132, -0.006314650853737174, -0.006364649848942587, +-0.006414648828236821, -0.006464647791493989, -0.006514646738589537, -0.006564645669398468, -0.006614644583796229, -0.006664643481656934, -0.006714642362856032, -0.006764641227268523, +-0.006814640074769854, -0.006864638905234142, -0.006914637718536832, -0.006964636514553373, -0.007014635293157877, -0.007064634054225794, -0.007114632797632125, -0.007164631523252319, +-0.007214630230960490, -0.007264628920632085, -0.007314627592142108, -0.007364626245366005, -0.007414624880177894, -0.007464623496453220, -0.007514622094066987, -0.007564620672894643, +-0.007614619232810304, -0.007664617773689416, -0.007714616295406984, -0.007764614797838455, -0.007814613280857946, -0.007864611744340902, -0.007914610188162774, -0.007964608612197676, +-0.008014607016321057, -0.008064605400407919, -0.008114603764333714, -0.008164602107972555, -0.008214600431199889, -0.008264598733890722, -0.008314597015920503, -0.008364595277163349, +-0.008414593517494705, -0.008464591736789576, -0.008514589934923414, -0.008564588111770332, -0.008614586267205781, -0.008664584401104764, -0.008714582513342728, -0.008764580603793794, +-0.008814578672333408, -0.008864576718837018, -0.008914574743178742, -0.008964572745234031, -0.009014570724877888, -0.009064568681985762, -0.009114566616431770, -0.009164564528091361, +-0.009214562416839541, -0.009264560282551760, -0.009314558125102132, -0.009364555944366110, -0.009414553740218698, -0.009464551512535346, -0.009514549261190171, -0.009564546986058624, +-0.009614544687015707, -0.009664542363936874, -0.009714540016696241, -0.009764537645169259, -0.009814535249231374, -0.009864532828756710, -0.009914530383620711, -0.009964527913698389, +-0.010014525418865189, -0.010064522898995232, -0.010114520353963968, -0.010164517783646403, -0.010214515187917989, -0.010264512566652841, -0.010314509919726413, -0.010364507247013708, +-0.010414504548390180, -0.010464501823729948, -0.010514499072908461, -0.010564496295800726, -0.010614493492282193, -0.010664490662226984, -0.010714487805510547, -0.010764484922007891, +-0.010814482011594467, -0.010864479074144394, -0.010914476109533123, -0.010964473117636106, -0.011014470098327463, -0.011064467051482643, -0.011114463976976656, -0.011164460874684954, +-0.011214457744481654, -0.011264454586242211, -0.011314451399841632, -0.011364448185155368, -0.011414444942057539, -0.011464441670423597, -0.011514438370128553, -0.011564435041047856, +-0.011614431683055627, -0.011664428296027318, -0.011714424879837940, -0.011764421434362944, -0.011814417959476449, -0.011864414455053910, -0.011914410920970779, -0.011964407357101177, +-0.012014403763320554, -0.012064400139503923, -0.012114396485526738, -0.012164392801263114, -0.012214389086588512, -0.012264385341377934, -0.012314381565506839, -0.012364377758849344, +-0.012414373921280905, -0.012464370052676532, -0.012514366152911679, -0.012564362221860465, -0.012614358259398346, -0.012664354265400331, -0.012714350239741875, -0.012764346182297099, +-0.012814342092941456, -0.012864337971550404, -0.012914333817998062, -0.012964329632159885, -0.013014325413910885, -0.013064321163126516, -0.013114316879680898, -0.013164312563449489, +-0.013214308214307299, -0.013264303832129782, -0.013314299416791062, -0.013364294968166593, -0.013414290486131386, -0.013464285970560898, -0.013514281421329251, -0.013564276838311899, +-0.013614272221383856, -0.013664267570420576, -0.013714262885296183, -0.013764258165886134, -0.013814253412065438, -0.013864248623709554, -0.013914243800692604, -0.013964238942890044, +-0.014014234050177330, -0.014064229122428587, -0.014114224159519273, -0.014164219161324397, -0.014214214127719418, -0.014264209058578460, -0.014314203953776979, -0.014364198813189987, +-0.014414193636692942, -0.014464188424159970, -0.014514183175466527, -0.014564177890487626, -0.014614172569098723, -0.014664167211173945, -0.014714161816588750, -0.014764156385218151, +-0.014814150916937604, -0.014864145411621236, -0.014914139869144503, -0.014964134289382865, -0.015014128672210449, -0.015064123017502710, -0.015114117325134664, -0.015164111594981768, +-0.015214105826918149, -0.015264100020819266, -0.015314094176560133, -0.015364088294016209, -0.015414082373061619, -0.015464076413571823, -0.015514070415421837, -0.015564064378487119, +-0.015614058302641795, -0.015664052187761325, -0.015714046033720726, -0.015764039840395455, -0.015814033607659643, -0.015864027335388744, -0.015914021023458222, -0.015964014671742202, +-0.016014008280116145, -0.016064001848455071, -0.016113995376634434, -0.016163988864528363, -0.016213982312012321, -0.016263975718961324, -0.016313969085250832, -0.016363962410754971, +-0.016413955695349206, -0.016463948938908551, -0.016513942141308469, -0.016563935302423088, -0.016613928422127867, -0.016663921500297826, -0.016713914536808424, -0.016763907531533791, +-0.016813900484349390, -0.016863893395130239, -0.016913886263751798, -0.016963879090088198, -0.017013871874014899, -0.017063864615407365, -0.017113857314139724, -0.017163849970087443, +-0.017213842583125534, -0.017263835153129462, -0.017313827679973359, -0.017363820163532689, -0.017413812603682466, -0.017463805000298160, -0.017513797353253893, -0.017563789662425132, +-0.017613781927686898, -0.017663774148914655, -0.017713766325982531, -0.017763758458765991, -0.017813750547140055, -0.017863742590980190, -0.017913734590160522, -0.017963726544556517, +-0.018013718454043638, -0.018063710318496021, -0.018113702137789130, -0.018163693911797979, -0.018213685640398040, -0.018263677323463443, -0.018313668960869653, -0.018363660552491688, +-0.018413652098205020, -0.018463643597883776, -0.018513635051403420, -0.018563626458638981, -0.018613617819465918, -0.018663609133758367, -0.018713600401391792, -0.018763591622241213, +-0.018813582796182105, -0.018863573923088593, -0.018913565002836145, -0.018963556035300231, -0.019013547020354980, -0.019063537957875864, -0.019113528847737902, -0.019163519689816565, +-0.019213510483985979, -0.019263501230121622, -0.019313491928098510, -0.019363482577792111, -0.019413473179076563, -0.019463463731827332, -0.019513454235919443, -0.019563444691228359, +-0.019613435097628223, -0.019663425454994495, -0.019713415763202208, -0.019763406022126822, -0.019813396231642480, -0.019863386391624643, -0.019913376501948788, -0.019963366562489048, +-0.020013356573120887, -0.020063346533719339, -0.020113336444159868, -0.020163326304316612, -0.020213316114065037, -0.020263305873280176, -0.020313295581837493, -0.020363285239611124, +-0.020413274846476547, -0.020463264402308778, -0.020513253906983296, -0.020563243360374236, -0.020613232762357065, -0.020663222112806811, -0.020713211411598948, -0.020763200658607612, +-0.020813189853708274, -0.020863178996775960, -0.020913168087686142, -0.020963157126312963, -0.021013146112531890, -0.021063135046218397, -0.021113123927246621, -0.021163112755492035, +-0.021213101530829667, -0.021263090253134991, -0.021313078922282142, -0.021363067538146596, -0.021413056100603383, -0.021463044609527974, -0.021513033064794511, -0.021563021466278462, +-0.021613009813854861, -0.021662998107399179, -0.021712986346785559, -0.021762974531889471, -0.021812962662585946, -0.021862950738750463, -0.021912938760257156, -0.021962926726981500, +-0.022012914638798974, -0.022062902495583719, -0.022112890297211203, -0.022162878043556464, -0.022212865734494977, -0.022262853369900876, -0.022312840949649644, -0.022362828473616311, +-0.022412815941676351, -0.022462803353703903, -0.022512790709574453, -0.022562778009163020, -0.022612765252345089, -0.022662752438994800, -0.022712739568987630, -0.022762726642198614, +-0.022812713658503223, -0.022862700617775601, -0.022912687519891232, -0.022962674364725585, -0.023012661152152811, -0.023062647882048381, -0.023112634554287335, -0.023162621168745144, +-0.023212607725295958, -0.023262594223815249, -0.023312580664178059, -0.023362567046259858, -0.023412553369934797, -0.023462539635078352, -0.023512525841565560, -0.023562511989271895, +-0.023612498078071507, -0.023662484107839873, -0.023712470078452029, -0.023762455989783451, -0.023812441841708294, -0.023862427634102030, -0.023912413366839698, -0.023962399039796776, +-0.024012384652847413, -0.024062370205867087, -0.024112355698731280, -0.024162341131314140, -0.024212326503491147, -0.024262311815137338, -0.024312297066128193, -0.024362282256337863, +-0.024412267385641825, -0.024462252453915121, -0.024512237461033228, -0.024562222406870299, -0.024612207291301813, -0.024662192114202806, -0.024712176875448768, -0.024762161574913840, +-0.024812146212473508, -0.024862130788002812, -0.024912115301377234, -0.024962099752470924, -0.025012084141159362, -0.025062068467318035, -0.025112052730821094, -0.025162036931544018, +-0.025212021069361851, -0.025262005144150078, -0.025311989155782845, -0.025361973104135641, -0.025411956989083502, -0.025461940810501918, -0.025511924568265034, -0.025561908262248342, +-0.025611891892326877, -0.025661875458376129, -0.025711858960270246, -0.025761842397884715, -0.025811825771094581, -0.025861809079775325, -0.025911792323801100, -0.025961775503047398, +-0.026011758617389698, -0.026061741666702158, -0.026111724650860268, -0.026161707569739061, -0.026211690423214033, -0.026261673211159332, -0.026311655933450449, -0.026361638589962429, +-0.026411621180570753, -0.026461603705149581, -0.026511586163574401, -0.026561568555720252, -0.026611550881462630, -0.026661533140675684, -0.026711515333234907, -0.026761497459015342, +-0.026811479517892475, -0.026861461509740465, -0.026911443434434804, -0.026961425291850975, -0.027011407081863142, -0.027061388804346789, -0.027111370459176967, -0.027161352046229159, +-0.027211333565377530, -0.027261315016497565, -0.027311296399464315, -0.027361277714153264, -0.027411258960438580, -0.027461240138195744, -0.027511221247299811, -0.027561202287626266, +-0.027611183259049273, -0.027661164161444322, -0.027711144994686462, -0.027761125758651181, -0.027811106453212640, -0.027861087078246336, -0.027911067633627315, -0.027961048119231065, +-0.028011028534931755, -0.028061008880604872, -0.028110989156125910, -0.028160969361369033, -0.028210949496209729, -0.028260929560523056, -0.028310909554184499, -0.028360889477068225, +-0.028410869329049730, -0.028460849110004058, -0.028510828819806711, -0.028560808458331845, -0.028610788025454959, -0.028660767521051102, -0.028710746944995771, -0.028760726297163131, +-0.028810705577428673, -0.028860684785667449, -0.028910663921754960, -0.028960642985565367, -0.029010621976974165, -0.029060600895856853, -0.029110579742087594, -0.029160558515541887, +-0.029210537216094783, -0.029260515843621781, -0.029310494397997044, -0.029360472879096072, -0.029410451286793919, -0.029460429620966080, -0.029510407881486723, -0.029560386068231345, +-0.029610364181075002, -0.029660342219893197, -0.029710320184560088, -0.029760298074951178, -0.029810275890941526, -0.029860253632406627, -0.029910231299220651, -0.029960208891259096, +-0.030010186408397463, -0.030060163850509917, -0.030110141217471964, -0.030160118509158659, -0.030210095725445502, -0.030260072866206657, -0.030310049931317636, -0.030360026920653486, +-0.030410003834089715, -0.030459980671500488, -0.030509957432761310, -0.030559934117747239, -0.030609910726333778, -0.030659887258395097, -0.030709863713806695, -0.030759840092443636, +-0.030809816394181417, -0.030859792618894218, -0.030909768766457534, -0.030959744836746430, -0.031009720829636406, -0.031059696745001638, -0.031109672582717626, -0.031159648342659878, +-0.031209624024702565, -0.031259599628721192, -0.031309575154590819, -0.031359550602186953, -0.031409525971383766, -0.031459501262056766, -0.031509476474081012, -0.031559451607332006, +-0.031609426661683933, -0.031659401637012294, -0.031709376533192148, -0.031759351350099004, -0.031809326087607039, -0.031859300745591762, -0.031909275323928225, -0.031959249822491952, +-0.032009224241157104, -0.032059198579799199, -0.032109172838293738, -0.032159147016514907, -0.032209121114338206, -0.032259095131638701, -0.032309069068291903, -0.032359042924171987, +-0.032409016699154469, -0.032458990393114402, -0.032508964005927309, -0.032558937537467358, -0.032608910987610061, -0.032658884356230489, -0.032708857643204151, -0.032758830848405224, +-0.032808803971709224, -0.032858777012991211, -0.032908749972126700, -0.032958722848989867, -0.033008695643456230, -0.033058668355401298, -0.033108640984699247, -0.033158613531225602, +-0.033208585994855419, -0.033258558375464209, -0.033308530672926169, -0.033358502887116795, -0.033408475017911166, -0.033458447065184797, -0.033508419028811860, -0.033558390908667877, +-0.033608362704627921, -0.033658334416567501, -0.033708306044360800, -0.033758277587883329, -0.033808249047010172, -0.033858220421616833, -0.033908191711577496, -0.033958162916767683, +-0.034008134037062911, -0.034058105072337350, -0.034108076022466537, -0.034158046887325523, -0.034208017666789846, -0.034257988360733675, -0.034307958969032534, -0.034357929491561495, +-0.034407899928196074, -0.034457870278810462, -0.034507840543280176, -0.034557810721480287, -0.034607780813286318, -0.034657750818572454, -0.034707720737214204, -0.034757690569086661, +-0.034807660314065333, -0.034857629972024406, -0.034907599542839410, -0.034957569026385416, -0.035007538422537940, -0.035057507731171174, -0.035107476952160634, -0.035157446085381849, +-0.035207415130709012, -0.035257384088017631, -0.035307352957182792, -0.035357321738080011, -0.035407290430583480, -0.035457259034568728, -0.035507227549910828, -0.035557195976485302, +-0.035607164314166342, -0.035657132562829472, -0.035707100722349769, -0.035757068792602757, -0.035807036773462635, -0.035857004664804917, -0.035906972466504691, -0.035956940178437473, +-0.036006907800477460, -0.036056875332500182, -0.036106842774381157, -0.036156810125994580, -0.036206777387215977, -0.036256744557920433, -0.036306711637983477, -0.036356678627279287, +-0.036406645525683408, -0.036456612333070910, -0.036506579049317332, -0.036556545674296857, -0.036606512207885022, -0.036656478649956900, -0.036706445000388034, -0.036756411259052602, +-0.036806377425826146, -0.036856343500583748, -0.036906309483200936, -0.036956275373551908, -0.037006241171512189, -0.037056206876957307, -0.037106172489761467, -0.037156138009800194, +-0.037206103436948579, -0.037256068771082153, -0.037306034012075107, -0.037355999159802970, -0.037405964214140844, -0.037455929174964243, -0.037505894042147381, -0.037555858815565786, +-0.037605823495094538, -0.037655788080609182, -0.037705752571983907, -0.037755716969094251, -0.037805681271815307, -0.037855645480022598, -0.037905609593590336, -0.037955573612394045, +-0.038005537536308823, -0.038055501365210201, -0.038105465098972384, -0.038155428737470895, -0.038205392280581285, -0.038255355728177752, -0.038305319080135826, -0.038355282336330607, +-0.038405245496637624, -0.038455208560931084, -0.038505171529086522, -0.038555134400979026, -0.038605097176484145, -0.038655059855476070, -0.038705022437830354, -0.038754984923422074, +-0.038804947312126782, -0.038854909603818676, -0.038904871798373299, -0.038954833895665737, -0.039004795895571535, -0.039054757797964898, -0.039104719602721369, -0.039154681309716485, +-0.039204642918824452, -0.039254604429920813, -0.039304565842880668, -0.039354527157579547, -0.039404488373891662, -0.039454449491692564, -0.039504410510857332, -0.039554371431261524, +-0.039604332252779345, -0.039654292975286332, -0.039704253598657584, -0.039754214122768652, -0.039804174547493736, -0.039854134872708391, -0.039904095098287698, -0.039954055224107221, +-0.040004015250041158, -0.040053975175965054, -0.040103935001754458, -0.040153894727283583, -0.040203854352427973, -0.040253813877062720, -0.040303773301063384, -0.040353732624304160, +-0.040403691846660615, -0.040453650968007834, -0.040503609988221376, -0.040553568907175444, -0.040603527724745590, -0.040653486440806921, -0.040703445055234974, -0.040753403567903974, +-0.040803361978689466, -0.040853320287466549, -0.040903278494110774, -0.040953236598496368, -0.041003194600498866, -0.041053152499993820, -0.041103110296855448, -0.041153067990959302, +-0.041203025582180482, -0.041252983070394544, -0.041302940455475709, -0.041352897737299520, -0.041402854915741083, -0.041452811990675957, -0.041502768961978360, -0.041552725829523837, +-0.041602682593187494, -0.041652639252844896, -0.041702595808370255, -0.041752552259639121, -0.041802508606526609, -0.041852464848908269, -0.041902420986658327, -0.041952377019652327, +-0.042002332947765383, -0.042052288770873053, -0.042102244488849562, -0.042152200101570454, -0.042202155608911295, -0.042252111010746295, -0.042302066306951019, -0.042352021497400583, +-0.042401976581970535, -0.042451931560535103, -0.042501886432969836, -0.042551841199149856, -0.042601795858950721, -0.042651750412246649, -0.042701704858913204, -0.042751659198825495, +-0.042801613431859079, -0.042851567557888187, -0.042901521576788379, -0.042951475488434761, -0.043001429292702904, -0.043051382989467028, -0.043101336578602698, -0.043151290059985463, +-0.043201243433489564, -0.043251196698990552, -0.043301149856363554, -0.043351102905484121, -0.043401055846226493, -0.043451008678466220, -0.043500961402078424, -0.043550914016938676, +-0.043600866522921194, -0.043650818919901545, -0.043700771207754847, -0.043750723386356667, -0.043800675455581237, -0.043850627415304114, -0.043900579265400426, -0.043950531005745731, +-0.044000482636214269, -0.044050434156681598, -0.044100385567023288, -0.044150336867113567, -0.044200288056828005, -0.044250239136041723, -0.044300190104630280, -0.044350140962467928, +-0.044400091709430219, -0.044450042345392279, -0.044499992870229682, -0.044549943283816659, -0.044599893586028776, -0.044649843776741159, -0.044699793855829374, -0.044749743823167661, +-0.044799693678631590, -0.044849643422096283, -0.044899593053437312, -0.044949542572528915, -0.044999491979246665, -0.045049441273465683, -0.045099390455061540, -0.045149339523908476, +-0.045199288479882069, -0.045249237322857877, -0.045299186052710154, -0.045349134669314464, -0.045399083172545936, -0.045449031562280147, -0.045498979838391330, -0.045548928000755072, +-0.045598876049246485, -0.045648823983741156, -0.045698771804113324, -0.045748719510238560, -0.045798667101991999, -0.045848614579249214, -0.045898561941884450, -0.045948509189773279, +-0.045998456322790836, -0.046048403340812692, -0.046098350243713102, -0.046148297031367629, -0.046198243703651866, -0.046248190260440046, -0.046298136701607748, -0.046348083027030113, +-0.046398029236582712, -0.046447975330139793, -0.046497921307576934, -0.046547867168769276, -0.046597812913592392, -0.046647758541920534, -0.046697704053629274, -0.046747649448593762, +-0.046797594726689568, -0.046847539887790939, -0.046897484931773460, -0.046947429858512274, -0.046997374667882952, -0.047047319359759754, -0.047097263934018259, -0.047147208390534039, +-0.047197152729181360, -0.047247096949835803, -0.047297041052372500, -0.047346985036667039, -0.047396928902593671, -0.047446872650027977, -0.047496816278845104, -0.047546759788920638, +-0.047596703180128826, -0.047646646452345252, -0.047696589605445067, -0.047746532639303854, -0.047796475553795861, -0.047846418348796681, -0.047896361024181454, -0.047946303579825766, +-0.047996246015603879, -0.048046188331391376, -0.048096130527063845, -0.048146072602495545, -0.048196014557562068, -0.048245956392138550, -0.048295898106100583, -0.048345839699322428, +-0.048395781171679676, -0.048445722523047470, -0.048495663753301402, -0.048545604862315725, -0.048595545849966046, -0.048645486716127492, -0.048695427460675671, -0.048745368083484841, +-0.048795308584430583, -0.048845248963388058, -0.048895189220232858, -0.048945129354839231, -0.048995069367082790, -0.049045009256838669, -0.049094949023982475, -0.049144888668388460, +-0.049194828189932226, -0.049244767588489363, -0.049294706863934140, -0.049344646016142149, -0.049394585044988538, -0.049444523950348915, -0.049494462732097538, -0.049544401390110002, +-0.049594339924261460, -0.049644278334427513, -0.049694216620482429, -0.049744154782301805, -0.049794092819760792, -0.049844030732734988, -0.049893968521098668, -0.049943906184727424, +-0.049993843723496419, -0.050043781137281237, -0.050093718425956169, -0.050143655589396804, -0.050193592627478738, -0.050243529540076250, -0.050293466327064940, -0.050343402988319963, +-0.050393339523716926, -0.050443275933130090, -0.050493212216435067, -0.050543148373507013, -0.050593084404221535, -0.050643020308452899, -0.050692956086076713, -0.050742891736968131, +-0.050792827261002774, -0.050842762658054895, -0.050892697928000115, -0.050942633070713589, -0.050992568086070930, -0.051042502973946399, -0.051092437734215616, -0.051142372366754174, +-0.051192306871436367, -0.051242241248137789, -0.051292175496733608, -0.051342109617099431, -0.051392043609109539, -0.051441977472639532, -0.051491911207564592, -0.051541844813760306, +-0.051591778291100975, -0.051641711639462191, -0.051691644858719125, -0.051741577948747397, -0.051791510909421280, -0.051841443740616382, -0.051891376442207877, -0.051941309014071381, +-0.051991241456081159, -0.052041173768112840, -0.052091105950041579, -0.052141038001743002, -0.052190969923091385, -0.052240901713962347, -0.052290833374231495, -0.052340764903773117, +-0.052390696302462826, -0.052440627570175792, -0.052490558706787635, -0.052540489712172643, -0.052590420586206416, -0.052640351328764143, -0.052690281939721438, -0.052740212418952583, +-0.052790142766333197, -0.052840072981738449, -0.052890003065043968, -0.052939933016124034, -0.052989862834854268, -0.053039792521109845, -0.053089722074766380, -0.053139651495698173, +-0.053189580783780832, -0.053239509938889984, -0.053289438960899924, -0.053339367849686257, -0.053389296605124176, -0.053439225227089299, -0.053489153715455907, -0.053539082070099636, +-0.053589010290895661, -0.053638938377719603, -0.053688866330445756, -0.053738794148949741, -0.053788721833106741, -0.053838649382792383, -0.053888576797880956, -0.053938504078248087, +-0.053988431223768958, -0.054038358234319191, -0.054088285109773093, -0.054138211850006272, -0.054188138454894376, -0.054238064924311685, -0.054287991258133828, -0.054337917456236000, +-0.054387843518493816, -0.054437769444781584, -0.054487695234974924, -0.054537620888949027, -0.054587546406579521, -0.054637471787740713, -0.054687397032308217, -0.054737322140157231, +-0.054787247111163381, -0.054837171945200977, -0.054887096642145639, -0.054937021201872556, -0.054986945624257363, -0.055036869909174370, -0.055086794056499196, -0.055136718066107482, +-0.055186641937873530, -0.055236565671672976, -0.055286489267381000, -0.055336412724873253, -0.055386336044024022, -0.055436259224708954, -0.055486182266803241, -0.055536105170182516, +-0.055586027934721081, -0.055635950560294578, -0.055685873046778203, -0.055735795394047584, -0.055785717601977036, -0.055835639670442187, -0.055885561599318248, -0.055935483388480846, +-0.055985405037804289, -0.056035326547164220, -0.056085247916435835, -0.056135169145494775, -0.056185090234215349, -0.056235011182473198, -0.056284931990143956, -0.056334852657101947, +-0.056384773183222804, -0.056434693568381732, -0.056484613812454364, -0.056534533915315023, -0.056584453876839344, -0.056634373696902530, -0.056684293375380224, -0.056734212912146746, +-0.056784132307077732, -0.056834051560048386, -0.056883970670934363, -0.056933889639609964, -0.056983808465950837, -0.057033727149832195, -0.057083645691129677, -0.057133564089717599, +-0.057183482345471610, -0.057233400458267365, -0.057283318427979173, -0.057333236254482681, -0.057383153937653100, -0.057433071477366079, -0.057482988873495934, -0.057532906125918319, +-0.057582823234508439, -0.057632740199141941, -0.057682657019693155, -0.057732573696037723, -0.057782490228050855, -0.057832406615608206, -0.057882322858584100, -0.057932238956854183, +-0.057982154910293668, -0.058032070718778216, -0.058081986382182135, -0.058131901900381096, -0.058181817273250738, -0.058231732500665399, -0.058281647582500727, -0.058331562518631939, +-0.058381477308934684, -0.058431391953283292, -0.058481306451553423, -0.058531220803620290, -0.058581135009359540, -0.058631049068645517, -0.058680962981353869, -0.058730876747359814, +-0.058780790366539007, -0.058830703838765784, -0.058880617163915801, -0.058930530341864275, -0.058980443372486868, -0.059030356255657911, -0.059080268991253057, -0.059130181579147532, +-0.059180094019216999, -0.059230006311335792, -0.059279918455379561, -0.059329830451223982, -0.059379742298743383, -0.059429653997813428, -0.059479565548309334, -0.059529476950106776, +-0.059579388203080078, -0.059629299307104908, -0.059679210262056491, -0.059729121067810496, -0.059779031724241254, -0.059828942231224432, -0.059878852588635248, -0.059928762796349386, +-0.059978672854241168, -0.060028582762186269, -0.060078492520059909, -0.060128402127737769, -0.060178311585094173, -0.060228220892004802, -0.060278130048345320, -0.060328039053990076, +-0.060377947908814726, -0.060427856612694508, -0.060477765165505099, -0.060527673567120827, -0.060577581817417368, -0.060627489916269962, -0.060677397863554271, -0.060727305659144644, +-0.060777213302916751, -0.060827120794745823, -0.060877028134507544, -0.060926935322076242, -0.060976842357327608, -0.061026749240136867, -0.061076655970379694, -0.061126562547930439, +-0.061176468972664780, -0.061226375244458384, -0.061276281363185615, -0.061326187328722137, -0.061376093140943194, -0.061425998799724463, -0.061475904304940286, -0.061525809656466354, +-0.061575714854177899, -0.061625619897950595, -0.061675524787658802, -0.061725429523178194, -0.061775334104384010, -0.061825238531151940, -0.061875142803356327, -0.061925046920872862, +-0.061974950883576775, -0.062024854691343750, -0.062074758344048152, -0.062124661841565655, -0.062174565183771950, -0.062224468370541387, -0.062274371401749649, -0.062324274277271989, +-0.062374176996984082, -0.062424079560760293, -0.062473981968476297, -0.062523884220007361, -0.062573786315229141, -0.062623688254016027, -0.062673590036243676, -0.062723491661787367, +-0.062773393130522756, -0.062823294442324235, -0.062873195597067472, -0.062923096594627720, -0.062972997434880662, -0.063022898117700676, -0.063072798642963432, -0.063122699010544209, +-0.063172599220318676, -0.063222499272161198, -0.063272399165947471, -0.063322298901553192, -0.063372198478852726, -0.063422097897721755, -0.063471997158035545, -0.063521896259669794, +-0.063571795202498851, -0.063621693986398414, -0.063671592611243749, -0.063721491076910539, -0.063771389383273161, -0.063821287530207313, -0.063871185517588247, -0.063921083345291660, +-0.063970981013191916, -0.064020878521164726, -0.064070775869085342, -0.064120673056829447, -0.064170570084271447, -0.064220466951287011, -0.064270363657751850, -0.064320260203540328, +-0.064370156588528168, -0.064420052812590611, -0.064469948875603367, -0.064519844777440813, -0.064569740517978647, -0.064619636097092120, -0.064669531514656958, -0.064719426770547511, +-0.064769321864639504, -0.064819216796808188, -0.064869111566929274, -0.064919006174877142, -0.064968900620527500, -0.065018794903755603, -0.065068689024437160, -0.065118582982446549, +-0.065168476777659481, -0.065218370409951654, -0.065268263879197472, -0.065318157185272632, -0.065368050328052388, -0.065417943307412477, -0.065467836123227249, -0.065517728775372430, +-0.065567621263723300, -0.065617513588155554, -0.065667405748543586, -0.065717297744763106, -0.065767189576689367, -0.065817081244198106, -0.065866972747163702, -0.065916864085461865, +-0.065966755258967863, -0.066016646267557419, -0.066066537111104925, -0.066116427789486079, -0.066166318302576160, -0.066216208650250893, -0.066266098832384657, -0.066315988848853188, +-0.066365878699532171, -0.066415768384296026, -0.066465657903020461, -0.066515547255580745, -0.066565436441852602, -0.066615325461710437, -0.066665214315029947, -0.066715103001686427, +-0.066764991521555586, -0.066814879874511832, -0.066864768060430874, -0.066914656079187992, -0.066964543930658912, -0.067014431614718040, -0.067064319131241085, -0.067114206480103328, +-0.067164093661180507, -0.067213980674347001, -0.067263867519478535, -0.067313754196450859, -0.067363640705138353, -0.067413527045416727, -0.067463413217161303, -0.067513299220247777, +-0.067563185054550570, -0.067613070719945392, -0.067662956216307552, -0.067712841543512745, -0.067762726701435405, -0.067812611689951244, -0.067862496508935555, -0.067912381158264062, +-0.067962265637811173, -0.068012149947452624, -0.068062034087063711, -0.068111918056520143, -0.068161801855696341, -0.068211685484468029, -0.068261568942710946, -0.068311452230299496, +-0.068361335347109420, -0.068411218293016010, -0.068461101067894992, -0.068510983671620784, -0.068560866104069113, -0.068610748365115271, -0.068660630454635010, -0.068710512372502724, +-0.068760394118594165, -0.068810275692784612, -0.068860157094949817, -0.068910038324964187, -0.068959919382703461, -0.069009800268042931, -0.069059680980858351, -0.069109561521024127, +-0.069159441888415996, -0.069209322082909697, -0.069259202104379650, -0.069309081952701607, -0.069358961627750862, -0.069408841129403140, -0.069458720457532888, -0.069508599612015817, +-0.069558478592727263, -0.069608357399542950, -0.069658236032337298, -0.069708114490986059, -0.069757992775364541, -0.069807870885348469, -0.069857748820812290, -0.069907626581631729, +-0.069957504167682108, -0.070007381578839165, -0.070057258814977333, -0.070107135875972351, -0.070157012761699528, -0.070206889472034614, -0.070256766006852031, -0.070306642366027544, +-0.070356518549436878, -0.070406394556954480, -0.070456270388456102, -0.070506146043817039, -0.070556021522913057, -0.070605896825618589, -0.070655771951809360, -0.070705646901360719, +-0.070755521674148392, -0.070805396270046825, -0.070855270688931757, -0.070905144930678524, -0.070955018995162863, -0.071004892882259210, -0.071054766591843330, -0.071104640123790544, +-0.071154513477976578, -0.071204386654275906, -0.071254259652564253, -0.071304132472717399, -0.071354005114609778, -0.071403877578117142, -0.071453749863114799, -0.071503621969478542, +-0.071553493897082779, -0.071603365645803274, -0.071653237215515364, -0.071703108606094801, -0.071752979817416018, -0.071802850849354796, -0.071852721701786443, -0.071902592374586724, +-0.071952462867630088, -0.072002333180792299, -0.072052203313948668, -0.072102073266974973, -0.072151943039745647, -0.072201812632136472, -0.072251682044023213, -0.072301551275280290, +-0.072351420325783497, -0.072401289195408156, -0.072451157884030032, -0.072501026391523574, -0.072550894717764547, -0.072600762862628287, -0.072650630825990561, -0.072700498607725816, +-0.072750366207709818, -0.072800233625817903, -0.072850100861925851, -0.072899967915908109, -0.072949834787640444, -0.072999701476998191, -0.073049567983857130, -0.073099434308091710, +-0.073149300449577695, -0.073199166408190436, -0.073249032183805698, -0.073298897776297930, -0.073348763185542940, -0.073398628411416464, -0.073448493453792979, -0.073498358312548265, +-0.073548222987557657, -0.073598087478696936, -0.073647951785840535, -0.073697815908864275, -0.073747679847643466, -0.073797543602053900, -0.073847407171970039, -0.073897270557267650, +-0.073947133757822095, -0.073996996773509141, -0.074046859604203263, -0.074096722249780228, -0.074146584710115385, -0.074196446985084527, -0.074246309074562103, -0.074296170978423906, +-0.074346032696545730, -0.074395894228802037, -0.074445755575068592, -0.074495616735220774, -0.074545477709134347, -0.074595338496683788, -0.074645199097744877, -0.074695059512192963, +-0.074744919739903853, -0.074794779780751997, -0.074844639634613200, -0.074894499301362799, -0.074944358780876588, -0.074994218073029043, -0.075044077177695956, -0.075093936094752664, +-0.075143794824074975, -0.075193653365537363, -0.075243511719015624, -0.075293369884385536, -0.075343227861521589, -0.075393085650299577, -0.075442943250594835, -0.075492800662283185, +-0.075542657885239090, -0.075592514919338355, -0.075642371764456331, -0.075692228420468813, -0.075742084887250288, -0.075791941164676552, -0.075841797252622967, -0.075891653150965327, +-0.075941508859578108, -0.075991364378337117, -0.076041219707117719, -0.076091074845795706, -0.076140929794245582, -0.076190784552343113, -0.076240639119963691, -0.076290493496983122, +-0.076340347683275869, -0.076390201678717740, -0.076440055483184555, -0.076489909096550790, -0.076539762518692253, -0.076589615749484308, -0.076639468788802775, -0.076689321636522118, +-0.076739174292518156, -0.076789026756666254, -0.076838879028842233, -0.076888731108920583, -0.076938582996777097, -0.076988434692287153, -0.077038286195326558, -0.077088137505769816, +-0.077137988623492720, -0.077187839548370663, -0.077237690280279436, -0.077287540819093559, -0.077337391164688810, -0.077387241316941038, -0.077437091275724720, -0.077486941040915677, +-0.077536790612389273, -0.077586639990021342, -0.077636489173686360, -0.077686338163260163, -0.077736186958618114, -0.077786035559636049, -0.077835883966188443, -0.077885732178151132, +-0.077935580195399493, -0.077985428017809347, -0.078035275645255184, -0.078085123077612825, -0.078134970314757676, -0.078184817356565531, -0.078234664202910906, -0.078284510853669609, +-0.078334357308717489, -0.078384203567929037, -0.078434049631180058, -0.078483895498345974, -0.078533741169302590, -0.078583586643924397, -0.078633431922087257, -0.078683277003666521, +-0.078733121888538038, -0.078782966576576310, -0.078832811067657174, -0.078882655361656007, -0.078932499458448629, -0.078982343357909574, -0.079032187059914660, -0.079082030564339281, +-0.079131873871059258, -0.079181716979949121, -0.079231559890884679, -0.079281402603741780, -0.079331245118394941, -0.079381087434719985, -0.079430929552592316, -0.079480771471887757, +-0.079530613192480823, -0.079580454714247365, -0.079630296037062773, -0.079680137160802883, -0.079729978085342199, -0.079779818810556569, -0.079829659336321399, -0.079879499662512524, +-0.079929339789004461, -0.079979179715673032, -0.080029019442393670, -0.080078858969042196, -0.080128698295493128, -0.080178537421622315, -0.080228376347305161, -0.080278215072417516, +-0.080328053596833884, -0.080377891920430114, -0.080427730043082069, -0.080477567964664251, -0.080527405685052511, -0.080577243204122254, -0.080627080521749328, -0.080676917637808265, +-0.080726754552174915, -0.080776591264724668, -0.080826427775333387, -0.080876264083875590, -0.080926100190227140, -0.080975936094263443, -0.081025771795860346, -0.081075607294892368, +-0.081125442591235386, -0.081175277684764791, -0.081225112575356431, -0.081274947262884867, -0.081324781747225919, -0.081374616028255478, -0.081424450105848034, -0.081474283979879478, +-0.081524117650225214, -0.081573951116761093, -0.081623784379361644, -0.081673617437902746, -0.081723450292259803, -0.081773282942308678, -0.081823115387923889, -0.081872947628981327, +-0.081922779665356396, -0.081972611496924946, -0.082022443123561536, -0.082072274545142015, -0.082122105761541803, -0.082171936772636775, -0.082221767578301463, -0.082271598178411731, +-0.082321428572843441, -0.082371258761471139, -0.082421088744170687, -0.082470918520817518, -0.082520748091287496, -0.082570577455455166, -0.082620406613196390, -0.082670235564386588, +-0.082720064308901650, -0.082769892846616108, -0.082819721177405825, -0.082869549301146248, -0.082919377217713239, -0.082969204926981344, -0.083019032428826439, -0.083068859723123945, +-0.083118686809749751, -0.083168513688578388, -0.083218340359485748, -0.083268166822347264, -0.083317993077038799, -0.083367819123434911, -0.083417644961411463, -0.083467470590844361, +-0.083517296011608136, -0.083567121223578664, -0.083616946226631392, -0.083666771020642211, -0.083716595605485639, -0.083766419981037593, -0.083816244147173494, -0.083866068103769217, +-0.083915891850699337, -0.083965715387839729, -0.084015538715065827, -0.084065361832253521, -0.084115184739277371, -0.084165007436013253, -0.084214829922336629, -0.084264652198123360, +-0.084314474263248021, -0.084364296117586501, -0.084414117761014679, -0.084463939193407125, -0.084513760414639719, -0.084563581424587905, -0.084613402223127590, -0.084663222810133332, +-0.084713043185481007, -0.084762863349046078, -0.084812683300704433, -0.084862503040330634, -0.084912322567800583, -0.084962141882989714, -0.085011960985773946, -0.085061779876027824, +-0.085111598553627252, -0.085161417018447691, -0.085211235270365032, -0.085261053309253834, -0.085310871134990002, -0.085360688747449440, -0.085410506146506721, -0.085460323332037721, +-0.085510140303917931, -0.085559957062023212, -0.085609773606228165, -0.085659589936408695, -0.085709406052440235, -0.085759221954198717, -0.085809037641558686, -0.085858853114396075, +-0.085908668372586330, -0.085958483416005343, -0.086008298244527714, -0.086058112858029348, -0.086107927256385691, -0.086157741439472649, -0.086207555407164821, -0.086257369159338113, +-0.086307182695868415, -0.086356996016630314, -0.086406809121499728, -0.086456622010352119, -0.086506434683063405, -0.086556247139508144, -0.086606059379562284, -0.086655871403101256, +-0.086705683210001008, -0.086755494800136099, -0.086805306173382460, -0.086855117329615553, -0.086904928268711296, -0.086954738990544289, -0.087004549494990410, -0.087054359781925175, +-0.087104169851224475, -0.087153979702762910, -0.087203789336416399, -0.087253598752060416, -0.087303407949570866, -0.087353216928822364, -0.087403025689690814, -0.087452834232052148, +-0.087502642555780955, -0.087552450660753151, -0.087602258546844225, -0.087652066213930097, -0.087701873661885352, -0.087751680890585923, -0.087801487899907299, -0.087851294689725398, +-0.087901101259914807, -0.087950907610351473, -0.088000713740910869, -0.088050519651468928, -0.088100325341900237, -0.088150130812080729, -0.088199936061885906, -0.088249741091191672, +-0.088299545899872656, -0.088349350487804762, -0.088399154854863951, -0.088448959000924796, -0.088498762925863242, -0.088548566629554792, -0.088598370111875366, -0.088648173372699562, +-0.088697976411903343, -0.088747779229362167, -0.088797581824951996, -0.088847384198547416, -0.088897186350024388, -0.088946988279258385, -0.088996789986125355, -0.089046591470499911, +-0.089096392732257987, -0.089146193771275084, -0.089195994587427135, -0.089245795180588755, -0.089295595550635889, -0.089345395697444485, -0.089395195620889142, -0.089444995320845808, +-0.089494794797189997, -0.089544594049797629, -0.089594393078543333, -0.089644191883303068, -0.089693990463952308, -0.089743788820367015, -0.089793586952421817, -0.089843384859992645, +-0.089893182542955016, -0.089942980001184877, -0.089992777234556828, -0.090042574242946857, -0.090092371026230439, -0.090142167584283533, -0.090191963916980769, -0.090241760024198106, +-0.090291555905811033, -0.090341351561695510, -0.090391146991726165, -0.090440942195778959, -0.090490737173729838, -0.090540531925453430, -0.090590326450825695, -0.090640120749722136, +-0.090689914822018727, -0.090739708667590083, -0.090789502286312176, -0.090839295678060511, -0.090889088842711033, -0.090938881780138411, -0.090988674490218580, -0.091038466972827053, +-0.091088259227839807, -0.091138051255131469, -0.091187843054578013, -0.091237634626054942, -0.091287425969438216, -0.091337217084602504, -0.091387007971423725, -0.091436798629777882, +-0.091486589059539603, -0.091536379260584846, -0.091586169232789144, -0.091635958976028470, -0.091685748490177438, -0.091735537775112050, -0.091785326830707809, -0.091835115656840702, +-0.091884904253385344, -0.091934692620217751, -0.091984480757213410, -0.092034268664248312, -0.092084056341197096, -0.092133843787935751, -0.092183631004339794, -0.092233417990285199, +-0.092283204745646608, -0.092332991270300008, -0.092382777564121388, -0.092432563626985362, -0.092482349458767946, -0.092532135059344642, -0.092581920428591452, -0.092631705566383005, +-0.092681490472595301, -0.092731275147103873, -0.092781059589784706, -0.092830843800512444, -0.092880627779163061, -0.092930411525612128, -0.092980195039735591, -0.093029978321408135, +-0.093079761370505720, -0.093129544186903918, -0.093179326770478688, -0.093229109121104700, -0.093278891238657943, -0.093328673123014391, -0.093378454774048728, -0.093428236191636926, +-0.093478017375654518, -0.093527798325977518, -0.093577579042480583, -0.093627359525039699, -0.093677139773530427, -0.093726919787828725, -0.093776699567809305, -0.093826479113348113, +-0.093876258424320735, -0.093926037500603160, -0.093975816342070043, -0.094025594948597385, -0.094075373320060732, -0.094125151456336098, -0.094174929357298140, -0.094224707022822859, +-0.094274484452785814, -0.094324261647062993, -0.094374038605529079, -0.094423815328060073, -0.094473591814531965, -0.094523368064819438, -0.094573144078798480, -0.094622919856344676, +-0.094672695397334014, -0.094722470701641165, -0.094772245769142144, -0.094822020599712509, -0.094871795193228262, -0.094921569549564086, -0.094971343668595984, -0.095021117550199527, +-0.095070891194250703, -0.095120664600624225, -0.095170437769196078, -0.095220210699841851, -0.095269983392437529, -0.095319755846857798, -0.095369528062978687, -0.095419300040676197, +-0.095469071779825013, -0.095518843280301149, -0.095568614541980179, -0.095618385564738118, -0.095668156348449648, -0.095717926892990787, -0.095767697198237120, -0.095817467264064635, +-0.095867237090348043, -0.095917006676963359, -0.095966776023786171, -0.096016545130692466, -0.096066313997556968, -0.096116082624255680, -0.096165851010664188, -0.096215619156658508, +-0.096265387062113336, -0.096315154726904703, -0.096364922150908625, -0.096414689333999798, -0.096464456276054253, -0.096514222976947561, -0.096563989436555753, -0.096613755654753525, +-0.096663521631416921, -0.096713287366421499, -0.096763052859643303, -0.096812818110957044, -0.096862583120238738, -0.096912347887363956, -0.096962112412208770, -0.097011876694647850, +-0.097061640734557239, -0.097111404531812523, -0.097161168086289745, -0.097210931397863590, -0.097260694466410128, -0.097310457291804917, -0.097360219873924000, -0.097409982212642104, +-0.097459744307835244, -0.097509506159379464, -0.097559267767149488, -0.097609029131021333, -0.097658790250870597, -0.097708551126573340, -0.097758311758004271, -0.097808072145039407, +-0.097857832287554375, -0.097907592185425191, -0.097957351838526593, -0.098007111246734613, -0.098056870409924848, -0.098106629327973358, -0.098156388000754852, -0.098206146428145374, +-0.098255904610020539, -0.098305662546256375, -0.098355420236727623, -0.098405177681310310, -0.098454934879880496, -0.098504691832312904, -0.098554448538483580, -0.098604204998268136, +-0.098653961211542615, -0.098703717178181757, -0.098753472898061606, -0.098803228371057775, -0.098852983597046321, -0.098902738575901955, -0.098952493307500750, -0.099002247791718304, +-0.099052002028430675, -0.099101756017512616, -0.099151509758840156, -0.099201263252288924, -0.099251016497734976, -0.099300769495053037, -0.099350522244119194, -0.099400274744809475, +-0.099450026996998619, -0.099499779000562713, -0.099549530755377341, -0.099599282261318603, -0.099649033518261210, -0.099698784526081233, -0.099748535284654286, -0.099798285793856453, +-0.099848036053562461, -0.099897786063648381, -0.099947535823989839, -0.099997285334462893, -0.100047034594942280, -0.100096783605304110, -0.100146532365423950, -0.100196280875177910, +-0.100246029134440740, -0.100295777143088490, -0.100345524900997240, -0.100395272408041730, -0.100445019664098050, -0.100494766669041810, -0.100544513422749100, -0.100594259925094660, +-0.100644006175954580, -0.100693752175204470, -0.100743497922720430, -0.100793243418377210, -0.100842988662050880, -0.100892733653617060, -0.100942478392951870, -0.100992222879930040, +-0.101041967114427640, -0.101091711096320330, -0.101141454825484170, -0.101191198301793950, -0.101240941525125740, -0.101290684495355150, -0.101340427212358310, -0.101390169676009960, +-0.101439911886186170, -0.101489653842763050, -0.101539395545615360, -0.101589136994619190, -0.101638878189650160, -0.101688619130584380, -0.101738359817296620, -0.101788100249662950, +-0.101837840427559030, -0.101887580350860960, -0.101937320019443490, -0.101987059433182720, -0.102036798591954290, -0.102086537495634320, -0.102136276144097570, -0.102186014537220120, +-0.102235752674877630, -0.102285490556946200, -0.102335228183300610, -0.102384965553816950, -0.102434702668371320, -0.102484439526838490, -0.102534176129094550, -0.102583912475015180, +-0.102633648564476460, -0.102683384397353190, -0.102733119973521460, -0.102782855292856910, -0.102832590355235690, -0.102882325160532530, -0.102932059708623570, -0.102981793999384450, +-0.103031528032691310, -0.103081261808418880, -0.103130995326443320, -0.103180728586640250, -0.103230461588885810, -0.103280194333054780, -0.103329926819023250, -0.103379659046667360, +-0.103429391015861880, -0.103479122726482910, -0.103528854178406140, -0.103578585371507690, -0.103628316305662310, -0.103678046980746160, -0.103727777396634880, -0.103777507553204600, +-0.103827237450330110, -0.103876967087887530, -0.103926696465752530, -0.103976425583801230, -0.104026154441908420, -0.104075883039950230, -0.104125611377802340, -0.104175339455340850, +-0.104225067272440570, -0.104274794828977630, -0.104324522124827690, -0.104374249159866900, -0.104423975933970040, -0.104473702447013250, -0.104523428698872630, -0.104573154689423010, +-0.104622880418540500, -0.104672605886100780, -0.104722331091979990, -0.104772056036052940, -0.104821780718195740, -0.104871505138284100, -0.104921229296194130, -0.104970953191800640, +-0.105020676824979770, -0.105070400195607220, -0.105120123303559090, -0.105169846148710220, -0.105219568730936740, -0.105269291050114340, -0.105319013106119140, -0.105368734898825980, +-0.105418456428110980, -0.105468177693850280, -0.105517898695918700, -0.105567619434192360, -0.105617339908546980, -0.105667060118858680, -0.105716780065002310, -0.105766499746853970, +-0.105816219164289390, -0.105865938317184700, -0.105915657205414720, -0.105965375828855610, -0.106015094187383040, -0.106064812280873190, -0.106114530109200870, -0.106164247672242220, +-0.106213964969872950, -0.106263682001969210, -0.106313398768405830, -0.106363115269058950, -0.106412831503804720, -0.106462547472517960, -0.106512263175074850, -0.106561978611351070, +-0.106611693781222790, -0.106661408684564830, -0.106711123321253350, -0.106760837691164070, -0.106810551794173130, -0.106860265630155370, -0.106909979198986940, -0.106959692500543570, +-0.107009405534701410, -0.107059118301335300, -0.107108830800321380, -0.107158543031535390, -0.107208254994853480, -0.107257966690150500, -0.107307678117302600, -0.107357389276185950, +-0.107407100166675370, -0.107456810788647050, -0.107506521141976700, -0.107556231226540500, -0.107605941042213270, -0.107655650588871180, -0.107705359866389970, -0.107755068874645810, +-0.107804777613513540, -0.107854486082869310, -0.107904194282588880, -0.107953902212548390, -0.108003609872622710, -0.108053317262688010, -0.108103024382620010, -0.108152731232294890, +-0.108202437811587520, -0.108252144120374020, -0.108301850158530190, -0.108351555925932170, -0.108401261422454810, -0.108450966647974300, -0.108500671602366820, -0.108550376285507220, +-0.108600080697271670, -0.108649784837535910, -0.108699488706176160, -0.108749192303067220, -0.108798895628085310, -0.108848598681106160, -0.108898301462005950, -0.108948003970659550, +-0.108997706206943140, -0.109047408170732470, -0.109097109861903710, -0.109146811280331740, -0.109196512425892750, -0.109246213298462470, -0.109295913897917100, -0.109345614224131500, +-0.109395314276981860, -0.109445014056344380, -0.109494713562093930, -0.109544412794106690, -0.109594111752258420, -0.109643810436425320, -0.109693508846482240, -0.109743206982305390, +-0.109792904843770520, -0.109842602430753850, -0.109892299743130210, -0.109941996780775830, -0.109991693543566460, -0.110041390031378290, -0.110091086244086200, -0.110140782181566410, +-0.110190477843694650, -0.110240173230347140, -0.110289868341398770, -0.110339563176725720, -0.110389257736204200, -0.110438952019709090, -0.110488646027116610, -0.110538339758302500, +-0.110588033213143010, -0.110637726391512970, -0.110687419293288620, -0.110737111918345720, -0.110786804266560480, -0.110836496337807800, -0.110886188131963880, -0.110935879648904490, +-0.110985570888505830, -0.111035261850642800, -0.111084952535191630, -0.111134642942028070, -0.111184333071028350, -0.111234022922067340, -0.111283712495021280, -0.111333401789765950, +-0.111383090806177550, -0.111432779544130970, -0.111482468003502460, -0.111532156184168220, -0.111581844086003130, -0.111631531708883440, -0.111681219052684920, -0.111730906117283810, +-0.111780592902554970, -0.111830279408374660, -0.111879965634618650, -0.111929651581163160, -0.111979337247883120, -0.112029022634654720, -0.112078707741353770, -0.112128392567856490, +-0.112178077114037780, -0.112227761379773890, -0.112277445364940580, -0.112327129069414110, -0.112376812493069370, -0.112426495635782610, -0.112476178497430040, -0.112525861077886590, +-0.112575543377028490, -0.112625225394731520, -0.112674907130871940, -0.112724588585324640, -0.112774269757965880, -0.112823950648671440, -0.112873631257317560, -0.112923311583779160, +-0.112972991627932490, -0.113022671389653340, -0.113072350868817950, -0.113122030065301240, -0.113171708978979460, -0.113221387609728400, -0.113271065957424310, -0.113320744021942130, +-0.113370421803158080, -0.113420099300948420, -0.113469776515188070, -0.113519453445753270, -0.113569130092519840, -0.113618806455364030, -0.113668482534160760, -0.113718158328786290, +-0.113767833839116410, -0.113817509065027400, -0.113867184006394170, -0.113916858663092990, -0.113966533034999650, -0.114016207121990430, -0.114065880923940240, -0.114115554440725350, +-0.114165227672221580, -0.114214900618305180, -0.114264573278851090, -0.114314245653735560, -0.114363917742834860, -0.114413589546023930, -0.114463261063179010, -0.114512932294175960, +-0.114562603238891000, -0.114612273897199110, -0.114661944268976520, -0.114711614354099070, -0.114761284152443040, -0.114810953663883340, -0.114860622888296270, -0.114910291825557630, +-0.114959960475543720, -0.115009628838129460, -0.115059296913191130, -0.115108964700604540, -0.115158632200246000, -0.115208299411990430, -0.115257966335714100, -0.115307632971292870, +-0.115357299318603000, -0.115406965377519430, -0.115456631147918460, -0.115506296629676330, -0.115555961822668040, -0.115605626726769840, -0.115655291341857580, -0.115704955667807520, +-0.115754619704494630, -0.115804283451795190, -0.115853946909585050, -0.115903610077740480, -0.115953272956136440, -0.116002935544649230, -0.116052597843154660, -0.116102259851529050, +-0.116151921569647360, -0.116201582997385850, -0.116251244134620390, -0.116300904981227260, -0.116350565537081420, -0.116400225802059180, -0.116449885776036810, -0.116499545458889270, +-0.116549204850492890, -0.116598863950723480, -0.116648522759457360, -0.116698181276569490, -0.116747839501936170, -0.116797497435433250, -0.116847155076937020, -0.116896812426322470, +-0.116946469483465880, -0.116996126248243130, -0.117045782720530480, -0.117095438900202960, -0.117145094787136830, -0.117194750381207970, -0.117244405682292660, -0.117294060690265920, +-0.117343715405004000, -0.117393369826383250, -0.117443023954278640, -0.117492677788566450, -0.117542331329122590, -0.117591984575823330, -0.117641637528543660, -0.117691290187159900, +-0.117740942551547920, -0.117790594621584030, -0.117840246397143200, -0.117889897878101770, -0.117939549064335570, -0.117989199955720960, -0.118038850552132900, -0.118088500853447710, +-0.118138150859541280, -0.118187800570289910, -0.118237449985568590, -0.118287099105253660, -0.118336747929220970, -0.118386396457346850, -0.118436044689506300, -0.118485692625575650, +-0.118535340265431190, -0.118584987608947950, -0.118634634656002240, -0.118684281406469940, -0.118733927860227390, -0.118783574017149560, -0.118833219877112820, -0.118882865439993000, +-0.118932510705666470, -0.118982155674008230, -0.119031800344894590, -0.119081444718201470, -0.119131088793805160, -0.119180732571580680, -0.119230376051404390, -0.119280019233152150, +-0.119329662116700310, -0.119379304701923860, -0.119428946988699160, -0.119478588976902530, -0.119528230666408980, -0.119577872057094860, -0.119627513148836060, -0.119677153941508910, +-0.119726794434988450, -0.119776434629150980, -0.119826074523872450, -0.119875714119029160, -0.119925353414496140, -0.119974992410149750, -0.120024631105865860, -0.120074269501520850, +-0.120123907596989720, -0.120173545392148830, -0.120223182886874070, -0.120272820081041790, -0.120322456974527020, -0.120372093567206110, -0.120421729858955410, -0.120471365849649930, +-0.120521001539166050, -0.120570636927379670, -0.120620272014167130, -0.120669906799403470, -0.120719541282965040, -0.120769175464727760, -0.120818809344567980, -0.120868442922360740, +-0.120918076197982390, -0.120967709171308850, -0.121017341842216480, -0.121066974210580310, -0.121116606276276710, -0.121166238039181580, -0.121215869499171320, -0.121265500656120930, +-0.121315131509906790, -0.121364762060405270, -0.121414392307491390, -0.121464022251041540, -0.121513651890931630, -0.121563281227038040, -0.121612910259235790, -0.121662538987401270, +-0.121712167411410420, -0.121761795531139570, -0.121811423346463800, -0.121861050857259470, -0.121910678063402510, -0.121960304964769300, -0.122009931561234890, -0.122059557852675640, +-0.122109183838967500, -0.122158809519986850, -0.122208434895608730, -0.122258059965709510, -0.122307684730165160, -0.122357309188852030, -0.122406933341645190, -0.122456557188421020, +-0.122506180729055890, -0.122555803963424870, -0.122605426891404340, -0.122655049512870230, -0.122704671827698950, -0.122754293835765550, -0.122803915536946420, -0.122853536931117500, +-0.122903158018155170, -0.122952778797934510, -0.123002399270331910, -0.123052019435223300, -0.123101639292485080, -0.123151258841992340, -0.123200878083621430, -0.123250497017248330, +-0.123300115642749440, -0.123349733959999800, -0.123399351968875850, -0.123448969669253950, -0.123498587061009180, -0.123548204144017950, -0.123597820918156200, -0.123647437383300350, +-0.123697053539325460, -0.123746669386107940, -0.123796284923523740, -0.123845900151449280, -0.123895515069759610, -0.123945129678331170, -0.123994743977039900, -0.124044357965762210, +-0.124093971644373190, -0.124143585012749230, -0.124193198070766310, -0.124242810818300840, -0.124292423255227910, -0.124342035381423910, -0.124391647196765260, -0.124441258701127060, +-0.124490869894385710, -0.124540480776417190, -0.124590091347097890, -0.124639701606302940, -0.124689311553908740, -0.124738921189791240, -0.124788530513826890, -0.124838139525890780, +-0.124887748225859310, -0.124937356613608480, -0.124986964689014700, -0.125036572451953040, -0.125086179902299980, -0.125135787039931470, -0.125185393864723910, -0.125235000376552440, +-0.125284606575293470, -0.125334212460822990, -0.125383818033017400, -0.125433423291751830, -0.125483028236902720, -0.125532632868346460, -0.125582237185958180, -0.125631841189614320, +-0.125681444879190830, -0.125731048254564190, -0.125780651315609500, -0.125830254062203160, -0.125879856494221200, -0.125929458611540030, -0.125979060414034780, -0.126028661901581850, +-0.126078263074057310, -0.126127863931337510, -0.126177464473297640, -0.126227064699814100, -0.126276664610762900, -0.126326264206020470, -0.126375863485461950, -0.126425462448963770, +-0.126475061096402390, -0.126524659427652900, -0.126574257442591740, -0.126623855141094980, -0.126673452523038990, -0.126723049588298940, -0.126772646336751250, -0.126822242768271980, +-0.126871838882737510, -0.126921434680023010, -0.126971030160004940, -0.127020625322559280, -0.127070220167562500, -0.127119814694889730, -0.127169408904417410, -0.127219002796021580, +-0.127268596369578680, -0.127318189624963860, -0.127367782562053560, -0.127417375180724240, -0.127466967480851040, -0.127516559462310440, -0.127566151124978430, -0.127615742468731470, +-0.127665333493444720, -0.127714924198994630, -0.127764514585257260, -0.127814104652109020, -0.127863694399425080, -0.127913283827081890, -0.127962872934955510, -0.128012461722922380, +-0.128062050190857670, -0.128111638338637810, -0.128161226166138870, -0.128210813673237310, -0.128260400859808280, -0.128309987725728240, -0.128359574270873660, -0.128409160495119720, +-0.128458746398342870, -0.128508331980419140, -0.128557917241225030, -0.128607502180635690, -0.128657086798527610, -0.128706671094776790, -0.128756255069259750, -0.128805838721851610, +-0.128855422052428890, -0.128905005060867610, -0.128954587747044270, -0.129004170110834010, -0.129053752152113320, -0.129103333870758260, -0.129152915266645300, -0.129202496339649610, +-0.129252077089647670, -0.129301657516515570, -0.129351237620129730, -0.129400817400365380, -0.129450396857098970, -0.129499975990207020, -0.129549554799564680, -0.129599133285048460, +-0.129648711446534420, -0.129698289283899010, -0.129747866797017470, -0.129797443985766230, -0.129847020850021390, -0.129896597389659450, -0.129946173604555570, -0.129995749494586250, +-0.130045325059627570, -0.130094900299556030, -0.130144475214246770, -0.130194049803576320, -0.130243624067420770, -0.130293198005656590, -0.130342771618158960, -0.130392344904804420, +-0.130441917865469460, -0.130491490500029260, -0.130541062808360340, -0.130590634790338750, -0.130640206445841010, -0.130689777774742330, -0.130739348776919200, -0.130788919452247690, +-0.130838489800604340, -0.130888059821864300, -0.130937629515904120, -0.130987198882599850, -0.131036767921828060, -0.131086336633463890, -0.131135905017383870, -0.131185473073464120, +-0.131235040801581100, -0.131284608201610030, -0.131334175273427470, -0.131383742016909890, -0.131433308431932520, -0.131482874518371870, -0.131532440276104060, -0.131582005705005560, +-0.131631570804951610, -0.131681135575818760, -0.131730700017483050, -0.131780264129821020, -0.131829827912707890, -0.131879391366020230, -0.131928954489634040, -0.131978517283425940, +-0.132028079747271100, -0.132077641881046040, -0.132127203684626880, -0.132176765157890170, -0.132226326300711100, -0.132275887112966230, -0.132325447594531600, -0.132375007745283820, +-0.132424567565098100, -0.132474127053850920, -0.132523686211418880, -0.132573245037677200, -0.132622803532502390, -0.132672361695770570, -0.132721919527358290, -0.132771477027140760, +-0.132821034194994550, -0.132870591030795760, -0.132920147534420910, -0.132969703705745290, -0.133019259544645390, -0.133068815050997320, -0.133118370224677680, -0.133167925065561660, +-0.133217479573525840, -0.133267033748446310, -0.133316587590199650, -0.133366141098661070, -0.133415694273707140, -0.133465247115214400, -0.133514799623058120, -0.133564351797114840, +-0.133613903637260670, -0.133663455143372190, -0.133713006315324620, -0.133762557152994540, -0.133812107656258090, -0.133861657824991790, -0.133911207659070910, -0.133960757158372000, +-0.134010306322771190, -0.134059855152145080, -0.134109403646368890, -0.134158951805319170, -0.134208499628872100, -0.134258047116904200, -0.134307594269290760, -0.134357141085908320, +-0.134406687566633460, -0.134456233711341440, -0.134505779519908860, -0.134555324992211820, -0.134604870128126890, -0.134654414927529360, -0.134703959390295810, -0.134753503516302330, +-0.134803047305425560, -0.134852590757540690, -0.134902133872524390, -0.134951676650252730, -0.135001219090602310, -0.135050761193448420, -0.135100302958667620, -0.135149844386136090, +-0.135199385475730350, -0.135248926227325730, -0.135298466640798780, -0.135348006716025680, -0.135397546452882990, -0.135447085851245990, -0.135496624910991260, -0.135546163631995450, +-0.135595702014133760, -0.135645240057282850, -0.135694777761318800, -0.135744315126118260, -0.135793852151556480, -0.135843388837510100, -0.135892925183855230, -0.135942461190468490, +-0.135991996857225160, -0.136041532184001830, -0.136091067170674680, -0.136140601817120290, -0.136190136123213960, -0.136239670088832280, -0.136289203713851450, -0.136338736998148020, +-0.136388269941597330, -0.136437802544075950, -0.136487334805460520, -0.136536866725626320, -0.136586398304449940, -0.136635929541807560, -0.136685460437575790, -0.136734990991629950, +-0.136784521203846600, -0.136834051074101990, -0.136883580602272650, -0.136933109788233950, -0.136982638631862470, -0.137032167133034370, -0.137081695291626310, -0.137131223107513580, +-0.137180750580572770, -0.137230277710680110, -0.137279804497712180, -0.137329330941544310, -0.137378857042053100, -0.137428382799115210, -0.137477908212605890, -0.137527433282401830, +-0.137576958008379160, -0.137626482390414560, -0.137676006428383290, -0.137725530122162020, -0.137775053471626910, -0.137824576476654640, -0.137874099137120450, -0.137923621452901020, +-0.137973143423872540, -0.138022665049911650, -0.138072186330893660, -0.138121707266695200, -0.138171227857192460, -0.138220748102262120, -0.138270268001779440, -0.138319787555621100, +-0.138369306763663710, -0.138418825625782640, -0.138468344141854520, -0.138517862311755500, -0.138567380135362290, -0.138616897612550190, -0.138666414743195830, -0.138715931527175460, +-0.138765447964365680, -0.138814964054641830, -0.138864479797880610, -0.138913995193958140, -0.138963510242751160, -0.139013024944134950, -0.139062539297986180, -0.139112053304181050, +-0.139161566962596240, -0.139211080273107080, -0.139260593235590200, -0.139310105849921840, -0.139359618115978660, -0.139409130033636000, -0.139458641602770520, -0.139508152823258870, +-0.139557663694976410, -0.139607174217799780, -0.139656684391605200, -0.139706194216269370, -0.139755703691667590, -0.139805212817676580, -0.139854721594172500, -0.139904230021032080, +-0.139953738098130660, -0.140003245825344870, -0.140052753202550980, -0.140102260229625660, -0.140151766906444210, -0.140201273232883370, -0.140250779208819340, -0.140300284834128820, +-0.140349790108687120, -0.140399295032370950, -0.140448799605056990, -0.140498303826620600, -0.140547807696938450, -0.140597311215886760, -0.140646814383342260, -0.140696317199180240, +-0.140745819663277450, -0.140795321775510130, -0.140844823535754920, -0.140894324943887230, -0.140943825999783720, -0.140993326703320650, -0.141042827054374710, -0.141092327052821240, +-0.141141826698536980, -0.141191325991398110, -0.141240824931281400, -0.141290323518062170, -0.141339821751617160, -0.141389319631823020, -0.141438817158555140, -0.141488314331690210, +-0.141537811151104500, -0.141587307616674710, -0.141636803728276190, -0.141686299485785680, -0.141735794889079390, -0.141785289938034100, -0.141834784632525110, -0.141884278972429170, +-0.141933772957622550, -0.141983266587981910, -0.142032759863382680, -0.142082252783701540, -0.142131745348814790, -0.142181237558599070, -0.142230729412929860, -0.142280220911683820, +-0.142329712054737210, -0.142379202841966780, -0.142428693273247890, -0.142478183348457270, -0.142527673067471630, -0.142577162430166380, -0.142626651436418200, -0.142676140086103410, +-0.142725628379098720, -0.142775116315279480, -0.142824603894522480, -0.142874091116703960, -0.142923577981700660, -0.142973064489387990, -0.143022550639642610, -0.143072036432340900, +-0.143121521867359520, -0.143171006944573910, -0.143220491663860750, -0.143269976025096390, -0.143319460028157510, -0.143368943672919550, -0.143418426959259240, -0.143467909887053300, +-0.143517392456177150, -0.143566874666507500, -0.143616356517920680, -0.143665838010293400, -0.143715319143501080, -0.143764799917420470, -0.143814280331927860, -0.143863760386899990, +-0.143913240082212260, -0.143962719417741470, -0.144012198393363850, -0.144061677008956200, -0.144111155264393890, -0.144160633159553690, -0.144210110694311920, -0.144259587868545310, +-0.144309064682129310, -0.144358541134940620, -0.144408017226856030, -0.144457492957750950, -0.144506968327502150, -0.144556443335985910, -0.144605917983079040, -0.144655392268656900, +-0.144704866192596290, -0.144754339754773500, -0.144803812955065340, -0.144853285793347160, -0.144902758269495810, -0.144952230383387530, -0.145001702134899130, -0.145051173523906040, +-0.145100644550284990, -0.145150115213912360, -0.145199585514664860, -0.145249055452417950, -0.145298525027048430, -0.145347994238433030, -0.145397463086447190, -0.145446931570967690, +-0.145496399691870890, -0.145545867449033500, -0.145595334842331000, -0.145644801871640190, -0.145694268536837370, -0.145743734837799320, -0.145793200774401470, -0.145842666346520630, +-0.145892131554033130, -0.145941596396815730, -0.145991060874743890, -0.146040524987694430, -0.146089988735543630, -0.146139452118168310, -0.146188915135443940, -0.146238377787247240, +-0.146287840073454630, -0.146337301993942850, -0.146386763548587370, -0.146436224737264980, -0.146485685559852470, -0.146535146016225300, -0.146584606106260280, -0.146634065829833740, +-0.146683525186822480, -0.146732984177101950, -0.146782442800548970, -0.146831901057039890, -0.146881358946451490, -0.146930816468659270, -0.146980273623539990, -0.147029730410970030, +-0.147079186830826160, -0.147128642882983910, -0.147178098567320060, -0.147227553883710950, -0.147277008832033400, -0.147326463412162880, -0.147375917623976200, -0.147425371467350190, +-0.147474824942160270, -0.147524278048283330, -0.147573730785595690, -0.147623183153974130, -0.147672635153294210, -0.147722086783432680, -0.147771538044265930, -0.147820988935670780, +-0.147870439457522730, -0.147919889609698570, -0.147969339392074680, -0.148018788804527900, -0.148068237846933680, -0.148117686519168900, -0.148167134821109880, -0.148216582752633470, +-0.148266030313615150, -0.148315477503931790, -0.148364924323460130, -0.148414370772075750, -0.148463816849655430, -0.148513262556075580, -0.148562707891213010, -0.148612152854943220, +-0.148661597447143050, -0.148711041667688920, -0.148760485516457600, -0.148809928993324600, -0.148859372098166800, -0.148908814830860580, -0.148958257191282750, -0.149007699179308840, +-0.149057140794815690, -0.149106582037679680, -0.149156022907777660, -0.149205463404985140, -0.149254903529178970, -0.149304343280235540, -0.149353782658031680, -0.149403221662442910, +-0.149452660293346110, -0.149502098550618110, -0.149551536434134410, -0.149600973943771860, -0.149650411079406880, -0.149699847840916310, -0.149749284228175680, -0.149798720241061830, +-0.149848155879451220, -0.149897591143220630, -0.149947026032245610, -0.149996460546403060, -0.150045894685569340, -0.150095328449621310, -0.150144761838434530, -0.150194194851885840, +-0.150243627489851680, -0.150293059752208890, -0.150342491638832980, -0.150391923149600870, -0.150441354284389400, -0.150490785043074090, -0.150540215425531810, -0.150589645431639000, +-0.150639075061272530, -0.150688504314307910, -0.150737933190622040, -0.150787361690091330, -0.150836789812592660, -0.150886217558001580, -0.150935644926194930, -0.150985071917049210, +-0.151034498530441210, -0.151083924766246550, -0.151133350624342080, -0.151182776104604230, -0.151232201206909860, -0.151281625931134560, -0.151331050277155210, -0.151380474244848660, +-0.151429897834090470, -0.151479321044757560, -0.151528743876726350, -0.151578166329873700, -0.151627588404075200, -0.151677010099207730, -0.151726431415147740, -0.151775852351772130, +-0.151825272908956420, -0.151874693086577530, -0.151924112884511910, -0.151973532302636470, -0.152022951340826720, -0.152072369998959620, -0.152121788276911580, -0.152171206174559540, +-0.152220623691778990, -0.152270040828446920, -0.152319457584440180, -0.152368873959634360, -0.152418289953906360, -0.152467705567132630, -0.152517120799190080, -0.152566535649954260, +-0.152615950119302120, -0.152665364207110130, -0.152714777913255130, -0.152764191237612760, -0.152813604180059930, -0.152863016740473060, -0.152912428918729110, -0.152961840714703650, +-0.153011252128273570, -0.153060663159315350, -0.153110073807705940, -0.153159484073320890, -0.153208893956037150, -0.153258303455731160, -0.153307712572279850, -0.153357121305558810, +-0.153406529655444990, -0.153455937621815250, -0.153505345204545260, -0.153554752403511910, -0.153604159218591660, -0.153653565649661460, -0.153702971696596890, -0.153752377359274910, +-0.153801782637571990, -0.153851187531365040, -0.153900592040529690, -0.153949996164942840, -0.153999399904481030, -0.154048803259021150, -0.154098206228438810, -0.154147608812610970, +-0.154197011011414090, -0.154246412824725120, -0.154295814252419700, -0.154345215294374730, -0.154394615950467160, -0.154444016220572630, -0.154493416104568040, -0.154542815602329940, +-0.154592214713735190, -0.154641613438659510, -0.154691011776979780, -0.154740409728572500, -0.154789807293314650, -0.154839204471081850, -0.154888601261751050, -0.154937997665198720, +-0.154987393681301850, -0.155036789309936060, -0.155086184550978280, -0.155135579404305060, -0.155184973869793300, -0.155234367947318710, -0.155283761636758170, -0.155333154937988660, +-0.155382547850885840, -0.155431940375326650, -0.155481332511187590, -0.155530724258345660, -0.155580115616676480, -0.155629506586057010, -0.155678897166363770, -0.155728287357473710, +-0.155777677159262500, -0.155827066571607110, -0.155876455594384040, -0.155925844227470270, -0.155975232470741470, -0.156024620324074580, -0.156074007787346120, -0.156123394860433110, +-0.156172781543211150, -0.156222167835557260, -0.156271553737347940, -0.156320939248460160, -0.156370324368769600, -0.156419709098153230, -0.156469093436488040, -0.156518477383649660, +-0.156567860939515110, -0.156617244103960880, -0.156666626876863970, -0.156716009258100090, -0.156765391247546180, -0.156814772845078780, -0.156864154050574880, -0.156913534863910160, +-0.156962915284961620, -0.157012295313605780, -0.157061674949719650, -0.157111054193178860, -0.157160433043860490, -0.157209811501640980, -0.157259189566397420, -0.157308567238005430, +-0.157357944516342020, -0.157407321401284220, -0.157456697892707640, -0.157506073990489330, -0.157555449694505830, -0.157604825004634130, -0.157654199920749970, -0.157703574442730280, +-0.157752948570451660, -0.157802322303791100, -0.157851695642624300, -0.157901068586828260, -0.157950441136279570, -0.157999813290855190, -0.158049185050430830, -0.158098556414883550, +-0.158147927384089840, -0.158197297957926780, -0.158246668136270000, -0.158296037918996570, -0.158345407305983480, -0.158394776297106440, -0.158444144892242460, -0.158493513091268110, +-0.158542880894060430, -0.158592248300495090, -0.158641615310449150, -0.158690981923799160, -0.158740348140422150, -0.158789713960193840, -0.158839079382991240, -0.158888444408690930, +-0.158937809037169970, -0.158987173268304030, -0.159036537101970190, -0.159085900538044970, -0.159135263576405450, -0.159184626216927330, -0.159233988459487660, -0.159283350303963430, +-0.159332711750230390, -0.159382072798165600, -0.159431433447645600, -0.159480793698547480, -0.159530153550746900, -0.159579513004120960, -0.159628872058546260, -0.159678230713899780, +-0.159727588970057290, -0.159776946826895830, -0.159826304284292040, -0.159875661342122890, -0.159925018000264150, -0.159974374258592870, -0.160023730116985650, -0.160073085575319550, +-0.160122440633470310, -0.160171795291314950, -0.160221149548730100, -0.160270503405592820, -0.160319856861778850, -0.160369209917165220, -0.160418562571629040, -0.160467914825045970, +-0.160517266677293130, -0.160566618128247130, -0.160615969177785030, -0.160665319825782550, -0.160714670072116790, -0.160764019916664340, -0.160813369359302290, -0.160862718399906370, +-0.160912067038353650, -0.160961415274520760, -0.161010763108284800, -0.161060110539521460, -0.161109457568107850, -0.161158804193920620, -0.161208150416836780, -0.161257496236732160, +-0.161306841653483770, -0.161356186666968740, -0.161405531277062810, -0.161454875483643040, -0.161504219286586060, -0.161553562685768980, -0.161602905681067580, -0.161652248272358880, +-0.161701590459519600, -0.161750932242426760, -0.161800273620956140, -0.161849614594984870, -0.161898955164389540, -0.161948295329047250, -0.161997635088833800, -0.162046974443626260, +-0.162096313393301270, -0.162145651937735950, -0.162194990076806070, -0.162244327810388690, -0.162293665138360940, -0.162343002060598600, -0.162392338576978740, -0.162441674687378050, +-0.162491010391673600, -0.162540345689741180, -0.162589680581457920, -0.162639015066700450, -0.162688349145345860, -0.162737682817269970, -0.162787016082349880, -0.162836348940462230, +-0.162885681391484180, -0.162935013435291460, -0.162984345071761210, -0.163033676300770120, -0.163083007122195260, -0.163132337535912440, -0.163181667541798770, -0.163230997139730940, +-0.163280326329586060, -0.163329655111239920, -0.163378983484569670, -0.163428311449452360, -0.163477639005763840, -0.163526966153381250, -0.163576292892181230, -0.163625619222040890, +-0.163674945142836090, -0.163724270654443920, -0.163773595756741080, -0.163822920449604700, -0.163872244732910570, -0.163921568606535810, -0.163970892070357140, -0.164020215124251690, +-0.164069537768095240, -0.164118860001764980, -0.164168181825137540, -0.164217503238090090, -0.164266824240498460, -0.164316144832239750, -0.164365465013191130, -0.164414784783228410, +-0.164464104142228700, -0.164513423090068780, -0.164562741626625710, -0.164612059751775340, -0.164661377465394830, -0.164710694767360890, -0.164760011657550610, -0.164809328135839900, +-0.164858644202105860, -0.164907959856225220, -0.164957275098075120, -0.165006589927531370, -0.165055904344471150, -0.165105218348771180, -0.165154531940308600, -0.165203845118959250, +-0.165253157884600290, -0.165302470237108870, -0.165351782176360850, -0.165401093702233350, -0.165450404814603130, -0.165499715513347360, -0.165549025798341830, -0.165598335669463750, +-0.165647645126589800, -0.165696954169597200, -0.165746262798361800, -0.165795571012760710, -0.165844878812670710, -0.165894186197968950, -0.165943493168531270, -0.165992799724234860, +-0.166042105864956460, -0.166091411590573250, -0.166140716900961050, -0.166190021795997070, -0.166239326275558460, -0.166288630339521100, -0.166337933987762170, -0.166387237220158410, +-0.166436540036586980, -0.166485842436923770, -0.166535144421045940, -0.166584445988830270, -0.166633747140153910, -0.166683047874892770, -0.166732348192923980, -0.166781648094124320, +-0.166830947578371000, -0.166880246645539850, -0.166929545295508100, -0.166978843528152480, -0.167028141343350200, -0.167077438740977110, -0.167126735720910440, -0.167176032283026910, +-0.167225328427203750, -0.167274624153316840, -0.167323919461243360, -0.167373214350860530, -0.167422508822044210, -0.167471802874671620, -0.167521096508619540, -0.167570389723765150, +-0.167619682519984330, -0.167668974897154320, -0.167718266855151870, -0.167767558393854180, -0.167816849513137190, -0.167866140212878050, -0.167915430492953540, -0.167964720353240920, +-0.168014009793616050, -0.168063298813956180, -0.168112587414138040, -0.168161875594038860, -0.168211163353534590, -0.168260450692502370, -0.168309737610819490, -0.168359024108361820, +-0.168408310185006570, -0.168457595840630580, -0.168506881075111000, -0.168556165888323810, -0.168605450280146200, -0.168654734250454960, -0.168704017799127300, -0.168753300926039180, +-0.168802583631067820, -0.168851865914089990, -0.168901147774982940, -0.168950429213622580, -0.168999710229886140, -0.169048990823650410, -0.169098270994792660, -0.169147550743188800, +-0.169196830068716050, -0.169246108971251670, -0.169295387450671580, -0.169344665506853010, -0.169393943139672790, -0.169443220349008130, -0.169492497134735020, -0.169541773496730640, +-0.169591049434871830, -0.169640324949035830, -0.169689600039098580, -0.169738874704937340, -0.169788148946428910, -0.169837422763450540, -0.169886696155878180, -0.169935969123589080, +-0.169985241666460060, -0.170034513784368370, -0.170083785477189940, -0.170133056744802090, -0.170182327587081540, -0.170231598003905670, -0.170280867995150330, -0.170330137560692820, +-0.170379406700410410, -0.170428675414179050, -0.170477943701875990, -0.170527211563378110, -0.170576478998562600, -0.170625746007305460, -0.170675012589483950, -0.170724278744974920, +-0.170773544473655640, -0.170822809775402040, -0.170872074650091440, -0.170921339097600630, -0.170970603117806930, -0.171019866710586250, -0.171069129875815930, -0.171118392613372780, +-0.171167654923134100, -0.171216916804975830, -0.171266178258775270, -0.171315439284409700, -0.171364699881755090, -0.171413960050688760, -0.171463219791087500, -0.171512479102828630, +-0.171561737985788140, -0.171610996439843290, -0.171660254464870960, -0.171709512060748410, -0.171758769227351670, -0.171808025964557990, -0.171857282272244260, -0.171906538150287750, +-0.171955793598564470, -0.172005048616951710, -0.172054303205326300, -0.172103557363565580, -0.172152811091545540, -0.172202064389143460, -0.172251317256236660, -0.172300569692701130, +-0.172349821698414200, -0.172399073273252680, -0.172448324417093930, -0.172497575129813920, -0.172546825411289990, -0.172596075261399000, -0.172645324680018250, -0.172694573667023730, +-0.172743822222292810, -0.172793070345702320, -0.172842318037129600, -0.172891565296450640, -0.172940812123542760, -0.172990058518282840, -0.173039304480548240, -0.173088550010214920, +-0.173137795107160240, -0.173187039771261510, -0.173236284002394710, -0.173285527800437240, -0.173334771165265940, -0.173384014096758160, -0.173433256594789890, -0.173482498659238480, +-0.173531740289980810, -0.173580981486894240, -0.173630222249854800, -0.173679462578739780, -0.173728702473426120, -0.173777941933791120, -0.173827180959710840, -0.173876419551062620, +-0.173925657707723340, -0.173974895429570340, -0.174024132716479680, -0.174073369568328670, -0.174122605984994270, -0.174171841966353770, -0.174221077512283220, -0.174270312622659990, +-0.174319547297361400, -0.174368781536263530, -0.174418015339243700, -0.174467248706178800, -0.174516481636946250, -0.174565714131422050, -0.174614946189483560, -0.174664177811007710, +-0.174713408995871840, -0.174762639743952040, -0.174811870055125610, -0.174861099929269510, -0.174910329366261110, -0.174959558365976460, -0.175008786928292890, -0.175058015053087380, +-0.175107242740237230, -0.175156469989618560, -0.175205696801108730, -0.175254923174585080, -0.175304149109923670, -0.175353374607001900, -0.175402599665696680, -0.175451824285885430, +-0.175501048467444160, -0.175550272210250270, -0.175599495514180690, -0.175648718379112830, -0.175697940804922740, -0.175747162791487780, -0.175796384338684910, -0.175845605446391520, +-0.175894826114483680, -0.175944046342838780, -0.175993266131333760, -0.176042485479846020, -0.176091704388251640, -0.176140922856427990, -0.176190140884252440, -0.176239358471601130, +-0.176288575618351430, -0.176337792324380270, -0.176387008589565080, -0.176436224413781930, -0.176485439796908200, -0.176534654738820910, -0.176583869239397400, -0.176633083298513770, +-0.176682296916047420, -0.176731510091875350, -0.176780722825874950, -0.176829935117922300, -0.176879146967894810, -0.176928358375669450, -0.176977569341123630, -0.177026779864133450, +-0.177075989944576320, -0.177125199582329220, -0.177174408777269530, -0.177223617529273430, -0.177272825838218240, -0.177322033703981450, -0.177371241126439150, -0.177420448105468730, +-0.177469654640947190, -0.177518860732751940, -0.177568066380759120, -0.177617271584846110, -0.177666476344889940, -0.177715680660768010, -0.177764884532356450, -0.177814087959532690, +-0.177863290942173680, -0.177912493480156890, -0.177961695573358450, -0.178010897221655750, -0.178060098424925820, -0.178109299183046050, -0.178158499495892630, -0.178207699363342940, +-0.178256898785274450, -0.178306097761563280, -0.178355296292086850, -0.178404494376722210, -0.178453692015346750, -0.178502889207836610, -0.178552085954069270, -0.178601282253921690, +-0.178650478107271360, -0.178699673513994410, -0.178748868473968260, -0.178798062987069930, -0.178847257053176890, -0.178896450672165250, -0.178945643843912510, -0.178994836568295650, +-0.179044028845192160, -0.179093220674478140, -0.179142412056031070, -0.179191602989728390, -0.179240793475446280, -0.179289983513062190, -0.179339173102453150, -0.179388362243496610, +-0.179437550936068700, -0.179486739180046930, -0.179535926975308320, -0.179585114321730330, -0.179634301219189110, -0.179683487667562150, -0.179732673666726460, -0.179781859216559510, +-0.179831044316937500, -0.179880228967737870, -0.179929413168837650, -0.179978596920114360, -0.180027780221444140, -0.180076963072704460, -0.180126145473772810, -0.180175327424525360, +-0.180224508924839570, -0.180273689974592530, -0.180322870573661700, -0.180372050721923280, -0.180421230419254700, -0.180470409665533040, -0.180519588460635820, -0.180568766804439170, +-0.180617944696820630, -0.180667122137657200, -0.180716299126826410, -0.180765475664204450, -0.180814651749668790, -0.180863827383096500, -0.180913002564365070, -0.180962177293350710, +-0.181011351569930900, -0.181060525393982710, -0.181109698765383630, -0.181158871684009900, -0.181208044149738980, -0.181257216162448360, -0.181306387722014290, -0.181355558828314250, +-0.181404729481225300, -0.181453899680624970, -0.181503069426389470, -0.181552238718396260, -0.181601407556522490, -0.181650575940645630, -0.181699743870641860, -0.181748911346388760, +-0.181798078367763380, -0.181847244934643240, -0.181896411046904540, -0.181945576704424820, -0.181994741907081180, -0.182043906654751090, -0.182093070947310810, -0.182142234784637870, +-0.182191398166609760, -0.182240561093102720, -0.182289723563994250, -0.182338885579161500, -0.182388047138481970, -0.182437208241831910, -0.182486368889088780, -0.182535529080129770, +-0.182584688814832360, -0.182633848093072790, -0.182683006914728610, -0.182732165279676890, -0.182781323187795190, -0.182830480638959760, -0.182879637633048150, -0.182928794169937430, +-0.182977950249505140, -0.183027105871627570, -0.183076261036182210, -0.183125415743046640, -0.183174569992097110, -0.183223723783211140, -0.183272877116265860, -0.183322029991138840, +-0.183371182407706280, -0.183420334365845790, -0.183469485865434460, -0.183518636906349840, -0.183567787488468190, -0.183616937611667090, -0.183666087275823620, -0.183715236480815390, +-0.183764385226518640, -0.183813533512810910, -0.183862681339569340, -0.183911828706671530, -0.183960975613993690, -0.184010122061413400, -0.184059268048807820, -0.184108413576054510, +-0.184157558643029740, -0.184206703249611050, -0.184255847395676050, -0.184304991081100990, -0.184354134305763470, -0.184403277069540600, -0.184452419372309970, -0.184501561213947870, +-0.184550702594331840, -0.184599843513339080, -0.184648983970847140, -0.184698123966732300, -0.184747263500872140, -0.184796402573143840, -0.184845541183424970, -0.184894679331591790, +-0.184943817017521940, -0.184992954241092520, -0.185042091002181160, -0.185091227300664160, -0.185140363136419070, -0.185189498509323510, -0.185238633419253760, -0.185287767866087440, +-0.185336901849701700, -0.185386035369974140, -0.185435168426781040, -0.185484301020000050, -0.185533433149508260, -0.185582564815183370, -0.185631696016901600, -0.185680826754540620, +-0.185729957027977570, -0.185779086837090050, -0.185828216181754350, -0.185877345061848160, -0.185926473477248580, -0.185975601427833260, -0.186024728913478490, -0.186073855934061920, +-0.186122982489461130, -0.186172108579552440, -0.186221234204213490, -0.186270359363321450, -0.186319484056753970, -0.186368608284387310, -0.186417732046099150, -0.186466855341766660, +-0.186515978171267440, -0.186565100534477860, -0.186614222431275540, -0.186663343861537660, -0.186712464825141840, -0.186761585321964440, -0.186810705351883070, -0.186859824914774930, +-0.186908944010517660, -0.186958062638987620, -0.187007180800062400, -0.187056298493619680, -0.187105415719535760, -0.187154532477688320, -0.187203648767954530, -0.187252764590212060, +-0.187301879944337250, -0.187350994830207730, -0.187400109247700730, -0.187449223196693910, -0.187498336677063560, -0.187547449688687390, -0.187596562231442610, -0.187645674305206840, +-0.187694785909856440, -0.187743897045269090, -0.187793007711321990, -0.187842117907892820, -0.187891227634857910, -0.187940336892094940, -0.187989445679481120, -0.188038553996894090, +-0.188087661844210270, -0.188136769221307320, -0.188185876128062840, -0.188234982564353250, -0.188284088530056210, -0.188333194025048940, -0.188382299049209140, -0.188431403602413140, +-0.188480507684538640, -0.188529611295462860, -0.188578714435063490, -0.188627817103216910, -0.188676919299800770, -0.188726021024692330, -0.188775122277769300, -0.188824223058908000, +-0.188873323367986150, -0.188922423204881010, -0.188971522569470220, -0.189020621461630210, -0.189069719881238630, -0.189118817828173190, -0.189167915302310280, -0.189217012303527580, +-0.189266108831702330, -0.189315204886712270, -0.189364300468433750, -0.189413395576744470, -0.189462490211521730, -0.189511584372643180, -0.189560678059985220, -0.189609771273425570, +-0.189658864012841520, -0.189707956278110710, -0.189757048069109590, -0.189806139385715860, -0.189855230227806790, -0.189904320595260050, -0.189953410487952080, -0.190002499905760600, +-0.190051588848563300, -0.190100677316236590, -0.190149765308658180, -0.190198852825705370, -0.190247939867255830, -0.190297026433186050, -0.190346112523373660, -0.190395198137696040, +-0.190444283276030830, -0.190493367938254470, -0.190542452124244700, -0.190591535833878810, -0.190640619067034500, -0.190689701823588210, -0.190738784103417660, -0.190787865906400150, +-0.190836947232413430, -0.190886028081333900, -0.190935108453039290, -0.190984188347406910, -0.191033267764314510, -0.191082346703638490, -0.191131425165256610, -0.191180503149046580, +-0.191229580654884880, -0.191278657682649230, -0.191327734232216940, -0.191376810303465730, -0.191425885896272070, -0.191474961010513700, -0.191524035646067930, -0.191573109802812500, +-0.191622183480623850, -0.191671256679379760, -0.191720329398957500, -0.191769401639234890, -0.191818473400088310, -0.191867544681395550, -0.191916615483033960, -0.191965685804881240, +-0.192014755646813860, -0.192063825008709610, -0.192112893890446220, -0.192161962291900160, -0.192211030212949220, -0.192260097653470690, -0.192309164613342350, -0.192358231092440660, +-0.192407297090643390, -0.192456362607827890, -0.192505427643871910, -0.192554492198651920, -0.192603556272045700, -0.192652619863930590, -0.192701682974184390, -0.192750745602683520, +-0.192799807749305770, -0.192848869413928540, -0.192897930596429570, -0.192946991296685300, -0.192996051514573580, -0.193045111249972170, -0.193094170502757540, -0.193143229272807470, +-0.193192287559999340, -0.193241345364210950, -0.193290402685318720, -0.193339459523200500, -0.193388515877733650, -0.193437571748795920, -0.193486627136263830, -0.193535682040015170, +-0.193584736459927330, -0.193633790395878050, -0.193682843847743900, -0.193731896815402590, -0.193780949298731580, -0.193830001297608610, -0.193879052811910200, -0.193928103841514180, +-0.193977154386297870, -0.194026204446139130, -0.194075254020914440, -0.194124303110501610, -0.194173351714778450, -0.194222399833621500, -0.194271447466908530, -0.194320494614516950, +-0.194369541276324580, -0.194418587452207910, -0.194467633142044770, -0.194516678345712540, -0.194565723063089060, -0.194614767294050830, -0.194663811038475690, -0.194712854296241020, +-0.194761897067224660, -0.194810939351303090, -0.194859981148354210, -0.194909022458255340, -0.194958063280884390, -0.195007103616117810, -0.195056143463833490, -0.195105182823909230, +-0.195154221696221600, -0.195203260080648420, -0.195252297977067060, -0.195301335385355410, -0.195350372305389990, -0.195399408737048640, -0.195448444680208750, -0.195497480134748190, +-0.195546515100543490, -0.195595549577472520, -0.195644583565412670, -0.195693617064241790, -0.195742650073836450, -0.195791682594074480, -0.195840714624833300, -0.195889746165990750, +-0.195938777217423420, -0.195987807779009120, -0.196036837850625760, -0.196085867432149870, -0.196134896523459310, -0.196183925124431500, -0.196232953234944330, -0.196281980854874330, +-0.196331007984099390, -0.196380034622496900, -0.196429060769944790, -0.196478086426319590, -0.196527111591499160, -0.196576136265360940, -0.196625160447782830, -0.196674184138641380, +-0.196723207337814480, -0.196772230045179570, -0.196821252260614500, -0.196870273983995870, -0.196919295215201550, -0.196968315954109440, -0.197017336200596080, -0.197066355954539420, +-0.197115375215816850, -0.197164393984306270, -0.197213412259884260, -0.197262430042428740, -0.197311447331817130, -0.197360464127927350, -0.197409480430635970, -0.197458496239820900, +-0.197507511555359590, -0.197556526377129920, -0.197605540705008490, -0.197654554538873230, -0.197703567878601580, -0.197752580724071450, -0.197801593075159430, -0.197850604931743420, +-0.197899616293700900, -0.197948627160909770, -0.197997637533246650, -0.198046647410589420, -0.198095656792816020, -0.198144665679803040, -0.198193674071428380, -0.198242681967569560, +-0.198291689368104460, -0.198340696272909710, -0.198389702681863210, -0.198438708594842440, -0.198487714011725350, -0.198536718932388530, -0.198585723356709930, -0.198634727284567020, +-0.198683730715837700, -0.198732733650398650, -0.198781736088127740, -0.198830738028902500, -0.198879739472600870, -0.198928740419099440, -0.198977740868276160, -0.199026740820008960, +-0.199075740274174460, -0.199124739230650630, -0.199173737689314960, -0.199222735650045360, -0.199271733112718480, -0.199320730077212290, -0.199369726543404260, -0.199418722511172350, +-0.199467717980393200, -0.199516712950944780, -0.199565707422704550, -0.199614701395550490, -0.199663694869359230, -0.199712687844008750, -0.199761680319376550, -0.199810672295340580, +-0.199859663771777500, -0.199908654748565260, -0.199957645225581820, -0.200006635202703810, -0.200055624679809220, -0.200104613656775590, -0.200153602133480850, -0.200202590109801680, +-0.200251577585616010, -0.200300564560801420, -0.200349551035235830, -0.200398537008795950, -0.200447522481359720, -0.200496507452804670, -0.200545491923008800, -0.200594475891848760, +-0.200643459359202550, -0.200692442324947680, -0.200741424788962120, -0.200790406751122590, -0.200839388211307040, -0.200888369169392980, -0.200937349625258470, -0.200986329578780150, +-0.201035309029835990, -0.201084287978304020, -0.201133266424060870, -0.201182244366984560, -0.201231221806952630, -0.201280198743843090, -0.201329175177532630, -0.201378151107899220, +-0.201427126534820450, -0.201476101458174270, -0.201525075877837410, -0.201574049793687870, -0.201623023205603210, -0.201671996113461400, -0.201720968517139190, -0.201769940416514550, +-0.201818911811465080, -0.201867882701868730, -0.201916853087602270, -0.201965822968543650, -0.202014792344570930, -0.202063761215560770, -0.202112729581391230, -0.202161697441939850, +-0.202210664797084660, -0.202259631646702380, -0.202308597990671020, -0.202357563828868190, -0.202406529161171860, -0.202455493987458770, -0.202504458307606940, -0.202553422121493990, +-0.202602385428997890, -0.202651348229995420, -0.202700310524364570, -0.202749272311982920, -0.202798233592728560, -0.202847194366478160, -0.202896154633109780, -0.202945114392501460, +-0.202994073644529900, -0.203043032389073150, -0.203091990626008830, -0.203140948355214980, -0.203189905576568320, -0.203238862289946890, -0.203287818495228310, -0.203336774192290600, +-0.203385729381010540, -0.203434684061266140, -0.203483638232935050, -0.203532591895895290, -0.203581545050023600, -0.203630497695198090, -0.203679449831296290, -0.203728401458196320, +-0.203777352575774920, -0.203826303183910120, -0.203875253282480020, -0.203924202871361320, -0.203973151950432140, -0.204022100519570070, -0.204071048578653190, -0.204119996127558240, +-0.204168943166163320, -0.204217889694346010, -0.204266835711984450, -0.204315781218955360, -0.204364726215136790, -0.204413670700406420, -0.204462614674642300, -0.204511558137721230, +-0.204560501089521230, -0.204609443529920000, -0.204658385458795610, -0.204707326876024800, -0.204756267781485670, -0.204805208175055880, -0.204854148056613510, -0.204903087426035330, +-0.204952026283199450, -0.205000964627983890, -0.205049902460265530, -0.205098839779922380, -0.205147776586832170, -0.205196712880872930, -0.205245648661921460, -0.205294583929855890, +-0.205343518684553860, -0.205392452925893450, -0.205441386653751500, -0.205490319868006060, -0.205539252568534840, -0.205588184755215900, -0.205637116427926060, -0.205686047586543460, +-0.205734978230945720, -0.205783908361010990, -0.205832837976616030, -0.205881767077638970, -0.205930695663957970, -0.205979623735449760, -0.206028551291992490, -0.206077478333463850, +-0.206126404859741960, -0.206175330870703610, -0.206224256366226930, -0.206273181346189600, -0.206322105810469780, -0.206371029758944250, -0.206419953191491150, -0.206468876107988140, +-0.206517798508313420, -0.206566720392343720, -0.206615641759957250, -0.206664562611031670, -0.206713482945445120, -0.206762402763074420, -0.206811322063797740, -0.206860240847493160, +-0.206909159114037540, -0.206958076863309030, -0.207006994095185330, -0.207055910809544580, -0.207104827006263620, -0.207153742685220600, -0.207202657846293210, -0.207251572489359630, +-0.207300486614296650, -0.207349400220982470, -0.207398313309294810, -0.207447225879111770, -0.207496137930310240, -0.207545049462768390, -0.207593960476363890, -0.207642870970974950, +-0.207691780946478360, -0.207740690402752340, -0.207789599339674590, -0.207838507757123290, -0.207887415654975260, -0.207936323033108690, -0.207985229891401780, -0.208034136229731330, +-0.208083042047975560, -0.208131947346012170, -0.208180852123719340, -0.208229756380973960, -0.208278660117654200, -0.208327563333637780, -0.208376466028802890, -0.208425368203026370, +-0.208474269856186470, -0.208523170988160870, -0.208572071598827790, -0.208620971688064090, -0.208669871255747960, -0.208718770301757170, -0.208767668825969870, -0.208816566828262970, +-0.208865464308514630, -0.208914361266603090, -0.208963257702405200, -0.209012153615799200, -0.209061049006662780, -0.209109943874874170, -0.209158838220310280, -0.209207732042849290, +-0.209256625342368970, -0.209305518118747540, -0.209354410371861840, -0.209403302101590140, -0.209452193307810200, -0.209501083990400180, -0.209549974149237040, -0.209598863784198950, +-0.209647752895163710, -0.209696641482009500, -0.209745529544613290, -0.209794417082853210, -0.209843304096607560, -0.209892190585753200, -0.209941076550168360, -0.209989961989730830, +-0.210038846904318840, -0.210087731293809280, -0.210136615158080410, -0.210185498497010010, -0.210234381310476280, -0.210283263598356170, -0.210332145360527910, -0.210381026596869270, +-0.210429907307258500, -0.210478787491572530, -0.210527667149689600, -0.210576546281487480, -0.210625424886844440, -0.210674302965637410, -0.210723180517744630, -0.210772057543044320, +-0.210820934041413420, -0.210869810012730200, -0.210918685456872450, -0.210967560373718440, -0.211016434763145080, -0.211065308625030620, -0.211114181959252910, -0.211163054765690170, +-0.211211927044219370, -0.211260798794718730, -0.211309670017066100, -0.211358540711139740, -0.211407410876816610, -0.211456280513974910, -0.211505149622492530, -0.211554018202247730, +-0.211602886253117430, -0.211651753774979910, -0.211700620767713010, -0.211749487231194990, -0.211798353165302820, -0.211847218569914790, -0.211896083444909120, -0.211944947790162820, +-0.211993811605554140, -0.212042674890960930, -0.212091537646261460, -0.212140399871332740, -0.212189261566053000, -0.212238122730300100, -0.212286983363952350, -0.212335843466886690, +-0.212384703038981440, -0.212433562080114410, -0.212482420590163920, -0.212531278569006940, -0.212580136016521790, -0.212628992932586270, -0.212677849317078700, -0.212726705169876100, +-0.212775560490856720, -0.212824415279898870, -0.212873269536879540, -0.212922123261677060, -0.212970976454169240, -0.213019829114234450, -0.213068681241749630, -0.213117532836593100, +-0.213166383898642760, -0.213215234427776870, -0.213264084423872490, -0.213312933886807890, -0.213361782816460930, -0.213410631212709980, -0.213459479075432000, -0.213508326404505320, +-0.213557173199807830, -0.213606019461217850, -0.213654865188612380, -0.213703710381869750, -0.213752555040868260, -0.213801399165484960, -0.213850242755598160, -0.213899085811085770, +-0.213947928331826100, -0.213996770317696150, -0.214045611768574280, -0.214094452684338410, -0.214143293064866820, -0.214192132910036550, -0.214240972219725960, -0.214289810993812950, +-0.214338649232175830, -0.214387486934691670, -0.214436324101238780, -0.214485160731695070, -0.214533996825938930, -0.214582832383847340, -0.214631667405298650, -0.214680501890170820, +-0.214729335838342170, -0.214778169249689730, -0.214827002124091860, -0.214875834461426940, -0.214924666261572000, -0.214973497524405390, -0.215022328249805020, -0.215071158437649290, +-0.215119988087815210, -0.215168817200181160, -0.215217645774625070, -0.215266473811025320, -0.215315301309258940, -0.215364128269204290, -0.215412954690739340, -0.215461780573742430, +-0.215510605918090630, -0.215559430723662320, -0.215608254990335420, -0.215657078717988340, -0.215705901906498100, -0.215754724555743130, -0.215803546665601780, -0.215852368235951140, +-0.215901189266669540, -0.215950009757635010, -0.215998829708725860, -0.216047649119819220, -0.216096467990793460, -0.216145286321526520, -0.216194104111896800, -0.216242921361781390, +-0.216291738071058670, -0.216340554239606600, -0.216389369867303590, -0.216438184954026700, -0.216486999499654360, -0.216535813504064530, -0.216584626967135600, -0.216633439888744670, +-0.216682252268770140, -0.216731064107090390, -0.216779875403582570, -0.216828686158125060, -0.216877496370595830, -0.216926306040873290, -0.216975115168834550, -0.217023923754358030, +-0.217072731797321700, -0.217121539297603970, -0.217170346255081970, -0.217219152669634100, -0.217267958541138340, -0.217316763869473130, -0.217365568654515560, -0.217414372896144070, +-0.217463176594236670, -0.217511979748671730, -0.217560782359326440, -0.217609584426079170, -0.217658385948808370, -0.217707186927391190, -0.217755987361706040, -0.217804787251630910, +-0.217853586597044240, -0.217902385397823200, -0.217951183653846160, -0.217999981364991190, -0.218048778531136690, -0.218097575152159800, -0.218146371227938980, -0.218195166758352240, +-0.218243961743278010, -0.218292756182593440, -0.218341550076177000, -0.218390343423906670, -0.218439136225660910, -0.218487928481316870, -0.218536720190753010, -0.218585511353847380, +-0.218634301970478370, -0.218683092040523190, -0.218731881563860280, -0.218780670540368090, -0.218829458969923780, -0.218878246852405840, -0.218927034187692300, -0.218975820975661570, +-0.219024607216190880, -0.219073392909158670, -0.219122178054442950, -0.219170962651922260, -0.219219746701473710, -0.219268530202975790, -0.219317313156306540, -0.219366095561344450, +-0.219414877417966700, -0.219463658726051750, -0.219512439485477630, -0.219561219696122860, -0.219609999357864630, -0.219658778470581380, -0.219707557034151600, -0.219756335048452520, +-0.219805112513362600, -0.219853889428759890, -0.219902665794522890, -0.219951441610528790, -0.220000216876656110, -0.220048991592782850, -0.220097765758787590, -0.220146539374547450, +-0.220195312439940950, -0.220244084954846210, -0.220292856919141660, -0.220341628332704540, -0.220390399195413370, -0.220439169507146180, -0.220487939267781490, -0.220536708477196530, +-0.220585477135269800, -0.220634245241879830, -0.220683012796903780, -0.220731779800220210, -0.220780546251707200, -0.220829312151243270, -0.220878077498705580, -0.220926842293972750, +-0.220975606536922780, -0.221024370227434240, -0.221073133365384340, -0.221121895950651600, -0.221170657983114140, -0.221219419462650450, -0.221268180389137760, -0.221316940762454640, +-0.221365700582479170, -0.221414459849089890, -0.221463218562164030, -0.221511976721580100, -0.221560734327216240, -0.221609491378950970, -0.221658247876661550, -0.221707003820226510, +-0.221755759209524390, -0.221804514044432440, -0.221853268324829210, -0.221902022050592810, -0.221950775221601780, -0.221999527837733380, -0.222048279898866160, -0.222097031404878240, +-0.222145782355648160, -0.222194532751053220, -0.222243282590971920, -0.222292031875282460, -0.222340780603863310, -0.222389528776591790, -0.222438276393346460, -0.222487023454005420, +-0.222535769958447260, -0.222584515906549240, -0.222633261298189920, -0.222682006133247900, -0.222730750411600430, -0.222779494133126060, -0.222828237297702990, -0.222876979905209740, +-0.222925721955523600, -0.222974463448523170, -0.223023204384086570, -0.223071944762092410, -0.223120684582417930, -0.223169423844941760, -0.223218162549542020, -0.223266900696097310, +-0.223315638284484920, -0.223364375314583450, -0.223413111786271020, -0.223461847699426230, -0.223510583053926400, -0.223559317849650140, -0.223608052086475970, -0.223656785764281270, +-0.223705518882944600, -0.223754251442344120, -0.223802983442358470, -0.223851714882864900, -0.223900445763742070, -0.223949176084868110, -0.223997905846121640, -0.224046635047379980, +-0.224095363688521730, -0.224144091769425070, -0.224192819289968620, -0.224241546250029680, -0.224290272649486870, -0.224338998488218390, -0.224387723766102830, -0.224436448483017550, +-0.224485172638841130, -0.224533896233452240, -0.224582619266728150, -0.224631341738547510, -0.224680063648788540, -0.224728784997329820, -0.224777505784048700, -0.224826226008823850, +-0.224874945671533400, -0.224923664772056050, -0.224972383310269090, -0.225021101286051160, -0.225069818699280500, -0.225118535549835710, -0.225167251837594150, -0.225215967562434450, +-0.225264682724234860, -0.225313397322873980, -0.225362111358229170, -0.225410824830179070, -0.225459537738601950, -0.225508250083376380, -0.225556961864379760, -0.225605673081490740, +-0.225654383734587990, -0.225703093823548810, -0.225751803348251930, -0.225800512308575510, -0.225849220704398250, -0.225897928535597540, -0.225946635802051960, -0.225995342503639810, +-0.226044048640239750, -0.226092754211729110, -0.226141459217986620, -0.226190163658890440, -0.226238867534319320, -0.226287570844150580, -0.226336273588262920, -0.226384975766534570, +-0.226433677378844210, -0.226482378425069240, -0.226531078905088310, -0.226579778818780140, -0.226628478166022050, -0.226677176946692790, -0.226725875160670580, -0.226774572807834110, +-0.226823269888060790, -0.226871966401229280, -0.226920662347217890, -0.226969357725905240, -0.227018052537168780, -0.227066746780887170, -0.227115440456938710, -0.227164133565202070, +-0.227212826105554680, -0.227261518077875200, -0.227310209482041950, -0.227358900317933600, -0.227407590585427560, -0.227456280284402540, -0.227504969414737270, -0.227553657976309140, +-0.227602345968996870, -0.227651033392678700, -0.227699720247233420, -0.227748406532538390, -0.227797092248472330, -0.227845777394913570, -0.227894461971740790, -0.227943145978831420, +-0.227991829416064160, -0.228040512283317370, -0.228089194580469700, -0.228137876307398620, -0.228186557463982860, -0.228235238050100680, -0.228283918065630860, -0.228332597510450820, +-0.228381276384439250, -0.228429954687474540, -0.228478632419435330, -0.228527309580199120, -0.228575986169644640, -0.228624662187650650, -0.228673337634094530, -0.228722012508855100, +-0.228770686811810620, -0.228819360542839860, -0.228868033701820270, -0.228916706288630590, -0.228965378303149140, -0.229014049745254690, -0.229062720614824690, -0.229111390911737880, +-0.229160060635872580, -0.229208729787107570, -0.229257398365320300, -0.229306066370389560, -0.229354733802193620, -0.229403400660611300, -0.229452066945520030, -0.229500732656798600, +-0.229549397794325760, -0.229598062357979000, -0.229646726347637080, -0.229695389763178350, -0.229744052604481580, -0.229792714871424250, -0.229841376563885150, -0.229890037681742570, +-0.229938698224875340, -0.229987358193160930, -0.230036017586478150, -0.230084676404705310, -0.230133334647721200, -0.230181992315403340, -0.230230649407630490, -0.230279305924281000, +-0.230327961865233720, -0.230376617230366070, -0.230425272019556870, -0.230473926232684950, -0.230522579869627760, -0.230571232930264130, -0.230619885414472430, -0.230668537322131440, +-0.230717188653118660, -0.230765839407312930, -0.230814489584592580, -0.230863139184836450, -0.230911788207922050, -0.230960436653728170, -0.231009084522133200, -0.231057731813015950, +-0.231106378526253930, -0.231155024661725970, -0.231203670219310460, -0.231252315198886200, -0.231300959600330700, -0.231349603423522810, -0.231398246668341360, -0.231446889334663840, +-0.231495531422369120, -0.231544172931335560, -0.231592813861442010, -0.231641454212565990, -0.231690093984586310, -0.231738733177381420, -0.231787371790830120, -0.231836009824809950, +-0.231884647279199770, -0.231933284153877980, -0.231981920448723400, -0.232030556163613590, -0.232079191298427380, -0.232127825853043200, -0.232176459827339890, -0.232225093221195000, +-0.232273726034487370, -0.232322358267095440, -0.232370989918898010, -0.232419620989772700, -0.232468251479598350, -0.232516881388253770, -0.232565510715616600, -0.232614139461565620, +-0.232662767625979290, -0.232711395208736490, -0.232760022209714760, -0.232808648628792970, -0.232857274465849560, -0.232905899720763390, -0.232954524393412050, -0.233003148483674400, +-0.233051771991428870, -0.233100394916554350, -0.233149017258928420, -0.233197639018429940, -0.233246260194937350, -0.233294880788329550, -0.233343500798484120, -0.233392120225279940, +-0.233440739068595890, -0.233489357328309550, -0.233537975004299820, -0.233586592096445170, -0.233635208604624440, -0.233683824528715280, -0.233732439868596570, -0.233781054624146750, +-0.233829668795244690, -0.233878282381768080, -0.233926895383595730, -0.233975507800606160, -0.234024119632678250, -0.234072730879689610, -0.234121341541519120, -0.234169951618045300, +-0.234218561109147020, -0.234267170014701900, -0.234315778334588890, -0.234364386068686840, -0.234412993216873390, -0.234461599779027450, -0.234510205755027540, -0.234558811144752520, +-0.234607415948080040, -0.234656020164889040, -0.234704623795057990, -0.234753226838465810, -0.234801829294990110, -0.234850431164509850, -0.234899032446903520, -0.234947633142050030, +-0.234996233249827050, -0.235044832770113450, -0.235093431702787790, -0.235142030047728990, -0.235190627804814640, -0.235239224973923770, -0.235287821554934830, -0.235336417547726750, +-0.235385012952177200, -0.235433607768165130, -0.235482201995569460, -0.235530795634267850, -0.235579388684139250, -0.235627981145062200, -0.235676573016915610, -0.235725164299577160, +-0.235773754992925800, -0.235822345096840050, -0.235870934611198870, -0.235919523535879920, -0.235968111870762160, -0.236016699615724130, -0.236065286770644780, -0.236113873335401760, +-0.236162459309874090, -0.236211044693940250, -0.236259629487479250, -0.236308213690368720, -0.236356797302487680, -0.236405380323715050, -0.236453962753928580, -0.236502544593007180, +-0.236551125840829410, -0.236599706497274270, -0.236648286562219420, -0.236696866035543850, -0.236745444917126120, -0.236794023206845230, -0.236842600904578810, -0.236891178010205930, +-0.236939754523605080, -0.236988330444655280, -0.237036905773234250, -0.237085480509220900, -0.237134054652493900, -0.237182628202932180, -0.237231201160413440, -0.237279773524816720, +-0.237328345296020980, -0.237376916473903960, -0.237425487058344630, -0.237474057049221620, -0.237522626446413860, -0.237571195249799110, -0.237619763459256390, -0.237668331074664230, +-0.237716898095901710, -0.237765464522846500, -0.237814030355377630, -0.237862595593373670, -0.237911160236713660, -0.237959724285275310, -0.238008287738937670, -0.238056850597579310, +-0.238105412861079250, -0.238153974529315220, -0.238202535602166250, -0.238251096079511370, -0.238299655961228350, -0.238348215247196150, -0.238396773937293440, -0.238445332031399200, +-0.238493889529391210, -0.238542446431148520, -0.238591002736549710, -0.238639558445473800, -0.238688113557798560, -0.238736668073403050, -0.238785221992165870, -0.238833775313966070, +-0.238882328038681400, -0.238930880166190910, -0.238979431696373200, -0.239027982629107380, -0.239076532964271140, -0.239125082701743570, -0.239173631841403310, -0.239222180383129400, +-0.239270728326799580, -0.239319275672292970, -0.239367822419488590, -0.239416368568264230, -0.239464914118498930, -0.239513459070071380, -0.239562003422860580, -0.239610547176744350, +-0.239659090331601770, -0.239707632887311450, -0.239756174843752470, -0.239804716200802630, -0.239853256958341000, -0.239901797116246230, -0.239950336674397390, -0.239998875632672280, +-0.240047413990949980, -0.240095951749109170, -0.240144488907028890, -0.240193025464586960, -0.240241561421662450, -0.240290096778134480, -0.240338631533880850, -0.240387165688780630, +-0.240435699242712490, -0.240484232195555540, -0.240532764547187580, -0.240581296297487700, -0.240629827446334600, -0.240678357993607340, -0.240726887939183760, -0.240775417282942970, +-0.240823946024763620, -0.240872474164524840, -0.240921001702104450, -0.240969528637381580, -0.241018054970234850, -0.241066580700543430, -0.241115105828185130, -0.241163630353039060, +-0.241212154274984350, -0.241260677593898830, -0.241309200309661580, -0.241357722422151370, -0.241406243931247270, -0.241454764836827120, -0.241503285138770060, -0.241551804836954820, +-0.241600323931260460, -0.241648842421564870, -0.241697360307747190, -0.241745877589686080, -0.241794394267260740, -0.241842910340348970, -0.241891425808829910, -0.241939940672582290, +-0.241988454931485270, -0.242036968585416650, -0.242085481634255640, -0.242133994077880920, -0.242182505916171630, -0.242231017149005660, -0.242279527776262130, -0.242328037797820220, +-0.242376547213557810, -0.242425056023353990, -0.242473564227087550, -0.242522071824637640, -0.242570578815882090, -0.242619085200700140, -0.242667590978970420, -0.242716096150572190, +-0.242764600715383280, -0.242813104673282880, -0.242861608024149720, -0.242910110767862950, -0.242958612904300490, -0.243007114433341470, -0.243055615354864700, -0.243104115668749290, +-0.243152615374873180, -0.243201114473115540, -0.243249612963355540, -0.243298110845471070, -0.243346608119341310, -0.243395104784845050, -0.243443600841861450, -0.243492096290268410, +-0.243540591129945140, -0.243589085360770400, -0.243637578982623370, -0.243686071995381950, -0.243734564398925350, -0.243783056193132370, -0.243831547377882150, -0.243880037953052630, +-0.243928527918523040, -0.243977017274172120, -0.244025506019879070, -0.244073994155521830, -0.244122481680979640, -0.244170968596131630, -0.244219454900855780, -0.244267940595031320, +-0.244316425678536980, -0.244364910151252030, -0.244413394013054340, -0.244461877263823210, -0.244510359903437340, -0.244558841931776020, -0.244607323348717180, -0.244655804154140010, +-0.244704284347923350, -0.244752763929946380, -0.244801242900087090, -0.244849721258224710, -0.244898199004238010, -0.244946676138006250, -0.244995152659407360, -0.245043628568320570, +-0.245092103864625150, -0.245140578548199070, -0.245189052618921520, -0.245237526076671350, -0.245285998921327770, -0.245334471152768770, -0.245382942770873610, -0.245431413775521080, +-0.245479884166590450, -0.245528353943959690, -0.245576823107508030, -0.245625291657114300, -0.245673759592657800, -0.245722226914016460, -0.245770693621069540, -0.245819159713695920, +-0.245867625191774800, -0.245916090055184190, -0.245964554303803370, -0.246013017937511150, -0.246061480956186820, -0.246109943359708370, -0.246158405147955030, -0.246206866320806160, +-0.246255326878139640, -0.246303786819834840, -0.246352246145770560, -0.246400704855826070, -0.246449162949879420, -0.246497620427809840, -0.246546077289496230, -0.246594533534817860, +-0.246642989163652710, -0.246691444175880100, -0.246739898571378870, -0.246788352350028330, -0.246836805511706480, -0.246885258056292610, -0.246933709983665590, -0.246982161293704730, +-0.247030611986288030, -0.247079062061294820, -0.247127511518604380, -0.247175960358094720, -0.247224408579645170, -0.247272856183134580, -0.247321303168442310, -0.247369749535446330, +-0.247418195284025980, -0.247466640414060140, -0.247515084925428120, -0.247563528818007970, -0.247611972091679010, -0.247660414746320110, -0.247708856781810590, -0.247757298198028520, +-0.247805738994853200, -0.247854179172163510, -0.247902618729838820, -0.247951057667757160, -0.247999495985797850, -0.248047933683840230, -0.248096370761762360, -0.248144807219443540, +-0.248193243056762710, -0.248241678273599190, -0.248290112869831050, -0.248338546845337650, -0.248386980199997860, -0.248435412933691060, -0.248483845046295310, -0.248532276537689920, +-0.248580707407753840, -0.248629137656366430, -0.248677567283405760, -0.248725996288751170, -0.248774424672281590, -0.248822852433876360, -0.248871279573413570, -0.248919706090772600, +-0.248968131985832340, -0.249016557258472190, -0.249064981908570240, -0.249113405936005810, -0.249161829340658310, -0.249210252122405800, -0.249258674281127630, -0.249307095816702820, +-0.249355516729010680, -0.249403937017929320, -0.249452356683338120, -0.249500775725116030, -0.249549194143142420, -0.249597611937295400, -0.249646029107454370, -0.249694445653498240, +-0.249742861575306450, -0.249791276872757070, -0.249839691545729490, -0.249888105594102680, -0.249936519017756040, -0.249984931816567670, -0.250033343990416990, -0.250081755539183330, +-0.250130166462744890, -0.250178576760981040, -0.250226986433770730, -0.250275395480993370, -0.250323803902527120, -0.250372211698251360, -0.250420618868045060, -0.250469025411787620, +-0.250517431329357220, -0.250565836620633250, -0.250614241285494640, -0.250662645323820930, -0.250711048735490110, -0.250759451520381700, -0.250807853678374660, -0.250856255209348400, +-0.250904656113181080, -0.250953056389752130, -0.251001456038940970, -0.251049855060625720, -0.251098253454685840, -0.251146651221000330, -0.251195048359448670, -0.251243444869908910, +-0.251291840752260520, -0.251340236006382560, -0.251388630632154440, -0.251437024629454280, -0.251485417998161600, -0.251533810738155340, -0.251582202849314980, -0.251630594331518740, +-0.251678985184645930, -0.251727375408575700, -0.251775765003187490, -0.251824153968359440, -0.251872542303970940, -0.251920930009901120, -0.251969317086029430, -0.252017703532234020, +-0.252066089348394310, -0.252114474534389790, -0.252162859090098720, -0.252211243015400430, -0.252259626310174120, -0.252308008974299110, -0.252356391007653670, -0.252404772410117220, +-0.252453153181568910, -0.252501533321888070, -0.252549912830953020, -0.252598291708643170, -0.252646669954837590, -0.252695047569415740, -0.252743424552255900, -0.252791800903237440, +-0.252840176622239510, -0.252888551709141540, -0.252936926163821800, -0.252985299986159710, -0.253033673176034810, -0.253082045733325320, -0.253130417657910720, -0.253178788949670050, +-0.253227159608482850, -0.253275529634227280, -0.253323899026782930, -0.253372267786028840, -0.253420635911844490, -0.253469003404108110, -0.253517370262699220, -0.253565736487496920, +-0.253614102078380750, -0.253662467035228820, -0.253710831357920770, -0.253759195046335650, -0.253807558100352940, -0.253855920519850900, -0.253904282304709070, -0.253952643454806950, +-0.254001003970022840, -0.254049363850236190, -0.254097723095326130, -0.254146081705172170, -0.254194439679652610, -0.254242797018646940, -0.254291153722034310, -0.254339509789694160, +-0.254387865221504860, -0.254436220017345840, -0.254484574177096360, -0.254532927700635790, -0.254581280587842520, -0.254629632838596020, -0.254677984452775450, -0.254726335430260350, +-0.254774685770928990, -0.254823035474660900, -0.254871384541335620, -0.254919732970831480, -0.254968080763028020, -0.255016427917804380, -0.255064774435040050, -0.255113120314613360, +-0.255161465556403900, -0.255209810160290760, -0.255258154126153550, -0.255306497453870460, -0.255354840143321220, -0.255403182194384790, -0.255451523606940900, -0.255499864380867750, +-0.255548204516044930, -0.255596544012351600, -0.255644882869667300, -0.255693221087870400, -0.255741558666840450, -0.255789895606456650, -0.255838231906598490, -0.255886567567144290, +-0.255934902587973740, -0.255983236968966300, -0.256031570710000380, -0.256079903810955520, -0.256128236271710890, -0.256176568092146120, -0.256224899272139480, -0.256273229811570640, +-0.256321559710318670, -0.256369888968263240, -0.256418217585282720, -0.256466545561256590, -0.256514872896064120, -0.256563199589584840, -0.256611525641697200, -0.256659851052280730, +-0.256708175821214630, -0.256756499948378510, -0.256804823433650740, -0.256853146276910860, -0.256901468478038570, -0.256949790036912210, -0.256998110953411350, -0.257046431227415220, +-0.257094750858803400, -0.257143069847454330, -0.257191388193247550, -0.257239705896062320, -0.257288022955778240, -0.257336339372273680, -0.257384655145428300, -0.257432970275121240, +-0.257481284761232170, -0.257529598603639500, -0.257577911802222840, -0.257626224356861390, -0.257674536267434750, -0.257722847533821410, -0.257771158155900960, -0.257819468133553000, +-0.257867777466655960, -0.257916086155089490, -0.257964394198732740, -0.258012701597465480, -0.258061008351166080, -0.258109314459714080, -0.258157619922988860, -0.258205924740869950, +-0.258254228913235850, -0.258302532439966200, -0.258350835320940160, -0.258399137556037490, -0.258447439145136570, -0.258495740088116990, -0.258544040384858120, -0.258592340035239570, +-0.258640639039139700, -0.258688937396438280, -0.258737235107014460, -0.258785532170748010, -0.258833828587517360, -0.258882124357202040, -0.258930419479681870, -0.258978713954835240, +-0.259027007782541840, -0.259075300962680890, -0.259123593495132140, -0.259171885379773980, -0.259220176616486110, -0.259268467205147730, -0.259316757145638680, -0.259365046437837310, +-0.259413335081623290, -0.259461623076875980, -0.259509910423474990, -0.259558197121298790, -0.259606483170227160, -0.259654768570139250, -0.259703053320914920, -0.259751337422432450, +-0.259799620874571700, -0.259847903677212280, -0.259896185830232720, -0.259944467333512670, -0.259992748186931470, -0.260041028390368800, -0.260089307943703110, -0.260137586846814210, +-0.260185865099581300, -0.260234142701884160, -0.260282419653601270, -0.260330695954612280, -0.260378971604796560, -0.260427246604033880, -0.260475520952202610, -0.260523794649182570, +-0.260572067694853030, -0.260620340089093790, -0.260668611831783190, -0.260716882922801150, -0.260765153362027270, -0.260813423149340080, -0.260861692284619360, -0.260909960767744360, +-0.260958228598594970, -0.261006495777049490, -0.261054762302987850, -0.261103028176289220, -0.261151293396833520, -0.261199557964499120, -0.261247821879165840, -0.261296085140713010, +-0.261344347749020380, -0.261392609703966490, -0.261440871005431060, -0.261489131653293410, -0.261537391647433390, -0.261585650987729460, -0.261633909674061420, -0.261682167706309030, +-0.261730425084350790, -0.261778681808066460, -0.261826937877335460, -0.261875193292037510, -0.261923448052051140, -0.261971702157256180, -0.262019955607532000, -0.262068208402758300, +-0.262116460542813680, -0.262164712027577910, -0.262212962856930350, -0.262261213030750780, -0.262309462548917790, -0.262357711411311150, -0.262405959617810210, -0.262454207168294820, +-0.262502454062643440, -0.262550700300735960, -0.262598945882451750, -0.262647190807670570, -0.262695435076271020, -0.262743678688132860, -0.262791921643135920, -0.262840163941158720, +-0.262888405582081150, -0.262936646565782580, -0.262984886892142780, -0.263033126561040390, -0.263081365572355120, -0.263129603925966520, -0.263177841621754280, -0.263226078659597020, +-0.263274315039374540, -0.263322550760966280, -0.263370785824252110, -0.263419020229110510, -0.263467253975421370, -0.263515487063064100, -0.263563719491918540, -0.263611951261863210, +-0.263660182372778050, -0.263708412824542830, -0.263756642617036190, -0.263804871750137950, -0.263853100223727490, -0.263901328037684730, -0.263949555191888230, -0.263997781686217790, +-0.264046007520552960, -0.264094232694773500, -0.264142457208758060, -0.264190681062386470, -0.264238904255538140, -0.264287126788093020, -0.264335348659929640, -0.264383569870927870, +-0.264431790420967210, -0.264480010309927520, -0.264528229537687340, -0.264576448104126560, -0.264624666009125150, -0.264672883252561610, -0.264721099834315850, -0.264769315754267380, +-0.264817531012295990, -0.264865745608280410, -0.264913959542100400, -0.264962172813635540, -0.265010385422765670, -0.265058597369369430, -0.265106808653326640, -0.265155019274516850, +-0.265203229232819970, -0.265251438528114560, -0.265299647160280590, -0.265347855129197450, -0.265396062434745120, -0.265444269076802240, -0.265492475055248640, -0.265540680369963870, +-0.265588885020827840, -0.265637089007719150, -0.265685292330517740, -0.265733494989103540, -0.265781696983355130, -0.265829898313152510, -0.265878098978375170, -0.265926298978902960, +-0.265974498314614620, -0.266022696985390050, -0.266070894991108700, -0.266119092331650540, -0.266167289006894240, -0.266215485016719710, -0.266263680361006450, -0.266311875039634440, +-0.266360069052482270, -0.266408262399430000, -0.266456455080357040, -0.266504647095143320, -0.266552838443667620, -0.266601029125809800, -0.266649219141449840, -0.266697408490466410, +-0.266745597172739430, -0.266793785188148500, -0.266841972536573550, -0.266890159217893160, -0.266938345231987450, -0.266986530578735840, -0.267034715258018310, -0.267082899269713630, +-0.267131082613701660, -0.267179265289861970, -0.267227447298074570, -0.267275628638218130, -0.267323809310172580, -0.267371989313817560, -0.267420168649032950, -0.267468347315697520, +-0.267516525313691190, -0.267564702642894000, -0.267612879303184610, -0.267661055294443060, -0.267709230616548830, -0.267757405269381970, -0.267805579252821170, -0.267853752566746370, +-0.267901925211037280, -0.267950097185573720, -0.267998268490234560, -0.268046439124899670, -0.268094609089448710, -0.268142778383761660, -0.268190947007717230, -0.268239114961195460, +-0.268287282244075890, -0.268335448856238500, -0.268383614797562060, -0.268431780067926620, -0.268479944667212140, -0.268528108595297410, -0.268576271852062400, -0.268624434437386650, +-0.268672596351150320, -0.268720757593232000, -0.268768918163511840, -0.268817078061869390, -0.268865237288184620, -0.268913395842336370, -0.268961553724204610, -0.269009710933668990, +-0.269057867470609500, -0.269106023334904910, -0.269154178526435250, -0.269202333045080180, -0.269250486890719680, -0.269298640063232560, -0.269346792562498830, -0.269394944388398060, +-0.269443095540810420, -0.269491246019614610, -0.269539395824690660, -0.269587544955918690, -0.269635693413177390, -0.269683841196346860, -0.269731988305306760, -0.269780134739937120, +-0.269828280500116650, -0.269876425585725550, -0.269924569996643330, -0.269972713732750170, -0.270020856793924740, -0.270068999180047230, -0.270117140890997140, -0.270165281926654680, +-0.270213422286898600, -0.270261561971608940, -0.270309700980665370, -0.270357839313948020, -0.270405976971335620, -0.270454113952708240, -0.270502250257946050, -0.270550385886927760, +-0.270598520839533560, -0.270646655115643010, -0.270694788715136300, -0.270742921637892150, -0.270791053883790710, -0.270839185452711630, -0.270887316344535000, -0.270935446559139700, +-0.270983576096405720, -0.271031704956212870, -0.271079833138441140, -0.271127960642969400, -0.271176087469677750, -0.271224213618445900, -0.271272339089153940, -0.271320463881680740, +-0.271368587995906350, -0.271416711431710920, -0.271464834188973270, -0.271512956267573550, -0.271561077667391400, -0.271609198388307050, -0.271657318430199250, -0.271705437792948150, +-0.271753556476433400, -0.271801674480535270, -0.271849791805132470, -0.271897908450105250, -0.271946024415333220, -0.271994139700696580, -0.272042254306074090, -0.272090368231346020, +-0.272138481476392080, -0.272186594041092300, -0.272234705925325620, -0.272282817128972180, -0.272330927651911690, -0.272379037494024310, -0.272427146655188910, -0.272475255135285640, +-0.272523362934194660, -0.272571470051794830, -0.272619576487966360, -0.272667682242588970, -0.272715787315542750, -0.272763891706706620, -0.272811995415960800, -0.272860098443184980, +-0.272908200788259340, -0.272956302451062780, -0.273004403431475470, -0.273052503729377120, -0.273100603344647970, -0.273148702277166870, -0.273196800526814050, -0.273244898093469190, +-0.273292994977012480, -0.273341091177322910, -0.273389186694280580, -0.273437281527765750, -0.273485375677657240, -0.273533469143835360, -0.273581561926179770, -0.273629654024570680, +-0.273677745438887070, -0.273725836169009030, -0.273773926214816440, -0.273822015576189460, -0.273870104253007010, -0.273918192245149350, -0.273966279552496140, -0.274014366174927690, +-0.274062452112322890, -0.274110537364561980, -0.274158621931524680, -0.274206705813091310, -0.274254789009140690, -0.274302871519553130, -0.274350953344208840, -0.274399034482986690, +-0.274447114935766960, -0.274495194702429500, -0.274543273782854420, -0.274591352176920770, -0.274639429884508680, -0.274687506905498090, -0.274735583239769100, -0.274783658887200740, +-0.274831733847673290, -0.274879808121066440, -0.274927881707260510, -0.274975954606134440, -0.275024026817568550, -0.275072098341442530, -0.275120169177636710, -0.275168239326030020, +-0.275216308786502720, -0.275264377558935120, -0.275312445643206120, -0.275360513039196010, -0.275408579746784620, -0.275456645765852210, -0.275504711096277780, -0.275552775737941570, +-0.275600839690723350, -0.275648902954503560, -0.275696965529161010, -0.275745027414576070, -0.275793088610628570, -0.275841149117198760, -0.275889208934165690, -0.275937268061409560, +-0.275985326498810250, -0.276033384246248070, -0.276081441303602020, -0.276129497670752340, -0.276177553347578930, -0.276225608333962040, -0.276273662629780700, -0.276321716234915250, +-0.276369769149245880, -0.276417821372651700, -0.276465872905012950, -0.276513923746209530, -0.276561973896121750, -0.276610023354628590, -0.276658072121610370, -0.276706120196946960, +-0.276754167580518680, -0.276802214272204530, -0.276850260271884860, -0.276898305579439560, -0.276946350194748890, -0.276994394117691940, -0.277042437348149040, -0.277090479886000000, +-0.277138521731125190, -0.277186562883403650, -0.277234603342715710, -0.277282643108941680, -0.277330682181960660, -0.277378720561652860, -0.277426758247898310, -0.277474795240577280, +-0.277522831539568860, -0.277570867144753320, -0.277618902056010640, -0.277666936273221090, -0.277714969796263810, -0.277763002625019070, -0.277811034759366860, -0.277859066199187490, +-0.277907096944360050, -0.277955126994764820, -0.278003156350281780, -0.278051185010791290, -0.278099212976172410, -0.278147240246305490, -0.278195266821070930, -0.278243292700347700, +-0.278291317884016290, -0.278339342371956620, -0.278387366164048970, -0.278435389260172470, -0.278483411660207510, -0.278531433364034020, -0.278579454371532420, -0.278627474682581700, +-0.278675494297062290, -0.278723513214854170, -0.278771531435837720, -0.278819548959891970, -0.278867565786897360, -0.278915581916733820, -0.278963597349281780, -0.279011612084420320, +-0.279059626122029840, -0.279107639461990240, -0.279155652104182030, -0.279203664048484230, -0.279251675294777290, -0.279299685842941570, -0.279347695692856220, -0.279395704844401630, +-0.279443713297457760, -0.279491721051905060, -0.279539728107622620, -0.279587734464490810, -0.279635740122389730, -0.279683745081199700, -0.279731749340799920, -0.279779752901070710, +-0.279827755761892170, -0.279875757923144620, -0.279923759384707260, -0.279971760146460520, -0.280019760208284400, -0.280067759570059250, -0.280115758231664290, -0.280163756192979950, +-0.280211753453886660, -0.280259750014263510, -0.280307745873991040, -0.280355741032949190, -0.280403735491018380, -0.280451729248077870, -0.280499722304007990, -0.280547714658688830, +-0.280595706312000760, -0.280643697263823040, -0.280691687514036060, -0.280739677062519900, -0.280787665909154940, -0.280835654053820380, -0.280883641496396660, -0.280931628236763880, +-0.280979614274802450, -0.281027599610391590, -0.281075584243411670, -0.281123568173743290, -0.281171551401265480, -0.281219533925858860, -0.281267515747403330, -0.281315496865779500, +-0.281363477280866470, -0.281411456992544770, -0.281459436000694450, -0.281507414305195940, -0.281555391905928430, -0.281603368802772480, -0.281651344995608120, -0.281699320484315780, +-0.281747295268774730, -0.281795269348865450, -0.281843242724468030, -0.281891215395462860, -0.281939187361729290, -0.281987158623147720, -0.282035129179598660, -0.282083099030961400, +-0.282131068177116360, -0.282179036617943630, -0.282227004353323820, -0.282274971383136010, -0.282322937707260750, -0.282370903325578180, -0.282418868237968750, -0.282466832444311760, +-0.282514795944487700, -0.282562758738376610, -0.282610720825859030, -0.282658682206814280, -0.282706642881122790, -0.282754602848664720, -0.282802562109320530, -0.282850520662969510, +-0.282898478509492230, -0.282946435648768760, -0.282994392080679560, -0.283042347805104010, -0.283090302821922550, -0.283138257131015810, -0.283186210732262970, -0.283234163625544600, +-0.283282115810740810, -0.283330067287732190, -0.283378018056397950, -0.283425968116618690, -0.283473917468274490, -0.283521866111245970, -0.283569814045412320, -0.283617761270654080, +-0.283665707786851520, -0.283713653593885060, -0.283761598691634090, -0.283809543079979080, -0.283857486758800240, -0.283905429727978110, -0.283953371987391960, -0.284001313536922370, +-0.284049254376449960, -0.284097194505853970, -0.284145133925015000, -0.284193072633813220, -0.284241010632129140, -0.284288947919842110, -0.284336884496832750, -0.284384820362981130, +-0.284432755518167930, -0.284480689962272380, -0.284528623695175120, -0.284576556716756300, -0.284624489026896520, -0.284672420625475100, -0.284720351512372570, -0.284768281687469200, +-0.284816211150645590, -0.284864139901781000, -0.284912067940756020, -0.284959995267451360, -0.285007921881746230, -0.285055847783521330, -0.285103772972656820, -0.285151697449033290, +-0.285199621212530060, -0.285247544263027790, -0.285295466600406720, -0.285343388224547360, -0.285391309135329060, -0.285439229332632550, -0.285487148816337970, -0.285535067586325910, +-0.285582985642475750, -0.285630902984668140, -0.285678819612783300, -0.285726735526701800, -0.285774650726303090, -0.285822565211467710, -0.285870478982075900, -0.285918392038008340, +-0.285966304379144390, -0.286014216005364640, -0.286062126916549810, -0.286110037112579210, -0.286157946593333550, -0.286205855358693030, -0.286253763408538250, -0.286301670742748650, +-0.286349577361204920, -0.286397483263787170, -0.286445388450376200, -0.286493292920851290, -0.286541196675093200, -0.286589099712982080, -0.286637002034398620, -0.286684903639222280, +-0.286732804527333630, -0.286780704698613000, -0.286828604152941040, -0.286876502890197120, -0.286924400910261950, -0.286972298213016230, -0.287020194798339350, -0.287068090666111940, +-0.287115985816214280, -0.287163880248527130, -0.287211773962929850, -0.287259666959303110, -0.287307559237527210, -0.287355450797482870, -0.287403341639049460, -0.287451231762107680, +-0.287499121166537810, -0.287547009852220590, -0.287594897819035410, -0.287642785066862970, -0.287690671595583590, -0.287738557405077980, -0.287786442495225500, -0.287834326865906930, +-0.287882210517002970, -0.287930093448393100, -0.287977975659957920, -0.288025857151577860, -0.288073737923133570, -0.288121617974504530, -0.288169497305571400, -0.288217375916214550, +-0.288265253806314680, -0.288313130975751230, -0.288361007424404960, -0.288408883152156240, -0.288456758158885660, -0.288504632444472770, -0.288552506008798340, -0.288600378851742610, +-0.288648250973186360, -0.288696122373009070, -0.288743993051091440, -0.288791863007314300, -0.288839732241557070, -0.288887600753700460, -0.288935468543624900, -0.288983335611211090, +-0.289031201956338520, -0.289079067578887900, -0.289126932478739660, -0.289174796655774500, -0.289222660109871910, -0.289270522840912700, -0.289318384848777140, -0.289366246133346050, +-0.289414106694498960, -0.289461966532116590, -0.289509825646079240, -0.289557684036267860, -0.289605541702561750, -0.289653398644841850, -0.289701254862988420, -0.289749110356882280, +-0.289796965126402960, -0.289844819171431180, -0.289892672491847800, -0.289940525087532370, -0.289988376958365550, -0.290036228104227860, -0.290084078524999960, -0.290131928220561440, +-0.290179777190793130, -0.290227625435575400, -0.290275472954789000, -0.290323319748313490, -0.290371165816029670, -0.290419011157817930, -0.290466855773559130, -0.290514699663132760, +-0.290562542826419580, -0.290610385263300130, -0.290658226973655060, -0.290706067957364030, -0.290753908214307850, -0.290801747744367340, -0.290849586547421990, -0.290897424623352660, +-0.290945261972039850, -0.290993098593364250, -0.291040934487205470, -0.291088769653444380, -0.291136604091961350, -0.291184437802637250, -0.291232270785351630, -0.291280103039985310, +-0.291327934566418760, -0.291375765364532800, -0.291423595434206980, -0.291471424775322170, -0.291519253387758800, -0.291567081271397740, -0.291614908426118590, -0.291662734851802110, +-0.291710560548329220, -0.291758385515579530, -0.291806209753433850, -0.291854033261772670, -0.291901856040476800, -0.291949678089425900, -0.291997499408500780, -0.292045319997581930, +-0.292093139856550170, -0.292140958985285190, -0.292188777383667770, -0.292236595051578400, -0.292284411988897990, -0.292332228195506140, -0.292380043671283670, -0.292427858416111130, +-0.292475672429869380, -0.292523485712438020, -0.292571298263697930, -0.292619110083529590, -0.292666921171813920, -0.292714731528430470, -0.292762541153260280, -0.292810350046184110, +-0.292858158207081610, -0.292905965635833760, -0.292953772332321010, -0.293001578296424200, -0.293049383528023070, -0.293097188026998470, -0.293144991793230840, -0.293192794826601210, +-0.293240597126989190, -0.293288398694275640, -0.293336199528341110, -0.293383999629066470, -0.293431798996331480, -0.293479597630016910, -0.293527395530003400, -0.293575192696171830, +-0.293622989128401790, -0.293670784826574330, -0.293718579790570370, -0.293766374020269450, -0.293814167515552670, -0.293861960276300400, -0.293909752302393690, -0.293957543593712180, +-0.294005334150136800, -0.294053123971548090, -0.294100913057827040, -0.294148701408853240, -0.294196489024507680, -0.294244275904670890, -0.294292062049223870, -0.294339847458046260, +-0.294387632131018980, -0.294435416068022650, -0.294483199268938230, -0.294530981733645390, -0.294578763462025050, -0.294626544453958250, -0.294674324709324700, -0.294722104228005320, +-0.294769883009880660, -0.294817661054831700, -0.294865438362738210, -0.294913214933481100, -0.294960990766940930, -0.295008765862998730, -0.295056540221534210, -0.295104313842428300, +-0.295152086725561650, -0.295199858870815180, -0.295247630278068660, -0.295295400947203020, -0.295343170878098920, -0.295390940070637320, -0.295438708524697890, -0.295486476240161780, +-0.295534243216909850, -0.295582009454821880, -0.295629774953778900, -0.295677539713661450, -0.295725303734350630, -0.295773067015726090, -0.295820829557668920, -0.295868591360059610, +-0.295916352422779310, -0.295964112745707660, -0.296011872328725780, -0.296059631171714190, -0.296107389274553930, -0.296155146637124780, -0.296202903259307760, -0.296250659140983530, +-0.296298414282033020, -0.296346168682336040, -0.296393922341773700, -0.296441675260226520, -0.296489427437575560, -0.296537178873700620, -0.296584929568482760, -0.296632679521803000, +-0.296680428733541060, -0.296728177203578080, -0.296775924931794670, -0.296823671918071850, -0.296871418162289460, -0.296919163664328520, -0.296966908424069640, -0.297014652441393910, +-0.297062395716181150, -0.297110138248312390, -0.297157880037668300, -0.297205621084129960, -0.297253361387577080, -0.297301100947890810, -0.297348839764951800, -0.297396577838641150, +-0.297444315168838570, -0.297492051755425260, -0.297539787598282200, -0.297587522697289280, -0.297635257052327520, -0.297682990663277640, -0.297730723530020670, -0.297778455652436550, +-0.297826187030406200, -0.297873917663810440, -0.297921647552530310, -0.297969376696445580, -0.298017105095437440, -0.298064832749386550, -0.298112559658174010, -0.298160285821679640, +-0.298208011239784580, -0.298255735912369420, -0.298303459839315390, -0.298351183020502290, -0.298398905455811210, -0.298446627145123320, -0.298494348088318430, -0.298542068285277680, +-0.298589787735881740, -0.298637506440011750, -0.298685224397547580, -0.298732941608370330, -0.298780658072360760, -0.298828373789399910, -0.298876088759367780, -0.298923802982145380, +-0.298971516457613500, -0.299019229185653210, -0.299066941166144460, -0.299114652398968340, -0.299162362884005610, -0.299210072621137410, -0.299257781610243580, -0.299305489851205250, +-0.299353197343903250, -0.299400904088218680, -0.299448610084031450, -0.299496315331222620, -0.299544019829673490, -0.299591723579263890, -0.299639426579874910, -0.299687128831387430, +-0.299734830333682530, -0.299782531086640160, -0.299830231090141400, -0.299877930344067120, -0.299925628848298430, -0.299973326602715200, -0.300021023607198680, -0.300068719861629580, +-0.300116415365889180, -0.300164110119857220, -0.300211804123415080, -0.300259497376443360, -0.300307189878823320, -0.300354881630434940, -0.300402572631159330, -0.300450262880877670, +-0.300497952379469970, -0.300545641126817360, -0.300593329122800680, -0.300641016367301120, -0.300688702860198550, -0.300736388601374250, -0.300784073590708970, -0.300831757828083910, +-0.300879441313379010, -0.300927124046475590, -0.300974806027254290, -0.301022487255596440, -0.301070167731381900, -0.301117847454491990, -0.301165526424807430, -0.301213204642209520, +-0.301260882106578140, -0.301308558817794560, -0.301356234775740030, -0.301403909980294430, -0.301451584431339130, -0.301499258128754830, -0.301546931072422810, -0.301594603262223040, +-0.301642274698036730, -0.301689945379744750, -0.301737615307228370, -0.301785284480367510, -0.301832952899043440, -0.301880620563136970, -0.301928287472529370, -0.301975953627100670, +-0.302023619026732030, -0.302071283671304370, -0.302118947560698900, -0.302166610694795670, -0.302214273073475930, -0.302261934696620880, -0.302309595564110630, -0.302357255675826330, +-0.302404915031648960, -0.302452573631459660, -0.302500231475138550, -0.302547888562566810, -0.302595544893625390, -0.302643200468195480, -0.302690855286157190, -0.302738509347391770, +-0.302786162651780040, -0.302833815199203380, -0.302881466989541710, -0.302929118022676410, -0.302976768298488300, -0.303024417816858680, -0.303072066577667610, -0.303119714580796340, +-0.303167361826125860, -0.303215008313537320, -0.303262654042910860, -0.303310299014127760, -0.303357943227069380, -0.303405586681615660, -0.303453229377648010, -0.303500871315047270, +-0.303548512493694740, -0.303596152913470580, -0.303643792574256000, -0.303691431475931920, -0.303739069618379710, -0.303786707001479420, -0.303834343625112360, -0.303881979489159400, +-0.303929614593501930, -0.303977248938020030, -0.304024882522594960, -0.304072515347107720, -0.304120147411439610, -0.304167778715470680, -0.304215409259082360, -0.304263039042155900, +-0.304310668064571410, -0.304358296326210250, -0.304405923826953360, -0.304453550566682110, -0.304501176545276530, -0.304548801762618000, -0.304596426218587510, -0.304644049913066370, +-0.304691672845934620, -0.304739295017073750, -0.304786916426364630, -0.304834537073688630, -0.304882156958925900, -0.304929776081957700, -0.304977394442665140, -0.305025012040929470, +-0.305072628876630890, -0.305120244949650680, -0.305167860259870300, -0.305215474807169870, -0.305263088591430750, -0.305310701612533930, -0.305358313870360720, -0.305405925364791330, +-0.305453536095707130, -0.305501146062989120, -0.305548755266518590, -0.305596363706175820, -0.305643971381842130, -0.305691578293398490, -0.305739184440726340, -0.305786789823705770, +-0.305834394442218270, -0.305881998296144760, -0.305929601385366680, -0.305977203709764220, -0.306024805269218710, -0.306072406063611190, -0.306120006092823080, -0.306167605356734480, +-0.306215203855226940, -0.306262801588181810, -0.306310398555479200, -0.306357994757000650, -0.306405590192627090, -0.306453184862239990, -0.306500778765719460, -0.306548371902947040, +-0.306595964273803650, -0.306643555878170770, -0.306691146715928620, -0.306738736786958570, -0.306786326091141700, -0.306833914628359410, -0.306881502398491930, -0.306929089401420720, +-0.306976675637026740, -0.307024261105191540, -0.307071845805795220, -0.307119429738719310, -0.307167012903845240, -0.307214595301053220, -0.307262176930224670, -0.307309757791240760, +-0.307357337883982780, -0.307404917208331130, -0.307452495764167110, -0.307500073551371880, -0.307547650569826910, -0.307595226819412370, -0.307642802300009790, -0.307690377011500150, +-0.307737950953765050, -0.307785524126684580, -0.307833096530140350, -0.307880668164013380, -0.307928239028185170, -0.307975809122535920, -0.308023378446947160, -0.308070947001300330, +-0.308118514785475750, -0.308166081799354900, -0.308213648042818810, -0.308261213515749030, -0.308308778218025830, -0.308356342149530670, -0.308403905310144610, -0.308451467699749240, +-0.308499029318224820, -0.308546590165452770, -0.308594150241314260, -0.308641709545690810, -0.308689268078462640, -0.308736825839511290, -0.308784382828717900, -0.308831939045964010, +-0.308879494491129780, -0.308927049164096860, -0.308974603064746280, -0.309022156192959640, -0.309069708548617210, -0.309117260131600460, -0.309164810941791050, -0.309212360979069120, +-0.309259910243316340, -0.309307458734413730, -0.309355006452242950, -0.309402553396684210, -0.309450099567619100, -0.309497644964928710, -0.309545189588494640, -0.309592733438197150, +-0.309640276513917900, -0.309687818815537920, -0.309735360342938800, -0.309782901096000870, -0.309830441074605670, -0.309877980278634390, -0.309925518707968580, -0.309973056362488510, +-0.310020593242075870, -0.310068129346612100, -0.310115664675977620, -0.310163199230053980, -0.310210733008722370, -0.310258266011864290, -0.310305798239360160, -0.310353329691091530, +-0.310400860366939590, -0.310448390266785890, -0.310495919390510800, -0.310543447737995910, -0.310590975309122440, -0.310638502103771920, -0.310686028121824720, -0.310733553363162440, +-0.310781077827666290, -0.310828601515217850, -0.310876124425697510, -0.310923646558986850, -0.310971167914967540, -0.311018688493519820, -0.311066208294525410, -0.311113727317865460, +-0.311161245563421670, -0.311208763031074250, -0.311256279720705020, -0.311303795632195010, -0.311351310765425990, -0.311398825120278280, -0.311446338696633460, -0.311493851494372810, +-0.311541363513377970, -0.311588874753529250, -0.311636385214708380, -0.311683894896796540, -0.311731403799675400, -0.311778911923225320, -0.311826419267327960, -0.311873925831864960, +-0.311921431616716760, -0.311968936621764950, -0.312016440846890840, -0.312063944291975980, -0.312111446956900910, -0.312158948841547160, -0.312206449945796050, -0.312253950269529290, +-0.312301449812627200, -0.312348948574971470, -0.312396446556443390, -0.312443943756924580, -0.312491440176295490, -0.312538935814437870, -0.312586430671232820, -0.312633924746562150, +-0.312681418040306300, -0.312728910552346860, -0.312776402282565150, -0.312823893230842810, -0.312871383397060390, -0.312918872781099480, -0.312966361382841780, -0.313013849202167790, +-0.313061336238959150, -0.313108822493097240, -0.313156307964463640, -0.313203792652938850, -0.313251276558404570, -0.313298759680742110, -0.313346242019833190, -0.313393723575558230, +-0.313441204347798930, -0.313488684336436670, -0.313536163541353050, -0.313583641962428660, -0.313631119599545150, -0.313678596452583890, -0.313726072521426480, -0.313773547805953510, +-0.313821022306046690, -0.313868496021587670, -0.313915968952457050, -0.313963441098536470, -0.314010912459707300, -0.314058383035851260, -0.314105852826848890, -0.314153321832581820, +-0.314200790052931500, -0.314248257487779630, -0.314295724137006630, -0.314343190000494380, -0.314390655078124140, -0.314438119369777670, -0.314485582875335510, -0.314533045594679370, +-0.314580507527690620, -0.314627968674251020, -0.314675429034241060, -0.314722888607542550, -0.314770347394037200, -0.314817805393605600, -0.314865262606129510, -0.314912719031490210, +-0.314960174669569600, -0.315007629520248080, -0.315055083583407500, -0.315102536858929190, -0.315149989346694970, -0.315197441046585370, -0.315244891958482150, -0.315292342082266750, +-0.315339791417820870, -0.315387239965025100, -0.315434687723761210, -0.315482134693910620, -0.315529580875355150, -0.315577026267975240, -0.315624470871652800, -0.315671914686269210, +-0.315719357711706230, -0.315766799947844400, -0.315814241394565600, -0.315861682051751640, -0.315909121919283000, -0.315956560997041610, -0.316003999284908800, -0.316051436782766370, +-0.316098873490494980, -0.316146309407976390, -0.316193744535092030, -0.316241178871723700, -0.316288612417752020, -0.316336045173058860, -0.316383477137525520, -0.316430908311033930, +-0.316478338693464640, -0.316525768284699530, -0.316573197084620010, -0.316620625093107900, -0.316668052310043750, -0.316715478735309530, -0.316762904368787010, -0.316810329210356840, +-0.316857753259900840, -0.316905176517300440, -0.316952598982437550, -0.317000020655192670, -0.317047441535447780, -0.317094861623084310, -0.317142280917984080, -0.317189699420027730, +-0.317237117129097130, -0.317284534045073780, -0.317331950167839490, -0.317379365497274860, -0.317426780033261860, -0.317474193775681920, -0.317521606724416870, -0.317569018879347410, +-0.317616430240355410, -0.317663840807322740, -0.317711250580130060, -0.317758659558659280, -0.317806067742791800, -0.317853475132409580, -0.317900881727393280, -0.317948287527624770, +-0.317995692532985540, -0.318043096743357460, -0.318090500158621280, -0.318137902778658780, -0.318185304603351590, -0.318232705632581550, -0.318280105866229290, -0.318327505304176750, +-0.318374903946305520, -0.318422301792497360, -0.318469698842633100, -0.318517095096594590, -0.318564490554263720, -0.318611885215521250, -0.318659279080249050, -0.318706672148328600, +-0.318754064419641940, -0.318801455894069720, -0.318848846571493820, -0.318896236451795820, -0.318943625534857610, -0.318991013820560000, -0.319038401308784800, -0.319085787999413560, +-0.319133173892328310, -0.319180558987409770, -0.319227943284539740, -0.319275326783599880, -0.319322709484472110, -0.319370091387037200, -0.319417472491177020, -0.319464852796773170, +-0.319512232303707620, -0.319559611011861030, -0.319606988921115440, -0.319654366031352780, -0.319701742342453800, -0.319749117854300490, -0.319796492566774340, -0.319843866479757380, +-0.319891239593130370, -0.319938611906775250, -0.319985983420573550, -0.320033354134407370, -0.320080724048157410, -0.320128093161705600, -0.320175461474933530, -0.320222828987723250, +-0.320270195699955460, -0.320317561611512200, -0.320364926722275070, -0.320412291032125980, -0.320459654540945770, -0.320507017248616470, -0.320554379155020000, -0.320601740260037130, +-0.320649100563549950, -0.320696460065440000, -0.320743818765589380, -0.320791176663878740, -0.320838533760190170, -0.320885890054405270, -0.320933245546406010, -0.320980600236073280, +-0.321027954123289050, -0.321075307207934920, -0.321122659489892940, -0.321170010969043910, -0.321217361645269820, -0.321264711518452320, -0.321312060588473500, -0.321359408855214080, +-0.321406756318556140, -0.321454102978381730, -0.321501448834571660, -0.321548793887007970, -0.321596138135572310, -0.321643481580146660, -0.321690824220611960, -0.321738166056850130, +-0.321785507088742930, -0.321832847316172340, -0.321880186739019300, -0.321927525357165730, -0.321974863170493340, -0.322022200178884220, -0.322069536382219190, -0.322116871780380290, +-0.322164206373249270, -0.322211540160708130, -0.322258873142637680, -0.322306205318920070, -0.322353536689436950, -0.322400867254070410, -0.322448197012701330, -0.322495525965211690, +-0.322542854111483700, -0.322590181451398120, -0.322637507984837090, -0.322684833711682330, -0.322732158631815870, -0.322779482745118580, -0.322826806051472630, -0.322874128550759590, +-0.322921450242861730, -0.322968771127659760, -0.323016091205035880, -0.323063410474871800, -0.323110728937049620, -0.323158046591450140, -0.323205363437955580, -0.323252679476447650, +-0.323299994706808370, -0.323347309128918740, -0.323394622742660790, -0.323441935547916730, -0.323489247544567430, -0.323536558732494980, -0.323583869111581160, -0.323631178681708040, +-0.323678487442756620, -0.323725795394608940, -0.323773102537146750, -0.323820408870252260, -0.323867714393806350, -0.323915019107691100, -0.323962323011788340, -0.324009626105980160, +-0.324056928390147550, -0.324104229864172530, -0.324151530527936990, -0.324198830381323080, -0.324246129424211600, -0.324293427656484830, -0.324340725078024920, -0.324388021688712780, +-0.324435317488430570, -0.324482612477060120, -0.324529906654483500, -0.324577200020581710, -0.324624492575236900, -0.324671784318330880, -0.324719075249745800, -0.324766365369362650, +-0.324813654677063520, -0.324860943172730340, -0.324908230856245150, -0.324955517727488990, -0.325002803786344050, -0.325050089032692110, -0.325097373466415320, -0.325144657087394710, +-0.325191939895512430, -0.325239221890650740, -0.325286503072690580, -0.325333783441514200, -0.325381062997003310, -0.325428341739040170, -0.325475619667505770, -0.325522896782282360, +-0.325570173083251650, -0.325617448570295950, -0.325664723243296260, -0.325711997102134660, -0.325759270146693150, -0.325806542376853860, -0.325853813792497780, -0.325901084393507180, +-0.325948354179763870, -0.325995623151150100, -0.326042891307546820, -0.326090158648836340, -0.326137425174900460, -0.326184690885621460, -0.326231955780880270, -0.326279219860559240, +-0.326326483124540550, -0.326373745572705210, -0.326421007204935550, -0.326468268021113340, -0.326515528021120880, -0.326562787204839220, -0.326610045572150560, -0.326657303122936780, +-0.326704559857080190, -0.326751815774461770, -0.326799070874963790, -0.326846325158468120, -0.326893578624857130, -0.326940831274011690, -0.326988083105814230, -0.327035334120146510, +-0.327082584316890910, -0.327129833695928460, -0.327177082257141370, -0.327224330000412010, -0.327271576925621420, -0.327318823032651920, -0.327366068321385320, -0.327413312791703940, +-0.327460556443488930, -0.327507799276622490, -0.327555041290986500, -0.327602282486463390, -0.327649522862934140, -0.327696762420281120, -0.327744001158386140, -0.327791239077131590, +-0.327838476176398550, -0.327885712456069290, -0.327932947916025730, -0.327980182556150250, -0.328027416376323930, -0.328074649376429000, -0.328121881556347920, -0.328169112915961680, +-0.328216343455152660, -0.328263573173802840, -0.328310802071794420, -0.328358030149008610, -0.328405257405327780, -0.328452483840633750, -0.328499709454808940, -0.328546934247734400, +-0.328594158219292550, -0.328641381369365330, -0.328688603697835090, -0.328735825204582890, -0.328783045889491090, -0.328830265752441730, -0.328877484793317130, -0.328924703011998330, +-0.328971920408367870, -0.329019136982307560, -0.329066352733699830, -0.329113567662425780, -0.329160781768367830, -0.329207995051408350, -0.329255207511428450, -0.329302419148310540, +-0.329349629961936560, -0.329396839952188940, -0.329444049118948810, -0.329491257462098560, -0.329538464981520170, -0.329585671677096010, -0.329632877548707240, -0.329680082596236320, +-0.329727286819565200, -0.329774490218576240, -0.329821692793150660, -0.329868894543170870, -0.329916095468518800, -0.329963295569076940, -0.330010494844726390, -0.330057693295349620, +-0.330104890920829060, -0.330152087721045820, -0.330199283695882360, -0.330246478845220740, -0.330293673168943260, -0.330340866666931240, -0.330388059339067060, -0.330435251185232700, +-0.330482442205310640, -0.330529632399182040, -0.330576821766729370, -0.330624010307834670, -0.330671198022380320, -0.330718384910247630, -0.330765570971318920, -0.330812756205476290, +-0.330859940612602150, -0.330907124192577780, -0.330954306945285600, -0.331001488870608100, -0.331048669968426410, -0.331095850238623090, -0.331143029681080110, -0.331190208295679970, +-0.331237386082303910, -0.331284563040834420, -0.331331739171153440, -0.331378914473143600, -0.331426088946686010, -0.331473262591663210, -0.331520435407957280, -0.331567607395450660, +-0.331614778554024600, -0.331661948883561600, -0.331709118383943740, -0.331756287055053500, -0.331803454896772100, -0.331850621908982070, -0.331897788091565890, -0.331944953444404890, +-0.331992117967381430, -0.332039281660377720, -0.332086444523276180, -0.332133606555958140, -0.332180767758306070, -0.332227928130202130, -0.332275087671528750, -0.332322246382167230, +-0.332369404262000070, -0.332416561310909460, -0.332463717528777850, -0.332510872915486480, -0.332558027470917950, -0.332605181194954360, -0.332652334087478240, -0.332699486148370860, +-0.332746637377514750, -0.332793787774792070, -0.332840937340085350, -0.332888086073275860, -0.332935233974246130, -0.332982381042878750, -0.333029527279054990, -0.333076672682657450, +-0.333123817253568210, -0.333170960991669820, -0.333218103896843640, -0.333265245968972170, -0.333312387207937600, -0.333359527613622470, -0.333406667185908110, -0.333453805924677100, +-0.333500943829811550, -0.333548080901194090, -0.333595217138705990, -0.333642352542229850, -0.333689487111647810, -0.333736620846842470, -0.333783753747695200, -0.333830885814088480, +-0.333878017045905030, -0.333925147443026090, -0.333972277005334270, -0.334019405732711830, -0.334066533625041180, -0.334113660682203880, -0.334160786904082350, -0.334207912290558910, +-0.334255036841516080, -0.334302160556835260, -0.334349283436399030, -0.334396405480089590, -0.334443526687789540, -0.334490647059380250, -0.334537766594744380, -0.334584885293764070, +-0.334632003156321970, -0.334679120182299390, -0.334726236371579110, -0.334773351724043600, -0.334820466239574290, -0.334867579918053830, -0.334914692759364420, -0.334961804763388660, +-0.335008915930008030, -0.335056026259105080, -0.335103135750562050, -0.335150244404261610, -0.335197352220085180, -0.335244459197915350, -0.335291565337634320, -0.335338670639124870, +-0.335385775102268250, -0.335432878726947270, -0.335479981513044030, -0.335527083460441300, -0.335574184569020380, -0.335621284838664050, -0.335668384269254490, -0.335715482860674430, +-0.335762580612805230, -0.335809677525529540, -0.335856773598730120, -0.335903868832288290, -0.335950963226086810, -0.335998056780007940, -0.336045149493934380, -0.336092241367747460, +-0.336139332401329980, -0.336186422594564160, -0.336233511947332700, -0.336280600459517020, -0.336327688130999840, -0.336374774961663460, -0.336421860951390590, -0.336468946100062620, +-0.336516030407562280, -0.336563113873771860, -0.336610196498574040, -0.336657278281850380, -0.336704359223483520, -0.336751439323356110, -0.336798518581349740, -0.336845596997347060, +-0.336892674571230400, -0.336939751302882450, -0.336986827192184760, -0.337033902239019910, -0.337080976443270400, -0.337128049804818810, -0.337175122323546680, -0.337222193999336730, +-0.337269264832071310, -0.337316334821633200, -0.337363403967903760, -0.337410472270765820, -0.337457539730101730, -0.337504606345794210, -0.337551672117724740, -0.337598737045776090, +-0.337645801129831000, -0.337692864369771030, -0.337739926765478870, -0.337786988316836900, -0.337834049023727880, -0.337881108886033340, -0.337928167903636000, -0.337975226076418220, +-0.338022283404262820, -0.338069339887051350, -0.338116395524666440, -0.338163450316990580, -0.338210504263906530, -0.338257557365295780, -0.338304609621041090, -0.338351661031024930, +-0.338398711595130020, -0.338445761313237950, -0.338492810185231420, -0.338539858210993310, -0.338586905390405150, -0.338633951723349700, -0.338680997209709400, -0.338728041849367000, +-0.338775085642204100, -0.338822128588103460, -0.338869170686947550, -0.338916211938619090, -0.338963252342999680, -0.339010291899972120, -0.339057330609418840, -0.339104368471222720, +-0.339151405485265180, -0.339198441651429150, -0.339245476969597000, -0.339292511439651610, -0.339339545061474510, -0.339386577834948580, -0.339433609759956180, -0.339480640836380130, +-0.339527671064102090, -0.339574700443004920, -0.339621728972971330, -0.339668756653883070, -0.339715783485622870, -0.339762809468073250, -0.339809834601117020, -0.339856858884635790, +-0.339903882318512370, -0.339950904902629300, -0.339997926636869340, -0.340044947521114190, -0.340091967555246620, -0.340138986739149160, -0.340186005072704630, -0.340233022555794740, +-0.340280039188302240, -0.340327054970109620, -0.340374069901099810, -0.340421083981154390, -0.340468097210156310, -0.340515109587988360, -0.340562121114532210, -0.340609131789670780, +-0.340656141613286500, -0.340703150585262290, -0.340750158705479810, -0.340797165973821930, -0.340844172390171120, -0.340891177954410320, -0.340938182666421120, -0.340985186526086450, +-0.341032189533288840, -0.341079191687911230, -0.341126192989835150, -0.341173193438943590, -0.341220193035119080, -0.341267191778244490, -0.341314189668201540, -0.341361186704873030, +-0.341408182888142060, -0.341455178217890180, -0.341502172694000350, -0.341549166316355070, -0.341596159084837310, -0.341643150999328740, -0.341690142059712320, -0.341737132265870490, +-0.341784121617686290, -0.341831110115041360, -0.341878097757818630, -0.341925084545900650, -0.341972070479170390, -0.342019055557509550, -0.342066039780801080, -0.342113023148927500, +-0.342160005661771790, -0.342206987319215620, -0.342253968121142000, -0.342300948067433440, -0.342347927157972960, -0.342394905392642220, -0.342441882771324200, -0.342488859293901940, +-0.342535834960257080, -0.342582809770272670, -0.342629783723831180, -0.342676756820815720, -0.342723729061107870, -0.342770700444590740, -0.342817670971146850, -0.342864640640659190, +-0.342911609453009580, -0.342958577408080890, -0.343005544505755710, -0.343052510745917140, -0.343099476128446880, -0.343146440653227910, -0.343193404320142890, -0.343240367129074740, +-0.343287329079905220, -0.343334290172517430, -0.343381250406794290, -0.343428209782617620, -0.343475168299870460, -0.343522125958435340, -0.343569082758195370, -0.343616038699032230, +-0.343662993780828980, -0.343709948003468270, -0.343756901366833120, -0.343803853870805310, -0.343850805515267810, -0.343897756300103330, -0.343944706225194910, -0.343991655290424250, +-0.344038603495674500, -0.344085550840828200, -0.344132497325768450, -0.344179442950377060, -0.344226387714537060, -0.344273331618131450, -0.344320274661042150, -0.344367216843152190, +-0.344414158164344120, -0.344461098624501140, -0.344508038223504950, -0.344554976961238660, -0.344601914837584960, -0.344648851852426890, -0.344695788005646210, -0.344742723297126130, +-0.344789657726749240, -0.344836591294398590, -0.344883523999956030, -0.344930455843304730, -0.344977386824327210, -0.345024316942906690, -0.345071246198924930, -0.345118174592265130, +-0.345165102122810210, -0.345212028790442160, -0.345258954595044080, -0.345305879536498550, -0.345352803614688790, -0.345399726829496550, -0.345446649180805030, -0.345493570668496900, +-0.345540491292455230, -0.345587411052561910, -0.345634329948700080, -0.345681247980752390, -0.345728165148602050, -0.345775081452130870, -0.345821996891221950, -0.345868911465758100, +-0.345915825175622300, -0.345962738020696600, -0.346009650000864030, -0.346056561116007360, -0.346103471366009660, -0.346150380750752880, -0.346197289270120110, -0.346244196923994610, +-0.346291103712258130, -0.346338009634793940, -0.346384914691484750, -0.346431818882213640, -0.346478722206862540, -0.346525624665314670, -0.346572526257452770, -0.346619426983159950, +-0.346666326842318130, -0.346713225834810510, -0.346760123960519810, -0.346807021219329210, -0.346853917611120670, -0.346900813135777310, -0.346947707793181900, -0.346994601583217710, +-0.347041494505766550, -0.347088386560711670, -0.347135277747936180, -0.347182168067322160, -0.347229057518752660, -0.347275946102110540, -0.347322833817279020, -0.347369720664139960, +-0.347416606642576560, -0.347463491752471710, -0.347510375993708490, -0.347557259366168940, -0.347604141869736260, -0.347651023504293170, -0.347697904269722970, -0.347744784165907590, +-0.347791663192730300, -0.347838541350073800, -0.347885418637821350, -0.347932295055854990, -0.347979170604057860, -0.348026045282313180, -0.348072919090503030, -0.348119792028510570, +-0.348166664096218600, -0.348213535293510460, -0.348260405620268000, -0.348307275076374550, -0.348354143661712910, -0.348401011376166300, -0.348447878219616760, -0.348494744191947540, +-0.348541609293041450, -0.348588473522781770, -0.348635336881050470, -0.348682199367730820, -0.348729060982705670, -0.348775921725858310, -0.348822781597070750, -0.348869640596226220, +-0.348916498723207570, -0.348963355977898070, -0.349010212360179760, -0.349057067869935960, -0.349103922507049910, -0.349150776271403620, -0.349197629162880390, -0.349244481181363090, +-0.349291332326734980, -0.349338182598878170, -0.349385031997675840, -0.349431880523011000, -0.349478728174766830, -0.349525574952825440, -0.349572420857070130, -0.349619265887383730, +-0.349666110043649610, -0.349712953325749810, -0.349759795733567580, -0.349806637266985910, -0.349853477925888000, -0.349900317710156060, -0.349947156619673240, -0.349993994654323020, +-0.350040831813987370, -0.350087668098549630, -0.350134503507892710, -0.350181338041899990, -0.350228171700453450, -0.350275004483436510, -0.350321836390732110, -0.350368667422223450, +-0.350415497577792780, -0.350462326857323310, -0.350509155260698040, -0.350555982787800310, -0.350602809438512190, -0.350649635212717080, -0.350696460110297810, -0.350743284131137870, +-0.350790107275119280, -0.350836929542125420, -0.350883750932039720, -0.350930571444744150, -0.350977391080122160, -0.351024209838056710, -0.351071027718431130, -0.351117844721127560, +-0.351164660846029430, -0.351211476093019610, -0.351258290461981540, -0.351305103952797290, -0.351351916565350310, -0.351398728299523510, -0.351445539155200330, -0.351492349132262900, +-0.351539158230594560, -0.351585966450078340, -0.351632773790597650, -0.351679580252034550, -0.351726385834272510, -0.351773190537194970, -0.351819994360684010, -0.351866797304623060, +-0.351913599368895100, -0.351960400553383620, -0.352007200857970660, -0.352054000282539750, -0.352100798826973820, -0.352147596491156290, -0.352194393274969320, -0.352241189178296440, +-0.352287984201020530, -0.352334778343025120, -0.352381571604192310, -0.352428363984405630, -0.352475155483548020, -0.352521946101502890, -0.352568735838152510, -0.352615524693380310, +-0.352662312667069270, -0.352709099759102860, -0.352755885969363300, -0.352802671297734020, -0.352849455744098480, -0.352896239308338850, -0.352943021990338670, -0.352989803789980960, +-0.353036584707149100, -0.353083364741725360, -0.353130143893593260, -0.353176922162635740, -0.353223699548736390, -0.353270476051777360, -0.353317251671642070, -0.353364026408213740, +-0.353410800261375720, -0.353457573231010290, -0.353504345317000920, -0.353551116519230710, -0.353597886837583090, -0.353644656271940360, -0.353691424822186020, -0.353738192488203480, +-0.353784959269875080, -0.353831725167084280, -0.353878490179714120, -0.353925254307648210, -0.353972017550768680, -0.354018779908959190, -0.354065541382102670, -0.354112301970082750, +-0.354159061672781660, -0.354205820490082920, -0.354252578421869630, -0.354299335468025330, -0.354346091628432220, -0.354392846902973900, -0.354439601291533510, -0.354486354793994480, +-0.354533107410239190, -0.354579859140151110, -0.354626609983613780, -0.354673359940509520, -0.354720109010721870, -0.354766857194133920, -0.354813604490629260, -0.354860350900090220, +-0.354907096422400260, -0.354953841057442540, -0.355000584805100660, -0.355047327665256870, -0.355094069637794830, -0.355140810722597570, -0.355187550919548680, -0.355234290228530540, +-0.355281028649426620, -0.355327766182120200, -0.355374502826494740, -0.355421238582432570, -0.355467973449817400, -0.355514707428532200, -0.355561440518460730, -0.355608172719485190, +-0.355654904031489190, -0.355701634454356430, -0.355748363987969110, -0.355795092632210870, -0.355841820386964940, -0.355888547252114880, -0.355935273227542980, -0.355981998313132930, +-0.356028722508767880, -0.356075445814331480, -0.356122168229705990, -0.356168889754775120, -0.356215610389422010, -0.356262330133530310, -0.356309048986982350, -0.356355766949661760, +-0.356402484021451750, -0.356449200202235970, -0.356495915491896740, -0.356542629890317760, -0.356589343397382570, -0.356636056012973660, -0.356682767736974600, -0.356729478569268620, +-0.356776188509739360, -0.356822897558269180, -0.356869605714741740, -0.356916312979040360, -0.356963019351048570, -0.357009724830648860, -0.357056429417724750, -0.357103133112159630, +-0.357149835913837090, -0.357196537822639550, -0.357243238838450660, -0.357289938961153630, -0.357336638190632220, -0.357383336526768790, -0.357430033969447000, -0.357476730518550560, +-0.357523426173961880, -0.357570120935564620, -0.357616814803242030, -0.357663507776877890, -0.357710199856354490, -0.357756891041555670, -0.357803581332364560, -0.357850270728664930, +-0.357896959230339210, -0.357943646837271090, -0.357990333549343840, -0.358037019366441220, -0.358083704288445600, -0.358130388315240740, -0.358177071446709900, -0.358223753682736790, +-0.358270435023203880, -0.358317115467994880, -0.358363795016993500, -0.358410473670082220, -0.358457151427144740, -0.358503828288064430, -0.358550504252724940, -0.358597179321008760, +-0.358643853492799650, -0.358690526767980910, -0.358737199146436260, -0.358783870628048170, -0.358830541212700470, -0.358877210900276360, -0.358923879690659640, -0.358970547583732870, +-0.359017214579379680, -0.359063880677483460, -0.359110545877927960, -0.359157210180595650, -0.359203873585370310, -0.359250536092135310, -0.359297197700774400, -0.359343858411170060, +-0.359390518223206110, -0.359437177136766260, -0.359483835151733040, -0.359530492267990220, -0.359577148485421220, -0.359623803803909680, -0.359670458223338320, -0.359717111743590720, +-0.359763764364550380, -0.359810416086101040, -0.359857066908125240, -0.359903716830506810, -0.359950365853129060, -0.359997013975875800, -0.360043661198629630, -0.360090307521274240, +-0.360136952943693130, -0.360183597465770060, -0.360230241087387550, -0.360276883808429480, -0.360323525628779560, -0.360370166548320490, -0.360416806566935920, -0.360463445684509390, +-0.360510083900924650, -0.360556721216064250, -0.360603357629812050, -0.360649993142051480, -0.360696627752666370, -0.360743261461539230, -0.360789894268553960, -0.360836526173593960, +-0.360883157176543010, -0.360929787277283810, -0.360976416475700110, -0.361023044771675410, -0.361069672165093450, -0.361116298655836940, -0.361162924243789650, -0.361209548928835500, +-0.361256172710857030, -0.361302795589738160, -0.361349417565362320, -0.361396038637613270, -0.361442658806373770, -0.361489278071527640, -0.361535896432958250, -0.361582513890549570, +-0.361629130444184210, -0.361675746093746030, -0.361722360839118460, -0.361768974680185370, -0.361815587616829470, -0.361862199648934570, -0.361908810776384200, -0.361955420999062250, +-0.362002030316851300, -0.362048638729635220, -0.362095246237297610, -0.362141852839722280, -0.362188458536791940, -0.362235063328390390, -0.362281667214401640, -0.362328270194708260, +-0.362374872269194240, -0.362421473437743060, -0.362468073700238590, -0.362514673056563490, -0.362561271506601780, -0.362607869050236840, -0.362654465687352660, -0.362701061417831870, +-0.362747656241558470, -0.362794250158415880, -0.362840843168288130, -0.362887435271057820, -0.362934026466608940, -0.362980616754824960, -0.363027206135589920, -0.363073794608786420, +-0.363120382174298430, -0.363166968832009880, -0.363213554581803490, -0.363260139423563280, -0.363306723357172680, -0.363353306382515670, -0.363399888499474970, -0.363446469707934590, +-0.363493050007777980, -0.363539629398889230, -0.363586207881150920, -0.363632785454447160, -0.363679362118661420, -0.363725937873677680, -0.363772512719378660, -0.363819086655648380, +-0.363865659682370390, -0.363912231799428660, -0.363958803006705910, -0.364005373304086170, -0.364051942691453410, -0.364098511168690410, -0.364145078735681080, -0.364191645392309080, +-0.364238211138458390, -0.364284775974011770, -0.364331339898853130, -0.364377902912866200, -0.364424465015934950, -0.364471026207942080, -0.364517586488771690, -0.364564145858307320, +-0.364610704316433000, -0.364657261863031490, -0.364703818497986830, -0.364750374221182620, -0.364796929032502880, -0.364843482931830390, -0.364890035919049230, -0.364936587994042990, +-0.364983139156695670, -0.365029689406890070, -0.365076238744510280, -0.365122787169440300, -0.365169334681562930, -0.365215881280762210, -0.365262426966921790, -0.365308971739925770, +-0.365355515599656840, -0.365402058545999160, -0.365448600578836320, -0.365495141698052360, -0.365541681903530200, -0.365588221195153770, -0.365634759572806830, -0.365681297036373420, +-0.365727833585736290, -0.365774369220779660, -0.365820903941387050, -0.365867437747442570, -0.365913970638829130, -0.365960502615430780, -0.366007033677131550, -0.366053563823814320, +-0.366100093055363170, -0.366146621371661820, -0.366193148772594350, -0.366239675258043570, -0.366286200827893590, -0.366332725482028110, -0.366379249220331220, -0.366425772042685840, +-0.366472293948975960, -0.366518814939085390, -0.366565335012898170, -0.366611854170297240, -0.366658372411166670, -0.366704889735390120, -0.366751406142851790, -0.366797921633434550, +-0.366844436207022510, -0.366890949863499740, -0.366937462602749230, -0.366983974424655020, -0.367030485329100930, -0.367076995315971040, -0.367123504385148180, -0.367170012536516600, +-0.367216519769960000, -0.367263026085362490, -0.367309531482607030, -0.367356035961577730, -0.367402539522158340, -0.367449042164233020, -0.367495543887684680, -0.367542044692397480, +-0.367588544578255130, -0.367635043545141870, -0.367681541592940590, -0.367728038721535420, -0.367774534930810640, -0.367821030220649050, -0.367867524590934910, -0.367914018041551940, +-0.367960510572384330, -0.368007002183315060, -0.368053492874228280, -0.368099982645007760, -0.368146471495537700, -0.368192959425701020, -0.368239446435381980, -0.368285932524464290, +-0.368332417692832200, -0.368378901940368650, -0.368425385266957890, -0.368471867672483630, -0.368518349156830070, -0.368564829719880300, -0.368611309361518420, -0.368657788081628250, +-0.368704265880094030, -0.368750742756798760, -0.368797218711626630, -0.368843693744461850, -0.368890167855187410, -0.368936641043687560, -0.368983113309846120, -0.369029584653547290, +-0.369076055074674110, -0.369122524573110790, -0.369168993148741190, -0.369215460801449460, -0.369261927531118690, -0.369308393337633100, -0.369354858220876490, -0.369401322180733180, +-0.369447785217086160, -0.369494247329819670, -0.369540708518817600, -0.369587168783964140, -0.369633628125142330, -0.369680086542236440, -0.369726544035130780, -0.369773000603708320, +-0.369819456247853400, -0.369865910967449810, -0.369912364762381870, -0.369958817632532580, -0.370005269577786230, -0.370051720598026770, -0.370098170693138380, -0.370144619863004180, +-0.370191068107508400, -0.370237515426534940, -0.370283961819968140, -0.370330407287691010, -0.370376851829587850, -0.370423295445542530, -0.370469738135439430, -0.370516179899161580, +-0.370562620736593300, -0.370609060647618840, -0.370655499632121300, -0.370701937689985050, -0.370748374821093910, -0.370794811025332290, -0.370841246302583190, -0.370887680652731030, +-0.370934114075659630, -0.370980546571253400, -0.371026978139395340, -0.371073408779969860, -0.371119838492860840, -0.371166267277952660, -0.371212695135128390, -0.371259122064272360, +-0.371305548065268550, -0.371351973138001280, -0.371398397282353630, -0.371444820498210040, -0.371491242785454370, -0.371537664143970990, -0.371584084573643060, -0.371630504074354940, +-0.371676922645990950, -0.371723340288434230, -0.371769757001569170, -0.371816172785279730, -0.371862587639450290, -0.371909001563963890, -0.371955414558705070, -0.372001826623557690, +-0.372048237758406120, -0.372094647963133570, -0.372141057237624420, -0.372187465581762580, -0.372233872995432540, -0.372280279478517380, -0.372326685030901490, -0.372373089652468960, +-0.372419493343104040, -0.372465896102690040, -0.372512297931111240, -0.372558698828252150, -0.372605098793995890, -0.372651497828226870, -0.372697895930829140, -0.372744293101687050, +-0.372790689340683820, -0.372837084647703880, -0.372883479022631250, -0.372929872465350310, -0.372976264975744260, -0.373022656553697540, -0.373069047199094230, -0.373115436911818640, +-0.373161825691754100, -0.373208213538785030, -0.373254600452795350, -0.373300986433669600, -0.373347371481290990, -0.373393755595543940, -0.373440138776312940, -0.373486521023481180, +-0.373532902336933090, -0.373579282716552770, -0.373625662162224650, -0.373672040673831920, -0.373718418251259120, -0.373764794894390300, -0.373811170603109870, -0.373857545377301090, +-0.373903919216848510, -0.373950292121636050, -0.373996664091548300, -0.374043035126468530, -0.374089405226281150, -0.374135774390870200, -0.374182142620120280, -0.374228509913914600, +-0.374274876272137620, -0.374321241694673850, -0.374367606181406580, -0.374413969732220300, -0.374460332346999100, -0.374506694025627470, -0.374553054767988670, -0.374599414573967280, +-0.374645773443447290, -0.374692131376313350, -0.374738488372448610, -0.374784844431737710, -0.374831199554064630, -0.374877553739314030, -0.374923906987369100, -0.374970259298114390, +-0.375016610671434050, -0.375062961107212600, -0.375109310605333370, -0.375155659165680780, -0.375202006788139090, -0.375248353472592830, -0.375294699218925220, -0.375341044027020900, +-0.375387387896764350, -0.375433730828038940, -0.375480072820729150, -0.375526413874719240, -0.375572753989893700, -0.375619093166135840, -0.375665431403330250, -0.375711768701361080, +-0.375758105060112920, -0.375804440479469090, -0.375850774959314130, -0.375897108499532230, -0.375943441100007990, -0.375989772760624790, -0.376036103481267090, -0.376082433261819120, +-0.376128762102165500, -0.376175090002189570, -0.376221416961775910, -0.376267742980809120, -0.376314068059172560, -0.376360392196750830, -0.376406715393428130, -0.376453037649089050, +-0.376499358963616970, -0.376545679336896480, -0.376591998768811780, -0.376638317259247510, -0.376684634808087060, -0.376730951415214950, -0.376777267080515510, -0.376823581803873320, +-0.376869895585171750, -0.376916208424295460, -0.376962520321128650, -0.377008831275555960, -0.377055141287460760, -0.377101450356727710, -0.377147758483241390, -0.377194065666885350, +-0.377240371907544110, -0.377286677205101950, -0.377332981559443500, -0.377379284970452140, -0.377425587438012630, -0.377471888962009120, -0.377518189542326350, -0.377564489178847660, +-0.377610787871457740, -0.377657085620040860, -0.377703382424481650, -0.377749678284663600, -0.377795973200471370, -0.377842267171789150, -0.377888560198501760, -0.377934852280492510, +-0.377981143417646100, -0.378027433609846860, -0.378073722856979430, -0.378120011158927290, -0.378166298515575150, -0.378212584926807650, -0.378258870392508330, -0.378305154912561780, +-0.378351438486852320, -0.378397721115264710, -0.378444002797682370, -0.378490283533990060, -0.378536563324072040, -0.378582842167812960, -0.378629120065096410, -0.378675397015807050, +-0.378721673019829230, -0.378767948077047610, -0.378814222187345670, -0.378860495350608230, -0.378906767566719540, -0.378953038835564360, -0.378999309157026120, -0.379045578530989640, +-0.379091846957339660, -0.379138114435959570, -0.379184380966734240, -0.379230646549547970, -0.379276911184285470, -0.379323174870830280, -0.379369437609067160, -0.379415699398880480, +-0.379461960240154940, -0.379508220132774080, -0.379554479076622650, -0.379600737071585040, -0.379646994117546040, -0.379693250214389100, -0.379739505361999020, -0.379785759560260230, +-0.379832012809057430, -0.379878265108274160, -0.379924516457795240, -0.379970766857505470, -0.380017016307288350, -0.380063264807028680, -0.380109512356610830, -0.380155758955919630, +-0.380202004604838660, -0.380248249303252630, -0.380294493051046010, -0.380340735848103520, -0.380386977694308850, -0.380433218589546650, -0.380479458533701460, -0.380525697526658050, +-0.380571935568299930, -0.380618172658512000, -0.380664408797178670, -0.380710643984184690, -0.380756878219413730, -0.380803111502750540, -0.380849343834079980, -0.380895575213285650, +-0.380941805640252370, -0.380988035114864620, -0.381034263637007150, -0.381080491206563620, -0.381126717823418890, -0.381172943487457340, -0.381219168198563830, -0.381265391956622010, +-0.381311614761516700, -0.381357836613132380, -0.381404057511353870, -0.381450277456064800, -0.381496496447150000, -0.381542714484494010, -0.381588931567981630, -0.381635147697496510, +-0.381681362872923540, -0.381727577094147120, -0.381773790361052190, -0.381820002673522340, -0.381866214031442550, -0.381912424434697580, -0.381958633883171190, -0.382004842376748140, +-0.382051049915313080, -0.382097256498750760, -0.382143462126944830, -0.382189666799780340, -0.382235870517141640, -0.382282073278913670, -0.382328275084980130, -0.382374475935225890, +-0.382420675829535430, -0.382466874767793730, -0.382513072749884390, -0.382559269775692430, -0.382605465845102240, -0.382651660957998850, -0.382697855114265850, -0.382744048313788220, +-0.382790240556450890, -0.382836431842137560, -0.382882622170733160, -0.382928811542122160, -0.382974999956189550, -0.383021187412819040, -0.383067373911895600, -0.383113559453303660, +-0.383159744036928260, -0.383205927662653100, -0.383252110330363160, -0.383298292039942870, -0.383344472791277310, -0.383390652584250150, -0.383436831418746290, -0.383483009294650460, +-0.383529186211847450, -0.383575362170221090, -0.383621537169656300, -0.383667711210038060, -0.383713884291250200, -0.383760056413177560, -0.383806227575704820, -0.383852397778716940, +-0.383898567022097630, -0.383944735305731920, -0.383990902629504300, -0.384037068993299920, -0.384083234397002430, -0.384129398840496850, -0.384175562323667790, -0.384221724846400210, +-0.384267886408577900, -0.384314047010085870, -0.384360206650808780, -0.384406365330631550, -0.384452523049437940, -0.384498679807113110, -0.384544835603541520, -0.384590990438608280, +-0.384637144312197140, -0.384683297224193200, -0.384729449174481370, -0.384775600162945490, -0.384821750189470620, -0.384867899253941440, -0.384914047356242850, -0.384960194496258730, +-0.385006340673874180, -0.385052485888973730, -0.385098630141442520, -0.385144773431164270, -0.385190915758024110, -0.385237057121906650, -0.385283197522697020, -0.385329336960278930, +-0.385375475434537480, -0.385421612945357370, -0.385467749492623630, -0.385513885076220140, -0.385560019696031870, -0.385606153351944040, -0.385652286043840330, -0.385698417771605960, +-0.385744548535125580, -0.385790678334284150, -0.385836807168965680, -0.385882935039055190, -0.385929061944437320, -0.385975187884997240, -0.386021312860618750, -0.386067436871187000, +-0.386113559916586690, -0.386159681996702860, -0.386205803111419390, -0.386251923260621470, -0.386298042444193690, -0.386344160662021210, -0.386390277913987950, -0.386436394199978990, +-0.386482509519879450, -0.386528623873573230, -0.386574737260945430, -0.386620849681880820, -0.386666961136264480, -0.386713071623980330, -0.386759181144913480, -0.386805289698948730, +-0.386851397285971120, -0.386897503905864640, -0.386943609558514370, -0.386989714243805070, -0.387035817961621900, -0.387081920711848770, -0.387128022494370890, -0.387174123309072920, +-0.387220223155840040, -0.387266322034556190, -0.387312419945106570, -0.387358516887376270, -0.387404612861249280, -0.387450707866610790, -0.387496801903345510, -0.387542894971338590, +-0.387588987070474070, -0.387635078200637080, -0.387681168361712400, -0.387727257553585170, -0.387773345776139420, -0.387819433029260310, -0.387865519312832640, -0.387911604626741510, +-0.387957688970871020, -0.388003772345106300, -0.388049854749332120, -0.388095936183433740, -0.388142016647295090, -0.388188096140801410, -0.388234174663837470, -0.388280252216288540, +-0.388326328798038580, -0.388372404408972750, -0.388418479048976310, -0.388464552717933290, -0.388510625415728890, -0.388556697142247940, -0.388602767897375630, -0.388648837680996010, +-0.388694906492994320, -0.388740974333255330, -0.388787041201664300, -0.388833107098105260, -0.388879172022463470, -0.388925235974623750, -0.388971298954471360, -0.389017360961890320, +-0.389063421996765860, -0.389109482058982830, -0.389155541148426540, -0.389201599264980940, -0.389247656408531370, -0.389293712578963060, -0.389339767776160080, -0.389385822000007650, +-0.389431875250390690, -0.389477927527194460, -0.389523978830302990, -0.389570029159601540, -0.389616078514975040, -0.389662126896308800, -0.389708174303486750, -0.389754220736394320, +-0.389800266194916370, -0.389846310678938100, -0.389892354188343670, -0.389938396723018330, -0.389984438282847010, -0.390030478867715020, -0.390076518477506410, -0.390122557112106530, +-0.390168594771400650, -0.390214631455272850, -0.390260667163608520, -0.390306701896292460, -0.390352735653210100, -0.390398768434245480, -0.390444800239283960, -0.390490831068210420, +-0.390536860920910170, -0.390582889797267410, -0.390628917697167450, -0.390674944620495120, -0.390720970567135890, -0.390766995536973800, -0.390813019529894280, -0.390859042545782130, +-0.390905064584522840, -0.390951085646000450, -0.390997105730100380, -0.391043124836707500, -0.391089142965707240, -0.391135160116983680, -0.391181176290422260, -0.391227191485908340, +-0.391273205703325970, -0.391319218942560610, -0.391365231203497200, -0.391411242486021100, -0.391457252790016530, -0.391503262115368790, -0.391549270461962920, -0.391595277829684290, +-0.391641284218417040, -0.391687289628046550, -0.391733294058457910, -0.391779297509536380, -0.391825299981166220, -0.391871301473232790, -0.391917301985621140, -0.391963301518216620, +-0.392009300070903450, -0.392055297643567060, -0.392101294236092750, -0.392147289848364890, -0.392193284480268740, -0.392239278131689410, -0.392285270802512300, -0.392331262492621570, +-0.392377253201902700, -0.392423242930240720, -0.392469231677521010, -0.392515219443627830, -0.392561206228446590, -0.392607192031862340, -0.392653176853760500, -0.392699160694025330, +-0.392745143552542250, -0.392791125429196360, -0.392837106323873030, -0.392883086236456510, -0.392929065166832290, -0.392975043114885790, -0.393021020080501330, -0.393066996063564270, +-0.393112971063959700, -0.393158945081573170, -0.393204918116288830, -0.393250890167992200, -0.393296861236568370, -0.393342831321902790, -0.393388800423879690, -0.393434768542384630, +-0.393480735677302630, -0.393526701828519180, -0.393572666995918590, -0.393618631179386340, -0.393664594378807520, -0.393710556594067620, -0.393756517825050890, -0.393802478071642870, +-0.393848437333729100, -0.393894395611193770, -0.393940352903922490, -0.393986309211800330, -0.394032264534712800, -0.394078218872544180, -0.394124172225180040, -0.394170124592505440, +-0.394216075974406000, -0.394262026370765910, -0.394307975781470750, -0.394353924206405690, -0.394399871645456200, -0.394445818098506600, -0.394491763565442520, -0.394537708046148960, +-0.394583651540511560, -0.394629594048414630, -0.394675535569743720, -0.394721476104384020, -0.394767415652220950, -0.394813354213138960, -0.394859291787023610, -0.394905228373760410, +-0.394951163973233770, -0.394997098585329160, -0.395043032209931870, -0.395088964846927400, -0.395134896496200040, -0.395180827157635530, -0.395226756831118910, -0.395272685516535770, +-0.395318613213770540, -0.395364539922708810, -0.395410465643235680, -0.395456390375236830, -0.395502314118596600, -0.395548236873200560, -0.395594158638933930, -0.395640079415682300, +-0.395685999203330090, -0.395731918001762880, -0.395777835810866290, -0.395823752630524660, -0.395869668460623660, -0.395915583301048530, -0.395961497151684830, -0.396007410012416960, +-0.396053321883130580, -0.396099232763710900, -0.396145142654043550, -0.396191051554012910, -0.396236959463504680, -0.396282866382404010, -0.396328772310596600, -0.396374677247966880, +-0.396420581194400430, -0.396466484149782530, -0.396512386113998860, -0.396558287086933750, -0.396604187068473000, -0.396650086058502160, -0.396695984056905650, -0.396741881063569220, +-0.396787777078378090, -0.396833672101217950, -0.396879566131973170, -0.396925459170529520, -0.396971351216772240, -0.397017242270586930, -0.397063132331858140, -0.397109021400471500, +-0.397154909476312320, -0.397200796559266270, -0.397246682649217810, -0.397292567746052700, -0.397338451849656100, -0.397384334959913820, -0.397430217076710280, -0.397476098199931180, +-0.397521978329461840, -0.397567857465188020, -0.397613735606994090, -0.397659612754765800, -0.397705488908388970, -0.397751364067747910, -0.397797238232728500, -0.397843111403215990, +-0.397888983579096130, -0.397934854760253360, -0.397980724946573490, -0.398026594137941780, -0.398072462334244040, -0.398118329535364690, -0.398164195741189500, -0.398210060951603830, +-0.398255925166493440, -0.398301788385742820, -0.398347650609237770, -0.398393511836863560, -0.398439372068505940, -0.398485231304049500, -0.398531089543380010, -0.398576946786383220, +-0.398622803032943620, -0.398668658282947010, -0.398714512536278760, -0.398760365792824640, -0.398806218052469190, -0.398852069315098200, -0.398897919580597060, -0.398943768848851520, +-0.398989617119746120, -0.399035464393166730, -0.399081310668998600, -0.399127155947127670, -0.399173000227438400, -0.399218843509816680, -0.399264685794147810, -0.399310527080317670, +-0.399356367368210790, -0.399402206657712980, -0.399448044948710060, -0.399493882241086620, -0.399539718534728470, -0.399585553829520990, -0.399631388125350100, -0.399677221422100330, +-0.399723053719657440, -0.399768885017906970, -0.399814715316734680, -0.399860544616025220, -0.399906372915664390, -0.399952200215537620, -0.399998026515530740, -0.400043851815528370, +-0.400089676115416400, -0.400135499415080250, -0.400181321714405790, -0.400227143013277550, -0.400272963311581460, -0.400318782609203390, -0.400364600906027990, -0.400410418201941070, +-0.400456234496828050, -0.400502049790574910, -0.400547864083066200, -0.400593677374187880, -0.400639489663825340, -0.400685300951864440, -0.400731111238189940, -0.400776920522687650, +-0.400822728805243060, -0.400868536085742020, -0.400914342364069250, -0.400960147640110620, -0.401005951913751660, -0.401051755184878180, -0.401097557453374940, -0.401143358719127820, +-0.401189158982022230, -0.401234958241944220, -0.401280756498778370, -0.401326553752410660, -0.401372350002726970, -0.401418145249611950, -0.401463939492951620, -0.401509732732631410, +-0.401555524968537300, -0.401601316200553950, -0.401647106428567320, -0.401692895652462910, -0.401738683872126690, -0.401784471087443360, -0.401830257298298800, -0.401876042504578650, +-0.401921826706168770, -0.401967609902953940, -0.402013392094820070, -0.402059173281652750, -0.402104953463337860, -0.402150732639760200, -0.402196510810805710, -0.402242287976360360, +-0.402288064136308850, -0.402333839290537230, -0.402379613438930970, -0.402425386581376110, -0.402471158717757350, -0.402516929847960720, -0.402562699971871770, -0.402608469089376420, +-0.402654237200359530, -0.402700004304707090, -0.402745770402304580, -0.402791535493038090, -0.402837299576792320, -0.402883062653453310, -0.402928824722906640, -0.402974585785038310, +-0.403020345839733120, -0.403066104886877110, -0.403111862926356200, -0.403157619958055210, -0.403203375981860180, -0.403249130997656750, -0.403294885005330840, -0.403340638004767330, +-0.403386389995852250, -0.403432140978471190, -0.403477890952510190, -0.403523639917854000, -0.403569387874388790, -0.403615134822000070, -0.403660880760573880, -0.403706625689995160, +-0.403752369610149820, -0.403798112520923570, -0.403843854422202440, -0.403889595313871310, -0.403935335195816150, -0.403981074067922660, -0.404026811930076890, -0.404072548782163700, +-0.404118284624069120, -0.404164019455679260, -0.404209753276878910, -0.404255486087554180, -0.404301217887590770, -0.404346948676874710, -0.404392678455290870, -0.404438407222725280, +-0.404484134979063710, -0.404529861724192250, -0.404575587457995710, -0.404621312180360180, -0.404667035891171370, -0.404712758590315410, -0.404758480277677080, -0.404804200953142620, +-0.404849920616597640, -0.404895639267928260, -0.404941356907019380, -0.404987073533757070, -0.405032789148027540, -0.405078503749715550, -0.405124217338707400, -0.405169929914888650, +-0.405215641478145480, -0.405261352028362830, -0.405307061565426780, -0.405352770089223050, -0.405398477599637820, -0.405444184096556030, -0.405489889579863760, -0.405535594049446720, +-0.405581297505191170, -0.405626999946981930, -0.405672701374705180, -0.405718401788246700, -0.405764101187492620, -0.405809799572327880, -0.405855496942638620, -0.405901193298311090, +-0.405946888639230120, -0.405992582965281900, -0.406038276276352250, -0.406083968572327310, -0.406129659853092070, -0.406175350118532670, -0.406221039368534880, -0.406266727602984930, +-0.406312414821767720, -0.406358101024769490, -0.406403786211876010, -0.406449470382973470, -0.406495153537946850, -0.406540835676682310, -0.406586516799065710, -0.406632196904983260, +-0.406677875994319870, -0.406723554066961760, -0.406769231122795230, -0.406814907161705210, -0.406860582183577900, -0.406906256188299120, -0.406951929175755120, -0.406997601145830890, +-0.407043272098412680, -0.407088942033386250, -0.407134610950637910, -0.407180278850052650, -0.407225945731516660, -0.407271611594915820, -0.407317276440136320, -0.407362940267063270, +-0.407408603075582850, -0.407454264865580900, -0.407499925636943710, -0.407545585389556320, -0.407591244123304940, -0.407636901838075490, -0.407682558533754180, -0.407728214210226040, +-0.407773868867377380, -0.407819522505094460, -0.407865175123262310, -0.407910826721767260, -0.407956477300495110, -0.408002126859332180, -0.408047775398163500, -0.408093422916875390, +-0.408139069415353770, -0.408184714893484850, -0.408230359351153760, -0.408276002788246720, -0.408321645204649750, -0.408367286600249010, -0.408412926974929650, -0.408458566328578020, +-0.408504204661079950, -0.408549841972321750, -0.408595478262188560, -0.408641113530566650, -0.408686747777342370, -0.408732381002400840, -0.408778013205628340, -0.408823644386910820, +-0.408869274546134590, -0.408914903683184780, -0.408960531797947720, -0.409006158890309280, -0.409051784960155870, -0.409097410007372650, -0.409143034031845820, -0.409188657033461470, +-0.409234279012105850, -0.409279899967664120, -0.409325519900022640, -0.409371138809067390, -0.409416756694684690, -0.409462373556759680, -0.409507989395178740, -0.409553604209828230, +-0.409599218000593290, -0.409644830767360300, -0.409690442510015300, -0.409736053228444530, -0.409781662922533260, -0.409827271592167810, -0.409872879237234200, -0.409918485857618750, +-0.409964091453206720, -0.410009696023884480, -0.410055299569538010, -0.410100902090053620, -0.410146503585316620, -0.410192104055213390, -0.410237703499629850, -0.410283301918452470, +-0.410328899311566410, -0.410374495678858140, -0.410420091020213650, -0.410465685335519300, -0.410511278624660300, -0.410556870887523180, -0.410602462123994210, -0.410648052333958740, +-0.410693641517303090, -0.410739229673913410, -0.410784816803676010, -0.410830402906476160, -0.410875987982200320, -0.410921572030734480, -0.410967155051965130, -0.411012737045777510, +-0.411058318012058000, -0.411103897950692740, -0.411149476861568160, -0.411195054744569410, -0.411240631599583070, -0.411286207426495130, -0.411331782225192120, -0.411377355995559250, +-0.411422928737482930, -0.411468500450849710, -0.411514071135544890, -0.411559640791454850, -0.411605209418465680, -0.411650777016463910, -0.411696343585334800, -0.411741909124964830, +-0.411787473635240100, -0.411833037116047070, -0.411878599567271080, -0.411924160988798580, -0.411969721380515690, -0.412015280742308860, -0.412060839074063430, -0.412106396375665930, +-0.412151952647002380, -0.412197507887959390, -0.412243062098422260, -0.412288615278277430, -0.412334167427411470, -0.412379718545709710, -0.412425268633058670, -0.412470817689344400, +-0.412516365714453550, -0.412561912708271360, -0.412607458670684380, -0.412653003601578750, -0.412698547500841010, -0.412744090368356520, -0.412789632204011770, -0.412835173007693010, +-0.412880712779286670, -0.412926251518678120, -0.412971789225753950, -0.413017325900400360, -0.413062861542503820, -0.413108396151949720, -0.413153929728624640, -0.413199462272415160, +-0.413244993783206560, -0.413290524260885530, -0.413336053705338210, -0.413381582116451100, -0.413427109494109660, -0.413472635838200430, -0.413518161148609620, -0.413563685425223810, +-0.413609208667928390, -0.413654730876609980, -0.413700252051154680, -0.413745772191449200, -0.413791291297378850, -0.413836809368830330, -0.413882326405689730, -0.413927842407843750, +-0.413973357375177710, -0.414018871307578310, -0.414064384204931750, -0.414109896067124620, -0.414155406894042340, -0.414200916685571520, -0.414246425441598840, -0.414291933162009740, +-0.414337439846690750, -0.414382945495528180, -0.414428450108408620, -0.414473953685217560, -0.414519456225841580, -0.414564957730166990, -0.414610458198080400, -0.414655957629467280, +-0.414701456024214270, -0.414746953382207570, -0.414792449703333950, -0.414837944987478780, -0.414883439234528750, -0.414928932444370120, -0.414974424616889550, -0.415019915751972500, +-0.415065405849505690, -0.415110894909375750, -0.415156382931468230, -0.415201869915669710, -0.415247355861866510, -0.415292840769945330, -0.415338324639791590, -0.415383807471292110, +-0.415429289264333090, -0.415474770018801230, -0.415520249734582070, -0.415565728411562310, -0.415611206049628200, -0.415656682648666450, -0.415702158208562660, -0.415747632729203400, +-0.415793106210475110, -0.415838578652264420, -0.415884050054456890, -0.415929520416939260, -0.415974989739598230, -0.416020458022319290, -0.416065925264989200, -0.416111391467494320, +-0.416156856629721410, -0.416202320751555890, -0.416247783832884580, -0.416293245873593840, -0.416338706873570330, -0.416384166832699740, -0.416429625750868670, -0.416475083627963540, +-0.416520540463871100, -0.416565996258476900, -0.416611451011667740, -0.416656904723329950, -0.416702357393350320, -0.416747809021614350, -0.416793259608008840, -0.416838709152420220, +-0.416884157654735240, -0.416929605114839450, -0.416975051532619660, -0.417020496907962610, -0.417065941240753910, -0.417111384530880420, -0.417156826778228410, -0.417202267982684780, +-0.417247708144135030, -0.417293147262466020, -0.417338585337564180, -0.417384022369316270, -0.417429458357607860, -0.417474893302325840, -0.417520327203356580, -0.417565760060586880, +-0.417611191873902440, -0.417656622643189980, -0.417702052368335960, -0.417747481049227210, -0.417792908685749360, -0.417838335277789240, -0.417883760825233710, -0.417929185327968300, +-0.417974608785880000, -0.418020031198855170, -0.418065452566780630, -0.418110872889542070, -0.418156292167026320, -0.418201710399119910, -0.418247127585709530, -0.418292543726680950, +-0.418337958821921040, -0.418383372871316220, -0.418428785874753410, -0.418474197832118200, -0.418519608743297470, -0.418565018608177740, -0.418610427426645890, -0.418655835198587510, +-0.418701241923889580, -0.418746647602438960, -0.418792052234121300, -0.418837455818823530, -0.418882858356432130, -0.418928259846833960, -0.418973660289914730, -0.419019059685561360, +-0.419064458033660330, -0.419109855334098560, -0.419155251586761760, -0.419200646791536850, -0.419246040948310310, -0.419291434056969060, -0.419336826117398810, -0.419382217129486530, +-0.419427607093118660, -0.419472996008182220, -0.419518383874562860, -0.419563770692147560, -0.419609156460822810, -0.419654541180475570, -0.419699924850991610, -0.419745307472257800, +-0.419790689044161170, -0.419836069566587370, -0.419881449039423430, -0.419926827462555830, -0.419972204835871610, -0.420017581159256470, -0.420062956432597330, -0.420108330655780850, +-0.420153703828693940, -0.420199075951222300, -0.420244447023253030, -0.420289817044672660, -0.420335186015368120, -0.420380553935225220, -0.420425920804130940, -0.420471286621971860, +-0.420516651388634920, -0.420562015104005980, -0.420607377767972020, -0.420652739380420030, -0.420698099941235750, -0.420743459450306220, -0.420788817907518100, -0.420834175312758300, +-0.420879531665912630, -0.420924886966868190, -0.420970241215511460, -0.421015594411729590, -0.421060946555408320, -0.421106297646434700, -0.421151647684695260, -0.421196996670077210, +-0.421242344602466180, -0.421287691481749330, -0.421333037307813240, -0.421378382080544960, -0.421423725799830340, -0.421469068465556370, -0.421514410077610150, -0.421559750635877530, +-0.421605090140245500, -0.421650428590600760, -0.421695765986830340, -0.421741102328820060, -0.421786437616457070, -0.421831771849628000, -0.421877105028219900, -0.421922437152118630, +-0.421967768221211240, -0.422013098235384470, -0.422058427194525350, -0.422103755098519720, -0.422149081947254760, -0.422194407740617060, -0.422239732478493720, -0.422285056160770720, +-0.422330378787335040, -0.422375700358073760, -0.422421020872872920, -0.422466340331619450, -0.422511658734200160, -0.422556976080502130, -0.422602292370411300, -0.422647607603814700, +-0.422692921780599080, -0.422738234900651540, -0.422783546963858000, -0.422828857970105660, -0.422874167919281120, -0.422919476811271570, -0.422964784645962930, -0.423010091423242360, +-0.423055397142996560, -0.423100701805112610, -0.423146005409476560, -0.423191307955975480, -0.423236609444496090, -0.423281909874925640, -0.423327209247150000, -0.423372507561056320, +-0.423417804816531800, -0.423463101013462300, -0.423508396151735080, -0.423553690231236900, -0.423598983251854910, -0.423644275213475030, -0.423689566115984460, -0.423734855959269960, +-0.423780144743218730, -0.423825432467716760, -0.423870719132651170, -0.423916004737908800, -0.423961289283376840, -0.424006572768941270, -0.424051855194489240, -0.424097136559907550, +-0.424142416865083470, -0.424187696109902870, -0.424232974294253110, -0.424278251418021280, -0.424323527481093420, -0.424368802483356730, -0.424414076424698080, -0.424459349305004620, +-0.424504621124162370, -0.424549891882058550, -0.424595161578580020, -0.424640430213614030, -0.424685697787046510, -0.424730964298764780, -0.424776229748655590, -0.424821494136606250, +-0.424866757462502800, -0.424912019726232440, -0.424957280927682040, -0.425002541066738790, -0.425047800143288860, -0.425093058157219370, -0.425138315108417650, -0.425183570996769790, +-0.425228825822162930, -0.425274079584484040, -0.425319332283620400, -0.425364583919457970, -0.425409834491884080, -0.425455084000785630, -0.425500332446049840, -0.425545579827562860, +-0.425590826145211880, -0.425636071398883880, -0.425681315588466060, -0.425726558713844570, -0.425771800774906670, -0.425817041771539280, -0.425862281703629720, -0.425907520571064010, +-0.425952758373729530, -0.425997995111513150, -0.426043230784302170, -0.426088465391982700, -0.426133698934442080, -0.426178931411567650, -0.426224162823245430, -0.426269393169362850, +-0.426314622449806780, -0.426359850664464520, -0.426405077813222230, -0.426450303895967280, -0.426495528912586570, -0.426540752862967440, -0.426585975746996030, -0.426631197564559640, +-0.426676418315545310, -0.426721637999840310, -0.426766856617330830, -0.426812074167904180, -0.426857290651447340, -0.426902506067847690, -0.426947720416991360, -0.426992933698765790, +-0.427038145913058220, -0.427083357059754920, -0.427128567138743200, -0.427173776149910090, -0.427218984093142910, -0.427264190968327910, -0.427309396775352400, -0.427354601514103370, +-0.427399805184468300, -0.427445007786333320, -0.427490209319585760, -0.427535409784112700, -0.427580609179801560, -0.427625807506538450, -0.427671004764210830, -0.427716200952705680, +-0.427761396071910490, -0.427806590121711350, -0.427851783101995730, -0.427896975012651120, -0.427942165853563590, -0.427987355624620700, -0.428032544325709420, -0.428077731956717170, +-0.428122918517530150, -0.428168104008035900, -0.428213288428121340, -0.428258471777674010, -0.428303654056580050, -0.428348835264727000, -0.428394015402001840, -0.428439194468292040, +-0.428484372463483810, -0.428529549387464740, -0.428574725240121750, -0.428619900021342310, -0.428665073731012760, -0.428710246369020550, -0.428755417935253070, -0.428800588429596670, +-0.428845757851938790, -0.428890926202166570, -0.428936093480167370, -0.428981259685827570, -0.429026424819034580, -0.429071588879675560, -0.429116751867637980, -0.429161913782808100, +-0.429207074625073460, -0.429252234394321090, -0.429297393090438570, -0.429342550713312180, -0.429387707262829380, -0.429432862738877320, -0.429478017141343480, -0.429523170470114240, +-0.429568322725077060, -0.429613473906119090, -0.429658624013127820, -0.429703773045989560, -0.429748921004591890, -0.429794067888822350, -0.429839213698567200, -0.429884358433714030, +-0.429929502094149930, -0.429974644679762540, -0.430019786190438070, -0.430064926626064210, -0.430110065986527960, -0.430155204271717000, -0.430200341481517590, -0.430245477615817380, +-0.430290612674503410, -0.430335746657463380, -0.430380879564583540, -0.430426011395751480, -0.430471142150854410, -0.430516271829779920, -0.430561400432414310, -0.430606527958645240, +-0.430651654408360170, -0.430696779781445660, -0.430741904077789120, -0.430787027297277860, -0.430832149439799420, -0.430877270505240220, -0.430922390493487850, -0.430967509404429520, +-0.431012627237952750, -0.431057743993944090, -0.431102859672291010, -0.431147974272880820, -0.431193087795601060, -0.431238200240338210, -0.431283311606979860, -0.431328421895413210, +-0.431373531105525900, -0.431418639237204420, -0.431463746290336290, -0.431508852264809170, -0.431553957160509590, -0.431599060977325030, -0.431644163715142910, -0.431689265373850720, +-0.431734365953334980, -0.431779465453483340, -0.431824563874183050, -0.431869661215321720, -0.431914757476785820, -0.431959852658463090, -0.432004946760240700, -0.432050039782006290, +-0.432095131723646440, -0.432140222585048750, -0.432185312366100530, -0.432230401066689360, -0.432275488686701850, -0.432320575226025570, -0.432365660684547900, -0.432410745062156430, +-0.432455828358737750, -0.432500910574179440, -0.432545991708369330, -0.432591071761193770, -0.432636150732540580, -0.432681228622296970, -0.432726305430350730, -0.432771381156588310, +-0.432816455800897450, -0.432861529363165410, -0.432906601843280000, -0.432951673241127650, -0.432996743556596120, -0.433041812789572710, -0.433086880939945180, -0.433131948007600080, +-0.433177013992425090, -0.433222078894307580, -0.433267142713135270, -0.433312205448794670, -0.433357267101173620, -0.433402327670159740, -0.433447387155639690, -0.433492445557501100, +-0.433537502875631480, -0.433582559109918440, -0.433627614260248650, -0.433672668326509800, -0.433717721308589270, -0.433762773206374850, -0.433807824019753100, -0.433852873748611810, +-0.433897922392838310, -0.433942969952320400, -0.433988016426944680, -0.434033061816598900, -0.434078106121170480, -0.434123149340547190, -0.434168191474615610, -0.434213232523263600, +-0.434258272486378880, -0.434303311363848090, -0.434348349155558980, -0.434393385861399030, -0.434438421481256000, -0.434483456015016530, -0.434528489462568450, -0.434573521823799100, +-0.434618553098596370, -0.434663583286846840, -0.434708612388438390, -0.434753640403258370, -0.434798667331194650, -0.434843693172133890, -0.434888717925963840, -0.434933741592572090, +-0.434978764171846280, -0.435023785663673220, -0.435068806067940680, -0.435113825384536580, -0.435158843613347450, -0.435203860754261210, -0.435248876807165340, -0.435293891771947660, +-0.435338905648494870, -0.435383918436694830, -0.435428930136434970, -0.435473940747603210, -0.435518950270086190, -0.435563958703771790, -0.435608966048547490, -0.435653972304301140, +-0.435698977470919510, -0.435743981548290420, -0.435788984536301380, -0.435833986434840280, -0.435878987243793810, -0.435923986963049850, -0.435968985592495970, -0.436013983132020000, +-0.436058979581508630, -0.436103974940849900, -0.436148969209931570, -0.436193962388640440, -0.436238954476864390, -0.436283945474490950, -0.436328935381408100, -0.436373924197502430, +-0.436418911922662020, -0.436463898556774310, -0.436508884099727210, -0.436553868551407540, -0.436598851911703220, -0.436643834180501730, -0.436688815357691050, -0.436733795443157990, +-0.436778774436790360, -0.436823752338475870, -0.436868729148102370, -0.436913704865556640, -0.436958679490726640, -0.437003653023500360, -0.437048625463764550, -0.437093596811407140, +-0.437138567066315760, -0.437183536228378360, -0.437228504297481720, -0.437273471273513850, -0.437318437156362260, -0.437363401945915000, -0.437408365642058870, -0.437453328244681750, +-0.437498289753671390, -0.437543250168915650, -0.437588209490301420, -0.437633167717716600, -0.437678124851048900, -0.437723080890186300, -0.437768035835015610, -0.437812989685424810, +-0.437857942441301940, -0.437902894102533800, -0.437947844669008430, -0.437992794140613480, -0.438037742517236930, -0.438082689798765580, -0.438127635985087580, -0.438172581076090420, +-0.438217525071662230, -0.438262467971689830, -0.438307409776061310, -0.438352350484664200, -0.438397290097386650, -0.438442228614115470, -0.438487166034738700, -0.438532102359144030, +-0.438577037587219500, -0.438621971718851980, -0.438666904753929500, -0.438711836692339760, -0.438756767533970860, -0.438801697278709660, -0.438846625926444190, -0.438891553477062550, +-0.438936479930451650, -0.438981405286499540, -0.439026329545093910, -0.439071252706122850, -0.439116174769473230, -0.439161095735033260, -0.439206015602690460, -0.439250934372333090, +-0.439295852043847970, -0.439340768617123180, -0.439385684092046480, -0.439430598468506020, -0.439475511746388600, -0.439520423925582440, -0.439565335005975220, -0.439610244987455050, +-0.439655153869908830, -0.439700061653224780, -0.439744968337290990, -0.439789873921994310, -0.439834778407223010, -0.439879681792864740, -0.439924584078807690, -0.439969485264938730, +-0.440014385351146060, -0.440059284337317500, -0.440104182223341080, -0.440149079009103770, -0.440193974694493840, -0.440238869279398930, -0.440283762763707230, -0.440328655147305740, +-0.440373546430082590, -0.440418436611925590, -0.440463325692722950, -0.440508213672361540, -0.440553100550729600, -0.440597986327715300, -0.440642871003205650, -0.440687754577088860, +-0.440732637049252640, -0.440777518419585230, -0.440822398687973630, -0.440867277854306020, -0.440912155918470220, -0.440957032880354480, -0.441001908739845680, -0.441046783496832180, +-0.441091657151201690, -0.441136529702842450, -0.441181401151641450, -0.441226271497487000, -0.441271140740266850, -0.441316008879869270, -0.441360875916181280, -0.441405741849091090, +-0.441450606678486900, -0.441495470404255850, -0.441540333026286090, -0.441585194544465490, -0.441630054958682350, -0.441674914268823600, -0.441719772474777620, -0.441764629576432200, +-0.441809485573675610, -0.441854340466394880, -0.441899194254478320, -0.441944046937813810, -0.441988898516289530, -0.442033748989792640, -0.442078598358211340, -0.442123446621433550, +-0.442168293779347580, -0.442213139831840460, -0.442257984778800460, -0.442302828620115550, -0.442347671355673930, -0.442392512985362750, -0.442437353509070260, -0.442482192926684780, +-0.442527031238093450, -0.442571868443184580, -0.442616704541845980, -0.442661539533966030, -0.442706373419431810, -0.442751206198131690, -0.442796037869953580, -0.442840868434785710, +-0.442885697892515310, -0.442930526243030640, -0.442975353486219690, -0.443020179621970770, -0.443065004650170960, -0.443109828570708630, -0.443154651383471760, -0.443199473088348620, +-0.443244293685226440, -0.443289113173993500, -0.443333931554538210, -0.443378748826747660, -0.443423564990510280, -0.443468380045713930, -0.443513193992247030, -0.443558006829996800, +-0.443602818558851530, -0.443647629178699210, -0.443692438689428200, -0.443737247090925710, -0.443782054383080100, -0.443826860565779360, -0.443871665638911890, -0.443916469602364800, +-0.443961272456026570, -0.444006074199785160, -0.444050874833528950, -0.444095674357145200, -0.444140472770522210, -0.444185270073548470, -0.444230066266111110, -0.444274861348098630, +-0.444319655319398990, -0.444364448179900620, -0.444409239929490720, -0.444454030568057710, -0.444498820095489630, -0.444543608511674900, -0.444588395816500730, -0.444633182009855580, +-0.444677967091627490, -0.444722751061704890, -0.444767533919974980, -0.444812315666326290, -0.444857096300646740, -0.444901875822824920, -0.444946654232747980, -0.444991431530304400, +-0.445036207715382210, -0.445080982787869950, -0.445125756747654810, -0.445170529594625270, -0.445215301328669820, -0.445260071949675760, -0.445304841457531460, -0.445349609852125070, +-0.445394377133345070, -0.445439143301078700, -0.445483908355214510, -0.445528672295640530, -0.445573435122245230, -0.445618196834915990, -0.445662957433541280, -0.445707716918009140, +-0.445752475288208110, -0.445797232544025480, -0.445841988685349800, -0.445886743712069160, -0.445931497624072030, -0.445976250421245720, -0.446021002103478840, -0.446065752670659840, +-0.446110502122676060, -0.446155250459416010, -0.446199997680767850, -0.446244743786620100, -0.446289488776860090, -0.446334232651376340, -0.446378975410057060, -0.446423717052790660, +-0.446468457579464630, -0.446513196989967440, -0.446557935284187250, -0.446602672462012630, -0.446647408523330900, -0.446692143468030710, -0.446736877296000090, -0.446781610007127740, +-0.446826341601300910, -0.446871072078408260, -0.446915801438338310, -0.446960529680978490, -0.447005256806217330, -0.447049982813943040, -0.447094707704044190, -0.447139431476408170, +-0.447184154130923550, -0.447228875667478540, -0.447273596085961730, -0.447318315386260600, -0.447363033568263620, -0.447407750631859060, -0.447452466576935550, -0.447497181403380460, +-0.447541895111082440, -0.447586607699929640, -0.447631319169810750, -0.447676029520613140, -0.447720738752225510, -0.447765446864536340, -0.447810153857433220, -0.447854859730804740, +-0.447899564484539050, -0.447944268118524890, -0.447988970632649640, -0.448033672026801940, -0.448078372300870110, -0.448123071454742730, -0.448167769488307280, -0.448212466401452400, +-0.448257162194066310, -0.448301856866037800, -0.448346550417254190, -0.448391242847604180, -0.448435934156976130, -0.448480624345258590, -0.448525313412339140, -0.448570001358106370, +-0.448614688182448600, -0.448659373885254510, -0.448704058466411590, -0.448748741925808550, -0.448793424263334020, -0.448838105478875540, -0.448882785572321810, -0.448927464543561080, +-0.448972142392482120, -0.449016819118972400, -0.449061494722920620, -0.449106169204215140, -0.449150842562744570, -0.449195514798396590, -0.449240185911059740, -0.449284855900622450, +-0.449329524766973410, -0.449374192510000160, -0.449418859129591450, -0.449463524625635600, -0.449508188998021310, -0.449552852246636160, -0.449597514371368910, -0.449642175372108210, +-0.449686835248741700, -0.449731494001158140, -0.449776151629245780, -0.449820808132893490, -0.449865463511988750, -0.449910117766420370, -0.449954770896076720, -0.449999422900846490, +-0.450044073780617340, -0.450088723535277960, -0.450133372164716830, -0.450178019668822650, -0.450222666047483010, -0.450267311300586730, -0.450311955428022100, -0.450356598429678070, +-0.450401240305442100, -0.450445881055203000, -0.450490520678849650, -0.450535159176269630, -0.450579796547351640, -0.450624432791984160, -0.450669067910056060, -0.450713701901454820, +-0.450758334766069360, -0.450802966503788090, -0.450847597114499730, -0.450892226598092080, -0.450936854954453790, -0.450981482183473390, -0.451026108285039640, -0.451070733259040290, +-0.451115357105364050, -0.451159979823899440, -0.451204601414535280, -0.451249221877159210, -0.451293841211660110, -0.451338459417926390, -0.451383076495846910, -0.451427692445309340, +-0.451472307266202580, -0.451516920958415390, -0.451561533521835530, -0.451606144956351820, -0.451650755261852780, -0.451695364438227220, -0.451739972485362910, -0.451784579403148590, +-0.451829185191472860, -0.451873789850224580, -0.451918393379291410, -0.451962995778562250, -0.452007597047925590, -0.452052197187270350, -0.452096796196484240, -0.452141394075456120, +-0.452185990824074510, -0.452230586442228300, -0.452275180929805290, -0.452319774286694290, -0.452364366512784220, -0.452408957607962900, -0.452453547572119140, -0.452498136405141530, +-0.452542724106918980, -0.452587310677339210, -0.452631896116291180, -0.452676480423663370, -0.452721063599344830, -0.452765645643223190, -0.452810226555187430, -0.452854806335126090, +-0.452899384982928140, -0.452943962498481350, -0.452988538881674670, -0.453033114132396610, -0.453077688250536180, -0.453122261235981090, -0.453166833088620380, -0.453211403808343020, +-0.453255973395036700, -0.453300541848590480, -0.453345109168892870, -0.453389675355832910, -0.453434240409298360, -0.453478804329178200, -0.453523367115361060, -0.453567928767735880, +-0.453612489286190470, -0.453657048670613850, -0.453701606920894620, -0.453746164036921750, -0.453790720018583060, -0.453835274865767580, -0.453879828578363950, -0.453924381156261100, +-0.453968932599346900, -0.454013482907510420, -0.454058032080640610, -0.454102580118625310, -0.454147127021353510, -0.454191672788713970, -0.454236217420595610, -0.454280760916886350, +-0.454325303277475110, -0.454369844502250650, -0.454414384591102010, -0.454458923543916980, -0.454503461360584670, -0.454547998040993660, -0.454592533585033100, -0.454637067992590740, +-0.454681601263555780, -0.454726133397816810, -0.454770664395262870, -0.454815194255781870, -0.454859722979262910, -0.454904250565594640, -0.454948777014666130, -0.454993302326365310, +-0.455037826500581220, -0.455082349537202950, -0.455126871436118410, -0.455171392197216700, -0.455215911820386450, -0.455260430305516880, -0.455304947652495850, -0.455349463861212440, +-0.455393978931555370, -0.455438492863413700, -0.455483005656675430, -0.455527517311229700, -0.455572027826965150, -0.455616537203770880, -0.455661045441534910, -0.455705552540146330, +-0.455750058499493850, -0.455794563319466610, -0.455839066999952580, -0.455883569540840920, -0.455928070942020700, -0.455972571203379860, -0.456017070324807650, -0.456061568306192770, +-0.456106065147424360, -0.456150560848390340, -0.456195055408979980, -0.456239548829081960, -0.456284041108585450, -0.456328532247378460, -0.456373022245350150, -0.456417511102389260, +-0.456461998818385010, -0.456506485393225360, -0.456550970826799460, -0.456595455118996190, -0.456639938269704610, -0.456684420278812840, -0.456728901146210010, -0.456773380871785370, +-0.456817859455426800, -0.456862336897023660, -0.456906813196464590, -0.456951288353638960, -0.456995762368434700, -0.457040235240741000, -0.457084706970446730, -0.457129177557441090, +-0.457173647001612120, -0.457218115302849000, -0.457262582461040620, -0.457307048476076170, -0.457351513347843690, -0.457395977076232470, -0.457440439661131240, -0.457484901102429340, +-0.457529361400014820, -0.457573820553776880, -0.457618278563604370, -0.457662735429386620, -0.457707191151011550, -0.457751645728368570, -0.457796099161346840, -0.457840551449834490, +-0.457885002593720720, -0.457929452592894470, -0.457973901447244980, -0.458018349156660340, -0.458062795721029810, -0.458107241140242320, -0.458151685414187100, -0.458196128542752320, +-0.458240570525827170, -0.458285011363300580, -0.458329451055061900, -0.458373889600999170, -0.458418327001001770, -0.458462763254958490, -0.458507198362758720, -0.458551632324290530, +-0.458596065139443290, -0.458640496808106310, -0.458684927330167640, -0.458729356705516680, -0.458773784934042310, -0.458818212015633890, -0.458862637950179560, -0.458907062737568590, +-0.458951486377690010, -0.458995908870433070, -0.459040330215686020, -0.459084750413338070, -0.459129169463278310, -0.459173587365395990, -0.459218004119579300, -0.459262419725717570, +-0.459306834183699890, -0.459351247493415440, -0.459395659654752490, -0.459440070667600400, -0.459484480531848540, -0.459528889247385050, -0.459573296814099360, -0.459617703231880390, +-0.459662108500617620, -0.459706512620199130, -0.459750915590514400, -0.459795317411452350, -0.459839718082902470, -0.459884117604752840, -0.459928515976892880, -0.459972913199211690, +-0.460017309271598620, -0.460061704193941820, -0.460106097966130830, -0.460150490588054570, -0.460194882059602460, -0.460239272380662760, -0.460283661551124880, -0.460328049570878250, +-0.460372436439811070, -0.460416822157812820, -0.460461206724772530, -0.460505590140579620, -0.460549972405122300, -0.460594353518290090, -0.460638733479971970, -0.460683112290057430, +-0.460727489948434710, -0.460771866454993300, -0.460816241809622160, -0.460860616012210840, -0.460904989062647600, -0.460949360960821840, -0.460993731706622720, -0.461038101299939660, +-0.461082469740660970, -0.461126837028676070, -0.461171203163874110, -0.461215568146144510, -0.461259931975375570, -0.461304294651456840, -0.461348656174277780, -0.461393016543726660, +-0.461437375759693010, -0.461481733822065920, -0.461526090730734860, -0.461570446485588200, -0.461614801086515480, -0.461659154533405670, -0.461703506826148410, -0.461747857964632020, +-0.461792207948745930, -0.461836556778379310, -0.461880904453421730, -0.461925250973761530, -0.461969596339288140, -0.462013940549890760, -0.462058283605458970, -0.462102625505881050, +-0.462146966251046560, -0.462191305840845060, -0.462235644275164890, -0.462279981553895600, -0.462324317676926390, -0.462368652644146780, -0.462412986455445100, -0.462457319110710970, +-0.462501650609833560, -0.462545980952702440, -0.462590310139205930, -0.462634638169233670, -0.462678965042674810, -0.462723290759418930, -0.462767615319354400, -0.462811938722370860, +-0.462856260968357470, -0.462900582057203800, -0.462944901988798340, -0.462989220763030560, -0.463033538379790170, -0.463077854838965520, -0.463122170140446210, -0.463166484284121550, +-0.463210797269881010, -0.463255109097613080, -0.463299419767207400, -0.463343729278553160, -0.463388037631540020, -0.463432344826056330, -0.463476650861991860, -0.463520955739235680, +-0.463565259457677570, -0.463609562017205880, -0.463653863417710310, -0.463698163659080060, -0.463742462741204790, -0.463786760663973010, -0.463831057427274320, -0.463875353030997920, +-0.463919647475033610, -0.463963940759269720, -0.464008232883596050, -0.464052523847902130, -0.464096813652076560, -0.464141102296008910, -0.464185389779588560, -0.464229676102705100, +-0.464273961265247060, -0.464318245267104080, -0.464362528108165530, -0.464406809788321050, -0.464451090307459120, -0.464495369665469500, -0.464539647862241440, -0.464583924897664650, +-0.464628200771627640, -0.464672475484020130, -0.464716749034731480, -0.464761021423651330, -0.464805292650668220, -0.464849562715671900, -0.464893831618552020, -0.464938099359197220, +-0.464982365937497140, -0.465026631353341160, -0.465070895606618960, -0.465115158697219200, -0.465159420625031460, -0.465203681389945220, -0.465247940991850180, -0.465292199430634880, +-0.465336456706189060, -0.465380712818402100, -0.465424967767163800, -0.465469221552362640, -0.465513474173888440, -0.465557725631630560, -0.465601975925478750, -0.465646225055321610, +-0.465690473021048930, -0.465734719822550440, -0.465778965459714760, -0.465823209932431650, -0.465867453240590530, -0.465911695384081170, -0.465955936362792200, -0.466000176176613320, +-0.466044414825434070, -0.466088652309144150, -0.466132888627632250, -0.466177123780788070, -0.466221357768501100, -0.466265590590661140, -0.466309822247156780, -0.466354052737877890, +-0.466398282062713830, -0.466442510221554530, -0.466486737214288520, -0.466530963040805660, -0.466575187700995820, -0.466619411194747590, -0.466663633521950840, -0.466707854682494980, +-0.466752074676269890, -0.466796293503164210, -0.466840511163067850, -0.466884727655870190, -0.466928942981461090, -0.466973157139729200, -0.467017370130564490, -0.467061581953856330, +-0.467105792609494590, -0.467150002097368010, -0.467194210417366360, -0.467238417569379230, -0.467282623553296470, -0.467326828369006740, -0.467371032016399900, -0.467415234495365540, +-0.467459435805793470, -0.467503635947572380, -0.467547834920592260, -0.467592032724742920, -0.467636229359913110, -0.467680424825992700, -0.467724619122871220, -0.467768812250438650, +-0.467813004208583630, -0.467857194997196080, -0.467901384616165540, -0.467945573065381930, -0.467989760344734000, -0.468033946454111670, -0.468078131393404480, -0.468122315162502360, +-0.468166497761294040, -0.468210679189669520, -0.468254859447518270, -0.468299038534730260, -0.468343216451194260, -0.468387393196800230, -0.468431568771438100, -0.468475743174996680, +-0.468519916407365900, -0.468564088468435280, -0.468608259358094910, -0.468652429076233450, -0.468696597622740910, -0.468740764997506890, -0.468784931200421360, -0.468829096231373090, +-0.468873260090252100, -0.468917422776947920, -0.468961584291350600, -0.469005744633348930, -0.469049903802832900, -0.469094061799692150, -0.469138218623816610, -0.469182374275095070, +-0.469226528753417640, -0.469270682058674340, -0.469314834190753870, -0.469358985149546330, -0.469403134934941350, -0.469447283546828910, -0.469491430985097820, -0.469535577249638240, +-0.469579722340339620, -0.469623866257092180, -0.469668008999784610, -0.469712150568307060, -0.469756290962549120, -0.469800430182400860, -0.469844568227751110, -0.469888705098489960, +-0.469932840794507030, -0.469976975315692440, -0.470021108661934970, -0.470065240833124730, -0.470109371829151410, -0.470153501649905050, -0.470197630295274500, -0.470241757765149930, +-0.470285884059421340, -0.470330009177977630, -0.470374133120708910, -0.470418255887504850, -0.470462377478255590, -0.470506497892849930, -0.470550617131178070, -0.470594735193129670, +-0.470638852078594790, -0.470682967787462380, -0.470727082319622570, -0.470771195674965060, -0.470815307853379940, -0.470859418854756180, -0.470903528678983880, -0.470947637325952740, +-0.470991744795552890, -0.471035851087673320, -0.471079956202204050, -0.471124060139035350, -0.471168162898056080, -0.471212264479156430, -0.471256364882226110, -0.471300464107155260, +-0.471344562153832860, -0.471388659022149050, -0.471432754711993580, -0.471476849223256610, -0.471520942555827160, -0.471565034709595320, -0.471609125684450960, -0.471653215480284100, +-0.471697304096983850, -0.471741391534440340, -0.471785477792543320, -0.471829562871183050, -0.471873646770248460, -0.471917729489629730, -0.471961811029217080, -0.472005891388899480, +-0.472049970568567230, -0.472094048568109990, -0.472138125387418010, -0.472182201026380370, -0.472226275484887210, -0.472270348762828360, -0.472314420860094060, -0.472358491776573300, +-0.472402561512156260, -0.472446630066732880, -0.472490697440193290, -0.472534763632426580, -0.472578828643322960, -0.472622892472772230, -0.472666955120664700, -0.472711016586889410, +-0.472755076871336500, -0.472799135973895950, -0.472843193894457950, -0.472887250632911590, -0.472931306189147080, -0.472975360563054730, -0.473019413754523550, -0.473063465763443820, +-0.473107516589705460, -0.473151566233198710, -0.473195614693812660, -0.473239661971437520, -0.473283708065963260, -0.473327752977280140, -0.473371796705277180, -0.473415839249844760, +-0.473459880610872800, -0.473503920788251490, -0.473547959781869980, -0.473591997591618520, -0.473636034217387150, -0.473680069659066060, -0.473724103916544400, -0.473768136989712490, +-0.473812168878460560, -0.473856199582677880, -0.473900229102254710, -0.473944257437080960, -0.473988284587046950, -0.474032310552041870, -0.474076335331955980, -0.474120358926679250, +-0.474164381336102000, -0.474208402560113430, -0.474252422598603840, -0.474296441451463210, -0.474340459118581860, -0.474384475599848980, -0.474428490895154880, -0.474472505004389590, +-0.474516517927443430, -0.474560529664205530, -0.474604540214566380, -0.474648549578416230, -0.474692557755644280, -0.474736564746141010, -0.474780570549796280, -0.474824575166500560, +-0.474868578596142950, -0.474912580838613930, -0.474956581893803460, -0.475000581761601930, -0.475044580441898510, -0.475088577934583700, -0.475132574239547410, -0.475176569356680070, +-0.475220563285870920, -0.475264556027010400, -0.475308547579988470, -0.475352537944695560, -0.475396527121020870, -0.475440515108854930, -0.475484501908088050, -0.475528487518609540, +-0.475572471940309830, -0.475616455173078930, -0.475660437216807230, -0.475704418071384140, -0.475748397736699910, -0.475792376212644750, -0.475836353499109020, -0.475880329595982030, +-0.475924304503154210, -0.475968278220515630, -0.476012250747956720, -0.476056222085366800, -0.476100192232636330, -0.476144161189655410, -0.476188128956314460, -0.476232095532502790, +-0.476276060918110870, -0.476320025113028790, -0.476363988117147090, -0.476407949930355010, -0.476451910552543050, -0.476495869983601660, -0.476539828223420280, -0.476583785271889270, +-0.476627741128898830, -0.476671695794339430, -0.476715649268100390, -0.476759601550072190, -0.476803552640145010, -0.476847502538209340, -0.476891451244154550, -0.476935398757871110, +-0.476979345079249220, -0.477023290208179300, -0.477067234144550770, -0.477111176888254160, -0.477155118439179630, -0.477199058797217690, -0.477242997962257660, -0.477286935934190190, +-0.477330872712905750, -0.477374808298293760, -0.477418742690244760, -0.477462675888648880, -0.477506607893396660, -0.477550538704377580, -0.477594468321482170, -0.477638396744600570, +-0.477682323973623370, -0.477726250008439930, -0.477770174848940910, -0.477814098495016440, -0.477858020946557100, -0.477901942203452330, -0.477945862265592710, -0.477989781132868440, +-0.478033698805170100, -0.478077615282387130, -0.478121530564410090, -0.478165444651129650, -0.478209357542435210, -0.478253269238217370, -0.478297179738366330, -0.478341089042772730, +-0.478384997151326040, -0.478428904063916860, -0.478472809780435440, -0.478516714300772360, -0.478560617624817110, -0.478604519752460320, -0.478648420683592200, -0.478692320418103450, +-0.478736218955883470, -0.478780116296822990, -0.478824012440812240, -0.478867907387741760, -0.478911801137501200, -0.478955693689981140, -0.478999585045071790, -0.479043475202663880, +-0.479087364162646910, -0.479131251924911570, -0.479175138489348450, -0.479219023855847080, -0.479262908024298160, -0.479306790994591950, -0.479350672766619190, -0.479394553340269370, +-0.479438432715433130, -0.479482310892000830, -0.479526187869863120, -0.479570063648909530, -0.479613938229030810, -0.479657811610117280, -0.479701683792059570, -0.479745554774747280, +-0.479789424558071110, -0.479833293141921360, -0.479877160526188730, -0.479921026710762870, -0.479964891695534410, -0.480008755480394120, -0.480052618065231580, -0.480096479449937440, +-0.480140339634402170, -0.480184198618516360, -0.480228056402169760, -0.480271912985252960, -0.480315768367656380, -0.480359622549270780, -0.480403475529985690, -0.480447327309691970, +-0.480491177888279890, -0.480535027265640290, -0.480578875441662720, -0.480622722416237940, -0.480666568189256400, -0.480710412760608770, -0.480754256130184800, -0.480798098297875120, +-0.480841939263570610, -0.480885779027160840, -0.480929617588536640, -0.480973454947588420, -0.481017291104206930, -0.481061126058281830, -0.481104959809703910, -0.481148792358363550, +-0.481192623704151670, -0.481236453846957790, -0.481280282786672790, -0.481324110523187130, -0.481367937056391530, -0.481411762386175670, -0.481455586512430480, -0.481499409435046270, +-0.481543231153913950, -0.481587051668923130, -0.481630870979964710, -0.481674689086929510, -0.481718505989707220, -0.481762321688188610, -0.481806136182264200, -0.481849949471824910, +-0.481893761556760280, -0.481937572436961280, -0.481981382112318340, -0.482025190582722360, -0.482068997848062950, -0.482112803908231080, -0.482156608763117220, -0.482200412412612240, +-0.482244214856605790, -0.482288016094988840, -0.482331816127651860, -0.482375614954485670, -0.482419412575380120, -0.482463208990225990, -0.482507004198913850, -0.482550798201334620, +-0.482594590997377950, -0.482638382586934870, -0.482682172969896180, -0.482725962146151650, -0.482769750115592260, -0.482813536878108460, -0.482857322433591250, -0.482901106781930320, +-0.482944889923016600, -0.482988671856740660, -0.483032452582993430, -0.483076232101664730, -0.483120010412645410, -0.483163787515826060, -0.483207563411097660, -0.483251338098349910, +-0.483295111577473850, -0.483338883848360050, -0.483382654910899380, -0.483426424764981710, -0.483470193410497960, -0.483513960847339110, -0.483557727075394960, -0.483601492094556500, +-0.483645255904714300, -0.483689018505759400, -0.483732779897581510, -0.483776540080071700, -0.483820299053120520, -0.483864056816619040, -0.483907813370456960, -0.483951568714525380, +-0.483995322848714880, -0.484039075772916440, -0.484082827487019920, -0.484126577990916350, -0.484170327284496330, -0.484214075367650880, -0.484257822240269860, -0.484301567902244270, +-0.484345312353465170, -0.484389055593822390, -0.484432797623206960, -0.484476538441509560, -0.484520278048621190, -0.484564016444431760, -0.484607753628832240, -0.484651489601713340, +-0.484695224362966140, -0.484738957912480510, -0.484782690250147420, -0.484826421375857630, -0.484870151289502230, -0.484913879990970960, -0.484957607480155100, -0.485001333756945150, +-0.485045058821232280, -0.485088782672906340, -0.485132505311858480, -0.485176226737979330, -0.485219946951160050, -0.485263665951290450, -0.485307383738261770, -0.485351100311964930, +-0.485394815672289980, -0.485438529819128000, -0.485482242752369730, -0.485525954471906160, -0.485569664977627380, -0.485613374269424410, -0.485657082347188070, -0.485700789210809340, +-0.485744494860178290, -0.485788199295185960, -0.485831902515723170, -0.485875604521680990, -0.485919305312949410, -0.485963004889419570, -0.486006703250982220, -0.486050400397528500, +-0.486094096328948400, -0.486137791045133050, -0.486181484545973600, -0.486225176831360070, -0.486268867901183570, -0.486312557755334940, -0.486356246393705280, -0.486399933816184630, +-0.486443620022664110, -0.486487305013034610, -0.486530988787187150, -0.486574671345011870, -0.486618352686399910, -0.486662032811242100, -0.486705711719429560, -0.486749389410852380, +-0.486793065885401720, -0.486836741142968380, -0.486880415183443550, -0.486924088006717330, -0.486967759612680910, -0.487011430001225430, -0.487055099172241050, -0.487098767125618890, +-0.487142433861249780, -0.487186099379025020, -0.487229763678834580, -0.487273426760569780, -0.487317088624121380, -0.487360749269380670, -0.487404408696237690, -0.487448066904583640, +-0.487491723894309500, -0.487535379665306410, -0.487579034217464460, -0.487622687550674950, -0.487666339664828700, -0.487709990559817010, -0.487753640235529920, -0.487797288691858790, +-0.487840935928694760, -0.487884581945928040, -0.487928226743449880, -0.487971870321151140, -0.488015512678923120, -0.488059153816655930, -0.488102793734240810, -0.488146432431568740, +-0.488190069908530980, -0.488233706165017660, -0.488277341200920090, -0.488320975016129140, -0.488364607610536130, -0.488408238984031240, -0.488451869136505730, -0.488495498067850590, +-0.488539125777957050, -0.488582752266715330, -0.488626377534016720, -0.488670001579752160, -0.488713624403813000, -0.488757246006089390, -0.488800866386472630, -0.488844485544854160, +-0.488888103481124050, -0.488931720195173670, -0.488975335686894000, -0.489018949956176400, -0.489062563002911010, -0.489106174826989200, -0.489149785428302010, -0.489193394806740680, +-0.489237002962195520, -0.489280609894557790, -0.489324215603718640, -0.489367820089569250, -0.489411423351999940, -0.489455025390902130, -0.489498626206166690, -0.489542225797685080, +-0.489585824165347520, -0.489629421309045410, -0.489673017228670180, -0.489716611924111980, -0.489760205395262220, -0.489803797642011980, -0.489847388664252650, -0.489890978461874400, +-0.489934567034768730, -0.489978154382826660, -0.490021740505939610, -0.490065325403997780, -0.490108909076892640, -0.490152491524515290, -0.490196072746757030, -0.490239652743508230, +-0.490283231514660300, -0.490326809060104290, -0.490370385379731600, -0.490413960473432610, -0.490457534341098730, -0.490501106982621340, -0.490544678397890840, -0.490588248586798670, +-0.490631817549235850, -0.490675385285093860, -0.490718951794263000, -0.490762517076634820, -0.490806081132100340, -0.490849643960550970, -0.490893205561877160, -0.490936765935970350, +-0.490980325082721600, -0.491023883002022430, -0.491067439693763150, -0.491110995157835300, -0.491154549394129950, -0.491198102402538640, -0.491241654182951630, -0.491285204735260550, +-0.491328754059356390, -0.491372302155130780, -0.491415849022474040, -0.491459394661277640, -0.491502939071433160, -0.491546482252830930, -0.491590024205362520, -0.491633564928919020, +-0.491677104423392020, -0.491720642688671830, -0.491764179724650090, -0.491807715531217880, -0.491851250108266750, -0.491894783455687100, -0.491938315573370530, -0.491981846461208180, +-0.492025376119091580, -0.492068904546911160, -0.492112431744558430, -0.492155957711924660, -0.492199482448901380, -0.492243005955379010, -0.492286528231249130, -0.492330049276403340, +-0.492373569090731990, -0.492417087674126730, -0.492460605026478760, -0.492504121147679660, -0.492547636037619860, -0.492591149696191000, -0.492634662123284270, -0.492678173318791210, +-0.492721683282602410, -0.492765192014609330, -0.492808699514703350, -0.492852205782775940, -0.492895710818717640, -0.492939214622420070, -0.492982717193774510, -0.493026218532672480, +-0.493069718639004560, -0.493113217512662290, -0.493156715153537430, -0.493200211561520330, -0.493243706736502750, -0.493287200678375890, -0.493330693387031390, -0.493374184862359840, +-0.493417675104252770, -0.493461164112601490, -0.493504651887297750, -0.493548138428231980, -0.493591623735295800, -0.493635107808380660, -0.493678590647378070, -0.493722072252178620, +-0.493765552622674020, -0.493809031758755510, -0.493852509660314800, -0.493895986327242460, -0.493939461759430150, -0.493982935956769560, -0.494026408919151280, -0.494069880646466950, +-0.494113351138607880, -0.494156820395465880, -0.494200288416931420, -0.494243755202896210, -0.494287220753251650, -0.494330685067889410, -0.494374148146700050, -0.494417609989575350, +-0.494461070596406650, -0.494504529967085600, -0.494547988101502910, -0.494591444999550210, -0.494634900661118870, -0.494678355086100700, -0.494721808274386280, -0.494765260225867310, +-0.494808710940435160, -0.494852160417981630, -0.494895608658397320, -0.494939055661574030, -0.494982501427403470, -0.495025945955776260, -0.495069389246584170, -0.495112831299718610, +-0.495156272115071350, -0.495199711692533070, -0.495243150031995480, -0.495286587133350000, -0.495330022996488480, -0.495373457621301470, -0.495416891007680830, -0.495460323155517970, +-0.495503754064704700, -0.495547183735131620, -0.495590612166690650, -0.495634039359273080, -0.495677465312770850, -0.495720890027074530, -0.495764313502076000, -0.495807735737667070, +-0.495851156733738420, -0.495894576490181930, -0.495937995006888900, -0.495981412283751370, -0.496024828320659860, -0.496068243117506250, -0.496111656674182110, -0.496155068990579150, +-0.496198480066588180, -0.496241889902101000, -0.496285298497009090, -0.496328705851204310, -0.496372111964577370, -0.496415516837020180, -0.496458920468424160, -0.496502322858681230, +-0.496545724007682150, -0.496589123915318730, -0.496632522581482880, -0.496675920006065360, -0.496719316188958040, -0.496762711130052380, -0.496806104829240370, -0.496849497286412760, +-0.496892888501461350, -0.496936278474277680, -0.496979667204753780, -0.497023054692780300, -0.497066440938249140, -0.497109825941051960, -0.497153209701080510, -0.497196592218225710, +-0.497239973492379420, -0.497283353523433220, -0.497326732311278940, -0.497370109855807540, -0.497413486156910830, -0.497456861214480350, -0.497500235028408180, -0.497543607598585010, +-0.497586978924902830, -0.497630349007253560, -0.497673717845528050, -0.497717085439618230, -0.497760451789415750, -0.497803816894812460, -0.497847180755699280, -0.497890543371968140, +-0.497933904743510620, -0.497977264870218760, -0.498020623751983360, -0.498063981388696340, -0.498107337780249400, -0.498150692926534520, -0.498194046827442500, -0.498237399482865380, +-0.498280750892694750, -0.498324101056822680, -0.498367449975139880, -0.498410797647538540, -0.498454144073910530, -0.498497489254146780, -0.498540833188139350, -0.498584175875779800, +-0.498627517316960200, -0.498670857511571420, -0.498714196459505540, -0.498757534160654100, -0.498800870614909240, -0.498844205822161820, -0.498887539782303880, -0.498930872495227110, +-0.498974203960823540, -0.499017534178984090, -0.499060863149600740, -0.499104190872565300, -0.499147517347769740, -0.499190842575104990, -0.499234166554463180, -0.499277489285736290, +-0.499320810768815290, -0.499364131003592340, -0.499407449989958950, -0.499450767727807390, -0.499494084217028510, -0.499537399457514460, -0.499580713449156830, -0.499624026191847870, +-0.499667337685478440, -0.499710647929940630, -0.499753956925126250, -0.499797264670927330, -0.499840571167234900, -0.499883876413941000, -0.499927180410937420, -0.499970483158116320, +-0.500013784655368610, -0.500057084902586380, -0.500100383899661830, -0.500143681646486040, -0.500186978142950990, -0.500230273388948430, -0.500273567384370680, -0.500316860129108480, +-0.500360151623054250, -0.500403441866099640, -0.500446730858136730, -0.500490018599056730, -0.500533305088751600, -0.500576590327113210, -0.500619874314033760, -0.500663157049404230, +-0.500706438533116690, -0.500749718765063250, -0.500792997745135750, -0.500836275473225400, -0.500879551949224400, -0.500922827173024500, -0.500966101144518010, -0.501009373863595790, +-0.501052645330150150, -0.501095915544073290, -0.501139184505256190, -0.501182452213591150, -0.501225718668970030, -0.501268983871285050, -0.501312247820427160, -0.501355510516288570, +-0.501398771958761370, -0.501442032147737530, -0.501485291083108240, -0.501528548764765710, -0.501571805192601810, -0.501615060366508710, -0.501658314286377640, -0.501701566952100890, +-0.501744818363570100, -0.501788068520677700, -0.501831317423314660, -0.501874565071373400, -0.501917811464746120, -0.501961056603323910, -0.502004300486999070, -0.502047543115663460, +-0.502090784489209300, -0.502134024607527870, -0.502177263470511390, -0.502220501078051830, -0.502263737430041270, -0.502306972526371020, -0.502350206366933390, -0.502393438951620140, +-0.502436670280323790, -0.502479900352935330, -0.502523129169347160, -0.502566356729451050, -0.502609583033139520, -0.502652808080303660, -0.502696031870835780, -0.502739254404628190, +-0.502782475681572080, -0.502825695701559770, -0.502868914464483230, -0.502912131970234770, -0.502955348218705580, -0.502998563209788090, -0.503041776943374150, -0.503084989419356200, +-0.503128200637625310, -0.503171410598073910, -0.503214619300594080, -0.503257826745078020, -0.503301032931417040, -0.503344237859503440, -0.503387441529229320, -0.503430643940486870, +-0.503473845093167500, -0.503517044987163540, -0.503560243622366840, -0.503603440998670050, -0.503646637115964250, -0.503689831974141860, -0.503733025573095180, -0.503776217912715650, +-0.503819408992895570, -0.503862598813526910, -0.503905787374502200, -0.503948974675712650, -0.503992160717050550, -0.504035345498408120, -0.504078529019677760, -0.504121711280750670, +-0.504164892281519280, -0.504208072021875680, -0.504251250501712270, -0.504294427720920260, -0.504337603679392290, -0.504380778377020330, -0.504423951813696700, -0.504467123989312930, +-0.504510294903761310, -0.504553464556934280, -0.504596632948723260, -0.504639800079020650, -0.504682965947718550, -0.504726130554709380, -0.504769293899884450, -0.504812455983136400, +-0.504855616804357200, -0.504898776363439270, -0.504941934660274040, -0.504985091694754030, -0.505028247466771220, -0.505071401976218250, -0.505114555222986320, -0.505157707206968070, +-0.505200857928055470, -0.505244007386141170, -0.505287155581116370, -0.505330302512873810, -0.505373448181305810, -0.505416592586303780, -0.505459735727760370, -0.505502877605567560, +-0.505546018219617980, -0.505589157569802940, -0.505632295656014970, -0.505675432478146280, -0.505718568036089390, -0.505761702329735720, -0.505804835358977800, -0.505847967123707720, +-0.505891097623818230, -0.505934226859200530, -0.505977354829747260, -0.506020481535350620, -0.506063606975903140, -0.506106731151296340, -0.506149854061422650, -0.506192975706174720, +-0.506236096085443950, -0.506279215199122890, -0.506322333047103830, -0.506365449629279430, -0.506408564945540870, -0.506451678995781030, -0.506494791779891870, -0.506537903297766160, +-0.506581013549295300, -0.506624122534371950, -0.506667230252888290, -0.506710336704736970, -0.506753441889809310, -0.506796545807998160, -0.506839648459195600, -0.506882749843294290, +-0.506925849960185640, -0.506968948809762510, -0.507012046391916990, -0.507055142706541620, -0.507098237753528140, -0.507141331532768970, -0.507184424044156980, -0.507227515287583360, +-0.507270605262941100, -0.507313693970122270, -0.507356781409019630, -0.507399867579524600, -0.507442952481529930, -0.507486036114927930, -0.507529118479611130, -0.507572199575471170, +-0.507615279402400810, -0.507658357960292130, -0.507701435249037990, -0.507744511268529930, -0.507787586018660480, -0.507830659499322160, -0.507873731710407510, -0.507916802651808160, +-0.507959872323416880, -0.508002940725126200, -0.508046007856827850, -0.508089073718414390, -0.508132138309778330, -0.508175201630812310, -0.508218263681407880, -0.508261324461457780, +-0.508304383970854420, -0.508347442209490460, -0.508390499177257430, -0.508433554874048290, -0.508476609299755130, -0.508519662454270940, -0.508562714337487120, -0.508605764949296550, +-0.508648814289591630, -0.508691862358265020, -0.508734909155208360, -0.508777954680314390, -0.508820998933475880, -0.508864041914584560, -0.508907083623533210, -0.508950124060214000, +-0.508993163224519930, -0.509036201116342620, -0.509079237735574730, -0.509122273082108780, -0.509165307155837520, -0.509208339956652710, -0.509251371484446880, -0.509294401739112780, +-0.509337430720542940, -0.509380458428629220, -0.509423484863264280, -0.509466510024340740, -0.509509533911751130, -0.509552556525387450, -0.509595577865142310, -0.509638597930908270, +-0.509681616722578060, -0.509724634240043550, -0.509767650483197280, -0.509810665451932430, -0.509853679146140440, -0.509896691565714270, -0.509939702710546340, -0.509982712580529630, +-0.510025721175555670, -0.510068728495517430, -0.510111734540307340, -0.510154739309818360, -0.510197742803942140, -0.510240745022571550, -0.510283745965599110, -0.510326745632917580, +-0.510369744024418930, -0.510412741139995910, -0.510455736979540940, -0.510498731542947120, -0.510541724830106070, -0.510584716840910670, -0.510627707575253890, -0.510670697033027480, +-0.510713685214124190, -0.510756672118436780, -0.510799657745858120, -0.510842642096279940, -0.510885625169595130, -0.510928606965696200, -0.510971587484476130, -0.511014566725826790, +-0.511057544689641040, -0.511100521375811300, -0.511143496784230770, -0.511186470914791080, -0.511229443767385220, -0.511272415341905710, -0.511315385638245520, -0.511358354656296530, +-0.511401322395951710, -0.511444288857103910, -0.511487254039645010, -0.511530217943467980, -0.511573180568465350, -0.511616141914530200, -0.511659101981554290, -0.511702060769430700, +-0.511745018278051860, -0.511787974507310950, -0.511830929457099630, -0.511873883127311080, -0.511916835517837730, -0.511959786628572780, -0.512002736459407860, -0.512045685010236170, +-0.512088632280950250, -0.512131578271443180, -0.512174522981606710, -0.512217466411333920, -0.512260408560517910, -0.512303349429050540, -0.512346289016824660, -0.512389227323733150, +-0.512432164349668980, -0.512475100094523910, -0.512518034558191230, -0.512560967740563370, -0.512603899641533410, -0.512646830260993450, -0.512689759598836340, -0.512732687654954830, +-0.512775614429242020, -0.512818539921589770, -0.512861464131891260, -0.512904387060038940, -0.512947308705926090, -0.512990229069444690, -0.513033148150487620, -0.513076065948947610, +-0.513118982464717990, -0.513161897697690380, -0.513204811647758110, -0.513247724314814140, -0.513290635698750550, -0.513333545799460330, -0.513376454616836230, -0.513419362150771330, +-0.513462268401157720, -0.513505173367888370, -0.513548077050856140, -0.513590979449954130, -0.513633880565074310, -0.513676780396109640, -0.513719678942953120, -0.513762576205497810, +-0.513805472183635700, -0.513848366877259770, -0.513891260286263090, -0.513934152410538530, -0.513977043249978170, -0.514019932804475330, -0.514062821073922980, -0.514105708058213210, +-0.514148593757239090, -0.514191478170893610, -0.514234361299069740, -0.514277243141659570, -0.514320123698556400, -0.514363002969652870, -0.514405880954842190, -0.514448757654016430, +-0.514491633067068690, -0.514534507193891930, -0.514577380034379360, -0.514620251588422950, -0.514663121855915780, -0.514705990836750950, -0.514748858530821420, -0.514791724938019390, +-0.514834590058238060, -0.514877453891370740, -0.514920316437309290, -0.514963177695947020, -0.515006037667176900, -0.515048896350892020, -0.515091753746984460, -0.515134609855347540, +-0.515177464675874220, -0.515220318208457480, -0.515263170452989640, -0.515306021409363880, -0.515348871077472960, -0.515391719457210300, -0.515434566548467980, -0.515477412351139310, +-0.515520256865117040, -0.515563100090294490, -0.515605942026563850, -0.515648782673818310, -0.515691622031950850, -0.515734460100854660, -0.515777296880421950, -0.515820132370546030, +-0.515862966571120190, -0.515905799482036520, -0.515948631103188340, -0.515991461434468610, -0.516034290475770650, -0.516077118226986540, -0.516119944688009590, -0.516162769858732770, +-0.516205593739049510, -0.516248416328851770, -0.516291237628033080, -0.516334057636486210, -0.516376876354104670, -0.516419693780780560, -0.516462509916407080, -0.516505324760877520, +-0.516548138314084860, -0.516590950575921530, -0.516633761546280820, -0.516676571225056170, -0.516719379612139650, -0.516762186707424580, -0.516804992510804140, -0.516847797022171650, +-0.516890600241419200, -0.516933402168440300, -0.516976202803127840, -0.517019002145375330, -0.517061800195074860, -0.517104596952119970, -0.517147392416403510, -0.517190186587819010, +-0.517232979466258680, -0.517275771051615820, -0.517318561343783510, -0.517361350342655290, -0.517404138048123240, -0.517446924460080890, -0.517489709578421550, -0.517532493403037640, +-0.517575275933822470, -0.517618057170669000, -0.517660837113470880, -0.517703615762120320, -0.517746393116510610, -0.517789169176534950, -0.517831943942086870, -0.517874717413058460, +-0.517917489589343140, -0.517960260470834210, -0.518003030057425100, -0.518045798349007880, -0.518088565345476200, -0.518131331046723150, -0.518174095452642150, -0.518216858563125490, +-0.518259620378066720, -0.518302380897359250, -0.518345140120895500, -0.518387898048568880, -0.518430654680272500, -0.518473410015899860, -0.518516164055343290, -0.518558916798496310, +-0.518601668245252110, -0.518644418395504010, -0.518687167249144650, -0.518729914806067230, -0.518772661066165040, -0.518815406029331630, -0.518858149695459290, -0.518900892064441570, +-0.518943633136171640, -0.518986372910543060, -0.519029111387448120, -0.519071848566780350, -0.519114584448432950, -0.519157319032299560, -0.519200052318272490, -0.519242784306245260, +-0.519285514996111420, -0.519328244387763370, -0.519370972481094870, -0.519413699275998790, -0.519456424772368860, -0.519499148970097520, -0.519541871869078300, -0.519584593469204490, +-0.519627313770369530, -0.519670032772465820, -0.519712750475387120, -0.519755466879026520, -0.519798181983277540, -0.519840895788032830, -0.519883608293185920, -0.519926319498629890, +-0.519969029404258490, -0.520011738009964030, -0.520054445315640380, -0.520097151321180950, -0.520139856026478280, -0.520182559431425880, -0.520225261535917190, -0.520267962339845620, +-0.520310661843103820, -0.520353360045585410, -0.520396056947183490, -0.520438752547791930, -0.520481446847303020, -0.520524139845610520, -0.520566831542607740, -0.520609521938188210, +-0.520652211032244460, -0.520694898824670240, -0.520737585315358630, -0.520780270504203610, -0.520822954391097490, -0.520865636975933910, -0.520908318258606730, -0.520950998239008260, +-0.520993676917032360, -0.521036354292572330, -0.521079030365521720, -0.521121705135773160, -0.521164378603220290, -0.521207050767756530, -0.521249721629275520, -0.521292391187669790, +-0.521335059442833090, -0.521377726394658850, -0.521420392043040580, -0.521463056387870940, -0.521505719429043670, -0.521548381166452080, -0.521591041599989920, -0.521633700729549840, +-0.521676358555025480, -0.521719015076310240, -0.521761670293297790, -0.521804324205880850, -0.521846976813952980, -0.521889628117408130, -0.521932278116138850, -0.521974926810038880, +-0.522017574199001630, -0.522060220282920760, -0.522102865061688900, -0.522145508535199920, -0.522188150703347230, -0.522230791566024480, -0.522273431123124410, -0.522316069374540780, +-0.522358706320166900, -0.522401341959896740, -0.522443976293622710, -0.522486609321238800, -0.522529241042638430, -0.522571871457715330, -0.522614500566362050, -0.522657128368472670, +-0.522699754863940710, -0.522742380052659050, -0.522785003934521430, -0.522827626509421380, -0.522870247777252550, -0.522912867737907790, -0.522955486391280750, -0.522998103737265070, +-0.523040719775754500, -0.523083334506641790, -0.523125947929820700, -0.523168560045184750, -0.523211170852627800, -0.523253780352042510, -0.523296388543322720, -0.523338995426362090, +-0.523381601001054240, -0.523424205267292050, -0.523466808224969380, -0.523509409873979980, -0.523552010214216710, -0.523594609245573440, -0.523637206967943690, -0.523679803381221220, +-0.523722398485298890, -0.523764992280070560, -0.523807584765429770, -0.523850175941270480, -0.523892765807485230, -0.523935354363968100, -0.523977941610612620, -0.524020527547312650, +-0.524063112173960950, -0.524105695490451500, -0.524148277496677810, -0.524190858192533860, -0.524233437577912300, -0.524276015652707210, -0.524318592416812000, -0.524361167870120770, +-0.524403742012526150, -0.524446314843922230, -0.524488886364202990, -0.524531456573261060, -0.524574025470990520, -0.524616593057284810, -0.524659159332038110, -0.524701724295143060, +-0.524744287946493750, -0.524786850285983820, -0.524829411313507020, -0.524871971028956330, -0.524914529432225720, -0.524957086523208720, -0.524999642301799520, -0.525042196767890660, +-0.525084749921376440, -0.525127301762150280, -0.525169852290106380, -0.525212401505137370, -0.525254949407137350, -0.525297495996000290, -0.525340041271619150, -0.525382585233887920, +-0.525425127882700240, -0.525467669217950070, -0.525510209239530400, -0.525552747947335200, -0.525595285341258100, -0.525637821421193200, -0.525680356187033350, -0.525722889638672640, +-0.525765421776004720, -0.525807952598923540, -0.525850482107322210, -0.525893010301094590, -0.525935537180134420, -0.525978062744335890, -0.526020586993591780, -0.526063109927796150, +-0.526105631546843200, -0.526148151850625690, -0.526190670839037920, -0.526233188511973430, -0.526275704869326290, -0.526318219910989590, -0.526360733636857310, -0.526403246046823200, +-0.526445757140781350, -0.526488266918624710, -0.526530775380247400, -0.526573282525543140, -0.526615788354406140, -0.526658292866729270, -0.526700796062406610, -0.526743297941332010, +-0.526785798503399460, -0.526828297748502150, -0.526870795676534050, -0.526913292287389260, -0.526955787580960950, -0.526998281557143120, -0.527040774215829620, -0.527083265556914650, +-0.527125755580290960, -0.527168244285852960, -0.527210731673494410, -0.527253217743109290, -0.527295702494590900, -0.527338185927833100, -0.527380668042729980, -0.527423148839175520, +-0.527465628317062670, -0.527508106476285880, -0.527550583316738870, -0.527593058838315640, -0.527635533040909490, -0.527678005924414490, -0.527720477488724530, -0.527762947733733670, +-0.527805416659335110, -0.527847884265422950, -0.527890350551891490, -0.527932815518633800, -0.527975279165543990, -0.528017741492516010, -0.528060202499444190, -0.528102662186221370, +-0.528145120552741880, -0.528187577598899560, -0.528230033324588730, -0.528272487729702480, -0.528314940814134990, -0.528357392577780140, -0.528399843020532110, -0.528442292142284220, +-0.528484739942930550, -0.528527186422364960, -0.528569631580481870, -0.528612075417174250, -0.528654517932336530, -0.528696959125862790, -0.528739398997646330, -0.528781837547581460, +-0.528824274775561820, -0.528866710681482060, -0.528909145265235030, -0.528951578526715150, -0.528994010465816290, -0.529036441082432860, -0.529078870376457840, -0.529121298347785760, +-0.529163724996310370, -0.529206150321926080, -0.529248574324525990, -0.529290997004004500, -0.529333418360255600, -0.529375838393173370, -0.529418257102651340, -0.529460674488583470, +-0.529503090550864420, -0.529545505289387260, -0.529587918704046310, -0.529630330794735540, -0.529672741561349360, -0.529715151003780970, -0.529757559121924680, -0.529799965915674460, +-0.529842371384924740, -0.529884775529568700, -0.529927178349500760, -0.529969579844614790, -0.530011980014805320, -0.530054378859965540, -0.530096776379989750, -0.530139172574772060, +-0.530181567444206750, -0.530223960988187250, -0.530266353206607750, -0.530308744099362350, -0.530351133666345560, -0.530393521907450480, -0.530435908822571740, -0.530478294411603430, +-0.530520678674439080, -0.530563061610973110, -0.530605443221099370, -0.530647823504712400, -0.530690202461705620, -0.530732580091973220, -0.530774956395409390, -0.530817331371908560, +-0.530859705021364040, -0.530902077343670230, -0.530944448338721230, -0.530986818006411450, -0.531029186346634320, -0.531071553359284240, -0.531113919044255200, -0.531156283401441720, +-0.531198646430737220, -0.531241008132036120, -0.531283368505232830, -0.531325727550220780, -0.531368085266894390, -0.531410441655147730, -0.531452796714875440, -0.531495150445970730, +-0.531537502848328130, -0.531579853921841820, -0.531622203666406220, -0.531664552081914770, -0.531706899168261860, -0.531749244925341810, -0.531791589353048930, -0.531833932451276750, +-0.531876274219919790, -0.531918614658872020, -0.531960953768028210, -0.532003291547281540, -0.532045627996526770, -0.532087963115658200, -0.532130296904569370, -0.532172629363154790, +-0.532214960491308680, -0.532257290288925430, -0.532299618755898710, -0.532341945892122910, -0.532384271697492250, -0.532426596171901250, -0.532468919315243320, -0.532511241127413220, +-0.532553561608305030, -0.532595880757813170, -0.532638198575831390, -0.532680515062254000, -0.532722830216975310, -0.532765144039889950, -0.532807456530891450, -0.532849767689874240, +-0.532892077516732950, -0.532934386011361120, -0.532976693173653370, -0.533018999003503800, -0.533061303500807160, -0.533103606665456860, -0.533145908497347550, -0.533188208996373540, +-0.533230508162429340, -0.533272805995408380, -0.533315102495205530, -0.533357397661714970, -0.533399691494831130, -0.533441983994447870, -0.533484275160459490, -0.533526564992760520, +-0.533568853491245500, -0.533611140655807950, -0.533653426486342510, -0.533695710982743600, -0.533737994144905640, -0.533780275972722480, -0.533822556466088560, -0.533864835624898610, +-0.533907113449046180, -0.533949389938426000, -0.533991665092932390, -0.534033938912459980, -0.534076211396902310, -0.534118482546154130, -0.534160752360109740, -0.534203020838663780, +-0.534245287981709890, -0.534287553789142940, -0.534329818260857010, -0.534372081396746860, -0.534414343196706220, -0.534456603660629640, -0.534498862788411630, -0.534541120579946740, +-0.534583377035128700, -0.534625632153852280, -0.534667885936012110, -0.534710138381501940, -0.534752389490216310, -0.534794639262049730, -0.534836887696896970, -0.534879134794651550, +-0.534921380555208330, -0.534963624978461730, -0.535005868064306390, -0.535048109812635950, -0.535090350223345280, -0.535132589296328680, -0.535174827031481120, -0.535217063428696020, +-0.535259298487868240, -0.535301532208892210, -0.535343764591662770, -0.535385995636073590, -0.535428225342019280, -0.535470453709394940, -0.535512680738093990, -0.535554906428011400, +-0.535597130779041470, -0.535639353791079190, -0.535681575464018070, -0.535723795797752980, -0.535766014792178450, -0.535808232447189340, -0.535850448762679180, -0.535892663738542830, +-0.535934877374674930, -0.535977089670970240, -0.536019300627322390, -0.536061510243626250, -0.536103718519776340, -0.536145925455667640, -0.536188131051193670, -0.536230335306249310, +-0.536272538220729180, -0.536314739794528040, -0.536356940027539750, -0.536399138919659070, -0.536441336470780850, -0.536483532680798960, -0.536525727549608260, -0.536567921077103270, +-0.536610113263178870, -0.536652304107728680, -0.536694493610647800, -0.536736681771830760, -0.536778868591172300, -0.536821054068566280, -0.536863238203907690, -0.536905420997090930, +-0.536947602448011100, -0.536989782556561820, -0.537031961322638090, -0.537074138746134520, -0.537116314826945880, -0.537158489564966150, -0.537200662960090170, -0.537242835012212820, +-0.537285005721228170, -0.537327175087030870, -0.537369343109515670, -0.537411509788577550, -0.537453675124110240, -0.537495839116008730, -0.537538001764167660, -0.537580163068481890, +-0.537622323028845380, -0.537664481645153130, -0.537706638917299530, -0.537748794845179790, -0.537790949428687770, -0.537833102667718220, -0.537875254562166010, -0.537917405111925980, +-0.537959554316892130, -0.538001702176959420, -0.538043848692022710, -0.538085993861976090, -0.538128137686714410, -0.538170280166132440, -0.538212421300125140, -0.538254561088586490, +-0.538296699531411350, -0.538338836628494470, -0.538380972379730820, -0.538423106785014480, -0.538465239844240330, -0.538507371557302990, -0.538549501924097670, -0.538591630944518230, +-0.538633758618459750, -0.538675884945816860, -0.538718009926484550, -0.538760133560356900, -0.538802255847328880, -0.538844376787295690, -0.538886496380151070, -0.538928614625790230, +-0.538970731524107900, -0.539012847074999080, -0.539054961278357840, -0.539097074134079150, -0.539139185642057760, -0.539181295802188760, -0.539223404614366130, -0.539265512078485050, +-0.539307618194440170, -0.539349722962126690, -0.539391826381438460, -0.539433928452270670, -0.539476029174517980, -0.539518128548075680, -0.539560226572837640, -0.539602323248699060, +-0.539644418575554670, -0.539686512553299690, -0.539728605181827970, -0.539770696461034700, -0.539812786390815090, -0.539854874971063210, -0.539896962201674050, -0.539939048082542560, +-0.539981132613563840, -0.540023215794631860, -0.540065297625641820, -0.540107378106488570, -0.540149457237067200, -0.540191535017271910, -0.540233611446997660, -0.540275686526139440, +-0.540317760254592440, -0.540359832632250630, -0.540401903659009200, -0.540443973334763020, -0.540486041659407280, -0.540528108632836070, -0.540570174254944690, -0.540612238525628120, +-0.540654301444780550, -0.540696363012297290, -0.540738423228073200, -0.540780482092003360, -0.540822539603981860, -0.540864595763904110, -0.540906650571664870, -0.540948704027159330, +-0.540990756130281690, -0.541032806880927140, -0.541074856278990550, -0.541116904324367210, -0.541158951016951220, -0.541200996356637990, -0.541243040343322160, -0.541285082976899030, +-0.541327124257262930, -0.541369164184308920, -0.541411202757932530, -0.541453239978027630, -0.541495275844489640, -0.541537310357213530, -0.541579343516094490, -0.541621375321026610, +-0.541663405771905420, -0.541705434868625660, -0.541747462611082750, -0.541789488999170790, -0.541831514032785070, -0.541873537711820560, -0.541915560036172580, -0.541957581005735320, +-0.541999600620404200, -0.542041618880073960, -0.542083635784640140, -0.542125651333996820, -0.542167665528039410, -0.542209678366662780, -0.542251689849762350, -0.542293699977232310, +-0.542335708748967970, -0.542377716164864850, -0.542419722224816940, -0.542461726928719860, -0.542503730276468370, -0.542545732267957880, -0.542587732903082820, -0.542629732181738380, +-0.542671730103819530, -0.542713726669221800, -0.542755721877839380, -0.542797715729567700, -0.542839708224301610, -0.542881699361936750, -0.542923689142367220, -0.542965677565488410, +-0.543007664631195430, -0.543049650339383680, -0.543091634689947480, -0.543133617682782120, -0.543175599317783140, -0.543217579594844730, -0.543259558513862430, -0.543301536074731310, +-0.543343512277346560, -0.543385487121602730, -0.543427460607395220, -0.543469432734619010, -0.543511403503169510, -0.543553372912941260, -0.543595340963829550, -0.543637307655729480, +-0.543679272988536470, -0.543721236962144920, -0.543763199576450360, -0.543805160831347670, -0.543847120726732580, -0.543889079262499300, -0.543931036438543240, -0.543972992254760030, +-0.544014946711043890, -0.544056899807290440, -0.544098851543394770, -0.544140801919252290, -0.544182750934757430, -0.544224698589805710, -0.544266644884292220, -0.544308589818112590, +-0.544350533391161020, -0.544392475603333150, -0.544434416454524060, -0.544476355944629290, -0.544518294073543240, -0.544560230841161560, -0.544602166247379230, -0.544644100292091870, +-0.544686032975193910, -0.544727964296580770, -0.544769894256148190, -0.544811822853790480, -0.544853750089403290, -0.544895675962881580, -0.544937600474121100, -0.544979523623016270, +-0.545021445409462620, -0.545063365833355460, -0.545105284894590090, -0.545147202593061260, -0.545189118928664400, -0.545231033901294680, -0.545272947510847760, -0.545314859757218160, +-0.545356770640301410, -0.545398680159992600, -0.545440588316187580, -0.545482495108780770, -0.545524400537667600, -0.545566304602743470, -0.545608207303904020, -0.545650108641043570, +-0.545692008614057980, -0.545733907222842650, -0.545775804467292120, -0.545817700347302150, -0.545859594862767920, -0.545901488013585070, -0.545943379799648240, -0.545985270220852860, +-0.546027159277094220, -0.546069046968268190, -0.546110933294269070, -0.546152818254992730, -0.546194701850334250, -0.546236584080189490, -0.546278464944452760, -0.546320344443019910, +-0.546362222575786260, -0.546404099342647440, -0.546445974743497880, -0.546487848778233530, -0.546529721446749830, -0.546571592748941510, -0.546613462684704120, -0.546655331253933170, +-0.546697198456524200, -0.546739064292371960, -0.546780928761371960, -0.546822791863419640, -0.546864653598410740, -0.546906513966239790, -0.546948372966802650, -0.546990230599994520, +-0.547032086865711250, -0.547073941763847270, -0.547115795294298550, -0.547157647456960270, -0.547199498251728310, -0.547241347678497190, -0.547283195737162660, -0.547325042427620590, +-0.547366887749765500, -0.547408731703493130, -0.547450574288699030, -0.547492415505278830, -0.547534255353127270, -0.547576093832140010, -0.547617930942212450, -0.547659766683240570, +-0.547701601055118890, -0.547743434057743170, -0.547785265691008830, -0.547827095954811720, -0.547868924849046480, -0.547910752373608980, -0.547952578528394520, -0.547994403313299070, +-0.548036226728217170, -0.548078048773044780, -0.548119869447677210, -0.548161688752010430, -0.548203506685938980, -0.548245323249358710, -0.548287138442165590, -0.548328952264254270, +-0.548370764715520490, -0.548412575795859890, -0.548454385505168120, -0.548496193843340030, -0.548538000810271490, -0.548579806405858020, -0.548621610629995260, -0.548663413482578190, +-0.548705214963502550, -0.548747015072663880, -0.548788813809958140, -0.548830611175279870, -0.548872407168525140, -0.548914201789589380, -0.548955995038368450, -0.548997786914757200, +-0.549039577418651390, -0.549081366549947100, -0.549123154308539090, -0.549164940694323090, -0.549206725707194750, -0.549248509347049940, -0.549290291613783620, -0.549332072507291440, +-0.549373852027469130, -0.549415630174212470, -0.549457406947416520, -0.549499182346976920, -0.549540956372789440, -0.549582729024749920, -0.549624500302753230, -0.549666270206695230, +-0.549708038736471560, -0.549749805891978190, -0.549791571673109990, -0.549833336079762810, -0.549875099111832630, -0.549916860769214420, -0.549958621051803930, -0.550000379959497020, +-0.550042137492189440, -0.550083893649776170, -0.550125648432153170, -0.550167401839216090, -0.550209153870860780, -0.550250904526982330, -0.550292653807476500, -0.550334401712239130, +-0.550376148241166100, -0.550417893394152260, -0.550459637171093810, -0.550501379571886160, -0.550543120596425520, -0.550584860244606620, -0.550626598516325670, -0.550668335411478530, +-0.550710070929960160, -0.550751805071666660, -0.550793537836493650, -0.550835269224337120, -0.550876999235092150, -0.550918727868654590, -0.550960455124920200, -0.551002181003785060, +-0.551043905505144150, -0.551085628628893430, -0.551127350374928550, -0.551169070743145810, -0.551210789733439950, -0.551252507345707190, -0.551294223579843030, -0.551335938435743800, +-0.551377651913304350, -0.551419364012420750, -0.551461074732988670, -0.551502784074904380, -0.551544492038062660, -0.551586198622359800, -0.551627903827691780, -0.551669607653953560, +-0.551711310101041460, -0.551753011168851000, -0.551794710857278380, -0.551836409166218570, -0.551878106095567870, -0.551919801645221810, -0.551961495815076590, -0.552003188605027280, +-0.552044880014970100, -0.552086570044800660, -0.552128258694415060, -0.552169945963708610, -0.552211631852577160, -0.552253316360916680, -0.552294999488623370, -0.552336681235592100, +-0.552378361601719160, -0.552420040586900640, -0.552461718191031630, -0.552503394414008420, -0.552545069255726660, -0.552586742716082550, -0.552628414794971270, -0.552670085492289020, +-0.552711754807931440, -0.552753422741794950, -0.552795089293774410, -0.552836754463766230, -0.552878418251666170, -0.552920080657370420, -0.552961741680774050, -0.553003401321773390, +-0.553045059580264180, -0.553086716456142710, -0.553128371949304090, -0.553170026059644600, -0.553211678787060350, -0.553253330131446510, -0.553294980092699400, -0.553336628670714760, +-0.553378275865389010, -0.553419921676617130, -0.553461566104295530, -0.553503209148319960, -0.553544850808586730, -0.553586491084991030, -0.553628129977429050, -0.553669767485796770, +-0.553711403609990490, -0.553753038349905190, -0.553794671705437500, -0.553836303676482960, -0.553877934262938080, -0.553919563464698060, -0.553961191281659100, -0.554002817713717070, +-0.554044442760768470, -0.554086066422708410, -0.554127688699433070, -0.554169309590838990, -0.554210929096821240, -0.554252547217276130, -0.554294163952099740, -0.554335779301188160, +-0.554377393264436910, -0.554419005841742090, -0.554460617032999760, -0.554502226838106350, -0.554543835256956940, -0.554585442289447840, -0.554627047935475240, -0.554668652194935440, +-0.554710255067723530, -0.554751856553736040, -0.554793456652868940, -0.554835055365018540, -0.554876652690080130, -0.554918248627950030, -0.554959843178524760, -0.555001436341699410, +-0.555043028117370610, -0.555084618505434110, -0.555126207505786560, -0.555167795118323040, -0.555209381342940070, -0.555250966179533620, -0.555292549628000120, -0.555334131688234870, +-0.555375712360134280, -0.555417291643594440, -0.555458869538511760, -0.555500446044781440, -0.555542021162300110, -0.555583594890963760, -0.555625167230668680, -0.555666738181310400, +-0.555708307742785230, -0.555749875914989700, -0.555791442697818990, -0.555833008091169760, -0.555874572094938070, -0.555916134709020240, -0.555957695933311680, -0.555999255767708920, +-0.556040814212108050, -0.556082371266405470, -0.556123926930496610, -0.556165481204278000, -0.556207034087645600, -0.556248585580496060, -0.556290135682724560, -0.556331684394227870, +-0.556373231714901830, -0.556414777644643200, -0.556456322183347170, -0.556497865330910390, -0.556539407087229270, -0.556580947452199330, -0.556622486425716990, -0.556664024007678340, +-0.556705560197980120, -0.556747094996517530, -0.556788628403187320, -0.556830160417885470, -0.556871691040508600, -0.556913220270952140, -0.556954748109112610, -0.556996274554886210, +-0.557037799608169570, -0.557079323268858010, -0.557120845536848150, -0.557162366412036090, -0.557203885894318570, -0.557245403983591010, -0.557286920679749830, -0.557328435982691440, +-0.557369949892312260, -0.557411462408507810, -0.557452973531174840, -0.557494483260209670, -0.557535991595508040, -0.557577498536966360, -0.557619004084480950, -0.557660508237948330, +-0.557702010997264130, -0.557743512362324890, -0.557785012333026910, -0.557826510909266830, -0.557868008090939950, -0.557909503877943140, -0.557950998270172470, -0.557992491267524810, +-0.558033982869895470, -0.558075473077181190, -0.558116961889278280, -0.558158449306083270, -0.558199935327491790, -0.558241419953400490, -0.558282903183705990, -0.558324385018303840, +-0.558365865457090770, -0.558407344499962990, -0.558448822146817240, -0.558490298397549050, -0.558531773252055160, -0.558573246710231790, -0.558614718771975770, -0.558656189437182430, +-0.558697658705748720, -0.558739126577570850, -0.558780593052545570, -0.558822058130568400, -0.558863521811536090, -0.558904984095344950, -0.558946444981891720, -0.558987904471071940, +-0.559029362562782570, -0.559070819256920040, -0.559112274553380080, -0.559153728452059460, -0.559195180952854590, -0.559236632055662100, -0.559278081760377630, -0.559319530066897940, +-0.559360976975119550, -0.559402422484938990, -0.559443866596252000, -0.559485309308955350, -0.559526750622945430, -0.559568190538118900, -0.559609629054371730, -0.559651066171600320, +-0.559692501889701320, -0.559733936208571480, -0.559775369128106330, -0.559816800648202830, -0.559858230768757290, -0.559899659489666580, -0.559941086810826330, -0.559982512732133290, +-0.560023937253484430, -0.560065360374775390, -0.560106782095902810, -0.560148202416763440, -0.560189621337253810, -0.560231038857269770, -0.560272454976708190, -0.560313869695465480, +-0.560355283013438400, -0.560396694930522800, -0.560438105446615430, -0.560479514561612820, -0.560520922275411730, -0.560562328587908000, -0.560603733498998500, -0.560645137008579650, +-0.560686539116548310, -0.560727939822800230, -0.560769339127232260, -0.560810737029741380, -0.560852133530223340, -0.560893528628574890, -0.560934922324692660, -0.560976314618473420, +-0.561017705509813110, -0.561059094998608510, -0.561100483084756130, -0.561141869768152950, -0.561183255048694710, -0.561224638926278390, -0.561266021400800400, -0.561307402472157820, +-0.561348782140246190, -0.561390160404962810, -0.561431537266203870, -0.561472912723866570, -0.561514286777846540, -0.561555659428040870, -0.561597030674346300, -0.561638400516658920, +-0.561679768954875370, -0.561721135988892510, -0.561762501618607190, -0.561803865843915280, -0.561845228664713650, -0.561886590080898920, -0.561927950092368180, -0.561969308699017070, +-0.562010665900742780, -0.562052021697441840, -0.562093376089011110, -0.562134729075346670, -0.562176080656345390, -0.562217430831903900, -0.562258779601919170, -0.562300126966287170, +-0.562341472924904770, -0.562382817477669160, -0.562424160624476090, -0.562465502365222640, -0.562506842699805330, -0.562548181628121370, -0.562589519150066610, -0.562630855265538020, +-0.562672189974432360, -0.562713523276646480, -0.562754855172076460, -0.562796185660619400, -0.562837514742171810, -0.562878842416630780, -0.562920168683892270, -0.562961493543853390, +-0.563002816996410640, -0.563044139041461330, -0.563085459678901330, -0.563126778908627610, -0.563168096730537030, -0.563209413144526440, -0.563250728150492040, -0.563292041748330810, +-0.563333353937939930, -0.563374664719215160, -0.563415974092053800, -0.563457282056352480, -0.563498588612008300, -0.563539893758917330, -0.563581197496976550, -0.563622499826082920, +-0.563663800746133310, -0.563705100257023810, -0.563746398358651590, -0.563787695050913420, -0.563828990333706260, -0.563870284206926310, -0.563911576670470760, -0.563952867724236140, +-0.563994157368119750, -0.564035445602017570, -0.564076732425826900, -0.564118017839444600, -0.564159301842766970, -0.564200584435691100, -0.564241865618113740, -0.564283145389932180, +-0.564324423751042300, -0.564365700701341290, -0.564406976240726110, -0.564448250369093850, -0.564489523086340590, -0.564530794392363640, -0.564572064287059530, -0.564613332770325660, +-0.564654599842058120, -0.564695865502154120, -0.564737129750510490, -0.564778392587024340, -0.564819654011591730, -0.564860914024110090, -0.564902172624476620, -0.564943429812587270, +-0.564984685588339360, -0.565025939951629640, -0.565067192902355520, -0.565108444440413080, -0.565149694565699520, -0.565190943278111700, -0.565232190577546810, -0.565273436463901160, +-0.565314680937071930, -0.565355923996956000, -0.565397165643450660, -0.565438405876452000, -0.565479644695857320, -0.565520882101563480, -0.565562118093467790, -0.565603352671466550, +-0.565644585835456850, -0.565685817585335760, -0.565727047921000370, -0.565768276842347100, -0.565809504349273130, -0.565850730441675780, -0.565891955119451120, -0.565933178382496680, +-0.565974400230709220, -0.566015620663986250, -0.566056839682223760, -0.566098057285319150, -0.566139273473169500, -0.566180488245671910, -0.566221701602722780, -0.566262913544219430, +-0.566304124070058810, -0.566345333180138240, -0.566386540874353920, -0.566427747152603240, -0.566468952014783200, -0.566510155460791200, -0.566551357490523430, -0.566592558103877320, +-0.566633757300750050, -0.566674955081038160, -0.566716151444638830, -0.566757346391449040, -0.566798539921366310, -0.566839732034286840, -0.566880922730108150, -0.566922112008727000, +-0.566963299870041020, -0.567004486313946400, -0.567045671340340560, -0.567086854949120590, -0.567128037140183780, -0.567169217913426560, -0.567210397268746340, -0.567251575206040080, +-0.567292751725205210, -0.567333926826138150, -0.567375100508736190, -0.567416272772896970, -0.567457443618516580, -0.567498613045492650, -0.567539781053722160, -0.567580947643102630, +-0.567622112813530370, -0.567663276564902790, -0.567704438897116970, -0.567745599810070440, -0.567786759303659630, -0.567827917377781820, -0.567869074032334330, -0.567910229267214460, +-0.567951383082318630, -0.567992535477544360, -0.568033686452788730, -0.568074836007949280, -0.568115984142922300, -0.568157130857605440, -0.568198276151896110, -0.568239420025690720, +-0.568280562478886810, -0.568321703511381450, -0.568362843123072170, -0.568403981313855500, -0.568445118083628850, -0.568486253432289310, -0.568527387359734630, -0.568568519865861100, +-0.568609650950566260, -0.568650780613747190, -0.568691908855301630, -0.568733035675125900, -0.568774161073117620, -0.568815285049173890, -0.568856407603192340, -0.568897528735069380, +-0.568938648444702650, -0.568979766731989240, -0.569020883596826900, -0.569061999039111810, -0.569103113058741840, -0.569144225655614400, -0.569185336829626130, -0.569226446580674450, +-0.569267554908656550, -0.569308661813470280, -0.569349767295011970, -0.569390871353179120, -0.569431973987869270, -0.569473075198979720, -0.569514174986407110, -0.569555273350049180, +-0.569596370289802920, -0.569637465805566180, -0.569678559897235480, -0.569719652564708250, -0.569760743807882000, -0.569801833626654150, -0.569842922020921460, -0.569884008990581340, +-0.569925094535531640, -0.569966178655668900, -0.570007261350890640, -0.570048342621094160, -0.570089422466177220, -0.570130500886036450, -0.570171577880569380, -0.570212653449673310, +-0.570253727593246110, -0.570294800311184070, -0.570335871603385170, -0.570376941469746490, -0.570418009910165890, -0.570459076924539790, -0.570500142512766150, -0.570541206674742060, +-0.570582269410365270, -0.570623330719532530, -0.570664390602141470, -0.570705449058089730, -0.570746506087274060, -0.570787561689592100, -0.570828615864941270, -0.570869668613219190, +-0.570910719934322630, -0.570951769828149210, -0.570992818294596470, -0.571033865333562040, -0.571074910944942450, -0.571115955128635670, -0.571156997884539000, -0.571198039212550190, +-0.571239079112566000, -0.571280117584484050, -0.571321154628201770, -0.571362190243617010, -0.571403224430626410, -0.571444257189127720, -0.571485288519018360, -0.571526318420196300, +-0.571567346892557950, -0.571608373936001170, -0.571649399550423930, -0.571690423735722760, -0.571731446491795640, -0.571772467818539850, -0.571813487715853160, -0.571854506183632540, +-0.571895523221775500, -0.571936538830179810, -0.571977553008742980, -0.572018565757361990, -0.572059577075934580, -0.572100586964358280, -0.572141595422530850, -0.572182602450349020, +-0.572223608047710660, -0.572264612214513410, -0.572305614950654910, -0.572346616256032000, -0.572387616130542560, -0.572428614574084450, -0.572469611586554410, -0.572510607167850290, +-0.572551601317869750, -0.572592594036510530, -0.572633585323669480, -0.572674575179244470, -0.572715563603133030, -0.572756550595233000, -0.572797536155441380, -0.572838520283655780, +-0.572879502979773860, -0.572920484243693570, -0.572961464075311790, -0.573002442474526250, -0.573043419441234600, -0.573084394975334810, -0.573125369076723730, -0.573166341745299120, +-0.573207312980959060, -0.573248282783600400, -0.573289251153120900, -0.573330218089418420, -0.573371183592390700, -0.573412147661934600, -0.573453110297948210, -0.573494071500329050, +-0.573535031268975090, -0.573575989603783090, -0.573616946504651230, -0.573657901971476920, -0.573698856004158260, -0.573739808602591990, -0.573780759766676310, -0.573821709496308730, +-0.573862657791387230, -0.573903604651808670, -0.573944550077471140, -0.573985494068272260, -0.574026436624110010, -0.574067377744881260, -0.574108317430484070, -0.574149255680816540, +-0.574190192495775410, -0.574231127875258870, -0.574272061819164460, -0.574312994327390250, -0.574353925399833210, -0.574394855036391320, -0.574435783236962320, -0.574476710001444290, +-0.574517635329733990, -0.574558559221729710, -0.574599481677328990, -0.574640402696429910, -0.574681322278929540, -0.574722240424725750, -0.574763157133716400, -0.574804072405799560, +-0.574844986240872210, -0.574885898638832330, -0.574926809599578090, -0.574967719123006480, -0.575008627209015470, -0.575049533857503010, -0.575090439068366990, -0.575131342841504580, +-0.575172245176813760, -0.575213146074192380, -0.575254045533538430, -0.575294943554749080, -0.575335840137722320, -0.575376735282356000, -0.575417628988548200, -0.575458521256195900, +-0.575499412085197390, -0.575540301475450320, -0.575581189426852880, -0.575622075939302040, -0.575662961012695980, -0.575703844646933030, -0.575744726841910030, -0.575785607597525170, +-0.575826486913676330, -0.575867364790261570, -0.575908241227178100, -0.575949116224323990, -0.575989989781597100, -0.576030861898895630, -0.576071732576116660, -0.576112601813158380, +-0.576153469609918530, -0.576194335966295320, -0.576235200882186050, -0.576276064357488680, -0.576316926392101190, -0.576357786985921660, -0.576398646138847390, -0.576439503850776470, +-0.576480360121607190, -0.576521214951236650, -0.576562068339563030, -0.576602920286484190, -0.576643770791898550, -0.576684619855702960, -0.576725467477795960, -0.576766313658075180, +-0.576807158396439150, -0.576848001692784720, -0.576888843547010310, -0.576929683959013780, -0.576970522928693440, -0.577011360455946360, -0.577052196540670970, -0.577093031182765000, +-0.577133864382126880, -0.577174696138653800, -0.577215526452243830, -0.577256355322795180, -0.577297182750205920, -0.577338008734373350, -0.577378833275195790, -0.577419656372571420, +-0.577460478026397660, -0.577501298236572590, -0.577542117002994400, -0.577582934325561180, -0.577623750204170340, -0.577664564638720070, -0.577705377629108450, -0.577746189175233680, +-0.577786999276993170, -0.577827807934285010, -0.577868615147007490, -0.577909420915058700, -0.577950225238336060, -0.577991028116737750, -0.578031829550161970, -0.578072629538506910, +-0.578113428081669990, -0.578154225179549400, -0.578195020832043660, -0.578235815039050080, -0.578276607800466860, -0.578317399116192180, -0.578358188986124340, -0.578398977410160660, +-0.578439764388199550, -0.578480549920138980, -0.578521334005877460, -0.578562116645312210, -0.578602897838341730, -0.578643677584863900, -0.578684455884777350, -0.578725232737979270, +-0.578766008144368070, -0.578806782103841840, -0.578847554616299000, -0.578888325681636950, -0.578929095299754120, -0.578969863470548910, -0.579010630193918630, -0.579051395469761810, +-0.579092159297976530, -0.579132921678461090, -0.579173682611113130, -0.579214442095830840, -0.579255200132512530, -0.579295956721056600, -0.579336711861360380, -0.579377465553322370, +-0.579418217796840660, -0.579458968591813780, -0.579499717938139150, -0.579540465835715280, -0.579581212284440150, -0.579621957284212400, -0.579662700834929320, -0.579703442936489570, +-0.579744183588791210, -0.579784922791732770, -0.579825660545211670, -0.579866396849126330, -0.579907131703375380, -0.579947865107856340, -0.579988597062467530, -0.580029327567107230, +-0.580070056621673990, -0.580110784226065320, -0.580151510380179650, -0.580192235083915150, -0.580232958337170480, -0.580273680139843040, -0.580314400491831360, -0.580355119393033750, +-0.580395836843348610, -0.580436552842673590, -0.580477267390907210, -0.580517980487947560, -0.580558692133693380, -0.580599402328042190, -0.580640111070892420, -0.580680818362142690, +-0.580721524201690650, -0.580762228589434710, -0.580802931525273180, -0.580843633009104800, -0.580884333040826870, -0.580925031620338150, -0.580965728747536820, -0.581006424422321640, +-0.581047118644589910, -0.581087811414240480, -0.581128502731171450, -0.581169192595281550, -0.581209881006468310, -0.581250567964630370, -0.581291253469665930, -0.581331937521473830, +-0.581372620119951500, -0.581413301264997570, -0.581453980956510800, -0.581494659194388700, -0.581535335978530020, -0.581576011308832850, -0.581616685185196160, -0.581657357607517360, +-0.581698028575695080, -0.581738698089627860, -0.581779366149214110, -0.581820032754351680, -0.581860697904939220, -0.581901361600874910, -0.581942023842057620, -0.581982684628384870, +-0.582023343959755410, -0.582064001836067550, -0.582104658257220130, -0.582145313223110690, -0.582185966733637870, -0.582226618788700630, -0.582267269388196400, -0.582307918532024020, +-0.582348566220081910, -0.582389212452268600, -0.582429857228482060, -0.582470500548620710, -0.582511142412583280, -0.582551782820268200, -0.582592421771573440, -0.582633059266397520, +-0.582673695304638970, -0.582714329886196540, -0.582754963010967960, -0.582795594678852000, -0.582836224889746960, -0.582876853643551800, -0.582917480940164160, -0.582958106779482790, +-0.582998731161406100, -0.583039354085832960, -0.583079975552661110, -0.583120595561789300, -0.583161214113116390, -0.583201831206540120, -0.583242446841959140, -0.583283061019272190, +-0.583323673738377790, -0.583364284999174030, -0.583404894801559440, -0.583445503145432640, -0.583486110030692400, -0.583526715457236560, -0.583567319424963980, -0.583607921933773090, +-0.583648522983562620, -0.583689122574230670, -0.583729720705675750, -0.583770317377796610, -0.583810912590492110, -0.583851506343659900, -0.583892098637198930, -0.583932689471007960, +-0.583973278844985070, -0.584013866759028890, -0.584054453213038060, -0.584095038206911440, -0.584135621740547010, -0.584176203813843390, -0.584216784426699220, -0.584257363579013590, +-0.584297941270684130, -0.584338517501609700, -0.584379092271689160, -0.584419665580821150, -0.584460237428903630, -0.584500807815835470, -0.584541376741515410, -0.584581944205842200, +-0.584622510208713700, -0.584663074750028990, -0.584703637829687040, -0.584744199447585490, -0.584784759603623530, -0.584825318297699680, -0.584865875529712810, -0.584906431299560990, +-0.584946985607142980, -0.584987538452357620, -0.585028089835103680, -0.585068639755279230, -0.585109188212783130, -0.585149735207514120, -0.585190280739371070, -0.585230824808252060, +-0.585271367414055830, -0.585311908556681250, -0.585352448236027280, -0.585392986451991890, -0.585433523204473950, -0.585474058493372200, -0.585514592318585710, -0.585555124680012360, +-0.585595655577551110, -0.585636185011101150, -0.585676712980560450, -0.585717239485827880, -0.585757764526802170, -0.585798288103382530, -0.585838810215466690, -0.585879330862953960, +-0.585919850045742760, -0.585960367763732390, -0.586000884016820710, -0.586041398804906800, -0.586081912127889400, -0.586122423985667610, -0.586162934378139380, -0.586203443305203910, +-0.586243950766759720, -0.586284456762706020, -0.586324961292940870, -0.586365464357363250, -0.586405965955872350, -0.586446466088366150, -0.586486964754743820, -0.586527461954904130, +-0.586567957688746030, -0.586608451956167730, -0.586648944757068300, -0.586689436091346610, -0.586729925958901610, -0.586770414359631400, -0.586810901293435160, -0.586851386760211650, +-0.586891870759860160, -0.586932353292278440, -0.586972834357366020, -0.587013313955021430, -0.587053792085143860, -0.587094268747631600, -0.587134743942383520, -0.587175217669299030, +-0.587215689928276110, -0.587256160719213940, -0.587296630042011380, -0.587337097896567630, -0.587377564282780760, -0.587418029200549970, -0.587458492649774120, -0.587498954630352400, +-0.587539415142182890, -0.587579874185164890, -0.587620331759197260, -0.587660787864179080, -0.587701242500008550, -0.587741695666584960, -0.587782147363807070, -0.587822597591574290, +-0.587863046349784590, -0.587903493638337270, -0.587943939457131530, -0.587984383806065660, -0.588024826685038860, -0.588065268093949880, -0.588105708032698130, -0.588146146501181800, +-0.588186583499300090, -0.588227019026951850, -0.588267453084036500, -0.588307885670452110, -0.588348316786098110, -0.588388746430873240, -0.588429174604676810, -0.588469601307407110, +-0.588510026538963450, -0.588550450299244690, -0.588590872588150240, -0.588631293405578180, -0.588671712751427930, -0.588712130625598350, -0.588752547027988850, -0.588792961958497510, +-0.588833375417023850, -0.588873787403467190, -0.588914197917725590, -0.588954606959698480, -0.588995014529284930, -0.589035420626384140, -0.589075825250894520, -0.589116228402715270, +-0.589156630081745460, -0.589197030287884500, -0.589237429021030490, -0.589277826281083050, -0.589318222067940930, -0.589358616381503660, -0.589399009221669430, -0.589439400588337770, +-0.589479790481407530, -0.589520178900778240, -0.589560565846348080, -0.589600951318016490, -0.589641335315682970, -0.589681717839245720, -0.589722098888604160, -0.589762478463657370, +-0.589802856564304760, -0.589843233190444630, -0.589883608341976400, -0.589923982018799140, -0.589964354220812280, -0.590004724947914230, -0.590045094200004280, -0.590085461976981640, +-0.590125828278745710, -0.590166193105194910, -0.590206556456228550, -0.590246918331745810, -0.590287278731646210, -0.590327637655827960, -0.590367995104190690, -0.590408351076633700, +-0.590448705573055510, -0.590489058593355540, -0.590529410137432990, -0.590569760205187260, -0.590610108796516650, -0.590650455911320930, -0.590690801549499040, -0.590731145710950420, +-0.590771488395573700, -0.590811829603268170, -0.590852169333933030, -0.590892507587467920, -0.590932844363771140, -0.590973179662742210, -0.591013513484280440, -0.591053845828285130, +-0.591094176694654920, -0.591134506083289210, -0.591174833994087320, -0.591215160426948550, -0.591255485381771640, -0.591295808858456010, -0.591336130856901180, -0.591376451377005790, +-0.591416770418669140, -0.591457087981790530, -0.591497404066269720, -0.591537718672004890, -0.591578031798895900, -0.591618343446841720, -0.591658653615741990, -0.591698962305495460, +-0.591739269516001310, -0.591779575247159180, -0.591819879498868380, -0.591860182271027440, -0.591900483563536190, -0.591940783376293630, -0.591981081709199500, -0.592021378562152420, +-0.592061673935051710, -0.592101967827797340, -0.592142260240287600, -0.592182551172422130, -0.592222840624100360, -0.592263128595221900, -0.592303415085685180, -0.592343700095390060, +-0.592383983624235500, -0.592424265672121480, -0.592464546238946400, -0.592504825324609910, -0.592545102929011410, -0.592585379052050440, -0.592625653693625740, -0.592665926853636950, +-0.592706198531983250, -0.592746468728564400, -0.592786737443279140, -0.592827004676026890, -0.592867270426707500, -0.592907534695219730, -0.592947797481462980, -0.592988058785336780, +-0.593028318606740770, -0.593068576945573690, -0.593108833801735070, -0.593149089175124430, -0.593189343065641310, -0.593229595473184550, -0.593269846397653900, -0.593310095838948450, +-0.593350343796968270, -0.593390590271611780, -0.593430835262778840, -0.593471078770368870, -0.593511320794281480, -0.593551561334415450, -0.593591800390670610, -0.593632037962946500, +-0.593672274051141980, -0.593712508655156790, -0.593752741774890350, -0.593792973410242400, -0.593833203561111580, -0.593873432227397860, -0.593913659409000540, -0.593953885105819370, +-0.593994109317753200, -0.594034332044701690, -0.594074553286564330, -0.594114773043241010, -0.594154991314630450, -0.594195208100632310, -0.594235423401146210, -0.594275637216071910, +-0.594315849545308140, -0.594356060388754660, -0.594396269746311100, -0.594436477617877320, -0.594476684003351850, -0.594516888902634770, -0.594557092315625700, -0.594597294242223630, +-0.594637494682328400, -0.594677693635839330, -0.594717891102656380, -0.594758087082678410, -0.594798281575805170, -0.594838474581936170, -0.594878666100971510, -0.594918856132809700, +-0.594959044677350720, -0.594999231734494200, -0.595039417304140010, -0.595079601386186760, -0.595119783980534670, -0.595159965087083020, -0.595200144705731900, -0.595240322836379950, +-0.595280499478927250, -0.595320674633273650, -0.595360848299318010, -0.595401020476960310, -0.595441191166099950, -0.595481360366637010, -0.595521528078470360, -0.595561694301499860, +-0.595601859035625130, -0.595642022280746140, -0.595682184036761650, -0.595722344303571740, -0.595762503081076030, -0.595802660369174290, -0.595842816167765690, -0.595882970476749980, +-0.595923123296026810, -0.595963274625496250, -0.596003424465057160, -0.596043572814609400, -0.596083719674053160, -0.596123865043287180, -0.596164008922211660, -0.596204151310726020, +-0.596244292208730430, -0.596284431616123660, -0.596324569532805880, -0.596364705958676740, -0.596404840893636100, -0.596444974337583030, -0.596485106290417510, -0.596525236752039170, +-0.596565365722348200, -0.596605493201243340, -0.596645619188624910, -0.596685743684392310, -0.596725866688445740, -0.596765988200684160, -0.596806108221007550, -0.596846226749315760, +-0.596886343785508640, -0.596926459329485400, -0.596966573381146000, -0.597006685940390520, -0.597046797007117940, -0.597086906581228430, -0.597127014662621640, -0.597167121251197640, +-0.597207226346855410, -0.597247329949495250, -0.597287432059016690, -0.597327532675319910, -0.597367631798303990, -0.597407729427868910, -0.597447825563914630, -0.597487920206341010, +-0.597528013355047350, -0.597568105009933510, -0.597608195170899580, -0.597648283837845410, -0.597688371010670180, -0.597728456689273990, -0.597768540873557130, -0.597808623563418460, +-0.597848704758758290, -0.597888784459476350, -0.597928862665472740, -0.597968939376646750, -0.598009014592898240, -0.598049088314127290, -0.598089160540233980, -0.598129231271117390, +-0.598169300506677710, -0.598209368246814810, -0.598249434491428870, -0.598289499240418960, -0.598329562493685300, -0.598369624251127720, -0.598409684512646530, -0.598449743278140600, +-0.598489800547510440, -0.598529856320656140, -0.598569910597476770, -0.598609963377872640, -0.598650014661743610, -0.598690064448989980, -0.598730112739510710, -0.598770159533206230, +-0.598810204829976270, -0.598850248629721250, -0.598890290932340250, -0.598930331737733470, -0.598970371045800860, -0.599010408856442740, -0.599050445169558190, -0.599090479985047500, +-0.599130513302810640, -0.599170545122747920, -0.599210575444758420, -0.599250604268742440, -0.599290631594600390, -0.599330657422231350, -0.599370681751535740, -0.599410704582413300, +-0.599450725914764560, -0.599490745748488600, -0.599530764083485820, -0.599570780919656100, -0.599610796256899840, -0.599650810095116120, -0.599690822434205460, -0.599730833274067730, +-0.599770842614603230, -0.599810850455711250, -0.599850856797292220, -0.599890861639246100, -0.599930864981473080, -0.599970866823872570, -0.600010867166344890, -0.600050866008789980, +-0.600090863351108390, -0.600130859193199200, -0.600170853534962910, -0.600210846376299730, -0.600250837717109190, -0.600290827557291570, -0.600330815896746860, -0.600370802735375350, +-0.600410788073076570, -0.600450771909750820, -0.600490754245298190, -0.600530735079618960, -0.600570714412612560, -0.600610692244179400, -0.600650668574219450, -0.600690643402633230, +-0.600730616729320040, -0.600770588554180310, -0.600810558877114100, -0.600850527698021940, -0.600890495016802920, -0.600930460833357770, -0.600970425147586810, -0.601010387959389440, +-0.601050349268666180, -0.601090309075316910, -0.601130267379242240, -0.601170224180341610, -0.601210179478515410, -0.601250133273663720, -0.601290085565687080, -0.601330036354484900, +-0.601369985639957580, -0.601409933422005330, -0.601449879700528540, -0.601489824475426760, -0.601529767746600390, -0.601569709513949610, -0.601609649777374970, -0.601649588536775750, +-0.601689525792052590, -0.601729461543106030, -0.601769395789835460, -0.601809328532141310, -0.601849259769923870, -0.601889189503083680, -0.601929117731520140, -0.601969044455133770, +-0.602008969673824890, -0.602048893387493790, -0.602088815596040220, -0.602128736299364590, -0.602168655497367090, -0.602208573189948250, -0.602248489377007700, -0.602288404058445970, +-0.602328317234163140, -0.602368228904059940, -0.602408139068035810, -0.602448047725991250, -0.602487954877826690, -0.602527860523442540, -0.602567764662738310, -0.602607667295614770, +-0.602647568421972420, -0.602687468041710690, -0.602727366154730440, -0.602767262760931620, -0.602807157860215100, -0.602847051452480300, -0.602886943537627840, -0.602926834115558140, +-0.602966723186171620, -0.603006610749367900, -0.603046496805047740, -0.603086381353111210, -0.603126264393459180, -0.603166145925991160, -0.603206025950607790, -0.603245904467209270, +-0.603285781475696340, -0.603325656975968630, -0.603365530967926780, -0.603405403451471530, -0.603445274426502310, -0.603485143892919960, -0.603525011850624680, -0.603564878299517330, +-0.603604743239497420, -0.603644606670465600, -0.603684468592322280, -0.603724329004968090, -0.603764187908302770, -0.603804045302226980, -0.603843901186641110, -0.603883755561445800, +-0.603923608426540800, -0.603963459781826750, -0.604003309627203940, -0.604043157962573350, -0.604083004787834500, -0.604122850102888130, -0.604162693907635000, -0.604202536201974730, +-0.604242376985808070, -0.604282216259035550, -0.604322054021557810, -0.604361890273274690, -0.604401725014086730, -0.604441558243894450, -0.604481389962598700, -0.604521220170099130, +-0.604561048866296470, -0.604600876051091140, -0.604640701724384000, -0.604680525886074790, -0.604720348536064270, -0.604760169674252830, -0.604799989300541350, -0.604839807414829570, +-0.604879624017018220, -0.604919439107008180, -0.604959252684699190, -0.604999064749992100, -0.605038875302787220, -0.605078684342985620, -0.605118491870486940, -0.605158297885192040, +-0.605198102387001450, -0.605237905375815900, -0.605277706851535150, -0.605317506814060270, -0.605357305263291570, -0.605397102199129900, -0.605436897621475230, -0.605476691530228210, +-0.605516483925289560, -0.605556274806560050, -0.605596064173939410, -0.605635852027328610, -0.605675638366628300, -0.605715423191739100, -0.605755206502561090, -0.605794988298995030, +-0.605834768580941870, -0.605874547348301480, -0.605914324600974610, -0.605954100338861990, -0.605993874561864490, -0.606033647269881960, -0.606073418462815260, -0.606113188140565030, +-0.606152956303032230, -0.606192722950116610, -0.606232488081719260, -0.606272251697740680, -0.606312013798081750, -0.606351774382642540, -0.606391533451323790, -0.606431291004026260, +-0.606471047040650800, -0.606510801561097380, -0.606550554565267070, -0.606590306053060630, -0.606630056024378140, -0.606669804479120440, -0.606709551417188190, -0.606749296838482550, +-0.606789040742903190, -0.606828783130351270, -0.606868524000727440, -0.606908263353932550, -0.606948001189866690, -0.606987737508430940, -0.607027472309525700, -0.607067205593052270, +-0.607106937358910300, -0.607146667607001090, -0.607186396337225260, -0.607226123549483690, -0.607265849243676550, -0.607305573419704700, -0.607345296077469340, -0.607385017216870330, +-0.607424736837808840, -0.607464454940185420, -0.607504171523901240, -0.607543886588856390, -0.607583600134951720, -0.607623312162088090, -0.607663022670166470, -0.607702731659086950, +-0.607742439128750700, -0.607782145079058260, -0.607821849509910810, -0.607861552421208430, -0.607901253812852090, -0.607940953684742770, -0.607980652036781310, -0.608020348868867910, +-0.608060044180903540, -0.608099737972789160, -0.608139430244425740, -0.608179120995713470, -0.608218810226553330, -0.608258497936846500, -0.608298184126493060, -0.608337868795394200, +-0.608377551943450670, -0.608417233570563650, -0.608456913676633130, -0.608496592261560390, -0.608536269325246070, -0.608575944867591480, -0.608615618888496690, -0.608655291387862900, +-0.608694962365590840, -0.608734631821581720, -0.608774299755735600, -0.608813966167953800, -0.608853631058137170, -0.608893294426186670, -0.608932956272002610, -0.608972616595486180, +-0.609012275396538570, -0.609051932675059970, -0.609091588430951460, -0.609131242664114000, -0.609170895374448800, -0.609210546561856030, -0.609250196226236880, -0.609289844367492230, +-0.609329490985523250, -0.609369136080230240, -0.609408779651514410, -0.609448421699276710, -0.609488062223418230, -0.609527701223839150, -0.609567338700441000, -0.609606974653124410, +-0.609646609081790690, -0.609686241986340140, -0.609725873366673940, -0.609765503222693520, -0.609805131554298940, -0.609844758361391510, -0.609884383643872210, -0.609924007401642210, +-0.609963629634601930, -0.610003250342652570, -0.610042869525695090, -0.610082487183630780, -0.610122103316359850, -0.610161717923783710, -0.610201331005803320, -0.610240942562319870, +-0.610280552593233770, -0.610320161098446220, -0.610359768077858410, -0.610399373531371410, -0.610438977458885650, -0.610478579860302410, -0.610518180735523110, -0.610557780084448050, +-0.610597377906978430, -0.610636974203015440, -0.610676568972460370, -0.610716162215213520, -0.610755753931176320, -0.610795344120249610, -0.610834932782335030, -0.610874519917332660, +-0.610914105525144020, -0.610953689605670090, -0.610993272158812380, -0.611032853184471090, -0.611072432682547630, -0.611112010652943070, -0.611151587095558950, -0.611191162010295440, +-0.611230735397053970, -0.611270307255735720, -0.611309877586242110, -0.611349446388473330, -0.611389013662331000, -0.611428579407716550, -0.611468143624530170, -0.611507706312673480, +-0.611547267472047570, -0.611586827102553850, -0.611626385204092630, -0.611665941776565520, -0.611705496819873520, -0.611745050333918130, -0.611784602318599770, -0.611824152773819960, +-0.611863701699479680, -0.611903249095480550, -0.611942794961722990, -0.611982339298108300, -0.612021882104537900, -0.612061423380913070, -0.612100963127134360, -0.612140501343103270, +-0.612180038028721230, -0.612219573183888750, -0.612259106808507370, -0.612298638902478150, -0.612338169465702740, -0.612377698498081550, -0.612417225999516090, -0.612456751969907560, +-0.612496276409157600, -0.612535799317166510, -0.612575320693835910, -0.612614840539067010, -0.612654358852761430, -0.612693875634819580, -0.612733390885143000, -0.612772904603632980, +-0.612812416790191050, -0.612851927444717730, -0.612891436567114530, -0.612930944157283110, -0.612970450215124090, -0.613009954740538760, -0.613049457733428670, -0.613088959193695220, +-0.613128459121239140, -0.613167957515961760, -0.613207454377764580, -0.613246949706549140, -0.613286443502215840, -0.613325935764666540, -0.613365426493802430, -0.613404915689525040, +-0.613444403351735000, -0.613483889480333940, -0.613523374075223280, -0.613562857136304430, -0.613602338663478130, -0.613641818656645910, -0.613681297115709180, -0.613720774040569570, +-0.613760249431127720, -0.613799723287285160, -0.613839195608943730, -0.613878666396003860, -0.613918135648367390, -0.613957603365935630, -0.613997069548610110, -0.614036534196291670, +-0.614075997308881850, -0.614115458886281940, -0.614154918928393910, -0.614194377435118070, -0.614233834406356370, -0.614273289842010020, -0.614312743741980860, -0.614352196106169530, +-0.614391646934477680, -0.614431096226806690, -0.614470543983058230, -0.614509990203133130, -0.614549434886933140, -0.614588878034359800, -0.614628319645313950, -0.614667759719697340, +-0.614707198257411270, -0.614746635258357600, -0.614786070722436960, -0.614825504649551100, -0.614864937039601540, -0.614904367892490030, -0.614943797208117200, -0.614983224986384910, +-0.615022651227194460, -0.615062075930447820, -0.615101499096045610, -0.615140920723889710, -0.615180340813881400, -0.615219759365922660, -0.615259176379914230, -0.615298591855757750, +-0.615338005793355180, -0.615377418192607270, -0.615416829053415770, -0.615456238375682200, -0.615495646159308410, -0.615535052404195150, -0.615574457110244280, -0.615613860277357210, +-0.615653261905435900, -0.615692661994381110, -0.615732060544094570, -0.615771457554477930, -0.615810853025433040, -0.615850246956860640, -0.615889639348662590, -0.615929030200740410, +-0.615968419512996080, -0.616007807285330330, -0.616047193517645030, -0.616086578209842140, -0.616125961361822410, -0.616165342973487800, -0.616204723044739830, -0.616244101575480370, +-0.616283478565610390, -0.616322854015031620, -0.616362227923645810, -0.616401600291354710, -0.616440971118059290, -0.616480340403661400, -0.616519708148062670, -0.616559074351165080, +-0.616598439012869480, -0.616637802133077730, -0.616677163711691460, -0.616716523748612630, -0.616755882243742120, -0.616795239196981980, -0.616834594608233640, -0.616873948477399180, +-0.616913300804379560, -0.616952651589076750, -0.616992000831392500, -0.617031348531227990, -0.617070694688485080, -0.617110039303065520, -0.617149382374871050, -0.617188723903802970, +-0.617228063889762920, -0.617267402332652760, -0.617306739232374450, -0.617346074588828950, -0.617385408401918250, -0.617424740671544070, -0.617464071397608280, -0.617503400580012070, +-0.617542728218657300, -0.617582054313445820, -0.617621378864279480, -0.617660701871059260, -0.617700023333687340, -0.617739343252065810, -0.617778661626095520, -0.617817978455678540, +-0.617857293740716630, -0.617896607481111750, -0.617935919676765090, -0.617975230327578620, -0.618014539433454080, -0.618053846994293550, -0.618093153009998010, -0.618132457480469630, +-0.618171760405610170, -0.618211061785321590, -0.618250361619504970, -0.618289659908062510, -0.618328956650895820, -0.618368251847907110, -0.618407545498997460, -0.618446837604068930, +-0.618486128163023620, -0.618525417175762700, -0.618564704642188270, -0.618603990562202060, -0.618643274935706140, -0.618682557762601730, -0.618721839042790990, -0.618761118776175570, +-0.618800396962657650, -0.618839673602138540, -0.618878948694520090, -0.618918222239704390, -0.618957494237593500, -0.618996764688088400, -0.619036033591091490, -0.619075300946504430, +-0.619114566754229490, -0.619153831014167770, -0.619193093726221560, -0.619232354890292490, -0.619271614506282990, -0.619310872574094120, -0.619350129093627970, -0.619389384064786830, +-0.619428637487472010, -0.619467889361585480, -0.619507139687029310, -0.619546388463705580, -0.619585635691515590, -0.619624881370361420, -0.619664125500145160, -0.619703368080768870, +-0.619742609112133750, -0.619781848594142200, -0.619821086526695990, -0.619860322909697390, -0.619899557743047720, -0.619938791026649060, -0.619978022760403480, -0.620017252944213170, +-0.620056481577979430, -0.620095708661604460, -0.620134934194990550, -0.620174158178038890, -0.620213380610651900, -0.620252601492731540, -0.620291820824179880, -0.620331038604898470, +-0.620370254834789360, -0.620409469513754640, -0.620448682641696610, -0.620487894218516470, -0.620527104244116610, -0.620566312718399020, -0.620605519641265980, -0.620644725012618800, +-0.620683928832359790, -0.620723131100391010, -0.620762331816614670, -0.620801530980932270, -0.620840728593245910, -0.620879924653458200, -0.620919119161470250, -0.620958312117184440, +-0.620997503520502980, -0.621036693371328050, -0.621075881669561070, -0.621115068415104330, -0.621154253607860030, -0.621193437247730350, -0.621232619334616710, -0.621271799868421630, +-0.621310978849046960, -0.621350156276395230, -0.621389332150367730, -0.621428506470866890, -0.621467679237794780, -0.621506850451053920, -0.621546020110545490, -0.621585188216172040, +-0.621624354767835620, -0.621663519765438650, -0.621702683208882560, -0.621741845098069730, -0.621781005432902600, -0.621820164213282680, -0.621859321439112270, -0.621898477110293670, +-0.621937631226729180, -0.621976783788320220, -0.622015934794969310, -0.622055084246578630, -0.622094232143050490, -0.622133378484286510, -0.622172523270189020, -0.622211666500660290, +-0.622250808175602630, -0.622289948294917680, -0.622329086858507850, -0.622368223866275330, -0.622407359318122630, -0.622446493213951070, -0.622485625553663380, -0.622524756337161980, +-0.622563885564348270, -0.622603013235124900, -0.622642139349393940, -0.622681263907058020, -0.622720386908018560, -0.622759508352178190, -0.622798628239438990, -0.622837746569703590, +-0.622876863342873400, -0.622915978558851170, -0.622955092217538970, -0.622994204318839340, -0.623033314862653900, -0.623072423848885170, -0.623111531277435350, -0.623150637148207060, +-0.623189741461101840, -0.623228844216022320, -0.623267945412870890, -0.623307045051549440, -0.623346143131960240, -0.623385239654005720, -0.623424334617588390, -0.623463428022610010, +-0.623502519868972980, -0.623541610156579610, -0.623580698885332630, -0.623619786055133570, -0.623658871665884960, -0.623697955717489210, -0.623737038209848940, -0.623776119142865680, +-0.623815198516442180, -0.623854276330480630, -0.623893352584883760, -0.623932427279553230, -0.623971500414391530, -0.624010571989301540, -0.624049642004184670, -0.624088710458943760, +-0.624127777353481020, -0.624166842687699170, -0.624205906461499980, -0.624244968674785850, -0.624284029327459410, -0.624323088419423300, -0.624362145950579040, -0.624401201920829370, +-0.624440256330076720, -0.624479309178223810, -0.624518360465172280, -0.624557410190824890, -0.624596458355083930, -0.624635504957852140, -0.624674549999031270, -0.624713593478524070, +-0.624752635396232820, -0.624791675752060400, -0.624830714545908440, -0.624869751777679560, -0.624908787447276740, -0.624947821554601600, -0.624986854099557010, -0.625025885082045150, +-0.625064914501968990, -0.625103942359230170, -0.625142968653731420, -0.625181993385375390, -0.625221016554064590, -0.625260038159700990, -0.625299058202187340, -0.625338076681425940, +-0.625377093597319740, -0.625416108949770400, -0.625455122738680870, -0.625494134963953560, -0.625533145625491120, -0.625572154723195610, -0.625611162256969670, -0.625650168226716150, +-0.625689172632336810, -0.625728175473734600, -0.625767176750811950, -0.625806176463471700, -0.625845174611615710, -0.625884171195146720, -0.625923166213967370, -0.625962159667980410, +-0.626001151557087690, -0.626040141881192060, -0.626079130640196160, -0.626118117834002730, -0.626157103462513740, -0.626196087525631830, -0.626235070023259840, -0.626274050955300420, +-0.626313030321655640, -0.626352008122228240, -0.626390984356921090, -0.626429959025636250, -0.626468932128276480, -0.626507903664744290, -0.626546873634942770, -0.626585842038773650, +-0.626624808876140030, -0.626663774146944300, -0.626702737851089540, -0.626741699988477620, -0.626780660559011380, -0.626819619562593470, -0.626858576999126950, -0.626897532868513570, +-0.626936487170656310, -0.626975439905457900, -0.627014391072821310, -0.627053340672648290, -0.627092288704841900, -0.627131235169304910, -0.627170180065940050, -0.627209123394649510, +-0.627248065155336040, -0.627287005347902830, -0.627325943972251830, -0.627364881028285800, -0.627403816515907710, -0.627442750435020400, -0.627481682785525740, -0.627520613567327020, +-0.627559542780326660, -0.627598470424427850, -0.627637396499532540, -0.627676321005543710, -0.627715243942364110, -0.627754165309896690, -0.627793085108043550, -0.627832003336707740, +-0.627870919995791810, -0.627909835085199040, -0.627948748604831300, -0.627987660554591650, -0.628026570934383190, -0.628065479744107980, -0.628104386983669110, -0.628143292652969200, +-0.628182196751911450, -0.628221099280397820, -0.628260000238331510, -0.628298899625615140, -0.628337797442151900, -0.628376693687843880, -0.628415588362594040, -0.628454481466305230, +-0.628493372998880530, -0.628532262960222130, -0.628571151350233110, -0.628610038168816110, -0.628648923415874420, -0.628687807091310000, -0.628726689195026170, -0.628765569726925880, +-0.628804448686911320, -0.628843326074885690, -0.628882201890751720, -0.628921076134412620, -0.628959948805770440, -0.628998819904728390, -0.629037689431189320, -0.629076557385056410, +-0.629115423766231750, -0.629154288574618410, -0.629193151810119480, -0.629232013472637910, -0.629270873562076120, -0.629309732078336960, -0.629348589021323620, -0.629387444390939080, +-0.629426298187085620, -0.629465150409666330, -0.629504001058584620, -0.629542850133742450, -0.629581697635043240, -0.629620543562389720, -0.629659387915685320, -0.629698230694832000, +-0.629737071899733050, -0.629775911530291550, -0.629814749586410480, -0.629853586067992350, -0.629892420974940140, -0.629931254307156910, -0.629970086064545850, -0.630008916247009280, +-0.630047744854450480, -0.630086571886772200, -0.630125397343877850, -0.630164221225669730, -0.630203043532051030, -0.630241864262924720, -0.630280683418194100, -0.630319500997761350, +-0.630358317001530000, -0.630397131429403120, -0.630435944281283020, -0.630474755557073110, -0.630513565256676230, -0.630552373379995920, -0.630591179926934250, -0.630629984897394640, +-0.630668788291280150, -0.630707590108493870, -0.630746390348938420, -0.630785189012516900, -0.630823986099132480, -0.630862781608688360, -0.630901575541087060, -0.630940367896231650, +-0.630979158674025430, -0.631017947874371710, -0.631056735497172670, -0.631095521542331840, -0.631134306009752510, -0.631173088899337100, -0.631211870210989010, -0.631250649944611220, +-0.631289428100107130, -0.631328204677379160, -0.631366979676330600, -0.631405753096864640, -0.631444524938884700, -0.631483295202293070, -0.631522063886993170, -0.631560830992888070, +-0.631599596519881290, -0.631638360467875140, -0.631677122836773130, -0.631715883626478350, -0.631754642836894090, -0.631793400467922980, -0.631832156519468340, -0.631870910991433670, +-0.631909663883721380, -0.631948415196234900, -0.631987164928877410, -0.632025913081552320, -0.632064659654162140, -0.632103404646610300, -0.632142148058799870, -0.632180889890634480, +-0.632219630142016540, -0.632258368812849580, -0.632297105903036560, -0.632335841412481230, -0.632374575341085880, -0.632413307688754140, -0.632452038455389110, -0.632490767640894290, +-0.632529495245172320, -0.632568221268126510, -0.632606945709660140, -0.632645668569676860, -0.632684389848078950, -0.632723109544770180, -0.632761827659653830, -0.632800544192632650, +-0.632839259143610170, -0.632877972512489450, -0.632916684299174140, -0.632955394503566860, -0.632994103125571030, -0.633032810165089940, -0.633071515622027240, -0.633110219496285320, +-0.633148921787767830, -0.633187622496378170, -0.633226321622019640, -0.633265019164595100, -0.633303715124007960, -0.633342409500161520, -0.633381102292959410, -0.633419793502304150, +-0.633458483128099490, -0.633497171170248840, -0.633535857628655050, -0.633574542503221540, -0.633613225793851710, -0.633651907500449200, -0.633690587622916520, -0.633729266161157430, +-0.633767943115075120, -0.633806618484573310, -0.633845292269554550, -0.633883964469922680, -0.633922635085580780, -0.633961304116432700, -0.633999971562380970, -0.634038637423329440, +-0.634077301699181200, -0.634115964389840080, -0.634154625495208730, -0.634193285015190790, -0.634231942949689990, -0.634270599298608960, -0.634309254061851460, -0.634347907239320770, +-0.634386558830920650, -0.634425208836553840, -0.634463857256124090, -0.634502504089534570, -0.634541149336689150, -0.634579792997490570, -0.634618435071842460, -0.634657075559648340, +-0.634695714460811860, -0.634734351775235630, -0.634772987502823630, -0.634811621643479150, -0.634850254197105950, -0.634888885163606750, -0.634927514542885320, -0.634966142334845500, +-0.635004768539390030, -0.635043393156422550, -0.635082016185846590, -0.635120637627565990, -0.635159257481483390, -0.635197875747502640, -0.635236492425527270, -0.635275107515460900, +-0.635313721017206510, -0.635352332930667840, -0.635390943255748300, -0.635429551992351740, -0.635468159140380910, -0.635506764699739770, -0.635545368670331620, -0.635583971052060440, +-0.635622571844829070, -0.635661171048541140, -0.635699768663100410, -0.635738364688410500, -0.635776959124374370, -0.635815551970895900, -0.635854143227878810, -0.635892732895226080, +-0.635931320972841440, -0.635969907460628540, -0.636008492358491220, -0.636047075666332340, -0.636085657384055760, -0.636124237511564990, -0.636162816048764010, -0.636201392995555670, +-0.636239968351843820, -0.636278542117532100, -0.636317114292524360, -0.636355684876723450, -0.636394253870033340, -0.636432821272357560, -0.636471387083600070, -0.636509951303663830, +-0.636548513932452710, -0.636587074969870550, -0.636625634415820430, -0.636664192270206210, -0.636702748532931520, -0.636741303203900320, -0.636779856283015590, -0.636818407770181060, +-0.636856957665300590, -0.636895505968278040, -0.636934052679016480, -0.636972597797419660, -0.637011141323391430, -0.637049683256835640, -0.637088223597655380, -0.637126762345754490, +-0.637165299501036730, -0.637203835063406050, -0.637242369032765430, -0.637280901409018830, -0.637319432192070430, -0.637357961381822990, -0.637396488978180800, -0.637435014981047270, +-0.637473539390326580, -0.637512062205921710, -0.637550583427736630, -0.637589103055675180, -0.637627621089641220, -0.637666137529537940, -0.637704652375269300, -0.637743165626738940, +-0.637781677283851160, -0.637820187346508800, -0.637858695814615850, -0.637897202688076260, -0.637935707966794000, -0.637974211650672140, -0.638012713739614770, -0.638051214233525620, +-0.638089713132308670, -0.638128210435867200, -0.638166706144105200, -0.638205200256926730, -0.638243692774234980, -0.638282183695933920, -0.638320673021927410, -0.638359160752119630, +-0.638397646886413540, -0.638436131424713340, -0.638474614366922880, -0.638513095712946120, -0.638551575462686370, -0.638590053616047590, -0.638628530172933750, -0.638667005133248920, +-0.638705478496896180, -0.638743950263779840, -0.638782420433803510, -0.638820889006871620, -0.638859355982887010, -0.638897821361754100, -0.638936285143376970, -0.638974747327658800, +-0.639013207914503670, -0.639051666903815650, -0.639090124295498720, -0.639128580089456170, -0.639167034285592180, -0.639205486883810510, -0.639243937884015570, -0.639282387286110420, +-0.639320835089999260, -0.639359281295586060, -0.639397725902774990, -0.639436168911469260, -0.639474610321573160, -0.639513050132990420, -0.639551488345625470, -0.639589924959381500, +-0.639628359974162670, -0.639666793389873310, -0.639705225206416590, -0.639743655423696820, -0.639782084041617850, -0.639820511060084090, -0.639858936478998610, -0.639897360298265940, +-0.639935782517789820, -0.639974203137474550, -0.640012622157223430, -0.640051039576940760, -0.640089455396530500, -0.640127869615896960, -0.640166282234943320, -0.640204693253574100, +-0.640243102671693040, -0.640281510489204560, -0.640319916706012070, -0.640358321322019750, -0.640396724337131910, -0.640435125751251940, -0.640473525564284160, -0.640511923776132640, +-0.640550320386701570, -0.640588715395894460, -0.640627108803615400, -0.640665500609768680, -0.640703890814258490, -0.640742279416988250, -0.640780666417862350, -0.640819051816784780, +-0.640857435613659930, -0.640895817808391110, -0.640934198400882730, -0.640972577391038860, -0.641010954778763910, -0.641049330563961290, -0.641087704746535310, -0.641126077326390040, +-0.641164448303429890, -0.641202817677558270, -0.641241185448679700, -0.641279551616698470, -0.641317916181518010, -0.641356279143042720, -0.641394640501176780, -0.641433000255824610, +-0.641471358406889510, -0.641509714954276110, -0.641548069897888370, -0.641586423237630710, -0.641624774973406750, -0.641663125105120910, -0.641701473632677160, -0.641739820555980110, +-0.641778165874933190, -0.641816509589440810, -0.641854851699407150, -0.641893192204736730, -0.641931531105332960, -0.641969868401100370, -0.642008204091943480, -0.642046538177765690, +-0.642084870658471640, -0.642123201533965400, -0.642161530804151390, -0.642199858468933350, -0.642238184528215570, -0.642276508981902360, -0.642314831829898240, -0.642353153072106610, +-0.642391472708432220, -0.642429790738779040, -0.642468107163051800, -0.642506421981153930, -0.642544735192989940, -0.642583046798464230, -0.642621356797481220, -0.642659665189944440, +-0.642697971975758400, -0.642736277154827950, -0.642774580727056400, -0.642812882692348380, -0.642851183050608180, -0.642889481801740330, -0.642927778945648450, -0.642966074482237080, +-0.643004368411410620, -0.643042660733073480, -0.643080951447129400, -0.643119240553482910, -0.643157528052038410, -0.643195813942700310, -0.643234098225372470, -0.643272380899959310, +-0.643310661966365100, -0.643348941424494720, -0.643387219274251580, -0.643425495515540400, -0.643463770148265500, -0.643502043172331510, -0.643540314587642050, -0.643578584394101870, +-0.643616852591615500, -0.643655119180086670, -0.643693384159420120, -0.643731647529519950, -0.643769909290291100, -0.643808169441637210, -0.643846427983462810, -0.643884684915672300, +-0.643922940238170540, -0.643961193950860930, -0.643999446053648450, -0.644037696546437390, -0.644075945429132270, -0.644114192701637060, -0.644152438363856380, -0.644190682415694550, +-0.644228924857056410, -0.644267165687845590, -0.644305404907966840, -0.644343642517324900, -0.644381878515823630, -0.644420112903367540, -0.644458345679861160, -0.644496576845209330, +-0.644534806399315710, -0.644573034342085020, -0.644611260673421780, -0.644649485393230750, -0.644687708501415660, -0.644725929997881250, -0.644764149882532060, -0.644802368155272810, +-0.644840584816007370, -0.644878799864640360, -0.644917013301076420, -0.644955225125220300, -0.644993435336975730, -0.645031643936247570, -0.645069850922940670, -0.645108056296958890, +-0.645146260058206860, -0.645184462206589200, -0.645222662742010680, -0.645260861664375240, -0.645299058973587520, -0.645337254669552270, -0.645375448752174230, -0.645413641221357140, +-0.645451832077006070, -0.645490021319025330, -0.645528208947319880, -0.645566394961793580, -0.645604579362351380, -0.645642762148897600, -0.645680943321337300, -0.645719122879574340, +-0.645757300823513570, -0.645795477153059850, -0.645833651868117030, -0.645871824968590190, -0.645909996454383740, -0.645948166325402640, -0.645986334581550860, -0.646024501222733140, +-0.646062666248854220, -0.646100829659818960, -0.646138991455531330, -0.646177151635896170, -0.646215310200818130, -0.646253467150202150, -0.646291622483952220, -0.646329776201973180, +-0.646367928304169780, -0.646406078790446760, -0.646444227660708300, -0.646482374914859270, -0.646520520552804290, -0.646558664574448330, -0.646596806979695350, -0.646634947768450430, +-0.646673086940618420, -0.646711224496103410, -0.646749360434810240, -0.646787494756643770, -0.646825627461508850, -0.646863758549309550, -0.646901888019950850, -0.646940015873337380, +-0.646978142109374320, -0.647016266727965420, -0.647054389729015970, -0.647092511112430490, -0.647130630878114070, -0.647168749025970770, -0.647206865555905560, -0.647244980467823190, +-0.647283093761628740, -0.647321205437226150, -0.647359315494520640, -0.647397423933417150, -0.647435530753819770, -0.647473635955633450, -0.647511739538763180, -0.647549841503113790, +-0.647587941848589590, -0.647626040575095430, -0.647664137682536280, -0.647702233170816990, -0.647740327039841860, -0.647778419289515850, -0.647816509919743820, -0.647854598930430850, +-0.647892686321481110, -0.647930772092799590, -0.647968856244291120, -0.648006938775860910, -0.648045019687413020, -0.648083098978852520, -0.648121176650084620, -0.648159252701013490, +-0.648197327131544210, -0.648235399941581640, -0.648273471131030840, -0.648311540699796020, -0.648349608647782350, -0.648387674974894690, -0.648425739681038230, -0.648463802766117040, +-0.648501864230036310, -0.648539924072701000, -0.648577982294016090, -0.648616038893885970, -0.648654093872215840, -0.648692147228910330, -0.648730198963874850, -0.648768249077013470, +-0.648806297568231600, -0.648844344437433880, -0.648882389684525720, -0.648920433309411180, -0.648958475311995580, -0.648996515692184080, -0.649034554449881010, -0.649072591584991530, +-0.649110627097420620, -0.649148660987073470, -0.649186693253854250, -0.649224723897668390, -0.649262752918420620, -0.649300780316016350, -0.649338806090359880, -0.649376830241356280, +-0.649414852768910640, -0.649452873672928250, -0.649490892953313300, -0.649528910609971090, -0.649566926642806690, -0.649604941051725170, -0.649642953836631070, -0.649680964997429560, +-0.649718974534026050, -0.649756982446324630, -0.649794988734230810, -0.649832993397649550, -0.649870996436486160, -0.649908997850644820, -0.649946997640031170, -0.649984995804549830, +-0.650022992344106540, -0.650060987258605280, -0.650098980547951570, -0.650136972212050470, -0.650174962250807290, -0.650212950664126210, -0.650250937451912980, -0.650288922614072230, +-0.650326906150509590, -0.650364888061129350, -0.650402868345836830, -0.650440847004537530, -0.650478824037135750, -0.650516799443536910, -0.650554773223646080, -0.650592745377368660, +-0.650630715904609080, -0.650668684805272620, -0.650706652079264480, -0.650744617726490060, -0.650782581746853770, -0.650820544140261030, -0.650858504906616900, -0.650896464045826910, +-0.650934421557795350, -0.650972377442427750, -0.651010331699629300, -0.651048284329305280, -0.651086235331360230, -0.651124184705699550, -0.651162132452228760, -0.651200078570852270, +-0.651238023061475600, -0.651275965924003940, -0.651313907158342700, -0.651351846764396280, -0.651389784742070320, -0.651427721091269780, -0.651465655811900410, -0.651503588903866500, +-0.651541520367073580, -0.651579450201426940, -0.651617378406831980, -0.651655304983193240, -0.651693229930416230, -0.651731153248406140, -0.651769074937068480, -0.651806994996307900, +-0.651844913426029680, -0.651882830226139350, -0.651920745396542100, -0.651958658937142780, -0.651996570847846790, -0.652034481128559660, -0.652072389779186020, -0.652110296799631390, +-0.652148202189801070, -0.652186105949600580, -0.652224008078934440, -0.652261908577708270, -0.652299807445827380, -0.652337704683197290, -0.652375600289722520, -0.652413494265308920, +-0.652451386609861460, -0.652489277323285880, -0.652527166405486800, -0.652565053856369760, -0.652602939675840150, -0.652640823863803510, -0.652678706420164460, -0.652716587344828620, +-0.652754466637701650, -0.652792344298688270, -0.652830220327694000, -0.652868094724624040, -0.652905967489384340, -0.652943838621879320, -0.652981708122014730, -0.653019575989695840, +-0.653057442224828310, -0.653095306827316870, -0.653133169797067260, -0.653171031133984670, -0.653208890837974730, -0.653246748908942300, -0.653284605346793110, -0.653322460151432250, +-0.653360313322765670, -0.653398164860697910, -0.653436014765134800, -0.653473863035981870, -0.653511709673144090, -0.653549554676526980, -0.653587398046035940, -0.653625239781576830, +-0.653663079883054170, -0.653700918350373920, -0.653738755183441270, -0.653776590382162180, -0.653814423946441180, -0.653852255876184230, -0.653890086171296510, -0.653927914831684000, +-0.653965741857251310, -0.654003567247904320, -0.654041391003548410, -0.654079213124089340, -0.654117033609431850, -0.654154852459481910, -0.654192669674144690, -0.654230485253326280, +-0.654268299196931190, -0.654306111504865400, -0.654343922177034740, -0.654381731213343860, -0.654419538613698610, -0.654457344378004620, -0.654495148506167520, -0.654532950998092280, +-0.654570751853684630, -0.654608551072850100, -0.654646348655494540, -0.654684144601522690, -0.654721938910840520, -0.654759731583353540, -0.654797522618967620, -0.654835312017587490, +-0.654873099779119120, -0.654910885903467910, -0.654948670390539830, -0.654986453240239850, -0.655024234452473710, -0.655062014027147250, -0.655099791964165460, -0.655137568263434170, +-0.655175342924859020, -0.655213115948345750, -0.655250887333799440, -0.655288657081125820, -0.655326425190230650, -0.655364191661019780, -0.655401956493397940, -0.655439719687271330, +-0.655477481242545460, -0.655515241159126180, -0.655552999436918360, -0.655590756075828170, -0.655628511075761030, -0.655666264436623010, -0.655704016158318860, -0.655741766240754750, +-0.655779514683836550, -0.655817261487469330, -0.655855006651558830, -0.655892750176010900, -0.655930492060731400, -0.655968232305625290, -0.656005970910598650, -0.656043707875556990, +-0.656081443200406510, -0.656119176885052060, -0.656156908929399600, -0.656194639333354980, -0.656232368096824060, -0.656270095219711800, -0.656307820701924390, -0.656345544543367350, +-0.656383266743946870, -0.656420987303567900, -0.656458706222136420, -0.656496423499558500, -0.656534139135739210, -0.656571853130584530, -0.656609565484000290, -0.656647276195892360, +-0.656684985266166030, -0.656722692694727160, -0.656760398481481600, -0.656798102626335310, -0.656835805129193480, -0.656873505989962080, -0.656911205208547070, -0.656948902784854180, +-0.656986598718788840, -0.657024293010257000, -0.657061985659164400, -0.657099676665417130, -0.657137366028920370, -0.657175053749580180, -0.657212739827302330, -0.657250424261993090, +-0.657288107053557340, -0.657325788201901350, -0.657363467706931210, -0.657401145568552110, -0.657438821786670120, -0.657476496361190990, -0.657514169292021110, -0.657551840579065350, +-0.657589510222230000, -0.657627178221420920, -0.657664844576544280, -0.657702509287505180, -0.657740172354209670, -0.657777833776563850, -0.657815493554473770, -0.657853151687844640, +-0.657890808176582630, -0.657928463020593490, -0.657966116219783630, -0.658003767774058110, -0.658041417683323140, -0.658079065947485000, -0.658116712566448880, -0.658154357540120970, +-0.658192000868407120, -0.658229642551213740, -0.658267282588445800, -0.658304920980009700, -0.658342557725811180, -0.658380192825756770, -0.658417826279751430, -0.658455458087701560, +-0.658493088249513030, -0.658530716765092120, -0.658568343634344130, -0.658605968857175260, -0.658643592433491460, -0.658681214363198930, -0.658718834646203180, -0.658756453282410280, +-0.658794070271726540, -0.658831685614057360, -0.658869299309308930, -0.658906911357387210, -0.658944521758198620, -0.658982130511648330, -0.659019737617642760, -0.659057343076087760, +-0.659094946886889850, -0.659132549049954220, -0.659170149565187160, -0.659207748432494740, -0.659245345651783390, -0.659282941222958160, -0.659320535145925700, -0.659358127420591860, +-0.659395718046863030, -0.659433307024644640, -0.659470894353842870, -0.659508480034364020, -0.659546064066114160, -0.659583646448998810, -0.659621227182924490, -0.659658806267797270, +-0.659696383703522790, -0.659733959490007350, -0.659771533627157010, -0.659809106114878090, -0.659846676953076190, -0.659884246141657530, -0.659921813680528270, -0.659959379569594830, +-0.659996943808762620, -0.660034506397937930, -0.660072067337027060, -0.660109626625936420, -0.660147184264571310, -0.660184740252838240, -0.660222294590643300, -0.660259847277893000, +-0.660297398314492750, -0.660334947700348950, -0.660372495435368130, -0.660410041519455810, -0.660447585952518290, -0.660485128734461860, -0.660522669865192920, -0.660560209344617010, +-0.660597747172640530, -0.660635283349169770, -0.660672817874111030, -0.660710350747369950, -0.660747881968853030, -0.660785411538466370, -0.660822939456116480, -0.660860465721708980, +-0.660897990335150290, -0.660935513296346590, -0.660973034605204400, -0.661010554261629360, -0.661048072265527980, -0.661085588616806660, -0.661123103315371050, -0.661160616361127770, +-0.661198127753982900, -0.661235637493843060, -0.661273145580613790, -0.661310652014201580, -0.661348156794512750, -0.661385659921453930, -0.661423161394930630, -0.661460661214849370, +-0.661498159381116560, -0.661535655893638500, -0.661573150752321150, -0.661610643957070810, -0.661648135507793890, -0.661685625404397020, -0.661723113646785710, -0.661760600234866600, +-0.661798085168546320, -0.661835568447730620, -0.661873050072325890, -0.661910530042238540, -0.661948008357375110, -0.661985485017641430, -0.662022960022944030, -0.662060433373189210, +-0.662097905068283700, -0.662135375108133030, -0.662172843492643940, -0.662210310221722720, -0.662247775295276120, -0.662285238713209660, -0.662322700475430180, -0.662360160581843880, +-0.662397619032357610, -0.662435075826876880, -0.662472530965308450, -0.662509984447558820, -0.662547436273534410, -0.662584886443141170, -0.662622334956285640, -0.662659781812874660, +-0.662697227012813860, -0.662734670556009990, -0.662772112442369550, -0.662809552671799080, -0.662846991244204320, -0.662884428159492220, -0.662921863417568980, -0.662959297018341440, +-0.662996728961715240, -0.663034159247597340, -0.663071587875893930, -0.663109014846511970, -0.663146440159357090, -0.663183863814336140, -0.663221285811355530, -0.663258706150322010, +-0.663296124831141420, -0.663333541853720510, -0.663370957217966020, -0.663408370923783910, -0.663445782971080810, -0.663483193359763250, -0.663520602089738070, -0.663558009160911120, +-0.663595414573189050, -0.663632818326478470, -0.663670220420686130, -0.663707620855717990, -0.663745019631480690, -0.663782416747880970, -0.663819812204825440, -0.663857206002220090, +-0.663894598139971650, -0.663931988617986860, -0.663969377436172350, -0.664006764594434080, -0.664044150092678810, -0.664081533930813590, -0.664118916108744180, -0.664156296626377540, +-0.664193675483620070, -0.664231052680378850, -0.664268428216559510, -0.664305802092069240, -0.664343174306814440, -0.664380544860701970, -0.664417913753637790, -0.664455280985528970, +-0.664492646556281820, -0.664530010465803400, -0.664567372713999680, -0.664604733300777520, -0.664642092226043420, -0.664679449489704590, -0.664716805091666750, -0.664754159031836770, +-0.664791511310121490, -0.664828861926427760, -0.664866210880661560, -0.664903558172729840, -0.664940903802539560, -0.664978247769996700, -0.665015590075008100, -0.665052930717480620, +-0.665090269697321210, -0.665127607014435630, -0.665164942668731160, -0.665202276660114330, -0.665239608988492100, -0.665276939653770550, -0.665314268655856630, -0.665351595994656990, +-0.665388921670078790, -0.665426245682027910, -0.665463568030411400, -0.665500888715135910, -0.665538207736108610, -0.665575525093235480, -0.665612840786423470, -0.665650154815579760, +-0.665687467180610340, -0.665724777881422150, -0.665762086917922160, -0.665799394290017110, -0.665836699997613300, -0.665874004040617810, -0.665911306418937250, -0.665948607132478830, +-0.665985906181148500, -0.666023203564853450, -0.666060499283500310, -0.666097793336996260, -0.666135085725247490, -0.666172376448160960, -0.666209665505643420, -0.666246952897602160, +-0.666284238623943150, -0.666321522684573560, -0.666358805079400370, -0.666396085808329990, -0.666433364871269360, -0.666470642268125250, -0.666507917998804930, -0.666545192063214500, +-0.666582464461261020, -0.666619735192851450, -0.666657004257892760, -0.666694271656291360, -0.666731537387954210, -0.666768801452788270, -0.666806063850700510, -0.666843324581597450, +-0.666880583645385940, -0.666917841041973050, -0.666955096771265850, -0.666992350833170660, -0.667029603227594530, -0.667066853954444430, -0.667104103013627440, -0.667141350405049960, +-0.667178596128618960, -0.667215840184241960, -0.667253082571824920, -0.667290323291275240, -0.667327562342499790, -0.667364799725405630, -0.667402035439899290, -0.667439269485887720, +-0.667476501863278120, -0.667513732571977550, -0.667550961611892200, -0.667588188982929600, -0.667625414684996480, -0.667662638718000130, -0.667699861081846870, -0.667737081776443860, +-0.667774300801698310, -0.667811518157517270, -0.667848733843807050, -0.667885947860475060, -0.667923160207428480, -0.667960370884573720, -0.667997579891818070, -0.668034787229068390, +-0.668071992896232090, -0.668109196893215460, -0.668146399219925910, -0.668183599876270300, -0.668220798862156020, -0.668257996177489490, -0.668295191822177890, -0.668332385796128300, +-0.668369578099248130, -0.668406768731443670, -0.668443957692622330, -0.668481144982691070, -0.668518330601557190, -0.668555514549127210, -0.668592696825308530, -0.668629877430008350, +-0.668667056363133170, -0.668704233624590310, -0.668741409214286930, -0.668778583132130230, -0.668815755378026840, -0.668852925951884060, -0.668890094853608950, -0.668927262083109040, +-0.668964427640290520, -0.669001591525061000, -0.669038753737327460, -0.669075914276997310, -0.669113073143977170, -0.669150230338174220, -0.669187385859495780, -0.669224539707849230, +-0.669261691883140890, -0.669298842385278370, -0.669335991214169090, -0.669373138369719570, -0.669410283851837100, -0.669447427660428970, -0.669484569795402610, -0.669521710256664400, +-0.669558849044122000, -0.669595986157682450, -0.669633121597253300, -0.669670255362741050, -0.669707387454053120, -0.669744517871096680, -0.669781646613779370, -0.669818773682007480, +-0.669855899075688770, -0.669893022794730290, -0.669930144839039570, -0.669967265208523120, -0.670004383903088470, -0.670041500922643030, -0.670078616267093970, -0.670115729936348160, +-0.670152841930312990, -0.670189952248896100, -0.670227060892003900, -0.670264167859544120, -0.670301273151423960, -0.670338376767550810, -0.670375478707831540, -0.670412578972173550, +-0.670449677560484010, -0.670486774472670690, -0.670523869708640090, -0.670560963268299730, -0.670598055151557130, -0.670635145358319580, -0.670672233888493840, -0.670709320741987640, +-0.670746405918708040, -0.670783489418562810, -0.670820571241458440, -0.670857651387302690, -0.670894729856003180, -0.670931806647466430, -0.670968881761600300, -0.671005955198311850, +-0.671043026957508840, -0.671080097039097990, -0.671117165442986830, -0.671154232169082880, -0.671191297217293540, -0.671228360587525770, -0.671265422279687000, -0.671302482293684720, +-0.671339540629426470, -0.671376597286819090, -0.671413652265770320, -0.671450705566187360, -0.671487757187977820, -0.671524807131048780, -0.671561855395307550, -0.671598901980662080, +-0.671635946887019000, -0.671672990114286160, -0.671710031662370750, -0.671747071531180630, -0.671784109720622410, -0.671821146230604070, -0.671858181061032680, -0.671895214211816310, +-0.671932245682861580, -0.671969275474076140, -0.672006303585367610, -0.672043330016643510, -0.672080354767810920, -0.672117377838777340, -0.672154399229450310, -0.672191418939737660, +-0.672228436969546150, -0.672265453318783510, -0.672302467987357270, -0.672339480975175150, -0.672376492282144020, -0.672413501908171620, -0.672450509853165900, -0.672487516117033500, +-0.672524520699682270, -0.672561523601019840, -0.672598524820953840, -0.672635524359391220, -0.672672522216239740, -0.672709518391407140, -0.672746512884800920, -0.672783505696328050, +-0.672820496825896510, -0.672857486273413690, -0.672894474038787550, -0.672931460121924840, -0.672968444522733520, -0.673005427241121000, -0.673042408276995350, -0.673079387630263200, +-0.673116365300832740, -0.673153341288611600, -0.673190315593506840, -0.673227288215426210, -0.673264259154277460, -0.673301228409968310, -0.673338195982405850, -0.673375161871497820, +-0.673412126077151950, -0.673449088599275990, -0.673486049437777010, -0.673523008592562980, -0.673559966063541400, -0.673596921850620260, -0.673633875953706380, -0.673670828372707970, +-0.673707779107532320, -0.673744728158087720, -0.673781675524280810, -0.673818621206019760, -0.673855565203212550, -0.673892507515766010, -0.673929448143588350, -0.673966387086586960, +-0.674003324344669920, -0.674040259917744300, -0.674077193805717960, -0.674114126008498630, -0.674151056525994390, -0.674187985358112090, -0.674224912504759910, -0.674261837965845380, +-0.674298761741276680, -0.674335683830960650, -0.674372604234805490, -0.674409522952718720, -0.674446439984608630, -0.674483355330381950, -0.674520268989946990, -0.674557180963211600, +-0.674594091250082960, -0.674630999850469150, -0.674667906764277790, -0.674704811991416960, -0.674741715531793850, -0.674778617385316410, -0.674815517551892400, -0.674852416031429980, +-0.674889312823836130, -0.674926207929019030, -0.674963101346886420, -0.674999993077346480, -0.675036883120306070, -0.675073771475673490, -0.675110658143356580, -0.675147543123263190, +-0.675184426415300740, -0.675221308019377190, -0.675258187935400380, -0.675295066163278390, -0.675331942702918410, -0.675368817554228620, -0.675405690717117090, -0.675442562191491010, +-0.675479431977258460, -0.675516300074327390, -0.675553166482605880, -0.675590031202001230, -0.675626894232421390, -0.675663755573774340, -0.675700615225968250, -0.675737473188910310, +-0.675774329462508590, -0.675811184046671180, -0.675848036941306020, -0.675884888146320420, -0.675921737661622670, -0.675958585487120620, -0.675995431622722350, -0.676032276068335270, +-0.676069118823867440, -0.676105959889227170, -0.676142799264321640, -0.676179636949059030, -0.676216472943347520, -0.676253307247094980, -0.676290139860208920, -0.676326970782597510, +-0.676363800014168740, -0.676400627554830660, -0.676437453404490800, -0.676474277563057220, -0.676511100030438020, -0.676547920806541360, -0.676584739891274540, -0.676621557284545870, +-0.676658372986263410, -0.676695186996335240, -0.676731999314668760, -0.676768809941172390, -0.676805618875754300, -0.676842426118321790, -0.676879231668783170, -0.676916035527046600, +-0.676952837693020170, -0.676989638166611290, -0.677026436947728350, -0.677063234036279440, -0.677100029432172620, -0.677136823135315420, -0.677173615145616250, -0.677210405462982950, +-0.677247194087324030, -0.677283981018546700, -0.677320766256559570, -0.677357549801270390, -0.677394331652587780, -0.677431111810418930, -0.677467890274672250, -0.677504667045256030, +-0.677541442122078340, -0.677578215505046710, -0.677614987194069540, -0.677651757189055240, -0.677688525489911210, -0.677725292096545970, -0.677762057008867380, -0.677798820226783950, +-0.677835581750203310, -0.677872341579033530, -0.677909099713183030, -0.677945856152559980, -0.677982610897072120, -0.678019363946627650, -0.678056115301134740, -0.678092864960501920, +-0.678129612924636580, -0.678166359193447250, -0.678203103766842010, -0.678239846644729250, -0.678276587827016720, -0.678313327313612600, -0.678350065104425410, -0.678386801199362900, +-0.678423535598333350, -0.678460268301244840, -0.678496999308006110, -0.678533728618524570, -0.678570456232708620, -0.678607182150466560, -0.678643906371706910, -0.678680628896337180, +-0.678717349724265780, -0.678754068855401020, -0.678790786289651500, -0.678827502026924660, -0.678864216067128990, -0.678900928410172910, -0.678937639055964710, -0.678974348004412140, +-0.679011055255423710, -0.679047760808907940, -0.679084464664772460, -0.679121166822925890, -0.679157867283276320, -0.679194566045732360, -0.679231263110201770, -0.679267958476593050, +-0.679304652144814280, -0.679341344114774310, -0.679378034386380670, -0.679414722959541860, -0.679451409834166300, -0.679488095010162500, -0.679524778487438200, -0.679561460265901920, +-0.679598140345461950, -0.679634818726027050, -0.679671495407504710, -0.679708170389803580, -0.679744843672832500, -0.679781515256498880, -0.679818185140711460, -0.679854853325378650, +-0.679891519810408960, -0.679928184595710140, -0.679964847681190920, -0.680001509066759600, -0.680038168752324810, -0.680074826737794180, -0.680111483023076560, -0.680148137608080240, +-0.680184790492713850, -0.680221441676885250, -0.680258091160502950, -0.680294738943475470, -0.680331385025711550, -0.680368029407118710, -0.680404672087605910, -0.680441313067081330, +-0.680477952345453830, -0.680514589922631140, -0.680551225798522010, -0.680587859973035060, -0.680624492446078140, -0.680661123217560000, -0.680697752287389050, -0.680734379655474120, +-0.680771005321722860, -0.680807629286044100, -0.680844251548346160, -0.680880872108538090, -0.680917490966527430, -0.680954108122223010, -0.680990723575533360, -0.681027337326367220, +-0.681063949374632440, -0.681100559720237750, -0.681137168363091680, -0.681173775303102970, -0.681210380540179570, -0.681246984074230230, -0.681283585905163690, -0.681320186032887800, +-0.681356784457311630, -0.681393381178343360, -0.681429976195891960, -0.681466569509865390, -0.681503161120172280, -0.681539751026721370, -0.681576339229421290, -0.681612925728180220, +-0.681649510522906680, -0.681686093613509400, -0.681722674999897250, -0.681759254681978070, -0.681795832659660710, -0.681832408932853800, -0.681868983501466190, -0.681905556365405840, +-0.681942127524581500, -0.681978696978902230, -0.682015264728275890, -0.682051830772611440, -0.682088395111817290, -0.682124957745802620, -0.682161518674475160, -0.682198077897743890, +-0.682234635415517430, -0.682271191227704740, -0.682307745334213680, -0.682344297734953310, -0.682380848429832270, -0.682417397418759290, -0.682453944701642560, -0.682490490278390930, +-0.682527034148913140, -0.682563576313118040, -0.682600116770913700, -0.682636655522209090, -0.682673192566912720, -0.682709727904933890, -0.682746261536180340, -0.682782793460561030, +-0.682819323677985150, -0.682855852188360650, -0.682892378991596490, -0.682928904087601430, -0.682965427476284300, -0.683001949157553410, -0.683038469131317600, -0.683074987397485620, +-0.683111503955966540, -0.683148018806668310, -0.683184531949500020, -0.683221043384370510, -0.683257553111188630, -0.683294061129862570, -0.683330567440301300, -0.683367072042413650, +-0.683403574936108700, -0.683440076121294430, -0.683476575597880000, -0.683513073365774490, -0.683549569424885870, -0.683586063775123430, -0.683622556416395800, -0.683659047348612050, +-0.683695536571680360, -0.683732024085509820, -0.683768509890009260, -0.683804993985087760, -0.683841476370653510, -0.683877957046615470, -0.683914436012882600, -0.683950913269363860, +-0.683987388815967660, -0.684023862652602840, -0.684060334779178490, -0.684096805195603560, -0.684133273901786240, -0.684169740897635830, -0.684206206183061380, -0.684242669757971100, +-0.684279131622274160, -0.684315591775879310, -0.684352050218695830, -0.684388506950631910, -0.684424961971596750, -0.684461415281499170, -0.684497866880248380, -0.684534316767752670, +-0.684570764943921000, -0.684607211408662540, -0.684643656161886380, -0.684680099203500700, -0.684716540533414800, -0.684752980151537520, -0.684789418057778150, -0.684825854252044900, +-0.684862288734247040, -0.684898721504293760, -0.684935152562093250, -0.684971581907555030, -0.685008009540587710, -0.685044435461100830, -0.685080859669002450, -0.685117282164201980, +-0.685153702946608270, -0.685190122016130610, -0.685226539372677300, -0.685262955016157750, -0.685299368946480690, -0.685335781163555650, -0.685372191667290690, -0.685408600457595330, +-0.685445007534378540, -0.685481412897549380, -0.685517816547016490, -0.685554218482689050, -0.685590618704476020, -0.685627017212286800, -0.685663414006029700, -0.685699809085614120, +-0.685736202450949350, -0.685772594101943690, -0.685808984038506540, -0.685845372260546870, -0.685881758767974190, -0.685918143560696800, -0.685954526638624000, -0.685990908001664960, +-0.686027287649728870, -0.686063665582724250, -0.686100041800560500, -0.686136416303146700, -0.686172789090392140, -0.686209160162205230, -0.686245529518495490, -0.686281897159171870, +-0.686318263084143900, -0.686354627293319860, -0.686390989786609280, -0.686427350563921570, -0.686463709625165230, -0.686500066970249570, -0.686536422599083650, -0.686572776511577110, +-0.686609128707638240, -0.686645479187176560, -0.686681827950101240, -0.686718174996321600, -0.686754520325746240, -0.686790863938284480, -0.686827205833845710, -0.686863546012339230, +-0.686899884473673450, -0.686936221217758100, -0.686972556244502040, -0.687008889553815010, -0.687045221145605400, -0.687081551019782850, -0.687117879176256660, -0.687154205614935340, +-0.687190530335728630, -0.687226853338545610, -0.687263174623295780, -0.687299494189887670, -0.687335812038230800, -0.687372128168234340, -0.687408442579807930, -0.687444755272860200, +-0.687481066247300430, -0.687517375503038150, -0.687553683039982650, -0.687589988858042570, -0.687626292957127630, -0.687662595337146910, -0.687698895998010040, -0.687735194939625540, +-0.687771492161903140, -0.687807787664752040, -0.687844081448081730, -0.687880373511800870, -0.687916663855819070, -0.687952952480045950, -0.687989239384390160, -0.688025524568761200, +-0.688061808033068490, -0.688098089777221640, -0.688134369801129190, -0.688170648104700740, -0.688206924687845720, -0.688243199550473750, -0.688279472692493450, -0.688315744113814460, +-0.688352013814346080, -0.688388281793998020, -0.688424548052678940, -0.688460812590298450, -0.688497075406765970, -0.688533336501991110, -0.688569595875882620, -0.688605853528350130, +-0.688642109459303260, -0.688678363668650870, -0.688714616156302470, -0.688750866922167690, -0.688787115966155940, -0.688823363288176060, -0.688859608888137910, -0.688895852765950670, +-0.688932094921524070, -0.688968335354766980, -0.689004574065589010, -0.689040811053899580, -0.689077046319608420, -0.689113279862624490, -0.689149511682857210, -0.689185741780216190, +-0.689221970154611170, -0.689258196805950800, -0.689294421734145010, -0.689330644939103570, -0.689366866420735080, -0.689403086178949410, -0.689439304213656180, -0.689475520524764800, +-0.689511735112184440, -0.689547947975824750, -0.689584159115595120, -0.689620368531405400, -0.689656576223164560, -0.689692782190782120, -0.689728986434167800, -0.689765188953231360, +-0.689801389747881630, -0.689837588818028370, -0.689873786163581190, -0.689909981784449840, -0.689946175680543170, -0.689982367851771140, -0.690018558298043480, -0.690054747019269170, +-0.690090934015357930, -0.690127119286219280, -0.690163302831763300, -0.690199484651898620, -0.690235664746535300, -0.690271843115582760, -0.690308019758951060, -0.690344194676548840, +-0.690380367868286270, -0.690416539334072650, -0.690452709073818060, -0.690488877087431340, -0.690525043374822460, -0.690561207935901030, -0.690597370770576810, -0.690633531878758870, +-0.690669691260357150, -0.690705848915281080, -0.690742004843440840, -0.690778159044745270, -0.690814311519104220, -0.690850462266427770, -0.690886611286624760, -0.690922758579605280, +-0.690958904145278940, -0.690995047983555600, -0.691031190094344330, -0.691067330477555200, -0.691103469133097610, -0.691139606060881650, -0.691175741260816380, -0.691211874732811760, +-0.691248006476777530, -0.691284136492623550, -0.691320264780258990, -0.691356391339593590, -0.691392516170537320, -0.691428639273000130, -0.691464760646890890, -0.691500880292119870, +-0.691536998208596930, -0.691573114396231150, -0.691609228854932590, -0.691645341584611000, -0.691681452585176330, -0.691717561856537650, -0.691753669398605160, -0.691789775211288480, +-0.691825879294497680, -0.691861981648141940, -0.691898082272131120, -0.691934181166375170, -0.691970278330784060, -0.692006373765266860, -0.692042467469733860, -0.692078559444094580, +-0.692114649688259310, -0.692150738202137020, -0.692186824985637990, -0.692222910038672090, -0.692258993361148710, -0.692295074952977710, -0.692331154814069150, -0.692367232944333000, +-0.692403309343678440, -0.692439384012015550, -0.692475456949254280, -0.692511528155304700, -0.692547597630075900, -0.692583665373478150, -0.692619731385421210, -0.692655795665815250, +-0.692691858214569580, -0.692727919031594140, -0.692763978116798910, -0.692800035470094170, -0.692836091091388880, -0.692872144980593460, -0.692908197137617750, -0.692944247562371720, +-0.692980296254764870, -0.693016343214707180, -0.693052388442108920, -0.693088431936879410, -0.693124473698928930, -0.693160513728167120, -0.693196552024504480, -0.693232588587850080, +-0.693268623418114130, -0.693304656515206670, -0.693340687879037910, -0.693376717509517130, -0.693412745406554620, -0.693448771570060130, -0.693484795999944060, -0.693520818696115700, +-0.693556839658485250, -0.693592858886962650, -0.693628876381458430, -0.693664892141881540, -0.693700906168142390, -0.693736918460151400, -0.693772929017817730, -0.693808937841051800, +-0.693844944929763450, -0.693880950283863100, -0.693916953903260030, -0.693952955787864530, -0.693988955937586800, -0.694024954352336910, -0.694060951032024250, -0.694096945976559350, +-0.694132939185851950, -0.694168930659812560, -0.694204920398350580, -0.694240908401376200, -0.694276894668799600, -0.694312879200531090, -0.694348861996480160, -0.694384843056556900, +-0.694420822380672040, -0.694456799968734660, -0.694492775820655270, -0.694528749936344060, -0.694564722315711200, -0.694600692958666220, -0.694636661865119520, -0.694672629034981170, +-0.694708594468161580, -0.694744558164570150, -0.694780520124117400, -0.694816480346713280, -0.694852438832268330, -0.694888395580691930, -0.694924350591894500, -0.694960303865786330, +-0.694996255402277610, -0.695032205201277950, -0.695068153262697770, -0.695104099586447480, -0.695140044172436690, -0.695175987020575810, -0.695211928130774930, -0.695247867502944540, +-0.695283805136994170, -0.695319741032834340, -0.695355675190375110, -0.695391607609527010, -0.695427538290199540, -0.695463467232303230, -0.695499394435748260, -0.695535319900445150, +-0.695571243626303510, -0.695607165613233660, -0.695643085861145870, -0.695679004369950670, -0.695714921139557680, -0.695750836169877430, -0.695786749460820090, -0.695822661012296170, +-0.695858570824215210, -0.695894478896487920, -0.695930385229024730, -0.695966289821735140, -0.696002192674530010, -0.696038093787319290, -0.696073993160013730, -0.696109890792522720, +-0.696145786684757130, -0.696181680836627010, -0.696217573248043010, -0.696253463918914850, -0.696289352849152940, -0.696325240038667690, -0.696361125487369610, -0.696397009195168340, +-0.696432891161974710, -0.696468771387698690, -0.696504649872251140, -0.696540526615541670, -0.696576401617480910, -0.696612274877979390, -0.696648146396946940, -0.696684016174293990, +-0.696719884209931140, -0.696755750503768810, -0.696791615055716850, -0.696827477865685770, -0.696863338933586100, -0.696899198259328330, -0.696935055842822230, -0.696970911683978510, +-0.697006765782707590, -0.697042618138919990, -0.697078468752525550, -0.697114317623434900, -0.697150164751558550, -0.697186010136807030, -0.697221853779090180, -0.697257695678318630, +-0.697293535834403230, -0.697329374247253720, -0.697365210916780720, -0.697401045842894750, -0.697436879025506440, -0.697472710464525520, -0.697508540159862970, -0.697544368111429060, +-0.697580194319134430, -0.697616018782889040, -0.697651841502603730, -0.697687662478188700, -0.697723481709554780, -0.697759299196611950, -0.697795114939270820, -0.697830928937441920, +-0.697866741191035980, -0.697902551699962960, -0.697938360464133490, -0.697974167483458090, -0.698009972757847600, -0.698045776287211980, -0.698081578071461760, -0.698117378110508000, +-0.698153176404260440, -0.698188972952630050, -0.698224767755527110, -0.698260560812862590, -0.698296352124546330, -0.698332141690489180, -0.698367929510601780, -0.698403715584794750, +-0.698439499912978160, -0.698475282495062850, -0.698511063330959360, -0.698546842420578410, -0.698582619763830180, -0.698618395360625310, -0.698654169210874420, -0.698689941314488470, +-0.698725711671377430, -0.698761480281452020, -0.698797247144623210, -0.698833012260801080, -0.698868775629896350, -0.698904537251819670, -0.698940297126481980, -0.698976055253793140, +-0.699011811633664220, -0.699047566266005840, -0.699083319150728850, -0.699119070287743230, -0.699154819676959920, -0.699190567318289440, -0.699226313211642970, -0.699262057356930480, +-0.699297799754062810, -0.699333540402950590, -0.699369279303504790, -0.699405016455635580, -0.699440751859253810, -0.699476485514270330, -0.699512217420595440, -0.699547947578140090, +-0.699583675986814700, -0.699619402646530550, -0.699655127557197610, -0.699690850718726720, -0.699726572131028850, -0.699762291794014720, -0.699798009707594650, -0.699833725871679580, +-0.699869440286180140, -0.699905152951007410, -0.699940863866071460, -0.699976573031283360, -0.700012280446553840, -0.700047986111793970, -0.700083690026913840, -0.700119392191824400, +-0.700155092606436820, -0.700190791270661190, -0.700226488184408580, -0.700262183347589830, -0.700297876760115790, -0.700333568421896870, -0.700369258332844020, -0.700404946492868000, +-0.700440632901879860, -0.700476317559789900, -0.700512000466509080, -0.700547681621948360, -0.700583361026018700, -0.700619038678630290, -0.700654714579694420, -0.700690388729121590, +-0.700726061126823120, -0.700761731772709280, -0.700797400666691050, -0.700833067808679380, -0.700868733198585340, -0.700904396836319110, -0.700940058721791880, -0.700975718854914830, +-0.701011377235598250, -0.701047033863753110, -0.701082688739290470, -0.701118341862121410, -0.701153993232156100, -0.701189642849305850, -0.701225290713481500, -0.701260936824594230, +-0.701296581182554330, -0.701332223787273000, -0.701367864638661080, -0.701403503736629740, -0.701439141081089400, -0.701474776671951240, -0.701510410509126100, -0.701546042592525290, +-0.701581672922058970, -0.701617301497638570, -0.701652928319175140, -0.701688553386579090, -0.701724176699761730, -0.701759798258633880, -0.701795418063106860, -0.701831036113090940, +-0.701866652408497550, -0.701902266949237410, -0.701937879735221930, -0.701973490766361510, -0.702009100042567220, -0.702044707563750260, -0.702080313329821900, -0.702115917340692340, +-0.702151519596273090, -0.702187120096474990, -0.702222718841209460, -0.702258315830386780, -0.702293911063918250, -0.702329504541715280, -0.702365096263688260, -0.702400686229748490, +-0.702436274439807050, -0.702471860893775220, -0.702507445591563420, -0.702543028533083040, -0.702578609718244930, -0.702614189146960830, -0.702649766819140820, -0.702685342734696410, +-0.702720916893538660, -0.702756489295578880, -0.702792059940727580, -0.702827628828896160, -0.702863195959995690, -0.702898761333937470, -0.702934324950632130, -0.702969886809990840, +-0.703005446911924900, -0.703041005256345720, -0.703076561843163690, -0.703112116672290230, -0.703147669743636740, -0.703183221057113840, -0.703218770612632940, -0.703254318410104990, +-0.703289864449441640, -0.703325408730553270, -0.703360951253351410, -0.703396492017747120, -0.703432031023651930, -0.703467568270976340, -0.703503103759631880, -0.703538637489529610, +-0.703574169460581160, -0.703609699672696930, -0.703645228125788340, -0.703680754819766770, -0.703716279754543650, -0.703751802930029480, -0.703787324346135890, -0.703822844002774170, +-0.703858361899855070, -0.703893878037290090, -0.703929392414990420, -0.703964905032867570, -0.704000415890832070, -0.704035924988795640, -0.704071432326669360, -0.704106937904364740, +-0.704142441721792520, -0.704177943778864220, -0.704213444075491140, -0.704248942611584660, -0.704284439387055540, -0.704319934401815280, -0.704355427655775190, -0.704390919148846880, +-0.704426408880940880, -0.704461896851968920, -0.704497383061842620, -0.704532867510472390, -0.704568350197770090, -0.704603831123646880, -0.704639310288014410, -0.704674787690783400, +-0.704710263331865370, -0.704745737211171620, -0.704781209328613990, -0.704816679684102890, -0.704852148277550160, -0.704887615108866990, -0.704923080177965230, -0.704958543484755400, +-0.704994005029149110, -0.705029464811057880, -0.705064922830393350, -0.705100379087066130, -0.705135833580987970, -0.705171286312070600, -0.705206737280224650, -0.705242186485361850, +-0.705277633927393620, -0.705313079606231570, -0.705348523521786560, -0.705383965673970210, -0.705419406062694040, -0.705454844687869560, -0.705490281549407630, -0.705525716647220080, +-0.705561149981218220, -0.705596581551313770, -0.705632011357417600, -0.705667439399441320, -0.705702865677296560, -0.705738290190894850, -0.705773712940147120, -0.705809133924965140, +-0.705844553145260290, -0.705879970600944430, -0.705915386291928290, -0.705950800218123620, -0.705986212379442370, -0.706021622775795170, -0.706057031407093970, -0.706092438273250190, +-0.706127843374175670, -0.706163246709781140, -0.706198648279978580, -0.706234048084679380, -0.706269446123795390, -0.706304842397237450, -0.706340236904917430, -0.706375629646746720, +-0.706411020622637280, -0.706446409832500070, -0.706481797276246710, -0.706517182953788960, -0.706552566865038530, -0.706587949009906400, -0.706623329388304300, -0.706658708000144300, +-0.706694084845337130, -0.706729459923794880, -0.706764833235428820, -0.706800204780151150, -0.706835574557872490, -0.706870942568505020, -0.706906308811960150, -0.706941673288149830, +-0.706977035996984910, -0.707012396938377590, -0.707047756112239130, -0.707083113518481630, -0.707118469157016040, -0.707153823027754310, -0.707189175130607970, -0.707224525465489080, +-0.707259874032308500, -0.707295220830978180, -0.707330565861410300, -0.707365909123515490, -0.707401250617206050, -0.707436590342393480, -0.707471928298989640, -0.707507264486905710, +-0.707542598906053750, -0.707577931556345190, -0.707613262437692070, -0.707648591550005480, -0.707683918893197480, -0.707719244467179600, -0.707754568271864000, -0.707789890307161660, +-0.707825210572984640, -0.707860529069244460, -0.707895845795853410, -0.707931160752722330, -0.707966473939763310, -0.708001785356888180, -0.708037095004008910, -0.708072402881036570, +-0.708107708987883220, -0.708143013324460950, -0.708178315890680810, -0.708213616686454880, -0.708248915711694900, -0.708284212966312940, -0.708319508450220180, -0.708354802163328690, +-0.708390094105549980, -0.708425384276796580, -0.708460672676979320, -0.708495959306010390, -0.708531244163801530, -0.708566527250264810, -0.708601808565311520, -0.708637088108853730, +-0.708672365880803290, -0.708707641881072160, -0.708742916109571630, -0.708778188566213770, -0.708813459250910880, -0.708848728163573920, -0.708883995304115170, -0.708919260672446370, +-0.708954524268479820, -0.708989786092126590, -0.709025046143298980, -0.709060304421908590, -0.709095560927867850, -0.709130815661087930, -0.709166068621480910, -0.709201319808958730, +-0.709236569223433590, -0.709271816864816770, -0.709307062733020350, -0.709342306827956180, -0.709377549149536660, -0.709412789697672960, -0.709448028472277280, -0.709483265473261790, +-0.709518500700537900, -0.709553734154017680, -0.709588965833613190, -0.709624195739236630, -0.709659423870799170, -0.709694650228213210, -0.709729874811390600, -0.709765097620243650, +-0.709800318654683520, -0.709835537914622730, -0.709870755399973020, -0.709905971110646790, -0.709941185046555350, -0.709976397207610850, -0.710011607593725390, -0.710046816204811250, +-0.710082023040779720, -0.710117228101543210, -0.710152431387013560, -0.710187632897103180, -0.710222832631723370, -0.710258030590786520, -0.710293226774204920, -0.710328421181889880, +-0.710363613813753790, -0.710398804669708730, -0.710433993749666870, -0.710469181053539730, -0.710504366581239720, -0.710539550332678790, -0.710574732307769240, -0.710609912506422580, +-0.710645090928551100, -0.710680267574066880, -0.710715442442882430, -0.710750615534908920, -0.710785786850059000, -0.710820956388244500, -0.710856124149377930, -0.710891290133370820, +-0.710926454340135350, -0.710961616769584140, -0.710996777421628590, -0.711031936296181110, -0.711067093393153770, -0.711102248712458970, -0.711137402254008340, -0.711172554017714060, +-0.711207704003488540, -0.711242852211243950, -0.711277998640892030, -0.711313143292345070, -0.711348286165515260, -0.711383427260315000, -0.711418566576655920, -0.711453704114450300, +-0.711488839873610560, -0.711523973854048860, -0.711559106055677180, -0.711594236478407580, -0.711629365122152690, -0.711664491986824020, -0.711699617072334200, -0.711734740378595410, +-0.711769861905519940, -0.711804981653019640, -0.711840099621006810, -0.711875215809393720, -0.711910330218092910, -0.711945442847016000, -0.711980553696075490, -0.712015662765183470, +-0.712050770054252660, -0.712085875563194690, -0.712120979291921970, -0.712156081240346910, -0.712191181408381780, -0.712226279795938550, -0.712261376402929520, -0.712296471229267420, +-0.712331564274863770, -0.712366655539631300, -0.712401745023482080, -0.712436832726328850, -0.712471918648083240, -0.712507002788657860, -0.712542085147964910, -0.712577165725917120, +-0.712612244522426110, -0.712647321537404400, -0.712682396770764500, -0.712717470222418830, -0.712752541892279210, -0.712787611780258290, -0.712822679886268240, -0.712857746210221800, +-0.712892810752030700, -0.712927873511607690, -0.712962934488864830, -0.712997993683715080, -0.713033051096069960, -0.713068106725842200, -0.713103160572944540, -0.713138212637288720, +-0.713173262918787240, -0.713208311417352640, -0.713243358132897630, -0.713278403065333850, -0.713313446214574150, -0.713348487580530710, -0.713383527163116480, -0.713418564962243100, +-0.713453600977823180, -0.713488635209769350, -0.713523667657994240, -0.713558698322409700, -0.713593727202928350, -0.713628754299462710, -0.713663779611925510, -0.713698803140228490, +-0.713733824884284500, -0.713768844844006270, -0.713803863019305540, -0.713838879410095270, -0.713873894016287760, -0.713908906837795840, -0.713943917874531260, -0.713978927126406980, +-0.714013934593335400, -0.714048940275229250, -0.714083944172000380, -0.714118946283561760, -0.714153946609825670, -0.714188945150705080, -0.714223941906111830, -0.714258936875958650, +-0.714293930060158290, -0.714328921458623260, -0.714363911071265620, -0.714398898897998240, -0.714433884938733940, -0.714468869193384590, -0.714503851661863140, -0.714538832344082000, +-0.714573811239954000, -0.714608788349391340, -0.714643763672306640, -0.714678737208612520, -0.714713708958221840, -0.714748678921046650, -0.714783647096999710, -0.714818613485993630, +-0.714853578087941370, -0.714888540902754780, -0.714923501930346930, -0.714958461170630330, -0.714993418623517840, -0.715028374288921520, -0.715063328166754220, -0.715098280256928680, +-0.715133230559357620, -0.715168179073953250, -0.715203125800628500, -0.715238070739296240, -0.715273013889868410, -0.715307955252257990, -0.715342894826377810, -0.715377832612140610, +-0.715412768609458680, -0.715447702818244660, -0.715482635238411380, -0.715517565869871920, -0.715552494712538230, -0.715587421766323280, -0.715622347031139800, -0.715657270506900640, +-0.715692192193518100, -0.715727112090905120, -0.715762030198974220, -0.715796946517638700, -0.715831861046810400, -0.715866773786402510, -0.715901684736327980, -0.715936593896499000, +-0.715971501266828400, -0.716006406847229160, -0.716041310637614110, -0.716076212637895450, -0.716111112847986450, -0.716146011267799530, -0.716180907897247860, -0.716215802736243630, +-0.716250695784700020, -0.716285587042529540, -0.716320476509645370, -0.716355364185959800, -0.716390250071385900, -0.716425134165836200, -0.716460016469224080, -0.716494896981461520, +-0.716529775702461790, -0.716564652632137870, -0.716599527770402030, -0.716634401117167470, -0.716669272672346810, -0.716704142435853230, -0.716739010407599130, -0.716773876587497360, +-0.716808740975460990, -0.716843603571403090, -0.716878464375235720, -0.716913323386872410, -0.716948180606225670, -0.716983036033208790, -0.717017889667734050, -0.717052741509714540, +-0.717087591559063210, -0.717122439815693240, -0.717157286279516800, -0.717192130950447090, -0.717226973828397400, -0.717261814913280120, -0.717296654205008100, -0.717331491703494530, +-0.717366327408652580, -0.717401161320394440, -0.717435993438633400, -0.717470823763282420, -0.717505652294254670, -0.717540479031462560, -0.717575303974819170, -0.717610127124237440, +-0.717644948479630780, -0.717679768040911490, -0.717714585807992740, -0.717749401780787500, -0.717784215959209050, -0.717819028343169800, -0.717853838932582920, -0.717888647727361500, +-0.717923454727418810, -0.717958259932667040, -0.717993063343019710, -0.718027864958390110, -0.718062664778690410, -0.718097462803834130, -0.718132259033734120, -0.718167053468303780, +-0.718201846107455520, -0.718236636951102620, -0.718271425999158280, -0.718306213251535430, -0.718340998708146940, -0.718375782368905870, -0.718410564233725400, -0.718445344302518720, +-0.718480122575198440, -0.718514899051677870, -0.718549673731870060, -0.718584446615688320, -0.718619217703045150, -0.718653986993853970, -0.718688754488028160, -0.718723520185480140, +-0.718758284086123300, -0.718793046189870720, -0.718827806496635910, -0.718862565006331280, -0.718897321718870110, -0.718932076634165810, -0.718966829752131440, -0.719001581072679860, +-0.719036330595724250, -0.719071078321177780, -0.719105824248953970, -0.719140568378965230, -0.719175310711125170, -0.719210051245346760, -0.719244789981543620, -0.719279526919628040, +-0.719314262059513760, -0.719348995401114080, -0.719383726944341720, -0.719418456689109980, -0.719453184635332030, -0.719487910782921510, -0.719522635131790820, -0.719557357681853580, +-0.719592078433022970, -0.719626797385212400, -0.719661514538334600, -0.719696229892303090, -0.719730943447030810, -0.719765655202431630, -0.719800365158417940, -0.719835073314903370, +-0.719869779671801100, -0.719904484229024640, -0.719939186986486730, -0.719973887944100890, -0.720008587101780280, -0.720043284459438440, -0.720077980016988200, -0.720112673774342960, +-0.720147365731416360, -0.720182055888121010, -0.720216744244370540, -0.720251430800078250, -0.720286115555157650, -0.720320798509521350, -0.720355479663083220, -0.720390159015756320, +-0.720424836567454370, -0.720459512318089910, -0.720494186267576770, -0.720528858415828140, -0.720563528762757640, -0.720598197308278010, -0.720632864052302980, -0.720667528994745730, +-0.720702192135519890, -0.720736853474538420, -0.720771513011714720, -0.720806170746962520, -0.720840826680194670, -0.720875480811324690, -0.720910133140266090, -0.720944783666932270, +-0.720979432391236410, -0.721014079313091800, -0.721048724432412080, -0.721083367749110860, -0.721118009263100880, -0.721152648974295980, -0.721187286882609250, -0.721221922987954840, +-0.721256557290245180, -0.721291189789394100, -0.721325820485315130, -0.721360449377921880, -0.721395076467127190, -0.721429701752844820, -0.721464325234988600, -0.721498946913471160, +-0.721533566788206350, -0.721568184859107680, -0.721602801126088770, -0.721637415589062580, -0.721672028247942850, -0.721706639102643100, -0.721741248153076940, -0.721775855399157450, +-0.721810460840798360, -0.721845064477913080, -0.721879666310415450, -0.721914266338218310, -0.721948864561235530, -0.721983460979380600, -0.722018055592567260, -0.722052648400708490, +-0.722087239403718220, -0.722121828601509970, -0.722156415993997050, -0.722191001581092950, -0.722225585362711420, -0.722260167338766190, -0.722294747509170220, -0.722329325873837360, +-0.722363902432681230, -0.722398477185615670, -0.722433050132553540, -0.722467621273408910, -0.722502190608095060, -0.722536758136526180, -0.722571323858615000, -0.722605887774275590, +-0.722640449883421470, -0.722675010185966470, -0.722709568681823680, -0.722744125370906930, -0.722778680253129860, -0.722813233328406410, -0.722847784596649670, -0.722882334057773360, +-0.722916881711691550, -0.722951427558317210, -0.722985971597564390, -0.723020513829346510, -0.723055054253577740, -0.723089592870170940, -0.723124129679040270, -0.723158664680099150, +-0.723193197873261750, -0.723227729258441140, -0.723262258835551060, -0.723296786604505360, -0.723331312565218100, -0.723365836717602130, -0.723400359061571630, -0.723434879597040230, +-0.723469398323921880, -0.723503915242129870, -0.723538430351577940, -0.723572943652180280, -0.723607455143849940, -0.723641964826500890, -0.723676472700047090, -0.723710978764402270, +-0.723745483019479830, -0.723779985465193620, -0.723814486101457490, -0.723848984928185390, -0.723883481945290510, -0.723917977152686910, -0.723952470550288440, -0.723986962138009170, +-0.724021451915762060, -0.724055939883461290, -0.724090426041020810, -0.724124910388354470, -0.724159392925375570, -0.724193873651998170, -0.724228352568136450, -0.724262829673703480, +-0.724297304968613440, -0.724331778452780180, -0.724366250126117770, -0.724400719988539390, -0.724435188039959320, -0.724469654280291200, -0.724504118709449200, -0.724538581327346610, +-0.724573042133897620, -0.724607501129016060, -0.724641958312616020, -0.724676413684610780, -0.724710867244914510, -0.724745318993440970, -0.724779768930104540, -0.724814217054818410, +-0.724848663367496650, -0.724883107868053320, -0.724917550556402390, -0.724951991432457370, -0.724986430496132430, -0.725020867747341650, -0.725055303185998420, -0.725089736812016940, +-0.725124168625311040, -0.725158598625795130, -0.725193026813382380, -0.725227453187986980, -0.725261877749523000, -0.725296300497904720, -0.725330721433045330, -0.725365140554859120, +-0.725399557863260050, -0.725433973358162400, -0.725468387039479470, -0.725502798907125660, -0.725537208961014810, -0.725571617201061230, -0.725606023627178300, -0.725640428239280320, +-0.725674831037281590, -0.725709232021095390, -0.725743631190636230, -0.725778028545817970, -0.725812424086554890, -0.725846817812760500, -0.725881209724349000, -0.725915599821234550, +-0.725949988103331450, -0.725984374570552980, -0.726018759222813560, -0.726053142060027360, -0.726087523082108440, -0.726121902288970440, -0.726156279680527870, -0.726190655256694460, +-0.726225029017384730, -0.726259400962512070, -0.726293771091991000, -0.726328139405735710, -0.726362505903659810, -0.726396870585677700, -0.726431233451703350, -0.726465594501651270, +-0.726499953735434860, -0.726534311152968630, -0.726568666754166540, -0.726603020538943100, -0.726637372507211830, -0.726671722658887130, -0.726706070993883180, -0.726740417512114270, +-0.726774762213494020, -0.726809105097936840, -0.726843446165357010, -0.726877785415668830, -0.726912122848785810, -0.726946458464622580, -0.726980792263093420, -0.727015124244111970, +-0.727049454407592830, -0.727083782753449980, -0.727118109281597920, -0.727152433991950400, -0.727186756884421690, -0.727221077958926100, -0.727255397215378130, -0.727289714653691410, +-0.727324030273780340, -0.727358344075559220, -0.727392656058942540, -0.727426966223843950, -0.727461274570177950, -0.727495581097858720, -0.727529885806800890, -0.727564188696917970, +-0.727598489768124690, -0.727632789020335120, -0.727667086453463900, -0.727701382067424630, -0.727735675862131840, -0.727769967837500250, -0.727804257993443390, -0.727838546329875990, +-0.727872832846712110, -0.727907117543866500, -0.727941400421252770, -0.727975681478785660, -0.728009960716379250, -0.728044238133948250, -0.728078513731406310, -0.728112787508668150, +-0.728147059465647950, -0.728181329602260450, -0.728215597918419280, -0.728249864414039160, -0.728284129089034390, -0.728318391943319600, -0.728352652976808510, -0.728386912189415760, +-0.728421169581056070, -0.728455425151643080, -0.728489678901091620, -0.728523930829315880, -0.728558180936230810, -0.728592429221749830, -0.728626675685787760, -0.728660920328259020, +-0.728695163149078340, -0.728729404148159340, -0.728763643325416990, -0.728797880680765340, -0.728832116214119360, -0.728866349925392900, -0.728900581814500460, -0.728934811881356560, +-0.728969040125875930, -0.729003266547972430, -0.729037491147560780, -0.729071713924555720, -0.729105934878871100, -0.729140154010421540, -0.729174371319121660, -0.729208586804886090, +-0.729242800467628790, -0.729277012307264490, -0.729311222323707710, -0.729345430516873170, -0.729379636886674730, -0.729413841433027120, -0.729448044155844970, -0.729482245055043000, +-0.729516444130535180, -0.729550641382236130, -0.729584836810060590, -0.729619030413923180, -0.729653222193737960, -0.729687412149419680, -0.729721600280882840, -0.729755786588042300, +-0.729789971070812000, -0.729824153729106690, -0.729858334562841440, -0.729892513571929970, -0.729926690756287240, -0.729960866115827670, -0.729995039650466420, -0.730029211360117230, +-0.730063381244694940, -0.730097549304114190, -0.730131715538289930, -0.730165879947136110, -0.730200042530567470, -0.730234203288498860, -0.730268362220845010, -0.730302519327519880, +-0.730336674608438540, -0.730370828063515390, -0.730404979692665600, -0.730439129495803030, -0.730473277472842520, -0.730507423623699250, -0.730541567948287060, -0.730575710446521030, +-0.730609851118315670, -0.730643989963585930, -0.730678126982245990, -0.730712262174210700, -0.730746395539394800, -0.730780527077713130, -0.730814656789079970, -0.730848784673409970, +-0.730882910730618170, -0.730917034960619330, -0.730951157363327610, -0.730985277938658080, -0.731019396686525270, -0.731053513606844340, -0.731087628699529260, -0.731121741964495090, +-0.731155853401656900, -0.731189963010928760, -0.731224070792225730, -0.731258176745462450, -0.731292280870554200, -0.731326383167414830, -0.731360483635959510, -0.731394582276102990, +-0.731428679087760330, -0.731462774070845700, -0.731496867225273960, -0.731530958550960290, -0.731565048047819410, -0.731599135715765620, -0.731633221554713890, -0.731667305564579260, +-0.731701387745276600, -0.731735468096720190, -0.731769546618825100, -0.731803623311506500, -0.731837698174678470, -0.731871771208256190, -0.731905842412154510, -0.731939911786288590, +-0.731973979330572510, -0.732008045044921450, -0.732042108929250370, -0.732076170983474220, -0.732110231207507400, -0.732144289601264990, -0.732178346164661820, -0.732212400897613190, +-0.732246453800033170, -0.732280504871837050, -0.732314554112939660, -0.732348601523256200, -0.732382647102700850, -0.732416690851188990, -0.732450732768635370, -0.732484772854955170, +-0.732518811110062900, -0.732552847533873400, -0.732586882126302190, -0.732620914887263440, -0.732654945816672450, -0.732688974914444070, -0.732723002180493470, -0.732757027614735160, +-0.732791051217084210, -0.732825072987455690, -0.732859092925764790, -0.732893111031925890, -0.732927127305854190, -0.732961141747464630, -0.732995154356672510, -0.733029165133392220, +-0.733063174077539070, -0.733097181189027890, -0.733131186467774200, -0.733165189913692170, -0.733199191526697100, -0.733233191306704390, -0.733267189253628440, -0.733301185367384530, +-0.733335179647887640, -0.733369172095053030, -0.733403162708795240, -0.733437151489029550, -0.733471138435671020, -0.733505123548634840, -0.733539106827835630, -0.733573088273188680, +-0.733607067884608940, -0.733641045662011830, -0.733675021605311840, -0.733708995714424270, -0.733742967989264310, -0.733776938429747120, -0.733810907035787330, -0.733844873807300240, +-0.733878838744201230, -0.733912801846404950, -0.733946763113826560, -0.733980722546381250, -0.734014680143984520, -0.734048635906550780, -0.734082589833995440, -0.734116541926233550, +-0.734150492183180740, -0.734184440604751300, -0.734218387190860740, -0.734252331941424250, -0.734286274856357220, -0.734320215935574280, -0.734354155178990720, -0.734388092586521820, +-0.734422028158082880, -0.734455961893588750, -0.734489893792954600, -0.734523823856095710, -0.734557752082927620, -0.734591678473364710, -0.734625603027322830, -0.734659525744717050, +-0.734693446625462210, -0.734727365669473830, -0.734761282876666980, -0.734795198246957160, -0.734829111780259110, -0.734863023476488240, -0.734896933335559940, -0.734930841357389510, +-0.734964747541891560, -0.734998651888981950, -0.735032554398575620, -0.735066455070588210, -0.735100353904934330, -0.735134250901529620, -0.735168146060289240, -0.735202039381128820, +-0.735235930863962990, -0.735269820508707370, -0.735303708315277470, -0.735337594283587910, -0.735371478413554550, -0.735405360705092330, -0.735439241158117100, -0.735473119772543370, +-0.735506996548287000, -0.735540871485263040, -0.735574744583387230, -0.735608615842574200, -0.735642485262739680, -0.735676352843798950, -0.735710218585667650, -0.735744082488260510, +-0.735777944551493150, -0.735811804775280850, -0.735845663159539360, -0.735879519704183530, -0.735913374409128850, -0.735947227274290960, -0.735981078299584810, -0.736014927484925810, +-0.736048774830229680, -0.736082620335411830, -0.736116464000387110, -0.736150305825071240, -0.736184145809379630, -0.736217983953227910, -0.736251820256530910, -0.736285654719204370, +-0.736319487341163810, -0.736353318122324740, -0.736387147062602110, -0.736420974161911550, -0.736454799420168560, -0.736488622837289000, -0.736522444413187480, -0.736556264147779860, +-0.736590082040981860, -0.736623898092708340, -0.736657712302875130, -0.736691524671397650, -0.736725335198191610, -0.736759143883171990, -0.736792950726254390, -0.736826755727354570, +-0.736860558886388020, -0.736894360203269820, -0.736928159677915810, -0.736961957310241280, -0.736995753100162190, -0.737029547047593490, -0.737063339152450810, -0.737097129414649890, +-0.737130917834106340, -0.737164704410735340, -0.737198489144452410, -0.737232272035173390, -0.737266053082813900, -0.737299832287289010, -0.737333609648514580, -0.737367385166406430, +-0.737401158840879420, -0.737434930671849620, -0.737468700659232420, -0.737502468802943790, -0.737536235102898670, -0.737569999559013030, -0.737603762171202380, -0.737637522939382560, +-0.737671281863468640, -0.737705038943376580, -0.737738794179021880, -0.737772547570320510, -0.737806299117187430, -0.737840048819538690, -0.737873796677289700, -0.737907542690356630, +-0.737941286858654340, -0.737975029182098900, -0.738008769660606130, -0.738042508294091130, -0.738076245082469830, -0.738109980025658090, -0.738143713123571520, -0.738177444376125420, +-0.738211173783235750, -0.738244901344818130, -0.738278627060788510, -0.738312350931062070, -0.738346072955554660, -0.738379793134182230, -0.738413511466860520, -0.738447227953504700, +-0.738480942594030850, -0.738514655388354700, -0.738548366336392090, -0.738582075438058430, -0.738615782693269440, -0.738649488101941310, -0.738683191663989210, -0.738716893379329110, +-0.738750593247876840, -0.738784291269548250, -0.738817987444258750, -0.738851681771924170, -0.738885374252460480, -0.738919064885783630, -0.738952753671808790, -0.738986440610452160, +-0.739020125701629340, -0.739053808945256520, -0.739087490341248880, -0.739121169889522590, -0.739154847589993280, -0.739188523442577130, -0.739222197447189420, -0.739255869603746230, +-0.739289539912163400, -0.739323208372356880, -0.739356874984242190, -0.739390539747735280, -0.739424202662752330, -0.739457863729208520, -0.739491522947020030, -0.739525180316102810, +-0.739558835836372830, -0.739592489507745590, -0.739626141330137040, -0.739659791303463150, -0.739693439427640210, -0.739727085702583160, -0.739760730128208530, -0.739794372704432050, +-0.739828013431170000, -0.739861652308337450, -0.739895289335850910, -0.739928924513626130, -0.739962557841579270, -0.739996189319625740, -0.740029818947681830, -0.740063446725663600, +-0.740097072653486450, -0.740130696731066570, -0.740164318958320020, -0.740197939335162980, -0.740231557861510740, -0.740265174537279690, -0.740298789362385580, -0.740332402336744910, +-0.740366013460272860, -0.740399622732885840, -0.740433230154499690, -0.740466835725030800, -0.740500439444394480, -0.740534041312507220, -0.740567641329284650, -0.740601239494643400, +-0.740634835808498760, -0.740668430270766900, -0.740702022881364440, -0.740735613640206570, -0.740769202547209570, -0.740802789602289740, -0.740836374805363020, -0.740869958156345270, +-0.740903539655152430, -0.740937119301700810, -0.740970697095906790, -0.741004273037685680, -0.741037847126953860, -0.741071419363627410, -0.741104989747622730, -0.741138558278855220, +-0.741172124957241380, -0.741205689782697300, -0.741239252755139240, -0.741272813874482630, -0.741306373140644070, -0.741339930553539860, -0.741373486113085620, -0.741407039819197640, +-0.741440591671791990, -0.741474141670785180, -0.741507689816092720, -0.741541236107631010, -0.741574780545316230, -0.741608323129064770, -0.741641863858792270, -0.741675402734415120, +-0.741708939755849390, -0.741742474923011710, -0.741776008235817350, -0.741809539694183170, -0.741843069298025130, -0.741876597047259610, -0.741910122941802360, -0.741943646981569780, +-0.741977169166478050, -0.742010689496443780, -0.742044207971382490, -0.742077724591210570, -0.742111239355844780, -0.742144752265200490, -0.742178263319194340, -0.742211772517742510, +-0.742245279860761610, -0.742278785348167160, -0.742312288979875780, -0.742345790755803650, -0.742379290675867280, -0.742412788739982510, -0.742446284948065750, -0.742479779300033170, +-0.742513271795801620, -0.742546762435286390, -0.742580251218404430, -0.742613738145071810, -0.742647223215205040, -0.742680706428719970, -0.742714187785533220, -0.742747667285561190, +-0.742781144928719610, -0.742814620714925320, -0.742848094644094510, -0.742881566716143580, -0.742915036930988590, -0.742948505288545950, -0.742981971788732040, -0.743015436431463620, +-0.743048899216656180, -0.743082360144226460, -0.743115819214090980, -0.743149276426166130, -0.743182731780367870, -0.743216185276612710, -0.743249636914817160, -0.743283086694897730, +-0.743316534616770390, -0.743349980680351630, -0.743383424885558310, -0.743416867232306040, -0.743450307720511570, -0.743483746350091400, -0.743517183120962160, -0.743550618033039680, +-0.743584051086240590, -0.743617482280481410, -0.743650911615678870, -0.743684339091748690, -0.743717764708607730, -0.743751188466172270, -0.743784610364359170, -0.743818030403084250, +-0.743851448582264260, -0.743884864901815710, -0.743918279361655220, -0.743951691961698750, -0.743985102701863020, -0.744018511582064560, -0.744051918602220090, -0.744085323762245570, +-0.744118727062057730, -0.744152128501573420, -0.744185528080708480, -0.744218925799379650, -0.744252321657503440, -0.744285715654996900, -0.744319107791775680, -0.744352498067756720, +-0.744385886482856530, -0.744419273036991850, -0.744452657730078740, -0.744486040562033930, -0.744519421532774170, -0.744552800642215960, -0.744586177890275590, -0.744619553276869680, +-0.744652926801914970, -0.744686298465328190, -0.744719668267025400, -0.744753036206923460, -0.744786402284939200, -0.744819766500988580, -0.744853128854988670, -0.744886489346855860, +-0.744919847976507010, -0.744953204743858400, -0.744986559648826760, -0.745019912691328720, -0.745053263871281120, -0.745086613188600140, -0.745119960643202630, -0.745153306235005200, +-0.745186649963924810, -0.745219991829877420, -0.745253331832780200, -0.745286669972549440, -0.745320006249102550, -0.745353340662355150, -0.745386673212224520, -0.745420003898627390, +-0.745453332721480070, -0.745486659680699380, -0.745519984776202070, -0.745553308007904980, -0.745586629375724400, -0.745619948879577280, -0.745653266519380240, -0.745686582295050360, +-0.745719896206503700, -0.745753208253657320, -0.745786518436427960, -0.745819826754732460, -0.745853133208487230, -0.745886437797609100, -0.745919740522014930, -0.745953041381621770, +-0.745986340376345590, -0.746019637506103560, -0.746052932770812750, -0.746086226170389330, -0.746119517704750380, -0.746152807373812510, -0.746186095177493120, -0.746219381115708070, +-0.746252665188374520, -0.746285947395409320, -0.746319227736729650, -0.746352506212251580, -0.746385782821892270, -0.746419057565568370, -0.746452330443197250, -0.746485601454695000, +-0.746518870599978680, -0.746552137878965240, -0.746585403291571750, -0.746618666837714380, -0.746651928517310440, -0.746685188330276640, -0.746718446276530170, -0.746751702355987200, +-0.746784956568565140, -0.746818208914180940, -0.746851459392750770, -0.746884708004192150, -0.746917954748421600, -0.746951199625356610, -0.746984442634913260, -0.747017683777008830, +-0.747050923051560070, -0.747084160458484470, -0.747117395997698000, -0.747150629669118160, -0.747183861472661690, -0.747217091408245880, -0.747250319475787130, -0.747283545675202500, +-0.747316770006408950, -0.747349992469323880, -0.747383213063863460, -0.747416431789944990, -0.747449648647485860, -0.747482863636402150, -0.747516076756611470, -0.747549288008030440, +-0.747582497390576470, -0.747615704904166070, -0.747648910548716410, -0.747682114324144440, -0.747715316230367470, -0.747748516267301880, -0.747781714434865070, -0.747814910732973900, +-0.747848105161545870, -0.747881297720497160, -0.747914488409745280, -0.747947677229207190, -0.747980864178800160, -0.748014049258440620, -0.748047232468046050, -0.748080413807533650, +-0.748113593276819920, -0.748146770875822260, -0.748179946604457520, -0.748213120462643320, -0.748246292450296060, -0.748279462567333020, -0.748312630813671390, -0.748345797189228450, +-0.748378961693920600, -0.748412124327665460, -0.748445285090380000, -0.748478443981981600, -0.748511601002386780, -0.748544756151513060, -0.748577909429277380, -0.748611060835597140, +-0.748644210370389080, -0.748677358033570490, -0.748710503825058440, -0.748743647744770420, -0.748776789792623080, -0.748809929968533570, -0.748843068272419750, -0.748876204704197910, +-0.748909339263785560, -0.748942471951099750, -0.748975602766058120, -0.749008731708577180, -0.749041858778574430, -0.749074983975967060, -0.749108107300672450, -0.749141228752607360, +-0.749174348331689170, -0.749207466037835170, -0.749240581870962650, -0.749273695830988460, -0.749306807917830110, -0.749339918131404660, -0.749373026471629730, -0.749406132938421950, +-0.749439237531698720, -0.749472340251377770, -0.749505441097375710, -0.749538540069610070, -0.749571637167998130, -0.749604732392457280, -0.749637825742904270, -0.749670917219256720, +-0.749704006821431900, -0.749737094549347340, -0.749770180402919870, -0.749803264382066900, -0.749836346486705720, -0.749869426716753940, -0.749902505072128300, -0.749935581552746420, +-0.749968656158525590, -0.750001728889383430, -0.750034799745236680, -0.750067868726002950, -0.750100935831599760, -0.750134001061943940, -0.750167064416953130, -0.750200125896544720, +-0.750233185500636220, -0.750266243229144480, -0.750299299081987110, -0.750332353059081520, -0.750365405160345330, -0.750398455385695380, -0.750431503735049300, -0.750464550208324370, +-0.750497594805438430, -0.750530637526308220, -0.750563678370851360, -0.750596717338985360, -0.750629754430627740, -0.750662789645695550, -0.750695822984106420, -0.750728854445777640, +-0.750761884030627050, -0.750794911738571490, -0.750827937569528590, -0.750860961523416190, -0.750893983600151140, -0.750927003799651050, -0.750960022121833440, -0.750993038566616030, +-0.751026053133915910, -0.751059065823650450, -0.751092076635737520, -0.751125085570094500, -0.751158092626638570, -0.751191097805287370, -0.751224101105958500, -0.751257102528569700, +-0.751290102073037810, -0.751323099739280580, -0.751356095527215610, -0.751389089436760750, -0.751422081467832960, -0.751455071620349860, -0.751488059894229400, -0.751521046289388430, +-0.751554030805744900, -0.751587013443216320, -0.751619994201720430, -0.751652973081174290, -0.751685950081495750, -0.751718925202602420, -0.751751898444411930, -0.751784869806841450, +-0.751817839289808720, -0.751850806893231470, -0.751883772617027550, -0.751916736461113900, -0.751949698425408260, -0.751982658509828480, -0.752015616714292400, -0.752048573038716860, +-0.752081527483019930, -0.752114480047119560, -0.752147430730932600, -0.752180379534377110, -0.752213326457370600, -0.752246271499831140, -0.752279214661675690, -0.752312155942822190, +-0.752345095343188270, -0.752378032862692000, -0.752410968501250330, -0.752443902258781220, -0.752476834135202280, -0.752509764130431690, -0.752542692244386300, -0.752575618476984180, +-0.752608542828143050, -0.752641465297780870, -0.752674385885814700, -0.752707304592162620, -0.752740221416742460, -0.752773136359471520, -0.752806049420267740, -0.752838960599048760, +-0.752871869895732740, -0.752904777310236860, -0.752937682842478970, -0.752970586492376800, -0.753003488259848420, -0.753036388144811110, -0.753069286147182830, -0.753102182266881300, +-0.753135076503824720, -0.753167968857930030, -0.753200859329115510, -0.753233747917298800, -0.753266634622397960, -0.753299519444330270, -0.753332402383013800, -0.753365283438366400, +-0.753398162610305900, -0.753431039898749820, -0.753463915303616230, -0.753496788824822960, -0.753529660462287530, -0.753562530215928010, -0.753595398085662000, -0.753628264071407930, +-0.753661128173082840, -0.753693990390604920, -0.753726850723892010, -0.753759709172862280, -0.753792565737433030, -0.753825420417522320, -0.753858273213048100, -0.753891124123928450, +-0.753923973150080750, -0.753956820291423080, -0.753989665547873390, -0.754022508919349850, -0.754055350405769650, -0.754088190007051180, -0.754121027723112400, -0.754153863553870930, +-0.754186697499244610, -0.754219529559151610, -0.754252359733510120, -0.754285188022237430, -0.754318014425251810, -0.754350838942471120, -0.754383661573813540, -0.754416482319196670, +-0.754449301178538480, -0.754482118151757030, -0.754514933238770610, -0.754547746439496620, -0.754580557753853240, -0.754613367181758420, -0.754646174723130560, -0.754678980377886830, +-0.754711784145945750, -0.754744586027225490, -0.754777386021643460, -0.754810184129117930, -0.754842980349567090, -0.754875774682908900, -0.754908567129061070, -0.754941357687941910, +-0.754974146359469240, -0.755006933143561490, -0.755039718040136140, -0.755072501049111500, -0.755105282170405620, -0.755138061403936800, -0.755170838749622540, -0.755203614207381250, +-0.755236387777130870, -0.755269159458789810, -0.755301929252275570, -0.755334697157506450, -0.755367463174400620, -0.755400227302876480, -0.755432989542851430, -0.755465749894243870, +-0.755498508356972300, -0.755531264930954130, -0.755564019616107860, -0.755596772412351460, -0.755629523319603540, -0.755662272337781380, -0.755695019466803620, -0.755727764706588310, +-0.755760508057053750, -0.755793249518117770, -0.755825989089698670, -0.755858726771714510, -0.755891462564083900, -0.755924196466724260, -0.755956928479554200, -0.755989658602491790, +-0.756022386835455640, -0.756055113178363050, -0.756087837631132850, -0.756120560193683120, -0.756153280865931920, -0.756185999647797420, -0.756218716539197920, -0.756251431540051920, +-0.756284144650277050, -0.756316855869791920, -0.756349565198514600, -0.756382272636363600, -0.756414978183256650, -0.756447681839112260, -0.756480383603848620, -0.756513083477384330, +-0.756545781459637130, -0.756578477550525320, -0.756611171749967500, -0.756643864057881870, -0.756676554474186360, -0.756709242998799600, -0.756741929631639780, -0.756774614372625050, +-0.756807297221673610, -0.756839978178704080, -0.756872657243635060, -0.756905334416383860, -0.756938009696869420, -0.756970683085009810, -0.757003354580723540, -0.757036024183928900, +-0.757068691894544290, -0.757101357712487880, -0.757134021637678070, -0.757166683670033150, -0.757199343809471510, -0.757232002055911680, -0.757264658409272260, -0.757297312869470660, +-0.757329965436425830, -0.757362616110056620, -0.757395264890280310, -0.757427911777015740, -0.757460556770181540, -0.757493199869695880, -0.757525841075477160, -0.757558480387443890, +-0.757591117805514470, -0.757623753329607190, -0.757656386959640660, -0.757689018695532960, -0.757721648537202810, -0.757754276484569170, -0.757786902537549210, -0.757819526696062010, +-0.757852148960025950, -0.757884769329360110, -0.757917387803981770, -0.757950004383809990, -0.757982619068763190, -0.758015231858759850, -0.758047842753718390, -0.758080451753557320, +-0.758113058858195130, -0.758145664067550350, -0.758178267381541370, -0.758210868800086700, -0.758243468323105410, -0.758276065950515000, -0.758308661682234320, -0.758341255518181990, +-0.758373847458277180, -0.758406437502437080, -0.758439025650580970, -0.758471611902627240, -0.758504196258494520, -0.758536778718101210, -0.758569359281366040, -0.758601937948207410, +-0.758634514718544040, -0.758667089592294340, -0.758699662569376930, -0.758732233649710870, -0.758764802833213680, -0.758797370119804530, -0.758829935509401920, -0.758862499001925040, +-0.758895060597291280, -0.758927620295420050, -0.758960178096229620, -0.758992733999638740, -0.759025288005566120, -0.759057840113930180, -0.759090390324649640, -0.759122938637643240, +-0.759155485052829370, -0.759188029570126880, -0.759220572189454270, -0.759253112910730830, -0.759285651733873970, -0.759318188658803070, -0.759350723685437210, -0.759383256813694010, +-0.759415788043492630, -0.759448317374751820, -0.759480844807390200, -0.759513370341326380, -0.759545893976479310, -0.759578415712767410, -0.759610935550109390, -0.759643453488424210, +-0.759675969527630280, -0.759708483667646430, -0.759740995908391950, -0.759773506249784350, -0.759806014691743140, -0.759838521234186710, -0.759871025877034700, -0.759903528620204490, +-0.759936029463615490, -0.759968528407186430, -0.760001025450835920, -0.760033520594483040, -0.760066013838046170, -0.760098505181444390, -0.760130994624596320, -0.760163482167420800, +-0.760195967809836450, -0.760228451551762880, -0.760260933393117620, -0.760293413333819950, -0.760325891373788700, -0.760358367512943390, -0.760390841751201530, -0.760423314088482630, +-0.760455784524705410, -0.760488253059788730, -0.760520719693651430, -0.760553184426212340, -0.760585647257390310, -0.760618108187104070, -0.760650567215272580, -0.760683024341814780, +-0.760715479566649870, -0.760747932889695780, -0.760780384310871800, -0.760812833830096900, -0.760845281447290470, -0.760877727162370230, -0.760910170975255710, -0.760942612885865730, +-0.760975052894119260, -0.761007490999935140, -0.761039927203232210, -0.761072361503929650, -0.761104793901946080, -0.761137224397200440, -0.761169652989611810, -0.761202079679099140, +-0.761234504465581720, -0.761266927348977500, -0.761299348329205980, -0.761331767406186690, -0.761364184579837340, -0.761396599850077680, -0.761429013216826320, -0.761461424680002550, +-0.761493834239525210, -0.761526241895313260, -0.761558647647285650, -0.761591051495361440, -0.761623453439459700, -0.761655853479499270, -0.761688251615399210, -0.761720647847079050, +-0.761753042174456720, -0.761785434597451850, -0.761817825115983280, -0.761850213729970860, -0.761882600439332200, -0.761914985243987150, -0.761947368143854550, -0.761979749138853580, +-0.762012128228903180, -0.762044505413922550, -0.762076880693830620, -0.762109254068546460, -0.762141625537989140, -0.762173995102077840, -0.762206362760732060, -0.762238728513869760, +-0.762271092361410770, -0.762303454303273950, -0.762335814339379140, -0.762368172469644170, -0.762400528693988780, -0.762432883012332030, -0.762465235424593100, -0.762497585930691060, +-0.762529934530545180, -0.762562281224074320, -0.762594626011197760, -0.762626968891834790, -0.762659309865904240, -0.762691648933326080, -0.762723986094018150, -0.762756321347900280, +-0.762788654694891650, -0.762820986134911890, -0.762853315667879170, -0.762885643293713110, -0.762917969012332890, -0.762950292823657890, -0.762982614727607090, -0.763014934724099760, +-0.763047252813054970, -0.763079568994392220, -0.763111883268030480, -0.763144195633889020, -0.763176506091887140, -0.763208814641944460, -0.763241121283979250, -0.763273426017911150, +-0.763305728843660100, -0.763338029761144290, -0.763370328770283210, -0.763402625870996390, -0.763434921063202990, -0.763467214346822300, -0.763499505721773610, -0.763531795187976090, +-0.763564082745349150, -0.763596368393811950, -0.763628652133283900, -0.763660933963684170, -0.763693213884932610, -0.763725491896947610, -0.763757767999648670, -0.763790042192955430, +-0.763822314476787720, -0.763854584851063500, -0.763886853315702940, -0.763919119870625220, -0.763951384515749620, -0.763983647250995660, -0.764015908076282610, -0.764048166991529660, +-0.764080423996656320, -0.764112679091581980, -0.764144932276225930, -0.764177183550508120, -0.764209432914346840, -0.764241680367661820, -0.764273925910372800, -0.764306169542399380, +-0.764338411263659980, -0.764370651074074650, -0.764402888973562570, -0.764435124962043360, -0.764467359039436300, -0.764499591205660910, -0.764531821460636470, -0.764564049804282500, +-0.764596276236518380, -0.764628500757263520, -0.764660723366438090, -0.764692944063960270, -0.764725162849750010, -0.764757379723726820, -0.764789594685810870, -0.764821807735920340, +-0.764854018873975190, -0.764886228099895150, -0.764918435413599380, -0.764950640815007630, -0.764982844304039290, -0.765015045880613750, -0.765047245544650640, -0.765079443296069470, +-0.765111639134789630, -0.765143833060730640, -0.765176025073812770, -0.765208215173954210, -0.765240403361075020, -0.765272589635095480, -0.765304773995933880, -0.765336956443510410, +-0.765369136977744450, -0.765401315598555730, -0.765433492305863660, -0.765465667099587850, -0.765497839979647930, -0.765530010945963400, -0.765562179998453880, -0.765594347137038780, +-0.765626512361637920, -0.765658675672171380, -0.765690837068557450, -0.765722996550716520, -0.765755154118568090, -0.765787309772032350, -0.765819463511027700, -0.765851615335474520, +-0.765883765245292230, -0.765915913240400540, -0.765948059320718970, -0.765980203486167350, -0.766012345736665210, -0.766044486072132160, -0.766076624492487920, -0.766108760997652240, +-0.766140895587545060, -0.766173028262085110, -0.766205159021192680, -0.766237287864787180, -0.766269414792789210, -0.766301539805117060, -0.766333662901691030, -0.766365784082430830, +-0.766397903347256330, -0.766430020696086900, -0.766462136128842510, -0.766494249645442660, -0.766526361245807310, -0.766558470929856070, -0.766590578697508570, -0.766622684548685210, +-0.766654788483304590, -0.766686890501287020, -0.766718990602552110, -0.766751088787020470, -0.766783185054610410, -0.766815279405242410, -0.766847371838836220, -0.766879462355311680, +-0.766911550954588410, -0.766943637636586240, -0.766975722401225020, -0.767007805248424490, -0.767039886178104370, -0.767071965190184610, -0.767104042284584950, -0.767136117461225790, +-0.767168190720025620, -0.767200262060905080, -0.767232331483784450, -0.767264398988582450, -0.767296464575219380, -0.767328528243615190, -0.767360589993689720, -0.767392649825362700, +-0.767424707738554090, -0.767456763733183720, -0.767488817809171330, -0.767520869966437090, -0.767552920204900510, -0.767584968524481660, -0.767617014925101040, -0.767649059406677270, +-0.767681101969130860, -0.767713142612381660, -0.767745181336350170, -0.767777218140955230, -0.767809253026117130, -0.767841285991756050, -0.767873317037791710, -0.767905346164143960, +-0.767937373370732980, -0.767969398657478490, -0.768001422024300550, -0.768033443471119020, -0.768065462997853940, -0.768097480604425730, -0.768129496290753220, -0.768161510056757040, +-0.768193521902357010, -0.768225531827473770, -0.768257539832026160, -0.768289545915934680, -0.768321550079119290, -0.768353552321500040, -0.768385552642997020, -0.768417551043530040, +-0.768449547523019080, -0.768481542081384420, -0.768513534718545890, -0.768545525434423450, -0.768577514228937720, -0.768609501102007760, -0.768641486053553980, -0.768673469083496430, +-0.768705450191755850, -0.768737429378251180, -0.768769406642902720, -0.768801381985630860, -0.768833355406355560, -0.768865326904996870, -0.768897296481474870, -0.768929264135709610, +-0.768961229867621170, -0.768993193677129590, -0.769025155564155070, -0.769057115528617770, -0.769089073570438100, -0.769121029689535330, -0.769152983885829870, -0.769184936159242550, +-0.769216886509692330, -0.769248834937099950, -0.769280781441385340, -0.769312726022468920, -0.769344668680270630, -0.769376609414710640, -0.769408548225709140, -0.769440485113186300, +-0.769472420077062290, -0.769504353117257180, -0.769536284233691140, -0.769568213426285010, -0.769600140694957750, -0.769632066039630190, -0.769663989460222410, -0.769695910956655240, +-0.769727830528847750, -0.769759748176720660, -0.769791663900194160, -0.769823577699188520, -0.769855489573623930, -0.769887399523420670, -0.769919307548498910, -0.769951213648778830, +-0.769983117824180830, -0.770015020074624860, -0.770046920400032090, -0.770078818800321250, -0.770110715275413530, -0.770142609825228970, -0.770174502449688440, -0.770206393148711090, +-0.770238281922217770, -0.770270168770128770, -0.770302053692364260, -0.770333936688844760, -0.770365817759490310, -0.770397696904221330, -0.770429574122958090, -0.770461449415621000, +-0.770493322782130230, -0.770525194222406730, -0.770557063736369560, -0.770588931323939910, -0.770620796985037830, -0.770652660719584380, -0.770684522527498640, -0.770716382408701660, +-0.770748240363113730, -0.770780096390655150, -0.770811950491246400, -0.770843802664807680, -0.770875652911259480, -0.770907501230522210, -0.770939347622516150, -0.770971192087161690, +-0.771003034624379910, -0.771034875234089870, -0.771066713916212730, -0.771098550670668680, -0.771130385497379000, -0.771162218396262640, -0.771194049367240790, -0.771225878410233820, +-0.771257705525162150, -0.771289530711946170, -0.771321353970506380, -0.771353175300763310, -0.771384994702637220, -0.771416812176048630, -0.771448627720918050, -0.771480441337165870, +-0.771512253024713160, -0.771544062783479310, -0.771575870613385170, -0.771607676514351470, -0.771639480486299160, -0.771671282529147520, -0.771703082642817620, -0.771734880827230070, +-0.771766677082305290, -0.771798471407963870, -0.771830263804126340, -0.771862054270713080, -0.771893842807644610, -0.771925629414841550, -0.771957414092224510, -0.771989196839714450, +-0.772020977657230880, -0.772052756544694740, -0.772084533502026770, -0.772116308529148140, -0.772148081625978030, -0.772179852792437840, -0.772211622028447950, -0.772243389333929000, +-0.772275154708801590, -0.772306918152986240, -0.772338679666403680, -0.772370439248974420, -0.772402196900618950, -0.772433952621258140, -0.772465706410812910, -0.772497458269202800, +-0.772529208196349180, -0.772560956192172470, -0.772592702256593930, -0.772624446389533090, -0.772656188590911120, -0.772687928860648740, -0.772719667198666470, -0.772751403604885030, +-0.772783138079225160, -0.772814870621607360, -0.772846601231952370, -0.772878329910180910, -0.772910056656213710, -0.772941781469971830, -0.772973504351374910, -0.773005225300344320, +-0.773036944316800590, -0.773068661400665100, -0.773100376551857480, -0.773132089770298790, -0.773163801055909870, -0.773195510408611560, -0.773227217828324380, -0.773258923314969150, +-0.773290626868466720, -0.773322328488737610, -0.773354028175702760, -0.773385725929282790, -0.773417421749398540, -0.773449115635971300, -0.773480807588920680, -0.773512497608167980, +-0.773544185693634150, -0.773575871845240350, -0.773607556062906320, -0.773639238346553460, -0.773670918696102380, -0.773702597111474160, -0.773734273592589280, -0.773765948139368830, +-0.773797620751733420, -0.773829291429604100, -0.773860960172901400, -0.773892626981546370, -0.773924291855460410, -0.773955954794563030, -0.773987615798775840, -0.774019274868019580, +-0.774050932002215750, -0.774082587201283980, -0.774114240465145760, -0.774145891793721840, -0.774177541186933380, -0.774209188644700900, -0.774240834166945560, -0.774272477753587980, +-0.774304119404549350, -0.774335759119750390, -0.774367396899112050, -0.774399032742555730, -0.774430666650001380, -0.774462298621370170, -0.774493928656583400, -0.774525556755562230, +-0.774557182918226730, -0.774588807144498180, -0.774620429434297650, -0.774652049787545980, -0.774683668204164340, -0.774715284684073360, -0.774746899227194310, -0.774778511833447920, +-0.774810122502755270, -0.774841731235037300, -0.774873338030215630, -0.774904942888209990, -0.774936545808942000, -0.774968146792332720, -0.774999745838303560, -0.775031342946774450, +-0.775062938117667020, -0.775094531350902340, -0.775126122646401130, -0.775157712004084790, -0.775189299423874050, -0.775220884905690190, -0.775252468449453950, -0.775284050055086720, +-0.775315629722509230, -0.775347207451642760, -0.775378783242408720, -0.775410357094727280, -0.775441929008519830, -0.775473498983708210, -0.775505067020212270, -0.775536633117953620, +-0.775568197276853440, -0.775599759496832800, -0.775631319777812630, -0.775662878119714240, -0.775694434522458680, -0.775725988985967010, -0.775757541510160410, -0.775789092094959830, +-0.775820640740286670, -0.775852187446062440, -0.775883732212207080, -0.775915275038642440, -0.775946815925289690, -0.775978354872070340, -0.776009891878904570, -0.776041426945714100, +-0.776072960072420100, -0.776104491258943650, -0.776136020505206030, -0.776167547811128290, -0.776199073176631730, -0.776230596601637400, -0.776262118086066710, -0.776293637629840600, +-0.776325155232881040, -0.776356670895107960, -0.776388184616443320, -0.776419696396808080, -0.776451206236124290, -0.776482714134311800, -0.776514220091292560, -0.776545724106987860, +-0.776577226181318750, -0.776608726314206630, -0.776640224505572680, -0.776671720755338190, -0.776703215063424320, -0.776734707429752480, -0.776766197854243830, -0.776797686336820340, +-0.776829172877401940, -0.776860657475910710, -0.776892140132267820, -0.776923620846395100, -0.776955099618212850, -0.776986576447642690, -0.777018051334606220, -0.777049524279024630, +-0.777080995280819200, -0.777112464339911210, -0.777143931456222180, -0.777175396629673280, -0.777206859860185890, -0.777238321147681320, -0.777269780492080950, -0.777301237893306740, +-0.777332693351278750, -0.777364146865919150, -0.777395598437149670, -0.777427048064890710, -0.777458495749064120, -0.777489941489591270, -0.777521385286393580, -0.777552827139392330, +-0.777584267048509140, -0.777615705013665280, -0.777647141034782050, -0.777678575111781070, -0.777710007244583610, -0.777741437433111080, -0.777772865677285650, -0.777804291977027380, +-0.777835716332258450, -0.777867138742900140, -0.777898559208874630, -0.777929977730102200, -0.777961394306504680, -0.777992808938003820, -0.778024221624520780, -0.778055632365977300, +-0.778087041162294770, -0.778118448013394580, -0.778149852919198250, -0.778181255879627280, -0.778212656894603280, -0.778244055964048110, -0.778275453087882260, -0.778306848266027700, +-0.778338241498406140, -0.778369632784939420, -0.778401022125548180, -0.778432409520154360, -0.778463794968679460, -0.778495178471045100, -0.778526560027172800, -0.778557939636984050, +-0.778589317300400600, -0.778620693017343710, -0.778652066787735130, -0.778683438611496360, -0.778714808488549570, -0.778746176418815270, -0.778777542402215420, -0.778808906438671840, +-0.778840268528106390, -0.778871628670439800, -0.778902986865594120, -0.778934343113490970, -0.778965697414052080, -0.778997049767198860, -0.779028400172852910, -0.779059748630936080, +-0.779091095141369870, -0.779122439704075910, -0.779153782318975810, -0.779185122985991300, -0.779216461705044550, -0.779247798476056070, -0.779279133298948050, -0.779310466173642860, +-0.779341797100060910, -0.779373126078124370, -0.779404453107755080, -0.779435778188874770, -0.779467101321404840, -0.779498422505267240, -0.779529741740383590, -0.779561059026675610, +-0.779592374364064920, -0.779623687752473260, -0.779654999191822460, -0.779686308682034700, -0.779717616223030600, -0.779748921814732430, -0.779780225457062050, -0.779811527149941620, +-0.779842826893291760, -0.779874124687034880, -0.779905420531092690, -0.779936714425386920, -0.779968006369839430, -0.779999296364371930, -0.780030584408906050, -0.780061870503363840, +-0.780093154647666930, -0.780124436841737160, -0.780155717085496800, -0.780186995378866600, -0.780218271721768940, -0.780249546114125560, -0.780280818555858850, -0.780312089046889530, +-0.780343357587140130, -0.780374624176532250, -0.780405888814987740, -0.780437151502428650, -0.780468412238776500, -0.780499671023953460, -0.780530927857881250, -0.780562182740481610, +-0.780593435671676610, -0.780624686651388510, -0.780655935679538170, -0.780687182756048090, -0.780718427880839890, -0.780749671053836300, -0.780780912274957830, -0.780812151544127200, +-0.780843388861266250, -0.780874624226296720, -0.780905857639140550, -0.780937089099719930, -0.780968318607956460, -0.780999546163772210, -0.781030771767089130, -0.781061995417829170, +-0.781093217115914060, -0.781124436861266650, -0.781155654653807430, -0.781186870493459140, -0.781218084380144280, -0.781249296313783590, -0.781280506294299680, -0.781311714321614500, +-0.781342920395650120, -0.781374124516328370, -0.781405326683571210, -0.781436526897300810, -0.781467725157439120, -0.781498921463908090, -0.781530115816629790, -0.781561308215526160, +-0.781592498660519830, -0.781623687151531740, -0.781654873688484410, -0.781686058271299890, -0.781717240899900800, -0.781748421574207990, -0.781779600294144170, -0.781810777059631310, +-0.781841951870591580, -0.781873124726946920, -0.781904295628619410, -0.781935464575531200, -0.781966631567604380, -0.781997796604760990, -0.782028959686922990, -0.782060120814013220, +-0.782091279985952630, -0.782122437202663830, -0.782153592464068900, -0.782184745770090560, -0.782215897120649760, -0.782247046515669230, -0.782278193955071140, -0.782309339438777560, +-0.782340482966710550, -0.782371624538792390, -0.782402764154945140, -0.782433901815090980, -0.782465037519152080, -0.782496171267050620, -0.782527303058709320, -0.782558432894049140, +-0.782589560772992910, -0.782620686695462700, -0.782651810661381450, -0.782682932670670020, -0.782714052723251230, -0.782745170819047380, -0.782776286957980630, -0.782807401139973160, +-0.782838513364947140, -0.782869623632824860, -0.782900731943528490, -0.782931838296980320, -0.782962942693102630, -0.782994045131817470, -0.783025145613047700, -0.783056244136714600, +-0.783087340702741000, -0.783118435311049410, -0.783149527961561230, -0.783180618654199300, -0.783211707388885790, -0.783242794165542990, -0.783273878984093170, -0.783304961844458750, +-0.783336042746561880, -0.783367121690324960, -0.783398198675670180, -0.783429273702519910, -0.783460346770796350, -0.783491417880422650, -0.783522487031319770, -0.783553554223410660, +-0.783584619456617730, -0.783615682730863680, -0.783646744046070040, -0.783677803402159420, -0.783708860799054330, -0.783739916236677050, -0.783770969714949970, -0.783802021233795500, +-0.783833070793136020, -0.783864118392893830, -0.783895164032991310, -0.783926207713350980, -0.783957249433895550, -0.783988289194546550, -0.784019326995226810, -0.784050362835858720, +-0.784081396716365230, -0.784112428636667750, -0.784143458596689210, -0.784174486596352030, -0.784205512635578690, -0.784236536714291500, -0.784267558832412950, -0.784298578989865440, +-0.784329597186571580, -0.784360613422453780, -0.784391627697434310, -0.784422640011436470, -0.784453650364381310, -0.784484658756192220, -0.784515665186791280, -0.784546669656101870, +-0.784577672164045170, -0.784608672710544350, -0.784639671295521810, -0.784670667918900060, -0.784701662580601700, -0.784732655280549140, -0.784763646018665000, -0.784794634794871660, +-0.784825621609091750, -0.784856606461247890, -0.784887589351262350, -0.784918570279058540, -0.784949549244557620, -0.784980526247682890, -0.785011501288357390, -0.785042474366502650, +-0.785073445482041720, -0.785104414634897110, -0.785135381824991430, -0.785166347052247420, -0.785197310316587460, -0.785228271617934180, -0.785259230956210310, -0.785290188331338350, +-0.785321143743240910, -0.785352097191840630, -0.785383048677060550, -0.785413998198822410, -0.785444945757049260, -0.785475891351663740, -0.785506834982589000, -0.785537776649746670, +-0.785568716353059910, -0.785599654092451250, -0.785630589867843620, -0.785661523679159420, -0.785692455526321390, -0.785723385409252240, -0.785754313327874710, -0.785785239282111300, +-0.785816163271884860, -0.785847085297118440, -0.785878005357733890, -0.785908923453654260, -0.785939839584802400, -0.785970753751101370, -0.786001665952473010, -0.786032576188840370, +-0.786063484460126420, -0.786094390766253650, -0.786125295107145020, -0.786156197482723030, -0.786187097892910640, -0.786217996337630450, -0.786248892816805320, -0.786279787330357970, +-0.786310679878211570, -0.786341570460288080, -0.786372459076510540, -0.786403345726801930, -0.786434230411085510, -0.786465113129282910, -0.786495993881317630, -0.786526872667112300, +-0.786557749486589740, -0.786588624339672800, -0.786619497226284330, -0.786650368146347150, -0.786681237099784100, -0.786712104086517930, -0.786742969106471460, -0.786773832159567530, +-0.786804693245729550, -0.786835552364879340, -0.786866409516940310, -0.786897264701835740, -0.786928117919487470, -0.786958969169818890, -0.786989818452752950, -0.787020665768212390, +-0.787051511116120260, -0.787082354496399290, -0.787113195908972330, -0.787144035353762540, -0.787174872830692650, -0.787205708339685510, -0.787236541880664050, -0.787267373453551910, +-0.787298203058270700, -0.787329030694744030, -0.787359856362894740, -0.787390680062646450, -0.787421501793920900, -0.787452321556641470, -0.787483139350731330, -0.787513955176113330, +-0.787544769032710420, -0.787575580920445660, -0.787606390839241890, -0.787637198789022160, -0.787668004769709440, -0.787698808781226670, -0.787729610823497460, -0.787760410896443660, +-0.787791208999988780, -0.787822005134055980, -0.787852799298568660, -0.787883591493448780, -0.787914381718619940, -0.787945169974005210, -0.787975956259527430, -0.788006740575109890, +-0.788037522920675420, -0.788068303296147190, -0.788099081701448160, -0.788129858136501380, -0.788160632601230040, -0.788191405095557630, -0.788222175619406110, -0.788252944172699310, +-0.788283710755359970, -0.788314475367312030, -0.788345238008477330, -0.788375998678779500, -0.788406757378141700, -0.788437514106486990, -0.788468268863738440, -0.788499021649819330, +-0.788529772464652610, -0.788560521308161460, -0.788591268180268920, -0.788622013080898300, -0.788652756009972760, -0.788683496967415690, -0.788714235953149380, -0.788744972967097560, +-0.788775708009183730, -0.788806441079330180, -0.788837172177460520, -0.788867901303497930, -0.788898628457365580, -0.788929353638986640, -0.788960076848284290, -0.788990798085181800, +-0.789021517349602240, -0.789052234641469010, -0.789082949960705050, -0.789113663307233870, -0.789144374680978980, -0.789175084081862650, -0.789205791509808520, -0.789236496964740080, +-0.789267200446580830, -0.789297901955253070, -0.789328601490680510, -0.789359299052786460, -0.789389994641494170, -0.789420688256726840, -0.789451379898407860, -0.789482069566460390, +-0.789512757260807830, -0.789543442981373360, -0.789574126728080250, -0.789604808500852350, -0.789635488299611830, -0.789666166124282640, -0.789696841974788070, -0.789727515851051940, +-0.789758187752996440, -0.789788857680545520, -0.789819525633622450, -0.789850191612150530, -0.789880855616053150, -0.789911517645253580, -0.789942177699675230, -0.789972835779241490, +-0.790003491883875640, -0.790034146013501080, -0.790064798168041650, -0.790095448347419740, -0.790126096551559190, -0.790156742780383390, -0.790187387033816190, -0.790218029311780090, +-0.790248669614198930, -0.790279307940995990, -0.790309944292094890, -0.790340578667418910, -0.790371211066891450, -0.790401841490436020, -0.790432469937975890, -0.790463096409434680, +-0.790493720904735690, -0.790524343423802960, -0.790554963966558780, -0.790585582532927210, -0.790616199122831650, -0.790646813736196160, -0.790677426372943140, -0.790708037032996520, +-0.790738645716279830, -0.790769252422716450, -0.790799857152230000, -0.790830459904743990, -0.790861060680181690, -0.790891659478466850, -0.790922256299522730, -0.790952851143273070, +-0.790983444009641270, -0.791014034898551380, -0.791044623809925910, -0.791075210743688810, -0.791105795699763690, -0.791136378678074630, -0.791166959678544110, -0.791197538701096210, +-0.791228115745654440, -0.791258690812142400, -0.791289263900483600, -0.791319835010601660, -0.791350404142420080, -0.791380971295862600, -0.791411536470852610, -0.791442099667313710, +-0.791472660885170210, -0.791503220124344490, -0.791533777384760720, -0.791564332666342520, -0.791594885969014060, -0.791625437292697740, -0.791655986637317950, -0.791686534002798090, +-0.791717079389062000, -0.791747622796033170, -0.791778164223635230, -0.791808703671791900, -0.791839241140426810, -0.791869776629463670, -0.791900310138826000, -0.791930841668438190, +-0.791961371218222740, -0.791991898788103830, -0.792022424378005190, -0.792052947987850970, -0.792083469617563820, -0.792113989267068110, -0.792144506936287350, -0.792175022625145390, +-0.792205536333565720, -0.792236048061472300, -0.792266557808788850, -0.792297065575438890, -0.792327571361346350, -0.792358075166434750, -0.792388576990628700, -0.792419076833850490, +-0.792449574696024620, -0.792480070577074920, -0.792510564476925470, -0.792541056395499100, -0.792571546332720090, -0.792602034288512280, -0.792632520262799290, -0.792663004255505070, +-0.792693486266553340, -0.792723966295867830, -0.792754444343372390, -0.792784920408990960, -0.792815394492647150, -0.792845866594264810, -0.792876336713768450, -0.792906804851080670, +-0.792937271006125880, -0.792967735178827900, -0.792998197369111040, -0.793028657576898220, -0.793059115802113860, -0.793089572044681560, -0.793120026304525380, -0.793150478581569170, +-0.793180928875736660, -0.793211377186952000, -0.793241823515138720, -0.793272267860220980, -0.793302710222122510, -0.793333150600767920, -0.793363588996079840, -0.793394025407982760, +-0.793424459836400640, -0.793454892281257870, -0.793485322742477410, -0.793515751219983630, -0.793546177713700400, -0.793576602223551860, -0.793607024749461650, -0.793637445291353940, +-0.793667863849152670, -0.793698280422781680, -0.793728695012165030, -0.793759107617226680, -0.793789518237891010, -0.793819926874081090, -0.793850333525721320, -0.793880738192735750, +-0.793911140875048770, -0.793941541572583450, -0.793971940285264300, -0.794002337013015260, -0.794032731755760390, -0.794063124513423760, -0.794093515285929200, -0.794123904073200990, +-0.794154290875162870, -0.794184675691739120, -0.794215058522853680, -0.794245439368431170, -0.794275818228394440, -0.794306195102668200, -0.794336569991176410, -0.794366942893843800, +-0.794397313810593310, -0.794427682741349450, -0.794458049686036500, -0.794488414644578310, -0.794518777616899150, -0.794549138602923090, -0.794579497602574070, -0.794609854615776490, +-0.794640209642454080, -0.794670562682531220, -0.794700913735931990, -0.794731262802581000, -0.794761609882401190, -0.794791954975317520, -0.794822298081254490, -0.794852639200135050, +-0.794882978331884040, -0.794913315476425630, -0.794943650633684000, -0.794973983803583200, -0.795004314986047400, -0.795034644181000780, -0.795064971388367630, -0.795095296608072100, +-0.795125619840038270, -0.795155941084190300, -0.795186260340453140, -0.795216577608749750, -0.795246892889004850, -0.795277206181142840, -0.795307517485088210, -0.795337826800764370, +-0.795368134128095930, -0.795398439467007170, -0.795428742817422260, -0.795459044179265500, -0.795489343552461150, -0.795519640936933390, -0.795549936332606620, -0.795580229739405010, +-0.795610521157252730, -0.795640810586074720, -0.795671098025794280, -0.795701383476335900, -0.795731666937624200, -0.795761948409583810, -0.795792227892137990, -0.795822505385211710, +-0.795852780888729020, -0.795883054402614420, -0.795913325926792200, -0.795943595461186650, -0.795973863005722150, -0.796004128560322990, -0.796034392124913560, -0.796064653699418030, +-0.796094913283761470, -0.796125170877867160, -0.796155426481659820, -0.796185680095063850, -0.796215931718004310, -0.796246181350404480, -0.796276428992189090, -0.796306674643282640, +-0.796336918303609530, -0.796367159973094150, -0.796397399651660790, -0.796427637339233940, -0.796457873035738120, -0.796488106741097490, -0.796518338455236560, -0.796548568178079950, +-0.796578795909552270, -0.796609021649577250, -0.796639245398079510, -0.796669467154984320, -0.796699686920214870, -0.796729904693696200, -0.796760120475352830, -0.796790334265109030, +-0.796820546062889430, -0.796850755868618530, -0.796880963682220720, -0.796911169503620510, -0.796941373332742400, -0.796971575169510780, -0.797001775013850280, -0.797031972865685830, +-0.797062168724940960, -0.797092362591540700, -0.797122554465409470, -0.797152744346472430, -0.797182932234652970, -0.797213118129876160, -0.797243302032066610, -0.797273483941148720, +-0.797303663857047210, -0.797333841779686470, -0.797364017708991120, -0.797394191644885790, -0.797424363587294960, -0.797454533536143260, -0.797484701491355640, -0.797514867452855820, +-0.797545031420568870, -0.797575193394419290, -0.797605353374332250, -0.797635511360231360, -0.797665667352041590, -0.797695821349687750, -0.797725973353094250, -0.797756123362185930, +-0.797786271376887180, -0.797816417397122830, -0.797846561422817510, -0.797876703453895610, -0.797906843490282070, -0.797936981531901960, -0.797967117578678890, -0.797997251630537920, +-0.798027383687403890, -0.798057513749201860, -0.798087641815855560, -0.798117767887290160, -0.798147891963430390, -0.798178014044200860, -0.798208134129526290, -0.798238252219331420, +-0.798268368313540870, -0.798298482412079350, -0.798328594514871700, -0.798358704621842550, -0.798388812732916620, -0.798418918848019190, -0.798449022967073980, -0.798479125090006180, +-0.798509225216741060, -0.798539323347202350, -0.798569419481315430, -0.798599513619004830, -0.798629605760195590, -0.798659695904812230, -0.798689784052779680, -0.798719870204022690, +-0.798749954358465960, -0.798780036516034350, -0.798810116676652690, -0.798840194840245710, -0.798870271006738800, -0.798900345176055680, -0.798930417348121650, -0.798960487522861530, +-0.798990555700200830, -0.799020621880063290, -0.799050686062374060, -0.799080748247058100, -0.799110808434040370, -0.799140866623245460, -0.799170922814598560, -0.799200977008024280, +-0.799231029203447570, -0.799261079400793270, -0.799291127599986220, -0.799321173800952020, -0.799351218003614190, -0.799381260207898460, -0.799411300413729430, -0.799441338621032840, +-0.799471374829732300, -0.799501409039753310, -0.799531441251020820, -0.799561471463459680, -0.799591499676994940, -0.799621525891551440, -0.799651550107054020, -0.799681572323427850, +-0.799711592540597760, -0.799741610758488600, -0.799771626977025970, -0.799801641196133730, -0.799831653415737480, -0.799861663635761940, -0.799891671856132860, -0.799921678076774060, +-0.799951682297611040, -0.799981684518568880, -0.800011684739572520, -0.800041682960546900, -0.800071679181417080, -0.800101673402108030, -0.800131665622544790, -0.800161655842652530, +-0.800191644062355990, -0.800221630281580330, -0.800251614500251170, -0.800281596718292470, -0.800311576935629710, -0.800341555152188630, -0.800371531367893070, -0.800401505582668650, +-0.800431477796440530, -0.800461448009133660, -0.800491416220673210, -0.800521382430984250, -0.800551346639991830, -0.800581308847621020, -0.800611269053796870, -0.800641227258444670, +-0.800671183461489360, -0.800701137662856550, -0.800731089862470440, -0.800761040060256610, -0.800790988256140150, -0.800820934450046760, -0.800850878641900520, -0.800880820831627040, +-0.800910761019151480, -0.800940699204399140, -0.800970635387294960, -0.801000569567764220, -0.801030501745731980, -0.801060431921123640, -0.801090360093864140, -0.801120286263878660, +-0.801150210431093130, -0.801180132595431530, -0.801210052756819560, -0.801239970915182400, -0.801269887070445890, -0.801299801222534190, -0.801329713371372930, -0.801359623516887390, +-0.801389531659002840, -0.801419437797644350, -0.801449341932737310, -0.801479244064207010, -0.801509144191978500, -0.801539042315977170, -0.801568938436128200, -0.801598832552357420, +-0.801628724664589120, -0.801658614772748910, -0.801688502876762190, -0.801718388976554670, -0.801748273072050770, -0.801778155163176190, -0.801808035249856110, -0.801837913332016040, +-0.801867789409581140, -0.801897663482476820, -0.801927535550628230, -0.801957405613960890, -0.801987273672400080, -0.802017139725870960, -0.802047003774299050, -0.802076865817610170, +-0.802106725855728620, -0.802136583888580220, -0.802166439916090930, -0.802196293938184920, -0.802226145954788250, -0.802255995965826200, -0.802285843971224160, -0.802315689970907520, +-0.802345533964801680, -0.802375375952831930, -0.802405215934923750, -0.802435053911002670, -0.802464889880993740, -0.802494723844822790, -0.802524555802415440, -0.802554385753696200, +-0.802584213698591010, -0.802614039637025160, -0.802643863568924920, -0.802673685494214470, -0.802703505412819650, -0.802733323324666290, -0.802763139229679460, -0.802792953127784870, +-0.802822765018907810, -0.802852574902973900, -0.802882382779908530, -0.802912188649637200, -0.802941992512085420, -0.802971794367179140, -0.803001594214842960, -0.803031392055002740, +-0.803061187887583960, -0.803090981712512810, -0.803120773529713670, -0.803150563339112610, -0.803180351140635130, -0.803210136934206730, -0.803239920719753030, -0.803269702497199530, +-0.803299482266471740, -0.803329260027495270, -0.803359035780195630, -0.803388809524498430, -0.803418581260329720, -0.803448350987614020, -0.803478118706277500, -0.803507884416245650, +-0.803537648117444660, -0.803567409809798900, -0.803597169493234680, -0.803626927167677580, -0.803656682833053140, -0.803686436489286950, -0.803716188136304740, -0.803745937774032030, +-0.803775685402394410, -0.803805431021317630, -0.803835174630727290, -0.803864916230549010, -0.803894655820708960, -0.803924393401131750, -0.803954128971743560, -0.803983862532470560, +-0.804013594083237470, -0.804043323623970240, -0.804073051154594820, -0.804102776675036710, -0.804132500185221640, -0.804162221685075340, -0.804191941174523530, -0.804221658653491820, +-0.804251374121905950, -0.804281087579691630, -0.804310799026774710, -0.804340508463081250, -0.804370215888535970, -0.804399921303065150, -0.804429624706594510, -0.804459326099050460, +-0.804489025480357390, -0.804518722850441900, -0.804548418209229510, -0.804578111556646160, -0.804607802892617460, -0.804637492217069260, -0.804667179529927390, -0.804696864831117460, +-0.804726548120565430, -0.804756229398197020, -0.804785908663938620, -0.804815585917714850, -0.804845261159452210, -0.804874934389076310, -0.804904605606513670, -0.804934274811689000, +-0.804963942004528590, -0.804993607184958380, -0.805023270352904110, -0.805052931508291600, -0.805082590651046930, -0.805112247781095690, -0.805141902898363740, -0.805171556002777120, +-0.805201207094261680, -0.805230856172743700, -0.805260503238148020, -0.805290148290401020, -0.805319791329428770, -0.805349432355157550, -0.805379071367512190, -0.805408708366419090, +-0.805438343351804310, -0.805467976323593680, -0.805497607281713050, -0.805527236226088460, -0.805556863156645760, -0.805586488073310900, -0.805616110976009820, -0.805645731864668480, +-0.805675350739212700, -0.805704967599569220, -0.805734582445662760, -0.805764195277419830, -0.805793806094766920, -0.805823414897628990, -0.805853021685932420, -0.805882626459603400, +-0.805912229218567870, -0.805941829962751650, -0.805971428692080940, -0.806001025406481550, -0.806030620105879780, -0.806060212790201350, -0.806089803459372310, -0.806119392113318840, +-0.806148978751967450, -0.806178563375243070, -0.806208145983072220, -0.806237726575381060, -0.806267305152096100, -0.806296881713142400, -0.806326456258446460, -0.806356028787934330, +-0.806385599301532200, -0.806415167799166000, -0.806444734280761910, -0.806474298746245990, -0.806503861195544290, -0.806533421628582990, -0.806562980045288150, -0.806592536445586370, +-0.806622090829402730, -0.806651643196663830, -0.806681193547295840, -0.806710741881225380, -0.806740288198377510, -0.806769832498678950, -0.806799374782055880, -0.806828915048434350, +-0.806858453297740420, -0.806887989529900480, -0.806917523744840490, -0.806947055942486720, -0.806976586122765350, -0.807006114285602430, -0.807035640430924790, -0.807065164558657510, +-0.807094686668727410, -0.807124206761060450, -0.807153724835583560, -0.807183240892221930, -0.807212754930902050, -0.807242266951550320, -0.807271776954093020, -0.807301284938456210, +-0.807330790904566160, -0.807360294852349170, -0.807389796781731390, -0.807419296692639230, -0.807448794584998740, -0.807478290458736760, -0.807507784313778560, -0.807537276150051000, +-0.807566765967480120, -0.807596253765992870, -0.807625739545514530, -0.807655223305971840, -0.807684705047290950, -0.807714184769398490, -0.807743662472220400, -0.807773138155683300, +-0.807802611819713250, -0.807832083464236740, -0.807861553089179950, -0.807891020694469390, -0.807920486280031100, -0.807949949845792270, -0.807979411391677950, -0.808008870917615200, +-0.808038328423530180, -0.808067783909349970, -0.808097237374999720, -0.808126688820406280, -0.808156138245496260, -0.808185585650195830, -0.808215031034431490, -0.808244474398129520, +-0.808273915741216320, -0.808303355063618390, -0.808332792365262120, -0.808362227646073790, -0.808391660905980470, -0.808421092144907430, -0.808450521362781730, -0.808479948559529650, +-0.808509373735078250, -0.808538796889352820, -0.808568218022280520, -0.808597637133787630, -0.808627054223800660, -0.808656469292245990, -0.808685882339050250, -0.808715293364139720, +-0.808744702367441000, -0.808774109348880500, -0.808803514308384710, -0.808832917245880690, -0.808862318161293840, -0.808891717054551210, -0.808921113925579300, -0.808950508774305080, +-0.808979901600654140, -0.809009292404553330, -0.809038681185929360, -0.809068067944708760, -0.809097452680817900, -0.809126835394183400, -0.809156216084731870, -0.809185594752389710, +-0.809214971397083650, -0.809244346018740180, -0.809273718617286250, -0.809303089192647600, -0.809332457744751270, -0.809361824273523660, -0.809391188778892160, -0.809420551260782050, +-0.809449911719120620, -0.809479270153834360, -0.809508626564849900, -0.809537980952093950, -0.809567333315493020, -0.809596683654973840, -0.809626031970462790, -0.809655378261886830, +-0.809684722529172340, -0.809714064772246060, -0.809743404991035030, -0.809772743185465100, -0.809802079355463220, -0.809831413500956220, -0.809860745621871160, -0.809890075718133760, +-0.809919403789671200, -0.809948729836410090, -0.809978053858277150, -0.810007375855199110, -0.810036695827102580, -0.810066013773914300, -0.810095329695560970, -0.810124643591969340, +-0.810153955463066120, -0.810183265308778600, -0.810212573129032280, -0.810241878923754540, -0.810271182692872240, -0.810300484436312420, -0.810329784154000810, -0.810359081845864800, +-0.810388377511831020, -0.810417671151826280, -0.810446962765777430, -0.810476252353611200, -0.810505539915254310, -0.810534825450633600, -0.810564108959675790, -0.810593390442307720, +-0.810622669898456660, -0.810651947328048460, -0.810681222731010400, -0.810710496107269200, -0.810739767456752360, -0.810769036779385500, -0.810798304075096120, -0.810827569343810950, +-0.810856832585456930, -0.810886093799960680, -0.810915352987249370, -0.810944610147249500, -0.810973865279888240, -0.811003118385092310, -0.811032369462788560, -0.811061618512904370, +-0.811090865535365690, -0.811120110530099690, -0.811149353497033540, -0.811178594436094520, -0.811207833347208470, -0.811237070230302890, -0.811266305085304620, -0.811295537912140490, +-0.811324768710737660, -0.811353997481022770, -0.811383224222922970, -0.811412448936365100, -0.811441671621276120, -0.811470892277582840, -0.811500110905212460, -0.811529327504092350, +-0.811558542074148350, -0.811587754615307970, -0.811616965127498700, -0.811646173610646620, -0.811675380064678990, -0.811704584489522870, -0.811733786885105450, -0.811762987251353430, +-0.811792185588193990, -0.811821381895554080, -0.811850576173360760, -0.811879768421540970, -0.811908958640021770, -0.811938146828730110, -0.811967332987593720, -0.811996517116538420, +-0.812025699215491730, -0.812054879284380910, -0.812084057323133380, -0.812113233331675180, -0.812142407309933920, -0.812171579257836670, -0.812200749175310380, -0.812229917062282310, +-0.812259082918679320, -0.812288246744428790, -0.812317408539457550, -0.812346568303692780, -0.812375726037061650, -0.812404881739491660, -0.812434035410908970, -0.812463187051241210, +-0.812492336660415430, -0.812521484238359350, -0.812550629784999030, -0.812579773300262210, -0.812608914784075930, -0.812638054236367370, -0.812667191657063580, -0.812696327046091960, +-0.812725460403379340, -0.812754591728853230, -0.812783721022440560, -0.812812848284068630, -0.812841973513665050, -0.812871096711156090, -0.812900217876469270, -0.812929337009532070, +-0.812958454110271900, -0.812987569178615140, -0.813016682214489420, -0.813045793217822110, -0.813074902188540170, -0.813104009126571100, -0.813133114031841850, -0.813162216904279920, +-0.813191317743812480, -0.813220416550366700, -0.813249513323869850, -0.813278608064249340, -0.813307700771432660, -0.813336791445346320, -0.813365880085918040, -0.813394966693075430, +-0.813424051266745000, -0.813453133806854360, -0.813482214313331010, -0.813511292786102010, -0.813540369225094870, -0.813569443630236640, -0.813598516001454940, -0.813627586338676930, +-0.813656654641830010, -0.813685720910841350, -0.813714785145638440, -0.813743847346149130, -0.813772907512299580, -0.813801965644017860, -0.813831021741231120, -0.813860075803867430, +-0.813889127831852970, -0.813918177825115770, -0.813947225783583030, -0.813976271707182340, -0.814005315595840880, -0.814034357449486160, -0.814063397268045550, -0.814092435051446460, +-0.814121470799616280, -0.814150504512482390, -0.814179536189972850, -0.814208565832013840, -0.814237593438533410, -0.814266619009459070, -0.814295642544718650, -0.814324664044238640, +-0.814353683507947010, -0.814382700935771140, -0.814411716327638420, -0.814440729683476580, -0.814469741003212790, -0.814498750286774650, -0.814527757534089680, -0.814556762745085370, +-0.814585765919689010, -0.814614767057828870, -0.814643766159431240, -0.814672763224424280, -0.814701758252735280, -0.814730751244292510, -0.814759742199022250, -0.814788731116852680, +-0.814817717997711300, -0.814846702841525610, -0.814875685648223210, -0.814904666417731520, -0.814933645149978240, -0.814962621844890770, -0.814991596502396830, -0.815020569122423820, +-0.815049539704899460, -0.815078508249751700, -0.815107474756907150, -0.815136439226293970, -0.815165401657840240, -0.815194362051472330, -0.815223320407118650, -0.815252276724706680, +-0.815281231004163940, -0.815310183245418150, -0.815339133448396920, -0.815368081613027870, -0.815397027739238610, -0.815425971826956750, -0.815454913876110020, -0.815483853886625920, +-0.815512791858432730, -0.815541727791457060, -0.815570661685627090, -0.815599593540870420, -0.815628523357115330, -0.815657451134288450, -0.815686376872317820, -0.815715300571131290, +-0.815744222230656570, -0.815773141850821280, -0.815802059431553150, -0.815830974972779790, -0.815859888474429030, -0.815888799936428600, -0.815917709358706110, -0.815946616741189960, +-0.815975522083806640, -0.816004425386484540, -0.816033326649151400, -0.816062225871735380, -0.816091123054163430, -0.816120018196363590, -0.816148911298263610, -0.816177802359791540, +-0.816206691380874870, -0.816235578361441450, -0.816264463301419110, -0.816293346200735570, -0.816322227059318670, -0.816351105877096250, -0.816379982653996580, -0.816408857389946510, +-0.816437730084874190, -0.816466600738707580, -0.816495469351374960, -0.816524335922803160, -0.816553200452920570, -0.816582062941654920, -0.816610923388934150, -0.816639781794685990, +-0.816668638158838500, -0.816697492481319290, -0.816726344762056410, -0.816755195000977710, -0.816784043198010900, -0.816812889353084160, -0.816841733466125540, -0.816870575537062220, +-0.816899415565822350, -0.816928253552334450, -0.816957089496525460, -0.816985923398323770, -0.817014755257657210, -0.817043585074453850, -0.817072412848641410, -0.817101238580148050, +-0.817130062268901500, -0.817158883914829830, -0.817187703517860960, -0.817216521077922860, -0.817245336594943360, -0.817274150068851180, -0.817302961499573040, -0.817331770887037460, +-0.817360578231172470, -0.817389383531906490, -0.817418186789166670, -0.817446988002881290, -0.817475787172978420, -0.817504584299386220, -0.817533379382032410, -0.817562172420845280, +-0.817590963415752660, -0.817619752366682610, -0.817648539273563180, -0.817677324136322440, -0.817706106954888880, -0.817734887729189450, -0.817763666459152990, -0.817792443144707230, +-0.817821217785780870, -0.817849990382301000, -0.817878760934196200, -0.817907529441394440, -0.817936295903823880, -0.817965060321412470, -0.817993822694088600, -0.818022583021779990, +-0.818051341304415040, -0.818080097541921680, -0.818108851734228090, -0.818137603881262890, -0.818166353982953230, -0.818195102039227630, -0.818223848050014250, -0.818252592015241810, +-0.818281333934837370, -0.818310073808729550, -0.818338811636846630, -0.818367547419116550, -0.818396281155467700, -0.818425012845828140, -0.818453742490126030, -0.818482470088289560, +-0.818511195640246990, -0.818539919145926390, -0.818568640605255910, -0.818597360018164410, -0.818626077384579040, -0.818654792704428420, -0.818683505977641280, -0.818712217204144890, +-0.818740926383868080, -0.818769633516738820, -0.818798338602685470, -0.818827041641636330, -0.818855742633519570, -0.818884441578263570, -0.818913138475796280, -0.818941833326046200, +-0.818970526128941610, -0.818999216884410690, -0.819027905592382140, -0.819056592252783380, -0.819085276865543220, -0.819113959430589730, -0.819142639947851970, -0.819171318417256990, +-0.819199994838733740, -0.819228669212210600, -0.819257341537615650, -0.819286011814877480, -0.819314680043924160, -0.819343346224684190, -0.819372010357085840, -0.819400672441057520, +-0.819429332476527490, -0.819457990463424600, -0.819486646401676230, -0.819515300291211330, -0.819543952131958080, -0.819572601923845510, -0.819601249666800920, -0.819629895360753260, +-0.819658539005630790, -0.819687180601361920, -0.819715820147875250, -0.819744457645098960, -0.819773093092961420, -0.819801726491391270, -0.819830357840316770, -0.819858987139666430, +-0.819887614389369080, -0.819916239589352110, -0.819944862739544700, -0.819973483839875010, -0.820002102890272200, -0.820030719890663560, -0.820059334840978150, -0.820087947741144460, +-0.820116558591090780, -0.820145167390745830, -0.820173774140037890, -0.820202378838895460, -0.820230981487247160, -0.820259582085021370, -0.820288180632146700, -0.820316777128551440, +-0.820345371574164870, -0.820373963968914380, -0.820402554312728900, -0.820431142605537620, -0.820459728847267920, -0.820488313037848860, -0.820516895177209050, -0.820545475265276990, +-0.820574053301981300, -0.820602629287250470, -0.820631203221013020, -0.820659775103197540, -0.820688344933732660, -0.820716912712546990, -0.820745478439568910, -0.820774042114727710, +-0.820802603737950890, -0.820831163309167610, -0.820859720828306380, -0.820888276295296370, -0.820916829710065080, -0.820945381072541780, -0.820973930382655090, -0.821002477640333520, +-0.821031022845505660, -0.821059565998100370, -0.821088107098046140, -0.821116646145271580, -0.821145183139705530, -0.821173718081276370, -0.821202250969913510, -0.821230781805544540, +-0.821259310588098530, -0.821287837317504320, -0.821316361993691070, -0.821344884616586280, -0.821373405186119340, -0.821401923702218870, -0.821430440164813590, -0.821458954573832220, +-0.821487466929203490, -0.821515977230856120, -0.821544485478718720, -0.821572991672720130, -0.821601495812789070, -0.821629997898854820, -0.821658497930845000, -0.821686995908688990, +-0.821715491832315510, -0.821743985701653750, -0.821772477516631520, -0.821800967277178110, -0.821829454983222350, -0.821857940634692860, -0.821886424231518590, -0.821914905773628130, +-0.821943385260950570, -0.821971862693414490, -0.822000338070948740, -0.822028811393482050, -0.822057282660943470, -0.822085751873262160, -0.822114219030365860, -0.822142684132184160, +-0.822171147178646140, -0.822199608169679850, -0.822228067105214460, -0.822256523985179010, -0.822284978809502130, -0.822313431578112870, -0.822341882290939960, -0.822370330947912450, +-0.822398777548959070, -0.822427222094008650, -0.822455664582990350, -0.822484105015832800, -0.822512543392465490, -0.822540979712816260, -0.822569413976814710, -0.822597846184389470, +-0.822626276335470250, -0.822654704429984780, -0.822683130467862570, -0.822711554449032540, -0.822739976373423550, -0.822768396240964760, -0.822796814051584890, -0.822825229805213000, +-0.822853643501778030, -0.822882055141208930, -0.822910464723434650, -0.822938872248384800, -0.822967277715987210, -0.822995681126171500, -0.823024082478866600, -0.823052481774001920, +-0.823080879011505510, -0.823109274191306970, -0.823137667313335260, -0.823166058377519330, -0.823194447383788220, -0.823222834332071110, -0.823251219222296830, -0.823279602054394430, +-0.823307982828293210, -0.823336361543921870, -0.823364738201210260, -0.823393112800086200, -0.823421485340479430, -0.823449855822318890, -0.823478224245534300, -0.823506590610053490, +-0.823534954915806310, -0.823563317162721800, -0.823591677350728910, -0.823620035479756820, -0.823648391549734680, -0.823676745560591560, -0.823705097512256510, -0.823733447404658810, +-0.823761795237727410, -0.823790141011391590, -0.823818484725580950, -0.823846826380223550, -0.823875165975249010, -0.823903503510587170, -0.823931838986166070, -0.823960172401915330, +-0.823988503757764110, -0.824016833053641710, -0.824045160289477160, -0.824073485465199760, -0.824101808580738670, -0.824130129636022950, -0.824158448630981980, -0.824186765565544930, +-0.824215080439640870, -0.824243393253199730, -0.824271704006149460, -0.824300012698420130, -0.824328319329940550, -0.824356623900640790, -0.824384926410449030, -0.824413226859294860, +-0.824441525247107570, -0.824469821573816540, -0.824498115839350950, -0.824526408043640080, -0.824554698186613200, -0.824582986268199590, -0.824611272288328420, -0.824639556246929200, +-0.824667838143931520, -0.824696117979263790, -0.824724395752855610, -0.824752671464636600, -0.824780945114536370, -0.824809216702483310, -0.824837486228407140, -0.824865753692237360, +-0.824894019093903030, -0.824922282433333760, -0.824950543710458840, -0.824978802925207420, -0.825007060077509120, -0.825035315167293120, -0.825063568194488780, -0.825091819159026070, +-0.825120068060833380, -0.825148314899840420, -0.825176559675976700, -0.825204802389172040, -0.825233043039354960, -0.825261281626455290, -0.825289518150402300, -0.825317752611125610, +-0.825345985008554490, -0.825374215342618460, -0.825402443613246770, -0.825430669820369060, -0.825458893963914700, -0.825487116043813090, -0.825515336059994160, -0.825543554012386440, +-0.825571769900919740, -0.825599983725523790, -0.825628195486128200, -0.825656405182661700, -0.825684612815054230, -0.825712818383235180, -0.825741021887134050, -0.825769223326680350, +-0.825797422701803670, -0.825825620012433430, -0.825853815258499100, -0.825882008439930200, -0.825910199556656340, -0.825938388608607020, -0.825966575595712180, -0.825994760517900330, +-0.826022943375101630, -0.826051124167245580, -0.826079302894262350, -0.826107479556080220, -0.826135654152629350, -0.826163826683839480, -0.826191997149639870, -0.826220165549960360, +-0.826248331884730460, -0.826276496153879770, -0.826304658357337800, -0.826332818495034150, -0.826360976566898440, -0.826389132572860840, -0.826417286512849960, -0.826445438386795740, +-0.826473588194628020, -0.826501735936276740, -0.826529881611670740, -0.826558025220739960, -0.826586166763414120, -0.826614306239622840, -0.826642443649295840, -0.826670578992362740, +-0.826698712268753130, -0.826726843478396760, -0.826754972621223330, -0.826783099697162460, -0.826811224706144320, -0.826839347648097630, -0.826867468522952560, -0.826895587330638840, +-0.826923704071086620, -0.826951818744224630, -0.826979931349983160, -0.827008041888291800, -0.827036150359080290, -0.827064256762278460, -0.827092361097816030, -0.827120463365622620, +-0.827148563565628160, -0.827176661697762160, -0.827204757761954570, -0.827232851758135660, -0.827260943686234040, -0.827289033546180110, -0.827317121337903470, -0.827345207061334630, +-0.827373290716402310, -0.827401372303036680, -0.827429451821167670, -0.827457529270725020, -0.827485604651638560, -0.827513677963838010, -0.827541749207253320, -0.827569818381814310, +-0.827597885487450720, -0.827625950524092380, -0.827654013491669230, -0.827682074390111430, -0.827710133219348050, -0.827738189979309260, -0.827766244669925100, -0.827794297291125750, +-0.827822347842840140, -0.827850396324998680, -0.827878442737531310, -0.827906487080367740, -0.827934529353438030, -0.827962569556671910, -0.827990607689999440, -0.828018643753350440, +-0.828046677746654750, -0.828074709669842420, -0.828102739522843860, -0.828130767305587880, -0.828158793018004990, -0.828186816660025250, -0.828214838231578820, -0.828242857732594870, +-0.828270875163003680, -0.828298890522735420, -0.828326903811719810, -0.828354915029887010, -0.828382924177166970, -0.828410931253489520, -0.828438936258784840, -0.828466939192982750, +-0.828494940056013430, -0.828522938847807140, -0.828550935568292960, -0.828578930217401590, -0.828606922795062760, -0.828634913301207200, -0.828662901735763850, -0.828690888098663200, +-0.828718872389835440, -0.828746854609210380, -0.828774834756718200, -0.828802812832288960, -0.828830788835852710, -0.828858762767339500, -0.828886734626679390, -0.828914704413802330, +-0.828942672128639150, -0.828970637771118680, -0.828998601341171650, -0.829026562838728110, -0.829054522263718670, -0.829082479616072510, -0.829110434895720010, -0.829138388102591550, +-0.829166339236617090, -0.829194288297726680, -0.829222235285850710, -0.829250180200919010, -0.829278123042861970, -0.829306063811609540, -0.829334002507091990, -0.829361939129239390, +-0.829389873677982450, -0.829417806153250340, -0.829445736554973780, -0.829473664883083270, -0.829501591137508210, -0.829529515318179090, -0.829557437425026190, -0.829585357457979790, +-0.829613275416969940, -0.829641191301926820, -0.829669105112780800, -0.829697016849461950, -0.829724926511900660, -0.829752834100026980, -0.829780739613771300, -0.829808643053064230, +-0.829836544417835050, -0.829864443708014490, -0.829892340923532810, -0.829920236064320750, -0.829948129130307690, -0.829976020121424240, -0.830003909037600800, -0.830031795878767520, +-0.830059680644854800, -0.830087563335792810, -0.830115443951511930, -0.830143322491942560, -0.830171198957014740, -0.830199073346658990, -0.830226945660806010, -0.830254815899385320, +-0.830282684062327410, -0.830310550149562900, -0.830338414161022390, -0.830366276096635490, -0.830394135956332820, -0.830421993740044770, -0.830449849447701840, -0.830477703079234300, +-0.830505554634572430, -0.830533404113646620, -0.830561251516387380, -0.830589096842724970, -0.830616940092589910, -0.830644781265912900, -0.830672620362623460, -0.830700457382652520, +-0.830728292325930370, -0.830756125192388060, -0.830783955981954870, -0.830811784694561850, -0.830839611330139280, -0.830867435888617780, -0.830895258369927610, -0.830923078773999400, +-0.830950897100763420, -0.830978713350150170, -0.831006527522090140, -0.831034339616513850, -0.831062149633351680, -0.831089957572534680, -0.831117763433992240, -0.831145567217655420, +-0.831173368923455060, -0.831201168551320870, -0.831228966101183800, -0.831256761572974350, -0.831284554966622900, -0.831312346282060080, -0.831340135519216370, -0.831367922678022400, +-0.831395707758408540, -0.831423490760305530, -0.831451271683643740, -0.831479050528353690, -0.831506827294366650, -0.831534601981611890, -0.831562374590020690, -0.831590145119523560, +-0.831617913570051550, -0.831645679941534380, -0.831673444233902880, -0.831701206447087780, -0.831728966581019690, -0.831756724635629220, -0.831784480610846870, -0.831812234506603350, +-0.831839986322829180, -0.831867736059455190, -0.831895483716411750, -0.831923229293630050, -0.831950972791039910, -0.831978714208572280, -0.832006453546157880, -0.832034190803727870, +-0.832061925981211760, -0.832089659078540930, -0.832117390095646000, -0.832145119032457470, -0.832172845888906280, -0.832200570664922920, -0.832228293360438130, -0.832256013975382510, +-0.832283732509687010, -0.832311448963282130, -0.832339163336099030, -0.832366875628067660, -0.832394585839119070, -0.832422293969183990, -0.832450000018193690, -0.832477703986077790, +-0.832505405872767780, -0.832533105678194160, -0.832560803402287770, -0.832588499044979450, -0.832616192606199900, -0.832643884085879750, -0.832671573483949930, -0.832699260800341290, +-0.832726946034984430, -0.832754629187810070, -0.832782310258749820, -0.832809989247733200, -0.832837666154691680, -0.832865340979556450, -0.832893013722257320, -0.832920684382725710, +-0.832948352960892310, -0.832976019456688200, -0.833003683870043870, -0.833031346200890480, -0.833059006449158650, -0.833086664614779320, -0.833114320697683210, -0.833141974697801490, +-0.833169626615064660, -0.833197276449404440, -0.833224924200750340, -0.833252569869034070, -0.833280213454186350, -0.833307854956138570, -0.833335494374820680, -0.833363131710163960, +-0.833390766962099570, -0.833418400130558120, -0.833446031215470780, -0.833473660216768280, -0.833501287134381650, -0.833528911968241860, -0.833556534718279730, -0.833584155384426320, +-0.833611773966612900, -0.833639390464769650, -0.833667004878827940, -0.833694617208718620, -0.833722227454373300, -0.833749835615722020, -0.833777441692696080, -0.833805045685226400, +-0.833832647593244270, -0.833860247416680520, -0.833887845155466100, -0.833915440809532060, -0.833943034378809460, -0.833970625863229230, -0.833998215262722440, -0.834025802577220590, +-0.834053387806653830, -0.834080970950953460, -0.834108552010050850, -0.834136130983877180, -0.834163707872362710, -0.834191282675439070, -0.834218855393037200, -0.834246426025088140, +-0.834273994571523070, -0.834301561032272930, -0.834329125407269000, -0.834356687696442110, -0.834384247899723650, -0.834411806017044460, -0.834439362048335910, -0.834466915993529290, +-0.834494467852554990, -0.834522017625344390, -0.834549565311829330, -0.834577110911939870, -0.834604654425607610, -0.834632195852763710, -0.834659735193339360, -0.834687272447265590, +-0.834714807614473700, -0.834742340694894840, -0.834769871688460060, -0.834797400595100660, -0.834824927414747680, -0.834852452147332390, -0.834879974792786530, -0.834907495351040140, +-0.834935013822025060, -0.834962530205672460, -0.834990044501914050, -0.835017556710680010, -0.835045066831902050, -0.835072574865511560, -0.835100080811439490, -0.835127584669617230, +-0.835155086439976050, -0.835182586122447110, -0.835210083716961820, -0.835237579223451210, -0.835265072641846680, -0.835292563972079960, -0.835320053214081320, -0.835347540367782580, +-0.835375025433114930, -0.835402508410010290, -0.835429989298398850, -0.835457468098212420, -0.835484944809382400, -0.835512419431839850, -0.835539891965516370, -0.835567362410343240, +-0.835594830766251520, -0.835622297033172920, -0.835649761211038400, -0.835677223299779560, -0.835704683299328120, -0.835732141209614590, -0.835759597030570570, -0.835787050762127670, +-0.835814502404217510, -0.835841951956770690, -0.835869399419718940, -0.835896844792993750, -0.835924288076526410, -0.835951729270248410, -0.835979168374091030, -0.836006605387985660, +-0.836034040311863900, -0.836061473145657040, -0.836088903889296350, -0.836116332542713560, -0.836143759105840380, -0.836171183578607310, -0.836198605960946310, -0.836226026252789190, +-0.836253444454066570, -0.836280860564710400, -0.836308274584651960, -0.836335686513822950, -0.836363096352154670, -0.836390504099578600, -0.836417909756026370, -0.836445313321429350, +-0.836472714795718940, -0.836500114178826860, -0.836527511470684490, -0.836554906671223790, -0.836582299780375350, -0.836609690798071130, -0.836637079724242730, -0.836664466558821980, +-0.836691851301739730, -0.836719233952927800, -0.836746614512317800, -0.836773992979841230, -0.836801369355429810, -0.836828743639014830, -0.836856115830527990, -0.836883485929900920, +-0.836910853937065100, -0.836938219851952160, -0.836965583674494140, -0.836992945404621770, -0.837020305042266880, -0.837047662587361410, -0.837075018039837080, -0.837102371399624840, +-0.837129722666656640, -0.837157071840864080, -0.837184418922178990, -0.837211763910532760, -0.837239106805857110, -0.837266447608083660, -0.837293786317144130, -0.837321122932970120, +-0.837348457455493360, -0.837375789884645890, -0.837403120220358450, -0.837430448462563200, -0.837457774611191860, -0.837485098666176600, -0.837512420627448130, -0.837539740494938510, +-0.837567058268579580, -0.837594373948303050, -0.837621687534040540, -0.837648999025723760, -0.837676308423284550, -0.837703615726654640, -0.837730920935765510, -0.837758224050549230, +-0.837785525070937400, -0.837812823996862190, -0.837840120828254320, -0.837867415565046290, -0.837894708207170160, -0.837921998754556860, -0.837949287207138460, -0.837976573564846890, +-0.838003857827613880, -0.838031139995371150, -0.838058420068050650, -0.838085698045584080, -0.838112973927903290, -0.838140247714940110, -0.838167519406626260, -0.838194789002893570, +-0.838222056503674430, -0.838249321908899670, -0.838276585218501570, -0.838303846432411960, -0.838331105550563340, -0.838358362572886430, -0.838385617499313620, -0.838412870329776740, +-0.838440121064207730, -0.838467369702538320, -0.838494616244700560, -0.838521860690626290, -0.838549103040247320, -0.838576343293495620, -0.838603581450303000, -0.838630817510601980, +-0.838658051474323370, -0.838685283341399690, -0.838712513111762760, -0.838739740785345080, -0.838766966362077590, -0.838794189841892580, -0.838821411224722200, -0.838848630510498180, +-0.838875847699152690, -0.838903062790617550, -0.838930275784824710, -0.838957486681706220, -0.838984695481194030, -0.839011902183220080, -0.839039106787716870, -0.839066309294615340, +-0.839093509703848110, -0.839120708015347110, -0.839147904229044730, -0.839175098344872250, -0.839202290362761950, -0.839229480282645880, -0.839256668104456200, -0.839283853828124760, +-0.839311037453583710, -0.839338218980765110, -0.839365398409601000, -0.839392575740023350, -0.839419750971964200, -0.839446924105355710, -0.839474095140130490, -0.839501264076219390, +-0.839528430913555220, -0.839555595652070500, -0.839582758291696150, -0.839609918832365020, -0.839637077274009160, -0.839664233616560510, -0.839691387859951230, -0.839718540004113610, +-0.839745690048979480, -0.839772837994481320, -0.839799983840550990, -0.839827127587120640, -0.839854269234122430, -0.839881408781489200, -0.839908546229151790, -0.839935681577043130, +-0.839962814825095270, -0.839989945973240730, -0.840017075021410990, -0.840044201969538550, -0.840071326817555470, -0.840098449565394260, -0.840125570212986730, -0.840152688760265390, +-0.840179805207162400, -0.840206919553609710, -0.840234031799539820, -0.840261141944884880, -0.840288249989577520, -0.840315355933549110, -0.840342459776732280, -0.840369561519059280, +-0.840396661160462850, -0.840423758700874380, -0.840450854140226470, -0.840477947478451390, -0.840505038715481430, -0.840532127851248870, -0.840559214885685970, -0.840586299818725120, +-0.840613382650298500, -0.840640463380338380, -0.840667542008777140, -0.840694618535547500, -0.840721692960580860, -0.840748765283809930, -0.840775835505167100, -0.840802903624585210, +-0.840829969641995630, -0.840857033557331100, -0.840884095370523890, -0.840911155081506490, -0.840938212690211180, -0.840965268196570470, -0.840992321600516400, -0.841019372901981700, +-0.841046422100898420, -0.841073469197199160, -0.841100514190816660, -0.841127557081682520, -0.841154597869729350, -0.841181636554889760, -0.841208673137096460, -0.841235707616281080, +-0.841262739992376440, -0.841289770265314930, -0.841316798435029050, -0.841343824501451070, -0.841370848464513600, -0.841397870324149030, -0.841424890080289760, -0.841451907732868270, +-0.841478923281816950, -0.841505936727068300, -0.841532948068555390, -0.841559957306209580, -0.841586964439963950, -0.841613969469750870, -0.841640972395503280, -0.841667973217152810, +-0.841694971934632390, -0.841721968547874620, -0.841748963056811910, -0.841775955461376730, -0.841802945761501720, -0.841829933957119360, -0.841856920048162150, -0.841883904034562590, +-0.841910885916253290, -0.841937865693167200, -0.841964843365236030, -0.841991818932392830, -0.842018792394570000, -0.842045763751700700, -0.842072733003716430, -0.842099700150550360, +-0.842126665192135080, -0.842153628128403110, -0.842180588959287160, -0.842207547684719620, -0.842234504304633200, -0.842261458818960640, -0.842288411227634310, -0.842315361530587060, +-0.842342309727751810, -0.842369255819060300, -0.842396199804445690, -0.842423141683840580, -0.842450081457178150, -0.842477019124389990, -0.842503954685409280, -0.842530888140168630, +-0.842557819488600760, -0.842584748730638380, -0.842611675866214100, -0.842638600895260770, -0.842665523817710760, -0.842692444633497020, -0.842719363342552150, -0.842746279944809440, +-0.842773194440200380, -0.842800106828658470, -0.842827017110116320, -0.842853925284506980, -0.842880831351762390, -0.842907735311815730, -0.842934637164599710, -0.842961536910047160, +-0.842988434548090800, -0.843015330078663250, -0.843042223501697440, -0.843069114817125990, -0.843096004024881830, -0.843122891124897690, -0.843149776117106290, -0.843176659001440900, +-0.843203539777833360, -0.843230418446217040, -0.843257295006524580, -0.843284169458689450, -0.843311041802643380, -0.843337912038319760, -0.843364780165651310, -0.843391646184570850, +-0.843418510095011340, -0.843445371896905600, -0.843472231590186470, -0.843499089174786660, -0.843525944650639130, -0.843552798017676690, -0.843579649275832840, -0.843606498425039320, +-0.843633345465229610, -0.843660190396336550, -0.843687033218293410, -0.843713873931032250, -0.843740712534486460, -0.843767549028588860, -0.843794383413272290, -0.843821215688469910, +-0.843848045854114330, -0.843874873910138820, -0.843901699856476010, -0.843928523693058930, -0.843955345419820650, -0.843982165036694320, -0.844008982543612230, -0.844035797940507650, +-0.844062611227313520, -0.844089422403963450, -0.844116231470389280, -0.844143038426524610, -0.844169843272302270, -0.844196646007655320, -0.844223446632516690, -0.844250245146819570, +-0.844277041550496770, -0.844303835843481450, -0.844330628025706460, -0.844357418097104850, -0.844384206057610330, -0.844410991907154630, -0.844437775645671570, -0.844464557273094110, +-0.844491336789355620, -0.844518114194388380, -0.844544889488125890, -0.844571662670501100, -0.844598433741447160, -0.844625202700897140, -0.844651969548784190, -0.844678734285041250, +-0.844705496909601390, -0.844732257422397880, -0.844759015823363770, -0.844785772112432110, -0.844812526289536400, -0.844839278354609040, -0.844866028307583390, -0.844892776148393090, +-0.844919521876970500, -0.844946265493249030, -0.844973006997161940, -0.844999746388642280, -0.845026483667623340, -0.845053218834038060, -0.845079951887819810, -0.845106682828901780, +-0.845133411657216890, -0.845160138372698540, -0.845186862975279780, -0.845213585464894450, -0.845240305841474580, -0.845267024104954020, -0.845293740255265820, -0.845320454292343810, +-0.845347166216120160, -0.845373876026528690, -0.845400583723502350, -0.845427289306974640, -0.845453992776878720, -0.845480694133147860, -0.845507393375715230, -0.845534090504514110, +-0.845560785519477780, -0.845587478420539380, -0.845614169207632880, -0.845640857880690430, -0.845667544439645870, -0.845694228884432460, -0.845720911214983940, -0.845747591431232570, +-0.845774269533112300, -0.845800945520556400, -0.845827619393498150, -0.845854291151870720, -0.845880960795607710, -0.845907628324642280, -0.845934293738907720, -0.845960957038337400, +-0.845987618222864720, -0.846014277292423510, -0.846040934246946040, -0.846067589086366260, -0.846094241810617540, -0.846120892419633730, -0.846147540913347210, -0.846174187291691800, +-0.846200831554600910, -0.846227473702007900, -0.846254113733846290, -0.846280751650049350, -0.846307387450550560, -0.846334021135283330, -0.846360652704181040, -0.846387282157177070, +-0.846413909494204920, -0.846440534715198420, -0.846467157820090190, -0.846493778808814050, -0.846520397681303830, -0.846547014437492250, -0.846573629077313150, -0.846600241600699910, +-0.846626852007586140, -0.846653460297905220, -0.846680066471590660, -0.846706670528575840, -0.846733272468794370, -0.846759872292179750, -0.846786469998665470, -0.846813065588185030, +-0.846839659060672380, -0.846866250416060120, -0.846892839654282190, -0.846919426775272210, -0.846946011778964110, -0.846972594665290510, -0.846999175434185460, -0.847025754085582340, +-0.847052330619414980, -0.847078905035616780, -0.847105477334121230, -0.847132047514862040, -0.847158615577772720, -0.847185181522786880, -0.847211745349838120, -0.847238307058860380, +-0.847264866649786510, -0.847291424122550430, -0.847317979477085760, -0.847344532713326550, -0.847371083831205630, -0.847397632830657050, -0.847424179711614320, -0.847450724474011150, +-0.847477267117781150, -0.847503807642857930, -0.847530346049175320, -0.847556882336666820, -0.847583416505266030, -0.847609948554906790, -0.847636478485523040, -0.847663006297047720, +-0.847689531989414880, -0.847716055562558140, -0.847742577016411760, -0.847769096350908580, -0.847795613565982540, -0.847822128661567480, -0.847848641637597100, -0.847875152494005140, +-0.847901661230725300, -0.847928167847691320, -0.847954672344836790, -0.847981174722095780, -0.848007674979401660, -0.848034173116688490, -0.848060669133890220, -0.848087163030939890, +-0.848113654807771680, -0.848140144464319730, -0.848166632000517010, -0.848193117416297770, -0.848219600711595630, -0.848246081886344540, -0.848272560940478200, -0.848299037873930460, +-0.848325512686635140, -0.848351985378526070, -0.848378455949536980, -0.848404924399601800, -0.848431390728654260, -0.848457854936628840, -0.848484317023458170, -0.848510776989076730, +-0.848537234833418360, -0.848563690556417450, -0.848590144158006820, -0.848616595638120750, -0.848643044996693190, -0.848669492233658060, -0.848695937348949210, -0.848722380342500580, +-0.848748821214245890, -0.848775259964119180, -0.848801696592054290, -0.848828131097985270, -0.848854563481846290, -0.848880993743570400, -0.848907421883092090, -0.848933847900345210, +-0.848960271795264230, -0.848986693567782110, -0.849013113217833130, -0.849039530745351430, -0.849065946150270980, -0.849092359432525590, -0.849118770592049320, -0.849145179628776110, +-0.849171586542640020, -0.849197991333574880, -0.849224394001514840, -0.849250794546394180, -0.849277192968146080, -0.849303589266705130, -0.849329983442005050, -0.849356375493980580, +-0.849382765422564630, -0.849409153227691840, -0.849435538909296130, -0.849461922467311560, -0.849488303901672180, -0.849514683212312050, -0.849541060399165220, -0.849567435462165730, +-0.849593808401247650, -0.849620179216345140, -0.849646547907392140, -0.849672914474323140, -0.849699278917071420, -0.849725641235571590, -0.849752001429758040, -0.849778359499564040, +-0.849804715444924200, -0.849831069265772450, -0.849857420962043200, -0.849883770533670260, -0.849910117980587910, -0.849936463302730320, -0.849962806500031530, -0.849989147572425720, +-0.850015486519847040, -0.850041823342229660, -0.850068158039508190, -0.850094490611615900, -0.850120821058487300, -0.850147149380056640, -0.850173475576258660, -0.850199799647026520, +-0.850226121592294830, -0.850252441411997850, -0.850278759106069760, -0.850305074674444830, -0.850331388117057110, -0.850357699433840990, -0.850384008624730630, -0.850410315689660190, +-0.850436620628564070, -0.850462923441376750, -0.850489224128031740, -0.850515522688463530, -0.850541819122606620, -0.850568113430395620, -0.850594405611763920, -0.850620695666646220, +-0.850646983594976700, -0.850673269396689750, -0.850699553071719630, -0.850725834620000620, -0.850752114041467000, -0.850778391336053040, -0.850804666503693240, -0.850830939544321760, +-0.850857210457873330, -0.850883479244281430, -0.850909745903480790, -0.850936010435405790, -0.850962272839991370, -0.850988533117170600, -0.851014791266878620, -0.851041047289049610, +-0.851067301183618060, -0.851093552950518250, -0.851119802589684450, -0.851146050101051270, -0.851172295484552870, -0.851198538740123740, -0.851224779867698290, -0.851251018867210880, +-0.851277255738596470, -0.851303490481788330, -0.851329723096721500, -0.851355953583330940, -0.851382181941549910, -0.851408408171313470, -0.851434632272556000, -0.851460854245211900, +-0.851487074089215760, -0.851513291804501860, -0.851539507391004700, -0.851565720848658890, -0.851591932177398700, -0.851618141377158740, -0.851644348447873400, -0.851670553389477610, +-0.851696756201904990, -0.851722956885090480, -0.851749155438968560, -0.851775351863474310, -0.851801546158541090, -0.851827738324104080, -0.851853928360097770, -0.851880116266456540, +-0.851906302043115020, -0.851932485690007790, -0.851958667207069360, -0.851984846594234240, -0.852011023851437010, -0.852037198978612300, -0.852063371975694930, -0.852089542842618730, +-0.852115711579318650, -0.852141878185729280, -0.852168042661785700, -0.852194205007421490, -0.852220365222571830, -0.852246523307171320, -0.852272679261154460, -0.852298833084455860, +-0.852324984777010130, -0.852351134338751980, -0.852377281769616020, -0.852403427069536870, -0.852429570238449120, -0.852455711276287940, -0.852481850182987060, -0.852507986958481510, +-0.852534121602705920, -0.852560254115595550, -0.852586384497084130, -0.852612512747106700, -0.852638638865597990, -0.852664762852492600, -0.852690884707725470, -0.852717004431231000, +-0.852743122022944110, -0.852769237482799310, -0.852795350810731550, -0.852821462006675300, -0.852847571070565410, -0.852873678002337150, -0.852899782801924130, -0.852925885469261620, +-0.852951986004285010, -0.852978084406927910, -0.853004180677125580, -0.853030274814812750, -0.853056366819924250, -0.853082456692394910, -0.853108544432159440, -0.853134630039152460, +-0.853160713513309020, -0.853186794854563830, -0.853212874062851510, -0.853238951138107100, -0.853265026080265780, -0.853291098889261470, -0.853317169565029340, -0.853343238107504340, +-0.853369304516621630, -0.853395368792315260, -0.853421430934520500, -0.853447490943172070, -0.853473548818205030, -0.853499604559553980, -0.853525658167153980, -0.853551709640939850, +-0.853577758980846420, -0.853603806186808640, -0.853629851258761340, -0.853655894196639790, -0.853681935000378140, -0.853707973669911580, -0.853734010205175140, -0.853760044606104110, +-0.853786076872632530, -0.853812107004695790, -0.853838135002228720, -0.853864160865166370, -0.853890184593443570, -0.853916206186995260, -0.853942225645756500, -0.853968242969662230, +-0.853994258158647270, -0.854020271212646680, -0.854046282131595840, -0.854072290915428910, -0.854098297564081180, -0.854124302077487800, -0.854150304455584040, -0.854176304698304080, +-0.854202302805583400, -0.854228298777356950, -0.854254292613559670, -0.854280284314126730, -0.854306273878993160, -0.854332261308093810, -0.854358246601363720, -0.854384229758738180, +-0.854410210780152000, -0.854436189665540250, -0.854462166414838520, -0.854488141027980990, -0.854514113504903030, -0.854540083845540250, -0.854566052049826830, -0.854592018117698250, +-0.854617982049089560, -0.854643943843936050, -0.854669903502172530, -0.854695861023734400, -0.854721816408556600, -0.854747769656574170, -0.854773720767722400, -0.854799669741936220, +-0.854825616579151020, -0.854851561279302170, -0.854877503842323860, -0.854903444268151900, -0.854929382556721350, -0.854955318707967700, -0.854981252721825350, -0.855007184598229890, +-0.855033114337116480, -0.855059041938420190, -0.855084967402076400, -0.855110890728020160, -0.855136811916186730, -0.855162730966511190, -0.855188647878928900, -0.855214562653374920, +-0.855240475289784970, -0.855266385788093440, -0.855292294148235930, -0.855318200370147720, -0.855344104453764410, -0.855370006399020390, -0.855395906205851380, -0.855421803874192640, +-0.855447699403979360, -0.855473592795146790, -0.855499484047630320, -0.855525373161365010, -0.855551260136286350, -0.855577144972329510, -0.855603027669429860, -0.855628908227523130, +-0.855654786646543600, -0.855680662926427080, -0.855706537067108970, -0.855732409068524990, -0.855758278930609410, -0.855784146653298270, -0.855810012236526640, -0.855835875680230120, +-0.855861736984343760, -0.855887596148803160, -0.855913453173543500, -0.855939308058500270, -0.855965160803608740, -0.855991011408804290, -0.856016859874022430, -0.856042706199198760, +-0.856068550384267880, -0.856094392429165630, -0.856120232333827950, -0.856146070098189100, -0.856171905722185160, -0.856197739205751370, -0.856223570548823250, -0.856249399751336290, +-0.856275226813225760, -0.856301051734427170, -0.856326874514875990, -0.856352695154507630, -0.856378513653257460, -0.856404330011061090, -0.856430144227854240, -0.856455956303571740, +-0.856481766238149200, -0.856507574031522330, -0.856533379683626970, -0.856559183194397610, -0.856584984563770410, -0.856610783791680650, -0.856636580878064050, -0.856662375822855870, +-0.856688168625991840, -0.856713959287407350, -0.856739747807037990, -0.856765534184819270, -0.856791318420686680, -0.856817100514576270, -0.856842880466422650, -0.856868658276161770, +-0.856894433943729330, -0.856920207469061280, -0.856945978852092230, -0.856971748092758110, -0.856997515190994760, -0.857023280146737560, -0.857049042959922240, -0.857074803630484270, +-0.857100562158359280, -0.857126318543482870, -0.857152072785790640, -0.857177824885218320, -0.857203574841701840, -0.857229322655175930, -0.857255068325576740, -0.857280811852839890, +-0.857306553236901410, -0.857332292477696160, -0.857358029575160160, -0.857383764529229150, -0.857409497339838620, -0.857435228006924510, -0.857460956530422200, -0.857486682910267530, +-0.857512407146396090, -0.857538129238743730, -0.857563849187245930, -0.857589566991839080, -0.857615282652457790, -0.857640996169038330, -0.857666707541516420, -0.857692416769828100, +-0.857718123853908330, -0.857743828793693260, -0.857769531589118620, -0.857795232240120110, -0.857820930746633570, -0.857846627108594720, -0.857872321325939160, -0.857898013398602940, +-0.857923703326521680, -0.857949391109631090, -0.857975076747867100, -0.858000760241165780, -0.858026441589462170, -0.858052120792692440, -0.858077797850792410, -0.858103472763698360, +-0.858129145531345230, -0.858154816153669180, -0.858180484630606030, -0.858206150962091740, -0.858231815148062020, -0.858257477188452800, -0.858283137083199920, -0.858308794832239100, +-0.858334450435506380, -0.858360103892937490, -0.858385755204468800, -0.858411404370035270, -0.858437051389573270, -0.858462696263018630, -0.858488338990307630, -0.858513979571375430, +-0.858539618006158190, -0.858565254294591960, -0.858590888436612580, -0.858616520432155970, -0.858642150281158090, -0.858667777983554870, -0.858693403539282140, -0.858719026948275840, +-0.858744648210472140, -0.858770267325807080, -0.858795884294216050, -0.858821499115635210, -0.858847111790000730, -0.858872722317248870, -0.858898330697314690, -0.858923936930134800, +-0.858949541015645020, -0.858975142953781300, -0.859000742744479910, -0.859026340387676560, -0.859051935883307300, -0.859077529231308310, -0.859103120431615410, -0.859128709484164750, +-0.859154296388892740, -0.859179881145734510, -0.859205463754626700, -0.859231044215505110, -0.859256622528306370, -0.859282198692965740, -0.859307772709419490, -0.859333344577603910, +-0.859358914297454810, -0.859384481868908590, -0.859410047291901070, -0.859435610566368520, -0.859461171692246890, -0.859486730669472340, -0.859512287497980920, -0.859537842177708790, +-0.859563394708592550, -0.859588945090567380, -0.859614493323569760, -0.859640039407535970, -0.859665583342402620, -0.859691125128104750, -0.859716664764579090, -0.859742202251761790, +-0.859767737589588910, -0.859793270777996720, -0.859818801816921390, -0.859844330706299060, -0.859869857446065920, -0.859895382036158120, -0.859920904476511820, -0.859946424767063730, +-0.859971942907749140, -0.859997458898504650, -0.860022972739266530, -0.860048484429971500, -0.860073993970554730, -0.860099501360953030, -0.860125006601102580, -0.860150509690939540, +-0.860176010630400280, -0.860201509419420970, -0.860227006057937890, -0.860252500545887310, -0.860277992883205500, -0.860303483069828620, -0.860328971105693620, -0.860354456990735650, +-0.860379940724891550, -0.860405422308097580, -0.860430901740290580, -0.860456379021405810, -0.860481854151380120, -0.860507327130149770, -0.860532797957651140, -0.860558266633820510, +-0.860583733158594160, -0.860609197531908450, -0.860634659753699900, -0.860660119823904560, -0.860685577742459020, -0.860711033509299890, -0.860736487124362790, -0.860761938587584540, +-0.860787387898901300, -0.860812835058250130, -0.860838280065566400, -0.860863722920786940, -0.860889163623848150, -0.860914602174686520, -0.860940038573238420, -0.860965472819440140, +-0.860990904913228160, -0.861016334854538990, -0.861041762643309010, -0.861067188279474590, -0.861092611762972140, -0.861118033093738690, -0.861143452271709630, -0.861168869296822010, +-0.861194284169012670, -0.861219696888217090, -0.861245107454372330, -0.861270515867414770, -0.861295922127280900, -0.861321326233907340, -0.861346728187230350, -0.861372127987186540, +-0.861397525633712520, -0.861422921126744570, -0.861448314466219390, -0.861473705652073370, -0.861499094684243570, -0.861524481562665590, -0.861549866287276480, -0.861575248858012510, +-0.861600629274811070, -0.861626007537607430, -0.861651383646338860, -0.861676757600941870, -0.861702129401352930, -0.861727499047508670, -0.861752866539345690, -0.861778231876800580, +-0.861803595059809750, -0.861828956088310120, -0.861854314962237970, -0.861879671681530460, -0.861905026246123420, -0.861930378655953790, -0.861955728910958170, -0.861981077011073740, +-0.862006422956236080, -0.862031766746382490, -0.862057108381449330, -0.862082447861373560, -0.862107785186091550, -0.862133120355540130, -0.862158453369655910, -0.862183784228375490, +-0.862209112931635600, -0.862234439479373060, -0.862259763871524810, -0.862285086108026680, -0.862310406188815830, -0.862335724113828970, -0.862361039883003280, -0.862386353496274570, +-0.862411664953579900, -0.862436974254856100, -0.862462281400039890, -0.862487586389067970, -0.862512889221876970, -0.862538189898403920, -0.862563488418585320, -0.862588784782358010, +-0.862614078989658690, -0.862639371040424210, -0.862664660934591710, -0.862689948672097140, -0.862715234252877770, -0.862740517676870660, -0.862765798944011840, -0.862791078054238600, +-0.862816355007487550, -0.862841629803695720, -0.862866902442799730, -0.862892172924736520, -0.862917441249442810, -0.862942707416855640, -0.862967971426911620, -0.862993233279547580, +-0.863018492974700570, -0.863043750512307750, -0.863069005892305170, -0.863094259114630000, -0.863119510179219170, -0.863144759086010070, -0.863170005834938640, -0.863195250425942140, +-0.863220492858957520, -0.863245733133921610, -0.863270971250771460, -0.863296207209443890, -0.863321441009875730, -0.863346672652004040, -0.863371902135765650, -0.863397129461097480, +-0.863422354627936930, -0.863447577636220040, -0.863472798485884210, -0.863498017176866470, -0.863523233709104000, -0.863548448082533060, -0.863573660297091040, -0.863598870352714760, +-0.863624078249341400, -0.863649283986907880, -0.863674487565351030, -0.863699688984608030, -0.863724888244615910, -0.863750085345311390, -0.863775280286631750, -0.863800473068514370, +-0.863825663690895310, -0.863850852153712050, -0.863876038456901750, -0.863901222600401810, -0.863926404584148270, -0.863951584408078840, -0.863976762072130370, -0.864001937576240000, +-0.864027110920344790, -0.864052282104381790, -0.864077451128288150, -0.864102617992000830, -0.864127782695456980, -0.864152945238593650, -0.864178105621348000, -0.864203263843657530, +-0.864228419905458400, -0.864253573806688210, -0.864278725547284580, -0.864303875127183760, -0.864329022546323160, -0.864354167804640030, -0.864379310902071430, -0.864404451838554630, +-0.864429590614026690, -0.864454727228424760, -0.864479861681686000, -0.864504993973747580, -0.864530124104546660, -0.864555252074020400, -0.864580377882106510, -0.864605501528741270, +-0.864630623013862290, -0.864655742337406720, -0.864680859499312170, -0.864705974499515030, -0.864731087337953010, -0.864756198014563270, -0.864781306529283090, -0.864806412882049620, +-0.864831517072800040, -0.864856619101471710, -0.864881718968001810, -0.864906816672327610, -0.864931912214386480, -0.864957005594115810, -0.864982096811452330, -0.865007185866333630, +-0.865032272758696870, -0.865057357488479890, -0.865082440055619180, -0.865107520460052240, -0.865132598701716550, -0.865157674780549390, -0.865182748696488040, -0.865207820449469760, +-0.865232890039431930, -0.865257957466311960, -0.865283022730047090, -0.865308085830574610, -0.865333146767832350, -0.865358205541756800, -0.865383262152285780, -0.865408316599356460, +-0.865433368882906890, -0.865458419002873570, -0.865483466959194090, -0.865508512751805850, -0.865533556380646440, -0.865558597845653140, -0.865583637146763340, -0.865608674283914410, +-0.865633709257043860, -0.865658742066088950, -0.865683772710987290, -0.865708801191676150, -0.865733827508093470, -0.865758851660175740, -0.865783873647860800, -0.865808893471086800, +-0.865833911129790020, -0.865858926623908510, -0.865883939953379640, -0.865908951118140920, -0.865933960118129840, -0.865958966953283780, -0.865983971623540460, -0.866008974128837150, +-0.866033974469111350, -0.866058972644300650, -0.866083968654342560, -0.866108962499174910, -0.866133954178734400, -0.866158943692959090, -0.866183931041786370, -0.866208916225154280, +-0.866233899242999540, -0.866258880095259980, -0.866283858781873200, -0.866308835302776800, -0.866333809657908290, -0.866358781847205270, -0.866383751870605230, -0.866408719728045900, +-0.866433685419464750, -0.866458648944799400, -0.866483610303987790, -0.866508569496966750, -0.866533526523674320, -0.866558481384048120, -0.866583434078026070, -0.866608384605545010, +-0.866633332966542990, -0.866658279160957720, -0.866683223188726700, -0.866708165049787540, -0.866733104744078050, -0.866758042271535860, -0.866782977632098440, -0.866807910825703630, +-0.866832841852289040, -0.866857770711792820, -0.866882697404151690, -0.866907621929303820, -0.866932544287186910, -0.866957464477739030, -0.866982382500897100, -0.867007298356599180, +-0.867032212044783090, -0.867057123565386330, -0.867082032918346960, -0.867106940103602340, -0.867131845121090430, -0.867156747970748930, -0.867181648652515570, -0.867206547166328060, +-0.867231443512124110, -0.867256337689842120, -0.867281229699418790, -0.867306119540792400, -0.867331007213901110, -0.867355892718681850, -0.867380776055072910, -0.867405657223011990, +-0.867430536222436930, -0.867455413053285550, -0.867480287715495680, -0.867505160209005030, -0.867530030533751550, -0.867554898689672950, -0.867579764676707050, -0.867604628494791810, +-0.867629490143865480, -0.867654349623864900, -0.867679206934728440, -0.867704062076393940, -0.867728915048799790, -0.867753765851882910, -0.867778614485581690, -0.867803460949833850, +-0.867828305244577320, -0.867853147369750060, -0.867877987325289980, -0.867902825111134810, -0.867927660727222720, -0.867952494173491410, -0.867977325449878820, -0.868002154556323460, +-0.868026981492762250, -0.868051806259133470, -0.868076628855375290, -0.868101449281425960, -0.868126267537222550, -0.868151083622703550, -0.868175897537806770, -0.868200709282470170, +-0.868225518856631910, -0.868250326260229800, -0.868275131493201900, -0.868299934555486150, -0.868324735447020600, -0.868349534167743190, -0.868374330717592400, -0.868399125096505300, +-0.868423917304420480, -0.868448707341275770, -0.868473495207009780, -0.868498280901559670, -0.868523064424863710, -0.868547845776860170, -0.868572624957486990, -0.868597401966682340, +-0.868622176804384140, -0.868646949470530450, -0.868671719965059430, -0.868696488287909020, -0.868721254439017490, -0.868746018418322770, -0.868770780225763480, -0.868795539861276780, +-0.868820297324801260, -0.868845052616275430, -0.868869805735636550, -0.868894556682823120, -0.868919305457773290, -0.868944052060425240, -0.868968796490717010, -0.868993538748586760, +-0.869018278833972760, -0.869043016746813060, -0.869067752487045710, -0.869092486054609090, -0.869117217449441150, -0.869141946671480700, -0.869166673720664920, -0.869191398596932400, +-0.869216121300221410, -0.869240841830470680, -0.869265560187617250, -0.869290276371599950, -0.869314990382357040, -0.869339702219826590, -0.869364411883946860, -0.869389119374656130, +-0.869413824691892660, -0.869438527835594500, -0.869463228805700150, -0.869487927602147660, -0.869512624224875850, -0.869537318673822000, -0.869562010948924820, -0.869586701050122590, +-0.869611388977354130, -0.869636074730556710, -0.869660758309669160, -0.869685439714629640, -0.869710118945376530, -0.869734796001848220, -0.869759470883982870, -0.869784143591718740, +-0.869808814124994330, -0.869833482483747920, -0.869858148667917770, -0.869882812677442720, -0.869907474512260140, -0.869932134172308970, -0.869956791657527370, -0.869981446967854290, +-0.870006100103227100, -0.870030751063584630, -0.870055399848865370, -0.870080046459007610, -0.870104690893949710, -0.870129333153630060, -0.870153973237987040, -0.870178611146959160, +-0.870203246880484780, -0.870227880438502190, -0.870252511820949980, -0.870277141027766880, -0.870301768058890480, -0.870326392914259730, -0.870351015593813450, -0.870375636097489020, +-0.870400254425225730, -0.870424870576961610, -0.870449484552635380, -0.870474096352185530, -0.870498705975550350, -0.870523313422668420, -0.870547918693478140, -0.870572521787918220, +-0.870597122705926820, -0.870621721447442760, -0.870646318012404770, -0.870670912400750560, -0.870695504612419070, -0.870720094647348790, -0.870744682505478760, -0.870769268186746490, +-0.870793851691091140, -0.870818433018451190, -0.870843012168765030, -0.870867589141971490, -0.870892163938008830, -0.870916736556815900, -0.870941306998331060, -0.870965875262492920, +-0.870990441349240090, -0.871015005258511720, -0.871039566990245320, -0.871064126544379920, -0.871088683920854370, -0.871113239119607360, -0.871137792140576960, -0.871162342983702100, +-0.871186891648921270, -0.871211438136173190, -0.871235982445396570, -0.871260524576530030, -0.871285064529512270, -0.871309602304281670, -0.871334137900777070, -0.871358671318937290, +-0.871383202558701160, -0.871407731620006510, -0.871432258502792710, -0.871456783206998150, -0.871481305732562110, -0.871505826079422290, -0.871530344247517960, -0.871554860236787740, +-0.871579374047170450, -0.871603885678604700, -0.871628395131029190, -0.871652902404382760, -0.871677407498604010, -0.871701910413631760, -0.871726411149404750, -0.871750909705862110, +-0.871775406082941800, -0.871799900280582960, -0.871824392298724330, -0.871848882137305160, -0.871873369796263400, -0.871897855275538200, -0.871922338575068400, -0.871946819694792710, +-0.871971298634649950, -0.871995775394579060, -0.872020249974518660, -0.872044722374407550, -0.872069192594184690, -0.872093660633788900, -0.872118126493158900, -0.872142590172234060, +-0.872167051670952320, -0.872191510989252850, -0.872215968127074690, -0.872240423084357120, -0.872264875861037960, -0.872289326457056590, -0.872313774872351950, -0.872338221106862880, +-0.872362665160528180, -0.872387107033286920, -0.872411546725077810, -0.872435984235839900, -0.872460419565512010, -0.872484852714032980, -0.872509283681342400, -0.872533712467378100, +-0.872558139072079460, -0.872582563495385540, -0.872606985737235720, -0.872631405797567930, -0.872655823676321660, -0.872680239373435750, -0.872704652888849240, -0.872729064222501180, +-0.872753473374330400, -0.872777880344276060, -0.872802285132276870, -0.872826687738271990, -0.872851088162200470, -0.872875486404001590, -0.872899882463613610, -0.872924276340975910, +-0.872948668036027550, -0.872973057548707910, -0.872997444878955140, -0.873021830026708860, -0.873046212991907990, -0.873070593774491480, -0.873094972374398590, -0.873119348791568270, +-0.873143723025939570, -0.873168095077451520, -0.873192464946043300, -0.873216832631653840, -0.873241198134222740, -0.873265561453688280, -0.873289922589989830, -0.873314281543066670, +-0.873338638312858180, -0.873362992899302640, -0.873387345302339630, -0.873411695521908340, -0.873436043557947790, -0.873460389410397050, -0.873484733079195390, -0.873509074564281840, +-0.873533413865595690, -0.873557750983075980, -0.873582085916661870, -0.873606418666292520, -0.873630749231907640, -0.873655077613445410, -0.873679403810845520, -0.873703727824047040, +-0.873728049652989670, -0.873752369297611910, -0.873776686757853030, -0.873801002033652520, -0.873825315124949540, -0.873849626031683150, -0.873873934753792820, -0.873898241291217630, +-0.873922545643896820, -0.873946847811769680, -0.873971147794775360, -0.873995445592853580, -0.874019741205942840, -0.874044034633982720, -0.874068325876912410, -0.874092614934671830, +-0.874116901807199250, -0.874141186494434510, -0.874165468996316640, -0.874189749312785260, -0.874214027443779410, -0.874238303389238470, -0.874262577149101830, -0.874286848723308750, +-0.874311118111798510, -0.874335385314510490, -0.874359650331384410, -0.874383913162358860, -0.874408173807373460, -0.874432432266367580, -0.874456688539281160, -0.874480942626052580, +-0.874505194526621570, -0.874529444240927600, -0.874553691768910070, -0.874577937110508240, -0.874602180265661610, -0.874626421234309450, -0.874650660016391360, -0.874674896611846500, +-0.874699131020614470, -0.874723363242635000, -0.874747593277846790, -0.874771821126189560, -0.874796046787602700, -0.874820270262026240, -0.874844491549398580, -0.874868710649659760, +-0.874892927562749170, -0.874917142288606290, -0.874941354827170500, -0.874965565178381310, -0.874989773342178200, -0.875013979318500670, -0.875038183107288200, -0.875062384708480300, +-0.875086584122016450, -0.875110781347836600, -0.875134976385879230, -0.875159169236084500, -0.875183359898392350, -0.875207548372741280, -0.875231734659071340, -0.875255918757322120, +-0.875280100667433000, -0.875304280389343710, -0.875328457922993740, -0.875352633268322580, -0.875376806425269830, -0.875400977393775090, -0.875425146173777870, -0.875449312765217760, +-0.875473477168034920, -0.875497639382167850, -0.875521799407556700, -0.875545957244141080, -0.875570112891861040, -0.875594266350655180, -0.875618417620463770, -0.875642566701226200, +-0.875666713592882280, -0.875690858295371630, -0.875715000808633740, -0.875739141132608420, -0.875763279267235180, -0.875787415212453730, -0.875811548968203790, -0.875835680534425400, +-0.875859809911057390, -0.875883937098039800, -0.875908062095312470, -0.875932184902815330, -0.875956305520487310, -0.875980423948268580, -0.876004540186098750, -0.876028654233917630, +-0.876052766091664830, -0.876076875759280060, -0.876100983236703160, -0.876125088523873720, -0.876149191620731680, -0.876173292527216650, -0.876197391243268680, -0.876221487768826910, +-0.876245582103831410, -0.876269674248222000, -0.876293764201938830, -0.876317851964920740, -0.876341937537108100, -0.876366020918440510, -0.876390102108857930, -0.876414181108300160, +-0.876438257916706820, -0.876462332534017950, -0.876486404960173160, -0.876510475195112380, -0.876534543238775440, -0.876558609091102170, -0.876582672752032720, -0.876606734221506260, +-0.876630793499462820, -0.876654850585842920, -0.876678905480585470, -0.876702958183630750, -0.876727008694918710, -0.876751057014389050, -0.876775103141981700, -0.876799147077636730, +-0.876823188821293730, -0.876847228372892860, -0.876871265732373950, -0.876895300899676820, -0.876919333874741520, -0.876943364657508220, -0.876967393247916060, -0.876991419645905550, +-0.877015443851416390, -0.877039465864389080, -0.877063485684762670, -0.877087503312477530, -0.877111518747473620, -0.877135531989690960, -0.877159543039069400, -0.877183551895549090, +-0.877207558559069840, -0.877231563029571610, -0.877255565306994560, -0.877279565391278600, -0.877303563282364140, -0.877327558980190440, -0.877351552484697760, -0.877375543795826160, +-0.877399532913516130, -0.877423519837706940, -0.877447504568338870, -0.877471487105352050, -0.877495467448686560, -0.877519445598282320, -0.877543421554079490, -0.877567395316018130, +-0.877591366884038270, -0.877615336258079970, -0.877639303438083380, -0.877663268423989010, -0.877687231215735890, -0.877711191813264850, -0.877735150216515710, -0.877759106425429200, +-0.877783060439944360, -0.877807012260002020, -0.877830961885542100, -0.877854909316504780, -0.877878854552830210, -0.877902797594458440, -0.877926738441329730, -0.877950677093384150, +-0.877974613550561940, -0.877998547812803070, -0.878022479880047890, -0.878046409752237020, -0.878070337429309620, -0.878094262911206400, -0.878118186197867970, -0.878142107289233590, +-0.878166026185243980, -0.878189942885839290, -0.878213857390959700, -0.878237769700545570, -0.878261679814536960, -0.878285587732874130, -0.878309493455497360, -0.878333396982346800, +-0.878357298313362840, -0.878381197448485530, -0.878405094387655790, -0.878428989130812800, -0.878452881677897370, -0.878476772028849660, -0.878500660183610500, -0.878524546142119280, +-0.878548429904316700, -0.878572311470143030, -0.878596190839538550, -0.878620068012443630, -0.878643942988798550, -0.878667815768543580, -0.878691686351619090, -0.878715554737965370, +-0.878739420927522770, -0.878763284920232150, -0.878787146716032750, -0.878811006314865530, -0.878834863716670740, -0.878858718921389340, -0.878882571928960580, -0.878906422739325510, +-0.878930271352424300, -0.878954117768197430, -0.878977961986585290, -0.879001804007528250, -0.879025643830966710, -0.879049481456841030, -0.879073316885091600, -0.879097150115658920, +-0.879120981148483800, -0.879144809983505860, -0.879168636620665800, -0.879192461059904230, -0.879216283301161860, -0.879240103344378410, -0.879263921189494590, -0.879287736836451120, +-0.879311550285188260, -0.879335361535646510, -0.879359170587766360, -0.879382977441488300, -0.879406782096752710, -0.879430584553500210, -0.879454384811671260, -0.879478182871206380, +-0.879501978732046500, -0.879525772394131210, -0.879549563857401460, -0.879573353121798180, -0.879597140187261210, -0.879620925053731350, -0.879644707721149110, -0.879668488189455200, +-0.879692266458590000, -0.879716042528494110, -0.879739816399108250, -0.879763588070372690, -0.879787357542228250, -0.879811124814615430, -0.879834889887474710, -0.879858652760747260, +-0.879882413434372790, -0.879906171908292230, -0.879929928182446200, -0.879953682256775840, -0.879977434131220870, -0.880001183805722230, -0.880024931280220750, -0.880048676554656790, +-0.880072419628971310, -0.880096160503104690, -0.880119899176997620, -0.880143635650590840, -0.880167369923825050, -0.880191101996640750, -0.880214831868979090, -0.880238559540780010, +-0.880262285011984450, -0.880286008282533230, -0.880309729352367400, -0.880333448221426900, -0.880357164889652650, -0.880380879356985610, -0.880404591623366260, -0.880428301688735540, +-0.880452009553034040, -0.880475715216202490, -0.880499418678181600, -0.880523119938912190, -0.880546818998335090, -0.880570515856391230, -0.880594210513020670, -0.880617902968164670, +-0.880641593221763830, -0.880665281273759540, -0.880688967124091500, -0.880712650772701110, -0.880736332219529070, -0.880760011464516210, -0.880783688507603360, -0.880807363348731220, +-0.880831035987840630, -0.880854706424872510, -0.880878374659767700, -0.880902040692466910, -0.880925704522910970, -0.880949366151041250, -0.880973025576797570, -0.880996682800121440, +-0.881020337820954010, -0.881043990639235330, -0.881067641254906660, -0.881091289667908840, -0.881114935878182900, -0.881138579885669570, -0.881162221690309780, -0.881185861292044350, +-0.881209498690814330, -0.881233133886560660, -0.881256766879224050, -0.881280397668745550, -0.881304026255066430, -0.881327652638126960, -0.881351276817868290, -0.881374898794231370, +-0.881398518567157670, -0.881422136136587260, -0.881445751502461520, -0.881469364664721370, -0.881492975623307750, -0.881516584378161830, -0.881540190929224310, -0.881563795276436470, +-0.881587397419739020, -0.881610997359073110, -0.881634595094379690, -0.881658190625600250, -0.881681783952674820, -0.881705375075545030, -0.881728963994151790, -0.881752550708436500, +-0.881776135218339530, -0.881799717523802150, -0.881823297624765410, -0.881846875521170470, -0.881870451212958370, -0.881894024700070170, -0.881917595982446900, -0.881941165060029620, +-0.881964731932759370, -0.881988296600577320, -0.882011859063425050, -0.882035419321242630, -0.882058977373971650, -0.882082533221553170, -0.882106086863928880, -0.882129638301038970, +-0.882153187532824900, -0.882176734559227850, -0.882200279380188970, -0.882223821995649420, -0.882247362405550350, -0.882270900609832820, -0.882294436608438090, -0.882317970401307220, +-0.882341501988381460, -0.882365031369601870, -0.882388558544910160, -0.882412083514246710, -0.882435606277552910, -0.882459126834770680, -0.882482645185840080, -0.882506161330702920, +-0.882529675269300370, -0.882553187001573590, -0.882576696527463840, -0.882600203846912400, -0.882623708959860420, -0.882647211866249170, -0.882670712566019920, -0.882694211059113830, +-0.882717707345472280, -0.882741201425036870, -0.882764693297747980, -0.882788182963547440, -0.882811670422376400, -0.882835155674176590, -0.882858638718888480, -0.882882119556453790, +-0.882905598186813800, -0.882929074609909770, -0.882952548825683080, -0.882976020834075000, -0.882999490635026920, -0.883022958228480090, -0.883046423614375910, -0.883069886792655630, +-0.883093347763260980, -0.883116806526132670, -0.883140263081212300, -0.883163717428441240, -0.883187169567761330, -0.883210619499113060, -0.883234067222438250, -0.883257512737678270, +-0.883280956044774520, -0.883304397143668370, -0.883327836034301210, -0.883351272716614510, -0.883374707190549560, -0.883398139456047950, -0.883421569513050840, -0.883444997361500390, +-0.883468423001336880, -0.883491846432502450, -0.883515267654938260, -0.883538686668586480, -0.883562103473387370, -0.883585518069283200, -0.883608930456215140, -0.883632340634124770, +-0.883655748602953480, -0.883679154362642880, -0.883702557913134460, -0.883725959254369590, -0.883749358386289760, -0.883772755308836590, -0.883796150021951550, -0.883819542525576480, +-0.883842932819652210, -0.883866320904120650, -0.883889706778923650, -0.883913090444001900, -0.883936471899297470, -0.883959851144751840, -0.883983228180306720, -0.884006603005903390, +-0.884029975621483550, -0.884053346026988820, -0.884076714222360780, -0.884100080207540830, -0.884123443982470780, -0.884146805547092020, -0.884170164901346810, -0.884193522045175650, +-0.884216876978520690, -0.884240229701323540, -0.884263580213526360, -0.884286928515069630, -0.884310274605895730, -0.884333618485946050, -0.884356960155162410, -0.884380299613486300, +-0.884403636860859430, -0.884426971897223520, -0.884450304722520060, -0.884473635336690990, -0.884496963739677790, -0.884520289931422620, -0.884543613911866200, -0.884566935680950790, +-0.884590255238618120, -0.884613572584810210, -0.884636887719467910, -0.884660200642533370, -0.884683511353948400, -0.884706819853654510, -0.884730126141593740, -0.884753430217707580, +-0.884776732081937860, -0.884800031734226280, -0.884823329174514670, -0.884846624402744750, -0.884869917418858560, -0.884893208222797270, -0.884916496814502910, -0.884939783193917420, +-0.884963067360982740, -0.884986349315640020, -0.885009629057831540, -0.885032906587498890, -0.885056181904583910, -0.885079455009028630, -0.885102725900774550, -0.885125994579763820, +-0.885149261045937940, -0.885172525299238950, -0.885195787339608800, -0.885219047166988960, -0.885242304781322040, -0.885265560182548980, -0.885288813370611940, -0.885312064345453290, +-0.885335313107014080, -0.885358559655236580, -0.885381803990062720, -0.885405046111434340, -0.885428286019293350, -0.885451523713581600, -0.885474759194241010, -0.885497992461213630, +-0.885521223514441180, -0.885544452353865700, -0.885567678979429120, -0.885590903391073710, -0.885614125588740640, -0.885637345572372280, -0.885660563341910570, -0.885683778897297880, +-0.885706992238475270, -0.885730203365385220, -0.885753412277969670, -0.885776618976170550, -0.885799823459929910, -0.885823025729189690, -0.885846225783891830, -0.885869423623978580, +-0.885892619249391670, -0.885915812660073240, -0.885939003855965580, -0.885962192837010170, -0.885985379603149160, -0.886008564154324720, -0.886031746490479330, -0.886054926611554160, +-0.886078104517491690, -0.886101280208233870, -0.886124453683722950, -0.886147624943900760, -0.886170793988709680, -0.886193960818091430, -0.886217125431988380, -0.886240287830342590, +-0.886263448013095980, -0.886286605980191160, -0.886309761731569500, -0.886332915267173390, -0.886356066586944990, -0.886379215690826780, -0.886402362578760150, -0.886425507250687580, +-0.886448649706551350, -0.886471789946293390, -0.886494927969856070, -0.886518063777181340, -0.886541197368211460, -0.886564328742888600, -0.886587457901155010, -0.886610584842952630, +-0.886633709568224290, -0.886656832076911150, -0.886679952368956030, -0.886703070444301080, -0.886726186302888800, -0.886749299944660560, -0.886772411369559200, -0.886795520577526750, +-0.886818627568505490, -0.886841732342437680, -0.886864834899265600, -0.886887935238931390, -0.886911033361377330, -0.886934129266545690, -0.886957222954378730, -0.886980314424818620, +-0.887003403677808280, -0.887026490713288980, -0.887049575531203450, -0.887072658131493940, -0.887095738514103170, -0.887118816678972740, -0.887141892626045260, -0.887164966355262980, +-0.887188037866568300, -0.887211107159903590, -0.887234174235211000, -0.887257239092433040, -0.887280301731512070, -0.887303362152390250, -0.887326420355009970, -0.887349476339314160, +-0.887372530105244190, -0.887395581652742900, -0.887418630981752670, -0.887441678092216300, -0.887464722984075300, -0.887487765657272500, -0.887510806111750260, -0.887533844347450970, +-0.887556880364317120, -0.887579914162291090, -0.887602945741315260, -0.887625975101332010, -0.887649002242283940, -0.887672027164113310, -0.887695049866762950, -0.887718070350174690, +-0.887741088614291130, -0.887764104659054860, -0.887787118484408830, -0.887810130090294520, -0.887833139476654990, -0.887856146643432490, -0.887879151590569630, -0.887902154318008900, +-0.887925154825692900, -0.887948153113563900, -0.887971149181564500, -0.887994143029637310, -0.888017134657724690, -0.888040124065769710, -0.888063111253713950, -0.888086096221500480, +-0.888109078969071650, -0.888132059496370640, -0.888155037803339040, -0.888178013889919900, -0.888200987756055600, -0.888223959401688970, -0.888246928826762370, -0.888269896031218420, +-0.888292861014999820, -0.888315823778048960, -0.888338784320308660, -0.888361742641721300, -0.888384698742229580, -0.888407652621776570, -0.888430604280304070, -0.888453553717754920, +-0.888476500934072040, -0.888499445929198160, -0.888522388703075430, -0.888545329255646550, -0.888568267586854480, -0.888591203696641680, -0.888614137584950890, -0.888637069251724810, +-0.888659998696905930, -0.888682925920437180, -0.888705850922261060, -0.888728773702320280, -0.888751694260558000, -0.888774612596916150, -0.888797528711337660, -0.888820442603765470, +-0.888843354274142410, -0.888866263722410730, -0.888889170948513270, -0.888912075952392970, -0.888934978733992410, -0.888957879293254430, -0.888980777630121730, -0.889003673744537150, +-0.889026567636443280, -0.889049459305783160, -0.889072348752499190, -0.889095235976534950, -0.889118120977832050, -0.889141003756333980, -0.889163884311983340, -0.889186762644723410, +-0.889209638754496100, -0.889232512641244700, -0.889255384304912130, -0.889278253745441010, -0.889301120962774250, -0.889323985956854690, -0.889346848727625260, -0.889369709275028670, +-0.889392567599007760, -0.889415423699505440, -0.889438277576464990, -0.889461129229828450, -0.889483978659538990, -0.889506825865539750, -0.889529670847773680, -0.889552513606183150, +-0.889575354140711320, -0.889598192451301010, -0.889621028537895380, -0.889643862400437020, -0.889666694038869110, -0.889689523453134460, -0.889712350643175890, -0.889735175608936560, +-0.889757998350359290, -0.889780818867386910, -0.889803637159963020, -0.889826453228029560, -0.889849267071530000, -0.889872078690407630, -0.889894888084604710, -0.889917695254064610, +-0.889940500198730170, -0.889963302918544530, -0.889986103413450640, -0.890008901683391530, -0.890031697728310140, -0.890054491548149420, -0.890077283142852500, -0.890100072512362450, +-0.890122859656622190, -0.890145644575575210, -0.890168427269163680, -0.890191207737331070, -0.890213985980020440, -0.890236761997175270, -0.890259535788737730, -0.890282307354651410, +-0.890305076694859370, -0.890327843809304520, -0.890350608697930150, -0.890373371360679290, -0.890396131797494880, -0.890418890008320310, -0.890441645993098390, -0.890464399751772380, +-0.890487151284285790, -0.890509900590580880, -0.890532647670601250, -0.890555392524289950, -0.890578135151590680, -0.890600875552445600, -0.890623613726798320, -0.890646349674592000, +-0.890669083395769780, -0.890691814890274940, -0.890714544158050510, -0.890737271199039780, -0.890759996013185780, -0.890782718600431900, -0.890805438960721170, -0.890828157093997210, +-0.890850873000202490, -0.890873586679280520, -0.890896298131174660, -0.890919007355828410, -0.890941714353184370, -0.890964419123185910, -0.890987121665776430, -0.891009821980899170, +-0.891032520068497310, -0.891055215928514220, -0.891077909560893060, -0.891100600965577080, -0.891123290142509570, -0.891145977091633900, -0.891168661812893340, -0.891191344306231480, +-0.891214024571590820, -0.891236702608915190, -0.891259378418148170, -0.891282051999232270, -0.891304723352111190, -0.891327392476728430, -0.891350059373027140, -0.891372724040950580, +-0.891395386480442360, -0.891418046691445640, -0.891440704673903790, -0.891463360427760200, -0.891486013952958230, -0.891508665249441170, -0.891531314317152820, -0.891553961156035800, +-0.891576605766033920, -0.891599248147090570, -0.891621888299149460, -0.891644526222153180, -0.891667161916045670, -0.891689795380770090, -0.891712426616270150, -0.891735055622489230, +-0.891757682399370480, -0.891780306946857610, -0.891802929264894020, -0.891825549353423060, -0.891848167212388240, -0.891870782841733380, -0.891893396241401180, -0.891916007411335480, +-0.891938616351479750, -0.891961223061777940, -0.891983827542172650, -0.892006429792607800, -0.892029029813026790, -0.892051627603373310, -0.892074223163590750, -0.892096816493622600, +-0.892119407593412350, -0.892141996462903710, -0.892164583102039940, -0.892187167510764770, -0.892209749689022110, -0.892232329636754700, -0.892254907353906450, -0.892277482840420850, +-0.892300056096241970, -0.892322627121312610, -0.892345195915576710, -0.892367762478977760, -0.892390326811459360, -0.892412888912965220, -0.892435448783438830, -0.892458006422823800, +-0.892480561831063830, -0.892503115008102420, -0.892525665953883160, -0.892548214668349770, -0.892570761151446290, -0.892593305403115430, -0.892615847423301360, -0.892638387211948100, +-0.892660924768998390, -0.892683460094396360, -0.892705993188085740, -0.892728524050010130, -0.892751052680113230, -0.892773579078338650, -0.892796103244630210, -0.892818625178931400, +-0.892841144881186160, -0.892863662351337960, -0.892886177589330640, -0.892908690595108250, -0.892931201368613700, -0.892953709909791170, -0.892976216218584470, -0.892998720294937540, +-0.893021222138793420, -0.893043721750096160, -0.893066219128789700, -0.893088714274817730, -0.893111207188123870, -0.893133697868652040, -0.893156186316345970, -0.893178672531149460, +-0.893201156513006240, -0.893223638261860130, -0.893246117777655280, -0.893268595060334740, -0.893291070109842770, -0.893313542926123080, -0.893336013509119950, -0.893358481858776420, +-0.893380947975036640, -0.893403411857844550, -0.893425873507143860, -0.893448332922878510, -0.893470790104992420, -0.893493245053429200, -0.893515697768133000, -0.893538148249047430, +-0.893560596496116630, -0.893583042509284660, -0.893605486288494680, -0.893627927833690940, -0.893650367144817490, -0.893672804221818500, -0.893695239064636990, -0.893717671673217470, +-0.893740102047503760, -0.893762530187439790, -0.893784956092969480, -0.893807379764036900, -0.893829801200585750, -0.893852220402560070, -0.893874637369903910, -0.893897052102561100, +-0.893919464600475780, -0.893941874863592110, -0.893964282891853370, -0.893986688685203920, -0.894009092243588040, -0.894031493566949220, -0.894053892655231500, -0.894076289508379140, +-0.894098684126336090, -0.894121076509046260, -0.894143466656453720, -0.894165854568502620, -0.894188240245136770, -0.894210623686300440, -0.894233004891937470, -0.894255383861991990, +-0.894277760596408400, -0.894300135095130070, -0.894322507358101480, -0.894344877385266470, -0.894367245176569740, -0.894389610731954550, -0.894411974051365300, -0.894434335134746130, +-0.894456693982041080, -0.894479050593194210, -0.894501404968149890, -0.894523757106851950, -0.894546107009244640, -0.894568454675272130, -0.894590800104878350, -0.894613143298008120, +-0.894635484254604480, -0.894657822974612270, -0.894680159457975410, -0.894702493704638610, -0.894724825714545150, -0.894747155487639610, -0.894769483023866160, -0.894791808323169070, +-0.894814131385492370, -0.894836452210780450, -0.894858770798977350, -0.894881087150027340, -0.894903401263874580, -0.894925713140463320, -0.894948022779738170, -0.894970330181642630, +-0.894992635346121170, -0.895014938273118180, -0.895037238962578250, -0.895059537414444770, -0.895081833628662450, -0.895104127605175660, -0.895126419343928450, -0.895148708844865190, +-0.895170996107930160, -0.895193281133067730, -0.895215563920222060, -0.895237844469337410, -0.895260122780358160, -0.895282398853228690, -0.895304672687893490, -0.895326944284296270, +-0.895349213642381740, -0.895371480762094610, -0.895393745643378260, -0.895416008286177620, -0.895438268690436970, -0.895460526856100560, -0.895482782783112890, -0.895505036471418210, +-0.895527287920961030, -0.895549537131685610, -0.895571784103536330, -0.895594028836457560, -0.895616271330393790, -0.895638511585289730, -0.895660749601088880, -0.895682985377736270, +-0.895705218915176180, -0.895727450213353430, -0.895749679272211610, -0.895771906091695660, -0.895794130671749960, -0.895816353012318880, -0.895838573113346910, -0.895860790974778550, +-0.895883006596558170, -0.895905219978630370, -0.895927431120939420, -0.895949640023429920, -0.895971846686046680, -0.895994051108733540, -0.896016253291435190, -0.896038453234096140, +-0.896060650936661430, -0.896082846399074760, -0.896105039621280850, -0.896127230603224410, -0.896149419344849930, -0.896171605846101890, -0.896193790106924790, -0.896215972127263230, +-0.896238151907061690, -0.896260329446264880, -0.896282504744817190, -0.896304677802663540, -0.896326848619747980, -0.896349017196015230, -0.896371183531409880, -0.896393347625876970, +-0.896415509479360330, -0.896437669091804890, -0.896459826463155360, -0.896481981593356240, -0.896504134482352110, -0.896526285130087700, -0.896548433536507480, -0.896570579701556290, +-0.896592723625178610, -0.896614865307319150, -0.896637004747922410, -0.896659141946933640, -0.896681276904296660, -0.896703409619956430, -0.896725540093858080, -0.896747668325945550, +-0.896769794316163770, -0.896791918064457460, -0.896814039570771440, -0.896836158835050300, -0.896858275857238760, -0.896880390637281640, -0.896902503175123430, -0.896924613470708950, +-0.896946721523982910, -0.896968827334890140, -0.896990930903375670, -0.897013032229383560, -0.897035131312858720, -0.897057228153746110, -0.897079322751990870, -0.897101415107536940, +-0.897123505220329460, -0.897145593090313160, -0.897167678717432860, -0.897189762101633480, -0.897211843242859630, -0.897233922141056130, -0.897255998796167910, -0.897278073208139570, +-0.897300145376916160, -0.897322215302442720, -0.897344282984663400, -0.897366348423523360, -0.897388411618967430, -0.897410472570940860, -0.897432531279387710, -0.897454587744253240, +-0.897476641965482380, -0.897498693943019840, -0.897520743676810560, -0.897542791166799470, -0.897564836412931280, -0.897586879415151140, -0.897608920173403770, -0.897630958687634100, +-0.897652994957787390, -0.897675028983807800, -0.897697060765640600, -0.897719090303230830, -0.897741117596523750, -0.897763142645463420, -0.897785165449995200, -0.897807186010064150, +-0.897829204325615080, -0.897851220396593040, -0.897873234222942850, -0.897895245804609670, -0.897917255141538420, -0.897939262233673930, -0.897961267080961360, -0.897983269683345520, +-0.898005270040772020, -0.898027268153184900, -0.898049264020529540, -0.898071257642751530, -0.898093249019794930, -0.898115238151605210, -0.898137225038127430, -0.898159209679306510, +-0.898181192075087620, -0.898203172225415790, -0.898225150130235960, -0.898247125789493280, -0.898269099203132800, -0.898291070371099560, -0.898313039293338610, -0.898335005969795540, +-0.898356970400414510, -0.898378932585141010, -0.898400892523920300, -0.898422850216697650, -0.898444805663417450, -0.898466758864025380, -0.898488709818466290, -0.898510658526685440, +-0.898532604988627970, -0.898554549204238940, -0.898576491173463610, -0.898598430896247020, -0.898620368372534340, -0.898642303602270820, -0.898664236585401840, -0.898686167321871900, +-0.898708095811626580, -0.898730022054610940, -0.898751946050770690, -0.898773867800050200, -0.898795787302395070, -0.898817704557750450, -0.898839619566061510, -0.898861532327273500, +-0.898883442841331810, -0.898905351108181370, -0.898927257127767660, -0.898949160900035740, -0.898971062424930860, -0.898992961702398840, -0.899014858732383960, -0.899036753514831920, +-0.899058646049687990, -0.899080536336897880, -0.899102424376406080, -0.899124310168158080, -0.899146193712099470, -0.899168075008175300, -0.899189954056330840, -0.899211830856511680, +-0.899233705408662880, -0.899255577712729790, -0.899277447768657700, -0.899299315576392090, -0.899321181135878560, -0.899343044447061590, -0.899364905509887120, -0.899386764324300310, +-0.899408620890247090, -0.899430475207671830, -0.899452327276520470, -0.899474177096738160, -0.899496024668270500, -0.899517869991062760, -0.899539713065060420, -0.899561553890208640, +-0.899583392466453140, -0.899605228793739050, -0.899627062872012000, -0.899648894701217120, -0.899670724281300570, -0.899692551612206740, -0.899714376693881430, -0.899736199526270370, +-0.899758020109319050, -0.899779838442972380, -0.899801654527176090, -0.899823468361875660, -0.899845279947016570, -0.899867089282544220, -0.899888896368404190, -0.899910701204541970, +-0.899932503790902950, -0.899954304127432710, -0.899976102214076650, -0.899997898050780790, -0.900019691637489740, -0.900041482974149430, -0.900063272060705470, -0.900085058897103660, +-0.900106843483288950, -0.900128625819207050, -0.900150405904803550, -0.900172183740024060, -0.900193959324814160, -0.900215732659119250, -0.900237503742885140, -0.900259272576057200, +-0.900281039158581040, -0.900302803490402370, -0.900324565571467010, -0.900346325401719880, -0.900368082981106930, -0.900389838309573750, -0.900411591387066500, -0.900433342213529660, +-0.900455090788909620, -0.900476837113151850, -0.900498581186201960, -0.900520323008005550, -0.900542062578508440, -0.900563799897656110, -0.900585534965394290, -0.900607267781668660, +-0.900628998346424850, -0.900650726659608880, -0.900672452721165810, -0.900694176531041560, -0.900715898089181840, -0.900737617395532820, -0.900759334450039310, -0.900781049252647460, +-0.900802761803302990, -0.900824472101951600, -0.900846180148539120, -0.900867885943011150, -0.900889589485313500, -0.900911290775391780, -0.900932989813191920, -0.900954686598659520, +-0.900976381131740390, -0.900998073412380810, -0.901019763440525590, -0.901041451216120890, -0.901063136739112650, -0.901084820009446900, -0.901106501027068800, -0.901128179791924390, +-0.901149856303959500, -0.901171530563120050, -0.901193202569351760, -0.901214872322600450, -0.901236539822811930, -0.901258205069932040, -0.901279868063906700, -0.901301528804681730, +-0.901323187292203180, -0.901344843526416420, -0.901366497507267490, -0.901388149234702340, -0.901409798708667110, -0.901431445929107070, -0.901453090895968480, -0.901474733609197050, +-0.901496374068738840, -0.901518012274539650, -0.901539648226545530, -0.901561281924702200, -0.901582913368955690, -0.901604542559251930, -0.901626169495536760, -0.901647794177756530, +-0.901669416605856530, -0.901691036779782910, -0.901712654699481810, -0.901734270364899280, -0.901755883775980820, -0.901777494932672560, -0.901799103834920680, -0.901820710482670980, +-0.901842314875869520, -0.901863917014462220, -0.901885516898395130, -0.901907114527614300, -0.901928709902065640, -0.901950303021695320, -0.901971893886449490, -0.901993482496273650, +-0.902015068851113930, -0.902036652950916730, -0.902058234795628190, -0.902079814385193690, -0.902101391719559610, -0.902122966798672100, -0.902144539622477200, -0.902166110190920970, +-0.902187678503949430, -0.902209244561508640, -0.902230808363544750, -0.902252369910003900, -0.902273929200832160, -0.902295486235975440, -0.902317041015380570, -0.902338593538992590, +-0.902360143806758220, -0.902381691818623820, -0.902403237574534780, -0.902424781074437690, -0.902446322318278590, -0.902467861306003760, -0.902489398037559230, -0.902510932512891160, +-0.902532464731945820, -0.902553994694669350, -0.902575522401007910, -0.902597047850907550, -0.902618571044314640, -0.902640091981175670, -0.902661610661436130, -0.902683127085042500, +-0.902704641251941160, -0.902726153162078490, -0.902747662815400090, -0.902769170211852550, -0.902790675351382020, -0.902812178233934890, -0.902833678859457310, -0.902855177227895430, +-0.902876673339195630, -0.902898167193304290, -0.902919658790167450, -0.902941148129731360, -0.902962635211942870, -0.902984120036747440, -0.903005602604091680, -0.903027082913921970, +-0.903048560966184800, -0.903070036760825980, -0.903091510297792000, -0.903112981577029240, -0.903134450598484070, -0.903155917362102770, -0.903177381867831700, -0.903198844115617130, +-0.903220304105405440, -0.903241761837143000, -0.903263217310776190, -0.903284670526251610, -0.903306121483515080, -0.903327570182513200, -0.903349016623192450, -0.903370460805499540, +-0.903391902729379970, -0.903413342394780770, -0.903434779801648210, -0.903456214949928670, -0.903477647839568520, -0.903499078470514360, -0.903520506842712460, -0.903541932956109290, +-0.903563356810651360, -0.903584778406284930, -0.903606197742956590, -0.903627614820613160, -0.903649029639200350, -0.903670442198664880, -0.903691852498953780, -0.903713260540012550, +-0.903734666321788230, -0.903756069844227290, -0.903777471107276130, -0.903798870110881340, -0.903820266854989280, -0.903841661339546580, -0.903863053564499810, -0.903884443529795360, +-0.903905831235379710, -0.903927216681199570, -0.903948599867201770, -0.903969980793332130, -0.903991359459537460, -0.904012735865764470, -0.904034110011959880, -0.904055481898069720, +-0.904076851524040940, -0.904098218889819890, -0.904119583995353420, -0.904140946840587880, -0.904162307425470100, -0.904183665749946460, -0.904205021813963670, -0.904226375617468330, +-0.904247727160407020, -0.904269076442726800, -0.904290423464373490, -0.904311768225294130, -0.904333110725435430, -0.904354450964744210, -0.904375788943166500, -0.904397124660649370, +-0.904418458117139500, -0.904439789312583400, -0.904461118246927760, -0.904482444920119420, -0.904503769332104970, -0.904525091482831000, -0.904546411372244450, -0.904567729000291700, +-0.904589044366920110, -0.904610357472075520, -0.904631668315705070, -0.904652976897755370, -0.904674283218173670, -0.904695587276905910, -0.904716889073899130, -0.904738188609100160, +-0.904759485882455690, -0.904780780893912450, -0.904802073643417360, -0.904823364130917020, -0.904844652356358360, -0.904865938319687980, -0.904887222020852810, -0.904908503459799560, +-0.904929782636475390, -0.904951059550826440, -0.904972334202799770, -0.904993606592342740, -0.905014876719401280, -0.905036144583922560, -0.905057410185853620, -0.905078673525141040, +-0.905099934601731770, -0.905121193415572730, -0.905142449966610640, -0.905163704254792530, -0.905184956280065120, -0.905206206042375230, -0.905227453541669890, -0.905248698777896380, +-0.905269941751000620, -0.905291182460929990, -0.905312420907631530, -0.905333657091052290, -0.905354891011138640, -0.905376122667837620, -0.905397352061096390, -0.905418579190861770, +-0.905439804057080690, -0.905461026659700070, -0.905482246998666970, -0.905503465073928200, -0.905524680885430700, -0.905545894433121610, -0.905567105716948100, -0.905588314736856410, +-0.905609521492794060, -0.905630725984707840, -0.905651928212545140, -0.905673128176252230, -0.905694325875776580, -0.905715521311065140, -0.905736714482064830, -0.905757905388722690, +-0.905779094030985890, -0.905800280408801230, -0.905821464522115980, -0.905842646370877080, -0.905863825955031450, -0.905885003274526810, -0.905906178329309090, -0.905927351119326100, +-0.905948521644524550, -0.905969689904852160, -0.905990855900255190, -0.906012019630681120, -0.906033181096076890, -0.906054340296389870, -0.906075497231566880, -0.906096651901555190, +-0.906117804306301840, -0.906138954445753990, -0.906160102319858660, -0.906181247928563250, -0.906202391271814570, -0.906223532349560320, -0.906244671161746900, -0.906265807708321880, +-0.906286941989232650, -0.906308074004425590, -0.906329203753848510, -0.906350331237448350, -0.906371456455172360, -0.906392579406967710, -0.906413700092781550, -0.906434818512561250, +-0.906455934666253850, -0.906477048553806620, -0.906498160175166820, -0.906519269530281610, -0.906540376619098590, -0.906561481441564230, -0.906582583997626150, -0.906603684287231700, +-0.906624782310328280, -0.906645878066862590, -0.906666971556782220, -0.906688062780034440, -0.906709151736566520, -0.906730238426325720, -0.906751322849259190, -0.906772405005314530, +-0.906793484894438780, -0.906814562516579330, -0.906835637871683420, -0.906856710959698780, -0.906877781780572100, -0.906898850334250880, -0.906919916620682610, -0.906940980639814880, +-0.906962042391594280, -0.906983101875968640, -0.907004159092885230, -0.907025214042291420, -0.907046266724134460, -0.907067317138361970, -0.907088365284921210, -0.907109411163759430, +-0.907130454774824240, -0.907151496118062780, -0.907172535193423110, -0.907193572000851600, -0.907214606540296180, -0.907235638811704330, -0.907256668815023650, -0.907277696550200960, +-0.907298722017184090, -0.907319745215920290, -0.907340766146357280, -0.907361784808442320, -0.907382801202122780, -0.907403815327346370, -0.907424827184060370, -0.907445836772212240, +-0.907466844091749600, -0.907487849142619820, -0.907508851924770820, -0.907529852438149320, -0.907550850682703140, -0.907571846658380200, -0.907592840365127330, -0.907613831802892350, +-0.907634820971622740, -0.907655807871266100, -0.907676792501770020, -0.907697774863081900, -0.907718754955149310, -0.907739732777919860, -0.907760708331341040, -0.907781681615360550, +-0.907802652629925770, -0.907823621374984730, -0.907844587850484270, -0.907865552056372320, -0.907886513992596570, -0.907907473659104850, -0.907928431055844090, -0.907949386182762330, +-0.907970339039806950, -0.907991289626925880, -0.908012237944066490, -0.908033183991176500, -0.908054127768203600, -0.908075069275095290, -0.908096008511799390, -0.908116945478263490, +-0.908137880174435530, -0.908158812600262540, -0.908179742755692470, -0.908200670640673110, -0.908221596255152420, -0.908242519599077420, -0.908263440672396060, -0.908284359475056040, +-0.908305276007005170, -0.908326190268191170, -0.908347102258561630, -0.908368011978064380, -0.908388919426647120, -0.908409824604257450, -0.908430727510843310, -0.908451628146352720, +-0.908472526510732630, -0.908493422603931290, -0.908514316425896420, -0.908535207976576050, -0.908556097255917350, -0.908576984263868350, -0.908597869000376870, -0.908618751465390840, +-0.908639631658857860, -0.908660509580725750, -0.908681385230942440, -0.908702258609455640, -0.908723129716213160, -0.908743998551162950, -0.908764865114252700, -0.908785729405430560, +-0.908806591424643820, -0.908827451171840610, -0.908848308646969080, -0.908869163849976510, -0.908890016780810940, -0.908910867439420400, -0.908931715825752610, -0.908952561939755600, +-0.908973405781377200, -0.908994247350565220, -0.909015086647267600, -0.909035923671432380, -0.909056758423007260, -0.909077590901940290, -0.909098421108179620, -0.909119249041672630, +-0.909140074702367570, -0.909160898090212170, -0.909181719205155000, -0.909202538047143130, -0.909223354616124910, -0.909244168912048290, -0.909264980934861300, -0.909285790684511760, +-0.909306598160947830, -0.909327403364117440, -0.909348206293968400, -0.909369006950448980, -0.909389805333507330, -0.909410601443090830, -0.909431395279147850, -0.909452186841626430, +-0.909472976130474400, -0.909493763145640010, -0.909514547887071530, -0.909535330354716450, -0.909556110548522920, -0.909576888468439090, -0.909597664114413120, -0.909618437486393040, +-0.909639208584326790, -0.909659977408162510, -0.909680743957848260, -0.909701508233332510, -0.909722270234562760, -0.909743029961487260, -0.909763787414054060, -0.909784542592211530, +-0.909805295495907610, -0.909826046125090880, -0.909846794479708620, -0.909867540559709310, -0.909888284365041210, -0.909909025895652370, -0.909929765151491040, -0.909950502132505280, +-0.909971236838643230, -0.909991969269853040, -0.910012699426082980, -0.910033427307281540, -0.910054152913396200, -0.910074876244375440, -0.910095597300167420, -0.910116316080720520, +-0.910137032585983220, -0.910157746815902890, -0.910178458770428130, -0.910199168449507320, -0.910219875853088610, -0.910240580981120150, -0.910261283833550320, -0.910281984410327150, +-0.910302682711399140, -0.910323378736714320, -0.910344072486221510, -0.910364763959868100, -0.910385453157602890, -0.910406140079373930, -0.910426824725129590, -0.910447507094818250, +-0.910468187188388510, -0.910488865005787960, -0.910509540546965200, -0.910530213811868610, -0.910550884800446550, -0.910571553512647180, -0.910592219948418990, -0.910612884107710130, +-0.910633545990469200, -0.910654205596644670, -0.910674862926184380, -0.910695517979036810, -0.910716170755150540, -0.910736821254473750, -0.910757469476955020, -0.910778115422542940, +-0.910798759091185130, -0.910819400482830500, -0.910840039597427430, -0.910860676434924190, -0.910881310995269140, -0.910901943278411010, -0.910922573284297930, -0.910943201012878400, +-0.910963826464101230, -0.910984449637914250, -0.911005070534266050, -0.911025689153105110, -0.911046305494380040, -0.911066919558039200, -0.911087531344031420, -0.911108140852304400, +-0.911128748082807080, -0.911149353035487830, -0.911169955710295240, -0.911190556107177810, -0.911211154226084010, -0.911231750066962220, -0.911252343629761040, -0.911272934914429070, +-0.911293523920915120, -0.911314110649167010, -0.911334695099133670, -0.911355277270763490, -0.911375857164005150, -0.911396434778807500, -0.911417010115118440, -0.911437583172886920, +-0.911458153952061310, -0.911478722452590430, -0.911499288674422650, -0.911519852617506680, -0.911540414281791110, -0.911560973667224550, -0.911581530773755480, -0.911602085601332930, +-0.911622638149904850, -0.911643188419420160, -0.911663736409827450, -0.911684282121075440, -0.911704825553112720, -0.911725366705888330, -0.911745905579350200, -0.911766442173447270, +-0.911786976488128120, -0.911807508523341690, -0.911828038279036360, -0.911848565755161040, -0.911869090951664240, -0.911889613868494760, -0.911910134505601540, -0.911930652862932730, +-0.911951168940437150, -0.911971682738063730, -0.911992194255761170, -0.912012703493477960, -0.912033210451163480, -0.912053715128765650, -0.912074217526233410, -0.912094717643515680, +-0.912115215480561180, -0.912135711037318610, -0.912156204313736780, -0.912176695309764420, -0.912197184025350330, -0.912217670460443660, -0.912238154614992360, -0.912258636488945780, +-0.912279116082252540, -0.912299593394861550, -0.912320068426721640, -0.912340541177781850, -0.912361011647990330, -0.912381479837296340, -0.912401945745648590, -0.912422409372996010, +-0.912442870719287420, -0.912463329784471530, -0.912483786568497490, -0.912504241071313890, -0.912524693292869670, -0.912545143233114200, -0.912565590891995400, -0.912586036269462660, +-0.912606479365464800, -0.912626920179950730, -0.912647358712869840, -0.912667794964170050, -0.912688228933800860, -0.912708660621711080, -0.912729090027849630, -0.912749517152165460, +-0.912769941994607480, -0.912790364555124630, -0.912810784833665960, -0.912831202830180270, -0.912851618544616940, -0.912872031976924240, -0.912892443127051310, -0.912912851994947430, +-0.912933258580561400, -0.912953662883842500, -0.912974064904739200, -0.912994464643200660, -0.913014862099176040, -0.913035257272614140, -0.913055650163464130, -0.913076040771675030, +-0.913096429097195910, -0.913116815139975560, -0.913137198899963250, -0.913157580377108370, -0.913177959571359050, -0.913198336482664910, -0.913218711110974860, -0.913239083456238170, +-0.913259453518403650, -0.913279821297420910, -0.913300186793238210, -0.913320550005805030, -0.913340910935070530, -0.913361269580983740, -0.913381625943493810, -0.913401980022549800, +-0.913422331818100840, -0.913442681330095980, -0.913463028558484820, -0.913483373503215730, -0.913503716164238200, -0.913524056541501480, -0.913544394634954520, -0.913564730444546560, +-0.913585063970227210, -0.913605395211944730, -0.913625724169648820, -0.913646050843288650, -0.913666375232813240, -0.913686697338171980, -0.913707017159314020, -0.913727334696188390, +-0.913747649948744580, -0.913767962916931850, -0.913788273600698920, -0.913808581999995370, -0.913828888114770250, -0.913849191944972940, -0.913869493490552690, -0.913889792751459100, +-0.913910089727640540, -0.913930384419046840, -0.913950676825627250, -0.913970966947330820, -0.913991254784107030, -0.914011540335905150, -0.914031823602674430, -0.914052104584364030, +-0.914072383280923550, -0.914092659692302360, -0.914112933818449160, -0.914133205659313660, -0.914153475214845020, -0.914173742484992840, -0.914194007469706580, -0.914214270168935080, +-0.914234530582627710, -0.914254788710734180, -0.914275044553203630, -0.914295298109985440, -0.914315549381028990, -0.914335798366283650, -0.914356045065698900, -0.914376289479224000, +-0.914396531606808670, -0.914416771448401720, -0.914437009003952860, -0.914457244273411460, -0.914477477256727010, -0.914497707953848770, -0.914517936364726670, -0.914538162489309300, +-0.914558386327546600, -0.914578607879387940, -0.914598827144782690, -0.914619044123680450, -0.914639258816030480, -0.914659471221782480, -0.914679681340885730, -0.914699889173290260, +-0.914720094718944550, -0.914740297977798660, -0.914760498949802050, -0.914780697634904220, -0.914800894033054650, -0.914821088144203150, -0.914841279968298560, -0.914861469505290790, +-0.914881656755129340, -0.914901841717763790, -0.914922024393143630, -0.914942204781218350, -0.914962382881937650, -0.914982558695250910, -0.915002732221108170, -0.915022903459458250, +-0.915043072410251070, -0.915063239073436120, -0.915083403448963220, -0.915103565536781740, -0.915123725336841720, -0.915143882849091980, -0.915164038073482570, -0.915184191009963070, +-0.915204341658483080, -0.915224490018992200, -0.915244636091440130, -0.915264779875776480, -0.915284921371950940, -0.915305060579913010, -0.915325197499612830, -0.915345332130999220, +-0.915365464474022340, -0.915385594528631770, -0.915405722294777350, -0.915425847772408870, -0.915445970961475400, -0.915466091861926960, -0.915486210473713370, -0.915506326796784230, +-0.915526440831089360, -0.915546552576578240, -0.915566662033200810, -0.915586769200906760, -0.915606874079645690, -0.915626976669367880, -0.915647076970022230, -0.915667174981558920, +-0.915687270703927750, -0.915707364137078210, -0.915727455280960450, -0.915747544135524280, -0.915767630700718980, -0.915787714976494470, -0.915807796962800790, -0.915827876659587650, +-0.915847954066804750, -0.915868029184401910, -0.915888102012329060, -0.915908172550535920, -0.915928240798972840, -0.915948306757588650, -0.915968370426333720, -0.915988431805157880, +-0.916008490894011040, -0.916028547692842920, -0.916048602201603780, -0.916068654420242770, -0.916088704348710040, -0.916108751986955740, -0.916128797334929360, -0.916148840392581150, +-0.916168881159860730, -0.916188919636718110, -0.916208955823103240, -0.916228989718966380, -0.916249021324256670, -0.916269050638924390, -0.916289077662919450, -0.916309102396191790, +-0.916329124838691440, -0.916349144990368570, -0.916369162851172540, -0.916389178421053610, -0.916409191699961710, -0.916429202687846890, -0.916449211384658960, -0.916469217790348070, +-0.916489221904864150, -0.916509223728157130, -0.916529223260177050, -0.916549220500874280, -0.916569215450198090, -0.916589208108098850, -0.916609198474526710, -0.916629186549431480, +-0.916649172332763660, -0.916669155824472500, -0.916689137024508490, -0.916709115932821560, -0.916729092549361970, -0.916749066874079640, -0.916769038906924520, -0.916789008647846960, +-0.916808976096796790, -0.916828941253724160, -0.916848904118579560, -0.916868864691312350, -0.916888822971873020, -0.916908778960211500, -0.916928732656278170, -0.916948684060022940, +-0.916968633171396430, -0.916988579990347890, -0.917008524516827910, -0.917028466750786640, -0.917048406692174240, -0.917068344340940870, -0.917088279697036550, -0.917108212760411550, +-0.917128143531016020, -0.917148072008800440, -0.917167998193714420, -0.917187922085708320, -0.917207843684732400, -0.917227762990736940, -0.917247680003672070, -0.917267594723488290, +-0.917287507150135300, -0.917307417283563460, -0.917327325123723060, -0.917347230670564340, -0.917367133924037570, -0.917387034884093010, -0.917406933550680810, -0.917426829923751240, +-0.917446724003255000, -0.917466615789141570, -0.917486505281361660, -0.917506392479865430, -0.917526277384603240, -0.917546159995525360, -0.917566040312582490, -0.917585918335724000, +-0.917605794064900840, -0.917625667500063250, -0.917645538641161380, -0.917665407488145730, -0.917685274040966450, -0.917705138299574120, -0.917725000263918900, -0.917744859933951160, +-0.917764717309621610, -0.917784572390879960, -0.917804425177676910, -0.917824275669962720, -0.917844123867687880, -0.917863969770803090, -0.917883813379257950, -0.917903654693003390, +-0.917923493711989560, -0.917943330436167160, -0.917963164865486240, -0.917982996999897600, -0.918002826839351300, -0.918022654383798040, -0.918042479633188190, -0.918062302587472350, +-0.918082123246600550, -0.918101941610523280, -0.918121757679191350, -0.918141571452554820, -0.918161382930564480, -0.918181192113171060, -0.918200999000324260, -0.918220803591975000, +-0.918240605888073660, -0.918260405888570830, -0.918280203593417000, -0.918299999002562650, -0.918319792115958380, -0.918339582933554550, -0.918359371455302110, -0.918379157681150970, +-0.918398941611051840, -0.918418723244955440, -0.918438502582812120, -0.918458279624572600, -0.918478054370187810, -0.918497826819607450, -0.918517596972782570, -0.918537364829663640, +-0.918557130390201370, -0.918576893654346140, -0.918596654622048760, -0.918616413293259830, -0.918636169667929710, -0.918655923746009680, -0.918675675527449330, -0.918695425012199920, +-0.918715172200211930, -0.918734917091435950, -0.918754659685822710, -0.918774399983323110, -0.918794137983887320, -0.918813873687466030, -0.918833607094010070, -0.918853338203470150, +-0.918873067015796850, -0.918892793530940890, -0.918912517748852960, -0.918932239669483790, -0.918951959292783950, -0.918971676618704600, -0.918991391647195680, -0.919011104378208210, +-0.919030814811693130, -0.919050522947600920, -0.919070228785882740, -0.919089932326488720, -0.919109633569369810, -0.919129332514476820, -0.919149029161760440, -0.919168723511171630, +-0.919188415562660950, -0.919208105316179140, -0.919227792771677210, -0.919247477929105660, -0.919267160788415860, -0.919286841349557850, -0.919306519612482660, -0.919326195577141130, +-0.919345869243484160, -0.919365540611462580, -0.919385209681027440, -0.919404876452128870, -0.919424540924718260, -0.919444203098746190, -0.919463862974163600, -0.919483520550921420, +-0.919503175828970340, -0.919522828808261420, -0.919542479488745350, -0.919562127870373500, -0.919581773953095930, -0.919601417736863990, -0.919621059221628400, -0.919640698407340310, +-0.919660335293950300, -0.919679969881409990, -0.919699602169669280, -0.919719232158679570, -0.919738859848391770, -0.919758485238756920, -0.919778108329725730, -0.919797729121249350, +-0.919817347613278710, -0.919836963805764520, -0.919856577698658470, -0.919876189291910510, -0.919895798585472100, -0.919915405579294190, -0.919935010273327690, -0.919954612667523760, +-0.919974212761833670, -0.919993810556207660, -0.920013406050597120, -0.920032999244953080, -0.920052590139226470, -0.920072178733368440, -0.920091765027330030, -0.920111349021062170, +-0.920130930714515900, -0.920150510107642260, -0.920170087200392840, -0.920189661992717680, -0.920209234484568480, -0.920228804675896180, -0.920248372566651820, -0.920267938156786980, +-0.920287501446251820, -0.920307062434998050, -0.920326621122976470, -0.920346177510138470, -0.920365731596434870, -0.920385283381817130, -0.920404832866236090, -0.920424380049642890, +-0.920443924931988900, -0.920463467513225280, -0.920483007793302720, -0.920502545772172720, -0.920522081449786310, -0.920541614826094650, -0.920561145901048980, -0.920580674674600810, +-0.920600201146700490, -0.920619725317299850, -0.920639247186349710, -0.920658766753801650, -0.920678284019606500, -0.920697798983715730, -0.920717311646080510, -0.920736822006651860, +-0.920756330065381600, -0.920775835822220220, -0.920795339277119210, -0.920814840430029810, -0.920834339280903300, -0.920853835829691050, -0.920873330076344420, -0.920892822020814240, +-0.920912311663051870, -0.920931799003008810, -0.920951284040636310, -0.920970766775885520, -0.920990247208707810, -0.921009725339054450, -0.921029201166876810, -0.921048674692126590, +-0.921068145914754280, -0.921087614834711580, -0.921107081451949860, -0.921126545766420500, -0.921146007778074650, -0.921165467486864230, -0.921184924892739730, -0.921204379995652970, +-0.921223832795555200, -0.921243283292397910, -0.921262731486132360, -0.921282177376710030, -0.921301620964082300, -0.921321062248200430, -0.921340501229015900, -0.921359937906480520, +-0.921379372280544890, -0.921398804351160950, -0.921418234118279940, -0.921437661581853250, -0.921457086741832800, -0.921476509598169400, -0.921495930150814550, -0.921515348399720050, +-0.921534764344837050, -0.921554177986117160, -0.921573589323511850, -0.921592998356972610, -0.921612405086450810, -0.921631809511898050, -0.921651211633266020, -0.921670611450505660, +-0.921690008963568790, -0.921709404172406880, -0.921728797076971530, -0.921748187677214110, -0.921767575973086560, -0.921786961964539800, -0.921806345651525530, -0.921825727033995460, +-0.921845106111901070, -0.921864482885193960, -0.921883857353825610, -0.921903229517747610, -0.921922599376911460, -0.921941966931269290, -0.921961332180771810, -0.921980695125370950, +-0.922000055765018420, -0.922019414099665700, -0.922038770129264500, -0.922058123853766620, -0.922077475273123230, -0.922096824387286020, -0.922116171196206810, -0.922135515699837200, +-0.922154857898128680, -0.922174197791033160, -0.922193535378502130, -0.922212870660487180, -0.922232203636940470, -0.922251534307812810, -0.922270862673056360, -0.922290188732622810, +-0.922309512486463760, -0.922328833934530910, -0.922348153076776310, -0.922367469913150990, -0.922386784443607110, -0.922406096668096140, -0.922425406586569910, -0.922444714198980220, +-0.922464019505278790, -0.922483322505417200, -0.922502623199347390, -0.922521921587021070, -0.922541217668390150, -0.922560511443405900, -0.922579802912020460, -0.922599092074185330, +-0.922618378929852660, -0.922637663478974250, -0.922656945721501360, -0.922676225657386160, -0.922695503286580450, -0.922714778609035840, -0.922734051624704340, -0.922753322333537800, +-0.922772590735487790, -0.922791856830506460, -0.922811120618545420, -0.922830382099556920, -0.922849641273492120, -0.922868898140303150, -0.922888152699942070, -0.922907404952360570, +-0.922926654897510470, -0.922945902535344140, -0.922965147865812740, -0.922984390888868410, -0.923003631604463080, -0.923022870012548790, -0.923042106113077240, -0.923061339906000480, +-0.923080571391270310, -0.923099800568838780, -0.923119027438658040, -0.923138252000679340, -0.923157474254855060, -0.923176694201137130, -0.923195911839477470, -0.923215127169828010, +-0.923234340192141010, -0.923253550906367850, -0.923272759312460890, -0.923291965410371950, -0.923311169200053180, -0.923330370681456400, -0.923349569854533760, -0.923368766719237070, +-0.923387961275518590, -0.923407153523330470, -0.923426343462624200, -0.923445531093352030, -0.923464716415466010, -0.923483899428918290, -0.923503080133660780, -0.923522258529645870, +-0.923541434616825030, -0.923560608395150530, -0.923579779864574620, -0.923598949025049130, -0.923618115876526310, -0.923637280418958320, -0.923656442652296960, -0.923675602576494610, +-0.923694760191503210, -0.923713915497275220, -0.923733068493762130, -0.923752219180916430, -0.923771367558690050, -0.923790513627035350, -0.923809657385904700, -0.923828798835249490, +-0.923847937975022400, -0.923867074805175380, -0.923886209325660680, -0.923905341536430560, -0.923924471437436940, -0.923943599028632210, -0.923962724309968510, -0.923981847281397980, +-0.924000967942873120, -0.924020086294345510, -0.924039202335767750, -0.924058316067091990, -0.924077427488270380, -0.924096536599255500, -0.924115643399999080, -0.924134747890453470, +-0.924153850070570940, -0.924172949940303860, -0.924192047499604370, -0.924211142748424860, -0.924230235686717360, -0.924249326314434350, -0.924268414631527980, -0.924287500637950950, +-0.924306584333654760, -0.924325665718592200, -0.924344744792715440, -0.924363821555976850, -0.924382896008328570, -0.924401968149723530, -0.924421037980113210, -0.924440105499450330, +-0.924459170707687020, -0.924478233604775990, -0.924497294190669280, -0.924516352465319270, -0.924535408428678540, -0.924554462080699140, -0.924573513421333980, -0.924592562450534670, +-0.924611609168254020, -0.924630653574444290, -0.924649695669057970, -0.924668735452047420, -0.924687772923365350, -0.924706808082963460, -0.924725840930794570, -0.924744871466811170, +-0.924763899690965510, -0.924782925603210070, -0.924801949203497340, -0.924820970491779800, -0.924839989468009720, -0.924859006132139780, -0.924878020484122600, -0.924897032523910090, +-0.924916042251454960, -0.924935049666709700, -0.924954054769626890, -0.924973057560159240, -0.924992058038258570, -0.925011056203877800, -0.925030052056969310, -0.925049045597485800, +-0.925068036825379640, -0.925087025740603420, -0.925106012343109520, -0.925124996632850750, -0.925143978609779370, -0.925162958273848420, -0.925181935625009720, -0.925200910663216190, +-0.925219883388420430, -0.925238853800574910, -0.925257821899632570, -0.925276787685545440, -0.925295751158266230, -0.925314712317747650, -0.925333671163942380, -0.925352627696802930, +-0.925371581916281770, -0.925390533822331830, -0.925409483414905480, -0.925428430693955310, -0.925447375659434580, -0.925466318311295000, -0.925485258649489610, -0.925504196673971100, +-0.925523132384692080, -0.925542065781605250, -0.925560996864663530, -0.925579925633819080, -0.925598852089024700, -0.925617776230233340, -0.925636698057397460, -0.925655617570469770, +-0.925674534769403090, -0.925693449654150120, -0.925712362224663470, -0.925731272480896260, -0.925750180422800550, -0.925769086050329370, -0.925787989363435540, -0.925806890362071640, +-0.925825789046190620, -0.925844685415745380, -0.925863579470688090, -0.925882471210971890, -0.925901360636549490, -0.925920247747373690, -0.925939132543397330, -0.925958015024573090, +-0.925976895190853800, -0.925995773042192270, -0.926014648578541650, -0.926033521799854100, -0.926052392706082750, -0.926071261297180430, -0.926090127573099830, -0.926108991533794110, +-0.926127853179216090, -0.926146712509318130, -0.926165569524053380, -0.926184424223374770, -0.926203276607235120, -0.926222126675587230, -0.926240974428383930, -0.926259819865578370, +-0.926278662987123140, -0.926297503792971270, -0.926316342283076020, -0.926335178457389550, -0.926354012315865120, -0.926372843858455750, -0.926391673085114160, -0.926410499995793830, +-0.926429324590446800, -0.926448146869026550, -0.926466966831485880, -0.926485784477777740, -0.926504599807855270, -0.926523412821671170, -0.926542223519178700, -0.926561031900330570, +-0.926579837965079810, -0.926598641713379800, -0.926617443145182910, -0.926636242260442500, -0.926655039059111290, -0.926673833541142630, -0.926692625706489360, -0.926711415555104830, +-0.926730203086941430, -0.926748988301952510, -0.926767771200091130, -0.926786551781310310, -0.926805330045563200, -0.926824105992802630, -0.926842879622981840, -0.926861650936053880, +-0.926880419931972120, -0.926899186610689040, -0.926917950972157900, -0.926936713016331960, -0.926955472743164140, -0.926974230152607710, -0.926992985244616040, -0.927011738019141500, +-0.927030488476137670, -0.927049236615557600, -0.927067982437354440, -0.927086725941481340, -0.927105467127891440, -0.927124205996537890, -0.927142942547373840, -0.927161676780352660, +-0.927180408695427060, -0.927199138292550410, -0.927217865571675850, -0.927236590532756640, -0.927255313175746050, -0.927274033500597450, -0.927292751507263420, -0.927311467195697570, +-0.927330180565852920, -0.927348891617682970, -0.927367600351140740, -0.927386306766179500, -0.927405010862752510, -0.927423712640812910, -0.927442412100314080, -0.927461109241209610, +-0.927479804063451980, -0.927498496566994790, -0.927517186751791510, -0.927535874617795190, -0.927554560164959520, -0.927573243393236990, -0.927591924302581530, -0.927610602892946170, +-0.927629279164284280, -0.927647953116549240, -0.927666624749694300, -0.927685294063672840, -0.927703961058438110, -0.927722625733943480, -0.927741288090142670, -0.927759948126988250, +-0.927778605844433950, -0.927797261242433220, -0.927815914320939240, -0.927834565079905470, -0.927853213519285740, -0.927871859639032510, -0.927890503439099730, -0.927909144919440650, +-0.927927784080008640, -0.927946420920757300, -0.927965055441639870, -0.927983687642609740, -0.928002317523620390, -0.928020945084625630, -0.928039570325578160, -0.928058193246431800, +-0.928076813847139910, -0.928095432127655990, -0.928114048087933520, -0.928132661727926300, -0.928151273047587040, -0.928169882046869570, -0.928188488725727460, -0.928207093084113980, +-0.928225695121982940, -0.928244294839287610, -0.928262892235981460, -0.928281487312018210, -0.928300080067351540, -0.928318670501934280, -0.928337258615720360, -0.928355844408663370, +-0.928374427880716670, -0.928393009031833970, -0.928411587861969090, -0.928430164371074840, -0.928448738559105150, -0.928467310426013710, -0.928485879971754020, -0.928504447196279560, +-0.928523012099544020, -0.928541574681500890, -0.928560134942103880, -0.928578692881306460, -0.928597248499062670, -0.928615801795325440, -0.928634352770048800, -0.928652901423186130, +-0.928671447754691240, -0.928689991764518160, -0.928708533452619720, -0.928727072818949950, -0.928745609863462440, -0.928764144586110900, -0.928782676986849020, -0.928801207065630520, +-0.928819734822408980, -0.928838260257138000, -0.928856783369771510, -0.928875304160263320, -0.928893822628566570, -0.928912338774635190, -0.928930852598423010, -0.928949364099883710, +-0.928967873278971010, -0.928986380135638940, -0.929004884669840660, -0.929023386881530080, -0.929041886770661020, -0.929060384337187290, -0.929078879581062610, -0.929097372502240670, +-0.929115863100675400, -0.929134351376320390, -0.929152837329129790, -0.929171320959056860, -0.929189802266055630, -0.929208281250079820, -0.929226757911083330, -0.929245232249020000, +-0.929263704263843860, -0.929282173955508160, -0.929300641323967060, -0.929319106369174360, -0.929337569091083780, -0.929356029489649350, -0.929374487564824880, -0.929392943316564190, +-0.929411396744821090, -0.929429847849549850, -0.929448296630703720, -0.929466743088236740, -0.929485187222102940, -0.929503629032256140, -0.929522068518650380, -0.929540505681239690, +-0.929558940519977450, -0.929577373034817800, -0.929595803225714780, -0.929614231092622200, -0.929632656635494100, -0.929651079854284300, -0.929669500748946830, -0.929687919319435620, +-0.929706335565704590, -0.929724749487708110, -0.929743161085399340, -0.929761570358732750, -0.929779977307662150, -0.929798381932141700, -0.929816784232125550, -0.929835184207567170, +-0.929853581858420820, -0.929871977184640430, -0.929890370186180150, -0.929908760862994010, -0.929927149215035830, -0.929945535242259870, -0.929963918944620050, -0.929982300322070520, +-0.930000679374565430, -0.930019056102058370, -0.930037430504503710, -0.930055802581855500, -0.930074172334067640, -0.930092539761094520, -0.930110904862890280, -0.930129267639408400, +-0.930147628090603470, -0.930165986216429430, -0.930184342016840420, -0.930202695491790470, -0.930221046641233950, -0.930239395465124690, -0.930257741963416930, -0.930276086136065160, +-0.930294427983022980, -0.930312767504244520, -0.930331104699684270, -0.930349439569296280, -0.930367772113034670, -0.930386102330853950, -0.930404430222707580, -0.930422755788550160, +-0.930441079028335950, -0.930459399942018980, -0.930477718529553410, -0.930496034790893710, -0.930514348725993810, -0.930532660334808080, -0.930550969617291000, -0.930569276573396280, +-0.930587581203078270, -0.930605883506291250, -0.930624183482989590, -0.930642481133127530, -0.930660776456659570, -0.930679069453539290, -0.930697360123721280, -0.930715648467160040, +-0.930733934483809590, -0.930752218173624300, -0.930770499536558440, -0.930788778572566370, -0.930807055281602350, -0.930825329663620640, -0.930843601718575940, -0.930861871446421960, +-0.930880138847113290, -0.930898403920604300, -0.930916666666849250, -0.930934927085802940, -0.930953185177418870, -0.930971440941651960, -0.930989694378456360, -0.931007945487786540, +-0.931026194269596870, -0.931044440723841740, -0.931062684850475500, -0.931080926649452520, -0.931099166120727180, -0.931117403264254300, -0.931135638079987670, -0.931153870567881790, +-0.931172100727891360, -0.931190328559970640, -0.931208554064074100, -0.931226777240156460, -0.931244998088171520, -0.931263216608074210, -0.931281432799818790, -0.931299646663359740, +-0.931317858198651650, -0.931336067405648890, -0.931354274284305950, -0.931372478834577410, -0.931390681056417870, -0.931408880949781360, -0.931427078514622700, -0.931445273750896250, +-0.931463466658556620, -0.931481657237558380, -0.931499845487856360, -0.931518031409404370, -0.931536215002157220, -0.931554396266069620, -0.931572575201095930, -0.931590751807190980, +-0.931608926084309010, -0.931627098032404730, -0.931645267651432740, -0.931663434941347960, -0.931681599902104200, -0.931699762533656380, -0.931717922835959220, -0.931736080808967300, +-0.931754236452635110, -0.931772389766917670, -0.931790540751768930, -0.931808689407143900, -0.931826835732997070, -0.931844979729283150, -0.931863121395956840, -0.931881260732972730, +-0.931899397740285410, -0.931917532417849580, -0.931935664765620060, -0.931953794783551560, -0.931971922471598320, -0.931990047829715170, -0.932008170857857030, -0.932026291555978380, +-0.932044409924034370, -0.932062525961979030, -0.932080639669767290, -0.932098751047354070, -0.932116860094693860, -0.932134966811741570, -0.932153071198451810, -0.932171173254779490, +-0.932189272980679110, -0.932207370376105570, -0.932225465441013920, -0.932243558175358310, -0.932261648579093880, -0.932279736652175230, -0.932297822394557270, -0.932315905806194720, +-0.932333986887042830, -0.932352065637055530, -0.932370142056188070, -0.932388216144395380, -0.932406287901632050, -0.932424357327853000, -0.932442424423013060, -0.932460489187067140, +-0.932478551619969950, -0.932496611721676640, -0.932514669492141570, -0.932532724931319780, -0.932550778039166190, -0.932568828815635630, -0.932586877260683010, -0.932604923374263480, +-0.932622967156331420, -0.932641008606841850, -0.932659047725749810, -0.932677084513010120, -0.932695118968577710, -0.932713151092407600, -0.932731180884454500, -0.932749208344673560, +-0.932767233473019820, -0.932785256269447640, -0.932803276733912390, -0.932821294866369000, -0.932839310666772280, -0.932857324135077380, -0.932875335271239450, -0.932893344075212850, +-0.932911350546952840, -0.932929354686414470, -0.932947356493552760, -0.932965355968322640, -0.932983353110679150, -0.933001347920577320, -0.933019340397972070, -0.933037330542818450, +-0.933055318355071830, -0.933073303834686560, -0.933091286981618140, -0.933109267795821370, -0.933127246277251520, -0.933145222425863840, -0.933163196241612810, -0.933181167724453810, +-0.933199136874341860, -0.933217103691232010, -0.933235068175079510, -0.933253030325839280, -0.933270990143466480, -0.933288947627916140, -0.933306902779143520, -0.933324855597103990, +-0.933342806081751910, -0.933360754233042880, -0.933378700050931930, -0.933396643535374220, -0.933414584686324990, -0.933432523503739510, -0.933450459987572480, -0.933468394137779270, +-0.933486325954315020, -0.933504255437135000, -0.933522182586194350, -0.933540107401448220, -0.933558029882851860, -0.933575950030360420, -0.933593867843929390, -0.933611783323513470, +-0.933629696469068020, -0.933647607280548300, -0.933665515757909570, -0.933683421901107090, -0.933701325710096340, -0.933719227184832020, -0.933737126325269510, -0.933755023131364270, +-0.933772917603071460, -0.933790809740346450, -0.933808699543144270, -0.933826587011420410, -0.933844472145130110, -0.933862354944228870, -0.933880235408671490, -0.933898113538413450, +-0.933915989333410130, -0.933933862793616900, -0.933951733918989000, -0.933969602709482150, -0.933987469165050820, -0.934005333285650940, -0.934023195071237660, -0.934041054521766450, +-0.934058911637192570, -0.934076766417471390, -0.934094618862558290, -0.934112468972408740, -0.934130316746977880, -0.934148162186221650, -0.934166005290094640, -0.934183846058552650, +-0.934201684491551050, -0.934219520589045230, -0.934237354350990980, -0.934255185777342900, -0.934273014868056920, -0.934290841623088510, -0.934308666042392820, -0.934326488125925560, +-0.934344307873642090, -0.934362125285497780, -0.934379940361448220, -0.934397753101448790, -0.934415563505455290, -0.934433371573422540, -0.934451177305306470, -0.934468980701062320, +-0.934486781760645810, -0.934504580484012300, -0.934522376871117610, -0.934540170921916770, -0.934557962636365480, -0.934575752014419230, -0.934593539056033600, -0.934611323761164180, +-0.934629106129766460, -0.934646886161795920, -0.934664663857208140, -0.934682439215959060, -0.934700212238003590, -0.934717982923297550, -0.934735751271796640, -0.934753517283456240, +-0.934771280958232030, -0.934789042296080060, -0.934806801296955040, -0.934824557960813100, -0.934842312287609720, -0.934860064277300620, -0.934877813929841370, -0.934895561245187470, +-0.934913306223294830, -0.934931048864118820, -0.934948789167615480, -0.934966527133739840, -0.934984262762447950, -0.935001996053695380, -0.935019727007437850, -0.935037455623630940, +-0.935055181902230800, -0.935072905843192360, -0.935090627446471530, -0.935108346712024250, -0.935126063639806100, -0.935143778229772790, -0.935161490481880020, -0.935179200396083490, +-0.935196907972339010, -0.935214613210602290, -0.935232316110829240, -0.935250016672975250, -0.935267714896996120, -0.935285410782847660, -0.935303104330485690, -0.935320795539866360, +-0.935338484410944690, -0.935356170943676730, -0.935373855138018410, -0.935391536993925520, -0.935409216511353670, -0.935426893690258780, -0.935444568530596770, -0.935462241032323230, +-0.935479911195394090, -0.935497579019765600, -0.935515244505392700, -0.935532907652231850, -0.935550568460238540, -0.935568226929368920, -0.935585883059579130, -0.935603536850824200, +-0.935621188303060400, -0.935638837416243760, -0.935656484190329870, -0.935674128625274880, -0.935691770721034600, -0.935709410477564840, -0.935727047894821530, -0.935744682972760590, +-0.935762315711338280, -0.935779946110509850, -0.935797574170231570, -0.935815199890459470, -0.935832823271149250, -0.935850444312256950, -0.935868063013738930, -0.935885679375550340, +-0.935903293397647660, -0.935920905079986710, -0.935938514422523400, -0.935956121425214000, -0.935973726088014100, -0.935991328410880060, -0.936008928393767590, -0.936026526036633170, +-0.936044121339432040, -0.936061714302120600, -0.936079304924654960, -0.936096893206991080, -0.936114479149084850, -0.936132062750892890, -0.936149644012370330, -0.936167222933473650, +-0.936184799514159010, -0.936202373754382310, -0.936219945654099720, -0.936237515213267260, -0.936255082431840970, -0.936272647309777000, -0.936290209847031710, -0.936307770043560580, +-0.936325327899320100, -0.936342883414266190, -0.936360436588355110, -0.936377987421542990, -0.936395535913786210, -0.936413082065040260, -0.936430625875261490, -0.936448167344406280, +-0.936465706472430660, -0.936483243259290780, -0.936500777704942670, -0.936518309809342700, -0.936535839572447020, -0.936553366994211660, -0.936570892074593210, -0.936588414813547270, +-0.936605935211030190, -0.936623453266998360, -0.936640968981407810, -0.936658482354215230, -0.936675993385376100, -0.936693502074847030, -0.936711008422584150, -0.936728512428543820, +-0.936746014092682100, -0.936763513414955450, -0.936781010395319910, -0.936798505033731970, -0.936815997330147640, -0.936833487284523760, -0.936850974896815790, -0.936868460166980330, +-0.936885943094973750, -0.936903423680752300, -0.936920901924272350, -0.936938377825490500, -0.936955851384362330, -0.936973322600844430, -0.936990791474893390, -0.937008258006465260, +-0.937025722195516500, -0.937043184042003490, -0.937060643545882480, -0.937078100707109840, -0.937095555525642390, -0.937113008001435600, -0.937130458134446290, -0.937147905924630930, +-0.937165351371945790, -0.937182794476347230, -0.937200235237791950, -0.937217673656235870, -0.937235109731635490, -0.937252543463947490, -0.937269974853128020, -0.937287403899133560, +-0.937304830601920710, -0.937322254961445720, -0.937339676977665180, -0.937357096650535680, -0.937374513980013150, -0.937391928966054390, -0.937409341608615660, -0.937426751907653680, +-0.937444159863124790, -0.937461565474985830, -0.937478968743192700, -0.937496369667702110, -0.937513768248470550, -0.937531164485454590, -0.937548558378610730, -0.937565949927895440, +-0.937583339133265300, -0.937600725994676810, -0.937618110512086540, -0.937635492685451320, -0.937652872514727060, -0.937670249999870480, -0.937687625140838370, -0.937704997937587210, +-0.937722368390073950, -0.937739736498254260, -0.937757102262085420, -0.937774465681523670, -0.937791826756525840, -0.937809185487048500, -0.937826541873048150, -0.937843895914481360, +-0.937861247611304850, -0.937878596963475310, -0.937895943970949550, -0.937913288633683620, -0.937930630951634430, -0.937947970924758680, -0.937965308553013080, -0.937982643836354100, +-0.937999976774738900, -0.938017307368123390, -0.938034635616464720, -0.938051961519719370, -0.938069285077844040, -0.938086606290795650, -0.938103925158530690, -0.938121241681005860, +-0.938138555858177960, -0.938155867690004030, -0.938173177176440110, -0.938190484317443230, -0.938207789112970090, -0.938225091562977510, -0.938242391667422290, -0.938259689426261260, +-0.938276984839450770, -0.938294277906947860, -0.938311568628709130, -0.938328857004691600, -0.938346143034851870, -0.938363426719146850, -0.938380708057533150, -0.938397987049967800, +-0.938415263696407710, -0.938432537996809150, -0.938449809951129250, -0.938467079559324850, -0.938484346821352730, -0.938501611737169840, -0.938518874306733090, -0.938536134529998960, +-0.938553392406924370, -0.938570647937466360, -0.938587901121581750, -0.938605151959227450, -0.938622400450360160, -0.938639646594936930, -0.938656890392914560, -0.938674131844249970, +-0.938691370948900320, -0.938708607706821960, -0.938725842117972160, -0.938743074182307620, -0.938760303899785490, -0.938777531270362900, -0.938794756293996110, -0.938811978970642500, +-0.938829199300258880, -0.938846417282802380, -0.938863632918229720, -0.938880846206498030, -0.938898057147564140, -0.938915265741385170, -0.938932471987918070, -0.938949675887120080, +-0.938966877438947580, -0.938984076643357920, -0.939001273500308040, -0.939018468009754970, -0.939035660171655740, -0.939052849985967720, -0.939070037452647170, -0.939087222571651560, +-0.939104405342937930, -0.939121585766463210, -0.939138763842184640, -0.939155939570059050, -0.939173112950043690, -0.939190283982095480, -0.939207452666171890, -0.939224619002229420, +-0.939241782990225320, -0.939258944630116830, -0.939276103921861010, -0.939293260865414870, -0.939310415460735900, -0.939327567707780590, -0.939344717606506290, -0.939361865156870260, +-0.939379010358829540, -0.939396153212341380, -0.939413293717362710, -0.939430431873850890, -0.939447567681762960, -0.939464701141056400, -0.939481832251687800, -0.939498961013614630, +-0.939516087426794040, -0.939533211491183300, -0.939550333206739420, -0.939567452573420110, -0.939584569591181860, -0.939601684259982140, -0.939618796579778200, -0.939635906550527310, +-0.939653014172186610, -0.939670119444713460, -0.939687222368064900, -0.939704322942198300, -0.939721421167071020, -0.939738517042640330, -0.939755610568863140, -0.939772701745696940, +-0.939789790573098860, -0.939806877051026390, -0.939823961179437120, -0.939841042958287520, -0.939858122387535300, -0.939875199467137820, -0.939892274197052350, -0.939909346577236240, +-0.939926416607646640, -0.939943484288241150, -0.939960549618976900, -0.939977612599811160, -0.939994673230701850, -0.940011731511605440, -0.940028787442479750, -0.940045841023282150, +-0.940062892253969880, -0.940079941134500330, -0.940096987664831300, -0.940114031844919480, -0.940131073674722590, -0.940148113154198000, -0.940165150283303160, -0.940182185061995470, +-0.940199217490232280, -0.940216247567970950, -0.940233275295169090, -0.940250300671784390, -0.940267323697773550, -0.940284344373094490, -0.940301362697704480, -0.940318378671561090, +-0.940335392294621820, -0.940352403566844350, -0.940369412488185510, -0.940386419058603210, -0.940403423278054820, -0.940420425146497820, -0.940437424663889800, -0.940454421830188240, +-0.940471416645350610, -0.940488409109334510, -0.940505399222097640, -0.940522386983596910, -0.940539372393790260, -0.940556355452635160, -0.940573336160089200, -0.940590314516109970, +-0.940607290520655170, -0.940624264173681830, -0.940641235475147890, -0.940658204425010800, -0.940675171023228170, -0.940692135269757700, -0.940709097164556860, -0.940726056707583250, +-0.940743013898794560, -0.940759968738148270, -0.940776921225602410, -0.940793871361113920, -0.940810819144640710, -0.940827764576140590, -0.940844707655570930, -0.940861648382889770, +-0.940878586758054360, -0.940895522781022290, -0.940912456451751590, -0.940929387770199630, -0.940946316736324230, -0.940963243350083080, -0.940980167611433770, -0.940997089520334010, +-0.941014009076741600, -0.941030926280614470, -0.941047841131909650, -0.941064753630585280, -0.941081663776599080, -0.941098571569908620, -0.941115477010471820, -0.941132380098246620, +-0.941149280833190050, -0.941166179215260360, -0.941183075244415250, -0.941199968920612420, -0.941216860243809680, -0.941233749213964850, -0.941250635831035520, -0.941267520094979710, +-0.941284402005755360, -0.941301281563319710, -0.941318158767630810, -0.941335033618646570, -0.941351906116324690, -0.941368776260623100, -0.941385644051499830, -0.941402509488912240, +-0.941419372572818270, -0.941436233303175940, -0.941453091679942950, -0.941469947703077240, -0.941486801372536710, -0.941503652688279180, -0.941520501650262460, -0.941537348258444930, +-0.941554192512783610, -0.941571034413236750, -0.941587873959762400, -0.941604711152318360, -0.941621545990862560, -0.941638378475353140, -0.941655208605747470, -0.941672036382003810, +-0.941688861804080070, -0.941705684871934180, -0.941722505585524060, -0.941739323944807750, -0.941756139949743050, -0.941772953600288010, -0.941789764896400540, -0.941806573838039010, +-0.941823380425160780, -0.941840184657724010, -0.941856986535686840, -0.941873786059007180, -0.941890583227643410, -0.941907378041552890, -0.941924170500693880, -0.941940960605024410, +-0.941957748354502520, -0.941974533749086350, -0.941991316788733820, -0.942008097473402970, -0.942024875803051940, -0.942041651777638660, -0.942058425397121480, -0.942075196661458110, +-0.942091965570606590, -0.942108732124525280, -0.942125496323172110, -0.942142258166505100, -0.942159017654482840, -0.942175774787062710, -0.942192529564203190, -0.942209281985862290, +-0.942226032051998170, -0.942242779762568980, -0.942259525117532970, -0.942276268116847950, -0.942293008760472390, -0.942309747048364570, -0.942326482980482050, -0.942343216556783440, +-0.942359947777226650, -0.942376676641770050, -0.942393403150371790, -0.942410127302990230, -0.942426849099583190, -0.942443568540108910, -0.942460285624525770, -0.942477000352791920, +-0.942493712724865480, -0.942510422740704850, -0.942527130400268140, -0.942543835703513630, -0.942560538650399790, -0.942577239240884320, -0.942593937474925700, -0.942610633352482300, +-0.942627326873512250, -0.942644018037974040, -0.942660706845825920, -0.942677393297025820, -0.942694077391532210, -0.942710759129303360, -0.942727438510297720, -0.942744115534473350, +-0.942760790201788820, -0.942777462512202290, -0.942794132465672010, -0.942810800062156450, -0.942827465301614210, -0.942844128184003090, -0.942860788709281470, -0.942877446877408040, +-0.942894102688340950, -0.942910756142038790, -0.942927407238459580, -0.942944055977561810, -0.942960702359303850, -0.942977346383644170, -0.942993988050541130, -0.943010627359953110, +-0.943027264311838590, -0.943043898906155810, -0.943060531142863370, -0.943077161021919850, -0.943093788543283180, -0.943110413706911950, -0.943127036512764750, -0.943143656960799940, +-0.943160275050975990, -0.943176890783251620, -0.943193504157584740, -0.943210115173934160, -0.943226723832258250, -0.943243330132515490, -0.943259934074664460, -0.943276535658663650, +-0.943293134884471420, -0.943309731752046350, -0.943326326261347270, -0.943342918412332090, -0.943359508204959510, -0.943376095639188340, -0.943392680714976840, -0.943409263432283600, +-0.943425843791067530, -0.943442421791286570, -0.943458997432899520, -0.943475570715864960, -0.943492141640141500, -0.943508710205687720, -0.943525276412462200, -0.943541840260423430, +-0.943558401749530100, -0.943574960879741020, -0.943591517651014230, -0.943608072063308660, -0.943624624116582880, -0.943641173810795600, -0.943657721145905400, -0.943674266121871110, +-0.943690808738650970, -0.943707348996203680, -0.943723886894488160, -0.943740422433462790, -0.943756955613086370, -0.943773486433317710, -0.943790014894115180, -0.943806540995437700, +-0.943823064737243870, -0.943839586119492590, -0.943856105142142130, -0.943872621805151300, -0.943889136108479020, -0.943905648052083880, -0.943922157635924910, -0.943938664859960250, +-0.943955169724148950, -0.943971672228449690, -0.943988172372821290, -0.944004670157222450, -0.944021165581611870, -0.944037658645948460, -0.944054149350190830, -0.944070637694297890, +-0.944087123678228670, -0.944103607301941320, -0.944120088565394870, -0.944136567468548350, -0.944153044011360240, -0.944169518193789690, -0.944185990015795510, -0.944202459477336160, +-0.944218926578370590, -0.944235391318857700, -0.944251853698756420, -0.944268313718025440, -0.944284771376623590, -0.944301226674510000, -0.944317679611643260, -0.944334130187982510, +-0.944350578403486240, -0.944367024258113590, -0.944383467751823250, -0.944399908884574370, -0.944416347656325540, -0.944432784067036350, -0.944449218116664710, -0.944465649805170120, +-0.944482079132511480, -0.944498506098647490, -0.944514930703537310, -0.944531352947139860, -0.944547772829413930, -0.944564190350318580, -0.944580605509813150, -0.944597018307855810, +-0.944613428744405900, -0.944629836819422470, -0.944646242532864440, -0.944662645884690840, -0.944679046874860930, -0.944695445503333060, -0.944711841770066620, -0.944728235675020510, +-0.944744627218153890, -0.944761016399425670, -0.944777403218794890, -0.944793787676220580, -0.944810169771661880, -0.944826549505077720, -0.944842926876427460, -0.944859301885669580, +-0.944875674532763440, -0.944892044817668200, -0.944908412740342760, -0.944924778300746620, -0.944941141498838230, -0.944957502334576980, -0.944973860807922010, -0.944990216918832340, +-0.945006570667267120, -0.945022922053185500, -0.945039271076546620, -0.945055617737309510, -0.945071962035433310, -0.945088303970877620, -0.945104643543600800, -0.945120980753562430, +-0.945137315600721560, -0.945153648085037320, -0.945169978206469420, -0.945186305964976210, -0.945202631360517190, -0.945218954393051590, -0.945235275062538680, -0.945251593368937600, +-0.945267909312207390, -0.945284222892307510, -0.945300534109197120, -0.945316842962835360, -0.945333149453181700, -0.945349453580194950, -0.945365755343834600, -0.945382054744059790, +-0.945398351780829870, -0.945414646454104110, -0.945430938763841990, -0.945447228710002200, -0.945463516292544330, -0.945479801511427740, -0.945496084366611590, -0.945512364858055230, +-0.945528642985718040, -0.945544918749559150, -0.945561192149538040, -0.945577463185614200, -0.945593731857746420, -0.945609998165894310, -0.945626262110017210, -0.945642523690074400, +-0.945658782906025340, -0.945675039757829630, -0.945691294245445960, -0.945707546368834140, -0.945723796127953430, -0.945740043522763200, -0.945756288553222800, -0.945772531219291720, +-0.945788771520929440, -0.945805009458095090, -0.945821245030748270, -0.945837478238848560, -0.945853709082355000, -0.945869937561227060, -0.945886163675424330, -0.945902387424906180, +-0.945918608809632300, -0.945934827829561620, -0.945951044484653950, -0.945967258774868650, -0.945983470700165200, -0.945999680260502960, -0.946015887455841640, -0.946032092286140600, +-0.946048294751359320, -0.946064494851457270, -0.946080692586394270, -0.946096887956129230, -0.946113080960622080, -0.946129271599832070, -0.946145459873719010, -0.946161645782242490, +-0.946177829325361650, -0.946194010503036200, -0.946210189315225710, -0.946226365761889790, -0.946242539842988010, -0.946258711558479740, -0.946274880908324790, -0.946291047892482640, +-0.946307212510912770, -0.946323374763575310, -0.946339534650428970, -0.946355692171433890, -0.946371847326549550, -0.946388000115735650, -0.946404150538951660, -0.946420298596157620, +-0.946436444287312550, -0.946452587612376380, -0.946468728571308700, -0.946484867164069210, -0.946501003390617600, -0.946517137250913470, -0.946533268744916390, -0.946549397872586300, +-0.946565524633882880, -0.946581649028765400, -0.946597771057193890, -0.946613890719127830, -0.946630008014527120, -0.946646122943351380, -0.946662235505560500, -0.946678345701113870, +-0.946694453529971390, -0.946710558992092670, -0.946726662087437610, -0.946742762815965920, -0.946758861177637300, -0.946774957172411560, -0.946791050800248390, -0.946807142061107940, +-0.946823230954949250, -0.946839317481732560, -0.946855401641417570, -0.946871483433963990, -0.946887562859331840, -0.946903639917480940, -0.946919714608370770, -0.946935786931961230, +-0.946951856888212260, -0.946967924477083670, -0.946983989698535140, -0.947000052552526840, -0.947016113039018230, -0.947032171157969450, -0.947048226909340210, -0.947064280293090640, +-0.947080331309180120, -0.947096379957568790, -0.947112426238216560, -0.947128470151083150, -0.947144511696128900, -0.947160550873313080, -0.947176587682595940, -0.947192622123937290, +-0.947208654197297050, -0.947224683902635260, -0.947240711239911600, -0.947256736209086350, -0.947272758810119190, -0.947288779042970040, -0.947304796907599390, -0.947320812403966370, +-0.947336825532031360, -0.947352836291754150, -0.947368844683095010, -0.947384850706013750, -0.947400854360470610, -0.947416855646424970, -0.947432854563837300, -0.947448851112667410, +-0.947464845292875450, -0.947480837104421440, -0.947496826547265190, -0.947512813621366970, -0.947528798326686680, -0.947544780663184700, -0.947560760630820510, -0.947576738229554460, +-0.947592713459346480, -0.947608686320156710, -0.947624656811945300, -0.947640624934672380, -0.947656590688297770, -0.947672554072781610, -0.947688515088084050, -0.947704473734165330, +-0.947720430010985270, -0.947736383918504230, -0.947752335456682140, -0.947768284625479350, -0.947784231424856020, -0.947800175854771830, -0.947816117915187270, -0.947832057606062370, +-0.947847994927357380, -0.947863929879032340, -0.947879862461047720, -0.947895792673363210, -0.947911720515939300, -0.947927645988736020, -0.947943569091713620, -0.947959489824832250, +-0.947975408188052260, -0.947991324181333690, -0.948007237804636800, -0.948023149057921840, -0.948039057941149290, -0.948054964454278840, -0.948070868597270850, -0.948086770370085820, +-0.948102669772683870, -0.948118566805025490, -0.948134461467070370, -0.948150353758779100, -0.948166243680112040, -0.948182131231029230, -0.948198016411491260, -0.948213899221458160, +-0.948229779660890280, -0.948245657729748000, -0.948261533427991580, -0.948277406755581590, -0.948293277712477730, -0.948309146298640830, -0.948325012514031010, -0.948340876358608640, +-0.948356737832333980, -0.948372596935167960, -0.948388453667070030, -0.948404308028000910, -0.948420160017921180, -0.948436009636790980, -0.948451856884570680, -0.948467701761220860, +-0.948483544266701670, -0.948499384400973700, -0.948515222163997640, -0.948531057555733080, -0.948546890576140940, -0.948562721225181590, -0.948578549502815390, -0.948594375409002820, +-0.948610198943704690, -0.948626020106880690, -0.948641838898491630, -0.948657655318497990, -0.948673469366860260, -0.948689281043538780, -0.948705090348494150, -0.948720897281686850, +-0.948736701843077230, -0.948752504032626120, -0.948768303850293540, -0.948784101296040180, -0.948799896369826530, -0.948815689071613180, -0.948831479401360590, -0.948847267359029580, +-0.948863052944580070, -0.948878836157972970, -0.948894616999168770, -0.948910395468128050, -0.948926171564811400, -0.948941945289179190, -0.948957716641192220, -0.948973485620810960, +-0.948989252227995910, -0.949005016462708070, -0.949020778324907390, -0.949036537814554770, -0.949052294931610810, -0.949068049676036090, -0.949083802047791520, -0.949099552046837160, +-0.949115299673134020, -0.949131044926642460, -0.949146787807323420, -0.949162528315137370, -0.949178266450044990, -0.949194002212007000, -0.949209735600983980, -0.949225466616936630, +-0.949241195259825870, -0.949256921529611830, -0.949272645426255450, -0.949288366949717520, -0.949304086099958640, -0.949319802876939620, -0.949335517280621270, -0.949351229310963940, +-0.949366938967928450, -0.949382646251475730, -0.949398351161566230, -0.949414053698161010, -0.949429753861220640, -0.949445451650705820, -0.949461147066577360, -0.949476840108796290, +-0.949492530777322870, -0.949508219072118240, -0.949523904993142990, -0.949539588540357920, -0.949555269713723840, -0.949570948513202010, -0.949586624938752450, -0.949602298990336320, +-0.949617970667914420, -0.949633639971447670, -0.949649306900896770, -0.949664971456222640, -0.949680633637386080, -0.949696293444347920, -0.949711950877069280, -0.949727605935510530, +-0.949743258619632710, -0.949758908929396740, -0.949774556864763640, -0.949790202425694010, -0.949805845612149200, -0.949821486424089480, -0.949837124861475980, -0.949852760924269730, +-0.949868394612431670, -0.949884025925922470, -0.949899654864703290, -0.949915281428734940, -0.949930905617978440, -0.949946527432394610, -0.949962146871944800, -0.949977763936589280, +-0.949993378626289410, -0.950008990941006100, -0.950024600880700290, -0.950040208445333210, -0.950055813634865350, -0.950071416449258080, -0.950087016888472080, -0.950102614952468620, +-0.950118210641208720, -0.950133803954653190, -0.950149394892763180, -0.950164983455499600, -0.950180569642823600, -0.950196153454696550, -0.950211734891078800, -0.950227313951931610, +-0.950242890637216230, -0.950258464946893590, -0.950274036880924820, -0.950289606439271180, -0.950305173621893370, -0.950320738428752530, -0.950336300859809800, -0.950351860915026440, +-0.950367418594363360, -0.950382973897781700, -0.950398526825242620, -0.950414077376707240, -0.950429625552136950, -0.950445171351492310, -0.950460714774734820, -0.950476255821825490, +-0.950491794492725470, -0.950507330787396020, -0.950522864705798500, -0.950538396247893490, -0.950553925413642590, -0.950569452203006810, -0.950584976615947430, -0.950600498652425570, +-0.950616018312402500, -0.950631535595839460, -0.950647050502697490, -0.950662563032938170, -0.950678073186522090, -0.950693580963410940, -0.950709086363565880, -0.950724589386948040, +-0.950740090033518670, -0.950755588303239360, -0.950771084196070930, -0.950786577711974720, -0.950802068850912010, -0.950817557612844140, -0.950833043997732500, -0.950848528005538100, +-0.950864009636222420, -0.950879488889746720, -0.950894965766072350, -0.950910440265160810, -0.950925912386972880, -0.950941382131470170, -0.950956849498614030, -0.950972314488365720, +-0.950987777100686940, -0.951003237335538490, -0.951018695192881850, -0.951034150672678600, -0.951049603774889900, -0.951065054499477090, -0.951080502846401780, -0.951095948815625200, +-0.951111392407108620, -0.951126833620813740, -0.951142272456701910, -0.951157708914734170, -0.951173142994872210, -0.951188574697077290, -0.951204004021311000, -0.951219430967534700, +-0.951234855535710190, -0.951250277725798070, -0.951265697537760360, -0.951281114971558430, -0.951296530027153750, -0.951311942704507580, -0.951327353003581730, -0.951342760924337450, +-0.951358166466736210, -0.951373569630739820, -0.951388970416309320, -0.951404368823406290, -0.951419764851992420, -0.951435158502029090, -0.951450549773477980, -0.951465938666300690, +-0.951481325180458250, -0.951496709315912460, -0.951512091072625020, -0.951527470450557190, -0.951542847449670880, -0.951558222069927350, -0.951573594311288180, -0.951588964173715190, +-0.951604331657169960, -0.951619696761613620, -0.951635059487008110, -0.951650419833314890, -0.951665777800495660, -0.951681133388512010, -0.951696486597325750, -0.951711837426898020, +-0.951727185877190630, -0.951742531948165380, -0.951757875639783760, -0.951773216952007450, -0.951788555884798050, -0.951803892438117360, -0.951819226611926860, -0.951834558406188360, +-0.951849887820863660, -0.951865214855914020, -0.951880539511301250, -0.951895861786987260, -0.951911181682933540, -0.951926499199102220, -0.951941814335454330, -0.951957127091951900, +-0.951972437468556640, -0.951987745465230240, -0.952003051081934610, -0.952018354318631240, -0.952033655175282050, -0.952048953651848720, -0.952064249748292960, -0.952079543464576790, +-0.952094834800661590, -0.952110123756509270, -0.952125410332081650, -0.952140694527340510, -0.952155976342247690, -0.952171255776765090, -0.952186532830854190, -0.952201807504476920, +-0.952217079797595070, -0.952232349710170570, -0.952247617242165220, -0.952262882393540840, -0.952278145164259130, -0.952293405554282210, -0.952308663563571910, -0.952323919192089810, +-0.952339172439797820, -0.952354423306657980, -0.952369671792631990, -0.952384917897681870, -0.952400161621769660, -0.952415402964856940, -0.952430641926905520, -0.952445878507877650, +-0.952461112707735040, -0.952476344526439590, -0.952491573963953340, -0.952506801020238100, -0.952522025695255900, -0.952537247988968880, -0.952552467901338520, -0.952567685432326950, +-0.952582900581896210, -0.952598113350008100, -0.952613323736624880, -0.952628531741708470, -0.952643737365220570, -0.952658940607123310, -0.952674141467378610, -0.952689339945948620, +-0.952704536042795260, -0.952719729757880550, -0.952734921091166640, -0.952750110042615340, -0.952765296612188670, -0.952780480799849120, -0.952795662605558150, -0.952810842029277900, +-0.952826019070970640, -0.952841193730598280, -0.952856366008123290, -0.952871535903507040, -0.952886703416712000, -0.952901868547700200, -0.952917031296433680, -0.952932191662874570, +-0.952947349646985020, -0.952962505248727050, -0.952977658468062930, -0.952992809304954560, -0.953007957759364420, -0.953023103831254210, -0.953038247520586190, -0.953053388827322600, +-0.953068527751425480, -0.953083664292857070, -0.953098798451579740, -0.953113930227555190, -0.953129059620745790, -0.953144186631113670, -0.953159311258621190, -0.953174433503230390, +-0.953189553364903520, -0.953204670843602720, -0.953219785939290350, -0.953234898651928670, -0.953250008981479490, -0.953265116927905390, -0.953280222491168390, -0.953295325671230880, +-0.953310426468055080, -0.953325524881603380, -0.953340620911837690, -0.953355714558720480, -0.953370805822213900, -0.953385894702280300, -0.953400981198882060, -0.953416065311981310, +-0.953431147041540420, -0.953446226387521630, -0.953461303349887550, -0.953476377928599960, -0.953491450123621350, -0.953506519934914200, -0.953521587362440750, -0.953536652406163250, +-0.953551715066044530, -0.953566775342046150, -0.953581833234130820, -0.953596888742261010, -0.953611941866398860, -0.953626992606506960, -0.953642040962547450, -0.953657086934482920, +-0.953672130522275730, -0.953687171725888130, -0.953702210545282920, -0.953717246980421820, -0.953732281031267730, -0.953747312697782900, -0.953762341979929710, -0.953777368877670950, +-0.953792393390968550, -0.953807415519785210, -0.953822435264083280, -0.953837452623825240, -0.953852467598973570, -0.953867480189490750, -0.953882490395339230, -0.953897498216481510, +-0.953912503652880050, -0.953927506704497550, -0.953942507371296040, -0.953957505653238220, -0.953972501550286680, -0.953987495062403880, -0.954002486189552410, -0.954017474931694860, +-0.954032461288793490, -0.954047445260810870, -0.954062426847709700, -0.954077406049452350, -0.954092382866001620, -0.954107357297319880, -0.954122329343369710, -0.954137299004113810, +-0.954152266279514880, -0.954167231169534950, -0.954182193674137040, -0.954197153793283630, -0.954212111526937300, -0.954227066875060650, -0.954242019837616700, -0.954256970414567360, +-0.954271918605875680, -0.954286864411504120, -0.954301807831415490, -0.954316748865572270, -0.954331687513937150, -0.954346623776472840, -0.954361557653142010, -0.954376489143907490, +-0.954391418248731530, -0.954406344967577040, -0.954421269300406610, -0.954436191247183040, -0.954451110807869040, -0.954466027982427520, -0.954480942770820630, -0.954495855173011390, +-0.954510765188962500, -0.954525672818636760, -0.954540578061996770, -0.954555480919005330, -0.954570381389625240, -0.954585279473819210, -0.954600175171549940, -0.954615068482780550, +-0.954629959407473190, -0.954644847945590900, -0.954659734097096480, -0.954674617861952730, -0.954689499240122810, -0.954704378231568730, -0.954719254836253750, -0.954734129054140680, +-0.954749000885192320, -0.954763870329371380, -0.954778737386640760, -0.954793602056963290, -0.954808464340301870, -0.954823324236619310, -0.954838181745878640, -0.954853036868042240, +-0.954867889603073340, -0.954882739950934640, -0.954897587911589070, -0.954912433484999880, -0.954927276671129310, -0.954942117469940510, -0.954956955881396400, -0.954971791905460000, +-0.954986625542094010, -0.955001456791261580, -0.955016285652925400, -0.955031112127048500, -0.955045936213593900, -0.955060757912524650, -0.955075577223803320, -0.955090394147393050, +-0.955105208683256770, -0.955120020831357390, -0.955134830591658050, -0.955149637964121890, -0.955164442948711280, -0.955179245545389690, -0.955194045754119920, -0.955208843574865020, +-0.955223639007588000, -0.955238432052252010, -0.955253222708819850, -0.955268010977254560, -0.955282796857519600, -0.955297580349577350, -0.955312361453391160, -0.955327140168924060, +-0.955341916496139200, -0.955356690434999490, -0.955371461985468300, -0.955386231147508090, -0.955400997921082460, -0.955415762306154330, -0.955430524302686710, -0.955445283910642760, +-0.955460041129985730, -0.955474795960678520, -0.955489548402684300, -0.955504298455966520, -0.955519046120487660, -0.955533791396211200, -0.955548534283100380, -0.955563274781118130, +-0.955578012890227700, -0.955592748610392450, -0.955607481941575190, -0.955622212883739160, -0.955636941436847520, -0.955651667600863620, -0.955666391375750490, -0.955681112761471500, +-0.955695831757989670, -0.955710548365268250, -0.955725262583270400, -0.955739974411959680, -0.955754683851298800, -0.955769390901251240, -0.955784095561780120, -0.955798797832848820, +-0.955813497714420810, -0.955828195206458790, -0.955842890308926220, -0.955857583021786470, -0.955872273345002690, -0.955886961278538340, -0.955901646822356570, -0.955916329976420620, +-0.955931010740693870, -0.955945689115139550, -0.955960365099721380, -0.955975038694401920, -0.955989709899145000, -0.956004378713913640, -0.956019045138671420, -0.956033709173381600, +-0.956048370818007750, -0.956063030072512700, -0.956077686936860130, -0.956092341411013290, -0.956106993494935660, -0.956121643188590500, -0.956136290491941150, -0.956150935404951220, +-0.956165577927583830, -0.956180218059802800, -0.956194855801571040, -0.956209491152852030, -0.956224124113609350, -0.956238754683806370, -0.956253382863406440, -0.956268008652373380, +-0.956282632050669990, -0.956297253058260080, -0.956311871675107010, -0.956326487901174250, -0.956341101736425280, -0.956355713180823570, -0.956370322234332600, -0.956384928896915730, +-0.956399533168536880, -0.956414135049158840, -0.956428734538745550, -0.956443331637260470, -0.956457926344666980, -0.956472518660928750, -0.956487108586009380, -0.956501696119872010, +-0.956516281262480450, -0.956530864013798170, -0.956545444373788630, -0.956560022342415660, -0.956574597919642500, -0.956589171105432850, -0.956603741899750390, -0.956618310302558510, +-0.956632876313820990, -0.956647439933501210, -0.956662001161562750, -0.956676559997969300, -0.956691116442684340, -0.956705670495672010, -0.956720222156895120, -0.956734771426317800, +-0.956749318303903530, -0.956763862789615890, -0.956778404883418590, -0.956792944585275310, -0.956807481895149750, -0.956822016813005380, -0.956836549338806020, -0.956851079472515460, +-0.956865607214096970, -0.956880132563514560, -0.956894655520731720, -0.956909176085712350, -0.956923694258419940, -0.956938210038818630, -0.956952723426871430, -0.956967234422542500, +-0.956981743025795420, -0.956996249236594100, -0.957010753054902020, -0.957025254480683210, -0.957039753513901140, -0.957054250154519730, -0.957068744402502890, -0.957083236257814000, +-0.957097725720417070, -0.957112212790275700, -0.957126697467353900, -0.957141179751615280, -0.957155659643024070, -0.957170137141543420, -0.957184612247137360, -0.957199084959769800, +-0.957213555279404550, -0.957228023206005420, -0.957242488739536210, -0.957256951879960740, -0.957271412627243020, -0.957285870981346880, -0.957300326942235880, -0.957314780509874060, +-0.957329231684225230, -0.957343680465253420, -0.957358126852922320, -0.957372570847196290, -0.957387012448038480, -0.957401451655413130, -0.957415888469284160, -0.957430322889615490, +-0.957444754916370930, -0.957459184549514620, -0.957473611789010250, -0.957488036634821850, -0.957502459086913450, -0.957516879145249080, -0.957531296809792320, -0.957545712080507210, +-0.957560124957357870, -0.957574535440308240, -0.957588943529322560, -0.957603349224364190, -0.957617752525397490, -0.957632153432386390, -0.957646551945295020, -0.957660948064087080, +-0.957675341788726930, -0.957689733119178380, -0.957704122055405450, -0.957718508597372180, -0.957732892745043030, -0.957747274498381260, -0.957761653857351350, -0.957776030821917310, +-0.957790405392043300, -0.957804777567693110, -0.957819147348831330, -0.957833514735421440, -0.957847879727427690, -0.957862242324814210, -0.957876602527545250, -0.957890960335584740, +-0.957905315748896810, -0.957919668767445610, -0.957934019391195160, -0.957948367620110040, -0.957962713454153620, -0.957977056893290490, -0.957991397937484780, -0.958005736586700410, +-0.958020072840901850, -0.958034406700053240, -0.958048738164118510, -0.958063067233061780, -0.958077393906847540, -0.958091718185439700, -0.958106040068802620, -0.958120359556900340, +-0.958134676649697310, -0.958148991347157470, -0.958163303649245510, -0.958177613555924900, -0.958191921067160330, -0.958206226182916070, -0.958220528903156120, -0.958234829227844860, +-0.958249127156946770, -0.958263422690425640, -0.958277715828245950, -0.958292006570371950, -0.958306294916767890, -0.958320580867398240, -0.958334864422227040, -0.958349145581218640, +-0.958363424344337410, -0.958377700711547710, -0.958391974682813900, -0.958406246258099890, -0.958420515437370390, -0.958434782220589530, -0.958449046607721680, -0.958463308598731520, +-0.958477568193582760, -0.958491825392240090, -0.958506080194667990, -0.958520332600830580, -0.958534582610692350, -0.958548830224217660, -0.958563075441370870, -0.958577318262116450, +-0.958591558686418770, -0.958605796714242290, -0.958620032345551150, -0.958634265580309950, -0.958648496418483150, -0.958662724860035010, -0.958676950904930100, -0.958691174553133020, +-0.958705395804607790, -0.958719614659319100, -0.958733831117231320, -0.958748045178309030, -0.958762256842516590, -0.958776466109818480, -0.958790672980179170, -0.958804877453563240, +-0.958819079529935390, -0.958833279209259540, -0.958847476491500590, -0.958861671376622820, -0.958875863864590890, -0.958890053955369410, -0.958904241648922960, -0.958918426945215670, +-0.958932609844212360, -0.958946790345877380, -0.958960968450175530, -0.958975144157071300, -0.958989317466529160, -0.959003488378513680, -0.959017656892989570, -0.959031823009921510, +-0.959045986729273660, -0.959060148051010810, -0.959074306975097660, -0.959088463501498680, -0.959102617630178570, -0.959116769361102240, -0.959130918694233610, -0.959145065629537720, +-0.959159210166979250, -0.959173352306522680, -0.959187492048132690, -0.959201629391774000, -0.959215764337411290, -0.959229896885009150, -0.959244027034532270, -0.959258154785945560, +-0.959272280139213170, -0.959286403094300130, -0.959300523651171020, -0.959314641809790650, -0.959328757570123920, -0.959342870932135110, -0.959356981895789110, -0.959371090461050620, +-0.959385196627884350, -0.959399300396255090, -0.959413401766127660, -0.959427500737466740, -0.959441597310237040, -0.959455691484403240, -0.959469783259930600, -0.959483872636783250, +-0.959497959614926120, -0.959512044194324120, -0.959526126374942060, -0.959540206156744620, -0.959554283539696960, -0.959568358523763320, -0.959582431108908840, -0.959596501295098210, +-0.959610569082296360, -0.959624634470468090, -0.959638697459578300, -0.959652758049591710, -0.959666816240473230, -0.959680872032187880, -0.959694925424700140, -0.959708976417975150, +-0.959723025011977700, -0.959737071206672620, -0.959751115002024920, -0.959765156397999640, -0.959779195394561360, -0.959793231991674880, -0.959807266189305450, -0.959821297987417890, +-0.959835327385976990, -0.959849354384947780, -0.959863378984295300, -0.959877401183984240, -0.959891420983979950, -0.959905438384246910, -0.959919453384750270, -0.959933465985454930, +-0.959947476186326030, -0.959961483987328280, -0.959975489388427250, -0.959989492389587080, -0.960003492990773370, -0.960017491191950790, -0.960031486993084490, -0.960045480394139510, +-0.960059471395080850, -0.960073459995873460, -0.960087446196482450, -0.960101429996872760, -0.960115411397009840, -0.960129390396858070, -0.960143366996382920, -0.960157341195549300, +-0.960171312994322350, -0.960185282392667320, -0.960199249390548790, -0.960213213987932250, -0.960227176184782590, -0.960241135981064970, -0.960255093376744640, -0.960269048371786500, +-0.960283000966155710, -0.960296951159817500, -0.960310898952736800, -0.960324844344879190, -0.960338787336209250, -0.960352727926692240, -0.960366666116293400, -0.960380601904977980, +-0.960394535292711020, -0.960408466279457970, -0.960422394865183550, -0.960436321049853100, -0.960450244833431890, -0.960464166215885040, -0.960478085197177700, -0.960492001777275230, +-0.960505915956142760, -0.960519827733745560, -0.960533737110048860, -0.960547644085017690, -0.960561548658617430, -0.960575450830813300, -0.960589350601570470, -0.960603247970854280, +-0.960617142938630320, -0.960631035504863060, -0.960644925669518420, -0.960658813432561320, -0.960672698793957220, -0.960686581753671390, -0.960700462311669170, -0.960714340467915710, +-0.960728216222376470, -0.960742089575016830, -0.960755960525801810, -0.960769829074696880, -0.960783695221667290, -0.960797558966678510, -0.960811420309695910, -0.960825279250684950, +-0.960839135789610550, -0.960852989926438310, -0.960866841661133560, -0.960880690993661690, -0.960894537923988160, -0.960908382452078320, -0.960922224577897440, -0.960936064301410990, +-0.960949901622584420, -0.960963736541383340, -0.960977569057772760, -0.960991399171718160, -0.961005226883185020, -0.961019052192138900, -0.961032875098545400, -0.961046695602369440, +-0.961060513703576700, -0.961074329402132670, -0.961088142698002910, -0.961101953591152690, -0.961115762081547700, -0.961129568169153180, -0.961143371853934840, -0.961157173135858020, +-0.961170972014888550, -0.961184768490991330, -0.961198562564132280, -0.961212354234276760, -0.961226143501390350, -0.961239930365438640, -0.961253714826387330, -0.961267496884201430, +-0.961281276538846870, -0.961295053790289120, -0.961308828638493650, -0.961322601083426150, -0.961336371125052210, -0.961350138763337300, -0.961363903998247000, -0.961377666829747230, +-0.961391427257803020, -0.961405185282380280, -0.961418940903444600, -0.961432694120961440, -0.961446444934896730, -0.961460193345216040, -0.961473939351884630, -0.961487682954868310, +-0.961501424154132870, -0.961515162949643900, -0.961528899341366980, -0.961542633329267820, -0.961556364913312090, -0.961570094093465390, -0.961583820869693740, -0.961597545241962280, +-0.961611267210236930, -0.961624986774483490, -0.961638703934667550, -0.961652418690754800, -0.961666131042711260, -0.961679840990502190, -0.961693548534093500, -0.961707253673451000, +-0.961720956408540270, -0.961734656739327230, -0.961748354665777460, -0.961762050187856880, -0.961775743305531170, -0.961789434018766040, -0.961803122327527630, -0.961816808231781170, +-0.961830491731492600, -0.961844172826627930, -0.961857851517152750, -0.961871527803033200, -0.961885201684234640, -0.961898873160722980, -0.961912542232464250, -0.961926208899424040, +-0.961939873161568370, -0.961953535018863050, -0.961967194471273880, -0.961980851518766670, -0.961994506161307330, -0.962008158398862000, -0.962021808231396050, -0.962035455658875600, +-0.962049100681266480, -0.962062743298534580, -0.962076383510645840, -0.962090021317566380, -0.962103656719261680, -0.962117289715697770, -0.962130920306840660, -0.962144548492656290, +-0.962158174273110460, -0.962171797648169290, -0.962185418617798600, -0.962199037181964310, -0.962212653340632770, -0.962226267093769240, -0.962239878441340070, -0.962253487383311290, +-0.962267093919648710, -0.962280698050318460, -0.962294299775286580, -0.962307899094518860, -0.962321496007981340, -0.962335090515640030, -0.962348682617460980, -0.962362272313410320, +-0.962375859603453950, -0.962389444487557920, -0.962403026965688250, -0.962416607037811290, -0.962430184703892520, -0.962443759963898420, -0.962457332817794780, -0.962470903265547850, +-0.962484471307123670, -0.962498036942488590, -0.962511600171608080, -0.962525160994448630, -0.962538719410976350, -0.962552275421157180, -0.962565829024957350, -0.962579380222342910, +-0.962592929013280090, -0.962606475397734920, -0.962620019375673540, -0.962633560947062320, -0.962647100111867050, -0.962660636870053990, -0.962674171221589270, -0.962687703166439150, +-0.962701232704570090, -0.962714759835947680, -0.962728284560538380, -0.962741806878308350, -0.962755326789223710, -0.962768844293250940, -0.962782359390355950, -0.962795872080504990, +-0.962809382363664420, -0.962822890239800500, -0.962836395708879470, -0.962849898770867240, -0.962863399425730290, -0.962876897673434760, -0.962890393513947120, -0.962903886947233610, +-0.962917377973260160, -0.962930866591993340, -0.962944352803399290, -0.962957836607444380, -0.962971318004094970, -0.962984796993317070, -0.962998273575077390, -0.963011747749341840, +-0.963025219516077000, -0.963038688875249350, -0.963052155826824800, -0.963065620370769810, -0.963079082507050770, -0.963092542235634010, -0.963105999556485900, -0.963119454469573030, +-0.963132906974861310, -0.963146357072317330, -0.963159804761907430, -0.963173250043597990, -0.963186692917355480, -0.963200133383146140, -0.963213571440936560, -0.963227007090692980, +-0.963240440332382210, -0.963253871165970050, -0.963267299591423210, -0.963280725608708140, -0.963294149217791330, -0.963307570418639010, -0.963320989211218110, -0.963334405595494440, +-0.963347819571434780, -0.963361231139005510, -0.963374640298173210, -0.963388047048904350, -0.963401451391165400, -0.963414853324922720, -0.963428252850142890, -0.963441649966792490, +-0.963455044674838220, -0.963468436974246110, -0.963481826864982850, -0.963495214347015020, -0.963508599420309200, -0.963521982084832200, -0.963535362340549820, -0.963548740187429200, +-0.963562115625436590, -0.963575488654538790, -0.963588859274702280, -0.963602227485893530, -0.963615593288079220, -0.963628956681226060, -0.963642317665300400, -0.963655676240269150, +-0.963669032406098580, -0.963682386162755370, -0.963695737510206210, -0.963709086448417680, -0.963722432977356600, -0.963735777096989320, -0.963749118807282650, -0.963762458108203050, +-0.963775794999717330, -0.963789129481792180, -0.963802461554394200, -0.963815791217490060, -0.963829118471046350, -0.963842443315029880, -0.963855765749407680, -0.963869085774145650, +-0.963882403389211050, -0.963895718594570350, -0.963909031390190350, -0.963922341776037860, -0.963935649752079680, -0.963948955318282060, -0.963962258474612140, -0.963975559221036620, +-0.963988857557522170, -0.964002153484035620, -0.964015447000543650, -0.964028738107012950, -0.964042026803410560, -0.964055313089703270, -0.964068596965857450, -0.964081878431840230, +-0.964095157487618200, -0.964108434133158280, -0.964121708368427370, -0.964134980193392390, -0.964148249608019700, -0.964161516612276340, -0.964174781206129320, -0.964188043389545220, +-0.964201303162491090, -0.964214560524933710, -0.964227815476839890, -0.964241068018176550, -0.964254318148910720, -0.964267565869008860, -0.964280811178438110, -0.964294054077165400, +-0.964307294565157510, -0.964320532642381380, -0.964333768308804130, -0.964347001564392240, -0.964360232409112840, -0.964373460842932960, -0.964386686865819300, -0.964399910477738990, +-0.964413131678658830, -0.964426350468545970, -0.964439566847367090, -0.964452780815089340, -0.964465992371679960, -0.964479201517105310, -0.964492408251332640, -0.964505612574328870, +-0.964518814486061250, -0.964532013986496680, -0.964545211075601870, -0.964558405753344060, -0.964571598019690280, -0.964584787874607440, -0.964597975318062680, -0.964611160350022920, +-0.964624342970455300, -0.964637523179326830, -0.964650700976604550, -0.964663876362255700, -0.964677049336246980, -0.964690219898545640, -0.964703388049118700, -0.964716553787933310, +-0.964729717114956590, -0.964742878030155790, -0.964756036533497510, -0.964769192624949200, -0.964782346304477790, -0.964795497572050630, -0.964808646427634750, -0.964821792871197180, +-0.964834936902705160, -0.964848078522125840, -0.964861217729426460, -0.964874354524573820, -0.964887488907535400, -0.964900620878278100, -0.964913750436769410, -0.964926877582976240, +-0.964940002316866160, -0.964953124638405770, -0.964966244547562630, -0.964979362044303900, -0.964992477128596700, -0.965005589800408290, -0.965018700059706020, -0.965031807906456930, +-0.965044913340628360, -0.965058016362187690, -0.965071116971101710, -0.965084215167338000, -0.965097310950863820, -0.965110404321646190, -0.965123495279652690, -0.965136583824850680, +-0.965149669957206860, -0.965162753676689020, -0.965175834983264200, -0.965188913876899870, -0.965201990357563160, -0.965215064425221540, -0.965228136079842150, -0.965241205321392570, +-0.965254272149839940, -0.965267336565151850, -0.965280398567295080, -0.965293458156237460, -0.965306515331946110, -0.965319570094388510, -0.965332622443532240, -0.965345672379344100, +-0.965358719901791900, -0.965371765010842760, -0.965384807706464290, -0.965397847988623830, -0.965410885857288740, -0.965423921312426380, -0.965436954354004230, -0.965449984981989750, +-0.965463013196350420, -0.965476038997053480, -0.965489062384066400, -0.965502083357356540, -0.965515101916891600, -0.965528118062638830, -0.965541131794566130, -0.965554143112640210, +-0.965567152016829080, -0.965580158507099990, -0.965593162583420430, -0.965606164245758070, -0.965619163494080280, -0.965632160328354530, -0.965645154748548510, -0.965658146754629690, +-0.965671136346565320, -0.965684123524323090, -0.965697108287870590, -0.965710090637175280, -0.965723070572204860, -0.965736048092926900, -0.965749023199308550, -0.965761995891317730, +-0.965774966168921890, -0.965787934032088620, -0.965800899480785510, -0.965813862514980140, -0.965826823134640190, -0.965839781339733140, -0.965852737130226790, -0.965865690506088500, +-0.965878641467285860, -0.965891590013786660, -0.965904536145558490, -0.965917479862569040, -0.965930421164786110, -0.965943360052176850, -0.965956296524709160, -0.965969230582350740, +-0.965982162225069270, -0.965995091452832470, -0.966008018265607890, -0.966020942663363250, -0.966033864646066220, -0.966046784213684510, -0.966059701366186130, -0.966072616103538230, +-0.966085528425708830, -0.966098438332665620, -0.966111345824376300, -0.966124250900808780, -0.966137153561930530, -0.966150053807709350, -0.966162951638112940, -0.966175847053109220, +-0.966188740052665860, -0.966201630636750690, -0.966214518805331490, -0.966227404558375860, -0.966240287895851810, -0.966253168817727270, -0.966266047323969590, -0.966278923414546800, +-0.966291797089426590, -0.966304668348576980, -0.966317537191965670, -0.966330403619560800, -0.966343267631329610, -0.966356129227240350, -0.966368988407260710, -0.966381845171358610, +-0.966394699519501850, -0.966407551451658350, -0.966420400967796020, -0.966433248067882670, -0.966446092751886420, -0.966458935019774760, -0.966471774871515700, -0.966484612307077270, +-0.966497447326427280, -0.966510279929533640, -0.966523110116364490, -0.966535937886887410, -0.966548763241070530, -0.966561586178881660, -0.966574406700288820, -0.966587224805259940, +-0.966600040493763140, -0.966612853765766110, -0.966625664621237000, -0.966638473060143940, -0.966651279082454410, -0.966664082688136750, -0.966676883877158890, -0.966689682649488850, +-0.966702479005094540, -0.966715272943944330, -0.966728064466005680, -0.966740853571246840, -0.966753640259635840, -0.966766424531140810, -0.966779206385729670, -0.966791985823370560, +-0.966804762844031380, -0.966817537447680400, -0.966830309634285510, -0.966843079403815200, -0.966855846756236810, -0.966868611691518940, -0.966881374209629390, -0.966894134310536500, +-0.966906891994208540, -0.966919647260613080, -0.966932400109718480, -0.966945150541492880, -0.966957898555904420, -0.966970644152921220, -0.966983387332511430, -0.966996128094643080, +-0.967008866439284520, -0.967021602366403780, -0.967034335875969210, -0.967047066967948620, -0.967059795642310260, -0.967072521899022490, -0.967085245738053430, -0.967097967159371240, +-0.967110686162944380, -0.967123402748740530, -0.967136116916728290, -0.967148828666875680, -0.967161537999150940, -0.967174244913522440, -0.967186949409958310, -0.967199651488426790, +-0.967212351148896140, -0.967225048391334830, -0.967237743215710650, -0.967250435621992200, -0.967263125610147600, -0.967275813180145110, -0.967288498331953180, -0.967301181065540310, +-0.967313861380874160, -0.967326539277923340, -0.967339214756656180, -0.967351887817041070, -0.967364558459046120, -0.967377226682639810, -0.967389892487790500, -0.967402555874466440, +-0.967415216842636210, -0.967427875392267710, -0.967440531523329430, -0.967453185235789940, -0.967465836529617480, -0.967478485404780320, -0.967491131861247240, -0.967503775898986170, +-0.967516417517965580, -0.967529056718154030, -0.967541693499519790, -0.967554327862031220, -0.967566959805656990, -0.967579589330365250, -0.967592216436124590, -0.967604841122903350, +-0.967617463390670230, -0.967630083239393370, -0.967642700669041120, -0.967655315679582180, -0.967667928270985020, -0.967680538443218110, -0.967693146196249800, -0.967705751530048560, +-0.967718354444582870, -0.967730954939821420, -0.967743553015732450, -0.967756148672284660, -0.967768741909446510, -0.967781332727186470, -0.967793921125473130, -0.967806507104275290, +-0.967819090663560870, -0.967831671803298770, -0.967844250523457350, -0.967856826824005420, -0.967869400704911450, -0.967881972166144130, -0.967894541207671710, -0.967907107829462990, +-0.967919672031486320, -0.967932233813710630, -0.967944793176104270, -0.967957350118636040, -0.967969904641274300, -0.967982456743987860, -0.967995006426745520, -0.968007553689515410, +-0.968020098532266450, -0.968032640954967220, -0.968045180957586400, -0.968057718540092590, -0.968070253702454700, -0.968082786444640960, -0.968095316766620310, -0.968107844668361310, +-0.968120370149832770, -0.968132893211003260, -0.968145413851841500, -0.968157932072316260, -0.968170447872396140, -0.968182961252050170, -0.968195472211246580, -0.968207980749954180, +-0.968220486868141990, -0.968232990565778500, -0.968245491842832600, -0.968257990699273100, -0.968270487135068470, -0.968282981150187630, -0.968295472744599260, -0.968307961918272290, +-0.968320448671175390, -0.968332933003277270, -0.968345414914546950, -0.968357894404953010, -0.968370371474464360, -0.968382846123050030, -0.968395318350678380, -0.968407788157318430, +-0.968420255542938980, -0.968432720507508950, -0.968445183050997250, -0.968457643173372460, -0.968470100874603500, -0.968482556154659280, -0.968495009013508710, -0.968507459451120600, +-0.968519907467463750, -0.968532353062507290, -0.968544796236219920, -0.968557236988570440, -0.968569675319528200, -0.968582111229061570, -0.968594544717139570, -0.968606975783731230, +-0.968619404428805450, -0.968631830652331270, -0.968644254454277600, -0.968656675834613120, -0.968669094793306980, -0.968681511330328090, -0.968693925445645370, -0.968706337139227940, +-0.968718746411044500, -0.968731153261064290, -0.968743557689256240, -0.968755959695589470, -0.968768359280032580, -0.968780756442554900, -0.968793151183125150, -0.968805543501712660, +-0.968817933398286260, -0.968830320872815180, -0.968842705925268220, -0.968855088555614420, -0.968867468763822900, -0.968879846549862700, -0.968892221913702830, -0.968904594855312550, +-0.968916965374660650, -0.968929333471716390, -0.968941699146449010, -0.968954062398827200, -0.968966423228820210, -0.968978781636397170, -0.968991137621527110, -0.969003491184179280, +-0.969015842324322920, -0.969028191041926720, -0.969040537336960050, -0.969052881209392040, -0.969065222659191820, -0.969077561686328530, -0.969089898290771410, -0.969102232472489500, +-0.969114564231452040, -0.969126893567628040, -0.969139220480987220, -0.969151544971498020, -0.969163867039129930, -0.969176186683852190, -0.969188503905634050, -0.969200818704444860, +-0.969213131080253310, -0.969225441033028990, -0.969237748562741140, -0.969250053669358790, -0.969262356352851410, -0.969274656613188010, -0.969286954450338080, -0.969299249864270740, +-0.969311542854955350, -0.969323833422361170, -0.969336121566457320, -0.969348407287213050, -0.969360690584597840, -0.969372971458580920, -0.969385249909131550, -0.969397525936219310, +-0.969409799539812990, -0.969422070719882180, -0.969434339476396120, -0.969446605809324290, -0.969458869718635930, -0.969471131204300400, -0.969483390266287050, -0.969495646904565240, +-0.969507901119104450, -0.969520152909873810, -0.969532402276842680, -0.969544649219980630, -0.969556893739256910, -0.969569135834640990, -0.969581375506102460, -0.969593612753610220, +-0.969605847577133970, -0.969618079976643070, -0.969630309952106970, -0.969642537503495160, -0.969654762630776990, -0.969666985333921930, -0.969679205612899330, -0.969691423467679000, +-0.969703638898229860, -0.969715851904521590, -0.969728062486523770, -0.969740270644205760, -0.969752476377537030, -0.969764679686487390, -0.969776880571025850, -0.969789079031122100, +-0.969801275066745630, -0.969813468677865890, -0.969825659864452570, -0.969837848626475150, -0.969850034963902980, -0.969862218876705870, -0.969874400364853060, -0.969886579428314580, +-0.969898756067059330, -0.969910930281057350, -0.969923102070277880, -0.969935271434690720, -0.969947438374265670, -0.969959602888971760, -0.969971764978778790, -0.969983924643656460, +-0.969996081883574330, -0.970008236698501890, -0.970020389088408930, -0.970032539053265030, -0.970044686593039770, -0.970056831707702850, -0.970068974397223950, -0.970081114661572430, +-0.970093252500718210, -0.970105387914630750, -0.970117520903279850, -0.970129651466635210, -0.970141779604666520, -0.970153905317343360, -0.970166028604635300, -0.970178149466512150, +-0.970190267902943710, -0.970202383913899570, -0.970214497499349400, -0.970226608659263130, -0.970238717393610230, -0.970250823702360820, -0.970262927585484050, -0.970275029042950040, +-0.970287128074728500, -0.970299224680789000, -0.970311318861101560, -0.970323410615635980, -0.970335499944361630, -0.970347586847248640, -0.970359671324266590, -0.970371753375385390, +-0.970383833000574740, -0.970395910199804650, -0.970407984973044700, -0.970420057320264710, -0.970432127241434910, -0.970444194736524550, -0.970456259805503650, -0.970468322448342140, +-0.970480382665009910, -0.970492440455476670, -0.970504495819712430, -0.970516548757686890, -0.970528599269369850, -0.970540647354731440, -0.970552693013741360, -0.970564736246369520, +-0.970576777052585830, -0.970588815432360200, -0.970600851385662540, -0.970612884912462780, -0.970624916012731040, -0.970636944686436800, -0.970648970933550180, -0.970660994754041110, +-0.970673016147879490, -0.970685035115035680, -0.970697051655479040, -0.970709065769179700, -0.970721077456107690, -0.970733086716233040, -0.970745093549525650, -0.970757097955955550, +-0.970769099935492760, -0.970781099488107090, -0.970793096613768780, -0.970805091312447850, -0.970817083584114120, -0.970829073428737590, -0.970841060846288300, -0.970853045836736480, +-0.970865028400052180, -0.970877008536205180, -0.970888986245165620, -0.970900961526903530, -0.970912934381389150, -0.970924904808592390, -0.970936872808483290, -0.970948838381032080, +-0.970960801526208780, -0.970972762243983430, -0.970984720534326500, -0.970996676397207440, -0.971008629832596730, -0.971020580840464500, -0.971032529420780670, -0.971044475573515700, +-0.971056419298639620, -0.971068360596122340, -0.971080299465934100, -0.971092235908045160, -0.971104169922425650, -0.971116101509045700, -0.971128030667875450, -0.971139957398885150, +-0.971151881702045030, -0.971163803577325350, -0.971175723024695900, -0.971187640044127280, -0.971199554635589490, -0.971211466799052790, -0.971223376534487430, -0.971235283841863860, +-0.971247188721151790, -0.971259091172321900, -0.971270991195344210, -0.971282888790188980, -0.971294783956826560, -0.971306676695227190, -0.971318567005361120, -0.971330454887198710, +-0.971342340340710320, -0.971354223365865850, -0.971366103962635900, -0.971377982130990580, -0.971389857870900380, -0.971401731182335530, -0.971413602065266500, -0.971425470519663330, +-0.971437336545496470, -0.971449200142736170, -0.971461061311353010, -0.971472920051317130, -0.971484776362598890, -0.971496630245168860, -0.971508481698997170, -0.971520330724054190, +-0.971532177320310720, -0.971544021487736550, -0.971555863226302390, -0.971567702535978460, -0.971579539416735360, -0.971591373868543660, -0.971603205891373170, -0.971615035485194790, +-0.971626862649978770, -0.971638687385695590, -0.971650509692315700, -0.971662329569809580, -0.971674147018147580, -0.971685962037300180, -0.971697774627237940, -0.971709584787931460, +-0.971721392519350860, -0.971733197821466720, -0.971745000694249630, -0.971756801137669930, -0.971768599151698330, -0.971780394736305400, -0.971792187891461270, -0.971803978617136740, +-0.971815766913302180, -0.971827552779928270, -0.971839336216985370, -0.971851117224444280, -0.971862895802275250, -0.971874671950449080, -0.971886445668936450, -0.971898216957707390, +-0.971909985816732940, -0.971921752245983430, -0.971933516245429560, -0.971945277815041810, -0.971957036954791190, -0.971968793664647720, -0.971980547944582330, -0.971992299794565470, +-0.972004049214567960, -0.972015796204560250, -0.972027540764513140, -0.972039282894397120, -0.972051022594182860, -0.972062759863841270, -0.972074494703342620, -0.972086227112657690, +-0.972097957091757170, -0.972109684640611870, -0.972121409759192260, -0.972133132447469350, -0.972144852705413400, -0.972156570532995310, -0.972168285930185780, -0.972179998896955610, +-0.972191709433275380, -0.972203417539115880, -0.972215123214447920, -0.972226826459242080, -0.972238527273469160, -0.972250225657100180, -0.972261921610105380, -0.972273615132455800, +-0.972285306224122130, -0.972296994885075260, -0.972308681115286120, -0.972320364914725070, -0.972332046283363010, -0.972343725221170960, -0.972355401728119520, -0.972367075804179580, +-0.972378747449321960, -0.972390416663517550, -0.972402083446736950, -0.972413747798951290, -0.972425409720131360, -0.972437069210247750, -0.972448726269271480, -0.972460380897173350, +-0.972472033093924270, -0.972483682859495160, -0.972495330193857030, -0.972506975096980360, -0.972518617568836290, -0.972530257609395600, -0.972541895218629330, -0.972553530396508270, +-0.972565163143003450, -0.972576793458085680, -0.972588421341725850, -0.972600046793895330, -0.972611669814564370, -0.972623290403704320, -0.972634908561285980, -0.972646524287280380, +-0.972658137581658530, -0.972669748444391470, -0.972681356875449880, -0.972692962874804780, -0.972704566442427420, -0.972716167578288600, -0.972727766282359350, -0.972739362554610690, +-0.972750956395013630, -0.972762547803539210, -0.972774136780158560, -0.972785723324842370, -0.972797307437561880, -0.972808889118288110, -0.972820468366992210, -0.972832045183645080, +-0.972843619568217970, -0.972855191520681670, -0.972866761041007440, -0.972878328129166300, -0.972889892785129270, -0.972901455008867490, -0.972913014800352190, -0.972924572159554300, +-0.972936127086444950, -0.972947679580995260, -0.972959229643176600, -0.972970777272959660, -0.972982322470315800, -0.972993865235216140, -0.973005405567631820, -0.973016943467534200, +-0.973028478934893970, -0.973040011969682590, -0.973051542571871210, -0.973063070741430950, -0.973074596478332940, -0.973086119782548440, -0.973097640654048690, -0.973109159092804820, +-0.973120675098788080, -0.973132188671969930, -0.973143699812320960, -0.973155208519812850, -0.973166714794416630, -0.973178218636103650, -0.973189720044845160, -0.973201219020612520, +-0.973212715563376740, -0.973224209673109080, -0.973235701349780880, -0.973247190593363510, -0.973258677403828100, -0.973270161781146000, -0.973281643725288470, -0.973293123236226850, +-0.973304600313932620, -0.973316074958376800, -0.973327547169530630, -0.973339016947365690, -0.973350484291853220, -0.973361949202964480, -0.973373411680671040, -0.973384871724943920, +-0.973396329335754600, -0.973407784513074530, -0.973419237256874960, -0.973430687567127250, -0.973442135443802870, -0.973453580886873170, -0.973465023896309510, -0.973476464472083470, +-0.973487902614166070, -0.973499338322528880, -0.973510771597143390, -0.973522202437980930, -0.973533630845012990, -0.973545056818211130, -0.973556480357546490, -0.973567901462990660, +-0.973579320134515090, -0.973590736372091150, -0.973602150175690410, -0.973613561545284220, -0.973624970480844290, -0.973636376982341730, -0.973647781049748360, -0.973659182683035750, +-0.973670581882174920, -0.973681978647137680, -0.973693372977895490, -0.973704764874419810, -0.973716154336682460, -0.973727541364654560, -0.973738925958307800, -0.973750308117613650, +-0.973761687842543800, -0.973773065133069720, -0.973784439989162980, -0.973795812410795160, -0.973807182397937730, -0.973818549950562380, -0.973829915068640920, -0.973841277752144350, +-0.973852638001044710, -0.973863995815313350, -0.973875351194922080, -0.973886704139842460, -0.973898054650046310, -0.973909402725504750, -0.973920748366189690, -0.973932091572072720, +-0.973943432343125530, -0.973954770679319790, -0.973966106580627210, -0.973977440047019250, -0.973988771078467710, -0.974000099674944500, -0.974011425836420750, -0.974022749562868500, +-0.974034070854259300, -0.974045389710565090, -0.974056706131757210, -0.974068020117807910, -0.974079331668688320, -0.974090640784370350, -0.974101947464825810, -0.974113251710026380, +-0.974124553519943870, -0.974135852894549960, -0.974147149833816450, -0.974158444337715030, -0.974169736406217620, -0.974181026039295790, -0.974192313236921350, -0.974203597999066080, +-0.974214880325701920, -0.974226160216800530, -0.974237437672333950, -0.974248712692273530, -0.974259985276591300, -0.974271255425259160, -0.974282523138248810, -0.974293788415532270, +-0.974305051257081220, -0.974316311662867470, -0.974327569632863040, -0.974338825167039620, -0.974350078265369350, -0.974361328927823680, -0.974372577154374750, -0.974383822944994260, +-0.974395066299654330, -0.974406307218326880, -0.974417545700983490, -0.974428781747596170, -0.974440015358136960, -0.974451246532577750, -0.974462475270890360, -0.974473701573046800, +-0.974484925439018990, -0.974496146868778830, -0.974507365862298360, -0.974518582419549580, -0.974529796540504200, -0.974541008225134340, -0.974552217473412030, -0.974563424285309070, +-0.974574628660797580, -0.974585830599849710, -0.974597030102437030, -0.974608227168531900, -0.974619421798106120, -0.974630613991131820, -0.974641803747580910, -0.974652991067425530, +-0.974664175950637700, -0.974675358397189440, -0.974686538407052880, -0.974697715980199940, -0.974708891116602530, -0.974720063816233000, -0.974731234079063370, -0.974742401905065560, +-0.974753567294211920, -0.974764730246474250, -0.974775890761824690, -0.974787048840235480, -0.974798204481678530, -0.974809357686126200, -0.974820508453550390, -0.974831656783923250, +-0.974842802677217120, -0.974853946133404040, -0.974865087152456010, -0.974876225734345180, -0.974887361879043900, -0.974898495586524080, -0.974909626856758080, -0.974920755689718250, +-0.974931882085376290, -0.974943006043704650, -0.974954127564675480, -0.974965246648261010, -0.974976363294433380, -0.974987477503164830, -0.974998589274427620, -0.975009698608193980, +-0.975020805504436040, -0.975031909963126280, -0.975043011984236600, -0.975054111567739360, -0.975065208713606800, -0.975076303421811290, -0.975087395692325170, -0.975098485525120460, +-0.975109572920169420, -0.975120657877444510, -0.975131740396917860, -0.975142820478561930, -0.975153898122348980, -0.975164973328251250, -0.975176046096241090, -0.975187116426290860, +-0.975198184318373020, -0.975209249772459490, -0.975220312788522840, -0.975231373366535430, -0.975242431506469500, -0.975253487208297630, -0.975264540471992180, -0.975275591297525170, +-0.975286639684869170, -0.975297685633996550, -0.975308729144879760, -0.975319770217491170, -0.975330808851803120, -0.975341845047787980, -0.975352878805418320, -0.975363910124666720, +-0.975374939005504980, -0.975385965447906010, -0.975396989451842170, -0.975408011017285690, -0.975419030144209280, -0.975430046832585500, -0.975441061082386480, -0.975452072893584710, +-0.975463082266152750, -0.975474089200063070, -0.975485093695288240, -0.975496095751800630, -0.975507095369572810, -0.975518092548577240, -0.975529087288786620, -0.975540079590173080, +-0.975551069452709420, -0.975562056876367990, -0.975573041861121480, -0.975584024406942360, -0.975595004513803320, -0.975605982181676600, -0.975616957410535000, -0.975627930200350880, +-0.975638900551097030, -0.975649868462745930, -0.975660833935270030, -0.975671796968642150, -0.975682757562834850, -0.975693715717820490, -0.975704671433572200, -0.975715624710061900, +-0.975726575547262610, -0.975737523945146900, -0.975748469903687350, -0.975759413422856770, -0.975770354502627500, -0.975781293142972350, -0.975792229343864000, -0.975803163105275040, +-0.975814094427178260, -0.975825023309546120, -0.975835949752351440, -0.975846873755567000, -0.975857795319165280, -0.975868714443119290, -0.975879631127401280, -0.975890545371984160, +-0.975901457176840850, -0.975912366541943690, -0.975923273467265710, -0.975934177952779810, -0.975945079998458140, -0.975955979604273830, -0.975966876770199670, -0.975977771496208120, +-0.975988663782272340, -0.975999553628364770, -0.976010441034458330, -0.976021326000525820, -0.976032208526540160, -0.976043088612473800, -0.976053966258299770, -0.976064841463990750, +-0.976075714229519660, -0.976086584554859300, -0.976097452439982690, -0.976108317884862190, -0.976119180889470920, -0.976130041453781680, -0.976140899577767400, -0.976151755261400860, +-0.976162608504654860, -0.976173459307502430, -0.976184307669916260, -0.976195153591869590, -0.976205997073334770, -0.976216838114285060, -0.976227676714693240, -0.976238512874532120, +-0.976249346593774820, -0.976260177872394270, -0.976271006710363150, -0.976281833107654480, -0.976292657064241290, -0.976303478580096360, -0.976314297655192730, -0.976325114289503420, +-0.976335928483001330, -0.976346740235659370, -0.976357549547450580, -0.976368356418348180, -0.976379160848324660, -0.976389962837353130, -0.976400762385406850, -0.976411559492458610, +-0.976422354158481550, -0.976433146383448580, -0.976443936167332600, -0.976454723510106870, -0.976465508411744400, -0.976476290872217990, -0.976487070891501000, -0.976497848469566220, +-0.976508623606386910, -0.976519396301935960, -0.976530166556186740, -0.976540934369111930, -0.976551699740684790, -0.976562462670878430, -0.976573223159665880, -0.976583981207020280, +-0.976594736812914870, -0.976605489977322440, -0.976616240700216350, -0.976626988981569630, -0.976637734821355410, -0.976648478219546810, -0.976659219176117090, -0.976669957691039370, +-0.976680693764286680, -0.976691427395832480, -0.976702158585649460, -0.976712887333711090, -0.976723613639990500, -0.976734337504460930, -0.976745058927095400, -0.976755777907867500, +-0.976766494446749900, -0.976777208543716080, -0.976787920198739280, -0.976798629411792740, -0.976809336182849490, -0.976820040511882980, -0.976830742398866360, -0.976841441843772860, +-0.976852138846575960, -0.976862833407248550, -0.976873525525764010, -0.976884215202095670, -0.976894902436216790, -0.976905587228100720, -0.976916269577720820, -0.976926949485049990, +-0.976937626950061920, -0.976948301972729640, -0.976958974553026720, -0.976969644690926290, -0.976980312386401820, -0.976990977639426550, -0.977001640449973730, -0.977012300818016930, +-0.977022958743529510, -0.977033614226484600, -0.977044267266855560, -0.977054917864615850, -0.977065566019738930, -0.977076211732198160, -0.977086855001966790, -0.977097495829018170, +-0.977108134213325870, -0.977118770154863260, -0.977129403653603680, -0.977140034709520710, -0.977150663322587490, -0.977161289492777700, -0.977171913220064690, -0.977182534504422050, +-0.977193153345822910, -0.977203769744240840, -0.977214383699649410, -0.977224995212022000, -0.977235604281332270, -0.977246210907553370, -0.977256815090658870, -0.977267416830622460, +-0.977278016127417380, -0.977288612981017320, -0.977299207391395750, -0.977309799358526130, -0.977320388882382040, -0.977330975962936940, -0.977341560600164640, -0.977352142794038260, +-0.977362722544531380, -0.977373299851617800, -0.977383874715270990, -0.977394447135464530, -0.977405017112172090, -0.977415584645366930, -0.977426149735022730, -0.977436712381113180, +-0.977447272583611970, -0.977457830342492450, -0.977468385657728420, -0.977478938529293460, -0.977489488957161030, -0.977500036941305160, -0.977510582481698980, -0.977521125578316390, +-0.977531666231130970, -0.977542204440116300, -0.977552740205246180, -0.977563273526494410, -0.977573804403834230, -0.977584332837239560, -0.977594858826684070, -0.977605382372141450, +-0.977615903473585400, -0.977626422130989490, -0.977636938344327630, -0.977647452113573400, -0.977657963438700480, -0.977668472319682900, -0.977678978756493900, -0.977689482749107500, +-0.977699984297497380, -0.977710483401637240, -0.977720980061501210, -0.977731474277062420, -0.977741966048295000, -0.977752455375172640, -0.977762942257669240, -0.977773426695758400, +-0.977783908689414010, -0.977794388238609760, -0.977804865343319670, -0.977815340003517330, -0.977825812219176860, -0.977836281990271730, -0.977846749316775840, -0.977857214198663010, +-0.977867676635907230, -0.977878136628482440, -0.977888594176362090, -0.977899049279520320, -0.977909501937930910, -0.977919952151567680, -0.977930399920404650, -0.977940845244415600, +-0.977951288123574350, -0.977961728557855010, -0.977972166547231290, -0.977982602091677310, -0.977993035191166650, -0.978003465845673440, -0.978013894055171580, -0.978024319819634890, +-0.978034743139037490, -0.978045164013353400, -0.978055582442556190, -0.978065998426620010, -0.978076411965518870, -0.978086823059226670, -0.978097231707717450, -0.978107637910965220, +-0.978118041668943780, -0.978128442981627270, -0.978138841848989800, -0.978149238271005080, -0.978159632247647350, -0.978170023778890400, -0.978180412864708470, -0.978190799505075480, +-0.978201183699965670, -0.978211565449352730, -0.978221944753210890, -0.978232321611514190, -0.978242696024236640, -0.978253067991352370, -0.978263437512835400, -0.978273804588659870, +-0.978284169218799900, -0.978294531403229640, -0.978304891141922760, -0.978315248434853850, -0.978325603281996690, -0.978335955683325540, -0.978346305638814530, -0.978356653148437890, +-0.978366998212169440, -0.978377340829983510, -0.978387681001854250, -0.978398018727755780, -0.978408354007662240, -0.978418686841547870, -0.978429017229386800, -0.978439345171153050, +-0.978449670666821090, -0.978459993716365050, -0.978470314319758840, -0.978480632476976920, -0.978490948187993310, -0.978501261452782380, -0.978511572271318570, -0.978521880643575480, +-0.978532186569527780, -0.978542490049149620, -0.978552791082415220, -0.978563089669298840, -0.978573385809774820, -0.978583679503817190, -0.978593970751400420, -0.978604259552498750, +-0.978614545907086630, -0.978624829815137880, -0.978635111276627170, -0.978645390291528640, -0.978655666859816530, -0.978665940981465420, -0.978676212656449550, -0.978686481884742940, +-0.978696748666320170, -0.978707013001155480, -0.978717274889223330, -0.978727534330497970, -0.978737791324953750, -0.978748045872565030, -0.978758297973306270, -0.978768547627151930, +-0.978778794834076040, -0.978789039594053060, -0.978799281907057670, -0.978809521773063910, -0.978819759192046450, -0.978829994163979640, -0.978840226688837860, -0.978850456766595320, +-0.978860684397226730, -0.978870909580706440, -0.978881132317008910, -0.978891352606108490, -0.978901570447979650, -0.978911785842596970, -0.978921998789935020, -0.978932209289967830, +-0.978942417342670070, -0.978952622948016330, -0.978962826105981070, -0.978973026816538750, -0.978983225079663950, -0.978993420895331030, -0.979003614263514450, -0.979013805184188900, +-0.979023993657328730, -0.979034179682908730, -0.979044363260903160, -0.979054544391286700, -0.979064723074033920, -0.979074899309119400, -0.979085073096517710, -0.979095244436203220, +-0.979105413328150490, -0.979115579772334320, -0.979125743768729300, -0.979135905317309980, -0.979146064418050740, -0.979156221070926260, -0.979166375275911330, -0.979176527032980410, +-0.979186676342108210, -0.979196823203269400, -0.979206967616438440, -0.979217109581590030, -0.979227249098698850, -0.979237386167739810, -0.979247520788687040, -0.979257652961515570, +-0.979267782686199850, -0.979277909962714690, -0.979288034791034880, -0.979298157171135000, -0.979308277102989620, -0.979318394586573550, -0.979328509621861460, -0.979338622208828170, +-0.979348732347448350, -0.979358840037696580, -0.979368945279547760, -0.979379048072976600, -0.979389148417957990, -0.979399246314466290, -0.979409341762476520, -0.979419434761963360, +-0.979429525312901620, -0.979439613415266090, -0.979449699069031790, -0.979459782274172960, -0.979469863030664630, -0.979479941338481710, -0.979490017197598980, -0.979500090607991150, +-0.979510161569633110, -0.979520230082499670, -0.979530296146565620, -0.979540359761805980, -0.979550420928195330, -0.979560479645708580, -0.979570535914320750, -0.979580589734006410, +-0.979590641104740700, -0.979600690026498520, -0.979610736499254450, -0.979620780522983630, -0.979630822097660730, -0.979640861223260880, -0.979650897899758790, -0.979660932127129460, +-0.979670963905347910, -0.979680993234388840, -0.979691020114227260, -0.979701044544838420, -0.979711066526196770, -0.979721086058277350, -0.979731103141055270, -0.979741117774505450, +-0.979751129958603030, -0.979761139693322680, -0.979771146978639320, -0.979781151814528180, -0.979791154200964190, -0.979801154137922240, -0.979811151625377460, -0.979821146663304780, +-0.979831139251679200, -0.979841129390475850, -0.979851117079669760, -0.979861102319235730, -0.979871085109149000, -0.979881065449384470, -0.979891043339917390, -0.979901018780722670, +-0.979910991771775540, -0.979920962313050700, -0.979930930404523610, -0.979940896046169070, -0.979950859237962320, -0.979960819979878380, -0.979970778271892500, -0.979980734113979570, +-0.979990687506114840, -0.980000638448273560, -0.980010586940430530, -0.980020532982561090, -0.980030476574640260, -0.980040417716643190, -0.980050356408545100, -0.980060292650321350, +-0.980070226441946630, -0.980080157783396410, -0.980090086674645810, -0.980100013115669850, -0.980109937106444010, -0.980119858646943290, -0.980129777737142830, -0.980139694377018090, +-0.980149608566544210, -0.980159520305696090, -0.980169429594449190, -0.980179336432778770, -0.980189240820659950, -0.980199142758068080, -0.980209042244978400, -0.980218939281366050, +-0.980228833867206380, -0.980238726002474530, -0.980248615687145940, -0.980258502921195760, -0.980268387704599450, -0.980278270037332030, -0.980288149919368970, -0.980298027350685610, +-0.980307902331257200, -0.980317774861058980, -0.980327644940066300, -0.980337512568254520, -0.980347377745598990, -0.980357240472075060, -0.980367100747657980, -0.980376958572323100, +-0.980386813946045880, -0.980396666868801560, -0.980406517340565610, -0.980416365361313270, -0.980426210931020110, -0.980436054049661390, -0.980445894717212550, -0.980455732933649180, +-0.980465568698946300, -0.980475402013079480, -0.980485232876024180, -0.980495061287755760, -0.980504887248249690, -0.980514710757481530, -0.980524531815426540, -0.980534350422060160, +-0.980544166577357880, -0.980553980281295150, -0.980563791533847540, -0.980573600334990410, -0.980583406684699340, -0.980593210582949680, -0.980603012029717220, -0.980612811024977100, +-0.980622607568704900, -0.980632401660876170, -0.980642193301466400, -0.980651982490451160, -0.980661769227806230, -0.980671553513506660, -0.980681335347528100, -0.980691114729846270, +-0.980700891660436720, -0.980710666139274930, -0.980720438166336360, -0.980730207741596800, -0.980739974865031730, -0.980749739536616820, -0.980759501756327420, -0.980769261524139350, +-0.980779018840028050, -0.980788773703969220, -0.980798526115938430, -0.980808276075911480, -0.980818023583863720, -0.980827768639770840, -0.980837511243608630, -0.980847251395352560, +-0.980856989094978430, -0.980866724342461800, -0.980876457137778380, -0.980886187480903730, -0.980895915371813640, -0.980905640810484040, -0.980915363796890040, -0.980925084331007670, +-0.980934802412812610, -0.980944518042280560, -0.980954231219387410, -0.980963941944108410, -0.980973650216419580, -0.980983356036296720, -0.980993059403715400, -0.981002760318651410, +-0.981012458781080570, -0.981022154790978540, -0.981031848348321130, -0.981041539453084140, -0.981051228105243480, -0.981060914304774490, -0.981070598051653310, -0.981080279345855620, +-0.981089958187357110, -0.981099634576133920, -0.981109308512161600, -0.981118979995415970, -0.981128649025872820, -0.981138315603508170, -0.981147979728297590, -0.981157641400217110, +-0.981167300619242510, -0.981176957385349710, -0.981186611698514510, -0.981196263558712920, -0.981205912965920520, -0.981215559920113330, -0.981225204421267260, -0.981234846469358210, +-0.981244486064361990, -0.981254123206254710, -0.981263757895011970, -0.981273390130609880, -0.981283019913024250, -0.981292647242231090, -0.981302272118206310, -0.981311894540925820, +-0.981321514510365640, -0.981331132026501680, -0.981340747089310070, -0.981350359698766380, -0.981359969854846860, -0.981369577557527300, -0.981379182806783930, -0.981388785602592460, +-0.981398385944929340, -0.981407983833770040, -0.981417579269090680, -0.981427172250867510, -0.981436762779076320, -0.981446350853693250, -0.981455936474694310, -0.981465519642055530, +-0.981475100355753030, -0.981484678615762610, -0.981494254422060840, -0.981503827774623080, -0.981513398673425910, -0.981522967118445220, -0.981532533109657050, -0.981542096647037730, +-0.981551657730562970, -0.981561216360209210, -0.981570772535952260, -0.981580326257768480, -0.981589877525633760, -0.981599426339524460, -0.981608972699416490, -0.981618516605286210, +-0.981628058057109620, -0.981637597054862980, -0.981647133598522180, -0.981656667688063590, -0.981666199323463330, -0.981675728504697530, -0.981685255231742440, -0.981694779504574400, +-0.981704301323169220, -0.981713820687503350, -0.981723337597552810, -0.981732852053294080, -0.981742364054703050, -0.981751873601756200, -0.981761380694429750, -0.981770885332699740, +-0.981780387516542730, -0.981789887245934520, -0.981799384520851580, -0.981808879341270260, -0.981818371707166680, -0.981827861618517210, -0.981837349075298290, -0.981846834077485740, +-0.981856316625056120, -0.981865796717985790, -0.981875274356250880, -0.981884749539827850, -0.981894222268692940, -0.981903692542822500, -0.981913160362192780, -0.981922625726780240, +-0.981932088636561120, -0.981941549091511660, -0.981951007091608430, -0.981960462636827680, -0.981969915727145760, -0.981979366362539130, -0.981988814542984030, -0.981998260268456820, +-0.982007703538933960, -0.982017144354391910, -0.982026582714806920, -0.982036018620155550, -0.982045452070414050, -0.982054883065558990, -0.982064311605566620, -0.982073737690413730, +-0.982083161320076340, -0.982092582494531020, -0.982102001213754240, -0.982111417477722460, -0.982120831286412370, -0.982130242639799870, -0.982139651537861870, -0.982149057980574720, +-0.982158461967915010, -0.982167863499859070, -0.982177262576383490, -0.982186659197464730, -0.982196053363079360, -0.982205445073203840, -0.982214834327814870, -0.982224221126888560, +-0.982233605470401840, -0.982242987358331040, -0.982252366790652750, -0.982261743767343650, -0.982271118288380210, -0.982280490353738880, -0.982289859963396350, -0.982299227117329200, +-0.982308591815513890, -0.982317954057927100, -0.982327313844545520, -0.982336671175345620, -0.982346026050303970, -0.982355378469397470, -0.982364728432602360, -0.982374075939895450, +-0.982383420991253420, -0.982392763586652730, -0.982402103726070170, -0.982411441409482440, -0.982420776636866000, -0.982430109408197640, -0.982439439723454040, -0.982448767582611790, +-0.982458092985647570, -0.982467415932538170, -0.982476736423260280, -0.982486054457790470, -0.982495370036105650, -0.982504683158182400, -0.982513993823997290, -0.982523302033527330, +-0.982532607786749000, -0.982541911083639200, -0.982551211924174830, -0.982560510308332140, -0.982569806236088250, -0.982579099707419860, -0.982588390722303750, -0.982597679280716620, +-0.982606965382635260, -0.982616249028036570, -0.982625530216897140, -0.982634808949193970, -0.982644085224903980, -0.982653359044003530, -0.982662630406469730, -0.982671899312279270, +-0.982681165761409180, -0.982690429753836250, -0.982699691289537160, -0.982708950368488820, -0.982718206990668030, -0.982727461156051810, -0.982736712864616950, -0.982745962116340240, +-0.982755208911198610, -0.982764453249169060, -0.982773695130228280, -0.982782934554353500, -0.982792171521521210, -0.982801406031708400, -0.982810638084892220, -0.982819867681049340, +-0.982829094820156790, -0.982838319502191690, -0.982847541727130620, -0.982856761494950710, -0.982865978805628980, -0.982875193659142220, -0.982884406055467450, -0.982893615994581690, +-0.982902823476461850, -0.982912028501085060, -0.982921231068428320, -0.982930431178468230, -0.982939628831182240, -0.982948824026547040, -0.982958016764539870, -0.982967207045137630, +-0.982976394868317450, -0.982985580234056240, -0.982994763142331030, -0.983003943593118930, -0.983013121586396980, -0.983022297122142170, -0.983031470200331660, -0.983040640820942450, +-0.983049808983951670, -0.983058974689336450, -0.983068137937073700, -0.983077298727140670, -0.983086457059514360, -0.983095612934171800, -0.983104766351090340, -0.983113917310247000, +-0.983123065811618790, -0.983132211855182960, -0.983141355440916520, -0.983150496568796720, -0.983159635238800680, -0.983168771450905530, -0.983177905205088410, -0.983187036501326660, +-0.983196165339597190, -0.983205291719877580, -0.983214415642144510, -0.983223537106375440, -0.983232656112547510, -0.983241772660637840, -0.983250886750624000, -0.983259998382482790, +-0.983269107556191570, -0.983278214271727570, -0.983287318529068030, -0.983296420328190200, -0.983305519669071430, -0.983314616551688720, -0.983323710976019450, -0.983332802942041060, +-0.983341892449730690, -0.983350979499065470, -0.983360064090022750, -0.983369146222579980, -0.983378225896714310, -0.983387303112403190, -0.983396377869623640, -0.983405450168353120, +-0.983414520008569100, -0.983423587390248710, -0.983432652313369290, -0.983441714777908320, -0.983450774783843130, -0.983459832331150860, -0.983468887419809090, -0.983477940049795270, +-0.983486990221086430, -0.983496037933660030, -0.983505083187493630, -0.983514125982564490, -0.983523166318850060, -0.983532204196327810, -0.983541239614974970, -0.983550272574769010, +-0.983559303075687290, -0.983568331117707470, -0.983577356700806700, -0.983586379824962550, -0.983595400490152480, -0.983604418696353950, -0.983613434443544430, -0.983622447731701270, +-0.983631458560801920, -0.983640466930823960, -0.983649472841744750, -0.983658476293541970, -0.983667477286193080, -0.983676475819675430, -0.983685471893966490, -0.983694465509043940, +-0.983703456664885230, -0.983712445361467850, -0.983721431598769350, -0.983730415376767310, -0.983739396695439190, -0.983748375554762690, -0.983757351954715140, -0.983766325895274240, +-0.983775297376417560, -0.983784266398122550, -0.983793232960366910, -0.983802197063128330, -0.983811158706384140, -0.983820117890112030, -0.983829074614289590, -0.983838028878894600, +-0.983846980683904420, -0.983855930029296720, -0.983864876915049310, -0.983873821341139650, -0.983882763307545540, -0.983891702814244540, -0.983900639861214230, -0.983909574448432300, +-0.983918506575876430, -0.983927436243524300, -0.983936363451353710, -0.983945288199342020, -0.983954210487467230, -0.983963130315706810, -0.983972047684038560, -0.983980962592440280, +-0.983989875040889530, -0.983998785029364110, -0.984007692557841710, -0.984016597626300120, -0.984025500234717130, -0.984034400383070220, -0.984043298071337390, -0.984052193299496230, +-0.984061086067524630, -0.984069976375400390, -0.984078864223101310, -0.984087749610604860, -0.984096632537889040, -0.984105513004931760, -0.984114391011710610, -0.984123266558203480, +-0.984132139644388170, -0.984141010270242590, -0.984149878435744420, -0.984158744140871680, -0.984167607385601940, -0.984176468169913220, -0.984185326493783320, -0.984194182357190140, +-0.984203035760111480, -0.984211886702525350, -0.984220735184409330, -0.984229581205741550, -0.984238424766499810, -0.984247265866661890, -0.984256104506205930, -0.984264940685109720, +-0.984273774403351060, -0.984282605660908080, -0.984291434457758680, -0.984300260793880550, -0.984309084669251710, -0.984317906083850170, -0.984326725037653950, -0.984335541530640850, +-0.984344355562789100, -0.984353167134076280, -0.984361976244480520, -0.984370782893979830, -0.984379587082552240, -0.984388388810175540, -0.984397188076827970, -0.984405984882487430, +-0.984414779227131940, -0.984423571110739530, -0.984432360533288310, -0.984441147494755970, -0.984449931995120870, -0.984458714034360920, -0.984467493612454110, -0.984476270729378710, +-0.984485045385112610, -0.984493817579633830, -0.984502587312920510, -0.984511354584950650, -0.984520119395702500, -0.984528881745153960, -0.984537641633283280, -0.984546399060068580, +-0.984555154025487770, -0.984563906529519190, -0.984572656572140770, -0.984581404153330730, -0.984590149273067090, -0.984598891931328210, -0.984607632128091990, -0.984616369863336890, +-0.984625105137040710, -0.984633837949181690, -0.984642568299738170, -0.984651296188688190, -0.984660021616009960, -0.984668744581681740, -0.984677465085681550, -0.984686183127987840, +-0.984694898708578740, -0.984703611827432160, -0.984712322484526670, -0.984721030679840400, -0.984729736413351490, -0.984738439685038270, -0.984747140494878990, -0.984755838842851780, +-0.984764534728935100, -0.984773228153106970, -0.984781919115345740, -0.984790607615629750, -0.984799293653937260, -0.984807977230246490, -0.984816658344535800, -0.984825336996783650, +-0.984834013186967950, -0.984842686915067270, -0.984851358181059840, -0.984860026984924030, -0.984868693326638070, -0.984877357206180640, -0.984886018623529650, -0.984894677578663560, +-0.984903334071560830, -0.984911988102199710, -0.984920639670558650, -0.984929288776616010, -0.984937935420350130, -0.984946579601739480, -0.984955221320762300, -0.984963860577397270, +-0.984972497371622400, -0.984981131703416280, -0.984989763572757360, -0.984998392979623990, -0.985007019923994750, -0.985015644405847880, -0.985024266425161940, -0.985032885981915300, +-0.985041503076086400, -0.985050117707653830, -0.985058729876595930, -0.985067339582891170, -0.985075946826518000, -0.985084551607455120, -0.985093153925680860, -0.985101753781173710, +-0.985110351173912100, -0.985118946103874630, -0.985127538571039740, -0.985136128575386020, -0.985144716116892250, -0.985153301195536350, -0.985161883811297320, -0.985170463964153530, +-0.985179041654083650, -0.985187616881066150, -0.985196189645079600, -0.985204759946102570, -0.985213327784113630, -0.985221893159091480, -0.985230456071014450, -0.985239016519861340, +-0.985247574505610620, -0.985256130028241080, -0.985264683087731190, -0.985273233684059610, -0.985281781817204940, -0.985290327487145730, -0.985298870693860800, -0.985307411437328580, +-0.985315949717527890, -0.985324485534437300, -0.985333018888035480, -0.985341549778301130, -0.985350078205213140, -0.985358604168749760, -0.985367127668889790, -0.985375648705612120, +-0.985384167278895220, -0.985392683388717990, -0.985401197035059130, -0.985409708217897200, -0.985418216937210880, -0.985426723192979080, -0.985435226985180490, -0.985443728313793900, +-0.985452227178797880, -0.985460723580171340, -0.985469217517892960, -0.985477708991941650, -0.985486198002296090, -0.985494684548934960, -0.985503168631837070, -0.985511650250981310, +-0.985520129406346370, -0.985528606097911260, -0.985537080325654460, -0.985545552089555080, -0.985554021389591690, -0.985562488225743330, -0.985570952597988660, -0.985579414506306710, +-0.985587873950676150, -0.985596330931075900, -0.985604785447484870, -0.985613237499882060, -0.985621687088245930, -0.985630134212555630, -0.985638578872790050, -0.985647021068927880, +-0.985655460800948240, -0.985663898068830150, -0.985672332872552070, -0.985680765212093250, -0.985689195087432470, -0.985697622498548640, -0.985706047445420790, -0.985714469928027910, +-0.985722889946348710, -0.985731307500362420, -0.985739722590047940, -0.985748135215384070, -0.985756545376349710, -0.985764953072924110, -0.985773358305086170, -0.985781761072814790, +-0.985790161376089100, -0.985798559214887900, -0.985806954589190320, -0.985815347498975260, -0.985823737944221960, -0.985832125924909210, -0.985840511441016250, -0.985848894492521890, +-0.985857275079405460, -0.985865653201645880, -0.985874028859222040, -0.985882402052113080, -0.985890772780298130, -0.985899141043756310, -0.985907506842466640, -0.985915870176408250, +-0.985924231045560150, -0.985932589449901360, -0.985940945389411240, -0.985949298864068680, -0.985957649873852810, -0.985965998418742880, -0.985974344498718010, -0.985982688113757220, +-0.985991029263839640, -0.985999367948944720, -0.986007704169051260, -0.986016037924138500, -0.986024369214185680, -0.986032698039171820, -0.986041024399076480, -0.986049348293878360, +-0.986057669723556910, -0.986065988688091370, -0.986074305187460750, -0.986082619221644310, -0.986090930790621490, -0.986099239894371200, -0.986107546532872910, -0.986115850706105630, +-0.986124152414049050, -0.986132451656681840, -0.986140748433983470, -0.986149042745933290, -0.986157334592510430, -0.986165623973694340, -0.986173910889464270, -0.986182195339799230, +-0.986190477324678790, -0.986198756844082090, -0.986207033897988580, -0.986215308486377400, -0.986223580609227990, -0.986231850266519720, -0.986240117458231700, -0.986248382184343520, +-0.986256644444834300, -0.986264904239683490, -0.986273161568870350, -0.986281416432374320, -0.986289668830174770, -0.986297918762251260, -0.986306166228582690, -0.986314411229148760, +-0.986322653763928800, -0.986330893832902180, -0.986339131436048460, -0.986347366573346760, -0.986355599244776670, -0.986363829450317640, -0.986372057189949140, -0.986380282463650280, +-0.986388505271400870, -0.986396725613180040, -0.986404943488967570, -0.986413158898742590, -0.986421371842484910, -0.986429582320173640, -0.986437790331788470, -0.986445995877308750, +-0.986454198956714160, -0.986462399569983940, -0.986470597717097770, -0.986478793398035130, -0.986486986612775450, -0.986495177361298330, -0.986503365643583430, -0.986511551459610000, +-0.986519734809357620, -0.986527915692805960, -0.986536094109934480, -0.986544270060722980, -0.986552443545150590, -0.986560614563197100, -0.986568783114842080, -0.986576949200065110, +-0.986585112818845760, -0.986593273971163590, -0.986601432656998290, -0.986609588876329440, -0.986617742629136480, -0.986625893915399450, -0.986634042735097470, -0.986642189088210440, +-0.986650332974717830, -0.986658474394599530, -0.986666613347834900, -0.986674749834403950, -0.986682883854286040, -0.986691015407460850, -0.986699144493908160, -0.986707271113607560, +-0.986715395266538840, -0.986723516952681570, -0.986731636172015540, -0.986739752924520430, -0.986747867210176040, -0.986755979028961950, -0.986764088380857830, -0.986772195265843480, +-0.986780299683898690, -0.986788401635003030, -0.986796501119136640, -0.986804598136278850, -0.986812692686409480, -0.986820784769508410, -0.986828874385555440, -0.986836961534530270, +-0.986845046216412670, -0.986853128431182450, -0.986861208178819390, -0.986869285459303410, -0.986877360272614190, -0.986885432618731520, -0.986893502497635300, -0.986901569909305220, +-0.986909634853721300, -0.986917697330863430, -0.986925757340711200, -0.986933814883244500, -0.986941869958443350, -0.986949922566287440, -0.986957972706756780, -0.986966020379831170, +-0.986974065585490500, -0.986982108323714690, -0.986990148594483640, -0.986998186397777370, -0.987006221733575440, -0.987014254601857880, -0.987022285002604800, -0.987030312935796020, +-0.987038338401411530, -0.987046361399431030, -0.987054381929834750, -0.987062399992602370, -0.987070415587714130, -0.987078428715149720, -0.987086439374889270, -0.987094447566912780, +-0.987102453291200170, -0.987110456547731440, -0.987118457336486620, -0.987126455657445610, -0.987134451510588430, -0.987142444895895090, -0.987150435813345610, -0.987158424262920110, +-0.987166410244598720, -0.987174393758361020, -0.987182374804187470, -0.987190353382057960, -0.987198329491952520, -0.987206303133851270, -0.987214274307734340, -0.987222243013581640, +-0.987230209251373390, -0.987238173021089740, -0.987246134322710470, -0.987254093156215930, -0.987262049521586140, -0.987270003418801220, -0.987277954847841200, -0.987285903808686530, +-0.987293850301317000, -0.987301794325712740, -0.987309735881854110, -0.987317674969721120, -0.987325611589293880, -0.987333545740552540, -0.987341477423477440, -0.987349406638048710, +-0.987357333384246470, -0.987365257662050850, -0.987373179471442100, -0.987381098812400330, -0.987389015684905780, -0.987396930088938810, -0.987404842024479650, -0.987412751491508090, +-0.987420658490004820, -0.987428563019949860, -0.987436465081323430, -0.987444364674105900, -0.987452261798277390, -0.987460156453818350, -0.987468048640708810, -0.987475938358929220, +-0.987483825608459820, -0.987491710389280850, -0.987499592701372440, -0.987507472544715160, -0.987515349919289240, -0.987523224825075040, -0.987531097262052570, -0.987538967230202400, +-0.987546834729504890, -0.987554699759940260, -0.987562562321488870, -0.987570422414130960, -0.987578280037847090, -0.987586135192617620, -0.987593987878422670, -0.987601838095242930, +-0.987609685843058530, -0.987617531121849800, -0.987625373931597330, -0.987633214272281350, -0.987641052143882310, -0.987648887546380920, -0.987656720479757060, -0.987664550943991420, +-0.987672378939064450, -0.987680204464956520, -0.987688027521648080, -0.987695848109119480, -0.987703666227351400, -0.987711481876324070, -0.987719295056018190, -0.987727105766413870, +-0.987734914007491920, -0.987742719779232560, -0.987750523081616480, -0.987758323914624040, -0.987766122278236010, -0.987773918172432430, -0.987781711597194190, -0.987789502552501530, +-0.987797291038335250, -0.987805077054675570, -0.987812860601503310, -0.987820641678798910, -0.987828420286542940, -0.987836196424715980, -0.987843970093298380, -0.987851741292270940, +-0.987859510021614100, -0.987867276281308440, -0.987875040071334640, -0.987882801391673390, -0.987890560242304930, -0.987898316623210150, -0.987906070534369520, -0.987913821975763720, +-0.987921570947373430, -0.987929317449179110, -0.987937061481161560, -0.987944803043301350, -0.987952542135579150, -0.987960278757975760, -0.987968012910471430, -0.987975744593047160, +-0.987983473805683520, -0.987991200548361200, -0.987998924821061000, -0.988006646623763360, -0.988014365956449090, -0.988022082819098870, -0.988029797211693480, -0.988037509134213620, +-0.988045218586639960, -0.988052925568953190, -0.988060630081134210, -0.988068332123163580, -0.988076031695022340, -0.988083728796690820, -0.988091423428150040, -0.988099115589380680, +-0.988106805280363430, -0.988114492501079410, -0.988122177251508970, -0.988129859531633130, -0.988137539341432670, -0.988145216680888280, -0.988152891549980870, -0.988160563948691340, +-0.988168233877000260, -0.988175901334888640, -0.988183566322337280, -0.988191228839327200, -0.988198888885838840, -0.988206546461853240, -0.988214201567351290, -0.988221854202313900, +-0.988229504366721740, -0.988237152060556070, -0.988244797283797330, -0.988252440036426650, -0.988260080318424830, -0.988267718129772880, -0.988275353470451480, -0.988282986340441870, +-0.988290616739724630, -0.988298244668280980, -0.988305870126091830, -0.988313493113137880, -0.988321113629400120, -0.988328731674859570, -0.988336347249497260, -0.988343960353294080, +-0.988351570986231160, -0.988359179148289080, -0.988366784839449180, -0.988374388059692240, -0.988381988808999300, -0.988389587087351470, -0.988397182894729660, -0.988404776231114780, +-0.988412367096488050, -0.988419955490830390, -0.988427541414123030, -0.988435124866346660, -0.988442705847482390, -0.988450284357511480, -0.988457860396414810, -0.988465433964173630, +-0.988473005060768740, -0.988480573686181250, -0.988488139840392410, -0.988495703523383230, -0.988503264735134720, -0.988510823475628130, -0.988518379744844470, -0.988525933542764750, +-0.988533484869370320, -0.988541033724642300, -0.988548580108561500, -0.988556124021109260, -0.988563665462266820, -0.988571204432015070, -0.988578740930335490, -0.988586274957208970, +-0.988593806512616750, -0.988601335596539950, -0.988608862208959940, -0.988616386349857600, -0.988623908019214400, -0.988631427217011470, -0.988638943943229930, -0.988646458197851020, +-0.988653969980856080, -0.988661479292226140, -0.988668986131942430, -0.988676490499986290, -0.988683992396338970, -0.988691491820981590, -0.988698988773895620, -0.988706483255062160, +-0.988713975264462360, -0.988721464802077680, -0.988728951867889340, -0.988736436461878590, -0.988743918584026770, -0.988751398234315130, -0.988758875412725000, -0.988766350119237860, +-0.988773822353834710, -0.988781292116497010, -0.988788759407206010, -0.988796224225943150, -0.988803686572689690, -0.988811146447427180, -0.988818603850136760, -0.988826058780799770, +-0.988833511239397560, -0.988840961225911590, -0.988848408740323310, -0.988855853782613980, -0.988863296352764930, -0.988870736450757740, -0.988878174076573750, -0.988885609230194310, +-0.988893041911600770, -0.988900472120774590, -0.988907899857697340, -0.988915325122350250, -0.988922747914715020, -0.988930168234772760, -0.988937586082505040, -0.988945001457893440, +-0.988952414360919300, -0.988959824791564190, -0.988967232749809470, -0.988974638235636580, -0.988982041249027220, -0.988989441789962730, -0.988996839858424680, -0.989004235454394530, +-0.989011628577853740, -0.989019019228783880, -0.989026407407166410, -0.989033793112983120, -0.989041176346215250, -0.989048557106844360, -0.989055935394852150, -0.989063311210219950, +-0.989070684552929680, -0.989078055422962570, -0.989085423820300400, -0.989092789744924540, -0.989100153196816880, -0.989107514175958880, -0.989114872682331890, -0.989122228715917820, +-0.989129582276698120, -0.989136933364654580, -0.989144281979768560, -0.989151628122022060, -0.989158971791396340, -0.989166312987873160, -0.989173651711434230, -0.989180987962061110, +-0.989188321739735590, -0.989195653044439240, -0.989202981876153850, -0.989210308234860890, -0.989217632120542260, -0.989224953533179520, -0.989232272472754360, -0.989239588939248570, +-0.989246902932643720, -0.989254214452921610, -0.989261523500064130, -0.989268830074052750, -0.989276134174869260, -0.989283435802495450, -0.989290734956913000, -0.989298031638103810, +-0.989305325846049470, -0.989312617580731750, -0.989319906842132560, -0.989327193630233800, -0.989334477945016830, -0.989341759786463770, -0.989349039154556190, -0.989356316049276100, +-0.989363590470605180, -0.989370862418525340, -0.989378131893018380, -0.989385398894065960, -0.989392663421650110, -0.989399925475752510, -0.989407185056355170, -0.989414442163439880, +-0.989421696796988440, -0.989428948956982860, -0.989436198643404820, -0.989443445856236450, -0.989450690595459310, -0.989457932861055430, -0.989465172653006710, -0.989472409971295150, +-0.989479644815902560, -0.989486877186810830, -0.989494107084001870, -0.989501334507457700, -0.989508559457160100, -0.989515781933091090, -0.989523001935232680, -0.989530219463566780, +-0.989537434518075410, -0.989544647098740350, -0.989551857205543730, -0.989559064838467450, -0.989566269997493530, -0.989573472682603870, -0.989580672893780490, -0.989587870631005510, +-0.989595065894260940, -0.989602258683528580, -0.989609448998790660, -0.989616636840028980, -0.989623822207225780, -0.989631005100363060, -0.989638185519422840, -0.989645363464387030, +-0.989652538935237860, -0.989659711931957560, -0.989666882454527830, -0.989674050502930780, -0.989681216077148650, -0.989688379177163570, -0.989695539802957440, -0.989702697954512710, +-0.989709853631810970, -0.989717006834834660, -0.989724157563565800, -0.989731305817986630, -0.989738451598079160, -0.989745594903825520, -0.989752735735207940, -0.989759874092208450, +-0.989767009974809490, -0.989774143382992850, -0.989781274316740790, -0.989788402776035640, -0.989795528760859410, -0.989802652271194350, -0.989809773307022800, -0.989816891868326780, +-0.989824007955088400, -0.989831121567290140, -0.989838232704914000, -0.989845341367942220, -0.989852447556357150, -0.989859551270141020, -0.989866652509275970, -0.989873751273744220, +-0.989880847563528230, -0.989887941378610030, -0.989895032718972060, -0.989902121584596450, -0.989909207975465440, -0.989916291891561610, -0.989923373332866950, -0.989930452299363830, +-0.989937528791034580, -0.989944602807861560, -0.989951674349827000, -0.989958743416913260, -0.989965810009102550, -0.989972874126377470, -0.989979935768720120, -0.989986994936113080, +-0.989994051628538490, -0.990001105845978670, -0.990008157588416090, -0.990015206855833220, -0.990022253648212280, -0.990029297965535740, -0.990036339807785940, -0.990043379174945230, +-0.990050416066996180, -0.990057450483920910, -0.990064482425702220, -0.990071511892322120, -0.990078538883763400, -0.990085563400008310, -0.990092585441039400, -0.990099605006838910, +-0.990106622097389310, -0.990113636712673270, -0.990120648852673150, -0.990127658517371390, -0.990134665706750570, -0.990141670420792930, -0.990148672659481250, -0.990155672422797780, +-0.990162669710725200, -0.990169664523245840, -0.990176656860342400, -0.990183646721997320, -0.990190634108193080, -0.990197619018912460, -0.990204601454137580, -0.990211581413851240, +-0.990218558898035890, -0.990225533906674230, -0.990232506439748690, -0.990239476497241980, -0.990246444079136530, -0.990253409185414930, -0.990260371816059860, -0.990267331971053770, +-0.990274289650379340, -0.990281244854019250, -0.990288197581956080, -0.990295147834172380, -0.990302095610650750, -0.990309040911374060, -0.990315983736324680, -0.990322924085485280, +-0.990329861958838540, -0.990336797356367260, -0.990343730278054000, -0.990350660723881340, -0.990357588693832060, -0.990364514187888840, -0.990371437206034270, -0.990378357748251110, +-0.990385275814521960, -0.990392191404829810, -0.990399104519157030, -0.990406015157486610, -0.990412923319801130, -0.990419829006083390, -0.990426732216315940, -0.990433632950481700, +-0.990440531208563460, -0.990447426990543780, -0.990454320296405680, -0.990461211126131720, -0.990468099479704710, -0.990474985357107430, -0.990481868758322670, -0.990488749683333220, +-0.990495628132121890, -0.990502504104671560, -0.990509377600964910, -0.990516248620984970, -0.990523117164714310, -0.990529983232135920, -0.990536846823232400, -0.990543707937986850, +-0.990550566576382070, -0.990557422738400970, -0.990564276424026220, -0.990571127633240730, -0.990577976366027400, -0.990584822622369130, -0.990591666402248830, -0.990598507705649390, +-0.990605346532553720, -0.990612182882944610, -0.990619016756805190, -0.990625848154118030, -0.990632677074866350, -0.990639503519032960, -0.990646327486600750, -0.990653148977552740, +-0.990659967991872060, -0.990666784529541270, -0.990673598590543490, -0.990680410174861860, -0.990687219282479050, -0.990694025913378300, -0.990700830067542390, -0.990707631744954460, +-0.990714430945597410, -0.990721227669454360, -0.990728021916508330, -0.990734813686742100, -0.990741602980138800, -0.990748389796681560, -0.990755174136353280, -0.990761955999137300, +-0.990768735385016200, -0.990775512293973320, -0.990782286725991670, -0.990789058681054270, -0.990795828159144240, -0.990802595160244600, -0.990809359684338480, -0.990816121731408980, +-0.990822881301439250, -0.990829638394412290, -0.990836393010311230, -0.990843145149119200, -0.990849894810819200, -0.990856641995394470, -0.990863386702828250, -0.990870128933103670, +-0.990876868686203500, -0.990883605962111340, -0.990890340760810060, -0.990897073082282920, -0.990903802926513140, -0.990910530293483860, -0.990917255183178190, -0.990923977595579490, +-0.990930697530670870, -0.990937414988435460, -0.990944129968856500, -0.990950842471917110, -0.990957552497600760, -0.990964260045890440, -0.990970965116769630, -0.990977667710221220, +-0.990984367826228780, -0.990991065464775330, -0.990997760625844220, -0.991004453309418660, -0.991011143515482030, -0.991017831244017540, -0.991024516495008450, -0.991031199268438190, +-0.991037879564289790, -0.991044557382546820, -0.991051232723192290, -0.991057905586209760, -0.991064575971582480, -0.991071243879293910, -0.991077909309327040, -0.991084572261665350, +-0.991091232736292290, -0.991097890733191210, -0.991104546252345340, -0.991111199293738140, -0.991117849857352850, -0.991124497943173030, -0.991131143551181930, -0.991137786681363100, +-0.991144427333699670, -0.991151065508175220, -0.991157701204773090, -0.991164334423476730, -0.991170965164269610, -0.991177593427134960, -0.991184219212056240, -0.991190842519017120, +-0.991197463348000850, -0.991204081698990880, -0.991210697571970780, -0.991217310966923890, -0.991223921883833680, -0.991230530322683710, -0.991237136283457550, -0.991243739766138440, +-0.991250340770709950, -0.991256939297155640, -0.991263535345458860, -0.991270128915603400, -0.991276720007572610, -0.991283308621350060, -0.991289894756919090, -0.991296478414263490, +-0.991303059593366620, -0.991309638294212150, -0.991316214516783530, -0.991322788261064350, -0.991329359527038270, -0.991335928314688970, -0.991342494623999590, -0.991349058454954020, +-0.991355619807535840, -0.991362178681728600, -0.991368735077515880, -0.991375288994881480, -0.991381840433808730, -0.991388389394281420, -0.991394935876283130, -0.991401479879797430, +-0.991408021404808100, -0.991414560451298720, -0.991421097019252850, -0.991427631108654280, -0.991434162719486810, -0.991440691851733780, -0.991447218505378980, -0.991453742680406200, +-0.991460264376799020, -0.991466783594541100, -0.991473300333616470, -0.991479814594008470, -0.991486326375700890, -0.991492835678677520, -0.991499342502921930, -0.991505846848418140, +-0.991512348715149710, -0.991518848103100430, -0.991525345012253980, -0.991531839442594150, -0.991538331394104850, -0.991544820866769650, -0.991551307860572330, -0.991557792375496790, +-0.991564274411526720, -0.991570753968646130, -0.991577231046838480, -0.991583705646087890, -0.991590177766377920, -0.991596647407692490, -0.991603114570015490, -0.991609579253330710, +-0.991616041457621940, -0.991622501182873100, -0.991628958429068060, -0.991635413196190640, -0.991641865484224620, -0.991648315293154000, -0.991654762622962480, -0.991661207473634070, +-0.991667649845152650, -0.991674089737502260, -0.991680527150666570, -0.991686962084629480, -0.991693394539374990, -0.991699824514887030, -0.991706252011149590, -0.991712677028146360, +-0.991719099565861570, -0.991725519624279020, -0.991731937203382710, -0.991738352303156550, -0.991744764923584430, -0.991751175064650380, -0.991757582726338400, -0.991763987908632520, +-0.991770390611516730, -0.991776790834974830, -0.991783188578991060, -0.991789583843549210, -0.991795976628633500, -0.991802366934227740, -0.991808754760316160, -0.991815140106882650, +-0.991821522973911350, -0.991827903361386260, -0.991834281269291300, -0.991840656697610680, -0.991847029646328430, -0.991853400115428550, -0.991859768104895290, -0.991866133614712650, +-0.991872496644864540, -0.991878857195335200, -0.991885215266108730, -0.991891570857169170, -0.991897923968500740, -0.991904274600087570, -0.991910622751913550, -0.991916968423963040, +-0.991923311616220160, -0.991929652328669140, -0.991935990561293780, -0.991942326314078530, -0.991948659587007400, -0.991954990380064630, -0.991961318693234450, -0.991967644526500990, +-0.991973967879848260, -0.991980288753260720, -0.991986607146722490, -0.991992923060217690, -0.991999236493730560, -0.992005547447245340, -0.992011855920746250, -0.992018161914217540, +-0.992024465427643550, -0.992030766461008300, -0.992037065014296120, -0.992043361087491250, -0.992049654680578040, -0.992055945793540620, -0.992062234426363540, -0.992068520579030610, +-0.992074804251526500, -0.992081085443835330, -0.992087364155941450, -0.992093640387829210, -0.992099914139482840, -0.992106185410886690, -0.992112454202025100, -0.992118720512882410, +-0.992124984343442870, -0.992131245693690820, -0.992137504563610720, -0.992143760953186790, -0.992150014862403510, -0.992156266291245310, -0.992162515239696340, -0.992168761707741040, +-0.992175005695363880, -0.992181247202549190, -0.992187486229281320, -0.992193722775544850, -0.992199956841324000, -0.992206188426603240, -0.992212417531367130, -0.992218644155599900, +-0.992224868299286020, -0.992231089962410050, -0.992237309144956230, -0.992243525846909220, -0.992249740068253510, -0.992255951808973300, -0.992262161069053290, -0.992268367848477830, +-0.992274572147231470, -0.992280773965298570, -0.992286973302663910, -0.992293170159311620, -0.992299364535226600, -0.992305556430393090, -0.992311745844795760, -0.992317932778418950, +-0.992324117231247360, -0.992330299203265430, -0.992336478694457850, -0.992342655704809060, -0.992348830234303650, -0.992355002282926060, -0.992361171850660970, -0.992367338937493070, +-0.992373503543406700, -0.992379665668386530, -0.992385825312417370, -0.992391982475483550, -0.992398137157569750, -0.992404289358660760, -0.992410439078740940, -0.992416586317794950, +-0.992422731075807580, -0.992428873352763310, -0.992435013148647020, -0.992441150463443060, -0.992447285297136220, -0.992453417649711180, -0.992459547521152620, -0.992465674911445220, +-0.992471799820573540, -0.992477922248522380, -0.992484042195276530, -0.992490159660820440, -0.992496274645139120, -0.992502387148216920, -0.992508497170038860, -0.992514604710589500, +-0.992520709769853740, -0.992526812347816030, -0.992532912444461510, -0.992539010059774630, -0.992545105193740170, -0.992551197846342940, -0.992557288017567710, -0.992563375707399280, +-0.992569460915822430, -0.992575543642821860, -0.992581623888382450, -0.992587701652489220, -0.992593776935126510, -0.992599849736279350, -0.992605920055932620, -0.992611987894071010, +-0.992618053250679530, -0.992624116125742970, -0.992630176519246010, -0.992636234431173550, -0.992642289861510600, -0.992648342810241950, -0.992654393277352390, -0.992660441262826820, +-0.992666486766650150, -0.992672529788807270, -0.992678570329283190, -0.992684608388062610, -0.992690643965130510, -0.992696677060471710, -0.992702707674071320, -0.992708735805914120, +-0.992714761455985140, -0.992720784624269270, -0.992726805310751300, -0.992732823515416360, -0.992738839238249460, -0.992744852479235380, -0.992750863238359150, -0.992756871515605770, +-0.992762877310960250, -0.992768880624407490, -0.992774881455932730, -0.992780879805520540, -0.992786875673156270, -0.992792869058824690, -0.992798859962511050, -0.992804848384200240, +-0.992810834323877290, -0.992816817781527310, -0.992822798757135190, -0.992828777250686080, -0.992834753262165080, -0.992840726791557100, -0.992846697838847380, -0.992852666404020920, +-0.992858632487062740, -0.992864596087958180, -0.992870557206691930, -0.992876515843249320, -0.992882471997615480, -0.992888425669775420, -0.992894376859714270, -0.992900325567417250, +-0.992906271792869390, -0.992912215536055800, -0.992918156796961720, -0.992924095575572150, -0.992930031871872450, -0.992935965685847630, -0.992941897017482920, -0.992947825866763440, +-0.992953752233674440, -0.992959676118201020, -0.992965597520328420, -0.992971516440041890, -0.992977432877326430, -0.992983346832167490, -0.992989258304550200, -0.992995167294459800, +-0.993001073801881410, -0.993006977826800250, -0.993012879369201800, -0.993018778429071050, -0.993024675006393350, -0.993030569101153950, -0.993036460713338180, -0.993042349842931380, +-0.993048236489918580, -0.993054120654285110, -0.993060002336016430, -0.993065881535097780, -0.993071758251514390, -0.993077632485251600, -0.993083504236294770, -0.993089373504629110, +-0.993095240290239990, -0.993101104593112850, -0.993106966413232930, -0.993112825750585570, -0.993118682605156120, -0.993124536976930040, -0.993130388865892550, -0.993136238272029240, +-0.993142085195325210, -0.993147929635765920, -0.993153771593336840, -0.993159611068023310, -0.993165448059810880, -0.993171282568684810, -0.993177114594630430, -0.993182944137633310, +-0.993188771197678790, -0.993194595774752330, -0.993200417868839500, -0.993206237479925540, -0.993212054607996000, -0.993217869253036230, -0.993223681415032030, -0.993229491093968410, +-0.993235298289831150, -0.993241103002605600, -0.993246905232277320, -0.993252704978831780, -0.993258502242254540, -0.993264297022531050, -0.993270089319646670, -0.993275879133587170, +-0.993281666464337910, -0.993287451311884560, -0.993293233676212470, -0.993299013557307430, -0.993304790955154780, -0.993310565869740200, -0.993316338301049150, -0.993322108249067300, +-0.993327875713780120, -0.993333640695173270, -0.993339403193232330, -0.993345163207942970, -0.993350920739290650, -0.993356675787261060, -0.993362428351839630, -0.993368178433012280, +-0.993373926030764350, -0.993379671145081740, -0.993385413775949910, -0.993391153923354420, -0.993396891587281280, -0.993402626767715850, -0.993408359464643790, -0.993414089678050780, +-0.993419817407922620, -0.993425542654244880, -0.993431265417003330, -0.993436985696183660, -0.993442703491771440, -0.993448418803752450, -0.993454131632112380, -0.993459841976837010, +-0.993465549837912130, -0.993471255215323310, -0.993476958109056340, -0.993482658519097010, -0.993488356445431100, -0.993494051888044180, -0.993499744846922160, -0.993505435322050710, +-0.993511123313415730, -0.993516808821003130, -0.993522491844798350, -0.993528172384787300, -0.993533850440955770, -0.993539526013289760, -0.993545199101774860, -0.993550869706396940, +-0.993556537827141820, -0.993562203463995490, -0.993567866616943520, -0.993573527285972040, -0.993579185471066610, -0.993584841172213240, -0.993590494389397730, -0.993596145122606080, +-0.993601793371823970, -0.993607439137037530, -0.993613082418232430, -0.993618723215394570, -0.993624361528509860, -0.993629997357564300, -0.993635630702543680, -0.993641261563434130, +-0.993646889940221320, -0.993652515832891270, -0.993658139241430090, -0.993663760165823470, -0.993669378606057420, -0.993674994562117830, -0.993680608033990830, -0.993686219021662430, +-0.993691827525118420, -0.993697433544344810, -0.993703037079327610, -0.993708638130052830, -0.993714236696506380, -0.993719832778674480, -0.993725426376542930, -0.993731017490097730, +-0.993736606119325130, -0.993742192264211010, -0.993747775924741280, -0.993753357100902180, -0.993758935792679710, -0.993764512000059890, -0.993770085723028830, -0.993775656961572550, +-0.993781225715677060, -0.993786791985328600, -0.993792355770513060, -0.993797917071216670, -0.993803475887425460, -0.993809032219125530, -0.993814586066303130, -0.993820137428944150, +-0.993825686307034940, -0.993831232700561510, -0.993836776609509980, -0.993842318033866470, -0.993847856973617110, -0.993853393428748120, -0.993858927399245860, -0.993864458885096110, +-0.993869987886285220, -0.993875514402799310, -0.993881038434624720, -0.993886559981747460, -0.993892079044153780, -0.993897595621830000, -0.993903109714762150, -0.993908621322936560, +-0.993914130446339470, -0.993919637084957010, -0.993925141238775400, -0.993930642907780990, -0.993936142091959910, -0.993941638791298600, -0.993947133005783190, -0.993952624735399910, +-0.993958113980135010, -0.993963600739974810, -0.993969085014905660, -0.993974566804913810, -0.993980046109985470, -0.993985522930107110, -0.993990997265264850, -0.993996469115445260, +-0.994001938480634450, -0.994007405360818660, -0.994012869755984460, -0.994018331666118080, -0.994023791091205760, -0.994029248031234160, -0.994034702486189300, -0.994040154456057760, +-0.994045603940825750, -0.994051050940479740, -0.994056495455006180, -0.994061937484391310, -0.994067377028621580, -0.994072814087683440, -0.994078248661563360, -0.994083680750247670, +-0.994089110353722600, -0.994094537471974850, -0.994099962104990740, -0.994105384252756740, -0.994110803915259300, -0.994116221092484880, -0.994121635784419810, -0.994127047991050670, +-0.994132457712363920, -0.994137864948346110, -0.994143269698983480, -0.994148671964262820, -0.994154071744170360, -0.994159469038692790, -0.994164863847816660, -0.994170256171528210, +-0.994175646009814120, -0.994181033362660950, -0.994186418230055270, -0.994191800611983530, -0.994197180508432200, -0.994202557919387940, -0.994207932844837330, -0.994213305284766810, +-0.994218675239163070, -0.994224042708012680, -0.994229407691302190, -0.994234770189018070, -0.994240130201147100, -0.994245487727675960, -0.994250842768590880, -0.994256195323878770, +-0.994261545393526180, -0.994266892977519690, -0.994272238075845970, -0.994277580688491810, -0.994282920815443560, -0.994288258456688000, -0.994293593612211810, -0.994298926282001560, +-0.994304256466044030, -0.994309584164325910, -0.994314909376833870, -0.994320232103554470, -0.994325552344474620, -0.994330870099580770, -0.994336185368859820, -0.994341498152298330, +-0.994346808449883100, -0.994352116261600800, -0.994357421587438450, -0.994362724427382380, -0.994368024781419390, -0.994373322649536480, -0.994378618031720230, -0.994383910927957420, +-0.994389201338234830, -0.994394489262539260, -0.994399774700857500, -0.994405057653176330, -0.994410338119482430, -0.994415616099762700, -0.994420891594003930, -0.994426164602192910, +-0.994431435124316530, -0.994436703160361590, -0.994441968710314870, -0.994447231774163170, -0.994452492351893480, -0.994457750443492490, -0.994463006048947110, -0.994468259168244220, +-0.994473509801370730, -0.994478757948313420, -0.994484003609059200, -0.994489246783595070, -0.994494487471907830, -0.994499725673984260, -0.994504961389811370, -0.994510194619376180, +-0.994515425362665570, -0.994520653619666240, -0.994525879390365300, -0.994531102674749650, -0.994536323472806290, -0.994541541784522030, -0.994546757609883980, -0.994551970948879040, +-0.994557181801494220, -0.994562390167716410, -0.994567596047532640, -0.994572799440929910, -0.994578000347895120, -0.994583198768415280, -0.994588394702477510, -0.994593588150068820, +-0.994598779111176110, -0.994603967585786400, -0.994609153573886800, -0.994614337075464320, -0.994619518090505970, -0.994624696618998880, -0.994629872660930060, -0.994635046216286510, +-0.994640217285055360, -0.994645385867223730, -0.994650551962778520, -0.994655715571706960, -0.994660876693996170, -0.994666035329633160, -0.994671191478605050, -0.994676345140898980, +-0.994681496316502050, -0.994686645005401380, -0.994691791207584110, -0.994696934923037230, -0.994702076151748100, -0.994707214893703840, -0.994712351148891450, -0.994717484917298280, +-0.994722616198911450, -0.994727744993717970, -0.994732871301705070, -0.994737995122860100, -0.994743116457170060, -0.994748235304622310, -0.994753351665203960, -0.994758465538902240, +-0.994763576925704270, -0.994768685825597410, -0.994773792238568880, -0.994778896164605800, -0.994783997603695510, -0.994789096555825260, -0.994794193020982150, -0.994799286999153650, +-0.994804378490326990, -0.994809467494489290, -0.994814554011627990, -0.994819638041730240, -0.994824719584783470, -0.994829798640774920, -0.994834875209691720, -0.994839949291521420, +-0.994845020886251260, -0.994850089993868590, -0.994855156614360640, -0.994860220747714740, -0.994865282393918360, -0.994870341552958730, -0.994875398224823290, -0.994880452409499410, +-0.994885504106974290, -0.994890553317235530, -0.994895600040270220, -0.994900644276066060, -0.994905686024610160, -0.994910725285890200, -0.994915762059893400, -0.994920796346607130, +-0.994925828146018820, -0.994930857458116050, -0.994935884282886040, -0.994940908620316370, -0.994945930470394370, -0.994950949833107610, -0.994955966708443550, -0.994960981096389530, +-0.994965992996933000, -0.994971002410061420, -0.994976009335762470, -0.994981013774023370, -0.994986015724831920, -0.994991015188175340, -0.994996012164041210, -0.995001006652416970, +-0.995005998653290310, -0.995010988166648680, -0.995015975192479530, -0.995020959730770430, -0.995025941781508940, -0.995030921344682630, -0.995035898420279060, -0.995040873008285590, +-0.995045845108690100, -0.995050814721479830, -0.995055781846642670, -0.995060746484166090, -0.995065708634037540, -0.995070668296244690, -0.995075625470775220, -0.995080580157616690, +-0.995085532356756670, -0.995090482068182850, -0.995095429291882770, -0.995100374027844240, -0.995105316276054700, -0.995110256036501940, -0.995115193309173420, -0.995120128094057030, +-0.995125060391140240, -0.995129990200410820, -0.995134917521856450, -0.995139842355464820, -0.995144764701223480, -0.995149684559120340, -0.995154601929142850, -0.995159516811279010, +-0.995164429205516290, -0.995169339111842470, -0.995174246530245330, -0.995179151460712560, -0.995184053903232060, -0.995188953857791270, -0.995193851324378100, -0.995198746302980330, +-0.995203638793585750, -0.995208528796181930, -0.995213416310756990, -0.995218301337298380, -0.995223183875794120, -0.995228063926231750, -0.995232941488599310, -0.995237816562884460, +-0.995242689149075100, -0.995247559247159020, -0.995252426857124010, -0.995257291978958070, -0.995262154612648780, -0.995267014758184130, -0.995271872415551930, -0.995276727584740060, +-0.995281580265736320, -0.995286430458528830, -0.995291278163105030, -0.995296123379453170, -0.995300966107560910, -0.995305806347416280, -0.995310644099007160, -0.995315479362321340, +-0.995320312137346840, -0.995325142424071660, -0.995329970222483600, -0.995334795532570650, -0.995339618354320610, -0.995344438687721490, -0.995349256532761410, -0.995354071889428040, +-0.995358884757709730, -0.995363695137594040, -0.995368503029069100, -0.995373308432122910, -0.995378111346743480, -0.995382911772918710, -0.995387709710636730, -0.995392505159885420, +-0.995397298120652920, -0.995402088592927110, -0.995406876576696130, -0.995411662071947980, -0.995416445078670550, -0.995421225596852090, -0.995426003626480590, -0.995430779167544190, +-0.995435552220030660, -0.995440322783928240, -0.995445090859225060, -0.995449856445909220, -0.995454619543968630, -0.995459380153391530, -0.995464138274166020, -0.995468893906280130, +-0.995473647049722080, -0.995478397704479880, -0.995483145870541650, -0.995487891547895520, -0.995492634736529710, -0.995497375436432350, -0.995502113647591560, -0.995506849369995450, +-0.995511582603632150, -0.995516313348490000, -0.995521041604557010, -0.995525767371821410, -0.995530490650271330, -0.995535211439895100, -0.995539929740680840, -0.995544645552616790, +-0.995549358875691180, -0.995554069709892020, -0.995558778055207760, -0.995563483911626520, -0.995568187279136650, -0.995572888157726270, -0.995577586547383710, -0.995582282448097100, +-0.995586975859854780, -0.995591666782645100, -0.995596355216456170, -0.995601041161276460, -0.995605724617094070, -0.995610405583897350, -0.995615084061674650, -0.995619760050414300, +-0.995624433550104440, -0.995629104560733610, -0.995633773082289950, -0.995638439114761800, -0.995643102658137600, -0.995647763712405710, -0.995652422277554460, -0.995657078353571980, +-0.995661731940446940, -0.995666383038167460, -0.995671031646722100, -0.995675677766099110, -0.995680321396286930, -0.995684962537274010, -0.995689601189048590, -0.995694237351599340, +-0.995698871024914280, -0.995703502208982180, -0.995708130903791290, -0.995712757109330050, -0.995717380825587030, -0.995722002052550460, -0.995726620790208910, -0.995731237038550710, +-0.995735850797564550, -0.995740462067238650, -0.995745070847561700, -0.995749677138522030, -0.995754280940108090, -0.995758882252308570, -0.995763481075111810, -0.995768077408506370, +-0.995772671252480700, -0.995777262607023370, -0.995781851472122840, -0.995786437847767770, -0.995791021733946510, -0.995795603130647740, -0.995800182037860030, -0.995804758455571700, +-0.995809332383771560, -0.995813903822448170, -0.995818472771589860, -0.995823039231185540, -0.995827603201223430, -0.995832164681692560, -0.995836723672581140, -0.995841280173877850, +-0.995845834185571490, -0.995850385707650390, -0.995854934740103450, -0.995859481282919230, -0.995864025336086200, -0.995868566899593130, -0.995873105973428600, -0.995877642557581380, +-0.995882176652039930, -0.995886708256793150, -0.995891237371829610, -0.995895763997137860, -0.995900288132706920, -0.995904809778525020, -0.995909328934581280, -0.995913845600864040, +-0.995918359777362320, -0.995922871464064660, -0.995927380660959870, -0.995931887368036620, -0.995936391585283580, -0.995940893312689650, -0.995945392550243390, -0.995949889297933710, +-0.995954383555749280, -0.995958875323678880, -0.995963364601711310, -0.995967851389835350, -0.995972335688039780, -0.995976817496313280, -0.995981296814644870, -0.995985773643023100, +-0.995990247981436980, -0.995994719829875200, -0.995999189188326640, -0.996003656056780100, -0.996008120435224350, -0.996012582323648420, -0.996017041722040970, -0.996021498630390910, +-0.996025953048687020, -0.996030404976918420, -0.996034854415073670, -0.996039301363141890, -0.996043745821111880, -0.996048187788972420, -0.996052627266712510, -0.996057064254320950, +-0.996061498751786960, -0.996065930759098990, -0.996070360276246290, -0.996074787303217630, -0.996079211840002140, -0.996083633886588490, -0.996088053442965800, -0.996092470509122970, +-0.996096885085048900, -0.996101297170732700, -0.996105706766163280, -0.996110113871329640, -0.996114518486220570, -0.996118920610825300, -0.996123320245132620, -0.996127717389131750, +-0.996132112042811600, -0.996136504206161180, -0.996140893879169380, -0.996145281061825430, -0.996149665754118230, -0.996154047956036900, -0.996158427667570460, -0.996162804888707900, +-0.996167179619438350, -0.996171551859750930, -0.996175921609634530, -0.996180288869078390, -0.996184653638071520, -0.996189015916602920, -0.996193375704661820, -0.996197733002237460, +-0.996202087809318630, -0.996206440125894540, -0.996210789951954330, -0.996215137287487230, -0.996219482132482240, -0.996223824486928590, -0.996228164350815290, -0.996232501724131690, +-0.996236836606866900, -0.996241168999009830, -0.996245498900549920, -0.996249826311476290, -0.996254151231778070, -0.996258473661444490, -0.996262793600464770, -0.996267111048827920, +-0.996271426006523410, -0.996275738473540230, -0.996280048449867840, -0.996284355935495250, -0.996288660930411800, -0.996292963434606600, -0.996297263448069130, -0.996301560970788370, +-0.996305856002753900, -0.996310148543954610, -0.996314438594380070, -0.996318726154019400, -0.996323011222861820, -0.996327293800896910, -0.996331573888113550, -0.996335851484501430, +-0.996340126590049560, -0.996344399204747380, -0.996348669328584240, -0.996352936961549470, -0.996357202103632210, -0.996361464754822120, -0.996365724915108220, -0.996369982584480170, +-0.996374237762927110, -0.996378490450438360, -0.996382740647003500, -0.996386988352611750, -0.996391233567252450, -0.996395476290915180, -0.996399716523589160, -0.996403954265263850, +-0.996408189515928690, -0.996412422275573030, -0.996416652544186320, -0.996420880321758020, -0.996425105608277460, -0.996429328403734100, -0.996433548708117510, -0.996437766521417020, +-0.996441981843622090, -0.996446194674722290, -0.996450405014706830, -0.996454612863565510, -0.996458818221287680, -0.996463021087862780, -0.996467221463280260, -0.996471419347529700, +-0.996475614740600530, -0.996479807642482450, -0.996483998053164790, -0.996488185972637110, -0.996492371400888980, -0.996496554337910070, -0.996500734783689610, -0.996504912738217290, +-0.996509088201482760, -0.996513261173475500, -0.996517431654185050, -0.996521599643601210, -0.996525765141713200, -0.996529928148510710, -0.996534088663983520, -0.996538246688121080, +-0.996542402220913060, -0.996546555262348920, -0.996550705812418450, -0.996554853871111310, -0.996558999438416860, -0.996563142514325100, -0.996567283098825360, -0.996571421191907450, +-0.996575556793561020, -0.996579689903775660, -0.996583820522541130, -0.996587948649847010, -0.996592074285682970, -0.996596197430038800, -0.996600318082904170, -0.996604436244268640, +-0.996608551914122010, -0.996612665092454160, -0.996616775779254450, -0.996620883974512980, -0.996624989678219220, -0.996629092890363060, -0.996633193610934050, -0.996637291839922110, +-0.996641387577316910, -0.996645480823108220, -0.996649571577285950, -0.996653659839839670, -0.996657745610759260, -0.996661828890034520, -0.996665909677655120, -0.996669987973610950, +-0.996674063777891920, -0.996678137090487580, -0.996682207911388060, -0.996686276240582920, -0.996690342078062170, -0.996694405423815490, -0.996698466277832760, -0.996702524640104000, +-0.996706580510618780, -0.996710633889367200, -0.996714684776339070, -0.996718733171524150, -0.996722779074912470, -0.996726822486493690, -0.996730863406257940, -0.996734901834195110, +-0.996738937770294990, -0.996742971214547470, -0.996747002166942560, -0.996751030627470170, -0.996755056596120180, -0.996759080072882500, -0.996763101057747130, -0.996767119550704070, +-0.996771135551743240, -0.996775149060854520, -0.996779160078027910, -0.996783168603253330, -0.996787174636521000, -0.996791178177820590, -0.996795179227142230, -0.996799177784476020, +-0.996803173849811870, -0.996807167423139680, -0.996811158504449680, -0.996815147093731760, -0.996819133190975930, -0.996823116796172300, -0.996827097909310900, -0.996831076530381720, +-0.996835052659374890, -0.996839026296280410, -0.996842997441088290, -0.996846966093788760, -0.996850932254371710, -0.996854895922827390, -0.996858857099145900, -0.996862815783317150, +-0.996866771975331470, -0.996870725675178870, -0.996874676882849360, -0.996878625598333290, -0.996882571821620540, -0.996886515552701360, -0.996890456791565960, -0.996894395538204360, +-0.996898331792606780, -0.996902265554763470, -0.996906196824664300, -0.996910125602299750, -0.996914051887659910, -0.996917975680734920, -0.996921896981515010, -0.996925815789990290, +-0.996929732106151100, -0.996933645929987570, -0.996937557261489920, -0.996941466100648380, -0.996945372447453180, -0.996949276301894450, -0.996953177663962740, -0.996957076533647960, +-0.996960972910940440, -0.996964866795830520, -0.996968758188308430, -0.996972647088364530, -0.996976533495988910, -0.996980417411172050, -0.996984298833904050, -0.996988177764175370, +-0.996992054201976230, -0.996995928147296980, -0.996999799600127860, -0.997003668560459190, -0.997007535028281430, -0.997011399003584930, -0.997015260486359800, -0.997019119476596490, +-0.997022975974285460, -0.997026829979416940, -0.997030681491981370, -0.997034530511969110, -0.997038377039370480, -0.997042221074175950, -0.997046062616375850, -0.997049901665960640, +-0.997053738222920650, -0.997057572287246340, -0.997061403858928050, -0.997065232937956240, -0.997069059524321450, -0.997072883618013940, -0.997076705219024140, -0.997080524327342730, +-0.997084340942959830, -0.997088155065866230, -0.997091966696052160, -0.997095775833508170, -0.997099582478224830, -0.997103386630192490, -0.997107188289401700, -0.997110987455842920, +-0.997114784129506710, -0.997118578310383420, -0.997122369998463820, -0.997126159193738150, -0.997129945896197300, -0.997133730105831400, -0.997137511822631220, -0.997141291046587330, +-0.997145067777690080, -0.997148842015930240, -0.997152613761298270, -0.997156383013784840, -0.997160149773380410, -0.997163914040075650, -0.997167675813861010, -0.997171435094727280, +-0.997175191882664900, -0.997178946177664450, -0.997182697979716810, -0.997186447288812340, -0.997190194104941810, -0.997193938428095670, -0.997197680258264830, -0.997201419595439730, +-0.997205156439611050, -0.997208890790769460, -0.997212622648905640, -0.997216352014010380, -0.997220078886074220, -0.997223803265087750, -0.997227525151041850, -0.997231244543927090, +-0.997234961443734250, -0.997238675850454000, -0.997242387764077140, -0.997246097184594230, -0.997249804111996150, -0.997253508546273480, -0.997257210487417000, -0.997260909935417610, +-0.997264606890265860, -0.997268301351952550, -0.997271993320468560, -0.997275682795804590, -0.997279369777951510, -0.997283054266899890, -0.997286736262640640, -0.997290415765164530, +-0.997294092774462460, -0.997297767290525110, -0.997301439313343360, -0.997305108842908020, -0.997308775879209850, -0.997312440422239770, -0.997316102471988540, -0.997319762028447190, +-0.997323419091606270, -0.997327073661456900, -0.997330725737989860, -0.997334375321195950, -0.997338022411066170, -0.997341667007591300, -0.997345309110762250, -0.997348948720569890, +-0.997352585837005260, -0.997356220460059120, -0.997359852589722480, -0.997363482225986140, -0.997367109368841100, -0.997370734018278250, -0.997374356174288600, -0.997377975836863050, +-0.997381593005992610, -0.997385207681668050, -0.997388819863880730, -0.997392429552621200, -0.997396036747880580, -0.997399641449649880, -0.997403243657920100, -0.997406843372682150, +-0.997410440593927250, -0.997414035321646080, -0.997417627555829860, -0.997421217296469600, -0.997424804543556310, -0.997428389297081000, -0.997431971557034670, -0.997435551323408440, +-0.997439128596193330, -0.997442703375380550, -0.997446275660960780, -0.997449845452925480, -0.997453412751265420, -0.997456977555971960, -0.997460539867035980, -0.997464099684448710, +-0.997467657008201170, -0.997471211838284470, -0.997474764174689720, -0.997478314017408160, -0.997481861366430690, -0.997485406221748640, -0.997488948583353020, -0.997492488451235060, +-0.997496025825385880, -0.997499560705796710, -0.997503093092458550, -0.997506622985362630, -0.997510150384500300, -0.997513675289862460, -0.997517197701440540, -0.997520717619225560, +-0.997524235043208750, -0.997527749973381340, -0.997531262409734550, -0.997534772352259740, -0.997538279800947890, -0.997541784755790360, -0.997545287216778380, -0.997548787183903160, +-0.997552284657156060, -0.997555779636528080, -0.997559272122010790, -0.997562762113595290, -0.997566249611272830, -0.997569734615034840, -0.997573217124872460, -0.997576697140777010, +-0.997580174662739850, -0.997583649690752310, -0.997587122224805610, -0.997590592264891000, -0.997594059811000020, -0.997597524863123810, -0.997600987421253920, -0.997604447485381460, +-0.997607905055497900, -0.997611360131594570, -0.997614812713662920, -0.997618262801694190, -0.997621710395679710, -0.997625155495611150, -0.997628598101479520, -0.997632038213276510, +-0.997635475830993320, -0.997638910954621430, -0.997642343584152380, -0.997645773719577300, -0.997649201360887970, -0.997652626508075510, -0.997656049161131600, -0.997659469320047450, +-0.997662886984814650, -0.997666302155424730, -0.997669714831868950, -0.997673125014138850, -0.997676532702226120, -0.997679937896121860, -0.997683340595817870, -0.997686740801305480, +-0.997690138512576260, -0.997693533729621660, -0.997696926452433240, -0.997700316681002560, -0.997703704415321080, -0.997707089655380240, -0.997710472401171830, -0.997713852652687080, +-0.997717230409917780, -0.997720605672855370, -0.997723978441491520, -0.997727348715817700, -0.997730716495825450, -0.997734081781506470, -0.997737444572852290, -0.997740804869854500, +-0.997744162672504650, -0.997747517980794420, -0.997750870794715360, -0.997754221114259150, -0.997757568939417360, -0.997760914270181760, -0.997764257106543710, -0.997767597448495080, +-0.997770935296027560, -0.997774270649132600, -0.997777603507801980, -0.997780933872027380, -0.997784261741800460, -0.997787587117112800, -0.997790909997956170, -0.997794230384322360, +-0.997797548276202930, -0.997800863673589560, -0.997804176576474130, -0.997807486984848220, -0.997810794898703720, -0.997814100318032080, -0.997817403242825200, -0.997820703673074850, +-0.997824001608772710, -0.997827297049910580, -0.997830589996480220, -0.997833880448473430, -0.997837168405881880, -0.997840453868697460, -0.997843736836911850, -0.997847017310516840, +-0.997850295289504420, -0.997853570773866160, -0.997856843763593960, -0.997860114258679820, -0.997863382259115310, -0.997866647764892310, -0.997869910776002620, -0.997873171292438240, +-0.997876429314190960, -0.997879684841252560, -0.997882937873615040, -0.997886188411270080, -0.997889436454209580, -0.997892682002425650, -0.997895925055909850, -0.997899165614654300, +-0.997902403678650910, -0.997905639247891440, -0.997908872322367910, -0.997912102902072220, -0.997915330986996250, -0.997918556577131910, -0.997921779672471200, -0.997925000273006120, +-0.997928218378728470, -0.997931433989630360, -0.997934647105703570, -0.997937857726940100, -0.997941065853332090, -0.997944271484871410, -0.997947474621549980, -0.997950675263359900, +-0.997953873410293180, -0.997957069062341720, -0.997960262219497630, -0.997963452881752920, -0.997966641049099490, -0.997969826721529450, -0.997973009899034920, -0.997976190581607910, +-0.997979368769240320, -0.997982544461924360, -0.997985717659651940, -0.997988888362415280, -0.997992056570206510, -0.997995222283017510, -0.997998385500840410, -0.998001546223667320, +-0.998004704451490480, -0.998007860184301880, -0.998011013422093640, -0.998014164164857780, -0.998017312412586510, -0.998020458165271960, -0.998023601422906360, -0.998026742185481710, +-0.998029880452990240, -0.998033016225423950, -0.998036149502775190, -0.998039280285036080, -0.998042408572198720, -0.998045534364255360, -0.998048657661198100, -0.998051778463019290, +-0.998054896769711040, -0.998058012581265590, -0.998061125897675040, -0.998064236718931630, -0.998067345045027700, -0.998070450875955360, -0.998073554211706960, -0.998076655052274610, +-0.998079753397650650, -0.998082849247827310, -0.998085942602796820, -0.998089033462551510, -0.998092121827083510, -0.998095207696385270, -0.998098291070449120, -0.998101371949267180, +-0.998104450332831790, -0.998107526221135190, -0.998110599614169920, -0.998113670511928010, -0.998116738914402000, -0.998119804821584240, -0.998122868233466850, -0.998125929150042280, +-0.998128987571302970, -0.998132043497241160, -0.998135096927849190, -0.998138147863119500, -0.998141196303044430, -0.998144242247616440, -0.998147285696827760, -0.998150326650670940, +-0.998153365109138320, -0.998156401072222250, -0.998159434539915070, -0.998162465512209440, -0.998165493989097710, -0.998168519970572100, -0.998171543456625180, -0.998174564447249500, +-0.998177582942437300, -0.998180598942181250, -0.998183612446473690, -0.998186623455306950, -0.998189631968673830, -0.998192637986566540, -0.998195641508977770, -0.998198642535899740, +-0.998201641067325230, -0.998204637103246580, -0.998207630643656250, -0.998210621688546910, -0.998213610237911110, -0.998216596291741200, -0.998219579850029850, -0.998222560912769400, +-0.998225539479952630, -0.998228515551572100, -0.998231489127620160, -0.998234460208089590, -0.998237428792972840, -0.998240394882262460, -0.998243358475951140, -0.998246319574031430, +-0.998249278176496000, -0.998252234283337200, -0.998255187894547920, -0.998258139010120730, -0.998261087630048060, -0.998264033754322820, -0.998266977382937350, -0.998269918515884540, +-0.998272857153156830, -0.998275793294747030, -0.998278726940647790, -0.998281658090851680, -0.998284586745351480, -0.998287512904139750, -0.998290436567209280, -0.998293357734552630, +-0.998296276406162700, -0.998299192582032040, -0.998302106262153430, -0.998305017446519560, -0.998307926135123090, -0.998310832327956810, -0.998313736025013500, -0.998316637226285720, +-0.998319535931766480, -0.998322432141448330, -0.998325325855324190, -0.998328217073386700, -0.998331105795628670, -0.998333992022042870, -0.998336875752621980, -0.998339756987358990, +-0.998342635726246600, -0.998345511969277680, -0.998348385716445020, -0.998351256967741300, -0.998354125723159400, -0.998356991982692230, -0.998359855746332570, -0.998362717014073310, +-0.998365575785907230, -0.998368432061827240, -0.998371285841826110, -0.998374137125896840, -0.998376985914032230, -0.998379832206225060, -0.998382676002468330, -0.998385517302754930, +-0.998388356107077770, -0.998391192415429730, -0.998394026227803710, -0.998396857544192610, -0.998399686364589310, -0.998402512688986830, -0.998405336517378060, -0.998408157849756010, +-0.998410976686113560, -0.998413793026443620, -0.998416606870739190, -0.998419418218993270, -0.998422227071198880, -0.998425033427348780, -0.998427837287436120, -0.998430638651453980, +-0.998433437519395170, -0.998436233891252800, -0.998439027767019760, -0.998441819146689170, -0.998444608030254140, -0.998447394417707470, -0.998450178309042370, -0.998452959704251740, +-0.998455738603328810, -0.998458515006266590, -0.998461288913057960, -0.998464060323696170, -0.998466829238174200, -0.998469595656485190, -0.998472359578622130, -0.998475121004578250, +-0.998477879934346560, -0.998480636367920170, -0.998483390305292100, -0.998486141746455670, -0.998488890691403790, -0.998491637140129670, -0.998494381092626560, -0.998497122548887450, +-0.998499861508905460, -0.998502597972674040, -0.998505331940185870, -0.998508063411434500, -0.998510792386412940, -0.998513518865114410, -0.998516242847532150, -0.998518964333659160, +-0.998521683323488900, -0.998524399817014350, -0.998527113814228760, -0.998529825315125460, -0.998532534319697460, -0.998535240827938320, -0.998537944839840930, -0.998540646355398740, +-0.998543345374604980, -0.998546041897452770, -0.998548735923935450, -0.998551427454046350, -0.998554116487778700, -0.998556803025125730, -0.998559487066080780, -0.998562168610637070, +-0.998564847658787950, -0.998567524210526640, -0.998570198265846590, -0.998572869824741030, -0.998575538887203410, -0.998578205453226730, -0.998580869522804670, -0.998583531095930450, +-0.998586190172597420, -0.998588846752798800, -0.998591500836528150, -0.998594152423778690, -0.998596801514543890, -0.998599448108817180, -0.998602092206591680, -0.998604733807861080, +-0.998607372912618580, -0.998610009520857660, -0.998612643632571740, -0.998615275247754170, -0.998617904366398410, -0.998620530988497900, -0.998623155114046090, -0.998625776743036430, +-0.998628395875462260, -0.998631012511317030, -0.998633626650594410, -0.998636238293287630, -0.998638847439390350, -0.998641454088895930, -0.998644058241797810, -0.998646659898089540, +-0.998649259057764690, -0.998651855720816610, -0.998654449887238950, -0.998657041557025170, -0.998659630730168720, -0.998662217406663280, -0.998664801586502280, -0.998667383269679300, +-0.998669962456187780, -0.998672539146021390, -0.998675113339173580, -0.998677685035638140, -0.998680254235408400, -0.998682820938478040, -0.998685385144840620, -0.998687946854489810, +-0.998690506067419050, -0.998693062783622020, -0.998695617003092280, -0.998698168725823620, -0.998700717951809480, -0.998703264681043650, -0.998705808913519570, -0.998708350649230910, +-0.998710889888171470, -0.998713426630334690, -0.998715960875714460, -0.998718492624304340, -0.998721021876097900, -0.998723548631088920, -0.998726072889271070, -0.998728594650638120, +-0.998731113915183540, -0.998733630682901330, -0.998736144953784930, -0.998738656727828240, -0.998741166005024830, -0.998743672785368570, -0.998746177068853160, -0.998748678855472250, +-0.998751178145219630, -0.998753674938089090, -0.998756169234074400, -0.998758661033169240, -0.998761150335367500, -0.998763637140662740, -0.998766121449048970, -0.998768603260519860, +-0.998771082575069300, -0.998773559392691080, -0.998776033713378860, -0.998778505537126660, -0.998780974863928140, -0.998783441693777090, -0.998785906026667500, -0.998788367862593170, +-0.998790827201547880, -0.998793284043525630, -0.998795738388520090, -0.998798190236525270, -0.998800639587534840, -0.998803086441542920, -0.998805530798543280, -0.998807972658529720, +-0.998810412021496340, -0.998812848887436820, -0.998815283256345280, -0.998817715128215490, -0.998820144503041460, -0.998822571380816980, -0.998824995761536160, -0.998827417645192780, +-0.998829837031780960, -0.998832253921294490, -0.998834668313727360, -0.998837080209073580, -0.998839489607327050, -0.998841896508481870, -0.998844300912531850, -0.998846702819471190, +-0.998849102229293680, -0.998851499141993450, -0.998853893557564600, -0.998856285476000920, -0.998858674897296410, -0.998861061821445410, -0.998863446248441590, -0.998865828178279180, +-0.998868207610952300, -0.998870584546454830, -0.998872958984780900, -0.998875330925924620, -0.998877700369880000, -0.998880067316641140, -0.998882431766202060, -0.998884793718556870, +-0.998887153173699800, -0.998889510131624860, -0.998891864592326040, -0.998894216555797580, -0.998896566022033580, -0.998898912991028180, -0.998901257462775580, -0.998903599437269700, +-0.998905938914504960, -0.998908275894475280, -0.998910610377174880, -0.998912942362597980, -0.998915271850738810, -0.998917598841591370, -0.998919923335150010, -0.998922245331408720, +-0.998924564830361960, -0.998926881832003730, -0.998929196336328260, -0.998931508343329780, -0.998933817853002610, -0.998936124865340890, -0.998938429380338830, -0.998940731397990670, +-0.998943030918290730, -0.998945327941233140, -0.998947622466812350, -0.998949914495022350, -0.998952204025857720, -0.998954491059312440, -0.998956775595380990, -0.998959057634057680, +-0.998961337175336640, -0.998963614219212310, -0.998965888765678930, -0.998968160814730830, -0.998970430366362240, -0.998972697420567710, -0.998974961977341370, -0.998977224036677660, +-0.998979483598570810, -0.998981740663015260, -0.998983995230005470, -0.998986247299535560, -0.998988496871600070, -0.998990743946193360, -0.998992988523309870, -0.998995230602943820, +-0.998997470185089660, -0.998999707269741970, -0.999001941856894840, -0.999004173946542950, -0.999006403538680640, -0.999008630633302250, -0.999010855230402340, -0.999013077329975240, +-0.999015296932015520, -0.999017514036517510, -0.999019728643475660, -0.999021940752884640, -0.999024150364738680, -0.999026357479032350, -0.999028562095760080, -0.999030764214916430, +-0.999032963836495980, -0.999035160960492940, -0.999037355586902100, -0.999039547715717900, -0.999041737346934800, -0.999043924480547350, -0.999046109116550120, -0.999048291254937550, +-0.999050470895704310, -0.999052648038844860, -0.999054822684353750, -0.999056994832225650, -0.999059164482455020, -0.999061331635036520, -0.999063496289964710, -0.999065658447234160, +-0.999067818106839420, -0.999069975268775060, -0.999072129933035850, -0.999074282099616350, -0.999076431768511130, -0.999078578939714860, -0.999080723613222090, -0.999082865789027500, +-0.999085005467125750, -0.999087142647511530, -0.999089277330179380, -0.999091409515124100, -0.999093539202340230, -0.999095666391822570, -0.999097791083565780, -0.999099913277564420, +-0.999102032973813390, -0.999104150172307140, -0.999106264873040660, -0.999108377076008410, -0.999110486781205290, -0.999112593988625950, -0.999114698698265080, -0.999116800910117450, +-0.999118900624177850, -0.999120997840440950, -0.999123092558901640, -0.999125184779554590, -0.999127274502394580, -0.999129361727416290, -0.999131446454614710, -0.999133528683984420, +-0.999135608415520290, -0.999137685649217230, -0.999139760385070020, -0.999141832623073320, -0.999143902363222040, -0.999145969605510940, -0.999148034349934930, -0.999150096596488900, +-0.999152156345167630, -0.999154213595965900, -0.999156268348878720, -0.999158320603900860, -0.999160370361027230, -0.999162417620252600, -0.999164462381571970, -0.999166504644980140, +-0.999168544410471980, -0.999170581678042620, -0.999172616447686730, -0.999174648719399320, -0.999176678493175260, -0.999178705769009470, -0.999180730546897040, -0.999182752826832670, +-0.999184772608811440, -0.999186789892828280, -0.999188804678878270, -0.999190816966956110, -0.999192826757056900, -0.999194834049175640, -0.999196838843307340, -0.999198841139446900, +-0.999200840937589430, -0.999202838237729820, -0.999204833039863070, -0.999206825343984310, -0.999208815150088410, -0.999210802458170510, -0.999212787268225600, -0.999214769580248690, +-0.999216749394234880, -0.999218726710179310, -0.999220701528076850, -0.999222673847922520, -0.999224643669711640, -0.999226610993439120, -0.999228575819100070, -0.999230538146689610, +-0.999232497976202730, -0.999234455307634660, -0.999236410140980410, -0.999238362476235100, -0.999240312313393940, -0.999242259652452060, -0.999244204493404450, -0.999246146836246350, +-0.999248086680972870, -0.999250024027579230, -0.999251958876060550, -0.999253891226411840, -0.999255821078628540, -0.999257748432705540, -0.999259673288638290, -0.999261595646421920, +-0.999263515506051410, -0.999265432867522120, -0.999267347730829370, -0.999269260095968170, -0.999271169962933750, -0.999273077331721550, -0.999274982202326580, -0.999276884574744170, +-0.999278784448969560, -0.999280681824997960, -0.999282576702824610, -0.999284469082444950, -0.999286358963853980, -0.999288246347047160, -0.999290131232019820, -0.999292013618767070, +-0.999293893507284260, -0.999295770897566720, -0.999297645789609780, -0.999299518183408790, -0.999301388078958960, -0.999303255476255540, -0.999305120375294180, -0.999306982776069890, +-0.999308842678578220, -0.999310700082814420, -0.999312554988773800, -0.999314407396451830, -0.999316257305843840, -0.999318104716945270, -0.999319949629751350, -0.999321792044257640, +-0.999323631960459370, -0.999325469378352090, -0.999327304297931150, -0.999329136719191880, -0.999330966642129730, -0.999332794066740250, -0.999334618993018790, -0.999336441420960790, +-0.999338261350561700, -0.999340078781816850, -0.999341893714721820, -0.999343706149272150, -0.999345516085463180, -0.999347323523290370, -0.999349128462749370, -0.999350930903835420, +-0.999352730846544190, -0.999354528290871120, -0.999356323236811780, -0.999358115684361610, -0.999359905633516070, -0.999361693084270810, -0.999363478036621400, -0.999365260490563290, +-0.999367040446091930, -0.999368817903202980, -0.999370592861892120, -0.999372365322154680, -0.999374135283986330, -0.999375902747382640, -0.999377667712339160, -0.999379430178851560, +-0.999381190146915400, -0.999382947616526130, -0.999384702587679640, -0.999386455060371380, -0.999388205034596910, -0.999389952510352010, -0.999391697487632240, -0.999393439966433150, +-0.999395179946750420, -0.999396917428579830, -0.999398652411916940, -0.999400384896757420, -0.999402114883096940, -0.999403842370931160, -0.999405567360255760, -0.999407289851066420, +-0.999409009843358900, -0.999410727337128880, -0.999412442332372030, -0.999414154829084020, -0.999415864827260640, -0.999417572326897650, -0.999419277327990740, -0.999420979830535570, +-0.999422679834527930, -0.999424377339963590, -0.999426072346838450, -0.999427764855148060, -0.999429454864888210, -0.999431142376054680, -0.999432827388643360, -0.999434509902650040, +-0.999436189918070260, -0.999437867434900150, -0.999439542453135380, -0.999441214972771720, -0.999442884993805070, -0.999444552516231100, -0.999446217540045810, -0.999447880065244990, +-0.999449540091824410, -0.999451197619780070, -0.999452852649107660, -0.999454505179803170, -0.999456155211862370, -0.999457802745281290, -0.999459447780055580, -0.999461090316181240, +-0.999462730353654290, -0.999464367892470400, -0.999466002932625660, -0.999467635474115990, -0.999469265516937040, -0.999470893061085050, -0.999472518106555800, -0.999474140653345280, +-0.999475760701449390, -0.999477378250864130, -0.999478993301585410, -0.999480605853609210, -0.999482215906931430, -0.999483823461548180, -0.999485428517455250, -0.999487031074648870, +-0.999488631133124920, -0.999490228692879400, -0.999491823753908220, -0.999493416316207580, -0.999495006379773290, -0.999496593944601550, -0.999498179010688380, -0.999499761578029670, +-0.999501341646621630, -0.999502919216460170, -0.999504494287541510, -0.999506066859861540, -0.999507636933416380, -0.999509204508202130, -0.999510769584214920, -0.999512332161450750, +-0.999513892239905720, -0.999515449819576070, -0.999517004900457700, -0.999518557482546810, -0.999520107565839640, -0.999521655150332090, -0.999523200236020480, -0.999524742822900820, +-0.999526282910969340, -0.999527820500222040, -0.999529355590655370, -0.999530888182265210, -0.999532418275047800, -0.999533945868999350, -0.999535470964116100, -0.999536993560394160, +-0.999538513657829750, -0.999540031256418990, -0.999541546356158220, -0.999543058957043540, -0.999544569059071190, -0.999546076662237380, -0.999547581766538570, -0.999549084371970650, +-0.999550584478530070, -0.999552082086212930, -0.999553577195015700, -0.999555069804934470, -0.999556559915965590, -0.999558047528105400, -0.999559532641350000, -0.999561015255695740, +-0.999562495371138950, -0.999563972987675960, -0.999565448105303010, -0.999566920724016540, -0.999568390843812660, -0.999569858464687820, -0.999571323586638360, -0.999572786209660610, +-0.999574246333750800, -0.999575703958905490, -0.999577159085120790, -0.999578611712393260, -0.999580061840719240, -0.999581509470095050, -0.999582954600517050, -0.999584397231981780, +-0.999585837364485360, -0.999587274998024470, -0.999588710132595320, -0.999590142768194360, -0.999591572904818150, -0.999593000542462920, -0.999594425681125220, -0.999595848320801510, +-0.999597268461488110, -0.999598686103181480, -0.999600101245878280, -0.999601513889574740, -0.999602924034267430, -0.999604331679952770, -0.999605736826627340, -0.999607139474287590, +-0.999608539622929950, -0.999609937272550990, -0.999611332423147150, -0.999612725074714990, -0.999614115227251080, -0.999615502880751740, -0.999616888035213760, -0.999618270690633580, +-0.999619650847007660, -0.999621028504332540, -0.999622403662605020, -0.999623776321821420, -0.999625146481978310, -0.999626514143072460, -0.999627879305100220, -0.999629241968058360, +-0.999630602131943320, -0.999631959796751790, -0.999633314962480420, -0.999634667629125670, -0.999636017796684320, -0.999637365465152920, -0.999638710634528140, -0.999640053304806540, +-0.999641393475984800, -0.999642731148059570, -0.999644066321027540, -0.999645398994885250, -0.999646729169629600, -0.999648056845257040, -0.999649382021764450, -0.999650704699148300, +-0.999652024877405340, -0.999653342556532490, -0.999654657736526180, -0.999655970417383190, -0.999657280599100310, -0.999658588281674310, -0.999659893465101760, -0.999661196149379430, +-0.999662496334504210, -0.999663794020472670, -0.999665089207281700, -0.999666381894927960, -0.999667672083408340, -0.999668959772719520, -0.999670244962858280, -0.999671527653821390, +-0.999672807845605750, -0.999674085538208020, -0.999675360731625110, -0.999676633425853780, -0.999677903620890930, -0.999679171316733230, -0.999680436513377680, -0.999681699210820950, +-0.999682959409060050, -0.999684217108091740, -0.999685472307912940, -0.999686725008520400, -0.999687975209911040, -0.999689222912081730, -0.999690468115029370, -0.999691710818750860, +-0.999692951023243070, -0.999694188728502910, -0.999695423934527260, -0.999696656641313130, -0.999697886848857300, -0.999699114557156760, -0.999700339766208420, -0.999701562476009160, +-0.999702782686556100, -0.999704000397846020, -0.999705215609876020, -0.999706428322642890, -0.999707638536143750, -0.999708846250375480, -0.999710051465335090, -0.999711254181019580, +-0.999712454397425950, -0.999713652114551210, -0.999714847332392350, -0.999716040050946280, -0.999717230270210200, -0.999718417990181020, -0.999719603210855730, -0.999720785932231460, +-0.999721966154305310, -0.999723143877074170, -0.999724319100535160, -0.999725491824685400, -0.999726662049521870, -0.999727829775041710, -0.999728995001242020, -0.999730157728119790, +-0.999731317955672160, -0.999732475683896230, -0.999733630912789110, -0.999734783642347910, -0.999735933872569870, -0.999737081603451870, -0.999738226834991140, -0.999739369567184900, +-0.999740509800030260, -0.999741647533524350, -0.999742782767664260, -0.999743915502447230, -0.999745045737870490, -0.999746173473931020, -0.999747298710626180, -0.999748421447953170, +-0.999749541685909020, -0.999750659424490930, -0.999751774663696360, -0.999752887403522190, -0.999753997643965890, -0.999755105385024660, -0.999756210626695620, -0.999757313368976000, +-0.999758413611863130, -0.999759511355354240, -0.999760606599446540, -0.999761699344137390, -0.999762789589423880, -0.999763877335303470, -0.999764962581773390, -0.999766045328830840, +-0.999767125576473180, -0.999768203324697740, -0.999769278573501840, -0.999770351322882720, -0.999771421572837720, -0.999772489323364040, -0.999773554574459270, -0.999774617326120610, +-0.999775677578345400, -0.999776735331130980, -0.999777790584474690, -0.999778843338373970, -0.999779893592826150, -0.999780941347828580, -0.999781986603378580, -0.999783029359473720, +-0.999784069616111220, -0.999785107373288630, -0.999786142631003180, -0.999787175389252440, -0.999788205648033720, -0.999789233407344490, -0.999790258667182190, -0.999791281427544250, +-0.999792301688428140, -0.999793319449831190, -0.999794334711750940, -0.999795347474184970, -0.999796357737130600, -0.999797365500585290, -0.999798370764546580, -0.999799373529011940, +-0.999800373793978790, -0.999801371559444820, -0.999802366825407350, -0.999803359591864060, -0.999804349858812280, -0.999805337626249680, -0.999806322894173700, -0.999807305662581910, +-0.999808285931471860, -0.999809263700841110, -0.999810238970687220, -0.999811211741007730, -0.999812182011800220, -0.999813149783062240, -0.999814115054791340, -0.999815077826985200, +-0.999816038099641370, -0.999816995872757410, -0.999817951146330990, -0.999818903920359660, -0.999819854194841100, -0.999820801969772850, -0.999821747245152710, -0.999822690020978120, +-0.999823630297246750, -0.999824568073956370, -0.999825503351104650, -0.999826436128689040, -0.999827366406707440, -0.999828294185157400, -0.999829219464036580, -0.999830142243342770, +-0.999831062523073520, -0.999831980303226730, -0.999832895583799840, -0.999833808364790850, -0.999834718646197330, -0.999835626428016930, -0.999836531710247560, -0.999837434492886760, +-0.999838334775932420, -0.999839232559382230, -0.999840127843234060, -0.999841020627485480, -0.999841910912134260, -0.999842798697178400, -0.999843683982615470, -0.999844566768443350, +-0.999845447054659830, -0.999846324841262790, -0.999847200128249790, -0.999848072915618840, -0.999848943203367700, -0.999849810991494170, -0.999850676279996240, -0.999851539068871480, +-0.999852399358117980, -0.999853257147733430, -0.999854112437715710, -0.999854965228062720, -0.999855815518772340, -0.999856663309842460, -0.999857508601270870, -0.999858351393055460, +-0.999859191685194220, -0.999860029477685040, -0.999860864770525710, -0.999861697563714350, -0.999862527857248610, -0.999863355651126610, -0.999864180945346240, -0.999865003739905390, +-0.999865824034801950, -0.999866641830034040, -0.999867457125599550, -0.999868269921496360, -0.999869080217722580, -0.999869888014276010, -0.999870693311154750, -0.999871496108356790, +-0.999872296405880050, -0.999873094203722610, -0.999873889501882380, -0.999874682300357480, -0.999875472599145780, -0.999876260398245510, -0.999877045697654570, -0.999877828497370950, +-0.999878608797392760, -0.999879386597718130, -0.999880161898344940, -0.999880934699271420, -0.999881705000495560, -0.999882472802015480, -0.999883238103829060, -0.999884000905934660, +-0.999884761208330250, -0.999885519011013970, -0.999886274313983800, -0.999887027117238090, -0.999887777420774610, -0.999888525224591820, -0.999889270528687700, -0.999890013333060490, +-0.999890753637708070, -0.999891491442628900, -0.999892226747820970, -0.999892959553282390, -0.999893689859011500, -0.999894417665006420, -0.999895142971265140, -0.999895865777786110, +-0.999896586084567440, -0.999897303891607360, -0.999898019198903860, -0.999898732006455400, -0.999899442314260090, -0.999900150122316260, -0.999900855430621900, -0.999901558239175480, +-0.999902258547975210, -0.999902956357019200, -0.999903651666305900, -0.999904344475833430, -0.999905034785600110, -0.999905722595604170, -0.999906407905843950, -0.999907090716317670, +-0.999907771027023660, -0.999908448837960260, -0.999909124149125810, -0.999909796960518400, -0.999910467272136620, -0.999911135083978550, -0.999911800396042770, -0.999912463208327500, +-0.999913123520830950, -0.999913781333551690, -0.999914436646487940, -0.999915089459638030, -0.999915739773000520, -0.999916387586573530, -0.999917032900355720, -0.999917675714345200, +-0.999918316028540640, -0.999918953842940160, -0.999919589157542310, -0.999920221972345540, -0.999920852287348170, -0.999921480102548670, -0.999922105417945460, -0.999922728233537010, +-0.999923348549321740, -0.999923966365298120, -0.999924581681464590, -0.999925194497819580, -0.999925804814361550, -0.999926412631089060, -0.999927017948000540, -0.999927620765094450, +-0.999928221082369340, -0.999928818899823660, -0.999929414217455960, -0.999930007035264690, -0.999930597353248410, -0.999931185171405670, -0.999931770489734920, -0.999932353308234710, +-0.999932933626903720, -0.999933511445740280, -0.999934086764743160, -0.999934659583910810, -0.999935229903241800, -0.999935797722734660, -0.999936363042388090, -0.999936925862200620, +-0.999937486182170820, -0.999938044002297240, -0.999938599322578560, -0.999939152143013430, -0.999939702463600420, -0.999940250284338190, -0.999940795605225310, -0.999941338426260430, +-0.999941878747442230, -0.999942416568769250, -0.999942951890240290, -0.999943484711853900, -0.999944015033608860, -0.999944542855503830, -0.999945068177537370, -0.999945590999708260, +-0.999946111322015160, -0.999946629144456760, -0.999947144467031810, -0.999947657289739000, -0.999948167612577100, -0.999948675435544660, -0.999949180758640700, -0.999949683581863650, +-0.999950183905212400, -0.999950681728685730, -0.999951177052282420, -0.999951669876001040, -0.999952160199840570, -0.999952648023799680, -0.999953133347877170, -0.999953616172071790, +-0.999954096496382450, -0.999954574320807810, -0.999955049645346760, -0.999955522469998080, -0.999955992794760550, -0.999956460619633060, -0.999956925944614490, -0.999957388769703530, +-0.999957849094899150, -0.999958306920200050, -0.999958762245605310, -0.999959215071113520, -0.999959665396723870, -0.999960113222434940, -0.999960558548245730, -0.999961001374155110, +-0.999961441700162100, -0.999961879526265360, -0.999962314852464010, -0.999962747678756810, -0.999963178005142780, -0.999963605831620810, -0.999964031158189770, -0.999964453984848680, +-0.999964874311596530, -0.999965292138432100, -0.999965707465354400, -0.999966120292362540, -0.999966530619455400, -0.999966938446631870, -0.999967343773890960, -0.999967746601231780, +-0.999968146928653100, -0.999968544756154150, -0.999968940083733830, -0.999969332911391230, -0.999969723239125140, -0.999970111066934900, -0.999970496394819270, -0.999970879222777500, +-0.999971259550808460, -0.999971637378911260, -0.999972012707085020, -0.999972385535328740, -0.999972755863641430, -0.999973123692022290, -0.999973489020470340, -0.999973851848984690, +-0.999974212177564330, -0.999974570006208490, -0.999974925334916280, -0.999975278163686700, -0.999975628492518860, -0.999975976321412000, -0.999976321650365210, -0.999976664479377610, +-0.999977004808448420, -0.999977342637576650, -0.999977677966761510, -0.999978010796002240, -0.999978341125297930, -0.999978668954647710, -0.999978994284050790, -0.999979317113506520, +-0.999979637443013880, -0.999979955272572110, -0.999980270602180530, -0.999980583431838270, -0.999980893761544420, -0.999981201591298440, -0.999981506921099440, -0.999981809750946750, +-0.999982110080839480, -0.999982407910776860, -0.999982703240758330, -0.999982996070783000, -0.999983286400850100, -0.999983574230959070, -0.999983859561109130, -0.999984142391299510, +-0.999984422721529540, -0.999984700551798560, -0.999984975882105780, -0.999985248712450540, -0.999985519042832170, -0.999985786873250020, -0.999986052203703400, -0.999986315034191660, +-0.999986575364714140, -0.999986833195270150, -0.999987088525859160, -0.999987341356480370, -0.999987591687133250, -0.999987839517817110, -0.999988084848531520, -0.999988327679275590, +-0.999988568010048870, -0.999988805840850700, -0.999989041171680530, -0.999989274002537790, -0.999989504333421820, -0.999989732164332070, -0.999989957495268090, -0.999990180326229110, +-0.999990400657214780, -0.999990618488224350, -0.999990833819257460, -0.999991046650313460, -0.999991256981391800, -0.999991464812492010, -0.999991670143613560, -0.999991872974756000, +-0.999992073305918770, -0.999992271137101210, -0.999992466468303090, -0.999992659299523750, -0.999992849630762850, -0.999993037462019730, -0.999993222793294060, -0.999993405624585390, +-0.999993585955893050, -0.999993763787216830, -0.999993939118556270, -0.999994111949910840, -0.999994282281280070, -0.999994450112663640, -0.999994615444060990, -0.999994778275471900, +-0.999994938606895810, -0.999995096438332400, -0.999995251769781320, -0.999995404601242030, -0.999995554932714190, -0.999995702764197580, -0.999995848095691640, -0.999995990927196040, +-0.999996131258710560, -0.999996269090234650, -0.999996404421768180, -0.999996537253310610, -0.999996667584861720, -0.999996795416421170, -0.999996920747988630, -0.999997043579563760, +-0.999997163911146350, -0.999997281742736050, -0.999997397074332440, -0.999997509905935390, -0.999997620237544570, -0.999997728069159650, -0.999997833400780520, -0.999997936232406740, +-0.999998036564038070, -0.999998134395674420, -0.999998229727315340, -0.999998322558960710, -0.999998412890610310, -0.999998500722263820, -0.999998586053921110, -0.999998668885581980, +-0.999998749217246070, -0.999998827048913410, -0.999998902380583640, -0.999998975212256560, -0.999999045543932150, -0.999999113375609980, -0.999999178707290160, -0.999999241538972350, +-0.999999301870656440, -0.999999359702342220, -0.999999415034029670, -0.999999467865718580, -0.999999518197408730, -0.999999566029100230, -0.999999611360792740, -0.999999654192486150, +-0.999999694524180470, -0.999999732355875580, -0.999999767687571370, -0.999999800519267730, -0.999999830850964670, -0.999999858682661950, -0.999999884014359570, -0.999999906846057440, +-0.999999927177755650, -0.999999945009453990, -0.999999960341152460, -0.999999973172851050, -0.999999983504549660, -0.999999991336248390, -0.999999996667947140, -0.999999999499645800, +-0.999999999831344580, -0.999999997663043260, -0.999999992994741960, -0.999999985826440780, -0.999999976158139510, -0.999999963989838370, -0.999999949321537350, -0.999999932153236350, +-0.999999912484935580, -0.999999890316635050, -0.999999865648334760, -0.999999838480034820, -0.999999808811735340, -0.999999776643436310, -0.999999741975137750, -0.999999704806839970, +-0.999999665138542880, -0.999999622970246580, -0.999999578301951190, -0.999999531133656920, -0.999999481465363880, -0.999999429297072080, -0.999999374628781630, -0.999999317460492860, +-0.999999257792205780, -0.999999195623920480, -0.999999130955637310, -0.999999063787356150, -0.999998994119077440, -0.999998921950801200, -0.999998847282527750, -0.999998770114257090, +-0.999998690445989550, -0.999998608277725240, -0.999998523609464510, -0.999998436441207340, -0.999998346772954180, -0.999998254604705040, -0.999998159936460350, -0.999998062768220230, +-0.999997963099985010, -0.999997860931754800, -0.999997756263530050, -0.999997649095310860, -0.999997539427097460, -0.999997427258890290, -0.999997312590689580, -0.999997195422495540, +-0.999997075754308520, -0.999996953586128830, -0.999996828917956710, -0.999996701749792600, -0.999996572081636610, -0.999996439913489300, -0.999996305245350880, -0.999996168077221690, +-0.999996028409102070, -0.999995886240992340, -0.999995741572892950, -0.999995594404804120, -0.999995444736726410, -0.999995292568660040, -0.999995137900605460, -0.999994980732562990, +-0.999994821064533080, -0.999994658896516180, -0.999994494228512610, -0.999994327060522830, -0.999994157392547160, -0.999993985224586160, -0.999993810556640160, -0.999993633388709610, +-0.999993453720794960, -0.999993271552896750, -0.999993086885015310, -0.999992899717151220, -0.999992710049304790, -0.999992517881476690, -0.999992323213667270, -0.999992126045876950, +-0.999991926378106410, -0.999991724210355980, -0.999991519542626330, -0.999991312374917780, -0.999991102707231020, -0.999990890539566470, -0.999990675871924810, -0.999990458704306360, +-0.999990239036711690, -0.999990016869141570, -0.999989792201596340, -0.999989565034076540, -0.999989335366582970, -0.999989103199116050, -0.999988868531676230, -0.999988631364264410, +-0.999988391696880920, -0.999988149529526530, -0.999987904862201680, -0.999987657694907050, -0.999987408027643300, -0.999987155860411090, -0.999986901193210990, -0.999986644026043540, +-0.999986384358909630, -0.999986122191809600, -0.999985857524744340, -0.999985590357714500, -0.999985320690720550, -0.999985048523763350, -0.999984773856843590, -0.999984496689961920, +-0.999984217023118900, -0.999983934856315430, -0.999983650189552040, -0.999983363022829530, -0.999983073356148670, -0.999982781189510120, -0.999982486522914550, -0.999982189356362850, +-0.999981889689855570, -0.999981587523393720, -0.999981282856977740, -0.999980975690608620, -0.999980666024287150, -0.999980353858013870, -0.999980039191789790, -0.999979722025615580, +-0.999979402359492120, -0.999979080193420080, -0.999978755527400340, -0.999978428361433800, -0.999978098695521120, -0.999977766529663190, -0.999977431863860900, -0.999977094698115020, +-0.999976755032426330, -0.999976412866795840, -0.999976068201224310, -0.999975721035712530, -0.999975371370261490, -0.999975019204872080, -0.999974664539545090, -0.999974307374281390, +-0.999973947709081880, -0.999973585543947660, -0.999973220878879410, -0.999972853713878010, -0.999972484048944570, -0.999972111884079970, -0.999971737219285010, -0.999971360054560670, +-0.999970980389908060, -0.999970598225327860, -0.999970213560821270, -0.999969826396389090, -0.999969436732032310, -0.999969044567752040, -0.999968649903549060, -0.999968252739424580, +-0.999967853075379390, -0.999967450911414590, -0.999967046247531080, -0.999966639083730070, -0.999966229420012340, -0.999965817256379120, -0.999965402592831400, -0.999964985429370070, +-0.999964565765996350, -0.999964143602711240, -0.999963718939515630, -0.999963291776410860, -0.999962862113397800, -0.999962429950477680, -0.999961995287651400, -0.999961558124920160, +-0.999961118462284970, -0.999960676299747050, -0.999960231637307410, -0.999959784474967140, -0.999959334812727470, -0.999958882650589410, -0.999958427988554280, -0.999957970826622970, +-0.999957511164796700, -0.999957049003076690, -0.999956584341464170, -0.999956117179960020, -0.999955647518565690, -0.999955175357282180, -0.999954700696110810, -0.999954223535052590, +-0.999953743874108850, -0.999953261713280810, -0.999952777052569460, -0.999952289891976380, -0.999951800231502430, -0.999951308071148960, -0.999950813410917290, -0.999950316250808660, +-0.999949816590824050, -0.999949314430965020, -0.999948809771232680, -0.999948302611628370, -0.999947792952153300, -0.999947280792808700, -0.999946766133595900, -0.999946248974516120, +-0.999945729315570800, -0.999945207156761160, -0.999944682498088430, -0.999944155339554160, -0.999943625681159350, -0.999943093522905560, -0.999942558864794000, -0.999942021706826000, +-0.999941482049003020, -0.999940939891326260, -0.999940395233797190, -0.999939848076417110, -0.999939298419187490, -0.999938746262109550, -0.999938191605184710, -0.999937634448414550, +-0.999937074791800160, -0.999936512635343110, -0.999935947979044840, -0.999935380822906560, -0.999934811166929950, -0.999934239011116330, -0.999933664355467040, -0.999933087199983640, +-0.999932507544667450, -0.999931925389520030, -0.999931340734542820, -0.999930753579737260, -0.999930163925104810, -0.999929571770646900, -0.999928977116365190, -0.999928379962260920, +-0.999927780308335730, -0.999927178154591090, -0.999926573501028540, -0.999925966347649520, -0.999925356694455590, -0.999924744541448310, -0.999924129888629110, -0.999923512735999550, +-0.999922893083561300, -0.999922270931315800, -0.999921646279264610, -0.999921019127409270, -0.999920389475751350, -0.999919757324292610, -0.999919122673034290, -0.999918485521978260, +-0.999917845871126090, -0.999917203720479210, -0.999916559070039290, -0.999915911919808110, -0.999915262269787000, -0.999914610119977840, -0.999913955470382090, -0.999913298321001510, +-0.999912638671837660, -0.999911976522892210, -0.999911311874166820, -0.999910644725663160, -0.999909975077382880, -0.999909302929327670, -0.999908628281499180, -0.999907951133899080, +-0.999907271486529140, -0.999906589339391030, -0.999905904692486520, -0.999905217545817180, -0.999904527899384780, -0.999903835753191080, -0.999903141107237770, -0.999902443961526610, +-0.999901744316059380, -0.999901042170837750, -0.999900337525863600, -0.999899630381138490, -0.999898920736664310, -0.999898208592442940, -0.999897493948475930, -0.999896776804765300, +-0.999896057161312690, -0.999895335018119890, -0.999894610375188790, -0.999893883232521150, -0.999893153590118770, -0.999892421447983510, -0.999891686806117290, -0.999890949664521740, +-0.999890210023198890, -0.999889467882150500, -0.999888723241378450, -0.999887976100884530, -0.999887226460670740, -0.999886474320738850, -0.999885719681090860, -0.999884962541728430, +-0.999884202902653670, -0.999883440763868370, -0.999882676125374510, -0.999881908987174000, -0.999881139349268590, -0.999880367211660400, -0.999879592574351330, -0.999878815437343250, +-0.999878035800638170, -0.999877253664237850, -0.999876469028144530, -0.999875681892360090, -0.999874892256886310, -0.999874100121725400, -0.999873305486879140, -0.999872508352349750, +-0.999871708718139020, -0.999870906584248930, -0.999870101950681710, -0.999869294817439140, -0.999868485184523430, -0.999867673051936470, -0.999866858419680260, -0.999866041287757020, +-0.999865221656168530, -0.999864399524917120, -0.999863574894004680, -0.999862747763433200, -0.999861918133205020, -0.999861086003321910, -0.999860251373786200, -0.999859414244599790, +-0.999858574615764770, -0.999857732487283490, -0.999856887859157720, -0.999856040731389780, -0.999855191103981800, -0.999854338976935760, -0.999853484350254010, -0.999852627223938420, +-0.999851767597991210, -0.999850905472414730, -0.999850040847210960, -0.999849173722382020, -0.999848304097930130, -0.999847431973857610, -0.999846557350166370, -0.999845680226858820, +-0.999844800603937100, -0.999843918481403300, -0.999843033859259660, -0.999842146737508490, -0.999841257116152020, -0.999840364995192350, -0.999839470374631830, -0.999838573254472560, +-0.999837673634716870, -0.999836771515366980, -0.999835866896425230, -0.999834959777893720, -0.999834050159774890, -0.999833138042070860, -0.999832223424784060, -0.999831306307916610, +-0.999830386691470950, -0.999829464575449410, -0.999828539959854100, -0.999827612844687460, -0.999826683229951830, -0.999825751115649420, -0.999824816501782680, -0.999823879388353930, +-0.999822939775365400, -0.999821997662819540, -0.999821053050718780, -0.999820105939065340, -0.999819156327861560, -0.999818204217109980, -0.999817249606812840, -0.999816292496972570, +-0.999815332887591610, -0.999814370778672300, -0.999813406170217080, -0.999812439062228280, -0.999811469454708450, -0.999810497347659920, -0.999809522741085140, -0.999808545634986560, +-0.999807566029366710, -0.999806583924227830, -0.999805599319572470, -0.999804612215403180, -0.999803622611722400, -0.999802630508532460, -0.999801635905836040, -0.999800638803635460, +-0.999799639201933270, -0.999798637100732020, -0.999797632500034170, -0.999796625399842260, -0.999795615800158740, -0.999794603700986270, -0.999793589102327180, -0.999792572004184250, +-0.999791552406559810, -0.999790530309456420, -0.999789505712876840, -0.999788478616823410, -0.999787449021298790, -0.999786416926305650, -0.999785382331846330, -0.999784345237923590, +-0.999783305644539990, -0.999782263551698190, -0.999781218959400640, -0.999780171867650110, -0.999779122276449160, -0.999778070185800340, -0.999777015595706420, -0.999775958506169850, +-0.999774898917193510, -0.999773836828779850, -0.999772772240931640, -0.999771705153651440, -0.999770635566942010, -0.999769563480806030, -0.999768488895246050, -0.999767411810264960, +-0.999766332225865310, -0.999765250142049760, -0.999764165558821080, -0.999763078476182070, -0.999761988894135370, -0.999760896812683650, -0.999759802231829700, -0.999758705151576280, +-0.999757605571926060, -0.999756503492881810, -0.999755398914446310, -0.999754291836622340, -0.999753182259412570, -0.999752070182819860, -0.999750955606847010, -0.999749838531496790, +-0.999748718956771980, -0.999747596882675340, -0.999746472309209770, -0.999745345236377920, -0.999744215664182810, -0.999743083592627090, -0.999741949021713650, -0.999740811951445370, +-0.999739672381825040, -0.999738530312855640, -0.999737385744539740, -0.999736238676880550, -0.999735089109880630, -0.999733937043542960, -0.999732782477870560, -0.999731625412866200, +-0.999730465848532760, -0.999729303784873120, -0.999728139221890190, -0.999726972159586950, -0.999725802597966280, -0.999724630537031200, -0.999723455976784470, -0.999722278917229090, +-0.999721099358367950, -0.999719917300204150, -0.999718732742740480, -0.999717545685980040, -0.999716356129925710, -0.999715164074580500, -0.999713969519947400, -0.999712772466029410, +-0.999711572912829420, -0.999710370860350530, -0.999709166308595740, -0.999707959257567950, -0.999706749707270360, -0.999705537657705870, -0.999704323108877470, -0.999703106060788270, +-0.999701886513441380, -0.999700664466839690, -0.999699439920986420, -0.999698212875884560, -0.999696983331537110, -0.999695751287947190, -0.999694516745117890, -0.999693279703052330, +-0.999692040161753610, -0.999690798121224740, -0.999689553581468940, -0.999688306542489190, -0.999687057004288620, -0.999685804966870540, -0.999684550430237850, -0.999683293394393770, +-0.999682033859341510, -0.999680771825084190, -0.999679507291624910, -0.999678240258966900, -0.999676970727113260, -0.999675698696067090, -0.999674424165831850, -0.999673147136410420, +-0.999671867607806240, -0.999670585580022310, -0.999669301053061950, -0.999668014026928290, -0.999666724501624640, -0.999665432477154110, -0.999664137953520050, -0.999662840930725660, +-0.999661541408774170, -0.999660239387668790, -0.999658934867412860, -0.999657627848009600, -0.999656318329462220, -0.999655006311774060, -0.999653691794948340, -0.999652374778988500, +-0.999651055263897640, -0.999649733249679210, -0.999648408736336310, -0.999647081723872510, -0.999645752212291020, -0.999644420201595050, -0.999643085691788170, -0.999641748682873480, +-0.999640409174854420, -0.999639067167734320, -0.999637722661516630, -0.999636375656204560, -0.999635026151801550, -0.999633674148311060, -0.999632319645736290, -0.999630962644080800, +-0.999629603143347810, -0.999628241143540870, -0.999626876644663320, -0.999625509646718590, -0.999624140149710130, -0.999622768153641260, -0.999621393658515430, -0.999620016664336200, +-0.999618637171106880, -0.999617255178831040, -0.999615870687512010, -0.999614483697153220, -0.999613094207758350, -0.999611702219330710, -0.999610307731873760, -0.999608910745391040, +-0.999607511259886120, -0.999606109275362420, -0.999604704791823400, -0.999603297809272600, -0.999601888327713680, -0.999600476347149880, -0.999599061867584960, -0.999597644889022360, +-0.999596225411465760, -0.999594803434918470, -0.999593378959384160, -0.999591951984866500, -0.999590522511368930, -0.999589090538895000, -0.999587656067448370, -0.999586219097032710, +-0.999584779627651350, -0.999583337659308070, -0.999581893192006520, -0.999580446225750150, -0.999578996760542740, -0.999577544796387830, -0.999576090333288980, -0.999574633371249970, +-0.999573173910274450, -0.999571711950365870, -0.999570247491528010, -0.999568780533764630, -0.999567311077079190, -0.999565839121475560, -0.999564364666957310, -0.999562887713528080, +-0.999561408261191780, -0.999559926309951830, -0.999558441859812130, -0.999556954910776230, -0.999555465462848130, -0.999553973516031150, -0.999552479070329400, -0.999550982125746330, +-0.999549482682285940, -0.999547980739951770, -0.999546476298747600, -0.999544969358677320, -0.999543459919744580, -0.999541947981953170, -0.999540433545306860, -0.999538916609809540, +-0.999537397175464970, -0.999535875242276830, -0.999534350810248990, -0.999532823879385360, -0.999531294449689580, -0.999529762521165650, -0.999528228093817250, -0.999526691167648250, +-0.999525151742662540, -0.999523609818864010, -0.999522065396256430, -0.999520518474843690, -0.999518969054629670, -0.999517417135618150, -0.999515862717813120, -0.999514305801218470, +-0.999512746385838090, -0.999511184471675750, -0.999509620058735560, -0.999508053147021180, -0.999506483736536830, -0.999504911827286180, -0.999503337419273220, -0.999501760512501950, +-0.999500181106976250, -0.999498599202700120, -0.999497014799677560, -0.999495427897912350, -0.999493838497408690, -0.999492246598170380, -0.999490652200201390, -0.999489055303505850, +-0.999487455908087630, -0.999485854013950850, -0.999484249621099270, -0.999482642729537240, -0.999481033339268520, -0.999479421450297220, -0.999477807062627340, -0.999476190176262990, +-0.999474570791208160, -0.999472948907466960, -0.999471324525043280, -0.999469697643941330, -0.999468068264165120, -0.999466436385718750, -0.999464802008606320, -0.999463165132831950, +-0.999461525758399530, -0.999459883885313370, -0.999458239513577480, -0.999456592643195970, -0.999454943274173060, -0.999453291406512730, -0.999451637040219110, -0.999449980175296520, +-0.999448320811748840, -0.999446658949580510, -0.999444994588795430, -0.999443327729397920, -0.999441658371392090, -0.999439986514782050, -0.999438312159572130, -0.999436635305766430, +-0.999434955953369060, -0.999433274102384360, -0.999431589752816430, -0.999429902904669600, -0.999428213557947980, -0.999426521712655780, -0.999424827368797340, -0.999423130526376770, +-0.999421431185398390, -0.999419729345866430, -0.999418025007785200, -0.999416318171158840, -0.999414608835991760, -0.999412897002288080, -0.999411182670052240, -0.999409465839288360, +-0.999407746510000860, -0.999406024682193970, -0.999404300355872130, -0.999402573531039450, -0.999400844207700260, -0.999399112385859100, -0.999397378065520090, -0.999395641246687560, +-0.999393901929366060, -0.999392160113559800, -0.999390415799273010, -0.999388668986510350, -0.999386919675275930, -0.999385167865574190, -0.999383413557409560, -0.999381656750786380, +-0.999379897445709100, -0.999378135642182030, -0.999376371340209620, -0.999374604539796320, -0.999372835240946440, -0.999371063443664550, -0.999369289147954980, -0.999367512353822150, +-0.999365733061270630, -0.999363951270304750, -0.999362166980928950, -0.999360380193147770, -0.999358590906965550, -0.999356799122386950, -0.999355004839416310, -0.999353208058058160, +-0.999351408778316960, -0.999349607000197260, -0.999347802723703600, -0.999345995948840440, -0.999344186675612200, -0.999342374904023560, -0.999340560634078940, -0.999338743865782920, +-0.999336924599140140, -0.999335102834154940, -0.999333278570831980, -0.999331451809175930, -0.999329622549191110, -0.999327790790882410, -0.999325956534254050, -0.999324119779310900, +-0.999322280526057430, -0.999320438774498280, -0.999318594524638000, -0.999316747776481270, -0.999314898530032520, -0.999313046785296750, -0.999311192542278180, -0.999309335800981800, +-0.999307476561411940, -0.999305614823573500, -0.999303750587470900, -0.999301883853109030, -0.999300014620492450, -0.999298142889625710, -0.999296268660513690, -0.999294391933161050, +-0.999292512707572360, -0.999290630983752480, -0.999288746761705980, -0.999286860041437520, -0.999284970822951980, -0.999283079106254020, -0.999281184891348430, -0.999279288178239740, +-0.999277388966932970, -0.999275487257432650, -0.999273583049743560, -0.999271676343870600, -0.999269767139818410, -0.999267855437591780, -0.999265941237195590, -0.999264024538634500, +-0.999262105341913400, -0.999260183647036950, -0.999258259454010030, -0.999256332762837540, -0.999254403573524240, -0.999252471886074910, -0.999250537700494320, -0.999248601016787470, +-0.999246661834959140, -0.999244720155014090, -0.999242775976957210, -0.999240829300793500, -0.999238880126527620, -0.999236928454164560, -0.999234974283709220, -0.999233017615166360, +-0.999231058448540990, -0.999229096783837980, -0.999227132621062330, -0.999225165960218710, -0.999223196801312220, -0.999221225144347750, -0.999219250989330290, -0.999217274336264620, +-0.999215295185155730, -0.999213313536008730, -0.999211329388828280, -0.999209342743619610, -0.999207353600387590, -0.999205361959137120, -0.999203367819873290, -0.999201371182601110, +-0.999199372047325340, -0.999197370414051210, -0.999195366282783710, -0.999193359653527740, -0.999191350526288380, -0.999189338901070760, -0.999187324777879640, -0.999185308156720240, +-0.999183289037597680, -0.999181267420516720, -0.999179243305482690, -0.999177216692500590, -0.999175187581575310, -0.999173155972712170, -0.999171121865916170, -0.999169085261192300, +-0.999167046158545680, -0.999165004557981520, -0.999162960459504810, -0.999160913863120780, -0.999158864768834420, -0.999156813176650840, -0.999154759086575250, -0.999152702498612880, +-0.999150643412768600, -0.999148581829047750, -0.999146517747455440, -0.999144451167996880, -0.999142382090677180, -0.999140310515501560, -0.999138236442475130, -0.999136159871603090, +-0.999134080802890680, -0.999131999236342990, -0.999129915171965370, -0.999127828609763010, -0.999125739549741040, -0.999123647991904670, -0.999121553936259230, -0.999119457382809940, +-0.999117358331561900, -0.999115256782520560, -0.999113152735691010, -0.999111046191078600, -0.999108937148688650, -0.999106825608526260, -0.999104711570596770, -0.999102595034905620, +-0.999100476001457900, -0.999098354470259080, -0.999096230441314350, -0.999094103914628940, -0.999091974890208400, -0.999089843368057840, -0.999087709348182700, -0.999085572830588300, +-0.999083433815279980, -0.999081292302263060, -0.999079148291542870, -0.999077001783124860, -0.999074852777014350, -0.999072701273216680, -0.999070547271737270, -0.999068390772581470, +-0.999066231775754710, -0.999064070281262430, -0.999061906289109850, -0.999059739799302630, -0.999057570811845990, -0.999055399326745470, -0.999053225344006420, -0.999051048863634270, +-0.999048869885634460, -0.999046688410012650, -0.999044504436773950, -0.999042317965924130, -0.999040128997468410, -0.999037937531412350, -0.999035743567761480, -0.999033547106521370, +-0.999031348147697230, -0.999029146691294830, -0.999026942737319510, -0.999024736285776820, -0.999022527336672290, -0.999020315890011500, -0.999018101945799870, -0.999015885504042970, +-0.999013666564746440, -0.999011445127915620, -0.999009221193556280, -0.999006994761673870, -0.999004765832273930, -0.999002534405362130, -0.999000300480944010, -0.998998064059025140, +-0.998995825139611050, -0.998993583722707410, -0.998991339808319890, -0.998989093396453920, -0.998986844487115280, -0.998984593080309510, -0.998982339176042180, -0.998980082774319160, +-0.998977823875145780, -0.998975562478527920, -0.998973298584471150, -0.998971032192981110, -0.998968763304063590, -0.998966491917724020, -0.998964218033968290, -0.998961941652802050, +-0.998959662774230870, -0.998957381398260620, -0.998955097524896860, -0.998952811154145360, -0.998950522286011890, -0.998948230920502000, -0.998945937057621580, -0.998943640697376400, +-0.998941341839772010, -0.998939040484814410, -0.998936736632509040, -0.998934430282861880, -0.998932121435878730, -0.998929810091565230, -0.998927496249927160, -0.998925179910970410, +-0.998922861074700630, -0.998920539741123830, -0.998918215910245540, -0.998915889582071780, -0.998913560756608310, -0.998911229433860900, -0.998908895613835450, -0.998906559296537710, +-0.998904220481973580, -0.998901879170148940, -0.998899535361069570, -0.998897189054741340, -0.998894840251170260, -0.998892488950361980, -0.998890135152322500, -0.998887778857057710, +-0.998885420064573370, -0.998883058774875600, -0.998880694987970160, -0.998878328703862950, -0.998875959922559840, -0.998873588644066950, -0.998871214868390030, -0.998868838595535210, +-0.998866459825508150, -0.998864078558314940, -0.998861694793961590, -0.998859308532453970, -0.998856919773798090, -0.998854528517999940, -0.998852134765065400, -0.998849738515000580, +-0.998847339767811480, -0.998844938523503870, -0.998842534782084070, -0.998840128543557750, -0.998837719807931230, -0.998835308575210410, -0.998832894845401390, -0.998830478618510040, +-0.998828059894542490, -0.998825638673504710, -0.998823214955402940, -0.998820788740243160, -0.998818360028031370, -0.998815928818773680, -0.998813495112476190, -0.998811058909145010, +-0.998808620208786140, -0.998806179011405670, -0.998803735317009720, -0.998801289125604510, -0.998798840437196020, -0.998796389251790480, -0.998793935569394000, -0.998791479390012670, +-0.998789020713652500, -0.998786559540319920, -0.998784095870020930, -0.998781629702761740, -0.998779161038548360, -0.998776689877387210, -0.998774216219284190, -0.998771740064245740, +-0.998769261412277950, -0.998766780263386830, -0.998764296617578930, -0.998761810474860230, -0.998759321835237080, -0.998756830698715570, -0.998754337065302030, -0.998751840935002470, +-0.998749342307823530, -0.998746841183771110, -0.998744337562851640, -0.998741831445071340, -0.998739322830436430, -0.998736811718953230, -0.998734298110627970, -0.998731782005466970, +-0.998729263403476450, -0.998726742304662850, -0.998724218709032390, -0.998721692616591380, -0.998719164027346170, -0.998716632941303080, -0.998714099358468330, -0.998711563278848360, +-0.998709024702449490, -0.998706483629278050, -0.998703940059340380, -0.998701393992642910, -0.998698845429191850, -0.998696294368993760, -0.998693740812054980, -0.998691184758381810, +-0.998688626207980600, -0.998686065160857890, -0.998683501617020020, -0.998680935576473420, -0.998678367039224410, -0.998675796005279450, -0.998673222474645180, -0.998670646447327730, +-0.998668067923333620, -0.998665486902669430, -0.998662903385341580, -0.998660317371356410, -0.998657728860720350, -0.998655137853440070, -0.998652544349521890, -0.998649948348972360, +-0.998647349851798040, -0.998644748858005250, -0.998642145367600650, -0.998639539380590690, -0.998636930896981800, -0.998634319916780640, -0.998631706439993660, -0.998629090466627510, +-0.998626471996688530, -0.998623851030183360, -0.998621227567118690, -0.998618601607500820, -0.998615973151336540, -0.998613342198632290, -0.998610708749394620, -0.998608072803630180, +-0.998605434361345630, -0.998602793422547430, -0.998600149987242340, -0.998597504055436790, -0.998594855627137570, -0.998592204702351110, -0.998589551281084180, -0.998586895363343440, +-0.998584236949135340, -0.998581576038466760, -0.998578912631344240, -0.998576246727774340, -0.998573578327763830, -0.998570907431319490, -0.998568234038447740, -0.998565558149155490, +-0.998562879763449370, -0.998560198881335960, -0.998557515502822120, -0.998554829627914420, -0.998552141256619730, -0.998549450388944710, -0.998546757024896040, -0.998544061164480360, +-0.998541362807704670, -0.998538661954575520, -0.998535958605099690, -0.998533252759284060, -0.998530544417135180, -0.998527833578660040, -0.998525120243865190, -0.998522404412757640, +-0.998519686085344140, -0.998516965261631250, -0.998514241941626080, -0.998511516125335290, -0.998508787812765640, -0.998506057003924030, -0.998503323698817340, -0.998500587897452330, +-0.998497849599835900, -0.998495108805974700, -0.998492365515875830, -0.998489619729546090, -0.998486871446992220, -0.998484120668221120, -0.998481367393239780, -0.998478611622055090, +-0.998475853354673810, -0.998473092591102840, -0.998470329331349270, -0.998467563575419770, -0.998464795323321440, -0.998462024575061060, -0.998459251330645610, -0.998456475590082100, +-0.998453697353377410, -0.998450916620538420, -0.998448133391572120, -0.998445347666485520, -0.998442559445285480, -0.998439768727979130, -0.998436975514573330, -0.998434179805075210, +-0.998431381599491520, -0.998428580897829270, -0.998425777700095770, -0.998422972006297700, -0.998420163816442270, -0.998417353130536370, -0.998414539948587200, -0.998411724270601540, +-0.998408906096586720, -0.998406085426549520, -0.998403262260497140, -0.998400436598436580, -0.998397608440374950, -0.998394777786319240, -0.998391944636276670, -0.998389108990254240, +-0.998386270848258930, -0.998383430210298070, -0.998380587076378560, -0.998377741446507700, -0.998374893320692400, -0.998372042698939870, -0.998369189581257200, -0.998366333967651620, +-0.998363475858130120, -0.998360615252699920, -0.998357752151368350, -0.998354886554142280, -0.998352018461028940, -0.998349147872035660, -0.998346274787169530, -0.998343399206437550, +-0.998340521129847280, -0.998337640557405590, -0.998334757489119820, -0.998331871924997170, -0.998328983865044760, -0.998326093309270020, -0.998323200257679950, -0.998320304710281990, +-0.998317406667083130, -0.998314506128090810, -0.998311603093312240, -0.998308697562754640, -0.998305789536425350, -0.998302879014331570, -0.998299965996480520, -0.998297050482879530, +-0.998294132473536040, -0.998291211968457160, -0.998288288967650320, -0.998285363471122620, -0.998282435478881620, -0.998279504990934540, -0.998276572007288700, -0.998273636527951310, +-0.998270698552929940, -0.998267758082231780, -0.998264815115864290, -0.998261869653834680, -0.998258921696150380, -0.998255971242818840, -0.998253018293847380, -0.998250062849243340, +-0.998247104909014140, -0.998244144473167230, -0.998241181541709930, -0.998238216114649690, -0.998235248191993830, -0.998232277773749900, -0.998229304859925340, -0.998226329450527360, +-0.998223351545563740, -0.998220371145041700, -0.998217388248968660, -0.998214402857352190, -0.998211414970199720, -0.998208424587518680, -0.998205431709316530, -0.998202436335600910, +-0.998199438466379150, -0.998196438101658810, -0.998193435241447440, -0.998190429885752350, -0.998187422034581330, -0.998184411687941700, -0.998181398845840890, -0.998178383508286800, +-0.998175365675286640, -0.998172345346848070, -0.998169322522978630, -0.998166297203685990, -0.998163269388977480, -0.998160239078860760, -0.998157206273343590, -0.998154170972433310, +-0.998151133176137680, -0.998148092884464160, -0.998145050097420490, -0.998142004815014030, -0.998138957037252750, -0.998135906764143990, -0.998132853995695400, -0.998129798731914760, +-0.998126740972809510, -0.998123680718387530, -0.998120617968656370, -0.998117552723623570, -0.998114484983296910, -0.998111414747684060, -0.998108342016792660, -0.998105266790630390, +-0.998102189069205000, -0.998099108852524180, -0.998096026140595450, -0.998092940933426710, -0.998089853231025730, -0.998086763033399940, -0.998083670340557340, -0.998080575152505590, +-0.998077477469252350, -0.998074377290805390, -0.998071274617172600, -0.998068169448361520, -0.998065061784380040, -0.998061951625235920, -0.998058838970936950, -0.998055723821490770, +-0.998052606176905390, -0.998049486037188460, -0.998046363402347870, -0.998043238272391280, -0.998040110647326560, -0.998036980527161720, -0.998033847911904300, -0.998030712801562410, +-0.998027575196143600, -0.998024435095655860, -0.998021292500107070, -0.998018147409505010, -0.998014999823857660, -0.998011849743172810, -0.998008697167458210, -0.998005542096721990, +-0.998002384530971900, -0.997999224470215830, -0.997996061914461660, -0.997992896863717390, -0.997989729317990790, -0.997986559277289960, -0.997983386741622790, -0.997980211710997040, +-0.997977034185420830, -0.997973854164901920, -0.997970671649448420, -0.997967486639068310, -0.997964299133769490, -0.997961109133559840, -0.997957916638447460, -0.997954721648440350, +-0.997951524163546380, -0.997948324183773550, -0.997945121709129970, -0.997941916739623510, -0.997938709275262400, -0.997935499316054410, -0.997932286862007740, -0.997929071913130290, +-0.997925854469430160, -0.997922634530915450, -0.997919412097594050, -0.997916187169474280, -0.997912959746563910, -0.997909729828871160, -0.997906497416404140, -0.997903262509170830, +-0.997900025107179460, -0.997896785210437900, -0.997893542818954370, -0.997890297932737090, -0.997887050551794050, -0.997883800676133360, -0.997880548305763120, -0.997877293440691650, +-0.997874036080926730, -0.997870776226476910, -0.997867513877350070, -0.997864249033554420, -0.997860981695098180, -0.997857711861989460, -0.997854439534236580, -0.997851164711847430, +-0.997847887394830550, -0.997844607583193710, -0.997841325276945580, -0.997838040476094030, -0.997834753180647400, -0.997831463390613900, -0.997828171106001750, -0.997824876326819040, +-0.997821579053074340, -0.997818279284775620, -0.997814977021931120, -0.997811672264549250, -0.997808365012638250, -0.997805055266206330, -0.997801743025261700, -0.997798428289812690, +-0.997795111059867620, -0.997791791335434830, -0.997788469116522530, -0.997785144403139150, -0.997781817195292800, -0.997778487492991920, -0.997775155296244830, -0.997771820605059870, +-0.997768483419445350, -0.997765143739409610, -0.997761801564961080, -0.997758456896107980, -0.997755109732858750, -0.997751760075221710, -0.997748407923205290, -0.997745053276817950, +-0.997741696136067780, -0.997738336500963550, -0.997734974371513370, -0.997731609747725790, -0.997728242629609240, -0.997724873017171940, -0.997721500910422550, -0.997718126309369510, +-0.997714749214021030, -0.997711369624385670, -0.997707987540471960, -0.997704602962288250, -0.997701215889843060, -0.997697826323144850, -0.997694434262201950, -0.997691039707023000, +-0.997687642657616560, -0.997684243113990950, -0.997680841076154730, -0.997677436544116340, -0.997674029517884420, -0.997670619997467420, -0.997667207982873890, -0.997663793474112380, +-0.997660376471191320, -0.997656956974119270, -0.997653534982904990, -0.997650110497556700, -0.997646683518083280, -0.997643254044493060, -0.997639822076794690, -0.997636387614996840, +-0.997632950659107950, -0.997629511209136790, -0.997626069265091790, -0.997622624826981610, -0.997619177894814800, -0.997615728468600140, -0.997612276548346060, -0.997608822134061430, +-0.997605365225754710, -0.997601905823434550, -0.997598443927109610, -0.997594979536788550, -0.997591512652480030, -0.997588043274192700, -0.997584571401935350, -0.997581097035716620, +-0.997577620175545080, -0.997574140821429480, -0.997570658973378490, -0.997567174631400880, -0.997563687795505310, -0.997560198465700650, -0.997556706641995360, -0.997553212324398420, +-0.997549715512918380, -0.997546216207564010, -0.997542714408344190, -0.997539210115267470, -0.997535703328342850, -0.997532194047578870, -0.997528682272984410, -0.997525168004568360, +-0.997521651242339270, -0.997518131986306120, -0.997514610236477580, -0.997511085992862530, -0.997507559255469740, -0.997504030024308210, -0.997500498299386470, -0.997496964080713530, +-0.997493427368298160, -0.997489888162149230, -0.997486346462275520, -0.997482802268686020, -0.997479255581389500, -0.997475706400394850, -0.997472154725710820, -0.997468600557346540, +-0.997465043895310770, -0.997461484739612380, -0.997457923090260160, -0.997454358947263200, -0.997450792310630390, -0.997447223180370490, -0.997443651556492620, -0.997440077439005650, +-0.997436500827918460, -0.997432921723240050, -0.997429340124979300, -0.997425756033145090, -0.997422169447746640, -0.997418580368792720, -0.997414988796292310, -0.997411394730254530, +-0.997407798170688140, -0.997404199117602250, -0.997400597571005960, -0.997396993530908160, -0.997393386997317940, -0.997389777970244080, -0.997386166449695910, -0.997382552435682300, +-0.997378935928212360, -0.997375316927294970, -0.997371695432939240, -0.997368071445154380, -0.997364444963949380, -0.997360815989333240, -0.997357184521315050, -0.997353550559903820, +-0.997349914105108760, -0.997346275156938970, -0.997342633715403440, -0.997338989780511390, -0.997335343352271810, -0.997331694430693920, -0.997328043015786700, -0.997324389107559490, +-0.997320732706021170, -0.997317073811181180, -0.997313412423048270, -0.997309748541632010, -0.997306082166941390, -0.997302413298985500, -0.997298741937773680, -0.997295068083314810, +-0.997291391735618430, -0.997287712894693530, -0.997284031560549340, -0.997280347733195070, -0.997276661412639930, -0.997272972598893250, -0.997269281291964020, -0.997265587491861560, +-0.997261891198595210, -0.997258192412174060, -0.997254491132607450, -0.997250787359904690, -0.997247081094074890, -0.997243372335127390, -0.997239661083071490, -0.997235947337916320, +-0.997232231099671410, -0.997228512368345870, -0.997224791143949130, -0.997221067426490300, -0.997217341215978940, -0.997213612512424130, -0.997209881315835320, -0.997206147626221840, +-0.997202411443592780, -0.997198672767957930, -0.997194931599326260, -0.997191187937707340, -0.997187441783110470, -0.997183693135545000, -0.997179941995020140, -0.997176188361545650, +-0.997172432235130520, -0.997168673615784430, -0.997164912503516580, -0.997161148898336510, -0.997157382800253460, -0.997153614209277060, -0.997149843125416660, -0.997146069548681460, +-0.997142293479081230, -0.997138514916625200, -0.997134733861323010, -0.997130950313183880, -0.997127164272217370, -0.997123375738432900, -0.997119584711840150, -0.997115791192448310, +-0.997111995180267050, -0.997108196675305810, -0.997104395677574030, -0.997100592187081360, -0.997096786203837130, -0.997092977727850990, -0.997089166759132390, -0.997085353297690770, +-0.997081537343535770, -0.997077718896677070, -0.997073897957123980, -0.997070074524886160, -0.997066248599973170, -0.997062420182394550, -0.997058589272159850, -0.997054755869278720, +-0.997050919973760720, -0.997047081585615390, -0.997043240704852400, -0.997039397331481280, -0.997035551465511590, -0.997031703106953100, -0.997027852255815360, -0.997023998912107910, +-0.997020143075840530, -0.997016284747022860, -0.997012423925664360, -0.997008560611774900, -0.997004694805363910, -0.997000826506441280, -0.996996955715016560, -0.996993082431099410, +-0.996989206654699590, -0.996985328385826760, -0.996981447624490700, -0.996977564370700950, -0.996973678624467290, -0.996969790385799250, -0.996965899654706940, -0.996962006431199920, +-0.996958110715287730, -0.996954212506980350, -0.996950311806287460, -0.996946408613218700, -0.996942502927783970, -0.996938594749993020, -0.996934684079855530, -0.996930770917381360, +-0.996926855262580290, -0.996922937115462090, -0.996919016476036530, -0.996915093344313390, -0.996911167720302530, -0.996907239604013730, -0.996903308995456870, -0.996899375894641730, +-0.996895440301578170, -0.996891502216275980, -0.996887561638744920, -0.996883618568995100, -0.996879673007036280, -0.996875724952878130, -0.996871774406530850, -0.996867821368004000, +-0.996863865837307680, -0.996859907814451660, -0.996855947299445820, -0.996851984292300150, -0.996848018793024430, -0.996844050801628740, -0.996840080318122990, -0.996836107342517040, +-0.996832131874820780, -0.996828153915044090, -0.996824173463197070, -0.996820190519289720, -0.996816205083331800, -0.996812217155333410, -0.996808226735304450, -0.996804233823255000, +-0.996800238419194850, -0.996796240523134200, -0.996792240135082940, -0.996788237255050950, -0.996784231883048430, -0.996780224019085390, -0.996776213663171820, -0.996772200815317590, +-0.996768185475532920, -0.996764167643827800, -0.996760147320212230, -0.996756124504696310, -0.996752099197290130, -0.996748071398003700, -0.996744041106847000, -0.996740008323830250, +-0.996735973048963550, -0.996731935282256790, -0.996727895023720280, -0.996723852273363910, -0.996719807031198110, -0.996715759297232660, -0.996711709071477880, -0.996707656353943760, +-0.996703601144640410, -0.996699543443578250, -0.996695483250767180, -0.996691420566217290, -0.996687355389939020, -0.996683287721942260, -0.996679217562237320, -0.996675144910834310, +-0.996671069767743440, -0.996666992132974830, -0.996662912006538890, -0.996658829388445520, -0.996654744278705150, -0.996650656677328000, -0.996646566584324160, -0.996642473999703740, +-0.996638378923477290, -0.996634281355654910, -0.996630181296246810, -0.996626078745263210, -0.996621973702714440, -0.996617866168610700, -0.996613756142962330, -0.996609643625779640, +-0.996605528617072740, -0.996601411116851970, -0.996597291125127850, -0.996593168641910390, -0.996589043667210020, -0.996584916201037060, -0.996580786243401740, -0.996576653794314480, +-0.996572518853785620, -0.996568381421825470, -0.996564241498444360, -0.996560099083652620, -0.996555954177460680, -0.996551806779878870, -0.996547656890917510, -0.996543504510587040, +-0.996539349638897680, -0.996535192275860070, -0.996531032421484440, -0.996526870075781220, -0.996522705238760850, -0.996518537910433650, -0.996514368090810180, -0.996510195779900850, +-0.996506020977715900, -0.996501843684265980, -0.996497663899561400, -0.996493481623612730, -0.996489296856430400, -0.996485109598024720, -0.996480919848406250, -0.996476727607585430, +-0.996472532875572910, -0.996468335652379020, -0.996464135938014310, -0.996459933732489310, -0.996455729035814470, -0.996451521848000120, -0.996447312169057130, -0.996443099998995830, +-0.996438885337826760, -0.996434668185560590, -0.996430448542207640, -0.996426226407778560, -0.996422001782284020, -0.996417774665734330, -0.996413545058140280, -0.996409312959512410, +-0.996405078369861140, -0.996400841289197260, -0.996396601717531310, -0.996392359654873830, -0.996388115101235370, -0.996383868056626600, -0.996379618521058270, -0.996375366494540950, +-0.996371111977085060, -0.996366854968701480, -0.996362595469400760, -0.996358333479193560, -0.996354068998090540, -0.996349802026102350, -0.996345532563239540, -0.996341260609512890, +-0.996336986164933270, -0.996332709229511120, -0.996328429803257090, -0.996324147886182070, -0.996319863478296600, -0.996315576579611560, -0.996311287190137620, -0.996306995309885420, +-0.996302700938865750, -0.996298404077089250, -0.996294104724566810, -0.996289802881309080, -0.996285498547326840, -0.996281191722630850, -0.996276882407231890, -0.996272570601140720, +-0.996268256304368220, -0.996263939516924930, -0.996259620238821860, -0.996255298470069660, -0.996250974210679320, -0.996246647460661490, -0.996242318220027180, -0.996237986488786920, +-0.996233652266951710, -0.996229315554532420, -0.996224976351539840, -0.996220634657984830, -0.996216290473878160, -0.996211943799230730, -0.996207594634053620, -0.996203242978357380, +-0.996198888832153130, -0.996194532195451510, -0.996190173068263630, -0.996185811450600370, -0.996181447342472600, -0.996177080743891110, -0.996172711654866980, -0.996168340075411110, +-0.996163966005534360, -0.996159589445247630, -0.996155210394562010, -0.996150828853488270, -0.996146444822037510, -0.996142058300220620, -0.996137669288048700, -0.996133277785532510, +-0.996128883792683160, -0.996124487309511530, -0.996120088336028720, -0.996115686872245720, -0.996111282918173410, -0.996106876473823010, -0.996102467539205390, -0.996098056114331550, +-0.996093642199212700, -0.996089225793859610, -0.996084806898283490, -0.996080385512495340, -0.996075961636506250, -0.996071535270327210, -0.996067106413969450, -0.996062675067443840, +-0.996058241230761480, -0.996053804903933580, -0.996049366086971260, -0.996044924779885380, -0.996040480982687270, -0.996036034695388040, -0.996031585917998560, -0.996027134650530170, +-0.996022680892994060, -0.996018224645401130, -0.996013765907762580, -0.996009304680089640, -0.996004840962393500, -0.996000374754685280, -0.995995906056976080, -0.995991434869277100, +-0.995986961191599570, -0.995982485023954590, -0.995978006366353470, -0.995973525218807330, -0.995969041581327370, -0.995964555453924700, -0.995960066836610760, -0.995955575729396640, +-0.995951082132293550, -0.995946586045312720, -0.995942087468465460, -0.995937586401763000, -0.995933082845216640, -0.995928576798837510, -0.995924068262636910, -0.995919557236626060, +-0.995915043720816410, -0.995910527715219150, -0.995906009219845620, -0.995901488234707030, -0.995896964759814710, -0.995892438795179970, -0.995887910340814140, -0.995883379396728550, +-0.995878845962934520, -0.995874310039443380, -0.995869771626266440, -0.995865230723415040, -0.995860687330900610, -0.995856141448734470, -0.995851593076927940, -0.995847042215492360, +-0.995842488864439270, -0.995837933023779990, -0.995833374693525840, -0.995828813873688270, -0.995824250564278700, -0.995819684765308470, -0.995815116476789000, -0.995810545698731620, +-0.995805972431148100, -0.995801396674049540, -0.995796818427447490, -0.995792237691353390, -0.995787654465778770, -0.995783068750734860, -0.995778480546233410, -0.995773889852285770, +-0.995769296668903350, -0.995764700996097710, -0.995760102833880280, -0.995755502182262610, -0.995750899041256240, -0.995746293410872620, -0.995741685291123170, -0.995737074682019550, +-0.995732461583573200, -0.995727845995795780, -0.995723227918698830, -0.995718607352293670, -0.995713984296591970, -0.995709358751605380, -0.995704730717345330, -0.995700100193823490, +-0.995695467181051510, -0.995690831679040710, -0.995686193687802870, -0.995681553207349630, -0.995676910237692450, -0.995672264778842960, -0.995667616830812730, -0.995662966393613620, +-0.995658313467257080, -0.995653658051754650, -0.995649000147118210, -0.995644339753359200, -0.995639676870489270, -0.995635011498520180, -0.995630343637463610, -0.995625673287331200, +-0.995621000448134620, -0.995616325119885510, -0.995611647302595550, -0.995606966996276490, -0.995602284200939990, -0.995597598916597830, -0.995592911143261650, -0.995588220880943230, +-0.995583528129654230, -0.995578832889406410, -0.995574135160211430, -0.995569434942081170, -0.995564732235027280, -0.995560027039061660, -0.995555319354195940, -0.995550609180441910, +-0.995545896517811450, -0.995541181366316090, -0.995536463725967940, -0.995531743596778540, -0.995527020978759670, -0.995522295871923310, -0.995517568276281350, -0.995512838191845330, +-0.995508105618627350, -0.995503370556638960, -0.995498633005892140, -0.995493892966398790, -0.995489150438170770, -0.995484405421219850, -0.995479657915557930, -0.995474907921196750, +-0.995470155438148430, -0.995465400466424730, -0.995460643006037430, -0.995455883056998610, -0.995451120619319950, -0.995446355693013540, -0.995441588278091260, -0.995436818374565100, +-0.995432045982446830, -0.995427271101748330, -0.995422493732481820, -0.995417713874658940, -0.995412931528291910, -0.995408146693392500, -0.995403359369972710, -0.995398569558044510, +-0.995393777257619910, -0.995388982468710880, -0.995384185191329430, -0.995379385425487430, -0.995374583171196980, -0.995369778428470080, -0.995364971197318820, -0.995360161477754970, +-0.995355349269790860, -0.995350534573438250, -0.995345717388709360, -0.995340897715616290, -0.995336075554170810, -0.995331250904385230, -0.995326423766271560, -0.995321594139841780, +-0.995316762025107990, -0.995311927422082410, -0.995307090330776800, -0.995302250751203600, -0.995297408683374800, -0.995292564127302380, -0.995287717082998680, -0.995282867550475570, +-0.995278015529745260, -0.995273161020819970, -0.995268304023711800, -0.995263444538432960, -0.995258582564995440, -0.995253718103411460, -0.995248851153693100, -0.995243981715852710, +-0.995239109789902380, -0.995234235375854090, -0.995229358473720400, -0.995224479083513300, -0.995219597205245000, -0.995214712838927600, -0.995209825984573530, -0.995204936642194780, +-0.995200044811803800, -0.995195150493412670, -0.995190253687033730, -0.995185354392679080, -0.995180452610361140, -0.995175548340091920, -0.995170641581883950, -0.995165732335749340, +-0.995160820601700410, -0.995155906379749270, -0.995150989669908560, -0.995146070472190280, -0.995141148786606980, -0.995136224613170640, -0.995131297951893700, -0.995126368802788600, +-0.995121437165867650, -0.995116503041143070, -0.995111566428627190, -0.995106627328332440, -0.995101685740271020, -0.995096741664455500, -0.995091795100898070, -0.995086846049611170, +-0.995081894510607130, -0.995076940483898390, -0.995071983969497250, -0.995067024967416280, -0.995062063477667680, -0.995057099500263890, -0.995052133035217220, -0.995047164082540350, +-0.995042192642245580, -0.995037218714345360, -0.995032242298852120, -0.995027263395778180, -0.995022282005136200, -0.995017298126938400, -0.995012311761197420, -0.995007322907925480, +-0.995002331567135470, -0.994997337738839470, -0.994992341423050260, -0.994987342619780170, -0.994982341329041730, -0.994977337550847270, -0.994972331285209570, -0.994967322532141150, +-0.994962311291654360, -0.994957297563761720, -0.994952281348475910, -0.994947262645809350, -0.994942241455774700, -0.994937217778384400, -0.994932191613650980, -0.994927162961587230, +-0.994922131822205460, -0.994917098195518430, -0.994912062081538710, -0.994907023480278710, -0.994901982391751090, -0.994896938815968750, -0.994891892752943870, -0.994886844202689360, +-0.994881793165217740, -0.994876739640541570, -0.994871683628673620, -0.994866625129626430, -0.994861564143412650, -0.994856500670045050, -0.994851434709536080, -0.994846366261898600, +-0.994841295327145160, -0.994836221905288530, -0.994831145996341370, -0.994826067600316110, -0.994820986717225960, -0.994815903347083250, -0.994810817489900740, -0.994805729145691320, +-0.994800638314467410, -0.994795544996242010, -0.994790449191027770, -0.994785350898837350, -0.994780250119683630, -0.994775146853579150, -0.994770041100536790, -0.994764932860569440, +-0.994759822133689740, -0.994754708919910470, -0.994749593219244500, -0.994744475031704380, -0.994739354357303210, -0.994734231196053640, -0.994729105547968450, -0.994723977413060510, +-0.994718846791342590, -0.994713713682827680, -0.994708578087528440, -0.994703440005457630, -0.994698299436628240, -0.994693156381053270, -0.994688010838745250, -0.994682862809717290, +-0.994677712293982160, -0.994672559291552740, -0.994667403802441790, -0.994662245826662520, -0.994657085364227590, -0.994651922415149990, -0.994646756979442490, -0.994641589057118190, +-0.994636418648189860, -0.994631245752670480, -0.994626070370572930, -0.994620892501910210, -0.994615712146695310, -0.994610529304941200, -0.994605343976660670, -0.994600156161866920, +-0.994594965860572610, -0.994589773072790840, -0.994584577798534820, -0.994579380037817320, -0.994574179790651320, -0.994568977057049940, -0.994563771837026040, -0.994558564130592740, +-0.994553353937763010, -0.994548141258549960, -0.994542926092966460, -0.994537708441025630, -0.994532488302740660, -0.994527265678124330, -0.994522040567189960, -0.994516812969950430, +-0.994511582886418830, -0.994506350316608280, -0.994501115260531980, -0.994495877718202800, -0.994490637689633970, -0.994485395174838470, -0.994480150173829510, -0.994474902686620200, +-0.994469652713223630, -0.994464400253652900, -0.994459145307921120, -0.994453887876041610, -0.994448627958027350, -0.994443365553891460, -0.994438100663647240, -0.994432833287307690, +-0.994427563424886030, -0.994422291076395460, -0.994417016241849310, -0.994411738921260450, -0.994406459114642320, -0.994401176822008130, -0.994395892043370870, -0.994390604778743970, +-0.994385315028140540, -0.994380022791573670, -0.994374728069056910, -0.994369430860603250, -0.994364131166226020, -0.994358828985938530, -0.994353524319753990, -0.994348217167685510, +-0.994342907529746520, -0.994337595405950350, -0.994332280796310090, -0.994326963700839170, -0.994321644119550930, -0.994316322052458460, -0.994310997499575300, -0.994305670460914560, +-0.994300340936489560, -0.994295008926313840, -0.994289674430400510, -0.994284337448763100, -0.994278997981414840, -0.994273656028369040, -0.994268311589639020, -0.994262964665238340, +-0.994257615255180190, -0.994252263359478030, -0.994246908978145160, -0.994241552111195140, -0.994236192758641170, -0.994230830920496690, -0.994225466596775130, -0.994220099787490040, +-0.994214730492654410, -0.994209358712282220, -0.994203984446386580, -0.994198607694980920, -0.994193228458078780, -0.994187846735693490, -0.994182462527838600, -0.994177075834527630, +-0.994171686655773930, -0.994166294991591150, -0.994160900841992490, -0.994155504206991610, -0.994150105086601950, -0.994144703480837060, -0.994139299389710460, -0.994133892813235390, +-0.994128483751425820, -0.994123072204294970, -0.994117658171856380, -0.994112241654123710, -0.994106822651110500, -0.994101401162830080, -0.994095977189296210, -0.994090550730522440, +-0.994085121786522310, -0.994079690357309360, -0.994074256442897150, -0.994068820043299330, -0.994063381158529440, -0.994057939788601130, -0.994052495933527850, -0.994047049593323460, +-0.994041600768001410, -0.994036149457575350, -0.994030695662058930, -0.994025239381465810, -0.994019780615809530, -0.994014319365103760, -0.994008855629362250, -0.994003389408598670, +-0.993997920702826550, -0.993992449512059670, -0.993986975836311680, -0.993981499675596130, -0.993976021029926990, -0.993970539899317610, -0.993965056283781960, -0.993959570183333700, +-0.993954081597986480, -0.993948590527754080, -0.993943096972650260, -0.993937600932688570, -0.993932102407882990, -0.993926601398247070, -0.993921097903794680, -0.993915591924539600, +-0.993910083460495470, -0.993904572511676190, -0.993899059078095500, -0.993893543159767080, -0.993888024756704900, -0.993882503868922520, -0.993876980496433910, -0.993871454639252970, +-0.993865926297393340, -0.993860395470868910, -0.993854862159693320, -0.993849326363880680, -0.993843788083444760, -0.993838247318399430, -0.993832704068758450, -0.993827158334535610, +-0.993821610115744990, -0.993816059412400370, -0.993810506224515500, -0.993804950552104380, -0.993799392395180780, -0.993793831753758910, -0.993788268627852300, -0.993782703017475180, +-0.993777134922641190, -0.993771564343364440, -0.993765991279658590, -0.993760415731537950, -0.993754837699016180, -0.993749257182107380, -0.993743674180825430, -0.993738088695184320, +-0.993732500725197920, -0.993726910270880340, -0.993721317332245450, -0.993715721909307130, -0.993710124002079700, -0.993704523610576820, -0.993698920734812810, -0.993693315374801320, +-0.993687707530556690, -0.993682097202092550, -0.993676484389423350, -0.993670869092562970, -0.993665251311525390, -0.993659631046324710, -0.993654008296974920, -0.993648383063490130, +-0.993642755345884310, -0.993637125144171680, -0.993631492458366130, -0.993625857288481850, -0.993620219634533060, -0.993614579496533650, -0.993608936874497810, -0.993603291768439640, +-0.993597644178373150, -0.993591994104312650, -0.993586341546272120, -0.993580686504265790, -0.993575028978307630, -0.993569368968411970, -0.993563706474592910, -0.993558041496864660, +-0.993552374035241210, -0.993546704089736780, -0.993541031660365560, -0.993535356747141880, -0.993529679350079740, -0.993523999469193450, -0.993518317104497120, -0.993512632256004950, +-0.993506944923731260, -0.993501255107690270, -0.993495562807896080, -0.993489868024363010, -0.993484170757105270, -0.993478471006137180, -0.993472768771472730, -0.993467064053126460, +-0.993461356851112590, -0.993455647165445210, -0.993449934996138760, -0.993444220343207450, -0.993438503206665600, -0.993432783586527530, -0.993427061482807350, -0.993421336895519700, +-0.993415609824678690, -0.993409880270298640, -0.993404148232393870, -0.993398413710978700, -0.993392676706067570, -0.993386937217674680, -0.993381195245814470, -0.993375450790501270, +-0.993369703851749390, -0.993363954429573370, -0.993358202523987430, -0.993352448135005890, -0.993346691262643300, -0.993340931906914080, -0.993335170067832340, -0.993329405745412730, +-0.993323638939669680, -0.993317869650617520, -0.993312097878270570, -0.993306323622643480, -0.993300546883750690, -0.993294767661606400, -0.993288985956225170, -0.993283201767621420, +-0.993277415095809800, -0.993271625940804540, -0.993265834302620390, -0.993260040181271450, -0.993254243576772500, -0.993248444489137850, -0.993242642918382270, -0.993236838864519970, +-0.993231032327565600, -0.993225223307533710, -0.993219411804438620, -0.993213597818295100, -0.993207781349117580, -0.993201962396920600, -0.993196140961718600, -0.993190317043526450, +-0.993184490642358360, -0.993178661758229110, -0.993172830391153230, -0.993166996541145260, -0.993161160208219650, -0.993155321392391270, -0.993149480093674650, -0.993143636312084240, +-0.993137790047634810, -0.993131941300340880, -0.993126090070217020, -0.993120236357278090, -0.993114380161538410, -0.993108521483012870, -0.993102660321715900, -0.993096796677662370, +-0.993090930550866950, -0.993085061941344050, -0.993079190849108560, -0.993073317274175030, -0.993067441216558320, -0.993061562676272880, -0.993055681653333690, -0.993049798147755180, +-0.993043912159552230, -0.993038023688739500, -0.993032132735331640, -0.993026239299343530, -0.993020343380789820, -0.993014444979685160, -0.993008544096044440, -0.993002640729882420, +-0.992996734881213760, -0.992990826550053220, -0.992984915736415670, -0.992979002440315780, -0.992973086661768420, -0.992967168400788360, -0.992961247657390360, -0.992955324431589180, +-0.992949398723399820, -0.992943470532836820, -0.992937539859915290, -0.992931606704649860, -0.992925671067055320, -0.992919732947146640, -0.992913792344938710, -0.992907849260446280, +-0.992901903693684140, -0.992895955644667370, -0.992890005113410520, -0.992884052099928800, -0.992878096604236870, -0.992872138626349820, -0.992866178166282420, -0.992860215224049440, +-0.992854249799666080, -0.992848281893147000, -0.992842311504507300, -0.992836338633761640, -0.992830363280925220, -0.992824385446012920, -0.992818405129039740, -0.992812422330020430, +-0.992806437048970090, -0.992800449285903610, -0.992794459040836070, -0.992788466313782370, -0.992782471104757480, -0.992776473413776510, -0.992770473240854320, -0.992764470586005920, +-0.992758465449246400, -0.992752457830590630, -0.992746447730053720, -0.992740435147650650, -0.992734420083396520, -0.992728402537306430, -0.992722382509395260, -0.992716359999678220, +-0.992710335008170070, -0.992704307534886250, -0.992698277579841750, -0.992692245143051430, -0.992686210224530520, -0.992680172824294100, -0.992674132942357180, -0.992668090578735060, +-0.992662045733442630, -0.992655998406495100, -0.992649948597907450, -0.992643896307695120, -0.992637841535872980, -0.992631784282456240, -0.992625724547460010, -0.992619662330899490, +-0.992613597632789670, -0.992607530453146090, -0.992601460791983640, -0.992595388649317400, -0.992589314025162820, -0.992583236919534980, -0.992577157332449000, -0.992571075263920080, +-0.992564990713963540, -0.992558903682594360, -0.992552814169828100, -0.992546722175679740, -0.992540627700164600, -0.992534530743297890, -0.992528431305094830, -0.992522329385570610, +-0.992516224984740680, -0.992510118102620240, -0.992504008739224400, -0.992497896894568580, -0.992491782568668100, -0.992485665761538070, -0.992479546473193920, -0.992473424703650850, +-0.992467300452924190, -0.992461173721029270, -0.992455044507981500, -0.992448912813796100, -0.992442778638488400, -0.992436641982073820, -0.992430502844567460, -0.992424361225984990, +-0.992418217126341600, -0.992412070545652720, -0.992405921483933580, -0.992399769941199720, -0.992393615917466330, -0.992387459412748970, -0.992381300427062960, -0.992375138960423620, +-0.992368975012846490, -0.992362808584346890, -0.992356639674940370, -0.992350468284642130, -0.992344294413467830, -0.992338118061432570, -0.992331939228552230, -0.992325757914842010, +-0.992319574120317460, -0.992313387844993900, -0.992307199088886870, -0.992301007852011810, -0.992294814134384250, -0.992288617936019750, -0.992282419256933610, -0.992276218097141280, +-0.992270014456658630, -0.992263808335500870, -0.992257599733683660, -0.992251388651222310, -0.992245175088132590, -0.992238959044429820, -0.992232740520129770, -0.992226519515247870, +-0.992220296029799660, -0.992214070063800690, -0.992207841617266610, -0.992201610690212840, -0.992195377282655060, -0.992189141394608900, -0.992182903026089690, -0.992176662177113420, +-0.992170418847695410, -0.992164173037851430, -0.992157924747596900, -0.992151673976947700, -0.992145420725919160, -0.992139164994527150, -0.992132906782787210, -0.992126646090715100, +-0.992120382918326270, -0.992114117265636590, -0.992107849132661480, -0.992101578519416830, -0.992095305425918280, -0.992089029852181280, -0.992082751798221810, -0.992076471264055510, +-0.992070188249697950, -0.992063902755164980, -0.992057614780472270, -0.992051324325635480, -0.992045031390670350, -0.992038735975592670, -0.992032438080418190, -0.992026137705162680, +-0.992019834849841690, -0.992013529514471190, -0.992007221699066850, -0.992000911403644440, -0.991994598628219810, -0.991988283372808530, -0.991981965637426690, -0.991975645422089820, +-0.991969322726813930, -0.991962997551614770, -0.991956669896507990, -0.991950339761509590, -0.991944007146635330, -0.991937672051901090, -0.991931334477322730, -0.991924994422915930, +-0.991918651888696770, -0.991912306874680790, -0.991905959380884220, -0.991899609407322690, -0.991893256954011980, -0.991886902020968300, -0.991880544608207400, -0.991874184715745070, +-0.991867822343597270, -0.991861457491779900, -0.991855090160308820, -0.991848720349200130, -0.991842348058469600, -0.991835973288133330, -0.991829596038206970, -0.991823216308706730, +-0.991816834099648380, -0.991810449411047900, -0.991804062242921390, -0.991797672595284620, -0.991791280468153680, -0.991784885861544670, -0.991778488775473370, -0.991772089209955850, +-0.991765687165008130, -0.991759282640646060, -0.991752875636885860, -0.991746466153743510, -0.991740054191235010, -0.991733639749376340, -0.991727222828183600, -0.991720803427672880, +-0.991714381547860070, -0.991707957188761260, -0.991701530350392550, -0.991695101032770030, -0.991688669235909810, -0.991682234959827880, -0.991675798204540440, -0.991669358970063360, +-0.991662917256412870, -0.991656473063605270, -0.991650026391656340, -0.991643577240582500, -0.991637125610399630, -0.991630671501123940, -0.991624214912771530, -0.991617755845358610, +-0.991611294298901380, -0.991604830273415840, -0.991598363768918190, -0.991591894785424640, -0.991585423322951410, -0.991578949381514580, -0.991572472961130380, -0.991565994061815000, +-0.991559512683584670, -0.991553028826455460, -0.991546542490443830, -0.991540053675565750, -0.991533562381837650, -0.991527068609275530, -0.991520572357895810, -0.991514073627714600, +-0.991507572418748210, -0.991501068731012740, -0.991494562564524840, -0.991488053919300390, -0.991481542795355940, -0.991475029192707580, -0.991468513111371630, -0.991461994551364300, +-0.991455473512702020, -0.991448949995401230, -0.991442423999477910, -0.991435895524948600, -0.991429364571829510, -0.991422831140137070, -0.991416295229887500, -0.991409756841097220, +-0.991403215973782450, -0.991396672627959720, -0.991390126803645240, -0.991383578500855570, -0.991377027719606900, -0.991370474459915660, -0.991363918721798190, -0.991357360505270900, +-0.991350799810350350, -0.991344236637052730, -0.991337670985394490, -0.991331102855392170, -0.991324532247061960, -0.991317959160420540, -0.991311383595484100, -0.991304805552269190, +-0.991298225030792350, -0.991291642031070010, -0.991285056553118490, -0.991278468596954340, -0.991271878162593990, -0.991265285250053860, -0.991258689859350620, -0.991252091990500680, +-0.991245491643520490, -0.991238888818426590, -0.991232283515235510, -0.991225675733963700, -0.991219065474627570, -0.991212452737243900, -0.991205837521829110, -0.991199219828399540, +-0.991192599656972150, -0.991185977007563170, -0.991179351880189240, -0.991172724274867020, -0.991166094191612720, -0.991159461630443440, -0.991152826591375490, -0.991146189074425420, +-0.991139549079609880, -0.991132906606945530, -0.991126261656448790, -0.991119614228136550, -0.991112964322025220, -0.991106311938131480, -0.991099657076471740, -0.991092999737063110, +-0.991086339919921900, -0.991079677625064880, -0.991073012852508710, -0.991066345602269920, -0.991059675874365160, -0.991053003668811440, -0.991046328985625060, -0.991039651824823010, +-0.991032972186421720, -0.991026290070437970, -0.991019605476888610, -0.991012918405790200, -0.991006228857159390, -0.990999536831013050, -0.990992842327367840, -0.990986145346240630, +-0.990979445887647970, -0.990972743951606840, -0.990966039538133670, -0.990959332647245450, -0.990952623278958940, -0.990945911433290800, -0.990939197110258020, -0.990932480309877130, +-0.990925761032165120, -0.990919039277138650, -0.990912315044814700, -0.990905588335209810, -0.990898859148340860, -0.990892127484224950, -0.990885393342878730, -0.990878656724318960, +-0.990871917628562530, -0.990865176055626410, -0.990858432005527150, -0.990851685478281950, -0.990844936473907590, -0.990838184992420820, -0.990831431033838640, -0.990824674598177800, +-0.990817915685455300, -0.990811154295688000, -0.990804390428892900, -0.990797624085086760, -0.990790855264286450, -0.990784083966509190, -0.990777310191771620, -0.990770533940090850, +-0.990763755211483630, -0.990756974005966960, -0.990750190323558040, -0.990743404164273640, -0.990736615528130640, -0.990729824415146120, -0.990723030825337080, -0.990716234758720500, +-0.990709436215313270, -0.990702635195132460, -0.990695831698195080, -0.990689025724518000, -0.990682217274118430, -0.990675406347013450, -0.990668592943219850, -0.990661777062754710, +-0.990654958705635250, -0.990648137871878220, -0.990641314561500950, -0.990634488774520430, -0.990627660510953630, -0.990620829770817780, -0.990613996554129740, -0.990607160860906830, +-0.990600322691165940, -0.990593482044924260, -0.990586638922198670, -0.990579793323006720, -0.990572945247365280, -0.990566094695291440, -0.990559241666802310, -0.990552386161915210, +-0.990545528180646890, -0.990538667723015020, -0.990531804789036350, -0.990524939378728210, -0.990518071492107690, -0.990511201129192110, -0.990504328289998460, -0.990497452974543950, +-0.990490575182845780, -0.990483694914921160, -0.990476812170787310, -0.990469926950461540, -0.990463039253960840, -0.990456149081302640, -0.990449256432504030, -0.990442361307582120, +-0.990435463706554550, -0.990428563629438210, -0.990421661076250510, -0.990414756047008570, -0.990407848541729810, -0.990400938560431430, -0.990394026103130760, -0.990387111169845010, +-0.990380193760591390, -0.990373273875387210, -0.990366351514250010, -0.990359426677196900, -0.990352499364245190, -0.990345569575412310, -0.990338637310715250, -0.990331702570171890, +-0.990324765353799100, -0.990317825661614530, -0.990310883493635390, -0.990303938849879000, -0.990296991730362790, -0.990290042135104080, -0.990283090064120190, -0.990276135517428660, +-0.990269178495046700, -0.990262218996991850, -0.990255257023281430, -0.990248292573932990, -0.990241325648963720, -0.990234356248391180, -0.990227384372232570, -0.990220410020505650, +-0.990213433193227740, -0.990206453890416280, -0.990199472112088590, -0.990192487858262300, -0.990185501128954650, -0.990178511924183380, -0.990171520243965820, -0.990164526088319290, +-0.990157529457261650, -0.990150530350810130, -0.990143528768982260, -0.990136524711795580, -0.990129518179267640, -0.990122509171415750, -0.990115497688257680, -0.990108483729810860, +-0.990101467296092940, -0.990094448387121240, -0.990087427002913410, -0.990080403143487110, -0.990073376808859760, -0.990066347999048910, -0.990059316714072100, -0.990052282953947200, +-0.990045246718691540, -0.990038208008322760, -0.990031166822858410, -0.990024123162316250, -0.990017077026713600, -0.990010028416068330, -0.990002977330398100, -0.989995923769720340, +-0.989988867734052810, -0.989981809223413060, -0.989974748237818840, -0.989967684777287690, -0.989960618841837390, -0.989953550431485580, -0.989946479546249700, -0.989939406186147730, +-0.989932330351197320, -0.989925252041416020, -0.989918171256821690, -0.989911087997431660, -0.989904002263264140, -0.989896914054336550, -0.989889823370666780, -0.989882730212272350, +-0.989875634579171160, -0.989868536471380840, -0.989861435888919170, -0.989854332831803910, -0.989847227300052810, -0.989840119293683540, -0.989833008812714190, -0.989825895857162190, +-0.989818780427045520, -0.989811662522381840, -0.989804542143188910, -0.989797419289484730, -0.989790293961287040, -0.989783166158613610, -0.989776035881482220, -0.989768903129910840, +-0.989761767903917120, -0.989754630203518950, -0.989747490028734300, -0.989740347379580830, -0.989733202256076420, -0.989726054658239150, -0.989718904586086690, -0.989711752039637020, +-0.989704597018908010, -0.989697439523917420, -0.989690279554683140, -0.989683117111223250, -0.989675952193555640, -0.989668784801698060, -0.989661614935668620, -0.989654442595485070, +-0.989647267781165410, -0.989640090492727610, -0.989632910730189550, -0.989625728493569110, -0.989618543782884500, -0.989611356598153470, -0.989604166939394130, -0.989596974806624340, +-0.989589780199862100, -0.989582583119125280, -0.989575383564432200, -0.989568181535800620, -0.989560977033248520, -0.989553770056794010, -0.989546560606455070, -0.989539348682249800, +-0.989532134284196060, -0.989524917412312080, -0.989517698066615830, -0.989510476247125070, -0.989503251953858350, -0.989496025186833440, -0.989488795946068530, -0.989481564231581620, +-0.989474330043390580, -0.989467093381513950, -0.989459854245969490, -0.989452612636775530, -0.989445368553949930, -0.989438121997510910, -0.989430872967476670, -0.989423621463865200, +-0.989416367486694700, -0.989409111035983170, -0.989401852111748800, -0.989394590714010040, -0.989387326842784630, -0.989380060498091020, -0.989372791679947180, -0.989365520388371330, +-0.989358246623381790, -0.989350970384996530, -0.989343691673233990, -0.989336410488112160, -0.989329126829649240, -0.989321840697863550, -0.989314552092773300, -0.989307261014396590, +-0.989299967462751730, -0.989292671437856930, -0.989285372939730510, -0.989278071968390680, -0.989270768523855650, -0.989263462606143620, -0.989256154215273020, -0.989248843351261950, +-0.989241530014128840, -0.989234214203891900, -0.989226895920569450, -0.989219575164179800, -0.989212251934741160, -0.989204926232271850, -0.989197598056790310, -0.989190267408314730, +-0.989182934286863320, -0.989175598692454750, -0.989168260625107210, -0.989160920084839020, -0.989153577071668510, -0.989146231585613990, -0.989138883626693890, -0.989131533194926640, +-0.989124180290330450, -0.989116824912923960, -0.989109467062725400, -0.989102106739753070, -0.989094743944025520, -0.989087378675561180, -0.989080010934378360, -0.989072640720495390, +-0.989065268033930910, -0.989057892874703250, -0.989050515242830940, -0.989043135138332200, -0.989035752561225780, -0.989028367511529780, -0.989020979989262970, -0.989013589994443780, +-0.989006197527090510, -0.988998802587221840, -0.988991405174856060, -0.988984005290011850, -0.988976602932707620, -0.988969198102961910, -0.988961790800793160, -0.988954381026219800, +-0.988946968779260690, -0.988939554059934060, -0.988932136868258540, -0.988924717204252790, -0.988917295067935020, -0.988909870459324210, -0.988902443378438690, -0.988895013825297100, +-0.988887581799917870, -0.988880147302319770, -0.988872710332521330, -0.988865270890540990, -0.988857828976397620, -0.988850384590109540, -0.988842937731695510, -0.988835488401174190, +-0.988828036598564110, -0.988820582323884030, -0.988813125577152400, -0.988805666358388070, -0.988798204667609370, -0.988790740504835290, -0.988783273870084360, -0.988775804763375230, +-0.988768333184726680, -0.988760859134157230, -0.988753382611685660, -0.988745903617330610, -0.988738422151110740, -0.988730938213044810, -0.988723451803151580, -0.988715962921449700, +-0.988708471567957940, -0.988700977742695050, -0.988693481445679700, -0.988685982676930420, -0.988678481436466420, -0.988670977724306230, -0.988663471540468520, -0.988655962884972150, +-0.988648451757835890, -0.988640938159078500, -0.988633422088718850, -0.988625903546775490, -0.988618382533267390, -0.988610859048213330, -0.988603333091632170, -0.988595804663542690, +-0.988588273763963740, -0.988580740392914100, -0.988573204550412420, -0.988565666236477900, -0.988558125451129200, -0.988550582194385190, -0.988543036466264620, -0.988535488266786610, +-0.988527937595969800, -0.988520384453833170, -0.988512828840395600, -0.988505270755675960, -0.988497710199693010, -0.988490147172465860, -0.988482581674013370, -0.988475013704354530, +-0.988467443263507990, -0.988459870351492850, -0.988452294968328090, -0.988444717114032590, -0.988437136788625330, -0.988429553992125180, -0.988421968724551240, -0.988414380985922270, +-0.988406790776257370, -0.988399198095575530, -0.988391602943895720, -0.988384005321236710, -0.988376405227617830, -0.988368802663058040, -0.988361197627576130, -0.988353590121191280, +-0.988345980143922390, -0.988338367695788420, -0.988330752776808710, -0.988323135387002120, -0.988315515526387630, -0.988307893194984470, -0.988300268392811490, -0.988292641119887900, +-0.988285011376232590, -0.988277379161864870, -0.988269744476803490, -0.988262107321068010, -0.988254467694677170, -0.988246825597650090, -0.988239181030006080, -0.988231533991764000, +-0.988223884482943070, -0.988216232503562500, -0.988208578053641370, -0.988200921133198680, -0.988193261742253860, -0.988185599880825770, -0.988177935548933740, -0.988170268746596860, +-0.988162599473834340, -0.988154927730665160, -0.988147253517108750, -0.988139576833184210, -0.988131897678910740, -0.988124216054307560, -0.988116531959393860, -0.988108845394188640, +-0.988101156358711540, -0.988093464852981440, -0.988085770877017660, -0.988078074430839500, -0.988070375514466190, -0.988062674127916930, -0.988054970271211030, -0.988047263944367590, +-0.988039555147406050, -0.988031843880345480, -0.988024130143205450, -0.988016413936005030, -0.988008695258763670, -0.988000974111500560, -0.987993250494234810, -0.987985524406986170, +-0.987977795849773630, -0.987970064822616620, -0.987962331325534460, -0.987954595358546460, -0.987946856921671950, -0.987939116014930340, -0.987931372638340970, -0.987923626791923140, +-0.987915878475696060, -0.987908127689679500, -0.987900374433892560, -0.987892618708354650, -0.987884860513085330, -0.987877099848103790, -0.987869336713429360, -0.987861571109081680, +-0.987853803035080080, -0.987846032491443980, -0.987838259478192810, -0.987830483995346010, -0.987822706042922990, -0.987814925620943310, -0.987807142729426160, -0.987799357368391080, +-0.987791569537857740, -0.987783779237845440, -0.987775986468373720, -0.987768191229462130, -0.987760393521129880, -0.987752593343396600, -0.987744790696282070, -0.987736985579805380, +-0.987729177993986410, -0.987721367938844350, -0.987713555414398980, -0.987705740420669610, -0.987697922957676000, -0.987690103025437470, -0.987682280623973670, -0.987674455753304150, +-0.987666628413448660, -0.987658798604426510, -0.987650966326257370, -0.987643131578960780, -0.987635294362556260, -0.987627454677063700, -0.987619612522502410, -0.987611767898892160, +-0.987603920806252480, -0.987596071244602910, -0.987588219213963230, -0.987580364714353070, -0.987572507745791860, -0.987564648308299490, -0.987556786401895370, -0.987548922026599390, +-0.987541055182431070, -0.987533185869410080, -0.987525314087556170, -0.987517439836888890, -0.987509563117428100, -0.987501683929193350, -0.987493802272204510, -0.987485918146481120, +-0.987478031552042950, -0.987470142488909630, -0.987462250957100940, -0.987454356956636750, -0.987446460487536590, -0.987438561549820130, -0.987430660143507440, -0.987422756268618080, +-0.987414849925171810, -0.987406941113188500, -0.987399029832687790, -0.987391116083689350, -0.987383199866213260, -0.987375281180279170, -0.987367360025906860, -0.987359436403116190, +-0.987351510311926920, -0.987343581752358810, -0.987335650724431860, -0.987327717228165700, -0.987319781263580110, -0.987311842830695290, -0.987303901929530770, -0.987295958560106550, +-0.987288012722442380, -0.987280064416558250, -0.987272113642473690, -0.987264160400209150, -0.987256204689784140, -0.987248246511218560, -0.987240285864532500, -0.987232322749745590, +-0.987224357166877950, -0.987216389115949440, -0.987208418596979830, -0.987200445609989210, -0.987192470154997450, -0.987184492232024650, -0.987176511841090560, -0.987168528982215190, +-0.987160543655418500, -0.987152555860720260, -0.987144565598140900, -0.987136572867700070, -0.987128577669417750, -0.987120580003314040, -0.987112579869408810, -0.987104577267722160, +-0.987096572198274180, -0.987088564661084630, -0.987080554656173730, -0.987072542183561330, -0.987064527243267650, -0.987056509835312680, -0.987048489959716500, -0.987040467616499000, +-0.987032442805680250, -0.987024415527280490, -0.987016385781319670, -0.987008353567817910, -0.987000318886795290, -0.986992281738271910, -0.986984242122267760, -0.986976200038803040, +-0.986968155487897850, -0.986960108469572160, -0.986952058983846190, -0.986944007030740140, -0.986935952610274110, -0.986927895722468200, -0.986919836367342480, -0.986911774544917190, +-0.986903710255212400, -0.986895643498248430, -0.986887574274045280, -0.986879502582623250, -0.986871428424002550, -0.986863351798203170, -0.986855272705245420, -0.986847191145149520, +-0.986839107117935650, -0.986831020623623820, -0.986822931662234670, -0.986814840233788180, -0.986806746338304560, -0.986798649975804020, -0.986790551146306870, -0.986782449849833320, +-0.986774346086403690, -0.986766239856038170, -0.986758131158757100, -0.986750019994580670, -0.986741906363529210, -0.986733790265623020, -0.986725671700882320, -0.986717550669327430, +-0.986709427170978540, -0.986701301205856200, -0.986693172773980610, -0.986685041875372090, -0.986676908510050970, -0.986668772678037650, -0.986660634379352140, -0.986652493614015300, +-0.986644350382047120, -0.986636204683468130, -0.986628056518298550, -0.986619905886558900, -0.986611752788269510, -0.986603597223450700, -0.986595439192122890, -0.986587278694306510, +-0.986579115730021770, -0.986570950299289430, -0.986562782402129690, -0.986554612038562870, -0.986546439208609740, -0.986538263912290160, -0.986530086149625230, -0.986521905920635040, +-0.986513723225340030, -0.986505538063760730, -0.986497350435917570, -0.986489160341831100, -0.986480967781521720, -0.986472772755009890, -0.986464575262316120, -0.986456375303460750, +-0.986448172878464650, -0.986439967987348120, -0.986431760630131600, -0.986423550806835750, -0.986415338517480980, -0.986407123762087720, -0.986398906540676860, -0.986390686853268580, +-0.986382464699883780, -0.986374240080542640, -0.986366012995266050, -0.986357783444074320, -0.986349551426988210, -0.986341316944028160, -0.986333079995214690, -0.986324840580568680, +-0.986316598700110570, -0.986308354353860990, -0.986300107541840500, -0.986291858264069620, -0.986283606520569120, -0.986275352311359650, -0.986267095636461870, -0.986258836495896300, +-0.986250574889683710, -0.986242310817844640, -0.986234044280399740, -0.986225775277369760, -0.986217503808775380, -0.986209229874637110, -0.986200953474975830, -0.986192674609812300, +-0.986184393279166960, -0.986176109483060670, -0.986167823221514080, -0.986159534494547850, -0.986151243302182960, -0.986142949644439830, -0.986134653521339440, -0.986126354932902350, +-0.986118053879149410, -0.986109750360101290, -0.986101444375778850, -0.986093135926202740, -0.986084825011393830, -0.986076511631372780, -0.986068195786160450, -0.986059877475777720, +-0.986051556700245360, -0.986043233459584000, -0.986034907753814420, -0.986026579582957810, -0.986018248947034600, -0.986009915846065900, -0.986001580280072340, -0.985993242249074920, +-0.985984901753094280, -0.985976558792151400, -0.985968213366267170, -0.985959865475462440, -0.985951515119757870, -0.985943162299174560, -0.985934807013733480, -0.985926449263455300, +-0.985918089048361090, -0.985909726368471520, -0.985901361223807670, -0.985892993614390420, -0.985884623540240760, -0.985876251001379430, -0.985867875997827550, -0.985859498529605970, +-0.985851118596735690, -0.985842736199237570, -0.985834351337132600, -0.985825964010441650, -0.985817574219185920, -0.985809181963386290, -0.985800787243063640, -0.985792390058239040, +-0.985783990408933500, -0.985775588295167760, -0.985767183716963260, -0.985758776674340750, -0.985750367167321340, -0.985741955195926000, -0.985733540760175830, -0.985725123860091700, +-0.985716704495694820, -0.985708282667006270, -0.985699858374046720, -0.985691431616837700, -0.985683002395400190, -0.985674570709755060, -0.985666136559923630, -0.985657699945926780, +-0.985649260867785480, -0.985640819325521280, -0.985632375319154930, -0.985623928848707750, -0.985615479914200730, -0.985607028515654960, -0.985598574653091640, -0.985590118326531870, +-0.985581659535996750, -0.985573198281507580, -0.985564734563085240, -0.985556268380751170, -0.985547799734526550, -0.985539328624432280, -0.985530855050489760, -0.985522379012720000, +-0.985513900511144400, -0.985505419545783970, -0.985496936116660120, -0.985488450223793830, -0.985479961867206540, -0.985471471046919230, -0.985462977762953220, -0.985454482015329810, +-0.985445983804070220, -0.985437483129195550, -0.985428979990727320, -0.985420474388686520, -0.985411966323094690, -0.985403455793972820, -0.985394942801342430, -0.985386427345224410, +-0.985377909425640520, -0.985369389042611950, -0.985360866196159810, -0.985352340886305520, -0.985343813113070290, -0.985335282876475650, -0.985326750176542810, -0.985318215013293090, +-0.985309677386747570, -0.985301137296928140, -0.985292594743855780, -0.985284049727552010, -0.985275502248038060, -0.985266952305335340, -0.985258399899465060, -0.985249845030448990, +-0.985241287698308320, -0.985232727903064490, -0.985224165644738690, -0.985215600923352590, -0.985207033738927480, -0.985198464091484700, -0.985189891981045780, -0.985181317407632040, +-0.985172740371265120, -0.985164160871966450, -0.985155578909757250, -0.985146994484659140, -0.985138407596693580, -0.985129818245881750, -0.985121226432245640, -0.985112632155806470, +-0.985104035416585640, -0.985095436214604710, -0.985086834549885220, -0.985078230422448690, -0.985069623832316550, -0.985061014779510360, -0.985052403264051630, -0.985043789285961700, +-0.985035172845262540, -0.985026553941975360, -0.985017932576121910, -0.985009308747723520, -0.985000682456801720, -0.984992053703378390, -0.984983422487474950, -0.984974788809112930, +-0.984966152668313890, -0.984957514065099460, -0.984948872999491300, -0.984940229471510940, -0.984931583481180040, -0.984922935028520240, -0.984914284113552860, -0.984905630736299890, +-0.984896974896782850, -0.984888316595023520, -0.984879655831043200, -0.984870992604863660, -0.984862326916506880, -0.984853658765994180, -0.984844988153347420, -0.984836315078588150, +-0.984827639541738020, -0.984818961542818890, -0.984810281081852310, -0.984801598158860040, -0.984792912773863720, -0.984784224926885110, -0.984775534617945980, -0.984766841847067980, +-0.984758146614272970, -0.984749448919582490, -0.984740748763018540, -0.984732046144602410, -0.984723341064356440, -0.984714633522302040, -0.984705923518461090, -0.984697211052855350, +-0.984688496125506460, -0.984679778736436530, -0.984671058885666970, -0.984662336573219890, -0.984653611799116700, -0.984644884563379730, -0.984636154866030510, -0.984627422707090920, +-0.984618688086582820, -0.984609951004527860, -0.984601211460948030, -0.984592469455865200, -0.984583724989301250, -0.984574978061278030, -0.984566228671817310, -0.984557476820941080, +-0.984548722508671090, -0.984539965735029330, -0.984531206500037560, -0.984522444803717760, -0.984513680646091900, -0.984504914027181880, -0.984496144947009650, -0.984487373405597000, +-0.984478599402965890, -0.984469822939138100, -0.984461044014135920, -0.984452262627981130, -0.984443478780695820, -0.984434692472301640, -0.984425903702820790, -0.984417112472275260, +-0.984408318780686800, -0.984399522628077620, -0.984390724014469700, -0.984381922939884690, -0.984373119404345130, -0.984364313407872670, -0.984355504950489510, -0.984346694032217530, +-0.984337880653078700, -0.984329064813095340, -0.984320246512289330, -0.984311425750682640, -0.984302602528297490, -0.984293776845155730, -0.984284948701279580, -0.984276118096691020, +-0.984267285031412140, -0.984258449505465150, -0.984249611518871800, -0.984240771071654640, -0.984231928163835420, -0.984223082795436580, -0.984214234966479860, -0.984205384676987590, +-0.984196531926981750, -0.984187676716484770, -0.984178819045518520, -0.984169958914105300, -0.984161096322267110, -0.984152231270026160, -0.984143363757404740, -0.984134493784424860, +-0.984125621351108700, -0.984116746457478380, -0.984107869103556300, -0.984098989289364570, -0.984090107014925390, -0.984081222280260960, -0.984072335085393490, -0.984063445430344960, +-0.984054553315137910, -0.984045658739794660, -0.984036761704337180, -0.984027862208787680, -0.984018960253168710, -0.984010055837502230, -0.984001148961810680, -0.983992239626116150, +-0.983983327830440960, -0.983974413574807640, -0.983965496859238180, -0.983956577683755000, -0.983947656048380410, -0.983938731953136750, -0.983929805398045980, -0.983920876383130860, +-0.983911944908413600, -0.983903010973916530, -0.983894074579661830, -0.983885135725672040, -0.983876194411969270, -0.983867250638576160, -0.983858304405514810, -0.983849355712807850, +-0.983840404560477170, -0.983831450948545740, -0.983822494877035660, -0.983813536345969350, -0.983804575355369140, -0.983795611905257440, -0.983786645995656790, -0.983777677626589520, +-0.983768706798078150, -0.983759733510144900, -0.983750757762812400, -0.983741779556102980, -0.983732798890039060, -0.983723815764643180, -0.983714830179937770, -0.983705842135945140, +-0.983696851632688050, -0.983687858670188820, -0.983678863248469980, -0.983669865367553960, -0.983660865027463300, -0.983651862228220320, -0.983642856969847770, -0.983633849252368190, +-0.983624839075803890, -0.983615826440177530, -0.983606811345511530, -0.983597793791828660, -0.983588773779151220, -0.983579751307501750, -0.983570726376902900, -0.983561698987377330, +-0.983552669138947460, -0.983543636831636040, -0.983534602065465390, -0.983525564840458390, -0.983516525156637230, -0.983507483014024910, -0.983498438412643840, -0.983489391352516780, +-0.983480341833666170, -0.983471289856114760, -0.983462235419885090, -0.983453178524999800, -0.983444119171481560, -0.983435057359352880, -0.983425993088636760, -0.983416926359355630, +-0.983407857171532230, -0.983398785525189110, -0.983389711420349140, -0.983380634857034640, -0.983371555835268700, -0.983362474355073960, -0.983353390416472960, -0.983344304019488470, +-0.983335215164143240, -0.983326123850460030, -0.983317030078461380, -0.983307933848170280, -0.983298835159609360, -0.983289734012801060, -0.983280630407768700, -0.983271524344534690, +-0.983262415823121900, -0.983253304843553110, -0.983244191405850840, -0.983235075510038300, -0.983225957156138030, -0.983216836344172900, -0.983207713074165660, -0.983198587346139190, +-0.983189459160116240, -0.983180328516119580, -0.983171195414172080, -0.983162059854296720, -0.983152921836515930, -0.983143781360853010, -0.983134638427330730, -0.983125493035971740, +-0.983116345186799130, -0.983107194879835560, -0.983098042115103880, -0.983088886892627300, -0.983079729212428370, -0.983070569074530280, -0.983061406478955680, -0.983052241425727560, +-0.983043073914868890, -0.983033903946402440, -0.983024731520351300, -0.983015556636738230, -0.983006379295586320, -0.982997199496918440, -0.982988017240757680, -0.982978832527126810, +-0.982969645356048920, -0.982960455727546640, -0.982951263641643540, -0.982942069098362130, -0.982932872097725620, -0.982923672639756880, -0.982914470724479020, -0.982905266351915000, +-0.982896059522087810, -0.982886850235020430, -0.982877638490735730, -0.982868424289257140, -0.982859207630607520, -0.982849988514809760, -0.982840766941887160, -0.982831542911862590, +-0.982822316424759030, -0.982813087480599810, -0.982803856079407900, -0.982794622221206390, -0.982785385906018270, -0.982776147133866630, -0.982766905904774670, -0.982757662218765480, +-0.982748416075862160, -0.982739167476087690, -0.982729916419465170, -0.982720662906018120, -0.982711406935769300, -0.982702148508742050, -0.982692887624959320, -0.982683624284444330, +-0.982674358487220400, -0.982665090233310500, -0.982655819522737950, -0.982646546355525840, -0.982637270731697380, -0.982627992651275760, -0.982618712114284090, -0.982609429120745670, +-0.982600143670683710, -0.982590855764121200, -0.982581565401081770, -0.982572272581588300, -0.982562977305664220, -0.982553679573332730, -0.982544379384617030, -0.982535076739540210, +-0.982525771638125820, -0.982516464080397060, -0.982507154066377120, -0.982497841596089330, -0.982488526669556880, -0.982479209286803100, -0.982469889447851300, -0.982460567152724780, +-0.982451242401446770, -0.982441915194040780, -0.982432585530529920, -0.982423253410937610, -0.982413918835287280, -0.982404581803602020, -0.982395242315905250, -0.982385900372220510, +-0.982376555972571010, -0.982367209116980060, -0.982357859805471190, -0.982348508038067610, -0.982339153814792750, -0.982329797135670040, -0.982320438000722880, -0.982311076409974390, +-0.982301712363448320, -0.982292345861168090, -0.982282976903156910, -0.982273605489438320, -0.982264231620035730, -0.982254855294972360, -0.982245476514272080, -0.982236095277958080, +-0.982226711586053790, -0.982217325438582870, -0.982207936835568510, -0.982198545777034360, -0.982189152263003740, -0.982179756293500410, -0.982170357868547560, -0.982160956988168630, +-0.982151553652387600, -0.982142147861227550, -0.982132739614712260, -0.982123328912865020, -0.982113915755709390, -0.982104500143269000, -0.982095082075567500, -0.982085661552628220, +-0.982076238574474790, -0.982066813141130760, -0.982057385252619760, -0.982047954908965240, -0.982038522110190830, -0.982029086856320180, -0.982019649147376610, -0.982010208983383980, +-0.982000766364365950, -0.981991321290345940, -0.981981873761347710, -0.981972423777394800, -0.981962971338510520, -0.981953516444719070, -0.981944059096043880, -0.981934599292508480, +-0.981925137034136640, -0.981915672320951890, -0.981906205152978000, -0.981896735530238600, -0.981887263452757340, -0.981877788920557770, -0.981868311933663860, -0.981858832492099150, +-0.981849350595887400, -0.981839866245052260, -0.981830379439617480, -0.981820890179606610, -0.981811398465043620, -0.981801904295952150, -0.981792407672355980, -0.981782908594278750, +-0.981773407061744210, -0.981763903074776230, -0.981754396633398470, -0.981744887737634690, -0.981735376387508520, -0.981725862583044060, -0.981716346324264970, -0.981706827611194990, +-0.981697306443858000, -0.981687782822277750, -0.981678256746477800, -0.981668728216482430, -0.981659197232315210, -0.981649663793999980, -0.981640127901560630, -0.981630589555021030, +-0.981621048754404810, -0.981611505499736080, -0.981601959791038480, -0.981592411628336100, -0.981582861011652490, -0.981573307941011830, -0.981563752416438010, -0.981554194437954660, +-0.981544634005586000, -0.981535071119355450, -0.981525505779287430, -0.981515937985405710, -0.981506367737734030, -0.981496795036296500, -0.981487219881116980, -0.981477642272219450, +-0.981468062209627790, -0.981458479693365860, -0.981448894723457870, -0.981439307299927450, -0.981429717422798940, -0.981420125092096090, -0.981410530307842980, -0.981400933070063490, +-0.981391333378781710, -0.981381731234021390, -0.981372126635806860, -0.981362519584162100, -0.981352910079111070, -0.981343298120677670, -0.981333683708886070, -0.981324066843760280, +-0.981314447525324370, -0.981304825753602230, -0.981295201528617930, -0.981285574850395800, -0.981275945718959710, -0.981266314134333740, -0.981256680096541990, -0.981247043605608550, +-0.981237404661557290, -0.981227763264412740, -0.981218119414198790, -0.981208473110939510, -0.981198824354659100, -0.981189173145381570, -0.981179519483131200, -0.981169863367931880, +-0.981160204799808030, -0.981150543778783410, -0.981140880304882670, -0.981131214378129670, -0.981121545998548730, -0.981111875166163830, -0.981102201880999280, -0.981092526143079070, +-0.981082847952427730, -0.981073167309069240, -0.981063484213027800, -0.981053798664327630, -0.981044110662993020, -0.981034420209048190, -0.981024727302517220, -0.981015031943424430, +-0.981005334131794140, -0.980995633867650320, -0.980985931151017510, -0.980976225981919910, -0.980966518360381730, -0.980956808286427280, -0.980947095760080660, -0.980937380781366500, +-0.980927663350308790, -0.980917943466932060, -0.980908221131260310, -0.980898496343318160, -0.980888769103129610, -0.980879039410719300, -0.980869307266111320, -0.980859572669329990, +-0.980849835620399620, -0.980840096119344860, -0.980830354166189910, -0.980820609760958970, -0.980810862903676580, -0.980801113594367060, -0.980791361833054490, -0.980781607619763740, +-0.980771850954518910, -0.980762091837344530, -0.980752330268264920, -0.980742566247304380, -0.980732799774487570, -0.980723030849838700, -0.980713259473382170, -0.980703485645142430, +-0.980693709365144110, -0.980683930633411530, -0.980674149449969110, -0.980664365814841290, -0.980654579728052590, -0.980644791189627330, -0.980635000199590160, -0.980625206757965500, +-0.980615410864777880, -0.980605612520051740, -0.980595811723811490, -0.980586008476081790, -0.980576202776887060, -0.980566394626251720, -0.980556584024200320, -0.980546770970757600, +-0.980536955465947990, -0.980527137509796030, -0.980517317102326150, -0.980507494243562980, -0.980497668933530850, -0.980487841172254850, -0.980478010959759170, -0.980468178296068470, +-0.980458343181207390, -0.980448505615200360, -0.980438665598072130, -0.980428823129847140, -0.980418978210550240, -0.980409130840205760, -0.980399281018838330, -0.980389428746472950, +-0.980379574023133920, -0.980369716848845880, -0.980359857223633610, -0.980349995147521640, -0.980340130620534710, -0.980330263642697490, -0.980320394214034610, -0.980310522334570830, +-0.980300648004330590, -0.980290771223338850, -0.980280891991620160, -0.980271010309199280, -0.980261126176100730, -0.980251239592349390, -0.980241350557970010, -0.980231459072987250, +-0.980221565137425870, -0.980211668751310490, -0.980201769914666010, -0.980191868627516950, -0.980181964889888400, -0.980172058701804900, -0.980162150063291330, -0.980152238974372310, +-0.980142325435072740, -0.980132409445417240, -0.980122491005430810, -0.980112570115138190, -0.980102646774563930, -0.980092720983733230, -0.980082792742670740, -0.980072862051401210, +-0.980062928909949620, -0.980052993318340620, -0.980043055276598960, -0.980033114784749860, -0.980023171842818060, -0.980013226450828220, -0.980003278608805320, -0.979993328316774330, +-0.979983375574759900, -0.979973420382787120, -0.979963462740880750, -0.979953502649065560, -0.979943540107366730, -0.979933575115809140, -0.979923607674417550, -0.979913637783216940, +-0.979903665442232290, -0.979893690651488240, -0.979883713411010100, -0.979873733720822760, -0.979863751580951070, -0.979853766991420020, -0.979843779952254580, -0.979833790463479630, +-0.979823798525120250, -0.979813804137201320, -0.979803807299747920, -0.979793808012784820, -0.979783806276337320, -0.979773802090430300, -0.979763795455088850, -0.979753786370337940, +-0.979743774836202340, -0.979733760852707470, -0.979723744419878200, -0.979713725537739500, -0.979703704206316580, -0.979693680425634430, -0.979683654195718010, -0.979673625516592540, +-0.979663594388282880, -0.979653560810814340, -0.979643524784211680, -0.979633486308500330, -0.979623445383705380, -0.979613402009851700, -0.979603356186964590, -0.979593307915068930, +-0.979583257194190150, -0.979573204024353220, -0.979563148405583230, -0.979553090337905390, -0.979543029821344890, -0.979532966855926720, -0.979522901441676200, -0.979512833578618510, +-0.979502763266778650, -0.979492690506181710, -0.979482615296853210, -0.979472537638818140, -0.979462457532101700, -0.979452374976729210, -0.979442289972725750, -0.979432202520116420, +-0.979422112618926750, -0.979412020269181730, -0.979401925470906760, -0.979391828224126960, -0.979381728528867510, -0.979371626385153740, -0.979361521793010950, -0.979351414752464340, +-0.979341305263539130, -0.979331193326260730, -0.979321078940654340, -0.979310962106745290, -0.979300842824558760, -0.979290721094120190, -0.979280596915454660, -0.979270470288587710, +-0.979260341213544660, -0.979250209690350810, -0.979240075719031380, -0.979229939299611770, -0.979219800432117320, -0.979209659116573320, -0.979199515353005200, -0.979189369141438280, +-0.979179220481897760, -0.979169069374409400, -0.979158915818998390, -0.979148759815690050, -0.979138601364509810, -0.979128440465482860, -0.979118277118635080, -0.979108111323991560, +-0.979097943081577720, -0.979087772391419090, -0.979077599253540990, -0.979067423667968840, -0.979057245634728180, -0.979047065153844430, -0.979036882225343020, -0.979026696849249260, +-0.979016509025588900, -0.979006318754387150, -0.978996126035669770, -0.978985930869461950, -0.978975733255789240, -0.978965533194677270, -0.978955330686151590, -0.978945125730237510, +-0.978934918326960560, -0.978924708476346380, -0.978914496178420410, -0.978904281433208290, -0.978894064240735330, -0.978883844601027290, -0.978873622514109480, -0.978863397980007770, +-0.978853170998747470, -0.978842941570354340, -0.978832709694853920, -0.978822475372271630, -0.978812238602633000, -0.978801999385963910, -0.978791757722289880, -0.978781513611636340, +-0.978771267054029170, -0.978761018049493780, -0.978750766598055820, -0.978740512699740940, -0.978730256354574780, -0.978719997562582880, -0.978709736323791100, -0.978699472638224990, +-0.978689206505910180, -0.978678937926872330, -0.978668666901137190, -0.978658393428730180, -0.978648117509677400, -0.978637839144004260, -0.978627558331736540, -0.978617275072899970, +-0.978606989367520220, -0.978596701215622920, -0.978586410617233950, -0.978576117572378950, -0.978565822081083450, -0.978555524143373550, -0.978545223759274880, -0.978534920928813110, +-0.978524615652014100, -0.978514307928903480, -0.978503997759506920, -0.978493685143850600, -0.978483370081959960, -0.978473052573861080, -0.978462732619579390, -0.978452410219140980, +-0.978442085372571490, -0.978431758079896800, -0.978421428341142760, -0.978411096156335040, -0.978400761525499480, -0.978390424448662200, -0.978380084925848830, -0.978369742957085230, +-0.978359398542397280, -0.978349051681810740, -0.978338702375351700, -0.978328350623045910, -0.978317996424919230, -0.978307639780997550, -0.978297280691306730, -0.978286919155872740, +-0.978276555174721450, -0.978266188747878850, -0.978255819875370690, -0.978245448557222840, -0.978235074793461610, -0.978224698584112540, -0.978214319929201830, -0.978203938828755340, +-0.978193555282798940, -0.978183169291358510, -0.978172780854460240, -0.978162389972130120, -0.978151996644394010, -0.978141600871277990, -0.978131202652807840, -0.978120801989009750, +-0.978110398879909580, -0.978099993325533430, -0.978089585325907170, -0.978079174881057110, -0.978068761991009120, -0.978058346655789280, -0.978047928875423470, -0.978037508649937880, +-0.978027085979358390, -0.978016660863711310, -0.978006233303022610, -0.977995803297318280, -0.977985370846624400, -0.977974935950967180, -0.977964498610372600, -0.977954058824866750, +-0.977943616594475820, -0.977933171919225570, -0.977922724799142660, -0.977912275234252950, -0.977901823224582410, -0.977891368770157480, -0.977880911871004010, -0.977870452527148100, +-0.977859990738616290, -0.977849526505434550, -0.977839059827628860, -0.977828590705225650, -0.977818119138250900, -0.977807645126730800, -0.977797168670691660, -0.977786689770159590, +-0.977776208425160780, -0.977765724635721310, -0.977755238401867620, -0.977744749723625910, -0.977734258601022250, -0.977723765034083090, -0.977713269022834170, -0.977702770567302370, +-0.977692269667513550, -0.977681766323494130, -0.977671260535270310, -0.977660752302868310, -0.977650241626314420, -0.977639728505634960, -0.977629212940856140, -0.977618694932004260, +-0.977608174479105530, -0.977597651582186480, -0.977587126241273420, -0.977576598456392440, -0.977566068227569970, -0.977555535554832320, -0.977545000438205690, -0.977534462877716730, +-0.977523922873391630, -0.977513380425256710, -0.977502835533338390, -0.977492288197662870, -0.977481738418256700, -0.977471186195146170, -0.977460631528357720, -0.977450074417917420, +-0.977439514863852170, -0.977428952866188140, -0.977418388424951770, -0.977407821540169360, -0.977397252211867350, -0.977386680440072150, -0.977376106224810300, -0.977365529566108340, +-0.977354950463992460, -0.977344368918489190, -0.977333784929625080, -0.977323198497426440, -0.977312609621919790, -0.977302018303131680, -0.977291424541088300, -0.977280828335816530, +-0.977270229687342670, -0.977259628595693260, -0.977249025060894840, -0.977238419082973820, -0.977227810661956520, -0.977217199797869920, -0.977206586490740330, -0.977195970740594280, +-0.977185352547458310, -0.977174731911358950, -0.977164108832322740, -0.977153483310376210, -0.977142855345546010, -0.977132224937858670, -0.977121592087340620, -0.977110956794018830, +-0.977100319057919500, -0.977089678879069500, -0.977079036257495260, -0.977068391193223200, -0.977057743686280400, -0.977047093736693180, -0.977036441344488300, -0.977025786509692300, +-0.977015129232331800, -0.977004469512433580, -0.976993807350024060, -0.976983142745130100, -0.976972475697778230, -0.976961806207995000, -0.976951134275807490, -0.976940459901242120, +-0.976929783084325540, -0.976919103825084620, -0.976908422123545780, -0.976897737979735780, -0.976887051393681700, -0.976876362365409870, -0.976865670894947250, -0.976854976982320380, +-0.976844280627556020, -0.976833581830681030, -0.976822880591722060, -0.976812176910705990, -0.976801470787659110, -0.976790762222608850, -0.976780051215581760, -0.976769337766604350, +-0.976758621875703730, -0.976747903542906530, -0.976737182768239400, -0.976726459551729430, -0.976715733893403380, -0.976705005793288010, -0.976694275251410060, -0.976683542267796520, +-0.976672806842474040, -0.976662068975469590, -0.976651328666809930, -0.976640585916521700, -0.976629840724632330, -0.976619093091168230, -0.976608343016156510, -0.976597590499623910, +-0.976586835541597310, -0.976576078142103340, -0.976565318301169550, -0.976554556018822350, -0.976543791295088730, -0.976533024129995760, -0.976522254523570110, -0.976511482475838850, +-0.976500707986828980, -0.976489931056567230, -0.976479151685080700, -0.976468369872396050, -0.976457585618540680, -0.976446798923541360, -0.976436009787425060, -0.976425218210218770, +-0.976414424191949240, -0.976403627732643780, -0.976392828832329250, -0.976382027491032640, -0.976371223708781040, -0.976360417485601320, -0.976349608821520550, -0.976338797716565840, +-0.976327984170764050, -0.976317168184142380, -0.976306349756727480, -0.976295528888546980, -0.976284705579627650, -0.976273879829996580, -0.976263051639680750, -0.976252221008707340, +-0.976241387937103130, -0.976230552424895650, -0.976219714472111870, -0.976208874078778770, -0.976198031244923440, -0.976187185970573080, -0.976176338255754780, -0.976165488100495530, +-0.976154635504822620, -0.976143780468762930, -0.976132922992344000, -0.976122063075592790, -0.976111200718536300, -0.976100335921201930, -0.976089468683616680, -0.976078599005807510, +-0.976067726887802190, -0.976056852329627360, -0.976045975331310540, -0.976035095892878730, -0.976024214014359240, -0.976013329695779140, -0.976002442937165760, -0.975991553738546180, +-0.975980662099947600, -0.975969768021397570, -0.975958871502923150, -0.975947972544551460, -0.975937071146309900, -0.975926167308225680, -0.975915261030325780, -0.975904352312637950, +-0.975893441155189280, -0.975882527558006970, -0.975871611521118340, -0.975860693044550700, -0.975849772128331240, -0.975838848772487500, -0.975827922977046570, -0.975816994742035760, +-0.975806064067482380, -0.975795130953413970, -0.975784195399857720, -0.975773257406841070, -0.975762316974391200, -0.975751374102535430, -0.975740428791301300, -0.975729481040716220, +-0.975718530850807290, -0.975707578221602150, -0.975696623153128000, -0.975685665645412370, -0.975674705698482580, -0.975663743312365940, -0.975652778487089980, -0.975641811222681900, +-0.975630841519169460, -0.975619869376579850, -0.975608894794940730, -0.975597917774279290, -0.975586938314622950, -0.975575956415999260, -0.975564972078435730, -0.975553985301959800, +-0.975542996086599000, -0.975532004432380640, -0.975521010339332250, -0.975510013807481370, -0.975499014836855420, -0.975488013427481930, -0.975477009579388320, -0.975466003292602250, +-0.975454994567151230, -0.975443983403062710, -0.975432969800364200, -0.975421953759083360, -0.975410935279247380, -0.975399914360884250, -0.975388891004021370, -0.975377865208686190, +-0.975366836974906450, -0.975355806302709570, -0.975344773192123090, -0.975333737643174770, -0.975322699655892130, -0.975311659230302500, -0.975300616366433950, -0.975289571064313800, +-0.975278523323969800, -0.975267473145429390, -0.975256420528720410, -0.975245365473870090, -0.975234307980906600, -0.975223248049857380, -0.975212185680749970, -0.975201120873612100, +-0.975190053628471440, -0.975178983945355740, -0.975167911824292410, -0.975156837265309440, -0.975145760268434360, -0.975134680833694590, -0.975123598961118440, -0.975112514650733230, +-0.975101427902566710, -0.975090338716646630, -0.975079247093000530, -0.975068153031656500, -0.975057056532642070, -0.975045957595985000, -0.975034856221713040, -0.975023752409853950, +-0.975012646160435480, -0.975001537473485390, -0.974990426349031550, -0.974979312787101480, -0.974968196787723060, -0.974957078350924270, -0.974945957476732850, -0.974934834165176460, +-0.974923708416283060, -0.974912580230080320, -0.974901449606595970, -0.974890316545858230, -0.974879181047894620, -0.974868043112733120, -0.974856902740401490, -0.974845759930927590, +-0.974834614684339300, -0.974823467000664470, -0.974812316879930970, -0.974801164322166460, -0.974790009327399340, -0.974778851895657050, -0.974767692026967780, -0.974756529721359180, +-0.974745364978859330, -0.974734197799495770, -0.974723028183296920, -0.974711856130290540, -0.974700681640504610, -0.974689504713966870, -0.974678325350705420, -0.974667143550748130, +-0.974655959314122970, -0.974644772640857910, -0.974633583530980730, -0.974622391984519830, -0.974611198001502870, -0.974600001581957920, -0.974588802725913080, -0.974577601433396110, +-0.974566397704434980, -0.974555191539058120, -0.974543982937293160, -0.974532771899168320, -0.974521558424711550, -0.974510342513950860, -0.974499124166914310, -0.974487903383630010, +-0.974476680164125920, -0.974465454508430140, -0.974454226416570420, -0.974442995888575410, -0.974431762924472980, -0.974420527524291090, -0.974409289688057840, -0.974398049415801220, +-0.974386806707549620, -0.974375561563331050, -0.974364313983173580, -0.974353063967105300, -0.974341811515154420, -0.974330556627348910, -0.974319299303717080, -0.974308039544287020, +-0.974296777349086820, -0.974285512718144450, -0.974274245651488570, -0.974262976149147030, -0.974251704211148040, -0.974240429837519790, -0.974229153028290500, -0.974217873783488120, +-0.974206592103141310, -0.974195307987277940, -0.974184021435926310, -0.974172732449114620, -0.974161441026871190, -0.974150147169223990, -0.974138850876201560, -0.974127552147831980, +-0.974116250984143340, -0.974104947385164180, -0.974093641350922690, -0.974082332881447190, -0.974071021976765760, -0.974059708636906720, -0.974048392861898370, -0.974037074651769140, +-0.974025754006547230, -0.974014430926260940, -0.974003105410938600, -0.973991777460608390, -0.973980447075298850, -0.973969114255038180, -0.973957778999854700, -0.973946441309776590, +-0.973935101184832620, -0.973923758625050760, -0.973912413630459660, -0.973901066201087410, -0.973889716336962530, -0.973878364038113230, -0.973867009304568150, -0.973855652136355500, +-0.973844292533503800, -0.973832930496041360, -0.973821566023996610, -0.973810199117397860, -0.973798829776273740, -0.973787458000652470, -0.973776083790562570, -0.973764707146032250, +-0.973753328067090360, -0.973741946553765110, -0.973730562606085040, -0.973719176224078550, -0.973707787407773970, -0.973696396157200050, -0.973685002472385210, -0.973673606353357870, +-0.973662207800146450, -0.973650806812779600, -0.973639403391285630, -0.973627997535693180, -0.973616589246030780, -0.973605178522326860, -0.973593765364609840, -0.973582349772908580, +-0.973570931747251400, -0.973559511287666930, -0.973548088394183720, -0.973536663066830180, -0.973525235305634950, -0.973513805110626680, -0.973502372481834020, -0.973490937419285270, +-0.973479499923009310, -0.973468059993034540, -0.973456617629389730, -0.973445172832103300, -0.973433725601203890, -0.973422275936720040, -0.973410823838680610, -0.973399369307114240, +-0.973387912342049360, -0.973376452943514710, -0.973364991111538960, -0.973353526846150510, -0.973342060147378450, -0.973330591015251210, -0.973319119449797540, -0.973307645451046090, +-0.973296169019025490, -0.973284690153764510, -0.973273208855291670, -0.973261725123635960, -0.973250238958825680, -0.973238750360890030, -0.973227259329857430, -0.973215765865756750, +-0.973204269968616640, -0.973192771638465850, -0.973181270875332900, -0.973169767679247010, -0.973158262050236700, -0.973146753988330730, -0.973135243493557960, -0.973123730565946920, +-0.973112215205526710, -0.973100697412325850, -0.973089177186373330, -0.973077654527697790, -0.973066129436327980, -0.973054601912292980, -0.973043071955621560, -0.973031539566342360, +-0.973020004744484360, -0.973008467490076190, -0.972996927803146950, -0.972985385683725500, -0.972973841131840490, -0.972962294147521000, -0.972950744730795680, -0.972939192881693500, +-0.972927638600243340, -0.972916081886474160, -0.972904522740414720, -0.972892961162093780, -0.972881397151540650, -0.972869830708783970, -0.972858261833852710, -0.972846690526775860, +-0.972835116787582050, -0.972823540616300720, -0.972811962012960500, -0.972800380977590250, -0.972788797510219180, -0.972777211610876160, -0.972765623279590040, -0.972754032516389810, +-0.972742439321304550, -0.972730843694363250, -0.972719245635594530, -0.972707645145027940, -0.972696042222692240, -0.972684436868616500, -0.972672829082829590, -0.972661218865360610, +-0.972649606216238420, -0.972637991135492430, -0.972626373623151410, -0.972614753679244440, -0.972603131303800720, -0.972591506496849000, -0.972579879258418600, -0.972568249588538490, +-0.972556617487237760, -0.972544982954545280, -0.972533345990490570, -0.972521706595102510, -0.972510064768410180, -0.972498420510442660, -0.972486773821229060, -0.972475124700798330, +-0.972463473149180020, -0.972451819166403000, -0.972440162752496450, -0.972428503907489470, -0.972416842631411260, -0.972405178924291010, -0.972393512786157710, -0.972381844217040660, +-0.972370173216968840, -0.972358499785971770, -0.972346823924078340, -0.972335145631317950, -0.972323464907719700, -0.972311781753312790, -0.972300096168126180, -0.972288408152189640, +-0.972276717705532030, -0.972265024828182560, -0.972253329520170520, -0.972241631781525230, -0.972229931612275890, -0.972218229012451580, -0.972206523982081850, -0.972194816521195770, +-0.972183106629822320, -0.972171394307991490, -0.972159679555732130, -0.972147962373073440, -0.972136242760044960, -0.972124520716675660, -0.972112796242995290, -0.972101069339032840, +-0.972089340004817840, -0.972077608240379360, -0.972065874045746960, -0.972054137420949820, -0.972042398366017360, -0.972030656880978890, -0.972018912965863740, -0.972007166620701190, +-0.971995417845520900, -0.971983666640352070, -0.971971913005224010, -0.971960156940166240, -0.971948398445208080, -0.971936637520378620, -0.971924874165707830, -0.971913108381224910, +-0.971901340166959170, -0.971889569522940140, -0.971877796449197140, -0.971866020945759580, -0.971854243012657100, -0.971842462649918910, -0.971830679857574430, -0.971818894635653410, +-0.971807106984185150, -0.971795316903199090, -0.971783524392724860, -0.971771729452791670, -0.971759932083429030, -0.971748132284666830, -0.971736330056534260, -0.971724525399060850, +-0.971712718312276010, -0.971700908796209520, -0.971689096850890780, -0.971677282476349210, -0.971665465672614470, -0.971653646439715860, -0.971641824777683240, -0.971630000686546150, +-0.971618174166334110, -0.971606345217076560, -0.971594513838803240, -0.971582680031543360, -0.971570843795326990, -0.971559005130183450, -0.971547164036142500, -0.971535320513233550, +-0.971523474561486360, -0.971511626180930450, -0.971499775371595490, -0.971487922133511090, -0.971476066466706920, -0.971464208371212390, -0.971452347847057470, -0.971440484894271710, +-0.971428619512884730, -0.971416751702926300, -0.971404881464425610, -0.971393008797413080, -0.971381133701917920, -0.971369256177969990, -0.971357376225598920, -0.971345493844834370, +-0.971333609035706090, -0.971321721798243830, -0.971309832132477240, -0.971297940038436060, -0.971286045516149830, -0.971274148565648750, -0.971262249186962250, -0.971250347380120060, +-0.971238443145152060, -0.971226536482088010, -0.971214627390957320, -0.971202715871790300, -0.971190801924616600, -0.971178885549465740, -0.971166966746367710, -0.971155045515352260, +-0.971143121856449240, -0.971131195769688430, -0.971119267255099560, -0.971107336312712400, -0.971095402942557030, -0.971083467144663090, -0.971071528919060680, -0.971059588265779320, +-0.971047645184848980, -0.971035699676299320, -0.971023751740160650, -0.971011801376462590, -0.970999848585235030, -0.970987893366507930, -0.970975935720310930, -0.970963975646674250, +-0.970952013145627510, -0.970940048217200810, -0.970928080861423790, -0.970916111078326760, -0.970904138867939360, -0.970892164230291790, -0.970880187165413690, -0.970868207673335150, +-0.970856225754085810, -0.970844241407696210, -0.970832254634195980, -0.970820265433615100, -0.970808273805983670, -0.970796279751331430, -0.970784283269688460, -0.970772284361084870, +-0.970760283025550510, -0.970748279263115470, -0.970736273073809610, -0.970724264457663130, -0.970712253414706130, -0.970700239944968350, -0.970688224048480100, -0.970676205725271020, +-0.970664184975371660, -0.970652161798811750, -0.970640136195621510, -0.970628108165830890, -0.970616077709470120, -0.970604044826569030, -0.970592009517157850, -0.970579971781266650, +-0.970567931618925520, -0.970555889030164430, -0.970543844015013700, -0.970531796573503520, -0.970519746705663660, -0.970507694411524620, -0.970495639691116190, -0.970483582544468540, +-0.970471522971612100, -0.970459460972576850, -0.970447396547392980, -0.970435329696090590, -0.970423260418699970, -0.970411188715251120, -0.970399114585774330, -0.970387038030299690, +-0.970374959048857290, -0.970362877641477660, -0.970350793808190890, -0.970338707549027070, -0.970326618864016610, -0.970314527753189490, -0.970302434216575800, -0.970290338254206410, +-0.970278239866111060, -0.970266139052320060, -0.970254035812863850, -0.970241930147772490, -0.970229822057076200, -0.970217711540805490, -0.970205598598990470, -0.970193483231661210, +-0.970181365438848480, -0.970169245220582340, -0.970157122576893130, -0.970144997507811020, -0.970132870013366460, -0.970120740093589510, -0.970108607748510930, -0.970096472978160820, +-0.970084335782569580, -0.970072196161767430, -0.970060054115784780, -0.970047909644652040, -0.970035762748399530, -0.970023613427057670, -0.970011461680656660, -0.969999307509226800, +-0.969987150912798970, -0.969974991891403240, -0.969962830445069920, -0.969950666573829670, -0.969938500277712450, -0.969926331556749230, -0.969914160410970230, -0.969901986840405740, +-0.969889810845086300, -0.969877632425042320, -0.969865451580304350, -0.969853268310902680, -0.969841082616867860, -0.969828894498230290, -0.969816703955020290, -0.969804510987268830, +-0.969792315595006000, -0.969780117778262340, -0.969767917537068480, -0.969755714871454840, -0.969743509781451630, -0.969731302267089810, -0.969719092328399810, -0.969706879965412160, +-0.969694665178157170, -0.969682447966665580, -0.969670228330967940, -0.969658006271094660, -0.969645781787076280, -0.969633554878943320, -0.969621325546726750, -0.969609093790456790, +-0.969596859610164060, -0.969584623005879220, -0.969572383977632900, -0.969560142525455300, -0.969547898649377630, -0.969535652349430180, -0.969523403625643600, -0.969511152478048420, +-0.969498898906675510, -0.969486642911555290, -0.969474384492718500, -0.969462123650195680, -0.969449860384017370, -0.969437594694214640, -0.969425326580817930, -0.969413056043857860, +-0.969400783083365190, -0.969388507699370460, -0.969376229891904420, -0.969363949660997930, -0.969351667006681520, -0.969339381928985940, -0.969327094427942070, -0.969314804503580320, +-0.969302512155931550, -0.969290217385026520, -0.969277920190895980, -0.969265620573570690, -0.969253318533081050, -0.969241014069458400, -0.969228707182733130, -0.969216397872936120, +-0.969204086140098120, -0.969191771984249660, -0.969179455405422050, -0.969167136403645820, -0.969154814978951620, -0.969142491131370520, -0.969130164860933170, -0.969117836167670330, +-0.969105505051612970, -0.969093171512791840, -0.969080835551237700, -0.969068497166981400, -0.969056156360053930, -0.969043813130486150, -0.969031467478308820, -0.969019119403552900, +-0.969006768906249040, -0.968994415986428100, -0.968982060644121400, -0.968969702879359460, -0.968957342692173260, -0.968944980082593780, -0.968932615050651870, -0.968920247596378290, +-0.968907877719804240, -0.968895505420960370, -0.968883130699877530, -0.968870753556587140, -0.968858373991119850, -0.968845992003506630, -0.968833607593778460, -0.968821220761966200, +-0.968808831508100710, -0.968796439832213420, -0.968784045734334960, -0.968771649214496430, -0.968759250272728690, -0.968746848909062930, -0.968734445123529910, -0.968722038916160930, +-0.968709630286986760, -0.968697219236038350, -0.968684805763347030, -0.968672389868943770, -0.968659971552859540, -0.968647550815125320, -0.968635127655772310, -0.968622702074831140, +-0.968610274072333580, -0.968597843648310250, -0.968585410802792260, -0.968572975535810900, -0.968560537847396930, -0.968548097737581770, -0.968535655206396280, -0.968523210253871670, +-0.968510762880039010, -0.968498313084929290, -0.968485860868573910, -0.968473406231003970, -0.968460949172250450, -0.968448489692344540, -0.968436027791317210, -0.968423563469200110, +-0.968411096726023990, -0.968398627561820160, -0.968386155976619810, -0.968373681970454040, -0.968361205543354140, -0.968348726695351100, -0.968336245426476340, -0.968323761736760940, +-0.968311275626235870, -0.968298787094932890, -0.968286296142882860, -0.968273802770117210, -0.968261306976666900, -0.968248808762563470, -0.968236308127837670, -0.968223805072521370, +-0.968211299596645650, -0.968198791700241590, -0.968186281383340620, -0.968173768645973820, -0.968161253488172720, -0.968148735909968420, -0.968136215911392320, -0.968123693492475400, +-0.968111168653249530, -0.968098641393745800, -0.968086111713995390, -0.968073579614029620, -0.968061045093880020, -0.968048508153577570, -0.968035968793154010, -0.968023427012640550, +-0.968010882812068600, -0.967998336191469360, -0.967985787150874240, -0.967973235690314790, -0.967960681809822200, -0.967948125509427880, -0.967935566789163040, -0.967923005649059420, +-0.967910442089148340, -0.967897876109461210, -0.967885307710029340, -0.967872736890884270, -0.967860163652057070, -0.967847587993579730, -0.967835009915483320, -0.967822429417799500, +-0.967809846500559570, -0.967797261163794940, -0.967784673407537270, -0.967772083231817850, -0.967759490636668220, -0.967746895622119910, -0.967734298188204110, -0.967721698334952810, +-0.967709096062397300, -0.967696491370569010, -0.967683884259499470, -0.967671274729219990, -0.967658662779762650, -0.967646048411158530, -0.967633431623439400, -0.967620812416636560, +-0.967608190790781750, -0.967595566745906520, -0.967582940282042280, -0.967570311399220780, -0.967557680097473450, -0.967545046376831700, -0.967532410237327500, -0.967519771678992390, +-0.967507130701857790, -0.967494487305955330, -0.967481841491316660, -0.967469193257973200, -0.967456542605957040, -0.967443889535299470, -0.967431234046032150, -0.967418576138186710, +-0.967405915811794910, -0.967393253066888280, -0.967380587903498570, -0.967367920321657300, -0.967355250321396130, -0.967342577902746910, -0.967329903065741400, -0.967317225810411020, +-0.967304546136787620, -0.967291864044902860, -0.967279179534788150, -0.967266492606475790, -0.967253803259997210, -0.967241111495384050, -0.967228417312668180, -0.967215720711881220, +-0.967203021693054940, -0.967190320256221200, -0.967177616401411640, -0.967164910128657680, -0.967152201437991850, -0.967139490329445460, -0.967126776803050260, -0.967114060858838220, +-0.967101342496840990, -0.967088621717090090, -0.967075898519617950, -0.967063172904456090, -0.967050444871636270, -0.967037714421190350, -0.967024981553150200, -0.967012246267547450, +-0.966999508564414190, -0.966986768443782170, -0.966974025905683150, -0.966961280950148880, -0.966948533577211670, -0.966935783786903040, -0.966923031579255080, -0.966910276954299430, +-0.966897519912067850, -0.966884760452592750, -0.966871998575905780, -0.966859234282038790, -0.966846467571023660, -0.966833698442892460, -0.966820926897676960, -0.966808152935409120, +-0.966795376556120910, -0.966782597759844320, -0.966769816546610870, -0.966757032916453210, -0.966744246869402970, -0.966731458405492130, -0.966718667524752550, -0.966705874227216430, +-0.966693078512915300, -0.966680280381881700, -0.966667479834147470, -0.966654676869744490, -0.966641871488704840, -0.966629063691060500, -0.966616253476843430, -0.966603440846085850, +-0.966590625798819600, -0.966577808335076560, -0.966564988454889250, -0.966552166158289540, -0.966539341445309290, -0.966526514315980690, -0.966513684770335950, -0.966500852808406590, +-0.966488018430225470, -0.966475181635824240, -0.966462342425234990, -0.966449500798490010, -0.966436656755621180, -0.966423810296660800, -0.966410961421640850, -0.966398110130593510, +-0.966385256423550660, -0.966372400300544830, -0.966359541761608100, -0.966346680806772440, -0.966333817436070050, -0.966320951649533240, -0.966308083447193770, -0.966295212829084260, +-0.966282339795236810, -0.966269464345683500, -0.966256586480456430, -0.966243706199587990, -0.966230823503110290, -0.966217938391055520, -0.966205050863455870, -0.966192160920343550, +-0.966179268561750740, -0.966166373787709860, -0.966153476598253120, -0.966140576993412600, -0.966127674973220720, -0.966114770537709440, -0.966101863686911420, -0.966088954420858740, +-0.966076042739583700, -0.966063128643118500, -0.966050212131495560, -0.966037293204746960, -0.966024371862905240, -0.966011448106002590, -0.965998521934071320, -0.965985593347143400, +-0.965972662345251810, -0.965959728928428630, -0.965946793096706060, -0.965933854850116510, -0.965920914188692080, -0.965907971112465620, -0.965895025621469230, -0.965882077715735310, +-0.965869127395296180, -0.965856174660184140, -0.965843219510431730, -0.965830261946071360, -0.965817301967135220, -0.965804339573655860, -0.965791374765665460, -0.965778407543196770, +-0.965765437906282110, -0.965752465854953890, -0.965739491389244420, -0.965726514509186230, -0.965713535214811620, -0.965700553506153360, -0.965687569383243740, -0.965674582846115070, +-0.965661593894800110, -0.965648602529331050, -0.965635608749740530, -0.965622612556060970, -0.965609613948324900, -0.965596612926564510, -0.965583609490812900, -0.965570603641102250, +-0.965557595377465110, -0.965544584699933870, -0.965531571608541310, -0.965518556103319490, -0.965505538184301510, -0.965492517851519790, -0.965479495105006640, -0.965466469944794900, +-0.965453442370916900, -0.965440412383405280, -0.965427379982292670, -0.965414345167611600, -0.965401307939394600, -0.965388268297674210, -0.965375226242483290, -0.965362181773854360, +-0.965349134891819950, -0.965336085596412710, -0.965323033887665050, -0.965309979765609950, -0.965296923230280050, -0.965283864281707760, -0.965270802919925730, -0.965257739144966820, +-0.965244672956863450, -0.965231604355648480, -0.965218533341354550, -0.965205459914014190, -0.965192384073659930, -0.965179305820325070, -0.965166225154041820, -0.965153142074843040, +-0.965140056582761470, -0.965126968677829430, -0.965113878360080220, -0.965100785629546380, -0.965087690486260530, -0.965074592930255440, -0.965061492961563960, -0.965048390580218630, +-0.965035285786252420, -0.965022178579697850, -0.965009068960588020, -0.964995956928955120, -0.964982842484832680, -0.964969725628253120, -0.964956606359249180, -0.964943484677853740, +-0.964930360584099640, -0.964917234078019440, -0.964904105159646310, -0.964890973829012900, -0.964877840086152070, -0.964864703931096690, -0.964851565363879500, -0.964838424384533490, +-0.964825280993091280, -0.964812135189585970, -0.964798986974050090, -0.964785836346516930, -0.964772683307019150, -0.964759527855589720, -0.964746369992261490, -0.964733209717067220, +-0.964720047030039770, -0.964706881931212460, -0.964693714420617910, -0.964680544498289110, -0.964667372164258910, -0.964654197418560290, -0.964641020261226220, -0.964627840692289570, +-0.964614658711783310, -0.964601474319740190, -0.964588287516193630, -0.964575098301176270, -0.964561906674721190, -0.964548712636861370, -0.964535516187629780, -0.964522317327059180, +-0.964509116055182970, -0.964495912372034030, -0.964482706277645320, -0.964469497772049820, -0.964456286855280510, -0.964443073527370580, -0.964429857788352880, -0.964416639638260630, +-0.964403419077126680, -0.964390196104984000, -0.964376970721866010, -0.964363742927805690, -0.964350512722836010, -0.964337280106989940, -0.964324045080300560, -0.964310807642801190, +-0.964297567794524910, -0.964284325535504580, -0.964271080865773510, -0.964257833785364780, -0.964244584294311480, -0.964231332392646580, -0.964218078080403500, -0.964204821357615090, +-0.964191562224314570, -0.964178300680535230, -0.964165036726310150, -0.964151770361672540, -0.964138501586655480, -0.964125230401292170, -0.964111956805615570, -0.964098680799659210, +-0.964085402383456300, -0.964072121557039810, -0.964058838320442920, -0.964045552673699070, -0.964032264616841330, -0.964018974149902900, -0.964005681272916970, -0.963992385985916740, +-0.963979088288935640, -0.963965788182006960, -0.963952485665163670, -0.963939180738439320, -0.963925873401866860, -0.963912563655479620, -0.963899251499311100, -0.963885936933394530, +-0.963872619957763080, -0.963859300572450060, -0.963845978777488790, -0.963832654572912560, -0.963819327958754800, -0.963805998935048590, -0.963792667501827240, -0.963779333659124380, +-0.963765997406973220, -0.963752658745407050, -0.963739317674459310, -0.963725974194163280, -0.963712628304551950, -0.963699280005659410, -0.963685929297518620, -0.963672576180163000, +-0.963659220653625970, -0.963645862717940840, -0.963632502373141020, -0.963619139619260050, -0.963605774456331220, -0.963592406884387850, -0.963579036903463360, -0.963565664513591490, +-0.963552289714805330, -0.963538912507138520, -0.963525532890624480, -0.963512150865296400, -0.963498766431188040, -0.963485379588332910, -0.963471990336764230, -0.963458598676515620, +-0.963445204607620510, -0.963431808130112420, -0.963418409244024780, -0.963405007949391100, -0.963391604246244930, -0.963378198134619450, -0.963364789614548740, -0.963351378686066130, +-0.963337965349204910, -0.963324549603998940, -0.963311131450481530, -0.963297710888686100, -0.963284287918646510, -0.963270862540396290, -0.963257434753968970, -0.963244004559397960, +-0.963230571956717020, -0.963217136945959560, -0.963203699527159340, -0.963190259700349880, -0.963176817465564490, -0.963163372822837260, -0.963149925772201710, -0.963136476313691260, +-0.963123024447339660, -0.963109570173180440, -0.963096113491247020, -0.963082654401573700, -0.963069192904193680, -0.963055728999140600, -0.963042262686448320, -0.963028793966150260, +-0.963015322838280290, -0.963001849302872030, -0.962988373359959130, -0.962974895009575120, -0.962961414251753970, -0.962947931086529430, -0.962934445513934920, -0.962920957534004420, +-0.962907467146771450, -0.962893974352269640, -0.962880479150533100, -0.962866981541595330, -0.962853481525490110, -0.962839979102251280, -0.962826474271912370, -0.962812967034507360, +-0.962799457390069890, -0.962785945338633820, -0.962772430880232900, -0.962758914014900660, -0.962745394742671290, -0.962731873063578550, -0.962718348977656070, -0.962704822484937720, +-0.962691293585457020, -0.962677762279248390, -0.962664228566345370, -0.962650692446781700, -0.962637153920591350, -0.962623612987808070, -0.962610069648465850, -0.962596523902598420, +-0.962582975750239660, -0.962569425191423410, -0.962555872226183440, -0.962542316854554050, -0.962528759076568760, -0.962515198892261670, -0.962501636301666630, -0.962488071304817390, +-0.962474503901747710, -0.962460934092492120, -0.962447361877084130, -0.962433787255557730, -0.962420210227946880, -0.962406630794285570, -0.962393048954607530, -0.962379464708946970, +-0.962365878057337750, -0.962352288999813620, -0.962338697536408880, -0.962325103667157510, -0.962311507392093370, -0.962297908711250430, -0.962284307624662770, -0.962270704132364040, +-0.962257098234388870, -0.962243489930770910, -0.962229879221544240, -0.962216266106742820, -0.962202650586400750, -0.962189032660552000, -0.962175412329230760, -0.962161789592471010, +-0.962148164450306490, -0.962134536902771840, -0.962120906949900820, -0.962107274591727510, -0.962093639828286110, -0.962080002659610470, -0.962066363085734680, -0.962052721106693150, +-0.962039076722519870, -0.962025429933248910, -0.962011780738914360, -0.961998129139550410, -0.961984475135191030, -0.961970818725870540, -0.961957159911623010, -0.961943498692482520, +-0.961929835068483060, -0.961916169039659260, -0.961902500606045100, -0.961888829767674650, -0.961875156524582110, -0.961861480876801460, -0.961847802824367330, -0.961834122367313690, +-0.961820439505674750, -0.961806754239484700, -0.961793066568777720, -0.961779376493588130, -0.961765684013950130, -0.961751989129897900, -0.961738291841465640, -0.961724592148687440, +-0.961710890051598040, -0.961697185550231430, -0.961683478644621780, -0.961669769334803530, -0.961656057620810740, -0.961642343502677630, -0.961628626980438940, -0.961614908054128640, +-0.961601186723781030, -0.961587462989430540, -0.961573736851111360, -0.961560008308857790, -0.961546277362704260, -0.961532544012684950, -0.961518808258834180, -0.961505070101186580, +-0.961491329539776230, -0.961477586574637550, -0.961463841205804970, -0.961450093433312780, -0.961436343257195180, -0.961422590677486920, -0.961408835694222090, -0.961395078307435310, +-0.961381318517160690, -0.961367556323432850, -0.961353791726286210, -0.961340024725754970, -0.961326255321873660, -0.961312483514676570, -0.961298709304198360, -0.961284932690473550, +-0.961271153673536330, -0.961257372253421230, -0.961243588430162670, -0.961229802203794950, -0.961216013574352930, -0.961202222541870820, -0.961188429106383250, -0.961174633267924630, +-0.961160835026529380, -0.961147034382232040, -0.961133231335067120, -0.961119425885069050, -0.961105618032272570, -0.961091807776711660, -0.961077995118421510, -0.961064180057436430, +-0.961050362593790840, -0.961036542727519370, -0.961022720458656330, -0.961008895787236690, -0.960995068713294760, -0.960981239236865290, -0.960967407357982580, -0.960953573076681500, +-0.960939736392996350, -0.960925897306961980, -0.960912055818612830, -0.960898211927983410, -0.960884365635108370, -0.960870516940022680, -0.960856665842760640, -0.960842812343356890, +-0.960828956441846180, -0.960815098138263050, -0.960801237432641900, -0.960787374325017930, -0.960773508815425560, -0.960759640903899310, -0.960745770590474060, -0.960731897875184320, +-0.960718022758064950, -0.960704145239150380, -0.960690265318475570, -0.960676382996074720, -0.960662498271983250, -0.960648611146235560, -0.960634721618866320, -0.960620829689910250, +-0.960606935359402110, -0.960593038627376330, -0.960579139493868310, -0.960565237958912350, -0.960551334022543330, -0.960537427684796000, -0.960523518945705090, -0.960509607805305370, +-0.960495694263631680, -0.960481778320718680, -0.960467859976601000, -0.960453939231313950, -0.960440016084892050, -0.960426090537370160, -0.960412162588782920, -0.960398232239165320, +-0.960384299488551970, -0.960370364336978090, -0.960356426784478190, -0.960342486831087360, -0.960328544476840240, -0.960314599721771800, -0.960300652565916790, -0.960286703009310180, +-0.960272751051986840, -0.960258796693981620, -0.960244839935329160, -0.960230880776064890, -0.960216919216223320, -0.960202955255839540, -0.960188988894948300, -0.960175020133584360, +-0.960161048971783230, -0.960147075409579330, -0.960133099447007870, -0.960119121084103580, -0.960105140320901440, -0.960091157157436540, -0.960077171593743730, -0.960063183629857870, +-0.960049193265814170, -0.960035200501647260, -0.960021205337392550, -0.960007207773084790, -0.959993207808759070, -0.959979205444450370, -0.959965200680193640, -0.959951193516023650, +-0.959937183951975800, -0.959923171988085190, -0.959909157624386560, -0.959895140860914990, -0.959881121697705560, -0.959867100134793370, -0.959853076172213490, -0.959839049810000900, +-0.959825021048190340, -0.959810989886817570, -0.959796956325917330, -0.959782920365524590, -0.959768882005674670, -0.959754841246402530, -0.959740798087742930, -0.959726752529731720, +-0.959712704572403540, -0.959698654215793590, -0.959684601459937060, -0.959670546304869030, -0.959656488750624590, -0.959642428797238930, -0.959628366444747250, -0.959614301693184400, +-0.959600234542586030, -0.959586164992987100, -0.959572093044422700, -0.959558018696928140, -0.959543941950538490, -0.959529862805288740, -0.959515781261214510, -0.959501697318350890, +-0.959487610976733070, -0.959473522236396150, -0.959459431097375530, -0.959445337559706180, -0.959431241623423640, -0.959417143288562870, -0.959403042555159290, -0.959388939423247880, +-0.959374833892864380, -0.959360725964043760, -0.959346615636821330, -0.959332502911232400, -0.959318387787311930, -0.959304270265095680, -0.959290150344618840, -0.959276028025916610, +-0.959261903309024280, -0.959247776193977280, -0.959233646680810790, -0.959219514769560130, -0.959205380460260710, -0.959191243752947840, -0.959177104647656600, -0.959162963144422950, +-0.959148819243281770, -0.959134672944268570, -0.959120524247418670, -0.959106373152767590, -0.959092219660350190, -0.959078063770202550, -0.959063905482359760, -0.959049744796857120, +-0.959035581713730160, -0.959021416233014290, -0.959007248354744820, -0.958993078078957280, -0.958978905405687090, -0.958964730334969320, -0.958950552866839940, -0.958936373001334270, +-0.958922190738487610, -0.958908006078335480, -0.958893819020913310, -0.958879629566256390, -0.958865437714400580, -0.958851243465381310, -0.958837046819233760, -0.958822847775993690, +-0.958808646335696510, -0.958794442498377640, -0.958780236264072720, -0.958766027632817260, -0.958751816604646480, -0.958737603179596330, -0.958723387357702130, -0.958709169138999620, +-0.958694948523524100, -0.958680725511311230, -0.958666500102396180, -0.958652272296815270, -0.958638042094603680, -0.958623809495796840, -0.958609574500430610, -0.958595337108540390, +-0.958581097320161950, -0.958566855135330580, -0.958552610554082140, -0.958538363576452280, -0.958524114202476190, -0.958509862432190050, -0.958495608265629180, -0.958481351702829440, +-0.958467092743826240, -0.958452831388655000, -0.958438567637352020, -0.958424301489952610, -0.958410032946492410, -0.958395762007007160, -0.958381488671532500, -0.958367212940104190, +-0.958352934812757740, -0.958338654289528910, -0.958324371370453560, -0.958310086055567000, -0.958295798344905530, -0.958281508238504440, -0.958267215736399610, -0.958252920838626790, +-0.958238623545221710, -0.958224323856219810, -0.958210021771657260, -0.958195717291569720, -0.958181410415992810, -0.958167101144962510, -0.958152789478514340, -0.958138475416684290, +-0.958124158959507980, -0.958109840107021270, -0.958095518859259700, -0.958081195216259670, -0.958066869178056610, -0.958052540744686380, -0.958038209916184820, -0.958023876692587710, +-0.958009541073930550, -0.957995203060249880, -0.957980862651581220, -0.957966519847960440, -0.957952174649423280, -0.957937827056005720, -0.957923477067743610, -0.957909124684672820, +-0.957894769906829200, -0.957880412734248400, -0.957866053166966820, -0.957851691205020120, -0.957837326848444140, -0.957822960097274860, -0.957808590951548240, -0.957794219411299830, +-0.957779845476566140, -0.957765469147382810, -0.957751090423785920, -0.957736709305811230, -0.957722325793494700, -0.957707939886872420, -0.957693551585980350, -0.957679160890854250, +-0.957664767801530430, -0.957650372318044290, -0.957635974440432580, -0.957621574168730840, -0.957607171502975250, -0.957592766443201680, -0.957578358989445880, -0.957563949141744590, +-0.957549536900133340, -0.957535122264648210, -0.957520705235325290, -0.957506285812200650, -0.957491863995310280, -0.957477439784690240, -0.957463013180376630, -0.957448584182405420, +-0.957434152790812560, -0.957419719005634610, -0.957405282826907290, -0.957390844254666810, -0.957376403288949130, -0.957361959929790340, -0.957347514177226740, -0.957333066031294420, +-0.957318615492029460, -0.957304162559468040, -0.957289707233646040, -0.957275249514599860, -0.957260789402365590, -0.957246326896979300, -0.957231861998477210, -0.957217394706895150, +-0.957202925022270000, -0.957188452944637390, -0.957173978474033740, -0.957159501610495120, -0.957145022354057740, -0.957130540704757560, -0.957116056662631220, -0.957101570227714800, +-0.957087081400044500, -0.957072590179656400, -0.957058096566586910, -0.957043600560872120, -0.957029102162548330, -0.957014601371651840, -0.957000098188218520, -0.956985592612285220, +-0.956971084643888030, -0.956956574283063020, -0.956942061529846620, -0.956927546384275020, -0.956913028846384410, -0.956898508916211420, -0.956883986593792150, -0.956869461879162890, +-0.956854934772360060, -0.956840405273419850, -0.956825873382378570, -0.956811339099272630, -0.956796802424138340, -0.956782263357011890, -0.956767721897929910, -0.956753178046928720, +-0.956738631804044500, -0.956724083169313790, -0.956709532142772770, -0.956694978724457750, -0.956680422914405470, -0.956665864712652250, -0.956651304119234270, -0.956636741134188060, +-0.956622175757549930, -0.956607607989356400, -0.956593037829643890, -0.956578465278448810, -0.956563890335807580, -0.956549313001756270, -0.956534733276331980, -0.956520151159570790, +-0.956505566651509320, -0.956490979752183890, -0.956476390461630800, -0.956461798779886910, -0.956447204706988630, -0.956432608242972270, -0.956418009387874360, -0.956403408141731530, +-0.956388804504580080, -0.956374198476456660, -0.956359590057397790, -0.956344979247439890, -0.956330366046619250, -0.956315750454972970, -0.956301132472537340, -0.956286512099348900, +-0.956271889335444160, -0.956257264180859660, -0.956242636635631800, -0.956228006699797570, -0.956213374373393380, -0.956198739656455740, -0.956184102549021200, -0.956169463051126380, +-0.956154821162807920, -0.956140176884102470, -0.956125530215046540, -0.956110881155676550, -0.956096229706029590, -0.956081575866142060, -0.956066919636050620, -0.956052261015791880, +-0.956037600005402390, -0.956022936604918770, -0.956008270814378000, -0.955993602633816610, -0.955978932063271110, -0.955964259102778380, -0.955949583752374930, -0.955934906012097630, +-0.955920225881982890, -0.955905543362067790, -0.955890858452388410, -0.955876171152982180, -0.955861481463885610, -0.955846789385135230, -0.955832094916767900, -0.955817398058820380, +-0.955802698811329070, -0.955787997174331270, -0.955773293147863520, -0.955758586731962460, -0.955743877926665040, -0.955729166732007810, -0.955714453148027720, -0.955699737174761530, +-0.955685018812245990, -0.955670298060517840, -0.955655574919613730, -0.955640849389570950, -0.955626121470426030, -0.955611391162215830, -0.955596658464977100, -0.955581923378746480, +-0.955567185903561380, -0.955552446039458210, -0.955537703786474070, -0.955522959144645580, -0.955508212114009710, -0.955493462694603220, -0.955478710886463190, -0.955463956689626360, +-0.955449200104129590, -0.955434441130009640, -0.955419679767303800, -0.955404916016048710, -0.955390149876281350, -0.955375381348038680, -0.955360610431357560, -0.955345837126274630, +-0.955331061432827310, -0.955316283351052340, -0.955301502880986700, -0.955286720022667350, -0.955271934776131150, -0.955257147141415190, -0.955242357118556210, -0.955227564707591400, +-0.955212769908557520, -0.955197972721491870, -0.955183173146431310, -0.955168371183412800, -0.955153566832473430, -0.955138760093650060, -0.955123950966979550, -0.955109139452499530, +-0.955094325550246540, -0.955079509260257750, -0.955064690582570260, -0.955049869517220930, -0.955035046064247050, -0.955020220223685490, -0.955005391995573330, -0.954990561379947530, +-0.954975728376845520, -0.954960892986304270, -0.954946055208360620, -0.954931215043052010, -0.954916372490415280, -0.954901527550487410, -0.954886680223305920, -0.954871830508907780, +-0.954856978407329970, -0.954842123918609790, -0.954827267042784310, -0.954812407779890630, -0.954797546129966030, -0.954782682093047400, -0.954767815669172240, -0.954752946858377080, +-0.954738075660700010, -0.954723202076177670, -0.954708326104847350, -0.954693447746746140, -0.954678567001911120, -0.954663683870379920, -0.954648798352189520, -0.954633910447377110, +-0.954619020155979880, -0.954604127478035140, -0.954589232413580070, -0.954574334962651980, -0.954559435125288070, -0.954544532901525520, -0.954529628291401310, -0.954514721294953410, +-0.954499811912218550, -0.954484900143234280, -0.954469985988037780, -0.954455069446666250, -0.954440150519156870, -0.954425229205547290, -0.954410305505874690, -0.954395379420176270, +-0.954380450948489440, -0.954365520090851520, -0.954350586847299790, -0.954335651217871560, -0.954320713202604140, -0.954305772801534720, -0.954290830014701160, -0.954275884842140540, +-0.954260937283890160, -0.954245987339987560, -0.954231035010469800, -0.954216080295374300, -0.954201123194738820, -0.954186163708600650, -0.954171201836997000, -0.954156237579965260, +-0.954141270937542970, -0.954126301909767550, -0.954111330496676400, -0.954096356698306840, -0.954081380514696150, -0.954066401945882330, -0.954051420991902430, -0.954036437652794000, +-0.954021451928594440, -0.954006463819341400, -0.953991473325071840, -0.953976480445823840, -0.953961485181634590, -0.953946487532541740, -0.953931487498582590, -0.953916485079794760, +-0.953901480276215690, -0.953886473087882990, -0.953871463514833980, -0.953856451557106410, -0.953841437214737460, -0.953826420487765110, -0.953811401376226780, -0.953796379880159970, +-0.953781355999602120, -0.953766329734590630, -0.953751301085163590, -0.953736270051358300, -0.953721236633212400, -0.953706200830763410, -0.953691162644048850, -0.953676122073106370, +-0.953661079117973600, -0.953646033778688170, -0.953630986055287620, -0.953615935947809360, -0.953600883456291460, -0.953585828580771460, -0.953570771321286870, -0.953555711677875340, +-0.953540649650574500, -0.953525585239421770, -0.953510518444455340, -0.953495449265712610, -0.953480377703231240, -0.953465303757048970, -0.953450227427203530, -0.953435148713732360, +-0.953420067616673420, -0.953404984136064230, -0.953389898271942430, -0.953374810024346100, -0.953359719393312650, -0.953344626378880070, -0.953329530981085750, -0.953314433199967670, +-0.953299333035563360, -0.953284230487910780, -0.953269125557047790, -0.953254018243011920, -0.953238908545841030, -0.953223796465572870, -0.953208682002245180, -0.953193565155895820, +-0.953178445926562530, -0.953163324314282860, -0.953148200319095080, -0.953133073941036860, -0.953117945180146030, -0.953102814036460240, -0.953087680510017470, -0.953072544600855220, +-0.953057406309011810, -0.953042265634524990, -0.953027122577432380, -0.953011977137772080, -0.952996829315581830, -0.952981679110899370, -0.952966526523762900, -0.952951371554210060, +-0.952936214202278700, -0.952921054468006570, -0.952905892351432190, -0.952890727852592880, -0.952875560971526920, -0.952860391708271970, -0.952845220062865870, -0.952830046035346930, +-0.952814869625752790, -0.952799690834121530, -0.952784509660491110, -0.952769326104899390, -0.952754140167384360, -0.952738951847983960, -0.952723761146736180, -0.952708568063678980, +-0.952693372598850120, -0.952678174752288110, -0.952662974524030590, -0.952647771914115650, -0.952632566922581360, -0.952617359549465580, -0.952602149794806170, -0.952586937658641660, +-0.952571723141009800, -0.952556506241948650, -0.952541286961496200, -0.952526065299690530, -0.952510841256569710, -0.952495614832171710, -0.952480386026534840, -0.952465154839696630, +-0.952449921271695810, -0.952434685322570140, -0.952419446992357810, -0.952404206281096900, -0.952388963188825490, -0.952373717715581320, -0.952358469861403160, -0.952343219626328840, +-0.952327967010396460, -0.952312712013644200, -0.952297454636110040, -0.952282194877832390, -0.952266932738849100, -0.952251668219198600, -0.952236401318918620, -0.952221132038047920, +-0.952205860376624360, -0.952190586334686230, -0.952175309912271620, -0.952160031109418600, -0.952144749926165380, -0.952129466362550470, -0.952114180418611960, -0.952098892094387920, +-0.952083601389916770, -0.952068308305236480, -0.952053012840385460, -0.952037714995402020, -0.952022414770324230, -0.952007112165190290, -0.951991807180038400, -0.951976499814907280, +-0.951961190069834930, -0.951945877944859520, -0.951930563440019470, -0.951915246555352650, -0.951899927290898120, -0.951884605646693750, -0.951869281622777730, -0.951853955219188700, +-0.951838626435964620, -0.951823295273144020, -0.951807961730765210, -0.951792625808866480, -0.951777287507486250, -0.951761946826662490, -0.951746603766434050, -0.951731258326839250, +-0.951715910507916150, -0.951700560309703400, -0.951685207732239190, -0.951669852775561710, -0.951654495439709810, -0.951639135724721810, -0.951623773630635880, -0.951608409157490450, +-0.951593042305324150, -0.951577673074175070, -0.951562301464081940, -0.951546927475083070, -0.951531551107216540, -0.951516172360521440, -0.951500791235035840, -0.951485407730798370, +-0.951470021847847240, -0.951454633586221180, -0.951439242945958160, -0.951423849927097390, -0.951408454529677040, -0.951393056753735420, -0.951377656599311280, -0.951362254066442930, +-0.951346849155168980, -0.951331441865527870, -0.951316032197558230, -0.951300620151298130, -0.951285205726786880, -0.951269788924062440, -0.951254369743163690, -0.951238948184128910, +-0.951223524246996850, -0.951208097931805610, -0.951192669238594470, -0.951177238167401630, -0.951161804718265720, -0.951146368891225280, -0.951130930686318930, -0.951115490103585310, +-0.951100047143062840, -0.951084601804790370, -0.951069154088806320, -0.951053703995149100, -0.951038251523857900, -0.951022796674971140, -0.951007339448527330, -0.950991879844565240, +-0.950976417863123040, -0.950960953504240260, -0.950945486767954980, -0.950930017654305960, -0.950914546163331930, -0.950899072295071530, -0.950883596049563410, -0.950868117426846400, +-0.950852636426959050, -0.950837153049940100, -0.950821667295827950, -0.950806179164662040, -0.950790688656480530, -0.950775195771322410, -0.950759700509226200, -0.950744202870230870, +-0.950728702854374610, -0.950713200461696940, -0.950697695692236280, -0.950682188546031370, -0.950666679023121080, -0.950651167123543920, -0.950635652847338970, -0.950620136194544880, +-0.950604617165200390, -0.950589095759344140, -0.950573571977015310, -0.950558045818252650, -0.950542517283094910, -0.950526986371580840, -0.950511453083749290, -0.950495917419638790, +-0.950480379379288860, -0.950464838962737920, -0.950449296170024830, -0.950433751001188650, -0.950418203456268040, -0.950402653535301840, -0.950387101238329040, -0.950371546565388580, +-0.950355989516518900, -0.950340430091759500, -0.950324868291149040, -0.950309304114726470, -0.950293737562530550, -0.950278168634600350, -0.950262597330974400, -0.950247023651692340, +-0.950231447596792680, -0.950215869166314290, -0.950200288360296350, -0.950184705178777620, -0.950169119621797180, -0.950153531689393870, -0.950137941381606790, -0.950122348698474890, +-0.950106753640036830, -0.950091156206332110, -0.950075556397399490, -0.950059954213278050, -0.950044349654006640, -0.950028742719624120, -0.950013133410170020, -0.949997521725683190, +-0.949981907666202390, -0.949966291231766900, -0.949950672422415710, -0.949935051238187780, -0.949919427679122300, -0.949903801745258130, -0.949888173436634560, -0.949872542753290250, +-0.949856909695264820, -0.949841274262597120, -0.949825636455326360, -0.949809996273491390, -0.949794353717131390, -0.949778708786285340, -0.949763061480992770, -0.949747411801292520, +-0.949731759747223680, -0.949716105318825550, -0.949700448516137110, -0.949684789339197530, -0.949669127788046020, -0.949653463862721650, -0.949637797563263390, -0.949622128889710870, +-0.949606457842103070, -0.949590784420479170, -0.949575108624878150, -0.949559430455339530, -0.949543749911901940, -0.949528066994605350, -0.949512381703488510, -0.949496694038590720, +-0.949481003999951170, -0.949465311587609160, -0.949449616801603890, -0.949433919641974540, -0.949418220108760420, -0.949402518202000500, -0.949386813921734520, -0.949371107268001560, +-0.949355398240840700, -0.949339686840291460, -0.949323973066392930, -0.949308256919184300, -0.949292538398705200, -0.949276817504994820, -0.949261094238092350, -0.949245368598037210, +-0.949229640584868580, -0.949213910198625890, -0.949198177439348310, -0.949182442307075380, -0.949166704801846390, -0.949150964923700320, -0.949135222672677140, -0.949119478048815910, +-0.949103731052155950, -0.949087981682736670, -0.949072229940597150, -0.949056475825777350, -0.949040719338316240, -0.949024960478253470, -0.949009199245628320, -0.948993435640480110, +-0.948977669662848360, -0.948961901312772360, -0.948946130590291650, -0.948930357495445630, -0.948914582028273390, -0.948898804188815000, -0.948883023977109660, -0.948867241393196670, +-0.948851456437115550, -0.948835669108905600, -0.948819879408606790, -0.948804087336258210, -0.948788292891899370, -0.948772496075569900, -0.948756696887309130, -0.948740895327156660, +-0.948725091395151930, -0.948709285091334450, -0.948693476415743750, -0.948677665368419130, -0.948661851949400560, -0.948646036158727450, -0.948630217996439100, -0.948614397462575360, +-0.948598574557175560, -0.948582749280279080, -0.948566921631925910, -0.948551091612155560, -0.948535259221007450, -0.948519424458521110, -0.948503587324736270, -0.948487747819692470, +-0.948471905943429340, -0.948456061695986400, -0.948440215077403060, -0.948424366087719410, -0.948408514726974850, -0.948392660995209020, -0.948376804892461570, -0.948360946418772110, +-0.948345085574179960, -0.948329222358725300, -0.948313356772447660, -0.948297488815386670, -0.948281618487581970, -0.948265745789073190, -0.948249870719899970, -0.948233993280102160, +-0.948218113469719400, -0.948202231288791330, -0.948186346737357360, -0.948170459815457780, -0.948154570523132120, -0.948138678860420030, -0.948122784827361230, -0.948106888423995150, +-0.948090989650362090, -0.948075088506501680, -0.948059184992453450, -0.948043279108257360, -0.948027370853953060, -0.948011460229580270, -0.947995547235178760, -0.947979631870788490, +-0.947963714136449200, -0.947947794032200200, -0.947931871558082120, -0.947915946714134260, -0.947900019500396600, -0.947884089916908870, -0.947868157963710600, -0.947852223640842210, +-0.947836286948343320, -0.947820347886253690, -0.947804406454613280, -0.947788462653461730, -0.947772516482839110, -0.947756567942785070, -0.947740617033339780, -0.947724663754542780, +-0.947708708106433930, -0.947692750089053630, -0.947676789702441400, -0.947660826946637220, -0.947644861821680950, -0.947628894327612550, -0.947612924464471540, -0.947596952232298670, +-0.947580977631133250, -0.947565000661015460, -0.947549021321985150, -0.947533039614082420, -0.947517055537346890, -0.947501069091818860, -0.947485080277538080, -0.947469089094544410, +-0.947453095542878150, -0.947437099622579270, -0.947421101333687620, -0.947405100676243170, -0.947389097650286120, -0.947373092255855860, -0.947357084492993270, -0.947341074361737870, +-0.947325061862129840, -0.947309046994209150, -0.947293029758015880, -0.947277010153590000, -0.947260988180971600, -0.947244963840200740, -0.947228937131317170, -0.947212908054361540, +-0.947196876609373680, -0.947180842796393590, -0.947164806615461320, -0.947148768066617190, -0.947132727149900710, -0.947116683865352860, -0.947100638213013160, -0.947084590192921900, +-0.947068539805119180, -0.947052487049645060, -0.947036431926539860, -0.947020374435843420, -0.947004314577596150, -0.946988252351838030, -0.946972187758609030, -0.946956120797949890, +-0.946940051469900350, -0.946923979774500710, -0.946907905711791180, -0.946891829281811590, -0.946875750484602710, -0.946859669320204380, -0.946843585788656910, -0.946827499890000480, +-0.946811411624275400, -0.946795320991521640, -0.946779227991779710, -0.946763132625089600, -0.946747034891491700, -0.946730934791025990, -0.946714832323733100, -0.946698727489653220, +-0.946682620288826550, -0.946666510721293260, -0.946650398787093670, -0.946634284486267850, -0.946618167818856660, -0.946602048784899950, -0.946585927384438140, -0.946569803617511530, +-0.946553677484160420, -0.946537548984425100, -0.946521418118345890, -0.946505284885963190, -0.946489149287316980, -0.946473011322448100, -0.946456870991396860, -0.946440728294203340, +-0.946424583230907950, -0.946408435801551210, -0.946392286006172980, -0.946376133844814340, -0.946359979317515480, -0.946343822424316580, -0.946327663165258180, -0.946311501540380570, +-0.946295337549724170, -0.946279171193329490, -0.946263002471236850, -0.946246831383486420, -0.946230657930119290, -0.946214482111175430, -0.946198303926695350, -0.946182123376719590, +-0.946165940461288430, -0.946149755180442200, -0.946133567534221840, -0.946117377522667560, -0.946101185145819870, -0.946084990403719180, -0.946068793296406030, -0.946052593823920820, +-0.946036391986304180, -0.946020187783596640, -0.946003981215838510, -0.945987772283070290, -0.945971560985332750, -0.945955347322666400, -0.945939131295111760, -0.945922912902709130, +-0.945906692145499050, -0.945890469023522470, -0.945874243536819700, -0.945858015685431370, -0.945841785469398010, -0.945825552888760130, -0.945809317943558490, -0.945793080633833380, +-0.945776840959625660, -0.945760598920975860, -0.945744354517924270, -0.945728107750512080, -0.945711858618779600, -0.945695607122767460, -0.945679353262516290, -0.945663097038066840, +-0.945646838449459180, -0.945630577496734850, -0.945614314179934020, -0.945598048499097450, -0.945581780454265770, -0.945565510045479620, -0.945549237272779730, -0.945532962136206630, +-0.945516684635801190, -0.945500404771603800, -0.945484122543655660, -0.945467837951997180, -0.945451550996669110, -0.945435261677712190, -0.945418969995167170, -0.945402675949074340, +-0.945386379539475130, -0.945370080766409940, -0.945353779629919620, -0.945337476130044820, -0.945321170266826380, -0.945304862040304950, -0.945288551450521370, -0.945272238497516400, +-0.945255923181330560, -0.945239605502005250, -0.945223285459580900, -0.945206963054098240, -0.945190638285598350, -0.945174311154121760, -0.945157981659709100, -0.945141649802401780, +-0.945125315582240330, -0.945108978999265600, -0.945092640053518450, -0.945076298745039730, -0.945059955073870190, -0.945043609040050800, -0.945027260643622300, -0.945010909884625770, +-0.944994556763101620, -0.944978201279091380, -0.944961843432635670, -0.944945483223775360, -0.944929120652551300, -0.944912755719004130, -0.944896388423175360, -0.944880018765105630, +-0.944863646744835920, -0.944847272362406950, -0.944830895617859930, -0.944814516511235600, -0.944798135042575040, -0.944781751211919100, -0.944765365019308860, -0.944748976464784840, +-0.944732585548388680, -0.944716192270161010, -0.944699796630142920, -0.944683398628375360, -0.944666998264899190, -0.944650595539755390, -0.944634190452985250, -0.944617783004629730, +-0.944601373194729700, -0.944584961023326340, -0.944568546490460400, -0.944552129596173300, -0.944535710340505760, -0.944519288723498880, -0.944502864745193630, -0.944486438405631400, +-0.944470009704853180, -0.944453578642899800, -0.944437145219812590, -0.944420709435632500, -0.944404271290400280, -0.944387830784157670, -0.944371387916945530, -0.944354942688804930, +-0.944338495099776960, -0.944322045149902810, -0.944305592839223440, -0.944289138167780150, -0.944272681135614020, -0.944256221742765910, -0.944239759989277450, -0.944223295875189720, +-0.944206829400543680, -0.944190360565380530, -0.944173889369741560, -0.944157415813667520, -0.944140939897200270, -0.944124461620380550, -0.944107980983249770, -0.944091497985849130, +-0.944075012628219580, -0.944058524910402650, -0.944042034832439310, -0.944025542394370860, -0.944009047596238600, -0.943992550438083500, -0.943976050919947180, -0.943959549041870850, +-0.943943044803895570, -0.943926538206062760, -0.943910029248413160, -0.943893517930988970, -0.943877004253830810, -0.943860488216980320, -0.943843969820478470, -0.943827449064366770, +-0.943810925948686430, -0.943794400473478730, -0.943777872638785100, -0.943761342444646710, -0.943744809891104650, -0.943728274978201000, -0.943711737705976610, -0.943695198074472770, +-0.943678656083731030, -0.943662111733792660, -0.943645565024698650, -0.943629015956491070, -0.943612464529210990, -0.943595910742899720, -0.943579354597598670, -0.943562796093349140, +-0.943546235230192760, -0.943529672008170730, -0.943513106427324550, -0.943496538487695210, -0.943479968189325000, -0.943463395532254670, -0.943446820516525950, -0.943430243142180270, +-0.943413663409258810, -0.943397081317802980, -0.943380496867854750, -0.943363910059455300, -0.943347320892646060, -0.943330729367468420, -0.943314135483964030, -0.943297539242174410, +-0.943280940642140740, -0.943264339683904880, -0.943247736367507810, -0.943231130692991690, -0.943214522660397740, -0.943197912269767570, -0.943181299521142490, -0.943164684414564250, +-0.943148066950073920, -0.943131447127713800, -0.943114824947525080, -0.943098200409549170, -0.943081573513827930, -0.943064944260402660, -0.943048312649314990, -0.943031678680606560, +-0.943015042354318990, -0.942998403670493810, -0.942981762629172330, -0.942965119230396720, -0.942948473474208290, -0.942931825360648680, -0.942915174889759510, -0.942898522061582090, +-0.942881866876158710, -0.942865209333530680, -0.942848549433739520, -0.942831887176827090, -0.942815222562834900, -0.942798555591804700, -0.942781886263778010, -0.942765214578796700, +-0.942748540536902270, -0.942731864138136260, -0.942715185382540950, -0.942698504270157560, -0.942681820801027910, -0.942665134975193770, -0.942648446792696770, -0.942631756253578310, +-0.942615063357880810, -0.942598368105645680, -0.942581670496914550, -0.942564970531729380, -0.942548268210131600, -0.942531563532163270, -0.942514856497866040, -0.942498147107281640, +-0.942481435360451590, -0.942464721257418200, -0.942448004798222990, -0.942431285982907820, -0.942414564811514420, -0.942397841284084660, -0.942381115400659940, -0.942364387161282790, +-0.942347656565994620, -0.942330923614837280, -0.942314188307852740, -0.942297450645082630, -0.942280710626568930, -0.942263968252353480, -0.942247223522478030, -0.942230476436984320, +-0.942213726995914660, -0.942196975199310670, -0.942180221047214330, -0.942163464539667260, -0.942146705676711660, -0.942129944458389050, -0.942113180884741830, -0.942096414955811530, +-0.942079646671640350, -0.942062876032270010, -0.942046103037742500, -0.942029327688099660, -0.942012549983383570, -0.941995769923636090, -0.941978987508899190, -0.941962202739214490, +-0.941945415614624640, -0.941928626135171140, -0.941911834300896200, -0.941895040111841660, -0.941878243568049170, -0.941861444669561340, -0.941844643416419940, -0.941827839808666910, +-0.941811033846344350, -0.941794225529494210, -0.941777414858158470, -0.941760601832379200, -0.941743786452198360, -0.941726968717658150, -0.941710148628800090, -0.941693326185667030, +-0.941676501388300720, -0.941659674236743130, -0.941642844731036320, -0.941626012871222380, -0.941609178657343170, -0.941592342089441310, -0.941575503167558560, -0.941558661891736980, +-0.941541818262018880, -0.941524972278446230, -0.941508123941060980, -0.941491273249905560, -0.941474420205022030, -0.941457564806452040, -0.941440707054238430, -0.941423846948423070, +-0.941406984489048140, -0.941390119676155710, -0.941373252509787980, -0.941356382989986810, -0.941339511116794920, -0.941322636890254420, -0.941305760310407250, -0.941288881377295610, +-0.941272000090961790, -0.941255116451447990, -0.941238230458796400, -0.941221342113049310, -0.941204451414248470, -0.941187558362436840, -0.941170662957656280, -0.941153765199949090, +-0.941136865089357570, -0.941119962625923790, -0.941103057809689840, -0.941086150640698450, -0.941069241118991820, -0.941052329244612020, -0.941035415017601350, -0.941018498438002230, +-0.941001579505856830, -0.940984658221207470, -0.940967734584096550, -0.940950808594566150, -0.940933880252658560, -0.940916949558416540, -0.940900016511882040, -0.940883081113097600, +-0.940866143362105390, -0.940849203258947610, -0.940832260803667110, -0.940815315996305860, -0.940798368836906370, -0.940781419325511070, -0.940764467462162140, -0.940747513246901980, +-0.940730556679773120, -0.940713597760817870, -0.940696636490078510, -0.940679672867597350, -0.940662706893417360, -0.940645738567580490, -0.940628767890129390, -0.940611794861106240, +-0.940594819480553680, -0.940577841748513780, -0.940560861665029610, -0.940543879230143150, -0.940526894443897140, -0.940509907306333770, -0.940492917817495780, -0.940475925977425350, +-0.940458931786165240, -0.940441935243757630, -0.940424936350245040, -0.940407935105670330, -0.940390931510075800, -0.940373925563503970, -0.940356917265997350, -0.940339906617598360, +-0.940322893618349310, -0.940305878268293370, -0.940288860567472740, -0.940271840515929940, -0.940254818113707480, -0.940237793360848010, -0.940220766257394040, -0.940203736803388200, +-0.940186704998873020, -0.940169670843890800, -0.940152634338484620, -0.940135595482696980, -0.940118554276570210, -0.940101510720147140, -0.940084464813470300, -0.940067416556581990, +-0.940050365949525400, -0.940033312992342940, -0.940016257685077130, -0.939999200027770710, -0.939982140020466320, -0.939965077663206580, -0.939948012956034140, -0.939930945898991620, +-0.939913876492121770, -0.939896804735467000, -0.939879730629070380, -0.939862654172974540, -0.939845575367222020, -0.939828494211855550, -0.939811410706917540, -0.939794324852451400, +-0.939777236648499330, -0.939760146095104280, -0.939743053192308770, -0.939725957940155680, -0.939708860338687610, -0.939691760387947550, -0.939674658087977900, -0.939657553438821740, +-0.939640446440521360, -0.939623337093120180, -0.939606225396660610, -0.939589111351185500, -0.939571994956737600, -0.939554876213359760, -0.939537755121094390, -0.939520631679985010, +-0.939503505890073920, -0.939486377751404200, -0.939469247264018370, -0.939452114427959620, -0.939434979243270460, -0.939417841709993870, -0.939400701828172700, -0.939383559597849470, +-0.939366415019067590, -0.939349268091869690, -0.939332118816298630, -0.939314967192397270, -0.939297813220208560, -0.939280656899774910, -0.939263498231139970, -0.939246337214346360, +-0.939229173849436830, -0.939212008136454330, -0.939194840075441850, -0.939177669666442340, -0.939160496909498540, -0.939143321804653540, -0.939126144351949970, -0.939108964551431340, +-0.939091782403140280, -0.939074597907119780, -0.939057411063412670, -0.939040221872062150, -0.939023030333110740, -0.939005836446602070, -0.938988640212578880, -0.938971441631083930, +-0.938954240702160490, -0.938937037425851440, -0.938919831802199730, -0.938902623831248560, -0.938885413513040780, -0.938868200847619460, -0.938850985835027240, -0.938833768475307970, +-0.938816548768504290, -0.938799326714659150, -0.938782102313815760, -0.938764875566016730, -0.938747646471305930, -0.938730415029725980, -0.938713181241319970, -0.938695945106130970, +-0.938678706624202160, -0.938661465795576630, -0.938644222620297340, -0.938626977098407590, -0.938609729229950340, -0.938592479014968450, -0.938575226453505660, -0.938557971545604830, +-0.938540714291309030, -0.938523454690661560, -0.938506192743705060, -0.938488928450483370, -0.938471661811039360, -0.938454392825416210, -0.938437121493657100, -0.938419847815805230, +-0.938402571791903670, -0.938385293421995730, -0.938368012706124470, -0.938350729644333300, -0.938333444236664870, -0.938316156483163240, -0.938298866383871170, -0.938281573938831940, +-0.938264279148088740, -0.938246982011684880, -0.938229682529663320, -0.938212380702067810, -0.938195076528941300, -0.938177770010327210, -0.938160461146268610, -0.938143149936808810, +-0.938125836381991210, -0.938108520481859000, -0.938091202236455590, -0.938073881645823730, -0.938056558710007480, -0.938039233429049930, -0.938021905802994160, -0.938004575831883790, +-0.937987243515761900, -0.937969908854671570, -0.937952571848656770, -0.937935232497760560, -0.937917890802026260, -0.937900546761497260, -0.937883200376216970, -0.937865851646228600, +-0.937848500571575540, -0.937831147152301310, -0.937813791388448890, -0.937796433280062240, -0.937779072827184530, -0.937761710029859200, -0.937744344888129520, -0.937726977402039030, +-0.937709607571630800, -0.937692235396948790, -0.937674860878036310, -0.937657484014936650, -0.937640104807693220, -0.937622723256349540, -0.937605339360949030, -0.937587953121535200, +-0.937570564538151460, -0.937553173610841340, -0.937535780339648020, -0.937518384724615460, -0.937500986765787080, -0.937483586463206060, -0.937466183816916150, -0.937448778826960540, +-0.937431371493383180, -0.937413961816227490, -0.937396549795536880, -0.937379135431354870, -0.937361718723724980, -0.937344299672690840, -0.937326878278295970, -0.937309454540583900, +-0.937292028459598140, -0.937274600035381990, -0.937257169267979750, -0.937239736157434500, -0.937222300703789980, -0.937204862907089600, -0.937187422767377210, -0.937169980284695890, +-0.937152535459089830, -0.937135088290602550, -0.937117638779277560, -0.937100186925158400, -0.937082732728288790, -0.937065276188712380, -0.937047817306472800, -0.937030356081613560, +-0.937012892514178300, -0.936995426604210980, -0.936977958351755120, -0.936960487756854370, -0.936943014819552440, -0.936925539539892880, -0.936908061917919310, -0.936890581953675810, +-0.936873099647205780, -0.936855614998553080, -0.936838128007761340, -0.936820638674874310, -0.936803146999935720, -0.936785652982989100, -0.936768156624078530, -0.936750657923247190, +-0.936733156880539490, -0.936715653495998830, -0.936698147769669200, -0.936680639701594100, -0.936663129291817390, -0.936645616540382590, -0.936628101447333990, -0.936610584012715240, +-0.936593064236569960, -0.936575542118942010, -0.936558017659875230, -0.936540490859413490, -0.936522961717600410, -0.936505430234479960, -0.936487896410096000, -0.936470360244491930, +-0.936452821737712270, -0.936435280889800550, -0.936417737700800610, -0.936400192170756320, -0.936382644299711300, -0.936365094087709960, -0.936347541534795820, -0.936329986641012860, +-0.936312429406405020, -0.936294869831016060, -0.936277307914889830, -0.936259743658070410, -0.936242177060601640, -0.936224608122527390, -0.936207036843891390, -0.936189463224738060, +-0.936171887265111020, -0.936154308965054360, -0.936136728324611810, -0.936119145343827560, -0.936101560022745030, -0.936083972361409060, -0.936066382359863060, -0.936048790018151110, +-0.936031195336317180, -0.936013598314405230, -0.935995998952459330, -0.935978397250523450, -0.935960793208641560, -0.935943186826857290, -0.935925578105215480, -0.935907967043759670, +-0.935890353642533920, -0.935872737901582430, -0.935855119820948930, -0.935837499400677400, -0.935819876640812450, -0.935802251541397730, -0.935784624102477420, -0.935766994324095600, +-0.935749362206296230, -0.935731727749123500, -0.935714090952621370, -0.935696451816834140, -0.935678810341805330, -0.935661166527579910, -0.935643520374201510, -0.935625871881714310, +-0.935608221050162500, -0.935590567879590160, -0.935572912370041030, -0.935555254521559850, -0.935537594334190590, -0.935519931807977430, -0.935502266942964340, -0.935484599739195620, +-0.935466930196715450, -0.935449258315567910, -0.935431584095797190, -0.935413907537447580, -0.935396228640562820, -0.935378547405187890, -0.935360863831366520, -0.935343177919143010, +-0.935325489668561550, -0.935307799079665990, -0.935290106152501300, -0.935272410887111440, -0.935254713283540480, -0.935237013341832730, -0.935219311062032380, -0.935201606444183820, +-0.935183899488331250, -0.935166190194518960, -0.935148478562791150, -0.935130764593191780, -0.935113048285765910, -0.935095329640557420, -0.935077608657610470, -0.935059885336969600, +-0.935042159678679100, -0.935024431682782710, -0.935006701349325730, -0.934988968678351910, -0.934971233669905640, -0.934953496324031350, -0.934935756640773220, -0.934918014620175760, +-0.934900270262283280, -0.934882523567140190, -0.934864774534790330, -0.934847023165279010, -0.934829269458649970, -0.934811513414947840, -0.934793755034216910, -0.934775994316501600, +-0.934758231261845980, -0.934740465870295130, -0.934722698141893130, -0.934704928076684370, -0.934687155674713280, -0.934669380936024250, -0.934651603860661820, -0.934633824448670380, +-0.934616042700094350, -0.934598258614977920, -0.934580472193366150, -0.934562683435303130, -0.934544892340833490, -0.934527098910001630, -0.934509303142852080, -0.934491505039428790, +-0.934473704599777190, -0.934455901823941230, -0.934438096711965650, -0.934420289263894750, -0.934402479479773060, -0.934384667359645200, -0.934366852903555810, -0.934349036111549180, +-0.934331216983669940, -0.934313395519962290, -0.934295571720471620, -0.934277745585241900, -0.934259917114317880, -0.934242086307744080, -0.934224253165564680, -0.934206417687824970, +-0.934188579874569270, -0.934170739725842080, -0.934152897241688150, -0.934135052422151890, -0.934117205267277930, -0.934099355777111010, -0.934081503951695760, -0.934063649791076700, +-0.934045793295298240, -0.934027934464405570, -0.934010073298443100, -0.933992209797455340, -0.933974343961487150, -0.933956475790583050, -0.933938605284787560, -0.933920732444145750, +-0.933902857268702150, -0.933884979758501490, -0.933867099913588290, -0.933849217734007310, -0.933831333219803380, -0.933813446371021040, -0.933795557187705130, -0.933777665669899950, +-0.933759771817651020, -0.933741875631002530, -0.933723977109999440, -0.933706076254686380, -0.933688173065108210, -0.933670267541309220, -0.933652359683334820, -0.933634449491229650, +-0.933616536965038320, -0.933598622104805600, -0.933580704910576320, -0.933562785382395340, -0.933544863520307300, -0.933526939324357260, -0.933509012794589420, -0.933491083931049400, +-0.933473152733781620, -0.933455219202831030, -0.933437283338242390, -0.933419345140060530, -0.933401404608329990, -0.933383461743096280, -0.933365516544403920, -0.933347569012297650, +-0.933329619146822550, -0.933311666948023480, -0.933293712415945160, -0.933275755550632580, -0.933257796352130580, -0.933239834820484120, -0.933221870955737720, -0.933203904757937020, +-0.933185936227126420, -0.933167965363351120, -0.933149992166655840, -0.933132016637085340, -0.933114038774685020, -0.933096058579499730, -0.933078076051574110, -0.933060091190953460, +-0.933042103997682500, -0.933024114471806330, -0.933006122613369900, -0.932988128422418070, -0.932970131898996020, -0.932952133043148170, -0.932934131854920470, -0.932916128334357330, +-0.932898122481503940, -0.932880114296405160, -0.932862103779106170, -0.932844090929651590, -0.932826075748087180, -0.932808058234457450, -0.932790038388807590, -0.932772016211182660, +-0.932753991701627760, -0.932735964860187840, -0.932717935686907970, -0.932699904181833240, -0.932681870345008490, -0.932663834176479360, -0.932645795676290690, -0.932627754844487460, +-0.932609711681114840, -0.932591666186218030, -0.932573618359841650, -0.932555568202031560, -0.932537515712832610, -0.932519460892289760, -0.932501403740448320, -0.932483344257353460, +-0.932465282443050160, -0.932447218297583590, -0.932429151820999060, -0.932411083013341300, -0.932393011874656170, -0.932374938404988420, -0.932356862604383440, -0.932338784472886320, +-0.932320704010542120, -0.932302621217395930, -0.932284536093493490, -0.932266448638879750, -0.932248358853599800, -0.932230266737699040, -0.932212172291222550, -0.932194075514215630, +-0.932175976406723560, -0.932157874968791540, -0.932139771200464760, -0.932121665101788290, -0.932103556672807980, -0.932085445913568790, -0.932067332824116020, -0.932049217404494870, +-0.932031099654750390, -0.932012979574928460, -0.931994857165074020, -0.931976732425232490, -0.931958605355449170, -0.931940475955769340, -0.931922344226238210, -0.931904210166901280, +-0.931886073777803860, -0.931867935058991240, -0.931849794010508490, -0.931831650632401480, -0.931813504924715490, -0.931795356887495600, -0.931777206520787330, -0.931759053824636090, +-0.931740898799086950, -0.931722741444185760, -0.931704581759977830, -0.931686419746508340, -0.931668255403822920, -0.931650088731966750, -0.931631919730985470, -0.931613748400924370, +-0.931595574741828860, -0.931577398753744010, -0.931559220436716130, -0.931541039790790060, -0.931522856816011550, -0.931504671512425770, -0.931486483880078380, -0.931468293919014420, +-0.931450101629280100, -0.931431907010920490, -0.931413710063981100, -0.931395510788507460, -0.931377309184544980, -0.931359105252139270, -0.931340898991335870, -0.931322690402180190, +-0.931304479484717400, -0.931286266238993800, -0.931268050665054470, -0.931249832762945040, -0.931231612532711030, -0.931213389974397950, -0.931195165088051110, -0.931176937873716690, +-0.931158708331439990, -0.931140476461266410, -0.931122242263241700, -0.931104005737411370, -0.931085766883821050, -0.931067525702516270, -0.931049282193542660, -0.931031036356945950, +-0.931012788192771220, -0.930994537701064880, -0.930976284881872120, -0.930958029735238780, -0.930939772261210270, -0.930921512459832120, -0.930903250331150400, -0.930884985875210620, +-0.930866719092058310, -0.930848449981739210, -0.930830178544299060, -0.930811904779783370, -0.930793628688238010, -0.930775350269708590, -0.930757069524240640, -0.930738786451879800, +-0.930720501052672340, -0.930702213326663590, -0.930683923273899370, -0.930665630894425220, -0.930647336188287100, -0.930629039155530300, -0.930610739796201240, -0.930592438110345200, +-0.930574134098008270, -0.930555827759235840, -0.930537519094073890, -0.930519208102568160, -0.930500894784764390, -0.930482579140708420, -0.930464261170445670, -0.930445940874022550, +-0.930427618251484570, -0.930409293302877580, -0.930390966028247330, -0.930372636427639790, -0.930354304501100240, -0.930335970248675200, -0.930317633670410320, -0.930299294766351310, +-0.930280953536544050, -0.930262609981034380, -0.930244264099868270, -0.930225915893091450, -0.930207565360749890, -0.930189212502889110, -0.930170857319555510, -0.930152499810794840, +-0.930134139976652950, -0.930115777817175690, -0.930097413332408920, -0.930079046522398370, -0.930060677387190450, -0.930042305926830900, -0.930023932141365580, -0.930005556030840450, +-0.929987177595301360, -0.929968796834794390, -0.929950413749365380, -0.929932028339060410, -0.929913640603925340, -0.929895250544005790, -0.929876858159348510, -0.929858463449999010, +-0.929840066416003360, -0.929821667057407650, -0.929803265374257390, -0.929784861366599210, -0.929766455034478970, -0.929748046377942620, -0.929729635397036120, -0.929711222091805460, +-0.929692806462296790, -0.929674388508556100, -0.929655968230629460, -0.929637545628562930, -0.929619120702402160, -0.929600693452193870, -0.929582263877983930, -0.929563831979818290, +-0.929545397757743140, -0.929526961211804450, -0.929508522342048060, -0.929490081148520610, -0.929471637631267940, -0.929453191790336250, -0.929434743625771610, -0.929416293137620090, +-0.929397840325927760, -0.929379385190740930, -0.929360927732105660, -0.929342467950067590, -0.929324005844673780, -0.929305541415969990, -0.929287074664002290, -0.929268605588816850, +-0.929250134190459990, -0.929231660468977430, -0.929213184424416140, -0.929194706056821750, -0.929176225366240670, -0.929157742352718970, -0.929139257016302960, -0.929120769357038800, +-0.929102279374972690, -0.929083787070150930, -0.929065292442619370, -0.929046795492424860, -0.929028296219613470, -0.929009794624231280, -0.928991290706324580, -0.928972784465939670, +-0.928954275903122410, -0.928935765017919860, -0.928917251810377880, -0.928898736280542760, -0.928880218428460800, -0.928861698254178300, -0.928843175757741560, -0.928824650939196860, +-0.928806123798590620, -0.928787594335968910, -0.928769062551378030, -0.928750528444864720, -0.928731992016475160, -0.928713453266255650, -0.928694912194252490, -0.928676368800511630, +-0.928657823085080270, -0.928639275048004360, -0.928620724689330210, -0.928602172009104220, -0.928583617007372910, -0.928565059684182460, -0.928546500039579390, -0.928527938073610000, +-0.928509373786320920, -0.928490807177758000, -0.928472238247968320, -0.928453666996998160, -0.928435093424893720, -0.928416517531701620, -0.928397939317467950, -0.928379358782239650, +-0.928360775926063030, -0.928342190748984500, -0.928323603251050340, -0.928305013432307310, -0.928286421292801700, -0.928267826832580020, -0.928249230051688800, -0.928230630950174550, +-0.928212029528083350, -0.928193425785462380, -0.928174819722357940, -0.928156211338816320, -0.928137600634884260, -0.928118987610608180, -0.928100372266034260, -0.928081754601209790, +-0.928063134616180950, -0.928044512310994160, -0.928025887685696160, -0.928007260740333460, -0.927988631474952700, -0.927969999889600160, -0.927951365984322820, -0.927932729759166630, +-0.927914091214178890, -0.927895450349406010, -0.927876807164894510, -0.927858161660690910, -0.927839513836841930, -0.927820863693393890, -0.927802211230394080, -0.927783556447888570, +-0.927764899345924320, -0.927746239924547740, -0.927727578183805580, -0.927708914123744450, -0.927690247744411110, -0.927671579045852070, -0.927652908028114180, -0.927634234691243620, +-0.927615559035287810, -0.927596881060293030, -0.927578200766306150, -0.927559518153373790, -0.927540833221542240, -0.927522145970858910, -0.927503456401370220, -0.927484764513123010, +-0.927466070306163790, -0.927447373780539430, -0.927428674936296550, -0.927409973773482110, -0.927391270292142630, -0.927372564492325080, -0.927353856374075750, -0.927335145937442040, +-0.927316433182470480, -0.927297718109207910, -0.927279000717700970, -0.927260281007996290, -0.927241558980141160, -0.927222834634182200, -0.927204107970166060, -0.927185378988139690, +-0.927166647688149940, -0.927147914070243550, -0.927129178134467270, -0.927110439880868160, -0.927091699309492870, -0.927072956420388120, -0.927054211213601210, -0.927035463689178770, +-0.927016713847167660, -0.926997961687614840, -0.926979207210567040, -0.926960450416070890, -0.926941691304174030, -0.926922929874922860, -0.926904166128364460, -0.926885400064545560, +-0.926866631683513240, -0.926847860985314240, -0.926829087969995640, -0.926810312637604270, -0.926791534988186890, -0.926772755021790910, -0.926753972738463050, -0.926735188138250400, +-0.926716401221199580, -0.926697611987357890, -0.926678820436771740, -0.926660026569488980, -0.926641230385556120, -0.926622431885020140, -0.926603631067928090, -0.926584827934326950, +-0.926566022484263780, -0.926547214717785560, -0.926528404634939350, -0.926509592235771670, -0.926490777520330380, -0.926471960488662210, -0.926453141140814120, -0.926434319476833190, +-0.926415495496766380, -0.926396669200660550, -0.926377840588563430, -0.926359009660521650, -0.926340176416582390, -0.926321340856792630, -0.926302502981199540, -0.926283662789850190, +-0.926264820282791670, -0.926245975460071150, -0.926227128321735590, -0.926208278867831970, -0.926189427098408010, -0.926170573013510470, -0.926151716613186400, -0.926132857897483120, +-0.926113996866447350, -0.926095133520126960, -0.926076267858568670, -0.926057399881819790, -0.926038529589927270, -0.926019656982938530, -0.926000782060900640, -0.925981904823860780, +-0.925963025271866140, -0.925944143404964000, -0.925925259223201120, -0.925906372726625460, -0.925887483915283860, -0.925868592789223510, -0.925849699348491710, -0.925830803593135630, +-0.925811905523202250, -0.925793005138739410, -0.925774102439794080, -0.925755197426413550, -0.925736290098645000, -0.925717380456535620, -0.925698468500132820, -0.925679554229483890, +-0.925660637644636130, -0.925641718745636390, -0.925622797532532630, -0.925603874005371920, -0.925584948164201560, -0.925566020009068850, -0.925547089540021070, -0.925528156757105200, +-0.925509221660369310, -0.925490284249860240, -0.925471344525625630, -0.925452402487712540, -0.925433458136168510, -0.925414511471040810, -0.925395562492376870, -0.925376611200223960, +-0.925357657594629180, -0.925338701675640700, -0.925319743443305360, -0.925300782897670700, -0.925281820038784120, -0.925262854866692910, -0.925243887381444250, -0.925224917583086230, +-0.925205945471666010, -0.925186971047230800, -0.925167994309828210, -0.925149015259505550, -0.925130033896310430, -0.925111050220290280, -0.925092064231492370, -0.925073075929964350, +-0.925054085315753390, -0.925035092388907470, -0.925016097149473860, -0.924997099597499980, -0.924978099733033350, -0.924959097556121160, -0.924940093066811580, -0.924921086265151680, +-0.924902077151189110, -0.924883065724971360, -0.924864051986545980, -0.924845035935960460, -0.924826017573262330, -0.924806996898499100, -0.924787973911718410, -0.924768948612967550, +-0.924749921002294470, -0.924730891079746710, -0.924711858845371770, -0.924692824299217060, -0.924673787441330330, -0.924654748271758860, -0.924635706790550850, -0.924616662997753470, +-0.924597616893414460, -0.924578568477581460, -0.924559517750302100, -0.924540464711623880, -0.924521409361594440, -0.924502351700261520, -0.924483291727672410, -0.924464229443875410, +-0.924445164848917810, -0.924426097942847250, -0.924407028725711570, -0.924387957197558170, -0.924368883358434700, -0.924349807208389220, -0.924330728747469240, -0.924311647975722520, +-0.924292564893196670, -0.924273479499939320, -0.924254391795998330, -0.924235301781421440, -0.924216209456256150, -0.924197114820550110, -0.924178017874351500, -0.924158918617707940, +-0.924139817050667060, -0.924120713173276710, -0.924101606985584520, -0.924082498487637900, -0.924063387679485480, -0.924044274561174550, -0.924025159132752960, -0.924006041394268450, +-0.923986921345768760, -0.923967798987301860, -0.923948674318915470, -0.923929547340657350, -0.923910418052575340, -0.923891286454717080, -0.923872152547130840, -0.923853016329864160, +-0.923833877802965000, -0.923814736966481200, -0.923795593820460170, -0.923776448364950430, -0.923757300599999720, -0.923738150525655670, -0.923718998141966230, -0.923699843448979370, +-0.923680686446742840, -0.923661527135304580, -0.923642365514712460, -0.923623201585014540, -0.923604035346258230, -0.923584866798492170, -0.923565695941763960, -0.923546522776121480, +-0.923527347301612680, -0.923508169518285630, -0.923488989426187620, -0.923469807025367630, -0.923450622315873050, -0.923431435297751960, -0.923412245971052310, -0.923393054335821970, +-0.923373860392109000, -0.923354664139961480, -0.923335465579427140, -0.923316264710553950, -0.923297061533390310, -0.923277856047984070, -0.923258648254383200, -0.923239438152635760, +-0.923220225742789610, -0.923201011024892600, -0.923181793998993470, -0.923162574665139850, -0.923143353023379690, -0.923124129073761180, -0.923104902816332400, -0.923085674251141410, +-0.923066443378236070, -0.923047210197664780, -0.923027974709475060, -0.923008736913715770, -0.922989496810434520, -0.922970254399679720, -0.922951009681499120, -0.922931762655941120, +-0.922912513323053240, -0.922893261682884550, -0.922874007735482670, -0.922854751480895690, -0.922835492919171880, -0.922816232050359340, -0.922796968874506240, -0.922777703391660760, +-0.922758435601870990, -0.922739165505185090, -0.922719893101650920, -0.922700618391317450, -0.922681341374232300, -0.922662062050443880, -0.922642780420000360, -0.922623496482949500, +-0.922604210239340250, -0.922584921689220460, -0.922565630832638320, -0.922546337669642110, -0.922527042200280150, -0.922507744424600480, -0.922488444342651540, -0.922469141954481490, +-0.922449837260138520, -0.922430530259670590, -0.922411220953126780, -0.922391909340554820, -0.922372595422003120, -0.922353279197519970, -0.922333960667153560, -0.922314639830951970, +-0.922295316688964140, -0.922275991241237940, -0.922256663487821760, -0.922237333428764020, -0.922218001064112890, -0.922198666393916680, -0.922179329418223890, -0.922159990137082830, +-0.922140648550541340, -0.922121304658648610, -0.922101958461452600, -0.922082609959001710, -0.922063259151344350, -0.922043906038528820, -0.922024550620603180, -0.922005192897616510, +-0.921985832869616770, -0.921966470536652480, -0.921947105898772050, -0.921927738956023870, -0.921908369708456350, -0.921888998156117910, -0.921869624299056940, -0.921850248137321530, +-0.921830869670960950, -0.921811488900023070, -0.921792105824556620, -0.921772720444609780, -0.921753332760231190, -0.921733942771468920, -0.921714550478372140, -0.921695155880988940, +-0.921675758979367930, -0.921656359773557420, -0.921636958263606140, -0.921617554449562390, -0.921598148331474690, -0.921578739909391760, -0.921559329183361920, -0.921539916153433340, +-0.921520500819655420, -0.921501083182076130, -0.921481663240744210, -0.921462240995708170, -0.921442816447016200, -0.921423389594717480, -0.921403960438860190, -0.921384528979493190, +-0.921365095216664760, -0.921345659150423550, -0.921326220780818270, -0.921306780107897460, -0.921287337131709630, -0.921267891852303510, -0.921248444269727180, -0.921228994384030280, +-0.921209542195260740, -0.921190087703467440, -0.921170630908698880, -0.921151171811003810, -0.921131710410430400, -0.921112246707028070, -0.921092780700845100, -0.921073312391930240, +-0.921053841780332010, -0.921034368866099240, -0.921014893649280570, -0.920995416129924640, -0.920975936308080170, -0.920956454183795570, -0.920936969757120030, -0.920917483028102170, +-0.920897993996790620, -0.920878502663234010, -0.920859009027481190, -0.920839513089580560, -0.920820014849581430, -0.920800514307532290, -0.920781011463481790, -0.920761506317478880, +-0.920741998869572090, -0.920722489119810360, -0.920702977068242450, -0.920683462714916970, -0.920663946059882670, -0.920644427103188720, -0.920624905844883660, -0.920605382285016430, +-0.920585856423635770, -0.920566328260790430, -0.920546797796528820, -0.920527265030900650, -0.920507729963954360, -0.920488192595738770, -0.920468652926302640, -0.920449110955694820, +-0.920429566683964250, -0.920410020111159800, -0.920390471237330310, -0.920370920062524630, -0.920351366586791290, -0.920331810810179900, -0.920312252732738980, -0.920292692354517490, +-0.920273129675564180, -0.920253564695927670, -0.920233997415657700, -0.920214427834802670, -0.920194855953411550, -0.920175281771533400, -0.920155705289216860, -0.920136126506511220, +-0.920116545423465220, -0.920096962040127810, -0.920077376356548070, -0.920057788372774520, -0.920038198088856780, -0.920018605504843600, -0.919999010620783930, -0.919979413436726730, +-0.919959813952720970, -0.919940212168815390, -0.919920608085059490, -0.919901001701502240, -0.919881393018192380, -0.919861782035178990, -0.919842168752511240, -0.919822553170238090, +-0.919802935288408510, -0.919783315107071560, -0.919763692626276000, -0.919744067846071540, -0.919724440766506950, -0.919704811387631270, -0.919685179709493590, -0.919665545732142880, +-0.919645909455627960, -0.919626270879998600, -0.919606630005303630, -0.919586986831592120, -0.919567341358913050, -0.919547693587315700, -0.919528043516849030, -0.919508391147562330, +-0.919488736479504580, -0.919469079512724720, -0.919449420247272390, -0.919429758683196650, -0.919410094820546480, -0.919390428659371040, -0.919370760199719530, -0.919351089441640790, +-0.919331416385184560, -0.919311741030399920, -0.919292063377335930, -0.919272383426041780, -0.919252701176566660, -0.919233016628959730, -0.919213329783270310, -0.919193640639547560, +-0.919173949197840680, -0.919154255458198620, -0.919134559420671240, -0.919114861085307490, -0.919095160452156560, -0.919075457521267740, -0.919055752292689990, -0.919036044766473160, +-0.919016334942666100, -0.918996622821318330, -0.918976908402479030, -0.918957191686197380, -0.918937472672522790, -0.918917751361504550, -0.918898027753191850, -0.918878301847634190, +-0.918858573644880330, -0.918838843144980430, -0.918819110347983470, -0.918799375253938620, -0.918779637862895400, -0.918759898174903110, -0.918740156190010590, -0.918720411908268140, +-0.918700665329724720, -0.918680916454429510, -0.918661165282432140, -0.918641411813781780, -0.918621656048527860, -0.918601897986719870, -0.918582137628407120, -0.918562374973638570, +-0.918542610022464620, -0.918522842774934010, -0.918503073231096370, -0.918483301391000980, -0.918463527254697380, -0.918443750822234620, -0.918423972093662780, -0.918404191069031040, +-0.918384407748388810, -0.918364622131785600, -0.918344834219270820, -0.918325044010893880, -0.918305251506704390, -0.918285456706751770, -0.918265659611085190, -0.918245860219754850, +-0.918226058532809700, -0.918206254550299580, -0.918186448272273690, -0.918166639698781760, -0.918146828829872860, -0.918127015665597180, -0.918107200206004110, -0.918087382451142850, +-0.918067562401063240, -0.918047740055814800, -0.918027915415446930, -0.918008088480009250, -0.917988259249551300, -0.917968427724122790, -0.917948593903772810, -0.917928757788551760, +-0.917908919378508830, -0.917889078673693510, -0.917869235674155570, -0.917849390379944170, -0.917829542791109620, -0.917809692907701200, -0.917789840729768550, -0.917769986257361390, +-0.917750129490529140, -0.917730270429321650, -0.917710409073788420, -0.917690545423979210, -0.917670679479943740, -0.917650811241731090, -0.917630940709391770, -0.917611067882975080, +-0.917591192762530760, -0.917571315348108430, -0.917551435639757940, -0.917531553637528360, -0.917511669341470330, -0.917491782751633010, -0.917471893868066380, -0.917452002690819950, +-0.917432109219943560, -0.917412213455486850, -0.917392315397499550, -0.917372415046031510, -0.917352512401132140, -0.917332607462851830, -0.917312700231239900, -0.917292790706346280, +-0.917272878888220730, -0.917252964776912980, -0.917233048372472440, -0.917213129674949610, -0.917193208684393910, -0.917173285400855300, -0.917153359824383400, -0.917133431955028170, +-0.917113501792839240, -0.917093569337866680, -0.917073634590160110, -0.917053697549769180, -0.917033758216744270, -0.917013816591135010, -0.916993872672991260, -0.916973926462362750, +-0.916953977959299450, -0.916934027163850860, -0.916914074076067620, -0.916894118695999130, -0.916874161023695340, -0.916854201059206120, -0.916834238802581410, -0.916814274253871190, +-0.916794307413125180, -0.916774338280393450, -0.916754366855725870, -0.916734393139172040, -0.916714417130782500, -0.916694438830606970, -0.916674458238695310, -0.916654475355097590, +-0.916634490179863310, -0.916614502713043120, -0.916594512954686640, -0.916574520904843930, -0.916554526563564950, -0.916534529930899570, -0.916514531006897950, -0.916494529791609950, +-0.916474526285085630, -0.916454520487374970, -0.916434512398527690, -0.916414502018594530, -0.916394489347625020, -0.916374474385669320, -0.916354457132777520, -0.916334437588999130, +-0.916314415754384990, -0.916294391628984850, -0.916274365212848770, -0.916254336506026720, -0.916234305508568880, -0.916214272220525210, -0.916194236641945880, -0.916174198772880980, +-0.916154158613380560, -0.916134116163494380, -0.916114071423273280, -0.916094024392766990, -0.916073975072025700, -0.916053923461099480, -0.916033869560038290, -0.916013813368892200, +-0.915993754887711950, -0.915973694116547280, -0.915953631055448360, -0.915933565704465380, -0.915913498063648520, -0.915893428133047860, -0.915873355912713680, -0.915853281402696060, +-0.915833204603044850, -0.915813125513811110, -0.915793044135044480, -0.915772960466795240, -0.915752874509113580, -0.915732786262049680, -0.915712695725653610, -0.915692602899976120, +-0.915672507785067040, -0.915652410380976670, -0.915632310687755410, -0.915612208705453230, -0.915592104434120650, -0.915571997873807720, -0.915551889024564860, -0.915531777886441910, +-0.915511664459489840, -0.915491548743758710, -0.915471430739298600, -0.915451310446159900, -0.915431187864393040, -0.915411062994047730, -0.915390935835175170, -0.915370806387825310, +-0.915350674652048340, -0.915330540627894760, -0.915310404315414770, -0.915290265714658880, -0.915270124825677270, -0.915249981648520340, -0.915229836183238390, -0.915209688429881600, +-0.915189538388500810, -0.915169386059146330, -0.915149231441868330, -0.915129074536717210, -0.915108915343743060, -0.915088753862997040, -0.915068590094529120, -0.915048424038389600, +-0.915028255694629200, -0.915008085063298000, -0.914987912144446750, -0.914967736938125610, -0.914947559444385110, -0.914927379663275750, -0.914907197594847620, -0.914887013239151890, +-0.914866826596238520, -0.914846637666158150, -0.914826446448961160, -0.914806252944698080, -0.914786057153418990, -0.914765859075175050, -0.914745658710016560, -0.914725456057993820, +-0.914705251119157570, -0.914685043893558090, -0.914664834381246130, -0.914644622582271970, -0.914624408496686250, -0.914604192124539140, -0.914583973465882050, -0.914563752520764830, +-0.914543529289238430, -0.914523303771353050, -0.914503075967159520, -0.914482845876707810, -0.914462613500049430, -0.914442378837234560, -0.914422141888313610, -0.914401902653337430, +-0.914381661132356420, -0.914361417325421310, -0.914341171232582630, -0.914320922853891100, -0.914300672189396810, -0.914280419239151150, -0.914260164003204530, -0.914239906481607580, +-0.914219646674410690, -0.914199384581664830, -0.914179120203420070, -0.914158853539727810, -0.914138584590638570, -0.914118313356202750, -0.914098039836471200, -0.914077764031494540, +-0.914057485941323410, -0.914037205566008650, -0.914016922905600880, -0.913996637960150740, -0.913976350729708730, -0.913956061214326150, -0.913935769414053410, -0.913915475328941240, +-0.913895178959040380, -0.913874880304401230, -0.913854579365075190, -0.913834276141112790, -0.913813970632564640, -0.913793662839481600, -0.913773352761914400, -0.913753040399913790, +-0.913732725753530590, -0.913712408822815680, -0.913692089607819560, -0.913671768108592960, -0.913651444325187300, -0.913631118257653090, -0.913610789906040940, -0.913590459270401940, +-0.913570126350786720, -0.913549791147245880, -0.913529453659830850, -0.913509113888592240, -0.913488771833580790, -0.913468427494847470, -0.913448080872443110, -0.913427731966418470, +-0.913407380776824480, -0.913387027303712130, -0.913366671547131800, -0.913346313507135240, -0.913325953183772740, -0.913305590577095480, -0.913285225687154200, -0.913264858513999860, +-0.913244489057682960, -0.913224117318255260, -0.913203743295767260, -0.913183366990269920, -0.913162988401814200, -0.913142607530450960, -0.913122224376231140, -0.913101838939205820, +-0.913081451219425850, -0.913061061216941970, -0.913040668931805800, -0.913020274364067850, -0.912999877513779310, -0.912979478380991140, -0.912959076965754180, -0.912938673268119170, +-0.912918267288137850, -0.912897859025860850, -0.912877448481339230, -0.912857035654623950, -0.912836620545766090, -0.912816203154816710, -0.912795783481826770, -0.912775361526847460, +-0.912754937289929620, -0.912734510771124220, -0.912714081970482760, -0.912693650888056210, -0.912673217523895520, -0.912652781878051770, -0.912632343950575690, -0.912611903741519130, +-0.912591461250932710, -0.912571016478867740, -0.912550569425375270, -0.912530120090506270, -0.912509668474312030, -0.912489214576843620, -0.912468758398152110, -0.912448299938288800, +-0.912427839197304300, -0.912407376175250700, -0.912386910872178490, -0.912366443288139100, -0.912345973423183580, -0.912325501277363120, -0.912305026850728560, -0.912284550143331760, +-0.912264071155223570, -0.912243589886455260, -0.912223106337078040, -0.912202620507142960, -0.912182132396701320, -0.912161642005804410, -0.912141149334503300, -0.912120654382849060, +-0.912100157150893430, -0.912079657638687480, -0.912059155846282390, -0.912038651773729450, -0.912018145421079840, -0.911997636788384410, -0.911977125875695350, -0.911956612683063490, +-0.911936097210540030, -0.911915579458176470, -0.911895059426023780, -0.911874537114133580, -0.911854012522556930, -0.911833485651345370, -0.911812956500549610, -0.911792425070221960, +-0.911771891360413140, -0.911751355371174580, -0.911730817102557660, -0.911710276554613670, -0.911689733727393700, -0.911669188620949700, -0.911648641235332850, -0.911628091570594210, +-0.911607539626785420, -0.911586985403957770, -0.911566428902162770, -0.911545870121451610, -0.911525309061875790, -0.911504745723486610, -0.911484180106335250, -0.911463612210473890, +-0.911443042035953390, -0.911422469582825360, -0.911401894851141090, -0.911381317840951780, -0.911360738552309590, -0.911340156985265380, -0.911319573139870890, -0.911298987016177510, +-0.911278398614236540, -0.911257807934099720, -0.911237214975818330, -0.911216619739443790, -0.911196022225027820, -0.911175422432621400, -0.911154820362276800, -0.911134216014045210, +-0.911113609387977920, -0.911093000484126670, -0.911072389302542970, -0.911051775843277900, -0.911031160106383740, -0.911010542091911790, -0.910989921799913340, -0.910969299230440120, +-0.910948674383543770, -0.910928047259275560, -0.910907417857687360, -0.910886786178830570, -0.910866152222756460, -0.910845515989517350, -0.910824877479164410, -0.910804236691749260, +-0.910783593627323530, -0.910762948285938840, -0.910742300667646390, -0.910721650772498670, -0.910700998600546650, -0.910680344151842290, -0.910659687426436990, -0.910639028424382380, +-0.910618367145730300, -0.910597703590532380, -0.910577037758840020, -0.910556369650704860, -0.910535699266179050, -0.910515026605314030, -0.910494351668161510, -0.910473674454773010, +-0.910452994965200380, -0.910432313199494800, -0.910411629157708900, -0.910390942839893860, -0.910370254246101520, -0.910349563376383510, -0.910328870230791680, -0.910308174809377530, +-0.910287477112193040, -0.910266777139289830, -0.910246074890719740, -0.910225370366534060, -0.910204663566785310, -0.910183954491524890, -0.910163243140804550, -0.910142529514676110, +-0.910121813613191000, -0.910101095436401720, -0.910080374984359790, -0.910059652257116820, -0.910038927254724790, -0.910018199977235430, -0.909997470424700470, -0.909976738597171870, +-0.909956004494701490, -0.909935268117341050, -0.909914529465142170, -0.909893788538157170, -0.909873045336437870, -0.909852299860035800, -0.909831552109003130, -0.909810802083391490, +-0.909790049783252510, -0.909769295208638700, -0.909748538359601680, -0.909727779236193410, -0.909707017838465640, -0.909686254166470310, -0.909665488220259280, -0.909644719999884610, +-0.909623949505398150, -0.909603176736851430, -0.909582401694297160, -0.909561624377786760, -0.909540844787372400, -0.909520062923105940, -0.909499278785039330, -0.909478492373224200, +-0.909457703687713060, -0.909436912728557760, -0.909416119495810140, -0.909395323989522280, -0.909374526209746130, -0.909353726156533540, -0.909332923829936690, -0.909312119230007540, +-0.909291312356797720, -0.909270503210360070, -0.909249691790746110, -0.909228878098007900, -0.909208062132197400, -0.909187243893366910, -0.909166423381567830, -0.909145600596853120, +-0.909124775539274400, -0.909103948208883740, -0.909083118605733210, -0.909062286729874880, -0.909041452581360820, -0.909020616160243100, -0.908999777466573900, -0.908978936500405290, +-0.908958093261788890, -0.908937247750777670, -0.908916399967423350, -0.908895549911777900, -0.908874697583893720, -0.908853842983822440, -0.908832986111616780, -0.908812126967328720, +-0.908791265551010420, -0.908770401862713850, -0.908749535902491300, -0.908728667670394950, -0.908707797166476980, -0.908686924390789460, -0.908666049343384570, -0.908645172024314270, +-0.908624292433631300, -0.908603410571387720, -0.908582526437635600, -0.908561640032427120, -0.908540751355814580, -0.908519860407849710, -0.908498967188585690, -0.908478071698074150, +-0.908457173936367490, -0.908436273903517890, -0.908415371599577530, -0.908394467024598810, -0.908373560178633910, -0.908352651061735130, -0.908331739673954310, -0.908310826015344520, +-0.908289910085957720, -0.908268991885846090, -0.908248071415061920, -0.908227148673657720, -0.908206223661685130, -0.908185296379197430, -0.908164366826246460, -0.908143435002884640, +-0.908122500909164240, -0.908101564545137460, -0.908080625910856920, -0.908059685006374680, -0.908038741831743380, -0.908017796387014740, -0.907996848672241950, -0.907975898687477190, +-0.907954946432772530, -0.907933991908180580, -0.907913035113753650, -0.907892076049543690, -0.907871114715604000, -0.907850151111986530, -0.907829185238743560, -0.907808217095927740, +-0.907787246683591340, -0.907766274001786890, -0.907745299050566670, -0.907724321829983190, -0.907703342340088980, -0.907682360580935990, -0.907661376552577500, -0.907640390255065600, +-0.907619401688452680, -0.907598410852791250, -0.907577417748133390, -0.907556422374532490, -0.907535424732040410, -0.907514424820709760, -0.907493422640593180, -0.907472418191742960, +-0.907451411474211600, -0.907430402488051850, -0.907409391233316100, -0.907388377710056760, -0.907367361918326120, -0.907346343858177580, -0.907325323529663110, -0.907304300932835210, +-0.907283276067746720, -0.907262248934449960, -0.907241219532997300, -0.907220187863441830, -0.907199153925835940, -0.907178117720232160, -0.907157079246683210, -0.907136038505241380, +-0.907114995495959530, -0.907093950218890170, -0.907072902674086020, -0.907051852861599170, -0.907030800781483020, -0.907009746433789950, -0.906988689818572500, -0.906967630935883280, +-0.906946569785775040, -0.906925506368299940, -0.906904440683511500, -0.906883372731461910, -0.906862302512204010, -0.906841230025790200, -0.906820155272273440, -0.906799078251706250, +-0.906777998964141350, -0.906756917409631380, -0.906735833588228850, -0.906714747499987040, -0.906693659144958470, -0.906672568523195670, -0.906651475634751460, -0.906630380479678480, +-0.906609283058029240, -0.906588183369857250, -0.906567081415214690, -0.906545977194154530, -0.906524870706729380, -0.906503761952991980, -0.906482650932995290, -0.906461537646791830, +-0.906440422094434650, -0.906419304275976390, -0.906398184191469450, -0.906377061840967560, -0.906355937224522900, -0.906334810342188430, -0.906313681194016900, -0.906292549780060800, +-0.906271416100373650, -0.906250280155008080, -0.906229141944016710, -0.906208001467452510, -0.906186858725368420, -0.906165713717817070, -0.906144566444851420, -0.906123416906524430, +-0.906102265102888830, -0.906081111033997240, -0.906059954699903190, -0.906038796100659290, -0.906017635236318400, -0.905996472106933460, -0.905975306712557330, -0.905954139053242510, +-0.905932969129042750, -0.905911796940010560, -0.905890622486198890, -0.905869445767660600, -0.905848266784448740, -0.905827085536616280, -0.905805902024216070, -0.905784716247301060, +-0.905763528205923870, -0.905742337900138250, -0.905721145329996810, -0.905699950495552520, -0.905678753396858330, -0.905657554033967300, -0.905636352406931970, -0.905615148515806160, +-0.905593942360642390, -0.905572733941493850, -0.905551523258413480, -0.905530310311454260, -0.905509095100669350, -0.905487877626111600, -0.905466657887834200, -0.905445435885889770, +-0.905424211620332150, -0.905402985091213970, -0.905381756298588410, -0.905360525242508320, -0.905339291923027090, -0.905318056340197130, -0.905296818494072400, -0.905275578384705630, +-0.905254336012150000, -0.905233091376458470, -0.905211844477684210, -0.905190595315880310, -0.905169343891099930, -0.905148090203396260, -0.905126834252822250, -0.905105576039430870, +-0.905084315563275950, -0.905063052824410130, -0.905041787822886800, -0.905020520558758920, -0.904999251032079450, -0.904977979242902130, -0.904956705191279910, -0.904935428877265860, +-0.904914150300913380, -0.904892869462275430, -0.904871586361405300, -0.904850300998356170, -0.904829013373181330, -0.904807723485933970, -0.904786431336666920, -0.904765136925434250, +-0.904743840252288600, -0.904722541317283470, -0.904701240120471930, -0.904679936661906830, -0.904658630941642340, -0.904637322959731320, -0.904616012716226940, -0.904594700211182600, +-0.904573385444651380, -0.904552068416686780, -0.904530749127341990, -0.904509427576670300, -0.904488103764725100, -0.904466777691559250, -0.904445449357226820, -0.904424118761780750, +-0.904402785905274450, -0.904381450787761110, -0.904360113409294230, -0.904338773769926550, -0.904317431869712470, -0.904296087708704730, -0.904274741286956730, -0.904253392604521980, +-0.904232041661453660, -0.904210688457805280, -0.904189332993630130, -0.904167975268981740, -0.904146615283912940, -0.904125253038478020, -0.904103888532729940, -0.904082521766722210, +-0.904061152740508130, -0.904039781454141210, -0.904018407907674400, -0.903997032101162000, -0.903975654034656960, -0.903954273708212800, -0.903932891121883020, -0.903911506275720920, +-0.903890119169780130, -0.903868729804114030, -0.903847338178776050, -0.903825944293819790, -0.903804548149298230, -0.903783149745265750, -0.903761749081775310, -0.903740346158880550, +-0.903718940976634970, -0.903697533535091630, -0.903676123834304730, -0.903654711874327670, -0.903633297655213720, -0.903611881177016630, -0.903590462439789800, -0.903569041443586740, +-0.903547618188461190, -0.903526192674466540, -0.903504764901656430, -0.903483334870083920, -0.903461902579803520, -0.903440468030868420, -0.903419031223332110, -0.903397592157248240, +-0.903376150832669980, -0.903354707249651720, -0.903333261408246770, -0.903311813308508630, -0.903290362950490920, -0.903268910334247280, -0.903247455459831430, -0.903225998327296890, +-0.903204538936697390, -0.903183077288086560, -0.903161613381517570, -0.903140147217045050, -0.903118678794722070, -0.903097208114602480, -0.903075735176739780, -0.903054259981187820, +-0.903032782527999680, -0.903011302817230080, -0.902989820848932200, -0.902968336623159900, -0.902946850139966560, -0.902925361399406160, -0.902903870401532420, -0.902882377146398960, +-0.902860881634059530, -0.902839383864567520, -0.902817883837977450, -0.902796381554342720, -0.902774877013716950, -0.902753370216154090, -0.902731861161707670, -0.902710349850431300, +-0.902688836282379500, -0.902667320457605560, -0.902645802376163210, -0.902624282038106520, -0.902602759443489000, -0.902581234592364610, -0.902559707484787200, -0.902538178120810500, +-0.902516646500487910, -0.902495112623874050, -0.902473576491022560, -0.902452038101987040, -0.902430497456821470, -0.902408954555579570, -0.902387409398314970, -0.902365861985082170, +-0.902344312315934820, -0.902322760390926630, -0.902301206210111560, -0.902279649773543470, -0.902258091081276190, -0.902236530133363690, -0.902214966929859920, -0.902193401470818720, +-0.902171833756293620, -0.902150263786339330, -0.902128691561009390, -0.902107117080357730, -0.902085540344438330, -0.902063961353304580, -0.902042380107011430, -0.902020796605612190, +-0.901999210849161010, -0.901977622837711880, -0.901956032571318620, -0.901934440050035310, -0.901912845273915910, -0.901891248243014370, -0.901869648957384640, -0.901848047417080580, +-0.901826443622156580, -0.901804837572666610, -0.901783229268664500, -0.901761618710204330, -0.901740005897340160, -0.901718390830125500, -0.901696773508615320, -0.901675153932863130, +-0.901653532102923090, -0.901631908018849290, -0.901610281680695680, -0.901588653088516320, -0.901567022242365400, -0.901545389142296870, -0.901523753788364470, -0.901502116180623150, +-0.901480476319126420, -0.901458834203928580, -0.901437189835083700, -0.901415543212645720, -0.901393894336668610, -0.901372243207207100, -0.901350589824314930, -0.901328934188046380, +-0.901307276298455420, -0.901285616155596330, -0.901263953759523170, -0.901242289110290140, -0.901220622207951410, -0.901198953052560700, -0.901177281644172990, -0.901155607982842110, +-0.901133932068622250, -0.901112253901567460, -0.901090573481732050, -0.901068890809169850, -0.901047205883935830, -0.901025518706083720, -0.901003829275667910, -0.900982137592742480, +-0.900960443657361720, -0.900938747469579800, -0.900917049029451130, -0.900895348337029780, -0.900873645392370030, -0.900851940195525720, -0.900830232746552050, -0.900808523045502740, +-0.900786811092432190, -0.900765096887394590, -0.900743380430443770, -0.900721661721635040, -0.900699940761022110, -0.900678217548659290, -0.900656492084600860, -0.900634764368901330, +-0.900613034401614780, -0.900591302182795710, -0.900569567712498410, -0.900547830990777070, -0.900526092017685850, -0.900504350793279840, -0.900482607317612870, -0.900460861590739460, +-0.900439113612713780, -0.900417363383590460, -0.900395610903423240, -0.900373856172267390, -0.900352099190176890, -0.900330339957206240, -0.900308578473409620, -0.900286814738841650, +-0.900265048753556620, -0.900243280517608930, -0.900221510031053000, -0.900199737293942980, -0.900177962306334070, -0.900156185068280100, -0.900134405579835820, -0.900112623841055390, +-0.900090839851993450, -0.900069053612704060, -0.900047265123242400, -0.900025474383662540, -0.900003681394019090, -0.899981886154366360, -0.899960088664758960, -0.899938288925251300, +-0.899916486935897870, -0.899894682696753320, -0.899872876207871600, -0.899851067469308210, -0.899829256481117000, -0.899807443243352710, -0.899785627756069850, -0.899763810019322820, +-0.899741990033166020, -0.899720167797654510, -0.899698343312842600, -0.899676516578784890, -0.899654687595535800, -0.899632856363150050, -0.899611022881682150, -0.899589187151186740, +-0.899567349171718320, -0.899545508943331520, -0.899523666466080620, -0.899501821740020800, -0.899479974765206580, -0.899458125541692350, -0.899436274069532750, -0.899414420348782160, +-0.899392564379495880, -0.899370706161728210, -0.899348845695533860, -0.899326982980967250, -0.899305118018083220, -0.899283250806936390, -0.899261381347581490, -0.899239509640073150, +-0.899217635684465890, -0.899195759480814320, -0.899173881029173620, -0.899152000329598300, -0.899130117382142990, -0.899108232186862310, -0.899086344743811110, -0.899064455053043550, +-0.899042563114615390, -0.899020668928580790, -0.898998772494994490, -0.898976873813911230, -0.898954972885385840, -0.898933069709472950, -0.898911164286227420, -0.898889256615703960, +-0.898867346697957090, -0.898845434533042110, -0.898823520121013520, -0.898801603461926280, -0.898779684555834900, -0.898757763402794340, -0.898735840002859000, -0.898713914356084500, +-0.898691986462525130, -0.898670056322235840, -0.898648123935271380, -0.898626189301686700, -0.898604252421536410, -0.898582313294875590, -0.898560371921758970, -0.898538428302240950, +-0.898516482436377270, -0.898494534324222440, -0.898472583965831300, -0.898450631361258690, -0.898428676510559470, -0.898406719413788140, -0.898384760071000430, -0.898362798482250870, +-0.898340834647594180, -0.898318868567085540, -0.898296900240779680, -0.898274929668731570, -0.898252956850996150, -0.898230981787628280, -0.898209004478683020, -0.898187024924214870, +-0.898165043124279470, -0.898143059078931550, -0.898121072788225950, -0.898099084252217630, -0.898077093470961320, -0.898055100444512530, -0.898033105172926120, -0.898011107656256800, +-0.897989107894559770, -0.897967105887890080, -0.897945101636302480, -0.897923095139852250, -0.897901086398594120, -0.897879075412583380, -0.897857062181874550, -0.897835046706523480, +-0.897813028986584770, -0.897791009022113510, -0.897768986813164640, -0.897746962359793450, -0.897724935662054360, -0.897702906720003300, -0.897680875533695020, -0.897658842103184580, +-0.897636806428526950, -0.897614768509777390, -0.897592728346990890, -0.897570685940222600, -0.897548641289527490, -0.897526594394960520, -0.897504545256577300, -0.897482493874432800, +-0.897460440248582070, -0.897438384379080300, -0.897416326265982440, -0.897394265909343460, -0.897372203309219190, -0.897350138465664470, -0.897328071378734270, -0.897306002048483990, +-0.897283930474968680, -0.897261856658243540, -0.897239780598363850, -0.897217702295384560, -0.897195621749360740, -0.897173538960348130, -0.897151453928401790, -0.897129366653576790, +-0.897107277135928300, -0.897085185375511740, -0.897063091372381720, -0.897040995126594410, -0.897018896638204670, -0.896996795907267550, -0.896974692933838580, -0.896952587717972820, +-0.896930480259725550, -0.896908370559152070, -0.896886258616307770, -0.896864144431247730, -0.896842028004027010, -0.896819909334701570, -0.896797788423326360, -0.896775665269956670, +-0.896753539874647790, -0.896731412237454670, -0.896709282358433500, -0.896687150237639120, -0.896665015875126810, -0.896642879270951880, -0.896620740425169930, -0.896598599337836030, +-0.896576456009005600, -0.896554310438734130, -0.896532162627076800, -0.896510012574088690, -0.896487860279825970, -0.896465705744343590, -0.896443548967696850, -0.896421389949941360, +-0.896399228691132420, -0.896377065191324870, -0.896354899450575230, -0.896332731468938220, -0.896310561246469350, -0.896288388783224140, -0.896266214079257990, -0.896244037134626300, +-0.896221857949384470, -0.896199676523588010, -0.896177492857291980, -0.896155306950552570, -0.896133118803424940, -0.896110928415964510, -0.896088735788226680, -0.896066540920267160, +-0.896044343812140820, -0.896022144463903940, -0.895999942875611800, -0.895977739047319810, -0.895955532979083370, -0.895933324670958210, -0.895911114122999620, -0.895888901335263330, +-0.895866686307804750, -0.895844469040679160, -0.895822249533942740, -0.895800027787650550, -0.895777803801858450, -0.895755577576621830, -0.895733349111996200, -0.895711118408036850, +-0.895688885464800080, -0.895666650282341160, -0.895644412860715500, -0.895622173199978940, -0.895599931300186890, -0.895577687161394960, -0.895555440783658900, -0.895533192167034200, +-0.895510941311576490, -0.895488688217341070, -0.895466432884384320, -0.895444175312761440, -0.895421915502528140, -0.895399653453740060, -0.895377389166452490, -0.895355122640721810, +-0.895332853876603330, -0.895310582874152770, -0.895288309633425650, -0.895266034154477810, -0.895243756437364870, -0.895221476482142560, -0.895199194288866520, -0.895176909857592570, +-0.895154623188375910, -0.895132334281273030, -0.895110043136339350, -0.895087749753630590, -0.895065454133202490, -0.895043156275110660, -0.895020856179410630, -0.894998553846158780, +-0.894976249275410640, -0.894953942467221820, -0.894931633421648160, -0.894909322138745410, -0.894887008618569290, -0.894864692861175760, -0.894842374866620440, -0.894820054634958840, +-0.894797732166247360, -0.894775407460541740, -0.894753080517897480, -0.894730751338370540, -0.894708419922016770, -0.894686086268891460, -0.894663750379051440, -0.894641412252551890, +-0.894619071889449000, -0.894596729289798280, -0.894574384453655780, -0.894552037381077360, -0.894529688072118860, -0.894507336526836120, -0.894484982745284540, -0.894462626727520970, +-0.894440268473600920, -0.894417907983580120, -0.894395545257514520, -0.894373180295460090, -0.894350813097472330, -0.894328443663607970, -0.894306071993922420, -0.894283698088471750, +-0.894261321947311780, -0.894238943570498600, -0.894216562958087930, -0.894194180110135960, -0.894171795026698520, -0.894149407707831580, -0.894127018153590640, -0.894104626364032650, +-0.894082232339213020, -0.894059836079187930, -0.894037437584013220, -0.894015036853744390, -0.893992633888438530, -0.893970228688151010, -0.893947821252937920, -0.893925411582855320, +-0.893902999677959050, -0.893880585538305410, -0.893858169163950330, -0.893835750554949790, -0.893813329711359850, -0.893790906633236130, -0.893768481320635690, -0.893746053773613940, +-0.893723623992227050, -0.893701191976531200, -0.893678757726582340, -0.893656321242436100, -0.893633882524149550, -0.893611441571778190, -0.893588998385378310, -0.893566552965005870, +-0.893544105310717150, -0.893521655422568120, -0.893499203300614940, -0.893476748944913690, -0.893454292355520320, -0.893431833532491450, -0.893409372475883150, -0.893386909185751370, +-0.893364443662152290, -0.893341975905142080, -0.893319505914776490, -0.893297033691112690, -0.893274559234206180, -0.893252082544113370, -0.893229603620890210, -0.893207122464593220, +-0.893184639075278230, -0.893162153453001760, -0.893139665597819880, -0.893117175509788530, -0.893094683188964570, -0.893072188635403830, -0.893049691849162720, -0.893027192830297300, +-0.893004691578863970, -0.892982188094918470, -0.892959682378517860, -0.892937174429718090, -0.892914664248575460, -0.892892151835146030, -0.892869637189486310, -0.892847120311652480, +-0.892824601201700930, -0.892802079859687740, -0.892779556285669410, -0.892757030479701790, -0.892734502441842050, -0.892711972172145930, -0.892689439670669940, -0.892666904937470360, +-0.892644367972603160, -0.892621828776125390, -0.892599287348093020, -0.892576743688562440, -0.892554197797590040, -0.892531649675232130, -0.892509099321545100, -0.892486546736585340, +-0.892463991920409260, -0.892441434873073040, -0.892418875594632950, -0.892396314085146080, -0.892373750344668370, -0.892351184373256330, -0.892328616170966260, -0.892306045737854770, +-0.892283473073977710, -0.892260898179392360, -0.892238321054154680, -0.892215741698321300, -0.892193160111948600, -0.892170576295092890, -0.892147990247810770, -0.892125401970158770, +-0.892102811462193170, -0.892080218723970140, -0.892057623755546980, -0.892035026556979750, -0.892012427128325070, -0.891989825469639230, -0.891967221580978740, -0.891944615462399890, +-0.891922007113959970, -0.891899396535714930, -0.891876783727721390, -0.891854168690035980, -0.891831551422715090, -0.891808931925815230, -0.891786310199393140, -0.891763686243505330, +-0.891741060058207860, -0.891718431643558130, -0.891695800999612320, -0.891673168126426940, -0.891650533024058720, -0.891627895692564180, -0.891605256131999480, -0.891582614342422030, +-0.891559970323888010, -0.891537324076454140, -0.891514675600176940, -0.891492024895113030, -0.891469371961319030, -0.891446716798851680, -0.891424059407767480, -0.891401399788123160, +-0.891378737939974910, -0.891356073863380230, -0.891333407558395410, -0.891310739025076960, -0.891288068263481730, -0.891265395273665990, -0.891242720055687050, -0.891220042609601410, +-0.891197362935465590, -0.891174681033336410, -0.891151996903270520, -0.891129310545324630, -0.891106621959555480, -0.891083931146019690, -0.891061238104774110, -0.891038542835875140, +-0.891015845339380160, -0.890993145615345480, -0.890970443663828050, -0.890947739484884480, -0.890925033078571070, -0.890902324444945550, -0.890879613584064200, -0.890856900495983870, +-0.890834185180761300, -0.890811467638453200, -0.890788747869116440, -0.890766025872807840, -0.890743301649584150, -0.890720575199502210, -0.890697846522618520, -0.890675115618990490, +-0.890652382488674730, -0.890629647131727990, -0.890606909548207200, -0.890584169738169010, -0.890561427701670130, -0.890538683438767960, -0.890515936949519140, -0.890493188233980490, +-0.890470437292208870, -0.890447684124261120, -0.890424928730194190, -0.890402171110064920, -0.890379411263930280, -0.890356649191846650, -0.890333884893871890, -0.890311118370062270, +-0.890288349620474980, -0.890265578645166760, -0.890242805444194540, -0.890220030017614960, -0.890197252365485750, -0.890174472487863410, -0.890151690384804790, -0.890128906056367080, +-0.890106119502606980, -0.890083330723581590, -0.890060539719347950, -0.890037746489962920, -0.890014951035483120, -0.889992153355966380, -0.889969353451469210, -0.889946551322048700, +-0.889923746967761780, -0.889900940388665520, -0.889878131584816430, -0.889855320556272590, -0.889832507303090270, -0.889809691825326770, -0.889786874123039030, -0.889764054196284020, +-0.889741232045119010, -0.889718407669600860, -0.889695581069786630, -0.889672752245733500, -0.889649921197498080, -0.889627087925138340, -0.889604252428710770, -0.889581414708272680, +-0.889558574763881000, -0.889535732595592380, -0.889512888203464970, -0.889490041587555290, -0.889467192747920520, -0.889444341684617720, -0.889421488397704070, -0.889398632887236750, +-0.889375775153272820, -0.889352915195869560, -0.889330053015083830, -0.889307188610972690, -0.889284321983593970, -0.889261453133004420, -0.889238582059261210, -0.889215708762421510, +-0.889192833242542610, -0.889169955499681250, -0.889147075533895380, -0.889124193345241840, -0.889101308933777700, -0.889078422299560360, -0.889055533442647090, -0.889032642363094870, +-0.889009749060960970, -0.888986853536302800, -0.888963955789177080, -0.888941055819641890, -0.888918153627754060, -0.888895249213570770, -0.888872342577149420, -0.888849433718547190, +-0.888826522637821030, -0.888803609335028890, -0.888780693810227730, -0.888757776063474950, -0.888734856094827610, -0.888711933904343110, -0.888689009492078850, -0.888666082858092120, +-0.888643154002440090, -0.888620222925179730, -0.888597289626369300, -0.888574354106065670, -0.888551416364326110, -0.888528476401208020, -0.888505534216768700, -0.888482589811065200, +-0.888459643184155600, -0.888436694336096840, -0.888413743266946440, -0.888390789976761690, -0.888367834465599860, -0.888344876733518580, -0.888321916780575040, -0.888298954606826620, +-0.888275990212330950, -0.888253023597144860, -0.888230054761326550, -0.888207083704933180, -0.888184110428022030, -0.888161134930650630, -0.888138157212876030, -0.888115177274756420, +-0.888092195116348960, -0.888069210737710830, -0.888046224138899780, -0.888023235319973180, -0.888000244280988450, -0.887977251022003090, -0.887954255543074720, -0.887931257844260640, +-0.887908257925618010, -0.887885255787205120, -0.887862251429079040, -0.887839244851297390, -0.887816236053917680, -0.887793225036997310, -0.887770211800593460, -0.887747196344764620, +-0.887724178669567650, -0.887701158775060280, -0.887678136661300020, -0.887655112328344380, -0.887632085776250970, -0.887609057005077420, -0.887586026014881120, -0.887562992805719380, +-0.887539957377650680, -0.887516919730731990, -0.887493879865020930, -0.887470837780575230, -0.887447793477452510, -0.887424746955709830, -0.887401698215405710, -0.887378647256597320, +-0.887355594079342280, -0.887332538683698320, -0.887309481069723070, -0.887286421237474030, -0.887263359187008940, -0.887240294918385410, -0.887217228431660840, -0.887194159726893530, +-0.887171088804140860, -0.887148015663460470, -0.887124940304910070, -0.887101862728547190, -0.887078782934429320, -0.887055700922614990, -0.887032616693161360, -0.887009530246126050, +-0.886986441581567140, -0.886963350699542020, -0.886940257600108420, -0.886917162283324290, -0.886894064749247260, -0.886870964997935050, -0.886847863029444960, -0.886824758843835710, +-0.886801652441164600, -0.886778543821489240, -0.886755432984867590, -0.886732319931356930, -0.886709204661015880, -0.886686087173901850, -0.886662967470072560, -0.886639845549585860, +-0.886616721412499480, -0.886593595058871360, -0.886570466488759260, -0.886547335702221000, -0.886524202699314420, -0.886501067480096940, -0.886477930044627160, -0.886454790392962490, +-0.886431648525160990, -0.886408504441280280, -0.886385358141378310, -0.886362209625512490, -0.886339058893741650, -0.886315905946123080, -0.886292750782714860, -0.886269593403574700, +-0.886246433808760560, -0.886223271998330290, -0.886200107972341830, -0.886176941730853150, -0.886153773273921750, -0.886130602601606250, -0.886107429713964280, -0.886084254611053780, +-0.886061077292932600, -0.886037897759658690, -0.886014716011289670, -0.885991532047884170, -0.885968345869500020, -0.885945157476194840, -0.885921966868026930, -0.885898774045054020, +-0.885875579007334160, -0.885852381754925310, -0.885829182287885540, -0.885805980606272470, -0.885782776710144830, -0.885759570599560230, -0.885736362274576640, -0.885713151735252220, +-0.885689938981644940, -0.885666724013812300, -0.885643506831813370, -0.885620287435705640, -0.885597065825547200, -0.885573842001396110, -0.885550615963310420, -0.885527387711348090, +-0.885504157245567410, -0.885480924566026230, -0.885457689672782820, -0.885434452565894810, -0.885411213245420940, -0.885387971711419140, -0.885364727963947380, -0.885341482003063840, +-0.885318233828826130, -0.885294983441293310, -0.885271730840523020, -0.885248476026573310, -0.885225218999502570, -0.885201959759368660, -0.885178698306229860, -0.885155434640144350, +-0.885132168761170290, -0.885108900669365760, -0.885085630364788490, -0.885062357847497650, -0.885039083117550970, -0.885015806175006410, -0.884992527019922480, -0.884969245652357240, +-0.884945962072368420, -0.884922676280015090, -0.884899388275355080, -0.884876098058446580, -0.884852805629347870, -0.884829510988117240, -0.884806214134812640, -0.884782915069492690, +-0.884759613792215350, -0.884736310303038560, -0.884713004602021400, -0.884689696689221820, -0.884666386564697870, -0.884643074228508080, -0.884619759680710490, -0.884596442921363190, +-0.884573123950525120, -0.884549802768254230, -0.884526479374608930, -0.884503153769647280, -0.884479825953427890, -0.884456495926008830, -0.884433163687448620, -0.884409829237805530, +-0.884386492577137310, -0.884363153705503340, -0.884339812622961570, -0.884316469329570200, -0.884293123825387610, -0.884269776110472310, -0.884246426184882030, -0.884223074048676170, +-0.884199719701912690, -0.884176363144649870, -0.884153004376946110, -0.884129643398859800, -0.884106280210449460, -0.884082914811773370, -0.884059547202890040, -0.884036177383857760, +-0.884012805354734700, -0.883989431115580040, -0.883966054666451840, -0.883942676007408390, -0.883919295138508310, -0.883895912059809550, -0.883872526771371510, -0.883849139273252040, +-0.883825749565509860, -0.883802357648203140, -0.883778963521390630, -0.883755567185130710, -0.883732168639481900, -0.883708767884502590, -0.883685364920251400, -0.883661959746786410, +-0.883638552364166880, -0.883615142772451010, -0.883591730971697190, -0.883568316961964140, -0.883544900743310270, -0.883521482315793750, -0.883498061679473980, -0.883474638834409020, +-0.883451213780657390, -0.883427786518277800, -0.883404357047328780, -0.883380925367868720, -0.883357491479956460, -0.883334055383650510, -0.883310617079008930, -0.883287176566091240, +-0.883263733844955600, -0.883240288915660640, -0.883216841778264980, -0.883193392432827240, -0.883169940879405480, -0.883146487118059430, -0.883123031148847050, -0.883099572971827170, +-0.883076112587058320, -0.883052649994599200, -0.883029185194508460, -0.883005718186844700, -0.882982248971666770, -0.882958777549032740, -0.882935303919002100, -0.882911828081633270, +-0.882888350036984850, -0.882864869785115580, -0.882841387326084190, -0.882817902659948860, -0.882794415786769200, -0.882770926706603400, -0.882747435419510400, -0.882723941925548820, +-0.882700446224777390, -0.882676948317254740, -0.882653448203039810, -0.882629945882191240, -0.882606441354767730, -0.882582934620827820, -0.882559425680430890, -0.882535914533635450, +-0.882512401180500230, -0.882488885621084070, -0.882465367855445160, -0.882441847883643330, -0.882418325705736860, -0.882394801321784490, -0.882371274731845180, -0.882347745935977760, +-0.882324214934240850, -0.882300681726693510, -0.882277146313394380, -0.882253608694402500, -0.882230068869776060, -0.882206526839574900, -0.882182982603857410, -0.882159436162682550, +-0.882135887516109050, -0.882112336664195750, -0.882088783607001270, -0.882065228344585230, -0.882041670877006130, -0.882018111204322830, -0.881994549326594270, -0.881970985243879400, +-0.881947418956236960, -0.881923850463726010, -0.881900279766405500, -0.881876706864333840, -0.881853131757570740, -0.881829554446174950, -0.881805974930205180, -0.881782393209720520, +-0.881758809284779900, -0.881735223155441730, -0.881711634821765950, -0.881688044283811200, -0.881664451541636200, -0.881640856595300230, -0.881617259444861910, -0.881593660090380650, +-0.881570058531915060, -0.881546454769524420, -0.881522848803267260, -0.881499240633203280, -0.881475630259391350, -0.881452017681890190, -0.881428402900759080, -0.881404785916056980, +-0.881381166727842390, -0.881357545336175390, -0.881333921741114580, -0.881310295942718810, -0.881286667941047370, -0.881263037736159330, -0.881239405328113620, -0.881215770716969440, +-0.881192133902785830, -0.881168494885621880, -0.881144853665536190, -0.881121210242588940, -0.881097564616838520, -0.881073916788344240, -0.881050266757165250, -0.881026614523360060, +-0.881002960086988860, -0.880979303448110150, -0.880955644606783220, -0.880931983563067230, -0.880908320317021150, -0.880884654868704380, -0.880860987218175960, -0.880837317365495090, +-0.880813645310720930, -0.880789971053912210, -0.880766294595129010, -0.880742615934430040, -0.880718935071874490, -0.880695252007521630, -0.880671566741430660, -0.880647879273660390, +-0.880624189604270800, -0.880600497733320720, -0.880576803660869430, -0.880553107386976120, -0.880529408911700060, -0.880505708235100440, -0.880482005357236530, -0.880458300278167740, +-0.880434592997952680, -0.880410883516651530, -0.880387171834323250, -0.880363457951027000, -0.880339741866822070, -0.880316023581767860, -0.880292303095923100, -0.880268580409347970, +-0.880244855522101520, -0.880221128434242830, -0.880197399145831390, -0.880173667656926400, -0.880149933967587230, -0.880126198077873290, -0.880102459987843750, -0.880078719697557800, +-0.880054977207075370, -0.880031232516455430, -0.880007485625757590, -0.879983736535040920, -0.879959985244364920, -0.879936231753788540, -0.879912476063371970, -0.879888718173174270, +-0.879864958083254710, -0.879841195793672810, -0.879817431304487860, -0.879793664615759360, -0.879769895727546710, -0.879746124639909420, -0.879722351352906660, -0.879698575866597720, +-0.879674798181042660, -0.879651018296300660, -0.879627236212431110, -0.879603451929493520, -0.879579665447546730, -0.879555876766651370, -0.879532085886866270, -0.879508292808250820, +-0.879484497530864770, -0.879460700054767510, -0.879436900380018430, -0.879413098506677150, -0.879389294434803070, -0.879365488164455700, -0.879341679695694320, -0.879317869028579110, +-0.879294056163169140, -0.879270241099524120, -0.879246423837703570, -0.879222604377766780, -0.879198782719773250, -0.879174958863783050, -0.879151132809855460, -0.879127304558050100, +-0.879103474108426490, -0.879079641461044110, -0.879055806615962720, -0.879031969573241700, -0.879008130332940900, -0.878984288895119260, -0.878960445259837300, -0.878936599427154300, +-0.878912751397129770, -0.878888901169823320, -0.878865048745294700, -0.878841194123602950, -0.878817337304808710, -0.878793478288971140, -0.878769617076149760, -0.878745753666404510, +-0.878721888059794680, -0.878698020256380220, -0.878674150256220750, -0.878650278059375900, -0.878626403665904940, -0.878602527075868280, -0.878578648289325410, -0.878554767306335860, +-0.878530884126959450, -0.878506998751255820, -0.878483111179284240, -0.878459221411105330, -0.878435329446778380, -0.878411435286363120, -0.878387538929919160, -0.878363640377506470, +-0.878339739629184660, -0.878315836685013450, -0.878291931545052700, -0.878268024209362010, -0.878244114678001010, -0.878220202951029980, -0.878196289028508550, -0.878172372910496430, +-0.878148454597053260, -0.878124534088238650, -0.878100611384112990, -0.878076686484735910, -0.878052759390167140, -0.878028830100466400, -0.878004898615693640, -0.877980964935908600, +-0.877957029061171120, -0.877933090991541040, -0.877909150727078310, -0.877885208267842330, -0.877861263613893610, -0.877837316765291860, -0.877813367722096730, -0.877789416484368260, +-0.877765463052165740, -0.877741507425550020, -0.877717549604580590, -0.877693589589317200, -0.877669627379819910, -0.877645662976148430, -0.877621696378362850, -0.877597727586523100, +-0.877573756600689040, -0.877549783420920490, -0.877525808047277090, -0.877501830479819670, -0.877477850718607620, -0.877453868763700910, -0.877429884615159580, -0.877405898273043490, +-0.877381909737412150, -0.877357919008326600, -0.877333926085846260, -0.877309930970031070, -0.877285933660940990, -0.877261934158636180, -0.877237932463176500, -0.877213928574621990, +-0.877189922493032630, -0.877165914218468010, -0.877141903750989100, -0.877117891090655410, -0.877093876237526990, -0.877069859191663910, -0.877045839953126130, -0.877021818521973360, +-0.876997794898266460, -0.876973769082065040, -0.876949741073429160, -0.876925710872419000, -0.876901678479094620, -0.876877643893515970, -0.876853607115743230, -0.876829568145836460, +-0.876805526983855720, -0.876781483629860860, -0.876757438083912600, -0.876733390346070780, -0.876709340416395480, -0.876685288294946850, -0.876661233981784640, -0.876637177476969680, +-0.876613118780561810, -0.876589057892621090, -0.876564994813207820, -0.876540929542382050, -0.876516862080203850, -0.876492792426733610, -0.876468720582031290, -0.876444646546157280, +-0.876420570319171200, -0.876396491901134000, -0.876372411292105640, -0.876348328492146390, -0.876324243501316100, -0.876300156319674950, -0.876276066947283770, -0.876251975384202410, +-0.876227881630491150, -0.876203785686210160, -0.876179687551419620, -0.876155587226180030, -0.876131484710551360, -0.876107380004593980, -0.876083273108368200, -0.876059164021933730, +-0.876035052745351870, -0.876010939278682340, -0.875986823621985430, -0.875962705775321540, -0.875938585738750830, -0.875914463512333260, -0.875890339096129900, -0.875866212490200690, +-0.875842083694606030, -0.875817952709406100, -0.875793819534661290, -0.875769684170431990, -0.875745546616778500, -0.875721406873761100, -0.875697264941439730, -0.875673120819875580, +-0.875648974509128710, -0.875624826009259390, -0.875600675320328040, -0.875576522442394920, -0.875552367375520110, -0.875528210119764780, -0.875504050675188990, -0.875479889041853030, +-0.875455725219817290, -0.875431559209142400, -0.875407391009888510, -0.875383220622116040, -0.875359048045885710, -0.875334873281257250, -0.875310696328291950, -0.875286517187050080, +-0.875262335857591830, -0.875238152339977700, -0.875213966634268200, -0.875189778740523390, -0.875165588658804560, -0.875141396389171770, -0.875117201931685520, -0.875093005286406210, +-0.875068806453394350, -0.875044605432710560, -0.875020402224415240, -0.874996196828568880, -0.874971989245232010, -0.874947779474464780, -0.874923567516328490, -0.874899353370883310, +-0.874875137038189750, -0.874850918518308430, -0.874826697811299290, -0.874802474917223850, -0.874778249836142160, -0.874754022568114960, -0.874729793113202650, -0.874705561471465830, +-0.874681327642965130, -0.874657091627761170, -0.874632853425914350, -0.874608613037485490, -0.874584370462534680, -0.874560125701123400, -0.874535878753311740, -0.874511629619160290, +-0.874487378298729910, -0.874463124792081100, -0.874438869099273930, -0.874414611220370120, -0.874390351155429730, -0.874366088904513510, -0.874341824467682050, -0.874317557844995990, +-0.874293289036516040, -0.874269018042302950, -0.874244744862417210, -0.874220469496919230, -0.874196191945870500, -0.874171912209331330, -0.874147630287362310, -0.874123346180024300, +-0.874099059887377790, -0.874074771409483310, -0.874050480746402350, -0.874026187898195080, -0.874001892864922470, -0.873977595646645010, -0.873953296243423660, -0.873928994655319040, +-0.873904690882391870, -0.873880384924702990, -0.873856076782312810, -0.873831766455282820, -0.873807453943673320, -0.873783139247545250, -0.873758822366959450, -0.873734503301976440, +-0.873710182052656830, -0.873685858619062120, -0.873661533001252820, -0.873637205199289670, -0.873612875213233500, -0.873588543043145150, -0.873564208689085460, -0.873539872151115280, +-0.873515533429295330, -0.873491192523686570, -0.873466849434349380, -0.873442504161345610, -0.873418156704735550, -0.873393807064580030, -0.873369455240940010, -0.873345101233875880, +-0.873320745043449480, -0.873296386669721310, -0.873272026112752010, -0.873247663372602730, -0.873223298449334330, -0.873198931343007630, -0.873174562053683600, -0.873150190581423070, +-0.873125816926287210, -0.873101441088336320, -0.873077063067632330, -0.873052682864235540, -0.873028300478207120, -0.873003915909608020, -0.872979529158499080, -0.872955140224940810, +-0.872930749108995260, -0.872906355810722730, -0.872881960330184280, -0.872857562667441080, -0.872833162822553850, -0.872808760795583780, -0.872784356586591700, -0.872759950195638790, +-0.872735541622785660, -0.872711130868094040, -0.872686717931624560, -0.872662302813438260, -0.872637885513596330, -0.872613466032159610, -0.872589044369188830, -0.872564620524745820, +-0.872540194498891310, -0.872515766291686260, -0.872491335903191830, -0.872466903333468990, -0.872442468582579010, -0.872418031650582740, -0.872393592537541450, -0.872369151243515770, +-0.872344707768567650, -0.872320262112757700, -0.872295814276147110, -0.872271364258797030, -0.872246912060768540, -0.872222457682122250, -0.872198001122920340, -0.872173542383223420, +-0.872149081463092560, -0.872124618362589140, -0.872100153081774130, -0.872075685620708580, -0.872051215979454010, -0.872026744158071350, -0.872002270156621790, -0.871977793975166170, +-0.871953315613766430, -0.871928835072483420, -0.871904352351378310, -0.871879867450512380, -0.871855380369946360, -0.871830891109742210, -0.871806399669960990, -0.871781906050663640, +-0.871757410251911560, -0.871732912273766040, -0.871708412116288130, -0.871683909779539250, -0.871659405263580540, -0.871634898568473430, -0.871610389694278510, -0.871585878641058080, +-0.871561365408872970, -0.871536849997784470, -0.871512332407853860, -0.871487812639142320, -0.871463290691710910, -0.871438766565621690, -0.871414240260935610, -0.871389711777713850, +-0.871365181116017800, -0.871340648275908850, -0.871316113257448180, -0.871291576060697290, -0.871267036685717480, -0.871242495132569680, -0.871217951401315970, -0.871193405492017510, +-0.871168857404735490, -0.871144307139531280, -0.871119754696466300, -0.871095200075601590, -0.871070643276999230, -0.871046084300720280, -0.871021523146826130, -0.870996959815378170, +-0.870972394306437800, -0.870947826620066420, -0.870923256756325540, -0.870898684715276540, -0.870874110496980270, -0.870849534101499230, -0.870824955528894380, -0.870800374779227120, +-0.870775791852558930, -0.870751206748951230, -0.870726619468465080, -0.870702030011162860, -0.870677438377105540, -0.870652844566354610, -0.870628248578971590, -0.870603650415017970, +-0.870579050074555270, -0.870554447557644770, -0.870529842864348310, -0.870505235994727180, -0.870480626948842540, -0.870456015726756790, -0.870431402328530890, -0.870406786754226670, +-0.870382169003905300, -0.870357549077628190, -0.870332926975457610, -0.870308302697454740, -0.870283676243681080, -0.870259047614198140, -0.870234416809067770, -0.870209783828351240, +-0.870185148672110280, -0.870160511340406400, -0.870135871833301320, -0.870111230150856120, -0.870086586293133180, -0.870061940260193900, -0.870037292052099680, -0.870012641668912350, +-0.869987989110693300, -0.869963334377503840, -0.869938677469406560, -0.869914018386462540, -0.869889357128733390, -0.869864693696280940, -0.869840028089166830, -0.869815360307452550, +-0.869790690351199820, -0.869766018220470500, -0.869741343915325650, -0.869716667435827870, -0.869691988782038350, -0.869667307954018920, -0.869642624951831200, -0.869617939775537030, +-0.869593252425197470, -0.869568562900875140, -0.869543871202631550, -0.869519177330528190, -0.869494481284626920, -0.869469783064989450, -0.869445082671677530, -0.869420380104752980, +-0.869395675364277310, -0.869370968450312140, -0.869346259362919980, -0.869321548102162110, -0.869296834668100370, -0.869272119060796600, -0.869247401280312530, -0.869222681326709430, +-0.869197959200050160, -0.869173234900396000, -0.869148508427808660, -0.869123779782350110, -0.869099048964082190, -0.869074315973066500, -0.869049580809365120, -0.869024843473039770, +-0.869000103964152280, -0.868975362282764060, -0.868950618428937950, -0.868925872402735220, -0.868901124204217950, -0.868876373833447730, -0.868851621290486210, -0.868826866575395980, +-0.868802109688238680, -0.868777350629076130, -0.868752589397970070, -0.868727825994982660, -0.868703060420175640, -0.868678292673610960, -0.868653522755350570, -0.868628750665456420, +-0.868603976403989900, -0.868579199971013850, -0.868554421366589780, -0.868529640590779750, -0.868504857643645600, -0.868480072525249280, -0.868455285235652300, -0.868430495774917600, +-0.868405704143106690, -0.868380910340281420, -0.868356114366503950, -0.868331316221836240, -0.868306515906340120, -0.868281713420077760, -0.868256908763111120, -0.868232101935501820, +-0.868207292937312690, -0.868182481768605240, -0.868157668429441640, -0.868132852919883960, -0.868108035239994020, -0.868083215389833570, -0.868058393369465550, -0.868033569178951580, +-0.868008742818353610, -0.867983914287733800, -0.867959083587154230, -0.867934250716676960, -0.867909415676364150, -0.867884578466277650, -0.867859739086479290, -0.867834897537032130, +-0.867810053817997580, -0.867785207929438030, -0.867760359871415310, -0.867735509643991820, -0.867710657247229070, -0.867685802681190110, -0.867660945945936680, -0.867636087041530830, +-0.867611225968034860, -0.867586362725510710, -0.867561497314020660, -0.867536629733627000, -0.867511759984391670, -0.867486888066376970, -0.867462013979644510, -0.867437137724257570, +-0.867412259300277770, -0.867387378707767280, -0.867362495946788380, -0.867337611017402700, -0.867312723919673510, -0.867287834653662550, -0.867262943219431980, -0.867238049617044090, +-0.867213153846561060, -0.867188255908045050, -0.867163355801558460, -0.867138453527163460, -0.867113549084922440, -0.867088642474897030, -0.867063733697150400, -0.867038822751744490, +-0.867013909638741480, -0.866988994358203760, -0.866964076910193500, -0.866939157294772670, -0.866914235512004310, -0.866889311561950480, -0.866864385444673260, -0.866839457160235140, +-0.866814526708698300, -0.866789594090125240, -0.866764659304578130, -0.866739722352119380, -0.866714783232810930, -0.866689841946715940, -0.866664898493896270, -0.866639952874414420, +-0.866615005088332670, -0.866590055135713410, -0.866565103016618600, -0.866540148731111510, -0.866515192279254000, -0.866490233661108440, -0.866465272876737470, -0.866440309926203130, +-0.866415344809568170, -0.866390377526894740, -0.866365408078245470, -0.866340436463682080, -0.866315462683268200, -0.866290486737065550, -0.866265508625136740, -0.866240528347544170, +-0.866215545904350240, -0.866190561295617000, -0.866165574521407860, -0.866140585581784750, -0.866115594476810190, -0.866090601206546570, -0.866065605771056510, -0.866040608170402510, +-0.866015608404646860, -0.865990606473852290, -0.865965602378081070, -0.865940596117395490, -0.865915587691858830, -0.865890577101533280, -0.865865564346481210, -0.865840549426765250, +-0.865815532342447570, -0.865790513093591340, -0.865765491680258960, -0.865740468102512820, -0.865715442360415420, -0.865690414454029500, -0.865665384383417560, -0.865640352148642100, +-0.865615317749765740, -0.865590281186851110, -0.865565242459960360, -0.865540201569157010, -0.865515158514503000, -0.865490113296061180, -0.865465065913894160, -0.865440016368064340, +-0.865414964658634100, -0.865389910785666850, -0.865364854749224870, -0.865339796549370770, -0.865314736186167170, -0.865289673659676680, -0.865264608969962050, -0.865239542117085870, +-0.865214473101110880, -0.865189401922099140, -0.865164328580114490, -0.865139253075218880, -0.865114175407475260, -0.865089095576946130, -0.865064013583694340, -0.865038929427782040, +-0.865013843109272870, -0.864988754628229000, -0.864963663984713360, -0.864938571178788470, -0.864913476210517170, -0.864888379079962190, -0.864863279787186360, -0.864838178332252180, +-0.864813074715222170, -0.864787968936159950, -0.864762860995127780, -0.864737750892188520, -0.864712638627404770, -0.864687524200839500, -0.864662407612554970, -0.864637288862614820, +-0.864612167951081420, -0.864587044878017740, -0.864561919643486390, -0.864536792247550200, -0.864511662690272020, -0.864486530971714680, -0.864461397091941030, -0.864436261051014010, +-0.864411122848995680, -0.864385982485950110, -0.864360839961939580, -0.864335695277026920, -0.864310548431275080, -0.864285399424746360, -0.864260248257504580, -0.864235094929612260, +-0.864209939441132110, -0.864184781792127210, -0.864159621982660280, -0.864134460012794370, -0.864109295882592220, -0.864084129592116890, -0.864058961141431210, -0.864033790530597700, +-0.864008617759680080, -0.863983442828741070, -0.863958265737843400, -0.863933086487050030, -0.863907905076423900, -0.863882721506027630, -0.863857535775924950, -0.863832347886178460, +-0.863807157836851140, -0.863781965628005910, -0.863756771259705740, -0.863731574732013560, -0.863706376044992560, -0.863681175198705580, -0.863655972193215330, -0.863630767028585430, +-0.863605559704878620, -0.863580350222158070, -0.863555138580486490, -0.863529924779927180, -0.863504708820542530, -0.863479490702396490, -0.863454270425551900, -0.863429047990071470, +-0.863403823396018510, -0.863378596643455950, -0.863353367732446970, -0.863328136663054520, -0.863302903435341770, -0.863277668049371230, -0.863252430505207060, -0.863227190802911770, +-0.863201948942548420, -0.863176704924180300, -0.863151458747870470, -0.863126210413681430, -0.863100959921677350, -0.863075707271920840, -0.863050452464475200, -0.863025195499403260, +-0.862999936376768420, -0.862974675096633730, -0.862949411659062360, -0.862924146064117490, -0.862898878311862180, -0.862873608402359270, -0.862848336335672710, -0.862823062111865440, +-0.862797785731000410, -0.862772507193140910, -0.862747226498349780, -0.862721943646690970, -0.862696658638227310, -0.862671371473022090, -0.862646082151138360, -0.862620790672639410, +-0.862595497037588530, -0.862570201246048880, -0.862544903298083750, -0.862519603193756310, -0.862494300933129510, -0.862468996516267290, -0.862443689943232620, -0.862418381214088760, +-0.862393070328899000, -0.862367757287725970, -0.862342442090634040, -0.862317124737686070, -0.862291805228945330, -0.862266483564474990, -0.862241159744338460, -0.862215833768599000, +-0.862190505637319910, -0.862165175350564690, -0.862139842908396400, -0.862114508310878210, -0.862089171558074070, -0.862063832650047050, -0.862038491586860410, -0.862013148368577560, +-0.861987802995261900, -0.861962455466976250, -0.861937105783784910, -0.861911753945750810, -0.861886399952937250, -0.861861043805407730, -0.861835685503225650, -0.861810325046454380, +-0.861784962435157230, -0.861759597669397690, -0.861734230749238720, -0.861708861674744590, -0.861683490445978250, -0.861658117063003330, -0.861632741525882980, -0.861607363834680950, +-0.861581983989459840, -0.861556601990284390, -0.861531217837217420, -0.861505831530322340, -0.861480443069662760, -0.861455052455301960, -0.861429659687303560, -0.861404264765731060, +-0.861378867690647860, -0.861353468462117130, -0.861328067080203040, -0.861302663544968870, -0.861277257856478020, -0.861251850014794100, -0.861226440019980500, -0.861201027872100290, +-0.861175613571218080, -0.861150197117396710, -0.861124778510699910, -0.861099357751191170, -0.861073934838934020, -0.861048509773992050, -0.861023082556428790, -0.860997653186307830, +-0.860972221663692690, -0.860946787988646540, -0.860921352161234000, -0.860895914181518010, -0.860870474049562180, -0.860845031765430260, -0.860819587329185180, -0.860794140740891670, +-0.860768692000612900, -0.860743241108412270, -0.860717788064353510, -0.860692332868500330, -0.860666875520916360, -0.860641416021665220, -0.860615954370810510, -0.860590490568415860, +-0.860565024614544540, -0.860539556509261170, -0.860514086252628820, -0.860488613844711310, -0.860463139285572280, -0.860437662575275430, -0.860412183713883950, -0.860386702701462450, +-0.860361219538074210, -0.860335734223782840, -0.860310246758652200, -0.860284757142745990, -0.860259265376127850, -0.860233771458861480, -0.860208275391010750, -0.860182777172638800, +-0.860157276803810490, -0.860131774284588870, -0.860106269615037890, -0.860080762795221280, -0.860055253825202650, -0.860029742705045510, -0.860004229434814470, -0.859978714014572820, +-0.859953196444384280, -0.859927676724312920, -0.859902154854422340, -0.859876630834776280, -0.859851104665438680, -0.859825576346473390, -0.859800045877943670, -0.859774513259914270, +-0.859748978492448580, -0.859723441575610540, -0.859697902509463760, -0.859672361294072320, -0.859646817929499480, -0.859621272415809990, -0.859595724753067450, -0.859570174941335470, +-0.859544622980678130, -0.859519068871159250, -0.859493512612842680, -0.859467954205792360, -0.859442393650072020, -0.859416830945745840, -0.859391266092877080, -0.859365699091530600, +-0.859340129941769890, -0.859314558643658800, -0.859288985197261380, -0.859263409602641030, -0.859237831859862580, -0.859212251968989540, -0.859186669930085970, -0.859161085743215590, +-0.859135499408442580, -0.859109910925830890, -0.859084320295444240, -0.859058727517346910, -0.859033132591602740, -0.859007535518275240, -0.858981936297429470, -0.858956334929128820, +-0.858930731413437230, -0.858905125750419000, -0.858879517940137730, -0.858853907982657370, -0.858828295878042660, -0.858802681626357200, -0.858777065227665060, -0.858751446682030180, +-0.858725825989516740, -0.858700203150188690, -0.858674578164110190, -0.858648951031345310, -0.858623321751957440, -0.858597690326011850, -0.858572056753571950, -0.858546421034701910, +-0.858520783169465900, -0.858495143157927850, -0.858469501000151510, -0.858443856696201930, -0.858418210246142620, -0.858392561650037860, -0.858366910907951700, -0.858341258019948210, +-0.858315602986091550, -0.858289945806445910, -0.858264286481075440, -0.858238625010043780, -0.858212961393416070, -0.858187295631255840, -0.858161627723627470, -0.858135957670595030, +-0.858110285472222570, -0.858084611128574040, -0.858058934639714500, -0.858033256005707570, -0.858007575226617410, -0.857981892302508430, -0.857956207233444680, -0.857930520019490330, +-0.857904830660709770, -0.857879139157167180, -0.857853445508926620, -0.857827749716052130, -0.857802051778608580, -0.857776351696660000, -0.857750649470270470, -0.857724945099504370, +-0.857699238584425430, -0.857673529925098930, -0.857647819121588490, -0.857622106173958510, -0.857596391082273260, -0.857570673846597130, -0.857544954466994300, -0.857519232943528940, +-0.857493509276265660, -0.857467783465268530, -0.857442055510601490, -0.857416325412329820, -0.857390593170517250, -0.857364858785228280, -0.857339122256527200, -0.857313383584478170, +-0.857287642769145370, -0.857261899810593750, -0.857236154708887480, -0.857210407464090830, -0.857184658076268200, -0.857158906545483880, -0.857133152871802250, -0.857107397055287820, +-0.857081639096004880, -0.857055878994017360, -0.857030116749390560, -0.857004352362188530, -0.856978585832475660, -0.856952817160316240, -0.856927046345774770, -0.856901273388915310, +-0.856875498289803140, -0.856849721048502100, -0.856823941665076800, -0.856798160139591650, -0.856772376472111130, -0.856746590662699650, -0.856720802711421700, -0.856695012618341800, +-0.856669220383523890, -0.856643426007033360, -0.856617629488934160, -0.856591830829291020, -0.856566030028168330, -0.856540227085630490, -0.856514422001741660, -0.856488614776567130, +-0.856462805410171170, -0.856436993902618180, -0.856411180253972670, -0.856385364464299250, -0.856359546533662420, -0.856333726462126690, -0.856307904249756670, -0.856282079896616980, +-0.856256253402771450, -0.856230424768285920, -0.856204593993224240, -0.856178761077651010, -0.856152926021630960, -0.856127088825228140, -0.856101249488508080, -0.856075408011534810, +-0.856049564394373070, -0.856023718637087370, -0.855997870739742430, -0.855972020702402860, -0.855946168525133170, -0.855920314207998080, -0.855894457751062210, -0.855868599154389730, +-0.855842738418046150, -0.855816875542095850, -0.855791010526603220, -0.855765143371633120, -0.855739274077250260, -0.855713402643518580, -0.855687529070504050, -0.855661653358270600, +-0.855635775506882970, -0.855609895516405980, -0.855584013386904150, -0.855558129118442310, -0.855532242711085190, -0.855506354164897510, -0.855480463479943440, -0.855454570656288720, +-0.855428675693997500, -0.855402778593134630, -0.855376879353764720, -0.855350977975952720, -0.855325074459762800, -0.855299168805260690, -0.855273261012510560, -0.855247351081577340, +-0.855221439012525670, -0.855195524805420490, -0.855169608460326520, -0.855143689977308500, -0.855117769356431250, -0.855091846597759050, -0.855065921701357760, -0.855039994667291640, +-0.855014065495625530, -0.854988134186424280, -0.854962200739752710, -0.854936265155675110, -0.854910327434257430, -0.854884387575563840, -0.854858445579659290, -0.854832501446608610, +-0.854806555176476750, -0.854780606769328430, -0.854754656225228620, -0.854728703544242130, -0.854702748726433930, -0.854676791771868390, -0.854650832680611370, -0.854624871452727140, +-0.854598908088280870, -0.854572942587337290, -0.854546974949960900, -0.854521005176217540, -0.854495033266171600, -0.854469059219888140, -0.854443083037431990, -0.854417104718868110, +-0.854391124264261560, -0.854365141673677160, -0.854339156947179880, -0.854313170084834760, -0.854287181086706200, -0.854261189952860160, -0.854235196683361230, -0.854209201278274160, +-0.854183203737664210, -0.854157204061596230, -0.854131202250134720, -0.854105198303345750, -0.854079192221293690, -0.854053184004043730, -0.854027173651660700, -0.854001161164209880, +-0.853975146541756100, -0.853949129784364440, -0.853923110892099930, -0.853897089865027210, -0.853871066703212220, -0.853845041406719570, -0.853819013975614330, -0.853792984409961540, +-0.853766952709826280, -0.853740918875273260, -0.853714882906368320, -0.853688844803176190, -0.853662804565761930, -0.853636762194190600, -0.853610717688527480, -0.853584671048837510, +-0.853558622275185860, -0.853532571367637720, -0.853506518326257680, -0.853480463151111700, -0.853454405842264730, -0.853428346399781600, -0.853402284823727600, -0.853376221114168000, +-0.853350155271167310, -0.853324087294791700, -0.853298017185105890, -0.853271944942175060, -0.853245870566064380, -0.853219794056838900, -0.853193715414564010, -0.853167634639304890, +-0.853141551731126600, -0.853115466690094530, -0.853089379516273280, -0.853063290209729040, -0.853037198770526530, -0.853011105198731020, -0.852985009494407810, -0.852958911657621610, +-0.852932811688438600, -0.852906709586923490, -0.852880605353141700, -0.852854498987158370, -0.852828390489038690, -0.852802279858848160, -0.852776167096651940, -0.852750052202515210, +-0.852723935176503360, -0.852697816018681220, -0.852671694729115080, -0.852645571307869670, -0.852619445755010250, -0.852593318070602350, -0.852567188254711010, -0.852541056307401290, +-0.852514922228739480, -0.852488786018790300, -0.852462647677619150, -0.852436507205291400, -0.852410364601872360, -0.852384219867427410, -0.852358073002021930, -0.852331924005721220, +-0.852305772878590220, -0.852279619620695320, -0.852253464232101350, -0.852227306712873720, -0.852201147063077810, -0.852174985282779130, -0.852148821372042400, -0.852122655330934120, +-0.852096487159519240, -0.852070316857863050, -0.852044144426031160, -0.852017969864088840, -0.851991793172101610, -0.851965614350134960, -0.851939433398254290, -0.851913250316524430, +-0.851887065105012000, -0.851860877763781940, -0.851834688292899660, -0.851808496692430640, -0.851782302962440400, -0.851756107102993880, -0.851729909114157690, -0.851703708995996570, +-0.851677506748576230, -0.851651302371962180, -0.851625095866219820, -0.851598887231414750, -0.851572676467612480, -0.851546463574878510, -0.851520248553278350, -0.851494031402877050, +-0.851467812123741230, -0.851441590715935840, -0.851415367179526480, -0.851389141514578780, -0.851362913721157690, -0.851336683799329700, -0.851310451749160090, -0.851284217570714370, +-0.851257981264058050, -0.851231742829256840, -0.851205502266376260, -0.851179259575481910, -0.851153014756639400, -0.851126767809914360, -0.851100518735371960, -0.851074267533078690, +-0.851048014203099720, -0.851021758745500790, -0.850995501160347390, -0.850969241447705360, -0.850942979607639650, -0.850916715640216980, -0.850890449545502530, -0.850864181323562010, +-0.850837910974460930, -0.850811638498265130, -0.850785363895040230, -0.850759087164851930, -0.850732808307765880, -0.850706527323847440, -0.850680244213163020, -0.850653958975778110, +-0.850627671611758230, -0.850601382121169090, -0.850575090504076650, -0.850548796760545960, -0.850522500890643740, -0.850496202894435280, -0.850469902771986310, -0.850443600523362540, +-0.850417296148629820, -0.850390989647853870, -0.850364681021100410, -0.850338370268435280, -0.850312057389923660, -0.850285742385632480, -0.850259425255626920, -0.850233105999972700, +-0.850206784618735890, -0.850180461111981980, -0.850154135479776470, -0.850127807722186210, -0.850101477839276250, -0.850075145831112770, -0.850048811697761250, -0.850022475439287880, +-0.849996137055758160, -0.849969796547238250, -0.849943453913793780, -0.849917109155490570, -0.849890762272394240, -0.849864413264571410, -0.849838062132087570, -0.849811708875008680, +-0.849785353493400450, -0.849758995987328290, -0.849732636356859140, -0.849706274602058500, -0.849679910722992090, -0.849653544719725870, -0.849627176592325890, -0.849600806340857880, +-0.849574433965387900, -0.849548059465981780, -0.849521682842705570, -0.849495304095624680, -0.849468923224805940, -0.849442540230314960, -0.849416155112217570, -0.849389767870579850, +-0.849363378505467730, -0.849336987016946600, -0.849310593405083520, -0.849284197669944010, -0.849257799811593990, -0.849231399830099430, -0.849204997725526380, -0.849178593497940780, +-0.849152187147408810, -0.849125778673996300, -0.849099368077768870, -0.849072955358793570, -0.849046540517135790, -0.849020123552861720, -0.848993704466037280, -0.848967283256728660, +-0.848940859925001230, -0.848914434470922300, -0.848888006894557120, -0.848861577195971990, -0.848835145375232970, -0.848808711432405990, -0.848782275367557350, -0.848755837180752870, +-0.848729396872058950, -0.848702954441540980, -0.848676509889266130, -0.848650063215300010, -0.848623614419708680, -0.848597163502558320, -0.848570710463915080, -0.848544255303844590, +-0.848517798022413890, -0.848491338619688840, -0.848464877095735260, -0.848438413450619660, -0.848411947684407860, -0.848385479797166280, -0.848359009788961060, -0.848332537659858170, +-0.848306063409923980, -0.848279587039224240, -0.848253108547825980, -0.848226627935794950, -0.848200145203197310, -0.848173660350099330, -0.848147173376566640, -0.848120684282666630, +-0.848094193068464790, -0.848067699734027620, -0.848041204279421090, -0.848014706704711570, -0.847988207009965240, -0.847961705195248490, -0.847935201260627380, -0.847908695206168290, +-0.847882187031937070, -0.847855676738000770, -0.847829164324425340, -0.847802649791276950, -0.847776133138621880, -0.847749614366526070, -0.847723093475056700, -0.847696570464279710, +-0.847670045334261160, -0.847643518085067550, -0.847616988716765050, -0.847590457229420170, -0.847563923623099070, -0.847537387897868260, -0.847510850053793900, -0.847484310090942050, +-0.847457768009379770, -0.847431223809173130, -0.847404677490388390, -0.847378129053091960, -0.847351578497350320, -0.847325025823229220, -0.847298471030795920, -0.847271914120116490, +-0.847245355091257310, -0.847218793944284790, -0.847192230679265190, -0.847165665296265020, -0.847139097795350790, -0.847112528176588660, -0.847085956440044920, -0.847059382585786610, +-0.847032806613879920, -0.847006228524391220, -0.846979648317386810, -0.846953065992933410, -0.846926481551096840, -0.846899894991944620, -0.846873306315542580, -0.846846715521957340, +-0.846820122611255170, -0.846793527583502790, -0.846766930438766610, -0.846740331177113110, -0.846713729798608710, -0.846687126303319990, -0.846660520691313030, -0.846633912962655220, +-0.846607303117412720, -0.846580691155651820, -0.846554077077439240, -0.846527460882841030, -0.846500842571924710, -0.846474222144756210, -0.846447599601402030, -0.846420974941929030, +-0.846394348166403470, -0.846367719274892070, -0.846341088267461460, -0.846314455144178020, -0.846287819905108480, -0.846261182550319010, -0.846234543079876890, -0.846207901493848500, +-0.846181257792300360, -0.846154611975299060, -0.846127964042910800, -0.846101313995203050, -0.846074661832242110, -0.846048007554094370, -0.846021351160826660, -0.845994692652505710, +-0.845968032029197900, -0.845941369290969970, -0.845914704437888740, -0.845888037470020620, -0.845861368387431980, -0.845834697190190440, -0.845808023878362070, -0.845781348452013690, +-0.845754670911212040, -0.845727991256023600, -0.845701309486514670, -0.845674625602753080, -0.845647939604804780, -0.845621251492736700, -0.845594561266615470, -0.845567868926507930, +-0.845541174472480560, -0.845514477904600440, -0.845487779222933940, -0.845461078427547590, -0.845434375518509080, -0.845407670495884610, -0.845380963359740890, -0.845354254110144750, +-0.845327542747163040, -0.845300829270862030, -0.845274113681309450, -0.845247395978571460, -0.845220676162715010, -0.845193954233806940, -0.845167230191913980, -0.845140504037102840, +-0.845113775769440580, -0.845087045388993820, -0.845060312895828950, -0.845033578290013800, -0.845006841571614650, -0.844980102740698460, -0.844953361797331940, -0.844926618741582150, +-0.844899873573515150, -0.844873126293199110, -0.844846376900700190, -0.844819625396085350, -0.844792871779421420, -0.844766116050775340, -0.844739358210213950, -0.844712598257804090, +-0.844685836193612820, -0.844659072017706960, -0.844632305730152910, -0.844605537331018620, -0.844578766820370470, -0.844551994198275420, -0.844525219464800300, -0.844498442620011720, +-0.844471663663977520, -0.844444882596764200, -0.844418099418438590, -0.844391314129067760, -0.844364526728718650, -0.844337737217458200, -0.844310945595353470, -0.844284151862471300, +-0.844257356018878860, -0.844230558064642420, -0.844203757999830160, -0.844176955824508470, -0.844150151538744400, -0.844123345142604900, -0.844096536636157020, -0.844069726019467390, +-0.844042913292603950, -0.844016098455633190, -0.843989281508622180, -0.843962462451637970, -0.843935641284747630, -0.843908818008018090, -0.843881992621516640, -0.843855165125310110, +-0.843828335519465230, -0.843801503804050060, -0.843774669979130980, -0.843747834044775270, -0.843720996001050110, -0.843694155848022320, -0.843667313585758750, -0.843640469214327230, +-0.843613622733794700, -0.843586774144228000, -0.843559923445694420, -0.843533070638261000, -0.843506215721994910, -0.843479358696963330, -0.843452499563233320, -0.843425638320871580, +-0.843398774969946310, -0.843371909510523990, -0.843345041942671900, -0.843318172266457220, -0.843291300481947110, -0.843264426589208300, -0.843237550588308960, -0.843210672479315580, +-0.843183792262295670, -0.843156909937316180, -0.843130025504444490, -0.843103138963747670, -0.843076250315292990, -0.843049359559147730, -0.843022466695379060, -0.842995571724053820, +-0.842968674645240060, -0.842941775459004620, -0.842914874165414770, -0.842887970764537700, -0.842861065256440220, -0.842834157641190520, -0.842807247918855530, -0.842780336089502310, +-0.842753422153198370, -0.842726506110010760, -0.842699587960006990, -0.842672667703254110, -0.842645745339819730, -0.842618820869770910, -0.842591894293174490, -0.842564965610098860, +-0.842538034820610850, -0.842511101924777740, -0.842484166922666920, -0.842457229814345570, -0.842430290599880730, -0.842403349279340690, -0.842376405852792160, -0.842349460320302780, +-0.842322512681939580, -0.842295562937770190, -0.842268611087861880, -0.842241657132282050, -0.842214701071098080, -0.842187742904376920, -0.842160782632186740, -0.842133820254594710, +-0.842106855771668110, -0.842079889183474430, -0.842052920490080960, -0.842025949691554750, -0.841998976787964090, -0.841972001779376030, -0.841945024665857970, -0.841918045447477280, +-0.841891064124301590, -0.841864080696398060, -0.841837095163834540, -0.841810107526678180, -0.841783117784996040, -0.841756125938856630, -0.841729131988326880, -0.841702135933474320, +-0.841675137774366420, -0.841648137511070700, -0.841621135143654220, -0.841594130672185250, -0.841567124096730960, -0.841540115417358960, -0.841513104634136640, -0.841486091747131510, +-0.841459076756411180, -0.841432059662043150, -0.841405040464094920, -0.841378019162633660, -0.841350995757727870, -0.841323970249444610, -0.841296942637851260, -0.841269912923015670, +-0.841242881105005340, -0.841215847183887750, -0.841188811159730100, -0.841161773032600870, -0.841134732802567230, -0.841107690469696690, -0.841080646034056970, -0.841053599495715680, +-0.841026550854740430, -0.840999500111198620, -0.840972447265157740, -0.840945392316686190, -0.840918335265851140, -0.840891276112720190, -0.840864214857361180, -0.840837151499841510, +-0.840810086040229000, -0.840783018478590830, -0.840755948814995600, -0.840728877049510490, -0.840701803182203110, -0.840674727213141290, -0.840647649142392650, -0.840620568970024910, +-0.840593486696105780, -0.840566402320702790, -0.840539315843883420, -0.840512227265716280, -0.840485136586268440, -0.840458043805607850, -0.840430948923802210, -0.840403851940919040, +-0.840376752857025840, -0.840349651672191330, -0.840322548386482570, -0.840295442999967500, -0.840268335512713740, -0.840241225924789230, -0.840214114236261580, -0.840187000447198740, +-0.840159884557668320, -0.840132766567737720, -0.840105646477475650, -0.840078524286949620, -0.840051399996227130, -0.840024273605376240, -0.839997145114464550, -0.839970014523560020, +-0.839942881832730030, -0.839915747042043300, -0.839888610151567240, -0.839861471161369670, -0.839834330071518310, -0.839807186882081220, -0.839780041593126140, -0.839752894204720880, +-0.839725744716932950, -0.839698593129831190, -0.839671439443482880, -0.839644283657956070, -0.839617125773318480, -0.839589965789638070, -0.839562803706982770, -0.839535639525419990, +-0.839508473245018540, -0.839481304865845930, -0.839454134387970120, -0.839426961811458930, -0.839399787136380300, -0.839372610362802200, -0.839345431490792660, -0.839318250520418970, +-0.839291067451750190, -0.839263882284853710, -0.839236695019797590, -0.839209505656649650, -0.839182314195477950, -0.839155120636350560, -0.839127924979334750, -0.839100727224499690, +-0.839073527371912760, -0.839046325421642040, -0.839019121373755560, -0.838991915228321280, -0.838964706985407150, -0.838937496645081220, -0.838910284207411650, -0.838883069672465840, +-0.838855853040312850, -0.838828634311020170, -0.838801413484655980, -0.838774190561288210, -0.838746965540985050, -0.838719738423813870, -0.838692509209843840, -0.838665277899142580, +-0.838638044491778150, -0.838610808987818590, -0.838583571387331970, -0.838556331690386460, -0.838529089897050110, -0.838501846007391080, -0.838474600021476890, -0.838447351939376690, +-0.838420101761158220, -0.838392849486889410, -0.838365595116638440, -0.838338338650473470, -0.838311080088462780, -0.838283819430673760, -0.838256556677175800, -0.838229291828036290, +-0.838202024883323740, -0.838174755843105970, -0.838147484707451370, -0.838120211476428120, -0.838092936150104270, -0.838065658728547660, -0.838038379211827330, -0.838011097600011020, +-0.837983813893167010, -0.837956528091363450, -0.837929240194668630, -0.837901950203150610, -0.837874658116877340, -0.837847363935917850, -0.837820067660339900, -0.837792769290211960, +-0.837765468825601880, -0.837738166266578270, -0.837710861613209180, -0.837683554865563010, -0.837656246023707360, -0.837628935087711630, -0.837601622057643550, -0.837574306933571490, +-0.837546989715563630, -0.837519670403688240, -0.837492348998013720, -0.837465025498607800, -0.837437699905539850, -0.837410372218877600, -0.837383042438689440, -0.837355710565043650, +-0.837328376598008630, -0.837301040537652640, -0.837273702384044080, -0.837246362137251340, -0.837219019797342030, -0.837191675364385770, -0.837164328838450380, -0.837136980219604030, +-0.837109629507915340, -0.837082276703452480, -0.837054921806283490, -0.837027564816477660, -0.837000205734102940, -0.836972844559227710, -0.836945481291920370, -0.836918115932249300, +-0.836890748480283000, -0.836863378936089750, -0.836836007299738170, -0.836808633571295980, -0.836781257750832670, -0.836753879838416310, -0.836726499834115180, -0.836699117737997880, +-0.836671733550132690, -0.836644347270588230, -0.836616958899432440, -0.836589568436734710, -0.836562175882562990, -0.836534781236985880, -0.836507384500071890, -0.836479985671889300, +-0.836452584752506830, -0.836425181741992870, -0.836397776640415590, -0.836370369447844150, -0.836342960164346950, -0.836315548789992260, -0.836288135324848800, -0.836260719768984860, +-0.836233302122469160, -0.836205882385369750, -0.836178460557756130, -0.836151036639696370, -0.836123610631259060, -0.836096182532512610, -0.836068752343525730, -0.836041320064367040, +-0.836013885695105040, -0.835986449235807780, -0.835959010686544880, -0.835931570047384500, -0.835904127318395250, -0.835876682499645530, -0.835849235591204160, -0.835821786593139770, +-0.835794335505520400, -0.835766882328415670, -0.835739427061893750, -0.835711969706023240, -0.835684510260872760, -0.835657048726511140, -0.835629585103006780, -0.835602119390428500, +-0.835574651588844920, -0.835547181698324200, -0.835519709718935970, -0.835492235650748590, -0.835464759493830480, -0.835437281248250560, -0.835409800914077460, -0.835382318491379340, +-0.835354833980225920, -0.835327347380685370, -0.835299858692826520, -0.835272367916717990, -0.835244875052428500, -0.835217380100026880, -0.835189883059581750, -0.835162383931162040, +-0.835134882714835710, -0.835107379410672810, -0.835079874018741400, -0.835052366539110300, -0.835024856971848250, -0.834997345317024080, -0.834969831574706610, -0.834942315744964030, +-0.834914797827866150, -0.834887277823481270, -0.834859755731878210, -0.834832231553125800, -0.834804705287292670, -0.834777176934447970, -0.834749646494660210, -0.834722113967997890, +-0.834694579354530730, -0.834667042654327120, -0.834639503867455890, -0.834611962993985990, -0.834584420033986140, -0.834556874987525180, -0.834529327854671600, -0.834501778635495130, +-0.834474227330064270, -0.834446673938447850, -0.834419118460714700, -0.834391560896933780, -0.834364001247174030, -0.834336439511504270, -0.834308875689992790, -0.834281309782709650, +-0.834253741789723340, -0.834226171711102580, -0.834198599546916440, -0.834171025297233750, -0.834143448962123560, -0.834115870541654260, -0.834088290035895690, -0.834060707444916450, +-0.834033122768785380, -0.834005536007571660, -0.833977947161343990, -0.833950356230171440, -0.833922763214123060, -0.833895168113267690, -0.833867570927673940, -0.833839971657411750, +-0.833812370302549730, -0.833784766863156720, -0.833757161339301780, -0.833729553731053840, -0.833701944038481630, -0.833674332261655100, -0.833646718400642640, -0.833619102455513410, +-0.833591484426336460, -0.833563864313180860, -0.833536242116115430, -0.833508617835209460, -0.833480991470532010, -0.833453363022151560, -0.833425732490138180, -0.833398099874560480, +-0.833370465175487520, -0.833342828392988340, -0.833315189527132240, -0.833287548577987590, -0.833259905545624570, -0.833232260430111780, -0.833204613231518290, -0.833176963949913360, +-0.833149312585365950, -0.833121659137945230, -0.833094003607720460, -0.833066345994760590, -0.833038686299134470, -0.833011024520912020, -0.832983360660162100, -0.832955694716953630, +-0.832928026691356130, -0.832900356583438420, -0.832872684393269890, -0.832845010120919050, -0.832817333766456280, -0.832789655329950200, -0.832761974811469850, -0.832734292211084750, +-0.832706607528863720, -0.832678920764876370, -0.832651231919191550, -0.832623540991878190, -0.832595847983006570, -0.832568152892645190, -0.832540455720863550, -0.832512756467730710, +-0.832485055133316050, -0.832457351717688640, -0.832429646220917420, -0.832401938643072550, -0.832374228984222860, -0.832346517244437640, -0.832318803423786060, -0.832291087522337490, +-0.832263369540161220, -0.832235649477326530, -0.832207927333902700, -0.832180203109958550, -0.832152476805564370, -0.832124748420788980, -0.832097017955701790, -0.832069285410372060, +-0.832041550784869080, -0.832013814079261670, -0.831986075293620340, -0.831958334428013700, -0.831930591482511360, -0.831902846457182490, -0.831875099352096470, -0.831847350167322700, +-0.831819598902930560, -0.831791845558989440, -0.831764090135568180, -0.831736332632737270, -0.831708573050565450, -0.831680811389122200, -0.831653047648476920, -0.831625281828699100, +-0.831597513929857480, -0.831569743952022660, -0.831541971895263470, -0.831514197759649300, -0.831486421545249650, -0.831458643252133920, -0.831430862880371600, -0.831403080430032190, +-0.831375295901184970, -0.831347509293899110, -0.831319720608244880, -0.831291929844291460, -0.831264137002108110, -0.831236342081764450, -0.831208545083329970, -0.831180746006874080, +-0.831152944852465940, -0.831125141620175810, -0.831097336310072880, -0.831069528922226630, -0.831041719456706460, -0.831013907913582090, -0.830986094292922920, -0.830958278594798540, +-0.830930460819277910, -0.830902640966431630, -0.830874819036328870, -0.830846995029038910, -0.830819168944631480, -0.830791340783176180, -0.830763510544742510, -0.830735678229399640, +-0.830707843837217960, -0.830680007368266750, -0.830652168822615500, -0.830624328200333830, -0.830596485501491340, -0.830568640726157550, -0.830540793874402270, -0.830512944946295020, +-0.830485093941904840, -0.830457240861302460, -0.830429385704556930, -0.830401528471737980, -0.830373669162915220, -0.830345807778158250, -0.830317944317536250, -0.830290078781119930, +-0.830262211168978360, -0.830234341481181250, -0.830206469717798430, -0.830178595878899310, -0.830150719964553700, -0.830122841974831330, -0.830094961909801920, -0.830067079769534530, +-0.830039195554099880, -0.830011309263567370, -0.829983420898006470, -0.829955530457487160, -0.829927637942078910, -0.829899743351851020, -0.829871846686874410, -0.829843947947218050, +-0.829816047132951980, -0.829788144244145710, -0.829760239280869060, -0.829732332243191760, -0.829704423131183750, -0.829676511944914650, -0.829648598684453730, -0.829620683349871820, +-0.829592765941238210, -0.829564846458622720, -0.829536924902095070, -0.829509001271725110, -0.829481075567582660, -0.829453147789737000, -0.829425217938258960, -0.829397286013217940, +-0.829369352014683650, -0.829341415942726030, -0.829313477797414820, -0.829285537578819950, -0.829257595287011260, -0.829229650922058030, -0.829201704484031190, -0.829173755973000140, +-0.829145805389034600, -0.829117852732204620, -0.829089898002579930, -0.829061941200230580, -0.829033982325225850, -0.829006021377636680, -0.828978058357532350, -0.828950093264983030, +-0.828922126100058440, -0.828894156862828520, -0.828866185553363110, -0.828838212171732370, -0.828810236718006020, -0.828782259192253680, -0.828754279594546060, -0.828726297924952780, +-0.828698314183543780, -0.828670328370389010, -0.828642340485558400, -0.828614350529121470, -0.828586358501149150, -0.828558364401710930, -0.828530368230876780, -0.828502369988716740, +-0.828474369675300750, -0.828446367290698870, -0.828418362834981050, -0.828390356308217330, -0.828362347710477120, -0.828334337041831680, -0.828306324302350290, -0.828278309492103240, +-0.828250292611160340, -0.828222273659591670, -0.828194252637466820, -0.828166229544856860, -0.828138204381831280, -0.828110177148460250, -0.828082147844813820, -0.828054116470961940, +-0.828026083026974780, -0.827998047512922390, -0.827970009928874930, -0.827941970274901910, -0.827913928551074490, -0.827885884757462280, -0.827857838894135330, -0.827829790961163710, +-0.827801740958617690, -0.827773688886567330, -0.827745634745082230, -0.827717578534233560, -0.827689520254090930, -0.827661459904724510, -0.827633397486204460, -0.827605332998600840, +-0.827577266441983930, -0.827549197816423890, -0.827521127121990330, -0.827493054358754420, -0.827464979526785880, -0.827436902626154880, -0.827408823656931690, -0.827380742619186370, +-0.827352659512989200, -0.827324574338409890, -0.827296487095519730, -0.827268397784388210, -0.827240306405085830, -0.827212212957682660, -0.827184117442248850, -0.827156019858854900, +-0.827127920207570750, -0.827099818488466370, -0.827071714701613000, -0.827043608847080280, -0.827015500924938580, -0.826987390935258080, -0.826959278878109050, -0.826931164753561990, +-0.826903048561686390, -0.826874930302553660, -0.826846809976233720, -0.826818687582796640, -0.826790563122312920, -0.826762436594852710, -0.826734308000486420, -0.826706177339284420, +-0.826678044611317000, -0.826649909816653870, -0.826621772955366540, -0.826593634027524730, -0.826565493033198930, -0.826537349972459310, -0.826509204845376270, -0.826481057652019850, +-0.826452908392461220, -0.826424757066770320, -0.826396603675017440, -0.826368448217273180, -0.826340290693607700, -0.826312131104091630, -0.826283969448795120, -0.826255805727788780, +-0.826227639941142340, -0.826199472088927300, -0.826171302171213600, -0.826143130188071620, -0.826114956139571870, -0.826086780025784730, -0.826058601846780590, -0.826030421602629520, +-0.826002239293402770, -0.825974054919170530, -0.825945868480003180, -0.825917679975971100, -0.825889489407144790, -0.825861296773594770, -0.825833102075391510, -0.825804905312605090, +-0.825776706485306770, -0.825748505593566720, -0.825720302637455440, -0.825692097617043430, -0.825663890532401190, -0.825635681383599110, -0.825607470170707460, -0.825579256893797520, +-0.825551041552939460, -0.825522824148203880, -0.825494604679661180, -0.825466383147381970, -0.825438159551436850, -0.825409933891896210, -0.825381706168830330, -0.825353476382310710, +-0.825325244532407300, -0.825297010619190810, -0.825268774642731850, -0.825240536603100930, -0.825212296500368650, -0.825184054334605180, -0.825155810105882010, -0.825127563814269330, +-0.825099315459837720, -0.825071065042657930, -0.825042812562800320, -0.825014558020335850, -0.824986301415334910, -0.824958042747868100, -0.824929782018005820, -0.824901519225819560, +-0.824873254371379480, -0.824844987454756320, -0.824816718476020670, -0.824788447435243150, -0.824760174332494040, -0.824731899167845060, -0.824703621941366260, -0.824675342653128470, +-0.824647061303202310, -0.824618777891658490, -0.824590492418567740, -0.824562204884000670, -0.824533915288028220, -0.824505623630720330, -0.824477329912148950, -0.824449034132384350, +-0.824420736291497040, -0.824392436389557950, -0.824364134426637700, -0.824335830402807220, -0.824307524318136590, -0.824279216172697620, -0.824250905966560700, -0.824222593699796450, +-0.824194279372475690, -0.824165962984669380, -0.824137644536448000, -0.824109324027882620, -0.824081001459043390, -0.824052676830002050, -0.824024350140829200, -0.823996021391595330, +-0.823967690582371510, -0.823939357713228350, -0.823911022784236890, -0.823882685795467420, -0.823854346746991650, -0.823826005638879980, -0.823797662471203340, -0.823769317244032570, +-0.823740969957438510, -0.823712620611491970, -0.823684269206264030, -0.823655915741824730, -0.823627560218246240, -0.823599202635598830, -0.823570842993953330, -0.823542481293380810, +-0.823514117533952090, -0.823485751715738120, -0.823457383838809180, -0.823429013903237310, -0.823400641909092900, -0.823372267856446900, -0.823343891745370260, -0.823315513575933800, +-0.823287133348208690, -0.823258751062265650, -0.823230366718175730, -0.823201980316009440, -0.823173591855838720, -0.823145201337733940, -0.823116808761766180, -0.823088414128006370, +-0.823060017436525570, -0.823031618687394270, -0.823003217880684420, -0.822974815016466410, -0.822946410094811510, -0.822918003115790440, -0.822889594079474480, -0.822861182985934470, +-0.822832769835241560, -0.822804354627466710, -0.822775937362680400, -0.822747518040954810, -0.822719096662360430, -0.822690673226968320, -0.822662247734849420, -0.822633820186075000, +-0.822605390580716020, -0.822576958918843080, -0.822548525200528240, -0.822520089425842090, -0.822491651594855710, -0.822463211707640140, -0.822434769764266550, -0.822406325764806100, +-0.822377879709329850, -0.822349431597908300, -0.822320981430613720, -0.822292529207516720, -0.822264074928688360, -0.822235618594199910, -0.822207160204122320, -0.822178699758526750, +-0.822150237257484040, -0.822121772701066230, -0.822093306089344060, -0.822064837422388450, -0.822036366700270920, -0.822007893923062390, -0.821979419090834160, -0.821950942203657280, +-0.821922463261602680, -0.821893982264742310, -0.821865499213147110, -0.821837014106888030, -0.821808526946036460, -0.821780037730663550, -0.821751546460840700, -0.821723053136638290, +-0.821694557758128830, -0.821666060325383030, -0.821637560838471950, -0.821609059297467080, -0.821580555702439490, -0.821552050053460550, -0.821523542350601430, -0.821495032593933530, +-0.821466520783527550, -0.821438006919455790, -0.821409491001788950, -0.821380973030598320, -0.821352453005955390, -0.821323930927931210, -0.821295406796596850, -0.821266880612024350, +-0.821238352374284660, -0.821209822083449170, -0.821181289739589040, -0.821152755342775760, -0.821124218893080520, -0.821095680390574790, -0.821067139835329750, -0.821038597227416460, +-0.821010052566907180, -0.820981505853872750, -0.820952957088384560, -0.820924406270514000, -0.820895853400332330, -0.820867298477911180, -0.820838741503321150, -0.820810182476634840, +-0.820781621397922990, -0.820753058267257200, -0.820724493084708740, -0.820695925850349010, -0.820667356564249490, -0.820638785226481480, -0.820610211837116130, -0.820581636396225720, +-0.820553058903881190, -0.820524479360154050, -0.820495897765115670, -0.820467314118837550, -0.820438728421391210, -0.820410140672847450, -0.820381550873279020, -0.820352959022756510, +-0.820324365121351650, -0.820295769169135940, -0.820267171166180750, -0.820238571112557710, -0.820209969008338200, -0.820181364853593280, -0.820152758648395430, -0.820124150392815610, +-0.820095540086925530, -0.820066927730796590, -0.820038313324500280, -0.820009696868108210, -0.819981078361691430, -0.819952457805322330, -0.819923835199072190, -0.819895210543012510, +-0.819866583837214670, -0.819837955081750500, -0.819809324276691400, -0.819780691422108960, -0.819752056518074810, -0.819723419564659990, -0.819694780561937120, -0.819666139509977350, +-0.819637496408852200, -0.819608851258633360, -0.819580204059392250, -0.819551554811200230, -0.819522903514129820, -0.819494250168252170, -0.819465594773638890, -0.819436937330361600, +-0.819408277838492020, -0.819379616298101740, -0.819350952709262390, -0.819322287072045690, -0.819293619386522680, -0.819264949652766190, -0.819236277870847300, -0.819207604040837700, +-0.819178928162809130, -0.819150250236833190, -0.819121570262981710, -0.819092888241325760, -0.819064204171938040, -0.819035518054889940, -0.819006829890252970, -0.818978139678098960, +-0.818949447418499510, -0.818920753111526460, -0.818892056757251630, -0.818863358355746080, -0.818834657907082650, -0.818805955411332500, -0.818777250868567560, -0.818748544278859460, +-0.818719835642280010, -0.818691124958900950, -0.818662412228793660, -0.818633697452030740, -0.818604980628683590, -0.818576261758824030, -0.818547540842523790, -0.818518817879854700, +-0.818490092870888590, -0.818461365815697170, -0.818432636714351960, -0.818403905566925550, -0.818375172373489450, -0.818346437134115370, -0.818317699848875260, -0.818288960517840840, +-0.818260219141084040, -0.818231475718676160, -0.818202730250690120, -0.818173982737197210, -0.818145233178269480, -0.818116481573978540, -0.818087727924396440, -0.818058972229595010, +-0.818030214489646190, -0.818001454704621820, -0.817972692874593290, -0.817943928999633530, -0.817915163079813930, -0.817886395115206440, -0.817857625105882890, -0.817828853051915440, +-0.817800078953375250, -0.817771302810335390, -0.817742524622867230, -0.817713744391042830, -0.817684962114934020, -0.817656177794612750, -0.817627391430151170, -0.817598603021621020, +-0.817569812569094450, -0.817541020072642730, -0.817512225532339040, -0.817483428948254760, -0.817454630320461950, -0.817425829649032430, -0.817397026934038480, -0.817368222175551940, +-0.817339415373644300, -0.817310606528388610, -0.817281795639856480, -0.817252982708119860, -0.817224167733250680, -0.817195350715321120, -0.817166531654403230, -0.817137710550569050, +-0.817108887403889980, -0.817080062214439180, -0.817051234982288380, -0.817022405707509390, -0.816993574390174390, -0.816964741030355430, -0.816935905628124680, -0.816907068183553630, +-0.816878228696715450, -0.816849387167681630, -0.816820543596524340, -0.816791697983315750, -0.816762850328127900, -0.816734000631032960, -0.816705148892102990, -0.816676295111409600, +-0.816647439289026060, -0.816618581425023860, -0.816589721519475180, -0.816560859572452280, -0.816531995584027230, -0.816503129554272070, -0.816474261483258630, -0.816445391371060090, +-0.816416519217748050, -0.816387645023394780, -0.816358768788072340, -0.816329890511852900, -0.816301010194808830, -0.816272127837012200, -0.816243243438535270, -0.816214356999449770, +-0.816185468519828870, -0.816156577999744170, -0.816127685439268170, -0.816098790838472920, -0.816069894197430590, -0.816040995516213120, -0.816012094794893670, -0.815983192033543970, +-0.815954287232236290, -0.815925380391042900, -0.815896471510036080, -0.815867560589288000, -0.815838647628871150, -0.815809732628857590, -0.815780815589319140, -0.815751896510329200, +-0.815722975391959590, -0.815694052234282490, -0.815665127037370260, -0.815636199801295200, -0.815607270526129140, -0.815578339211945450, -0.815549405858815860, -0.815520470466812860, +-0.815491533036008520, -0.815462593566475440, -0.815433652058285880, -0.815404708511512140, -0.815375762926226710, -0.815346815302501300, -0.815317865640409420, -0.815288913940022790, +-0.815259960201414000, -0.815231004424655240, -0.815202046609818880, -0.815173086756977530, -0.815144124866202910, -0.815115160937568530, -0.815086194971146210, -0.815057226967008330, +-0.815028256925227510, -0.814999284845875920, -0.814970310729026260, -0.814941334574750710, -0.814912356383121320, -0.814883376154211690, -0.814854393888093440, -0.814825409584839290, +-0.814796423244521620, -0.814767434867212930, -0.814738444452985600, -0.814709452001911580, -0.814680457514064590, -0.814651460989516350, -0.814622462428339470, -0.814593461830606440, +-0.814564459196389870, -0.814535454525762040, -0.814506447818795550, -0.814477439075562910, -0.814448428296136280, -0.814419415480589050, -0.814390400628993260, -0.814361383741421530, +-0.814332364817946240, -0.814303343858640120, -0.814274320863575100, -0.814245295832824790, -0.814216268766461250, -0.814187239664556970, -0.814158208527184680, -0.814129175354416870, +-0.814100140146326030, -0.814071102902984900, -0.814042063624466070, -0.814013022310841490, -0.813983978962184880, -0.813954933578568300, -0.813925886160064450, -0.813896836706745840, +-0.813867785218685190, -0.813838731695954550, -0.813809676138627540, -0.813780618546776410, -0.813751558920473680, -0.813722497259792070, -0.813693433564804170, -0.813664367835582710, +-0.813635300072200420, -0.813606230274729780, -0.813577158443243080, -0.813548084577814020, -0.813519008678514680, -0.813489930745417980, -0.813460850778596310, -0.813431768778122510, +-0.813402684744069290, -0.813373598676508940, -0.813344510575515050, -0.813315420441159900, -0.813286328273516100, -0.813257234072656600, -0.813228137838654000, -0.813199039571581020, +-0.813169939271510490, -0.813140836938514580, -0.813111732572667000, -0.813082626174040150, -0.813053517742706840, -0.813024407278739590, -0.812995294782211440, -0.812966180253194890, +-0.812937063691762550, -0.812907945097987920, -0.812878824471943600, -0.812849701813702090, -0.812820577123336330, -0.812791450400919160, -0.812762321646523400, -0.812733190860221780, +-0.812704058042087120, -0.812674923192191920, -0.812645786310609910, -0.812616647397413350, -0.812587506452675300, -0.812558363476468370, -0.812529218468865610, -0.812500071429939190, +-0.812470922359763150, -0.812441771258409880, -0.812412618125952110, -0.812383462962462780, -0.812354305768014820, -0.812325146542681180, -0.812295985286534570, -0.812266821999648060, +-0.812237656682093910, -0.812208489333946180, -0.812179319955277260, -0.812150148546159970, -0.812120975106667250, -0.812091799636872170, -0.812062622136847100, -0.812033442606665990, +-0.812004261046401330, -0.811975077456125850, -0.811945891835912810, -0.811916704185835060, -0.811887514505965410, -0.811858322796377040, -0.811829129057143000, -0.811799933288335440, +-0.811770735490028650, -0.811741535662295010, -0.811712333805207460, -0.811683129918839170, -0.811653924003262970, -0.811624716058552020, -0.811595506084778820, -0.811566294082017300, +-0.811537080050340090, -0.811507863989820110, -0.811478645900530430, -0.811449425782544310, -0.811420203635934480, -0.811390979460774210, -0.811361753257135890, -0.811332525025093790, +-0.811303294764720410, -0.811274062476088690, -0.811244828159271790, -0.811215591814342880, -0.811186353441375130, -0.811157113040440800, -0.811127870611614290, -0.811098626154968080, +-0.811069379670575240, -0.811040131158509040, -0.811010880618842410, -0.810981628051648640, -0.810952373457000890, -0.810923116834971540, -0.810893858185635090, -0.810864597509063810, +-0.810835334805331100, -0.810806070074510110, -0.810776803316673900, -0.810747534531895630, -0.810718263720248130, -0.810688990881805350, -0.810659716016640220, -0.810630439124825690, +-0.810601160206435130, -0.810571879261541730, -0.810542596290218520, -0.810513311292538900, -0.810484024268575910, -0.810454735218402390, -0.810425444142092610, -0.810396151039719070, +-0.810366855911355270, -0.810337558757074360, -0.810308259576949520, -0.810278958371053460, -0.810249655139460570, -0.810220349882243450, -0.810191042599475610, -0.810161733291230090, +-0.810132421957580170, -0.810103108598599240, -0.810073793214360570, -0.810044475804937440, -0.810015156370402560, -0.809985834910830320, -0.809956511426293550, -0.809927185916865410, +-0.809897858382619300, -0.809868528823628590, -0.809839197239966560, -0.809809863631706040, -0.809780527998921310, -0.809751190341685300, -0.809721850660071300, -0.809692508954152790, +-0.809663165224002830, -0.809633819469695040, -0.809604471691302670, -0.809575121888898690, -0.809545770062557350, -0.809516416212351600, -0.809487060338354820, -0.809457702440640410, +-0.809428342519281640, -0.809398980574352110, -0.809369616605924550, -0.809340250614073550, -0.809310882598871850, -0.809281512560392930, -0.809252140498710300, -0.809222766413897340, +-0.809193390306027440, -0.809164012175173970, -0.809134632021410010, -0.809105249844810030, -0.809075865645446870, -0.809046479423394030, -0.809017091178725110, -0.808987700911513400, +-0.808958308621832380, -0.808928914309755110, -0.808899517975356090, -0.808870119618708250, -0.808840719239885100, -0.808811316838960240, -0.808781912416006940, -0.808752505971099040, +-0.808723097504309710, -0.808693687015712760, -0.808664274505381030, -0.808634859973389130, -0.808605443419810000, -0.808576024844717360, -0.808546604248184700, -0.808517181630285410, +-0.808487756991092650, -0.808458330330681150, -0.808428901649123730, -0.808399470946494000, -0.808370038222865680, -0.808340603478312270, -0.808311166712907370, -0.808281727926724480, +-0.808252287119837320, -0.808222844292318940, -0.808193399444243840, -0.808163952575685410, -0.808134503686717020, -0.808105052777412400, -0.808075599847845050, -0.808046144898088790, +-0.808016687928216680, -0.807987228938303330, -0.807957767928421890, -0.807928304898646090, -0.807898839849049420, -0.807869372779705720, -0.807839903690688590, -0.807810432582071640, +-0.807780959453928250, -0.807751484306332810, -0.807722007139358710, -0.807692527953079660, -0.807663046747569170, -0.807633563522901170, -0.807604078279149150, -0.807574591016386510, +-0.807545101734687960, -0.807515610434126560, -0.807486117114776140, -0.807456621776710400, -0.807427124420003190, -0.807397625044728120, -0.807368123650959000, -0.807338620238769120, +-0.807309114808233090, -0.807279607359424390, -0.807250097892416530, -0.807220586407283560, -0.807191072904098970, -0.807161557382936820, -0.807132039843870270, -0.807102520286974160, +-0.807072998712321630, -0.807043475119986640, -0.807013949510043020, -0.806984421882564470, -0.806954892237624950, -0.806925360575298070, -0.806895826895657860, -0.806866291198777620, +-0.806836753484732050, -0.806807213753594770, -0.806777672005439260, -0.806748128240339700, -0.806718582458369800, -0.806689034659602840, -0.806659484844113870, -0.806629933011976270, +-0.806600379163263770, -0.806570823298050300, -0.806541265416409690, -0.806511705518416110, -0.806482143604143160, -0.806452579673664790, -0.806423013727054610, -0.806393445764387320, +-0.806363875785736430, -0.806334303791175770, -0.806304729780779490, -0.806275153754621330, -0.806245575712775220, -0.806215995655314770, -0.806186413582314800, -0.806156829493848810, +-0.806127243389990640, -0.806097655270814450, -0.806068065136394170, -0.806038472986803640, -0.806008878822117030, -0.805979282642407590, -0.805949684447750500, -0.805920084238219260, +-0.805890482013887690, -0.805860877774830060, -0.805831271521120110, -0.805801663252832090, -0.805772052970039290, -0.805742440672816970, -0.805712826361238420, -0.805683210035377910, +-0.805653591695309370, -0.805623971341106860, -0.805594348972844430, -0.805564724590596030, -0.805535098194435360, -0.805505469784437490, -0.805475839360675900, -0.805446206923224770, +-0.805416572472158030, -0.805386936007549960, -0.805357297529474490, -0.805327657038005350, -0.805298014533217480, -0.805268370015184590, -0.805238723483980840, -0.805209074939680190, +-0.805179424382356900, -0.805149771812085020, -0.805120117228938730, -0.805090460632992170, -0.805060802024318960, -0.805031141402994250, -0.805001478769091670, -0.804971814122685370, +-0.804942147463849510, -0.804912478792658370, -0.804882808109185440, -0.804853135413506000, -0.804823460705693880, -0.804793783985822910, -0.804764105253967580, -0.804734424510201940, +-0.804704741754600270, -0.804675056987236740, -0.804645370208185610, -0.804615681417520490, -0.804585990615316660, -0.804556297801647950, -0.804526602976588400, -0.804496906140212410, +-0.804467207292594130, -0.804437506433807850, -0.804407803563927160, -0.804378098683027560, -0.804348391791182780, -0.804318682888466970, -0.804288971974954530, -0.804259259050719490, +-0.804229544115836470, -0.804199827170379520, -0.804170108214422470, -0.804140387248040710, -0.804110664271307950, -0.804080939284298470, -0.804051212287086760, -0.804021483279746980, +-0.803991752262353420, -0.803962019234980010, -0.803932284197702130, -0.803902547150593500, -0.803872808093728410, -0.803843067027181450, -0.803813323951026780, -0.803783578865338690, +-0.803753831770191770, -0.803724082665659760, -0.803694331551818020, -0.803664578428740390, -0.803634823296501380, -0.803605066155175350, -0.803575307004836590, -0.803545545845559590, +-0.803515782677418300, -0.803486017500487870, -0.803456250314842580, -0.803426481120556590, -0.803396709917704400, -0.803366936706360390, -0.803337161486599170, -0.803307384258494910, +-0.803277605022122200, -0.803247823777555100, -0.803218040524868780, -0.803188255264137400, -0.803158467995435440, -0.803128678718837310, -0.803098887434417490, -0.803069094142249920, +-0.803039298842410100, -0.803009501534972080, -0.802979702220010250, -0.802949900897599210, -0.802920097567813460, -0.802890292230727390, -0.802860484886415590, -0.802830675534952580, +-0.802800864176412390, -0.802771050810870520, -0.802741235438401040, -0.802711418059078530, -0.802681598672977390, -0.802651777280172340, -0.802621953880737760, -0.802592128474747810, +-0.802562301062278110, -0.802532471643402580, -0.802502640218195950, -0.802472806786732720, -0.802442971349087380, -0.802413133905334640, -0.802383294455549120, -0.802353452999804760, +-0.802323609538177380, -0.802293764070740930, -0.802263916597570130, -0.802234067118739460, -0.802204215634323650, -0.802174362144397300, -0.802144506649034470, -0.802114649148310990, +-0.802084789642300790, -0.802054928131078700, -0.802025064614719340, -0.801995199093297200, -0.801965331566887100, -0.801935462035563650, -0.801905590499401020, -0.801875716958475040, +-0.801845841412859640, -0.801815963862629650, -0.801786084307859800, -0.801756202748624800, -0.801726319184999260, -0.801696433617057340, -0.801666546044874860, -0.801636656468526000, +-0.801606764888085580, -0.801576871303628200, -0.801546975715228700, -0.801517078122961690, -0.801487178526901990, -0.801457276927124320, -0.801427373323702950, -0.801397467716713720, +-0.801367560106230780, -0.801337650492328970, -0.801307738875083000, -0.801277825254567700, -0.801247909630857350, -0.801217992004027660, -0.801188072374153130, -0.801158150741308250, +-0.801128227105568080, -0.801098301467007450, -0.801068373825700950, -0.801038444181723430, -0.801008512535149930, -0.800978578886054620, -0.800948643234513310, -0.800918705580600410, +-0.800888765924390840, -0.800858824265959330, -0.800828880605380710, -0.800798934942729800, -0.800768987278081210, -0.800739037611510550, -0.800709085943092310, -0.800679132272901440, +-0.800649176601012650, -0.800619218927500990, -0.800589259252441290, -0.800559297575908380, -0.800529333897976650, -0.800499368218722250, -0.800469400538219360, -0.800439430856543010, +-0.800409459173768050, -0.800379485489969400, -0.800349509805222010, -0.800319532119600390, -0.800289552433180450, -0.800259570746036710, -0.800229587058243990, -0.800199601369877220, +-0.800169613681011470, -0.800139623991721780, -0.800109632302082980, -0.800079638612169570, -0.800049642922057600, -0.800019645231821560, -0.799989645541536290, -0.799959643851277050, +-0.799929640161118670, -0.799899634471136100, -0.799869626781403940, -0.799839617091998250, -0.799809605402993620, -0.799779591714464890, -0.799749576026487110, -0.799719558339135550, +-0.799689538652484930, -0.799659516966610530, -0.799629493281587390, -0.799599467597489900, -0.799569439914394330, -0.799539410232375180, -0.799509378551507500, -0.799479344871866340, +-0.799449309193526860, -0.799419271516563560, -0.799389231841052590, -0.799359190167068470, -0.799329146494686450, -0.799299100823981590, -0.799269053155028940, -0.799239003487903670, +-0.799208951822680920, -0.799178898159435770, -0.799148842498242810, -0.799118784839178310, -0.799088725182316880, -0.799058663527733580, -0.799028599875503680, -0.798998534225702220, +-0.798968466578403920, -0.798938396933684960, -0.798908325291620040, -0.798878251652284320, -0.798848176015752980, -0.798818098382101160, -0.798788018751404040, -0.798757937123736990, +-0.798727853499175080, -0.798697767877792900, -0.798667680259666950, -0.798637590644871720, -0.798607499033482600, -0.798577405425574650, -0.798547309821223240, -0.798517212220503540, +-0.798487112623490260, -0.798457011030259680, -0.798426907440886620, -0.798396801855446370, -0.798366694274013970, -0.798336584696664910, -0.798306473123474470, -0.798276359554517700, +-0.798246243989869650, -0.798216126429606380, -0.798186006873802920, -0.798155885322534340, -0.798125761775876130, -0.798095636233903450, -0.798065508696691680, -0.798035379164315660, +-0.798005247636851660, -0.797975114114374610, -0.797944978596959680, -0.797914841084682360, -0.797884701577618040, -0.797854560075841770, -0.797824416579429260, -0.797794271088455690, +-0.797764123602995760, -0.797733974123126190, -0.797703822648921700, -0.797673669180457570, -0.797643513717809280, -0.797613356261052340, -0.797583196810261350, -0.797553035365512920, +-0.797522871926881870, -0.797492706494443700, -0.797462539068273690, -0.797432369648447440, -0.797402198235040220, -0.797372024828127410, -0.797341849427784630, -0.797311672034086700, +-0.797281492647110120, -0.797251311266929830, -0.797221127893621210, -0.797190942527259860, -0.797160755167921060, -0.797130565815679870, -0.797100374470612770, -0.797070181132794710, +-0.797039985802301290, -0.797009788479207890, -0.796979589163589910, -0.796949387855523160, -0.796919184555082700, -0.796888979262344480, -0.796858771977383200, -0.796828562700275470, +-0.796798351431096450, -0.796768138169921420, -0.796737922916826100, -0.796707705671885980, -0.796677486435176660, -0.796647265206772980, -0.796617041986751760, -0.796586816775187940, +-0.796556589572157030, -0.796526360377734610, -0.796496129191996300, -0.796465896015017720, -0.796435660846874340, -0.796405423687641330, -0.796375184537395310, -0.796344943396211310, +-0.796314700264164950, -0.796284455141331840, -0.796254208027787570, -0.796223958923607760, -0.796193707828867560, -0.796163454743643690, -0.796133199668011100, -0.796102942602045500, +-0.796072683545822500, -0.796042422499417920, -0.796012159462907260, -0.795981894436366130, -0.795951627419870240, -0.795921358413494870, -0.795891087417316510, -0.795860814431410550, +-0.795830539455852470, -0.795800262490718110, -0.795769983536083080, -0.795739702592022540, -0.795709419658613190, -0.795679134735930440, -0.795648847824049770, -0.795618558923047000, +-0.795588268032997760, -0.795557975153977970, -0.795527680286063130, -0.795497383429329190, -0.795467084583851290, -0.795436783749706060, -0.795406480926968970, -0.795376176115715650, +-0.795345869316021910, -0.795315560527963480, -0.795285249751615630, -0.795254936987055180, -0.795224622234357410, -0.795194305493598150, -0.795163986764853000, -0.795133666048197910, +-0.795103343343708690, -0.795073018651461070, -0.795042691971530990, -0.795012363303993610, -0.794982032648925750, -0.794951700006402920, -0.794921365376500820, -0.794891028759295290, +-0.794860690154862160, -0.794830349563277360, -0.794800006984616170, -0.794769662418955410, -0.794739315866370590, -0.794708967326937410, -0.794678616800731820, -0.794648264287829750, +-0.794617909788306930, -0.794587553302239400, -0.794557194829702440, -0.794526834370772980, -0.794496471925526530, -0.794466107494038900, -0.794435741076385930, -0.794405372672643550, +-0.794375002282887820, -0.794344629907194120, -0.794314255545639280, -0.794283879198298790, -0.794253500865248710, -0.794223120546564740, -0.794192738242323060, -0.794162353952599490, +-0.794131967677470070, -0.794101579417010760, -0.794071189171296930, -0.794040796940405640, -0.794010402724412370, -0.793980006523393070, -0.793949608337423780, -0.793919208166580570, +-0.793888806010938700, -0.793858401870575330, -0.793827995745565950, -0.793797587635986620, -0.793767177541913280, -0.793736765463422090, -0.793706351400588870, -0.793675935353489900, +-0.793645517322201010, -0.793615097306797800, -0.793584675307357430, -0.793554251323955300, -0.793523825356667540, -0.793493397405570230, -0.793462967470739520, -0.793432535552250790, +-0.793402101650181210, -0.793371665764606380, -0.793341227895602460, -0.793310788043245510, -0.793280346207611450, -0.793249902388776570, -0.793219456586817030, -0.793189008801808760, +-0.793158559033827370, -0.793128107282950250, -0.793097653549252770, -0.793067197832811210, -0.793036740133701620, -0.793006280452000170, -0.792975818787783120, -0.792945355141125850, +-0.792914889512105870, -0.792884421900798550, -0.792853952307280290, -0.792823480731627010, -0.792793007173915100, -0.792762531634220720, -0.792732054112619930, -0.792701574609188440, +-0.792671093124003630, -0.792640609657141120, -0.792610124208676940, -0.792579636778687590, -0.792549147367249130, -0.792518655974437710, -0.792488162600329170, -0.792457667245000770, +-0.792427169908528240, -0.792396670590987730, -0.792366169292455510, -0.792335666013007980, -0.792305160752721170, -0.792274653511671590, -0.792244144289934730, -0.792213633087588080, +-0.792183119904707360, -0.792152604741368730, -0.792122087597648680, -0.792091568473623500, -0.792061047369369220, -0.792030524284961900, -0.791999999220478810, -0.791969472175995670, +-0.791938943151588860, -0.791908412147334760, -0.791877879163309650, -0.791847344199589690, -0.791816807256251480, -0.791786268333371180, -0.791755727431024740, -0.791725184549289530, +-0.791694639688241280, -0.791664092847956470, -0.791633544028511490, -0.791602993229982620, -0.791572440452445680, -0.791541885695978160, -0.791511328960656010, -0.791480770246555500, +-0.791450209553753000, -0.791419646882325020, -0.791389082232347940, -0.791358515603898250, -0.791327946997052110, -0.791297376411885580, -0.791266803848476250, -0.791236229306899850, +-0.791205652787232870, -0.791175074289551810, -0.791144493813933040, -0.791113911360453060, -0.791083326929187700, -0.791052740520214570, -0.791022152133609600, -0.790991561769449290, +-0.790960969427810020, -0.790930375108768400, -0.790899778812400810, -0.790869180538783740, -0.790838580287993140, -0.790807978060106720, -0.790777373855200310, -0.790746767673350500, +-0.790716159514633700, -0.790685549379126610, -0.790654937266905500, -0.790624323178046650, -0.790593707112627440, -0.790563089070724030, -0.790532469052412920, -0.790501847057770490, +-0.790471223086873560, -0.790440597139798640, -0.790409969216622100, -0.790379339317420100, -0.790348707442270370, -0.790318073591248840, -0.790287437764432110, -0.790256799961896790, +-0.790226160183719490, -0.790195518429976710, -0.790164874700744700, -0.790134228996100970, -0.790103581316121680, -0.790072931660883440, -0.790042280030462950, -0.790011626424936720, +-0.789980970844381350, -0.789950313288873660, -0.789919653758490050, -0.789888992253306890, -0.789858328773401790, -0.789827663318850790, -0.789796995889730620, -0.789766326486118110, +-0.789735655108089630, -0.789704981755721570, -0.789674306429091530, -0.789643629128275680, -0.789612949853350840, -0.789582268604393620, -0.789551585381480740, -0.789520900184688900, +-0.789490213014094720, -0.789459523869775140, -0.789428832751806090, -0.789398139660265620, -0.789367444595229670, -0.789336747556775190, -0.789306048544978880, -0.789275347559917350, +-0.789244644601667540, -0.789213939670305510, -0.789183232765909180, -0.789152523888554840, -0.789121813038319080, -0.789091100215278840, -0.789060385419510850, -0.789029668651091920, +-0.788998949910098780, -0.788968229196607810, -0.788937506510696720, -0.788906781852441900, -0.788876055221920060, -0.788845326619208140, -0.788814596044382870, -0.788783863497521160, +-0.788753128978699200, -0.788722392487995030, -0.788691654025484800, -0.788660913591245460, -0.788630171185353830, -0.788599426807886860, -0.788568680458921260, -0.788537932138533960, +-0.788507181846801240, -0.788476429583801150, -0.788445675349609960, -0.788414919144304620, -0.788384160967962040, -0.788353400820658970, -0.788322638702472430, -0.788291874613478720, +-0.788261108553755860, -0.788230340523380260, -0.788199570522428840, -0.788168798550978430, -0.788138024609106090, -0.788107248696888640, -0.788076470814403020, -0.788045690961726280, +-0.788014909138934790, -0.787984125346106510, -0.787953339583318040, -0.787922551850646080, -0.787891762148167810, -0.787860970475960150, -0.787830176834099500, -0.787799381222663910, +-0.787768583641729970, -0.787737784091374520, -0.787706982571674600, -0.787676179082707150, -0.787645373624549340, -0.787614566197278100, -0.787583756800970370, -0.787552945435702870, +-0.787522132101553420, -0.787491316798598630, -0.787460499526915550, -0.787429680286581220, -0.787398859077672820, -0.787368035900267160, -0.787337210754440850, -0.787306383640272060, +-0.787275554557837380, -0.787244723507213750, -0.787213890488478340, -0.787183055501708200, -0.787152218546980360, -0.787121379624372120, -0.787090538733959840, -0.787059695875821700, +-0.787028851050034280, -0.786998004256674880, -0.786967155495820300, -0.786936304767547950, -0.786905452071934740, -0.786874597409057520, -0.786843740778994220, -0.786812882181821550, +-0.786782021617616790, -0.786751159086456870, -0.786720294588419080, -0.786689428123580560, -0.786658559692018480, -0.786627689293809440, -0.786596816929031830, -0.786565942597762020, +-0.786535066300077410, -0.786504188036055150, -0.786473307805772400, -0.786442425609306440, -0.786411541446733750, -0.786380655318132840, -0.786349767223580300, -0.786318877163153300, +-0.786287985136929100, -0.786257091144984990, -0.786226195187398110, -0.786195297264245860, -0.786164397375605170, -0.786133495521553090, -0.786102591702167790, -0.786071685917525960, +-0.786040778167705010, -0.786009868452781980, -0.785978956772834360, -0.785948043127938760, -0.785917127518173660, -0.785886209943615690, -0.785855290404342210, -0.785824368900430500, +-0.785793445431957950, -0.785762519999001710, -0.785731592601639160, -0.785700663239947580, -0.785669731914003910, -0.785638798623886410, -0.785607863369671920, -0.785576926151437700, +-0.785545986969261260, -0.785515045823219850, -0.785484102713390750, -0.785453157639850910, -0.785422210602678690, -0.785391261601951050, -0.785360310637745140, -0.785329357710138450, +-0.785298402819208490, -0.785267445965032400, -0.785236487147687680, -0.785205526367251270, -0.785174563623801560, -0.785143598917415480, -0.785112632248170290, -0.785081663616143620, +-0.785050693021412730, -0.785019720464055220, -0.784988745944147800, -0.784957769461768980, -0.784926791016995810, -0.784895810609905650, -0.784864828240576020, -0.784833843909084280, +-0.784802857615507940, -0.784771869359924380, -0.784740879142410640, -0.784709886963045330, -0.784678892821905280, -0.784647896719067980, -0.784616898654610820, -0.784585898628611610, +-0.784554896641147530, -0.784523892692295720, -0.784492886782134690, -0.784461878910741480, -0.784430869078193480, -0.784399857284568400, -0.784368843529943630, -0.784337827814396760, +-0.784306810138005290, -0.784275790500846840, -0.784244768902998430, -0.784213745344538580, -0.784182719825544330, -0.784151692346093280, -0.784120662906263030, -0.784089631506131200, +-0.784058598145774610, -0.784027562825272200, -0.783996525544700780, -0.783965486304138090, -0.783934445103661730, -0.783903401943349180, -0.783872356823278160, -0.783841309743526170, +-0.783810260704171040, -0.783779209705289580, -0.783748156746960740, -0.783717101829261580, -0.783686044952269570, -0.783654986116062440, -0.783623925320717780, -0.783592862566313440, +-0.783561797852926230, -0.783530731180635210, -0.783499662549517310, -0.783468591959650350, -0.783437519411111840, -0.783406444903979480, -0.783375368438331110, -0.783344290014244220, +-0.783313209631796070, -0.783282127291065500, -0.783251042992129550, -0.783219956735066060, -0.783188868519952620, -0.783157778346867060, -0.783126686215886990, -0.783095592127089790, +-0.783064496080554060, -0.783033398076357080, -0.783002298114576560, -0.782971196195290430, -0.782940092318576200, -0.782908986484511790, -0.782877878693174930, -0.782846768944642780, +-0.782815657238994270, -0.782784543576306670, -0.782753427956657590, -0.782722310380125070, -0.782691190846786730, -0.782660069356720390, -0.782628945910003320, -0.782597820506714450, +-0.782566693146931060, -0.782535563830730860, -0.782504432558191800, -0.782473299329391690, -0.782442164144408260, -0.782411027003319440, -0.782379887906203160, -0.782348746853136490, +-0.782317603844198570, -0.782286458879466570, -0.782255311959018430, -0.782224163082932080, -0.782193012251285350, -0.782161859464155400, -0.782130704721621490, -0.782099548023760690, +-0.782068389370651150, -0.782037228762370470, -0.782006066198996930, -0.781974901680608010, -0.781943735207282000, -0.781912566779096600, -0.781881396396129190, -0.781850224058458940, +-0.781819049766163010, -0.781787873519319550, -0.781756695318006400, -0.781725515162301490, -0.781694333052282750, -0.781663148988027690, -0.781631962969615230, -0.781600774997122880, +-0.781569585070628680, -0.781538393190210460, -0.781507199355946260, -0.781476003567914130, -0.781444805826191800, -0.781413606130857090, -0.781382404481988810, -0.781351200879664590, +-0.781319995323962350, -0.781288787814960140, -0.781257578352735900, -0.781226366937367800, -0.781195153568933210, -0.781163938247511180, -0.781132720973179430, -0.781101501746015890, +-0.781070280566098510, -0.781039057433505430, -0.781007832348314720, -0.780976605310604530, -0.780945376320452130, -0.780914145377936910, -0.780882912483136350, -0.780851677636128510, +-0.780820440836991430, -0.780789202085803270, -0.780757961382642090, -0.780726718727585480, -0.780695474120712610, -0.780664227562100970, -0.780632979051828820, -0.780601728589974340, +-0.780570476176615460, -0.780539221811830330, -0.780507965495697230, -0.780476707228294100, -0.780445447009698760, -0.780414184839990370, -0.780382920719246420, -0.780351654647545300, +-0.780320386624964950, -0.780289116651583630, -0.780257844727478940, -0.780226570852730280, -0.780195295027415140, -0.780164017251611770, -0.780132737525398360, -0.780101455848853150, +-0.780070172222054210, -0.780038886645079920, -0.780007599118008320, -0.779976309640917240, -0.779945018213885950, -0.779913724836992060, -0.779882429510313950, -0.779851132233929660, +-0.779819833007917570, -0.779788531832355410, -0.779757228707322450, -0.779725923632896390, -0.779694616609155510, -0.779663307636178080, -0.779631996714042490, -0.779600683842826770, +-0.779569369022609430, -0.779538052253468620, -0.779506733535482170, -0.779475412868729340, -0.779444090253288090, -0.779412765689236560, -0.779381439176653150, -0.779350110715616110, +-0.779318780306203830, -0.779287447948494030, -0.779256113642566190, -0.779224777388497940, -0.779193439186367850, -0.779162099036254220, -0.779130756938235300, -0.779099412892389380, +-0.779068066898795040, -0.779036718957530020, -0.779005369068673680, -0.778974017232303860, -0.778942663448499050, -0.778911307717337630, -0.778879950038897870, -0.778848590413258270, +-0.778817228840496640, -0.778785865320692490, -0.778754499853923750, -0.778723132440268690, -0.778691763079805810, -0.778660391772613480, -0.778629018518770200, -0.778597643318354460, +-0.778566266171444420, -0.778534887078118350, -0.778503506038455530, -0.778472123052533990, -0.778440738120432020, -0.778409351242228320, -0.778377962418001280, -0.778346571647828610, +-0.778315178931790250, -0.778283784269963810, -0.778252387662427990, -0.778220989109261190, -0.778189588610541880, -0.778158186166348690, -0.778126781776759870, -0.778095375441854250, +-0.778063967161709560, -0.778032556936405490, -0.778001144766020110, -0.777969730650631800, -0.777938314590319150, -0.777906896585160770, -0.777875476635234600, -0.777844054740620240, +-0.777812630901395850, -0.777781205117639820, -0.777749777389430740, -0.777718347716847220, -0.777686916099967870, -0.777655482538871180, -0.777624047033635860, -0.777592609584339840, +-0.777561170191062740, -0.777529728853882830, -0.777498285572878590, -0.777466840348128630, -0.777435393179711550, -0.777403944067706080, -0.777372493012190020, -0.777341040013243450, +-0.777309585070944160, -0.777278128185371010, -0.777246669356602470, -0.777215208584717270, -0.777183745869794000, -0.777152281211911490, -0.777120814611147680, -0.777089346067582290, +-0.777057875581293580, -0.777026403152360270, -0.776994928780860850, -0.776963452466874150, -0.776931974210478880, -0.776900494011752980, -0.776869011870776500, -0.776837527787627490, +-0.776806041762384660, -0.776774553795126720, -0.776743063885932280, -0.776711572034880280, -0.776680078242049430, -0.776648582507518340, -0.776617084831365160, -0.776585585213669830, +-0.776554083654510620, -0.776522580153966140, -0.776491074712115200, -0.776459567329036650, -0.776428058004808520, -0.776396546739510860, -0.776365033533221840, -0.776333518386020270, +-0.776302001297984880, -0.776270482269194480, -0.776238961299727800, -0.776207438389663770, -0.776175913539081220, -0.776144386748058190, -0.776112858016674840, -0.776081327345009340, +-0.776049794733140510, -0.776018260181147280, -0.775986723689108260, -0.775955185257101940, -0.775923644885208260, -0.775892102573505380, -0.775860558322072240, -0.775829012130987760, +-0.775797464000330780, -0.775765913930180020, -0.775734361920614620, -0.775702807971713200, -0.775671252083554250, -0.775639694256217820, -0.775608134489782050, -0.775576572784325900, +-0.775545009139928410, -0.775513443556668290, -0.775481876034624710, -0.775450306573875700, -0.775418735174501660, -0.775387161836580740, -0.775355586560191880, -0.775324009345414010, +-0.775292430192326190, -0.775260849101007230, -0.775229266071536190, -0.775197681103991450, -0.775166094198453060, -0.775134505354999390, -0.775102914573709500, -0.775071321854662320, +-0.775039727197936790, -0.775008130603611960, -0.774976532071766310, -0.774944931602479790, -0.774913329195831000, -0.774881724851898880, -0.774850118570762470, -0.774818510352500710, +-0.774786900197192760, -0.774755288104917560, -0.774723674075753490, -0.774692058109780810, -0.774660440207078030, -0.774628820367724070, -0.774597198591798100, -0.774565574879379160, +-0.774533949230546300, -0.774502321645378020, -0.774470692123954470, -0.774439060666354150, -0.774407427272656210, -0.774375791942939710, -0.774344154677283680, -0.774312515475767290, +-0.774280874338469590, -0.774249231265469740, -0.774217586256846340, -0.774185939312679430, -0.774154290433047620, -0.774122639618030180, -0.774090986867706050, -0.774059332182154610, +-0.774027675561454130, -0.773996017005685100, -0.773964356514926010, -0.773932694089256020, -0.773901029728754300, -0.773869363433499990, -0.773837695203572260, -0.773806025039050380, +-0.773774352940013400, -0.773742678906539920, -0.773711002938710310, -0.773679325036603190, -0.773647645200297830, -0.773615963429873380, -0.773584279725408890, -0.773552594086983850, +-0.773520906514676640, -0.773489217008567760, -0.773457525568735820, -0.773425832195260180, -0.773394136888219790, -0.773362439647694130, -0.773330740473762380, -0.773299039366503790, +-0.773267336325997090, -0.773235631352322540, -0.773203924445558850, -0.773172215605785530, -0.773140504833081500, -0.773108792127526370, -0.773077077489199070, -0.773045360918178660, +-0.773013642414545290, -0.772981921978377890, -0.772950199609755750, -0.772918475308758010, -0.772886749075464060, -0.772855020909953390, -0.772823290812305050, -0.772791558782597980, +-0.772759824820912430, -0.772728088927327470, -0.772696351101922250, -0.772664611344776150, -0.772632869655968560, -0.772601126035578730, -0.772569380483685510, -0.772537633000369480, +-0.772505883585709260, -0.772474132239784450, -0.772442378962674200, -0.772410623754458130, -0.772378866615215380, -0.772347107545025560, -0.772315346543967940, -0.772283583612121350, +-0.772251818749566390, -0.772220051956381880, -0.772188283232647210, -0.772156512578441870, -0.772124739993845230, -0.772092965478936240, -0.772061189033795390, -0.772029410658501500, +-0.771997630353134180, -0.771965848117772690, -0.771934063952496640, -0.771902277857385410, -0.771870489832518380, -0.771838699877975270, -0.771806907993834780, -0.771775114180177630, +-0.771743318437082660, -0.771711520764629340, -0.771679721162897290, -0.771647919631966000, -0.771616116171914830, -0.771584310782822860, -0.771552503464770560, -0.771520694217837090, +-0.771488883042101840, -0.771457069937644400, -0.771425254904544390, -0.771393437942881070, -0.771361619052734260, -0.771329798234182800, -0.771297975487307500, -0.771266150812187190, +-0.771234324208901480, -0.771202495677529960, -0.771170665218152250, -0.771138832830847830, -0.771106998515695750, -0.771075162272776840, -0.771043324102169910, -0.771011484003954690, +-0.770979641978210780, -0.770947798025017780, -0.770915952144455300, -0.770884104336602930, -0.770852254601539720, -0.770820402939346390, -0.770788549350102100, -0.770756693833886450, +-0.770724836390779040, -0.770692977020859590, -0.770661115724207700, -0.770629252500902420, -0.770597387351024570, -0.770565520274653190, -0.770533651271868130, -0.770501780342748850, +-0.770469907487375210, -0.770438032705826780, -0.770406155998183180, -0.770374277364524240, -0.770342396804929000, -0.770310514319478390, -0.770278629908251580, -0.770246743571328050, +-0.770214855308787750, -0.770182965120710270, -0.770151073007174780, -0.770119178968262210, -0.770087283004051710, -0.770055385114623010, -0.770023485300055820, -0.769991583560429960, +-0.769959679895825030, -0.769927774306321090, -0.769895866791997510, -0.769863957352933780, -0.769832045989210730, -0.769800132700907640, -0.769768217488104090, -0.769736300350880030, +-0.769704381289315290, -0.769672460303489570, -0.769640537393482040, -0.769608612559373850, -0.769576685801244050, -0.769544757119172580, -0.769512826513239270, -0.769480893983523820, +-0.769448959530106170, -0.769417023153066040, -0.769385084852482800, -0.769353144628437510, -0.769321202481009330, -0.769289258410278070, -0.769257312416323780, -0.769225364499226070, +-0.769193414659065100, -0.769161462895919910, -0.769129509209871660, -0.769097553600999630, -0.769065596069383740, -0.769033636615103930, -0.769001675238239920, -0.768969711938871760, +-0.768937746717079370, -0.768905779572941930, -0.768873810506540690, -0.768841839517954930, -0.768809866607264470, -0.768777891774549470, -0.768745915019889760, -0.768713936343365160, +-0.768681955745055160, -0.768649973225040920, -0.768617988783401710, -0.768586002420217460, -0.768554014135568230, -0.768522023929534060, -0.768490031802194770, -0.768458037753630310, +-0.768426041783920820, -0.768394043893145700, -0.768362044081386090, -0.768330042348721260, -0.768298038695231390, -0.768266033120996390, -0.768234025626096330, -0.768202016210610570, +-0.768170004874620390, -0.768137991618205170, -0.768105976441445070, -0.768073959344419910, -0.768041940327209960, -0.768009919389895050, -0.767977896532555440, -0.767945871755270960, +-0.767913845058121320, -0.767881816441187690, -0.767849785904549440, -0.767817753448286730, -0.767785719072479610, -0.767753682777208240, -0.767721644562552760, -0.767689604428592460, +-0.767657562375408720, -0.767625518403081130, -0.767593472511689750, -0.767561424701314610, -0.767529374972035990, -0.767497323323933940, -0.767465269757088510, -0.767433214271579400, +-0.767401156867487780, -0.767369097544893240, -0.767337036303876060, -0.767304973144516180, -0.767272908066893970, -0.767240841071089360, -0.767208772157182190, -0.767176701325253620, +-0.767144628575383350, -0.767112553907651430, -0.767080477322138130, -0.767048398818923730, -0.767016318398088260, -0.766984236059712000, -0.766952151803874550, -0.766920065630657400, +-0.766887977540139930, -0.766855887532402640, -0.766823795607525560, -0.766791701765589080, -0.766759606006673260, -0.766727508330857900, -0.766695408738224280, -0.766663307228852230, +-0.766631203802821790, -0.766599098460213460, -0.766566991201107380, -0.766534882025583730, -0.766502770933722990, -0.766470657925605200, -0.766438543001310310, -0.766406426160919580, +-0.766374307404512730, -0.766342186732170140, -0.766310064143972180, -0.766277939639998910, -0.766245813220330360, -0.766213684885047820, -0.766181554634230990, -0.766149422467960360, +-0.766117288386316100, -0.766085152389378690, -0.766053014477228290, -0.766020874649945500, -0.765988732907610380, -0.765956589250302970, -0.765924443678104530, -0.765892296191095110, +-0.765860146789354880, -0.765827995472964320, -0.765795842242003810, -0.765763687096553620, -0.765731530036693700, -0.765699371062505520, -0.765667210174068800, -0.765635047371464150, +-0.765602882654771940, -0.765570716024072450, -0.765538547479446160, -0.765506377020973570, -0.765474204648734390, -0.765442030362810220, -0.765409854163281110, -0.765377676050227330, +-0.765345496023729370, -0.765313314083867600, -0.765281130230722530, -0.765248944464374190, -0.765216756784903970, -0.765184567192391810, -0.765152375686918300, -0.765120182268563930, +-0.765087986937408980, -0.765055789693534050, -0.765023590537019740, -0.764991389467945870, -0.764959186486394050, -0.764926981592444320, -0.764894774786177070, -0.764862566067672890, +-0.764830355437012390, -0.764798142894275950, -0.764765928439543500, -0.764733712072896870, -0.764701493794415990, -0.764669273604181350, -0.764637051502273460, -0.764604827488773010, +-0.764572601563760500, -0.764540373727316420, -0.764508143979521490, -0.764475912320455640, -0.764443678750200470, -0.764411443268836250, -0.764379205876443260, -0.764346966573102420, +-0.764314725358894000, -0.764282482233898270, -0.764250237198196960, -0.764217990251869980, -0.764185741394998060, -0.764153490627661800, -0.764121237949941800, -0.764088983361918660, +-0.764056726863673100, -0.764024468455285710, -0.763992208136836660, -0.763959945908407550, -0.763927681770078640, -0.763895415721930540, -0.763863147764043850, -0.763830877896499280, +-0.763798606119377550, -0.763766332432758710, -0.763734056836724680, -0.763701779331355410, -0.763669499916731830, -0.763637218592934320, -0.763604935360043920, -0.763572650218141140, +-0.763540363167306670, -0.763508074207620790, -0.763475783339165210, -0.763443490562020210, -0.763411195876266600, -0.763378899281984880, -0.763346600779255870, -0.763314300368160500, +-0.763281998048778720, -0.763249693821192570, -0.763217387685482080, -0.763185079641728210, -0.763152769690011560, -0.763120457830413050, -0.763088144063013400, -0.763055828387893430, +-0.763023510805133200, -0.762991191314814850, -0.762958869917018560, -0.762926546611825020, -0.762894221399315060, -0.762861894279569630, -0.762829565252669540, -0.762797234318694840, +-0.762764901477727690, -0.762732566729848240, -0.762700230075137430, -0.762667891513675980, -0.762635551045544810, -0.762603208670824760, -0.762570864389596760, -0.762538518201941630, +-0.762506170107939530, -0.762473820107672620, -0.762441468201221160, -0.762409114388665990, -0.762376758670088030, -0.762344401045568220, -0.762312041515186830, -0.762279680079025910, +-0.762247316737165730, -0.762214951489687320, -0.762182584336671520, -0.762150215278199260, -0.762117844314351480, -0.762085471445209110, -0.762053096670852970, -0.762020719991363560, +-0.761988341406822920, -0.761955960917311440, -0.761923578522910150, -0.761891194223699770, -0.761858808019761470, -0.761826419911175500, -0.761794029898024140, -0.761761637980387650, +-0.761729244158347200, -0.761696848431983490, -0.761664450801377680, -0.761632051266610820, -0.761599649827763740, -0.761567246484917580, -0.761534841238152740, -0.761502434087551360, +-0.761470025033193940, -0.761437614075161310, -0.761405201213534830, -0.761372786448395230, -0.761340369779823670, -0.761307951207900620, -0.761275530732708370, -0.761243108354327180, +-0.761210684072838320, -0.761178257888322610, -0.761145829800861320, -0.761113399810535500, -0.761080967917426190, -0.761048534121613770, -0.761016098423180630, -0.760983660822207360, +-0.760951221318774800, -0.760918779912964300, -0.760886336604856720, -0.760853891394533410, -0.760821444282074770, -0.760788995267563050, -0.760756544351078870, -0.760724091532703370, +-0.760691636812517610, -0.760659180190602750, -0.760626721667039930, -0.760594261241910320, -0.760561798915295070, -0.760529334687274680, -0.760496868557931640, -0.760464400527346320, +-0.760431930595600100, -0.760399458762773930, -0.760366985028949280, -0.760334509394206440, -0.760302031858627990, -0.760269552422294440, -0.760237071085286930, -0.760204587847686850, +-0.760172102709575250, -0.760139615671033500, -0.760107126732142650, -0.760074635892983850, -0.760042143153638050, -0.760009648514187400, -0.759977151974712610, -0.759944653535294950, +-0.759912153196015680, -0.759879650956956090, -0.759847146818196650, -0.759814640779819970, -0.759782132841906770, -0.759749623004538190, -0.759717111267795510, -0.759684597631760110, +-0.759652082096513140, -0.759619564662136090, -0.759587045328710020, -0.759554524096315850, -0.759522000965035860, -0.759489475934950970, -0.759456949006142250, -0.759424420178691270, +-0.759391889452679210, -0.759359356828187450, -0.759326822305296690, -0.759294285884089430, -0.759261747564646480, -0.759229207347049240, -0.759196665231378850, -0.759164121217716810, +-0.759131575306144500, -0.759099027496743290, -0.759066477789593910, -0.759033926184778940, -0.759001372682378990, -0.758968817282475780, -0.758936259985150570, -0.758903700790484640, +-0.758871139698559350, -0.758838576709455760, -0.758806011823256240, -0.758773445040041740, -0.758740876359893620, -0.758708305782893390, -0.758675733309122300, -0.758643158938661850, +-0.758610582671593540, -0.758578004507998840, -0.758545424447958470, -0.758512842491555040, -0.758480258638869590, -0.758447672889983600, -0.758415085244978250, -0.758382495703935230, +-0.758349904266935490, -0.758317310934061520, -0.758284715705394240, -0.758252118581015160, -0.758219519561005860, -0.758186918645447740, -0.758154315834422280, -0.758121711128011080, +-0.758089104526295520, -0.758056496029356650, -0.758023885637277180, -0.757991273350137940, -0.757958659168020520, -0.757926043091006530, -0.757893425119177340, -0.757860805252614120, +-0.757828183491399350, -0.757795559835614090, -0.757762934285340030, -0.757730306840658670, -0.757697677501651400, -0.757665046268400030, -0.757632413140986060, -0.757599778119490970, +-0.757567141203995930, -0.757534502394583640, -0.757501861691335040, -0.757469219094331740, -0.757436574603655540, -0.757403928219387730, -0.757371279941610240, -0.757338629770403890, +-0.757305977705851620, -0.757273323748034350, -0.757240667897033810, -0.757208010152931490, -0.757175350515809310, -0.757142688985748660, -0.757110025562831250, -0.757077360247138230, +-0.757044693038752440, -0.757012023937754910, -0.756979352944227250, -0.756946680058251280, -0.756914005279908600, -0.756881328609280810, -0.756848650046449190, -0.756815969591496550, +-0.756783287244503940, -0.756750603005553190, -0.756717916874725890, -0.756685228852103760, -0.756652538937768630, -0.756619847131802080, -0.756587153434285950, -0.756554457845301400, +-0.756521760364931240, -0.756489060993256630, -0.756456359730359410, -0.756423656576321270, -0.756390951531224040, -0.756358244595148890, -0.756325535768178630, -0.756292825050394520, +-0.756260112441878410, -0.756227397942711880, -0.756194681552976980, -0.756161963272755420, -0.756129243102128920, -0.756096521041179190, -0.756063797089987720, -0.756031071248637330, +-0.755998343517209180, -0.755965613895785200, -0.755932882384447110, -0.755900148983276950, -0.755867413692355880, -0.755834676511766720, -0.755801937441590970, -0.755769196481910210, +-0.755736453632806620, -0.755703708894361890, -0.755670962266657750, -0.755638213749776360, -0.755605463343799300, -0.755572711048808190, -0.755539956864885730, -0.755507200792113420, +-0.755474442830573080, -0.755441682980346640, -0.755408921241516040, -0.755376157614163100, -0.755343392098369200, -0.755310624694217390, -0.755277855401789040, -0.755245084221165990, +-0.755212311152430260, -0.755179536195663800, -0.755146759350948440, -0.755113980618366210, -0.755081199997998500, -0.755048417489928350, -0.755015633094237030, -0.754982846811006800, +-0.754950058640319390, -0.754917268582256830, -0.754884476636901060, -0.754851682804333570, -0.754818887084637400, -0.754786089477894050, -0.754753289984185450, -0.754720488603593750, +-0.754687685336200680, -0.754654880182088480, -0.754622073141339000, -0.754589264214033720, -0.754556453400256010, -0.754523640700087040, -0.754490826113609070, -0.754458009640903930, +-0.754425191282053880, -0.754392371037140850, -0.754359548906246240, -0.754326724889453290, -0.754293898986843630, -0.754261071198499170, -0.754228241524502070, -0.754195409964934390, +-0.754162576519878170, -0.754129741189415450, -0.754096903973628390, -0.754064064872598580, -0.754031223886409090, -0.753998381015141610, -0.753965536258878080, -0.753932689617700770, +-0.753899841091691720, -0.753866990680932550, -0.753834138385506390, -0.753801284205494970, -0.753768428140980330, -0.753735570192044510, -0.753702710358769900, -0.753669848641238540, +-0.753636985039532360, -0.753604119553733850, -0.753571252183924510, -0.753538382930187490, -0.753505511792604610, -0.753472638771257920, -0.753439763866229680, -0.753406887077601950, +-0.753374008405457100, -0.753341127849876500, -0.753308245410943770, -0.753275361088740380, -0.753242474883348720, -0.753209586794850730, -0.753176696823328770, -0.753143804968865130, +-0.753110911231541950, -0.753078015611440940, -0.753045118108645490, -0.753012218723237200, -0.752979317455298340, -0.752946414304911270, -0.752913509272158050, -0.752880602357121060, +-0.752847693559882130, -0.752814782880524390, -0.752781870319129800, -0.752748955875780500, -0.752716039550558770, -0.752683121343546980, -0.752650201254827400, -0.752617279284482300, +-0.752584355432593500, -0.752551429699244270, -0.752518502084516540, -0.752485572588492470, -0.752452641211254550, -0.752419707952885040, -0.752386772813466220, -0.752353835793079910, +-0.752320896891809590, -0.752287956109736980, -0.752255013446944450, -0.752222068903514510, -0.752189122479529400, -0.752156174175071410, -0.752123223990222910, -0.752090271925066500, +-0.752057317979683780, -0.752024362154158240, -0.751991404448571930, -0.751958444863007110, -0.751925483397546170, -0.751892520052271470, -0.751859554827264850, -0.751826587722610020, +-0.751793618738388680, -0.751760647874683220, -0.751727675131576230, -0.751694700509150100, -0.751661724007487100, -0.751628745626669930, -0.751595765366780850, -0.751562783227901710, +-0.751529799210116200, -0.751496813313506260, -0.751463825538154270, -0.751430835884142610, -0.751397844351553990, -0.751364850940470670, -0.751331855650974710, -0.751298858483149590, +-0.751265859437077470, -0.751232858512840610, -0.751199855710521610, -0.751166851030202980, -0.751133844471967290, -0.751100836035896950, -0.751067825722073870, -0.751034813530581880, +-0.751001799461502810, -0.750968783514919250, -0.750935765690913690, -0.750902745989568850, -0.750869724410967000, -0.750836700955190390, -0.750803675622322530, -0.750770648412445450, +-0.750737619325641870, -0.750704588361994160, -0.750671555521584930, -0.750638520804496890, -0.750605484210812520, -0.750572445740613880, -0.750539405393984670, -0.750506363171007050, +-0.750473319071763400, -0.750440273096336430, -0.750407225244808960, -0.750374175517263260, -0.750341123913781600, -0.750308070434447690, -0.750275015079343580, -0.750241957848551970, +-0.750208898742155460, -0.750175837760236770, -0.750142774902878400, -0.750109710170163150, -0.750076643562173520, -0.750043575078991780, -0.750010504720701740, -0.749977432487385350, +-0.749944358379125430, -0.749911282396004570, -0.749878204538105500, -0.749845124805510350, -0.749812043198302970, -0.749778959716565500, -0.749745874360380650, -0.749712787129831030, +-0.749679698024999560, -0.749646607045968750, -0.749613514192821520, -0.749580419465640360, -0.749547322864507760, -0.749514224389507210, -0.749481124040721310, -0.749448021818232450, +-0.749414917722123650, -0.749381811752477420, -0.749348703909376800, -0.749315594192903720, -0.749282482603142340, -0.749249369140174700, -0.749216253804083630, -0.749183136594951950, +-0.749150017512862480, -0.749116896557897930, -0.749083773730141010, -0.749050649029674220, -0.749017522456581370, -0.748984394010944740, -0.748951263692847040, -0.748918131502371190, +-0.748884997439600130, -0.748851861504616470, -0.748818723697502580, -0.748785584018342500, -0.748752442467218390, -0.748719299044213300, -0.748686153749409830, -0.748653006582891020, +-0.748619857544739810, -0.748586706635038790, -0.748553553853870460, -0.748520399201318850, -0.748487242677466250, -0.748454084282395570, -0.748420924016189650, -0.748387761878931410, +-0.748354597870703800, -0.748321431991589070, -0.748288264241671270, -0.748255094621032900, -0.748221923129756880, -0.748188749767925930, -0.748155574535623200, -0.748122397432931410, +-0.748089218459933700, -0.748056037616713020, -0.748022854903351520, -0.747989670319933580, -0.747956483866541340, -0.747923295543257980, -0.747890105350166310, -0.747856913287349490, +-0.747823719354889780, -0.747790523552871340, -0.747757325881376560, -0.747724126340488460, -0.747690924930290100, -0.747657721650864300, -0.747624516502294330, -0.747591309484663010, +-0.747558100598053390, -0.747524889842548060, -0.747491677218230950, -0.747458462725184790, -0.747425246363492390, -0.747392028133236800, -0.747358808034501280, -0.747325586067368650, +-0.747292362231921410, -0.747259136528243940, -0.747225908956418610, -0.747192679516528570, -0.747159448208656760, -0.747126215032886340, -0.747092979989300470, -0.747059743077982060, +-0.747026504299013740, -0.746993263652479640, -0.746960021138462490, -0.746926776757045330, -0.746893530508311200, -0.746860282392343140, -0.746827032409224430, -0.746793780559037670, +-0.746760526841866890, -0.746727271257794810, -0.746694013806904590, -0.746660754489279380, -0.746627493305002220, -0.746594230254156390, -0.746560965336824920, -0.746527698553090420, +-0.746494429903037270, -0.746461159386748060, -0.746427887004306070, -0.746394612755794330, -0.746361336641295890, -0.746328058660894240, -0.746294778814671880, -0.746261497102713060, +-0.746228213525100600, -0.746194928081917560, -0.746161640773247200, -0.746128351599172680, -0.746095060559777370, -0.746061767655144430, -0.746028472885357010, -0.745995176250497830, +-0.745961877750651260, -0.745928577385900020, -0.745895275156327360, -0.745861971062016460, -0.745828665103050680, -0.745795357279512630, -0.745762047591486900, -0.745728736039055870, +-0.745695422622303040, -0.745662107341311780, -0.745628790196165130, -0.745595471186946470, -0.745562150313739290, -0.745528827576626530, -0.745495502975691340, -0.745462176511017870, +-0.745428848182688840, -0.745395517990787850, -0.745362185935398050, -0.745328852016602820, -0.745295516234485310, -0.745262178589128470, -0.745228839080616880, -0.745195497709033150, +-0.745162154474460550, -0.745128809376982670, -0.745095462416682790, -0.745062113593644270, -0.745028762907950390, -0.744995410359683970, -0.744962055948929720, -0.744928699675770360, +-0.744895341540289140, -0.744861981542569660, -0.744828619682695200, -0.744795255960749140, -0.744761890376814390, -0.744728522930975470, -0.744695153623315290, -0.744661782453917230, +-0.744628409422864680, -0.744595034530241120, -0.744561657776129930, -0.744528279160614700, -0.744494898683778050, -0.744461516345704900, -0.744428132146477850, -0.744394746086180500, +-0.744361358164896240, -0.744327968382708650, -0.744294576739701120, -0.744261183235956580, -0.744227787871559630, -0.744194390646593210, -0.744160991561140790, -0.744127590615285990, +-0.744094187809112070, -0.744060783142702850, -0.744027376616141490, -0.743993968229511800, -0.743960557982896620, -0.743927145876380650, -0.743893731910046710, -0.743860316083978510, +-0.743826898398259550, -0.743793478852973310, -0.743760057448202730, -0.743726634184032620, -0.743693209060545920, -0.743659782077826350, -0.743626353235957160, -0.743592922535022070, +-0.743559489975104790, -0.743526055556288700, -0.743492619278657510, -0.743459181142294150, -0.743425741147283440, -0.743392299293708430, -0.743358855581652600, -0.743325410011199670, +-0.743291962582433240, -0.743258513295436800, -0.743225062150293600, -0.743191609147088260, -0.743158154285903930, -0.743124697566824200, -0.743091238989932790, -0.743057778555313190, +-0.743024316263049210, -0.742990852113224460, -0.742957386105921880, -0.742923918241226500, -0.742890448519221370, -0.742856976939989980, -0.742823503503616370, -0.742790028210183810, +-0.742756551059776230, -0.742723072052476670, -0.742689591188369970, -0.742656108467539380, -0.742622623890068610, -0.742589137456041160, -0.742555649165540840, -0.742522159018651370, +-0.742488667015456680, -0.742455173156039590, -0.742421677440485150, -0.742388179868876510, -0.742354680441297490, -0.742321179157831800, -0.742287676018563050, -0.742254171023575160, +-0.742220664172951290, -0.742187155466776270, -0.742153644905133470, -0.742120132488106490, -0.742086618215779260, -0.742053102088235380, -0.742019584105558790, -0.741986064267833200, +-0.741952542575142540, -0.741919019027569850, -0.741885493625200180, -0.741851966368116790, -0.741818437256403510, -0.741784906290144150, -0.741751373469422550, -0.741717838794321960, +-0.741684302264927210, -0.741650763881321890, -0.741617223643589510, -0.741583681551814090, -0.741550137606079570, -0.741516591806469670, -0.741483044153068200, -0.741449494645959110, +-0.741415943285225860, -0.741382390070953190, -0.741348835003224680, -0.741315278082123940, -0.741281719307735120, -0.741248158680141930, -0.741214596199427760, -0.741181031865677630, +-0.741147465678975050, -0.741113897639403720, -0.741080327747047680, -0.741046756001990880, -0.741013182404317130, -0.740979606954110360, -0.740946029651454730, -0.740912450496433280, +-0.740878869489131290, -0.740845286629632230, -0.740811701918019930, -0.740778115354378430, -0.740744526938791560, -0.740710936671343360, -0.740677344552117200, -0.740643750581198360, +-0.740610154758670090, -0.740576557084616560, -0.740542957559121470, -0.740509356182269100, -0.740475752954143250, -0.740442147874827980, -0.740408540944406890, -0.740374932162964900, +-0.740341321530585740, -0.740307709047353210, -0.740274094713351370, -0.740240478528664260, -0.740206860493376030, -0.740173240607570060, -0.740139618871331510, -0.740105995284743970, +-0.740072369847891490, -0.740038742560858000, -0.740005113423727660, -0.739971482436584620, -0.739937849599512810, -0.739904214912596280, -0.739870578375918740, -0.739836939989565350, +-0.739803299753619580, -0.739769657668165600, -0.739736013733287460, -0.739702367949069180, -0.739668720315594500, -0.739635070832948660, -0.739601419501215050, -0.739567766320477830, +-0.739534111290821360, -0.739500454412329480, -0.739466795685086550, -0.739433135109176520, -0.739399472684683760, -0.739365808411691640, -0.739332142290285650, -0.739298474320549400, +-0.739264804502566820, -0.739231132836422280, -0.739197459322199930, -0.739163783959983280, -0.739130106749857800, -0.739096427691907090, -0.739062746786215200, -0.739029064032866610, +-0.738995379431945270, -0.738961692983535420, -0.738928004687721350, -0.738894314544587320, -0.738860622554216920, -0.738826928716695530, -0.738793233032106870, -0.738759535500535080, +-0.738725836122064440, -0.738692134896779210, -0.738658431824763650, -0.738624726906101480, -0.738591020140878070, -0.738557311529177030, -0.738523601071082720, -0.738489888766679540, +-0.738456174616051400, -0.738422458619283020, -0.738388740776458440, -0.738355021087661490, -0.738321299552977430, -0.738287576172490190, -0.738253850946284040, -0.738220123874443250, +-0.738186394957052070, -0.738152664194195120, -0.738118931585955760, -0.738085197132419600, -0.738051460833670570, -0.738017722689792820, -0.737983982700870730, -0.737950240866988790, +-0.737916497188231160, -0.737882751664682310, -0.737849004296426640, -0.737815255083547840, -0.737781504026131520, -0.737747751124261390, -0.737713996378021820, -0.737680239787497300, +-0.737646481352772220, -0.737612721073930390, -0.737578958951057300, -0.737545194984236760, -0.737511429173553280, -0.737477661519091220, -0.737443892020935080, -0.737410120679169110, +-0.737376347493877930, -0.737342572465145780, -0.737308795593056620, -0.737275016877696140, -0.737241236319148060, -0.737207453917496870, -0.737173669672827160, -0.737139883585223200, +-0.737106095654768920, -0.737072305881550040, -0.737038514265650260, -0.737004720807154400, -0.736970925506146620, -0.736937128362711520, -0.736903329376933700, -0.736869528548897420, +-0.736835725878687400, -0.736801921366387450, -0.736768115012083280, -0.736734306815858830, -0.736700496777798590, -0.736666684897987150, -0.736632871176509000, -0.736599055613448740, +-0.736565238208890080, -0.736531418962918960, -0.736497597875619410, -0.736463774947075820, -0.736429950177372780, -0.736396123566594780, -0.736362295114826540, -0.736328464822152640, +-0.736294632688656910, -0.736260798714425180, -0.736226962899541370, -0.736193125244090310, -0.736159285748156370, -0.736125444411824260, -0.736091601235178470, -0.736057756218303160, +-0.736023909361283920, -0.735990060664205030, -0.735956210127150960, -0.735922357750206310, -0.735888503533455920, -0.735854647476984150, -0.735820789580875710, -0.735786929845214770, +-0.735753068270087130, -0.735719204855576850, -0.735685339601768410, -0.735651472508746740, -0.735617603576596450, -0.735583732805402010, -0.735549860195247710, -0.735515985746219240, +-0.735482109458400980, -0.735448231331877310, -0.735414351366733170, -0.735380469563053140, -0.735346585920921840, -0.735312700440424180, -0.735278813121644780, -0.735244923964667670, +-0.735211032969578790, -0.735177140136462510, -0.735143245465403220, -0.735109348956485940, -0.735075450609795180, -0.735041550425415300, -0.735007648403432020, -0.734973744543929720, +-0.734939838846992990, -0.734905931312706760, -0.734872021941155640, -0.734838110732424440, -0.734804197686597990, -0.734770282803761110, -0.734736366083997840, -0.734702447527394220, +-0.734668527134034520, -0.734634604904003560, -0.734600680837386060, -0.734566754934266820, -0.734532827194730680, -0.734498897618862000, -0.734464966206746510, -0.734431032958468680, +-0.734397097874113220, -0.734363160953765080, -0.734329222197509070, -0.734295281605430010, -0.734261339177612600, -0.734227394914141350, -0.734193448815102290, -0.734159500880579460, +-0.734125551110657910, -0.734091599505422580, -0.734057646064958160, -0.734023690789349590, -0.733989733678681370, -0.733955774733039190, -0.733921813952507660, -0.733887851337171710, +-0.733853886887116060, -0.733819920602425620, -0.733785952483185460, -0.733751982529480370, -0.733718010741394750, -0.733684037119014640, -0.733650061662424520, -0.733616084371709220, +-0.733582105246953780, -0.733548124288242900, -0.733514141495661850, -0.733480156869294800, -0.733446170409227990, -0.733412182115545710, -0.733378191988332980, -0.733344200027674860, +-0.733310206233656170, -0.733276210606361940, -0.733242213145877230, -0.733208213852286960, -0.733174212725675620, -0.733140209766129260, -0.733106204973732360, -0.733072198348569960, +-0.733038189890727110, -0.733004179600288850, -0.732970167477339450, -0.732936153521965170, -0.732902137734250610, -0.732868120114280710, -0.732834100662140500, -0.732800079377915030, +-0.732766056261689340, -0.732732031313548470, -0.732698004533577580, -0.732663975921861050, -0.732629945478485260, -0.732595913203534570, -0.732561879097094140, -0.732527843159248900, +-0.732493805390084130, -0.732459765789684750, -0.732425724358135470, -0.732391681095522440, -0.732357636001930160, -0.732323589077443880, -0.732289540322148550, -0.732255489736129420, +-0.732221437319471540, -0.732187383072260060, -0.732153326994579580, -0.732119269086516260, -0.732085209348154910, -0.732051147779580470, -0.732017084380878090, -0.731983019152133150, +-0.731948952093430580, -0.731914883204854980, -0.731880812486492840, -0.731846739938428750, -0.731812665560747640, -0.731778589353535010, -0.731744511316875790, -0.731710431450855350, +-0.731676349755558840, -0.731642266231070870, -0.731608180877477810, -0.731574093694864260, -0.731540004683315480, -0.731505913842916740, -0.731471821173753200, -0.731437726675910120, +-0.731403630349472090, -0.731369532194525610, -0.731335432211155270, -0.731301330399446450, -0.731267226759484190, -0.731233121291353870, -0.731199013995140760, -0.731164904870930110, +-0.731130793918807200, -0.731096681138856840, -0.731062566531165190, -0.731028450095817290, -0.730994331832898080, -0.730960211742493150, -0.730926089824687650, -0.730891966079566410, +-0.730857840507215810, -0.730823713107720540, -0.730789583881166100, -0.730755452827637540, -0.730721319947220560, -0.730687185240000090, -0.730653048706061740, -0.730618910345490760, +-0.730584770158371980, -0.730550628144791770, -0.730516484304835070, -0.730482338638587030, -0.730448191146133240, -0.730414041827558980, -0.730379890682949620, -0.730345737712389860, +-0.730311582915966430, -0.730277426293764020, -0.730243267845868130, -0.730209107572363900, -0.730174945473337060, -0.730140781548872740, -0.730106615799056560, -0.730072448223973100, +-0.730038278823709310, -0.730004107598349660, -0.729969934547979870, -0.729935759672685200, -0.729901582972551030, -0.729867404447662960, -0.729833224098105800, -0.729799041923966160, +-0.729764857925328970, -0.729730672102279600, -0.729696484454903540, -0.729662294983286270, -0.729628103687513410, -0.729593910567670090, -0.729559715623841480, -0.729525518856114160, +-0.729491320264572970, -0.729457119849303610, -0.729422917610391460, -0.729388713547921900, -0.729354507661980620, -0.729320299952652460, -0.729286090420024240, -0.729251879064180650, +-0.729217665885207420, -0.729183450883190030, -0.729149234058213970, -0.729115015410364940, -0.729080794939728220, -0.729046572646389610, -0.729012348530433950, -0.728978122591948050, +-0.728943894831016740, -0.728909665247725820, -0.728875433842160580, -0.728841200614406940, -0.728806965564549600, -0.728772728692675400, -0.728738489998869480, -0.728704249483217330, +-0.728670007145804540, -0.728635762986716730, -0.728601517006039480, -0.728567269203858390, -0.728533019580259290, -0.728498768135326880, -0.728464514869148210, -0.728430259781808310, +-0.728396002873392680, -0.728361744143987020, -0.728327483593677050, -0.728293221222548360, -0.728258957030686100, -0.728224691018176990, -0.728190423185106070, -0.728156153531559270, +-0.728121882057621850, -0.728087608763379970, -0.728053333648918890, -0.728019056714324540, -0.727984777959681970, -0.727950497385078000, -0.727916214990597890, -0.727881930776327120, +-0.727847644742351640, -0.727813356888756920, -0.727779067215628910, -0.727744775723052630, -0.727710482411114910, -0.727676187279901020, -0.727641890329496780, -0.727607591559987780, +-0.727573290971459730, -0.727538988563998460, -0.727504684337689670, -0.727470378292618620, -0.727436070428872260, -0.727401760746535730, -0.727367449245694740, -0.727333135926435110, +-0.727298820788842670, -0.727264503833003230, -0.727230185059001940, -0.727195864466925750, -0.727161542056859900, -0.727127217828890120, -0.727092891783102440, -0.727058563919582460, +-0.727024234238416000, -0.726989902739689110, -0.726955569423487270, -0.726921234289896080, -0.726886897339002250, -0.726852558570891370, -0.726818217985648940, -0.726783875583360990, +-0.726749531364113350, -0.726715185327991400, -0.726680837475081940, -0.726646487805470480, -0.726612136319242710, -0.726577783016484680, -0.726543427897282100, -0.726509070961721020, +-0.726474712209887240, -0.726440351641866710, -0.726405989257744690, -0.726371625057608330, -0.726337259041542890, -0.726302891209634320, -0.726268521561968420, -0.726234150098631240, +-0.726199776819708820, -0.726165401725286320, -0.726131024815450780, -0.726096646090287790, -0.726062265549883180, -0.726027883194322880, -0.725993499023692810, -0.725959113038079030, +-0.725924725237567570, -0.725890335622243590, -0.725855944192194460, -0.725821550947505330, -0.725787155888262480, -0.725752759014551610, -0.725718360326458980, -0.725683959824070300, +-0.725649557507471180, -0.725615153376748760, -0.725580747431988530, -0.725546339673276420, -0.725511930100698370, -0.725477518714340520, -0.725443105514288920, -0.725408690500629500, +-0.725374273673447760, -0.725339855032831050, -0.725305434578864540, -0.725271012311634600, -0.725236588231227050, -0.725202162337728050, -0.725167734631223640, -0.725133305111799190, +-0.725098873779542190, -0.725064440634538010, -0.725030005676872700, -0.724995568906632410, -0.724961130323903080, -0.724926689928771070, -0.724892247721322210, -0.724857803701642770, +-0.724823357869818330, -0.724788910225935950, -0.724754460770081320, -0.724720009502340720, -0.724685556422799860, -0.724651101531545220, -0.724616644828662170, -0.724582186314238210, +-0.724547725988358700, -0.724513263851109920, -0.724478799902577910, -0.724444334142848920, -0.724409866572009120, -0.724375397190144770, -0.724340925997341790, -0.724306452993685900, +-0.724271978179264480, -0.724237501554163110, -0.724203023118467960, -0.724168542872265400, -0.724134060815641360, -0.724099576948682210, -0.724065091271473450, -0.724030603784102670, +-0.723996114486655350, -0.723961623379217660, -0.723927130461875960, -0.723892635734716410, -0.723858139197825380, -0.723823640851288920, -0.723789140695192730, -0.723754638729624310, +-0.723720134954669360, -0.723685629370414030, -0.723651121976944590, -0.723616612774347410, -0.723582101762708650, -0.723547588942114020, -0.723513074312651110, -0.723478557874405400, +-0.723444039627463400, -0.723409519571911240, -0.723374997707835200, -0.723340474035321760, -0.723305948554457180, -0.723271421265327060, -0.723236892168019010, -0.723202361262618720, +-0.723167828549212580, -0.723133294027886840, -0.723098757698727780, -0.723064219561821990, -0.723029679617254840, -0.722995137865114270, -0.722960594305485760, -0.722926048938455800, +-0.722891501764110770, -0.722856952782536920, -0.722822401993820640, -0.722787849398048520, -0.722753294995306610, -0.722718738785680940, -0.722684180769259000, -0.722649620946126610, +-0.722615059316370160, -0.722580495880076110, -0.722545930637330750, -0.722511363588219990, -0.722476794732831440, -0.722442224071250920, -0.722407651603564900, -0.722373077329859560, +-0.722338501250221700, -0.722303923364737480, -0.722269343673493490, -0.722234762176576120, -0.722200178874071290, -0.722165593766066590, -0.722131006852647970, -0.722096418133901690, +-0.722061827609914550, -0.722027235280772730, -0.721992641146562140, -0.721958045207370720, -0.721923447463284070, -0.721888847914388790, -0.721854246560771460, -0.721819643402518580, +-0.721785038439716420, -0.721750431672451790, -0.721715823100811060, -0.721681212724880170, -0.721646600544746830, -0.721611986560496970, -0.721577370772217170, -0.721542753179993950, +-0.721508133783913760, -0.721473512584063340, -0.721438889580528490, -0.721404264773397140, -0.721369638162754900, -0.721335009748688690, -0.721300379531285010, -0.721265747510630330, +-0.721231113686811250, -0.721196478059914490, -0.721161840630025750, -0.721127201397233190, -0.721092560361622500, -0.721057917523280520, -0.721023272882293620, -0.720988626438748610, +-0.720953978192732100, -0.720919328144330020, -0.720884676293630070, -0.720850022640718620, -0.720815367185681950, -0.720780709928606990, -0.720746050869580210, -0.720711390008688340, +-0.720676727346017950, -0.720642062881655780, -0.720607396615687850, -0.720572728548201980, -0.720538058679284330, -0.720503387009021500, -0.720468713537500190, -0.720434038264807120, +-0.720399361191028320, -0.720364682316251840, -0.720330001640563600, -0.720295319164050210, -0.720260634886798700, -0.720225948808895570, -0.720191260930427510, -0.720156571251481360, +-0.720121879772143700, -0.720087186492500810, -0.720052491412640490, -0.720017794532649020, -0.719983095852613110, -0.719948395372619340, -0.719913693092754660, -0.719878989013105100, +-0.719844283133758700, -0.719809575454801510, -0.719774865976320450, -0.719740154698402250, -0.719705441621133590, -0.719670726744601420, -0.719636010068892330, -0.719601291594093360, +-0.719566571320290450, -0.719531849247571740, -0.719497125376023390, -0.719462399705732230, -0.719427672236785050, -0.719392942969268700, -0.719358211903270100, -0.719323479038875170, +-0.719288744376172300, -0.719254007915247520, -0.719219269656187770, -0.719184529599079750, -0.719149787744010500, -0.719115044091066750, -0.719080298640335400, -0.719045551391902630, +-0.719010802345856680, -0.718976051502283610, -0.718941298861270560, -0.718906544422904140, -0.718871788187271380, -0.718837030154459210, -0.718802270324553790, -0.718767508697643390, +-0.718732745273814140, -0.718697980053153000, -0.718663213035746980, -0.718628444221682930, -0.718593673611047760, -0.718558901203928400, -0.718524127000411790, -0.718489351000584200, +-0.718454573204533880, -0.718419793612347200, -0.718385012224110890, -0.718350229039912190, -0.718315444059837830, -0.718280657283974280, -0.718245868712409700, -0.718211078345230460, +-0.718176286182523490, -0.718141492224375840, -0.718106696470874440, -0.718071898922106320, -0.718037099578158420, -0.718002298439117780, -0.717967495505070770, -0.717932690776105660, +-0.717897884252308830, -0.717863075933767300, -0.717828265820568020, -0.717793453912798140, -0.717758640210544030, -0.717723824713893840, -0.717689007422934180, -0.717654188337751850, +-0.717619367458434240, -0.717584544785068170, -0.717549720317740670, -0.717514894056538900, -0.717480066001549900, -0.717445236152860040, -0.717410404510557820, -0.717375571074729490, +-0.717340735845462320, -0.717305898822843350, -0.717271060006959500, -0.717236219397898060, -0.717201376995745490, -0.717166532800590060, -0.717131686812518270, -0.717096839031617360, +-0.717061989457974280, -0.717027138091676170, -0.716992284932810310, -0.716957429981463720, -0.716922573237723020, -0.716887714701676340, -0.716852854373410510, -0.716817992253012460, +-0.716783128340569450, -0.716748262636168530, -0.716713395139897070, -0.716678525851841550, -0.716643654772090240, -0.716608781900729740, -0.716573907237847420, -0.716539030783530210, +-0.716504152537865590, -0.716469272500940390, -0.716434390672842090, -0.716399507053657960, -0.716364621643474250, -0.716329734442379680, -0.716294845450460740, -0.716259954667804680, +-0.716225062094498770, -0.716190167730630270, -0.716155271576285560, -0.716120373631553450, -0.716085473896520330, -0.716050572371273560, -0.716015669055900310, -0.715980763950487930, +-0.715945857055123700, -0.715910948369894660, -0.715876037894888410, -0.715841125630191310, -0.715806211575892190, -0.715771295732077430, -0.715736378098834390, -0.715701458676250460, +-0.715666537464412890, -0.715631614463408390, -0.715596689673325350, -0.715561763094250790, -0.715526834726271650, -0.715491904569475420, -0.715456972623949470, -0.715422038889781180, +-0.715387103367057690, -0.715352166055866380, -0.715317226956294180, -0.715282286068429470, -0.715247343392359070, -0.715212398928170230, -0.715177452675950560, -0.715142504635787100, +-0.715107554807767440, -0.715072603191978300, -0.715037649788508150, -0.715002694597444030, -0.714967737618873110, -0.714932778852882870, -0.714897818299560560, -0.714862855958993900, +-0.714827891831269930, -0.714792925916475700, -0.714757958214699780, -0.714722988726028910, -0.714688017450550660, -0.714653044388352310, -0.714618069539521340, -0.714583092904145230, +-0.714548114482310700, -0.714513134274106560, -0.714478152279619530, -0.714443168498937190, -0.714408182932146920, -0.714373195579336210, -0.714338206440592430, -0.714303215516003180, +-0.714268222805655270, -0.714233228309637420, -0.714198232028036450, -0.714163233960940060, -0.714128234108435400, -0.714093232470610180, -0.714058229047552010, -0.714023223839347580, +-0.713988216846085710, -0.713953208067853230, -0.713918197504737840, -0.713883185156826920, -0.713848171024207940, -0.713813155106968630, -0.713778137405196470, -0.713743117918978930, +-0.713708096648402960, -0.713673073593557360, -0.713638048754529080, -0.713603022131405700, -0.713567993724274820, -0.713532963533223820, -0.713497931558339850, -0.713462897799711730, +-0.713427862257426270, -0.713392824931571190, -0.713357785822234080, -0.713322744929502540, -0.713287702253464050, -0.713252657794206320, -0.713217611551816950, -0.713182563526382980, +-0.713147513717993120, -0.713112462126734630, -0.713077408752694870, -0.713042353595961580, -0.713007296656622440, -0.712972237934765160, -0.712937177430476470, -0.712902115143845600, +-0.712867051074959400, -0.712831985223905560, -0.712796917590771790, -0.712761848175645700, -0.712726776978614970, -0.712691703999767330, -0.712656629239189820, -0.712621552696971360, +-0.712586474373199000, -0.712551394267960330, -0.712516312381343390, -0.712481228713435550, -0.712446143264324650, -0.712411056034097820, -0.712375967022843890, -0.712340876230650120, +-0.712305783657604110, -0.712270689303793670, -0.712235593169306510, -0.712200495254230350, -0.712165395558652990, -0.712130294082661490, -0.712095190826344870, -0.712060085789790300, +-0.712024978973085480, -0.711989870376318220, -0.711954759999576250, -0.711919647842947370, -0.711884533906518850, -0.711849418190379610, -0.711814300694616710, -0.711779181419318170, +-0.711744060364571610, -0.711708937530464940, -0.711673812917085980, -0.711638686524522330, -0.711603558352862150, -0.711568428402192250, -0.711533296672602010, -0.711498163164178580, +-0.711463027877009770, -0.711427890811183290, -0.711392751966787080, -0.711357611343908400, -0.711322468942636290, -0.711287324763058000, -0.711252178805261480, -0.711217031069334430, +-0.711181881555364770, -0.711146730263440550, -0.711111577193649370, -0.711076422346079370, -0.711041265720817610, -0.711006107317953220, -0.710970947137573690, -0.710935785179766740, +-0.710900621444620410, -0.710865455932222500, -0.710830288642660850, -0.710795119576022930, -0.710759948732397890, -0.710724776111872900, -0.710689601714535990, -0.710654425540475090, +-0.710619247589778010, -0.710584067862533030, -0.710548886358827740, -0.710513703078749610, -0.710478518022387820, -0.710443331189829830, -0.710408142581163470, -0.710372952196476780, +-0.710337760035857580, -0.710302566099394130, -0.710267370387173580, -0.710232172899285310, -0.710196973635816460, -0.710161772596855310, -0.710126569782489670, -0.710091365192807580, +-0.710056158827897080, -0.710020950687846210, -0.709985740772742350, -0.709950529082674750, -0.709915315617730910, -0.709880100377998650, -0.709844883363566210, -0.709809664574521550, +-0.709774444010952690, -0.709739221672947120, -0.709703997560594100, -0.709668771673981120, -0.709633544013196230, -0.709598314578327450, -0.709563083369462940, -0.709527850386690640, +-0.709492615630098800, -0.709457379099775350, -0.709422140795807790, -0.709386900718285580, -0.709351658867296120, -0.709316415242927430, -0.709281169845267790, -0.709245922674405230, +-0.709210673730427230, -0.709175423013423180, -0.709140170523480440, -0.709104916260687390, -0.709069660225132070, -0.709034402416902520, -0.708999142836087000, -0.708963881482773670, +-0.708928618357050570, -0.708893353459005390, -0.708858086788727420, -0.708822818346304120, -0.708787548131823870, -0.708752276145374730, -0.708717002387044940, -0.708681726856922540, +-0.708646449555095370, -0.708611170481652560, -0.708575889636681830, -0.708540607020271440, -0.708505322632509540, -0.708470036473484280, -0.708434748543284030, -0.708399458841996730, +-0.708364167369710310, -0.708328874126514020, -0.708293579112495570, -0.708258282327743130, -0.708222983772345050, -0.708187683446389490, -0.708152381349964720, -0.708117077483158330, +-0.708081771846059920, -0.708046464438757070, -0.708011155261338070, -0.707975844313891270, -0.707940531596504720, -0.707905217109266900, -0.707869900852265980, -0.707834582825589750, +-0.707799263029327720, -0.707763941463567360, -0.707728618128397270, -0.707693293023905600, -0.707657966150180840, -0.707622637507311030, -0.707587307095383980, -0.707551974914489400, +-0.707516640964714780, -0.707481305246148610, -0.707445967758879140, -0.707410628502994740, -0.707375287478583800, -0.707339944685734690, -0.707304600124535670, -0.707269253795074440, +-0.707233905697440820, -0.707198555831722420, -0.707163204198007600, -0.707127850796384740, -0.707092495626942320, -0.707057138689768050, -0.707021779984951530, -0.706986419512580570, +-0.706951057272743540, -0.706915693265528830, -0.706880327491024920, -0.706844959949320170, -0.706809590640503080, -0.706774219564662020, -0.706738846721884690, -0.706703472112260920, +-0.706668095735878520, -0.706632717592825870, -0.706597337683191330, -0.706561956007063510, -0.706526572564530890, -0.706491187355681060, -0.706455800380603960, -0.706420411639387400, +-0.706385021132119760, -0.706349628858889520, -0.706314234819785280, -0.706278839014895410, -0.706243441444308510, -0.706208042108112280, -0.706172641006396650, -0.706137238139249450, +-0.706101833506759040, -0.706066427109014130, -0.706031018946103090, -0.705995609018114530, -0.705960197325136370, -0.705924783867258320, -0.705889368644568300, -0.705853951657154810, +-0.705818532905106540, -0.705783112388511880, -0.705747690107459410, -0.705712266062037740, -0.705676840252334790, -0.705641412678440380, -0.705605983340442440, -0.705570552238429460, +-0.705535119372490250, -0.705499684742713180, -0.705464248349186860, -0.705428810191999320, -0.705393370271240380, -0.705357928586997970, -0.705322485139360800, -0.705287039928417350, +-0.705251592954256320, -0.705216144216966320, -0.705180693716636050, -0.705145241453353890, -0.705109787427208090, -0.705074331638288480, -0.705038874086682980, -0.705003414772480300, +-0.704967953695769150, -0.704932490856638010, -0.704897026255175030, -0.704861559891470150, -0.704826091765611400, -0.704790621877687370, -0.704755150227786790, -0.704719676815998340, +-0.704684201642410750, -0.704648724707112590, -0.704613246010192710, -0.704577765551739010, -0.704542283331841550, -0.704506799350588350, -0.704471313608068140, -0.704435826104369720, +-0.704400336839581700, -0.704364845813792770, -0.704329353027091210, -0.704293858479566830, -0.704258362171307770, -0.704222864102402870, -0.704187364272940820, -0.704151862683010330, +-0.704116359332700230, -0.704080854222099100, -0.704045347351295310, -0.704009838720378810, -0.703974328329437630, -0.703938816178560690, -0.703903302267836710, -0.703867786597354380, +-0.703832269167202760, -0.703796749977469660, -0.703761229028245340, -0.703725706319618060, -0.703690181851676420, -0.703654655624509350, -0.703619127638205670, -0.703583597892854180, +-0.703548066388543610, -0.703512533125362330, -0.703476998103400360, -0.703441461322745760, -0.703405922783487680, -0.703370382485714710, -0.703334840429515770, -0.703299296614979810, +-0.703263751042194850, -0.703228203711251170, -0.703192654622237120, -0.703157103775241320, -0.703121551170352800, -0.703085996807660370, -0.703050440687252860, -0.703014882809219420, +-0.702979323173648640, -0.702943761780629010, -0.702908198630250560, -0.702872633722601670, -0.702837067057771160, -0.702801498635847950, -0.702765928456920990, -0.702730356521078630, +-0.702694782828411020, -0.702659207379006330, -0.702623630172953820, -0.702588051210342070, -0.702552470491260240, -0.702516888015797260, -0.702481303784042050, -0.702445717796083560, +-0.702410130052010250, -0.702374540551912060, -0.702338949295877700, -0.702303356283995870, -0.702267761516355620, -0.702232164993046080, -0.702196566714155980, -0.702160966679773900, +-0.702125364889990110, -0.702089761344892870, -0.702054156044571220, -0.702018548989114090, -0.701982940178610630, -0.701947329613149870, -0.701911717292820760, -0.701876103217711770, +-0.701840487387913160, -0.701804869803513200, -0.701769250464601150, -0.701733629371266040, -0.701698006523596820, -0.701662381921682510, -0.701626755565611600, -0.701591127455474580, +-0.701555497591359600, -0.701519865973355920, -0.701484232601552680, -0.701448597476038720, -0.701412960596903280, -0.701377321964235520, -0.701341681578123710, -0.701306039438658440, +-0.701270395545928070, -0.701234749900021660, -0.701199102501028350, -0.701163453349037290, -0.701127802444137640, -0.701092149786417870, -0.701056495375968370, -0.701020839212877610, +-0.700985181297234640, -0.700949521629128820, -0.700913860208649210, -0.700878197035884940, -0.700842532110925060, -0.700806865433859060, -0.700771197004775080, -0.700735526823763830, +-0.700699854890913800, -0.700664181206314020, -0.700628505770053870, -0.700592828582222490, -0.700557149642908270, -0.700521468952201910, -0.700485786510191890, -0.700450102316967360, +-0.700414416372617590, -0.700378728677231830, -0.700343039230899130, -0.700307348033708870, -0.700271655085750290, -0.700235960387112000, -0.700200263937884260, -0.700164565738156000, +-0.700128865788016250, -0.700093164087554400, -0.700057460636859590, -0.700021755436020520, -0.699986048485127690, -0.699950339784269790, -0.699914629333535990, -0.699878917133015640, +-0.699843203182797910, -0.699807487482972280, -0.699771770033627890, -0.699736050834854020, -0.699700329886739470, -0.699664607189374730, -0.699628882742848400, -0.699593156547249960, +-0.699557428602668560, -0.699521698909193690, -0.699485967466914490, -0.699450234275919680, -0.699414499336299960, -0.699378762648144030, -0.699343024211541150, -0.699307284026580820, +-0.699271542093352180, -0.699235798411944610, -0.699200052982447700, -0.699164305804949930, -0.699128556879542120, -0.699092806206312870, -0.699057053785351550, -0.699021299616747640, +-0.698985543700590520, -0.698949786036969440, -0.698914026625973350, -0.698878265467692830, -0.698842502562216580, -0.698806737909634100, -0.698770971510034760, -0.698735203363508030, +-0.698699433470143290, -0.698663661830029930, -0.698627888443257520, -0.698592113309914660, -0.698556336430092180, -0.698520557803878780, -0.698484777431364060, -0.698448995312637380, +-0.698413211447788230, -0.698377425836905430, -0.698341638480079690, -0.698305849377399810, -0.698270058528955300, -0.698234265934835730, -0.698198471595130490, -0.698162675509928940, +-0.698126877679320800, -0.698091078103395550, -0.698055276782241880, -0.698019473715950630, -0.697983668904610720, -0.697947862348311630, -0.697912054047142850, -0.697876244001193970, +-0.697840432210553920, -0.697804618675313290, -0.697768803395561240, -0.697732986371387030, -0.697697167602880470, -0.697661347090130950, -0.697625524833228150, -0.697589700832261460, +-0.697553875087320470, -0.697518047598494230, -0.697482218365873540, -0.697446387389547230, -0.697410554669605000, -0.697374720206136330, -0.697338883999230940, -0.697303046048978300, +-0.697267206355467350, -0.697231364918789120, -0.697195521739032430, -0.697159676816286880, -0.697123830150642170, -0.697087981742188000, -0.697052131591013760, -0.697016279697209250, +-0.696980426060863300, -0.696944570682067050, -0.696908713560909330, -0.696872854697479730, -0.696836994091868060, -0.696801131744164030, -0.696765267654457010, -0.696729401822836270, +-0.696693534249392620, -0.696657664934215100, -0.696621793877393540, -0.696585921079017400, -0.696550046539176400, -0.696514170257960360, -0.696478292235458870, -0.696442412471761750, +-0.696406530966957820, -0.696370647721138330, -0.696334762734392100, -0.696298876006809060, -0.696262987538478820, -0.696227097329491060, -0.696191205379934950, -0.696155311689901410, +-0.696119416259479710, -0.696083519088759320, -0.696047620177830280, -0.696011719526782090, -0.695975817135704670, -0.695939913004687600, -0.695904007133820830, -0.695868099523193400, +-0.695832190172896330, -0.695796279083018780, -0.695760366253650560, -0.695724451684881510, -0.695688535376801200, -0.695652617329499010, -0.695616697543065770, -0.695580776017590940, +-0.695544852753164130, -0.695508927749875160, -0.695473001007813840, -0.695437072527070100, -0.695401142307733640, -0.695365210349894290, -0.695329276653641300, -0.695293341219065830, +-0.695257404046256910, -0.695221465135304470, -0.695185524486298450, -0.695149582099328530, -0.695113637974484780, -0.695077692111856220, -0.695041744511534000, -0.695005795173607500, +-0.694969844098166530, -0.694933891285300920, -0.694897936735100590, -0.694861980447655350, -0.694826022423055250, -0.694790062661389430, -0.694754101162749160, -0.694718137927223480, +-0.694682172954902530, -0.694646206245876140, -0.694610237800234340, -0.694574267618066840, -0.694538295699463020, -0.694502322044514120, -0.694466346653309420, -0.694430369525938950, +-0.694394390662492420, -0.694358410063059980, -0.694322427727731450, -0.694286443656596970, -0.694250457849745590, -0.694214470307268790, -0.694178481029255830, -0.694142490015796640, +-0.694106497266981260, -0.694070502782899610, -0.694034506563641740, -0.693998508609296900, -0.693962508919956480, -0.693926507495709720, -0.693890504336646790, -0.693854499442857490, +-0.693818492814431980, -0.693782484451460290, -0.693746474354032360, -0.693710462522238220, -0.693674448956167370, -0.693638433655910940, -0.693602416621558420, -0.693566397853199960, +-0.693530377350925380, -0.693494355114824930, -0.693458331144988000, -0.693422305441505740, -0.693386278004467840, -0.693350248833964230, -0.693314217930084960, -0.693278185292920180, +-0.693242150922559920, -0.693206114819094220, -0.693170076982613350, -0.693134037413206560, -0.693097996110965340, -0.693061953075979180, -0.693025908308338100, -0.692989861808132270, +-0.692953813575451720, -0.692917763610386710, -0.692881711913026610, -0.692845658483462800, -0.692809603321784980, -0.692773546428083090, -0.692737487802447370, -0.692701427444967880, +-0.692665365355734860, -0.692629301534838370, -0.692593235982367990, -0.692557168698415220, -0.692521099683069520, -0.692485028936421050, -0.692448956458560080, -0.692412882249576640, +-0.692376806309561000, -0.692340728638602740, -0.692304649236793250, -0.692268568104222100, -0.692232485240979580, -0.692196400647155930, -0.692160314322841200, -0.692124226268125640, +-0.692088136483099640, -0.692052044967852550, -0.692015951722475990, -0.691979856747059640, -0.691943760041693560, -0.691907661606468110, -0.691871561441473440, -0.691835459546800040, +-0.691799355922537160, -0.691763250568776630, -0.691727143485608040, -0.691691034673121430, -0.691654924131407390, -0.691618811860555960, -0.691582697860657510, -0.691546582131802310, +-0.691510464674080620, -0.691474345487582130, -0.691438224572398450, -0.691402101928619280, -0.691365977556334780, -0.691329851455635300, -0.691293723626611230, -0.691257594069352280, +-0.691221462783949910, -0.691185329770493850, -0.691149195029074570, -0.691113058559782220, -0.691076920362707290, -0.691040780437939930, -0.691004638785570720, -0.690968495405689940, +-0.690932350298387290, -0.690896203463754240, -0.690860054901880850, -0.690823904612857250, -0.690787752596773940, -0.690751598853721170, -0.690715443383789540, -0.690679286187068530, +-0.690643127263649960, -0.690606966613623640, -0.690570804237079840, -0.690534640134109030, -0.690498474304801710, -0.690462306749248130, -0.690426137467538780, -0.690389966459763470, +-0.690353793726013910, -0.690317619266379800, -0.690281443080951630, -0.690245265169819880, -0.690209085533075030, -0.690172904170807460, -0.690136721083106860, -0.690100536270065180, +-0.690064349731772220, -0.690028161468318360, -0.689991971479794080, -0.689955779766289860, -0.689919586327896180, -0.689883391164703540, -0.689847194276801750, -0.689810995664282610, +-0.689774795327236070, -0.689738593265752490, -0.689702389479922460, -0.689666183969836480, -0.689629976735584900, -0.689593767777257890, -0.689557557094947040, -0.689521344688742270, +-0.689485130558734170, -0.689448914705013240, -0.689412697127670060, -0.689376477826795010, -0.689340256802478900, -0.689304034054812110, -0.689267809583884670, -0.689231583389788180, +-0.689195355472612900, -0.689159125832449090, -0.689122894469387570, -0.689086661383518710, -0.689050426574932650, -0.689014190043721110, -0.688977951789974120, -0.688941711813782280, +-0.688905470115236060, -0.688869226694426300, -0.688832981551443350, -0.688796734686378030, -0.688760486099320830, -0.688724235790361790, -0.688687983759592840, -0.688651730007103890, +-0.688615474532985660, -0.688579217337328630, -0.688542958420223620, -0.688506697781761320, -0.688470435422031460, -0.688434171341126280, -0.688397905539135600, -0.688361638016150130, +-0.688325368772260690, -0.688289097807557760, -0.688252825122132040, -0.688216550716074350, -0.688180274589474510, -0.688143996742424770, -0.688107717175014950, -0.688071435887335880, +-0.688035152879478140, -0.687998868151532660, -0.687962581703589930, -0.687926293535740090, -0.687890003648075180, -0.687853712040685240, -0.687817418713660980, -0.687781123667093320, +-0.687744826901072750, -0.687708528415690080, -0.687672228211036130, -0.687635926287200940, -0.687599622644276650, -0.687563317282353200, -0.687527010201521630, -0.687490701401872410, +-0.687454390883496470, -0.687418078646484520, -0.687381764690926710, -0.687345449016915190, -0.687309131624539990, -0.687272812513892050, -0.687236491685061960, -0.687200169138140750, +-0.687163844873219020, -0.687127518890387810, -0.687091191189737720, -0.687054861771358990, -0.687018530635343680, -0.686982197781782160, -0.686945863210765120, -0.686909526922383500, +-0.686873188916727880, -0.686836849193888770, -0.686800507753958180, -0.686764164597026380, -0.686727819723184090, -0.686691473132522210, -0.686655124825131690, -0.686618774801103340, +-0.686582423060528080, -0.686546069603496730, -0.686509714430099560, -0.686473357540428820, -0.686436998934574660, -0.686400638612628010, -0.686364276574679690, -0.686327912820820730, +-0.686291547351141950, -0.686255180165733720, -0.686218811264688200, -0.686182440648095640, -0.686146068316046960, -0.686109694268633000, -0.686073318505944880, -0.686036941028073550, +-0.686000561835109820, -0.685964180927144060, -0.685927798304268420, -0.685891413966573270, -0.685855027914149650, -0.685818640147088490, -0.685782250665480710, -0.685745859469417240, +-0.685709466558988570, -0.685673071934286840, -0.685636675595402420, -0.685600277542426250, -0.685563877775449470, -0.685527476294562900, -0.685491073099857800, -0.685454668191424870, +-0.685418261569354700, -0.685381853233739570, -0.685345443184669720, -0.685309031422236310, -0.685272617946530270, -0.685236202757642740, -0.685199785855664660, -0.685163367240686490, +-0.685126946912800520, -0.685090524872097210, -0.685054101118667600, -0.685017675652602740, -0.684981248473993660, -0.684944819582931410, -0.684908388979507230, -0.684871956663812060, +-0.684835522635936280, -0.684799086895972350, -0.684762649444010770, -0.684726210280142470, -0.684689769404458690, -0.684653326817050490, -0.684616882518008340, -0.684580436507424730, +-0.684543988785389910, -0.684507539351995040, -0.684471088207331490, -0.684434635351490070, -0.684398180784562160, -0.684361724506638790, -0.684325266517811110, -0.684288806818169610, +-0.684252345407806770, -0.684215882286812960, -0.684179417455279550, -0.684142950913297580, -0.684106482660958190, -0.684070012698352550, -0.684033541025571350, -0.683997067642706850, +-0.683960592549849760, -0.683924115747091220, -0.683887637234522280, -0.683851157012234310, -0.683814675080318460, -0.683778191438865870, -0.683741706087967140, -0.683705219027714860, +-0.683668730258199410, -0.683632239779512260, -0.683595747591744460, -0.683559253694987380, -0.683522758089332050, -0.683486260774869180, -0.683449761751691360, -0.683413261019889200, +-0.683376758579553820, -0.683340254430776510, -0.683303748573648620, -0.683267241008261310, -0.683230731734705830, -0.683194220753073010, -0.683157708063455220, -0.683121193665943150, +-0.683084677560628180, -0.683048159747601470, -0.683011640226954380, -0.682975118998778160, -0.682938596063163430, -0.682902071420202980, -0.682865545069987200, -0.682829017012607680, +-0.682792487248155670, -0.682755955776722320, -0.682719422598399130, -0.682682887713277340, -0.682646351121448450, -0.682609812823002930, -0.682573272818033480, -0.682536731106630930, +-0.682500187688886540, -0.682463642564891670, -0.682427095734737700, -0.682390547198515440, -0.682353996956317270, -0.682317445008234210, -0.682280891354357540, -0.682244335994778630, +-0.682207778929588950, -0.682171220158879770, -0.682134659682742450, -0.682098097501268600, -0.682061533614548800, -0.682024968022675870, -0.681988400725740520, -0.681951831723834110, +-0.681915261017048140, -0.681878688605473960, -0.681842114489203180, -0.681805538668326380, -0.681768961142936390, -0.681732381913124020, -0.681695800978980750, -0.681659218340597840, +-0.681622633998067000, -0.681586047951479590, -0.681549460200926990, -0.681512870746500130, -0.681476279588291710, -0.681439686726392550, -0.681403092160894230, -0.681366495891888140, +-0.681329897919465970, -0.681293298243718870, -0.681256696864738000, -0.681220093782615940, -0.681183488997443630, -0.681146882509312660, -0.681110274318314500, -0.681073664424540650, +-0.681037052828082580, -0.681000439529031890, -0.680963824527479500, -0.680927207823518230, -0.680890589417238790, -0.680853969308732990, -0.680817347498092310, -0.680780723985408230, +-0.680744098770772240, -0.680707471854275490, -0.680670843236010570, -0.680634212916068740, -0.680597580894541140, -0.680560947171519710, -0.680524311747095930, -0.680487674621361390, +-0.680451035794407580, -0.680414395266326300, -0.680377753037208270, -0.680341109107146510, -0.680304463476232080, -0.680267816144556340, -0.680231167112211210, -0.680194516379288070, +-0.680157863945878070, -0.680121209812073910, -0.680084553977966850, -0.680047896443648380, -0.680011237209210200, -0.679974576274743890, -0.679937913640341170, -0.679901249306093640, +-0.679864583272092980, -0.679827915538430140, -0.679791246105198250, -0.679754574972488260, -0.679717902140391850, -0.679681227609000630, -0.679644551378406400, -0.679607873448700110, +-0.679571193819974660, -0.679534512492321440, -0.679497829465831820, -0.679461144740597600, -0.679424458316710610, -0.679387770194262440, -0.679351080373344800, -0.679314388854049490, +-0.679277695636467560, -0.679241000720692050, -0.679204304106813980, -0.679167605794925300, -0.679130905785117480, -0.679094204077482440, -0.679057500672111790, -0.679020795569096890, +-0.678984088768530560, -0.678947380270504050, -0.678910670075109080, -0.678873958182437450, -0.678837244592580880, -0.678800529305631170, -0.678763812321680260, -0.678727093640819070, +-0.678690373263140740, -0.678653651188736660, -0.678616927417698300, -0.678580201950117700, -0.678543474786086560, -0.678506745925696710, -0.678470015369039390, -0.678433283116207650, +-0.678396549167292750, -0.678359813522386500, -0.678323076181580610, -0.678286337144967110, -0.678249596412637710, -0.678212853984684340, -0.678176109861198920, -0.678139364042272490, +-0.678102616527998300, -0.678065867318467630, -0.678029116413772170, -0.677992363814004070, -0.677955609519254930, -0.677918853529616230, -0.677882095845181000, -0.677845336466040500, +-0.677808575392286670, -0.677771812624011430, -0.677735048161306590, -0.677698282004264190, -0.677661514152976040, -0.677624744607534190, -0.677587973368029780, -0.677551200434556080, +-0.677514425807204330, -0.677477649486066590, -0.677440871471234770, -0.677404091762800700, -0.677367310360855730, -0.677330527265493140, -0.677293742476804290, -0.677256955994881120, +-0.677220167819815420, -0.677183377951699360, -0.677146586390624860, -0.677109793136683960, -0.677072998189968470, -0.677036201550569870, -0.676999403218581430, -0.676962603194094510, +-0.676925801477201050, -0.676888998067993080, -0.676852192966562630, -0.676815386173001740, -0.676778577687401680, -0.676741767509855820, -0.676704955640455630, -0.676668142079292930, +-0.676631326826459880, -0.676594509882048610, -0.676557691246150950, -0.676520870918859150, -0.676484048900264480, -0.676447225190460410, -0.676410399789538210, -0.676373572697590020, +-0.676336743914707880, -0.676299913440983950, -0.676263081276510250, -0.676226247421378050, -0.676189411875681050, -0.676152574639510400, -0.676115735712958350, -0.676078895096116960, +-0.676042052789078360, -0.676005208791934600, -0.675968363104777810, -0.675931515727700160, -0.675894666660793010, -0.675857815904149840, -0.675820963457862130, -0.675784109322022040, +-0.675747253496721710, -0.675710395982053290, -0.675673536778108150, -0.675636675884979780, -0.675599813302759760, -0.675562949031540240, -0.675526083071413370, -0.675489215422471200, +-0.675452346084806090, -0.675415475058509960, -0.675378602343675300, -0.675341727940393380, -0.675304851848757880, -0.675267974068860190, -0.675231094600792560, -0.675194213444647250, +-0.675157330600516410, -0.675120446068491530, -0.675083559848666190, -0.675046671941131990, -0.675009782345981080, -0.674972891063305820, -0.674935998093198150, -0.674899103435750660, +-0.674862207091055270, -0.674825309059204460, -0.674788409340289720, -0.674751507934404530, -0.674714604841640590, -0.674677700062090270, -0.674640793595845500, -0.674603885442998870, +-0.674566975603642540, -0.674530064077868090, -0.674493150865769110, -0.674456235967437310, -0.674419319382964840, -0.674382401112444070, -0.674345481155967370, -0.674308559513626890, +-0.674271636185515110, -0.674234711171723510, -0.674197784472345800, -0.674160856087473670, -0.674123926017199280, -0.674086994261615220, -0.674050060820813530, -0.674013125694886810, +-0.673976188883926630, -0.673939250388026600, -0.673902310207278420, -0.673865368341774460, -0.673828424791607090, -0.673791479556868690, -0.673754532637651500, -0.673717584034048130, +-0.673680633746150730, -0.673643681774050980, -0.673606728117842830, -0.673569772777617870, -0.673532815753468350, -0.673495857045486870, -0.673458896653765680, -0.673421934578396720, +-0.673384970819473460, -0.673348005377087830, -0.673311038251332210, -0.673274069442298950, -0.673237098950080550, -0.673200126774769370, -0.673163152916457900, -0.673126177375238500, +-0.673089200151202990, -0.673052221244445190, -0.673015240655056910, -0.672978258383130410, -0.672941274428758280, -0.672904288792033010, -0.672867301473046410, -0.672830312471892070, +-0.672793321788662020, -0.672756329423448650, -0.672719335376344540, -0.672682339647441950, -0.672645342236833590, -0.672608343144611930, -0.672571342370869350, -0.672534339915697780, +-0.672497335779191020, -0.672460329961440890, -0.672423322462539890, -0.672386313282580690, -0.672349302421655580, -0.672312289879857250, -0.672275275657277630, -0.672238259754010410, +-0.672201242170147540, -0.672164222905781590, -0.672127201961005170, -0.672090179335910640, -0.672053155030590600, -0.672016129045137740, -0.671979101379643890, -0.671942072034202980, +-0.671905041008906910, -0.671868008303848190, -0.671830973919119500, -0.671793937854813340, -0.671756900111022290, -0.671719860687838400, -0.671682819585355470, -0.671645776803665550, +-0.671608732342861110, -0.671571686203034870, -0.671534638384279400, -0.671497588886687420, -0.671460537710351410, -0.671423484855363300, -0.671386430321817330, -0.671349374109805110, +-0.671312316219419560, -0.671275256650753160, -0.671238195403898620, -0.671201132478948640, -0.671164067875995140, -0.671127001595132170, -0.671089933636451640, -0.671052864000046380, +-0.671015792686008860, -0.670978719694431900, -0.670941645025408100, -0.670904568679030140, -0.670867490655390860, -0.670830410954582180, -0.670793329576698130, -0.670756246521830750, +-0.670719161790072740, -0.670682075381516810, -0.670644987296255660, -0.670607897534381440, -0.670570806095988180, -0.670533712981167820, -0.670496618190013270, -0.670459521722617140, +-0.670422423579072110, -0.670385323759471130, -0.670348222263906780, -0.670311119092471990, -0.670274014245258560, -0.670236907722360890, -0.670199799523870880, -0.670162689649881460, +-0.670125578100485230, -0.670088464875775110, -0.670051349975843810, -0.670014233400783480, -0.669977115150688140, -0.669939995225650180, -0.669902873625762060, -0.669865750351116840, +-0.669828625401807320, -0.669791498777926100, -0.669754370479566210, -0.669717240506819690, -0.669680108859780800, -0.669642975538541570, -0.669605840543194940, -0.669568703873833710, +-0.669531565530550710, -0.669494425513438740, -0.669457283822590070, -0.669420140458098940, -0.669382995420057410, -0.669345848708558290, -0.669308700323694720, -0.669271550265559290, +-0.669234398534245050, -0.669197245129844690, -0.669160090052450700, -0.669122933302157110, -0.669085774879056070, -0.669048614783240740, -0.669011453014803800, -0.668974289573838200, +-0.668937124460436960, -0.668899957674692240, -0.668862789216698280, -0.668825619086547360, -0.668788447284332290, -0.668751273810146210, -0.668714098664081820, -0.668676921846232290, +-0.668639743356690520, -0.668602563195549230, -0.668565381362901000, -0.668528197858839990, -0.668491012683458340, -0.668453825836849310, -0.668416637319105610, -0.668379447130320380, +-0.668342255270585770, -0.668305061739996380, -0.668267866538644120, -0.668230669666622370, -0.668193471124023830, -0.668156270910941650, -0.668119069027468760, -0.668081865473698300, +-0.668044660249723090, -0.668007453355635490, -0.667970244791530110, -0.667933034557498970, -0.667895822653635340, -0.667858609080032140, -0.667821393836782300, -0.667784176923979070, +-0.667746958341714820, -0.667709738090083720, -0.667672516169178330, -0.667635292579091600, -0.667598067319916670, -0.667560840391746570, -0.667523611794674340, -0.667486381528793030, +-0.667449149594195210, -0.667411915990975160, -0.667374680719225340, -0.667337443779038700, -0.667300205170508590, -0.667262964893727940, -0.667225722948789790, -0.667188479335786730, +-0.667151234054813140, -0.667113987105961480, -0.667076738489324810, -0.667039488204996370, -0.667002236253069090, -0.666964982633636350, -0.666927727346791070, -0.666890470392625830, +-0.666853211771235130, -0.666815951482711330, -0.666778689527147690, -0.666741425904637250, -0.666704160615273270, -0.666666893659149000, -0.666629625036356700, -0.666592354746991080, +-0.666555082791144500, -0.666517809168910350, -0.666480533880381530, -0.666443256925651430, -0.666405978304813180, -0.666368698017960060, -0.666331416065185090, -0.666294132446580980, +-0.666256847162242210, -0.666219560212261250, -0.666182271596731490, -0.666144981315745950, -0.666107689369398010, -0.666070395757780150, -0.666033100480986960, -0.665995803539111140, +-0.665958504932245620, -0.665921204660483990, -0.665883902723919290, -0.665846599122644880, -0.665809293856753910, -0.665771986926339760, -0.665734678331494910, -0.665697368072314060, +-0.665660056148889790, -0.665622742561315480, -0.665585427309684170, -0.665548110394089340, -0.665510791814624250, -0.665473471571381480, -0.665436149664455740, -0.665398826093939630, +-0.665361500859926400, -0.665324173962509420, -0.665286845401782070, -0.665249515177837590, -0.665212183290769250, -0.665174849740669870, -0.665137514527634030, -0.665100177651754330, +-0.665062839113124250, -0.665025498911837040, -0.664988157047986080, -0.664950813521664740, -0.664913468332965720, -0.664876121481983720, -0.664838772968811330, -0.664801422793542150, +-0.664764070956269220, -0.664726717457086220, -0.664689362296086440, -0.664652005473363230, -0.664614646989009410, -0.664577286843119560, -0.664539925035786520, -0.664502561567103630, +-0.664465196437164400, -0.664427829646062060, -0.664390461193890220, -0.664353091080741590, -0.664315719306710850, -0.664278345871890830, -0.664240970776375010, -0.664203594020256750, +-0.664166215603629430, -0.664128835526586640, -0.664091453789221630, -0.664054070391628120, -0.664016685333898790, -0.663979298616128370, -0.663941910238409650, -0.663904520200836230, +-0.663867128503501380, -0.663829735146498790, -0.663792340129921280, -0.663754943453863430, -0.663717545118418410, -0.663680145123679340, -0.663642743469740060, -0.663605340156693810, +-0.663567935184634310, -0.663530528553654910, -0.663493120263849210, -0.663455710315309920, -0.663418298708132180, -0.663380885442408590, -0.663343470518232840, -0.663306053935698410, +-0.663268635694898910, -0.663231215795927700, -0.663193794238877920, -0.663156371023844170, -0.663118946150919600, -0.663081519620197680, -0.663044091431771900, -0.663006661585735850, +-0.662969230082183230, -0.662931796921207520, -0.662894362102901650, -0.662856925627360540, -0.662819487494677120, -0.662782047704944980, -0.662744606258257600, -0.662707163154708900, +-0.662669718394392150, -0.662632271977400490, -0.662594823903828840, -0.662557374173770140, -0.662519922787317970, -0.662482469744565930, -0.662445015045607820, -0.662407558690537130, +-0.662370100679447570, -0.662332641012432060, -0.662295179689585620, -0.662257716711001310, -0.662220252076772600, -0.662182785786993300, -0.662145317841757010, -0.662107848241157430, +-0.662070376985287590, -0.662032904074242530, -0.661995429508115070, -0.661957953286999130, -0.661920475410988310, -0.661882995880176290, -0.661845514694656800, -0.661808031854523530, +-0.661770547359870060, -0.661733061210789670, -0.661695573407377280, -0.661658083949725920, -0.661620592837929400, -0.661583100072081320, -0.661545605652275600, -0.661508109578605170, +-0.661470611851165070, -0.661433112470048550, -0.661395611435349080, -0.661358108747160720, -0.661320604405577050, -0.661283098410691880, -0.661245590762598920, -0.661208081461391980, +-0.661170570507164210, -0.661133057900010760, -0.661095543640024540, -0.661058027727299490, -0.661020510161929420, -0.660982990944008030, -0.660945470073629140, -0.660907947550885890, +-0.660870423375873540, -0.660832897548685020, -0.660795370069414360, -0.660757840938155260, -0.660720310155001430, -0.660682777720047020, -0.660645243633385500, -0.660607707895110360, +-0.660570170505316520, -0.660532631464097240, -0.660495090771546330, -0.660457548427757830, -0.660420004432825450, -0.660382458786842990, -0.660344911489903710, -0.660307362542102870, +-0.660269811943533510, -0.660232259694289780, -0.660194705794465260, -0.660157150244154110, -0.660119593043450030, -0.660082034192446930, -0.660044473691238090, -0.660006911539918750, +-0.659969347738582180, -0.659931782287322190, -0.659894215186232700, -0.659856646435407760, -0.659819076034941170, -0.659781503984926190, -0.659743930285458080, -0.659706354936630210, +-0.659668777938536510, -0.659631199291270790, -0.659593618994927080, -0.659556037049599310, -0.659518453455381510, -0.659480868212367510, -0.659443281320650660, -0.659405692780326350, +-0.659368102591487810, -0.659330510754228990, -0.659292917268643810, -0.659255322134826400, -0.659217725352870040, -0.659180126922870090, -0.659142526844919700, -0.659104925119113010, +-0.659067321745544050, -0.659029716724306770, -0.658992110055495180, -0.658954501739203340, -0.658916891775525260, -0.658879280164554330, -0.658841666906385790, -0.658804052001113140, +-0.658766435448830290, -0.658728817249631390, -0.658691197403610370, -0.658653575910861490, -0.658615952771477890, -0.658578327985555160, -0.658540701553186560, -0.658503073474466240, +-0.658465443749488230, -0.658427812378346580, -0.658390179361135420, -0.658352544697948790, -0.658314908388880180, -0.658277270434024950, -0.658239630833476470, -0.658201989587329010, +-0.658164346695676580, -0.658126702158613240, -0.658089055976233130, -0.658051408148629720, -0.658013758675898510, -0.657976107558132850, -0.657938454795426900, -0.657900800387874910, +-0.657863144335570800, -0.657825486638608960, -0.657787827297083290, -0.657750166311087400, -0.657712503680716880, -0.657674839406064970, -0.657637173487225950, -0.657599505924294060, +-0.657561836717363460, -0.657524165866528180, -0.657486493371881810, -0.657448819233519940, -0.657411143451535950, -0.657373466026024200, -0.657335786957078730, -0.657298106244793790, +-0.657260423889263530, -0.657222739890582330, -0.657185054248844210, -0.657147366964142780, -0.657109678036573610, -0.657071987466230190, -0.657034295253206890, -0.656996601397597860, +-0.656958905899497240, -0.656921208758998730, -0.656883509976197820, -0.656845809551188210, -0.656808107484064040, -0.656770403774919690, -0.656732698423849180, -0.656694991430947010, +-0.656657282796307420, -0.656619572520024560, -0.656581860602192040, -0.656544147042905650, -0.656506431842258760, -0.656468715000345870, -0.656430996517261220, -0.656393276393099080, +-0.656355554627953030, -0.656317831221918780, -0.656280106175089920, -0.656242379487560920, -0.656204651159425830, -0.656166921190779130, -0.656129189581715180, -0.656091456332328240, +-0.656053721442712680, -0.656015984912962090, -0.655978246743172290, -0.655940506933436750, -0.655902765483850070, -0.655865022394506390, -0.655827277665500200, -0.655789531296925850, +-0.655751783288876950, -0.655714033641449310, -0.655676282354736520, -0.655638529428833050, -0.655600774863833280, -0.655563018659831460, -0.655525260816922200, -0.655487501335199840, +-0.655449740214757990, -0.655411977455692460, -0.655374213058096950, -0.655336447022065950, -0.655298679347693810, -0.655260910035075030, -0.655223139084303850, -0.655185366495474320, +-0.655147592268681910, -0.655109816404020550, -0.655072038901584720, -0.655034259761468670, -0.654996478983767120, -0.654958696568574310, -0.654920912515984720, -0.654883126826092840, +-0.654845339498992480, -0.654807550534779460, -0.654769759933547580, -0.654731967695391330, -0.654694173820405180, -0.654656378308683510, -0.654618581160320230, -0.654580782375411170, +-0.654542981954050250, -0.654505179896331720, -0.654467376202350400, -0.654429570872200550, -0.654391763905976750, -0.654353955303773600, -0.654316145065685580, -0.654278333191806390, +-0.654240519682232180, -0.654202704537056650, -0.654164887756374270, -0.654127069340279750, -0.654089249288867580, -0.654051427602231560, -0.654013604280467620, -0.653975779323669790, +-0.653937952731932450, -0.653900124505350180, -0.653862294644017570, -0.653824463148029330, -0.653786630017479830, -0.653748795252463880, -0.653710958853075170, -0.653673120819409760, +-0.653635281151561550, -0.653597439849625150, -0.653559596913695140, -0.653521752343866110, -0.653483906140232770, -0.653446058302888930, -0.653408208831930630, -0.653370357727451890, +-0.653332504989547090, -0.653294650618311160, -0.653256794613838570, -0.653218936976224020, -0.653181077705562110, -0.653143216801946870, -0.653105354265474110, -0.653067490096238100, +-0.653029624294333310, -0.652991756859854560, -0.652953887792896310, -0.652916017093553290, -0.652878144761919630, -0.652840270798091370, -0.652802395202162320, -0.652764517974227300, +-0.652726639114381000, -0.652688758622718130, -0.652650876499333290, -0.652612992744321390, -0.652575107357776910, -0.652537220339794000, -0.652499331690468700, -0.652461441409895040, +-0.652423549498167830, -0.652385655955381780, -0.652347760781631480, -0.652309863977011180, -0.652271965541616930, -0.652234065475542750, -0.652196163778883340, -0.652158260451733530, +-0.652120355494188120, -0.652082448906341820, -0.652044540688289320, -0.652006630840125560, -0.651968719361944560, -0.651930806253842370, -0.651892891515913230, -0.651854975148251750, +-0.651817057150952950, -0.651779137524111430, -0.651741216267821440, -0.651703293382179030, -0.651665368867278440, -0.651627442723214380, -0.651589514950081770, -0.651551585547975320, +-0.651513654516989950, -0.651475721857220470, -0.651437787568761580, -0.651399851651707660, -0.651361914106154740, -0.651323974932197070, -0.651286034129929360, -0.651248091699446640, +-0.651210147640843730, -0.651172201954215320, -0.651134254639655910, -0.651096305697261400, -0.651058355127126180, -0.651020402929345040, -0.650982449104012930, -0.650944493651224640, +-0.650906536571075220, -0.650868577863659370, -0.650830617529071450, -0.650792655567407620, -0.650754691978762120, -0.650716726763230000, -0.650678759920905960, -0.650640791451885030, +-0.650602821356262240, -0.650564849634131640, -0.650526876285589580, -0.650488901310730340, -0.650450924709648830, -0.650412946482439970, -0.650374966629198800, -0.650336985150020250, +-0.650299002044999240, -0.650261017314230030, -0.650223030957808870, -0.650185042975830240, -0.650147053368388850, -0.650109062135579950, -0.650071069277498470, -0.650033074794239220, +-0.649995078685896570, -0.649957080952566990, -0.649919081594344640, -0.649881080611324550, -0.649843078003601860, -0.649805073771271390, -0.649767067914428290, -0.649729060433167470, +-0.649691051327584090, -0.649653040597772400, -0.649615028243828660, -0.649577014265847460, -0.649538998663923730, -0.649500981438152380, -0.649462962588628680, -0.649424942115446880, +-0.649386920018703460, -0.649348896298492680, -0.649310870954909580, -0.649272843988049410, -0.649234815398007200, -0.649196785184877780, -0.649158753348756500, -0.649120719889738300, +-0.649082684807917640, -0.649044648103390910, -0.649006609776252570, -0.648968569826597790, -0.648930528254521470, -0.648892485060118980, -0.648854440243485150, -0.648816393804714560, +-0.648778345743903690, -0.648740296061146910, -0.648702244756539370, -0.648664191830176320, -0.648626137282152790, -0.648588081112563830, -0.648550023321504690, -0.648511963909069840, +-0.648473902875355780, -0.648435840220456860, -0.648397775944468460, -0.648359710047485600, -0.648321642529603450, -0.648283573390917130, -0.648245502631521250, -0.648207430251512280, +-0.648169356250984710, -0.648131280630033780, -0.648093203388754760, -0.648055124527242570, -0.648017044045592570, -0.647978961943900030, -0.647940878222259430, -0.647902792880767240, +-0.647864705919518170, -0.647826617338607250, -0.647788527138129840, -0.647750435318180990, -0.647712341878856180, -0.647674246820249770, -0.647636150142458460, -0.647598051845576840, +-0.647559951929699950, -0.647521850394923270, -0.647483747241341940, -0.647445642469051230, -0.647407536078146490, -0.647369428068722770, -0.647331318440874880, -0.647293207194699400, +-0.647255094330290830, -0.647216979847744620, -0.647178863747155940, -0.647140746028620040, -0.647102626692231620, -0.647064505738087270, -0.647026383166281800, -0.646988258976910260, +-0.646950133170068110, -0.646912005745850620, -0.646873876704353030, -0.646835746045670850, -0.646797613769899300, -0.646759479877133000, -0.646721344367468640, -0.646683207241001030, +-0.646645068497825330, -0.646606928138037000, -0.646568786161731300, -0.646530642569003610, -0.646492497359948740, -0.646454350534663270, -0.646416202093241910, -0.646378052035780030, +-0.646339900362372990, -0.646301747073116270, -0.646263592168105140, -0.646225435647435060, -0.646187277511200640, -0.646149117759498790, -0.646110956392424110, -0.646072793410072070, +-0.646034628812538040, -0.645996462599917390, -0.645958294772305600, -0.645920125329797370, -0.645881954272489620, -0.645843781600476840, -0.645805607313854720, -0.645767431412718530, +-0.645729253897163740, -0.645691074767285930, -0.645652894023180270, -0.645614711664941780, -0.645576527692667160, -0.645538342106451330, -0.645500154906389570, -0.645461966092577330, +-0.645423775665110330, -0.645385583624083830, -0.645347389969592620, -0.645309194701733650, -0.645270997820601710, -0.645232799326292290, -0.645194599218900880, -0.645156397498523050, +-0.645118194165254070, -0.645079989219189630, -0.645041782660425330, -0.645003574489055760, -0.644965364705178070, -0.644927153308886840, -0.644888940300277770, -0.644850725679446460, +-0.644812509446488160, -0.644774291601498020, -0.644736072144572740, -0.644697851075807350, -0.644659628395297330, -0.644621404103138280, -0.644583178199425680, -0.644544950684255100, +-0.644506721557722150, -0.644468490819922410, -0.644430258470950810, -0.644392024510904160, -0.644353788939877490, -0.644315551757966400, -0.644277312965266360, -0.644239072561873070, +-0.644200830547882020, -0.644162586923388350, -0.644124341688488760, -0.644086094843278390, -0.644047846387852730, -0.644009596322307590, -0.643971344646738330, -0.643933091361240770, +-0.643894836465910390, -0.643856579960842330, -0.643818321846133520, -0.643780062121878880, -0.643741800788174000, -0.643703537845114690, -0.643665273292796550, -0.643627007131315270, +-0.643588739360765660, -0.643550469981244990, -0.643512198992848060, -0.643473926395670690, -0.643435652189808470, -0.643397376375357210, -0.643359098952412390, -0.643320819921069930, +-0.643282539281424650, -0.643244257033573800, -0.643205973177612190, -0.643167687713635750, -0.643129400641740070, -0.643091111962020840, -0.643052821674573780, -0.643014529779494140, +-0.642976236276878720, -0.642937941166822790, -0.642899644449421940, -0.642861346124772080, -0.642823046192968820, -0.642784744654107840, -0.642746441508285080, -0.642708136755596240, +-0.642669830396136450, -0.642631522430002660, -0.642593212857289990, -0.642554901678094370, -0.642516588892511510, -0.642478274500637210, -0.642439958502566520, -0.642401640898396580, +-0.642363321688222520, -0.642325000872140170, -0.642286678450245450, -0.642248354422633840, -0.642210028789401480, -0.642171701550643960, -0.642133372706457210, -0.642095042256936370, +-0.642056710202178580, -0.642018376542279110, -0.641980041277333550, -0.641941704407437920, -0.641903365932688150, -0.641865025853179840, -0.641826684169008340, -0.641788340880270810, +-0.641749995987062390, -0.641711649489479010, -0.641673301387616470, -0.641634951681570700, -0.641596600371437620, -0.641558247457312940, -0.641519892939292010, -0.641481536817472000, +-0.641443179091948150, -0.641404819762816380, -0.641366458830172630, -0.641328096294112580, -0.641289732154732390, -0.641251366412127210, -0.641212999066394170, -0.641174630117628760, +-0.641136259565926680, -0.641097887411384070, -0.641059513654096640, -0.641021138294160410, -0.640982761331671420, -0.640944382766724830, -0.640906002599417880, -0.640867620829846050, +-0.640829237458105050, -0.640790852484291020, -0.640752465908499880, -0.640714077730827560, -0.640675687951369310, -0.640637296570222610, -0.640598903587482620, -0.640560509003245350, +-0.640522112817606850, -0.640483715030663040, -0.640445315642509950, -0.640406914653243510, -0.640368512062959860, -0.640330107871754260, -0.640291702079724080, -0.640253294686964570, +-0.640214885693571880, -0.640176475099641930, -0.640138062905270870, -0.640099649110553950, -0.640061233715588540, -0.640022816720470010, -0.639984398125294510, -0.639945977930157950, +-0.639907556135156600, -0.639869132740386260, -0.639830707745943080, -0.639792281151923100, -0.639753852958421800, -0.639715423165536530, -0.639676991773362680, -0.639638558781996380, +-0.639600124191533670, -0.639561688002070580, -0.639523250213703380, -0.639484810826527310, -0.639446369840639960, -0.639407927256136600, -0.639369483073113480, -0.639331037291666630, +-0.639292589911892200, -0.639254140933886330, -0.639215690357745060, -0.639177238183563870, -0.639138784411440340, -0.639100329041469740, -0.639061872073748430, -0.639023413508372330, +-0.638984953345437810, -0.638946491585040800, -0.638908028227276990, -0.638869563272243650, -0.638831096720036570, -0.638792628570751590, -0.638754158824485160, -0.638715687481333230, +-0.638677214541392150, -0.638638740004758070, -0.638600263871526350, -0.638561786141794710, -0.638523306815658610, -0.638484825893214200, -0.638446343374557860, -0.638407859259785490, +-0.638369373548993590, -0.638330886242277520, -0.638292397339734970, -0.638253906841461330, -0.638215414747552940, -0.638176921058106080, -0.638138425773216890, -0.638099928892981620, +-0.638061430417496630, -0.638022930346857970, -0.637984428681161340, -0.637945925420504210, -0.637907420564982400, -0.637868914114691930, -0.637830406069729290, -0.637791896430190520, +-0.637753385196171420, -0.637714872367769470, -0.637676357945080370, -0.637637841928200390, -0.637599324317225770, -0.637560805112252880, -0.637522284313377980, -0.637483761920697330, +-0.637445237934307300, -0.637406712354303570, -0.637368185180783640, -0.637329656413843200, -0.637291126053578740, -0.637252594100086390, -0.637214060553462640, -0.637175525413803620, +-0.637136988681205160, -0.637098450355764960, -0.637059910437578590, -0.637021368926742440, -0.636982825823352860, -0.636944281127506230, -0.636905734839298910, -0.636867186958827160, +-0.636828637486186900, -0.636790086421475610, -0.636751533764789210, -0.636712979516223960, -0.636674423675876230, -0.636635866243842390, -0.636597307220218900, -0.636558746605101480, +-0.636520184398587930, -0.636481620600773850, -0.636443055211755810, -0.636404488231630090, -0.636365919660493050, -0.636327349498441390, -0.636288777745571240, -0.636250204401978440, +-0.636211629467760890, -0.636173052943014180, -0.636134474827834920, -0.636095895122319450, -0.636057313826564160, -0.636018730940665740, -0.635980146464719680, -0.635941560398823990, +-0.635902972743074390, -0.635864383497567350, -0.635825792662399360, -0.635787200237666880, -0.635748606223466520, -0.635710010619894520, -0.635671413427047470, -0.635632814645021300, +-0.635594214273913720, -0.635555612313820630, -0.635517008764838410, -0.635478403627063760, -0.635439796900593050, -0.635401188585522190, -0.635362578681949120, -0.635323967189969530, +-0.635285354109680010, -0.635246739441177160, -0.635208123184557440, -0.635169505339917340, -0.635130885907353560, -0.635092264886962580, -0.635053642278840200, -0.635015018083084360, +-0.634976392299791080, -0.634937764929056740, -0.634899135970978020, -0.634860505425651530, -0.634821873293172970, -0.634783239573640470, -0.634744604267149850, -0.634705967373797700, +-0.634667328893680720, -0.634628688826895380, -0.634590047173538290, -0.634551403933706020, -0.634512759107495380, -0.634474112695002090, -0.634435464696324170, -0.634396815111557650, +-0.634358163940799020, -0.634319511184145090, -0.634280856841692330, -0.634242200913537340, -0.634203543399776250, -0.634164884300506990, -0.634126223615825490, -0.634087561345828440, +-0.634048897490612550, -0.634010232050274290, -0.633971565024910590, -0.633932896414617920, -0.633894226219492320, -0.633855554439631820, -0.633816881075132450, -0.633778206126090820, +-0.633739529592603820, -0.633700851474767850, -0.633662171772679810, -0.633623490486435630, -0.633584807616133450, -0.633546123161869310, -0.633507437123739690, -0.633468749501841620, +-0.633430060296271690, -0.633391369507126490, -0.633352677134502940, -0.633313983178497630, -0.633275287639206820, -0.633236590516728310, -0.633197891811158490, -0.633159191522593810, +-0.633120489651131210, -0.633081786196867390, -0.633043081159898380, -0.633004374540322320, -0.632965666338235370, -0.632926956553734320, -0.632888245186915780, -0.632849532237876660, +-0.632810817706713770, -0.632772101593523820, -0.632733383898403500, -0.632694664621449190, -0.632655943762758800, -0.632617221322428590, -0.632578497300555260, -0.632539771697235740, +-0.632501044512566830, -0.632462315746644580, -0.632423585399567220, -0.632384853471430920, -0.632346119962332480, -0.632307384872368820, -0.632268648201636530, -0.632229909950232760, +-0.632191170118254100, -0.632152428705797580, -0.632113685712959340, -0.632074941139837530, -0.632036194986528410, -0.631997447253128670, -0.631958697939735470, -0.631919947046445500, +-0.631881194573355560, -0.631842440520562040, -0.631803684888163080, -0.631764927676254920, -0.631726168884934380, -0.631687408514298500, -0.631648646564444080, -0.631609883035467940, +-0.631571117927467230, -0.631532351240537970, -0.631493582974778530, -0.631454813130285180, -0.631416041707154710, -0.631377268705484270, -0.631338494125370580, -0.631299717966910650, +-0.631260940230200740, -0.631222160915339110, -0.631183380022422140, -0.631144597551546730, -0.631105813502809810, -0.631067027876308310, -0.631028240672139250, -0.630989451890399680, +-0.630950661531186400, -0.630911869594595780, -0.630873076080726180, -0.630834280989673980, -0.630795484321535980, -0.630756686076409330, -0.630717886254390960, -0.630679084855577110, +-0.630640281880066270, -0.630601477327954680, -0.630562671199339510, -0.630523863494317660, -0.630485054212986060, -0.630446243355441860, -0.630407430921782090, -0.630368616912103660, +-0.630329801326503070, -0.630290984165078670, -0.630252165427926720, -0.630213345115144490, -0.630174523226828760, -0.630135699763076820, -0.630096874723984900, -0.630058048109651490, +-0.630019219920172960, -0.629980390155646440, -0.629941558816168870, -0.629902725901837380, -0.629863891412749120, -0.629825055349001130, -0.629786217710690540, -0.629747378497913730, +-0.629708537710769070, -0.629669695349353130, -0.629630851413762960, -0.629592005904095590, -0.629553158820448270, -0.629514310162918030, -0.629475459931601260, -0.629436608126596630, +-0.629397754748000420, -0.629358899795909870, -0.629320043270422010, -0.629281185171634120, -0.629242325499643210, -0.629203464254546540, -0.629164601436440480, -0.629125737045423630, +-0.629086871081592450, -0.629048003545044090, -0.629009134435875690, -0.628970263754184410, -0.628931391500067490, -0.628892517673621420, -0.628853642274944780, -0.628814765304134050, +-0.628775886761286370, -0.628737006646499010, -0.628698124959869100, -0.628659241701493790, -0.628620356871470550, -0.628581470469896320, -0.628542582496867670, -0.628503692952483320, +-0.628464801836839730, -0.628425909150034160, -0.628387014892163860, -0.628348119063325880, -0.628309221663617020, -0.628270322693135760, -0.628231422151978690, -0.628192520040243170, +-0.628153616358026250, -0.628114711105425270, -0.628075804282537510, -0.628036895889460320, -0.627997985926290860, -0.627959074393125700, -0.627920161290063560, -0.627881246617201020, +-0.627842330374635330, -0.627803412562463970, -0.627764493180783870, -0.627725572229691940, -0.627686649709286780, -0.627647725619664980, -0.627608799960923890, -0.627569872733160780, +-0.627530943936473020, -0.627492013570957850, -0.627453081636712760, -0.627414148133834780, -0.627375213062420830, -0.627336276422569620, -0.627297338214377610, -0.627258398437942290, +-0.627219457093361020, -0.627180514180731060, -0.627141569700149780, -0.627102623651713880, -0.627063676035522160, -0.627024726851671320, -0.626985776100258520, -0.626946823781381330, +-0.626907869895137140, -0.626868914441623290, -0.626829957420937060, -0.626790998833175240, -0.626752038678436650, -0.626713076956817990, -0.626674113668416630, -0.626635148813330050, +-0.626596182391655490, -0.626557214403490550, -0.626518244848931820, -0.626479273728078100, -0.626440301041026330, -0.626401326787873750, -0.626362350968717950, -0.626323373583656200, +-0.626284394632785960, -0.626245414116204820, -0.626206432034009390, -0.626167448386298560, -0.626128463173169170, -0.626089476394718570, -0.626050488051044350, -0.626011498142243770, +-0.625972506668414640, -0.625933513629653440, -0.625894519026059190, -0.625855522857728610, -0.625816525124759160, -0.625777525827248440, -0.625738524965294030, -0.625699522538993190, +-0.625660518548443510, -0.625621512993742580, -0.625582505874987200, -0.625543497192276200, -0.625504486945706590, -0.625465475135375650, -0.625426461761380950, -0.625387446823820190, +-0.625348430322790190, -0.625309412258389650, -0.625270392630715710, -0.625231371439865740, -0.625192348685937320, -0.625153324369028040, -0.625114298489235500, -0.625075271046657170, +-0.625036242041390630, -0.624997211473532820, -0.624958179343182650, -0.624919145650437050, -0.624880110395393600, -0.624841073578149890, -0.624802035198803510, -0.624762995257452050, +-0.624723953754192320, -0.624684910689123460, -0.624645866062342290, -0.624606819873946510, -0.624567772124033580, -0.624528722812701330, -0.624489671940047230, -0.624450619506168980, +-0.624411565511163390, -0.624372509955129720, -0.624333452838164660, -0.624294394160366030, -0.624255333921831410, -0.624216272122658400, -0.624177208762944800, -0.624138143842787430, +-0.624099077362285430, -0.624060009321535710, -0.624020939720635990, -0.623981868559683850, -0.623942795838777100, -0.623903721558013320, -0.623864645717490340, -0.623825568317304960, +-0.623786489357556320, -0.623747408838341570, -0.623708326759758180, -0.623669243121904080, -0.623630157924876750, -0.623591071168774100, -0.623551982853693070, -0.623512892979732780, +-0.623473801546990280, -0.623434708555563270, -0.623395614005549440, -0.623356517897046600, -0.623317420230152570, -0.623278321004964830, -0.623239220221581400, -0.623200117880099100, +-0.623161013980617300, -0.623121908523233010, -0.623082801508043850, -0.623043692935147720, -0.623004582804642330, -0.622965471116624810, -0.622926357871194320, -0.622887243068448000, +-0.622848126708483440, -0.622809008791398670, -0.622769889317291270, -0.622730768286259280, -0.622691645698400300, -0.622652521553812230, -0.622613395852592120, -0.622574268594839220, +-0.622535139780650670, -0.622496009410124280, -0.622456877483357870, -0.622417744000449250, -0.622378608961496220, -0.622339472366596040, -0.622300334215847850, -0.622261194509348800, +-0.622222053247196820, -0.622182910429489700, -0.622143766056325260, -0.622104620127801430, -0.622065472644016020, -0.622026323605066270, -0.621987173011051440, -0.621948020862068570, +-0.621908867158215810, -0.621869711899590730, -0.621830555086291480, -0.621791396718415770, -0.621752236796060840, -0.621713075319326070, -0.621673912288308710, -0.621634747703106450, +-0.621595581563817330, -0.621556413870539280, -0.621517244623370100, -0.621478073822407940, -0.621438901467749830, -0.621399727559495240, -0.621360552097741210, -0.621321375082585890, +-0.621282196514127080, -0.621243016392462820, -0.621203834717691030, -0.621164651489908960, -0.621125466709215980, -0.621086280375709230, -0.621047092489486860, -0.621007903050646680, +-0.620968712059286830, -0.620929519515505120, -0.620890325419399700, -0.620851129771068490, -0.620811932570608630, -0.620772733818119700, -0.620733533513698980, -0.620694331657444360, +-0.620655128249453900, -0.620615923289825620, -0.620576716778656890, -0.620537508716047070, -0.620498299102093420, -0.620459087936894080, -0.620419875220546980, -0.620380660953150250, +-0.620341445134801830, -0.620302227765599850, -0.620263008845642230, -0.620223788375026340, -0.620184566353851770, -0.620145342782215780, -0.620106117660216390, -0.620066890987951760, +-0.620027662765519790, -0.619988432993018760, -0.619949201670545900, -0.619909968798200820, -0.619870734376080760, -0.619831498404283860, -0.619792260882908290, -0.619753021812051940, +-0.619713781191813080, -0.619674539022289860, -0.619635295303579530, -0.619596050035781550, -0.619556803218993650, -0.619517554853313610, -0.619478304938839710, -0.619439053475670080, +-0.619399800463902750, -0.619360545903635210, -0.619321289794967030, -0.619282032137995710, -0.619242772932819260, -0.619203512179535840, -0.619164249878243700, -0.619124986029040870, +-0.619085720632025600, -0.619046453687295270, -0.619007185194949570, -0.618967915155085980, -0.618928643567802530, -0.618889370433197470, -0.618850095751368960, -0.618810819522415230, +-0.618771541746433780, -0.618732262423524080, -0.618692981553783830, -0.618653699137311160, -0.618614415174204120, -0.618575129664561070, -0.618535842608480270, -0.618496554006059850, +-0.618457263857397970, -0.618417972162592310, -0.618378678921742360, -0.618339384134945710, -0.618300087802300610, -0.618260789923905320, -0.618221490499858080, -0.618182189530256390, +-0.618142887015199930, -0.618103582954786180, -0.618064277349113620, -0.618024970198280290, -0.617985661502384430, -0.617946351261524530, -0.617907039475798730, -0.617867726145305380, +-0.617828411270141990, -0.617789094850408230, -0.617749776886201700, -0.617710457377620760, -0.617671136324763780, -0.617631813727728800, -0.617592489586614390, -0.617553163901518040, +-0.617513836672539450, -0.617474507899776310, -0.617435177583326890, -0.617395845723289540, -0.617356512319762520, -0.617317177372844190, -0.617277840882633040, -0.617238502849226540, +-0.617199163272724500, -0.617159822153224510, -0.617120479490824940, -0.617081135285624250, -0.617041789537720600, -0.617002442247212570, -0.616963093414197750, -0.616923743038775840, +-0.616884391121044650, -0.616845037661102440, -0.616805682659047560, -0.616766326114978610, -0.616726968028993740, -0.616687608401191520, -0.616648247231669560, -0.616608884520527640, +-0.616569520267863490, -0.616530154473775680, -0.616490787138362360, -0.616451418261722120, -0.616412047843953310, -0.616372675885153650, -0.616333302385423050, -0.616293927344859220, +-0.616254550763560500, -0.616215172641625510, -0.616175792979152480, -0.616136411776240010, -0.616097029032986470, -0.616057644749490430, -0.616018258925849490, -0.615978871562163690, +-0.615939482658530710, -0.615900092215049040, -0.615860700231817050, -0.615821306708933310, -0.615781911646495650, -0.615742515044603980, -0.615703116903355880, -0.615663717222850070, +-0.615624316003185010, -0.615584913244459080, -0.615545508946770850, -0.615506103110218920, -0.615466695734901760, -0.615427286820917070, -0.615387876368364890, -0.615348464377343030, +-0.615309050847949960, -0.615269635780284370, -0.615230219174444650, -0.615190801030529370, -0.615151381348636340, -0.615111960128865600, -0.615072537371314950, -0.615033113076082990, +-0.614993687243268190, -0.614954259872969260, -0.614914830965284540, -0.614875400520312860, -0.614835968538151920, -0.614796535018901860, -0.614757099962660370, -0.614717663369526160, +-0.614678225239597700, -0.614638785572973800, -0.614599344369752940, -0.614559901630032930, -0.614520457353913920, -0.614481011541493700, -0.614441564192871100, -0.614402115308144480, +-0.614362664887412540, -0.614323212930773970, -0.614283759438327470, -0.614244304410170750, -0.614204847846404060, -0.614165389747125090, -0.614125930112432770, -0.614086468942425690, +-0.614047006237202320, -0.614007541996861470, -0.613968076221501070, -0.613928608911221140, -0.613889140066119720, -0.613849669686295510, -0.613810197771847090, -0.613770724322873160, +-0.613731249339472430, -0.613691772821743480, -0.613652294769785220, -0.613612815183695480, -0.613573334063574390, -0.613533851409519990, -0.613494367221630980, -0.613454881500006040, +-0.613415394244743890, -0.613375905455942560, -0.613336415133702070, -0.613296923278120690, -0.613257429889296880, -0.613217934967329570, -0.613178438512317460, -0.613138940524359130, +-0.613099441003553510, -0.613059939949999410, -0.613020437363794630, -0.612980933245039440, -0.612941427593831970, -0.612901920410270920, -0.612862411694455100, -0.612822901446483210, +-0.612783389666454070, -0.612743876354465700, -0.612704361510618360, -0.612664845135010180, -0.612625327227739880, -0.612585807788906260, -0.612546286818608120, -0.612506764316944170, +-0.612467240284013450, -0.612427714719913860, -0.612388187624745670, -0.612348658998607020, -0.612309128841596720, -0.612269597153813680, -0.612230063935356620, -0.612190529186324330, +-0.612150992906814960, -0.612111455096928990, -0.612071915756764230, -0.612032374886419820, -0.611992832485994340, -0.611953288555586840, -0.611913743095296110, -0.611874196105220980, +-0.611834647585459690, -0.611795097536112500, -0.611755545957277660, -0.611715992849053760, -0.611676438211540050, -0.611636882044835130, -0.611597324349038020, -0.611557765124246980, +-0.611518204370562150, -0.611478642088081780, -0.611439078276904910, -0.611399512937130240, -0.611359946068856910, -0.611320377672183610, -0.611280807747209390, -0.611241236294033150, +-0.611201663312753160, -0.611162088803469670, -0.611122512766280930, -0.611082935201285980, -0.611043356108583740, -0.611003775488273000, -0.610964193340452160, -0.610924609665221550, +-0.610885024462679340, -0.610845437732924660, -0.610805849476056320, -0.610766259692173350, -0.610726668381374790, -0.610687075543759560, -0.610647481179426690, -0.610607885288474320, +-0.610568287871002920, -0.610528688927110870, -0.610489088456897090, -0.610449486460460490, -0.610409882937900330, -0.610370277889314640, -0.610330671314804010, -0.610291063214466690, +-0.610251453588401720, -0.610211842436708120, -0.610172229759484930, -0.610132615556831180, -0.610092999828845790, -0.610053382575628020, -0.610013763797276010, -0.609974143493890340, +-0.609934521665569270, -0.609894898312411950, -0.609855273434517400, -0.609815647031984540, -0.609776019104912640, -0.609736389653400050, -0.609696758677547130, -0.609657126177452270, +-0.609617492153214700, -0.609577856604933350, -0.609538219532707370, -0.609498580936635780, -0.609458940816817840, -0.609419299173351690, -0.609379656006338140, -0.609340011315875340, +-0.609300365102062650, -0.609260717364998980, -0.609221068104783490, -0.609181417321515320, -0.609141765015292940, -0.609102111186216820, -0.609062455834385450, -0.609022798959897970, +-0.608983140562853410, -0.608943480643351130, -0.608903819201490060, -0.608864156237369450, -0.608824491751088440, -0.608784825742745510, -0.608745158212441240, -0.608705489160274000, +-0.608665818586343050, -0.608626146490747640, -0.608586472873586800, -0.608546797734959120, -0.608507121074965070, -0.608467442893703250, -0.608427763191272900, -0.608388081967773050, +-0.608348399223303080, -0.608308714957962020, -0.608269029171849220, -0.608229341865063830, -0.608189653037704450, -0.608149962689871540, -0.608110270821663800, -0.608070577433180270, +-0.608030882524520420, -0.607991186095783290, -0.607951488147067560, -0.607911788678473730, -0.607872087690100480, -0.607832385182047070, -0.607792681154412650, -0.607752975607296460, +-0.607713268540797880, -0.607673559955016150, -0.607633849850050530, -0.607594138225999500, -0.607554425082963870, -0.607514710421042210, -0.607474994240333800, -0.607435276540937870, +-0.607395557322953690, -0.607355836586480620, -0.607316114331617360, -0.607276390558464390, -0.607236665267120610, -0.607196938457685080, -0.607157210130257140, -0.607117480284936170, +-0.607077748921821650, -0.607038016041012600, -0.606998281642607940, -0.606958545726708150, -0.606918808293412050, -0.606879069342818990, -0.606839328875028230, -0.606799586890139130, +-0.606759843388251060, -0.606720098369462610, -0.606680351833874700, -0.606640603781585910, -0.606600854212695610, -0.606561103127303160, -0.606521350525507930, -0.606481596407409280, +-0.606441840773106810, -0.606402083622699540, -0.606362324956286500, -0.606322564773968290, -0.606282803075843700, -0.606243039862012110, -0.606203275132572880, -0.606163508887625490, +-0.606123741127268520, -0.606083971851603010, -0.606044201060727540, -0.606004428754741590, -0.605964654933744630, -0.605924879597835920, -0.605885102747115050, -0.605845324381681480, +-0.605805544501634490, -0.605765763107072970, -0.605725980198097760, -0.605686195774807650, -0.605646409837302000, -0.605606622385680300, -0.605566833420042140, -0.605527042940486090, +-0.605487250947113200, -0.605447457440022150, -0.605407662419312540, -0.605367865885083620, -0.605328067837435090, -0.605288268276466420, -0.605248467202277100, -0.605208664614966580, +-0.605168860514633700, -0.605129054901379470, -0.605089247775302490, -0.605049439136502440, -0.605009628985078710, -0.604969817321130980, -0.604930004144758730, -0.604890189456060660, +-0.604850373255137910, -0.604810555542089180, -0.604770736317014060, -0.604730915580012130, -0.604691093331182870, -0.604651269570625980, -0.604611444298440830, -0.604571617514726430, +-0.604531789219583620, -0.604491959413111400, -0.604452128095409160, -0.604412295266576690, -0.604372460926713480, -0.604332625075919120, -0.604292787714292510, -0.604252948841934590, +-0.604213108458944380, -0.604173266565421360, -0.604133423161465120, -0.604093578247175360, -0.604053731822651650, -0.604013883887993600, -0.603974034443300110, -0.603934183488672340, +-0.603894331024208970, -0.603854477050009940, -0.603814621566174600, -0.603774764572802770, -0.603734906069993920, -0.603695046057847180, -0.603655184536463500, -0.603615321505941880, +-0.603575456966382040, -0.603535590917883450, -0.603495723360545910, -0.603455854294469020, -0.603415983719752580, -0.603376111636496180, -0.603336238044798740, -0.603296362944761410, +-0.603256486336483210, -0.603216608220063730, -0.603176728595602780, -0.603136847463200070, -0.603096964822954380, -0.603057080674967110, -0.603017195019337040, -0.602977307856164100, +-0.602937419185547770, -0.602897529007587970, -0.602857637322384400, -0.602817744130036640, -0.602777849430644610, -0.602737953224307120, -0.602698055511125540, -0.602658156291198790, +-0.602618255564626670, -0.602578353331508890, -0.602538449591945250, -0.602498544346035560, -0.602458637593878630, -0.602418729335575940, -0.602378819571226410, -0.602338908300929840, +-0.602298995524785940, -0.602259081242894620, -0.602219165455355480, -0.602179248162268530, -0.602139329363732710, -0.602099409059849380, -0.602059487250717450, -0.602019563936436740, +-0.601979639117107170, -0.601939712792828540, -0.601899784963700560, -0.601859855629822470, -0.601819924791295420, -0.601779992448218560, -0.601740058600691800, -0.601700123248814720, +-0.601660186392687480, -0.601620248032409770, -0.601580308168081280, -0.601540366799801500, -0.601500423927671450, -0.601460479551790270, -0.601420533672258010, -0.601380586289174350, +-0.601340637402639210, -0.601300687012752520, -0.601260735119613310, -0.601220781723323050, -0.601180826823980890, -0.601140870421686620, -0.601100912516540080, -0.601060953108641380, +-0.601020992198090240, -0.600981029784986690, -0.600941065869430410, -0.600901100451520900, -0.600861133531359280, -0.600821165109044930, -0.600781195184677540, -0.600741223758357150, +-0.600701250830183770, -0.600661276400256570, -0.600621300468676900, -0.600581323035543900, -0.600541344100957610, -0.600501363665018050, -0.600461381727825040, -0.600421398289478490, +-0.600381413350078550, -0.600341426909725030, -0.600301438968517180, -0.600261449526556580, -0.600221458583942270, -0.600181466140774280, -0.600141472197152640, -0.600101476753177380, +-0.600061479808948420, -0.600021481364565010, -0.599981481420128640, -0.599941479975738550, -0.599901477031494770, -0.599861472587497220, -0.599821466643846060, -0.599781459200641190, +-0.599741450257982760, -0.599701439815969910, -0.599661427874704220, -0.599621414434284960, -0.599581399494812150, -0.599541383056385820, -0.599501365119106120, -0.599461345683072970, +-0.599421324748385720, -0.599381302315145860, -0.599341278383452750, -0.599301252953406420, -0.599261226025107010, -0.599221197598654440, -0.599181167674148970, -0.599141136251690520, +-0.599101103331378560, -0.599061068913314560, -0.599021032997597900, -0.598980995584328600, -0.598940956673606920, -0.598900916265532770, -0.598860874360206300, -0.598820830957726980, +-0.598780786058196290, -0.598740739661713590, -0.598700691768379150, -0.598660642378292860, -0.598620591491555000, -0.598580539108265700, -0.598540485228524990, -0.598500429852433120, +-0.598460372980089470, -0.598420314611595620, -0.598380254747050920, -0.598340193386555530, -0.598300130530209810, -0.598260066178113670, -0.598220000330366600, -0.598179932987070400, +-0.598139864148324210, -0.598099793814228510, -0.598059721984883220, -0.598019648660388590, -0.597979573840844880, -0.597939497526352340, -0.597899419717010880, -0.597859340412920330, +-0.597819259614182030, -0.597779177320895580, -0.597739093533161240, -0.597699008251079130, -0.597658921474749530, -0.597618833204272670, -0.597578743439747930, -0.597538652181277110, +-0.597498559428959570, -0.597458465182895690, -0.597418369443185600, -0.597378272209929670, -0.597338173483228040, -0.597298073263180960, -0.597257971549887910, -0.597217868343450700, +-0.597177763643968910, -0.597137657451542570, -0.597097549766272160, -0.597057440588257830, -0.597017329917600040, -0.596977217754398050, -0.596937104098753780, -0.596896988950766700, +-0.596856872310537300, -0.596816754178165600, -0.596776634553751960, -0.596736513437396860, -0.596696390829200450, -0.596656266729262310, -0.596616141137684240, -0.596576014054565840, +-0.596535885480007360, -0.596495755414109150, -0.596455623856971600, -0.596415490808694940, -0.596375356269378880, -0.596335220239125220, -0.596295082718033440, -0.596254943706203910, +-0.596214803203736990, -0.596174661210733150, -0.596134517727292650, -0.596094372753515840, -0.596054226289503110, -0.596014078335354030, -0.595973928891170620, -0.595933777957052270, +-0.595893625533099440, -0.595853471619412600, -0.595813316216092130, -0.595773159323237600, -0.595733000940950940, -0.595692841069331740, -0.595652679708480460, -0.595612516858497370, +-0.595572352519483150, -0.595532186691537960, -0.595492019374762260, -0.595451850569256650, -0.595411680275120590, -0.595371508492456010, -0.595331335221362720, -0.595291160461941190, +-0.595250984214291570, -0.595210806478514650, -0.595170627254710590, -0.595130446542979310, -0.595090264343422600, -0.595050080656140290, -0.595009895481232730, -0.594969708818800510, +-0.594929520668943890, -0.594889331031763560, -0.594849139907359880, -0.594808947295832670, -0.594768753197283730, -0.594728557611812870, -0.594688360539520790, -0.594648161980507630, +-0.594607961934874200, -0.594567760402720750, -0.594527557384147310, -0.594487352879255580, -0.594447146888145480, -0.594406939410917600, -0.594366730447672300, -0.594326519998510160, +-0.594286308063531780, -0.594246094642837620, -0.594205879736527500, -0.594165663344703330, -0.594125445467465150, -0.594085226104913210, -0.594045005257148320, -0.594004782924270840, +-0.593964559106381350, -0.593924333803579900, -0.593884107015968170, -0.593843878743646300, -0.593803648986714670, -0.593763417745273970, -0.593723185019424670, -0.593682950809267470, +-0.593642715114902850, -0.593602477936431390, -0.593562239273953020, -0.593521999127569870, -0.593481757497381630, -0.593441514383489130, -0.593401269785992720, -0.593361023704993110, +-0.593320776140590310, -0.593280527092886260, -0.593240276561980970, -0.593200024547974820, -0.593159771050968730, -0.593119516071063170, -0.593079259608358830, -0.593039001662956420, +-0.592998742234956410, -0.592958481324458830, -0.592918218931565820, -0.592877955056377190, -0.592837689698993750, -0.592797422859515980, -0.592757154538044780, -0.592716884734680650, +-0.592676613449523490, -0.592636340682675680, -0.592596066434236900, -0.592555790704307970, -0.592515513492989590, -0.592475234800382440, -0.592434954626587130, -0.592394672971704560, +-0.592354389835834440, -0.592314105219079230, -0.592273819121538650, -0.592233531543313490, -0.592193242484504560, -0.592152951945212560, -0.592112659925538080, -0.592072366425581360, +-0.592032071445444340, -0.591991774985227150, -0.591951477045030590, -0.591911177624955260, -0.591870876725101970, -0.591830574345571630, -0.591790270486464710, -0.591749965147881470, +-0.591709658329923950, -0.591669350032692390, -0.591629040256287380, -0.591588729000809830, -0.591548416266360460, -0.591508102053040050, -0.591467786360948540, -0.591427469190188400, +-0.591387150540859660, -0.591346830413062910, -0.591306508806899170, -0.591266185722469030, -0.591225861159873520, -0.591185535119213350, -0.591145207600589420, -0.591104878604101660, +-0.591064548129852430, -0.591024216177941760, -0.590983882748470690, -0.590943547841539800, -0.590903211457250110, -0.590862873595701670, -0.590822534256996710, -0.590782193441235500, +-0.590741851148518740, -0.590701507378947330, -0.590661162132622210, -0.590620815409644170, -0.590580467210114150, -0.590540117534132820, -0.590499766381800570, -0.590459413753219640, +-0.590419059648490170, -0.590378704067712980, -0.590338347010989080, -0.590297988478419410, -0.590257628470104660, -0.590217266986145070, -0.590176904026643130, -0.590136539591698870, +-0.590096173681413320, -0.590055806295887280, -0.590015437435221780, -0.589975067099517640, -0.589934695288875880, -0.589894322003396530, -0.589853947243182300, -0.589813571008332980, +-0.589773193298949950, -0.589732814115133790, -0.589692433456985630, -0.589652051324606410, -0.589611667718096370, -0.589571282637557760, -0.589530896083091060, -0.589490508054797080, +-0.589450118552776850, -0.589409727577131280, -0.589369335127961410, -0.589328941205368270, -0.589288545809452000, -0.589248148940315080, -0.589207750598057740, -0.589167350782781150, +-0.589126949494586110, -0.589086546733573630, -0.589046142499844880, -0.589005736793499990, -0.588965329614641540, -0.588924920963369790, -0.588884510839785660, -0.588844099243990280, +-0.588803686176084580, -0.588763271636169820, -0.588722855624346790, -0.588682438140716640, -0.588642019185379620, -0.588601598758438320, -0.588561176859992980, -0.588520753490144770, +-0.588480328648994690, -0.588439902336643670, -0.588399474553192300, -0.588359045298742940, -0.588318614573395960, -0.588278182377252380, -0.588237748710413340, -0.588197313572980000, +-0.588156876965053370, -0.588116438886734480, -0.588075999338124600, -0.588035558319323970, -0.587995115830435070, -0.587954671871558480, -0.587914226442795230, -0.587873779544246360, +-0.587833331176013000, -0.587792881338195630, -0.587752430030896830, -0.587711977254216870, -0.587671523008256980, -0.587631067293118310, -0.587590610108902010, -0.587550151455709100, +-0.587509691333640950, -0.587469229742798470, -0.587428766683282140, -0.587388302155194770, -0.587347836158636500, -0.587307368693708700, -0.587266899760512500, -0.587226429359149040, +-0.587185957489719470, -0.587145484152324260, -0.587105009347066110, -0.587064533074045490, -0.587024055333363440, -0.586983576125121310, -0.586943095449420250, -0.586902613306361400, +-0.586862129696046120, -0.586821644618574670, -0.586781158074049850, -0.586740670062572240, -0.586700180584242890, -0.586659689639163040, -0.586619197227433940, -0.586578703349156960, +-0.586538208004432460, -0.586497711193363140, -0.586457212916049580, -0.586416713172592920, -0.586376211963094530, -0.586335709287655660, -0.586295205146377450, -0.586254699539361160, +-0.586214192466708250, -0.586173683928519100, -0.586133173924896390, -0.586092662455940830, -0.586052149521753550, -0.586011635122436040, -0.585971119258089310, -0.585930601928814080, +-0.585890083134713020, -0.585849562875886850, -0.585809041152436700, -0.585768517964464050, -0.585727993312070040, -0.585687467195356030, -0.585646939614423270, -0.585606410569373350, +-0.585565880060306520, -0.585525348087325810, -0.585484814650531700, -0.585444279750025550, -0.585403743385908730, -0.585363205558282470, -0.585322666267247490, -0.585282125512906700, +-0.585241583295360470, -0.585201039614710260, -0.585160494471057560, -0.585119947864503500, -0.585079399795149670, -0.585038850263097320, -0.584998299268447820, -0.584957746811301860, +-0.584917192891762250, -0.584876637509929690, -0.584836080665905530, -0.584795522359791150, -0.584754962591688020, -0.584714401361697390, -0.584673838669920070, -0.584633274516458860, +-0.584592708901414570, -0.584552141824888350, -0.584511573286981890, -0.584471003287796440, -0.584430431827433480, -0.584389858905994490, -0.584349284523580040, -0.584308708680293170, +-0.584268131376234570, -0.584227552611505610, -0.584186972386207760, -0.584146390700442500, -0.584105807554311180, -0.584065222947914630, -0.584024636881355860, -0.583984049354735360, +-0.583943460368154810, -0.583902869921715690, -0.583862278015519260, -0.583821684649667220, -0.583781089824260910, -0.583740493539401830, -0.583699895795190880, -0.583659296591730880, +-0.583618695929122740, -0.583578093807467720, -0.583537490226867520, -0.583496885187423600, -0.583456278689236770, -0.583415670732409960, -0.583375061317043860, -0.583334450443240280, +-0.583293838111100470, -0.583253224320726130, -0.583212609072218610, -0.583171992365679630, -0.583131374201210750, -0.583090754578912570, -0.583050133498888350, -0.583009510961238760, +-0.582968886966065410, -0.582928261513469770, -0.582887634603553530, -0.582847006236417500, -0.582806376412164600, -0.582765745130895850, -0.582725112392712630, -0.582684478197716740, +-0.582643842546009650, -0.582603205437692840, -0.582562566872868120, -0.582521926851636950, -0.582481285374100270, -0.582440642440361090, -0.582399998050520230, -0.582359352204679490, +-0.582318704902940240, -0.582278056145404290, -0.582237405932173210, -0.582196754263347940, -0.582156101139031490, -0.582115446559324680, -0.582074790524329310, -0.582034133034147080, +-0.581993474088879360, -0.581952813688628060, -0.581912151833494650, -0.581871488523580170, -0.581830823758987760, -0.581790157539818220, -0.581749489866173250, -0.581708820738154660, +-0.581668150155863930, -0.581627478119402850, -0.581586804628872360, -0.581546129684375580, -0.581505453286013440, -0.581464775433887750, -0.581424096128099980, -0.581383415368752040, +-0.581342733155945650, -0.581302049489782370, -0.581261364370363910, -0.581220677797791410, -0.581179989772167890, -0.581139300293594400, -0.581098609362172610, -0.581057916978004350, +-0.581017223141191310, -0.580976527851834510, -0.580935831110036990, -0.580895132915900000, -0.580854433269525130, -0.580813732171014290, -0.580773029620468950, -0.580732325617991150, +-0.580691620163682480, -0.580650913257644840, -0.580610204899979050, -0.580569495090788590, -0.580528783830174370, -0.580488071118238190, -0.580447356955081870, -0.580406641340807110, +-0.580365924275515030, -0.580325205759308790, -0.580284485792289640, -0.580243764374559270, -0.580203041506219370, -0.580162317187371990, -0.580121591418118810, -0.580080864198561640, +-0.580040135528802290, -0.579999405408941900, -0.579958673839083730, -0.579917940819328790, -0.579877206349779020, -0.579836470430536320, -0.579795733061702400, -0.579754994243379170, +-0.579714253975667670, -0.579673512258671360, -0.579632769092491170, -0.579592024477229020, -0.579551278412986930, -0.579510530899866590, -0.579469781937969940, -0.579429031527398770, +-0.579388279668254460, -0.579347526360640020, -0.579306771604656820, -0.579266015400406680, -0.579225257747991500, -0.579184498647513200, -0.579143738099073600, -0.579102976102773950, +-0.579062212658717600, -0.579021447767005700, -0.578980681427740280, -0.578939913641023040, -0.578899144406956000, -0.578858373725641200, -0.578817601597180430, -0.578776828021674850, +-0.578736052999228030, -0.578695276529941020, -0.578654498613915820, -0.578613719251254490, -0.578572938442058700, -0.578532156186430610, -0.578491372484471470, -0.578450587336284630, +-0.578409800741971240, -0.578369012701633320, -0.578328223215372920, -0.578287432283292050, -0.578246639905492520, -0.578205846082076370, -0.578165050813145620, -0.578124254098801530, +-0.578083455939147450, -0.578042656334284870, -0.578001855284315580, -0.577961052789341620, -0.577920248849465130, -0.577879443464787150, -0.577838636635411350, -0.577797828361439000, +-0.577757018642972130, -0.577716207480112540, -0.577675394872962600, -0.577634580821624110, -0.577593765326199100, -0.577552948386789720, -0.577512130003497330, -0.577471310176425280, +-0.577430488905674940, -0.577389666191348350, -0.577348842033547640, -0.577308016432374840, -0.577267189387931980, -0.577226360900320310, -0.577185530969643650, -0.577144699596003010, +-0.577103866779500760, -0.577063032520238720, -0.577022196818319230, -0.576981359673844120, -0.576940521086915630, -0.576899681057635230, -0.576858839586106180, -0.576817996672430170, +-0.576777152316709120, -0.576736306519045170, -0.576695459279540470, -0.576654610598297150, -0.576613760475416570, -0.576572908911002320, -0.576532055905155770, -0.576491201457979050, +-0.576450345569574310, -0.576409488240043790, -0.576368629469489520, -0.576327769258013660, -0.576286907605717660, -0.576246044512705110, -0.576205179979077500, -0.576164314004936950, +-0.576123446590385500, -0.576082577735525510, -0.576041707440459130, -0.576000835705287710, -0.575959962530114830, -0.575919087915042090, -0.575878211860171740, -0.575837334365605800, +-0.575796455431446530, -0.575755575057796070, -0.575714693244756660, -0.575673809992430560, -0.575632925300919250, -0.575592039170326310, -0.575551151600753210, -0.575510262592302310, +-0.575469372145075760, -0.575428480259175810, -0.575387586934703820, -0.575346692171763710, -0.575305795970456830, -0.575264898330885450, -0.575223999253151820, -0.575183098737358180, +-0.575142196783606790, -0.575101293391999890, -0.575060388562639860, -0.575019482295628050, -0.574978574591068270, -0.574937665449062000, -0.574896754869711700, -0.574855842853119410, +-0.574814929399387500, -0.574774014508618310, -0.574733098180913340, -0.574692180416376370, -0.574651261215109010, -0.574610340577213390, -0.574569418502791970, -0.574528494991947030, +-0.574487570044780790, -0.574446643661395640, -0.574405715841893150, -0.574364786586377130, -0.574323855894949160, -0.574282923767711510, -0.574241990204766520, -0.574201055206216670, +-0.574160118772164110, -0.574119180902710410, -0.574078241597959620, -0.574037300858013190, -0.573996358682973610, -0.573955415072943010, -0.573914470028023870, -0.573873523548318660, +-0.573832575633929530, -0.573791626284958280, -0.573750675501508710, -0.573709723283682420, -0.573668769631581870, -0.573627814545309310, -0.573586858024967340, -0.573545900070658090, +-0.573504940682483480, -0.573463979860547200, -0.573423017604950850, -0.573382053915797110, -0.573341088793188240, -0.573300122237226590, -0.573259154248014660, -0.573218184825654790, +-0.573177213970249460, -0.573136241681900470, -0.573095267960711530, -0.573054292806784440, -0.573013316220221560, -0.572972338201125480, -0.572931358749598550, -0.572890377865742370, +-0.572849395549661080, -0.572808411801456250, -0.572767426621230480, -0.572726440009086120, -0.572685451965125550, -0.572644462489451440, -0.572603471582166180, -0.572562479243372220, +-0.572521485473171390, -0.572480490271667470, -0.572439493638962400, -0.572398495575158540, -0.572357496080358460, -0.572316495154664650, -0.572275492798179690, -0.572234489011005150, +-0.572193483793245190, -0.572152477145001500, -0.572111469066376550, -0.572070459557472930, -0.572029448618393220, -0.571988436249239900, -0.571947422450115540, -0.571906407221121740, +-0.571865390562362740, -0.571824372473940250, -0.571783352955956840, -0.571742332008515100, -0.571701309631717500, -0.571660285825666530, -0.571619260590464200, -0.571578233926214430, +-0.571537205833019150, -0.571496176310980710, -0.571455145360201920, -0.571414112980785260, -0.571373079172833310, -0.571332043936448650, -0.571291007271733210, -0.571249969178790900, +-0.571208929657723740, -0.571167888708634220, -0.571126846331625030, -0.571085802526798640, -0.571044757294257740, -0.571003710634104270, -0.570962662546442230, -0.570921613031373560, +-0.570880562089000840, -0.570839509719426760, -0.570798455922753800, -0.570757400699084760, -0.570716344048522230, -0.570675285971168900, -0.570634226467126470, -0.570593165536499300, +-0.570552103179389200, -0.570511039395898870, -0.570469974186130990, -0.570428907550188050, -0.570387839488172180, -0.570346770000187410, -0.570305699086335770, -0.570264626746719850, +-0.570223552981442340, -0.570182477790605930, -0.570141401174313440, -0.570100323132667340, -0.570059243665770430, -0.570018162773724750, -0.569977080456634310, -0.569935996714601270, +-0.569894911547728200, -0.569853824956117800, -0.569812736939872890, -0.569771647499096150, -0.569730556633889500, -0.569689464344357190, -0.569648370630601250, -0.569607275492724390, +-0.569566178930829390, -0.569525080945018860, -0.569483981535395700, -0.569442880702062500, -0.569401778445121410, -0.569360674764676670, -0.569319569660830190, -0.569278463133684800, +-0.569237355183343170, -0.569196245809908240, -0.569155135013482690, -0.569114022794168450, -0.569072909152070090, -0.569031794087289320, -0.568990677599929050, -0.568949559690092200, +-0.568908440357881350, -0.568867319603399420, -0.568826197426749220, -0.568785073828032780, -0.568743948807354350, -0.568702822364816170, -0.568661694500520840, -0.568620565214571270, +-0.568579434507070270, -0.568538302378120750, -0.568497168827824640, -0.568456033856286510, -0.568414897463608180, -0.568373759649892560, -0.568332620415242570, -0.568291479759761130, +-0.568250337683550930, -0.568209194186714890, -0.568168049269355820, -0.568126902931575970, -0.568085755173479480, -0.568044605995168710, -0.568003455396746350, -0.567962303378315440, +-0.567921149939978780, -0.567879995081838400, -0.567838838803998770, -0.567797681106562150, -0.567756521989631220, -0.567715361453309030, -0.567674199497698480, -0.567633036122902390, +-0.567591871329023780, -0.567550705116165450, -0.567509537484429560, -0.567468368433920570, -0.567427197964740730, -0.567386026076992840, -0.567344852770779950, -0.567303678046204850, +-0.567262501903370580, -0.567221324342379370, -0.567180145363335500, -0.567138964966341310, -0.567097783151499720, -0.567056599918913660, -0.567015415268686040, -0.566974229200920000, +-0.566933041715718340, -0.566891852813183330, -0.566850662493419420, -0.566809470756528770, -0.566768277602614610, -0.566727083031779650, -0.566685887044127030, -0.566644689639759670, +-0.566603490818779810, -0.566562290581292040, -0.566521088927398500, -0.566479885857202210, -0.566438681370806220, -0.566397475468313650, -0.566356268149827200, -0.566315059415450240, +-0.566273849265284790, -0.566232637699435440, -0.566191424718004540, -0.566150210321095140, -0.566108994508810140, -0.566067777281252680, -0.566026558638525800, -0.565985338580731740, +-0.565944117107975100, -0.565902894220358110, -0.565861669917983920, -0.565820444200955560, -0.565779217069376060, -0.565737988523348560, -0.565696758562976080, -0.565655527188361760, +-0.565614294399607750, -0.565573060196818860, -0.565531824580097320, -0.565490587549546180, -0.565449349105268560, -0.565408109247367510, -0.565366867975945600, -0.565325625291107080, +-0.565284381192954650, -0.565243135681591240, -0.565201888757119960, -0.565160640419643870, -0.565119390669266310, -0.565078139506090200, -0.565036886930218810, -0.564995632941754480, +-0.564954377540801690, -0.564913120727463030, -0.564871862501841520, -0.564830602864040410, -0.564789341814162740, -0.564748079352311860, -0.564706815478589920, -0.564665550193101720, +-0.564624283495949510, -0.564583015387236760, -0.564541745867066400, -0.564500474935541670, -0.564459202592765830, -0.564417928838841900, -0.564376653673872460, -0.564335377097962110, +-0.564294099111213310, -0.564252819713729200, -0.564211538905613150, -0.564170256686968190, -0.564128973057897550, -0.564087688018503840, -0.564046401568891630, -0.564005113709163290, +-0.563963824439422280, -0.563922533759771750, -0.563881241670314840, -0.563839948171154790, -0.563798653262394870, -0.563757356944137640, -0.563716059216487710, -0.563674760079547640, +-0.563633459533420700, -0.563592157578210020, -0.563550854214019070, -0.563509549440950890, -0.563468243259108160, -0.563426935668595470, -0.563385626669515530, -0.563344316261971460, +-0.563303004446066620, -0.563261691221904390, -0.563220376589587790, -0.563179060549220290, -0.563137743100905140, -0.563096424244744820, -0.563055103980844350, -0.563013782309305990, +-0.562972459230233200, -0.562931134743729240, -0.562889808849897480, -0.562848481548840480, -0.562807152840662960, -0.562765822725467600, -0.562724491203357660, -0.562683158274436490, +-0.562641823938807460, -0.562600488196573820, -0.562559151047838930, -0.562517812492706270, -0.562476472531278300, -0.562435131163659840, -0.562393788389953580, -0.562352444210262870, +-0.562311098624690970, -0.562269751633341470, -0.562228403236316730, -0.562187053433721770, -0.562145702225659180, -0.562104349612232320, -0.562062995593544560, -0.562021640169699350, +-0.561980283340800080, -0.561938925106949980, -0.561897565468252650, -0.561856204424810660, -0.561814841976728930, -0.561773478124110050, -0.561732112867057490, -0.561690746205674610, +-0.561649378140064880, -0.561608008670331780, -0.561566637796577890, -0.561525265518908130, -0.561483891837425200, -0.561442516752232450, -0.561401140263433570, -0.561359762371131720, +-0.561318383075430470, -0.561277002376433300, -0.561235620274242900, -0.561194236768964180, -0.561152851860699850, -0.561111465549553490, -0.561070077835628340, -0.561028688719028000, +-0.560987298199856040, -0.560945906278214950, -0.560904512954209960, -0.560863118227943660, -0.560821722099519530, -0.560780324569041140, -0.560738925636611870, -0.560697525302335300, +-0.560656123566315000, -0.560614720428654350, -0.560573315889456140, -0.560531909948825290, -0.560490502606864840, -0.560449093863678030, -0.560407683719368550, -0.560366272174039780, +-0.560324859227794620, -0.560283444880738110, -0.560242029132972940, -0.560200611984602690, -0.560159193435730840, -0.560117773486461080, -0.560076352136896990, -0.560034929387141830, +-0.559993505237299520, -0.559952079687472630, -0.559910652737766190, -0.559869224388283240, -0.559827794639127240, -0.559786363490401670, -0.559744930942210230, -0.559703496994655710, +-0.559662061647843270, -0.559620624901875590, -0.559579186756856360, -0.559537747212889180, -0.559496306270077630, -0.559454863928525280, -0.559413420188335730, -0.559371975049612780, +-0.559330528512459010, -0.559289080576979680, -0.559247631243277700, -0.559206180511456650, -0.559164728381620120, -0.559123274853871810, -0.559081819928315290, -0.559040363605053490, +-0.558998905884191430, -0.558957446765832260, -0.558915986250079320, -0.558874524337036550, -0.558833061026807410, -0.558791596319495600, -0.558750130215204810, -0.558708662714037960, +-0.558667193816100190, -0.558625723521494420, -0.558584251830324340, -0.558542778742693650, -0.558501304258706030, -0.558459828378465080, -0.558418351102073940, -0.558376872429637520, +-0.558335392361259060, -0.558293910897042060, -0.558252428037090190, -0.558210943781507370, -0.558169458130397200, -0.558127971083863360, -0.558086482642009550, -0.558044992804938800, +-0.558003501572756360, -0.557962008945565020, -0.557920514923468840, -0.557879019506571260, -0.557837522694976220, -0.557796024488786510, -0.557754524888107620, -0.557713023893042340, +-0.557671521503694480, -0.557630017720167850, -0.557588512542566250, -0.557547005970993270, -0.557505498005552820, -0.557463988646348610, -0.557422477893483650, -0.557380965747063310, +-0.557339452207190500, -0.557297937273969040, -0.557256420947502830, -0.557214903227895460, -0.557173384115250190, -0.557131863609672150, -0.557090341711264480, -0.557048818420130880, +-0.557007293736375250, -0.556965767660101420, -0.556924240191413180, -0.556882711330414340, -0.556841181077208700, -0.556799649431899410, -0.556758116394591720, -0.556716581965388760, +-0.556675046144394340, -0.556633508931712260, -0.556591970327446450, -0.556550430331700600, -0.556508888944578060, -0.556467346166183980, -0.556425801996621620, -0.556384256435994650, +-0.556342709484407120, -0.556301161141962710, -0.556259611408765450, -0.556218060284919270, -0.556176507770527070, -0.556134953865694340, -0.556093398570524310, -0.556051841885120690, +-0.556010283809587610, -0.555968724344028660, -0.555927163488547980, -0.555885601243248590, -0.555844037608235970, -0.555802472583613370, -0.555760906169484480, -0.555719338365953330, +-0.555677769173123840, -0.555636198591099920, -0.555594626619985490, -0.555553053259883800, -0.555511478510900100, -0.555469902373137870, -0.555428324846700790, -0.555386745931692900, +-0.555345165628218230, -0.555303583936380570, -0.555262000856283190, -0.555220416388031550, -0.555178830531728900, -0.555137243287479150, -0.555095654655386350, -0.555054064635554400, +-0.555012473228087220, -0.554970880433088950, -0.554929286250663400, -0.554887690680913930, -0.554846093723946000, -0.554804495379862760, -0.554762895648768350, -0.554721294530766680, +-0.554679692025961790, -0.554638088134456810, -0.554596482856357540, -0.554554876191766910, -0.554513268140789160, -0.554471658703528210, -0.554430047880088210, -0.554388435670572940, +-0.554346822075086680, -0.554305207093733320, -0.554263590726616240, -0.554221972973840900, -0.554180353835510680, -0.554138733311729580, -0.554097111402601540, -0.554055488108230800, +-0.554013863428721390, -0.553972237364176450, -0.553930609914701780, -0.553888981080400520, -0.553847350861376820, -0.553805719257734700, -0.553764086269578290, -0.553722451897011750, +-0.553680816140138980, -0.553639178999063450, -0.553597540473890760, -0.553555900564724260, -0.553514259271667860, -0.553472616594825940, -0.553430972534302400, -0.553389327090201500, +-0.553347680262626480, -0.553306032051683050, -0.553264382457474560, -0.553222731480105030, -0.553181079119678730, -0.553139425376299680, -0.553097770250072120, -0.553056113741100090, +-0.553014455849487160, -0.552972796575338710, -0.552931135918758310, -0.552889473879849990, -0.552847810458718110, -0.552806145655466600, -0.552764479470199800, -0.552722811903020970, +-0.552681142954035920, -0.552639472623348000, -0.552597800911061480, -0.552556127817280360, -0.552514453342108910, -0.552472777485651380, -0.552431100248011900, -0.552389421629294610, +-0.552347741629603100, -0.552306060249042940, -0.552264377487717620, -0.552222693345731370, -0.552181007823188460, -0.552139320920192910, -0.552097632636848410, -0.552055942973260550, +-0.552014251929532800, -0.551972559505769400, -0.551930865702074610, -0.551889170518552690, -0.551847473955307870, -0.551805776012444290, -0.551764076690066330, -0.551722375988277450, +-0.551680673907183340, -0.551638970446887480, -0.551597265607494340, -0.551555559389107940, -0.551513851791832650, -0.551472142815772730, -0.551430432461031740, -0.551388720727715280, +-0.551347007615927140, -0.551305293125771480, -0.551263577257352640, -0.551221860010774780, -0.551180141386142240, -0.551138421383559400, -0.551096700003129710, -0.551054977244959110, +-0.551013253109151060, -0.550971527595809810, -0.550929800705039720, -0.550888072436945150, -0.550846342791630470, -0.550804611769199150, -0.550762879369756990, -0.550721145593407680, +-0.550679410440255590, -0.550637673910404860, -0.550595936003959950, -0.550554196721025240, -0.550512456061704960, -0.550470714026102930, -0.550428970614324720, -0.550387225826474150, +-0.550345479662655570, -0.550303732122973230, -0.550261983207531610, -0.550220232916434960, -0.550178481249786970, -0.550136728207693660, -0.550094973790258400, -0.550053217997585660, +-0.550011460829780030, -0.549969702286945640, -0.549927942369187070, -0.549886181076608580, -0.549844418409314640, -0.549802654367408940, -0.549760888950997400, -0.549719122160183590, +-0.549677353995071890, -0.549635584455766880, -0.549593813542372910, -0.549552041254993680, -0.549510267593735110, -0.549468492558700780, -0.549426716149995280, -0.549384938367722950, +-0.549343159211988400, -0.549301378682895750, -0.549259596780549810, -0.549217813505054830, -0.549176028856514620, -0.549134242835034980, -0.549092455440719830, -0.549050666673673420, +-0.549008876534000430, -0.548967085021805250, -0.548925292137192320, -0.548883497880265470, -0.548841702251130600, -0.548799905249891530, -0.548758106876652610, -0.548716307131518420, +-0.548674506014593550, -0.548632703525982370, -0.548590899665789330, -0.548549094434118480, -0.548507287831075500, -0.548465479856764300, -0.548423670511289480, -0.548381859794755400, +-0.548340047707266740, -0.548298234248927980, -0.548256419419842820, -0.548214603220117390, -0.548172785649855500, -0.548130966709161620, -0.548089146398140210, -0.548047324716896100, +-0.548005501665533520, -0.547963677244157290, -0.547921851452871090, -0.547880024291781060, -0.547838195760990910, -0.547796365860605320, -0.547754534590728760, -0.547712701951465930, +-0.547670867942921300, -0.547629032565198680, -0.547587195818404320, -0.547545357702642010, -0.547503518218016240, -0.547461677364631690, -0.547419835142592960, -0.547377991552004620, +-0.547336146592971250, -0.547294300265597560, -0.547252452569987450, -0.547210603506246840, -0.547168753074479760, -0.547126901274790800, -0.547085048107284640, -0.547043193572065770, +-0.547001337669238200, -0.546959480398908070, -0.546917621761179200, -0.546875761756156260, -0.546833900383943970, -0.546792037644646900, -0.546750173538369740, -0.546708308065217200, +-0.546666441225293840, -0.546624573018703600, -0.546582703445552710, -0.546540832505945100, -0.546498960199985340, -0.546457086527778250, -0.546415211489428290, -0.546373335085040490, +-0.546331457314718550, -0.546289578178568600, -0.546247697676694790, -0.546205815809201800, -0.546163932576194220, -0.546122047977776750, -0.546080162014054180, -0.546038274685131330, +-0.545996385991111890, -0.545954495932102320, -0.545912604508206440, -0.545870711719529170, -0.545828817566174960, -0.545786922048248860, -0.545745025165855320, -0.545703126919098610, +-0.545661227308084750, -0.545619326332917760, -0.545577423993702570, -0.545535520290543750, -0.545493615223546220, -0.545451708792814570, -0.545409800998453600, -0.545367891840567440, +-0.545325981319262350, -0.545284069434642250, -0.545242156186811930, -0.545200241575876320, -0.545158325601940110, -0.545116408265107990, -0.545074489565484210, -0.545032569503174800, +-0.544990648078284120, -0.544948725290916760, -0.544906801141177620, -0.544864875629171410, -0.544822948755003030, -0.544781020518777300, -0.544739090920599020, -0.544697159960572220, +-0.544655227638803360, -0.544613293955396370, -0.544571358910456160, -0.544529422504087530, -0.544487484736395410, -0.544445545607483710, -0.544403605117459000, -0.544361663266425210, +-0.544319720054487370, -0.544277775481750160, -0.544235829548318510, -0.544193882254297210, -0.544151933599791300, -0.544109983584905480, -0.544068032209744090, -0.544026079474413280, +-0.543984125379017300, -0.543942169923660960, -0.543900213108449160, -0.543858254933486940, -0.543816295398878990, -0.543774334504729670, -0.543732372251145120, -0.543690408638229710, +-0.543648443666088330, -0.543606477334825700, -0.543564509644546940, -0.543522540595356980, -0.543480570187360620, -0.543438598420662110, -0.543396625295367810, -0.543354650811581960, +-0.543312674969409490, -0.543270697768955310, -0.543228719210324450, -0.543186739293621710, -0.543144758018951460, -0.543102775386419930, -0.543060791396131610, -0.543018806048191190, +-0.542976819342703810, -0.542934831279774380, -0.542892841859507920, -0.542850851082009370, -0.542808858947382840, -0.542766865455734940, -0.542724870607169900, -0.542682874401792640, +-0.542640876839708300, -0.542598877921021680, -0.542556877645837930, -0.542514876014261180, -0.542472873026398020, -0.542430868682352570, -0.542388862982230100, -0.542346855926135410, +-0.542304847514173630, -0.542262837746449570, -0.542220826623068590, -0.542178814144135490, -0.542136800309754640, -0.542094785120032400, -0.542052768575073340, -0.542010750674982280, +-0.541968731419864460, -0.541926710809824690, -0.541884688844967430, -0.541842665525399170, -0.541800640851224370, -0.541758614822547830, -0.541716587439474820, -0.541674558702110340, +-0.541632528610559440, -0.541590497164927130, -0.541548464365318670, -0.541506430211838310, -0.541464394704592620, -0.541422357843685980, -0.541380319629223390, -0.541338280061310020, +-0.541296239140050980, -0.541254196865551320, -0.541212153237915380, -0.541170108257249870, -0.541128061923659030, -0.541086014237248000, -0.541043965198122030, -0.541001914806386150, +-0.540959863062145390, -0.540917809965504980, -0.540875755516569410, -0.540833699715445150, -0.540791642562236550, -0.540749584057048980, -0.540707524199987350, -0.540665462991156920, +-0.540623400430662930, -0.540581336518609620, -0.540539271255103700, -0.540497204640249640, -0.540455136674152570, -0.540413067356917630, -0.540370996688649960, -0.540328924669454920, +-0.540286851299437540, -0.540244776578702180, -0.540202700507355750, -0.540160623085502500, -0.540118544313247790, -0.540076464190696660, -0.540034382717954340, -0.539992299895126090, +-0.539950215722316270, -0.539908130199631800, -0.539866043327176910, -0.539823955105056870, -0.539781865533377040, -0.539739774612242540, -0.539697682341758520, -0.539655588722030340, +-0.539613493753163250, -0.539571397435261610, -0.539529299768432220, -0.539487200752779560, -0.539445100388408980, -0.539402998675425630, -0.539360895613934740, -0.539318791204040910, +-0.539276685445850830, -0.539234578339468970, -0.539192469885000800, -0.539150360082551350, -0.539108248932226090, -0.539066136434130040, -0.539024022588368790, -0.538981907395047480, +-0.538939790854270570, -0.538897672966144990, -0.538855553730775320, -0.538813433148266570, -0.538771311218724350, -0.538729187942253880, -0.538687063318959660, -0.538644937348948470, +-0.538602810032325020, -0.538560681369194550, -0.538518551359662310, -0.538476420003833780, -0.538434287301814090, -0.538392153253708710, -0.538350017859623000, -0.538307881119661440, +-0.538265743033931040, -0.538223603602536180, -0.538181462825582320, -0.538139320703174830, -0.538097177235418940, -0.538055032422420250, -0.538012886264283120, -0.537970738761114560, +-0.537928589913019170, -0.537886439720102310, -0.537844288182469430, -0.537802135300225690, -0.537759981073476670, -0.537717825502327720, -0.537675668586883430, -0.537633510327250710, +-0.537591350723534260, -0.537549189775839320, -0.537507027484271480, -0.537464863848936100, -0.537422698869938540, -0.537380532547383490, -0.537338364881377870, -0.537296195872026260, +-0.537254025519434240, -0.537211853823707170, -0.537169680784950420, -0.537127506403269450, -0.537085330678769730, -0.537043153611556630, -0.537000975201735060, -0.536958795449411610, +-0.536916614354691290, -0.536874431917679470, -0.536832248138481520, -0.536790063017202890, -0.536747876553948400, -0.536705688748824960, -0.536663499601937270, -0.536621309113390900, +-0.536579117283291220, -0.536536924111743810, -0.536494729598854030, -0.536452533744727460, -0.536410336549469460, -0.536368138013184950, -0.536325938135980840, -0.536283736917961830, +-0.536241534359233610, -0.536199330459901420, -0.536157125220070970, -0.536114918639846950, -0.536072710719336380, -0.536030501458643950, -0.535988290857875360, -0.535946078917136080, +-0.535903865636531470, -0.535861651016167340, -0.535819435056149040, -0.535777217756582050, -0.535734999117571390, -0.535692779139223970, -0.535650557821644500, -0.535608335164938780, +-0.535566111169212160, -0.535523885834570220, -0.535481659161118560, -0.535439431148962090, -0.535397201798207710, -0.535354971108960350, -0.535312739081325590, -0.535270505715408910, +-0.535228271011316090, -0.535186034969152510, -0.535143797589023860, -0.535101558871034940, -0.535059318815292890, -0.535017077421902520, -0.534974834690969510, -0.534932590622599350, +-0.534890345216897820, -0.534848098473970300, -0.534805850393921920, -0.534763600976859490, -0.534721350222888250, -0.534679098132113450, -0.534636844704641010, -0.534594589940576510, +-0.534552333840025430, -0.534510076403093560, -0.534467817629886490, -0.534425557520509130, -0.534383296075068630, -0.534341033293669890, -0.534298769176418500, -0.534256503723420260, +-0.534214236934780760, -0.534171968810604910, -0.534129699350999960, -0.534087428556070610, -0.534045156425922760, -0.534002882960662120, -0.533960608160394150, -0.533918332025224650, +-0.533876054555259440, -0.533833775750603980, -0.533791495611363410, -0.533749214137644760, -0.533706931329553160, -0.533664647187194200, -0.533622361710673570, -0.533580074900097070, +-0.533537786755569620, -0.533495497277198470, -0.533453206465088650, -0.533410914319345730, -0.533368620840075520, -0.533326326027383830, -0.533284029881376240, -0.533241732402158660, +-0.533199433589836680, -0.533157133444515320, -0.533114831966301940, -0.533072529155301570, -0.533030225011619780, -0.532987919535362400, -0.532945612726635320, -0.532903304585544140, +-0.532860995112193980, -0.532818684306691990, -0.532776372169143420, -0.532734058699653850, -0.532691743898329070, -0.532649427765275020, -0.532607110300597380, -0.532564791504402060, +-0.532522471376793870, -0.532480149917880290, -0.532437827127766330, -0.532395503006557910, -0.532353177554360620, -0.532310850771280370, -0.532268522657423080, -0.532226193212893660, +-0.532183862437799580, -0.532141530332245760, -0.532099196896338110, -0.532056862130182550, -0.532014526033884770, -0.531972188607550690, -0.531929849851286220, -0.531887509765197050, +-0.531845168349388330, -0.531802825603967520, -0.531760481529039540, -0.531718136124710420, -0.531675789391085950, -0.531633441328272060, -0.531591091936373770, -0.531548741215498440, +-0.531506389165751330, -0.531464035787238220, -0.531421681080065040, -0.531379325044337710, -0.531336967680162030, -0.531294608987643910, -0.531252248966889270, -0.531209887618003250, +-0.531167524941093210, -0.531125160936264380, -0.531082795603622700, -0.531040428943274080, -0.530998060955324310, -0.530955691639878660, -0.530913320997044470, -0.530870949026927110, +-0.530828575729632270, -0.530786201105265980, -0.530743825153934260, -0.530701447875742920, -0.530659069270797980, -0.530616689339205360, -0.530574308081070310, -0.530531925496500190, +-0.530489541585600240, -0.530447156348476500, -0.530404769785234880, -0.530362381895981280, -0.530319992680821750, -0.530277602139861410, -0.530235210273207970, -0.530192817080966330, +-0.530150422563242740, -0.530108026720143120, -0.530065629551773390, -0.530023231058239670, -0.529980831239647790, -0.529938430096103090, -0.529896027627713040, -0.529853623834583010, +-0.529811218716818800, -0.529768812274526660, -0.529726404507812390, -0.529683995416782130, -0.529641585001541130, -0.529599173262196960, -0.529556760198854890, -0.529514345811620820, +-0.529471930100601010, -0.529429513065901250, -0.529387094707627790, -0.529344675025886560, -0.529302254020782900, -0.529259831692424300, -0.529217408040916220, -0.529174983066364570, +-0.529132556768875490, -0.529090129148554910, -0.529047700205509170, -0.529005269939843310, -0.528962838351665020, -0.528920405441079770, -0.528877971208193350, -0.528835535653112140, +-0.528793098775941940, -0.528750660576789100, -0.528708221055759650, -0.528665780212959510, -0.528623338048494260, -0.528580894562471370, -0.528538449754996310, -0.528496003626175100, +-0.528453556176113780, -0.528411107404918700, -0.528368657312695110, -0.528326205899550480, -0.528283753165590510, -0.528241299110920990, -0.528198843735648400, -0.528156387039878550, +-0.528113929023717790, -0.528071469687272250, -0.528029009030647980, -0.527986547053950430, -0.527944083757287300, -0.527901619140763940, -0.527859153204486510, -0.527816685948561240, +-0.527774217373094270, -0.527731747478191740, -0.527689276263959120, -0.527646803730503990, -0.527604329877931930, -0.527561854706348980, -0.527519378215861370, -0.527476900406575360, +-0.527434421278597080, -0.527391940832032780, -0.527349459066987820, -0.527306975983570010, -0.527264491581884820, -0.527222005862038270, -0.527179518824136830, -0.527137030468286530, +-0.527094540794593610, -0.527052049803163670, -0.527009557494104270, -0.526967063867521120, -0.526924568923520130, -0.526882072662207880, -0.526839575083690390, -0.526797076188073920, +-0.526754575975464820, -0.526712074445968460, -0.526669571599692740, -0.526627067436743030, -0.526584561957225690, -0.526542055161246860, -0.526499547048913000, -0.526457037620330250, +-0.526414526875604080, -0.526372014814842410, -0.526329501438150720, -0.526286986745635230, -0.526244470737402330, -0.526201953413558240, -0.526159434774209230, -0.526116914819461660, +-0.526074393549421760, -0.526031870964195240, -0.525989347063889670, -0.525946821848610750, -0.525904295318464830, -0.525861767473558170, -0.525819238313997020, -0.525776707839887060, +-0.525734176051336100, -0.525691642948449720, -0.525649108531334170, -0.525606572800095930, -0.525564035754841230, -0.525521497395676440, -0.525478957722707810, -0.525436416736041910, +-0.525393874435784110, -0.525351330822042440, -0.525308785894922470, -0.525266239654530560, -0.525223692100972970, -0.525181143234356160, -0.525138593054786500, -0.525096041562369660, +-0.525053488757213360, -0.525010934639423500, -0.524968379209106110, -0.524925822466367880, -0.524883264411315160, -0.524840705044054110, -0.524798144364691410, -0.524755582373332640, +-0.524713019070085610, -0.524670454455056000, -0.524627888528350290, -0.524585321290074850, -0.524542752740336130, -0.524500182879240500, -0.524457611706893640, -0.524415039223403490, +-0.524372465428875830, -0.524329890323416930, -0.524287313907133350, -0.524244736180131450, -0.524202157142517720, -0.524159576794398620, -0.524116995135879840, -0.524074412167069290, +-0.524031827888072680, -0.523989242298996570, -0.523946655399947340, -0.523904067191031440, -0.523861477672355360, -0.523818886844024890, -0.523776294706147840, -0.523733701258830120, +-0.523691106502178210, -0.523648510436298450, -0.523605913061297560, -0.523563314377281760, -0.523520714384357650, -0.523478113082631810, -0.523435510472209930, -0.523392906553200030, +-0.523350301325707810, -0.523307694789839850, -0.523265086945702730, -0.523222477793402810, -0.523179867333046000, -0.523137255564740220, -0.523094642488591390, -0.523052028104705860, +-0.523009412413190320, -0.522966795414151250, -0.522924177107695230, -0.522881557493928620, -0.522838936572958210, -0.522796314344889710, -0.522753690809831140, -0.522711065967888410, +-0.522668439819168000, -0.522625812363776480, -0.522583183601820430, -0.522540553533406340, -0.522497922158640220, -0.522455289477629980, -0.522412655490481550, -0.522370020197301500, +-0.522327383598196420, -0.522284745693272770, -0.522242106482637360, -0.522199465966396660, -0.522156824144656470, -0.522114181017525050, -0.522071536585108190, -0.522028890847512470, +-0.521986243804844490, -0.521943595457210920, -0.521900945804718350, -0.521858294847472700, -0.521815642585582110, -0.521772989019152370, -0.521730334148290060, -0.521687677973102000, +-0.521645020493694770, -0.521602361710174930, -0.521559701622649200, -0.521517040231223470, -0.521474377536005900, -0.521431713537102380, -0.521389048234619620, -0.521346381628664200, +-0.521303713719342810, -0.521261044506762140, -0.521218373991028110, -0.521175702172248960, -0.521133029050530490, -0.521090354625979410, -0.521047678898702520, -0.521005001868806380, +-0.520962323536397820, -0.520919643901583410, -0.520876962964469840, -0.520834280725163130, -0.520791597183771550, -0.520748912340400880, -0.520706226195157940, -0.520663538748149520, +-0.520620849999482100, -0.520578159949261930, -0.520535468597597030, -0.520492775944593530, -0.520450081990358140, -0.520407386734997420, -0.520364690178618310, -0.520321992321327480, +-0.520279293163231630, -0.520236592704437560, -0.520193890945051200, -0.520151187885180890, -0.520108483524932660, -0.520065777864413210, -0.520023070903729350, -0.519980362642987750, +-0.519937653082295230, -0.519894942221757810, -0.519852230061483840, -0.519809516601579370, -0.519766801842150960, -0.519724085783305640, -0.519681368425150110, -0.519638649767791060, +-0.519595929811335510, -0.519553208555889270, -0.519510486001560910, -0.519467762148456250, -0.519425036996682080, -0.519382310546345430, -0.519339582797552990, -0.519296853750411680, +-0.519254123405027300, -0.519211391761508540, -0.519168658819961220, -0.519125924580492230, -0.519083189043208490, -0.519040452208216710, -0.518997714075623780, -0.518954974645536640, +-0.518912233918061290, -0.518869491893306110, -0.518826748571377230, -0.518784003952381450, -0.518741258036425680, -0.518698510823616730, -0.518655762314061520, -0.518613012507866070, +-0.518570261405138950, -0.518527509005986100, -0.518484755310514520, -0.518442000318831140, -0.518399244031042650, -0.518356486447256070, -0.518313727567578320, -0.518270967392116200, +-0.518228205920975850, -0.518185443154265850, -0.518142679092092220, -0.518099913734561880, -0.518057147081781740, -0.518014379133858730, -0.517971609890898970, -0.517928839353011040, +-0.517886067520300970, -0.517843294392875690, -0.517800519970842200, -0.517757744254307430, -0.517714967243378290, -0.517672188938161800, -0.517629409338764780, -0.517586628445293460, +-0.517543846257856320, -0.517501062776559610, -0.517458278001510230, -0.517415491932815110, -0.517372704570581380, -0.517329915914915730, -0.517287125965924630, -0.517244334723716450, +-0.517201542188397420, -0.517158748360074580, -0.517115953238854840, -0.517073156824845230, -0.517030359118152650, -0.516987560118884250, -0.516944759827146160, -0.516901958243046970, +-0.516859155366692910, -0.516816351198190920, -0.516773545737648000, -0.516730738985171300, -0.516687930940867620, -0.516645121604843550, -0.516602310977207320, -0.516559499058065310, +-0.516516685847524530, -0.516473871345692110, -0.516431055552674990, -0.516388238468580170, -0.516345420093514810, -0.516302600427585130, -0.516259779470899740, -0.516216957223564870, +-0.516174133685687650, -0.516131308857375020, -0.516088482738734200, -0.516045655329872120, -0.516002826630895140, -0.515959996641911830, -0.515917165363028560, -0.515874332794352350, +-0.515831498935990340, -0.515788663788049660, -0.515745827350637230, -0.515702989623860190, -0.515660150607825770, -0.515617310302640130, -0.515574468708412060, -0.515531625825247810, +-0.515488781653254400, -0.515445936192539090, -0.515403089443209010, -0.515360241405370290, -0.515317392079131850, -0.515274541464599940, -0.515231689561881590, -0.515188836371084040, +-0.515145981892314530, -0.515103126125679880, -0.515060269071287550, -0.515017410729244450, -0.514974551099657060, -0.514931690182634180, -0.514888827978281950, -0.514845964486707720, +-0.514803099708018520, -0.514760233642321600, -0.514717366289724090, -0.514674497650332460, -0.514631627724255300, -0.514588756511599080, -0.514545884012470920, -0.514503010226978090, +-0.514460135155227700, -0.514417258797327030, -0.514374381153383190, -0.514331502223502660, -0.514288622007794130, -0.514245740506364070, -0.514202857719319620, -0.514159973646767910, +-0.514117088288816420, -0.514074201645572160, -0.514031313717141720, -0.513988424503633580, -0.513945534005154530, -0.513902642221811590, -0.513859749153712020, -0.513816854800963170, +-0.513773959163672080, -0.513731062241946090, -0.513688164035891790, -0.513645264545617760, -0.513602363771230590, -0.513559461712837510, -0.513516558370545770, -0.513473653744462630, +-0.513430747834695330, -0.513387840641350460, -0.513344932164536690, -0.513302022404360620, -0.513259111360929500, -0.513216199034350670, -0.513173285424731280, -0.513130370532178580, +-0.513087454356800140, -0.513044536898702890, -0.513001618157993610, -0.512958698134781120, -0.512915776829171780, -0.512872854241273050, -0.512829930371192180, -0.512787005219036420, +-0.512744078784912460, -0.512701151068929000, -0.512658222071192720, -0.512615291791810870, -0.512572360230890810, -0.512529427388539790, -0.512486493264865280, -0.512443557859974530, +-0.512400621173974890, -0.512357683206972840, -0.512314743959077390, -0.512271803430395130, -0.512228861621033320, -0.512185918531099290, -0.512142974160700650, -0.512100028509943630, +-0.512057081578937370, -0.512014133367788450, -0.511971183876604120, -0.511928233105491850, -0.511885281054558990, -0.511842327723913030, -0.511799373113661080, -0.511756417223910850, +-0.511713460054768700, -0.511670501606343750, -0.511627541878742490, -0.511584580872072480, -0.511541618586440870, -0.511498655021955240, -0.511455690178723050, -0.511412724056850900, +-0.511369756656447570, -0.511326787977619880, -0.511283818020475290, -0.511240846785121160, -0.511197874271664850, -0.511154900480213840, -0.511111925410875690, -0.511068949063756880, +-0.511025971438966440, -0.510982992536611170, -0.510940012356798310, -0.510897030899635450, -0.510854048165230060, -0.510811064153689490, -0.510768078865120550, -0.510725092299632140, +-0.510682104457330980, -0.510639115338324620, -0.510596124942720440, -0.510553133270625900, -0.510510140322148590, -0.510467146097395850, -0.510424150596475390, -0.510381153819493670, +-0.510338155766559830, -0.510295156437780670, -0.510252155833263550, -0.510209153953116170, -0.510166150797445760, -0.510123146366359250, -0.510080140659965650, -0.510037133678371780, +-0.509994125421684990, -0.509951115890012850, -0.509908105083462960, -0.509865093002142780, -0.509822079646159890, -0.509779065015621870, -0.509736049110635300, -0.509693031931309440, +-0.509650013477751070, -0.509606993750067570, -0.509563972748366620, -0.509520950472755700, -0.509477926923341710, -0.509434902100233570, -0.509391876003538190, -0.509348848633363160, +-0.509305819989816060, -0.509262790073004350, -0.509219758883035610, -0.509176726420017540, -0.509133692684057730, -0.509090657675262850, -0.509047621393742040, -0.509004583839602230, +-0.508961545012950990, -0.508918504913895790, -0.508875463542544430, -0.508832420899004380, -0.508789376983382450, -0.508746331795787880, -0.508703285336327580, -0.508660237605108920, +-0.508617188602239700, -0.508574138327827610, -0.508531086781980110, -0.508488033964804800, -0.508444979876408800, -0.508401924516901030, -0.508358867886388400, -0.508315809984978720, +-0.508272750812779450, -0.508229690369898290, -0.508186628656442930, -0.508143565672520280, -0.508100501418239370, -0.508057435893707330, -0.508014369099031530, -0.507971301034319980, +-0.507928231699680040, -0.507885161095219640, -0.507842089221046340, -0.507799016077267740, -0.507755941663990850, -0.507712865981324920, -0.507669789029376760, -0.507626710808254170, +-0.507583631318064720, -0.507540550558916340, -0.507497468530915710, -0.507454385234172190, -0.507411300668792700, -0.507368214834885030, -0.507325127732556780, -0.507282039361915630, +-0.507238949723069490, -0.507195858816125940, -0.507152766641192800, -0.507109673198376850, -0.507066578487787580, -0.507023482509531890, -0.506980385263717360, -0.506937286750452020, +-0.506894186969843340, -0.506851085921998460, -0.506807983607026720, -0.506764880025034950, -0.506721775176130930, -0.506678669060422580, -0.506635561678017490, -0.506592453029023560, +-0.506549343113548380, -0.506506231931699970, -0.506463119483585130, -0.506420005769313230, -0.506376890788991400, -0.506333774542727320, -0.506290657030628810, -0.506247538252803660, +-0.506204418209359570, -0.506161296900403790, -0.506118174326045440, -0.506075050486391790, -0.506031925381550400, -0.505988799011629190, -0.505945671376736070, -0.505902542476978630, +-0.505859412312465010, -0.505816280883301990, -0.505773148189599060, -0.505730014231463240, -0.505686879009002330, -0.505643742522324360, -0.505600604771536900, -0.505557465756748090, +-0.505514325478064740, -0.505471183935596310, -0.505428041129449950, -0.505384897059733550, -0.505341751726554820, -0.505298605130021780, -0.505255457270242130, -0.505212308147323990, +-0.505169157761374170, -0.505126006112502360, -0.505082853200815360, -0.505039699026421320, -0.504996543589428140, -0.504953386889943400, -0.504910228928075360, -0.504867069703930920, +-0.504823909217619550, -0.504780747469248390, -0.504737584458925360, -0.504694420186758470, -0.504651254652855430, -0.504608087857324250, -0.504564919800272960, -0.504521750481809250, +-0.504478579902040480, -0.504435408061076010, -0.504392234959022970, -0.504349060595989380, -0.504305884972083060, -0.504262708087412140, -0.504219529942083630, -0.504176350536207130, +-0.504133169869889650, -0.504089987943239340, -0.504046804756363990, -0.504003620309371620, -0.503960434602370280, -0.503917247635467750, -0.503874059408772170, -0.503830869922390680, +-0.503787679176432750, -0.503744487171005730, -0.503701293906217320, -0.503658099382175760, -0.503614903598988970, -0.503571706556764860, -0.503528508255610800, -0.503485308695636240, +-0.503442107876948320, -0.503398905799655180, -0.503355702463864740, -0.503312497869685130, -0.503269292017224150, -0.503226084906590040, -0.503182876537889840, -0.503139666911233350, +-0.503096456026727700, -0.503053243884480810, -0.503010030484600800, -0.502966815827195820, -0.502923599912373680, -0.502880382740241830, -0.502837164310909860, -0.502793944624484900, +-0.502750723681075100, -0.502707501480788470, -0.502664278023733150, -0.502621053310017050, -0.502577827339748320, -0.502534600113034300, -0.502491371629984580, -0.502448141890706410, +-0.502404910895307810, -0.502361678643897020, -0.502318445136581970, -0.502275210373470890, -0.502231974354670930, -0.502188737080291770, -0.502145498550440880, -0.502102258765226180, +-0.502059017724755920, -0.502015775429138000, -0.501972531878480680, -0.501929287072892080, -0.501886041012480240, -0.501842793697352410, -0.501799545127618480, -0.501756295303385720, +-0.501713044224762150, -0.501669791891856010, -0.501626538304775330, -0.501583283463627570, -0.501540027368522430, -0.501496770019567160, -0.501453511416870000, -0.501410251560539090, +-0.501366990450682450, -0.501323728087408440, -0.501280464470824970, -0.501237199601040410, -0.501193933478162100, -0.501150666102299750, -0.501107397473560700, -0.501064127592053210, +-0.501020856457885300, -0.500977584071165330, -0.500934310432001430, -0.500891035540500850, -0.500847759396773620, -0.500804482000926860, -0.500761203353068950, -0.500717923453308010, +-0.500674642301752290, -0.500631359898509930, -0.500588076243689170, -0.500544791337397490, -0.500501505179744570, -0.500458217770837880, -0.500414929110785670, -0.500371639199696070, +-0.500328348037677450, -0.500285055624837940, -0.500241761961285000, -0.500198467047128450, -0.500155170882475740, -0.500111873467435130, -0.500068574802114750, -0.500025274886623070, +-0.499981973721068060, -0.499938671305558190, -0.499895367640200870, -0.499852062725105850, -0.499808756560380710, -0.499765449146133690, -0.499722140482473040, -0.499678830569507020, +-0.499635519407343960, -0.499592206996091300, -0.499548893335858890, -0.499505578426754250, -0.499462262268885680, -0.499418944862361490, -0.499375626207289870, -0.499332306303779230, +-0.499288985151937760, -0.499245662751873880, -0.499202339103695100, -0.499159014207511190, -0.499115688063429760, -0.499072360671559130, -0.499029032032007550, -0.498985702144883470, +-0.498942371010294260, -0.498899038628350000, -0.498855704999158100, -0.498812370122826920, -0.498769033999464820, -0.498725696629180150, -0.498682358012081220, -0.498639018148276380, +-0.498595677037874050, -0.498552334680981700, -0.498508991077709300, -0.498465646228164470, -0.498422300132455480, -0.498378952790690780, -0.498335604202978620, -0.498292254369427530, +-0.498248903290144980, -0.498205550965240940, -0.498162197394823090, -0.498118842578999690, -0.498075486517879200, -0.498032129211569970, -0.497988770660180440, -0.497945410863818990, +-0.497902049822593230, -0.497858687536613110, -0.497815324005986270, -0.497771959230821180, -0.497728593211226090, -0.497685225947309570, -0.497641857439179990, -0.497598487686945030, +-0.497555116690714560, -0.497511744450596320, -0.497468370966698710, -0.497424996239130220, -0.497381620267999200, -0.497338243053414120, -0.497294864595483440, -0.497251484894314870, +-0.497208103950018300, -0.497164721762701490, -0.497121338332472910, -0.497077953659440910, -0.497034567743714070, -0.496991180585400820, -0.496947792184608830, -0.496904402541448190, +-0.496861011656026470, -0.496817619528452270, -0.496774226158833990, -0.496730831547280150, -0.496687435693899230, -0.496644038598799690, -0.496600640262090110, -0.496557240683878130, +-0.496513839864273830, -0.496470437803384900, -0.496427034501319920, -0.496383629958187360, -0.496340224174095680, -0.496296817149152690, -0.496253408883468420, -0.496209999377150660, +-0.496166588630307880, -0.496123176643048610, -0.496079763415481430, -0.496036348947714810, -0.495992933239857330, -0.495949516292017560, -0.495906098104303140, -0.495862678676824320, +-0.495819258009688790, -0.495775836103005070, -0.495732412956881810, -0.495688988571427510, -0.495645562946750720, -0.495602136082959280, -0.495558707980163270, -0.495515278638470450, +-0.495471848057989490, -0.495428416238828830, -0.495384983181097190, -0.495341548884903120, -0.495298113350355120, -0.495254676577561060, -0.495211238566631130, -0.495167799317673070, +-0.495124358830795530, -0.495080917106107080, -0.495037474143716350, -0.494994029943731930, -0.494950584506261670, -0.494907137831415710, -0.494863689919301910, -0.494820240770028840, +-0.494776790383705200, -0.494733338760439620, -0.494689885900340690, -0.494646431803517030, -0.494602976470076510, -0.494559519900129310, -0.494516062093783290, -0.494472603051147150, +-0.494429142772329520, -0.494385681257439040, -0.494342218506584330, -0.494298754519873260, -0.494255289297416130, -0.494211822839320800, -0.494168355145695850, -0.494124886216650070, +-0.494081416052292060, -0.494037944652730490, -0.493994472018074060, -0.493950998148431460, -0.493907523043910560, -0.493864046704621640, -0.493820569130672630, -0.493777090322172210, +-0.493733610279229020, -0.493690129001951810, -0.493646646490448540, -0.493603162744829400, -0.493559677765202380, -0.493516191551676140, -0.493472704104359390, -0.493429215423360930, +-0.493385725508789450, -0.493342234360753580, -0.493298741979362190, -0.493255248364723120, -0.493211753516946740, -0.493168257436141010, -0.493124760122414570, -0.493081261575876280, +-0.493037761796634780, -0.492994260784798910, -0.492950758540476650, -0.492907255063778190, -0.492863750354811670, -0.492820244413685720, -0.492776737240509190, -0.492733228835390780, +-0.492689719198439350, -0.492646208329763580, -0.492602696229471500, -0.492559182897673530, -0.492515668334477520, -0.492472152539992380, -0.492428635514326860, -0.492385117257589770, +-0.492341597769889840, -0.492298077051335160, -0.492254555102036080, -0.492211031922100580, -0.492167507511637570, -0.492123981870755730, -0.492080454999563930, -0.492036926898171020, +-0.491993397566685750, -0.491949867005216260, -0.491906335213872890, -0.491862802192763630, -0.491819267941997370, -0.491775732461682990, -0.491732195751929220, -0.491688657812844990, +-0.491645118644538360, -0.491601578247119700, -0.491558036620697080, -0.491514493765379370, -0.491470949681275420, -0.491427404368494140, -0.491383857827144280, -0.491340310057334810, +-0.491296761059174580, -0.491253210832771630, -0.491209659378236460, -0.491166106695677170, -0.491122552785202560, -0.491078997646921590, -0.491035441280943120, -0.490991883687375290, +-0.490948324866328500, -0.490904764817910900, -0.490861203542231390, -0.490817641039398900, -0.490774077309522270, -0.490730512352710480, -0.490686946169072380, -0.490643378758716940, +-0.490599810121752240, -0.490556240258288870, -0.490512669168434830, -0.490469096852299110, -0.490425523309990670, -0.490381948541618430, -0.490338372547291350, -0.490294795327117510, +-0.490251216881207490, -0.490207637209669420, -0.490164056312612230, -0.490120474190144930, -0.490076890842376430, -0.490033306269415710, -0.489989720471371740, -0.489946133448352640, +-0.489902545200469050, -0.489858955727829060, -0.489815365030541680, -0.489771773108715890, -0.489728179962460650, -0.489684585591884990, -0.489640989997097100, -0.489597393178207500, +-0.489553795135324380, -0.489510195868556820, -0.489466595378013740, -0.489422993663804210, -0.489379390726037140, -0.489335786564821630, -0.489292181180265850, -0.489248574572480440, +-0.489204966741573540, -0.489161357687654290, -0.489117747410831580, -0.489074135911214570, -0.489030523188912160, -0.488986909244032710, -0.488943294076686740, -0.488899677686982500, +-0.488856060075029130, -0.488812441240935590, -0.488768821184810910, -0.488725199906764220, -0.488681577406904490, -0.488637953685340850, -0.488594328742181560, -0.488550702577537190, +-0.488507075191516090, -0.488463446584227300, -0.488419816755779890, -0.488376185706282940, -0.488332553435844750, -0.488288919944575960, -0.488245285232584810, -0.488201649299980560, +-0.488158012146872100, -0.488114373773368640, -0.488070734179579250, -0.488027093365613010, -0.487983451331579000, -0.487939808077585640, -0.487896163603743550, -0.487852517910160990, +-0.487808870996947200, -0.487765222864211200, -0.487721573512062130, -0.487677922940608350, -0.487634271149960550, -0.487590618140227080, -0.487546963911517080, -0.487503308463939630, +-0.487459651797603980, -0.487415993912619140, -0.487372334809094310, -0.487328674487138680, -0.487285012946860550, -0.487241350188370670, -0.487197686211777450, -0.487154021017189960, +-0.487110354604717470, -0.487066686974469090, -0.487023018126553960, -0.486979348061080510, -0.486935676778159520, -0.486892004277899300, -0.486848330560409050, -0.486804655625798000, +-0.486760979474175290, -0.486717302105650120, -0.486673623520331780, -0.486629943718328520, -0.486586262699751190, -0.486542580464708220, -0.486498897013308780, -0.486455212345662140, +-0.486411526461877460, -0.486367839362063960, -0.486324151046330030, -0.486280461514786540, -0.486236770767541900, -0.486193078804705360, -0.486149385626386100, -0.486105691232693370, +-0.486061995623736420, -0.486018298799624440, -0.485974600760466780, -0.485930901506371800, -0.485887201037450370, -0.485843499353810880, -0.485799796455562700, -0.485756092342815030, +-0.485712387015677090, -0.485668680474257430, -0.485624972718666840, -0.485581263749013840, -0.485537553565407620, -0.485493842167957550, -0.485450129556772910, -0.485406415731962910, +-0.485362700693636910, -0.485318984441904130, -0.485275266976873070, -0.485231548298654670, -0.485187828407357410, -0.485144107303090540, -0.485100384985963420, -0.485056661456085340, +-0.485012936713564820, -0.484969210758512740, -0.484925483591037650, -0.484881755211248820, -0.484838025619255650, -0.484794294815167390, -0.484750562799093400, -0.484706829571142970, +-0.484663095131425470, -0.484619359480049530, -0.484575622617125890, -0.484531884542763190, -0.484488145257070850, -0.484444404760158100, -0.484400663052134310, -0.484356920133108940, +-0.484313176003190400, -0.484269430662489790, -0.484225684111115550, -0.484181936349177110, -0.484138187376783820, -0.484094437194045050, -0.484050685801070250, -0.484006933197968670, +-0.483963179384849010, -0.483919424361822170, -0.483875668128996740, -0.483831910686482180, -0.483788152034387850, -0.483744392172823110, -0.483700631101897430, -0.483656868821719380, +-0.483613105332399870, -0.483569340634047660, -0.483525574726772100, -0.483481807610682600, -0.483438039285888580, -0.483394269752499440, -0.483350499010624660, -0.483306727060373640, +-0.483262953901854970, -0.483219179535179730, -0.483175403960456550, -0.483131627177794840, -0.483087849187304070, -0.483044069989093660, -0.483000289583272350, -0.482956507969951040, +-0.482912725149238440, -0.482868941121244120, -0.482825155886077380, -0.482781369443847750, -0.482737581794664690, -0.482693792938637730, -0.482650002875876230, -0.482606211606488980, +-0.482562419130586950, -0.482518625448278890, -0.482474830559674270, -0.482431034464882560, -0.482387237164013270, -0.482343438657175160, -0.482299638944479140, -0.482255838026034110, +-0.482212035901949440, -0.482168232572334650, -0.482124428037299320, -0.482080622296952920, -0.482036815351404970, -0.481993007200764990, -0.481949197845141670, -0.481905387284646160, +-0.481861575519387190, -0.481817762549474280, -0.481773948375016910, -0.481730132996124720, -0.481686316412907210, -0.481642498625473090, -0.481598679633933550, -0.481554859438397260, +-0.481511038038973880, -0.481467215435772870, -0.481423391628903800, -0.481379566618476310, -0.481335740404599870, -0.481291912987383270, -0.481248084366937720, -0.481204254543371900, +-0.481160423516795500, -0.481116591287318040, -0.481072757855049050, -0.481028923220098210, -0.480985087382574280, -0.480941250342588390, -0.480897412100249390, -0.480853572655666860, +-0.480809732008950390, -0.480765890160209600, -0.480722047109554070, -0.480678202857093450, -0.480634357402937310, -0.480590510747194500, -0.480546662889976160, -0.480502813831391210, +-0.480458963571549210, -0.480415112110559760, -0.480371259448532590, -0.480327405585576460, -0.480283550521802600, -0.480239694257319880, -0.480195836792237930, -0.480151978126666380, +-0.480108118260714870, -0.480064257194493080, -0.480020394928110610, -0.479976531461677180, -0.479932666795301670, -0.479888800929095250, -0.479844933863166790, -0.479801065597626030, +-0.479757196132582610, -0.479713325468146210, -0.479669453604425700, -0.479625580541532310, -0.479581706279575030, -0.479537830818663410, -0.479493954158907280, -0.479450076300416250, +-0.479406197243300030, -0.479362316987668290, -0.479318435533630790, -0.479274552881296390, -0.479230669030776380, -0.479186783982179730, -0.479142897735616140, -0.479099010291195280, +-0.479055121649026860, -0.479011231809220670, -0.478967340771885630, -0.478923448537133030, -0.478879555105071740, -0.478835660475811660, -0.478791764649462380, -0.478747867626133640, +-0.478703969405935290, -0.478660069988977030, -0.478616169375367770, -0.478572267565218870, -0.478528364558639340, -0.478484460355738880, -0.478440554956627240, -0.478396648361414270, +-0.478352740570209660, -0.478308831583122370, -0.478264921400263830, -0.478221010021743000, -0.478177097447669620, -0.478133183678153490, -0.478089268713304370, -0.478045352553232160, +-0.478001435198046500, -0.477957516647856520, -0.477913596902773520, -0.477869675962906470, -0.477825753828365280, -0.477781830499259710, -0.477737905975699540, -0.477693980257794640, +-0.477650053345653970, -0.477606125239389000, -0.477562195939108650, -0.477518265444922870, -0.477474333756941370, -0.477430400875274110, -0.477386466800030770, -0.477342531531321280, +-0.477298595069254710, -0.477254657413942460, -0.477210718565493520, -0.477166778524017790, -0.477122837289625120, -0.477078894862425330, -0.477034951242528320, -0.476991006430043940, +-0.476947060425081280, -0.476903113227751700, -0.476859164838164370, -0.476815215256429170, -0.476771264482655890, -0.476727312516954440, -0.476683359359434680, -0.476639405010206570, +-0.476595449469379150, -0.476551492737063930, -0.476507534813369940, -0.476463575698407080, -0.476419615392285330, -0.476375653895114550, -0.476331691207004580, -0.476287727328064630, +-0.476243762258406140, -0.476199795998138280, -0.476155828547370870, -0.476111859906213960, -0.476067890074777340, -0.476023919053171040, -0.475979946841504910, -0.475935973439888140, +-0.475891998848432200, -0.475848023067246270, -0.475804046096440340, -0.475760067936124240, -0.475716088586407960, -0.475672108047401510, -0.475628126319213970, -0.475584143401956870, +-0.475540159295739450, -0.475496174000671620, -0.475452187516863410, -0.475408199844424670, -0.475364210983465430, -0.475320220934095710, -0.475276229696424580, -0.475232237270563740, +-0.475188243656622270, -0.475144248854710180, -0.475100252864937460, -0.475056255687414110, -0.475012257322250160, -0.474968257769554760, -0.474924257029439520, -0.474880255102013590, +-0.474836251987387050, -0.474792247685669910, -0.474748242196972090, -0.474704235521403730, -0.474660227659074730, -0.474616218610094400, -0.474572208374574310, -0.474528196952623660, +-0.474484184344352580, -0.474440170549870980, -0.474396155569288990, -0.474352139402716590, -0.474308122050263850, -0.474264103512040070, -0.474220083788156780, -0.474176062878723270, +-0.474132040783849570, -0.474088017503645820, -0.474043993038221980, -0.473999967387688240, -0.473955940552154510, -0.473911912531730150, -0.473867883326526800, -0.473823852936653740, +-0.473779821362221080, -0.473735788603338870, -0.473691754660117150, -0.473647719532666040, -0.473603683221094860, -0.473559645725515290, -0.473515607046036570, -0.473471567182768840, +-0.473427526135822170, -0.473383483905306710, -0.473339440491332530, -0.473295395894009760, -0.473251350113447710, -0.473207303149758060, -0.473163255003050180, -0.473119205673434130, +-0.473075155161020110, -0.473031103465918200, -0.472987050588238480, -0.472942996528090350, -0.472898941285585570, -0.472854884860833380, -0.472810827253944020, -0.472766768465027580, +-0.472722708494194230, -0.472678647341554070, -0.472634585007217330, -0.472590521491293320, -0.472546456793893840, -0.472502390915128130, -0.472458323855106500, -0.472414255613939070, +-0.472370186191735990, -0.472326115588607430, -0.472282043804662820, -0.472237970840013840, -0.472193896694769970, -0.472149821369041380, -0.472105744862938210, -0.472061667176570670, +-0.472017588310048970, -0.471973508263483280, -0.471929427036983040, -0.471885344630660060, -0.471841261044623710, -0.471797176278984150, -0.471753090333851710, -0.471709003209336510, +-0.471664914905548790, -0.471620825422598810, -0.471576734760596030, -0.471532642919652130, -0.471488549899876650, -0.471444455701379770, -0.471400360324271740, -0.471356263768662850, +-0.471312166034663300, -0.471268067122383340, -0.471223967031932370, -0.471179865763422300, -0.471135763316962610, -0.471091659692663480, -0.471047554890635160, -0.471003448910988000, +-0.470959341753832190, -0.470915233419277270, -0.470871123907435020, -0.470827013218415020, -0.470782901352327420, -0.470738788309282620, -0.470694674089390810, -0.470650558692762340, +-0.470606442119507420, -0.470562324369735660, -0.470518205443558880, -0.470474085341086590, -0.470429964062429040, -0.470385841607696640, -0.470341717976999580, -0.470297593170448280, +-0.470253467188152140, -0.470209340030223190, -0.470165211696770840, -0.470121082187905490, -0.470076951503737460, -0.470032819644376990, -0.469988686609934480, -0.469944552400520300, +-0.469900417016243910, -0.469856280457217280, -0.469812142723549990, -0.469768003815352280, -0.469723863732734560, -0.469679722475807250, -0.469635580044680530, -0.469591436439464160, +-0.469547291660269980, -0.469503145707207530, -0.469458998580387250, -0.469414850279919470, -0.469370700805914530, -0.469326550158482850, -0.469282398337734830, -0.469238245343780000, +-0.469194091176730330, -0.469149935836695450, -0.469105779323785720, -0.469061621638111550, -0.469017462779783350, -0.468973302748911470, -0.468929141545606330, -0.468884979169977570, +-0.468840815622137140, -0.468796650902194630, -0.468752485010260570, -0.468708317946445240, -0.468664149710859120, -0.468619980303612630, -0.468575809724816220, -0.468531637974579470, +-0.468487465053014420, -0.468443290960230680, -0.468399115696338740, -0.468354939261449000, -0.468310761655671930, -0.468266582879117930, -0.468222402931896760, -0.468178221814120280, +-0.468134039525898270, -0.468089856067341210, -0.468045671438559460, -0.468001485639663540, -0.467957298670763910, -0.467913110531971040, -0.467868921223394570, -0.467824730745146630, +-0.467780539097336860, -0.467736346280075710, -0.467692152293473720, -0.467647957137641350, -0.467603760812689060, -0.467559563318726610, -0.467515364655866020, -0.467471164824217020, +-0.467426963823890150, -0.467382761654995820, -0.467338558317644590, -0.467294353811947010, -0.467250148138013520, -0.467205941295953830, -0.467161733285880120, -0.467117524107902080, +-0.467073313762130240, -0.467029102248675050, -0.466984889567647170, -0.466940675719157040, -0.466896460703314420, -0.466852244520231500, -0.466808027170017900, -0.466763808652784270, +-0.466719588968641070, -0.466675368117698940, -0.466631146100068390, -0.466586922915859960, -0.466542698565183430, -0.466498473048150950, -0.466454246364872320, -0.466410018515458050, +-0.466365789500018720, -0.466321559318664920, -0.466277327971507230, -0.466233095458656210, -0.466188861780221670, -0.466144626936315810, -0.466100390927048300, -0.466056153752529840, +-0.466011915412871010, -0.465967675908182390, -0.465923435238574600, -0.465879193404158180, -0.465834950405043020, -0.465790706241341280, -0.465746460913162740, -0.465702214420618100, +-0.465657966763817880, -0.465613717942872760, -0.465569467957893330, -0.465525216808989450, -0.465480964496273300, -0.465436711019854790, -0.465392456379844440, -0.465348200576353010, +-0.465303943609491010, -0.465259685479369190, -0.465215426186098180, -0.465171165729787780, -0.465126904110550240, -0.465082641328495470, -0.465038377383734100, -0.464994112276376770, +-0.464949846006534220, -0.464905578574316970, -0.464861309979835050, -0.464817040223200580, -0.464772769304523550, -0.464728497223914570, -0.464684223981484400, -0.464639949577343610, +-0.464595674011603010, -0.464551397284373170, -0.464507119395764060, -0.464462840345887920, -0.464418560134854720, -0.464374278762775150, -0.464329996229759790, -0.464285712535919490, +-0.464241427681364950, -0.464197141666206010, -0.464152854490554990, -0.464108566154521840, -0.464064276658217310, -0.464019986001752040, -0.463975694185236820, -0.463931401208782400, +-0.463887107072499420, -0.463842811776497940, -0.463798515320890170, -0.463754217705786180, -0.463709918931296590, -0.463665618997532230, -0.463621317904603760, -0.463577015652622050, +-0.463532712241697790, -0.463488407671940990, -0.463444101943463920, -0.463399795056376630, -0.463355487010789820, -0.463311177806814300, -0.463266867444560860, -0.463222555924140190, +-0.463178243245663200, -0.463133929409239810, -0.463089614414982310, -0.463045298263000840, -0.463000980953406140, -0.462956662486308960, -0.462912342861820090, -0.462868022080050400, +-0.462823700141109850, -0.462779377045110850, -0.462735052792163430, -0.462690727382378380, -0.462646400815866440, -0.462602073092738600, -0.462557744213105470, -0.462513414177078030, +-0.462469082984766300, -0.462424750636282630, -0.462380417131737050, -0.462336082471240470, -0.462291746654903690, -0.462247409682837510, -0.462203071555152780, -0.462158732271959640, +-0.462114391833370440, -0.462070050239495270, -0.462025707490444970, -0.461981363586330350, -0.461937018527262380, -0.461892672313351850, -0.461848324944709620, -0.461803976421445830, +-0.461759626743672880, -0.461715275911500860, -0.461670923925040610, -0.461626570784403110, -0.461582216489699100, -0.461537861041039610, -0.461493504438534710, -0.461449146682296810, +-0.461404787772435990, -0.461360427709063270, -0.461316066492289460, -0.461271704122225460, -0.461227340598982240, -0.461182975922670600, -0.461138610093400790, -0.461094243111285220, +-0.461049874976434070, -0.461005505688958210, -0.460961135248968590, -0.460916763656576130, -0.460872390911891800, -0.460828017015025680, -0.460783641966090280, -0.460739265765195800, +-0.460694888412453150, -0.460650509907973290, -0.460606130251867140, -0.460561749444245660, -0.460517367485219820, -0.460472984374900530, -0.460428600113398030, -0.460384214700824800, +-0.460339828137291020, -0.460295440422907710, -0.460251051557785780, -0.460206661542036210, -0.460162270375770010, -0.460117878059097320, -0.460073484592130770, -0.460029089974980430, +-0.459984694207757450, -0.459940297290572670, -0.459895899223537190, -0.459851500006761950, -0.459807099640357930, -0.459762698124435380, -0.459718295459106920, -0.459673891644482690, +-0.459629486680673720, -0.459585080567791020, -0.459540673305945670, -0.459496264895248590, -0.459451855335810120, -0.459407444627742740, -0.459363032771156750, -0.459318619766163230, +-0.459274205612873130, -0.459229790311397490, -0.459185373861847430, -0.459140956264333880, -0.459096537518967170, -0.459052117625859900, -0.459007696585122360, -0.458963274396865570, +-0.458918851061200620, -0.458874426578238510, -0.458830000948090340, -0.458785574170866350, -0.458741146246679220, -0.458696717175639260, -0.458652286957857480, -0.458607855593445020, +-0.458563423082512910, -0.458518989425172220, -0.458474554621534080, -0.458430118671708740, -0.458385681575808890, -0.458341243333944830, -0.458296803946227680, -0.458252363412768540, +-0.458207921733678470, -0.458163478909068610, -0.458119034939049260, -0.458074589823733060, -0.458030143563230460, -0.457985696157652440, -0.457941247607110250, -0.457896797911714890, +-0.457852347071577510, -0.457807895086809360, -0.457763441957521390, -0.457718987683824020, -0.457674532265830050, -0.457630075703649660, -0.457585617997394110, -0.457541159147174530, +-0.457496699153102090, -0.457452238015287840, -0.457407775733842230, -0.457363312308877950, -0.457318847740505410, -0.457274382028835750, -0.457229915173980150, -0.457185447176049700, +-0.457140978035155690, -0.457096507751409250, -0.457052036324920700, -0.457007563755802870, -0.456963090044166130, -0.456918615190121670, -0.456874139193780670, -0.456829662055254330, +-0.456785183774653820, -0.456740704352089580, -0.456696223787674330, -0.456651742081518540, -0.456607259233733410, -0.456562775244430120, -0.456518290113719920, -0.456473803841713990, +-0.456429316428523520, -0.456384827874258990, -0.456340338179033130, -0.456295847342956470, -0.456251355366140200, -0.456206862248695550, -0.456162367990733730, -0.456117872592365970, +-0.456073376053702790, -0.456028878374856890, -0.455984379555938850, -0.455939879597059840, -0.455895378498331120, -0.455850876259863980, -0.455806372881769620, -0.455761868364159330, +-0.455717362707143580, -0.455672855910835280, -0.455628347975344740, -0.455583838900783410, -0.455539328687262430, -0.455494817334893170, -0.455450304843786850, -0.455405791214053950, +-0.455361276445807370, -0.455316760539157650, -0.455272243494215970, -0.455227725311093730, -0.455183205989902140, -0.455138685530752540, -0.455094163933756230, -0.455049641199024520, +-0.455005117326667930, -0.454960592316799310, -0.454916066169529230, -0.454871538884968950, -0.454827010463229870, -0.454782480904423190, -0.454737950208660370, -0.454693418376051870, +-0.454648885406710610, -0.454604351300747170, -0.454559816058272840, -0.454515279679398920, -0.454470742164236830, -0.454426203512897920, -0.454381663725493490, -0.454337122802134060, +-0.454292580742932660, -0.454248037547999810, -0.454203493217446850, -0.454158947751385160, -0.454114401149926070, -0.454069853413181010, -0.454025304541260550, -0.453980754534277550, +-0.453936203392342750, -0.453891651115567400, -0.453847097704062900, -0.453802543157940660, -0.453757987477312110, -0.453713430662288530, -0.453668872712980620, -0.453624313629501340, +-0.453579753411961220, -0.453535192060471770, -0.453490629575144300, -0.453446065956090270, -0.453401501203421100, -0.453356935317247360, -0.453312368297682070, -0.453267800144835860, +-0.453223230858820160, -0.453178660439746360, -0.453134088887725940, -0.453089516202870300, -0.453044942385290860, -0.453000367435098250, -0.452955791352405550, -0.452911214137323330, +-0.452866635789963110, -0.452822056310436320, -0.452777475698854350, -0.452732893955328670, -0.452688311079969980, -0.452643727072891360, -0.452599141934203360, -0.452554555664017530, +-0.452509968262445330, -0.452465379729598160, -0.452420790065587550, -0.452376199270525030, -0.452331607344521160, -0.452287014287689080, -0.452242420100139430, -0.452197824781983780, +-0.452153228333333550, -0.452108630754300240, -0.452064032044995350, -0.452019432205530420, -0.451974831236016060, -0.451930229136565440, -0.451885625907289260, -0.451841021548299030, +-0.451796416059706220, -0.451751809441622350, -0.451707201694159010, -0.451662592817427600, -0.451617982811538980, -0.451573371676606160, -0.451528759412739900, -0.451484146020051770, +-0.451439531498653290, -0.451394915848655930, -0.451350299070171320, -0.451305681163310160, -0.451261062128185560, -0.451216441964908340, -0.451171820673590020, -0.451127198254342110, +-0.451082574707276250, -0.451037950032503960, -0.450993324230136770, -0.450948697300285470, -0.450904069243063200, -0.450859440058580810, -0.450814809746949760, -0.450770178308281750, +-0.450725545742688250, -0.450680912050280880, -0.450636277231170500, -0.450591641285470130, -0.450547004213290750, -0.450502366014743800, -0.450457726689940940, -0.450413086238993790, +-0.450368444662013870, -0.450323801959112870, -0.450279158130401590, -0.450234513175993220, -0.450189867095998510, -0.450145219890529190, -0.450100571559696790, -0.450055922103612950, +-0.450011271522389340, -0.449966619816136730, -0.449921966984968390, -0.449877313028995090, -0.449832657948328550, -0.449788001743080370, -0.449743344413362170, -0.449698685959285580, +-0.449654026380962300, -0.449609365678503180, -0.449564703852021410, -0.449520040901627890, -0.449475376827434270, -0.449430711629552230, -0.449386045308093340, -0.449341377863169410, +-0.449296709294892020, -0.449252039603372070, -0.449207368788722810, -0.449162696851055090, -0.449118023790480660, -0.449073349607111150, -0.449028674301058310, -0.448983997872433760, +-0.448939320321349200, -0.448894641647915540, -0.448849961852246130, -0.448805280934451770, -0.448760598894644200, -0.448715915732935120, -0.448671231449436270, -0.448626546044259390, +-0.448581859517515280, -0.448537171869317350, -0.448492483099776460, -0.448447793209004410, -0.448403102197112880, -0.448358410064213560, -0.448313716810418210, -0.448269022435838600, +-0.448224326940585620, -0.448179630324772590, -0.448134932588510500, -0.448090233731911090, -0.448045533755086100, -0.448000832658147270, -0.447956130441206410, -0.447911427104374370, +-0.447866722647764560, -0.447822017071487940, -0.447777310375656320, -0.447732602560381390, -0.447687893625774940, -0.447643183571948770, -0.447598472399014680, -0.447553760107083590, +-0.447509046696268840, -0.447464332166681520, -0.447419616518433370, -0.447374899751636190, -0.447330181866401780, -0.447285462862841880, -0.447240742741067510, -0.447196021501192090, +-0.447151299143326630, -0.447106575667582940, -0.447061851074072760, -0.447017125362908000, -0.446972398534200400, -0.446927670588061820, -0.446882941524603280, -0.446838211343938140, +-0.446793480046177530, -0.446748747631433190, -0.446704014099816970, -0.446659279451440680, -0.446614543686416230, -0.446569806804855470, -0.446525068806869320, -0.446480329692571340, +-0.446435589462072510, -0.446390848115484740, -0.446346105652919820, -0.446301362074489670, -0.446256617380306090, -0.446211871570480920, -0.446167124645125370, -0.446122376604352720, +-0.446077627448274170, -0.446032877177001570, -0.445988125790646730, -0.445943373289321600, -0.445898619673138040, -0.445853864942207130, -0.445809109096642340, -0.445764352136554800, +-0.445719594062056410, -0.445674834873258980, -0.445630074570274480, -0.445585313153214810, -0.445540550622191830, -0.445495786977316680, -0.445451022218702860, -0.445406256346461530, +-0.445361489360704520, -0.445316721261543760, -0.445271952049091260, -0.445227181723458820, -0.445182410284757690, -0.445137637733101280, -0.445092864068600770, -0.445048089291368130, +-0.445003313401515280, -0.444958536399154110, -0.444913758284396610, -0.444868979057354730, -0.444824198718139610, -0.444779417266864760, -0.444734634703641380, -0.444689851028581440, +-0.444645066241796840, -0.444600280343399600, -0.444555493333501640, -0.444510705212214140, -0.444465915979650680, -0.444421125635922450, -0.444376334181141420, -0.444331541615419550, +-0.444286747938868800, -0.444241953151601140, -0.444197157253728660, -0.444152360245362480, -0.444107562126616170, -0.444062762897600990, -0.444017962558428900, -0.443973161109211870, +-0.443928358550061960, -0.443883554881091160, -0.443838750102411470, -0.443793944214134100, -0.443749137216372660, -0.443704329109238400, -0.443659519892843300, -0.443614709567299430, +-0.443569898132718740, -0.443525085589213330, -0.443480271936895210, -0.443435457175875620, -0.443390641306268150, -0.443345824328184090, -0.443301006241735520, -0.443256187047034340, +-0.443211366744192760, -0.443166545333322780, -0.443121722814535600, -0.443076899187944910, -0.443032074453661990, -0.442987248611798890, -0.442942421662467610, -0.442897593605780350, +-0.442852764441849070, -0.442807934170785900, -0.442763102792702030, -0.442718270307711270, -0.442673436715924850, -0.442628602017454800, -0.442583766212413240, -0.442538929300912260, +-0.442494091283063990, -0.442449252158979680, -0.442404411928773060, -0.442359570592555370, -0.442314728150438760, -0.442269884602535360, -0.442225039948957180, -0.442180194189816470, +-0.442135347325225250, -0.442090499355294870, -0.442045650280139040, -0.442000800099869080, -0.441955948814597100, -0.441911096424435270, -0.441866242929495720, -0.441821388329890540, +-0.441776532625731080, -0.441731675817131130, -0.441686817904201940, -0.441641958887055710, -0.441597098765804610, -0.441552237540560780, -0.441507375211436290, -0.441462511778543400, +-0.441417647241993450, -0.441372781601900190, -0.441327914858374910, -0.441283047011529870, -0.441238178061477250, -0.441193308008329180, -0.441148436852197790, -0.441103564593195330, +-0.441058691231433210, -0.441013816767025110, -0.440968941200082450, -0.440924064530717470, -0.440879186759042360, -0.440834307885169200, -0.440789427909210330, -0.440744546831277890, +-0.440699664651483250, -0.440654781369940300, -0.440609896986760340, -0.440565011502055680, -0.440520124915938500, -0.440475237228520940, -0.440430348439915350, -0.440385458550233090, +-0.440340567559587950, -0.440295675468091400, -0.440250782275855680, -0.440205887982992980, -0.440160992589615610, -0.440116096095835680, -0.440071198501765570, -0.440026299807516620, +-0.439981400013202740, -0.439936499118935400, -0.439891597124826780, -0.439846694030989140, -0.439801789837534820, -0.439756884544575950, -0.439711978152224130, -0.439667070660593180, +-0.439622162069794490, -0.439577252379940440, -0.439532341591143240, -0.439487429703515230, -0.439442516717168610, -0.439397602632215670, -0.439352687448767990, -0.439307771166939310, +-0.439262853786841270, -0.439217935308586050, -0.439173015732286010, -0.439128095058053450, -0.439083173286000660, -0.439038250416239120, -0.438993326448882730, -0.438948401384043010, +-0.438903475221832320, -0.438858547962362950, -0.438813619605747220, -0.438768690152097410, -0.438723759601525880, -0.438678827954144200, -0.438633895210066180, -0.438588961369403450, +-0.438544026432268310, -0.438499090398773110, -0.438454153269030200, -0.438409215043151890, -0.438364275721250580, -0.438319335303437750, -0.438274393789827350, -0.438229451180531030, +-0.438184507475661010, -0.438139562675329770, -0.438094616779649610, -0.438049669788732890, -0.438004721702692060, -0.437959772521638540, -0.437914822245686450, -0.437869870874947280, +-0.437824918409533470, -0.437779964849557330, -0.437735010195131280, -0.437690054446367720, -0.437645097603378160, -0.437600139666276760, -0.437555180635174960, -0.437510220510185180, +-0.437465259291419880, -0.437420296978991430, -0.437375333573012230, -0.437330369073594680, -0.437285403480850430, -0.437240436794893490, -0.437195469015835450, -0.437150500143788700, +-0.437105530178865720, -0.437060559121178920, -0.437015586970840750, -0.436970613727962750, -0.436925639392659100, -0.436880663965041270, -0.436835687445221830, -0.436790709833313140, +-0.436745731129427720, -0.436700751333677920, -0.436655770446176260, -0.436610788467034380, -0.436565805396366360, -0.436520821234283760, -0.436475835980899170, -0.436430849636324950, +-0.436385862200673600, -0.436340873674057660, -0.436295884056588650, -0.436250893348380800, -0.436205901549545690, -0.436160908660195800, -0.436115914680443690, -0.436070919610401730, +-0.436025923450182540, -0.435980926199898480, -0.435935927859661340, -0.435890928429585160, -0.435845927909781720, -0.435800926300363380, -0.435755923601442770, -0.435710919813132310, +-0.435665914935544630, -0.435620908968791300, -0.435575901912986510, -0.435530893768241940, -0.435485884534670190, -0.435440874212383700, -0.435395862801495000, -0.435350850302116680, +-0.435305836714361240, -0.435260822038341160, -0.435215806274168280, -0.435170789421956640, -0.435125771481818080, -0.435080752453865020, -0.435035732338210130, -0.434990711134965900, +-0.434945688844244890, -0.434900665466158850, -0.434855641000821970, -0.434810615448345980, -0.434765588808843420, -0.434720561082426900, -0.434675532269209020, -0.434630502369302290, +-0.434585471382819280, -0.434540439309871800, -0.434495406150574030, -0.434450371905037710, -0.434405336573375540, -0.434360300155699990, -0.434315262652123670, -0.434270224062759170, +-0.434225184387718340, -0.434180143627115380, -0.434135101781062020, -0.434090058849670950, -0.434045014833054690, -0.433999969731325930, -0.433954923544597190, -0.433909876272981170, +-0.433864827916589700, -0.433819778475536880, -0.433774727949934660, -0.433729676339895620, -0.433684623645532400, -0.433639569866957620, -0.433594515004283920, -0.433549459057623100, +-0.433504402027089450, -0.433459343912794780, -0.433414284714851770, -0.433369224433373060, -0.433324163068471270, -0.433279100620259090, -0.433234037088849110, -0.433188972474353280, +-0.433143906776885800, -0.433098839996558570, -0.433053772133484280, -0.433008703187775510, -0.432963633159544950, -0.432918562048905330, -0.432873489855968570, -0.432828416580848810, +-0.432783342223658050, -0.432738266784508880, -0.432693190263514100, -0.432648112660786340, -0.432603033976438290, -0.432557954210582630, -0.432512873363332110, -0.432467791434798630, +-0.432422708425096390, -0.432377624334337460, -0.432332539162634420, -0.432287452910100070, -0.432242365576847090, -0.432197277162988170, -0.432152187668635280, -0.432107097093902710, +-0.432062005438902390, -0.432016912703747040, -0.431971818888549410, -0.431926723993422300, -0.431881628018478290, -0.431836530963830290, -0.431791432829590090, -0.431746333615872170, +-0.431701233322788370, -0.431656131950451490, -0.431611029498974340, -0.431565925968469540, -0.431520821359049960, -0.431475715670827540, -0.431430608903916600, -0.431385501058429150, +-0.431340392134478000, -0.431295282132175770, -0.431250171051635430, -0.431205058892969620, -0.431159945656291120, -0.431114831341712020, -0.431069715949346620, -0.431024599479306940, +-0.430979481931705770, -0.430934363306655850, -0.430889243604270060, -0.430844122824661170, -0.430799000967941160, -0.430753878034224440, -0.430708754023623020, -0.430663628936249710, +-0.430618502772217360, -0.430573375531638710, -0.430528247214626620, -0.430483117821293950, -0.430437987351752700, -0.430392855806117250, -0.430347723184499650, -0.430302589487012780, +-0.430257454713769420, -0.430212318864882370, -0.430167181940464600, -0.430122043940628030, -0.430076904865487160, -0.430031764715154030, -0.429986623489741540, -0.429941481189362430, +-0.429896337814129610, -0.429851193364156000, -0.429806047839554340, -0.429760901240437590, -0.429715753566917820, -0.429670604819109400, -0.429625454997124510, -0.429580304101076000, +-0.429535152131076740, -0.429489999087239560, -0.429444844969677390, -0.429399689778502290, -0.429354533513828800, -0.429309376175768980, -0.429264217764435680, -0.429219058279941830, +-0.429173897722400390, -0.429128736091924150, -0.429083573388626130, -0.429038409612618300, -0.428993244764015290, -0.428948078842929180, -0.428902911849472880, -0.428857743783759290, +-0.428812574645901330, -0.428767404436011910, -0.428722233154203210, -0.428677060800589760, -0.428631887375283630, -0.428586712878397720, -0.428541537310045130, -0.428496360670338640, +-0.428451182959391220, -0.428406004177315890, -0.428360824324224730, -0.428315643400232320, -0.428270461405450830, -0.428225278339993130, -0.428180094203972290, -0.428134908997501170, +-0.428089722720692790, -0.428044535373659330, -0.427999346956515310, -0.427954157469372930, -0.427908966912345150, -0.427863775285544920, -0.427818582589085280, -0.427773388823079190, +-0.427728193987639620, -0.427682998082878800, -0.427637801108911250, -0.427592603065849170, -0.427547403953805640, -0.427502203772893610, -0.427457002523225990, -0.427411800204915930, +-0.427366596818075540, -0.427321392362819460, -0.427276186839259940, -0.427230980247509880, -0.427185772587682420, -0.427140563859890520, -0.427095354064247200, -0.427050143200865540, +-0.427004931269858500, -0.426959718271338270, -0.426914504205419600, -0.426869289072214660, -0.426824072871836550, -0.426778855604398210, -0.426733637270012680, -0.426688417868793140, +-0.426643197400851710, -0.426597975866303100, -0.426552753265259540, -0.426507529597834110, -0.426462304864139890, -0.426417079064289830, -0.426371852198397130, -0.426326624266574810, +-0.426281395268935100, -0.426236165205592710, -0.426190934076659870, -0.426145701882249760, -0.426100468622475360, -0.426055234297449790, -0.426009998907286140, -0.425964762452096690, +-0.425919524931996140, -0.425874286347096730, -0.425829046697511650, -0.425783805983353970, -0.425738564204736770, -0.425693321361773120, -0.425648077454576170, -0.425602832483258250, +-0.425557586447934070, -0.425512339348715910, -0.425467091185716910, -0.425421841959050140, -0.425376591668828800, -0.425331340315165950, -0.425286087898173960, -0.425240834417967560, +-0.425195579874659110, -0.425150324268361630, -0.425105067599188420, -0.425059809867252500, -0.425014551072667060, -0.424969291215545280, -0.424924030295999400, -0.424878768314144280, +-0.424833505270092230, -0.424788241163956470, -0.424742975995850040, -0.424697709765886220, -0.424652442474178100, -0.424607174120838040, -0.424561904705980870, -0.424516634229718970, +-0.424471362692165450, -0.424426090093433570, -0.424380816433636400, -0.424335541712887230, -0.424290265931299200, -0.424244989088984730, -0.424199711186058540, -0.424154432222633100, +-0.424109152198821560, -0.424063871114737150, -0.424018588970493050, -0.423973305766202510, -0.423928021501978670, -0.423882736177933980, -0.423837449794183310, -0.423792162350838940, +-0.423746873848014180, -0.423701584285822270, -0.423656293664376400, -0.423611001983789760, -0.423565709244175640, -0.423520415445646450, -0.423475120588316990, -0.423429824672299730, +-0.423384527697707960, -0.423339229664654810, -0.423293930573253600, -0.423248630423617600, -0.423203329215859180, -0.423158026950093250, -0.423112723626432260, -0.423067419244989470, +-0.423022113805878120, -0.422976807309211500, -0.422931499755102860, -0.422886191143665490, -0.422840881475011810, -0.422795570749256720, -0.422750258966512690, -0.422704946126893080, +-0.422659632230511060, -0.422614317277479950, -0.422569001267913080, -0.422523684201922880, -0.422478366079624250, -0.422433046901129760, -0.422387726666552610, -0.422342405376006150, +-0.422297083029603670, -0.422251759627458530, -0.422206435169683920, -0.422161109656392470, -0.422115783087699040, -0.422070455463716130, -0.422025126784557110, -0.421979797050335280, +-0.421934466261163930, -0.421889134417156420, -0.421843801518425320, -0.421798467565085430, -0.421753132557249440, -0.421707796495030600, -0.421662459378542300, -0.421617121207897790, +-0.421571781983210490, -0.421526441704593750, -0.421481100372160130, -0.421435757986024510, -0.421390414546299550, -0.421345070053098510, -0.421299724506534800, -0.421254377906721820, +-0.421209030253772820, -0.421163681547801320, -0.421118331788919780, -0.421072980977243220, -0.421027629112884220, -0.420982276195956130, -0.420936922226572310, -0.420891567204846220, +-0.420846211130891270, -0.420800854004820700, -0.420755495826747260, -0.420710136596785860, -0.420664776315049120, -0.420619414981650400, -0.420574052596703160, -0.420528689160320820, +-0.420483324672616730, -0.420437959133703580, -0.420392592543696260, -0.420347224902707480, -0.420301856210850700, -0.420256486468239210, -0.420211115674986540, -0.420165743831206030, +-0.420120370937011210, -0.420074996992514660, -0.420029621997831390, -0.419984245953074100, -0.419938868858356180, -0.419893490713791060, -0.419848111519492250, -0.419802731275573160, +-0.419757349982146420, -0.419711967639327110, -0.419666584247227910, -0.419621199805962240, -0.419575814315643560, -0.419530427776385330, -0.419485040188301020, -0.419439651551504140, +-0.419394261866107340, -0.419348871132225690, -0.419303479349971810, -0.419258086519459280, -0.419212692640801520, -0.419167297714112040, -0.419121901739504310, -0.419076504717091010, +-0.419031106646987230, -0.418985707529305750, -0.418940307364159940, -0.418894906151663360, -0.418849503891929540, -0.418804100585072000, -0.418758696231204150, -0.418713290830438790, +-0.418667884382890990, -0.418622476888673490, -0.418577068347899760, -0.418531658760683380, -0.418486248127137860, -0.418440836447376730, -0.418395423721513500, -0.418350009949660930, +-0.418304595131934080, -0.418259179268445800, -0.418213762359309570, -0.418168344404638900, -0.418122925404547370, -0.418077505359148560, -0.418032084268555980, -0.417986662132882380, +-0.417941238952242890, -0.417895814726750360, -0.417850389456518260, -0.417804963141660210, -0.417759535782289750, -0.417714107378520440, -0.417668677930465030, -0.417623247438238750, +-0.417577815901954360, -0.417532383321725430, -0.417486949697665530, -0.417441515029888300, -0.417396079318507250, -0.417350642563635970, -0.417305204765387290, -0.417259765923876420, +-0.417214326039216150, -0.417168885111520060, -0.417123443140901770, -0.417078000127474870, -0.417032556071352920, -0.416987110972648790, -0.416941664831477710, -0.416896217647952480, +-0.416850769422186680, -0.416805320154294000, -0.416759869844387950, -0.416714418492582280, -0.416668966098990570, -0.416623512663725600, -0.416578058186902630, -0.416532602668634570, +-0.416487146109034980, -0.416441688508217560, -0.416396229866295870, -0.416350770183383620, -0.416305309459593650, -0.416259847695041210, -0.416214384889839200, -0.416168921044101140, +-0.416123456157940830, -0.416077990231471850, -0.416032523264807940, -0.415987055258062680, -0.415941586211348970, -0.415896116124782110, -0.415850644998474960, -0.415805172832541260, +-0.415759699627094530, -0.415714225382248610, -0.415668750098117100, -0.415623273774813730, -0.415577796412451410, -0.415532318011145320, -0.415486838571008490, -0.415441358092154540, +-0.415395876574697230, -0.415350394018750180, -0.415304910424427190, -0.415259425791841890, -0.415213940121107240, -0.415168453412338550, -0.415122965665648710, -0.415077476881151490, +-0.415031987058960550, -0.414986496199189590, -0.414941004301952470, -0.414895511367362020, -0.414850017395533570, -0.414804522386580110, -0.414759026340615290, -0.414713529257752960, +-0.414668031138106800, -0.414622531981790550, -0.414577031788917970, -0.414531530559602010, -0.414486028293957980, -0.414440524992098940, -0.414395020654138580, -0.414349515280190650, +-0.414304008870368940, -0.414258501424787210, -0.414212992943558400, -0.414167483426797990, -0.414121972874618770, -0.414076461287134660, -0.414030948664459440, -0.413985435006706810, +-0.413939920313990570, -0.413894404586424570, -0.413848887824121710, -0.413803370027197470, -0.413757851195764800, -0.413712331329937510, -0.413666810429829390, -0.413621288495554240, +-0.413575765527225860, -0.413530241524957260, -0.413484716488863870, -0.413439190419058630, -0.413393663315655520, -0.413348135178768170, -0.413302606008510540, -0.413257075804996380, +-0.413211544568339470, -0.413166012298652960, -0.413120478996052200, -0.413074944660650260, -0.413029409292560930, -0.412983872891898140, -0.412938335458775620, -0.412892796993307280, +-0.412847257495606910, -0.412801716965787600, -0.412756175403964810, -0.412710632810251610, -0.412665089184761800, -0.412619544527609290, -0.412573998838907880, -0.412528452118771480, +-0.412482904367314000, -0.412437355584648390, -0.412391805770890240, -0.412346254926152570, -0.412300703050549280, -0.412255150144194170, -0.412209596207201270, -0.412164041239684310, +-0.412118485241756480, -0.412072928213533200, -0.412027370155127640, -0.411981811066653660, -0.411936250948225110, -0.411890689799955970, -0.411845127621960070, -0.411799564414351390, +-0.411754000177242950, -0.411708434910750380, -0.411662868614986690, -0.411617301290065800, -0.411571732936101660, -0.411526163553208260, -0.411480593141499370, -0.411435021701088250, +-0.411389449232090310, -0.411343875734618840, -0.411298301208787630, -0.411252725654710660, -0.411207149072501890, -0.411161571462275220, -0.411115992824144630, -0.411070413158223290, +-0.411024832464626680, -0.410979250743468030, -0.410933667994861250, -0.410888084218920260, -0.410842499415759070, -0.410796913585491640, -0.410751326728231110, -0.410705738844093120, +-0.410660149933190720, -0.410614559995638010, -0.410568969031548820, -0.410523377041037250, -0.410477784024217250, -0.410432189981202790, -0.410386594912107050, -0.410340998817045610, +-0.410295401696131660, -0.410249803549479260, -0.410204204377202290, -0.410158604179414850, -0.410113002956230880, -0.410067400707764430, -0.410021797434128640, -0.409976193135439150, +-0.409930587811809190, -0.409884981463352780, -0.409839374090183890, -0.409793765692416600, -0.409748156270164920, -0.409702545823542760, -0.409656934352663480, -0.409611321857642710, +-0.409565708338593570, -0.409520093795630200, -0.409474478228866570, -0.409428861638416740, -0.409383244024394800, -0.409337625386913870, -0.409292005726089760, -0.409246385042035590, +-0.409200763334865490, -0.409155140604693430, -0.409109516851633550, -0.409063892075799910, -0.409018266277306470, -0.408972639456266610, -0.408927011612795930, -0.408881382747007750, +-0.408835752859016130, -0.408790121948935100, -0.408744490016878740, -0.408698857062961160, -0.408653223087295680, -0.408607588089997920, -0.408561952071181180, -0.408516315030959590, +-0.408470676969447170, -0.408425037886758100, -0.408379397783006410, -0.408333756658306240, -0.408288114512770810, -0.408242471346515980, -0.408196827159654940, -0.408151181952301820, +-0.408105535724570760, -0.408059888476575870, -0.408014240208431240, -0.407968590920250230, -0.407922940612148510, -0.407877289284239500, -0.407831636936637210, -0.407785983569455830, +-0.407740329182809560, -0.407694673776812400, -0.407649017351578550, -0.407603359907221410, -0.407557701443856610, -0.407512041961597570, -0.407466381460558470, -0.407420719940853380, +-0.407375057402596500, -0.407329393845902000, -0.407283729270883190, -0.407238063677655860, -0.407192397066333370, -0.407146729437029840, -0.407101060789859530, -0.407055391124936610, +-0.407009720442375160, -0.406964048742289420, -0.406918376024793580, -0.406872702290000940, -0.406827027538027410, -0.406781351768986280, -0.406735674982991790, -0.406689997180158080, +-0.406644318360599390, -0.406598638524429900, -0.406552957671763030, -0.406507275802714560, -0.406461592917397920, -0.406415909015927280, -0.406370224098416890, -0.406324538164980880, +-0.406278851215733590, -0.406233163250789120, -0.406187474270260970, -0.406141784274264950, -0.406096093262914460, -0.406050401236323690, -0.406004708194606990, -0.405959014137878490, +-0.405913319066252440, -0.405867622979842300, -0.405821925878763870, -0.405776227763130660, -0.405730528633056920, -0.405684828488656830, -0.405639127330044650, -0.405593425157334650, +-0.405547721970641100, -0.405502017770077440, -0.405456312555759530, -0.405410606327800850, -0.405364899086315680, -0.405319190831418210, -0.405273481563222790, -0.405227771281843670, +-0.405182059987394320, -0.405136347679990630, -0.405090634359746020, -0.405044920026774890, -0.404999204681191440, -0.404953488323109960, -0.404907770952644740, -0.404862052569910150, +-0.404816333175019580, -0.404770612768089010, -0.404724891349231900, -0.404679168918562540, -0.404633445476195290, -0.404587721022244440, -0.404541995556824240, -0.404496269080048270, +-0.404450541592032420, -0.404404813092890230, -0.404359083582735980, -0.404313353061684090, -0.404267621529848740, -0.404221888987344400, -0.404176155434285310, -0.404130420870785820, +-0.404084685296959460, -0.404038948712922230, -0.403993211118787610, -0.403947472514669950, -0.403901732900683650, -0.403855992276942970, -0.403810250643562350, -0.403764508000655280, +-0.403718764348337760, -0.403673019686723310, -0.403627274015926300, -0.403581527336061120, -0.403535779647242130, -0.403490030949583690, -0.403444281243200140, -0.403398530528205120, +-0.403352778804714540, -0.403307026072842080, -0.403261272332701980, -0.403215517584408770, -0.403169761828076730, -0.403124005063820290, -0.403078247291753010, -0.403032488511990920, +-0.402986728724647640, -0.402940967929837520, -0.402895206127674990, -0.402849443318274440, -0.402803679501750280, -0.402757914678216920, -0.402712148847787940, -0.402666382010579470, +-0.402620614166704970, -0.402574845316278960, -0.402529075459415850, -0.402483304596230050, -0.402437532726835970, -0.402391759851347290, -0.402345985969879970, -0.402300211082547710, +-0.402254435189464910, -0.402208658290746040, -0.402162880386505490, -0.402117101476857750, -0.402071321561917270, -0.402025540641797690, -0.401979758716615070, -0.401933975786483040, +-0.401888191851516090, -0.401842406911828600, -0.401796620967535160, -0.401750834018750110, -0.401705046065587210, -0.401659257108162530, -0.401613467146589630, -0.401567676180983100, +-0.401521884211457400, -0.401476091238126940, -0.401430297261106290, -0.401384502280509920, -0.401338706296452240, -0.401292909309047040, -0.401247111318410340, -0.401201312324655830, +-0.401155512327898090, -0.401109711328251570, -0.401063909325830750, -0.401018106320750190, -0.400972302313123530, -0.400926497303066900, -0.400880691290694040, -0.400834884276119460, +-0.400789076259457700, -0.400743267240823210, -0.400697457220330570, -0.400651646198094290, -0.400605834174228070, -0.400560021148848090, -0.400514207122068030, -0.400468392094002480, +-0.400422576064765940, -0.400376759034472950, -0.400330941003238070, -0.400285121971175050, -0.400239301938400020, -0.400193480905026710, -0.400147658871169710, -0.400101835836943590, +-0.400056011802462860, -0.400010186767842110, -0.399964360733195860, -0.399918533698637950, -0.399872705664284460, -0.399826876630249240, -0.399781046596646820, -0.399735215563591820, +-0.399689383531198760, -0.399643550499582220, -0.399597716468856000, -0.399551881439136280, -0.399506045410536910, -0.399460208383172420, -0.399414370357157380, -0.399368531332606410, +-0.399322691309634100, -0.399276850288355130, -0.399231008268883140, -0.399185165251334520, -0.399139321235822910, -0.399093476222463050, -0.399047630211369460, -0.399001783202656830, +-0.398955935196439740, -0.398910086192831970, -0.398864236191949830, -0.398818385193907110, -0.398772533198818390, -0.398726680206798360, -0.398680826217961640, -0.398634971232422810, +-0.398589115250296610, -0.398543258271696730, -0.398497400296739580, -0.398451541325538890, -0.398405681358209420, -0.398359820394865670, -0.398313958435622400, -0.398268095480594220, +-0.398222231529895830, -0.398176366583641030, -0.398130500641946110, -0.398084633704924970, -0.398038765772692260, -0.397992896845362600, -0.397947026923050730, -0.397901156005871230, +-0.397855284093938890, -0.397809411187367510, -0.397763537286273450, -0.397717662390770500, -0.397671786500973400, -0.397625909616996840, -0.397580031738955510, -0.397534152866964140, +-0.397488273001136540, -0.397442392141589050, -0.397396510288435590, -0.397350627441790890, -0.397304743601769590, -0.397258858768486430, -0.397212972942056150, -0.397167086122593380, +-0.397121198310212140, -0.397075309505028730, -0.397029419707156990, -0.396983528916711740, -0.396937637133807640, -0.396891744358559450, -0.396845850591081910, -0.396799955831488920, +-0.396754060079896890, -0.396708163336419670, -0.396662265601172070, -0.396616366874268770, -0.396570467155824560, -0.396524566445954240, -0.396478664744772450, -0.396432762052393190, +-0.396386858368932840, -0.396340953694505340, -0.396295048029225490, -0.396249141373207990, -0.396203233726567630, -0.396157325089419200, -0.396111415461876670, -0.396065504844056340, +-0.396019593236072330, -0.395973680638039280, -0.395927767050072040, -0.395881852472285410, -0.395835936904794130, -0.395790020347713050, -0.395744102801156020, -0.395698184265239620, +-0.395652264740077700, -0.395606344225785170, -0.395560422722476770, -0.395514500230267300, -0.395468576749271610, -0.395422652279604440, -0.395376726821379810, -0.395330800374714240, +-0.395284872939721590, -0.395238944516516810, -0.395193015105214650, -0.395147084705929960, -0.395101153318777600, -0.395055220943872300, -0.395009287581328140, -0.394963353231261580, +-0.394917417893786650, -0.394871481569018190, -0.394825544257071000, -0.394779605958059940, -0.394733666672099910, -0.394687726399304880, -0.394641785139791310, -0.394595842893673330, +-0.394549899661065680, -0.394503955442083330, -0.394458010236841130, -0.394412064045453810, -0.394366116868036410, -0.394320168704702880, -0.394274219555569740, -0.394228269420751010, +-0.394182318300361660, -0.394136366194516470, -0.394090413103330430, -0.394044459026918310, -0.393998503965394210, -0.393952547918874680, -0.393906590887473820, -0.393860632871306460, +-0.393814673870487520, -0.393768713885131850, -0.393722752915354470, -0.393676790961270170, -0.393630828022993040, -0.393584864100639700, -0.393538899194324220, -0.393492933304161460, +-0.393446966430266390, -0.393400998572753850, -0.393355029731738860, -0.393309059907335500, -0.393263089099660230, -0.393217117308827300, -0.393171144534951560, -0.393125170778147960, +-0.393079196038531480, -0.393033220316216960, -0.392987243611319370, -0.392941265923952900, -0.392895287254234060, -0.392849307602276990, -0.392803326968196640, -0.392757345352107990, +-0.392711362754125990, -0.392665379174365610, -0.392619394612941710, -0.392573409069968570, -0.392527422545562670, -0.392481435039838290, -0.392435446552910240, -0.392389457084893640, +-0.392343466635903360, -0.392297475206054400, -0.392251482795461790, -0.392205489404239660, -0.392159495032504580, -0.392113499680370790, -0.392067503347953260, -0.392021506035366950, +-0.391975507742726880, -0.391929508470148070, -0.391883508217744590, -0.391837506985633240, -0.391791504773928100, -0.391745501582744180, -0.391699497412196560, -0.391653492262400150, +-0.391607486133470020, -0.391561479025521130, -0.391515470938667790, -0.391469461873026560, -0.391423451828711690, -0.391377440805838190, -0.391331428804521100, -0.391285415824875420, +-0.391239401867016170, -0.391193386931057650, -0.391147371017116440, -0.391101354125306830, -0.391055336255743850, -0.391009317408542500, -0.390963297583817810, -0.390917276781684970, +-0.390871255002258890, -0.390825232245653850, -0.390779208511986550, -0.390733183801371290, -0.390687158113922960, -0.390641131449756820, -0.390595103808987820, -0.390549075191731100, +-0.390503045598100840, -0.390457015028213780, -0.390410983482184170, -0.390364950960127130, -0.390318917462157690, -0.390272882988390970, -0.390226847538942050, -0.390180811113926000, +-0.390134773713457120, -0.390088735337652090, -0.390042695986625220, -0.389996655660491690, -0.389950614359366450, -0.389904572083364650, -0.389858528832601470, -0.389812484607191980, +-0.389766439407250420, -0.389720393232893590, -0.389674346084235790, -0.389628297961392140, -0.389582248864477730, -0.389536198793607680, -0.389490147748897120, -0.389444095730461240, +-0.389398042738414270, -0.389351988772873030, -0.389305933833951790, -0.389259877921765750, -0.389213821036429990, -0.389167763178059680, -0.389121704346769960, -0.389075644542675180, +-0.389029583765892140, -0.388983522016535080, -0.388937459294719230, -0.388891395600559740, -0.388845330934171730, -0.388799265295670440, -0.388753198685170940, -0.388707131102787650, +-0.388661062548637360, -0.388614993022834420, -0.388568922525493960, -0.388522851056731230, -0.388476778616661360, -0.388430705205399570, -0.388384630823060180, -0.388338555469760040, +-0.388292479145613490, -0.388246401850735720, -0.388200323585241980, -0.388154244349247450, -0.388108164142867250, -0.388062082966216690, -0.388016000819410070, -0.387969917702564280, +-0.387923833615793750, -0.387877748559213590, -0.387831662532939050, -0.387785575537085310, -0.387739487571767680, -0.387693398637100560, -0.387647308733200690, -0.387601217860182590, +-0.387555126018161440, -0.387509033207252440, -0.387462939427570870, -0.387416844679231990, -0.387370748962350960, -0.387324652277042270, -0.387278554623422750, -0.387232456001606830, +-0.387186356411709790, -0.387140255853846870, -0.387094154328133270, -0.387048051834684330, -0.387001948373615230, -0.386955843945040460, -0.386909738549076900, -0.386863632185838970, +-0.386817524855441960, -0.386771416558001120, -0.386725307293631800, -0.386679197062449190, -0.386633085864568570, -0.386586973700104420, -0.386540860569173640, -0.386494746471890750, +-0.386448631408370990, -0.386402515378729610, -0.386356398383082000, -0.386310280421543360, -0.386264161494228150, -0.386218041601253450, -0.386171920742733600, -0.386125798918783960, +-0.386079676129519770, -0.386033552375056430, -0.385987427655509250, -0.385941301970993470, -0.385895175321623600, -0.385849047707516600, -0.385802919128787000, -0.385756789585550100, +-0.385710659077921240, -0.385664527606015720, -0.385618395169948890, -0.385572261769835280, -0.385526127405791790, -0.385479992077932990, -0.385433855786374180, -0.385387718531230770, +-0.385341580312618060, -0.385295441130651390, -0.385249300985446130, -0.385203159877116840, -0.385157017805780380, -0.385110874771551430, -0.385064730774545280, -0.385018585814877300, +-0.384972439892662890, -0.384926293008017340, -0.384880145161055230, -0.384833996351893640, -0.384787846580647020, -0.384741695847430730, -0.384695544152360290, -0.384649391495550940, +-0.384603237877118140, -0.384557083297177190, -0.384510927755842780, -0.384464771253231810, -0.384418613789458960, -0.384372455364639540, -0.384326295978889010, -0.384280135632322720, +-0.384233974325056130, -0.384187812057204540, -0.384141648828882630, -0.384095484640207430, -0.384049319491293510, -0.384003153382256320, -0.383956986313211230, -0.383910818284273650, +-0.383864649295559020, -0.383818479347182830, -0.383772308439259580, -0.383726136571906350, -0.383679963745237830, -0.383633789959369360, -0.383587615214416420, -0.383541439510494460, +-0.383495262847718900, -0.383449085226204360, -0.383402906646067910, -0.383356727107424240, -0.383310546610388710, -0.383264365155076840, -0.383218182741604020, -0.383171999370085780, +-0.383125815040637530, -0.383079629753373900, -0.383033443508412060, -0.382987256305866550, -0.382941068145852940, -0.382894879028486680, -0.382848688953883190, -0.382802497922157980, +-0.382756305933425740, -0.382710112987803500, -0.382663919085406030, -0.382617724226348770, -0.382571528410747150, -0.382525331638716710, -0.382479133910372970, -0.382432935225831380, +-0.382386735585206640, -0.382340534988615870, -0.382294333436173750, -0.382248130927995810, -0.382201927464197570, -0.382155723044894480, -0.382109517670202130, -0.382063311340235130, +-0.382017104055110630, -0.381970895814943420, -0.381924686619848960, -0.381878476469942830, -0.381832265365340430, -0.381786053306157390, -0.381739840292509240, -0.381693626324510650, +-0.381647411402278810, -0.381601195525928470, -0.381554978695575140, -0.381508760911334340, -0.381462542173321650, -0.381416322481652580, -0.381370101836441930, -0.381323880237806830, +-0.381277657685862030, -0.381231434180723080, -0.381185209722505520, -0.381138984311324980, -0.381092757947296970, -0.381046530630537010, -0.381000302361160780, -0.380954073139282980, +-0.380907842965020780, -0.380861611838488990, -0.380815379759803170, -0.380769146729078910, -0.380722912746431770, -0.380676677811977340, -0.380630441925830400, -0.380584205088108200, +-0.380537967298925470, -0.380491728558397860, -0.380445488866640870, -0.380399248223770190, -0.380353006629901350, -0.380306764085150020, -0.380260520589631000, -0.380214276143461430, +-0.380168030746756200, -0.380121784399630900, -0.380075537102201160, -0.380029288854582540, -0.379983039656890730, -0.379936789509240480, -0.379890538411749080, -0.379844286364531320, +-0.379798033367702850, -0.379751779421379330, -0.379705524525676300, -0.379659268680709480, -0.379613011886594520, -0.379566754143446210, -0.379520495451381780, -0.379474235810516200, +-0.379427975220964940, -0.379381713682843790, -0.379335451196268380, -0.379289187761354290, -0.379242923378216410, -0.379196658046972060, -0.379150391767736070, -0.379104124540624140, +-0.379057856365751840, -0.379011587243234920, -0.378965317173189040, -0.378919046155729860, -0.378872774190972210, -0.378826501279033500, -0.378780227420028480, -0.378733952614072940, +-0.378687676861282520, -0.378641400161772890, -0.378595122515659740, -0.378548843923057990, -0.378502564384084970, -0.378456283898855490, -0.378410002467485350, -0.378363720090090170, +-0.378317436766785700, -0.378271152497687610, -0.378224867282911660, -0.378178581122573580, -0.378132294016788160, -0.378086005965672880, -0.378039716969342580, -0.377993427027912940, +-0.377947136141499770, -0.377900844310218750, -0.377854551534185680, -0.377808257813515350, -0.377761963148325160, -0.377715667538730150, -0.377669370984845930, -0.377623073486788250, +-0.377576775044672910, -0.377530475658615640, -0.377484175328732190, -0.377437874055137460, -0.377391571837948860, -0.377345268677281350, -0.377298964573250680, -0.377252659525972590, +-0.377206353535562870, -0.377160046602137200, -0.377113738725810670, -0.377067429906700560, -0.377021120144921900, -0.376974809440590420, -0.376928497793821930, -0.376882185204732210, +-0.376835871673437020, -0.376789557200052140, -0.376743241784692540, -0.376696925427475680, -0.376650608128516470, -0.376604289887930770, -0.376557970705834360, -0.376511650582342980, +-0.376465329517572500, -0.376419007511637870, -0.376372684564656560, -0.376326360676743520, -0.376280035848014560, -0.376233710078585580, -0.376187383368572270, -0.376141055718090480, +-0.376094727127256110, -0.376048397596184080, -0.376002067124991850, -0.375955735713794480, -0.375909403362707730, -0.375863070071847550, -0.375816735841329630, -0.375770400671269880, +-0.375724064561783310, -0.375677727512987390, -0.375631389524997190, -0.375585050597928520, -0.375538710731897150, -0.375492369927019070, -0.375446028183410050, -0.375399685501185960, +-0.375353341880462650, -0.375306997321355200, -0.375260651823981000, -0.375214305388455240, -0.375167958014893670, -0.375121609703412240, -0.375075260454126760, -0.375028910267153180, +-0.374982559142606480, -0.374936207080604160, -0.374889854081261350, -0.374843500144693920, -0.374797145271017710, -0.374750789460348680, -0.374704432712802630, -0.374658075028495520, +-0.374611716407542430, -0.374565356850060820, -0.374518996356165810, -0.374472634925973380, -0.374426272559599320, -0.374379909257159580, -0.374333545018770030, -0.374287179844545850, +-0.374240813734604550, -0.374194446689061160, -0.374148078708031680, -0.374101709791632040, -0.374055339939978080, -0.374008969153185770, -0.373962597431371060, -0.373916224774649030, +-0.373869851183137260, -0.373823476656950870, -0.373777101196205770, -0.373730724801017930, -0.373684347471503250, -0.373637969207777750, -0.373591590009956450, -0.373545209878157040, +-0.373498828812494580, -0.373452446813085090, -0.373406063880044440, -0.373359680013488630, -0.373313295213533620, -0.373266909480295390, -0.373220522813889070, -0.373174135214432270, +-0.373127746682040130, -0.373081357216828610, -0.373034966818913680, -0.372988575488411360, -0.372942183225437600, -0.372895790030107530, -0.372849395902538850, -0.372803000842846680, +-0.372756604851146980, -0.372710207927555770, -0.372663810072189020, -0.372617411285162790, -0.372571011566593000, -0.372524610916595720, -0.372478209335286080, -0.372431806822781710, +-0.372385403379197840, -0.372338999004650450, -0.372292593699255600, -0.372246187463129210, -0.372199780296387390, -0.372153372199145290, -0.372106963171520590, -0.372060553213628460, +-0.372014142325584940, -0.371967730507506090, -0.371921317759507930, -0.371874904081706430, -0.371828489474217700, -0.371782073937156900, -0.371735657470641740, -0.371689240074787490, +-0.371642821749710080, -0.371596402495525670, -0.371549982312350200, -0.371503561200299810, -0.371457139159489690, -0.371410716190037520, -0.371364292292058580, -0.371317867465668920, +-0.371271441710984530, -0.371225015028121610, -0.371178587417196120, -0.371132158878324180, -0.371085729411620990, -0.371039299017204340, -0.370992867695189410, -0.370946435445692280, +-0.370900002268829130, -0.370853568164715930, -0.370807133133468860, -0.370760697175203100, -0.370714260290036400, -0.370667822478084050, -0.370621383739462180, -0.370574944074286820, +-0.370528503482674130, -0.370482061964740150, -0.370435619520601060, -0.370389176150372030, -0.370342731854170940, -0.370296286632113000, -0.370249840484314360, -0.370203393410891090, +-0.370156945411959370, -0.370110496487635280, -0.370064046638034110, -0.370017595863273650, -0.369971144163469210, -0.369924691538736860, -0.369878237989192840, -0.369831783514953220, +-0.369785328116134130, -0.369738871792851700, -0.369692414545221280, -0.369645956373360670, -0.369599497277385170, -0.369553037257410900, -0.369506576313554050, -0.369460114445930740, +-0.369413651654657170, -0.369367187939849460, -0.369320723301622970, -0.369274257740095480, -0.369227791255382350, -0.369181323847599720, -0.369134855516863810, -0.369088386263290770, +-0.369041916086996770, -0.368995444988097940, -0.368948972966709700, -0.368902500022949830, -0.368856026156933750, -0.368809551368777580, -0.368763075658597510, -0.368716599026509770, +-0.368670121472630560, -0.368623642997075170, -0.368577163599961510, -0.368530683281404980, -0.368484202041521710, -0.368437719880427950, -0.368391236798239870, -0.368344752795073730, +-0.368298267871045690, -0.368251782026271120, -0.368205295260867980, -0.368158807574951560, -0.368112318968638160, -0.368065829442043910, -0.368019338995285160, -0.367972847628477980, +-0.367926355341737900, -0.367879862135182760, -0.367833368008927960, -0.367786872963089760, -0.367740376997784340, -0.367693880113127980, -0.367647382309236940, -0.367600883586227440, +-0.367554383944214910, -0.367507883383317250, -0.367461381903649850, -0.367414879505329030, -0.367368376188471010, -0.367321871953192050, -0.367275366799608370, -0.367228860727835500, +-0.367182353737991240, -0.367135845830191150, -0.367089337004551430, -0.367042827261188360, -0.366996316600218250, -0.366949805021757340, -0.366903292525921910, -0.366856779112827380, +-0.366810264782591770, -0.366763749535330530, -0.366717233371159860, -0.366670716290196150, -0.366624198292555600, -0.366577679378354620, -0.366531159547709370, -0.366484638800735450, +-0.366438117137550760, -0.366391594558270750, -0.366345071063011730, -0.366298546651890100, -0.366252021325022050, -0.366205495082523980, -0.366158967924512140, -0.366112439851102090, +-0.366065910862411750, -0.366019380958556630, -0.365972850139653030, -0.365926318405817350, -0.365879785757165840, -0.365833252193814910, -0.365786717715880010, -0.365740182323479100, +-0.365693646016727770, -0.365647108795742300, -0.365600570660639110, -0.365554031611534440, -0.365507491648544740, -0.365460950771786250, -0.365414408981374620, -0.365367866277427730, +-0.365321322660061230, -0.365274778129391410, -0.365228232685534620, -0.365181686328607260, -0.365135139058725690, -0.365088590876005430, -0.365042041780564540, -0.364995491772518550, +-0.364948940851983820, -0.364902389019076730, -0.364855836273913710, -0.364809282616611050, -0.364762728047285210, -0.364716172566051710, -0.364669616173028620, -0.364623058868331460, +-0.364576500652076640, -0.364529941524380620, -0.364483381485359750, -0.364436820535130380, -0.364390258673808140, -0.364343695901511110, -0.364297132218354860, -0.364250567624455730, +-0.364204002119930200, -0.364157435704894670, -0.364110868379465550, -0.364064300143759230, -0.364017730997891360, -0.363971160941979950, -0.363924589976140690, -0.363878018100489920, +-0.363831445315144160, -0.363784871620219720, -0.363738297015833160, -0.363691721502100830, -0.363645145079138370, -0.363598567747063840, -0.363551989505992930, -0.363505410356042060, +-0.363458830297327620, -0.363412249329966130, -0.363365667454074000, -0.363319084669767760, -0.363272500977162900, -0.363225916376377690, -0.363179330867527630, -0.363132744450729240, +-0.363086157126099040, -0.363039568893753440, -0.362992979753808900, -0.362946389706381050, -0.362899798751588120, -0.362853206889545640, -0.362806614120370190, -0.362760020444178160, +-0.362713425861086070, -0.362666830371210450, -0.362620233974667750, -0.362573636671573660, -0.362527038462046260, -0.362480439346201280, -0.362433839324155180, -0.362387238396024550, +-0.362340636561925780, -0.362294033821975390, -0.362247430176289130, -0.362200825624985120, -0.362154220168179050, -0.362107613805987380, -0.362061006538526740, -0.362014398365913540, +-0.361967789288264400, -0.361921179305695730, -0.361874568418323270, -0.361827956626265270, -0.361781343929637340, -0.361734730328556080, -0.361688115823137980, -0.361641500413499630, +-0.361594884099757490, -0.361548266882027290, -0.361501648760427290, -0.361455029735073150, -0.361408409806081410, -0.361361788973568690, -0.361315167237651500, -0.361268544598446370, +-0.361221921056069870, -0.361175296610637740, -0.361128671262268220, -0.361082045011076990, -0.361035417857180680, -0.360988789800695820, -0.360942160841738970, -0.360895530980426760, +-0.360848900216875660, -0.360802268551201510, -0.360755635983522560, -0.360709002513954440, -0.360662368142613880, -0.360615732869617340, -0.360569096695081530, -0.360522459619122940, +-0.360475821641858210, -0.360429182763403130, -0.360382542983875900, -0.360335902303392300, -0.360289260722068900, -0.360242618240022410, -0.360195974857369370, -0.360149330574226380, +-0.360102685390709220, -0.360056039306936190, -0.360009392323023090, -0.359962744439086490, -0.359916095655243020, -0.359869445971609300, -0.359822795388301970, -0.359776143905437720, +-0.359729491523132220, -0.359682838241503820, -0.359636184060668330, -0.359589528980742370, -0.359542873001842570, -0.359496216124085610, -0.359449558347588130, -0.359402899672465910, +-0.359356240098837270, -0.359309579626818030, -0.359262918256524840, -0.359216255988074380, -0.359169592821583230, -0.359122928757168110, -0.359076263794945730, -0.359029597935031810, +-0.358982931177544710, -0.358936263522600270, -0.358889594970315250, -0.358842925520806160, -0.358796255174189780, -0.358749583930582820, -0.358702911790101000, -0.358656238752862730, +-0.358609564818983930, -0.358562889988581160, -0.358516214261771160, -0.358469537638670680, -0.358422860119396280, -0.358376181704064820, -0.358329502392791990, -0.358282822185696290, +-0.358236141082893530, -0.358189459084500390, -0.358142776190633620, -0.358096092401409880, -0.358049407716945930, -0.358002722137358510, -0.357956035662763410, -0.357909348293279030, +-0.357862660029021280, -0.357815970870106910, -0.357769280816652600, -0.357722589868775090, -0.357675898026591110, -0.357629205290217410, -0.357582511659769840, -0.357535817135366810, +-0.357489121717124270, -0.357442425405158910, -0.357395728199587480, -0.357349030100526710, -0.357302331108093400, -0.357255631222403390, -0.357208930443575160, -0.357162228771724600, +-0.357115526206968510, -0.357068822749423530, -0.357022118399206560, -0.356975413156434270, -0.356928707021223420, -0.356881999993690020, -0.356835292073952430, -0.356788583262126590, +-0.356741873558329310, -0.356695162962677340, -0.356648451475287450, -0.356601739096276460, -0.356555025825760260, -0.356508311663857380, -0.356461596610683660, -0.356414880666355960, +-0.356368163830991120, -0.356321446104705790, -0.356274727487616900, -0.356228007979841170, -0.356181287581494590, -0.356134566292695630, -0.356087844113560260, -0.356041121044205270, +-0.355994397084747450, -0.355947672235303660, -0.355900946495990690, -0.355854219866924500, -0.355807492348223620, -0.355760763940004000, -0.355714034642382490, -0.355667304455475900, +-0.355620573379401010, -0.355573841414274730, -0.355527108560213800, -0.355480374817334300, -0.355433640185754680, -0.355386904665590970, -0.355340168256959970, -0.355293430959978560, +-0.355246692774763620, -0.355199953701431930, -0.355153213740100340, -0.355106472890884870, -0.355059731153904050, -0.355012988529273930, -0.354966245017111330, -0.354919500617533080, +-0.354872755330656100, -0.354826009156597230, -0.354779262095473390, -0.354732514147400480, -0.354685765312497180, -0.354639015590879460, -0.354592264982664160, -0.354545513487968260, +-0.354498761106908530, -0.354452007839601900, -0.354405253686164430, -0.354358498646714650, -0.354311742721368620, -0.354264985910243250, -0.354218228213455390, -0.354171469631122000, +-0.354124710163359890, -0.354077949810286060, -0.354031188572016490, -0.353984426448669790, -0.353937663440361980, -0.353890899547210090, -0.353844134769330910, -0.353797369106841340, +-0.353750602559858410, -0.353703835128498120, -0.353657066812879120, -0.353610297613117410, -0.353563527529329960, -0.353516756561633730, -0.353469984710145570, -0.353423211974982440, +-0.353376438356261310, -0.353329663854098200, -0.353282888468611830, -0.353236112199918180, -0.353189335048134270, -0.353142557013377050, -0.353095778095763420, -0.353048998295410370, +-0.353002217612433940, -0.352955436046952840, -0.352908653599083130, -0.352861870268941780, -0.352815086056645740, -0.352768300962312040, -0.352721514986057530, -0.352674728127999270, +-0.352627940388253350, -0.352581151766938440, -0.352534362264170560, -0.352487571880066850, -0.352440780614744210, -0.352393988468319600, -0.352347195440910030, -0.352300401532631650, +-0.352253606743603060, -0.352206811073940470, -0.352160014523760830, -0.352113217093181220, -0.352066418782318540, -0.352019619591289750, -0.351972819520211980, -0.351926018569202140, +-0.351879216738376410, -0.351832414027853540, -0.351785610437749530, -0.351738805968181580, -0.351692000619266590, -0.351645194391121570, -0.351598387283863560, -0.351551579297608770, +-0.351504770432475850, -0.351457960688581040, -0.351411150066041340, -0.351364338564973730, -0.351317526185495280, -0.351270712927722990, -0.351223898791773960, -0.351177083777764300, +-0.351130267885812810, -0.351083451116035620, -0.351036633468549850, -0.350989814943472420, -0.350942995540920510, -0.350896175261011130, -0.350849354103860420, -0.350802532069587170, +-0.350755709158307620, -0.350708885370138780, -0.350662060705197730, -0.350615235163601550, -0.350568408745467240, -0.350521581450911950, -0.350474753280051840, -0.350427924233005670, +-0.350381094309889730, -0.350334263510821030, -0.350287431835916710, -0.350240599285293770, -0.350193765859069310, -0.350146931557359650, -0.350100096380283440, -0.350053260327957030, +-0.350006423400497480, -0.349959585598021870, -0.349912746920647280, -0.349865907368490820, -0.349819066941669590, -0.349772225640299860, -0.349725383464500440, -0.349678540414387510, +-0.349631696490078250, -0.349584851691689740, -0.349538006019339100, -0.349491159473143460, -0.349444312053219070, -0.349397463759684780, -0.349350614592656760, -0.349303764552252260, +-0.349256913638588300, -0.349210061851782110, -0.349163209191950710, -0.349116355659211340, -0.349069501253681020, -0.349022645975476160, -0.348975789824715550, -0.348928932801515380, +-0.348882074905992930, -0.348835216138265290, -0.348788356498449640, -0.348741495986663040, -0.348694634603021910, -0.348647772347644990, -0.348600909220648680, -0.348554045222150060, +-0.348507180352266350, -0.348460314611114650, -0.348413447998812190, -0.348366580515476140, -0.348319712161222760, -0.348272842936171000, -0.348225972840437050, -0.348179101874138200, +-0.348132230037391630, -0.348085357330314430, -0.348038483753023880, -0.347991609305636270, -0.347944733988270470, -0.347897857801042820, -0.347850980744070560, -0.347804102817470820, +-0.347757224021360830, -0.347710344355857790, -0.347663463821078880, -0.347616582417140500, -0.347569700144161440, -0.347522817002258180, -0.347475932991547890, -0.347429048112147700, +-0.347382162364174960, -0.347335275747746750, -0.347288388262979590, -0.347241499909992260, -0.347194610688901170, -0.347147720599823570, -0.347100829642876640, -0.347053937818177670, +-0.347007045125843790, -0.346960151565992360, -0.346913257138739720, -0.346866361844204770, -0.346819465682503880, -0.346772568653754390, -0.346725670758073420, -0.346678771995578280, +-0.346631872366386210, -0.346584971870613660, -0.346538070508379480, -0.346491168279800140, -0.346444265184992830, -0.346397361224074940, -0.346350456397163610, -0.346303550704376130, +-0.346256644145829800, -0.346209736721641790, -0.346162828431928690, -0.346115919276809290, -0.346069009256400110, -0.346022098370818430, -0.345975186620181510, -0.345928274004606570, +-0.345881360524210980, -0.345834446179111190, -0.345787530969426050, -0.345740614895272140, -0.345693697956766690, -0.345646780154026940, -0.345599861487170260, -0.345552941956313970, +-0.345506021561575280, -0.345459100303070750, -0.345412178180919240, -0.345365255195237310, -0.345318331346142260, -0.345271406633751390, -0.345224481058181990, -0.345177554619551350, +-0.345130627317976000, -0.345083699153574950, -0.345036770126464660, -0.344989840236762440, -0.344942909484585560, -0.344895977870051500, -0.344849045393277430, -0.344802112054380770, +-0.344755177853477980, -0.344708242790688070, -0.344661306866127560, -0.344614370079913800, -0.344567432432164140, -0.344520493922995830, -0.344473554552526320, -0.344426614320872130, +-0.344379673228152160, -0.344332731274483050, -0.344285788459982140, -0.344238844784766740, -0.344191900248954190, -0.344144954852661940, -0.344098008596007250, -0.344051061479106750, +-0.344004113502079430, -0.343957164665041780, -0.343910214968111250, -0.343863264411405190, -0.343816312995041010, -0.343769360719136000, -0.343722407583806730, -0.343675453589172290, +-0.343628498735349230, -0.343581543022454920, -0.343534586450606750, -0.343487629019922140, -0.343440670730518430, -0.343393711582513030, -0.343346751576022510, -0.343299790711166010, +-0.343252828988059980, -0.343205866406821880, -0.343158902967569120, -0.343111938670419110, -0.343064973515489260, -0.343018007502896960, -0.342971040632758790, -0.342924072905193890, +-0.342877104320318820, -0.342830134878250980, -0.342783164579107790, -0.342736193423006650, -0.342689221410065080, -0.342642248540400430, -0.342595274814129320, -0.342548300231370890, +-0.342501324792241710, -0.342454348496859180, -0.342407371345340830, -0.342360393337803990, -0.342313414474366200, -0.342266434755144010, -0.342219454180256620, -0.342172472749820540, +-0.342125490463953350, -0.342078507322772400, -0.342031523326395140, -0.341984538474939090, -0.341937552768521720, -0.341890566207259660, -0.341843578791271970, -0.341796590520675350, +-0.341749601395587240, -0.341702611416125120, -0.341655620582406510, -0.341608628894548790, -0.341561636352668730, -0.341514642956885380, -0.341467648707315440, -0.341420653604076360, +-0.341373657647285670, -0.341326660837060760, -0.341279663173519270, -0.341232664656778590, -0.341185665286955490, -0.341138665064168960, -0.341091663988535800, -0.341044662060173530, +-0.340997659279199560, -0.340950655645731460, -0.340903651159886690, -0.340856645821781990, -0.340809639631536490, -0.340762632589266870, -0.340715624695090700, -0.340668615949125450, +-0.340621606351488690, -0.340574595902297880, -0.340527584601670650, -0.340480572449723570, -0.340433559446575880, -0.340386545592344330, -0.340339530887146360, -0.340292515331099610, +-0.340245498924321540, -0.340198481666929790, -0.340151463559041740, -0.340104444600774270, -0.340057424792246490, -0.340010404133575140, -0.339963382624877800, -0.339916360266272030, +-0.339869337057875310, -0.339822312999805250, -0.339775288092179440, -0.339728262335114550, -0.339681235728729880, -0.339634208273142060, -0.339587179968468770, -0.339540150814827520, +-0.339493120812335900, -0.339446089961111420, -0.339399058261270930, -0.339352025712933660, -0.339304992316216250, -0.339257958071236430, -0.339210922978111670, -0.339163887036959600, +-0.339116850247897840, -0.339069812611043910, -0.339022774126514660, -0.338975734794429330, -0.338928694614904600, -0.338881653588058160, -0.338834611714007580, -0.338787568992870490, +-0.338740525424764460, -0.338693481009806290, -0.338646435748115260, -0.338599389639808120, -0.338552342685002510, -0.338505294883816090, -0.338458246236366390, -0.338411196742771040, +-0.338364146403147770, -0.338317095217613270, -0.338270043186286840, -0.338222990309285320, -0.338175936586726340, -0.338128882018727480, -0.338081826605406480, -0.338034770346880840, +-0.337987713243267480, -0.337940655294685700, -0.337893596501252220, -0.337846536863084800, -0.337799476380301000, -0.337752415053018560, -0.337705352881355060, -0.337658289865428120, +-0.337611226005354700, -0.337564161301254000, -0.337517095753242900, -0.337470029361439110, -0.337422962125960180, -0.337375894046923920, -0.337328825124447840, -0.337281755358649740, +-0.337234684749646460, -0.337187613297557250, -0.337140541002499020, -0.337093467864589440, -0.337046393883946190, -0.336999319060686920, -0.336952243394929410, -0.336905166886791230, +-0.336858089536389350, -0.336811011343843060, -0.336763932309269260, -0.336716852432785600, -0.336669771714509850, -0.336622690154559650, -0.336575607753052670, -0.336528524510105900, +-0.336481440425838660, -0.336434355500367770, -0.336387269733811060, -0.336340183126286110, -0.336293095677910710, -0.336246007388802610, -0.336198918259079490, -0.336151828288858200, +-0.336104737478258200, -0.336057645827396330, -0.336010553336390410, -0.335963460005358040, -0.335916365834417030, -0.335869270823685120, -0.335822174973279210, -0.335775078283318710, +-0.335727980753920460, -0.335680882385202270, -0.335633783177281930, -0.335586683130277060, -0.335539582244305520, -0.335492480519485050, -0.335445377955932490, -0.335398274553767360, +-0.335351170313106520, -0.335304065234067750, -0.335256959316768850, -0.335209852561327510, -0.335162744967861580, -0.335115636536487960, -0.335068527267326060, -0.335021417160492830, +-0.334974306216106080, -0.334927194434283540, -0.334880081815143000, -0.334832968358802330, -0.334785854065379140, -0.334738738934990570, -0.334691622967755950, -0.334644506163792270, +-0.334597388523217300, -0.334550270046148900, -0.334503150732704810, -0.334456030583002830, -0.334408909597160800, -0.334361787775295630, -0.334314665117526890, -0.334267541623971430, +-0.334220417294747110, -0.334173292129971770, -0.334126166129763200, -0.334079039294239210, -0.334031911623517640, -0.333984783117715400, -0.333937653776952110, -0.333890523601344640, +-0.333843392591010870, -0.333796260746068610, -0.333749128066635700, -0.333701994552830010, -0.333654860204768420, -0.333607725022570580, -0.333560589006353440, -0.333513452156234790, +-0.333466314472332490, -0.333419175954764450, -0.333372036603648450, -0.333324896419102350, -0.333277755401243210, -0.333230613550190460, -0.333183470866061200, -0.333136327348973300, +-0.333089182999044550, -0.333042037816392860, -0.332994891801136060, -0.332947744953391190, -0.332900597273277810, -0.332853448760912880, -0.332806299416414380, -0.332759149239900130, +-0.332711998231488000, -0.332664846391295900, -0.332617693719441660, -0.332570540216042380, -0.332523385881217550, -0.332476230715084250, -0.332429074717760400, -0.332381917889363830, +-0.332334760230012460, -0.332287601739824250, -0.332240442418916150, -0.332193282267407800, -0.332146121285416260, -0.332098959473059400, -0.332051796830455100, -0.332004633357721350, +-0.331957469054976030, -0.331910303922337000, -0.331863137959921390, -0.331815971167848780, -0.331768803546236220, -0.331721635095201690, -0.331674465814863040, -0.331627295705338280, +-0.331580124766745200, -0.331532952999201880, -0.331485780402825280, -0.331438606977735080, -0.331391432724048420, -0.331344257641883130, -0.331297081731357190, -0.331249904992588550, +-0.331202727425695180, -0.331155549030794920, -0.331108369808005010, -0.331061189757445030, -0.331014008879232050, -0.330966827173484020, -0.330919644640318920, -0.330872461279854760, +-0.330825277092209440, -0.330778092077500030, -0.330730906235846280, -0.330683719567365250, -0.330636532072174920, -0.330589343750393280, -0.330542154602138260, -0.330494964627527870, +-0.330447773826680060, -0.330400582199711970, -0.330353389746743280, -0.330306196467891060, -0.330259002363273440, -0.330211807433008260, -0.330164611677213560, -0.330117415096007340, +-0.330070217689506730, -0.330023019457831410, -0.329975820401098570, -0.329928620519426170, -0.329881419812932230, -0.329834218281734700, -0.329787015925951670, -0.329739812745701080, +-0.329692608741100120, -0.329645403912268490, -0.329598198259323350, -0.329550991782382670, -0.329503784481564590, -0.329456576356987000, -0.329409367408767970, -0.329362157637024640, +-0.329314947041876800, -0.329267735623441640, -0.329220523381837050, -0.329173310317181220, -0.329126096429592120, -0.329078881719187700, -0.329031666186086150, -0.328984449830404590, +-0.328937232652262710, -0.328890014651777750, -0.328842795829067780, -0.328795576184250820, -0.328748355717444870, -0.328701134428768080, -0.328653912318338460, -0.328606689386273190, +-0.328559465632692060, -0.328512241057712260, -0.328465015661451860, -0.328417789444028880, -0.328370562405561510, -0.328323334546167630, -0.328276105865965510, -0.328228876365072250, +-0.328181646043607610, -0.328134414901688880, -0.328087182939434120, -0.328039950156961410, -0.327992716554388770, -0.327945482131834390, -0.327898246889415430, -0.327851010827251770, +-0.327803773945460510, -0.327756536244159850, -0.327709297723467800, -0.327662058383502540, -0.327614818224382150, -0.327567577246224710, -0.327520335449147440, -0.327473092833270200, +-0.327425849398710280, -0.327378605145585640, -0.327331360074014590, -0.327284114184115070, -0.327236867476005280, -0.327189619949802500, -0.327142371605626480, -0.327095122443594570, +-0.327047872463824830, -0.327000621666435400, -0.326953370051544400, -0.326906117619270020, -0.326858864369730330, -0.326811610303042620, -0.326764355419326750, -0.326717099718700000, +-0.326669843201280450, -0.326622585867186340, -0.326575327716535750, -0.326528068749446840, -0.326480808966036930, -0.326433548366425800, -0.326386286950730850, -0.326339024719070170, +-0.326291761671561880, -0.326244497808324260, -0.326197233129475350, -0.326149967635133380, -0.326102701325415630, -0.326055434200441970, -0.326008166260329750, -0.325960897505197080, +-0.325913627935162150, -0.325866357550343210, -0.325819086350858320, -0.325771814336824890, -0.325724541508362770, -0.325677267865589310, -0.325629993408622700, -0.325582718137581050, +-0.325535442052582670, -0.325488165153745620, -0.325440887441188210, -0.325393608915028550, -0.325346329575384060, -0.325299049422374530, -0.325251768456117420, -0.325204486676730850, +-0.325157204084333130, -0.325109920679042370, -0.325062636460976770, -0.325015351430253780, -0.324968065586993260, -0.324920778931312550, -0.324873491463329890, -0.324826203183163520, +-0.324778914090931630, -0.324731624186752440, -0.324684333470744210, -0.324637041943024280, -0.324589749603712620, -0.324542456452926560, -0.324495162490784420, -0.324447867717404300, +-0.324400572132904570, -0.324353275737403360, -0.324305978531018170, -0.324258680513868800, -0.324211381686072770, -0.324164082047748330, -0.324116781599013640, -0.324069480339987000, +-0.324022178270786660, -0.323974875391530860, -0.323927571702337050, -0.323880267203325130, -0.323832961894612580, -0.323785655776317570, -0.323738348848558450, -0.323691041111453470, +-0.323643732565120910, -0.323596423209678130, -0.323549113045245140, -0.323501802071939400, -0.323454490289879100, -0.323407177699182650, -0.323359864299968210, -0.323312550092354100, +-0.323265235076458660, -0.323217919252399230, -0.323170602620295900, -0.323123285180266010, -0.323075966932427960, -0.323028647876899940, -0.322981328013800310, -0.322934007343247400, +-0.322886685865358620, -0.322839363580253950, -0.322792040488050880, -0.322744716588867660, -0.322697391882822700, -0.322650066370034290, -0.322602740050620670, -0.322555412924700190, +-0.322508084992391200, -0.322460756253811150, -0.322413426709080080, -0.322366096358315420, -0.322318765201635490, -0.322271433239158690, -0.322224100471003310, -0.322176766897287640, +-0.322129432518129200, -0.322082097333648070, -0.322034761343961700, -0.321987424549188380, -0.321940086949446540, -0.321892748544854450, -0.321845409335530520, -0.321798069321593050, +-0.321750728503159560, -0.321703386880350110, -0.321656044453282160, -0.321608701222074130, -0.321561357186844310, -0.321514012347711150, -0.321466666704792960, -0.321419320258207190, +-0.321371973008074020, -0.321324624954510920, -0.321277276097636230, -0.321229926437568370, -0.321182575974425680, -0.321135224708326560, -0.321087872639389370, -0.321040519767731680, +-0.320993166093473500, -0.320945811616732410, -0.320898456337626810, -0.320851100256275060, -0.320803743372795550, -0.320756385687306690, -0.320709027199926000, -0.320661667910773610, +-0.320614307819967080, -0.320566946927624720, -0.320519585233865030, -0.320472222738806380, -0.320424859442567160, -0.320377495345265770, -0.320330130447019860, -0.320282764747949420, +-0.320235398248172100, -0.320188030947806230, -0.320140662846970350, -0.320093293945782730, -0.320045924244361960, -0.319998553742825490, -0.319951182441293500, -0.319903810339883520, +-0.319856437438714060, -0.319809063737903470, -0.319761689237570260, -0.319714313937832780, -0.319666937838809560, -0.319619560940618940, -0.319572183243378600, -0.319524804747208680, +-0.319477425452226740, -0.319430045358551180, -0.319382664466300540, -0.319335282775593250, -0.319287900286547740, -0.319240516999281690, -0.319193132913915100, -0.319145748030565720, +-0.319098362349352020, -0.319050975870392330, -0.319003588593805230, -0.318956200519709190, -0.318908811648222600, -0.318861421979463160, -0.318814031513551030, -0.318766640250603810, +-0.318719248190739990, -0.318671855334078050, -0.318624461680736440, -0.318577067230833680, -0.318529671984487450, -0.318482275941817830, -0.318434879102942550, -0.318387481467980070, +-0.318340083037048920, -0.318292683810267540, -0.318245283787754460, -0.318197882969628140, -0.318150481356006260, -0.318103078947009070, -0.318055675742754170, -0.318008271743360050, +-0.317960866948945260, -0.317913461359628340, -0.317866054975527720, -0.317818647796761110, -0.317771239823448790, -0.317723831055708340, -0.317676421493658270, -0.317629011137417210, +-0.317581599987103560, -0.317534188042835950, -0.317486775304732850, -0.317439361772911990, -0.317391947447493550, -0.317344532328595270, -0.317297116416335620, -0.317249699710833220, +-0.317202282212206590, -0.317154863920574180, -0.317107444836053800, -0.317060024958765670, -0.317012604288827440, -0.316965182826357720, -0.316917760571475080, -0.316870337524298000, +-0.316822913684945080, -0.316775489053534860, -0.316728063630185960, -0.316680637415016010, -0.316633210408145350, -0.316585782609691610, -0.316538354019773480, -0.316490924638509420, +-0.316443494466018050, -0.316396063502418000, -0.316348631747826900, -0.316301199202365050, -0.316253765866150230, -0.316206331739300960, -0.316158896821935930, -0.316111461114173600, +-0.316064024616132640, -0.316016587327931590, -0.315969149249688270, -0.315921710381522890, -0.315874270723553230, -0.315826830275897920, -0.315779389038675530, -0.315731947012004630, +-0.315684504196003910, -0.315637060590791050, -0.315589616196486460, -0.315542171013207750, -0.315494725041073620, -0.315447278280202690, -0.315399830730713590, -0.315352382392724890, +-0.315304933266355230, -0.315257483351722380, -0.315210032648946700, -0.315162581158145880, -0.315115128879438660, -0.315067675812943590, -0.315020221958779380, -0.314972767317064580, +-0.314925311887917000, -0.314877855671457040, -0.314830398667802380, -0.314782940877071760, -0.314735482299383750, -0.314688022934857090, -0.314640562783610360, -0.314593101845762170, +-0.314545640121430440, -0.314498177610735450, -0.314450714313794950, -0.314403250230727740, -0.314355785361652370, -0.314308319706687540, -0.314260853265951930, -0.314213386039563340, +-0.314165918027642100, -0.314118449230306070, -0.314070979647673940, -0.314023509279864330, -0.313976038126995980, -0.313928566189187520, -0.313881093466557680, -0.313833619959224210, +-0.313786145667307560, -0.313738670590925530, -0.313691194730196850, -0.313643718085240160, -0.313596240656174200, -0.313548762443117580, -0.313501283446189110, -0.313453803665506570, +-0.313406323101190380, -0.313358841753358370, -0.313311359622129250, -0.313263876707621740, -0.313216393009954520, -0.313168908529246340, -0.313121423265615870, -0.313073937219181030, +-0.313026450390062160, -0.312978962778377170, -0.312931474384244790, -0.312883985207783710, -0.312836495249112670, -0.312789004508350400, -0.312741512985614760, -0.312694020681026200, +-0.312646527594702570, -0.312599033726762620, -0.312551539077325080, -0.312504043646508690, -0.312456547434432240, -0.312409050441214360, -0.312361552666973070, -0.312314054111828670, +-0.312266554775899210, -0.312219054659303330, -0.312171553762159770, -0.312124052084587380, -0.312076549626704840, -0.312029046388630100, -0.311981542370483590, -0.311934037572383190, +-0.311886531994447770, -0.311839025636795940, -0.311791518499546560, -0.311744010582818420, -0.311696501886730200, -0.311648992411399930, -0.311601482156948000, -0.311553971123492370, +-0.311506459311151840, -0.311458946720045150, -0.311411433350291090, -0.311363919202008400, -0.311316404275315100, -0.311268888570331640, -0.311221372087175980, -0.311173854825966880, +-0.311126336786823110, -0.311078817969863530, -0.311031298375206880, -0.310983778002972000, -0.310936256853276800, -0.310888734926241860, -0.310841212221985020, -0.310793688740625180, +-0.310746164482281150, -0.310698639447071660, -0.310651113635115610, -0.310603587046531740, -0.310556059681438120, -0.310508531539955110, -0.310461002622200830, -0.310413472928294020, +-0.310365942458353530, -0.310318411212498200, -0.310270879190846840, -0.310223346393518280, -0.310175812820630500, -0.310128278472304010, -0.310080743348656870, -0.310033207449807830, +-0.309985670775875800, -0.309938133326979610, -0.309890595103238020, -0.309843056104769140, -0.309795516331693500, -0.309747975784129050, -0.309700434462194640, -0.309652892366009120, +-0.309605349495691410, -0.309557805851360280, -0.309510261433134700, -0.309462716241132580, -0.309415170275474550, -0.309367623536278560, -0.309320076023663510, -0.309272527737748270, +-0.309224978678651730, -0.309177428846492740, -0.309129878241389320, -0.309082326863462100, -0.309034774712828970, -0.308987221789608970, -0.308939668093920930, -0.308892113625883650, +-0.308844558385616140, -0.308797002373237210, -0.308749445588864970, -0.308701888032619940, -0.308654329704620150, -0.308606770604984590, -0.308559210733832080, -0.308511650091281560, +-0.308464088677451900, -0.308416526492461150, -0.308368963536429950, -0.308321399809476370, -0.308273835311719260, -0.308226270043277570, -0.308178704004270170, -0.308131137194816050, +-0.308083569615034080, -0.308036001265042330, -0.307988432144961410, -0.307940862254909460, -0.307893291595005340, -0.307845720165367990, -0.307798147966116320, -0.307750574997369240, +-0.307703001259245770, -0.307655426751863970, -0.307607851475344420, -0.307560275429805240, -0.307512698615365400, -0.307465121032143800, -0.307417542680259390, -0.307369963559831150, +-0.307322383670977970, -0.307274803013817990, -0.307227221588471880, -0.307179639395057660, -0.307132056433694340, -0.307084472704500950, -0.307036888207596340, -0.306989302943099510, +-0.306941716911128540, -0.306894130111804160, -0.306846542545244460, -0.306798954211568390, -0.306751365110894960, -0.306703775243343080, -0.306656184609031820, -0.306608593208080040, +-0.306561001040605960, -0.306513408106730220, -0.306465814406570950, -0.306418219940247150, -0.306370624707877790, -0.306323028709581890, -0.306275431945478400, -0.306227834415685460, +-0.306180236120323800, -0.306132637059511600, -0.306085037233367770, -0.306037436642011330, -0.305989835285561280, -0.305942233164136710, -0.305894630277856520, -0.305847026626838880, +-0.305799422211204600, -0.305751817031071680, -0.305704211086559260, -0.305656604377786300, -0.305608996904871810, -0.305561388667934860, -0.305513779667093590, -0.305466169902468720, +-0.305418559374178440, -0.305370948082341720, -0.305323336027077620, -0.305275723208505210, -0.305228109626743520, -0.305180495281911550, -0.305132880174127430, -0.305085264303512020, +-0.305037647670183430, -0.304990030274260690, -0.304942412115862930, -0.304894793195109090, -0.304847173512118320, -0.304799553067009570, -0.304751931859901130, -0.304704309890913680, +-0.304656687160165420, -0.304609063667775510, -0.304561439413862930, -0.304513814398546690, -0.304466188621945970, -0.304418562084179780, -0.304370934785366310, -0.304323306725626410, +-0.304275677905078150, -0.304228048323840760, -0.304180417982033210, -0.304132786879774690, -0.304085155017184140, -0.304037522394379870, -0.303989889011482610, -0.303942254868610650, +-0.303894619965883070, -0.303846984303418940, -0.303799347881337330, -0.303751710699757370, -0.303704072758798130, -0.303656434058577840, -0.303608794599217360, -0.303561154380834810, +-0.303513513403549430, -0.303465871667480290, -0.303418229172746410, -0.303370585919467030, -0.303322941907760270, -0.303275297137747040, -0.303227651609545570, -0.303180005323274940, +-0.303132358279054330, -0.303084710477002810, -0.303037061917239500, -0.302989412599883550, -0.302941762525053230, -0.302894111692869340, -0.302846460103450180, -0.302798807756914870, +-0.302751154653382480, -0.302703500792972260, -0.302655846175803320, -0.302608190801993860, -0.302560534671664830, -0.302512877784934410, -0.302465220141921790, -0.302417561742746140, +-0.302369902587526610, -0.302322242676382300, -0.302274582009432360, -0.302226920586795180, -0.302179258408591500, -0.302131595474939670, -0.302083931785958880, -0.302036267341768250, +-0.301988602142486910, -0.301940936188234090, -0.301893269479128980, -0.301845602015289820, -0.301797933796837450, -0.301750264823890280, -0.301702595096567490, -0.301654924614988160, +-0.301607253379271520, -0.301559581389536810, -0.301511908645903100, -0.301464235148488750, -0.301416560897414700, -0.301368885892799200, -0.301321210134761540, -0.301273533623420800, +-0.301225856358896260, -0.301178178341307110, -0.301130499570771590, -0.301082820047410720, -0.301035139771342830, -0.300987458742687010, -0.300939776961562600, -0.300892094428088730, +-0.300844411142384640, -0.300796727104569510, -0.300749042314761680, -0.300701356773082130, -0.300653670479649190, -0.300605983434582060, -0.300558295638000020, -0.300510607090022200, +-0.300462917790767840, -0.300415227740355340, -0.300367536938905670, -0.300319845386537110, -0.300272153083368960, -0.300224460029520410, -0.300176766225110750, -0.300129071670259150, +-0.300081376365084860, -0.300033680309706290, -0.299985983504244320, -0.299938285948817440, -0.299890587643544870, -0.299842888588545800, -0.299795188783939510, -0.299747488229845260, +-0.299699786926381440, -0.299652084873668960, -0.299604382071826330, -0.299556678520972730, -0.299508974221227410, -0.299461269172709650, -0.299413563375538700, -0.299365856829833910, +-0.299318149535713560, -0.299270441493298730, -0.299222732702707770, -0.299175023164060030, -0.299127312877474680, -0.299079601843071090, -0.299031890060968420, -0.298984177531286090, +-0.298936464254142440, -0.298888750229658500, -0.298841035457952650, -0.298793319939144260, -0.298745603673352570, -0.298697886660696800, -0.298650168901296360, -0.298602450395270500, +-0.298554731142737670, -0.298507011143818890, -0.298459290398632500, -0.298411568907297970, -0.298363846669934480, -0.298316123686661380, -0.298268399957597960, -0.298220675482862680, +-0.298172950262576560, -0.298125224296858060, -0.298077497585826520, -0.298029770129601250, -0.297982041928301580, -0.297934312982046760, -0.297886583290956130, -0.297838852855148220, +-0.297791121674744030, -0.297743389749862030, -0.297695657080621570, -0.297647923667141990, -0.297600189509542590, -0.297552454607942660, -0.297504718962460780, -0.297456982573217950, +-0.297409245440332700, -0.297361507563924320, -0.297313768944112160, -0.297266029581015560, -0.297218289474753870, -0.297170548625446510, -0.297122807033211920, -0.297075064698171130, +-0.297027321620442710, -0.296979577800145940, -0.296931833237400300, -0.296884087932325010, -0.296836341885039550, -0.296788595095662360, -0.296740847564314510, -0.296693099291114590, +-0.296645350276181890, -0.296597600519635800, -0.296549850021595730, -0.296502098782181030, -0.296454346801511110, -0.296406594079704430, -0.296358840616882170, -0.296311086413162780, +-0.296263331468665680, -0.296215575783510210, -0.296167819357815830, -0.296120062191701890, -0.296072304285286970, -0.296024545638692130, -0.295976786252035940, -0.295929026125437760, +-0.295881265259017030, -0.295833503652893130, -0.295785741307185490, -0.295737978222013480, -0.295690214397496490, -0.295642449833753150, -0.295594684530904540, -0.295546918489069220, +-0.295499151708366600, -0.295451384188916090, -0.295403615930837140, -0.295355846934249100, -0.295308077199270660, -0.295260306726022830, -0.295212535514624230, -0.295164763565194330, +-0.295116990877852480, -0.295069217452718190, -0.295021443289910870, -0.294973668389549860, -0.294925892751753900, -0.294878116376644070, -0.294830339264338880, -0.294782561414957900, +-0.294734782828620480, -0.294687003505446130, -0.294639223445554270, -0.294591442649063510, -0.294543661116094980, -0.294495878846767310, -0.294448095841199910, -0.294400312099512280, +-0.294352527621823900, -0.294304742408254160, -0.294256956458922580, -0.294209169773947790, -0.294161382353450910, -0.294113594197550510, -0.294065805306366220, -0.294018015680017340, +-0.293970225318623490, -0.293922434222304020, -0.293874642391177670, -0.293826849825365500, -0.293779056524986260, -0.293731262490159350, -0.293683467721004290, -0.293635672217640530, +-0.293587875980187650, -0.293540079008765050, -0.293492281303491360, -0.293444482864487880, -0.293396683691873160, -0.293348883785766790, -0.293301083146288170, -0.293253281773556810, +-0.293205479667692280, -0.293157676828813160, -0.293109873257040740, -0.293062068952493650, -0.293014263915291340, -0.292966458145553440, -0.292918651643399310, -0.292870844408948620, +-0.292823036442320770, -0.292775227743635350, -0.292727418313011020, -0.292679608150568980, -0.292631797256427960, -0.292583985630707370, -0.292536173273526880, -0.292488360185005960, +-0.292440546365264060, -0.292392731814420050, -0.292344916532594980, -0.292297100519907650, -0.292249283776477580, -0.292201466302424270, -0.292153648097867310, -0.292105829162926270, +-0.292058009497720590, -0.292010189102369090, -0.291962367976992930, -0.291914546121710860, -0.291866723536642450, -0.291818900221907210, -0.291771076177624710, -0.291723251403914530, +-0.291675425900895350, -0.291627599668688510, -0.291579772707412640, -0.291531945017187320, -0.291484116598132170, -0.291436287450366700, -0.291388457574010500, -0.291340626969183230, +-0.291292795636003470, -0.291244963574592560, -0.291197130785069310, -0.291149297267553180, -0.291101463022163830, -0.291053628049020850, -0.291005792348243750, -0.290957955919951330, +-0.290910118764264870, -0.290862280881303110, -0.290814442271185690, -0.290766602934032110, -0.290718762869962070, -0.290670922079095060, -0.290623080561550780, -0.290575238317447970, +-0.290527395346907910, -0.290479551650049350, -0.290431707226991910, -0.290383862077855210, -0.290336016202758840, -0.290288169601822410, -0.290240322275164770, -0.290192474222907120, +-0.290144625445168280, -0.290096775942067950, -0.290048925713725590, -0.290001074760260990, -0.289953223081793670, -0.289905370678443240, -0.289857517550329460, -0.289809663697571000, +-0.289761809120289260, -0.289713953818602990, -0.289666097792631800, -0.289618241042495390, -0.289570383568313380, -0.289522525370205400, -0.289474666448290290, -0.289426806802689340, +-0.289378946433521360, -0.289331085340906010, -0.289283223524963000, -0.289235360985811870, -0.289187497723572380, -0.289139633738364100, -0.289091769030305920, -0.289043903599519150, +-0.288996037446122620, -0.288948170570236030, -0.288900302971979000, -0.288852434651471200, -0.288804565608832330, -0.288756695844181180, -0.288708825357639140, -0.288660954149325020, +-0.288613082219358550, -0.288565209567859360, -0.288517336194947180, -0.288469462100741590, -0.288421587285362380, -0.288373711748928400, -0.288325835491560930, -0.288277958513378900, +-0.288230080814501970, -0.288182202395049820, -0.288134323255142160, -0.288086443394898690, -0.288038562814438290, -0.287990681513882300, -0.287942799493349670, -0.287894916752959970, +-0.287847033292833010, -0.287799149113088460, -0.287751264213846060, -0.287703378595225430, -0.287655492257345600, -0.287607605200327800, -0.287559717424291040, -0.287511828929355010, +-0.287463939715639330, -0.287416049783263850, -0.287368159132348260, -0.287320267763011390, -0.287272375675374720, -0.287224482869557100, -0.287176589345678300, -0.287128695103857970, +-0.287080800144215940, -0.287032904466871910, -0.286985008071945660, -0.286937110959555990, -0.286889213129824350, -0.286841314582869770, -0.286793415318811860, -0.286745515337770370, +-0.286697614639865150, -0.286649713225215870, -0.286601811093942340, -0.286553908246163390, -0.286506004682000550, -0.286458100401572660, -0.286410195404999570, -0.286362289692400960, +-0.286314383263896630, -0.286266476119606320, -0.286218568259649860, -0.286170659684146120, -0.286122750393216550, -0.286074840386980170, -0.286026929665556600, -0.285979018229065800, +-0.285931106077627390, -0.285883193211361240, -0.285835279630386240, -0.285787365334823910, -0.285739450324793140, -0.285691534600413740, -0.285643618161805560, -0.285595701009088270, +-0.285547783142381770, -0.285499864561805820, -0.285451945267479300, -0.285404025259523800, -0.285356104538058260, -0.285308183103202440, -0.285260260955076170, -0.285212338093799260, +-0.285164414519491480, -0.285116490232271810, -0.285068565232261760, -0.285020639519580340, -0.284972713094347300, -0.284924785956682470, -0.284876858106705650, -0.284828929544536700, +-0.284781000270295460, -0.284733070284100830, -0.284685139586074390, -0.284637208176335090, -0.284589276055002780, -0.284541343222197320, -0.284493409678038430, -0.284445475422646090, +-0.284397540456139130, -0.284349604778639240, -0.284301668390265270, -0.284253731291137180, -0.284205793481374760, -0.284157854961097860, -0.284109915730426320, -0.284061975789479950, +-0.284014035138377810, -0.283966093777241470, -0.283918151706189840, -0.283870208925342870, -0.283822265434820360, -0.283774321234742220, -0.283726376325228240, -0.283678430706398310, +-0.283630484378371520, -0.283582537341269310, -0.283534589595210770, -0.283486641140315740, -0.283438691976704130, -0.283390742104495770, -0.283342791523810590, -0.283294840234768420, +-0.283246888237488280, -0.283198935532091740, -0.283150982118697940, -0.283103027997426650, -0.283055073168397790, -0.283007117631731200, -0.282959161387546900, -0.282911204435963790, +-0.282863246777103510, -0.282815288411085160, -0.282767329338028560, -0.282719369558053660, -0.282671409071280300, -0.282623447877828450, -0.282575485977817950, -0.282527523371367880, +-0.282479560058599920, -0.282431596039632970, -0.282383631314587100, -0.282335665883582110, -0.282287699746738010, -0.282239732904174590, -0.282191765356011040, -0.282143797102368920, +-0.282095828143367260, -0.282047858479126060, -0.281999888109765230, -0.281951917035404680, -0.281903945256164300, -0.281855972772164120, -0.281807999583523090, -0.281760025690362960, +-0.281712051092802730, -0.281664075790962420, -0.281616099784961880, -0.281568123074921070, -0.281520145660960010, -0.281472167543197700, -0.281424188721755840, -0.281376209196753490, +-0.281328228968310610, -0.281280248036547220, -0.281232266401583160, -0.281184284063538400, -0.281136301022533010, -0.281088317278685940, -0.281040332832118990, -0.280992347682951170, +-0.280944361831302500, -0.280896375277292890, -0.280848388021042390, -0.280800400062670870, -0.280752411402298400, -0.280704422040044030, -0.280656431976029460, -0.280608441210373820, +-0.280560449743197050, -0.280512457574619180, -0.280464464704760160, -0.280416471133739960, -0.280368476861678590, -0.280320481888695180, -0.280272486214911410, -0.280224489840446460, +-0.280176492765420280, -0.280128494989952850, -0.280080496514164170, -0.280032497338174260, -0.279984497462102240, -0.279936496886069860, -0.279888495610196190, -0.279840493634601340, +-0.279792490959405230, -0.279744487584727860, -0.279696483510689320, -0.279648478737409560, -0.279600473265007750, -0.279552467093605590, -0.279504460223322260, -0.279456452654277820, +-0.279408444386592240, -0.279360435420385520, -0.279312425755777750, -0.279264415392887990, -0.279216404331838140, -0.279168392572747230, -0.279120380115735310, -0.279072366960922470, +-0.279024353108428710, -0.278976338558374060, -0.278928323310878580, -0.278880307366061450, -0.278832290724044420, -0.278784273384946600, -0.278736255348888130, -0.278688236615989020, +-0.278640217186369330, -0.278592197060149090, -0.278544176237447480, -0.278496154718386290, -0.278448132503084760, -0.278400109591662840, -0.278352085984240660, -0.278304061680938300, +-0.278256036681875760, -0.278208010987173130, -0.278159984596949630, -0.278111957511327000, -0.278063929730424490, -0.278015901254362150, -0.277967872083260070, -0.277919842217238310, +-0.277871811656416940, -0.277823780400916040, -0.277775748450854840, -0.277727715806355080, -0.277679682467536050, -0.277631648434517870, -0.277583613707420520, -0.277535578286364160, +-0.277487542171468820, -0.277439505362854670, -0.277391467860640840, -0.277343429664949240, -0.277295390775899040, -0.277247351193610380, -0.277199310918203380, -0.277151269949798050, +-0.277103228288514580, -0.277055185934472150, -0.277007142887792600, -0.276959099148595230, -0.276911054717000120, -0.276863009593127320, -0.276814963777097020, -0.276766917269029360, +-0.276718870069044330, -0.276670822177261360, -0.276622773593802110, -0.276574724318785940, -0.276526674352332970, -0.276478623694563330, -0.276430572345597150, -0.276382520305554490, +-0.276334467574554710, -0.276286414152719590, -0.276238360040168440, -0.276190305237021370, -0.276142249743398570, -0.276094193559420110, -0.276046136685206220, -0.275998079120876980, +-0.275950020866551630, -0.275901961922352110, -0.275853902288397730, -0.275805841964808560, -0.275757780951704780, -0.275709719249206560, -0.275661656857434050, -0.275613593776506520, +-0.275565530006545880, -0.275517465547671370, -0.275469400400003230, -0.275421334563661580, -0.275373268038766610, -0.275325200825438490, -0.275277132923797350, -0.275229064333962490, +-0.275180995056055870, -0.275132925090196710, -0.275084854436505270, -0.275036783095101710, -0.274988711066106170, -0.274940638349638830, -0.274892564945819930, -0.274844490854768750, +-0.274796416076607210, -0.274748340611454640, -0.274700264459431190, -0.274652187620657070, -0.274604110095252540, -0.274556031883337660, -0.274507952985032780, -0.274459873400457080, +-0.274411793129732630, -0.274363712172978670, -0.274315630530315380, -0.274267548201863050, -0.274219465187741870, -0.274171381488072020, -0.274123297102972840, -0.274075212032566300, +-0.274027126276971680, -0.273979039836309280, -0.273930952710699280, -0.273882864900261920, -0.273834776405117330, -0.273786687225385850, -0.273738597361186830, -0.273690506812642120, +-0.273642415579871120, -0.273594323662994130, -0.273546231062131330, -0.273498137777402950, -0.273450043808929180, -0.273401949156829530, -0.273353853821225790, -0.273305757802237430, +-0.273257661099984670, -0.273209563714587770, -0.273161465646167000, -0.273113366894842500, -0.273065267460734620, -0.273017167343962700, -0.272969066544648750, -0.272920965062912080, +-0.272872862898873030, -0.272824760052651830, -0.272776656524368720, -0.272728552314143950, -0.272680447422096960, -0.272632341848349720, -0.272584235593021640, -0.272536128656232950, +-0.272488021038103880, -0.272439912738754840, -0.272391803758305960, -0.272343694096877640, -0.272295583754589180, -0.272247472731562630, -0.272199361027917360, -0.272151248643773770, +-0.272103135579251980, -0.272055021834472390, -0.272006907409555240, -0.271958792304620830, -0.271910676519788560, -0.271862560055180450, -0.271814442910916000, -0.271766325087115400, +-0.271718206583898950, -0.271670087401387040, -0.271621967539699860, -0.271573846998957810, -0.271525725779280300, -0.271477603880789290, -0.271429481303604280, -0.271381358047845580, +-0.271333234113633470, -0.271285109501088250, -0.271236984210330320, -0.271188858241479040, -0.271140731594656460, -0.271092604269982050, -0.271044476267576160, -0.270996347587559030, +-0.270948218230051110, -0.270900088195172580, -0.270851957483043860, -0.270803826093784340, -0.270755694027516150, -0.270707561284358740, -0.270659427864432420, -0.270611293767857470, +-0.270563158994754360, -0.270515023545243320, -0.270466887419443860, -0.270418750617478050, -0.270370613139465370, -0.270322474985526200, -0.270274336155780780, -0.270226196650349530, +-0.270178056469352780, -0.270129915612910890, -0.270081774081143370, -0.270033631874172290, -0.269985488992117110, -0.269937345435098170, -0.269889201203235900, -0.269841056296650670, +-0.269792910715462740, -0.269744764459791670, -0.269696617529759600, -0.269648469925485970, -0.269600321647091130, -0.269552172694695500, -0.269504023068419470, -0.269455872768383340, +-0.269407721794707570, -0.269359570147511610, -0.269311417826917590, -0.269263264833045020, -0.269215111166014320, -0.269166956825945770, -0.269118801812959880, -0.269070646127176960, +-0.269022489768716620, -0.268974332737700880, -0.268926175034249320, -0.268878016658482270, -0.268829857610520250, -0.268781697890483560, -0.268733537498492600, -0.268685376434667830, +-0.268637214699129600, -0.268589052291997480, -0.268540889213393590, -0.268492725463437440, -0.268444561042249560, -0.268396395949950180, -0.268348230186659880, -0.268300063752498990, +-0.268251896647587080, -0.268203728872046300, -0.268155560425996140, -0.268107391309557130, -0.268059221522849670, -0.268011051065994100, -0.267962879939110890, -0.267914708142320550, +-0.267866535675742530, -0.267818362539499030, -0.267770188733709670, -0.267722014258494790, -0.267673839113974850, -0.267625663300270380, -0.267577486817501710, -0.267529309665788470, +-0.267481131845252850, -0.267432953356014360, -0.267384774198193510, -0.267336594371910710, -0.267288413877286410, -0.267240232714441080, -0.267192050883495180, -0.267143868384568330, +-0.267095685217782650, -0.267047501383257720, -0.266999316881114060, -0.266951131711472110, -0.266902945874452290, -0.266854759370175170, -0.266806572198760250, -0.266758384360329780, +-0.266710195855003330, -0.266662006682901410, -0.266613816844144480, -0.266565626338853000, -0.266517435167147430, -0.266469243329148290, -0.266421050824975190, -0.266372857654750330, +-0.266324663818593320, -0.266276469316624630, -0.266228274148964770, -0.266180078315734260, -0.266131881817053490, -0.266083684653042220, -0.266035486823822550, -0.265987288329514180, +-0.265939089170237620, -0.265890889346113320, -0.265842688857261760, -0.265794487703803540, -0.265746285885859020, -0.265698083403548890, -0.265649880256992600, -0.265601676446312500, +-0.265553471971628210, -0.265505266833060250, -0.265457061030729140, -0.265408854564755330, -0.265360647435259440, -0.265312439642361010, -0.265264231186182360, -0.265216022066843190, +-0.265167812284463900, -0.265119601839165110, -0.265071390731067280, -0.265023178960290980, -0.264974966526956790, -0.264926753431184270, -0.264878539673095710, -0.264830325252810860, +-0.264782110170450170, -0.264733894426134210, -0.264685678019983490, -0.264637460952118600, -0.264589243222659200, -0.264541024831727530, -0.264492805779443290, -0.264444586065927080, +-0.264396365691299370, -0.264348144655680740, -0.264299922959191750, -0.264251700601952970, -0.264203477584084080, -0.264155253905707380, -0.264107029566942490, -0.264058804567910090, +-0.264010578908730590, -0.263962352589524720, -0.263914125610412940, -0.263865897971515000, -0.263817669672953170, -0.263769440714847150, -0.263721211097317550, -0.263672980820484900, +-0.263624749884469820, -0.263576518289392820, -0.263528286035374590, -0.263480053122534750, -0.263431819550995650, -0.263383585320876970, -0.263335350432299390, -0.263287114885383370, +-0.263238878680249590, -0.263190641817018620, -0.263142404295810150, -0.263094166116746580, -0.263045927279947580, -0.262997687785533730, -0.262949447633625650, -0.262901206824344040, +-0.262852965357809330, -0.262804723234142220, -0.262756480453463340, -0.262708237015892350, -0.262659992921551680, -0.262611748170560990, -0.262563502763040910, -0.262515256699112130, +-0.262467009978895160, -0.262418762602510680, -0.262370514570078480, -0.262322265881720810, -0.262274016537557440, -0.262225766537709070, -0.262177515882296320, -0.262129264571439700, +-0.262081012605260010, -0.262032759983877710, -0.261984506707412690, -0.261936252775987250, -0.261887998189721190, -0.261839742948735130, -0.261791487053149700, -0.261743230503085570, +-0.261694973298663370, -0.261646715440002840, -0.261598456927226390, -0.261550197760453850, -0.261501937939805750, -0.261453677465402820, -0.261405416337365750, -0.261357154555815100, +-0.261308892120871550, -0.261260629032654900, -0.261212365291287550, -0.261164100896889300, -0.261115835849580810, -0.261067570149482730, -0.261019303796715670, -0.260971036791400430, +-0.260922769133656700, -0.260874500823606860, -0.260826231861370830, -0.260777962247069230, -0.260729691980822690, -0.260681421062751940, -0.260633149492977610, -0.260584877271620440, +-0.260536604398800160, -0.260488330874639300, -0.260440056699257570, -0.260391781872775730, -0.260343506395314390, -0.260295230266994300, -0.260246953487936140, -0.260198676058259750, +-0.260150397978087530, -0.260102119247539290, -0.260053839866735800, -0.260005559835797650, -0.259957279154845620, -0.259908997824000400, -0.259860715843382720, -0.259812433213113200, +-0.259764149933311760, -0.259715866004100790, -0.259667581425600150, -0.259619296197930620, -0.259571010321212770, -0.259522723795567460, -0.259474436621115300, -0.259426148797976150, +-0.259377860326272580, -0.259329571206124270, -0.259281281437652110, -0.259232991020976690, -0.259184699956218790, -0.259136408243499210, -0.259088115882938560, -0.259039822874656770, +-0.258991529218776270, -0.258943234915416930, -0.258894939964699530, -0.258846644366744760, -0.258798348121673400, -0.258750051229606150, -0.258701753690662950, -0.258653455504966210, +-0.258605156672635840, -0.258556857193792570, -0.258508557068557130, -0.258460256297050330, -0.258411954879392840, -0.258363652815705500, -0.258315350106108180, -0.258267046750723320, +-0.258218742749670880, -0.258170438103071550, -0.258122132811046120, -0.258073826873715380, -0.258025520291200070, -0.257977213063620090, -0.257928905191097960, -0.257880596673753570, +-0.257832287511707670, -0.257783977705081050, -0.257735667253994440, -0.257687356158568750, -0.257639044418924600, -0.257590732035182010, -0.257542419007463440, -0.257494105335888850, +-0.257445791020578960, -0.257397476061654640, -0.257349160459236560, -0.257300844213445620, -0.257252527324401740, -0.257204209792227360, -0.257155891617042440, -0.257107572798967840, +-0.257059253338124290, -0.257010933234632590, -0.256962612488613570, -0.256914291100187990, -0.256865969069475840, -0.256817646396599650, -0.256769323081679320, -0.256720999124835700, +-0.256672674526189580, -0.256624349285861750, -0.256576023403973060, -0.256527696880644360, -0.256479369715995500, -0.256431041910149090, -0.256382713463225050, -0.256334384375344280, +-0.256286054646627510, -0.256237724277195660, -0.256189393267169440, -0.256141061616669720, -0.256092729325816560, -0.256044396394732370, -0.255996062823537210, -0.255947728612351880, +-0.255899393761297280, -0.255851058270494150, -0.255802722140063390, -0.255754385370124960, -0.255706047960801430, -0.255657709912212760, -0.255609371224479850, -0.255561031897723500, +-0.255512691932064550, -0.255464351327623910, -0.255416010084522360, -0.255367668202879930, -0.255319325682819180, -0.255270982524460120, -0.255222638727923610, -0.255174294293330490, +-0.255125949220801670, -0.255077603510457940, -0.255029257162419360, -0.254980910176808520, -0.254932562553745360, -0.254884214293350840, -0.254835865395745760, -0.254787515861051030, +-0.254739165689387480, -0.254690814880876030, -0.254642463435636680, -0.254594111353792010, -0.254545758635462140, -0.254497405280767810, -0.254449051289829970, -0.254400696662769490, +-0.254352341399707300, -0.254303985500763390, -0.254255628966060350, -0.254207271795718280, -0.254158913989858020, -0.254110555548600460, -0.254062196472066510, -0.254013836760377090, +-0.253965476413653020, -0.253917115432014450, -0.253868753815583940, -0.253820391564481550, -0.253772028678828200, -0.253723665158744780, -0.253675301004352150, -0.253626936215771310, +-0.253578570793123130, -0.253530204736527600, -0.253481838046107470, -0.253433470721982750, -0.253385102764274340, -0.253336734173103210, -0.253288364948590190, -0.253239995090856260, +-0.253191624600022370, -0.253143253476208530, -0.253094881719537480, -0.253046509330129180, -0.252998136308104580, -0.252949762653584710, -0.252901388366690350, -0.252853013447542570, +-0.252804637896261400, -0.252756261712969500, -0.252707884897786890, -0.252659507450834600, -0.252611129372233570, -0.252562750662104710, -0.252514371320568920, -0.252465991347747280, +-0.252417610743759730, -0.252369229508729090, -0.252320847642775290, -0.252272465146019420, -0.252224082018582370, -0.252175698260585170, -0.252127313872148650, -0.252078928853393000, +-0.252030543204440900, -0.251982156925412480, -0.251933770016428640, -0.251885382477610330, -0.251836994309078630, -0.251788605510954390, -0.251740216083358670, -0.251691826026411550, +-0.251643435340235700, -0.251595044024951310, -0.251546652080679280, -0.251498259507540620, -0.251449866305656300, -0.251401472475147330, -0.251353078016133820, -0.251304682928738480, +-0.251256287213081410, -0.251207890869283630, -0.251159493897466110, -0.251111096297749860, -0.251062698070255890, -0.251014299215105210, -0.250965899732417840, -0.250917499622316630, +-0.250869098884921650, -0.250820697520353960, -0.250772295528734480, -0.250723892910184270, -0.250675489664824340, -0.250627085792775710, -0.250578681294158500, -0.250530276169095400, +-0.250481870417706640, -0.250433464040113190, -0.250385057036436100, -0.250336649406796340, -0.250288241151314980, -0.250239832270113040, -0.250191422763310630, -0.250143012631030500, +-0.250094601873392890, -0.250046190490518740, -0.249997778482529130, -0.249949365849545050, -0.249900952591687600, -0.249852538709076870, -0.249804124201835680, -0.249755709070084150, +-0.249707293313943370, -0.249658876933534330, -0.249610459928978120, -0.249562042300395780, -0.249513624047908310, -0.249465205171635900, -0.249416785671701360, -0.249368365548224860, +-0.249319944801327440, -0.249271523431130150, -0.249223101437754090, -0.249174678821320220, -0.249126255581948840, -0.249077831719762640, -0.249029407234881900, -0.248980982127427610, +-0.248932556397520880, -0.248884130045282760, -0.248835703070834330, -0.248787275474296600, -0.248738847255789850, -0.248690418415436850, -0.248641988953357790, -0.248593558869673770, +-0.248545128164505830, -0.248496696837975100, -0.248448264890202610, -0.248399832321308610, -0.248351399131415850, -0.248302965320644640, -0.248254530889115980, -0.248206095836951020, +-0.248157660164270820, -0.248109223871196470, -0.248060786957849030, -0.248012349424348800, -0.247963911270818540, -0.247915472497378500, -0.247867033104149790, -0.247818593091253480, +-0.247770152458810680, -0.247721711206942530, -0.247673269335770080, -0.247624826845413620, -0.247576383735995910, -0.247527940007637280, -0.247479495660458790, -0.247431050694581570, +-0.247382605110126720, -0.247334158907215330, -0.247285712085968560, -0.247237264646506670, -0.247188816588952450, -0.247140367913426200, -0.247091918620049030, -0.247043468708942060, +-0.246995018180226430, -0.246946567034023230, -0.246898115270452770, -0.246849662889637890, -0.246801209891698850, -0.246752756276756770, -0.246704302044932820, -0.246655847196348120, +-0.246607391731123780, -0.246558935649380940, -0.246510478951239950, -0.246462021636823600, -0.246413563706252200, -0.246365105159646880, -0.246316645997128800, -0.246268186218819130, +-0.246219725824838980, -0.246171264815308630, -0.246122803190350990, -0.246074340950086370, -0.246025878094635860, -0.245977414624120680, -0.245928950538661960, -0.245880485838380850, +-0.245832020523398560, -0.245783554593835330, -0.245735088049814060, -0.245686620891455100, -0.245638153118879570, -0.245589684732208660, -0.245541215731563540, -0.245492746117065400, +-0.245444275888834520, -0.245395805046993790, -0.245347333591663580, -0.245298861522965010, -0.245250388841019300, -0.245201915545947610, -0.245153441637871140, -0.245104967116911070, +-0.245056491983187710, -0.245008016236824000, -0.244959539877940220, -0.244911062906657620, -0.244862585323097350, -0.244814107127380610, -0.244765628319628610, -0.244717148899962540, +-0.244668668868502720, -0.244620188225372100, -0.244571706970691030, -0.244523225104580660, -0.244474742627162260, -0.244426259538556980, -0.244377775838886060, -0.244329291528270680, +-0.244280806606831240, -0.244232321074690640, -0.244183834931969210, -0.244135348178788240, -0.244086860815268870, -0.244038372841532350, -0.243989884257699880, -0.243941395063891870, +-0.243892905260231220, -0.243844414846838300, -0.243795923823834360, -0.243747432191340600, -0.243698939949478280, -0.243650447098368580, -0.243601953638132780, -0.243553459568891210, +-0.243504964890766870, -0.243456469603880120, -0.243407973708352210, -0.243359477204304340, -0.243310980091857780, -0.243262482371133790, -0.243213984042252720, -0.243165485105337560, +-0.243116985560508670, -0.243068485407887340, -0.243019984647594780, -0.242971483279752270, -0.242922981304481030, -0.242874478721902350, -0.242825975532136610, -0.242777471735306780, +-0.242728967331533290, -0.242680462320937370, -0.242631956703640320, -0.242583450479763350, -0.242534943649427760, -0.242486436212753950, -0.242437928169864920, -0.242389419520881080, +-0.242340910265923660, -0.242292400405113990, -0.242243889938573290, -0.242195378866422890, -0.242146867188784030, -0.242098354905777160, -0.242049842017525250, -0.242001328524148740, +-0.241952814425768910, -0.241904299722507040, -0.241855784414484410, -0.241807268501822330, -0.241758751984642080, -0.241710234863064090, -0.241661717137211380, -0.241613198807204360, +-0.241564679873164350, -0.241516160335212640, -0.241467640193470560, -0.241419119448059330, -0.241370598099099470, -0.241322076146713970, -0.241273553591023260, -0.241225030432148680, +-0.241176506670211540, -0.241127982305333140, -0.241079457337634750, -0.241030931767237720, -0.240982405594262540, -0.240933878818832160, -0.240885351441067100, -0.240836823461088670, +-0.240788294879018180, -0.240739765694976960, -0.240691235909086310, -0.240642705521467580, -0.240594174532241220, -0.240545642941530270, -0.240497110749455230, -0.240448577956137420, +-0.240400044561698140, -0.240351510566258780, -0.240302975969940630, -0.240254440772864180, -0.240205904975152480, -0.240157368576926020, -0.240108831578306150, -0.240060293979414200, +-0.240011755780371480, -0.239963216981299410, -0.239914677582319300, -0.239866137583551600, -0.239817596985119450, -0.239769055787143300, -0.239720513989744500, -0.239671971593044430, +-0.239623428597164430, -0.239574885002225850, -0.239526340808349200, -0.239477796015657550, -0.239429250624271420, -0.239380704634312190, -0.239332158045901160, -0.239283610859159750, +-0.239235063074209300, -0.239186514691171190, -0.239137965710165960, -0.239089416131316650, -0.239040865954743830, -0.238992315180568820, -0.238943763808913020, -0.238895211839897810, +-0.238846659273644600, -0.238798106110274720, -0.238749552349908720, -0.238700997992669690, -0.238652443038678160, -0.238603887488055530, -0.238555331340923190, -0.238506774597402520, +-0.238458217257614900, -0.238409659321680900, -0.238361100789723580, -0.238312541661863550, -0.238263981938222120, -0.238215421618920790, -0.238166860704080860, -0.238118299193823800, +-0.238069737088270980, -0.238021174387542940, -0.237972611091762880, -0.237924047201051230, -0.237875482715529500, -0.237826917635319050, -0.237778351960541310, -0.237729785691317700, +-0.237681218827769600, -0.237632651370017630, -0.237584083318184870, -0.237535514672391900, -0.237486945432760140, -0.237438375599411030, -0.237389805172465970, -0.237341234152046390, +-0.237292662538272890, -0.237244090331268590, -0.237195517531154030, -0.237146944138050710, -0.237098370152080020, -0.237049795573363390, -0.237001220402022290, -0.236952644638178140, +-0.236904068281951510, -0.236855491333465590, -0.236806913792840910, -0.236758335660198970, -0.236709756935661180, -0.236661177619348990, -0.236612597711383880, -0.236564017211886380, +-0.236515436120979720, -0.236466854438784490, -0.236418272165422080, -0.236369689301014010, -0.236321105845681720, -0.236272521799546660, -0.236223937162730320, -0.236175351935353240, +-0.236126766117538660, -0.236078179709407170, -0.236029592711080230, -0.235981005122679300, -0.235932416944325850, -0.235883828176141370, -0.235835238818247310, -0.235786648870764310, +-0.235738058333815530, -0.235689467207521620, -0.235640875492004020, -0.235592283187384260, -0.235543690293783780, -0.235495096811324050, -0.235446502740125740, -0.235397908080312050, +-0.235349312832003550, -0.235300716995321820, -0.235252120570388250, -0.235203523557324410, -0.235154925956251730, -0.235106327767291760, -0.235057728990565100, -0.235009129626195000, +-0.234960529674302030, -0.234911929135007770, -0.234863328008433680, -0.234814726294701290, -0.234766123993932070, -0.234717521106247520, -0.234668917631768340, -0.234620313570617690, +-0.234571708922916290, -0.234523103688785590, -0.234474497868347150, -0.234425891461722460, -0.234377284469033050, -0.234328676890399550, -0.234280068725945230, -0.234231459975790730, +-0.234182850640057590, -0.234134240718867320, -0.234085630212341440, -0.234037019120601510, -0.233988407443769000, -0.233939795181964620, -0.233891182335311640, -0.233842568903930680, +-0.233793954887943300, -0.233745340287471020, -0.233696725102635420, -0.233648109333557980, -0.233599492980359420, -0.233550876043162990, -0.233502258522089360, -0.233453640417260080, +-0.233405021728796710, -0.233356402456820790, -0.233307782601453850, -0.233259162162817470, -0.233210541141032320, -0.233161919536221670, -0.233113297348506220, -0.233064674578007530, +-0.233016051224847170, -0.232967427289146660, -0.232918802771027580, -0.232870177670611490, -0.232821551988019130, -0.232772925723373710, -0.232724298876795990, -0.232675671448407530, +-0.232627043438329910, -0.232578414846684650, -0.232529785673593360, -0.232481155919176760, -0.232432525583558120, -0.232383894666858160, -0.232335263169198470, -0.232286631090700610, +-0.232237998431486180, -0.232189365191676770, -0.232140731371393930, -0.232092096970758420, -0.232043461989893510, -0.231994826428919940, -0.231946190287959320, -0.231897553567133210, +-0.231848916266563230, -0.231800278386370960, -0.231751639926677990, -0.231703000887605040, -0.231654361269275470, -0.231605721071809990, -0.231557080295330200, -0.231508438939957730, +-0.231459797005814150, -0.231411154493021080, -0.231362511401699280, -0.231313867731972040, -0.231265223483960140, -0.231216578657785170, -0.231167933253568770, -0.231119287271432520, +-0.231070640711498050, -0.231021993573887000, -0.230973345858720090, -0.230924697566120690, -0.230876048696209530, -0.230827399249108250, -0.230778749224938490, -0.230730098623821820, +-0.230681447445879930, -0.230632795691233570, -0.230584143360006070, -0.230535490452318220, -0.230486836968291610, -0.230438182908047930, -0.230389528271708800, -0.230340873059395850, +-0.230292217271230730, -0.230243560907334170, -0.230194903967829600, -0.230146246452837770, -0.230097588362480290, -0.230048929696878870, -0.230000270456155120, -0.229951610640430680, +-0.229902950249827240, -0.229854289284465520, -0.229805627744468970, -0.229756965629958370, -0.229708302941055320, -0.229659639677881530, -0.229610975840558650, -0.229562311429208300, +-0.229513646443951340, -0.229464980884911100, -0.229416314752208420, -0.229367648045964960, -0.229318980766302360, -0.229270312913342320, -0.229221644487206500, -0.229172975488016570, +-0.229124305915893330, -0.229075635770960210, -0.229026965053338000, -0.228978293763148350, -0.228929621900512970, -0.228880949465553570, -0.228832276458391770, -0.228783602879149260, +-0.228734928727946900, -0.228686254004908080, -0.228637578710153640, -0.228588902843805230, -0.228540226405984560, -0.228491549396813350, -0.228442871816413260, -0.228394193664905130, +-0.228345514942412370, -0.228296835649055810, -0.228248155784957160, -0.228199475350238160, -0.228150794345020450, -0.228102112769425740, -0.228053430623575750, -0.228004747907591340, +-0.227956064621595900, -0.227907380765710320, -0.227858696340056290, -0.227810011344755510, -0.227761325779929690, -0.227712639645700570, -0.227663952942188970, -0.227615265669518370, +-0.227566577827809590, -0.227517889417184400, -0.227469200437764450, -0.227420510889671520, -0.227371820773027310, -0.227323130087953520, -0.227274438834571070, -0.227225747013003380, +-0.227177054623371320, -0.227128361665796640, -0.227079668140401040, -0.227030974047306270, -0.226982279386634070, -0.226933584158505310, -0.226884888363043440, -0.226836192000369360, +-0.226787495070604810, -0.226738797573871500, -0.226690099510291200, -0.226641400879985660, -0.226592701683076630, -0.226544001919684960, -0.226495301589934170, -0.226446600693945090, +-0.226397899231839560, -0.226349197203739250, -0.226300494609765950, -0.226251791450041400, -0.226203087724687390, -0.226154383433824800, -0.226105678577577100, -0.226056973156065210, +-0.226008267169410890, -0.225959560617735920, -0.225910853501162020, -0.225862145819811010, -0.225813437573804620, -0.225764728763263760, -0.225716019388311960, -0.225667309449070120, +-0.225618598945660000, -0.225569887878203370, -0.225521176246822020, -0.225472464051637730, -0.225423751292771420, -0.225375037970346610, -0.225326324084484190, -0.225277609635305960, +-0.225228894622933720, -0.225180179047489240, -0.225131462909094300, -0.225082746207870720, -0.225034028943939400, -0.224985311117423870, -0.224936592728445070, -0.224887873777124770, +-0.224839154263584810, -0.224790434187946950, -0.224741713550333010, -0.224692992350863900, -0.224644270589663210, -0.224595548266851820, -0.224546825382551550, -0.224498101936884240, +-0.224449377929971690, -0.224400653361935650, -0.224351928232898010, -0.224303202542979670, -0.224254476292304190, -0.224205749480992530, -0.224157022109166490, -0.224108294176947890, +-0.224059565684458560, -0.224010836631820310, -0.223962107019154120, -0.223913376846583520, -0.223864646114229460, -0.223815914822213800, -0.223767182970658340, -0.223718450559684950, +-0.223669717589415420, -0.223620984059971580, -0.223572249971474430, -0.223523515324047520, -0.223474780117811830, -0.223426044352889180, -0.223377308029401420, -0.223328571147470400, +-0.223279833707217930, -0.223231095708765900, -0.223182357152235250, -0.223133618037749560, -0.223084878365429840, -0.223036138135397940, -0.222987397347775670, -0.222938656002684920, +-0.222889914100247530, -0.222841171640585340, -0.222792428623819370, -0.222743685050073190, -0.222694940919467820, -0.222646196232125060, -0.222597450988166830, -0.222548705187714970, +-0.222499958830891350, -0.222451211917816970, -0.222402464448615420, -0.222353716423407700, -0.222304967842315710, -0.222256218705461280, -0.222207469012966310, -0.222158718764952660, +-0.222109967961542230, -0.222061216602856020, -0.222012464689017610, -0.221963712220148050, -0.221914959196369220, -0.221866205617802960, -0.221817451484571220, -0.221768696796795840, +-0.221719941554597840, -0.221671185758100880, -0.221622429407425940, -0.221573672502694910, -0.221524915044029710, -0.221476157031552240, -0.221427398465384370, -0.221378639345648000, +-0.221329879672464150, -0.221281119445956490, -0.221232358666246020, -0.221183597333454660, -0.221134835447704290, -0.221086073009116840, -0.221037310017814210, -0.220988546473917440, +-0.220939782377550190, -0.220891017728833460, -0.220842252527889190, -0.220793486774839290, -0.220744720469805670, -0.220695953612910250, -0.220647186204274950, -0.220598418244020820, +-0.220549649732271510, -0.220500880669148050, -0.220452111054772410, -0.220403340889266500, -0.220354570172752230, -0.220305798905351540, -0.220257027087186360, -0.220208254718377740, +-0.220159481799049340, -0.220110708329322220, -0.220061934309318360, -0.220013159739159660, -0.219964384618968060, -0.219915608948865500, -0.219866832728973890, -0.219818055959414370, +-0.219769278640310540, -0.219720500771783540, -0.219671722353955300, -0.219622943386947710, -0.219574163870882800, -0.219525383805882460, -0.219476603192067800, -0.219427822029562510, +-0.219379040318487650, -0.219330258058965190, -0.219281475251117100, -0.219232691895065310, -0.219183907990931790, -0.219135123538838520, -0.219086338538906550, -0.219037552991259600, +-0.218988766896018760, -0.218939980253306020, -0.218891193063243340, -0.218842405325952670, -0.218793617041555980, -0.218744828210174380, -0.218696038831931560, -0.218647248906948670, +-0.218598458435347640, -0.218549667417250490, -0.218500875852779160, -0.218452083742055630, -0.218403291085201900, -0.218354497882339070, -0.218305704133590850, -0.218256909839078390, +-0.218208114998923650, -0.218159319613248640, -0.218110523682175290, -0.218061727205825670, -0.218012930184320830, -0.217964132617784550, -0.217915334506337960, -0.217866535850103020, +-0.217817736649201730, -0.217768936903756090, -0.217720136613888120, -0.217671335779719810, -0.217622534401372300, -0.217573732478969300, -0.217524930012631980, -0.217476127002482340, +-0.217427323448642380, -0.217378519351234120, -0.217329714710379540, -0.217280909526200690, -0.217232103798818720, -0.217183297528357330, -0.217134490714937680, -0.217085683358681840, +-0.217036875459711760, -0.216988067018149520, -0.216939258034117090, -0.216890448507736530, -0.216841638439128960, -0.216792827828418190, -0.216744016675725320, -0.216695204981172450, +-0.216646392744881540, -0.216597579966974650, -0.216548766647573800, -0.216499952786800180, -0.216451138384777560, -0.216402323441627080, -0.216353507957470770, -0.216304691932430710, +-0.216255875366628940, -0.216207058260187430, -0.216158240613228330, -0.216109422425872720, -0.216060603698244450, -0.216011784430464650, -0.215962964622655410, -0.215914144274938740, +-0.215865323387436720, -0.215816501960271380, -0.215767679993563940, -0.215718857487438130, -0.215670034442015210, -0.215621210857417200, -0.215572386733766160, -0.215523562071184140, +-0.215474736869793240, -0.215425911129715460, -0.215377084851072070, -0.215328258033986840, -0.215279430678580940, -0.215230602784976470, -0.215181774353295500, -0.215132945383660070, +-0.215084115876192310, -0.215035285831013360, -0.214986455248247080, -0.214937624128014680, -0.214888792470438210, -0.214839960275639730, -0.214791127543741380, -0.214742294274865210, +-0.214693460469133290, -0.214644626126666850, -0.214595791247589730, -0.214546955832023130, -0.214498119880089130, -0.214449283391909830, -0.214400446367607330, -0.214351608807303700, +-0.214302770711121050, -0.214253932079180640, -0.214205092911606220, -0.214156253208519110, -0.214107412970041350, -0.214058572196295040, -0.214009730887402330, -0.213960889043485260, +-0.213912046664665120, -0.213863203751065710, -0.213814360302808320, -0.213765516320015030, -0.213716671802807930, -0.213667826751309160, -0.213618981165640820, -0.213570135045925010, +-0.213521288392283020, -0.213472441204838690, -0.213423593483713230, -0.213374745229028770, -0.213325896440907490, -0.213277047119471430, -0.213228197264842790, -0.213179346877143630, +-0.213130495956495250, -0.213081644503021470, -0.213032792516843620, -0.212983939998083770, -0.212935086946864060, -0.212886233363306640, -0.212837379247533650, -0.212788524599666320, +-0.212739669419828550, -0.212690813708141640, -0.212641957464727670, -0.212593100689708800, -0.212544243383207180, -0.212495385545344970, -0.212446527176244290, -0.212397668276026410, +-0.212348808844815250, -0.212299948882732040, -0.212251088389898980, -0.212202227366438180, -0.212153365812471820, -0.212104503728122060, -0.212055641113510160, -0.212006777968760020, +-0.211957914293992940, -0.211909050089331090, -0.211860185354896590, -0.211811320090811630, -0.211762454297198390, -0.211713587974179000, -0.211664721121874760, -0.211615853740409620, +-0.211566985829904820, -0.211518117390482540, -0.211469248422265000, -0.211420378925374320, -0.211371508899932700, -0.211322638346062320, -0.211273767263884440, -0.211224895653523040, +-0.211176023515099400, -0.211127150848735710, -0.211078277654554110, -0.211029403932676830, -0.210980529683226060, -0.210931654906323070, -0.210882779602091840, -0.210833903770653640, +-0.210785027412130680, -0.210736150526645160, -0.210687273114319260, -0.210638395175275190, -0.210589516709635110, -0.210540637717520380, -0.210491758199054910, -0.210442878154360080, +-0.210393997583558030, -0.210345116486770980, -0.210296234864121160, -0.210247352715730720, -0.210198470041721930, -0.210149586842216100, -0.210100703117337140, -0.210051818867206450, +-0.210002934091946200, -0.209954048791678620, -0.209905162966525920, -0.209856276616610300, -0.209807389742053120, -0.209758502342978350, -0.209709614419507330, -0.209660725971762250, +-0.209611836999865380, -0.209562947503938890, -0.209514057484105040, -0.209465166940486060, -0.209416275873203300, -0.209367384282380690, -0.209318492168139640, -0.209269599530602340, +-0.209220706369891070, -0.209171812686128030, -0.209122918479435430, -0.209074023749934700, -0.209025128497749760, -0.208976232723002000, -0.208927336425813650, -0.208878439606306980, +-0.208829542264604210, -0.208780644400827550, -0.208731746015099310, -0.208682847107540840, -0.208633947678276120, -0.208585047727426500, -0.208536147255114300, -0.208487246261461700, +-0.208438344746591010, -0.208389442710624430, -0.208340540153684280, -0.208291637075891880, -0.208242733477371270, -0.208193829358243820, -0.208144924718631800, -0.208096019558657470, +-0.208047113878443100, -0.207998207678110920, -0.207949300957782380, -0.207900393717581460, -0.207851485957629530, -0.207802577678048880, -0.207753668878961820, -0.207704759560490560, +-0.207655849722757410, -0.207606939365884650, -0.207558028489993660, -0.207509117095208450, -0.207460205181650480, -0.207411292749441980, -0.207362379798705250, -0.207313466329562570, +-0.207264552342136230, -0.207215637836548480, -0.207166722812920810, -0.207117807271377190, -0.207068891212039030, -0.207019974635028660, -0.206971057540468350, -0.206922139928480380, +-0.206873221799187100, -0.206824303152709860, -0.206775383989172750, -0.206726464308697180, -0.206677544111405430, -0.206628623397419830, -0.206579702166862690, -0.206530780419856290, +-0.206481858156522920, -0.206432935376984040, -0.206384012081363700, -0.206335088269783310, -0.206286163942365240, -0.206237239099231720, -0.206188313740505110, -0.206139387866307730, +-0.206090461476760990, -0.206041534571988980, -0.205992607152113150, -0.205943679217255790, -0.205894750767539210, -0.205845821803085780, -0.205796892324017790, -0.205747962330457560, +-0.205699031822526580, -0.205650100800348870, -0.205601169264045900, -0.205552237213740020, -0.205503304649553550, -0.205454371571608810, -0.205405437980028140, -0.205356503874933870, +-0.205307569256447470, -0.205258634124693030, -0.205209698479792010, -0.205160762321866720, -0.205111825651039550, -0.205062888467432810, -0.205013950771168820, -0.204965012562369130, +-0.204916073841157760, -0.204867134607656180, -0.204818194861986800, -0.204769254604271920, -0.204720313834633900, -0.204671372553195090, -0.204622430760077860, -0.204573488455403660, +-0.204524545639296650, -0.204475602311878250, -0.204426658473270850, -0.204377714123596790, -0.204328769262978470, -0.204279823891538200, -0.204230878009398380, -0.204181931616680500, +-0.204132984713508660, -0.204084037300004350, -0.204035089376289970, -0.203986140942487850, -0.203937191998720370, -0.203888242545109930, -0.203839292581777990, -0.203790342108848720, +-0.203741391126443570, -0.203692439634684950, -0.203643487633695220, -0.203594535123596790, -0.203545582104512010, -0.203496628576563280, -0.203447674539872110, -0.203398719994562600, +-0.203349764940756320, -0.203300809378575610, -0.203251853308142910, -0.203202896729580560, -0.203153939643010960, -0.203104982048555620, -0.203056023946338730, -0.203007065336481750, +-0.202958106219107120, -0.202909146594337230, -0.202860186462294480, -0.202811225823101270, -0.202762264676879970, -0.202713303023752150, -0.202664340863841940, -0.202615378197270880, +-0.202566415024161370, -0.202517451344635830, -0.202468487158816660, -0.202419522466826260, -0.202370557268787080, -0.202321591564820630, -0.202272625355051060, -0.202223658639599930, +-0.202174691418589650, -0.202125723692142630, -0.202076755460381310, -0.202027786723428110, -0.201978817481404590, -0.201929847734434870, -0.201880877482640530, -0.201831906726144010, +-0.201782935465067730, -0.201733963699534090, -0.201684991429665530, -0.201636018655584530, -0.201587045377412590, -0.201538071595273930, -0.201489097309290040, -0.201440122519583460, +-0.201391147226276550, -0.201342171429491760, -0.201293195129351570, -0.201244218325978390, -0.201195241019493760, -0.201146263210021940, -0.201097284897684440, -0.201048306082603740, +-0.200999326764902260, -0.200950346944702460, -0.200901366622126790, -0.200852385797296860, -0.200803404470336820, -0.200754422641368280, -0.200705440310513660, -0.200656457477895460, +-0.200607474143636110, -0.200558490307858080, -0.200509505970683820, -0.200460521132234920, -0.200411535792635570, -0.200362549952007420, -0.200313563610472870, -0.200264576768154400, +-0.200215589425174510, -0.200166601581655640, -0.200117613237719400, -0.200068624393489990, -0.200019635049089040, -0.199970645204638970, -0.199921654860262310, -0.199872664016081500, +-0.199823672672219040, -0.199774680828797400, -0.199725688485938190, -0.199676695643765610, -0.199627702302401320, -0.199578708461967760, -0.199529714122587410, -0.199480719284382800, +-0.199431723947476380, -0.199382728111990650, -0.199333731778047250, -0.199284734945770370, -0.199235737615281660, -0.199186739786703590, -0.199137741460158700, -0.199088742635769420, +-0.199039743313658310, -0.198990743493946960, -0.198941743176759640, -0.198892742362217930, -0.198843741050444390, -0.198794739241561490, -0.198745736935691750, -0.198696734132957660, +-0.198647730833481720, -0.198598727037385600, -0.198549722744793540, -0.198500717955827160, -0.198451712670608990, -0.198402706889261540, -0.198353700611907320, -0.198304693838668860, +-0.198255686569668630, -0.198206678805028350, -0.198157670544872240, -0.198108661789321930, -0.198059652538500000, -0.198010642792528920, -0.197961632551531210, -0.197912621815629460, +-0.197863610584945250, -0.197814598859602900, -0.197765586639724070, -0.197716573925431240, -0.197667560716846990, -0.197618547014093840, -0.197569532817294340, -0.197520518126570980, +-0.197471502942045460, -0.197422487263842070, -0.197373471092082450, -0.197324454426889150, -0.197275437268384730, -0.197226419616691680, -0.197177401471932610, -0.197128382834229180, +-0.197079363703705630, -0.197030344080483700, -0.196981323964685870, -0.196932303356434770, -0.196883282255852890, -0.196834260663062810, -0.196785238578187080, -0.196736216001347390, +-0.196687192932668010, -0.196638169372270660, -0.196589145320277910, -0.196540120776812270, -0.196491095741996330, -0.196442070215952640, -0.196393044198802940, -0.196344017690671470, +-0.196294990691679970, -0.196245963201950980, -0.196196935221607080, -0.196147906750770870, -0.196098877789564860, -0.196049848338111680, -0.196000818396532990, -0.195951787964953130, +-0.195902757043493800, -0.195853725632277600, -0.195804693731427060, -0.195755661341064780, -0.195706628461313370, -0.195657595092295380, -0.195608561234132530, -0.195559526886949160, +-0.195510492050866960, -0.195461456726008510, -0.195412420912496440, -0.195363384610453330, -0.195314347820001730, -0.195265310541264280, -0.195216272774362680, -0.195167234519421280, +-0.195118195776561780, -0.195069156545906790, -0.195020116827578920, -0.194971076621700740, -0.194922035928394880, -0.194872994747783050, -0.194823953079989620, -0.194774910925136300, +-0.194725868283345700, -0.194676825154740440, -0.194627781539443100, -0.194578737437576310, -0.194529692849262690, -0.194480647774623950, -0.194431602213784470, -0.194382556166865980, +-0.194333509633991120, -0.194284462615282450, -0.194235415110862650, -0.194186367120854330, -0.194137318645379170, -0.194088269684561610, -0.194039220238523380, -0.193990170307387110, +-0.193941119891275410, -0.193892068990310890, -0.193843017604616200, -0.193793965734313980, -0.193744913379525980, -0.193695860540376550, -0.193646807216987490, -0.193597753409481380, +-0.193548699117980920, -0.193499644342608690, -0.193450589083487360, -0.193401533340738670, -0.193352477114487050, -0.193303420404854210, -0.193254363211962820, -0.193205305535935540, +-0.193156247376894990, -0.193107188734963800, -0.193058129610264670, -0.193009070002919340, -0.192960009913052180, -0.192910949340785010, -0.192861888286240480, -0.192812826749541200, +-0.192763764730809890, -0.192714702230169150, -0.192665639247741630, -0.192616575783649190, -0.192567511838016150, -0.192518447410964330, -0.192469382502616420, -0.192420317113095010, +-0.192371251242522830, -0.192322184891022540, -0.192273118058716750, -0.192224050745727320, -0.192174982952178640, -0.192125914678192480, -0.192076845923891540, -0.192027776689398490, +-0.191978706974836020, -0.191929636780326730, -0.191880566105992520, -0.191831494951957750, -0.191782423318344250, -0.191733351205274680, -0.191684278612871740, -0.191635205541258120, +-0.191586131990556460, -0.191537057960889490, -0.191487983452379000, -0.191438908465149410, -0.191389832999322550, -0.191340757055021130, -0.191291680632367790, -0.191242603731485240, +-0.191193526352496200, -0.191144448495522480, -0.191095370160688500, -0.191046291348116100, -0.190997212057927970, -0.190948132290246820, -0.190899052045195330, -0.190849971322896220, +-0.190800890123472150, -0.190751808447045010, -0.190702726293739220, -0.190653643663676600, -0.190604560556979890, -0.190555476973771760, -0.190506392914174950, -0.190457308378312150, +-0.190408223366305220, -0.190359137878278600, -0.190310051914354130, -0.190260965474654510, -0.190211878559302490, -0.190162791168420800, -0.190113703302132120, -0.190064614960559150, +-0.190015526143823800, -0.189966436852050500, -0.189917347085361120, -0.189868256843878370, -0.189819166127724980, -0.189770074937023660, -0.189720983271897150, -0.189671891132468180, +-0.189622798518858630, -0.189573705431192950, -0.189524611869592990, -0.189475517834181510, -0.189426423325081250, -0.189377328342414910, -0.189328232886305260, -0.189279136956875040, +-0.189230040554246080, -0.189180943678542910, -0.189131846329887390, -0.189082748508402230, -0.189033650214210200, -0.188984551447434060, -0.188935452208196550, -0.188886352496619500, +-0.188837252312827470, -0.188788151656942290, -0.188739050529086770, -0.188689948929383570, -0.188640846857955540, -0.188591744314925370, -0.188542641300415840, -0.188493537814548860, +-0.188444433857448880, -0.188395329429237810, -0.188346224530038440, -0.188297119159973490, -0.188248013319165770, -0.188198907007738000, -0.188149800225812070, -0.188100692973512530, +-0.188051585250961270, -0.188002477058281050, -0.187953368395594620, -0.187904259263024760, -0.187855149660694280, -0.187806039588725880, -0.187756929047241560, -0.187707818036365770, +-0.187658706556220410, -0.187609594606928330, -0.187560482188612240, -0.187511369301394950, -0.187462255945399230, -0.187413142120747000, -0.187364027827562780, -0.187314913065968510, +-0.187265797836086930, -0.187216682138040880, -0.187167565971953110, -0.187118449337946440, -0.187069332236143640, -0.187020214666666630, -0.186971096629639950, -0.186921978125185550, +-0.186872859153426190, -0.186823739714484680, -0.186774619808483840, -0.186725499435546420, -0.186676378595795280, -0.186627257289352310, -0.186578135516342060, -0.186529013276886480, +-0.186479890571108360, -0.186430767399130530, -0.186381643761075770, -0.186332519657066900, -0.186283395087226740, -0.186234270051677230, -0.186185144550542890, -0.186136018583945680, +-0.186086892152008470, -0.186037765254853990, -0.185988637892605110, -0.185939510065384640, -0.185890381773314520, -0.185841253016519330, -0.185792123795120970, -0.185742994109242330, +-0.185693863959006190, -0.185644733344535410, -0.185595602265952790, -0.185546470723381150, -0.185497338716942490, -0.185448206246761340, -0.185399073312959660, -0.185349939915660320, +-0.185300806054986110, -0.185251671731059890, -0.185202536944004510, -0.185153401693941900, -0.185104265980996660, -0.185055129805290740, -0.185005993166947020, -0.184956856066088300, +-0.184907718502837440, -0.184858580477317290, -0.184809441989650690, -0.184760303039959610, -0.184711163628368650, -0.184662023754999790, -0.184612883419975870, -0.184563742623419710, +-0.184514601365454220, -0.184465459646202230, -0.184416317465785680, -0.184367174824329240, -0.184318031721954880, -0.184268888158785420, -0.184219744134943740, -0.184170599650552690, +-0.184121454705735150, -0.184072309300614000, -0.184023163435311170, -0.183974017109951320, -0.183924870324656400, -0.183875723079549330, -0.183826575374752940, -0.183777427210390140, +-0.183728278586583750, -0.183679129503456660, -0.183629979961130870, -0.183580829959731020, -0.183531679499379100, -0.183482528580197950, -0.183433377202310510, -0.183384225365839590, +-0.183335073070908160, -0.183285920317638130, -0.183236767106154190, -0.183187613436578330, -0.183138459309033440, -0.183089304723642380, -0.183040149680528090, -0.182990994179813400, +-0.182941838221621240, -0.182892681806073630, -0.182843524933295140, -0.182794367603407860, -0.182745209816534690, -0.182696051572798470, -0.182646892872322110, -0.182597733715228530, +-0.182548574101640630, -0.182499414031680410, -0.182450253505472500, -0.182401092523138990, -0.182351931084802740, -0.182302769190586660, -0.182253606840613670, -0.182204444035006660, +-0.182155280773887650, -0.182106117057381330, -0.182056952885609720, -0.182007788258695710, -0.181958623176762230, -0.181909457639932190, -0.181860291648328540, -0.181811125202074130, +-0.181761958301291020, -0.181712790946103930, -0.181663623136634840, -0.181614454873006680, -0.181565286155342400, -0.181516116983764880, -0.181466947358397110, -0.181417777279361060, +-0.181368606746781460, -0.181319435760780330, -0.181270264321480630, -0.181221092429005250, -0.181171920083477160, -0.181122747285019260, -0.181073574033754490, -0.181024400329804910, +-0.180975226173295200, -0.180926051564347430, -0.180876876503084540, -0.180827700989629440, -0.180778525024105100, -0.180729348606634450, -0.180680171737340410, -0.180630994416345090, +-0.180581816643773150, -0.180532638419746650, -0.180483459744388590, -0.180434280617821850, -0.180385101040169420, -0.180335921011554240, -0.180286740532098370, -0.180237559601926530, +-0.180188378221160790, -0.180139196389924120, -0.180090014108339440, -0.180040831376529740, -0.179991648194617960, -0.179942464562727060, -0.179893280480979110, -0.179844095949498850, +-0.179794910968408330, -0.179745725537830550, -0.179696539657888450, -0.179647353328704990, -0.179598166550403170, -0.179548979323105930, -0.179499791646935360, -0.179450603522016170, +-0.179401414948470510, -0.179352225926421280, -0.179303036455991490, -0.179253846537304110, -0.179204656170482120, -0.179155465355647610, -0.179106274092925320, -0.179057082382437340, +-0.179007890224306630, -0.178958697618656240, -0.178909504565609080, -0.178860311065288160, -0.178811117117816470, -0.178761922723316090, -0.178712727881911810, -0.178663532593725690, +-0.178614336858880730, -0.178565140677499960, -0.178515944049706300, -0.178466746975622810, -0.178417549455371580, -0.178368351489077340, -0.178319153076862220, -0.178269954218849200, +-0.178220754915161320, -0.178171555165921540, -0.178122354971252890, -0.178073154331278320, -0.178023953246120030, -0.177974751715902710, -0.177925549740748510, -0.177876347320780420, +-0.177827144456121490, -0.177777941146894690, -0.177728737393223040, -0.177679533195229530, -0.177630328553036340, -0.177581123466768190, -0.177531917936547210, -0.177482711962496460, +-0.177433505544738940, -0.177384298683397640, -0.177335091378595600, -0.177285883630454940, -0.177236675439100460, -0.177187466804654280, -0.177138257727239460, -0.177089048206978960, +-0.177039838243995860, -0.176990627838413160, -0.176941416990353900, -0.176892205699940210, -0.176842993967296890, -0.176793781792546070, -0.176744569175810830, -0.176695356117214130, +-0.176646142616879050, -0.176596928674928630, -0.176547714291485860, -0.176498499466672950, -0.176449284200614680, -0.176400068493433180, -0.176350852345251500, -0.176301635756192700, +-0.176252418726379810, -0.176203201255935860, -0.176153983344983060, -0.176104764993646160, -0.176055546202047330, -0.176006326970309660, -0.175957107298556180, -0.175907887186909920, +-0.175858666635493930, -0.175809445644431290, -0.175760224213844160, -0.175711002343857340, -0.175661780034593010, -0.175612557286174230, -0.175563334098724040, -0.175514110472365560, +-0.175464886407221770, -0.175415661903414900, -0.175366436961069740, -0.175317211580308500, -0.175267985761254240, -0.175218759504029990, -0.175169532808758850, -0.175120305675563890, +-0.175071078104568150, -0.175021850095893860, -0.174972621649665820, -0.174923392766006210, -0.174874163445038120, -0.174824933686884620, -0.174775703491668790, -0.174726472859513700, +-0.174677241790542420, -0.174628010284877180, -0.174578778342642770, -0.174529545963961420, -0.174480313148956210, -0.174431079897750220, -0.174381846210466540, -0.174332612087228220, +-0.174283377528157510, -0.174234142533379240, -0.174184907103015600, -0.174135671237189680, -0.174086434936024600, -0.174037198199643420, -0.173987961028169240, -0.173938723421725170, +-0.173889485380433420, -0.173840246904418850, -0.173791007993803620, -0.173741768648710910, -0.173692528869263760, -0.173643288655585290, -0.173594048007798570, -0.173544806926026780, +-0.173495565410392070, -0.173446323461019320, -0.173397081078030760, -0.173347838261549510, -0.173298595011698640, -0.173249351328601310, -0.173200107212380610, -0.173150862663158740, +-0.173101617681060580, -0.173052372266208400, -0.173003126418725280, -0.172953880138734360, -0.172904633426358730, -0.172855386281721510, -0.172806138704945820, -0.172756890696153940, +-0.172707642255470670, -0.172658393383018300, -0.172609144078919970, -0.172559894343298770, -0.172510644176277820, -0.172461393577980270, -0.172412142548528350, -0.172362891088046980, +-0.172313639196658350, -0.172264386874485640, -0.172215134121651960, -0.172165880938280450, -0.172116627324494200, -0.172067373280416440, -0.172018118806169320, -0.171968863901877820, +-0.171919608567664140, -0.171870352803651430, -0.171821096609962860, -0.171771839986721520, -0.171722582934050600, -0.171673325452073230, -0.171624067540911670, -0.171574809200690790, +-0.171525550431532920, -0.171476291233561150, -0.171427031606898650, -0.171377771551668580, -0.171328511067994100, -0.171279250155997430, -0.171229988815803540, -0.171180727047534680, +-0.171131464851313970, -0.171082202227264640, -0.171032939175509770, -0.170983675696172570, -0.170934411789376180, -0.170885147455242890, -0.170835882693897570, -0.170786617505462590, +-0.170737351890061030, -0.170688085847816110, -0.170638819378850980, -0.170589552483288800, -0.170540285161252720, -0.170491017412865070, -0.170441749238250760, -0.170392480637532070, +-0.170343211610832160, -0.170293942158274230, -0.170244672279981470, -0.170195401976076990, -0.170146131246683150, -0.170096860091924850, -0.170047588511924420, -0.169998316506805000, +-0.169949044076689790, -0.169899771221701970, -0.169850497941964720, -0.169801224237601240, -0.169751950108733810, -0.169702675555487380, -0.169653400577984280, -0.169604125176347650, +-0.169554849350700730, -0.169505573101166680, -0.169456296427868690, -0.169407019330929080, -0.169357741810472810, -0.169308463866622180, -0.169259185499500390, -0.169209906709230640, +-0.169160627495936130, -0.169111347859740050, -0.169062067800765600, -0.169012787319135080, -0.168963506414973490, -0.168914225088403150, -0.168864943339547210, -0.168815661168528950, +-0.168766378575471500, -0.168717095560498130, -0.168667812123731140, -0.168618528265295470, -0.168569243985313500, -0.168519959283908420, -0.168470674161203450, -0.168421388617321780, +-0.168372102652386670, -0.168322816266521260, -0.168273529459847970, -0.168224242232491690, -0.168174954584574850, -0.168125666516220600, -0.168076378027552180, -0.168027089118692820, +-0.167977799789765740, -0.167928510040894150, -0.167879219872200420, -0.167829929283809520, -0.167780638275843800, -0.167731346848426470, -0.167682055001680790, -0.167632762735729970, +-0.167583470050697240, -0.167534176946705800, -0.167484883423878100, -0.167435589482339030, -0.167386295122210980, -0.167337000343617230, -0.167287705146680950, -0.167238409531525410, +-0.167189113498273870, -0.167139817047048640, -0.167090520177974740, -0.167041222891174570, -0.166991925186771330, -0.166942627064888270, -0.166893328525648640, -0.166844029569175710, +-0.166794730195592680, -0.166745430405021960, -0.166696130197588550, -0.166646829573414780, -0.166597528532623970, -0.166548227075339340, -0.166498925201684130, -0.166449622911781610, +-0.166400320205754150, -0.166351017083726770, -0.166301713545821850, -0.166252409592162640, -0.166203105222872430, -0.166153800438074430, -0.166104495237891950, -0.166055189622448220, +-0.166005883591865630, -0.165956577146269210, -0.165907270285781370, -0.165857963010525330, -0.165808655320624390, -0.165759347216201810, -0.165710038697380880, -0.165660729764283950, +-0.165611420417036080, -0.165562110655759650, -0.165512800480577980, -0.165463489891614270, -0.165414178888991850, -0.165364867472833990, -0.165315555643263950, -0.165266243400404160, +-0.165216930744379630, -0.165167617675312770, -0.165118304193326850, -0.165068990298545190, -0.165019675991091050, -0.164970361271087720, -0.164921046138658490, -0.164871730593925760, +-0.164822414637014610, -0.164773098268047400, -0.164723781487147420, -0.164674464294438020, -0.164625146690042440, -0.164575828674084020, -0.164526510246685990, -0.164477191407970850, +-0.164427872158063560, -0.164378552497086630, -0.164329232425163310, -0.164279911942416900, -0.164230591048970730, -0.164181269744948070, -0.164131948030471350, -0.164082625905665640, +-0.164033303370653360, -0.163983980425557840, -0.163934657070502370, -0.163885333305610230, -0.163836009131004770, -0.163786684546809310, -0.163737359553146220, -0.163688034150140630, +-0.163638708337914970, -0.163589382116592520, -0.163540055486296630, -0.163490728447150570, -0.163441400999277730, -0.163392073142800490, -0.163342744877843950, -0.163293416204530530, +-0.163244087122983580, -0.163194757633326410, -0.163145427735682360, -0.163096097430174720, -0.163046766716926860, -0.162997435596061200, -0.162948104067702800, -0.162898772131974180, +-0.162849439788998600, -0.162800107038899440, -0.162750773881800010, -0.162701440317823630, -0.162652106347092790, -0.162602771969732550, -0.162553437185865370, -0.162504101995614630, +-0.162454766399103610, -0.162405430396455660, -0.162356093987794160, -0.162306757173242420, -0.162257419952922920, -0.162208082326960740, -0.162158744295478360, -0.162109405858599090, +-0.162060067016446320, -0.162010727769143410, -0.161961388116813650, -0.161912048059580430, -0.161862707597566210, -0.161813366730896110, -0.161764025459692570, -0.161714683784078990, +-0.161665341704178680, -0.161615999220115020, -0.161566656332011370, -0.161517313039991090, -0.161467969344176620, -0.161418625244693140, -0.161369280741663070, -0.161319935835209820, +-0.161270590525456700, -0.161221244812527110, -0.161171898696544440, -0.161122552177631110, -0.161073205255912290, -0.161023857931510470, -0.160974510204549000, -0.160925162075151230, +-0.160875813543440580, -0.160826464609540390, -0.160777115273574050, -0.160727765535664040, -0.160678415395935470, -0.160629064854510870, -0.160579713911513630, -0.160530362567067100, +-0.160481010821294650, -0.160431658674319660, -0.160382306126264670, -0.160332953177254790, -0.160283599827412530, -0.160234246076861260, -0.160184891925724380, -0.160135537374125250, +-0.160086182422187310, -0.160036827070033890, -0.159987471317787540, -0.159938115165573380, -0.159888758613513950, -0.159839401661732610, -0.159790044310352760, -0.159740686559497800, +-0.159691328409291120, -0.159641969859855270, -0.159592610911315350, -0.159543251563793900, -0.159493891817414330, -0.159444531672300020, -0.159395171128574400, -0.159345810186360850, +-0.159296448845782760, -0.159247087106962670, -0.159197724970025740, -0.159148362435094500, -0.159098999502292370, -0.159049636171742730, -0.159000272443568990, -0.158950908317894570, +-0.158901543794842890, -0.158852178874536480, -0.158802813557100490, -0.158753447842657460, -0.158704081731330830, -0.158654715223243980, -0.158605348318520330, -0.158555981017283330, +-0.158506613319656380, -0.158457245225761990, -0.158407876735725400, -0.158358507849669090, -0.158309138567716530, -0.158259768889991130, -0.158210398816616280, -0.158161028347715450, +-0.158111657483411160, -0.158062286223828620, -0.158012914569090360, -0.157963542519319820, -0.157914170074640430, -0.157864797235175570, -0.157815424001048750, -0.157766050372383390, +-0.157716676349302000, -0.157667301931929790, -0.157617927120389360, -0.157568551914804070, -0.157519176315297410, -0.157469800321992810, -0.157420423935013740, -0.157371047154482720, +-0.157321669980524940, -0.157272292413262990, -0.157222914452820330, -0.157173536099320360, -0.157124157352886540, -0.157074778213642350, -0.157025398681711230, -0.156976018757215700, +-0.156926638440281010, -0.156877257731029730, -0.156827876629585310, -0.156778495136071200, -0.156729113250610840, -0.156679730973327710, -0.156630348304344360, -0.156580965243786040, +-0.156531581791775290, -0.156482197948435570, -0.156432813713890400, -0.156383429088263170, -0.156334044071677340, -0.156284658664256420, -0.156235272866122990, -0.156185886677402240, +-0.156136500098216810, -0.156087113128690090, -0.156037725768945590, -0.155988338019106780, -0.155938949879297130, -0.155889561349640100, -0.155840172430258300, -0.155790783121276950, +-0.155741393422818620, -0.155692003335006820, -0.155642612857965020, -0.155593221991816660, -0.155543830736685260, -0.155494439092693420, -0.155445047059966340, -0.155395654638626670, +-0.155346261828797850, -0.155296868630603350, -0.155247475044166690, -0.155198081069611360, -0.155148686707060830, -0.155099291956637690, -0.155049896818467200, -0.155000501292671980, +-0.154951105379375480, -0.154901709078701240, -0.154852312390772740, -0.154802915315713410, -0.154753517853646830, -0.154704120004695580, -0.154654721768984900, -0.154605323146637410, +-0.154555924137776610, -0.154506524742526020, -0.154457124961009080, -0.154407724793349350, -0.154358324239669440, -0.154308923300094600, -0.154259521974747430, -0.154210120263751470, +-0.154160718167230200, -0.154111315685307140, -0.154061912818105800, -0.154012509565749660, -0.153963105928361380, -0.153913701906066210, -0.153864297498986780, -0.153814892707246630, +-0.153765487530969220, -0.153716081970278080, -0.153666676025296770, -0.153617269696147890, -0.153567862982956690, -0.153518455885845840, -0.153469048404938860, -0.153419640540359250, +-0.153370232292230540, -0.153320823660676260, -0.153271414645819920, -0.153222005247784150, -0.153172595466694260, -0.153123185302672880, -0.153073774755843520, -0.153024363826329750, +-0.152974952514255050, -0.152925540819742970, -0.152876128742917030, -0.152826716283899900, -0.152777303442816870, -0.152727890219790580, -0.152678476614944550, -0.152629062628402340, +-0.152579648260287470, -0.152530233510723480, -0.152480818379833020, -0.152431402867741400, -0.152381986974571280, -0.152332570700446170, -0.152283154045489640, -0.152233737009825230, +-0.152184319593576510, -0.152134901796866950, -0.152085483619819270, -0.152036065062558760, -0.151986646125208070, -0.151937226807890790, -0.151887807110730440, -0.151838387033850550, +-0.151788966577374700, -0.151739545741426450, -0.151690124526128460, -0.151640702931606000, -0.151591280957981830, -0.151541858605379410, -0.151492435873922390, -0.151443012763734260, +-0.151393589274938590, -0.151344165407658080, -0.151294741162018020, -0.151245316538141130, -0.151195891536150930, -0.151146466156171030, -0.151097040398324920, -0.151047614262736250, +-0.150998187749528530, -0.150948760858824440, -0.150899333590749360, -0.150849905945425910, -0.150800477922977740, -0.150751049523528330, -0.150701620747201340, -0.150652191594120270, +-0.150602762064407840, -0.150553332158189390, -0.150503901875587630, -0.150454471216726090, -0.150405040181728370, -0.150355608770718070, -0.150306176983818730, -0.150256744821153950, +-0.150207312282846450, -0.150157879369021530, -0.150108446079801920, -0.150059012415311170, -0.150009578375672910, -0.149960143961010710, -0.149910709171448140, -0.149861274007108800, +-0.149811838468115380, -0.149762402554593280, -0.149712966266665140, -0.149663529604454610, -0.149614092568085220, -0.149564655157680640, -0.149515217373364400, -0.149465779215259250, +-0.149416340683490520, -0.149366901778180930, -0.149317462499454100, -0.149268022847433600, -0.149218582822243070, -0.149169142424006060, -0.149119701652846190, -0.149070260508886190, +-0.149020818992251450, -0.148971377103064630, -0.148921934841449360, -0.148872492207529270, -0.148823049201427940, -0.148773605823269010, -0.148724162073176040, -0.148674717951271800, +-0.148625273457681640, -0.148575828592528300, -0.148526383355935380, -0.148476937748026510, -0.148427491768925310, -0.148378045418755350, -0.148328598697639400, -0.148279151605702850, +-0.148229704143068410, -0.148180256309859730, -0.148130808106200380, -0.148081359532214020, -0.148031910588024260, -0.147982461273754720, -0.147933011589528180, -0.147883561535469940, +-0.147834111111702830, -0.147784660318350440, -0.147735209155536400, -0.147685757623384320, -0.147636305722017860, -0.147586853451559750, -0.147537400812135400, -0.147487947803867540, +-0.147438494426879780, -0.147389040681295820, -0.147339586567239250, -0.147290132084833710, -0.147240677234202870, -0.147191222015469410, -0.147141766428758810, -0.147092310474193770, +-0.147042854151897970, -0.146993397461995020, -0.146943940404608590, -0.146894482979862300, -0.146845025187879810, -0.146795567028783880, -0.146746108502699900, -0.146696649609750650, +-0.146647190350059770, -0.146597730723750930, -0.146548270730947760, -0.146498810371773920, -0.146449349646352170, -0.146399888554807900, -0.146350427097263950, -0.146300965273843900, +-0.146251503084671440, -0.146202040529870240, -0.146152577609563930, -0.146103114323876180, -0.146053650672929770, -0.146004186656850110, -0.145954722275759950, -0.145905257529783030, +-0.145855792419042950, -0.145806326943663380, -0.145756861103768010, -0.145707394899480480, -0.145657928330923560, -0.145608461398222730, -0.145558994101500750, -0.145509526440881250, +-0.145460058416487960, -0.145410590028444530, -0.145361121276874620, -0.145311652161901010, -0.145262182683649150, -0.145212712842241850, -0.145163242637802750, -0.145113772070455560, +-0.145064301140323950, -0.145014829847531560, -0.144965358192202100, -0.144915886174458390, -0.144866413794425830, -0.144816941052227230, -0.144767467947986280, -0.144717994481826650, +-0.144668520653872030, -0.144619046464246140, -0.144569571913071740, -0.144520097000474270, -0.144470621726576600, -0.144421146091502330, -0.144371670095375220, -0.144322193738318920, +-0.144272717020457160, -0.144223239941913580, -0.144173762502811050, -0.144124284703274960, -0.144074806543428190, -0.144025328023394380, -0.143975849143297250, -0.143926369903260520, +-0.143876890303407860, -0.143827410343862950, -0.143777930024748650, -0.143728449346190420, -0.143678968308311030, -0.143629486911234260, -0.143580005155083760, -0.143530523039983230, +-0.143481040566056400, -0.143431557733426080, -0.143382074542217770, -0.143332590992554270, -0.143283107084559270, -0.143233622818356530, -0.143184138194069720, -0.143134653211822560, +-0.143085167871738780, -0.143035682173941190, -0.142986196118555260, -0.142936709705703880, -0.142887222935510680, -0.142837735808099440, -0.142788248323593880, -0.142738760482117670, +-0.142689272283794580, -0.142639783728747440, -0.142590294817101700, -0.142540805548980220, -0.142491315924506730, -0.142441825943804940, -0.142392335606998630, -0.142342844914211420, +-0.142293353865566270, -0.142243862461188590, -0.142194370701201250, -0.142144878585728000, -0.142095386114892530, -0.142045893288818610, -0.141996400107629960, -0.141946906571450320, +-0.141897412680402510, -0.141847918434612060, -0.141798423834201800, -0.141748928879295490, -0.141699433570016850, -0.141649937906489640, -0.141600441888837580, -0.141550945517183530, +-0.141501448791653020, -0.141451951712368850, -0.141402454279454830, -0.141352956493034670, -0.141303458353232100, -0.141253959860170920, -0.141204461013974820, -0.141154961814766670, +-0.141105462262672010, -0.141055962357813700, -0.141006462100315480, -0.140956961490301120, -0.140907460527894320, -0.140857959213218890, -0.140808457546398590, -0.140758955527556240, +-0.140709453156817380, -0.140659950434304880, -0.140610447360142500, -0.140560943934454010, -0.140511440157363170, -0.140461936028993730, -0.140412431549468560, -0.140362926718913180, +-0.140313421537450520, -0.140263916005204270, -0.140214410122298240, -0.140164903888856190, -0.140115397305001890, -0.140065890370859090, -0.140016383086550680, -0.139966875452202180, +-0.139917367467936510, -0.139867859133877420, -0.139818350450148680, -0.139768841416874040, -0.139719332034177330, -0.139669822302182280, -0.139620312221011790, -0.139570801790791400, +-0.139521291011644010, -0.139471779883693390, -0.139422268407063320, -0.139372756581877560, -0.139323244408259940, -0.139273731886333320, -0.139224219016223260, -0.139174705798052630, +-0.139125192231945250, -0.139075678318024860, -0.139026164056415300, -0.138976649447240340, -0.138927134490623740, -0.138877619186688420, -0.138828103535559970, -0.138778587537361220, +-0.138729071192216000, -0.138679554500248130, -0.138630037461581370, -0.138580520076339500, -0.138531002344645440, -0.138481484266624770, -0.138431965842400390, -0.138382447072096100, +-0.138332927955835680, -0.138283408493742960, -0.138233888685941690, -0.138184368532555720, -0.138134848033707960, -0.138085327189523930, -0.138035806000126600, -0.137986284465639760, +-0.137936762586187200, -0.137887240361892730, -0.137837717792880150, -0.137788194879272410, -0.137738671621195070, -0.137689148018771050, -0.137639624072124130, -0.137590099781378180, +-0.137540575146656960, -0.137491050168084330, -0.137441524845784060, -0.137391999179879100, -0.137342473170495030, -0.137292946817754750, -0.137243420121782120, -0.137193893082700940, +-0.137144365700635010, -0.137094837975708210, -0.137045309908044280, -0.136995781497766200, -0.136946252744999550, -0.136896723649867270, -0.136847194212493170, -0.136797664433001090, +-0.136748134311514860, -0.136698603848158300, -0.136649073043055210, -0.136599541896328560, -0.136550010408103940, -0.136500478578504280, -0.136450946407653460, -0.136401413895675230, +-0.136351881042693500, -0.136302347848832050, -0.136252814314213850, -0.136203280438964510, -0.136153746223206950, -0.136104211667065020, -0.136054676770662570, -0.136005141534123440, +-0.135955605957571450, -0.135906070041130450, -0.135856533784923380, -0.135806997189075850, -0.135757460253710850, -0.135707922978952210, -0.135658385364923720, -0.135608847411749310, +-0.135559309119552750, -0.135509770488457050, -0.135460231518587800, -0.135410692210067960, -0.135361152563021420, -0.135311612577571960, -0.135262072253843510, -0.135212531591959840, +-0.135162990592044870, -0.135113449254221530, -0.135063907578615440, -0.135014365565349600, -0.134964823214547840, -0.134915280526334030, -0.134865737500832000, -0.134816194138165650, +-0.134766650438457920, -0.134717106401834430, -0.134667562028418200, -0.134618017318333030, -0.134568472271702850, -0.134518926888651500, -0.134469381169302790, -0.134419835113780670, +-0.134370288722208050, -0.134320741994710590, -0.134271194931411290, -0.134221647532433990, -0.134172099797902590, -0.134122551727940940, -0.134073003322672880, -0.134023454582222340, +-0.133973905506712290, -0.133924356096268320, -0.133874806351013480, -0.133825256271071640, -0.133775705856566650, -0.133726155107622370, -0.133676604024362740, -0.133627052606911570, +-0.133577500855391910, -0.133527948769929380, -0.133478396350646960, -0.133428843597668540, -0.133379290511118050, -0.133329737091119310, -0.133280183337796230, -0.133230629251271800, +-0.133181074831671690, -0.133131520079118880, -0.133081964993737280, -0.133032409575650770, -0.132982853824983230, -0.132933297741858580, -0.132883741326400660, -0.132834184578732500, +-0.132784627498979790, -0.132735070087265480, -0.132685512343713510, -0.132635954268447760, -0.132586395861592130, -0.132536837123270500, -0.132487278053605880, -0.132437718652723970, +-0.132388158920747760, -0.132338598857801140, -0.132289038464008020, -0.132239477739492320, -0.132189916684377930, -0.132140355298788730, -0.132090793582847780, -0.132041231536680710, +-0.131991669160410580, -0.131942106454161270, -0.131892543418056700, -0.131842980052220750, -0.131793416356777350, -0.131743852331849540, -0.131694287977563000, -0.131644723294040730, +-0.131595158281406640, -0.131545592939784660, -0.131496027269298680, -0.131446461270072650, -0.131396894942230450, -0.131347328285895150, -0.131297761301192420, -0.131248193988245250, +-0.131198626347177630, -0.131149058378113440, -0.131099490081176580, -0.131049921456491030, -0.131000352504180660, -0.130950783224368510, -0.130901213617180300, -0.130851643682739050, +-0.130802073421168700, -0.130752502832593150, -0.130702931917136360, -0.130653360674922230, -0.130603789106074700, -0.130554217210716830, -0.130504644988974290, -0.130455072440970130, +-0.130405499566828290, -0.130355926366672700, -0.130306352840627300, -0.130256778988816020, -0.130207204811361920, -0.130157630308390670, -0.130108055480025350, -0.130058480326389890, +-0.130008904847608240, -0.129959329043804310, -0.129909752915102070, -0.129860176461625450, -0.129810599683497510, -0.129761022580843930, -0.129711445153787820, -0.129661867402453080, +-0.129612289326963700, -0.129562710927443560, -0.129513132204016670, -0.129463553156806050, -0.129413973785937410, -0.129364394091533890, -0.129314814073719340, -0.129265233732617780, +-0.129215653068353110, -0.129166072081049330, -0.129116490770830370, -0.129066909137819290, -0.129017327182141820, -0.128967744903921040, -0.128918162303280880, -0.128868579380345320, +-0.128818996135238340, -0.128769412568083830, -0.128719828679004940, -0.128670244468127330, -0.128620659935574140, -0.128571075081469280, -0.128521489905936730, -0.128471904409100470, +-0.128422318591084440, -0.128372732452012610, -0.128323145992008090, -0.128273559211196570, -0.128223972109701130, -0.128174384687645780, -0.128124796945154470, -0.128075208882351160, +-0.128025620499359840, -0.127976031796304480, -0.127926442773308140, -0.127876853430496570, -0.127827263767992890, -0.127777673785921030, -0.127728083484404980, -0.127678492863568720, +-0.127628901923536240, -0.127579310664431510, -0.127529719086377610, -0.127480127189500300, -0.127430534973922680, -0.127380942439768720, -0.127331349587162380, -0.127281756416227710, +-0.127232162927088610, -0.127182569119868250, -0.127132974994692340, -0.127083380551683970, -0.127033785790967160, -0.126984190712665900, -0.126934595316904150, -0.126884999603805920, +-0.126835403573495180, -0.126785807226095060, -0.126736210561731290, -0.126686613580527020, -0.126637016282606210, -0.126587418668092840, -0.126537820737110920, -0.126488222489784470, +-0.126438623926236560, -0.126389025046593000, -0.126339425850976850, -0.126289826339512160, -0.126240226512322890, -0.126190626369533040, -0.126141025911266660, -0.126091425137647680, +-0.126041824048799270, -0.125992222644847190, -0.125942620925914540, -0.125893018892125340, -0.125843416543603620, -0.125793813880473340, -0.125744210902858510, -0.125694607610882280, +-0.125645004004670410, -0.125595400084346030, -0.125545795850033170, -0.125496191301855800, -0.125446586439937950, -0.125396981264403630, -0.125347375775376880, -0.125297769972980780, +-0.125248163857341170, -0.125198557428581130, -0.125148950686824690, -0.125099343632195910, -0.125049736264818720, -0.125000128584817210, -0.124950520592315400, -0.124900912287436380, +-0.124851303670305970, -0.124801694741047310, -0.124752085499784410, -0.124702475946641290, -0.124652866081741980, -0.124603255905210500, -0.124553645417170000, -0.124504034617746270, +-0.124454423507062470, -0.124404812085242590, -0.124355200352410680, -0.124305588308690790, -0.124255975954206910, -0.124206363289083090, -0.124156750313442490, -0.124107137027410900, +-0.124057523431111450, -0.124007909524668210, -0.123958295308205180, -0.123908680781846430, -0.123859065945715950, -0.123809450799937830, -0.123759835344635190, -0.123710219579933850, +-0.123660603505956960, -0.123610987122828560, -0.123561370430672700, -0.123511753429613400, -0.123462136119774720, -0.123412518501279820, -0.123362900574254500, -0.123313282338821940, +-0.123263663795106170, -0.123214044943231240, -0.123164425783321190, -0.123114806315500090, -0.123065186539891970, -0.123015566456620000, -0.122965946065809990, -0.122916325367585120, +-0.122866704362069440, -0.122817083049386990, -0.122767461429661840, -0.122717839503018040, -0.122668217269578740, -0.122618594729469800, -0.122568971882814360, -0.122519348729736510, +-0.122469725270360260, -0.122420101504809710, -0.122370477433208920, -0.122320853055681920, -0.122271228372351910, -0.122221603383344720, -0.122171978088783490, -0.122122352488792340, +-0.122072726583495310, -0.122023100373016460, -0.121973473857479860, -0.121923847037009580, -0.121874219911728800, -0.121824592481763330, -0.121774964747236400, -0.121725336708272060, +-0.121675708364994380, -0.121626079717527410, -0.121576450765995260, -0.121526821510521090, -0.121477191951230750, -0.121427562088247430, -0.121377931921695200, -0.121328301451698150, +-0.121278670678380340, -0.121229039601865860, -0.121179408222278780, -0.121129776539742300, -0.121080144554382250, -0.121030512266321850, -0.120980879675685160, -0.120931246782596270, +-0.120881613587179280, -0.120831980089558240, -0.120782346289857250, -0.120732712188199520, -0.120683077784710880, -0.120633443079514550, -0.120583808072734620, -0.120534172764495170, +-0.120484537154920290, -0.120434901244134060, -0.120385265032259690, -0.120335628519423050, -0.120285991705747330, -0.120236354591356630, -0.120186717176375050, -0.120137079460926680, +-0.120087441445135600, -0.120037803129125930, -0.119988164513020860, -0.119938525596946260, -0.119888886381025350, -0.119839246865382230, -0.119789607050140990, -0.119739966935425730, +-0.119690326521360550, -0.119640685808068680, -0.119591044795675960, -0.119541403484305640, -0.119491761874081820, -0.119442119965128590, -0.119392477757570060, -0.119342835251530330, +-0.119293192447133520, -0.119243549344502830, -0.119193905943764170, -0.119144262245040720, -0.119094618248456640, -0.119044973954136000, -0.118995329362202930, -0.118945684472781530, +-0.118896039285995930, -0.118846393801969350, -0.118796748020827670, -0.118747101942694100, -0.118697455567692790, -0.118647808895947840, -0.118598161927583360, -0.118548514662723480, +-0.118498867101491430, -0.118449219244013110, -0.118399571090411730, -0.118349922640811410, -0.118300273895336300, -0.118250624854110500, -0.118200975517258140, -0.118151325884903350, +-0.118101675957169350, -0.118052025734182040, -0.118002375216064670, -0.117952724402941370, -0.117903073294936250, -0.117853421892173450, -0.117803770194777100, -0.117754118202871310, +-0.117704465916579350, -0.117654813336027110, -0.117605160461337840, -0.117555507292635660, -0.117505853830044720, -0.117456200073689130, -0.117406546023693060, -0.117356891680179740, +-0.117307237043275060, -0.117257582113102300, -0.117207926889785580, -0.117158271373449040, -0.117108615564216830, -0.117058959462213060, -0.117009303067561910, -0.116959646380386630, +-0.116909989400813100, -0.116860332128964600, -0.116810674564965260, -0.116761016708939250, -0.116711358561010680, -0.116661700121303740, -0.116612041389941650, -0.116562382367050340, +-0.116512723052753080, -0.116463063447174000, -0.116413403550437280, -0.116363743362667030, -0.116314082883987440, -0.116264422114522630, -0.116214761054395890, -0.116165099703733120, +-0.116115438062657620, -0.116065776131293500, -0.116016113909764960, -0.115966451398196130, -0.115916788596711170, -0.115867125505434240, -0.115817462124488610, -0.115767798454000200, +-0.115718134494092310, -0.115668470244889080, -0.115618805706514670, -0.115569140879093240, -0.115519475762748970, -0.115469810357605120, -0.115420144663787640, -0.115370478681419780, +-0.115320812410625740, -0.115271145851529660, -0.115221479004255710, -0.115171811868928070, -0.115122144445670900, -0.115072476734607480, -0.115022808735863760, -0.114973140449563010, +-0.114923471875829420, -0.114873803014787140, -0.114824133866560360, -0.114774464431273250, -0.114724794709049960, -0.114675124700013810, -0.114625454404290730, -0.114575783822004020, +-0.114526112953277840, -0.114476441798236390, -0.114426770357003830, -0.114377098629704340, -0.114327426616461230, -0.114277754317400430, -0.114228081732645250, -0.114178408862319860, +-0.114128735706548450, -0.114079062265455190, -0.114029388539164290, -0.113979714527799910, -0.113930040231485370, -0.113880365650346610, -0.113830690784506930, -0.113781015634090530, +-0.113731340199221580, -0.113681664480024290, -0.113631988476622830, -0.113582312189140530, -0.113532635617703310, -0.113482958762434510, -0.113433281623458320, -0.113383604200898940, +-0.113333926494880530, -0.113284248505527300, -0.113234570232963460, -0.113184891677312300, -0.113135212838699800, -0.113085533717249280, -0.113035854313084910, -0.112986174626330910, +-0.112936494657111470, -0.112886814405550790, -0.112837133871773090, -0.112787453055901650, -0.112737771958062480, -0.112688090578378880, -0.112638408916975030, -0.112588726973975180, +-0.112539044749503510, -0.112489362243684220, -0.112439679456640660, -0.112389996388498770, -0.112340313039381880, -0.112290629409414210, -0.112240945498719980, -0.112191261307423380, +-0.112141576835648630, -0.112091892083519940, -0.112042207051160620, -0.111992521738696680, -0.111942836146251430, -0.111893150273949100, -0.111843464121913890, -0.111793777690270020, +-0.111744090979141700, -0.111694403988653160, -0.111644716718927710, -0.111595029170091370, -0.111545341342267440, -0.111495653235580180, -0.111445964850153780, -0.111396276186112450, +-0.111346587243580440, -0.111296898022681080, -0.111247208523540360, -0.111197518746281630, -0.111147828691029090, -0.111098138357906970, -0.111048447747039520, -0.110998756858550940, +-0.110949065692565480, -0.110899374249206460, -0.110849682528599890, -0.110799990530869110, -0.110750298256138370, -0.110700605704531870, -0.110650912876173860, -0.110601219771188570, +-0.110551526389699340, -0.110501832731832190, -0.110452138797710440, -0.110402444587458360, -0.110352750101200160, -0.110303055339060080, -0.110253360301162380, -0.110203664987631260, +-0.110153969398590110, -0.110104273534164910, -0.110054577394479030, -0.110004880979656700, -0.109955184289822180, -0.109905487325099690, -0.109855790085613480, -0.109806092571487800, +-0.109756394782846000, -0.109706696719814100, -0.109656998382515470, -0.109607299771074320, -0.109557600885614950, -0.109507901726261560, -0.109458202293138410, -0.109408502586368870, +-0.109358802606078970, -0.109309102352392070, -0.109259401825432400, -0.109209701025324220, -0.109159999952191790, -0.109110298606159370, -0.109060596987351200, -0.109010895095890650, +-0.108961192931903760, -0.108911490495513870, -0.108861787786845260, -0.108812084806022180, -0.108762381553168890, -0.108712678028409640, -0.108662974231868710, -0.108613270163669450, +-0.108563565823937900, -0.108513861212797440, -0.108464156330372320, -0.108414451176786820, -0.108364745752165180, -0.108315040056631670, -0.108265334090309700, -0.108215627853325250, +-0.108165921345801750, -0.108116214567863440, -0.108066507519634590, -0.108016800201239480, -0.107967092612802370, -0.107917384754447520, -0.107867676626298330, -0.107817968228480830, +-0.107768259561118410, -0.107718550624335340, -0.107668841418255890, -0.107619131943004350, -0.107569422198704970, -0.107519712185481150, -0.107470001903458940, -0.107420291352761710, +-0.107370580533513770, -0.107320869445839360, -0.107271158089862800, -0.107221446465708330, -0.107171734573500250, -0.107122022413361940, -0.107072309985419470, -0.107022597289796210, +-0.106972884326616470, -0.106923171096004520, -0.106873457598084640, -0.106823743832981110, -0.106774029800818220, -0.106724315501719390, -0.106674600935810630, -0.106624886103215380, +-0.106575171004057920, -0.106525455638462520, -0.106475740006553490, -0.106426024108455100, -0.106376307944290770, -0.106326591514186570, -0.106276874818265880, -0.106227157856653000, +-0.106177440629472220, -0.106127723136847850, -0.106078005378904160, -0.106028287355765470, -0.105978569067555180, -0.105928850514399330, -0.105879131696421370, -0.105829412613745580, +-0.105779693266496260, -0.105729973654797690, -0.105680253778774210, -0.105630533638550090, -0.105580813234248740, -0.105531092565996240, -0.105481371633916020, -0.105431650438132370, +-0.105381928978769590, -0.105332207255951990, -0.105282485269803870, -0.105232763020448660, -0.105183040508012420, -0.105133317732618580, -0.105083594694391440, -0.105033871393455320, +-0.104984147829934520, -0.104934424003953350, -0.104884699915636120, -0.104834975565106250, -0.104785250952489830, -0.104735526077910280, -0.104685800941491940, -0.104636075543359060, +-0.104586349883636020, -0.104536623962447090, -0.104486897779915710, -0.104437171336167990, -0.104387444631327330, -0.104337717665518050, -0.104287990438864500, -0.104238262951490950, +-0.104188535203521750, -0.104138807195081210, -0.104089078926292780, -0.104039350397282530, -0.103989621608173900, -0.103939892559091220, -0.103890163250158800, -0.103840433681500990, +-0.103790703853242090, -0.103740973765506410, -0.103691243418417430, -0.103641512812101220, -0.103591781946681240, -0.103542050822281790, -0.103492319439027220, -0.103442587797041850, +-0.103392855896450020, -0.103343123737375160, -0.103293391319943360, -0.103243658644278090, -0.103193925710503680, -0.103144192518744460, -0.103094459069124750, -0.103044725361768900, +-0.102994991396801220, -0.102945257174345190, -0.102895522694526900, -0.102845787957469810, -0.102796052963298230, -0.102746317712136530, -0.102696582204109040, -0.102646846439340090, +-0.102597110417953150, -0.102547374140074300, -0.102497637605827030, -0.102447900815335650, -0.102398163768724530, -0.102348426466118000, -0.102298688907640410, -0.102248951093416090, +-0.102199213023568510, -0.102149474698223770, -0.102099736117505350, -0.102049997281537600, -0.102000258190444850, -0.101950518844351450, -0.101900779243381760, -0.101851039387660120, +-0.101801299277309990, -0.101751558912457500, -0.101701818293226120, -0.101652077419740190, -0.101602336292124060, -0.101552594910502100, -0.101502853274998650, -0.101453111385737180, +-0.101403369242843820, -0.101353626846442030, -0.101303884196656170, -0.101254141293610610, -0.101204398137429690, -0.101154654728237790, -0.101104911066159240, -0.101055167151317530, +-0.101005422983838790, -0.100955678563846480, -0.100905933891464970, -0.100856188966818650, -0.100806443790031840, -0.100756698361228930, -0.100706952680533380, -0.100657206748071340, +-0.100607460563966290, -0.100557714128342570, -0.100507967441324580, -0.100458220503036650, -0.100408473313603200, -0.100358725873148550, -0.100308978181796200, -0.100259230239672290, +-0.100209482046900310, -0.100159733603604610, -0.100109984909909590, -0.100060235965939600, -0.100010486771819030, -0.099960737327672244, -0.099910987633622717, -0.099861237689796614, +-0.099811487496317422, -0.099761737053309499, -0.099711986360897231, -0.099662235419205006, -0.099612484228357195, -0.099562732788477284, -0.099512981099691436, -0.099463229162123121, +-0.099413476975896739, -0.099363724541136664, -0.099313971857967281, -0.099264218926512965, -0.099214465746898101, -0.099164712319246187, -0.099114958643683387, -0.099065204720333172, +-0.099015450549319955, -0.098965696130768124, -0.098915941464802037, -0.098866186551546095, -0.098816431391124698, -0.098766675983661331, -0.098716920329282157, -0.098667164428110687, +-0.098617408280271310, -0.098567651885888397, -0.098517895245086362, -0.098468138357989593, -0.098418381224721602, -0.098368623845408523, -0.098318866220173898, -0.098269108349142098, +-0.098219350232437538, -0.098169591870184592, -0.098119833262507672, -0.098070074409531166, -0.098020315311378586, -0.097970555968176110, -0.097920796380047248, -0.097871036547116388, +-0.097821276469507931, -0.097771516147346291, -0.097721755580755867, -0.097671994769860160, -0.097622233714785345, -0.097572472415654962, -0.097522710872593385, -0.097472949085725027, +-0.097423187055174304, -0.097373424781065615, -0.097323662263523361, -0.097273899502671082, -0.097224136498634914, -0.097174373251538423, -0.097124609761505984, -0.097074846028662037, +-0.097025082053130970, -0.096975317835037184, -0.096925553374505119, -0.096875788671658289, -0.096826023726622856, -0.096776258539522375, -0.096726493110481246, -0.096676727439623883, +-0.096626961527074701, -0.096577195372958113, -0.096527428977397647, -0.096477662340519507, -0.096427895462447205, -0.096378128343305169, -0.096328360983217801, -0.096278593382309541, +-0.096228825540704790, -0.096179057458527978, -0.096129289135902643, -0.096079520572954963, -0.096029751769808491, -0.095979982726587629, -0.095930213443416817, -0.095880443920420458, +-0.095830674157723006, -0.095780904155448862, -0.095731133913721581, -0.095681363432667338, -0.095631592712409688, -0.095581821753073060, -0.095532050554781880, -0.095482279117660565, +-0.095432507441833556, -0.095382735527424392, -0.095332963374559279, -0.095283190983361757, -0.095233418353956253, -0.095183645486467211, -0.095133872381019058, -0.095084099037736208, +-0.095034325456743118, -0.094984551638163342, -0.094934777582123056, -0.094885003288745828, -0.094835228758156101, -0.094785453990478288, -0.094735678985836846, -0.094685903744356217, +-0.094636128266159941, -0.094586352551374223, -0.094536576600122615, -0.094486800412529576, -0.094437023988719532, -0.094387247328816939, -0.094337470432946213, -0.094287693301231823, +-0.094237915933797309, -0.094188138330768889, -0.094138360492270132, -0.094088582418425465, -0.094038804109359345, -0.093989025565196213, -0.093939246786060512, -0.093889467772076698, +-0.093839688523368339, -0.093789909040061625, -0.093740129322280152, -0.093690349370148363, -0.093640569183790684, -0.093590788763331587, -0.093541008108895526, -0.093491227220606057, +-0.093441446098589398, -0.093391664742969130, -0.093341883153869695, -0.093292101331415550, -0.093242319275731164, -0.093192536986940966, -0.093142754465169439, -0.093092971710540137, +-0.093043188723179279, -0.092993405503210461, -0.092943622050758123, -0.092893838365946738, -0.092844054448900759, -0.092794270299744630, -0.092744485918602834, -0.092694701305598939, +-0.092644916460859178, -0.092595131384507118, -0.092545346076667229, -0.092495560537463981, -0.092445774767021829, -0.092395988765465245, -0.092346202532917795, -0.092296416069505727, +-0.092246629375352621, -0.092196842450582947, -0.092147055295321162, -0.092097267909691735, -0.092047480293819137, -0.091997692447827850, -0.091947904371841443, -0.091898116065986149, +-0.091848327530385576, -0.091798538765164181, -0.091748749770446433, -0.091698960546356817, -0.091649171093019802, -0.091599381410558969, -0.091549591499100580, -0.091499801358768201, +-0.091450010989686317, -0.091400220391979412, -0.091350429565771940, -0.091300638511188414, -0.091250847228353291, -0.091201055717390150, -0.091151263978425268, -0.091101472011582224, +-0.091051679816985490, -0.091001887394759562, -0.090952094745028925, -0.090902301867918034, -0.090852508763551401, -0.090802715432052608, -0.090752921873547915, -0.090703128088160917, +-0.090653334076016098, -0.090603539837237942, -0.090553745371950933, -0.090503950680279555, -0.090454155762347430, -0.090404360618280791, -0.090354565248203261, -0.090304769652239311, +-0.090254973830513438, -0.090205177783150126, -0.090155381510273871, -0.090105585012009173, -0.090055788288479613, -0.090005991339811478, -0.089956194166128350, -0.089906396767554755, +-0.089856599144215163, -0.089806801296234057, -0.089757003223735962, -0.089707204926845363, -0.089657406405685855, -0.089607607660383726, -0.089557808691062571, -0.089508009497846902, +-0.089458210080861203, -0.089408410440229985, -0.089358610576077732, -0.089308810488528081, -0.089259010177707279, -0.089209209643738949, -0.089159408886747601, -0.089109607906857721, +-0.089059806704193833, -0.089010005278880422, -0.088960203631041998, -0.088910401760802185, -0.088860599668287257, -0.088810797353620824, -0.088760994816927397, -0.088711192058331473, +-0.088661389077957578, -0.088611585875930210, -0.088561782452372992, -0.088511978807412212, -0.088462174941171479, -0.088412370853775304, -0.088362566545348201, -0.088312762016014679, +-0.088262957265899264, -0.088213152295126454, -0.088163347103819872, -0.088113541692105807, -0.088063736060107894, -0.088013930207950633, -0.087964124135758548, -0.087914317843656165, +-0.087864511331767967, -0.087814704600218507, -0.087764897649131396, -0.087715090478632921, -0.087665283088846732, -0.087615475479897315, -0.087565667651909221, -0.087515859605006963, +-0.087466051339315051, -0.087416242854957124, -0.087366434152059483, -0.087316625230745751, -0.087266816091140453, -0.087217006733368116, -0.087167197157553264, -0.087117387363820423, +-0.087067577352294104, -0.087017767123097972, -0.086967956676358288, -0.086918146012198730, -0.086868335130743796, -0.086818524032118025, -0.086768712716445942, -0.086718901183852087, +-0.086669089434460972, -0.086619277468396247, -0.086569465285784214, -0.086519652886748524, -0.086469840271413703, -0.086420027439904276, -0.086370214392344782, -0.086320401128859747, +-0.086270587649572822, -0.086220773954610322, -0.086170960044095885, -0.086121145918154049, -0.086071331576909341, -0.086021517020486313, -0.085971702249009491, -0.085921887262603414, +-0.085872072061391733, -0.085822256645500750, -0.085772441015054129, -0.085722625170176411, -0.085672809110992121, -0.085622992837625811, -0.085573176350202021, -0.085523359648844402, +-0.085473542733679284, -0.085423725604830289, -0.085373908262421999, -0.085324090706578926, -0.085274272937425621, -0.085224454955086640, -0.085174636759686520, -0.085124818351348927, +-0.085074999730200176, -0.085025180896363919, -0.084975361849964723, -0.084925542591127098, -0.084875723119975641, -0.084825903436634861, -0.084776083541229327, -0.084726263433882704, +-0.084676443114721306, -0.084626622583868785, -0.084576801841449722, -0.084526980887588657, -0.084477159722410128, -0.084427338346038716, -0.084377516758598059, -0.084327694960214500, +-0.084277872951011704, -0.084228050731114223, -0.084178228300646626, -0.084128405659733438, -0.084078582808499253, -0.084028759747068610, -0.083978936475565175, -0.083929112994115290, +-0.083879289302842622, -0.083829465401871722, -0.083779641291327173, -0.083729816971333512, -0.083679992442015308, -0.083630167703497127, -0.083580342755902634, -0.083530517599358173, +-0.083480692233987422, -0.083430866659914935, -0.083381040877265292, -0.083331214886163033, -0.083281388686732738, -0.083231562279098101, -0.083181735663385423, -0.083131908839718424, +-0.083082081808221644, -0.083032254569019665, -0.082982427122237037, -0.082932599467998358, -0.082882771606428166, -0.082832943537650167, -0.082783115261790691, -0.082733286778973431, +-0.082683458089322953, -0.082633629192963826, -0.082583800090020629, -0.082533970780617943, -0.082484141264879435, -0.082434311542931446, -0.082384481614897698, -0.082334651480902743, +-0.082284821141071149, -0.082234990595527510, -0.082185159844396394, -0.082135328887802367, -0.082085497725869150, -0.082035666358723058, -0.081985834786487813, -0.081936003009287980, +-0.081886171027248142, -0.081836338840492864, -0.081786506449146743, -0.081736673853334357, -0.081686841053179401, -0.081637008048808232, -0.081587174840344542, -0.081537341427912913, +-0.081487507811637938, -0.081437673991644186, -0.081387839968056250, -0.081338005740997824, -0.081288171310595264, -0.081238336676972292, -0.081188501840253474, -0.081138666800563392, +-0.081088831558026653, -0.081038996112767839, -0.080989160464911517, -0.080939324614581420, -0.080889488561903894, -0.080839652307002657, -0.080789815850002278, -0.080739979191027364, +-0.080690142330202497, -0.080640305267652285, -0.080590468003501295, -0.080540630537873262, -0.080490792870894529, -0.080440955002688816, -0.080391116933380719, -0.080341278663094831, +-0.080291440191955749, -0.080241601520088052, -0.080191762647615475, -0.080141923574664375, -0.080092084301358474, -0.080042244827822351, -0.079992405154180629, -0.079942565280557876, +-0.079892725207078727, -0.079842884933867764, -0.079793044461048693, -0.079743203788747899, -0.079693362917089103, -0.079643521846196885, -0.079593680576195869, -0.079543839107210662, +-0.079493997439365846, -0.079444155572785155, -0.079394313507594960, -0.079344471243918982, -0.079294628781881829, -0.079244786121608096, -0.079194943263222406, -0.079145100206849353, +-0.079095256952613546, -0.079045413500638720, -0.078995569851051245, -0.078945726003974842, -0.078895881959534120, -0.078846037717853701, -0.078796193279058180, -0.078746348643272179, +-0.078696503810620308, -0.078646658781226286, -0.078596813555216513, -0.078546968132714695, -0.078497122513845469, -0.078447276698733429, -0.078397430687503197, -0.078347584480279384, +-0.078297738077185736, -0.078247891478348625, -0.078198044683891785, -0.078148197693939825, -0.078098350508617381, -0.078048503128049049, -0.077998655552359478, -0.077948807781673249, +-0.077898959816114124, -0.077849111655808489, -0.077799263300880064, -0.077749414751453486, -0.077699566007653376, -0.077649717069604343, -0.077599867937431025, -0.077550018611258043, +-0.077500169091209117, -0.077450319377410648, -0.077400469469986397, -0.077350619369060958, -0.077300769074758982, -0.077250918587205078, -0.077201067906523882, -0.077151217032839128, +-0.077101365966277216, -0.077051514706961879, -0.077001663255017769, -0.076951811610569493, -0.076901959773741702, -0.076852107744658990, -0.076802255523446022, -0.076752403110226533, +-0.076702550505126921, -0.076652697708270920, -0.076602844719783181, -0.076552991539788340, -0.076503138168411006, -0.076453284605775843, -0.076403430852006571, -0.076353576907229603, +-0.076303722771568702, -0.076253868445148490, -0.076204013928093617, -0.076154159220528692, -0.076104304322578378, -0.076054449234367313, -0.076004593956019231, -0.075954738487660545, +-0.075904882829415016, -0.075855026981407281, -0.075805170943761976, -0.075755314716603739, -0.075705458300057232, -0.075655601694247065, -0.075605744899297014, -0.075555887915333478, +-0.075506030742480232, -0.075456173380861899, -0.075406315830603143, -0.075356458091828601, -0.075306600164662910, -0.075256742049229816, -0.075206883745655775, -0.075157025254064508, +-0.075107166574580692, -0.075057307707328949, -0.075007448652433945, -0.074957589410020314, -0.074907729980212709, -0.074857870363134904, -0.074808010558913299, -0.074758150567671669, +-0.074708290389534665, -0.074658430024626923, -0.074608569473073122, -0.074558708734997883, -0.074508847810524997, -0.074458986699780877, -0.074409125402889284, -0.074359263919974883, +-0.074309402251162324, -0.074259540396576257, -0.074209678356341346, -0.074159816130582229, -0.074109953719422680, -0.074060091122989141, -0.074010228341405374, -0.073960365374796042, +-0.073910502223285796, -0.073860638886999286, -0.073810775366061177, -0.073760911660596132, -0.073711047770727928, -0.073661183696582991, -0.073611319438285083, -0.073561454995958897, +-0.073511590369729055, -0.073461725559720248, -0.073411860566057113, -0.073361995388863455, -0.073312130028265685, -0.073262264484387593, -0.073212398757353844, -0.073162532847289102, +-0.073112666754318018, -0.073062800478565268, -0.073012934020155518, -0.072963067379212557, -0.072913200555862798, -0.072863333550230044, -0.072813466362438961, -0.072763598992614212, +-0.072713731440880461, -0.072663863707362372, -0.072613995792183750, -0.072564127695471034, -0.072514259417347987, -0.072464390957939287, -0.072414522317369612, -0.072364653495763639, +-0.072314784493246020, -0.072264915309941447, -0.072215045945973694, -0.072165176401469230, -0.072115306676551805, -0.072065436771346122, -0.072015566685976848, -0.071965696420568659, +-0.071915825975246220, -0.071865955350134222, -0.071816084545356443, -0.071766213561039349, -0.071716342397306718, -0.071666471054283226, -0.071616599532093567, -0.071566727830862403, +-0.071516855950714414, -0.071466983891773403, -0.071417111654165824, -0.071367239238015454, -0.071317366643446997, -0.071267493870585119, -0.071217620919554511, -0.071167747790479852, +-0.071117874483485818, -0.071068000998696201, -0.071018127336237483, -0.070968253496233438, -0.070918379478808774, -0.070868505284088154, -0.070818630912196256, -0.070768756363257801, +-0.070718881637397438, -0.070669006734738998, -0.070619131655408923, -0.070569256399531016, -0.070519380967229969, -0.070469505358630474, -0.070419629573857223, -0.070369753613034880, +-0.070319877476287276, -0.070270001163740867, -0.070220124675519455, -0.070170248011747718, -0.070120371172550378, -0.070070494158052096, -0.070020616968377594, -0.069970739603651536, +-0.069920862063997752, -0.069870984349542697, -0.069821106460410176, -0.069771228396724894, -0.069721350158611542, -0.069671471746194813, -0.069621593159599399, -0.069571714398949117, +-0.069521835464370449, -0.069471956355987172, -0.069422077073924018, -0.069372197618305667, -0.069322317989256824, -0.069272438186902180, -0.069222558211366456, -0.069172678062773441, +-0.069122797741249617, -0.069072917246918789, -0.069023036579905675, -0.068973155740334968, -0.068923274728331374, -0.068873393544019598, -0.068823512187524333, -0.068773630658969409, +-0.068723748958481282, -0.068673867086183796, -0.068623985042201630, -0.068574102826659503, -0.068524220439682121, -0.068474337881394190, -0.068424455151919528, -0.068374572251384616, +-0.068324689179913273, -0.068274805937630204, -0.068224922524660128, -0.068175038941127739, -0.068125155187157754, -0.068075271262874881, -0.068025387168402937, -0.067975502903868418, +-0.067925618469395141, -0.067875733865107812, -0.067825849091131152, -0.067775964147589879, -0.067726079034608686, -0.067676193752312291, -0.067626308300824542, -0.067576422680271891, +-0.067526536890778199, -0.067476650932468157, -0.067426764805466485, -0.067376878509897903, -0.067326992045887130, -0.067277105413557983, -0.067227218613036960, -0.067177331644447891, +-0.067127444507915496, -0.067077557203564481, -0.067027669731519579, -0.066977782091905511, -0.066927894284846981, -0.066878006310467822, -0.066828118168894543, -0.066778229860250962, +-0.066728341384661813, -0.066678452742251801, -0.066628563933145674, -0.066578674957468123, -0.066528785815342995, -0.066478896506896798, -0.066429007032253365, -0.066379117391537401, +-0.066329227584873654, -0.066279337612386829, -0.066229447474201661, -0.066179557170442882, -0.066129666701234324, -0.066079776066702484, -0.066029885266971192, -0.065979994302165196, +-0.065930103172409216, -0.065880211877827985, -0.065830320418546209, -0.065780428794688636, -0.065730537006379111, -0.065680645053744130, -0.065630752936907524, -0.065580860655994055, +-0.065530968211128415, -0.065481075602435365, -0.065431182830039625, -0.065381289894065039, -0.065331396794638119, -0.065281503531882709, -0.065231610105923529, -0.065181716516885341, +-0.065131822764892849, -0.065081928850070803, -0.065032034772543934, -0.064982140532436089, -0.064932246129873777, -0.064882351564980859, -0.064832456837882066, -0.064782561948702119, +-0.064732666897565766, -0.064682771684597754, -0.064632876309922815, -0.064582980773664783, -0.064533085075950208, -0.064483189216902909, -0.064433293196647631, -0.064383397015309124, +-0.064333500673012134, -0.064283604169881381, -0.064233707506040738, -0.064183810681616701, -0.064133913696733144, -0.064084016551514814, -0.064034119246086429, -0.063984221780572753, +-0.063934324155098518, -0.063884426369788472, -0.063834528424766473, -0.063784630320159047, -0.063734732056090038, -0.063684833632684207, -0.063634935050066274, -0.063585036308361029, +-0.063535137407693176, -0.063485238348186590, -0.063435339129967808, -0.063385439753160674, -0.063335540217889938, -0.063285640524280345, -0.063235740672456658, -0.063185840662543624, +-0.063135940494665976, -0.063086040168947602, -0.063036139685515011, -0.062986239044492076, -0.062936338246003531, -0.062886437290174152, -0.062836536177128671, -0.062786634906991851, +-0.062736733479888451, -0.062686831895942319, -0.062636930155280005, -0.062587028258025354, -0.062537126204303142, -0.062487223994238117, -0.062437321627955025, -0.062387419105578629, +-0.062337516427232800, -0.062287613593044071, -0.062237710603136306, -0.062187807457634262, -0.062137904156662697, -0.062088000700346375, -0.062038097088810050, -0.061988193322178489, +-0.061938289400575552, -0.061888385324127777, -0.061838481092959037, -0.061788576707194100, -0.061738672166957720, -0.061688767472374659, -0.061638862623569678, -0.061588957620667538, +-0.061539052463792127, -0.061489147153069960, -0.061439241688624933, -0.061389336070581800, -0.061339430299065328, -0.061289524374200273, -0.061239618296111416, -0.061189712064922623, +-0.061139805680760433, -0.061089899143748738, -0.061039992454012287, -0.060990085611675855, -0.060940178616864217, -0.060890271469702120, -0.060840364170314354, -0.060790456718824791, +-0.060740549115359969, -0.060690641360043776, -0.060640733453000979, -0.060590825394356347, -0.060540917184234655, -0.060491008822760664, -0.060441100310058268, -0.060391191646254012, +-0.060341282831471776, -0.060291373865836329, -0.060241464749472444, -0.060191555482504905, -0.060141646065058472, -0.060091736497257929, -0.060041826779227155, -0.059991916911092701, +-0.059942006892978454, -0.059892096725009190, -0.059842186407309685, -0.059792275940004712, -0.059742365323219054, -0.059692454557077473, -0.059642543641703877, -0.059592632577224809, +-0.059542721363764158, -0.059492810001446704, -0.059442898490397224, -0.059392986830740499, -0.059343075022601305, -0.059293163066103535, -0.059243250961373749, -0.059193338708535832, +-0.059143426307714575, -0.059093513759034745, -0.059043601062621132, -0.058993688218598517, -0.058943775227091683, -0.058893862088224523, -0.058843948802123590, -0.058794035368912791, +-0.058744121788716901, -0.058694208061660709, -0.058644294187868998, -0.058594380167466549, -0.058544466000578145, -0.058494551687327694, -0.058444637227841753, -0.058394722622244218, +-0.058344807870659869, -0.058294892973213511, -0.058244977930029911, -0.058195062741233872, -0.058145147406949288, -0.058095231927302725, -0.058045316302418083, -0.057995400532420145, +-0.057945484617433707, -0.057895568557583557, -0.057845652352994485, -0.057795736003791287, -0.057745819510097857, -0.057695902872040773, -0.057645986089743924, -0.057596069163332111, +-0.057546152092930125, -0.057496234878662761, -0.057446317520654808, -0.057396400019030180, -0.057346482373915431, -0.057296564585434480, -0.057246646653712117, -0.057196728578873139, +-0.057146810361042334, -0.057096892000344505, -0.057046973496904449, -0.056997054850846073, -0.056947136062295942, -0.056897217131377978, -0.056847298058216963, -0.056797378842937708, +-0.056747459485665008, -0.056697539986523653, -0.056647620345638451, -0.056597700563133312, -0.056547780639134806, -0.056497860573766857, -0.056447940367154247, -0.056398020019421791, +-0.056348099530694279, -0.056298178901096528, -0.056248258130752432, -0.056198337219788584, -0.056148416168328892, -0.056098494976498159, -0.056048573644421187, -0.055998652172222788, +-0.055948730560027755, -0.055898808807960894, -0.055848886916146125, -0.055798964884710020, -0.055749042713776509, -0.055699120403470394, -0.055649197953916471, -0.055599275365239557, +-0.055549352637564456, -0.055499429771015969, -0.055449506765718019, -0.055399583621797192, -0.055349660339377410, -0.055299736918583475, -0.055249813359540198, -0.055199889662372388, +-0.055149965827204848, -0.055100041854161515, -0.055050117743368959, -0.055000193494951111, -0.054950269109032779, -0.054900344585738767, -0.054850419925193905, -0.054800495127522983, +-0.054750570192850831, -0.054700645121301364, -0.054650719913001168, -0.054600794568074179, -0.054550869086645200, -0.054500943468839047, -0.054451017714780538, -0.054401091824594482, +-0.054351165798404814, -0.054301239636338115, -0.054251313338518313, -0.054201386905070238, -0.054151460336118687, -0.054101533631788490, -0.054051606792204457, -0.054001679817491405, +-0.053951752707773269, -0.053901825463176636, -0.053851898083825442, -0.053801970569844502, -0.053752042921358635, -0.053702115138492663, -0.053652187221371397, -0.053602259170119668, +-0.053552330984861410, -0.053502402665723203, -0.053452474212828990, -0.053402545626303595, -0.053352616906271834, -0.053302688052858531, -0.053252759066188503, -0.053202829946385699, +-0.053152900693576699, -0.053102971307885452, -0.053053041789436775, -0.053003112138355499, -0.052953182354766440, -0.052903252438794422, -0.052853322390564270, -0.052803392210199931, +-0.052753461897828001, -0.052703531453572407, -0.052653600877557993, -0.052603670169909571, -0.052553739330751977, -0.052503808360210034, -0.052453877258408568, -0.052403946025471528, +-0.052354014661525505, -0.052304083166694444, -0.052254151541103182, -0.052204219784876535, -0.052154287898139341, -0.052104355881016425, -0.052054423733631734, -0.052004491456111870, +-0.051954559048580776, -0.051904626511163288, -0.051854693843984230, -0.051804761047168441, -0.051754828120840750, -0.051704895065125982, -0.051654961880148093, -0.051605028566033689, +-0.051555095122906715, -0.051505161550891999, -0.051455227850114381, -0.051405294020698690, -0.051355360062769764, -0.051305425976451553, -0.051255491761870664, -0.051205557419151046, +-0.051155622948417537, -0.051105688349794967, -0.051055753623408182, -0.051005818769382004, -0.050955883787841286, -0.050905948678909969, -0.050856013442714662, -0.050806078079379327, +-0.050756142589028802, -0.050706206971787911, -0.050656271227781512, -0.050606335357134428, -0.050556399359971506, -0.050506463236416700, -0.050456526986596618, -0.050406590610635224, +-0.050356654108657355, -0.050306717480787848, -0.050256780727151548, -0.050206843847873300, -0.050156906843077047, -0.050106969712889422, -0.050057032457434369, -0.050007095076836733, +-0.049957157571221364, -0.049907219940713100, -0.049857282185436780, -0.049807344305517261, -0.049757406301078493, -0.049707468172247096, -0.049657529919147028, -0.049607591541903133, +-0.049557653040640262, -0.049507714415483260, -0.049457775666556972, -0.049407836793986241, -0.049357897797895033, -0.049307958678409966, -0.049258019435655005, -0.049208080069754995, +-0.049158140580834786, -0.049108200969019224, -0.049058261234433159, -0.049008321377200556, -0.048958381397448035, -0.048908441295299560, -0.048858501070879981, -0.048808560724314151, +-0.048758620255726921, -0.048708679665243136, -0.048658738952987654, -0.048608798119084438, -0.048558857163660110, -0.048508916086838647, -0.048458974888744892, -0.048409033569503691, +-0.048359092129239917, -0.048309150568078406, -0.048259208886143136, -0.048209267083560728, -0.048159325160455152, -0.048109383116951260, -0.048059440953173917, -0.048009498669247967, +-0.047959556265298277, -0.047909613741449690, -0.047859671097826184, -0.047809728334554387, -0.047759785451758269, -0.047709842449562681, -0.047659899328092496, -0.047609956087472559, +-0.047560012727827734, -0.047510069249282874, -0.047460125651961955, -0.047410181935991613, -0.047360238101495811, -0.047310294148599413, -0.047260350077427286, -0.047210405888104275, +-0.047160461580755257, -0.047110517155504197, -0.047060572612477723, -0.047010627951799826, -0.046960683173595356, -0.046910738277989181, -0.046860793265106157, -0.046810848135071151, +-0.046760902888009027, -0.046710957524043757, -0.046661012043301982, -0.046611066445907672, -0.046561120731985699, -0.046511174901660922, -0.046461228955058213, -0.046411282892302425, +-0.046361336713517547, -0.046311390418830214, -0.046261444008364405, -0.046211497482244984, -0.046161550840596824, -0.046111604083544783, -0.046061657211213733, -0.046011710223728540, +-0.045961763121213181, -0.045911815903794305, -0.045861868571595889, -0.045811921124742798, -0.045761973563359912, -0.045712025887572089, -0.045662078097504194, -0.045612130193281114, +-0.045562182175026812, -0.045512234042867951, -0.045462285796928500, -0.045412337437333333, -0.045362388964207329, -0.045312440377675345, -0.045262491677862261, -0.045212542864892062, +-0.045162593938891396, -0.045112644899984240, -0.045062695748295481, -0.045012746483949977, -0.044962797107072607, -0.044912847617788243, -0.044862898016221758, -0.044812948302497144, +-0.044762998476741041, -0.044713048539077448, -0.044663098489631237, -0.044613148328527273, -0.044563198055890436, -0.044513247671845613, -0.044463297176517667, -0.044413346570030585, +-0.044363395852511034, -0.044313445024082986, -0.044263494084871326, -0.044213543035000934, -0.044163591874596682, -0.044113640603783449, -0.044063689222685234, -0.044013737731428679, +-0.043963786130137773, -0.043913834418937411, -0.043863882597952458, -0.043813930667307800, -0.043763978627128317, -0.043714026477538886, -0.043664074218663501, -0.043614121850628823, +-0.043564169373558836, -0.043514216787578421, -0.043464264092812468, -0.043414311289385860, -0.043364358377423466, -0.043314405357049293, -0.043264452228389996, -0.043214498991569567, +-0.043164545646712883, -0.043114592193944846, -0.043064638633390322, -0.043014684965174202, -0.042964731189421367, -0.042914777306255820, -0.042864823315804219, -0.042814869218190561, +-0.042764915013539725, -0.042714960701976605, -0.042665006283626079, -0.042615051758613041, -0.042565097127062371, -0.042515142389098072, -0.042465187544846808, -0.042415232594432570, +-0.042365277537980257, -0.042315322375614743, -0.042265367107460927, -0.042215411733643689, -0.042165456254287040, -0.042115500669517636, -0.042065544979459475, -0.042015589184237458, +-0.041965633283976470, -0.041915677278801390, -0.041865721168837126, -0.041815764954208551, -0.041765808635039682, -0.041715852211457176, -0.041665895683585044, -0.041615939051548166, +-0.041565982315471442, -0.041516025475479765, -0.041466068531698028, -0.041416111484251110, -0.041366154333263030, -0.041316197078860452, -0.041266239721167386, -0.041216282260308712, +-0.041166324696409337, -0.041116367029594154, -0.041066409259988050, -0.041016451387715036, -0.040966493412901775, -0.040916535335672286, -0.040866577156151461, -0.040816618874464188, +-0.040766660490735372, -0.040716702005089901, -0.040666743417652682, -0.040616784728547711, -0.040566825937901667, -0.040516867045838553, -0.040466908052483277, -0.040416948957960733, +-0.040366989762395812, -0.040317030465913416, -0.040267071068637562, -0.040217111570694915, -0.040167151972209485, -0.040117192273306179, -0.040067232474109891, -0.040017272574745529, +-0.039967312575337977, -0.039917352476012143, -0.039867392276892046, -0.039817431978104355, -0.039767471579773082, -0.039717511082023128, -0.039667550484979400, -0.039617589788766797, +-0.039567628993510212, -0.039517668099334560, -0.039467707106363853, -0.039417746014724760, -0.039367784824541306, -0.039317823535938386, -0.039267862149040912, -0.039217900663973779, +-0.039167939080861899, -0.039117977399829279, -0.039068015621002608, -0.039018053744505891, -0.038968091770464043, -0.038918129699001963, -0.038868167530244566, -0.038818205264316744, +-0.038768242901343411, -0.038718280441448587, -0.038668317884758940, -0.038618355231398505, -0.038568392481492179, -0.038518429635164872, -0.038468466692541496, -0.038418503653746952, +-0.038368540518905259, -0.038318577288143099, -0.038268613961584499, -0.038218650539354367, -0.038168687021577601, -0.038118723408379122, -0.038068759699883839, -0.038018795896216651, +-0.037968831997501590, -0.037918868003865333, -0.037868903915431906, -0.037818939732326216, -0.037768975454673184, -0.037719011082597710, -0.037669046616224708, -0.037619082055679091, +-0.037569117401084880, -0.037519152652568763, -0.037469187810254767, -0.037419222874267799, -0.037369257844732773, -0.037319292721774602, -0.037269327505518202, -0.037219362196087596, +-0.037169396793609470, -0.037119431298207849, -0.037069465710007653, -0.037019500029133796, -0.036969534255711187, -0.036919568389864738, -0.036869602431719370, -0.036819636381399110, +-0.036769670239030647, -0.036719704004738007, -0.036669737678646112, -0.036619771260879869, -0.036569804751564197, -0.036519838150824012, -0.036469871458784234, -0.036419904675568888, +-0.036369937801304673, -0.036319970836115607, -0.036270003780126618, -0.036220036633462613, -0.036170069396248526, -0.036120102068609258, -0.036070134650668849, -0.036020167142553995, +-0.035970199544388723, -0.035920231856297946, -0.035870264078406593, -0.035820296210839583, -0.035770328253721825, -0.035720360207178253, -0.035670392071332893, -0.035620423846312435, +-0.035570455532240919, -0.035520487129243265, -0.035470518637444395, -0.035420550056969230, -0.035370581387942683, -0.035320612630488801, -0.035270643784734275, -0.035220674850803137, +-0.035170705828820314, -0.035120736718910722, -0.035070767521199288, -0.035020798235810939, -0.034970828862870597, -0.034920859402502294, -0.034870889854832728, -0.034820920219985937, +-0.034770950498086844, -0.034720980689260376, -0.034671010793631461, -0.034621040811325013, -0.034571070742465966, -0.034521100587178354, -0.034471130345588873, -0.034421160017821577, +-0.034371189604001373, -0.034321219104253196, -0.034271248518701974, -0.034221277847472628, -0.034171307090689197, -0.034121336248478393, -0.034071365320964248, -0.034021394308271682, +-0.033971423210525639, -0.033921452027851032, -0.033871480760372795, -0.033821509408215857, -0.033771537971504263, -0.033721566450364705, -0.033671594844921236, -0.033621623155298777, +-0.033571651381622263, -0.033521679524016613, -0.033471707582606772, -0.033421735557517658, -0.033371763448873319, -0.033321791256800459, -0.033271818981423118, -0.033221846622866237, +-0.033171874181254730, -0.033121901656713547, -0.033071929049367600, -0.033021956359340951, -0.032971983586760296, -0.032922010731749683, -0.032872037794434039, -0.032822064774938306, +-0.032772091673387412, -0.032722118489906284, -0.032672145224619857, -0.032622171877652185, -0.032572198449129973, -0.032522224939177259, -0.032472251347918986, -0.032422277675480081, +-0.032372303921985486, -0.032322330087560129, -0.032272356172328064, -0.032222382176415987, -0.032172408099947959, -0.032122433943048916, -0.032072459705843784, -0.032022485388457499, +-0.031972510991015002, -0.031922536513641235, -0.031872561956460231, -0.031822587319598715, -0.031772612603180726, -0.031722637807331207, -0.031672662932175091, -0.031622687977837322, +-0.031572712944442832, -0.031522737832116558, -0.031472762640982560, -0.031422787371167535, -0.031372812022795543, -0.031322836595991520, -0.031272861090880406, -0.031222885507587138, +-0.031172909846236659, -0.031122934106953017, -0.031072958289862927, -0.031022982395090441, -0.030973006422760501, -0.030923030372998043, -0.030873054245928008, -0.030823078041675341, +-0.030773101760364976, -0.030723125402120969, -0.030673148967070036, -0.030623172455336231, -0.030573195867044496, -0.030523219202319773, -0.030473242461286999, -0.030423265644071117, +-0.030373288750797076, -0.030323311781588921, -0.030273334736573378, -0.030223357615874497, -0.030173380419617219, -0.030123403147926494, -0.030073425800927259, -0.030023448378744461, +-0.029973470881502151, -0.029923493309327056, -0.029873515662343225, -0.029823537940675604, -0.029773560144449141, -0.029723582273788775, -0.029673604328819457, -0.029623626309666126, +-0.029573648216452839, -0.029523670049306321, -0.029473691808350629, -0.029423713493710708, -0.029373735105511504, -0.029323756643877957, -0.029273778108935024, -0.029223799500806755, +-0.029173820819619875, -0.029123842065498444, -0.029073863238567407, -0.029023884338951714, -0.028973905366776308, -0.028923926322166140, -0.028873947205246157, -0.028823968016140417, +-0.028773988754975645, -0.028724009421875901, -0.028674030016966130, -0.028624050540371287, -0.028574070992216320, -0.028524091372626171, -0.028474111681725797, -0.028424131919639255, +-0.028374152086493271, -0.028324172182411907, -0.028274192207520112, -0.028224212161942836, -0.028174232045805030, -0.028124251859231647, -0.028074271602346743, -0.028024291275277047, +-0.027974310878146627, -0.027924330411080427, -0.027874349874203400, -0.027824369267640502, -0.027774388591516676, -0.027724407845956880, -0.027674427031085178, -0.027624446147028296, +-0.027574465193910300, -0.027524484171856139, -0.027474503080990767, -0.027424521921439141, -0.027374540693326205, -0.027324559396776922, -0.027274578031915350, -0.027224596598868223, +-0.027174615097759602, -0.027124633528714442, -0.027074651891857700, -0.027024670187314331, -0.026974688415209284, -0.026924706575666629, -0.026874724668813094, -0.026824742694772748, +-0.026774760653670546, -0.026724778545631440, -0.026674796370780390, -0.026624814129242350, -0.026574831821142272, -0.026524849446604229, -0.026474867005754948, -0.026424884498718500, +-0.026374901925619840, -0.026324919286583929, -0.026274936581735717, -0.026224953811200161, -0.026174970975101339, -0.026124988073565971, -0.026075005106718136, -0.026025022074682790, +-0.025975038977584887, -0.025925055815549384, -0.025875072588701246, -0.025825089297165423, -0.025775105941065992, -0.025725122520529681, -0.025675139035680566, -0.025625155486643601, +-0.025575171873543748, -0.025525188196505968, -0.025475204455655216, -0.025425220651116451, -0.025375236783013750, -0.025325252851473842, -0.025275268856620802, -0.025225284798579592, +-0.025175300677475167, -0.025125316493432494, -0.025075332246576525, -0.025025347937031341, -0.024975363564923674, -0.024925379130377599, -0.024875394633518077, -0.024825410074470068, +-0.024775425453358531, -0.024725440770308433, -0.024675456025444732, -0.024625471218891505, -0.024575486350775486, -0.024525501421220751, -0.024475516430352263, -0.024425531378294982, +-0.024375546265173874, -0.024325561091113904, -0.024275575856240027, -0.024225590560676323, -0.024175605204549529, -0.024125619787983724, -0.024075634311103870, -0.024025648774034930, +-0.023975663176901869, -0.023925677519829647, -0.023875691802942346, -0.023825706026366703, -0.023775720190226796, -0.023725734294647586, -0.023675748339754041, -0.023625762325671127, +-0.023575776252523804, -0.023525790120437044, -0.023475803929534918, -0.023425817679944172, -0.023375831371788881, -0.023325845005194010, -0.023275858580284529, -0.023225872097185400, +-0.023175885556021590, -0.023125898956917180, -0.023075912299998912, -0.023025925585390860, -0.022975938813217994, -0.022925951983605284, -0.022875965096677692, -0.022825978152560187, +-0.022775991151377739, -0.022726004093254423, -0.022676016978316987, -0.022626029806689506, -0.022576042578496949, -0.022526055293864290, -0.022476067952916491, -0.022426080555778521, +-0.022376093102575351, -0.022326105593431057, -0.022276118028472392, -0.022226130407823428, -0.022176142731609141, -0.022126154999954496, -0.022076167212984461, -0.022026179370824010, +-0.021976191473597223, -0.021926203521430845, -0.021876215514448960, -0.021826227452776535, -0.021776239336538539, -0.021726251165859949, -0.021676262940865727, -0.021626274661680850, +-0.021576286328429398, -0.021526297941238118, -0.021476309500231092, -0.021426321005533294, -0.021376332457269692, -0.021326343855565262, -0.021276355200544970, -0.021226366492333788, +-0.021176377731055806, -0.021126388916837765, -0.021076400049803750, -0.021026411130078738, -0.020976422157787698, -0.020926433133055602, -0.020876444056007422, -0.020826454926767247, +-0.020776465745461818, -0.020726476512215229, -0.020676487227152446, -0.020626497890398447, -0.020576508502078202, -0.020526519062316687, -0.020476529571238872, -0.020426540028968848, +-0.020376550435633359, -0.020326560791356498, -0.020276571096263230, -0.020226581350478539, -0.020176591554127390, -0.020126601707334765, -0.020076611810224746, -0.020026621862924088, +-0.019976631865556874, -0.019926641818248082, -0.019876651721122681, -0.019826661574305654, -0.019776671377921974, -0.019726681132096614, -0.019676690836953663, -0.019626700492619872, +-0.019576710099219331, -0.019526719656877016, -0.019476729165717899, -0.019426738625866961, -0.019376748037449178, -0.019326757400589523, -0.019276766715412088, -0.019226775982043622, +-0.019176785200608216, -0.019126794371230847, -0.019076803494036496, -0.019026812569150130, -0.018976821596696739, -0.018926830576800401, -0.018876839509587878, -0.018826848395183254, +-0.018776857233711509, -0.018726866025297623, -0.018676874770066569, -0.018626883468143330, -0.018576892119652882, -0.018526900724719315, -0.018476909283469387, -0.018426917796027183, +-0.018376926262517686, -0.018326934683065871, -0.018276943057796723, -0.018226951386835215, -0.018176959670305439, -0.018126967908334155, -0.018076976101045448, -0.018026984248564304, +-0.017976992351015696, -0.017927000408524612, -0.017877008421216024, -0.017827016389214915, -0.017777024312645377, -0.017727032191634167, -0.017677040026305376, -0.017627047816783984, +-0.017577055563194971, -0.017527063265663324, -0.017477070924314015, -0.017427078539272032, -0.017377086110661463, -0.017327093638609063, -0.017277101123238933, -0.017227108564676050, +-0.017177115963045397, -0.017127123318471951, -0.017077130631080698, -0.017027137900995731, -0.016977145128343803, -0.016927152313249018, -0.016877159455836351, -0.016827166556230785, +-0.016777173614557300, -0.016727180630940884, -0.016677187605506513, -0.016627194538378288, -0.016577201429682966, -0.016527208279544636, -0.016477215088088290, -0.016427221855438903, +-0.016377228581721463, -0.016327235267060949, -0.016277241911582349, -0.016227248515409756, -0.016177255078669930, -0.016127261601486968, -0.016077268083985848, -0.016027274526291560, +-0.015977280928529087, -0.015927287290823409, -0.015877293613298628, -0.015827299896081497, -0.015777306139296118, -0.015727312343067474, -0.015677318507520549, -0.015627324632780330, +-0.015577330718971796, -0.015527336766219937, -0.015477342774648847, -0.015427348744385288, -0.015377354675553359, -0.015327360568278043, -0.015277366422684324, -0.015227372238897190, +-0.015177378017041625, -0.015127383757241725, -0.015077389459624257, -0.015027395124313314, -0.014977400751433882, -0.014927406341110951, -0.014877411893469502, -0.014827417408634523, +-0.014777422886731001, -0.014727428327883034, -0.014677433732217386, -0.014627439099858150, -0.014577444430930319, -0.014527449725558876, -0.014477454983868808, -0.014427460205985104, +-0.014377465392032749, -0.014327470542135842, -0.014277475656421148, -0.014227480735012763, -0.014177485778035678, -0.014127490785614876, -0.014077495757875350, -0.014027500694942083, +-0.013977505596939176, -0.013927510463993393, -0.013877515296228835, -0.013827520093770489, -0.013777524856743341, -0.013727529585272381, -0.013677534279482598, -0.013627538939498980, +-0.013577543565445625, -0.013527548157449300, -0.013477552715634104, -0.013427557240125027, -0.013377561731047058, -0.013327566188525182, -0.013277570612684392, -0.013227575003649676, +-0.013177579361545134, -0.013127583686497531, -0.013077587978630970, -0.013027592238070438, -0.012977596464940925, -0.012927600659367423, -0.012877604821474917, -0.012827608951387511, +-0.012777613049231971, -0.012727617115132400, -0.012677621149213785, -0.012627625151601117, -0.012577629122419387, -0.012527633061793582, -0.012477636969848696, -0.012427640846708830, +-0.012377644692500750, -0.012327648507348557, -0.012277652291377244, -0.012227656044711798, -0.012177659767477214, -0.012127663459798481, -0.012077667121799701, -0.012027670753607641, +-0.011977674355346402, -0.011927677927140980, -0.011877681469116361, -0.011827684981397541, -0.011777688464109506, -0.011727691917377251, -0.011677695341324878, -0.011627698736079155, +-0.011577702101764184, -0.011527705438504959, -0.011477708746426471, -0.011427712025653710, -0.011377715276311668, -0.011327718498525340, -0.011277721692418826, -0.011227724858118897, +-0.011177727995749655, -0.011127731105436094, -0.011077734187303205, -0.011027737241475979, -0.010977740268079411, -0.010927743267237604, -0.010877746239077328, -0.010827749183722686, +-0.010777752101298671, -0.010727754991930275, -0.010677757855742492, -0.010627760692860314, -0.010577763503408734, -0.010527766287511857, -0.010477769045296454, -0.010427771776886627, +-0.010377774482407372, -0.010327777161983680, -0.010277779815740545, -0.010227782443802959, -0.010177785046295918, -0.010127787623343527, -0.010077790175072555, -0.010027792701607108, +-0.009977795203072178, -0.009927797679592761, -0.009877800131293850, -0.009827802558300437, -0.009777804960736630, -0.009727807338729199, -0.009677809692402251, -0.009627812021880778, +-0.009577814327289774, -0.009527816608754234, -0.009477818866399155, -0.009427821100349525, -0.009377823310729457, -0.009327825497665717, -0.009277827661282415, -0.009227829801704543, +-0.009177831919057097, -0.009127834013465071, -0.009077836085053460, -0.009027838133946371, -0.008977840160270574, -0.008927842164150176, -0.008877844145710174, -0.008827846105075561, +-0.008777848042371333, -0.008727849957722486, -0.008677851851254012, -0.008627853723090022, -0.008577855573357284, -0.008527857402179907, -0.008477859209682888, -0.008427860995991221, +-0.008377862761229902, -0.008327864505523924, -0.008277866228998286, -0.008227867931777095, -0.008177869613987121, -0.008127871275752473, -0.008077872917198147, -0.008027874538449140, +-0.007977876139630444, -0.007927877720867060, -0.007877879282283094, -0.007827880824005316, -0.007777882346157837, -0.007727883848865652, -0.007677885332253757, -0.007627886796447149, +-0.007577888241570824, -0.007527889667749779, -0.007477891075108121, -0.007427892463772623, -0.007377893833867394, -0.007327895185517431, -0.007277896518847729, -0.007227897833983287, +-0.007177899131049100, -0.007127900410169277, -0.007077901671470591, -0.007027902915077151, -0.006977904141113954, -0.006927905349705996, -0.006877906540978275, -0.006827907715055787, +-0.006777908872063531, -0.006727910012125614, -0.006677911135368810, -0.006627912241917228, -0.006577913331895865, -0.006527914405429720, -0.006477915462643789, -0.006427916503663068, +-0.006377917528612556, -0.006327918537616363, -0.006277919530801261, -0.006227920508291360, -0.006177921470211658, -0.006127922416687153, -0.006077923347842841, -0.006027924263803722, +-0.005977925164693903, -0.005927926050640159, -0.005877926921766601, -0.005827927778198225, -0.005777928620060029, -0.005727929447477013, -0.005677930260574172, -0.005627931059476505, +-0.005577931844308124, -0.005527932615195800, -0.005477933372263645, -0.005427934115636657, -0.005377934845439833, -0.005327935561798172, -0.005277936264836673, -0.005227936954680332, +-0.005177937631453262, -0.005127938295282235, -0.005077938946291362, -0.005027939584605642, -0.004977940210350073, -0.004927940823649654, -0.004877941424629382, -0.004827942013413369, +-0.004777942590128389, -0.004727943154898552, -0.004677943707848858, -0.004627944249104304, -0.004577944778789890, -0.004527945297030614, -0.004477945803951475, -0.004427946299676583, +-0.004377946784332712, -0.004327947258043976, -0.004277947720935371, -0.004227948173131897, -0.004177948614758552, -0.004127949045940336, -0.004077949466801360, -0.004027949877468397, +-0.003977950278065560, -0.003927950668717847, -0.003877951049550258, -0.003827951420687791, -0.003777951782255445, -0.003727952134378220, -0.003677952477180227, -0.003627952810788240, +-0.003577953135326371, -0.003527953450919620, -0.003477953757692985, -0.003427954055771466, -0.003377954345280061, -0.003327954626343770, -0.003277954899086705, -0.003227955163635641, +-0.003177955420114689, -0.003127955668648848, -0.003077955909363118, -0.003027956142382499, -0.002977956367831988, -0.002927956585835699, -0.002877956796520407, -0.002827957000010223, +-0.002777957196430146, -0.002727957385905176, -0.002677957568560313, -0.002627957744520555, -0.002577957913910904, -0.002527958076855469, -0.002477958233481027, -0.002427958383911690, +-0.002377958528272457, -0.002327958666688328, -0.002277958799284302, -0.002227958926185378, -0.002177959047516558, -0.002127959163401952, -0.002077959273968336, -0.002027959379339822, +-0.001977959479641409, -0.001927959574998098, -0.001877959665534888, -0.001827959751376778, -0.001777959832647881, -0.001727959909474973, -0.001677959981982165, -0.001627960050294457, +-0.001577960114536849, -0.001527960174834340, -0.001477960231311931, -0.001427960284094622, -0.001377960333306523, -0.001327960379074412, -0.001277960421522400, -0.001227960460775487, +-0.001177960496958673, -0.001127960530196958, -0.001077960560615341, -0.001027960588337934, -0.000977960613491515, -0.000927960636200194, -0.000877960656588971, -0.000827960674782847, +-0.000777960690906820, -0.000727960705085893, -0.000677960717445063, -0.000627960728108444, -0.000577960737202810, -0.000527960744852275, -0.000477960751181838, -0.000427960756316500, +-0.000377960760381259, -0.000327960763501117, -0.000277960765801072, -0.000227960767405237, -0.000177960768440389, -0.000127960769030639, -0.000077960769300987 +}; + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_example_f32.c new file mode 100644 index 0000000..87908ed --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/arm_linear_interp_example_f32.c @@ -0,0 +1,204 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_linear_interp_example_f32.c +* +* Description: Example code demonstrating usage of sin function +* and uses linear interpolation to get higher precision +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup LinearInterpExample Linear Interpolate Example + * + * CMSIS DSP Software Library -- Linear Interpolate Example + * + * Description + * This example demonstrates usage of linear interpolate modules and fast math modules. + * Method 1 uses fast math sine function to calculate sine values using cubic interpolation and method 2 uses + * linear interpolation function and results are compared to reference output. + * Example shows linear interpolation function can be used to get higher precision compared to fast math sin calculation. + * + * \par Block Diagram: + * \par + * \image html linearInterpExampleMethod1.gif "Method 1: Sine caluclation using fast math" + * \par + * \image html linearInterpExampleMethod2.gif "Method 2: Sine caluclation using interpolation function" + * + * \par Variables Description: + * \par + * \li \c testInputSin_f32 points to the input values for sine calculation + * \li \c testRefSinOutput32_f32 points to the reference values caculated from sin() matlab function + * \li \c testOutput points to output buffer calculation from cubic interpolation + * \li \c testLinIntOutput points to output buffer calculation from linear interpolation + * \li \c snr1 Signal to noise ratio for reference and cubic interpolation output + * \li \c snr2 Signal to noise ratio for reference and linear interpolation output + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_sin_f32() + * - arm_linear_interp_f32() + * + * Refer + * \link arm_linear_interp_example_f32.c \endlink + * + */ + + +/** \example arm_linear_interp_example_f32.c + */ + +#include "arm_math.h" +#include "math_helper.h" + +#define SNR_THRESHOLD 90 +#define TEST_LENGTH_SAMPLES 10 +#define XSPACING (0.00005f) + +/* ---------------------------------------------------------------------- +* Test input data for F32 SIN function +* Generated by the MATLAB rand() function +* randn('state', 0) +* xi = (((1/4.18318581819710)* randn(blockSize, 1) * 2* pi)); +* --------------------------------------------------------------------*/ +float32_t testInputSin_f32[TEST_LENGTH_SAMPLES] = +{ + -0.649716504673081170, -2.501723745497831200, + 0.188250329003310100, 0.432092748487532540, + -1.722010988459680800, 1.788766476323060600, + 1.786136060975809500, -0.056525543169408797, + 0.491596272728153760, 0.262309671126153390 +}; + +/*------------------------------------------------------------------------------ +* Reference out of SIN F32 function for Block Size = 10 +* Calculated from sin(testInputSin_f32) +*------------------------------------------------------------------------------*/ +float32_t testRefSinOutput32_f32[TEST_LENGTH_SAMPLES] = +{ + -0.604960695383043530, -0.597090287967934840, + 0.187140422442966500, 0.418772124875992690, + -0.988588831792106880, 0.976338412038794010, + 0.976903856413481100, -0.056495446835214236, + 0.472033731854734240, 0.259311907228582830 +}; + +/*------------------------------------------------------------------------------ +* Method 1: Test out Buffer Calculated from Cubic Interpolation +*------------------------------------------------------------------------------*/ +float32_t testOutput[TEST_LENGTH_SAMPLES]; + +/*------------------------------------------------------------------------------ +* Method 2: Test out buffer Calculated from Linear Interpolation +*------------------------------------------------------------------------------*/ +float32_t testLinIntOutput[TEST_LENGTH_SAMPLES]; + +/*------------------------------------------------------------------------------ +* External table used for linear interpolation +*------------------------------------------------------------------------------*/ +extern float arm_linear_interep_table[188495]; + +/* ---------------------------------------------------------------------- +* Global Variables for caluclating SNR's for Method1 & Method 2 +* ------------------------------------------------------------------- */ +float32_t snr1; +float32_t snr2; + +/* ---------------------------------------------------------------------------- +* Calculation of Sine values from Cubic Interpolation and Linear interpolation +* ---------------------------------------------------------------------------- */ +int32_t main(void) +{ + uint32_t i; + arm_status status; + + arm_linear_interp_instance_f32 S = {188495, -3.141592653589793238, XSPACING, &arm_linear_interep_table[0]}; + + /*------------------------------------------------------------------------------ + * Method 1: Test out Calculated from Cubic Interpolation + *------------------------------------------------------------------------------*/ + for(i=0; i< TEST_LENGTH_SAMPLES; i++) + { + testOutput[i] = arm_sin_f32(testInputSin_f32[i]); + } + + /*------------------------------------------------------------------------------ + * Method 2: Test out Calculated from Cubic Interpolation and Linear interpolation + *------------------------------------------------------------------------------*/ + + for(i=0; i< TEST_LENGTH_SAMPLES; i++) + { + testLinIntOutput[i] = arm_linear_interp_f32(&S, testInputSin_f32[i]); + } + + /*------------------------------------------------------------------------------ + * SNR calculation for method 1 + *------------------------------------------------------------------------------*/ + snr1 = arm_snr_f32(testRefSinOutput32_f32, testOutput, 2); + + /*------------------------------------------------------------------------------ + * SNR calculation for method 2 + *------------------------------------------------------------------------------*/ + snr2 = arm_snr_f32(testRefSinOutput32_f32, testLinIntOutput, 2); + + /*------------------------------------------------------------------------------ + * Initialise status depending on SNR calculations + *------------------------------------------------------------------------------*/ + if ( snr2 > snr1) + { + status = ARM_MATH_SUCCESS; + } + else + { + status = ARM_MATH_TEST_FAILURE; + } + + /* ---------------------------------------------------------------------- + ** Loop here if the signals fail the PASS check. + ** This denotes a test failure + ** ------------------------------------------------------------------- */ + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.c new file mode 100644 index 0000000..f615e6f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.c @@ -0,0 +1,466 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 b +* +* Project: CMSIS DSP Library +* +* Title: math_helper.c +* +* Description: Definition of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Include standard header files +* -------------------------------------------------------------------- */ +#include + +/* ---------------------------------------------------------------------- +* Include project header files +* -------------------------------------------------------------------- */ +#include "math_helper.h" + +/** + * @brief Caluclation of SNR + * @param[in] pRef Pointer to the reference buffer + * @param[in] pTest Pointer to the test buffer + * @param[in] buffSize total number of samples + * @return SNR + * The function Caluclates signal to noise ratio for the reference output + * and test output + */ + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize) +{ + float EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + float SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10 (EnergySignal / EnergyError); + + return (SNR); + +} + + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q15 (q15_t * input_buf, uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Converts float to fixed in q12.20 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to outputbuffer + * @param[in] numSamples number of samples in the input buffer + * @return none + * The function converts floating point values to fixed point(q12.20) values + */ + +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1048576.0f corresponds to pow(2, 20) */ + pOut[i] = (q31_t) (pIn[i] * 1048576.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 1.0) + { + pOut[i] = 0x000FFFFF; + } + } +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q31 (q31_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q7 (q7_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + + + +/** + * @brief Caluclates number of guard bits + * @param[in] num_adds number of additions + * @return guard bits + * The function Caluclates the number of guard bits + * depending on the numtaps + */ + +uint32_t arm_calc_guard_bits (uint32_t num_adds) +{ + uint32_t i = 1, j = 0; + + if (num_adds == 1) + { + return (0); + } + + while (i < num_adds) + { + i = i * 2; + j++; + } + + return (j); +} + +/** + * @brief Apply guard bits to buffer + * @param[in,out] pIn pointer to input buffer + * @param[in] numSamples number of samples in the input buffer + * @param[in] guard_bits guard bits + * @return none + */ + +void arm_apply_guard_bits (float32_t *pIn, + uint32_t numSamples, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + pIn[i] = pIn[i] * arm_calc_2pow(guard_bits); + } +} + +/** + * @brief Calculates pow(2, numShifts) + * @param[in] numShifts number of shifts + * @return pow(2, numShifts) + */ +uint32_t arm_calc_2pow(uint32_t numShifts) +{ + + uint32_t i, val = 1; + + for (i = 0; i < numShifts; i++) + { + val = val * 2; + } + + return(val); +} + + + +/** + * @brief Converts float to fixed q14 + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q14 (float *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 16384.0f corresponds to pow(2, 14) */ + pOut[i] = (q15_t) (pIn[i] * 16384.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFF; + } + + } + +} + + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q30 (float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 1073741824.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q29 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 536870912.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 4.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + + +/** + * @brief Converts float to fixed q28 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q28 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 268435456.0f corresponds to pow(2, 28) */ + pOut[i] = (q31_t) (pIn[i] * 268435456.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 8.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Clip the float values to +/- 1 + * @param[in,out] pIn input buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_clip_f32 (float *pIn, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + if (pIn[i] > 1.0f) + { + pIn[i] = 1.0; + } + else if ( pIn[i] < -1.0f) + { + pIn[i] = -1.0; + } + + } +} + + + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.h b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.h new file mode 100644 index 0000000..5a18734 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_linear_interp_example/math_helper.h @@ -0,0 +1,63 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2013 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* +* Title: math_helper.h +* +* Description: Prototypes of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + + +#include "arm_math.h" + +#ifndef MATH_HELPER_H +#define MATH_HELPER_H + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize); +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples); +void arm_provide_guard_bits_q15(q15_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_provide_guard_bits_q31(q31_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_float_to_q14(float *pIn, q15_t *pOut, uint32_t numSamples); +void arm_float_to_q29(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q28(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q30(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_clip_f32(float *pIn, uint32_t numSamples); +uint32_t arm_calc_guard_bits(uint32_t num_adds); +void arm_apply_guard_bits (float32_t * pIn, uint32_t numSamples, uint32_t guard_bits); +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t * pOut, uint32_t numSamples); +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t *pOut, uint32_t numSamples); +uint32_t arm_calc_2pow(uint32_t guard_bits); +#endif + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/Abstract.txt new file mode 100644 index 0000000..f45b0e0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_matrix_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/arm_matrix_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/arm_matrix_example_f32.c new file mode 100644 index 0000000..3d7a505 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/arm_matrix_example_f32.c @@ -0,0 +1,233 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_matrix_example_f32.c +* +* Description: Example code demonstrating least square fit to data +* using matrix functions +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup MatrixExample Matrix Example + * + * \par Description: + * \par + * Demonstrates the use of Matrix Transpose, Matrix Muliplication, and Matrix Inverse + * functions to apply least squares fitting to input data. Least squares fitting is + * the procedure for finding the best-fitting curve that minimizes the sum of the + * squares of the offsets (least square error) from a given set of data. + * + * \par Algorithm: + * \par + * The linear combination of parameters considered is as follows: + * \par + * A * X = B, where \c X is the unknown value and can be estimated + * from \c A & \c B. + * \par + * The least squares estimate \c X is given by the following equation: + * \par + * X = Inverse(AT * A) * AT * B + * + * \par Block Diagram: + * \par + * \image html matrixExample.gif + * + * \par Variables Description: + * \par + * \li \c A_f32 input matrix in the linear combination equation + * \li \c B_f32 output matrix in the linear combination equation + * \li \c X_f32 unknown matrix estimated using \c A_f32 & \c B_f32 matrices + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_mat_init_f32() + * - arm_mat_trans_f32() + * - arm_mat_mult_f32() + * - arm_mat_inverse_f32() + * + * Refer + * \link arm_matrix_example_f32.c \endlink + * + */ + + +/** \example arm_matrix_example_f32.c + */ + +#include "arm_math.h" +#include "math_helper.h" + +#define SNR_THRESHOLD 90 + +/* -------------------------------------------------------------------------------- +* Test input data(Cycles) taken from FIR Q15 module for differant cases of blockSize +* and tapSize +* --------------------------------------------------------------------------------- */ + +const float32_t B_f32[4] = +{ + 782.0, 7577.0, 470.0, 4505.0 +}; + +/* -------------------------------------------------------------------------------- +* Formula to fit is C1 + C2 * numTaps + C3 * blockSize + C4 * numTaps * blockSize +* -------------------------------------------------------------------------------- */ + +const float32_t A_f32[16] = +{ + /* Const, numTaps, blockSize, numTaps*blockSize */ + 1.0, 32.0, 4.0, 128.0, + 1.0, 32.0, 64.0, 2048.0, + 1.0, 16.0, 4.0, 64.0, + 1.0, 16.0, 64.0, 1024.0, +}; + + +/* ---------------------------------------------------------------------- +* Temporary buffers for storing intermediate values +* ------------------------------------------------------------------- */ +/* Transpose of A Buffer */ +float32_t AT_f32[16]; +/* (Transpose of A * A) Buffer */ +float32_t ATMA_f32[16]; +/* Inverse(Transpose of A * A) Buffer */ +float32_t ATMAI_f32[16]; +/* Test Output Buffer */ +float32_t X_f32[4]; + +/* ---------------------------------------------------------------------- +* Reference ouput buffer C1, C2, C3 and C4 taken from MATLAB +* ------------------------------------------------------------------- */ +const float32_t xRef_f32[4] = {73.0, 8.0, 21.25, 2.875}; + +float32_t snr; + + +/* ---------------------------------------------------------------------- +* Max magnitude FFT Bin test +* ------------------------------------------------------------------- */ + +int32_t main(void) +{ + + arm_matrix_instance_f32 A; /* Matrix A Instance */ + arm_matrix_instance_f32 AT; /* Matrix AT(A transpose) instance */ + arm_matrix_instance_f32 ATMA; /* Matrix ATMA( AT multiply with A) instance */ + arm_matrix_instance_f32 ATMAI; /* Matrix ATMAI(Inverse of ATMA) instance */ + arm_matrix_instance_f32 B; /* Matrix B instance */ + arm_matrix_instance_f32 X; /* Matrix X(Unknown Matrix) instance */ + + uint32_t srcRows, srcColumns; /* Temporary variables */ + arm_status status; + + /* Initialise A Matrix Instance with numRows, numCols and data array(A_f32) */ + srcRows = 4; + srcColumns = 4; + arm_mat_init_f32(&A, srcRows, srcColumns, (float32_t *)A_f32); + + /* Initialise Matrix Instance AT with numRows, numCols and data array(AT_f32) */ + srcRows = 4; + srcColumns = 4; + arm_mat_init_f32(&AT, srcRows, srcColumns, AT_f32); + + /* calculation of A transpose */ + status = arm_mat_trans_f32(&A, &AT); + + + /* Initialise ATMA Matrix Instance with numRows, numCols and data array(ATMA_f32) */ + srcRows = 4; + srcColumns = 4; + arm_mat_init_f32(&ATMA, srcRows, srcColumns, ATMA_f32); + + /* calculation of AT Multiply with A */ + status = arm_mat_mult_f32(&AT, &A, &ATMA); + + /* Initialise ATMAI Matrix Instance with numRows, numCols and data array(ATMAI_f32) */ + srcRows = 4; + srcColumns = 4; + arm_mat_init_f32(&ATMAI, srcRows, srcColumns, ATMAI_f32); + + /* calculation of Inverse((Transpose(A) * A) */ + status = arm_mat_inverse_f32(&ATMA, &ATMAI); + + /* calculation of (Inverse((Transpose(A) * A)) * Transpose(A)) */ + status = arm_mat_mult_f32(&ATMAI, &AT, &ATMA); + + /* Initialise B Matrix Instance with numRows, numCols and data array(B_f32) */ + srcRows = 4; + srcColumns = 1; + arm_mat_init_f32(&B, srcRows, srcColumns, (float32_t *)B_f32); + + /* Initialise X Matrix Instance with numRows, numCols and data array(X_f32) */ + srcRows = 4; + srcColumns = 1; + arm_mat_init_f32(&X, srcRows, srcColumns, X_f32); + + /* calculation ((Inverse((Transpose(A) * A)) * Transpose(A)) * B) */ + status = arm_mat_mult_f32(&ATMA, &B, &X); + + /* Comparison of reference with test output */ + snr = arm_snr_f32((float32_t *)xRef_f32, X_f32, 4); + + /*------------------------------------------------------------------------------ + * Initialise status depending on SNR calculations + *------------------------------------------------------------------------------*/ + if ( snr > SNR_THRESHOLD) + { + status = ARM_MATH_SUCCESS; + } + else + { + status = ARM_MATH_TEST_FAILURE; + } + + + /* ---------------------------------------------------------------------- + ** Loop here if the signals fail the PASS check. + ** This denotes a test failure + ** ------------------------------------------------------------------- */ + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.c new file mode 100644 index 0000000..f615e6f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.c @@ -0,0 +1,466 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 b +* +* Project: CMSIS DSP Library +* +* Title: math_helper.c +* +* Description: Definition of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Include standard header files +* -------------------------------------------------------------------- */ +#include + +/* ---------------------------------------------------------------------- +* Include project header files +* -------------------------------------------------------------------- */ +#include "math_helper.h" + +/** + * @brief Caluclation of SNR + * @param[in] pRef Pointer to the reference buffer + * @param[in] pTest Pointer to the test buffer + * @param[in] buffSize total number of samples + * @return SNR + * The function Caluclates signal to noise ratio for the reference output + * and test output + */ + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize) +{ + float EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + float SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10 (EnergySignal / EnergyError); + + return (SNR); + +} + + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q15 (q15_t * input_buf, uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Converts float to fixed in q12.20 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to outputbuffer + * @param[in] numSamples number of samples in the input buffer + * @return none + * The function converts floating point values to fixed point(q12.20) values + */ + +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1048576.0f corresponds to pow(2, 20) */ + pOut[i] = (q31_t) (pIn[i] * 1048576.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 1.0) + { + pOut[i] = 0x000FFFFF; + } + } +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q31 (q31_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q7 (q7_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + + + +/** + * @brief Caluclates number of guard bits + * @param[in] num_adds number of additions + * @return guard bits + * The function Caluclates the number of guard bits + * depending on the numtaps + */ + +uint32_t arm_calc_guard_bits (uint32_t num_adds) +{ + uint32_t i = 1, j = 0; + + if (num_adds == 1) + { + return (0); + } + + while (i < num_adds) + { + i = i * 2; + j++; + } + + return (j); +} + +/** + * @brief Apply guard bits to buffer + * @param[in,out] pIn pointer to input buffer + * @param[in] numSamples number of samples in the input buffer + * @param[in] guard_bits guard bits + * @return none + */ + +void arm_apply_guard_bits (float32_t *pIn, + uint32_t numSamples, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + pIn[i] = pIn[i] * arm_calc_2pow(guard_bits); + } +} + +/** + * @brief Calculates pow(2, numShifts) + * @param[in] numShifts number of shifts + * @return pow(2, numShifts) + */ +uint32_t arm_calc_2pow(uint32_t numShifts) +{ + + uint32_t i, val = 1; + + for (i = 0; i < numShifts; i++) + { + val = val * 2; + } + + return(val); +} + + + +/** + * @brief Converts float to fixed q14 + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q14 (float *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 16384.0f corresponds to pow(2, 14) */ + pOut[i] = (q15_t) (pIn[i] * 16384.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFF; + } + + } + +} + + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q30 (float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 1073741824.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q29 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 536870912.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 4.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + + +/** + * @brief Converts float to fixed q28 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q28 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 268435456.0f corresponds to pow(2, 28) */ + pOut[i] = (q31_t) (pIn[i] * 268435456.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 8.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Clip the float values to +/- 1 + * @param[in,out] pIn input buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_clip_f32 (float *pIn, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + if (pIn[i] > 1.0f) + { + pIn[i] = 1.0; + } + else if ( pIn[i] < -1.0f) + { + pIn[i] = -1.0; + } + + } +} + + + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.h b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.h new file mode 100644 index 0000000..5a18734 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_matrix_example/math_helper.h @@ -0,0 +1,63 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2013 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* +* Title: math_helper.h +* +* Description: Prototypes of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + + +#include "arm_math.h" + +#ifndef MATH_HELPER_H +#define MATH_HELPER_H + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize); +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples); +void arm_provide_guard_bits_q15(q15_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_provide_guard_bits_q31(q31_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_float_to_q14(float *pIn, q15_t *pOut, uint32_t numSamples); +void arm_float_to_q29(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q28(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q30(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_clip_f32(float *pIn, uint32_t numSamples); +uint32_t arm_calc_guard_bits(uint32_t num_adds); +void arm_apply_guard_bits (float32_t * pIn, uint32_t numSamples, uint32_t guard_bits); +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t * pOut, uint32_t numSamples); +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t *pOut, uint32_t numSamples); +uint32_t arm_calc_2pow(uint32_t guard_bits); +#endif + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/Abstract.txt new file mode 100644 index 0000000..d202e78 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_signal_converge_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_data.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_data.c new file mode 100644 index 0000000..3a2337d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_data.c @@ -0,0 +1,269 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_signal_converge_data.c +* +* Description: Test input data for Floating point LMS Norm FIR filter +* +* Target Processor: Cortex-M4/Cortex-M3/Cortex-M0 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +#include "arm_math.h" + +/* ---------------------------------------------------------------------- +** Test input data for Floating point LMS Norm FIR filter +** Generated by the MATLAB randn() function +** ------------------------------------------------------------------- */ + +float32_t testInput_f32[1536] = +{ +-0.432565, -1.665584, 0.125332, 0.287676, -1.146471, 1.190915, 1.189164, -0.037633, +0.327292, 0.174639, -0.186709, 0.725791, -0.588317, 2.183186, -0.136396, 0.113931, +1.066768, 0.059281, -0.095648, -0.832349, 0.294411, -1.336182, 0.714325, 1.623562, +-0.691776, 0.857997, 1.254001, -1.593730, -1.440964, 0.571148, -0.399886, 0.689997, +0.815622, 0.711908, 1.290250, 0.668601, 1.190838, -1.202457, -0.019790, -0.156717, +-1.604086, 0.257304, -1.056473, 1.415141, -0.805090, 0.528743, 0.219321, -0.921902, +-2.170674, -0.059188, -1.010634, 0.614463, 0.507741, 1.692430, 0.591283, -0.643595, +0.380337, -1.009116, -0.019511, -0.048221, 0.000043, -0.317859, 1.095004, -1.873990, +0.428183, 0.895638, 0.730957, 0.577857, 0.040314, 0.677089, 0.568900, -0.255645, +-0.377469, -0.295887, -1.475135, -0.234004, 0.118445, 0.314809, 1.443508, -0.350975, +0.623234, 0.799049, 0.940890, -0.992092, 0.212035, 0.237882, -1.007763, -0.742045, +1.082295, -0.131500, 0.389880, 0.087987, -0.635465, -0.559573, 0.443653, -0.949904, +0.781182, 0.568961, -0.821714, -0.265607, -1.187777, -2.202321, 0.986337, -0.518635, +0.327368, 0.234057, 0.021466, -1.003944, -0.947146, -0.374429, -1.185886, -1.055903, +1.472480, 0.055744, -1.217317, -0.041227, -1.128344, -1.349278, -0.261102, 0.953465, +0.128644, 0.656468, -1.167819, -0.460605, -0.262440, -1.213152, -1.319437, 0.931218, +0.011245, -0.645146, 0.805729, 0.231626, -0.989760, 1.339586, 0.289502, 1.478917, +1.138028, -0.684139, -1.291936, -0.072926, -0.330599, -0.843628, 0.497770, 1.488490, +-0.546476, -0.846758, -0.246337, 0.663024, -0.854197, -1.201315, -0.119869, -0.065294, +0.485296, -0.595491, -0.149668, -0.434752, -0.079330, 1.535152, -0.606483, -1.347363, +0.469383, -0.903567, 0.035880, -0.627531, 0.535398, 0.552884, -0.203690, -2.054325, +0.132561, 1.592941, 1.018412, -1.580402, -0.078662, -0.681657, -1.024553, -1.234353, +0.288807, -0.429303, 0.055801, -0.367874, -0.464973, 0.370961, 0.728283, 2.112160, +-1.357298, -1.022610, 1.037834, -0.389800, -1.381266, 0.315543, 1.553243, 0.707894, +1.957385, 0.504542, 1.864529, -0.339812, -1.139779, -0.211123, 1.190245, -1.116209, +0.635274, -0.601412, 0.551185, -1.099840, 0.085991, -2.004563, -0.493088, 0.462048, +-0.321005, 1.236556, -0.631280, -2.325211, -1.231637, 1.055648, -0.113224, 0.379224, +0.944200, -2.120427, -0.644679, -0.704302, -1.018137, -0.182082, 1.521013, -0.038439, +1.227448, -0.696205, 0.007524, -0.782893, 0.586939, -0.251207, 0.480136, 0.668155, +-0.078321, 0.889173, 2.309287, 0.524639, -0.011787, 0.913141, 0.055941, -1.107070, +0.485498, -0.005005, -0.276218, 1.276452, 1.863401, -0.522559, 0.103424, -0.807649, +0.680439, -2.364590, 0.990115, 0.218899, 0.261662, 1.213444, -0.274667, -0.133134, +-1.270500, -1.663606, -0.703554, 0.280880, -0.541209, -1.333531, 1.072686, -0.712085, +-0.011286, -0.000817, -0.249436, 0.396575, -0.264013, -1.664011, -1.028975, 0.243095, +-1.256590, -0.347183, -0.941372, -1.174560, -1.021142, -0.401667, 0.173666, -0.116118, +1.064119, -0.245386, -1.517539, 0.009734, 0.071373, 0.316536, 0.499826, 1.278084, +-0.547816, 0.260808, -0.013177, -0.580264, 2.136308, -0.257617, -1.409528, 1.770101, +0.325546, -1.119040, 0.620350, 1.269782, -0.896043, 0.135175, -0.139040, -1.163395, +1.183720, -0.015430, 0.536219, -0.716429, -0.655559, 0.314363, 0.106814, 1.848216, +-0.275106, 2.212554, 1.508526, -1.945079, -1.680543, -0.573534, -0.185817, 0.008934, +0.836950, -0.722271, -0.721490, -0.201181, -0.020464, 0.278890, 1.058295, 0.621673, +-1.750615, 0.697348, 0.811486, 0.636345, 1.310080, 0.327098, -0.672993, -0.149327, +-2.449018, 0.473286, 0.116946, -0.591104, -0.654708, -1.080662, -0.047731, 0.379345, +-0.330361, -0.499898, -0.035979, -0.174760, -0.957265, 1.292548, 0.440910, 1.280941, +-0.497730, -1.118717, 0.807650, 0.041200, -0.756209, -0.089129, -2.008850, 1.083918, +-0.981191, -0.688489, 1.339479, -0.909243, -0.412858, -0.506163, 1.619748, 0.080901, +-1.081056, -1.124518, 1.735676, 1.937459, 1.635068, -1.255940, -0.213538, -0.198932, +0.307499, -0.572325, -0.977648, -0.446809, 1.082092, 2.372648, 0.229288, -0.266623, +0.701672, -0.487590, 1.862480, 1.106851, -1.227566, -0.669885, 1.340929, 0.388083, +0.393059, -1.707334, 0.227859, 0.685633, -0.636790, -1.002606, -0.185621, -1.054033, +-0.071539, 0.279198, 1.373275, 0.179841, -0.542017, 1.634191, 0.825215, 0.230761, +0.671634, -0.508078, 0.856352, 0.268503, 0.624975, -1.047338, 1.535670, 0.434426, +-1.917136, 0.469940, 1.274351, 0.638542, 1.380782, 1.319843, -0.909429, -2.305605, +1.788730, 0.390798, 0.020324, -0.405977, -1.534895, 0.221373, -1.374479, -0.839286, +-0.208643, 0.755913, 0.375734, -1.345413, 1.481876, 0.032736, 1.870453, -1.208991, +-0.782632, -0.767299, -0.107200, -0.977057, -0.963988, -2.379172, -0.838188, 0.257346, +-0.183834, -0.167615, -0.116989, 0.168488, -0.501206, -0.705076, 0.508165, -0.420922, +0.229133, -0.959497, -0.146043, 0.744538, -0.890496, 0.139062, -0.236144, -0.075459, +-0.358572, -2.077635, -0.143546, 1.393341, 0.651804, -0.377134, -0.661443, 0.248958, +-0.383516, -0.528480, 0.055388, 1.253769, -2.520004, 0.584856, -1.008064, 0.944285, +-2.423957, -0.223831, 0.058070, -0.424614, -0.202918, -1.513077, -1.126352, -0.815002, +0.366614, -0.586107, 1.537409, 0.140072, -1.862767, -0.454193, -0.652074, 0.103318, +-0.220632, -0.279043, -0.733662, -0.064534, -1.444004, 0.612340, -1.323503, -0.661577, +-0.146115, 0.248085, -0.076633, 1.738170, 1.621972, 0.626436, 0.091814, -0.807607, +-0.461337, -1.405969, -0.374530, -0.470911, 1.751296, 0.753225, 0.064989, -0.292764, +0.082823, 0.766191, 2.236850, 0.326887, 0.863304, 0.679387, 0.554758, 1.001630, +1.259365, 0.044151, -0.314138, 0.226708, 0.996692, 1.215912, -0.542702, 0.912228, +-0.172141, -0.335955, 0.541487, 0.932111, -0.570253, -1.498605, -0.050346, 0.553025, +0.083498, 1.577524, -0.330774, 0.795155, -0.784800, -1.263121, 0.666655, -1.392632, +-1.300562, -0.605022, -1.488565, 0.558543, -0.277354, -1.293685, -0.888435, -0.986520, +-0.071618, -2.414591, -0.694349, -1.391389, 0.329648, 0.598544, 0.147175, -0.101439, +-2.634981, 0.028053, -0.876310, -0.265477, -0.327578, -1.158247, 0.580053, 0.239756, +-0.350885, 0.892098, 1.578299, -1.108174, -0.025931, -1.110628, 0.750834, 0.500167, +-0.517261, -0.559209, -0.753371, 0.925813, -0.248520, -0.149835, -1.258415, 0.312620, +2.690277, 0.289696, -1.422803, 0.246786, -1.435773, 0.148573, -1.693073, 0.719188, +1.141773, 1.551936, 1.383630, -0.758092, 0.442663, 0.911098, -1.074086, 0.201762, +0.762863, -1.288187, -0.952962, 0.778175, -0.006331, 0.524487, 1.364272, 0.482039, +-0.787066, 0.751999, -0.166888, -0.816228, 2.094065, 0.080153, -0.937295, 0.635739, +1.682028, 0.593634, 0.790153, 0.105254, -0.158579, 0.870907, -0.194759, 0.075474, +-0.526635, -0.685484, -0.268388, -1.188346, 0.248579, 0.102452, -0.041007, -2.247582, +-0.510776, 0.249243, 0.369197, 0.179197, -0.037283, -1.603310, 0.339372, -0.131135, +0.485190, 0.598751, -0.086031, 0.325292, -0.335143, -0.322449, -0.382374, -0.953371, +0.233576, 1.235245, -0.578532, -0.501537, 0.722864, 0.039498, 1.541279, -1.701053, +-1.033741, -0.763708, 2.176426, 0.431612, -0.443765, 0.029996, -0.315671, 0.977846, +0.018295, 0.817963, 0.702341, -0.231271, -0.113690, 0.127941, -0.799410, -0.238612, +-0.089463, -1.023264, 0.937538, -1.131719, -0.710702, -1.169501, 1.065437, -0.680394, +-1.725773, 0.813200, 1.441867, 0.672272, 0.138665, -0.859534, -0.752251, 1.229615, +1.150754, -0.608025, 0.806158, 0.217133, -0.373461, -0.832030, 0.286866, -1.818892, +-1.573051, 2.015666, -0.071982, 2.628909, -0.243317, 0.173276, 0.923207, -0.178553, +-0.521705, 1.431962, -0.870117, 0.807542, -0.510635, 0.743514, 0.847898, -0.829901, +0.532994, 1.032848, -1.052024, 0.362114, -0.036787, -1.227636, -0.275099, -0.160435, +-1.083575, -1.954213, -0.909487, -0.005579, -1.723490, 1.263077, -0.600433, -2.063925, +0.110911, 1.487614, 0.053002, 0.161981, -0.026878, 0.173576, 0.882168, 0.182294, +0.755295, 0.508035, 0.131880, 0.280104, -0.982848, -0.944087, -0.013058, 0.354345, +-0.894709, 0.812111, 0.109537, 2.731644, 0.411079, -1.306862, 0.383806, 0.499504, +-0.510786, 0.234922, -0.597825, 0.020771, 0.419443, 1.191104, 0.771214, -2.644222, +0.285430, 0.826093, -0.008122, 0.858438, 0.774788, 1.305945, 1.231503, 0.958564, +-1.654548, -0.990396, 0.685236, -0.974870, -0.606726, 0.686794, 0.020049, 1.063801, +-1.341050, 0.479510, -1.633974, -1.442665, 0.293781, -0.140364, -1.130341, -0.292538, +-0.582536, -0.896348, 0.248601, -1.489663, 0.313509, -2.025084, 0.528990, 0.343471, +0.758193, -0.691940, 0.680179, -1.072541, 0.899772, -2.123092, 0.284712, -0.733323, +-0.773376, 0.151842, -0.336843, 0.970761, -0.107236, 1.013492, -0.475347, 0.068948, +0.398592, 1.116326, 0.620451, -0.287674, -1.371773, -0.685868, 0.331685, -0.997722, +0.291418, 1.107078, 0.244959, 0.164976, 0.406231, 1.215981, 1.448424, -1.025137, +0.205418, 0.588882, -0.264024, 2.495318, 0.855948, -0.850954, 0.811879, 0.700242, +0.759938, -1.712909, 1.537021, -1.609847, 1.109526, -1.109704, 0.385469, 0.965231, +0.818297, 0.037049, -0.926012, -0.111919, -0.803030, -1.665006, -0.901401, 0.588350, +0.554159, -0.415173, 0.061795, 0.457432, 0.199014, 0.257558, 2.080730, -2.277237, +0.339022, 0.289894, 0.662261, -0.580860, 0.887752, 0.171871, 0.848821, 0.963769, +1.321918, -0.064345, 1.317053, 0.228017, -1.429637, -0.149701, -0.504968, -1.729141, +-0.417472, -0.614969, 0.720777, 0.339364, 0.882845, 0.284245, -0.145541, -0.089646, +0.289161, 1.164831, 0.805729, -1.355643, 0.120893, -0.222178, 0.571732, -0.300140, +1.134277, -0.179356, -1.467067, 1.395346, 0.440836, 0.565384, -0.693623, 0.833869, +-2.237378, 1.097644, -0.001617, -1.614573, -1.228727, 0.207405, 0.220942, -1.006073, +-0.453067, 1.399453, -0.461964, 0.032716, 0.798783, 0.896816, 0.137892, -1.619146, +-1.646606, 0.428707, -0.737231, 0.564926, -1.384167, 0.460268, 0.629384, 0.379847, +-1.013330, -0.347243, 0.441912, -1.590240, -0.701417, -1.077601, 1.002220, 1.729481, +0.709032, -0.747897, 0.228862, -0.223497, -0.853275, 0.345627, 0.109764, -1.133039, +-0.683124, -0.277856, 0.654790, -1.248394, -0.597539, -0.481813, 0.983372, 1.762121, +1.427402, 0.911763, 0.326823, 0.069619, -1.499763, -0.418223, -0.021037, 0.228425, +-1.008196, -0.664622, 0.558177, -1.188542, -0.775481, 0.271042, 1.534976, -1.052283, +0.625559, -0.797626, -0.313522, -0.602210, 1.259060, 0.858484, -2.105292, -0.360937, +0.553557, -1.556384, -0.206666, -0.425568, 0.493778, -0.870908, 0.079828, -0.521619, +-1.413861, -0.384293, -0.457922, -0.291471, -0.301224, -1.588594, 1.094287, 1.324167, +-0.126480, -0.737164, 0.213719, -0.400529, 0.064938, -1.757996, 1.686748, 0.327400, +0.715967, 1.598648, -2.064741, -0.743632, 0.176185, 0.527839, -0.553153, 0.298280, +-1.226607, -0.189676, -0.301713, 0.956956, -0.533366, -0.901082, -0.892552, 0.278717, +-0.745807, 1.603464, 0.574270, 0.320655, -0.151383, 0.315762, 1.343703, -2.237832, +1.292906, -0.378459, 0.002521, 0.884641, 0.582450, -1.614244, -1.503666, 0.573586, +-0.910537, -1.631277, -0.359138, -0.397616, -1.161307, -1.109838, 0.290672, -1.910239, +1.314768, 0.665319, -0.275115, -0.023022, -0.907976, -1.043657, 0.373516, 0.901532, +1.278539, -0.128456, 0.612821, 1.956518, 2.266326, -0.373959, 2.238039, -0.159580, +-0.703281, 0.563477, -0.050296, 1.163593, 0.658808, -1.550089, -3.029118, 0.540578, +-1.008998, 0.908047, 1.582303, -0.979088, 1.007902, 0.158491, -0.586927, 1.574082, +-0.516649, 1.227800, 1.583876, -2.088950, 2.949545, 1.356125, 1.050068, -0.767170, +-0.257653, -1.371845, -1.267656, -0.894948, 0.589089, 1.842629, 1.347967, -0.491253, +-2.177568, 0.237000, -0.735411, -1.779419, 0.448030, 0.581214, 0.856607, -0.266263, +-0.417470, -0.205806, -0.174323, 0.217577, 1.684295, 0.119528, 0.650667, 2.080061, +-0.339225, 0.730113, 0.293969, -0.849109, -2.533858, -2.378941, -0.346276, -0.610937, +-0.408192, -1.415611, 0.227122, 0.207974, -0.719718, 0.757762, -1.643135, -1.056813, +-0.251662, -1.298441, 1.233255, 1.494625, 0.235938, -1.404359, 0.658791, -2.556613, +-0.534945, 3.202525, 0.439198, -1.149901, 0.886765, -0.283386, 1.035336, -0.364878, +1.341987, 1.008872, 0.213874, -0.299264, 0.255849, -0.190826, -0.079060, 0.699851, +-0.796540, -0.801284, -0.007599, -0.726810, -1.490902, 0.870335, -0.265675, -1.566695, +-0.394636, -0.143855, -2.334247, -1.357539, -1.815689, 1.108422, -0.142115, 1.112757, +0.559264, 0.478370, -0.679385, 0.284967, -1.332935, -0.723980, -0.663600, 0.198443, +-1.794868, -1.387673, 0.197768, 1.469328, 0.366493, -0.442775, -0.048563, 0.077709, +1.957910, -0.072848, 0.938810, -0.079608, -0.800959, 0.309424, 1.051826, -1.664211, +-1.090792, -0.191731, 0.463401, -0.924147, -0.649657, 0.622893, -1.335107, 1.047689, +0.863327, -0.642411, 0.660010, 1.294116, 0.314579, 0.859573, 0.128670, 0.016568, +-0.072801, -0.994310, -0.747358, -0.030814, 0.988355, -0.599017, 1.476644, -0.813801, +0.645040, -1.309919, -0.867425, -0.474233, 0.222417, 1.871323, 0.110001, -0.411341, +0.511242, -1.199117, -0.096361, 0.445817, -0.295825, -0.167996, 0.179543, 0.421118, +1.677678, 1.996949, 0.696964, -1.366382, 0.363045, -0.567044, -1.044154, 0.697139, +0.484026, -0.193751, -0.378095, -0.886374, -1.840197, -1.628195, -1.173789, -0.415411, +0.175088, 0.229433, -1.240889, 0.700004, 0.426877, 1.454803, -0.510186, -0.006657, +-0.525496, 0.717698, 1.088374, 0.500552, 2.771790, -0.160309, 0.429489, -1.966817, +-0.546019, -1.888395, -0.107952, -1.316144, -0.672632, -0.902365, -0.154798, 0.947242, +1.550375, 0.429040, -0.560795, 0.179304, -0.771509, -0.943390, -1.407569, -1.906131, +-0.065293, 0.672149, 0.206147, -0.008124, 0.020042, -0.558447, 1.886079, -0.219975, +-1.414395, -0.302811, -0.569574, -0.121495, -0.390171, -0.844287, -1.737757, -0.449520, +-1.547933, -0.095776, 0.907714, 2.369602, 0.519768, 0.410525, 1.052585, 0.428784, +1.295088, -0.186053, 0.130733, -0.657627, -0.759267, -0.595170, 0.812400, 0.069541, +-1.833687, 1.827363, 0.654075, -1.544769, -0.375109, 0.207688, -0.765615, -0.106355, +0.338769, 1.033461, -1.404822, -1.030570, -0.643372, 0.170787, 1.344839, 1.936273, +0.741336, 0.811980, -0.142808, -0.099858, -0.800131, 0.493249, 1.237574, 1.295951, +-0.278196, 0.217127, 0.630728, -0.548549, 0.229632, 0.355311, 0.521284, -0.615971, +1.345803, 0.974922, -2.377934, -1.092319, -0.325710, -2.012228, 1.567660, 0.233337, +0.646420, -1.129412, 0.197038, 1.696870, 0.726034, 0.792526, 0.603357, -0.058405, +-1.108666, 2.144229, -1.352821, 0.457021, 0.391175, 2.073013, -0.323318, 1.468132, +-0.502399, 0.209593, 0.754800, -0.948189, 0.613157, 1.760503, 0.088762, 2.595570, +-0.675470, 2.786804, -0.016827, 0.271651, -0.914102, -1.951371, -0.317418, 0.588333, +0.828996, -1.674851, -1.922293, -0.436662, 0.044974, 2.416609, -0.309892, 0.187583, +0.947699, -0.525703, -1.115605, -1.592320, 1.174844, 0.485144, 1.645480, -0.454233, +1.008768, 2.049403, 0.602020, 0.017860, -1.610426, 1.238752, 0.683587, -0.780716, +0.530979, 2.134498, 0.354361, 0.231700, 1.287980, -0.013488, -1.333345, -0.556343, +0.755597, -0.911854, 1.371684, 0.245580, 0.118845, 0.384690, -0.070152, -0.578309, +0.469308, 1.299687, 1.634798, -0.702809, 0.807253, -1.027451, 1.294496, 0.014930, +0.218705, 1.713188, -2.078805, 0.112917, -1.086491, -1.558311, 0.637406, -0.404576, +-0.403325, 0.084076, -0.435349, -0.562623, 0.878062, -0.814650, -0.258363, 0.493299, +-0.802694, -0.008329, 0.627571, 0.154382, 2.580735, -1.306246, 1.023526, 0.777795, +-0.833884, -0.586663, 0.065664, -0.012342, -0.076987, -1.558587, 1.702607, -0.468984, +0.094619, 0.287071, 0.919354, 0.510136, 0.245440, -1.400519, 0.969571, 1.593698, +-1.437917, -1.534230, -0.074710, 0.081459, -0.843240, -0.564640, -0.028207, -1.243702, +0.733039, 0.059580, 0.149144, 1.595857, -0.777250, 1.550277, 1.055002, -0.166654, +0.314484, 1.419571, 0.327348, 0.475653, 0.398754, -0.072770, 1.314784, 0.978279, +1.722114, -0.412302, 0.565133, 0.739851, 0.220138, 1.312807, 0.629152, -1.107987, +-0.447001, -0.725993, 0.354045, -0.506772, -2.103747, -0.664684, 1.450110, -0.329805, +2.701872, -1.634939, -0.536325, 0.547223, 1.492603, -0.455243, -0.496416, 1.235260, +0.040926, 0.748467, 1.230764, 0.304903, 1.077771, 0.765151, -1.319580, -0.509191, +0.555116, -1.957625, -0.760453, -2.443886, -0.659366, -0.114779, 0.300079, -0.583996, +-3.073745, 1.551042, -0.407369, 1.428095, -1.353242, 0.903970, 0.541671, -0.465020 +}; + + + +/* ---------------------------------------------------------------------- +** Coefficients for 32-tap filter for Floating point LMS FIR filter +* FIR high pass filter with cutoff freq 9.6kHz (transition 9.6KHz to 11.52KHz) +** ------------------------------------------------------------------- */ +float32_t lmsNormCoeff_f32[32] = { +-0.004240, 0.002301, 0.008860, -0.000000, -0.019782, -0.010543, 0.032881, 0.034736, +-0.037374, -0.069586, 0.022397, 0.102169, 0.014185, -0.115908, -0.061648, 0.101018, +0.101018, -0.061648, -0.115908, 0.014185, 0.102169, 0.022397, -0.069586, -0.037374, +0.034736, 0.032881, -0.010543, -0.019782, -0.000000, 0.008860, 0.002301, -0.004240 + +}; + +/* ---------------------------------------------------------------------- +** Coefficients for 32-tap filter for Floating point FIR filter +* FIR low pass filter with cutoff freq 24Hz (transition 24Hz to 240Hz) +** ------------------------------------------------------------------- */ +const float32_t FIRCoeff_f32[32] = { +0.004502, 0.005074, 0.006707, 0.009356, 0.012933, 0.017303, 0.022298, 0.027717, +0.033338, 0.038930, 0.044258, 0.049098, 0.053243, 0.056519, 0.058784, 0.059941, +0.059941, 0.058784, 0.056519, 0.053243, 0.049098, 0.044258, 0.038930, 0.033338, +0.027717, 0.022298, 0.017303, 0.012933, 0.009356, 0.006707, 0.005074, 0.004502 + +}; + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_example_f32.c new file mode 100644 index 0000000..d984e2f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/arm_signal_converge_example_f32.c @@ -0,0 +1,259 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_signal_converge_example_f32.c +* +* Description: Example code demonstrating convergence of an adaptive +* filter. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. + * -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup SignalConvergence Signal Convergence Example + * + * \par Description: + * \par + * Demonstrates the ability of an adaptive filter to "learn" the transfer function of + * a FIR lowpass filter using the Normalized LMS Filter, Finite Impulse + * Response (FIR) Filter, and Basic Math Functions. + * + * \par Algorithm: + * \par + * The figure below illustrates the signal flow in this example. Uniformly distributed white + * noise is passed through an FIR lowpass filter. The output of the FIR filter serves as the + * reference input of the adaptive filter (normalized LMS filter). The white noise is input + * to the adaptive filter. The adaptive filter learns the transfer function of the FIR filter. + * The filter outputs two signals: (1) the output of the internal adaptive FIR filter, and + * (2) the error signal which is the difference between the adaptive filter and the reference + * output of the FIR filter. Over time as the adaptive filter learns the transfer function + * of the FIR filter, the first output approaches the reference output of the FIR filter, + * and the error signal approaches zero. + * \par + * The adaptive filter converges properly even if the input signal has a large dynamic + * range (i.e., varies from small to large values). The coefficients of the adaptive filter + * are initially zero, and then converge over 1536 samples. The internal function test_signal_converge() + * implements the stopping condition. The function checks if all of the values of the error signal have a + * magnitude below a threshold DELTA. + * + * \par Block Diagram: + * \par + * \image html SignalFlow.gif + * + * + * \par Variables Description: + * \par + * \li \c testInput_f32 points to the input data + * \li \c firStateF32 points to FIR state buffer + * \li \c lmsStateF32 points to Normalised Least mean square FIR filter state buffer + * \li \c FIRCoeff_f32 points to coefficient buffer + * \li \c lmsNormCoeff_f32 points to Normalised Least mean square FIR filter coefficient buffer + * \li \c wire1, wir2, wire3 temporary buffers + * \li \c errOutput, err_signal temporary error buffers + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_lms_norm_init_f32() + * - arm_fir_init_f32() + * - arm_fir_f32() + * - arm_lms_norm_f32() + * - arm_scale_f32() + * - arm_abs_f32() + * - arm_sub_f32() + * - arm_min_f32() + * - arm_copy_f32() + * + * Refer + * \link arm_signal_converge_example_f32.c \endlink + * + */ + + +/** \example arm_signal_converge_example_f32.c + */ + +#include "arm_math.h" +#include "math_helper.h" + +/* ---------------------------------------------------------------------- +** Global defines for the simulation +* ------------------------------------------------------------------- */ + +#define TEST_LENGTH_SAMPLES 1536 +#define NUMTAPS 32 +#define BLOCKSIZE 32 +#define DELTA_ERROR 0.000001f +#define DELTA_COEFF 0.0001f +#define MU 0.5f + +#define NUMFRAMES (TEST_LENGTH_SAMPLES / BLOCKSIZE) + +/* ---------------------------------------------------------------------- +* Declare FIR state buffers and structure +* ------------------------------------------------------------------- */ + +float32_t firStateF32[NUMTAPS + BLOCKSIZE]; +arm_fir_instance_f32 LPF_instance; + +/* ---------------------------------------------------------------------- +* Declare LMSNorm state buffers and structure +* ------------------------------------------------------------------- */ + +float32_t lmsStateF32[NUMTAPS + BLOCKSIZE]; +float32_t errOutput[TEST_LENGTH_SAMPLES]; +arm_lms_norm_instance_f32 lmsNorm_instance; + + +/* ---------------------------------------------------------------------- +* Function Declarations for Signal Convergence Example +* ------------------------------------------------------------------- */ + +arm_status test_signal_converge_example( void ); + + +/* ---------------------------------------------------------------------- +* Internal functions +* ------------------------------------------------------------------- */ +arm_status test_signal_converge(float32_t* err_signal, + uint32_t blockSize); + +void getinput(float32_t* input, + uint32_t fr_cnt, + uint32_t blockSize); + +/* ---------------------------------------------------------------------- +* External Declarations for FIR F32 module Test +* ------------------------------------------------------------------- */ +extern float32_t testInput_f32[TEST_LENGTH_SAMPLES]; +extern float32_t lmsNormCoeff_f32[32]; +extern const float32_t FIRCoeff_f32[32]; +extern arm_lms_norm_instance_f32 lmsNorm_instance; + +/* ---------------------------------------------------------------------- +* Declare I/O buffers +* ------------------------------------------------------------------- */ + +float32_t wire1[BLOCKSIZE]; +float32_t wire2[BLOCKSIZE]; +float32_t wire3[BLOCKSIZE]; +float32_t err_signal[BLOCKSIZE]; + +/* ---------------------------------------------------------------------- +* Signal converge test +* ------------------------------------------------------------------- */ + +int32_t main(void) +{ + uint32_t i; + arm_status status; + uint32_t index; + float32_t minValue; + + /* Initialize the LMSNorm data structure */ + arm_lms_norm_init_f32(&lmsNorm_instance, NUMTAPS, lmsNormCoeff_f32, lmsStateF32, MU, BLOCKSIZE); + + /* Initialize the FIR data structure */ + arm_fir_init_f32(&LPF_instance, NUMTAPS, (float32_t *)FIRCoeff_f32, firStateF32, BLOCKSIZE); + + /* ---------------------------------------------------------------------- + * Loop over the frames of data and execute each of the processing + * functions in the system. + * ------------------------------------------------------------------- */ + + for(i=0; i < NUMFRAMES; i++) + { + /* Read the input data - uniformly distributed random noise - into wire1 */ + arm_copy_f32(testInput_f32 + (i * BLOCKSIZE), wire1, BLOCKSIZE); + + /* Execute the FIR processing function. Input wire1 and output wire2 */ + arm_fir_f32(&LPF_instance, wire1, wire2, BLOCKSIZE); + + /* Execute the LMS Norm processing function*/ + + arm_lms_norm_f32(&lmsNorm_instance, /* LMSNorm instance */ + wire1, /* Input signal */ + wire2, /* Reference Signal */ + wire3, /* Converged Signal */ + err_signal, /* Error Signal, this will become small as the signal converges */ + BLOCKSIZE); /* BlockSize */ + + /* apply overall gain */ + arm_scale_f32(wire3, 5, wire3, BLOCKSIZE); /* in-place buffer */ + } + + status = ARM_MATH_SUCCESS; + + /* ------------------------------------------------------------------------------- + * Test whether the error signal has reached towards 0. + * ----------------------------------------------------------------------------- */ + + arm_abs_f32(err_signal, err_signal, BLOCKSIZE); + arm_min_f32(err_signal, BLOCKSIZE, &minValue, &index); + + if (minValue > DELTA_ERROR) + { + status = ARM_MATH_TEST_FAILURE; + } + + /* ---------------------------------------------------------------------- + * Test whether the filter coefficients have converged. + * ------------------------------------------------------------------- */ + + arm_sub_f32((float32_t *)FIRCoeff_f32, lmsNormCoeff_f32, lmsNormCoeff_f32, NUMTAPS); + + arm_abs_f32(lmsNormCoeff_f32, lmsNormCoeff_f32, NUMTAPS); + arm_min_f32(lmsNormCoeff_f32, NUMTAPS, &minValue, &index); + + if (minValue > DELTA_COEFF) + { + status = ARM_MATH_TEST_FAILURE; + } + + /* ---------------------------------------------------------------------- + * Loop here if the signals did not pass the convergence check. + * This denotes a test failure + * ------------------------------------------------------------------- */ + + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.c new file mode 100644 index 0000000..f615e6f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.c @@ -0,0 +1,466 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 b +* +* Project: CMSIS DSP Library +* +* Title: math_helper.c +* +* Description: Definition of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/* ---------------------------------------------------------------------- +* Include standard header files +* -------------------------------------------------------------------- */ +#include + +/* ---------------------------------------------------------------------- +* Include project header files +* -------------------------------------------------------------------- */ +#include "math_helper.h" + +/** + * @brief Caluclation of SNR + * @param[in] pRef Pointer to the reference buffer + * @param[in] pTest Pointer to the test buffer + * @param[in] buffSize total number of samples + * @return SNR + * The function Caluclates signal to noise ratio for the reference output + * and test output + */ + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize) +{ + float EnergySignal = 0.0, EnergyError = 0.0; + uint32_t i; + float SNR; + int temp; + int *test; + + for (i = 0; i < buffSize; i++) + { + /* Checking for a NAN value in pRef array */ + test = (int *)(&pRef[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + /* Checking for a NAN value in pTest array */ + test = (int *)(&pTest[i]); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + EnergySignal += pRef[i] * pRef[i]; + EnergyError += (pRef[i] - pTest[i]) * (pRef[i] - pTest[i]); + } + + /* Checking for a NAN value in EnergyError */ + test = (int *)(&EnergyError); + temp = *test; + + if (temp == 0x7FC00000) + { + return(0); + } + + + SNR = 10 * log10 (EnergySignal / EnergyError); + + return (SNR); + +} + + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q15 (q15_t * input_buf, uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Converts float to fixed in q12.20 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to outputbuffer + * @param[in] numSamples number of samples in the input buffer + * @return none + * The function converts floating point values to fixed point(q12.20) values + */ + +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1048576.0f corresponds to pow(2, 20) */ + pOut[i] = (q31_t) (pIn[i] * 1048576.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 1.0) + { + pOut[i] = 0x000FFFFF; + } + } +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Compare MATLAB Reference Output and ARM Test output + * @param[in] pIn Pointer to Ref buffer + * @param[in] pOut Pointer to Test buffer + * @param[in] numSamples number of samples in the buffer + * @return maximum difference + */ + +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + int32_t diff, diffCrnt = 0; + uint32_t maxDiff = 0; + + for (i = 0; i < numSamples; i++) + { + diff = pIn[i] - pOut[i]; + diffCrnt = (diff > 0) ? diff : -diff; + + if (diffCrnt > maxDiff) + { + maxDiff = diffCrnt; + } + } + + return(maxDiff); +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q31 (q31_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + +/** + * @brief Provide guard bits for Input buffer + * @param[in,out] input_buf Pointer to input buffer + * @param[in] blockSize block Size + * @param[in] guard_bits guard bits + * @return none + * The function Provides the guard bits for the buffer + * to avoid overflow + */ + +void arm_provide_guard_bits_q7 (q7_t * input_buf, + uint32_t blockSize, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < blockSize; i++) + { + input_buf[i] = input_buf[i] >> guard_bits; + } +} + + + +/** + * @brief Caluclates number of guard bits + * @param[in] num_adds number of additions + * @return guard bits + * The function Caluclates the number of guard bits + * depending on the numtaps + */ + +uint32_t arm_calc_guard_bits (uint32_t num_adds) +{ + uint32_t i = 1, j = 0; + + if (num_adds == 1) + { + return (0); + } + + while (i < num_adds) + { + i = i * 2; + j++; + } + + return (j); +} + +/** + * @brief Apply guard bits to buffer + * @param[in,out] pIn pointer to input buffer + * @param[in] numSamples number of samples in the input buffer + * @param[in] guard_bits guard bits + * @return none + */ + +void arm_apply_guard_bits (float32_t *pIn, + uint32_t numSamples, + uint32_t guard_bits) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + pIn[i] = pIn[i] * arm_calc_2pow(guard_bits); + } +} + +/** + * @brief Calculates pow(2, numShifts) + * @param[in] numShifts number of shifts + * @return pow(2, numShifts) + */ +uint32_t arm_calc_2pow(uint32_t numShifts) +{ + + uint32_t i, val = 1; + + for (i = 0; i < numShifts; i++) + { + val = val * 2; + } + + return(val); +} + + + +/** + * @brief Converts float to fixed q14 + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q14 (float *pIn, q15_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 16384.0f corresponds to pow(2, 14) */ + pOut[i] = (q15_t) (pIn[i] * 16384.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFF; + } + + } + +} + + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q30 (float *pIn, q31_t * pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 1073741824.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 2.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Converts float to fixed q30 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q29 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 1073741824.0f corresponds to pow(2, 30) */ + pOut[i] = (q31_t) (pIn[i] * 536870912.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 4.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + + +/** + * @brief Converts float to fixed q28 format + * @param[in] pIn pointer to input buffer + * @param[out] pOut pointer to output buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_float_to_q28 (float *pIn, q31_t *pOut, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + /* 268435456.0f corresponds to pow(2, 28) */ + pOut[i] = (q31_t) (pIn[i] * 268435456.0f); + + pOut[i] += pIn[i] > 0 ? 0.5 : -0.5; + + if (pIn[i] == (float) 8.0) + { + pOut[i] = 0x7FFFFFFF; + } + } +} + +/** + * @brief Clip the float values to +/- 1 + * @param[in,out] pIn input buffer + * @param[in] numSamples number of samples in the buffer + * @return none + * The function converts floating point values to fixed point values + */ + +void arm_clip_f32 (float *pIn, uint32_t numSamples) +{ + uint32_t i; + + for (i = 0; i < numSamples; i++) + { + if (pIn[i] > 1.0f) + { + pIn[i] = 1.0; + } + else if ( pIn[i] < -1.0f) + { + pIn[i] = -1.0; + } + + } +} + + + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.h b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.h new file mode 100644 index 0000000..5a18734 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_signal_converge_example/math_helper.h @@ -0,0 +1,63 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2013 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* +* Title: math_helper.h +* +* Description: Prototypes of all helper functions required. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + + +#include "arm_math.h" + +#ifndef MATH_HELPER_H +#define MATH_HELPER_H + +float arm_snr_f32(float *pRef, float *pTest, uint32_t buffSize); +void arm_float_to_q12_20(float *pIn, q31_t * pOut, uint32_t numSamples); +void arm_provide_guard_bits_q15(q15_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_provide_guard_bits_q31(q31_t *input_buf, uint32_t blockSize, uint32_t guard_bits); +void arm_float_to_q14(float *pIn, q15_t *pOut, uint32_t numSamples); +void arm_float_to_q29(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q28(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_float_to_q30(float *pIn, q31_t *pOut, uint32_t numSamples); +void arm_clip_f32(float *pIn, uint32_t numSamples); +uint32_t arm_calc_guard_bits(uint32_t num_adds); +void arm_apply_guard_bits (float32_t * pIn, uint32_t numSamples, uint32_t guard_bits); +uint32_t arm_compare_fixed_q15(q15_t *pIn, q15_t * pOut, uint32_t numSamples); +uint32_t arm_compare_fixed_q31(q31_t *pIn, q31_t *pOut, uint32_t numSamples); +uint32_t arm_calc_2pow(uint32_t guard_bits); +#endif + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/Abstract.txt new file mode 100644 index 0000000..84bd3fd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_sin_cos_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/arm_sin_cos_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/arm_sin_cos_example_f32.c new file mode 100644 index 0000000..7e2eb00 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_sin_cos_example/arm_sin_cos_example_f32.c @@ -0,0 +1,161 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 12. March 2014 +* $Revision: V1.4.3 +* +* Project: CMSIS DSP Library +* Title: arm_sin_cos_example_f32.c +* +* Description: Example code demonstrating sin and cos calculation of input signal. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup SinCosExample SineCosine Example + * + * \par Description: + * \par + * Demonstrates the Pythagorean trignometric identity with the use of Cosine, Sine, Vector + * Multiplication, and Vector Addition functions. + * + * \par Algorithm: + * \par + * Mathematically, the Pythagorean trignometric identity is defined by the following equation: + *
sin(x) * sin(x) + cos(x) * cos(x) = 1
+ * where \c x is the angle in radians. + * + * \par Block Diagram: + * \par + * \image html sinCos.gif + * + * \par Variables Description: + * \par + * \li \c testInput_f32 array of input angle in radians + * \li \c testOutput stores sum of the squares of sine and cosine values of input angle + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_cos_f32() + * - arm_sin_f32() + * - arm_mult_f32() + * - arm_add_f32() + * + * Refer + * \link arm_sin_cos_example_f32.c \endlink + * + */ + + +/** \example arm_sin_cos_example_f32.c + */ + +#include +#include "arm_math.h" + +/* ---------------------------------------------------------------------- +* Defines each of the tests performed +* ------------------------------------------------------------------- */ +#define MAX_BLOCKSIZE 32 +#define DELTA (0.0001f) + + +/* ---------------------------------------------------------------------- +* Test input data for Floating point sin_cos example for 32-blockSize +* Generated by the MATLAB randn() function +* ------------------------------------------------------------------- */ + +const float32_t testInput_f32[MAX_BLOCKSIZE] = +{ + -1.244916875853235400, -4.793533929171324800, 0.360705030233248850, 0.827929644170887320, -3.299532218312426900, 3.427441903227623800, 3.422401784294607700, -0.108308165334010680, + 0.941943896490312180, 0.502609575000365850, -0.537345278736373500, 2.088817392965764500, -1.693168684143455700, 6.283185307179590700, -0.392545884746175080, 0.327893095115825040, + 3.070147440456292300, 0.170611405884662230, -0.275275082396073010, -2.395492805446796300, 0.847311163536506600, -3.845517018083148800, 2.055818378415868300, 4.672594161978930800, + -1.990923030266425800, 2.469305197656249500, 3.609002606064021000, -4.586736582331667500, -4.147080139136136300, 1.643756718868359500, -1.150866392366494800, 1.985805026477433800 + + +}; + +const float32_t testRefOutput_f32 = 1.000000000; + +/* ---------------------------------------------------------------------- +* Declare Global variables +* ------------------------------------------------------------------- */ +uint32_t blockSize = 32; +float32_t testOutput; +float32_t cosOutput; +float32_t sinOutput; +float32_t cosSquareOutput; +float32_t sinSquareOutput; + +/* ---------------------------------------------------------------------- +* Max magnitude FFT Bin test +* ------------------------------------------------------------------- */ + +arm_status status; + +int32_t main(void) +{ + float32_t diff; + uint32_t i; + + for(i=0; i< blockSize; i++) + { + cosOutput = arm_cos_f32(testInput_f32[i]); + sinOutput = arm_sin_f32(testInput_f32[i]); + + arm_mult_f32(&cosOutput, &cosOutput, &cosSquareOutput, 1); + arm_mult_f32(&sinOutput, &sinOutput, &sinSquareOutput, 1); + + arm_add_f32(&cosSquareOutput, &sinSquareOutput, &testOutput, 1); + + /* absolute value of difference between ref and test */ + diff = fabsf(testRefOutput_f32 - testOutput); + + /* Comparison of sin_cos value with reference */ + if (diff > DELTA) + { + status = ARM_MATH_TEST_FAILURE; + } + + if ( status == ARM_MATH_TEST_FAILURE) + { + while (1); + } + + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/Abstract.txt b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/Abstract.txt new file mode 100644 index 0000000..4dc03b8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/Abstract.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_variance_example for + Cortex-M0, Cortex-M3, Cortex-M4 with FPU and Cortex-M7 with single precision FPU. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/arm_variance_example_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/arm_variance_example_f32.c new file mode 100644 index 0000000..78a0681 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Examples/ARM/arm_variance_example/arm_variance_example_f32.c @@ -0,0 +1,204 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2012 ARM Limited. All rights reserved. +* +* $Date: 17. January 2013 +* $Revision: V1.4.0 +* +* Project: CMSIS DSP Library +* Title: arm_variance_example_f32.c +* +* Description: Example code demonstrating variance calculation of input sequence. +* +* Target Processor: Cortex-M4/Cortex-M3 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup VarianceExample Variance Example + * + * \par Description: + * \par + * Demonstrates the use of Basic Math and Support Functions to calculate the variance of an + * input sequence with N samples. Uniformly distributed white noise is taken as input. + * + * \par Algorithm: + * \par + * The variance of a sequence is the mean of the squared deviation of the sequence from its mean. + * \par + * This is denoted by the following equation: + *
 variance = ((x[0] - x') * (x[0] - x') + (x[1] - x') * (x[1] - x') + ... + * (x[n-1] - x') * (x[n-1] - x')) / (N-1)
+ * where, x[n] is the input sequence, N is the number of input samples, and + * x' is the mean value of the input sequence, x[n]. + * \par + * The mean value x' is defined as: + *
 x' = (x[0] + x[1] + ... + x[n-1]) / N
+ * + * \par Block Diagram: + * \par + * \image html Variance.gif + * + * + * \par Variables Description: + * \par + * \li \c testInput_f32 points to the input data + * \li \c wire1, \c wir2, \c wire3 temporary buffers + * \li \c blockSize number of samples processed at a time + * \li \c refVarianceOut reference variance value + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_dot_prod_f32() + * - arm_mult_f32() + * - arm_sub_f32() + * - arm_fill_f32() + * - arm_copy_f32() + * + * Refer + * \link arm_variance_example_f32.c \endlink + * + */ + + +/** \example arm_variance_example_f32.c + */ +#include +#include "arm_math.h" + +/* ---------------------------------------------------------------------- +* Defines each of the tests performed +* ------------------------------------------------------------------- */ +#define MAX_BLOCKSIZE 32 +#define DELTA (0.000001f) + + +/* ---------------------------------------------------------------------- +* Declare I/O buffers +* ------------------------------------------------------------------- */ +float32_t wire1[MAX_BLOCKSIZE]; +float32_t wire2[MAX_BLOCKSIZE]; +float32_t wire3[MAX_BLOCKSIZE]; + +/* ---------------------------------------------------------------------- +* Test input data for Floating point Variance example for 32-blockSize +* Generated by the MATLAB randn() function +* ------------------------------------------------------------------- */ + +float32_t testInput_f32[32] = +{ + -0.432564811528221, -1.665584378238097, 0.125332306474831, 0.287676420358549, + -1.146471350681464, 1.190915465642999, 1.189164201652103, -0.037633276593318, + 0.327292361408654, 0.174639142820925, -0.186708577681439, 0.725790548293303, + -0.588316543014189, 2.183185818197101, -0.136395883086596, 0.113931313520810, + 1.066768211359189, 0.059281460523605, -0.095648405483669, -0.832349463650022, + 0.294410816392640, -1.336181857937804, 0.714324551818952, 1.623562064446271, + -0.691775701702287, 0.857996672828263, 1.254001421602532, -1.593729576447477, + -1.440964431901020, 0.571147623658178, -0.399885577715363, 0.689997375464345 + +}; + +/* ---------------------------------------------------------------------- +* Declare Global variables +* ------------------------------------------------------------------- */ +uint32_t blockSize = 32; +float32_t refVarianceOut = 0.903941793931839; + +/* ---------------------------------------------------------------------- +* Variance calculation test +* ------------------------------------------------------------------- */ + +int32_t main(void) +{ + arm_status status; + float32_t mean, oneByBlockSize; + float32_t variance; + float32_t diff; + + status = ARM_MATH_SUCCESS; + + /* Calculation of mean value of input */ + + /* x' = 1/blockSize * (x(0)* 1 + x(1) * 1 + ... + x(n-1) * 1) */ + + /* Fill wire1 buffer with 1.0 value */ + arm_fill_f32(1.0, wire1, blockSize); + + /* Calculate the dot product of wire1 and wire2 */ + /* (x(0)* 1 + x(1) * 1 + ...+ x(n-1) * 1) */ + arm_dot_prod_f32(testInput_f32, wire1, blockSize, &mean); + + /* Calculation of 1/blockSize */ + oneByBlockSize = 1.0 / (blockSize); + + /* 1/blockSize * (x(0)* 1 + x(1) * 1 + ... + x(n-1) * 1) */ + arm_mult_f32(&mean, &oneByBlockSize, &mean, 1); + + + /* Calculation of variance value of input */ + + /* (1/blockSize) * (x(0) - x') * (x(0) - x') + (x(1) - x') * (x(1) - x') + ... + (x(n-1) - x') * (x(n-1) - x') */ + + /* Fill wire2 with mean value x' */ + arm_fill_f32(mean, wire2, blockSize); + + /* wire3 contains (x-x') */ + arm_sub_f32(testInput_f32, wire2, wire3, blockSize); + + /* wire2 contains (x-x') */ + arm_copy_f32(wire3, wire2, blockSize); + + /* (x(0) - x') * (x(0) - x') + (x(1) - x') * (x(1) - x') + ... + (x(n-1) - x') * (x(n-1) - x') */ + arm_dot_prod_f32(wire2, wire3, blockSize, &variance); + + /* Calculation of 1/blockSize */ + oneByBlockSize = 1.0 / (blockSize - 1); + + /* Calculation of variance */ + arm_mult_f32(&variance, &oneByBlockSize, &variance, 1); + + /* absolute value of difference between ref and test */ + diff = fabsf(refVarianceOut - variance); + + /* Comparison of variance value with reference */ + if (diff > DELTA) + { + status = ARM_MATH_TEST_FAILURE; + } + + if ( status != ARM_MATH_SUCCESS) + { + while (1); + } + + while (1); /* main function does not return */ +} + + /** \endlink */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Include/arm_common_tables.h b/Chapter04/bare/platform/CMSIS/DSP/Include/arm_common_tables.h new file mode 100644 index 0000000..233f623 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Include/arm_common_tables.h @@ -0,0 +1,121 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_common_tables.h + * Description: Extern declaration for common tables + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef _ARM_COMMON_TABLES_H +#define _ARM_COMMON_TABLES_H + +#include "arm_math.h" + +extern const uint16_t armBitRevTable[1024]; +extern const q15_t armRecipTableQ15[64]; +extern const q31_t armRecipTableQ31[64]; +extern const float32_t twiddleCoef_16[32]; +extern const float32_t twiddleCoef_32[64]; +extern const float32_t twiddleCoef_64[128]; +extern const float32_t twiddleCoef_128[256]; +extern const float32_t twiddleCoef_256[512]; +extern const float32_t twiddleCoef_512[1024]; +extern const float32_t twiddleCoef_1024[2048]; +extern const float32_t twiddleCoef_2048[4096]; +extern const float32_t twiddleCoef_4096[8192]; +#define twiddleCoef twiddleCoef_4096 +extern const q31_t twiddleCoef_16_q31[24]; +extern const q31_t twiddleCoef_32_q31[48]; +extern const q31_t twiddleCoef_64_q31[96]; +extern const q31_t twiddleCoef_128_q31[192]; +extern const q31_t twiddleCoef_256_q31[384]; +extern const q31_t twiddleCoef_512_q31[768]; +extern const q31_t twiddleCoef_1024_q31[1536]; +extern const q31_t twiddleCoef_2048_q31[3072]; +extern const q31_t twiddleCoef_4096_q31[6144]; +extern const q15_t twiddleCoef_16_q15[24]; +extern const q15_t twiddleCoef_32_q15[48]; +extern const q15_t twiddleCoef_64_q15[96]; +extern const q15_t twiddleCoef_128_q15[192]; +extern const q15_t twiddleCoef_256_q15[384]; +extern const q15_t twiddleCoef_512_q15[768]; +extern const q15_t twiddleCoef_1024_q15[1536]; +extern const q15_t twiddleCoef_2048_q15[3072]; +extern const q15_t twiddleCoef_4096_q15[6144]; +extern const float32_t twiddleCoef_rfft_32[32]; +extern const float32_t twiddleCoef_rfft_64[64]; +extern const float32_t twiddleCoef_rfft_128[128]; +extern const float32_t twiddleCoef_rfft_256[256]; +extern const float32_t twiddleCoef_rfft_512[512]; +extern const float32_t twiddleCoef_rfft_1024[1024]; +extern const float32_t twiddleCoef_rfft_2048[2048]; +extern const float32_t twiddleCoef_rfft_4096[4096]; + +/* floating-point bit reversal tables */ +#define ARMBITREVINDEXTABLE_16_TABLE_LENGTH ((uint16_t)20) +#define ARMBITREVINDEXTABLE_32_TABLE_LENGTH ((uint16_t)48) +#define ARMBITREVINDEXTABLE_64_TABLE_LENGTH ((uint16_t)56) +#define ARMBITREVINDEXTABLE_128_TABLE_LENGTH ((uint16_t)208) +#define ARMBITREVINDEXTABLE_256_TABLE_LENGTH ((uint16_t)440) +#define ARMBITREVINDEXTABLE_512_TABLE_LENGTH ((uint16_t)448) +#define ARMBITREVINDEXTABLE_1024_TABLE_LENGTH ((uint16_t)1800) +#define ARMBITREVINDEXTABLE_2048_TABLE_LENGTH ((uint16_t)3808) +#define ARMBITREVINDEXTABLE_4096_TABLE_LENGTH ((uint16_t)4032) + +extern const uint16_t armBitRevIndexTable16[ARMBITREVINDEXTABLE_16_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable32[ARMBITREVINDEXTABLE_32_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable64[ARMBITREVINDEXTABLE_64_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable128[ARMBITREVINDEXTABLE_128_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable256[ARMBITREVINDEXTABLE_256_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable512[ARMBITREVINDEXTABLE_512_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable1024[ARMBITREVINDEXTABLE_1024_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable2048[ARMBITREVINDEXTABLE_2048_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable4096[ARMBITREVINDEXTABLE_4096_TABLE_LENGTH]; + +/* fixed-point bit reversal tables */ +#define ARMBITREVINDEXTABLE_FIXED_16_TABLE_LENGTH ((uint16_t)12) +#define ARMBITREVINDEXTABLE_FIXED_32_TABLE_LENGTH ((uint16_t)24) +#define ARMBITREVINDEXTABLE_FIXED_64_TABLE_LENGTH ((uint16_t)56) +#define ARMBITREVINDEXTABLE_FIXED_128_TABLE_LENGTH ((uint16_t)112) +#define ARMBITREVINDEXTABLE_FIXED_256_TABLE_LENGTH ((uint16_t)240) +#define ARMBITREVINDEXTABLE_FIXED_512_TABLE_LENGTH ((uint16_t)480) +#define ARMBITREVINDEXTABLE_FIXED_1024_TABLE_LENGTH ((uint16_t)992) +#define ARMBITREVINDEXTABLE_FIXED_2048_TABLE_LENGTH ((uint16_t)1984) +#define ARMBITREVINDEXTABLE_FIXED_4096_TABLE_LENGTH ((uint16_t)4032) + +extern const uint16_t armBitRevIndexTable_fixed_16[ARMBITREVINDEXTABLE_FIXED_16_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_32[ARMBITREVINDEXTABLE_FIXED_32_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_64[ARMBITREVINDEXTABLE_FIXED_64_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_128[ARMBITREVINDEXTABLE_FIXED_128_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_256[ARMBITREVINDEXTABLE_FIXED_256_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_512[ARMBITREVINDEXTABLE_FIXED_512_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_1024[ARMBITREVINDEXTABLE_FIXED_1024_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_2048[ARMBITREVINDEXTABLE_FIXED_2048_TABLE_LENGTH]; +extern const uint16_t armBitRevIndexTable_fixed_4096[ARMBITREVINDEXTABLE_FIXED_4096_TABLE_LENGTH]; + +/* Tables for Fast Math Sine and Cosine */ +extern const float32_t sinTable_f32[FAST_MATH_TABLE_SIZE + 1]; +extern const q31_t sinTable_q31[FAST_MATH_TABLE_SIZE + 1]; +extern const q15_t sinTable_q15[FAST_MATH_TABLE_SIZE + 1]; + +#endif /* ARM_COMMON_TABLES_H */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Include/arm_const_structs.h b/Chapter04/bare/platform/CMSIS/DSP/Include/arm_const_structs.h new file mode 100644 index 0000000..677073e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Include/arm_const_structs.h @@ -0,0 +1,66 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_const_structs.h + * Description: Constant structs that are initialized for user convenience. + * For example, some can be given as arguments to the arm_cfft_f32() function. + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef _ARM_CONST_STRUCTS_H +#define _ARM_CONST_STRUCTS_H + +#include "arm_math.h" +#include "arm_common_tables.h" + + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len16; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len32; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len64; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len128; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len256; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len512; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len1024; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len2048; + extern const arm_cfft_instance_f32 arm_cfft_sR_f32_len4096; + + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len16; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len32; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len64; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len128; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len256; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len512; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len1024; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len2048; + extern const arm_cfft_instance_q31 arm_cfft_sR_q31_len4096; + + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len16; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len32; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len64; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len128; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len256; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len512; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len1024; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len2048; + extern const arm_cfft_instance_q15 arm_cfft_sR_q15_len4096; + +#endif diff --git a/Chapter04/bare/platform/CMSIS/DSP/Include/arm_math.h b/Chapter04/bare/platform/CMSIS/DSP/Include/arm_math.h new file mode 100644 index 0000000..997aeae --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Include/arm_math.h @@ -0,0 +1,7157 @@ +/****************************************************************************** + * @file arm_math.h + * @brief Public header file for CMSIS DSP LibraryU + * @version V1.5.3 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/** + \mainpage CMSIS DSP Software Library + * + * Introduction + * ------------ + * + * This user manual describes the CMSIS DSP software library, + * a suite of common signal processing functions for use on Cortex-M processor based devices. + * + * The library is divided into a number of functions each covering a specific category: + * - Basic math functions + * - Fast math functions + * - Complex math functions + * - Filters + * - Matrix functions + * - Transforms + * - Motor control functions + * - Statistical functions + * - Support functions + * - Interpolation functions + * + * The library has separate functions for operating on 8-bit integers, 16-bit integers, + * 32-bit integer and 32-bit floating-point values. + * + * Using the Library + * ------------ + * + * The library installer contains prebuilt versions of the libraries in the Lib folder. + * - arm_cortexM7lfdp_math.lib (Cortex-M7, Little endian, Double Precision Floating Point Unit) + * - arm_cortexM7bfdp_math.lib (Cortex-M7, Big endian, Double Precision Floating Point Unit) + * - arm_cortexM7lfsp_math.lib (Cortex-M7, Little endian, Single Precision Floating Point Unit) + * - arm_cortexM7bfsp_math.lib (Cortex-M7, Big endian and Single Precision Floating Point Unit on) + * - arm_cortexM7l_math.lib (Cortex-M7, Little endian) + * - arm_cortexM7b_math.lib (Cortex-M7, Big endian) + * - arm_cortexM4lf_math.lib (Cortex-M4, Little endian, Floating Point Unit) + * - arm_cortexM4bf_math.lib (Cortex-M4, Big endian, Floating Point Unit) + * - arm_cortexM4l_math.lib (Cortex-M4, Little endian) + * - arm_cortexM4b_math.lib (Cortex-M4, Big endian) + * - arm_cortexM3l_math.lib (Cortex-M3, Little endian) + * - arm_cortexM3b_math.lib (Cortex-M3, Big endian) + * - arm_cortexM0l_math.lib (Cortex-M0 / Cortex-M0+, Little endian) + * - arm_cortexM0b_math.lib (Cortex-M0 / Cortex-M0+, Big endian) + * - arm_ARMv8MBLl_math.lib (Armv8-M Baseline, Little endian) + * - arm_ARMv8MMLl_math.lib (Armv8-M Mainline, Little endian) + * - arm_ARMv8MMLlfsp_math.lib (Armv8-M Mainline, Little endian, Single Precision Floating Point Unit) + * - arm_ARMv8MMLld_math.lib (Armv8-M Mainline, Little endian, DSP instructions) + * - arm_ARMv8MMLldfsp_math.lib (Armv8-M Mainline, Little endian, DSP instructions, Single Precision Floating Point Unit) + * + * The library functions are declared in the public file arm_math.h which is placed in the Include folder. + * Simply include this file and link the appropriate library in the application and begin calling the library functions. The Library supports single + * public header file arm_math.h for Cortex-M cores with little endian and big endian. Same header file will be used for floating point unit(FPU) variants. + * Define the appropriate preprocessor macro ARM_MATH_CM7 or ARM_MATH_CM4 or ARM_MATH_CM3 or + * ARM_MATH_CM0 or ARM_MATH_CM0PLUS depending on the target processor in the application. + * For Armv8-M cores define preprocessor macro ARM_MATH_ARMV8MBL or ARM_MATH_ARMV8MML. + * Set preprocessor macro __DSP_PRESENT if Armv8-M Mainline core supports DSP instructions. + * + * + * Examples + * -------- + * + * The library ships with a number of examples which demonstrate how to use the library functions. + * + * Toolchain Support + * ------------ + * + * The library has been developed and tested with MDK version 5.14.0.0 + * The library is being tested in GCC and IAR toolchains and updates on this activity will be made available shortly. + * + * Building the Library + * ------------ + * + * The library installer contains a project file to rebuild libraries on MDK toolchain in the CMSIS\\DSP_Lib\\Source\\ARM folder. + * - arm_cortexM_math.uvprojx + * + * + * The libraries can be built by opening the arm_cortexM_math.uvprojx project in MDK-ARM, selecting a specific target, and defining the optional preprocessor macros detailed above. + * + * Preprocessor Macros + * ------------ + * + * Each library project have different preprocessor macros. + * + * - UNALIGNED_SUPPORT_DISABLE: + * + * Define macro UNALIGNED_SUPPORT_DISABLE, If the silicon does not support unaligned memory access + * + * - ARM_MATH_BIG_ENDIAN: + * + * Define macro ARM_MATH_BIG_ENDIAN to build the library for big endian targets. By default library builds for little endian targets. + * + * - ARM_MATH_MATRIX_CHECK: + * + * Define macro ARM_MATH_MATRIX_CHECK for checking on the input and output sizes of matrices + * + * - ARM_MATH_ROUNDING: + * + * Define macro ARM_MATH_ROUNDING for rounding on support functions + * + * - ARM_MATH_CMx: + * + * Define macro ARM_MATH_CM4 for building the library on Cortex-M4 target, ARM_MATH_CM3 for building library on Cortex-M3 target + * and ARM_MATH_CM0 for building library on Cortex-M0 target, ARM_MATH_CM0PLUS for building library on Cortex-M0+ target, and + * ARM_MATH_CM7 for building the library on cortex-M7. + * + * - ARM_MATH_ARMV8MxL: + * + * Define macro ARM_MATH_ARMV8MBL for building the library on Armv8-M Baseline target, ARM_MATH_ARMV8MML for building library + * on Armv8-M Mainline target. + * + * - __FPU_PRESENT: + * + * Initialize macro __FPU_PRESENT = 1 when building on FPU supported Targets. Enable this macro for floating point libraries. + * + * - __DSP_PRESENT: + * + * Initialize macro __DSP_PRESENT = 1 when Armv8-M Mainline core supports DSP instructions. + * + *
+ * CMSIS-DSP in ARM::CMSIS Pack + * ----------------------------- + * + * The following files relevant to CMSIS-DSP are present in the ARM::CMSIS Pack directories: + * |File/Folder |Content | + * |------------------------------|------------------------------------------------------------------------| + * |\b CMSIS\\Documentation\\DSP | This documentation | + * |\b CMSIS\\DSP_Lib | Software license agreement (license.txt) | + * |\b CMSIS\\DSP_Lib\\Examples | Example projects demonstrating the usage of the library functions | + * |\b CMSIS\\DSP_Lib\\Source | Source files for rebuilding the library | + * + *
+ * Revision History of CMSIS-DSP + * ------------ + * Please refer to \ref ChangeLog_pg. + * + * Copyright Notice + * ------------ + * + * Copyright (C) 2010-2015 Arm Limited. All rights reserved. + */ + + +/** + * @defgroup groupMath Basic Math Functions + */ + +/** + * @defgroup groupFastMath Fast Math Functions + * This set of functions provides a fast approximation to sine, cosine, and square root. + * As compared to most of the other functions in the CMSIS math library, the fast math functions + * operate on individual values and not arrays. + * There are separate functions for Q15, Q31, and floating-point data. + * + */ + +/** + * @defgroup groupCmplxMath Complex Math Functions + * This set of functions operates on complex data vectors. + * The data in the complex arrays is stored in an interleaved fashion + * (real, imag, real, imag, ...). + * In the API functions, the number of samples in a complex array refers + * to the number of complex values; the array contains twice this number of + * real values. + */ + +/** + * @defgroup groupFilters Filtering Functions + */ + +/** + * @defgroup groupMatrix Matrix Functions + * + * This set of functions provides basic matrix math operations. + * The functions operate on matrix data structures. For example, + * the type + * definition for the floating-point matrix structure is shown + * below: + *
+ *     typedef struct
+ *     {
+ *       uint16_t numRows;     // number of rows of the matrix.
+ *       uint16_t numCols;     // number of columns of the matrix.
+ *       float32_t *pData;     // points to the data of the matrix.
+ *     } arm_matrix_instance_f32;
+ * 
+ * There are similar definitions for Q15 and Q31 data types. + * + * The structure specifies the size of the matrix and then points to + * an array of data. The array is of size numRows X numCols + * and the values are arranged in row order. That is, the + * matrix element (i, j) is stored at: + *
+ *     pData[i*numCols + j]
+ * 
+ * + * \par Init Functions + * There is an associated initialization function for each type of matrix + * data structure. + * The initialization function sets the values of the internal structure fields. + * Refer to the function arm_mat_init_f32(), arm_mat_init_q31() + * and arm_mat_init_q15() for floating-point, Q31 and Q15 types, respectively. + * + * \par + * Use of the initialization function is optional. However, if initialization function is used + * then the instance structure cannot be placed into a const data section. + * To place the instance structure in a const data + * section, manually initialize the data structure. For example: + *
+ * arm_matrix_instance_f32 S = {nRows, nColumns, pData};
+ * arm_matrix_instance_q31 S = {nRows, nColumns, pData};
+ * arm_matrix_instance_q15 S = {nRows, nColumns, pData};
+ * 
+ * where nRows specifies the number of rows, nColumns + * specifies the number of columns, and pData points to the + * data array. + * + * \par Size Checking + * By default all of the matrix functions perform size checking on the input and + * output matrices. For example, the matrix addition function verifies that the + * two input matrices and the output matrix all have the same number of rows and + * columns. If the size check fails the functions return: + *
+ *     ARM_MATH_SIZE_MISMATCH
+ * 
+ * Otherwise the functions return + *
+ *     ARM_MATH_SUCCESS
+ * 
+ * There is some overhead associated with this matrix size checking. + * The matrix size checking is enabled via the \#define + *
+ *     ARM_MATH_MATRIX_CHECK
+ * 
+ * within the library project settings. By default this macro is defined + * and size checking is enabled. By changing the project settings and + * undefining this macro size checking is eliminated and the functions + * run a bit faster. With size checking disabled the functions always + * return ARM_MATH_SUCCESS. + */ + +/** + * @defgroup groupTransforms Transform Functions + */ + +/** + * @defgroup groupController Controller Functions + */ + +/** + * @defgroup groupStats Statistics Functions + */ +/** + * @defgroup groupSupport Support Functions + */ + +/** + * @defgroup groupInterpolation Interpolation Functions + * These functions perform 1- and 2-dimensional interpolation of data. + * Linear interpolation is used for 1-dimensional data and + * bilinear interpolation is used for 2-dimensional data. + */ + +/** + * @defgroup groupExamples Examples + */ +#ifndef _ARM_MATH_H +#define _ARM_MATH_H + +/* Compiler specific diagnostic adjustment */ +#if defined ( __CC_ARM ) + +#elif defined ( __ARMCC_VERSION ) && ( __ARMCC_VERSION >= 6010050 ) + +#elif defined ( __GNUC__ ) +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wsign-conversion" +#pragma GCC diagnostic ignored "-Wconversion" +#pragma GCC diagnostic ignored "-Wunused-parameter" + +#elif defined ( __ICCARM__ ) + +#elif defined ( __TI_ARM__ ) + +#elif defined ( __CSMC__ ) + +#elif defined ( __TASKING__ ) + +#else + #error Unknown compiler +#endif + + +#define __CMSIS_GENERIC /* disable NVIC and Systick functions */ + +#if defined(ARM_MATH_CM7) + #include "core_cm7.h" + #define ARM_MATH_DSP +#elif defined (ARM_MATH_CM4) + #include "core_cm4.h" + #define ARM_MATH_DSP +#elif defined (ARM_MATH_CM3) + #include "core_cm3.h" +#elif defined (ARM_MATH_CM0) + #include "core_cm0.h" + #define ARM_MATH_CM0_FAMILY +#elif defined (ARM_MATH_CM0PLUS) + #include "core_cm0plus.h" + #define ARM_MATH_CM0_FAMILY +#elif defined (ARM_MATH_ARMV8MBL) + #include "core_armv8mbl.h" + #define ARM_MATH_CM0_FAMILY +#elif defined (ARM_MATH_ARMV8MML) + #include "core_armv8mml.h" + #if (defined (__DSP_PRESENT) && (__DSP_PRESENT == 1)) + #define ARM_MATH_DSP + #endif +#else + #error "Define according the used Cortex core ARM_MATH_CM7, ARM_MATH_CM4, ARM_MATH_CM3, ARM_MATH_CM0PLUS, ARM_MATH_CM0, ARM_MATH_ARMV8MBL, ARM_MATH_ARMV8MML" +#endif + +#undef __CMSIS_GENERIC /* enable NVIC and Systick functions */ +#include "string.h" +#include "math.h" +#ifdef __cplusplus +extern "C" +{ +#endif + + + /** + * @brief Macros required for reciprocal calculation in Normalized LMS + */ + +#define DELTA_Q31 (0x100) +#define DELTA_Q15 0x5 +#define INDEX_MASK 0x0000003F +#ifndef PI + #define PI 3.14159265358979f +#endif + + /** + * @brief Macros required for SINE and COSINE Fast math approximations + */ + +#define FAST_MATH_TABLE_SIZE 512 +#define FAST_MATH_Q31_SHIFT (32 - 10) +#define FAST_MATH_Q15_SHIFT (16 - 10) +#define CONTROLLER_Q31_SHIFT (32 - 9) +#define TABLE_SPACING_Q31 0x400000 +#define TABLE_SPACING_Q15 0x80 + + /** + * @brief Macros required for SINE and COSINE Controller functions + */ + /* 1.31(q31) Fixed value of 2/360 */ + /* -1 to +1 is divided into 360 values so total spacing is (2/360) */ +#define INPUT_SPACING 0xB60B61 + + /** + * @brief Macro for Unaligned Support + */ +#ifndef UNALIGNED_SUPPORT_DISABLE + #define ALIGN4 +#else + #if defined (__GNUC__) + #define ALIGN4 __attribute__((aligned(4))) + #else + #define ALIGN4 __align(4) + #endif +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /** + * @brief Error status returned by some functions in the library. + */ + + typedef enum + { + ARM_MATH_SUCCESS = 0, /**< No error */ + ARM_MATH_ARGUMENT_ERROR = -1, /**< One or more arguments are incorrect */ + ARM_MATH_LENGTH_ERROR = -2, /**< Length of data buffer is incorrect */ + ARM_MATH_SIZE_MISMATCH = -3, /**< Size of matrices is not compatible with the operation. */ + ARM_MATH_NANINF = -4, /**< Not-a-number (NaN) or infinity is generated */ + ARM_MATH_SINGULAR = -5, /**< Generated by matrix inversion if the input matrix is singular and cannot be inverted. */ + ARM_MATH_TEST_FAILURE = -6 /**< Test Failed */ + } arm_status; + + /** + * @brief 8-bit fractional data type in 1.7 format. + */ + typedef int8_t q7_t; + + /** + * @brief 16-bit fractional data type in 1.15 format. + */ + typedef int16_t q15_t; + + /** + * @brief 32-bit fractional data type in 1.31 format. + */ + typedef int32_t q31_t; + + /** + * @brief 64-bit fractional data type in 1.63 format. + */ + typedef int64_t q63_t; + + /** + * @brief 32-bit floating-point type definition. + */ + typedef float float32_t; + + /** + * @brief 64-bit floating-point type definition. + */ + typedef double float64_t; + + /** + * @brief definition to read/write two 16 bit values. + */ +#if defined ( __CC_ARM ) + #define __SIMD32_TYPE int32_t __packed + #define CMSIS_UNUSED __attribute__((unused)) + #define CMSIS_INLINE __attribute__((always_inline)) + +#elif defined ( __ARMCC_VERSION ) && ( __ARMCC_VERSION >= 6010050 ) + #define __SIMD32_TYPE int32_t + #define CMSIS_UNUSED __attribute__((unused)) + #define CMSIS_INLINE __attribute__((always_inline)) + +#elif defined ( __GNUC__ ) + #define __SIMD32_TYPE int32_t + #define CMSIS_UNUSED __attribute__((unused)) + #define CMSIS_INLINE __attribute__((always_inline)) + +#elif defined ( __ICCARM__ ) + #define __SIMD32_TYPE int32_t __packed + #define CMSIS_UNUSED + #define CMSIS_INLINE + +#elif defined ( __TI_ARM__ ) + #define __SIMD32_TYPE int32_t + #define CMSIS_UNUSED __attribute__((unused)) + #define CMSIS_INLINE + +#elif defined ( __CSMC__ ) + #define __SIMD32_TYPE int32_t + #define CMSIS_UNUSED + #define CMSIS_INLINE + +#elif defined ( __TASKING__ ) + #define __SIMD32_TYPE __unaligned int32_t + #define CMSIS_UNUSED + #define CMSIS_INLINE + +#else + #error Unknown compiler +#endif + +#define __SIMD32(addr) (*(__SIMD32_TYPE **) & (addr)) +#define __SIMD32_CONST(addr) ((__SIMD32_TYPE *)(addr)) +#define _SIMD32_OFFSET(addr) (*(__SIMD32_TYPE *) (addr)) +#define __SIMD64(addr) (*(int64_t **) & (addr)) + +#if !defined (ARM_MATH_DSP) + /** + * @brief definition to pack two 16 bit values. + */ +#define __PKHBT(ARG1, ARG2, ARG3) ( (((int32_t)(ARG1) << 0) & (int32_t)0x0000FFFF) | \ + (((int32_t)(ARG2) << ARG3) & (int32_t)0xFFFF0000) ) +#define __PKHTB(ARG1, ARG2, ARG3) ( (((int32_t)(ARG1) << 0) & (int32_t)0xFFFF0000) | \ + (((int32_t)(ARG2) >> ARG3) & (int32_t)0x0000FFFF) ) + +#endif /* !defined (ARM_MATH_DSP) */ + + /** + * @brief definition to pack four 8 bit values. + */ +#ifndef ARM_MATH_BIG_ENDIAN + +#define __PACKq7(v0,v1,v2,v3) ( (((int32_t)(v0) << 0) & (int32_t)0x000000FF) | \ + (((int32_t)(v1) << 8) & (int32_t)0x0000FF00) | \ + (((int32_t)(v2) << 16) & (int32_t)0x00FF0000) | \ + (((int32_t)(v3) << 24) & (int32_t)0xFF000000) ) +#else + +#define __PACKq7(v0,v1,v2,v3) ( (((int32_t)(v3) << 0) & (int32_t)0x000000FF) | \ + (((int32_t)(v2) << 8) & (int32_t)0x0000FF00) | \ + (((int32_t)(v1) << 16) & (int32_t)0x00FF0000) | \ + (((int32_t)(v0) << 24) & (int32_t)0xFF000000) ) + +#endif + + + /** + * @brief Clips Q63 to Q31 values. + */ + CMSIS_INLINE __STATIC_INLINE q31_t clip_q63_to_q31( + q63_t x) + { + return ((q31_t) (x >> 32) != ((q31_t) x >> 31)) ? + ((0x7FFFFFFF ^ ((q31_t) (x >> 63)))) : (q31_t) x; + } + + /** + * @brief Clips Q63 to Q15 values. + */ + CMSIS_INLINE __STATIC_INLINE q15_t clip_q63_to_q15( + q63_t x) + { + return ((q31_t) (x >> 32) != ((q31_t) x >> 31)) ? + ((0x7FFF ^ ((q15_t) (x >> 63)))) : (q15_t) (x >> 15); + } + + /** + * @brief Clips Q31 to Q7 values. + */ + CMSIS_INLINE __STATIC_INLINE q7_t clip_q31_to_q7( + q31_t x) + { + return ((q31_t) (x >> 24) != ((q31_t) x >> 23)) ? + ((0x7F ^ ((q7_t) (x >> 31)))) : (q7_t) x; + } + + /** + * @brief Clips Q31 to Q15 values. + */ + CMSIS_INLINE __STATIC_INLINE q15_t clip_q31_to_q15( + q31_t x) + { + return ((q31_t) (x >> 16) != ((q31_t) x >> 15)) ? + ((0x7FFF ^ ((q15_t) (x >> 31)))) : (q15_t) x; + } + + /** + * @brief Multiplies 32 X 64 and returns 32 bit result in 2.30 format. + */ + + CMSIS_INLINE __STATIC_INLINE q63_t mult32x64( + q63_t x, + q31_t y) + { + return ((((q63_t) (x & 0x00000000FFFFFFFF) * y) >> 32) + + (((q63_t) (x >> 32) * y))); + } + + /** + * @brief Function to Calculates 1/in (reciprocal) value of Q31 Data type. + */ + + CMSIS_INLINE __STATIC_INLINE uint32_t arm_recip_q31( + q31_t in, + q31_t * dst, + q31_t * pRecipTable) + { + q31_t out; + uint32_t tempVal; + uint32_t index, i; + uint32_t signBits; + + if (in > 0) + { + signBits = ((uint32_t) (__CLZ( in) - 1)); + } + else + { + signBits = ((uint32_t) (__CLZ(-in) - 1)); + } + + /* Convert input sample to 1.31 format */ + in = (in << signBits); + + /* calculation of index for initial approximated Val */ + index = (uint32_t)(in >> 24); + index = (index & INDEX_MASK); + + /* 1.31 with exp 1 */ + out = pRecipTable[index]; + + /* calculation of reciprocal value */ + /* running approximation for two iterations */ + for (i = 0U; i < 2U; i++) + { + tempVal = (uint32_t) (((q63_t) in * out) >> 31); + tempVal = 0x7FFFFFFFu - tempVal; + /* 1.31 with exp 1 */ + /* out = (q31_t) (((q63_t) out * tempVal) >> 30); */ + out = clip_q63_to_q31(((q63_t) out * tempVal) >> 30); + } + + /* write output */ + *dst = out; + + /* return num of signbits of out = 1/in value */ + return (signBits + 1U); + } + + + /** + * @brief Function to Calculates 1/in (reciprocal) value of Q15 Data type. + */ + CMSIS_INLINE __STATIC_INLINE uint32_t arm_recip_q15( + q15_t in, + q15_t * dst, + q15_t * pRecipTable) + { + q15_t out = 0; + uint32_t tempVal = 0; + uint32_t index = 0, i = 0; + uint32_t signBits = 0; + + if (in > 0) + { + signBits = ((uint32_t)(__CLZ( in) - 17)); + } + else + { + signBits = ((uint32_t)(__CLZ(-in) - 17)); + } + + /* Convert input sample to 1.15 format */ + in = (in << signBits); + + /* calculation of index for initial approximated Val */ + index = (uint32_t)(in >> 8); + index = (index & INDEX_MASK); + + /* 1.15 with exp 1 */ + out = pRecipTable[index]; + + /* calculation of reciprocal value */ + /* running approximation for two iterations */ + for (i = 0U; i < 2U; i++) + { + tempVal = (uint32_t) (((q31_t) in * out) >> 15); + tempVal = 0x7FFFu - tempVal; + /* 1.15 with exp 1 */ + out = (q15_t) (((q31_t) out * tempVal) >> 14); + /* out = clip_q31_to_q15(((q31_t) out * tempVal) >> 14); */ + } + + /* write output */ + *dst = out; + + /* return num of signbits of out = 1/in value */ + return (signBits + 1); + } + + +/* + * @brief C custom defined intrinsic function for M3 and M0 processors + */ +#if !defined (ARM_MATH_DSP) + + /* + * @brief C custom defined QADD8 for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __QADD8( + uint32_t x, + uint32_t y) + { + q31_t r, s, t, u; + + r = __SSAT(((((q31_t)x << 24) >> 24) + (((q31_t)y << 24) >> 24)), 8) & (int32_t)0x000000FF; + s = __SSAT(((((q31_t)x << 16) >> 24) + (((q31_t)y << 16) >> 24)), 8) & (int32_t)0x000000FF; + t = __SSAT(((((q31_t)x << 8) >> 24) + (((q31_t)y << 8) >> 24)), 8) & (int32_t)0x000000FF; + u = __SSAT(((((q31_t)x ) >> 24) + (((q31_t)y ) >> 24)), 8) & (int32_t)0x000000FF; + + return ((uint32_t)((u << 24) | (t << 16) | (s << 8) | (r ))); + } + + + /* + * @brief C custom defined QSUB8 for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __QSUB8( + uint32_t x, + uint32_t y) + { + q31_t r, s, t, u; + + r = __SSAT(((((q31_t)x << 24) >> 24) - (((q31_t)y << 24) >> 24)), 8) & (int32_t)0x000000FF; + s = __SSAT(((((q31_t)x << 16) >> 24) - (((q31_t)y << 16) >> 24)), 8) & (int32_t)0x000000FF; + t = __SSAT(((((q31_t)x << 8) >> 24) - (((q31_t)y << 8) >> 24)), 8) & (int32_t)0x000000FF; + u = __SSAT(((((q31_t)x ) >> 24) - (((q31_t)y ) >> 24)), 8) & (int32_t)0x000000FF; + + return ((uint32_t)((u << 24) | (t << 16) | (s << 8) | (r ))); + } + + + /* + * @brief C custom defined QADD16 for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __QADD16( + uint32_t x, + uint32_t y) + { +/* q31_t r, s; without initialisation 'arm_offset_q15 test' fails but 'intrinsic' tests pass! for armCC */ + q31_t r = 0, s = 0; + + r = __SSAT(((((q31_t)x << 16) >> 16) + (((q31_t)y << 16) >> 16)), 16) & (int32_t)0x0000FFFF; + s = __SSAT(((((q31_t)x ) >> 16) + (((q31_t)y ) >> 16)), 16) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined SHADD16 for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SHADD16( + uint32_t x, + uint32_t y) + { + q31_t r, s; + + r = (((((q31_t)x << 16) >> 16) + (((q31_t)y << 16) >> 16)) >> 1) & (int32_t)0x0000FFFF; + s = (((((q31_t)x ) >> 16) + (((q31_t)y ) >> 16)) >> 1) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined QSUB16 for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __QSUB16( + uint32_t x, + uint32_t y) + { + q31_t r, s; + + r = __SSAT(((((q31_t)x << 16) >> 16) - (((q31_t)y << 16) >> 16)), 16) & (int32_t)0x0000FFFF; + s = __SSAT(((((q31_t)x ) >> 16) - (((q31_t)y ) >> 16)), 16) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined SHSUB16 for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SHSUB16( + uint32_t x, + uint32_t y) + { + q31_t r, s; + + r = (((((q31_t)x << 16) >> 16) - (((q31_t)y << 16) >> 16)) >> 1) & (int32_t)0x0000FFFF; + s = (((((q31_t)x ) >> 16) - (((q31_t)y ) >> 16)) >> 1) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined QASX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __QASX( + uint32_t x, + uint32_t y) + { + q31_t r, s; + + r = __SSAT(((((q31_t)x << 16) >> 16) - (((q31_t)y ) >> 16)), 16) & (int32_t)0x0000FFFF; + s = __SSAT(((((q31_t)x ) >> 16) + (((q31_t)y << 16) >> 16)), 16) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined SHASX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SHASX( + uint32_t x, + uint32_t y) + { + q31_t r, s; + + r = (((((q31_t)x << 16) >> 16) - (((q31_t)y ) >> 16)) >> 1) & (int32_t)0x0000FFFF; + s = (((((q31_t)x ) >> 16) + (((q31_t)y << 16) >> 16)) >> 1) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined QSAX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __QSAX( + uint32_t x, + uint32_t y) + { + q31_t r, s; + + r = __SSAT(((((q31_t)x << 16) >> 16) + (((q31_t)y ) >> 16)), 16) & (int32_t)0x0000FFFF; + s = __SSAT(((((q31_t)x ) >> 16) - (((q31_t)y << 16) >> 16)), 16) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined SHSAX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SHSAX( + uint32_t x, + uint32_t y) + { + q31_t r, s; + + r = (((((q31_t)x << 16) >> 16) + (((q31_t)y ) >> 16)) >> 1) & (int32_t)0x0000FFFF; + s = (((((q31_t)x ) >> 16) - (((q31_t)y << 16) >> 16)) >> 1) & (int32_t)0x0000FFFF; + + return ((uint32_t)((s << 16) | (r ))); + } + + + /* + * @brief C custom defined SMUSDX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SMUSDX( + uint32_t x, + uint32_t y) + { + return ((uint32_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y ) >> 16)) - + ((((q31_t)x ) >> 16) * (((q31_t)y << 16) >> 16)) )); + } + + /* + * @brief C custom defined SMUADX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SMUADX( + uint32_t x, + uint32_t y) + { + return ((uint32_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y ) >> 16)) + + ((((q31_t)x ) >> 16) * (((q31_t)y << 16) >> 16)) )); + } + + + /* + * @brief C custom defined QADD for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE int32_t __QADD( + int32_t x, + int32_t y) + { + return ((int32_t)(clip_q63_to_q31((q63_t)x + (q31_t)y))); + } + + + /* + * @brief C custom defined QSUB for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE int32_t __QSUB( + int32_t x, + int32_t y) + { + return ((int32_t)(clip_q63_to_q31((q63_t)x - (q31_t)y))); + } + + + /* + * @brief C custom defined SMLAD for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SMLAD( + uint32_t x, + uint32_t y, + uint32_t sum) + { + return ((uint32_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y << 16) >> 16)) + + ((((q31_t)x ) >> 16) * (((q31_t)y ) >> 16)) + + ( ((q31_t)sum ) ) )); + } + + + /* + * @brief C custom defined SMLADX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SMLADX( + uint32_t x, + uint32_t y, + uint32_t sum) + { + return ((uint32_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y ) >> 16)) + + ((((q31_t)x ) >> 16) * (((q31_t)y << 16) >> 16)) + + ( ((q31_t)sum ) ) )); + } + + + /* + * @brief C custom defined SMLSDX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SMLSDX( + uint32_t x, + uint32_t y, + uint32_t sum) + { + return ((uint32_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y ) >> 16)) - + ((((q31_t)x ) >> 16) * (((q31_t)y << 16) >> 16)) + + ( ((q31_t)sum ) ) )); + } + + + /* + * @brief C custom defined SMLALD for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint64_t __SMLALD( + uint32_t x, + uint32_t y, + uint64_t sum) + { +/* return (sum + ((q15_t) (x >> 16) * (q15_t) (y >> 16)) + ((q15_t) x * (q15_t) y)); */ + return ((uint64_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y << 16) >> 16)) + + ((((q31_t)x ) >> 16) * (((q31_t)y ) >> 16)) + + ( ((q63_t)sum ) ) )); + } + + + /* + * @brief C custom defined SMLALDX for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint64_t __SMLALDX( + uint32_t x, + uint32_t y, + uint64_t sum) + { +/* return (sum + ((q15_t) (x >> 16) * (q15_t) y)) + ((q15_t) x * (q15_t) (y >> 16)); */ + return ((uint64_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y ) >> 16)) + + ((((q31_t)x ) >> 16) * (((q31_t)y << 16) >> 16)) + + ( ((q63_t)sum ) ) )); + } + + + /* + * @brief C custom defined SMUAD for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SMUAD( + uint32_t x, + uint32_t y) + { + return ((uint32_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y << 16) >> 16)) + + ((((q31_t)x ) >> 16) * (((q31_t)y ) >> 16)) )); + } + + + /* + * @brief C custom defined SMUSD for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SMUSD( + uint32_t x, + uint32_t y) + { + return ((uint32_t)(((((q31_t)x << 16) >> 16) * (((q31_t)y << 16) >> 16)) - + ((((q31_t)x ) >> 16) * (((q31_t)y ) >> 16)) )); + } + + + /* + * @brief C custom defined SXTB16 for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE uint32_t __SXTB16( + uint32_t x) + { + return ((uint32_t)(((((q31_t)x << 24) >> 24) & (q31_t)0x0000FFFF) | + ((((q31_t)x << 8) >> 8) & (q31_t)0xFFFF0000) )); + } + + /* + * @brief C custom defined SMMLA for M3 and M0 processors + */ + CMSIS_INLINE __STATIC_INLINE int32_t __SMMLA( + int32_t x, + int32_t y, + int32_t sum) + { + return (sum + (int32_t) (((int64_t) x * y) >> 32)); + } + +#endif /* !defined (ARM_MATH_DSP) */ + + + /** + * @brief Instance structure for the Q7 FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of filter coefficients in the filter. */ + q7_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + q7_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + } arm_fir_instance_q7; + + /** + * @brief Instance structure for the Q15 FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of filter coefficients in the filter. */ + q15_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + q15_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + } arm_fir_instance_q15; + + /** + * @brief Instance structure for the Q31 FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of filter coefficients in the filter. */ + q31_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + q31_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + } arm_fir_instance_q31; + + /** + * @brief Instance structure for the floating-point FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of filter coefficients in the filter. */ + float32_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + float32_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + } arm_fir_instance_f32; + + + /** + * @brief Processing function for the Q7 FIR filter. + * @param[in] S points to an instance of the Q7 FIR filter structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_fir_q7( + const arm_fir_instance_q7 * S, + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q7 FIR filter. + * @param[in,out] S points to an instance of the Q7 FIR structure. + * @param[in] numTaps Number of filter coefficients in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of samples that are processed. + */ + void arm_fir_init_q7( + arm_fir_instance_q7 * S, + uint16_t numTaps, + q7_t * pCoeffs, + q7_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q15 FIR filter. + * @param[in] S points to an instance of the Q15 FIR structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_fir_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Processing function for the fast Q15 FIR filter for Cortex-M3 and Cortex-M4. + * @param[in] S points to an instance of the Q15 FIR filter structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_fir_fast_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q15 FIR filter. + * @param[in,out] S points to an instance of the Q15 FIR filter structure. + * @param[in] numTaps Number of filter coefficients in the filter. Must be even and greater than or equal to 4. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of samples that are processed at a time. + * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_ARGUMENT_ERROR if + * numTaps is not a supported value. + */ + arm_status arm_fir_init_q15( + arm_fir_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q31 FIR filter. + * @param[in] S points to an instance of the Q31 FIR filter structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_fir_q31( + const arm_fir_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Processing function for the fast Q31 FIR filter for Cortex-M3 and Cortex-M4. + * @param[in] S points to an instance of the Q31 FIR structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_fir_fast_q31( + const arm_fir_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q31 FIR filter. + * @param[in,out] S points to an instance of the Q31 FIR structure. + * @param[in] numTaps Number of filter coefficients in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of samples that are processed at a time. + */ + void arm_fir_init_q31( + arm_fir_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the floating-point FIR filter. + * @param[in] S points to an instance of the floating-point FIR structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_fir_f32( + const arm_fir_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the floating-point FIR filter. + * @param[in,out] S points to an instance of the floating-point FIR filter structure. + * @param[in] numTaps Number of filter coefficients in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of samples that are processed at a time. + */ + void arm_fir_init_f32( + arm_fir_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + uint32_t blockSize); + + + /** + * @brief Instance structure for the Q15 Biquad cascade filter. + */ + typedef struct + { + int8_t numStages; /**< number of 2nd order stages in the filter. Overall order is 2*numStages. */ + q15_t *pState; /**< Points to the array of state coefficients. The array is of length 4*numStages. */ + q15_t *pCoeffs; /**< Points to the array of coefficients. The array is of length 5*numStages. */ + int8_t postShift; /**< Additional shift, in bits, applied to each output sample. */ + } arm_biquad_casd_df1_inst_q15; + + /** + * @brief Instance structure for the Q31 Biquad cascade filter. + */ + typedef struct + { + uint32_t numStages; /**< number of 2nd order stages in the filter. Overall order is 2*numStages. */ + q31_t *pState; /**< Points to the array of state coefficients. The array is of length 4*numStages. */ + q31_t *pCoeffs; /**< Points to the array of coefficients. The array is of length 5*numStages. */ + uint8_t postShift; /**< Additional shift, in bits, applied to each output sample. */ + } arm_biquad_casd_df1_inst_q31; + + /** + * @brief Instance structure for the floating-point Biquad cascade filter. + */ + typedef struct + { + uint32_t numStages; /**< number of 2nd order stages in the filter. Overall order is 2*numStages. */ + float32_t *pState; /**< Points to the array of state coefficients. The array is of length 4*numStages. */ + float32_t *pCoeffs; /**< Points to the array of coefficients. The array is of length 5*numStages. */ + } arm_biquad_casd_df1_inst_f32; + + + /** + * @brief Processing function for the Q15 Biquad cascade filter. + * @param[in] S points to an instance of the Q15 Biquad cascade structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_df1_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q15 Biquad cascade filter. + * @param[in,out] S points to an instance of the Q15 Biquad cascade structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] postShift Shift to be applied to the output. Varies according to the coefficients format + */ + void arm_biquad_cascade_df1_init_q15( + arm_biquad_casd_df1_inst_q15 * S, + uint8_t numStages, + q15_t * pCoeffs, + q15_t * pState, + int8_t postShift); + + + /** + * @brief Fast but less precise processing function for the Q15 Biquad cascade filter for Cortex-M3 and Cortex-M4. + * @param[in] S points to an instance of the Q15 Biquad cascade structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_df1_fast_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q31 Biquad cascade filter + * @param[in] S points to an instance of the Q31 Biquad cascade structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_df1_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Fast but less precise processing function for the Q31 Biquad cascade filter for Cortex-M3 and Cortex-M4. + * @param[in] S points to an instance of the Q31 Biquad cascade structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_df1_fast_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q31 Biquad cascade filter. + * @param[in,out] S points to an instance of the Q31 Biquad cascade structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] postShift Shift to be applied to the output. Varies according to the coefficients format + */ + void arm_biquad_cascade_df1_init_q31( + arm_biquad_casd_df1_inst_q31 * S, + uint8_t numStages, + q31_t * pCoeffs, + q31_t * pState, + int8_t postShift); + + + /** + * @brief Processing function for the floating-point Biquad cascade filter. + * @param[in] S points to an instance of the floating-point Biquad cascade structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_df1_f32( + const arm_biquad_casd_df1_inst_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the floating-point Biquad cascade filter. + * @param[in,out] S points to an instance of the floating-point Biquad cascade structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + */ + void arm_biquad_cascade_df1_init_f32( + arm_biquad_casd_df1_inst_f32 * S, + uint8_t numStages, + float32_t * pCoeffs, + float32_t * pState); + + + /** + * @brief Instance structure for the floating-point matrix structure. + */ + typedef struct + { + uint16_t numRows; /**< number of rows of the matrix. */ + uint16_t numCols; /**< number of columns of the matrix. */ + float32_t *pData; /**< points to the data of the matrix. */ + } arm_matrix_instance_f32; + + + /** + * @brief Instance structure for the floating-point matrix structure. + */ + typedef struct + { + uint16_t numRows; /**< number of rows of the matrix. */ + uint16_t numCols; /**< number of columns of the matrix. */ + float64_t *pData; /**< points to the data of the matrix. */ + } arm_matrix_instance_f64; + + /** + * @brief Instance structure for the Q15 matrix structure. + */ + typedef struct + { + uint16_t numRows; /**< number of rows of the matrix. */ + uint16_t numCols; /**< number of columns of the matrix. */ + q15_t *pData; /**< points to the data of the matrix. */ + } arm_matrix_instance_q15; + + /** + * @brief Instance structure for the Q31 matrix structure. + */ + typedef struct + { + uint16_t numRows; /**< number of rows of the matrix. */ + uint16_t numCols; /**< number of columns of the matrix. */ + q31_t *pData; /**< points to the data of the matrix. */ + } arm_matrix_instance_q31; + + + /** + * @brief Floating-point matrix addition. + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_add_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + + + /** + * @brief Q15 matrix addition. + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_add_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst); + + + /** + * @brief Q31 matrix addition. + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_add_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + + + /** + * @brief Floating-point, complex, matrix multiplication. + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_cmplx_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + + + /** + * @brief Q15, complex, matrix multiplication. + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_cmplx_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst, + q15_t * pScratch); + + + /** + * @brief Q31, complex, matrix multiplication. + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_cmplx_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + + + /** + * @brief Floating-point matrix transpose. + * @param[in] pSrc points to the input matrix + * @param[out] pDst points to the output matrix + * @return The function returns either ARM_MATH_SIZE_MISMATCH + * or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_trans_f32( + const arm_matrix_instance_f32 * pSrc, + arm_matrix_instance_f32 * pDst); + + + /** + * @brief Q15 matrix transpose. + * @param[in] pSrc points to the input matrix + * @param[out] pDst points to the output matrix + * @return The function returns either ARM_MATH_SIZE_MISMATCH + * or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_trans_q15( + const arm_matrix_instance_q15 * pSrc, + arm_matrix_instance_q15 * pDst); + + + /** + * @brief Q31 matrix transpose. + * @param[in] pSrc points to the input matrix + * @param[out] pDst points to the output matrix + * @return The function returns either ARM_MATH_SIZE_MISMATCH + * or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_trans_q31( + const arm_matrix_instance_q31 * pSrc, + arm_matrix_instance_q31 * pDst); + + + /** + * @brief Floating-point matrix multiplication + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + + + /** + * @brief Q15 matrix multiplication + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @param[in] pState points to the array for storing intermediate results + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst, + q15_t * pState); + + + /** + * @brief Q15 matrix multiplication (fast variant) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @param[in] pState points to the array for storing intermediate results + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_mult_fast_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst, + q15_t * pState); + + + /** + * @brief Q31 matrix multiplication + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + + + /** + * @brief Q31 matrix multiplication (fast variant) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_mult_fast_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + + + /** + * @brief Floating-point matrix subtraction + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_sub_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst); + + + /** + * @brief Q15 matrix subtraction + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_sub_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst); + + + /** + * @brief Q31 matrix subtraction + * @param[in] pSrcA points to the first input matrix structure + * @param[in] pSrcB points to the second input matrix structure + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_sub_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst); + + + /** + * @brief Floating-point matrix scaling. + * @param[in] pSrc points to the input matrix + * @param[in] scale scale factor + * @param[out] pDst points to the output matrix + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_scale_f32( + const arm_matrix_instance_f32 * pSrc, + float32_t scale, + arm_matrix_instance_f32 * pDst); + + + /** + * @brief Q15 matrix scaling. + * @param[in] pSrc points to input matrix + * @param[in] scaleFract fractional portion of the scale factor + * @param[in] shift number of bits to shift the result by + * @param[out] pDst points to output matrix + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_scale_q15( + const arm_matrix_instance_q15 * pSrc, + q15_t scaleFract, + int32_t shift, + arm_matrix_instance_q15 * pDst); + + + /** + * @brief Q31 matrix scaling. + * @param[in] pSrc points to input matrix + * @param[in] scaleFract fractional portion of the scale factor + * @param[in] shift number of bits to shift the result by + * @param[out] pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + arm_status arm_mat_scale_q31( + const arm_matrix_instance_q31 * pSrc, + q31_t scaleFract, + int32_t shift, + arm_matrix_instance_q31 * pDst); + + + /** + * @brief Q31 matrix initialization. + * @param[in,out] S points to an instance of the floating-point matrix structure. + * @param[in] nRows number of rows in the matrix. + * @param[in] nColumns number of columns in the matrix. + * @param[in] pData points to the matrix data array. + */ + void arm_mat_init_q31( + arm_matrix_instance_q31 * S, + uint16_t nRows, + uint16_t nColumns, + q31_t * pData); + + + /** + * @brief Q15 matrix initialization. + * @param[in,out] S points to an instance of the floating-point matrix structure. + * @param[in] nRows number of rows in the matrix. + * @param[in] nColumns number of columns in the matrix. + * @param[in] pData points to the matrix data array. + */ + void arm_mat_init_q15( + arm_matrix_instance_q15 * S, + uint16_t nRows, + uint16_t nColumns, + q15_t * pData); + + + /** + * @brief Floating-point matrix initialization. + * @param[in,out] S points to an instance of the floating-point matrix structure. + * @param[in] nRows number of rows in the matrix. + * @param[in] nColumns number of columns in the matrix. + * @param[in] pData points to the matrix data array. + */ + void arm_mat_init_f32( + arm_matrix_instance_f32 * S, + uint16_t nRows, + uint16_t nColumns, + float32_t * pData); + + + + /** + * @brief Instance structure for the Q15 PID Control. + */ + typedef struct + { + q15_t A0; /**< The derived gain, A0 = Kp + Ki + Kd . */ +#if !defined (ARM_MATH_DSP) + q15_t A1; + q15_t A2; +#else + q31_t A1; /**< The derived gain A1 = -Kp - 2Kd | Kd.*/ +#endif + q15_t state[3]; /**< The state array of length 3. */ + q15_t Kp; /**< The proportional gain. */ + q15_t Ki; /**< The integral gain. */ + q15_t Kd; /**< The derivative gain. */ + } arm_pid_instance_q15; + + /** + * @brief Instance structure for the Q31 PID Control. + */ + typedef struct + { + q31_t A0; /**< The derived gain, A0 = Kp + Ki + Kd . */ + q31_t A1; /**< The derived gain, A1 = -Kp - 2Kd. */ + q31_t A2; /**< The derived gain, A2 = Kd . */ + q31_t state[3]; /**< The state array of length 3. */ + q31_t Kp; /**< The proportional gain. */ + q31_t Ki; /**< The integral gain. */ + q31_t Kd; /**< The derivative gain. */ + } arm_pid_instance_q31; + + /** + * @brief Instance structure for the floating-point PID Control. + */ + typedef struct + { + float32_t A0; /**< The derived gain, A0 = Kp + Ki + Kd . */ + float32_t A1; /**< The derived gain, A1 = -Kp - 2Kd. */ + float32_t A2; /**< The derived gain, A2 = Kd . */ + float32_t state[3]; /**< The state array of length 3. */ + float32_t Kp; /**< The proportional gain. */ + float32_t Ki; /**< The integral gain. */ + float32_t Kd; /**< The derivative gain. */ + } arm_pid_instance_f32; + + + + /** + * @brief Initialization function for the floating-point PID Control. + * @param[in,out] S points to an instance of the PID structure. + * @param[in] resetStateFlag flag to reset the state. 0 = no change in state 1 = reset the state. + */ + void arm_pid_init_f32( + arm_pid_instance_f32 * S, + int32_t resetStateFlag); + + + /** + * @brief Reset function for the floating-point PID Control. + * @param[in,out] S is an instance of the floating-point PID Control structure + */ + void arm_pid_reset_f32( + arm_pid_instance_f32 * S); + + + /** + * @brief Initialization function for the Q31 PID Control. + * @param[in,out] S points to an instance of the Q15 PID structure. + * @param[in] resetStateFlag flag to reset the state. 0 = no change in state 1 = reset the state. + */ + void arm_pid_init_q31( + arm_pid_instance_q31 * S, + int32_t resetStateFlag); + + + /** + * @brief Reset function for the Q31 PID Control. + * @param[in,out] S points to an instance of the Q31 PID Control structure + */ + + void arm_pid_reset_q31( + arm_pid_instance_q31 * S); + + + /** + * @brief Initialization function for the Q15 PID Control. + * @param[in,out] S points to an instance of the Q15 PID structure. + * @param[in] resetStateFlag flag to reset the state. 0 = no change in state 1 = reset the state. + */ + void arm_pid_init_q15( + arm_pid_instance_q15 * S, + int32_t resetStateFlag); + + + /** + * @brief Reset function for the Q15 PID Control. + * @param[in,out] S points to an instance of the q15 PID Control structure + */ + void arm_pid_reset_q15( + arm_pid_instance_q15 * S); + + + /** + * @brief Instance structure for the floating-point Linear Interpolate function. + */ + typedef struct + { + uint32_t nValues; /**< nValues */ + float32_t x1; /**< x1 */ + float32_t xSpacing; /**< xSpacing */ + float32_t *pYData; /**< pointer to the table of Y values */ + } arm_linear_interp_instance_f32; + + /** + * @brief Instance structure for the floating-point bilinear interpolation function. + */ + typedef struct + { + uint16_t numRows; /**< number of rows in the data table. */ + uint16_t numCols; /**< number of columns in the data table. */ + float32_t *pData; /**< points to the data table. */ + } arm_bilinear_interp_instance_f32; + + /** + * @brief Instance structure for the Q31 bilinear interpolation function. + */ + typedef struct + { + uint16_t numRows; /**< number of rows in the data table. */ + uint16_t numCols; /**< number of columns in the data table. */ + q31_t *pData; /**< points to the data table. */ + } arm_bilinear_interp_instance_q31; + + /** + * @brief Instance structure for the Q15 bilinear interpolation function. + */ + typedef struct + { + uint16_t numRows; /**< number of rows in the data table. */ + uint16_t numCols; /**< number of columns in the data table. */ + q15_t *pData; /**< points to the data table. */ + } arm_bilinear_interp_instance_q15; + + /** + * @brief Instance structure for the Q15 bilinear interpolation function. + */ + typedef struct + { + uint16_t numRows; /**< number of rows in the data table. */ + uint16_t numCols; /**< number of columns in the data table. */ + q7_t *pData; /**< points to the data table. */ + } arm_bilinear_interp_instance_q7; + + + /** + * @brief Q7 vector multiplication. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_mult_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q15 vector multiplication. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_mult_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q31 vector multiplication. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_mult_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Floating-point vector multiplication. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_mult_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Instance structure for the Q15 CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + uint8_t ifftFlag; /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */ + uint8_t bitReverseFlag; /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */ + q15_t *pTwiddle; /**< points to the Sin twiddle factor table. */ + uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t twidCoefModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + uint16_t bitRevFactor; /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */ + } arm_cfft_radix2_instance_q15; + +/* Deprecated */ + arm_status arm_cfft_radix2_init_q15( + arm_cfft_radix2_instance_q15 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +/* Deprecated */ + void arm_cfft_radix2_q15( + const arm_cfft_radix2_instance_q15 * S, + q15_t * pSrc); + + + /** + * @brief Instance structure for the Q15 CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + uint8_t ifftFlag; /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */ + uint8_t bitReverseFlag; /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */ + q15_t *pTwiddle; /**< points to the twiddle factor table. */ + uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t twidCoefModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + uint16_t bitRevFactor; /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */ + } arm_cfft_radix4_instance_q15; + +/* Deprecated */ + arm_status arm_cfft_radix4_init_q15( + arm_cfft_radix4_instance_q15 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +/* Deprecated */ + void arm_cfft_radix4_q15( + const arm_cfft_radix4_instance_q15 * S, + q15_t * pSrc); + + /** + * @brief Instance structure for the Radix-2 Q31 CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + uint8_t ifftFlag; /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */ + uint8_t bitReverseFlag; /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */ + q31_t *pTwiddle; /**< points to the Twiddle factor table. */ + uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t twidCoefModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + uint16_t bitRevFactor; /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */ + } arm_cfft_radix2_instance_q31; + +/* Deprecated */ + arm_status arm_cfft_radix2_init_q31( + arm_cfft_radix2_instance_q31 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +/* Deprecated */ + void arm_cfft_radix2_q31( + const arm_cfft_radix2_instance_q31 * S, + q31_t * pSrc); + + /** + * @brief Instance structure for the Q31 CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + uint8_t ifftFlag; /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */ + uint8_t bitReverseFlag; /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */ + q31_t *pTwiddle; /**< points to the twiddle factor table. */ + uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t twidCoefModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + uint16_t bitRevFactor; /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */ + } arm_cfft_radix4_instance_q31; + +/* Deprecated */ + void arm_cfft_radix4_q31( + const arm_cfft_radix4_instance_q31 * S, + q31_t * pSrc); + +/* Deprecated */ + arm_status arm_cfft_radix4_init_q31( + arm_cfft_radix4_instance_q31 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + + /** + * @brief Instance structure for the floating-point CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + uint8_t ifftFlag; /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */ + uint8_t bitReverseFlag; /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */ + float32_t *pTwiddle; /**< points to the Twiddle factor table. */ + uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t twidCoefModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + uint16_t bitRevFactor; /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */ + float32_t onebyfftLen; /**< value of 1/fftLen. */ + } arm_cfft_radix2_instance_f32; + +/* Deprecated */ + arm_status arm_cfft_radix2_init_f32( + arm_cfft_radix2_instance_f32 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +/* Deprecated */ + void arm_cfft_radix2_f32( + const arm_cfft_radix2_instance_f32 * S, + float32_t * pSrc); + + /** + * @brief Instance structure for the floating-point CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + uint8_t ifftFlag; /**< flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. */ + uint8_t bitReverseFlag; /**< flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. */ + float32_t *pTwiddle; /**< points to the Twiddle factor table. */ + uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t twidCoefModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + uint16_t bitRevFactor; /**< bit reversal modifier that supports different size FFTs with the same bit reversal table. */ + float32_t onebyfftLen; /**< value of 1/fftLen. */ + } arm_cfft_radix4_instance_f32; + +/* Deprecated */ + arm_status arm_cfft_radix4_init_f32( + arm_cfft_radix4_instance_f32 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + +/* Deprecated */ + void arm_cfft_radix4_f32( + const arm_cfft_radix4_instance_f32 * S, + float32_t * pSrc); + + /** + * @brief Instance structure for the fixed-point CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + const q15_t *pTwiddle; /**< points to the Twiddle factor table. */ + const uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t bitRevLength; /**< bit reversal table length. */ + } arm_cfft_instance_q15; + +void arm_cfft_q15( + const arm_cfft_instance_q15 * S, + q15_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + + /** + * @brief Instance structure for the fixed-point CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + const q31_t *pTwiddle; /**< points to the Twiddle factor table. */ + const uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t bitRevLength; /**< bit reversal table length. */ + } arm_cfft_instance_q31; + +void arm_cfft_q31( + const arm_cfft_instance_q31 * S, + q31_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + + /** + * @brief Instance structure for the floating-point CFFT/CIFFT function. + */ + typedef struct + { + uint16_t fftLen; /**< length of the FFT. */ + const float32_t *pTwiddle; /**< points to the Twiddle factor table. */ + const uint16_t *pBitRevTable; /**< points to the bit reversal table. */ + uint16_t bitRevLength; /**< bit reversal table length. */ + } arm_cfft_instance_f32; + + void arm_cfft_f32( + const arm_cfft_instance_f32 * S, + float32_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag); + + /** + * @brief Instance structure for the Q15 RFFT/RIFFT function. + */ + typedef struct + { + uint32_t fftLenReal; /**< length of the real FFT. */ + uint8_t ifftFlagR; /**< flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. */ + uint8_t bitReverseFlagR; /**< flag that enables (bitReverseFlagR=1) or disables (bitReverseFlagR=0) bit reversal of output. */ + uint32_t twidCoefRModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + q15_t *pTwiddleAReal; /**< points to the real twiddle factor table. */ + q15_t *pTwiddleBReal; /**< points to the imag twiddle factor table. */ + const arm_cfft_instance_q15 *pCfft; /**< points to the complex FFT instance. */ + } arm_rfft_instance_q15; + + arm_status arm_rfft_init_q15( + arm_rfft_instance_q15 * S, + uint32_t fftLenReal, + uint32_t ifftFlagR, + uint32_t bitReverseFlag); + + void arm_rfft_q15( + const arm_rfft_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst); + + /** + * @brief Instance structure for the Q31 RFFT/RIFFT function. + */ + typedef struct + { + uint32_t fftLenReal; /**< length of the real FFT. */ + uint8_t ifftFlagR; /**< flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. */ + uint8_t bitReverseFlagR; /**< flag that enables (bitReverseFlagR=1) or disables (bitReverseFlagR=0) bit reversal of output. */ + uint32_t twidCoefRModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + q31_t *pTwiddleAReal; /**< points to the real twiddle factor table. */ + q31_t *pTwiddleBReal; /**< points to the imag twiddle factor table. */ + const arm_cfft_instance_q31 *pCfft; /**< points to the complex FFT instance. */ + } arm_rfft_instance_q31; + + arm_status arm_rfft_init_q31( + arm_rfft_instance_q31 * S, + uint32_t fftLenReal, + uint32_t ifftFlagR, + uint32_t bitReverseFlag); + + void arm_rfft_q31( + const arm_rfft_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst); + + /** + * @brief Instance structure for the floating-point RFFT/RIFFT function. + */ + typedef struct + { + uint32_t fftLenReal; /**< length of the real FFT. */ + uint16_t fftLenBy2; /**< length of the complex FFT. */ + uint8_t ifftFlagR; /**< flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. */ + uint8_t bitReverseFlagR; /**< flag that enables (bitReverseFlagR=1) or disables (bitReverseFlagR=0) bit reversal of output. */ + uint32_t twidCoefRModifier; /**< twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. */ + float32_t *pTwiddleAReal; /**< points to the real twiddle factor table. */ + float32_t *pTwiddleBReal; /**< points to the imag twiddle factor table. */ + arm_cfft_radix4_instance_f32 *pCfft; /**< points to the complex FFT instance. */ + } arm_rfft_instance_f32; + + arm_status arm_rfft_init_f32( + arm_rfft_instance_f32 * S, + arm_cfft_radix4_instance_f32 * S_CFFT, + uint32_t fftLenReal, + uint32_t ifftFlagR, + uint32_t bitReverseFlag); + + void arm_rfft_f32( + const arm_rfft_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst); + + /** + * @brief Instance structure for the floating-point RFFT/RIFFT function. + */ +typedef struct + { + arm_cfft_instance_f32 Sint; /**< Internal CFFT structure. */ + uint16_t fftLenRFFT; /**< length of the real sequence */ + float32_t * pTwiddleRFFT; /**< Twiddle factors real stage */ + } arm_rfft_fast_instance_f32 ; + +arm_status arm_rfft_fast_init_f32 ( + arm_rfft_fast_instance_f32 * S, + uint16_t fftLen); + +void arm_rfft_fast_f32( + arm_rfft_fast_instance_f32 * S, + float32_t * p, float32_t * pOut, + uint8_t ifftFlag); + + /** + * @brief Instance structure for the floating-point DCT4/IDCT4 function. + */ + typedef struct + { + uint16_t N; /**< length of the DCT4. */ + uint16_t Nby2; /**< half of the length of the DCT4. */ + float32_t normalize; /**< normalizing factor. */ + float32_t *pTwiddle; /**< points to the twiddle factor table. */ + float32_t *pCosFactor; /**< points to the cosFactor table. */ + arm_rfft_instance_f32 *pRfft; /**< points to the real FFT instance. */ + arm_cfft_radix4_instance_f32 *pCfft; /**< points to the complex FFT instance. */ + } arm_dct4_instance_f32; + + + /** + * @brief Initialization function for the floating-point DCT4/IDCT4. + * @param[in,out] S points to an instance of floating-point DCT4/IDCT4 structure. + * @param[in] S_RFFT points to an instance of floating-point RFFT/RIFFT structure. + * @param[in] S_CFFT points to an instance of floating-point CFFT/CIFFT structure. + * @param[in] N length of the DCT4. + * @param[in] Nby2 half of the length of the DCT4. + * @param[in] normalize normalizing factor. + * @return arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLenReal is not a supported transform length. + */ + arm_status arm_dct4_init_f32( + arm_dct4_instance_f32 * S, + arm_rfft_instance_f32 * S_RFFT, + arm_cfft_radix4_instance_f32 * S_CFFT, + uint16_t N, + uint16_t Nby2, + float32_t normalize); + + + /** + * @brief Processing function for the floating-point DCT4/IDCT4. + * @param[in] S points to an instance of the floating-point DCT4/IDCT4 structure. + * @param[in] pState points to state buffer. + * @param[in,out] pInlineBuffer points to the in-place input and output buffer. + */ + void arm_dct4_f32( + const arm_dct4_instance_f32 * S, + float32_t * pState, + float32_t * pInlineBuffer); + + + /** + * @brief Instance structure for the Q31 DCT4/IDCT4 function. + */ + typedef struct + { + uint16_t N; /**< length of the DCT4. */ + uint16_t Nby2; /**< half of the length of the DCT4. */ + q31_t normalize; /**< normalizing factor. */ + q31_t *pTwiddle; /**< points to the twiddle factor table. */ + q31_t *pCosFactor; /**< points to the cosFactor table. */ + arm_rfft_instance_q31 *pRfft; /**< points to the real FFT instance. */ + arm_cfft_radix4_instance_q31 *pCfft; /**< points to the complex FFT instance. */ + } arm_dct4_instance_q31; + + + /** + * @brief Initialization function for the Q31 DCT4/IDCT4. + * @param[in,out] S points to an instance of Q31 DCT4/IDCT4 structure. + * @param[in] S_RFFT points to an instance of Q31 RFFT/RIFFT structure + * @param[in] S_CFFT points to an instance of Q31 CFFT/CIFFT structure + * @param[in] N length of the DCT4. + * @param[in] Nby2 half of the length of the DCT4. + * @param[in] normalize normalizing factor. + * @return arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if N is not a supported transform length. + */ + arm_status arm_dct4_init_q31( + arm_dct4_instance_q31 * S, + arm_rfft_instance_q31 * S_RFFT, + arm_cfft_radix4_instance_q31 * S_CFFT, + uint16_t N, + uint16_t Nby2, + q31_t normalize); + + + /** + * @brief Processing function for the Q31 DCT4/IDCT4. + * @param[in] S points to an instance of the Q31 DCT4 structure. + * @param[in] pState points to state buffer. + * @param[in,out] pInlineBuffer points to the in-place input and output buffer. + */ + void arm_dct4_q31( + const arm_dct4_instance_q31 * S, + q31_t * pState, + q31_t * pInlineBuffer); + + + /** + * @brief Instance structure for the Q15 DCT4/IDCT4 function. + */ + typedef struct + { + uint16_t N; /**< length of the DCT4. */ + uint16_t Nby2; /**< half of the length of the DCT4. */ + q15_t normalize; /**< normalizing factor. */ + q15_t *pTwiddle; /**< points to the twiddle factor table. */ + q15_t *pCosFactor; /**< points to the cosFactor table. */ + arm_rfft_instance_q15 *pRfft; /**< points to the real FFT instance. */ + arm_cfft_radix4_instance_q15 *pCfft; /**< points to the complex FFT instance. */ + } arm_dct4_instance_q15; + + + /** + * @brief Initialization function for the Q15 DCT4/IDCT4. + * @param[in,out] S points to an instance of Q15 DCT4/IDCT4 structure. + * @param[in] S_RFFT points to an instance of Q15 RFFT/RIFFT structure. + * @param[in] S_CFFT points to an instance of Q15 CFFT/CIFFT structure. + * @param[in] N length of the DCT4. + * @param[in] Nby2 half of the length of the DCT4. + * @param[in] normalize normalizing factor. + * @return arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if N is not a supported transform length. + */ + arm_status arm_dct4_init_q15( + arm_dct4_instance_q15 * S, + arm_rfft_instance_q15 * S_RFFT, + arm_cfft_radix4_instance_q15 * S_CFFT, + uint16_t N, + uint16_t Nby2, + q15_t normalize); + + + /** + * @brief Processing function for the Q15 DCT4/IDCT4. + * @param[in] S points to an instance of the Q15 DCT4 structure. + * @param[in] pState points to state buffer. + * @param[in,out] pInlineBuffer points to the in-place input and output buffer. + */ + void arm_dct4_q15( + const arm_dct4_instance_q15 * S, + q15_t * pState, + q15_t * pInlineBuffer); + + + /** + * @brief Floating-point vector addition. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_add_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q7 vector addition. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_add_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q15 vector addition. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_add_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q31 vector addition. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_add_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Floating-point vector subtraction. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_sub_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q7 vector subtraction. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_sub_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q15 vector subtraction. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_sub_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q31 vector subtraction. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in each vector + */ + void arm_sub_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Multiplies a floating-point vector by a scalar. + * @param[in] pSrc points to the input vector + * @param[in] scale scale factor to be applied + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_scale_f32( + float32_t * pSrc, + float32_t scale, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Multiplies a Q7 vector by a scalar. + * @param[in] pSrc points to the input vector + * @param[in] scaleFract fractional portion of the scale value + * @param[in] shift number of bits to shift the result by + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_scale_q7( + q7_t * pSrc, + q7_t scaleFract, + int8_t shift, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Multiplies a Q15 vector by a scalar. + * @param[in] pSrc points to the input vector + * @param[in] scaleFract fractional portion of the scale value + * @param[in] shift number of bits to shift the result by + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_scale_q15( + q15_t * pSrc, + q15_t scaleFract, + int8_t shift, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Multiplies a Q31 vector by a scalar. + * @param[in] pSrc points to the input vector + * @param[in] scaleFract fractional portion of the scale value + * @param[in] shift number of bits to shift the result by + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_scale_q31( + q31_t * pSrc, + q31_t scaleFract, + int8_t shift, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q7 vector absolute value. + * @param[in] pSrc points to the input buffer + * @param[out] pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + */ + void arm_abs_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Floating-point vector absolute value. + * @param[in] pSrc points to the input buffer + * @param[out] pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + */ + void arm_abs_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q15 vector absolute value. + * @param[in] pSrc points to the input buffer + * @param[out] pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + */ + void arm_abs_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Q31 vector absolute value. + * @param[in] pSrc points to the input buffer + * @param[out] pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + */ + void arm_abs_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Dot product of floating-point vectors. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] result output result returned here + */ + void arm_dot_prod_f32( + float32_t * pSrcA, + float32_t * pSrcB, + uint32_t blockSize, + float32_t * result); + + + /** + * @brief Dot product of Q7 vectors. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] result output result returned here + */ + void arm_dot_prod_q7( + q7_t * pSrcA, + q7_t * pSrcB, + uint32_t blockSize, + q31_t * result); + + + /** + * @brief Dot product of Q15 vectors. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] result output result returned here + */ + void arm_dot_prod_q15( + q15_t * pSrcA, + q15_t * pSrcB, + uint32_t blockSize, + q63_t * result); + + + /** + * @brief Dot product of Q31 vectors. + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] result output result returned here + */ + void arm_dot_prod_q31( + q31_t * pSrcA, + q31_t * pSrcB, + uint32_t blockSize, + q63_t * result); + + + /** + * @brief Shifts the elements of a Q7 vector a specified number of bits. + * @param[in] pSrc points to the input vector + * @param[in] shiftBits number of bits to shift. A positive value shifts left; a negative value shifts right. + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_shift_q7( + q7_t * pSrc, + int8_t shiftBits, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Shifts the elements of a Q15 vector a specified number of bits. + * @param[in] pSrc points to the input vector + * @param[in] shiftBits number of bits to shift. A positive value shifts left; a negative value shifts right. + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_shift_q15( + q15_t * pSrc, + int8_t shiftBits, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Shifts the elements of a Q31 vector a specified number of bits. + * @param[in] pSrc points to the input vector + * @param[in] shiftBits number of bits to shift. A positive value shifts left; a negative value shifts right. + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_shift_q31( + q31_t * pSrc, + int8_t shiftBits, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Adds a constant offset to a floating-point vector. + * @param[in] pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_offset_f32( + float32_t * pSrc, + float32_t offset, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Adds a constant offset to a Q7 vector. + * @param[in] pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_offset_q7( + q7_t * pSrc, + q7_t offset, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Adds a constant offset to a Q15 vector. + * @param[in] pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_offset_q15( + q15_t * pSrc, + q15_t offset, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Adds a constant offset to a Q31 vector. + * @param[in] pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_offset_q31( + q31_t * pSrc, + q31_t offset, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Negates the elements of a floating-point vector. + * @param[in] pSrc points to the input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_negate_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Negates the elements of a Q7 vector. + * @param[in] pSrc points to the input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_negate_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Negates the elements of a Q15 vector. + * @param[in] pSrc points to the input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_negate_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Negates the elements of a Q31 vector. + * @param[in] pSrc points to the input vector + * @param[out] pDst points to the output vector + * @param[in] blockSize number of samples in the vector + */ + void arm_negate_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Copies the elements of a floating-point vector. + * @param[in] pSrc input pointer + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_copy_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Copies the elements of a Q7 vector. + * @param[in] pSrc input pointer + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_copy_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Copies the elements of a Q15 vector. + * @param[in] pSrc input pointer + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_copy_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Copies the elements of a Q31 vector. + * @param[in] pSrc input pointer + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_copy_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Fills a constant value into a floating-point vector. + * @param[in] value input value to be filled + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_fill_f32( + float32_t value, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Fills a constant value into a Q7 vector. + * @param[in] value input value to be filled + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_fill_q7( + q7_t value, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Fills a constant value into a Q15 vector. + * @param[in] value input value to be filled + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_fill_q15( + q15_t value, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Fills a constant value into a Q31 vector. + * @param[in] value input value to be filled + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_fill_q31( + q31_t value, + q31_t * pDst, + uint32_t blockSize); + + +/** + * @brief Convolution of floating-point sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + */ + void arm_conv_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst); + + + /** + * @brief Convolution of Q15 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length srcALen+srcBLen-1. + * @param[in] pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + */ + void arm_conv_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2); + + +/** + * @brief Convolution of Q15 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + */ + void arm_conv_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + + + /** + * @brief Convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length srcALen+srcBLen-1. + */ + void arm_conv_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + + + /** + * @brief Convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length srcALen+srcBLen-1. + * @param[in] pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + */ + void arm_conv_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2); + + + /** + * @brief Convolution of Q31 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length srcALen+srcBLen-1. + */ + void arm_conv_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + + + /** + * @brief Convolution of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length srcALen+srcBLen-1. + */ + void arm_conv_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + + + /** + * @brief Convolution of Q7 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length srcALen+srcBLen-1. + * @param[in] pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen). + */ + void arm_conv_opt_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2); + + + /** + * @brief Convolution of Q7 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length srcALen+srcBLen-1. + */ + void arm_conv_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst); + + + /** + * @brief Partial convolution of floating-point sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + + + /** + * @brief Partial convolution of Q15 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @param[in] pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2); + + + /** + * @brief Partial convolution of Q15 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + + + /** + * @brief Partial convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + + + /** + * @brief Partial convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @param[in] pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2); + + + /** + * @brief Partial convolution of Q31 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + + + /** + * @brief Partial convolution of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + + + /** + * @brief Partial convolution of Q7 sequences + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @param[in] pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen). + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_opt_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2); + + +/** + * @brief Partial convolution of Q7 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + arm_status arm_conv_partial_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + uint32_t firstIndex, + uint32_t numPoints); + + + /** + * @brief Instance structure for the Q15 FIR decimator. + */ + typedef struct + { + uint8_t M; /**< decimation factor. */ + uint16_t numTaps; /**< number of coefficients in the filter. */ + q15_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + q15_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + } arm_fir_decimate_instance_q15; + + /** + * @brief Instance structure for the Q31 FIR decimator. + */ + typedef struct + { + uint8_t M; /**< decimation factor. */ + uint16_t numTaps; /**< number of coefficients in the filter. */ + q31_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + q31_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + } arm_fir_decimate_instance_q31; + + /** + * @brief Instance structure for the floating-point FIR decimator. + */ + typedef struct + { + uint8_t M; /**< decimation factor. */ + uint16_t numTaps; /**< number of coefficients in the filter. */ + float32_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + float32_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + } arm_fir_decimate_instance_f32; + + + /** + * @brief Processing function for the floating-point FIR decimator. + * @param[in] S points to an instance of the floating-point FIR decimator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_decimate_f32( + const arm_fir_decimate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the floating-point FIR decimator. + * @param[in,out] S points to an instance of the floating-point FIR decimator structure. + * @param[in] numTaps number of coefficients in the filter. + * @param[in] M decimation factor. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if + * blockSize is not a multiple of M. + */ + arm_status arm_fir_decimate_init_f32( + arm_fir_decimate_instance_f32 * S, + uint16_t numTaps, + uint8_t M, + float32_t * pCoeffs, + float32_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q15 FIR decimator. + * @param[in] S points to an instance of the Q15 FIR decimator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_decimate_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q15 FIR decimator (fast variant) for Cortex-M3 and Cortex-M4. + * @param[in] S points to an instance of the Q15 FIR decimator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_decimate_fast_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q15 FIR decimator. + * @param[in,out] S points to an instance of the Q15 FIR decimator structure. + * @param[in] numTaps number of coefficients in the filter. + * @param[in] M decimation factor. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if + * blockSize is not a multiple of M. + */ + arm_status arm_fir_decimate_init_q15( + arm_fir_decimate_instance_q15 * S, + uint16_t numTaps, + uint8_t M, + q15_t * pCoeffs, + q15_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q31 FIR decimator. + * @param[in] S points to an instance of the Q31 FIR decimator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_decimate_q31( + const arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + /** + * @brief Processing function for the Q31 FIR decimator (fast variant) for Cortex-M3 and Cortex-M4. + * @param[in] S points to an instance of the Q31 FIR decimator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_decimate_fast_q31( + arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q31 FIR decimator. + * @param[in,out] S points to an instance of the Q31 FIR decimator structure. + * @param[in] numTaps number of coefficients in the filter. + * @param[in] M decimation factor. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if + * blockSize is not a multiple of M. + */ + arm_status arm_fir_decimate_init_q31( + arm_fir_decimate_instance_q31 * S, + uint16_t numTaps, + uint8_t M, + q31_t * pCoeffs, + q31_t * pState, + uint32_t blockSize); + + + /** + * @brief Instance structure for the Q15 FIR interpolator. + */ + typedef struct + { + uint8_t L; /**< upsample factor. */ + uint16_t phaseLength; /**< length of each polyphase filter component. */ + q15_t *pCoeffs; /**< points to the coefficient array. The array is of length L*phaseLength. */ + q15_t *pState; /**< points to the state variable array. The array is of length blockSize+phaseLength-1. */ + } arm_fir_interpolate_instance_q15; + + /** + * @brief Instance structure for the Q31 FIR interpolator. + */ + typedef struct + { + uint8_t L; /**< upsample factor. */ + uint16_t phaseLength; /**< length of each polyphase filter component. */ + q31_t *pCoeffs; /**< points to the coefficient array. The array is of length L*phaseLength. */ + q31_t *pState; /**< points to the state variable array. The array is of length blockSize+phaseLength-1. */ + } arm_fir_interpolate_instance_q31; + + /** + * @brief Instance structure for the floating-point FIR interpolator. + */ + typedef struct + { + uint8_t L; /**< upsample factor. */ + uint16_t phaseLength; /**< length of each polyphase filter component. */ + float32_t *pCoeffs; /**< points to the coefficient array. The array is of length L*phaseLength. */ + float32_t *pState; /**< points to the state variable array. The array is of length phaseLength+numTaps-1. */ + } arm_fir_interpolate_instance_f32; + + + /** + * @brief Processing function for the Q15 FIR interpolator. + * @param[in] S points to an instance of the Q15 FIR interpolator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_interpolate_q15( + const arm_fir_interpolate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q15 FIR interpolator. + * @param[in,out] S points to an instance of the Q15 FIR interpolator structure. + * @param[in] L upsample factor. + * @param[in] numTaps number of filter coefficients in the filter. + * @param[in] pCoeffs points to the filter coefficient buffer. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if + * the filter length numTaps is not a multiple of the interpolation factor L. + */ + arm_status arm_fir_interpolate_init_q15( + arm_fir_interpolate_instance_q15 * S, + uint8_t L, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q31 FIR interpolator. + * @param[in] S points to an instance of the Q15 FIR interpolator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_interpolate_q31( + const arm_fir_interpolate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q31 FIR interpolator. + * @param[in,out] S points to an instance of the Q31 FIR interpolator structure. + * @param[in] L upsample factor. + * @param[in] numTaps number of filter coefficients in the filter. + * @param[in] pCoeffs points to the filter coefficient buffer. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if + * the filter length numTaps is not a multiple of the interpolation factor L. + */ + arm_status arm_fir_interpolate_init_q31( + arm_fir_interpolate_instance_q31 * S, + uint8_t L, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the floating-point FIR interpolator. + * @param[in] S points to an instance of the floating-point FIR interpolator structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_interpolate_f32( + const arm_fir_interpolate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the floating-point FIR interpolator. + * @param[in,out] S points to an instance of the floating-point FIR interpolator structure. + * @param[in] L upsample factor. + * @param[in] numTaps number of filter coefficients in the filter. + * @param[in] pCoeffs points to the filter coefficient buffer. + * @param[in] pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_LENGTH_ERROR if + * the filter length numTaps is not a multiple of the interpolation factor L. + */ + arm_status arm_fir_interpolate_init_f32( + arm_fir_interpolate_instance_f32 * S, + uint8_t L, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + uint32_t blockSize); + + + /** + * @brief Instance structure for the high precision Q31 Biquad cascade filter. + */ + typedef struct + { + uint8_t numStages; /**< number of 2nd order stages in the filter. Overall order is 2*numStages. */ + q63_t *pState; /**< points to the array of state coefficients. The array is of length 4*numStages. */ + q31_t *pCoeffs; /**< points to the array of coefficients. The array is of length 5*numStages. */ + uint8_t postShift; /**< additional shift, in bits, applied to each output sample. */ + } arm_biquad_cas_df1_32x64_ins_q31; + + + /** + * @param[in] S points to an instance of the high precision Q31 Biquad cascade filter structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cas_df1_32x64_q31( + const arm_biquad_cas_df1_32x64_ins_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @param[in,out] S points to an instance of the high precision Q31 Biquad cascade filter structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] postShift shift to be applied to the output. Varies according to the coefficients format + */ + void arm_biquad_cas_df1_32x64_init_q31( + arm_biquad_cas_df1_32x64_ins_q31 * S, + uint8_t numStages, + q31_t * pCoeffs, + q63_t * pState, + uint8_t postShift); + + + /** + * @brief Instance structure for the floating-point transposed direct form II Biquad cascade filter. + */ + typedef struct + { + uint8_t numStages; /**< number of 2nd order stages in the filter. Overall order is 2*numStages. */ + float32_t *pState; /**< points to the array of state coefficients. The array is of length 2*numStages. */ + float32_t *pCoeffs; /**< points to the array of coefficients. The array is of length 5*numStages. */ + } arm_biquad_cascade_df2T_instance_f32; + + /** + * @brief Instance structure for the floating-point transposed direct form II Biquad cascade filter. + */ + typedef struct + { + uint8_t numStages; /**< number of 2nd order stages in the filter. Overall order is 2*numStages. */ + float32_t *pState; /**< points to the array of state coefficients. The array is of length 4*numStages. */ + float32_t *pCoeffs; /**< points to the array of coefficients. The array is of length 5*numStages. */ + } arm_biquad_cascade_stereo_df2T_instance_f32; + + /** + * @brief Instance structure for the floating-point transposed direct form II Biquad cascade filter. + */ + typedef struct + { + uint8_t numStages; /**< number of 2nd order stages in the filter. Overall order is 2*numStages. */ + float64_t *pState; /**< points to the array of state coefficients. The array is of length 2*numStages. */ + float64_t *pCoeffs; /**< points to the array of coefficients. The array is of length 5*numStages. */ + } arm_biquad_cascade_df2T_instance_f64; + + + /** + * @brief Processing function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in] S points to an instance of the filter data structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_df2T_f32( + const arm_biquad_cascade_df2T_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Processing function for the floating-point transposed direct form II Biquad cascade filter. 2 channels + * @param[in] S points to an instance of the filter data structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_stereo_df2T_f32( + const arm_biquad_cascade_stereo_df2T_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Processing function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in] S points to an instance of the filter data structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of samples to process. + */ + void arm_biquad_cascade_df2T_f64( + const arm_biquad_cascade_df2T_instance_f64 * S, + float64_t * pSrc, + float64_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in,out] S points to an instance of the filter data structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + */ + void arm_biquad_cascade_df2T_init_f32( + arm_biquad_cascade_df2T_instance_f32 * S, + uint8_t numStages, + float32_t * pCoeffs, + float32_t * pState); + + + /** + * @brief Initialization function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in,out] S points to an instance of the filter data structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + */ + void arm_biquad_cascade_stereo_df2T_init_f32( + arm_biquad_cascade_stereo_df2T_instance_f32 * S, + uint8_t numStages, + float32_t * pCoeffs, + float32_t * pState); + + + /** + * @brief Initialization function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in,out] S points to an instance of the filter data structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] pCoeffs points to the filter coefficients. + * @param[in] pState points to the state buffer. + */ + void arm_biquad_cascade_df2T_init_f64( + arm_biquad_cascade_df2T_instance_f64 * S, + uint8_t numStages, + float64_t * pCoeffs, + float64_t * pState); + + + /** + * @brief Instance structure for the Q15 FIR lattice filter. + */ + typedef struct + { + uint16_t numStages; /**< number of filter stages. */ + q15_t *pState; /**< points to the state variable array. The array is of length numStages. */ + q15_t *pCoeffs; /**< points to the coefficient array. The array is of length numStages. */ + } arm_fir_lattice_instance_q15; + + /** + * @brief Instance structure for the Q31 FIR lattice filter. + */ + typedef struct + { + uint16_t numStages; /**< number of filter stages. */ + q31_t *pState; /**< points to the state variable array. The array is of length numStages. */ + q31_t *pCoeffs; /**< points to the coefficient array. The array is of length numStages. */ + } arm_fir_lattice_instance_q31; + + /** + * @brief Instance structure for the floating-point FIR lattice filter. + */ + typedef struct + { + uint16_t numStages; /**< number of filter stages. */ + float32_t *pState; /**< points to the state variable array. The array is of length numStages. */ + float32_t *pCoeffs; /**< points to the coefficient array. The array is of length numStages. */ + } arm_fir_lattice_instance_f32; + + + /** + * @brief Initialization function for the Q15 FIR lattice filter. + * @param[in] S points to an instance of the Q15 FIR lattice structure. + * @param[in] numStages number of filter stages. + * @param[in] pCoeffs points to the coefficient buffer. The array is of length numStages. + * @param[in] pState points to the state buffer. The array is of length numStages. + */ + void arm_fir_lattice_init_q15( + arm_fir_lattice_instance_q15 * S, + uint16_t numStages, + q15_t * pCoeffs, + q15_t * pState); + + + /** + * @brief Processing function for the Q15 FIR lattice filter. + * @param[in] S points to an instance of the Q15 FIR lattice structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_fir_lattice_q15( + const arm_fir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q31 FIR lattice filter. + * @param[in] S points to an instance of the Q31 FIR lattice structure. + * @param[in] numStages number of filter stages. + * @param[in] pCoeffs points to the coefficient buffer. The array is of length numStages. + * @param[in] pState points to the state buffer. The array is of length numStages. + */ + void arm_fir_lattice_init_q31( + arm_fir_lattice_instance_q31 * S, + uint16_t numStages, + q31_t * pCoeffs, + q31_t * pState); + + + /** + * @brief Processing function for the Q31 FIR lattice filter. + * @param[in] S points to an instance of the Q31 FIR lattice structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of samples to process. + */ + void arm_fir_lattice_q31( + const arm_fir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + +/** + * @brief Initialization function for the floating-point FIR lattice filter. + * @param[in] S points to an instance of the floating-point FIR lattice structure. + * @param[in] numStages number of filter stages. + * @param[in] pCoeffs points to the coefficient buffer. The array is of length numStages. + * @param[in] pState points to the state buffer. The array is of length numStages. + */ + void arm_fir_lattice_init_f32( + arm_fir_lattice_instance_f32 * S, + uint16_t numStages, + float32_t * pCoeffs, + float32_t * pState); + + + /** + * @brief Processing function for the floating-point FIR lattice filter. + * @param[in] S points to an instance of the floating-point FIR lattice structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] blockSize number of samples to process. + */ + void arm_fir_lattice_f32( + const arm_fir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Instance structure for the Q15 IIR lattice filter. + */ + typedef struct + { + uint16_t numStages; /**< number of stages in the filter. */ + q15_t *pState; /**< points to the state variable array. The array is of length numStages+blockSize. */ + q15_t *pkCoeffs; /**< points to the reflection coefficient array. The array is of length numStages. */ + q15_t *pvCoeffs; /**< points to the ladder coefficient array. The array is of length numStages+1. */ + } arm_iir_lattice_instance_q15; + + /** + * @brief Instance structure for the Q31 IIR lattice filter. + */ + typedef struct + { + uint16_t numStages; /**< number of stages in the filter. */ + q31_t *pState; /**< points to the state variable array. The array is of length numStages+blockSize. */ + q31_t *pkCoeffs; /**< points to the reflection coefficient array. The array is of length numStages. */ + q31_t *pvCoeffs; /**< points to the ladder coefficient array. The array is of length numStages+1. */ + } arm_iir_lattice_instance_q31; + + /** + * @brief Instance structure for the floating-point IIR lattice filter. + */ + typedef struct + { + uint16_t numStages; /**< number of stages in the filter. */ + float32_t *pState; /**< points to the state variable array. The array is of length numStages+blockSize. */ + float32_t *pkCoeffs; /**< points to the reflection coefficient array. The array is of length numStages. */ + float32_t *pvCoeffs; /**< points to the ladder coefficient array. The array is of length numStages+1. */ + } arm_iir_lattice_instance_f32; + + + /** + * @brief Processing function for the floating-point IIR lattice filter. + * @param[in] S points to an instance of the floating-point IIR lattice structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_iir_lattice_f32( + const arm_iir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the floating-point IIR lattice filter. + * @param[in] S points to an instance of the floating-point IIR lattice structure. + * @param[in] numStages number of stages in the filter. + * @param[in] pkCoeffs points to the reflection coefficient buffer. The array is of length numStages. + * @param[in] pvCoeffs points to the ladder coefficient buffer. The array is of length numStages+1. + * @param[in] pState points to the state buffer. The array is of length numStages+blockSize-1. + * @param[in] blockSize number of samples to process. + */ + void arm_iir_lattice_init_f32( + arm_iir_lattice_instance_f32 * S, + uint16_t numStages, + float32_t * pkCoeffs, + float32_t * pvCoeffs, + float32_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q31 IIR lattice filter. + * @param[in] S points to an instance of the Q31 IIR lattice structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_iir_lattice_q31( + const arm_iir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q31 IIR lattice filter. + * @param[in] S points to an instance of the Q31 IIR lattice structure. + * @param[in] numStages number of stages in the filter. + * @param[in] pkCoeffs points to the reflection coefficient buffer. The array is of length numStages. + * @param[in] pvCoeffs points to the ladder coefficient buffer. The array is of length numStages+1. + * @param[in] pState points to the state buffer. The array is of length numStages+blockSize. + * @param[in] blockSize number of samples to process. + */ + void arm_iir_lattice_init_q31( + arm_iir_lattice_instance_q31 * S, + uint16_t numStages, + q31_t * pkCoeffs, + q31_t * pvCoeffs, + q31_t * pState, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q15 IIR lattice filter. + * @param[in] S points to an instance of the Q15 IIR lattice structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + */ + void arm_iir_lattice_q15( + const arm_iir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + +/** + * @brief Initialization function for the Q15 IIR lattice filter. + * @param[in] S points to an instance of the fixed-point Q15 IIR lattice structure. + * @param[in] numStages number of stages in the filter. + * @param[in] pkCoeffs points to reflection coefficient buffer. The array is of length numStages. + * @param[in] pvCoeffs points to ladder coefficient buffer. The array is of length numStages+1. + * @param[in] pState points to state buffer. The array is of length numStages+blockSize. + * @param[in] blockSize number of samples to process per call. + */ + void arm_iir_lattice_init_q15( + arm_iir_lattice_instance_q15 * S, + uint16_t numStages, + q15_t * pkCoeffs, + q15_t * pvCoeffs, + q15_t * pState, + uint32_t blockSize); + + + /** + * @brief Instance structure for the floating-point LMS filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + float32_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + float32_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + float32_t mu; /**< step size that controls filter coefficient updates. */ + } arm_lms_instance_f32; + + + /** + * @brief Processing function for floating-point LMS filter. + * @param[in] S points to an instance of the floating-point LMS filter structure. + * @param[in] pSrc points to the block of input data. + * @param[in] pRef points to the block of reference data. + * @param[out] pOut points to the block of output data. + * @param[out] pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_f32( + const arm_lms_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize); + + + /** + * @brief Initialization function for floating-point LMS filter. + * @param[in] S points to an instance of the floating-point LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] pCoeffs points to the coefficient buffer. + * @param[in] pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_init_f32( + arm_lms_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + float32_t mu, + uint32_t blockSize); + + + /** + * @brief Instance structure for the Q15 LMS filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + q15_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + q15_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + q15_t mu; /**< step size that controls filter coefficient updates. */ + uint32_t postShift; /**< bit shift applied to coefficients. */ + } arm_lms_instance_q15; + + + /** + * @brief Initialization function for the Q15 LMS filter. + * @param[in] S points to an instance of the Q15 LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] pCoeffs points to the coefficient buffer. + * @param[in] pState points to the state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @param[in] postShift bit shift applied to coefficients. + */ + void arm_lms_init_q15( + arm_lms_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + q15_t mu, + uint32_t blockSize, + uint32_t postShift); + + + /** + * @brief Processing function for Q15 LMS filter. + * @param[in] S points to an instance of the Q15 LMS filter structure. + * @param[in] pSrc points to the block of input data. + * @param[in] pRef points to the block of reference data. + * @param[out] pOut points to the block of output data. + * @param[out] pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_q15( + const arm_lms_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize); + + + /** + * @brief Instance structure for the Q31 LMS filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + q31_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + q31_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + q31_t mu; /**< step size that controls filter coefficient updates. */ + uint32_t postShift; /**< bit shift applied to coefficients. */ + } arm_lms_instance_q31; + + + /** + * @brief Processing function for Q31 LMS filter. + * @param[in] S points to an instance of the Q15 LMS filter structure. + * @param[in] pSrc points to the block of input data. + * @param[in] pRef points to the block of reference data. + * @param[out] pOut points to the block of output data. + * @param[out] pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_q31( + const arm_lms_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize); + + + /** + * @brief Initialization function for Q31 LMS filter. + * @param[in] S points to an instance of the Q31 LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] pCoeffs points to coefficient buffer. + * @param[in] pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @param[in] postShift bit shift applied to coefficients. + */ + void arm_lms_init_q31( + arm_lms_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + q31_t mu, + uint32_t blockSize, + uint32_t postShift); + + + /** + * @brief Instance structure for the floating-point normalized LMS filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + float32_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + float32_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + float32_t mu; /**< step size that control filter coefficient updates. */ + float32_t energy; /**< saves previous frame energy. */ + float32_t x0; /**< saves previous input sample. */ + } arm_lms_norm_instance_f32; + + + /** + * @brief Processing function for floating-point normalized LMS filter. + * @param[in] S points to an instance of the floating-point normalized LMS filter structure. + * @param[in] pSrc points to the block of input data. + * @param[in] pRef points to the block of reference data. + * @param[out] pOut points to the block of output data. + * @param[out] pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_norm_f32( + arm_lms_norm_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize); + + + /** + * @brief Initialization function for floating-point normalized LMS filter. + * @param[in] S points to an instance of the floating-point LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] pCoeffs points to coefficient buffer. + * @param[in] pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_norm_init_f32( + arm_lms_norm_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + float32_t mu, + uint32_t blockSize); + + + /** + * @brief Instance structure for the Q31 normalized LMS filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + q31_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + q31_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + q31_t mu; /**< step size that controls filter coefficient updates. */ + uint8_t postShift; /**< bit shift applied to coefficients. */ + q31_t *recipTable; /**< points to the reciprocal initial value table. */ + q31_t energy; /**< saves previous frame energy. */ + q31_t x0; /**< saves previous input sample. */ + } arm_lms_norm_instance_q31; + + + /** + * @brief Processing function for Q31 normalized LMS filter. + * @param[in] S points to an instance of the Q31 normalized LMS filter structure. + * @param[in] pSrc points to the block of input data. + * @param[in] pRef points to the block of reference data. + * @param[out] pOut points to the block of output data. + * @param[out] pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_norm_q31( + arm_lms_norm_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize); + + + /** + * @brief Initialization function for Q31 normalized LMS filter. + * @param[in] S points to an instance of the Q31 normalized LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] pCoeffs points to coefficient buffer. + * @param[in] pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @param[in] postShift bit shift applied to coefficients. + */ + void arm_lms_norm_init_q31( + arm_lms_norm_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + q31_t mu, + uint32_t blockSize, + uint8_t postShift); + + + /** + * @brief Instance structure for the Q15 normalized LMS filter. + */ + typedef struct + { + uint16_t numTaps; /**< Number of coefficients in the filter. */ + q15_t *pState; /**< points to the state variable array. The array is of length numTaps+blockSize-1. */ + q15_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps. */ + q15_t mu; /**< step size that controls filter coefficient updates. */ + uint8_t postShift; /**< bit shift applied to coefficients. */ + q15_t *recipTable; /**< Points to the reciprocal initial value table. */ + q15_t energy; /**< saves previous frame energy. */ + q15_t x0; /**< saves previous input sample. */ + } arm_lms_norm_instance_q15; + + + /** + * @brief Processing function for Q15 normalized LMS filter. + * @param[in] S points to an instance of the Q15 normalized LMS filter structure. + * @param[in] pSrc points to the block of input data. + * @param[in] pRef points to the block of reference data. + * @param[out] pOut points to the block of output data. + * @param[out] pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + */ + void arm_lms_norm_q15( + arm_lms_norm_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize); + + + /** + * @brief Initialization function for Q15 normalized LMS filter. + * @param[in] S points to an instance of the Q15 normalized LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] pCoeffs points to coefficient buffer. + * @param[in] pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @param[in] postShift bit shift applied to coefficients. + */ + void arm_lms_norm_init_q15( + arm_lms_norm_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + q15_t mu, + uint32_t blockSize, + uint8_t postShift); + + + /** + * @brief Correlation of floating-point sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + */ + void arm_correlate_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst); + + + /** + * @brief Correlation of Q15 sequences + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + * @param[in] pScratch points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + */ + void arm_correlate_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch); + + + /** + * @brief Correlation of Q15 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + */ + + void arm_correlate_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + + + /** + * @brief Correlation of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + */ + + void arm_correlate_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst); + + + /** + * @brief Correlation of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + * @param[in] pScratch points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + */ + void arm_correlate_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch); + + + /** + * @brief Correlation of Q31 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + */ + void arm_correlate_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + + + /** + * @brief Correlation of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4 + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + */ + void arm_correlate_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst); + + + /** + * @brief Correlation of Q7 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + * @param[in] pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen). + */ + void arm_correlate_opt_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2); + + + /** + * @brief Correlation of Q7 sequences. + * @param[in] pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] pDst points to the block of output data Length 2 * max(srcALen, srcBLen) - 1. + */ + void arm_correlate_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst); + + + /** + * @brief Instance structure for the floating-point sparse FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + uint16_t stateIndex; /**< state buffer index. Points to the oldest sample in the state buffer. */ + float32_t *pState; /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */ + float32_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + uint16_t maxDelay; /**< maximum offset specified by the pTapDelay array. */ + int32_t *pTapDelay; /**< points to the array of delay values. The array is of length numTaps. */ + } arm_fir_sparse_instance_f32; + + /** + * @brief Instance structure for the Q31 sparse FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + uint16_t stateIndex; /**< state buffer index. Points to the oldest sample in the state buffer. */ + q31_t *pState; /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */ + q31_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + uint16_t maxDelay; /**< maximum offset specified by the pTapDelay array. */ + int32_t *pTapDelay; /**< points to the array of delay values. The array is of length numTaps. */ + } arm_fir_sparse_instance_q31; + + /** + * @brief Instance structure for the Q15 sparse FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + uint16_t stateIndex; /**< state buffer index. Points to the oldest sample in the state buffer. */ + q15_t *pState; /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */ + q15_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + uint16_t maxDelay; /**< maximum offset specified by the pTapDelay array. */ + int32_t *pTapDelay; /**< points to the array of delay values. The array is of length numTaps. */ + } arm_fir_sparse_instance_q15; + + /** + * @brief Instance structure for the Q7 sparse FIR filter. + */ + typedef struct + { + uint16_t numTaps; /**< number of coefficients in the filter. */ + uint16_t stateIndex; /**< state buffer index. Points to the oldest sample in the state buffer. */ + q7_t *pState; /**< points to the state buffer array. The array is of length maxDelay+blockSize-1. */ + q7_t *pCoeffs; /**< points to the coefficient array. The array is of length numTaps.*/ + uint16_t maxDelay; /**< maximum offset specified by the pTapDelay array. */ + int32_t *pTapDelay; /**< points to the array of delay values. The array is of length numTaps. */ + } arm_fir_sparse_instance_q7; + + + /** + * @brief Processing function for the floating-point sparse FIR filter. + * @param[in] S points to an instance of the floating-point sparse FIR structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] pScratchIn points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_sparse_f32( + arm_fir_sparse_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + float32_t * pScratchIn, + uint32_t blockSize); + + + /** + * @brief Initialization function for the floating-point sparse FIR filter. + * @param[in,out] S points to an instance of the floating-point sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] pCoeffs points to the array of filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + */ + void arm_fir_sparse_init_f32( + arm_fir_sparse_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q31 sparse FIR filter. + * @param[in] S points to an instance of the Q31 sparse FIR structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] pScratchIn points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_sparse_q31( + arm_fir_sparse_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + q31_t * pScratchIn, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q31 sparse FIR filter. + * @param[in,out] S points to an instance of the Q31 sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] pCoeffs points to the array of filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + */ + void arm_fir_sparse_init_q31( + arm_fir_sparse_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q15 sparse FIR filter. + * @param[in] S points to an instance of the Q15 sparse FIR structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] pScratchIn points to a temporary buffer of size blockSize. + * @param[in] pScratchOut points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_sparse_q15( + arm_fir_sparse_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + q15_t * pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q15 sparse FIR filter. + * @param[in,out] S points to an instance of the Q15 sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] pCoeffs points to the array of filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + */ + void arm_fir_sparse_init_q15( + arm_fir_sparse_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize); + + + /** + * @brief Processing function for the Q7 sparse FIR filter. + * @param[in] S points to an instance of the Q7 sparse FIR structure. + * @param[in] pSrc points to the block of input data. + * @param[out] pDst points to the block of output data + * @param[in] pScratchIn points to a temporary buffer of size blockSize. + * @param[in] pScratchOut points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + */ + void arm_fir_sparse_q7( + arm_fir_sparse_instance_q7 * S, + q7_t * pSrc, + q7_t * pDst, + q7_t * pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize); + + + /** + * @brief Initialization function for the Q7 sparse FIR filter. + * @param[in,out] S points to an instance of the Q7 sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] pCoeffs points to the array of filter coefficients. + * @param[in] pState points to the state buffer. + * @param[in] pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + */ + void arm_fir_sparse_init_q7( + arm_fir_sparse_instance_q7 * S, + uint16_t numTaps, + q7_t * pCoeffs, + q7_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize); + + + /** + * @brief Floating-point sin_cos function. + * @param[in] theta input value in degrees + * @param[out] pSinVal points to the processed sine output. + * @param[out] pCosVal points to the processed cos output. + */ + void arm_sin_cos_f32( + float32_t theta, + float32_t * pSinVal, + float32_t * pCosVal); + + + /** + * @brief Q31 sin_cos function. + * @param[in] theta scaled input value in degrees + * @param[out] pSinVal points to the processed sine output. + * @param[out] pCosVal points to the processed cosine output. + */ + void arm_sin_cos_q31( + q31_t theta, + q31_t * pSinVal, + q31_t * pCosVal); + + + /** + * @brief Floating-point complex conjugate. + * @param[in] pSrc points to the input vector + * @param[out] pDst points to the output vector + * @param[in] numSamples number of complex samples in each vector + */ + void arm_cmplx_conj_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples); + + /** + * @brief Q31 complex conjugate. + * @param[in] pSrc points to the input vector + * @param[out] pDst points to the output vector + * @param[in] numSamples number of complex samples in each vector + */ + void arm_cmplx_conj_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t numSamples); + + + /** + * @brief Q15 complex conjugate. + * @param[in] pSrc points to the input vector + * @param[out] pDst points to the output vector + * @param[in] numSamples number of complex samples in each vector + */ + void arm_cmplx_conj_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples); + + + /** + * @brief Floating-point complex magnitude squared + * @param[in] pSrc points to the complex input vector + * @param[out] pDst points to the real output vector + * @param[in] numSamples number of complex samples in the input vector + */ + void arm_cmplx_mag_squared_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples); + + + /** + * @brief Q31 complex magnitude squared + * @param[in] pSrc points to the complex input vector + * @param[out] pDst points to the real output vector + * @param[in] numSamples number of complex samples in the input vector + */ + void arm_cmplx_mag_squared_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t numSamples); + + + /** + * @brief Q15 complex magnitude squared + * @param[in] pSrc points to the complex input vector + * @param[out] pDst points to the real output vector + * @param[in] numSamples number of complex samples in the input vector + */ + void arm_cmplx_mag_squared_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples); + + + /** + * @ingroup groupController + */ + + /** + * @defgroup PID PID Motor Control + * + * A Proportional Integral Derivative (PID) controller is a generic feedback control + * loop mechanism widely used in industrial control systems. + * A PID controller is the most commonly used type of feedback controller. + * + * This set of functions implements (PID) controllers + * for Q15, Q31, and floating-point data types. The functions operate on a single sample + * of data and each call to the function returns a single processed value. + * S points to an instance of the PID control data structure. in + * is the input sample value. The functions return the output value. + * + * \par Algorithm: + *
+   *    y[n] = y[n-1] + A0 * x[n] + A1 * x[n-1] + A2 * x[n-2]
+   *    A0 = Kp + Ki + Kd
+   *    A1 = (-Kp ) - (2 * Kd )
+   *    A2 = Kd  
+ * + * \par + * where \c Kp is proportional constant, \c Ki is Integral constant and \c Kd is Derivative constant + * + * \par + * \image html PID.gif "Proportional Integral Derivative Controller" + * + * \par + * The PID controller calculates an "error" value as the difference between + * the measured output and the reference input. + * The controller attempts to minimize the error by adjusting the process control inputs. + * The proportional value determines the reaction to the current error, + * the integral value determines the reaction based on the sum of recent errors, + * and the derivative value determines the reaction based on the rate at which the error has been changing. + * + * \par Instance Structure + * The Gains A0, A1, A2 and state variables for a PID controller are stored together in an instance data structure. + * A separate instance structure must be defined for each PID Controller. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Reset Functions + * There is also an associated reset function for each data type which clears the state array. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Initializes the Gains A0, A1, A2 from Kp,Ki, Kd gains. + * - Zeros out the values in the state buffer. + * + * \par + * Instance structure cannot be placed into a const data section and it is recommended to use the initialization function. + * + * \par Fixed-Point Behavior + * Care must be taken when using the fixed-point versions of the PID Controller functions. + * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + + /** + * @addtogroup PID + * @{ + */ + + /** + * @brief Process function for the floating-point PID Control. + * @param[in,out] S is an instance of the floating-point PID Control structure + * @param[in] in input sample to process + * @return out processed output sample. + */ + CMSIS_INLINE __STATIC_INLINE float32_t arm_pid_f32( + arm_pid_instance_f32 * S, + float32_t in) + { + float32_t out; + + /* y[n] = y[n-1] + A0 * x[n] + A1 * x[n-1] + A2 * x[n-2] */ + out = (S->A0 * in) + + (S->A1 * S->state[0]) + (S->A2 * S->state[1]) + (S->state[2]); + + /* Update state */ + S->state[1] = S->state[0]; + S->state[0] = in; + S->state[2] = out; + + /* return to application */ + return (out); + + } + + /** + * @brief Process function for the Q31 PID Control. + * @param[in,out] S points to an instance of the Q31 PID Control structure + * @param[in] in input sample to process + * @return out processed output sample. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clip. + * In order to avoid overflows completely the input signal must be scaled down by 2 bits as there are four additions. + * After all multiply-accumulates are performed, the 2.62 accumulator is truncated to 1.32 format and then saturated to 1.31 format. + */ + CMSIS_INLINE __STATIC_INLINE q31_t arm_pid_q31( + arm_pid_instance_q31 * S, + q31_t in) + { + q63_t acc; + q31_t out; + + /* acc = A0 * x[n] */ + acc = (q63_t) S->A0 * in; + + /* acc += A1 * x[n-1] */ + acc += (q63_t) S->A1 * S->state[0]; + + /* acc += A2 * x[n-2] */ + acc += (q63_t) S->A2 * S->state[1]; + + /* convert output to 1.31 format to add y[n-1] */ + out = (q31_t) (acc >> 31U); + + /* out += y[n-1] */ + out += S->state[2]; + + /* Update state */ + S->state[1] = S->state[0]; + S->state[0] = in; + S->state[2] = out; + + /* return to application */ + return (out); + } + + + /** + * @brief Process function for the Q15 PID Control. + * @param[in,out] S points to an instance of the Q15 PID Control structure + * @param[in] in input sample to process + * @return out processed output sample. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both Gains and state variables are represented in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * After all additions have been performed, the accumulator is truncated to 34.15 format by discarding low 15 bits. + * Lastly, the accumulator is saturated to yield a result in 1.15 format. + */ + CMSIS_INLINE __STATIC_INLINE q15_t arm_pid_q15( + arm_pid_instance_q15 * S, + q15_t in) + { + q63_t acc; + q15_t out; + +#if defined (ARM_MATH_DSP) + __SIMD32_TYPE *vstate; + + /* Implementation of PID controller */ + + /* acc = A0 * x[n] */ + acc = (q31_t) __SMUAD((uint32_t)S->A0, (uint32_t)in); + + /* acc += A1 * x[n-1] + A2 * x[n-2] */ + vstate = __SIMD32_CONST(S->state); + acc = (q63_t)__SMLALD((uint32_t)S->A1, (uint32_t)*vstate, (uint64_t)acc); +#else + /* acc = A0 * x[n] */ + acc = ((q31_t) S->A0) * in; + + /* acc += A1 * x[n-1] + A2 * x[n-2] */ + acc += (q31_t) S->A1 * S->state[0]; + acc += (q31_t) S->A2 * S->state[1]; +#endif + + /* acc += y[n-1] */ + acc += (q31_t) S->state[2] << 15; + + /* saturate the output */ + out = (q15_t) (__SSAT((acc >> 15), 16)); + + /* Update state */ + S->state[1] = S->state[0]; + S->state[0] = in; + S->state[2] = out; + + /* return to application */ + return (out); + } + + /** + * @} end of PID group + */ + + + /** + * @brief Floating-point matrix inverse. + * @param[in] src points to the instance of the input floating-point matrix structure. + * @param[out] dst points to the instance of the output floating-point matrix structure. + * @return The function returns ARM_MATH_SIZE_MISMATCH, if the dimensions do not match. + * If the input matrix is singular (does not have an inverse), then the algorithm terminates and returns error status ARM_MATH_SINGULAR. + */ + arm_status arm_mat_inverse_f32( + const arm_matrix_instance_f32 * src, + arm_matrix_instance_f32 * dst); + + + /** + * @brief Floating-point matrix inverse. + * @param[in] src points to the instance of the input floating-point matrix structure. + * @param[out] dst points to the instance of the output floating-point matrix structure. + * @return The function returns ARM_MATH_SIZE_MISMATCH, if the dimensions do not match. + * If the input matrix is singular (does not have an inverse), then the algorithm terminates and returns error status ARM_MATH_SINGULAR. + */ + arm_status arm_mat_inverse_f64( + const arm_matrix_instance_f64 * src, + arm_matrix_instance_f64 * dst); + + + + /** + * @ingroup groupController + */ + + /** + * @defgroup clarke Vector Clarke Transform + * Forward Clarke transform converts the instantaneous stator phases into a two-coordinate time invariant vector. + * Generally the Clarke transform uses three-phase currents Ia, Ib and Ic to calculate currents + * in the two-phase orthogonal stator axis Ialpha and Ibeta. + * When Ialpha is superposed with Ia as shown in the figure below + * \image html clarke.gif Stator current space vector and its components in (a,b). + * and Ia + Ib + Ic = 0, in this condition Ialpha and Ibeta + * can be calculated using only Ia and Ib. + * + * The function operates on a single sample of data and each call to the function returns the processed output. + * The library provides separate functions for Q31 and floating-point data types. + * \par Algorithm + * \image html clarkeFormula.gif + * where Ia and Ib are the instantaneous stator phases and + * pIalpha and pIbeta are the two coordinates of time invariant vector. + * \par Fixed-Point Behavior + * Care must be taken when using the Q31 version of the Clarke transform. + * In particular, the overflow and saturation behavior of the accumulator used must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + + /** + * @addtogroup clarke + * @{ + */ + + /** + * + * @brief Floating-point Clarke transform + * @param[in] Ia input three-phase coordinate a + * @param[in] Ib input three-phase coordinate b + * @param[out] pIalpha points to output two-phase orthogonal vector axis alpha + * @param[out] pIbeta points to output two-phase orthogonal vector axis beta + */ + CMSIS_INLINE __STATIC_INLINE void arm_clarke_f32( + float32_t Ia, + float32_t Ib, + float32_t * pIalpha, + float32_t * pIbeta) + { + /* Calculate pIalpha using the equation, pIalpha = Ia */ + *pIalpha = Ia; + + /* Calculate pIbeta using the equation, pIbeta = (1/sqrt(3)) * Ia + (2/sqrt(3)) * Ib */ + *pIbeta = ((float32_t) 0.57735026919 * Ia + (float32_t) 1.15470053838 * Ib); + } + + + /** + * @brief Clarke transform for Q31 version + * @param[in] Ia input three-phase coordinate a + * @param[in] Ib input three-phase coordinate b + * @param[out] pIalpha points to output two-phase orthogonal vector axis alpha + * @param[out] pIbeta points to output two-phase orthogonal vector axis beta + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 32-bit accumulator. + * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format. + * There is saturation on the addition, hence there is no risk of overflow. + */ + CMSIS_INLINE __STATIC_INLINE void arm_clarke_q31( + q31_t Ia, + q31_t Ib, + q31_t * pIalpha, + q31_t * pIbeta) + { + q31_t product1, product2; /* Temporary variables used to store intermediate results */ + + /* Calculating pIalpha from Ia by equation pIalpha = Ia */ + *pIalpha = Ia; + + /* Intermediate product is calculated by (1/(sqrt(3)) * Ia) */ + product1 = (q31_t) (((q63_t) Ia * 0x24F34E8B) >> 30); + + /* Intermediate product is calculated by (2/sqrt(3) * Ib) */ + product2 = (q31_t) (((q63_t) Ib * 0x49E69D16) >> 30); + + /* pIbeta is calculated by adding the intermediate products */ + *pIbeta = __QADD(product1, product2); + } + + /** + * @} end of clarke group + */ + + /** + * @brief Converts the elements of the Q7 vector to Q31 vector. + * @param[in] pSrc input pointer + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_q7_to_q31( + q7_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + + /** + * @ingroup groupController + */ + + /** + * @defgroup inv_clarke Vector Inverse Clarke Transform + * Inverse Clarke transform converts the two-coordinate time invariant vector into instantaneous stator phases. + * + * The function operates on a single sample of data and each call to the function returns the processed output. + * The library provides separate functions for Q31 and floating-point data types. + * \par Algorithm + * \image html clarkeInvFormula.gif + * where pIa and pIb are the instantaneous stator phases and + * Ialpha and Ibeta are the two coordinates of time invariant vector. + * \par Fixed-Point Behavior + * Care must be taken when using the Q31 version of the Clarke transform. + * In particular, the overflow and saturation behavior of the accumulator used must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + + /** + * @addtogroup inv_clarke + * @{ + */ + + /** + * @brief Floating-point Inverse Clarke transform + * @param[in] Ialpha input two-phase orthogonal vector axis alpha + * @param[in] Ibeta input two-phase orthogonal vector axis beta + * @param[out] pIa points to output three-phase coordinate a + * @param[out] pIb points to output three-phase coordinate b + */ + CMSIS_INLINE __STATIC_INLINE void arm_inv_clarke_f32( + float32_t Ialpha, + float32_t Ibeta, + float32_t * pIa, + float32_t * pIb) + { + /* Calculating pIa from Ialpha by equation pIa = Ialpha */ + *pIa = Ialpha; + + /* Calculating pIb from Ialpha and Ibeta by equation pIb = -(1/2) * Ialpha + (sqrt(3)/2) * Ibeta */ + *pIb = -0.5f * Ialpha + 0.8660254039f * Ibeta; + } + + + /** + * @brief Inverse Clarke transform for Q31 version + * @param[in] Ialpha input two-phase orthogonal vector axis alpha + * @param[in] Ibeta input two-phase orthogonal vector axis beta + * @param[out] pIa points to output three-phase coordinate a + * @param[out] pIb points to output three-phase coordinate b + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 32-bit accumulator. + * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format. + * There is saturation on the subtraction, hence there is no risk of overflow. + */ + CMSIS_INLINE __STATIC_INLINE void arm_inv_clarke_q31( + q31_t Ialpha, + q31_t Ibeta, + q31_t * pIa, + q31_t * pIb) + { + q31_t product1, product2; /* Temporary variables used to store intermediate results */ + + /* Calculating pIa from Ialpha by equation pIa = Ialpha */ + *pIa = Ialpha; + + /* Intermediate product is calculated by (1/(2*sqrt(3)) * Ia) */ + product1 = (q31_t) (((q63_t) (Ialpha) * (0x40000000)) >> 31); + + /* Intermediate product is calculated by (1/sqrt(3) * pIb) */ + product2 = (q31_t) (((q63_t) (Ibeta) * (0x6ED9EBA1)) >> 31); + + /* pIb is calculated by subtracting the products */ + *pIb = __QSUB(product2, product1); + } + + /** + * @} end of inv_clarke group + */ + + /** + * @brief Converts the elements of the Q7 vector to Q15 vector. + * @param[in] pSrc input pointer + * @param[out] pDst output pointer + * @param[in] blockSize number of samples to process + */ + void arm_q7_to_q15( + q7_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + + /** + * @ingroup groupController + */ + + /** + * @defgroup park Vector Park Transform + * + * Forward Park transform converts the input two-coordinate vector to flux and torque components. + * The Park transform can be used to realize the transformation of the Ialpha and the Ibeta currents + * from the stationary to the moving reference frame and control the spatial relationship between + * the stator vector current and rotor flux vector. + * If we consider the d axis aligned with the rotor flux, the diagram below shows the + * current vector and the relationship from the two reference frames: + * \image html park.gif "Stator current space vector and its component in (a,b) and in the d,q rotating reference frame" + * + * The function operates on a single sample of data and each call to the function returns the processed output. + * The library provides separate functions for Q31 and floating-point data types. + * \par Algorithm + * \image html parkFormula.gif + * where Ialpha and Ibeta are the stator vector components, + * pId and pIq are rotor vector components and cosVal and sinVal are the + * cosine and sine values of theta (rotor flux position). + * \par Fixed-Point Behavior + * Care must be taken when using the Q31 version of the Park transform. + * In particular, the overflow and saturation behavior of the accumulator used must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + + /** + * @addtogroup park + * @{ + */ + + /** + * @brief Floating-point Park transform + * @param[in] Ialpha input two-phase vector coordinate alpha + * @param[in] Ibeta input two-phase vector coordinate beta + * @param[out] pId points to output rotor reference frame d + * @param[out] pIq points to output rotor reference frame q + * @param[in] sinVal sine value of rotation angle theta + * @param[in] cosVal cosine value of rotation angle theta + * + * The function implements the forward Park transform. + * + */ + CMSIS_INLINE __STATIC_INLINE void arm_park_f32( + float32_t Ialpha, + float32_t Ibeta, + float32_t * pId, + float32_t * pIq, + float32_t sinVal, + float32_t cosVal) + { + /* Calculate pId using the equation, pId = Ialpha * cosVal + Ibeta * sinVal */ + *pId = Ialpha * cosVal + Ibeta * sinVal; + + /* Calculate pIq using the equation, pIq = - Ialpha * sinVal + Ibeta * cosVal */ + *pIq = -Ialpha * sinVal + Ibeta * cosVal; + } + + + /** + * @brief Park transform for Q31 version + * @param[in] Ialpha input two-phase vector coordinate alpha + * @param[in] Ibeta input two-phase vector coordinate beta + * @param[out] pId points to output rotor reference frame d + * @param[out] pIq points to output rotor reference frame q + * @param[in] sinVal sine value of rotation angle theta + * @param[in] cosVal cosine value of rotation angle theta + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 32-bit accumulator. + * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format. + * There is saturation on the addition and subtraction, hence there is no risk of overflow. + */ + CMSIS_INLINE __STATIC_INLINE void arm_park_q31( + q31_t Ialpha, + q31_t Ibeta, + q31_t * pId, + q31_t * pIq, + q31_t sinVal, + q31_t cosVal) + { + q31_t product1, product2; /* Temporary variables used to store intermediate results */ + q31_t product3, product4; /* Temporary variables used to store intermediate results */ + + /* Intermediate product is calculated by (Ialpha * cosVal) */ + product1 = (q31_t) (((q63_t) (Ialpha) * (cosVal)) >> 31); + + /* Intermediate product is calculated by (Ibeta * sinVal) */ + product2 = (q31_t) (((q63_t) (Ibeta) * (sinVal)) >> 31); + + + /* Intermediate product is calculated by (Ialpha * sinVal) */ + product3 = (q31_t) (((q63_t) (Ialpha) * (sinVal)) >> 31); + + /* Intermediate product is calculated by (Ibeta * cosVal) */ + product4 = (q31_t) (((q63_t) (Ibeta) * (cosVal)) >> 31); + + /* Calculate pId by adding the two intermediate products 1 and 2 */ + *pId = __QADD(product1, product2); + + /* Calculate pIq by subtracting the two intermediate products 3 from 4 */ + *pIq = __QSUB(product4, product3); + } + + /** + * @} end of park group + */ + + /** + * @brief Converts the elements of the Q7 vector to floating-point vector. + * @param[in] pSrc is input pointer + * @param[out] pDst is output pointer + * @param[in] blockSize is the number of samples to process + */ + void arm_q7_to_float( + q7_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @ingroup groupController + */ + + /** + * @defgroup inv_park Vector Inverse Park transform + * Inverse Park transform converts the input flux and torque components to two-coordinate vector. + * + * The function operates on a single sample of data and each call to the function returns the processed output. + * The library provides separate functions for Q31 and floating-point data types. + * \par Algorithm + * \image html parkInvFormula.gif + * where pIalpha and pIbeta are the stator vector components, + * Id and Iq are rotor vector components and cosVal and sinVal are the + * cosine and sine values of theta (rotor flux position). + * \par Fixed-Point Behavior + * Care must be taken when using the Q31 version of the Park transform. + * In particular, the overflow and saturation behavior of the accumulator used must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + + /** + * @addtogroup inv_park + * @{ + */ + + /** + * @brief Floating-point Inverse Park transform + * @param[in] Id input coordinate of rotor reference frame d + * @param[in] Iq input coordinate of rotor reference frame q + * @param[out] pIalpha points to output two-phase orthogonal vector axis alpha + * @param[out] pIbeta points to output two-phase orthogonal vector axis beta + * @param[in] sinVal sine value of rotation angle theta + * @param[in] cosVal cosine value of rotation angle theta + */ + CMSIS_INLINE __STATIC_INLINE void arm_inv_park_f32( + float32_t Id, + float32_t Iq, + float32_t * pIalpha, + float32_t * pIbeta, + float32_t sinVal, + float32_t cosVal) + { + /* Calculate pIalpha using the equation, pIalpha = Id * cosVal - Iq * sinVal */ + *pIalpha = Id * cosVal - Iq * sinVal; + + /* Calculate pIbeta using the equation, pIbeta = Id * sinVal + Iq * cosVal */ + *pIbeta = Id * sinVal + Iq * cosVal; + } + + + /** + * @brief Inverse Park transform for Q31 version + * @param[in] Id input coordinate of rotor reference frame d + * @param[in] Iq input coordinate of rotor reference frame q + * @param[out] pIalpha points to output two-phase orthogonal vector axis alpha + * @param[out] pIbeta points to output two-phase orthogonal vector axis beta + * @param[in] sinVal sine value of rotation angle theta + * @param[in] cosVal cosine value of rotation angle theta + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 32-bit accumulator. + * The accumulator maintains 1.31 format by truncating lower 31 bits of the intermediate multiplication in 2.62 format. + * There is saturation on the addition, hence there is no risk of overflow. + */ + CMSIS_INLINE __STATIC_INLINE void arm_inv_park_q31( + q31_t Id, + q31_t Iq, + q31_t * pIalpha, + q31_t * pIbeta, + q31_t sinVal, + q31_t cosVal) + { + q31_t product1, product2; /* Temporary variables used to store intermediate results */ + q31_t product3, product4; /* Temporary variables used to store intermediate results */ + + /* Intermediate product is calculated by (Id * cosVal) */ + product1 = (q31_t) (((q63_t) (Id) * (cosVal)) >> 31); + + /* Intermediate product is calculated by (Iq * sinVal) */ + product2 = (q31_t) (((q63_t) (Iq) * (sinVal)) >> 31); + + + /* Intermediate product is calculated by (Id * sinVal) */ + product3 = (q31_t) (((q63_t) (Id) * (sinVal)) >> 31); + + /* Intermediate product is calculated by (Iq * cosVal) */ + product4 = (q31_t) (((q63_t) (Iq) * (cosVal)) >> 31); + + /* Calculate pIalpha by using the two intermediate products 1 and 2 */ + *pIalpha = __QSUB(product1, product2); + + /* Calculate pIbeta by using the two intermediate products 3 and 4 */ + *pIbeta = __QADD(product4, product3); + } + + /** + * @} end of Inverse park group + */ + + + /** + * @brief Converts the elements of the Q31 vector to floating-point vector. + * @param[in] pSrc is input pointer + * @param[out] pDst is output pointer + * @param[in] blockSize is the number of samples to process + */ + void arm_q31_to_float( + q31_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + /** + * @ingroup groupInterpolation + */ + + /** + * @defgroup LinearInterpolate Linear Interpolation + * + * Linear interpolation is a method of curve fitting using linear polynomials. + * Linear interpolation works by effectively drawing a straight line between two neighboring samples and returning the appropriate point along that line + * + * \par + * \image html LinearInterp.gif "Linear interpolation" + * + * \par + * A Linear Interpolate function calculates an output value(y), for the input(x) + * using linear interpolation of the input values x0, x1( nearest input values) and the output values y0 and y1(nearest output values) + * + * \par Algorithm: + *
+   *       y = y0 + (x - x0) * ((y1 - y0)/(x1-x0))
+   *       where x0, x1 are nearest values of input x
+   *             y0, y1 are nearest values to output y
+   * 
+ * + * \par + * This set of functions implements Linear interpolation process + * for Q7, Q15, Q31, and floating-point data types. The functions operate on a single + * sample of data and each call to the function returns a single processed value. + * S points to an instance of the Linear Interpolate function data structure. + * x is the input sample value. The functions returns the output value. + * + * \par + * if x is outside of the table boundary, Linear interpolation returns first value of the table + * if x is below input range and returns last value of table if x is above range. + */ + + /** + * @addtogroup LinearInterpolate + * @{ + */ + + /** + * @brief Process function for the floating-point Linear Interpolation Function. + * @param[in,out] S is an instance of the floating-point Linear Interpolation structure + * @param[in] x input sample to process + * @return y processed output sample. + * + */ + CMSIS_INLINE __STATIC_INLINE float32_t arm_linear_interp_f32( + arm_linear_interp_instance_f32 * S, + float32_t x) + { + float32_t y; + float32_t x0, x1; /* Nearest input values */ + float32_t y0, y1; /* Nearest output values */ + float32_t xSpacing = S->xSpacing; /* spacing between input values */ + int32_t i; /* Index variable */ + float32_t *pYData = S->pYData; /* pointer to output table */ + + /* Calculation of index */ + i = (int32_t) ((x - S->x1) / xSpacing); + + if (i < 0) + { + /* Iniatilize output for below specified range as least output value of table */ + y = pYData[0]; + } + else if ((uint32_t)i >= S->nValues) + { + /* Iniatilize output for above specified range as last output value of table */ + y = pYData[S->nValues - 1]; + } + else + { + /* Calculation of nearest input values */ + x0 = S->x1 + i * xSpacing; + x1 = S->x1 + (i + 1) * xSpacing; + + /* Read of nearest output values */ + y0 = pYData[i]; + y1 = pYData[i + 1]; + + /* Calculation of output */ + y = y0 + (x - x0) * ((y1 - y0) / (x1 - x0)); + + } + + /* returns output value */ + return (y); + } + + + /** + * + * @brief Process function for the Q31 Linear Interpolation Function. + * @param[in] pYData pointer to Q31 Linear Interpolation table + * @param[in] x input sample to process + * @param[in] nValues number of table values + * @return y processed output sample. + * + * \par + * Input sample x is in 12.20 format which contains 12 bits for table index and 20 bits for fractional part. + * This function can support maximum of table size 2^12. + * + */ + CMSIS_INLINE __STATIC_INLINE q31_t arm_linear_interp_q31( + q31_t * pYData, + q31_t x, + uint32_t nValues) + { + q31_t y; /* output */ + q31_t y0, y1; /* Nearest output values */ + q31_t fract; /* fractional part */ + int32_t index; /* Index to read nearest output values */ + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + index = ((x & (q31_t)0xFFF00000) >> 20); + + if (index >= (int32_t)(nValues - 1)) + { + return (pYData[nValues - 1]); + } + else if (index < 0) + { + return (pYData[0]); + } + else + { + /* 20 bits for the fractional part */ + /* shift left by 11 to keep fract in 1.31 format */ + fract = (x & 0x000FFFFF) << 11; + + /* Read two nearest output values from the index in 1.31(q31) format */ + y0 = pYData[index]; + y1 = pYData[index + 1]; + + /* Calculation of y0 * (1-fract) and y is in 2.30 format */ + y = ((q31_t) ((q63_t) y0 * (0x7FFFFFFF - fract) >> 32)); + + /* Calculation of y0 * (1-fract) + y1 *fract and y is in 2.30 format */ + y += ((q31_t) (((q63_t) y1 * fract) >> 32)); + + /* Convert y to 1.31 format */ + return (y << 1U); + } + } + + + /** + * + * @brief Process function for the Q15 Linear Interpolation Function. + * @param[in] pYData pointer to Q15 Linear Interpolation table + * @param[in] x input sample to process + * @param[in] nValues number of table values + * @return y processed output sample. + * + * \par + * Input sample x is in 12.20 format which contains 12 bits for table index and 20 bits for fractional part. + * This function can support maximum of table size 2^12. + * + */ + CMSIS_INLINE __STATIC_INLINE q15_t arm_linear_interp_q15( + q15_t * pYData, + q31_t x, + uint32_t nValues) + { + q63_t y; /* output */ + q15_t y0, y1; /* Nearest output values */ + q31_t fract; /* fractional part */ + int32_t index; /* Index to read nearest output values */ + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + index = ((x & (int32_t)0xFFF00000) >> 20); + + if (index >= (int32_t)(nValues - 1)) + { + return (pYData[nValues - 1]); + } + else if (index < 0) + { + return (pYData[0]); + } + else + { + /* 20 bits for the fractional part */ + /* fract is in 12.20 format */ + fract = (x & 0x000FFFFF); + + /* Read two nearest output values from the index */ + y0 = pYData[index]; + y1 = pYData[index + 1]; + + /* Calculation of y0 * (1-fract) and y is in 13.35 format */ + y = ((q63_t) y0 * (0xFFFFF - fract)); + + /* Calculation of (y0 * (1-fract) + y1 * fract) and y is in 13.35 format */ + y += ((q63_t) y1 * (fract)); + + /* convert y to 1.15 format */ + return (q15_t) (y >> 20); + } + } + + + /** + * + * @brief Process function for the Q7 Linear Interpolation Function. + * @param[in] pYData pointer to Q7 Linear Interpolation table + * @param[in] x input sample to process + * @param[in] nValues number of table values + * @return y processed output sample. + * + * \par + * Input sample x is in 12.20 format which contains 12 bits for table index and 20 bits for fractional part. + * This function can support maximum of table size 2^12. + */ + CMSIS_INLINE __STATIC_INLINE q7_t arm_linear_interp_q7( + q7_t * pYData, + q31_t x, + uint32_t nValues) + { + q31_t y; /* output */ + q7_t y0, y1; /* Nearest output values */ + q31_t fract; /* fractional part */ + uint32_t index; /* Index to read nearest output values */ + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + if (x < 0) + { + return (pYData[0]); + } + index = (x >> 20) & 0xfff; + + if (index >= (nValues - 1)) + { + return (pYData[nValues - 1]); + } + else + { + /* 20 bits for the fractional part */ + /* fract is in 12.20 format */ + fract = (x & 0x000FFFFF); + + /* Read two nearest output values from the index and are in 1.7(q7) format */ + y0 = pYData[index]; + y1 = pYData[index + 1]; + + /* Calculation of y0 * (1-fract ) and y is in 13.27(q27) format */ + y = ((y0 * (0xFFFFF - fract))); + + /* Calculation of y1 * fract + y0 * (1-fract) and y is in 13.27(q27) format */ + y += (y1 * fract); + + /* convert y to 1.7(q7) format */ + return (q7_t) (y >> 20); + } + } + + /** + * @} end of LinearInterpolate group + */ + + /** + * @brief Fast approximation to the trigonometric sine function for floating-point data. + * @param[in] x input value in radians. + * @return sin(x). + */ + float32_t arm_sin_f32( + float32_t x); + + + /** + * @brief Fast approximation to the trigonometric sine function for Q31 data. + * @param[in] x Scaled input value in radians. + * @return sin(x). + */ + q31_t arm_sin_q31( + q31_t x); + + + /** + * @brief Fast approximation to the trigonometric sine function for Q15 data. + * @param[in] x Scaled input value in radians. + * @return sin(x). + */ + q15_t arm_sin_q15( + q15_t x); + + + /** + * @brief Fast approximation to the trigonometric cosine function for floating-point data. + * @param[in] x input value in radians. + * @return cos(x). + */ + float32_t arm_cos_f32( + float32_t x); + + + /** + * @brief Fast approximation to the trigonometric cosine function for Q31 data. + * @param[in] x Scaled input value in radians. + * @return cos(x). + */ + q31_t arm_cos_q31( + q31_t x); + + + /** + * @brief Fast approximation to the trigonometric cosine function for Q15 data. + * @param[in] x Scaled input value in radians. + * @return cos(x). + */ + q15_t arm_cos_q15( + q15_t x); + + + /** + * @ingroup groupFastMath + */ + + + /** + * @defgroup SQRT Square Root + * + * Computes the square root of a number. + * There are separate functions for Q15, Q31, and floating-point data types. + * The square root function is computed using the Newton-Raphson algorithm. + * This is an iterative algorithm of the form: + *
+   *      x1 = x0 - f(x0)/f'(x0)
+   * 
+ * where x1 is the current estimate, + * x0 is the previous estimate, and + * f'(x0) is the derivative of f() evaluated at x0. + * For the square root function, the algorithm reduces to: + *
+   *     x0 = in/2                         [initial guess]
+   *     x1 = 1/2 * ( x0 + in / x0)        [each iteration]
+   * 
+ */ + + + /** + * @addtogroup SQRT + * @{ + */ + + /** + * @brief Floating-point square root function. + * @param[in] in input value. + * @param[out] pOut square root of input value. + * @return The function returns ARM_MATH_SUCCESS if input value is positive value or ARM_MATH_ARGUMENT_ERROR if + * in is negative value and returns zero output for negative values. + */ + CMSIS_INLINE __STATIC_INLINE arm_status arm_sqrt_f32( + float32_t in, + float32_t * pOut) + { + if (in >= 0.0f) + { + +#if (__FPU_USED == 1) && defined ( __CC_ARM ) + *pOut = __sqrtf(in); +#elif (__FPU_USED == 1) && (defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)) + *pOut = __builtin_sqrtf(in); +#elif (__FPU_USED == 1) && defined(__GNUC__) + *pOut = __builtin_sqrtf(in); +#elif (__FPU_USED == 1) && defined ( __ICCARM__ ) && (__VER__ >= 6040000) + __ASM("VSQRT.F32 %0,%1" : "=t"(*pOut) : "t"(in)); +#else + *pOut = sqrtf(in); +#endif + + return (ARM_MATH_SUCCESS); + } + else + { + *pOut = 0.0f; + return (ARM_MATH_ARGUMENT_ERROR); + } + } + + + /** + * @brief Q31 square root function. + * @param[in] in input value. The range of the input value is [0 +1) or 0x00000000 to 0x7FFFFFFF. + * @param[out] pOut square root of input value. + * @return The function returns ARM_MATH_SUCCESS if input value is positive value or ARM_MATH_ARGUMENT_ERROR if + * in is negative value and returns zero output for negative values. + */ + arm_status arm_sqrt_q31( + q31_t in, + q31_t * pOut); + + + /** + * @brief Q15 square root function. + * @param[in] in input value. The range of the input value is [0 +1) or 0x0000 to 0x7FFF. + * @param[out] pOut square root of input value. + * @return The function returns ARM_MATH_SUCCESS if input value is positive value or ARM_MATH_ARGUMENT_ERROR if + * in is negative value and returns zero output for negative values. + */ + arm_status arm_sqrt_q15( + q15_t in, + q15_t * pOut); + + /** + * @} end of SQRT group + */ + + + /** + * @brief floating-point Circular write function. + */ + CMSIS_INLINE __STATIC_INLINE void arm_circularWrite_f32( + int32_t * circBuffer, + int32_t L, + uint16_t * writeOffset, + int32_t bufferInc, + const int32_t * src, + int32_t srcInc, + uint32_t blockSize) + { + uint32_t i = 0U; + int32_t wOffset; + + /* Copy the value of Index pointer that points + * to the current location where the input samples to be copied */ + wOffset = *writeOffset; + + /* Loop over the blockSize */ + i = blockSize; + + while (i > 0U) + { + /* copy the input sample to the circular buffer */ + circBuffer[wOffset] = *src; + + /* Update the input pointer */ + src += srcInc; + + /* Circularly update wOffset. Watch out for positive and negative value */ + wOffset += bufferInc; + if (wOffset >= L) + wOffset -= L; + + /* Decrement the loop counter */ + i--; + } + + /* Update the index pointer */ + *writeOffset = (uint16_t)wOffset; + } + + + + /** + * @brief floating-point Circular Read function. + */ + CMSIS_INLINE __STATIC_INLINE void arm_circularRead_f32( + int32_t * circBuffer, + int32_t L, + int32_t * readOffset, + int32_t bufferInc, + int32_t * dst, + int32_t * dst_base, + int32_t dst_length, + int32_t dstInc, + uint32_t blockSize) + { + uint32_t i = 0U; + int32_t rOffset, dst_end; + + /* Copy the value of Index pointer that points + * to the current location from where the input samples to be read */ + rOffset = *readOffset; + dst_end = (int32_t) (dst_base + dst_length); + + /* Loop over the blockSize */ + i = blockSize; + + while (i > 0U) + { + /* copy the sample from the circular buffer to the destination buffer */ + *dst = circBuffer[rOffset]; + + /* Update the input pointer */ + dst += dstInc; + + if (dst == (int32_t *) dst_end) + { + dst = dst_base; + } + + /* Circularly update rOffset. Watch out for positive and negative value */ + rOffset += bufferInc; + + if (rOffset >= L) + { + rOffset -= L; + } + + /* Decrement the loop counter */ + i--; + } + + /* Update the index pointer */ + *readOffset = rOffset; + } + + + /** + * @brief Q15 Circular write function. + */ + CMSIS_INLINE __STATIC_INLINE void arm_circularWrite_q15( + q15_t * circBuffer, + int32_t L, + uint16_t * writeOffset, + int32_t bufferInc, + const q15_t * src, + int32_t srcInc, + uint32_t blockSize) + { + uint32_t i = 0U; + int32_t wOffset; + + /* Copy the value of Index pointer that points + * to the current location where the input samples to be copied */ + wOffset = *writeOffset; + + /* Loop over the blockSize */ + i = blockSize; + + while (i > 0U) + { + /* copy the input sample to the circular buffer */ + circBuffer[wOffset] = *src; + + /* Update the input pointer */ + src += srcInc; + + /* Circularly update wOffset. Watch out for positive and negative value */ + wOffset += bufferInc; + if (wOffset >= L) + wOffset -= L; + + /* Decrement the loop counter */ + i--; + } + + /* Update the index pointer */ + *writeOffset = (uint16_t)wOffset; + } + + + /** + * @brief Q15 Circular Read function. + */ + CMSIS_INLINE __STATIC_INLINE void arm_circularRead_q15( + q15_t * circBuffer, + int32_t L, + int32_t * readOffset, + int32_t bufferInc, + q15_t * dst, + q15_t * dst_base, + int32_t dst_length, + int32_t dstInc, + uint32_t blockSize) + { + uint32_t i = 0; + int32_t rOffset, dst_end; + + /* Copy the value of Index pointer that points + * to the current location from where the input samples to be read */ + rOffset = *readOffset; + + dst_end = (int32_t) (dst_base + dst_length); + + /* Loop over the blockSize */ + i = blockSize; + + while (i > 0U) + { + /* copy the sample from the circular buffer to the destination buffer */ + *dst = circBuffer[rOffset]; + + /* Update the input pointer */ + dst += dstInc; + + if (dst == (q15_t *) dst_end) + { + dst = dst_base; + } + + /* Circularly update wOffset. Watch out for positive and negative value */ + rOffset += bufferInc; + + if (rOffset >= L) + { + rOffset -= L; + } + + /* Decrement the loop counter */ + i--; + } + + /* Update the index pointer */ + *readOffset = rOffset; + } + + + /** + * @brief Q7 Circular write function. + */ + CMSIS_INLINE __STATIC_INLINE void arm_circularWrite_q7( + q7_t * circBuffer, + int32_t L, + uint16_t * writeOffset, + int32_t bufferInc, + const q7_t * src, + int32_t srcInc, + uint32_t blockSize) + { + uint32_t i = 0U; + int32_t wOffset; + + /* Copy the value of Index pointer that points + * to the current location where the input samples to be copied */ + wOffset = *writeOffset; + + /* Loop over the blockSize */ + i = blockSize; + + while (i > 0U) + { + /* copy the input sample to the circular buffer */ + circBuffer[wOffset] = *src; + + /* Update the input pointer */ + src += srcInc; + + /* Circularly update wOffset. Watch out for positive and negative value */ + wOffset += bufferInc; + if (wOffset >= L) + wOffset -= L; + + /* Decrement the loop counter */ + i--; + } + + /* Update the index pointer */ + *writeOffset = (uint16_t)wOffset; + } + + + /** + * @brief Q7 Circular Read function. + */ + CMSIS_INLINE __STATIC_INLINE void arm_circularRead_q7( + q7_t * circBuffer, + int32_t L, + int32_t * readOffset, + int32_t bufferInc, + q7_t * dst, + q7_t * dst_base, + int32_t dst_length, + int32_t dstInc, + uint32_t blockSize) + { + uint32_t i = 0; + int32_t rOffset, dst_end; + + /* Copy the value of Index pointer that points + * to the current location from where the input samples to be read */ + rOffset = *readOffset; + + dst_end = (int32_t) (dst_base + dst_length); + + /* Loop over the blockSize */ + i = blockSize; + + while (i > 0U) + { + /* copy the sample from the circular buffer to the destination buffer */ + *dst = circBuffer[rOffset]; + + /* Update the input pointer */ + dst += dstInc; + + if (dst == (q7_t *) dst_end) + { + dst = dst_base; + } + + /* Circularly update rOffset. Watch out for positive and negative value */ + rOffset += bufferInc; + + if (rOffset >= L) + { + rOffset -= L; + } + + /* Decrement the loop counter */ + i--; + } + + /* Update the index pointer */ + *readOffset = rOffset; + } + + + /** + * @brief Sum of the squares of the elements of a Q31 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_power_q31( + q31_t * pSrc, + uint32_t blockSize, + q63_t * pResult); + + + /** + * @brief Sum of the squares of the elements of a floating-point vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_power_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + + + /** + * @brief Sum of the squares of the elements of a Q15 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_power_q15( + q15_t * pSrc, + uint32_t blockSize, + q63_t * pResult); + + + /** + * @brief Sum of the squares of the elements of a Q7 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_power_q7( + q7_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + + + /** + * @brief Mean value of a Q7 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_mean_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult); + + + /** + * @brief Mean value of a Q15 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_mean_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + + + /** + * @brief Mean value of a Q31 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_mean_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + + + /** + * @brief Mean value of a floating-point vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_mean_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + + + /** + * @brief Variance of the elements of a floating-point vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_var_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + + + /** + * @brief Variance of the elements of a Q31 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_var_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + + + /** + * @brief Variance of the elements of a Q15 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_var_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + + + /** + * @brief Root Mean Square of the elements of a floating-point vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_rms_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + + + /** + * @brief Root Mean Square of the elements of a Q31 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_rms_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + + + /** + * @brief Root Mean Square of the elements of a Q15 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_rms_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + + + /** + * @brief Standard deviation of the elements of a floating-point vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_std_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult); + + + /** + * @brief Standard deviation of the elements of a Q31 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_std_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult); + + + /** + * @brief Standard deviation of the elements of a Q15 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output value. + */ + void arm_std_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult); + + + /** + * @brief Floating-point complex magnitude + * @param[in] pSrc points to the complex input vector + * @param[out] pDst points to the real output vector + * @param[in] numSamples number of complex samples in the input vector + */ + void arm_cmplx_mag_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t numSamples); + + + /** + * @brief Q31 complex magnitude + * @param[in] pSrc points to the complex input vector + * @param[out] pDst points to the real output vector + * @param[in] numSamples number of complex samples in the input vector + */ + void arm_cmplx_mag_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t numSamples); + + + /** + * @brief Q15 complex magnitude + * @param[in] pSrc points to the complex input vector + * @param[out] pDst points to the real output vector + * @param[in] numSamples number of complex samples in the input vector + */ + void arm_cmplx_mag_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t numSamples); + + + /** + * @brief Q15 complex dot product + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[in] numSamples number of complex samples in each vector + * @param[out] realResult real part of the result returned here + * @param[out] imagResult imaginary part of the result returned here + */ + void arm_cmplx_dot_prod_q15( + q15_t * pSrcA, + q15_t * pSrcB, + uint32_t numSamples, + q31_t * realResult, + q31_t * imagResult); + + + /** + * @brief Q31 complex dot product + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[in] numSamples number of complex samples in each vector + * @param[out] realResult real part of the result returned here + * @param[out] imagResult imaginary part of the result returned here + */ + void arm_cmplx_dot_prod_q31( + q31_t * pSrcA, + q31_t * pSrcB, + uint32_t numSamples, + q63_t * realResult, + q63_t * imagResult); + + + /** + * @brief Floating-point complex dot product + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[in] numSamples number of complex samples in each vector + * @param[out] realResult real part of the result returned here + * @param[out] imagResult imaginary part of the result returned here + */ + void arm_cmplx_dot_prod_f32( + float32_t * pSrcA, + float32_t * pSrcB, + uint32_t numSamples, + float32_t * realResult, + float32_t * imagResult); + + + /** + * @brief Q15 complex-by-real multiplication + * @param[in] pSrcCmplx points to the complex input vector + * @param[in] pSrcReal points to the real input vector + * @param[out] pCmplxDst points to the complex output vector + * @param[in] numSamples number of samples in each vector + */ + void arm_cmplx_mult_real_q15( + q15_t * pSrcCmplx, + q15_t * pSrcReal, + q15_t * pCmplxDst, + uint32_t numSamples); + + + /** + * @brief Q31 complex-by-real multiplication + * @param[in] pSrcCmplx points to the complex input vector + * @param[in] pSrcReal points to the real input vector + * @param[out] pCmplxDst points to the complex output vector + * @param[in] numSamples number of samples in each vector + */ + void arm_cmplx_mult_real_q31( + q31_t * pSrcCmplx, + q31_t * pSrcReal, + q31_t * pCmplxDst, + uint32_t numSamples); + + + /** + * @brief Floating-point complex-by-real multiplication + * @param[in] pSrcCmplx points to the complex input vector + * @param[in] pSrcReal points to the real input vector + * @param[out] pCmplxDst points to the complex output vector + * @param[in] numSamples number of samples in each vector + */ + void arm_cmplx_mult_real_f32( + float32_t * pSrcCmplx, + float32_t * pSrcReal, + float32_t * pCmplxDst, + uint32_t numSamples); + + + /** + * @brief Minimum value of a Q7 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] result is output pointer + * @param[in] index is the array index of the minimum value in the input buffer. + */ + void arm_min_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * result, + uint32_t * index); + + + /** + * @brief Minimum value of a Q15 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output pointer + * @param[in] pIndex is the array index of the minimum value in the input buffer. + */ + void arm_min_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult, + uint32_t * pIndex); + + + /** + * @brief Minimum value of a Q31 vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output pointer + * @param[out] pIndex is the array index of the minimum value in the input buffer. + */ + void arm_min_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult, + uint32_t * pIndex); + + + /** + * @brief Minimum value of a floating-point vector. + * @param[in] pSrc is input pointer + * @param[in] blockSize is the number of samples to process + * @param[out] pResult is output pointer + * @param[out] pIndex is the array index of the minimum value in the input buffer. + */ + void arm_min_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult, + uint32_t * pIndex); + + +/** + * @brief Maximum value of a Q7 vector. + * @param[in] pSrc points to the input buffer + * @param[in] blockSize length of the input vector + * @param[out] pResult maximum value returned here + * @param[out] pIndex index of maximum value returned here + */ + void arm_max_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult, + uint32_t * pIndex); + + +/** + * @brief Maximum value of a Q15 vector. + * @param[in] pSrc points to the input buffer + * @param[in] blockSize length of the input vector + * @param[out] pResult maximum value returned here + * @param[out] pIndex index of maximum value returned here + */ + void arm_max_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult, + uint32_t * pIndex); + + +/** + * @brief Maximum value of a Q31 vector. + * @param[in] pSrc points to the input buffer + * @param[in] blockSize length of the input vector + * @param[out] pResult maximum value returned here + * @param[out] pIndex index of maximum value returned here + */ + void arm_max_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult, + uint32_t * pIndex); + + +/** + * @brief Maximum value of a floating-point vector. + * @param[in] pSrc points to the input buffer + * @param[in] blockSize length of the input vector + * @param[out] pResult maximum value returned here + * @param[out] pIndex index of maximum value returned here + */ + void arm_max_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult, + uint32_t * pIndex); + + + /** + * @brief Q15 complex-by-complex multiplication + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] numSamples number of complex samples in each vector + */ + void arm_cmplx_mult_cmplx_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t numSamples); + + + /** + * @brief Q31 complex-by-complex multiplication + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] numSamples number of complex samples in each vector + */ + void arm_cmplx_mult_cmplx_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t numSamples); + + + /** + * @brief Floating-point complex-by-complex multiplication + * @param[in] pSrcA points to the first input vector + * @param[in] pSrcB points to the second input vector + * @param[out] pDst points to the output vector + * @param[in] numSamples number of complex samples in each vector + */ + void arm_cmplx_mult_cmplx_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t numSamples); + + + /** + * @brief Converts the elements of the floating-point vector to Q31 vector. + * @param[in] pSrc points to the floating-point input vector + * @param[out] pDst points to the Q31 output vector + * @param[in] blockSize length of the input vector + */ + void arm_float_to_q31( + float32_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Converts the elements of the floating-point vector to Q15 vector. + * @param[in] pSrc points to the floating-point input vector + * @param[out] pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + */ + void arm_float_to_q15( + float32_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Converts the elements of the floating-point vector to Q7 vector. + * @param[in] pSrc points to the floating-point input vector + * @param[out] pDst points to the Q7 output vector + * @param[in] blockSize length of the input vector + */ + void arm_float_to_q7( + float32_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Converts the elements of the Q31 vector to Q15 vector. + * @param[in] pSrc is input pointer + * @param[out] pDst is output pointer + * @param[in] blockSize is the number of samples to process + */ + void arm_q31_to_q15( + q31_t * pSrc, + q15_t * pDst, + uint32_t blockSize); + + + /** + * @brief Converts the elements of the Q31 vector to Q7 vector. + * @param[in] pSrc is input pointer + * @param[out] pDst is output pointer + * @param[in] blockSize is the number of samples to process + */ + void arm_q31_to_q7( + q31_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @brief Converts the elements of the Q15 vector to floating-point vector. + * @param[in] pSrc is input pointer + * @param[out] pDst is output pointer + * @param[in] blockSize is the number of samples to process + */ + void arm_q15_to_float( + q15_t * pSrc, + float32_t * pDst, + uint32_t blockSize); + + + /** + * @brief Converts the elements of the Q15 vector to Q31 vector. + * @param[in] pSrc is input pointer + * @param[out] pDst is output pointer + * @param[in] blockSize is the number of samples to process + */ + void arm_q15_to_q31( + q15_t * pSrc, + q31_t * pDst, + uint32_t blockSize); + + + /** + * @brief Converts the elements of the Q15 vector to Q7 vector. + * @param[in] pSrc is input pointer + * @param[out] pDst is output pointer + * @param[in] blockSize is the number of samples to process + */ + void arm_q15_to_q7( + q15_t * pSrc, + q7_t * pDst, + uint32_t blockSize); + + + /** + * @ingroup groupInterpolation + */ + + /** + * @defgroup BilinearInterpolate Bilinear Interpolation + * + * Bilinear interpolation is an extension of linear interpolation applied to a two dimensional grid. + * The underlying function f(x, y) is sampled on a regular grid and the interpolation process + * determines values between the grid points. + * Bilinear interpolation is equivalent to two step linear interpolation, first in the x-dimension and then in the y-dimension. + * Bilinear interpolation is often used in image processing to rescale images. + * The CMSIS DSP library provides bilinear interpolation functions for Q7, Q15, Q31, and floating-point data types. + * + * Algorithm + * \par + * The instance structure used by the bilinear interpolation functions describes a two dimensional data table. + * For floating-point, the instance structure is defined as: + *
+   *   typedef struct
+   *   {
+   *     uint16_t numRows;
+   *     uint16_t numCols;
+   *     float32_t *pData;
+   * } arm_bilinear_interp_instance_f32;
+   * 
+ * + * \par + * where numRows specifies the number of rows in the table; + * numCols specifies the number of columns in the table; + * and pData points to an array of size numRows*numCols values. + * The data table pTable is organized in row order and the supplied data values fall on integer indexes. + * That is, table element (x,y) is located at pTable[x + y*numCols] where x and y are integers. + * + * \par + * Let (x, y) specify the desired interpolation point. Then define: + *
+   *     XF = floor(x)
+   *     YF = floor(y)
+   * 
+ * \par + * The interpolated output point is computed as: + *
+   *  f(x, y) = f(XF, YF) * (1-(x-XF)) * (1-(y-YF))
+   *           + f(XF+1, YF) * (x-XF)*(1-(y-YF))
+   *           + f(XF, YF+1) * (1-(x-XF))*(y-YF)
+   *           + f(XF+1, YF+1) * (x-XF)*(y-YF)
+   * 
+ * Note that the coordinates (x, y) contain integer and fractional components. + * The integer components specify which portion of the table to use while the + * fractional components control the interpolation processor. + * + * \par + * if (x,y) are outside of the table boundary, Bilinear interpolation returns zero output. + */ + + /** + * @addtogroup BilinearInterpolate + * @{ + */ + + + /** + * + * @brief Floating-point bilinear interpolation. + * @param[in,out] S points to an instance of the interpolation structure. + * @param[in] X interpolation coordinate. + * @param[in] Y interpolation coordinate. + * @return out interpolated value. + */ + CMSIS_INLINE __STATIC_INLINE float32_t arm_bilinear_interp_f32( + const arm_bilinear_interp_instance_f32 * S, + float32_t X, + float32_t Y) + { + float32_t out; + float32_t f00, f01, f10, f11; + float32_t *pData = S->pData; + int32_t xIndex, yIndex, index; + float32_t xdiff, ydiff; + float32_t b1, b2, b3, b4; + + xIndex = (int32_t) X; + yIndex = (int32_t) Y; + + /* Care taken for table outside boundary */ + /* Returns zero output when values are outside table boundary */ + if (xIndex < 0 || xIndex > (S->numRows - 1) || yIndex < 0 || yIndex > (S->numCols - 1)) + { + return (0); + } + + /* Calculation of index for two nearest points in X-direction */ + index = (xIndex - 1) + (yIndex - 1) * S->numCols; + + + /* Read two nearest points in X-direction */ + f00 = pData[index]; + f01 = pData[index + 1]; + + /* Calculation of index for two nearest points in Y-direction */ + index = (xIndex - 1) + (yIndex) * S->numCols; + + + /* Read two nearest points in Y-direction */ + f10 = pData[index]; + f11 = pData[index + 1]; + + /* Calculation of intermediate values */ + b1 = f00; + b2 = f01 - f00; + b3 = f10 - f00; + b4 = f00 - f01 - f10 + f11; + + /* Calculation of fractional part in X */ + xdiff = X - xIndex; + + /* Calculation of fractional part in Y */ + ydiff = Y - yIndex; + + /* Calculation of bi-linear interpolated output */ + out = b1 + b2 * xdiff + b3 * ydiff + b4 * xdiff * ydiff; + + /* return to application */ + return (out); + } + + + /** + * + * @brief Q31 bilinear interpolation. + * @param[in,out] S points to an instance of the interpolation structure. + * @param[in] X interpolation coordinate in 12.20 format. + * @param[in] Y interpolation coordinate in 12.20 format. + * @return out interpolated value. + */ + CMSIS_INLINE __STATIC_INLINE q31_t arm_bilinear_interp_q31( + arm_bilinear_interp_instance_q31 * S, + q31_t X, + q31_t Y) + { + q31_t out; /* Temporary output */ + q31_t acc = 0; /* output */ + q31_t xfract, yfract; /* X, Y fractional parts */ + q31_t x1, x2, y1, y2; /* Nearest output values */ + int32_t rI, cI; /* Row and column indices */ + q31_t *pYData = S->pData; /* pointer to output table values */ + uint32_t nCols = S->numCols; /* num of rows */ + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + rI = ((X & (q31_t)0xFFF00000) >> 20); + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + cI = ((Y & (q31_t)0xFFF00000) >> 20); + + /* Care taken for table outside boundary */ + /* Returns zero output when values are outside table boundary */ + if (rI < 0 || rI > (S->numRows - 1) || cI < 0 || cI > (S->numCols - 1)) + { + return (0); + } + + /* 20 bits for the fractional part */ + /* shift left xfract by 11 to keep 1.31 format */ + xfract = (X & 0x000FFFFF) << 11U; + + /* Read two nearest output values from the index */ + x1 = pYData[(rI) + (int32_t)nCols * (cI) ]; + x2 = pYData[(rI) + (int32_t)nCols * (cI) + 1]; + + /* 20 bits for the fractional part */ + /* shift left yfract by 11 to keep 1.31 format */ + yfract = (Y & 0x000FFFFF) << 11U; + + /* Read two nearest output values from the index */ + y1 = pYData[(rI) + (int32_t)nCols * (cI + 1) ]; + y2 = pYData[(rI) + (int32_t)nCols * (cI + 1) + 1]; + + /* Calculation of x1 * (1-xfract ) * (1-yfract) and acc is in 3.29(q29) format */ + out = ((q31_t) (((q63_t) x1 * (0x7FFFFFFF - xfract)) >> 32)); + acc = ((q31_t) (((q63_t) out * (0x7FFFFFFF - yfract)) >> 32)); + + /* x2 * (xfract) * (1-yfract) in 3.29(q29) and adding to acc */ + out = ((q31_t) ((q63_t) x2 * (0x7FFFFFFF - yfract) >> 32)); + acc += ((q31_t) ((q63_t) out * (xfract) >> 32)); + + /* y1 * (1 - xfract) * (yfract) in 3.29(q29) and adding to acc */ + out = ((q31_t) ((q63_t) y1 * (0x7FFFFFFF - xfract) >> 32)); + acc += ((q31_t) ((q63_t) out * (yfract) >> 32)); + + /* y2 * (xfract) * (yfract) in 3.29(q29) and adding to acc */ + out = ((q31_t) ((q63_t) y2 * (xfract) >> 32)); + acc += ((q31_t) ((q63_t) out * (yfract) >> 32)); + + /* Convert acc to 1.31(q31) format */ + return ((q31_t)(acc << 2)); + } + + + /** + * @brief Q15 bilinear interpolation. + * @param[in,out] S points to an instance of the interpolation structure. + * @param[in] X interpolation coordinate in 12.20 format. + * @param[in] Y interpolation coordinate in 12.20 format. + * @return out interpolated value. + */ + CMSIS_INLINE __STATIC_INLINE q15_t arm_bilinear_interp_q15( + arm_bilinear_interp_instance_q15 * S, + q31_t X, + q31_t Y) + { + q63_t acc = 0; /* output */ + q31_t out; /* Temporary output */ + q15_t x1, x2, y1, y2; /* Nearest output values */ + q31_t xfract, yfract; /* X, Y fractional parts */ + int32_t rI, cI; /* Row and column indices */ + q15_t *pYData = S->pData; /* pointer to output table values */ + uint32_t nCols = S->numCols; /* num of rows */ + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + rI = ((X & (q31_t)0xFFF00000) >> 20); + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + cI = ((Y & (q31_t)0xFFF00000) >> 20); + + /* Care taken for table outside boundary */ + /* Returns zero output when values are outside table boundary */ + if (rI < 0 || rI > (S->numRows - 1) || cI < 0 || cI > (S->numCols - 1)) + { + return (0); + } + + /* 20 bits for the fractional part */ + /* xfract should be in 12.20 format */ + xfract = (X & 0x000FFFFF); + + /* Read two nearest output values from the index */ + x1 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI) ]; + x2 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI) + 1]; + + /* 20 bits for the fractional part */ + /* yfract should be in 12.20 format */ + yfract = (Y & 0x000FFFFF); + + /* Read two nearest output values from the index */ + y1 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI + 1) ]; + y2 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI + 1) + 1]; + + /* Calculation of x1 * (1-xfract ) * (1-yfract) and acc is in 13.51 format */ + + /* x1 is in 1.15(q15), xfract in 12.20 format and out is in 13.35 format */ + /* convert 13.35 to 13.31 by right shifting and out is in 1.31 */ + out = (q31_t) (((q63_t) x1 * (0xFFFFF - xfract)) >> 4U); + acc = ((q63_t) out * (0xFFFFF - yfract)); + + /* x2 * (xfract) * (1-yfract) in 1.51 and adding to acc */ + out = (q31_t) (((q63_t) x2 * (0xFFFFF - yfract)) >> 4U); + acc += ((q63_t) out * (xfract)); + + /* y1 * (1 - xfract) * (yfract) in 1.51 and adding to acc */ + out = (q31_t) (((q63_t) y1 * (0xFFFFF - xfract)) >> 4U); + acc += ((q63_t) out * (yfract)); + + /* y2 * (xfract) * (yfract) in 1.51 and adding to acc */ + out = (q31_t) (((q63_t) y2 * (xfract)) >> 4U); + acc += ((q63_t) out * (yfract)); + + /* acc is in 13.51 format and down shift acc by 36 times */ + /* Convert out to 1.15 format */ + return ((q15_t)(acc >> 36)); + } + + + /** + * @brief Q7 bilinear interpolation. + * @param[in,out] S points to an instance of the interpolation structure. + * @param[in] X interpolation coordinate in 12.20 format. + * @param[in] Y interpolation coordinate in 12.20 format. + * @return out interpolated value. + */ + CMSIS_INLINE __STATIC_INLINE q7_t arm_bilinear_interp_q7( + arm_bilinear_interp_instance_q7 * S, + q31_t X, + q31_t Y) + { + q63_t acc = 0; /* output */ + q31_t out; /* Temporary output */ + q31_t xfract, yfract; /* X, Y fractional parts */ + q7_t x1, x2, y1, y2; /* Nearest output values */ + int32_t rI, cI; /* Row and column indices */ + q7_t *pYData = S->pData; /* pointer to output table values */ + uint32_t nCols = S->numCols; /* num of rows */ + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + rI = ((X & (q31_t)0xFFF00000) >> 20); + + /* Input is in 12.20 format */ + /* 12 bits for the table index */ + /* Index value calculation */ + cI = ((Y & (q31_t)0xFFF00000) >> 20); + + /* Care taken for table outside boundary */ + /* Returns zero output when values are outside table boundary */ + if (rI < 0 || rI > (S->numRows - 1) || cI < 0 || cI > (S->numCols - 1)) + { + return (0); + } + + /* 20 bits for the fractional part */ + /* xfract should be in 12.20 format */ + xfract = (X & (q31_t)0x000FFFFF); + + /* Read two nearest output values from the index */ + x1 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI) ]; + x2 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI) + 1]; + + /* 20 bits for the fractional part */ + /* yfract should be in 12.20 format */ + yfract = (Y & (q31_t)0x000FFFFF); + + /* Read two nearest output values from the index */ + y1 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI + 1) ]; + y2 = pYData[((uint32_t)rI) + nCols * ((uint32_t)cI + 1) + 1]; + + /* Calculation of x1 * (1-xfract ) * (1-yfract) and acc is in 16.47 format */ + out = ((x1 * (0xFFFFF - xfract))); + acc = (((q63_t) out * (0xFFFFF - yfract))); + + /* x2 * (xfract) * (1-yfract) in 2.22 and adding to acc */ + out = ((x2 * (0xFFFFF - yfract))); + acc += (((q63_t) out * (xfract))); + + /* y1 * (1 - xfract) * (yfract) in 2.22 and adding to acc */ + out = ((y1 * (0xFFFFF - xfract))); + acc += (((q63_t) out * (yfract))); + + /* y2 * (xfract) * (yfract) in 2.22 and adding to acc */ + out = ((y2 * (yfract))); + acc += (((q63_t) out * (xfract))); + + /* acc in 16.47 format and down shift by 40 to convert to 1.7 format */ + return ((q7_t)(acc >> 40)); + } + + /** + * @} end of BilinearInterpolate group + */ + + +/* SMMLAR */ +#define multAcc_32x32_keep32_R(a, x, y) \ + a = (q31_t) (((((q63_t) a) << 32) + ((q63_t) x * y) + 0x80000000LL ) >> 32) + +/* SMMLSR */ +#define multSub_32x32_keep32_R(a, x, y) \ + a = (q31_t) (((((q63_t) a) << 32) - ((q63_t) x * y) + 0x80000000LL ) >> 32) + +/* SMMULR */ +#define mult_32x32_keep32_R(a, x, y) \ + a = (q31_t) (((q63_t) x * y + 0x80000000LL ) >> 32) + +/* SMMLA */ +#define multAcc_32x32_keep32(a, x, y) \ + a += (q31_t) (((q63_t) x * y) >> 32) + +/* SMMLS */ +#define multSub_32x32_keep32(a, x, y) \ + a -= (q31_t) (((q63_t) x * y) >> 32) + +/* SMMUL */ +#define mult_32x32_keep32(a, x, y) \ + a = (q31_t) (((q63_t) x * y ) >> 32) + + +#if defined ( __CC_ARM ) + /* Enter low optimization region - place directly above function definition */ + #if defined( ARM_MATH_CM4 ) || defined( ARM_MATH_CM7) + #define LOW_OPTIMIZATION_ENTER \ + _Pragma ("push") \ + _Pragma ("O1") + #else + #define LOW_OPTIMIZATION_ENTER + #endif + + /* Exit low optimization region - place directly after end of function definition */ + #if defined ( ARM_MATH_CM4 ) || defined ( ARM_MATH_CM7 ) + #define LOW_OPTIMIZATION_EXIT \ + _Pragma ("pop") + #else + #define LOW_OPTIMIZATION_EXIT + #endif + + /* Enter low optimization region - place directly above function definition */ + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER + + /* Exit low optimization region - place directly after end of function definition */ + #define IAR_ONLY_LOW_OPTIMIZATION_EXIT + +#elif defined (__ARMCC_VERSION ) && ( __ARMCC_VERSION >= 6010050 ) + #define LOW_OPTIMIZATION_ENTER + #define LOW_OPTIMIZATION_EXIT + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER + #define IAR_ONLY_LOW_OPTIMIZATION_EXIT + +#elif defined ( __GNUC__ ) + #define LOW_OPTIMIZATION_ENTER \ + __attribute__(( optimize("-O1") )) + #define LOW_OPTIMIZATION_EXIT + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER + #define IAR_ONLY_LOW_OPTIMIZATION_EXIT + +#elif defined ( __ICCARM__ ) + /* Enter low optimization region - place directly above function definition */ + #if defined ( ARM_MATH_CM4 ) || defined ( ARM_MATH_CM7 ) + #define LOW_OPTIMIZATION_ENTER \ + _Pragma ("optimize=low") + #else + #define LOW_OPTIMIZATION_ENTER + #endif + + /* Exit low optimization region - place directly after end of function definition */ + #define LOW_OPTIMIZATION_EXIT + + /* Enter low optimization region - place directly above function definition */ + #if defined ( ARM_MATH_CM4 ) || defined ( ARM_MATH_CM7 ) + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER \ + _Pragma ("optimize=low") + #else + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER + #endif + + /* Exit low optimization region - place directly after end of function definition */ + #define IAR_ONLY_LOW_OPTIMIZATION_EXIT + +#elif defined ( __TI_ARM__ ) + #define LOW_OPTIMIZATION_ENTER + #define LOW_OPTIMIZATION_EXIT + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER + #define IAR_ONLY_LOW_OPTIMIZATION_EXIT + +#elif defined ( __CSMC__ ) + #define LOW_OPTIMIZATION_ENTER + #define LOW_OPTIMIZATION_EXIT + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER + #define IAR_ONLY_LOW_OPTIMIZATION_EXIT + +#elif defined ( __TASKING__ ) + #define LOW_OPTIMIZATION_ENTER + #define LOW_OPTIMIZATION_EXIT + #define IAR_ONLY_LOW_OPTIMIZATION_ENTER + #define IAR_ONLY_LOW_OPTIMIZATION_EXIT + +#endif + + +#ifdef __cplusplus +} +#endif + +/* Compiler specific diagnostic adjustment */ +#if defined ( __CC_ARM ) + +#elif defined ( __ARMCC_VERSION ) && ( __ARMCC_VERSION >= 6010050 ) + +#elif defined ( __GNUC__ ) +#pragma GCC diagnostic pop + +#elif defined ( __ICCARM__ ) + +#elif defined ( __TI_ARM__ ) + +#elif defined ( __CSMC__ ) + +#elif defined ( __TASKING__ ) + +#else + #error Unknown compiler +#endif + +#endif /* _ARM_MATH_H */ + +/** + * + * End of file. + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_f32.c new file mode 100644 index 0000000..69b2bfc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_f32.c @@ -0,0 +1,153 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_abs_f32.c + * Description: Floating-point vector absolute value + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include + +/** + * @ingroup groupMath + */ + +/** + * @defgroup BasicAbs Vector Absolute Value + * + * Computes the absolute value of a vector on an element-by-element basis. + * + *
+ *     pDst[n] = abs(pSrc[n]),   0 <= n < blockSize.
+ * 
+ * + * The functions support in-place computation allowing the source and + * destination pointers to reference the same memory buffer. + * There are separate functions for floating-point, Q7, Q15, and Q31 data types. + */ + +/** + * @addtogroup BasicAbs + * @{ + */ + +/** + * @brief Floating-point vector absolute value. + * @param[in] *pSrc points to the input buffer + * @param[out] *pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + * @return none. + */ + +void arm_abs_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t in1, in2, in3, in4; /* temporary variables */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = |A| */ + /* Calculate absolute and then store the results in the destination buffer. */ + /* read sample from source */ + in1 = *pSrc; + in2 = *(pSrc + 1); + in3 = *(pSrc + 2); + + /* find absolute value */ + in1 = fabsf(in1); + + /* read sample from source */ + in4 = *(pSrc + 3); + + /* find absolute value */ + in2 = fabsf(in2); + + /* read sample from source */ + *pDst = in1; + + /* find absolute value */ + in3 = fabsf(in3); + + /* find absolute value */ + in4 = fabsf(in4); + + /* store result to destination */ + *(pDst + 1) = in2; + + /* store result to destination */ + *(pDst + 2) = in3; + + /* store result to destination */ + *(pDst + 3) = in4; + + + /* Update source pointer to process next sampels */ + pSrc += 4U; + + /* Update destination pointer to process next sampels */ + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = |A| */ + /* Calculate absolute and then store the results in the destination buffer. */ + *pDst++ = fabsf(*pSrc++); + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicAbs group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q15.c new file mode 100644 index 0000000..4bed8cc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q15.c @@ -0,0 +1,167 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_abs_q15.c + * Description: Q15 vector absolute value + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicAbs + * @{ + */ + +/** + * @brief Q15 vector absolute value. + * @param[in] *pSrc points to the input buffer + * @param[out] *pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * The Q15 value -1 (0x8000) will be saturated to the maximum allowable positive value 0x7FFF. + */ + +void arm_abs_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + __SIMD32_TYPE *simd; + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t in1; /* Input value1 */ + q15_t in2; /* Input value2 */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + simd = __SIMD32_CONST(pDst); + while (blkCnt > 0U) + { + /* C = |A| */ + /* Read two inputs */ + in1 = *pSrc++; + in2 = *pSrc++; + + + /* Store the Absolute result in the destination buffer by packing the two values, in a single cycle */ +#ifndef ARM_MATH_BIG_ENDIAN + *simd++ = + __PKHBT(((in1 > 0) ? in1 : (q15_t)__QSUB16(0, in1)), + ((in2 > 0) ? in2 : (q15_t)__QSUB16(0, in2)), 16); + +#else + + + *simd++ = + __PKHBT(((in2 > 0) ? in2 : (q15_t)__QSUB16(0, in2)), + ((in1 > 0) ? in1 : (q15_t)__QSUB16(0, in1)), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + in1 = *pSrc++; + in2 = *pSrc++; + + +#ifndef ARM_MATH_BIG_ENDIAN + + *simd++ = + __PKHBT(((in1 > 0) ? in1 : (q15_t)__QSUB16(0, in1)), + ((in2 > 0) ? in2 : (q15_t)__QSUB16(0, in2)), 16); + +#else + + + *simd++ = + __PKHBT(((in2 > 0) ? in2 : (q15_t)__QSUB16(0, in2)), + ((in1 > 0) ? in1 : (q15_t)__QSUB16(0, in1)), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Decrement the loop counter */ + blkCnt--; + } + pDst = (q15_t *)simd; + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = |A| */ + /* Read the input */ + in1 = *pSrc++; + + /* Calculate absolute value of input and then store the result in the destination buffer. */ + *pDst++ = (in1 > 0) ? in1 : (q15_t)__QSUB16(0, in1); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + q15_t in; /* Temporary input variable */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = |A| */ + /* Read the input */ + in = *pSrc++; + + /* Calculate absolute value of input and then store the result in the destination buffer. */ + *pDst++ = (in > 0) ? in : ((in == (q15_t) 0x8000) ? 0x7fff : -in); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of BasicAbs group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q31.c new file mode 100644 index 0000000..25cd036 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q31.c @@ -0,0 +1,118 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_abs_q31.c + * Description: Q31 vector absolute value + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicAbs + * @{ + */ + + +/** + * @brief Q31 vector absolute value. + * @param[in] *pSrc points to the input buffer + * @param[out] *pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * The Q31 value -1 (0x80000000) will be saturated to the maximum allowable positive value 0x7FFFFFFF. + */ + +void arm_abs_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + q31_t in; /* Input value */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2, in3, in4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = |A| */ + /* Calculate absolute of input (if -1 then saturated to 0x7fffffff) and then store the results in the destination buffer. */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + *pDst++ = (in1 > 0) ? in1 : (q31_t)__QSUB(0, in1); + *pDst++ = (in2 > 0) ? in2 : (q31_t)__QSUB(0, in2); + *pDst++ = (in3 > 0) ? in3 : (q31_t)__QSUB(0, in3); + *pDst++ = (in4 > 0) ? in4 : (q31_t)__QSUB(0, in4); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = |A| */ + /* Calculate absolute value of the input (if -1 then saturated to 0x7fffffff) and then store the results in the destination buffer. */ + in = *pSrc++; + *pDst++ = (in > 0) ? in : ((in == INT32_MIN) ? INT32_MAX : -in); + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of BasicAbs group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q7.c new file mode 100644 index 0000000..1ab2a1c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_abs_q7.c @@ -0,0 +1,145 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_abs_q7.c + * Description: Q7 vector absolute value + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicAbs + * @{ + */ + +/** + * @brief Q7 vector absolute value. + * @param[in] *pSrc points to the input buffer + * @param[out] *pDst points to the output buffer + * @param[in] blockSize number of samples in each vector + * @return none. + * + * \par Conditions for optimum performance + * Input and output buffers should be aligned by 32-bit + * + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * The Q7 value -1 (0x80) will be saturated to the maximum allowable positive value 0x7F. + */ + +void arm_abs_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + q7_t in; /* Input value1 */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2, in3, in4; /* temporary input variables */ + q31_t out1, out2, out3, out4; /* temporary output variables */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = |A| */ + /* Read inputs */ + in1 = (q31_t) * pSrc; + in2 = (q31_t) * (pSrc + 1); + in3 = (q31_t) * (pSrc + 2); + + /* find absolute value */ + out1 = (in1 > 0) ? in1 : (q31_t)__QSUB8(0, in1); + + /* read input */ + in4 = (q31_t) * (pSrc + 3); + + /* find absolute value */ + out2 = (in2 > 0) ? in2 : (q31_t)__QSUB8(0, in2); + + /* store result to destination */ + *pDst = (q7_t) out1; + + /* find absolute value */ + out3 = (in3 > 0) ? in3 : (q31_t)__QSUB8(0, in3); + + /* find absolute value */ + out4 = (in4 > 0) ? in4 : (q31_t)__QSUB8(0, in4); + + /* store result to destination */ + *(pDst + 1) = (q7_t) out2; + + /* store result to destination */ + *(pDst + 2) = (q7_t) out3; + + /* store result to destination */ + *(pDst + 3) = (q7_t) out4; + + /* update pointers to process next samples */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; +#else + + /* Run the below code for Cortex-M0 */ + blkCnt = blockSize; + +#endif /* #define ARM_MATH_CM0_FAMILY */ + + while (blkCnt > 0U) + { + /* C = |A| */ + /* Read the input */ + in = *pSrc++; + + /* Store the Absolute result in the destination buffer */ + *pDst++ = (in > 0) ? in : ((in == (q7_t) 0x80) ? 0x7f : -in); + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicAbs group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_f32.c new file mode 100644 index 0000000..4d1ac4d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_f32.c @@ -0,0 +1,138 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_add_f32.c + * Description: Floating-point vector addition + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @defgroup BasicAdd Vector Addition + * + * Element-by-element addition of two vectors. + * + *
+ *     pDst[n] = pSrcA[n] + pSrcB[n],   0 <= n < blockSize.
+ * 
+ * + * There are separate functions for floating-point, Q7, Q15, and Q31 data types. + */ + +/** + * @addtogroup BasicAdd + * @{ + */ + +/** + * @brief Floating-point vector addition. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + */ + +void arm_add_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t inA1, inA2, inA3, inA4; /* temporary input variabels */ + float32_t inB1, inB2, inB3, inB4; /* temporary input variables */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + + /* read four inputs from sourceA and four inputs from sourceB */ + inA1 = *pSrcA; + inB1 = *pSrcB; + inA2 = *(pSrcA + 1); + inB2 = *(pSrcB + 1); + inA3 = *(pSrcA + 2); + inB3 = *(pSrcB + 2); + inA4 = *(pSrcA + 3); + inB4 = *(pSrcB + 3); + + /* C = A + B */ + /* add and store result to destination */ + *pDst = inA1 + inB1; + *(pDst + 1) = inA2 + inB2; + *(pDst + 2) = inA3 + inB3; + *(pDst + 3) = inA4 + inB4; + + /* update pointers to process next samples */ + pSrcA += 4U; + pSrcB += 4U; + pDst += 4U; + + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *pDst++ = (*pSrcA++) + (*pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicAdd group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q15.c new file mode 100644 index 0000000..2a14c29 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q15.c @@ -0,0 +1,128 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_add_q15.c + * Description: Q15 vector addition + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicAdd + * @{ + */ + +/** + * @brief Q15 vector addition. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +void arm_add_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2, inB1, inB2; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + inA1 = *__SIMD32(pSrcA)++; + inA2 = *__SIMD32(pSrcA)++; + inB1 = *__SIMD32(pSrcB)++; + inB2 = *__SIMD32(pSrcB)++; + + *__SIMD32(pDst)++ = __QADD16(inA1, inB1); + *__SIMD32(pDst)++ = __QADD16(inA2, inB2); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *pDst++ = (q15_t) __QADD16(*pSrcA++, *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *pDst++ = (q15_t) __SSAT(((q31_t) * pSrcA++ + *pSrcB++), 16); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + +} + +/** + * @} end of BasicAdd group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q31.c new file mode 100644 index 0000000..7503e1a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q31.c @@ -0,0 +1,136 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_add_q31.c + * Description: Q31 vector addition + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicAdd + * @{ + */ + + +/** + * @brief Q31 vector addition. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range[0x80000000 0x7FFFFFFF] will be saturated. + */ + +void arm_add_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2, inA3, inA4; + q31_t inB1, inB2, inB3, inB4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + inA1 = *pSrcA++; + inA2 = *pSrcA++; + inB1 = *pSrcB++; + inB2 = *pSrcB++; + + inA3 = *pSrcA++; + inA4 = *pSrcA++; + inB3 = *pSrcB++; + inB4 = *pSrcB++; + + *pDst++ = __QADD(inA1, inB1); + *pDst++ = __QADD(inA2, inB2); + *pDst++ = __QADD(inA3, inB3); + *pDst++ = __QADD(inA4, inB4); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *pDst++ = __QADD(*pSrcA++, *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *pDst++ = (q31_t) clip_q63_to_q31((q63_t) * pSrcA++ + *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of BasicAdd group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q7.c new file mode 100644 index 0000000..fee1865 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_add_q7.c @@ -0,0 +1,122 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_add_q7.c + * Description: Q7 vector addition + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicAdd + * @{ + */ + +/** + * @brief Q7 vector addition. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x80 0x7F] will be saturated. + */ + +void arm_add_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *__SIMD32(pDst)++ = __QADD8(*__SIMD32(pSrcA)++, *__SIMD32(pSrcB)++); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *pDst++ = (q7_t) __SSAT(*pSrcA++ + *pSrcB++, 8); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A + B */ + /* Add and then store the results in the destination buffer. */ + *pDst++ = (q7_t) __SSAT((q15_t) * pSrcA++ + *pSrcB++, 8); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + +} + +/** + * @} end of BasicAdd group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_f32.c new file mode 100644 index 0000000..6c7aae1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_f32.c @@ -0,0 +1,123 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dot_prod_f32.c + * Description: Floating-point dot product + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @defgroup dot_prod Vector Dot Product + * + * Computes the dot product of two vectors. + * The vectors are multiplied element-by-element and then summed. + * + *
+ *     sum = pSrcA[0]*pSrcB[0] + pSrcA[1]*pSrcB[1] + ... + pSrcA[blockSize-1]*pSrcB[blockSize-1]
+ * 
+ * + * There are separate functions for floating-point, Q7, Q15, and Q31 data types. + */ + +/** + * @addtogroup dot_prod + * @{ + */ + +/** + * @brief Dot product of floating-point vectors. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] *result output result returned here + * @return none. + */ + + +void arm_dot_prod_f32( + float32_t * pSrcA, + float32_t * pSrcB, + uint32_t blockSize, + float32_t * result) +{ + float32_t sum = 0.0f; /* Temporary result storage */ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Calculate dot product and then store the result in a temporary buffer */ + sum += (*pSrcA++) * (*pSrcB++); + sum += (*pSrcA++) * (*pSrcB++); + sum += (*pSrcA++) * (*pSrcB++); + sum += (*pSrcA++) * (*pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Calculate dot product and then store the result in a temporary buffer. */ + sum += (*pSrcA++) * (*pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + /* Store the result back in the destination buffer */ + *result = sum; +} + +/** + * @} end of dot_prod group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q15.c new file mode 100644 index 0000000..6a48242 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q15.c @@ -0,0 +1,128 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dot_prod_q15.c + * Description: Q15 dot product + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup dot_prod + * @{ + */ + +/** + * @brief Dot product of Q15 vectors. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] *result output result returned here + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The intermediate multiplications are in 1.15 x 1.15 = 2.30 format and these + * results are added to a 64-bit accumulator in 34.30 format. + * Nonsaturating additions are used and given that there are 33 guard bits in the accumulator + * there is no risk of overflow. + * The return result is in 34.30 format. + */ + +void arm_dot_prod_q15( + q15_t * pSrcA, + q15_t * pSrcB, + uint32_t blockSize, + q63_t * result) +{ + q63_t sum = 0; /* Temporary result storage */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Calculate dot product and then store the result in a temporary buffer. */ + sum = __SMLALD(*__SIMD32(pSrcA)++, *__SIMD32(pSrcB)++, sum); + sum = __SMLALD(*__SIMD32(pSrcA)++, *__SIMD32(pSrcB)++, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Calculate dot product and then store the results in a temporary buffer. */ + sum = __SMLALD(*pSrcA++, *pSrcB++, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Calculate dot product and then store the results in a temporary buffer. */ + sum += (q63_t) ((q31_t) * pSrcA++ * *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Store the result in the destination buffer in 34.30 format */ + *result = sum; + +} + +/** + * @} end of dot_prod group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q31.c new file mode 100644 index 0000000..e739879 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q31.c @@ -0,0 +1,131 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dot_prod_q31.c + * Description: Q31 dot product + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup dot_prod + * @{ + */ + +/** + * @brief Dot product of Q31 vectors. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] *result output result returned here + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The intermediate multiplications are in 1.31 x 1.31 = 2.62 format and these + * are truncated to 2.48 format by discarding the lower 14 bits. + * The 2.48 result is then added without saturation to a 64-bit accumulator in 16.48 format. + * There are 15 guard bits in the accumulator and there is no risk of overflow as long as + * the length of the vectors is less than 2^16 elements. + * The return result is in 16.48 format. + */ + +void arm_dot_prod_q31( + q31_t * pSrcA, + q31_t * pSrcB, + uint32_t blockSize, + q63_t * result) +{ + q63_t sum = 0; /* Temporary result storage */ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2, inA3, inA4; + q31_t inB1, inB2, inB3, inB4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Calculate dot product and then store the result in a temporary buffer. */ + inA1 = *pSrcA++; + inA2 = *pSrcA++; + inA3 = *pSrcA++; + inA4 = *pSrcA++; + inB1 = *pSrcB++; + inB2 = *pSrcB++; + inB3 = *pSrcB++; + inB4 = *pSrcB++; + + sum += ((q63_t) inA1 * inB1) >> 14U; + sum += ((q63_t) inA2 * inB2) >> 14U; + sum += ((q63_t) inA3 * inB3) >> 14U; + sum += ((q63_t) inA4 * inB4) >> 14U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Calculate dot product and then store the result in a temporary buffer. */ + sum += ((q63_t) * pSrcA++ * *pSrcB++) >> 14U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the result in the destination buffer in 16.48 format */ + *result = sum; +} + +/** + * @} end of dot_prod group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q7.c new file mode 100644 index 0000000..ef08038 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_dot_prod_q7.c @@ -0,0 +1,147 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dot_prod_q7.c + * Description: Q7 dot product + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup dot_prod + * @{ + */ + +/** + * @brief Dot product of Q7 vectors. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[in] blockSize number of samples in each vector + * @param[out] *result output result returned here + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The intermediate multiplications are in 1.7 x 1.7 = 2.14 format and these + * results are added to an accumulator in 18.14 format. + * Nonsaturating additions are used and there is no danger of wrap around as long as + * the vectors are less than 2^18 elements long. + * The return result is in 18.14 format. + */ + +void arm_dot_prod_q7( + q7_t * pSrcA, + q7_t * pSrcB, + uint32_t blockSize, + q31_t * result) +{ + uint32_t blkCnt; /* loop counter */ + + q31_t sum = 0; /* Temporary variables to store output */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t input1, input2; /* Temporary variables to store input */ + q31_t inA1, inA2, inB1, inB2; /* Temporary variables to store input */ + + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* read 4 samples at a time from sourceA */ + input1 = *__SIMD32(pSrcA)++; + /* read 4 samples at a time from sourceB */ + input2 = *__SIMD32(pSrcB)++; + + /* extract two q7_t samples to q15_t samples */ + inA1 = __SXTB16(__ROR(input1, 8)); + /* extract reminaing two samples */ + inA2 = __SXTB16(input1); + /* extract two q7_t samples to q15_t samples */ + inB1 = __SXTB16(__ROR(input2, 8)); + /* extract reminaing two samples */ + inB2 = __SXTB16(input2); + + /* multiply and accumulate two samples at a time */ + sum = __SMLAD(inA1, inB1, sum); + sum = __SMLAD(inA2, inB2, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Dot product and then store the results in a temporary buffer. */ + sum = __SMLAD(*pSrcA++, *pSrcB++, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A[0]* B[0] + A[1]* B[1] + A[2]* B[2] + .....+ A[blockSize-1]* B[blockSize-1] */ + /* Dot product and then store the results in a temporary buffer. */ + sum += (q31_t) ((q15_t) * pSrcA++ * *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + + /* Store the result in the destination buffer in 18.14 format */ + *result = sum; +} + +/** + * @} end of dot_prod group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_f32.c new file mode 100644 index 0000000..334e32b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_f32.c @@ -0,0 +1,162 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mult_f32.c + * Description: Floating-point vector multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @defgroup BasicMult Vector Multiplication + * + * Element-by-element multiplication of two vectors. + * + *
+ *     pDst[n] = pSrcA[n] * pSrcB[n],   0 <= n < blockSize.
+ * 
+ * + * There are separate functions for floating-point, Q7, Q15, and Q31 data types. + */ + +/** + * @addtogroup BasicMult + * @{ + */ + +/** + * @brief Floating-point vector multiplication. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + */ + +void arm_mult_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counters */ +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t inA1, inA2, inA3, inA4; /* temporary input variables */ + float32_t inB1, inB2, inB3, inB4; /* temporary input variables */ + float32_t out1, out2, out3, out4; /* temporary output variables */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the results in output buffer */ + /* read sample from sourceA */ + inA1 = *pSrcA; + /* read sample from sourceB */ + inB1 = *pSrcB; + /* read sample from sourceA */ + inA2 = *(pSrcA + 1); + /* read sample from sourceB */ + inB2 = *(pSrcB + 1); + + /* out = sourceA * sourceB */ + out1 = inA1 * inB1; + + /* read sample from sourceA */ + inA3 = *(pSrcA + 2); + /* read sample from sourceB */ + inB3 = *(pSrcB + 2); + + /* out = sourceA * sourceB */ + out2 = inA2 * inB2; + + /* read sample from sourceA */ + inA4 = *(pSrcA + 3); + + /* store result to destination buffer */ + *pDst = out1; + + /* read sample from sourceB */ + inB4 = *(pSrcB + 3); + + /* out = sourceA * sourceB */ + out3 = inA3 * inB3; + + /* store result to destination buffer */ + *(pDst + 1) = out2; + + /* out = sourceA * sourceB */ + out4 = inA4 * inB4; + /* store result to destination buffer */ + *(pDst + 2) = out3; + /* store result to destination buffer */ + *(pDst + 3) = out4; + + + /* update pointers to process next samples */ + pSrcA += 4U; + pSrcB += 4U; + pDst += 4U; + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the results in output buffer */ + *pDst++ = (*pSrcA++) * (*pSrcB++); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q15.c new file mode 100644 index 0000000..f3039d2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q15.c @@ -0,0 +1,142 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mult_q15.c + * Description: Q15 vector multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicMult + * @{ + */ + + +/** + * @brief Q15 vector multiplication + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +void arm_mult_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counters */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2, inB1, inB2; /* temporary input variables */ + q15_t out1, out2, out3, out4; /* temporary output variables */ + q31_t mul1, mul2, mul3, mul4; /* temporary variables */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* read two samples at a time from sourceA */ + inA1 = *__SIMD32(pSrcA)++; + /* read two samples at a time from sourceB */ + inB1 = *__SIMD32(pSrcB)++; + /* read two samples at a time from sourceA */ + inA2 = *__SIMD32(pSrcA)++; + /* read two samples at a time from sourceB */ + inB2 = *__SIMD32(pSrcB)++; + + /* multiply mul = sourceA * sourceB */ + mul1 = (q31_t) ((q15_t) (inA1 >> 16) * (q15_t) (inB1 >> 16)); + mul2 = (q31_t) ((q15_t) inA1 * (q15_t) inB1); + mul3 = (q31_t) ((q15_t) (inA2 >> 16) * (q15_t) (inB2 >> 16)); + mul4 = (q31_t) ((q15_t) inA2 * (q15_t) inB2); + + /* saturate result to 16 bit */ + out1 = (q15_t) __SSAT(mul1 >> 15, 16); + out2 = (q15_t) __SSAT(mul2 >> 15, 16); + out3 = (q15_t) __SSAT(mul3 >> 15, 16); + out4 = (q15_t) __SSAT(mul4 >> 15, 16); + + /* store the result */ +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = __PKHBT(out2, out1, 16); + *__SIMD32(pDst)++ = __PKHBT(out4, out3, 16); + +#else + + *__SIMD32(pDst)++ = __PKHBT(out2, out1, 16); + *__SIMD32(pDst)++ = __PKHBT(out4, out3, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the result in the destination buffer */ + *pDst++ = (q15_t) __SSAT((((q31_t) (*pSrcA++) * (*pSrcB++)) >> 15), 16); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q31.c new file mode 100644 index 0000000..93f0c73 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q31.c @@ -0,0 +1,148 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mult_q31.c + * Description: Q31 vector multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicMult + * @{ + */ + +/** + * @brief Q31 vector multiplication. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range[0x80000000 0x7FFFFFFF] will be saturated. + */ + +void arm_mult_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counters */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2, inA3, inA4; /* temporary input variables */ + q31_t inB1, inB2, inB3, inB4; /* temporary input variables */ + q31_t out1, out2, out3, out4; /* temporary output variables */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and then store the results in the destination buffer. */ + inA1 = *pSrcA++; + inA2 = *pSrcA++; + inA3 = *pSrcA++; + inA4 = *pSrcA++; + inB1 = *pSrcB++; + inB2 = *pSrcB++; + inB3 = *pSrcB++; + inB4 = *pSrcB++; + + out1 = ((q63_t) inA1 * inB1) >> 32; + out2 = ((q63_t) inA2 * inB2) >> 32; + out3 = ((q63_t) inA3 * inB3) >> 32; + out4 = ((q63_t) inA4 * inB4) >> 32; + + out1 = __SSAT(out1, 31); + out2 = __SSAT(out2, 31); + out3 = __SSAT(out3, 31); + out4 = __SSAT(out4, 31); + + *pDst++ = out1 << 1U; + *pDst++ = out2 << 1U; + *pDst++ = out3 << 1U; + *pDst++ = out4 << 1U; + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and then store the results in the destination buffer. */ + inA1 = *pSrcA++; + inB1 = *pSrcB++; + out1 = ((q63_t) inA1 * inB1) >> 32; + out1 = __SSAT(out1, 31); + *pDst++ = out1 << 1U; + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and then store the results in the destination buffer. */ + *pDst++ = + (q31_t) clip_q63_to_q31(((q63_t) (*pSrcA++) * (*pSrcB++)) >> 31); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ +} + +/** + * @} end of BasicMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q7.c new file mode 100644 index 0000000..e5a8f24 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_mult_q7.c @@ -0,0 +1,115 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mult_q7.c + * Description: Q7 vector multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicMult + * @{ + */ + +/** + * @brief Q7 vector multiplication + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x80 0x7F] will be saturated. + */ + +void arm_mult_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counters */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q7_t out1, out2, out3, out4; /* Temporary variables to store the product */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the results in temporary variables */ + out1 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++)) >> 7), 8); + out2 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++)) >> 7), 8); + out3 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++)) >> 7), 8); + out4 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++)) >> 7), 8); + + /* Store the results of 4 inputs in the destination buffer in single cycle by packing */ + *__SIMD32(pDst)++ = __PACKq7(out1, out2, out3, out4); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the result in the destination buffer */ + *pDst++ = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++)) >> 7), 8); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_f32.c new file mode 100644 index 0000000..d463885 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_f32.c @@ -0,0 +1,134 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_negate_f32.c + * Description: Negates floating-point vectors + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @defgroup negate Vector Negate + * + * Negates the elements of a vector. + * + *
+ *     pDst[n] = -pSrc[n],   0 <= n < blockSize.
+ * 
+ * + * The functions support in-place computation allowing the source and + * destination pointers to reference the same memory buffer. + * There are separate functions for floating-point, Q7, Q15, and Q31 data types. + */ + +/** + * @addtogroup negate + * @{ + */ + +/** + * @brief Negates the elements of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + */ + +void arm_negate_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t in1, in2, in3, in4; /* temporary variables */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* read inputs from source */ + in1 = *pSrc; + in2 = *(pSrc + 1); + in3 = *(pSrc + 2); + in4 = *(pSrc + 3); + + /* negate the input */ + in1 = -in1; + in2 = -in2; + in3 = -in3; + in4 = -in4; + + /* store the result to destination */ + *pDst = in1; + *(pDst + 1) = in2; + *(pDst + 2) = in3; + *(pDst + 3) = in4; + + /* update pointers to process next samples */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = -A */ + /* Negate and then store the results in the destination buffer. */ + *pDst++ = -*pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of negate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q15.c new file mode 100644 index 0000000..0820f30 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q15.c @@ -0,0 +1,131 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_negate_q15.c + * Description: Negates Q15 vectors + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup negate + * @{ + */ + +/** + * @brief Negates the elements of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * \par Conditions for optimum performance + * Input and output buffers should be aligned by 32-bit + * + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * The Q15 value -1 (0x8000) will be saturated to the maximum allowable positive value 0x7FFF. + */ + +void arm_negate_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + q15_t in; + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in1, in2; /* Temporary variables */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = -A */ + /* Read two inputs at a time */ + in1 = _SIMD32_OFFSET(pSrc); + in2 = _SIMD32_OFFSET(pSrc + 2); + + /* negate two samples at a time */ + in1 = __QSUB16(0, in1); + + /* negate two samples at a time */ + in2 = __QSUB16(0, in2); + + /* store the result to destination 2 samples at a time */ + _SIMD32_OFFSET(pDst) = in1; + /* store the result to destination 2 samples at a time */ + _SIMD32_OFFSET(pDst + 2) = in2; + + + /* update pointers to process next samples */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = -A */ + /* Negate and then store the result in the destination buffer. */ + in = *pSrc++; + *pDst++ = (in == (q15_t) 0x8000) ? 0x7fff : -in; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of negate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q31.c new file mode 100644 index 0000000..ab5985a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q31.c @@ -0,0 +1,117 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_negate_q31.c + * Description: Negates Q31 vectors + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup negate + * @{ + */ + +/** + * @brief Negates the elements of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * The Q31 value -1 (0x80000000) will be saturated to the maximum allowable positive value 0x7FFFFFFF. + */ + +void arm_negate_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t in; /* Temporary variable */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2, in3, in4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = -A */ + /* Negate and then store the results in the destination buffer. */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + *pDst++ = __QSUB(0, in1); + *pDst++ = __QSUB(0, in2); + *pDst++ = __QSUB(0, in3); + *pDst++ = __QSUB(0, in4); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = -A */ + /* Negate and then store the result in the destination buffer. */ + in = *pSrc++; + *pDst++ = (in == INT32_MIN) ? INT32_MAX : -in; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of negate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q7.c new file mode 100644 index 0000000..b225c5e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_negate_q7.c @@ -0,0 +1,113 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_negate_q7.c + * Description: Negates Q7 vectors + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup negate + * @{ + */ + +/** + * @brief Negates the elements of a Q7 vector. + * @param[in] *pSrc points to the input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * The Q7 value -1 (0x80) will be saturated to the maximum allowable positive value 0x7F. + */ + +void arm_negate_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + q7_t in; + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t input; /* Input values1-4 */ + q31_t zero = 0x00000000; + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = -A */ + /* Read four inputs */ + input = *__SIMD32(pSrc)++; + + /* Store the Negated results in the destination buffer in a single cycle by packing the results */ + *__SIMD32(pDst)++ = __QSUB8(zero, input); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = -A */ + /* Negate and then store the results in the destination buffer. */ \ + in = *pSrc++; + *pDst++ = (in == (q7_t) 0x80) ? 0x7f : -in; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of negate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_f32.c new file mode 100644 index 0000000..c35fe8e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_f32.c @@ -0,0 +1,154 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_offset_f32.c + * Description: Floating-point vector offset + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @defgroup offset Vector Offset + * + * Adds a constant offset to each element of a vector. + * + *
+ *     pDst[n] = pSrc[n] + offset,   0 <= n < blockSize.
+ * 
+ * + * The functions support in-place computation allowing the source and + * destination pointers to reference the same memory buffer. + * There are separate functions for floating-point, Q7, Q15, and Q31 data types. + */ + +/** + * @addtogroup offset + * @{ + */ + +/** + * @brief Adds a constant offset to a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + */ + + +void arm_offset_f32( + float32_t * pSrc, + float32_t offset, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t in1, in2, in3, in4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the results in the destination buffer. */ + /* read samples from source */ + in1 = *pSrc; + in2 = *(pSrc + 1); + + /* add offset to input */ + in1 = in1 + offset; + + /* read samples from source */ + in3 = *(pSrc + 2); + + /* add offset to input */ + in2 = in2 + offset; + + /* read samples from source */ + in4 = *(pSrc + 3); + + /* add offset to input */ + in3 = in3 + offset; + + /* store result to destination */ + *pDst = in1; + + /* add offset to input */ + in4 = in4 + offset; + + /* store result to destination */ + *(pDst + 1) = in2; + + /* store result to destination */ + *(pDst + 2) = in3; + + /* store result to destination */ + *(pDst + 3) = in4; + + /* update pointers to process next samples */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the result in the destination buffer. */ + *pDst++ = (*pSrc++) + offset; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of offset group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q15.c new file mode 100644 index 0000000..4c16224 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q15.c @@ -0,0 +1,124 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_offset_q15.c + * Description: Q15 vector offset + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup offset + * @{ + */ + +/** + * @brief Adds a constant offset to a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] are saturated. + */ + +void arm_offset_q15( + q15_t * pSrc, + q15_t offset, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t offset_packed; /* Offset packed to 32 bit */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* Offset is packed to 32 bit in order to use SIMD32 for addition */ + offset_packed = __PKHBT(offset, offset, 16); + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the results in the destination buffer, 2 samples at a time. */ + *__SIMD32(pDst)++ = __QADD16(*__SIMD32(pSrc)++, offset_packed); + *__SIMD32(pDst)++ = __QADD16(*__SIMD32(pSrc)++, offset_packed); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the results in the destination buffer. */ + *pDst++ = (q15_t) __QADD16(*pSrc++, offset); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the results in the destination buffer. */ + *pDst++ = (q15_t) __SSAT(((q31_t) * pSrc++ + offset), 16); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of offset group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q31.c new file mode 100644 index 0000000..0b0ee32 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q31.c @@ -0,0 +1,128 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_offset_q31.c + * Description: Q31 vector offset + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup offset + * @{ + */ + +/** + * @brief Adds a constant offset to a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range [0x80000000 0x7FFFFFFF] are saturated. + */ + +void arm_offset_q31( + q31_t * pSrc, + q31_t offset, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2, in3, in4; + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the results in the destination buffer. */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + *pDst++ = __QADD(in1, offset); + *pDst++ = __QADD(in2, offset); + *pDst++ = __QADD(in3, offset); + *pDst++ = __QADD(in4, offset); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the result in the destination buffer. */ + *pDst++ = __QADD(*pSrc++, offset); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the result in the destination buffer. */ + *pDst++ = (q31_t) clip_q63_to_q31((q63_t) * pSrc++ + offset); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of offset group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q7.c new file mode 100644 index 0000000..5b98951 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_offset_q7.c @@ -0,0 +1,123 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_offset_q7.c + * Description: Q7 vector offset + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup offset + * @{ + */ + +/** + * @brief Adds a constant offset to a Q7 vector. + * @param[in] *pSrc points to the input vector + * @param[in] offset is the offset to be added + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x80 0x7F] are saturated. + */ + +void arm_offset_q7( + q7_t * pSrc, + q7_t offset, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t offset_packed; /* Offset packed to 32 bit */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* Offset is packed to 32 bit in order to use SIMD32 for addition */ + offset_packed = __PACKq7(offset, offset, offset, offset); + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the results in the destination bufferfor 4 samples at a time. */ + *__SIMD32(pDst)++ = __QADD8(*__SIMD32(pSrc)++, offset_packed); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the result in the destination buffer. */ + *pDst++ = (q7_t) __SSAT(*pSrc++ + offset, 8); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A + offset */ + /* Add offset and then store the result in the destination buffer. */ + *pDst++ = (q7_t) __SSAT((q15_t) * pSrc++ + offset, 8); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of offset group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_f32.c new file mode 100644 index 0000000..0fc3204 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_f32.c @@ -0,0 +1,157 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_scale_f32.c + * Description: Multiplies a floating-point vector by a scalar + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @defgroup scale Vector Scale + * + * Multiply a vector by a scalar value. For floating-point data, the algorithm used is: + * + *
+ *     pDst[n] = pSrc[n] * scale,   0 <= n < blockSize.
+ * 
+ * + * In the fixed-point Q7, Q15, and Q31 functions, scale is represented by + * a fractional multiplication scaleFract and an arithmetic shift shift. + * The shift allows the gain of the scaling operation to exceed 1.0. + * The algorithm used with fixed-point data is: + * + *
+ *     pDst[n] = (pSrc[n] * scaleFract) << shift,   0 <= n < blockSize.
+ * 
+ * + * The overall scale factor applied to the fixed-point data is + *
+ *     scale = scaleFract * 2^shift.
+ * 
+ * + * The functions support in-place computation allowing the source and destination + * pointers to reference the same memory buffer. + */ + +/** + * @addtogroup scale + * @{ + */ + +/** + * @brief Multiplies a floating-point vector by a scalar. + * @param[in] *pSrc points to the input vector + * @param[in] scale scale factor to be applied + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + */ + + +void arm_scale_f32( + float32_t * pSrc, + float32_t scale, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t in1, in2, in3, in4; /* temporary variabels */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the results in the destination buffer. */ + /* read input samples from source */ + in1 = *pSrc; + in2 = *(pSrc + 1); + + /* multiply with scaling factor */ + in1 = in1 * scale; + + /* read input sample from source */ + in3 = *(pSrc + 2); + + /* multiply with scaling factor */ + in2 = in2 * scale; + + /* read input sample from source */ + in4 = *(pSrc + 3); + + /* multiply with scaling factor */ + in3 = in3 * scale; + in4 = in4 * scale; + /* store the result to destination */ + *pDst = in1; + *(pDst + 1) = in2; + *(pDst + 2) = in3; + *(pDst + 3) = in4; + + /* update pointers to process next samples */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the result in the destination buffer. */ + *pDst++ = (*pSrc++) * scale; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of scale group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q15.c new file mode 100644 index 0000000..f1d3063 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q15.c @@ -0,0 +1,150 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_scale_q15.c + * Description: Multiplies a Q15 vector by a scalar + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup scale + * @{ + */ + +/** + * @brief Multiplies a Q15 vector by a scalar. + * @param[in] *pSrc points to the input vector + * @param[in] scaleFract fractional portion of the scale value + * @param[in] shift number of bits to shift the result by + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The input data *pSrc and scaleFract are in 1.15 format. + * These are multiplied to yield a 2.30 intermediate result and this is shifted with saturation to 1.15 format. + */ + + +void arm_scale_q15( + q15_t * pSrc, + q15_t scaleFract, + int8_t shift, + q15_t * pDst, + uint32_t blockSize) +{ + int8_t kShift = 15 - shift; /* shift to apply after scaling */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q15_t in1, in2, in3, in4; + q31_t inA1, inA2; /* Temporary variables */ + q31_t out1, out2, out3, out4; + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Reading 2 inputs from memory */ + inA1 = *__SIMD32(pSrc)++; + inA2 = *__SIMD32(pSrc)++; + + /* C = A * scale */ + /* Scale the inputs and then store the 2 results in the destination buffer + * in single cycle by packing the outputs */ + out1 = (q31_t) ((q15_t) (inA1 >> 16) * scaleFract); + out2 = (q31_t) ((q15_t) inA1 * scaleFract); + out3 = (q31_t) ((q15_t) (inA2 >> 16) * scaleFract); + out4 = (q31_t) ((q15_t) inA2 * scaleFract); + + /* apply shifting */ + out1 = out1 >> kShift; + out2 = out2 >> kShift; + out3 = out3 >> kShift; + out4 = out4 >> kShift; + + /* saturate the output */ + in1 = (q15_t) (__SSAT(out1, 16)); + in2 = (q15_t) (__SSAT(out2, 16)); + in3 = (q15_t) (__SSAT(out3, 16)); + in4 = (q15_t) (__SSAT(out4, 16)); + + /* store the result to destination */ + *__SIMD32(pDst)++ = __PKHBT(in2, in1, 16); + *__SIMD32(pDst)++ = __PKHBT(in4, in3, 16); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the result in the destination buffer. */ + *pDst++ = (q15_t) (__SSAT(((*pSrc++) * scaleFract) >> kShift, 16)); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the result in the destination buffer. */ + *pDst++ = (q15_t) (__SSAT(((q31_t) * pSrc++ * scaleFract) >> kShift, 16)); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of scale group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q31.c new file mode 100644 index 0000000..dcc7bbe --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q31.c @@ -0,0 +1,227 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_scale_q31.c + * Description: Multiplies a Q31 vector by a scalar + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup scale + * @{ + */ + +/** + * @brief Multiplies a Q31 vector by a scalar. + * @param[in] *pSrc points to the input vector + * @param[in] scaleFract fractional portion of the scale value + * @param[in] shift number of bits to shift the result by + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The input data *pSrc and scaleFract are in 1.31 format. + * These are multiplied to yield a 2.62 intermediate result and this is shifted with saturation to 1.31 format. + */ + +void arm_scale_q31( + q31_t * pSrc, + q31_t scaleFract, + int8_t shift, + q31_t * pDst, + uint32_t blockSize) +{ + int8_t kShift = shift + 1; /* Shift to apply after scaling */ + int8_t sign = (kShift & 0x80); + uint32_t blkCnt; /* loop counter */ + q31_t in, out; + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in1, in2, in3, in4; /* temporary input variables */ + q31_t out1, out2, out3, out4; /* temporary output variabels */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + if (sign == 0U) + { + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* read four inputs from source */ + in1 = *pSrc; + in2 = *(pSrc + 1); + in3 = *(pSrc + 2); + in4 = *(pSrc + 3); + + /* multiply input with scaler value */ + in1 = ((q63_t) in1 * scaleFract) >> 32; + in2 = ((q63_t) in2 * scaleFract) >> 32; + in3 = ((q63_t) in3 * scaleFract) >> 32; + in4 = ((q63_t) in4 * scaleFract) >> 32; + + /* apply shifting */ + out1 = in1 << kShift; + out2 = in2 << kShift; + + /* saturate the results. */ + if (in1 != (out1 >> kShift)) + out1 = 0x7FFFFFFF ^ (in1 >> 31); + + if (in2 != (out2 >> kShift)) + out2 = 0x7FFFFFFF ^ (in2 >> 31); + + out3 = in3 << kShift; + out4 = in4 << kShift; + + *pDst = out1; + *(pDst + 1) = out2; + + if (in3 != (out3 >> kShift)) + out3 = 0x7FFFFFFF ^ (in3 >> 31); + + if (in4 != (out4 >> kShift)) + out4 = 0x7FFFFFFF ^ (in4 >> 31); + + /* Store result destination */ + *(pDst + 2) = out3; + *(pDst + 3) = out4; + + /* Update pointers to process next sampels */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + } + else + { + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* read four inputs from source */ + in1 = *pSrc; + in2 = *(pSrc + 1); + in3 = *(pSrc + 2); + in4 = *(pSrc + 3); + + /* multiply input with scaler value */ + in1 = ((q63_t) in1 * scaleFract) >> 32; + in2 = ((q63_t) in2 * scaleFract) >> 32; + in3 = ((q63_t) in3 * scaleFract) >> 32; + in4 = ((q63_t) in4 * scaleFract) >> 32; + + /* apply shifting */ + out1 = in1 >> -kShift; + out2 = in2 >> -kShift; + + out3 = in3 >> -kShift; + out4 = in4 >> -kShift; + + /* Store result destination */ + *pDst = out1; + *(pDst + 1) = out2; + + *(pDst + 2) = out3; + *(pDst + 3) = out4; + + /* Update pointers to process next sampels */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + } + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + if (sign == 0) + { + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the result in the destination buffer. */ + in = *pSrc++; + in = ((q63_t) in * scaleFract) >> 32; + + out = in << kShift; + + if (in != (out >> kShift)) + out = 0x7FFFFFFF ^ (in >> 31); + + *pDst++ = out; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the result in the destination buffer. */ + in = *pSrc++; + in = ((q63_t) in * scaleFract) >> 32; + + out = in >> -kShift; + + *pDst++ = out; + + /* Decrement the loop counter */ + blkCnt--; + } + + } +} + +/** + * @} end of scale group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q7.c new file mode 100644 index 0000000..8c90396 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_scale_q7.c @@ -0,0 +1,137 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_scale_q7.c + * Description: Multiplies a Q7 vector by a scalar + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup scale + * @{ + */ + +/** + * @brief Multiplies a Q7 vector by a scalar. + * @param[in] *pSrc points to the input vector + * @param[in] scaleFract fractional portion of the scale value + * @param[in] shift number of bits to shift the result by + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The input data *pSrc and scaleFract are in 1.7 format. + * These are multiplied to yield a 2.14 intermediate result and this is shifted with saturation to 1.7 format. + */ + +void arm_scale_q7( + q7_t * pSrc, + q7_t scaleFract, + int8_t shift, + q7_t * pDst, + uint32_t blockSize) +{ + int8_t kShift = 7 - shift; /* shift to apply after scaling */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q7_t in1, in2, in3, in4, out1, out2, out3, out4; /* Temporary variables to store input & output */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Reading 4 inputs from memory */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + /* C = A * scale */ + /* Scale the inputs and then store the results in the temporary variables. */ + out1 = (q7_t) (__SSAT(((in1) * scaleFract) >> kShift, 8)); + out2 = (q7_t) (__SSAT(((in2) * scaleFract) >> kShift, 8)); + out3 = (q7_t) (__SSAT(((in3) * scaleFract) >> kShift, 8)); + out4 = (q7_t) (__SSAT(((in4) * scaleFract) >> kShift, 8)); + + /* Packing the individual outputs into 32bit and storing in + * destination buffer in single write */ + *__SIMD32(pDst)++ = __PACKq7(out1, out2, out3, out4); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the result in the destination buffer. */ + *pDst++ = (q7_t) (__SSAT(((*pSrc++) * scaleFract) >> kShift, 8)); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A * scale */ + /* Scale the input and then store the result in the destination buffer. */ + *pDst++ = (q7_t) (__SSAT((((q15_t) * pSrc++ * scaleFract) >> kShift), 8)); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of scale group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q15.c new file mode 100644 index 0000000..9462ad7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q15.c @@ -0,0 +1,236 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_shift_q15.c + * Description: Shifts the elements of a Q15 vector by a specified number of bits + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup shift + * @{ + */ + +/** + * @brief Shifts the elements of a Q15 vector a specified number of bits. + * @param[in] *pSrc points to the input vector + * @param[in] shiftBits number of bits to shift. A positive value shifts left; a negative value shifts right. + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +void arm_shift_q15( + q15_t * pSrc, + int8_t shiftBits, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + uint8_t sign; /* Sign of shiftBits */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t in1, in2; /* Temporary variables */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* Getting the sign of shiftBits */ + sign = (shiftBits & 0x80); + + /* If the shift value is positive then do right shift else left shift */ + if (sign == 0U) + { + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Read 2 inputs */ + in1 = *pSrc++; + in2 = *pSrc++; + /* C = A << shiftBits */ + /* Shift the inputs and then store the results in the destination buffer. */ +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = __PKHBT(__SSAT((in1 << shiftBits), 16), + __SSAT((in2 << shiftBits), 16), 16); + +#else + + *__SIMD32(pDst)++ = __PKHBT(__SSAT((in2 << shiftBits), 16), + __SSAT((in1 << shiftBits), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + in1 = *pSrc++; + in2 = *pSrc++; + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = __PKHBT(__SSAT((in1 << shiftBits), 16), + __SSAT((in2 << shiftBits), 16), 16); + +#else + + *__SIMD32(pDst)++ = __PKHBT(__SSAT((in2 << shiftBits), 16), + __SSAT((in1 << shiftBits), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A << shiftBits */ + /* Shift and then store the results in the destination buffer. */ + *pDst++ = __SSAT((*pSrc++ << shiftBits), 16); + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Read 2 inputs */ + in1 = *pSrc++; + in2 = *pSrc++; + + /* C = A >> shiftBits */ + /* Shift the inputs and then store the results in the destination buffer. */ +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = __PKHBT((in1 >> -shiftBits), + (in2 >> -shiftBits), 16); + +#else + + *__SIMD32(pDst)++ = __PKHBT((in2 >> -shiftBits), + (in1 >> -shiftBits), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + in1 = *pSrc++; + in2 = *pSrc++; + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = __PKHBT((in1 >> -shiftBits), + (in2 >> -shiftBits), 16); + +#else + + *__SIMD32(pDst)++ = __PKHBT((in2 >> -shiftBits), + (in1 >> -shiftBits), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A >> shiftBits */ + /* Shift the inputs and then store the results in the destination buffer. */ + *pDst++ = (*pSrc++ >> -shiftBits); + + /* Decrement the loop counter */ + blkCnt--; + } + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Getting the sign of shiftBits */ + sign = (shiftBits & 0x80); + + /* If the shift value is positive then do right shift else left shift */ + if (sign == 0U) + { + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A << shiftBits */ + /* Shift and then store the results in the destination buffer. */ + *pDst++ = __SSAT(((q31_t) * pSrc++ << shiftBits), 16); + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A >> shiftBits */ + /* Shift the inputs and then store the results in the destination buffer. */ + *pDst++ = (*pSrc++ >> -shiftBits); + + /* Decrement the loop counter */ + blkCnt--; + } + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of shift group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q31.c new file mode 100644 index 0000000..12490a1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q31.c @@ -0,0 +1,191 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_shift_q31.c + * Description: Shifts the elements of a Q31 vector by a specified number of bits + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ +/** + * @defgroup shift Vector Shift + * + * Shifts the elements of a fixed-point vector by a specified number of bits. + * There are separate functions for Q7, Q15, and Q31 data types. + * The underlying algorithm used is: + * + *
+ *     pDst[n] = pSrc[n] << shift,   0 <= n < blockSize.
+ * 
+ * + * If shift is positive then the elements of the vector are shifted to the left. + * If shift is negative then the elements of the vector are shifted to the right. + * + * The functions support in-place computation allowing the source and destination + * pointers to reference the same memory buffer. + */ + +/** + * @addtogroup shift + * @{ + */ + +/** + * @brief Shifts the elements of a Q31 vector a specified number of bits. + * @param[in] *pSrc points to the input vector + * @param[in] shiftBits number of bits to shift. A positive value shifts left; a negative value shifts right. + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range [0x80000000 0x7FFFFFFF] will be saturated. + */ + +void arm_shift_q31( + q31_t * pSrc, + int8_t shiftBits, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + uint8_t sign = (shiftBits & 0x80); /* Sign of shiftBits */ + +#if defined (ARM_MATH_DSP) + + q31_t in1, in2, in3, in4; /* Temporary input variables */ + q31_t out1, out2, out3, out4; /* Temporary output variables */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + + if (sign == 0U) + { + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A << shiftBits */ + /* Shift the input and then store the results in the destination buffer. */ + in1 = *pSrc; + in2 = *(pSrc + 1); + out1 = in1 << shiftBits; + in3 = *(pSrc + 2); + out2 = in2 << shiftBits; + in4 = *(pSrc + 3); + if (in1 != (out1 >> shiftBits)) + out1 = 0x7FFFFFFF ^ (in1 >> 31); + + if (in2 != (out2 >> shiftBits)) + out2 = 0x7FFFFFFF ^ (in2 >> 31); + + *pDst = out1; + out3 = in3 << shiftBits; + *(pDst + 1) = out2; + out4 = in4 << shiftBits; + + if (in3 != (out3 >> shiftBits)) + out3 = 0x7FFFFFFF ^ (in3 >> 31); + + if (in4 != (out4 >> shiftBits)) + out4 = 0x7FFFFFFF ^ (in4 >> 31); + + *(pDst + 2) = out3; + *(pDst + 3) = out4; + + /* Update destination pointer to process next sampels */ + pSrc += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A >> shiftBits */ + /* Shift the input and then store the results in the destination buffer. */ + in1 = *pSrc; + in2 = *(pSrc + 1); + in3 = *(pSrc + 2); + in4 = *(pSrc + 3); + + *pDst = (in1 >> -shiftBits); + *(pDst + 1) = (in2 >> -shiftBits); + *(pDst + 2) = (in3 >> -shiftBits); + *(pDst + 3) = (in4 >> -shiftBits); + + + pSrc += 4U; + pDst += 4U; + + blkCnt--; + } + + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A (>> or <<) shiftBits */ + /* Shift the input and then store the result in the destination buffer. */ + *pDst++ = (sign == 0U) ? clip_q63_to_q31((q63_t) * pSrc++ << shiftBits) : + (*pSrc++ >> -shiftBits); + + /* Decrement the loop counter */ + blkCnt--; + } + + +} + +/** + * @} end of shift group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q7.c new file mode 100644 index 0000000..6f40431 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_shift_q7.c @@ -0,0 +1,208 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_shift_q7.c + * Description: Processing function for the Q7 Shifting + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup shift + * @{ + */ + + +/** + * @brief Shifts the elements of a Q7 vector a specified number of bits. + * @param[in] *pSrc points to the input vector + * @param[in] shiftBits number of bits to shift. A positive value shifts left; a negative value shifts right. + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in the vector + * @return none. + * + * \par Conditions for optimum performance + * Input and output buffers should be aligned by 32-bit + * + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x8 0x7F] will be saturated. + */ + +void arm_shift_q7( + q7_t * pSrc, + int8_t shiftBits, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + uint8_t sign; /* Sign of shiftBits */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q7_t in1; /* Input value1 */ + q7_t in2; /* Input value2 */ + q7_t in3; /* Input value3 */ + q7_t in4; /* Input value4 */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* Getting the sign of shiftBits */ + sign = (shiftBits & 0x80); + + /* If the shift value is positive then do right shift else left shift */ + if (sign == 0U) + { + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A << shiftBits */ + /* Read 4 inputs */ + in1 = *pSrc; + in2 = *(pSrc + 1); + in3 = *(pSrc + 2); + in4 = *(pSrc + 3); + + /* Store the Shifted result in the destination buffer in single cycle by packing the outputs */ + *__SIMD32(pDst)++ = __PACKq7(__SSAT((in1 << shiftBits), 8), + __SSAT((in2 << shiftBits), 8), + __SSAT((in3 << shiftBits), 8), + __SSAT((in4 << shiftBits), 8)); + /* Update source pointer to process next sampels */ + pSrc += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A << shiftBits */ + /* Shift the input and then store the result in the destination buffer. */ + *pDst++ = (q7_t) __SSAT((*pSrc++ << shiftBits), 8); + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + shiftBits = -shiftBits; + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A >> shiftBits */ + /* Read 4 inputs */ + in1 = *pSrc; + in2 = *(pSrc + 1); + in3 = *(pSrc + 2); + in4 = *(pSrc + 3); + + /* Store the Shifted result in the destination buffer in single cycle by packing the outputs */ + *__SIMD32(pDst)++ = __PACKq7((in1 >> shiftBits), (in2 >> shiftBits), + (in3 >> shiftBits), (in4 >> shiftBits)); + + + pSrc += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A >> shiftBits */ + /* Shift the input and then store the result in the destination buffer. */ + in1 = *pSrc++; + *pDst++ = (in1 >> shiftBits); + + /* Decrement the loop counter */ + blkCnt--; + } + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Getting the sign of shiftBits */ + sign = (shiftBits & 0x80); + + /* If the shift value is positive then do right shift else left shift */ + if (sign == 0U) + { + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A << shiftBits */ + /* Shift the input and then store the result in the destination buffer. */ + *pDst++ = (q7_t) __SSAT(((q15_t) * pSrc++ << shiftBits), 8); + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A >> shiftBits */ + /* Shift the input and then store the result in the destination buffer. */ + *pDst++ = (*pSrc++ >> -shiftBits); + + /* Decrement the loop counter */ + blkCnt--; + } + } + +#endif /* #if defined (ARM_MATH_DSP) */ +} + +/** + * @} end of shift group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_f32.c new file mode 100644 index 0000000..6d56fa7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_f32.c @@ -0,0 +1,138 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sub_f32.c + * Description: Floating-point vector subtraction. + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @defgroup BasicSub Vector Subtraction + * + * Element-by-element subtraction of two vectors. + * + *
+ *     pDst[n] = pSrcA[n] - pSrcB[n],   0 <= n < blockSize.
+ * 
+ * + * There are separate functions for floating-point, Q7, Q15, and Q31 data types. + */ + +/** + * @addtogroup BasicSub + * @{ + */ + + +/** + * @brief Floating-point vector subtraction. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + */ + +void arm_sub_f32( + float32_t * pSrcA, + float32_t * pSrcB, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t inA1, inA2, inA3, inA4; /* temporary variables */ + float32_t inB1, inB2, inB3, inB4; /* temporary variables */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the results in the destination buffer. */ + /* Read 4 input samples from sourceA and sourceB */ + inA1 = *pSrcA; + inB1 = *pSrcB; + inA2 = *(pSrcA + 1); + inB2 = *(pSrcB + 1); + inA3 = *(pSrcA + 2); + inB3 = *(pSrcB + 2); + inA4 = *(pSrcA + 3); + inB4 = *(pSrcB + 3); + + /* dst = srcA - srcB */ + /* subtract and store the result */ + *pDst = inA1 - inB1; + *(pDst + 1) = inA2 - inB2; + *(pDst + 2) = inA3 - inB3; + *(pDst + 3) = inA4 - inB4; + + + /* Update pointers to process next sampels */ + pSrcA += 4U; + pSrcB += 4U; + pDst += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the results in the destination buffer. */ + *pDst++ = (*pSrcA++) - (*pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicSub group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q15.c new file mode 100644 index 0000000..643f933 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q15.c @@ -0,0 +1,128 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sub_q15.c + * Description: Q15 vector subtraction + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicSub + * @{ + */ + +/** + * @brief Q15 vector subtraction. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +void arm_sub_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2; + q31_t inB1, inB2; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the results in the destination buffer two samples at a time. */ + inA1 = *__SIMD32(pSrcA)++; + inA2 = *__SIMD32(pSrcA)++; + inB1 = *__SIMD32(pSrcB)++; + inB2 = *__SIMD32(pSrcB)++; + + *__SIMD32(pDst)++ = __QSUB16(inA1, inB1); + *__SIMD32(pDst)++ = __QSUB16(inA2, inB2); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the result in the destination buffer. */ + *pDst++ = (q15_t) __QSUB16(*pSrcA++, *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the result in the destination buffer. */ + *pDst++ = (q15_t) __SSAT(((q31_t) * pSrcA++ - *pSrcB++), 16); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + +} + +/** + * @} end of BasicSub group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q31.c new file mode 100644 index 0000000..1c83aae --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q31.c @@ -0,0 +1,134 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sub_q31.c + * Description: Q31 vector subtraction + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicSub + * @{ + */ + +/** + * @brief Q31 vector subtraction. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range [0x80000000 0x7FFFFFFF] will be saturated. + */ + +void arm_sub_q31( + q31_t * pSrcA, + q31_t * pSrcB, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2, inA3, inA4; + q31_t inB1, inB2, inB3, inB4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the results in the destination buffer. */ + inA1 = *pSrcA++; + inA2 = *pSrcA++; + inB1 = *pSrcB++; + inB2 = *pSrcB++; + + inA3 = *pSrcA++; + inA4 = *pSrcA++; + inB3 = *pSrcB++; + inB4 = *pSrcB++; + + *pDst++ = __QSUB(inA1, inB1); + *pDst++ = __QSUB(inA2, inB2); + *pDst++ = __QSUB(inA3, inB3); + *pDst++ = __QSUB(inA4, inB4); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the result in the destination buffer. */ + *pDst++ = __QSUB(*pSrcA++, *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the result in the destination buffer. */ + *pDst++ = (q31_t) clip_q63_to_q31((q63_t) * pSrcA++ - *pSrcB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of BasicSub group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q7.c new file mode 100644 index 0000000..8f8e111 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/BasicMathFunctions/arm_sub_q7.c @@ -0,0 +1,119 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sub_q7.c + * Description: Q7 vector subtraction + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMath + */ + +/** + * @addtogroup BasicSub + * @{ + */ + +/** + * @brief Q7 vector subtraction. + * @param[in] *pSrcA points to the first input vector + * @param[in] *pSrcB points to the second input vector + * @param[out] *pDst points to the output vector + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x80 0x7F] will be saturated. + */ + +void arm_sub_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the results in the destination buffer 4 samples at a time. */ + *__SIMD32(pDst)++ = __QSUB8(*__SIMD32(pSrcA)++, *__SIMD32(pSrcB)++); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the result in the destination buffer. */ + *pDst++ = __SSAT(*pSrcA++ - *pSrcB++, 8); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A - B */ + /* Subtract and then store the result in the destination buffer. */ + *pDst++ = (q7_t) __SSAT((q15_t) * pSrcA++ - *pSrcB++, 8); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + +} + +/** + * @} end of BasicSub group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_common_tables.c b/Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_common_tables.c new file mode 100644 index 0000000..bb5c15a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_common_tables.c @@ -0,0 +1,22176 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_common_tables.c + * Description: common tables like fft twiddle factors, Bitreverse, reciprocal etc + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup ComplexFFT + */ + +/** + * @addtogroup CFFT_CIFFT Complex FFT Tables + * @{ + */ + +/** +* \par +* Pseudo code for Generation of Bit reversal Table is +* \par +*
for(l=1;l <= N/4;l++)
+* {
+*   for(i=0;i> 1;
+*  } 
+* \par +* where N = 4096 logN2 = 12 +* \par +* N is the maximum FFT Size supported +*/ + +/* +* @brief Table for bit reversal process +*/ +const uint16_t armBitRevTable[1024] = { + 0x400, 0x200, 0x600, 0x100, 0x500, 0x300, 0x700, 0x80, 0x480, 0x280, + 0x680, 0x180, 0x580, 0x380, 0x780, 0x40, 0x440, 0x240, 0x640, 0x140, + 0x540, 0x340, 0x740, 0xc0, 0x4c0, 0x2c0, 0x6c0, 0x1c0, 0x5c0, 0x3c0, + 0x7c0, 0x20, 0x420, 0x220, 0x620, 0x120, 0x520, 0x320, 0x720, 0xa0, + 0x4a0, 0x2a0, 0x6a0, 0x1a0, 0x5a0, 0x3a0, 0x7a0, 0x60, 0x460, 0x260, + 0x660, 0x160, 0x560, 0x360, 0x760, 0xe0, 0x4e0, 0x2e0, 0x6e0, 0x1e0, + 0x5e0, 0x3e0, 0x7e0, 0x10, 0x410, 0x210, 0x610, 0x110, 0x510, 0x310, + 0x710, 0x90, 0x490, 0x290, 0x690, 0x190, 0x590, 0x390, 0x790, 0x50, + 0x450, 0x250, 0x650, 0x150, 0x550, 0x350, 0x750, 0xd0, 0x4d0, 0x2d0, + 0x6d0, 0x1d0, 0x5d0, 0x3d0, 0x7d0, 0x30, 0x430, 0x230, 0x630, 0x130, + 0x530, 0x330, 0x730, 0xb0, 0x4b0, 0x2b0, 0x6b0, 0x1b0, 0x5b0, 0x3b0, + 0x7b0, 0x70, 0x470, 0x270, 0x670, 0x170, 0x570, 0x370, 0x770, 0xf0, + 0x4f0, 0x2f0, 0x6f0, 0x1f0, 0x5f0, 0x3f0, 0x7f0, 0x8, 0x408, 0x208, + 0x608, 0x108, 0x508, 0x308, 0x708, 0x88, 0x488, 0x288, 0x688, 0x188, + 0x588, 0x388, 0x788, 0x48, 0x448, 0x248, 0x648, 0x148, 0x548, 0x348, + 0x748, 0xc8, 0x4c8, 0x2c8, 0x6c8, 0x1c8, 0x5c8, 0x3c8, 0x7c8, 0x28, + 0x428, 0x228, 0x628, 0x128, 0x528, 0x328, 0x728, 0xa8, 0x4a8, 0x2a8, + 0x6a8, 0x1a8, 0x5a8, 0x3a8, 0x7a8, 0x68, 0x468, 0x268, 0x668, 0x168, + 0x568, 0x368, 0x768, 0xe8, 0x4e8, 0x2e8, 0x6e8, 0x1e8, 0x5e8, 0x3e8, + 0x7e8, 0x18, 0x418, 0x218, 0x618, 0x118, 0x518, 0x318, 0x718, 0x98, + 0x498, 0x298, 0x698, 0x198, 0x598, 0x398, 0x798, 0x58, 0x458, 0x258, + 0x658, 0x158, 0x558, 0x358, 0x758, 0xd8, 0x4d8, 0x2d8, 0x6d8, 0x1d8, + 0x5d8, 0x3d8, 0x7d8, 0x38, 0x438, 0x238, 0x638, 0x138, 0x538, 0x338, + 0x738, 0xb8, 0x4b8, 0x2b8, 0x6b8, 0x1b8, 0x5b8, 0x3b8, 0x7b8, 0x78, + 0x478, 0x278, 0x678, 0x178, 0x578, 0x378, 0x778, 0xf8, 0x4f8, 0x2f8, + 0x6f8, 0x1f8, 0x5f8, 0x3f8, 0x7f8, 0x4, 0x404, 0x204, 0x604, 0x104, + 0x504, 0x304, 0x704, 0x84, 0x484, 0x284, 0x684, 0x184, 0x584, 0x384, + 0x784, 0x44, 0x444, 0x244, 0x644, 0x144, 0x544, 0x344, 0x744, 0xc4, + 0x4c4, 0x2c4, 0x6c4, 0x1c4, 0x5c4, 0x3c4, 0x7c4, 0x24, 0x424, 0x224, + 0x624, 0x124, 0x524, 0x324, 0x724, 0xa4, 0x4a4, 0x2a4, 0x6a4, 0x1a4, + 0x5a4, 0x3a4, 0x7a4, 0x64, 0x464, 0x264, 0x664, 0x164, 0x564, 0x364, + 0x764, 0xe4, 0x4e4, 0x2e4, 0x6e4, 0x1e4, 0x5e4, 0x3e4, 0x7e4, 0x14, + 0x414, 0x214, 0x614, 0x114, 0x514, 0x314, 0x714, 0x94, 0x494, 0x294, + 0x694, 0x194, 0x594, 0x394, 0x794, 0x54, 0x454, 0x254, 0x654, 0x154, + 0x554, 0x354, 0x754, 0xd4, 0x4d4, 0x2d4, 0x6d4, 0x1d4, 0x5d4, 0x3d4, + 0x7d4, 0x34, 0x434, 0x234, 0x634, 0x134, 0x534, 0x334, 0x734, 0xb4, + 0x4b4, 0x2b4, 0x6b4, 0x1b4, 0x5b4, 0x3b4, 0x7b4, 0x74, 0x474, 0x274, + 0x674, 0x174, 0x574, 0x374, 0x774, 0xf4, 0x4f4, 0x2f4, 0x6f4, 0x1f4, + 0x5f4, 0x3f4, 0x7f4, 0xc, 0x40c, 0x20c, 0x60c, 0x10c, 0x50c, 0x30c, + 0x70c, 0x8c, 0x48c, 0x28c, 0x68c, 0x18c, 0x58c, 0x38c, 0x78c, 0x4c, + 0x44c, 0x24c, 0x64c, 0x14c, 0x54c, 0x34c, 0x74c, 0xcc, 0x4cc, 0x2cc, + 0x6cc, 0x1cc, 0x5cc, 0x3cc, 0x7cc, 0x2c, 0x42c, 0x22c, 0x62c, 0x12c, + 0x52c, 0x32c, 0x72c, 0xac, 0x4ac, 0x2ac, 0x6ac, 0x1ac, 0x5ac, 0x3ac, + 0x7ac, 0x6c, 0x46c, 0x26c, 0x66c, 0x16c, 0x56c, 0x36c, 0x76c, 0xec, + 0x4ec, 0x2ec, 0x6ec, 0x1ec, 0x5ec, 0x3ec, 0x7ec, 0x1c, 0x41c, 0x21c, + 0x61c, 0x11c, 0x51c, 0x31c, 0x71c, 0x9c, 0x49c, 0x29c, 0x69c, 0x19c, + 0x59c, 0x39c, 0x79c, 0x5c, 0x45c, 0x25c, 0x65c, 0x15c, 0x55c, 0x35c, + 0x75c, 0xdc, 0x4dc, 0x2dc, 0x6dc, 0x1dc, 0x5dc, 0x3dc, 0x7dc, 0x3c, + 0x43c, 0x23c, 0x63c, 0x13c, 0x53c, 0x33c, 0x73c, 0xbc, 0x4bc, 0x2bc, + 0x6bc, 0x1bc, 0x5bc, 0x3bc, 0x7bc, 0x7c, 0x47c, 0x27c, 0x67c, 0x17c, + 0x57c, 0x37c, 0x77c, 0xfc, 0x4fc, 0x2fc, 0x6fc, 0x1fc, 0x5fc, 0x3fc, + 0x7fc, 0x2, 0x402, 0x202, 0x602, 0x102, 0x502, 0x302, 0x702, 0x82, + 0x482, 0x282, 0x682, 0x182, 0x582, 0x382, 0x782, 0x42, 0x442, 0x242, + 0x642, 0x142, 0x542, 0x342, 0x742, 0xc2, 0x4c2, 0x2c2, 0x6c2, 0x1c2, + 0x5c2, 0x3c2, 0x7c2, 0x22, 0x422, 0x222, 0x622, 0x122, 0x522, 0x322, + 0x722, 0xa2, 0x4a2, 0x2a2, 0x6a2, 0x1a2, 0x5a2, 0x3a2, 0x7a2, 0x62, + 0x462, 0x262, 0x662, 0x162, 0x562, 0x362, 0x762, 0xe2, 0x4e2, 0x2e2, + 0x6e2, 0x1e2, 0x5e2, 0x3e2, 0x7e2, 0x12, 0x412, 0x212, 0x612, 0x112, + 0x512, 0x312, 0x712, 0x92, 0x492, 0x292, 0x692, 0x192, 0x592, 0x392, + 0x792, 0x52, 0x452, 0x252, 0x652, 0x152, 0x552, 0x352, 0x752, 0xd2, + 0x4d2, 0x2d2, 0x6d2, 0x1d2, 0x5d2, 0x3d2, 0x7d2, 0x32, 0x432, 0x232, + 0x632, 0x132, 0x532, 0x332, 0x732, 0xb2, 0x4b2, 0x2b2, 0x6b2, 0x1b2, + 0x5b2, 0x3b2, 0x7b2, 0x72, 0x472, 0x272, 0x672, 0x172, 0x572, 0x372, + 0x772, 0xf2, 0x4f2, 0x2f2, 0x6f2, 0x1f2, 0x5f2, 0x3f2, 0x7f2, 0xa, + 0x40a, 0x20a, 0x60a, 0x10a, 0x50a, 0x30a, 0x70a, 0x8a, 0x48a, 0x28a, + 0x68a, 0x18a, 0x58a, 0x38a, 0x78a, 0x4a, 0x44a, 0x24a, 0x64a, 0x14a, + 0x54a, 0x34a, 0x74a, 0xca, 0x4ca, 0x2ca, 0x6ca, 0x1ca, 0x5ca, 0x3ca, + 0x7ca, 0x2a, 0x42a, 0x22a, 0x62a, 0x12a, 0x52a, 0x32a, 0x72a, 0xaa, + 0x4aa, 0x2aa, 0x6aa, 0x1aa, 0x5aa, 0x3aa, 0x7aa, 0x6a, 0x46a, 0x26a, + 0x66a, 0x16a, 0x56a, 0x36a, 0x76a, 0xea, 0x4ea, 0x2ea, 0x6ea, 0x1ea, + 0x5ea, 0x3ea, 0x7ea, 0x1a, 0x41a, 0x21a, 0x61a, 0x11a, 0x51a, 0x31a, + 0x71a, 0x9a, 0x49a, 0x29a, 0x69a, 0x19a, 0x59a, 0x39a, 0x79a, 0x5a, + 0x45a, 0x25a, 0x65a, 0x15a, 0x55a, 0x35a, 0x75a, 0xda, 0x4da, 0x2da, + 0x6da, 0x1da, 0x5da, 0x3da, 0x7da, 0x3a, 0x43a, 0x23a, 0x63a, 0x13a, + 0x53a, 0x33a, 0x73a, 0xba, 0x4ba, 0x2ba, 0x6ba, 0x1ba, 0x5ba, 0x3ba, + 0x7ba, 0x7a, 0x47a, 0x27a, 0x67a, 0x17a, 0x57a, 0x37a, 0x77a, 0xfa, + 0x4fa, 0x2fa, 0x6fa, 0x1fa, 0x5fa, 0x3fa, 0x7fa, 0x6, 0x406, 0x206, + 0x606, 0x106, 0x506, 0x306, 0x706, 0x86, 0x486, 0x286, 0x686, 0x186, + 0x586, 0x386, 0x786, 0x46, 0x446, 0x246, 0x646, 0x146, 0x546, 0x346, + 0x746, 0xc6, 0x4c6, 0x2c6, 0x6c6, 0x1c6, 0x5c6, 0x3c6, 0x7c6, 0x26, + 0x426, 0x226, 0x626, 0x126, 0x526, 0x326, 0x726, 0xa6, 0x4a6, 0x2a6, + 0x6a6, 0x1a6, 0x5a6, 0x3a6, 0x7a6, 0x66, 0x466, 0x266, 0x666, 0x166, + 0x566, 0x366, 0x766, 0xe6, 0x4e6, 0x2e6, 0x6e6, 0x1e6, 0x5e6, 0x3e6, + 0x7e6, 0x16, 0x416, 0x216, 0x616, 0x116, 0x516, 0x316, 0x716, 0x96, + 0x496, 0x296, 0x696, 0x196, 0x596, 0x396, 0x796, 0x56, 0x456, 0x256, + 0x656, 0x156, 0x556, 0x356, 0x756, 0xd6, 0x4d6, 0x2d6, 0x6d6, 0x1d6, + 0x5d6, 0x3d6, 0x7d6, 0x36, 0x436, 0x236, 0x636, 0x136, 0x536, 0x336, + 0x736, 0xb6, 0x4b6, 0x2b6, 0x6b6, 0x1b6, 0x5b6, 0x3b6, 0x7b6, 0x76, + 0x476, 0x276, 0x676, 0x176, 0x576, 0x376, 0x776, 0xf6, 0x4f6, 0x2f6, + 0x6f6, 0x1f6, 0x5f6, 0x3f6, 0x7f6, 0xe, 0x40e, 0x20e, 0x60e, 0x10e, + 0x50e, 0x30e, 0x70e, 0x8e, 0x48e, 0x28e, 0x68e, 0x18e, 0x58e, 0x38e, + 0x78e, 0x4e, 0x44e, 0x24e, 0x64e, 0x14e, 0x54e, 0x34e, 0x74e, 0xce, + 0x4ce, 0x2ce, 0x6ce, 0x1ce, 0x5ce, 0x3ce, 0x7ce, 0x2e, 0x42e, 0x22e, + 0x62e, 0x12e, 0x52e, 0x32e, 0x72e, 0xae, 0x4ae, 0x2ae, 0x6ae, 0x1ae, + 0x5ae, 0x3ae, 0x7ae, 0x6e, 0x46e, 0x26e, 0x66e, 0x16e, 0x56e, 0x36e, + 0x76e, 0xee, 0x4ee, 0x2ee, 0x6ee, 0x1ee, 0x5ee, 0x3ee, 0x7ee, 0x1e, + 0x41e, 0x21e, 0x61e, 0x11e, 0x51e, 0x31e, 0x71e, 0x9e, 0x49e, 0x29e, + 0x69e, 0x19e, 0x59e, 0x39e, 0x79e, 0x5e, 0x45e, 0x25e, 0x65e, 0x15e, + 0x55e, 0x35e, 0x75e, 0xde, 0x4de, 0x2de, 0x6de, 0x1de, 0x5de, 0x3de, + 0x7de, 0x3e, 0x43e, 0x23e, 0x63e, 0x13e, 0x53e, 0x33e, 0x73e, 0xbe, + 0x4be, 0x2be, 0x6be, 0x1be, 0x5be, 0x3be, 0x7be, 0x7e, 0x47e, 0x27e, + 0x67e, 0x17e, 0x57e, 0x37e, 0x77e, 0xfe, 0x4fe, 0x2fe, 0x6fe, 0x1fe, + 0x5fe, 0x3fe, 0x7fe, 0x1 +}; + + +/* +* @brief Floating-point Twiddle factors Table Generation +*/ + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 16 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_16[32] = { + 1.000000000f, 0.000000000f, + 0.923879533f, 0.382683432f, + 0.707106781f, 0.707106781f, + 0.382683432f, 0.923879533f, + 0.000000000f, 1.000000000f, + -0.382683432f, 0.923879533f, + -0.707106781f, 0.707106781f, + -0.923879533f, 0.382683432f, + -1.000000000f, 0.000000000f, + -0.923879533f, -0.382683432f, + -0.707106781f, -0.707106781f, + -0.382683432f, -0.923879533f, + -0.000000000f, -1.000000000f, + 0.382683432f, -0.923879533f, + 0.707106781f, -0.707106781f, + 0.923879533f, -0.382683432f +}; + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 32 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_32[64] = { + 1.000000000f, 0.000000000f, + 0.980785280f, 0.195090322f, + 0.923879533f, 0.382683432f, + 0.831469612f, 0.555570233f, + 0.707106781f, 0.707106781f, + 0.555570233f, 0.831469612f, + 0.382683432f, 0.923879533f, + 0.195090322f, 0.980785280f, + 0.000000000f, 1.000000000f, + -0.195090322f, 0.980785280f, + -0.382683432f, 0.923879533f, + -0.555570233f, 0.831469612f, + -0.707106781f, 0.707106781f, + -0.831469612f, 0.555570233f, + -0.923879533f, 0.382683432f, + -0.980785280f, 0.195090322f, + -1.000000000f, 0.000000000f, + -0.980785280f, -0.195090322f, + -0.923879533f, -0.382683432f, + -0.831469612f, -0.555570233f, + -0.707106781f, -0.707106781f, + -0.555570233f, -0.831469612f, + -0.382683432f, -0.923879533f, + -0.195090322f, -0.980785280f, + -0.000000000f, -1.000000000f, + 0.195090322f, -0.980785280f, + 0.382683432f, -0.923879533f, + 0.555570233f, -0.831469612f, + 0.707106781f, -0.707106781f, + 0.831469612f, -0.555570233f, + 0.923879533f, -0.382683432f, + 0.980785280f, -0.195090322f +}; + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 64 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_64[128] = { + 1.000000000f, 0.000000000f, + 0.995184727f, 0.098017140f, + 0.980785280f, 0.195090322f, + 0.956940336f, 0.290284677f, + 0.923879533f, 0.382683432f, + 0.881921264f, 0.471396737f, + 0.831469612f, 0.555570233f, + 0.773010453f, 0.634393284f, + 0.707106781f, 0.707106781f, + 0.634393284f, 0.773010453f, + 0.555570233f, 0.831469612f, + 0.471396737f, 0.881921264f, + 0.382683432f, 0.923879533f, + 0.290284677f, 0.956940336f, + 0.195090322f, 0.980785280f, + 0.098017140f, 0.995184727f, + 0.000000000f, 1.000000000f, + -0.098017140f, 0.995184727f, + -0.195090322f, 0.980785280f, + -0.290284677f, 0.956940336f, + -0.382683432f, 0.923879533f, + -0.471396737f, 0.881921264f, + -0.555570233f, 0.831469612f, + -0.634393284f, 0.773010453f, + -0.707106781f, 0.707106781f, + -0.773010453f, 0.634393284f, + -0.831469612f, 0.555570233f, + -0.881921264f, 0.471396737f, + -0.923879533f, 0.382683432f, + -0.956940336f, 0.290284677f, + -0.980785280f, 0.195090322f, + -0.995184727f, 0.098017140f, + -1.000000000f, 0.000000000f, + -0.995184727f, -0.098017140f, + -0.980785280f, -0.195090322f, + -0.956940336f, -0.290284677f, + -0.923879533f, -0.382683432f, + -0.881921264f, -0.471396737f, + -0.831469612f, -0.555570233f, + -0.773010453f, -0.634393284f, + -0.707106781f, -0.707106781f, + -0.634393284f, -0.773010453f, + -0.555570233f, -0.831469612f, + -0.471396737f, -0.881921264f, + -0.382683432f, -0.923879533f, + -0.290284677f, -0.956940336f, + -0.195090322f, -0.980785280f, + -0.098017140f, -0.995184727f, + -0.000000000f, -1.000000000f, + 0.098017140f, -0.995184727f, + 0.195090322f, -0.980785280f, + 0.290284677f, -0.956940336f, + 0.382683432f, -0.923879533f, + 0.471396737f, -0.881921264f, + 0.555570233f, -0.831469612f, + 0.634393284f, -0.773010453f, + 0.707106781f, -0.707106781f, + 0.773010453f, -0.634393284f, + 0.831469612f, -0.555570233f, + 0.881921264f, -0.471396737f, + 0.923879533f, -0.382683432f, + 0.956940336f, -0.290284677f, + 0.980785280f, -0.195090322f, + 0.995184727f, -0.098017140f +}; + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 128 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ + +const float32_t twiddleCoef_128[256] = { + 1.000000000f, 0.000000000f, + 0.998795456f, 0.049067674f, + 0.995184727f, 0.098017140f, + 0.989176510f, 0.146730474f, + 0.980785280f, 0.195090322f, + 0.970031253f, 0.242980180f, + 0.956940336f, 0.290284677f, + 0.941544065f, 0.336889853f, + 0.923879533f, 0.382683432f, + 0.903989293f, 0.427555093f, + 0.881921264f, 0.471396737f, + 0.857728610f, 0.514102744f, + 0.831469612f, 0.555570233f, + 0.803207531f, 0.595699304f, + 0.773010453f, 0.634393284f, + 0.740951125f, 0.671558955f, + 0.707106781f, 0.707106781f, + 0.671558955f, 0.740951125f, + 0.634393284f, 0.773010453f, + 0.595699304f, 0.803207531f, + 0.555570233f, 0.831469612f, + 0.514102744f, 0.857728610f, + 0.471396737f, 0.881921264f, + 0.427555093f, 0.903989293f, + 0.382683432f, 0.923879533f, + 0.336889853f, 0.941544065f, + 0.290284677f, 0.956940336f, + 0.242980180f, 0.970031253f, + 0.195090322f, 0.980785280f, + 0.146730474f, 0.989176510f, + 0.098017140f, 0.995184727f, + 0.049067674f, 0.998795456f, + 0.000000000f, 1.000000000f, + -0.049067674f, 0.998795456f, + -0.098017140f, 0.995184727f, + -0.146730474f, 0.989176510f, + -0.195090322f, 0.980785280f, + -0.242980180f, 0.970031253f, + -0.290284677f, 0.956940336f, + -0.336889853f, 0.941544065f, + -0.382683432f, 0.923879533f, + -0.427555093f, 0.903989293f, + -0.471396737f, 0.881921264f, + -0.514102744f, 0.857728610f, + -0.555570233f, 0.831469612f, + -0.595699304f, 0.803207531f, + -0.634393284f, 0.773010453f, + -0.671558955f, 0.740951125f, + -0.707106781f, 0.707106781f, + -0.740951125f, 0.671558955f, + -0.773010453f, 0.634393284f, + -0.803207531f, 0.595699304f, + -0.831469612f, 0.555570233f, + -0.857728610f, 0.514102744f, + -0.881921264f, 0.471396737f, + -0.903989293f, 0.427555093f, + -0.923879533f, 0.382683432f, + -0.941544065f, 0.336889853f, + -0.956940336f, 0.290284677f, + -0.970031253f, 0.242980180f, + -0.980785280f, 0.195090322f, + -0.989176510f, 0.146730474f, + -0.995184727f, 0.098017140f, + -0.998795456f, 0.049067674f, + -1.000000000f, 0.000000000f, + -0.998795456f, -0.049067674f, + -0.995184727f, -0.098017140f, + -0.989176510f, -0.146730474f, + -0.980785280f, -0.195090322f, + -0.970031253f, -0.242980180f, + -0.956940336f, -0.290284677f, + -0.941544065f, -0.336889853f, + -0.923879533f, -0.382683432f, + -0.903989293f, -0.427555093f, + -0.881921264f, -0.471396737f, + -0.857728610f, -0.514102744f, + -0.831469612f, -0.555570233f, + -0.803207531f, -0.595699304f, + -0.773010453f, -0.634393284f, + -0.740951125f, -0.671558955f, + -0.707106781f, -0.707106781f, + -0.671558955f, -0.740951125f, + -0.634393284f, -0.773010453f, + -0.595699304f, -0.803207531f, + -0.555570233f, -0.831469612f, + -0.514102744f, -0.857728610f, + -0.471396737f, -0.881921264f, + -0.427555093f, -0.903989293f, + -0.382683432f, -0.923879533f, + -0.336889853f, -0.941544065f, + -0.290284677f, -0.956940336f, + -0.242980180f, -0.970031253f, + -0.195090322f, -0.980785280f, + -0.146730474f, -0.989176510f, + -0.098017140f, -0.995184727f, + -0.049067674f, -0.998795456f, + -0.000000000f, -1.000000000f, + 0.049067674f, -0.998795456f, + 0.098017140f, -0.995184727f, + 0.146730474f, -0.989176510f, + 0.195090322f, -0.980785280f, + 0.242980180f, -0.970031253f, + 0.290284677f, -0.956940336f, + 0.336889853f, -0.941544065f, + 0.382683432f, -0.923879533f, + 0.427555093f, -0.903989293f, + 0.471396737f, -0.881921264f, + 0.514102744f, -0.857728610f, + 0.555570233f, -0.831469612f, + 0.595699304f, -0.803207531f, + 0.634393284f, -0.773010453f, + 0.671558955f, -0.740951125f, + 0.707106781f, -0.707106781f, + 0.740951125f, -0.671558955f, + 0.773010453f, -0.634393284f, + 0.803207531f, -0.595699304f, + 0.831469612f, -0.555570233f, + 0.857728610f, -0.514102744f, + 0.881921264f, -0.471396737f, + 0.903989293f, -0.427555093f, + 0.923879533f, -0.382683432f, + 0.941544065f, -0.336889853f, + 0.956940336f, -0.290284677f, + 0.970031253f, -0.242980180f, + 0.980785280f, -0.195090322f, + 0.989176510f, -0.146730474f, + 0.995184727f, -0.098017140f, + 0.998795456f, -0.049067674f +}; + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 256 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_256[512] = { + 1.000000000f, 0.000000000f, + 0.999698819f, 0.024541229f, + 0.998795456f, 0.049067674f, + 0.997290457f, 0.073564564f, + 0.995184727f, 0.098017140f, + 0.992479535f, 0.122410675f, + 0.989176510f, 0.146730474f, + 0.985277642f, 0.170961889f, + 0.980785280f, 0.195090322f, + 0.975702130f, 0.219101240f, + 0.970031253f, 0.242980180f, + 0.963776066f, 0.266712757f, + 0.956940336f, 0.290284677f, + 0.949528181f, 0.313681740f, + 0.941544065f, 0.336889853f, + 0.932992799f, 0.359895037f, + 0.923879533f, 0.382683432f, + 0.914209756f, 0.405241314f, + 0.903989293f, 0.427555093f, + 0.893224301f, 0.449611330f, + 0.881921264f, 0.471396737f, + 0.870086991f, 0.492898192f, + 0.857728610f, 0.514102744f, + 0.844853565f, 0.534997620f, + 0.831469612f, 0.555570233f, + 0.817584813f, 0.575808191f, + 0.803207531f, 0.595699304f, + 0.788346428f, 0.615231591f, + 0.773010453f, 0.634393284f, + 0.757208847f, 0.653172843f, + 0.740951125f, 0.671558955f, + 0.724247083f, 0.689540545f, + 0.707106781f, 0.707106781f, + 0.689540545f, 0.724247083f, + 0.671558955f, 0.740951125f, + 0.653172843f, 0.757208847f, + 0.634393284f, 0.773010453f, + 0.615231591f, 0.788346428f, + 0.595699304f, 0.803207531f, + 0.575808191f, 0.817584813f, + 0.555570233f, 0.831469612f, + 0.534997620f, 0.844853565f, + 0.514102744f, 0.857728610f, + 0.492898192f, 0.870086991f, + 0.471396737f, 0.881921264f, + 0.449611330f, 0.893224301f, + 0.427555093f, 0.903989293f, + 0.405241314f, 0.914209756f, + 0.382683432f, 0.923879533f, + 0.359895037f, 0.932992799f, + 0.336889853f, 0.941544065f, + 0.313681740f, 0.949528181f, + 0.290284677f, 0.956940336f, + 0.266712757f, 0.963776066f, + 0.242980180f, 0.970031253f, + 0.219101240f, 0.975702130f, + 0.195090322f, 0.980785280f, + 0.170961889f, 0.985277642f, + 0.146730474f, 0.989176510f, + 0.122410675f, 0.992479535f, + 0.098017140f, 0.995184727f, + 0.073564564f, 0.997290457f, + 0.049067674f, 0.998795456f, + 0.024541229f, 0.999698819f, + 0.000000000f, 1.000000000f, + -0.024541229f, 0.999698819f, + -0.049067674f, 0.998795456f, + -0.073564564f, 0.997290457f, + -0.098017140f, 0.995184727f, + -0.122410675f, 0.992479535f, + -0.146730474f, 0.989176510f, + -0.170961889f, 0.985277642f, + -0.195090322f, 0.980785280f, + -0.219101240f, 0.975702130f, + -0.242980180f, 0.970031253f, + -0.266712757f, 0.963776066f, + -0.290284677f, 0.956940336f, + -0.313681740f, 0.949528181f, + -0.336889853f, 0.941544065f, + -0.359895037f, 0.932992799f, + -0.382683432f, 0.923879533f, + -0.405241314f, 0.914209756f, + -0.427555093f, 0.903989293f, + -0.449611330f, 0.893224301f, + -0.471396737f, 0.881921264f, + -0.492898192f, 0.870086991f, + -0.514102744f, 0.857728610f, + -0.534997620f, 0.844853565f, + -0.555570233f, 0.831469612f, + -0.575808191f, 0.817584813f, + -0.595699304f, 0.803207531f, + -0.615231591f, 0.788346428f, + -0.634393284f, 0.773010453f, + -0.653172843f, 0.757208847f, + -0.671558955f, 0.740951125f, + -0.689540545f, 0.724247083f, + -0.707106781f, 0.707106781f, + -0.724247083f, 0.689540545f, + -0.740951125f, 0.671558955f, + -0.757208847f, 0.653172843f, + -0.773010453f, 0.634393284f, + -0.788346428f, 0.615231591f, + -0.803207531f, 0.595699304f, + -0.817584813f, 0.575808191f, + -0.831469612f, 0.555570233f, + -0.844853565f, 0.534997620f, + -0.857728610f, 0.514102744f, + -0.870086991f, 0.492898192f, + -0.881921264f, 0.471396737f, + -0.893224301f, 0.449611330f, + -0.903989293f, 0.427555093f, + -0.914209756f, 0.405241314f, + -0.923879533f, 0.382683432f, + -0.932992799f, 0.359895037f, + -0.941544065f, 0.336889853f, + -0.949528181f, 0.313681740f, + -0.956940336f, 0.290284677f, + -0.963776066f, 0.266712757f, + -0.970031253f, 0.242980180f, + -0.975702130f, 0.219101240f, + -0.980785280f, 0.195090322f, + -0.985277642f, 0.170961889f, + -0.989176510f, 0.146730474f, + -0.992479535f, 0.122410675f, + -0.995184727f, 0.098017140f, + -0.997290457f, 0.073564564f, + -0.998795456f, 0.049067674f, + -0.999698819f, 0.024541229f, + -1.000000000f, 0.000000000f, + -0.999698819f, -0.024541229f, + -0.998795456f, -0.049067674f, + -0.997290457f, -0.073564564f, + -0.995184727f, -0.098017140f, + -0.992479535f, -0.122410675f, + -0.989176510f, -0.146730474f, + -0.985277642f, -0.170961889f, + -0.980785280f, -0.195090322f, + -0.975702130f, -0.219101240f, + -0.970031253f, -0.242980180f, + -0.963776066f, -0.266712757f, + -0.956940336f, -0.290284677f, + -0.949528181f, -0.313681740f, + -0.941544065f, -0.336889853f, + -0.932992799f, -0.359895037f, + -0.923879533f, -0.382683432f, + -0.914209756f, -0.405241314f, + -0.903989293f, -0.427555093f, + -0.893224301f, -0.449611330f, + -0.881921264f, -0.471396737f, + -0.870086991f, -0.492898192f, + -0.857728610f, -0.514102744f, + -0.844853565f, -0.534997620f, + -0.831469612f, -0.555570233f, + -0.817584813f, -0.575808191f, + -0.803207531f, -0.595699304f, + -0.788346428f, -0.615231591f, + -0.773010453f, -0.634393284f, + -0.757208847f, -0.653172843f, + -0.740951125f, -0.671558955f, + -0.724247083f, -0.689540545f, + -0.707106781f, -0.707106781f, + -0.689540545f, -0.724247083f, + -0.671558955f, -0.740951125f, + -0.653172843f, -0.757208847f, + -0.634393284f, -0.773010453f, + -0.615231591f, -0.788346428f, + -0.595699304f, -0.803207531f, + -0.575808191f, -0.817584813f, + -0.555570233f, -0.831469612f, + -0.534997620f, -0.844853565f, + -0.514102744f, -0.857728610f, + -0.492898192f, -0.870086991f, + -0.471396737f, -0.881921264f, + -0.449611330f, -0.893224301f, + -0.427555093f, -0.903989293f, + -0.405241314f, -0.914209756f, + -0.382683432f, -0.923879533f, + -0.359895037f, -0.932992799f, + -0.336889853f, -0.941544065f, + -0.313681740f, -0.949528181f, + -0.290284677f, -0.956940336f, + -0.266712757f, -0.963776066f, + -0.242980180f, -0.970031253f, + -0.219101240f, -0.975702130f, + -0.195090322f, -0.980785280f, + -0.170961889f, -0.985277642f, + -0.146730474f, -0.989176510f, + -0.122410675f, -0.992479535f, + -0.098017140f, -0.995184727f, + -0.073564564f, -0.997290457f, + -0.049067674f, -0.998795456f, + -0.024541229f, -0.999698819f, + -0.000000000f, -1.000000000f, + 0.024541229f, -0.999698819f, + 0.049067674f, -0.998795456f, + 0.073564564f, -0.997290457f, + 0.098017140f, -0.995184727f, + 0.122410675f, -0.992479535f, + 0.146730474f, -0.989176510f, + 0.170961889f, -0.985277642f, + 0.195090322f, -0.980785280f, + 0.219101240f, -0.975702130f, + 0.242980180f, -0.970031253f, + 0.266712757f, -0.963776066f, + 0.290284677f, -0.956940336f, + 0.313681740f, -0.949528181f, + 0.336889853f, -0.941544065f, + 0.359895037f, -0.932992799f, + 0.382683432f, -0.923879533f, + 0.405241314f, -0.914209756f, + 0.427555093f, -0.903989293f, + 0.449611330f, -0.893224301f, + 0.471396737f, -0.881921264f, + 0.492898192f, -0.870086991f, + 0.514102744f, -0.857728610f, + 0.534997620f, -0.844853565f, + 0.555570233f, -0.831469612f, + 0.575808191f, -0.817584813f, + 0.595699304f, -0.803207531f, + 0.615231591f, -0.788346428f, + 0.634393284f, -0.773010453f, + 0.653172843f, -0.757208847f, + 0.671558955f, -0.740951125f, + 0.689540545f, -0.724247083f, + 0.707106781f, -0.707106781f, + 0.724247083f, -0.689540545f, + 0.740951125f, -0.671558955f, + 0.757208847f, -0.653172843f, + 0.773010453f, -0.634393284f, + 0.788346428f, -0.615231591f, + 0.803207531f, -0.595699304f, + 0.817584813f, -0.575808191f, + 0.831469612f, -0.555570233f, + 0.844853565f, -0.534997620f, + 0.857728610f, -0.514102744f, + 0.870086991f, -0.492898192f, + 0.881921264f, -0.471396737f, + 0.893224301f, -0.449611330f, + 0.903989293f, -0.427555093f, + 0.914209756f, -0.405241314f, + 0.923879533f, -0.382683432f, + 0.932992799f, -0.359895037f, + 0.941544065f, -0.336889853f, + 0.949528181f, -0.313681740f, + 0.956940336f, -0.290284677f, + 0.963776066f, -0.266712757f, + 0.970031253f, -0.242980180f, + 0.975702130f, -0.219101240f, + 0.980785280f, -0.195090322f, + 0.985277642f, -0.170961889f, + 0.989176510f, -0.146730474f, + 0.992479535f, -0.122410675f, + 0.995184727f, -0.098017140f, + 0.997290457f, -0.073564564f, + 0.998795456f, -0.049067674f, + 0.999698819f, -0.024541229f +}; + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 512 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_512[1024] = { + 1.000000000f, 0.000000000f, + 0.999924702f, 0.012271538f, + 0.999698819f, 0.024541229f, + 0.999322385f, 0.036807223f, + 0.998795456f, 0.049067674f, + 0.998118113f, 0.061320736f, + 0.997290457f, 0.073564564f, + 0.996312612f, 0.085797312f, + 0.995184727f, 0.098017140f, + 0.993906970f, 0.110222207f, + 0.992479535f, 0.122410675f, + 0.990902635f, 0.134580709f, + 0.989176510f, 0.146730474f, + 0.987301418f, 0.158858143f, + 0.985277642f, 0.170961889f, + 0.983105487f, 0.183039888f, + 0.980785280f, 0.195090322f, + 0.978317371f, 0.207111376f, + 0.975702130f, 0.219101240f, + 0.972939952f, 0.231058108f, + 0.970031253f, 0.242980180f, + 0.966976471f, 0.254865660f, + 0.963776066f, 0.266712757f, + 0.960430519f, 0.278519689f, + 0.956940336f, 0.290284677f, + 0.953306040f, 0.302005949f, + 0.949528181f, 0.313681740f, + 0.945607325f, 0.325310292f, + 0.941544065f, 0.336889853f, + 0.937339012f, 0.348418680f, + 0.932992799f, 0.359895037f, + 0.928506080f, 0.371317194f, + 0.923879533f, 0.382683432f, + 0.919113852f, 0.393992040f, + 0.914209756f, 0.405241314f, + 0.909167983f, 0.416429560f, + 0.903989293f, 0.427555093f, + 0.898674466f, 0.438616239f, + 0.893224301f, 0.449611330f, + 0.887639620f, 0.460538711f, + 0.881921264f, 0.471396737f, + 0.876070094f, 0.482183772f, + 0.870086991f, 0.492898192f, + 0.863972856f, 0.503538384f, + 0.857728610f, 0.514102744f, + 0.851355193f, 0.524589683f, + 0.844853565f, 0.534997620f, + 0.838224706f, 0.545324988f, + 0.831469612f, 0.555570233f, + 0.824589303f, 0.565731811f, + 0.817584813f, 0.575808191f, + 0.810457198f, 0.585797857f, + 0.803207531f, 0.595699304f, + 0.795836905f, 0.605511041f, + 0.788346428f, 0.615231591f, + 0.780737229f, 0.624859488f, + 0.773010453f, 0.634393284f, + 0.765167266f, 0.643831543f, + 0.757208847f, 0.653172843f, + 0.749136395f, 0.662415778f, + 0.740951125f, 0.671558955f, + 0.732654272f, 0.680600998f, + 0.724247083f, 0.689540545f, + 0.715730825f, 0.698376249f, + 0.707106781f, 0.707106781f, + 0.698376249f, 0.715730825f, + 0.689540545f, 0.724247083f, + 0.680600998f, 0.732654272f, + 0.671558955f, 0.740951125f, + 0.662415778f, 0.749136395f, + 0.653172843f, 0.757208847f, + 0.643831543f, 0.765167266f, + 0.634393284f, 0.773010453f, + 0.624859488f, 0.780737229f, + 0.615231591f, 0.788346428f, + 0.605511041f, 0.795836905f, + 0.595699304f, 0.803207531f, + 0.585797857f, 0.810457198f, + 0.575808191f, 0.817584813f, + 0.565731811f, 0.824589303f, + 0.555570233f, 0.831469612f, + 0.545324988f, 0.838224706f, + 0.534997620f, 0.844853565f, + 0.524589683f, 0.851355193f, + 0.514102744f, 0.857728610f, + 0.503538384f, 0.863972856f, + 0.492898192f, 0.870086991f, + 0.482183772f, 0.876070094f, + 0.471396737f, 0.881921264f, + 0.460538711f, 0.887639620f, + 0.449611330f, 0.893224301f, + 0.438616239f, 0.898674466f, + 0.427555093f, 0.903989293f, + 0.416429560f, 0.909167983f, + 0.405241314f, 0.914209756f, + 0.393992040f, 0.919113852f, + 0.382683432f, 0.923879533f, + 0.371317194f, 0.928506080f, + 0.359895037f, 0.932992799f, + 0.348418680f, 0.937339012f, + 0.336889853f, 0.941544065f, + 0.325310292f, 0.945607325f, + 0.313681740f, 0.949528181f, + 0.302005949f, 0.953306040f, + 0.290284677f, 0.956940336f, + 0.278519689f, 0.960430519f, + 0.266712757f, 0.963776066f, + 0.254865660f, 0.966976471f, + 0.242980180f, 0.970031253f, + 0.231058108f, 0.972939952f, + 0.219101240f, 0.975702130f, + 0.207111376f, 0.978317371f, + 0.195090322f, 0.980785280f, + 0.183039888f, 0.983105487f, + 0.170961889f, 0.985277642f, + 0.158858143f, 0.987301418f, + 0.146730474f, 0.989176510f, + 0.134580709f, 0.990902635f, + 0.122410675f, 0.992479535f, + 0.110222207f, 0.993906970f, + 0.098017140f, 0.995184727f, + 0.085797312f, 0.996312612f, + 0.073564564f, 0.997290457f, + 0.061320736f, 0.998118113f, + 0.049067674f, 0.998795456f, + 0.036807223f, 0.999322385f, + 0.024541229f, 0.999698819f, + 0.012271538f, 0.999924702f, + 0.000000000f, 1.000000000f, + -0.012271538f, 0.999924702f, + -0.024541229f, 0.999698819f, + -0.036807223f, 0.999322385f, + -0.049067674f, 0.998795456f, + -0.061320736f, 0.998118113f, + -0.073564564f, 0.997290457f, + -0.085797312f, 0.996312612f, + -0.098017140f, 0.995184727f, + -0.110222207f, 0.993906970f, + -0.122410675f, 0.992479535f, + -0.134580709f, 0.990902635f, + -0.146730474f, 0.989176510f, + -0.158858143f, 0.987301418f, + -0.170961889f, 0.985277642f, + -0.183039888f, 0.983105487f, + -0.195090322f, 0.980785280f, + -0.207111376f, 0.978317371f, + -0.219101240f, 0.975702130f, + -0.231058108f, 0.972939952f, + -0.242980180f, 0.970031253f, + -0.254865660f, 0.966976471f, + -0.266712757f, 0.963776066f, + -0.278519689f, 0.960430519f, + -0.290284677f, 0.956940336f, + -0.302005949f, 0.953306040f, + -0.313681740f, 0.949528181f, + -0.325310292f, 0.945607325f, + -0.336889853f, 0.941544065f, + -0.348418680f, 0.937339012f, + -0.359895037f, 0.932992799f, + -0.371317194f, 0.928506080f, + -0.382683432f, 0.923879533f, + -0.393992040f, 0.919113852f, + -0.405241314f, 0.914209756f, + -0.416429560f, 0.909167983f, + -0.427555093f, 0.903989293f, + -0.438616239f, 0.898674466f, + -0.449611330f, 0.893224301f, + -0.460538711f, 0.887639620f, + -0.471396737f, 0.881921264f, + -0.482183772f, 0.876070094f, + -0.492898192f, 0.870086991f, + -0.503538384f, 0.863972856f, + -0.514102744f, 0.857728610f, + -0.524589683f, 0.851355193f, + -0.534997620f, 0.844853565f, + -0.545324988f, 0.838224706f, + -0.555570233f, 0.831469612f, + -0.565731811f, 0.824589303f, + -0.575808191f, 0.817584813f, + -0.585797857f, 0.810457198f, + -0.595699304f, 0.803207531f, + -0.605511041f, 0.795836905f, + -0.615231591f, 0.788346428f, + -0.624859488f, 0.780737229f, + -0.634393284f, 0.773010453f, + -0.643831543f, 0.765167266f, + -0.653172843f, 0.757208847f, + -0.662415778f, 0.749136395f, + -0.671558955f, 0.740951125f, + -0.680600998f, 0.732654272f, + -0.689540545f, 0.724247083f, + -0.698376249f, 0.715730825f, + -0.707106781f, 0.707106781f, + -0.715730825f, 0.698376249f, + -0.724247083f, 0.689540545f, + -0.732654272f, 0.680600998f, + -0.740951125f, 0.671558955f, + -0.749136395f, 0.662415778f, + -0.757208847f, 0.653172843f, + -0.765167266f, 0.643831543f, + -0.773010453f, 0.634393284f, + -0.780737229f, 0.624859488f, + -0.788346428f, 0.615231591f, + -0.795836905f, 0.605511041f, + -0.803207531f, 0.595699304f, + -0.810457198f, 0.585797857f, + -0.817584813f, 0.575808191f, + -0.824589303f, 0.565731811f, + -0.831469612f, 0.555570233f, + -0.838224706f, 0.545324988f, + -0.844853565f, 0.534997620f, + -0.851355193f, 0.524589683f, + -0.857728610f, 0.514102744f, + -0.863972856f, 0.503538384f, + -0.870086991f, 0.492898192f, + -0.876070094f, 0.482183772f, + -0.881921264f, 0.471396737f, + -0.887639620f, 0.460538711f, + -0.893224301f, 0.449611330f, + -0.898674466f, 0.438616239f, + -0.903989293f, 0.427555093f, + -0.909167983f, 0.416429560f, + -0.914209756f, 0.405241314f, + -0.919113852f, 0.393992040f, + -0.923879533f, 0.382683432f, + -0.928506080f, 0.371317194f, + -0.932992799f, 0.359895037f, + -0.937339012f, 0.348418680f, + -0.941544065f, 0.336889853f, + -0.945607325f, 0.325310292f, + -0.949528181f, 0.313681740f, + -0.953306040f, 0.302005949f, + -0.956940336f, 0.290284677f, + -0.960430519f, 0.278519689f, + -0.963776066f, 0.266712757f, + -0.966976471f, 0.254865660f, + -0.970031253f, 0.242980180f, + -0.972939952f, 0.231058108f, + -0.975702130f, 0.219101240f, + -0.978317371f, 0.207111376f, + -0.980785280f, 0.195090322f, + -0.983105487f, 0.183039888f, + -0.985277642f, 0.170961889f, + -0.987301418f, 0.158858143f, + -0.989176510f, 0.146730474f, + -0.990902635f, 0.134580709f, + -0.992479535f, 0.122410675f, + -0.993906970f, 0.110222207f, + -0.995184727f, 0.098017140f, + -0.996312612f, 0.085797312f, + -0.997290457f, 0.073564564f, + -0.998118113f, 0.061320736f, + -0.998795456f, 0.049067674f, + -0.999322385f, 0.036807223f, + -0.999698819f, 0.024541229f, + -0.999924702f, 0.012271538f, + -1.000000000f, 0.000000000f, + -0.999924702f, -0.012271538f, + -0.999698819f, -0.024541229f, + -0.999322385f, -0.036807223f, + -0.998795456f, -0.049067674f, + -0.998118113f, -0.061320736f, + -0.997290457f, -0.073564564f, + -0.996312612f, -0.085797312f, + -0.995184727f, -0.098017140f, + -0.993906970f, -0.110222207f, + -0.992479535f, -0.122410675f, + -0.990902635f, -0.134580709f, + -0.989176510f, -0.146730474f, + -0.987301418f, -0.158858143f, + -0.985277642f, -0.170961889f, + -0.983105487f, -0.183039888f, + -0.980785280f, -0.195090322f, + -0.978317371f, -0.207111376f, + -0.975702130f, -0.219101240f, + -0.972939952f, -0.231058108f, + -0.970031253f, -0.242980180f, + -0.966976471f, -0.254865660f, + -0.963776066f, -0.266712757f, + -0.960430519f, -0.278519689f, + -0.956940336f, -0.290284677f, + -0.953306040f, -0.302005949f, + -0.949528181f, -0.313681740f, + -0.945607325f, -0.325310292f, + -0.941544065f, -0.336889853f, + -0.937339012f, -0.348418680f, + -0.932992799f, -0.359895037f, + -0.928506080f, -0.371317194f, + -0.923879533f, -0.382683432f, + -0.919113852f, -0.393992040f, + -0.914209756f, -0.405241314f, + -0.909167983f, -0.416429560f, + -0.903989293f, -0.427555093f, + -0.898674466f, -0.438616239f, + -0.893224301f, -0.449611330f, + -0.887639620f, -0.460538711f, + -0.881921264f, -0.471396737f, + -0.876070094f, -0.482183772f, + -0.870086991f, -0.492898192f, + -0.863972856f, -0.503538384f, + -0.857728610f, -0.514102744f, + -0.851355193f, -0.524589683f, + -0.844853565f, -0.534997620f, + -0.838224706f, -0.545324988f, + -0.831469612f, -0.555570233f, + -0.824589303f, -0.565731811f, + -0.817584813f, -0.575808191f, + -0.810457198f, -0.585797857f, + -0.803207531f, -0.595699304f, + -0.795836905f, -0.605511041f, + -0.788346428f, -0.615231591f, + -0.780737229f, -0.624859488f, + -0.773010453f, -0.634393284f, + -0.765167266f, -0.643831543f, + -0.757208847f, -0.653172843f, + -0.749136395f, -0.662415778f, + -0.740951125f, -0.671558955f, + -0.732654272f, -0.680600998f, + -0.724247083f, -0.689540545f, + -0.715730825f, -0.698376249f, + -0.707106781f, -0.707106781f, + -0.698376249f, -0.715730825f, + -0.689540545f, -0.724247083f, + -0.680600998f, -0.732654272f, + -0.671558955f, -0.740951125f, + -0.662415778f, -0.749136395f, + -0.653172843f, -0.757208847f, + -0.643831543f, -0.765167266f, + -0.634393284f, -0.773010453f, + -0.624859488f, -0.780737229f, + -0.615231591f, -0.788346428f, + -0.605511041f, -0.795836905f, + -0.595699304f, -0.803207531f, + -0.585797857f, -0.810457198f, + -0.575808191f, -0.817584813f, + -0.565731811f, -0.824589303f, + -0.555570233f, -0.831469612f, + -0.545324988f, -0.838224706f, + -0.534997620f, -0.844853565f, + -0.524589683f, -0.851355193f, + -0.514102744f, -0.857728610f, + -0.503538384f, -0.863972856f, + -0.492898192f, -0.870086991f, + -0.482183772f, -0.876070094f, + -0.471396737f, -0.881921264f, + -0.460538711f, -0.887639620f, + -0.449611330f, -0.893224301f, + -0.438616239f, -0.898674466f, + -0.427555093f, -0.903989293f, + -0.416429560f, -0.909167983f, + -0.405241314f, -0.914209756f, + -0.393992040f, -0.919113852f, + -0.382683432f, -0.923879533f, + -0.371317194f, -0.928506080f, + -0.359895037f, -0.932992799f, + -0.348418680f, -0.937339012f, + -0.336889853f, -0.941544065f, + -0.325310292f, -0.945607325f, + -0.313681740f, -0.949528181f, + -0.302005949f, -0.953306040f, + -0.290284677f, -0.956940336f, + -0.278519689f, -0.960430519f, + -0.266712757f, -0.963776066f, + -0.254865660f, -0.966976471f, + -0.242980180f, -0.970031253f, + -0.231058108f, -0.972939952f, + -0.219101240f, -0.975702130f, + -0.207111376f, -0.978317371f, + -0.195090322f, -0.980785280f, + -0.183039888f, -0.983105487f, + -0.170961889f, -0.985277642f, + -0.158858143f, -0.987301418f, + -0.146730474f, -0.989176510f, + -0.134580709f, -0.990902635f, + -0.122410675f, -0.992479535f, + -0.110222207f, -0.993906970f, + -0.098017140f, -0.995184727f, + -0.085797312f, -0.996312612f, + -0.073564564f, -0.997290457f, + -0.061320736f, -0.998118113f, + -0.049067674f, -0.998795456f, + -0.036807223f, -0.999322385f, + -0.024541229f, -0.999698819f, + -0.012271538f, -0.999924702f, + -0.000000000f, -1.000000000f, + 0.012271538f, -0.999924702f, + 0.024541229f, -0.999698819f, + 0.036807223f, -0.999322385f, + 0.049067674f, -0.998795456f, + 0.061320736f, -0.998118113f, + 0.073564564f, -0.997290457f, + 0.085797312f, -0.996312612f, + 0.098017140f, -0.995184727f, + 0.110222207f, -0.993906970f, + 0.122410675f, -0.992479535f, + 0.134580709f, -0.990902635f, + 0.146730474f, -0.989176510f, + 0.158858143f, -0.987301418f, + 0.170961889f, -0.985277642f, + 0.183039888f, -0.983105487f, + 0.195090322f, -0.980785280f, + 0.207111376f, -0.978317371f, + 0.219101240f, -0.975702130f, + 0.231058108f, -0.972939952f, + 0.242980180f, -0.970031253f, + 0.254865660f, -0.966976471f, + 0.266712757f, -0.963776066f, + 0.278519689f, -0.960430519f, + 0.290284677f, -0.956940336f, + 0.302005949f, -0.953306040f, + 0.313681740f, -0.949528181f, + 0.325310292f, -0.945607325f, + 0.336889853f, -0.941544065f, + 0.348418680f, -0.937339012f, + 0.359895037f, -0.932992799f, + 0.371317194f, -0.928506080f, + 0.382683432f, -0.923879533f, + 0.393992040f, -0.919113852f, + 0.405241314f, -0.914209756f, + 0.416429560f, -0.909167983f, + 0.427555093f, -0.903989293f, + 0.438616239f, -0.898674466f, + 0.449611330f, -0.893224301f, + 0.460538711f, -0.887639620f, + 0.471396737f, -0.881921264f, + 0.482183772f, -0.876070094f, + 0.492898192f, -0.870086991f, + 0.503538384f, -0.863972856f, + 0.514102744f, -0.857728610f, + 0.524589683f, -0.851355193f, + 0.534997620f, -0.844853565f, + 0.545324988f, -0.838224706f, + 0.555570233f, -0.831469612f, + 0.565731811f, -0.824589303f, + 0.575808191f, -0.817584813f, + 0.585797857f, -0.810457198f, + 0.595699304f, -0.803207531f, + 0.605511041f, -0.795836905f, + 0.615231591f, -0.788346428f, + 0.624859488f, -0.780737229f, + 0.634393284f, -0.773010453f, + 0.643831543f, -0.765167266f, + 0.653172843f, -0.757208847f, + 0.662415778f, -0.749136395f, + 0.671558955f, -0.740951125f, + 0.680600998f, -0.732654272f, + 0.689540545f, -0.724247083f, + 0.698376249f, -0.715730825f, + 0.707106781f, -0.707106781f, + 0.715730825f, -0.698376249f, + 0.724247083f, -0.689540545f, + 0.732654272f, -0.680600998f, + 0.740951125f, -0.671558955f, + 0.749136395f, -0.662415778f, + 0.757208847f, -0.653172843f, + 0.765167266f, -0.643831543f, + 0.773010453f, -0.634393284f, + 0.780737229f, -0.624859488f, + 0.788346428f, -0.615231591f, + 0.795836905f, -0.605511041f, + 0.803207531f, -0.595699304f, + 0.810457198f, -0.585797857f, + 0.817584813f, -0.575808191f, + 0.824589303f, -0.565731811f, + 0.831469612f, -0.555570233f, + 0.838224706f, -0.545324988f, + 0.844853565f, -0.534997620f, + 0.851355193f, -0.524589683f, + 0.857728610f, -0.514102744f, + 0.863972856f, -0.503538384f, + 0.870086991f, -0.492898192f, + 0.876070094f, -0.482183772f, + 0.881921264f, -0.471396737f, + 0.887639620f, -0.460538711f, + 0.893224301f, -0.449611330f, + 0.898674466f, -0.438616239f, + 0.903989293f, -0.427555093f, + 0.909167983f, -0.416429560f, + 0.914209756f, -0.405241314f, + 0.919113852f, -0.393992040f, + 0.923879533f, -0.382683432f, + 0.928506080f, -0.371317194f, + 0.932992799f, -0.359895037f, + 0.937339012f, -0.348418680f, + 0.941544065f, -0.336889853f, + 0.945607325f, -0.325310292f, + 0.949528181f, -0.313681740f, + 0.953306040f, -0.302005949f, + 0.956940336f, -0.290284677f, + 0.960430519f, -0.278519689f, + 0.963776066f, -0.266712757f, + 0.966976471f, -0.254865660f, + 0.970031253f, -0.242980180f, + 0.972939952f, -0.231058108f, + 0.975702130f, -0.219101240f, + 0.978317371f, -0.207111376f, + 0.980785280f, -0.195090322f, + 0.983105487f, -0.183039888f, + 0.985277642f, -0.170961889f, + 0.987301418f, -0.158858143f, + 0.989176510f, -0.146730474f, + 0.990902635f, -0.134580709f, + 0.992479535f, -0.122410675f, + 0.993906970f, -0.110222207f, + 0.995184727f, -0.098017140f, + 0.996312612f, -0.085797312f, + 0.997290457f, -0.073564564f, + 0.998118113f, -0.061320736f, + 0.998795456f, -0.049067674f, + 0.999322385f, -0.036807223f, + 0.999698819f, -0.024541229f, + 0.999924702f, -0.012271538f +}; +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 1024 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_1024[2048] = { + 1.000000000f, 0.000000000f, + 0.999981175f, 0.006135885f, + 0.999924702f, 0.012271538f, + 0.999830582f, 0.018406730f, + 0.999698819f, 0.024541229f, + 0.999529418f, 0.030674803f, + 0.999322385f, 0.036807223f, + 0.999077728f, 0.042938257f, + 0.998795456f, 0.049067674f, + 0.998475581f, 0.055195244f, + 0.998118113f, 0.061320736f, + 0.997723067f, 0.067443920f, + 0.997290457f, 0.073564564f, + 0.996820299f, 0.079682438f, + 0.996312612f, 0.085797312f, + 0.995767414f, 0.091908956f, + 0.995184727f, 0.098017140f, + 0.994564571f, 0.104121634f, + 0.993906970f, 0.110222207f, + 0.993211949f, 0.116318631f, + 0.992479535f, 0.122410675f, + 0.991709754f, 0.128498111f, + 0.990902635f, 0.134580709f, + 0.990058210f, 0.140658239f, + 0.989176510f, 0.146730474f, + 0.988257568f, 0.152797185f, + 0.987301418f, 0.158858143f, + 0.986308097f, 0.164913120f, + 0.985277642f, 0.170961889f, + 0.984210092f, 0.177004220f, + 0.983105487f, 0.183039888f, + 0.981963869f, 0.189068664f, + 0.980785280f, 0.195090322f, + 0.979569766f, 0.201104635f, + 0.978317371f, 0.207111376f, + 0.977028143f, 0.213110320f, + 0.975702130f, 0.219101240f, + 0.974339383f, 0.225083911f, + 0.972939952f, 0.231058108f, + 0.971503891f, 0.237023606f, + 0.970031253f, 0.242980180f, + 0.968522094f, 0.248927606f, + 0.966976471f, 0.254865660f, + 0.965394442f, 0.260794118f, + 0.963776066f, 0.266712757f, + 0.962121404f, 0.272621355f, + 0.960430519f, 0.278519689f, + 0.958703475f, 0.284407537f, + 0.956940336f, 0.290284677f, + 0.955141168f, 0.296150888f, + 0.953306040f, 0.302005949f, + 0.951435021f, 0.307849640f, + 0.949528181f, 0.313681740f, + 0.947585591f, 0.319502031f, + 0.945607325f, 0.325310292f, + 0.943593458f, 0.331106306f, + 0.941544065f, 0.336889853f, + 0.939459224f, 0.342660717f, + 0.937339012f, 0.348418680f, + 0.935183510f, 0.354163525f, + 0.932992799f, 0.359895037f, + 0.930766961f, 0.365612998f, + 0.928506080f, 0.371317194f, + 0.926210242f, 0.377007410f, + 0.923879533f, 0.382683432f, + 0.921514039f, 0.388345047f, + 0.919113852f, 0.393992040f, + 0.916679060f, 0.399624200f, + 0.914209756f, 0.405241314f, + 0.911706032f, 0.410843171f, + 0.909167983f, 0.416429560f, + 0.906595705f, 0.422000271f, + 0.903989293f, 0.427555093f, + 0.901348847f, 0.433093819f, + 0.898674466f, 0.438616239f, + 0.895966250f, 0.444122145f, + 0.893224301f, 0.449611330f, + 0.890448723f, 0.455083587f, + 0.887639620f, 0.460538711f, + 0.884797098f, 0.465976496f, + 0.881921264f, 0.471396737f, + 0.879012226f, 0.476799230f, + 0.876070094f, 0.482183772f, + 0.873094978f, 0.487550160f, + 0.870086991f, 0.492898192f, + 0.867046246f, 0.498227667f, + 0.863972856f, 0.503538384f, + 0.860866939f, 0.508830143f, + 0.857728610f, 0.514102744f, + 0.854557988f, 0.519355990f, + 0.851355193f, 0.524589683f, + 0.848120345f, 0.529803625f, + 0.844853565f, 0.534997620f, + 0.841554977f, 0.540171473f, + 0.838224706f, 0.545324988f, + 0.834862875f, 0.550457973f, + 0.831469612f, 0.555570233f, + 0.828045045f, 0.560661576f, + 0.824589303f, 0.565731811f, + 0.821102515f, 0.570780746f, + 0.817584813f, 0.575808191f, + 0.814036330f, 0.580813958f, + 0.810457198f, 0.585797857f, + 0.806847554f, 0.590759702f, + 0.803207531f, 0.595699304f, + 0.799537269f, 0.600616479f, + 0.795836905f, 0.605511041f, + 0.792106577f, 0.610382806f, + 0.788346428f, 0.615231591f, + 0.784556597f, 0.620057212f, + 0.780737229f, 0.624859488f, + 0.776888466f, 0.629638239f, + 0.773010453f, 0.634393284f, + 0.769103338f, 0.639124445f, + 0.765167266f, 0.643831543f, + 0.761202385f, 0.648514401f, + 0.757208847f, 0.653172843f, + 0.753186799f, 0.657806693f, + 0.749136395f, 0.662415778f, + 0.745057785f, 0.666999922f, + 0.740951125f, 0.671558955f, + 0.736816569f, 0.676092704f, + 0.732654272f, 0.680600998f, + 0.728464390f, 0.685083668f, + 0.724247083f, 0.689540545f, + 0.720002508f, 0.693971461f, + 0.715730825f, 0.698376249f, + 0.711432196f, 0.702754744f, + 0.707106781f, 0.707106781f, + 0.702754744f, 0.711432196f, + 0.698376249f, 0.715730825f, + 0.693971461f, 0.720002508f, + 0.689540545f, 0.724247083f, + 0.685083668f, 0.728464390f, + 0.680600998f, 0.732654272f, + 0.676092704f, 0.736816569f, + 0.671558955f, 0.740951125f, + 0.666999922f, 0.745057785f, + 0.662415778f, 0.749136395f, + 0.657806693f, 0.753186799f, + 0.653172843f, 0.757208847f, + 0.648514401f, 0.761202385f, + 0.643831543f, 0.765167266f, + 0.639124445f, 0.769103338f, + 0.634393284f, 0.773010453f, + 0.629638239f, 0.776888466f, + 0.624859488f, 0.780737229f, + 0.620057212f, 0.784556597f, + 0.615231591f, 0.788346428f, + 0.610382806f, 0.792106577f, + 0.605511041f, 0.795836905f, + 0.600616479f, 0.799537269f, + 0.595699304f, 0.803207531f, + 0.590759702f, 0.806847554f, + 0.585797857f, 0.810457198f, + 0.580813958f, 0.814036330f, + 0.575808191f, 0.817584813f, + 0.570780746f, 0.821102515f, + 0.565731811f, 0.824589303f, + 0.560661576f, 0.828045045f, + 0.555570233f, 0.831469612f, + 0.550457973f, 0.834862875f, + 0.545324988f, 0.838224706f, + 0.540171473f, 0.841554977f, + 0.534997620f, 0.844853565f, + 0.529803625f, 0.848120345f, + 0.524589683f, 0.851355193f, + 0.519355990f, 0.854557988f, + 0.514102744f, 0.857728610f, + 0.508830143f, 0.860866939f, + 0.503538384f, 0.863972856f, + 0.498227667f, 0.867046246f, + 0.492898192f, 0.870086991f, + 0.487550160f, 0.873094978f, + 0.482183772f, 0.876070094f, + 0.476799230f, 0.879012226f, + 0.471396737f, 0.881921264f, + 0.465976496f, 0.884797098f, + 0.460538711f, 0.887639620f, + 0.455083587f, 0.890448723f, + 0.449611330f, 0.893224301f, + 0.444122145f, 0.895966250f, + 0.438616239f, 0.898674466f, + 0.433093819f, 0.901348847f, + 0.427555093f, 0.903989293f, + 0.422000271f, 0.906595705f, + 0.416429560f, 0.909167983f, + 0.410843171f, 0.911706032f, + 0.405241314f, 0.914209756f, + 0.399624200f, 0.916679060f, + 0.393992040f, 0.919113852f, + 0.388345047f, 0.921514039f, + 0.382683432f, 0.923879533f, + 0.377007410f, 0.926210242f, + 0.371317194f, 0.928506080f, + 0.365612998f, 0.930766961f, + 0.359895037f, 0.932992799f, + 0.354163525f, 0.935183510f, + 0.348418680f, 0.937339012f, + 0.342660717f, 0.939459224f, + 0.336889853f, 0.941544065f, + 0.331106306f, 0.943593458f, + 0.325310292f, 0.945607325f, + 0.319502031f, 0.947585591f, + 0.313681740f, 0.949528181f, + 0.307849640f, 0.951435021f, + 0.302005949f, 0.953306040f, + 0.296150888f, 0.955141168f, + 0.290284677f, 0.956940336f, + 0.284407537f, 0.958703475f, + 0.278519689f, 0.960430519f, + 0.272621355f, 0.962121404f, + 0.266712757f, 0.963776066f, + 0.260794118f, 0.965394442f, + 0.254865660f, 0.966976471f, + 0.248927606f, 0.968522094f, + 0.242980180f, 0.970031253f, + 0.237023606f, 0.971503891f, + 0.231058108f, 0.972939952f, + 0.225083911f, 0.974339383f, + 0.219101240f, 0.975702130f, + 0.213110320f, 0.977028143f, + 0.207111376f, 0.978317371f, + 0.201104635f, 0.979569766f, + 0.195090322f, 0.980785280f, + 0.189068664f, 0.981963869f, + 0.183039888f, 0.983105487f, + 0.177004220f, 0.984210092f, + 0.170961889f, 0.985277642f, + 0.164913120f, 0.986308097f, + 0.158858143f, 0.987301418f, + 0.152797185f, 0.988257568f, + 0.146730474f, 0.989176510f, + 0.140658239f, 0.990058210f, + 0.134580709f, 0.990902635f, + 0.128498111f, 0.991709754f, + 0.122410675f, 0.992479535f, + 0.116318631f, 0.993211949f, + 0.110222207f, 0.993906970f, + 0.104121634f, 0.994564571f, + 0.098017140f, 0.995184727f, + 0.091908956f, 0.995767414f, + 0.085797312f, 0.996312612f, + 0.079682438f, 0.996820299f, + 0.073564564f, 0.997290457f, + 0.067443920f, 0.997723067f, + 0.061320736f, 0.998118113f, + 0.055195244f, 0.998475581f, + 0.049067674f, 0.998795456f, + 0.042938257f, 0.999077728f, + 0.036807223f, 0.999322385f, + 0.030674803f, 0.999529418f, + 0.024541229f, 0.999698819f, + 0.018406730f, 0.999830582f, + 0.012271538f, 0.999924702f, + 0.006135885f, 0.999981175f, + 0.000000000f, 1.000000000f, + -0.006135885f, 0.999981175f, + -0.012271538f, 0.999924702f, + -0.018406730f, 0.999830582f, + -0.024541229f, 0.999698819f, + -0.030674803f, 0.999529418f, + -0.036807223f, 0.999322385f, + -0.042938257f, 0.999077728f, + -0.049067674f, 0.998795456f, + -0.055195244f, 0.998475581f, + -0.061320736f, 0.998118113f, + -0.067443920f, 0.997723067f, + -0.073564564f, 0.997290457f, + -0.079682438f, 0.996820299f, + -0.085797312f, 0.996312612f, + -0.091908956f, 0.995767414f, + -0.098017140f, 0.995184727f, + -0.104121634f, 0.994564571f, + -0.110222207f, 0.993906970f, + -0.116318631f, 0.993211949f, + -0.122410675f, 0.992479535f, + -0.128498111f, 0.991709754f, + -0.134580709f, 0.990902635f, + -0.140658239f, 0.990058210f, + -0.146730474f, 0.989176510f, + -0.152797185f, 0.988257568f, + -0.158858143f, 0.987301418f, + -0.164913120f, 0.986308097f, + -0.170961889f, 0.985277642f, + -0.177004220f, 0.984210092f, + -0.183039888f, 0.983105487f, + -0.189068664f, 0.981963869f, + -0.195090322f, 0.980785280f, + -0.201104635f, 0.979569766f, + -0.207111376f, 0.978317371f, + -0.213110320f, 0.977028143f, + -0.219101240f, 0.975702130f, + -0.225083911f, 0.974339383f, + -0.231058108f, 0.972939952f, + -0.237023606f, 0.971503891f, + -0.242980180f, 0.970031253f, + -0.248927606f, 0.968522094f, + -0.254865660f, 0.966976471f, + -0.260794118f, 0.965394442f, + -0.266712757f, 0.963776066f, + -0.272621355f, 0.962121404f, + -0.278519689f, 0.960430519f, + -0.284407537f, 0.958703475f, + -0.290284677f, 0.956940336f, + -0.296150888f, 0.955141168f, + -0.302005949f, 0.953306040f, + -0.307849640f, 0.951435021f, + -0.313681740f, 0.949528181f, + -0.319502031f, 0.947585591f, + -0.325310292f, 0.945607325f, + -0.331106306f, 0.943593458f, + -0.336889853f, 0.941544065f, + -0.342660717f, 0.939459224f, + -0.348418680f, 0.937339012f, + -0.354163525f, 0.935183510f, + -0.359895037f, 0.932992799f, + -0.365612998f, 0.930766961f, + -0.371317194f, 0.928506080f, + -0.377007410f, 0.926210242f, + -0.382683432f, 0.923879533f, + -0.388345047f, 0.921514039f, + -0.393992040f, 0.919113852f, + -0.399624200f, 0.916679060f, + -0.405241314f, 0.914209756f, + -0.410843171f, 0.911706032f, + -0.416429560f, 0.909167983f, + -0.422000271f, 0.906595705f, + -0.427555093f, 0.903989293f, + -0.433093819f, 0.901348847f, + -0.438616239f, 0.898674466f, + -0.444122145f, 0.895966250f, + -0.449611330f, 0.893224301f, + -0.455083587f, 0.890448723f, + -0.460538711f, 0.887639620f, + -0.465976496f, 0.884797098f, + -0.471396737f, 0.881921264f, + -0.476799230f, 0.879012226f, + -0.482183772f, 0.876070094f, + -0.487550160f, 0.873094978f, + -0.492898192f, 0.870086991f, + -0.498227667f, 0.867046246f, + -0.503538384f, 0.863972856f, + -0.508830143f, 0.860866939f, + -0.514102744f, 0.857728610f, + -0.519355990f, 0.854557988f, + -0.524589683f, 0.851355193f, + -0.529803625f, 0.848120345f, + -0.534997620f, 0.844853565f, + -0.540171473f, 0.841554977f, + -0.545324988f, 0.838224706f, + -0.550457973f, 0.834862875f, + -0.555570233f, 0.831469612f, + -0.560661576f, 0.828045045f, + -0.565731811f, 0.824589303f, + -0.570780746f, 0.821102515f, + -0.575808191f, 0.817584813f, + -0.580813958f, 0.814036330f, + -0.585797857f, 0.810457198f, + -0.590759702f, 0.806847554f, + -0.595699304f, 0.803207531f, + -0.600616479f, 0.799537269f, + -0.605511041f, 0.795836905f, + -0.610382806f, 0.792106577f, + -0.615231591f, 0.788346428f, + -0.620057212f, 0.784556597f, + -0.624859488f, 0.780737229f, + -0.629638239f, 0.776888466f, + -0.634393284f, 0.773010453f, + -0.639124445f, 0.769103338f, + -0.643831543f, 0.765167266f, + -0.648514401f, 0.761202385f, + -0.653172843f, 0.757208847f, + -0.657806693f, 0.753186799f, + -0.662415778f, 0.749136395f, + -0.666999922f, 0.745057785f, + -0.671558955f, 0.740951125f, + -0.676092704f, 0.736816569f, + -0.680600998f, 0.732654272f, + -0.685083668f, 0.728464390f, + -0.689540545f, 0.724247083f, + -0.693971461f, 0.720002508f, + -0.698376249f, 0.715730825f, + -0.702754744f, 0.711432196f, + -0.707106781f, 0.707106781f, + -0.711432196f, 0.702754744f, + -0.715730825f, 0.698376249f, + -0.720002508f, 0.693971461f, + -0.724247083f, 0.689540545f, + -0.728464390f, 0.685083668f, + -0.732654272f, 0.680600998f, + -0.736816569f, 0.676092704f, + -0.740951125f, 0.671558955f, + -0.745057785f, 0.666999922f, + -0.749136395f, 0.662415778f, + -0.753186799f, 0.657806693f, + -0.757208847f, 0.653172843f, + -0.761202385f, 0.648514401f, + -0.765167266f, 0.643831543f, + -0.769103338f, 0.639124445f, + -0.773010453f, 0.634393284f, + -0.776888466f, 0.629638239f, + -0.780737229f, 0.624859488f, + -0.784556597f, 0.620057212f, + -0.788346428f, 0.615231591f, + -0.792106577f, 0.610382806f, + -0.795836905f, 0.605511041f, + -0.799537269f, 0.600616479f, + -0.803207531f, 0.595699304f, + -0.806847554f, 0.590759702f, + -0.810457198f, 0.585797857f, + -0.814036330f, 0.580813958f, + -0.817584813f, 0.575808191f, + -0.821102515f, 0.570780746f, + -0.824589303f, 0.565731811f, + -0.828045045f, 0.560661576f, + -0.831469612f, 0.555570233f, + -0.834862875f, 0.550457973f, + -0.838224706f, 0.545324988f, + -0.841554977f, 0.540171473f, + -0.844853565f, 0.534997620f, + -0.848120345f, 0.529803625f, + -0.851355193f, 0.524589683f, + -0.854557988f, 0.519355990f, + -0.857728610f, 0.514102744f, + -0.860866939f, 0.508830143f, + -0.863972856f, 0.503538384f, + -0.867046246f, 0.498227667f, + -0.870086991f, 0.492898192f, + -0.873094978f, 0.487550160f, + -0.876070094f, 0.482183772f, + -0.879012226f, 0.476799230f, + -0.881921264f, 0.471396737f, + -0.884797098f, 0.465976496f, + -0.887639620f, 0.460538711f, + -0.890448723f, 0.455083587f, + -0.893224301f, 0.449611330f, + -0.895966250f, 0.444122145f, + -0.898674466f, 0.438616239f, + -0.901348847f, 0.433093819f, + -0.903989293f, 0.427555093f, + -0.906595705f, 0.422000271f, + -0.909167983f, 0.416429560f, + -0.911706032f, 0.410843171f, + -0.914209756f, 0.405241314f, + -0.916679060f, 0.399624200f, + -0.919113852f, 0.393992040f, + -0.921514039f, 0.388345047f, + -0.923879533f, 0.382683432f, + -0.926210242f, 0.377007410f, + -0.928506080f, 0.371317194f, + -0.930766961f, 0.365612998f, + -0.932992799f, 0.359895037f, + -0.935183510f, 0.354163525f, + -0.937339012f, 0.348418680f, + -0.939459224f, 0.342660717f, + -0.941544065f, 0.336889853f, + -0.943593458f, 0.331106306f, + -0.945607325f, 0.325310292f, + -0.947585591f, 0.319502031f, + -0.949528181f, 0.313681740f, + -0.951435021f, 0.307849640f, + -0.953306040f, 0.302005949f, + -0.955141168f, 0.296150888f, + -0.956940336f, 0.290284677f, + -0.958703475f, 0.284407537f, + -0.960430519f, 0.278519689f, + -0.962121404f, 0.272621355f, + -0.963776066f, 0.266712757f, + -0.965394442f, 0.260794118f, + -0.966976471f, 0.254865660f, + -0.968522094f, 0.248927606f, + -0.970031253f, 0.242980180f, + -0.971503891f, 0.237023606f, + -0.972939952f, 0.231058108f, + -0.974339383f, 0.225083911f, + -0.975702130f, 0.219101240f, + -0.977028143f, 0.213110320f, + -0.978317371f, 0.207111376f, + -0.979569766f, 0.201104635f, + -0.980785280f, 0.195090322f, + -0.981963869f, 0.189068664f, + -0.983105487f, 0.183039888f, + -0.984210092f, 0.177004220f, + -0.985277642f, 0.170961889f, + -0.986308097f, 0.164913120f, + -0.987301418f, 0.158858143f, + -0.988257568f, 0.152797185f, + -0.989176510f, 0.146730474f, + -0.990058210f, 0.140658239f, + -0.990902635f, 0.134580709f, + -0.991709754f, 0.128498111f, + -0.992479535f, 0.122410675f, + -0.993211949f, 0.116318631f, + -0.993906970f, 0.110222207f, + -0.994564571f, 0.104121634f, + -0.995184727f, 0.098017140f, + -0.995767414f, 0.091908956f, + -0.996312612f, 0.085797312f, + -0.996820299f, 0.079682438f, + -0.997290457f, 0.073564564f, + -0.997723067f, 0.067443920f, + -0.998118113f, 0.061320736f, + -0.998475581f, 0.055195244f, + -0.998795456f, 0.049067674f, + -0.999077728f, 0.042938257f, + -0.999322385f, 0.036807223f, + -0.999529418f, 0.030674803f, + -0.999698819f, 0.024541229f, + -0.999830582f, 0.018406730f, + -0.999924702f, 0.012271538f, + -0.999981175f, 0.006135885f, + -1.000000000f, 0.000000000f, + -0.999981175f, -0.006135885f, + -0.999924702f, -0.012271538f, + -0.999830582f, -0.018406730f, + -0.999698819f, -0.024541229f, + -0.999529418f, -0.030674803f, + -0.999322385f, -0.036807223f, + -0.999077728f, -0.042938257f, + -0.998795456f, -0.049067674f, + -0.998475581f, -0.055195244f, + -0.998118113f, -0.061320736f, + -0.997723067f, -0.067443920f, + -0.997290457f, -0.073564564f, + -0.996820299f, -0.079682438f, + -0.996312612f, -0.085797312f, + -0.995767414f, -0.091908956f, + -0.995184727f, -0.098017140f, + -0.994564571f, -0.104121634f, + -0.993906970f, -0.110222207f, + -0.993211949f, -0.116318631f, + -0.992479535f, -0.122410675f, + -0.991709754f, -0.128498111f, + -0.990902635f, -0.134580709f, + -0.990058210f, -0.140658239f, + -0.989176510f, -0.146730474f, + -0.988257568f, -0.152797185f, + -0.987301418f, -0.158858143f, + -0.986308097f, -0.164913120f, + -0.985277642f, -0.170961889f, + -0.984210092f, -0.177004220f, + -0.983105487f, -0.183039888f, + -0.981963869f, -0.189068664f, + -0.980785280f, -0.195090322f, + -0.979569766f, -0.201104635f, + -0.978317371f, -0.207111376f, + -0.977028143f, -0.213110320f, + -0.975702130f, -0.219101240f, + -0.974339383f, -0.225083911f, + -0.972939952f, -0.231058108f, + -0.971503891f, -0.237023606f, + -0.970031253f, -0.242980180f, + -0.968522094f, -0.248927606f, + -0.966976471f, -0.254865660f, + -0.965394442f, -0.260794118f, + -0.963776066f, -0.266712757f, + -0.962121404f, -0.272621355f, + -0.960430519f, -0.278519689f, + -0.958703475f, -0.284407537f, + -0.956940336f, -0.290284677f, + -0.955141168f, -0.296150888f, + -0.953306040f, -0.302005949f, + -0.951435021f, -0.307849640f, + -0.949528181f, -0.313681740f, + -0.947585591f, -0.319502031f, + -0.945607325f, -0.325310292f, + -0.943593458f, -0.331106306f, + -0.941544065f, -0.336889853f, + -0.939459224f, -0.342660717f, + -0.937339012f, -0.348418680f, + -0.935183510f, -0.354163525f, + -0.932992799f, -0.359895037f, + -0.930766961f, -0.365612998f, + -0.928506080f, -0.371317194f, + -0.926210242f, -0.377007410f, + -0.923879533f, -0.382683432f, + -0.921514039f, -0.388345047f, + -0.919113852f, -0.393992040f, + -0.916679060f, -0.399624200f, + -0.914209756f, -0.405241314f, + -0.911706032f, -0.410843171f, + -0.909167983f, -0.416429560f, + -0.906595705f, -0.422000271f, + -0.903989293f, -0.427555093f, + -0.901348847f, -0.433093819f, + -0.898674466f, -0.438616239f, + -0.895966250f, -0.444122145f, + -0.893224301f, -0.449611330f, + -0.890448723f, -0.455083587f, + -0.887639620f, -0.460538711f, + -0.884797098f, -0.465976496f, + -0.881921264f, -0.471396737f, + -0.879012226f, -0.476799230f, + -0.876070094f, -0.482183772f, + -0.873094978f, -0.487550160f, + -0.870086991f, -0.492898192f, + -0.867046246f, -0.498227667f, + -0.863972856f, -0.503538384f, + -0.860866939f, -0.508830143f, + -0.857728610f, -0.514102744f, + -0.854557988f, -0.519355990f, + -0.851355193f, -0.524589683f, + -0.848120345f, -0.529803625f, + -0.844853565f, -0.534997620f, + -0.841554977f, -0.540171473f, + -0.838224706f, -0.545324988f, + -0.834862875f, -0.550457973f, + -0.831469612f, -0.555570233f, + -0.828045045f, -0.560661576f, + -0.824589303f, -0.565731811f, + -0.821102515f, -0.570780746f, + -0.817584813f, -0.575808191f, + -0.814036330f, -0.580813958f, + -0.810457198f, -0.585797857f, + -0.806847554f, -0.590759702f, + -0.803207531f, -0.595699304f, + -0.799537269f, -0.600616479f, + -0.795836905f, -0.605511041f, + -0.792106577f, -0.610382806f, + -0.788346428f, -0.615231591f, + -0.784556597f, -0.620057212f, + -0.780737229f, -0.624859488f, + -0.776888466f, -0.629638239f, + -0.773010453f, -0.634393284f, + -0.769103338f, -0.639124445f, + -0.765167266f, -0.643831543f, + -0.761202385f, -0.648514401f, + -0.757208847f, -0.653172843f, + -0.753186799f, -0.657806693f, + -0.749136395f, -0.662415778f, + -0.745057785f, -0.666999922f, + -0.740951125f, -0.671558955f, + -0.736816569f, -0.676092704f, + -0.732654272f, -0.680600998f, + -0.728464390f, -0.685083668f, + -0.724247083f, -0.689540545f, + -0.720002508f, -0.693971461f, + -0.715730825f, -0.698376249f, + -0.711432196f, -0.702754744f, + -0.707106781f, -0.707106781f, + -0.702754744f, -0.711432196f, + -0.698376249f, -0.715730825f, + -0.693971461f, -0.720002508f, + -0.689540545f, -0.724247083f, + -0.685083668f, -0.728464390f, + -0.680600998f, -0.732654272f, + -0.676092704f, -0.736816569f, + -0.671558955f, -0.740951125f, + -0.666999922f, -0.745057785f, + -0.662415778f, -0.749136395f, + -0.657806693f, -0.753186799f, + -0.653172843f, -0.757208847f, + -0.648514401f, -0.761202385f, + -0.643831543f, -0.765167266f, + -0.639124445f, -0.769103338f, + -0.634393284f, -0.773010453f, + -0.629638239f, -0.776888466f, + -0.624859488f, -0.780737229f, + -0.620057212f, -0.784556597f, + -0.615231591f, -0.788346428f, + -0.610382806f, -0.792106577f, + -0.605511041f, -0.795836905f, + -0.600616479f, -0.799537269f, + -0.595699304f, -0.803207531f, + -0.590759702f, -0.806847554f, + -0.585797857f, -0.810457198f, + -0.580813958f, -0.814036330f, + -0.575808191f, -0.817584813f, + -0.570780746f, -0.821102515f, + -0.565731811f, -0.824589303f, + -0.560661576f, -0.828045045f, + -0.555570233f, -0.831469612f, + -0.550457973f, -0.834862875f, + -0.545324988f, -0.838224706f, + -0.540171473f, -0.841554977f, + -0.534997620f, -0.844853565f, + -0.529803625f, -0.848120345f, + -0.524589683f, -0.851355193f, + -0.519355990f, -0.854557988f, + -0.514102744f, -0.857728610f, + -0.508830143f, -0.860866939f, + -0.503538384f, -0.863972856f, + -0.498227667f, -0.867046246f, + -0.492898192f, -0.870086991f, + -0.487550160f, -0.873094978f, + -0.482183772f, -0.876070094f, + -0.476799230f, -0.879012226f, + -0.471396737f, -0.881921264f, + -0.465976496f, -0.884797098f, + -0.460538711f, -0.887639620f, + -0.455083587f, -0.890448723f, + -0.449611330f, -0.893224301f, + -0.444122145f, -0.895966250f, + -0.438616239f, -0.898674466f, + -0.433093819f, -0.901348847f, + -0.427555093f, -0.903989293f, + -0.422000271f, -0.906595705f, + -0.416429560f, -0.909167983f, + -0.410843171f, -0.911706032f, + -0.405241314f, -0.914209756f, + -0.399624200f, -0.916679060f, + -0.393992040f, -0.919113852f, + -0.388345047f, -0.921514039f, + -0.382683432f, -0.923879533f, + -0.377007410f, -0.926210242f, + -0.371317194f, -0.928506080f, + -0.365612998f, -0.930766961f, + -0.359895037f, -0.932992799f, + -0.354163525f, -0.935183510f, + -0.348418680f, -0.937339012f, + -0.342660717f, -0.939459224f, + -0.336889853f, -0.941544065f, + -0.331106306f, -0.943593458f, + -0.325310292f, -0.945607325f, + -0.319502031f, -0.947585591f, + -0.313681740f, -0.949528181f, + -0.307849640f, -0.951435021f, + -0.302005949f, -0.953306040f, + -0.296150888f, -0.955141168f, + -0.290284677f, -0.956940336f, + -0.284407537f, -0.958703475f, + -0.278519689f, -0.960430519f, + -0.272621355f, -0.962121404f, + -0.266712757f, -0.963776066f, + -0.260794118f, -0.965394442f, + -0.254865660f, -0.966976471f, + -0.248927606f, -0.968522094f, + -0.242980180f, -0.970031253f, + -0.237023606f, -0.971503891f, + -0.231058108f, -0.972939952f, + -0.225083911f, -0.974339383f, + -0.219101240f, -0.975702130f, + -0.213110320f, -0.977028143f, + -0.207111376f, -0.978317371f, + -0.201104635f, -0.979569766f, + -0.195090322f, -0.980785280f, + -0.189068664f, -0.981963869f, + -0.183039888f, -0.983105487f, + -0.177004220f, -0.984210092f, + -0.170961889f, -0.985277642f, + -0.164913120f, -0.986308097f, + -0.158858143f, -0.987301418f, + -0.152797185f, -0.988257568f, + -0.146730474f, -0.989176510f, + -0.140658239f, -0.990058210f, + -0.134580709f, -0.990902635f, + -0.128498111f, -0.991709754f, + -0.122410675f, -0.992479535f, + -0.116318631f, -0.993211949f, + -0.110222207f, -0.993906970f, + -0.104121634f, -0.994564571f, + -0.098017140f, -0.995184727f, + -0.091908956f, -0.995767414f, + -0.085797312f, -0.996312612f, + -0.079682438f, -0.996820299f, + -0.073564564f, -0.997290457f, + -0.067443920f, -0.997723067f, + -0.061320736f, -0.998118113f, + -0.055195244f, -0.998475581f, + -0.049067674f, -0.998795456f, + -0.042938257f, -0.999077728f, + -0.036807223f, -0.999322385f, + -0.030674803f, -0.999529418f, + -0.024541229f, -0.999698819f, + -0.018406730f, -0.999830582f, + -0.012271538f, -0.999924702f, + -0.006135885f, -0.999981175f, + -0.000000000f, -1.000000000f, + 0.006135885f, -0.999981175f, + 0.012271538f, -0.999924702f, + 0.018406730f, -0.999830582f, + 0.024541229f, -0.999698819f, + 0.030674803f, -0.999529418f, + 0.036807223f, -0.999322385f, + 0.042938257f, -0.999077728f, + 0.049067674f, -0.998795456f, + 0.055195244f, -0.998475581f, + 0.061320736f, -0.998118113f, + 0.067443920f, -0.997723067f, + 0.073564564f, -0.997290457f, + 0.079682438f, -0.996820299f, + 0.085797312f, -0.996312612f, + 0.091908956f, -0.995767414f, + 0.098017140f, -0.995184727f, + 0.104121634f, -0.994564571f, + 0.110222207f, -0.993906970f, + 0.116318631f, -0.993211949f, + 0.122410675f, -0.992479535f, + 0.128498111f, -0.991709754f, + 0.134580709f, -0.990902635f, + 0.140658239f, -0.990058210f, + 0.146730474f, -0.989176510f, + 0.152797185f, -0.988257568f, + 0.158858143f, -0.987301418f, + 0.164913120f, -0.986308097f, + 0.170961889f, -0.985277642f, + 0.177004220f, -0.984210092f, + 0.183039888f, -0.983105487f, + 0.189068664f, -0.981963869f, + 0.195090322f, -0.980785280f, + 0.201104635f, -0.979569766f, + 0.207111376f, -0.978317371f, + 0.213110320f, -0.977028143f, + 0.219101240f, -0.975702130f, + 0.225083911f, -0.974339383f, + 0.231058108f, -0.972939952f, + 0.237023606f, -0.971503891f, + 0.242980180f, -0.970031253f, + 0.248927606f, -0.968522094f, + 0.254865660f, -0.966976471f, + 0.260794118f, -0.965394442f, + 0.266712757f, -0.963776066f, + 0.272621355f, -0.962121404f, + 0.278519689f, -0.960430519f, + 0.284407537f, -0.958703475f, + 0.290284677f, -0.956940336f, + 0.296150888f, -0.955141168f, + 0.302005949f, -0.953306040f, + 0.307849640f, -0.951435021f, + 0.313681740f, -0.949528181f, + 0.319502031f, -0.947585591f, + 0.325310292f, -0.945607325f, + 0.331106306f, -0.943593458f, + 0.336889853f, -0.941544065f, + 0.342660717f, -0.939459224f, + 0.348418680f, -0.937339012f, + 0.354163525f, -0.935183510f, + 0.359895037f, -0.932992799f, + 0.365612998f, -0.930766961f, + 0.371317194f, -0.928506080f, + 0.377007410f, -0.926210242f, + 0.382683432f, -0.923879533f, + 0.388345047f, -0.921514039f, + 0.393992040f, -0.919113852f, + 0.399624200f, -0.916679060f, + 0.405241314f, -0.914209756f, + 0.410843171f, -0.911706032f, + 0.416429560f, -0.909167983f, + 0.422000271f, -0.906595705f, + 0.427555093f, -0.903989293f, + 0.433093819f, -0.901348847f, + 0.438616239f, -0.898674466f, + 0.444122145f, -0.895966250f, + 0.449611330f, -0.893224301f, + 0.455083587f, -0.890448723f, + 0.460538711f, -0.887639620f, + 0.465976496f, -0.884797098f, + 0.471396737f, -0.881921264f, + 0.476799230f, -0.879012226f, + 0.482183772f, -0.876070094f, + 0.487550160f, -0.873094978f, + 0.492898192f, -0.870086991f, + 0.498227667f, -0.867046246f, + 0.503538384f, -0.863972856f, + 0.508830143f, -0.860866939f, + 0.514102744f, -0.857728610f, + 0.519355990f, -0.854557988f, + 0.524589683f, -0.851355193f, + 0.529803625f, -0.848120345f, + 0.534997620f, -0.844853565f, + 0.540171473f, -0.841554977f, + 0.545324988f, -0.838224706f, + 0.550457973f, -0.834862875f, + 0.555570233f, -0.831469612f, + 0.560661576f, -0.828045045f, + 0.565731811f, -0.824589303f, + 0.570780746f, -0.821102515f, + 0.575808191f, -0.817584813f, + 0.580813958f, -0.814036330f, + 0.585797857f, -0.810457198f, + 0.590759702f, -0.806847554f, + 0.595699304f, -0.803207531f, + 0.600616479f, -0.799537269f, + 0.605511041f, -0.795836905f, + 0.610382806f, -0.792106577f, + 0.615231591f, -0.788346428f, + 0.620057212f, -0.784556597f, + 0.624859488f, -0.780737229f, + 0.629638239f, -0.776888466f, + 0.634393284f, -0.773010453f, + 0.639124445f, -0.769103338f, + 0.643831543f, -0.765167266f, + 0.648514401f, -0.761202385f, + 0.653172843f, -0.757208847f, + 0.657806693f, -0.753186799f, + 0.662415778f, -0.749136395f, + 0.666999922f, -0.745057785f, + 0.671558955f, -0.740951125f, + 0.676092704f, -0.736816569f, + 0.680600998f, -0.732654272f, + 0.685083668f, -0.728464390f, + 0.689540545f, -0.724247083f, + 0.693971461f, -0.720002508f, + 0.698376249f, -0.715730825f, + 0.702754744f, -0.711432196f, + 0.707106781f, -0.707106781f, + 0.711432196f, -0.702754744f, + 0.715730825f, -0.698376249f, + 0.720002508f, -0.693971461f, + 0.724247083f, -0.689540545f, + 0.728464390f, -0.685083668f, + 0.732654272f, -0.680600998f, + 0.736816569f, -0.676092704f, + 0.740951125f, -0.671558955f, + 0.745057785f, -0.666999922f, + 0.749136395f, -0.662415778f, + 0.753186799f, -0.657806693f, + 0.757208847f, -0.653172843f, + 0.761202385f, -0.648514401f, + 0.765167266f, -0.643831543f, + 0.769103338f, -0.639124445f, + 0.773010453f, -0.634393284f, + 0.776888466f, -0.629638239f, + 0.780737229f, -0.624859488f, + 0.784556597f, -0.620057212f, + 0.788346428f, -0.615231591f, + 0.792106577f, -0.610382806f, + 0.795836905f, -0.605511041f, + 0.799537269f, -0.600616479f, + 0.803207531f, -0.595699304f, + 0.806847554f, -0.590759702f, + 0.810457198f, -0.585797857f, + 0.814036330f, -0.580813958f, + 0.817584813f, -0.575808191f, + 0.821102515f, -0.570780746f, + 0.824589303f, -0.565731811f, + 0.828045045f, -0.560661576f, + 0.831469612f, -0.555570233f, + 0.834862875f, -0.550457973f, + 0.838224706f, -0.545324988f, + 0.841554977f, -0.540171473f, + 0.844853565f, -0.534997620f, + 0.848120345f, -0.529803625f, + 0.851355193f, -0.524589683f, + 0.854557988f, -0.519355990f, + 0.857728610f, -0.514102744f, + 0.860866939f, -0.508830143f, + 0.863972856f, -0.503538384f, + 0.867046246f, -0.498227667f, + 0.870086991f, -0.492898192f, + 0.873094978f, -0.487550160f, + 0.876070094f, -0.482183772f, + 0.879012226f, -0.476799230f, + 0.881921264f, -0.471396737f, + 0.884797098f, -0.465976496f, + 0.887639620f, -0.460538711f, + 0.890448723f, -0.455083587f, + 0.893224301f, -0.449611330f, + 0.895966250f, -0.444122145f, + 0.898674466f, -0.438616239f, + 0.901348847f, -0.433093819f, + 0.903989293f, -0.427555093f, + 0.906595705f, -0.422000271f, + 0.909167983f, -0.416429560f, + 0.911706032f, -0.410843171f, + 0.914209756f, -0.405241314f, + 0.916679060f, -0.399624200f, + 0.919113852f, -0.393992040f, + 0.921514039f, -0.388345047f, + 0.923879533f, -0.382683432f, + 0.926210242f, -0.377007410f, + 0.928506080f, -0.371317194f, + 0.930766961f, -0.365612998f, + 0.932992799f, -0.359895037f, + 0.935183510f, -0.354163525f, + 0.937339012f, -0.348418680f, + 0.939459224f, -0.342660717f, + 0.941544065f, -0.336889853f, + 0.943593458f, -0.331106306f, + 0.945607325f, -0.325310292f, + 0.947585591f, -0.319502031f, + 0.949528181f, -0.313681740f, + 0.951435021f, -0.307849640f, + 0.953306040f, -0.302005949f, + 0.955141168f, -0.296150888f, + 0.956940336f, -0.290284677f, + 0.958703475f, -0.284407537f, + 0.960430519f, -0.278519689f, + 0.962121404f, -0.272621355f, + 0.963776066f, -0.266712757f, + 0.965394442f, -0.260794118f, + 0.966976471f, -0.254865660f, + 0.968522094f, -0.248927606f, + 0.970031253f, -0.242980180f, + 0.971503891f, -0.237023606f, + 0.972939952f, -0.231058108f, + 0.974339383f, -0.225083911f, + 0.975702130f, -0.219101240f, + 0.977028143f, -0.213110320f, + 0.978317371f, -0.207111376f, + 0.979569766f, -0.201104635f, + 0.980785280f, -0.195090322f, + 0.981963869f, -0.189068664f, + 0.983105487f, -0.183039888f, + 0.984210092f, -0.177004220f, + 0.985277642f, -0.170961889f, + 0.986308097f, -0.164913120f, + 0.987301418f, -0.158858143f, + 0.988257568f, -0.152797185f, + 0.989176510f, -0.146730474f, + 0.990058210f, -0.140658239f, + 0.990902635f, -0.134580709f, + 0.991709754f, -0.128498111f, + 0.992479535f, -0.122410675f, + 0.993211949f, -0.116318631f, + 0.993906970f, -0.110222207f, + 0.994564571f, -0.104121634f, + 0.995184727f, -0.098017140f, + 0.995767414f, -0.091908956f, + 0.996312612f, -0.085797312f, + 0.996820299f, -0.079682438f, + 0.997290457f, -0.073564564f, + 0.997723067f, -0.067443920f, + 0.998118113f, -0.061320736f, + 0.998475581f, -0.055195244f, + 0.998795456f, -0.049067674f, + 0.999077728f, -0.042938257f, + 0.999322385f, -0.036807223f, + 0.999529418f, -0.030674803f, + 0.999698819f, -0.024541229f, + 0.999830582f, -0.018406730f, + 0.999924702f, -0.012271538f, + 0.999981175f, -0.006135885f +}; + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 2048 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_2048[4096] = { + 1.000000000f, 0.000000000f, + 0.999995294f, 0.003067957f, + 0.999981175f, 0.006135885f, + 0.999957645f, 0.009203755f, + 0.999924702f, 0.012271538f, + 0.999882347f, 0.015339206f, + 0.999830582f, 0.018406730f, + 0.999769405f, 0.021474080f, + 0.999698819f, 0.024541229f, + 0.999618822f, 0.027608146f, + 0.999529418f, 0.030674803f, + 0.999430605f, 0.033741172f, + 0.999322385f, 0.036807223f, + 0.999204759f, 0.039872928f, + 0.999077728f, 0.042938257f, + 0.998941293f, 0.046003182f, + 0.998795456f, 0.049067674f, + 0.998640218f, 0.052131705f, + 0.998475581f, 0.055195244f, + 0.998301545f, 0.058258265f, + 0.998118113f, 0.061320736f, + 0.997925286f, 0.064382631f, + 0.997723067f, 0.067443920f, + 0.997511456f, 0.070504573f, + 0.997290457f, 0.073564564f, + 0.997060070f, 0.076623861f, + 0.996820299f, 0.079682438f, + 0.996571146f, 0.082740265f, + 0.996312612f, 0.085797312f, + 0.996044701f, 0.088853553f, + 0.995767414f, 0.091908956f, + 0.995480755f, 0.094963495f, + 0.995184727f, 0.098017140f, + 0.994879331f, 0.101069863f, + 0.994564571f, 0.104121634f, + 0.994240449f, 0.107172425f, + 0.993906970f, 0.110222207f, + 0.993564136f, 0.113270952f, + 0.993211949f, 0.116318631f, + 0.992850414f, 0.119365215f, + 0.992479535f, 0.122410675f, + 0.992099313f, 0.125454983f, + 0.991709754f, 0.128498111f, + 0.991310860f, 0.131540029f, + 0.990902635f, 0.134580709f, + 0.990485084f, 0.137620122f, + 0.990058210f, 0.140658239f, + 0.989622017f, 0.143695033f, + 0.989176510f, 0.146730474f, + 0.988721692f, 0.149764535f, + 0.988257568f, 0.152797185f, + 0.987784142f, 0.155828398f, + 0.987301418f, 0.158858143f, + 0.986809402f, 0.161886394f, + 0.986308097f, 0.164913120f, + 0.985797509f, 0.167938295f, + 0.985277642f, 0.170961889f, + 0.984748502f, 0.173983873f, + 0.984210092f, 0.177004220f, + 0.983662419f, 0.180022901f, + 0.983105487f, 0.183039888f, + 0.982539302f, 0.186055152f, + 0.981963869f, 0.189068664f, + 0.981379193f, 0.192080397f, + 0.980785280f, 0.195090322f, + 0.980182136f, 0.198098411f, + 0.979569766f, 0.201104635f, + 0.978948175f, 0.204108966f, + 0.978317371f, 0.207111376f, + 0.977677358f, 0.210111837f, + 0.977028143f, 0.213110320f, + 0.976369731f, 0.216106797f, + 0.975702130f, 0.219101240f, + 0.975025345f, 0.222093621f, + 0.974339383f, 0.225083911f, + 0.973644250f, 0.228072083f, + 0.972939952f, 0.231058108f, + 0.972226497f, 0.234041959f, + 0.971503891f, 0.237023606f, + 0.970772141f, 0.240003022f, + 0.970031253f, 0.242980180f, + 0.969281235f, 0.245955050f, + 0.968522094f, 0.248927606f, + 0.967753837f, 0.251897818f, + 0.966976471f, 0.254865660f, + 0.966190003f, 0.257831102f, + 0.965394442f, 0.260794118f, + 0.964589793f, 0.263754679f, + 0.963776066f, 0.266712757f, + 0.962953267f, 0.269668326f, + 0.962121404f, 0.272621355f, + 0.961280486f, 0.275571819f, + 0.960430519f, 0.278519689f, + 0.959571513f, 0.281464938f, + 0.958703475f, 0.284407537f, + 0.957826413f, 0.287347460f, + 0.956940336f, 0.290284677f, + 0.956045251f, 0.293219163f, + 0.955141168f, 0.296150888f, + 0.954228095f, 0.299079826f, + 0.953306040f, 0.302005949f, + 0.952375013f, 0.304929230f, + 0.951435021f, 0.307849640f, + 0.950486074f, 0.310767153f, + 0.949528181f, 0.313681740f, + 0.948561350f, 0.316593376f, + 0.947585591f, 0.319502031f, + 0.946600913f, 0.322407679f, + 0.945607325f, 0.325310292f, + 0.944604837f, 0.328209844f, + 0.943593458f, 0.331106306f, + 0.942573198f, 0.333999651f, + 0.941544065f, 0.336889853f, + 0.940506071f, 0.339776884f, + 0.939459224f, 0.342660717f, + 0.938403534f, 0.345541325f, + 0.937339012f, 0.348418680f, + 0.936265667f, 0.351292756f, + 0.935183510f, 0.354163525f, + 0.934092550f, 0.357030961f, + 0.932992799f, 0.359895037f, + 0.931884266f, 0.362755724f, + 0.930766961f, 0.365612998f, + 0.929640896f, 0.368466830f, + 0.928506080f, 0.371317194f, + 0.927362526f, 0.374164063f, + 0.926210242f, 0.377007410f, + 0.925049241f, 0.379847209f, + 0.923879533f, 0.382683432f, + 0.922701128f, 0.385516054f, + 0.921514039f, 0.388345047f, + 0.920318277f, 0.391170384f, + 0.919113852f, 0.393992040f, + 0.917900776f, 0.396809987f, + 0.916679060f, 0.399624200f, + 0.915448716f, 0.402434651f, + 0.914209756f, 0.405241314f, + 0.912962190f, 0.408044163f, + 0.911706032f, 0.410843171f, + 0.910441292f, 0.413638312f, + 0.909167983f, 0.416429560f, + 0.907886116f, 0.419216888f, + 0.906595705f, 0.422000271f, + 0.905296759f, 0.424779681f, + 0.903989293f, 0.427555093f, + 0.902673318f, 0.430326481f, + 0.901348847f, 0.433093819f, + 0.900015892f, 0.435857080f, + 0.898674466f, 0.438616239f, + 0.897324581f, 0.441371269f, + 0.895966250f, 0.444122145f, + 0.894599486f, 0.446868840f, + 0.893224301f, 0.449611330f, + 0.891840709f, 0.452349587f, + 0.890448723f, 0.455083587f, + 0.889048356f, 0.457813304f, + 0.887639620f, 0.460538711f, + 0.886222530f, 0.463259784f, + 0.884797098f, 0.465976496f, + 0.883363339f, 0.468688822f, + 0.881921264f, 0.471396737f, + 0.880470889f, 0.474100215f, + 0.879012226f, 0.476799230f, + 0.877545290f, 0.479493758f, + 0.876070094f, 0.482183772f, + 0.874586652f, 0.484869248f, + 0.873094978f, 0.487550160f, + 0.871595087f, 0.490226483f, + 0.870086991f, 0.492898192f, + 0.868570706f, 0.495565262f, + 0.867046246f, 0.498227667f, + 0.865513624f, 0.500885383f, + 0.863972856f, 0.503538384f, + 0.862423956f, 0.506186645f, + 0.860866939f, 0.508830143f, + 0.859301818f, 0.511468850f, + 0.857728610f, 0.514102744f, + 0.856147328f, 0.516731799f, + 0.854557988f, 0.519355990f, + 0.852960605f, 0.521975293f, + 0.851355193f, 0.524589683f, + 0.849741768f, 0.527199135f, + 0.848120345f, 0.529803625f, + 0.846490939f, 0.532403128f, + 0.844853565f, 0.534997620f, + 0.843208240f, 0.537587076f, + 0.841554977f, 0.540171473f, + 0.839893794f, 0.542750785f, + 0.838224706f, 0.545324988f, + 0.836547727f, 0.547894059f, + 0.834862875f, 0.550457973f, + 0.833170165f, 0.553016706f, + 0.831469612f, 0.555570233f, + 0.829761234f, 0.558118531f, + 0.828045045f, 0.560661576f, + 0.826321063f, 0.563199344f, + 0.824589303f, 0.565731811f, + 0.822849781f, 0.568258953f, + 0.821102515f, 0.570780746f, + 0.819347520f, 0.573297167f, + 0.817584813f, 0.575808191f, + 0.815814411f, 0.578313796f, + 0.814036330f, 0.580813958f, + 0.812250587f, 0.583308653f, + 0.810457198f, 0.585797857f, + 0.808656182f, 0.588281548f, + 0.806847554f, 0.590759702f, + 0.805031331f, 0.593232295f, + 0.803207531f, 0.595699304f, + 0.801376172f, 0.598160707f, + 0.799537269f, 0.600616479f, + 0.797690841f, 0.603066599f, + 0.795836905f, 0.605511041f, + 0.793975478f, 0.607949785f, + 0.792106577f, 0.610382806f, + 0.790230221f, 0.612810082f, + 0.788346428f, 0.615231591f, + 0.786455214f, 0.617647308f, + 0.784556597f, 0.620057212f, + 0.782650596f, 0.622461279f, + 0.780737229f, 0.624859488f, + 0.778816512f, 0.627251815f, + 0.776888466f, 0.629638239f, + 0.774953107f, 0.632018736f, + 0.773010453f, 0.634393284f, + 0.771060524f, 0.636761861f, + 0.769103338f, 0.639124445f, + 0.767138912f, 0.641481013f, + 0.765167266f, 0.643831543f, + 0.763188417f, 0.646176013f, + 0.761202385f, 0.648514401f, + 0.759209189f, 0.650846685f, + 0.757208847f, 0.653172843f, + 0.755201377f, 0.655492853f, + 0.753186799f, 0.657806693f, + 0.751165132f, 0.660114342f, + 0.749136395f, 0.662415778f, + 0.747100606f, 0.664710978f, + 0.745057785f, 0.666999922f, + 0.743007952f, 0.669282588f, + 0.740951125f, 0.671558955f, + 0.738887324f, 0.673829000f, + 0.736816569f, 0.676092704f, + 0.734738878f, 0.678350043f, + 0.732654272f, 0.680600998f, + 0.730562769f, 0.682845546f, + 0.728464390f, 0.685083668f, + 0.726359155f, 0.687315341f, + 0.724247083f, 0.689540545f, + 0.722128194f, 0.691759258f, + 0.720002508f, 0.693971461f, + 0.717870045f, 0.696177131f, + 0.715730825f, 0.698376249f, + 0.713584869f, 0.700568794f, + 0.711432196f, 0.702754744f, + 0.709272826f, 0.704934080f, + 0.707106781f, 0.707106781f, + 0.704934080f, 0.709272826f, + 0.702754744f, 0.711432196f, + 0.700568794f, 0.713584869f, + 0.698376249f, 0.715730825f, + 0.696177131f, 0.717870045f, + 0.693971461f, 0.720002508f, + 0.691759258f, 0.722128194f, + 0.689540545f, 0.724247083f, + 0.687315341f, 0.726359155f, + 0.685083668f, 0.728464390f, + 0.682845546f, 0.730562769f, + 0.680600998f, 0.732654272f, + 0.678350043f, 0.734738878f, + 0.676092704f, 0.736816569f, + 0.673829000f, 0.738887324f, + 0.671558955f, 0.740951125f, + 0.669282588f, 0.743007952f, + 0.666999922f, 0.745057785f, + 0.664710978f, 0.747100606f, + 0.662415778f, 0.749136395f, + 0.660114342f, 0.751165132f, + 0.657806693f, 0.753186799f, + 0.655492853f, 0.755201377f, + 0.653172843f, 0.757208847f, + 0.650846685f, 0.759209189f, + 0.648514401f, 0.761202385f, + 0.646176013f, 0.763188417f, + 0.643831543f, 0.765167266f, + 0.641481013f, 0.767138912f, + 0.639124445f, 0.769103338f, + 0.636761861f, 0.771060524f, + 0.634393284f, 0.773010453f, + 0.632018736f, 0.774953107f, + 0.629638239f, 0.776888466f, + 0.627251815f, 0.778816512f, + 0.624859488f, 0.780737229f, + 0.622461279f, 0.782650596f, + 0.620057212f, 0.784556597f, + 0.617647308f, 0.786455214f, + 0.615231591f, 0.788346428f, + 0.612810082f, 0.790230221f, + 0.610382806f, 0.792106577f, + 0.607949785f, 0.793975478f, + 0.605511041f, 0.795836905f, + 0.603066599f, 0.797690841f, + 0.600616479f, 0.799537269f, + 0.598160707f, 0.801376172f, + 0.595699304f, 0.803207531f, + 0.593232295f, 0.805031331f, + 0.590759702f, 0.806847554f, + 0.588281548f, 0.808656182f, + 0.585797857f, 0.810457198f, + 0.583308653f, 0.812250587f, + 0.580813958f, 0.814036330f, + 0.578313796f, 0.815814411f, + 0.575808191f, 0.817584813f, + 0.573297167f, 0.819347520f, + 0.570780746f, 0.821102515f, + 0.568258953f, 0.822849781f, + 0.565731811f, 0.824589303f, + 0.563199344f, 0.826321063f, + 0.560661576f, 0.828045045f, + 0.558118531f, 0.829761234f, + 0.555570233f, 0.831469612f, + 0.553016706f, 0.833170165f, + 0.550457973f, 0.834862875f, + 0.547894059f, 0.836547727f, + 0.545324988f, 0.838224706f, + 0.542750785f, 0.839893794f, + 0.540171473f, 0.841554977f, + 0.537587076f, 0.843208240f, + 0.534997620f, 0.844853565f, + 0.532403128f, 0.846490939f, + 0.529803625f, 0.848120345f, + 0.527199135f, 0.849741768f, + 0.524589683f, 0.851355193f, + 0.521975293f, 0.852960605f, + 0.519355990f, 0.854557988f, + 0.516731799f, 0.856147328f, + 0.514102744f, 0.857728610f, + 0.511468850f, 0.859301818f, + 0.508830143f, 0.860866939f, + 0.506186645f, 0.862423956f, + 0.503538384f, 0.863972856f, + 0.500885383f, 0.865513624f, + 0.498227667f, 0.867046246f, + 0.495565262f, 0.868570706f, + 0.492898192f, 0.870086991f, + 0.490226483f, 0.871595087f, + 0.487550160f, 0.873094978f, + 0.484869248f, 0.874586652f, + 0.482183772f, 0.876070094f, + 0.479493758f, 0.877545290f, + 0.476799230f, 0.879012226f, + 0.474100215f, 0.880470889f, + 0.471396737f, 0.881921264f, + 0.468688822f, 0.883363339f, + 0.465976496f, 0.884797098f, + 0.463259784f, 0.886222530f, + 0.460538711f, 0.887639620f, + 0.457813304f, 0.889048356f, + 0.455083587f, 0.890448723f, + 0.452349587f, 0.891840709f, + 0.449611330f, 0.893224301f, + 0.446868840f, 0.894599486f, + 0.444122145f, 0.895966250f, + 0.441371269f, 0.897324581f, + 0.438616239f, 0.898674466f, + 0.435857080f, 0.900015892f, + 0.433093819f, 0.901348847f, + 0.430326481f, 0.902673318f, + 0.427555093f, 0.903989293f, + 0.424779681f, 0.905296759f, + 0.422000271f, 0.906595705f, + 0.419216888f, 0.907886116f, + 0.416429560f, 0.909167983f, + 0.413638312f, 0.910441292f, + 0.410843171f, 0.911706032f, + 0.408044163f, 0.912962190f, + 0.405241314f, 0.914209756f, + 0.402434651f, 0.915448716f, + 0.399624200f, 0.916679060f, + 0.396809987f, 0.917900776f, + 0.393992040f, 0.919113852f, + 0.391170384f, 0.920318277f, + 0.388345047f, 0.921514039f, + 0.385516054f, 0.922701128f, + 0.382683432f, 0.923879533f, + 0.379847209f, 0.925049241f, + 0.377007410f, 0.926210242f, + 0.374164063f, 0.927362526f, + 0.371317194f, 0.928506080f, + 0.368466830f, 0.929640896f, + 0.365612998f, 0.930766961f, + 0.362755724f, 0.931884266f, + 0.359895037f, 0.932992799f, + 0.357030961f, 0.934092550f, + 0.354163525f, 0.935183510f, + 0.351292756f, 0.936265667f, + 0.348418680f, 0.937339012f, + 0.345541325f, 0.938403534f, + 0.342660717f, 0.939459224f, + 0.339776884f, 0.940506071f, + 0.336889853f, 0.941544065f, + 0.333999651f, 0.942573198f, + 0.331106306f, 0.943593458f, + 0.328209844f, 0.944604837f, + 0.325310292f, 0.945607325f, + 0.322407679f, 0.946600913f, + 0.319502031f, 0.947585591f, + 0.316593376f, 0.948561350f, + 0.313681740f, 0.949528181f, + 0.310767153f, 0.950486074f, + 0.307849640f, 0.951435021f, + 0.304929230f, 0.952375013f, + 0.302005949f, 0.953306040f, + 0.299079826f, 0.954228095f, + 0.296150888f, 0.955141168f, + 0.293219163f, 0.956045251f, + 0.290284677f, 0.956940336f, + 0.287347460f, 0.957826413f, + 0.284407537f, 0.958703475f, + 0.281464938f, 0.959571513f, + 0.278519689f, 0.960430519f, + 0.275571819f, 0.961280486f, + 0.272621355f, 0.962121404f, + 0.269668326f, 0.962953267f, + 0.266712757f, 0.963776066f, + 0.263754679f, 0.964589793f, + 0.260794118f, 0.965394442f, + 0.257831102f, 0.966190003f, + 0.254865660f, 0.966976471f, + 0.251897818f, 0.967753837f, + 0.248927606f, 0.968522094f, + 0.245955050f, 0.969281235f, + 0.242980180f, 0.970031253f, + 0.240003022f, 0.970772141f, + 0.237023606f, 0.971503891f, + 0.234041959f, 0.972226497f, + 0.231058108f, 0.972939952f, + 0.228072083f, 0.973644250f, + 0.225083911f, 0.974339383f, + 0.222093621f, 0.975025345f, + 0.219101240f, 0.975702130f, + 0.216106797f, 0.976369731f, + 0.213110320f, 0.977028143f, + 0.210111837f, 0.977677358f, + 0.207111376f, 0.978317371f, + 0.204108966f, 0.978948175f, + 0.201104635f, 0.979569766f, + 0.198098411f, 0.980182136f, + 0.195090322f, 0.980785280f, + 0.192080397f, 0.981379193f, + 0.189068664f, 0.981963869f, + 0.186055152f, 0.982539302f, + 0.183039888f, 0.983105487f, + 0.180022901f, 0.983662419f, + 0.177004220f, 0.984210092f, + 0.173983873f, 0.984748502f, + 0.170961889f, 0.985277642f, + 0.167938295f, 0.985797509f, + 0.164913120f, 0.986308097f, + 0.161886394f, 0.986809402f, + 0.158858143f, 0.987301418f, + 0.155828398f, 0.987784142f, + 0.152797185f, 0.988257568f, + 0.149764535f, 0.988721692f, + 0.146730474f, 0.989176510f, + 0.143695033f, 0.989622017f, + 0.140658239f, 0.990058210f, + 0.137620122f, 0.990485084f, + 0.134580709f, 0.990902635f, + 0.131540029f, 0.991310860f, + 0.128498111f, 0.991709754f, + 0.125454983f, 0.992099313f, + 0.122410675f, 0.992479535f, + 0.119365215f, 0.992850414f, + 0.116318631f, 0.993211949f, + 0.113270952f, 0.993564136f, + 0.110222207f, 0.993906970f, + 0.107172425f, 0.994240449f, + 0.104121634f, 0.994564571f, + 0.101069863f, 0.994879331f, + 0.098017140f, 0.995184727f, + 0.094963495f, 0.995480755f, + 0.091908956f, 0.995767414f, + 0.088853553f, 0.996044701f, + 0.085797312f, 0.996312612f, + 0.082740265f, 0.996571146f, + 0.079682438f, 0.996820299f, + 0.076623861f, 0.997060070f, + 0.073564564f, 0.997290457f, + 0.070504573f, 0.997511456f, + 0.067443920f, 0.997723067f, + 0.064382631f, 0.997925286f, + 0.061320736f, 0.998118113f, + 0.058258265f, 0.998301545f, + 0.055195244f, 0.998475581f, + 0.052131705f, 0.998640218f, + 0.049067674f, 0.998795456f, + 0.046003182f, 0.998941293f, + 0.042938257f, 0.999077728f, + 0.039872928f, 0.999204759f, + 0.036807223f, 0.999322385f, + 0.033741172f, 0.999430605f, + 0.030674803f, 0.999529418f, + 0.027608146f, 0.999618822f, + 0.024541229f, 0.999698819f, + 0.021474080f, 0.999769405f, + 0.018406730f, 0.999830582f, + 0.015339206f, 0.999882347f, + 0.012271538f, 0.999924702f, + 0.009203755f, 0.999957645f, + 0.006135885f, 0.999981175f, + 0.003067957f, 0.999995294f, + 0.000000000f, 1.000000000f, + -0.003067957f, 0.999995294f, + -0.006135885f, 0.999981175f, + -0.009203755f, 0.999957645f, + -0.012271538f, 0.999924702f, + -0.015339206f, 0.999882347f, + -0.018406730f, 0.999830582f, + -0.021474080f, 0.999769405f, + -0.024541229f, 0.999698819f, + -0.027608146f, 0.999618822f, + -0.030674803f, 0.999529418f, + -0.033741172f, 0.999430605f, + -0.036807223f, 0.999322385f, + -0.039872928f, 0.999204759f, + -0.042938257f, 0.999077728f, + -0.046003182f, 0.998941293f, + -0.049067674f, 0.998795456f, + -0.052131705f, 0.998640218f, + -0.055195244f, 0.998475581f, + -0.058258265f, 0.998301545f, + -0.061320736f, 0.998118113f, + -0.064382631f, 0.997925286f, + -0.067443920f, 0.997723067f, + -0.070504573f, 0.997511456f, + -0.073564564f, 0.997290457f, + -0.076623861f, 0.997060070f, + -0.079682438f, 0.996820299f, + -0.082740265f, 0.996571146f, + -0.085797312f, 0.996312612f, + -0.088853553f, 0.996044701f, + -0.091908956f, 0.995767414f, + -0.094963495f, 0.995480755f, + -0.098017140f, 0.995184727f, + -0.101069863f, 0.994879331f, + -0.104121634f, 0.994564571f, + -0.107172425f, 0.994240449f, + -0.110222207f, 0.993906970f, + -0.113270952f, 0.993564136f, + -0.116318631f, 0.993211949f, + -0.119365215f, 0.992850414f, + -0.122410675f, 0.992479535f, + -0.125454983f, 0.992099313f, + -0.128498111f, 0.991709754f, + -0.131540029f, 0.991310860f, + -0.134580709f, 0.990902635f, + -0.137620122f, 0.990485084f, + -0.140658239f, 0.990058210f, + -0.143695033f, 0.989622017f, + -0.146730474f, 0.989176510f, + -0.149764535f, 0.988721692f, + -0.152797185f, 0.988257568f, + -0.155828398f, 0.987784142f, + -0.158858143f, 0.987301418f, + -0.161886394f, 0.986809402f, + -0.164913120f, 0.986308097f, + -0.167938295f, 0.985797509f, + -0.170961889f, 0.985277642f, + -0.173983873f, 0.984748502f, + -0.177004220f, 0.984210092f, + -0.180022901f, 0.983662419f, + -0.183039888f, 0.983105487f, + -0.186055152f, 0.982539302f, + -0.189068664f, 0.981963869f, + -0.192080397f, 0.981379193f, + -0.195090322f, 0.980785280f, + -0.198098411f, 0.980182136f, + -0.201104635f, 0.979569766f, + -0.204108966f, 0.978948175f, + -0.207111376f, 0.978317371f, + -0.210111837f, 0.977677358f, + -0.213110320f, 0.977028143f, + -0.216106797f, 0.976369731f, + -0.219101240f, 0.975702130f, + -0.222093621f, 0.975025345f, + -0.225083911f, 0.974339383f, + -0.228072083f, 0.973644250f, + -0.231058108f, 0.972939952f, + -0.234041959f, 0.972226497f, + -0.237023606f, 0.971503891f, + -0.240003022f, 0.970772141f, + -0.242980180f, 0.970031253f, + -0.245955050f, 0.969281235f, + -0.248927606f, 0.968522094f, + -0.251897818f, 0.967753837f, + -0.254865660f, 0.966976471f, + -0.257831102f, 0.966190003f, + -0.260794118f, 0.965394442f, + -0.263754679f, 0.964589793f, + -0.266712757f, 0.963776066f, + -0.269668326f, 0.962953267f, + -0.272621355f, 0.962121404f, + -0.275571819f, 0.961280486f, + -0.278519689f, 0.960430519f, + -0.281464938f, 0.959571513f, + -0.284407537f, 0.958703475f, + -0.287347460f, 0.957826413f, + -0.290284677f, 0.956940336f, + -0.293219163f, 0.956045251f, + -0.296150888f, 0.955141168f, + -0.299079826f, 0.954228095f, + -0.302005949f, 0.953306040f, + -0.304929230f, 0.952375013f, + -0.307849640f, 0.951435021f, + -0.310767153f, 0.950486074f, + -0.313681740f, 0.949528181f, + -0.316593376f, 0.948561350f, + -0.319502031f, 0.947585591f, + -0.322407679f, 0.946600913f, + -0.325310292f, 0.945607325f, + -0.328209844f, 0.944604837f, + -0.331106306f, 0.943593458f, + -0.333999651f, 0.942573198f, + -0.336889853f, 0.941544065f, + -0.339776884f, 0.940506071f, + -0.342660717f, 0.939459224f, + -0.345541325f, 0.938403534f, + -0.348418680f, 0.937339012f, + -0.351292756f, 0.936265667f, + -0.354163525f, 0.935183510f, + -0.357030961f, 0.934092550f, + -0.359895037f, 0.932992799f, + -0.362755724f, 0.931884266f, + -0.365612998f, 0.930766961f, + -0.368466830f, 0.929640896f, + -0.371317194f, 0.928506080f, + -0.374164063f, 0.927362526f, + -0.377007410f, 0.926210242f, + -0.379847209f, 0.925049241f, + -0.382683432f, 0.923879533f, + -0.385516054f, 0.922701128f, + -0.388345047f, 0.921514039f, + -0.391170384f, 0.920318277f, + -0.393992040f, 0.919113852f, + -0.396809987f, 0.917900776f, + -0.399624200f, 0.916679060f, + -0.402434651f, 0.915448716f, + -0.405241314f, 0.914209756f, + -0.408044163f, 0.912962190f, + -0.410843171f, 0.911706032f, + -0.413638312f, 0.910441292f, + -0.416429560f, 0.909167983f, + -0.419216888f, 0.907886116f, + -0.422000271f, 0.906595705f, + -0.424779681f, 0.905296759f, + -0.427555093f, 0.903989293f, + -0.430326481f, 0.902673318f, + -0.433093819f, 0.901348847f, + -0.435857080f, 0.900015892f, + -0.438616239f, 0.898674466f, + -0.441371269f, 0.897324581f, + -0.444122145f, 0.895966250f, + -0.446868840f, 0.894599486f, + -0.449611330f, 0.893224301f, + -0.452349587f, 0.891840709f, + -0.455083587f, 0.890448723f, + -0.457813304f, 0.889048356f, + -0.460538711f, 0.887639620f, + -0.463259784f, 0.886222530f, + -0.465976496f, 0.884797098f, + -0.468688822f, 0.883363339f, + -0.471396737f, 0.881921264f, + -0.474100215f, 0.880470889f, + -0.476799230f, 0.879012226f, + -0.479493758f, 0.877545290f, + -0.482183772f, 0.876070094f, + -0.484869248f, 0.874586652f, + -0.487550160f, 0.873094978f, + -0.490226483f, 0.871595087f, + -0.492898192f, 0.870086991f, + -0.495565262f, 0.868570706f, + -0.498227667f, 0.867046246f, + -0.500885383f, 0.865513624f, + -0.503538384f, 0.863972856f, + -0.506186645f, 0.862423956f, + -0.508830143f, 0.860866939f, + -0.511468850f, 0.859301818f, + -0.514102744f, 0.857728610f, + -0.516731799f, 0.856147328f, + -0.519355990f, 0.854557988f, + -0.521975293f, 0.852960605f, + -0.524589683f, 0.851355193f, + -0.527199135f, 0.849741768f, + -0.529803625f, 0.848120345f, + -0.532403128f, 0.846490939f, + -0.534997620f, 0.844853565f, + -0.537587076f, 0.843208240f, + -0.540171473f, 0.841554977f, + -0.542750785f, 0.839893794f, + -0.545324988f, 0.838224706f, + -0.547894059f, 0.836547727f, + -0.550457973f, 0.834862875f, + -0.553016706f, 0.833170165f, + -0.555570233f, 0.831469612f, + -0.558118531f, 0.829761234f, + -0.560661576f, 0.828045045f, + -0.563199344f, 0.826321063f, + -0.565731811f, 0.824589303f, + -0.568258953f, 0.822849781f, + -0.570780746f, 0.821102515f, + -0.573297167f, 0.819347520f, + -0.575808191f, 0.817584813f, + -0.578313796f, 0.815814411f, + -0.580813958f, 0.814036330f, + -0.583308653f, 0.812250587f, + -0.585797857f, 0.810457198f, + -0.588281548f, 0.808656182f, + -0.590759702f, 0.806847554f, + -0.593232295f, 0.805031331f, + -0.595699304f, 0.803207531f, + -0.598160707f, 0.801376172f, + -0.600616479f, 0.799537269f, + -0.603066599f, 0.797690841f, + -0.605511041f, 0.795836905f, + -0.607949785f, 0.793975478f, + -0.610382806f, 0.792106577f, + -0.612810082f, 0.790230221f, + -0.615231591f, 0.788346428f, + -0.617647308f, 0.786455214f, + -0.620057212f, 0.784556597f, + -0.622461279f, 0.782650596f, + -0.624859488f, 0.780737229f, + -0.627251815f, 0.778816512f, + -0.629638239f, 0.776888466f, + -0.632018736f, 0.774953107f, + -0.634393284f, 0.773010453f, + -0.636761861f, 0.771060524f, + -0.639124445f, 0.769103338f, + -0.641481013f, 0.767138912f, + -0.643831543f, 0.765167266f, + -0.646176013f, 0.763188417f, + -0.648514401f, 0.761202385f, + -0.650846685f, 0.759209189f, + -0.653172843f, 0.757208847f, + -0.655492853f, 0.755201377f, + -0.657806693f, 0.753186799f, + -0.660114342f, 0.751165132f, + -0.662415778f, 0.749136395f, + -0.664710978f, 0.747100606f, + -0.666999922f, 0.745057785f, + -0.669282588f, 0.743007952f, + -0.671558955f, 0.740951125f, + -0.673829000f, 0.738887324f, + -0.676092704f, 0.736816569f, + -0.678350043f, 0.734738878f, + -0.680600998f, 0.732654272f, + -0.682845546f, 0.730562769f, + -0.685083668f, 0.728464390f, + -0.687315341f, 0.726359155f, + -0.689540545f, 0.724247083f, + -0.691759258f, 0.722128194f, + -0.693971461f, 0.720002508f, + -0.696177131f, 0.717870045f, + -0.698376249f, 0.715730825f, + -0.700568794f, 0.713584869f, + -0.702754744f, 0.711432196f, + -0.704934080f, 0.709272826f, + -0.707106781f, 0.707106781f, + -0.709272826f, 0.704934080f, + -0.711432196f, 0.702754744f, + -0.713584869f, 0.700568794f, + -0.715730825f, 0.698376249f, + -0.717870045f, 0.696177131f, + -0.720002508f, 0.693971461f, + -0.722128194f, 0.691759258f, + -0.724247083f, 0.689540545f, + -0.726359155f, 0.687315341f, + -0.728464390f, 0.685083668f, + -0.730562769f, 0.682845546f, + -0.732654272f, 0.680600998f, + -0.734738878f, 0.678350043f, + -0.736816569f, 0.676092704f, + -0.738887324f, 0.673829000f, + -0.740951125f, 0.671558955f, + -0.743007952f, 0.669282588f, + -0.745057785f, 0.666999922f, + -0.747100606f, 0.664710978f, + -0.749136395f, 0.662415778f, + -0.751165132f, 0.660114342f, + -0.753186799f, 0.657806693f, + -0.755201377f, 0.655492853f, + -0.757208847f, 0.653172843f, + -0.759209189f, 0.650846685f, + -0.761202385f, 0.648514401f, + -0.763188417f, 0.646176013f, + -0.765167266f, 0.643831543f, + -0.767138912f, 0.641481013f, + -0.769103338f, 0.639124445f, + -0.771060524f, 0.636761861f, + -0.773010453f, 0.634393284f, + -0.774953107f, 0.632018736f, + -0.776888466f, 0.629638239f, + -0.778816512f, 0.627251815f, + -0.780737229f, 0.624859488f, + -0.782650596f, 0.622461279f, + -0.784556597f, 0.620057212f, + -0.786455214f, 0.617647308f, + -0.788346428f, 0.615231591f, + -0.790230221f, 0.612810082f, + -0.792106577f, 0.610382806f, + -0.793975478f, 0.607949785f, + -0.795836905f, 0.605511041f, + -0.797690841f, 0.603066599f, + -0.799537269f, 0.600616479f, + -0.801376172f, 0.598160707f, + -0.803207531f, 0.595699304f, + -0.805031331f, 0.593232295f, + -0.806847554f, 0.590759702f, + -0.808656182f, 0.588281548f, + -0.810457198f, 0.585797857f, + -0.812250587f, 0.583308653f, + -0.814036330f, 0.580813958f, + -0.815814411f, 0.578313796f, + -0.817584813f, 0.575808191f, + -0.819347520f, 0.573297167f, + -0.821102515f, 0.570780746f, + -0.822849781f, 0.568258953f, + -0.824589303f, 0.565731811f, + -0.826321063f, 0.563199344f, + -0.828045045f, 0.560661576f, + -0.829761234f, 0.558118531f, + -0.831469612f, 0.555570233f, + -0.833170165f, 0.553016706f, + -0.834862875f, 0.550457973f, + -0.836547727f, 0.547894059f, + -0.838224706f, 0.545324988f, + -0.839893794f, 0.542750785f, + -0.841554977f, 0.540171473f, + -0.843208240f, 0.537587076f, + -0.844853565f, 0.534997620f, + -0.846490939f, 0.532403128f, + -0.848120345f, 0.529803625f, + -0.849741768f, 0.527199135f, + -0.851355193f, 0.524589683f, + -0.852960605f, 0.521975293f, + -0.854557988f, 0.519355990f, + -0.856147328f, 0.516731799f, + -0.857728610f, 0.514102744f, + -0.859301818f, 0.511468850f, + -0.860866939f, 0.508830143f, + -0.862423956f, 0.506186645f, + -0.863972856f, 0.503538384f, + -0.865513624f, 0.500885383f, + -0.867046246f, 0.498227667f, + -0.868570706f, 0.495565262f, + -0.870086991f, 0.492898192f, + -0.871595087f, 0.490226483f, + -0.873094978f, 0.487550160f, + -0.874586652f, 0.484869248f, + -0.876070094f, 0.482183772f, + -0.877545290f, 0.479493758f, + -0.879012226f, 0.476799230f, + -0.880470889f, 0.474100215f, + -0.881921264f, 0.471396737f, + -0.883363339f, 0.468688822f, + -0.884797098f, 0.465976496f, + -0.886222530f, 0.463259784f, + -0.887639620f, 0.460538711f, + -0.889048356f, 0.457813304f, + -0.890448723f, 0.455083587f, + -0.891840709f, 0.452349587f, + -0.893224301f, 0.449611330f, + -0.894599486f, 0.446868840f, + -0.895966250f, 0.444122145f, + -0.897324581f, 0.441371269f, + -0.898674466f, 0.438616239f, + -0.900015892f, 0.435857080f, + -0.901348847f, 0.433093819f, + -0.902673318f, 0.430326481f, + -0.903989293f, 0.427555093f, + -0.905296759f, 0.424779681f, + -0.906595705f, 0.422000271f, + -0.907886116f, 0.419216888f, + -0.909167983f, 0.416429560f, + -0.910441292f, 0.413638312f, + -0.911706032f, 0.410843171f, + -0.912962190f, 0.408044163f, + -0.914209756f, 0.405241314f, + -0.915448716f, 0.402434651f, + -0.916679060f, 0.399624200f, + -0.917900776f, 0.396809987f, + -0.919113852f, 0.393992040f, + -0.920318277f, 0.391170384f, + -0.921514039f, 0.388345047f, + -0.922701128f, 0.385516054f, + -0.923879533f, 0.382683432f, + -0.925049241f, 0.379847209f, + -0.926210242f, 0.377007410f, + -0.927362526f, 0.374164063f, + -0.928506080f, 0.371317194f, + -0.929640896f, 0.368466830f, + -0.930766961f, 0.365612998f, + -0.931884266f, 0.362755724f, + -0.932992799f, 0.359895037f, + -0.934092550f, 0.357030961f, + -0.935183510f, 0.354163525f, + -0.936265667f, 0.351292756f, + -0.937339012f, 0.348418680f, + -0.938403534f, 0.345541325f, + -0.939459224f, 0.342660717f, + -0.940506071f, 0.339776884f, + -0.941544065f, 0.336889853f, + -0.942573198f, 0.333999651f, + -0.943593458f, 0.331106306f, + -0.944604837f, 0.328209844f, + -0.945607325f, 0.325310292f, + -0.946600913f, 0.322407679f, + -0.947585591f, 0.319502031f, + -0.948561350f, 0.316593376f, + -0.949528181f, 0.313681740f, + -0.950486074f, 0.310767153f, + -0.951435021f, 0.307849640f, + -0.952375013f, 0.304929230f, + -0.953306040f, 0.302005949f, + -0.954228095f, 0.299079826f, + -0.955141168f, 0.296150888f, + -0.956045251f, 0.293219163f, + -0.956940336f, 0.290284677f, + -0.957826413f, 0.287347460f, + -0.958703475f, 0.284407537f, + -0.959571513f, 0.281464938f, + -0.960430519f, 0.278519689f, + -0.961280486f, 0.275571819f, + -0.962121404f, 0.272621355f, + -0.962953267f, 0.269668326f, + -0.963776066f, 0.266712757f, + -0.964589793f, 0.263754679f, + -0.965394442f, 0.260794118f, + -0.966190003f, 0.257831102f, + -0.966976471f, 0.254865660f, + -0.967753837f, 0.251897818f, + -0.968522094f, 0.248927606f, + -0.969281235f, 0.245955050f, + -0.970031253f, 0.242980180f, + -0.970772141f, 0.240003022f, + -0.971503891f, 0.237023606f, + -0.972226497f, 0.234041959f, + -0.972939952f, 0.231058108f, + -0.973644250f, 0.228072083f, + -0.974339383f, 0.225083911f, + -0.975025345f, 0.222093621f, + -0.975702130f, 0.219101240f, + -0.976369731f, 0.216106797f, + -0.977028143f, 0.213110320f, + -0.977677358f, 0.210111837f, + -0.978317371f, 0.207111376f, + -0.978948175f, 0.204108966f, + -0.979569766f, 0.201104635f, + -0.980182136f, 0.198098411f, + -0.980785280f, 0.195090322f, + -0.981379193f, 0.192080397f, + -0.981963869f, 0.189068664f, + -0.982539302f, 0.186055152f, + -0.983105487f, 0.183039888f, + -0.983662419f, 0.180022901f, + -0.984210092f, 0.177004220f, + -0.984748502f, 0.173983873f, + -0.985277642f, 0.170961889f, + -0.985797509f, 0.167938295f, + -0.986308097f, 0.164913120f, + -0.986809402f, 0.161886394f, + -0.987301418f, 0.158858143f, + -0.987784142f, 0.155828398f, + -0.988257568f, 0.152797185f, + -0.988721692f, 0.149764535f, + -0.989176510f, 0.146730474f, + -0.989622017f, 0.143695033f, + -0.990058210f, 0.140658239f, + -0.990485084f, 0.137620122f, + -0.990902635f, 0.134580709f, + -0.991310860f, 0.131540029f, + -0.991709754f, 0.128498111f, + -0.992099313f, 0.125454983f, + -0.992479535f, 0.122410675f, + -0.992850414f, 0.119365215f, + -0.993211949f, 0.116318631f, + -0.993564136f, 0.113270952f, + -0.993906970f, 0.110222207f, + -0.994240449f, 0.107172425f, + -0.994564571f, 0.104121634f, + -0.994879331f, 0.101069863f, + -0.995184727f, 0.098017140f, + -0.995480755f, 0.094963495f, + -0.995767414f, 0.091908956f, + -0.996044701f, 0.088853553f, + -0.996312612f, 0.085797312f, + -0.996571146f, 0.082740265f, + -0.996820299f, 0.079682438f, + -0.997060070f, 0.076623861f, + -0.997290457f, 0.073564564f, + -0.997511456f, 0.070504573f, + -0.997723067f, 0.067443920f, + -0.997925286f, 0.064382631f, + -0.998118113f, 0.061320736f, + -0.998301545f, 0.058258265f, + -0.998475581f, 0.055195244f, + -0.998640218f, 0.052131705f, + -0.998795456f, 0.049067674f, + -0.998941293f, 0.046003182f, + -0.999077728f, 0.042938257f, + -0.999204759f, 0.039872928f, + -0.999322385f, 0.036807223f, + -0.999430605f, 0.033741172f, + -0.999529418f, 0.030674803f, + -0.999618822f, 0.027608146f, + -0.999698819f, 0.024541229f, + -0.999769405f, 0.021474080f, + -0.999830582f, 0.018406730f, + -0.999882347f, 0.015339206f, + -0.999924702f, 0.012271538f, + -0.999957645f, 0.009203755f, + -0.999981175f, 0.006135885f, + -0.999995294f, 0.003067957f, + -1.000000000f, 0.000000000f, + -0.999995294f, -0.003067957f, + -0.999981175f, -0.006135885f, + -0.999957645f, -0.009203755f, + -0.999924702f, -0.012271538f, + -0.999882347f, -0.015339206f, + -0.999830582f, -0.018406730f, + -0.999769405f, -0.021474080f, + -0.999698819f, -0.024541229f, + -0.999618822f, -0.027608146f, + -0.999529418f, -0.030674803f, + -0.999430605f, -0.033741172f, + -0.999322385f, -0.036807223f, + -0.999204759f, -0.039872928f, + -0.999077728f, -0.042938257f, + -0.998941293f, -0.046003182f, + -0.998795456f, -0.049067674f, + -0.998640218f, -0.052131705f, + -0.998475581f, -0.055195244f, + -0.998301545f, -0.058258265f, + -0.998118113f, -0.061320736f, + -0.997925286f, -0.064382631f, + -0.997723067f, -0.067443920f, + -0.997511456f, -0.070504573f, + -0.997290457f, -0.073564564f, + -0.997060070f, -0.076623861f, + -0.996820299f, -0.079682438f, + -0.996571146f, -0.082740265f, + -0.996312612f, -0.085797312f, + -0.996044701f, -0.088853553f, + -0.995767414f, -0.091908956f, + -0.995480755f, -0.094963495f, + -0.995184727f, -0.098017140f, + -0.994879331f, -0.101069863f, + -0.994564571f, -0.104121634f, + -0.994240449f, -0.107172425f, + -0.993906970f, -0.110222207f, + -0.993564136f, -0.113270952f, + -0.993211949f, -0.116318631f, + -0.992850414f, -0.119365215f, + -0.992479535f, -0.122410675f, + -0.992099313f, -0.125454983f, + -0.991709754f, -0.128498111f, + -0.991310860f, -0.131540029f, + -0.990902635f, -0.134580709f, + -0.990485084f, -0.137620122f, + -0.990058210f, -0.140658239f, + -0.989622017f, -0.143695033f, + -0.989176510f, -0.146730474f, + -0.988721692f, -0.149764535f, + -0.988257568f, -0.152797185f, + -0.987784142f, -0.155828398f, + -0.987301418f, -0.158858143f, + -0.986809402f, -0.161886394f, + -0.986308097f, -0.164913120f, + -0.985797509f, -0.167938295f, + -0.985277642f, -0.170961889f, + -0.984748502f, -0.173983873f, + -0.984210092f, -0.177004220f, + -0.983662419f, -0.180022901f, + -0.983105487f, -0.183039888f, + -0.982539302f, -0.186055152f, + -0.981963869f, -0.189068664f, + -0.981379193f, -0.192080397f, + -0.980785280f, -0.195090322f, + -0.980182136f, -0.198098411f, + -0.979569766f, -0.201104635f, + -0.978948175f, -0.204108966f, + -0.978317371f, -0.207111376f, + -0.977677358f, -0.210111837f, + -0.977028143f, -0.213110320f, + -0.976369731f, -0.216106797f, + -0.975702130f, -0.219101240f, + -0.975025345f, -0.222093621f, + -0.974339383f, -0.225083911f, + -0.973644250f, -0.228072083f, + -0.972939952f, -0.231058108f, + -0.972226497f, -0.234041959f, + -0.971503891f, -0.237023606f, + -0.970772141f, -0.240003022f, + -0.970031253f, -0.242980180f, + -0.969281235f, -0.245955050f, + -0.968522094f, -0.248927606f, + -0.967753837f, -0.251897818f, + -0.966976471f, -0.254865660f, + -0.966190003f, -0.257831102f, + -0.965394442f, -0.260794118f, + -0.964589793f, -0.263754679f, + -0.963776066f, -0.266712757f, + -0.962953267f, -0.269668326f, + -0.962121404f, -0.272621355f, + -0.961280486f, -0.275571819f, + -0.960430519f, -0.278519689f, + -0.959571513f, -0.281464938f, + -0.958703475f, -0.284407537f, + -0.957826413f, -0.287347460f, + -0.956940336f, -0.290284677f, + -0.956045251f, -0.293219163f, + -0.955141168f, -0.296150888f, + -0.954228095f, -0.299079826f, + -0.953306040f, -0.302005949f, + -0.952375013f, -0.304929230f, + -0.951435021f, -0.307849640f, + -0.950486074f, -0.310767153f, + -0.949528181f, -0.313681740f, + -0.948561350f, -0.316593376f, + -0.947585591f, -0.319502031f, + -0.946600913f, -0.322407679f, + -0.945607325f, -0.325310292f, + -0.944604837f, -0.328209844f, + -0.943593458f, -0.331106306f, + -0.942573198f, -0.333999651f, + -0.941544065f, -0.336889853f, + -0.940506071f, -0.339776884f, + -0.939459224f, -0.342660717f, + -0.938403534f, -0.345541325f, + -0.937339012f, -0.348418680f, + -0.936265667f, -0.351292756f, + -0.935183510f, -0.354163525f, + -0.934092550f, -0.357030961f, + -0.932992799f, -0.359895037f, + -0.931884266f, -0.362755724f, + -0.930766961f, -0.365612998f, + -0.929640896f, -0.368466830f, + -0.928506080f, -0.371317194f, + -0.927362526f, -0.374164063f, + -0.926210242f, -0.377007410f, + -0.925049241f, -0.379847209f, + -0.923879533f, -0.382683432f, + -0.922701128f, -0.385516054f, + -0.921514039f, -0.388345047f, + -0.920318277f, -0.391170384f, + -0.919113852f, -0.393992040f, + -0.917900776f, -0.396809987f, + -0.916679060f, -0.399624200f, + -0.915448716f, -0.402434651f, + -0.914209756f, -0.405241314f, + -0.912962190f, -0.408044163f, + -0.911706032f, -0.410843171f, + -0.910441292f, -0.413638312f, + -0.909167983f, -0.416429560f, + -0.907886116f, -0.419216888f, + -0.906595705f, -0.422000271f, + -0.905296759f, -0.424779681f, + -0.903989293f, -0.427555093f, + -0.902673318f, -0.430326481f, + -0.901348847f, -0.433093819f, + -0.900015892f, -0.435857080f, + -0.898674466f, -0.438616239f, + -0.897324581f, -0.441371269f, + -0.895966250f, -0.444122145f, + -0.894599486f, -0.446868840f, + -0.893224301f, -0.449611330f, + -0.891840709f, -0.452349587f, + -0.890448723f, -0.455083587f, + -0.889048356f, -0.457813304f, + -0.887639620f, -0.460538711f, + -0.886222530f, -0.463259784f, + -0.884797098f, -0.465976496f, + -0.883363339f, -0.468688822f, + -0.881921264f, -0.471396737f, + -0.880470889f, -0.474100215f, + -0.879012226f, -0.476799230f, + -0.877545290f, -0.479493758f, + -0.876070094f, -0.482183772f, + -0.874586652f, -0.484869248f, + -0.873094978f, -0.487550160f, + -0.871595087f, -0.490226483f, + -0.870086991f, -0.492898192f, + -0.868570706f, -0.495565262f, + -0.867046246f, -0.498227667f, + -0.865513624f, -0.500885383f, + -0.863972856f, -0.503538384f, + -0.862423956f, -0.506186645f, + -0.860866939f, -0.508830143f, + -0.859301818f, -0.511468850f, + -0.857728610f, -0.514102744f, + -0.856147328f, -0.516731799f, + -0.854557988f, -0.519355990f, + -0.852960605f, -0.521975293f, + -0.851355193f, -0.524589683f, + -0.849741768f, -0.527199135f, + -0.848120345f, -0.529803625f, + -0.846490939f, -0.532403128f, + -0.844853565f, -0.534997620f, + -0.843208240f, -0.537587076f, + -0.841554977f, -0.540171473f, + -0.839893794f, -0.542750785f, + -0.838224706f, -0.545324988f, + -0.836547727f, -0.547894059f, + -0.834862875f, -0.550457973f, + -0.833170165f, -0.553016706f, + -0.831469612f, -0.555570233f, + -0.829761234f, -0.558118531f, + -0.828045045f, -0.560661576f, + -0.826321063f, -0.563199344f, + -0.824589303f, -0.565731811f, + -0.822849781f, -0.568258953f, + -0.821102515f, -0.570780746f, + -0.819347520f, -0.573297167f, + -0.817584813f, -0.575808191f, + -0.815814411f, -0.578313796f, + -0.814036330f, -0.580813958f, + -0.812250587f, -0.583308653f, + -0.810457198f, -0.585797857f, + -0.808656182f, -0.588281548f, + -0.806847554f, -0.590759702f, + -0.805031331f, -0.593232295f, + -0.803207531f, -0.595699304f, + -0.801376172f, -0.598160707f, + -0.799537269f, -0.600616479f, + -0.797690841f, -0.603066599f, + -0.795836905f, -0.605511041f, + -0.793975478f, -0.607949785f, + -0.792106577f, -0.610382806f, + -0.790230221f, -0.612810082f, + -0.788346428f, -0.615231591f, + -0.786455214f, -0.617647308f, + -0.784556597f, -0.620057212f, + -0.782650596f, -0.622461279f, + -0.780737229f, -0.624859488f, + -0.778816512f, -0.627251815f, + -0.776888466f, -0.629638239f, + -0.774953107f, -0.632018736f, + -0.773010453f, -0.634393284f, + -0.771060524f, -0.636761861f, + -0.769103338f, -0.639124445f, + -0.767138912f, -0.641481013f, + -0.765167266f, -0.643831543f, + -0.763188417f, -0.646176013f, + -0.761202385f, -0.648514401f, + -0.759209189f, -0.650846685f, + -0.757208847f, -0.653172843f, + -0.755201377f, -0.655492853f, + -0.753186799f, -0.657806693f, + -0.751165132f, -0.660114342f, + -0.749136395f, -0.662415778f, + -0.747100606f, -0.664710978f, + -0.745057785f, -0.666999922f, + -0.743007952f, -0.669282588f, + -0.740951125f, -0.671558955f, + -0.738887324f, -0.673829000f, + -0.736816569f, -0.676092704f, + -0.734738878f, -0.678350043f, + -0.732654272f, -0.680600998f, + -0.730562769f, -0.682845546f, + -0.728464390f, -0.685083668f, + -0.726359155f, -0.687315341f, + -0.724247083f, -0.689540545f, + -0.722128194f, -0.691759258f, + -0.720002508f, -0.693971461f, + -0.717870045f, -0.696177131f, + -0.715730825f, -0.698376249f, + -0.713584869f, -0.700568794f, + -0.711432196f, -0.702754744f, + -0.709272826f, -0.704934080f, + -0.707106781f, -0.707106781f, + -0.704934080f, -0.709272826f, + -0.702754744f, -0.711432196f, + -0.700568794f, -0.713584869f, + -0.698376249f, -0.715730825f, + -0.696177131f, -0.717870045f, + -0.693971461f, -0.720002508f, + -0.691759258f, -0.722128194f, + -0.689540545f, -0.724247083f, + -0.687315341f, -0.726359155f, + -0.685083668f, -0.728464390f, + -0.682845546f, -0.730562769f, + -0.680600998f, -0.732654272f, + -0.678350043f, -0.734738878f, + -0.676092704f, -0.736816569f, + -0.673829000f, -0.738887324f, + -0.671558955f, -0.740951125f, + -0.669282588f, -0.743007952f, + -0.666999922f, -0.745057785f, + -0.664710978f, -0.747100606f, + -0.662415778f, -0.749136395f, + -0.660114342f, -0.751165132f, + -0.657806693f, -0.753186799f, + -0.655492853f, -0.755201377f, + -0.653172843f, -0.757208847f, + -0.650846685f, -0.759209189f, + -0.648514401f, -0.761202385f, + -0.646176013f, -0.763188417f, + -0.643831543f, -0.765167266f, + -0.641481013f, -0.767138912f, + -0.639124445f, -0.769103338f, + -0.636761861f, -0.771060524f, + -0.634393284f, -0.773010453f, + -0.632018736f, -0.774953107f, + -0.629638239f, -0.776888466f, + -0.627251815f, -0.778816512f, + -0.624859488f, -0.780737229f, + -0.622461279f, -0.782650596f, + -0.620057212f, -0.784556597f, + -0.617647308f, -0.786455214f, + -0.615231591f, -0.788346428f, + -0.612810082f, -0.790230221f, + -0.610382806f, -0.792106577f, + -0.607949785f, -0.793975478f, + -0.605511041f, -0.795836905f, + -0.603066599f, -0.797690841f, + -0.600616479f, -0.799537269f, + -0.598160707f, -0.801376172f, + -0.595699304f, -0.803207531f, + -0.593232295f, -0.805031331f, + -0.590759702f, -0.806847554f, + -0.588281548f, -0.808656182f, + -0.585797857f, -0.810457198f, + -0.583308653f, -0.812250587f, + -0.580813958f, -0.814036330f, + -0.578313796f, -0.815814411f, + -0.575808191f, -0.817584813f, + -0.573297167f, -0.819347520f, + -0.570780746f, -0.821102515f, + -0.568258953f, -0.822849781f, + -0.565731811f, -0.824589303f, + -0.563199344f, -0.826321063f, + -0.560661576f, -0.828045045f, + -0.558118531f, -0.829761234f, + -0.555570233f, -0.831469612f, + -0.553016706f, -0.833170165f, + -0.550457973f, -0.834862875f, + -0.547894059f, -0.836547727f, + -0.545324988f, -0.838224706f, + -0.542750785f, -0.839893794f, + -0.540171473f, -0.841554977f, + -0.537587076f, -0.843208240f, + -0.534997620f, -0.844853565f, + -0.532403128f, -0.846490939f, + -0.529803625f, -0.848120345f, + -0.527199135f, -0.849741768f, + -0.524589683f, -0.851355193f, + -0.521975293f, -0.852960605f, + -0.519355990f, -0.854557988f, + -0.516731799f, -0.856147328f, + -0.514102744f, -0.857728610f, + -0.511468850f, -0.859301818f, + -0.508830143f, -0.860866939f, + -0.506186645f, -0.862423956f, + -0.503538384f, -0.863972856f, + -0.500885383f, -0.865513624f, + -0.498227667f, -0.867046246f, + -0.495565262f, -0.868570706f, + -0.492898192f, -0.870086991f, + -0.490226483f, -0.871595087f, + -0.487550160f, -0.873094978f, + -0.484869248f, -0.874586652f, + -0.482183772f, -0.876070094f, + -0.479493758f, -0.877545290f, + -0.476799230f, -0.879012226f, + -0.474100215f, -0.880470889f, + -0.471396737f, -0.881921264f, + -0.468688822f, -0.883363339f, + -0.465976496f, -0.884797098f, + -0.463259784f, -0.886222530f, + -0.460538711f, -0.887639620f, + -0.457813304f, -0.889048356f, + -0.455083587f, -0.890448723f, + -0.452349587f, -0.891840709f, + -0.449611330f, -0.893224301f, + -0.446868840f, -0.894599486f, + -0.444122145f, -0.895966250f, + -0.441371269f, -0.897324581f, + -0.438616239f, -0.898674466f, + -0.435857080f, -0.900015892f, + -0.433093819f, -0.901348847f, + -0.430326481f, -0.902673318f, + -0.427555093f, -0.903989293f, + -0.424779681f, -0.905296759f, + -0.422000271f, -0.906595705f, + -0.419216888f, -0.907886116f, + -0.416429560f, -0.909167983f, + -0.413638312f, -0.910441292f, + -0.410843171f, -0.911706032f, + -0.408044163f, -0.912962190f, + -0.405241314f, -0.914209756f, + -0.402434651f, -0.915448716f, + -0.399624200f, -0.916679060f, + -0.396809987f, -0.917900776f, + -0.393992040f, -0.919113852f, + -0.391170384f, -0.920318277f, + -0.388345047f, -0.921514039f, + -0.385516054f, -0.922701128f, + -0.382683432f, -0.923879533f, + -0.379847209f, -0.925049241f, + -0.377007410f, -0.926210242f, + -0.374164063f, -0.927362526f, + -0.371317194f, -0.928506080f, + -0.368466830f, -0.929640896f, + -0.365612998f, -0.930766961f, + -0.362755724f, -0.931884266f, + -0.359895037f, -0.932992799f, + -0.357030961f, -0.934092550f, + -0.354163525f, -0.935183510f, + -0.351292756f, -0.936265667f, + -0.348418680f, -0.937339012f, + -0.345541325f, -0.938403534f, + -0.342660717f, -0.939459224f, + -0.339776884f, -0.940506071f, + -0.336889853f, -0.941544065f, + -0.333999651f, -0.942573198f, + -0.331106306f, -0.943593458f, + -0.328209844f, -0.944604837f, + -0.325310292f, -0.945607325f, + -0.322407679f, -0.946600913f, + -0.319502031f, -0.947585591f, + -0.316593376f, -0.948561350f, + -0.313681740f, -0.949528181f, + -0.310767153f, -0.950486074f, + -0.307849640f, -0.951435021f, + -0.304929230f, -0.952375013f, + -0.302005949f, -0.953306040f, + -0.299079826f, -0.954228095f, + -0.296150888f, -0.955141168f, + -0.293219163f, -0.956045251f, + -0.290284677f, -0.956940336f, + -0.287347460f, -0.957826413f, + -0.284407537f, -0.958703475f, + -0.281464938f, -0.959571513f, + -0.278519689f, -0.960430519f, + -0.275571819f, -0.961280486f, + -0.272621355f, -0.962121404f, + -0.269668326f, -0.962953267f, + -0.266712757f, -0.963776066f, + -0.263754679f, -0.964589793f, + -0.260794118f, -0.965394442f, + -0.257831102f, -0.966190003f, + -0.254865660f, -0.966976471f, + -0.251897818f, -0.967753837f, + -0.248927606f, -0.968522094f, + -0.245955050f, -0.969281235f, + -0.242980180f, -0.970031253f, + -0.240003022f, -0.970772141f, + -0.237023606f, -0.971503891f, + -0.234041959f, -0.972226497f, + -0.231058108f, -0.972939952f, + -0.228072083f, -0.973644250f, + -0.225083911f, -0.974339383f, + -0.222093621f, -0.975025345f, + -0.219101240f, -0.975702130f, + -0.216106797f, -0.976369731f, + -0.213110320f, -0.977028143f, + -0.210111837f, -0.977677358f, + -0.207111376f, -0.978317371f, + -0.204108966f, -0.978948175f, + -0.201104635f, -0.979569766f, + -0.198098411f, -0.980182136f, + -0.195090322f, -0.980785280f, + -0.192080397f, -0.981379193f, + -0.189068664f, -0.981963869f, + -0.186055152f, -0.982539302f, + -0.183039888f, -0.983105487f, + -0.180022901f, -0.983662419f, + -0.177004220f, -0.984210092f, + -0.173983873f, -0.984748502f, + -0.170961889f, -0.985277642f, + -0.167938295f, -0.985797509f, + -0.164913120f, -0.986308097f, + -0.161886394f, -0.986809402f, + -0.158858143f, -0.987301418f, + -0.155828398f, -0.987784142f, + -0.152797185f, -0.988257568f, + -0.149764535f, -0.988721692f, + -0.146730474f, -0.989176510f, + -0.143695033f, -0.989622017f, + -0.140658239f, -0.990058210f, + -0.137620122f, -0.990485084f, + -0.134580709f, -0.990902635f, + -0.131540029f, -0.991310860f, + -0.128498111f, -0.991709754f, + -0.125454983f, -0.992099313f, + -0.122410675f, -0.992479535f, + -0.119365215f, -0.992850414f, + -0.116318631f, -0.993211949f, + -0.113270952f, -0.993564136f, + -0.110222207f, -0.993906970f, + -0.107172425f, -0.994240449f, + -0.104121634f, -0.994564571f, + -0.101069863f, -0.994879331f, + -0.098017140f, -0.995184727f, + -0.094963495f, -0.995480755f, + -0.091908956f, -0.995767414f, + -0.088853553f, -0.996044701f, + -0.085797312f, -0.996312612f, + -0.082740265f, -0.996571146f, + -0.079682438f, -0.996820299f, + -0.076623861f, -0.997060070f, + -0.073564564f, -0.997290457f, + -0.070504573f, -0.997511456f, + -0.067443920f, -0.997723067f, + -0.064382631f, -0.997925286f, + -0.061320736f, -0.998118113f, + -0.058258265f, -0.998301545f, + -0.055195244f, -0.998475581f, + -0.052131705f, -0.998640218f, + -0.049067674f, -0.998795456f, + -0.046003182f, -0.998941293f, + -0.042938257f, -0.999077728f, + -0.039872928f, -0.999204759f, + -0.036807223f, -0.999322385f, + -0.033741172f, -0.999430605f, + -0.030674803f, -0.999529418f, + -0.027608146f, -0.999618822f, + -0.024541229f, -0.999698819f, + -0.021474080f, -0.999769405f, + -0.018406730f, -0.999830582f, + -0.015339206f, -0.999882347f, + -0.012271538f, -0.999924702f, + -0.009203755f, -0.999957645f, + -0.006135885f, -0.999981175f, + -0.003067957f, -0.999995294f, + -0.000000000f, -1.000000000f, + 0.003067957f, -0.999995294f, + 0.006135885f, -0.999981175f, + 0.009203755f, -0.999957645f, + 0.012271538f, -0.999924702f, + 0.015339206f, -0.999882347f, + 0.018406730f, -0.999830582f, + 0.021474080f, -0.999769405f, + 0.024541229f, -0.999698819f, + 0.027608146f, -0.999618822f, + 0.030674803f, -0.999529418f, + 0.033741172f, -0.999430605f, + 0.036807223f, -0.999322385f, + 0.039872928f, -0.999204759f, + 0.042938257f, -0.999077728f, + 0.046003182f, -0.998941293f, + 0.049067674f, -0.998795456f, + 0.052131705f, -0.998640218f, + 0.055195244f, -0.998475581f, + 0.058258265f, -0.998301545f, + 0.061320736f, -0.998118113f, + 0.064382631f, -0.997925286f, + 0.067443920f, -0.997723067f, + 0.070504573f, -0.997511456f, + 0.073564564f, -0.997290457f, + 0.076623861f, -0.997060070f, + 0.079682438f, -0.996820299f, + 0.082740265f, -0.996571146f, + 0.085797312f, -0.996312612f, + 0.088853553f, -0.996044701f, + 0.091908956f, -0.995767414f, + 0.094963495f, -0.995480755f, + 0.098017140f, -0.995184727f, + 0.101069863f, -0.994879331f, + 0.104121634f, -0.994564571f, + 0.107172425f, -0.994240449f, + 0.110222207f, -0.993906970f, + 0.113270952f, -0.993564136f, + 0.116318631f, -0.993211949f, + 0.119365215f, -0.992850414f, + 0.122410675f, -0.992479535f, + 0.125454983f, -0.992099313f, + 0.128498111f, -0.991709754f, + 0.131540029f, -0.991310860f, + 0.134580709f, -0.990902635f, + 0.137620122f, -0.990485084f, + 0.140658239f, -0.990058210f, + 0.143695033f, -0.989622017f, + 0.146730474f, -0.989176510f, + 0.149764535f, -0.988721692f, + 0.152797185f, -0.988257568f, + 0.155828398f, -0.987784142f, + 0.158858143f, -0.987301418f, + 0.161886394f, -0.986809402f, + 0.164913120f, -0.986308097f, + 0.167938295f, -0.985797509f, + 0.170961889f, -0.985277642f, + 0.173983873f, -0.984748502f, + 0.177004220f, -0.984210092f, + 0.180022901f, -0.983662419f, + 0.183039888f, -0.983105487f, + 0.186055152f, -0.982539302f, + 0.189068664f, -0.981963869f, + 0.192080397f, -0.981379193f, + 0.195090322f, -0.980785280f, + 0.198098411f, -0.980182136f, + 0.201104635f, -0.979569766f, + 0.204108966f, -0.978948175f, + 0.207111376f, -0.978317371f, + 0.210111837f, -0.977677358f, + 0.213110320f, -0.977028143f, + 0.216106797f, -0.976369731f, + 0.219101240f, -0.975702130f, + 0.222093621f, -0.975025345f, + 0.225083911f, -0.974339383f, + 0.228072083f, -0.973644250f, + 0.231058108f, -0.972939952f, + 0.234041959f, -0.972226497f, + 0.237023606f, -0.971503891f, + 0.240003022f, -0.970772141f, + 0.242980180f, -0.970031253f, + 0.245955050f, -0.969281235f, + 0.248927606f, -0.968522094f, + 0.251897818f, -0.967753837f, + 0.254865660f, -0.966976471f, + 0.257831102f, -0.966190003f, + 0.260794118f, -0.965394442f, + 0.263754679f, -0.964589793f, + 0.266712757f, -0.963776066f, + 0.269668326f, -0.962953267f, + 0.272621355f, -0.962121404f, + 0.275571819f, -0.961280486f, + 0.278519689f, -0.960430519f, + 0.281464938f, -0.959571513f, + 0.284407537f, -0.958703475f, + 0.287347460f, -0.957826413f, + 0.290284677f, -0.956940336f, + 0.293219163f, -0.956045251f, + 0.296150888f, -0.955141168f, + 0.299079826f, -0.954228095f, + 0.302005949f, -0.953306040f, + 0.304929230f, -0.952375013f, + 0.307849640f, -0.951435021f, + 0.310767153f, -0.950486074f, + 0.313681740f, -0.949528181f, + 0.316593376f, -0.948561350f, + 0.319502031f, -0.947585591f, + 0.322407679f, -0.946600913f, + 0.325310292f, -0.945607325f, + 0.328209844f, -0.944604837f, + 0.331106306f, -0.943593458f, + 0.333999651f, -0.942573198f, + 0.336889853f, -0.941544065f, + 0.339776884f, -0.940506071f, + 0.342660717f, -0.939459224f, + 0.345541325f, -0.938403534f, + 0.348418680f, -0.937339012f, + 0.351292756f, -0.936265667f, + 0.354163525f, -0.935183510f, + 0.357030961f, -0.934092550f, + 0.359895037f, -0.932992799f, + 0.362755724f, -0.931884266f, + 0.365612998f, -0.930766961f, + 0.368466830f, -0.929640896f, + 0.371317194f, -0.928506080f, + 0.374164063f, -0.927362526f, + 0.377007410f, -0.926210242f, + 0.379847209f, -0.925049241f, + 0.382683432f, -0.923879533f, + 0.385516054f, -0.922701128f, + 0.388345047f, -0.921514039f, + 0.391170384f, -0.920318277f, + 0.393992040f, -0.919113852f, + 0.396809987f, -0.917900776f, + 0.399624200f, -0.916679060f, + 0.402434651f, -0.915448716f, + 0.405241314f, -0.914209756f, + 0.408044163f, -0.912962190f, + 0.410843171f, -0.911706032f, + 0.413638312f, -0.910441292f, + 0.416429560f, -0.909167983f, + 0.419216888f, -0.907886116f, + 0.422000271f, -0.906595705f, + 0.424779681f, -0.905296759f, + 0.427555093f, -0.903989293f, + 0.430326481f, -0.902673318f, + 0.433093819f, -0.901348847f, + 0.435857080f, -0.900015892f, + 0.438616239f, -0.898674466f, + 0.441371269f, -0.897324581f, + 0.444122145f, -0.895966250f, + 0.446868840f, -0.894599486f, + 0.449611330f, -0.893224301f, + 0.452349587f, -0.891840709f, + 0.455083587f, -0.890448723f, + 0.457813304f, -0.889048356f, + 0.460538711f, -0.887639620f, + 0.463259784f, -0.886222530f, + 0.465976496f, -0.884797098f, + 0.468688822f, -0.883363339f, + 0.471396737f, -0.881921264f, + 0.474100215f, -0.880470889f, + 0.476799230f, -0.879012226f, + 0.479493758f, -0.877545290f, + 0.482183772f, -0.876070094f, + 0.484869248f, -0.874586652f, + 0.487550160f, -0.873094978f, + 0.490226483f, -0.871595087f, + 0.492898192f, -0.870086991f, + 0.495565262f, -0.868570706f, + 0.498227667f, -0.867046246f, + 0.500885383f, -0.865513624f, + 0.503538384f, -0.863972856f, + 0.506186645f, -0.862423956f, + 0.508830143f, -0.860866939f, + 0.511468850f, -0.859301818f, + 0.514102744f, -0.857728610f, + 0.516731799f, -0.856147328f, + 0.519355990f, -0.854557988f, + 0.521975293f, -0.852960605f, + 0.524589683f, -0.851355193f, + 0.527199135f, -0.849741768f, + 0.529803625f, -0.848120345f, + 0.532403128f, -0.846490939f, + 0.534997620f, -0.844853565f, + 0.537587076f, -0.843208240f, + 0.540171473f, -0.841554977f, + 0.542750785f, -0.839893794f, + 0.545324988f, -0.838224706f, + 0.547894059f, -0.836547727f, + 0.550457973f, -0.834862875f, + 0.553016706f, -0.833170165f, + 0.555570233f, -0.831469612f, + 0.558118531f, -0.829761234f, + 0.560661576f, -0.828045045f, + 0.563199344f, -0.826321063f, + 0.565731811f, -0.824589303f, + 0.568258953f, -0.822849781f, + 0.570780746f, -0.821102515f, + 0.573297167f, -0.819347520f, + 0.575808191f, -0.817584813f, + 0.578313796f, -0.815814411f, + 0.580813958f, -0.814036330f, + 0.583308653f, -0.812250587f, + 0.585797857f, -0.810457198f, + 0.588281548f, -0.808656182f, + 0.590759702f, -0.806847554f, + 0.593232295f, -0.805031331f, + 0.595699304f, -0.803207531f, + 0.598160707f, -0.801376172f, + 0.600616479f, -0.799537269f, + 0.603066599f, -0.797690841f, + 0.605511041f, -0.795836905f, + 0.607949785f, -0.793975478f, + 0.610382806f, -0.792106577f, + 0.612810082f, -0.790230221f, + 0.615231591f, -0.788346428f, + 0.617647308f, -0.786455214f, + 0.620057212f, -0.784556597f, + 0.622461279f, -0.782650596f, + 0.624859488f, -0.780737229f, + 0.627251815f, -0.778816512f, + 0.629638239f, -0.776888466f, + 0.632018736f, -0.774953107f, + 0.634393284f, -0.773010453f, + 0.636761861f, -0.771060524f, + 0.639124445f, -0.769103338f, + 0.641481013f, -0.767138912f, + 0.643831543f, -0.765167266f, + 0.646176013f, -0.763188417f, + 0.648514401f, -0.761202385f, + 0.650846685f, -0.759209189f, + 0.653172843f, -0.757208847f, + 0.655492853f, -0.755201377f, + 0.657806693f, -0.753186799f, + 0.660114342f, -0.751165132f, + 0.662415778f, -0.749136395f, + 0.664710978f, -0.747100606f, + 0.666999922f, -0.745057785f, + 0.669282588f, -0.743007952f, + 0.671558955f, -0.740951125f, + 0.673829000f, -0.738887324f, + 0.676092704f, -0.736816569f, + 0.678350043f, -0.734738878f, + 0.680600998f, -0.732654272f, + 0.682845546f, -0.730562769f, + 0.685083668f, -0.728464390f, + 0.687315341f, -0.726359155f, + 0.689540545f, -0.724247083f, + 0.691759258f, -0.722128194f, + 0.693971461f, -0.720002508f, + 0.696177131f, -0.717870045f, + 0.698376249f, -0.715730825f, + 0.700568794f, -0.713584869f, + 0.702754744f, -0.711432196f, + 0.704934080f, -0.709272826f, + 0.707106781f, -0.707106781f, + 0.709272826f, -0.704934080f, + 0.711432196f, -0.702754744f, + 0.713584869f, -0.700568794f, + 0.715730825f, -0.698376249f, + 0.717870045f, -0.696177131f, + 0.720002508f, -0.693971461f, + 0.722128194f, -0.691759258f, + 0.724247083f, -0.689540545f, + 0.726359155f, -0.687315341f, + 0.728464390f, -0.685083668f, + 0.730562769f, -0.682845546f, + 0.732654272f, -0.680600998f, + 0.734738878f, -0.678350043f, + 0.736816569f, -0.676092704f, + 0.738887324f, -0.673829000f, + 0.740951125f, -0.671558955f, + 0.743007952f, -0.669282588f, + 0.745057785f, -0.666999922f, + 0.747100606f, -0.664710978f, + 0.749136395f, -0.662415778f, + 0.751165132f, -0.660114342f, + 0.753186799f, -0.657806693f, + 0.755201377f, -0.655492853f, + 0.757208847f, -0.653172843f, + 0.759209189f, -0.650846685f, + 0.761202385f, -0.648514401f, + 0.763188417f, -0.646176013f, + 0.765167266f, -0.643831543f, + 0.767138912f, -0.641481013f, + 0.769103338f, -0.639124445f, + 0.771060524f, -0.636761861f, + 0.773010453f, -0.634393284f, + 0.774953107f, -0.632018736f, + 0.776888466f, -0.629638239f, + 0.778816512f, -0.627251815f, + 0.780737229f, -0.624859488f, + 0.782650596f, -0.622461279f, + 0.784556597f, -0.620057212f, + 0.786455214f, -0.617647308f, + 0.788346428f, -0.615231591f, + 0.790230221f, -0.612810082f, + 0.792106577f, -0.610382806f, + 0.793975478f, -0.607949785f, + 0.795836905f, -0.605511041f, + 0.797690841f, -0.603066599f, + 0.799537269f, -0.600616479f, + 0.801376172f, -0.598160707f, + 0.803207531f, -0.595699304f, + 0.805031331f, -0.593232295f, + 0.806847554f, -0.590759702f, + 0.808656182f, -0.588281548f, + 0.810457198f, -0.585797857f, + 0.812250587f, -0.583308653f, + 0.814036330f, -0.580813958f, + 0.815814411f, -0.578313796f, + 0.817584813f, -0.575808191f, + 0.819347520f, -0.573297167f, + 0.821102515f, -0.570780746f, + 0.822849781f, -0.568258953f, + 0.824589303f, -0.565731811f, + 0.826321063f, -0.563199344f, + 0.828045045f, -0.560661576f, + 0.829761234f, -0.558118531f, + 0.831469612f, -0.555570233f, + 0.833170165f, -0.553016706f, + 0.834862875f, -0.550457973f, + 0.836547727f, -0.547894059f, + 0.838224706f, -0.545324988f, + 0.839893794f, -0.542750785f, + 0.841554977f, -0.540171473f, + 0.843208240f, -0.537587076f, + 0.844853565f, -0.534997620f, + 0.846490939f, -0.532403128f, + 0.848120345f, -0.529803625f, + 0.849741768f, -0.527199135f, + 0.851355193f, -0.524589683f, + 0.852960605f, -0.521975293f, + 0.854557988f, -0.519355990f, + 0.856147328f, -0.516731799f, + 0.857728610f, -0.514102744f, + 0.859301818f, -0.511468850f, + 0.860866939f, -0.508830143f, + 0.862423956f, -0.506186645f, + 0.863972856f, -0.503538384f, + 0.865513624f, -0.500885383f, + 0.867046246f, -0.498227667f, + 0.868570706f, -0.495565262f, + 0.870086991f, -0.492898192f, + 0.871595087f, -0.490226483f, + 0.873094978f, -0.487550160f, + 0.874586652f, -0.484869248f, + 0.876070094f, -0.482183772f, + 0.877545290f, -0.479493758f, + 0.879012226f, -0.476799230f, + 0.880470889f, -0.474100215f, + 0.881921264f, -0.471396737f, + 0.883363339f, -0.468688822f, + 0.884797098f, -0.465976496f, + 0.886222530f, -0.463259784f, + 0.887639620f, -0.460538711f, + 0.889048356f, -0.457813304f, + 0.890448723f, -0.455083587f, + 0.891840709f, -0.452349587f, + 0.893224301f, -0.449611330f, + 0.894599486f, -0.446868840f, + 0.895966250f, -0.444122145f, + 0.897324581f, -0.441371269f, + 0.898674466f, -0.438616239f, + 0.900015892f, -0.435857080f, + 0.901348847f, -0.433093819f, + 0.902673318f, -0.430326481f, + 0.903989293f, -0.427555093f, + 0.905296759f, -0.424779681f, + 0.906595705f, -0.422000271f, + 0.907886116f, -0.419216888f, + 0.909167983f, -0.416429560f, + 0.910441292f, -0.413638312f, + 0.911706032f, -0.410843171f, + 0.912962190f, -0.408044163f, + 0.914209756f, -0.405241314f, + 0.915448716f, -0.402434651f, + 0.916679060f, -0.399624200f, + 0.917900776f, -0.396809987f, + 0.919113852f, -0.393992040f, + 0.920318277f, -0.391170384f, + 0.921514039f, -0.388345047f, + 0.922701128f, -0.385516054f, + 0.923879533f, -0.382683432f, + 0.925049241f, -0.379847209f, + 0.926210242f, -0.377007410f, + 0.927362526f, -0.374164063f, + 0.928506080f, -0.371317194f, + 0.929640896f, -0.368466830f, + 0.930766961f, -0.365612998f, + 0.931884266f, -0.362755724f, + 0.932992799f, -0.359895037f, + 0.934092550f, -0.357030961f, + 0.935183510f, -0.354163525f, + 0.936265667f, -0.351292756f, + 0.937339012f, -0.348418680f, + 0.938403534f, -0.345541325f, + 0.939459224f, -0.342660717f, + 0.940506071f, -0.339776884f, + 0.941544065f, -0.336889853f, + 0.942573198f, -0.333999651f, + 0.943593458f, -0.331106306f, + 0.944604837f, -0.328209844f, + 0.945607325f, -0.325310292f, + 0.946600913f, -0.322407679f, + 0.947585591f, -0.319502031f, + 0.948561350f, -0.316593376f, + 0.949528181f, -0.313681740f, + 0.950486074f, -0.310767153f, + 0.951435021f, -0.307849640f, + 0.952375013f, -0.304929230f, + 0.953306040f, -0.302005949f, + 0.954228095f, -0.299079826f, + 0.955141168f, -0.296150888f, + 0.956045251f, -0.293219163f, + 0.956940336f, -0.290284677f, + 0.957826413f, -0.287347460f, + 0.958703475f, -0.284407537f, + 0.959571513f, -0.281464938f, + 0.960430519f, -0.278519689f, + 0.961280486f, -0.275571819f, + 0.962121404f, -0.272621355f, + 0.962953267f, -0.269668326f, + 0.963776066f, -0.266712757f, + 0.964589793f, -0.263754679f, + 0.965394442f, -0.260794118f, + 0.966190003f, -0.257831102f, + 0.966976471f, -0.254865660f, + 0.967753837f, -0.251897818f, + 0.968522094f, -0.248927606f, + 0.969281235f, -0.245955050f, + 0.970031253f, -0.242980180f, + 0.970772141f, -0.240003022f, + 0.971503891f, -0.237023606f, + 0.972226497f, -0.234041959f, + 0.972939952f, -0.231058108f, + 0.973644250f, -0.228072083f, + 0.974339383f, -0.225083911f, + 0.975025345f, -0.222093621f, + 0.975702130f, -0.219101240f, + 0.976369731f, -0.216106797f, + 0.977028143f, -0.213110320f, + 0.977677358f, -0.210111837f, + 0.978317371f, -0.207111376f, + 0.978948175f, -0.204108966f, + 0.979569766f, -0.201104635f, + 0.980182136f, -0.198098411f, + 0.980785280f, -0.195090322f, + 0.981379193f, -0.192080397f, + 0.981963869f, -0.189068664f, + 0.982539302f, -0.186055152f, + 0.983105487f, -0.183039888f, + 0.983662419f, -0.180022901f, + 0.984210092f, -0.177004220f, + 0.984748502f, -0.173983873f, + 0.985277642f, -0.170961889f, + 0.985797509f, -0.167938295f, + 0.986308097f, -0.164913120f, + 0.986809402f, -0.161886394f, + 0.987301418f, -0.158858143f, + 0.987784142f, -0.155828398f, + 0.988257568f, -0.152797185f, + 0.988721692f, -0.149764535f, + 0.989176510f, -0.146730474f, + 0.989622017f, -0.143695033f, + 0.990058210f, -0.140658239f, + 0.990485084f, -0.137620122f, + 0.990902635f, -0.134580709f, + 0.991310860f, -0.131540029f, + 0.991709754f, -0.128498111f, + 0.992099313f, -0.125454983f, + 0.992479535f, -0.122410675f, + 0.992850414f, -0.119365215f, + 0.993211949f, -0.116318631f, + 0.993564136f, -0.113270952f, + 0.993906970f, -0.110222207f, + 0.994240449f, -0.107172425f, + 0.994564571f, -0.104121634f, + 0.994879331f, -0.101069863f, + 0.995184727f, -0.098017140f, + 0.995480755f, -0.094963495f, + 0.995767414f, -0.091908956f, + 0.996044701f, -0.088853553f, + 0.996312612f, -0.085797312f, + 0.996571146f, -0.082740265f, + 0.996820299f, -0.079682438f, + 0.997060070f, -0.076623861f, + 0.997290457f, -0.073564564f, + 0.997511456f, -0.070504573f, + 0.997723067f, -0.067443920f, + 0.997925286f, -0.064382631f, + 0.998118113f, -0.061320736f, + 0.998301545f, -0.058258265f, + 0.998475581f, -0.055195244f, + 0.998640218f, -0.052131705f, + 0.998795456f, -0.049067674f, + 0.998941293f, -0.046003182f, + 0.999077728f, -0.042938257f, + 0.999204759f, -0.039872928f, + 0.999322385f, -0.036807223f, + 0.999430605f, -0.033741172f, + 0.999529418f, -0.030674803f, + 0.999618822f, -0.027608146f, + 0.999698819f, -0.024541229f, + 0.999769405f, -0.021474080f, + 0.999830582f, -0.018406730f, + 0.999882347f, -0.015339206f, + 0.999924702f, -0.012271538f, + 0.999957645f, -0.009203755f, + 0.999981175f, -0.006135885f, + 0.999995294f, -0.003067957f +}; + +/** +* \par +* Example code for Floating-point Twiddle factors Generation: +* \par +*
for(i = 0; i< N/; i++)
+* {
+*	twiddleCoef[2*i]= cos(i * 2*PI/(float)N);
+*	twiddleCoef[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 4096 and PI = 3.14159265358979 +* \par +* Cos and Sin values are in interleaved fashion +* +*/ +const float32_t twiddleCoef_4096[8192] = { + 1.000000000f, 0.000000000f, + 0.999998823f, 0.001533980f, + 0.999995294f, 0.003067957f, + 0.999989411f, 0.004601926f, + 0.999981175f, 0.006135885f, + 0.999970586f, 0.007669829f, + 0.999957645f, 0.009203755f, + 0.999942350f, 0.010737659f, + 0.999924702f, 0.012271538f, + 0.999904701f, 0.013805389f, + 0.999882347f, 0.015339206f, + 0.999857641f, 0.016872988f, + 0.999830582f, 0.018406730f, + 0.999801170f, 0.019940429f, + 0.999769405f, 0.021474080f, + 0.999735288f, 0.023007681f, + 0.999698819f, 0.024541229f, + 0.999659997f, 0.026074718f, + 0.999618822f, 0.027608146f, + 0.999575296f, 0.029141509f, + 0.999529418f, 0.030674803f, + 0.999481187f, 0.032208025f, + 0.999430605f, 0.033741172f, + 0.999377670f, 0.035274239f, + 0.999322385f, 0.036807223f, + 0.999264747f, 0.038340120f, + 0.999204759f, 0.039872928f, + 0.999142419f, 0.041405641f, + 0.999077728f, 0.042938257f, + 0.999010686f, 0.044470772f, + 0.998941293f, 0.046003182f, + 0.998869550f, 0.047535484f, + 0.998795456f, 0.049067674f, + 0.998719012f, 0.050599749f, + 0.998640218f, 0.052131705f, + 0.998559074f, 0.053663538f, + 0.998475581f, 0.055195244f, + 0.998389737f, 0.056726821f, + 0.998301545f, 0.058258265f, + 0.998211003f, 0.059789571f, + 0.998118113f, 0.061320736f, + 0.998022874f, 0.062851758f, + 0.997925286f, 0.064382631f, + 0.997825350f, 0.065913353f, + 0.997723067f, 0.067443920f, + 0.997618435f, 0.068974328f, + 0.997511456f, 0.070504573f, + 0.997402130f, 0.072034653f, + 0.997290457f, 0.073564564f, + 0.997176437f, 0.075094301f, + 0.997060070f, 0.076623861f, + 0.996941358f, 0.078153242f, + 0.996820299f, 0.079682438f, + 0.996696895f, 0.081211447f, + 0.996571146f, 0.082740265f, + 0.996443051f, 0.084268888f, + 0.996312612f, 0.085797312f, + 0.996179829f, 0.087325535f, + 0.996044701f, 0.088853553f, + 0.995907229f, 0.090381361f, + 0.995767414f, 0.091908956f, + 0.995625256f, 0.093436336f, + 0.995480755f, 0.094963495f, + 0.995333912f, 0.096490431f, + 0.995184727f, 0.098017140f, + 0.995033199f, 0.099543619f, + 0.994879331f, 0.101069863f, + 0.994723121f, 0.102595869f, + 0.994564571f, 0.104121634f, + 0.994403680f, 0.105647154f, + 0.994240449f, 0.107172425f, + 0.994074879f, 0.108697444f, + 0.993906970f, 0.110222207f, + 0.993736722f, 0.111746711f, + 0.993564136f, 0.113270952f, + 0.993389211f, 0.114794927f, + 0.993211949f, 0.116318631f, + 0.993032350f, 0.117842062f, + 0.992850414f, 0.119365215f, + 0.992666142f, 0.120888087f, + 0.992479535f, 0.122410675f, + 0.992290591f, 0.123932975f, + 0.992099313f, 0.125454983f, + 0.991905700f, 0.126976696f, + 0.991709754f, 0.128498111f, + 0.991511473f, 0.130019223f, + 0.991310860f, 0.131540029f, + 0.991107914f, 0.133060525f, + 0.990902635f, 0.134580709f, + 0.990695025f, 0.136100575f, + 0.990485084f, 0.137620122f, + 0.990272812f, 0.139139344f, + 0.990058210f, 0.140658239f, + 0.989841278f, 0.142176804f, + 0.989622017f, 0.143695033f, + 0.989400428f, 0.145212925f, + 0.989176510f, 0.146730474f, + 0.988950265f, 0.148247679f, + 0.988721692f, 0.149764535f, + 0.988490793f, 0.151281038f, + 0.988257568f, 0.152797185f, + 0.988022017f, 0.154312973f, + 0.987784142f, 0.155828398f, + 0.987543942f, 0.157343456f, + 0.987301418f, 0.158858143f, + 0.987056571f, 0.160372457f, + 0.986809402f, 0.161886394f, + 0.986559910f, 0.163399949f, + 0.986308097f, 0.164913120f, + 0.986053963f, 0.166425904f, + 0.985797509f, 0.167938295f, + 0.985538735f, 0.169450291f, + 0.985277642f, 0.170961889f, + 0.985014231f, 0.172473084f, + 0.984748502f, 0.173983873f, + 0.984480455f, 0.175494253f, + 0.984210092f, 0.177004220f, + 0.983937413f, 0.178513771f, + 0.983662419f, 0.180022901f, + 0.983385110f, 0.181531608f, + 0.983105487f, 0.183039888f, + 0.982823551f, 0.184547737f, + 0.982539302f, 0.186055152f, + 0.982252741f, 0.187562129f, + 0.981963869f, 0.189068664f, + 0.981672686f, 0.190574755f, + 0.981379193f, 0.192080397f, + 0.981083391f, 0.193585587f, + 0.980785280f, 0.195090322f, + 0.980484862f, 0.196594598f, + 0.980182136f, 0.198098411f, + 0.979877104f, 0.199601758f, + 0.979569766f, 0.201104635f, + 0.979260123f, 0.202607039f, + 0.978948175f, 0.204108966f, + 0.978633924f, 0.205610413f, + 0.978317371f, 0.207111376f, + 0.977998515f, 0.208611852f, + 0.977677358f, 0.210111837f, + 0.977353900f, 0.211611327f, + 0.977028143f, 0.213110320f, + 0.976700086f, 0.214608811f, + 0.976369731f, 0.216106797f, + 0.976037079f, 0.217604275f, + 0.975702130f, 0.219101240f, + 0.975364885f, 0.220597690f, + 0.975025345f, 0.222093621f, + 0.974683511f, 0.223589029f, + 0.974339383f, 0.225083911f, + 0.973992962f, 0.226578264f, + 0.973644250f, 0.228072083f, + 0.973293246f, 0.229565366f, + 0.972939952f, 0.231058108f, + 0.972584369f, 0.232550307f, + 0.972226497f, 0.234041959f, + 0.971866337f, 0.235533059f, + 0.971503891f, 0.237023606f, + 0.971139158f, 0.238513595f, + 0.970772141f, 0.240003022f, + 0.970402839f, 0.241491885f, + 0.970031253f, 0.242980180f, + 0.969657385f, 0.244467903f, + 0.969281235f, 0.245955050f, + 0.968902805f, 0.247441619f, + 0.968522094f, 0.248927606f, + 0.968139105f, 0.250413007f, + 0.967753837f, 0.251897818f, + 0.967366292f, 0.253382037f, + 0.966976471f, 0.254865660f, + 0.966584374f, 0.256348682f, + 0.966190003f, 0.257831102f, + 0.965793359f, 0.259312915f, + 0.965394442f, 0.260794118f, + 0.964993253f, 0.262274707f, + 0.964589793f, 0.263754679f, + 0.964184064f, 0.265234030f, + 0.963776066f, 0.266712757f, + 0.963365800f, 0.268190857f, + 0.962953267f, 0.269668326f, + 0.962538468f, 0.271145160f, + 0.962121404f, 0.272621355f, + 0.961702077f, 0.274096910f, + 0.961280486f, 0.275571819f, + 0.960856633f, 0.277046080f, + 0.960430519f, 0.278519689f, + 0.960002146f, 0.279992643f, + 0.959571513f, 0.281464938f, + 0.959138622f, 0.282936570f, + 0.958703475f, 0.284407537f, + 0.958266071f, 0.285877835f, + 0.957826413f, 0.287347460f, + 0.957384501f, 0.288816408f, + 0.956940336f, 0.290284677f, + 0.956493919f, 0.291752263f, + 0.956045251f, 0.293219163f, + 0.955594334f, 0.294685372f, + 0.955141168f, 0.296150888f, + 0.954685755f, 0.297615707f, + 0.954228095f, 0.299079826f, + 0.953768190f, 0.300543241f, + 0.953306040f, 0.302005949f, + 0.952841648f, 0.303467947f, + 0.952375013f, 0.304929230f, + 0.951906137f, 0.306389795f, + 0.951435021f, 0.307849640f, + 0.950961666f, 0.309308760f, + 0.950486074f, 0.310767153f, + 0.950008245f, 0.312224814f, + 0.949528181f, 0.313681740f, + 0.949045882f, 0.315137929f, + 0.948561350f, 0.316593376f, + 0.948074586f, 0.318048077f, + 0.947585591f, 0.319502031f, + 0.947094366f, 0.320955232f, + 0.946600913f, 0.322407679f, + 0.946105232f, 0.323859367f, + 0.945607325f, 0.325310292f, + 0.945107193f, 0.326760452f, + 0.944604837f, 0.328209844f, + 0.944100258f, 0.329658463f, + 0.943593458f, 0.331106306f, + 0.943084437f, 0.332553370f, + 0.942573198f, 0.333999651f, + 0.942059740f, 0.335445147f, + 0.941544065f, 0.336889853f, + 0.941026175f, 0.338333767f, + 0.940506071f, 0.339776884f, + 0.939983753f, 0.341219202f, + 0.939459224f, 0.342660717f, + 0.938932484f, 0.344101426f, + 0.938403534f, 0.345541325f, + 0.937872376f, 0.346980411f, + 0.937339012f, 0.348418680f, + 0.936803442f, 0.349856130f, + 0.936265667f, 0.351292756f, + 0.935725689f, 0.352728556f, + 0.935183510f, 0.354163525f, + 0.934639130f, 0.355597662f, + 0.934092550f, 0.357030961f, + 0.933543773f, 0.358463421f, + 0.932992799f, 0.359895037f, + 0.932439629f, 0.361325806f, + 0.931884266f, 0.362755724f, + 0.931326709f, 0.364184790f, + 0.930766961f, 0.365612998f, + 0.930205023f, 0.367040346f, + 0.929640896f, 0.368466830f, + 0.929074581f, 0.369892447f, + 0.928506080f, 0.371317194f, + 0.927935395f, 0.372741067f, + 0.927362526f, 0.374164063f, + 0.926787474f, 0.375586178f, + 0.926210242f, 0.377007410f, + 0.925630831f, 0.378427755f, + 0.925049241f, 0.379847209f, + 0.924465474f, 0.381265769f, + 0.923879533f, 0.382683432f, + 0.923291417f, 0.384100195f, + 0.922701128f, 0.385516054f, + 0.922108669f, 0.386931006f, + 0.921514039f, 0.388345047f, + 0.920917242f, 0.389758174f, + 0.920318277f, 0.391170384f, + 0.919717146f, 0.392581674f, + 0.919113852f, 0.393992040f, + 0.918508394f, 0.395401479f, + 0.917900776f, 0.396809987f, + 0.917290997f, 0.398217562f, + 0.916679060f, 0.399624200f, + 0.916064966f, 0.401029897f, + 0.915448716f, 0.402434651f, + 0.914830312f, 0.403838458f, + 0.914209756f, 0.405241314f, + 0.913587048f, 0.406643217f, + 0.912962190f, 0.408044163f, + 0.912335185f, 0.409444149f, + 0.911706032f, 0.410843171f, + 0.911074734f, 0.412241227f, + 0.910441292f, 0.413638312f, + 0.909805708f, 0.415034424f, + 0.909167983f, 0.416429560f, + 0.908528119f, 0.417823716f, + 0.907886116f, 0.419216888f, + 0.907241978f, 0.420609074f, + 0.906595705f, 0.422000271f, + 0.905947298f, 0.423390474f, + 0.905296759f, 0.424779681f, + 0.904644091f, 0.426167889f, + 0.903989293f, 0.427555093f, + 0.903332368f, 0.428941292f, + 0.902673318f, 0.430326481f, + 0.902012144f, 0.431710658f, + 0.901348847f, 0.433093819f, + 0.900683429f, 0.434475961f, + 0.900015892f, 0.435857080f, + 0.899346237f, 0.437237174f, + 0.898674466f, 0.438616239f, + 0.898000580f, 0.439994271f, + 0.897324581f, 0.441371269f, + 0.896646470f, 0.442747228f, + 0.895966250f, 0.444122145f, + 0.895283921f, 0.445496017f, + 0.894599486f, 0.446868840f, + 0.893912945f, 0.448240612f, + 0.893224301f, 0.449611330f, + 0.892533555f, 0.450980989f, + 0.891840709f, 0.452349587f, + 0.891145765f, 0.453717121f, + 0.890448723f, 0.455083587f, + 0.889749586f, 0.456448982f, + 0.889048356f, 0.457813304f, + 0.888345033f, 0.459176548f, + 0.887639620f, 0.460538711f, + 0.886932119f, 0.461899791f, + 0.886222530f, 0.463259784f, + 0.885510856f, 0.464618686f, + 0.884797098f, 0.465976496f, + 0.884081259f, 0.467333209f, + 0.883363339f, 0.468688822f, + 0.882643340f, 0.470043332f, + 0.881921264f, 0.471396737f, + 0.881197113f, 0.472749032f, + 0.880470889f, 0.474100215f, + 0.879742593f, 0.475450282f, + 0.879012226f, 0.476799230f, + 0.878279792f, 0.478147056f, + 0.877545290f, 0.479493758f, + 0.876808724f, 0.480839331f, + 0.876070094f, 0.482183772f, + 0.875329403f, 0.483527079f, + 0.874586652f, 0.484869248f, + 0.873841843f, 0.486210276f, + 0.873094978f, 0.487550160f, + 0.872346059f, 0.488888897f, + 0.871595087f, 0.490226483f, + 0.870842063f, 0.491562916f, + 0.870086991f, 0.492898192f, + 0.869329871f, 0.494232309f, + 0.868570706f, 0.495565262f, + 0.867809497f, 0.496897049f, + 0.867046246f, 0.498227667f, + 0.866280954f, 0.499557113f, + 0.865513624f, 0.500885383f, + 0.864744258f, 0.502212474f, + 0.863972856f, 0.503538384f, + 0.863199422f, 0.504863109f, + 0.862423956f, 0.506186645f, + 0.861646461f, 0.507508991f, + 0.860866939f, 0.508830143f, + 0.860085390f, 0.510150097f, + 0.859301818f, 0.511468850f, + 0.858516224f, 0.512786401f, + 0.857728610f, 0.514102744f, + 0.856938977f, 0.515417878f, + 0.856147328f, 0.516731799f, + 0.855353665f, 0.518044504f, + 0.854557988f, 0.519355990f, + 0.853760301f, 0.520666254f, + 0.852960605f, 0.521975293f, + 0.852158902f, 0.523283103f, + 0.851355193f, 0.524589683f, + 0.850549481f, 0.525895027f, + 0.849741768f, 0.527199135f, + 0.848932055f, 0.528502002f, + 0.848120345f, 0.529803625f, + 0.847306639f, 0.531104001f, + 0.846490939f, 0.532403128f, + 0.845673247f, 0.533701002f, + 0.844853565f, 0.534997620f, + 0.844031895f, 0.536292979f, + 0.843208240f, 0.537587076f, + 0.842382600f, 0.538879909f, + 0.841554977f, 0.540171473f, + 0.840725375f, 0.541461766f, + 0.839893794f, 0.542750785f, + 0.839060237f, 0.544038527f, + 0.838224706f, 0.545324988f, + 0.837387202f, 0.546610167f, + 0.836547727f, 0.547894059f, + 0.835706284f, 0.549176662f, + 0.834862875f, 0.550457973f, + 0.834017501f, 0.551737988f, + 0.833170165f, 0.553016706f, + 0.832320868f, 0.554294121f, + 0.831469612f, 0.555570233f, + 0.830616400f, 0.556845037f, + 0.829761234f, 0.558118531f, + 0.828904115f, 0.559390712f, + 0.828045045f, 0.560661576f, + 0.827184027f, 0.561931121f, + 0.826321063f, 0.563199344f, + 0.825456154f, 0.564466242f, + 0.824589303f, 0.565731811f, + 0.823720511f, 0.566996049f, + 0.822849781f, 0.568258953f, + 0.821977115f, 0.569520519f, + 0.821102515f, 0.570780746f, + 0.820225983f, 0.572039629f, + 0.819347520f, 0.573297167f, + 0.818467130f, 0.574553355f, + 0.817584813f, 0.575808191f, + 0.816700573f, 0.577061673f, + 0.815814411f, 0.578313796f, + 0.814926329f, 0.579564559f, + 0.814036330f, 0.580813958f, + 0.813144415f, 0.582061990f, + 0.812250587f, 0.583308653f, + 0.811354847f, 0.584553943f, + 0.810457198f, 0.585797857f, + 0.809557642f, 0.587040394f, + 0.808656182f, 0.588281548f, + 0.807752818f, 0.589521319f, + 0.806847554f, 0.590759702f, + 0.805940391f, 0.591996695f, + 0.805031331f, 0.593232295f, + 0.804120377f, 0.594466499f, + 0.803207531f, 0.595699304f, + 0.802292796f, 0.596930708f, + 0.801376172f, 0.598160707f, + 0.800457662f, 0.599389298f, + 0.799537269f, 0.600616479f, + 0.798614995f, 0.601842247f, + 0.797690841f, 0.603066599f, + 0.796764810f, 0.604289531f, + 0.795836905f, 0.605511041f, + 0.794907126f, 0.606731127f, + 0.793975478f, 0.607949785f, + 0.793041960f, 0.609167012f, + 0.792106577f, 0.610382806f, + 0.791169330f, 0.611597164f, + 0.790230221f, 0.612810082f, + 0.789289253f, 0.614021559f, + 0.788346428f, 0.615231591f, + 0.787401747f, 0.616440175f, + 0.786455214f, 0.617647308f, + 0.785506830f, 0.618852988f, + 0.784556597f, 0.620057212f, + 0.783604519f, 0.621259977f, + 0.782650596f, 0.622461279f, + 0.781694832f, 0.623661118f, + 0.780737229f, 0.624859488f, + 0.779777788f, 0.626056388f, + 0.778816512f, 0.627251815f, + 0.777853404f, 0.628445767f, + 0.776888466f, 0.629638239f, + 0.775921699f, 0.630829230f, + 0.774953107f, 0.632018736f, + 0.773982691f, 0.633206755f, + 0.773010453f, 0.634393284f, + 0.772036397f, 0.635578320f, + 0.771060524f, 0.636761861f, + 0.770082837f, 0.637943904f, + 0.769103338f, 0.639124445f, + 0.768122029f, 0.640303482f, + 0.767138912f, 0.641481013f, + 0.766153990f, 0.642657034f, + 0.765167266f, 0.643831543f, + 0.764178741f, 0.645004537f, + 0.763188417f, 0.646176013f, + 0.762196298f, 0.647345969f, + 0.761202385f, 0.648514401f, + 0.760206682f, 0.649681307f, + 0.759209189f, 0.650846685f, + 0.758209910f, 0.652010531f, + 0.757208847f, 0.653172843f, + 0.756206001f, 0.654333618f, + 0.755201377f, 0.655492853f, + 0.754194975f, 0.656650546f, + 0.753186799f, 0.657806693f, + 0.752176850f, 0.658961293f, + 0.751165132f, 0.660114342f, + 0.750151646f, 0.661265838f, + 0.749136395f, 0.662415778f, + 0.748119380f, 0.663564159f, + 0.747100606f, 0.664710978f, + 0.746080074f, 0.665856234f, + 0.745057785f, 0.666999922f, + 0.744033744f, 0.668142041f, + 0.743007952f, 0.669282588f, + 0.741980412f, 0.670421560f, + 0.740951125f, 0.671558955f, + 0.739920095f, 0.672694769f, + 0.738887324f, 0.673829000f, + 0.737852815f, 0.674961646f, + 0.736816569f, 0.676092704f, + 0.735778589f, 0.677222170f, + 0.734738878f, 0.678350043f, + 0.733697438f, 0.679476320f, + 0.732654272f, 0.680600998f, + 0.731609381f, 0.681724074f, + 0.730562769f, 0.682845546f, + 0.729514438f, 0.683965412f, + 0.728464390f, 0.685083668f, + 0.727412629f, 0.686200312f, + 0.726359155f, 0.687315341f, + 0.725303972f, 0.688428753f, + 0.724247083f, 0.689540545f, + 0.723188489f, 0.690650714f, + 0.722128194f, 0.691759258f, + 0.721066199f, 0.692866175f, + 0.720002508f, 0.693971461f, + 0.718937122f, 0.695075114f, + 0.717870045f, 0.696177131f, + 0.716801279f, 0.697277511f, + 0.715730825f, 0.698376249f, + 0.714658688f, 0.699473345f, + 0.713584869f, 0.700568794f, + 0.712509371f, 0.701662595f, + 0.711432196f, 0.702754744f, + 0.710353347f, 0.703845241f, + 0.709272826f, 0.704934080f, + 0.708190637f, 0.706021261f, + 0.707106781f, 0.707106781f, + 0.706021261f, 0.708190637f, + 0.704934080f, 0.709272826f, + 0.703845241f, 0.710353347f, + 0.702754744f, 0.711432196f, + 0.701662595f, 0.712509371f, + 0.700568794f, 0.713584869f, + 0.699473345f, 0.714658688f, + 0.698376249f, 0.715730825f, + 0.697277511f, 0.716801279f, + 0.696177131f, 0.717870045f, + 0.695075114f, 0.718937122f, + 0.693971461f, 0.720002508f, + 0.692866175f, 0.721066199f, + 0.691759258f, 0.722128194f, + 0.690650714f, 0.723188489f, + 0.689540545f, 0.724247083f, + 0.688428753f, 0.725303972f, + 0.687315341f, 0.726359155f, + 0.686200312f, 0.727412629f, + 0.685083668f, 0.728464390f, + 0.683965412f, 0.729514438f, + 0.682845546f, 0.730562769f, + 0.681724074f, 0.731609381f, + 0.680600998f, 0.732654272f, + 0.679476320f, 0.733697438f, + 0.678350043f, 0.734738878f, + 0.677222170f, 0.735778589f, + 0.676092704f, 0.736816569f, + 0.674961646f, 0.737852815f, + 0.673829000f, 0.738887324f, + 0.672694769f, 0.739920095f, + 0.671558955f, 0.740951125f, + 0.670421560f, 0.741980412f, + 0.669282588f, 0.743007952f, + 0.668142041f, 0.744033744f, + 0.666999922f, 0.745057785f, + 0.665856234f, 0.746080074f, + 0.664710978f, 0.747100606f, + 0.663564159f, 0.748119380f, + 0.662415778f, 0.749136395f, + 0.661265838f, 0.750151646f, + 0.660114342f, 0.751165132f, + 0.658961293f, 0.752176850f, + 0.657806693f, 0.753186799f, + 0.656650546f, 0.754194975f, + 0.655492853f, 0.755201377f, + 0.654333618f, 0.756206001f, + 0.653172843f, 0.757208847f, + 0.652010531f, 0.758209910f, + 0.650846685f, 0.759209189f, + 0.649681307f, 0.760206682f, + 0.648514401f, 0.761202385f, + 0.647345969f, 0.762196298f, + 0.646176013f, 0.763188417f, + 0.645004537f, 0.764178741f, + 0.643831543f, 0.765167266f, + 0.642657034f, 0.766153990f, + 0.641481013f, 0.767138912f, + 0.640303482f, 0.768122029f, + 0.639124445f, 0.769103338f, + 0.637943904f, 0.770082837f, + 0.636761861f, 0.771060524f, + 0.635578320f, 0.772036397f, + 0.634393284f, 0.773010453f, + 0.633206755f, 0.773982691f, + 0.632018736f, 0.774953107f, + 0.630829230f, 0.775921699f, + 0.629638239f, 0.776888466f, + 0.628445767f, 0.777853404f, + 0.627251815f, 0.778816512f, + 0.626056388f, 0.779777788f, + 0.624859488f, 0.780737229f, + 0.623661118f, 0.781694832f, + 0.622461279f, 0.782650596f, + 0.621259977f, 0.783604519f, + 0.620057212f, 0.784556597f, + 0.618852988f, 0.785506830f, + 0.617647308f, 0.786455214f, + 0.616440175f, 0.787401747f, + 0.615231591f, 0.788346428f, + 0.614021559f, 0.789289253f, + 0.612810082f, 0.790230221f, + 0.611597164f, 0.791169330f, + 0.610382806f, 0.792106577f, + 0.609167012f, 0.793041960f, + 0.607949785f, 0.793975478f, + 0.606731127f, 0.794907126f, + 0.605511041f, 0.795836905f, + 0.604289531f, 0.796764810f, + 0.603066599f, 0.797690841f, + 0.601842247f, 0.798614995f, + 0.600616479f, 0.799537269f, + 0.599389298f, 0.800457662f, + 0.598160707f, 0.801376172f, + 0.596930708f, 0.802292796f, + 0.595699304f, 0.803207531f, + 0.594466499f, 0.804120377f, + 0.593232295f, 0.805031331f, + 0.591996695f, 0.805940391f, + 0.590759702f, 0.806847554f, + 0.589521319f, 0.807752818f, + 0.588281548f, 0.808656182f, + 0.587040394f, 0.809557642f, + 0.585797857f, 0.810457198f, + 0.584553943f, 0.811354847f, + 0.583308653f, 0.812250587f, + 0.582061990f, 0.813144415f, + 0.580813958f, 0.814036330f, + 0.579564559f, 0.814926329f, + 0.578313796f, 0.815814411f, + 0.577061673f, 0.816700573f, + 0.575808191f, 0.817584813f, + 0.574553355f, 0.818467130f, + 0.573297167f, 0.819347520f, + 0.572039629f, 0.820225983f, + 0.570780746f, 0.821102515f, + 0.569520519f, 0.821977115f, + 0.568258953f, 0.822849781f, + 0.566996049f, 0.823720511f, + 0.565731811f, 0.824589303f, + 0.564466242f, 0.825456154f, + 0.563199344f, 0.826321063f, + 0.561931121f, 0.827184027f, + 0.560661576f, 0.828045045f, + 0.559390712f, 0.828904115f, + 0.558118531f, 0.829761234f, + 0.556845037f, 0.830616400f, + 0.555570233f, 0.831469612f, + 0.554294121f, 0.832320868f, + 0.553016706f, 0.833170165f, + 0.551737988f, 0.834017501f, + 0.550457973f, 0.834862875f, + 0.549176662f, 0.835706284f, + 0.547894059f, 0.836547727f, + 0.546610167f, 0.837387202f, + 0.545324988f, 0.838224706f, + 0.544038527f, 0.839060237f, + 0.542750785f, 0.839893794f, + 0.541461766f, 0.840725375f, + 0.540171473f, 0.841554977f, + 0.538879909f, 0.842382600f, + 0.537587076f, 0.843208240f, + 0.536292979f, 0.844031895f, + 0.534997620f, 0.844853565f, + 0.533701002f, 0.845673247f, + 0.532403128f, 0.846490939f, + 0.531104001f, 0.847306639f, + 0.529803625f, 0.848120345f, + 0.528502002f, 0.848932055f, + 0.527199135f, 0.849741768f, + 0.525895027f, 0.850549481f, + 0.524589683f, 0.851355193f, + 0.523283103f, 0.852158902f, + 0.521975293f, 0.852960605f, + 0.520666254f, 0.853760301f, + 0.519355990f, 0.854557988f, + 0.518044504f, 0.855353665f, + 0.516731799f, 0.856147328f, + 0.515417878f, 0.856938977f, + 0.514102744f, 0.857728610f, + 0.512786401f, 0.858516224f, + 0.511468850f, 0.859301818f, + 0.510150097f, 0.860085390f, + 0.508830143f, 0.860866939f, + 0.507508991f, 0.861646461f, + 0.506186645f, 0.862423956f, + 0.504863109f, 0.863199422f, + 0.503538384f, 0.863972856f, + 0.502212474f, 0.864744258f, + 0.500885383f, 0.865513624f, + 0.499557113f, 0.866280954f, + 0.498227667f, 0.867046246f, + 0.496897049f, 0.867809497f, + 0.495565262f, 0.868570706f, + 0.494232309f, 0.869329871f, + 0.492898192f, 0.870086991f, + 0.491562916f, 0.870842063f, + 0.490226483f, 0.871595087f, + 0.488888897f, 0.872346059f, + 0.487550160f, 0.873094978f, + 0.486210276f, 0.873841843f, + 0.484869248f, 0.874586652f, + 0.483527079f, 0.875329403f, + 0.482183772f, 0.876070094f, + 0.480839331f, 0.876808724f, + 0.479493758f, 0.877545290f, + 0.478147056f, 0.878279792f, + 0.476799230f, 0.879012226f, + 0.475450282f, 0.879742593f, + 0.474100215f, 0.880470889f, + 0.472749032f, 0.881197113f, + 0.471396737f, 0.881921264f, + 0.470043332f, 0.882643340f, + 0.468688822f, 0.883363339f, + 0.467333209f, 0.884081259f, + 0.465976496f, 0.884797098f, + 0.464618686f, 0.885510856f, + 0.463259784f, 0.886222530f, + 0.461899791f, 0.886932119f, + 0.460538711f, 0.887639620f, + 0.459176548f, 0.888345033f, + 0.457813304f, 0.889048356f, + 0.456448982f, 0.889749586f, + 0.455083587f, 0.890448723f, + 0.453717121f, 0.891145765f, + 0.452349587f, 0.891840709f, + 0.450980989f, 0.892533555f, + 0.449611330f, 0.893224301f, + 0.448240612f, 0.893912945f, + 0.446868840f, 0.894599486f, + 0.445496017f, 0.895283921f, + 0.444122145f, 0.895966250f, + 0.442747228f, 0.896646470f, + 0.441371269f, 0.897324581f, + 0.439994271f, 0.898000580f, + 0.438616239f, 0.898674466f, + 0.437237174f, 0.899346237f, + 0.435857080f, 0.900015892f, + 0.434475961f, 0.900683429f, + 0.433093819f, 0.901348847f, + 0.431710658f, 0.902012144f, + 0.430326481f, 0.902673318f, + 0.428941292f, 0.903332368f, + 0.427555093f, 0.903989293f, + 0.426167889f, 0.904644091f, + 0.424779681f, 0.905296759f, + 0.423390474f, 0.905947298f, + 0.422000271f, 0.906595705f, + 0.420609074f, 0.907241978f, + 0.419216888f, 0.907886116f, + 0.417823716f, 0.908528119f, + 0.416429560f, 0.909167983f, + 0.415034424f, 0.909805708f, + 0.413638312f, 0.910441292f, + 0.412241227f, 0.911074734f, + 0.410843171f, 0.911706032f, + 0.409444149f, 0.912335185f, + 0.408044163f, 0.912962190f, + 0.406643217f, 0.913587048f, + 0.405241314f, 0.914209756f, + 0.403838458f, 0.914830312f, + 0.402434651f, 0.915448716f, + 0.401029897f, 0.916064966f, + 0.399624200f, 0.916679060f, + 0.398217562f, 0.917290997f, + 0.396809987f, 0.917900776f, + 0.395401479f, 0.918508394f, + 0.393992040f, 0.919113852f, + 0.392581674f, 0.919717146f, + 0.391170384f, 0.920318277f, + 0.389758174f, 0.920917242f, + 0.388345047f, 0.921514039f, + 0.386931006f, 0.922108669f, + 0.385516054f, 0.922701128f, + 0.384100195f, 0.923291417f, + 0.382683432f, 0.923879533f, + 0.381265769f, 0.924465474f, + 0.379847209f, 0.925049241f, + 0.378427755f, 0.925630831f, + 0.377007410f, 0.926210242f, + 0.375586178f, 0.926787474f, + 0.374164063f, 0.927362526f, + 0.372741067f, 0.927935395f, + 0.371317194f, 0.928506080f, + 0.369892447f, 0.929074581f, + 0.368466830f, 0.929640896f, + 0.367040346f, 0.930205023f, + 0.365612998f, 0.930766961f, + 0.364184790f, 0.931326709f, + 0.362755724f, 0.931884266f, + 0.361325806f, 0.932439629f, + 0.359895037f, 0.932992799f, + 0.358463421f, 0.933543773f, + 0.357030961f, 0.934092550f, + 0.355597662f, 0.934639130f, + 0.354163525f, 0.935183510f, + 0.352728556f, 0.935725689f, + 0.351292756f, 0.936265667f, + 0.349856130f, 0.936803442f, + 0.348418680f, 0.937339012f, + 0.346980411f, 0.937872376f, + 0.345541325f, 0.938403534f, + 0.344101426f, 0.938932484f, + 0.342660717f, 0.939459224f, + 0.341219202f, 0.939983753f, + 0.339776884f, 0.940506071f, + 0.338333767f, 0.941026175f, + 0.336889853f, 0.941544065f, + 0.335445147f, 0.942059740f, + 0.333999651f, 0.942573198f, + 0.332553370f, 0.943084437f, + 0.331106306f, 0.943593458f, + 0.329658463f, 0.944100258f, + 0.328209844f, 0.944604837f, + 0.326760452f, 0.945107193f, + 0.325310292f, 0.945607325f, + 0.323859367f, 0.946105232f, + 0.322407679f, 0.946600913f, + 0.320955232f, 0.947094366f, + 0.319502031f, 0.947585591f, + 0.318048077f, 0.948074586f, + 0.316593376f, 0.948561350f, + 0.315137929f, 0.949045882f, + 0.313681740f, 0.949528181f, + 0.312224814f, 0.950008245f, + 0.310767153f, 0.950486074f, + 0.309308760f, 0.950961666f, + 0.307849640f, 0.951435021f, + 0.306389795f, 0.951906137f, + 0.304929230f, 0.952375013f, + 0.303467947f, 0.952841648f, + 0.302005949f, 0.953306040f, + 0.300543241f, 0.953768190f, + 0.299079826f, 0.954228095f, + 0.297615707f, 0.954685755f, + 0.296150888f, 0.955141168f, + 0.294685372f, 0.955594334f, + 0.293219163f, 0.956045251f, + 0.291752263f, 0.956493919f, + 0.290284677f, 0.956940336f, + 0.288816408f, 0.957384501f, + 0.287347460f, 0.957826413f, + 0.285877835f, 0.958266071f, + 0.284407537f, 0.958703475f, + 0.282936570f, 0.959138622f, + 0.281464938f, 0.959571513f, + 0.279992643f, 0.960002146f, + 0.278519689f, 0.960430519f, + 0.277046080f, 0.960856633f, + 0.275571819f, 0.961280486f, + 0.274096910f, 0.961702077f, + 0.272621355f, 0.962121404f, + 0.271145160f, 0.962538468f, + 0.269668326f, 0.962953267f, + 0.268190857f, 0.963365800f, + 0.266712757f, 0.963776066f, + 0.265234030f, 0.964184064f, + 0.263754679f, 0.964589793f, + 0.262274707f, 0.964993253f, + 0.260794118f, 0.965394442f, + 0.259312915f, 0.965793359f, + 0.257831102f, 0.966190003f, + 0.256348682f, 0.966584374f, + 0.254865660f, 0.966976471f, + 0.253382037f, 0.967366292f, + 0.251897818f, 0.967753837f, + 0.250413007f, 0.968139105f, + 0.248927606f, 0.968522094f, + 0.247441619f, 0.968902805f, + 0.245955050f, 0.969281235f, + 0.244467903f, 0.969657385f, + 0.242980180f, 0.970031253f, + 0.241491885f, 0.970402839f, + 0.240003022f, 0.970772141f, + 0.238513595f, 0.971139158f, + 0.237023606f, 0.971503891f, + 0.235533059f, 0.971866337f, + 0.234041959f, 0.972226497f, + 0.232550307f, 0.972584369f, + 0.231058108f, 0.972939952f, + 0.229565366f, 0.973293246f, + 0.228072083f, 0.973644250f, + 0.226578264f, 0.973992962f, + 0.225083911f, 0.974339383f, + 0.223589029f, 0.974683511f, + 0.222093621f, 0.975025345f, + 0.220597690f, 0.975364885f, + 0.219101240f, 0.975702130f, + 0.217604275f, 0.976037079f, + 0.216106797f, 0.976369731f, + 0.214608811f, 0.976700086f, + 0.213110320f, 0.977028143f, + 0.211611327f, 0.977353900f, + 0.210111837f, 0.977677358f, + 0.208611852f, 0.977998515f, + 0.207111376f, 0.978317371f, + 0.205610413f, 0.978633924f, + 0.204108966f, 0.978948175f, + 0.202607039f, 0.979260123f, + 0.201104635f, 0.979569766f, + 0.199601758f, 0.979877104f, + 0.198098411f, 0.980182136f, + 0.196594598f, 0.980484862f, + 0.195090322f, 0.980785280f, + 0.193585587f, 0.981083391f, + 0.192080397f, 0.981379193f, + 0.190574755f, 0.981672686f, + 0.189068664f, 0.981963869f, + 0.187562129f, 0.982252741f, + 0.186055152f, 0.982539302f, + 0.184547737f, 0.982823551f, + 0.183039888f, 0.983105487f, + 0.181531608f, 0.983385110f, + 0.180022901f, 0.983662419f, + 0.178513771f, 0.983937413f, + 0.177004220f, 0.984210092f, + 0.175494253f, 0.984480455f, + 0.173983873f, 0.984748502f, + 0.172473084f, 0.985014231f, + 0.170961889f, 0.985277642f, + 0.169450291f, 0.985538735f, + 0.167938295f, 0.985797509f, + 0.166425904f, 0.986053963f, + 0.164913120f, 0.986308097f, + 0.163399949f, 0.986559910f, + 0.161886394f, 0.986809402f, + 0.160372457f, 0.987056571f, + 0.158858143f, 0.987301418f, + 0.157343456f, 0.987543942f, + 0.155828398f, 0.987784142f, + 0.154312973f, 0.988022017f, + 0.152797185f, 0.988257568f, + 0.151281038f, 0.988490793f, + 0.149764535f, 0.988721692f, + 0.148247679f, 0.988950265f, + 0.146730474f, 0.989176510f, + 0.145212925f, 0.989400428f, + 0.143695033f, 0.989622017f, + 0.142176804f, 0.989841278f, + 0.140658239f, 0.990058210f, + 0.139139344f, 0.990272812f, + 0.137620122f, 0.990485084f, + 0.136100575f, 0.990695025f, + 0.134580709f, 0.990902635f, + 0.133060525f, 0.991107914f, + 0.131540029f, 0.991310860f, + 0.130019223f, 0.991511473f, + 0.128498111f, 0.991709754f, + 0.126976696f, 0.991905700f, + 0.125454983f, 0.992099313f, + 0.123932975f, 0.992290591f, + 0.122410675f, 0.992479535f, + 0.120888087f, 0.992666142f, + 0.119365215f, 0.992850414f, + 0.117842062f, 0.993032350f, + 0.116318631f, 0.993211949f, + 0.114794927f, 0.993389211f, + 0.113270952f, 0.993564136f, + 0.111746711f, 0.993736722f, + 0.110222207f, 0.993906970f, + 0.108697444f, 0.994074879f, + 0.107172425f, 0.994240449f, + 0.105647154f, 0.994403680f, + 0.104121634f, 0.994564571f, + 0.102595869f, 0.994723121f, + 0.101069863f, 0.994879331f, + 0.099543619f, 0.995033199f, + 0.098017140f, 0.995184727f, + 0.096490431f, 0.995333912f, + 0.094963495f, 0.995480755f, + 0.093436336f, 0.995625256f, + 0.091908956f, 0.995767414f, + 0.090381361f, 0.995907229f, + 0.088853553f, 0.996044701f, + 0.087325535f, 0.996179829f, + 0.085797312f, 0.996312612f, + 0.084268888f, 0.996443051f, + 0.082740265f, 0.996571146f, + 0.081211447f, 0.996696895f, + 0.079682438f, 0.996820299f, + 0.078153242f, 0.996941358f, + 0.076623861f, 0.997060070f, + 0.075094301f, 0.997176437f, + 0.073564564f, 0.997290457f, + 0.072034653f, 0.997402130f, + 0.070504573f, 0.997511456f, + 0.068974328f, 0.997618435f, + 0.067443920f, 0.997723067f, + 0.065913353f, 0.997825350f, + 0.064382631f, 0.997925286f, + 0.062851758f, 0.998022874f, + 0.061320736f, 0.998118113f, + 0.059789571f, 0.998211003f, + 0.058258265f, 0.998301545f, + 0.056726821f, 0.998389737f, + 0.055195244f, 0.998475581f, + 0.053663538f, 0.998559074f, + 0.052131705f, 0.998640218f, + 0.050599749f, 0.998719012f, + 0.049067674f, 0.998795456f, + 0.047535484f, 0.998869550f, + 0.046003182f, 0.998941293f, + 0.044470772f, 0.999010686f, + 0.042938257f, 0.999077728f, + 0.041405641f, 0.999142419f, + 0.039872928f, 0.999204759f, + 0.038340120f, 0.999264747f, + 0.036807223f, 0.999322385f, + 0.035274239f, 0.999377670f, + 0.033741172f, 0.999430605f, + 0.032208025f, 0.999481187f, + 0.030674803f, 0.999529418f, + 0.029141509f, 0.999575296f, + 0.027608146f, 0.999618822f, + 0.026074718f, 0.999659997f, + 0.024541229f, 0.999698819f, + 0.023007681f, 0.999735288f, + 0.021474080f, 0.999769405f, + 0.019940429f, 0.999801170f, + 0.018406730f, 0.999830582f, + 0.016872988f, 0.999857641f, + 0.015339206f, 0.999882347f, + 0.013805389f, 0.999904701f, + 0.012271538f, 0.999924702f, + 0.010737659f, 0.999942350f, + 0.009203755f, 0.999957645f, + 0.007669829f, 0.999970586f, + 0.006135885f, 0.999981175f, + 0.004601926f, 0.999989411f, + 0.003067957f, 0.999995294f, + 0.001533980f, 0.999998823f, + 0.000000000f, 1.000000000f, + -0.001533980f, 0.999998823f, + -0.003067957f, 0.999995294f, + -0.004601926f, 0.999989411f, + -0.006135885f, 0.999981175f, + -0.007669829f, 0.999970586f, + -0.009203755f, 0.999957645f, + -0.010737659f, 0.999942350f, + -0.012271538f, 0.999924702f, + -0.013805389f, 0.999904701f, + -0.015339206f, 0.999882347f, + -0.016872988f, 0.999857641f, + -0.018406730f, 0.999830582f, + -0.019940429f, 0.999801170f, + -0.021474080f, 0.999769405f, + -0.023007681f, 0.999735288f, + -0.024541229f, 0.999698819f, + -0.026074718f, 0.999659997f, + -0.027608146f, 0.999618822f, + -0.029141509f, 0.999575296f, + -0.030674803f, 0.999529418f, + -0.032208025f, 0.999481187f, + -0.033741172f, 0.999430605f, + -0.035274239f, 0.999377670f, + -0.036807223f, 0.999322385f, + -0.038340120f, 0.999264747f, + -0.039872928f, 0.999204759f, + -0.041405641f, 0.999142419f, + -0.042938257f, 0.999077728f, + -0.044470772f, 0.999010686f, + -0.046003182f, 0.998941293f, + -0.047535484f, 0.998869550f, + -0.049067674f, 0.998795456f, + -0.050599749f, 0.998719012f, + -0.052131705f, 0.998640218f, + -0.053663538f, 0.998559074f, + -0.055195244f, 0.998475581f, + -0.056726821f, 0.998389737f, + -0.058258265f, 0.998301545f, + -0.059789571f, 0.998211003f, + -0.061320736f, 0.998118113f, + -0.062851758f, 0.998022874f, + -0.064382631f, 0.997925286f, + -0.065913353f, 0.997825350f, + -0.067443920f, 0.997723067f, + -0.068974328f, 0.997618435f, + -0.070504573f, 0.997511456f, + -0.072034653f, 0.997402130f, + -0.073564564f, 0.997290457f, + -0.075094301f, 0.997176437f, + -0.076623861f, 0.997060070f, + -0.078153242f, 0.996941358f, + -0.079682438f, 0.996820299f, + -0.081211447f, 0.996696895f, + -0.082740265f, 0.996571146f, + -0.084268888f, 0.996443051f, + -0.085797312f, 0.996312612f, + -0.087325535f, 0.996179829f, + -0.088853553f, 0.996044701f, + -0.090381361f, 0.995907229f, + -0.091908956f, 0.995767414f, + -0.093436336f, 0.995625256f, + -0.094963495f, 0.995480755f, + -0.096490431f, 0.995333912f, + -0.098017140f, 0.995184727f, + -0.099543619f, 0.995033199f, + -0.101069863f, 0.994879331f, + -0.102595869f, 0.994723121f, + -0.104121634f, 0.994564571f, + -0.105647154f, 0.994403680f, + -0.107172425f, 0.994240449f, + -0.108697444f, 0.994074879f, + -0.110222207f, 0.993906970f, + -0.111746711f, 0.993736722f, + -0.113270952f, 0.993564136f, + -0.114794927f, 0.993389211f, + -0.116318631f, 0.993211949f, + -0.117842062f, 0.993032350f, + -0.119365215f, 0.992850414f, + -0.120888087f, 0.992666142f, + -0.122410675f, 0.992479535f, + -0.123932975f, 0.992290591f, + -0.125454983f, 0.992099313f, + -0.126976696f, 0.991905700f, + -0.128498111f, 0.991709754f, + -0.130019223f, 0.991511473f, + -0.131540029f, 0.991310860f, + -0.133060525f, 0.991107914f, + -0.134580709f, 0.990902635f, + -0.136100575f, 0.990695025f, + -0.137620122f, 0.990485084f, + -0.139139344f, 0.990272812f, + -0.140658239f, 0.990058210f, + -0.142176804f, 0.989841278f, + -0.143695033f, 0.989622017f, + -0.145212925f, 0.989400428f, + -0.146730474f, 0.989176510f, + -0.148247679f, 0.988950265f, + -0.149764535f, 0.988721692f, + -0.151281038f, 0.988490793f, + -0.152797185f, 0.988257568f, + -0.154312973f, 0.988022017f, + -0.155828398f, 0.987784142f, + -0.157343456f, 0.987543942f, + -0.158858143f, 0.987301418f, + -0.160372457f, 0.987056571f, + -0.161886394f, 0.986809402f, + -0.163399949f, 0.986559910f, + -0.164913120f, 0.986308097f, + -0.166425904f, 0.986053963f, + -0.167938295f, 0.985797509f, + -0.169450291f, 0.985538735f, + -0.170961889f, 0.985277642f, + -0.172473084f, 0.985014231f, + -0.173983873f, 0.984748502f, + -0.175494253f, 0.984480455f, + -0.177004220f, 0.984210092f, + -0.178513771f, 0.983937413f, + -0.180022901f, 0.983662419f, + -0.181531608f, 0.983385110f, + -0.183039888f, 0.983105487f, + -0.184547737f, 0.982823551f, + -0.186055152f, 0.982539302f, + -0.187562129f, 0.982252741f, + -0.189068664f, 0.981963869f, + -0.190574755f, 0.981672686f, + -0.192080397f, 0.981379193f, + -0.193585587f, 0.981083391f, + -0.195090322f, 0.980785280f, + -0.196594598f, 0.980484862f, + -0.198098411f, 0.980182136f, + -0.199601758f, 0.979877104f, + -0.201104635f, 0.979569766f, + -0.202607039f, 0.979260123f, + -0.204108966f, 0.978948175f, + -0.205610413f, 0.978633924f, + -0.207111376f, 0.978317371f, + -0.208611852f, 0.977998515f, + -0.210111837f, 0.977677358f, + -0.211611327f, 0.977353900f, + -0.213110320f, 0.977028143f, + -0.214608811f, 0.976700086f, + -0.216106797f, 0.976369731f, + -0.217604275f, 0.976037079f, + -0.219101240f, 0.975702130f, + -0.220597690f, 0.975364885f, + -0.222093621f, 0.975025345f, + -0.223589029f, 0.974683511f, + -0.225083911f, 0.974339383f, + -0.226578264f, 0.973992962f, + -0.228072083f, 0.973644250f, + -0.229565366f, 0.973293246f, + -0.231058108f, 0.972939952f, + -0.232550307f, 0.972584369f, + -0.234041959f, 0.972226497f, + -0.235533059f, 0.971866337f, + -0.237023606f, 0.971503891f, + -0.238513595f, 0.971139158f, + -0.240003022f, 0.970772141f, + -0.241491885f, 0.970402839f, + -0.242980180f, 0.970031253f, + -0.244467903f, 0.969657385f, + -0.245955050f, 0.969281235f, + -0.247441619f, 0.968902805f, + -0.248927606f, 0.968522094f, + -0.250413007f, 0.968139105f, + -0.251897818f, 0.967753837f, + -0.253382037f, 0.967366292f, + -0.254865660f, 0.966976471f, + -0.256348682f, 0.966584374f, + -0.257831102f, 0.966190003f, + -0.259312915f, 0.965793359f, + -0.260794118f, 0.965394442f, + -0.262274707f, 0.964993253f, + -0.263754679f, 0.964589793f, + -0.265234030f, 0.964184064f, + -0.266712757f, 0.963776066f, + -0.268190857f, 0.963365800f, + -0.269668326f, 0.962953267f, + -0.271145160f, 0.962538468f, + -0.272621355f, 0.962121404f, + -0.274096910f, 0.961702077f, + -0.275571819f, 0.961280486f, + -0.277046080f, 0.960856633f, + -0.278519689f, 0.960430519f, + -0.279992643f, 0.960002146f, + -0.281464938f, 0.959571513f, + -0.282936570f, 0.959138622f, + -0.284407537f, 0.958703475f, + -0.285877835f, 0.958266071f, + -0.287347460f, 0.957826413f, + -0.288816408f, 0.957384501f, + -0.290284677f, 0.956940336f, + -0.291752263f, 0.956493919f, + -0.293219163f, 0.956045251f, + -0.294685372f, 0.955594334f, + -0.296150888f, 0.955141168f, + -0.297615707f, 0.954685755f, + -0.299079826f, 0.954228095f, + -0.300543241f, 0.953768190f, + -0.302005949f, 0.953306040f, + -0.303467947f, 0.952841648f, + -0.304929230f, 0.952375013f, + -0.306389795f, 0.951906137f, + -0.307849640f, 0.951435021f, + -0.309308760f, 0.950961666f, + -0.310767153f, 0.950486074f, + -0.312224814f, 0.950008245f, + -0.313681740f, 0.949528181f, + -0.315137929f, 0.949045882f, + -0.316593376f, 0.948561350f, + -0.318048077f, 0.948074586f, + -0.319502031f, 0.947585591f, + -0.320955232f, 0.947094366f, + -0.322407679f, 0.946600913f, + -0.323859367f, 0.946105232f, + -0.325310292f, 0.945607325f, + -0.326760452f, 0.945107193f, + -0.328209844f, 0.944604837f, + -0.329658463f, 0.944100258f, + -0.331106306f, 0.943593458f, + -0.332553370f, 0.943084437f, + -0.333999651f, 0.942573198f, + -0.335445147f, 0.942059740f, + -0.336889853f, 0.941544065f, + -0.338333767f, 0.941026175f, + -0.339776884f, 0.940506071f, + -0.341219202f, 0.939983753f, + -0.342660717f, 0.939459224f, + -0.344101426f, 0.938932484f, + -0.345541325f, 0.938403534f, + -0.346980411f, 0.937872376f, + -0.348418680f, 0.937339012f, + -0.349856130f, 0.936803442f, + -0.351292756f, 0.936265667f, + -0.352728556f, 0.935725689f, + -0.354163525f, 0.935183510f, + -0.355597662f, 0.934639130f, + -0.357030961f, 0.934092550f, + -0.358463421f, 0.933543773f, + -0.359895037f, 0.932992799f, + -0.361325806f, 0.932439629f, + -0.362755724f, 0.931884266f, + -0.364184790f, 0.931326709f, + -0.365612998f, 0.930766961f, + -0.367040346f, 0.930205023f, + -0.368466830f, 0.929640896f, + -0.369892447f, 0.929074581f, + -0.371317194f, 0.928506080f, + -0.372741067f, 0.927935395f, + -0.374164063f, 0.927362526f, + -0.375586178f, 0.926787474f, + -0.377007410f, 0.926210242f, + -0.378427755f, 0.925630831f, + -0.379847209f, 0.925049241f, + -0.381265769f, 0.924465474f, + -0.382683432f, 0.923879533f, + -0.384100195f, 0.923291417f, + -0.385516054f, 0.922701128f, + -0.386931006f, 0.922108669f, + -0.388345047f, 0.921514039f, + -0.389758174f, 0.920917242f, + -0.391170384f, 0.920318277f, + -0.392581674f, 0.919717146f, + -0.393992040f, 0.919113852f, + -0.395401479f, 0.918508394f, + -0.396809987f, 0.917900776f, + -0.398217562f, 0.917290997f, + -0.399624200f, 0.916679060f, + -0.401029897f, 0.916064966f, + -0.402434651f, 0.915448716f, + -0.403838458f, 0.914830312f, + -0.405241314f, 0.914209756f, + -0.406643217f, 0.913587048f, + -0.408044163f, 0.912962190f, + -0.409444149f, 0.912335185f, + -0.410843171f, 0.911706032f, + -0.412241227f, 0.911074734f, + -0.413638312f, 0.910441292f, + -0.415034424f, 0.909805708f, + -0.416429560f, 0.909167983f, + -0.417823716f, 0.908528119f, + -0.419216888f, 0.907886116f, + -0.420609074f, 0.907241978f, + -0.422000271f, 0.906595705f, + -0.423390474f, 0.905947298f, + -0.424779681f, 0.905296759f, + -0.426167889f, 0.904644091f, + -0.427555093f, 0.903989293f, + -0.428941292f, 0.903332368f, + -0.430326481f, 0.902673318f, + -0.431710658f, 0.902012144f, + -0.433093819f, 0.901348847f, + -0.434475961f, 0.900683429f, + -0.435857080f, 0.900015892f, + -0.437237174f, 0.899346237f, + -0.438616239f, 0.898674466f, + -0.439994271f, 0.898000580f, + -0.441371269f, 0.897324581f, + -0.442747228f, 0.896646470f, + -0.444122145f, 0.895966250f, + -0.445496017f, 0.895283921f, + -0.446868840f, 0.894599486f, + -0.448240612f, 0.893912945f, + -0.449611330f, 0.893224301f, + -0.450980989f, 0.892533555f, + -0.452349587f, 0.891840709f, + -0.453717121f, 0.891145765f, + -0.455083587f, 0.890448723f, + -0.456448982f, 0.889749586f, + -0.457813304f, 0.889048356f, + -0.459176548f, 0.888345033f, + -0.460538711f, 0.887639620f, + -0.461899791f, 0.886932119f, + -0.463259784f, 0.886222530f, + -0.464618686f, 0.885510856f, + -0.465976496f, 0.884797098f, + -0.467333209f, 0.884081259f, + -0.468688822f, 0.883363339f, + -0.470043332f, 0.882643340f, + -0.471396737f, 0.881921264f, + -0.472749032f, 0.881197113f, + -0.474100215f, 0.880470889f, + -0.475450282f, 0.879742593f, + -0.476799230f, 0.879012226f, + -0.478147056f, 0.878279792f, + -0.479493758f, 0.877545290f, + -0.480839331f, 0.876808724f, + -0.482183772f, 0.876070094f, + -0.483527079f, 0.875329403f, + -0.484869248f, 0.874586652f, + -0.486210276f, 0.873841843f, + -0.487550160f, 0.873094978f, + -0.488888897f, 0.872346059f, + -0.490226483f, 0.871595087f, + -0.491562916f, 0.870842063f, + -0.492898192f, 0.870086991f, + -0.494232309f, 0.869329871f, + -0.495565262f, 0.868570706f, + -0.496897049f, 0.867809497f, + -0.498227667f, 0.867046246f, + -0.499557113f, 0.866280954f, + -0.500885383f, 0.865513624f, + -0.502212474f, 0.864744258f, + -0.503538384f, 0.863972856f, + -0.504863109f, 0.863199422f, + -0.506186645f, 0.862423956f, + -0.507508991f, 0.861646461f, + -0.508830143f, 0.860866939f, + -0.510150097f, 0.860085390f, + -0.511468850f, 0.859301818f, + -0.512786401f, 0.858516224f, + -0.514102744f, 0.857728610f, + -0.515417878f, 0.856938977f, + -0.516731799f, 0.856147328f, + -0.518044504f, 0.855353665f, + -0.519355990f, 0.854557988f, + -0.520666254f, 0.853760301f, + -0.521975293f, 0.852960605f, + -0.523283103f, 0.852158902f, + -0.524589683f, 0.851355193f, + -0.525895027f, 0.850549481f, + -0.527199135f, 0.849741768f, + -0.528502002f, 0.848932055f, + -0.529803625f, 0.848120345f, + -0.531104001f, 0.847306639f, + -0.532403128f, 0.846490939f, + -0.533701002f, 0.845673247f, + -0.534997620f, 0.844853565f, + -0.536292979f, 0.844031895f, + -0.537587076f, 0.843208240f, + -0.538879909f, 0.842382600f, + -0.540171473f, 0.841554977f, + -0.541461766f, 0.840725375f, + -0.542750785f, 0.839893794f, + -0.544038527f, 0.839060237f, + -0.545324988f, 0.838224706f, + -0.546610167f, 0.837387202f, + -0.547894059f, 0.836547727f, + -0.549176662f, 0.835706284f, + -0.550457973f, 0.834862875f, + -0.551737988f, 0.834017501f, + -0.553016706f, 0.833170165f, + -0.554294121f, 0.832320868f, + -0.555570233f, 0.831469612f, + -0.556845037f, 0.830616400f, + -0.558118531f, 0.829761234f, + -0.559390712f, 0.828904115f, + -0.560661576f, 0.828045045f, + -0.561931121f, 0.827184027f, + -0.563199344f, 0.826321063f, + -0.564466242f, 0.825456154f, + -0.565731811f, 0.824589303f, + -0.566996049f, 0.823720511f, + -0.568258953f, 0.822849781f, + -0.569520519f, 0.821977115f, + -0.570780746f, 0.821102515f, + -0.572039629f, 0.820225983f, + -0.573297167f, 0.819347520f, + -0.574553355f, 0.818467130f, + -0.575808191f, 0.817584813f, + -0.577061673f, 0.816700573f, + -0.578313796f, 0.815814411f, + -0.579564559f, 0.814926329f, + -0.580813958f, 0.814036330f, + -0.582061990f, 0.813144415f, + -0.583308653f, 0.812250587f, + -0.584553943f, 0.811354847f, + -0.585797857f, 0.810457198f, + -0.587040394f, 0.809557642f, + -0.588281548f, 0.808656182f, + -0.589521319f, 0.807752818f, + -0.590759702f, 0.806847554f, + -0.591996695f, 0.805940391f, + -0.593232295f, 0.805031331f, + -0.594466499f, 0.804120377f, + -0.595699304f, 0.803207531f, + -0.596930708f, 0.802292796f, + -0.598160707f, 0.801376172f, + -0.599389298f, 0.800457662f, + -0.600616479f, 0.799537269f, + -0.601842247f, 0.798614995f, + -0.603066599f, 0.797690841f, + -0.604289531f, 0.796764810f, + -0.605511041f, 0.795836905f, + -0.606731127f, 0.794907126f, + -0.607949785f, 0.793975478f, + -0.609167012f, 0.793041960f, + -0.610382806f, 0.792106577f, + -0.611597164f, 0.791169330f, + -0.612810082f, 0.790230221f, + -0.614021559f, 0.789289253f, + -0.615231591f, 0.788346428f, + -0.616440175f, 0.787401747f, + -0.617647308f, 0.786455214f, + -0.618852988f, 0.785506830f, + -0.620057212f, 0.784556597f, + -0.621259977f, 0.783604519f, + -0.622461279f, 0.782650596f, + -0.623661118f, 0.781694832f, + -0.624859488f, 0.780737229f, + -0.626056388f, 0.779777788f, + -0.627251815f, 0.778816512f, + -0.628445767f, 0.777853404f, + -0.629638239f, 0.776888466f, + -0.630829230f, 0.775921699f, + -0.632018736f, 0.774953107f, + -0.633206755f, 0.773982691f, + -0.634393284f, 0.773010453f, + -0.635578320f, 0.772036397f, + -0.636761861f, 0.771060524f, + -0.637943904f, 0.770082837f, + -0.639124445f, 0.769103338f, + -0.640303482f, 0.768122029f, + -0.641481013f, 0.767138912f, + -0.642657034f, 0.766153990f, + -0.643831543f, 0.765167266f, + -0.645004537f, 0.764178741f, + -0.646176013f, 0.763188417f, + -0.647345969f, 0.762196298f, + -0.648514401f, 0.761202385f, + -0.649681307f, 0.760206682f, + -0.650846685f, 0.759209189f, + -0.652010531f, 0.758209910f, + -0.653172843f, 0.757208847f, + -0.654333618f, 0.756206001f, + -0.655492853f, 0.755201377f, + -0.656650546f, 0.754194975f, + -0.657806693f, 0.753186799f, + -0.658961293f, 0.752176850f, + -0.660114342f, 0.751165132f, + -0.661265838f, 0.750151646f, + -0.662415778f, 0.749136395f, + -0.663564159f, 0.748119380f, + -0.664710978f, 0.747100606f, + -0.665856234f, 0.746080074f, + -0.666999922f, 0.745057785f, + -0.668142041f, 0.744033744f, + -0.669282588f, 0.743007952f, + -0.670421560f, 0.741980412f, + -0.671558955f, 0.740951125f, + -0.672694769f, 0.739920095f, + -0.673829000f, 0.738887324f, + -0.674961646f, 0.737852815f, + -0.676092704f, 0.736816569f, + -0.677222170f, 0.735778589f, + -0.678350043f, 0.734738878f, + -0.679476320f, 0.733697438f, + -0.680600998f, 0.732654272f, + -0.681724074f, 0.731609381f, + -0.682845546f, 0.730562769f, + -0.683965412f, 0.729514438f, + -0.685083668f, 0.728464390f, + -0.686200312f, 0.727412629f, + -0.687315341f, 0.726359155f, + -0.688428753f, 0.725303972f, + -0.689540545f, 0.724247083f, + -0.690650714f, 0.723188489f, + -0.691759258f, 0.722128194f, + -0.692866175f, 0.721066199f, + -0.693971461f, 0.720002508f, + -0.695075114f, 0.718937122f, + -0.696177131f, 0.717870045f, + -0.697277511f, 0.716801279f, + -0.698376249f, 0.715730825f, + -0.699473345f, 0.714658688f, + -0.700568794f, 0.713584869f, + -0.701662595f, 0.712509371f, + -0.702754744f, 0.711432196f, + -0.703845241f, 0.710353347f, + -0.704934080f, 0.709272826f, + -0.706021261f, 0.708190637f, + -0.707106781f, 0.707106781f, + -0.708190637f, 0.706021261f, + -0.709272826f, 0.704934080f, + -0.710353347f, 0.703845241f, + -0.711432196f, 0.702754744f, + -0.712509371f, 0.701662595f, + -0.713584869f, 0.700568794f, + -0.714658688f, 0.699473345f, + -0.715730825f, 0.698376249f, + -0.716801279f, 0.697277511f, + -0.717870045f, 0.696177131f, + -0.718937122f, 0.695075114f, + -0.720002508f, 0.693971461f, + -0.721066199f, 0.692866175f, + -0.722128194f, 0.691759258f, + -0.723188489f, 0.690650714f, + -0.724247083f, 0.689540545f, + -0.725303972f, 0.688428753f, + -0.726359155f, 0.687315341f, + -0.727412629f, 0.686200312f, + -0.728464390f, 0.685083668f, + -0.729514438f, 0.683965412f, + -0.730562769f, 0.682845546f, + -0.731609381f, 0.681724074f, + -0.732654272f, 0.680600998f, + -0.733697438f, 0.679476320f, + -0.734738878f, 0.678350043f, + -0.735778589f, 0.677222170f, + -0.736816569f, 0.676092704f, + -0.737852815f, 0.674961646f, + -0.738887324f, 0.673829000f, + -0.739920095f, 0.672694769f, + -0.740951125f, 0.671558955f, + -0.741980412f, 0.670421560f, + -0.743007952f, 0.669282588f, + -0.744033744f, 0.668142041f, + -0.745057785f, 0.666999922f, + -0.746080074f, 0.665856234f, + -0.747100606f, 0.664710978f, + -0.748119380f, 0.663564159f, + -0.749136395f, 0.662415778f, + -0.750151646f, 0.661265838f, + -0.751165132f, 0.660114342f, + -0.752176850f, 0.658961293f, + -0.753186799f, 0.657806693f, + -0.754194975f, 0.656650546f, + -0.755201377f, 0.655492853f, + -0.756206001f, 0.654333618f, + -0.757208847f, 0.653172843f, + -0.758209910f, 0.652010531f, + -0.759209189f, 0.650846685f, + -0.760206682f, 0.649681307f, + -0.761202385f, 0.648514401f, + -0.762196298f, 0.647345969f, + -0.763188417f, 0.646176013f, + -0.764178741f, 0.645004537f, + -0.765167266f, 0.643831543f, + -0.766153990f, 0.642657034f, + -0.767138912f, 0.641481013f, + -0.768122029f, 0.640303482f, + -0.769103338f, 0.639124445f, + -0.770082837f, 0.637943904f, + -0.771060524f, 0.636761861f, + -0.772036397f, 0.635578320f, + -0.773010453f, 0.634393284f, + -0.773982691f, 0.633206755f, + -0.774953107f, 0.632018736f, + -0.775921699f, 0.630829230f, + -0.776888466f, 0.629638239f, + -0.777853404f, 0.628445767f, + -0.778816512f, 0.627251815f, + -0.779777788f, 0.626056388f, + -0.780737229f, 0.624859488f, + -0.781694832f, 0.623661118f, + -0.782650596f, 0.622461279f, + -0.783604519f, 0.621259977f, + -0.784556597f, 0.620057212f, + -0.785506830f, 0.618852988f, + -0.786455214f, 0.617647308f, + -0.787401747f, 0.616440175f, + -0.788346428f, 0.615231591f, + -0.789289253f, 0.614021559f, + -0.790230221f, 0.612810082f, + -0.791169330f, 0.611597164f, + -0.792106577f, 0.610382806f, + -0.793041960f, 0.609167012f, + -0.793975478f, 0.607949785f, + -0.794907126f, 0.606731127f, + -0.795836905f, 0.605511041f, + -0.796764810f, 0.604289531f, + -0.797690841f, 0.603066599f, + -0.798614995f, 0.601842247f, + -0.799537269f, 0.600616479f, + -0.800457662f, 0.599389298f, + -0.801376172f, 0.598160707f, + -0.802292796f, 0.596930708f, + -0.803207531f, 0.595699304f, + -0.804120377f, 0.594466499f, + -0.805031331f, 0.593232295f, + -0.805940391f, 0.591996695f, + -0.806847554f, 0.590759702f, + -0.807752818f, 0.589521319f, + -0.808656182f, 0.588281548f, + -0.809557642f, 0.587040394f, + -0.810457198f, 0.585797857f, + -0.811354847f, 0.584553943f, + -0.812250587f, 0.583308653f, + -0.813144415f, 0.582061990f, + -0.814036330f, 0.580813958f, + -0.814926329f, 0.579564559f, + -0.815814411f, 0.578313796f, + -0.816700573f, 0.577061673f, + -0.817584813f, 0.575808191f, + -0.818467130f, 0.574553355f, + -0.819347520f, 0.573297167f, + -0.820225983f, 0.572039629f, + -0.821102515f, 0.570780746f, + -0.821977115f, 0.569520519f, + -0.822849781f, 0.568258953f, + -0.823720511f, 0.566996049f, + -0.824589303f, 0.565731811f, + -0.825456154f, 0.564466242f, + -0.826321063f, 0.563199344f, + -0.827184027f, 0.561931121f, + -0.828045045f, 0.560661576f, + -0.828904115f, 0.559390712f, + -0.829761234f, 0.558118531f, + -0.830616400f, 0.556845037f, + -0.831469612f, 0.555570233f, + -0.832320868f, 0.554294121f, + -0.833170165f, 0.553016706f, + -0.834017501f, 0.551737988f, + -0.834862875f, 0.550457973f, + -0.835706284f, 0.549176662f, + -0.836547727f, 0.547894059f, + -0.837387202f, 0.546610167f, + -0.838224706f, 0.545324988f, + -0.839060237f, 0.544038527f, + -0.839893794f, 0.542750785f, + -0.840725375f, 0.541461766f, + -0.841554977f, 0.540171473f, + -0.842382600f, 0.538879909f, + -0.843208240f, 0.537587076f, + -0.844031895f, 0.536292979f, + -0.844853565f, 0.534997620f, + -0.845673247f, 0.533701002f, + -0.846490939f, 0.532403128f, + -0.847306639f, 0.531104001f, + -0.848120345f, 0.529803625f, + -0.848932055f, 0.528502002f, + -0.849741768f, 0.527199135f, + -0.850549481f, 0.525895027f, + -0.851355193f, 0.524589683f, + -0.852158902f, 0.523283103f, + -0.852960605f, 0.521975293f, + -0.853760301f, 0.520666254f, + -0.854557988f, 0.519355990f, + -0.855353665f, 0.518044504f, + -0.856147328f, 0.516731799f, + -0.856938977f, 0.515417878f, + -0.857728610f, 0.514102744f, + -0.858516224f, 0.512786401f, + -0.859301818f, 0.511468850f, + -0.860085390f, 0.510150097f, + -0.860866939f, 0.508830143f, + -0.861646461f, 0.507508991f, + -0.862423956f, 0.506186645f, + -0.863199422f, 0.504863109f, + -0.863972856f, 0.503538384f, + -0.864744258f, 0.502212474f, + -0.865513624f, 0.500885383f, + -0.866280954f, 0.499557113f, + -0.867046246f, 0.498227667f, + -0.867809497f, 0.496897049f, + -0.868570706f, 0.495565262f, + -0.869329871f, 0.494232309f, + -0.870086991f, 0.492898192f, + -0.870842063f, 0.491562916f, + -0.871595087f, 0.490226483f, + -0.872346059f, 0.488888897f, + -0.873094978f, 0.487550160f, + -0.873841843f, 0.486210276f, + -0.874586652f, 0.484869248f, + -0.875329403f, 0.483527079f, + -0.876070094f, 0.482183772f, + -0.876808724f, 0.480839331f, + -0.877545290f, 0.479493758f, + -0.878279792f, 0.478147056f, + -0.879012226f, 0.476799230f, + -0.879742593f, 0.475450282f, + -0.880470889f, 0.474100215f, + -0.881197113f, 0.472749032f, + -0.881921264f, 0.471396737f, + -0.882643340f, 0.470043332f, + -0.883363339f, 0.468688822f, + -0.884081259f, 0.467333209f, + -0.884797098f, 0.465976496f, + -0.885510856f, 0.464618686f, + -0.886222530f, 0.463259784f, + -0.886932119f, 0.461899791f, + -0.887639620f, 0.460538711f, + -0.888345033f, 0.459176548f, + -0.889048356f, 0.457813304f, + -0.889749586f, 0.456448982f, + -0.890448723f, 0.455083587f, + -0.891145765f, 0.453717121f, + -0.891840709f, 0.452349587f, + -0.892533555f, 0.450980989f, + -0.893224301f, 0.449611330f, + -0.893912945f, 0.448240612f, + -0.894599486f, 0.446868840f, + -0.895283921f, 0.445496017f, + -0.895966250f, 0.444122145f, + -0.896646470f, 0.442747228f, + -0.897324581f, 0.441371269f, + -0.898000580f, 0.439994271f, + -0.898674466f, 0.438616239f, + -0.899346237f, 0.437237174f, + -0.900015892f, 0.435857080f, + -0.900683429f, 0.434475961f, + -0.901348847f, 0.433093819f, + -0.902012144f, 0.431710658f, + -0.902673318f, 0.430326481f, + -0.903332368f, 0.428941292f, + -0.903989293f, 0.427555093f, + -0.904644091f, 0.426167889f, + -0.905296759f, 0.424779681f, + -0.905947298f, 0.423390474f, + -0.906595705f, 0.422000271f, + -0.907241978f, 0.420609074f, + -0.907886116f, 0.419216888f, + -0.908528119f, 0.417823716f, + -0.909167983f, 0.416429560f, + -0.909805708f, 0.415034424f, + -0.910441292f, 0.413638312f, + -0.911074734f, 0.412241227f, + -0.911706032f, 0.410843171f, + -0.912335185f, 0.409444149f, + -0.912962190f, 0.408044163f, + -0.913587048f, 0.406643217f, + -0.914209756f, 0.405241314f, + -0.914830312f, 0.403838458f, + -0.915448716f, 0.402434651f, + -0.916064966f, 0.401029897f, + -0.916679060f, 0.399624200f, + -0.917290997f, 0.398217562f, + -0.917900776f, 0.396809987f, + -0.918508394f, 0.395401479f, + -0.919113852f, 0.393992040f, + -0.919717146f, 0.392581674f, + -0.920318277f, 0.391170384f, + -0.920917242f, 0.389758174f, + -0.921514039f, 0.388345047f, + -0.922108669f, 0.386931006f, + -0.922701128f, 0.385516054f, + -0.923291417f, 0.384100195f, + -0.923879533f, 0.382683432f, + -0.924465474f, 0.381265769f, + -0.925049241f, 0.379847209f, + -0.925630831f, 0.378427755f, + -0.926210242f, 0.377007410f, + -0.926787474f, 0.375586178f, + -0.927362526f, 0.374164063f, + -0.927935395f, 0.372741067f, + -0.928506080f, 0.371317194f, + -0.929074581f, 0.369892447f, + -0.929640896f, 0.368466830f, + -0.930205023f, 0.367040346f, + -0.930766961f, 0.365612998f, + -0.931326709f, 0.364184790f, + -0.931884266f, 0.362755724f, + -0.932439629f, 0.361325806f, + -0.932992799f, 0.359895037f, + -0.933543773f, 0.358463421f, + -0.934092550f, 0.357030961f, + -0.934639130f, 0.355597662f, + -0.935183510f, 0.354163525f, + -0.935725689f, 0.352728556f, + -0.936265667f, 0.351292756f, + -0.936803442f, 0.349856130f, + -0.937339012f, 0.348418680f, + -0.937872376f, 0.346980411f, + -0.938403534f, 0.345541325f, + -0.938932484f, 0.344101426f, + -0.939459224f, 0.342660717f, + -0.939983753f, 0.341219202f, + -0.940506071f, 0.339776884f, + -0.941026175f, 0.338333767f, + -0.941544065f, 0.336889853f, + -0.942059740f, 0.335445147f, + -0.942573198f, 0.333999651f, + -0.943084437f, 0.332553370f, + -0.943593458f, 0.331106306f, + -0.944100258f, 0.329658463f, + -0.944604837f, 0.328209844f, + -0.945107193f, 0.326760452f, + -0.945607325f, 0.325310292f, + -0.946105232f, 0.323859367f, + -0.946600913f, 0.322407679f, + -0.947094366f, 0.320955232f, + -0.947585591f, 0.319502031f, + -0.948074586f, 0.318048077f, + -0.948561350f, 0.316593376f, + -0.949045882f, 0.315137929f, + -0.949528181f, 0.313681740f, + -0.950008245f, 0.312224814f, + -0.950486074f, 0.310767153f, + -0.950961666f, 0.309308760f, + -0.951435021f, 0.307849640f, + -0.951906137f, 0.306389795f, + -0.952375013f, 0.304929230f, + -0.952841648f, 0.303467947f, + -0.953306040f, 0.302005949f, + -0.953768190f, 0.300543241f, + -0.954228095f, 0.299079826f, + -0.954685755f, 0.297615707f, + -0.955141168f, 0.296150888f, + -0.955594334f, 0.294685372f, + -0.956045251f, 0.293219163f, + -0.956493919f, 0.291752263f, + -0.956940336f, 0.290284677f, + -0.957384501f, 0.288816408f, + -0.957826413f, 0.287347460f, + -0.958266071f, 0.285877835f, + -0.958703475f, 0.284407537f, + -0.959138622f, 0.282936570f, + -0.959571513f, 0.281464938f, + -0.960002146f, 0.279992643f, + -0.960430519f, 0.278519689f, + -0.960856633f, 0.277046080f, + -0.961280486f, 0.275571819f, + -0.961702077f, 0.274096910f, + -0.962121404f, 0.272621355f, + -0.962538468f, 0.271145160f, + -0.962953267f, 0.269668326f, + -0.963365800f, 0.268190857f, + -0.963776066f, 0.266712757f, + -0.964184064f, 0.265234030f, + -0.964589793f, 0.263754679f, + -0.964993253f, 0.262274707f, + -0.965394442f, 0.260794118f, + -0.965793359f, 0.259312915f, + -0.966190003f, 0.257831102f, + -0.966584374f, 0.256348682f, + -0.966976471f, 0.254865660f, + -0.967366292f, 0.253382037f, + -0.967753837f, 0.251897818f, + -0.968139105f, 0.250413007f, + -0.968522094f, 0.248927606f, + -0.968902805f, 0.247441619f, + -0.969281235f, 0.245955050f, + -0.969657385f, 0.244467903f, + -0.970031253f, 0.242980180f, + -0.970402839f, 0.241491885f, + -0.970772141f, 0.240003022f, + -0.971139158f, 0.238513595f, + -0.971503891f, 0.237023606f, + -0.971866337f, 0.235533059f, + -0.972226497f, 0.234041959f, + -0.972584369f, 0.232550307f, + -0.972939952f, 0.231058108f, + -0.973293246f, 0.229565366f, + -0.973644250f, 0.228072083f, + -0.973992962f, 0.226578264f, + -0.974339383f, 0.225083911f, + -0.974683511f, 0.223589029f, + -0.975025345f, 0.222093621f, + -0.975364885f, 0.220597690f, + -0.975702130f, 0.219101240f, + -0.976037079f, 0.217604275f, + -0.976369731f, 0.216106797f, + -0.976700086f, 0.214608811f, + -0.977028143f, 0.213110320f, + -0.977353900f, 0.211611327f, + -0.977677358f, 0.210111837f, + -0.977998515f, 0.208611852f, + -0.978317371f, 0.207111376f, + -0.978633924f, 0.205610413f, + -0.978948175f, 0.204108966f, + -0.979260123f, 0.202607039f, + -0.979569766f, 0.201104635f, + -0.979877104f, 0.199601758f, + -0.980182136f, 0.198098411f, + -0.980484862f, 0.196594598f, + -0.980785280f, 0.195090322f, + -0.981083391f, 0.193585587f, + -0.981379193f, 0.192080397f, + -0.981672686f, 0.190574755f, + -0.981963869f, 0.189068664f, + -0.982252741f, 0.187562129f, + -0.982539302f, 0.186055152f, + -0.982823551f, 0.184547737f, + -0.983105487f, 0.183039888f, + -0.983385110f, 0.181531608f, + -0.983662419f, 0.180022901f, + -0.983937413f, 0.178513771f, + -0.984210092f, 0.177004220f, + -0.984480455f, 0.175494253f, + -0.984748502f, 0.173983873f, + -0.985014231f, 0.172473084f, + -0.985277642f, 0.170961889f, + -0.985538735f, 0.169450291f, + -0.985797509f, 0.167938295f, + -0.986053963f, 0.166425904f, + -0.986308097f, 0.164913120f, + -0.986559910f, 0.163399949f, + -0.986809402f, 0.161886394f, + -0.987056571f, 0.160372457f, + -0.987301418f, 0.158858143f, + -0.987543942f, 0.157343456f, + -0.987784142f, 0.155828398f, + -0.988022017f, 0.154312973f, + -0.988257568f, 0.152797185f, + -0.988490793f, 0.151281038f, + -0.988721692f, 0.149764535f, + -0.988950265f, 0.148247679f, + -0.989176510f, 0.146730474f, + -0.989400428f, 0.145212925f, + -0.989622017f, 0.143695033f, + -0.989841278f, 0.142176804f, + -0.990058210f, 0.140658239f, + -0.990272812f, 0.139139344f, + -0.990485084f, 0.137620122f, + -0.990695025f, 0.136100575f, + -0.990902635f, 0.134580709f, + -0.991107914f, 0.133060525f, + -0.991310860f, 0.131540029f, + -0.991511473f, 0.130019223f, + -0.991709754f, 0.128498111f, + -0.991905700f, 0.126976696f, + -0.992099313f, 0.125454983f, + -0.992290591f, 0.123932975f, + -0.992479535f, 0.122410675f, + -0.992666142f, 0.120888087f, + -0.992850414f, 0.119365215f, + -0.993032350f, 0.117842062f, + -0.993211949f, 0.116318631f, + -0.993389211f, 0.114794927f, + -0.993564136f, 0.113270952f, + -0.993736722f, 0.111746711f, + -0.993906970f, 0.110222207f, + -0.994074879f, 0.108697444f, + -0.994240449f, 0.107172425f, + -0.994403680f, 0.105647154f, + -0.994564571f, 0.104121634f, + -0.994723121f, 0.102595869f, + -0.994879331f, 0.101069863f, + -0.995033199f, 0.099543619f, + -0.995184727f, 0.098017140f, + -0.995333912f, 0.096490431f, + -0.995480755f, 0.094963495f, + -0.995625256f, 0.093436336f, + -0.995767414f, 0.091908956f, + -0.995907229f, 0.090381361f, + -0.996044701f, 0.088853553f, + -0.996179829f, 0.087325535f, + -0.996312612f, 0.085797312f, + -0.996443051f, 0.084268888f, + -0.996571146f, 0.082740265f, + -0.996696895f, 0.081211447f, + -0.996820299f, 0.079682438f, + -0.996941358f, 0.078153242f, + -0.997060070f, 0.076623861f, + -0.997176437f, 0.075094301f, + -0.997290457f, 0.073564564f, + -0.997402130f, 0.072034653f, + -0.997511456f, 0.070504573f, + -0.997618435f, 0.068974328f, + -0.997723067f, 0.067443920f, + -0.997825350f, 0.065913353f, + -0.997925286f, 0.064382631f, + -0.998022874f, 0.062851758f, + -0.998118113f, 0.061320736f, + -0.998211003f, 0.059789571f, + -0.998301545f, 0.058258265f, + -0.998389737f, 0.056726821f, + -0.998475581f, 0.055195244f, + -0.998559074f, 0.053663538f, + -0.998640218f, 0.052131705f, + -0.998719012f, 0.050599749f, + -0.998795456f, 0.049067674f, + -0.998869550f, 0.047535484f, + -0.998941293f, 0.046003182f, + -0.999010686f, 0.044470772f, + -0.999077728f, 0.042938257f, + -0.999142419f, 0.041405641f, + -0.999204759f, 0.039872928f, + -0.999264747f, 0.038340120f, + -0.999322385f, 0.036807223f, + -0.999377670f, 0.035274239f, + -0.999430605f, 0.033741172f, + -0.999481187f, 0.032208025f, + -0.999529418f, 0.030674803f, + -0.999575296f, 0.029141509f, + -0.999618822f, 0.027608146f, + -0.999659997f, 0.026074718f, + -0.999698819f, 0.024541229f, + -0.999735288f, 0.023007681f, + -0.999769405f, 0.021474080f, + -0.999801170f, 0.019940429f, + -0.999830582f, 0.018406730f, + -0.999857641f, 0.016872988f, + -0.999882347f, 0.015339206f, + -0.999904701f, 0.013805389f, + -0.999924702f, 0.012271538f, + -0.999942350f, 0.010737659f, + -0.999957645f, 0.009203755f, + -0.999970586f, 0.007669829f, + -0.999981175f, 0.006135885f, + -0.999989411f, 0.004601926f, + -0.999995294f, 0.003067957f, + -0.999998823f, 0.001533980f, + -1.000000000f, 0.000000000f, + -0.999998823f, -0.001533980f, + -0.999995294f, -0.003067957f, + -0.999989411f, -0.004601926f, + -0.999981175f, -0.006135885f, + -0.999970586f, -0.007669829f, + -0.999957645f, -0.009203755f, + -0.999942350f, -0.010737659f, + -0.999924702f, -0.012271538f, + -0.999904701f, -0.013805389f, + -0.999882347f, -0.015339206f, + -0.999857641f, -0.016872988f, + -0.999830582f, -0.018406730f, + -0.999801170f, -0.019940429f, + -0.999769405f, -0.021474080f, + -0.999735288f, -0.023007681f, + -0.999698819f, -0.024541229f, + -0.999659997f, -0.026074718f, + -0.999618822f, -0.027608146f, + -0.999575296f, -0.029141509f, + -0.999529418f, -0.030674803f, + -0.999481187f, -0.032208025f, + -0.999430605f, -0.033741172f, + -0.999377670f, -0.035274239f, + -0.999322385f, -0.036807223f, + -0.999264747f, -0.038340120f, + -0.999204759f, -0.039872928f, + -0.999142419f, -0.041405641f, + -0.999077728f, -0.042938257f, + -0.999010686f, -0.044470772f, + -0.998941293f, -0.046003182f, + -0.998869550f, -0.047535484f, + -0.998795456f, -0.049067674f, + -0.998719012f, -0.050599749f, + -0.998640218f, -0.052131705f, + -0.998559074f, -0.053663538f, + -0.998475581f, -0.055195244f, + -0.998389737f, -0.056726821f, + -0.998301545f, -0.058258265f, + -0.998211003f, -0.059789571f, + -0.998118113f, -0.061320736f, + -0.998022874f, -0.062851758f, + -0.997925286f, -0.064382631f, + -0.997825350f, -0.065913353f, + -0.997723067f, -0.067443920f, + -0.997618435f, -0.068974328f, + -0.997511456f, -0.070504573f, + -0.997402130f, -0.072034653f, + -0.997290457f, -0.073564564f, + -0.997176437f, -0.075094301f, + -0.997060070f, -0.076623861f, + -0.996941358f, -0.078153242f, + -0.996820299f, -0.079682438f, + -0.996696895f, -0.081211447f, + -0.996571146f, -0.082740265f, + -0.996443051f, -0.084268888f, + -0.996312612f, -0.085797312f, + -0.996179829f, -0.087325535f, + -0.996044701f, -0.088853553f, + -0.995907229f, -0.090381361f, + -0.995767414f, -0.091908956f, + -0.995625256f, -0.093436336f, + -0.995480755f, -0.094963495f, + -0.995333912f, -0.096490431f, + -0.995184727f, -0.098017140f, + -0.995033199f, -0.099543619f, + -0.994879331f, -0.101069863f, + -0.994723121f, -0.102595869f, + -0.994564571f, -0.104121634f, + -0.994403680f, -0.105647154f, + -0.994240449f, -0.107172425f, + -0.994074879f, -0.108697444f, + -0.993906970f, -0.110222207f, + -0.993736722f, -0.111746711f, + -0.993564136f, -0.113270952f, + -0.993389211f, -0.114794927f, + -0.993211949f, -0.116318631f, + -0.993032350f, -0.117842062f, + -0.992850414f, -0.119365215f, + -0.992666142f, -0.120888087f, + -0.992479535f, -0.122410675f, + -0.992290591f, -0.123932975f, + -0.992099313f, -0.125454983f, + -0.991905700f, -0.126976696f, + -0.991709754f, -0.128498111f, + -0.991511473f, -0.130019223f, + -0.991310860f, -0.131540029f, + -0.991107914f, -0.133060525f, + -0.990902635f, -0.134580709f, + -0.990695025f, -0.136100575f, + -0.990485084f, -0.137620122f, + -0.990272812f, -0.139139344f, + -0.990058210f, -0.140658239f, + -0.989841278f, -0.142176804f, + -0.989622017f, -0.143695033f, + -0.989400428f, -0.145212925f, + -0.989176510f, -0.146730474f, + -0.988950265f, -0.148247679f, + -0.988721692f, -0.149764535f, + -0.988490793f, -0.151281038f, + -0.988257568f, -0.152797185f, + -0.988022017f, -0.154312973f, + -0.987784142f, -0.155828398f, + -0.987543942f, -0.157343456f, + -0.987301418f, -0.158858143f, + -0.987056571f, -0.160372457f, + -0.986809402f, -0.161886394f, + -0.986559910f, -0.163399949f, + -0.986308097f, -0.164913120f, + -0.986053963f, -0.166425904f, + -0.985797509f, -0.167938295f, + -0.985538735f, -0.169450291f, + -0.985277642f, -0.170961889f, + -0.985014231f, -0.172473084f, + -0.984748502f, -0.173983873f, + -0.984480455f, -0.175494253f, + -0.984210092f, -0.177004220f, + -0.983937413f, -0.178513771f, + -0.983662419f, -0.180022901f, + -0.983385110f, -0.181531608f, + -0.983105487f, -0.183039888f, + -0.982823551f, -0.184547737f, + -0.982539302f, -0.186055152f, + -0.982252741f, -0.187562129f, + -0.981963869f, -0.189068664f, + -0.981672686f, -0.190574755f, + -0.981379193f, -0.192080397f, + -0.981083391f, -0.193585587f, + -0.980785280f, -0.195090322f, + -0.980484862f, -0.196594598f, + -0.980182136f, -0.198098411f, + -0.979877104f, -0.199601758f, + -0.979569766f, -0.201104635f, + -0.979260123f, -0.202607039f, + -0.978948175f, -0.204108966f, + -0.978633924f, -0.205610413f, + -0.978317371f, -0.207111376f, + -0.977998515f, -0.208611852f, + -0.977677358f, -0.210111837f, + -0.977353900f, -0.211611327f, + -0.977028143f, -0.213110320f, + -0.976700086f, -0.214608811f, + -0.976369731f, -0.216106797f, + -0.976037079f, -0.217604275f, + -0.975702130f, -0.219101240f, + -0.975364885f, -0.220597690f, + -0.975025345f, -0.222093621f, + -0.974683511f, -0.223589029f, + -0.974339383f, -0.225083911f, + -0.973992962f, -0.226578264f, + -0.973644250f, -0.228072083f, + -0.973293246f, -0.229565366f, + -0.972939952f, -0.231058108f, + -0.972584369f, -0.232550307f, + -0.972226497f, -0.234041959f, + -0.971866337f, -0.235533059f, + -0.971503891f, -0.237023606f, + -0.971139158f, -0.238513595f, + -0.970772141f, -0.240003022f, + -0.970402839f, -0.241491885f, + -0.970031253f, -0.242980180f, + -0.969657385f, -0.244467903f, + -0.969281235f, -0.245955050f, + -0.968902805f, -0.247441619f, + -0.968522094f, -0.248927606f, + -0.968139105f, -0.250413007f, + -0.967753837f, -0.251897818f, + -0.967366292f, -0.253382037f, + -0.966976471f, -0.254865660f, + -0.966584374f, -0.256348682f, + -0.966190003f, -0.257831102f, + -0.965793359f, -0.259312915f, + -0.965394442f, -0.260794118f, + -0.964993253f, -0.262274707f, + -0.964589793f, -0.263754679f, + -0.964184064f, -0.265234030f, + -0.963776066f, -0.266712757f, + -0.963365800f, -0.268190857f, + -0.962953267f, -0.269668326f, + -0.962538468f, -0.271145160f, + -0.962121404f, -0.272621355f, + -0.961702077f, -0.274096910f, + -0.961280486f, -0.275571819f, + -0.960856633f, -0.277046080f, + -0.960430519f, -0.278519689f, + -0.960002146f, -0.279992643f, + -0.959571513f, -0.281464938f, + -0.959138622f, -0.282936570f, + -0.958703475f, -0.284407537f, + -0.958266071f, -0.285877835f, + -0.957826413f, -0.287347460f, + -0.957384501f, -0.288816408f, + -0.956940336f, -0.290284677f, + -0.956493919f, -0.291752263f, + -0.956045251f, -0.293219163f, + -0.955594334f, -0.294685372f, + -0.955141168f, -0.296150888f, + -0.954685755f, -0.297615707f, + -0.954228095f, -0.299079826f, + -0.953768190f, -0.300543241f, + -0.953306040f, -0.302005949f, + -0.952841648f, -0.303467947f, + -0.952375013f, -0.304929230f, + -0.951906137f, -0.306389795f, + -0.951435021f, -0.307849640f, + -0.950961666f, -0.309308760f, + -0.950486074f, -0.310767153f, + -0.950008245f, -0.312224814f, + -0.949528181f, -0.313681740f, + -0.949045882f, -0.315137929f, + -0.948561350f, -0.316593376f, + -0.948074586f, -0.318048077f, + -0.947585591f, -0.319502031f, + -0.947094366f, -0.320955232f, + -0.946600913f, -0.322407679f, + -0.946105232f, -0.323859367f, + -0.945607325f, -0.325310292f, + -0.945107193f, -0.326760452f, + -0.944604837f, -0.328209844f, + -0.944100258f, -0.329658463f, + -0.943593458f, -0.331106306f, + -0.943084437f, -0.332553370f, + -0.942573198f, -0.333999651f, + -0.942059740f, -0.335445147f, + -0.941544065f, -0.336889853f, + -0.941026175f, -0.338333767f, + -0.940506071f, -0.339776884f, + -0.939983753f, -0.341219202f, + -0.939459224f, -0.342660717f, + -0.938932484f, -0.344101426f, + -0.938403534f, -0.345541325f, + -0.937872376f, -0.346980411f, + -0.937339012f, -0.348418680f, + -0.936803442f, -0.349856130f, + -0.936265667f, -0.351292756f, + -0.935725689f, -0.352728556f, + -0.935183510f, -0.354163525f, + -0.934639130f, -0.355597662f, + -0.934092550f, -0.357030961f, + -0.933543773f, -0.358463421f, + -0.932992799f, -0.359895037f, + -0.932439629f, -0.361325806f, + -0.931884266f, -0.362755724f, + -0.931326709f, -0.364184790f, + -0.930766961f, -0.365612998f, + -0.930205023f, -0.367040346f, + -0.929640896f, -0.368466830f, + -0.929074581f, -0.369892447f, + -0.928506080f, -0.371317194f, + -0.927935395f, -0.372741067f, + -0.927362526f, -0.374164063f, + -0.926787474f, -0.375586178f, + -0.926210242f, -0.377007410f, + -0.925630831f, -0.378427755f, + -0.925049241f, -0.379847209f, + -0.924465474f, -0.381265769f, + -0.923879533f, -0.382683432f, + -0.923291417f, -0.384100195f, + -0.922701128f, -0.385516054f, + -0.922108669f, -0.386931006f, + -0.921514039f, -0.388345047f, + -0.920917242f, -0.389758174f, + -0.920318277f, -0.391170384f, + -0.919717146f, -0.392581674f, + -0.919113852f, -0.393992040f, + -0.918508394f, -0.395401479f, + -0.917900776f, -0.396809987f, + -0.917290997f, -0.398217562f, + -0.916679060f, -0.399624200f, + -0.916064966f, -0.401029897f, + -0.915448716f, -0.402434651f, + -0.914830312f, -0.403838458f, + -0.914209756f, -0.405241314f, + -0.913587048f, -0.406643217f, + -0.912962190f, -0.408044163f, + -0.912335185f, -0.409444149f, + -0.911706032f, -0.410843171f, + -0.911074734f, -0.412241227f, + -0.910441292f, -0.413638312f, + -0.909805708f, -0.415034424f, + -0.909167983f, -0.416429560f, + -0.908528119f, -0.417823716f, + -0.907886116f, -0.419216888f, + -0.907241978f, -0.420609074f, + -0.906595705f, -0.422000271f, + -0.905947298f, -0.423390474f, + -0.905296759f, -0.424779681f, + -0.904644091f, -0.426167889f, + -0.903989293f, -0.427555093f, + -0.903332368f, -0.428941292f, + -0.902673318f, -0.430326481f, + -0.902012144f, -0.431710658f, + -0.901348847f, -0.433093819f, + -0.900683429f, -0.434475961f, + -0.900015892f, -0.435857080f, + -0.899346237f, -0.437237174f, + -0.898674466f, -0.438616239f, + -0.898000580f, -0.439994271f, + -0.897324581f, -0.441371269f, + -0.896646470f, -0.442747228f, + -0.895966250f, -0.444122145f, + -0.895283921f, -0.445496017f, + -0.894599486f, -0.446868840f, + -0.893912945f, -0.448240612f, + -0.893224301f, -0.449611330f, + -0.892533555f, -0.450980989f, + -0.891840709f, -0.452349587f, + -0.891145765f, -0.453717121f, + -0.890448723f, -0.455083587f, + -0.889749586f, -0.456448982f, + -0.889048356f, -0.457813304f, + -0.888345033f, -0.459176548f, + -0.887639620f, -0.460538711f, + -0.886932119f, -0.461899791f, + -0.886222530f, -0.463259784f, + -0.885510856f, -0.464618686f, + -0.884797098f, -0.465976496f, + -0.884081259f, -0.467333209f, + -0.883363339f, -0.468688822f, + -0.882643340f, -0.470043332f, + -0.881921264f, -0.471396737f, + -0.881197113f, -0.472749032f, + -0.880470889f, -0.474100215f, + -0.879742593f, -0.475450282f, + -0.879012226f, -0.476799230f, + -0.878279792f, -0.478147056f, + -0.877545290f, -0.479493758f, + -0.876808724f, -0.480839331f, + -0.876070094f, -0.482183772f, + -0.875329403f, -0.483527079f, + -0.874586652f, -0.484869248f, + -0.873841843f, -0.486210276f, + -0.873094978f, -0.487550160f, + -0.872346059f, -0.488888897f, + -0.871595087f, -0.490226483f, + -0.870842063f, -0.491562916f, + -0.870086991f, -0.492898192f, + -0.869329871f, -0.494232309f, + -0.868570706f, -0.495565262f, + -0.867809497f, -0.496897049f, + -0.867046246f, -0.498227667f, + -0.866280954f, -0.499557113f, + -0.865513624f, -0.500885383f, + -0.864744258f, -0.502212474f, + -0.863972856f, -0.503538384f, + -0.863199422f, -0.504863109f, + -0.862423956f, -0.506186645f, + -0.861646461f, -0.507508991f, + -0.860866939f, -0.508830143f, + -0.860085390f, -0.510150097f, + -0.859301818f, -0.511468850f, + -0.858516224f, -0.512786401f, + -0.857728610f, -0.514102744f, + -0.856938977f, -0.515417878f, + -0.856147328f, -0.516731799f, + -0.855353665f, -0.518044504f, + -0.854557988f, -0.519355990f, + -0.853760301f, -0.520666254f, + -0.852960605f, -0.521975293f, + -0.852158902f, -0.523283103f, + -0.851355193f, -0.524589683f, + -0.850549481f, -0.525895027f, + -0.849741768f, -0.527199135f, + -0.848932055f, -0.528502002f, + -0.848120345f, -0.529803625f, + -0.847306639f, -0.531104001f, + -0.846490939f, -0.532403128f, + -0.845673247f, -0.533701002f, + -0.844853565f, -0.534997620f, + -0.844031895f, -0.536292979f, + -0.843208240f, -0.537587076f, + -0.842382600f, -0.538879909f, + -0.841554977f, -0.540171473f, + -0.840725375f, -0.541461766f, + -0.839893794f, -0.542750785f, + -0.839060237f, -0.544038527f, + -0.838224706f, -0.545324988f, + -0.837387202f, -0.546610167f, + -0.836547727f, -0.547894059f, + -0.835706284f, -0.549176662f, + -0.834862875f, -0.550457973f, + -0.834017501f, -0.551737988f, + -0.833170165f, -0.553016706f, + -0.832320868f, -0.554294121f, + -0.831469612f, -0.555570233f, + -0.830616400f, -0.556845037f, + -0.829761234f, -0.558118531f, + -0.828904115f, -0.559390712f, + -0.828045045f, -0.560661576f, + -0.827184027f, -0.561931121f, + -0.826321063f, -0.563199344f, + -0.825456154f, -0.564466242f, + -0.824589303f, -0.565731811f, + -0.823720511f, -0.566996049f, + -0.822849781f, -0.568258953f, + -0.821977115f, -0.569520519f, + -0.821102515f, -0.570780746f, + -0.820225983f, -0.572039629f, + -0.819347520f, -0.573297167f, + -0.818467130f, -0.574553355f, + -0.817584813f, -0.575808191f, + -0.816700573f, -0.577061673f, + -0.815814411f, -0.578313796f, + -0.814926329f, -0.579564559f, + -0.814036330f, -0.580813958f, + -0.813144415f, -0.582061990f, + -0.812250587f, -0.583308653f, + -0.811354847f, -0.584553943f, + -0.810457198f, -0.585797857f, + -0.809557642f, -0.587040394f, + -0.808656182f, -0.588281548f, + -0.807752818f, -0.589521319f, + -0.806847554f, -0.590759702f, + -0.805940391f, -0.591996695f, + -0.805031331f, -0.593232295f, + -0.804120377f, -0.594466499f, + -0.803207531f, -0.595699304f, + -0.802292796f, -0.596930708f, + -0.801376172f, -0.598160707f, + -0.800457662f, -0.599389298f, + -0.799537269f, -0.600616479f, + -0.798614995f, -0.601842247f, + -0.797690841f, -0.603066599f, + -0.796764810f, -0.604289531f, + -0.795836905f, -0.605511041f, + -0.794907126f, -0.606731127f, + -0.793975478f, -0.607949785f, + -0.793041960f, -0.609167012f, + -0.792106577f, -0.610382806f, + -0.791169330f, -0.611597164f, + -0.790230221f, -0.612810082f, + -0.789289253f, -0.614021559f, + -0.788346428f, -0.615231591f, + -0.787401747f, -0.616440175f, + -0.786455214f, -0.617647308f, + -0.785506830f, -0.618852988f, + -0.784556597f, -0.620057212f, + -0.783604519f, -0.621259977f, + -0.782650596f, -0.622461279f, + -0.781694832f, -0.623661118f, + -0.780737229f, -0.624859488f, + -0.779777788f, -0.626056388f, + -0.778816512f, -0.627251815f, + -0.777853404f, -0.628445767f, + -0.776888466f, -0.629638239f, + -0.775921699f, -0.630829230f, + -0.774953107f, -0.632018736f, + -0.773982691f, -0.633206755f, + -0.773010453f, -0.634393284f, + -0.772036397f, -0.635578320f, + -0.771060524f, -0.636761861f, + -0.770082837f, -0.637943904f, + -0.769103338f, -0.639124445f, + -0.768122029f, -0.640303482f, + -0.767138912f, -0.641481013f, + -0.766153990f, -0.642657034f, + -0.765167266f, -0.643831543f, + -0.764178741f, -0.645004537f, + -0.763188417f, -0.646176013f, + -0.762196298f, -0.647345969f, + -0.761202385f, -0.648514401f, + -0.760206682f, -0.649681307f, + -0.759209189f, -0.650846685f, + -0.758209910f, -0.652010531f, + -0.757208847f, -0.653172843f, + -0.756206001f, -0.654333618f, + -0.755201377f, -0.655492853f, + -0.754194975f, -0.656650546f, + -0.753186799f, -0.657806693f, + -0.752176850f, -0.658961293f, + -0.751165132f, -0.660114342f, + -0.750151646f, -0.661265838f, + -0.749136395f, -0.662415778f, + -0.748119380f, -0.663564159f, + -0.747100606f, -0.664710978f, + -0.746080074f, -0.665856234f, + -0.745057785f, -0.666999922f, + -0.744033744f, -0.668142041f, + -0.743007952f, -0.669282588f, + -0.741980412f, -0.670421560f, + -0.740951125f, -0.671558955f, + -0.739920095f, -0.672694769f, + -0.738887324f, -0.673829000f, + -0.737852815f, -0.674961646f, + -0.736816569f, -0.676092704f, + -0.735778589f, -0.677222170f, + -0.734738878f, -0.678350043f, + -0.733697438f, -0.679476320f, + -0.732654272f, -0.680600998f, + -0.731609381f, -0.681724074f, + -0.730562769f, -0.682845546f, + -0.729514438f, -0.683965412f, + -0.728464390f, -0.685083668f, + -0.727412629f, -0.686200312f, + -0.726359155f, -0.687315341f, + -0.725303972f, -0.688428753f, + -0.724247083f, -0.689540545f, + -0.723188489f, -0.690650714f, + -0.722128194f, -0.691759258f, + -0.721066199f, -0.692866175f, + -0.720002508f, -0.693971461f, + -0.718937122f, -0.695075114f, + -0.717870045f, -0.696177131f, + -0.716801279f, -0.697277511f, + -0.715730825f, -0.698376249f, + -0.714658688f, -0.699473345f, + -0.713584869f, -0.700568794f, + -0.712509371f, -0.701662595f, + -0.711432196f, -0.702754744f, + -0.710353347f, -0.703845241f, + -0.709272826f, -0.704934080f, + -0.708190637f, -0.706021261f, + -0.707106781f, -0.707106781f, + -0.706021261f, -0.708190637f, + -0.704934080f, -0.709272826f, + -0.703845241f, -0.710353347f, + -0.702754744f, -0.711432196f, + -0.701662595f, -0.712509371f, + -0.700568794f, -0.713584869f, + -0.699473345f, -0.714658688f, + -0.698376249f, -0.715730825f, + -0.697277511f, -0.716801279f, + -0.696177131f, -0.717870045f, + -0.695075114f, -0.718937122f, + -0.693971461f, -0.720002508f, + -0.692866175f, -0.721066199f, + -0.691759258f, -0.722128194f, + -0.690650714f, -0.723188489f, + -0.689540545f, -0.724247083f, + -0.688428753f, -0.725303972f, + -0.687315341f, -0.726359155f, + -0.686200312f, -0.727412629f, + -0.685083668f, -0.728464390f, + -0.683965412f, -0.729514438f, + -0.682845546f, -0.730562769f, + -0.681724074f, -0.731609381f, + -0.680600998f, -0.732654272f, + -0.679476320f, -0.733697438f, + -0.678350043f, -0.734738878f, + -0.677222170f, -0.735778589f, + -0.676092704f, -0.736816569f, + -0.674961646f, -0.737852815f, + -0.673829000f, -0.738887324f, + -0.672694769f, -0.739920095f, + -0.671558955f, -0.740951125f, + -0.670421560f, -0.741980412f, + -0.669282588f, -0.743007952f, + -0.668142041f, -0.744033744f, + -0.666999922f, -0.745057785f, + -0.665856234f, -0.746080074f, + -0.664710978f, -0.747100606f, + -0.663564159f, -0.748119380f, + -0.662415778f, -0.749136395f, + -0.661265838f, -0.750151646f, + -0.660114342f, -0.751165132f, + -0.658961293f, -0.752176850f, + -0.657806693f, -0.753186799f, + -0.656650546f, -0.754194975f, + -0.655492853f, -0.755201377f, + -0.654333618f, -0.756206001f, + -0.653172843f, -0.757208847f, + -0.652010531f, -0.758209910f, + -0.650846685f, -0.759209189f, + -0.649681307f, -0.760206682f, + -0.648514401f, -0.761202385f, + -0.647345969f, -0.762196298f, + -0.646176013f, -0.763188417f, + -0.645004537f, -0.764178741f, + -0.643831543f, -0.765167266f, + -0.642657034f, -0.766153990f, + -0.641481013f, -0.767138912f, + -0.640303482f, -0.768122029f, + -0.639124445f, -0.769103338f, + -0.637943904f, -0.770082837f, + -0.636761861f, -0.771060524f, + -0.635578320f, -0.772036397f, + -0.634393284f, -0.773010453f, + -0.633206755f, -0.773982691f, + -0.632018736f, -0.774953107f, + -0.630829230f, -0.775921699f, + -0.629638239f, -0.776888466f, + -0.628445767f, -0.777853404f, + -0.627251815f, -0.778816512f, + -0.626056388f, -0.779777788f, + -0.624859488f, -0.780737229f, + -0.623661118f, -0.781694832f, + -0.622461279f, -0.782650596f, + -0.621259977f, -0.783604519f, + -0.620057212f, -0.784556597f, + -0.618852988f, -0.785506830f, + -0.617647308f, -0.786455214f, + -0.616440175f, -0.787401747f, + -0.615231591f, -0.788346428f, + -0.614021559f, -0.789289253f, + -0.612810082f, -0.790230221f, + -0.611597164f, -0.791169330f, + -0.610382806f, -0.792106577f, + -0.609167012f, -0.793041960f, + -0.607949785f, -0.793975478f, + -0.606731127f, -0.794907126f, + -0.605511041f, -0.795836905f, + -0.604289531f, -0.796764810f, + -0.603066599f, -0.797690841f, + -0.601842247f, -0.798614995f, + -0.600616479f, -0.799537269f, + -0.599389298f, -0.800457662f, + -0.598160707f, -0.801376172f, + -0.596930708f, -0.802292796f, + -0.595699304f, -0.803207531f, + -0.594466499f, -0.804120377f, + -0.593232295f, -0.805031331f, + -0.591996695f, -0.805940391f, + -0.590759702f, -0.806847554f, + -0.589521319f, -0.807752818f, + -0.588281548f, -0.808656182f, + -0.587040394f, -0.809557642f, + -0.585797857f, -0.810457198f, + -0.584553943f, -0.811354847f, + -0.583308653f, -0.812250587f, + -0.582061990f, -0.813144415f, + -0.580813958f, -0.814036330f, + -0.579564559f, -0.814926329f, + -0.578313796f, -0.815814411f, + -0.577061673f, -0.816700573f, + -0.575808191f, -0.817584813f, + -0.574553355f, -0.818467130f, + -0.573297167f, -0.819347520f, + -0.572039629f, -0.820225983f, + -0.570780746f, -0.821102515f, + -0.569520519f, -0.821977115f, + -0.568258953f, -0.822849781f, + -0.566996049f, -0.823720511f, + -0.565731811f, -0.824589303f, + -0.564466242f, -0.825456154f, + -0.563199344f, -0.826321063f, + -0.561931121f, -0.827184027f, + -0.560661576f, -0.828045045f, + -0.559390712f, -0.828904115f, + -0.558118531f, -0.829761234f, + -0.556845037f, -0.830616400f, + -0.555570233f, -0.831469612f, + -0.554294121f, -0.832320868f, + -0.553016706f, -0.833170165f, + -0.551737988f, -0.834017501f, + -0.550457973f, -0.834862875f, + -0.549176662f, -0.835706284f, + -0.547894059f, -0.836547727f, + -0.546610167f, -0.837387202f, + -0.545324988f, -0.838224706f, + -0.544038527f, -0.839060237f, + -0.542750785f, -0.839893794f, + -0.541461766f, -0.840725375f, + -0.540171473f, -0.841554977f, + -0.538879909f, -0.842382600f, + -0.537587076f, -0.843208240f, + -0.536292979f, -0.844031895f, + -0.534997620f, -0.844853565f, + -0.533701002f, -0.845673247f, + -0.532403128f, -0.846490939f, + -0.531104001f, -0.847306639f, + -0.529803625f, -0.848120345f, + -0.528502002f, -0.848932055f, + -0.527199135f, -0.849741768f, + -0.525895027f, -0.850549481f, + -0.524589683f, -0.851355193f, + -0.523283103f, -0.852158902f, + -0.521975293f, -0.852960605f, + -0.520666254f, -0.853760301f, + -0.519355990f, -0.854557988f, + -0.518044504f, -0.855353665f, + -0.516731799f, -0.856147328f, + -0.515417878f, -0.856938977f, + -0.514102744f, -0.857728610f, + -0.512786401f, -0.858516224f, + -0.511468850f, -0.859301818f, + -0.510150097f, -0.860085390f, + -0.508830143f, -0.860866939f, + -0.507508991f, -0.861646461f, + -0.506186645f, -0.862423956f, + -0.504863109f, -0.863199422f, + -0.503538384f, -0.863972856f, + -0.502212474f, -0.864744258f, + -0.500885383f, -0.865513624f, + -0.499557113f, -0.866280954f, + -0.498227667f, -0.867046246f, + -0.496897049f, -0.867809497f, + -0.495565262f, -0.868570706f, + -0.494232309f, -0.869329871f, + -0.492898192f, -0.870086991f, + -0.491562916f, -0.870842063f, + -0.490226483f, -0.871595087f, + -0.488888897f, -0.872346059f, + -0.487550160f, -0.873094978f, + -0.486210276f, -0.873841843f, + -0.484869248f, -0.874586652f, + -0.483527079f, -0.875329403f, + -0.482183772f, -0.876070094f, + -0.480839331f, -0.876808724f, + -0.479493758f, -0.877545290f, + -0.478147056f, -0.878279792f, + -0.476799230f, -0.879012226f, + -0.475450282f, -0.879742593f, + -0.474100215f, -0.880470889f, + -0.472749032f, -0.881197113f, + -0.471396737f, -0.881921264f, + -0.470043332f, -0.882643340f, + -0.468688822f, -0.883363339f, + -0.467333209f, -0.884081259f, + -0.465976496f, -0.884797098f, + -0.464618686f, -0.885510856f, + -0.463259784f, -0.886222530f, + -0.461899791f, -0.886932119f, + -0.460538711f, -0.887639620f, + -0.459176548f, -0.888345033f, + -0.457813304f, -0.889048356f, + -0.456448982f, -0.889749586f, + -0.455083587f, -0.890448723f, + -0.453717121f, -0.891145765f, + -0.452349587f, -0.891840709f, + -0.450980989f, -0.892533555f, + -0.449611330f, -0.893224301f, + -0.448240612f, -0.893912945f, + -0.446868840f, -0.894599486f, + -0.445496017f, -0.895283921f, + -0.444122145f, -0.895966250f, + -0.442747228f, -0.896646470f, + -0.441371269f, -0.897324581f, + -0.439994271f, -0.898000580f, + -0.438616239f, -0.898674466f, + -0.437237174f, -0.899346237f, + -0.435857080f, -0.900015892f, + -0.434475961f, -0.900683429f, + -0.433093819f, -0.901348847f, + -0.431710658f, -0.902012144f, + -0.430326481f, -0.902673318f, + -0.428941292f, -0.903332368f, + -0.427555093f, -0.903989293f, + -0.426167889f, -0.904644091f, + -0.424779681f, -0.905296759f, + -0.423390474f, -0.905947298f, + -0.422000271f, -0.906595705f, + -0.420609074f, -0.907241978f, + -0.419216888f, -0.907886116f, + -0.417823716f, -0.908528119f, + -0.416429560f, -0.909167983f, + -0.415034424f, -0.909805708f, + -0.413638312f, -0.910441292f, + -0.412241227f, -0.911074734f, + -0.410843171f, -0.911706032f, + -0.409444149f, -0.912335185f, + -0.408044163f, -0.912962190f, + -0.406643217f, -0.913587048f, + -0.405241314f, -0.914209756f, + -0.403838458f, -0.914830312f, + -0.402434651f, -0.915448716f, + -0.401029897f, -0.916064966f, + -0.399624200f, -0.916679060f, + -0.398217562f, -0.917290997f, + -0.396809987f, -0.917900776f, + -0.395401479f, -0.918508394f, + -0.393992040f, -0.919113852f, + -0.392581674f, -0.919717146f, + -0.391170384f, -0.920318277f, + -0.389758174f, -0.920917242f, + -0.388345047f, -0.921514039f, + -0.386931006f, -0.922108669f, + -0.385516054f, -0.922701128f, + -0.384100195f, -0.923291417f, + -0.382683432f, -0.923879533f, + -0.381265769f, -0.924465474f, + -0.379847209f, -0.925049241f, + -0.378427755f, -0.925630831f, + -0.377007410f, -0.926210242f, + -0.375586178f, -0.926787474f, + -0.374164063f, -0.927362526f, + -0.372741067f, -0.927935395f, + -0.371317194f, -0.928506080f, + -0.369892447f, -0.929074581f, + -0.368466830f, -0.929640896f, + -0.367040346f, -0.930205023f, + -0.365612998f, -0.930766961f, + -0.364184790f, -0.931326709f, + -0.362755724f, -0.931884266f, + -0.361325806f, -0.932439629f, + -0.359895037f, -0.932992799f, + -0.358463421f, -0.933543773f, + -0.357030961f, -0.934092550f, + -0.355597662f, -0.934639130f, + -0.354163525f, -0.935183510f, + -0.352728556f, -0.935725689f, + -0.351292756f, -0.936265667f, + -0.349856130f, -0.936803442f, + -0.348418680f, -0.937339012f, + -0.346980411f, -0.937872376f, + -0.345541325f, -0.938403534f, + -0.344101426f, -0.938932484f, + -0.342660717f, -0.939459224f, + -0.341219202f, -0.939983753f, + -0.339776884f, -0.940506071f, + -0.338333767f, -0.941026175f, + -0.336889853f, -0.941544065f, + -0.335445147f, -0.942059740f, + -0.333999651f, -0.942573198f, + -0.332553370f, -0.943084437f, + -0.331106306f, -0.943593458f, + -0.329658463f, -0.944100258f, + -0.328209844f, -0.944604837f, + -0.326760452f, -0.945107193f, + -0.325310292f, -0.945607325f, + -0.323859367f, -0.946105232f, + -0.322407679f, -0.946600913f, + -0.320955232f, -0.947094366f, + -0.319502031f, -0.947585591f, + -0.318048077f, -0.948074586f, + -0.316593376f, -0.948561350f, + -0.315137929f, -0.949045882f, + -0.313681740f, -0.949528181f, + -0.312224814f, -0.950008245f, + -0.310767153f, -0.950486074f, + -0.309308760f, -0.950961666f, + -0.307849640f, -0.951435021f, + -0.306389795f, -0.951906137f, + -0.304929230f, -0.952375013f, + -0.303467947f, -0.952841648f, + -0.302005949f, -0.953306040f, + -0.300543241f, -0.953768190f, + -0.299079826f, -0.954228095f, + -0.297615707f, -0.954685755f, + -0.296150888f, -0.955141168f, + -0.294685372f, -0.955594334f, + -0.293219163f, -0.956045251f, + -0.291752263f, -0.956493919f, + -0.290284677f, -0.956940336f, + -0.288816408f, -0.957384501f, + -0.287347460f, -0.957826413f, + -0.285877835f, -0.958266071f, + -0.284407537f, -0.958703475f, + -0.282936570f, -0.959138622f, + -0.281464938f, -0.959571513f, + -0.279992643f, -0.960002146f, + -0.278519689f, -0.960430519f, + -0.277046080f, -0.960856633f, + -0.275571819f, -0.961280486f, + -0.274096910f, -0.961702077f, + -0.272621355f, -0.962121404f, + -0.271145160f, -0.962538468f, + -0.269668326f, -0.962953267f, + -0.268190857f, -0.963365800f, + -0.266712757f, -0.963776066f, + -0.265234030f, -0.964184064f, + -0.263754679f, -0.964589793f, + -0.262274707f, -0.964993253f, + -0.260794118f, -0.965394442f, + -0.259312915f, -0.965793359f, + -0.257831102f, -0.966190003f, + -0.256348682f, -0.966584374f, + -0.254865660f, -0.966976471f, + -0.253382037f, -0.967366292f, + -0.251897818f, -0.967753837f, + -0.250413007f, -0.968139105f, + -0.248927606f, -0.968522094f, + -0.247441619f, -0.968902805f, + -0.245955050f, -0.969281235f, + -0.244467903f, -0.969657385f, + -0.242980180f, -0.970031253f, + -0.241491885f, -0.970402839f, + -0.240003022f, -0.970772141f, + -0.238513595f, -0.971139158f, + -0.237023606f, -0.971503891f, + -0.235533059f, -0.971866337f, + -0.234041959f, -0.972226497f, + -0.232550307f, -0.972584369f, + -0.231058108f, -0.972939952f, + -0.229565366f, -0.973293246f, + -0.228072083f, -0.973644250f, + -0.226578264f, -0.973992962f, + -0.225083911f, -0.974339383f, + -0.223589029f, -0.974683511f, + -0.222093621f, -0.975025345f, + -0.220597690f, -0.975364885f, + -0.219101240f, -0.975702130f, + -0.217604275f, -0.976037079f, + -0.216106797f, -0.976369731f, + -0.214608811f, -0.976700086f, + -0.213110320f, -0.977028143f, + -0.211611327f, -0.977353900f, + -0.210111837f, -0.977677358f, + -0.208611852f, -0.977998515f, + -0.207111376f, -0.978317371f, + -0.205610413f, -0.978633924f, + -0.204108966f, -0.978948175f, + -0.202607039f, -0.979260123f, + -0.201104635f, -0.979569766f, + -0.199601758f, -0.979877104f, + -0.198098411f, -0.980182136f, + -0.196594598f, -0.980484862f, + -0.195090322f, -0.980785280f, + -0.193585587f, -0.981083391f, + -0.192080397f, -0.981379193f, + -0.190574755f, -0.981672686f, + -0.189068664f, -0.981963869f, + -0.187562129f, -0.982252741f, + -0.186055152f, -0.982539302f, + -0.184547737f, -0.982823551f, + -0.183039888f, -0.983105487f, + -0.181531608f, -0.983385110f, + -0.180022901f, -0.983662419f, + -0.178513771f, -0.983937413f, + -0.177004220f, -0.984210092f, + -0.175494253f, -0.984480455f, + -0.173983873f, -0.984748502f, + -0.172473084f, -0.985014231f, + -0.170961889f, -0.985277642f, + -0.169450291f, -0.985538735f, + -0.167938295f, -0.985797509f, + -0.166425904f, -0.986053963f, + -0.164913120f, -0.986308097f, + -0.163399949f, -0.986559910f, + -0.161886394f, -0.986809402f, + -0.160372457f, -0.987056571f, + -0.158858143f, -0.987301418f, + -0.157343456f, -0.987543942f, + -0.155828398f, -0.987784142f, + -0.154312973f, -0.988022017f, + -0.152797185f, -0.988257568f, + -0.151281038f, -0.988490793f, + -0.149764535f, -0.988721692f, + -0.148247679f, -0.988950265f, + -0.146730474f, -0.989176510f, + -0.145212925f, -0.989400428f, + -0.143695033f, -0.989622017f, + -0.142176804f, -0.989841278f, + -0.140658239f, -0.990058210f, + -0.139139344f, -0.990272812f, + -0.137620122f, -0.990485084f, + -0.136100575f, -0.990695025f, + -0.134580709f, -0.990902635f, + -0.133060525f, -0.991107914f, + -0.131540029f, -0.991310860f, + -0.130019223f, -0.991511473f, + -0.128498111f, -0.991709754f, + -0.126976696f, -0.991905700f, + -0.125454983f, -0.992099313f, + -0.123932975f, -0.992290591f, + -0.122410675f, -0.992479535f, + -0.120888087f, -0.992666142f, + -0.119365215f, -0.992850414f, + -0.117842062f, -0.993032350f, + -0.116318631f, -0.993211949f, + -0.114794927f, -0.993389211f, + -0.113270952f, -0.993564136f, + -0.111746711f, -0.993736722f, + -0.110222207f, -0.993906970f, + -0.108697444f, -0.994074879f, + -0.107172425f, -0.994240449f, + -0.105647154f, -0.994403680f, + -0.104121634f, -0.994564571f, + -0.102595869f, -0.994723121f, + -0.101069863f, -0.994879331f, + -0.099543619f, -0.995033199f, + -0.098017140f, -0.995184727f, + -0.096490431f, -0.995333912f, + -0.094963495f, -0.995480755f, + -0.093436336f, -0.995625256f, + -0.091908956f, -0.995767414f, + -0.090381361f, -0.995907229f, + -0.088853553f, -0.996044701f, + -0.087325535f, -0.996179829f, + -0.085797312f, -0.996312612f, + -0.084268888f, -0.996443051f, + -0.082740265f, -0.996571146f, + -0.081211447f, -0.996696895f, + -0.079682438f, -0.996820299f, + -0.078153242f, -0.996941358f, + -0.076623861f, -0.997060070f, + -0.075094301f, -0.997176437f, + -0.073564564f, -0.997290457f, + -0.072034653f, -0.997402130f, + -0.070504573f, -0.997511456f, + -0.068974328f, -0.997618435f, + -0.067443920f, -0.997723067f, + -0.065913353f, -0.997825350f, + -0.064382631f, -0.997925286f, + -0.062851758f, -0.998022874f, + -0.061320736f, -0.998118113f, + -0.059789571f, -0.998211003f, + -0.058258265f, -0.998301545f, + -0.056726821f, -0.998389737f, + -0.055195244f, -0.998475581f, + -0.053663538f, -0.998559074f, + -0.052131705f, -0.998640218f, + -0.050599749f, -0.998719012f, + -0.049067674f, -0.998795456f, + -0.047535484f, -0.998869550f, + -0.046003182f, -0.998941293f, + -0.044470772f, -0.999010686f, + -0.042938257f, -0.999077728f, + -0.041405641f, -0.999142419f, + -0.039872928f, -0.999204759f, + -0.038340120f, -0.999264747f, + -0.036807223f, -0.999322385f, + -0.035274239f, -0.999377670f, + -0.033741172f, -0.999430605f, + -0.032208025f, -0.999481187f, + -0.030674803f, -0.999529418f, + -0.029141509f, -0.999575296f, + -0.027608146f, -0.999618822f, + -0.026074718f, -0.999659997f, + -0.024541229f, -0.999698819f, + -0.023007681f, -0.999735288f, + -0.021474080f, -0.999769405f, + -0.019940429f, -0.999801170f, + -0.018406730f, -0.999830582f, + -0.016872988f, -0.999857641f, + -0.015339206f, -0.999882347f, + -0.013805389f, -0.999904701f, + -0.012271538f, -0.999924702f, + -0.010737659f, -0.999942350f, + -0.009203755f, -0.999957645f, + -0.007669829f, -0.999970586f, + -0.006135885f, -0.999981175f, + -0.004601926f, -0.999989411f, + -0.003067957f, -0.999995294f, + -0.001533980f, -0.999998823f, + -0.000000000f, -1.000000000f, + 0.001533980f, -0.999998823f, + 0.003067957f, -0.999995294f, + 0.004601926f, -0.999989411f, + 0.006135885f, -0.999981175f, + 0.007669829f, -0.999970586f, + 0.009203755f, -0.999957645f, + 0.010737659f, -0.999942350f, + 0.012271538f, -0.999924702f, + 0.013805389f, -0.999904701f, + 0.015339206f, -0.999882347f, + 0.016872988f, -0.999857641f, + 0.018406730f, -0.999830582f, + 0.019940429f, -0.999801170f, + 0.021474080f, -0.999769405f, + 0.023007681f, -0.999735288f, + 0.024541229f, -0.999698819f, + 0.026074718f, -0.999659997f, + 0.027608146f, -0.999618822f, + 0.029141509f, -0.999575296f, + 0.030674803f, -0.999529418f, + 0.032208025f, -0.999481187f, + 0.033741172f, -0.999430605f, + 0.035274239f, -0.999377670f, + 0.036807223f, -0.999322385f, + 0.038340120f, -0.999264747f, + 0.039872928f, -0.999204759f, + 0.041405641f, -0.999142419f, + 0.042938257f, -0.999077728f, + 0.044470772f, -0.999010686f, + 0.046003182f, -0.998941293f, + 0.047535484f, -0.998869550f, + 0.049067674f, -0.998795456f, + 0.050599749f, -0.998719012f, + 0.052131705f, -0.998640218f, + 0.053663538f, -0.998559074f, + 0.055195244f, -0.998475581f, + 0.056726821f, -0.998389737f, + 0.058258265f, -0.998301545f, + 0.059789571f, -0.998211003f, + 0.061320736f, -0.998118113f, + 0.062851758f, -0.998022874f, + 0.064382631f, -0.997925286f, + 0.065913353f, -0.997825350f, + 0.067443920f, -0.997723067f, + 0.068974328f, -0.997618435f, + 0.070504573f, -0.997511456f, + 0.072034653f, -0.997402130f, + 0.073564564f, -0.997290457f, + 0.075094301f, -0.997176437f, + 0.076623861f, -0.997060070f, + 0.078153242f, -0.996941358f, + 0.079682438f, -0.996820299f, + 0.081211447f, -0.996696895f, + 0.082740265f, -0.996571146f, + 0.084268888f, -0.996443051f, + 0.085797312f, -0.996312612f, + 0.087325535f, -0.996179829f, + 0.088853553f, -0.996044701f, + 0.090381361f, -0.995907229f, + 0.091908956f, -0.995767414f, + 0.093436336f, -0.995625256f, + 0.094963495f, -0.995480755f, + 0.096490431f, -0.995333912f, + 0.098017140f, -0.995184727f, + 0.099543619f, -0.995033199f, + 0.101069863f, -0.994879331f, + 0.102595869f, -0.994723121f, + 0.104121634f, -0.994564571f, + 0.105647154f, -0.994403680f, + 0.107172425f, -0.994240449f, + 0.108697444f, -0.994074879f, + 0.110222207f, -0.993906970f, + 0.111746711f, -0.993736722f, + 0.113270952f, -0.993564136f, + 0.114794927f, -0.993389211f, + 0.116318631f, -0.993211949f, + 0.117842062f, -0.993032350f, + 0.119365215f, -0.992850414f, + 0.120888087f, -0.992666142f, + 0.122410675f, -0.992479535f, + 0.123932975f, -0.992290591f, + 0.125454983f, -0.992099313f, + 0.126976696f, -0.991905700f, + 0.128498111f, -0.991709754f, + 0.130019223f, -0.991511473f, + 0.131540029f, -0.991310860f, + 0.133060525f, -0.991107914f, + 0.134580709f, -0.990902635f, + 0.136100575f, -0.990695025f, + 0.137620122f, -0.990485084f, + 0.139139344f, -0.990272812f, + 0.140658239f, -0.990058210f, + 0.142176804f, -0.989841278f, + 0.143695033f, -0.989622017f, + 0.145212925f, -0.989400428f, + 0.146730474f, -0.989176510f, + 0.148247679f, -0.988950265f, + 0.149764535f, -0.988721692f, + 0.151281038f, -0.988490793f, + 0.152797185f, -0.988257568f, + 0.154312973f, -0.988022017f, + 0.155828398f, -0.987784142f, + 0.157343456f, -0.987543942f, + 0.158858143f, -0.987301418f, + 0.160372457f, -0.987056571f, + 0.161886394f, -0.986809402f, + 0.163399949f, -0.986559910f, + 0.164913120f, -0.986308097f, + 0.166425904f, -0.986053963f, + 0.167938295f, -0.985797509f, + 0.169450291f, -0.985538735f, + 0.170961889f, -0.985277642f, + 0.172473084f, -0.985014231f, + 0.173983873f, -0.984748502f, + 0.175494253f, -0.984480455f, + 0.177004220f, -0.984210092f, + 0.178513771f, -0.983937413f, + 0.180022901f, -0.983662419f, + 0.181531608f, -0.983385110f, + 0.183039888f, -0.983105487f, + 0.184547737f, -0.982823551f, + 0.186055152f, -0.982539302f, + 0.187562129f, -0.982252741f, + 0.189068664f, -0.981963869f, + 0.190574755f, -0.981672686f, + 0.192080397f, -0.981379193f, + 0.193585587f, -0.981083391f, + 0.195090322f, -0.980785280f, + 0.196594598f, -0.980484862f, + 0.198098411f, -0.980182136f, + 0.199601758f, -0.979877104f, + 0.201104635f, -0.979569766f, + 0.202607039f, -0.979260123f, + 0.204108966f, -0.978948175f, + 0.205610413f, -0.978633924f, + 0.207111376f, -0.978317371f, + 0.208611852f, -0.977998515f, + 0.210111837f, -0.977677358f, + 0.211611327f, -0.977353900f, + 0.213110320f, -0.977028143f, + 0.214608811f, -0.976700086f, + 0.216106797f, -0.976369731f, + 0.217604275f, -0.976037079f, + 0.219101240f, -0.975702130f, + 0.220597690f, -0.975364885f, + 0.222093621f, -0.975025345f, + 0.223589029f, -0.974683511f, + 0.225083911f, -0.974339383f, + 0.226578264f, -0.973992962f, + 0.228072083f, -0.973644250f, + 0.229565366f, -0.973293246f, + 0.231058108f, -0.972939952f, + 0.232550307f, -0.972584369f, + 0.234041959f, -0.972226497f, + 0.235533059f, -0.971866337f, + 0.237023606f, -0.971503891f, + 0.238513595f, -0.971139158f, + 0.240003022f, -0.970772141f, + 0.241491885f, -0.970402839f, + 0.242980180f, -0.970031253f, + 0.244467903f, -0.969657385f, + 0.245955050f, -0.969281235f, + 0.247441619f, -0.968902805f, + 0.248927606f, -0.968522094f, + 0.250413007f, -0.968139105f, + 0.251897818f, -0.967753837f, + 0.253382037f, -0.967366292f, + 0.254865660f, -0.966976471f, + 0.256348682f, -0.966584374f, + 0.257831102f, -0.966190003f, + 0.259312915f, -0.965793359f, + 0.260794118f, -0.965394442f, + 0.262274707f, -0.964993253f, + 0.263754679f, -0.964589793f, + 0.265234030f, -0.964184064f, + 0.266712757f, -0.963776066f, + 0.268190857f, -0.963365800f, + 0.269668326f, -0.962953267f, + 0.271145160f, -0.962538468f, + 0.272621355f, -0.962121404f, + 0.274096910f, -0.961702077f, + 0.275571819f, -0.961280486f, + 0.277046080f, -0.960856633f, + 0.278519689f, -0.960430519f, + 0.279992643f, -0.960002146f, + 0.281464938f, -0.959571513f, + 0.282936570f, -0.959138622f, + 0.284407537f, -0.958703475f, + 0.285877835f, -0.958266071f, + 0.287347460f, -0.957826413f, + 0.288816408f, -0.957384501f, + 0.290284677f, -0.956940336f, + 0.291752263f, -0.956493919f, + 0.293219163f, -0.956045251f, + 0.294685372f, -0.955594334f, + 0.296150888f, -0.955141168f, + 0.297615707f, -0.954685755f, + 0.299079826f, -0.954228095f, + 0.300543241f, -0.953768190f, + 0.302005949f, -0.953306040f, + 0.303467947f, -0.952841648f, + 0.304929230f, -0.952375013f, + 0.306389795f, -0.951906137f, + 0.307849640f, -0.951435021f, + 0.309308760f, -0.950961666f, + 0.310767153f, -0.950486074f, + 0.312224814f, -0.950008245f, + 0.313681740f, -0.949528181f, + 0.315137929f, -0.949045882f, + 0.316593376f, -0.948561350f, + 0.318048077f, -0.948074586f, + 0.319502031f, -0.947585591f, + 0.320955232f, -0.947094366f, + 0.322407679f, -0.946600913f, + 0.323859367f, -0.946105232f, + 0.325310292f, -0.945607325f, + 0.326760452f, -0.945107193f, + 0.328209844f, -0.944604837f, + 0.329658463f, -0.944100258f, + 0.331106306f, -0.943593458f, + 0.332553370f, -0.943084437f, + 0.333999651f, -0.942573198f, + 0.335445147f, -0.942059740f, + 0.336889853f, -0.941544065f, + 0.338333767f, -0.941026175f, + 0.339776884f, -0.940506071f, + 0.341219202f, -0.939983753f, + 0.342660717f, -0.939459224f, + 0.344101426f, -0.938932484f, + 0.345541325f, -0.938403534f, + 0.346980411f, -0.937872376f, + 0.348418680f, -0.937339012f, + 0.349856130f, -0.936803442f, + 0.351292756f, -0.936265667f, + 0.352728556f, -0.935725689f, + 0.354163525f, -0.935183510f, + 0.355597662f, -0.934639130f, + 0.357030961f, -0.934092550f, + 0.358463421f, -0.933543773f, + 0.359895037f, -0.932992799f, + 0.361325806f, -0.932439629f, + 0.362755724f, -0.931884266f, + 0.364184790f, -0.931326709f, + 0.365612998f, -0.930766961f, + 0.367040346f, -0.930205023f, + 0.368466830f, -0.929640896f, + 0.369892447f, -0.929074581f, + 0.371317194f, -0.928506080f, + 0.372741067f, -0.927935395f, + 0.374164063f, -0.927362526f, + 0.375586178f, -0.926787474f, + 0.377007410f, -0.926210242f, + 0.378427755f, -0.925630831f, + 0.379847209f, -0.925049241f, + 0.381265769f, -0.924465474f, + 0.382683432f, -0.923879533f, + 0.384100195f, -0.923291417f, + 0.385516054f, -0.922701128f, + 0.386931006f, -0.922108669f, + 0.388345047f, -0.921514039f, + 0.389758174f, -0.920917242f, + 0.391170384f, -0.920318277f, + 0.392581674f, -0.919717146f, + 0.393992040f, -0.919113852f, + 0.395401479f, -0.918508394f, + 0.396809987f, -0.917900776f, + 0.398217562f, -0.917290997f, + 0.399624200f, -0.916679060f, + 0.401029897f, -0.916064966f, + 0.402434651f, -0.915448716f, + 0.403838458f, -0.914830312f, + 0.405241314f, -0.914209756f, + 0.406643217f, -0.913587048f, + 0.408044163f, -0.912962190f, + 0.409444149f, -0.912335185f, + 0.410843171f, -0.911706032f, + 0.412241227f, -0.911074734f, + 0.413638312f, -0.910441292f, + 0.415034424f, -0.909805708f, + 0.416429560f, -0.909167983f, + 0.417823716f, -0.908528119f, + 0.419216888f, -0.907886116f, + 0.420609074f, -0.907241978f, + 0.422000271f, -0.906595705f, + 0.423390474f, -0.905947298f, + 0.424779681f, -0.905296759f, + 0.426167889f, -0.904644091f, + 0.427555093f, -0.903989293f, + 0.428941292f, -0.903332368f, + 0.430326481f, -0.902673318f, + 0.431710658f, -0.902012144f, + 0.433093819f, -0.901348847f, + 0.434475961f, -0.900683429f, + 0.435857080f, -0.900015892f, + 0.437237174f, -0.899346237f, + 0.438616239f, -0.898674466f, + 0.439994271f, -0.898000580f, + 0.441371269f, -0.897324581f, + 0.442747228f, -0.896646470f, + 0.444122145f, -0.895966250f, + 0.445496017f, -0.895283921f, + 0.446868840f, -0.894599486f, + 0.448240612f, -0.893912945f, + 0.449611330f, -0.893224301f, + 0.450980989f, -0.892533555f, + 0.452349587f, -0.891840709f, + 0.453717121f, -0.891145765f, + 0.455083587f, -0.890448723f, + 0.456448982f, -0.889749586f, + 0.457813304f, -0.889048356f, + 0.459176548f, -0.888345033f, + 0.460538711f, -0.887639620f, + 0.461899791f, -0.886932119f, + 0.463259784f, -0.886222530f, + 0.464618686f, -0.885510856f, + 0.465976496f, -0.884797098f, + 0.467333209f, -0.884081259f, + 0.468688822f, -0.883363339f, + 0.470043332f, -0.882643340f, + 0.471396737f, -0.881921264f, + 0.472749032f, -0.881197113f, + 0.474100215f, -0.880470889f, + 0.475450282f, -0.879742593f, + 0.476799230f, -0.879012226f, + 0.478147056f, -0.878279792f, + 0.479493758f, -0.877545290f, + 0.480839331f, -0.876808724f, + 0.482183772f, -0.876070094f, + 0.483527079f, -0.875329403f, + 0.484869248f, -0.874586652f, + 0.486210276f, -0.873841843f, + 0.487550160f, -0.873094978f, + 0.488888897f, -0.872346059f, + 0.490226483f, -0.871595087f, + 0.491562916f, -0.870842063f, + 0.492898192f, -0.870086991f, + 0.494232309f, -0.869329871f, + 0.495565262f, -0.868570706f, + 0.496897049f, -0.867809497f, + 0.498227667f, -0.867046246f, + 0.499557113f, -0.866280954f, + 0.500885383f, -0.865513624f, + 0.502212474f, -0.864744258f, + 0.503538384f, -0.863972856f, + 0.504863109f, -0.863199422f, + 0.506186645f, -0.862423956f, + 0.507508991f, -0.861646461f, + 0.508830143f, -0.860866939f, + 0.510150097f, -0.860085390f, + 0.511468850f, -0.859301818f, + 0.512786401f, -0.858516224f, + 0.514102744f, -0.857728610f, + 0.515417878f, -0.856938977f, + 0.516731799f, -0.856147328f, + 0.518044504f, -0.855353665f, + 0.519355990f, -0.854557988f, + 0.520666254f, -0.853760301f, + 0.521975293f, -0.852960605f, + 0.523283103f, -0.852158902f, + 0.524589683f, -0.851355193f, + 0.525895027f, -0.850549481f, + 0.527199135f, -0.849741768f, + 0.528502002f, -0.848932055f, + 0.529803625f, -0.848120345f, + 0.531104001f, -0.847306639f, + 0.532403128f, -0.846490939f, + 0.533701002f, -0.845673247f, + 0.534997620f, -0.844853565f, + 0.536292979f, -0.844031895f, + 0.537587076f, -0.843208240f, + 0.538879909f, -0.842382600f, + 0.540171473f, -0.841554977f, + 0.541461766f, -0.840725375f, + 0.542750785f, -0.839893794f, + 0.544038527f, -0.839060237f, + 0.545324988f, -0.838224706f, + 0.546610167f, -0.837387202f, + 0.547894059f, -0.836547727f, + 0.549176662f, -0.835706284f, + 0.550457973f, -0.834862875f, + 0.551737988f, -0.834017501f, + 0.553016706f, -0.833170165f, + 0.554294121f, -0.832320868f, + 0.555570233f, -0.831469612f, + 0.556845037f, -0.830616400f, + 0.558118531f, -0.829761234f, + 0.559390712f, -0.828904115f, + 0.560661576f, -0.828045045f, + 0.561931121f, -0.827184027f, + 0.563199344f, -0.826321063f, + 0.564466242f, -0.825456154f, + 0.565731811f, -0.824589303f, + 0.566996049f, -0.823720511f, + 0.568258953f, -0.822849781f, + 0.569520519f, -0.821977115f, + 0.570780746f, -0.821102515f, + 0.572039629f, -0.820225983f, + 0.573297167f, -0.819347520f, + 0.574553355f, -0.818467130f, + 0.575808191f, -0.817584813f, + 0.577061673f, -0.816700573f, + 0.578313796f, -0.815814411f, + 0.579564559f, -0.814926329f, + 0.580813958f, -0.814036330f, + 0.582061990f, -0.813144415f, + 0.583308653f, -0.812250587f, + 0.584553943f, -0.811354847f, + 0.585797857f, -0.810457198f, + 0.587040394f, -0.809557642f, + 0.588281548f, -0.808656182f, + 0.589521319f, -0.807752818f, + 0.590759702f, -0.806847554f, + 0.591996695f, -0.805940391f, + 0.593232295f, -0.805031331f, + 0.594466499f, -0.804120377f, + 0.595699304f, -0.803207531f, + 0.596930708f, -0.802292796f, + 0.598160707f, -0.801376172f, + 0.599389298f, -0.800457662f, + 0.600616479f, -0.799537269f, + 0.601842247f, -0.798614995f, + 0.603066599f, -0.797690841f, + 0.604289531f, -0.796764810f, + 0.605511041f, -0.795836905f, + 0.606731127f, -0.794907126f, + 0.607949785f, -0.793975478f, + 0.609167012f, -0.793041960f, + 0.610382806f, -0.792106577f, + 0.611597164f, -0.791169330f, + 0.612810082f, -0.790230221f, + 0.614021559f, -0.789289253f, + 0.615231591f, -0.788346428f, + 0.616440175f, -0.787401747f, + 0.617647308f, -0.786455214f, + 0.618852988f, -0.785506830f, + 0.620057212f, -0.784556597f, + 0.621259977f, -0.783604519f, + 0.622461279f, -0.782650596f, + 0.623661118f, -0.781694832f, + 0.624859488f, -0.780737229f, + 0.626056388f, -0.779777788f, + 0.627251815f, -0.778816512f, + 0.628445767f, -0.777853404f, + 0.629638239f, -0.776888466f, + 0.630829230f, -0.775921699f, + 0.632018736f, -0.774953107f, + 0.633206755f, -0.773982691f, + 0.634393284f, -0.773010453f, + 0.635578320f, -0.772036397f, + 0.636761861f, -0.771060524f, + 0.637943904f, -0.770082837f, + 0.639124445f, -0.769103338f, + 0.640303482f, -0.768122029f, + 0.641481013f, -0.767138912f, + 0.642657034f, -0.766153990f, + 0.643831543f, -0.765167266f, + 0.645004537f, -0.764178741f, + 0.646176013f, -0.763188417f, + 0.647345969f, -0.762196298f, + 0.648514401f, -0.761202385f, + 0.649681307f, -0.760206682f, + 0.650846685f, -0.759209189f, + 0.652010531f, -0.758209910f, + 0.653172843f, -0.757208847f, + 0.654333618f, -0.756206001f, + 0.655492853f, -0.755201377f, + 0.656650546f, -0.754194975f, + 0.657806693f, -0.753186799f, + 0.658961293f, -0.752176850f, + 0.660114342f, -0.751165132f, + 0.661265838f, -0.750151646f, + 0.662415778f, -0.749136395f, + 0.663564159f, -0.748119380f, + 0.664710978f, -0.747100606f, + 0.665856234f, -0.746080074f, + 0.666999922f, -0.745057785f, + 0.668142041f, -0.744033744f, + 0.669282588f, -0.743007952f, + 0.670421560f, -0.741980412f, + 0.671558955f, -0.740951125f, + 0.672694769f, -0.739920095f, + 0.673829000f, -0.738887324f, + 0.674961646f, -0.737852815f, + 0.676092704f, -0.736816569f, + 0.677222170f, -0.735778589f, + 0.678350043f, -0.734738878f, + 0.679476320f, -0.733697438f, + 0.680600998f, -0.732654272f, + 0.681724074f, -0.731609381f, + 0.682845546f, -0.730562769f, + 0.683965412f, -0.729514438f, + 0.685083668f, -0.728464390f, + 0.686200312f, -0.727412629f, + 0.687315341f, -0.726359155f, + 0.688428753f, -0.725303972f, + 0.689540545f, -0.724247083f, + 0.690650714f, -0.723188489f, + 0.691759258f, -0.722128194f, + 0.692866175f, -0.721066199f, + 0.693971461f, -0.720002508f, + 0.695075114f, -0.718937122f, + 0.696177131f, -0.717870045f, + 0.697277511f, -0.716801279f, + 0.698376249f, -0.715730825f, + 0.699473345f, -0.714658688f, + 0.700568794f, -0.713584869f, + 0.701662595f, -0.712509371f, + 0.702754744f, -0.711432196f, + 0.703845241f, -0.710353347f, + 0.704934080f, -0.709272826f, + 0.706021261f, -0.708190637f, + 0.707106781f, -0.707106781f, + 0.708190637f, -0.706021261f, + 0.709272826f, -0.704934080f, + 0.710353347f, -0.703845241f, + 0.711432196f, -0.702754744f, + 0.712509371f, -0.701662595f, + 0.713584869f, -0.700568794f, + 0.714658688f, -0.699473345f, + 0.715730825f, -0.698376249f, + 0.716801279f, -0.697277511f, + 0.717870045f, -0.696177131f, + 0.718937122f, -0.695075114f, + 0.720002508f, -0.693971461f, + 0.721066199f, -0.692866175f, + 0.722128194f, -0.691759258f, + 0.723188489f, -0.690650714f, + 0.724247083f, -0.689540545f, + 0.725303972f, -0.688428753f, + 0.726359155f, -0.687315341f, + 0.727412629f, -0.686200312f, + 0.728464390f, -0.685083668f, + 0.729514438f, -0.683965412f, + 0.730562769f, -0.682845546f, + 0.731609381f, -0.681724074f, + 0.732654272f, -0.680600998f, + 0.733697438f, -0.679476320f, + 0.734738878f, -0.678350043f, + 0.735778589f, -0.677222170f, + 0.736816569f, -0.676092704f, + 0.737852815f, -0.674961646f, + 0.738887324f, -0.673829000f, + 0.739920095f, -0.672694769f, + 0.740951125f, -0.671558955f, + 0.741980412f, -0.670421560f, + 0.743007952f, -0.669282588f, + 0.744033744f, -0.668142041f, + 0.745057785f, -0.666999922f, + 0.746080074f, -0.665856234f, + 0.747100606f, -0.664710978f, + 0.748119380f, -0.663564159f, + 0.749136395f, -0.662415778f, + 0.750151646f, -0.661265838f, + 0.751165132f, -0.660114342f, + 0.752176850f, -0.658961293f, + 0.753186799f, -0.657806693f, + 0.754194975f, -0.656650546f, + 0.755201377f, -0.655492853f, + 0.756206001f, -0.654333618f, + 0.757208847f, -0.653172843f, + 0.758209910f, -0.652010531f, + 0.759209189f, -0.650846685f, + 0.760206682f, -0.649681307f, + 0.761202385f, -0.648514401f, + 0.762196298f, -0.647345969f, + 0.763188417f, -0.646176013f, + 0.764178741f, -0.645004537f, + 0.765167266f, -0.643831543f, + 0.766153990f, -0.642657034f, + 0.767138912f, -0.641481013f, + 0.768122029f, -0.640303482f, + 0.769103338f, -0.639124445f, + 0.770082837f, -0.637943904f, + 0.771060524f, -0.636761861f, + 0.772036397f, -0.635578320f, + 0.773010453f, -0.634393284f, + 0.773982691f, -0.633206755f, + 0.774953107f, -0.632018736f, + 0.775921699f, -0.630829230f, + 0.776888466f, -0.629638239f, + 0.777853404f, -0.628445767f, + 0.778816512f, -0.627251815f, + 0.779777788f, -0.626056388f, + 0.780737229f, -0.624859488f, + 0.781694832f, -0.623661118f, + 0.782650596f, -0.622461279f, + 0.783604519f, -0.621259977f, + 0.784556597f, -0.620057212f, + 0.785506830f, -0.618852988f, + 0.786455214f, -0.617647308f, + 0.787401747f, -0.616440175f, + 0.788346428f, -0.615231591f, + 0.789289253f, -0.614021559f, + 0.790230221f, -0.612810082f, + 0.791169330f, -0.611597164f, + 0.792106577f, -0.610382806f, + 0.793041960f, -0.609167012f, + 0.793975478f, -0.607949785f, + 0.794907126f, -0.606731127f, + 0.795836905f, -0.605511041f, + 0.796764810f, -0.604289531f, + 0.797690841f, -0.603066599f, + 0.798614995f, -0.601842247f, + 0.799537269f, -0.600616479f, + 0.800457662f, -0.599389298f, + 0.801376172f, -0.598160707f, + 0.802292796f, -0.596930708f, + 0.803207531f, -0.595699304f, + 0.804120377f, -0.594466499f, + 0.805031331f, -0.593232295f, + 0.805940391f, -0.591996695f, + 0.806847554f, -0.590759702f, + 0.807752818f, -0.589521319f, + 0.808656182f, -0.588281548f, + 0.809557642f, -0.587040394f, + 0.810457198f, -0.585797857f, + 0.811354847f, -0.584553943f, + 0.812250587f, -0.583308653f, + 0.813144415f, -0.582061990f, + 0.814036330f, -0.580813958f, + 0.814926329f, -0.579564559f, + 0.815814411f, -0.578313796f, + 0.816700573f, -0.577061673f, + 0.817584813f, -0.575808191f, + 0.818467130f, -0.574553355f, + 0.819347520f, -0.573297167f, + 0.820225983f, -0.572039629f, + 0.821102515f, -0.570780746f, + 0.821977115f, -0.569520519f, + 0.822849781f, -0.568258953f, + 0.823720511f, -0.566996049f, + 0.824589303f, -0.565731811f, + 0.825456154f, -0.564466242f, + 0.826321063f, -0.563199344f, + 0.827184027f, -0.561931121f, + 0.828045045f, -0.560661576f, + 0.828904115f, -0.559390712f, + 0.829761234f, -0.558118531f, + 0.830616400f, -0.556845037f, + 0.831469612f, -0.555570233f, + 0.832320868f, -0.554294121f, + 0.833170165f, -0.553016706f, + 0.834017501f, -0.551737988f, + 0.834862875f, -0.550457973f, + 0.835706284f, -0.549176662f, + 0.836547727f, -0.547894059f, + 0.837387202f, -0.546610167f, + 0.838224706f, -0.545324988f, + 0.839060237f, -0.544038527f, + 0.839893794f, -0.542750785f, + 0.840725375f, -0.541461766f, + 0.841554977f, -0.540171473f, + 0.842382600f, -0.538879909f, + 0.843208240f, -0.537587076f, + 0.844031895f, -0.536292979f, + 0.844853565f, -0.534997620f, + 0.845673247f, -0.533701002f, + 0.846490939f, -0.532403128f, + 0.847306639f, -0.531104001f, + 0.848120345f, -0.529803625f, + 0.848932055f, -0.528502002f, + 0.849741768f, -0.527199135f, + 0.850549481f, -0.525895027f, + 0.851355193f, -0.524589683f, + 0.852158902f, -0.523283103f, + 0.852960605f, -0.521975293f, + 0.853760301f, -0.520666254f, + 0.854557988f, -0.519355990f, + 0.855353665f, -0.518044504f, + 0.856147328f, -0.516731799f, + 0.856938977f, -0.515417878f, + 0.857728610f, -0.514102744f, + 0.858516224f, -0.512786401f, + 0.859301818f, -0.511468850f, + 0.860085390f, -0.510150097f, + 0.860866939f, -0.508830143f, + 0.861646461f, -0.507508991f, + 0.862423956f, -0.506186645f, + 0.863199422f, -0.504863109f, + 0.863972856f, -0.503538384f, + 0.864744258f, -0.502212474f, + 0.865513624f, -0.500885383f, + 0.866280954f, -0.499557113f, + 0.867046246f, -0.498227667f, + 0.867809497f, -0.496897049f, + 0.868570706f, -0.495565262f, + 0.869329871f, -0.494232309f, + 0.870086991f, -0.492898192f, + 0.870842063f, -0.491562916f, + 0.871595087f, -0.490226483f, + 0.872346059f, -0.488888897f, + 0.873094978f, -0.487550160f, + 0.873841843f, -0.486210276f, + 0.874586652f, -0.484869248f, + 0.875329403f, -0.483527079f, + 0.876070094f, -0.482183772f, + 0.876808724f, -0.480839331f, + 0.877545290f, -0.479493758f, + 0.878279792f, -0.478147056f, + 0.879012226f, -0.476799230f, + 0.879742593f, -0.475450282f, + 0.880470889f, -0.474100215f, + 0.881197113f, -0.472749032f, + 0.881921264f, -0.471396737f, + 0.882643340f, -0.470043332f, + 0.883363339f, -0.468688822f, + 0.884081259f, -0.467333209f, + 0.884797098f, -0.465976496f, + 0.885510856f, -0.464618686f, + 0.886222530f, -0.463259784f, + 0.886932119f, -0.461899791f, + 0.887639620f, -0.460538711f, + 0.888345033f, -0.459176548f, + 0.889048356f, -0.457813304f, + 0.889749586f, -0.456448982f, + 0.890448723f, -0.455083587f, + 0.891145765f, -0.453717121f, + 0.891840709f, -0.452349587f, + 0.892533555f, -0.450980989f, + 0.893224301f, -0.449611330f, + 0.893912945f, -0.448240612f, + 0.894599486f, -0.446868840f, + 0.895283921f, -0.445496017f, + 0.895966250f, -0.444122145f, + 0.896646470f, -0.442747228f, + 0.897324581f, -0.441371269f, + 0.898000580f, -0.439994271f, + 0.898674466f, -0.438616239f, + 0.899346237f, -0.437237174f, + 0.900015892f, -0.435857080f, + 0.900683429f, -0.434475961f, + 0.901348847f, -0.433093819f, + 0.902012144f, -0.431710658f, + 0.902673318f, -0.430326481f, + 0.903332368f, -0.428941292f, + 0.903989293f, -0.427555093f, + 0.904644091f, -0.426167889f, + 0.905296759f, -0.424779681f, + 0.905947298f, -0.423390474f, + 0.906595705f, -0.422000271f, + 0.907241978f, -0.420609074f, + 0.907886116f, -0.419216888f, + 0.908528119f, -0.417823716f, + 0.909167983f, -0.416429560f, + 0.909805708f, -0.415034424f, + 0.910441292f, -0.413638312f, + 0.911074734f, -0.412241227f, + 0.911706032f, -0.410843171f, + 0.912335185f, -0.409444149f, + 0.912962190f, -0.408044163f, + 0.913587048f, -0.406643217f, + 0.914209756f, -0.405241314f, + 0.914830312f, -0.403838458f, + 0.915448716f, -0.402434651f, + 0.916064966f, -0.401029897f, + 0.916679060f, -0.399624200f, + 0.917290997f, -0.398217562f, + 0.917900776f, -0.396809987f, + 0.918508394f, -0.395401479f, + 0.919113852f, -0.393992040f, + 0.919717146f, -0.392581674f, + 0.920318277f, -0.391170384f, + 0.920917242f, -0.389758174f, + 0.921514039f, -0.388345047f, + 0.922108669f, -0.386931006f, + 0.922701128f, -0.385516054f, + 0.923291417f, -0.384100195f, + 0.923879533f, -0.382683432f, + 0.924465474f, -0.381265769f, + 0.925049241f, -0.379847209f, + 0.925630831f, -0.378427755f, + 0.926210242f, -0.377007410f, + 0.926787474f, -0.375586178f, + 0.927362526f, -0.374164063f, + 0.927935395f, -0.372741067f, + 0.928506080f, -0.371317194f, + 0.929074581f, -0.369892447f, + 0.929640896f, -0.368466830f, + 0.930205023f, -0.367040346f, + 0.930766961f, -0.365612998f, + 0.931326709f, -0.364184790f, + 0.931884266f, -0.362755724f, + 0.932439629f, -0.361325806f, + 0.932992799f, -0.359895037f, + 0.933543773f, -0.358463421f, + 0.934092550f, -0.357030961f, + 0.934639130f, -0.355597662f, + 0.935183510f, -0.354163525f, + 0.935725689f, -0.352728556f, + 0.936265667f, -0.351292756f, + 0.936803442f, -0.349856130f, + 0.937339012f, -0.348418680f, + 0.937872376f, -0.346980411f, + 0.938403534f, -0.345541325f, + 0.938932484f, -0.344101426f, + 0.939459224f, -0.342660717f, + 0.939983753f, -0.341219202f, + 0.940506071f, -0.339776884f, + 0.941026175f, -0.338333767f, + 0.941544065f, -0.336889853f, + 0.942059740f, -0.335445147f, + 0.942573198f, -0.333999651f, + 0.943084437f, -0.332553370f, + 0.943593458f, -0.331106306f, + 0.944100258f, -0.329658463f, + 0.944604837f, -0.328209844f, + 0.945107193f, -0.326760452f, + 0.945607325f, -0.325310292f, + 0.946105232f, -0.323859367f, + 0.946600913f, -0.322407679f, + 0.947094366f, -0.320955232f, + 0.947585591f, -0.319502031f, + 0.948074586f, -0.318048077f, + 0.948561350f, -0.316593376f, + 0.949045882f, -0.315137929f, + 0.949528181f, -0.313681740f, + 0.950008245f, -0.312224814f, + 0.950486074f, -0.310767153f, + 0.950961666f, -0.309308760f, + 0.951435021f, -0.307849640f, + 0.951906137f, -0.306389795f, + 0.952375013f, -0.304929230f, + 0.952841648f, -0.303467947f, + 0.953306040f, -0.302005949f, + 0.953768190f, -0.300543241f, + 0.954228095f, -0.299079826f, + 0.954685755f, -0.297615707f, + 0.955141168f, -0.296150888f, + 0.955594334f, -0.294685372f, + 0.956045251f, -0.293219163f, + 0.956493919f, -0.291752263f, + 0.956940336f, -0.290284677f, + 0.957384501f, -0.288816408f, + 0.957826413f, -0.287347460f, + 0.958266071f, -0.285877835f, + 0.958703475f, -0.284407537f, + 0.959138622f, -0.282936570f, + 0.959571513f, -0.281464938f, + 0.960002146f, -0.279992643f, + 0.960430519f, -0.278519689f, + 0.960856633f, -0.277046080f, + 0.961280486f, -0.275571819f, + 0.961702077f, -0.274096910f, + 0.962121404f, -0.272621355f, + 0.962538468f, -0.271145160f, + 0.962953267f, -0.269668326f, + 0.963365800f, -0.268190857f, + 0.963776066f, -0.266712757f, + 0.964184064f, -0.265234030f, + 0.964589793f, -0.263754679f, + 0.964993253f, -0.262274707f, + 0.965394442f, -0.260794118f, + 0.965793359f, -0.259312915f, + 0.966190003f, -0.257831102f, + 0.966584374f, -0.256348682f, + 0.966976471f, -0.254865660f, + 0.967366292f, -0.253382037f, + 0.967753837f, -0.251897818f, + 0.968139105f, -0.250413007f, + 0.968522094f, -0.248927606f, + 0.968902805f, -0.247441619f, + 0.969281235f, -0.245955050f, + 0.969657385f, -0.244467903f, + 0.970031253f, -0.242980180f, + 0.970402839f, -0.241491885f, + 0.970772141f, -0.240003022f, + 0.971139158f, -0.238513595f, + 0.971503891f, -0.237023606f, + 0.971866337f, -0.235533059f, + 0.972226497f, -0.234041959f, + 0.972584369f, -0.232550307f, + 0.972939952f, -0.231058108f, + 0.973293246f, -0.229565366f, + 0.973644250f, -0.228072083f, + 0.973992962f, -0.226578264f, + 0.974339383f, -0.225083911f, + 0.974683511f, -0.223589029f, + 0.975025345f, -0.222093621f, + 0.975364885f, -0.220597690f, + 0.975702130f, -0.219101240f, + 0.976037079f, -0.217604275f, + 0.976369731f, -0.216106797f, + 0.976700086f, -0.214608811f, + 0.977028143f, -0.213110320f, + 0.977353900f, -0.211611327f, + 0.977677358f, -0.210111837f, + 0.977998515f, -0.208611852f, + 0.978317371f, -0.207111376f, + 0.978633924f, -0.205610413f, + 0.978948175f, -0.204108966f, + 0.979260123f, -0.202607039f, + 0.979569766f, -0.201104635f, + 0.979877104f, -0.199601758f, + 0.980182136f, -0.198098411f, + 0.980484862f, -0.196594598f, + 0.980785280f, -0.195090322f, + 0.981083391f, -0.193585587f, + 0.981379193f, -0.192080397f, + 0.981672686f, -0.190574755f, + 0.981963869f, -0.189068664f, + 0.982252741f, -0.187562129f, + 0.982539302f, -0.186055152f, + 0.982823551f, -0.184547737f, + 0.983105487f, -0.183039888f, + 0.983385110f, -0.181531608f, + 0.983662419f, -0.180022901f, + 0.983937413f, -0.178513771f, + 0.984210092f, -0.177004220f, + 0.984480455f, -0.175494253f, + 0.984748502f, -0.173983873f, + 0.985014231f, -0.172473084f, + 0.985277642f, -0.170961889f, + 0.985538735f, -0.169450291f, + 0.985797509f, -0.167938295f, + 0.986053963f, -0.166425904f, + 0.986308097f, -0.164913120f, + 0.986559910f, -0.163399949f, + 0.986809402f, -0.161886394f, + 0.987056571f, -0.160372457f, + 0.987301418f, -0.158858143f, + 0.987543942f, -0.157343456f, + 0.987784142f, -0.155828398f, + 0.988022017f, -0.154312973f, + 0.988257568f, -0.152797185f, + 0.988490793f, -0.151281038f, + 0.988721692f, -0.149764535f, + 0.988950265f, -0.148247679f, + 0.989176510f, -0.146730474f, + 0.989400428f, -0.145212925f, + 0.989622017f, -0.143695033f, + 0.989841278f, -0.142176804f, + 0.990058210f, -0.140658239f, + 0.990272812f, -0.139139344f, + 0.990485084f, -0.137620122f, + 0.990695025f, -0.136100575f, + 0.990902635f, -0.134580709f, + 0.991107914f, -0.133060525f, + 0.991310860f, -0.131540029f, + 0.991511473f, -0.130019223f, + 0.991709754f, -0.128498111f, + 0.991905700f, -0.126976696f, + 0.992099313f, -0.125454983f, + 0.992290591f, -0.123932975f, + 0.992479535f, -0.122410675f, + 0.992666142f, -0.120888087f, + 0.992850414f, -0.119365215f, + 0.993032350f, -0.117842062f, + 0.993211949f, -0.116318631f, + 0.993389211f, -0.114794927f, + 0.993564136f, -0.113270952f, + 0.993736722f, -0.111746711f, + 0.993906970f, -0.110222207f, + 0.994074879f, -0.108697444f, + 0.994240449f, -0.107172425f, + 0.994403680f, -0.105647154f, + 0.994564571f, -0.104121634f, + 0.994723121f, -0.102595869f, + 0.994879331f, -0.101069863f, + 0.995033199f, -0.099543619f, + 0.995184727f, -0.098017140f, + 0.995333912f, -0.096490431f, + 0.995480755f, -0.094963495f, + 0.995625256f, -0.093436336f, + 0.995767414f, -0.091908956f, + 0.995907229f, -0.090381361f, + 0.996044701f, -0.088853553f, + 0.996179829f, -0.087325535f, + 0.996312612f, -0.085797312f, + 0.996443051f, -0.084268888f, + 0.996571146f, -0.082740265f, + 0.996696895f, -0.081211447f, + 0.996820299f, -0.079682438f, + 0.996941358f, -0.078153242f, + 0.997060070f, -0.076623861f, + 0.997176437f, -0.075094301f, + 0.997290457f, -0.073564564f, + 0.997402130f, -0.072034653f, + 0.997511456f, -0.070504573f, + 0.997618435f, -0.068974328f, + 0.997723067f, -0.067443920f, + 0.997825350f, -0.065913353f, + 0.997925286f, -0.064382631f, + 0.998022874f, -0.062851758f, + 0.998118113f, -0.061320736f, + 0.998211003f, -0.059789571f, + 0.998301545f, -0.058258265f, + 0.998389737f, -0.056726821f, + 0.998475581f, -0.055195244f, + 0.998559074f, -0.053663538f, + 0.998640218f, -0.052131705f, + 0.998719012f, -0.050599749f, + 0.998795456f, -0.049067674f, + 0.998869550f, -0.047535484f, + 0.998941293f, -0.046003182f, + 0.999010686f, -0.044470772f, + 0.999077728f, -0.042938257f, + 0.999142419f, -0.041405641f, + 0.999204759f, -0.039872928f, + 0.999264747f, -0.038340120f, + 0.999322385f, -0.036807223f, + 0.999377670f, -0.035274239f, + 0.999430605f, -0.033741172f, + 0.999481187f, -0.032208025f, + 0.999529418f, -0.030674803f, + 0.999575296f, -0.029141509f, + 0.999618822f, -0.027608146f, + 0.999659997f, -0.026074718f, + 0.999698819f, -0.024541229f, + 0.999735288f, -0.023007681f, + 0.999769405f, -0.021474080f, + 0.999801170f, -0.019940429f, + 0.999830582f, -0.018406730f, + 0.999857641f, -0.016872988f, + 0.999882347f, -0.015339206f, + 0.999904701f, -0.013805389f, + 0.999924702f, -0.012271538f, + 0.999942350f, -0.010737659f, + 0.999957645f, -0.009203755f, + 0.999970586f, -0.007669829f, + 0.999981175f, -0.006135885f, + 0.999989411f, -0.004601926f, + 0.999995294f, -0.003067957f, + 0.999998823f, -0.001533980f +}; + +/* +* @brief Q31 Twiddle factors Table +*/ + + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 16 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_16_q31[24] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, + (q31_t)0x7641AF3C, (q31_t)0x30FBC54D, + (q31_t)0x5A82799A, (q31_t)0x5A82799A, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, + (q31_t)0x00000000, (q31_t)0x7FFFFFFF, + (q31_t)0xCF043AB2, (q31_t)0x7641AF3C, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, + (q31_t)0x89BE50C3, (q31_t)0x30FBC54D, + (q31_t)0x80000000, (q31_t)0x00000000, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, + (q31_t)0xA57D8666, (q31_t)0xA57D8666, + (q31_t)0xCF043AB2, (q31_t)0x89BE50C3 +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 32 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_32_q31[48] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, + (q31_t)0x7D8A5F3F, (q31_t)0x18F8B83C, + (q31_t)0x7641AF3C, (q31_t)0x30FBC54D, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, + (q31_t)0x5A82799A, (q31_t)0x5A82799A, + (q31_t)0x471CECE6, (q31_t)0x6A6D98A4, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, + (q31_t)0x18F8B83C, (q31_t)0x7D8A5F3F, + (q31_t)0x00000000, (q31_t)0x7FFFFFFF, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, + (q31_t)0xCF043AB2, (q31_t)0x7641AF3C, + (q31_t)0xB8E31319, (q31_t)0x6A6D98A4, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, + (q31_t)0x9592675B, (q31_t)0x471CECE6, + (q31_t)0x89BE50C3, (q31_t)0x30FBC54D, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, + (q31_t)0x80000000, (q31_t)0x00000000, + (q31_t)0x8275A0C0, (q31_t)0xE70747C3, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, + (q31_t)0x9592675B, (q31_t)0xB8E31319, + (q31_t)0xA57D8666, (q31_t)0xA57D8666, + (q31_t)0xB8E31319, (q31_t)0x9592675B, + (q31_t)0xCF043AB2, (q31_t)0x89BE50C3, + (q31_t)0xE70747C3, (q31_t)0x8275A0C0 +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 64 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_64_q31[96] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, (q31_t)0x7F62368F, + (q31_t)0x0C8BD35E, (q31_t)0x7D8A5F3F, (q31_t)0x18F8B83C, + (q31_t)0x7A7D055B, (q31_t)0x25280C5D, (q31_t)0x7641AF3C, + (q31_t)0x30FBC54D, (q31_t)0x70E2CBC6, (q31_t)0x3C56BA70, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, (q31_t)0x62F201AC, + (q31_t)0x5133CC94, (q31_t)0x5A82799A, (q31_t)0x5A82799A, + (q31_t)0x5133CC94, (q31_t)0x62F201AC, (q31_t)0x471CECE6, + (q31_t)0x6A6D98A4, (q31_t)0x3C56BA70, (q31_t)0x70E2CBC6, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, (q31_t)0x25280C5D, + (q31_t)0x7A7D055B, (q31_t)0x18F8B83C, (q31_t)0x7D8A5F3F, + (q31_t)0x0C8BD35E, (q31_t)0x7F62368F, (q31_t)0x00000000, + (q31_t)0x7FFFFFFF, (q31_t)0xF3742CA1, (q31_t)0x7F62368F, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, (q31_t)0xDAD7F3A2, + (q31_t)0x7A7D055B, (q31_t)0xCF043AB2, (q31_t)0x7641AF3C, + (q31_t)0xC3A9458F, (q31_t)0x70E2CBC6, (q31_t)0xB8E31319, + (q31_t)0x6A6D98A4, (q31_t)0xAECC336B, (q31_t)0x62F201AC, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, (q31_t)0x9D0DFE53, + (q31_t)0x5133CC94, (q31_t)0x9592675B, (q31_t)0x471CECE6, + (q31_t)0x8F1D343A, (q31_t)0x3C56BA70, (q31_t)0x89BE50C3, + (q31_t)0x30FBC54D, (q31_t)0x8582FAA4, (q31_t)0x25280C5D, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, (q31_t)0x809DC970, + (q31_t)0x0C8BD35E, (q31_t)0x80000000, (q31_t)0x00000000, + (q31_t)0x809DC970, (q31_t)0xF3742CA1, (q31_t)0x8275A0C0, + (q31_t)0xE70747C3, (q31_t)0x8582FAA4, (q31_t)0xDAD7F3A2, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, (q31_t)0x8F1D343A, + (q31_t)0xC3A9458F, (q31_t)0x9592675B, (q31_t)0xB8E31319, + (q31_t)0x9D0DFE53, (q31_t)0xAECC336B, (q31_t)0xA57D8666, + (q31_t)0xA57D8666, (q31_t)0xAECC336B, (q31_t)0x9D0DFE53, + (q31_t)0xB8E31319, (q31_t)0x9592675B, (q31_t)0xC3A9458F, + (q31_t)0x8F1D343A, (q31_t)0xCF043AB2, (q31_t)0x89BE50C3, + (q31_t)0xDAD7F3A2, (q31_t)0x8582FAA4, (q31_t)0xE70747C3, + (q31_t)0x8275A0C0, (q31_t)0xF3742CA1, (q31_t)0x809DC970 +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 128 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_128_q31[192] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, (q31_t)0x7FD8878D, + (q31_t)0x0647D97C, (q31_t)0x7F62368F, (q31_t)0x0C8BD35E, + (q31_t)0x7E9D55FC, (q31_t)0x12C8106E, (q31_t)0x7D8A5F3F, + (q31_t)0x18F8B83C, (q31_t)0x7C29FBEE, (q31_t)0x1F19F97B, + (q31_t)0x7A7D055B, (q31_t)0x25280C5D, (q31_t)0x78848413, + (q31_t)0x2B1F34EB, (q31_t)0x7641AF3C, (q31_t)0x30FBC54D, + (q31_t)0x73B5EBD0, (q31_t)0x36BA2013, (q31_t)0x70E2CBC6, + (q31_t)0x3C56BA70, (q31_t)0x6DCA0D14, (q31_t)0x41CE1E64, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, (q31_t)0x66CF811F, + (q31_t)0x4C3FDFF3, (q31_t)0x62F201AC, (q31_t)0x5133CC94, + (q31_t)0x5ED77C89, (q31_t)0x55F5A4D2, (q31_t)0x5A82799A, + (q31_t)0x5A82799A, (q31_t)0x55F5A4D2, (q31_t)0x5ED77C89, + (q31_t)0x5133CC94, (q31_t)0x62F201AC, (q31_t)0x4C3FDFF3, + (q31_t)0x66CF811F, (q31_t)0x471CECE6, (q31_t)0x6A6D98A4, + (q31_t)0x41CE1E64, (q31_t)0x6DCA0D14, (q31_t)0x3C56BA70, + (q31_t)0x70E2CBC6, (q31_t)0x36BA2013, (q31_t)0x73B5EBD0, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, (q31_t)0x2B1F34EB, + (q31_t)0x78848413, (q31_t)0x25280C5D, (q31_t)0x7A7D055B, + (q31_t)0x1F19F97B, (q31_t)0x7C29FBEE, (q31_t)0x18F8B83C, + (q31_t)0x7D8A5F3F, (q31_t)0x12C8106E, (q31_t)0x7E9D55FC, + (q31_t)0x0C8BD35E, (q31_t)0x7F62368F, (q31_t)0x0647D97C, + (q31_t)0x7FD8878D, (q31_t)0x00000000, (q31_t)0x7FFFFFFF, + (q31_t)0xF9B82683, (q31_t)0x7FD8878D, (q31_t)0xF3742CA1, + (q31_t)0x7F62368F, (q31_t)0xED37EF91, (q31_t)0x7E9D55FC, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, (q31_t)0xE0E60684, + (q31_t)0x7C29FBEE, (q31_t)0xDAD7F3A2, (q31_t)0x7A7D055B, + (q31_t)0xD4E0CB14, (q31_t)0x78848413, (q31_t)0xCF043AB2, + (q31_t)0x7641AF3C, (q31_t)0xC945DFEC, (q31_t)0x73B5EBD0, + (q31_t)0xC3A9458F, (q31_t)0x70E2CBC6, (q31_t)0xBE31E19B, + (q31_t)0x6DCA0D14, (q31_t)0xB8E31319, (q31_t)0x6A6D98A4, + (q31_t)0xB3C0200C, (q31_t)0x66CF811F, (q31_t)0xAECC336B, + (q31_t)0x62F201AC, (q31_t)0xAA0A5B2D, (q31_t)0x5ED77C89, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, (q31_t)0xA1288376, + (q31_t)0x55F5A4D2, (q31_t)0x9D0DFE53, (q31_t)0x5133CC94, + (q31_t)0x99307EE0, (q31_t)0x4C3FDFF3, (q31_t)0x9592675B, + (q31_t)0x471CECE6, (q31_t)0x9235F2EB, (q31_t)0x41CE1E64, + (q31_t)0x8F1D343A, (q31_t)0x3C56BA70, (q31_t)0x8C4A142F, + (q31_t)0x36BA2013, (q31_t)0x89BE50C3, (q31_t)0x30FBC54D, + (q31_t)0x877B7BEC, (q31_t)0x2B1F34EB, (q31_t)0x8582FAA4, + (q31_t)0x25280C5D, (q31_t)0x83D60411, (q31_t)0x1F19F97B, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, (q31_t)0x8162AA03, + (q31_t)0x12C8106E, (q31_t)0x809DC970, (q31_t)0x0C8BD35E, + (q31_t)0x80277872, (q31_t)0x0647D97C, (q31_t)0x80000000, + (q31_t)0x00000000, (q31_t)0x80277872, (q31_t)0xF9B82683, + (q31_t)0x809DC970, (q31_t)0xF3742CA1, (q31_t)0x8162AA03, + (q31_t)0xED37EF91, (q31_t)0x8275A0C0, (q31_t)0xE70747C3, + (q31_t)0x83D60411, (q31_t)0xE0E60684, (q31_t)0x8582FAA4, + (q31_t)0xDAD7F3A2, (q31_t)0x877B7BEC, (q31_t)0xD4E0CB14, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, (q31_t)0x8C4A142F, + (q31_t)0xC945DFEC, (q31_t)0x8F1D343A, (q31_t)0xC3A9458F, + (q31_t)0x9235F2EB, (q31_t)0xBE31E19B, (q31_t)0x9592675B, + (q31_t)0xB8E31319, (q31_t)0x99307EE0, (q31_t)0xB3C0200C, + (q31_t)0x9D0DFE53, (q31_t)0xAECC336B, (q31_t)0xA1288376, + (q31_t)0xAA0A5B2D, (q31_t)0xA57D8666, (q31_t)0xA57D8666, + (q31_t)0xAA0A5B2D, (q31_t)0xA1288376, (q31_t)0xAECC336B, + (q31_t)0x9D0DFE53, (q31_t)0xB3C0200C, (q31_t)0x99307EE0, + (q31_t)0xB8E31319, (q31_t)0x9592675B, (q31_t)0xBE31E19B, + (q31_t)0x9235F2EB, (q31_t)0xC3A9458F, (q31_t)0x8F1D343A, + (q31_t)0xC945DFEC, (q31_t)0x8C4A142F, (q31_t)0xCF043AB2, + (q31_t)0x89BE50C3, (q31_t)0xD4E0CB14, (q31_t)0x877B7BEC, + (q31_t)0xDAD7F3A2, (q31_t)0x8582FAA4, (q31_t)0xE0E60684, + (q31_t)0x83D60411, (q31_t)0xE70747C3, (q31_t)0x8275A0C0, + (q31_t)0xED37EF91, (q31_t)0x8162AA03, (q31_t)0xF3742CA1, + (q31_t)0x809DC970, (q31_t)0xF9B82683, (q31_t)0x80277872 +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 256 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_256_q31[384] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, (q31_t)0x7FF62182, + (q31_t)0x03242ABF, (q31_t)0x7FD8878D, (q31_t)0x0647D97C, + (q31_t)0x7FA736B4, (q31_t)0x096A9049, (q31_t)0x7F62368F, + (q31_t)0x0C8BD35E, (q31_t)0x7F0991C3, (q31_t)0x0FAB272B, + (q31_t)0x7E9D55FC, (q31_t)0x12C8106E, (q31_t)0x7E1D93E9, + (q31_t)0x15E21444, (q31_t)0x7D8A5F3F, (q31_t)0x18F8B83C, + (q31_t)0x7CE3CEB1, (q31_t)0x1C0B826A, (q31_t)0x7C29FBEE, + (q31_t)0x1F19F97B, (q31_t)0x7B5D039D, (q31_t)0x2223A4C5, + (q31_t)0x7A7D055B, (q31_t)0x25280C5D, (q31_t)0x798A23B1, + (q31_t)0x2826B928, (q31_t)0x78848413, (q31_t)0x2B1F34EB, + (q31_t)0x776C4EDB, (q31_t)0x2E110A62, (q31_t)0x7641AF3C, + (q31_t)0x30FBC54D, (q31_t)0x7504D345, (q31_t)0x33DEF287, + (q31_t)0x73B5EBD0, (q31_t)0x36BA2013, (q31_t)0x72552C84, + (q31_t)0x398CDD32, (q31_t)0x70E2CBC6, (q31_t)0x3C56BA70, + (q31_t)0x6F5F02B1, (q31_t)0x3F1749B7, (q31_t)0x6DCA0D14, + (q31_t)0x41CE1E64, (q31_t)0x6C242960, (q31_t)0x447ACD50, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, (q31_t)0x68A69E81, + (q31_t)0x49B41533, (q31_t)0x66CF811F, (q31_t)0x4C3FDFF3, + (q31_t)0x64E88926, (q31_t)0x4EBFE8A4, (q31_t)0x62F201AC, + (q31_t)0x5133CC94, (q31_t)0x60EC3830, (q31_t)0x539B2AEF, + (q31_t)0x5ED77C89, (q31_t)0x55F5A4D2, (q31_t)0x5CB420DF, + (q31_t)0x5842DD54, (q31_t)0x5A82799A, (q31_t)0x5A82799A, + (q31_t)0x5842DD54, (q31_t)0x5CB420DF, (q31_t)0x55F5A4D2, + (q31_t)0x5ED77C89, (q31_t)0x539B2AEF, (q31_t)0x60EC3830, + (q31_t)0x5133CC94, (q31_t)0x62F201AC, (q31_t)0x4EBFE8A4, + (q31_t)0x64E88926, (q31_t)0x4C3FDFF3, (q31_t)0x66CF811F, + (q31_t)0x49B41533, (q31_t)0x68A69E81, (q31_t)0x471CECE6, + (q31_t)0x6A6D98A4, (q31_t)0x447ACD50, (q31_t)0x6C242960, + (q31_t)0x41CE1E64, (q31_t)0x6DCA0D14, (q31_t)0x3F1749B7, + (q31_t)0x6F5F02B1, (q31_t)0x3C56BA70, (q31_t)0x70E2CBC6, + (q31_t)0x398CDD32, (q31_t)0x72552C84, (q31_t)0x36BA2013, + (q31_t)0x73B5EBD0, (q31_t)0x33DEF287, (q31_t)0x7504D345, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, (q31_t)0x2E110A62, + (q31_t)0x776C4EDB, (q31_t)0x2B1F34EB, (q31_t)0x78848413, + (q31_t)0x2826B928, (q31_t)0x798A23B1, (q31_t)0x25280C5D, + (q31_t)0x7A7D055B, (q31_t)0x2223A4C5, (q31_t)0x7B5D039D, + (q31_t)0x1F19F97B, (q31_t)0x7C29FBEE, (q31_t)0x1C0B826A, + (q31_t)0x7CE3CEB1, (q31_t)0x18F8B83C, (q31_t)0x7D8A5F3F, + (q31_t)0x15E21444, (q31_t)0x7E1D93E9, (q31_t)0x12C8106E, + (q31_t)0x7E9D55FC, (q31_t)0x0FAB272B, (q31_t)0x7F0991C3, + (q31_t)0x0C8BD35E, (q31_t)0x7F62368F, (q31_t)0x096A9049, + (q31_t)0x7FA736B4, (q31_t)0x0647D97C, (q31_t)0x7FD8878D, + (q31_t)0x03242ABF, (q31_t)0x7FF62182, (q31_t)0x00000000, + (q31_t)0x7FFFFFFF, (q31_t)0xFCDBD541, (q31_t)0x7FF62182, + (q31_t)0xF9B82683, (q31_t)0x7FD8878D, (q31_t)0xF6956FB6, + (q31_t)0x7FA736B4, (q31_t)0xF3742CA1, (q31_t)0x7F62368F, + (q31_t)0xF054D8D4, (q31_t)0x7F0991C3, (q31_t)0xED37EF91, + (q31_t)0x7E9D55FC, (q31_t)0xEA1DEBBB, (q31_t)0x7E1D93E9, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, (q31_t)0xE3F47D95, + (q31_t)0x7CE3CEB1, (q31_t)0xE0E60684, (q31_t)0x7C29FBEE, + (q31_t)0xDDDC5B3A, (q31_t)0x7B5D039D, (q31_t)0xDAD7F3A2, + (q31_t)0x7A7D055B, (q31_t)0xD7D946D7, (q31_t)0x798A23B1, + (q31_t)0xD4E0CB14, (q31_t)0x78848413, (q31_t)0xD1EEF59E, + (q31_t)0x776C4EDB, (q31_t)0xCF043AB2, (q31_t)0x7641AF3C, + (q31_t)0xCC210D78, (q31_t)0x7504D345, (q31_t)0xC945DFEC, + (q31_t)0x73B5EBD0, (q31_t)0xC67322CD, (q31_t)0x72552C84, + (q31_t)0xC3A9458F, (q31_t)0x70E2CBC6, (q31_t)0xC0E8B648, + (q31_t)0x6F5F02B1, (q31_t)0xBE31E19B, (q31_t)0x6DCA0D14, + (q31_t)0xBB8532AF, (q31_t)0x6C242960, (q31_t)0xB8E31319, + (q31_t)0x6A6D98A4, (q31_t)0xB64BEACC, (q31_t)0x68A69E81, + (q31_t)0xB3C0200C, (q31_t)0x66CF811F, (q31_t)0xB140175B, + (q31_t)0x64E88926, (q31_t)0xAECC336B, (q31_t)0x62F201AC, + (q31_t)0xAC64D510, (q31_t)0x60EC3830, (q31_t)0xAA0A5B2D, + (q31_t)0x5ED77C89, (q31_t)0xA7BD22AB, (q31_t)0x5CB420DF, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, (q31_t)0xA34BDF20, + (q31_t)0x5842DD54, (q31_t)0xA1288376, (q31_t)0x55F5A4D2, + (q31_t)0x9F13C7D0, (q31_t)0x539B2AEF, (q31_t)0x9D0DFE53, + (q31_t)0x5133CC94, (q31_t)0x9B1776D9, (q31_t)0x4EBFE8A4, + (q31_t)0x99307EE0, (q31_t)0x4C3FDFF3, (q31_t)0x9759617E, + (q31_t)0x49B41533, (q31_t)0x9592675B, (q31_t)0x471CECE6, + (q31_t)0x93DBD69F, (q31_t)0x447ACD50, (q31_t)0x9235F2EB, + (q31_t)0x41CE1E64, (q31_t)0x90A0FD4E, (q31_t)0x3F1749B7, + (q31_t)0x8F1D343A, (q31_t)0x3C56BA70, (q31_t)0x8DAAD37B, + (q31_t)0x398CDD32, (q31_t)0x8C4A142F, (q31_t)0x36BA2013, + (q31_t)0x8AFB2CBA, (q31_t)0x33DEF287, (q31_t)0x89BE50C3, + (q31_t)0x30FBC54D, (q31_t)0x8893B124, (q31_t)0x2E110A62, + (q31_t)0x877B7BEC, (q31_t)0x2B1F34EB, (q31_t)0x8675DC4E, + (q31_t)0x2826B928, (q31_t)0x8582FAA4, (q31_t)0x25280C5D, + (q31_t)0x84A2FC62, (q31_t)0x2223A4C5, (q31_t)0x83D60411, + (q31_t)0x1F19F97B, (q31_t)0x831C314E, (q31_t)0x1C0B826A, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, (q31_t)0x81E26C16, + (q31_t)0x15E21444, (q31_t)0x8162AA03, (q31_t)0x12C8106E, + (q31_t)0x80F66E3C, (q31_t)0x0FAB272B, (q31_t)0x809DC970, + (q31_t)0x0C8BD35E, (q31_t)0x8058C94C, (q31_t)0x096A9049, + (q31_t)0x80277872, (q31_t)0x0647D97C, (q31_t)0x8009DE7D, + (q31_t)0x03242ABF, (q31_t)0x80000000, (q31_t)0x00000000, + (q31_t)0x8009DE7D, (q31_t)0xFCDBD541, (q31_t)0x80277872, + (q31_t)0xF9B82683, (q31_t)0x8058C94C, (q31_t)0xF6956FB6, + (q31_t)0x809DC970, (q31_t)0xF3742CA1, (q31_t)0x80F66E3C, + (q31_t)0xF054D8D4, (q31_t)0x8162AA03, (q31_t)0xED37EF91, + (q31_t)0x81E26C16, (q31_t)0xEA1DEBBB, (q31_t)0x8275A0C0, + (q31_t)0xE70747C3, (q31_t)0x831C314E, (q31_t)0xE3F47D95, + (q31_t)0x83D60411, (q31_t)0xE0E60684, (q31_t)0x84A2FC62, + (q31_t)0xDDDC5B3A, (q31_t)0x8582FAA4, (q31_t)0xDAD7F3A2, + (q31_t)0x8675DC4E, (q31_t)0xD7D946D7, (q31_t)0x877B7BEC, + (q31_t)0xD4E0CB14, (q31_t)0x8893B124, (q31_t)0xD1EEF59E, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, (q31_t)0x8AFB2CBA, + (q31_t)0xCC210D78, (q31_t)0x8C4A142F, (q31_t)0xC945DFEC, + (q31_t)0x8DAAD37B, (q31_t)0xC67322CD, (q31_t)0x8F1D343A, + (q31_t)0xC3A9458F, (q31_t)0x90A0FD4E, (q31_t)0xC0E8B648, + (q31_t)0x9235F2EB, (q31_t)0xBE31E19B, (q31_t)0x93DBD69F, + (q31_t)0xBB8532AF, (q31_t)0x9592675B, (q31_t)0xB8E31319, + (q31_t)0x9759617E, (q31_t)0xB64BEACC, (q31_t)0x99307EE0, + (q31_t)0xB3C0200C, (q31_t)0x9B1776D9, (q31_t)0xB140175B, + (q31_t)0x9D0DFE53, (q31_t)0xAECC336B, (q31_t)0x9F13C7D0, + (q31_t)0xAC64D510, (q31_t)0xA1288376, (q31_t)0xAA0A5B2D, + (q31_t)0xA34BDF20, (q31_t)0xA7BD22AB, (q31_t)0xA57D8666, + (q31_t)0xA57D8666, (q31_t)0xA7BD22AB, (q31_t)0xA34BDF20, + (q31_t)0xAA0A5B2D, (q31_t)0xA1288376, (q31_t)0xAC64D510, + (q31_t)0x9F13C7D0, (q31_t)0xAECC336B, (q31_t)0x9D0DFE53, + (q31_t)0xB140175B, (q31_t)0x9B1776D9, (q31_t)0xB3C0200C, + (q31_t)0x99307EE0, (q31_t)0xB64BEACC, (q31_t)0x9759617E, + (q31_t)0xB8E31319, (q31_t)0x9592675B, (q31_t)0xBB8532AF, + (q31_t)0x93DBD69F, (q31_t)0xBE31E19B, (q31_t)0x9235F2EB, + (q31_t)0xC0E8B648, (q31_t)0x90A0FD4E, (q31_t)0xC3A9458F, + (q31_t)0x8F1D343A, (q31_t)0xC67322CD, (q31_t)0x8DAAD37B, + (q31_t)0xC945DFEC, (q31_t)0x8C4A142F, (q31_t)0xCC210D78, + (q31_t)0x8AFB2CBA, (q31_t)0xCF043AB2, (q31_t)0x89BE50C3, + (q31_t)0xD1EEF59E, (q31_t)0x8893B124, (q31_t)0xD4E0CB14, + (q31_t)0x877B7BEC, (q31_t)0xD7D946D7, (q31_t)0x8675DC4E, + (q31_t)0xDAD7F3A2, (q31_t)0x8582FAA4, (q31_t)0xDDDC5B3A, + (q31_t)0x84A2FC62, (q31_t)0xE0E60684, (q31_t)0x83D60411, + (q31_t)0xE3F47D95, (q31_t)0x831C314E, (q31_t)0xE70747C3, + (q31_t)0x8275A0C0, (q31_t)0xEA1DEBBB, (q31_t)0x81E26C16, + (q31_t)0xED37EF91, (q31_t)0x8162AA03, (q31_t)0xF054D8D4, + (q31_t)0x80F66E3C, (q31_t)0xF3742CA1, (q31_t)0x809DC970, + (q31_t)0xF6956FB6, (q31_t)0x8058C94C, (q31_t)0xF9B82683, + (q31_t)0x80277872, (q31_t)0xFCDBD541, (q31_t)0x8009DE7D +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 512 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_512_q31[768] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, (q31_t)0x7FFD885A, + (q31_t)0x01921D1F, (q31_t)0x7FF62182, (q31_t)0x03242ABF, + (q31_t)0x7FE9CBC0, (q31_t)0x04B6195D, (q31_t)0x7FD8878D, + (q31_t)0x0647D97C, (q31_t)0x7FC25596, (q31_t)0x07D95B9E, + (q31_t)0x7FA736B4, (q31_t)0x096A9049, (q31_t)0x7F872BF3, + (q31_t)0x0AFB6805, (q31_t)0x7F62368F, (q31_t)0x0C8BD35E, + (q31_t)0x7F3857F5, (q31_t)0x0E1BC2E3, (q31_t)0x7F0991C3, + (q31_t)0x0FAB272B, (q31_t)0x7ED5E5C6, (q31_t)0x1139F0CE, + (q31_t)0x7E9D55FC, (q31_t)0x12C8106E, (q31_t)0x7E5FE493, + (q31_t)0x145576B1, (q31_t)0x7E1D93E9, (q31_t)0x15E21444, + (q31_t)0x7DD6668E, (q31_t)0x176DD9DE, (q31_t)0x7D8A5F3F, + (q31_t)0x18F8B83C, (q31_t)0x7D3980EC, (q31_t)0x1A82A025, + (q31_t)0x7CE3CEB1, (q31_t)0x1C0B826A, (q31_t)0x7C894BDD, + (q31_t)0x1D934FE5, (q31_t)0x7C29FBEE, (q31_t)0x1F19F97B, + (q31_t)0x7BC5E28F, (q31_t)0x209F701C, (q31_t)0x7B5D039D, + (q31_t)0x2223A4C5, (q31_t)0x7AEF6323, (q31_t)0x23A6887E, + (q31_t)0x7A7D055B, (q31_t)0x25280C5D, (q31_t)0x7A05EEAD, + (q31_t)0x26A82185, (q31_t)0x798A23B1, (q31_t)0x2826B928, + (q31_t)0x7909A92C, (q31_t)0x29A3C484, (q31_t)0x78848413, + (q31_t)0x2B1F34EB, (q31_t)0x77FAB988, (q31_t)0x2C98FBBA, + (q31_t)0x776C4EDB, (q31_t)0x2E110A62, (q31_t)0x76D94988, + (q31_t)0x2F875262, (q31_t)0x7641AF3C, (q31_t)0x30FBC54D, + (q31_t)0x75A585CF, (q31_t)0x326E54C7, (q31_t)0x7504D345, + (q31_t)0x33DEF287, (q31_t)0x745F9DD1, (q31_t)0x354D9056, + (q31_t)0x73B5EBD0, (q31_t)0x36BA2013, (q31_t)0x7307C3D0, + (q31_t)0x382493B0, (q31_t)0x72552C84, (q31_t)0x398CDD32, + (q31_t)0x719E2CD2, (q31_t)0x3AF2EEB7, (q31_t)0x70E2CBC6, + (q31_t)0x3C56BA70, (q31_t)0x70231099, (q31_t)0x3DB832A5, + (q31_t)0x6F5F02B1, (q31_t)0x3F1749B7, (q31_t)0x6E96A99C, + (q31_t)0x4073F21D, (q31_t)0x6DCA0D14, (q31_t)0x41CE1E64, + (q31_t)0x6CF934FB, (q31_t)0x4325C135, (q31_t)0x6C242960, + (q31_t)0x447ACD50, (q31_t)0x6B4AF278, (q31_t)0x45CD358F, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, (q31_t)0x698C246C, + (q31_t)0x4869E664, (q31_t)0x68A69E81, (q31_t)0x49B41533, + (q31_t)0x67BD0FBC, (q31_t)0x4AFB6C97, (q31_t)0x66CF811F, + (q31_t)0x4C3FDFF3, (q31_t)0x65DDFBD3, (q31_t)0x4D8162C4, + (q31_t)0x64E88926, (q31_t)0x4EBFE8A4, (q31_t)0x63EF328F, + (q31_t)0x4FFB654D, (q31_t)0x62F201AC, (q31_t)0x5133CC94, + (q31_t)0x61F1003E, (q31_t)0x5269126E, (q31_t)0x60EC3830, + (q31_t)0x539B2AEF, (q31_t)0x5FE3B38D, (q31_t)0x54CA0A4A, + (q31_t)0x5ED77C89, (q31_t)0x55F5A4D2, (q31_t)0x5DC79D7C, + (q31_t)0x571DEEF9, (q31_t)0x5CB420DF, (q31_t)0x5842DD54, + (q31_t)0x5B9D1153, (q31_t)0x59646497, (q31_t)0x5A82799A, + (q31_t)0x5A82799A, (q31_t)0x59646497, (q31_t)0x5B9D1153, + (q31_t)0x5842DD54, (q31_t)0x5CB420DF, (q31_t)0x571DEEF9, + (q31_t)0x5DC79D7C, (q31_t)0x55F5A4D2, (q31_t)0x5ED77C89, + (q31_t)0x54CA0A4A, (q31_t)0x5FE3B38D, (q31_t)0x539B2AEF, + (q31_t)0x60EC3830, (q31_t)0x5269126E, (q31_t)0x61F1003E, + (q31_t)0x5133CC94, (q31_t)0x62F201AC, (q31_t)0x4FFB654D, + (q31_t)0x63EF328F, (q31_t)0x4EBFE8A4, (q31_t)0x64E88926, + (q31_t)0x4D8162C4, (q31_t)0x65DDFBD3, (q31_t)0x4C3FDFF3, + (q31_t)0x66CF811F, (q31_t)0x4AFB6C97, (q31_t)0x67BD0FBC, + (q31_t)0x49B41533, (q31_t)0x68A69E81, (q31_t)0x4869E664, + (q31_t)0x698C246C, (q31_t)0x471CECE6, (q31_t)0x6A6D98A4, + (q31_t)0x45CD358F, (q31_t)0x6B4AF278, (q31_t)0x447ACD50, + (q31_t)0x6C242960, (q31_t)0x4325C135, (q31_t)0x6CF934FB, + (q31_t)0x41CE1E64, (q31_t)0x6DCA0D14, (q31_t)0x4073F21D, + (q31_t)0x6E96A99C, (q31_t)0x3F1749B7, (q31_t)0x6F5F02B1, + (q31_t)0x3DB832A5, (q31_t)0x70231099, (q31_t)0x3C56BA70, + (q31_t)0x70E2CBC6, (q31_t)0x3AF2EEB7, (q31_t)0x719E2CD2, + (q31_t)0x398CDD32, (q31_t)0x72552C84, (q31_t)0x382493B0, + (q31_t)0x7307C3D0, (q31_t)0x36BA2013, (q31_t)0x73B5EBD0, + (q31_t)0x354D9056, (q31_t)0x745F9DD1, (q31_t)0x33DEF287, + (q31_t)0x7504D345, (q31_t)0x326E54C7, (q31_t)0x75A585CF, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, (q31_t)0x2F875262, + (q31_t)0x76D94988, (q31_t)0x2E110A62, (q31_t)0x776C4EDB, + (q31_t)0x2C98FBBA, (q31_t)0x77FAB988, (q31_t)0x2B1F34EB, + (q31_t)0x78848413, (q31_t)0x29A3C484, (q31_t)0x7909A92C, + (q31_t)0x2826B928, (q31_t)0x798A23B1, (q31_t)0x26A82185, + (q31_t)0x7A05EEAD, (q31_t)0x25280C5D, (q31_t)0x7A7D055B, + (q31_t)0x23A6887E, (q31_t)0x7AEF6323, (q31_t)0x2223A4C5, + (q31_t)0x7B5D039D, (q31_t)0x209F701C, (q31_t)0x7BC5E28F, + (q31_t)0x1F19F97B, (q31_t)0x7C29FBEE, (q31_t)0x1D934FE5, + (q31_t)0x7C894BDD, (q31_t)0x1C0B826A, (q31_t)0x7CE3CEB1, + (q31_t)0x1A82A025, (q31_t)0x7D3980EC, (q31_t)0x18F8B83C, + (q31_t)0x7D8A5F3F, (q31_t)0x176DD9DE, (q31_t)0x7DD6668E, + (q31_t)0x15E21444, (q31_t)0x7E1D93E9, (q31_t)0x145576B1, + (q31_t)0x7E5FE493, (q31_t)0x12C8106E, (q31_t)0x7E9D55FC, + (q31_t)0x1139F0CE, (q31_t)0x7ED5E5C6, (q31_t)0x0FAB272B, + (q31_t)0x7F0991C3, (q31_t)0x0E1BC2E3, (q31_t)0x7F3857F5, + (q31_t)0x0C8BD35E, (q31_t)0x7F62368F, (q31_t)0x0AFB6805, + (q31_t)0x7F872BF3, (q31_t)0x096A9049, (q31_t)0x7FA736B4, + (q31_t)0x07D95B9E, (q31_t)0x7FC25596, (q31_t)0x0647D97C, + (q31_t)0x7FD8878D, (q31_t)0x04B6195D, (q31_t)0x7FE9CBC0, + (q31_t)0x03242ABF, (q31_t)0x7FF62182, (q31_t)0x01921D1F, + (q31_t)0x7FFD885A, (q31_t)0x00000000, (q31_t)0x7FFFFFFF, + (q31_t)0xFE6DE2E0, (q31_t)0x7FFD885A, (q31_t)0xFCDBD541, + (q31_t)0x7FF62182, (q31_t)0xFB49E6A2, (q31_t)0x7FE9CBC0, + (q31_t)0xF9B82683, (q31_t)0x7FD8878D, (q31_t)0xF826A461, + (q31_t)0x7FC25596, (q31_t)0xF6956FB6, (q31_t)0x7FA736B4, + (q31_t)0xF50497FA, (q31_t)0x7F872BF3, (q31_t)0xF3742CA1, + (q31_t)0x7F62368F, (q31_t)0xF1E43D1C, (q31_t)0x7F3857F5, + (q31_t)0xF054D8D4, (q31_t)0x7F0991C3, (q31_t)0xEEC60F31, + (q31_t)0x7ED5E5C6, (q31_t)0xED37EF91, (q31_t)0x7E9D55FC, + (q31_t)0xEBAA894E, (q31_t)0x7E5FE493, (q31_t)0xEA1DEBBB, + (q31_t)0x7E1D93E9, (q31_t)0xE8922621, (q31_t)0x7DD6668E, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, (q31_t)0xE57D5FDA, + (q31_t)0x7D3980EC, (q31_t)0xE3F47D95, (q31_t)0x7CE3CEB1, + (q31_t)0xE26CB01A, (q31_t)0x7C894BDD, (q31_t)0xE0E60684, + (q31_t)0x7C29FBEE, (q31_t)0xDF608FE3, (q31_t)0x7BC5E28F, + (q31_t)0xDDDC5B3A, (q31_t)0x7B5D039D, (q31_t)0xDC597781, + (q31_t)0x7AEF6323, (q31_t)0xDAD7F3A2, (q31_t)0x7A7D055B, + (q31_t)0xD957DE7A, (q31_t)0x7A05EEAD, (q31_t)0xD7D946D7, + (q31_t)0x798A23B1, (q31_t)0xD65C3B7B, (q31_t)0x7909A92C, + (q31_t)0xD4E0CB14, (q31_t)0x78848413, (q31_t)0xD3670445, + (q31_t)0x77FAB988, (q31_t)0xD1EEF59E, (q31_t)0x776C4EDB, + (q31_t)0xD078AD9D, (q31_t)0x76D94988, (q31_t)0xCF043AB2, + (q31_t)0x7641AF3C, (q31_t)0xCD91AB38, (q31_t)0x75A585CF, + (q31_t)0xCC210D78, (q31_t)0x7504D345, (q31_t)0xCAB26FA9, + (q31_t)0x745F9DD1, (q31_t)0xC945DFEC, (q31_t)0x73B5EBD0, + (q31_t)0xC7DB6C50, (q31_t)0x7307C3D0, (q31_t)0xC67322CD, + (q31_t)0x72552C84, (q31_t)0xC50D1148, (q31_t)0x719E2CD2, + (q31_t)0xC3A9458F, (q31_t)0x70E2CBC6, (q31_t)0xC247CD5A, + (q31_t)0x70231099, (q31_t)0xC0E8B648, (q31_t)0x6F5F02B1, + (q31_t)0xBF8C0DE2, (q31_t)0x6E96A99C, (q31_t)0xBE31E19B, + (q31_t)0x6DCA0D14, (q31_t)0xBCDA3ECA, (q31_t)0x6CF934FB, + (q31_t)0xBB8532AF, (q31_t)0x6C242960, (q31_t)0xBA32CA70, + (q31_t)0x6B4AF278, (q31_t)0xB8E31319, (q31_t)0x6A6D98A4, + (q31_t)0xB796199B, (q31_t)0x698C246C, (q31_t)0xB64BEACC, + (q31_t)0x68A69E81, (q31_t)0xB5049368, (q31_t)0x67BD0FBC, + (q31_t)0xB3C0200C, (q31_t)0x66CF811F, (q31_t)0xB27E9D3B, + (q31_t)0x65DDFBD3, (q31_t)0xB140175B, (q31_t)0x64E88926, + (q31_t)0xB0049AB2, (q31_t)0x63EF328F, (q31_t)0xAECC336B, + (q31_t)0x62F201AC, (q31_t)0xAD96ED91, (q31_t)0x61F1003E, + (q31_t)0xAC64D510, (q31_t)0x60EC3830, (q31_t)0xAB35F5B5, + (q31_t)0x5FE3B38D, (q31_t)0xAA0A5B2D, (q31_t)0x5ED77C89, + (q31_t)0xA8E21106, (q31_t)0x5DC79D7C, (q31_t)0xA7BD22AB, + (q31_t)0x5CB420DF, (q31_t)0xA69B9B68, (q31_t)0x5B9D1153, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, (q31_t)0xA462EEAC, + (q31_t)0x59646497, (q31_t)0xA34BDF20, (q31_t)0x5842DD54, + (q31_t)0xA2386283, (q31_t)0x571DEEF9, (q31_t)0xA1288376, + (q31_t)0x55F5A4D2, (q31_t)0xA01C4C72, (q31_t)0x54CA0A4A, + (q31_t)0x9F13C7D0, (q31_t)0x539B2AEF, (q31_t)0x9E0EFFC1, + (q31_t)0x5269126E, (q31_t)0x9D0DFE53, (q31_t)0x5133CC94, + (q31_t)0x9C10CD70, (q31_t)0x4FFB654D, (q31_t)0x9B1776D9, + (q31_t)0x4EBFE8A4, (q31_t)0x9A22042C, (q31_t)0x4D8162C4, + (q31_t)0x99307EE0, (q31_t)0x4C3FDFF3, (q31_t)0x9842F043, + (q31_t)0x4AFB6C97, (q31_t)0x9759617E, (q31_t)0x49B41533, + (q31_t)0x9673DB94, (q31_t)0x4869E664, (q31_t)0x9592675B, + (q31_t)0x471CECE6, (q31_t)0x94B50D87, (q31_t)0x45CD358F, + (q31_t)0x93DBD69F, (q31_t)0x447ACD50, (q31_t)0x9306CB04, + (q31_t)0x4325C135, (q31_t)0x9235F2EB, (q31_t)0x41CE1E64, + (q31_t)0x91695663, (q31_t)0x4073F21D, (q31_t)0x90A0FD4E, + (q31_t)0x3F1749B7, (q31_t)0x8FDCEF66, (q31_t)0x3DB832A5, + (q31_t)0x8F1D343A, (q31_t)0x3C56BA70, (q31_t)0x8E61D32D, + (q31_t)0x3AF2EEB7, (q31_t)0x8DAAD37B, (q31_t)0x398CDD32, + (q31_t)0x8CF83C30, (q31_t)0x382493B0, (q31_t)0x8C4A142F, + (q31_t)0x36BA2013, (q31_t)0x8BA0622F, (q31_t)0x354D9056, + (q31_t)0x8AFB2CBA, (q31_t)0x33DEF287, (q31_t)0x8A5A7A30, + (q31_t)0x326E54C7, (q31_t)0x89BE50C3, (q31_t)0x30FBC54D, + (q31_t)0x8926B677, (q31_t)0x2F875262, (q31_t)0x8893B124, + (q31_t)0x2E110A62, (q31_t)0x88054677, (q31_t)0x2C98FBBA, + (q31_t)0x877B7BEC, (q31_t)0x2B1F34EB, (q31_t)0x86F656D3, + (q31_t)0x29A3C484, (q31_t)0x8675DC4E, (q31_t)0x2826B928, + (q31_t)0x85FA1152, (q31_t)0x26A82185, (q31_t)0x8582FAA4, + (q31_t)0x25280C5D, (q31_t)0x85109CDC, (q31_t)0x23A6887E, + (q31_t)0x84A2FC62, (q31_t)0x2223A4C5, (q31_t)0x843A1D70, + (q31_t)0x209F701C, (q31_t)0x83D60411, (q31_t)0x1F19F97B, + (q31_t)0x8376B422, (q31_t)0x1D934FE5, (q31_t)0x831C314E, + (q31_t)0x1C0B826A, (q31_t)0x82C67F13, (q31_t)0x1A82A025, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, (q31_t)0x82299971, + (q31_t)0x176DD9DE, (q31_t)0x81E26C16, (q31_t)0x15E21444, + (q31_t)0x81A01B6C, (q31_t)0x145576B1, (q31_t)0x8162AA03, + (q31_t)0x12C8106E, (q31_t)0x812A1A39, (q31_t)0x1139F0CE, + (q31_t)0x80F66E3C, (q31_t)0x0FAB272B, (q31_t)0x80C7A80A, + (q31_t)0x0E1BC2E3, (q31_t)0x809DC970, (q31_t)0x0C8BD35E, + (q31_t)0x8078D40D, (q31_t)0x0AFB6805, (q31_t)0x8058C94C, + (q31_t)0x096A9049, (q31_t)0x803DAA69, (q31_t)0x07D95B9E, + (q31_t)0x80277872, (q31_t)0x0647D97C, (q31_t)0x80163440, + (q31_t)0x04B6195D, (q31_t)0x8009DE7D, (q31_t)0x03242ABF, + (q31_t)0x800277A5, (q31_t)0x01921D1F, (q31_t)0x80000000, + (q31_t)0x00000000, (q31_t)0x800277A5, (q31_t)0xFE6DE2E0, + (q31_t)0x8009DE7D, (q31_t)0xFCDBD541, (q31_t)0x80163440, + (q31_t)0xFB49E6A2, (q31_t)0x80277872, (q31_t)0xF9B82683, + (q31_t)0x803DAA69, (q31_t)0xF826A461, (q31_t)0x8058C94C, + (q31_t)0xF6956FB6, (q31_t)0x8078D40D, (q31_t)0xF50497FA, + (q31_t)0x809DC970, (q31_t)0xF3742CA1, (q31_t)0x80C7A80A, + (q31_t)0xF1E43D1C, (q31_t)0x80F66E3C, (q31_t)0xF054D8D4, + (q31_t)0x812A1A39, (q31_t)0xEEC60F31, (q31_t)0x8162AA03, + (q31_t)0xED37EF91, (q31_t)0x81A01B6C, (q31_t)0xEBAA894E, + (q31_t)0x81E26C16, (q31_t)0xEA1DEBBB, (q31_t)0x82299971, + (q31_t)0xE8922621, (q31_t)0x8275A0C0, (q31_t)0xE70747C3, + (q31_t)0x82C67F13, (q31_t)0xE57D5FDA, (q31_t)0x831C314E, + (q31_t)0xE3F47D95, (q31_t)0x8376B422, (q31_t)0xE26CB01A, + (q31_t)0x83D60411, (q31_t)0xE0E60684, (q31_t)0x843A1D70, + (q31_t)0xDF608FE3, (q31_t)0x84A2FC62, (q31_t)0xDDDC5B3A, + (q31_t)0x85109CDC, (q31_t)0xDC597781, (q31_t)0x8582FAA4, + (q31_t)0xDAD7F3A2, (q31_t)0x85FA1152, (q31_t)0xD957DE7A, + (q31_t)0x8675DC4E, (q31_t)0xD7D946D7, (q31_t)0x86F656D3, + (q31_t)0xD65C3B7B, (q31_t)0x877B7BEC, (q31_t)0xD4E0CB14, + (q31_t)0x88054677, (q31_t)0xD3670445, (q31_t)0x8893B124, + (q31_t)0xD1EEF59E, (q31_t)0x8926B677, (q31_t)0xD078AD9D, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, (q31_t)0x8A5A7A30, + (q31_t)0xCD91AB38, (q31_t)0x8AFB2CBA, (q31_t)0xCC210D78, + (q31_t)0x8BA0622F, (q31_t)0xCAB26FA9, (q31_t)0x8C4A142F, + (q31_t)0xC945DFEC, (q31_t)0x8CF83C30, (q31_t)0xC7DB6C50, + (q31_t)0x8DAAD37B, (q31_t)0xC67322CD, (q31_t)0x8E61D32D, + (q31_t)0xC50D1148, (q31_t)0x8F1D343A, (q31_t)0xC3A9458F, + (q31_t)0x8FDCEF66, (q31_t)0xC247CD5A, (q31_t)0x90A0FD4E, + (q31_t)0xC0E8B648, (q31_t)0x91695663, (q31_t)0xBF8C0DE2, + (q31_t)0x9235F2EB, (q31_t)0xBE31E19B, (q31_t)0x9306CB04, + (q31_t)0xBCDA3ECA, (q31_t)0x93DBD69F, (q31_t)0xBB8532AF, + (q31_t)0x94B50D87, (q31_t)0xBA32CA70, (q31_t)0x9592675B, + (q31_t)0xB8E31319, (q31_t)0x9673DB94, (q31_t)0xB796199B, + (q31_t)0x9759617E, (q31_t)0xB64BEACC, (q31_t)0x9842F043, + (q31_t)0xB5049368, (q31_t)0x99307EE0, (q31_t)0xB3C0200C, + (q31_t)0x9A22042C, (q31_t)0xB27E9D3B, (q31_t)0x9B1776D9, + (q31_t)0xB140175B, (q31_t)0x9C10CD70, (q31_t)0xB0049AB2, + (q31_t)0x9D0DFE53, (q31_t)0xAECC336B, (q31_t)0x9E0EFFC1, + (q31_t)0xAD96ED91, (q31_t)0x9F13C7D0, (q31_t)0xAC64D510, + (q31_t)0xA01C4C72, (q31_t)0xAB35F5B5, (q31_t)0xA1288376, + (q31_t)0xAA0A5B2D, (q31_t)0xA2386283, (q31_t)0xA8E21106, + (q31_t)0xA34BDF20, (q31_t)0xA7BD22AB, (q31_t)0xA462EEAC, + (q31_t)0xA69B9B68, (q31_t)0xA57D8666, (q31_t)0xA57D8666, + (q31_t)0xA69B9B68, (q31_t)0xA462EEAC, (q31_t)0xA7BD22AB, + (q31_t)0xA34BDF20, (q31_t)0xA8E21106, (q31_t)0xA2386283, + (q31_t)0xAA0A5B2D, (q31_t)0xA1288376, (q31_t)0xAB35F5B5, + (q31_t)0xA01C4C72, (q31_t)0xAC64D510, (q31_t)0x9F13C7D0, + (q31_t)0xAD96ED91, (q31_t)0x9E0EFFC1, (q31_t)0xAECC336B, + (q31_t)0x9D0DFE53, (q31_t)0xB0049AB2, (q31_t)0x9C10CD70, + (q31_t)0xB140175B, (q31_t)0x9B1776D9, (q31_t)0xB27E9D3B, + (q31_t)0x9A22042C, (q31_t)0xB3C0200C, (q31_t)0x99307EE0, + (q31_t)0xB5049368, (q31_t)0x9842F043, (q31_t)0xB64BEACC, + (q31_t)0x9759617E, (q31_t)0xB796199B, (q31_t)0x9673DB94, + (q31_t)0xB8E31319, (q31_t)0x9592675B, (q31_t)0xBA32CA70, + (q31_t)0x94B50D87, (q31_t)0xBB8532AF, (q31_t)0x93DBD69F, + (q31_t)0xBCDA3ECA, (q31_t)0x9306CB04, (q31_t)0xBE31E19B, + (q31_t)0x9235F2EB, (q31_t)0xBF8C0DE2, (q31_t)0x91695663, + (q31_t)0xC0E8B648, (q31_t)0x90A0FD4E, (q31_t)0xC247CD5A, + (q31_t)0x8FDCEF66, (q31_t)0xC3A9458F, (q31_t)0x8F1D343A, + (q31_t)0xC50D1148, (q31_t)0x8E61D32D, (q31_t)0xC67322CD, + (q31_t)0x8DAAD37B, (q31_t)0xC7DB6C50, (q31_t)0x8CF83C30, + (q31_t)0xC945DFEC, (q31_t)0x8C4A142F, (q31_t)0xCAB26FA9, + (q31_t)0x8BA0622F, (q31_t)0xCC210D78, (q31_t)0x8AFB2CBA, + (q31_t)0xCD91AB38, (q31_t)0x8A5A7A30, (q31_t)0xCF043AB2, + (q31_t)0x89BE50C3, (q31_t)0xD078AD9D, (q31_t)0x8926B677, + (q31_t)0xD1EEF59E, (q31_t)0x8893B124, (q31_t)0xD3670445, + (q31_t)0x88054677, (q31_t)0xD4E0CB14, (q31_t)0x877B7BEC, + (q31_t)0xD65C3B7B, (q31_t)0x86F656D3, (q31_t)0xD7D946D7, + (q31_t)0x8675DC4E, (q31_t)0xD957DE7A, (q31_t)0x85FA1152, + (q31_t)0xDAD7F3A2, (q31_t)0x8582FAA4, (q31_t)0xDC597781, + (q31_t)0x85109CDC, (q31_t)0xDDDC5B3A, (q31_t)0x84A2FC62, + (q31_t)0xDF608FE3, (q31_t)0x843A1D70, (q31_t)0xE0E60684, + (q31_t)0x83D60411, (q31_t)0xE26CB01A, (q31_t)0x8376B422, + (q31_t)0xE3F47D95, (q31_t)0x831C314E, (q31_t)0xE57D5FDA, + (q31_t)0x82C67F13, (q31_t)0xE70747C3, (q31_t)0x8275A0C0, + (q31_t)0xE8922621, (q31_t)0x82299971, (q31_t)0xEA1DEBBB, + (q31_t)0x81E26C16, (q31_t)0xEBAA894E, (q31_t)0x81A01B6C, + (q31_t)0xED37EF91, (q31_t)0x8162AA03, (q31_t)0xEEC60F31, + (q31_t)0x812A1A39, (q31_t)0xF054D8D4, (q31_t)0x80F66E3C, + (q31_t)0xF1E43D1C, (q31_t)0x80C7A80A, (q31_t)0xF3742CA1, + (q31_t)0x809DC970, (q31_t)0xF50497FA, (q31_t)0x8078D40D, + (q31_t)0xF6956FB6, (q31_t)0x8058C94C, (q31_t)0xF826A461, + (q31_t)0x803DAA69, (q31_t)0xF9B82683, (q31_t)0x80277872, + (q31_t)0xFB49E6A2, (q31_t)0x80163440, (q31_t)0xFCDBD541, + (q31_t)0x8009DE7D, (q31_t)0xFE6DE2E0, (q31_t)0x800277A5 +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 1024 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_1024_q31[1536] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, (q31_t)0x7FFF6216, + (q31_t)0x00C90F88, (q31_t)0x7FFD885A, (q31_t)0x01921D1F, + (q31_t)0x7FFA72D1, (q31_t)0x025B26D7, (q31_t)0x7FF62182, + (q31_t)0x03242ABF, (q31_t)0x7FF09477, (q31_t)0x03ED26E6, + (q31_t)0x7FE9CBC0, (q31_t)0x04B6195D, (q31_t)0x7FE1C76B, + (q31_t)0x057F0034, (q31_t)0x7FD8878D, (q31_t)0x0647D97C, + (q31_t)0x7FCE0C3E, (q31_t)0x0710A344, (q31_t)0x7FC25596, + (q31_t)0x07D95B9E, (q31_t)0x7FB563B2, (q31_t)0x08A2009A, + (q31_t)0x7FA736B4, (q31_t)0x096A9049, (q31_t)0x7F97CEBC, + (q31_t)0x0A3308BC, (q31_t)0x7F872BF3, (q31_t)0x0AFB6805, + (q31_t)0x7F754E7F, (q31_t)0x0BC3AC35, (q31_t)0x7F62368F, + (q31_t)0x0C8BD35E, (q31_t)0x7F4DE450, (q31_t)0x0D53DB92, + (q31_t)0x7F3857F5, (q31_t)0x0E1BC2E3, (q31_t)0x7F2191B4, + (q31_t)0x0EE38765, (q31_t)0x7F0991C3, (q31_t)0x0FAB272B, + (q31_t)0x7EF0585F, (q31_t)0x1072A047, (q31_t)0x7ED5E5C6, + (q31_t)0x1139F0CE, (q31_t)0x7EBA3A39, (q31_t)0x120116D4, + (q31_t)0x7E9D55FC, (q31_t)0x12C8106E, (q31_t)0x7E7F3956, + (q31_t)0x138EDBB0, (q31_t)0x7E5FE493, (q31_t)0x145576B1, + (q31_t)0x7E3F57FE, (q31_t)0x151BDF85, (q31_t)0x7E1D93E9, + (q31_t)0x15E21444, (q31_t)0x7DFA98A7, (q31_t)0x16A81305, + (q31_t)0x7DD6668E, (q31_t)0x176DD9DE, (q31_t)0x7DB0FDF7, + (q31_t)0x183366E8, (q31_t)0x7D8A5F3F, (q31_t)0x18F8B83C, + (q31_t)0x7D628AC5, (q31_t)0x19BDCBF2, (q31_t)0x7D3980EC, + (q31_t)0x1A82A025, (q31_t)0x7D0F4218, (q31_t)0x1B4732EF, + (q31_t)0x7CE3CEB1, (q31_t)0x1C0B826A, (q31_t)0x7CB72724, + (q31_t)0x1CCF8CB3, (q31_t)0x7C894BDD, (q31_t)0x1D934FE5, + (q31_t)0x7C5A3D4F, (q31_t)0x1E56CA1E, (q31_t)0x7C29FBEE, + (q31_t)0x1F19F97B, (q31_t)0x7BF88830, (q31_t)0x1FDCDC1A, + (q31_t)0x7BC5E28F, (q31_t)0x209F701C, (q31_t)0x7B920B89, + (q31_t)0x2161B39F, (q31_t)0x7B5D039D, (q31_t)0x2223A4C5, + (q31_t)0x7B26CB4F, (q31_t)0x22E541AE, (q31_t)0x7AEF6323, + (q31_t)0x23A6887E, (q31_t)0x7AB6CBA3, (q31_t)0x24677757, + (q31_t)0x7A7D055B, (q31_t)0x25280C5D, (q31_t)0x7A4210D8, + (q31_t)0x25E845B5, (q31_t)0x7A05EEAD, (q31_t)0x26A82185, + (q31_t)0x79C89F6D, (q31_t)0x27679DF4, (q31_t)0x798A23B1, + (q31_t)0x2826B928, (q31_t)0x794A7C11, (q31_t)0x28E5714A, + (q31_t)0x7909A92C, (q31_t)0x29A3C484, (q31_t)0x78C7ABA1, + (q31_t)0x2A61B101, (q31_t)0x78848413, (q31_t)0x2B1F34EB, + (q31_t)0x78403328, (q31_t)0x2BDC4E6F, (q31_t)0x77FAB988, + (q31_t)0x2C98FBBA, (q31_t)0x77B417DF, (q31_t)0x2D553AFB, + (q31_t)0x776C4EDB, (q31_t)0x2E110A62, (q31_t)0x77235F2D, + (q31_t)0x2ECC681E, (q31_t)0x76D94988, (q31_t)0x2F875262, + (q31_t)0x768E0EA5, (q31_t)0x3041C760, (q31_t)0x7641AF3C, + (q31_t)0x30FBC54D, (q31_t)0x75F42C0A, (q31_t)0x31B54A5D, + (q31_t)0x75A585CF, (q31_t)0x326E54C7, (q31_t)0x7555BD4B, + (q31_t)0x3326E2C2, (q31_t)0x7504D345, (q31_t)0x33DEF287, + (q31_t)0x74B2C883, (q31_t)0x3496824F, (q31_t)0x745F9DD1, + (q31_t)0x354D9056, (q31_t)0x740B53FA, (q31_t)0x36041AD9, + (q31_t)0x73B5EBD0, (q31_t)0x36BA2013, (q31_t)0x735F6626, + (q31_t)0x376F9E46, (q31_t)0x7307C3D0, (q31_t)0x382493B0, + (q31_t)0x72AF05A6, (q31_t)0x38D8FE93, (q31_t)0x72552C84, + (q31_t)0x398CDD32, (q31_t)0x71FA3948, (q31_t)0x3A402DD1, + (q31_t)0x719E2CD2, (q31_t)0x3AF2EEB7, (q31_t)0x71410804, + (q31_t)0x3BA51E29, (q31_t)0x70E2CBC6, (q31_t)0x3C56BA70, + (q31_t)0x708378FE, (q31_t)0x3D07C1D5, (q31_t)0x70231099, + (q31_t)0x3DB832A5, (q31_t)0x6FC19385, (q31_t)0x3E680B2C, + (q31_t)0x6F5F02B1, (q31_t)0x3F1749B7, (q31_t)0x6EFB5F12, + (q31_t)0x3FC5EC97, (q31_t)0x6E96A99C, (q31_t)0x4073F21D, + (q31_t)0x6E30E349, (q31_t)0x4121589A, (q31_t)0x6DCA0D14, + (q31_t)0x41CE1E64, (q31_t)0x6D6227FA, (q31_t)0x427A41D0, + (q31_t)0x6CF934FB, (q31_t)0x4325C135, (q31_t)0x6C8F351C, + (q31_t)0x43D09AEC, (q31_t)0x6C242960, (q31_t)0x447ACD50, + (q31_t)0x6BB812D0, (q31_t)0x452456BC, (q31_t)0x6B4AF278, + (q31_t)0x45CD358F, (q31_t)0x6ADCC964, (q31_t)0x46756827, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, (q31_t)0x69FD614A, + (q31_t)0x47C3C22E, (q31_t)0x698C246C, (q31_t)0x4869E664, + (q31_t)0x6919E320, (q31_t)0x490F57EE, (q31_t)0x68A69E81, + (q31_t)0x49B41533, (q31_t)0x683257AA, (q31_t)0x4A581C9D, + (q31_t)0x67BD0FBC, (q31_t)0x4AFB6C97, (q31_t)0x6746C7D7, + (q31_t)0x4B9E038F, (q31_t)0x66CF811F, (q31_t)0x4C3FDFF3, + (q31_t)0x66573CBB, (q31_t)0x4CE10034, (q31_t)0x65DDFBD3, + (q31_t)0x4D8162C4, (q31_t)0x6563BF92, (q31_t)0x4E210617, + (q31_t)0x64E88926, (q31_t)0x4EBFE8A4, (q31_t)0x646C59BF, + (q31_t)0x4F5E08E3, (q31_t)0x63EF328F, (q31_t)0x4FFB654D, + (q31_t)0x637114CC, (q31_t)0x5097FC5E, (q31_t)0x62F201AC, + (q31_t)0x5133CC94, (q31_t)0x6271FA69, (q31_t)0x51CED46E, + (q31_t)0x61F1003E, (q31_t)0x5269126E, (q31_t)0x616F146B, + (q31_t)0x53028517, (q31_t)0x60EC3830, (q31_t)0x539B2AEF, + (q31_t)0x60686CCE, (q31_t)0x5433027D, (q31_t)0x5FE3B38D, + (q31_t)0x54CA0A4A, (q31_t)0x5F5E0DB3, (q31_t)0x556040E2, + (q31_t)0x5ED77C89, (q31_t)0x55F5A4D2, (q31_t)0x5E50015D, + (q31_t)0x568A34A9, (q31_t)0x5DC79D7C, (q31_t)0x571DEEF9, + (q31_t)0x5D3E5236, (q31_t)0x57B0D256, (q31_t)0x5CB420DF, + (q31_t)0x5842DD54, (q31_t)0x5C290ACC, (q31_t)0x58D40E8C, + (q31_t)0x5B9D1153, (q31_t)0x59646497, (q31_t)0x5B1035CF, + (q31_t)0x59F3DE12, (q31_t)0x5A82799A, (q31_t)0x5A82799A, + (q31_t)0x59F3DE12, (q31_t)0x5B1035CF, (q31_t)0x59646497, + (q31_t)0x5B9D1153, (q31_t)0x58D40E8C, (q31_t)0x5C290ACC, + (q31_t)0x5842DD54, (q31_t)0x5CB420DF, (q31_t)0x57B0D256, + (q31_t)0x5D3E5236, (q31_t)0x571DEEF9, (q31_t)0x5DC79D7C, + (q31_t)0x568A34A9, (q31_t)0x5E50015D, (q31_t)0x55F5A4D2, + (q31_t)0x5ED77C89, (q31_t)0x556040E2, (q31_t)0x5F5E0DB3, + (q31_t)0x54CA0A4A, (q31_t)0x5FE3B38D, (q31_t)0x5433027D, + (q31_t)0x60686CCE, (q31_t)0x539B2AEF, (q31_t)0x60EC3830, + (q31_t)0x53028517, (q31_t)0x616F146B, (q31_t)0x5269126E, + (q31_t)0x61F1003E, (q31_t)0x51CED46E, (q31_t)0x6271FA69, + (q31_t)0x5133CC94, (q31_t)0x62F201AC, (q31_t)0x5097FC5E, + (q31_t)0x637114CC, (q31_t)0x4FFB654D, (q31_t)0x63EF328F, + (q31_t)0x4F5E08E3, (q31_t)0x646C59BF, (q31_t)0x4EBFE8A4, + (q31_t)0x64E88926, (q31_t)0x4E210617, (q31_t)0x6563BF92, + (q31_t)0x4D8162C4, (q31_t)0x65DDFBD3, (q31_t)0x4CE10034, + (q31_t)0x66573CBB, (q31_t)0x4C3FDFF3, (q31_t)0x66CF811F, + (q31_t)0x4B9E038F, (q31_t)0x6746C7D7, (q31_t)0x4AFB6C97, + (q31_t)0x67BD0FBC, (q31_t)0x4A581C9D, (q31_t)0x683257AA, + (q31_t)0x49B41533, (q31_t)0x68A69E81, (q31_t)0x490F57EE, + (q31_t)0x6919E320, (q31_t)0x4869E664, (q31_t)0x698C246C, + (q31_t)0x47C3C22E, (q31_t)0x69FD614A, (q31_t)0x471CECE6, + (q31_t)0x6A6D98A4, (q31_t)0x46756827, (q31_t)0x6ADCC964, + (q31_t)0x45CD358F, (q31_t)0x6B4AF278, (q31_t)0x452456BC, + (q31_t)0x6BB812D0, (q31_t)0x447ACD50, (q31_t)0x6C242960, + (q31_t)0x43D09AEC, (q31_t)0x6C8F351C, (q31_t)0x4325C135, + (q31_t)0x6CF934FB, (q31_t)0x427A41D0, (q31_t)0x6D6227FA, + (q31_t)0x41CE1E64, (q31_t)0x6DCA0D14, (q31_t)0x4121589A, + (q31_t)0x6E30E349, (q31_t)0x4073F21D, (q31_t)0x6E96A99C, + (q31_t)0x3FC5EC97, (q31_t)0x6EFB5F12, (q31_t)0x3F1749B7, + (q31_t)0x6F5F02B1, (q31_t)0x3E680B2C, (q31_t)0x6FC19385, + (q31_t)0x3DB832A5, (q31_t)0x70231099, (q31_t)0x3D07C1D5, + (q31_t)0x708378FE, (q31_t)0x3C56BA70, (q31_t)0x70E2CBC6, + (q31_t)0x3BA51E29, (q31_t)0x71410804, (q31_t)0x3AF2EEB7, + (q31_t)0x719E2CD2, (q31_t)0x3A402DD1, (q31_t)0x71FA3948, + (q31_t)0x398CDD32, (q31_t)0x72552C84, (q31_t)0x38D8FE93, + (q31_t)0x72AF05A6, (q31_t)0x382493B0, (q31_t)0x7307C3D0, + (q31_t)0x376F9E46, (q31_t)0x735F6626, (q31_t)0x36BA2013, + (q31_t)0x73B5EBD0, (q31_t)0x36041AD9, (q31_t)0x740B53FA, + (q31_t)0x354D9056, (q31_t)0x745F9DD1, (q31_t)0x3496824F, + (q31_t)0x74B2C883, (q31_t)0x33DEF287, (q31_t)0x7504D345, + (q31_t)0x3326E2C2, (q31_t)0x7555BD4B, (q31_t)0x326E54C7, + (q31_t)0x75A585CF, (q31_t)0x31B54A5D, (q31_t)0x75F42C0A, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, (q31_t)0x3041C760, + (q31_t)0x768E0EA5, (q31_t)0x2F875262, (q31_t)0x76D94988, + (q31_t)0x2ECC681E, (q31_t)0x77235F2D, (q31_t)0x2E110A62, + (q31_t)0x776C4EDB, (q31_t)0x2D553AFB, (q31_t)0x77B417DF, + (q31_t)0x2C98FBBA, (q31_t)0x77FAB988, (q31_t)0x2BDC4E6F, + (q31_t)0x78403328, (q31_t)0x2B1F34EB, (q31_t)0x78848413, + (q31_t)0x2A61B101, (q31_t)0x78C7ABA1, (q31_t)0x29A3C484, + (q31_t)0x7909A92C, (q31_t)0x28E5714A, (q31_t)0x794A7C11, + (q31_t)0x2826B928, (q31_t)0x798A23B1, (q31_t)0x27679DF4, + (q31_t)0x79C89F6D, (q31_t)0x26A82185, (q31_t)0x7A05EEAD, + (q31_t)0x25E845B5, (q31_t)0x7A4210D8, (q31_t)0x25280C5D, + (q31_t)0x7A7D055B, (q31_t)0x24677757, (q31_t)0x7AB6CBA3, + (q31_t)0x23A6887E, (q31_t)0x7AEF6323, (q31_t)0x22E541AE, + (q31_t)0x7B26CB4F, (q31_t)0x2223A4C5, (q31_t)0x7B5D039D, + (q31_t)0x2161B39F, (q31_t)0x7B920B89, (q31_t)0x209F701C, + (q31_t)0x7BC5E28F, (q31_t)0x1FDCDC1A, (q31_t)0x7BF88830, + (q31_t)0x1F19F97B, (q31_t)0x7C29FBEE, (q31_t)0x1E56CA1E, + (q31_t)0x7C5A3D4F, (q31_t)0x1D934FE5, (q31_t)0x7C894BDD, + (q31_t)0x1CCF8CB3, (q31_t)0x7CB72724, (q31_t)0x1C0B826A, + (q31_t)0x7CE3CEB1, (q31_t)0x1B4732EF, (q31_t)0x7D0F4218, + (q31_t)0x1A82A025, (q31_t)0x7D3980EC, (q31_t)0x19BDCBF2, + (q31_t)0x7D628AC5, (q31_t)0x18F8B83C, (q31_t)0x7D8A5F3F, + (q31_t)0x183366E8, (q31_t)0x7DB0FDF7, (q31_t)0x176DD9DE, + (q31_t)0x7DD6668E, (q31_t)0x16A81305, (q31_t)0x7DFA98A7, + (q31_t)0x15E21444, (q31_t)0x7E1D93E9, (q31_t)0x151BDF85, + (q31_t)0x7E3F57FE, (q31_t)0x145576B1, (q31_t)0x7E5FE493, + (q31_t)0x138EDBB0, (q31_t)0x7E7F3956, (q31_t)0x12C8106E, + (q31_t)0x7E9D55FC, (q31_t)0x120116D4, (q31_t)0x7EBA3A39, + (q31_t)0x1139F0CE, (q31_t)0x7ED5E5C6, (q31_t)0x1072A047, + (q31_t)0x7EF0585F, (q31_t)0x0FAB272B, (q31_t)0x7F0991C3, + (q31_t)0x0EE38765, (q31_t)0x7F2191B4, (q31_t)0x0E1BC2E3, + (q31_t)0x7F3857F5, (q31_t)0x0D53DB92, (q31_t)0x7F4DE450, + (q31_t)0x0C8BD35E, (q31_t)0x7F62368F, (q31_t)0x0BC3AC35, + (q31_t)0x7F754E7F, (q31_t)0x0AFB6805, (q31_t)0x7F872BF3, + (q31_t)0x0A3308BC, (q31_t)0x7F97CEBC, (q31_t)0x096A9049, + (q31_t)0x7FA736B4, (q31_t)0x08A2009A, (q31_t)0x7FB563B2, + (q31_t)0x07D95B9E, (q31_t)0x7FC25596, (q31_t)0x0710A344, + (q31_t)0x7FCE0C3E, (q31_t)0x0647D97C, (q31_t)0x7FD8878D, + (q31_t)0x057F0034, (q31_t)0x7FE1C76B, (q31_t)0x04B6195D, + (q31_t)0x7FE9CBC0, (q31_t)0x03ED26E6, (q31_t)0x7FF09477, + (q31_t)0x03242ABF, (q31_t)0x7FF62182, (q31_t)0x025B26D7, + (q31_t)0x7FFA72D1, (q31_t)0x01921D1F, (q31_t)0x7FFD885A, + (q31_t)0x00C90F88, (q31_t)0x7FFF6216, (q31_t)0x00000000, + (q31_t)0x7FFFFFFF, (q31_t)0xFF36F078, (q31_t)0x7FFF6216, + (q31_t)0xFE6DE2E0, (q31_t)0x7FFD885A, (q31_t)0xFDA4D928, + (q31_t)0x7FFA72D1, (q31_t)0xFCDBD541, (q31_t)0x7FF62182, + (q31_t)0xFC12D919, (q31_t)0x7FF09477, (q31_t)0xFB49E6A2, + (q31_t)0x7FE9CBC0, (q31_t)0xFA80FFCB, (q31_t)0x7FE1C76B, + (q31_t)0xF9B82683, (q31_t)0x7FD8878D, (q31_t)0xF8EF5CBB, + (q31_t)0x7FCE0C3E, (q31_t)0xF826A461, (q31_t)0x7FC25596, + (q31_t)0xF75DFF65, (q31_t)0x7FB563B2, (q31_t)0xF6956FB6, + (q31_t)0x7FA736B4, (q31_t)0xF5CCF743, (q31_t)0x7F97CEBC, + (q31_t)0xF50497FA, (q31_t)0x7F872BF3, (q31_t)0xF43C53CA, + (q31_t)0x7F754E7F, (q31_t)0xF3742CA1, (q31_t)0x7F62368F, + (q31_t)0xF2AC246D, (q31_t)0x7F4DE450, (q31_t)0xF1E43D1C, + (q31_t)0x7F3857F5, (q31_t)0xF11C789A, (q31_t)0x7F2191B4, + (q31_t)0xF054D8D4, (q31_t)0x7F0991C3, (q31_t)0xEF8D5FB8, + (q31_t)0x7EF0585F, (q31_t)0xEEC60F31, (q31_t)0x7ED5E5C6, + (q31_t)0xEDFEE92B, (q31_t)0x7EBA3A39, (q31_t)0xED37EF91, + (q31_t)0x7E9D55FC, (q31_t)0xEC71244F, (q31_t)0x7E7F3956, + (q31_t)0xEBAA894E, (q31_t)0x7E5FE493, (q31_t)0xEAE4207A, + (q31_t)0x7E3F57FE, (q31_t)0xEA1DEBBB, (q31_t)0x7E1D93E9, + (q31_t)0xE957ECFB, (q31_t)0x7DFA98A7, (q31_t)0xE8922621, + (q31_t)0x7DD6668E, (q31_t)0xE7CC9917, (q31_t)0x7DB0FDF7, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, (q31_t)0xE642340D, + (q31_t)0x7D628AC5, (q31_t)0xE57D5FDA, (q31_t)0x7D3980EC, + (q31_t)0xE4B8CD10, (q31_t)0x7D0F4218, (q31_t)0xE3F47D95, + (q31_t)0x7CE3CEB1, (q31_t)0xE330734C, (q31_t)0x7CB72724, + (q31_t)0xE26CB01A, (q31_t)0x7C894BDD, (q31_t)0xE1A935E1, + (q31_t)0x7C5A3D4F, (q31_t)0xE0E60684, (q31_t)0x7C29FBEE, + (q31_t)0xE02323E5, (q31_t)0x7BF88830, (q31_t)0xDF608FE3, + (q31_t)0x7BC5E28F, (q31_t)0xDE9E4C60, (q31_t)0x7B920B89, + (q31_t)0xDDDC5B3A, (q31_t)0x7B5D039D, (q31_t)0xDD1ABE51, + (q31_t)0x7B26CB4F, (q31_t)0xDC597781, (q31_t)0x7AEF6323, + (q31_t)0xDB9888A8, (q31_t)0x7AB6CBA3, (q31_t)0xDAD7F3A2, + (q31_t)0x7A7D055B, (q31_t)0xDA17BA4A, (q31_t)0x7A4210D8, + (q31_t)0xD957DE7A, (q31_t)0x7A05EEAD, (q31_t)0xD898620C, + (q31_t)0x79C89F6D, (q31_t)0xD7D946D7, (q31_t)0x798A23B1, + (q31_t)0xD71A8EB5, (q31_t)0x794A7C11, (q31_t)0xD65C3B7B, + (q31_t)0x7909A92C, (q31_t)0xD59E4EFE, (q31_t)0x78C7ABA1, + (q31_t)0xD4E0CB14, (q31_t)0x78848413, (q31_t)0xD423B190, + (q31_t)0x78403328, (q31_t)0xD3670445, (q31_t)0x77FAB988, + (q31_t)0xD2AAC504, (q31_t)0x77B417DF, (q31_t)0xD1EEF59E, + (q31_t)0x776C4EDB, (q31_t)0xD13397E1, (q31_t)0x77235F2D, + (q31_t)0xD078AD9D, (q31_t)0x76D94988, (q31_t)0xCFBE389F, + (q31_t)0x768E0EA5, (q31_t)0xCF043AB2, (q31_t)0x7641AF3C, + (q31_t)0xCE4AB5A2, (q31_t)0x75F42C0A, (q31_t)0xCD91AB38, + (q31_t)0x75A585CF, (q31_t)0xCCD91D3D, (q31_t)0x7555BD4B, + (q31_t)0xCC210D78, (q31_t)0x7504D345, (q31_t)0xCB697DB0, + (q31_t)0x74B2C883, (q31_t)0xCAB26FA9, (q31_t)0x745F9DD1, + (q31_t)0xC9FBE527, (q31_t)0x740B53FA, (q31_t)0xC945DFEC, + (q31_t)0x73B5EBD0, (q31_t)0xC89061BA, (q31_t)0x735F6626, + (q31_t)0xC7DB6C50, (q31_t)0x7307C3D0, (q31_t)0xC727016C, + (q31_t)0x72AF05A6, (q31_t)0xC67322CD, (q31_t)0x72552C84, + (q31_t)0xC5BFD22E, (q31_t)0x71FA3948, (q31_t)0xC50D1148, + (q31_t)0x719E2CD2, (q31_t)0xC45AE1D7, (q31_t)0x71410804, + (q31_t)0xC3A9458F, (q31_t)0x70E2CBC6, (q31_t)0xC2F83E2A, + (q31_t)0x708378FE, (q31_t)0xC247CD5A, (q31_t)0x70231099, + (q31_t)0xC197F4D3, (q31_t)0x6FC19385, (q31_t)0xC0E8B648, + (q31_t)0x6F5F02B1, (q31_t)0xC03A1368, (q31_t)0x6EFB5F12, + (q31_t)0xBF8C0DE2, (q31_t)0x6E96A99C, (q31_t)0xBEDEA765, + (q31_t)0x6E30E349, (q31_t)0xBE31E19B, (q31_t)0x6DCA0D14, + (q31_t)0xBD85BE2F, (q31_t)0x6D6227FA, (q31_t)0xBCDA3ECA, + (q31_t)0x6CF934FB, (q31_t)0xBC2F6513, (q31_t)0x6C8F351C, + (q31_t)0xBB8532AF, (q31_t)0x6C242960, (q31_t)0xBADBA943, + (q31_t)0x6BB812D0, (q31_t)0xBA32CA70, (q31_t)0x6B4AF278, + (q31_t)0xB98A97D8, (q31_t)0x6ADCC964, (q31_t)0xB8E31319, + (q31_t)0x6A6D98A4, (q31_t)0xB83C3DD1, (q31_t)0x69FD614A, + (q31_t)0xB796199B, (q31_t)0x698C246C, (q31_t)0xB6F0A811, + (q31_t)0x6919E320, (q31_t)0xB64BEACC, (q31_t)0x68A69E81, + (q31_t)0xB5A7E362, (q31_t)0x683257AA, (q31_t)0xB5049368, + (q31_t)0x67BD0FBC, (q31_t)0xB461FC70, (q31_t)0x6746C7D7, + (q31_t)0xB3C0200C, (q31_t)0x66CF811F, (q31_t)0xB31EFFCB, + (q31_t)0x66573CBB, (q31_t)0xB27E9D3B, (q31_t)0x65DDFBD3, + (q31_t)0xB1DEF9E8, (q31_t)0x6563BF92, (q31_t)0xB140175B, + (q31_t)0x64E88926, (q31_t)0xB0A1F71C, (q31_t)0x646C59BF, + (q31_t)0xB0049AB2, (q31_t)0x63EF328F, (q31_t)0xAF6803A1, + (q31_t)0x637114CC, (q31_t)0xAECC336B, (q31_t)0x62F201AC, + (q31_t)0xAE312B91, (q31_t)0x6271FA69, (q31_t)0xAD96ED91, + (q31_t)0x61F1003E, (q31_t)0xACFD7AE8, (q31_t)0x616F146B, + (q31_t)0xAC64D510, (q31_t)0x60EC3830, (q31_t)0xABCCFD82, + (q31_t)0x60686CCE, (q31_t)0xAB35F5B5, (q31_t)0x5FE3B38D, + (q31_t)0xAA9FBF1D, (q31_t)0x5F5E0DB3, (q31_t)0xAA0A5B2D, + (q31_t)0x5ED77C89, (q31_t)0xA975CB56, (q31_t)0x5E50015D, + (q31_t)0xA8E21106, (q31_t)0x5DC79D7C, (q31_t)0xA84F2DA9, + (q31_t)0x5D3E5236, (q31_t)0xA7BD22AB, (q31_t)0x5CB420DF, + (q31_t)0xA72BF173, (q31_t)0x5C290ACC, (q31_t)0xA69B9B68, + (q31_t)0x5B9D1153, (q31_t)0xA60C21ED, (q31_t)0x5B1035CF, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, (q31_t)0xA4EFCA31, + (q31_t)0x59F3DE12, (q31_t)0xA462EEAC, (q31_t)0x59646497, + (q31_t)0xA3D6F533, (q31_t)0x58D40E8C, (q31_t)0xA34BDF20, + (q31_t)0x5842DD54, (q31_t)0xA2C1ADC9, (q31_t)0x57B0D256, + (q31_t)0xA2386283, (q31_t)0x571DEEF9, (q31_t)0xA1AFFEA2, + (q31_t)0x568A34A9, (q31_t)0xA1288376, (q31_t)0x55F5A4D2, + (q31_t)0xA0A1F24C, (q31_t)0x556040E2, (q31_t)0xA01C4C72, + (q31_t)0x54CA0A4A, (q31_t)0x9F979331, (q31_t)0x5433027D, + (q31_t)0x9F13C7D0, (q31_t)0x539B2AEF, (q31_t)0x9E90EB94, + (q31_t)0x53028517, (q31_t)0x9E0EFFC1, (q31_t)0x5269126E, + (q31_t)0x9D8E0596, (q31_t)0x51CED46E, (q31_t)0x9D0DFE53, + (q31_t)0x5133CC94, (q31_t)0x9C8EEB33, (q31_t)0x5097FC5E, + (q31_t)0x9C10CD70, (q31_t)0x4FFB654D, (q31_t)0x9B93A640, + (q31_t)0x4F5E08E3, (q31_t)0x9B1776D9, (q31_t)0x4EBFE8A4, + (q31_t)0x9A9C406D, (q31_t)0x4E210617, (q31_t)0x9A22042C, + (q31_t)0x4D8162C4, (q31_t)0x99A8C344, (q31_t)0x4CE10034, + (q31_t)0x99307EE0, (q31_t)0x4C3FDFF3, (q31_t)0x98B93828, + (q31_t)0x4B9E038F, (q31_t)0x9842F043, (q31_t)0x4AFB6C97, + (q31_t)0x97CDA855, (q31_t)0x4A581C9D, (q31_t)0x9759617E, + (q31_t)0x49B41533, (q31_t)0x96E61CDF, (q31_t)0x490F57EE, + (q31_t)0x9673DB94, (q31_t)0x4869E664, (q31_t)0x96029EB5, + (q31_t)0x47C3C22E, (q31_t)0x9592675B, (q31_t)0x471CECE6, + (q31_t)0x9523369B, (q31_t)0x46756827, (q31_t)0x94B50D87, + (q31_t)0x45CD358F, (q31_t)0x9447ED2F, (q31_t)0x452456BC, + (q31_t)0x93DBD69F, (q31_t)0x447ACD50, (q31_t)0x9370CAE4, + (q31_t)0x43D09AEC, (q31_t)0x9306CB04, (q31_t)0x4325C135, + (q31_t)0x929DD805, (q31_t)0x427A41D0, (q31_t)0x9235F2EB, + (q31_t)0x41CE1E64, (q31_t)0x91CF1CB6, (q31_t)0x4121589A, + (q31_t)0x91695663, (q31_t)0x4073F21D, (q31_t)0x9104A0ED, + (q31_t)0x3FC5EC97, (q31_t)0x90A0FD4E, (q31_t)0x3F1749B7, + (q31_t)0x903E6C7A, (q31_t)0x3E680B2C, (q31_t)0x8FDCEF66, + (q31_t)0x3DB832A5, (q31_t)0x8F7C8701, (q31_t)0x3D07C1D5, + (q31_t)0x8F1D343A, (q31_t)0x3C56BA70, (q31_t)0x8EBEF7FB, + (q31_t)0x3BA51E29, (q31_t)0x8E61D32D, (q31_t)0x3AF2EEB7, + (q31_t)0x8E05C6B7, (q31_t)0x3A402DD1, (q31_t)0x8DAAD37B, + (q31_t)0x398CDD32, (q31_t)0x8D50FA59, (q31_t)0x38D8FE93, + (q31_t)0x8CF83C30, (q31_t)0x382493B0, (q31_t)0x8CA099D9, + (q31_t)0x376F9E46, (q31_t)0x8C4A142F, (q31_t)0x36BA2013, + (q31_t)0x8BF4AC05, (q31_t)0x36041AD9, (q31_t)0x8BA0622F, + (q31_t)0x354D9056, (q31_t)0x8B4D377C, (q31_t)0x3496824F, + (q31_t)0x8AFB2CBA, (q31_t)0x33DEF287, (q31_t)0x8AAA42B4, + (q31_t)0x3326E2C2, (q31_t)0x8A5A7A30, (q31_t)0x326E54C7, + (q31_t)0x8A0BD3F5, (q31_t)0x31B54A5D, (q31_t)0x89BE50C3, + (q31_t)0x30FBC54D, (q31_t)0x8971F15A, (q31_t)0x3041C760, + (q31_t)0x8926B677, (q31_t)0x2F875262, (q31_t)0x88DCA0D3, + (q31_t)0x2ECC681E, (q31_t)0x8893B124, (q31_t)0x2E110A62, + (q31_t)0x884BE820, (q31_t)0x2D553AFB, (q31_t)0x88054677, + (q31_t)0x2C98FBBA, (q31_t)0x87BFCCD7, (q31_t)0x2BDC4E6F, + (q31_t)0x877B7BEC, (q31_t)0x2B1F34EB, (q31_t)0x8738545E, + (q31_t)0x2A61B101, (q31_t)0x86F656D3, (q31_t)0x29A3C484, + (q31_t)0x86B583EE, (q31_t)0x28E5714A, (q31_t)0x8675DC4E, + (q31_t)0x2826B928, (q31_t)0x86376092, (q31_t)0x27679DF4, + (q31_t)0x85FA1152, (q31_t)0x26A82185, (q31_t)0x85BDEF27, + (q31_t)0x25E845B5, (q31_t)0x8582FAA4, (q31_t)0x25280C5D, + (q31_t)0x8549345C, (q31_t)0x24677757, (q31_t)0x85109CDC, + (q31_t)0x23A6887E, (q31_t)0x84D934B0, (q31_t)0x22E541AE, + (q31_t)0x84A2FC62, (q31_t)0x2223A4C5, (q31_t)0x846DF476, + (q31_t)0x2161B39F, (q31_t)0x843A1D70, (q31_t)0x209F701C, + (q31_t)0x840777CF, (q31_t)0x1FDCDC1A, (q31_t)0x83D60411, + (q31_t)0x1F19F97B, (q31_t)0x83A5C2B0, (q31_t)0x1E56CA1E, + (q31_t)0x8376B422, (q31_t)0x1D934FE5, (q31_t)0x8348D8DB, + (q31_t)0x1CCF8CB3, (q31_t)0x831C314E, (q31_t)0x1C0B826A, + (q31_t)0x82F0BDE8, (q31_t)0x1B4732EF, (q31_t)0x82C67F13, + (q31_t)0x1A82A025, (q31_t)0x829D753A, (q31_t)0x19BDCBF2, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, (q31_t)0x824F0208, + (q31_t)0x183366E8, (q31_t)0x82299971, (q31_t)0x176DD9DE, + (q31_t)0x82056758, (q31_t)0x16A81305, (q31_t)0x81E26C16, + (q31_t)0x15E21444, (q31_t)0x81C0A801, (q31_t)0x151BDF85, + (q31_t)0x81A01B6C, (q31_t)0x145576B1, (q31_t)0x8180C6A9, + (q31_t)0x138EDBB0, (q31_t)0x8162AA03, (q31_t)0x12C8106E, + (q31_t)0x8145C5C6, (q31_t)0x120116D4, (q31_t)0x812A1A39, + (q31_t)0x1139F0CE, (q31_t)0x810FA7A0, (q31_t)0x1072A047, + (q31_t)0x80F66E3C, (q31_t)0x0FAB272B, (q31_t)0x80DE6E4C, + (q31_t)0x0EE38765, (q31_t)0x80C7A80A, (q31_t)0x0E1BC2E3, + (q31_t)0x80B21BAF, (q31_t)0x0D53DB92, (q31_t)0x809DC970, + (q31_t)0x0C8BD35E, (q31_t)0x808AB180, (q31_t)0x0BC3AC35, + (q31_t)0x8078D40D, (q31_t)0x0AFB6805, (q31_t)0x80683143, + (q31_t)0x0A3308BC, (q31_t)0x8058C94C, (q31_t)0x096A9049, + (q31_t)0x804A9C4D, (q31_t)0x08A2009A, (q31_t)0x803DAA69, + (q31_t)0x07D95B9E, (q31_t)0x8031F3C1, (q31_t)0x0710A344, + (q31_t)0x80277872, (q31_t)0x0647D97C, (q31_t)0x801E3894, + (q31_t)0x057F0034, (q31_t)0x80163440, (q31_t)0x04B6195D, + (q31_t)0x800F6B88, (q31_t)0x03ED26E6, (q31_t)0x8009DE7D, + (q31_t)0x03242ABF, (q31_t)0x80058D2E, (q31_t)0x025B26D7, + (q31_t)0x800277A5, (q31_t)0x01921D1F, (q31_t)0x80009DE9, + (q31_t)0x00C90F88, (q31_t)0x80000000, (q31_t)0x00000000, + (q31_t)0x80009DE9, (q31_t)0xFF36F078, (q31_t)0x800277A5, + (q31_t)0xFE6DE2E0, (q31_t)0x80058D2E, (q31_t)0xFDA4D928, + (q31_t)0x8009DE7D, (q31_t)0xFCDBD541, (q31_t)0x800F6B88, + (q31_t)0xFC12D919, (q31_t)0x80163440, (q31_t)0xFB49E6A2, + (q31_t)0x801E3894, (q31_t)0xFA80FFCB, (q31_t)0x80277872, + (q31_t)0xF9B82683, (q31_t)0x8031F3C1, (q31_t)0xF8EF5CBB, + (q31_t)0x803DAA69, (q31_t)0xF826A461, (q31_t)0x804A9C4D, + (q31_t)0xF75DFF65, (q31_t)0x8058C94C, (q31_t)0xF6956FB6, + (q31_t)0x80683143, (q31_t)0xF5CCF743, (q31_t)0x8078D40D, + (q31_t)0xF50497FA, (q31_t)0x808AB180, (q31_t)0xF43C53CA, + (q31_t)0x809DC970, (q31_t)0xF3742CA1, (q31_t)0x80B21BAF, + (q31_t)0xF2AC246D, (q31_t)0x80C7A80A, (q31_t)0xF1E43D1C, + (q31_t)0x80DE6E4C, (q31_t)0xF11C789A, (q31_t)0x80F66E3C, + (q31_t)0xF054D8D4, (q31_t)0x810FA7A0, (q31_t)0xEF8D5FB8, + (q31_t)0x812A1A39, (q31_t)0xEEC60F31, (q31_t)0x8145C5C6, + (q31_t)0xEDFEE92B, (q31_t)0x8162AA03, (q31_t)0xED37EF91, + (q31_t)0x8180C6A9, (q31_t)0xEC71244F, (q31_t)0x81A01B6C, + (q31_t)0xEBAA894E, (q31_t)0x81C0A801, (q31_t)0xEAE4207A, + (q31_t)0x81E26C16, (q31_t)0xEA1DEBBB, (q31_t)0x82056758, + (q31_t)0xE957ECFB, (q31_t)0x82299971, (q31_t)0xE8922621, + (q31_t)0x824F0208, (q31_t)0xE7CC9917, (q31_t)0x8275A0C0, + (q31_t)0xE70747C3, (q31_t)0x829D753A, (q31_t)0xE642340D, + (q31_t)0x82C67F13, (q31_t)0xE57D5FDA, (q31_t)0x82F0BDE8, + (q31_t)0xE4B8CD10, (q31_t)0x831C314E, (q31_t)0xE3F47D95, + (q31_t)0x8348D8DB, (q31_t)0xE330734C, (q31_t)0x8376B422, + (q31_t)0xE26CB01A, (q31_t)0x83A5C2B0, (q31_t)0xE1A935E1, + (q31_t)0x83D60411, (q31_t)0xE0E60684, (q31_t)0x840777CF, + (q31_t)0xE02323E5, (q31_t)0x843A1D70, (q31_t)0xDF608FE3, + (q31_t)0x846DF476, (q31_t)0xDE9E4C60, (q31_t)0x84A2FC62, + (q31_t)0xDDDC5B3A, (q31_t)0x84D934B0, (q31_t)0xDD1ABE51, + (q31_t)0x85109CDC, (q31_t)0xDC597781, (q31_t)0x8549345C, + (q31_t)0xDB9888A8, (q31_t)0x8582FAA4, (q31_t)0xDAD7F3A2, + (q31_t)0x85BDEF27, (q31_t)0xDA17BA4A, (q31_t)0x85FA1152, + (q31_t)0xD957DE7A, (q31_t)0x86376092, (q31_t)0xD898620C, + (q31_t)0x8675DC4E, (q31_t)0xD7D946D7, (q31_t)0x86B583EE, + (q31_t)0xD71A8EB5, (q31_t)0x86F656D3, (q31_t)0xD65C3B7B, + (q31_t)0x8738545E, (q31_t)0xD59E4EFE, (q31_t)0x877B7BEC, + (q31_t)0xD4E0CB14, (q31_t)0x87BFCCD7, (q31_t)0xD423B190, + (q31_t)0x88054677, (q31_t)0xD3670445, (q31_t)0x884BE820, + (q31_t)0xD2AAC504, (q31_t)0x8893B124, (q31_t)0xD1EEF59E, + (q31_t)0x88DCA0D3, (q31_t)0xD13397E1, (q31_t)0x8926B677, + (q31_t)0xD078AD9D, (q31_t)0x8971F15A, (q31_t)0xCFBE389F, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, (q31_t)0x8A0BD3F5, + (q31_t)0xCE4AB5A2, (q31_t)0x8A5A7A30, (q31_t)0xCD91AB38, + (q31_t)0x8AAA42B4, (q31_t)0xCCD91D3D, (q31_t)0x8AFB2CBA, + (q31_t)0xCC210D78, (q31_t)0x8B4D377C, (q31_t)0xCB697DB0, + (q31_t)0x8BA0622F, (q31_t)0xCAB26FA9, (q31_t)0x8BF4AC05, + (q31_t)0xC9FBE527, (q31_t)0x8C4A142F, (q31_t)0xC945DFEC, + (q31_t)0x8CA099D9, (q31_t)0xC89061BA, (q31_t)0x8CF83C30, + (q31_t)0xC7DB6C50, (q31_t)0x8D50FA59, (q31_t)0xC727016C, + (q31_t)0x8DAAD37B, (q31_t)0xC67322CD, (q31_t)0x8E05C6B7, + (q31_t)0xC5BFD22E, (q31_t)0x8E61D32D, (q31_t)0xC50D1148, + (q31_t)0x8EBEF7FB, (q31_t)0xC45AE1D7, (q31_t)0x8F1D343A, + (q31_t)0xC3A9458F, (q31_t)0x8F7C8701, (q31_t)0xC2F83E2A, + (q31_t)0x8FDCEF66, (q31_t)0xC247CD5A, (q31_t)0x903E6C7A, + (q31_t)0xC197F4D3, (q31_t)0x90A0FD4E, (q31_t)0xC0E8B648, + (q31_t)0x9104A0ED, (q31_t)0xC03A1368, (q31_t)0x91695663, + (q31_t)0xBF8C0DE2, (q31_t)0x91CF1CB6, (q31_t)0xBEDEA765, + (q31_t)0x9235F2EB, (q31_t)0xBE31E19B, (q31_t)0x929DD805, + (q31_t)0xBD85BE2F, (q31_t)0x9306CB04, (q31_t)0xBCDA3ECA, + (q31_t)0x9370CAE4, (q31_t)0xBC2F6513, (q31_t)0x93DBD69F, + (q31_t)0xBB8532AF, (q31_t)0x9447ED2F, (q31_t)0xBADBA943, + (q31_t)0x94B50D87, (q31_t)0xBA32CA70, (q31_t)0x9523369B, + (q31_t)0xB98A97D8, (q31_t)0x9592675B, (q31_t)0xB8E31319, + (q31_t)0x96029EB5, (q31_t)0xB83C3DD1, (q31_t)0x9673DB94, + (q31_t)0xB796199B, (q31_t)0x96E61CDF, (q31_t)0xB6F0A811, + (q31_t)0x9759617E, (q31_t)0xB64BEACC, (q31_t)0x97CDA855, + (q31_t)0xB5A7E362, (q31_t)0x9842F043, (q31_t)0xB5049368, + (q31_t)0x98B93828, (q31_t)0xB461FC70, (q31_t)0x99307EE0, + (q31_t)0xB3C0200C, (q31_t)0x99A8C344, (q31_t)0xB31EFFCB, + (q31_t)0x9A22042C, (q31_t)0xB27E9D3B, (q31_t)0x9A9C406D, + (q31_t)0xB1DEF9E8, (q31_t)0x9B1776D9, (q31_t)0xB140175B, + (q31_t)0x9B93A640, (q31_t)0xB0A1F71C, (q31_t)0x9C10CD70, + (q31_t)0xB0049AB2, (q31_t)0x9C8EEB33, (q31_t)0xAF6803A1, + (q31_t)0x9D0DFE53, (q31_t)0xAECC336B, (q31_t)0x9D8E0596, + (q31_t)0xAE312B91, (q31_t)0x9E0EFFC1, (q31_t)0xAD96ED91, + (q31_t)0x9E90EB94, (q31_t)0xACFD7AE8, (q31_t)0x9F13C7D0, + (q31_t)0xAC64D510, (q31_t)0x9F979331, (q31_t)0xABCCFD82, + (q31_t)0xA01C4C72, (q31_t)0xAB35F5B5, (q31_t)0xA0A1F24C, + (q31_t)0xAA9FBF1D, (q31_t)0xA1288376, (q31_t)0xAA0A5B2D, + (q31_t)0xA1AFFEA2, (q31_t)0xA975CB56, (q31_t)0xA2386283, + (q31_t)0xA8E21106, (q31_t)0xA2C1ADC9, (q31_t)0xA84F2DA9, + (q31_t)0xA34BDF20, (q31_t)0xA7BD22AB, (q31_t)0xA3D6F533, + (q31_t)0xA72BF173, (q31_t)0xA462EEAC, (q31_t)0xA69B9B68, + (q31_t)0xA4EFCA31, (q31_t)0xA60C21ED, (q31_t)0xA57D8666, + (q31_t)0xA57D8666, (q31_t)0xA60C21ED, (q31_t)0xA4EFCA31, + (q31_t)0xA69B9B68, (q31_t)0xA462EEAC, (q31_t)0xA72BF173, + (q31_t)0xA3D6F533, (q31_t)0xA7BD22AB, (q31_t)0xA34BDF20, + (q31_t)0xA84F2DA9, (q31_t)0xA2C1ADC9, (q31_t)0xA8E21106, + (q31_t)0xA2386283, (q31_t)0xA975CB56, (q31_t)0xA1AFFEA2, + (q31_t)0xAA0A5B2D, (q31_t)0xA1288376, (q31_t)0xAA9FBF1D, + (q31_t)0xA0A1F24C, (q31_t)0xAB35F5B5, (q31_t)0xA01C4C72, + (q31_t)0xABCCFD82, (q31_t)0x9F979331, (q31_t)0xAC64D510, + (q31_t)0x9F13C7D0, (q31_t)0xACFD7AE8, (q31_t)0x9E90EB94, + (q31_t)0xAD96ED91, (q31_t)0x9E0EFFC1, (q31_t)0xAE312B91, + (q31_t)0x9D8E0596, (q31_t)0xAECC336B, (q31_t)0x9D0DFE53, + (q31_t)0xAF6803A1, (q31_t)0x9C8EEB33, (q31_t)0xB0049AB2, + (q31_t)0x9C10CD70, (q31_t)0xB0A1F71C, (q31_t)0x9B93A640, + (q31_t)0xB140175B, (q31_t)0x9B1776D9, (q31_t)0xB1DEF9E8, + (q31_t)0x9A9C406D, (q31_t)0xB27E9D3B, (q31_t)0x9A22042C, + (q31_t)0xB31EFFCB, (q31_t)0x99A8C344, (q31_t)0xB3C0200C, + (q31_t)0x99307EE0, (q31_t)0xB461FC70, (q31_t)0x98B93828, + (q31_t)0xB5049368, (q31_t)0x9842F043, (q31_t)0xB5A7E362, + (q31_t)0x97CDA855, (q31_t)0xB64BEACC, (q31_t)0x9759617E, + (q31_t)0xB6F0A811, (q31_t)0x96E61CDF, (q31_t)0xB796199B, + (q31_t)0x9673DB94, (q31_t)0xB83C3DD1, (q31_t)0x96029EB5, + (q31_t)0xB8E31319, (q31_t)0x9592675B, (q31_t)0xB98A97D8, + (q31_t)0x9523369B, (q31_t)0xBA32CA70, (q31_t)0x94B50D87, + (q31_t)0xBADBA943, (q31_t)0x9447ED2F, (q31_t)0xBB8532AF, + (q31_t)0x93DBD69F, (q31_t)0xBC2F6513, (q31_t)0x9370CAE4, + (q31_t)0xBCDA3ECA, (q31_t)0x9306CB04, (q31_t)0xBD85BE2F, + (q31_t)0x929DD805, (q31_t)0xBE31E19B, (q31_t)0x9235F2EB, + (q31_t)0xBEDEA765, (q31_t)0x91CF1CB6, (q31_t)0xBF8C0DE2, + (q31_t)0x91695663, (q31_t)0xC03A1368, (q31_t)0x9104A0ED, + (q31_t)0xC0E8B648, (q31_t)0x90A0FD4E, (q31_t)0xC197F4D3, + (q31_t)0x903E6C7A, (q31_t)0xC247CD5A, (q31_t)0x8FDCEF66, + (q31_t)0xC2F83E2A, (q31_t)0x8F7C8701, (q31_t)0xC3A9458F, + (q31_t)0x8F1D343A, (q31_t)0xC45AE1D7, (q31_t)0x8EBEF7FB, + (q31_t)0xC50D1148, (q31_t)0x8E61D32D, (q31_t)0xC5BFD22E, + (q31_t)0x8E05C6B7, (q31_t)0xC67322CD, (q31_t)0x8DAAD37B, + (q31_t)0xC727016C, (q31_t)0x8D50FA59, (q31_t)0xC7DB6C50, + (q31_t)0x8CF83C30, (q31_t)0xC89061BA, (q31_t)0x8CA099D9, + (q31_t)0xC945DFEC, (q31_t)0x8C4A142F, (q31_t)0xC9FBE527, + (q31_t)0x8BF4AC05, (q31_t)0xCAB26FA9, (q31_t)0x8BA0622F, + (q31_t)0xCB697DB0, (q31_t)0x8B4D377C, (q31_t)0xCC210D78, + (q31_t)0x8AFB2CBA, (q31_t)0xCCD91D3D, (q31_t)0x8AAA42B4, + (q31_t)0xCD91AB38, (q31_t)0x8A5A7A30, (q31_t)0xCE4AB5A2, + (q31_t)0x8A0BD3F5, (q31_t)0xCF043AB2, (q31_t)0x89BE50C3, + (q31_t)0xCFBE389F, (q31_t)0x8971F15A, (q31_t)0xD078AD9D, + (q31_t)0x8926B677, (q31_t)0xD13397E1, (q31_t)0x88DCA0D3, + (q31_t)0xD1EEF59E, (q31_t)0x8893B124, (q31_t)0xD2AAC504, + (q31_t)0x884BE820, (q31_t)0xD3670445, (q31_t)0x88054677, + (q31_t)0xD423B190, (q31_t)0x87BFCCD7, (q31_t)0xD4E0CB14, + (q31_t)0x877B7BEC, (q31_t)0xD59E4EFE, (q31_t)0x8738545E, + (q31_t)0xD65C3B7B, (q31_t)0x86F656D3, (q31_t)0xD71A8EB5, + (q31_t)0x86B583EE, (q31_t)0xD7D946D7, (q31_t)0x8675DC4E, + (q31_t)0xD898620C, (q31_t)0x86376092, (q31_t)0xD957DE7A, + (q31_t)0x85FA1152, (q31_t)0xDA17BA4A, (q31_t)0x85BDEF27, + (q31_t)0xDAD7F3A2, (q31_t)0x8582FAA4, (q31_t)0xDB9888A8, + (q31_t)0x8549345C, (q31_t)0xDC597781, (q31_t)0x85109CDC, + (q31_t)0xDD1ABE51, (q31_t)0x84D934B0, (q31_t)0xDDDC5B3A, + (q31_t)0x84A2FC62, (q31_t)0xDE9E4C60, (q31_t)0x846DF476, + (q31_t)0xDF608FE3, (q31_t)0x843A1D70, (q31_t)0xE02323E5, + (q31_t)0x840777CF, (q31_t)0xE0E60684, (q31_t)0x83D60411, + (q31_t)0xE1A935E1, (q31_t)0x83A5C2B0, (q31_t)0xE26CB01A, + (q31_t)0x8376B422, (q31_t)0xE330734C, (q31_t)0x8348D8DB, + (q31_t)0xE3F47D95, (q31_t)0x831C314E, (q31_t)0xE4B8CD10, + (q31_t)0x82F0BDE8, (q31_t)0xE57D5FDA, (q31_t)0x82C67F13, + (q31_t)0xE642340D, (q31_t)0x829D753A, (q31_t)0xE70747C3, + (q31_t)0x8275A0C0, (q31_t)0xE7CC9917, (q31_t)0x824F0208, + (q31_t)0xE8922621, (q31_t)0x82299971, (q31_t)0xE957ECFB, + (q31_t)0x82056758, (q31_t)0xEA1DEBBB, (q31_t)0x81E26C16, + (q31_t)0xEAE4207A, (q31_t)0x81C0A801, (q31_t)0xEBAA894E, + (q31_t)0x81A01B6C, (q31_t)0xEC71244F, (q31_t)0x8180C6A9, + (q31_t)0xED37EF91, (q31_t)0x8162AA03, (q31_t)0xEDFEE92B, + (q31_t)0x8145C5C6, (q31_t)0xEEC60F31, (q31_t)0x812A1A39, + (q31_t)0xEF8D5FB8, (q31_t)0x810FA7A0, (q31_t)0xF054D8D4, + (q31_t)0x80F66E3C, (q31_t)0xF11C789A, (q31_t)0x80DE6E4C, + (q31_t)0xF1E43D1C, (q31_t)0x80C7A80A, (q31_t)0xF2AC246D, + (q31_t)0x80B21BAF, (q31_t)0xF3742CA1, (q31_t)0x809DC970, + (q31_t)0xF43C53CA, (q31_t)0x808AB180, (q31_t)0xF50497FA, + (q31_t)0x8078D40D, (q31_t)0xF5CCF743, (q31_t)0x80683143, + (q31_t)0xF6956FB6, (q31_t)0x8058C94C, (q31_t)0xF75DFF65, + (q31_t)0x804A9C4D, (q31_t)0xF826A461, (q31_t)0x803DAA69, + (q31_t)0xF8EF5CBB, (q31_t)0x8031F3C1, (q31_t)0xF9B82683, + (q31_t)0x80277872, (q31_t)0xFA80FFCB, (q31_t)0x801E3894, + (q31_t)0xFB49E6A2, (q31_t)0x80163440, (q31_t)0xFC12D919, + (q31_t)0x800F6B88, (q31_t)0xFCDBD541, (q31_t)0x8009DE7D, + (q31_t)0xFDA4D928, (q31_t)0x80058D2E, (q31_t)0xFE6DE2E0, + (q31_t)0x800277A5, (q31_t)0xFF36F078, (q31_t)0x80009DE9 +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 2048 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_2048_q31[3072] = { + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, (q31_t)0x7FFFD885, + (q31_t)0x006487E3, (q31_t)0x7FFF6216, (q31_t)0x00C90F88, + (q31_t)0x7FFE9CB2, (q31_t)0x012D96B0, (q31_t)0x7FFD885A, + (q31_t)0x01921D1F, (q31_t)0x7FFC250F, (q31_t)0x01F6A296, + (q31_t)0x7FFA72D1, (q31_t)0x025B26D7, (q31_t)0x7FF871A1, + (q31_t)0x02BFA9A4, (q31_t)0x7FF62182, (q31_t)0x03242ABF, + (q31_t)0x7FF38273, (q31_t)0x0388A9E9, (q31_t)0x7FF09477, + (q31_t)0x03ED26E6, (q31_t)0x7FED5790, (q31_t)0x0451A176, + (q31_t)0x7FE9CBC0, (q31_t)0x04B6195D, (q31_t)0x7FE5F108, + (q31_t)0x051A8E5C, (q31_t)0x7FE1C76B, (q31_t)0x057F0034, + (q31_t)0x7FDD4EEC, (q31_t)0x05E36EA9, (q31_t)0x7FD8878D, + (q31_t)0x0647D97C, (q31_t)0x7FD37152, (q31_t)0x06AC406F, + (q31_t)0x7FCE0C3E, (q31_t)0x0710A344, (q31_t)0x7FC85853, + (q31_t)0x077501BE, (q31_t)0x7FC25596, (q31_t)0x07D95B9E, + (q31_t)0x7FBC040A, (q31_t)0x083DB0A7, (q31_t)0x7FB563B2, + (q31_t)0x08A2009A, (q31_t)0x7FAE7494, (q31_t)0x09064B3A, + (q31_t)0x7FA736B4, (q31_t)0x096A9049, (q31_t)0x7F9FAA15, + (q31_t)0x09CECF89, (q31_t)0x7F97CEBC, (q31_t)0x0A3308BC, + (q31_t)0x7F8FA4AF, (q31_t)0x0A973BA5, (q31_t)0x7F872BF3, + (q31_t)0x0AFB6805, (q31_t)0x7F7E648B, (q31_t)0x0B5F8D9F, + (q31_t)0x7F754E7F, (q31_t)0x0BC3AC35, (q31_t)0x7F6BE9D4, + (q31_t)0x0C27C389, (q31_t)0x7F62368F, (q31_t)0x0C8BD35E, + (q31_t)0x7F5834B6, (q31_t)0x0CEFDB75, (q31_t)0x7F4DE450, + (q31_t)0x0D53DB92, (q31_t)0x7F434563, (q31_t)0x0DB7D376, + (q31_t)0x7F3857F5, (q31_t)0x0E1BC2E3, (q31_t)0x7F2D1C0E, + (q31_t)0x0E7FA99D, (q31_t)0x7F2191B4, (q31_t)0x0EE38765, + (q31_t)0x7F15B8EE, (q31_t)0x0F475BFE, (q31_t)0x7F0991C3, + (q31_t)0x0FAB272B, (q31_t)0x7EFD1C3C, (q31_t)0x100EE8AD, + (q31_t)0x7EF0585F, (q31_t)0x1072A047, (q31_t)0x7EE34635, + (q31_t)0x10D64DBC, (q31_t)0x7ED5E5C6, (q31_t)0x1139F0CE, + (q31_t)0x7EC8371A, (q31_t)0x119D8940, (q31_t)0x7EBA3A39, + (q31_t)0x120116D4, (q31_t)0x7EABEF2C, (q31_t)0x1264994E, + (q31_t)0x7E9D55FC, (q31_t)0x12C8106E, (q31_t)0x7E8E6EB1, + (q31_t)0x132B7BF9, (q31_t)0x7E7F3956, (q31_t)0x138EDBB0, + (q31_t)0x7E6FB5F3, (q31_t)0x13F22F57, (q31_t)0x7E5FE493, + (q31_t)0x145576B1, (q31_t)0x7E4FC53E, (q31_t)0x14B8B17F, + (q31_t)0x7E3F57FE, (q31_t)0x151BDF85, (q31_t)0x7E2E9CDF, + (q31_t)0x157F0086, (q31_t)0x7E1D93E9, (q31_t)0x15E21444, + (q31_t)0x7E0C3D29, (q31_t)0x16451A83, (q31_t)0x7DFA98A7, + (q31_t)0x16A81305, (q31_t)0x7DE8A670, (q31_t)0x170AFD8D, + (q31_t)0x7DD6668E, (q31_t)0x176DD9DE, (q31_t)0x7DC3D90D, + (q31_t)0x17D0A7BB, (q31_t)0x7DB0FDF7, (q31_t)0x183366E8, + (q31_t)0x7D9DD55A, (q31_t)0x18961727, (q31_t)0x7D8A5F3F, + (q31_t)0x18F8B83C, (q31_t)0x7D769BB5, (q31_t)0x195B49E9, + (q31_t)0x7D628AC5, (q31_t)0x19BDCBF2, (q31_t)0x7D4E2C7E, + (q31_t)0x1A203E1B, (q31_t)0x7D3980EC, (q31_t)0x1A82A025, + (q31_t)0x7D24881A, (q31_t)0x1AE4F1D6, (q31_t)0x7D0F4218, + (q31_t)0x1B4732EF, (q31_t)0x7CF9AEF0, (q31_t)0x1BA96334, + (q31_t)0x7CE3CEB1, (q31_t)0x1C0B826A, (q31_t)0x7CCDA168, + (q31_t)0x1C6D9053, (q31_t)0x7CB72724, (q31_t)0x1CCF8CB3, + (q31_t)0x7CA05FF1, (q31_t)0x1D31774D, (q31_t)0x7C894BDD, + (q31_t)0x1D934FE5, (q31_t)0x7C71EAF8, (q31_t)0x1DF5163F, + (q31_t)0x7C5A3D4F, (q31_t)0x1E56CA1E, (q31_t)0x7C4242F2, + (q31_t)0x1EB86B46, (q31_t)0x7C29FBEE, (q31_t)0x1F19F97B, + (q31_t)0x7C116853, (q31_t)0x1F7B7480, (q31_t)0x7BF88830, + (q31_t)0x1FDCDC1A, (q31_t)0x7BDF5B94, (q31_t)0x203E300D, + (q31_t)0x7BC5E28F, (q31_t)0x209F701C, (q31_t)0x7BAC1D31, + (q31_t)0x21009C0B, (q31_t)0x7B920B89, (q31_t)0x2161B39F, + (q31_t)0x7B77ADA8, (q31_t)0x21C2B69C, (q31_t)0x7B5D039D, + (q31_t)0x2223A4C5, (q31_t)0x7B420D7A, (q31_t)0x22847DDF, + (q31_t)0x7B26CB4F, (q31_t)0x22E541AE, (q31_t)0x7B0B3D2C, + (q31_t)0x2345EFF7, (q31_t)0x7AEF6323, (q31_t)0x23A6887E, + (q31_t)0x7AD33D45, (q31_t)0x24070B07, (q31_t)0x7AB6CBA3, + (q31_t)0x24677757, (q31_t)0x7A9A0E4F, (q31_t)0x24C7CD32, + (q31_t)0x7A7D055B, (q31_t)0x25280C5D, (q31_t)0x7A5FB0D8, + (q31_t)0x2588349D, (q31_t)0x7A4210D8, (q31_t)0x25E845B5, + (q31_t)0x7A24256E, (q31_t)0x26483F6C, (q31_t)0x7A05EEAD, + (q31_t)0x26A82185, (q31_t)0x79E76CA6, (q31_t)0x2707EBC6, + (q31_t)0x79C89F6D, (q31_t)0x27679DF4, (q31_t)0x79A98715, + (q31_t)0x27C737D2, (q31_t)0x798A23B1, (q31_t)0x2826B928, + (q31_t)0x796A7554, (q31_t)0x288621B9, (q31_t)0x794A7C11, + (q31_t)0x28E5714A, (q31_t)0x792A37FE, (q31_t)0x2944A7A2, + (q31_t)0x7909A92C, (q31_t)0x29A3C484, (q31_t)0x78E8CFB1, + (q31_t)0x2A02C7B8, (q31_t)0x78C7ABA1, (q31_t)0x2A61B101, + (q31_t)0x78A63D10, (q31_t)0x2AC08025, (q31_t)0x78848413, + (q31_t)0x2B1F34EB, (q31_t)0x786280BF, (q31_t)0x2B7DCF17, + (q31_t)0x78403328, (q31_t)0x2BDC4E6F, (q31_t)0x781D9B64, + (q31_t)0x2C3AB2B9, (q31_t)0x77FAB988, (q31_t)0x2C98FBBA, + (q31_t)0x77D78DAA, (q31_t)0x2CF72939, (q31_t)0x77B417DF, + (q31_t)0x2D553AFB, (q31_t)0x7790583D, (q31_t)0x2DB330C7, + (q31_t)0x776C4EDB, (q31_t)0x2E110A62, (q31_t)0x7747FBCE, + (q31_t)0x2E6EC792, (q31_t)0x77235F2D, (q31_t)0x2ECC681E, + (q31_t)0x76FE790E, (q31_t)0x2F29EBCC, (q31_t)0x76D94988, + (q31_t)0x2F875262, (q31_t)0x76B3D0B3, (q31_t)0x2FE49BA6, + (q31_t)0x768E0EA5, (q31_t)0x3041C760, (q31_t)0x76680376, + (q31_t)0x309ED555, (q31_t)0x7641AF3C, (q31_t)0x30FBC54D, + (q31_t)0x761B1211, (q31_t)0x3158970D, (q31_t)0x75F42C0A, + (q31_t)0x31B54A5D, (q31_t)0x75CCFD42, (q31_t)0x3211DF03, + (q31_t)0x75A585CF, (q31_t)0x326E54C7, (q31_t)0x757DC5CA, + (q31_t)0x32CAAB6F, (q31_t)0x7555BD4B, (q31_t)0x3326E2C2, + (q31_t)0x752D6C6C, (q31_t)0x3382FA88, (q31_t)0x7504D345, + (q31_t)0x33DEF287, (q31_t)0x74DBF1EF, (q31_t)0x343ACA87, + (q31_t)0x74B2C883, (q31_t)0x3496824F, (q31_t)0x7489571B, + (q31_t)0x34F219A7, (q31_t)0x745F9DD1, (q31_t)0x354D9056, + (q31_t)0x74359CBD, (q31_t)0x35A8E624, (q31_t)0x740B53FA, + (q31_t)0x36041AD9, (q31_t)0x73E0C3A3, (q31_t)0x365F2E3B, + (q31_t)0x73B5EBD0, (q31_t)0x36BA2013, (q31_t)0x738ACC9E, + (q31_t)0x3714F02A, (q31_t)0x735F6626, (q31_t)0x376F9E46, + (q31_t)0x7333B883, (q31_t)0x37CA2A30, (q31_t)0x7307C3D0, + (q31_t)0x382493B0, (q31_t)0x72DB8828, (q31_t)0x387EDA8E, + (q31_t)0x72AF05A6, (q31_t)0x38D8FE93, (q31_t)0x72823C66, + (q31_t)0x3932FF87, (q31_t)0x72552C84, (q31_t)0x398CDD32, + (q31_t)0x7227D61C, (q31_t)0x39E6975D, (q31_t)0x71FA3948, + (q31_t)0x3A402DD1, (q31_t)0x71CC5626, (q31_t)0x3A99A057, + (q31_t)0x719E2CD2, (q31_t)0x3AF2EEB7, (q31_t)0x716FBD68, + (q31_t)0x3B4C18BA, (q31_t)0x71410804, (q31_t)0x3BA51E29, + (q31_t)0x71120CC5, (q31_t)0x3BFDFECD, (q31_t)0x70E2CBC6, + (q31_t)0x3C56BA70, (q31_t)0x70B34524, (q31_t)0x3CAF50DA, + (q31_t)0x708378FE, (q31_t)0x3D07C1D5, (q31_t)0x70536771, + (q31_t)0x3D600D2B, (q31_t)0x70231099, (q31_t)0x3DB832A5, + (q31_t)0x6FF27496, (q31_t)0x3E10320D, (q31_t)0x6FC19385, + (q31_t)0x3E680B2C, (q31_t)0x6F906D84, (q31_t)0x3EBFBDCC, + (q31_t)0x6F5F02B1, (q31_t)0x3F1749B7, (q31_t)0x6F2D532C, + (q31_t)0x3F6EAEB8, (q31_t)0x6EFB5F12, (q31_t)0x3FC5EC97, + (q31_t)0x6EC92682, (q31_t)0x401D0320, (q31_t)0x6E96A99C, + (q31_t)0x4073F21D, (q31_t)0x6E63E87F, (q31_t)0x40CAB957, + (q31_t)0x6E30E349, (q31_t)0x4121589A, (q31_t)0x6DFD9A1B, + (q31_t)0x4177CFB0, (q31_t)0x6DCA0D14, (q31_t)0x41CE1E64, + (q31_t)0x6D963C54, (q31_t)0x42244480, (q31_t)0x6D6227FA, + (q31_t)0x427A41D0, (q31_t)0x6D2DD027, (q31_t)0x42D0161E, + (q31_t)0x6CF934FB, (q31_t)0x4325C135, (q31_t)0x6CC45697, + (q31_t)0x437B42E1, (q31_t)0x6C8F351C, (q31_t)0x43D09AEC, + (q31_t)0x6C59D0A9, (q31_t)0x4425C923, (q31_t)0x6C242960, + (q31_t)0x447ACD50, (q31_t)0x6BEE3F62, (q31_t)0x44CFA73F, + (q31_t)0x6BB812D0, (q31_t)0x452456BC, (q31_t)0x6B81A3CD, + (q31_t)0x4578DB93, (q31_t)0x6B4AF278, (q31_t)0x45CD358F, + (q31_t)0x6B13FEF5, (q31_t)0x4621647C, (q31_t)0x6ADCC964, + (q31_t)0x46756827, (q31_t)0x6AA551E8, (q31_t)0x46C9405C, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, (q31_t)0x6A359DB9, + (q31_t)0x47706D93, (q31_t)0x69FD614A, (q31_t)0x47C3C22E, + (q31_t)0x69C4E37A, (q31_t)0x4816EA85, (q31_t)0x698C246C, + (q31_t)0x4869E664, (q31_t)0x69532442, (q31_t)0x48BCB598, + (q31_t)0x6919E320, (q31_t)0x490F57EE, (q31_t)0x68E06129, + (q31_t)0x4961CD32, (q31_t)0x68A69E81, (q31_t)0x49B41533, + (q31_t)0x686C9B4B, (q31_t)0x4A062FBD, (q31_t)0x683257AA, + (q31_t)0x4A581C9D, (q31_t)0x67F7D3C4, (q31_t)0x4AA9DBA1, + (q31_t)0x67BD0FBC, (q31_t)0x4AFB6C97, (q31_t)0x67820BB6, + (q31_t)0x4B4CCF4D, (q31_t)0x6746C7D7, (q31_t)0x4B9E038F, + (q31_t)0x670B4443, (q31_t)0x4BEF092D, (q31_t)0x66CF811F, + (q31_t)0x4C3FDFF3, (q31_t)0x66937E90, (q31_t)0x4C9087B1, + (q31_t)0x66573CBB, (q31_t)0x4CE10034, (q31_t)0x661ABBC5, + (q31_t)0x4D31494B, (q31_t)0x65DDFBD3, (q31_t)0x4D8162C4, + (q31_t)0x65A0FD0B, (q31_t)0x4DD14C6E, (q31_t)0x6563BF92, + (q31_t)0x4E210617, (q31_t)0x6526438E, (q31_t)0x4E708F8F, + (q31_t)0x64E88926, (q31_t)0x4EBFE8A4, (q31_t)0x64AA907F, + (q31_t)0x4F0F1126, (q31_t)0x646C59BF, (q31_t)0x4F5E08E3, + (q31_t)0x642DE50D, (q31_t)0x4FACCFAB, (q31_t)0x63EF328F, + (q31_t)0x4FFB654D, (q31_t)0x63B0426D, (q31_t)0x5049C999, + (q31_t)0x637114CC, (q31_t)0x5097FC5E, (q31_t)0x6331A9D4, + (q31_t)0x50E5FD6C, (q31_t)0x62F201AC, (q31_t)0x5133CC94, + (q31_t)0x62B21C7B, (q31_t)0x518169A4, (q31_t)0x6271FA69, + (q31_t)0x51CED46E, (q31_t)0x62319B9D, (q31_t)0x521C0CC1, + (q31_t)0x61F1003E, (q31_t)0x5269126E, (q31_t)0x61B02876, + (q31_t)0x52B5E545, (q31_t)0x616F146B, (q31_t)0x53028517, + (q31_t)0x612DC446, (q31_t)0x534EF1B5, (q31_t)0x60EC3830, + (q31_t)0x539B2AEF, (q31_t)0x60AA704F, (q31_t)0x53E73097, + (q31_t)0x60686CCE, (q31_t)0x5433027D, (q31_t)0x60262DD5, + (q31_t)0x547EA073, (q31_t)0x5FE3B38D, (q31_t)0x54CA0A4A, + (q31_t)0x5FA0FE1E, (q31_t)0x55153FD4, (q31_t)0x5F5E0DB3, + (q31_t)0x556040E2, (q31_t)0x5F1AE273, (q31_t)0x55AB0D46, + (q31_t)0x5ED77C89, (q31_t)0x55F5A4D2, (q31_t)0x5E93DC1F, + (q31_t)0x56400757, (q31_t)0x5E50015D, (q31_t)0x568A34A9, + (q31_t)0x5E0BEC6E, (q31_t)0x56D42C99, (q31_t)0x5DC79D7C, + (q31_t)0x571DEEF9, (q31_t)0x5D8314B0, (q31_t)0x57677B9D, + (q31_t)0x5D3E5236, (q31_t)0x57B0D256, (q31_t)0x5CF95638, + (q31_t)0x57F9F2F7, (q31_t)0x5CB420DF, (q31_t)0x5842DD54, + (q31_t)0x5C6EB258, (q31_t)0x588B913F, (q31_t)0x5C290ACC, + (q31_t)0x58D40E8C, (q31_t)0x5BE32A67, (q31_t)0x591C550E, + (q31_t)0x5B9D1153, (q31_t)0x59646497, (q31_t)0x5B56BFBD, + (q31_t)0x59AC3CFD, (q31_t)0x5B1035CF, (q31_t)0x59F3DE12, + (q31_t)0x5AC973B4, (q31_t)0x5A3B47AA, (q31_t)0x5A82799A, + (q31_t)0x5A82799A, (q31_t)0x5A3B47AA, (q31_t)0x5AC973B4, + (q31_t)0x59F3DE12, (q31_t)0x5B1035CF, (q31_t)0x59AC3CFD, + (q31_t)0x5B56BFBD, (q31_t)0x59646497, (q31_t)0x5B9D1153, + (q31_t)0x591C550E, (q31_t)0x5BE32A67, (q31_t)0x58D40E8C, + (q31_t)0x5C290ACC, (q31_t)0x588B913F, (q31_t)0x5C6EB258, + (q31_t)0x5842DD54, (q31_t)0x5CB420DF, (q31_t)0x57F9F2F7, + (q31_t)0x5CF95638, (q31_t)0x57B0D256, (q31_t)0x5D3E5236, + (q31_t)0x57677B9D, (q31_t)0x5D8314B0, (q31_t)0x571DEEF9, + (q31_t)0x5DC79D7C, (q31_t)0x56D42C99, (q31_t)0x5E0BEC6E, + (q31_t)0x568A34A9, (q31_t)0x5E50015D, (q31_t)0x56400757, + (q31_t)0x5E93DC1F, (q31_t)0x55F5A4D2, (q31_t)0x5ED77C89, + (q31_t)0x55AB0D46, (q31_t)0x5F1AE273, (q31_t)0x556040E2, + (q31_t)0x5F5E0DB3, (q31_t)0x55153FD4, (q31_t)0x5FA0FE1E, + (q31_t)0x54CA0A4A, (q31_t)0x5FE3B38D, (q31_t)0x547EA073, + (q31_t)0x60262DD5, (q31_t)0x5433027D, (q31_t)0x60686CCE, + (q31_t)0x53E73097, (q31_t)0x60AA704F, (q31_t)0x539B2AEF, + (q31_t)0x60EC3830, (q31_t)0x534EF1B5, (q31_t)0x612DC446, + (q31_t)0x53028517, (q31_t)0x616F146B, (q31_t)0x52B5E545, + (q31_t)0x61B02876, (q31_t)0x5269126E, (q31_t)0x61F1003E, + (q31_t)0x521C0CC1, (q31_t)0x62319B9D, (q31_t)0x51CED46E, + (q31_t)0x6271FA69, (q31_t)0x518169A4, (q31_t)0x62B21C7B, + (q31_t)0x5133CC94, (q31_t)0x62F201AC, (q31_t)0x50E5FD6C, + (q31_t)0x6331A9D4, (q31_t)0x5097FC5E, (q31_t)0x637114CC, + (q31_t)0x5049C999, (q31_t)0x63B0426D, (q31_t)0x4FFB654D, + (q31_t)0x63EF328F, (q31_t)0x4FACCFAB, (q31_t)0x642DE50D, + (q31_t)0x4F5E08E3, (q31_t)0x646C59BF, (q31_t)0x4F0F1126, + (q31_t)0x64AA907F, (q31_t)0x4EBFE8A4, (q31_t)0x64E88926, + (q31_t)0x4E708F8F, (q31_t)0x6526438E, (q31_t)0x4E210617, + (q31_t)0x6563BF92, (q31_t)0x4DD14C6E, (q31_t)0x65A0FD0B, + (q31_t)0x4D8162C4, (q31_t)0x65DDFBD3, (q31_t)0x4D31494B, + (q31_t)0x661ABBC5, (q31_t)0x4CE10034, (q31_t)0x66573CBB, + (q31_t)0x4C9087B1, (q31_t)0x66937E90, (q31_t)0x4C3FDFF3, + (q31_t)0x66CF811F, (q31_t)0x4BEF092D, (q31_t)0x670B4443, + (q31_t)0x4B9E038F, (q31_t)0x6746C7D7, (q31_t)0x4B4CCF4D, + (q31_t)0x67820BB6, (q31_t)0x4AFB6C97, (q31_t)0x67BD0FBC, + (q31_t)0x4AA9DBA1, (q31_t)0x67F7D3C4, (q31_t)0x4A581C9D, + (q31_t)0x683257AA, (q31_t)0x4A062FBD, (q31_t)0x686C9B4B, + (q31_t)0x49B41533, (q31_t)0x68A69E81, (q31_t)0x4961CD32, + (q31_t)0x68E06129, (q31_t)0x490F57EE, (q31_t)0x6919E320, + (q31_t)0x48BCB598, (q31_t)0x69532442, (q31_t)0x4869E664, + (q31_t)0x698C246C, (q31_t)0x4816EA85, (q31_t)0x69C4E37A, + (q31_t)0x47C3C22E, (q31_t)0x69FD614A, (q31_t)0x47706D93, + (q31_t)0x6A359DB9, (q31_t)0x471CECE6, (q31_t)0x6A6D98A4, + (q31_t)0x46C9405C, (q31_t)0x6AA551E8, (q31_t)0x46756827, + (q31_t)0x6ADCC964, (q31_t)0x4621647C, (q31_t)0x6B13FEF5, + (q31_t)0x45CD358F, (q31_t)0x6B4AF278, (q31_t)0x4578DB93, + (q31_t)0x6B81A3CD, (q31_t)0x452456BC, (q31_t)0x6BB812D0, + (q31_t)0x44CFA73F, (q31_t)0x6BEE3F62, (q31_t)0x447ACD50, + (q31_t)0x6C242960, (q31_t)0x4425C923, (q31_t)0x6C59D0A9, + (q31_t)0x43D09AEC, (q31_t)0x6C8F351C, (q31_t)0x437B42E1, + (q31_t)0x6CC45697, (q31_t)0x4325C135, (q31_t)0x6CF934FB, + (q31_t)0x42D0161E, (q31_t)0x6D2DD027, (q31_t)0x427A41D0, + (q31_t)0x6D6227FA, (q31_t)0x42244480, (q31_t)0x6D963C54, + (q31_t)0x41CE1E64, (q31_t)0x6DCA0D14, (q31_t)0x4177CFB0, + (q31_t)0x6DFD9A1B, (q31_t)0x4121589A, (q31_t)0x6E30E349, + (q31_t)0x40CAB957, (q31_t)0x6E63E87F, (q31_t)0x4073F21D, + (q31_t)0x6E96A99C, (q31_t)0x401D0320, (q31_t)0x6EC92682, + (q31_t)0x3FC5EC97, (q31_t)0x6EFB5F12, (q31_t)0x3F6EAEB8, + (q31_t)0x6F2D532C, (q31_t)0x3F1749B7, (q31_t)0x6F5F02B1, + (q31_t)0x3EBFBDCC, (q31_t)0x6F906D84, (q31_t)0x3E680B2C, + (q31_t)0x6FC19385, (q31_t)0x3E10320D, (q31_t)0x6FF27496, + (q31_t)0x3DB832A5, (q31_t)0x70231099, (q31_t)0x3D600D2B, + (q31_t)0x70536771, (q31_t)0x3D07C1D5, (q31_t)0x708378FE, + (q31_t)0x3CAF50DA, (q31_t)0x70B34524, (q31_t)0x3C56BA70, + (q31_t)0x70E2CBC6, (q31_t)0x3BFDFECD, (q31_t)0x71120CC5, + (q31_t)0x3BA51E29, (q31_t)0x71410804, (q31_t)0x3B4C18BA, + (q31_t)0x716FBD68, (q31_t)0x3AF2EEB7, (q31_t)0x719E2CD2, + (q31_t)0x3A99A057, (q31_t)0x71CC5626, (q31_t)0x3A402DD1, + (q31_t)0x71FA3948, (q31_t)0x39E6975D, (q31_t)0x7227D61C, + (q31_t)0x398CDD32, (q31_t)0x72552C84, (q31_t)0x3932FF87, + (q31_t)0x72823C66, (q31_t)0x38D8FE93, (q31_t)0x72AF05A6, + (q31_t)0x387EDA8E, (q31_t)0x72DB8828, (q31_t)0x382493B0, + (q31_t)0x7307C3D0, (q31_t)0x37CA2A30, (q31_t)0x7333B883, + (q31_t)0x376F9E46, (q31_t)0x735F6626, (q31_t)0x3714F02A, + (q31_t)0x738ACC9E, (q31_t)0x36BA2013, (q31_t)0x73B5EBD0, + (q31_t)0x365F2E3B, (q31_t)0x73E0C3A3, (q31_t)0x36041AD9, + (q31_t)0x740B53FA, (q31_t)0x35A8E624, (q31_t)0x74359CBD, + (q31_t)0x354D9056, (q31_t)0x745F9DD1, (q31_t)0x34F219A7, + (q31_t)0x7489571B, (q31_t)0x3496824F, (q31_t)0x74B2C883, + (q31_t)0x343ACA87, (q31_t)0x74DBF1EF, (q31_t)0x33DEF287, + (q31_t)0x7504D345, (q31_t)0x3382FA88, (q31_t)0x752D6C6C, + (q31_t)0x3326E2C2, (q31_t)0x7555BD4B, (q31_t)0x32CAAB6F, + (q31_t)0x757DC5CA, (q31_t)0x326E54C7, (q31_t)0x75A585CF, + (q31_t)0x3211DF03, (q31_t)0x75CCFD42, (q31_t)0x31B54A5D, + (q31_t)0x75F42C0A, (q31_t)0x3158970D, (q31_t)0x761B1211, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, (q31_t)0x309ED555, + (q31_t)0x76680376, (q31_t)0x3041C760, (q31_t)0x768E0EA5, + (q31_t)0x2FE49BA6, (q31_t)0x76B3D0B3, (q31_t)0x2F875262, + (q31_t)0x76D94988, (q31_t)0x2F29EBCC, (q31_t)0x76FE790E, + (q31_t)0x2ECC681E, (q31_t)0x77235F2D, (q31_t)0x2E6EC792, + (q31_t)0x7747FBCE, (q31_t)0x2E110A62, (q31_t)0x776C4EDB, + (q31_t)0x2DB330C7, (q31_t)0x7790583D, (q31_t)0x2D553AFB, + (q31_t)0x77B417DF, (q31_t)0x2CF72939, (q31_t)0x77D78DAA, + (q31_t)0x2C98FBBA, (q31_t)0x77FAB988, (q31_t)0x2C3AB2B9, + (q31_t)0x781D9B64, (q31_t)0x2BDC4E6F, (q31_t)0x78403328, + (q31_t)0x2B7DCF17, (q31_t)0x786280BF, (q31_t)0x2B1F34EB, + (q31_t)0x78848413, (q31_t)0x2AC08025, (q31_t)0x78A63D10, + (q31_t)0x2A61B101, (q31_t)0x78C7ABA1, (q31_t)0x2A02C7B8, + (q31_t)0x78E8CFB1, (q31_t)0x29A3C484, (q31_t)0x7909A92C, + (q31_t)0x2944A7A2, (q31_t)0x792A37FE, (q31_t)0x28E5714A, + (q31_t)0x794A7C11, (q31_t)0x288621B9, (q31_t)0x796A7554, + (q31_t)0x2826B928, (q31_t)0x798A23B1, (q31_t)0x27C737D2, + (q31_t)0x79A98715, (q31_t)0x27679DF4, (q31_t)0x79C89F6D, + (q31_t)0x2707EBC6, (q31_t)0x79E76CA6, (q31_t)0x26A82185, + (q31_t)0x7A05EEAD, (q31_t)0x26483F6C, (q31_t)0x7A24256E, + (q31_t)0x25E845B5, (q31_t)0x7A4210D8, (q31_t)0x2588349D, + (q31_t)0x7A5FB0D8, (q31_t)0x25280C5D, (q31_t)0x7A7D055B, + (q31_t)0x24C7CD32, (q31_t)0x7A9A0E4F, (q31_t)0x24677757, + (q31_t)0x7AB6CBA3, (q31_t)0x24070B07, (q31_t)0x7AD33D45, + (q31_t)0x23A6887E, (q31_t)0x7AEF6323, (q31_t)0x2345EFF7, + (q31_t)0x7B0B3D2C, (q31_t)0x22E541AE, (q31_t)0x7B26CB4F, + (q31_t)0x22847DDF, (q31_t)0x7B420D7A, (q31_t)0x2223A4C5, + (q31_t)0x7B5D039D, (q31_t)0x21C2B69C, (q31_t)0x7B77ADA8, + (q31_t)0x2161B39F, (q31_t)0x7B920B89, (q31_t)0x21009C0B, + (q31_t)0x7BAC1D31, (q31_t)0x209F701C, (q31_t)0x7BC5E28F, + (q31_t)0x203E300D, (q31_t)0x7BDF5B94, (q31_t)0x1FDCDC1A, + (q31_t)0x7BF88830, (q31_t)0x1F7B7480, (q31_t)0x7C116853, + (q31_t)0x1F19F97B, (q31_t)0x7C29FBEE, (q31_t)0x1EB86B46, + (q31_t)0x7C4242F2, (q31_t)0x1E56CA1E, (q31_t)0x7C5A3D4F, + (q31_t)0x1DF5163F, (q31_t)0x7C71EAF8, (q31_t)0x1D934FE5, + (q31_t)0x7C894BDD, (q31_t)0x1D31774D, (q31_t)0x7CA05FF1, + (q31_t)0x1CCF8CB3, (q31_t)0x7CB72724, (q31_t)0x1C6D9053, + (q31_t)0x7CCDA168, (q31_t)0x1C0B826A, (q31_t)0x7CE3CEB1, + (q31_t)0x1BA96334, (q31_t)0x7CF9AEF0, (q31_t)0x1B4732EF, + (q31_t)0x7D0F4218, (q31_t)0x1AE4F1D6, (q31_t)0x7D24881A, + (q31_t)0x1A82A025, (q31_t)0x7D3980EC, (q31_t)0x1A203E1B, + (q31_t)0x7D4E2C7E, (q31_t)0x19BDCBF2, (q31_t)0x7D628AC5, + (q31_t)0x195B49E9, (q31_t)0x7D769BB5, (q31_t)0x18F8B83C, + (q31_t)0x7D8A5F3F, (q31_t)0x18961727, (q31_t)0x7D9DD55A, + (q31_t)0x183366E8, (q31_t)0x7DB0FDF7, (q31_t)0x17D0A7BB, + (q31_t)0x7DC3D90D, (q31_t)0x176DD9DE, (q31_t)0x7DD6668E, + (q31_t)0x170AFD8D, (q31_t)0x7DE8A670, (q31_t)0x16A81305, + (q31_t)0x7DFA98A7, (q31_t)0x16451A83, (q31_t)0x7E0C3D29, + (q31_t)0x15E21444, (q31_t)0x7E1D93E9, (q31_t)0x157F0086, + (q31_t)0x7E2E9CDF, (q31_t)0x151BDF85, (q31_t)0x7E3F57FE, + (q31_t)0x14B8B17F, (q31_t)0x7E4FC53E, (q31_t)0x145576B1, + (q31_t)0x7E5FE493, (q31_t)0x13F22F57, (q31_t)0x7E6FB5F3, + (q31_t)0x138EDBB0, (q31_t)0x7E7F3956, (q31_t)0x132B7BF9, + (q31_t)0x7E8E6EB1, (q31_t)0x12C8106E, (q31_t)0x7E9D55FC, + (q31_t)0x1264994E, (q31_t)0x7EABEF2C, (q31_t)0x120116D4, + (q31_t)0x7EBA3A39, (q31_t)0x119D8940, (q31_t)0x7EC8371A, + (q31_t)0x1139F0CE, (q31_t)0x7ED5E5C6, (q31_t)0x10D64DBC, + (q31_t)0x7EE34635, (q31_t)0x1072A047, (q31_t)0x7EF0585F, + (q31_t)0x100EE8AD, (q31_t)0x7EFD1C3C, (q31_t)0x0FAB272B, + (q31_t)0x7F0991C3, (q31_t)0x0F475BFE, (q31_t)0x7F15B8EE, + (q31_t)0x0EE38765, (q31_t)0x7F2191B4, (q31_t)0x0E7FA99D, + (q31_t)0x7F2D1C0E, (q31_t)0x0E1BC2E3, (q31_t)0x7F3857F5, + (q31_t)0x0DB7D376, (q31_t)0x7F434563, (q31_t)0x0D53DB92, + (q31_t)0x7F4DE450, (q31_t)0x0CEFDB75, (q31_t)0x7F5834B6, + (q31_t)0x0C8BD35E, (q31_t)0x7F62368F, (q31_t)0x0C27C389, + (q31_t)0x7F6BE9D4, (q31_t)0x0BC3AC35, (q31_t)0x7F754E7F, + (q31_t)0x0B5F8D9F, (q31_t)0x7F7E648B, (q31_t)0x0AFB6805, + (q31_t)0x7F872BF3, (q31_t)0x0A973BA5, (q31_t)0x7F8FA4AF, + (q31_t)0x0A3308BC, (q31_t)0x7F97CEBC, (q31_t)0x09CECF89, + (q31_t)0x7F9FAA15, (q31_t)0x096A9049, (q31_t)0x7FA736B4, + (q31_t)0x09064B3A, (q31_t)0x7FAE7494, (q31_t)0x08A2009A, + (q31_t)0x7FB563B2, (q31_t)0x083DB0A7, (q31_t)0x7FBC040A, + (q31_t)0x07D95B9E, (q31_t)0x7FC25596, (q31_t)0x077501BE, + (q31_t)0x7FC85853, (q31_t)0x0710A344, (q31_t)0x7FCE0C3E, + (q31_t)0x06AC406F, (q31_t)0x7FD37152, (q31_t)0x0647D97C, + (q31_t)0x7FD8878D, (q31_t)0x05E36EA9, (q31_t)0x7FDD4EEC, + (q31_t)0x057F0034, (q31_t)0x7FE1C76B, (q31_t)0x051A8E5C, + (q31_t)0x7FE5F108, (q31_t)0x04B6195D, (q31_t)0x7FE9CBC0, + (q31_t)0x0451A176, (q31_t)0x7FED5790, (q31_t)0x03ED26E6, + (q31_t)0x7FF09477, (q31_t)0x0388A9E9, (q31_t)0x7FF38273, + (q31_t)0x03242ABF, (q31_t)0x7FF62182, (q31_t)0x02BFA9A4, + (q31_t)0x7FF871A1, (q31_t)0x025B26D7, (q31_t)0x7FFA72D1, + (q31_t)0x01F6A296, (q31_t)0x7FFC250F, (q31_t)0x01921D1F, + (q31_t)0x7FFD885A, (q31_t)0x012D96B0, (q31_t)0x7FFE9CB2, + (q31_t)0x00C90F88, (q31_t)0x7FFF6216, (q31_t)0x006487E3, + (q31_t)0x7FFFD885, (q31_t)0x00000000, (q31_t)0x7FFFFFFF, + (q31_t)0xFF9B781D, (q31_t)0x7FFFD885, (q31_t)0xFF36F078, + (q31_t)0x7FFF6216, (q31_t)0xFED2694F, (q31_t)0x7FFE9CB2, + (q31_t)0xFE6DE2E0, (q31_t)0x7FFD885A, (q31_t)0xFE095D69, + (q31_t)0x7FFC250F, (q31_t)0xFDA4D928, (q31_t)0x7FFA72D1, + (q31_t)0xFD40565B, (q31_t)0x7FF871A1, (q31_t)0xFCDBD541, + (q31_t)0x7FF62182, (q31_t)0xFC775616, (q31_t)0x7FF38273, + (q31_t)0xFC12D919, (q31_t)0x7FF09477, (q31_t)0xFBAE5E89, + (q31_t)0x7FED5790, (q31_t)0xFB49E6A2, (q31_t)0x7FE9CBC0, + (q31_t)0xFAE571A4, (q31_t)0x7FE5F108, (q31_t)0xFA80FFCB, + (q31_t)0x7FE1C76B, (q31_t)0xFA1C9156, (q31_t)0x7FDD4EEC, + (q31_t)0xF9B82683, (q31_t)0x7FD8878D, (q31_t)0xF953BF90, + (q31_t)0x7FD37152, (q31_t)0xF8EF5CBB, (q31_t)0x7FCE0C3E, + (q31_t)0xF88AFE41, (q31_t)0x7FC85853, (q31_t)0xF826A461, + (q31_t)0x7FC25596, (q31_t)0xF7C24F58, (q31_t)0x7FBC040A, + (q31_t)0xF75DFF65, (q31_t)0x7FB563B2, (q31_t)0xF6F9B4C5, + (q31_t)0x7FAE7494, (q31_t)0xF6956FB6, (q31_t)0x7FA736B4, + (q31_t)0xF6313076, (q31_t)0x7F9FAA15, (q31_t)0xF5CCF743, + (q31_t)0x7F97CEBC, (q31_t)0xF568C45A, (q31_t)0x7F8FA4AF, + (q31_t)0xF50497FA, (q31_t)0x7F872BF3, (q31_t)0xF4A07260, + (q31_t)0x7F7E648B, (q31_t)0xF43C53CA, (q31_t)0x7F754E7F, + (q31_t)0xF3D83C76, (q31_t)0x7F6BE9D4, (q31_t)0xF3742CA1, + (q31_t)0x7F62368F, (q31_t)0xF310248A, (q31_t)0x7F5834B6, + (q31_t)0xF2AC246D, (q31_t)0x7F4DE450, (q31_t)0xF2482C89, + (q31_t)0x7F434563, (q31_t)0xF1E43D1C, (q31_t)0x7F3857F5, + (q31_t)0xF1805662, (q31_t)0x7F2D1C0E, (q31_t)0xF11C789A, + (q31_t)0x7F2191B4, (q31_t)0xF0B8A401, (q31_t)0x7F15B8EE, + (q31_t)0xF054D8D4, (q31_t)0x7F0991C3, (q31_t)0xEFF11752, + (q31_t)0x7EFD1C3C, (q31_t)0xEF8D5FB8, (q31_t)0x7EF0585F, + (q31_t)0xEF29B243, (q31_t)0x7EE34635, (q31_t)0xEEC60F31, + (q31_t)0x7ED5E5C6, (q31_t)0xEE6276BF, (q31_t)0x7EC8371A, + (q31_t)0xEDFEE92B, (q31_t)0x7EBA3A39, (q31_t)0xED9B66B2, + (q31_t)0x7EABEF2C, (q31_t)0xED37EF91, (q31_t)0x7E9D55FC, + (q31_t)0xECD48406, (q31_t)0x7E8E6EB1, (q31_t)0xEC71244F, + (q31_t)0x7E7F3956, (q31_t)0xEC0DD0A8, (q31_t)0x7E6FB5F3, + (q31_t)0xEBAA894E, (q31_t)0x7E5FE493, (q31_t)0xEB474E80, + (q31_t)0x7E4FC53E, (q31_t)0xEAE4207A, (q31_t)0x7E3F57FE, + (q31_t)0xEA80FF79, (q31_t)0x7E2E9CDF, (q31_t)0xEA1DEBBB, + (q31_t)0x7E1D93E9, (q31_t)0xE9BAE57C, (q31_t)0x7E0C3D29, + (q31_t)0xE957ECFB, (q31_t)0x7DFA98A7, (q31_t)0xE8F50273, + (q31_t)0x7DE8A670, (q31_t)0xE8922621, (q31_t)0x7DD6668E, + (q31_t)0xE82F5844, (q31_t)0x7DC3D90D, (q31_t)0xE7CC9917, + (q31_t)0x7DB0FDF7, (q31_t)0xE769E8D8, (q31_t)0x7D9DD55A, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, (q31_t)0xE6A4B616, + (q31_t)0x7D769BB5, (q31_t)0xE642340D, (q31_t)0x7D628AC5, + (q31_t)0xE5DFC1E4, (q31_t)0x7D4E2C7E, (q31_t)0xE57D5FDA, + (q31_t)0x7D3980EC, (q31_t)0xE51B0E2A, (q31_t)0x7D24881A, + (q31_t)0xE4B8CD10, (q31_t)0x7D0F4218, (q31_t)0xE4569CCB, + (q31_t)0x7CF9AEF0, (q31_t)0xE3F47D95, (q31_t)0x7CE3CEB1, + (q31_t)0xE3926FAC, (q31_t)0x7CCDA168, (q31_t)0xE330734C, + (q31_t)0x7CB72724, (q31_t)0xE2CE88B2, (q31_t)0x7CA05FF1, + (q31_t)0xE26CB01A, (q31_t)0x7C894BDD, (q31_t)0xE20AE9C1, + (q31_t)0x7C71EAF8, (q31_t)0xE1A935E1, (q31_t)0x7C5A3D4F, + (q31_t)0xE14794B9, (q31_t)0x7C4242F2, (q31_t)0xE0E60684, + (q31_t)0x7C29FBEE, (q31_t)0xE0848B7F, (q31_t)0x7C116853, + (q31_t)0xE02323E5, (q31_t)0x7BF88830, (q31_t)0xDFC1CFF2, + (q31_t)0x7BDF5B94, (q31_t)0xDF608FE3, (q31_t)0x7BC5E28F, + (q31_t)0xDEFF63F4, (q31_t)0x7BAC1D31, (q31_t)0xDE9E4C60, + (q31_t)0x7B920B89, (q31_t)0xDE3D4963, (q31_t)0x7B77ADA8, + (q31_t)0xDDDC5B3A, (q31_t)0x7B5D039D, (q31_t)0xDD7B8220, + (q31_t)0x7B420D7A, (q31_t)0xDD1ABE51, (q31_t)0x7B26CB4F, + (q31_t)0xDCBA1008, (q31_t)0x7B0B3D2C, (q31_t)0xDC597781, + (q31_t)0x7AEF6323, (q31_t)0xDBF8F4F8, (q31_t)0x7AD33D45, + (q31_t)0xDB9888A8, (q31_t)0x7AB6CBA3, (q31_t)0xDB3832CD, + (q31_t)0x7A9A0E4F, (q31_t)0xDAD7F3A2, (q31_t)0x7A7D055B, + (q31_t)0xDA77CB62, (q31_t)0x7A5FB0D8, (q31_t)0xDA17BA4A, + (q31_t)0x7A4210D8, (q31_t)0xD9B7C093, (q31_t)0x7A24256E, + (q31_t)0xD957DE7A, (q31_t)0x7A05EEAD, (q31_t)0xD8F81439, + (q31_t)0x79E76CA6, (q31_t)0xD898620C, (q31_t)0x79C89F6D, + (q31_t)0xD838C82D, (q31_t)0x79A98715, (q31_t)0xD7D946D7, + (q31_t)0x798A23B1, (q31_t)0xD779DE46, (q31_t)0x796A7554, + (q31_t)0xD71A8EB5, (q31_t)0x794A7C11, (q31_t)0xD6BB585D, + (q31_t)0x792A37FE, (q31_t)0xD65C3B7B, (q31_t)0x7909A92C, + (q31_t)0xD5FD3847, (q31_t)0x78E8CFB1, (q31_t)0xD59E4EFE, + (q31_t)0x78C7ABA1, (q31_t)0xD53F7FDA, (q31_t)0x78A63D10, + (q31_t)0xD4E0CB14, (q31_t)0x78848413, (q31_t)0xD48230E8, + (q31_t)0x786280BF, (q31_t)0xD423B190, (q31_t)0x78403328, + (q31_t)0xD3C54D46, (q31_t)0x781D9B64, (q31_t)0xD3670445, + (q31_t)0x77FAB988, (q31_t)0xD308D6C6, (q31_t)0x77D78DAA, + (q31_t)0xD2AAC504, (q31_t)0x77B417DF, (q31_t)0xD24CCF38, + (q31_t)0x7790583D, (q31_t)0xD1EEF59E, (q31_t)0x776C4EDB, + (q31_t)0xD191386D, (q31_t)0x7747FBCE, (q31_t)0xD13397E1, + (q31_t)0x77235F2D, (q31_t)0xD0D61433, (q31_t)0x76FE790E, + (q31_t)0xD078AD9D, (q31_t)0x76D94988, (q31_t)0xD01B6459, + (q31_t)0x76B3D0B3, (q31_t)0xCFBE389F, (q31_t)0x768E0EA5, + (q31_t)0xCF612AAA, (q31_t)0x76680376, (q31_t)0xCF043AB2, + (q31_t)0x7641AF3C, (q31_t)0xCEA768F2, (q31_t)0x761B1211, + (q31_t)0xCE4AB5A2, (q31_t)0x75F42C0A, (q31_t)0xCDEE20FC, + (q31_t)0x75CCFD42, (q31_t)0xCD91AB38, (q31_t)0x75A585CF, + (q31_t)0xCD355490, (q31_t)0x757DC5CA, (q31_t)0xCCD91D3D, + (q31_t)0x7555BD4B, (q31_t)0xCC7D0577, (q31_t)0x752D6C6C, + (q31_t)0xCC210D78, (q31_t)0x7504D345, (q31_t)0xCBC53578, + (q31_t)0x74DBF1EF, (q31_t)0xCB697DB0, (q31_t)0x74B2C883, + (q31_t)0xCB0DE658, (q31_t)0x7489571B, (q31_t)0xCAB26FA9, + (q31_t)0x745F9DD1, (q31_t)0xCA5719DB, (q31_t)0x74359CBD, + (q31_t)0xC9FBE527, (q31_t)0x740B53FA, (q31_t)0xC9A0D1C4, + (q31_t)0x73E0C3A3, (q31_t)0xC945DFEC, (q31_t)0x73B5EBD0, + (q31_t)0xC8EB0FD6, (q31_t)0x738ACC9E, (q31_t)0xC89061BA, + (q31_t)0x735F6626, (q31_t)0xC835D5D0, (q31_t)0x7333B883, + (q31_t)0xC7DB6C50, (q31_t)0x7307C3D0, (q31_t)0xC7812571, + (q31_t)0x72DB8828, (q31_t)0xC727016C, (q31_t)0x72AF05A6, + (q31_t)0xC6CD0079, (q31_t)0x72823C66, (q31_t)0xC67322CD, + (q31_t)0x72552C84, (q31_t)0xC61968A2, (q31_t)0x7227D61C, + (q31_t)0xC5BFD22E, (q31_t)0x71FA3948, (q31_t)0xC5665FA8, + (q31_t)0x71CC5626, (q31_t)0xC50D1148, (q31_t)0x719E2CD2, + (q31_t)0xC4B3E746, (q31_t)0x716FBD68, (q31_t)0xC45AE1D7, + (q31_t)0x71410804, (q31_t)0xC4020132, (q31_t)0x71120CC5, + (q31_t)0xC3A9458F, (q31_t)0x70E2CBC6, (q31_t)0xC350AF25, + (q31_t)0x70B34524, (q31_t)0xC2F83E2A, (q31_t)0x708378FE, + (q31_t)0xC29FF2D4, (q31_t)0x70536771, (q31_t)0xC247CD5A, + (q31_t)0x70231099, (q31_t)0xC1EFCDF2, (q31_t)0x6FF27496, + (q31_t)0xC197F4D3, (q31_t)0x6FC19385, (q31_t)0xC1404233, + (q31_t)0x6F906D84, (q31_t)0xC0E8B648, (q31_t)0x6F5F02B1, + (q31_t)0xC0915147, (q31_t)0x6F2D532C, (q31_t)0xC03A1368, + (q31_t)0x6EFB5F12, (q31_t)0xBFE2FCDF, (q31_t)0x6EC92682, + (q31_t)0xBF8C0DE2, (q31_t)0x6E96A99C, (q31_t)0xBF3546A8, + (q31_t)0x6E63E87F, (q31_t)0xBEDEA765, (q31_t)0x6E30E349, + (q31_t)0xBE88304F, (q31_t)0x6DFD9A1B, (q31_t)0xBE31E19B, + (q31_t)0x6DCA0D14, (q31_t)0xBDDBBB7F, (q31_t)0x6D963C54, + (q31_t)0xBD85BE2F, (q31_t)0x6D6227FA, (q31_t)0xBD2FE9E1, + (q31_t)0x6D2DD027, (q31_t)0xBCDA3ECA, (q31_t)0x6CF934FB, + (q31_t)0xBC84BD1E, (q31_t)0x6CC45697, (q31_t)0xBC2F6513, + (q31_t)0x6C8F351C, (q31_t)0xBBDA36DC, (q31_t)0x6C59D0A9, + (q31_t)0xBB8532AF, (q31_t)0x6C242960, (q31_t)0xBB3058C0, + (q31_t)0x6BEE3F62, (q31_t)0xBADBA943, (q31_t)0x6BB812D0, + (q31_t)0xBA87246C, (q31_t)0x6B81A3CD, (q31_t)0xBA32CA70, + (q31_t)0x6B4AF278, (q31_t)0xB9DE9B83, (q31_t)0x6B13FEF5, + (q31_t)0xB98A97D8, (q31_t)0x6ADCC964, (q31_t)0xB936BFA3, + (q31_t)0x6AA551E8, (q31_t)0xB8E31319, (q31_t)0x6A6D98A4, + (q31_t)0xB88F926C, (q31_t)0x6A359DB9, (q31_t)0xB83C3DD1, + (q31_t)0x69FD614A, (q31_t)0xB7E9157A, (q31_t)0x69C4E37A, + (q31_t)0xB796199B, (q31_t)0x698C246C, (q31_t)0xB7434A67, + (q31_t)0x69532442, (q31_t)0xB6F0A811, (q31_t)0x6919E320, + (q31_t)0xB69E32CD, (q31_t)0x68E06129, (q31_t)0xB64BEACC, + (q31_t)0x68A69E81, (q31_t)0xB5F9D042, (q31_t)0x686C9B4B, + (q31_t)0xB5A7E362, (q31_t)0x683257AA, (q31_t)0xB556245E, + (q31_t)0x67F7D3C4, (q31_t)0xB5049368, (q31_t)0x67BD0FBC, + (q31_t)0xB4B330B2, (q31_t)0x67820BB6, (q31_t)0xB461FC70, + (q31_t)0x6746C7D7, (q31_t)0xB410F6D2, (q31_t)0x670B4443, + (q31_t)0xB3C0200C, (q31_t)0x66CF811F, (q31_t)0xB36F784E, + (q31_t)0x66937E90, (q31_t)0xB31EFFCB, (q31_t)0x66573CBB, + (q31_t)0xB2CEB6B5, (q31_t)0x661ABBC5, (q31_t)0xB27E9D3B, + (q31_t)0x65DDFBD3, (q31_t)0xB22EB392, (q31_t)0x65A0FD0B, + (q31_t)0xB1DEF9E8, (q31_t)0x6563BF92, (q31_t)0xB18F7070, + (q31_t)0x6526438E, (q31_t)0xB140175B, (q31_t)0x64E88926, + (q31_t)0xB0F0EEDA, (q31_t)0x64AA907F, (q31_t)0xB0A1F71C, + (q31_t)0x646C59BF, (q31_t)0xB0533055, (q31_t)0x642DE50D, + (q31_t)0xB0049AB2, (q31_t)0x63EF328F, (q31_t)0xAFB63667, + (q31_t)0x63B0426D, (q31_t)0xAF6803A1, (q31_t)0x637114CC, + (q31_t)0xAF1A0293, (q31_t)0x6331A9D4, (q31_t)0xAECC336B, + (q31_t)0x62F201AC, (q31_t)0xAE7E965B, (q31_t)0x62B21C7B, + (q31_t)0xAE312B91, (q31_t)0x6271FA69, (q31_t)0xADE3F33E, + (q31_t)0x62319B9D, (q31_t)0xAD96ED91, (q31_t)0x61F1003E, + (q31_t)0xAD4A1ABA, (q31_t)0x61B02876, (q31_t)0xACFD7AE8, + (q31_t)0x616F146B, (q31_t)0xACB10E4A, (q31_t)0x612DC446, + (q31_t)0xAC64D510, (q31_t)0x60EC3830, (q31_t)0xAC18CF68, + (q31_t)0x60AA704F, (q31_t)0xABCCFD82, (q31_t)0x60686CCE, + (q31_t)0xAB815F8C, (q31_t)0x60262DD5, (q31_t)0xAB35F5B5, + (q31_t)0x5FE3B38D, (q31_t)0xAAEAC02B, (q31_t)0x5FA0FE1E, + (q31_t)0xAA9FBF1D, (q31_t)0x5F5E0DB3, (q31_t)0xAA54F2B9, + (q31_t)0x5F1AE273, (q31_t)0xAA0A5B2D, (q31_t)0x5ED77C89, + (q31_t)0xA9BFF8A8, (q31_t)0x5E93DC1F, (q31_t)0xA975CB56, + (q31_t)0x5E50015D, (q31_t)0xA92BD366, (q31_t)0x5E0BEC6E, + (q31_t)0xA8E21106, (q31_t)0x5DC79D7C, (q31_t)0xA8988463, + (q31_t)0x5D8314B0, (q31_t)0xA84F2DA9, (q31_t)0x5D3E5236, + (q31_t)0xA8060D08, (q31_t)0x5CF95638, (q31_t)0xA7BD22AB, + (q31_t)0x5CB420DF, (q31_t)0xA7746EC0, (q31_t)0x5C6EB258, + (q31_t)0xA72BF173, (q31_t)0x5C290ACC, (q31_t)0xA6E3AAF2, + (q31_t)0x5BE32A67, (q31_t)0xA69B9B68, (q31_t)0x5B9D1153, + (q31_t)0xA653C302, (q31_t)0x5B56BFBD, (q31_t)0xA60C21ED, + (q31_t)0x5B1035CF, (q31_t)0xA5C4B855, (q31_t)0x5AC973B4, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, (q31_t)0xA5368C4B, + (q31_t)0x5A3B47AA, (q31_t)0xA4EFCA31, (q31_t)0x59F3DE12, + (q31_t)0xA4A94042, (q31_t)0x59AC3CFD, (q31_t)0xA462EEAC, + (q31_t)0x59646497, (q31_t)0xA41CD598, (q31_t)0x591C550E, + (q31_t)0xA3D6F533, (q31_t)0x58D40E8C, (q31_t)0xA3914DA7, + (q31_t)0x588B913F, (q31_t)0xA34BDF20, (q31_t)0x5842DD54, + (q31_t)0xA306A9C7, (q31_t)0x57F9F2F7, (q31_t)0xA2C1ADC9, + (q31_t)0x57B0D256, (q31_t)0xA27CEB4F, (q31_t)0x57677B9D, + (q31_t)0xA2386283, (q31_t)0x571DEEF9, (q31_t)0xA1F41391, + (q31_t)0x56D42C99, (q31_t)0xA1AFFEA2, (q31_t)0x568A34A9, + (q31_t)0xA16C23E1, (q31_t)0x56400757, (q31_t)0xA1288376, + (q31_t)0x55F5A4D2, (q31_t)0xA0E51D8C, (q31_t)0x55AB0D46, + (q31_t)0xA0A1F24C, (q31_t)0x556040E2, (q31_t)0xA05F01E1, + (q31_t)0x55153FD4, (q31_t)0xA01C4C72, (q31_t)0x54CA0A4A, + (q31_t)0x9FD9D22A, (q31_t)0x547EA073, (q31_t)0x9F979331, + (q31_t)0x5433027D, (q31_t)0x9F558FB0, (q31_t)0x53E73097, + (q31_t)0x9F13C7D0, (q31_t)0x539B2AEF, (q31_t)0x9ED23BB9, + (q31_t)0x534EF1B5, (q31_t)0x9E90EB94, (q31_t)0x53028517, + (q31_t)0x9E4FD789, (q31_t)0x52B5E545, (q31_t)0x9E0EFFC1, + (q31_t)0x5269126E, (q31_t)0x9DCE6462, (q31_t)0x521C0CC1, + (q31_t)0x9D8E0596, (q31_t)0x51CED46E, (q31_t)0x9D4DE384, + (q31_t)0x518169A4, (q31_t)0x9D0DFE53, (q31_t)0x5133CC94, + (q31_t)0x9CCE562B, (q31_t)0x50E5FD6C, (q31_t)0x9C8EEB33, + (q31_t)0x5097FC5E, (q31_t)0x9C4FBD92, (q31_t)0x5049C999, + (q31_t)0x9C10CD70, (q31_t)0x4FFB654D, (q31_t)0x9BD21AF2, + (q31_t)0x4FACCFAB, (q31_t)0x9B93A640, (q31_t)0x4F5E08E3, + (q31_t)0x9B556F80, (q31_t)0x4F0F1126, (q31_t)0x9B1776D9, + (q31_t)0x4EBFE8A4, (q31_t)0x9AD9BC71, (q31_t)0x4E708F8F, + (q31_t)0x9A9C406D, (q31_t)0x4E210617, (q31_t)0x9A5F02F5, + (q31_t)0x4DD14C6E, (q31_t)0x9A22042C, (q31_t)0x4D8162C4, + (q31_t)0x99E5443A, (q31_t)0x4D31494B, (q31_t)0x99A8C344, + (q31_t)0x4CE10034, (q31_t)0x996C816F, (q31_t)0x4C9087B1, + (q31_t)0x99307EE0, (q31_t)0x4C3FDFF3, (q31_t)0x98F4BBBC, + (q31_t)0x4BEF092D, (q31_t)0x98B93828, (q31_t)0x4B9E038F, + (q31_t)0x987DF449, (q31_t)0x4B4CCF4D, (q31_t)0x9842F043, + (q31_t)0x4AFB6C97, (q31_t)0x98082C3B, (q31_t)0x4AA9DBA1, + (q31_t)0x97CDA855, (q31_t)0x4A581C9D, (q31_t)0x979364B5, + (q31_t)0x4A062FBD, (q31_t)0x9759617E, (q31_t)0x49B41533, + (q31_t)0x971F9ED6, (q31_t)0x4961CD32, (q31_t)0x96E61CDF, + (q31_t)0x490F57EE, (q31_t)0x96ACDBBD, (q31_t)0x48BCB598, + (q31_t)0x9673DB94, (q31_t)0x4869E664, (q31_t)0x963B1C85, + (q31_t)0x4816EA85, (q31_t)0x96029EB5, (q31_t)0x47C3C22E, + (q31_t)0x95CA6246, (q31_t)0x47706D93, (q31_t)0x9592675B, + (q31_t)0x471CECE6, (q31_t)0x955AAE17, (q31_t)0x46C9405C, + (q31_t)0x9523369B, (q31_t)0x46756827, (q31_t)0x94EC010B, + (q31_t)0x4621647C, (q31_t)0x94B50D87, (q31_t)0x45CD358F, + (q31_t)0x947E5C32, (q31_t)0x4578DB93, (q31_t)0x9447ED2F, + (q31_t)0x452456BC, (q31_t)0x9411C09D, (q31_t)0x44CFA73F, + (q31_t)0x93DBD69F, (q31_t)0x447ACD50, (q31_t)0x93A62F56, + (q31_t)0x4425C923, (q31_t)0x9370CAE4, (q31_t)0x43D09AEC, + (q31_t)0x933BA968, (q31_t)0x437B42E1, (q31_t)0x9306CB04, + (q31_t)0x4325C135, (q31_t)0x92D22FD8, (q31_t)0x42D0161E, + (q31_t)0x929DD805, (q31_t)0x427A41D0, (q31_t)0x9269C3AC, + (q31_t)0x42244480, (q31_t)0x9235F2EB, (q31_t)0x41CE1E64, + (q31_t)0x920265E4, (q31_t)0x4177CFB0, (q31_t)0x91CF1CB6, + (q31_t)0x4121589A, (q31_t)0x919C1780, (q31_t)0x40CAB957, + (q31_t)0x91695663, (q31_t)0x4073F21D, (q31_t)0x9136D97D, + (q31_t)0x401D0320, (q31_t)0x9104A0ED, (q31_t)0x3FC5EC97, + (q31_t)0x90D2ACD3, (q31_t)0x3F6EAEB8, (q31_t)0x90A0FD4E, + (q31_t)0x3F1749B7, (q31_t)0x906F927B, (q31_t)0x3EBFBDCC, + (q31_t)0x903E6C7A, (q31_t)0x3E680B2C, (q31_t)0x900D8B69, + (q31_t)0x3E10320D, (q31_t)0x8FDCEF66, (q31_t)0x3DB832A5, + (q31_t)0x8FAC988E, (q31_t)0x3D600D2B, (q31_t)0x8F7C8701, + (q31_t)0x3D07C1D5, (q31_t)0x8F4CBADB, (q31_t)0x3CAF50DA, + (q31_t)0x8F1D343A, (q31_t)0x3C56BA70, (q31_t)0x8EEDF33B, + (q31_t)0x3BFDFECD, (q31_t)0x8EBEF7FB, (q31_t)0x3BA51E29, + (q31_t)0x8E904298, (q31_t)0x3B4C18BA, (q31_t)0x8E61D32D, + (q31_t)0x3AF2EEB7, (q31_t)0x8E33A9D9, (q31_t)0x3A99A057, + (q31_t)0x8E05C6B7, (q31_t)0x3A402DD1, (q31_t)0x8DD829E4, + (q31_t)0x39E6975D, (q31_t)0x8DAAD37B, (q31_t)0x398CDD32, + (q31_t)0x8D7DC399, (q31_t)0x3932FF87, (q31_t)0x8D50FA59, + (q31_t)0x38D8FE93, (q31_t)0x8D2477D8, (q31_t)0x387EDA8E, + (q31_t)0x8CF83C30, (q31_t)0x382493B0, (q31_t)0x8CCC477D, + (q31_t)0x37CA2A30, (q31_t)0x8CA099D9, (q31_t)0x376F9E46, + (q31_t)0x8C753361, (q31_t)0x3714F02A, (q31_t)0x8C4A142F, + (q31_t)0x36BA2013, (q31_t)0x8C1F3C5C, (q31_t)0x365F2E3B, + (q31_t)0x8BF4AC05, (q31_t)0x36041AD9, (q31_t)0x8BCA6342, + (q31_t)0x35A8E624, (q31_t)0x8BA0622F, (q31_t)0x354D9056, + (q31_t)0x8B76A8E4, (q31_t)0x34F219A7, (q31_t)0x8B4D377C, + (q31_t)0x3496824F, (q31_t)0x8B240E10, (q31_t)0x343ACA87, + (q31_t)0x8AFB2CBA, (q31_t)0x33DEF287, (q31_t)0x8AD29393, + (q31_t)0x3382FA88, (q31_t)0x8AAA42B4, (q31_t)0x3326E2C2, + (q31_t)0x8A823A35, (q31_t)0x32CAAB6F, (q31_t)0x8A5A7A30, + (q31_t)0x326E54C7, (q31_t)0x8A3302BD, (q31_t)0x3211DF03, + (q31_t)0x8A0BD3F5, (q31_t)0x31B54A5D, (q31_t)0x89E4EDEE, + (q31_t)0x3158970D, (q31_t)0x89BE50C3, (q31_t)0x30FBC54D, + (q31_t)0x8997FC89, (q31_t)0x309ED555, (q31_t)0x8971F15A, + (q31_t)0x3041C760, (q31_t)0x894C2F4C, (q31_t)0x2FE49BA6, + (q31_t)0x8926B677, (q31_t)0x2F875262, (q31_t)0x890186F1, + (q31_t)0x2F29EBCC, (q31_t)0x88DCA0D3, (q31_t)0x2ECC681E, + (q31_t)0x88B80431, (q31_t)0x2E6EC792, (q31_t)0x8893B124, + (q31_t)0x2E110A62, (q31_t)0x886FA7C2, (q31_t)0x2DB330C7, + (q31_t)0x884BE820, (q31_t)0x2D553AFB, (q31_t)0x88287255, + (q31_t)0x2CF72939, (q31_t)0x88054677, (q31_t)0x2C98FBBA, + (q31_t)0x87E2649B, (q31_t)0x2C3AB2B9, (q31_t)0x87BFCCD7, + (q31_t)0x2BDC4E6F, (q31_t)0x879D7F40, (q31_t)0x2B7DCF17, + (q31_t)0x877B7BEC, (q31_t)0x2B1F34EB, (q31_t)0x8759C2EF, + (q31_t)0x2AC08025, (q31_t)0x8738545E, (q31_t)0x2A61B101, + (q31_t)0x8717304E, (q31_t)0x2A02C7B8, (q31_t)0x86F656D3, + (q31_t)0x29A3C484, (q31_t)0x86D5C802, (q31_t)0x2944A7A2, + (q31_t)0x86B583EE, (q31_t)0x28E5714A, (q31_t)0x86958AAB, + (q31_t)0x288621B9, (q31_t)0x8675DC4E, (q31_t)0x2826B928, + (q31_t)0x865678EA, (q31_t)0x27C737D2, (q31_t)0x86376092, + (q31_t)0x27679DF4, (q31_t)0x86189359, (q31_t)0x2707EBC6, + (q31_t)0x85FA1152, (q31_t)0x26A82185, (q31_t)0x85DBDA91, + (q31_t)0x26483F6C, (q31_t)0x85BDEF27, (q31_t)0x25E845B5, + (q31_t)0x85A04F28, (q31_t)0x2588349D, (q31_t)0x8582FAA4, + (q31_t)0x25280C5D, (q31_t)0x8565F1B0, (q31_t)0x24C7CD32, + (q31_t)0x8549345C, (q31_t)0x24677757, (q31_t)0x852CC2BA, + (q31_t)0x24070B07, (q31_t)0x85109CDC, (q31_t)0x23A6887E, + (q31_t)0x84F4C2D3, (q31_t)0x2345EFF7, (q31_t)0x84D934B0, + (q31_t)0x22E541AE, (q31_t)0x84BDF285, (q31_t)0x22847DDF, + (q31_t)0x84A2FC62, (q31_t)0x2223A4C5, (q31_t)0x84885257, + (q31_t)0x21C2B69C, (q31_t)0x846DF476, (q31_t)0x2161B39F, + (q31_t)0x8453E2CE, (q31_t)0x21009C0B, (q31_t)0x843A1D70, + (q31_t)0x209F701C, (q31_t)0x8420A46B, (q31_t)0x203E300D, + (q31_t)0x840777CF, (q31_t)0x1FDCDC1A, (q31_t)0x83EE97AC, + (q31_t)0x1F7B7480, (q31_t)0x83D60411, (q31_t)0x1F19F97B, + (q31_t)0x83BDBD0D, (q31_t)0x1EB86B46, (q31_t)0x83A5C2B0, + (q31_t)0x1E56CA1E, (q31_t)0x838E1507, (q31_t)0x1DF5163F, + (q31_t)0x8376B422, (q31_t)0x1D934FE5, (q31_t)0x835FA00E, + (q31_t)0x1D31774D, (q31_t)0x8348D8DB, (q31_t)0x1CCF8CB3, + (q31_t)0x83325E97, (q31_t)0x1C6D9053, (q31_t)0x831C314E, + (q31_t)0x1C0B826A, (q31_t)0x8306510F, (q31_t)0x1BA96334, + (q31_t)0x82F0BDE8, (q31_t)0x1B4732EF, (q31_t)0x82DB77E5, + (q31_t)0x1AE4F1D6, (q31_t)0x82C67F13, (q31_t)0x1A82A025, + (q31_t)0x82B1D381, (q31_t)0x1A203E1B, (q31_t)0x829D753A, + (q31_t)0x19BDCBF2, (q31_t)0x8289644A, (q31_t)0x195B49E9, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, (q31_t)0x82622AA5, + (q31_t)0x18961727, (q31_t)0x824F0208, (q31_t)0x183366E8, + (q31_t)0x823C26F2, (q31_t)0x17D0A7BB, (q31_t)0x82299971, + (q31_t)0x176DD9DE, (q31_t)0x8217598F, (q31_t)0x170AFD8D, + (q31_t)0x82056758, (q31_t)0x16A81305, (q31_t)0x81F3C2D7, + (q31_t)0x16451A83, (q31_t)0x81E26C16, (q31_t)0x15E21444, + (q31_t)0x81D16320, (q31_t)0x157F0086, (q31_t)0x81C0A801, + (q31_t)0x151BDF85, (q31_t)0x81B03AC1, (q31_t)0x14B8B17F, + (q31_t)0x81A01B6C, (q31_t)0x145576B1, (q31_t)0x81904A0C, + (q31_t)0x13F22F57, (q31_t)0x8180C6A9, (q31_t)0x138EDBB0, + (q31_t)0x8171914E, (q31_t)0x132B7BF9, (q31_t)0x8162AA03, + (q31_t)0x12C8106E, (q31_t)0x815410D3, (q31_t)0x1264994E, + (q31_t)0x8145C5C6, (q31_t)0x120116D4, (q31_t)0x8137C8E6, + (q31_t)0x119D8940, (q31_t)0x812A1A39, (q31_t)0x1139F0CE, + (q31_t)0x811CB9CA, (q31_t)0x10D64DBC, (q31_t)0x810FA7A0, + (q31_t)0x1072A047, (q31_t)0x8102E3C3, (q31_t)0x100EE8AD, + (q31_t)0x80F66E3C, (q31_t)0x0FAB272B, (q31_t)0x80EA4712, + (q31_t)0x0F475BFE, (q31_t)0x80DE6E4C, (q31_t)0x0EE38765, + (q31_t)0x80D2E3F1, (q31_t)0x0E7FA99D, (q31_t)0x80C7A80A, + (q31_t)0x0E1BC2E3, (q31_t)0x80BCBA9C, (q31_t)0x0DB7D376, + (q31_t)0x80B21BAF, (q31_t)0x0D53DB92, (q31_t)0x80A7CB49, + (q31_t)0x0CEFDB75, (q31_t)0x809DC970, (q31_t)0x0C8BD35E, + (q31_t)0x8094162B, (q31_t)0x0C27C389, (q31_t)0x808AB180, + (q31_t)0x0BC3AC35, (q31_t)0x80819B74, (q31_t)0x0B5F8D9F, + (q31_t)0x8078D40D, (q31_t)0x0AFB6805, (q31_t)0x80705B50, + (q31_t)0x0A973BA5, (q31_t)0x80683143, (q31_t)0x0A3308BC, + (q31_t)0x806055EA, (q31_t)0x09CECF89, (q31_t)0x8058C94C, + (q31_t)0x096A9049, (q31_t)0x80518B6B, (q31_t)0x09064B3A, + (q31_t)0x804A9C4D, (q31_t)0x08A2009A, (q31_t)0x8043FBF6, + (q31_t)0x083DB0A7, (q31_t)0x803DAA69, (q31_t)0x07D95B9E, + (q31_t)0x8037A7AC, (q31_t)0x077501BE, (q31_t)0x8031F3C1, + (q31_t)0x0710A344, (q31_t)0x802C8EAD, (q31_t)0x06AC406F, + (q31_t)0x80277872, (q31_t)0x0647D97C, (q31_t)0x8022B113, + (q31_t)0x05E36EA9, (q31_t)0x801E3894, (q31_t)0x057F0034, + (q31_t)0x801A0EF7, (q31_t)0x051A8E5C, (q31_t)0x80163440, + (q31_t)0x04B6195D, (q31_t)0x8012A86F, (q31_t)0x0451A176, + (q31_t)0x800F6B88, (q31_t)0x03ED26E6, (q31_t)0x800C7D8C, + (q31_t)0x0388A9E9, (q31_t)0x8009DE7D, (q31_t)0x03242ABF, + (q31_t)0x80078E5E, (q31_t)0x02BFA9A4, (q31_t)0x80058D2E, + (q31_t)0x025B26D7, (q31_t)0x8003DAF0, (q31_t)0x01F6A296, + (q31_t)0x800277A5, (q31_t)0x01921D1F, (q31_t)0x8001634D, + (q31_t)0x012D96B0, (q31_t)0x80009DE9, (q31_t)0x00C90F88, + (q31_t)0x8000277A, (q31_t)0x006487E3, (q31_t)0x80000000, + (q31_t)0x00000000, (q31_t)0x8000277A, (q31_t)0xFF9B781D, + (q31_t)0x80009DE9, (q31_t)0xFF36F078, (q31_t)0x8001634D, + (q31_t)0xFED2694F, (q31_t)0x800277A5, (q31_t)0xFE6DE2E0, + (q31_t)0x8003DAF0, (q31_t)0xFE095D69, (q31_t)0x80058D2E, + (q31_t)0xFDA4D928, (q31_t)0x80078E5E, (q31_t)0xFD40565B, + (q31_t)0x8009DE7D, (q31_t)0xFCDBD541, (q31_t)0x800C7D8C, + (q31_t)0xFC775616, (q31_t)0x800F6B88, (q31_t)0xFC12D919, + (q31_t)0x8012A86F, (q31_t)0xFBAE5E89, (q31_t)0x80163440, + (q31_t)0xFB49E6A2, (q31_t)0x801A0EF7, (q31_t)0xFAE571A4, + (q31_t)0x801E3894, (q31_t)0xFA80FFCB, (q31_t)0x8022B113, + (q31_t)0xFA1C9156, (q31_t)0x80277872, (q31_t)0xF9B82683, + (q31_t)0x802C8EAD, (q31_t)0xF953BF90, (q31_t)0x8031F3C1, + (q31_t)0xF8EF5CBB, (q31_t)0x8037A7AC, (q31_t)0xF88AFE41, + (q31_t)0x803DAA69, (q31_t)0xF826A461, (q31_t)0x8043FBF6, + (q31_t)0xF7C24F58, (q31_t)0x804A9C4D, (q31_t)0xF75DFF65, + (q31_t)0x80518B6B, (q31_t)0xF6F9B4C5, (q31_t)0x8058C94C, + (q31_t)0xF6956FB6, (q31_t)0x806055EA, (q31_t)0xF6313076, + (q31_t)0x80683143, (q31_t)0xF5CCF743, (q31_t)0x80705B50, + (q31_t)0xF568C45A, (q31_t)0x8078D40D, (q31_t)0xF50497FA, + (q31_t)0x80819B74, (q31_t)0xF4A07260, (q31_t)0x808AB180, + (q31_t)0xF43C53CA, (q31_t)0x8094162B, (q31_t)0xF3D83C76, + (q31_t)0x809DC970, (q31_t)0xF3742CA1, (q31_t)0x80A7CB49, + (q31_t)0xF310248A, (q31_t)0x80B21BAF, (q31_t)0xF2AC246D, + (q31_t)0x80BCBA9C, (q31_t)0xF2482C89, (q31_t)0x80C7A80A, + (q31_t)0xF1E43D1C, (q31_t)0x80D2E3F1, (q31_t)0xF1805662, + (q31_t)0x80DE6E4C, (q31_t)0xF11C789A, (q31_t)0x80EA4712, + (q31_t)0xF0B8A401, (q31_t)0x80F66E3C, (q31_t)0xF054D8D4, + (q31_t)0x8102E3C3, (q31_t)0xEFF11752, (q31_t)0x810FA7A0, + (q31_t)0xEF8D5FB8, (q31_t)0x811CB9CA, (q31_t)0xEF29B243, + (q31_t)0x812A1A39, (q31_t)0xEEC60F31, (q31_t)0x8137C8E6, + (q31_t)0xEE6276BF, (q31_t)0x8145C5C6, (q31_t)0xEDFEE92B, + (q31_t)0x815410D3, (q31_t)0xED9B66B2, (q31_t)0x8162AA03, + (q31_t)0xED37EF91, (q31_t)0x8171914E, (q31_t)0xECD48406, + (q31_t)0x8180C6A9, (q31_t)0xEC71244F, (q31_t)0x81904A0C, + (q31_t)0xEC0DD0A8, (q31_t)0x81A01B6C, (q31_t)0xEBAA894E, + (q31_t)0x81B03AC1, (q31_t)0xEB474E80, (q31_t)0x81C0A801, + (q31_t)0xEAE4207A, (q31_t)0x81D16320, (q31_t)0xEA80FF79, + (q31_t)0x81E26C16, (q31_t)0xEA1DEBBB, (q31_t)0x81F3C2D7, + (q31_t)0xE9BAE57C, (q31_t)0x82056758, (q31_t)0xE957ECFB, + (q31_t)0x8217598F, (q31_t)0xE8F50273, (q31_t)0x82299971, + (q31_t)0xE8922621, (q31_t)0x823C26F2, (q31_t)0xE82F5844, + (q31_t)0x824F0208, (q31_t)0xE7CC9917, (q31_t)0x82622AA5, + (q31_t)0xE769E8D8, (q31_t)0x8275A0C0, (q31_t)0xE70747C3, + (q31_t)0x8289644A, (q31_t)0xE6A4B616, (q31_t)0x829D753A, + (q31_t)0xE642340D, (q31_t)0x82B1D381, (q31_t)0xE5DFC1E4, + (q31_t)0x82C67F13, (q31_t)0xE57D5FDA, (q31_t)0x82DB77E5, + (q31_t)0xE51B0E2A, (q31_t)0x82F0BDE8, (q31_t)0xE4B8CD10, + (q31_t)0x8306510F, (q31_t)0xE4569CCB, (q31_t)0x831C314E, + (q31_t)0xE3F47D95, (q31_t)0x83325E97, (q31_t)0xE3926FAC, + (q31_t)0x8348D8DB, (q31_t)0xE330734C, (q31_t)0x835FA00E, + (q31_t)0xE2CE88B2, (q31_t)0x8376B422, (q31_t)0xE26CB01A, + (q31_t)0x838E1507, (q31_t)0xE20AE9C1, (q31_t)0x83A5C2B0, + (q31_t)0xE1A935E1, (q31_t)0x83BDBD0D, (q31_t)0xE14794B9, + (q31_t)0x83D60411, (q31_t)0xE0E60684, (q31_t)0x83EE97AC, + (q31_t)0xE0848B7F, (q31_t)0x840777CF, (q31_t)0xE02323E5, + (q31_t)0x8420A46B, (q31_t)0xDFC1CFF2, (q31_t)0x843A1D70, + (q31_t)0xDF608FE3, (q31_t)0x8453E2CE, (q31_t)0xDEFF63F4, + (q31_t)0x846DF476, (q31_t)0xDE9E4C60, (q31_t)0x84885257, + (q31_t)0xDE3D4963, (q31_t)0x84A2FC62, (q31_t)0xDDDC5B3A, + (q31_t)0x84BDF285, (q31_t)0xDD7B8220, (q31_t)0x84D934B0, + (q31_t)0xDD1ABE51, (q31_t)0x84F4C2D3, (q31_t)0xDCBA1008, + (q31_t)0x85109CDC, (q31_t)0xDC597781, (q31_t)0x852CC2BA, + (q31_t)0xDBF8F4F8, (q31_t)0x8549345C, (q31_t)0xDB9888A8, + (q31_t)0x8565F1B0, (q31_t)0xDB3832CD, (q31_t)0x8582FAA4, + (q31_t)0xDAD7F3A2, (q31_t)0x85A04F28, (q31_t)0xDA77CB62, + (q31_t)0x85BDEF27, (q31_t)0xDA17BA4A, (q31_t)0x85DBDA91, + (q31_t)0xD9B7C093, (q31_t)0x85FA1152, (q31_t)0xD957DE7A, + (q31_t)0x86189359, (q31_t)0xD8F81439, (q31_t)0x86376092, + (q31_t)0xD898620C, (q31_t)0x865678EA, (q31_t)0xD838C82D, + (q31_t)0x8675DC4E, (q31_t)0xD7D946D7, (q31_t)0x86958AAB, + (q31_t)0xD779DE46, (q31_t)0x86B583EE, (q31_t)0xD71A8EB5, + (q31_t)0x86D5C802, (q31_t)0xD6BB585D, (q31_t)0x86F656D3, + (q31_t)0xD65C3B7B, (q31_t)0x8717304E, (q31_t)0xD5FD3847, + (q31_t)0x8738545E, (q31_t)0xD59E4EFE, (q31_t)0x8759C2EF, + (q31_t)0xD53F7FDA, (q31_t)0x877B7BEC, (q31_t)0xD4E0CB14, + (q31_t)0x879D7F40, (q31_t)0xD48230E8, (q31_t)0x87BFCCD7, + (q31_t)0xD423B190, (q31_t)0x87E2649B, (q31_t)0xD3C54D46, + (q31_t)0x88054677, (q31_t)0xD3670445, (q31_t)0x88287255, + (q31_t)0xD308D6C6, (q31_t)0x884BE820, (q31_t)0xD2AAC504, + (q31_t)0x886FA7C2, (q31_t)0xD24CCF38, (q31_t)0x8893B124, + (q31_t)0xD1EEF59E, (q31_t)0x88B80431, (q31_t)0xD191386D, + (q31_t)0x88DCA0D3, (q31_t)0xD13397E1, (q31_t)0x890186F1, + (q31_t)0xD0D61433, (q31_t)0x8926B677, (q31_t)0xD078AD9D, + (q31_t)0x894C2F4C, (q31_t)0xD01B6459, (q31_t)0x8971F15A, + (q31_t)0xCFBE389F, (q31_t)0x8997FC89, (q31_t)0xCF612AAA, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, (q31_t)0x89E4EDEE, + (q31_t)0xCEA768F2, (q31_t)0x8A0BD3F5, (q31_t)0xCE4AB5A2, + (q31_t)0x8A3302BD, (q31_t)0xCDEE20FC, (q31_t)0x8A5A7A30, + (q31_t)0xCD91AB38, (q31_t)0x8A823A35, (q31_t)0xCD355490, + (q31_t)0x8AAA42B4, (q31_t)0xCCD91D3D, (q31_t)0x8AD29393, + (q31_t)0xCC7D0577, (q31_t)0x8AFB2CBA, (q31_t)0xCC210D78, + (q31_t)0x8B240E10, (q31_t)0xCBC53578, (q31_t)0x8B4D377C, + (q31_t)0xCB697DB0, (q31_t)0x8B76A8E4, (q31_t)0xCB0DE658, + (q31_t)0x8BA0622F, (q31_t)0xCAB26FA9, (q31_t)0x8BCA6342, + (q31_t)0xCA5719DB, (q31_t)0x8BF4AC05, (q31_t)0xC9FBE527, + (q31_t)0x8C1F3C5C, (q31_t)0xC9A0D1C4, (q31_t)0x8C4A142F, + (q31_t)0xC945DFEC, (q31_t)0x8C753361, (q31_t)0xC8EB0FD6, + (q31_t)0x8CA099D9, (q31_t)0xC89061BA, (q31_t)0x8CCC477D, + (q31_t)0xC835D5D0, (q31_t)0x8CF83C30, (q31_t)0xC7DB6C50, + (q31_t)0x8D2477D8, (q31_t)0xC7812571, (q31_t)0x8D50FA59, + (q31_t)0xC727016C, (q31_t)0x8D7DC399, (q31_t)0xC6CD0079, + (q31_t)0x8DAAD37B, (q31_t)0xC67322CD, (q31_t)0x8DD829E4, + (q31_t)0xC61968A2, (q31_t)0x8E05C6B7, (q31_t)0xC5BFD22E, + (q31_t)0x8E33A9D9, (q31_t)0xC5665FA8, (q31_t)0x8E61D32D, + (q31_t)0xC50D1148, (q31_t)0x8E904298, (q31_t)0xC4B3E746, + (q31_t)0x8EBEF7FB, (q31_t)0xC45AE1D7, (q31_t)0x8EEDF33B, + (q31_t)0xC4020132, (q31_t)0x8F1D343A, (q31_t)0xC3A9458F, + (q31_t)0x8F4CBADB, (q31_t)0xC350AF25, (q31_t)0x8F7C8701, + (q31_t)0xC2F83E2A, (q31_t)0x8FAC988E, (q31_t)0xC29FF2D4, + (q31_t)0x8FDCEF66, (q31_t)0xC247CD5A, (q31_t)0x900D8B69, + (q31_t)0xC1EFCDF2, (q31_t)0x903E6C7A, (q31_t)0xC197F4D3, + (q31_t)0x906F927B, (q31_t)0xC1404233, (q31_t)0x90A0FD4E, + (q31_t)0xC0E8B648, (q31_t)0x90D2ACD3, (q31_t)0xC0915147, + (q31_t)0x9104A0ED, (q31_t)0xC03A1368, (q31_t)0x9136D97D, + (q31_t)0xBFE2FCDF, (q31_t)0x91695663, (q31_t)0xBF8C0DE2, + (q31_t)0x919C1780, (q31_t)0xBF3546A8, (q31_t)0x91CF1CB6, + (q31_t)0xBEDEA765, (q31_t)0x920265E4, (q31_t)0xBE88304F, + (q31_t)0x9235F2EB, (q31_t)0xBE31E19B, (q31_t)0x9269C3AC, + (q31_t)0xBDDBBB7F, (q31_t)0x929DD805, (q31_t)0xBD85BE2F, + (q31_t)0x92D22FD8, (q31_t)0xBD2FE9E1, (q31_t)0x9306CB04, + (q31_t)0xBCDA3ECA, (q31_t)0x933BA968, (q31_t)0xBC84BD1E, + (q31_t)0x9370CAE4, (q31_t)0xBC2F6513, (q31_t)0x93A62F56, + (q31_t)0xBBDA36DC, (q31_t)0x93DBD69F, (q31_t)0xBB8532AF, + (q31_t)0x9411C09D, (q31_t)0xBB3058C0, (q31_t)0x9447ED2F, + (q31_t)0xBADBA943, (q31_t)0x947E5C32, (q31_t)0xBA87246C, + (q31_t)0x94B50D87, (q31_t)0xBA32CA70, (q31_t)0x94EC010B, + (q31_t)0xB9DE9B83, (q31_t)0x9523369B, (q31_t)0xB98A97D8, + (q31_t)0x955AAE17, (q31_t)0xB936BFA3, (q31_t)0x9592675B, + (q31_t)0xB8E31319, (q31_t)0x95CA6246, (q31_t)0xB88F926C, + (q31_t)0x96029EB5, (q31_t)0xB83C3DD1, (q31_t)0x963B1C85, + (q31_t)0xB7E9157A, (q31_t)0x9673DB94, (q31_t)0xB796199B, + (q31_t)0x96ACDBBD, (q31_t)0xB7434A67, (q31_t)0x96E61CDF, + (q31_t)0xB6F0A811, (q31_t)0x971F9ED6, (q31_t)0xB69E32CD, + (q31_t)0x9759617E, (q31_t)0xB64BEACC, (q31_t)0x979364B5, + (q31_t)0xB5F9D042, (q31_t)0x97CDA855, (q31_t)0xB5A7E362, + (q31_t)0x98082C3B, (q31_t)0xB556245E, (q31_t)0x9842F043, + (q31_t)0xB5049368, (q31_t)0x987DF449, (q31_t)0xB4B330B2, + (q31_t)0x98B93828, (q31_t)0xB461FC70, (q31_t)0x98F4BBBC, + (q31_t)0xB410F6D2, (q31_t)0x99307EE0, (q31_t)0xB3C0200C, + (q31_t)0x996C816F, (q31_t)0xB36F784E, (q31_t)0x99A8C344, + (q31_t)0xB31EFFCB, (q31_t)0x99E5443A, (q31_t)0xB2CEB6B5, + (q31_t)0x9A22042C, (q31_t)0xB27E9D3B, (q31_t)0x9A5F02F5, + (q31_t)0xB22EB392, (q31_t)0x9A9C406D, (q31_t)0xB1DEF9E8, + (q31_t)0x9AD9BC71, (q31_t)0xB18F7070, (q31_t)0x9B1776D9, + (q31_t)0xB140175B, (q31_t)0x9B556F80, (q31_t)0xB0F0EEDA, + (q31_t)0x9B93A640, (q31_t)0xB0A1F71C, (q31_t)0x9BD21AF2, + (q31_t)0xB0533055, (q31_t)0x9C10CD70, (q31_t)0xB0049AB2, + (q31_t)0x9C4FBD92, (q31_t)0xAFB63667, (q31_t)0x9C8EEB33, + (q31_t)0xAF6803A1, (q31_t)0x9CCE562B, (q31_t)0xAF1A0293, + (q31_t)0x9D0DFE53, (q31_t)0xAECC336B, (q31_t)0x9D4DE384, + (q31_t)0xAE7E965B, (q31_t)0x9D8E0596, (q31_t)0xAE312B91, + (q31_t)0x9DCE6462, (q31_t)0xADE3F33E, (q31_t)0x9E0EFFC1, + (q31_t)0xAD96ED91, (q31_t)0x9E4FD789, (q31_t)0xAD4A1ABA, + (q31_t)0x9E90EB94, (q31_t)0xACFD7AE8, (q31_t)0x9ED23BB9, + (q31_t)0xACB10E4A, (q31_t)0x9F13C7D0, (q31_t)0xAC64D510, + (q31_t)0x9F558FB0, (q31_t)0xAC18CF68, (q31_t)0x9F979331, + (q31_t)0xABCCFD82, (q31_t)0x9FD9D22A, (q31_t)0xAB815F8C, + (q31_t)0xA01C4C72, (q31_t)0xAB35F5B5, (q31_t)0xA05F01E1, + (q31_t)0xAAEAC02B, (q31_t)0xA0A1F24C, (q31_t)0xAA9FBF1D, + (q31_t)0xA0E51D8C, (q31_t)0xAA54F2B9, (q31_t)0xA1288376, + (q31_t)0xAA0A5B2D, (q31_t)0xA16C23E1, (q31_t)0xA9BFF8A8, + (q31_t)0xA1AFFEA2, (q31_t)0xA975CB56, (q31_t)0xA1F41391, + (q31_t)0xA92BD366, (q31_t)0xA2386283, (q31_t)0xA8E21106, + (q31_t)0xA27CEB4F, (q31_t)0xA8988463, (q31_t)0xA2C1ADC9, + (q31_t)0xA84F2DA9, (q31_t)0xA306A9C7, (q31_t)0xA8060D08, + (q31_t)0xA34BDF20, (q31_t)0xA7BD22AB, (q31_t)0xA3914DA7, + (q31_t)0xA7746EC0, (q31_t)0xA3D6F533, (q31_t)0xA72BF173, + (q31_t)0xA41CD598, (q31_t)0xA6E3AAF2, (q31_t)0xA462EEAC, + (q31_t)0xA69B9B68, (q31_t)0xA4A94042, (q31_t)0xA653C302, + (q31_t)0xA4EFCA31, (q31_t)0xA60C21ED, (q31_t)0xA5368C4B, + (q31_t)0xA5C4B855, (q31_t)0xA57D8666, (q31_t)0xA57D8666, + (q31_t)0xA5C4B855, (q31_t)0xA5368C4B, (q31_t)0xA60C21ED, + (q31_t)0xA4EFCA31, (q31_t)0xA653C302, (q31_t)0xA4A94042, + (q31_t)0xA69B9B68, (q31_t)0xA462EEAC, (q31_t)0xA6E3AAF2, + (q31_t)0xA41CD598, (q31_t)0xA72BF173, (q31_t)0xA3D6F533, + (q31_t)0xA7746EC0, (q31_t)0xA3914DA7, (q31_t)0xA7BD22AB, + (q31_t)0xA34BDF20, (q31_t)0xA8060D08, (q31_t)0xA306A9C7, + (q31_t)0xA84F2DA9, (q31_t)0xA2C1ADC9, (q31_t)0xA8988463, + (q31_t)0xA27CEB4F, (q31_t)0xA8E21106, (q31_t)0xA2386283, + (q31_t)0xA92BD366, (q31_t)0xA1F41391, (q31_t)0xA975CB56, + (q31_t)0xA1AFFEA2, (q31_t)0xA9BFF8A8, (q31_t)0xA16C23E1, + (q31_t)0xAA0A5B2D, (q31_t)0xA1288376, (q31_t)0xAA54F2B9, + (q31_t)0xA0E51D8C, (q31_t)0xAA9FBF1D, (q31_t)0xA0A1F24C, + (q31_t)0xAAEAC02B, (q31_t)0xA05F01E1, (q31_t)0xAB35F5B5, + (q31_t)0xA01C4C72, (q31_t)0xAB815F8C, (q31_t)0x9FD9D22A, + (q31_t)0xABCCFD82, (q31_t)0x9F979331, (q31_t)0xAC18CF68, + (q31_t)0x9F558FB0, (q31_t)0xAC64D510, (q31_t)0x9F13C7D0, + (q31_t)0xACB10E4A, (q31_t)0x9ED23BB9, (q31_t)0xACFD7AE8, + (q31_t)0x9E90EB94, (q31_t)0xAD4A1ABA, (q31_t)0x9E4FD789, + (q31_t)0xAD96ED91, (q31_t)0x9E0EFFC1, (q31_t)0xADE3F33E, + (q31_t)0x9DCE6462, (q31_t)0xAE312B91, (q31_t)0x9D8E0596, + (q31_t)0xAE7E965B, (q31_t)0x9D4DE384, (q31_t)0xAECC336B, + (q31_t)0x9D0DFE53, (q31_t)0xAF1A0293, (q31_t)0x9CCE562B, + (q31_t)0xAF6803A1, (q31_t)0x9C8EEB33, (q31_t)0xAFB63667, + (q31_t)0x9C4FBD92, (q31_t)0xB0049AB2, (q31_t)0x9C10CD70, + (q31_t)0xB0533055, (q31_t)0x9BD21AF2, (q31_t)0xB0A1F71C, + (q31_t)0x9B93A640, (q31_t)0xB0F0EEDA, (q31_t)0x9B556F80, + (q31_t)0xB140175B, (q31_t)0x9B1776D9, (q31_t)0xB18F7070, + (q31_t)0x9AD9BC71, (q31_t)0xB1DEF9E8, (q31_t)0x9A9C406D, + (q31_t)0xB22EB392, (q31_t)0x9A5F02F5, (q31_t)0xB27E9D3B, + (q31_t)0x9A22042C, (q31_t)0xB2CEB6B5, (q31_t)0x99E5443A, + (q31_t)0xB31EFFCB, (q31_t)0x99A8C344, (q31_t)0xB36F784E, + (q31_t)0x996C816F, (q31_t)0xB3C0200C, (q31_t)0x99307EE0, + (q31_t)0xB410F6D2, (q31_t)0x98F4BBBC, (q31_t)0xB461FC70, + (q31_t)0x98B93828, (q31_t)0xB4B330B2, (q31_t)0x987DF449, + (q31_t)0xB5049368, (q31_t)0x9842F043, (q31_t)0xB556245E, + (q31_t)0x98082C3B, (q31_t)0xB5A7E362, (q31_t)0x97CDA855, + (q31_t)0xB5F9D042, (q31_t)0x979364B5, (q31_t)0xB64BEACC, + (q31_t)0x9759617E, (q31_t)0xB69E32CD, (q31_t)0x971F9ED6, + (q31_t)0xB6F0A811, (q31_t)0x96E61CDF, (q31_t)0xB7434A67, + (q31_t)0x96ACDBBD, (q31_t)0xB796199B, (q31_t)0x9673DB94, + (q31_t)0xB7E9157A, (q31_t)0x963B1C85, (q31_t)0xB83C3DD1, + (q31_t)0x96029EB5, (q31_t)0xB88F926C, (q31_t)0x95CA6246, + (q31_t)0xB8E31319, (q31_t)0x9592675B, (q31_t)0xB936BFA3, + (q31_t)0x955AAE17, (q31_t)0xB98A97D8, (q31_t)0x9523369B, + (q31_t)0xB9DE9B83, (q31_t)0x94EC010B, (q31_t)0xBA32CA70, + (q31_t)0x94B50D87, (q31_t)0xBA87246C, (q31_t)0x947E5C32, + (q31_t)0xBADBA943, (q31_t)0x9447ED2F, (q31_t)0xBB3058C0, + (q31_t)0x9411C09D, (q31_t)0xBB8532AF, (q31_t)0x93DBD69F, + (q31_t)0xBBDA36DC, (q31_t)0x93A62F56, (q31_t)0xBC2F6513, + (q31_t)0x9370CAE4, (q31_t)0xBC84BD1E, (q31_t)0x933BA968, + (q31_t)0xBCDA3ECA, (q31_t)0x9306CB04, (q31_t)0xBD2FE9E1, + (q31_t)0x92D22FD8, (q31_t)0xBD85BE2F, (q31_t)0x929DD805, + (q31_t)0xBDDBBB7F, (q31_t)0x9269C3AC, (q31_t)0xBE31E19B, + (q31_t)0x9235F2EB, (q31_t)0xBE88304F, (q31_t)0x920265E4, + (q31_t)0xBEDEA765, (q31_t)0x91CF1CB6, (q31_t)0xBF3546A8, + (q31_t)0x919C1780, (q31_t)0xBF8C0DE2, (q31_t)0x91695663, + (q31_t)0xBFE2FCDF, (q31_t)0x9136D97D, (q31_t)0xC03A1368, + (q31_t)0x9104A0ED, (q31_t)0xC0915147, (q31_t)0x90D2ACD3, + (q31_t)0xC0E8B648, (q31_t)0x90A0FD4E, (q31_t)0xC1404233, + (q31_t)0x906F927B, (q31_t)0xC197F4D3, (q31_t)0x903E6C7A, + (q31_t)0xC1EFCDF2, (q31_t)0x900D8B69, (q31_t)0xC247CD5A, + (q31_t)0x8FDCEF66, (q31_t)0xC29FF2D4, (q31_t)0x8FAC988E, + (q31_t)0xC2F83E2A, (q31_t)0x8F7C8701, (q31_t)0xC350AF25, + (q31_t)0x8F4CBADB, (q31_t)0xC3A9458F, (q31_t)0x8F1D343A, + (q31_t)0xC4020132, (q31_t)0x8EEDF33B, (q31_t)0xC45AE1D7, + (q31_t)0x8EBEF7FB, (q31_t)0xC4B3E746, (q31_t)0x8E904298, + (q31_t)0xC50D1148, (q31_t)0x8E61D32D, (q31_t)0xC5665FA8, + (q31_t)0x8E33A9D9, (q31_t)0xC5BFD22E, (q31_t)0x8E05C6B7, + (q31_t)0xC61968A2, (q31_t)0x8DD829E4, (q31_t)0xC67322CD, + (q31_t)0x8DAAD37B, (q31_t)0xC6CD0079, (q31_t)0x8D7DC399, + (q31_t)0xC727016C, (q31_t)0x8D50FA59, (q31_t)0xC7812571, + (q31_t)0x8D2477D8, (q31_t)0xC7DB6C50, (q31_t)0x8CF83C30, + (q31_t)0xC835D5D0, (q31_t)0x8CCC477D, (q31_t)0xC89061BA, + (q31_t)0x8CA099D9, (q31_t)0xC8EB0FD6, (q31_t)0x8C753361, + (q31_t)0xC945DFEC, (q31_t)0x8C4A142F, (q31_t)0xC9A0D1C4, + (q31_t)0x8C1F3C5C, (q31_t)0xC9FBE527, (q31_t)0x8BF4AC05, + (q31_t)0xCA5719DB, (q31_t)0x8BCA6342, (q31_t)0xCAB26FA9, + (q31_t)0x8BA0622F, (q31_t)0xCB0DE658, (q31_t)0x8B76A8E4, + (q31_t)0xCB697DB0, (q31_t)0x8B4D377C, (q31_t)0xCBC53578, + (q31_t)0x8B240E10, (q31_t)0xCC210D78, (q31_t)0x8AFB2CBA, + (q31_t)0xCC7D0577, (q31_t)0x8AD29393, (q31_t)0xCCD91D3D, + (q31_t)0x8AAA42B4, (q31_t)0xCD355490, (q31_t)0x8A823A35, + (q31_t)0xCD91AB38, (q31_t)0x8A5A7A30, (q31_t)0xCDEE20FC, + (q31_t)0x8A3302BD, (q31_t)0xCE4AB5A2, (q31_t)0x8A0BD3F5, + (q31_t)0xCEA768F2, (q31_t)0x89E4EDEE, (q31_t)0xCF043AB2, + (q31_t)0x89BE50C3, (q31_t)0xCF612AAA, (q31_t)0x8997FC89, + (q31_t)0xCFBE389F, (q31_t)0x8971F15A, (q31_t)0xD01B6459, + (q31_t)0x894C2F4C, (q31_t)0xD078AD9D, (q31_t)0x8926B677, + (q31_t)0xD0D61433, (q31_t)0x890186F1, (q31_t)0xD13397E1, + (q31_t)0x88DCA0D3, (q31_t)0xD191386D, (q31_t)0x88B80431, + (q31_t)0xD1EEF59E, (q31_t)0x8893B124, (q31_t)0xD24CCF38, + (q31_t)0x886FA7C2, (q31_t)0xD2AAC504, (q31_t)0x884BE820, + (q31_t)0xD308D6C6, (q31_t)0x88287255, (q31_t)0xD3670445, + (q31_t)0x88054677, (q31_t)0xD3C54D46, (q31_t)0x87E2649B, + (q31_t)0xD423B190, (q31_t)0x87BFCCD7, (q31_t)0xD48230E8, + (q31_t)0x879D7F40, (q31_t)0xD4E0CB14, (q31_t)0x877B7BEC, + (q31_t)0xD53F7FDA, (q31_t)0x8759C2EF, (q31_t)0xD59E4EFE, + (q31_t)0x8738545E, (q31_t)0xD5FD3847, (q31_t)0x8717304E, + (q31_t)0xD65C3B7B, (q31_t)0x86F656D3, (q31_t)0xD6BB585D, + (q31_t)0x86D5C802, (q31_t)0xD71A8EB5, (q31_t)0x86B583EE, + (q31_t)0xD779DE46, (q31_t)0x86958AAB, (q31_t)0xD7D946D7, + (q31_t)0x8675DC4E, (q31_t)0xD838C82D, (q31_t)0x865678EA, + (q31_t)0xD898620C, (q31_t)0x86376092, (q31_t)0xD8F81439, + (q31_t)0x86189359, (q31_t)0xD957DE7A, (q31_t)0x85FA1152, + (q31_t)0xD9B7C093, (q31_t)0x85DBDA91, (q31_t)0xDA17BA4A, + (q31_t)0x85BDEF27, (q31_t)0xDA77CB62, (q31_t)0x85A04F28, + (q31_t)0xDAD7F3A2, (q31_t)0x8582FAA4, (q31_t)0xDB3832CD, + (q31_t)0x8565F1B0, (q31_t)0xDB9888A8, (q31_t)0x8549345C, + (q31_t)0xDBF8F4F8, (q31_t)0x852CC2BA, (q31_t)0xDC597781, + (q31_t)0x85109CDC, (q31_t)0xDCBA1008, (q31_t)0x84F4C2D3, + (q31_t)0xDD1ABE51, (q31_t)0x84D934B0, (q31_t)0xDD7B8220, + (q31_t)0x84BDF285, (q31_t)0xDDDC5B3A, (q31_t)0x84A2FC62, + (q31_t)0xDE3D4963, (q31_t)0x84885257, (q31_t)0xDE9E4C60, + (q31_t)0x846DF476, (q31_t)0xDEFF63F4, (q31_t)0x8453E2CE, + (q31_t)0xDF608FE3, (q31_t)0x843A1D70, (q31_t)0xDFC1CFF2, + (q31_t)0x8420A46B, (q31_t)0xE02323E5, (q31_t)0x840777CF, + (q31_t)0xE0848B7F, (q31_t)0x83EE97AC, (q31_t)0xE0E60684, + (q31_t)0x83D60411, (q31_t)0xE14794B9, (q31_t)0x83BDBD0D, + (q31_t)0xE1A935E1, (q31_t)0x83A5C2B0, (q31_t)0xE20AE9C1, + (q31_t)0x838E1507, (q31_t)0xE26CB01A, (q31_t)0x8376B422, + (q31_t)0xE2CE88B2, (q31_t)0x835FA00E, (q31_t)0xE330734C, + (q31_t)0x8348D8DB, (q31_t)0xE3926FAC, (q31_t)0x83325E97, + (q31_t)0xE3F47D95, (q31_t)0x831C314E, (q31_t)0xE4569CCB, + (q31_t)0x8306510F, (q31_t)0xE4B8CD10, (q31_t)0x82F0BDE8, + (q31_t)0xE51B0E2A, (q31_t)0x82DB77E5, (q31_t)0xE57D5FDA, + (q31_t)0x82C67F13, (q31_t)0xE5DFC1E4, (q31_t)0x82B1D381, + (q31_t)0xE642340D, (q31_t)0x829D753A, (q31_t)0xE6A4B616, + (q31_t)0x8289644A, (q31_t)0xE70747C3, (q31_t)0x8275A0C0, + (q31_t)0xE769E8D8, (q31_t)0x82622AA5, (q31_t)0xE7CC9917, + (q31_t)0x824F0208, (q31_t)0xE82F5844, (q31_t)0x823C26F2, + (q31_t)0xE8922621, (q31_t)0x82299971, (q31_t)0xE8F50273, + (q31_t)0x8217598F, (q31_t)0xE957ECFB, (q31_t)0x82056758, + (q31_t)0xE9BAE57C, (q31_t)0x81F3C2D7, (q31_t)0xEA1DEBBB, + (q31_t)0x81E26C16, (q31_t)0xEA80FF79, (q31_t)0x81D16320, + (q31_t)0xEAE4207A, (q31_t)0x81C0A801, (q31_t)0xEB474E80, + (q31_t)0x81B03AC1, (q31_t)0xEBAA894E, (q31_t)0x81A01B6C, + (q31_t)0xEC0DD0A8, (q31_t)0x81904A0C, (q31_t)0xEC71244F, + (q31_t)0x8180C6A9, (q31_t)0xECD48406, (q31_t)0x8171914E, + (q31_t)0xED37EF91, (q31_t)0x8162AA03, (q31_t)0xED9B66B2, + (q31_t)0x815410D3, (q31_t)0xEDFEE92B, (q31_t)0x8145C5C6, + (q31_t)0xEE6276BF, (q31_t)0x8137C8E6, (q31_t)0xEEC60F31, + (q31_t)0x812A1A39, (q31_t)0xEF29B243, (q31_t)0x811CB9CA, + (q31_t)0xEF8D5FB8, (q31_t)0x810FA7A0, (q31_t)0xEFF11752, + (q31_t)0x8102E3C3, (q31_t)0xF054D8D4, (q31_t)0x80F66E3C, + (q31_t)0xF0B8A401, (q31_t)0x80EA4712, (q31_t)0xF11C789A, + (q31_t)0x80DE6E4C, (q31_t)0xF1805662, (q31_t)0x80D2E3F1, + (q31_t)0xF1E43D1C, (q31_t)0x80C7A80A, (q31_t)0xF2482C89, + (q31_t)0x80BCBA9C, (q31_t)0xF2AC246D, (q31_t)0x80B21BAF, + (q31_t)0xF310248A, (q31_t)0x80A7CB49, (q31_t)0xF3742CA1, + (q31_t)0x809DC970, (q31_t)0xF3D83C76, (q31_t)0x8094162B, + (q31_t)0xF43C53CA, (q31_t)0x808AB180, (q31_t)0xF4A07260, + (q31_t)0x80819B74, (q31_t)0xF50497FA, (q31_t)0x8078D40D, + (q31_t)0xF568C45A, (q31_t)0x80705B50, (q31_t)0xF5CCF743, + (q31_t)0x80683143, (q31_t)0xF6313076, (q31_t)0x806055EA, + (q31_t)0xF6956FB6, (q31_t)0x8058C94C, (q31_t)0xF6F9B4C5, + (q31_t)0x80518B6B, (q31_t)0xF75DFF65, (q31_t)0x804A9C4D, + (q31_t)0xF7C24F58, (q31_t)0x8043FBF6, (q31_t)0xF826A461, + (q31_t)0x803DAA69, (q31_t)0xF88AFE41, (q31_t)0x8037A7AC, + (q31_t)0xF8EF5CBB, (q31_t)0x8031F3C1, (q31_t)0xF953BF90, + (q31_t)0x802C8EAD, (q31_t)0xF9B82683, (q31_t)0x80277872, + (q31_t)0xFA1C9156, (q31_t)0x8022B113, (q31_t)0xFA80FFCB, + (q31_t)0x801E3894, (q31_t)0xFAE571A4, (q31_t)0x801A0EF7, + (q31_t)0xFB49E6A2, (q31_t)0x80163440, (q31_t)0xFBAE5E89, + (q31_t)0x8012A86F, (q31_t)0xFC12D919, (q31_t)0x800F6B88, + (q31_t)0xFC775616, (q31_t)0x800C7D8C, (q31_t)0xFCDBD541, + (q31_t)0x8009DE7D, (q31_t)0xFD40565B, (q31_t)0x80078E5E, + (q31_t)0xFDA4D928, (q31_t)0x80058D2E, (q31_t)0xFE095D69, + (q31_t)0x8003DAF0, (q31_t)0xFE6DE2E0, (q31_t)0x800277A5, + (q31_t)0xFED2694F, (q31_t)0x8001634D, (q31_t)0xFF36F078, + (q31_t)0x80009DE9, (q31_t)0xFF9B781D, (q31_t)0x8000277A +}; + +/** +* \par +* Example code for Q31 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefQ31[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefQ31[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 4096 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to Q31(Fixed point 1.31): +* round(twiddleCoefQ31(i) * pow(2, 31)) +* +*/ +const q31_t twiddleCoef_4096_q31[6144] = +{ + (q31_t)0x7FFFFFFF, (q31_t)0x00000000, (q31_t)0x7FFFF621, + (q31_t)0x003243F5, (q31_t)0x7FFFD885, (q31_t)0x006487E3, + (q31_t)0x7FFFA72C, (q31_t)0x0096CBC1, (q31_t)0x7FFF6216, + (q31_t)0x00C90F88, (q31_t)0x7FFF0942, (q31_t)0x00FB532F, + (q31_t)0x7FFE9CB2, (q31_t)0x012D96B0, (q31_t)0x7FFE1C64, + (q31_t)0x015FDA03, (q31_t)0x7FFD885A, (q31_t)0x01921D1F, + (q31_t)0x7FFCE093, (q31_t)0x01C45FFE, (q31_t)0x7FFC250F, + (q31_t)0x01F6A296, (q31_t)0x7FFB55CE, (q31_t)0x0228E4E1, + (q31_t)0x7FFA72D1, (q31_t)0x025B26D7, (q31_t)0x7FF97C17, + (q31_t)0x028D6870, (q31_t)0x7FF871A1, (q31_t)0x02BFA9A4, + (q31_t)0x7FF7536F, (q31_t)0x02F1EA6B, (q31_t)0x7FF62182, + (q31_t)0x03242ABF, (q31_t)0x7FF4DBD8, (q31_t)0x03566A96, + (q31_t)0x7FF38273, (q31_t)0x0388A9E9, (q31_t)0x7FF21553, + (q31_t)0x03BAE8B1, (q31_t)0x7FF09477, (q31_t)0x03ED26E6, + (q31_t)0x7FEEFFE1, (q31_t)0x041F647F, (q31_t)0x7FED5790, + (q31_t)0x0451A176, (q31_t)0x7FEB9B85, (q31_t)0x0483DDC3, + (q31_t)0x7FE9CBC0, (q31_t)0x04B6195D, (q31_t)0x7FE7E840, + (q31_t)0x04E8543D, (q31_t)0x7FE5F108, (q31_t)0x051A8E5C, + (q31_t)0x7FE3E616, (q31_t)0x054CC7B0, (q31_t)0x7FE1C76B, + (q31_t)0x057F0034, (q31_t)0x7FDF9508, (q31_t)0x05B137DF, + (q31_t)0x7FDD4EEC, (q31_t)0x05E36EA9, (q31_t)0x7FDAF518, + (q31_t)0x0615A48A, (q31_t)0x7FD8878D, (q31_t)0x0647D97C, + (q31_t)0x7FD6064B, (q31_t)0x067A0D75, (q31_t)0x7FD37152, + (q31_t)0x06AC406F, (q31_t)0x7FD0C8A3, (q31_t)0x06DE7261, + (q31_t)0x7FCE0C3E, (q31_t)0x0710A344, (q31_t)0x7FCB3C23, + (q31_t)0x0742D310, (q31_t)0x7FC85853, (q31_t)0x077501BE, + (q31_t)0x7FC560CF, (q31_t)0x07A72F45, (q31_t)0x7FC25596, + (q31_t)0x07D95B9E, (q31_t)0x7FBF36A9, (q31_t)0x080B86C1, + (q31_t)0x7FBC040A, (q31_t)0x083DB0A7, (q31_t)0x7FB8BDB7, + (q31_t)0x086FD947, (q31_t)0x7FB563B2, (q31_t)0x08A2009A, + (q31_t)0x7FB1F5FC, (q31_t)0x08D42698, (q31_t)0x7FAE7494, + (q31_t)0x09064B3A, (q31_t)0x7FAADF7C, (q31_t)0x09386E77, + (q31_t)0x7FA736B4, (q31_t)0x096A9049, (q31_t)0x7FA37A3C, + (q31_t)0x099CB0A7, (q31_t)0x7F9FAA15, (q31_t)0x09CECF89, + (q31_t)0x7F9BC63F, (q31_t)0x0A00ECE8, (q31_t)0x7F97CEBC, + (q31_t)0x0A3308BC, (q31_t)0x7F93C38C, (q31_t)0x0A6522FE, + (q31_t)0x7F8FA4AF, (q31_t)0x0A973BA5, (q31_t)0x7F8B7226, + (q31_t)0x0AC952AA, (q31_t)0x7F872BF3, (q31_t)0x0AFB6805, + (q31_t)0x7F82D214, (q31_t)0x0B2D7BAE, (q31_t)0x7F7E648B, + (q31_t)0x0B5F8D9F, (q31_t)0x7F79E35A, (q31_t)0x0B919DCE, + (q31_t)0x7F754E7F, (q31_t)0x0BC3AC35, (q31_t)0x7F70A5FD, + (q31_t)0x0BF5B8CB, (q31_t)0x7F6BE9D4, (q31_t)0x0C27C389, + (q31_t)0x7F671A04, (q31_t)0x0C59CC67, (q31_t)0x7F62368F, + (q31_t)0x0C8BD35E, (q31_t)0x7F5D3F75, (q31_t)0x0CBDD865, + (q31_t)0x7F5834B6, (q31_t)0x0CEFDB75, (q31_t)0x7F531654, + (q31_t)0x0D21DC87, (q31_t)0x7F4DE450, (q31_t)0x0D53DB92, + (q31_t)0x7F489EAA, (q31_t)0x0D85D88F, (q31_t)0x7F434563, + (q31_t)0x0DB7D376, (q31_t)0x7F3DD87C, (q31_t)0x0DE9CC3F, + (q31_t)0x7F3857F5, (q31_t)0x0E1BC2E3, (q31_t)0x7F32C3D0, + (q31_t)0x0E4DB75B, (q31_t)0x7F2D1C0E, (q31_t)0x0E7FA99D, + (q31_t)0x7F2760AF, (q31_t)0x0EB199A3, (q31_t)0x7F2191B4, + (q31_t)0x0EE38765, (q31_t)0x7F1BAF1E, (q31_t)0x0F1572DC, + (q31_t)0x7F15B8EE, (q31_t)0x0F475BFE, (q31_t)0x7F0FAF24, + (q31_t)0x0F7942C6, (q31_t)0x7F0991C3, (q31_t)0x0FAB272B, + (q31_t)0x7F0360CB, (q31_t)0x0FDD0925, (q31_t)0x7EFD1C3C, + (q31_t)0x100EE8AD, (q31_t)0x7EF6C418, (q31_t)0x1040C5BB, + (q31_t)0x7EF0585F, (q31_t)0x1072A047, (q31_t)0x7EE9D913, + (q31_t)0x10A4784A, (q31_t)0x7EE34635, (q31_t)0x10D64DBC, + (q31_t)0x7EDC9FC6, (q31_t)0x11082096, (q31_t)0x7ED5E5C6, + (q31_t)0x1139F0CE, (q31_t)0x7ECF1837, (q31_t)0x116BBE5F, + (q31_t)0x7EC8371A, (q31_t)0x119D8940, (q31_t)0x7EC1426F, + (q31_t)0x11CF516A, (q31_t)0x7EBA3A39, (q31_t)0x120116D4, + (q31_t)0x7EB31E77, (q31_t)0x1232D978, (q31_t)0x7EABEF2C, + (q31_t)0x1264994E, (q31_t)0x7EA4AC58, (q31_t)0x1296564D, + (q31_t)0x7E9D55FC, (q31_t)0x12C8106E, (q31_t)0x7E95EC19, + (q31_t)0x12F9C7AA, (q31_t)0x7E8E6EB1, (q31_t)0x132B7BF9, + (q31_t)0x7E86DDC5, (q31_t)0x135D2D53, (q31_t)0x7E7F3956, + (q31_t)0x138EDBB0, (q31_t)0x7E778165, (q31_t)0x13C0870A, + (q31_t)0x7E6FB5F3, (q31_t)0x13F22F57, (q31_t)0x7E67D702, + (q31_t)0x1423D492, (q31_t)0x7E5FE493, (q31_t)0x145576B1, + (q31_t)0x7E57DEA6, (q31_t)0x148715AD, (q31_t)0x7E4FC53E, + (q31_t)0x14B8B17F, (q31_t)0x7E47985B, (q31_t)0x14EA4A1F, + (q31_t)0x7E3F57FE, (q31_t)0x151BDF85, (q31_t)0x7E37042A, + (q31_t)0x154D71AA, (q31_t)0x7E2E9CDF, (q31_t)0x157F0086, + (q31_t)0x7E26221E, (q31_t)0x15B08C11, (q31_t)0x7E1D93E9, + (q31_t)0x15E21444, (q31_t)0x7E14F242, (q31_t)0x16139917, + (q31_t)0x7E0C3D29, (q31_t)0x16451A83, (q31_t)0x7E03749F, + (q31_t)0x1676987F, (q31_t)0x7DFA98A7, (q31_t)0x16A81305, + (q31_t)0x7DF1A942, (q31_t)0x16D98A0C, (q31_t)0x7DE8A670, + (q31_t)0x170AFD8D, (q31_t)0x7DDF9034, (q31_t)0x173C6D80, + (q31_t)0x7DD6668E, (q31_t)0x176DD9DE, (q31_t)0x7DCD2981, + (q31_t)0x179F429F, (q31_t)0x7DC3D90D, (q31_t)0x17D0A7BB, + (q31_t)0x7DBA7534, (q31_t)0x1802092C, (q31_t)0x7DB0FDF7, + (q31_t)0x183366E8, (q31_t)0x7DA77359, (q31_t)0x1864C0E9, + (q31_t)0x7D9DD55A, (q31_t)0x18961727, (q31_t)0x7D9423FB, + (q31_t)0x18C7699B, (q31_t)0x7D8A5F3F, (q31_t)0x18F8B83C, + (q31_t)0x7D808727, (q31_t)0x192A0303, (q31_t)0x7D769BB5, + (q31_t)0x195B49E9, (q31_t)0x7D6C9CE9, (q31_t)0x198C8CE6, + (q31_t)0x7D628AC5, (q31_t)0x19BDCBF2, (q31_t)0x7D58654C, + (q31_t)0x19EF0706, (q31_t)0x7D4E2C7E, (q31_t)0x1A203E1B, + (q31_t)0x7D43E05E, (q31_t)0x1A517127, (q31_t)0x7D3980EC, + (q31_t)0x1A82A025, (q31_t)0x7D2F0E2A, (q31_t)0x1AB3CB0C, + (q31_t)0x7D24881A, (q31_t)0x1AE4F1D6, (q31_t)0x7D19EEBE, + (q31_t)0x1B161479, (q31_t)0x7D0F4218, (q31_t)0x1B4732EF, + (q31_t)0x7D048228, (q31_t)0x1B784D30, (q31_t)0x7CF9AEF0, + (q31_t)0x1BA96334, (q31_t)0x7CEEC873, (q31_t)0x1BDA74F5, + (q31_t)0x7CE3CEB1, (q31_t)0x1C0B826A, (q31_t)0x7CD8C1AD, + (q31_t)0x1C3C8B8C, (q31_t)0x7CCDA168, (q31_t)0x1C6D9053, + (q31_t)0x7CC26DE5, (q31_t)0x1C9E90B8, (q31_t)0x7CB72724, + (q31_t)0x1CCF8CB3, (q31_t)0x7CABCD27, (q31_t)0x1D00843C, + (q31_t)0x7CA05FF1, (q31_t)0x1D31774D, (q31_t)0x7C94DF82, + (q31_t)0x1D6265DD, (q31_t)0x7C894BDD, (q31_t)0x1D934FE5, + (q31_t)0x7C7DA504, (q31_t)0x1DC4355D, (q31_t)0x7C71EAF8, + (q31_t)0x1DF5163F, (q31_t)0x7C661DBB, (q31_t)0x1E25F281, + (q31_t)0x7C5A3D4F, (q31_t)0x1E56CA1E, (q31_t)0x7C4E49B6, + (q31_t)0x1E879D0C, (q31_t)0x7C4242F2, (q31_t)0x1EB86B46, + (q31_t)0x7C362904, (q31_t)0x1EE934C2, (q31_t)0x7C29FBEE, + (q31_t)0x1F19F97B, (q31_t)0x7C1DBBB2, (q31_t)0x1F4AB967, + (q31_t)0x7C116853, (q31_t)0x1F7B7480, (q31_t)0x7C0501D1, + (q31_t)0x1FAC2ABF, (q31_t)0x7BF88830, (q31_t)0x1FDCDC1A, + (q31_t)0x7BEBFB70, (q31_t)0x200D888C, (q31_t)0x7BDF5B94, + (q31_t)0x203E300D, (q31_t)0x7BD2A89E, (q31_t)0x206ED295, + (q31_t)0x7BC5E28F, (q31_t)0x209F701C, (q31_t)0x7BB9096A, + (q31_t)0x20D0089B, (q31_t)0x7BAC1D31, (q31_t)0x21009C0B, + (q31_t)0x7B9F1DE5, (q31_t)0x21312A65, (q31_t)0x7B920B89, + (q31_t)0x2161B39F, (q31_t)0x7B84E61E, (q31_t)0x219237B4, + (q31_t)0x7B77ADA8, (q31_t)0x21C2B69C, (q31_t)0x7B6A6227, + (q31_t)0x21F3304E, (q31_t)0x7B5D039D, (q31_t)0x2223A4C5, + (q31_t)0x7B4F920E, (q31_t)0x225413F8, (q31_t)0x7B420D7A, + (q31_t)0x22847DDF, (q31_t)0x7B3475E4, (q31_t)0x22B4E274, + (q31_t)0x7B26CB4F, (q31_t)0x22E541AE, (q31_t)0x7B190DBB, + (q31_t)0x23159B87, (q31_t)0x7B0B3D2C, (q31_t)0x2345EFF7, + (q31_t)0x7AFD59A3, (q31_t)0x23763EF7, (q31_t)0x7AEF6323, + (q31_t)0x23A6887E, (q31_t)0x7AE159AE, (q31_t)0x23D6CC86, + (q31_t)0x7AD33D45, (q31_t)0x24070B07, (q31_t)0x7AC50DEB, + (q31_t)0x243743FA, (q31_t)0x7AB6CBA3, (q31_t)0x24677757, + (q31_t)0x7AA8766E, (q31_t)0x2497A517, (q31_t)0x7A9A0E4F, + (q31_t)0x24C7CD32, (q31_t)0x7A8B9348, (q31_t)0x24F7EFA1, + (q31_t)0x7A7D055B, (q31_t)0x25280C5D, (q31_t)0x7A6E648A, + (q31_t)0x2558235E, (q31_t)0x7A5FB0D8, (q31_t)0x2588349D, + (q31_t)0x7A50EA46, (q31_t)0x25B84012, (q31_t)0x7A4210D8, + (q31_t)0x25E845B5, (q31_t)0x7A33248F, (q31_t)0x26184581, + (q31_t)0x7A24256E, (q31_t)0x26483F6C, (q31_t)0x7A151377, + (q31_t)0x26783370, (q31_t)0x7A05EEAD, (q31_t)0x26A82185, + (q31_t)0x79F6B711, (q31_t)0x26D809A5, (q31_t)0x79E76CA6, + (q31_t)0x2707EBC6, (q31_t)0x79D80F6F, (q31_t)0x2737C7E3, + (q31_t)0x79C89F6D, (q31_t)0x27679DF4, (q31_t)0x79B91CA4, + (q31_t)0x27976DF1, (q31_t)0x79A98715, (q31_t)0x27C737D2, + (q31_t)0x7999DEC3, (q31_t)0x27F6FB92, (q31_t)0x798A23B1, + (q31_t)0x2826B928, (q31_t)0x797A55E0, (q31_t)0x2856708C, + (q31_t)0x796A7554, (q31_t)0x288621B9, (q31_t)0x795A820E, + (q31_t)0x28B5CCA5, (q31_t)0x794A7C11, (q31_t)0x28E5714A, + (q31_t)0x793A6360, (q31_t)0x29150FA1, (q31_t)0x792A37FE, + (q31_t)0x2944A7A2, (q31_t)0x7919F9EB, (q31_t)0x29743945, + (q31_t)0x7909A92C, (q31_t)0x29A3C484, (q31_t)0x78F945C3, + (q31_t)0x29D34958, (q31_t)0x78E8CFB1, (q31_t)0x2A02C7B8, + (q31_t)0x78D846FB, (q31_t)0x2A323F9D, (q31_t)0x78C7ABA1, + (q31_t)0x2A61B101, (q31_t)0x78B6FDA8, (q31_t)0x2A911BDB, + (q31_t)0x78A63D10, (q31_t)0x2AC08025, (q31_t)0x789569DE, + (q31_t)0x2AEFDDD8, (q31_t)0x78848413, (q31_t)0x2B1F34EB, + (q31_t)0x78738BB3, (q31_t)0x2B4E8558, (q31_t)0x786280BF, + (q31_t)0x2B7DCF17, (q31_t)0x7851633B, (q31_t)0x2BAD1221, + (q31_t)0x78403328, (q31_t)0x2BDC4E6F, (q31_t)0x782EF08B, + (q31_t)0x2C0B83F9, (q31_t)0x781D9B64, (q31_t)0x2C3AB2B9, + (q31_t)0x780C33B8, (q31_t)0x2C69DAA6, (q31_t)0x77FAB988, + (q31_t)0x2C98FBBA, (q31_t)0x77E92CD8, (q31_t)0x2CC815ED, + (q31_t)0x77D78DAA, (q31_t)0x2CF72939, (q31_t)0x77C5DC01, + (q31_t)0x2D263595, (q31_t)0x77B417DF, (q31_t)0x2D553AFB, + (q31_t)0x77A24148, (q31_t)0x2D843963, (q31_t)0x7790583D, + (q31_t)0x2DB330C7, (q31_t)0x777E5CC3, (q31_t)0x2DE2211E, + (q31_t)0x776C4EDB, (q31_t)0x2E110A62, (q31_t)0x775A2E88, + (q31_t)0x2E3FEC8B, (q31_t)0x7747FBCE, (q31_t)0x2E6EC792, + (q31_t)0x7735B6AE, (q31_t)0x2E9D9B70, (q31_t)0x77235F2D, + (q31_t)0x2ECC681E, (q31_t)0x7710F54B, (q31_t)0x2EFB2D94, + (q31_t)0x76FE790E, (q31_t)0x2F29EBCC, (q31_t)0x76EBEA77, + (q31_t)0x2F58A2BD, (q31_t)0x76D94988, (q31_t)0x2F875262, + (q31_t)0x76C69646, (q31_t)0x2FB5FAB2, (q31_t)0x76B3D0B3, + (q31_t)0x2FE49BA6, (q31_t)0x76A0F8D2, (q31_t)0x30133538, + (q31_t)0x768E0EA5, (q31_t)0x3041C760, (q31_t)0x767B1230, + (q31_t)0x30705217, (q31_t)0x76680376, (q31_t)0x309ED555, + (q31_t)0x7654E279, (q31_t)0x30CD5114, (q31_t)0x7641AF3C, + (q31_t)0x30FBC54D, (q31_t)0x762E69C3, (q31_t)0x312A31F8, + (q31_t)0x761B1211, (q31_t)0x3158970D, (q31_t)0x7607A827, + (q31_t)0x3186F487, (q31_t)0x75F42C0A, (q31_t)0x31B54A5D, + (q31_t)0x75E09DBD, (q31_t)0x31E39889, (q31_t)0x75CCFD42, + (q31_t)0x3211DF03, (q31_t)0x75B94A9C, (q31_t)0x32401DC5, + (q31_t)0x75A585CF, (q31_t)0x326E54C7, (q31_t)0x7591AEDD, + (q31_t)0x329C8402, (q31_t)0x757DC5CA, (q31_t)0x32CAAB6F, + (q31_t)0x7569CA98, (q31_t)0x32F8CB07, (q31_t)0x7555BD4B, + (q31_t)0x3326E2C2, (q31_t)0x75419DE6, (q31_t)0x3354F29A, + (q31_t)0x752D6C6C, (q31_t)0x3382FA88, (q31_t)0x751928E0, + (q31_t)0x33B0FA84, (q31_t)0x7504D345, (q31_t)0x33DEF287, + (q31_t)0x74F06B9E, (q31_t)0x340CE28A, (q31_t)0x74DBF1EF, + (q31_t)0x343ACA87, (q31_t)0x74C7663A, (q31_t)0x3468AA76, + (q31_t)0x74B2C883, (q31_t)0x3496824F, (q31_t)0x749E18CD, + (q31_t)0x34C4520D, (q31_t)0x7489571B, (q31_t)0x34F219A7, + (q31_t)0x74748371, (q31_t)0x351FD917, (q31_t)0x745F9DD1, + (q31_t)0x354D9056, (q31_t)0x744AA63E, (q31_t)0x357B3F5D, + (q31_t)0x74359CBD, (q31_t)0x35A8E624, (q31_t)0x74208150, + (q31_t)0x35D684A5, (q31_t)0x740B53FA, (q31_t)0x36041AD9, + (q31_t)0x73F614C0, (q31_t)0x3631A8B7, (q31_t)0x73E0C3A3, + (q31_t)0x365F2E3B, (q31_t)0x73CB60A7, (q31_t)0x368CAB5C, + (q31_t)0x73B5EBD0, (q31_t)0x36BA2013, (q31_t)0x73A06522, + (q31_t)0x36E78C5A, (q31_t)0x738ACC9E, (q31_t)0x3714F02A, + (q31_t)0x73752249, (q31_t)0x37424B7A, (q31_t)0x735F6626, + (q31_t)0x376F9E46, (q31_t)0x73499838, (q31_t)0x379CE884, + (q31_t)0x7333B883, (q31_t)0x37CA2A30, (q31_t)0x731DC709, + (q31_t)0x37F76340, (q31_t)0x7307C3D0, (q31_t)0x382493B0, + (q31_t)0x72F1AED8, (q31_t)0x3851BB76, (q31_t)0x72DB8828, + (q31_t)0x387EDA8E, (q31_t)0x72C54FC0, (q31_t)0x38ABF0EF, + (q31_t)0x72AF05A6, (q31_t)0x38D8FE93, (q31_t)0x7298A9DC, + (q31_t)0x39060372, (q31_t)0x72823C66, (q31_t)0x3932FF87, + (q31_t)0x726BBD48, (q31_t)0x395FF2C9, (q31_t)0x72552C84, + (q31_t)0x398CDD32, (q31_t)0x723E8A1F, (q31_t)0x39B9BEBB, + (q31_t)0x7227D61C, (q31_t)0x39E6975D, (q31_t)0x7211107D, + (q31_t)0x3A136712, (q31_t)0x71FA3948, (q31_t)0x3A402DD1, + (q31_t)0x71E3507F, (q31_t)0x3A6CEB95, (q31_t)0x71CC5626, + (q31_t)0x3A99A057, (q31_t)0x71B54A40, (q31_t)0x3AC64C0F, + (q31_t)0x719E2CD2, (q31_t)0x3AF2EEB7, (q31_t)0x7186FDDE, + (q31_t)0x3B1F8847, (q31_t)0x716FBD68, (q31_t)0x3B4C18BA, + (q31_t)0x71586B73, (q31_t)0x3B78A007, (q31_t)0x71410804, + (q31_t)0x3BA51E29, (q31_t)0x7129931E, (q31_t)0x3BD19317, + (q31_t)0x71120CC5, (q31_t)0x3BFDFECD, (q31_t)0x70FA74FB, + (q31_t)0x3C2A6142, (q31_t)0x70E2CBC6, (q31_t)0x3C56BA70, + (q31_t)0x70CB1127, (q31_t)0x3C830A4F, (q31_t)0x70B34524, + (q31_t)0x3CAF50DA, (q31_t)0x709B67C0, (q31_t)0x3CDB8E09, + (q31_t)0x708378FE, (q31_t)0x3D07C1D5, (q31_t)0x706B78E3, + (q31_t)0x3D33EC39, (q31_t)0x70536771, (q31_t)0x3D600D2B, + (q31_t)0x703B44AC, (q31_t)0x3D8C24A7, (q31_t)0x70231099, + (q31_t)0x3DB832A5, (q31_t)0x700ACB3B, (q31_t)0x3DE4371F, + (q31_t)0x6FF27496, (q31_t)0x3E10320D, (q31_t)0x6FDA0CAD, + (q31_t)0x3E3C2369, (q31_t)0x6FC19385, (q31_t)0x3E680B2C, + (q31_t)0x6FA90920, (q31_t)0x3E93E94F, (q31_t)0x6F906D84, + (q31_t)0x3EBFBDCC, (q31_t)0x6F77C0B3, (q31_t)0x3EEB889C, + (q31_t)0x6F5F02B1, (q31_t)0x3F1749B7, (q31_t)0x6F463383, + (q31_t)0x3F430118, (q31_t)0x6F2D532C, (q31_t)0x3F6EAEB8, + (q31_t)0x6F1461AF, (q31_t)0x3F9A528F, (q31_t)0x6EFB5F12, + (q31_t)0x3FC5EC97, (q31_t)0x6EE24B57, (q31_t)0x3FF17CCA, + (q31_t)0x6EC92682, (q31_t)0x401D0320, (q31_t)0x6EAFF098, + (q31_t)0x40487F93, (q31_t)0x6E96A99C, (q31_t)0x4073F21D, + (q31_t)0x6E7D5193, (q31_t)0x409F5AB6, (q31_t)0x6E63E87F, + (q31_t)0x40CAB957, (q31_t)0x6E4A6E65, (q31_t)0x40F60DFB, + (q31_t)0x6E30E349, (q31_t)0x4121589A, (q31_t)0x6E17472F, + (q31_t)0x414C992E, (q31_t)0x6DFD9A1B, (q31_t)0x4177CFB0, + (q31_t)0x6DE3DC11, (q31_t)0x41A2FC1A, (q31_t)0x6DCA0D14, + (q31_t)0x41CE1E64, (q31_t)0x6DB02D29, (q31_t)0x41F93688, + (q31_t)0x6D963C54, (q31_t)0x42244480, (q31_t)0x6D7C3A98, + (q31_t)0x424F4845, (q31_t)0x6D6227FA, (q31_t)0x427A41D0, + (q31_t)0x6D48047E, (q31_t)0x42A5311A, (q31_t)0x6D2DD027, + (q31_t)0x42D0161E, (q31_t)0x6D138AFA, (q31_t)0x42FAF0D4, + (q31_t)0x6CF934FB, (q31_t)0x4325C135, (q31_t)0x6CDECE2E, + (q31_t)0x4350873C, (q31_t)0x6CC45697, (q31_t)0x437B42E1, + (q31_t)0x6CA9CE3A, (q31_t)0x43A5F41E, (q31_t)0x6C8F351C, + (q31_t)0x43D09AEC, (q31_t)0x6C748B3F, (q31_t)0x43FB3745, + (q31_t)0x6C59D0A9, (q31_t)0x4425C923, (q31_t)0x6C3F055D, + (q31_t)0x4450507E, (q31_t)0x6C242960, (q31_t)0x447ACD50, + (q31_t)0x6C093CB6, (q31_t)0x44A53F93, (q31_t)0x6BEE3F62, + (q31_t)0x44CFA73F, (q31_t)0x6BD3316A, (q31_t)0x44FA044F, + (q31_t)0x6BB812D0, (q31_t)0x452456BC, (q31_t)0x6B9CE39B, + (q31_t)0x454E9E80, (q31_t)0x6B81A3CD, (q31_t)0x4578DB93, + (q31_t)0x6B66536A, (q31_t)0x45A30DF0, (q31_t)0x6B4AF278, + (q31_t)0x45CD358F, (q31_t)0x6B2F80FA, (q31_t)0x45F7526B, + (q31_t)0x6B13FEF5, (q31_t)0x4621647C, (q31_t)0x6AF86C6C, + (q31_t)0x464B6BBD, (q31_t)0x6ADCC964, (q31_t)0x46756827, + (q31_t)0x6AC115E1, (q31_t)0x469F59B4, (q31_t)0x6AA551E8, + (q31_t)0x46C9405C, (q31_t)0x6A897D7D, (q31_t)0x46F31C1A, + (q31_t)0x6A6D98A4, (q31_t)0x471CECE6, (q31_t)0x6A51A361, + (q31_t)0x4746B2BC, (q31_t)0x6A359DB9, (q31_t)0x47706D93, + (q31_t)0x6A1987B0, (q31_t)0x479A1D66, (q31_t)0x69FD614A, + (q31_t)0x47C3C22E, (q31_t)0x69E12A8C, (q31_t)0x47ED5BE6, + (q31_t)0x69C4E37A, (q31_t)0x4816EA85, (q31_t)0x69A88C18, + (q31_t)0x48406E07, (q31_t)0x698C246C, (q31_t)0x4869E664, + (q31_t)0x696FAC78, (q31_t)0x48935397, (q31_t)0x69532442, + (q31_t)0x48BCB598, (q31_t)0x69368BCE, (q31_t)0x48E60C62, + (q31_t)0x6919E320, (q31_t)0x490F57EE, (q31_t)0x68FD2A3D, + (q31_t)0x49389836, (q31_t)0x68E06129, (q31_t)0x4961CD32, + (q31_t)0x68C387E9, (q31_t)0x498AF6DE, (q31_t)0x68A69E81, + (q31_t)0x49B41533, (q31_t)0x6889A4F5, (q31_t)0x49DD282A, + (q31_t)0x686C9B4B, (q31_t)0x4A062FBD, (q31_t)0x684F8186, + (q31_t)0x4A2F2BE5, (q31_t)0x683257AA, (q31_t)0x4A581C9D, + (q31_t)0x68151DBE, (q31_t)0x4A8101DE, (q31_t)0x67F7D3C4, + (q31_t)0x4AA9DBA1, (q31_t)0x67DA79C2, (q31_t)0x4AD2A9E1, + (q31_t)0x67BD0FBC, (q31_t)0x4AFB6C97, (q31_t)0x679F95B7, + (q31_t)0x4B2423BD, (q31_t)0x67820BB6, (q31_t)0x4B4CCF4D, + (q31_t)0x676471C0, (q31_t)0x4B756F3F, (q31_t)0x6746C7D7, + (q31_t)0x4B9E038F, (q31_t)0x67290E02, (q31_t)0x4BC68C36, + (q31_t)0x670B4443, (q31_t)0x4BEF092D, (q31_t)0x66ED6AA1, + (q31_t)0x4C177A6E, (q31_t)0x66CF811F, (q31_t)0x4C3FDFF3, + (q31_t)0x66B187C3, (q31_t)0x4C6839B6, (q31_t)0x66937E90, + (q31_t)0x4C9087B1, (q31_t)0x6675658C, (q31_t)0x4CB8C9DD, + (q31_t)0x66573CBB, (q31_t)0x4CE10034, (q31_t)0x66390422, + (q31_t)0x4D092AB0, (q31_t)0x661ABBC5, (q31_t)0x4D31494B, + (q31_t)0x65FC63A9, (q31_t)0x4D595BFE, (q31_t)0x65DDFBD3, + (q31_t)0x4D8162C4, (q31_t)0x65BF8447, (q31_t)0x4DA95D96, + (q31_t)0x65A0FD0B, (q31_t)0x4DD14C6E, (q31_t)0x65826622, + (q31_t)0x4DF92F45, (q31_t)0x6563BF92, (q31_t)0x4E210617, + (q31_t)0x6545095F, (q31_t)0x4E48D0DC, (q31_t)0x6526438E, + (q31_t)0x4E708F8F, (q31_t)0x65076E24, (q31_t)0x4E984229, + (q31_t)0x64E88926, (q31_t)0x4EBFE8A4, (q31_t)0x64C99498, + (q31_t)0x4EE782FA, (q31_t)0x64AA907F, (q31_t)0x4F0F1126, + (q31_t)0x648B7CDF, (q31_t)0x4F369320, (q31_t)0x646C59BF, + (q31_t)0x4F5E08E3, (q31_t)0x644D2722, (q31_t)0x4F857268, + (q31_t)0x642DE50D, (q31_t)0x4FACCFAB, (q31_t)0x640E9385, + (q31_t)0x4FD420A3, (q31_t)0x63EF328F, (q31_t)0x4FFB654D, + (q31_t)0x63CFC230, (q31_t)0x50229DA0, (q31_t)0x63B0426D, + (q31_t)0x5049C999, (q31_t)0x6390B34A, (q31_t)0x5070E92F, + (q31_t)0x637114CC, (q31_t)0x5097FC5E, (q31_t)0x635166F8, + (q31_t)0x50BF031F, (q31_t)0x6331A9D4, (q31_t)0x50E5FD6C, + (q31_t)0x6311DD63, (q31_t)0x510CEB40, (q31_t)0x62F201AC, + (q31_t)0x5133CC94, (q31_t)0x62D216B2, (q31_t)0x515AA162, + (q31_t)0x62B21C7B, (q31_t)0x518169A4, (q31_t)0x6292130C, + (q31_t)0x51A82555, (q31_t)0x6271FA69, (q31_t)0x51CED46E, + (q31_t)0x6251D297, (q31_t)0x51F576E9, (q31_t)0x62319B9D, + (q31_t)0x521C0CC1, (q31_t)0x6211557D, (q31_t)0x524295EF, + (q31_t)0x61F1003E, (q31_t)0x5269126E, (q31_t)0x61D09BE5, + (q31_t)0x528F8237, (q31_t)0x61B02876, (q31_t)0x52B5E545, + (q31_t)0x618FA5F6, (q31_t)0x52DC3B92, (q31_t)0x616F146B, + (q31_t)0x53028517, (q31_t)0x614E73D9, (q31_t)0x5328C1D0, + (q31_t)0x612DC446, (q31_t)0x534EF1B5, (q31_t)0x610D05B7, + (q31_t)0x537514C1, (q31_t)0x60EC3830, (q31_t)0x539B2AEF, + (q31_t)0x60CB5BB6, (q31_t)0x53C13438, (q31_t)0x60AA704F, + (q31_t)0x53E73097, (q31_t)0x60897600, (q31_t)0x540D2005, + (q31_t)0x60686CCE, (q31_t)0x5433027D, (q31_t)0x604754BE, + (q31_t)0x5458D7F9, (q31_t)0x60262DD5, (q31_t)0x547EA073, + (q31_t)0x6004F818, (q31_t)0x54A45BE5, (q31_t)0x5FE3B38D, + (q31_t)0x54CA0A4A, (q31_t)0x5FC26038, (q31_t)0x54EFAB9C, + (q31_t)0x5FA0FE1E, (q31_t)0x55153FD4, (q31_t)0x5F7F8D46, + (q31_t)0x553AC6ED, (q31_t)0x5F5E0DB3, (q31_t)0x556040E2, + (q31_t)0x5F3C7F6B, (q31_t)0x5585ADAC, (q31_t)0x5F1AE273, + (q31_t)0x55AB0D46, (q31_t)0x5EF936D1, (q31_t)0x55D05FAA, + (q31_t)0x5ED77C89, (q31_t)0x55F5A4D2, (q31_t)0x5EB5B3A1, + (q31_t)0x561ADCB8, (q31_t)0x5E93DC1F, (q31_t)0x56400757, + (q31_t)0x5E71F606, (q31_t)0x566524AA, (q31_t)0x5E50015D, + (q31_t)0x568A34A9, (q31_t)0x5E2DFE28, (q31_t)0x56AF3750, + (q31_t)0x5E0BEC6E, (q31_t)0x56D42C99, (q31_t)0x5DE9CC32, + (q31_t)0x56F9147E, (q31_t)0x5DC79D7C, (q31_t)0x571DEEF9, + (q31_t)0x5DA5604E, (q31_t)0x5742BC05, (q31_t)0x5D8314B0, + (q31_t)0x57677B9D, (q31_t)0x5D60BAA6, (q31_t)0x578C2DB9, + (q31_t)0x5D3E5236, (q31_t)0x57B0D256, (q31_t)0x5D1BDB65, + (q31_t)0x57D5696C, (q31_t)0x5CF95638, (q31_t)0x57F9F2F7, + (q31_t)0x5CD6C2B4, (q31_t)0x581E6EF1, (q31_t)0x5CB420DF, + (q31_t)0x5842DD54, (q31_t)0x5C9170BF, (q31_t)0x58673E1B, + (q31_t)0x5C6EB258, (q31_t)0x588B913F, (q31_t)0x5C4BE5B0, + (q31_t)0x58AFD6BC, (q31_t)0x5C290ACC, (q31_t)0x58D40E8C, + (q31_t)0x5C0621B2, (q31_t)0x58F838A9, (q31_t)0x5BE32A67, + (q31_t)0x591C550E, (q31_t)0x5BC024F0, (q31_t)0x594063B4, + (q31_t)0x5B9D1153, (q31_t)0x59646497, (q31_t)0x5B79EF96, + (q31_t)0x598857B1, (q31_t)0x5B56BFBD, (q31_t)0x59AC3CFD, + (q31_t)0x5B3381CE, (q31_t)0x59D01474, (q31_t)0x5B1035CF, + (q31_t)0x59F3DE12, (q31_t)0x5AECDBC4, (q31_t)0x5A1799D0, + (q31_t)0x5AC973B4, (q31_t)0x5A3B47AA, (q31_t)0x5AA5FDA4, + (q31_t)0x5A5EE79A, (q31_t)0x5A82799A, (q31_t)0x5A82799A, + (q31_t)0x5A5EE79A, (q31_t)0x5AA5FDA4, (q31_t)0x5A3B47AA, + (q31_t)0x5AC973B4, (q31_t)0x5A1799D0, (q31_t)0x5AECDBC4, + (q31_t)0x59F3DE12, (q31_t)0x5B1035CF, (q31_t)0x59D01474, + (q31_t)0x5B3381CE, (q31_t)0x59AC3CFD, (q31_t)0x5B56BFBD, + (q31_t)0x598857B1, (q31_t)0x5B79EF96, (q31_t)0x59646497, + (q31_t)0x5B9D1153, (q31_t)0x594063B4, (q31_t)0x5BC024F0, + (q31_t)0x591C550E, (q31_t)0x5BE32A67, (q31_t)0x58F838A9, + (q31_t)0x5C0621B2, (q31_t)0x58D40E8C, (q31_t)0x5C290ACC, + (q31_t)0x58AFD6BC, (q31_t)0x5C4BE5B0, (q31_t)0x588B913F, + (q31_t)0x5C6EB258, (q31_t)0x58673E1B, (q31_t)0x5C9170BF, + (q31_t)0x5842DD54, (q31_t)0x5CB420DF, (q31_t)0x581E6EF1, + (q31_t)0x5CD6C2B4, (q31_t)0x57F9F2F7, (q31_t)0x5CF95638, + (q31_t)0x57D5696C, (q31_t)0x5D1BDB65, (q31_t)0x57B0D256, + (q31_t)0x5D3E5236, (q31_t)0x578C2DB9, (q31_t)0x5D60BAA6, + (q31_t)0x57677B9D, (q31_t)0x5D8314B0, (q31_t)0x5742BC05, + (q31_t)0x5DA5604E, (q31_t)0x571DEEF9, (q31_t)0x5DC79D7C, + (q31_t)0x56F9147E, (q31_t)0x5DE9CC32, (q31_t)0x56D42C99, + (q31_t)0x5E0BEC6E, (q31_t)0x56AF3750, (q31_t)0x5E2DFE28, + (q31_t)0x568A34A9, (q31_t)0x5E50015D, (q31_t)0x566524AA, + (q31_t)0x5E71F606, (q31_t)0x56400757, (q31_t)0x5E93DC1F, + (q31_t)0x561ADCB8, (q31_t)0x5EB5B3A1, (q31_t)0x55F5A4D2, + (q31_t)0x5ED77C89, (q31_t)0x55D05FAA, (q31_t)0x5EF936D1, + (q31_t)0x55AB0D46, (q31_t)0x5F1AE273, (q31_t)0x5585ADAC, + (q31_t)0x5F3C7F6B, (q31_t)0x556040E2, (q31_t)0x5F5E0DB3, + (q31_t)0x553AC6ED, (q31_t)0x5F7F8D46, (q31_t)0x55153FD4, + (q31_t)0x5FA0FE1E, (q31_t)0x54EFAB9C, (q31_t)0x5FC26038, + (q31_t)0x54CA0A4A, (q31_t)0x5FE3B38D, (q31_t)0x54A45BE5, + (q31_t)0x6004F818, (q31_t)0x547EA073, (q31_t)0x60262DD5, + (q31_t)0x5458D7F9, (q31_t)0x604754BE, (q31_t)0x5433027D, + (q31_t)0x60686CCE, (q31_t)0x540D2005, (q31_t)0x60897600, + (q31_t)0x53E73097, (q31_t)0x60AA704F, (q31_t)0x53C13438, + (q31_t)0x60CB5BB6, (q31_t)0x539B2AEF, (q31_t)0x60EC3830, + (q31_t)0x537514C1, (q31_t)0x610D05B7, (q31_t)0x534EF1B5, + (q31_t)0x612DC446, (q31_t)0x5328C1D0, (q31_t)0x614E73D9, + (q31_t)0x53028517, (q31_t)0x616F146B, (q31_t)0x52DC3B92, + (q31_t)0x618FA5F6, (q31_t)0x52B5E545, (q31_t)0x61B02876, + (q31_t)0x528F8237, (q31_t)0x61D09BE5, (q31_t)0x5269126E, + (q31_t)0x61F1003E, (q31_t)0x524295EF, (q31_t)0x6211557D, + (q31_t)0x521C0CC1, (q31_t)0x62319B9D, (q31_t)0x51F576E9, + (q31_t)0x6251D297, (q31_t)0x51CED46E, (q31_t)0x6271FA69, + (q31_t)0x51A82555, (q31_t)0x6292130C, (q31_t)0x518169A4, + (q31_t)0x62B21C7B, (q31_t)0x515AA162, (q31_t)0x62D216B2, + (q31_t)0x5133CC94, (q31_t)0x62F201AC, (q31_t)0x510CEB40, + (q31_t)0x6311DD63, (q31_t)0x50E5FD6C, (q31_t)0x6331A9D4, + (q31_t)0x50BF031F, (q31_t)0x635166F8, (q31_t)0x5097FC5E, + (q31_t)0x637114CC, (q31_t)0x5070E92F, (q31_t)0x6390B34A, + (q31_t)0x5049C999, (q31_t)0x63B0426D, (q31_t)0x50229DA0, + (q31_t)0x63CFC230, (q31_t)0x4FFB654D, (q31_t)0x63EF328F, + (q31_t)0x4FD420A3, (q31_t)0x640E9385, (q31_t)0x4FACCFAB, + (q31_t)0x642DE50D, (q31_t)0x4F857268, (q31_t)0x644D2722, + (q31_t)0x4F5E08E3, (q31_t)0x646C59BF, (q31_t)0x4F369320, + (q31_t)0x648B7CDF, (q31_t)0x4F0F1126, (q31_t)0x64AA907F, + (q31_t)0x4EE782FA, (q31_t)0x64C99498, (q31_t)0x4EBFE8A4, + (q31_t)0x64E88926, (q31_t)0x4E984229, (q31_t)0x65076E24, + (q31_t)0x4E708F8F, (q31_t)0x6526438E, (q31_t)0x4E48D0DC, + (q31_t)0x6545095F, (q31_t)0x4E210617, (q31_t)0x6563BF92, + (q31_t)0x4DF92F45, (q31_t)0x65826622, (q31_t)0x4DD14C6E, + (q31_t)0x65A0FD0B, (q31_t)0x4DA95D96, (q31_t)0x65BF8447, + (q31_t)0x4D8162C4, (q31_t)0x65DDFBD3, (q31_t)0x4D595BFE, + (q31_t)0x65FC63A9, (q31_t)0x4D31494B, (q31_t)0x661ABBC5, + (q31_t)0x4D092AB0, (q31_t)0x66390422, (q31_t)0x4CE10034, + (q31_t)0x66573CBB, (q31_t)0x4CB8C9DD, (q31_t)0x6675658C, + (q31_t)0x4C9087B1, (q31_t)0x66937E90, (q31_t)0x4C6839B6, + (q31_t)0x66B187C3, (q31_t)0x4C3FDFF3, (q31_t)0x66CF811F, + (q31_t)0x4C177A6E, (q31_t)0x66ED6AA1, (q31_t)0x4BEF092D, + (q31_t)0x670B4443, (q31_t)0x4BC68C36, (q31_t)0x67290E02, + (q31_t)0x4B9E038F, (q31_t)0x6746C7D7, (q31_t)0x4B756F3F, + (q31_t)0x676471C0, (q31_t)0x4B4CCF4D, (q31_t)0x67820BB6, + (q31_t)0x4B2423BD, (q31_t)0x679F95B7, (q31_t)0x4AFB6C97, + (q31_t)0x67BD0FBC, (q31_t)0x4AD2A9E1, (q31_t)0x67DA79C2, + (q31_t)0x4AA9DBA1, (q31_t)0x67F7D3C4, (q31_t)0x4A8101DE, + (q31_t)0x68151DBE, (q31_t)0x4A581C9D, (q31_t)0x683257AA, + (q31_t)0x4A2F2BE5, (q31_t)0x684F8186, (q31_t)0x4A062FBD, + (q31_t)0x686C9B4B, (q31_t)0x49DD282A, (q31_t)0x6889A4F5, + (q31_t)0x49B41533, (q31_t)0x68A69E81, (q31_t)0x498AF6DE, + (q31_t)0x68C387E9, (q31_t)0x4961CD32, (q31_t)0x68E06129, + (q31_t)0x49389836, (q31_t)0x68FD2A3D, (q31_t)0x490F57EE, + (q31_t)0x6919E320, (q31_t)0x48E60C62, (q31_t)0x69368BCE, + (q31_t)0x48BCB598, (q31_t)0x69532442, (q31_t)0x48935397, + (q31_t)0x696FAC78, (q31_t)0x4869E664, (q31_t)0x698C246C, + (q31_t)0x48406E07, (q31_t)0x69A88C18, (q31_t)0x4816EA85, + (q31_t)0x69C4E37A, (q31_t)0x47ED5BE6, (q31_t)0x69E12A8C, + (q31_t)0x47C3C22E, (q31_t)0x69FD614A, (q31_t)0x479A1D66, + (q31_t)0x6A1987B0, (q31_t)0x47706D93, (q31_t)0x6A359DB9, + (q31_t)0x4746B2BC, (q31_t)0x6A51A361, (q31_t)0x471CECE6, + (q31_t)0x6A6D98A4, (q31_t)0x46F31C1A, (q31_t)0x6A897D7D, + (q31_t)0x46C9405C, (q31_t)0x6AA551E8, (q31_t)0x469F59B4, + (q31_t)0x6AC115E1, (q31_t)0x46756827, (q31_t)0x6ADCC964, + (q31_t)0x464B6BBD, (q31_t)0x6AF86C6C, (q31_t)0x4621647C, + (q31_t)0x6B13FEF5, (q31_t)0x45F7526B, (q31_t)0x6B2F80FA, + (q31_t)0x45CD358F, (q31_t)0x6B4AF278, (q31_t)0x45A30DF0, + (q31_t)0x6B66536A, (q31_t)0x4578DB93, (q31_t)0x6B81A3CD, + (q31_t)0x454E9E80, (q31_t)0x6B9CE39B, (q31_t)0x452456BC, + (q31_t)0x6BB812D0, (q31_t)0x44FA044F, (q31_t)0x6BD3316A, + (q31_t)0x44CFA73F, (q31_t)0x6BEE3F62, (q31_t)0x44A53F93, + (q31_t)0x6C093CB6, (q31_t)0x447ACD50, (q31_t)0x6C242960, + (q31_t)0x4450507E, (q31_t)0x6C3F055D, (q31_t)0x4425C923, + (q31_t)0x6C59D0A9, (q31_t)0x43FB3745, (q31_t)0x6C748B3F, + (q31_t)0x43D09AEC, (q31_t)0x6C8F351C, (q31_t)0x43A5F41E, + (q31_t)0x6CA9CE3A, (q31_t)0x437B42E1, (q31_t)0x6CC45697, + (q31_t)0x4350873C, (q31_t)0x6CDECE2E, (q31_t)0x4325C135, + (q31_t)0x6CF934FB, (q31_t)0x42FAF0D4, (q31_t)0x6D138AFA, + (q31_t)0x42D0161E, (q31_t)0x6D2DD027, (q31_t)0x42A5311A, + (q31_t)0x6D48047E, (q31_t)0x427A41D0, (q31_t)0x6D6227FA, + (q31_t)0x424F4845, (q31_t)0x6D7C3A98, (q31_t)0x42244480, + (q31_t)0x6D963C54, (q31_t)0x41F93688, (q31_t)0x6DB02D29, + (q31_t)0x41CE1E64, (q31_t)0x6DCA0D14, (q31_t)0x41A2FC1A, + (q31_t)0x6DE3DC11, (q31_t)0x4177CFB0, (q31_t)0x6DFD9A1B, + (q31_t)0x414C992E, (q31_t)0x6E17472F, (q31_t)0x4121589A, + (q31_t)0x6E30E349, (q31_t)0x40F60DFB, (q31_t)0x6E4A6E65, + (q31_t)0x40CAB957, (q31_t)0x6E63E87F, (q31_t)0x409F5AB6, + (q31_t)0x6E7D5193, (q31_t)0x4073F21D, (q31_t)0x6E96A99C, + (q31_t)0x40487F93, (q31_t)0x6EAFF098, (q31_t)0x401D0320, + (q31_t)0x6EC92682, (q31_t)0x3FF17CCA, (q31_t)0x6EE24B57, + (q31_t)0x3FC5EC97, (q31_t)0x6EFB5F12, (q31_t)0x3F9A528F, + (q31_t)0x6F1461AF, (q31_t)0x3F6EAEB8, (q31_t)0x6F2D532C, + (q31_t)0x3F430118, (q31_t)0x6F463383, (q31_t)0x3F1749B7, + (q31_t)0x6F5F02B1, (q31_t)0x3EEB889C, (q31_t)0x6F77C0B3, + (q31_t)0x3EBFBDCC, (q31_t)0x6F906D84, (q31_t)0x3E93E94F, + (q31_t)0x6FA90920, (q31_t)0x3E680B2C, (q31_t)0x6FC19385, + (q31_t)0x3E3C2369, (q31_t)0x6FDA0CAD, (q31_t)0x3E10320D, + (q31_t)0x6FF27496, (q31_t)0x3DE4371F, (q31_t)0x700ACB3B, + (q31_t)0x3DB832A5, (q31_t)0x70231099, (q31_t)0x3D8C24A7, + (q31_t)0x703B44AC, (q31_t)0x3D600D2B, (q31_t)0x70536771, + (q31_t)0x3D33EC39, (q31_t)0x706B78E3, (q31_t)0x3D07C1D5, + (q31_t)0x708378FE, (q31_t)0x3CDB8E09, (q31_t)0x709B67C0, + (q31_t)0x3CAF50DA, (q31_t)0x70B34524, (q31_t)0x3C830A4F, + (q31_t)0x70CB1127, (q31_t)0x3C56BA70, (q31_t)0x70E2CBC6, + (q31_t)0x3C2A6142, (q31_t)0x70FA74FB, (q31_t)0x3BFDFECD, + (q31_t)0x71120CC5, (q31_t)0x3BD19317, (q31_t)0x7129931E, + (q31_t)0x3BA51E29, (q31_t)0x71410804, (q31_t)0x3B78A007, + (q31_t)0x71586B73, (q31_t)0x3B4C18BA, (q31_t)0x716FBD68, + (q31_t)0x3B1F8847, (q31_t)0x7186FDDE, (q31_t)0x3AF2EEB7, + (q31_t)0x719E2CD2, (q31_t)0x3AC64C0F, (q31_t)0x71B54A40, + (q31_t)0x3A99A057, (q31_t)0x71CC5626, (q31_t)0x3A6CEB95, + (q31_t)0x71E3507F, (q31_t)0x3A402DD1, (q31_t)0x71FA3948, + (q31_t)0x3A136712, (q31_t)0x7211107D, (q31_t)0x39E6975D, + (q31_t)0x7227D61C, (q31_t)0x39B9BEBB, (q31_t)0x723E8A1F, + (q31_t)0x398CDD32, (q31_t)0x72552C84, (q31_t)0x395FF2C9, + (q31_t)0x726BBD48, (q31_t)0x3932FF87, (q31_t)0x72823C66, + (q31_t)0x39060372, (q31_t)0x7298A9DC, (q31_t)0x38D8FE93, + (q31_t)0x72AF05A6, (q31_t)0x38ABF0EF, (q31_t)0x72C54FC0, + (q31_t)0x387EDA8E, (q31_t)0x72DB8828, (q31_t)0x3851BB76, + (q31_t)0x72F1AED8, (q31_t)0x382493B0, (q31_t)0x7307C3D0, + (q31_t)0x37F76340, (q31_t)0x731DC709, (q31_t)0x37CA2A30, + (q31_t)0x7333B883, (q31_t)0x379CE884, (q31_t)0x73499838, + (q31_t)0x376F9E46, (q31_t)0x735F6626, (q31_t)0x37424B7A, + (q31_t)0x73752249, (q31_t)0x3714F02A, (q31_t)0x738ACC9E, + (q31_t)0x36E78C5A, (q31_t)0x73A06522, (q31_t)0x36BA2013, + (q31_t)0x73B5EBD0, (q31_t)0x368CAB5C, (q31_t)0x73CB60A7, + (q31_t)0x365F2E3B, (q31_t)0x73E0C3A3, (q31_t)0x3631A8B7, + (q31_t)0x73F614C0, (q31_t)0x36041AD9, (q31_t)0x740B53FA, + (q31_t)0x35D684A5, (q31_t)0x74208150, (q31_t)0x35A8E624, + (q31_t)0x74359CBD, (q31_t)0x357B3F5D, (q31_t)0x744AA63E, + (q31_t)0x354D9056, (q31_t)0x745F9DD1, (q31_t)0x351FD917, + (q31_t)0x74748371, (q31_t)0x34F219A7, (q31_t)0x7489571B, + (q31_t)0x34C4520D, (q31_t)0x749E18CD, (q31_t)0x3496824F, + (q31_t)0x74B2C883, (q31_t)0x3468AA76, (q31_t)0x74C7663A, + (q31_t)0x343ACA87, (q31_t)0x74DBF1EF, (q31_t)0x340CE28A, + (q31_t)0x74F06B9E, (q31_t)0x33DEF287, (q31_t)0x7504D345, + (q31_t)0x33B0FA84, (q31_t)0x751928E0, (q31_t)0x3382FA88, + (q31_t)0x752D6C6C, (q31_t)0x3354F29A, (q31_t)0x75419DE6, + (q31_t)0x3326E2C2, (q31_t)0x7555BD4B, (q31_t)0x32F8CB07, + (q31_t)0x7569CA98, (q31_t)0x32CAAB6F, (q31_t)0x757DC5CA, + (q31_t)0x329C8402, (q31_t)0x7591AEDD, (q31_t)0x326E54C7, + (q31_t)0x75A585CF, (q31_t)0x32401DC5, (q31_t)0x75B94A9C, + (q31_t)0x3211DF03, (q31_t)0x75CCFD42, (q31_t)0x31E39889, + (q31_t)0x75E09DBD, (q31_t)0x31B54A5D, (q31_t)0x75F42C0A, + (q31_t)0x3186F487, (q31_t)0x7607A827, (q31_t)0x3158970D, + (q31_t)0x761B1211, (q31_t)0x312A31F8, (q31_t)0x762E69C3, + (q31_t)0x30FBC54D, (q31_t)0x7641AF3C, (q31_t)0x30CD5114, + (q31_t)0x7654E279, (q31_t)0x309ED555, (q31_t)0x76680376, + (q31_t)0x30705217, (q31_t)0x767B1230, (q31_t)0x3041C760, + (q31_t)0x768E0EA5, (q31_t)0x30133538, (q31_t)0x76A0F8D2, + (q31_t)0x2FE49BA6, (q31_t)0x76B3D0B3, (q31_t)0x2FB5FAB2, + (q31_t)0x76C69646, (q31_t)0x2F875262, (q31_t)0x76D94988, + (q31_t)0x2F58A2BD, (q31_t)0x76EBEA77, (q31_t)0x2F29EBCC, + (q31_t)0x76FE790E, (q31_t)0x2EFB2D94, (q31_t)0x7710F54B, + (q31_t)0x2ECC681E, (q31_t)0x77235F2D, (q31_t)0x2E9D9B70, + (q31_t)0x7735B6AE, (q31_t)0x2E6EC792, (q31_t)0x7747FBCE, + (q31_t)0x2E3FEC8B, (q31_t)0x775A2E88, (q31_t)0x2E110A62, + (q31_t)0x776C4EDB, (q31_t)0x2DE2211E, (q31_t)0x777E5CC3, + (q31_t)0x2DB330C7, (q31_t)0x7790583D, (q31_t)0x2D843963, + (q31_t)0x77A24148, (q31_t)0x2D553AFB, (q31_t)0x77B417DF, + (q31_t)0x2D263595, (q31_t)0x77C5DC01, (q31_t)0x2CF72939, + (q31_t)0x77D78DAA, (q31_t)0x2CC815ED, (q31_t)0x77E92CD8, + (q31_t)0x2C98FBBA, (q31_t)0x77FAB988, (q31_t)0x2C69DAA6, + (q31_t)0x780C33B8, (q31_t)0x2C3AB2B9, (q31_t)0x781D9B64, + (q31_t)0x2C0B83F9, (q31_t)0x782EF08B, (q31_t)0x2BDC4E6F, + (q31_t)0x78403328, (q31_t)0x2BAD1221, (q31_t)0x7851633B, + (q31_t)0x2B7DCF17, (q31_t)0x786280BF, (q31_t)0x2B4E8558, + (q31_t)0x78738BB3, (q31_t)0x2B1F34EB, (q31_t)0x78848413, + (q31_t)0x2AEFDDD8, (q31_t)0x789569DE, (q31_t)0x2AC08025, + (q31_t)0x78A63D10, (q31_t)0x2A911BDB, (q31_t)0x78B6FDA8, + (q31_t)0x2A61B101, (q31_t)0x78C7ABA1, (q31_t)0x2A323F9D, + (q31_t)0x78D846FB, (q31_t)0x2A02C7B8, (q31_t)0x78E8CFB1, + (q31_t)0x29D34958, (q31_t)0x78F945C3, (q31_t)0x29A3C484, + (q31_t)0x7909A92C, (q31_t)0x29743945, (q31_t)0x7919F9EB, + (q31_t)0x2944A7A2, (q31_t)0x792A37FE, (q31_t)0x29150FA1, + (q31_t)0x793A6360, (q31_t)0x28E5714A, (q31_t)0x794A7C11, + (q31_t)0x28B5CCA5, (q31_t)0x795A820E, (q31_t)0x288621B9, + (q31_t)0x796A7554, (q31_t)0x2856708C, (q31_t)0x797A55E0, + (q31_t)0x2826B928, (q31_t)0x798A23B1, (q31_t)0x27F6FB92, + (q31_t)0x7999DEC3, (q31_t)0x27C737D2, (q31_t)0x79A98715, + (q31_t)0x27976DF1, (q31_t)0x79B91CA4, (q31_t)0x27679DF4, + (q31_t)0x79C89F6D, (q31_t)0x2737C7E3, (q31_t)0x79D80F6F, + (q31_t)0x2707EBC6, (q31_t)0x79E76CA6, (q31_t)0x26D809A5, + (q31_t)0x79F6B711, (q31_t)0x26A82185, (q31_t)0x7A05EEAD, + (q31_t)0x26783370, (q31_t)0x7A151377, (q31_t)0x26483F6C, + (q31_t)0x7A24256E, (q31_t)0x26184581, (q31_t)0x7A33248F, + (q31_t)0x25E845B5, (q31_t)0x7A4210D8, (q31_t)0x25B84012, + (q31_t)0x7A50EA46, (q31_t)0x2588349D, (q31_t)0x7A5FB0D8, + (q31_t)0x2558235E, (q31_t)0x7A6E648A, (q31_t)0x25280C5D, + (q31_t)0x7A7D055B, (q31_t)0x24F7EFA1, (q31_t)0x7A8B9348, + (q31_t)0x24C7CD32, (q31_t)0x7A9A0E4F, (q31_t)0x2497A517, + (q31_t)0x7AA8766E, (q31_t)0x24677757, (q31_t)0x7AB6CBA3, + (q31_t)0x243743FA, (q31_t)0x7AC50DEB, (q31_t)0x24070B07, + (q31_t)0x7AD33D45, (q31_t)0x23D6CC86, (q31_t)0x7AE159AE, + (q31_t)0x23A6887E, (q31_t)0x7AEF6323, (q31_t)0x23763EF7, + (q31_t)0x7AFD59A3, (q31_t)0x2345EFF7, (q31_t)0x7B0B3D2C, + (q31_t)0x23159B87, (q31_t)0x7B190DBB, (q31_t)0x22E541AE, + (q31_t)0x7B26CB4F, (q31_t)0x22B4E274, (q31_t)0x7B3475E4, + (q31_t)0x22847DDF, (q31_t)0x7B420D7A, (q31_t)0x225413F8, + (q31_t)0x7B4F920E, (q31_t)0x2223A4C5, (q31_t)0x7B5D039D, + (q31_t)0x21F3304E, (q31_t)0x7B6A6227, (q31_t)0x21C2B69C, + (q31_t)0x7B77ADA8, (q31_t)0x219237B4, (q31_t)0x7B84E61E, + (q31_t)0x2161B39F, (q31_t)0x7B920B89, (q31_t)0x21312A65, + (q31_t)0x7B9F1DE5, (q31_t)0x21009C0B, (q31_t)0x7BAC1D31, + (q31_t)0x20D0089B, (q31_t)0x7BB9096A, (q31_t)0x209F701C, + (q31_t)0x7BC5E28F, (q31_t)0x206ED295, (q31_t)0x7BD2A89E, + (q31_t)0x203E300D, (q31_t)0x7BDF5B94, (q31_t)0x200D888C, + (q31_t)0x7BEBFB70, (q31_t)0x1FDCDC1A, (q31_t)0x7BF88830, + (q31_t)0x1FAC2ABF, (q31_t)0x7C0501D1, (q31_t)0x1F7B7480, + (q31_t)0x7C116853, (q31_t)0x1F4AB967, (q31_t)0x7C1DBBB2, + (q31_t)0x1F19F97B, (q31_t)0x7C29FBEE, (q31_t)0x1EE934C2, + (q31_t)0x7C362904, (q31_t)0x1EB86B46, (q31_t)0x7C4242F2, + (q31_t)0x1E879D0C, (q31_t)0x7C4E49B6, (q31_t)0x1E56CA1E, + (q31_t)0x7C5A3D4F, (q31_t)0x1E25F281, (q31_t)0x7C661DBB, + (q31_t)0x1DF5163F, (q31_t)0x7C71EAF8, (q31_t)0x1DC4355D, + (q31_t)0x7C7DA504, (q31_t)0x1D934FE5, (q31_t)0x7C894BDD, + (q31_t)0x1D6265DD, (q31_t)0x7C94DF82, (q31_t)0x1D31774D, + (q31_t)0x7CA05FF1, (q31_t)0x1D00843C, (q31_t)0x7CABCD27, + (q31_t)0x1CCF8CB3, (q31_t)0x7CB72724, (q31_t)0x1C9E90B8, + (q31_t)0x7CC26DE5, (q31_t)0x1C6D9053, (q31_t)0x7CCDA168, + (q31_t)0x1C3C8B8C, (q31_t)0x7CD8C1AD, (q31_t)0x1C0B826A, + (q31_t)0x7CE3CEB1, (q31_t)0x1BDA74F5, (q31_t)0x7CEEC873, + (q31_t)0x1BA96334, (q31_t)0x7CF9AEF0, (q31_t)0x1B784D30, + (q31_t)0x7D048228, (q31_t)0x1B4732EF, (q31_t)0x7D0F4218, + (q31_t)0x1B161479, (q31_t)0x7D19EEBE, (q31_t)0x1AE4F1D6, + (q31_t)0x7D24881A, (q31_t)0x1AB3CB0C, (q31_t)0x7D2F0E2A, + (q31_t)0x1A82A025, (q31_t)0x7D3980EC, (q31_t)0x1A517127, + (q31_t)0x7D43E05E, (q31_t)0x1A203E1B, (q31_t)0x7D4E2C7E, + (q31_t)0x19EF0706, (q31_t)0x7D58654C, (q31_t)0x19BDCBF2, + (q31_t)0x7D628AC5, (q31_t)0x198C8CE6, (q31_t)0x7D6C9CE9, + (q31_t)0x195B49E9, (q31_t)0x7D769BB5, (q31_t)0x192A0303, + (q31_t)0x7D808727, (q31_t)0x18F8B83C, (q31_t)0x7D8A5F3F, + (q31_t)0x18C7699B, (q31_t)0x7D9423FB, (q31_t)0x18961727, + (q31_t)0x7D9DD55A, (q31_t)0x1864C0E9, (q31_t)0x7DA77359, + (q31_t)0x183366E8, (q31_t)0x7DB0FDF7, (q31_t)0x1802092C, + (q31_t)0x7DBA7534, (q31_t)0x17D0A7BB, (q31_t)0x7DC3D90D, + (q31_t)0x179F429F, (q31_t)0x7DCD2981, (q31_t)0x176DD9DE, + (q31_t)0x7DD6668E, (q31_t)0x173C6D80, (q31_t)0x7DDF9034, + (q31_t)0x170AFD8D, (q31_t)0x7DE8A670, (q31_t)0x16D98A0C, + (q31_t)0x7DF1A942, (q31_t)0x16A81305, (q31_t)0x7DFA98A7, + (q31_t)0x1676987F, (q31_t)0x7E03749F, (q31_t)0x16451A83, + (q31_t)0x7E0C3D29, (q31_t)0x16139917, (q31_t)0x7E14F242, + (q31_t)0x15E21444, (q31_t)0x7E1D93E9, (q31_t)0x15B08C11, + (q31_t)0x7E26221E, (q31_t)0x157F0086, (q31_t)0x7E2E9CDF, + (q31_t)0x154D71AA, (q31_t)0x7E37042A, (q31_t)0x151BDF85, + (q31_t)0x7E3F57FE, (q31_t)0x14EA4A1F, (q31_t)0x7E47985B, + (q31_t)0x14B8B17F, (q31_t)0x7E4FC53E, (q31_t)0x148715AD, + (q31_t)0x7E57DEA6, (q31_t)0x145576B1, (q31_t)0x7E5FE493, + (q31_t)0x1423D492, (q31_t)0x7E67D702, (q31_t)0x13F22F57, + (q31_t)0x7E6FB5F3, (q31_t)0x13C0870A, (q31_t)0x7E778165, + (q31_t)0x138EDBB0, (q31_t)0x7E7F3956, (q31_t)0x135D2D53, + (q31_t)0x7E86DDC5, (q31_t)0x132B7BF9, (q31_t)0x7E8E6EB1, + (q31_t)0x12F9C7AA, (q31_t)0x7E95EC19, (q31_t)0x12C8106E, + (q31_t)0x7E9D55FC, (q31_t)0x1296564D, (q31_t)0x7EA4AC58, + (q31_t)0x1264994E, (q31_t)0x7EABEF2C, (q31_t)0x1232D978, + (q31_t)0x7EB31E77, (q31_t)0x120116D4, (q31_t)0x7EBA3A39, + (q31_t)0x11CF516A, (q31_t)0x7EC1426F, (q31_t)0x119D8940, + (q31_t)0x7EC8371A, (q31_t)0x116BBE5F, (q31_t)0x7ECF1837, + (q31_t)0x1139F0CE, (q31_t)0x7ED5E5C6, (q31_t)0x11082096, + (q31_t)0x7EDC9FC6, (q31_t)0x10D64DBC, (q31_t)0x7EE34635, + (q31_t)0x10A4784A, (q31_t)0x7EE9D913, (q31_t)0x1072A047, + (q31_t)0x7EF0585F, (q31_t)0x1040C5BB, (q31_t)0x7EF6C418, + (q31_t)0x100EE8AD, (q31_t)0x7EFD1C3C, (q31_t)0x0FDD0925, + (q31_t)0x7F0360CB, (q31_t)0x0FAB272B, (q31_t)0x7F0991C3, + (q31_t)0x0F7942C6, (q31_t)0x7F0FAF24, (q31_t)0x0F475BFE, + (q31_t)0x7F15B8EE, (q31_t)0x0F1572DC, (q31_t)0x7F1BAF1E, + (q31_t)0x0EE38765, (q31_t)0x7F2191B4, (q31_t)0x0EB199A3, + (q31_t)0x7F2760AF, (q31_t)0x0E7FA99D, (q31_t)0x7F2D1C0E, + (q31_t)0x0E4DB75B, (q31_t)0x7F32C3D0, (q31_t)0x0E1BC2E3, + (q31_t)0x7F3857F5, (q31_t)0x0DE9CC3F, (q31_t)0x7F3DD87C, + (q31_t)0x0DB7D376, (q31_t)0x7F434563, (q31_t)0x0D85D88F, + (q31_t)0x7F489EAA, (q31_t)0x0D53DB92, (q31_t)0x7F4DE450, + (q31_t)0x0D21DC87, (q31_t)0x7F531654, (q31_t)0x0CEFDB75, + (q31_t)0x7F5834B6, (q31_t)0x0CBDD865, (q31_t)0x7F5D3F75, + (q31_t)0x0C8BD35E, (q31_t)0x7F62368F, (q31_t)0x0C59CC67, + (q31_t)0x7F671A04, (q31_t)0x0C27C389, (q31_t)0x7F6BE9D4, + (q31_t)0x0BF5B8CB, (q31_t)0x7F70A5FD, (q31_t)0x0BC3AC35, + (q31_t)0x7F754E7F, (q31_t)0x0B919DCE, (q31_t)0x7F79E35A, + (q31_t)0x0B5F8D9F, (q31_t)0x7F7E648B, (q31_t)0x0B2D7BAE, + (q31_t)0x7F82D214, (q31_t)0x0AFB6805, (q31_t)0x7F872BF3, + (q31_t)0x0AC952AA, (q31_t)0x7F8B7226, (q31_t)0x0A973BA5, + (q31_t)0x7F8FA4AF, (q31_t)0x0A6522FE, (q31_t)0x7F93C38C, + (q31_t)0x0A3308BC, (q31_t)0x7F97CEBC, (q31_t)0x0A00ECE8, + (q31_t)0x7F9BC63F, (q31_t)0x09CECF89, (q31_t)0x7F9FAA15, + (q31_t)0x099CB0A7, (q31_t)0x7FA37A3C, (q31_t)0x096A9049, + (q31_t)0x7FA736B4, (q31_t)0x09386E77, (q31_t)0x7FAADF7C, + (q31_t)0x09064B3A, (q31_t)0x7FAE7494, (q31_t)0x08D42698, + (q31_t)0x7FB1F5FC, (q31_t)0x08A2009A, (q31_t)0x7FB563B2, + (q31_t)0x086FD947, (q31_t)0x7FB8BDB7, (q31_t)0x083DB0A7, + (q31_t)0x7FBC040A, (q31_t)0x080B86C1, (q31_t)0x7FBF36A9, + (q31_t)0x07D95B9E, (q31_t)0x7FC25596, (q31_t)0x07A72F45, + (q31_t)0x7FC560CF, (q31_t)0x077501BE, (q31_t)0x7FC85853, + (q31_t)0x0742D310, (q31_t)0x7FCB3C23, (q31_t)0x0710A344, + (q31_t)0x7FCE0C3E, (q31_t)0x06DE7261, (q31_t)0x7FD0C8A3, + (q31_t)0x06AC406F, (q31_t)0x7FD37152, (q31_t)0x067A0D75, + (q31_t)0x7FD6064B, (q31_t)0x0647D97C, (q31_t)0x7FD8878D, + (q31_t)0x0615A48A, (q31_t)0x7FDAF518, (q31_t)0x05E36EA9, + (q31_t)0x7FDD4EEC, (q31_t)0x05B137DF, (q31_t)0x7FDF9508, + (q31_t)0x057F0034, (q31_t)0x7FE1C76B, (q31_t)0x054CC7B0, + (q31_t)0x7FE3E616, (q31_t)0x051A8E5C, (q31_t)0x7FE5F108, + (q31_t)0x04E8543D, (q31_t)0x7FE7E840, (q31_t)0x04B6195D, + (q31_t)0x7FE9CBC0, (q31_t)0x0483DDC3, (q31_t)0x7FEB9B85, + (q31_t)0x0451A176, (q31_t)0x7FED5790, (q31_t)0x041F647F, + (q31_t)0x7FEEFFE1, (q31_t)0x03ED26E6, (q31_t)0x7FF09477, + (q31_t)0x03BAE8B1, (q31_t)0x7FF21553, (q31_t)0x0388A9E9, + (q31_t)0x7FF38273, (q31_t)0x03566A96, (q31_t)0x7FF4DBD8, + (q31_t)0x03242ABF, (q31_t)0x7FF62182, (q31_t)0x02F1EA6B, + (q31_t)0x7FF7536F, (q31_t)0x02BFA9A4, (q31_t)0x7FF871A1, + (q31_t)0x028D6870, (q31_t)0x7FF97C17, (q31_t)0x025B26D7, + (q31_t)0x7FFA72D1, (q31_t)0x0228E4E1, (q31_t)0x7FFB55CE, + (q31_t)0x01F6A296, (q31_t)0x7FFC250F, (q31_t)0x01C45FFE, + (q31_t)0x7FFCE093, (q31_t)0x01921D1F, (q31_t)0x7FFD885A, + (q31_t)0x015FDA03, (q31_t)0x7FFE1C64, (q31_t)0x012D96B0, + (q31_t)0x7FFE9CB2, (q31_t)0x00FB532F, (q31_t)0x7FFF0942, + (q31_t)0x00C90F88, (q31_t)0x7FFF6216, (q31_t)0x0096CBC1, + (q31_t)0x7FFFA72C, (q31_t)0x006487E3, (q31_t)0x7FFFD885, + (q31_t)0x003243F5, (q31_t)0x7FFFF621, (q31_t)0x00000000, + (q31_t)0x7FFFFFFF, (q31_t)0xFFCDBC0A, (q31_t)0x7FFFF621, + (q31_t)0xFF9B781D, (q31_t)0x7FFFD885, (q31_t)0xFF69343E, + (q31_t)0x7FFFA72C, (q31_t)0xFF36F078, (q31_t)0x7FFF6216, + (q31_t)0xFF04ACD0, (q31_t)0x7FFF0942, (q31_t)0xFED2694F, + (q31_t)0x7FFE9CB2, (q31_t)0xFEA025FC, (q31_t)0x7FFE1C64, + (q31_t)0xFE6DE2E0, (q31_t)0x7FFD885A, (q31_t)0xFE3BA001, + (q31_t)0x7FFCE093, (q31_t)0xFE095D69, (q31_t)0x7FFC250F, + (q31_t)0xFDD71B1E, (q31_t)0x7FFB55CE, (q31_t)0xFDA4D928, + (q31_t)0x7FFA72D1, (q31_t)0xFD72978F, (q31_t)0x7FF97C17, + (q31_t)0xFD40565B, (q31_t)0x7FF871A1, (q31_t)0xFD0E1594, + (q31_t)0x7FF7536F, (q31_t)0xFCDBD541, (q31_t)0x7FF62182, + (q31_t)0xFCA99569, (q31_t)0x7FF4DBD8, (q31_t)0xFC775616, + (q31_t)0x7FF38273, (q31_t)0xFC45174E, (q31_t)0x7FF21553, + (q31_t)0xFC12D919, (q31_t)0x7FF09477, (q31_t)0xFBE09B80, + (q31_t)0x7FEEFFE1, (q31_t)0xFBAE5E89, (q31_t)0x7FED5790, + (q31_t)0xFB7C223C, (q31_t)0x7FEB9B85, (q31_t)0xFB49E6A2, + (q31_t)0x7FE9CBC0, (q31_t)0xFB17ABC2, (q31_t)0x7FE7E840, + (q31_t)0xFAE571A4, (q31_t)0x7FE5F108, (q31_t)0xFAB3384F, + (q31_t)0x7FE3E616, (q31_t)0xFA80FFCB, (q31_t)0x7FE1C76B, + (q31_t)0xFA4EC820, (q31_t)0x7FDF9508, (q31_t)0xFA1C9156, + (q31_t)0x7FDD4EEC, (q31_t)0xF9EA5B75, (q31_t)0x7FDAF518, + (q31_t)0xF9B82683, (q31_t)0x7FD8878D, (q31_t)0xF985F28A, + (q31_t)0x7FD6064B, (q31_t)0xF953BF90, (q31_t)0x7FD37152, + (q31_t)0xF9218D9E, (q31_t)0x7FD0C8A3, (q31_t)0xF8EF5CBB, + (q31_t)0x7FCE0C3E, (q31_t)0xF8BD2CEF, (q31_t)0x7FCB3C23, + (q31_t)0xF88AFE41, (q31_t)0x7FC85853, (q31_t)0xF858D0BA, + (q31_t)0x7FC560CF, (q31_t)0xF826A461, (q31_t)0x7FC25596, + (q31_t)0xF7F4793E, (q31_t)0x7FBF36A9, (q31_t)0xF7C24F58, + (q31_t)0x7FBC040A, (q31_t)0xF79026B8, (q31_t)0x7FB8BDB7, + (q31_t)0xF75DFF65, (q31_t)0x7FB563B2, (q31_t)0xF72BD967, + (q31_t)0x7FB1F5FC, (q31_t)0xF6F9B4C5, (q31_t)0x7FAE7494, + (q31_t)0xF6C79188, (q31_t)0x7FAADF7C, (q31_t)0xF6956FB6, + (q31_t)0x7FA736B4, (q31_t)0xF6634F58, (q31_t)0x7FA37A3C, + (q31_t)0xF6313076, (q31_t)0x7F9FAA15, (q31_t)0xF5FF1317, + (q31_t)0x7F9BC63F, (q31_t)0xF5CCF743, (q31_t)0x7F97CEBC, + (q31_t)0xF59ADD01, (q31_t)0x7F93C38C, (q31_t)0xF568C45A, + (q31_t)0x7F8FA4AF, (q31_t)0xF536AD55, (q31_t)0x7F8B7226, + (q31_t)0xF50497FA, (q31_t)0x7F872BF3, (q31_t)0xF4D28451, + (q31_t)0x7F82D214, (q31_t)0xF4A07260, (q31_t)0x7F7E648B, + (q31_t)0xF46E6231, (q31_t)0x7F79E35A, (q31_t)0xF43C53CA, + (q31_t)0x7F754E7F, (q31_t)0xF40A4734, (q31_t)0x7F70A5FD, + (q31_t)0xF3D83C76, (q31_t)0x7F6BE9D4, (q31_t)0xF3A63398, + (q31_t)0x7F671A04, (q31_t)0xF3742CA1, (q31_t)0x7F62368F, + (q31_t)0xF342279A, (q31_t)0x7F5D3F75, (q31_t)0xF310248A, + (q31_t)0x7F5834B6, (q31_t)0xF2DE2378, (q31_t)0x7F531654, + (q31_t)0xF2AC246D, (q31_t)0x7F4DE450, (q31_t)0xF27A2770, + (q31_t)0x7F489EAA, (q31_t)0xF2482C89, (q31_t)0x7F434563, + (q31_t)0xF21633C0, (q31_t)0x7F3DD87C, (q31_t)0xF1E43D1C, + (q31_t)0x7F3857F5, (q31_t)0xF1B248A5, (q31_t)0x7F32C3D0, + (q31_t)0xF1805662, (q31_t)0x7F2D1C0E, (q31_t)0xF14E665C, + (q31_t)0x7F2760AF, (q31_t)0xF11C789A, (q31_t)0x7F2191B4, + (q31_t)0xF0EA8D23, (q31_t)0x7F1BAF1E, (q31_t)0xF0B8A401, + (q31_t)0x7F15B8EE, (q31_t)0xF086BD39, (q31_t)0x7F0FAF24, + (q31_t)0xF054D8D4, (q31_t)0x7F0991C3, (q31_t)0xF022F6DA, + (q31_t)0x7F0360CB, (q31_t)0xEFF11752, (q31_t)0x7EFD1C3C, + (q31_t)0xEFBF3A44, (q31_t)0x7EF6C418, (q31_t)0xEF8D5FB8, + (q31_t)0x7EF0585F, (q31_t)0xEF5B87B5, (q31_t)0x7EE9D913, + (q31_t)0xEF29B243, (q31_t)0x7EE34635, (q31_t)0xEEF7DF6A, + (q31_t)0x7EDC9FC6, (q31_t)0xEEC60F31, (q31_t)0x7ED5E5C6, + (q31_t)0xEE9441A0, (q31_t)0x7ECF1837, (q31_t)0xEE6276BF, + (q31_t)0x7EC8371A, (q31_t)0xEE30AE95, (q31_t)0x7EC1426F, + (q31_t)0xEDFEE92B, (q31_t)0x7EBA3A39, (q31_t)0xEDCD2687, + (q31_t)0x7EB31E77, (q31_t)0xED9B66B2, (q31_t)0x7EABEF2C, + (q31_t)0xED69A9B2, (q31_t)0x7EA4AC58, (q31_t)0xED37EF91, + (q31_t)0x7E9D55FC, (q31_t)0xED063855, (q31_t)0x7E95EC19, + (q31_t)0xECD48406, (q31_t)0x7E8E6EB1, (q31_t)0xECA2D2AC, + (q31_t)0x7E86DDC5, (q31_t)0xEC71244F, (q31_t)0x7E7F3956, + (q31_t)0xEC3F78F5, (q31_t)0x7E778165, (q31_t)0xEC0DD0A8, + (q31_t)0x7E6FB5F3, (q31_t)0xEBDC2B6D, (q31_t)0x7E67D702, + (q31_t)0xEBAA894E, (q31_t)0x7E5FE493, (q31_t)0xEB78EA52, + (q31_t)0x7E57DEA6, (q31_t)0xEB474E80, (q31_t)0x7E4FC53E, + (q31_t)0xEB15B5E0, (q31_t)0x7E47985B, (q31_t)0xEAE4207A, + (q31_t)0x7E3F57FE, (q31_t)0xEAB28E55, (q31_t)0x7E37042A, + (q31_t)0xEA80FF79, (q31_t)0x7E2E9CDF, (q31_t)0xEA4F73EE, + (q31_t)0x7E26221E, (q31_t)0xEA1DEBBB, (q31_t)0x7E1D93E9, + (q31_t)0xE9EC66E8, (q31_t)0x7E14F242, (q31_t)0xE9BAE57C, + (q31_t)0x7E0C3D29, (q31_t)0xE9896780, (q31_t)0x7E03749F, + (q31_t)0xE957ECFB, (q31_t)0x7DFA98A7, (q31_t)0xE92675F4, + (q31_t)0x7DF1A942, (q31_t)0xE8F50273, (q31_t)0x7DE8A670, + (q31_t)0xE8C3927F, (q31_t)0x7DDF9034, (q31_t)0xE8922621, + (q31_t)0x7DD6668E, (q31_t)0xE860BD60, (q31_t)0x7DCD2981, + (q31_t)0xE82F5844, (q31_t)0x7DC3D90D, (q31_t)0xE7FDF6D3, + (q31_t)0x7DBA7534, (q31_t)0xE7CC9917, (q31_t)0x7DB0FDF7, + (q31_t)0xE79B3F16, (q31_t)0x7DA77359, (q31_t)0xE769E8D8, + (q31_t)0x7D9DD55A, (q31_t)0xE7389664, (q31_t)0x7D9423FB, + (q31_t)0xE70747C3, (q31_t)0x7D8A5F3F, (q31_t)0xE6D5FCFC, + (q31_t)0x7D808727, (q31_t)0xE6A4B616, (q31_t)0x7D769BB5, + (q31_t)0xE6737319, (q31_t)0x7D6C9CE9, (q31_t)0xE642340D, + (q31_t)0x7D628AC5, (q31_t)0xE610F8F9, (q31_t)0x7D58654C, + (q31_t)0xE5DFC1E4, (q31_t)0x7D4E2C7E, (q31_t)0xE5AE8ED8, + (q31_t)0x7D43E05E, (q31_t)0xE57D5FDA, (q31_t)0x7D3980EC, + (q31_t)0xE54C34F3, (q31_t)0x7D2F0E2A, (q31_t)0xE51B0E2A, + (q31_t)0x7D24881A, (q31_t)0xE4E9EB86, (q31_t)0x7D19EEBE, + (q31_t)0xE4B8CD10, (q31_t)0x7D0F4218, (q31_t)0xE487B2CF, + (q31_t)0x7D048228, (q31_t)0xE4569CCB, (q31_t)0x7CF9AEF0, + (q31_t)0xE4258B0A, (q31_t)0x7CEEC873, (q31_t)0xE3F47D95, + (q31_t)0x7CE3CEB1, (q31_t)0xE3C37473, (q31_t)0x7CD8C1AD, + (q31_t)0xE3926FAC, (q31_t)0x7CCDA168, (q31_t)0xE3616F47, + (q31_t)0x7CC26DE5, (q31_t)0xE330734C, (q31_t)0x7CB72724, + (q31_t)0xE2FF7BC3, (q31_t)0x7CABCD27, (q31_t)0xE2CE88B2, + (q31_t)0x7CA05FF1, (q31_t)0xE29D9A22, (q31_t)0x7C94DF82, + (q31_t)0xE26CB01A, (q31_t)0x7C894BDD, (q31_t)0xE23BCAA2, + (q31_t)0x7C7DA504, (q31_t)0xE20AE9C1, (q31_t)0x7C71EAF8, + (q31_t)0xE1DA0D7E, (q31_t)0x7C661DBB, (q31_t)0xE1A935E1, + (q31_t)0x7C5A3D4F, (q31_t)0xE17862F3, (q31_t)0x7C4E49B6, + (q31_t)0xE14794B9, (q31_t)0x7C4242F2, (q31_t)0xE116CB3D, + (q31_t)0x7C362904, (q31_t)0xE0E60684, (q31_t)0x7C29FBEE, + (q31_t)0xE0B54698, (q31_t)0x7C1DBBB2, (q31_t)0xE0848B7F, + (q31_t)0x7C116853, (q31_t)0xE053D541, (q31_t)0x7C0501D1, + (q31_t)0xE02323E5, (q31_t)0x7BF88830, (q31_t)0xDFF27773, + (q31_t)0x7BEBFB70, (q31_t)0xDFC1CFF2, (q31_t)0x7BDF5B94, + (q31_t)0xDF912D6A, (q31_t)0x7BD2A89E, (q31_t)0xDF608FE3, + (q31_t)0x7BC5E28F, (q31_t)0xDF2FF764, (q31_t)0x7BB9096A, + (q31_t)0xDEFF63F4, (q31_t)0x7BAC1D31, (q31_t)0xDECED59B, + (q31_t)0x7B9F1DE5, (q31_t)0xDE9E4C60, (q31_t)0x7B920B89, + (q31_t)0xDE6DC84B, (q31_t)0x7B84E61E, (q31_t)0xDE3D4963, + (q31_t)0x7B77ADA8, (q31_t)0xDE0CCFB1, (q31_t)0x7B6A6227, + (q31_t)0xDDDC5B3A, (q31_t)0x7B5D039D, (q31_t)0xDDABEC07, + (q31_t)0x7B4F920E, (q31_t)0xDD7B8220, (q31_t)0x7B420D7A, + (q31_t)0xDD4B1D8B, (q31_t)0x7B3475E4, (q31_t)0xDD1ABE51, + (q31_t)0x7B26CB4F, (q31_t)0xDCEA6478, (q31_t)0x7B190DBB, + (q31_t)0xDCBA1008, (q31_t)0x7B0B3D2C, (q31_t)0xDC89C108, + (q31_t)0x7AFD59A3, (q31_t)0xDC597781, (q31_t)0x7AEF6323, + (q31_t)0xDC293379, (q31_t)0x7AE159AE, (q31_t)0xDBF8F4F8, + (q31_t)0x7AD33D45, (q31_t)0xDBC8BC05, (q31_t)0x7AC50DEB, + (q31_t)0xDB9888A8, (q31_t)0x7AB6CBA3, (q31_t)0xDB685AE8, + (q31_t)0x7AA8766E, (q31_t)0xDB3832CD, (q31_t)0x7A9A0E4F, + (q31_t)0xDB08105E, (q31_t)0x7A8B9348, (q31_t)0xDAD7F3A2, + (q31_t)0x7A7D055B, (q31_t)0xDAA7DCA1, (q31_t)0x7A6E648A, + (q31_t)0xDA77CB62, (q31_t)0x7A5FB0D8, (q31_t)0xDA47BFED, + (q31_t)0x7A50EA46, (q31_t)0xDA17BA4A, (q31_t)0x7A4210D8, + (q31_t)0xD9E7BA7E, (q31_t)0x7A33248F, (q31_t)0xD9B7C093, + (q31_t)0x7A24256E, (q31_t)0xD987CC8F, (q31_t)0x7A151377, + (q31_t)0xD957DE7A, (q31_t)0x7A05EEAD, (q31_t)0xD927F65B, + (q31_t)0x79F6B711, (q31_t)0xD8F81439, (q31_t)0x79E76CA6, + (q31_t)0xD8C8381C, (q31_t)0x79D80F6F, (q31_t)0xD898620C, + (q31_t)0x79C89F6D, (q31_t)0xD868920F, (q31_t)0x79B91CA4, + (q31_t)0xD838C82D, (q31_t)0x79A98715, (q31_t)0xD809046D, + (q31_t)0x7999DEC3, (q31_t)0xD7D946D7, (q31_t)0x798A23B1, + (q31_t)0xD7A98F73, (q31_t)0x797A55E0, (q31_t)0xD779DE46, + (q31_t)0x796A7554, (q31_t)0xD74A335A, (q31_t)0x795A820E, + (q31_t)0xD71A8EB5, (q31_t)0x794A7C11, (q31_t)0xD6EAF05E, + (q31_t)0x793A6360, (q31_t)0xD6BB585D, (q31_t)0x792A37FE, + (q31_t)0xD68BC6BA, (q31_t)0x7919F9EB, (q31_t)0xD65C3B7B, + (q31_t)0x7909A92C, (q31_t)0xD62CB6A7, (q31_t)0x78F945C3, + (q31_t)0xD5FD3847, (q31_t)0x78E8CFB1, (q31_t)0xD5CDC062, + (q31_t)0x78D846FB, (q31_t)0xD59E4EFE, (q31_t)0x78C7ABA1, + (q31_t)0xD56EE424, (q31_t)0x78B6FDA8, (q31_t)0xD53F7FDA, + (q31_t)0x78A63D10, (q31_t)0xD5102227, (q31_t)0x789569DE, + (q31_t)0xD4E0CB14, (q31_t)0x78848413, (q31_t)0xD4B17AA7, + (q31_t)0x78738BB3, (q31_t)0xD48230E8, (q31_t)0x786280BF, + (q31_t)0xD452EDDE, (q31_t)0x7851633B, (q31_t)0xD423B190, + (q31_t)0x78403328, (q31_t)0xD3F47C06, (q31_t)0x782EF08B, + (q31_t)0xD3C54D46, (q31_t)0x781D9B64, (q31_t)0xD3962559, + (q31_t)0x780C33B8, (q31_t)0xD3670445, (q31_t)0x77FAB988, + (q31_t)0xD337EA12, (q31_t)0x77E92CD8, (q31_t)0xD308D6C6, + (q31_t)0x77D78DAA, (q31_t)0xD2D9CA6A, (q31_t)0x77C5DC01, + (q31_t)0xD2AAC504, (q31_t)0x77B417DF, (q31_t)0xD27BC69C, + (q31_t)0x77A24148, (q31_t)0xD24CCF38, (q31_t)0x7790583D, + (q31_t)0xD21DDEE1, (q31_t)0x777E5CC3, (q31_t)0xD1EEF59E, + (q31_t)0x776C4EDB, (q31_t)0xD1C01374, (q31_t)0x775A2E88, + (q31_t)0xD191386D, (q31_t)0x7747FBCE, (q31_t)0xD162648F, + (q31_t)0x7735B6AE, (q31_t)0xD13397E1, (q31_t)0x77235F2D, + (q31_t)0xD104D26B, (q31_t)0x7710F54B, (q31_t)0xD0D61433, + (q31_t)0x76FE790E, (q31_t)0xD0A75D42, (q31_t)0x76EBEA77, + (q31_t)0xD078AD9D, (q31_t)0x76D94988, (q31_t)0xD04A054D, + (q31_t)0x76C69646, (q31_t)0xD01B6459, (q31_t)0x76B3D0B3, + (q31_t)0xCFECCAC7, (q31_t)0x76A0F8D2, (q31_t)0xCFBE389F, + (q31_t)0x768E0EA5, (q31_t)0xCF8FADE8, (q31_t)0x767B1230, + (q31_t)0xCF612AAA, (q31_t)0x76680376, (q31_t)0xCF32AEEB, + (q31_t)0x7654E279, (q31_t)0xCF043AB2, (q31_t)0x7641AF3C, + (q31_t)0xCED5CE08, (q31_t)0x762E69C3, (q31_t)0xCEA768F2, + (q31_t)0x761B1211, (q31_t)0xCE790B78, (q31_t)0x7607A827, + (q31_t)0xCE4AB5A2, (q31_t)0x75F42C0A, (q31_t)0xCE1C6776, + (q31_t)0x75E09DBD, (q31_t)0xCDEE20FC, (q31_t)0x75CCFD42, + (q31_t)0xCDBFE23A, (q31_t)0x75B94A9C, (q31_t)0xCD91AB38, + (q31_t)0x75A585CF, (q31_t)0xCD637BFD, (q31_t)0x7591AEDD, + (q31_t)0xCD355490, (q31_t)0x757DC5CA, (q31_t)0xCD0734F8, + (q31_t)0x7569CA98, (q31_t)0xCCD91D3D, (q31_t)0x7555BD4B, + (q31_t)0xCCAB0D65, (q31_t)0x75419DE6, (q31_t)0xCC7D0577, + (q31_t)0x752D6C6C, (q31_t)0xCC4F057B, (q31_t)0x751928E0, + (q31_t)0xCC210D78, (q31_t)0x7504D345, (q31_t)0xCBF31D75, + (q31_t)0x74F06B9E, (q31_t)0xCBC53578, (q31_t)0x74DBF1EF, + (q31_t)0xCB975589, (q31_t)0x74C7663A, (q31_t)0xCB697DB0, + (q31_t)0x74B2C883, (q31_t)0xCB3BADF2, (q31_t)0x749E18CD, + (q31_t)0xCB0DE658, (q31_t)0x7489571B, (q31_t)0xCAE026E8, + (q31_t)0x74748371, (q31_t)0xCAB26FA9, (q31_t)0x745F9DD1, + (q31_t)0xCA84C0A2, (q31_t)0x744AA63E, (q31_t)0xCA5719DB, + (q31_t)0x74359CBD, (q31_t)0xCA297B5A, (q31_t)0x74208150, + (q31_t)0xC9FBE527, (q31_t)0x740B53FA, (q31_t)0xC9CE5748, + (q31_t)0x73F614C0, (q31_t)0xC9A0D1C4, (q31_t)0x73E0C3A3, + (q31_t)0xC97354A3, (q31_t)0x73CB60A7, (q31_t)0xC945DFEC, + (q31_t)0x73B5EBD0, (q31_t)0xC91873A5, (q31_t)0x73A06522, + (q31_t)0xC8EB0FD6, (q31_t)0x738ACC9E, (q31_t)0xC8BDB485, + (q31_t)0x73752249, (q31_t)0xC89061BA, (q31_t)0x735F6626, + (q31_t)0xC863177B, (q31_t)0x73499838, (q31_t)0xC835D5D0, + (q31_t)0x7333B883, (q31_t)0xC8089CBF, (q31_t)0x731DC709, + (q31_t)0xC7DB6C50, (q31_t)0x7307C3D0, (q31_t)0xC7AE4489, + (q31_t)0x72F1AED8, (q31_t)0xC7812571, (q31_t)0x72DB8828, + (q31_t)0xC7540F10, (q31_t)0x72C54FC0, (q31_t)0xC727016C, + (q31_t)0x72AF05A6, (q31_t)0xC6F9FC8D, (q31_t)0x7298A9DC, + (q31_t)0xC6CD0079, (q31_t)0x72823C66, (q31_t)0xC6A00D36, + (q31_t)0x726BBD48, (q31_t)0xC67322CD, (q31_t)0x72552C84, + (q31_t)0xC6464144, (q31_t)0x723E8A1F, (q31_t)0xC61968A2, + (q31_t)0x7227D61C, (q31_t)0xC5EC98ED, (q31_t)0x7211107D, + (q31_t)0xC5BFD22E, (q31_t)0x71FA3948, (q31_t)0xC593146A, + (q31_t)0x71E3507F, (q31_t)0xC5665FA8, (q31_t)0x71CC5626, + (q31_t)0xC539B3F0, (q31_t)0x71B54A40, (q31_t)0xC50D1148, + (q31_t)0x719E2CD2, (q31_t)0xC4E077B8, (q31_t)0x7186FDDE, + (q31_t)0xC4B3E746, (q31_t)0x716FBD68, (q31_t)0xC4875FF8, + (q31_t)0x71586B73, (q31_t)0xC45AE1D7, (q31_t)0x71410804, + (q31_t)0xC42E6CE8, (q31_t)0x7129931E, (q31_t)0xC4020132, + (q31_t)0x71120CC5, (q31_t)0xC3D59EBD, (q31_t)0x70FA74FB, + (q31_t)0xC3A9458F, (q31_t)0x70E2CBC6, (q31_t)0xC37CF5B0, + (q31_t)0x70CB1127, (q31_t)0xC350AF25, (q31_t)0x70B34524, + (q31_t)0xC32471F6, (q31_t)0x709B67C0, (q31_t)0xC2F83E2A, + (q31_t)0x708378FE, (q31_t)0xC2CC13C7, (q31_t)0x706B78E3, + (q31_t)0xC29FF2D4, (q31_t)0x70536771, (q31_t)0xC273DB58, + (q31_t)0x703B44AC, (q31_t)0xC247CD5A, (q31_t)0x70231099, + (q31_t)0xC21BC8E0, (q31_t)0x700ACB3B, (q31_t)0xC1EFCDF2, + (q31_t)0x6FF27496, (q31_t)0xC1C3DC96, (q31_t)0x6FDA0CAD, + (q31_t)0xC197F4D3, (q31_t)0x6FC19385, (q31_t)0xC16C16B0, + (q31_t)0x6FA90920, (q31_t)0xC1404233, (q31_t)0x6F906D84, + (q31_t)0xC1147763, (q31_t)0x6F77C0B3, (q31_t)0xC0E8B648, + (q31_t)0x6F5F02B1, (q31_t)0xC0BCFEE7, (q31_t)0x6F463383, + (q31_t)0xC0915147, (q31_t)0x6F2D532C, (q31_t)0xC065AD70, + (q31_t)0x6F1461AF, (q31_t)0xC03A1368, (q31_t)0x6EFB5F12, + (q31_t)0xC00E8335, (q31_t)0x6EE24B57, (q31_t)0xBFE2FCDF, + (q31_t)0x6EC92682, (q31_t)0xBFB7806C, (q31_t)0x6EAFF098, + (q31_t)0xBF8C0DE2, (q31_t)0x6E96A99C, (q31_t)0xBF60A54A, + (q31_t)0x6E7D5193, (q31_t)0xBF3546A8, (q31_t)0x6E63E87F, + (q31_t)0xBF09F204, (q31_t)0x6E4A6E65, (q31_t)0xBEDEA765, + (q31_t)0x6E30E349, (q31_t)0xBEB366D1, (q31_t)0x6E17472F, + (q31_t)0xBE88304F, (q31_t)0x6DFD9A1B, (q31_t)0xBE5D03E5, + (q31_t)0x6DE3DC11, (q31_t)0xBE31E19B, (q31_t)0x6DCA0D14, + (q31_t)0xBE06C977, (q31_t)0x6DB02D29, (q31_t)0xBDDBBB7F, + (q31_t)0x6D963C54, (q31_t)0xBDB0B7BA, (q31_t)0x6D7C3A98, + (q31_t)0xBD85BE2F, (q31_t)0x6D6227FA, (q31_t)0xBD5ACEE5, + (q31_t)0x6D48047E, (q31_t)0xBD2FE9E1, (q31_t)0x6D2DD027, + (q31_t)0xBD050F2C, (q31_t)0x6D138AFA, (q31_t)0xBCDA3ECA, + (q31_t)0x6CF934FB, (q31_t)0xBCAF78C3, (q31_t)0x6CDECE2E, + (q31_t)0xBC84BD1E, (q31_t)0x6CC45697, (q31_t)0xBC5A0BE1, + (q31_t)0x6CA9CE3A, (q31_t)0xBC2F6513, (q31_t)0x6C8F351C, + (q31_t)0xBC04C8BA, (q31_t)0x6C748B3F, (q31_t)0xBBDA36DC, + (q31_t)0x6C59D0A9, (q31_t)0xBBAFAF81, (q31_t)0x6C3F055D, + (q31_t)0xBB8532AF, (q31_t)0x6C242960, (q31_t)0xBB5AC06C, + (q31_t)0x6C093CB6, (q31_t)0xBB3058C0, (q31_t)0x6BEE3F62, + (q31_t)0xBB05FBB0, (q31_t)0x6BD3316A, (q31_t)0xBADBA943, + (q31_t)0x6BB812D0, (q31_t)0xBAB1617F, (q31_t)0x6B9CE39B, + (q31_t)0xBA87246C, (q31_t)0x6B81A3CD, (q31_t)0xBA5CF210, + (q31_t)0x6B66536A, (q31_t)0xBA32CA70, (q31_t)0x6B4AF278, + (q31_t)0xBA08AD94, (q31_t)0x6B2F80FA, (q31_t)0xB9DE9B83, + (q31_t)0x6B13FEF5, (q31_t)0xB9B49442, (q31_t)0x6AF86C6C, + (q31_t)0xB98A97D8, (q31_t)0x6ADCC964, (q31_t)0xB960A64B, + (q31_t)0x6AC115E1, (q31_t)0xB936BFA3, (q31_t)0x6AA551E8, + (q31_t)0xB90CE3E6, (q31_t)0x6A897D7D, (q31_t)0xB8E31319, + (q31_t)0x6A6D98A4, (q31_t)0xB8B94D44, (q31_t)0x6A51A361, + (q31_t)0xB88F926C, (q31_t)0x6A359DB9, (q31_t)0xB865E299, + (q31_t)0x6A1987B0, (q31_t)0xB83C3DD1, (q31_t)0x69FD614A, + (q31_t)0xB812A419, (q31_t)0x69E12A8C, (q31_t)0xB7E9157A, + (q31_t)0x69C4E37A, (q31_t)0xB7BF91F8, (q31_t)0x69A88C18, + (q31_t)0xB796199B, (q31_t)0x698C246C, (q31_t)0xB76CAC68, + (q31_t)0x696FAC78, (q31_t)0xB7434A67, (q31_t)0x69532442, + (q31_t)0xB719F39D, (q31_t)0x69368BCE, (q31_t)0xB6F0A811, + (q31_t)0x6919E320, (q31_t)0xB6C767CA, (q31_t)0x68FD2A3D, + (q31_t)0xB69E32CD, (q31_t)0x68E06129, (q31_t)0xB6750921, + (q31_t)0x68C387E9, (q31_t)0xB64BEACC, (q31_t)0x68A69E81, + (q31_t)0xB622D7D5, (q31_t)0x6889A4F5, (q31_t)0xB5F9D042, + (q31_t)0x686C9B4B, (q31_t)0xB5D0D41A, (q31_t)0x684F8186, + (q31_t)0xB5A7E362, (q31_t)0x683257AA, (q31_t)0xB57EFE21, + (q31_t)0x68151DBE, (q31_t)0xB556245E, (q31_t)0x67F7D3C4, + (q31_t)0xB52D561E, (q31_t)0x67DA79C2, (q31_t)0xB5049368, + (q31_t)0x67BD0FBC, (q31_t)0xB4DBDC42, (q31_t)0x679F95B7, + (q31_t)0xB4B330B2, (q31_t)0x67820BB6, (q31_t)0xB48A90C0, + (q31_t)0x676471C0, (q31_t)0xB461FC70, (q31_t)0x6746C7D7, + (q31_t)0xB43973C9, (q31_t)0x67290E02, (q31_t)0xB410F6D2, + (q31_t)0x670B4443, (q31_t)0xB3E88591, (q31_t)0x66ED6AA1, + (q31_t)0xB3C0200C, (q31_t)0x66CF811F, (q31_t)0xB397C649, + (q31_t)0x66B187C3, (q31_t)0xB36F784E, (q31_t)0x66937E90, + (q31_t)0xB3473622, (q31_t)0x6675658C, (q31_t)0xB31EFFCB, + (q31_t)0x66573CBB, (q31_t)0xB2F6D54F, (q31_t)0x66390422, + (q31_t)0xB2CEB6B5, (q31_t)0x661ABBC5, (q31_t)0xB2A6A401, + (q31_t)0x65FC63A9, (q31_t)0xB27E9D3B, (q31_t)0x65DDFBD3, + (q31_t)0xB256A26A, (q31_t)0x65BF8447, (q31_t)0xB22EB392, + (q31_t)0x65A0FD0B, (q31_t)0xB206D0BA, (q31_t)0x65826622, + (q31_t)0xB1DEF9E8, (q31_t)0x6563BF92, (q31_t)0xB1B72F23, + (q31_t)0x6545095F, (q31_t)0xB18F7070, (q31_t)0x6526438E, + (q31_t)0xB167BDD6, (q31_t)0x65076E24, (q31_t)0xB140175B, + (q31_t)0x64E88926, (q31_t)0xB1187D05, (q31_t)0x64C99498, + (q31_t)0xB0F0EEDA, (q31_t)0x64AA907F, (q31_t)0xB0C96CDF, + (q31_t)0x648B7CDF, (q31_t)0xB0A1F71C, (q31_t)0x646C59BF, + (q31_t)0xB07A8D97, (q31_t)0x644D2722, (q31_t)0xB0533055, + (q31_t)0x642DE50D, (q31_t)0xB02BDF5C, (q31_t)0x640E9385, + (q31_t)0xB0049AB2, (q31_t)0x63EF328F, (q31_t)0xAFDD625F, + (q31_t)0x63CFC230, (q31_t)0xAFB63667, (q31_t)0x63B0426D, + (q31_t)0xAF8F16D0, (q31_t)0x6390B34A, (q31_t)0xAF6803A1, + (q31_t)0x637114CC, (q31_t)0xAF40FCE0, (q31_t)0x635166F8, + (q31_t)0xAF1A0293, (q31_t)0x6331A9D4, (q31_t)0xAEF314BF, + (q31_t)0x6311DD63, (q31_t)0xAECC336B, (q31_t)0x62F201AC, + (q31_t)0xAEA55E9D, (q31_t)0x62D216B2, (q31_t)0xAE7E965B, + (q31_t)0x62B21C7B, (q31_t)0xAE57DAAA, (q31_t)0x6292130C, + (q31_t)0xAE312B91, (q31_t)0x6271FA69, (q31_t)0xAE0A8916, + (q31_t)0x6251D297, (q31_t)0xADE3F33E, (q31_t)0x62319B9D, + (q31_t)0xADBD6A10, (q31_t)0x6211557D, (q31_t)0xAD96ED91, + (q31_t)0x61F1003E, (q31_t)0xAD707DC8, (q31_t)0x61D09BE5, + (q31_t)0xAD4A1ABA, (q31_t)0x61B02876, (q31_t)0xAD23C46D, + (q31_t)0x618FA5F6, (q31_t)0xACFD7AE8, (q31_t)0x616F146B, + (q31_t)0xACD73E30, (q31_t)0x614E73D9, (q31_t)0xACB10E4A, + (q31_t)0x612DC446, (q31_t)0xAC8AEB3E, (q31_t)0x610D05B7, + (q31_t)0xAC64D510, (q31_t)0x60EC3830, (q31_t)0xAC3ECBC7, + (q31_t)0x60CB5BB6, (q31_t)0xAC18CF68, (q31_t)0x60AA704F, + (q31_t)0xABF2DFFA, (q31_t)0x60897600, (q31_t)0xABCCFD82, + (q31_t)0x60686CCE, (q31_t)0xABA72806, (q31_t)0x604754BE, + (q31_t)0xAB815F8C, (q31_t)0x60262DD5, (q31_t)0xAB5BA41A, + (q31_t)0x6004F818, (q31_t)0xAB35F5B5, (q31_t)0x5FE3B38D, + (q31_t)0xAB105464, (q31_t)0x5FC26038, (q31_t)0xAAEAC02B, + (q31_t)0x5FA0FE1E, (q31_t)0xAAC53912, (q31_t)0x5F7F8D46, + (q31_t)0xAA9FBF1D, (q31_t)0x5F5E0DB3, (q31_t)0xAA7A5253, + (q31_t)0x5F3C7F6B, (q31_t)0xAA54F2B9, (q31_t)0x5F1AE273, + (q31_t)0xAA2FA055, (q31_t)0x5EF936D1, (q31_t)0xAA0A5B2D, + (q31_t)0x5ED77C89, (q31_t)0xA9E52347, (q31_t)0x5EB5B3A1, + (q31_t)0xA9BFF8A8, (q31_t)0x5E93DC1F, (q31_t)0xA99ADB56, + (q31_t)0x5E71F606, (q31_t)0xA975CB56, (q31_t)0x5E50015D, + (q31_t)0xA950C8AF, (q31_t)0x5E2DFE28, (q31_t)0xA92BD366, + (q31_t)0x5E0BEC6E, (q31_t)0xA906EB81, (q31_t)0x5DE9CC32, + (q31_t)0xA8E21106, (q31_t)0x5DC79D7C, (q31_t)0xA8BD43FA, + (q31_t)0x5DA5604E, (q31_t)0xA8988463, (q31_t)0x5D8314B0, + (q31_t)0xA873D246, (q31_t)0x5D60BAA6, (q31_t)0xA84F2DA9, + (q31_t)0x5D3E5236, (q31_t)0xA82A9693, (q31_t)0x5D1BDB65, + (q31_t)0xA8060D08, (q31_t)0x5CF95638, (q31_t)0xA7E1910E, + (q31_t)0x5CD6C2B4, (q31_t)0xA7BD22AB, (q31_t)0x5CB420DF, + (q31_t)0xA798C1E4, (q31_t)0x5C9170BF, (q31_t)0xA7746EC0, + (q31_t)0x5C6EB258, (q31_t)0xA7502943, (q31_t)0x5C4BE5B0, + (q31_t)0xA72BF173, (q31_t)0x5C290ACC, (q31_t)0xA707C756, + (q31_t)0x5C0621B2, (q31_t)0xA6E3AAF2, (q31_t)0x5BE32A67, + (q31_t)0xA6BF9C4B, (q31_t)0x5BC024F0, (q31_t)0xA69B9B68, + (q31_t)0x5B9D1153, (q31_t)0xA677A84E, (q31_t)0x5B79EF96, + (q31_t)0xA653C302, (q31_t)0x5B56BFBD, (q31_t)0xA62FEB8B, + (q31_t)0x5B3381CE, (q31_t)0xA60C21ED, (q31_t)0x5B1035CF, + (q31_t)0xA5E8662F, (q31_t)0x5AECDBC4, (q31_t)0xA5C4B855, + (q31_t)0x5AC973B4, (q31_t)0xA5A11865, (q31_t)0x5AA5FDA4, + (q31_t)0xA57D8666, (q31_t)0x5A82799A, (q31_t)0xA55A025B, + (q31_t)0x5A5EE79A, (q31_t)0xA5368C4B, (q31_t)0x5A3B47AA, + (q31_t)0xA513243B, (q31_t)0x5A1799D0, (q31_t)0xA4EFCA31, + (q31_t)0x59F3DE12, (q31_t)0xA4CC7E31, (q31_t)0x59D01474, + (q31_t)0xA4A94042, (q31_t)0x59AC3CFD, (q31_t)0xA4861069, + (q31_t)0x598857B1, (q31_t)0xA462EEAC, (q31_t)0x59646497, + (q31_t)0xA43FDB0F, (q31_t)0x594063B4, (q31_t)0xA41CD598, + (q31_t)0x591C550E, (q31_t)0xA3F9DE4D, (q31_t)0x58F838A9, + (q31_t)0xA3D6F533, (q31_t)0x58D40E8C, (q31_t)0xA3B41A4F, + (q31_t)0x58AFD6BC, (q31_t)0xA3914DA7, (q31_t)0x588B913F, + (q31_t)0xA36E8F40, (q31_t)0x58673E1B, (q31_t)0xA34BDF20, + (q31_t)0x5842DD54, (q31_t)0xA3293D4B, (q31_t)0x581E6EF1, + (q31_t)0xA306A9C7, (q31_t)0x57F9F2F7, (q31_t)0xA2E4249A, + (q31_t)0x57D5696C, (q31_t)0xA2C1ADC9, (q31_t)0x57B0D256, + (q31_t)0xA29F4559, (q31_t)0x578C2DB9, (q31_t)0xA27CEB4F, + (q31_t)0x57677B9D, (q31_t)0xA25A9FB1, (q31_t)0x5742BC05, + (q31_t)0xA2386283, (q31_t)0x571DEEF9, (q31_t)0xA21633CD, + (q31_t)0x56F9147E, (q31_t)0xA1F41391, (q31_t)0x56D42C99, + (q31_t)0xA1D201D7, (q31_t)0x56AF3750, (q31_t)0xA1AFFEA2, + (q31_t)0x568A34A9, (q31_t)0xA18E09F9, (q31_t)0x566524AA, + (q31_t)0xA16C23E1, (q31_t)0x56400757, (q31_t)0xA14A4C5E, + (q31_t)0x561ADCB8, (q31_t)0xA1288376, (q31_t)0x55F5A4D2, + (q31_t)0xA106C92E, (q31_t)0x55D05FAA, (q31_t)0xA0E51D8C, + (q31_t)0x55AB0D46, (q31_t)0xA0C38094, (q31_t)0x5585ADAC, + (q31_t)0xA0A1F24C, (q31_t)0x556040E2, (q31_t)0xA08072BA, + (q31_t)0x553AC6ED, (q31_t)0xA05F01E1, (q31_t)0x55153FD4, + (q31_t)0xA03D9FC7, (q31_t)0x54EFAB9C, (q31_t)0xA01C4C72, + (q31_t)0x54CA0A4A, (q31_t)0x9FFB07E7, (q31_t)0x54A45BE5, + (q31_t)0x9FD9D22A, (q31_t)0x547EA073, (q31_t)0x9FB8AB41, + (q31_t)0x5458D7F9, (q31_t)0x9F979331, (q31_t)0x5433027D, + (q31_t)0x9F7689FF, (q31_t)0x540D2005, (q31_t)0x9F558FB0, + (q31_t)0x53E73097, (q31_t)0x9F34A449, (q31_t)0x53C13438, + (q31_t)0x9F13C7D0, (q31_t)0x539B2AEF, (q31_t)0x9EF2FA48, + (q31_t)0x537514C1, (q31_t)0x9ED23BB9, (q31_t)0x534EF1B5, + (q31_t)0x9EB18C26, (q31_t)0x5328C1D0, (q31_t)0x9E90EB94, + (q31_t)0x53028517, (q31_t)0x9E705A09, (q31_t)0x52DC3B92, + (q31_t)0x9E4FD789, (q31_t)0x52B5E545, (q31_t)0x9E2F641A, + (q31_t)0x528F8237, (q31_t)0x9E0EFFC1, (q31_t)0x5269126E, + (q31_t)0x9DEEAA82, (q31_t)0x524295EF, (q31_t)0x9DCE6462, + (q31_t)0x521C0CC1, (q31_t)0x9DAE2D68, (q31_t)0x51F576E9, + (q31_t)0x9D8E0596, (q31_t)0x51CED46E, (q31_t)0x9D6DECF4, + (q31_t)0x51A82555, (q31_t)0x9D4DE384, (q31_t)0x518169A4, + (q31_t)0x9D2DE94D, (q31_t)0x515AA162, (q31_t)0x9D0DFE53, + (q31_t)0x5133CC94, (q31_t)0x9CEE229C, (q31_t)0x510CEB40, + (q31_t)0x9CCE562B, (q31_t)0x50E5FD6C, (q31_t)0x9CAE9907, + (q31_t)0x50BF031F, (q31_t)0x9C8EEB33, (q31_t)0x5097FC5E, + (q31_t)0x9C6F4CB5, (q31_t)0x5070E92F, (q31_t)0x9C4FBD92, + (q31_t)0x5049C999, (q31_t)0x9C303DCF, (q31_t)0x50229DA0, + (q31_t)0x9C10CD70, (q31_t)0x4FFB654D, (q31_t)0x9BF16C7A, + (q31_t)0x4FD420A3, (q31_t)0x9BD21AF2, (q31_t)0x4FACCFAB, + (q31_t)0x9BB2D8DD, (q31_t)0x4F857268, (q31_t)0x9B93A640, + (q31_t)0x4F5E08E3, (q31_t)0x9B748320, (q31_t)0x4F369320, + (q31_t)0x9B556F80, (q31_t)0x4F0F1126, (q31_t)0x9B366B67, + (q31_t)0x4EE782FA, (q31_t)0x9B1776D9, (q31_t)0x4EBFE8A4, + (q31_t)0x9AF891DB, (q31_t)0x4E984229, (q31_t)0x9AD9BC71, + (q31_t)0x4E708F8F, (q31_t)0x9ABAF6A0, (q31_t)0x4E48D0DC, + (q31_t)0x9A9C406D, (q31_t)0x4E210617, (q31_t)0x9A7D99DD, + (q31_t)0x4DF92F45, (q31_t)0x9A5F02F5, (q31_t)0x4DD14C6E, + (q31_t)0x9A407BB8, (q31_t)0x4DA95D96, (q31_t)0x9A22042C, + (q31_t)0x4D8162C4, (q31_t)0x9A039C56, (q31_t)0x4D595BFE, + (q31_t)0x99E5443A, (q31_t)0x4D31494B, (q31_t)0x99C6FBDE, + (q31_t)0x4D092AB0, (q31_t)0x99A8C344, (q31_t)0x4CE10034, + (q31_t)0x998A9A73, (q31_t)0x4CB8C9DD, (q31_t)0x996C816F, + (q31_t)0x4C9087B1, (q31_t)0x994E783C, (q31_t)0x4C6839B6, + (q31_t)0x99307EE0, (q31_t)0x4C3FDFF3, (q31_t)0x9912955E, + (q31_t)0x4C177A6E, (q31_t)0x98F4BBBC, (q31_t)0x4BEF092D, + (q31_t)0x98D6F1FE, (q31_t)0x4BC68C36, (q31_t)0x98B93828, + (q31_t)0x4B9E038F, (q31_t)0x989B8E3F, (q31_t)0x4B756F3F, + (q31_t)0x987DF449, (q31_t)0x4B4CCF4D, (q31_t)0x98606A48, + (q31_t)0x4B2423BD, (q31_t)0x9842F043, (q31_t)0x4AFB6C97, + (q31_t)0x9825863D, (q31_t)0x4AD2A9E1, (q31_t)0x98082C3B, + (q31_t)0x4AA9DBA1, (q31_t)0x97EAE241, (q31_t)0x4A8101DE, + (q31_t)0x97CDA855, (q31_t)0x4A581C9D, (q31_t)0x97B07E7A, + (q31_t)0x4A2F2BE5, (q31_t)0x979364B5, (q31_t)0x4A062FBD, + (q31_t)0x97765B0A, (q31_t)0x49DD282A, (q31_t)0x9759617E, + (q31_t)0x49B41533, (q31_t)0x973C7816, (q31_t)0x498AF6DE, + (q31_t)0x971F9ED6, (q31_t)0x4961CD32, (q31_t)0x9702D5C2, + (q31_t)0x49389836, (q31_t)0x96E61CDF, (q31_t)0x490F57EE, + (q31_t)0x96C97431, (q31_t)0x48E60C62, (q31_t)0x96ACDBBD, + (q31_t)0x48BCB598, (q31_t)0x96905387, (q31_t)0x48935397, + (q31_t)0x9673DB94, (q31_t)0x4869E664, (q31_t)0x965773E7, + (q31_t)0x48406E07, (q31_t)0x963B1C85, (q31_t)0x4816EA85, + (q31_t)0x961ED573, (q31_t)0x47ED5BE6, (q31_t)0x96029EB5, + (q31_t)0x47C3C22E, (q31_t)0x95E6784F, (q31_t)0x479A1D66, + (q31_t)0x95CA6246, (q31_t)0x47706D93, (q31_t)0x95AE5C9E, + (q31_t)0x4746B2BC, (q31_t)0x9592675B, (q31_t)0x471CECE6, + (q31_t)0x95768282, (q31_t)0x46F31C1A, (q31_t)0x955AAE17, + (q31_t)0x46C9405C, (q31_t)0x953EEA1E, (q31_t)0x469F59B4, + (q31_t)0x9523369B, (q31_t)0x46756827, (q31_t)0x95079393, + (q31_t)0x464B6BBD, (q31_t)0x94EC010B, (q31_t)0x4621647C, + (q31_t)0x94D07F05, (q31_t)0x45F7526B, (q31_t)0x94B50D87, + (q31_t)0x45CD358F, (q31_t)0x9499AC95, (q31_t)0x45A30DF0, + (q31_t)0x947E5C32, (q31_t)0x4578DB93, (q31_t)0x94631C64, + (q31_t)0x454E9E80, (q31_t)0x9447ED2F, (q31_t)0x452456BC, + (q31_t)0x942CCE95, (q31_t)0x44FA044F, (q31_t)0x9411C09D, + (q31_t)0x44CFA73F, (q31_t)0x93F6C34A, (q31_t)0x44A53F93, + (q31_t)0x93DBD69F, (q31_t)0x447ACD50, (q31_t)0x93C0FAA2, + (q31_t)0x4450507E, (q31_t)0x93A62F56, (q31_t)0x4425C923, + (q31_t)0x938B74C0, (q31_t)0x43FB3745, (q31_t)0x9370CAE4, + (q31_t)0x43D09AEC, (q31_t)0x935631C5, (q31_t)0x43A5F41E, + (q31_t)0x933BA968, (q31_t)0x437B42E1, (q31_t)0x932131D1, + (q31_t)0x4350873C, (q31_t)0x9306CB04, (q31_t)0x4325C135, + (q31_t)0x92EC7505, (q31_t)0x42FAF0D4, (q31_t)0x92D22FD8, + (q31_t)0x42D0161E, (q31_t)0x92B7FB82, (q31_t)0x42A5311A, + (q31_t)0x929DD805, (q31_t)0x427A41D0, (q31_t)0x9283C567, + (q31_t)0x424F4845, (q31_t)0x9269C3AC, (q31_t)0x42244480, + (q31_t)0x924FD2D6, (q31_t)0x41F93688, (q31_t)0x9235F2EB, + (q31_t)0x41CE1E64, (q31_t)0x921C23EE, (q31_t)0x41A2FC1A, + (q31_t)0x920265E4, (q31_t)0x4177CFB0, (q31_t)0x91E8B8D0, + (q31_t)0x414C992E, (q31_t)0x91CF1CB6, (q31_t)0x4121589A, + (q31_t)0x91B5919A, (q31_t)0x40F60DFB, (q31_t)0x919C1780, + (q31_t)0x40CAB957, (q31_t)0x9182AE6C, (q31_t)0x409F5AB6, + (q31_t)0x91695663, (q31_t)0x4073F21D, (q31_t)0x91500F67, + (q31_t)0x40487F93, (q31_t)0x9136D97D, (q31_t)0x401D0320, + (q31_t)0x911DB4A8, (q31_t)0x3FF17CCA, (q31_t)0x9104A0ED, + (q31_t)0x3FC5EC97, (q31_t)0x90EB9E50, (q31_t)0x3F9A528F, + (q31_t)0x90D2ACD3, (q31_t)0x3F6EAEB8, (q31_t)0x90B9CC7C, + (q31_t)0x3F430118, (q31_t)0x90A0FD4E, (q31_t)0x3F1749B7, + (q31_t)0x90883F4C, (q31_t)0x3EEB889C, (q31_t)0x906F927B, + (q31_t)0x3EBFBDCC, (q31_t)0x9056F6DF, (q31_t)0x3E93E94F, + (q31_t)0x903E6C7A, (q31_t)0x3E680B2C, (q31_t)0x9025F352, + (q31_t)0x3E3C2369, (q31_t)0x900D8B69, (q31_t)0x3E10320D, + (q31_t)0x8FF534C4, (q31_t)0x3DE4371F, (q31_t)0x8FDCEF66, + (q31_t)0x3DB832A5, (q31_t)0x8FC4BB53, (q31_t)0x3D8C24A7, + (q31_t)0x8FAC988E, (q31_t)0x3D600D2B, (q31_t)0x8F94871D, + (q31_t)0x3D33EC39, (q31_t)0x8F7C8701, (q31_t)0x3D07C1D5, + (q31_t)0x8F64983F, (q31_t)0x3CDB8E09, (q31_t)0x8F4CBADB, + (q31_t)0x3CAF50DA, (q31_t)0x8F34EED8, (q31_t)0x3C830A4F, + (q31_t)0x8F1D343A, (q31_t)0x3C56BA70, (q31_t)0x8F058B04, + (q31_t)0x3C2A6142, (q31_t)0x8EEDF33B, (q31_t)0x3BFDFECD, + (q31_t)0x8ED66CE1, (q31_t)0x3BD19317, (q31_t)0x8EBEF7FB, + (q31_t)0x3BA51E29, (q31_t)0x8EA7948C, (q31_t)0x3B78A007, + (q31_t)0x8E904298, (q31_t)0x3B4C18BA, (q31_t)0x8E790222, + (q31_t)0x3B1F8847, (q31_t)0x8E61D32D, (q31_t)0x3AF2EEB7, + (q31_t)0x8E4AB5BF, (q31_t)0x3AC64C0F, (q31_t)0x8E33A9D9, + (q31_t)0x3A99A057, (q31_t)0x8E1CAF80, (q31_t)0x3A6CEB95, + (q31_t)0x8E05C6B7, (q31_t)0x3A402DD1, (q31_t)0x8DEEEF82, + (q31_t)0x3A136712, (q31_t)0x8DD829E4, (q31_t)0x39E6975D, + (q31_t)0x8DC175E0, (q31_t)0x39B9BEBB, (q31_t)0x8DAAD37B, + (q31_t)0x398CDD32, (q31_t)0x8D9442B7, (q31_t)0x395FF2C9, + (q31_t)0x8D7DC399, (q31_t)0x3932FF87, (q31_t)0x8D675623, + (q31_t)0x39060372, (q31_t)0x8D50FA59, (q31_t)0x38D8FE93, + (q31_t)0x8D3AB03F, (q31_t)0x38ABF0EF, (q31_t)0x8D2477D8, + (q31_t)0x387EDA8E, (q31_t)0x8D0E5127, (q31_t)0x3851BB76, + (q31_t)0x8CF83C30, (q31_t)0x382493B0, (q31_t)0x8CE238F6, + (q31_t)0x37F76340, (q31_t)0x8CCC477D, (q31_t)0x37CA2A30, + (q31_t)0x8CB667C7, (q31_t)0x379CE884, (q31_t)0x8CA099D9, + (q31_t)0x376F9E46, (q31_t)0x8C8ADDB6, (q31_t)0x37424B7A, + (q31_t)0x8C753361, (q31_t)0x3714F02A, (q31_t)0x8C5F9ADD, + (q31_t)0x36E78C5A, (q31_t)0x8C4A142F, (q31_t)0x36BA2013, + (q31_t)0x8C349F58, (q31_t)0x368CAB5C, (q31_t)0x8C1F3C5C, + (q31_t)0x365F2E3B, (q31_t)0x8C09EB40, (q31_t)0x3631A8B7, + (q31_t)0x8BF4AC05, (q31_t)0x36041AD9, (q31_t)0x8BDF7EAF, + (q31_t)0x35D684A5, (q31_t)0x8BCA6342, (q31_t)0x35A8E624, + (q31_t)0x8BB559C1, (q31_t)0x357B3F5D, (q31_t)0x8BA0622F, + (q31_t)0x354D9056, (q31_t)0x8B8B7C8F, (q31_t)0x351FD917, + (q31_t)0x8B76A8E4, (q31_t)0x34F219A7, (q31_t)0x8B61E732, + (q31_t)0x34C4520D, (q31_t)0x8B4D377C, (q31_t)0x3496824F, + (q31_t)0x8B3899C5, (q31_t)0x3468AA76, (q31_t)0x8B240E10, + (q31_t)0x343ACA87, (q31_t)0x8B0F9461, (q31_t)0x340CE28A, + (q31_t)0x8AFB2CBA, (q31_t)0x33DEF287, (q31_t)0x8AE6D71F, + (q31_t)0x33B0FA84, (q31_t)0x8AD29393, (q31_t)0x3382FA88, + (q31_t)0x8ABE6219, (q31_t)0x3354F29A, (q31_t)0x8AAA42B4, + (q31_t)0x3326E2C2, (q31_t)0x8A963567, (q31_t)0x32F8CB07, + (q31_t)0x8A823A35, (q31_t)0x32CAAB6F, (q31_t)0x8A6E5122, + (q31_t)0x329C8402, (q31_t)0x8A5A7A30, (q31_t)0x326E54C7, + (q31_t)0x8A46B563, (q31_t)0x32401DC5, (q31_t)0x8A3302BD, + (q31_t)0x3211DF03, (q31_t)0x8A1F6242, (q31_t)0x31E39889, + (q31_t)0x8A0BD3F5, (q31_t)0x31B54A5D, (q31_t)0x89F857D8, + (q31_t)0x3186F487, (q31_t)0x89E4EDEE, (q31_t)0x3158970D, + (q31_t)0x89D1963C, (q31_t)0x312A31F8, (q31_t)0x89BE50C3, + (q31_t)0x30FBC54D, (q31_t)0x89AB1D86, (q31_t)0x30CD5114, + (q31_t)0x8997FC89, (q31_t)0x309ED555, (q31_t)0x8984EDCF, + (q31_t)0x30705217, (q31_t)0x8971F15A, (q31_t)0x3041C760, + (q31_t)0x895F072D, (q31_t)0x30133538, (q31_t)0x894C2F4C, + (q31_t)0x2FE49BA6, (q31_t)0x893969B9, (q31_t)0x2FB5FAB2, + (q31_t)0x8926B677, (q31_t)0x2F875262, (q31_t)0x89141589, + (q31_t)0x2F58A2BD, (q31_t)0x890186F1, (q31_t)0x2F29EBCC, + (q31_t)0x88EF0AB4, (q31_t)0x2EFB2D94, (q31_t)0x88DCA0D3, + (q31_t)0x2ECC681E, (q31_t)0x88CA4951, (q31_t)0x2E9D9B70, + (q31_t)0x88B80431, (q31_t)0x2E6EC792, (q31_t)0x88A5D177, + (q31_t)0x2E3FEC8B, (q31_t)0x8893B124, (q31_t)0x2E110A62, + (q31_t)0x8881A33C, (q31_t)0x2DE2211E, (q31_t)0x886FA7C2, + (q31_t)0x2DB330C7, (q31_t)0x885DBEB7, (q31_t)0x2D843963, + (q31_t)0x884BE820, (q31_t)0x2D553AFB, (q31_t)0x883A23FE, + (q31_t)0x2D263595, (q31_t)0x88287255, (q31_t)0x2CF72939, + (q31_t)0x8816D327, (q31_t)0x2CC815ED, (q31_t)0x88054677, + (q31_t)0x2C98FBBA, (q31_t)0x87F3CC47, (q31_t)0x2C69DAA6, + (q31_t)0x87E2649B, (q31_t)0x2C3AB2B9, (q31_t)0x87D10F75, + (q31_t)0x2C0B83F9, (q31_t)0x87BFCCD7, (q31_t)0x2BDC4E6F, + (q31_t)0x87AE9CC5, (q31_t)0x2BAD1221, (q31_t)0x879D7F40, + (q31_t)0x2B7DCF17, (q31_t)0x878C744C, (q31_t)0x2B4E8558, + (q31_t)0x877B7BEC, (q31_t)0x2B1F34EB, (q31_t)0x876A9621, + (q31_t)0x2AEFDDD8, (q31_t)0x8759C2EF, (q31_t)0x2AC08025, + (q31_t)0x87490257, (q31_t)0x2A911BDB, (q31_t)0x8738545E, + (q31_t)0x2A61B101, (q31_t)0x8727B904, (q31_t)0x2A323F9D, + (q31_t)0x8717304E, (q31_t)0x2A02C7B8, (q31_t)0x8706BA3C, + (q31_t)0x29D34958, (q31_t)0x86F656D3, (q31_t)0x29A3C484, + (q31_t)0x86E60614, (q31_t)0x29743945, (q31_t)0x86D5C802, + (q31_t)0x2944A7A2, (q31_t)0x86C59C9F, (q31_t)0x29150FA1, + (q31_t)0x86B583EE, (q31_t)0x28E5714A, (q31_t)0x86A57DF1, + (q31_t)0x28B5CCA5, (q31_t)0x86958AAB, (q31_t)0x288621B9, + (q31_t)0x8685AA1F, (q31_t)0x2856708C, (q31_t)0x8675DC4E, + (q31_t)0x2826B928, (q31_t)0x8666213C, (q31_t)0x27F6FB92, + (q31_t)0x865678EA, (q31_t)0x27C737D2, (q31_t)0x8646E35B, + (q31_t)0x27976DF1, (q31_t)0x86376092, (q31_t)0x27679DF4, + (q31_t)0x8627F090, (q31_t)0x2737C7E3, (q31_t)0x86189359, + (q31_t)0x2707EBC6, (q31_t)0x860948EE, (q31_t)0x26D809A5, + (q31_t)0x85FA1152, (q31_t)0x26A82185, (q31_t)0x85EAEC88, + (q31_t)0x26783370, (q31_t)0x85DBDA91, (q31_t)0x26483F6C, + (q31_t)0x85CCDB70, (q31_t)0x26184581, (q31_t)0x85BDEF27, + (q31_t)0x25E845B5, (q31_t)0x85AF15B9, (q31_t)0x25B84012, + (q31_t)0x85A04F28, (q31_t)0x2588349D, (q31_t)0x85919B75, + (q31_t)0x2558235E, (q31_t)0x8582FAA4, (q31_t)0x25280C5D, + (q31_t)0x85746CB7, (q31_t)0x24F7EFA1, (q31_t)0x8565F1B0, + (q31_t)0x24C7CD32, (q31_t)0x85578991, (q31_t)0x2497A517, + (q31_t)0x8549345C, (q31_t)0x24677757, (q31_t)0x853AF214, + (q31_t)0x243743FA, (q31_t)0x852CC2BA, (q31_t)0x24070B07, + (q31_t)0x851EA652, (q31_t)0x23D6CC86, (q31_t)0x85109CDC, + (q31_t)0x23A6887E, (q31_t)0x8502A65C, (q31_t)0x23763EF7, + (q31_t)0x84F4C2D3, (q31_t)0x2345EFF7, (q31_t)0x84E6F244, + (q31_t)0x23159B87, (q31_t)0x84D934B0, (q31_t)0x22E541AE, + (q31_t)0x84CB8A1B, (q31_t)0x22B4E274, (q31_t)0x84BDF285, + (q31_t)0x22847DDF, (q31_t)0x84B06DF1, (q31_t)0x225413F8, + (q31_t)0x84A2FC62, (q31_t)0x2223A4C5, (q31_t)0x84959DD9, + (q31_t)0x21F3304E, (q31_t)0x84885257, (q31_t)0x21C2B69C, + (q31_t)0x847B19E1, (q31_t)0x219237B4, (q31_t)0x846DF476, + (q31_t)0x2161B39F, (q31_t)0x8460E21A, (q31_t)0x21312A65, + (q31_t)0x8453E2CE, (q31_t)0x21009C0B, (q31_t)0x8446F695, + (q31_t)0x20D0089B, (q31_t)0x843A1D70, (q31_t)0x209F701C, + (q31_t)0x842D5761, (q31_t)0x206ED295, (q31_t)0x8420A46B, + (q31_t)0x203E300D, (q31_t)0x8414048F, (q31_t)0x200D888C, + (q31_t)0x840777CF, (q31_t)0x1FDCDC1A, (q31_t)0x83FAFE2E, + (q31_t)0x1FAC2ABF, (q31_t)0x83EE97AC, (q31_t)0x1F7B7480, + (q31_t)0x83E2444D, (q31_t)0x1F4AB967, (q31_t)0x83D60411, + (q31_t)0x1F19F97B, (q31_t)0x83C9D6FB, (q31_t)0x1EE934C2, + (q31_t)0x83BDBD0D, (q31_t)0x1EB86B46, (q31_t)0x83B1B649, + (q31_t)0x1E879D0C, (q31_t)0x83A5C2B0, (q31_t)0x1E56CA1E, + (q31_t)0x8399E244, (q31_t)0x1E25F281, (q31_t)0x838E1507, + (q31_t)0x1DF5163F, (q31_t)0x83825AFB, (q31_t)0x1DC4355D, + (q31_t)0x8376B422, (q31_t)0x1D934FE5, (q31_t)0x836B207D, + (q31_t)0x1D6265DD, (q31_t)0x835FA00E, (q31_t)0x1D31774D, + (q31_t)0x835432D8, (q31_t)0x1D00843C, (q31_t)0x8348D8DB, + (q31_t)0x1CCF8CB3, (q31_t)0x833D921A, (q31_t)0x1C9E90B8, + (q31_t)0x83325E97, (q31_t)0x1C6D9053, (q31_t)0x83273E52, + (q31_t)0x1C3C8B8C, (q31_t)0x831C314E, (q31_t)0x1C0B826A, + (q31_t)0x8311378C, (q31_t)0x1BDA74F5, (q31_t)0x8306510F, + (q31_t)0x1BA96334, (q31_t)0x82FB7DD8, (q31_t)0x1B784D30, + (q31_t)0x82F0BDE8, (q31_t)0x1B4732EF, (q31_t)0x82E61141, + (q31_t)0x1B161479, (q31_t)0x82DB77E5, (q31_t)0x1AE4F1D6, + (q31_t)0x82D0F1D5, (q31_t)0x1AB3CB0C, (q31_t)0x82C67F13, + (q31_t)0x1A82A025, (q31_t)0x82BC1FA1, (q31_t)0x1A517127, + (q31_t)0x82B1D381, (q31_t)0x1A203E1B, (q31_t)0x82A79AB3, + (q31_t)0x19EF0706, (q31_t)0x829D753A, (q31_t)0x19BDCBF2, + (q31_t)0x82936316, (q31_t)0x198C8CE6, (q31_t)0x8289644A, + (q31_t)0x195B49E9, (q31_t)0x827F78D8, (q31_t)0x192A0303, + (q31_t)0x8275A0C0, (q31_t)0x18F8B83C, (q31_t)0x826BDC04, + (q31_t)0x18C7699B, (q31_t)0x82622AA5, (q31_t)0x18961727, + (q31_t)0x82588CA6, (q31_t)0x1864C0E9, (q31_t)0x824F0208, + (q31_t)0x183366E8, (q31_t)0x82458ACB, (q31_t)0x1802092C, + (q31_t)0x823C26F2, (q31_t)0x17D0A7BB, (q31_t)0x8232D67E, + (q31_t)0x179F429F, (q31_t)0x82299971, (q31_t)0x176DD9DE, + (q31_t)0x82206FCB, (q31_t)0x173C6D80, (q31_t)0x8217598F, + (q31_t)0x170AFD8D, (q31_t)0x820E56BE, (q31_t)0x16D98A0C, + (q31_t)0x82056758, (q31_t)0x16A81305, (q31_t)0x81FC8B60, + (q31_t)0x1676987F, (q31_t)0x81F3C2D7, (q31_t)0x16451A83, + (q31_t)0x81EB0DBD, (q31_t)0x16139917, (q31_t)0x81E26C16, + (q31_t)0x15E21444, (q31_t)0x81D9DDE1, (q31_t)0x15B08C11, + (q31_t)0x81D16320, (q31_t)0x157F0086, (q31_t)0x81C8FBD5, + (q31_t)0x154D71AA, (q31_t)0x81C0A801, (q31_t)0x151BDF85, + (q31_t)0x81B867A4, (q31_t)0x14EA4A1F, (q31_t)0x81B03AC1, + (q31_t)0x14B8B17F, (q31_t)0x81A82159, (q31_t)0x148715AD, + (q31_t)0x81A01B6C, (q31_t)0x145576B1, (q31_t)0x819828FD, + (q31_t)0x1423D492, (q31_t)0x81904A0C, (q31_t)0x13F22F57, + (q31_t)0x81887E9A, (q31_t)0x13C0870A, (q31_t)0x8180C6A9, + (q31_t)0x138EDBB0, (q31_t)0x8179223A, (q31_t)0x135D2D53, + (q31_t)0x8171914E, (q31_t)0x132B7BF9, (q31_t)0x816A13E6, + (q31_t)0x12F9C7AA, (q31_t)0x8162AA03, (q31_t)0x12C8106E, + (q31_t)0x815B53A8, (q31_t)0x1296564D, (q31_t)0x815410D3, + (q31_t)0x1264994E, (q31_t)0x814CE188, (q31_t)0x1232D978, + (q31_t)0x8145C5C6, (q31_t)0x120116D4, (q31_t)0x813EBD90, + (q31_t)0x11CF516A, (q31_t)0x8137C8E6, (q31_t)0x119D8940, + (q31_t)0x8130E7C8, (q31_t)0x116BBE5F, (q31_t)0x812A1A39, + (q31_t)0x1139F0CE, (q31_t)0x81236039, (q31_t)0x11082096, + (q31_t)0x811CB9CA, (q31_t)0x10D64DBC, (q31_t)0x811626EC, + (q31_t)0x10A4784A, (q31_t)0x810FA7A0, (q31_t)0x1072A047, + (q31_t)0x81093BE8, (q31_t)0x1040C5BB, (q31_t)0x8102E3C3, + (q31_t)0x100EE8AD, (q31_t)0x80FC9F35, (q31_t)0x0FDD0925, + (q31_t)0x80F66E3C, (q31_t)0x0FAB272B, (q31_t)0x80F050DB, + (q31_t)0x0F7942C6, (q31_t)0x80EA4712, (q31_t)0x0F475BFE, + (q31_t)0x80E450E2, (q31_t)0x0F1572DC, (q31_t)0x80DE6E4C, + (q31_t)0x0EE38765, (q31_t)0x80D89F51, (q31_t)0x0EB199A3, + (q31_t)0x80D2E3F1, (q31_t)0x0E7FA99D, (q31_t)0x80CD3C2F, + (q31_t)0x0E4DB75B, (q31_t)0x80C7A80A, (q31_t)0x0E1BC2E3, + (q31_t)0x80C22783, (q31_t)0x0DE9CC3F, (q31_t)0x80BCBA9C, + (q31_t)0x0DB7D376, (q31_t)0x80B76155, (q31_t)0x0D85D88F, + (q31_t)0x80B21BAF, (q31_t)0x0D53DB92, (q31_t)0x80ACE9AB, + (q31_t)0x0D21DC87, (q31_t)0x80A7CB49, (q31_t)0x0CEFDB75, + (q31_t)0x80A2C08B, (q31_t)0x0CBDD865, (q31_t)0x809DC970, + (q31_t)0x0C8BD35E, (q31_t)0x8098E5FB, (q31_t)0x0C59CC67, + (q31_t)0x8094162B, (q31_t)0x0C27C389, (q31_t)0x808F5A02, + (q31_t)0x0BF5B8CB, (q31_t)0x808AB180, (q31_t)0x0BC3AC35, + (q31_t)0x80861CA5, (q31_t)0x0B919DCE, (q31_t)0x80819B74, + (q31_t)0x0B5F8D9F, (q31_t)0x807D2DEB, (q31_t)0x0B2D7BAE, + (q31_t)0x8078D40D, (q31_t)0x0AFB6805, (q31_t)0x80748DD9, + (q31_t)0x0AC952AA, (q31_t)0x80705B50, (q31_t)0x0A973BA5, + (q31_t)0x806C3C73, (q31_t)0x0A6522FE, (q31_t)0x80683143, + (q31_t)0x0A3308BC, (q31_t)0x806439C0, (q31_t)0x0A00ECE8, + (q31_t)0x806055EA, (q31_t)0x09CECF89, (q31_t)0x805C85C3, + (q31_t)0x099CB0A7, (q31_t)0x8058C94C, (q31_t)0x096A9049, + (q31_t)0x80552083, (q31_t)0x09386E77, (q31_t)0x80518B6B, + (q31_t)0x09064B3A, (q31_t)0x804E0A03, (q31_t)0x08D42698, + (q31_t)0x804A9C4D, (q31_t)0x08A2009A, (q31_t)0x80474248, + (q31_t)0x086FD947, (q31_t)0x8043FBF6, (q31_t)0x083DB0A7, + (q31_t)0x8040C956, (q31_t)0x080B86C1, (q31_t)0x803DAA69, + (q31_t)0x07D95B9E, (q31_t)0x803A9F31, (q31_t)0x07A72F45, + (q31_t)0x8037A7AC, (q31_t)0x077501BE, (q31_t)0x8034C3DC, + (q31_t)0x0742D310, (q31_t)0x8031F3C1, (q31_t)0x0710A344, + (q31_t)0x802F375C, (q31_t)0x06DE7261, (q31_t)0x802C8EAD, + (q31_t)0x06AC406F, (q31_t)0x8029F9B4, (q31_t)0x067A0D75, + (q31_t)0x80277872, (q31_t)0x0647D97C, (q31_t)0x80250AE7, + (q31_t)0x0615A48A, (q31_t)0x8022B113, (q31_t)0x05E36EA9, + (q31_t)0x80206AF8, (q31_t)0x05B137DF, (q31_t)0x801E3894, + (q31_t)0x057F0034, (q31_t)0x801C19E9, (q31_t)0x054CC7B0, + (q31_t)0x801A0EF7, (q31_t)0x051A8E5C, (q31_t)0x801817BF, + (q31_t)0x04E8543D, (q31_t)0x80163440, (q31_t)0x04B6195D, + (q31_t)0x8014647A, (q31_t)0x0483DDC3, (q31_t)0x8012A86F, + (q31_t)0x0451A176, (q31_t)0x8011001E, (q31_t)0x041F647F, + (q31_t)0x800F6B88, (q31_t)0x03ED26E6, (q31_t)0x800DEAAC, + (q31_t)0x03BAE8B1, (q31_t)0x800C7D8C, (q31_t)0x0388A9E9, + (q31_t)0x800B2427, (q31_t)0x03566A96, (q31_t)0x8009DE7D, + (q31_t)0x03242ABF, (q31_t)0x8008AC90, (q31_t)0x02F1EA6B, + (q31_t)0x80078E5E, (q31_t)0x02BFA9A4, (q31_t)0x800683E8, + (q31_t)0x028D6870, (q31_t)0x80058D2E, (q31_t)0x025B26D7, + (q31_t)0x8004AA31, (q31_t)0x0228E4E1, (q31_t)0x8003DAF0, + (q31_t)0x01F6A296, (q31_t)0x80031F6C, (q31_t)0x01C45FFE, + (q31_t)0x800277A5, (q31_t)0x01921D1F, (q31_t)0x8001E39B, + (q31_t)0x015FDA03, (q31_t)0x8001634D, (q31_t)0x012D96B0, + (q31_t)0x8000F6BD, (q31_t)0x00FB532F, (q31_t)0x80009DE9, + (q31_t)0x00C90F88, (q31_t)0x800058D3, (q31_t)0x0096CBC1, + (q31_t)0x8000277A, (q31_t)0x006487E3, (q31_t)0x800009DE, + (q31_t)0x003243F5, (q31_t)0x80000000, (q31_t)0x00000000, + (q31_t)0x800009DE, (q31_t)0xFFCDBC0A, (q31_t)0x8000277A, + (q31_t)0xFF9B781D, (q31_t)0x800058D3, (q31_t)0xFF69343E, + (q31_t)0x80009DE9, (q31_t)0xFF36F078, (q31_t)0x8000F6BD, + (q31_t)0xFF04ACD0, (q31_t)0x8001634D, (q31_t)0xFED2694F, + (q31_t)0x8001E39B, (q31_t)0xFEA025FC, (q31_t)0x800277A5, + (q31_t)0xFE6DE2E0, (q31_t)0x80031F6C, (q31_t)0xFE3BA001, + (q31_t)0x8003DAF0, (q31_t)0xFE095D69, (q31_t)0x8004AA31, + (q31_t)0xFDD71B1E, (q31_t)0x80058D2E, (q31_t)0xFDA4D928, + (q31_t)0x800683E8, (q31_t)0xFD72978F, (q31_t)0x80078E5E, + (q31_t)0xFD40565B, (q31_t)0x8008AC90, (q31_t)0xFD0E1594, + (q31_t)0x8009DE7D, (q31_t)0xFCDBD541, (q31_t)0x800B2427, + (q31_t)0xFCA99569, (q31_t)0x800C7D8C, (q31_t)0xFC775616, + (q31_t)0x800DEAAC, (q31_t)0xFC45174E, (q31_t)0x800F6B88, + (q31_t)0xFC12D919, (q31_t)0x8011001E, (q31_t)0xFBE09B80, + (q31_t)0x8012A86F, (q31_t)0xFBAE5E89, (q31_t)0x8014647A, + (q31_t)0xFB7C223C, (q31_t)0x80163440, (q31_t)0xFB49E6A2, + (q31_t)0x801817BF, (q31_t)0xFB17ABC2, (q31_t)0x801A0EF7, + (q31_t)0xFAE571A4, (q31_t)0x801C19E9, (q31_t)0xFAB3384F, + (q31_t)0x801E3894, (q31_t)0xFA80FFCB, (q31_t)0x80206AF8, + (q31_t)0xFA4EC820, (q31_t)0x8022B113, (q31_t)0xFA1C9156, + (q31_t)0x80250AE7, (q31_t)0xF9EA5B75, (q31_t)0x80277872, + (q31_t)0xF9B82683, (q31_t)0x8029F9B4, (q31_t)0xF985F28A, + (q31_t)0x802C8EAD, (q31_t)0xF953BF90, (q31_t)0x802F375C, + (q31_t)0xF9218D9E, (q31_t)0x8031F3C1, (q31_t)0xF8EF5CBB, + (q31_t)0x8034C3DC, (q31_t)0xF8BD2CEF, (q31_t)0x8037A7AC, + (q31_t)0xF88AFE41, (q31_t)0x803A9F31, (q31_t)0xF858D0BA, + (q31_t)0x803DAA69, (q31_t)0xF826A461, (q31_t)0x8040C956, + (q31_t)0xF7F4793E, (q31_t)0x8043FBF6, (q31_t)0xF7C24F58, + (q31_t)0x80474248, (q31_t)0xF79026B8, (q31_t)0x804A9C4D, + (q31_t)0xF75DFF65, (q31_t)0x804E0A03, (q31_t)0xF72BD967, + (q31_t)0x80518B6B, (q31_t)0xF6F9B4C5, (q31_t)0x80552083, + (q31_t)0xF6C79188, (q31_t)0x8058C94C, (q31_t)0xF6956FB6, + (q31_t)0x805C85C3, (q31_t)0xF6634F58, (q31_t)0x806055EA, + (q31_t)0xF6313076, (q31_t)0x806439C0, (q31_t)0xF5FF1317, + (q31_t)0x80683143, (q31_t)0xF5CCF743, (q31_t)0x806C3C73, + (q31_t)0xF59ADD01, (q31_t)0x80705B50, (q31_t)0xF568C45A, + (q31_t)0x80748DD9, (q31_t)0xF536AD55, (q31_t)0x8078D40D, + (q31_t)0xF50497FA, (q31_t)0x807D2DEB, (q31_t)0xF4D28451, + (q31_t)0x80819B74, (q31_t)0xF4A07260, (q31_t)0x80861CA5, + (q31_t)0xF46E6231, (q31_t)0x808AB180, (q31_t)0xF43C53CA, + (q31_t)0x808F5A02, (q31_t)0xF40A4734, (q31_t)0x8094162B, + (q31_t)0xF3D83C76, (q31_t)0x8098E5FB, (q31_t)0xF3A63398, + (q31_t)0x809DC970, (q31_t)0xF3742CA1, (q31_t)0x80A2C08B, + (q31_t)0xF342279A, (q31_t)0x80A7CB49, (q31_t)0xF310248A, + (q31_t)0x80ACE9AB, (q31_t)0xF2DE2378, (q31_t)0x80B21BAF, + (q31_t)0xF2AC246D, (q31_t)0x80B76155, (q31_t)0xF27A2770, + (q31_t)0x80BCBA9C, (q31_t)0xF2482C89, (q31_t)0x80C22783, + (q31_t)0xF21633C0, (q31_t)0x80C7A80A, (q31_t)0xF1E43D1C, + (q31_t)0x80CD3C2F, (q31_t)0xF1B248A5, (q31_t)0x80D2E3F1, + (q31_t)0xF1805662, (q31_t)0x80D89F51, (q31_t)0xF14E665C, + (q31_t)0x80DE6E4C, (q31_t)0xF11C789A, (q31_t)0x80E450E2, + (q31_t)0xF0EA8D23, (q31_t)0x80EA4712, (q31_t)0xF0B8A401, + (q31_t)0x80F050DB, (q31_t)0xF086BD39, (q31_t)0x80F66E3C, + (q31_t)0xF054D8D4, (q31_t)0x80FC9F35, (q31_t)0xF022F6DA, + (q31_t)0x8102E3C3, (q31_t)0xEFF11752, (q31_t)0x81093BE8, + (q31_t)0xEFBF3A44, (q31_t)0x810FA7A0, (q31_t)0xEF8D5FB8, + (q31_t)0x811626EC, (q31_t)0xEF5B87B5, (q31_t)0x811CB9CA, + (q31_t)0xEF29B243, (q31_t)0x81236039, (q31_t)0xEEF7DF6A, + (q31_t)0x812A1A39, (q31_t)0xEEC60F31, (q31_t)0x8130E7C8, + (q31_t)0xEE9441A0, (q31_t)0x8137C8E6, (q31_t)0xEE6276BF, + (q31_t)0x813EBD90, (q31_t)0xEE30AE95, (q31_t)0x8145C5C6, + (q31_t)0xEDFEE92B, (q31_t)0x814CE188, (q31_t)0xEDCD2687, + (q31_t)0x815410D3, (q31_t)0xED9B66B2, (q31_t)0x815B53A8, + (q31_t)0xED69A9B2, (q31_t)0x8162AA03, (q31_t)0xED37EF91, + (q31_t)0x816A13E6, (q31_t)0xED063855, (q31_t)0x8171914E, + (q31_t)0xECD48406, (q31_t)0x8179223A, (q31_t)0xECA2D2AC, + (q31_t)0x8180C6A9, (q31_t)0xEC71244F, (q31_t)0x81887E9A, + (q31_t)0xEC3F78F5, (q31_t)0x81904A0C, (q31_t)0xEC0DD0A8, + (q31_t)0x819828FD, (q31_t)0xEBDC2B6D, (q31_t)0x81A01B6C, + (q31_t)0xEBAA894E, (q31_t)0x81A82159, (q31_t)0xEB78EA52, + (q31_t)0x81B03AC1, (q31_t)0xEB474E80, (q31_t)0x81B867A4, + (q31_t)0xEB15B5E0, (q31_t)0x81C0A801, (q31_t)0xEAE4207A, + (q31_t)0x81C8FBD5, (q31_t)0xEAB28E55, (q31_t)0x81D16320, + (q31_t)0xEA80FF79, (q31_t)0x81D9DDE1, (q31_t)0xEA4F73EE, + (q31_t)0x81E26C16, (q31_t)0xEA1DEBBB, (q31_t)0x81EB0DBD, + (q31_t)0xE9EC66E8, (q31_t)0x81F3C2D7, (q31_t)0xE9BAE57C, + (q31_t)0x81FC8B60, (q31_t)0xE9896780, (q31_t)0x82056758, + (q31_t)0xE957ECFB, (q31_t)0x820E56BE, (q31_t)0xE92675F4, + (q31_t)0x8217598F, (q31_t)0xE8F50273, (q31_t)0x82206FCB, + (q31_t)0xE8C3927F, (q31_t)0x82299971, (q31_t)0xE8922621, + (q31_t)0x8232D67E, (q31_t)0xE860BD60, (q31_t)0x823C26F2, + (q31_t)0xE82F5844, (q31_t)0x82458ACB, (q31_t)0xE7FDF6D3, + (q31_t)0x824F0208, (q31_t)0xE7CC9917, (q31_t)0x82588CA6, + (q31_t)0xE79B3F16, (q31_t)0x82622AA5, (q31_t)0xE769E8D8, + (q31_t)0x826BDC04, (q31_t)0xE7389664, (q31_t)0x8275A0C0, + (q31_t)0xE70747C3, (q31_t)0x827F78D8, (q31_t)0xE6D5FCFC, + (q31_t)0x8289644A, (q31_t)0xE6A4B616, (q31_t)0x82936316, + (q31_t)0xE6737319, (q31_t)0x829D753A, (q31_t)0xE642340D, + (q31_t)0x82A79AB3, (q31_t)0xE610F8F9, (q31_t)0x82B1D381, + (q31_t)0xE5DFC1E4, (q31_t)0x82BC1FA1, (q31_t)0xE5AE8ED8, + (q31_t)0x82C67F13, (q31_t)0xE57D5FDA, (q31_t)0x82D0F1D5, + (q31_t)0xE54C34F3, (q31_t)0x82DB77E5, (q31_t)0xE51B0E2A, + (q31_t)0x82E61141, (q31_t)0xE4E9EB86, (q31_t)0x82F0BDE8, + (q31_t)0xE4B8CD10, (q31_t)0x82FB7DD8, (q31_t)0xE487B2CF, + (q31_t)0x8306510F, (q31_t)0xE4569CCB, (q31_t)0x8311378C, + (q31_t)0xE4258B0A, (q31_t)0x831C314E, (q31_t)0xE3F47D95, + (q31_t)0x83273E52, (q31_t)0xE3C37473, (q31_t)0x83325E97, + (q31_t)0xE3926FAC, (q31_t)0x833D921A, (q31_t)0xE3616F47, + (q31_t)0x8348D8DB, (q31_t)0xE330734C, (q31_t)0x835432D8, + (q31_t)0xE2FF7BC3, (q31_t)0x835FA00E, (q31_t)0xE2CE88B2, + (q31_t)0x836B207D, (q31_t)0xE29D9A22, (q31_t)0x8376B422, + (q31_t)0xE26CB01A, (q31_t)0x83825AFB, (q31_t)0xE23BCAA2, + (q31_t)0x838E1507, (q31_t)0xE20AE9C1, (q31_t)0x8399E244, + (q31_t)0xE1DA0D7E, (q31_t)0x83A5C2B0, (q31_t)0xE1A935E1, + (q31_t)0x83B1B649, (q31_t)0xE17862F3, (q31_t)0x83BDBD0D, + (q31_t)0xE14794B9, (q31_t)0x83C9D6FB, (q31_t)0xE116CB3D, + (q31_t)0x83D60411, (q31_t)0xE0E60684, (q31_t)0x83E2444D, + (q31_t)0xE0B54698, (q31_t)0x83EE97AC, (q31_t)0xE0848B7F, + (q31_t)0x83FAFE2E, (q31_t)0xE053D541, (q31_t)0x840777CF, + (q31_t)0xE02323E5, (q31_t)0x8414048F, (q31_t)0xDFF27773, + (q31_t)0x8420A46B, (q31_t)0xDFC1CFF2, (q31_t)0x842D5761, + (q31_t)0xDF912D6A, (q31_t)0x843A1D70, (q31_t)0xDF608FE3, + (q31_t)0x8446F695, (q31_t)0xDF2FF764, (q31_t)0x8453E2CE, + (q31_t)0xDEFF63F4, (q31_t)0x8460E21A, (q31_t)0xDECED59B, + (q31_t)0x846DF476, (q31_t)0xDE9E4C60, (q31_t)0x847B19E1, + (q31_t)0xDE6DC84B, (q31_t)0x84885257, (q31_t)0xDE3D4963, + (q31_t)0x84959DD9, (q31_t)0xDE0CCFB1, (q31_t)0x84A2FC62, + (q31_t)0xDDDC5B3A, (q31_t)0x84B06DF1, (q31_t)0xDDABEC07, + (q31_t)0x84BDF285, (q31_t)0xDD7B8220, (q31_t)0x84CB8A1B, + (q31_t)0xDD4B1D8B, (q31_t)0x84D934B0, (q31_t)0xDD1ABE51, + (q31_t)0x84E6F244, (q31_t)0xDCEA6478, (q31_t)0x84F4C2D3, + (q31_t)0xDCBA1008, (q31_t)0x8502A65C, (q31_t)0xDC89C108, + (q31_t)0x85109CDC, (q31_t)0xDC597781, (q31_t)0x851EA652, + (q31_t)0xDC293379, (q31_t)0x852CC2BA, (q31_t)0xDBF8F4F8, + (q31_t)0x853AF214, (q31_t)0xDBC8BC05, (q31_t)0x8549345C, + (q31_t)0xDB9888A8, (q31_t)0x85578991, (q31_t)0xDB685AE8, + (q31_t)0x8565F1B0, (q31_t)0xDB3832CD, (q31_t)0x85746CB7, + (q31_t)0xDB08105E, (q31_t)0x8582FAA4, (q31_t)0xDAD7F3A2, + (q31_t)0x85919B75, (q31_t)0xDAA7DCA1, (q31_t)0x85A04F28, + (q31_t)0xDA77CB62, (q31_t)0x85AF15B9, (q31_t)0xDA47BFED, + (q31_t)0x85BDEF27, (q31_t)0xDA17BA4A, (q31_t)0x85CCDB70, + (q31_t)0xD9E7BA7E, (q31_t)0x85DBDA91, (q31_t)0xD9B7C093, + (q31_t)0x85EAEC88, (q31_t)0xD987CC8F, (q31_t)0x85FA1152, + (q31_t)0xD957DE7A, (q31_t)0x860948EE, (q31_t)0xD927F65B, + (q31_t)0x86189359, (q31_t)0xD8F81439, (q31_t)0x8627F090, + (q31_t)0xD8C8381C, (q31_t)0x86376092, (q31_t)0xD898620C, + (q31_t)0x8646E35B, (q31_t)0xD868920F, (q31_t)0x865678EA, + (q31_t)0xD838C82D, (q31_t)0x8666213C, (q31_t)0xD809046D, + (q31_t)0x8675DC4E, (q31_t)0xD7D946D7, (q31_t)0x8685AA1F, + (q31_t)0xD7A98F73, (q31_t)0x86958AAB, (q31_t)0xD779DE46, + (q31_t)0x86A57DF1, (q31_t)0xD74A335A, (q31_t)0x86B583EE, + (q31_t)0xD71A8EB5, (q31_t)0x86C59C9F, (q31_t)0xD6EAF05E, + (q31_t)0x86D5C802, (q31_t)0xD6BB585D, (q31_t)0x86E60614, + (q31_t)0xD68BC6BA, (q31_t)0x86F656D3, (q31_t)0xD65C3B7B, + (q31_t)0x8706BA3C, (q31_t)0xD62CB6A7, (q31_t)0x8717304E, + (q31_t)0xD5FD3847, (q31_t)0x8727B904, (q31_t)0xD5CDC062, + (q31_t)0x8738545E, (q31_t)0xD59E4EFE, (q31_t)0x87490257, + (q31_t)0xD56EE424, (q31_t)0x8759C2EF, (q31_t)0xD53F7FDA, + (q31_t)0x876A9621, (q31_t)0xD5102227, (q31_t)0x877B7BEC, + (q31_t)0xD4E0CB14, (q31_t)0x878C744C, (q31_t)0xD4B17AA7, + (q31_t)0x879D7F40, (q31_t)0xD48230E8, (q31_t)0x87AE9CC5, + (q31_t)0xD452EDDE, (q31_t)0x87BFCCD7, (q31_t)0xD423B190, + (q31_t)0x87D10F75, (q31_t)0xD3F47C06, (q31_t)0x87E2649B, + (q31_t)0xD3C54D46, (q31_t)0x87F3CC47, (q31_t)0xD3962559, + (q31_t)0x88054677, (q31_t)0xD3670445, (q31_t)0x8816D327, + (q31_t)0xD337EA12, (q31_t)0x88287255, (q31_t)0xD308D6C6, + (q31_t)0x883A23FE, (q31_t)0xD2D9CA6A, (q31_t)0x884BE820, + (q31_t)0xD2AAC504, (q31_t)0x885DBEB7, (q31_t)0xD27BC69C, + (q31_t)0x886FA7C2, (q31_t)0xD24CCF38, (q31_t)0x8881A33C, + (q31_t)0xD21DDEE1, (q31_t)0x8893B124, (q31_t)0xD1EEF59E, + (q31_t)0x88A5D177, (q31_t)0xD1C01374, (q31_t)0x88B80431, + (q31_t)0xD191386D, (q31_t)0x88CA4951, (q31_t)0xD162648F, + (q31_t)0x88DCA0D3, (q31_t)0xD13397E1, (q31_t)0x88EF0AB4, + (q31_t)0xD104D26B, (q31_t)0x890186F1, (q31_t)0xD0D61433, + (q31_t)0x89141589, (q31_t)0xD0A75D42, (q31_t)0x8926B677, + (q31_t)0xD078AD9D, (q31_t)0x893969B9, (q31_t)0xD04A054D, + (q31_t)0x894C2F4C, (q31_t)0xD01B6459, (q31_t)0x895F072D, + (q31_t)0xCFECCAC7, (q31_t)0x8971F15A, (q31_t)0xCFBE389F, + (q31_t)0x8984EDCF, (q31_t)0xCF8FADE8, (q31_t)0x8997FC89, + (q31_t)0xCF612AAA, (q31_t)0x89AB1D86, (q31_t)0xCF32AEEB, + (q31_t)0x89BE50C3, (q31_t)0xCF043AB2, (q31_t)0x89D1963C, + (q31_t)0xCED5CE08, (q31_t)0x89E4EDEE, (q31_t)0xCEA768F2, + (q31_t)0x89F857D8, (q31_t)0xCE790B78, (q31_t)0x8A0BD3F5, + (q31_t)0xCE4AB5A2, (q31_t)0x8A1F6242, (q31_t)0xCE1C6776, + (q31_t)0x8A3302BD, (q31_t)0xCDEE20FC, (q31_t)0x8A46B563, + (q31_t)0xCDBFE23A, (q31_t)0x8A5A7A30, (q31_t)0xCD91AB38, + (q31_t)0x8A6E5122, (q31_t)0xCD637BFD, (q31_t)0x8A823A35, + (q31_t)0xCD355490, (q31_t)0x8A963567, (q31_t)0xCD0734F8, + (q31_t)0x8AAA42B4, (q31_t)0xCCD91D3D, (q31_t)0x8ABE6219, + (q31_t)0xCCAB0D65, (q31_t)0x8AD29393, (q31_t)0xCC7D0577, + (q31_t)0x8AE6D71F, (q31_t)0xCC4F057B, (q31_t)0x8AFB2CBA, + (q31_t)0xCC210D78, (q31_t)0x8B0F9461, (q31_t)0xCBF31D75, + (q31_t)0x8B240E10, (q31_t)0xCBC53578, (q31_t)0x8B3899C5, + (q31_t)0xCB975589, (q31_t)0x8B4D377C, (q31_t)0xCB697DB0, + (q31_t)0x8B61E732, (q31_t)0xCB3BADF2, (q31_t)0x8B76A8E4, + (q31_t)0xCB0DE658, (q31_t)0x8B8B7C8F, (q31_t)0xCAE026E8, + (q31_t)0x8BA0622F, (q31_t)0xCAB26FA9, (q31_t)0x8BB559C1, + (q31_t)0xCA84C0A2, (q31_t)0x8BCA6342, (q31_t)0xCA5719DB, + (q31_t)0x8BDF7EAF, (q31_t)0xCA297B5A, (q31_t)0x8BF4AC05, + (q31_t)0xC9FBE527, (q31_t)0x8C09EB40, (q31_t)0xC9CE5748, + (q31_t)0x8C1F3C5C, (q31_t)0xC9A0D1C4, (q31_t)0x8C349F58, + (q31_t)0xC97354A3, (q31_t)0x8C4A142F, (q31_t)0xC945DFEC, + (q31_t)0x8C5F9ADD, (q31_t)0xC91873A5, (q31_t)0x8C753361, + (q31_t)0xC8EB0FD6, (q31_t)0x8C8ADDB6, (q31_t)0xC8BDB485, + (q31_t)0x8CA099D9, (q31_t)0xC89061BA, (q31_t)0x8CB667C7, + (q31_t)0xC863177B, (q31_t)0x8CCC477D, (q31_t)0xC835D5D0, + (q31_t)0x8CE238F6, (q31_t)0xC8089CBF, (q31_t)0x8CF83C30, + (q31_t)0xC7DB6C50, (q31_t)0x8D0E5127, (q31_t)0xC7AE4489, + (q31_t)0x8D2477D8, (q31_t)0xC7812571, (q31_t)0x8D3AB03F, + (q31_t)0xC7540F10, (q31_t)0x8D50FA59, (q31_t)0xC727016C, + (q31_t)0x8D675623, (q31_t)0xC6F9FC8D, (q31_t)0x8D7DC399, + (q31_t)0xC6CD0079, (q31_t)0x8D9442B7, (q31_t)0xC6A00D36, + (q31_t)0x8DAAD37B, (q31_t)0xC67322CD, (q31_t)0x8DC175E0, + (q31_t)0xC6464144, (q31_t)0x8DD829E4, (q31_t)0xC61968A2, + (q31_t)0x8DEEEF82, (q31_t)0xC5EC98ED, (q31_t)0x8E05C6B7, + (q31_t)0xC5BFD22E, (q31_t)0x8E1CAF80, (q31_t)0xC593146A, + (q31_t)0x8E33A9D9, (q31_t)0xC5665FA8, (q31_t)0x8E4AB5BF, + (q31_t)0xC539B3F0, (q31_t)0x8E61D32D, (q31_t)0xC50D1148, + (q31_t)0x8E790222, (q31_t)0xC4E077B8, (q31_t)0x8E904298, + (q31_t)0xC4B3E746, (q31_t)0x8EA7948C, (q31_t)0xC4875FF8, + (q31_t)0x8EBEF7FB, (q31_t)0xC45AE1D7, (q31_t)0x8ED66CE1, + (q31_t)0xC42E6CE8, (q31_t)0x8EEDF33B, (q31_t)0xC4020132, + (q31_t)0x8F058B04, (q31_t)0xC3D59EBD, (q31_t)0x8F1D343A, + (q31_t)0xC3A9458F, (q31_t)0x8F34EED8, (q31_t)0xC37CF5B0, + (q31_t)0x8F4CBADB, (q31_t)0xC350AF25, (q31_t)0x8F64983F, + (q31_t)0xC32471F6, (q31_t)0x8F7C8701, (q31_t)0xC2F83E2A, + (q31_t)0x8F94871D, (q31_t)0xC2CC13C7, (q31_t)0x8FAC988E, + (q31_t)0xC29FF2D4, (q31_t)0x8FC4BB53, (q31_t)0xC273DB58, + (q31_t)0x8FDCEF66, (q31_t)0xC247CD5A, (q31_t)0x8FF534C4, + (q31_t)0xC21BC8E0, (q31_t)0x900D8B69, (q31_t)0xC1EFCDF2, + (q31_t)0x9025F352, (q31_t)0xC1C3DC96, (q31_t)0x903E6C7A, + (q31_t)0xC197F4D3, (q31_t)0x9056F6DF, (q31_t)0xC16C16B0, + (q31_t)0x906F927B, (q31_t)0xC1404233, (q31_t)0x90883F4C, + (q31_t)0xC1147763, (q31_t)0x90A0FD4E, (q31_t)0xC0E8B648, + (q31_t)0x90B9CC7C, (q31_t)0xC0BCFEE7, (q31_t)0x90D2ACD3, + (q31_t)0xC0915147, (q31_t)0x90EB9E50, (q31_t)0xC065AD70, + (q31_t)0x9104A0ED, (q31_t)0xC03A1368, (q31_t)0x911DB4A8, + (q31_t)0xC00E8335, (q31_t)0x9136D97D, (q31_t)0xBFE2FCDF, + (q31_t)0x91500F67, (q31_t)0xBFB7806C, (q31_t)0x91695663, + (q31_t)0xBF8C0DE2, (q31_t)0x9182AE6C, (q31_t)0xBF60A54A, + (q31_t)0x919C1780, (q31_t)0xBF3546A8, (q31_t)0x91B5919A, + (q31_t)0xBF09F204, (q31_t)0x91CF1CB6, (q31_t)0xBEDEA765, + (q31_t)0x91E8B8D0, (q31_t)0xBEB366D1, (q31_t)0x920265E4, + (q31_t)0xBE88304F, (q31_t)0x921C23EE, (q31_t)0xBE5D03E5, + (q31_t)0x9235F2EB, (q31_t)0xBE31E19B, (q31_t)0x924FD2D6, + (q31_t)0xBE06C977, (q31_t)0x9269C3AC, (q31_t)0xBDDBBB7F, + (q31_t)0x9283C567, (q31_t)0xBDB0B7BA, (q31_t)0x929DD805, + (q31_t)0xBD85BE2F, (q31_t)0x92B7FB82, (q31_t)0xBD5ACEE5, + (q31_t)0x92D22FD8, (q31_t)0xBD2FE9E1, (q31_t)0x92EC7505, + (q31_t)0xBD050F2C, (q31_t)0x9306CB04, (q31_t)0xBCDA3ECA, + (q31_t)0x932131D1, (q31_t)0xBCAF78C3, (q31_t)0x933BA968, + (q31_t)0xBC84BD1E, (q31_t)0x935631C5, (q31_t)0xBC5A0BE1, + (q31_t)0x9370CAE4, (q31_t)0xBC2F6513, (q31_t)0x938B74C0, + (q31_t)0xBC04C8BA, (q31_t)0x93A62F56, (q31_t)0xBBDA36DC, + (q31_t)0x93C0FAA2, (q31_t)0xBBAFAF81, (q31_t)0x93DBD69F, + (q31_t)0xBB8532AF, (q31_t)0x93F6C34A, (q31_t)0xBB5AC06C, + (q31_t)0x9411C09D, (q31_t)0xBB3058C0, (q31_t)0x942CCE95, + (q31_t)0xBB05FBB0, (q31_t)0x9447ED2F, (q31_t)0xBADBA943, + (q31_t)0x94631C64, (q31_t)0xBAB1617F, (q31_t)0x947E5C32, + (q31_t)0xBA87246C, (q31_t)0x9499AC95, (q31_t)0xBA5CF210, + (q31_t)0x94B50D87, (q31_t)0xBA32CA70, (q31_t)0x94D07F05, + (q31_t)0xBA08AD94, (q31_t)0x94EC010B, (q31_t)0xB9DE9B83, + (q31_t)0x95079393, (q31_t)0xB9B49442, (q31_t)0x9523369B, + (q31_t)0xB98A97D8, (q31_t)0x953EEA1E, (q31_t)0xB960A64B, + (q31_t)0x955AAE17, (q31_t)0xB936BFA3, (q31_t)0x95768282, + (q31_t)0xB90CE3E6, (q31_t)0x9592675B, (q31_t)0xB8E31319, + (q31_t)0x95AE5C9E, (q31_t)0xB8B94D44, (q31_t)0x95CA6246, + (q31_t)0xB88F926C, (q31_t)0x95E6784F, (q31_t)0xB865E299, + (q31_t)0x96029EB5, (q31_t)0xB83C3DD1, (q31_t)0x961ED573, + (q31_t)0xB812A419, (q31_t)0x963B1C85, (q31_t)0xB7E9157A, + (q31_t)0x965773E7, (q31_t)0xB7BF91F8, (q31_t)0x9673DB94, + (q31_t)0xB796199B, (q31_t)0x96905387, (q31_t)0xB76CAC68, + (q31_t)0x96ACDBBD, (q31_t)0xB7434A67, (q31_t)0x96C97431, + (q31_t)0xB719F39D, (q31_t)0x96E61CDF, (q31_t)0xB6F0A811, + (q31_t)0x9702D5C2, (q31_t)0xB6C767CA, (q31_t)0x971F9ED6, + (q31_t)0xB69E32CD, (q31_t)0x973C7816, (q31_t)0xB6750921, + (q31_t)0x9759617E, (q31_t)0xB64BEACC, (q31_t)0x97765B0A, + (q31_t)0xB622D7D5, (q31_t)0x979364B5, (q31_t)0xB5F9D042, + (q31_t)0x97B07E7A, (q31_t)0xB5D0D41A, (q31_t)0x97CDA855, + (q31_t)0xB5A7E362, (q31_t)0x97EAE241, (q31_t)0xB57EFE21, + (q31_t)0x98082C3B, (q31_t)0xB556245E, (q31_t)0x9825863D, + (q31_t)0xB52D561E, (q31_t)0x9842F043, (q31_t)0xB5049368, + (q31_t)0x98606A48, (q31_t)0xB4DBDC42, (q31_t)0x987DF449, + (q31_t)0xB4B330B2, (q31_t)0x989B8E3F, (q31_t)0xB48A90C0, + (q31_t)0x98B93828, (q31_t)0xB461FC70, (q31_t)0x98D6F1FE, + (q31_t)0xB43973C9, (q31_t)0x98F4BBBC, (q31_t)0xB410F6D2, + (q31_t)0x9912955E, (q31_t)0xB3E88591, (q31_t)0x99307EE0, + (q31_t)0xB3C0200C, (q31_t)0x994E783C, (q31_t)0xB397C649, + (q31_t)0x996C816F, (q31_t)0xB36F784E, (q31_t)0x998A9A73, + (q31_t)0xB3473622, (q31_t)0x99A8C344, (q31_t)0xB31EFFCB, + (q31_t)0x99C6FBDE, (q31_t)0xB2F6D54F, (q31_t)0x99E5443A, + (q31_t)0xB2CEB6B5, (q31_t)0x9A039C56, (q31_t)0xB2A6A401, + (q31_t)0x9A22042C, (q31_t)0xB27E9D3B, (q31_t)0x9A407BB8, + (q31_t)0xB256A26A, (q31_t)0x9A5F02F5, (q31_t)0xB22EB392, + (q31_t)0x9A7D99DD, (q31_t)0xB206D0BA, (q31_t)0x9A9C406D, + (q31_t)0xB1DEF9E8, (q31_t)0x9ABAF6A0, (q31_t)0xB1B72F23, + (q31_t)0x9AD9BC71, (q31_t)0xB18F7070, (q31_t)0x9AF891DB, + (q31_t)0xB167BDD6, (q31_t)0x9B1776D9, (q31_t)0xB140175B, + (q31_t)0x9B366B67, (q31_t)0xB1187D05, (q31_t)0x9B556F80, + (q31_t)0xB0F0EEDA, (q31_t)0x9B748320, (q31_t)0xB0C96CDF, + (q31_t)0x9B93A640, (q31_t)0xB0A1F71C, (q31_t)0x9BB2D8DD, + (q31_t)0xB07A8D97, (q31_t)0x9BD21AF2, (q31_t)0xB0533055, + (q31_t)0x9BF16C7A, (q31_t)0xB02BDF5C, (q31_t)0x9C10CD70, + (q31_t)0xB0049AB2, (q31_t)0x9C303DCF, (q31_t)0xAFDD625F, + (q31_t)0x9C4FBD92, (q31_t)0xAFB63667, (q31_t)0x9C6F4CB5, + (q31_t)0xAF8F16D0, (q31_t)0x9C8EEB33, (q31_t)0xAF6803A1, + (q31_t)0x9CAE9907, (q31_t)0xAF40FCE0, (q31_t)0x9CCE562B, + (q31_t)0xAF1A0293, (q31_t)0x9CEE229C, (q31_t)0xAEF314BF, + (q31_t)0x9D0DFE53, (q31_t)0xAECC336B, (q31_t)0x9D2DE94D, + (q31_t)0xAEA55E9D, (q31_t)0x9D4DE384, (q31_t)0xAE7E965B, + (q31_t)0x9D6DECF4, (q31_t)0xAE57DAAA, (q31_t)0x9D8E0596, + (q31_t)0xAE312B91, (q31_t)0x9DAE2D68, (q31_t)0xAE0A8916, + (q31_t)0x9DCE6462, (q31_t)0xADE3F33E, (q31_t)0x9DEEAA82, + (q31_t)0xADBD6A10, (q31_t)0x9E0EFFC1, (q31_t)0xAD96ED91, + (q31_t)0x9E2F641A, (q31_t)0xAD707DC8, (q31_t)0x9E4FD789, + (q31_t)0xAD4A1ABA, (q31_t)0x9E705A09, (q31_t)0xAD23C46D, + (q31_t)0x9E90EB94, (q31_t)0xACFD7AE8, (q31_t)0x9EB18C26, + (q31_t)0xACD73E30, (q31_t)0x9ED23BB9, (q31_t)0xACB10E4A, + (q31_t)0x9EF2FA48, (q31_t)0xAC8AEB3E, (q31_t)0x9F13C7D0, + (q31_t)0xAC64D510, (q31_t)0x9F34A449, (q31_t)0xAC3ECBC7, + (q31_t)0x9F558FB0, (q31_t)0xAC18CF68, (q31_t)0x9F7689FF, + (q31_t)0xABF2DFFA, (q31_t)0x9F979331, (q31_t)0xABCCFD82, + (q31_t)0x9FB8AB41, (q31_t)0xABA72806, (q31_t)0x9FD9D22A, + (q31_t)0xAB815F8C, (q31_t)0x9FFB07E7, (q31_t)0xAB5BA41A, + (q31_t)0xA01C4C72, (q31_t)0xAB35F5B5, (q31_t)0xA03D9FC7, + (q31_t)0xAB105464, (q31_t)0xA05F01E1, (q31_t)0xAAEAC02B, + (q31_t)0xA08072BA, (q31_t)0xAAC53912, (q31_t)0xA0A1F24C, + (q31_t)0xAA9FBF1D, (q31_t)0xA0C38094, (q31_t)0xAA7A5253, + (q31_t)0xA0E51D8C, (q31_t)0xAA54F2B9, (q31_t)0xA106C92E, + (q31_t)0xAA2FA055, (q31_t)0xA1288376, (q31_t)0xAA0A5B2D, + (q31_t)0xA14A4C5E, (q31_t)0xA9E52347, (q31_t)0xA16C23E1, + (q31_t)0xA9BFF8A8, (q31_t)0xA18E09F9, (q31_t)0xA99ADB56, + (q31_t)0xA1AFFEA2, (q31_t)0xA975CB56, (q31_t)0xA1D201D7, + (q31_t)0xA950C8AF, (q31_t)0xA1F41391, (q31_t)0xA92BD366, + (q31_t)0xA21633CD, (q31_t)0xA906EB81, (q31_t)0xA2386283, + (q31_t)0xA8E21106, (q31_t)0xA25A9FB1, (q31_t)0xA8BD43FA, + (q31_t)0xA27CEB4F, (q31_t)0xA8988463, (q31_t)0xA29F4559, + (q31_t)0xA873D246, (q31_t)0xA2C1ADC9, (q31_t)0xA84F2DA9, + (q31_t)0xA2E4249A, (q31_t)0xA82A9693, (q31_t)0xA306A9C7, + (q31_t)0xA8060D08, (q31_t)0xA3293D4B, (q31_t)0xA7E1910E, + (q31_t)0xA34BDF20, (q31_t)0xA7BD22AB, (q31_t)0xA36E8F40, + (q31_t)0xA798C1E4, (q31_t)0xA3914DA7, (q31_t)0xA7746EC0, + (q31_t)0xA3B41A4F, (q31_t)0xA7502943, (q31_t)0xA3D6F533, + (q31_t)0xA72BF173, (q31_t)0xA3F9DE4D, (q31_t)0xA707C756, + (q31_t)0xA41CD598, (q31_t)0xA6E3AAF2, (q31_t)0xA43FDB0F, + (q31_t)0xA6BF9C4B, (q31_t)0xA462EEAC, (q31_t)0xA69B9B68, + (q31_t)0xA4861069, (q31_t)0xA677A84E, (q31_t)0xA4A94042, + (q31_t)0xA653C302, (q31_t)0xA4CC7E31, (q31_t)0xA62FEB8B, + (q31_t)0xA4EFCA31, (q31_t)0xA60C21ED, (q31_t)0xA513243B, + (q31_t)0xA5E8662F, (q31_t)0xA5368C4B, (q31_t)0xA5C4B855, + (q31_t)0xA55A025B, (q31_t)0xA5A11865, (q31_t)0xA57D8666, + (q31_t)0xA57D8666, (q31_t)0xA5A11865, (q31_t)0xA55A025B, + (q31_t)0xA5C4B855, (q31_t)0xA5368C4B, (q31_t)0xA5E8662F, + (q31_t)0xA513243B, (q31_t)0xA60C21ED, (q31_t)0xA4EFCA31, + (q31_t)0xA62FEB8B, (q31_t)0xA4CC7E31, (q31_t)0xA653C302, + (q31_t)0xA4A94042, (q31_t)0xA677A84E, (q31_t)0xA4861069, + (q31_t)0xA69B9B68, (q31_t)0xA462EEAC, (q31_t)0xA6BF9C4B, + (q31_t)0xA43FDB0F, (q31_t)0xA6E3AAF2, (q31_t)0xA41CD598, + (q31_t)0xA707C756, (q31_t)0xA3F9DE4D, (q31_t)0xA72BF173, + (q31_t)0xA3D6F533, (q31_t)0xA7502943, (q31_t)0xA3B41A4F, + (q31_t)0xA7746EC0, (q31_t)0xA3914DA7, (q31_t)0xA798C1E4, + (q31_t)0xA36E8F40, (q31_t)0xA7BD22AB, (q31_t)0xA34BDF20, + (q31_t)0xA7E1910E, (q31_t)0xA3293D4B, (q31_t)0xA8060D08, + (q31_t)0xA306A9C7, (q31_t)0xA82A9693, (q31_t)0xA2E4249A, + (q31_t)0xA84F2DA9, (q31_t)0xA2C1ADC9, (q31_t)0xA873D246, + (q31_t)0xA29F4559, (q31_t)0xA8988463, (q31_t)0xA27CEB4F, + (q31_t)0xA8BD43FA, (q31_t)0xA25A9FB1, (q31_t)0xA8E21106, + (q31_t)0xA2386283, (q31_t)0xA906EB81, (q31_t)0xA21633CD, + (q31_t)0xA92BD366, (q31_t)0xA1F41391, (q31_t)0xA950C8AF, + (q31_t)0xA1D201D7, (q31_t)0xA975CB56, (q31_t)0xA1AFFEA2, + (q31_t)0xA99ADB56, (q31_t)0xA18E09F9, (q31_t)0xA9BFF8A8, + (q31_t)0xA16C23E1, (q31_t)0xA9E52347, (q31_t)0xA14A4C5E, + (q31_t)0xAA0A5B2D, (q31_t)0xA1288376, (q31_t)0xAA2FA055, + (q31_t)0xA106C92E, (q31_t)0xAA54F2B9, (q31_t)0xA0E51D8C, + (q31_t)0xAA7A5253, (q31_t)0xA0C38094, (q31_t)0xAA9FBF1D, + (q31_t)0xA0A1F24C, (q31_t)0xAAC53912, (q31_t)0xA08072BA, + (q31_t)0xAAEAC02B, (q31_t)0xA05F01E1, (q31_t)0xAB105464, + (q31_t)0xA03D9FC7, (q31_t)0xAB35F5B5, (q31_t)0xA01C4C72, + (q31_t)0xAB5BA41A, (q31_t)0x9FFB07E7, (q31_t)0xAB815F8C, + (q31_t)0x9FD9D22A, (q31_t)0xABA72806, (q31_t)0x9FB8AB41, + (q31_t)0xABCCFD82, (q31_t)0x9F979331, (q31_t)0xABF2DFFA, + (q31_t)0x9F7689FF, (q31_t)0xAC18CF68, (q31_t)0x9F558FB0, + (q31_t)0xAC3ECBC7, (q31_t)0x9F34A449, (q31_t)0xAC64D510, + (q31_t)0x9F13C7D0, (q31_t)0xAC8AEB3E, (q31_t)0x9EF2FA48, + (q31_t)0xACB10E4A, (q31_t)0x9ED23BB9, (q31_t)0xACD73E30, + (q31_t)0x9EB18C26, (q31_t)0xACFD7AE8, (q31_t)0x9E90EB94, + (q31_t)0xAD23C46D, (q31_t)0x9E705A09, (q31_t)0xAD4A1ABA, + (q31_t)0x9E4FD789, (q31_t)0xAD707DC8, (q31_t)0x9E2F641A, + (q31_t)0xAD96ED91, (q31_t)0x9E0EFFC1, (q31_t)0xADBD6A10, + (q31_t)0x9DEEAA82, (q31_t)0xADE3F33E, (q31_t)0x9DCE6462, + (q31_t)0xAE0A8916, (q31_t)0x9DAE2D68, (q31_t)0xAE312B91, + (q31_t)0x9D8E0596, (q31_t)0xAE57DAAA, (q31_t)0x9D6DECF4, + (q31_t)0xAE7E965B, (q31_t)0x9D4DE384, (q31_t)0xAEA55E9D, + (q31_t)0x9D2DE94D, (q31_t)0xAECC336B, (q31_t)0x9D0DFE53, + (q31_t)0xAEF314BF, (q31_t)0x9CEE229C, (q31_t)0xAF1A0293, + (q31_t)0x9CCE562B, (q31_t)0xAF40FCE0, (q31_t)0x9CAE9907, + (q31_t)0xAF6803A1, (q31_t)0x9C8EEB33, (q31_t)0xAF8F16D0, + (q31_t)0x9C6F4CB5, (q31_t)0xAFB63667, (q31_t)0x9C4FBD92, + (q31_t)0xAFDD625F, (q31_t)0x9C303DCF, (q31_t)0xB0049AB2, + (q31_t)0x9C10CD70, (q31_t)0xB02BDF5C, (q31_t)0x9BF16C7A, + (q31_t)0xB0533055, (q31_t)0x9BD21AF2, (q31_t)0xB07A8D97, + (q31_t)0x9BB2D8DD, (q31_t)0xB0A1F71C, (q31_t)0x9B93A640, + (q31_t)0xB0C96CDF, (q31_t)0x9B748320, (q31_t)0xB0F0EEDA, + (q31_t)0x9B556F80, (q31_t)0xB1187D05, (q31_t)0x9B366B67, + (q31_t)0xB140175B, (q31_t)0x9B1776D9, (q31_t)0xB167BDD6, + (q31_t)0x9AF891DB, (q31_t)0xB18F7070, (q31_t)0x9AD9BC71, + (q31_t)0xB1B72F23, (q31_t)0x9ABAF6A0, (q31_t)0xB1DEF9E8, + (q31_t)0x9A9C406D, (q31_t)0xB206D0BA, (q31_t)0x9A7D99DD, + (q31_t)0xB22EB392, (q31_t)0x9A5F02F5, (q31_t)0xB256A26A, + (q31_t)0x9A407BB8, (q31_t)0xB27E9D3B, (q31_t)0x9A22042C, + (q31_t)0xB2A6A401, (q31_t)0x9A039C56, (q31_t)0xB2CEB6B5, + (q31_t)0x99E5443A, (q31_t)0xB2F6D54F, (q31_t)0x99C6FBDE, + (q31_t)0xB31EFFCB, (q31_t)0x99A8C344, (q31_t)0xB3473622, + (q31_t)0x998A9A73, (q31_t)0xB36F784E, (q31_t)0x996C816F, + (q31_t)0xB397C649, (q31_t)0x994E783C, (q31_t)0xB3C0200C, + (q31_t)0x99307EE0, (q31_t)0xB3E88591, (q31_t)0x9912955E, + (q31_t)0xB410F6D2, (q31_t)0x98F4BBBC, (q31_t)0xB43973C9, + (q31_t)0x98D6F1FE, (q31_t)0xB461FC70, (q31_t)0x98B93828, + (q31_t)0xB48A90C0, (q31_t)0x989B8E3F, (q31_t)0xB4B330B2, + (q31_t)0x987DF449, (q31_t)0xB4DBDC42, (q31_t)0x98606A48, + (q31_t)0xB5049368, (q31_t)0x9842F043, (q31_t)0xB52D561E, + (q31_t)0x9825863D, (q31_t)0xB556245E, (q31_t)0x98082C3B, + (q31_t)0xB57EFE21, (q31_t)0x97EAE241, (q31_t)0xB5A7E362, + (q31_t)0x97CDA855, (q31_t)0xB5D0D41A, (q31_t)0x97B07E7A, + (q31_t)0xB5F9D042, (q31_t)0x979364B5, (q31_t)0xB622D7D5, + (q31_t)0x97765B0A, (q31_t)0xB64BEACC, (q31_t)0x9759617E, + (q31_t)0xB6750921, (q31_t)0x973C7816, (q31_t)0xB69E32CD, + (q31_t)0x971F9ED6, (q31_t)0xB6C767CA, (q31_t)0x9702D5C2, + (q31_t)0xB6F0A811, (q31_t)0x96E61CDF, (q31_t)0xB719F39D, + (q31_t)0x96C97431, (q31_t)0xB7434A67, (q31_t)0x96ACDBBD, + (q31_t)0xB76CAC68, (q31_t)0x96905387, (q31_t)0xB796199B, + (q31_t)0x9673DB94, (q31_t)0xB7BF91F8, (q31_t)0x965773E7, + (q31_t)0xB7E9157A, (q31_t)0x963B1C85, (q31_t)0xB812A419, + (q31_t)0x961ED573, (q31_t)0xB83C3DD1, (q31_t)0x96029EB5, + (q31_t)0xB865E299, (q31_t)0x95E6784F, (q31_t)0xB88F926C, + (q31_t)0x95CA6246, (q31_t)0xB8B94D44, (q31_t)0x95AE5C9E, + (q31_t)0xB8E31319, (q31_t)0x9592675B, (q31_t)0xB90CE3E6, + (q31_t)0x95768282, (q31_t)0xB936BFA3, (q31_t)0x955AAE17, + (q31_t)0xB960A64B, (q31_t)0x953EEA1E, (q31_t)0xB98A97D8, + (q31_t)0x9523369B, (q31_t)0xB9B49442, (q31_t)0x95079393, + (q31_t)0xB9DE9B83, (q31_t)0x94EC010B, (q31_t)0xBA08AD94, + (q31_t)0x94D07F05, (q31_t)0xBA32CA70, (q31_t)0x94B50D87, + (q31_t)0xBA5CF210, (q31_t)0x9499AC95, (q31_t)0xBA87246C, + (q31_t)0x947E5C32, (q31_t)0xBAB1617F, (q31_t)0x94631C64, + (q31_t)0xBADBA943, (q31_t)0x9447ED2F, (q31_t)0xBB05FBB0, + (q31_t)0x942CCE95, (q31_t)0xBB3058C0, (q31_t)0x9411C09D, + (q31_t)0xBB5AC06C, (q31_t)0x93F6C34A, (q31_t)0xBB8532AF, + (q31_t)0x93DBD69F, (q31_t)0xBBAFAF81, (q31_t)0x93C0FAA2, + (q31_t)0xBBDA36DC, (q31_t)0x93A62F56, (q31_t)0xBC04C8BA, + (q31_t)0x938B74C0, (q31_t)0xBC2F6513, (q31_t)0x9370CAE4, + (q31_t)0xBC5A0BE1, (q31_t)0x935631C5, (q31_t)0xBC84BD1E, + (q31_t)0x933BA968, (q31_t)0xBCAF78C3, (q31_t)0x932131D1, + (q31_t)0xBCDA3ECA, (q31_t)0x9306CB04, (q31_t)0xBD050F2C, + (q31_t)0x92EC7505, (q31_t)0xBD2FE9E1, (q31_t)0x92D22FD8, + (q31_t)0xBD5ACEE5, (q31_t)0x92B7FB82, (q31_t)0xBD85BE2F, + (q31_t)0x929DD805, (q31_t)0xBDB0B7BA, (q31_t)0x9283C567, + (q31_t)0xBDDBBB7F, (q31_t)0x9269C3AC, (q31_t)0xBE06C977, + (q31_t)0x924FD2D6, (q31_t)0xBE31E19B, (q31_t)0x9235F2EB, + (q31_t)0xBE5D03E5, (q31_t)0x921C23EE, (q31_t)0xBE88304F, + (q31_t)0x920265E4, (q31_t)0xBEB366D1, (q31_t)0x91E8B8D0, + (q31_t)0xBEDEA765, (q31_t)0x91CF1CB6, (q31_t)0xBF09F204, + (q31_t)0x91B5919A, (q31_t)0xBF3546A8, (q31_t)0x919C1780, + (q31_t)0xBF60A54A, (q31_t)0x9182AE6C, (q31_t)0xBF8C0DE2, + (q31_t)0x91695663, (q31_t)0xBFB7806C, (q31_t)0x91500F67, + (q31_t)0xBFE2FCDF, (q31_t)0x9136D97D, (q31_t)0xC00E8335, + (q31_t)0x911DB4A8, (q31_t)0xC03A1368, (q31_t)0x9104A0ED, + (q31_t)0xC065AD70, (q31_t)0x90EB9E50, (q31_t)0xC0915147, + (q31_t)0x90D2ACD3, (q31_t)0xC0BCFEE7, (q31_t)0x90B9CC7C, + (q31_t)0xC0E8B648, (q31_t)0x90A0FD4E, (q31_t)0xC1147763, + (q31_t)0x90883F4C, (q31_t)0xC1404233, (q31_t)0x906F927B, + (q31_t)0xC16C16B0, (q31_t)0x9056F6DF, (q31_t)0xC197F4D3, + (q31_t)0x903E6C7A, (q31_t)0xC1C3DC96, (q31_t)0x9025F352, + (q31_t)0xC1EFCDF2, (q31_t)0x900D8B69, (q31_t)0xC21BC8E0, + (q31_t)0x8FF534C4, (q31_t)0xC247CD5A, (q31_t)0x8FDCEF66, + (q31_t)0xC273DB58, (q31_t)0x8FC4BB53, (q31_t)0xC29FF2D4, + (q31_t)0x8FAC988E, (q31_t)0xC2CC13C7, (q31_t)0x8F94871D, + (q31_t)0xC2F83E2A, (q31_t)0x8F7C8701, (q31_t)0xC32471F6, + (q31_t)0x8F64983F, (q31_t)0xC350AF25, (q31_t)0x8F4CBADB, + (q31_t)0xC37CF5B0, (q31_t)0x8F34EED8, (q31_t)0xC3A9458F, + (q31_t)0x8F1D343A, (q31_t)0xC3D59EBD, (q31_t)0x8F058B04, + (q31_t)0xC4020132, (q31_t)0x8EEDF33B, (q31_t)0xC42E6CE8, + (q31_t)0x8ED66CE1, (q31_t)0xC45AE1D7, (q31_t)0x8EBEF7FB, + (q31_t)0xC4875FF8, (q31_t)0x8EA7948C, (q31_t)0xC4B3E746, + (q31_t)0x8E904298, (q31_t)0xC4E077B8, (q31_t)0x8E790222, + (q31_t)0xC50D1148, (q31_t)0x8E61D32D, (q31_t)0xC539B3F0, + (q31_t)0x8E4AB5BF, (q31_t)0xC5665FA8, (q31_t)0x8E33A9D9, + (q31_t)0xC593146A, (q31_t)0x8E1CAF80, (q31_t)0xC5BFD22E, + (q31_t)0x8E05C6B7, (q31_t)0xC5EC98ED, (q31_t)0x8DEEEF82, + (q31_t)0xC61968A2, (q31_t)0x8DD829E4, (q31_t)0xC6464144, + (q31_t)0x8DC175E0, (q31_t)0xC67322CD, (q31_t)0x8DAAD37B, + (q31_t)0xC6A00D36, (q31_t)0x8D9442B7, (q31_t)0xC6CD0079, + (q31_t)0x8D7DC399, (q31_t)0xC6F9FC8D, (q31_t)0x8D675623, + (q31_t)0xC727016C, (q31_t)0x8D50FA59, (q31_t)0xC7540F10, + (q31_t)0x8D3AB03F, (q31_t)0xC7812571, (q31_t)0x8D2477D8, + (q31_t)0xC7AE4489, (q31_t)0x8D0E5127, (q31_t)0xC7DB6C50, + (q31_t)0x8CF83C30, (q31_t)0xC8089CBF, (q31_t)0x8CE238F6, + (q31_t)0xC835D5D0, (q31_t)0x8CCC477D, (q31_t)0xC863177B, + (q31_t)0x8CB667C7, (q31_t)0xC89061BA, (q31_t)0x8CA099D9, + (q31_t)0xC8BDB485, (q31_t)0x8C8ADDB6, (q31_t)0xC8EB0FD6, + (q31_t)0x8C753361, (q31_t)0xC91873A5, (q31_t)0x8C5F9ADD, + (q31_t)0xC945DFEC, (q31_t)0x8C4A142F, (q31_t)0xC97354A3, + (q31_t)0x8C349F58, (q31_t)0xC9A0D1C4, (q31_t)0x8C1F3C5C, + (q31_t)0xC9CE5748, (q31_t)0x8C09EB40, (q31_t)0xC9FBE527, + (q31_t)0x8BF4AC05, (q31_t)0xCA297B5A, (q31_t)0x8BDF7EAF, + (q31_t)0xCA5719DB, (q31_t)0x8BCA6342, (q31_t)0xCA84C0A2, + (q31_t)0x8BB559C1, (q31_t)0xCAB26FA9, (q31_t)0x8BA0622F, + (q31_t)0xCAE026E8, (q31_t)0x8B8B7C8F, (q31_t)0xCB0DE658, + (q31_t)0x8B76A8E4, (q31_t)0xCB3BADF2, (q31_t)0x8B61E732, + (q31_t)0xCB697DB0, (q31_t)0x8B4D377C, (q31_t)0xCB975589, + (q31_t)0x8B3899C5, (q31_t)0xCBC53578, (q31_t)0x8B240E10, + (q31_t)0xCBF31D75, (q31_t)0x8B0F9461, (q31_t)0xCC210D78, + (q31_t)0x8AFB2CBA, (q31_t)0xCC4F057B, (q31_t)0x8AE6D71F, + (q31_t)0xCC7D0577, (q31_t)0x8AD29393, (q31_t)0xCCAB0D65, + (q31_t)0x8ABE6219, (q31_t)0xCCD91D3D, (q31_t)0x8AAA42B4, + (q31_t)0xCD0734F8, (q31_t)0x8A963567, (q31_t)0xCD355490, + (q31_t)0x8A823A35, (q31_t)0xCD637BFD, (q31_t)0x8A6E5122, + (q31_t)0xCD91AB38, (q31_t)0x8A5A7A30, (q31_t)0xCDBFE23A, + (q31_t)0x8A46B563, (q31_t)0xCDEE20FC, (q31_t)0x8A3302BD, + (q31_t)0xCE1C6776, (q31_t)0x8A1F6242, (q31_t)0xCE4AB5A2, + (q31_t)0x8A0BD3F5, (q31_t)0xCE790B78, (q31_t)0x89F857D8, + (q31_t)0xCEA768F2, (q31_t)0x89E4EDEE, (q31_t)0xCED5CE08, + (q31_t)0x89D1963C, (q31_t)0xCF043AB2, (q31_t)0x89BE50C3, + (q31_t)0xCF32AEEB, (q31_t)0x89AB1D86, (q31_t)0xCF612AAA, + (q31_t)0x8997FC89, (q31_t)0xCF8FADE8, (q31_t)0x8984EDCF, + (q31_t)0xCFBE389F, (q31_t)0x8971F15A, (q31_t)0xCFECCAC7, + (q31_t)0x895F072D, (q31_t)0xD01B6459, (q31_t)0x894C2F4C, + (q31_t)0xD04A054D, (q31_t)0x893969B9, (q31_t)0xD078AD9D, + (q31_t)0x8926B677, (q31_t)0xD0A75D42, (q31_t)0x89141589, + (q31_t)0xD0D61433, (q31_t)0x890186F1, (q31_t)0xD104D26B, + (q31_t)0x88EF0AB4, (q31_t)0xD13397E1, (q31_t)0x88DCA0D3, + (q31_t)0xD162648F, (q31_t)0x88CA4951, (q31_t)0xD191386D, + (q31_t)0x88B80431, (q31_t)0xD1C01374, (q31_t)0x88A5D177, + (q31_t)0xD1EEF59E, (q31_t)0x8893B124, (q31_t)0xD21DDEE1, + (q31_t)0x8881A33C, (q31_t)0xD24CCF38, (q31_t)0x886FA7C2, + (q31_t)0xD27BC69C, (q31_t)0x885DBEB7, (q31_t)0xD2AAC504, + (q31_t)0x884BE820, (q31_t)0xD2D9CA6A, (q31_t)0x883A23FE, + (q31_t)0xD308D6C6, (q31_t)0x88287255, (q31_t)0xD337EA12, + (q31_t)0x8816D327, (q31_t)0xD3670445, (q31_t)0x88054677, + (q31_t)0xD3962559, (q31_t)0x87F3CC47, (q31_t)0xD3C54D46, + (q31_t)0x87E2649B, (q31_t)0xD3F47C06, (q31_t)0x87D10F75, + (q31_t)0xD423B190, (q31_t)0x87BFCCD7, (q31_t)0xD452EDDE, + (q31_t)0x87AE9CC5, (q31_t)0xD48230E8, (q31_t)0x879D7F40, + (q31_t)0xD4B17AA7, (q31_t)0x878C744C, (q31_t)0xD4E0CB14, + (q31_t)0x877B7BEC, (q31_t)0xD5102227, (q31_t)0x876A9621, + (q31_t)0xD53F7FDA, (q31_t)0x8759C2EF, (q31_t)0xD56EE424, + (q31_t)0x87490257, (q31_t)0xD59E4EFE, (q31_t)0x8738545E, + (q31_t)0xD5CDC062, (q31_t)0x8727B904, (q31_t)0xD5FD3847, + (q31_t)0x8717304E, (q31_t)0xD62CB6A7, (q31_t)0x8706BA3C, + (q31_t)0xD65C3B7B, (q31_t)0x86F656D3, (q31_t)0xD68BC6BA, + (q31_t)0x86E60614, (q31_t)0xD6BB585D, (q31_t)0x86D5C802, + (q31_t)0xD6EAF05E, (q31_t)0x86C59C9F, (q31_t)0xD71A8EB5, + (q31_t)0x86B583EE, (q31_t)0xD74A335A, (q31_t)0x86A57DF1, + (q31_t)0xD779DE46, (q31_t)0x86958AAB, (q31_t)0xD7A98F73, + (q31_t)0x8685AA1F, (q31_t)0xD7D946D7, (q31_t)0x8675DC4E, + (q31_t)0xD809046D, (q31_t)0x8666213C, (q31_t)0xD838C82D, + (q31_t)0x865678EA, (q31_t)0xD868920F, (q31_t)0x8646E35B, + (q31_t)0xD898620C, (q31_t)0x86376092, (q31_t)0xD8C8381C, + (q31_t)0x8627F090, (q31_t)0xD8F81439, (q31_t)0x86189359, + (q31_t)0xD927F65B, (q31_t)0x860948EE, (q31_t)0xD957DE7A, + (q31_t)0x85FA1152, (q31_t)0xD987CC8F, (q31_t)0x85EAEC88, + (q31_t)0xD9B7C093, (q31_t)0x85DBDA91, (q31_t)0xD9E7BA7E, + (q31_t)0x85CCDB70, (q31_t)0xDA17BA4A, (q31_t)0x85BDEF27, + (q31_t)0xDA47BFED, (q31_t)0x85AF15B9, (q31_t)0xDA77CB62, + (q31_t)0x85A04F28, (q31_t)0xDAA7DCA1, (q31_t)0x85919B75, + (q31_t)0xDAD7F3A2, (q31_t)0x8582FAA4, (q31_t)0xDB08105E, + (q31_t)0x85746CB7, (q31_t)0xDB3832CD, (q31_t)0x8565F1B0, + (q31_t)0xDB685AE8, (q31_t)0x85578991, (q31_t)0xDB9888A8, + (q31_t)0x8549345C, (q31_t)0xDBC8BC05, (q31_t)0x853AF214, + (q31_t)0xDBF8F4F8, (q31_t)0x852CC2BA, (q31_t)0xDC293379, + (q31_t)0x851EA652, (q31_t)0xDC597781, (q31_t)0x85109CDC, + (q31_t)0xDC89C108, (q31_t)0x8502A65C, (q31_t)0xDCBA1008, + (q31_t)0x84F4C2D3, (q31_t)0xDCEA6478, (q31_t)0x84E6F244, + (q31_t)0xDD1ABE51, (q31_t)0x84D934B0, (q31_t)0xDD4B1D8B, + (q31_t)0x84CB8A1B, (q31_t)0xDD7B8220, (q31_t)0x84BDF285, + (q31_t)0xDDABEC07, (q31_t)0x84B06DF1, (q31_t)0xDDDC5B3A, + (q31_t)0x84A2FC62, (q31_t)0xDE0CCFB1, (q31_t)0x84959DD9, + (q31_t)0xDE3D4963, (q31_t)0x84885257, (q31_t)0xDE6DC84B, + (q31_t)0x847B19E1, (q31_t)0xDE9E4C60, (q31_t)0x846DF476, + (q31_t)0xDECED59B, (q31_t)0x8460E21A, (q31_t)0xDEFF63F4, + (q31_t)0x8453E2CE, (q31_t)0xDF2FF764, (q31_t)0x8446F695, + (q31_t)0xDF608FE3, (q31_t)0x843A1D70, (q31_t)0xDF912D6A, + (q31_t)0x842D5761, (q31_t)0xDFC1CFF2, (q31_t)0x8420A46B, + (q31_t)0xDFF27773, (q31_t)0x8414048F, (q31_t)0xE02323E5, + (q31_t)0x840777CF, (q31_t)0xE053D541, (q31_t)0x83FAFE2E, + (q31_t)0xE0848B7F, (q31_t)0x83EE97AC, (q31_t)0xE0B54698, + (q31_t)0x83E2444D, (q31_t)0xE0E60684, (q31_t)0x83D60411, + (q31_t)0xE116CB3D, (q31_t)0x83C9D6FB, (q31_t)0xE14794B9, + (q31_t)0x83BDBD0D, (q31_t)0xE17862F3, (q31_t)0x83B1B649, + (q31_t)0xE1A935E1, (q31_t)0x83A5C2B0, (q31_t)0xE1DA0D7E, + (q31_t)0x8399E244, (q31_t)0xE20AE9C1, (q31_t)0x838E1507, + (q31_t)0xE23BCAA2, (q31_t)0x83825AFB, (q31_t)0xE26CB01A, + (q31_t)0x8376B422, (q31_t)0xE29D9A22, (q31_t)0x836B207D, + (q31_t)0xE2CE88B2, (q31_t)0x835FA00E, (q31_t)0xE2FF7BC3, + (q31_t)0x835432D8, (q31_t)0xE330734C, (q31_t)0x8348D8DB, + (q31_t)0xE3616F47, (q31_t)0x833D921A, (q31_t)0xE3926FAC, + (q31_t)0x83325E97, (q31_t)0xE3C37473, (q31_t)0x83273E52, + (q31_t)0xE3F47D95, (q31_t)0x831C314E, (q31_t)0xE4258B0A, + (q31_t)0x8311378C, (q31_t)0xE4569CCB, (q31_t)0x8306510F, + (q31_t)0xE487B2CF, (q31_t)0x82FB7DD8, (q31_t)0xE4B8CD10, + (q31_t)0x82F0BDE8, (q31_t)0xE4E9EB86, (q31_t)0x82E61141, + (q31_t)0xE51B0E2A, (q31_t)0x82DB77E5, (q31_t)0xE54C34F3, + (q31_t)0x82D0F1D5, (q31_t)0xE57D5FDA, (q31_t)0x82C67F13, + (q31_t)0xE5AE8ED8, (q31_t)0x82BC1FA1, (q31_t)0xE5DFC1E4, + (q31_t)0x82B1D381, (q31_t)0xE610F8F9, (q31_t)0x82A79AB3, + (q31_t)0xE642340D, (q31_t)0x829D753A, (q31_t)0xE6737319, + (q31_t)0x82936316, (q31_t)0xE6A4B616, (q31_t)0x8289644A, + (q31_t)0xE6D5FCFC, (q31_t)0x827F78D8, (q31_t)0xE70747C3, + (q31_t)0x8275A0C0, (q31_t)0xE7389664, (q31_t)0x826BDC04, + (q31_t)0xE769E8D8, (q31_t)0x82622AA5, (q31_t)0xE79B3F16, + (q31_t)0x82588CA6, (q31_t)0xE7CC9917, (q31_t)0x824F0208, + (q31_t)0xE7FDF6D3, (q31_t)0x82458ACB, (q31_t)0xE82F5844, + (q31_t)0x823C26F2, (q31_t)0xE860BD60, (q31_t)0x8232D67E, + (q31_t)0xE8922621, (q31_t)0x82299971, (q31_t)0xE8C3927F, + (q31_t)0x82206FCB, (q31_t)0xE8F50273, (q31_t)0x8217598F, + (q31_t)0xE92675F4, (q31_t)0x820E56BE, (q31_t)0xE957ECFB, + (q31_t)0x82056758, (q31_t)0xE9896780, (q31_t)0x81FC8B60, + (q31_t)0xE9BAE57C, (q31_t)0x81F3C2D7, (q31_t)0xE9EC66E8, + (q31_t)0x81EB0DBD, (q31_t)0xEA1DEBBB, (q31_t)0x81E26C16, + (q31_t)0xEA4F73EE, (q31_t)0x81D9DDE1, (q31_t)0xEA80FF79, + (q31_t)0x81D16320, (q31_t)0xEAB28E55, (q31_t)0x81C8FBD5, + (q31_t)0xEAE4207A, (q31_t)0x81C0A801, (q31_t)0xEB15B5E0, + (q31_t)0x81B867A4, (q31_t)0xEB474E80, (q31_t)0x81B03AC1, + (q31_t)0xEB78EA52, (q31_t)0x81A82159, (q31_t)0xEBAA894E, + (q31_t)0x81A01B6C, (q31_t)0xEBDC2B6D, (q31_t)0x819828FD, + (q31_t)0xEC0DD0A8, (q31_t)0x81904A0C, (q31_t)0xEC3F78F5, + (q31_t)0x81887E9A, (q31_t)0xEC71244F, (q31_t)0x8180C6A9, + (q31_t)0xECA2D2AC, (q31_t)0x8179223A, (q31_t)0xECD48406, + (q31_t)0x8171914E, (q31_t)0xED063855, (q31_t)0x816A13E6, + (q31_t)0xED37EF91, (q31_t)0x8162AA03, (q31_t)0xED69A9B2, + (q31_t)0x815B53A8, (q31_t)0xED9B66B2, (q31_t)0x815410D3, + (q31_t)0xEDCD2687, (q31_t)0x814CE188, (q31_t)0xEDFEE92B, + (q31_t)0x8145C5C6, (q31_t)0xEE30AE95, (q31_t)0x813EBD90, + (q31_t)0xEE6276BF, (q31_t)0x8137C8E6, (q31_t)0xEE9441A0, + (q31_t)0x8130E7C8, (q31_t)0xEEC60F31, (q31_t)0x812A1A39, + (q31_t)0xEEF7DF6A, (q31_t)0x81236039, (q31_t)0xEF29B243, + (q31_t)0x811CB9CA, (q31_t)0xEF5B87B5, (q31_t)0x811626EC, + (q31_t)0xEF8D5FB8, (q31_t)0x810FA7A0, (q31_t)0xEFBF3A44, + (q31_t)0x81093BE8, (q31_t)0xEFF11752, (q31_t)0x8102E3C3, + (q31_t)0xF022F6DA, (q31_t)0x80FC9F35, (q31_t)0xF054D8D4, + (q31_t)0x80F66E3C, (q31_t)0xF086BD39, (q31_t)0x80F050DB, + (q31_t)0xF0B8A401, (q31_t)0x80EA4712, (q31_t)0xF0EA8D23, + (q31_t)0x80E450E2, (q31_t)0xF11C789A, (q31_t)0x80DE6E4C, + (q31_t)0xF14E665C, (q31_t)0x80D89F51, (q31_t)0xF1805662, + (q31_t)0x80D2E3F1, (q31_t)0xF1B248A5, (q31_t)0x80CD3C2F, + (q31_t)0xF1E43D1C, (q31_t)0x80C7A80A, (q31_t)0xF21633C0, + (q31_t)0x80C22783, (q31_t)0xF2482C89, (q31_t)0x80BCBA9C, + (q31_t)0xF27A2770, (q31_t)0x80B76155, (q31_t)0xF2AC246D, + (q31_t)0x80B21BAF, (q31_t)0xF2DE2378, (q31_t)0x80ACE9AB, + (q31_t)0xF310248A, (q31_t)0x80A7CB49, (q31_t)0xF342279A, + (q31_t)0x80A2C08B, (q31_t)0xF3742CA1, (q31_t)0x809DC970, + (q31_t)0xF3A63398, (q31_t)0x8098E5FB, (q31_t)0xF3D83C76, + (q31_t)0x8094162B, (q31_t)0xF40A4734, (q31_t)0x808F5A02, + (q31_t)0xF43C53CA, (q31_t)0x808AB180, (q31_t)0xF46E6231, + (q31_t)0x80861CA5, (q31_t)0xF4A07260, (q31_t)0x80819B74, + (q31_t)0xF4D28451, (q31_t)0x807D2DEB, (q31_t)0xF50497FA, + (q31_t)0x8078D40D, (q31_t)0xF536AD55, (q31_t)0x80748DD9, + (q31_t)0xF568C45A, (q31_t)0x80705B50, (q31_t)0xF59ADD01, + (q31_t)0x806C3C73, (q31_t)0xF5CCF743, (q31_t)0x80683143, + (q31_t)0xF5FF1317, (q31_t)0x806439C0, (q31_t)0xF6313076, + (q31_t)0x806055EA, (q31_t)0xF6634F58, (q31_t)0x805C85C3, + (q31_t)0xF6956FB6, (q31_t)0x8058C94C, (q31_t)0xF6C79188, + (q31_t)0x80552083, (q31_t)0xF6F9B4C5, (q31_t)0x80518B6B, + (q31_t)0xF72BD967, (q31_t)0x804E0A03, (q31_t)0xF75DFF65, + (q31_t)0x804A9C4D, (q31_t)0xF79026B8, (q31_t)0x80474248, + (q31_t)0xF7C24F58, (q31_t)0x8043FBF6, (q31_t)0xF7F4793E, + (q31_t)0x8040C956, (q31_t)0xF826A461, (q31_t)0x803DAA69, + (q31_t)0xF858D0BA, (q31_t)0x803A9F31, (q31_t)0xF88AFE41, + (q31_t)0x8037A7AC, (q31_t)0xF8BD2CEF, (q31_t)0x8034C3DC, + (q31_t)0xF8EF5CBB, (q31_t)0x8031F3C1, (q31_t)0xF9218D9E, + (q31_t)0x802F375C, (q31_t)0xF953BF90, (q31_t)0x802C8EAD, + (q31_t)0xF985F28A, (q31_t)0x8029F9B4, (q31_t)0xF9B82683, + (q31_t)0x80277872, (q31_t)0xF9EA5B75, (q31_t)0x80250AE7, + (q31_t)0xFA1C9156, (q31_t)0x8022B113, (q31_t)0xFA4EC820, + (q31_t)0x80206AF8, (q31_t)0xFA80FFCB, (q31_t)0x801E3894, + (q31_t)0xFAB3384F, (q31_t)0x801C19E9, (q31_t)0xFAE571A4, + (q31_t)0x801A0EF7, (q31_t)0xFB17ABC2, (q31_t)0x801817BF, + (q31_t)0xFB49E6A2, (q31_t)0x80163440, (q31_t)0xFB7C223C, + (q31_t)0x8014647A, (q31_t)0xFBAE5E89, (q31_t)0x8012A86F, + (q31_t)0xFBE09B80, (q31_t)0x8011001E, (q31_t)0xFC12D919, + (q31_t)0x800F6B88, (q31_t)0xFC45174E, (q31_t)0x800DEAAC, + (q31_t)0xFC775616, (q31_t)0x800C7D8C, (q31_t)0xFCA99569, + (q31_t)0x800B2427, (q31_t)0xFCDBD541, (q31_t)0x8009DE7D, + (q31_t)0xFD0E1594, (q31_t)0x8008AC90, (q31_t)0xFD40565B, + (q31_t)0x80078E5E, (q31_t)0xFD72978F, (q31_t)0x800683E8, + (q31_t)0xFDA4D928, (q31_t)0x80058D2E, (q31_t)0xFDD71B1E, + (q31_t)0x8004AA31, (q31_t)0xFE095D69, (q31_t)0x8003DAF0, + (q31_t)0xFE3BA001, (q31_t)0x80031F6C, (q31_t)0xFE6DE2E0, + (q31_t)0x800277A5, (q31_t)0xFEA025FC, (q31_t)0x8001E39B, + (q31_t)0xFED2694F, (q31_t)0x8001634D, (q31_t)0xFF04ACD0, + (q31_t)0x8000F6BD, (q31_t)0xFF36F078, (q31_t)0x80009DE9, + (q31_t)0xFF69343E, (q31_t)0x800058D3, (q31_t)0xFF9B781D, + (q31_t)0x8000277A, (q31_t)0xFFCDBC0A, (q31_t)0x800009DE +}; + + + +/* +* @brief q15 Twiddle factors Table +*/ + + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 16 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_16_q15[24] = { + (q15_t)0x7FFF, (q15_t)0x0000, + (q15_t)0x7641, (q15_t)0x30FB, + (q15_t)0x5A82, (q15_t)0x5A82, + (q15_t)0x30FB, (q15_t)0x7641, + (q15_t)0x0000, (q15_t)0x7FFF, + (q15_t)0xCF04, (q15_t)0x7641, + (q15_t)0xA57D, (q15_t)0x5A82, + (q15_t)0x89BE, (q15_t)0x30FB, + (q15_t)0x8000, (q15_t)0x0000, + (q15_t)0x89BE, (q15_t)0xCF04, + (q15_t)0xA57D, (q15_t)0xA57D, + (q15_t)0xCF04, (q15_t)0x89BE +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 32 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_32_q15[48] = { + (q15_t)0x7FFF, (q15_t)0x0000, + (q15_t)0x7D8A, (q15_t)0x18F8, + (q15_t)0x7641, (q15_t)0x30FB, + (q15_t)0x6A6D, (q15_t)0x471C, + (q15_t)0x5A82, (q15_t)0x5A82, + (q15_t)0x471C, (q15_t)0x6A6D, + (q15_t)0x30FB, (q15_t)0x7641, + (q15_t)0x18F8, (q15_t)0x7D8A, + (q15_t)0x0000, (q15_t)0x7FFF, + (q15_t)0xE707, (q15_t)0x7D8A, + (q15_t)0xCF04, (q15_t)0x7641, + (q15_t)0xB8E3, (q15_t)0x6A6D, + (q15_t)0xA57D, (q15_t)0x5A82, + (q15_t)0x9592, (q15_t)0x471C, + (q15_t)0x89BE, (q15_t)0x30FB, + (q15_t)0x8275, (q15_t)0x18F8, + (q15_t)0x8000, (q15_t)0x0000, + (q15_t)0x8275, (q15_t)0xE707, + (q15_t)0x89BE, (q15_t)0xCF04, + (q15_t)0x9592, (q15_t)0xB8E3, + (q15_t)0xA57D, (q15_t)0xA57D, + (q15_t)0xB8E3, (q15_t)0x9592, + (q15_t)0xCF04, (q15_t)0x89BE, + (q15_t)0xE707, (q15_t)0x8275 +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 64 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_64_q15[96] = { + (q15_t)0x7FFF, (q15_t)0x0000, (q15_t)0x7F62, (q15_t)0x0C8B, + (q15_t)0x7D8A, (q15_t)0x18F8, (q15_t)0x7A7D, (q15_t)0x2528, + (q15_t)0x7641, (q15_t)0x30FB, (q15_t)0x70E2, (q15_t)0x3C56, + (q15_t)0x6A6D, (q15_t)0x471C, (q15_t)0x62F2, (q15_t)0x5133, + (q15_t)0x5A82, (q15_t)0x5A82, (q15_t)0x5133, (q15_t)0x62F2, + (q15_t)0x471C, (q15_t)0x6A6D, (q15_t)0x3C56, (q15_t)0x70E2, + (q15_t)0x30FB, (q15_t)0x7641, (q15_t)0x2528, (q15_t)0x7A7D, + (q15_t)0x18F8, (q15_t)0x7D8A, (q15_t)0x0C8B, (q15_t)0x7F62, + (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0xF374, (q15_t)0x7F62, + (q15_t)0xE707, (q15_t)0x7D8A, (q15_t)0xDAD7, (q15_t)0x7A7D, + (q15_t)0xCF04, (q15_t)0x7641, (q15_t)0xC3A9, (q15_t)0x70E2, + (q15_t)0xB8E3, (q15_t)0x6A6D, (q15_t)0xAECC, (q15_t)0x62F2, + (q15_t)0xA57D, (q15_t)0x5A82, (q15_t)0x9D0D, (q15_t)0x5133, + (q15_t)0x9592, (q15_t)0x471C, (q15_t)0x8F1D, (q15_t)0x3C56, + (q15_t)0x89BE, (q15_t)0x30FB, (q15_t)0x8582, (q15_t)0x2528, + (q15_t)0x8275, (q15_t)0x18F8, (q15_t)0x809D, (q15_t)0x0C8B, + (q15_t)0x8000, (q15_t)0x0000, (q15_t)0x809D, (q15_t)0xF374, + (q15_t)0x8275, (q15_t)0xE707, (q15_t)0x8582, (q15_t)0xDAD7, + (q15_t)0x89BE, (q15_t)0xCF04, (q15_t)0x8F1D, (q15_t)0xC3A9, + (q15_t)0x9592, (q15_t)0xB8E3, (q15_t)0x9D0D, (q15_t)0xAECC, + (q15_t)0xA57D, (q15_t)0xA57D, (q15_t)0xAECC, (q15_t)0x9D0D, + (q15_t)0xB8E3, (q15_t)0x9592, (q15_t)0xC3A9, (q15_t)0x8F1D, + (q15_t)0xCF04, (q15_t)0x89BE, (q15_t)0xDAD7, (q15_t)0x8582, + (q15_t)0xE707, (q15_t)0x8275, (q15_t)0xF374, (q15_t)0x809D +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 128 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_128_q15[192] = { + (q15_t)0x7FFF, (q15_t)0x0000, (q15_t)0x7FD8, (q15_t)0x0647, + (q15_t)0x7F62, (q15_t)0x0C8B, (q15_t)0x7E9D, (q15_t)0x12C8, + (q15_t)0x7D8A, (q15_t)0x18F8, (q15_t)0x7C29, (q15_t)0x1F19, + (q15_t)0x7A7D, (q15_t)0x2528, (q15_t)0x7884, (q15_t)0x2B1F, + (q15_t)0x7641, (q15_t)0x30FB, (q15_t)0x73B5, (q15_t)0x36BA, + (q15_t)0x70E2, (q15_t)0x3C56, (q15_t)0x6DCA, (q15_t)0x41CE, + (q15_t)0x6A6D, (q15_t)0x471C, (q15_t)0x66CF, (q15_t)0x4C3F, + (q15_t)0x62F2, (q15_t)0x5133, (q15_t)0x5ED7, (q15_t)0x55F5, + (q15_t)0x5A82, (q15_t)0x5A82, (q15_t)0x55F5, (q15_t)0x5ED7, + (q15_t)0x5133, (q15_t)0x62F2, (q15_t)0x4C3F, (q15_t)0x66CF, + (q15_t)0x471C, (q15_t)0x6A6D, (q15_t)0x41CE, (q15_t)0x6DCA, + (q15_t)0x3C56, (q15_t)0x70E2, (q15_t)0x36BA, (q15_t)0x73B5, + (q15_t)0x30FB, (q15_t)0x7641, (q15_t)0x2B1F, (q15_t)0x7884, + (q15_t)0x2528, (q15_t)0x7A7D, (q15_t)0x1F19, (q15_t)0x7C29, + (q15_t)0x18F8, (q15_t)0x7D8A, (q15_t)0x12C8, (q15_t)0x7E9D, + (q15_t)0x0C8B, (q15_t)0x7F62, (q15_t)0x0647, (q15_t)0x7FD8, + (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0xF9B8, (q15_t)0x7FD8, + (q15_t)0xF374, (q15_t)0x7F62, (q15_t)0xED37, (q15_t)0x7E9D, + (q15_t)0xE707, (q15_t)0x7D8A, (q15_t)0xE0E6, (q15_t)0x7C29, + (q15_t)0xDAD7, (q15_t)0x7A7D, (q15_t)0xD4E0, (q15_t)0x7884, + (q15_t)0xCF04, (q15_t)0x7641, (q15_t)0xC945, (q15_t)0x73B5, + (q15_t)0xC3A9, (q15_t)0x70E2, (q15_t)0xBE31, (q15_t)0x6DCA, + (q15_t)0xB8E3, (q15_t)0x6A6D, (q15_t)0xB3C0, (q15_t)0x66CF, + (q15_t)0xAECC, (q15_t)0x62F2, (q15_t)0xAA0A, (q15_t)0x5ED7, + (q15_t)0xA57D, (q15_t)0x5A82, (q15_t)0xA128, (q15_t)0x55F5, + (q15_t)0x9D0D, (q15_t)0x5133, (q15_t)0x9930, (q15_t)0x4C3F, + (q15_t)0x9592, (q15_t)0x471C, (q15_t)0x9235, (q15_t)0x41CE, + (q15_t)0x8F1D, (q15_t)0x3C56, (q15_t)0x8C4A, (q15_t)0x36BA, + (q15_t)0x89BE, (q15_t)0x30FB, (q15_t)0x877B, (q15_t)0x2B1F, + (q15_t)0x8582, (q15_t)0x2528, (q15_t)0x83D6, (q15_t)0x1F19, + (q15_t)0x8275, (q15_t)0x18F8, (q15_t)0x8162, (q15_t)0x12C8, + (q15_t)0x809D, (q15_t)0x0C8B, (q15_t)0x8027, (q15_t)0x0647, + (q15_t)0x8000, (q15_t)0x0000, (q15_t)0x8027, (q15_t)0xF9B8, + (q15_t)0x809D, (q15_t)0xF374, (q15_t)0x8162, (q15_t)0xED37, + (q15_t)0x8275, (q15_t)0xE707, (q15_t)0x83D6, (q15_t)0xE0E6, + (q15_t)0x8582, (q15_t)0xDAD7, (q15_t)0x877B, (q15_t)0xD4E0, + (q15_t)0x89BE, (q15_t)0xCF04, (q15_t)0x8C4A, (q15_t)0xC945, + (q15_t)0x8F1D, (q15_t)0xC3A9, (q15_t)0x9235, (q15_t)0xBE31, + (q15_t)0x9592, (q15_t)0xB8E3, (q15_t)0x9930, (q15_t)0xB3C0, + (q15_t)0x9D0D, (q15_t)0xAECC, (q15_t)0xA128, (q15_t)0xAA0A, + (q15_t)0xA57D, (q15_t)0xA57D, (q15_t)0xAA0A, (q15_t)0xA128, + (q15_t)0xAECC, (q15_t)0x9D0D, (q15_t)0xB3C0, (q15_t)0x9930, + (q15_t)0xB8E3, (q15_t)0x9592, (q15_t)0xBE31, (q15_t)0x9235, + (q15_t)0xC3A9, (q15_t)0x8F1D, (q15_t)0xC945, (q15_t)0x8C4A, + (q15_t)0xCF04, (q15_t)0x89BE, (q15_t)0xD4E0, (q15_t)0x877B, + (q15_t)0xDAD7, (q15_t)0x8582, (q15_t)0xE0E6, (q15_t)0x83D6, + (q15_t)0xE707, (q15_t)0x8275, (q15_t)0xED37, (q15_t)0x8162, + (q15_t)0xF374, (q15_t)0x809D, (q15_t)0xF9B8, (q15_t)0x8027 +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 256 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_256_q15[384] = { + (q15_t)0x7FFF, (q15_t)0x0000, (q15_t)0x7FF6, (q15_t)0x0324, + (q15_t)0x7FD8, (q15_t)0x0647, (q15_t)0x7FA7, (q15_t)0x096A, + (q15_t)0x7F62, (q15_t)0x0C8B, (q15_t)0x7F09, (q15_t)0x0FAB, + (q15_t)0x7E9D, (q15_t)0x12C8, (q15_t)0x7E1D, (q15_t)0x15E2, + (q15_t)0x7D8A, (q15_t)0x18F8, (q15_t)0x7CE3, (q15_t)0x1C0B, + (q15_t)0x7C29, (q15_t)0x1F19, (q15_t)0x7B5D, (q15_t)0x2223, + (q15_t)0x7A7D, (q15_t)0x2528, (q15_t)0x798A, (q15_t)0x2826, + (q15_t)0x7884, (q15_t)0x2B1F, (q15_t)0x776C, (q15_t)0x2E11, + (q15_t)0x7641, (q15_t)0x30FB, (q15_t)0x7504, (q15_t)0x33DE, + (q15_t)0x73B5, (q15_t)0x36BA, (q15_t)0x7255, (q15_t)0x398C, + (q15_t)0x70E2, (q15_t)0x3C56, (q15_t)0x6F5F, (q15_t)0x3F17, + (q15_t)0x6DCA, (q15_t)0x41CE, (q15_t)0x6C24, (q15_t)0x447A, + (q15_t)0x6A6D, (q15_t)0x471C, (q15_t)0x68A6, (q15_t)0x49B4, + (q15_t)0x66CF, (q15_t)0x4C3F, (q15_t)0x64E8, (q15_t)0x4EBF, + (q15_t)0x62F2, (q15_t)0x5133, (q15_t)0x60EC, (q15_t)0x539B, + (q15_t)0x5ED7, (q15_t)0x55F5, (q15_t)0x5CB4, (q15_t)0x5842, + (q15_t)0x5A82, (q15_t)0x5A82, (q15_t)0x5842, (q15_t)0x5CB4, + (q15_t)0x55F5, (q15_t)0x5ED7, (q15_t)0x539B, (q15_t)0x60EC, + (q15_t)0x5133, (q15_t)0x62F2, (q15_t)0x4EBF, (q15_t)0x64E8, + (q15_t)0x4C3F, (q15_t)0x66CF, (q15_t)0x49B4, (q15_t)0x68A6, + (q15_t)0x471C, (q15_t)0x6A6D, (q15_t)0x447A, (q15_t)0x6C24, + (q15_t)0x41CE, (q15_t)0x6DCA, (q15_t)0x3F17, (q15_t)0x6F5F, + (q15_t)0x3C56, (q15_t)0x70E2, (q15_t)0x398C, (q15_t)0x7255, + (q15_t)0x36BA, (q15_t)0x73B5, (q15_t)0x33DE, (q15_t)0x7504, + (q15_t)0x30FB, (q15_t)0x7641, (q15_t)0x2E11, (q15_t)0x776C, + (q15_t)0x2B1F, (q15_t)0x7884, (q15_t)0x2826, (q15_t)0x798A, + (q15_t)0x2528, (q15_t)0x7A7D, (q15_t)0x2223, (q15_t)0x7B5D, + (q15_t)0x1F19, (q15_t)0x7C29, (q15_t)0x1C0B, (q15_t)0x7CE3, + (q15_t)0x18F8, (q15_t)0x7D8A, (q15_t)0x15E2, (q15_t)0x7E1D, + (q15_t)0x12C8, (q15_t)0x7E9D, (q15_t)0x0FAB, (q15_t)0x7F09, + (q15_t)0x0C8B, (q15_t)0x7F62, (q15_t)0x096A, (q15_t)0x7FA7, + (q15_t)0x0647, (q15_t)0x7FD8, (q15_t)0x0324, (q15_t)0x7FF6, + (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0xFCDB, (q15_t)0x7FF6, + (q15_t)0xF9B8, (q15_t)0x7FD8, (q15_t)0xF695, (q15_t)0x7FA7, + (q15_t)0xF374, (q15_t)0x7F62, (q15_t)0xF054, (q15_t)0x7F09, + (q15_t)0xED37, (q15_t)0x7E9D, (q15_t)0xEA1D, (q15_t)0x7E1D, + (q15_t)0xE707, (q15_t)0x7D8A, (q15_t)0xE3F4, (q15_t)0x7CE3, + (q15_t)0xE0E6, (q15_t)0x7C29, (q15_t)0xDDDC, (q15_t)0x7B5D, + (q15_t)0xDAD7, (q15_t)0x7A7D, (q15_t)0xD7D9, (q15_t)0x798A, + (q15_t)0xD4E0, (q15_t)0x7884, (q15_t)0xD1EE, (q15_t)0x776C, + (q15_t)0xCF04, (q15_t)0x7641, (q15_t)0xCC21, (q15_t)0x7504, + (q15_t)0xC945, (q15_t)0x73B5, (q15_t)0xC673, (q15_t)0x7255, + (q15_t)0xC3A9, (q15_t)0x70E2, (q15_t)0xC0E8, (q15_t)0x6F5F, + (q15_t)0xBE31, (q15_t)0x6DCA, (q15_t)0xBB85, (q15_t)0x6C24, + (q15_t)0xB8E3, (q15_t)0x6A6D, (q15_t)0xB64B, (q15_t)0x68A6, + (q15_t)0xB3C0, (q15_t)0x66CF, (q15_t)0xB140, (q15_t)0x64E8, + (q15_t)0xAECC, (q15_t)0x62F2, (q15_t)0xAC64, (q15_t)0x60EC, + (q15_t)0xAA0A, (q15_t)0x5ED7, (q15_t)0xA7BD, (q15_t)0x5CB4, + (q15_t)0xA57D, (q15_t)0x5A82, (q15_t)0xA34B, (q15_t)0x5842, + (q15_t)0xA128, (q15_t)0x55F5, (q15_t)0x9F13, (q15_t)0x539B, + (q15_t)0x9D0D, (q15_t)0x5133, (q15_t)0x9B17, (q15_t)0x4EBF, + (q15_t)0x9930, (q15_t)0x4C3F, (q15_t)0x9759, (q15_t)0x49B4, + (q15_t)0x9592, (q15_t)0x471C, (q15_t)0x93DB, (q15_t)0x447A, + (q15_t)0x9235, (q15_t)0x41CE, (q15_t)0x90A0, (q15_t)0x3F17, + (q15_t)0x8F1D, (q15_t)0x3C56, (q15_t)0x8DAA, (q15_t)0x398C, + (q15_t)0x8C4A, (q15_t)0x36BA, (q15_t)0x8AFB, (q15_t)0x33DE, + (q15_t)0x89BE, (q15_t)0x30FB, (q15_t)0x8893, (q15_t)0x2E11, + (q15_t)0x877B, (q15_t)0x2B1F, (q15_t)0x8675, (q15_t)0x2826, + (q15_t)0x8582, (q15_t)0x2528, (q15_t)0x84A2, (q15_t)0x2223, + (q15_t)0x83D6, (q15_t)0x1F19, (q15_t)0x831C, (q15_t)0x1C0B, + (q15_t)0x8275, (q15_t)0x18F8, (q15_t)0x81E2, (q15_t)0x15E2, + (q15_t)0x8162, (q15_t)0x12C8, (q15_t)0x80F6, (q15_t)0x0FAB, + (q15_t)0x809D, (q15_t)0x0C8B, (q15_t)0x8058, (q15_t)0x096A, + (q15_t)0x8027, (q15_t)0x0647, (q15_t)0x8009, (q15_t)0x0324, + (q15_t)0x8000, (q15_t)0x0000, (q15_t)0x8009, (q15_t)0xFCDB, + (q15_t)0x8027, (q15_t)0xF9B8, (q15_t)0x8058, (q15_t)0xF695, + (q15_t)0x809D, (q15_t)0xF374, (q15_t)0x80F6, (q15_t)0xF054, + (q15_t)0x8162, (q15_t)0xED37, (q15_t)0x81E2, (q15_t)0xEA1D, + (q15_t)0x8275, (q15_t)0xE707, (q15_t)0x831C, (q15_t)0xE3F4, + (q15_t)0x83D6, (q15_t)0xE0E6, (q15_t)0x84A2, (q15_t)0xDDDC, + (q15_t)0x8582, (q15_t)0xDAD7, (q15_t)0x8675, (q15_t)0xD7D9, + (q15_t)0x877B, (q15_t)0xD4E0, (q15_t)0x8893, (q15_t)0xD1EE, + (q15_t)0x89BE, (q15_t)0xCF04, (q15_t)0x8AFB, (q15_t)0xCC21, + (q15_t)0x8C4A, (q15_t)0xC945, (q15_t)0x8DAA, (q15_t)0xC673, + (q15_t)0x8F1D, (q15_t)0xC3A9, (q15_t)0x90A0, (q15_t)0xC0E8, + (q15_t)0x9235, (q15_t)0xBE31, (q15_t)0x93DB, (q15_t)0xBB85, + (q15_t)0x9592, (q15_t)0xB8E3, (q15_t)0x9759, (q15_t)0xB64B, + (q15_t)0x9930, (q15_t)0xB3C0, (q15_t)0x9B17, (q15_t)0xB140, + (q15_t)0x9D0D, (q15_t)0xAECC, (q15_t)0x9F13, (q15_t)0xAC64, + (q15_t)0xA128, (q15_t)0xAA0A, (q15_t)0xA34B, (q15_t)0xA7BD, + (q15_t)0xA57D, (q15_t)0xA57D, (q15_t)0xA7BD, (q15_t)0xA34B, + (q15_t)0xAA0A, (q15_t)0xA128, (q15_t)0xAC64, (q15_t)0x9F13, + (q15_t)0xAECC, (q15_t)0x9D0D, (q15_t)0xB140, (q15_t)0x9B17, + (q15_t)0xB3C0, (q15_t)0x9930, (q15_t)0xB64B, (q15_t)0x9759, + (q15_t)0xB8E3, (q15_t)0x9592, (q15_t)0xBB85, (q15_t)0x93DB, + (q15_t)0xBE31, (q15_t)0x9235, (q15_t)0xC0E8, (q15_t)0x90A0, + (q15_t)0xC3A9, (q15_t)0x8F1D, (q15_t)0xC673, (q15_t)0x8DAA, + (q15_t)0xC945, (q15_t)0x8C4A, (q15_t)0xCC21, (q15_t)0x8AFB, + (q15_t)0xCF04, (q15_t)0x89BE, (q15_t)0xD1EE, (q15_t)0x8893, + (q15_t)0xD4E0, (q15_t)0x877B, (q15_t)0xD7D9, (q15_t)0x8675, + (q15_t)0xDAD7, (q15_t)0x8582, (q15_t)0xDDDC, (q15_t)0x84A2, + (q15_t)0xE0E6, (q15_t)0x83D6, (q15_t)0xE3F4, (q15_t)0x831C, + (q15_t)0xE707, (q15_t)0x8275, (q15_t)0xEA1D, (q15_t)0x81E2, + (q15_t)0xED37, (q15_t)0x8162, (q15_t)0xF054, (q15_t)0x80F6, + (q15_t)0xF374, (q15_t)0x809D, (q15_t)0xF695, (q15_t)0x8058, + (q15_t)0xF9B8, (q15_t)0x8027, (q15_t)0xFCDB, (q15_t)0x8009 +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 512 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_512_q15[768] = { + (q15_t)0x7FFF, (q15_t)0x0000, (q15_t)0x7FFD, (q15_t)0x0192, + (q15_t)0x7FF6, (q15_t)0x0324, (q15_t)0x7FE9, (q15_t)0x04B6, + (q15_t)0x7FD8, (q15_t)0x0647, (q15_t)0x7FC2, (q15_t)0x07D9, + (q15_t)0x7FA7, (q15_t)0x096A, (q15_t)0x7F87, (q15_t)0x0AFB, + (q15_t)0x7F62, (q15_t)0x0C8B, (q15_t)0x7F38, (q15_t)0x0E1B, + (q15_t)0x7F09, (q15_t)0x0FAB, (q15_t)0x7ED5, (q15_t)0x1139, + (q15_t)0x7E9D, (q15_t)0x12C8, (q15_t)0x7E5F, (q15_t)0x1455, + (q15_t)0x7E1D, (q15_t)0x15E2, (q15_t)0x7DD6, (q15_t)0x176D, + (q15_t)0x7D8A, (q15_t)0x18F8, (q15_t)0x7D39, (q15_t)0x1A82, + (q15_t)0x7CE3, (q15_t)0x1C0B, (q15_t)0x7C89, (q15_t)0x1D93, + (q15_t)0x7C29, (q15_t)0x1F19, (q15_t)0x7BC5, (q15_t)0x209F, + (q15_t)0x7B5D, (q15_t)0x2223, (q15_t)0x7AEF, (q15_t)0x23A6, + (q15_t)0x7A7D, (q15_t)0x2528, (q15_t)0x7A05, (q15_t)0x26A8, + (q15_t)0x798A, (q15_t)0x2826, (q15_t)0x7909, (q15_t)0x29A3, + (q15_t)0x7884, (q15_t)0x2B1F, (q15_t)0x77FA, (q15_t)0x2C98, + (q15_t)0x776C, (q15_t)0x2E11, (q15_t)0x76D9, (q15_t)0x2F87, + (q15_t)0x7641, (q15_t)0x30FB, (q15_t)0x75A5, (q15_t)0x326E, + (q15_t)0x7504, (q15_t)0x33DE, (q15_t)0x745F, (q15_t)0x354D, + (q15_t)0x73B5, (q15_t)0x36BA, (q15_t)0x7307, (q15_t)0x3824, + (q15_t)0x7255, (q15_t)0x398C, (q15_t)0x719E, (q15_t)0x3AF2, + (q15_t)0x70E2, (q15_t)0x3C56, (q15_t)0x7023, (q15_t)0x3DB8, + (q15_t)0x6F5F, (q15_t)0x3F17, (q15_t)0x6E96, (q15_t)0x4073, + (q15_t)0x6DCA, (q15_t)0x41CE, (q15_t)0x6CF9, (q15_t)0x4325, + (q15_t)0x6C24, (q15_t)0x447A, (q15_t)0x6B4A, (q15_t)0x45CD, + (q15_t)0x6A6D, (q15_t)0x471C, (q15_t)0x698C, (q15_t)0x4869, + (q15_t)0x68A6, (q15_t)0x49B4, (q15_t)0x67BD, (q15_t)0x4AFB, + (q15_t)0x66CF, (q15_t)0x4C3F, (q15_t)0x65DD, (q15_t)0x4D81, + (q15_t)0x64E8, (q15_t)0x4EBF, (q15_t)0x63EF, (q15_t)0x4FFB, + (q15_t)0x62F2, (q15_t)0x5133, (q15_t)0x61F1, (q15_t)0x5269, + (q15_t)0x60EC, (q15_t)0x539B, (q15_t)0x5FE3, (q15_t)0x54CA, + (q15_t)0x5ED7, (q15_t)0x55F5, (q15_t)0x5DC7, (q15_t)0x571D, + (q15_t)0x5CB4, (q15_t)0x5842, (q15_t)0x5B9D, (q15_t)0x5964, + (q15_t)0x5A82, (q15_t)0x5A82, (q15_t)0x5964, (q15_t)0x5B9D, + (q15_t)0x5842, (q15_t)0x5CB4, (q15_t)0x571D, (q15_t)0x5DC7, + (q15_t)0x55F5, (q15_t)0x5ED7, (q15_t)0x54CA, (q15_t)0x5FE3, + (q15_t)0x539B, (q15_t)0x60EC, (q15_t)0x5269, (q15_t)0x61F1, + (q15_t)0x5133, (q15_t)0x62F2, (q15_t)0x4FFB, (q15_t)0x63EF, + (q15_t)0x4EBF, (q15_t)0x64E8, (q15_t)0x4D81, (q15_t)0x65DD, + (q15_t)0x4C3F, (q15_t)0x66CF, (q15_t)0x4AFB, (q15_t)0x67BD, + (q15_t)0x49B4, (q15_t)0x68A6, (q15_t)0x4869, (q15_t)0x698C, + (q15_t)0x471C, (q15_t)0x6A6D, (q15_t)0x45CD, (q15_t)0x6B4A, + (q15_t)0x447A, (q15_t)0x6C24, (q15_t)0x4325, (q15_t)0x6CF9, + (q15_t)0x41CE, (q15_t)0x6DCA, (q15_t)0x4073, (q15_t)0x6E96, + (q15_t)0x3F17, (q15_t)0x6F5F, (q15_t)0x3DB8, (q15_t)0x7023, + (q15_t)0x3C56, (q15_t)0x70E2, (q15_t)0x3AF2, (q15_t)0x719E, + (q15_t)0x398C, (q15_t)0x7255, (q15_t)0x3824, (q15_t)0x7307, + (q15_t)0x36BA, (q15_t)0x73B5, (q15_t)0x354D, (q15_t)0x745F, + (q15_t)0x33DE, (q15_t)0x7504, (q15_t)0x326E, (q15_t)0x75A5, + (q15_t)0x30FB, (q15_t)0x7641, (q15_t)0x2F87, (q15_t)0x76D9, + (q15_t)0x2E11, (q15_t)0x776C, (q15_t)0x2C98, (q15_t)0x77FA, + (q15_t)0x2B1F, (q15_t)0x7884, (q15_t)0x29A3, (q15_t)0x7909, + (q15_t)0x2826, (q15_t)0x798A, (q15_t)0x26A8, (q15_t)0x7A05, + (q15_t)0x2528, (q15_t)0x7A7D, (q15_t)0x23A6, (q15_t)0x7AEF, + (q15_t)0x2223, (q15_t)0x7B5D, (q15_t)0x209F, (q15_t)0x7BC5, + (q15_t)0x1F19, (q15_t)0x7C29, (q15_t)0x1D93, (q15_t)0x7C89, + (q15_t)0x1C0B, (q15_t)0x7CE3, (q15_t)0x1A82, (q15_t)0x7D39, + (q15_t)0x18F8, (q15_t)0x7D8A, (q15_t)0x176D, (q15_t)0x7DD6, + (q15_t)0x15E2, (q15_t)0x7E1D, (q15_t)0x1455, (q15_t)0x7E5F, + (q15_t)0x12C8, (q15_t)0x7E9D, (q15_t)0x1139, (q15_t)0x7ED5, + (q15_t)0x0FAB, (q15_t)0x7F09, (q15_t)0x0E1B, (q15_t)0x7F38, + (q15_t)0x0C8B, (q15_t)0x7F62, (q15_t)0x0AFB, (q15_t)0x7F87, + (q15_t)0x096A, (q15_t)0x7FA7, (q15_t)0x07D9, (q15_t)0x7FC2, + (q15_t)0x0647, (q15_t)0x7FD8, (q15_t)0x04B6, (q15_t)0x7FE9, + (q15_t)0x0324, (q15_t)0x7FF6, (q15_t)0x0192, (q15_t)0x7FFD, + (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0xFE6D, (q15_t)0x7FFD, + (q15_t)0xFCDB, (q15_t)0x7FF6, (q15_t)0xFB49, (q15_t)0x7FE9, + (q15_t)0xF9B8, (q15_t)0x7FD8, (q15_t)0xF826, (q15_t)0x7FC2, + (q15_t)0xF695, (q15_t)0x7FA7, (q15_t)0xF504, (q15_t)0x7F87, + (q15_t)0xF374, (q15_t)0x7F62, (q15_t)0xF1E4, (q15_t)0x7F38, + (q15_t)0xF054, (q15_t)0x7F09, (q15_t)0xEEC6, (q15_t)0x7ED5, + (q15_t)0xED37, (q15_t)0x7E9D, (q15_t)0xEBAA, (q15_t)0x7E5F, + (q15_t)0xEA1D, (q15_t)0x7E1D, (q15_t)0xE892, (q15_t)0x7DD6, + (q15_t)0xE707, (q15_t)0x7D8A, (q15_t)0xE57D, (q15_t)0x7D39, + (q15_t)0xE3F4, (q15_t)0x7CE3, (q15_t)0xE26C, (q15_t)0x7C89, + (q15_t)0xE0E6, (q15_t)0x7C29, (q15_t)0xDF60, (q15_t)0x7BC5, + (q15_t)0xDDDC, (q15_t)0x7B5D, (q15_t)0xDC59, (q15_t)0x7AEF, + (q15_t)0xDAD7, (q15_t)0x7A7D, (q15_t)0xD957, (q15_t)0x7A05, + (q15_t)0xD7D9, (q15_t)0x798A, (q15_t)0xD65C, (q15_t)0x7909, + (q15_t)0xD4E0, (q15_t)0x7884, (q15_t)0xD367, (q15_t)0x77FA, + (q15_t)0xD1EE, (q15_t)0x776C, (q15_t)0xD078, (q15_t)0x76D9, + (q15_t)0xCF04, (q15_t)0x7641, (q15_t)0xCD91, (q15_t)0x75A5, + (q15_t)0xCC21, (q15_t)0x7504, (q15_t)0xCAB2, (q15_t)0x745F, + (q15_t)0xC945, (q15_t)0x73B5, (q15_t)0xC7DB, (q15_t)0x7307, + (q15_t)0xC673, (q15_t)0x7255, (q15_t)0xC50D, (q15_t)0x719E, + (q15_t)0xC3A9, (q15_t)0x70E2, (q15_t)0xC247, (q15_t)0x7023, + (q15_t)0xC0E8, (q15_t)0x6F5F, (q15_t)0xBF8C, (q15_t)0x6E96, + (q15_t)0xBE31, (q15_t)0x6DCA, (q15_t)0xBCDA, (q15_t)0x6CF9, + (q15_t)0xBB85, (q15_t)0x6C24, (q15_t)0xBA32, (q15_t)0x6B4A, + (q15_t)0xB8E3, (q15_t)0x6A6D, (q15_t)0xB796, (q15_t)0x698C, + (q15_t)0xB64B, (q15_t)0x68A6, (q15_t)0xB504, (q15_t)0x67BD, + (q15_t)0xB3C0, (q15_t)0x66CF, (q15_t)0xB27E, (q15_t)0x65DD, + (q15_t)0xB140, (q15_t)0x64E8, (q15_t)0xB004, (q15_t)0x63EF, + (q15_t)0xAECC, (q15_t)0x62F2, (q15_t)0xAD96, (q15_t)0x61F1, + (q15_t)0xAC64, (q15_t)0x60EC, (q15_t)0xAB35, (q15_t)0x5FE3, + (q15_t)0xAA0A, (q15_t)0x5ED7, (q15_t)0xA8E2, (q15_t)0x5DC7, + (q15_t)0xA7BD, (q15_t)0x5CB4, (q15_t)0xA69B, (q15_t)0x5B9D, + (q15_t)0xA57D, (q15_t)0x5A82, (q15_t)0xA462, (q15_t)0x5964, + (q15_t)0xA34B, (q15_t)0x5842, (q15_t)0xA238, (q15_t)0x571D, + (q15_t)0xA128, (q15_t)0x55F5, (q15_t)0xA01C, (q15_t)0x54CA, + (q15_t)0x9F13, (q15_t)0x539B, (q15_t)0x9E0E, (q15_t)0x5269, + (q15_t)0x9D0D, (q15_t)0x5133, (q15_t)0x9C10, (q15_t)0x4FFB, + (q15_t)0x9B17, (q15_t)0x4EBF, (q15_t)0x9A22, (q15_t)0x4D81, + (q15_t)0x9930, (q15_t)0x4C3F, (q15_t)0x9842, (q15_t)0x4AFB, + (q15_t)0x9759, (q15_t)0x49B4, (q15_t)0x9673, (q15_t)0x4869, + (q15_t)0x9592, (q15_t)0x471C, (q15_t)0x94B5, (q15_t)0x45CD, + (q15_t)0x93DB, (q15_t)0x447A, (q15_t)0x9306, (q15_t)0x4325, + (q15_t)0x9235, (q15_t)0x41CE, (q15_t)0x9169, (q15_t)0x4073, + (q15_t)0x90A0, (q15_t)0x3F17, (q15_t)0x8FDC, (q15_t)0x3DB8, + (q15_t)0x8F1D, (q15_t)0x3C56, (q15_t)0x8E61, (q15_t)0x3AF2, + (q15_t)0x8DAA, (q15_t)0x398C, (q15_t)0x8CF8, (q15_t)0x3824, + (q15_t)0x8C4A, (q15_t)0x36BA, (q15_t)0x8BA0, (q15_t)0x354D, + (q15_t)0x8AFB, (q15_t)0x33DE, (q15_t)0x8A5A, (q15_t)0x326E, + (q15_t)0x89BE, (q15_t)0x30FB, (q15_t)0x8926, (q15_t)0x2F87, + (q15_t)0x8893, (q15_t)0x2E11, (q15_t)0x8805, (q15_t)0x2C98, + (q15_t)0x877B, (q15_t)0x2B1F, (q15_t)0x86F6, (q15_t)0x29A3, + (q15_t)0x8675, (q15_t)0x2826, (q15_t)0x85FA, (q15_t)0x26A8, + (q15_t)0x8582, (q15_t)0x2528, (q15_t)0x8510, (q15_t)0x23A6, + (q15_t)0x84A2, (q15_t)0x2223, (q15_t)0x843A, (q15_t)0x209F, + (q15_t)0x83D6, (q15_t)0x1F19, (q15_t)0x8376, (q15_t)0x1D93, + (q15_t)0x831C, (q15_t)0x1C0B, (q15_t)0x82C6, (q15_t)0x1A82, + (q15_t)0x8275, (q15_t)0x18F8, (q15_t)0x8229, (q15_t)0x176D, + (q15_t)0x81E2, (q15_t)0x15E2, (q15_t)0x81A0, (q15_t)0x1455, + (q15_t)0x8162, (q15_t)0x12C8, (q15_t)0x812A, (q15_t)0x1139, + (q15_t)0x80F6, (q15_t)0x0FAB, (q15_t)0x80C7, (q15_t)0x0E1B, + (q15_t)0x809D, (q15_t)0x0C8B, (q15_t)0x8078, (q15_t)0x0AFB, + (q15_t)0x8058, (q15_t)0x096A, (q15_t)0x803D, (q15_t)0x07D9, + (q15_t)0x8027, (q15_t)0x0647, (q15_t)0x8016, (q15_t)0x04B6, + (q15_t)0x8009, (q15_t)0x0324, (q15_t)0x8002, (q15_t)0x0192, + (q15_t)0x8000, (q15_t)0x0000, (q15_t)0x8002, (q15_t)0xFE6D, + (q15_t)0x8009, (q15_t)0xFCDB, (q15_t)0x8016, (q15_t)0xFB49, + (q15_t)0x8027, (q15_t)0xF9B8, (q15_t)0x803D, (q15_t)0xF826, + (q15_t)0x8058, (q15_t)0xF695, (q15_t)0x8078, (q15_t)0xF504, + (q15_t)0x809D, (q15_t)0xF374, (q15_t)0x80C7, (q15_t)0xF1E4, + (q15_t)0x80F6, (q15_t)0xF054, (q15_t)0x812A, (q15_t)0xEEC6, + (q15_t)0x8162, (q15_t)0xED37, (q15_t)0x81A0, (q15_t)0xEBAA, + (q15_t)0x81E2, (q15_t)0xEA1D, (q15_t)0x8229, (q15_t)0xE892, + (q15_t)0x8275, (q15_t)0xE707, (q15_t)0x82C6, (q15_t)0xE57D, + (q15_t)0x831C, (q15_t)0xE3F4, (q15_t)0x8376, (q15_t)0xE26C, + (q15_t)0x83D6, (q15_t)0xE0E6, (q15_t)0x843A, (q15_t)0xDF60, + (q15_t)0x84A2, (q15_t)0xDDDC, (q15_t)0x8510, (q15_t)0xDC59, + (q15_t)0x8582, (q15_t)0xDAD7, (q15_t)0x85FA, (q15_t)0xD957, + (q15_t)0x8675, (q15_t)0xD7D9, (q15_t)0x86F6, (q15_t)0xD65C, + (q15_t)0x877B, (q15_t)0xD4E0, (q15_t)0x8805, (q15_t)0xD367, + (q15_t)0x8893, (q15_t)0xD1EE, (q15_t)0x8926, (q15_t)0xD078, + (q15_t)0x89BE, (q15_t)0xCF04, (q15_t)0x8A5A, (q15_t)0xCD91, + (q15_t)0x8AFB, (q15_t)0xCC21, (q15_t)0x8BA0, (q15_t)0xCAB2, + (q15_t)0x8C4A, (q15_t)0xC945, (q15_t)0x8CF8, (q15_t)0xC7DB, + (q15_t)0x8DAA, (q15_t)0xC673, (q15_t)0x8E61, (q15_t)0xC50D, + (q15_t)0x8F1D, (q15_t)0xC3A9, (q15_t)0x8FDC, (q15_t)0xC247, + (q15_t)0x90A0, (q15_t)0xC0E8, (q15_t)0x9169, (q15_t)0xBF8C, + (q15_t)0x9235, (q15_t)0xBE31, (q15_t)0x9306, (q15_t)0xBCDA, + (q15_t)0x93DB, (q15_t)0xBB85, (q15_t)0x94B5, (q15_t)0xBA32, + (q15_t)0x9592, (q15_t)0xB8E3, (q15_t)0x9673, (q15_t)0xB796, + (q15_t)0x9759, (q15_t)0xB64B, (q15_t)0x9842, (q15_t)0xB504, + (q15_t)0x9930, (q15_t)0xB3C0, (q15_t)0x9A22, (q15_t)0xB27E, + (q15_t)0x9B17, (q15_t)0xB140, (q15_t)0x9C10, (q15_t)0xB004, + (q15_t)0x9D0D, (q15_t)0xAECC, (q15_t)0x9E0E, (q15_t)0xAD96, + (q15_t)0x9F13, (q15_t)0xAC64, (q15_t)0xA01C, (q15_t)0xAB35, + (q15_t)0xA128, (q15_t)0xAA0A, (q15_t)0xA238, (q15_t)0xA8E2, + (q15_t)0xA34B, (q15_t)0xA7BD, (q15_t)0xA462, (q15_t)0xA69B, + (q15_t)0xA57D, (q15_t)0xA57D, (q15_t)0xA69B, (q15_t)0xA462, + (q15_t)0xA7BD, (q15_t)0xA34B, (q15_t)0xA8E2, (q15_t)0xA238, + (q15_t)0xAA0A, (q15_t)0xA128, (q15_t)0xAB35, (q15_t)0xA01C, + (q15_t)0xAC64, (q15_t)0x9F13, (q15_t)0xAD96, (q15_t)0x9E0E, + (q15_t)0xAECC, (q15_t)0x9D0D, (q15_t)0xB004, (q15_t)0x9C10, + (q15_t)0xB140, (q15_t)0x9B17, (q15_t)0xB27E, (q15_t)0x9A22, + (q15_t)0xB3C0, (q15_t)0x9930, (q15_t)0xB504, (q15_t)0x9842, + (q15_t)0xB64B, (q15_t)0x9759, (q15_t)0xB796, (q15_t)0x9673, + (q15_t)0xB8E3, (q15_t)0x9592, (q15_t)0xBA32, (q15_t)0x94B5, + (q15_t)0xBB85, (q15_t)0x93DB, (q15_t)0xBCDA, (q15_t)0x9306, + (q15_t)0xBE31, (q15_t)0x9235, (q15_t)0xBF8C, (q15_t)0x9169, + (q15_t)0xC0E8, (q15_t)0x90A0, (q15_t)0xC247, (q15_t)0x8FDC, + (q15_t)0xC3A9, (q15_t)0x8F1D, (q15_t)0xC50D, (q15_t)0x8E61, + (q15_t)0xC673, (q15_t)0x8DAA, (q15_t)0xC7DB, (q15_t)0x8CF8, + (q15_t)0xC945, (q15_t)0x8C4A, (q15_t)0xCAB2, (q15_t)0x8BA0, + (q15_t)0xCC21, (q15_t)0x8AFB, (q15_t)0xCD91, (q15_t)0x8A5A, + (q15_t)0xCF04, (q15_t)0x89BE, (q15_t)0xD078, (q15_t)0x8926, + (q15_t)0xD1EE, (q15_t)0x8893, (q15_t)0xD367, (q15_t)0x8805, + (q15_t)0xD4E0, (q15_t)0x877B, (q15_t)0xD65C, (q15_t)0x86F6, + (q15_t)0xD7D9, (q15_t)0x8675, (q15_t)0xD957, (q15_t)0x85FA, + (q15_t)0xDAD7, (q15_t)0x8582, (q15_t)0xDC59, (q15_t)0x8510, + (q15_t)0xDDDC, (q15_t)0x84A2, (q15_t)0xDF60, (q15_t)0x843A, + (q15_t)0xE0E6, (q15_t)0x83D6, (q15_t)0xE26C, (q15_t)0x8376, + (q15_t)0xE3F4, (q15_t)0x831C, (q15_t)0xE57D, (q15_t)0x82C6, + (q15_t)0xE707, (q15_t)0x8275, (q15_t)0xE892, (q15_t)0x8229, + (q15_t)0xEA1D, (q15_t)0x81E2, (q15_t)0xEBAA, (q15_t)0x81A0, + (q15_t)0xED37, (q15_t)0x8162, (q15_t)0xEEC6, (q15_t)0x812A, + (q15_t)0xF054, (q15_t)0x80F6, (q15_t)0xF1E4, (q15_t)0x80C7, + (q15_t)0xF374, (q15_t)0x809D, (q15_t)0xF504, (q15_t)0x8078, + (q15_t)0xF695, (q15_t)0x8058, (q15_t)0xF826, (q15_t)0x803D, + (q15_t)0xF9B8, (q15_t)0x8027, (q15_t)0xFB49, (q15_t)0x8016, + (q15_t)0xFCDB, (q15_t)0x8009, (q15_t)0xFE6D, (q15_t)0x8002 +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 1024 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_1024_q15[1536] = { + (q15_t)0x7FFF, (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0x00C9, + (q15_t)0x7FFD, (q15_t)0x0192, (q15_t)0x7FFA, (q15_t)0x025B, + (q15_t)0x7FF6, (q15_t)0x0324, (q15_t)0x7FF0, (q15_t)0x03ED, + (q15_t)0x7FE9, (q15_t)0x04B6, (q15_t)0x7FE1, (q15_t)0x057F, + (q15_t)0x7FD8, (q15_t)0x0647, (q15_t)0x7FCE, (q15_t)0x0710, + (q15_t)0x7FC2, (q15_t)0x07D9, (q15_t)0x7FB5, (q15_t)0x08A2, + (q15_t)0x7FA7, (q15_t)0x096A, (q15_t)0x7F97, (q15_t)0x0A33, + (q15_t)0x7F87, (q15_t)0x0AFB, (q15_t)0x7F75, (q15_t)0x0BC3, + (q15_t)0x7F62, (q15_t)0x0C8B, (q15_t)0x7F4D, (q15_t)0x0D53, + (q15_t)0x7F38, (q15_t)0x0E1B, (q15_t)0x7F21, (q15_t)0x0EE3, + (q15_t)0x7F09, (q15_t)0x0FAB, (q15_t)0x7EF0, (q15_t)0x1072, + (q15_t)0x7ED5, (q15_t)0x1139, (q15_t)0x7EBA, (q15_t)0x1201, + (q15_t)0x7E9D, (q15_t)0x12C8, (q15_t)0x7E7F, (q15_t)0x138E, + (q15_t)0x7E5F, (q15_t)0x1455, (q15_t)0x7E3F, (q15_t)0x151B, + (q15_t)0x7E1D, (q15_t)0x15E2, (q15_t)0x7DFA, (q15_t)0x16A8, + (q15_t)0x7DD6, (q15_t)0x176D, (q15_t)0x7DB0, (q15_t)0x1833, + (q15_t)0x7D8A, (q15_t)0x18F8, (q15_t)0x7D62, (q15_t)0x19BD, + (q15_t)0x7D39, (q15_t)0x1A82, (q15_t)0x7D0F, (q15_t)0x1B47, + (q15_t)0x7CE3, (q15_t)0x1C0B, (q15_t)0x7CB7, (q15_t)0x1CCF, + (q15_t)0x7C89, (q15_t)0x1D93, (q15_t)0x7C5A, (q15_t)0x1E56, + (q15_t)0x7C29, (q15_t)0x1F19, (q15_t)0x7BF8, (q15_t)0x1FDC, + (q15_t)0x7BC5, (q15_t)0x209F, (q15_t)0x7B92, (q15_t)0x2161, + (q15_t)0x7B5D, (q15_t)0x2223, (q15_t)0x7B26, (q15_t)0x22E5, + (q15_t)0x7AEF, (q15_t)0x23A6, (q15_t)0x7AB6, (q15_t)0x2467, + (q15_t)0x7A7D, (q15_t)0x2528, (q15_t)0x7A42, (q15_t)0x25E8, + (q15_t)0x7A05, (q15_t)0x26A8, (q15_t)0x79C8, (q15_t)0x2767, + (q15_t)0x798A, (q15_t)0x2826, (q15_t)0x794A, (q15_t)0x28E5, + (q15_t)0x7909, (q15_t)0x29A3, (q15_t)0x78C7, (q15_t)0x2A61, + (q15_t)0x7884, (q15_t)0x2B1F, (q15_t)0x7840, (q15_t)0x2BDC, + (q15_t)0x77FA, (q15_t)0x2C98, (q15_t)0x77B4, (q15_t)0x2D55, + (q15_t)0x776C, (q15_t)0x2E11, (q15_t)0x7723, (q15_t)0x2ECC, + (q15_t)0x76D9, (q15_t)0x2F87, (q15_t)0x768E, (q15_t)0x3041, + (q15_t)0x7641, (q15_t)0x30FB, (q15_t)0x75F4, (q15_t)0x31B5, + (q15_t)0x75A5, (q15_t)0x326E, (q15_t)0x7555, (q15_t)0x3326, + (q15_t)0x7504, (q15_t)0x33DE, (q15_t)0x74B2, (q15_t)0x3496, + (q15_t)0x745F, (q15_t)0x354D, (q15_t)0x740B, (q15_t)0x3604, + (q15_t)0x73B5, (q15_t)0x36BA, (q15_t)0x735F, (q15_t)0x376F, + (q15_t)0x7307, (q15_t)0x3824, (q15_t)0x72AF, (q15_t)0x38D8, + (q15_t)0x7255, (q15_t)0x398C, (q15_t)0x71FA, (q15_t)0x3A40, + (q15_t)0x719E, (q15_t)0x3AF2, (q15_t)0x7141, (q15_t)0x3BA5, + (q15_t)0x70E2, (q15_t)0x3C56, (q15_t)0x7083, (q15_t)0x3D07, + (q15_t)0x7023, (q15_t)0x3DB8, (q15_t)0x6FC1, (q15_t)0x3E68, + (q15_t)0x6F5F, (q15_t)0x3F17, (q15_t)0x6EFB, (q15_t)0x3FC5, + (q15_t)0x6E96, (q15_t)0x4073, (q15_t)0x6E30, (q15_t)0x4121, + (q15_t)0x6DCA, (q15_t)0x41CE, (q15_t)0x6D62, (q15_t)0x427A, + (q15_t)0x6CF9, (q15_t)0x4325, (q15_t)0x6C8F, (q15_t)0x43D0, + (q15_t)0x6C24, (q15_t)0x447A, (q15_t)0x6BB8, (q15_t)0x4524, + (q15_t)0x6B4A, (q15_t)0x45CD, (q15_t)0x6ADC, (q15_t)0x4675, + (q15_t)0x6A6D, (q15_t)0x471C, (q15_t)0x69FD, (q15_t)0x47C3, + (q15_t)0x698C, (q15_t)0x4869, (q15_t)0x6919, (q15_t)0x490F, + (q15_t)0x68A6, (q15_t)0x49B4, (q15_t)0x6832, (q15_t)0x4A58, + (q15_t)0x67BD, (q15_t)0x4AFB, (q15_t)0x6746, (q15_t)0x4B9E, + (q15_t)0x66CF, (q15_t)0x4C3F, (q15_t)0x6657, (q15_t)0x4CE1, + (q15_t)0x65DD, (q15_t)0x4D81, (q15_t)0x6563, (q15_t)0x4E21, + (q15_t)0x64E8, (q15_t)0x4EBF, (q15_t)0x646C, (q15_t)0x4F5E, + (q15_t)0x63EF, (q15_t)0x4FFB, (q15_t)0x6371, (q15_t)0x5097, + (q15_t)0x62F2, (q15_t)0x5133, (q15_t)0x6271, (q15_t)0x51CE, + (q15_t)0x61F1, (q15_t)0x5269, (q15_t)0x616F, (q15_t)0x5302, + (q15_t)0x60EC, (q15_t)0x539B, (q15_t)0x6068, (q15_t)0x5433, + (q15_t)0x5FE3, (q15_t)0x54CA, (q15_t)0x5F5E, (q15_t)0x5560, + (q15_t)0x5ED7, (q15_t)0x55F5, (q15_t)0x5E50, (q15_t)0x568A, + (q15_t)0x5DC7, (q15_t)0x571D, (q15_t)0x5D3E, (q15_t)0x57B0, + (q15_t)0x5CB4, (q15_t)0x5842, (q15_t)0x5C29, (q15_t)0x58D4, + (q15_t)0x5B9D, (q15_t)0x5964, (q15_t)0x5B10, (q15_t)0x59F3, + (q15_t)0x5A82, (q15_t)0x5A82, (q15_t)0x59F3, (q15_t)0x5B10, + (q15_t)0x5964, (q15_t)0x5B9D, (q15_t)0x58D4, (q15_t)0x5C29, + (q15_t)0x5842, (q15_t)0x5CB4, (q15_t)0x57B0, (q15_t)0x5D3E, + (q15_t)0x571D, (q15_t)0x5DC7, (q15_t)0x568A, (q15_t)0x5E50, + (q15_t)0x55F5, (q15_t)0x5ED7, (q15_t)0x5560, (q15_t)0x5F5E, + (q15_t)0x54CA, (q15_t)0x5FE3, (q15_t)0x5433, (q15_t)0x6068, + (q15_t)0x539B, (q15_t)0x60EC, (q15_t)0x5302, (q15_t)0x616F, + (q15_t)0x5269, (q15_t)0x61F1, (q15_t)0x51CE, (q15_t)0x6271, + (q15_t)0x5133, (q15_t)0x62F2, (q15_t)0x5097, (q15_t)0x6371, + (q15_t)0x4FFB, (q15_t)0x63EF, (q15_t)0x4F5E, (q15_t)0x646C, + (q15_t)0x4EBF, (q15_t)0x64E8, (q15_t)0x4E21, (q15_t)0x6563, + (q15_t)0x4D81, (q15_t)0x65DD, (q15_t)0x4CE1, (q15_t)0x6657, + (q15_t)0x4C3F, (q15_t)0x66CF, (q15_t)0x4B9E, (q15_t)0x6746, + (q15_t)0x4AFB, (q15_t)0x67BD, (q15_t)0x4A58, (q15_t)0x6832, + (q15_t)0x49B4, (q15_t)0x68A6, (q15_t)0x490F, (q15_t)0x6919, + (q15_t)0x4869, (q15_t)0x698C, (q15_t)0x47C3, (q15_t)0x69FD, + (q15_t)0x471C, (q15_t)0x6A6D, (q15_t)0x4675, (q15_t)0x6ADC, + (q15_t)0x45CD, (q15_t)0x6B4A, (q15_t)0x4524, (q15_t)0x6BB8, + (q15_t)0x447A, (q15_t)0x6C24, (q15_t)0x43D0, (q15_t)0x6C8F, + (q15_t)0x4325, (q15_t)0x6CF9, (q15_t)0x427A, (q15_t)0x6D62, + (q15_t)0x41CE, (q15_t)0x6DCA, (q15_t)0x4121, (q15_t)0x6E30, + (q15_t)0x4073, (q15_t)0x6E96, (q15_t)0x3FC5, (q15_t)0x6EFB, + (q15_t)0x3F17, (q15_t)0x6F5F, (q15_t)0x3E68, (q15_t)0x6FC1, + (q15_t)0x3DB8, (q15_t)0x7023, (q15_t)0x3D07, (q15_t)0x7083, + (q15_t)0x3C56, (q15_t)0x70E2, (q15_t)0x3BA5, (q15_t)0x7141, + (q15_t)0x3AF2, (q15_t)0x719E, (q15_t)0x3A40, (q15_t)0x71FA, + (q15_t)0x398C, (q15_t)0x7255, (q15_t)0x38D8, (q15_t)0x72AF, + (q15_t)0x3824, (q15_t)0x7307, (q15_t)0x376F, (q15_t)0x735F, + (q15_t)0x36BA, (q15_t)0x73B5, (q15_t)0x3604, (q15_t)0x740B, + (q15_t)0x354D, (q15_t)0x745F, (q15_t)0x3496, (q15_t)0x74B2, + (q15_t)0x33DE, (q15_t)0x7504, (q15_t)0x3326, (q15_t)0x7555, + (q15_t)0x326E, (q15_t)0x75A5, (q15_t)0x31B5, (q15_t)0x75F4, + (q15_t)0x30FB, (q15_t)0x7641, (q15_t)0x3041, (q15_t)0x768E, + (q15_t)0x2F87, (q15_t)0x76D9, (q15_t)0x2ECC, (q15_t)0x7723, + (q15_t)0x2E11, (q15_t)0x776C, (q15_t)0x2D55, (q15_t)0x77B4, + (q15_t)0x2C98, (q15_t)0x77FA, (q15_t)0x2BDC, (q15_t)0x7840, + (q15_t)0x2B1F, (q15_t)0x7884, (q15_t)0x2A61, (q15_t)0x78C7, + (q15_t)0x29A3, (q15_t)0x7909, (q15_t)0x28E5, (q15_t)0x794A, + (q15_t)0x2826, (q15_t)0x798A, (q15_t)0x2767, (q15_t)0x79C8, + (q15_t)0x26A8, (q15_t)0x7A05, (q15_t)0x25E8, (q15_t)0x7A42, + (q15_t)0x2528, (q15_t)0x7A7D, (q15_t)0x2467, (q15_t)0x7AB6, + (q15_t)0x23A6, (q15_t)0x7AEF, (q15_t)0x22E5, (q15_t)0x7B26, + (q15_t)0x2223, (q15_t)0x7B5D, (q15_t)0x2161, (q15_t)0x7B92, + (q15_t)0x209F, (q15_t)0x7BC5, (q15_t)0x1FDC, (q15_t)0x7BF8, + (q15_t)0x1F19, (q15_t)0x7C29, (q15_t)0x1E56, (q15_t)0x7C5A, + (q15_t)0x1D93, (q15_t)0x7C89, (q15_t)0x1CCF, (q15_t)0x7CB7, + (q15_t)0x1C0B, (q15_t)0x7CE3, (q15_t)0x1B47, (q15_t)0x7D0F, + (q15_t)0x1A82, (q15_t)0x7D39, (q15_t)0x19BD, (q15_t)0x7D62, + (q15_t)0x18F8, (q15_t)0x7D8A, (q15_t)0x1833, (q15_t)0x7DB0, + (q15_t)0x176D, (q15_t)0x7DD6, (q15_t)0x16A8, (q15_t)0x7DFA, + (q15_t)0x15E2, (q15_t)0x7E1D, (q15_t)0x151B, (q15_t)0x7E3F, + (q15_t)0x1455, (q15_t)0x7E5F, (q15_t)0x138E, (q15_t)0x7E7F, + (q15_t)0x12C8, (q15_t)0x7E9D, (q15_t)0x1201, (q15_t)0x7EBA, + (q15_t)0x1139, (q15_t)0x7ED5, (q15_t)0x1072, (q15_t)0x7EF0, + (q15_t)0x0FAB, (q15_t)0x7F09, (q15_t)0x0EE3, (q15_t)0x7F21, + (q15_t)0x0E1B, (q15_t)0x7F38, (q15_t)0x0D53, (q15_t)0x7F4D, + (q15_t)0x0C8B, (q15_t)0x7F62, (q15_t)0x0BC3, (q15_t)0x7F75, + (q15_t)0x0AFB, (q15_t)0x7F87, (q15_t)0x0A33, (q15_t)0x7F97, + (q15_t)0x096A, (q15_t)0x7FA7, (q15_t)0x08A2, (q15_t)0x7FB5, + (q15_t)0x07D9, (q15_t)0x7FC2, (q15_t)0x0710, (q15_t)0x7FCE, + (q15_t)0x0647, (q15_t)0x7FD8, (q15_t)0x057F, (q15_t)0x7FE1, + (q15_t)0x04B6, (q15_t)0x7FE9, (q15_t)0x03ED, (q15_t)0x7FF0, + (q15_t)0x0324, (q15_t)0x7FF6, (q15_t)0x025B, (q15_t)0x7FFA, + (q15_t)0x0192, (q15_t)0x7FFD, (q15_t)0x00C9, (q15_t)0x7FFF, + (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0xFF36, (q15_t)0x7FFF, + (q15_t)0xFE6D, (q15_t)0x7FFD, (q15_t)0xFDA4, (q15_t)0x7FFA, + (q15_t)0xFCDB, (q15_t)0x7FF6, (q15_t)0xFC12, (q15_t)0x7FF0, + (q15_t)0xFB49, (q15_t)0x7FE9, (q15_t)0xFA80, (q15_t)0x7FE1, + (q15_t)0xF9B8, (q15_t)0x7FD8, (q15_t)0xF8EF, (q15_t)0x7FCE, + (q15_t)0xF826, (q15_t)0x7FC2, (q15_t)0xF75D, (q15_t)0x7FB5, + (q15_t)0xF695, (q15_t)0x7FA7, (q15_t)0xF5CC, (q15_t)0x7F97, + (q15_t)0xF504, (q15_t)0x7F87, (q15_t)0xF43C, (q15_t)0x7F75, + (q15_t)0xF374, (q15_t)0x7F62, (q15_t)0xF2AC, (q15_t)0x7F4D, + (q15_t)0xF1E4, (q15_t)0x7F38, (q15_t)0xF11C, (q15_t)0x7F21, + (q15_t)0xF054, (q15_t)0x7F09, (q15_t)0xEF8D, (q15_t)0x7EF0, + (q15_t)0xEEC6, (q15_t)0x7ED5, (q15_t)0xEDFE, (q15_t)0x7EBA, + (q15_t)0xED37, (q15_t)0x7E9D, (q15_t)0xEC71, (q15_t)0x7E7F, + (q15_t)0xEBAA, (q15_t)0x7E5F, (q15_t)0xEAE4, (q15_t)0x7E3F, + (q15_t)0xEA1D, (q15_t)0x7E1D, (q15_t)0xE957, (q15_t)0x7DFA, + (q15_t)0xE892, (q15_t)0x7DD6, (q15_t)0xE7CC, (q15_t)0x7DB0, + (q15_t)0xE707, (q15_t)0x7D8A, (q15_t)0xE642, (q15_t)0x7D62, + (q15_t)0xE57D, (q15_t)0x7D39, (q15_t)0xE4B8, (q15_t)0x7D0F, + (q15_t)0xE3F4, (q15_t)0x7CE3, (q15_t)0xE330, (q15_t)0x7CB7, + (q15_t)0xE26C, (q15_t)0x7C89, (q15_t)0xE1A9, (q15_t)0x7C5A, + (q15_t)0xE0E6, (q15_t)0x7C29, (q15_t)0xE023, (q15_t)0x7BF8, + (q15_t)0xDF60, (q15_t)0x7BC5, (q15_t)0xDE9E, (q15_t)0x7B92, + (q15_t)0xDDDC, (q15_t)0x7B5D, (q15_t)0xDD1A, (q15_t)0x7B26, + (q15_t)0xDC59, (q15_t)0x7AEF, (q15_t)0xDB98, (q15_t)0x7AB6, + (q15_t)0xDAD7, (q15_t)0x7A7D, (q15_t)0xDA17, (q15_t)0x7A42, + (q15_t)0xD957, (q15_t)0x7A05, (q15_t)0xD898, (q15_t)0x79C8, + (q15_t)0xD7D9, (q15_t)0x798A, (q15_t)0xD71A, (q15_t)0x794A, + (q15_t)0xD65C, (q15_t)0x7909, (q15_t)0xD59E, (q15_t)0x78C7, + (q15_t)0xD4E0, (q15_t)0x7884, (q15_t)0xD423, (q15_t)0x7840, + (q15_t)0xD367, (q15_t)0x77FA, (q15_t)0xD2AA, (q15_t)0x77B4, + (q15_t)0xD1EE, (q15_t)0x776C, (q15_t)0xD133, (q15_t)0x7723, + (q15_t)0xD078, (q15_t)0x76D9, (q15_t)0xCFBE, (q15_t)0x768E, + (q15_t)0xCF04, (q15_t)0x7641, (q15_t)0xCE4A, (q15_t)0x75F4, + (q15_t)0xCD91, (q15_t)0x75A5, (q15_t)0xCCD9, (q15_t)0x7555, + (q15_t)0xCC21, (q15_t)0x7504, (q15_t)0xCB69, (q15_t)0x74B2, + (q15_t)0xCAB2, (q15_t)0x745F, (q15_t)0xC9FB, (q15_t)0x740B, + (q15_t)0xC945, (q15_t)0x73B5, (q15_t)0xC890, (q15_t)0x735F, + (q15_t)0xC7DB, (q15_t)0x7307, (q15_t)0xC727, (q15_t)0x72AF, + (q15_t)0xC673, (q15_t)0x7255, (q15_t)0xC5BF, (q15_t)0x71FA, + (q15_t)0xC50D, (q15_t)0x719E, (q15_t)0xC45A, (q15_t)0x7141, + (q15_t)0xC3A9, (q15_t)0x70E2, (q15_t)0xC2F8, (q15_t)0x7083, + (q15_t)0xC247, (q15_t)0x7023, (q15_t)0xC197, (q15_t)0x6FC1, + (q15_t)0xC0E8, (q15_t)0x6F5F, (q15_t)0xC03A, (q15_t)0x6EFB, + (q15_t)0xBF8C, (q15_t)0x6E96, (q15_t)0xBEDE, (q15_t)0x6E30, + (q15_t)0xBE31, (q15_t)0x6DCA, (q15_t)0xBD85, (q15_t)0x6D62, + (q15_t)0xBCDA, (q15_t)0x6CF9, (q15_t)0xBC2F, (q15_t)0x6C8F, + (q15_t)0xBB85, (q15_t)0x6C24, (q15_t)0xBADB, (q15_t)0x6BB8, + (q15_t)0xBA32, (q15_t)0x6B4A, (q15_t)0xB98A, (q15_t)0x6ADC, + (q15_t)0xB8E3, (q15_t)0x6A6D, (q15_t)0xB83C, (q15_t)0x69FD, + (q15_t)0xB796, (q15_t)0x698C, (q15_t)0xB6F0, (q15_t)0x6919, + (q15_t)0xB64B, (q15_t)0x68A6, (q15_t)0xB5A7, (q15_t)0x6832, + (q15_t)0xB504, (q15_t)0x67BD, (q15_t)0xB461, (q15_t)0x6746, + (q15_t)0xB3C0, (q15_t)0x66CF, (q15_t)0xB31E, (q15_t)0x6657, + (q15_t)0xB27E, (q15_t)0x65DD, (q15_t)0xB1DE, (q15_t)0x6563, + (q15_t)0xB140, (q15_t)0x64E8, (q15_t)0xB0A1, (q15_t)0x646C, + (q15_t)0xB004, (q15_t)0x63EF, (q15_t)0xAF68, (q15_t)0x6371, + (q15_t)0xAECC, (q15_t)0x62F2, (q15_t)0xAE31, (q15_t)0x6271, + (q15_t)0xAD96, (q15_t)0x61F1, (q15_t)0xACFD, (q15_t)0x616F, + (q15_t)0xAC64, (q15_t)0x60EC, (q15_t)0xABCC, (q15_t)0x6068, + (q15_t)0xAB35, (q15_t)0x5FE3, (q15_t)0xAA9F, (q15_t)0x5F5E, + (q15_t)0xAA0A, (q15_t)0x5ED7, (q15_t)0xA975, (q15_t)0x5E50, + (q15_t)0xA8E2, (q15_t)0x5DC7, (q15_t)0xA84F, (q15_t)0x5D3E, + (q15_t)0xA7BD, (q15_t)0x5CB4, (q15_t)0xA72B, (q15_t)0x5C29, + (q15_t)0xA69B, (q15_t)0x5B9D, (q15_t)0xA60C, (q15_t)0x5B10, + (q15_t)0xA57D, (q15_t)0x5A82, (q15_t)0xA4EF, (q15_t)0x59F3, + (q15_t)0xA462, (q15_t)0x5964, (q15_t)0xA3D6, (q15_t)0x58D4, + (q15_t)0xA34B, (q15_t)0x5842, (q15_t)0xA2C1, (q15_t)0x57B0, + (q15_t)0xA238, (q15_t)0x571D, (q15_t)0xA1AF, (q15_t)0x568A, + (q15_t)0xA128, (q15_t)0x55F5, (q15_t)0xA0A1, (q15_t)0x5560, + (q15_t)0xA01C, (q15_t)0x54CA, (q15_t)0x9F97, (q15_t)0x5433, + (q15_t)0x9F13, (q15_t)0x539B, (q15_t)0x9E90, (q15_t)0x5302, + (q15_t)0x9E0E, (q15_t)0x5269, (q15_t)0x9D8E, (q15_t)0x51CE, + (q15_t)0x9D0D, (q15_t)0x5133, (q15_t)0x9C8E, (q15_t)0x5097, + (q15_t)0x9C10, (q15_t)0x4FFB, (q15_t)0x9B93, (q15_t)0x4F5E, + (q15_t)0x9B17, (q15_t)0x4EBF, (q15_t)0x9A9C, (q15_t)0x4E21, + (q15_t)0x9A22, (q15_t)0x4D81, (q15_t)0x99A8, (q15_t)0x4CE1, + (q15_t)0x9930, (q15_t)0x4C3F, (q15_t)0x98B9, (q15_t)0x4B9E, + (q15_t)0x9842, (q15_t)0x4AFB, (q15_t)0x97CD, (q15_t)0x4A58, + (q15_t)0x9759, (q15_t)0x49B4, (q15_t)0x96E6, (q15_t)0x490F, + (q15_t)0x9673, (q15_t)0x4869, (q15_t)0x9602, (q15_t)0x47C3, + (q15_t)0x9592, (q15_t)0x471C, (q15_t)0x9523, (q15_t)0x4675, + (q15_t)0x94B5, (q15_t)0x45CD, (q15_t)0x9447, (q15_t)0x4524, + (q15_t)0x93DB, (q15_t)0x447A, (q15_t)0x9370, (q15_t)0x43D0, + (q15_t)0x9306, (q15_t)0x4325, (q15_t)0x929D, (q15_t)0x427A, + (q15_t)0x9235, (q15_t)0x41CE, (q15_t)0x91CF, (q15_t)0x4121, + (q15_t)0x9169, (q15_t)0x4073, (q15_t)0x9104, (q15_t)0x3FC5, + (q15_t)0x90A0, (q15_t)0x3F17, (q15_t)0x903E, (q15_t)0x3E68, + (q15_t)0x8FDC, (q15_t)0x3DB8, (q15_t)0x8F7C, (q15_t)0x3D07, + (q15_t)0x8F1D, (q15_t)0x3C56, (q15_t)0x8EBE, (q15_t)0x3BA5, + (q15_t)0x8E61, (q15_t)0x3AF2, (q15_t)0x8E05, (q15_t)0x3A40, + (q15_t)0x8DAA, (q15_t)0x398C, (q15_t)0x8D50, (q15_t)0x38D8, + (q15_t)0x8CF8, (q15_t)0x3824, (q15_t)0x8CA0, (q15_t)0x376F, + (q15_t)0x8C4A, (q15_t)0x36BA, (q15_t)0x8BF4, (q15_t)0x3604, + (q15_t)0x8BA0, (q15_t)0x354D, (q15_t)0x8B4D, (q15_t)0x3496, + (q15_t)0x8AFB, (q15_t)0x33DE, (q15_t)0x8AAA, (q15_t)0x3326, + (q15_t)0x8A5A, (q15_t)0x326E, (q15_t)0x8A0B, (q15_t)0x31B5, + (q15_t)0x89BE, (q15_t)0x30FB, (q15_t)0x8971, (q15_t)0x3041, + (q15_t)0x8926, (q15_t)0x2F87, (q15_t)0x88DC, (q15_t)0x2ECC, + (q15_t)0x8893, (q15_t)0x2E11, (q15_t)0x884B, (q15_t)0x2D55, + (q15_t)0x8805, (q15_t)0x2C98, (q15_t)0x87BF, (q15_t)0x2BDC, + (q15_t)0x877B, (q15_t)0x2B1F, (q15_t)0x8738, (q15_t)0x2A61, + (q15_t)0x86F6, (q15_t)0x29A3, (q15_t)0x86B5, (q15_t)0x28E5, + (q15_t)0x8675, (q15_t)0x2826, (q15_t)0x8637, (q15_t)0x2767, + (q15_t)0x85FA, (q15_t)0x26A8, (q15_t)0x85BD, (q15_t)0x25E8, + (q15_t)0x8582, (q15_t)0x2528, (q15_t)0x8549, (q15_t)0x2467, + (q15_t)0x8510, (q15_t)0x23A6, (q15_t)0x84D9, (q15_t)0x22E5, + (q15_t)0x84A2, (q15_t)0x2223, (q15_t)0x846D, (q15_t)0x2161, + (q15_t)0x843A, (q15_t)0x209F, (q15_t)0x8407, (q15_t)0x1FDC, + (q15_t)0x83D6, (q15_t)0x1F19, (q15_t)0x83A5, (q15_t)0x1E56, + (q15_t)0x8376, (q15_t)0x1D93, (q15_t)0x8348, (q15_t)0x1CCF, + (q15_t)0x831C, (q15_t)0x1C0B, (q15_t)0x82F0, (q15_t)0x1B47, + (q15_t)0x82C6, (q15_t)0x1A82, (q15_t)0x829D, (q15_t)0x19BD, + (q15_t)0x8275, (q15_t)0x18F8, (q15_t)0x824F, (q15_t)0x1833, + (q15_t)0x8229, (q15_t)0x176D, (q15_t)0x8205, (q15_t)0x16A8, + (q15_t)0x81E2, (q15_t)0x15E2, (q15_t)0x81C0, (q15_t)0x151B, + (q15_t)0x81A0, (q15_t)0x1455, (q15_t)0x8180, (q15_t)0x138E, + (q15_t)0x8162, (q15_t)0x12C8, (q15_t)0x8145, (q15_t)0x1201, + (q15_t)0x812A, (q15_t)0x1139, (q15_t)0x810F, (q15_t)0x1072, + (q15_t)0x80F6, (q15_t)0x0FAB, (q15_t)0x80DE, (q15_t)0x0EE3, + (q15_t)0x80C7, (q15_t)0x0E1B, (q15_t)0x80B2, (q15_t)0x0D53, + (q15_t)0x809D, (q15_t)0x0C8B, (q15_t)0x808A, (q15_t)0x0BC3, + (q15_t)0x8078, (q15_t)0x0AFB, (q15_t)0x8068, (q15_t)0x0A33, + (q15_t)0x8058, (q15_t)0x096A, (q15_t)0x804A, (q15_t)0x08A2, + (q15_t)0x803D, (q15_t)0x07D9, (q15_t)0x8031, (q15_t)0x0710, + (q15_t)0x8027, (q15_t)0x0647, (q15_t)0x801E, (q15_t)0x057F, + (q15_t)0x8016, (q15_t)0x04B6, (q15_t)0x800F, (q15_t)0x03ED, + (q15_t)0x8009, (q15_t)0x0324, (q15_t)0x8005, (q15_t)0x025B, + (q15_t)0x8002, (q15_t)0x0192, (q15_t)0x8000, (q15_t)0x00C9, + (q15_t)0x8000, (q15_t)0x0000, (q15_t)0x8000, (q15_t)0xFF36, + (q15_t)0x8002, (q15_t)0xFE6D, (q15_t)0x8005, (q15_t)0xFDA4, + (q15_t)0x8009, (q15_t)0xFCDB, (q15_t)0x800F, (q15_t)0xFC12, + (q15_t)0x8016, (q15_t)0xFB49, (q15_t)0x801E, (q15_t)0xFA80, + (q15_t)0x8027, (q15_t)0xF9B8, (q15_t)0x8031, (q15_t)0xF8EF, + (q15_t)0x803D, (q15_t)0xF826, (q15_t)0x804A, (q15_t)0xF75D, + (q15_t)0x8058, (q15_t)0xF695, (q15_t)0x8068, (q15_t)0xF5CC, + (q15_t)0x8078, (q15_t)0xF504, (q15_t)0x808A, (q15_t)0xF43C, + (q15_t)0x809D, (q15_t)0xF374, (q15_t)0x80B2, (q15_t)0xF2AC, + (q15_t)0x80C7, (q15_t)0xF1E4, (q15_t)0x80DE, (q15_t)0xF11C, + (q15_t)0x80F6, (q15_t)0xF054, (q15_t)0x810F, (q15_t)0xEF8D, + (q15_t)0x812A, (q15_t)0xEEC6, (q15_t)0x8145, (q15_t)0xEDFE, + (q15_t)0x8162, (q15_t)0xED37, (q15_t)0x8180, (q15_t)0xEC71, + (q15_t)0x81A0, (q15_t)0xEBAA, (q15_t)0x81C0, (q15_t)0xEAE4, + (q15_t)0x81E2, (q15_t)0xEA1D, (q15_t)0x8205, (q15_t)0xE957, + (q15_t)0x8229, (q15_t)0xE892, (q15_t)0x824F, (q15_t)0xE7CC, + (q15_t)0x8275, (q15_t)0xE707, (q15_t)0x829D, (q15_t)0xE642, + (q15_t)0x82C6, (q15_t)0xE57D, (q15_t)0x82F0, (q15_t)0xE4B8, + (q15_t)0x831C, (q15_t)0xE3F4, (q15_t)0x8348, (q15_t)0xE330, + (q15_t)0x8376, (q15_t)0xE26C, (q15_t)0x83A5, (q15_t)0xE1A9, + (q15_t)0x83D6, (q15_t)0xE0E6, (q15_t)0x8407, (q15_t)0xE023, + (q15_t)0x843A, (q15_t)0xDF60, (q15_t)0x846D, (q15_t)0xDE9E, + (q15_t)0x84A2, (q15_t)0xDDDC, (q15_t)0x84D9, (q15_t)0xDD1A, + (q15_t)0x8510, (q15_t)0xDC59, (q15_t)0x8549, (q15_t)0xDB98, + (q15_t)0x8582, (q15_t)0xDAD7, (q15_t)0x85BD, (q15_t)0xDA17, + (q15_t)0x85FA, (q15_t)0xD957, (q15_t)0x8637, (q15_t)0xD898, + (q15_t)0x8675, (q15_t)0xD7D9, (q15_t)0x86B5, (q15_t)0xD71A, + (q15_t)0x86F6, (q15_t)0xD65C, (q15_t)0x8738, (q15_t)0xD59E, + (q15_t)0x877B, (q15_t)0xD4E0, (q15_t)0x87BF, (q15_t)0xD423, + (q15_t)0x8805, (q15_t)0xD367, (q15_t)0x884B, (q15_t)0xD2AA, + (q15_t)0x8893, (q15_t)0xD1EE, (q15_t)0x88DC, (q15_t)0xD133, + (q15_t)0x8926, (q15_t)0xD078, (q15_t)0x8971, (q15_t)0xCFBE, + (q15_t)0x89BE, (q15_t)0xCF04, (q15_t)0x8A0B, (q15_t)0xCE4A, + (q15_t)0x8A5A, (q15_t)0xCD91, (q15_t)0x8AAA, (q15_t)0xCCD9, + (q15_t)0x8AFB, (q15_t)0xCC21, (q15_t)0x8B4D, (q15_t)0xCB69, + (q15_t)0x8BA0, (q15_t)0xCAB2, (q15_t)0x8BF4, (q15_t)0xC9FB, + (q15_t)0x8C4A, (q15_t)0xC945, (q15_t)0x8CA0, (q15_t)0xC890, + (q15_t)0x8CF8, (q15_t)0xC7DB, (q15_t)0x8D50, (q15_t)0xC727, + (q15_t)0x8DAA, (q15_t)0xC673, (q15_t)0x8E05, (q15_t)0xC5BF, + (q15_t)0x8E61, (q15_t)0xC50D, (q15_t)0x8EBE, (q15_t)0xC45A, + (q15_t)0x8F1D, (q15_t)0xC3A9, (q15_t)0x8F7C, (q15_t)0xC2F8, + (q15_t)0x8FDC, (q15_t)0xC247, (q15_t)0x903E, (q15_t)0xC197, + (q15_t)0x90A0, (q15_t)0xC0E8, (q15_t)0x9104, (q15_t)0xC03A, + (q15_t)0x9169, (q15_t)0xBF8C, (q15_t)0x91CF, (q15_t)0xBEDE, + (q15_t)0x9235, (q15_t)0xBE31, (q15_t)0x929D, (q15_t)0xBD85, + (q15_t)0x9306, (q15_t)0xBCDA, (q15_t)0x9370, (q15_t)0xBC2F, + (q15_t)0x93DB, (q15_t)0xBB85, (q15_t)0x9447, (q15_t)0xBADB, + (q15_t)0x94B5, (q15_t)0xBA32, (q15_t)0x9523, (q15_t)0xB98A, + (q15_t)0x9592, (q15_t)0xB8E3, (q15_t)0x9602, (q15_t)0xB83C, + (q15_t)0x9673, (q15_t)0xB796, (q15_t)0x96E6, (q15_t)0xB6F0, + (q15_t)0x9759, (q15_t)0xB64B, (q15_t)0x97CD, (q15_t)0xB5A7, + (q15_t)0x9842, (q15_t)0xB504, (q15_t)0x98B9, (q15_t)0xB461, + (q15_t)0x9930, (q15_t)0xB3C0, (q15_t)0x99A8, (q15_t)0xB31E, + (q15_t)0x9A22, (q15_t)0xB27E, (q15_t)0x9A9C, (q15_t)0xB1DE, + (q15_t)0x9B17, (q15_t)0xB140, (q15_t)0x9B93, (q15_t)0xB0A1, + (q15_t)0x9C10, (q15_t)0xB004, (q15_t)0x9C8E, (q15_t)0xAF68, + (q15_t)0x9D0D, (q15_t)0xAECC, (q15_t)0x9D8E, (q15_t)0xAE31, + (q15_t)0x9E0E, (q15_t)0xAD96, (q15_t)0x9E90, (q15_t)0xACFD, + (q15_t)0x9F13, (q15_t)0xAC64, (q15_t)0x9F97, (q15_t)0xABCC, + (q15_t)0xA01C, (q15_t)0xAB35, (q15_t)0xA0A1, (q15_t)0xAA9F, + (q15_t)0xA128, (q15_t)0xAA0A, (q15_t)0xA1AF, (q15_t)0xA975, + (q15_t)0xA238, (q15_t)0xA8E2, (q15_t)0xA2C1, (q15_t)0xA84F, + (q15_t)0xA34B, (q15_t)0xA7BD, (q15_t)0xA3D6, (q15_t)0xA72B, + (q15_t)0xA462, (q15_t)0xA69B, (q15_t)0xA4EF, (q15_t)0xA60C, + (q15_t)0xA57D, (q15_t)0xA57D, (q15_t)0xA60C, (q15_t)0xA4EF, + (q15_t)0xA69B, (q15_t)0xA462, (q15_t)0xA72B, (q15_t)0xA3D6, + (q15_t)0xA7BD, (q15_t)0xA34B, (q15_t)0xA84F, (q15_t)0xA2C1, + (q15_t)0xA8E2, (q15_t)0xA238, (q15_t)0xA975, (q15_t)0xA1AF, + (q15_t)0xAA0A, (q15_t)0xA128, (q15_t)0xAA9F, (q15_t)0xA0A1, + (q15_t)0xAB35, (q15_t)0xA01C, (q15_t)0xABCC, (q15_t)0x9F97, + (q15_t)0xAC64, (q15_t)0x9F13, (q15_t)0xACFD, (q15_t)0x9E90, + (q15_t)0xAD96, (q15_t)0x9E0E, (q15_t)0xAE31, (q15_t)0x9D8E, + (q15_t)0xAECC, (q15_t)0x9D0D, (q15_t)0xAF68, (q15_t)0x9C8E, + (q15_t)0xB004, (q15_t)0x9C10, (q15_t)0xB0A1, (q15_t)0x9B93, + (q15_t)0xB140, (q15_t)0x9B17, (q15_t)0xB1DE, (q15_t)0x9A9C, + (q15_t)0xB27E, (q15_t)0x9A22, (q15_t)0xB31E, (q15_t)0x99A8, + (q15_t)0xB3C0, (q15_t)0x9930, (q15_t)0xB461, (q15_t)0x98B9, + (q15_t)0xB504, (q15_t)0x9842, (q15_t)0xB5A7, (q15_t)0x97CD, + (q15_t)0xB64B, (q15_t)0x9759, (q15_t)0xB6F0, (q15_t)0x96E6, + (q15_t)0xB796, (q15_t)0x9673, (q15_t)0xB83C, (q15_t)0x9602, + (q15_t)0xB8E3, (q15_t)0x9592, (q15_t)0xB98A, (q15_t)0x9523, + (q15_t)0xBA32, (q15_t)0x94B5, (q15_t)0xBADB, (q15_t)0x9447, + (q15_t)0xBB85, (q15_t)0x93DB, (q15_t)0xBC2F, (q15_t)0x9370, + (q15_t)0xBCDA, (q15_t)0x9306, (q15_t)0xBD85, (q15_t)0x929D, + (q15_t)0xBE31, (q15_t)0x9235, (q15_t)0xBEDE, (q15_t)0x91CF, + (q15_t)0xBF8C, (q15_t)0x9169, (q15_t)0xC03A, (q15_t)0x9104, + (q15_t)0xC0E8, (q15_t)0x90A0, (q15_t)0xC197, (q15_t)0x903E, + (q15_t)0xC247, (q15_t)0x8FDC, (q15_t)0xC2F8, (q15_t)0x8F7C, + (q15_t)0xC3A9, (q15_t)0x8F1D, (q15_t)0xC45A, (q15_t)0x8EBE, + (q15_t)0xC50D, (q15_t)0x8E61, (q15_t)0xC5BF, (q15_t)0x8E05, + (q15_t)0xC673, (q15_t)0x8DAA, (q15_t)0xC727, (q15_t)0x8D50, + (q15_t)0xC7DB, (q15_t)0x8CF8, (q15_t)0xC890, (q15_t)0x8CA0, + (q15_t)0xC945, (q15_t)0x8C4A, (q15_t)0xC9FB, (q15_t)0x8BF4, + (q15_t)0xCAB2, (q15_t)0x8BA0, (q15_t)0xCB69, (q15_t)0x8B4D, + (q15_t)0xCC21, (q15_t)0x8AFB, (q15_t)0xCCD9, (q15_t)0x8AAA, + (q15_t)0xCD91, (q15_t)0x8A5A, (q15_t)0xCE4A, (q15_t)0x8A0B, + (q15_t)0xCF04, (q15_t)0x89BE, (q15_t)0xCFBE, (q15_t)0x8971, + (q15_t)0xD078, (q15_t)0x8926, (q15_t)0xD133, (q15_t)0x88DC, + (q15_t)0xD1EE, (q15_t)0x8893, (q15_t)0xD2AA, (q15_t)0x884B, + (q15_t)0xD367, (q15_t)0x8805, (q15_t)0xD423, (q15_t)0x87BF, + (q15_t)0xD4E0, (q15_t)0x877B, (q15_t)0xD59E, (q15_t)0x8738, + (q15_t)0xD65C, (q15_t)0x86F6, (q15_t)0xD71A, (q15_t)0x86B5, + (q15_t)0xD7D9, (q15_t)0x8675, (q15_t)0xD898, (q15_t)0x8637, + (q15_t)0xD957, (q15_t)0x85FA, (q15_t)0xDA17, (q15_t)0x85BD, + (q15_t)0xDAD7, (q15_t)0x8582, (q15_t)0xDB98, (q15_t)0x8549, + (q15_t)0xDC59, (q15_t)0x8510, (q15_t)0xDD1A, (q15_t)0x84D9, + (q15_t)0xDDDC, (q15_t)0x84A2, (q15_t)0xDE9E, (q15_t)0x846D, + (q15_t)0xDF60, (q15_t)0x843A, (q15_t)0xE023, (q15_t)0x8407, + (q15_t)0xE0E6, (q15_t)0x83D6, (q15_t)0xE1A9, (q15_t)0x83A5, + (q15_t)0xE26C, (q15_t)0x8376, (q15_t)0xE330, (q15_t)0x8348, + (q15_t)0xE3F4, (q15_t)0x831C, (q15_t)0xE4B8, (q15_t)0x82F0, + (q15_t)0xE57D, (q15_t)0x82C6, (q15_t)0xE642, (q15_t)0x829D, + (q15_t)0xE707, (q15_t)0x8275, (q15_t)0xE7CC, (q15_t)0x824F, + (q15_t)0xE892, (q15_t)0x8229, (q15_t)0xE957, (q15_t)0x8205, + (q15_t)0xEA1D, (q15_t)0x81E2, (q15_t)0xEAE4, (q15_t)0x81C0, + (q15_t)0xEBAA, (q15_t)0x81A0, (q15_t)0xEC71, (q15_t)0x8180, + (q15_t)0xED37, (q15_t)0x8162, (q15_t)0xEDFE, (q15_t)0x8145, + (q15_t)0xEEC6, (q15_t)0x812A, (q15_t)0xEF8D, (q15_t)0x810F, + (q15_t)0xF054, (q15_t)0x80F6, (q15_t)0xF11C, (q15_t)0x80DE, + (q15_t)0xF1E4, (q15_t)0x80C7, (q15_t)0xF2AC, (q15_t)0x80B2, + (q15_t)0xF374, (q15_t)0x809D, (q15_t)0xF43C, (q15_t)0x808A, + (q15_t)0xF504, (q15_t)0x8078, (q15_t)0xF5CC, (q15_t)0x8068, + (q15_t)0xF695, (q15_t)0x8058, (q15_t)0xF75D, (q15_t)0x804A, + (q15_t)0xF826, (q15_t)0x803D, (q15_t)0xF8EF, (q15_t)0x8031, + (q15_t)0xF9B8, (q15_t)0x8027, (q15_t)0xFA80, (q15_t)0x801E, + (q15_t)0xFB49, (q15_t)0x8016, (q15_t)0xFC12, (q15_t)0x800F, + (q15_t)0xFCDB, (q15_t)0x8009, (q15_t)0xFDA4, (q15_t)0x8005, + (q15_t)0xFE6D, (q15_t)0x8002, (q15_t)0xFF36, (q15_t)0x8000 +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 2048 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_2048_q15[3072] = { + (q15_t)0x7FFF, (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0x0064, + (q15_t)0x7FFF, (q15_t)0x00C9, (q15_t)0x7FFE, (q15_t)0x012D, + (q15_t)0x7FFD, (q15_t)0x0192, (q15_t)0x7FFC, (q15_t)0x01F6, + (q15_t)0x7FFA, (q15_t)0x025B, (q15_t)0x7FF8, (q15_t)0x02BF, + (q15_t)0x7FF6, (q15_t)0x0324, (q15_t)0x7FF3, (q15_t)0x0388, + (q15_t)0x7FF0, (q15_t)0x03ED, (q15_t)0x7FED, (q15_t)0x0451, + (q15_t)0x7FE9, (q15_t)0x04B6, (q15_t)0x7FE5, (q15_t)0x051A, + (q15_t)0x7FE1, (q15_t)0x057F, (q15_t)0x7FDD, (q15_t)0x05E3, + (q15_t)0x7FD8, (q15_t)0x0647, (q15_t)0x7FD3, (q15_t)0x06AC, + (q15_t)0x7FCE, (q15_t)0x0710, (q15_t)0x7FC8, (q15_t)0x0775, + (q15_t)0x7FC2, (q15_t)0x07D9, (q15_t)0x7FBC, (q15_t)0x083D, + (q15_t)0x7FB5, (q15_t)0x08A2, (q15_t)0x7FAE, (q15_t)0x0906, + (q15_t)0x7FA7, (q15_t)0x096A, (q15_t)0x7F9F, (q15_t)0x09CE, + (q15_t)0x7F97, (q15_t)0x0A33, (q15_t)0x7F8F, (q15_t)0x0A97, + (q15_t)0x7F87, (q15_t)0x0AFB, (q15_t)0x7F7E, (q15_t)0x0B5F, + (q15_t)0x7F75, (q15_t)0x0BC3, (q15_t)0x7F6B, (q15_t)0x0C27, + (q15_t)0x7F62, (q15_t)0x0C8B, (q15_t)0x7F58, (q15_t)0x0CEF, + (q15_t)0x7F4D, (q15_t)0x0D53, (q15_t)0x7F43, (q15_t)0x0DB7, + (q15_t)0x7F38, (q15_t)0x0E1B, (q15_t)0x7F2D, (q15_t)0x0E7F, + (q15_t)0x7F21, (q15_t)0x0EE3, (q15_t)0x7F15, (q15_t)0x0F47, + (q15_t)0x7F09, (q15_t)0x0FAB, (q15_t)0x7EFD, (q15_t)0x100E, + (q15_t)0x7EF0, (q15_t)0x1072, (q15_t)0x7EE3, (q15_t)0x10D6, + (q15_t)0x7ED5, (q15_t)0x1139, (q15_t)0x7EC8, (q15_t)0x119D, + (q15_t)0x7EBA, (q15_t)0x1201, (q15_t)0x7EAB, (q15_t)0x1264, + (q15_t)0x7E9D, (q15_t)0x12C8, (q15_t)0x7E8E, (q15_t)0x132B, + (q15_t)0x7E7F, (q15_t)0x138E, (q15_t)0x7E6F, (q15_t)0x13F2, + (q15_t)0x7E5F, (q15_t)0x1455, (q15_t)0x7E4F, (q15_t)0x14B8, + (q15_t)0x7E3F, (q15_t)0x151B, (q15_t)0x7E2E, (q15_t)0x157F, + (q15_t)0x7E1D, (q15_t)0x15E2, (q15_t)0x7E0C, (q15_t)0x1645, + (q15_t)0x7DFA, (q15_t)0x16A8, (q15_t)0x7DE8, (q15_t)0x170A, + (q15_t)0x7DD6, (q15_t)0x176D, (q15_t)0x7DC3, (q15_t)0x17D0, + (q15_t)0x7DB0, (q15_t)0x1833, (q15_t)0x7D9D, (q15_t)0x1896, + (q15_t)0x7D8A, (q15_t)0x18F8, (q15_t)0x7D76, (q15_t)0x195B, + (q15_t)0x7D62, (q15_t)0x19BD, (q15_t)0x7D4E, (q15_t)0x1A20, + (q15_t)0x7D39, (q15_t)0x1A82, (q15_t)0x7D24, (q15_t)0x1AE4, + (q15_t)0x7D0F, (q15_t)0x1B47, (q15_t)0x7CF9, (q15_t)0x1BA9, + (q15_t)0x7CE3, (q15_t)0x1C0B, (q15_t)0x7CCD, (q15_t)0x1C6D, + (q15_t)0x7CB7, (q15_t)0x1CCF, (q15_t)0x7CA0, (q15_t)0x1D31, + (q15_t)0x7C89, (q15_t)0x1D93, (q15_t)0x7C71, (q15_t)0x1DF5, + (q15_t)0x7C5A, (q15_t)0x1E56, (q15_t)0x7C42, (q15_t)0x1EB8, + (q15_t)0x7C29, (q15_t)0x1F19, (q15_t)0x7C11, (q15_t)0x1F7B, + (q15_t)0x7BF8, (q15_t)0x1FDC, (q15_t)0x7BDF, (q15_t)0x203E, + (q15_t)0x7BC5, (q15_t)0x209F, (q15_t)0x7BAC, (q15_t)0x2100, + (q15_t)0x7B92, (q15_t)0x2161, (q15_t)0x7B77, (q15_t)0x21C2, + (q15_t)0x7B5D, (q15_t)0x2223, (q15_t)0x7B42, (q15_t)0x2284, + (q15_t)0x7B26, (q15_t)0x22E5, (q15_t)0x7B0B, (q15_t)0x2345, + (q15_t)0x7AEF, (q15_t)0x23A6, (q15_t)0x7AD3, (q15_t)0x2407, + (q15_t)0x7AB6, (q15_t)0x2467, (q15_t)0x7A9A, (q15_t)0x24C7, + (q15_t)0x7A7D, (q15_t)0x2528, (q15_t)0x7A5F, (q15_t)0x2588, + (q15_t)0x7A42, (q15_t)0x25E8, (q15_t)0x7A24, (q15_t)0x2648, + (q15_t)0x7A05, (q15_t)0x26A8, (q15_t)0x79E7, (q15_t)0x2707, + (q15_t)0x79C8, (q15_t)0x2767, (q15_t)0x79A9, (q15_t)0x27C7, + (q15_t)0x798A, (q15_t)0x2826, (q15_t)0x796A, (q15_t)0x2886, + (q15_t)0x794A, (q15_t)0x28E5, (q15_t)0x792A, (q15_t)0x2944, + (q15_t)0x7909, (q15_t)0x29A3, (q15_t)0x78E8, (q15_t)0x2A02, + (q15_t)0x78C7, (q15_t)0x2A61, (q15_t)0x78A6, (q15_t)0x2AC0, + (q15_t)0x7884, (q15_t)0x2B1F, (q15_t)0x7862, (q15_t)0x2B7D, + (q15_t)0x7840, (q15_t)0x2BDC, (q15_t)0x781D, (q15_t)0x2C3A, + (q15_t)0x77FA, (q15_t)0x2C98, (q15_t)0x77D7, (q15_t)0x2CF7, + (q15_t)0x77B4, (q15_t)0x2D55, (q15_t)0x7790, (q15_t)0x2DB3, + (q15_t)0x776C, (q15_t)0x2E11, (q15_t)0x7747, (q15_t)0x2E6E, + (q15_t)0x7723, (q15_t)0x2ECC, (q15_t)0x76FE, (q15_t)0x2F29, + (q15_t)0x76D9, (q15_t)0x2F87, (q15_t)0x76B3, (q15_t)0x2FE4, + (q15_t)0x768E, (q15_t)0x3041, (q15_t)0x7668, (q15_t)0x309E, + (q15_t)0x7641, (q15_t)0x30FB, (q15_t)0x761B, (q15_t)0x3158, + (q15_t)0x75F4, (q15_t)0x31B5, (q15_t)0x75CC, (q15_t)0x3211, + (q15_t)0x75A5, (q15_t)0x326E, (q15_t)0x757D, (q15_t)0x32CA, + (q15_t)0x7555, (q15_t)0x3326, (q15_t)0x752D, (q15_t)0x3382, + (q15_t)0x7504, (q15_t)0x33DE, (q15_t)0x74DB, (q15_t)0x343A, + (q15_t)0x74B2, (q15_t)0x3496, (q15_t)0x7489, (q15_t)0x34F2, + (q15_t)0x745F, (q15_t)0x354D, (q15_t)0x7435, (q15_t)0x35A8, + (q15_t)0x740B, (q15_t)0x3604, (q15_t)0x73E0, (q15_t)0x365F, + (q15_t)0x73B5, (q15_t)0x36BA, (q15_t)0x738A, (q15_t)0x3714, + (q15_t)0x735F, (q15_t)0x376F, (q15_t)0x7333, (q15_t)0x37CA, + (q15_t)0x7307, (q15_t)0x3824, (q15_t)0x72DB, (q15_t)0x387E, + (q15_t)0x72AF, (q15_t)0x38D8, (q15_t)0x7282, (q15_t)0x3932, + (q15_t)0x7255, (q15_t)0x398C, (q15_t)0x7227, (q15_t)0x39E6, + (q15_t)0x71FA, (q15_t)0x3A40, (q15_t)0x71CC, (q15_t)0x3A99, + (q15_t)0x719E, (q15_t)0x3AF2, (q15_t)0x716F, (q15_t)0x3B4C, + (q15_t)0x7141, (q15_t)0x3BA5, (q15_t)0x7112, (q15_t)0x3BFD, + (q15_t)0x70E2, (q15_t)0x3C56, (q15_t)0x70B3, (q15_t)0x3CAF, + (q15_t)0x7083, (q15_t)0x3D07, (q15_t)0x7053, (q15_t)0x3D60, + (q15_t)0x7023, (q15_t)0x3DB8, (q15_t)0x6FF2, (q15_t)0x3E10, + (q15_t)0x6FC1, (q15_t)0x3E68, (q15_t)0x6F90, (q15_t)0x3EBF, + (q15_t)0x6F5F, (q15_t)0x3F17, (q15_t)0x6F2D, (q15_t)0x3F6E, + (q15_t)0x6EFB, (q15_t)0x3FC5, (q15_t)0x6EC9, (q15_t)0x401D, + (q15_t)0x6E96, (q15_t)0x4073, (q15_t)0x6E63, (q15_t)0x40CA, + (q15_t)0x6E30, (q15_t)0x4121, (q15_t)0x6DFD, (q15_t)0x4177, + (q15_t)0x6DCA, (q15_t)0x41CE, (q15_t)0x6D96, (q15_t)0x4224, + (q15_t)0x6D62, (q15_t)0x427A, (q15_t)0x6D2D, (q15_t)0x42D0, + (q15_t)0x6CF9, (q15_t)0x4325, (q15_t)0x6CC4, (q15_t)0x437B, + (q15_t)0x6C8F, (q15_t)0x43D0, (q15_t)0x6C59, (q15_t)0x4425, + (q15_t)0x6C24, (q15_t)0x447A, (q15_t)0x6BEE, (q15_t)0x44CF, + (q15_t)0x6BB8, (q15_t)0x4524, (q15_t)0x6B81, (q15_t)0x4578, + (q15_t)0x6B4A, (q15_t)0x45CD, (q15_t)0x6B13, (q15_t)0x4621, + (q15_t)0x6ADC, (q15_t)0x4675, (q15_t)0x6AA5, (q15_t)0x46C9, + (q15_t)0x6A6D, (q15_t)0x471C, (q15_t)0x6A35, (q15_t)0x4770, + (q15_t)0x69FD, (q15_t)0x47C3, (q15_t)0x69C4, (q15_t)0x4816, + (q15_t)0x698C, (q15_t)0x4869, (q15_t)0x6953, (q15_t)0x48BC, + (q15_t)0x6919, (q15_t)0x490F, (q15_t)0x68E0, (q15_t)0x4961, + (q15_t)0x68A6, (q15_t)0x49B4, (q15_t)0x686C, (q15_t)0x4A06, + (q15_t)0x6832, (q15_t)0x4A58, (q15_t)0x67F7, (q15_t)0x4AA9, + (q15_t)0x67BD, (q15_t)0x4AFB, (q15_t)0x6782, (q15_t)0x4B4C, + (q15_t)0x6746, (q15_t)0x4B9E, (q15_t)0x670B, (q15_t)0x4BEF, + (q15_t)0x66CF, (q15_t)0x4C3F, (q15_t)0x6693, (q15_t)0x4C90, + (q15_t)0x6657, (q15_t)0x4CE1, (q15_t)0x661A, (q15_t)0x4D31, + (q15_t)0x65DD, (q15_t)0x4D81, (q15_t)0x65A0, (q15_t)0x4DD1, + (q15_t)0x6563, (q15_t)0x4E21, (q15_t)0x6526, (q15_t)0x4E70, + (q15_t)0x64E8, (q15_t)0x4EBF, (q15_t)0x64AA, (q15_t)0x4F0F, + (q15_t)0x646C, (q15_t)0x4F5E, (q15_t)0x642D, (q15_t)0x4FAC, + (q15_t)0x63EF, (q15_t)0x4FFB, (q15_t)0x63B0, (q15_t)0x5049, + (q15_t)0x6371, (q15_t)0x5097, (q15_t)0x6331, (q15_t)0x50E5, + (q15_t)0x62F2, (q15_t)0x5133, (q15_t)0x62B2, (q15_t)0x5181, + (q15_t)0x6271, (q15_t)0x51CE, (q15_t)0x6231, (q15_t)0x521C, + (q15_t)0x61F1, (q15_t)0x5269, (q15_t)0x61B0, (q15_t)0x52B5, + (q15_t)0x616F, (q15_t)0x5302, (q15_t)0x612D, (q15_t)0x534E, + (q15_t)0x60EC, (q15_t)0x539B, (q15_t)0x60AA, (q15_t)0x53E7, + (q15_t)0x6068, (q15_t)0x5433, (q15_t)0x6026, (q15_t)0x547E, + (q15_t)0x5FE3, (q15_t)0x54CA, (q15_t)0x5FA0, (q15_t)0x5515, + (q15_t)0x5F5E, (q15_t)0x5560, (q15_t)0x5F1A, (q15_t)0x55AB, + (q15_t)0x5ED7, (q15_t)0x55F5, (q15_t)0x5E93, (q15_t)0x5640, + (q15_t)0x5E50, (q15_t)0x568A, (q15_t)0x5E0B, (q15_t)0x56D4, + (q15_t)0x5DC7, (q15_t)0x571D, (q15_t)0x5D83, (q15_t)0x5767, + (q15_t)0x5D3E, (q15_t)0x57B0, (q15_t)0x5CF9, (q15_t)0x57F9, + (q15_t)0x5CB4, (q15_t)0x5842, (q15_t)0x5C6E, (q15_t)0x588B, + (q15_t)0x5C29, (q15_t)0x58D4, (q15_t)0x5BE3, (q15_t)0x591C, + (q15_t)0x5B9D, (q15_t)0x5964, (q15_t)0x5B56, (q15_t)0x59AC, + (q15_t)0x5B10, (q15_t)0x59F3, (q15_t)0x5AC9, (q15_t)0x5A3B, + (q15_t)0x5A82, (q15_t)0x5A82, (q15_t)0x5A3B, (q15_t)0x5AC9, + (q15_t)0x59F3, (q15_t)0x5B10, (q15_t)0x59AC, (q15_t)0x5B56, + (q15_t)0x5964, (q15_t)0x5B9D, (q15_t)0x591C, (q15_t)0x5BE3, + (q15_t)0x58D4, (q15_t)0x5C29, (q15_t)0x588B, (q15_t)0x5C6E, + (q15_t)0x5842, (q15_t)0x5CB4, (q15_t)0x57F9, (q15_t)0x5CF9, + (q15_t)0x57B0, (q15_t)0x5D3E, (q15_t)0x5767, (q15_t)0x5D83, + (q15_t)0x571D, (q15_t)0x5DC7, (q15_t)0x56D4, (q15_t)0x5E0B, + (q15_t)0x568A, (q15_t)0x5E50, (q15_t)0x5640, (q15_t)0x5E93, + (q15_t)0x55F5, (q15_t)0x5ED7, (q15_t)0x55AB, (q15_t)0x5F1A, + (q15_t)0x5560, (q15_t)0x5F5E, (q15_t)0x5515, (q15_t)0x5FA0, + (q15_t)0x54CA, (q15_t)0x5FE3, (q15_t)0x547E, (q15_t)0x6026, + (q15_t)0x5433, (q15_t)0x6068, (q15_t)0x53E7, (q15_t)0x60AA, + (q15_t)0x539B, (q15_t)0x60EC, (q15_t)0x534E, (q15_t)0x612D, + (q15_t)0x5302, (q15_t)0x616F, (q15_t)0x52B5, (q15_t)0x61B0, + (q15_t)0x5269, (q15_t)0x61F1, (q15_t)0x521C, (q15_t)0x6231, + (q15_t)0x51CE, (q15_t)0x6271, (q15_t)0x5181, (q15_t)0x62B2, + (q15_t)0x5133, (q15_t)0x62F2, (q15_t)0x50E5, (q15_t)0x6331, + (q15_t)0x5097, (q15_t)0x6371, (q15_t)0x5049, (q15_t)0x63B0, + (q15_t)0x4FFB, (q15_t)0x63EF, (q15_t)0x4FAC, (q15_t)0x642D, + (q15_t)0x4F5E, (q15_t)0x646C, (q15_t)0x4F0F, (q15_t)0x64AA, + (q15_t)0x4EBF, (q15_t)0x64E8, (q15_t)0x4E70, (q15_t)0x6526, + (q15_t)0x4E21, (q15_t)0x6563, (q15_t)0x4DD1, (q15_t)0x65A0, + (q15_t)0x4D81, (q15_t)0x65DD, (q15_t)0x4D31, (q15_t)0x661A, + (q15_t)0x4CE1, (q15_t)0x6657, (q15_t)0x4C90, (q15_t)0x6693, + (q15_t)0x4C3F, (q15_t)0x66CF, (q15_t)0x4BEF, (q15_t)0x670B, + (q15_t)0x4B9E, (q15_t)0x6746, (q15_t)0x4B4C, (q15_t)0x6782, + (q15_t)0x4AFB, (q15_t)0x67BD, (q15_t)0x4AA9, (q15_t)0x67F7, + (q15_t)0x4A58, (q15_t)0x6832, (q15_t)0x4A06, (q15_t)0x686C, + (q15_t)0x49B4, (q15_t)0x68A6, (q15_t)0x4961, (q15_t)0x68E0, + (q15_t)0x490F, (q15_t)0x6919, (q15_t)0x48BC, (q15_t)0x6953, + (q15_t)0x4869, (q15_t)0x698C, (q15_t)0x4816, (q15_t)0x69C4, + (q15_t)0x47C3, (q15_t)0x69FD, (q15_t)0x4770, (q15_t)0x6A35, + (q15_t)0x471C, (q15_t)0x6A6D, (q15_t)0x46C9, (q15_t)0x6AA5, + (q15_t)0x4675, (q15_t)0x6ADC, (q15_t)0x4621, (q15_t)0x6B13, + (q15_t)0x45CD, (q15_t)0x6B4A, (q15_t)0x4578, (q15_t)0x6B81, + (q15_t)0x4524, (q15_t)0x6BB8, (q15_t)0x44CF, (q15_t)0x6BEE, + (q15_t)0x447A, (q15_t)0x6C24, (q15_t)0x4425, (q15_t)0x6C59, + (q15_t)0x43D0, (q15_t)0x6C8F, (q15_t)0x437B, (q15_t)0x6CC4, + (q15_t)0x4325, (q15_t)0x6CF9, (q15_t)0x42D0, (q15_t)0x6D2D, + (q15_t)0x427A, (q15_t)0x6D62, (q15_t)0x4224, (q15_t)0x6D96, + (q15_t)0x41CE, (q15_t)0x6DCA, (q15_t)0x4177, (q15_t)0x6DFD, + (q15_t)0x4121, (q15_t)0x6E30, (q15_t)0x40CA, (q15_t)0x6E63, + (q15_t)0x4073, (q15_t)0x6E96, (q15_t)0x401D, (q15_t)0x6EC9, + (q15_t)0x3FC5, (q15_t)0x6EFB, (q15_t)0x3F6E, (q15_t)0x6F2D, + (q15_t)0x3F17, (q15_t)0x6F5F, (q15_t)0x3EBF, (q15_t)0x6F90, + (q15_t)0x3E68, (q15_t)0x6FC1, (q15_t)0x3E10, (q15_t)0x6FF2, + (q15_t)0x3DB8, (q15_t)0x7023, (q15_t)0x3D60, (q15_t)0x7053, + (q15_t)0x3D07, (q15_t)0x7083, (q15_t)0x3CAF, (q15_t)0x70B3, + (q15_t)0x3C56, (q15_t)0x70E2, (q15_t)0x3BFD, (q15_t)0x7112, + (q15_t)0x3BA5, (q15_t)0x7141, (q15_t)0x3B4C, (q15_t)0x716F, + (q15_t)0x3AF2, (q15_t)0x719E, (q15_t)0x3A99, (q15_t)0x71CC, + (q15_t)0x3A40, (q15_t)0x71FA, (q15_t)0x39E6, (q15_t)0x7227, + (q15_t)0x398C, (q15_t)0x7255, (q15_t)0x3932, (q15_t)0x7282, + (q15_t)0x38D8, (q15_t)0x72AF, (q15_t)0x387E, (q15_t)0x72DB, + (q15_t)0x3824, (q15_t)0x7307, (q15_t)0x37CA, (q15_t)0x7333, + (q15_t)0x376F, (q15_t)0x735F, (q15_t)0x3714, (q15_t)0x738A, + (q15_t)0x36BA, (q15_t)0x73B5, (q15_t)0x365F, (q15_t)0x73E0, + (q15_t)0x3604, (q15_t)0x740B, (q15_t)0x35A8, (q15_t)0x7435, + (q15_t)0x354D, (q15_t)0x745F, (q15_t)0x34F2, (q15_t)0x7489, + (q15_t)0x3496, (q15_t)0x74B2, (q15_t)0x343A, (q15_t)0x74DB, + (q15_t)0x33DE, (q15_t)0x7504, (q15_t)0x3382, (q15_t)0x752D, + (q15_t)0x3326, (q15_t)0x7555, (q15_t)0x32CA, (q15_t)0x757D, + (q15_t)0x326E, (q15_t)0x75A5, (q15_t)0x3211, (q15_t)0x75CC, + (q15_t)0x31B5, (q15_t)0x75F4, (q15_t)0x3158, (q15_t)0x761B, + (q15_t)0x30FB, (q15_t)0x7641, (q15_t)0x309E, (q15_t)0x7668, + (q15_t)0x3041, (q15_t)0x768E, (q15_t)0x2FE4, (q15_t)0x76B3, + (q15_t)0x2F87, (q15_t)0x76D9, (q15_t)0x2F29, (q15_t)0x76FE, + (q15_t)0x2ECC, (q15_t)0x7723, (q15_t)0x2E6E, (q15_t)0x7747, + (q15_t)0x2E11, (q15_t)0x776C, (q15_t)0x2DB3, (q15_t)0x7790, + (q15_t)0x2D55, (q15_t)0x77B4, (q15_t)0x2CF7, (q15_t)0x77D7, + (q15_t)0x2C98, (q15_t)0x77FA, (q15_t)0x2C3A, (q15_t)0x781D, + (q15_t)0x2BDC, (q15_t)0x7840, (q15_t)0x2B7D, (q15_t)0x7862, + (q15_t)0x2B1F, (q15_t)0x7884, (q15_t)0x2AC0, (q15_t)0x78A6, + (q15_t)0x2A61, (q15_t)0x78C7, (q15_t)0x2A02, (q15_t)0x78E8, + (q15_t)0x29A3, (q15_t)0x7909, (q15_t)0x2944, (q15_t)0x792A, + (q15_t)0x28E5, (q15_t)0x794A, (q15_t)0x2886, (q15_t)0x796A, + (q15_t)0x2826, (q15_t)0x798A, (q15_t)0x27C7, (q15_t)0x79A9, + (q15_t)0x2767, (q15_t)0x79C8, (q15_t)0x2707, (q15_t)0x79E7, + (q15_t)0x26A8, (q15_t)0x7A05, (q15_t)0x2648, (q15_t)0x7A24, + (q15_t)0x25E8, (q15_t)0x7A42, (q15_t)0x2588, (q15_t)0x7A5F, + (q15_t)0x2528, (q15_t)0x7A7D, (q15_t)0x24C7, (q15_t)0x7A9A, + (q15_t)0x2467, (q15_t)0x7AB6, (q15_t)0x2407, (q15_t)0x7AD3, + (q15_t)0x23A6, (q15_t)0x7AEF, (q15_t)0x2345, (q15_t)0x7B0B, + (q15_t)0x22E5, (q15_t)0x7B26, (q15_t)0x2284, (q15_t)0x7B42, + (q15_t)0x2223, (q15_t)0x7B5D, (q15_t)0x21C2, (q15_t)0x7B77, + (q15_t)0x2161, (q15_t)0x7B92, (q15_t)0x2100, (q15_t)0x7BAC, + (q15_t)0x209F, (q15_t)0x7BC5, (q15_t)0x203E, (q15_t)0x7BDF, + (q15_t)0x1FDC, (q15_t)0x7BF8, (q15_t)0x1F7B, (q15_t)0x7C11, + (q15_t)0x1F19, (q15_t)0x7C29, (q15_t)0x1EB8, (q15_t)0x7C42, + (q15_t)0x1E56, (q15_t)0x7C5A, (q15_t)0x1DF5, (q15_t)0x7C71, + (q15_t)0x1D93, (q15_t)0x7C89, (q15_t)0x1D31, (q15_t)0x7CA0, + (q15_t)0x1CCF, (q15_t)0x7CB7, (q15_t)0x1C6D, (q15_t)0x7CCD, + (q15_t)0x1C0B, (q15_t)0x7CE3, (q15_t)0x1BA9, (q15_t)0x7CF9, + (q15_t)0x1B47, (q15_t)0x7D0F, (q15_t)0x1AE4, (q15_t)0x7D24, + (q15_t)0x1A82, (q15_t)0x7D39, (q15_t)0x1A20, (q15_t)0x7D4E, + (q15_t)0x19BD, (q15_t)0x7D62, (q15_t)0x195B, (q15_t)0x7D76, + (q15_t)0x18F8, (q15_t)0x7D8A, (q15_t)0x1896, (q15_t)0x7D9D, + (q15_t)0x1833, (q15_t)0x7DB0, (q15_t)0x17D0, (q15_t)0x7DC3, + (q15_t)0x176D, (q15_t)0x7DD6, (q15_t)0x170A, (q15_t)0x7DE8, + (q15_t)0x16A8, (q15_t)0x7DFA, (q15_t)0x1645, (q15_t)0x7E0C, + (q15_t)0x15E2, (q15_t)0x7E1D, (q15_t)0x157F, (q15_t)0x7E2E, + (q15_t)0x151B, (q15_t)0x7E3F, (q15_t)0x14B8, (q15_t)0x7E4F, + (q15_t)0x1455, (q15_t)0x7E5F, (q15_t)0x13F2, (q15_t)0x7E6F, + (q15_t)0x138E, (q15_t)0x7E7F, (q15_t)0x132B, (q15_t)0x7E8E, + (q15_t)0x12C8, (q15_t)0x7E9D, (q15_t)0x1264, (q15_t)0x7EAB, + (q15_t)0x1201, (q15_t)0x7EBA, (q15_t)0x119D, (q15_t)0x7EC8, + (q15_t)0x1139, (q15_t)0x7ED5, (q15_t)0x10D6, (q15_t)0x7EE3, + (q15_t)0x1072, (q15_t)0x7EF0, (q15_t)0x100E, (q15_t)0x7EFD, + (q15_t)0x0FAB, (q15_t)0x7F09, (q15_t)0x0F47, (q15_t)0x7F15, + (q15_t)0x0EE3, (q15_t)0x7F21, (q15_t)0x0E7F, (q15_t)0x7F2D, + (q15_t)0x0E1B, (q15_t)0x7F38, (q15_t)0x0DB7, (q15_t)0x7F43, + (q15_t)0x0D53, (q15_t)0x7F4D, (q15_t)0x0CEF, (q15_t)0x7F58, + (q15_t)0x0C8B, (q15_t)0x7F62, (q15_t)0x0C27, (q15_t)0x7F6B, + (q15_t)0x0BC3, (q15_t)0x7F75, (q15_t)0x0B5F, (q15_t)0x7F7E, + (q15_t)0x0AFB, (q15_t)0x7F87, (q15_t)0x0A97, (q15_t)0x7F8F, + (q15_t)0x0A33, (q15_t)0x7F97, (q15_t)0x09CE, (q15_t)0x7F9F, + (q15_t)0x096A, (q15_t)0x7FA7, (q15_t)0x0906, (q15_t)0x7FAE, + (q15_t)0x08A2, (q15_t)0x7FB5, (q15_t)0x083D, (q15_t)0x7FBC, + (q15_t)0x07D9, (q15_t)0x7FC2, (q15_t)0x0775, (q15_t)0x7FC8, + (q15_t)0x0710, (q15_t)0x7FCE, (q15_t)0x06AC, (q15_t)0x7FD3, + (q15_t)0x0647, (q15_t)0x7FD8, (q15_t)0x05E3, (q15_t)0x7FDD, + (q15_t)0x057F, (q15_t)0x7FE1, (q15_t)0x051A, (q15_t)0x7FE5, + (q15_t)0x04B6, (q15_t)0x7FE9, (q15_t)0x0451, (q15_t)0x7FED, + (q15_t)0x03ED, (q15_t)0x7FF0, (q15_t)0x0388, (q15_t)0x7FF3, + (q15_t)0x0324, (q15_t)0x7FF6, (q15_t)0x02BF, (q15_t)0x7FF8, + (q15_t)0x025B, (q15_t)0x7FFA, (q15_t)0x01F6, (q15_t)0x7FFC, + (q15_t)0x0192, (q15_t)0x7FFD, (q15_t)0x012D, (q15_t)0x7FFE, + (q15_t)0x00C9, (q15_t)0x7FFF, (q15_t)0x0064, (q15_t)0x7FFF, + (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0xFF9B, (q15_t)0x7FFF, + (q15_t)0xFF36, (q15_t)0x7FFF, (q15_t)0xFED2, (q15_t)0x7FFE, + (q15_t)0xFE6D, (q15_t)0x7FFD, (q15_t)0xFE09, (q15_t)0x7FFC, + (q15_t)0xFDA4, (q15_t)0x7FFA, (q15_t)0xFD40, (q15_t)0x7FF8, + (q15_t)0xFCDB, (q15_t)0x7FF6, (q15_t)0xFC77, (q15_t)0x7FF3, + (q15_t)0xFC12, (q15_t)0x7FF0, (q15_t)0xFBAE, (q15_t)0x7FED, + (q15_t)0xFB49, (q15_t)0x7FE9, (q15_t)0xFAE5, (q15_t)0x7FE5, + (q15_t)0xFA80, (q15_t)0x7FE1, (q15_t)0xFA1C, (q15_t)0x7FDD, + (q15_t)0xF9B8, (q15_t)0x7FD8, (q15_t)0xF953, (q15_t)0x7FD3, + (q15_t)0xF8EF, (q15_t)0x7FCE, (q15_t)0xF88A, (q15_t)0x7FC8, + (q15_t)0xF826, (q15_t)0x7FC2, (q15_t)0xF7C2, (q15_t)0x7FBC, + (q15_t)0xF75D, (q15_t)0x7FB5, (q15_t)0xF6F9, (q15_t)0x7FAE, + (q15_t)0xF695, (q15_t)0x7FA7, (q15_t)0xF631, (q15_t)0x7F9F, + (q15_t)0xF5CC, (q15_t)0x7F97, (q15_t)0xF568, (q15_t)0x7F8F, + (q15_t)0xF504, (q15_t)0x7F87, (q15_t)0xF4A0, (q15_t)0x7F7E, + (q15_t)0xF43C, (q15_t)0x7F75, (q15_t)0xF3D8, (q15_t)0x7F6B, + (q15_t)0xF374, (q15_t)0x7F62, (q15_t)0xF310, (q15_t)0x7F58, + (q15_t)0xF2AC, (q15_t)0x7F4D, (q15_t)0xF248, (q15_t)0x7F43, + (q15_t)0xF1E4, (q15_t)0x7F38, (q15_t)0xF180, (q15_t)0x7F2D, + (q15_t)0xF11C, (q15_t)0x7F21, (q15_t)0xF0B8, (q15_t)0x7F15, + (q15_t)0xF054, (q15_t)0x7F09, (q15_t)0xEFF1, (q15_t)0x7EFD, + (q15_t)0xEF8D, (q15_t)0x7EF0, (q15_t)0xEF29, (q15_t)0x7EE3, + (q15_t)0xEEC6, (q15_t)0x7ED5, (q15_t)0xEE62, (q15_t)0x7EC8, + (q15_t)0xEDFE, (q15_t)0x7EBA, (q15_t)0xED9B, (q15_t)0x7EAB, + (q15_t)0xED37, (q15_t)0x7E9D, (q15_t)0xECD4, (q15_t)0x7E8E, + (q15_t)0xEC71, (q15_t)0x7E7F, (q15_t)0xEC0D, (q15_t)0x7E6F, + (q15_t)0xEBAA, (q15_t)0x7E5F, (q15_t)0xEB47, (q15_t)0x7E4F, + (q15_t)0xEAE4, (q15_t)0x7E3F, (q15_t)0xEA80, (q15_t)0x7E2E, + (q15_t)0xEA1D, (q15_t)0x7E1D, (q15_t)0xE9BA, (q15_t)0x7E0C, + (q15_t)0xE957, (q15_t)0x7DFA, (q15_t)0xE8F5, (q15_t)0x7DE8, + (q15_t)0xE892, (q15_t)0x7DD6, (q15_t)0xE82F, (q15_t)0x7DC3, + (q15_t)0xE7CC, (q15_t)0x7DB0, (q15_t)0xE769, (q15_t)0x7D9D, + (q15_t)0xE707, (q15_t)0x7D8A, (q15_t)0xE6A4, (q15_t)0x7D76, + (q15_t)0xE642, (q15_t)0x7D62, (q15_t)0xE5DF, (q15_t)0x7D4E, + (q15_t)0xE57D, (q15_t)0x7D39, (q15_t)0xE51B, (q15_t)0x7D24, + (q15_t)0xE4B8, (q15_t)0x7D0F, (q15_t)0xE456, (q15_t)0x7CF9, + (q15_t)0xE3F4, (q15_t)0x7CE3, (q15_t)0xE392, (q15_t)0x7CCD, + (q15_t)0xE330, (q15_t)0x7CB7, (q15_t)0xE2CE, (q15_t)0x7CA0, + (q15_t)0xE26C, (q15_t)0x7C89, (q15_t)0xE20A, (q15_t)0x7C71, + (q15_t)0xE1A9, (q15_t)0x7C5A, (q15_t)0xE147, (q15_t)0x7C42, + (q15_t)0xE0E6, (q15_t)0x7C29, (q15_t)0xE084, (q15_t)0x7C11, + (q15_t)0xE023, (q15_t)0x7BF8, (q15_t)0xDFC1, (q15_t)0x7BDF, + (q15_t)0xDF60, (q15_t)0x7BC5, (q15_t)0xDEFF, (q15_t)0x7BAC, + (q15_t)0xDE9E, (q15_t)0x7B92, (q15_t)0xDE3D, (q15_t)0x7B77, + (q15_t)0xDDDC, (q15_t)0x7B5D, (q15_t)0xDD7B, (q15_t)0x7B42, + (q15_t)0xDD1A, (q15_t)0x7B26, (q15_t)0xDCBA, (q15_t)0x7B0B, + (q15_t)0xDC59, (q15_t)0x7AEF, (q15_t)0xDBF8, (q15_t)0x7AD3, + (q15_t)0xDB98, (q15_t)0x7AB6, (q15_t)0xDB38, (q15_t)0x7A9A, + (q15_t)0xDAD7, (q15_t)0x7A7D, (q15_t)0xDA77, (q15_t)0x7A5F, + (q15_t)0xDA17, (q15_t)0x7A42, (q15_t)0xD9B7, (q15_t)0x7A24, + (q15_t)0xD957, (q15_t)0x7A05, (q15_t)0xD8F8, (q15_t)0x79E7, + (q15_t)0xD898, (q15_t)0x79C8, (q15_t)0xD838, (q15_t)0x79A9, + (q15_t)0xD7D9, (q15_t)0x798A, (q15_t)0xD779, (q15_t)0x796A, + (q15_t)0xD71A, (q15_t)0x794A, (q15_t)0xD6BB, (q15_t)0x792A, + (q15_t)0xD65C, (q15_t)0x7909, (q15_t)0xD5FD, (q15_t)0x78E8, + (q15_t)0xD59E, (q15_t)0x78C7, (q15_t)0xD53F, (q15_t)0x78A6, + (q15_t)0xD4E0, (q15_t)0x7884, (q15_t)0xD482, (q15_t)0x7862, + (q15_t)0xD423, (q15_t)0x7840, (q15_t)0xD3C5, (q15_t)0x781D, + (q15_t)0xD367, (q15_t)0x77FA, (q15_t)0xD308, (q15_t)0x77D7, + (q15_t)0xD2AA, (q15_t)0x77B4, (q15_t)0xD24C, (q15_t)0x7790, + (q15_t)0xD1EE, (q15_t)0x776C, (q15_t)0xD191, (q15_t)0x7747, + (q15_t)0xD133, (q15_t)0x7723, (q15_t)0xD0D6, (q15_t)0x76FE, + (q15_t)0xD078, (q15_t)0x76D9, (q15_t)0xD01B, (q15_t)0x76B3, + (q15_t)0xCFBE, (q15_t)0x768E, (q15_t)0xCF61, (q15_t)0x7668, + (q15_t)0xCF04, (q15_t)0x7641, (q15_t)0xCEA7, (q15_t)0x761B, + (q15_t)0xCE4A, (q15_t)0x75F4, (q15_t)0xCDEE, (q15_t)0x75CC, + (q15_t)0xCD91, (q15_t)0x75A5, (q15_t)0xCD35, (q15_t)0x757D, + (q15_t)0xCCD9, (q15_t)0x7555, (q15_t)0xCC7D, (q15_t)0x752D, + (q15_t)0xCC21, (q15_t)0x7504, (q15_t)0xCBC5, (q15_t)0x74DB, + (q15_t)0xCB69, (q15_t)0x74B2, (q15_t)0xCB0D, (q15_t)0x7489, + (q15_t)0xCAB2, (q15_t)0x745F, (q15_t)0xCA57, (q15_t)0x7435, + (q15_t)0xC9FB, (q15_t)0x740B, (q15_t)0xC9A0, (q15_t)0x73E0, + (q15_t)0xC945, (q15_t)0x73B5, (q15_t)0xC8EB, (q15_t)0x738A, + (q15_t)0xC890, (q15_t)0x735F, (q15_t)0xC835, (q15_t)0x7333, + (q15_t)0xC7DB, (q15_t)0x7307, (q15_t)0xC781, (q15_t)0x72DB, + (q15_t)0xC727, (q15_t)0x72AF, (q15_t)0xC6CD, (q15_t)0x7282, + (q15_t)0xC673, (q15_t)0x7255, (q15_t)0xC619, (q15_t)0x7227, + (q15_t)0xC5BF, (q15_t)0x71FA, (q15_t)0xC566, (q15_t)0x71CC, + (q15_t)0xC50D, (q15_t)0x719E, (q15_t)0xC4B3, (q15_t)0x716F, + (q15_t)0xC45A, (q15_t)0x7141, (q15_t)0xC402, (q15_t)0x7112, + (q15_t)0xC3A9, (q15_t)0x70E2, (q15_t)0xC350, (q15_t)0x70B3, + (q15_t)0xC2F8, (q15_t)0x7083, (q15_t)0xC29F, (q15_t)0x7053, + (q15_t)0xC247, (q15_t)0x7023, (q15_t)0xC1EF, (q15_t)0x6FF2, + (q15_t)0xC197, (q15_t)0x6FC1, (q15_t)0xC140, (q15_t)0x6F90, + (q15_t)0xC0E8, (q15_t)0x6F5F, (q15_t)0xC091, (q15_t)0x6F2D, + (q15_t)0xC03A, (q15_t)0x6EFB, (q15_t)0xBFE2, (q15_t)0x6EC9, + (q15_t)0xBF8C, (q15_t)0x6E96, (q15_t)0xBF35, (q15_t)0x6E63, + (q15_t)0xBEDE, (q15_t)0x6E30, (q15_t)0xBE88, (q15_t)0x6DFD, + (q15_t)0xBE31, (q15_t)0x6DCA, (q15_t)0xBDDB, (q15_t)0x6D96, + (q15_t)0xBD85, (q15_t)0x6D62, (q15_t)0xBD2F, (q15_t)0x6D2D, + (q15_t)0xBCDA, (q15_t)0x6CF9, (q15_t)0xBC84, (q15_t)0x6CC4, + (q15_t)0xBC2F, (q15_t)0x6C8F, (q15_t)0xBBDA, (q15_t)0x6C59, + (q15_t)0xBB85, (q15_t)0x6C24, (q15_t)0xBB30, (q15_t)0x6BEE, + (q15_t)0xBADB, (q15_t)0x6BB8, (q15_t)0xBA87, (q15_t)0x6B81, + (q15_t)0xBA32, (q15_t)0x6B4A, (q15_t)0xB9DE, (q15_t)0x6B13, + (q15_t)0xB98A, (q15_t)0x6ADC, (q15_t)0xB936, (q15_t)0x6AA5, + (q15_t)0xB8E3, (q15_t)0x6A6D, (q15_t)0xB88F, (q15_t)0x6A35, + (q15_t)0xB83C, (q15_t)0x69FD, (q15_t)0xB7E9, (q15_t)0x69C4, + (q15_t)0xB796, (q15_t)0x698C, (q15_t)0xB743, (q15_t)0x6953, + (q15_t)0xB6F0, (q15_t)0x6919, (q15_t)0xB69E, (q15_t)0x68E0, + (q15_t)0xB64B, (q15_t)0x68A6, (q15_t)0xB5F9, (q15_t)0x686C, + (q15_t)0xB5A7, (q15_t)0x6832, (q15_t)0xB556, (q15_t)0x67F7, + (q15_t)0xB504, (q15_t)0x67BD, (q15_t)0xB4B3, (q15_t)0x6782, + (q15_t)0xB461, (q15_t)0x6746, (q15_t)0xB410, (q15_t)0x670B, + (q15_t)0xB3C0, (q15_t)0x66CF, (q15_t)0xB36F, (q15_t)0x6693, + (q15_t)0xB31E, (q15_t)0x6657, (q15_t)0xB2CE, (q15_t)0x661A, + (q15_t)0xB27E, (q15_t)0x65DD, (q15_t)0xB22E, (q15_t)0x65A0, + (q15_t)0xB1DE, (q15_t)0x6563, (q15_t)0xB18F, (q15_t)0x6526, + (q15_t)0xB140, (q15_t)0x64E8, (q15_t)0xB0F0, (q15_t)0x64AA, + (q15_t)0xB0A1, (q15_t)0x646C, (q15_t)0xB053, (q15_t)0x642D, + (q15_t)0xB004, (q15_t)0x63EF, (q15_t)0xAFB6, (q15_t)0x63B0, + (q15_t)0xAF68, (q15_t)0x6371, (q15_t)0xAF1A, (q15_t)0x6331, + (q15_t)0xAECC, (q15_t)0x62F2, (q15_t)0xAE7E, (q15_t)0x62B2, + (q15_t)0xAE31, (q15_t)0x6271, (q15_t)0xADE3, (q15_t)0x6231, + (q15_t)0xAD96, (q15_t)0x61F1, (q15_t)0xAD4A, (q15_t)0x61B0, + (q15_t)0xACFD, (q15_t)0x616F, (q15_t)0xACB1, (q15_t)0x612D, + (q15_t)0xAC64, (q15_t)0x60EC, (q15_t)0xAC18, (q15_t)0x60AA, + (q15_t)0xABCC, (q15_t)0x6068, (q15_t)0xAB81, (q15_t)0x6026, + (q15_t)0xAB35, (q15_t)0x5FE3, (q15_t)0xAAEA, (q15_t)0x5FA0, + (q15_t)0xAA9F, (q15_t)0x5F5E, (q15_t)0xAA54, (q15_t)0x5F1A, + (q15_t)0xAA0A, (q15_t)0x5ED7, (q15_t)0xA9BF, (q15_t)0x5E93, + (q15_t)0xA975, (q15_t)0x5E50, (q15_t)0xA92B, (q15_t)0x5E0B, + (q15_t)0xA8E2, (q15_t)0x5DC7, (q15_t)0xA898, (q15_t)0x5D83, + (q15_t)0xA84F, (q15_t)0x5D3E, (q15_t)0xA806, (q15_t)0x5CF9, + (q15_t)0xA7BD, (q15_t)0x5CB4, (q15_t)0xA774, (q15_t)0x5C6E, + (q15_t)0xA72B, (q15_t)0x5C29, (q15_t)0xA6E3, (q15_t)0x5BE3, + (q15_t)0xA69B, (q15_t)0x5B9D, (q15_t)0xA653, (q15_t)0x5B56, + (q15_t)0xA60C, (q15_t)0x5B10, (q15_t)0xA5C4, (q15_t)0x5AC9, + (q15_t)0xA57D, (q15_t)0x5A82, (q15_t)0xA536, (q15_t)0x5A3B, + (q15_t)0xA4EF, (q15_t)0x59F3, (q15_t)0xA4A9, (q15_t)0x59AC, + (q15_t)0xA462, (q15_t)0x5964, (q15_t)0xA41C, (q15_t)0x591C, + (q15_t)0xA3D6, (q15_t)0x58D4, (q15_t)0xA391, (q15_t)0x588B, + (q15_t)0xA34B, (q15_t)0x5842, (q15_t)0xA306, (q15_t)0x57F9, + (q15_t)0xA2C1, (q15_t)0x57B0, (q15_t)0xA27C, (q15_t)0x5767, + (q15_t)0xA238, (q15_t)0x571D, (q15_t)0xA1F4, (q15_t)0x56D4, + (q15_t)0xA1AF, (q15_t)0x568A, (q15_t)0xA16C, (q15_t)0x5640, + (q15_t)0xA128, (q15_t)0x55F5, (q15_t)0xA0E5, (q15_t)0x55AB, + (q15_t)0xA0A1, (q15_t)0x5560, (q15_t)0xA05F, (q15_t)0x5515, + (q15_t)0xA01C, (q15_t)0x54CA, (q15_t)0x9FD9, (q15_t)0x547E, + (q15_t)0x9F97, (q15_t)0x5433, (q15_t)0x9F55, (q15_t)0x53E7, + (q15_t)0x9F13, (q15_t)0x539B, (q15_t)0x9ED2, (q15_t)0x534E, + (q15_t)0x9E90, (q15_t)0x5302, (q15_t)0x9E4F, (q15_t)0x52B5, + (q15_t)0x9E0E, (q15_t)0x5269, (q15_t)0x9DCE, (q15_t)0x521C, + (q15_t)0x9D8E, (q15_t)0x51CE, (q15_t)0x9D4D, (q15_t)0x5181, + (q15_t)0x9D0D, (q15_t)0x5133, (q15_t)0x9CCE, (q15_t)0x50E5, + (q15_t)0x9C8E, (q15_t)0x5097, (q15_t)0x9C4F, (q15_t)0x5049, + (q15_t)0x9C10, (q15_t)0x4FFB, (q15_t)0x9BD2, (q15_t)0x4FAC, + (q15_t)0x9B93, (q15_t)0x4F5E, (q15_t)0x9B55, (q15_t)0x4F0F, + (q15_t)0x9B17, (q15_t)0x4EBF, (q15_t)0x9AD9, (q15_t)0x4E70, + (q15_t)0x9A9C, (q15_t)0x4E21, (q15_t)0x9A5F, (q15_t)0x4DD1, + (q15_t)0x9A22, (q15_t)0x4D81, (q15_t)0x99E5, (q15_t)0x4D31, + (q15_t)0x99A8, (q15_t)0x4CE1, (q15_t)0x996C, (q15_t)0x4C90, + (q15_t)0x9930, (q15_t)0x4C3F, (q15_t)0x98F4, (q15_t)0x4BEF, + (q15_t)0x98B9, (q15_t)0x4B9E, (q15_t)0x987D, (q15_t)0x4B4C, + (q15_t)0x9842, (q15_t)0x4AFB, (q15_t)0x9808, (q15_t)0x4AA9, + (q15_t)0x97CD, (q15_t)0x4A58, (q15_t)0x9793, (q15_t)0x4A06, + (q15_t)0x9759, (q15_t)0x49B4, (q15_t)0x971F, (q15_t)0x4961, + (q15_t)0x96E6, (q15_t)0x490F, (q15_t)0x96AC, (q15_t)0x48BC, + (q15_t)0x9673, (q15_t)0x4869, (q15_t)0x963B, (q15_t)0x4816, + (q15_t)0x9602, (q15_t)0x47C3, (q15_t)0x95CA, (q15_t)0x4770, + (q15_t)0x9592, (q15_t)0x471C, (q15_t)0x955A, (q15_t)0x46C9, + (q15_t)0x9523, (q15_t)0x4675, (q15_t)0x94EC, (q15_t)0x4621, + (q15_t)0x94B5, (q15_t)0x45CD, (q15_t)0x947E, (q15_t)0x4578, + (q15_t)0x9447, (q15_t)0x4524, (q15_t)0x9411, (q15_t)0x44CF, + (q15_t)0x93DB, (q15_t)0x447A, (q15_t)0x93A6, (q15_t)0x4425, + (q15_t)0x9370, (q15_t)0x43D0, (q15_t)0x933B, (q15_t)0x437B, + (q15_t)0x9306, (q15_t)0x4325, (q15_t)0x92D2, (q15_t)0x42D0, + (q15_t)0x929D, (q15_t)0x427A, (q15_t)0x9269, (q15_t)0x4224, + (q15_t)0x9235, (q15_t)0x41CE, (q15_t)0x9202, (q15_t)0x4177, + (q15_t)0x91CF, (q15_t)0x4121, (q15_t)0x919C, (q15_t)0x40CA, + (q15_t)0x9169, (q15_t)0x4073, (q15_t)0x9136, (q15_t)0x401D, + (q15_t)0x9104, (q15_t)0x3FC5, (q15_t)0x90D2, (q15_t)0x3F6E, + (q15_t)0x90A0, (q15_t)0x3F17, (q15_t)0x906F, (q15_t)0x3EBF, + (q15_t)0x903E, (q15_t)0x3E68, (q15_t)0x900D, (q15_t)0x3E10, + (q15_t)0x8FDC, (q15_t)0x3DB8, (q15_t)0x8FAC, (q15_t)0x3D60, + (q15_t)0x8F7C, (q15_t)0x3D07, (q15_t)0x8F4C, (q15_t)0x3CAF, + (q15_t)0x8F1D, (q15_t)0x3C56, (q15_t)0x8EED, (q15_t)0x3BFD, + (q15_t)0x8EBE, (q15_t)0x3BA5, (q15_t)0x8E90, (q15_t)0x3B4C, + (q15_t)0x8E61, (q15_t)0x3AF2, (q15_t)0x8E33, (q15_t)0x3A99, + (q15_t)0x8E05, (q15_t)0x3A40, (q15_t)0x8DD8, (q15_t)0x39E6, + (q15_t)0x8DAA, (q15_t)0x398C, (q15_t)0x8D7D, (q15_t)0x3932, + (q15_t)0x8D50, (q15_t)0x38D8, (q15_t)0x8D24, (q15_t)0x387E, + (q15_t)0x8CF8, (q15_t)0x3824, (q15_t)0x8CCC, (q15_t)0x37CA, + (q15_t)0x8CA0, (q15_t)0x376F, (q15_t)0x8C75, (q15_t)0x3714, + (q15_t)0x8C4A, (q15_t)0x36BA, (q15_t)0x8C1F, (q15_t)0x365F, + (q15_t)0x8BF4, (q15_t)0x3604, (q15_t)0x8BCA, (q15_t)0x35A8, + (q15_t)0x8BA0, (q15_t)0x354D, (q15_t)0x8B76, (q15_t)0x34F2, + (q15_t)0x8B4D, (q15_t)0x3496, (q15_t)0x8B24, (q15_t)0x343A, + (q15_t)0x8AFB, (q15_t)0x33DE, (q15_t)0x8AD2, (q15_t)0x3382, + (q15_t)0x8AAA, (q15_t)0x3326, (q15_t)0x8A82, (q15_t)0x32CA, + (q15_t)0x8A5A, (q15_t)0x326E, (q15_t)0x8A33, (q15_t)0x3211, + (q15_t)0x8A0B, (q15_t)0x31B5, (q15_t)0x89E4, (q15_t)0x3158, + (q15_t)0x89BE, (q15_t)0x30FB, (q15_t)0x8997, (q15_t)0x309E, + (q15_t)0x8971, (q15_t)0x3041, (q15_t)0x894C, (q15_t)0x2FE4, + (q15_t)0x8926, (q15_t)0x2F87, (q15_t)0x8901, (q15_t)0x2F29, + (q15_t)0x88DC, (q15_t)0x2ECC, (q15_t)0x88B8, (q15_t)0x2E6E, + (q15_t)0x8893, (q15_t)0x2E11, (q15_t)0x886F, (q15_t)0x2DB3, + (q15_t)0x884B, (q15_t)0x2D55, (q15_t)0x8828, (q15_t)0x2CF7, + (q15_t)0x8805, (q15_t)0x2C98, (q15_t)0x87E2, (q15_t)0x2C3A, + (q15_t)0x87BF, (q15_t)0x2BDC, (q15_t)0x879D, (q15_t)0x2B7D, + (q15_t)0x877B, (q15_t)0x2B1F, (q15_t)0x8759, (q15_t)0x2AC0, + (q15_t)0x8738, (q15_t)0x2A61, (q15_t)0x8717, (q15_t)0x2A02, + (q15_t)0x86F6, (q15_t)0x29A3, (q15_t)0x86D5, (q15_t)0x2944, + (q15_t)0x86B5, (q15_t)0x28E5, (q15_t)0x8695, (q15_t)0x2886, + (q15_t)0x8675, (q15_t)0x2826, (q15_t)0x8656, (q15_t)0x27C7, + (q15_t)0x8637, (q15_t)0x2767, (q15_t)0x8618, (q15_t)0x2707, + (q15_t)0x85FA, (q15_t)0x26A8, (q15_t)0x85DB, (q15_t)0x2648, + (q15_t)0x85BD, (q15_t)0x25E8, (q15_t)0x85A0, (q15_t)0x2588, + (q15_t)0x8582, (q15_t)0x2528, (q15_t)0x8565, (q15_t)0x24C7, + (q15_t)0x8549, (q15_t)0x2467, (q15_t)0x852C, (q15_t)0x2407, + (q15_t)0x8510, (q15_t)0x23A6, (q15_t)0x84F4, (q15_t)0x2345, + (q15_t)0x84D9, (q15_t)0x22E5, (q15_t)0x84BD, (q15_t)0x2284, + (q15_t)0x84A2, (q15_t)0x2223, (q15_t)0x8488, (q15_t)0x21C2, + (q15_t)0x846D, (q15_t)0x2161, (q15_t)0x8453, (q15_t)0x2100, + (q15_t)0x843A, (q15_t)0x209F, (q15_t)0x8420, (q15_t)0x203E, + (q15_t)0x8407, (q15_t)0x1FDC, (q15_t)0x83EE, (q15_t)0x1F7B, + (q15_t)0x83D6, (q15_t)0x1F19, (q15_t)0x83BD, (q15_t)0x1EB8, + (q15_t)0x83A5, (q15_t)0x1E56, (q15_t)0x838E, (q15_t)0x1DF5, + (q15_t)0x8376, (q15_t)0x1D93, (q15_t)0x835F, (q15_t)0x1D31, + (q15_t)0x8348, (q15_t)0x1CCF, (q15_t)0x8332, (q15_t)0x1C6D, + (q15_t)0x831C, (q15_t)0x1C0B, (q15_t)0x8306, (q15_t)0x1BA9, + (q15_t)0x82F0, (q15_t)0x1B47, (q15_t)0x82DB, (q15_t)0x1AE4, + (q15_t)0x82C6, (q15_t)0x1A82, (q15_t)0x82B1, (q15_t)0x1A20, + (q15_t)0x829D, (q15_t)0x19BD, (q15_t)0x8289, (q15_t)0x195B, + (q15_t)0x8275, (q15_t)0x18F8, (q15_t)0x8262, (q15_t)0x1896, + (q15_t)0x824F, (q15_t)0x1833, (q15_t)0x823C, (q15_t)0x17D0, + (q15_t)0x8229, (q15_t)0x176D, (q15_t)0x8217, (q15_t)0x170A, + (q15_t)0x8205, (q15_t)0x16A8, (q15_t)0x81F3, (q15_t)0x1645, + (q15_t)0x81E2, (q15_t)0x15E2, (q15_t)0x81D1, (q15_t)0x157F, + (q15_t)0x81C0, (q15_t)0x151B, (q15_t)0x81B0, (q15_t)0x14B8, + (q15_t)0x81A0, (q15_t)0x1455, (q15_t)0x8190, (q15_t)0x13F2, + (q15_t)0x8180, (q15_t)0x138E, (q15_t)0x8171, (q15_t)0x132B, + (q15_t)0x8162, (q15_t)0x12C8, (q15_t)0x8154, (q15_t)0x1264, + (q15_t)0x8145, (q15_t)0x1201, (q15_t)0x8137, (q15_t)0x119D, + (q15_t)0x812A, (q15_t)0x1139, (q15_t)0x811C, (q15_t)0x10D6, + (q15_t)0x810F, (q15_t)0x1072, (q15_t)0x8102, (q15_t)0x100E, + (q15_t)0x80F6, (q15_t)0x0FAB, (q15_t)0x80EA, (q15_t)0x0F47, + (q15_t)0x80DE, (q15_t)0x0EE3, (q15_t)0x80D2, (q15_t)0x0E7F, + (q15_t)0x80C7, (q15_t)0x0E1B, (q15_t)0x80BC, (q15_t)0x0DB7, + (q15_t)0x80B2, (q15_t)0x0D53, (q15_t)0x80A7, (q15_t)0x0CEF, + (q15_t)0x809D, (q15_t)0x0C8B, (q15_t)0x8094, (q15_t)0x0C27, + (q15_t)0x808A, (q15_t)0x0BC3, (q15_t)0x8081, (q15_t)0x0B5F, + (q15_t)0x8078, (q15_t)0x0AFB, (q15_t)0x8070, (q15_t)0x0A97, + (q15_t)0x8068, (q15_t)0x0A33, (q15_t)0x8060, (q15_t)0x09CE, + (q15_t)0x8058, (q15_t)0x096A, (q15_t)0x8051, (q15_t)0x0906, + (q15_t)0x804A, (q15_t)0x08A2, (q15_t)0x8043, (q15_t)0x083D, + (q15_t)0x803D, (q15_t)0x07D9, (q15_t)0x8037, (q15_t)0x0775, + (q15_t)0x8031, (q15_t)0x0710, (q15_t)0x802C, (q15_t)0x06AC, + (q15_t)0x8027, (q15_t)0x0647, (q15_t)0x8022, (q15_t)0x05E3, + (q15_t)0x801E, (q15_t)0x057F, (q15_t)0x801A, (q15_t)0x051A, + (q15_t)0x8016, (q15_t)0x04B6, (q15_t)0x8012, (q15_t)0x0451, + (q15_t)0x800F, (q15_t)0x03ED, (q15_t)0x800C, (q15_t)0x0388, + (q15_t)0x8009, (q15_t)0x0324, (q15_t)0x8007, (q15_t)0x02BF, + (q15_t)0x8005, (q15_t)0x025B, (q15_t)0x8003, (q15_t)0x01F6, + (q15_t)0x8002, (q15_t)0x0192, (q15_t)0x8001, (q15_t)0x012D, + (q15_t)0x8000, (q15_t)0x00C9, (q15_t)0x8000, (q15_t)0x0064, + (q15_t)0x8000, (q15_t)0x0000, (q15_t)0x8000, (q15_t)0xFF9B, + (q15_t)0x8000, (q15_t)0xFF36, (q15_t)0x8001, (q15_t)0xFED2, + (q15_t)0x8002, (q15_t)0xFE6D, (q15_t)0x8003, (q15_t)0xFE09, + (q15_t)0x8005, (q15_t)0xFDA4, (q15_t)0x8007, (q15_t)0xFD40, + (q15_t)0x8009, (q15_t)0xFCDB, (q15_t)0x800C, (q15_t)0xFC77, + (q15_t)0x800F, (q15_t)0xFC12, (q15_t)0x8012, (q15_t)0xFBAE, + (q15_t)0x8016, (q15_t)0xFB49, (q15_t)0x801A, (q15_t)0xFAE5, + (q15_t)0x801E, (q15_t)0xFA80, (q15_t)0x8022, (q15_t)0xFA1C, + (q15_t)0x8027, (q15_t)0xF9B8, (q15_t)0x802C, (q15_t)0xF953, + (q15_t)0x8031, (q15_t)0xF8EF, (q15_t)0x8037, (q15_t)0xF88A, + (q15_t)0x803D, (q15_t)0xF826, (q15_t)0x8043, (q15_t)0xF7C2, + (q15_t)0x804A, (q15_t)0xF75D, (q15_t)0x8051, (q15_t)0xF6F9, + (q15_t)0x8058, (q15_t)0xF695, (q15_t)0x8060, (q15_t)0xF631, + (q15_t)0x8068, (q15_t)0xF5CC, (q15_t)0x8070, (q15_t)0xF568, + (q15_t)0x8078, (q15_t)0xF504, (q15_t)0x8081, (q15_t)0xF4A0, + (q15_t)0x808A, (q15_t)0xF43C, (q15_t)0x8094, (q15_t)0xF3D8, + (q15_t)0x809D, (q15_t)0xF374, (q15_t)0x80A7, (q15_t)0xF310, + (q15_t)0x80B2, (q15_t)0xF2AC, (q15_t)0x80BC, (q15_t)0xF248, + (q15_t)0x80C7, (q15_t)0xF1E4, (q15_t)0x80D2, (q15_t)0xF180, + (q15_t)0x80DE, (q15_t)0xF11C, (q15_t)0x80EA, (q15_t)0xF0B8, + (q15_t)0x80F6, (q15_t)0xF054, (q15_t)0x8102, (q15_t)0xEFF1, + (q15_t)0x810F, (q15_t)0xEF8D, (q15_t)0x811C, (q15_t)0xEF29, + (q15_t)0x812A, (q15_t)0xEEC6, (q15_t)0x8137, (q15_t)0xEE62, + (q15_t)0x8145, (q15_t)0xEDFE, (q15_t)0x8154, (q15_t)0xED9B, + (q15_t)0x8162, (q15_t)0xED37, (q15_t)0x8171, (q15_t)0xECD4, + (q15_t)0x8180, (q15_t)0xEC71, (q15_t)0x8190, (q15_t)0xEC0D, + (q15_t)0x81A0, (q15_t)0xEBAA, (q15_t)0x81B0, (q15_t)0xEB47, + (q15_t)0x81C0, (q15_t)0xEAE4, (q15_t)0x81D1, (q15_t)0xEA80, + (q15_t)0x81E2, (q15_t)0xEA1D, (q15_t)0x81F3, (q15_t)0xE9BA, + (q15_t)0x8205, (q15_t)0xE957, (q15_t)0x8217, (q15_t)0xE8F5, + (q15_t)0x8229, (q15_t)0xE892, (q15_t)0x823C, (q15_t)0xE82F, + (q15_t)0x824F, (q15_t)0xE7CC, (q15_t)0x8262, (q15_t)0xE769, + (q15_t)0x8275, (q15_t)0xE707, (q15_t)0x8289, (q15_t)0xE6A4, + (q15_t)0x829D, (q15_t)0xE642, (q15_t)0x82B1, (q15_t)0xE5DF, + (q15_t)0x82C6, (q15_t)0xE57D, (q15_t)0x82DB, (q15_t)0xE51B, + (q15_t)0x82F0, (q15_t)0xE4B8, (q15_t)0x8306, (q15_t)0xE456, + (q15_t)0x831C, (q15_t)0xE3F4, (q15_t)0x8332, (q15_t)0xE392, + (q15_t)0x8348, (q15_t)0xE330, (q15_t)0x835F, (q15_t)0xE2CE, + (q15_t)0x8376, (q15_t)0xE26C, (q15_t)0x838E, (q15_t)0xE20A, + (q15_t)0x83A5, (q15_t)0xE1A9, (q15_t)0x83BD, (q15_t)0xE147, + (q15_t)0x83D6, (q15_t)0xE0E6, (q15_t)0x83EE, (q15_t)0xE084, + (q15_t)0x8407, (q15_t)0xE023, (q15_t)0x8420, (q15_t)0xDFC1, + (q15_t)0x843A, (q15_t)0xDF60, (q15_t)0x8453, (q15_t)0xDEFF, + (q15_t)0x846D, (q15_t)0xDE9E, (q15_t)0x8488, (q15_t)0xDE3D, + (q15_t)0x84A2, (q15_t)0xDDDC, (q15_t)0x84BD, (q15_t)0xDD7B, + (q15_t)0x84D9, (q15_t)0xDD1A, (q15_t)0x84F4, (q15_t)0xDCBA, + (q15_t)0x8510, (q15_t)0xDC59, (q15_t)0x852C, (q15_t)0xDBF8, + (q15_t)0x8549, (q15_t)0xDB98, (q15_t)0x8565, (q15_t)0xDB38, + (q15_t)0x8582, (q15_t)0xDAD7, (q15_t)0x85A0, (q15_t)0xDA77, + (q15_t)0x85BD, (q15_t)0xDA17, (q15_t)0x85DB, (q15_t)0xD9B7, + (q15_t)0x85FA, (q15_t)0xD957, (q15_t)0x8618, (q15_t)0xD8F8, + (q15_t)0x8637, (q15_t)0xD898, (q15_t)0x8656, (q15_t)0xD838, + (q15_t)0x8675, (q15_t)0xD7D9, (q15_t)0x8695, (q15_t)0xD779, + (q15_t)0x86B5, (q15_t)0xD71A, (q15_t)0x86D5, (q15_t)0xD6BB, + (q15_t)0x86F6, (q15_t)0xD65C, (q15_t)0x8717, (q15_t)0xD5FD, + (q15_t)0x8738, (q15_t)0xD59E, (q15_t)0x8759, (q15_t)0xD53F, + (q15_t)0x877B, (q15_t)0xD4E0, (q15_t)0x879D, (q15_t)0xD482, + (q15_t)0x87BF, (q15_t)0xD423, (q15_t)0x87E2, (q15_t)0xD3C5, + (q15_t)0x8805, (q15_t)0xD367, (q15_t)0x8828, (q15_t)0xD308, + (q15_t)0x884B, (q15_t)0xD2AA, (q15_t)0x886F, (q15_t)0xD24C, + (q15_t)0x8893, (q15_t)0xD1EE, (q15_t)0x88B8, (q15_t)0xD191, + (q15_t)0x88DC, (q15_t)0xD133, (q15_t)0x8901, (q15_t)0xD0D6, + (q15_t)0x8926, (q15_t)0xD078, (q15_t)0x894C, (q15_t)0xD01B, + (q15_t)0x8971, (q15_t)0xCFBE, (q15_t)0x8997, (q15_t)0xCF61, + (q15_t)0x89BE, (q15_t)0xCF04, (q15_t)0x89E4, (q15_t)0xCEA7, + (q15_t)0x8A0B, (q15_t)0xCE4A, (q15_t)0x8A33, (q15_t)0xCDEE, + (q15_t)0x8A5A, (q15_t)0xCD91, (q15_t)0x8A82, (q15_t)0xCD35, + (q15_t)0x8AAA, (q15_t)0xCCD9, (q15_t)0x8AD2, (q15_t)0xCC7D, + (q15_t)0x8AFB, (q15_t)0xCC21, (q15_t)0x8B24, (q15_t)0xCBC5, + (q15_t)0x8B4D, (q15_t)0xCB69, (q15_t)0x8B76, (q15_t)0xCB0D, + (q15_t)0x8BA0, (q15_t)0xCAB2, (q15_t)0x8BCA, (q15_t)0xCA57, + (q15_t)0x8BF4, (q15_t)0xC9FB, (q15_t)0x8C1F, (q15_t)0xC9A0, + (q15_t)0x8C4A, (q15_t)0xC945, (q15_t)0x8C75, (q15_t)0xC8EB, + (q15_t)0x8CA0, (q15_t)0xC890, (q15_t)0x8CCC, (q15_t)0xC835, + (q15_t)0x8CF8, (q15_t)0xC7DB, (q15_t)0x8D24, (q15_t)0xC781, + (q15_t)0x8D50, (q15_t)0xC727, (q15_t)0x8D7D, (q15_t)0xC6CD, + (q15_t)0x8DAA, (q15_t)0xC673, (q15_t)0x8DD8, (q15_t)0xC619, + (q15_t)0x8E05, (q15_t)0xC5BF, (q15_t)0x8E33, (q15_t)0xC566, + (q15_t)0x8E61, (q15_t)0xC50D, (q15_t)0x8E90, (q15_t)0xC4B3, + (q15_t)0x8EBE, (q15_t)0xC45A, (q15_t)0x8EED, (q15_t)0xC402, + (q15_t)0x8F1D, (q15_t)0xC3A9, (q15_t)0x8F4C, (q15_t)0xC350, + (q15_t)0x8F7C, (q15_t)0xC2F8, (q15_t)0x8FAC, (q15_t)0xC29F, + (q15_t)0x8FDC, (q15_t)0xC247, (q15_t)0x900D, (q15_t)0xC1EF, + (q15_t)0x903E, (q15_t)0xC197, (q15_t)0x906F, (q15_t)0xC140, + (q15_t)0x90A0, (q15_t)0xC0E8, (q15_t)0x90D2, (q15_t)0xC091, + (q15_t)0x9104, (q15_t)0xC03A, (q15_t)0x9136, (q15_t)0xBFE2, + (q15_t)0x9169, (q15_t)0xBF8C, (q15_t)0x919C, (q15_t)0xBF35, + (q15_t)0x91CF, (q15_t)0xBEDE, (q15_t)0x9202, (q15_t)0xBE88, + (q15_t)0x9235, (q15_t)0xBE31, (q15_t)0x9269, (q15_t)0xBDDB, + (q15_t)0x929D, (q15_t)0xBD85, (q15_t)0x92D2, (q15_t)0xBD2F, + (q15_t)0x9306, (q15_t)0xBCDA, (q15_t)0x933B, (q15_t)0xBC84, + (q15_t)0x9370, (q15_t)0xBC2F, (q15_t)0x93A6, (q15_t)0xBBDA, + (q15_t)0x93DB, (q15_t)0xBB85, (q15_t)0x9411, (q15_t)0xBB30, + (q15_t)0x9447, (q15_t)0xBADB, (q15_t)0x947E, (q15_t)0xBA87, + (q15_t)0x94B5, (q15_t)0xBA32, (q15_t)0x94EC, (q15_t)0xB9DE, + (q15_t)0x9523, (q15_t)0xB98A, (q15_t)0x955A, (q15_t)0xB936, + (q15_t)0x9592, (q15_t)0xB8E3, (q15_t)0x95CA, (q15_t)0xB88F, + (q15_t)0x9602, (q15_t)0xB83C, (q15_t)0x963B, (q15_t)0xB7E9, + (q15_t)0x9673, (q15_t)0xB796, (q15_t)0x96AC, (q15_t)0xB743, + (q15_t)0x96E6, (q15_t)0xB6F0, (q15_t)0x971F, (q15_t)0xB69E, + (q15_t)0x9759, (q15_t)0xB64B, (q15_t)0x9793, (q15_t)0xB5F9, + (q15_t)0x97CD, (q15_t)0xB5A7, (q15_t)0x9808, (q15_t)0xB556, + (q15_t)0x9842, (q15_t)0xB504, (q15_t)0x987D, (q15_t)0xB4B3, + (q15_t)0x98B9, (q15_t)0xB461, (q15_t)0x98F4, (q15_t)0xB410, + (q15_t)0x9930, (q15_t)0xB3C0, (q15_t)0x996C, (q15_t)0xB36F, + (q15_t)0x99A8, (q15_t)0xB31E, (q15_t)0x99E5, (q15_t)0xB2CE, + (q15_t)0x9A22, (q15_t)0xB27E, (q15_t)0x9A5F, (q15_t)0xB22E, + (q15_t)0x9A9C, (q15_t)0xB1DE, (q15_t)0x9AD9, (q15_t)0xB18F, + (q15_t)0x9B17, (q15_t)0xB140, (q15_t)0x9B55, (q15_t)0xB0F0, + (q15_t)0x9B93, (q15_t)0xB0A1, (q15_t)0x9BD2, (q15_t)0xB053, + (q15_t)0x9C10, (q15_t)0xB004, (q15_t)0x9C4F, (q15_t)0xAFB6, + (q15_t)0x9C8E, (q15_t)0xAF68, (q15_t)0x9CCE, (q15_t)0xAF1A, + (q15_t)0x9D0D, (q15_t)0xAECC, (q15_t)0x9D4D, (q15_t)0xAE7E, + (q15_t)0x9D8E, (q15_t)0xAE31, (q15_t)0x9DCE, (q15_t)0xADE3, + (q15_t)0x9E0E, (q15_t)0xAD96, (q15_t)0x9E4F, (q15_t)0xAD4A, + (q15_t)0x9E90, (q15_t)0xACFD, (q15_t)0x9ED2, (q15_t)0xACB1, + (q15_t)0x9F13, (q15_t)0xAC64, (q15_t)0x9F55, (q15_t)0xAC18, + (q15_t)0x9F97, (q15_t)0xABCC, (q15_t)0x9FD9, (q15_t)0xAB81, + (q15_t)0xA01C, (q15_t)0xAB35, (q15_t)0xA05F, (q15_t)0xAAEA, + (q15_t)0xA0A1, (q15_t)0xAA9F, (q15_t)0xA0E5, (q15_t)0xAA54, + (q15_t)0xA128, (q15_t)0xAA0A, (q15_t)0xA16C, (q15_t)0xA9BF, + (q15_t)0xA1AF, (q15_t)0xA975, (q15_t)0xA1F4, (q15_t)0xA92B, + (q15_t)0xA238, (q15_t)0xA8E2, (q15_t)0xA27C, (q15_t)0xA898, + (q15_t)0xA2C1, (q15_t)0xA84F, (q15_t)0xA306, (q15_t)0xA806, + (q15_t)0xA34B, (q15_t)0xA7BD, (q15_t)0xA391, (q15_t)0xA774, + (q15_t)0xA3D6, (q15_t)0xA72B, (q15_t)0xA41C, (q15_t)0xA6E3, + (q15_t)0xA462, (q15_t)0xA69B, (q15_t)0xA4A9, (q15_t)0xA653, + (q15_t)0xA4EF, (q15_t)0xA60C, (q15_t)0xA536, (q15_t)0xA5C4, + (q15_t)0xA57D, (q15_t)0xA57D, (q15_t)0xA5C4, (q15_t)0xA536, + (q15_t)0xA60C, (q15_t)0xA4EF, (q15_t)0xA653, (q15_t)0xA4A9, + (q15_t)0xA69B, (q15_t)0xA462, (q15_t)0xA6E3, (q15_t)0xA41C, + (q15_t)0xA72B, (q15_t)0xA3D6, (q15_t)0xA774, (q15_t)0xA391, + (q15_t)0xA7BD, (q15_t)0xA34B, (q15_t)0xA806, (q15_t)0xA306, + (q15_t)0xA84F, (q15_t)0xA2C1, (q15_t)0xA898, (q15_t)0xA27C, + (q15_t)0xA8E2, (q15_t)0xA238, (q15_t)0xA92B, (q15_t)0xA1F4, + (q15_t)0xA975, (q15_t)0xA1AF, (q15_t)0xA9BF, (q15_t)0xA16C, + (q15_t)0xAA0A, (q15_t)0xA128, (q15_t)0xAA54, (q15_t)0xA0E5, + (q15_t)0xAA9F, (q15_t)0xA0A1, (q15_t)0xAAEA, (q15_t)0xA05F, + (q15_t)0xAB35, (q15_t)0xA01C, (q15_t)0xAB81, (q15_t)0x9FD9, + (q15_t)0xABCC, (q15_t)0x9F97, (q15_t)0xAC18, (q15_t)0x9F55, + (q15_t)0xAC64, (q15_t)0x9F13, (q15_t)0xACB1, (q15_t)0x9ED2, + (q15_t)0xACFD, (q15_t)0x9E90, (q15_t)0xAD4A, (q15_t)0x9E4F, + (q15_t)0xAD96, (q15_t)0x9E0E, (q15_t)0xADE3, (q15_t)0x9DCE, + (q15_t)0xAE31, (q15_t)0x9D8E, (q15_t)0xAE7E, (q15_t)0x9D4D, + (q15_t)0xAECC, (q15_t)0x9D0D, (q15_t)0xAF1A, (q15_t)0x9CCE, + (q15_t)0xAF68, (q15_t)0x9C8E, (q15_t)0xAFB6, (q15_t)0x9C4F, + (q15_t)0xB004, (q15_t)0x9C10, (q15_t)0xB053, (q15_t)0x9BD2, + (q15_t)0xB0A1, (q15_t)0x9B93, (q15_t)0xB0F0, (q15_t)0x9B55, + (q15_t)0xB140, (q15_t)0x9B17, (q15_t)0xB18F, (q15_t)0x9AD9, + (q15_t)0xB1DE, (q15_t)0x9A9C, (q15_t)0xB22E, (q15_t)0x9A5F, + (q15_t)0xB27E, (q15_t)0x9A22, (q15_t)0xB2CE, (q15_t)0x99E5, + (q15_t)0xB31E, (q15_t)0x99A8, (q15_t)0xB36F, (q15_t)0x996C, + (q15_t)0xB3C0, (q15_t)0x9930, (q15_t)0xB410, (q15_t)0x98F4, + (q15_t)0xB461, (q15_t)0x98B9, (q15_t)0xB4B3, (q15_t)0x987D, + (q15_t)0xB504, (q15_t)0x9842, (q15_t)0xB556, (q15_t)0x9808, + (q15_t)0xB5A7, (q15_t)0x97CD, (q15_t)0xB5F9, (q15_t)0x9793, + (q15_t)0xB64B, (q15_t)0x9759, (q15_t)0xB69E, (q15_t)0x971F, + (q15_t)0xB6F0, (q15_t)0x96E6, (q15_t)0xB743, (q15_t)0x96AC, + (q15_t)0xB796, (q15_t)0x9673, (q15_t)0xB7E9, (q15_t)0x963B, + (q15_t)0xB83C, (q15_t)0x9602, (q15_t)0xB88F, (q15_t)0x95CA, + (q15_t)0xB8E3, (q15_t)0x9592, (q15_t)0xB936, (q15_t)0x955A, + (q15_t)0xB98A, (q15_t)0x9523, (q15_t)0xB9DE, (q15_t)0x94EC, + (q15_t)0xBA32, (q15_t)0x94B5, (q15_t)0xBA87, (q15_t)0x947E, + (q15_t)0xBADB, (q15_t)0x9447, (q15_t)0xBB30, (q15_t)0x9411, + (q15_t)0xBB85, (q15_t)0x93DB, (q15_t)0xBBDA, (q15_t)0x93A6, + (q15_t)0xBC2F, (q15_t)0x9370, (q15_t)0xBC84, (q15_t)0x933B, + (q15_t)0xBCDA, (q15_t)0x9306, (q15_t)0xBD2F, (q15_t)0x92D2, + (q15_t)0xBD85, (q15_t)0x929D, (q15_t)0xBDDB, (q15_t)0x9269, + (q15_t)0xBE31, (q15_t)0x9235, (q15_t)0xBE88, (q15_t)0x9202, + (q15_t)0xBEDE, (q15_t)0x91CF, (q15_t)0xBF35, (q15_t)0x919C, + (q15_t)0xBF8C, (q15_t)0x9169, (q15_t)0xBFE2, (q15_t)0x9136, + (q15_t)0xC03A, (q15_t)0x9104, (q15_t)0xC091, (q15_t)0x90D2, + (q15_t)0xC0E8, (q15_t)0x90A0, (q15_t)0xC140, (q15_t)0x906F, + (q15_t)0xC197, (q15_t)0x903E, (q15_t)0xC1EF, (q15_t)0x900D, + (q15_t)0xC247, (q15_t)0x8FDC, (q15_t)0xC29F, (q15_t)0x8FAC, + (q15_t)0xC2F8, (q15_t)0x8F7C, (q15_t)0xC350, (q15_t)0x8F4C, + (q15_t)0xC3A9, (q15_t)0x8F1D, (q15_t)0xC402, (q15_t)0x8EED, + (q15_t)0xC45A, (q15_t)0x8EBE, (q15_t)0xC4B3, (q15_t)0x8E90, + (q15_t)0xC50D, (q15_t)0x8E61, (q15_t)0xC566, (q15_t)0x8E33, + (q15_t)0xC5BF, (q15_t)0x8E05, (q15_t)0xC619, (q15_t)0x8DD8, + (q15_t)0xC673, (q15_t)0x8DAA, (q15_t)0xC6CD, (q15_t)0x8D7D, + (q15_t)0xC727, (q15_t)0x8D50, (q15_t)0xC781, (q15_t)0x8D24, + (q15_t)0xC7DB, (q15_t)0x8CF8, (q15_t)0xC835, (q15_t)0x8CCC, + (q15_t)0xC890, (q15_t)0x8CA0, (q15_t)0xC8EB, (q15_t)0x8C75, + (q15_t)0xC945, (q15_t)0x8C4A, (q15_t)0xC9A0, (q15_t)0x8C1F, + (q15_t)0xC9FB, (q15_t)0x8BF4, (q15_t)0xCA57, (q15_t)0x8BCA, + (q15_t)0xCAB2, (q15_t)0x8BA0, (q15_t)0xCB0D, (q15_t)0x8B76, + (q15_t)0xCB69, (q15_t)0x8B4D, (q15_t)0xCBC5, (q15_t)0x8B24, + (q15_t)0xCC21, (q15_t)0x8AFB, (q15_t)0xCC7D, (q15_t)0x8AD2, + (q15_t)0xCCD9, (q15_t)0x8AAA, (q15_t)0xCD35, (q15_t)0x8A82, + (q15_t)0xCD91, (q15_t)0x8A5A, (q15_t)0xCDEE, (q15_t)0x8A33, + (q15_t)0xCE4A, (q15_t)0x8A0B, (q15_t)0xCEA7, (q15_t)0x89E4, + (q15_t)0xCF04, (q15_t)0x89BE, (q15_t)0xCF61, (q15_t)0x8997, + (q15_t)0xCFBE, (q15_t)0x8971, (q15_t)0xD01B, (q15_t)0x894C, + (q15_t)0xD078, (q15_t)0x8926, (q15_t)0xD0D6, (q15_t)0x8901, + (q15_t)0xD133, (q15_t)0x88DC, (q15_t)0xD191, (q15_t)0x88B8, + (q15_t)0xD1EE, (q15_t)0x8893, (q15_t)0xD24C, (q15_t)0x886F, + (q15_t)0xD2AA, (q15_t)0x884B, (q15_t)0xD308, (q15_t)0x8828, + (q15_t)0xD367, (q15_t)0x8805, (q15_t)0xD3C5, (q15_t)0x87E2, + (q15_t)0xD423, (q15_t)0x87BF, (q15_t)0xD482, (q15_t)0x879D, + (q15_t)0xD4E0, (q15_t)0x877B, (q15_t)0xD53F, (q15_t)0x8759, + (q15_t)0xD59E, (q15_t)0x8738, (q15_t)0xD5FD, (q15_t)0x8717, + (q15_t)0xD65C, (q15_t)0x86F6, (q15_t)0xD6BB, (q15_t)0x86D5, + (q15_t)0xD71A, (q15_t)0x86B5, (q15_t)0xD779, (q15_t)0x8695, + (q15_t)0xD7D9, (q15_t)0x8675, (q15_t)0xD838, (q15_t)0x8656, + (q15_t)0xD898, (q15_t)0x8637, (q15_t)0xD8F8, (q15_t)0x8618, + (q15_t)0xD957, (q15_t)0x85FA, (q15_t)0xD9B7, (q15_t)0x85DB, + (q15_t)0xDA17, (q15_t)0x85BD, (q15_t)0xDA77, (q15_t)0x85A0, + (q15_t)0xDAD7, (q15_t)0x8582, (q15_t)0xDB38, (q15_t)0x8565, + (q15_t)0xDB98, (q15_t)0x8549, (q15_t)0xDBF8, (q15_t)0x852C, + (q15_t)0xDC59, (q15_t)0x8510, (q15_t)0xDCBA, (q15_t)0x84F4, + (q15_t)0xDD1A, (q15_t)0x84D9, (q15_t)0xDD7B, (q15_t)0x84BD, + (q15_t)0xDDDC, (q15_t)0x84A2, (q15_t)0xDE3D, (q15_t)0x8488, + (q15_t)0xDE9E, (q15_t)0x846D, (q15_t)0xDEFF, (q15_t)0x8453, + (q15_t)0xDF60, (q15_t)0x843A, (q15_t)0xDFC1, (q15_t)0x8420, + (q15_t)0xE023, (q15_t)0x8407, (q15_t)0xE084, (q15_t)0x83EE, + (q15_t)0xE0E6, (q15_t)0x83D6, (q15_t)0xE147, (q15_t)0x83BD, + (q15_t)0xE1A9, (q15_t)0x83A5, (q15_t)0xE20A, (q15_t)0x838E, + (q15_t)0xE26C, (q15_t)0x8376, (q15_t)0xE2CE, (q15_t)0x835F, + (q15_t)0xE330, (q15_t)0x8348, (q15_t)0xE392, (q15_t)0x8332, + (q15_t)0xE3F4, (q15_t)0x831C, (q15_t)0xE456, (q15_t)0x8306, + (q15_t)0xE4B8, (q15_t)0x82F0, (q15_t)0xE51B, (q15_t)0x82DB, + (q15_t)0xE57D, (q15_t)0x82C6, (q15_t)0xE5DF, (q15_t)0x82B1, + (q15_t)0xE642, (q15_t)0x829D, (q15_t)0xE6A4, (q15_t)0x8289, + (q15_t)0xE707, (q15_t)0x8275, (q15_t)0xE769, (q15_t)0x8262, + (q15_t)0xE7CC, (q15_t)0x824F, (q15_t)0xE82F, (q15_t)0x823C, + (q15_t)0xE892, (q15_t)0x8229, (q15_t)0xE8F5, (q15_t)0x8217, + (q15_t)0xE957, (q15_t)0x8205, (q15_t)0xE9BA, (q15_t)0x81F3, + (q15_t)0xEA1D, (q15_t)0x81E2, (q15_t)0xEA80, (q15_t)0x81D1, + (q15_t)0xEAE4, (q15_t)0x81C0, (q15_t)0xEB47, (q15_t)0x81B0, + (q15_t)0xEBAA, (q15_t)0x81A0, (q15_t)0xEC0D, (q15_t)0x8190, + (q15_t)0xEC71, (q15_t)0x8180, (q15_t)0xECD4, (q15_t)0x8171, + (q15_t)0xED37, (q15_t)0x8162, (q15_t)0xED9B, (q15_t)0x8154, + (q15_t)0xEDFE, (q15_t)0x8145, (q15_t)0xEE62, (q15_t)0x8137, + (q15_t)0xEEC6, (q15_t)0x812A, (q15_t)0xEF29, (q15_t)0x811C, + (q15_t)0xEF8D, (q15_t)0x810F, (q15_t)0xEFF1, (q15_t)0x8102, + (q15_t)0xF054, (q15_t)0x80F6, (q15_t)0xF0B8, (q15_t)0x80EA, + (q15_t)0xF11C, (q15_t)0x80DE, (q15_t)0xF180, (q15_t)0x80D2, + (q15_t)0xF1E4, (q15_t)0x80C7, (q15_t)0xF248, (q15_t)0x80BC, + (q15_t)0xF2AC, (q15_t)0x80B2, (q15_t)0xF310, (q15_t)0x80A7, + (q15_t)0xF374, (q15_t)0x809D, (q15_t)0xF3D8, (q15_t)0x8094, + (q15_t)0xF43C, (q15_t)0x808A, (q15_t)0xF4A0, (q15_t)0x8081, + (q15_t)0xF504, (q15_t)0x8078, (q15_t)0xF568, (q15_t)0x8070, + (q15_t)0xF5CC, (q15_t)0x8068, (q15_t)0xF631, (q15_t)0x8060, + (q15_t)0xF695, (q15_t)0x8058, (q15_t)0xF6F9, (q15_t)0x8051, + (q15_t)0xF75D, (q15_t)0x804A, (q15_t)0xF7C2, (q15_t)0x8043, + (q15_t)0xF826, (q15_t)0x803D, (q15_t)0xF88A, (q15_t)0x8037, + (q15_t)0xF8EF, (q15_t)0x8031, (q15_t)0xF953, (q15_t)0x802C, + (q15_t)0xF9B8, (q15_t)0x8027, (q15_t)0xFA1C, (q15_t)0x8022, + (q15_t)0xFA80, (q15_t)0x801E, (q15_t)0xFAE5, (q15_t)0x801A, + (q15_t)0xFB49, (q15_t)0x8016, (q15_t)0xFBAE, (q15_t)0x8012, + (q15_t)0xFC12, (q15_t)0x800F, (q15_t)0xFC77, (q15_t)0x800C, + (q15_t)0xFCDB, (q15_t)0x8009, (q15_t)0xFD40, (q15_t)0x8007, + (q15_t)0xFDA4, (q15_t)0x8005, (q15_t)0xFE09, (q15_t)0x8003, + (q15_t)0xFE6D, (q15_t)0x8002, (q15_t)0xFED2, (q15_t)0x8001, + (q15_t)0xFF36, (q15_t)0x8000, (q15_t)0xFF9B, (q15_t)0x8000 +}; + +/** +* \par +* Example code for q15 Twiddle factors Generation:: +* \par +*
for(i = 0; i< 3N/4; i++)
+* {
+*    twiddleCoefq15[2*i]= cos(i * 2*PI/(float)N);
+*    twiddleCoefq15[2*i+1]= sin(i * 2*PI/(float)N);
+* } 
+* \par +* where N = 4096 and PI = 3.14159265358979 +* \par +* Cos and Sin values are interleaved fashion +* \par +* Convert Floating point to q15(Fixed point 1.15): +* round(twiddleCoefq15(i) * pow(2, 15)) +* +*/ +const q15_t twiddleCoef_4096_q15[6144] = +{ + (q15_t)0x7FFF, (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0x0032, + (q15_t)0x7FFF, (q15_t)0x0064, (q15_t)0x7FFF, (q15_t)0x0096, + (q15_t)0x7FFF, (q15_t)0x00C9, (q15_t)0x7FFF, (q15_t)0x00FB, + (q15_t)0x7FFE, (q15_t)0x012D, (q15_t)0x7FFE, (q15_t)0x015F, + (q15_t)0x7FFD, (q15_t)0x0192, (q15_t)0x7FFC, (q15_t)0x01C4, + (q15_t)0x7FFC, (q15_t)0x01F6, (q15_t)0x7FFB, (q15_t)0x0228, + (q15_t)0x7FFA, (q15_t)0x025B, (q15_t)0x7FF9, (q15_t)0x028D, + (q15_t)0x7FF8, (q15_t)0x02BF, (q15_t)0x7FF7, (q15_t)0x02F1, + (q15_t)0x7FF6, (q15_t)0x0324, (q15_t)0x7FF4, (q15_t)0x0356, + (q15_t)0x7FF3, (q15_t)0x0388, (q15_t)0x7FF2, (q15_t)0x03BA, + (q15_t)0x7FF0, (q15_t)0x03ED, (q15_t)0x7FEE, (q15_t)0x041F, + (q15_t)0x7FED, (q15_t)0x0451, (q15_t)0x7FEB, (q15_t)0x0483, + (q15_t)0x7FE9, (q15_t)0x04B6, (q15_t)0x7FE7, (q15_t)0x04E8, + (q15_t)0x7FE5, (q15_t)0x051A, (q15_t)0x7FE3, (q15_t)0x054C, + (q15_t)0x7FE1, (q15_t)0x057F, (q15_t)0x7FDF, (q15_t)0x05B1, + (q15_t)0x7FDD, (q15_t)0x05E3, (q15_t)0x7FDA, (q15_t)0x0615, + (q15_t)0x7FD8, (q15_t)0x0647, (q15_t)0x7FD6, (q15_t)0x067A, + (q15_t)0x7FD3, (q15_t)0x06AC, (q15_t)0x7FD0, (q15_t)0x06DE, + (q15_t)0x7FCE, (q15_t)0x0710, (q15_t)0x7FCB, (q15_t)0x0742, + (q15_t)0x7FC8, (q15_t)0x0775, (q15_t)0x7FC5, (q15_t)0x07A7, + (q15_t)0x7FC2, (q15_t)0x07D9, (q15_t)0x7FBF, (q15_t)0x080B, + (q15_t)0x7FBC, (q15_t)0x083D, (q15_t)0x7FB8, (q15_t)0x086F, + (q15_t)0x7FB5, (q15_t)0x08A2, (q15_t)0x7FB1, (q15_t)0x08D4, + (q15_t)0x7FAE, (q15_t)0x0906, (q15_t)0x7FAA, (q15_t)0x0938, + (q15_t)0x7FA7, (q15_t)0x096A, (q15_t)0x7FA3, (q15_t)0x099C, + (q15_t)0x7F9F, (q15_t)0x09CE, (q15_t)0x7F9B, (q15_t)0x0A00, + (q15_t)0x7F97, (q15_t)0x0A33, (q15_t)0x7F93, (q15_t)0x0A65, + (q15_t)0x7F8F, (q15_t)0x0A97, (q15_t)0x7F8B, (q15_t)0x0AC9, + (q15_t)0x7F87, (q15_t)0x0AFB, (q15_t)0x7F82, (q15_t)0x0B2D, + (q15_t)0x7F7E, (q15_t)0x0B5F, (q15_t)0x7F79, (q15_t)0x0B91, + (q15_t)0x7F75, (q15_t)0x0BC3, (q15_t)0x7F70, (q15_t)0x0BF5, + (q15_t)0x7F6B, (q15_t)0x0C27, (q15_t)0x7F67, (q15_t)0x0C59, + (q15_t)0x7F62, (q15_t)0x0C8B, (q15_t)0x7F5D, (q15_t)0x0CBD, + (q15_t)0x7F58, (q15_t)0x0CEF, (q15_t)0x7F53, (q15_t)0x0D21, + (q15_t)0x7F4D, (q15_t)0x0D53, (q15_t)0x7F48, (q15_t)0x0D85, + (q15_t)0x7F43, (q15_t)0x0DB7, (q15_t)0x7F3D, (q15_t)0x0DE9, + (q15_t)0x7F38, (q15_t)0x0E1B, (q15_t)0x7F32, (q15_t)0x0E4D, + (q15_t)0x7F2D, (q15_t)0x0E7F, (q15_t)0x7F27, (q15_t)0x0EB1, + (q15_t)0x7F21, (q15_t)0x0EE3, (q15_t)0x7F1B, (q15_t)0x0F15, + (q15_t)0x7F15, (q15_t)0x0F47, (q15_t)0x7F0F, (q15_t)0x0F79, + (q15_t)0x7F09, (q15_t)0x0FAB, (q15_t)0x7F03, (q15_t)0x0FDD, + (q15_t)0x7EFD, (q15_t)0x100E, (q15_t)0x7EF6, (q15_t)0x1040, + (q15_t)0x7EF0, (q15_t)0x1072, (q15_t)0x7EE9, (q15_t)0x10A4, + (q15_t)0x7EE3, (q15_t)0x10D6, (q15_t)0x7EDC, (q15_t)0x1108, + (q15_t)0x7ED5, (q15_t)0x1139, (q15_t)0x7ECF, (q15_t)0x116B, + (q15_t)0x7EC8, (q15_t)0x119D, (q15_t)0x7EC1, (q15_t)0x11CF, + (q15_t)0x7EBA, (q15_t)0x1201, (q15_t)0x7EB3, (q15_t)0x1232, + (q15_t)0x7EAB, (q15_t)0x1264, (q15_t)0x7EA4, (q15_t)0x1296, + (q15_t)0x7E9D, (q15_t)0x12C8, (q15_t)0x7E95, (q15_t)0x12F9, + (q15_t)0x7E8E, (q15_t)0x132B, (q15_t)0x7E86, (q15_t)0x135D, + (q15_t)0x7E7F, (q15_t)0x138E, (q15_t)0x7E77, (q15_t)0x13C0, + (q15_t)0x7E6F, (q15_t)0x13F2, (q15_t)0x7E67, (q15_t)0x1423, + (q15_t)0x7E5F, (q15_t)0x1455, (q15_t)0x7E57, (q15_t)0x1487, + (q15_t)0x7E4F, (q15_t)0x14B8, (q15_t)0x7E47, (q15_t)0x14EA, + (q15_t)0x7E3F, (q15_t)0x151B, (q15_t)0x7E37, (q15_t)0x154D, + (q15_t)0x7E2E, (q15_t)0x157F, (q15_t)0x7E26, (q15_t)0x15B0, + (q15_t)0x7E1D, (q15_t)0x15E2, (q15_t)0x7E14, (q15_t)0x1613, + (q15_t)0x7E0C, (q15_t)0x1645, (q15_t)0x7E03, (q15_t)0x1676, + (q15_t)0x7DFA, (q15_t)0x16A8, (q15_t)0x7DF1, (q15_t)0x16D9, + (q15_t)0x7DE8, (q15_t)0x170A, (q15_t)0x7DDF, (q15_t)0x173C, + (q15_t)0x7DD6, (q15_t)0x176D, (q15_t)0x7DCD, (q15_t)0x179F, + (q15_t)0x7DC3, (q15_t)0x17D0, (q15_t)0x7DBA, (q15_t)0x1802, + (q15_t)0x7DB0, (q15_t)0x1833, (q15_t)0x7DA7, (q15_t)0x1864, + (q15_t)0x7D9D, (q15_t)0x1896, (q15_t)0x7D94, (q15_t)0x18C7, + (q15_t)0x7D8A, (q15_t)0x18F8, (q15_t)0x7D80, (q15_t)0x192A, + (q15_t)0x7D76, (q15_t)0x195B, (q15_t)0x7D6C, (q15_t)0x198C, + (q15_t)0x7D62, (q15_t)0x19BD, (q15_t)0x7D58, (q15_t)0x19EF, + (q15_t)0x7D4E, (q15_t)0x1A20, (q15_t)0x7D43, (q15_t)0x1A51, + (q15_t)0x7D39, (q15_t)0x1A82, (q15_t)0x7D2F, (q15_t)0x1AB3, + (q15_t)0x7D24, (q15_t)0x1AE4, (q15_t)0x7D19, (q15_t)0x1B16, + (q15_t)0x7D0F, (q15_t)0x1B47, (q15_t)0x7D04, (q15_t)0x1B78, + (q15_t)0x7CF9, (q15_t)0x1BA9, (q15_t)0x7CEE, (q15_t)0x1BDA, + (q15_t)0x7CE3, (q15_t)0x1C0B, (q15_t)0x7CD8, (q15_t)0x1C3C, + (q15_t)0x7CCD, (q15_t)0x1C6D, (q15_t)0x7CC2, (q15_t)0x1C9E, + (q15_t)0x7CB7, (q15_t)0x1CCF, (q15_t)0x7CAB, (q15_t)0x1D00, + (q15_t)0x7CA0, (q15_t)0x1D31, (q15_t)0x7C94, (q15_t)0x1D62, + (q15_t)0x7C89, (q15_t)0x1D93, (q15_t)0x7C7D, (q15_t)0x1DC4, + (q15_t)0x7C71, (q15_t)0x1DF5, (q15_t)0x7C66, (q15_t)0x1E25, + (q15_t)0x7C5A, (q15_t)0x1E56, (q15_t)0x7C4E, (q15_t)0x1E87, + (q15_t)0x7C42, (q15_t)0x1EB8, (q15_t)0x7C36, (q15_t)0x1EE9, + (q15_t)0x7C29, (q15_t)0x1F19, (q15_t)0x7C1D, (q15_t)0x1F4A, + (q15_t)0x7C11, (q15_t)0x1F7B, (q15_t)0x7C05, (q15_t)0x1FAC, + (q15_t)0x7BF8, (q15_t)0x1FDC, (q15_t)0x7BEB, (q15_t)0x200D, + (q15_t)0x7BDF, (q15_t)0x203E, (q15_t)0x7BD2, (q15_t)0x206E, + (q15_t)0x7BC5, (q15_t)0x209F, (q15_t)0x7BB9, (q15_t)0x20D0, + (q15_t)0x7BAC, (q15_t)0x2100, (q15_t)0x7B9F, (q15_t)0x2131, + (q15_t)0x7B92, (q15_t)0x2161, (q15_t)0x7B84, (q15_t)0x2192, + (q15_t)0x7B77, (q15_t)0x21C2, (q15_t)0x7B6A, (q15_t)0x21F3, + (q15_t)0x7B5D, (q15_t)0x2223, (q15_t)0x7B4F, (q15_t)0x2254, + (q15_t)0x7B42, (q15_t)0x2284, (q15_t)0x7B34, (q15_t)0x22B4, + (q15_t)0x7B26, (q15_t)0x22E5, (q15_t)0x7B19, (q15_t)0x2315, + (q15_t)0x7B0B, (q15_t)0x2345, (q15_t)0x7AFD, (q15_t)0x2376, + (q15_t)0x7AEF, (q15_t)0x23A6, (q15_t)0x7AE1, (q15_t)0x23D6, + (q15_t)0x7AD3, (q15_t)0x2407, (q15_t)0x7AC5, (q15_t)0x2437, + (q15_t)0x7AB6, (q15_t)0x2467, (q15_t)0x7AA8, (q15_t)0x2497, + (q15_t)0x7A9A, (q15_t)0x24C7, (q15_t)0x7A8B, (q15_t)0x24F7, + (q15_t)0x7A7D, (q15_t)0x2528, (q15_t)0x7A6E, (q15_t)0x2558, + (q15_t)0x7A5F, (q15_t)0x2588, (q15_t)0x7A50, (q15_t)0x25B8, + (q15_t)0x7A42, (q15_t)0x25E8, (q15_t)0x7A33, (q15_t)0x2618, + (q15_t)0x7A24, (q15_t)0x2648, (q15_t)0x7A15, (q15_t)0x2678, + (q15_t)0x7A05, (q15_t)0x26A8, (q15_t)0x79F6, (q15_t)0x26D8, + (q15_t)0x79E7, (q15_t)0x2707, (q15_t)0x79D8, (q15_t)0x2737, + (q15_t)0x79C8, (q15_t)0x2767, (q15_t)0x79B9, (q15_t)0x2797, + (q15_t)0x79A9, (q15_t)0x27C7, (q15_t)0x7999, (q15_t)0x27F6, + (q15_t)0x798A, (q15_t)0x2826, (q15_t)0x797A, (q15_t)0x2856, + (q15_t)0x796A, (q15_t)0x2886, (q15_t)0x795A, (q15_t)0x28B5, + (q15_t)0x794A, (q15_t)0x28E5, (q15_t)0x793A, (q15_t)0x2915, + (q15_t)0x792A, (q15_t)0x2944, (q15_t)0x7919, (q15_t)0x2974, + (q15_t)0x7909, (q15_t)0x29A3, (q15_t)0x78F9, (q15_t)0x29D3, + (q15_t)0x78E8, (q15_t)0x2A02, (q15_t)0x78D8, (q15_t)0x2A32, + (q15_t)0x78C7, (q15_t)0x2A61, (q15_t)0x78B6, (q15_t)0x2A91, + (q15_t)0x78A6, (q15_t)0x2AC0, (q15_t)0x7895, (q15_t)0x2AEF, + (q15_t)0x7884, (q15_t)0x2B1F, (q15_t)0x7873, (q15_t)0x2B4E, + (q15_t)0x7862, (q15_t)0x2B7D, (q15_t)0x7851, (q15_t)0x2BAD, + (q15_t)0x7840, (q15_t)0x2BDC, (q15_t)0x782E, (q15_t)0x2C0B, + (q15_t)0x781D, (q15_t)0x2C3A, (q15_t)0x780C, (q15_t)0x2C69, + (q15_t)0x77FA, (q15_t)0x2C98, (q15_t)0x77E9, (q15_t)0x2CC8, + (q15_t)0x77D7, (q15_t)0x2CF7, (q15_t)0x77C5, (q15_t)0x2D26, + (q15_t)0x77B4, (q15_t)0x2D55, (q15_t)0x77A2, (q15_t)0x2D84, + (q15_t)0x7790, (q15_t)0x2DB3, (q15_t)0x777E, (q15_t)0x2DE2, + (q15_t)0x776C, (q15_t)0x2E11, (q15_t)0x775A, (q15_t)0x2E3F, + (q15_t)0x7747, (q15_t)0x2E6E, (q15_t)0x7735, (q15_t)0x2E9D, + (q15_t)0x7723, (q15_t)0x2ECC, (q15_t)0x7710, (q15_t)0x2EFB, + (q15_t)0x76FE, (q15_t)0x2F29, (q15_t)0x76EB, (q15_t)0x2F58, + (q15_t)0x76D9, (q15_t)0x2F87, (q15_t)0x76C6, (q15_t)0x2FB5, + (q15_t)0x76B3, (q15_t)0x2FE4, (q15_t)0x76A0, (q15_t)0x3013, + (q15_t)0x768E, (q15_t)0x3041, (q15_t)0x767B, (q15_t)0x3070, + (q15_t)0x7668, (q15_t)0x309E, (q15_t)0x7654, (q15_t)0x30CD, + (q15_t)0x7641, (q15_t)0x30FB, (q15_t)0x762E, (q15_t)0x312A, + (q15_t)0x761B, (q15_t)0x3158, (q15_t)0x7607, (q15_t)0x3186, + (q15_t)0x75F4, (q15_t)0x31B5, (q15_t)0x75E0, (q15_t)0x31E3, + (q15_t)0x75CC, (q15_t)0x3211, (q15_t)0x75B9, (q15_t)0x3240, + (q15_t)0x75A5, (q15_t)0x326E, (q15_t)0x7591, (q15_t)0x329C, + (q15_t)0x757D, (q15_t)0x32CA, (q15_t)0x7569, (q15_t)0x32F8, + (q15_t)0x7555, (q15_t)0x3326, (q15_t)0x7541, (q15_t)0x3354, + (q15_t)0x752D, (q15_t)0x3382, (q15_t)0x7519, (q15_t)0x33B0, + (q15_t)0x7504, (q15_t)0x33DE, (q15_t)0x74F0, (q15_t)0x340C, + (q15_t)0x74DB, (q15_t)0x343A, (q15_t)0x74C7, (q15_t)0x3468, + (q15_t)0x74B2, (q15_t)0x3496, (q15_t)0x749E, (q15_t)0x34C4, + (q15_t)0x7489, (q15_t)0x34F2, (q15_t)0x7474, (q15_t)0x351F, + (q15_t)0x745F, (q15_t)0x354D, (q15_t)0x744A, (q15_t)0x357B, + (q15_t)0x7435, (q15_t)0x35A8, (q15_t)0x7420, (q15_t)0x35D6, + (q15_t)0x740B, (q15_t)0x3604, (q15_t)0x73F6, (q15_t)0x3631, + (q15_t)0x73E0, (q15_t)0x365F, (q15_t)0x73CB, (q15_t)0x368C, + (q15_t)0x73B5, (q15_t)0x36BA, (q15_t)0x73A0, (q15_t)0x36E7, + (q15_t)0x738A, (q15_t)0x3714, (q15_t)0x7375, (q15_t)0x3742, + (q15_t)0x735F, (q15_t)0x376F, (q15_t)0x7349, (q15_t)0x379C, + (q15_t)0x7333, (q15_t)0x37CA, (q15_t)0x731D, (q15_t)0x37F7, + (q15_t)0x7307, (q15_t)0x3824, (q15_t)0x72F1, (q15_t)0x3851, + (q15_t)0x72DB, (q15_t)0x387E, (q15_t)0x72C5, (q15_t)0x38AB, + (q15_t)0x72AF, (q15_t)0x38D8, (q15_t)0x7298, (q15_t)0x3906, + (q15_t)0x7282, (q15_t)0x3932, (q15_t)0x726B, (q15_t)0x395F, + (q15_t)0x7255, (q15_t)0x398C, (q15_t)0x723E, (q15_t)0x39B9, + (q15_t)0x7227, (q15_t)0x39E6, (q15_t)0x7211, (q15_t)0x3A13, + (q15_t)0x71FA, (q15_t)0x3A40, (q15_t)0x71E3, (q15_t)0x3A6C, + (q15_t)0x71CC, (q15_t)0x3A99, (q15_t)0x71B5, (q15_t)0x3AC6, + (q15_t)0x719E, (q15_t)0x3AF2, (q15_t)0x7186, (q15_t)0x3B1F, + (q15_t)0x716F, (q15_t)0x3B4C, (q15_t)0x7158, (q15_t)0x3B78, + (q15_t)0x7141, (q15_t)0x3BA5, (q15_t)0x7129, (q15_t)0x3BD1, + (q15_t)0x7112, (q15_t)0x3BFD, (q15_t)0x70FA, (q15_t)0x3C2A, + (q15_t)0x70E2, (q15_t)0x3C56, (q15_t)0x70CB, (q15_t)0x3C83, + (q15_t)0x70B3, (q15_t)0x3CAF, (q15_t)0x709B, (q15_t)0x3CDB, + (q15_t)0x7083, (q15_t)0x3D07, (q15_t)0x706B, (q15_t)0x3D33, + (q15_t)0x7053, (q15_t)0x3D60, (q15_t)0x703B, (q15_t)0x3D8C, + (q15_t)0x7023, (q15_t)0x3DB8, (q15_t)0x700A, (q15_t)0x3DE4, + (q15_t)0x6FF2, (q15_t)0x3E10, (q15_t)0x6FDA, (q15_t)0x3E3C, + (q15_t)0x6FC1, (q15_t)0x3E68, (q15_t)0x6FA9, (q15_t)0x3E93, + (q15_t)0x6F90, (q15_t)0x3EBF, (q15_t)0x6F77, (q15_t)0x3EEB, + (q15_t)0x6F5F, (q15_t)0x3F17, (q15_t)0x6F46, (q15_t)0x3F43, + (q15_t)0x6F2D, (q15_t)0x3F6E, (q15_t)0x6F14, (q15_t)0x3F9A, + (q15_t)0x6EFB, (q15_t)0x3FC5, (q15_t)0x6EE2, (q15_t)0x3FF1, + (q15_t)0x6EC9, (q15_t)0x401D, (q15_t)0x6EAF, (q15_t)0x4048, + (q15_t)0x6E96, (q15_t)0x4073, (q15_t)0x6E7D, (q15_t)0x409F, + (q15_t)0x6E63, (q15_t)0x40CA, (q15_t)0x6E4A, (q15_t)0x40F6, + (q15_t)0x6E30, (q15_t)0x4121, (q15_t)0x6E17, (q15_t)0x414C, + (q15_t)0x6DFD, (q15_t)0x4177, (q15_t)0x6DE3, (q15_t)0x41A2, + (q15_t)0x6DCA, (q15_t)0x41CE, (q15_t)0x6DB0, (q15_t)0x41F9, + (q15_t)0x6D96, (q15_t)0x4224, (q15_t)0x6D7C, (q15_t)0x424F, + (q15_t)0x6D62, (q15_t)0x427A, (q15_t)0x6D48, (q15_t)0x42A5, + (q15_t)0x6D2D, (q15_t)0x42D0, (q15_t)0x6D13, (q15_t)0x42FA, + (q15_t)0x6CF9, (q15_t)0x4325, (q15_t)0x6CDE, (q15_t)0x4350, + (q15_t)0x6CC4, (q15_t)0x437B, (q15_t)0x6CA9, (q15_t)0x43A5, + (q15_t)0x6C8F, (q15_t)0x43D0, (q15_t)0x6C74, (q15_t)0x43FB, + (q15_t)0x6C59, (q15_t)0x4425, (q15_t)0x6C3F, (q15_t)0x4450, + (q15_t)0x6C24, (q15_t)0x447A, (q15_t)0x6C09, (q15_t)0x44A5, + (q15_t)0x6BEE, (q15_t)0x44CF, (q15_t)0x6BD3, (q15_t)0x44FA, + (q15_t)0x6BB8, (q15_t)0x4524, (q15_t)0x6B9C, (q15_t)0x454E, + (q15_t)0x6B81, (q15_t)0x4578, (q15_t)0x6B66, (q15_t)0x45A3, + (q15_t)0x6B4A, (q15_t)0x45CD, (q15_t)0x6B2F, (q15_t)0x45F7, + (q15_t)0x6B13, (q15_t)0x4621, (q15_t)0x6AF8, (q15_t)0x464B, + (q15_t)0x6ADC, (q15_t)0x4675, (q15_t)0x6AC1, (q15_t)0x469F, + (q15_t)0x6AA5, (q15_t)0x46C9, (q15_t)0x6A89, (q15_t)0x46F3, + (q15_t)0x6A6D, (q15_t)0x471C, (q15_t)0x6A51, (q15_t)0x4746, + (q15_t)0x6A35, (q15_t)0x4770, (q15_t)0x6A19, (q15_t)0x479A, + (q15_t)0x69FD, (q15_t)0x47C3, (q15_t)0x69E1, (q15_t)0x47ED, + (q15_t)0x69C4, (q15_t)0x4816, (q15_t)0x69A8, (q15_t)0x4840, + (q15_t)0x698C, (q15_t)0x4869, (q15_t)0x696F, (q15_t)0x4893, + (q15_t)0x6953, (q15_t)0x48BC, (q15_t)0x6936, (q15_t)0x48E6, + (q15_t)0x6919, (q15_t)0x490F, (q15_t)0x68FD, (q15_t)0x4938, + (q15_t)0x68E0, (q15_t)0x4961, (q15_t)0x68C3, (q15_t)0x498A, + (q15_t)0x68A6, (q15_t)0x49B4, (q15_t)0x6889, (q15_t)0x49DD, + (q15_t)0x686C, (q15_t)0x4A06, (q15_t)0x684F, (q15_t)0x4A2F, + (q15_t)0x6832, (q15_t)0x4A58, (q15_t)0x6815, (q15_t)0x4A81, + (q15_t)0x67F7, (q15_t)0x4AA9, (q15_t)0x67DA, (q15_t)0x4AD2, + (q15_t)0x67BD, (q15_t)0x4AFB, (q15_t)0x679F, (q15_t)0x4B24, + (q15_t)0x6782, (q15_t)0x4B4C, (q15_t)0x6764, (q15_t)0x4B75, + (q15_t)0x6746, (q15_t)0x4B9E, (q15_t)0x6729, (q15_t)0x4BC6, + (q15_t)0x670B, (q15_t)0x4BEF, (q15_t)0x66ED, (q15_t)0x4C17, + (q15_t)0x66CF, (q15_t)0x4C3F, (q15_t)0x66B1, (q15_t)0x4C68, + (q15_t)0x6693, (q15_t)0x4C90, (q15_t)0x6675, (q15_t)0x4CB8, + (q15_t)0x6657, (q15_t)0x4CE1, (q15_t)0x6639, (q15_t)0x4D09, + (q15_t)0x661A, (q15_t)0x4D31, (q15_t)0x65FC, (q15_t)0x4D59, + (q15_t)0x65DD, (q15_t)0x4D81, (q15_t)0x65BF, (q15_t)0x4DA9, + (q15_t)0x65A0, (q15_t)0x4DD1, (q15_t)0x6582, (q15_t)0x4DF9, + (q15_t)0x6563, (q15_t)0x4E21, (q15_t)0x6545, (q15_t)0x4E48, + (q15_t)0x6526, (q15_t)0x4E70, (q15_t)0x6507, (q15_t)0x4E98, + (q15_t)0x64E8, (q15_t)0x4EBF, (q15_t)0x64C9, (q15_t)0x4EE7, + (q15_t)0x64AA, (q15_t)0x4F0F, (q15_t)0x648B, (q15_t)0x4F36, + (q15_t)0x646C, (q15_t)0x4F5E, (q15_t)0x644D, (q15_t)0x4F85, + (q15_t)0x642D, (q15_t)0x4FAC, (q15_t)0x640E, (q15_t)0x4FD4, + (q15_t)0x63EF, (q15_t)0x4FFB, (q15_t)0x63CF, (q15_t)0x5022, + (q15_t)0x63B0, (q15_t)0x5049, (q15_t)0x6390, (q15_t)0x5070, + (q15_t)0x6371, (q15_t)0x5097, (q15_t)0x6351, (q15_t)0x50BF, + (q15_t)0x6331, (q15_t)0x50E5, (q15_t)0x6311, (q15_t)0x510C, + (q15_t)0x62F2, (q15_t)0x5133, (q15_t)0x62D2, (q15_t)0x515A, + (q15_t)0x62B2, (q15_t)0x5181, (q15_t)0x6292, (q15_t)0x51A8, + (q15_t)0x6271, (q15_t)0x51CE, (q15_t)0x6251, (q15_t)0x51F5, + (q15_t)0x6231, (q15_t)0x521C, (q15_t)0x6211, (q15_t)0x5242, + (q15_t)0x61F1, (q15_t)0x5269, (q15_t)0x61D0, (q15_t)0x528F, + (q15_t)0x61B0, (q15_t)0x52B5, (q15_t)0x618F, (q15_t)0x52DC, + (q15_t)0x616F, (q15_t)0x5302, (q15_t)0x614E, (q15_t)0x5328, + (q15_t)0x612D, (q15_t)0x534E, (q15_t)0x610D, (q15_t)0x5375, + (q15_t)0x60EC, (q15_t)0x539B, (q15_t)0x60CB, (q15_t)0x53C1, + (q15_t)0x60AA, (q15_t)0x53E7, (q15_t)0x6089, (q15_t)0x540D, + (q15_t)0x6068, (q15_t)0x5433, (q15_t)0x6047, (q15_t)0x5458, + (q15_t)0x6026, (q15_t)0x547E, (q15_t)0x6004, (q15_t)0x54A4, + (q15_t)0x5FE3, (q15_t)0x54CA, (q15_t)0x5FC2, (q15_t)0x54EF, + (q15_t)0x5FA0, (q15_t)0x5515, (q15_t)0x5F7F, (q15_t)0x553A, + (q15_t)0x5F5E, (q15_t)0x5560, (q15_t)0x5F3C, (q15_t)0x5585, + (q15_t)0x5F1A, (q15_t)0x55AB, (q15_t)0x5EF9, (q15_t)0x55D0, + (q15_t)0x5ED7, (q15_t)0x55F5, (q15_t)0x5EB5, (q15_t)0x561A, + (q15_t)0x5E93, (q15_t)0x5640, (q15_t)0x5E71, (q15_t)0x5665, + (q15_t)0x5E50, (q15_t)0x568A, (q15_t)0x5E2D, (q15_t)0x56AF, + (q15_t)0x5E0B, (q15_t)0x56D4, (q15_t)0x5DE9, (q15_t)0x56F9, + (q15_t)0x5DC7, (q15_t)0x571D, (q15_t)0x5DA5, (q15_t)0x5742, + (q15_t)0x5D83, (q15_t)0x5767, (q15_t)0x5D60, (q15_t)0x578C, + (q15_t)0x5D3E, (q15_t)0x57B0, (q15_t)0x5D1B, (q15_t)0x57D5, + (q15_t)0x5CF9, (q15_t)0x57F9, (q15_t)0x5CD6, (q15_t)0x581E, + (q15_t)0x5CB4, (q15_t)0x5842, (q15_t)0x5C91, (q15_t)0x5867, + (q15_t)0x5C6E, (q15_t)0x588B, (q15_t)0x5C4B, (q15_t)0x58AF, + (q15_t)0x5C29, (q15_t)0x58D4, (q15_t)0x5C06, (q15_t)0x58F8, + (q15_t)0x5BE3, (q15_t)0x591C, (q15_t)0x5BC0, (q15_t)0x5940, + (q15_t)0x5B9D, (q15_t)0x5964, (q15_t)0x5B79, (q15_t)0x5988, + (q15_t)0x5B56, (q15_t)0x59AC, (q15_t)0x5B33, (q15_t)0x59D0, + (q15_t)0x5B10, (q15_t)0x59F3, (q15_t)0x5AEC, (q15_t)0x5A17, + (q15_t)0x5AC9, (q15_t)0x5A3B, (q15_t)0x5AA5, (q15_t)0x5A5E, + (q15_t)0x5A82, (q15_t)0x5A82, (q15_t)0x5A5E, (q15_t)0x5AA5, + (q15_t)0x5A3B, (q15_t)0x5AC9, (q15_t)0x5A17, (q15_t)0x5AEC, + (q15_t)0x59F3, (q15_t)0x5B10, (q15_t)0x59D0, (q15_t)0x5B33, + (q15_t)0x59AC, (q15_t)0x5B56, (q15_t)0x5988, (q15_t)0x5B79, + (q15_t)0x5964, (q15_t)0x5B9D, (q15_t)0x5940, (q15_t)0x5BC0, + (q15_t)0x591C, (q15_t)0x5BE3, (q15_t)0x58F8, (q15_t)0x5C06, + (q15_t)0x58D4, (q15_t)0x5C29, (q15_t)0x58AF, (q15_t)0x5C4B, + (q15_t)0x588B, (q15_t)0x5C6E, (q15_t)0x5867, (q15_t)0x5C91, + (q15_t)0x5842, (q15_t)0x5CB4, (q15_t)0x581E, (q15_t)0x5CD6, + (q15_t)0x57F9, (q15_t)0x5CF9, (q15_t)0x57D5, (q15_t)0x5D1B, + (q15_t)0x57B0, (q15_t)0x5D3E, (q15_t)0x578C, (q15_t)0x5D60, + (q15_t)0x5767, (q15_t)0x5D83, (q15_t)0x5742, (q15_t)0x5DA5, + (q15_t)0x571D, (q15_t)0x5DC7, (q15_t)0x56F9, (q15_t)0x5DE9, + (q15_t)0x56D4, (q15_t)0x5E0B, (q15_t)0x56AF, (q15_t)0x5E2D, + (q15_t)0x568A, (q15_t)0x5E50, (q15_t)0x5665, (q15_t)0x5E71, + (q15_t)0x5640, (q15_t)0x5E93, (q15_t)0x561A, (q15_t)0x5EB5, + (q15_t)0x55F5, (q15_t)0x5ED7, (q15_t)0x55D0, (q15_t)0x5EF9, + (q15_t)0x55AB, (q15_t)0x5F1A, (q15_t)0x5585, (q15_t)0x5F3C, + (q15_t)0x5560, (q15_t)0x5F5E, (q15_t)0x553A, (q15_t)0x5F7F, + (q15_t)0x5515, (q15_t)0x5FA0, (q15_t)0x54EF, (q15_t)0x5FC2, + (q15_t)0x54CA, (q15_t)0x5FE3, (q15_t)0x54A4, (q15_t)0x6004, + (q15_t)0x547E, (q15_t)0x6026, (q15_t)0x5458, (q15_t)0x6047, + (q15_t)0x5433, (q15_t)0x6068, (q15_t)0x540D, (q15_t)0x6089, + (q15_t)0x53E7, (q15_t)0x60AA, (q15_t)0x53C1, (q15_t)0x60CB, + (q15_t)0x539B, (q15_t)0x60EC, (q15_t)0x5375, (q15_t)0x610D, + (q15_t)0x534E, (q15_t)0x612D, (q15_t)0x5328, (q15_t)0x614E, + (q15_t)0x5302, (q15_t)0x616F, (q15_t)0x52DC, (q15_t)0x618F, + (q15_t)0x52B5, (q15_t)0x61B0, (q15_t)0x528F, (q15_t)0x61D0, + (q15_t)0x5269, (q15_t)0x61F1, (q15_t)0x5242, (q15_t)0x6211, + (q15_t)0x521C, (q15_t)0x6231, (q15_t)0x51F5, (q15_t)0x6251, + (q15_t)0x51CE, (q15_t)0x6271, (q15_t)0x51A8, (q15_t)0x6292, + (q15_t)0x5181, (q15_t)0x62B2, (q15_t)0x515A, (q15_t)0x62D2, + (q15_t)0x5133, (q15_t)0x62F2, (q15_t)0x510C, (q15_t)0x6311, + (q15_t)0x50E5, (q15_t)0x6331, (q15_t)0x50BF, (q15_t)0x6351, + (q15_t)0x5097, (q15_t)0x6371, (q15_t)0x5070, (q15_t)0x6390, + (q15_t)0x5049, (q15_t)0x63B0, (q15_t)0x5022, (q15_t)0x63CF, + (q15_t)0x4FFB, (q15_t)0x63EF, (q15_t)0x4FD4, (q15_t)0x640E, + (q15_t)0x4FAC, (q15_t)0x642D, (q15_t)0x4F85, (q15_t)0x644D, + (q15_t)0x4F5E, (q15_t)0x646C, (q15_t)0x4F36, (q15_t)0x648B, + (q15_t)0x4F0F, (q15_t)0x64AA, (q15_t)0x4EE7, (q15_t)0x64C9, + (q15_t)0x4EBF, (q15_t)0x64E8, (q15_t)0x4E98, (q15_t)0x6507, + (q15_t)0x4E70, (q15_t)0x6526, (q15_t)0x4E48, (q15_t)0x6545, + (q15_t)0x4E21, (q15_t)0x6563, (q15_t)0x4DF9, (q15_t)0x6582, + (q15_t)0x4DD1, (q15_t)0x65A0, (q15_t)0x4DA9, (q15_t)0x65BF, + (q15_t)0x4D81, (q15_t)0x65DD, (q15_t)0x4D59, (q15_t)0x65FC, + (q15_t)0x4D31, (q15_t)0x661A, (q15_t)0x4D09, (q15_t)0x6639, + (q15_t)0x4CE1, (q15_t)0x6657, (q15_t)0x4CB8, (q15_t)0x6675, + (q15_t)0x4C90, (q15_t)0x6693, (q15_t)0x4C68, (q15_t)0x66B1, + (q15_t)0x4C3F, (q15_t)0x66CF, (q15_t)0x4C17, (q15_t)0x66ED, + (q15_t)0x4BEF, (q15_t)0x670B, (q15_t)0x4BC6, (q15_t)0x6729, + (q15_t)0x4B9E, (q15_t)0x6746, (q15_t)0x4B75, (q15_t)0x6764, + (q15_t)0x4B4C, (q15_t)0x6782, (q15_t)0x4B24, (q15_t)0x679F, + (q15_t)0x4AFB, (q15_t)0x67BD, (q15_t)0x4AD2, (q15_t)0x67DA, + (q15_t)0x4AA9, (q15_t)0x67F7, (q15_t)0x4A81, (q15_t)0x6815, + (q15_t)0x4A58, (q15_t)0x6832, (q15_t)0x4A2F, (q15_t)0x684F, + (q15_t)0x4A06, (q15_t)0x686C, (q15_t)0x49DD, (q15_t)0x6889, + (q15_t)0x49B4, (q15_t)0x68A6, (q15_t)0x498A, (q15_t)0x68C3, + (q15_t)0x4961, (q15_t)0x68E0, (q15_t)0x4938, (q15_t)0x68FD, + (q15_t)0x490F, (q15_t)0x6919, (q15_t)0x48E6, (q15_t)0x6936, + (q15_t)0x48BC, (q15_t)0x6953, (q15_t)0x4893, (q15_t)0x696F, + (q15_t)0x4869, (q15_t)0x698C, (q15_t)0x4840, (q15_t)0x69A8, + (q15_t)0x4816, (q15_t)0x69C4, (q15_t)0x47ED, (q15_t)0x69E1, + (q15_t)0x47C3, (q15_t)0x69FD, (q15_t)0x479A, (q15_t)0x6A19, + (q15_t)0x4770, (q15_t)0x6A35, (q15_t)0x4746, (q15_t)0x6A51, + (q15_t)0x471C, (q15_t)0x6A6D, (q15_t)0x46F3, (q15_t)0x6A89, + (q15_t)0x46C9, (q15_t)0x6AA5, (q15_t)0x469F, (q15_t)0x6AC1, + (q15_t)0x4675, (q15_t)0x6ADC, (q15_t)0x464B, (q15_t)0x6AF8, + (q15_t)0x4621, (q15_t)0x6B13, (q15_t)0x45F7, (q15_t)0x6B2F, + (q15_t)0x45CD, (q15_t)0x6B4A, (q15_t)0x45A3, (q15_t)0x6B66, + (q15_t)0x4578, (q15_t)0x6B81, (q15_t)0x454E, (q15_t)0x6B9C, + (q15_t)0x4524, (q15_t)0x6BB8, (q15_t)0x44FA, (q15_t)0x6BD3, + (q15_t)0x44CF, (q15_t)0x6BEE, (q15_t)0x44A5, (q15_t)0x6C09, + (q15_t)0x447A, (q15_t)0x6C24, (q15_t)0x4450, (q15_t)0x6C3F, + (q15_t)0x4425, (q15_t)0x6C59, (q15_t)0x43FB, (q15_t)0x6C74, + (q15_t)0x43D0, (q15_t)0x6C8F, (q15_t)0x43A5, (q15_t)0x6CA9, + (q15_t)0x437B, (q15_t)0x6CC4, (q15_t)0x4350, (q15_t)0x6CDE, + (q15_t)0x4325, (q15_t)0x6CF9, (q15_t)0x42FA, (q15_t)0x6D13, + (q15_t)0x42D0, (q15_t)0x6D2D, (q15_t)0x42A5, (q15_t)0x6D48, + (q15_t)0x427A, (q15_t)0x6D62, (q15_t)0x424F, (q15_t)0x6D7C, + (q15_t)0x4224, (q15_t)0x6D96, (q15_t)0x41F9, (q15_t)0x6DB0, + (q15_t)0x41CE, (q15_t)0x6DCA, (q15_t)0x41A2, (q15_t)0x6DE3, + (q15_t)0x4177, (q15_t)0x6DFD, (q15_t)0x414C, (q15_t)0x6E17, + (q15_t)0x4121, (q15_t)0x6E30, (q15_t)0x40F6, (q15_t)0x6E4A, + (q15_t)0x40CA, (q15_t)0x6E63, (q15_t)0x409F, (q15_t)0x6E7D, + (q15_t)0x4073, (q15_t)0x6E96, (q15_t)0x4048, (q15_t)0x6EAF, + (q15_t)0x401D, (q15_t)0x6EC9, (q15_t)0x3FF1, (q15_t)0x6EE2, + (q15_t)0x3FC5, (q15_t)0x6EFB, (q15_t)0x3F9A, (q15_t)0x6F14, + (q15_t)0x3F6E, (q15_t)0x6F2D, (q15_t)0x3F43, (q15_t)0x6F46, + (q15_t)0x3F17, (q15_t)0x6F5F, (q15_t)0x3EEB, (q15_t)0x6F77, + (q15_t)0x3EBF, (q15_t)0x6F90, (q15_t)0x3E93, (q15_t)0x6FA9, + (q15_t)0x3E68, (q15_t)0x6FC1, (q15_t)0x3E3C, (q15_t)0x6FDA, + (q15_t)0x3E10, (q15_t)0x6FF2, (q15_t)0x3DE4, (q15_t)0x700A, + (q15_t)0x3DB8, (q15_t)0x7023, (q15_t)0x3D8C, (q15_t)0x703B, + (q15_t)0x3D60, (q15_t)0x7053, (q15_t)0x3D33, (q15_t)0x706B, + (q15_t)0x3D07, (q15_t)0x7083, (q15_t)0x3CDB, (q15_t)0x709B, + (q15_t)0x3CAF, (q15_t)0x70B3, (q15_t)0x3C83, (q15_t)0x70CB, + (q15_t)0x3C56, (q15_t)0x70E2, (q15_t)0x3C2A, (q15_t)0x70FA, + (q15_t)0x3BFD, (q15_t)0x7112, (q15_t)0x3BD1, (q15_t)0x7129, + (q15_t)0x3BA5, (q15_t)0x7141, (q15_t)0x3B78, (q15_t)0x7158, + (q15_t)0x3B4C, (q15_t)0x716F, (q15_t)0x3B1F, (q15_t)0x7186, + (q15_t)0x3AF2, (q15_t)0x719E, (q15_t)0x3AC6, (q15_t)0x71B5, + (q15_t)0x3A99, (q15_t)0x71CC, (q15_t)0x3A6C, (q15_t)0x71E3, + (q15_t)0x3A40, (q15_t)0x71FA, (q15_t)0x3A13, (q15_t)0x7211, + (q15_t)0x39E6, (q15_t)0x7227, (q15_t)0x39B9, (q15_t)0x723E, + (q15_t)0x398C, (q15_t)0x7255, (q15_t)0x395F, (q15_t)0x726B, + (q15_t)0x3932, (q15_t)0x7282, (q15_t)0x3906, (q15_t)0x7298, + (q15_t)0x38D8, (q15_t)0x72AF, (q15_t)0x38AB, (q15_t)0x72C5, + (q15_t)0x387E, (q15_t)0x72DB, (q15_t)0x3851, (q15_t)0x72F1, + (q15_t)0x3824, (q15_t)0x7307, (q15_t)0x37F7, (q15_t)0x731D, + (q15_t)0x37CA, (q15_t)0x7333, (q15_t)0x379C, (q15_t)0x7349, + (q15_t)0x376F, (q15_t)0x735F, (q15_t)0x3742, (q15_t)0x7375, + (q15_t)0x3714, (q15_t)0x738A, (q15_t)0x36E7, (q15_t)0x73A0, + (q15_t)0x36BA, (q15_t)0x73B5, (q15_t)0x368C, (q15_t)0x73CB, + (q15_t)0x365F, (q15_t)0x73E0, (q15_t)0x3631, (q15_t)0x73F6, + (q15_t)0x3604, (q15_t)0x740B, (q15_t)0x35D6, (q15_t)0x7420, + (q15_t)0x35A8, (q15_t)0x7435, (q15_t)0x357B, (q15_t)0x744A, + (q15_t)0x354D, (q15_t)0x745F, (q15_t)0x351F, (q15_t)0x7474, + (q15_t)0x34F2, (q15_t)0x7489, (q15_t)0x34C4, (q15_t)0x749E, + (q15_t)0x3496, (q15_t)0x74B2, (q15_t)0x3468, (q15_t)0x74C7, + (q15_t)0x343A, (q15_t)0x74DB, (q15_t)0x340C, (q15_t)0x74F0, + (q15_t)0x33DE, (q15_t)0x7504, (q15_t)0x33B0, (q15_t)0x7519, + (q15_t)0x3382, (q15_t)0x752D, (q15_t)0x3354, (q15_t)0x7541, + (q15_t)0x3326, (q15_t)0x7555, (q15_t)0x32F8, (q15_t)0x7569, + (q15_t)0x32CA, (q15_t)0x757D, (q15_t)0x329C, (q15_t)0x7591, + (q15_t)0x326E, (q15_t)0x75A5, (q15_t)0x3240, (q15_t)0x75B9, + (q15_t)0x3211, (q15_t)0x75CC, (q15_t)0x31E3, (q15_t)0x75E0, + (q15_t)0x31B5, (q15_t)0x75F4, (q15_t)0x3186, (q15_t)0x7607, + (q15_t)0x3158, (q15_t)0x761B, (q15_t)0x312A, (q15_t)0x762E, + (q15_t)0x30FB, (q15_t)0x7641, (q15_t)0x30CD, (q15_t)0x7654, + (q15_t)0x309E, (q15_t)0x7668, (q15_t)0x3070, (q15_t)0x767B, + (q15_t)0x3041, (q15_t)0x768E, (q15_t)0x3013, (q15_t)0x76A0, + (q15_t)0x2FE4, (q15_t)0x76B3, (q15_t)0x2FB5, (q15_t)0x76C6, + (q15_t)0x2F87, (q15_t)0x76D9, (q15_t)0x2F58, (q15_t)0x76EB, + (q15_t)0x2F29, (q15_t)0x76FE, (q15_t)0x2EFB, (q15_t)0x7710, + (q15_t)0x2ECC, (q15_t)0x7723, (q15_t)0x2E9D, (q15_t)0x7735, + (q15_t)0x2E6E, (q15_t)0x7747, (q15_t)0x2E3F, (q15_t)0x775A, + (q15_t)0x2E11, (q15_t)0x776C, (q15_t)0x2DE2, (q15_t)0x777E, + (q15_t)0x2DB3, (q15_t)0x7790, (q15_t)0x2D84, (q15_t)0x77A2, + (q15_t)0x2D55, (q15_t)0x77B4, (q15_t)0x2D26, (q15_t)0x77C5, + (q15_t)0x2CF7, (q15_t)0x77D7, (q15_t)0x2CC8, (q15_t)0x77E9, + (q15_t)0x2C98, (q15_t)0x77FA, (q15_t)0x2C69, (q15_t)0x780C, + (q15_t)0x2C3A, (q15_t)0x781D, (q15_t)0x2C0B, (q15_t)0x782E, + (q15_t)0x2BDC, (q15_t)0x7840, (q15_t)0x2BAD, (q15_t)0x7851, + (q15_t)0x2B7D, (q15_t)0x7862, (q15_t)0x2B4E, (q15_t)0x7873, + (q15_t)0x2B1F, (q15_t)0x7884, (q15_t)0x2AEF, (q15_t)0x7895, + (q15_t)0x2AC0, (q15_t)0x78A6, (q15_t)0x2A91, (q15_t)0x78B6, + (q15_t)0x2A61, (q15_t)0x78C7, (q15_t)0x2A32, (q15_t)0x78D8, + (q15_t)0x2A02, (q15_t)0x78E8, (q15_t)0x29D3, (q15_t)0x78F9, + (q15_t)0x29A3, (q15_t)0x7909, (q15_t)0x2974, (q15_t)0x7919, + (q15_t)0x2944, (q15_t)0x792A, (q15_t)0x2915, (q15_t)0x793A, + (q15_t)0x28E5, (q15_t)0x794A, (q15_t)0x28B5, (q15_t)0x795A, + (q15_t)0x2886, (q15_t)0x796A, (q15_t)0x2856, (q15_t)0x797A, + (q15_t)0x2826, (q15_t)0x798A, (q15_t)0x27F6, (q15_t)0x7999, + (q15_t)0x27C7, (q15_t)0x79A9, (q15_t)0x2797, (q15_t)0x79B9, + (q15_t)0x2767, (q15_t)0x79C8, (q15_t)0x2737, (q15_t)0x79D8, + (q15_t)0x2707, (q15_t)0x79E7, (q15_t)0x26D8, (q15_t)0x79F6, + (q15_t)0x26A8, (q15_t)0x7A05, (q15_t)0x2678, (q15_t)0x7A15, + (q15_t)0x2648, (q15_t)0x7A24, (q15_t)0x2618, (q15_t)0x7A33, + (q15_t)0x25E8, (q15_t)0x7A42, (q15_t)0x25B8, (q15_t)0x7A50, + (q15_t)0x2588, (q15_t)0x7A5F, (q15_t)0x2558, (q15_t)0x7A6E, + (q15_t)0x2528, (q15_t)0x7A7D, (q15_t)0x24F7, (q15_t)0x7A8B, + (q15_t)0x24C7, (q15_t)0x7A9A, (q15_t)0x2497, (q15_t)0x7AA8, + (q15_t)0x2467, (q15_t)0x7AB6, (q15_t)0x2437, (q15_t)0x7AC5, + (q15_t)0x2407, (q15_t)0x7AD3, (q15_t)0x23D6, (q15_t)0x7AE1, + (q15_t)0x23A6, (q15_t)0x7AEF, (q15_t)0x2376, (q15_t)0x7AFD, + (q15_t)0x2345, (q15_t)0x7B0B, (q15_t)0x2315, (q15_t)0x7B19, + (q15_t)0x22E5, (q15_t)0x7B26, (q15_t)0x22B4, (q15_t)0x7B34, + (q15_t)0x2284, (q15_t)0x7B42, (q15_t)0x2254, (q15_t)0x7B4F, + (q15_t)0x2223, (q15_t)0x7B5D, (q15_t)0x21F3, (q15_t)0x7B6A, + (q15_t)0x21C2, (q15_t)0x7B77, (q15_t)0x2192, (q15_t)0x7B84, + (q15_t)0x2161, (q15_t)0x7B92, (q15_t)0x2131, (q15_t)0x7B9F, + (q15_t)0x2100, (q15_t)0x7BAC, (q15_t)0x20D0, (q15_t)0x7BB9, + (q15_t)0x209F, (q15_t)0x7BC5, (q15_t)0x206E, (q15_t)0x7BD2, + (q15_t)0x203E, (q15_t)0x7BDF, (q15_t)0x200D, (q15_t)0x7BEB, + (q15_t)0x1FDC, (q15_t)0x7BF8, (q15_t)0x1FAC, (q15_t)0x7C05, + (q15_t)0x1F7B, (q15_t)0x7C11, (q15_t)0x1F4A, (q15_t)0x7C1D, + (q15_t)0x1F19, (q15_t)0x7C29, (q15_t)0x1EE9, (q15_t)0x7C36, + (q15_t)0x1EB8, (q15_t)0x7C42, (q15_t)0x1E87, (q15_t)0x7C4E, + (q15_t)0x1E56, (q15_t)0x7C5A, (q15_t)0x1E25, (q15_t)0x7C66, + (q15_t)0x1DF5, (q15_t)0x7C71, (q15_t)0x1DC4, (q15_t)0x7C7D, + (q15_t)0x1D93, (q15_t)0x7C89, (q15_t)0x1D62, (q15_t)0x7C94, + (q15_t)0x1D31, (q15_t)0x7CA0, (q15_t)0x1D00, (q15_t)0x7CAB, + (q15_t)0x1CCF, (q15_t)0x7CB7, (q15_t)0x1C9E, (q15_t)0x7CC2, + (q15_t)0x1C6D, (q15_t)0x7CCD, (q15_t)0x1C3C, (q15_t)0x7CD8, + (q15_t)0x1C0B, (q15_t)0x7CE3, (q15_t)0x1BDA, (q15_t)0x7CEE, + (q15_t)0x1BA9, (q15_t)0x7CF9, (q15_t)0x1B78, (q15_t)0x7D04, + (q15_t)0x1B47, (q15_t)0x7D0F, (q15_t)0x1B16, (q15_t)0x7D19, + (q15_t)0x1AE4, (q15_t)0x7D24, (q15_t)0x1AB3, (q15_t)0x7D2F, + (q15_t)0x1A82, (q15_t)0x7D39, (q15_t)0x1A51, (q15_t)0x7D43, + (q15_t)0x1A20, (q15_t)0x7D4E, (q15_t)0x19EF, (q15_t)0x7D58, + (q15_t)0x19BD, (q15_t)0x7D62, (q15_t)0x198C, (q15_t)0x7D6C, + (q15_t)0x195B, (q15_t)0x7D76, (q15_t)0x192A, (q15_t)0x7D80, + (q15_t)0x18F8, (q15_t)0x7D8A, (q15_t)0x18C7, (q15_t)0x7D94, + (q15_t)0x1896, (q15_t)0x7D9D, (q15_t)0x1864, (q15_t)0x7DA7, + (q15_t)0x1833, (q15_t)0x7DB0, (q15_t)0x1802, (q15_t)0x7DBA, + (q15_t)0x17D0, (q15_t)0x7DC3, (q15_t)0x179F, (q15_t)0x7DCD, + (q15_t)0x176D, (q15_t)0x7DD6, (q15_t)0x173C, (q15_t)0x7DDF, + (q15_t)0x170A, (q15_t)0x7DE8, (q15_t)0x16D9, (q15_t)0x7DF1, + (q15_t)0x16A8, (q15_t)0x7DFA, (q15_t)0x1676, (q15_t)0x7E03, + (q15_t)0x1645, (q15_t)0x7E0C, (q15_t)0x1613, (q15_t)0x7E14, + (q15_t)0x15E2, (q15_t)0x7E1D, (q15_t)0x15B0, (q15_t)0x7E26, + (q15_t)0x157F, (q15_t)0x7E2E, (q15_t)0x154D, (q15_t)0x7E37, + (q15_t)0x151B, (q15_t)0x7E3F, (q15_t)0x14EA, (q15_t)0x7E47, + (q15_t)0x14B8, (q15_t)0x7E4F, (q15_t)0x1487, (q15_t)0x7E57, + (q15_t)0x1455, (q15_t)0x7E5F, (q15_t)0x1423, (q15_t)0x7E67, + (q15_t)0x13F2, (q15_t)0x7E6F, (q15_t)0x13C0, (q15_t)0x7E77, + (q15_t)0x138E, (q15_t)0x7E7F, (q15_t)0x135D, (q15_t)0x7E86, + (q15_t)0x132B, (q15_t)0x7E8E, (q15_t)0x12F9, (q15_t)0x7E95, + (q15_t)0x12C8, (q15_t)0x7E9D, (q15_t)0x1296, (q15_t)0x7EA4, + (q15_t)0x1264, (q15_t)0x7EAB, (q15_t)0x1232, (q15_t)0x7EB3, + (q15_t)0x1201, (q15_t)0x7EBA, (q15_t)0x11CF, (q15_t)0x7EC1, + (q15_t)0x119D, (q15_t)0x7EC8, (q15_t)0x116B, (q15_t)0x7ECF, + (q15_t)0x1139, (q15_t)0x7ED5, (q15_t)0x1108, (q15_t)0x7EDC, + (q15_t)0x10D6, (q15_t)0x7EE3, (q15_t)0x10A4, (q15_t)0x7EE9, + (q15_t)0x1072, (q15_t)0x7EF0, (q15_t)0x1040, (q15_t)0x7EF6, + (q15_t)0x100E, (q15_t)0x7EFD, (q15_t)0x0FDD, (q15_t)0x7F03, + (q15_t)0x0FAB, (q15_t)0x7F09, (q15_t)0x0F79, (q15_t)0x7F0F, + (q15_t)0x0F47, (q15_t)0x7F15, (q15_t)0x0F15, (q15_t)0x7F1B, + (q15_t)0x0EE3, (q15_t)0x7F21, (q15_t)0x0EB1, (q15_t)0x7F27, + (q15_t)0x0E7F, (q15_t)0x7F2D, (q15_t)0x0E4D, (q15_t)0x7F32, + (q15_t)0x0E1B, (q15_t)0x7F38, (q15_t)0x0DE9, (q15_t)0x7F3D, + (q15_t)0x0DB7, (q15_t)0x7F43, (q15_t)0x0D85, (q15_t)0x7F48, + (q15_t)0x0D53, (q15_t)0x7F4D, (q15_t)0x0D21, (q15_t)0x7F53, + (q15_t)0x0CEF, (q15_t)0x7F58, (q15_t)0x0CBD, (q15_t)0x7F5D, + (q15_t)0x0C8B, (q15_t)0x7F62, (q15_t)0x0C59, (q15_t)0x7F67, + (q15_t)0x0C27, (q15_t)0x7F6B, (q15_t)0x0BF5, (q15_t)0x7F70, + (q15_t)0x0BC3, (q15_t)0x7F75, (q15_t)0x0B91, (q15_t)0x7F79, + (q15_t)0x0B5F, (q15_t)0x7F7E, (q15_t)0x0B2D, (q15_t)0x7F82, + (q15_t)0x0AFB, (q15_t)0x7F87, (q15_t)0x0AC9, (q15_t)0x7F8B, + (q15_t)0x0A97, (q15_t)0x7F8F, (q15_t)0x0A65, (q15_t)0x7F93, + (q15_t)0x0A33, (q15_t)0x7F97, (q15_t)0x0A00, (q15_t)0x7F9B, + (q15_t)0x09CE, (q15_t)0x7F9F, (q15_t)0x099C, (q15_t)0x7FA3, + (q15_t)0x096A, (q15_t)0x7FA7, (q15_t)0x0938, (q15_t)0x7FAA, + (q15_t)0x0906, (q15_t)0x7FAE, (q15_t)0x08D4, (q15_t)0x7FB1, + (q15_t)0x08A2, (q15_t)0x7FB5, (q15_t)0x086F, (q15_t)0x7FB8, + (q15_t)0x083D, (q15_t)0x7FBC, (q15_t)0x080B, (q15_t)0x7FBF, + (q15_t)0x07D9, (q15_t)0x7FC2, (q15_t)0x07A7, (q15_t)0x7FC5, + (q15_t)0x0775, (q15_t)0x7FC8, (q15_t)0x0742, (q15_t)0x7FCB, + (q15_t)0x0710, (q15_t)0x7FCE, (q15_t)0x06DE, (q15_t)0x7FD0, + (q15_t)0x06AC, (q15_t)0x7FD3, (q15_t)0x067A, (q15_t)0x7FD6, + (q15_t)0x0647, (q15_t)0x7FD8, (q15_t)0x0615, (q15_t)0x7FDA, + (q15_t)0x05E3, (q15_t)0x7FDD, (q15_t)0x05B1, (q15_t)0x7FDF, + (q15_t)0x057F, (q15_t)0x7FE1, (q15_t)0x054C, (q15_t)0x7FE3, + (q15_t)0x051A, (q15_t)0x7FE5, (q15_t)0x04E8, (q15_t)0x7FE7, + (q15_t)0x04B6, (q15_t)0x7FE9, (q15_t)0x0483, (q15_t)0x7FEB, + (q15_t)0x0451, (q15_t)0x7FED, (q15_t)0x041F, (q15_t)0x7FEE, + (q15_t)0x03ED, (q15_t)0x7FF0, (q15_t)0x03BA, (q15_t)0x7FF2, + (q15_t)0x0388, (q15_t)0x7FF3, (q15_t)0x0356, (q15_t)0x7FF4, + (q15_t)0x0324, (q15_t)0x7FF6, (q15_t)0x02F1, (q15_t)0x7FF7, + (q15_t)0x02BF, (q15_t)0x7FF8, (q15_t)0x028D, (q15_t)0x7FF9, + (q15_t)0x025B, (q15_t)0x7FFA, (q15_t)0x0228, (q15_t)0x7FFB, + (q15_t)0x01F6, (q15_t)0x7FFC, (q15_t)0x01C4, (q15_t)0x7FFC, + (q15_t)0x0192, (q15_t)0x7FFD, (q15_t)0x015F, (q15_t)0x7FFE, + (q15_t)0x012D, (q15_t)0x7FFE, (q15_t)0x00FB, (q15_t)0x7FFF, + (q15_t)0x00C9, (q15_t)0x7FFF, (q15_t)0x0096, (q15_t)0x7FFF, + (q15_t)0x0064, (q15_t)0x7FFF, (q15_t)0x0032, (q15_t)0x7FFF, + (q15_t)0x0000, (q15_t)0x7FFF, (q15_t)0xFFCD, (q15_t)0x7FFF, + (q15_t)0xFF9B, (q15_t)0x7FFF, (q15_t)0xFF69, (q15_t)0x7FFF, + (q15_t)0xFF36, (q15_t)0x7FFF, (q15_t)0xFF04, (q15_t)0x7FFF, + (q15_t)0xFED2, (q15_t)0x7FFE, (q15_t)0xFEA0, (q15_t)0x7FFE, + (q15_t)0xFE6D, (q15_t)0x7FFD, (q15_t)0xFE3B, (q15_t)0x7FFC, + (q15_t)0xFE09, (q15_t)0x7FFC, (q15_t)0xFDD7, (q15_t)0x7FFB, + (q15_t)0xFDA4, (q15_t)0x7FFA, (q15_t)0xFD72, (q15_t)0x7FF9, + (q15_t)0xFD40, (q15_t)0x7FF8, (q15_t)0xFD0E, (q15_t)0x7FF7, + (q15_t)0xFCDB, (q15_t)0x7FF6, (q15_t)0xFCA9, (q15_t)0x7FF4, + (q15_t)0xFC77, (q15_t)0x7FF3, (q15_t)0xFC45, (q15_t)0x7FF2, + (q15_t)0xFC12, (q15_t)0x7FF0, (q15_t)0xFBE0, (q15_t)0x7FEE, + (q15_t)0xFBAE, (q15_t)0x7FED, (q15_t)0xFB7C, (q15_t)0x7FEB, + (q15_t)0xFB49, (q15_t)0x7FE9, (q15_t)0xFB17, (q15_t)0x7FE7, + (q15_t)0xFAE5, (q15_t)0x7FE5, (q15_t)0xFAB3, (q15_t)0x7FE3, + (q15_t)0xFA80, (q15_t)0x7FE1, (q15_t)0xFA4E, (q15_t)0x7FDF, + (q15_t)0xFA1C, (q15_t)0x7FDD, (q15_t)0xF9EA, (q15_t)0x7FDA, + (q15_t)0xF9B8, (q15_t)0x7FD8, (q15_t)0xF985, (q15_t)0x7FD6, + (q15_t)0xF953, (q15_t)0x7FD3, (q15_t)0xF921, (q15_t)0x7FD0, + (q15_t)0xF8EF, (q15_t)0x7FCE, (q15_t)0xF8BD, (q15_t)0x7FCB, + (q15_t)0xF88A, (q15_t)0x7FC8, (q15_t)0xF858, (q15_t)0x7FC5, + (q15_t)0xF826, (q15_t)0x7FC2, (q15_t)0xF7F4, (q15_t)0x7FBF, + (q15_t)0xF7C2, (q15_t)0x7FBC, (q15_t)0xF790, (q15_t)0x7FB8, + (q15_t)0xF75D, (q15_t)0x7FB5, (q15_t)0xF72B, (q15_t)0x7FB1, + (q15_t)0xF6F9, (q15_t)0x7FAE, (q15_t)0xF6C7, (q15_t)0x7FAA, + (q15_t)0xF695, (q15_t)0x7FA7, (q15_t)0xF663, (q15_t)0x7FA3, + (q15_t)0xF631, (q15_t)0x7F9F, (q15_t)0xF5FF, (q15_t)0x7F9B, + (q15_t)0xF5CC, (q15_t)0x7F97, (q15_t)0xF59A, (q15_t)0x7F93, + (q15_t)0xF568, (q15_t)0x7F8F, (q15_t)0xF536, (q15_t)0x7F8B, + (q15_t)0xF504, (q15_t)0x7F87, (q15_t)0xF4D2, (q15_t)0x7F82, + (q15_t)0xF4A0, (q15_t)0x7F7E, (q15_t)0xF46E, (q15_t)0x7F79, + (q15_t)0xF43C, (q15_t)0x7F75, (q15_t)0xF40A, (q15_t)0x7F70, + (q15_t)0xF3D8, (q15_t)0x7F6B, (q15_t)0xF3A6, (q15_t)0x7F67, + (q15_t)0xF374, (q15_t)0x7F62, (q15_t)0xF342, (q15_t)0x7F5D, + (q15_t)0xF310, (q15_t)0x7F58, (q15_t)0xF2DE, (q15_t)0x7F53, + (q15_t)0xF2AC, (q15_t)0x7F4D, (q15_t)0xF27A, (q15_t)0x7F48, + (q15_t)0xF248, (q15_t)0x7F43, (q15_t)0xF216, (q15_t)0x7F3D, + (q15_t)0xF1E4, (q15_t)0x7F38, (q15_t)0xF1B2, (q15_t)0x7F32, + (q15_t)0xF180, (q15_t)0x7F2D, (q15_t)0xF14E, (q15_t)0x7F27, + (q15_t)0xF11C, (q15_t)0x7F21, (q15_t)0xF0EA, (q15_t)0x7F1B, + (q15_t)0xF0B8, (q15_t)0x7F15, (q15_t)0xF086, (q15_t)0x7F0F, + (q15_t)0xF054, (q15_t)0x7F09, (q15_t)0xF022, (q15_t)0x7F03, + (q15_t)0xEFF1, (q15_t)0x7EFD, (q15_t)0xEFBF, (q15_t)0x7EF6, + (q15_t)0xEF8D, (q15_t)0x7EF0, (q15_t)0xEF5B, (q15_t)0x7EE9, + (q15_t)0xEF29, (q15_t)0x7EE3, (q15_t)0xEEF7, (q15_t)0x7EDC, + (q15_t)0xEEC6, (q15_t)0x7ED5, (q15_t)0xEE94, (q15_t)0x7ECF, + (q15_t)0xEE62, (q15_t)0x7EC8, (q15_t)0xEE30, (q15_t)0x7EC1, + (q15_t)0xEDFE, (q15_t)0x7EBA, (q15_t)0xEDCD, (q15_t)0x7EB3, + (q15_t)0xED9B, (q15_t)0x7EAB, (q15_t)0xED69, (q15_t)0x7EA4, + (q15_t)0xED37, (q15_t)0x7E9D, (q15_t)0xED06, (q15_t)0x7E95, + (q15_t)0xECD4, (q15_t)0x7E8E, (q15_t)0xECA2, (q15_t)0x7E86, + (q15_t)0xEC71, (q15_t)0x7E7F, (q15_t)0xEC3F, (q15_t)0x7E77, + (q15_t)0xEC0D, (q15_t)0x7E6F, (q15_t)0xEBDC, (q15_t)0x7E67, + (q15_t)0xEBAA, (q15_t)0x7E5F, (q15_t)0xEB78, (q15_t)0x7E57, + (q15_t)0xEB47, (q15_t)0x7E4F, (q15_t)0xEB15, (q15_t)0x7E47, + (q15_t)0xEAE4, (q15_t)0x7E3F, (q15_t)0xEAB2, (q15_t)0x7E37, + (q15_t)0xEA80, (q15_t)0x7E2E, (q15_t)0xEA4F, (q15_t)0x7E26, + (q15_t)0xEA1D, (q15_t)0x7E1D, (q15_t)0xE9EC, (q15_t)0x7E14, + (q15_t)0xE9BA, (q15_t)0x7E0C, (q15_t)0xE989, (q15_t)0x7E03, + (q15_t)0xE957, (q15_t)0x7DFA, (q15_t)0xE926, (q15_t)0x7DF1, + (q15_t)0xE8F5, (q15_t)0x7DE8, (q15_t)0xE8C3, (q15_t)0x7DDF, + (q15_t)0xE892, (q15_t)0x7DD6, (q15_t)0xE860, (q15_t)0x7DCD, + (q15_t)0xE82F, (q15_t)0x7DC3, (q15_t)0xE7FD, (q15_t)0x7DBA, + (q15_t)0xE7CC, (q15_t)0x7DB0, (q15_t)0xE79B, (q15_t)0x7DA7, + (q15_t)0xE769, (q15_t)0x7D9D, (q15_t)0xE738, (q15_t)0x7D94, + (q15_t)0xE707, (q15_t)0x7D8A, (q15_t)0xE6D5, (q15_t)0x7D80, + (q15_t)0xE6A4, (q15_t)0x7D76, (q15_t)0xE673, (q15_t)0x7D6C, + (q15_t)0xE642, (q15_t)0x7D62, (q15_t)0xE610, (q15_t)0x7D58, + (q15_t)0xE5DF, (q15_t)0x7D4E, (q15_t)0xE5AE, (q15_t)0x7D43, + (q15_t)0xE57D, (q15_t)0x7D39, (q15_t)0xE54C, (q15_t)0x7D2F, + (q15_t)0xE51B, (q15_t)0x7D24, (q15_t)0xE4E9, (q15_t)0x7D19, + (q15_t)0xE4B8, (q15_t)0x7D0F, (q15_t)0xE487, (q15_t)0x7D04, + (q15_t)0xE456, (q15_t)0x7CF9, (q15_t)0xE425, (q15_t)0x7CEE, + (q15_t)0xE3F4, (q15_t)0x7CE3, (q15_t)0xE3C3, (q15_t)0x7CD8, + (q15_t)0xE392, (q15_t)0x7CCD, (q15_t)0xE361, (q15_t)0x7CC2, + (q15_t)0xE330, (q15_t)0x7CB7, (q15_t)0xE2FF, (q15_t)0x7CAB, + (q15_t)0xE2CE, (q15_t)0x7CA0, (q15_t)0xE29D, (q15_t)0x7C94, + (q15_t)0xE26C, (q15_t)0x7C89, (q15_t)0xE23B, (q15_t)0x7C7D, + (q15_t)0xE20A, (q15_t)0x7C71, (q15_t)0xE1DA, (q15_t)0x7C66, + (q15_t)0xE1A9, (q15_t)0x7C5A, (q15_t)0xE178, (q15_t)0x7C4E, + (q15_t)0xE147, (q15_t)0x7C42, (q15_t)0xE116, (q15_t)0x7C36, + (q15_t)0xE0E6, (q15_t)0x7C29, (q15_t)0xE0B5, (q15_t)0x7C1D, + (q15_t)0xE084, (q15_t)0x7C11, (q15_t)0xE053, (q15_t)0x7C05, + (q15_t)0xE023, (q15_t)0x7BF8, (q15_t)0xDFF2, (q15_t)0x7BEB, + (q15_t)0xDFC1, (q15_t)0x7BDF, (q15_t)0xDF91, (q15_t)0x7BD2, + (q15_t)0xDF60, (q15_t)0x7BC5, (q15_t)0xDF2F, (q15_t)0x7BB9, + (q15_t)0xDEFF, (q15_t)0x7BAC, (q15_t)0xDECE, (q15_t)0x7B9F, + (q15_t)0xDE9E, (q15_t)0x7B92, (q15_t)0xDE6D, (q15_t)0x7B84, + (q15_t)0xDE3D, (q15_t)0x7B77, (q15_t)0xDE0C, (q15_t)0x7B6A, + (q15_t)0xDDDC, (q15_t)0x7B5D, (q15_t)0xDDAB, (q15_t)0x7B4F, + (q15_t)0xDD7B, (q15_t)0x7B42, (q15_t)0xDD4B, (q15_t)0x7B34, + (q15_t)0xDD1A, (q15_t)0x7B26, (q15_t)0xDCEA, (q15_t)0x7B19, + (q15_t)0xDCBA, (q15_t)0x7B0B, (q15_t)0xDC89, (q15_t)0x7AFD, + (q15_t)0xDC59, (q15_t)0x7AEF, (q15_t)0xDC29, (q15_t)0x7AE1, + (q15_t)0xDBF8, (q15_t)0x7AD3, (q15_t)0xDBC8, (q15_t)0x7AC5, + (q15_t)0xDB98, (q15_t)0x7AB6, (q15_t)0xDB68, (q15_t)0x7AA8, + (q15_t)0xDB38, (q15_t)0x7A9A, (q15_t)0xDB08, (q15_t)0x7A8B, + (q15_t)0xDAD7, (q15_t)0x7A7D, (q15_t)0xDAA7, (q15_t)0x7A6E, + (q15_t)0xDA77, (q15_t)0x7A5F, (q15_t)0xDA47, (q15_t)0x7A50, + (q15_t)0xDA17, (q15_t)0x7A42, (q15_t)0xD9E7, (q15_t)0x7A33, + (q15_t)0xD9B7, (q15_t)0x7A24, (q15_t)0xD987, (q15_t)0x7A15, + (q15_t)0xD957, (q15_t)0x7A05, (q15_t)0xD927, (q15_t)0x79F6, + (q15_t)0xD8F8, (q15_t)0x79E7, (q15_t)0xD8C8, (q15_t)0x79D8, + (q15_t)0xD898, (q15_t)0x79C8, (q15_t)0xD868, (q15_t)0x79B9, + (q15_t)0xD838, (q15_t)0x79A9, (q15_t)0xD809, (q15_t)0x7999, + (q15_t)0xD7D9, (q15_t)0x798A, (q15_t)0xD7A9, (q15_t)0x797A, + (q15_t)0xD779, (q15_t)0x796A, (q15_t)0xD74A, (q15_t)0x795A, + (q15_t)0xD71A, (q15_t)0x794A, (q15_t)0xD6EA, (q15_t)0x793A, + (q15_t)0xD6BB, (q15_t)0x792A, (q15_t)0xD68B, (q15_t)0x7919, + (q15_t)0xD65C, (q15_t)0x7909, (q15_t)0xD62C, (q15_t)0x78F9, + (q15_t)0xD5FD, (q15_t)0x78E8, (q15_t)0xD5CD, (q15_t)0x78D8, + (q15_t)0xD59E, (q15_t)0x78C7, (q15_t)0xD56E, (q15_t)0x78B6, + (q15_t)0xD53F, (q15_t)0x78A6, (q15_t)0xD510, (q15_t)0x7895, + (q15_t)0xD4E0, (q15_t)0x7884, (q15_t)0xD4B1, (q15_t)0x7873, + (q15_t)0xD482, (q15_t)0x7862, (q15_t)0xD452, (q15_t)0x7851, + (q15_t)0xD423, (q15_t)0x7840, (q15_t)0xD3F4, (q15_t)0x782E, + (q15_t)0xD3C5, (q15_t)0x781D, (q15_t)0xD396, (q15_t)0x780C, + (q15_t)0xD367, (q15_t)0x77FA, (q15_t)0xD337, (q15_t)0x77E9, + (q15_t)0xD308, (q15_t)0x77D7, (q15_t)0xD2D9, (q15_t)0x77C5, + (q15_t)0xD2AA, (q15_t)0x77B4, (q15_t)0xD27B, (q15_t)0x77A2, + (q15_t)0xD24C, (q15_t)0x7790, (q15_t)0xD21D, (q15_t)0x777E, + (q15_t)0xD1EE, (q15_t)0x776C, (q15_t)0xD1C0, (q15_t)0x775A, + (q15_t)0xD191, (q15_t)0x7747, (q15_t)0xD162, (q15_t)0x7735, + (q15_t)0xD133, (q15_t)0x7723, (q15_t)0xD104, (q15_t)0x7710, + (q15_t)0xD0D6, (q15_t)0x76FE, (q15_t)0xD0A7, (q15_t)0x76EB, + (q15_t)0xD078, (q15_t)0x76D9, (q15_t)0xD04A, (q15_t)0x76C6, + (q15_t)0xD01B, (q15_t)0x76B3, (q15_t)0xCFEC, (q15_t)0x76A0, + (q15_t)0xCFBE, (q15_t)0x768E, (q15_t)0xCF8F, (q15_t)0x767B, + (q15_t)0xCF61, (q15_t)0x7668, (q15_t)0xCF32, (q15_t)0x7654, + (q15_t)0xCF04, (q15_t)0x7641, (q15_t)0xCED5, (q15_t)0x762E, + (q15_t)0xCEA7, (q15_t)0x761B, (q15_t)0xCE79, (q15_t)0x7607, + (q15_t)0xCE4A, (q15_t)0x75F4, (q15_t)0xCE1C, (q15_t)0x75E0, + (q15_t)0xCDEE, (q15_t)0x75CC, (q15_t)0xCDBF, (q15_t)0x75B9, + (q15_t)0xCD91, (q15_t)0x75A5, (q15_t)0xCD63, (q15_t)0x7591, + (q15_t)0xCD35, (q15_t)0x757D, (q15_t)0xCD07, (q15_t)0x7569, + (q15_t)0xCCD9, (q15_t)0x7555, (q15_t)0xCCAB, (q15_t)0x7541, + (q15_t)0xCC7D, (q15_t)0x752D, (q15_t)0xCC4F, (q15_t)0x7519, + (q15_t)0xCC21, (q15_t)0x7504, (q15_t)0xCBF3, (q15_t)0x74F0, + (q15_t)0xCBC5, (q15_t)0x74DB, (q15_t)0xCB97, (q15_t)0x74C7, + (q15_t)0xCB69, (q15_t)0x74B2, (q15_t)0xCB3B, (q15_t)0x749E, + (q15_t)0xCB0D, (q15_t)0x7489, (q15_t)0xCAE0, (q15_t)0x7474, + (q15_t)0xCAB2, (q15_t)0x745F, (q15_t)0xCA84, (q15_t)0x744A, + (q15_t)0xCA57, (q15_t)0x7435, (q15_t)0xCA29, (q15_t)0x7420, + (q15_t)0xC9FB, (q15_t)0x740B, (q15_t)0xC9CE, (q15_t)0x73F6, + (q15_t)0xC9A0, (q15_t)0x73E0, (q15_t)0xC973, (q15_t)0x73CB, + (q15_t)0xC945, (q15_t)0x73B5, (q15_t)0xC918, (q15_t)0x73A0, + (q15_t)0xC8EB, (q15_t)0x738A, (q15_t)0xC8BD, (q15_t)0x7375, + (q15_t)0xC890, (q15_t)0x735F, (q15_t)0xC863, (q15_t)0x7349, + (q15_t)0xC835, (q15_t)0x7333, (q15_t)0xC808, (q15_t)0x731D, + (q15_t)0xC7DB, (q15_t)0x7307, (q15_t)0xC7AE, (q15_t)0x72F1, + (q15_t)0xC781, (q15_t)0x72DB, (q15_t)0xC754, (q15_t)0x72C5, + (q15_t)0xC727, (q15_t)0x72AF, (q15_t)0xC6F9, (q15_t)0x7298, + (q15_t)0xC6CD, (q15_t)0x7282, (q15_t)0xC6A0, (q15_t)0x726B, + (q15_t)0xC673, (q15_t)0x7255, (q15_t)0xC646, (q15_t)0x723E, + (q15_t)0xC619, (q15_t)0x7227, (q15_t)0xC5EC, (q15_t)0x7211, + (q15_t)0xC5BF, (q15_t)0x71FA, (q15_t)0xC593, (q15_t)0x71E3, + (q15_t)0xC566, (q15_t)0x71CC, (q15_t)0xC539, (q15_t)0x71B5, + (q15_t)0xC50D, (q15_t)0x719E, (q15_t)0xC4E0, (q15_t)0x7186, + (q15_t)0xC4B3, (q15_t)0x716F, (q15_t)0xC487, (q15_t)0x7158, + (q15_t)0xC45A, (q15_t)0x7141, (q15_t)0xC42E, (q15_t)0x7129, + (q15_t)0xC402, (q15_t)0x7112, (q15_t)0xC3D5, (q15_t)0x70FA, + (q15_t)0xC3A9, (q15_t)0x70E2, (q15_t)0xC37C, (q15_t)0x70CB, + (q15_t)0xC350, (q15_t)0x70B3, (q15_t)0xC324, (q15_t)0x709B, + (q15_t)0xC2F8, (q15_t)0x7083, (q15_t)0xC2CC, (q15_t)0x706B, + (q15_t)0xC29F, (q15_t)0x7053, (q15_t)0xC273, (q15_t)0x703B, + (q15_t)0xC247, (q15_t)0x7023, (q15_t)0xC21B, (q15_t)0x700A, + (q15_t)0xC1EF, (q15_t)0x6FF2, (q15_t)0xC1C3, (q15_t)0x6FDA, + (q15_t)0xC197, (q15_t)0x6FC1, (q15_t)0xC16C, (q15_t)0x6FA9, + (q15_t)0xC140, (q15_t)0x6F90, (q15_t)0xC114, (q15_t)0x6F77, + (q15_t)0xC0E8, (q15_t)0x6F5F, (q15_t)0xC0BC, (q15_t)0x6F46, + (q15_t)0xC091, (q15_t)0x6F2D, (q15_t)0xC065, (q15_t)0x6F14, + (q15_t)0xC03A, (q15_t)0x6EFB, (q15_t)0xC00E, (q15_t)0x6EE2, + (q15_t)0xBFE2, (q15_t)0x6EC9, (q15_t)0xBFB7, (q15_t)0x6EAF, + (q15_t)0xBF8C, (q15_t)0x6E96, (q15_t)0xBF60, (q15_t)0x6E7D, + (q15_t)0xBF35, (q15_t)0x6E63, (q15_t)0xBF09, (q15_t)0x6E4A, + (q15_t)0xBEDE, (q15_t)0x6E30, (q15_t)0xBEB3, (q15_t)0x6E17, + (q15_t)0xBE88, (q15_t)0x6DFD, (q15_t)0xBE5D, (q15_t)0x6DE3, + (q15_t)0xBE31, (q15_t)0x6DCA, (q15_t)0xBE06, (q15_t)0x6DB0, + (q15_t)0xBDDB, (q15_t)0x6D96, (q15_t)0xBDB0, (q15_t)0x6D7C, + (q15_t)0xBD85, (q15_t)0x6D62, (q15_t)0xBD5A, (q15_t)0x6D48, + (q15_t)0xBD2F, (q15_t)0x6D2D, (q15_t)0xBD05, (q15_t)0x6D13, + (q15_t)0xBCDA, (q15_t)0x6CF9, (q15_t)0xBCAF, (q15_t)0x6CDE, + (q15_t)0xBC84, (q15_t)0x6CC4, (q15_t)0xBC5A, (q15_t)0x6CA9, + (q15_t)0xBC2F, (q15_t)0x6C8F, (q15_t)0xBC04, (q15_t)0x6C74, + (q15_t)0xBBDA, (q15_t)0x6C59, (q15_t)0xBBAF, (q15_t)0x6C3F, + (q15_t)0xBB85, (q15_t)0x6C24, (q15_t)0xBB5A, (q15_t)0x6C09, + (q15_t)0xBB30, (q15_t)0x6BEE, (q15_t)0xBB05, (q15_t)0x6BD3, + (q15_t)0xBADB, (q15_t)0x6BB8, (q15_t)0xBAB1, (q15_t)0x6B9C, + (q15_t)0xBA87, (q15_t)0x6B81, (q15_t)0xBA5C, (q15_t)0x6B66, + (q15_t)0xBA32, (q15_t)0x6B4A, (q15_t)0xBA08, (q15_t)0x6B2F, + (q15_t)0xB9DE, (q15_t)0x6B13, (q15_t)0xB9B4, (q15_t)0x6AF8, + (q15_t)0xB98A, (q15_t)0x6ADC, (q15_t)0xB960, (q15_t)0x6AC1, + (q15_t)0xB936, (q15_t)0x6AA5, (q15_t)0xB90C, (q15_t)0x6A89, + (q15_t)0xB8E3, (q15_t)0x6A6D, (q15_t)0xB8B9, (q15_t)0x6A51, + (q15_t)0xB88F, (q15_t)0x6A35, (q15_t)0xB865, (q15_t)0x6A19, + (q15_t)0xB83C, (q15_t)0x69FD, (q15_t)0xB812, (q15_t)0x69E1, + (q15_t)0xB7E9, (q15_t)0x69C4, (q15_t)0xB7BF, (q15_t)0x69A8, + (q15_t)0xB796, (q15_t)0x698C, (q15_t)0xB76C, (q15_t)0x696F, + (q15_t)0xB743, (q15_t)0x6953, (q15_t)0xB719, (q15_t)0x6936, + (q15_t)0xB6F0, (q15_t)0x6919, (q15_t)0xB6C7, (q15_t)0x68FD, + (q15_t)0xB69E, (q15_t)0x68E0, (q15_t)0xB675, (q15_t)0x68C3, + (q15_t)0xB64B, (q15_t)0x68A6, (q15_t)0xB622, (q15_t)0x6889, + (q15_t)0xB5F9, (q15_t)0x686C, (q15_t)0xB5D0, (q15_t)0x684F, + (q15_t)0xB5A7, (q15_t)0x6832, (q15_t)0xB57E, (q15_t)0x6815, + (q15_t)0xB556, (q15_t)0x67F7, (q15_t)0xB52D, (q15_t)0x67DA, + (q15_t)0xB504, (q15_t)0x67BD, (q15_t)0xB4DB, (q15_t)0x679F, + (q15_t)0xB4B3, (q15_t)0x6782, (q15_t)0xB48A, (q15_t)0x6764, + (q15_t)0xB461, (q15_t)0x6746, (q15_t)0xB439, (q15_t)0x6729, + (q15_t)0xB410, (q15_t)0x670B, (q15_t)0xB3E8, (q15_t)0x66ED, + (q15_t)0xB3C0, (q15_t)0x66CF, (q15_t)0xB397, (q15_t)0x66B1, + (q15_t)0xB36F, (q15_t)0x6693, (q15_t)0xB347, (q15_t)0x6675, + (q15_t)0xB31E, (q15_t)0x6657, (q15_t)0xB2F6, (q15_t)0x6639, + (q15_t)0xB2CE, (q15_t)0x661A, (q15_t)0xB2A6, (q15_t)0x65FC, + (q15_t)0xB27E, (q15_t)0x65DD, (q15_t)0xB256, (q15_t)0x65BF, + (q15_t)0xB22E, (q15_t)0x65A0, (q15_t)0xB206, (q15_t)0x6582, + (q15_t)0xB1DE, (q15_t)0x6563, (q15_t)0xB1B7, (q15_t)0x6545, + (q15_t)0xB18F, (q15_t)0x6526, (q15_t)0xB167, (q15_t)0x6507, + (q15_t)0xB140, (q15_t)0x64E8, (q15_t)0xB118, (q15_t)0x64C9, + (q15_t)0xB0F0, (q15_t)0x64AA, (q15_t)0xB0C9, (q15_t)0x648B, + (q15_t)0xB0A1, (q15_t)0x646C, (q15_t)0xB07A, (q15_t)0x644D, + (q15_t)0xB053, (q15_t)0x642D, (q15_t)0xB02B, (q15_t)0x640E, + (q15_t)0xB004, (q15_t)0x63EF, (q15_t)0xAFDD, (q15_t)0x63CF, + (q15_t)0xAFB6, (q15_t)0x63B0, (q15_t)0xAF8F, (q15_t)0x6390, + (q15_t)0xAF68, (q15_t)0x6371, (q15_t)0xAF40, (q15_t)0x6351, + (q15_t)0xAF1A, (q15_t)0x6331, (q15_t)0xAEF3, (q15_t)0x6311, + (q15_t)0xAECC, (q15_t)0x62F2, (q15_t)0xAEA5, (q15_t)0x62D2, + (q15_t)0xAE7E, (q15_t)0x62B2, (q15_t)0xAE57, (q15_t)0x6292, + (q15_t)0xAE31, (q15_t)0x6271, (q15_t)0xAE0A, (q15_t)0x6251, + (q15_t)0xADE3, (q15_t)0x6231, (q15_t)0xADBD, (q15_t)0x6211, + (q15_t)0xAD96, (q15_t)0x61F1, (q15_t)0xAD70, (q15_t)0x61D0, + (q15_t)0xAD4A, (q15_t)0x61B0, (q15_t)0xAD23, (q15_t)0x618F, + (q15_t)0xACFD, (q15_t)0x616F, (q15_t)0xACD7, (q15_t)0x614E, + (q15_t)0xACB1, (q15_t)0x612D, (q15_t)0xAC8A, (q15_t)0x610D, + (q15_t)0xAC64, (q15_t)0x60EC, (q15_t)0xAC3E, (q15_t)0x60CB, + (q15_t)0xAC18, (q15_t)0x60AA, (q15_t)0xABF2, (q15_t)0x6089, + (q15_t)0xABCC, (q15_t)0x6068, (q15_t)0xABA7, (q15_t)0x6047, + (q15_t)0xAB81, (q15_t)0x6026, (q15_t)0xAB5B, (q15_t)0x6004, + (q15_t)0xAB35, (q15_t)0x5FE3, (q15_t)0xAB10, (q15_t)0x5FC2, + (q15_t)0xAAEA, (q15_t)0x5FA0, (q15_t)0xAAC5, (q15_t)0x5F7F, + (q15_t)0xAA9F, (q15_t)0x5F5E, (q15_t)0xAA7A, (q15_t)0x5F3C, + (q15_t)0xAA54, (q15_t)0x5F1A, (q15_t)0xAA2F, (q15_t)0x5EF9, + (q15_t)0xAA0A, (q15_t)0x5ED7, (q15_t)0xA9E5, (q15_t)0x5EB5, + (q15_t)0xA9BF, (q15_t)0x5E93, (q15_t)0xA99A, (q15_t)0x5E71, + (q15_t)0xA975, (q15_t)0x5E50, (q15_t)0xA950, (q15_t)0x5E2D, + (q15_t)0xA92B, (q15_t)0x5E0B, (q15_t)0xA906, (q15_t)0x5DE9, + (q15_t)0xA8E2, (q15_t)0x5DC7, (q15_t)0xA8BD, (q15_t)0x5DA5, + (q15_t)0xA898, (q15_t)0x5D83, (q15_t)0xA873, (q15_t)0x5D60, + (q15_t)0xA84F, (q15_t)0x5D3E, (q15_t)0xA82A, (q15_t)0x5D1B, + (q15_t)0xA806, (q15_t)0x5CF9, (q15_t)0xA7E1, (q15_t)0x5CD6, + (q15_t)0xA7BD, (q15_t)0x5CB4, (q15_t)0xA798, (q15_t)0x5C91, + (q15_t)0xA774, (q15_t)0x5C6E, (q15_t)0xA750, (q15_t)0x5C4B, + (q15_t)0xA72B, (q15_t)0x5C29, (q15_t)0xA707, (q15_t)0x5C06, + (q15_t)0xA6E3, (q15_t)0x5BE3, (q15_t)0xA6BF, (q15_t)0x5BC0, + (q15_t)0xA69B, (q15_t)0x5B9D, (q15_t)0xA677, (q15_t)0x5B79, + (q15_t)0xA653, (q15_t)0x5B56, (q15_t)0xA62F, (q15_t)0x5B33, + (q15_t)0xA60C, (q15_t)0x5B10, (q15_t)0xA5E8, (q15_t)0x5AEC, + (q15_t)0xA5C4, (q15_t)0x5AC9, (q15_t)0xA5A1, (q15_t)0x5AA5, + (q15_t)0xA57D, (q15_t)0x5A82, (q15_t)0xA55A, (q15_t)0x5A5E, + (q15_t)0xA536, (q15_t)0x5A3B, (q15_t)0xA513, (q15_t)0x5A17, + (q15_t)0xA4EF, (q15_t)0x59F3, (q15_t)0xA4CC, (q15_t)0x59D0, + (q15_t)0xA4A9, (q15_t)0x59AC, (q15_t)0xA486, (q15_t)0x5988, + (q15_t)0xA462, (q15_t)0x5964, (q15_t)0xA43F, (q15_t)0x5940, + (q15_t)0xA41C, (q15_t)0x591C, (q15_t)0xA3F9, (q15_t)0x58F8, + (q15_t)0xA3D6, (q15_t)0x58D4, (q15_t)0xA3B4, (q15_t)0x58AF, + (q15_t)0xA391, (q15_t)0x588B, (q15_t)0xA36E, (q15_t)0x5867, + (q15_t)0xA34B, (q15_t)0x5842, (q15_t)0xA329, (q15_t)0x581E, + (q15_t)0xA306, (q15_t)0x57F9, (q15_t)0xA2E4, (q15_t)0x57D5, + (q15_t)0xA2C1, (q15_t)0x57B0, (q15_t)0xA29F, (q15_t)0x578C, + (q15_t)0xA27C, (q15_t)0x5767, (q15_t)0xA25A, (q15_t)0x5742, + (q15_t)0xA238, (q15_t)0x571D, (q15_t)0xA216, (q15_t)0x56F9, + (q15_t)0xA1F4, (q15_t)0x56D4, (q15_t)0xA1D2, (q15_t)0x56AF, + (q15_t)0xA1AF, (q15_t)0x568A, (q15_t)0xA18E, (q15_t)0x5665, + (q15_t)0xA16C, (q15_t)0x5640, (q15_t)0xA14A, (q15_t)0x561A, + (q15_t)0xA128, (q15_t)0x55F5, (q15_t)0xA106, (q15_t)0x55D0, + (q15_t)0xA0E5, (q15_t)0x55AB, (q15_t)0xA0C3, (q15_t)0x5585, + (q15_t)0xA0A1, (q15_t)0x5560, (q15_t)0xA080, (q15_t)0x553A, + (q15_t)0xA05F, (q15_t)0x5515, (q15_t)0xA03D, (q15_t)0x54EF, + (q15_t)0xA01C, (q15_t)0x54CA, (q15_t)0x9FFB, (q15_t)0x54A4, + (q15_t)0x9FD9, (q15_t)0x547E, (q15_t)0x9FB8, (q15_t)0x5458, + (q15_t)0x9F97, (q15_t)0x5433, (q15_t)0x9F76, (q15_t)0x540D, + (q15_t)0x9F55, (q15_t)0x53E7, (q15_t)0x9F34, (q15_t)0x53C1, + (q15_t)0x9F13, (q15_t)0x539B, (q15_t)0x9EF2, (q15_t)0x5375, + (q15_t)0x9ED2, (q15_t)0x534E, (q15_t)0x9EB1, (q15_t)0x5328, + (q15_t)0x9E90, (q15_t)0x5302, (q15_t)0x9E70, (q15_t)0x52DC, + (q15_t)0x9E4F, (q15_t)0x52B5, (q15_t)0x9E2F, (q15_t)0x528F, + (q15_t)0x9E0E, (q15_t)0x5269, (q15_t)0x9DEE, (q15_t)0x5242, + (q15_t)0x9DCE, (q15_t)0x521C, (q15_t)0x9DAE, (q15_t)0x51F5, + (q15_t)0x9D8E, (q15_t)0x51CE, (q15_t)0x9D6D, (q15_t)0x51A8, + (q15_t)0x9D4D, (q15_t)0x5181, (q15_t)0x9D2D, (q15_t)0x515A, + (q15_t)0x9D0D, (q15_t)0x5133, (q15_t)0x9CEE, (q15_t)0x510C, + (q15_t)0x9CCE, (q15_t)0x50E5, (q15_t)0x9CAE, (q15_t)0x50BF, + (q15_t)0x9C8E, (q15_t)0x5097, (q15_t)0x9C6F, (q15_t)0x5070, + (q15_t)0x9C4F, (q15_t)0x5049, (q15_t)0x9C30, (q15_t)0x5022, + (q15_t)0x9C10, (q15_t)0x4FFB, (q15_t)0x9BF1, (q15_t)0x4FD4, + (q15_t)0x9BD2, (q15_t)0x4FAC, (q15_t)0x9BB2, (q15_t)0x4F85, + (q15_t)0x9B93, (q15_t)0x4F5E, (q15_t)0x9B74, (q15_t)0x4F36, + (q15_t)0x9B55, (q15_t)0x4F0F, (q15_t)0x9B36, (q15_t)0x4EE7, + (q15_t)0x9B17, (q15_t)0x4EBF, (q15_t)0x9AF8, (q15_t)0x4E98, + (q15_t)0x9AD9, (q15_t)0x4E70, (q15_t)0x9ABA, (q15_t)0x4E48, + (q15_t)0x9A9C, (q15_t)0x4E21, (q15_t)0x9A7D, (q15_t)0x4DF9, + (q15_t)0x9A5F, (q15_t)0x4DD1, (q15_t)0x9A40, (q15_t)0x4DA9, + (q15_t)0x9A22, (q15_t)0x4D81, (q15_t)0x9A03, (q15_t)0x4D59, + (q15_t)0x99E5, (q15_t)0x4D31, (q15_t)0x99C6, (q15_t)0x4D09, + (q15_t)0x99A8, (q15_t)0x4CE1, (q15_t)0x998A, (q15_t)0x4CB8, + (q15_t)0x996C, (q15_t)0x4C90, (q15_t)0x994E, (q15_t)0x4C68, + (q15_t)0x9930, (q15_t)0x4C3F, (q15_t)0x9912, (q15_t)0x4C17, + (q15_t)0x98F4, (q15_t)0x4BEF, (q15_t)0x98D6, (q15_t)0x4BC6, + (q15_t)0x98B9, (q15_t)0x4B9E, (q15_t)0x989B, (q15_t)0x4B75, + (q15_t)0x987D, (q15_t)0x4B4C, (q15_t)0x9860, (q15_t)0x4B24, + (q15_t)0x9842, (q15_t)0x4AFB, (q15_t)0x9825, (q15_t)0x4AD2, + (q15_t)0x9808, (q15_t)0x4AA9, (q15_t)0x97EA, (q15_t)0x4A81, + (q15_t)0x97CD, (q15_t)0x4A58, (q15_t)0x97B0, (q15_t)0x4A2F, + (q15_t)0x9793, (q15_t)0x4A06, (q15_t)0x9776, (q15_t)0x49DD, + (q15_t)0x9759, (q15_t)0x49B4, (q15_t)0x973C, (q15_t)0x498A, + (q15_t)0x971F, (q15_t)0x4961, (q15_t)0x9702, (q15_t)0x4938, + (q15_t)0x96E6, (q15_t)0x490F, (q15_t)0x96C9, (q15_t)0x48E6, + (q15_t)0x96AC, (q15_t)0x48BC, (q15_t)0x9690, (q15_t)0x4893, + (q15_t)0x9673, (q15_t)0x4869, (q15_t)0x9657, (q15_t)0x4840, + (q15_t)0x963B, (q15_t)0x4816, (q15_t)0x961E, (q15_t)0x47ED, + (q15_t)0x9602, (q15_t)0x47C3, (q15_t)0x95E6, (q15_t)0x479A, + (q15_t)0x95CA, (q15_t)0x4770, (q15_t)0x95AE, (q15_t)0x4746, + (q15_t)0x9592, (q15_t)0x471C, (q15_t)0x9576, (q15_t)0x46F3, + (q15_t)0x955A, (q15_t)0x46C9, (q15_t)0x953E, (q15_t)0x469F, + (q15_t)0x9523, (q15_t)0x4675, (q15_t)0x9507, (q15_t)0x464B, + (q15_t)0x94EC, (q15_t)0x4621, (q15_t)0x94D0, (q15_t)0x45F7, + (q15_t)0x94B5, (q15_t)0x45CD, (q15_t)0x9499, (q15_t)0x45A3, + (q15_t)0x947E, (q15_t)0x4578, (q15_t)0x9463, (q15_t)0x454E, + (q15_t)0x9447, (q15_t)0x4524, (q15_t)0x942C, (q15_t)0x44FA, + (q15_t)0x9411, (q15_t)0x44CF, (q15_t)0x93F6, (q15_t)0x44A5, + (q15_t)0x93DB, (q15_t)0x447A, (q15_t)0x93C0, (q15_t)0x4450, + (q15_t)0x93A6, (q15_t)0x4425, (q15_t)0x938B, (q15_t)0x43FB, + (q15_t)0x9370, (q15_t)0x43D0, (q15_t)0x9356, (q15_t)0x43A5, + (q15_t)0x933B, (q15_t)0x437B, (q15_t)0x9321, (q15_t)0x4350, + (q15_t)0x9306, (q15_t)0x4325, (q15_t)0x92EC, (q15_t)0x42FA, + (q15_t)0x92D2, (q15_t)0x42D0, (q15_t)0x92B7, (q15_t)0x42A5, + (q15_t)0x929D, (q15_t)0x427A, (q15_t)0x9283, (q15_t)0x424F, + (q15_t)0x9269, (q15_t)0x4224, (q15_t)0x924F, (q15_t)0x41F9, + (q15_t)0x9235, (q15_t)0x41CE, (q15_t)0x921C, (q15_t)0x41A2, + (q15_t)0x9202, (q15_t)0x4177, (q15_t)0x91E8, (q15_t)0x414C, + (q15_t)0x91CF, (q15_t)0x4121, (q15_t)0x91B5, (q15_t)0x40F6, + (q15_t)0x919C, (q15_t)0x40CA, (q15_t)0x9182, (q15_t)0x409F, + (q15_t)0x9169, (q15_t)0x4073, (q15_t)0x9150, (q15_t)0x4048, + (q15_t)0x9136, (q15_t)0x401D, (q15_t)0x911D, (q15_t)0x3FF1, + (q15_t)0x9104, (q15_t)0x3FC5, (q15_t)0x90EB, (q15_t)0x3F9A, + (q15_t)0x90D2, (q15_t)0x3F6E, (q15_t)0x90B9, (q15_t)0x3F43, + (q15_t)0x90A0, (q15_t)0x3F17, (q15_t)0x9088, (q15_t)0x3EEB, + (q15_t)0x906F, (q15_t)0x3EBF, (q15_t)0x9056, (q15_t)0x3E93, + (q15_t)0x903E, (q15_t)0x3E68, (q15_t)0x9025, (q15_t)0x3E3C, + (q15_t)0x900D, (q15_t)0x3E10, (q15_t)0x8FF5, (q15_t)0x3DE4, + (q15_t)0x8FDC, (q15_t)0x3DB8, (q15_t)0x8FC4, (q15_t)0x3D8C, + (q15_t)0x8FAC, (q15_t)0x3D60, (q15_t)0x8F94, (q15_t)0x3D33, + (q15_t)0x8F7C, (q15_t)0x3D07, (q15_t)0x8F64, (q15_t)0x3CDB, + (q15_t)0x8F4C, (q15_t)0x3CAF, (q15_t)0x8F34, (q15_t)0x3C83, + (q15_t)0x8F1D, (q15_t)0x3C56, (q15_t)0x8F05, (q15_t)0x3C2A, + (q15_t)0x8EED, (q15_t)0x3BFD, (q15_t)0x8ED6, (q15_t)0x3BD1, + (q15_t)0x8EBE, (q15_t)0x3BA5, (q15_t)0x8EA7, (q15_t)0x3B78, + (q15_t)0x8E90, (q15_t)0x3B4C, (q15_t)0x8E79, (q15_t)0x3B1F, + (q15_t)0x8E61, (q15_t)0x3AF2, (q15_t)0x8E4A, (q15_t)0x3AC6, + (q15_t)0x8E33, (q15_t)0x3A99, (q15_t)0x8E1C, (q15_t)0x3A6C, + (q15_t)0x8E05, (q15_t)0x3A40, (q15_t)0x8DEE, (q15_t)0x3A13, + (q15_t)0x8DD8, (q15_t)0x39E6, (q15_t)0x8DC1, (q15_t)0x39B9, + (q15_t)0x8DAA, (q15_t)0x398C, (q15_t)0x8D94, (q15_t)0x395F, + (q15_t)0x8D7D, (q15_t)0x3932, (q15_t)0x8D67, (q15_t)0x3906, + (q15_t)0x8D50, (q15_t)0x38D8, (q15_t)0x8D3A, (q15_t)0x38AB, + (q15_t)0x8D24, (q15_t)0x387E, (q15_t)0x8D0E, (q15_t)0x3851, + (q15_t)0x8CF8, (q15_t)0x3824, (q15_t)0x8CE2, (q15_t)0x37F7, + (q15_t)0x8CCC, (q15_t)0x37CA, (q15_t)0x8CB6, (q15_t)0x379C, + (q15_t)0x8CA0, (q15_t)0x376F, (q15_t)0x8C8A, (q15_t)0x3742, + (q15_t)0x8C75, (q15_t)0x3714, (q15_t)0x8C5F, (q15_t)0x36E7, + (q15_t)0x8C4A, (q15_t)0x36BA, (q15_t)0x8C34, (q15_t)0x368C, + (q15_t)0x8C1F, (q15_t)0x365F, (q15_t)0x8C09, (q15_t)0x3631, + (q15_t)0x8BF4, (q15_t)0x3604, (q15_t)0x8BDF, (q15_t)0x35D6, + (q15_t)0x8BCA, (q15_t)0x35A8, (q15_t)0x8BB5, (q15_t)0x357B, + (q15_t)0x8BA0, (q15_t)0x354D, (q15_t)0x8B8B, (q15_t)0x351F, + (q15_t)0x8B76, (q15_t)0x34F2, (q15_t)0x8B61, (q15_t)0x34C4, + (q15_t)0x8B4D, (q15_t)0x3496, (q15_t)0x8B38, (q15_t)0x3468, + (q15_t)0x8B24, (q15_t)0x343A, (q15_t)0x8B0F, (q15_t)0x340C, + (q15_t)0x8AFB, (q15_t)0x33DE, (q15_t)0x8AE6, (q15_t)0x33B0, + (q15_t)0x8AD2, (q15_t)0x3382, (q15_t)0x8ABE, (q15_t)0x3354, + (q15_t)0x8AAA, (q15_t)0x3326, (q15_t)0x8A96, (q15_t)0x32F8, + (q15_t)0x8A82, (q15_t)0x32CA, (q15_t)0x8A6E, (q15_t)0x329C, + (q15_t)0x8A5A, (q15_t)0x326E, (q15_t)0x8A46, (q15_t)0x3240, + (q15_t)0x8A33, (q15_t)0x3211, (q15_t)0x8A1F, (q15_t)0x31E3, + (q15_t)0x8A0B, (q15_t)0x31B5, (q15_t)0x89F8, (q15_t)0x3186, + (q15_t)0x89E4, (q15_t)0x3158, (q15_t)0x89D1, (q15_t)0x312A, + (q15_t)0x89BE, (q15_t)0x30FB, (q15_t)0x89AB, (q15_t)0x30CD, + (q15_t)0x8997, (q15_t)0x309E, (q15_t)0x8984, (q15_t)0x3070, + (q15_t)0x8971, (q15_t)0x3041, (q15_t)0x895F, (q15_t)0x3013, + (q15_t)0x894C, (q15_t)0x2FE4, (q15_t)0x8939, (q15_t)0x2FB5, + (q15_t)0x8926, (q15_t)0x2F87, (q15_t)0x8914, (q15_t)0x2F58, + (q15_t)0x8901, (q15_t)0x2F29, (q15_t)0x88EF, (q15_t)0x2EFB, + (q15_t)0x88DC, (q15_t)0x2ECC, (q15_t)0x88CA, (q15_t)0x2E9D, + (q15_t)0x88B8, (q15_t)0x2E6E, (q15_t)0x88A5, (q15_t)0x2E3F, + (q15_t)0x8893, (q15_t)0x2E11, (q15_t)0x8881, (q15_t)0x2DE2, + (q15_t)0x886F, (q15_t)0x2DB3, (q15_t)0x885D, (q15_t)0x2D84, + (q15_t)0x884B, (q15_t)0x2D55, (q15_t)0x883A, (q15_t)0x2D26, + (q15_t)0x8828, (q15_t)0x2CF7, (q15_t)0x8816, (q15_t)0x2CC8, + (q15_t)0x8805, (q15_t)0x2C98, (q15_t)0x87F3, (q15_t)0x2C69, + (q15_t)0x87E2, (q15_t)0x2C3A, (q15_t)0x87D1, (q15_t)0x2C0B, + (q15_t)0x87BF, (q15_t)0x2BDC, (q15_t)0x87AE, (q15_t)0x2BAD, + (q15_t)0x879D, (q15_t)0x2B7D, (q15_t)0x878C, (q15_t)0x2B4E, + (q15_t)0x877B, (q15_t)0x2B1F, (q15_t)0x876A, (q15_t)0x2AEF, + (q15_t)0x8759, (q15_t)0x2AC0, (q15_t)0x8749, (q15_t)0x2A91, + (q15_t)0x8738, (q15_t)0x2A61, (q15_t)0x8727, (q15_t)0x2A32, + (q15_t)0x8717, (q15_t)0x2A02, (q15_t)0x8706, (q15_t)0x29D3, + (q15_t)0x86F6, (q15_t)0x29A3, (q15_t)0x86E6, (q15_t)0x2974, + (q15_t)0x86D5, (q15_t)0x2944, (q15_t)0x86C5, (q15_t)0x2915, + (q15_t)0x86B5, (q15_t)0x28E5, (q15_t)0x86A5, (q15_t)0x28B5, + (q15_t)0x8695, (q15_t)0x2886, (q15_t)0x8685, (q15_t)0x2856, + (q15_t)0x8675, (q15_t)0x2826, (q15_t)0x8666, (q15_t)0x27F6, + (q15_t)0x8656, (q15_t)0x27C7, (q15_t)0x8646, (q15_t)0x2797, + (q15_t)0x8637, (q15_t)0x2767, (q15_t)0x8627, (q15_t)0x2737, + (q15_t)0x8618, (q15_t)0x2707, (q15_t)0x8609, (q15_t)0x26D8, + (q15_t)0x85FA, (q15_t)0x26A8, (q15_t)0x85EA, (q15_t)0x2678, + (q15_t)0x85DB, (q15_t)0x2648, (q15_t)0x85CC, (q15_t)0x2618, + (q15_t)0x85BD, (q15_t)0x25E8, (q15_t)0x85AF, (q15_t)0x25B8, + (q15_t)0x85A0, (q15_t)0x2588, (q15_t)0x8591, (q15_t)0x2558, + (q15_t)0x8582, (q15_t)0x2528, (q15_t)0x8574, (q15_t)0x24F7, + (q15_t)0x8565, (q15_t)0x24C7, (q15_t)0x8557, (q15_t)0x2497, + (q15_t)0x8549, (q15_t)0x2467, (q15_t)0x853A, (q15_t)0x2437, + (q15_t)0x852C, (q15_t)0x2407, (q15_t)0x851E, (q15_t)0x23D6, + (q15_t)0x8510, (q15_t)0x23A6, (q15_t)0x8502, (q15_t)0x2376, + (q15_t)0x84F4, (q15_t)0x2345, (q15_t)0x84E6, (q15_t)0x2315, + (q15_t)0x84D9, (q15_t)0x22E5, (q15_t)0x84CB, (q15_t)0x22B4, + (q15_t)0x84BD, (q15_t)0x2284, (q15_t)0x84B0, (q15_t)0x2254, + (q15_t)0x84A2, (q15_t)0x2223, (q15_t)0x8495, (q15_t)0x21F3, + (q15_t)0x8488, (q15_t)0x21C2, (q15_t)0x847B, (q15_t)0x2192, + (q15_t)0x846D, (q15_t)0x2161, (q15_t)0x8460, (q15_t)0x2131, + (q15_t)0x8453, (q15_t)0x2100, (q15_t)0x8446, (q15_t)0x20D0, + (q15_t)0x843A, (q15_t)0x209F, (q15_t)0x842D, (q15_t)0x206E, + (q15_t)0x8420, (q15_t)0x203E, (q15_t)0x8414, (q15_t)0x200D, + (q15_t)0x8407, (q15_t)0x1FDC, (q15_t)0x83FA, (q15_t)0x1FAC, + (q15_t)0x83EE, (q15_t)0x1F7B, (q15_t)0x83E2, (q15_t)0x1F4A, + (q15_t)0x83D6, (q15_t)0x1F19, (q15_t)0x83C9, (q15_t)0x1EE9, + (q15_t)0x83BD, (q15_t)0x1EB8, (q15_t)0x83B1, (q15_t)0x1E87, + (q15_t)0x83A5, (q15_t)0x1E56, (q15_t)0x8399, (q15_t)0x1E25, + (q15_t)0x838E, (q15_t)0x1DF5, (q15_t)0x8382, (q15_t)0x1DC4, + (q15_t)0x8376, (q15_t)0x1D93, (q15_t)0x836B, (q15_t)0x1D62, + (q15_t)0x835F, (q15_t)0x1D31, (q15_t)0x8354, (q15_t)0x1D00, + (q15_t)0x8348, (q15_t)0x1CCF, (q15_t)0x833D, (q15_t)0x1C9E, + (q15_t)0x8332, (q15_t)0x1C6D, (q15_t)0x8327, (q15_t)0x1C3C, + (q15_t)0x831C, (q15_t)0x1C0B, (q15_t)0x8311, (q15_t)0x1BDA, + (q15_t)0x8306, (q15_t)0x1BA9, (q15_t)0x82FB, (q15_t)0x1B78, + (q15_t)0x82F0, (q15_t)0x1B47, (q15_t)0x82E6, (q15_t)0x1B16, + (q15_t)0x82DB, (q15_t)0x1AE4, (q15_t)0x82D0, (q15_t)0x1AB3, + (q15_t)0x82C6, (q15_t)0x1A82, (q15_t)0x82BC, (q15_t)0x1A51, + (q15_t)0x82B1, (q15_t)0x1A20, (q15_t)0x82A7, (q15_t)0x19EF, + (q15_t)0x829D, (q15_t)0x19BD, (q15_t)0x8293, (q15_t)0x198C, + (q15_t)0x8289, (q15_t)0x195B, (q15_t)0x827F, (q15_t)0x192A, + (q15_t)0x8275, (q15_t)0x18F8, (q15_t)0x826B, (q15_t)0x18C7, + (q15_t)0x8262, (q15_t)0x1896, (q15_t)0x8258, (q15_t)0x1864, + (q15_t)0x824F, (q15_t)0x1833, (q15_t)0x8245, (q15_t)0x1802, + (q15_t)0x823C, (q15_t)0x17D0, (q15_t)0x8232, (q15_t)0x179F, + (q15_t)0x8229, (q15_t)0x176D, (q15_t)0x8220, (q15_t)0x173C, + (q15_t)0x8217, (q15_t)0x170A, (q15_t)0x820E, (q15_t)0x16D9, + (q15_t)0x8205, (q15_t)0x16A8, (q15_t)0x81FC, (q15_t)0x1676, + (q15_t)0x81F3, (q15_t)0x1645, (q15_t)0x81EB, (q15_t)0x1613, + (q15_t)0x81E2, (q15_t)0x15E2, (q15_t)0x81D9, (q15_t)0x15B0, + (q15_t)0x81D1, (q15_t)0x157F, (q15_t)0x81C8, (q15_t)0x154D, + (q15_t)0x81C0, (q15_t)0x151B, (q15_t)0x81B8, (q15_t)0x14EA, + (q15_t)0x81B0, (q15_t)0x14B8, (q15_t)0x81A8, (q15_t)0x1487, + (q15_t)0x81A0, (q15_t)0x1455, (q15_t)0x8198, (q15_t)0x1423, + (q15_t)0x8190, (q15_t)0x13F2, (q15_t)0x8188, (q15_t)0x13C0, + (q15_t)0x8180, (q15_t)0x138E, (q15_t)0x8179, (q15_t)0x135D, + (q15_t)0x8171, (q15_t)0x132B, (q15_t)0x816A, (q15_t)0x12F9, + (q15_t)0x8162, (q15_t)0x12C8, (q15_t)0x815B, (q15_t)0x1296, + (q15_t)0x8154, (q15_t)0x1264, (q15_t)0x814C, (q15_t)0x1232, + (q15_t)0x8145, (q15_t)0x1201, (q15_t)0x813E, (q15_t)0x11CF, + (q15_t)0x8137, (q15_t)0x119D, (q15_t)0x8130, (q15_t)0x116B, + (q15_t)0x812A, (q15_t)0x1139, (q15_t)0x8123, (q15_t)0x1108, + (q15_t)0x811C, (q15_t)0x10D6, (q15_t)0x8116, (q15_t)0x10A4, + (q15_t)0x810F, (q15_t)0x1072, (q15_t)0x8109, (q15_t)0x1040, + (q15_t)0x8102, (q15_t)0x100E, (q15_t)0x80FC, (q15_t)0x0FDD, + (q15_t)0x80F6, (q15_t)0x0FAB, (q15_t)0x80F0, (q15_t)0x0F79, + (q15_t)0x80EA, (q15_t)0x0F47, (q15_t)0x80E4, (q15_t)0x0F15, + (q15_t)0x80DE, (q15_t)0x0EE3, (q15_t)0x80D8, (q15_t)0x0EB1, + (q15_t)0x80D2, (q15_t)0x0E7F, (q15_t)0x80CD, (q15_t)0x0E4D, + (q15_t)0x80C7, (q15_t)0x0E1B, (q15_t)0x80C2, (q15_t)0x0DE9, + (q15_t)0x80BC, (q15_t)0x0DB7, (q15_t)0x80B7, (q15_t)0x0D85, + (q15_t)0x80B2, (q15_t)0x0D53, (q15_t)0x80AC, (q15_t)0x0D21, + (q15_t)0x80A7, (q15_t)0x0CEF, (q15_t)0x80A2, (q15_t)0x0CBD, + (q15_t)0x809D, (q15_t)0x0C8B, (q15_t)0x8098, (q15_t)0x0C59, + (q15_t)0x8094, (q15_t)0x0C27, (q15_t)0x808F, (q15_t)0x0BF5, + (q15_t)0x808A, (q15_t)0x0BC3, (q15_t)0x8086, (q15_t)0x0B91, + (q15_t)0x8081, (q15_t)0x0B5F, (q15_t)0x807D, (q15_t)0x0B2D, + (q15_t)0x8078, (q15_t)0x0AFB, (q15_t)0x8074, (q15_t)0x0AC9, + (q15_t)0x8070, (q15_t)0x0A97, (q15_t)0x806C, (q15_t)0x0A65, + (q15_t)0x8068, (q15_t)0x0A33, (q15_t)0x8064, (q15_t)0x0A00, + (q15_t)0x8060, (q15_t)0x09CE, (q15_t)0x805C, (q15_t)0x099C, + (q15_t)0x8058, (q15_t)0x096A, (q15_t)0x8055, (q15_t)0x0938, + (q15_t)0x8051, (q15_t)0x0906, (q15_t)0x804E, (q15_t)0x08D4, + (q15_t)0x804A, (q15_t)0x08A2, (q15_t)0x8047, (q15_t)0x086F, + (q15_t)0x8043, (q15_t)0x083D, (q15_t)0x8040, (q15_t)0x080B, + (q15_t)0x803D, (q15_t)0x07D9, (q15_t)0x803A, (q15_t)0x07A7, + (q15_t)0x8037, (q15_t)0x0775, (q15_t)0x8034, (q15_t)0x0742, + (q15_t)0x8031, (q15_t)0x0710, (q15_t)0x802F, (q15_t)0x06DE, + (q15_t)0x802C, (q15_t)0x06AC, (q15_t)0x8029, (q15_t)0x067A, + (q15_t)0x8027, (q15_t)0x0647, (q15_t)0x8025, (q15_t)0x0615, + (q15_t)0x8022, (q15_t)0x05E3, (q15_t)0x8020, (q15_t)0x05B1, + (q15_t)0x801E, (q15_t)0x057F, (q15_t)0x801C, (q15_t)0x054C, + (q15_t)0x801A, (q15_t)0x051A, (q15_t)0x8018, (q15_t)0x04E8, + (q15_t)0x8016, (q15_t)0x04B6, (q15_t)0x8014, (q15_t)0x0483, + (q15_t)0x8012, (q15_t)0x0451, (q15_t)0x8011, (q15_t)0x041F, + (q15_t)0x800F, (q15_t)0x03ED, (q15_t)0x800D, (q15_t)0x03BA, + (q15_t)0x800C, (q15_t)0x0388, (q15_t)0x800B, (q15_t)0x0356, + (q15_t)0x8009, (q15_t)0x0324, (q15_t)0x8008, (q15_t)0x02F1, + (q15_t)0x8007, (q15_t)0x02BF, (q15_t)0x8006, (q15_t)0x028D, + (q15_t)0x8005, (q15_t)0x025B, (q15_t)0x8004, (q15_t)0x0228, + (q15_t)0x8003, (q15_t)0x01F6, (q15_t)0x8003, (q15_t)0x01C4, + (q15_t)0x8002, (q15_t)0x0192, (q15_t)0x8001, (q15_t)0x015F, + (q15_t)0x8001, (q15_t)0x012D, (q15_t)0x8000, (q15_t)0x00FB, + (q15_t)0x8000, (q15_t)0x00C9, (q15_t)0x8000, (q15_t)0x0096, + (q15_t)0x8000, (q15_t)0x0064, (q15_t)0x8000, (q15_t)0x0032, + (q15_t)0x8000, (q15_t)0x0000, (q15_t)0x8000, (q15_t)0xFFCD, + (q15_t)0x8000, (q15_t)0xFF9B, (q15_t)0x8000, (q15_t)0xFF69, + (q15_t)0x8000, (q15_t)0xFF36, (q15_t)0x8000, (q15_t)0xFF04, + (q15_t)0x8001, (q15_t)0xFED2, (q15_t)0x8001, (q15_t)0xFEA0, + (q15_t)0x8002, (q15_t)0xFE6D, (q15_t)0x8003, (q15_t)0xFE3B, + (q15_t)0x8003, (q15_t)0xFE09, (q15_t)0x8004, (q15_t)0xFDD7, + (q15_t)0x8005, (q15_t)0xFDA4, (q15_t)0x8006, (q15_t)0xFD72, + (q15_t)0x8007, (q15_t)0xFD40, (q15_t)0x8008, (q15_t)0xFD0E, + (q15_t)0x8009, (q15_t)0xFCDB, (q15_t)0x800B, (q15_t)0xFCA9, + (q15_t)0x800C, (q15_t)0xFC77, (q15_t)0x800D, (q15_t)0xFC45, + (q15_t)0x800F, (q15_t)0xFC12, (q15_t)0x8011, (q15_t)0xFBE0, + (q15_t)0x8012, (q15_t)0xFBAE, (q15_t)0x8014, (q15_t)0xFB7C, + (q15_t)0x8016, (q15_t)0xFB49, (q15_t)0x8018, (q15_t)0xFB17, + (q15_t)0x801A, (q15_t)0xFAE5, (q15_t)0x801C, (q15_t)0xFAB3, + (q15_t)0x801E, (q15_t)0xFA80, (q15_t)0x8020, (q15_t)0xFA4E, + (q15_t)0x8022, (q15_t)0xFA1C, (q15_t)0x8025, (q15_t)0xF9EA, + (q15_t)0x8027, (q15_t)0xF9B8, (q15_t)0x8029, (q15_t)0xF985, + (q15_t)0x802C, (q15_t)0xF953, (q15_t)0x802F, (q15_t)0xF921, + (q15_t)0x8031, (q15_t)0xF8EF, (q15_t)0x8034, (q15_t)0xF8BD, + (q15_t)0x8037, (q15_t)0xF88A, (q15_t)0x803A, (q15_t)0xF858, + (q15_t)0x803D, (q15_t)0xF826, (q15_t)0x8040, (q15_t)0xF7F4, + (q15_t)0x8043, (q15_t)0xF7C2, (q15_t)0x8047, (q15_t)0xF790, + (q15_t)0x804A, (q15_t)0xF75D, (q15_t)0x804E, (q15_t)0xF72B, + (q15_t)0x8051, (q15_t)0xF6F9, (q15_t)0x8055, (q15_t)0xF6C7, + (q15_t)0x8058, (q15_t)0xF695, (q15_t)0x805C, (q15_t)0xF663, + (q15_t)0x8060, (q15_t)0xF631, (q15_t)0x8064, (q15_t)0xF5FF, + (q15_t)0x8068, (q15_t)0xF5CC, (q15_t)0x806C, (q15_t)0xF59A, + (q15_t)0x8070, (q15_t)0xF568, (q15_t)0x8074, (q15_t)0xF536, + (q15_t)0x8078, (q15_t)0xF504, (q15_t)0x807D, (q15_t)0xF4D2, + (q15_t)0x8081, (q15_t)0xF4A0, (q15_t)0x8086, (q15_t)0xF46E, + (q15_t)0x808A, (q15_t)0xF43C, (q15_t)0x808F, (q15_t)0xF40A, + (q15_t)0x8094, (q15_t)0xF3D8, (q15_t)0x8098, (q15_t)0xF3A6, + (q15_t)0x809D, (q15_t)0xF374, (q15_t)0x80A2, (q15_t)0xF342, + (q15_t)0x80A7, (q15_t)0xF310, (q15_t)0x80AC, (q15_t)0xF2DE, + (q15_t)0x80B2, (q15_t)0xF2AC, (q15_t)0x80B7, (q15_t)0xF27A, + (q15_t)0x80BC, (q15_t)0xF248, (q15_t)0x80C2, (q15_t)0xF216, + (q15_t)0x80C7, (q15_t)0xF1E4, (q15_t)0x80CD, (q15_t)0xF1B2, + (q15_t)0x80D2, (q15_t)0xF180, (q15_t)0x80D8, (q15_t)0xF14E, + (q15_t)0x80DE, (q15_t)0xF11C, (q15_t)0x80E4, (q15_t)0xF0EA, + (q15_t)0x80EA, (q15_t)0xF0B8, (q15_t)0x80F0, (q15_t)0xF086, + (q15_t)0x80F6, (q15_t)0xF054, (q15_t)0x80FC, (q15_t)0xF022, + (q15_t)0x8102, (q15_t)0xEFF1, (q15_t)0x8109, (q15_t)0xEFBF, + (q15_t)0x810F, (q15_t)0xEF8D, (q15_t)0x8116, (q15_t)0xEF5B, + (q15_t)0x811C, (q15_t)0xEF29, (q15_t)0x8123, (q15_t)0xEEF7, + (q15_t)0x812A, (q15_t)0xEEC6, (q15_t)0x8130, (q15_t)0xEE94, + (q15_t)0x8137, (q15_t)0xEE62, (q15_t)0x813E, (q15_t)0xEE30, + (q15_t)0x8145, (q15_t)0xEDFE, (q15_t)0x814C, (q15_t)0xEDCD, + (q15_t)0x8154, (q15_t)0xED9B, (q15_t)0x815B, (q15_t)0xED69, + (q15_t)0x8162, (q15_t)0xED37, (q15_t)0x816A, (q15_t)0xED06, + (q15_t)0x8171, (q15_t)0xECD4, (q15_t)0x8179, (q15_t)0xECA2, + (q15_t)0x8180, (q15_t)0xEC71, (q15_t)0x8188, (q15_t)0xEC3F, + (q15_t)0x8190, (q15_t)0xEC0D, (q15_t)0x8198, (q15_t)0xEBDC, + (q15_t)0x81A0, (q15_t)0xEBAA, (q15_t)0x81A8, (q15_t)0xEB78, + (q15_t)0x81B0, (q15_t)0xEB47, (q15_t)0x81B8, (q15_t)0xEB15, + (q15_t)0x81C0, (q15_t)0xEAE4, (q15_t)0x81C8, (q15_t)0xEAB2, + (q15_t)0x81D1, (q15_t)0xEA80, (q15_t)0x81D9, (q15_t)0xEA4F, + (q15_t)0x81E2, (q15_t)0xEA1D, (q15_t)0x81EB, (q15_t)0xE9EC, + (q15_t)0x81F3, (q15_t)0xE9BA, (q15_t)0x81FC, (q15_t)0xE989, + (q15_t)0x8205, (q15_t)0xE957, (q15_t)0x820E, (q15_t)0xE926, + (q15_t)0x8217, (q15_t)0xE8F5, (q15_t)0x8220, (q15_t)0xE8C3, + (q15_t)0x8229, (q15_t)0xE892, (q15_t)0x8232, (q15_t)0xE860, + (q15_t)0x823C, (q15_t)0xE82F, (q15_t)0x8245, (q15_t)0xE7FD, + (q15_t)0x824F, (q15_t)0xE7CC, (q15_t)0x8258, (q15_t)0xE79B, + (q15_t)0x8262, (q15_t)0xE769, (q15_t)0x826B, (q15_t)0xE738, + (q15_t)0x8275, (q15_t)0xE707, (q15_t)0x827F, (q15_t)0xE6D5, + (q15_t)0x8289, (q15_t)0xE6A4, (q15_t)0x8293, (q15_t)0xE673, + (q15_t)0x829D, (q15_t)0xE642, (q15_t)0x82A7, (q15_t)0xE610, + (q15_t)0x82B1, (q15_t)0xE5DF, (q15_t)0x82BC, (q15_t)0xE5AE, + (q15_t)0x82C6, (q15_t)0xE57D, (q15_t)0x82D0, (q15_t)0xE54C, + (q15_t)0x82DB, (q15_t)0xE51B, (q15_t)0x82E6, (q15_t)0xE4E9, + (q15_t)0x82F0, (q15_t)0xE4B8, (q15_t)0x82FB, (q15_t)0xE487, + (q15_t)0x8306, (q15_t)0xE456, (q15_t)0x8311, (q15_t)0xE425, + (q15_t)0x831C, (q15_t)0xE3F4, (q15_t)0x8327, (q15_t)0xE3C3, + (q15_t)0x8332, (q15_t)0xE392, (q15_t)0x833D, (q15_t)0xE361, + (q15_t)0x8348, (q15_t)0xE330, (q15_t)0x8354, (q15_t)0xE2FF, + (q15_t)0x835F, (q15_t)0xE2CE, (q15_t)0x836B, (q15_t)0xE29D, + (q15_t)0x8376, (q15_t)0xE26C, (q15_t)0x8382, (q15_t)0xE23B, + (q15_t)0x838E, (q15_t)0xE20A, (q15_t)0x8399, (q15_t)0xE1DA, + (q15_t)0x83A5, (q15_t)0xE1A9, (q15_t)0x83B1, (q15_t)0xE178, + (q15_t)0x83BD, (q15_t)0xE147, (q15_t)0x83C9, (q15_t)0xE116, + (q15_t)0x83D6, (q15_t)0xE0E6, (q15_t)0x83E2, (q15_t)0xE0B5, + (q15_t)0x83EE, (q15_t)0xE084, (q15_t)0x83FA, (q15_t)0xE053, + (q15_t)0x8407, (q15_t)0xE023, (q15_t)0x8414, (q15_t)0xDFF2, + (q15_t)0x8420, (q15_t)0xDFC1, (q15_t)0x842D, (q15_t)0xDF91, + (q15_t)0x843A, (q15_t)0xDF60, (q15_t)0x8446, (q15_t)0xDF2F, + (q15_t)0x8453, (q15_t)0xDEFF, (q15_t)0x8460, (q15_t)0xDECE, + (q15_t)0x846D, (q15_t)0xDE9E, (q15_t)0x847B, (q15_t)0xDE6D, + (q15_t)0x8488, (q15_t)0xDE3D, (q15_t)0x8495, (q15_t)0xDE0C, + (q15_t)0x84A2, (q15_t)0xDDDC, (q15_t)0x84B0, (q15_t)0xDDAB, + (q15_t)0x84BD, (q15_t)0xDD7B, (q15_t)0x84CB, (q15_t)0xDD4B, + (q15_t)0x84D9, (q15_t)0xDD1A, (q15_t)0x84E6, (q15_t)0xDCEA, + (q15_t)0x84F4, (q15_t)0xDCBA, (q15_t)0x8502, (q15_t)0xDC89, + (q15_t)0x8510, (q15_t)0xDC59, (q15_t)0x851E, (q15_t)0xDC29, + (q15_t)0x852C, (q15_t)0xDBF8, (q15_t)0x853A, (q15_t)0xDBC8, + (q15_t)0x8549, (q15_t)0xDB98, (q15_t)0x8557, (q15_t)0xDB68, + (q15_t)0x8565, (q15_t)0xDB38, (q15_t)0x8574, (q15_t)0xDB08, + (q15_t)0x8582, (q15_t)0xDAD7, (q15_t)0x8591, (q15_t)0xDAA7, + (q15_t)0x85A0, (q15_t)0xDA77, (q15_t)0x85AF, (q15_t)0xDA47, + (q15_t)0x85BD, (q15_t)0xDA17, (q15_t)0x85CC, (q15_t)0xD9E7, + (q15_t)0x85DB, (q15_t)0xD9B7, (q15_t)0x85EA, (q15_t)0xD987, + (q15_t)0x85FA, (q15_t)0xD957, (q15_t)0x8609, (q15_t)0xD927, + (q15_t)0x8618, (q15_t)0xD8F8, (q15_t)0x8627, (q15_t)0xD8C8, + (q15_t)0x8637, (q15_t)0xD898, (q15_t)0x8646, (q15_t)0xD868, + (q15_t)0x8656, (q15_t)0xD838, (q15_t)0x8666, (q15_t)0xD809, + (q15_t)0x8675, (q15_t)0xD7D9, (q15_t)0x8685, (q15_t)0xD7A9, + (q15_t)0x8695, (q15_t)0xD779, (q15_t)0x86A5, (q15_t)0xD74A, + (q15_t)0x86B5, (q15_t)0xD71A, (q15_t)0x86C5, (q15_t)0xD6EA, + (q15_t)0x86D5, (q15_t)0xD6BB, (q15_t)0x86E6, (q15_t)0xD68B, + (q15_t)0x86F6, (q15_t)0xD65C, (q15_t)0x8706, (q15_t)0xD62C, + (q15_t)0x8717, (q15_t)0xD5FD, (q15_t)0x8727, (q15_t)0xD5CD, + (q15_t)0x8738, (q15_t)0xD59E, (q15_t)0x8749, (q15_t)0xD56E, + (q15_t)0x8759, (q15_t)0xD53F, (q15_t)0x876A, (q15_t)0xD510, + (q15_t)0x877B, (q15_t)0xD4E0, (q15_t)0x878C, (q15_t)0xD4B1, + (q15_t)0x879D, (q15_t)0xD482, (q15_t)0x87AE, (q15_t)0xD452, + (q15_t)0x87BF, (q15_t)0xD423, (q15_t)0x87D1, (q15_t)0xD3F4, + (q15_t)0x87E2, (q15_t)0xD3C5, (q15_t)0x87F3, (q15_t)0xD396, + (q15_t)0x8805, (q15_t)0xD367, (q15_t)0x8816, (q15_t)0xD337, + (q15_t)0x8828, (q15_t)0xD308, (q15_t)0x883A, (q15_t)0xD2D9, + (q15_t)0x884B, (q15_t)0xD2AA, (q15_t)0x885D, (q15_t)0xD27B, + (q15_t)0x886F, (q15_t)0xD24C, (q15_t)0x8881, (q15_t)0xD21D, + (q15_t)0x8893, (q15_t)0xD1EE, (q15_t)0x88A5, (q15_t)0xD1C0, + (q15_t)0x88B8, (q15_t)0xD191, (q15_t)0x88CA, (q15_t)0xD162, + (q15_t)0x88DC, (q15_t)0xD133, (q15_t)0x88EF, (q15_t)0xD104, + (q15_t)0x8901, (q15_t)0xD0D6, (q15_t)0x8914, (q15_t)0xD0A7, + (q15_t)0x8926, (q15_t)0xD078, (q15_t)0x8939, (q15_t)0xD04A, + (q15_t)0x894C, (q15_t)0xD01B, (q15_t)0x895F, (q15_t)0xCFEC, + (q15_t)0x8971, (q15_t)0xCFBE, (q15_t)0x8984, (q15_t)0xCF8F, + (q15_t)0x8997, (q15_t)0xCF61, (q15_t)0x89AB, (q15_t)0xCF32, + (q15_t)0x89BE, (q15_t)0xCF04, (q15_t)0x89D1, (q15_t)0xCED5, + (q15_t)0x89E4, (q15_t)0xCEA7, (q15_t)0x89F8, (q15_t)0xCE79, + (q15_t)0x8A0B, (q15_t)0xCE4A, (q15_t)0x8A1F, (q15_t)0xCE1C, + (q15_t)0x8A33, (q15_t)0xCDEE, (q15_t)0x8A46, (q15_t)0xCDBF, + (q15_t)0x8A5A, (q15_t)0xCD91, (q15_t)0x8A6E, (q15_t)0xCD63, + (q15_t)0x8A82, (q15_t)0xCD35, (q15_t)0x8A96, (q15_t)0xCD07, + (q15_t)0x8AAA, (q15_t)0xCCD9, (q15_t)0x8ABE, (q15_t)0xCCAB, + (q15_t)0x8AD2, (q15_t)0xCC7D, (q15_t)0x8AE6, (q15_t)0xCC4F, + (q15_t)0x8AFB, (q15_t)0xCC21, (q15_t)0x8B0F, (q15_t)0xCBF3, + (q15_t)0x8B24, (q15_t)0xCBC5, (q15_t)0x8B38, (q15_t)0xCB97, + (q15_t)0x8B4D, (q15_t)0xCB69, (q15_t)0x8B61, (q15_t)0xCB3B, + (q15_t)0x8B76, (q15_t)0xCB0D, (q15_t)0x8B8B, (q15_t)0xCAE0, + (q15_t)0x8BA0, (q15_t)0xCAB2, (q15_t)0x8BB5, (q15_t)0xCA84, + (q15_t)0x8BCA, (q15_t)0xCA57, (q15_t)0x8BDF, (q15_t)0xCA29, + (q15_t)0x8BF4, (q15_t)0xC9FB, (q15_t)0x8C09, (q15_t)0xC9CE, + (q15_t)0x8C1F, (q15_t)0xC9A0, (q15_t)0x8C34, (q15_t)0xC973, + (q15_t)0x8C4A, (q15_t)0xC945, (q15_t)0x8C5F, (q15_t)0xC918, + (q15_t)0x8C75, (q15_t)0xC8EB, (q15_t)0x8C8A, (q15_t)0xC8BD, + (q15_t)0x8CA0, (q15_t)0xC890, (q15_t)0x8CB6, (q15_t)0xC863, + (q15_t)0x8CCC, (q15_t)0xC835, (q15_t)0x8CE2, (q15_t)0xC808, + (q15_t)0x8CF8, (q15_t)0xC7DB, (q15_t)0x8D0E, (q15_t)0xC7AE, + (q15_t)0x8D24, (q15_t)0xC781, (q15_t)0x8D3A, (q15_t)0xC754, + (q15_t)0x8D50, (q15_t)0xC727, (q15_t)0x8D67, (q15_t)0xC6F9, + (q15_t)0x8D7D, (q15_t)0xC6CD, (q15_t)0x8D94, (q15_t)0xC6A0, + (q15_t)0x8DAA, (q15_t)0xC673, (q15_t)0x8DC1, (q15_t)0xC646, + (q15_t)0x8DD8, (q15_t)0xC619, (q15_t)0x8DEE, (q15_t)0xC5EC, + (q15_t)0x8E05, (q15_t)0xC5BF, (q15_t)0x8E1C, (q15_t)0xC593, + (q15_t)0x8E33, (q15_t)0xC566, (q15_t)0x8E4A, (q15_t)0xC539, + (q15_t)0x8E61, (q15_t)0xC50D, (q15_t)0x8E79, (q15_t)0xC4E0, + (q15_t)0x8E90, (q15_t)0xC4B3, (q15_t)0x8EA7, (q15_t)0xC487, + (q15_t)0x8EBE, (q15_t)0xC45A, (q15_t)0x8ED6, (q15_t)0xC42E, + (q15_t)0x8EED, (q15_t)0xC402, (q15_t)0x8F05, (q15_t)0xC3D5, + (q15_t)0x8F1D, (q15_t)0xC3A9, (q15_t)0x8F34, (q15_t)0xC37C, + (q15_t)0x8F4C, (q15_t)0xC350, (q15_t)0x8F64, (q15_t)0xC324, + (q15_t)0x8F7C, (q15_t)0xC2F8, (q15_t)0x8F94, (q15_t)0xC2CC, + (q15_t)0x8FAC, (q15_t)0xC29F, (q15_t)0x8FC4, (q15_t)0xC273, + (q15_t)0x8FDC, (q15_t)0xC247, (q15_t)0x8FF5, (q15_t)0xC21B, + (q15_t)0x900D, (q15_t)0xC1EF, (q15_t)0x9025, (q15_t)0xC1C3, + (q15_t)0x903E, (q15_t)0xC197, (q15_t)0x9056, (q15_t)0xC16C, + (q15_t)0x906F, (q15_t)0xC140, (q15_t)0x9088, (q15_t)0xC114, + (q15_t)0x90A0, (q15_t)0xC0E8, (q15_t)0x90B9, (q15_t)0xC0BC, + (q15_t)0x90D2, (q15_t)0xC091, (q15_t)0x90EB, (q15_t)0xC065, + (q15_t)0x9104, (q15_t)0xC03A, (q15_t)0x911D, (q15_t)0xC00E, + (q15_t)0x9136, (q15_t)0xBFE2, (q15_t)0x9150, (q15_t)0xBFB7, + (q15_t)0x9169, (q15_t)0xBF8C, (q15_t)0x9182, (q15_t)0xBF60, + (q15_t)0x919C, (q15_t)0xBF35, (q15_t)0x91B5, (q15_t)0xBF09, + (q15_t)0x91CF, (q15_t)0xBEDE, (q15_t)0x91E8, (q15_t)0xBEB3, + (q15_t)0x9202, (q15_t)0xBE88, (q15_t)0x921C, (q15_t)0xBE5D, + (q15_t)0x9235, (q15_t)0xBE31, (q15_t)0x924F, (q15_t)0xBE06, + (q15_t)0x9269, (q15_t)0xBDDB, (q15_t)0x9283, (q15_t)0xBDB0, + (q15_t)0x929D, (q15_t)0xBD85, (q15_t)0x92B7, (q15_t)0xBD5A, + (q15_t)0x92D2, (q15_t)0xBD2F, (q15_t)0x92EC, (q15_t)0xBD05, + (q15_t)0x9306, (q15_t)0xBCDA, (q15_t)0x9321, (q15_t)0xBCAF, + (q15_t)0x933B, (q15_t)0xBC84, (q15_t)0x9356, (q15_t)0xBC5A, + (q15_t)0x9370, (q15_t)0xBC2F, (q15_t)0x938B, (q15_t)0xBC04, + (q15_t)0x93A6, (q15_t)0xBBDA, (q15_t)0x93C0, (q15_t)0xBBAF, + (q15_t)0x93DB, (q15_t)0xBB85, (q15_t)0x93F6, (q15_t)0xBB5A, + (q15_t)0x9411, (q15_t)0xBB30, (q15_t)0x942C, (q15_t)0xBB05, + (q15_t)0x9447, (q15_t)0xBADB, (q15_t)0x9463, (q15_t)0xBAB1, + (q15_t)0x947E, (q15_t)0xBA87, (q15_t)0x9499, (q15_t)0xBA5C, + (q15_t)0x94B5, (q15_t)0xBA32, (q15_t)0x94D0, (q15_t)0xBA08, + (q15_t)0x94EC, (q15_t)0xB9DE, (q15_t)0x9507, (q15_t)0xB9B4, + (q15_t)0x9523, (q15_t)0xB98A, (q15_t)0x953E, (q15_t)0xB960, + (q15_t)0x955A, (q15_t)0xB936, (q15_t)0x9576, (q15_t)0xB90C, + (q15_t)0x9592, (q15_t)0xB8E3, (q15_t)0x95AE, (q15_t)0xB8B9, + (q15_t)0x95CA, (q15_t)0xB88F, (q15_t)0x95E6, (q15_t)0xB865, + (q15_t)0x9602, (q15_t)0xB83C, (q15_t)0x961E, (q15_t)0xB812, + (q15_t)0x963B, (q15_t)0xB7E9, (q15_t)0x9657, (q15_t)0xB7BF, + (q15_t)0x9673, (q15_t)0xB796, (q15_t)0x9690, (q15_t)0xB76C, + (q15_t)0x96AC, (q15_t)0xB743, (q15_t)0x96C9, (q15_t)0xB719, + (q15_t)0x96E6, (q15_t)0xB6F0, (q15_t)0x9702, (q15_t)0xB6C7, + (q15_t)0x971F, (q15_t)0xB69E, (q15_t)0x973C, (q15_t)0xB675, + (q15_t)0x9759, (q15_t)0xB64B, (q15_t)0x9776, (q15_t)0xB622, + (q15_t)0x9793, (q15_t)0xB5F9, (q15_t)0x97B0, (q15_t)0xB5D0, + (q15_t)0x97CD, (q15_t)0xB5A7, (q15_t)0x97EA, (q15_t)0xB57E, + (q15_t)0x9808, (q15_t)0xB556, (q15_t)0x9825, (q15_t)0xB52D, + (q15_t)0x9842, (q15_t)0xB504, (q15_t)0x9860, (q15_t)0xB4DB, + (q15_t)0x987D, (q15_t)0xB4B3, (q15_t)0x989B, (q15_t)0xB48A, + (q15_t)0x98B9, (q15_t)0xB461, (q15_t)0x98D6, (q15_t)0xB439, + (q15_t)0x98F4, (q15_t)0xB410, (q15_t)0x9912, (q15_t)0xB3E8, + (q15_t)0x9930, (q15_t)0xB3C0, (q15_t)0x994E, (q15_t)0xB397, + (q15_t)0x996C, (q15_t)0xB36F, (q15_t)0x998A, (q15_t)0xB347, + (q15_t)0x99A8, (q15_t)0xB31E, (q15_t)0x99C6, (q15_t)0xB2F6, + (q15_t)0x99E5, (q15_t)0xB2CE, (q15_t)0x9A03, (q15_t)0xB2A6, + (q15_t)0x9A22, (q15_t)0xB27E, (q15_t)0x9A40, (q15_t)0xB256, + (q15_t)0x9A5F, (q15_t)0xB22E, (q15_t)0x9A7D, (q15_t)0xB206, + (q15_t)0x9A9C, (q15_t)0xB1DE, (q15_t)0x9ABA, (q15_t)0xB1B7, + (q15_t)0x9AD9, (q15_t)0xB18F, (q15_t)0x9AF8, (q15_t)0xB167, + (q15_t)0x9B17, (q15_t)0xB140, (q15_t)0x9B36, (q15_t)0xB118, + (q15_t)0x9B55, (q15_t)0xB0F0, (q15_t)0x9B74, (q15_t)0xB0C9, + (q15_t)0x9B93, (q15_t)0xB0A1, (q15_t)0x9BB2, (q15_t)0xB07A, + (q15_t)0x9BD2, (q15_t)0xB053, (q15_t)0x9BF1, (q15_t)0xB02B, + (q15_t)0x9C10, (q15_t)0xB004, (q15_t)0x9C30, (q15_t)0xAFDD, + (q15_t)0x9C4F, (q15_t)0xAFB6, (q15_t)0x9C6F, (q15_t)0xAF8F, + (q15_t)0x9C8E, (q15_t)0xAF68, (q15_t)0x9CAE, (q15_t)0xAF40, + (q15_t)0x9CCE, (q15_t)0xAF1A, (q15_t)0x9CEE, (q15_t)0xAEF3, + (q15_t)0x9D0D, (q15_t)0xAECC, (q15_t)0x9D2D, (q15_t)0xAEA5, + (q15_t)0x9D4D, (q15_t)0xAE7E, (q15_t)0x9D6D, (q15_t)0xAE57, + (q15_t)0x9D8E, (q15_t)0xAE31, (q15_t)0x9DAE, (q15_t)0xAE0A, + (q15_t)0x9DCE, (q15_t)0xADE3, (q15_t)0x9DEE, (q15_t)0xADBD, + (q15_t)0x9E0E, (q15_t)0xAD96, (q15_t)0x9E2F, (q15_t)0xAD70, + (q15_t)0x9E4F, (q15_t)0xAD4A, (q15_t)0x9E70, (q15_t)0xAD23, + (q15_t)0x9E90, (q15_t)0xACFD, (q15_t)0x9EB1, (q15_t)0xACD7, + (q15_t)0x9ED2, (q15_t)0xACB1, (q15_t)0x9EF2, (q15_t)0xAC8A, + (q15_t)0x9F13, (q15_t)0xAC64, (q15_t)0x9F34, (q15_t)0xAC3E, + (q15_t)0x9F55, (q15_t)0xAC18, (q15_t)0x9F76, (q15_t)0xABF2, + (q15_t)0x9F97, (q15_t)0xABCC, (q15_t)0x9FB8, (q15_t)0xABA7, + (q15_t)0x9FD9, (q15_t)0xAB81, (q15_t)0x9FFB, (q15_t)0xAB5B, + (q15_t)0xA01C, (q15_t)0xAB35, (q15_t)0xA03D, (q15_t)0xAB10, + (q15_t)0xA05F, (q15_t)0xAAEA, (q15_t)0xA080, (q15_t)0xAAC5, + (q15_t)0xA0A1, (q15_t)0xAA9F, (q15_t)0xA0C3, (q15_t)0xAA7A, + (q15_t)0xA0E5, (q15_t)0xAA54, (q15_t)0xA106, (q15_t)0xAA2F, + (q15_t)0xA128, (q15_t)0xAA0A, (q15_t)0xA14A, (q15_t)0xA9E5, + (q15_t)0xA16C, (q15_t)0xA9BF, (q15_t)0xA18E, (q15_t)0xA99A, + (q15_t)0xA1AF, (q15_t)0xA975, (q15_t)0xA1D2, (q15_t)0xA950, + (q15_t)0xA1F4, (q15_t)0xA92B, (q15_t)0xA216, (q15_t)0xA906, + (q15_t)0xA238, (q15_t)0xA8E2, (q15_t)0xA25A, (q15_t)0xA8BD, + (q15_t)0xA27C, (q15_t)0xA898, (q15_t)0xA29F, (q15_t)0xA873, + (q15_t)0xA2C1, (q15_t)0xA84F, (q15_t)0xA2E4, (q15_t)0xA82A, + (q15_t)0xA306, (q15_t)0xA806, (q15_t)0xA329, (q15_t)0xA7E1, + (q15_t)0xA34B, (q15_t)0xA7BD, (q15_t)0xA36E, (q15_t)0xA798, + (q15_t)0xA391, (q15_t)0xA774, (q15_t)0xA3B4, (q15_t)0xA750, + (q15_t)0xA3D6, (q15_t)0xA72B, (q15_t)0xA3F9, (q15_t)0xA707, + (q15_t)0xA41C, (q15_t)0xA6E3, (q15_t)0xA43F, (q15_t)0xA6BF, + (q15_t)0xA462, (q15_t)0xA69B, (q15_t)0xA486, (q15_t)0xA677, + (q15_t)0xA4A9, (q15_t)0xA653, (q15_t)0xA4CC, (q15_t)0xA62F, + (q15_t)0xA4EF, (q15_t)0xA60C, (q15_t)0xA513, (q15_t)0xA5E8, + (q15_t)0xA536, (q15_t)0xA5C4, (q15_t)0xA55A, (q15_t)0xA5A1, + (q15_t)0xA57D, (q15_t)0xA57D, (q15_t)0xA5A1, (q15_t)0xA55A, + (q15_t)0xA5C4, (q15_t)0xA536, (q15_t)0xA5E8, (q15_t)0xA513, + (q15_t)0xA60C, (q15_t)0xA4EF, (q15_t)0xA62F, (q15_t)0xA4CC, + (q15_t)0xA653, (q15_t)0xA4A9, (q15_t)0xA677, (q15_t)0xA486, + (q15_t)0xA69B, (q15_t)0xA462, (q15_t)0xA6BF, (q15_t)0xA43F, + (q15_t)0xA6E3, (q15_t)0xA41C, (q15_t)0xA707, (q15_t)0xA3F9, + (q15_t)0xA72B, (q15_t)0xA3D6, (q15_t)0xA750, (q15_t)0xA3B4, + (q15_t)0xA774, (q15_t)0xA391, (q15_t)0xA798, (q15_t)0xA36E, + (q15_t)0xA7BD, (q15_t)0xA34B, (q15_t)0xA7E1, (q15_t)0xA329, + (q15_t)0xA806, (q15_t)0xA306, (q15_t)0xA82A, (q15_t)0xA2E4, + (q15_t)0xA84F, (q15_t)0xA2C1, (q15_t)0xA873, (q15_t)0xA29F, + (q15_t)0xA898, (q15_t)0xA27C, (q15_t)0xA8BD, (q15_t)0xA25A, + (q15_t)0xA8E2, (q15_t)0xA238, (q15_t)0xA906, (q15_t)0xA216, + (q15_t)0xA92B, (q15_t)0xA1F4, (q15_t)0xA950, (q15_t)0xA1D2, + (q15_t)0xA975, (q15_t)0xA1AF, (q15_t)0xA99A, (q15_t)0xA18E, + (q15_t)0xA9BF, (q15_t)0xA16C, (q15_t)0xA9E5, (q15_t)0xA14A, + (q15_t)0xAA0A, (q15_t)0xA128, (q15_t)0xAA2F, (q15_t)0xA106, + (q15_t)0xAA54, (q15_t)0xA0E5, (q15_t)0xAA7A, (q15_t)0xA0C3, + (q15_t)0xAA9F, (q15_t)0xA0A1, (q15_t)0xAAC5, (q15_t)0xA080, + (q15_t)0xAAEA, (q15_t)0xA05F, (q15_t)0xAB10, (q15_t)0xA03D, + (q15_t)0xAB35, (q15_t)0xA01C, (q15_t)0xAB5B, (q15_t)0x9FFB, + (q15_t)0xAB81, (q15_t)0x9FD9, (q15_t)0xABA7, (q15_t)0x9FB8, + (q15_t)0xABCC, (q15_t)0x9F97, (q15_t)0xABF2, (q15_t)0x9F76, + (q15_t)0xAC18, (q15_t)0x9F55, (q15_t)0xAC3E, (q15_t)0x9F34, + (q15_t)0xAC64, (q15_t)0x9F13, (q15_t)0xAC8A, (q15_t)0x9EF2, + (q15_t)0xACB1, (q15_t)0x9ED2, (q15_t)0xACD7, (q15_t)0x9EB1, + (q15_t)0xACFD, (q15_t)0x9E90, (q15_t)0xAD23, (q15_t)0x9E70, + (q15_t)0xAD4A, (q15_t)0x9E4F, (q15_t)0xAD70, (q15_t)0x9E2F, + (q15_t)0xAD96, (q15_t)0x9E0E, (q15_t)0xADBD, (q15_t)0x9DEE, + (q15_t)0xADE3, (q15_t)0x9DCE, (q15_t)0xAE0A, (q15_t)0x9DAE, + (q15_t)0xAE31, (q15_t)0x9D8E, (q15_t)0xAE57, (q15_t)0x9D6D, + (q15_t)0xAE7E, (q15_t)0x9D4D, (q15_t)0xAEA5, (q15_t)0x9D2D, + (q15_t)0xAECC, (q15_t)0x9D0D, (q15_t)0xAEF3, (q15_t)0x9CEE, + (q15_t)0xAF1A, (q15_t)0x9CCE, (q15_t)0xAF40, (q15_t)0x9CAE, + (q15_t)0xAF68, (q15_t)0x9C8E, (q15_t)0xAF8F, (q15_t)0x9C6F, + (q15_t)0xAFB6, (q15_t)0x9C4F, (q15_t)0xAFDD, (q15_t)0x9C30, + (q15_t)0xB004, (q15_t)0x9C10, (q15_t)0xB02B, (q15_t)0x9BF1, + (q15_t)0xB053, (q15_t)0x9BD2, (q15_t)0xB07A, (q15_t)0x9BB2, + (q15_t)0xB0A1, (q15_t)0x9B93, (q15_t)0xB0C9, (q15_t)0x9B74, + (q15_t)0xB0F0, (q15_t)0x9B55, (q15_t)0xB118, (q15_t)0x9B36, + (q15_t)0xB140, (q15_t)0x9B17, (q15_t)0xB167, (q15_t)0x9AF8, + (q15_t)0xB18F, (q15_t)0x9AD9, (q15_t)0xB1B7, (q15_t)0x9ABA, + (q15_t)0xB1DE, (q15_t)0x9A9C, (q15_t)0xB206, (q15_t)0x9A7D, + (q15_t)0xB22E, (q15_t)0x9A5F, (q15_t)0xB256, (q15_t)0x9A40, + (q15_t)0xB27E, (q15_t)0x9A22, (q15_t)0xB2A6, (q15_t)0x9A03, + (q15_t)0xB2CE, (q15_t)0x99E5, (q15_t)0xB2F6, (q15_t)0x99C6, + (q15_t)0xB31E, (q15_t)0x99A8, (q15_t)0xB347, (q15_t)0x998A, + (q15_t)0xB36F, (q15_t)0x996C, (q15_t)0xB397, (q15_t)0x994E, + (q15_t)0xB3C0, (q15_t)0x9930, (q15_t)0xB3E8, (q15_t)0x9912, + (q15_t)0xB410, (q15_t)0x98F4, (q15_t)0xB439, (q15_t)0x98D6, + (q15_t)0xB461, (q15_t)0x98B9, (q15_t)0xB48A, (q15_t)0x989B, + (q15_t)0xB4B3, (q15_t)0x987D, (q15_t)0xB4DB, (q15_t)0x9860, + (q15_t)0xB504, (q15_t)0x9842, (q15_t)0xB52D, (q15_t)0x9825, + (q15_t)0xB556, (q15_t)0x9808, (q15_t)0xB57E, (q15_t)0x97EA, + (q15_t)0xB5A7, (q15_t)0x97CD, (q15_t)0xB5D0, (q15_t)0x97B0, + (q15_t)0xB5F9, (q15_t)0x9793, (q15_t)0xB622, (q15_t)0x9776, + (q15_t)0xB64B, (q15_t)0x9759, (q15_t)0xB675, (q15_t)0x973C, + (q15_t)0xB69E, (q15_t)0x971F, (q15_t)0xB6C7, (q15_t)0x9702, + (q15_t)0xB6F0, (q15_t)0x96E6, (q15_t)0xB719, (q15_t)0x96C9, + (q15_t)0xB743, (q15_t)0x96AC, (q15_t)0xB76C, (q15_t)0x9690, + (q15_t)0xB796, (q15_t)0x9673, (q15_t)0xB7BF, (q15_t)0x9657, + (q15_t)0xB7E9, (q15_t)0x963B, (q15_t)0xB812, (q15_t)0x961E, + (q15_t)0xB83C, (q15_t)0x9602, (q15_t)0xB865, (q15_t)0x95E6, + (q15_t)0xB88F, (q15_t)0x95CA, (q15_t)0xB8B9, (q15_t)0x95AE, + (q15_t)0xB8E3, (q15_t)0x9592, (q15_t)0xB90C, (q15_t)0x9576, + (q15_t)0xB936, (q15_t)0x955A, (q15_t)0xB960, (q15_t)0x953E, + (q15_t)0xB98A, (q15_t)0x9523, (q15_t)0xB9B4, (q15_t)0x9507, + (q15_t)0xB9DE, (q15_t)0x94EC, (q15_t)0xBA08, (q15_t)0x94D0, + (q15_t)0xBA32, (q15_t)0x94B5, (q15_t)0xBA5C, (q15_t)0x9499, + (q15_t)0xBA87, (q15_t)0x947E, (q15_t)0xBAB1, (q15_t)0x9463, + (q15_t)0xBADB, (q15_t)0x9447, (q15_t)0xBB05, (q15_t)0x942C, + (q15_t)0xBB30, (q15_t)0x9411, (q15_t)0xBB5A, (q15_t)0x93F6, + (q15_t)0xBB85, (q15_t)0x93DB, (q15_t)0xBBAF, (q15_t)0x93C0, + (q15_t)0xBBDA, (q15_t)0x93A6, (q15_t)0xBC04, (q15_t)0x938B, + (q15_t)0xBC2F, (q15_t)0x9370, (q15_t)0xBC5A, (q15_t)0x9356, + (q15_t)0xBC84, (q15_t)0x933B, (q15_t)0xBCAF, (q15_t)0x9321, + (q15_t)0xBCDA, (q15_t)0x9306, (q15_t)0xBD05, (q15_t)0x92EC, + (q15_t)0xBD2F, (q15_t)0x92D2, (q15_t)0xBD5A, (q15_t)0x92B7, + (q15_t)0xBD85, (q15_t)0x929D, (q15_t)0xBDB0, (q15_t)0x9283, + (q15_t)0xBDDB, (q15_t)0x9269, (q15_t)0xBE06, (q15_t)0x924F, + (q15_t)0xBE31, (q15_t)0x9235, (q15_t)0xBE5D, (q15_t)0x921C, + (q15_t)0xBE88, (q15_t)0x9202, (q15_t)0xBEB3, (q15_t)0x91E8, + (q15_t)0xBEDE, (q15_t)0x91CF, (q15_t)0xBF09, (q15_t)0x91B5, + (q15_t)0xBF35, (q15_t)0x919C, (q15_t)0xBF60, (q15_t)0x9182, + (q15_t)0xBF8C, (q15_t)0x9169, (q15_t)0xBFB7, (q15_t)0x9150, + (q15_t)0xBFE2, (q15_t)0x9136, (q15_t)0xC00E, (q15_t)0x911D, + (q15_t)0xC03A, (q15_t)0x9104, (q15_t)0xC065, (q15_t)0x90EB, + (q15_t)0xC091, (q15_t)0x90D2, (q15_t)0xC0BC, (q15_t)0x90B9, + (q15_t)0xC0E8, (q15_t)0x90A0, (q15_t)0xC114, (q15_t)0x9088, + (q15_t)0xC140, (q15_t)0x906F, (q15_t)0xC16C, (q15_t)0x9056, + (q15_t)0xC197, (q15_t)0x903E, (q15_t)0xC1C3, (q15_t)0x9025, + (q15_t)0xC1EF, (q15_t)0x900D, (q15_t)0xC21B, (q15_t)0x8FF5, + (q15_t)0xC247, (q15_t)0x8FDC, (q15_t)0xC273, (q15_t)0x8FC4, + (q15_t)0xC29F, (q15_t)0x8FAC, (q15_t)0xC2CC, (q15_t)0x8F94, + (q15_t)0xC2F8, (q15_t)0x8F7C, (q15_t)0xC324, (q15_t)0x8F64, + (q15_t)0xC350, (q15_t)0x8F4C, (q15_t)0xC37C, (q15_t)0x8F34, + (q15_t)0xC3A9, (q15_t)0x8F1D, (q15_t)0xC3D5, (q15_t)0x8F05, + (q15_t)0xC402, (q15_t)0x8EED, (q15_t)0xC42E, (q15_t)0x8ED6, + (q15_t)0xC45A, (q15_t)0x8EBE, (q15_t)0xC487, (q15_t)0x8EA7, + (q15_t)0xC4B3, (q15_t)0x8E90, (q15_t)0xC4E0, (q15_t)0x8E79, + (q15_t)0xC50D, (q15_t)0x8E61, (q15_t)0xC539, (q15_t)0x8E4A, + (q15_t)0xC566, (q15_t)0x8E33, (q15_t)0xC593, (q15_t)0x8E1C, + (q15_t)0xC5BF, (q15_t)0x8E05, (q15_t)0xC5EC, (q15_t)0x8DEE, + (q15_t)0xC619, (q15_t)0x8DD8, (q15_t)0xC646, (q15_t)0x8DC1, + (q15_t)0xC673, (q15_t)0x8DAA, (q15_t)0xC6A0, (q15_t)0x8D94, + (q15_t)0xC6CD, (q15_t)0x8D7D, (q15_t)0xC6F9, (q15_t)0x8D67, + (q15_t)0xC727, (q15_t)0x8D50, (q15_t)0xC754, (q15_t)0x8D3A, + (q15_t)0xC781, (q15_t)0x8D24, (q15_t)0xC7AE, (q15_t)0x8D0E, + (q15_t)0xC7DB, (q15_t)0x8CF8, (q15_t)0xC808, (q15_t)0x8CE2, + (q15_t)0xC835, (q15_t)0x8CCC, (q15_t)0xC863, (q15_t)0x8CB6, + (q15_t)0xC890, (q15_t)0x8CA0, (q15_t)0xC8BD, (q15_t)0x8C8A, + (q15_t)0xC8EB, (q15_t)0x8C75, (q15_t)0xC918, (q15_t)0x8C5F, + (q15_t)0xC945, (q15_t)0x8C4A, (q15_t)0xC973, (q15_t)0x8C34, + (q15_t)0xC9A0, (q15_t)0x8C1F, (q15_t)0xC9CE, (q15_t)0x8C09, + (q15_t)0xC9FB, (q15_t)0x8BF4, (q15_t)0xCA29, (q15_t)0x8BDF, + (q15_t)0xCA57, (q15_t)0x8BCA, (q15_t)0xCA84, (q15_t)0x8BB5, + (q15_t)0xCAB2, (q15_t)0x8BA0, (q15_t)0xCAE0, (q15_t)0x8B8B, + (q15_t)0xCB0D, (q15_t)0x8B76, (q15_t)0xCB3B, (q15_t)0x8B61, + (q15_t)0xCB69, (q15_t)0x8B4D, (q15_t)0xCB97, (q15_t)0x8B38, + (q15_t)0xCBC5, (q15_t)0x8B24, (q15_t)0xCBF3, (q15_t)0x8B0F, + (q15_t)0xCC21, (q15_t)0x8AFB, (q15_t)0xCC4F, (q15_t)0x8AE6, + (q15_t)0xCC7D, (q15_t)0x8AD2, (q15_t)0xCCAB, (q15_t)0x8ABE, + (q15_t)0xCCD9, (q15_t)0x8AAA, (q15_t)0xCD07, (q15_t)0x8A96, + (q15_t)0xCD35, (q15_t)0x8A82, (q15_t)0xCD63, (q15_t)0x8A6E, + (q15_t)0xCD91, (q15_t)0x8A5A, (q15_t)0xCDBF, (q15_t)0x8A46, + (q15_t)0xCDEE, (q15_t)0x8A33, (q15_t)0xCE1C, (q15_t)0x8A1F, + (q15_t)0xCE4A, (q15_t)0x8A0B, (q15_t)0xCE79, (q15_t)0x89F8, + (q15_t)0xCEA7, (q15_t)0x89E4, (q15_t)0xCED5, (q15_t)0x89D1, + (q15_t)0xCF04, (q15_t)0x89BE, (q15_t)0xCF32, (q15_t)0x89AB, + (q15_t)0xCF61, (q15_t)0x8997, (q15_t)0xCF8F, (q15_t)0x8984, + (q15_t)0xCFBE, (q15_t)0x8971, (q15_t)0xCFEC, (q15_t)0x895F, + (q15_t)0xD01B, (q15_t)0x894C, (q15_t)0xD04A, (q15_t)0x8939, + (q15_t)0xD078, (q15_t)0x8926, (q15_t)0xD0A7, (q15_t)0x8914, + (q15_t)0xD0D6, (q15_t)0x8901, (q15_t)0xD104, (q15_t)0x88EF, + (q15_t)0xD133, (q15_t)0x88DC, (q15_t)0xD162, (q15_t)0x88CA, + (q15_t)0xD191, (q15_t)0x88B8, (q15_t)0xD1C0, (q15_t)0x88A5, + (q15_t)0xD1EE, (q15_t)0x8893, (q15_t)0xD21D, (q15_t)0x8881, + (q15_t)0xD24C, (q15_t)0x886F, (q15_t)0xD27B, (q15_t)0x885D, + (q15_t)0xD2AA, (q15_t)0x884B, (q15_t)0xD2D9, (q15_t)0x883A, + (q15_t)0xD308, (q15_t)0x8828, (q15_t)0xD337, (q15_t)0x8816, + (q15_t)0xD367, (q15_t)0x8805, (q15_t)0xD396, (q15_t)0x87F3, + (q15_t)0xD3C5, (q15_t)0x87E2, (q15_t)0xD3F4, (q15_t)0x87D1, + (q15_t)0xD423, (q15_t)0x87BF, (q15_t)0xD452, (q15_t)0x87AE, + (q15_t)0xD482, (q15_t)0x879D, (q15_t)0xD4B1, (q15_t)0x878C, + (q15_t)0xD4E0, (q15_t)0x877B, (q15_t)0xD510, (q15_t)0x876A, + (q15_t)0xD53F, (q15_t)0x8759, (q15_t)0xD56E, (q15_t)0x8749, + (q15_t)0xD59E, (q15_t)0x8738, (q15_t)0xD5CD, (q15_t)0x8727, + (q15_t)0xD5FD, (q15_t)0x8717, (q15_t)0xD62C, (q15_t)0x8706, + (q15_t)0xD65C, (q15_t)0x86F6, (q15_t)0xD68B, (q15_t)0x86E6, + (q15_t)0xD6BB, (q15_t)0x86D5, (q15_t)0xD6EA, (q15_t)0x86C5, + (q15_t)0xD71A, (q15_t)0x86B5, (q15_t)0xD74A, (q15_t)0x86A5, + (q15_t)0xD779, (q15_t)0x8695, (q15_t)0xD7A9, (q15_t)0x8685, + (q15_t)0xD7D9, (q15_t)0x8675, (q15_t)0xD809, (q15_t)0x8666, + (q15_t)0xD838, (q15_t)0x8656, (q15_t)0xD868, (q15_t)0x8646, + (q15_t)0xD898, (q15_t)0x8637, (q15_t)0xD8C8, (q15_t)0x8627, + (q15_t)0xD8F8, (q15_t)0x8618, (q15_t)0xD927, (q15_t)0x8609, + (q15_t)0xD957, (q15_t)0x85FA, (q15_t)0xD987, (q15_t)0x85EA, + (q15_t)0xD9B7, (q15_t)0x85DB, (q15_t)0xD9E7, (q15_t)0x85CC, + (q15_t)0xDA17, (q15_t)0x85BD, (q15_t)0xDA47, (q15_t)0x85AF, + (q15_t)0xDA77, (q15_t)0x85A0, (q15_t)0xDAA7, (q15_t)0x8591, + (q15_t)0xDAD7, (q15_t)0x8582, (q15_t)0xDB08, (q15_t)0x8574, + (q15_t)0xDB38, (q15_t)0x8565, (q15_t)0xDB68, (q15_t)0x8557, + (q15_t)0xDB98, (q15_t)0x8549, (q15_t)0xDBC8, (q15_t)0x853A, + (q15_t)0xDBF8, (q15_t)0x852C, (q15_t)0xDC29, (q15_t)0x851E, + (q15_t)0xDC59, (q15_t)0x8510, (q15_t)0xDC89, (q15_t)0x8502, + (q15_t)0xDCBA, (q15_t)0x84F4, (q15_t)0xDCEA, (q15_t)0x84E6, + (q15_t)0xDD1A, (q15_t)0x84D9, (q15_t)0xDD4B, (q15_t)0x84CB, + (q15_t)0xDD7B, (q15_t)0x84BD, (q15_t)0xDDAB, (q15_t)0x84B0, + (q15_t)0xDDDC, (q15_t)0x84A2, (q15_t)0xDE0C, (q15_t)0x8495, + (q15_t)0xDE3D, (q15_t)0x8488, (q15_t)0xDE6D, (q15_t)0x847B, + (q15_t)0xDE9E, (q15_t)0x846D, (q15_t)0xDECE, (q15_t)0x8460, + (q15_t)0xDEFF, (q15_t)0x8453, (q15_t)0xDF2F, (q15_t)0x8446, + (q15_t)0xDF60, (q15_t)0x843A, (q15_t)0xDF91, (q15_t)0x842D, + (q15_t)0xDFC1, (q15_t)0x8420, (q15_t)0xDFF2, (q15_t)0x8414, + (q15_t)0xE023, (q15_t)0x8407, (q15_t)0xE053, (q15_t)0x83FA, + (q15_t)0xE084, (q15_t)0x83EE, (q15_t)0xE0B5, (q15_t)0x83E2, + (q15_t)0xE0E6, (q15_t)0x83D6, (q15_t)0xE116, (q15_t)0x83C9, + (q15_t)0xE147, (q15_t)0x83BD, (q15_t)0xE178, (q15_t)0x83B1, + (q15_t)0xE1A9, (q15_t)0x83A5, (q15_t)0xE1DA, (q15_t)0x8399, + (q15_t)0xE20A, (q15_t)0x838E, (q15_t)0xE23B, (q15_t)0x8382, + (q15_t)0xE26C, (q15_t)0x8376, (q15_t)0xE29D, (q15_t)0x836B, + (q15_t)0xE2CE, (q15_t)0x835F, (q15_t)0xE2FF, (q15_t)0x8354, + (q15_t)0xE330, (q15_t)0x8348, (q15_t)0xE361, (q15_t)0x833D, + (q15_t)0xE392, (q15_t)0x8332, (q15_t)0xE3C3, (q15_t)0x8327, + (q15_t)0xE3F4, (q15_t)0x831C, (q15_t)0xE425, (q15_t)0x8311, + (q15_t)0xE456, (q15_t)0x8306, (q15_t)0xE487, (q15_t)0x82FB, + (q15_t)0xE4B8, (q15_t)0x82F0, (q15_t)0xE4E9, (q15_t)0x82E6, + (q15_t)0xE51B, (q15_t)0x82DB, (q15_t)0xE54C, (q15_t)0x82D0, + (q15_t)0xE57D, (q15_t)0x82C6, (q15_t)0xE5AE, (q15_t)0x82BC, + (q15_t)0xE5DF, (q15_t)0x82B1, (q15_t)0xE610, (q15_t)0x82A7, + (q15_t)0xE642, (q15_t)0x829D, (q15_t)0xE673, (q15_t)0x8293, + (q15_t)0xE6A4, (q15_t)0x8289, (q15_t)0xE6D5, (q15_t)0x827F, + (q15_t)0xE707, (q15_t)0x8275, (q15_t)0xE738, (q15_t)0x826B, + (q15_t)0xE769, (q15_t)0x8262, (q15_t)0xE79B, (q15_t)0x8258, + (q15_t)0xE7CC, (q15_t)0x824F, (q15_t)0xE7FD, (q15_t)0x8245, + (q15_t)0xE82F, (q15_t)0x823C, (q15_t)0xE860, (q15_t)0x8232, + (q15_t)0xE892, (q15_t)0x8229, (q15_t)0xE8C3, (q15_t)0x8220, + (q15_t)0xE8F5, (q15_t)0x8217, (q15_t)0xE926, (q15_t)0x820E, + (q15_t)0xE957, (q15_t)0x8205, (q15_t)0xE989, (q15_t)0x81FC, + (q15_t)0xE9BA, (q15_t)0x81F3, (q15_t)0xE9EC, (q15_t)0x81EB, + (q15_t)0xEA1D, (q15_t)0x81E2, (q15_t)0xEA4F, (q15_t)0x81D9, + (q15_t)0xEA80, (q15_t)0x81D1, (q15_t)0xEAB2, (q15_t)0x81C8, + (q15_t)0xEAE4, (q15_t)0x81C0, (q15_t)0xEB15, (q15_t)0x81B8, + (q15_t)0xEB47, (q15_t)0x81B0, (q15_t)0xEB78, (q15_t)0x81A8, + (q15_t)0xEBAA, (q15_t)0x81A0, (q15_t)0xEBDC, (q15_t)0x8198, + (q15_t)0xEC0D, (q15_t)0x8190, (q15_t)0xEC3F, (q15_t)0x8188, + (q15_t)0xEC71, (q15_t)0x8180, (q15_t)0xECA2, (q15_t)0x8179, + (q15_t)0xECD4, (q15_t)0x8171, (q15_t)0xED06, (q15_t)0x816A, + (q15_t)0xED37, (q15_t)0x8162, (q15_t)0xED69, (q15_t)0x815B, + (q15_t)0xED9B, (q15_t)0x8154, (q15_t)0xEDCD, (q15_t)0x814C, + (q15_t)0xEDFE, (q15_t)0x8145, (q15_t)0xEE30, (q15_t)0x813E, + (q15_t)0xEE62, (q15_t)0x8137, (q15_t)0xEE94, (q15_t)0x8130, + (q15_t)0xEEC6, (q15_t)0x812A, (q15_t)0xEEF7, (q15_t)0x8123, + (q15_t)0xEF29, (q15_t)0x811C, (q15_t)0xEF5B, (q15_t)0x8116, + (q15_t)0xEF8D, (q15_t)0x810F, (q15_t)0xEFBF, (q15_t)0x8109, + (q15_t)0xEFF1, (q15_t)0x8102, (q15_t)0xF022, (q15_t)0x80FC, + (q15_t)0xF054, (q15_t)0x80F6, (q15_t)0xF086, (q15_t)0x80F0, + (q15_t)0xF0B8, (q15_t)0x80EA, (q15_t)0xF0EA, (q15_t)0x80E4, + (q15_t)0xF11C, (q15_t)0x80DE, (q15_t)0xF14E, (q15_t)0x80D8, + (q15_t)0xF180, (q15_t)0x80D2, (q15_t)0xF1B2, (q15_t)0x80CD, + (q15_t)0xF1E4, (q15_t)0x80C7, (q15_t)0xF216, (q15_t)0x80C2, + (q15_t)0xF248, (q15_t)0x80BC, (q15_t)0xF27A, (q15_t)0x80B7, + (q15_t)0xF2AC, (q15_t)0x80B2, (q15_t)0xF2DE, (q15_t)0x80AC, + (q15_t)0xF310, (q15_t)0x80A7, (q15_t)0xF342, (q15_t)0x80A2, + (q15_t)0xF374, (q15_t)0x809D, (q15_t)0xF3A6, (q15_t)0x8098, + (q15_t)0xF3D8, (q15_t)0x8094, (q15_t)0xF40A, (q15_t)0x808F, + (q15_t)0xF43C, (q15_t)0x808A, (q15_t)0xF46E, (q15_t)0x8086, + (q15_t)0xF4A0, (q15_t)0x8081, (q15_t)0xF4D2, (q15_t)0x807D, + (q15_t)0xF504, (q15_t)0x8078, (q15_t)0xF536, (q15_t)0x8074, + (q15_t)0xF568, (q15_t)0x8070, (q15_t)0xF59A, (q15_t)0x806C, + (q15_t)0xF5CC, (q15_t)0x8068, (q15_t)0xF5FF, (q15_t)0x8064, + (q15_t)0xF631, (q15_t)0x8060, (q15_t)0xF663, (q15_t)0x805C, + (q15_t)0xF695, (q15_t)0x8058, (q15_t)0xF6C7, (q15_t)0x8055, + (q15_t)0xF6F9, (q15_t)0x8051, (q15_t)0xF72B, (q15_t)0x804E, + (q15_t)0xF75D, (q15_t)0x804A, (q15_t)0xF790, (q15_t)0x8047, + (q15_t)0xF7C2, (q15_t)0x8043, (q15_t)0xF7F4, (q15_t)0x8040, + (q15_t)0xF826, (q15_t)0x803D, (q15_t)0xF858, (q15_t)0x803A, + (q15_t)0xF88A, (q15_t)0x8037, (q15_t)0xF8BD, (q15_t)0x8034, + (q15_t)0xF8EF, (q15_t)0x8031, (q15_t)0xF921, (q15_t)0x802F, + (q15_t)0xF953, (q15_t)0x802C, (q15_t)0xF985, (q15_t)0x8029, + (q15_t)0xF9B8, (q15_t)0x8027, (q15_t)0xF9EA, (q15_t)0x8025, + (q15_t)0xFA1C, (q15_t)0x8022, (q15_t)0xFA4E, (q15_t)0x8020, + (q15_t)0xFA80, (q15_t)0x801E, (q15_t)0xFAB3, (q15_t)0x801C, + (q15_t)0xFAE5, (q15_t)0x801A, (q15_t)0xFB17, (q15_t)0x8018, + (q15_t)0xFB49, (q15_t)0x8016, (q15_t)0xFB7C, (q15_t)0x8014, + (q15_t)0xFBAE, (q15_t)0x8012, (q15_t)0xFBE0, (q15_t)0x8011, + (q15_t)0xFC12, (q15_t)0x800F, (q15_t)0xFC45, (q15_t)0x800D, + (q15_t)0xFC77, (q15_t)0x800C, (q15_t)0xFCA9, (q15_t)0x800B, + (q15_t)0xFCDB, (q15_t)0x8009, (q15_t)0xFD0E, (q15_t)0x8008, + (q15_t)0xFD40, (q15_t)0x8007, (q15_t)0xFD72, (q15_t)0x8006, + (q15_t)0xFDA4, (q15_t)0x8005, (q15_t)0xFDD7, (q15_t)0x8004, + (q15_t)0xFE09, (q15_t)0x8003, (q15_t)0xFE3B, (q15_t)0x8003, + (q15_t)0xFE6D, (q15_t)0x8002, (q15_t)0xFEA0, (q15_t)0x8001, + (q15_t)0xFED2, (q15_t)0x8001, (q15_t)0xFF04, (q15_t)0x8000, + (q15_t)0xFF36, (q15_t)0x8000, (q15_t)0xFF69, (q15_t)0x8000, + (q15_t)0xFF9B, (q15_t)0x8000, (q15_t)0xFFCD, (q15_t)0x8000 +}; + + +/** +* @} end of CFFT_CIFFT group +*/ + +/* +* @brief Q15 table for reciprocal +*/ +const q15_t ALIGN4 armRecipTableQ15[64] = { + 0x7F03, 0x7D13, 0x7B31, 0x795E, 0x7798, 0x75E0, + 0x7434, 0x7294, 0x70FF, 0x6F76, 0x6DF6, 0x6C82, + 0x6B16, 0x69B5, 0x685C, 0x670C, 0x65C4, 0x6484, + 0x634C, 0x621C, 0x60F3, 0x5FD0, 0x5EB5, 0x5DA0, + 0x5C91, 0x5B88, 0x5A85, 0x5988, 0x5890, 0x579E, + 0x56B0, 0x55C8, 0x54E4, 0x5405, 0x532B, 0x5255, + 0x5183, 0x50B6, 0x4FEC, 0x4F26, 0x4E64, 0x4DA6, + 0x4CEC, 0x4C34, 0x4B81, 0x4AD0, 0x4A23, 0x4978, + 0x48D1, 0x482D, 0x478C, 0x46ED, 0x4651, 0x45B8, + 0x4521, 0x448D, 0x43FC, 0x436C, 0x42DF, 0x4255, + 0x41CC, 0x4146, 0x40C2, 0x4040 +}; + +/* +* @brief Q31 table for reciprocal +*/ +const q31_t armRecipTableQ31[64] = { + 0x7F03F03F, 0x7D137420, 0x7B31E739, 0x795E9F94, 0x7798FD29, 0x75E06928, + 0x7434554D, 0x72943B4B, 0x70FF9C40, 0x6F760031, 0x6DF6F593, 0x6C8210E3, + 0x6B16EC3A, 0x69B526F6, 0x685C655F, 0x670C505D, 0x65C4952D, 0x6484E519, + 0x634CF53E, 0x621C7E4F, 0x60F33C61, 0x5FD0EEB3, 0x5EB55785, 0x5DA03BEB, + 0x5C9163A1, 0x5B8898E6, 0x5A85A85A, 0x598860DF, 0x58909373, 0x579E1318, + 0x56B0B4B8, 0x55C84F0B, 0x54E4BA80, 0x5405D124, 0x532B6E8F, 0x52556FD0, + 0x5183B35A, 0x50B618F3, 0x4FEC81A2, 0x4F26CFA2, 0x4E64E64E, 0x4DA6AA1D, + 0x4CEC008B, 0x4C34D010, 0x4B810016, 0x4AD078EF, 0x4A2323C4, 0x4978EA96, + 0x48D1B827, 0x482D77FE, 0x478C1657, 0x46ED801D, 0x4651A2E5, 0x45B86CE2, + 0x4521CCE1, 0x448DB244, 0x43FC0CFA, 0x436CCD78, 0x42DFE4B4, 0x42554426, + 0x41CCDDB6, 0x4146A3C6, 0x40C28923, 0x40408102 +}; + +const uint16_t armBitRevIndexTable16[ARMBITREVINDEXTABLE_16_TABLE_LENGTH] = +{ + /* 8x2, size 20 */ + 8,64, 24,72, 16,64, 40,80, 32,64, 56,88, 48,72, 88,104, 72,96, 104,112 +}; + +const uint16_t armBitRevIndexTable32[ARMBITREVINDEXTABLE_32_TABLE_LENGTH] = +{ + /* 8x4, size 48 */ + 8,64, 16,128, 24,192, 32,64, 40,72, 48,136, 56,200, 64,128, 72,80, 88,208, + 80,144, 96,192, 104,208, 112,152, 120,216, 136,192, 144,160, 168,208, + 152,224, 176,208, 184,232, 216,240, 200,224, 232,240 +}; + +const uint16_t armBitRevIndexTable64[ARMBITREVINDEXTABLE_64_TABLE_LENGTH] = +{ + /* radix 8, size 56 */ + 8,64, 16,128, 24,192, 32,256, 40,320, 48,384, 56,448, 80,136, 88,200, + 96,264, 104,328, 112,392, 120,456, 152,208, 160,272, 168,336, 176,400, + 184,464, 224,280, 232,344, 240,408, 248,472, 296,352, 304,416, 312,480, + 368,424, 376,488, 440,496 +}; + +const uint16_t armBitRevIndexTable128[ARMBITREVINDEXTABLE_128_TABLE_LENGTH] = +{ + /* 8x2, size 208 */ + 8,512, 16,64, 24,576, 32,128, 40,640, 48,192, 56,704, 64,256, 72,768, + 80,320, 88,832, 96,384, 104,896, 112,448, 120,960, 128,512, 136,520, + 144,768, 152,584, 160,520, 168,648, 176,200, 184,712, 192,264, 200,776, + 208,328, 216,840, 224,392, 232,904, 240,456, 248,968, 264,528, 272,320, + 280,592, 288,768, 296,656, 304,328, 312,720, 328,784, 344,848, 352,400, + 360,912, 368,464, 376,976, 384,576, 392,536, 400,832, 408,600, 416,584, + 424,664, 432,840, 440,728, 448,592, 456,792, 464,848, 472,856, 480,600, + 488,920, 496,856, 504,984, 520,544, 528,576, 536,608, 552,672, 560,608, + 568,736, 576,768, 584,800, 592,832, 600,864, 608,800, 616,928, 624,864, + 632,992, 648,672, 656,896, 664,928, 688,904, 696,744, 704,896, 712,808, + 720,912, 728,872, 736,928, 744,936, 752,920, 760,1000, 776,800, 784,832, + 792,864, 808,904, 816,864, 824,920, 840,864, 856,880, 872,944, 888,1008, + 904,928, 912,960, 920,992, 944,968, 952,1000, 968,992, 984,1008 +}; + +const uint16_t armBitRevIndexTable256[ARMBITREVINDEXTABLE_256_TABLE_LENGTH] = +{ + /* 8x4, size 440 */ + 8,512, 16,1024, 24,1536, 32,64, 40,576, 48,1088, 56,1600, 64,128, 72,640, + 80,1152, 88,1664, 96,192, 104,704, 112,1216, 120,1728, 128,256, 136,768, + 144,1280, 152,1792, 160,320, 168,832, 176,1344, 184,1856, 192,384, + 200,896, 208,1408, 216,1920, 224,448, 232,960, 240,1472, 248,1984, + 256,512, 264,520, 272,1032, 280,1544, 288,640, 296,584, 304,1096, 312,1608, + 320,768, 328,648, 336,1160, 344,1672, 352,896, 360,712, 368,1224, 376,1736, + 384,520, 392,776, 400,1288, 408,1800, 416,648, 424,840, 432,1352, 440,1864, + 448,776, 456,904, 464,1416, 472,1928, 480,904, 488,968, 496,1480, 504,1992, + 520,528, 512,1024, 528,1040, 536,1552, 544,1152, 552,592, 560,1104, + 568,1616, 576,1280, 584,656, 592,1168, 600,1680, 608,1408, 616,720, + 624,1232, 632,1744, 640,1032, 648,784, 656,1296, 664,1808, 672,1160, + 680,848, 688,1360, 696,1872, 704,1288, 712,912, 720,1424, 728,1936, + 736,1416, 744,976, 752,1488, 760,2000, 768,1536, 776,1552, 784,1048, + 792,1560, 800,1664, 808,1680, 816,1112, 824,1624, 832,1792, 840,1808, + 848,1176, 856,1688, 864,1920, 872,1936, 880,1240, 888,1752, 896,1544, + 904,1560, 912,1304, 920,1816, 928,1672, 936,1688, 944,1368, 952,1880, + 960,1800, 968,1816, 976,1432, 984,1944, 992,1928, 1000,1944, 1008,1496, + 1016,2008, 1032,1152, 1040,1056, 1048,1568, 1064,1408, 1072,1120, + 1080,1632, 1088,1536, 1096,1160, 1104,1184, 1112,1696, 1120,1552, + 1128,1416, 1136,1248, 1144,1760, 1160,1664, 1168,1312, 1176,1824, + 1184,1544, 1192,1920, 1200,1376, 1208,1888, 1216,1568, 1224,1672, + 1232,1440, 1240,1952, 1248,1560, 1256,1928, 1264,1504, 1272,2016, + 1288,1312, 1296,1408, 1304,1576, 1320,1424, 1328,1416, 1336,1640, + 1344,1792, 1352,1824, 1360,1920, 1368,1704, 1376,1800, 1384,1432, + 1392,1928, 1400,1768, 1416,1680, 1432,1832, 1440,1576, 1448,1936, + 1456,1832, 1464,1896, 1472,1808, 1480,1688, 1488,1936, 1496,1960, + 1504,1816, 1512,1944, 1520,1944, 1528,2024, 1560,1584, 1592,1648, + 1600,1792, 1608,1920, 1616,1800, 1624,1712, 1632,1808, 1640,1936, + 1648,1816, 1656,1776, 1672,1696, 1688,1840, 1704,1952, 1712,1928, + 1720,1904, 1728,1824, 1736,1952, 1744,1832, 1752,1968, 1760,1840, + 1768,1960, 1776,1944, 1784,2032, 1864,1872, 1848,1944, 1872,1888, + 1880,1904, 1888,1984, 1896,2000, 1912,2032, 1904,2016, 1976,2032, + 1960,1968, 2008,2032, 1992,2016, 2024,2032 +}; + +const uint16_t armBitRevIndexTable512[ARMBITREVINDEXTABLE_512_TABLE_LENGTH] = +{ + /* radix 8, size 448 */ + 8,512, 16,1024, 24,1536, 32,2048, 40,2560, 48,3072, 56,3584, 72,576, + 80,1088, 88,1600, 96,2112, 104,2624, 112,3136, 120,3648, 136,640, 144,1152, + 152,1664, 160,2176, 168,2688, 176,3200, 184,3712, 200,704, 208,1216, + 216,1728, 224,2240, 232,2752, 240,3264, 248,3776, 264,768, 272,1280, + 280,1792, 288,2304, 296,2816, 304,3328, 312,3840, 328,832, 336,1344, + 344,1856, 352,2368, 360,2880, 368,3392, 376,3904, 392,896, 400,1408, + 408,1920, 416,2432, 424,2944, 432,3456, 440,3968, 456,960, 464,1472, + 472,1984, 480,2496, 488,3008, 496,3520, 504,4032, 528,1032, 536,1544, + 544,2056, 552,2568, 560,3080, 568,3592, 592,1096, 600,1608, 608,2120, + 616,2632, 624,3144, 632,3656, 656,1160, 664,1672, 672,2184, 680,2696, + 688,3208, 696,3720, 720,1224, 728,1736, 736,2248, 744,2760, 752,3272, + 760,3784, 784,1288, 792,1800, 800,2312, 808,2824, 816,3336, 824,3848, + 848,1352, 856,1864, 864,2376, 872,2888, 880,3400, 888,3912, 912,1416, + 920,1928, 928,2440, 936,2952, 944,3464, 952,3976, 976,1480, 984,1992, + 992,2504, 1000,3016, 1008,3528, 1016,4040, 1048,1552, 1056,2064, 1064,2576, + 1072,3088, 1080,3600, 1112,1616, 1120,2128, 1128,2640, 1136,3152, + 1144,3664, 1176,1680, 1184,2192, 1192,2704, 1200,3216, 1208,3728, + 1240,1744, 1248,2256, 1256,2768, 1264,3280, 1272,3792, 1304,1808, + 1312,2320, 1320,2832, 1328,3344, 1336,3856, 1368,1872, 1376,2384, + 1384,2896, 1392,3408, 1400,3920, 1432,1936, 1440,2448, 1448,2960, + 1456,3472, 1464,3984, 1496,2000, 1504,2512, 1512,3024, 1520,3536, + 1528,4048, 1568,2072, 1576,2584, 1584,3096, 1592,3608, 1632,2136, + 1640,2648, 1648,3160, 1656,3672, 1696,2200, 1704,2712, 1712,3224, + 1720,3736, 1760,2264, 1768,2776, 1776,3288, 1784,3800, 1824,2328, + 1832,2840, 1840,3352, 1848,3864, 1888,2392, 1896,2904, 1904,3416, + 1912,3928, 1952,2456, 1960,2968, 1968,3480, 1976,3992, 2016,2520, + 2024,3032, 2032,3544, 2040,4056, 2088,2592, 2096,3104, 2104,3616, + 2152,2656, 2160,3168, 2168,3680, 2216,2720, 2224,3232, 2232,3744, + 2280,2784, 2288,3296, 2296,3808, 2344,2848, 2352,3360, 2360,3872, + 2408,2912, 2416,3424, 2424,3936, 2472,2976, 2480,3488, 2488,4000, + 2536,3040, 2544,3552, 2552,4064, 2608,3112, 2616,3624, 2672,3176, + 2680,3688, 2736,3240, 2744,3752, 2800,3304, 2808,3816, 2864,3368, + 2872,3880, 2928,3432, 2936,3944, 2992,3496, 3000,4008, 3056,3560, + 3064,4072, 3128,3632, 3192,3696, 3256,3760, 3320,3824, 3384,3888, + 3448,3952, 3512,4016, 3576,4080 +}; + +const uint16_t armBitRevIndexTable1024[ARMBITREVINDEXTABLE_1024_TABLE_LENGTH] = +{ + /* 8x2, size 1800 */ + 8,4096, 16,512, 24,4608, 32,1024, 40,5120, 48,1536, 56,5632, 64,2048, + 72,6144, 80,2560, 88,6656, 96,3072, 104,7168, 112,3584, 120,7680, 128,2048, + 136,4160, 144,576, 152,4672, 160,1088, 168,5184, 176,1600, 184,5696, + 192,2112, 200,6208, 208,2624, 216,6720, 224,3136, 232,7232, 240,3648, + 248,7744, 256,2048, 264,4224, 272,640, 280,4736, 288,1152, 296,5248, + 304,1664, 312,5760, 320,2176, 328,6272, 336,2688, 344,6784, 352,3200, + 360,7296, 368,3712, 376,7808, 384,2112, 392,4288, 400,704, 408,4800, + 416,1216, 424,5312, 432,1728, 440,5824, 448,2240, 456,6336, 464,2752, + 472,6848, 480,3264, 488,7360, 496,3776, 504,7872, 512,2048, 520,4352, + 528,768, 536,4864, 544,1280, 552,5376, 560,1792, 568,5888, 576,2304, + 584,6400, 592,2816, 600,6912, 608,3328, 616,7424, 624,3840, 632,7936, + 640,2176, 648,4416, 656,832, 664,4928, 672,1344, 680,5440, 688,1856, + 696,5952, 704,2368, 712,6464, 720,2880, 728,6976, 736,3392, 744,7488, + 752,3904, 760,8000, 768,2112, 776,4480, 784,896, 792,4992, 800,1408, + 808,5504, 816,1920, 824,6016, 832,2432, 840,6528, 848,2944, 856,7040, + 864,3456, 872,7552, 880,3968, 888,8064, 896,2240, 904,4544, 912,960, + 920,5056, 928,1472, 936,5568, 944,1984, 952,6080, 960,2496, 968,6592, + 976,3008, 984,7104, 992,3520, 1000,7616, 1008,4032, 1016,8128, 1024,4096, + 1032,4104, 1040,4352, 1048,4616, 1056,4104, 1064,5128, 1072,1544, + 1080,5640, 1088,2056, 1096,6152, 1104,2568, 1112,6664, 1120,3080, + 1128,7176, 1136,3592, 1144,7688, 1152,6144, 1160,4168, 1168,6400, + 1176,4680, 1184,6152, 1192,5192, 1200,1608, 1208,5704, 1216,2120, + 1224,6216, 1232,2632, 1240,6728, 1248,3144, 1256,7240, 1264,3656, + 1272,7752, 1280,4160, 1288,4232, 1296,4416, 1304,4744, 1312,4168, + 1320,5256, 1328,1672, 1336,5768, 1344,2184, 1352,6280, 1360,2696, + 1368,6792, 1376,3208, 1384,7304, 1392,3720, 1400,7816, 1408,6208, + 1416,4296, 1424,6464, 1432,4808, 1440,6216, 1448,5320, 1456,1736, + 1464,5832, 1472,2248, 1480,6344, 1488,2760, 1496,6856, 1504,3272, + 1512,7368, 1520,3784, 1528,7880, 1536,4224, 1544,4360, 1552,4480, + 1560,4872, 1568,4232, 1576,5384, 1584,1800, 1592,5896, 1600,2312, + 1608,6408, 1616,2824, 1624,6920, 1632,3336, 1640,7432, 1648,3848, + 1656,7944, 1664,6272, 1672,4424, 1680,6528, 1688,4936, 1696,6280, + 1704,5448, 1712,1864, 1720,5960, 1728,2376, 1736,6472, 1744,2888, + 1752,6984, 1760,3400, 1768,7496, 1776,3912, 1784,8008, 1792,4288, + 1800,4488, 1808,4544, 1816,5000, 1824,4296, 1832,5512, 1840,1928, + 1848,6024, 1856,2440, 1864,6536, 1872,2952, 1880,7048, 1888,3464, + 1896,7560, 1904,3976, 1912,8072, 1920,6336, 1928,4552, 1936,6592, + 1944,5064, 1952,6344, 1960,5576, 1968,1992, 1976,6088, 1984,2504, + 1992,6600, 2000,3016, 2008,7112, 2016,3528, 2024,7624, 2032,4040, + 2040,8136, 2056,4112, 2064,2112, 2072,4624, 2080,4352, 2088,5136, + 2096,4480, 2104,5648, 2120,6160, 2128,2576, 2136,6672, 2144,3088, + 2152,7184, 2160,3600, 2168,7696, 2176,2560, 2184,4176, 2192,2816, + 2200,4688, 2208,2568, 2216,5200, 2224,2824, 2232,5712, 2240,2576, + 2248,6224, 2256,2640, 2264,6736, 2272,3152, 2280,7248, 2288,3664, + 2296,7760, 2312,4240, 2320,2432, 2328,4752, 2336,6400, 2344,5264, + 2352,6528, 2360,5776, 2368,2816, 2376,6288, 2384,2704, 2392,6800, + 2400,3216, 2408,7312, 2416,3728, 2424,7824, 2432,2624, 2440,4304, + 2448,2880, 2456,4816, 2464,2632, 2472,5328, 2480,2888, 2488,5840, + 2496,2640, 2504,6352, 2512,2768, 2520,6864, 2528,3280, 2536,7376, + 2544,3792, 2552,7888, 2568,4368, 2584,4880, 2592,4416, 2600,5392, + 2608,4544, 2616,5904, 2632,6416, 2640,2832, 2648,6928, 2656,3344, + 2664,7440, 2672,3856, 2680,7952, 2696,4432, 2704,2944, 2712,4944, + 2720,4432, 2728,5456, 2736,2952, 2744,5968, 2752,2944, 2760,6480, + 2768,2896, 2776,6992, 2784,3408, 2792,7504, 2800,3920, 2808,8016, + 2824,4496, 2840,5008, 2848,6464, 2856,5520, 2864,6592, 2872,6032, + 2888,6544, 2896,2960, 2904,7056, 2912,3472, 2920,7568, 2928,3984, + 2936,8080, 2952,4560, 2960,3008, 2968,5072, 2976,6480, 2984,5584, + 2992,3016, 3000,6096, 3016,6608, 3032,7120, 3040,3536, 3048,7632, + 3056,4048, 3064,8144, 3072,4608, 3080,4120, 3088,4864, 3096,4632, + 3104,4616, 3112,5144, 3120,4872, 3128,5656, 3136,4624, 3144,6168, + 3152,4880, 3160,6680, 3168,4632, 3176,7192, 3184,3608, 3192,7704, + 3200,6656, 3208,4184, 3216,6912, 3224,4696, 3232,6664, 3240,5208, + 3248,6920, 3256,5720, 3264,6672, 3272,6232, 3280,6928, 3288,6744, + 3296,6680, 3304,7256, 3312,3672, 3320,7768, 3328,4672, 3336,4248, + 3344,4928, 3352,4760, 3360,4680, 3368,5272, 3376,4936, 3384,5784, + 3392,4688, 3400,6296, 3408,4944, 3416,6808, 3424,4696, 3432,7320, + 3440,3736, 3448,7832, 3456,6720, 3464,4312, 3472,6976, 3480,4824, + 3488,6728, 3496,5336, 3504,6984, 3512,5848, 3520,6736, 3528,6360, + 3536,6992, 3544,6872, 3552,6744, 3560,7384, 3568,3800, 3576,7896, + 3584,4736, 3592,4376, 3600,4992, 3608,4888, 3616,4744, 3624,5400, + 3632,5000, 3640,5912, 3648,4752, 3656,6424, 3664,5008, 3672,6936, + 3680,4760, 3688,7448, 3696,3864, 3704,7960, 3712,6784, 3720,4440, + 3728,7040, 3736,4952, 3744,6792, 3752,5464, 3760,7048, 3768,5976, + 3776,6800, 3784,6488, 3792,7056, 3800,7000, 3808,6808, 3816,7512, + 3824,3928, 3832,8024, 3840,4800, 3848,4504, 3856,5056, 3864,5016, + 3872,4808, 3880,5528, 3888,5064, 3896,6040, 3904,4816, 3912,6552, + 3920,5072, 3928,7064, 3936,4824, 3944,7576, 3952,3992, 3960,8088, + 3968,6848, 3976,4568, 3984,7104, 3992,5080, 4000,6856, 4008,5592, + 4016,7112, 4024,6104, 4032,6864, 4040,6616, 4048,7120, 4056,7128, + 4064,6872, 4072,7640, 4080,7128, 4088,8152, 4104,4128, 4112,4160, + 4120,4640, 4136,5152, 4144,4232, 4152,5664, 4160,4352, 4168,6176, + 4176,4416, 4184,6688, 4192,4616, 4200,7200, 4208,4744, 4216,7712, + 4224,4608, 4232,4616, 4240,4672, 4248,4704, 4256,4640, 4264,5216, + 4272,4704, 4280,5728, 4288,4864, 4296,6240, 4304,4928, 4312,6752, + 4320,4632, 4328,7264, 4336,4760, 4344,7776, 4360,4640, 4368,4416, + 4376,4768, 4384,6152, 4392,5280, 4400,6280, 4408,5792, 4424,6304, + 4440,6816, 4448,6664, 4456,7328, 4464,6792, 4472,7840, 4480,4624, + 4488,4632, 4496,4688, 4504,4832, 4512,6168, 4520,5344, 4528,6296, + 4536,5856, 4544,4880, 4552,6368, 4560,4944, 4568,6880, 4576,6680, + 4584,7392, 4592,6808, 4600,7904, 4608,6144, 4616,6152, 4624,6208, + 4632,4896, 4640,6176, 4648,5408, 4656,6240, 4664,5920, 4672,6400, + 4680,6432, 4688,6464, 4696,6944, 4704,6432, 4712,7456, 4720,4808, + 4728,7968, 4736,6656, 4744,6664, 4752,6720, 4760,4960, 4768,6688, + 4776,5472, 4784,6752, 4792,5984, 4800,6912, 4808,6496, 4816,6976, + 4824,7008, 4832,6944, 4840,7520, 4848,7008, 4856,8032, 4864,6160, + 4872,6168, 4880,6224, 4888,5024, 4896,6216, 4904,5536, 4912,6344, + 4920,6048, 4928,6416, 4936,6560, 4944,6480, 4952,7072, 4960,6728, + 4968,7584, 4976,6856, 4984,8096, 4992,6672, 5000,6680, 5008,6736, + 5016,5088, 5024,6232, 5032,5600, 5040,6360, 5048,6112, 5056,6928, + 5064,6624, 5072,6992, 5080,7136, 5088,6744, 5096,7648, 5104,6872, + 5112,8160, 5128,5152, 5136,5376, 5144,5408, 5168,5384, 5176,5672, + 5184,5376, 5192,6184, 5200,5392, 5208,6696, 5216,5408, 5224,7208, + 5232,5400, 5240,7720, 5248,7168, 5256,7200, 5264,7424, 5272,7456, + 5280,7176, 5288,7208, 5296,7432, 5304,5736, 5312,7184, 5320,6248, + 5328,7440, 5336,6760, 5344,7192, 5352,7272, 5360,7448, 5368,7784, + 5384,5408, 5392,5440, 5400,5472, 5408,6184, 5416,7208, 5424,5448, + 5432,5800, 5448,6312, 5464,6824, 5472,6696, 5480,7336, 5488,6824, + 5496,7848, 5504,7232, 5512,7264, 5520,7488, 5528,7520, 5536,7240, + 5544,7272, 5552,7496, 5560,5864, 5568,7248, 5576,6376, 5584,7504, + 5592,6888, 5600,7256, 5608,7400, 5616,7512, 5624,7912, 5632,7168, + 5640,7176, 5648,7232, 5656,7240, 5664,7200, 5672,7208, 5680,7264, + 5688,5928, 5696,7424, 5704,6440, 5712,7488, 5720,6952, 5728,7456, + 5736,7464, 5744,7520, 5752,7976, 5760,7296, 5768,7328, 5776,7552, + 5784,7584, 5792,7304, 5800,7336, 5808,7560, 5816,5992, 5824,7312, + 5832,6504, 5840,7568, 5848,7016, 5856,7320, 5864,7528, 5872,7576, + 5880,8040, 5888,7184, 5896,7192, 5904,7248, 5912,7256, 5920,6248, + 5928,7272, 5936,6376, 5944,6056, 5952,7440, 5960,6568, 5968,7504, + 5976,7080, 5984,6760, 5992,7592, 6000,6888, 6008,8104, 6016,7360, + 6024,7392, 6032,7616, 6040,7648, 6048,7368, 6056,7400, 6064,7624, + 6072,6120, 6080,7376, 6088,6632, 6096,7632, 6104,7144, 6112,7384, + 6120,7656, 6128,7640, 6136,8168, 6168,6240, 6192,6216, 6200,7264, + 6232,6704, 6248,7216, 6256,6680, 6264,7728, 6272,6656, 6280,6664, + 6288,6912, 6296,6496, 6304,6688, 6312,6696, 6320,6944, 6328,7520, + 6336,6672, 6344,6680, 6352,6928, 6360,6768, 6368,6704, 6376,7280, + 6384,6744, 6392,7792, 6408,6432, 6424,6752, 6440,7432, 6448,6536, + 6456,7560, 6472,6944, 6488,6832, 6496,6920, 6504,7344, 6512,7048, + 6520,7856, 6528,6720, 6536,6728, 6544,6976, 6552,7008, 6560,6752, + 6568,7448, 6576,7008, 6584,7576, 6592,6736, 6600,6744, 6608,6992, + 6616,6896, 6624,6936, 6632,7408, 6640,7064, 6648,7920, 6712,7280, + 6744,6960, 6760,7472, 6768,6936, 6776,7984, 6800,6848, 6808,6856, + 6832,6880, 6840,6888, 6848,7040, 6856,7048, 6864,7104, 6872,7024, + 6880,7072, 6888,7536, 6896,7136, 6904,8048, 6952,7496, 6968,7624, + 6984,7008, 7000,7088, 7016,7600, 7024,7112, 7032,8112, 7056,7104, + 7064,7112, 7080,7512, 7088,7136, 7096,7640, 7128,7152, 7144,7664, + 7160,8176, 7176,7200, 7192,7216, 7224,7272, 7240,7264, 7256,7280, + 7288,7736, 7296,7680, 7304,7712, 7312,7936, 7320,7968, 7328,7688, + 7336,7720, 7344,7944, 7352,7976, 7360,7696, 7368,7728, 7376,7952, + 7384,7984, 7392,7704, 7400,7736, 7408,7960, 7416,7800, 7432,7456, + 7448,7472, 7480,7592, 7496,7520, 7512,7536, 7528,7976, 7544,7864, + 7552,7744, 7560,7776, 7568,8000, 7576,8032, 7584,7752, 7592,7784, + 7600,8008, 7608,8040, 7616,7760, 7624,7792, 7632,8016, 7640,8048, + 7648,7768, 7656,7800, 7664,8024, 7672,7928, 7688,7712, 7704,7728, + 7752,7776, 7768,7792, 7800,7992, 7816,7840, 7824,8064, 7832,8096, + 7856,8072, 7864,8104, 7872,8064, 7880,8072, 7888,8080, 7896,8112, + 7904,8096, 7912,8104, 7920,8088, 7928,8056, 7944,7968, 7960,7984, + 8008,8032, 8024,8048, 8056,8120, 8072,8096, 8080,8128, 8088,8160, + 8112,8136, 8120,8168, 8136,8160, 8152,8176 +}; + +const uint16_t armBitRevIndexTable2048[ARMBITREVINDEXTABLE_2048_TABLE_LENGTH] = +{ + /* 8x2, size 3808 */ + 8,4096, 16,8192, 24,12288, 32,512, 40,4608, 48,8704, 56,12800, 64,1024, + 72,5120, 80,9216, 88,13312, 96,1536, 104,5632, 112,9728, 120,13824, + 128,2048, 136,6144, 144,10240, 152,14336, 160,2560, 168,6656, 176,10752, + 184,14848, 192,3072, 200,7168, 208,11264, 216,15360, 224,3584, 232,7680, + 240,11776, 248,15872, 256,1024, 264,4160, 272,8256, 280,12352, 288,576, + 296,4672, 304,8768, 312,12864, 320,1088, 328,5184, 336,9280, 344,13376, + 352,1600, 360,5696, 368,9792, 376,13888, 384,2112, 392,6208, 400,10304, + 408,14400, 416,2624, 424,6720, 432,10816, 440,14912, 448,3136, 456,7232, + 464,11328, 472,15424, 480,3648, 488,7744, 496,11840, 504,15936, 512,2048, + 520,4224, 528,8320, 536,12416, 544,640, 552,4736, 560,8832, 568,12928, + 576,1152, 584,5248, 592,9344, 600,13440, 608,1664, 616,5760, 624,9856, + 632,13952, 640,2176, 648,6272, 656,10368, 664,14464, 672,2688, 680,6784, + 688,10880, 696,14976, 704,3200, 712,7296, 720,11392, 728,15488, 736,3712, + 744,7808, 752,11904, 760,16000, 768,3072, 776,4288, 784,8384, 792,12480, + 800,3200, 808,4800, 816,8896, 824,12992, 832,1216, 840,5312, 848,9408, + 856,13504, 864,1728, 872,5824, 880,9920, 888,14016, 896,2240, 904,6336, + 912,10432, 920,14528, 928,2752, 936,6848, 944,10944, 952,15040, 960,3264, + 968,7360, 976,11456, 984,15552, 992,3776, 1000,7872, 1008,11968, 1016,16064, + 1032,4352, 1040,8448, 1048,12544, 1056,3072, 1064,4864, 1072,8960, + 1080,13056, 1088,1280, 1096,5376, 1104,9472, 1112,13568, 1120,1792, + 1128,5888, 1136,9984, 1144,14080, 1152,2304, 1160,6400, 1168,10496, + 1176,14592, 1184,2816, 1192,6912, 1200,11008, 1208,15104, 1216,3328, + 1224,7424, 1232,11520, 1240,15616, 1248,3840, 1256,7936, 1264,12032, + 1272,16128, 1288,4416, 1296,8512, 1304,12608, 1312,3328, 1320,4928, + 1328,9024, 1336,13120, 1352,5440, 1360,9536, 1368,13632, 1376,1856, + 1384,5952, 1392,10048, 1400,14144, 1408,2368, 1416,6464, 1424,10560, + 1432,14656, 1440,2880, 1448,6976, 1456,11072, 1464,15168, 1472,3392, + 1480,7488, 1488,11584, 1496,15680, 1504,3904, 1512,8000, 1520,12096, + 1528,16192, 1536,2112, 1544,4480, 1552,8576, 1560,12672, 1568,2240, + 1576,4992, 1584,9088, 1592,13184, 1600,2368, 1608,5504, 1616,9600, + 1624,13696, 1632,1920, 1640,6016, 1648,10112, 1656,14208, 1664,2432, + 1672,6528, 1680,10624, 1688,14720, 1696,2944, 1704,7040, 1712,11136, + 1720,15232, 1728,3456, 1736,7552, 1744,11648, 1752,15744, 1760,3968, + 1768,8064, 1776,12160, 1784,16256, 1792,3136, 1800,4544, 1808,8640, + 1816,12736, 1824,3264, 1832,5056, 1840,9152, 1848,13248, 1856,3392, + 1864,5568, 1872,9664, 1880,13760, 1888,1984, 1896,6080, 1904,10176, + 1912,14272, 1920,2496, 1928,6592, 1936,10688, 1944,14784, 1952,3008, + 1960,7104, 1968,11200, 1976,15296, 1984,3520, 1992,7616, 2000,11712, + 2008,15808, 2016,4032, 2024,8128, 2032,12224, 2040,16320, 2048,4096, + 2056,4104, 2064,8200, 2072,12296, 2080,4224, 2088,4616, 2096,8712, + 2104,12808, 2112,4352, 2120,5128, 2128,9224, 2136,13320, 2144,4480, + 2152,5640, 2160,9736, 2168,13832, 2176,4104, 2184,6152, 2192,10248, + 2200,14344, 2208,2568, 2216,6664, 2224,10760, 2232,14856, 2240,3080, + 2248,7176, 2256,11272, 2264,15368, 2272,3592, 2280,7688, 2288,11784, + 2296,15880, 2304,5120, 2312,4168, 2320,8264, 2328,12360, 2336,5248, + 2344,4680, 2352,8776, 2360,12872, 2368,5376, 2376,5192, 2384,9288, + 2392,13384, 2400,5504, 2408,5704, 2416,9800, 2424,13896, 2432,5128, + 2440,6216, 2448,10312, 2456,14408, 2464,2632, 2472,6728, 2480,10824, + 2488,14920, 2496,3144, 2504,7240, 2512,11336, 2520,15432, 2528,3656, + 2536,7752, 2544,11848, 2552,15944, 2560,6144, 2568,4232, 2576,8328, + 2584,12424, 2592,6272, 2600,4744, 2608,8840, 2616,12936, 2624,6400, + 2632,5256, 2640,9352, 2648,13448, 2656,6528, 2664,5768, 2672,9864, + 2680,13960, 2688,6152, 2696,6280, 2704,10376, 2712,14472, 2720,6280, + 2728,6792, 2736,10888, 2744,14984, 2752,3208, 2760,7304, 2768,11400, + 2776,15496, 2784,3720, 2792,7816, 2800,11912, 2808,16008, 2816,7168, + 2824,4296, 2832,8392, 2840,12488, 2848,7296, 2856,4808, 2864,8904, + 2872,13000, 2880,7424, 2888,5320, 2896,9416, 2904,13512, 2912,7552, + 2920,5832, 2928,9928, 2936,14024, 2944,7176, 2952,6344, 2960,10440, + 2968,14536, 2976,7304, 2984,6856, 2992,10952, 3000,15048, 3008,3272, + 3016,7368, 3024,11464, 3032,15560, 3040,3784, 3048,7880, 3056,11976, + 3064,16072, 3072,4160, 3080,4360, 3088,8456, 3096,12552, 3104,4288, + 3112,4872, 3120,8968, 3128,13064, 3136,4416, 3144,5384, 3152,9480, + 3160,13576, 3168,4544, 3176,5896, 3184,9992, 3192,14088, 3200,4168, + 3208,6408, 3216,10504, 3224,14600, 3232,4296, 3240,6920, 3248,11016, + 3256,15112, 3264,3336, 3272,7432, 3280,11528, 3288,15624, 3296,3848, + 3304,7944, 3312,12040, 3320,16136, 3328,5184, 3336,4424, 3344,8520, + 3352,12616, 3360,5312, 3368,4936, 3376,9032, 3384,13128, 3392,5440, + 3400,5448, 3408,9544, 3416,13640, 3424,5568, 3432,5960, 3440,10056, + 3448,14152, 3456,5192, 3464,6472, 3472,10568, 3480,14664, 3488,5320, + 3496,6984, 3504,11080, 3512,15176, 3520,5448, 3528,7496, 3536,11592, + 3544,15688, 3552,3912, 3560,8008, 3568,12104, 3576,16200, 3584,6208, + 3592,4488, 3600,8584, 3608,12680, 3616,6336, 3624,5000, 3632,9096, + 3640,13192, 3648,6464, 3656,5512, 3664,9608, 3672,13704, 3680,6592, + 3688,6024, 3696,10120, 3704,14216, 3712,6216, 3720,6536, 3728,10632, + 3736,14728, 3744,6344, 3752,7048, 3760,11144, 3768,15240, 3776,6472, + 3784,7560, 3792,11656, 3800,15752, 3808,3976, 3816,8072, 3824,12168, + 3832,16264, 3840,7232, 3848,4552, 3856,8648, 3864,12744, 3872,7360, + 3880,5064, 3888,9160, 3896,13256, 3904,7488, 3912,5576, 3920,9672, + 3928,13768, 3936,7616, 3944,6088, 3952,10184, 3960,14280, 3968,7240, + 3976,6600, 3984,10696, 3992,14792, 4000,7368, 4008,7112, 4016,11208, + 4024,15304, 4032,7496, 4040,7624, 4048,11720, 4056,15816, 4064,7624, + 4072,8136, 4080,12232, 4088,16328, 4096,8192, 4104,4112, 4112,8208, + 4120,12304, 4128,8320, 4136,4624, 4144,8720, 4152,12816, 4160,8448, + 4168,5136, 4176,9232, 4184,13328, 4192,8576, 4200,5648, 4208,9744, + 4216,13840, 4224,8200, 4232,6160, 4240,10256, 4248,14352, 4256,8328, + 4264,6672, 4272,10768, 4280,14864, 4288,8456, 4296,7184, 4304,11280, + 4312,15376, 4320,8584, 4328,7696, 4336,11792, 4344,15888, 4352,9216, + 4360,9232, 4368,8272, 4376,12368, 4384,9344, 4392,4688, 4400,8784, + 4408,12880, 4416,9472, 4424,5200, 4432,9296, 4440,13392, 4448,9600, + 4456,5712, 4464,9808, 4472,13904, 4480,9224, 4488,6224, 4496,10320, + 4504,14416, 4512,9352, 4520,6736, 4528,10832, 4536,14928, 4544,9480, + 4552,7248, 4560,11344, 4568,15440, 4576,9608, 4584,7760, 4592,11856, + 4600,15952, 4608,10240, 4616,10256, 4624,8336, 4632,12432, 4640,10368, + 4648,4752, 4656,8848, 4664,12944, 4672,10496, 4680,5264, 4688,9360, + 4696,13456, 4704,10624, 4712,5776, 4720,9872, 4728,13968, 4736,10248, + 4744,6288, 4752,10384, 4760,14480, 4768,10376, 4776,6800, 4784,10896, + 4792,14992, 4800,10504, 4808,7312, 4816,11408, 4824,15504, 4832,10632, + 4840,7824, 4848,11920, 4856,16016, 4864,11264, 4872,11280, 4880,8400, + 4888,12496, 4896,11392, 4904,11408, 4912,8912, 4920,13008, 4928,11520, + 4936,5328, 4944,9424, 4952,13520, 4960,11648, 4968,5840, 4976,9936, + 4984,14032, 4992,11272, 5000,6352, 5008,10448, 5016,14544, 5024,11400, + 5032,6864, 5040,10960, 5048,15056, 5056,11528, 5064,7376, 5072,11472, + 5080,15568, 5088,11656, 5096,7888, 5104,11984, 5112,16080, 5120,8256, + 5128,8272, 5136,8464, 5144,12560, 5152,8384, 5160,8400, 5168,8976, + 5176,13072, 5184,8512, 5192,5392, 5200,9488, 5208,13584, 5216,8640, + 5224,5904, 5232,10000, 5240,14096, 5248,8264, 5256,6416, 5264,10512, + 5272,14608, 5280,8392, 5288,6928, 5296,11024, 5304,15120, 5312,8520, + 5320,7440, 5328,11536, 5336,15632, 5344,8648, 5352,7952, 5360,12048, + 5368,16144, 5376,9280, 5384,9296, 5392,8528, 5400,12624, 5408,9408, + 5416,9424, 5424,9040, 5432,13136, 5440,9536, 5448,5456, 5456,9552, + 5464,13648, 5472,9664, 5480,5968, 5488,10064, 5496,14160, 5504,9288, + 5512,6480, 5520,10576, 5528,14672, 5536,9416, 5544,6992, 5552,11088, + 5560,15184, 5568,9544, 5576,7504, 5584,11600, 5592,15696, 5600,9672, + 5608,8016, 5616,12112, 5624,16208, 5632,10304, 5640,10320, 5648,8592, + 5656,12688, 5664,10432, 5672,10448, 5680,9104, 5688,13200, 5696,10560, + 5704,10576, 5712,9616, 5720,13712, 5728,10688, 5736,6032, 5744,10128, + 5752,14224, 5760,10312, 5768,6544, 5776,10640, 5784,14736, 5792,10440, + 5800,7056, 5808,11152, 5816,15248, 5824,10568, 5832,7568, 5840,11664, + 5848,15760, 5856,10696, 5864,8080, 5872,12176, 5880,16272, 5888,11328, + 5896,11344, 5904,8656, 5912,12752, 5920,11456, 5928,11472, 5936,9168, + 5944,13264, 5952,11584, 5960,11600, 5968,9680, 5976,13776, 5984,11712, + 5992,6096, 6000,10192, 6008,14288, 6016,11336, 6024,6608, 6032,10704, + 6040,14800, 6048,11464, 6056,7120, 6064,11216, 6072,15312, 6080,11592, + 6088,7632, 6096,11728, 6104,15824, 6112,11720, 6120,8144, 6128,12240, + 6136,16336, 6144,12288, 6152,12304, 6160,8216, 6168,12312, 6176,12416, + 6184,12432, 6192,8728, 6200,12824, 6208,12544, 6216,12560, 6224,9240, + 6232,13336, 6240,12672, 6248,12688, 6256,9752, 6264,13848, 6272,12296, + 6280,12312, 6288,10264, 6296,14360, 6304,12424, 6312,6680, 6320,10776, + 6328,14872, 6336,12552, 6344,7192, 6352,11288, 6360,15384, 6368,12680, + 6376,7704, 6384,11800, 6392,15896, 6400,13312, 6408,13328, 6416,8280, + 6424,12376, 6432,13440, 6440,13456, 6448,8792, 6456,12888, 6464,13568, + 6472,13584, 6480,9304, 6488,13400, 6496,13696, 6504,13712, 6512,9816, + 6520,13912, 6528,13320, 6536,13336, 6544,10328, 6552,14424, 6560,13448, + 6568,6744, 6576,10840, 6584,14936, 6592,13576, 6600,7256, 6608,11352, + 6616,15448, 6624,13704, 6632,7768, 6640,11864, 6648,15960, 6656,14336, + 6664,14352, 6672,8344, 6680,12440, 6688,14464, 6696,14480, 6704,8856, + 6712,12952, 6720,14592, 6728,14608, 6736,9368, 6744,13464, 6752,14720, + 6760,14736, 6768,9880, 6776,13976, 6784,14344, 6792,14360, 6800,10392, + 6808,14488, 6816,14472, 6824,14488, 6832,10904, 6840,15000, 6848,14600, + 6856,7320, 6864,11416, 6872,15512, 6880,14728, 6888,7832, 6896,11928, + 6904,16024, 6912,15360, 6920,15376, 6928,8408, 6936,12504, 6944,15488, + 6952,15504, 6960,8920, 6968,13016, 6976,15616, 6984,15632, 6992,9432, + 7000,13528, 7008,15744, 7016,15760, 7024,9944, 7032,14040, 7040,15368, + 7048,15384, 7056,10456, 7064,14552, 7072,15496, 7080,15512, 7088,10968, + 7096,15064, 7104,15624, 7112,7384, 7120,11480, 7128,15576, 7136,15752, + 7144,7896, 7152,11992, 7160,16088, 7168,12352, 7176,12368, 7184,8472, + 7192,12568, 7200,12480, 7208,12496, 7216,8984, 7224,13080, 7232,12608, + 7240,12624, 7248,9496, 7256,13592, 7264,12736, 7272,12752, 7280,10008, + 7288,14104, 7296,12360, 7304,12376, 7312,10520, 7320,14616, 7328,12488, + 7336,12504, 7344,11032, 7352,15128, 7360,12616, 7368,7448, 7376,11544, + 7384,15640, 7392,12744, 7400,7960, 7408,12056, 7416,16152, 7424,13376, + 7432,13392, 7440,8536, 7448,12632, 7456,13504, 7464,13520, 7472,9048, + 7480,13144, 7488,13632, 7496,13648, 7504,9560, 7512,13656, 7520,13760, + 7528,13776, 7536,10072, 7544,14168, 7552,13384, 7560,13400, 7568,10584, + 7576,14680, 7584,13512, 7592,13528, 7600,11096, 7608,15192, 7616,13640, + 7624,13656, 7632,11608, 7640,15704, 7648,13768, 7656,8024, 7664,12120, + 7672,16216, 7680,14400, 7688,14416, 7696,8600, 7704,12696, 7712,14528, + 7720,14544, 7728,9112, 7736,13208, 7744,14656, 7752,14672, 7760,9624, + 7768,13720, 7776,14784, 7784,14800, 7792,10136, 7800,14232, 7808,14408, + 7816,14424, 7824,10648, 7832,14744, 7840,14536, 7848,14552, 7856,11160, + 7864,15256, 7872,14664, 7880,14680, 7888,11672, 7896,15768, 7904,14792, + 7912,8088, 7920,12184, 7928,16280, 7936,15424, 7944,15440, 7952,8664, + 7960,12760, 7968,15552, 7976,15568, 7984,9176, 7992,13272, 8000,15680, + 8008,15696, 8016,9688, 8024,13784, 8032,15808, 8040,15824, 8048,10200, + 8056,14296, 8064,15432, 8072,15448, 8080,10712, 8088,14808, 8096,15560, + 8104,15576, 8112,11224, 8120,15320, 8128,15688, 8136,15704, 8144,11736, + 8152,15832, 8160,15816, 8168,15832, 8176,12248, 8184,16344, 8200,8320, + 8208,8224, 8216,12320, 8232,10368, 8240,8736, 8248,12832, 8256,8448, + 8264,8384, 8272,9248, 8280,13344, 8288,9232, 8296,10432, 8304,9760, + 8312,13856, 8328,12416, 8336,10272, 8344,14368, 8352,12296, 8360,14464, + 8368,10784, 8376,14880, 8384,8456, 8392,12480, 8400,11296, 8408,15392, + 8416,12552, 8424,14528, 8432,11808, 8440,15904, 8448,9216, 8456,8576, + 8464,9232, 8472,12384, 8480,9248, 8488,10624, 8496,8800, 8504,12896, + 8512,9472, 8520,8640, 8528,9312, 8536,13408, 8544,9296, 8552,10688, + 8560,9824, 8568,13920, 8576,9224, 8584,12672, 8592,10336, 8600,14432, + 8608,13320, 8616,14720, 8624,10848, 8632,14944, 8640,9480, 8648,12736, + 8656,11360, 8664,15456, 8672,13576, 8680,14784, 8688,11872, 8696,15968, + 8704,12288, 8712,12416, 8720,12296, 8728,12448, 8736,12304, 8744,10376, + 8752,8864, 8760,12960, 8768,12352, 8776,12480, 8784,9376, 8792,13472, + 8800,12368, 8808,10440, 8816,9888, 8824,13984, 8832,12320, 8840,12424, + 8848,10400, 8856,14496, 8864,12312, 8872,14472, 8880,10912, 8888,15008, + 8896,12384, 8904,12488, 8912,11424, 8920,15520, 8928,12568, 8936,14536, + 8944,11936, 8952,16032, 8960,12544, 8968,12672, 8976,12552, 8984,12512, + 8992,12560, 9000,10632, 9008,12568, 9016,13024, 9024,12608, 9032,12736, + 9040,9440, 9048,13536, 9056,12624, 9064,10696, 9072,9952, 9080,14048, + 9088,9240, 9096,12680, 9104,10464, 9112,14560, 9120,13336, 9128,14728, + 9136,10976, 9144,15072, 9152,9496, 9160,12744, 9168,11488, 9176,15584, + 9184,13592, 9192,14792, 9200,12000, 9208,16096, 9224,9344, 9232,9248, + 9240,12576, 9256,11392, 9264,12560, 9272,13088, 9280,9472, 9288,9408, + 9296,9504, 9304,13600, 9312,9488, 9320,11456, 9328,10016, 9336,14112, + 9352,13440, 9360,10528, 9368,14624, 9376,12360, 9384,15488, 9392,11040, + 9400,15136, 9408,9480, 9416,13504, 9424,11552, 9432,15648, 9440,12616, + 9448,15552, 9456,12064, 9464,16160, 9480,9600, 9488,9504, 9496,12640, + 9512,11648, 9520,12624, 9528,13152, 9544,9664, 9552,9568, 9560,13664, + 9576,11712, 9584,10080, 9592,14176, 9608,13696, 9616,10592, 9624,14688, + 9632,13384, 9640,15744, 9648,11104, 9656,15200, 9672,13760, 9680,11616, + 9688,15712, 9696,13640, 9704,15808, 9712,12128, 9720,16224, 9728,13312, + 9736,13440, 9744,13320, 9752,12704, 9760,13328, 9768,11400, 9776,13336, + 9784,13216, 9792,13376, 9800,13504, 9808,13384, 9816,13728, 9824,13392, + 9832,11464, 9840,10144, 9848,14240, 9856,13344, 9864,13448, 9872,10656, + 9880,14752, 9888,12376, 9896,15496, 9904,11168, 9912,15264, 9920,13408, + 9928,13512, 9936,11680, 9944,15776, 9952,12632, 9960,15560, 9968,12192, + 9976,16288, 9984,13568, 9992,13696, 10000,13576, 10008,12768, 10016,13584, + 10024,11656, 10032,13592, 10040,13280, 10048,13632, 10056,13760, + 10064,13640, 10072,13792, 10080,13648, 10088,11720, 10096,10208, + 10104,14304, 10112,13600, 10120,13704, 10128,10720, 10136,14816, + 10144,13400, 10152,15752, 10160,11232, 10168,15328, 10176,13664, + 10184,13768, 10192,11744, 10200,15840, 10208,13656, 10216,15816, + 10224,12256, 10232,16352, 10248,10272, 10256,10368, 10264,12328, + 10280,10384, 10288,10376, 10296,12840, 10304,11264, 10312,11296, + 10320,11392, 10328,13352, 10336,11272, 10344,10448, 10352,11400, + 10360,13864, 10376,12432, 10392,14376, 10400,12328, 10408,14480, + 10416,10792, 10424,14888, 10432,11280, 10440,12496, 10448,11304, + 10456,15400, 10464,11288, 10472,14544, 10480,11816, 10488,15912, + 10496,11264, 10504,11272, 10512,11280, 10520,12392, 10528,11296, + 10536,10640, 10544,12496, 10552,12904, 10560,11328, 10568,11360, + 10576,11456, 10584,13416, 10592,11336, 10600,10704, 10608,11464, + 10616,13928, 10624,11392, 10632,12688, 10640,11304, 10648,14440, + 10656,13352, 10664,14736, 10672,10856, 10680,14952, 10688,11344, + 10696,12752, 10704,11368, 10712,15464, 10720,11352, 10728,14800, + 10736,11880, 10744,15976, 10752,14336, 10760,14368, 10768,14464, + 10776,12456, 10784,14344, 10792,14376, 10800,14472, 10808,12968, + 10816,15360, 10824,15392, 10832,15488, 10840,13480, 10848,15368, + 10856,15400, 10864,15496, 10872,13992, 10880,14352, 10888,12440, + 10896,14480, 10904,14504, 10912,14360, 10920,14488, 10928,14488, + 10936,15016, 10944,15376, 10952,12504, 10960,11432, 10968,15528, + 10976,15384, 10984,14552, 10992,11944, 11000,16040, 11008,14400, + 11016,14432, 11024,14528, 11032,12520, 11040,14408, 11048,14440, + 11056,14536, 11064,13032, 11072,15424, 11080,15456, 11088,15552, + 11096,13544, 11104,15432, 11112,15464, 11120,15560, 11128,14056, + 11136,14416, 11144,12696, 11152,14544, 11160,14568, 11168,14424, + 11176,14744, 11184,14552, 11192,15080, 11200,15440, 11208,12760, + 11216,11496, 11224,15592, 11232,15448, 11240,14808, 11248,12008, + 11256,16104, 11272,11296, 11280,11392, 11288,12584, 11304,11408, + 11312,12688, 11320,13096, 11328,11520, 11336,11552, 11344,11648, + 11352,13608, 11360,11528, 11368,11472, 11376,11656, 11384,14120, + 11400,13456, 11416,14632, 11424,12392, 11432,15504, 11440,14440, + 11448,15144, 11456,11536, 11464,13520, 11472,11560, 11480,15656, + 11488,11544, 11496,15568, 11504,12072, 11512,16168, 11528,11552, + 11536,11648, 11544,12648, 11560,11664, 11568,12752, 11576,13160, + 11592,11616, 11600,11712, 11608,13672, 11624,11728, 11632,11720, + 11640,14184, 11656,13712, 11672,14696, 11680,13416, 11688,15760, + 11696,15464, 11704,15208, 11720,13776, 11736,15720, 11744,13672, + 11752,15824, 11760,12136, 11768,16232, 11776,14592, 11784,14624, + 11792,14720, 11800,12712, 11808,14600, 11816,14632, 11824,14728, + 11832,13224, 11840,15616, 11848,15648, 11856,15744, 11864,13736, + 11872,15624, 11880,15656, 11888,15752, 11896,14248, 11904,14608, + 11912,13464, 11920,14736, 11928,14760, 11936,14616, 11944,15512, + 11952,14744, 11960,15272, 11968,15632, 11976,13528, 11984,15760, + 11992,15784, 12000,15640, 12008,15576, 12016,12200, 12024,16296, + 12032,14656, 12040,14688, 12048,14784, 12056,12776, 12064,14664, + 12072,14696, 12080,14792, 12088,13288, 12096,15680, 12104,15712, + 12112,15808, 12120,13800, 12128,15688, 12136,15720, 12144,15816, + 12152,14312, 12160,14672, 12168,13720, 12176,14800, 12184,14824, + 12192,14680, 12200,15768, 12208,14808, 12216,15336, 12224,15696, + 12232,13784, 12240,15824, 12248,15848, 12256,15704, 12264,15832, + 12272,15832, 12280,16360, 12312,12336, 12344,12848, 12352,12544, + 12360,12552, 12368,12560, 12376,13360, 12384,12576, 12392,12584, + 12400,13336, 12408,13872, 12424,12448, 12440,14384, 12456,14496, + 12464,14472, 12472,14896, 12480,12672, 12488,12512, 12496,12688, + 12504,15408, 12512,12680, 12520,14560, 12528,14728, 12536,15920, + 12544,13312, 12552,13320, 12560,13328, 12568,13336, 12576,13344, + 12584,13352, 12592,13360, 12600,12912, 12608,13568, 12616,13576, + 12624,13584, 12632,13424, 12640,13600, 12648,13608, 12656,13400, + 12664,13936, 12672,13440, 12680,12704, 12688,13456, 12696,14448, + 12704,13448, 12712,14752, 12720,15496, 12728,14960, 12736,13696, + 12744,12768, 12752,13712, 12760,15472, 12768,13704, 12776,14816, + 12784,15752, 12792,15984, 12800,14336, 12808,14464, 12816,14344, + 12824,14472, 12832,14352, 12840,14480, 12848,14360, 12856,12976, + 12864,14400, 12872,14528, 12880,14408, 12888,13488, 12896,14416, + 12904,14544, 12912,14424, 12920,14000, 12928,14368, 12936,14496, + 12944,14376, 12952,14512, 12960,14384, 12968,14504, 12976,14488, + 12984,15024, 12992,14432, 13000,14560, 13008,14440, 13016,15536, + 13024,14448, 13032,14568, 13040,14744, 13048,16048, 13056,14592, + 13064,14720, 13072,14600, 13080,14728, 13088,14608, 13096,14736, + 13104,14616, 13112,14744, 13120,14656, 13128,14784, 13136,14664, + 13144,13552, 13152,14672, 13160,14800, 13168,14680, 13176,14064, + 13184,14624, 13192,14752, 13200,14632, 13208,14576, 13216,13464, + 13224,14760, 13232,15512, 13240,15088, 13248,14688, 13256,14816, + 13264,14696, 13272,15600, 13280,13720, 13288,14824, 13296,15768, + 13304,16112, 13336,13360, 13368,14616, 13376,13568, 13384,13576, + 13392,13584, 13400,13616, 13408,13600, 13416,13608, 13424,13592, + 13432,14128, 13448,13472, 13464,14640, 13480,15520, 13488,14536, + 13496,15152, 13504,13696, 13512,13536, 13520,13712, 13528,15664, + 13536,13704, 13544,15584, 13552,14792, 13560,16176, 13592,13616, + 13624,14680, 13656,13680, 13688,14192, 13704,13728, 13720,14704, + 13736,15776, 13744,15560, 13752,15216, 13768,13792, 13784,15728, + 13800,15840, 13808,15816, 13816,16240, 13824,15360, 13832,15488, + 13840,15368, 13848,15496, 13856,15376, 13864,15504, 13872,15384, + 13880,15512, 13888,15424, 13896,15552, 13904,15432, 13912,15560, + 13920,15440, 13928,15568, 13936,15448, 13944,14256, 13952,15392, + 13960,15520, 13968,15400, 13976,14768, 13984,15408, 13992,15528, + 14000,14552, 14008,15280, 14016,15456, 14024,15584, 14032,15464, + 14040,15792, 14048,15472, 14056,15592, 14064,14808, 14072,16304, + 14080,15616, 14088,15744, 14096,15624, 14104,15752, 14112,15632, + 14120,15760, 14128,15640, 14136,15768, 14144,15680, 14152,15808, + 14160,15688, 14168,15816, 14176,15696, 14184,15824, 14192,15704, + 14200,14320, 14208,15648, 14216,15776, 14224,15656, 14232,14832, + 14240,15664, 14248,15784, 14256,15576, 14264,15344, 14272,15712, + 14280,15840, 14288,15720, 14296,15856, 14304,15728, 14312,15848, + 14320,15832, 14328,16368, 14392,14488, 14400,14592, 14408,14600, + 14416,14608, 14424,14616, 14432,14624, 14440,14632, 14448,14640, + 14456,15512, 14504,14512, 14520,14904, 14528,14720, 14536,14728, + 14544,14736, 14552,15416, 14560,14752, 14568,14576, 14584,15928, + 14576,14760, 14592,15360, 14600,15368, 14608,15376, 14616,15384, + 14624,15392, 14632,15400, 14640,15408, 14648,15416, 14656,15616, + 14664,15624, 14672,15632, 14680,15640, 14688,15648, 14696,15656, + 14704,15664, 14712,15576, 14720,15488, 14728,15496, 14736,15504, + 14744,15512, 14752,15520, 14760,14768, 14776,14968, 14768,15528, + 14784,15744, 14792,15752, 14800,15760, 14808,15480, 14816,15776, + 14824,14832, 14840,15992, 14832,15784, 14856,14864, 14864,14880, + 14872,14896, 14880,14976, 14888,14992, 14896,15008, 14904,15024, + 14912,15104, 14920,15120, 14928,15136, 14936,15152, 14944,15232, + 14952,15248, 14960,15264, 14968,15280, 14984,15008, 15000,15024, + 15016,15024, 15040,15112, 15048,15128, 15056,15144, 15064,15544, + 15072,15240, 15080,15256, 15088,15272, 15096,16056, 15104,15872, + 15112,15888, 15120,15904, 15128,15920, 15136,16000, 15144,16016, + 15152,16032, 15160,16048, 15168,16128, 15176,16144, 15184,16160, + 15192,16176, 15200,16256, 15208,16272, 15216,16288, 15224,16304, + 15232,15880, 15240,15896, 15248,15912, 15256,15928, 15264,16008, + 15272,16024, 15280,16040, 15288,16056, 15296,16136, 15304,16152, + 15312,16168, 15320,15608, 15328,16264, 15336,16280, 15344,16296, + 15352,16120, 15416,15512, 15424,15616, 15432,15624, 15440,15632, + 15448,15640, 15456,15648, 15464,15656, 15472,15664, 15480,15768, + 15528,15536, 15544,16048, 15552,15744, 15560,15752, 15568,15760, + 15576,15672, 15584,15776, 15592,15600, 15600,15784, 15608,16184, + 15672,15768, 15736,15832, 15784,15792, 15800,16304, 15848,15856, + 15880,16000, 15864,16248, 15888,16000, 15896,16008, 15904,16000, + 15912,16016, 15920,16008, 15928,16024, 15936,16128, 15944,16160, + 15952,16256, 15960,16288, 15968,16136, 15976,16168, 15984,16264, + 15992,16296, 16008,16032, 16024,16040, 16064,16144, 16040,16048, + 16072,16176, 16080,16272, 16088,16304, 16096,16152, 16104,16184, + 16112,16280, 16136,16256, 16120,16312, 16144,16256, 16152,16264, + 16160,16256, 16168,16272, 16176,16264, 16184,16280, 16200,16208, + 16208,16224, 16216,16240, 16224,16320, 16232,16336, 16240,16352, + 16248,16368, 16264,16288, 16280,16296, 16296,16304, 16344,16368, + 16328,16352, 16360,16368 +}; + +const uint16_t armBitRevIndexTable4096[ARMBITREVINDEXTABLE_4096_TABLE_LENGTH] = +{ + /* radix 8, size 4032 */ + 8,4096, 16,8192, 24,12288, 32,16384, 40,20480, 48,24576, 56,28672, 64,512, + 72,4608, 80,8704, 88,12800, 96,16896, 104,20992, 112,25088, 120,29184, + 128,1024, 136,5120, 144,9216, 152,13312, 160,17408, 168,21504, 176,25600, + 184,29696, 192,1536, 200,5632, 208,9728, 216,13824, 224,17920, 232,22016, + 240,26112, 248,30208, 256,2048, 264,6144, 272,10240, 280,14336, 288,18432, + 296,22528, 304,26624, 312,30720, 320,2560, 328,6656, 336,10752, 344,14848, + 352,18944, 360,23040, 368,27136, 376,31232, 384,3072, 392,7168, 400,11264, + 408,15360, 416,19456, 424,23552, 432,27648, 440,31744, 448,3584, 456,7680, + 464,11776, 472,15872, 480,19968, 488,24064, 496,28160, 504,32256, 520,4160, + 528,8256, 536,12352, 544,16448, 552,20544, 560,24640, 568,28736, 584,4672, + 592,8768, 600,12864, 608,16960, 616,21056, 624,25152, 632,29248, 640,1088, + 648,5184, 656,9280, 664,13376, 672,17472, 680,21568, 688,25664, 696,29760, + 704,1600, 712,5696, 720,9792, 728,13888, 736,17984, 744,22080, 752,26176, + 760,30272, 768,2112, 776,6208, 784,10304, 792,14400, 800,18496, 808,22592, + 816,26688, 824,30784, 832,2624, 840,6720, 848,10816, 856,14912, 864,19008, + 872,23104, 880,27200, 888,31296, 896,3136, 904,7232, 912,11328, 920,15424, + 928,19520, 936,23616, 944,27712, 952,31808, 960,3648, 968,7744, 976,11840, + 984,15936, 992,20032, 1000,24128, 1008,28224, 1016,32320, 1032,4224, + 1040,8320, 1048,12416, 1056,16512, 1064,20608, 1072,24704, 1080,28800, + 1096,4736, 1104,8832, 1112,12928, 1120,17024, 1128,21120, 1136,25216, + 1144,29312, 1160,5248, 1168,9344, 1176,13440, 1184,17536, 1192,21632, + 1200,25728, 1208,29824, 1216,1664, 1224,5760, 1232,9856, 1240,13952, + 1248,18048, 1256,22144, 1264,26240, 1272,30336, 1280,2176, 1288,6272, + 1296,10368, 1304,14464, 1312,18560, 1320,22656, 1328,26752, 1336,30848, + 1344,2688, 1352,6784, 1360,10880, 1368,14976, 1376,19072, 1384,23168, + 1392,27264, 1400,31360, 1408,3200, 1416,7296, 1424,11392, 1432,15488, + 1440,19584, 1448,23680, 1456,27776, 1464,31872, 1472,3712, 1480,7808, + 1488,11904, 1496,16000, 1504,20096, 1512,24192, 1520,28288, 1528,32384, + 1544,4288, 1552,8384, 1560,12480, 1568,16576, 1576,20672, 1584,24768, + 1592,28864, 1608,4800, 1616,8896, 1624,12992, 1632,17088, 1640,21184, + 1648,25280, 1656,29376, 1672,5312, 1680,9408, 1688,13504, 1696,17600, + 1704,21696, 1712,25792, 1720,29888, 1736,5824, 1744,9920, 1752,14016, + 1760,18112, 1768,22208, 1776,26304, 1784,30400, 1792,2240, 1800,6336, + 1808,10432, 1816,14528, 1824,18624, 1832,22720, 1840,26816, 1848,30912, + 1856,2752, 1864,6848, 1872,10944, 1880,15040, 1888,19136, 1896,23232, + 1904,27328, 1912,31424, 1920,3264, 1928,7360, 1936,11456, 1944,15552, + 1952,19648, 1960,23744, 1968,27840, 1976,31936, 1984,3776, 1992,7872, + 2000,11968, 2008,16064, 2016,20160, 2024,24256, 2032,28352, 2040,32448, + 2056,4352, 2064,8448, 2072,12544, 2080,16640, 2088,20736, 2096,24832, + 2104,28928, 2120,4864, 2128,8960, 2136,13056, 2144,17152, 2152,21248, + 2160,25344, 2168,29440, 2184,5376, 2192,9472, 2200,13568, 2208,17664, + 2216,21760, 2224,25856, 2232,29952, 2248,5888, 2256,9984, 2264,14080, + 2272,18176, 2280,22272, 2288,26368, 2296,30464, 2312,6400, 2320,10496, + 2328,14592, 2336,18688, 2344,22784, 2352,26880, 2360,30976, 2368,2816, + 2376,6912, 2384,11008, 2392,15104, 2400,19200, 2408,23296, 2416,27392, + 2424,31488, 2432,3328, 2440,7424, 2448,11520, 2456,15616, 2464,19712, + 2472,23808, 2480,27904, 2488,32000, 2496,3840, 2504,7936, 2512,12032, + 2520,16128, 2528,20224, 2536,24320, 2544,28416, 2552,32512, 2568,4416, + 2576,8512, 2584,12608, 2592,16704, 2600,20800, 2608,24896, 2616,28992, + 2632,4928, 2640,9024, 2648,13120, 2656,17216, 2664,21312, 2672,25408, + 2680,29504, 2696,5440, 2704,9536, 2712,13632, 2720,17728, 2728,21824, + 2736,25920, 2744,30016, 2760,5952, 2768,10048, 2776,14144, 2784,18240, + 2792,22336, 2800,26432, 2808,30528, 2824,6464, 2832,10560, 2840,14656, + 2848,18752, 2856,22848, 2864,26944, 2872,31040, 2888,6976, 2896,11072, + 2904,15168, 2912,19264, 2920,23360, 2928,27456, 2936,31552, 2944,3392, + 2952,7488, 2960,11584, 2968,15680, 2976,19776, 2984,23872, 2992,27968, + 3000,32064, 3008,3904, 3016,8000, 3024,12096, 3032,16192, 3040,20288, + 3048,24384, 3056,28480, 3064,32576, 3080,4480, 3088,8576, 3096,12672, + 3104,16768, 3112,20864, 3120,24960, 3128,29056, 3144,4992, 3152,9088, + 3160,13184, 3168,17280, 3176,21376, 3184,25472, 3192,29568, 3208,5504, + 3216,9600, 3224,13696, 3232,17792, 3240,21888, 3248,25984, 3256,30080, + 3272,6016, 3280,10112, 3288,14208, 3296,18304, 3304,22400, 3312,26496, + 3320,30592, 3336,6528, 3344,10624, 3352,14720, 3360,18816, 3368,22912, + 3376,27008, 3384,31104, 3400,7040, 3408,11136, 3416,15232, 3424,19328, + 3432,23424, 3440,27520, 3448,31616, 3464,7552, 3472,11648, 3480,15744, + 3488,19840, 3496,23936, 3504,28032, 3512,32128, 3520,3968, 3528,8064, + 3536,12160, 3544,16256, 3552,20352, 3560,24448, 3568,28544, 3576,32640, + 3592,4544, 3600,8640, 3608,12736, 3616,16832, 3624,20928, 3632,25024, + 3640,29120, 3656,5056, 3664,9152, 3672,13248, 3680,17344, 3688,21440, + 3696,25536, 3704,29632, 3720,5568, 3728,9664, 3736,13760, 3744,17856, + 3752,21952, 3760,26048, 3768,30144, 3784,6080, 3792,10176, 3800,14272, + 3808,18368, 3816,22464, 3824,26560, 3832,30656, 3848,6592, 3856,10688, + 3864,14784, 3872,18880, 3880,22976, 3888,27072, 3896,31168, 3912,7104, + 3920,11200, 3928,15296, 3936,19392, 3944,23488, 3952,27584, 3960,31680, + 3976,7616, 3984,11712, 3992,15808, 4000,19904, 4008,24000, 4016,28096, + 4024,32192, 4040,8128, 4048,12224, 4056,16320, 4064,20416, 4072,24512, + 4080,28608, 4088,32704, 4112,8200, 4120,12296, 4128,16392, 4136,20488, + 4144,24584, 4152,28680, 4168,4616, 4176,8712, 4184,12808, 4192,16904, + 4200,21000, 4208,25096, 4216,29192, 4232,5128, 4240,9224, 4248,13320, + 4256,17416, 4264,21512, 4272,25608, 4280,29704, 4296,5640, 4304,9736, + 4312,13832, 4320,17928, 4328,22024, 4336,26120, 4344,30216, 4360,6152, + 4368,10248, 4376,14344, 4384,18440, 4392,22536, 4400,26632, 4408,30728, + 4424,6664, 4432,10760, 4440,14856, 4448,18952, 4456,23048, 4464,27144, + 4472,31240, 4488,7176, 4496,11272, 4504,15368, 4512,19464, 4520,23560, + 4528,27656, 4536,31752, 4552,7688, 4560,11784, 4568,15880, 4576,19976, + 4584,24072, 4592,28168, 4600,32264, 4624,8264, 4632,12360, 4640,16456, + 4648,20552, 4656,24648, 4664,28744, 4688,8776, 4696,12872, 4704,16968, + 4712,21064, 4720,25160, 4728,29256, 4744,5192, 4752,9288, 4760,13384, + 4768,17480, 4776,21576, 4784,25672, 4792,29768, 4808,5704, 4816,9800, + 4824,13896, 4832,17992, 4840,22088, 4848,26184, 4856,30280, 4872,6216, + 4880,10312, 4888,14408, 4896,18504, 4904,22600, 4912,26696, 4920,30792, + 4936,6728, 4944,10824, 4952,14920, 4960,19016, 4968,23112, 4976,27208, + 4984,31304, 5000,7240, 5008,11336, 5016,15432, 5024,19528, 5032,23624, + 5040,27720, 5048,31816, 5064,7752, 5072,11848, 5080,15944, 5088,20040, + 5096,24136, 5104,28232, 5112,32328, 5136,8328, 5144,12424, 5152,16520, + 5160,20616, 5168,24712, 5176,28808, 5200,8840, 5208,12936, 5216,17032, + 5224,21128, 5232,25224, 5240,29320, 5264,9352, 5272,13448, 5280,17544, + 5288,21640, 5296,25736, 5304,29832, 5320,5768, 5328,9864, 5336,13960, + 5344,18056, 5352,22152, 5360,26248, 5368,30344, 5384,6280, 5392,10376, + 5400,14472, 5408,18568, 5416,22664, 5424,26760, 5432,30856, 5448,6792, + 5456,10888, 5464,14984, 5472,19080, 5480,23176, 5488,27272, 5496,31368, + 5512,7304, 5520,11400, 5528,15496, 5536,19592, 5544,23688, 5552,27784, + 5560,31880, 5576,7816, 5584,11912, 5592,16008, 5600,20104, 5608,24200, + 5616,28296, 5624,32392, 5648,8392, 5656,12488, 5664,16584, 5672,20680, + 5680,24776, 5688,28872, 5712,8904, 5720,13000, 5728,17096, 5736,21192, + 5744,25288, 5752,29384, 5776,9416, 5784,13512, 5792,17608, 5800,21704, + 5808,25800, 5816,29896, 5840,9928, 5848,14024, 5856,18120, 5864,22216, + 5872,26312, 5880,30408, 5896,6344, 5904,10440, 5912,14536, 5920,18632, + 5928,22728, 5936,26824, 5944,30920, 5960,6856, 5968,10952, 5976,15048, + 5984,19144, 5992,23240, 6000,27336, 6008,31432, 6024,7368, 6032,11464, + 6040,15560, 6048,19656, 6056,23752, 6064,27848, 6072,31944, 6088,7880, + 6096,11976, 6104,16072, 6112,20168, 6120,24264, 6128,28360, 6136,32456, + 6160,8456, 6168,12552, 6176,16648, 6184,20744, 6192,24840, 6200,28936, + 6224,8968, 6232,13064, 6240,17160, 6248,21256, 6256,25352, 6264,29448, + 6288,9480, 6296,13576, 6304,17672, 6312,21768, 6320,25864, 6328,29960, + 6352,9992, 6360,14088, 6368,18184, 6376,22280, 6384,26376, 6392,30472, + 6416,10504, 6424,14600, 6432,18696, 6440,22792, 6448,26888, 6456,30984, + 6472,6920, 6480,11016, 6488,15112, 6496,19208, 6504,23304, 6512,27400, + 6520,31496, 6536,7432, 6544,11528, 6552,15624, 6560,19720, 6568,23816, + 6576,27912, 6584,32008, 6600,7944, 6608,12040, 6616,16136, 6624,20232, + 6632,24328, 6640,28424, 6648,32520, 6672,8520, 6680,12616, 6688,16712, + 6696,20808, 6704,24904, 6712,29000, 6736,9032, 6744,13128, 6752,17224, + 6760,21320, 6768,25416, 6776,29512, 6800,9544, 6808,13640, 6816,17736, + 6824,21832, 6832,25928, 6840,30024, 6864,10056, 6872,14152, 6880,18248, + 6888,22344, 6896,26440, 6904,30536, 6928,10568, 6936,14664, 6944,18760, + 6952,22856, 6960,26952, 6968,31048, 6992,11080, 7000,15176, 7008,19272, + 7016,23368, 7024,27464, 7032,31560, 7048,7496, 7056,11592, 7064,15688, + 7072,19784, 7080,23880, 7088,27976, 7096,32072, 7112,8008, 7120,12104, + 7128,16200, 7136,20296, 7144,24392, 7152,28488, 7160,32584, 7184,8584, + 7192,12680, 7200,16776, 7208,20872, 7216,24968, 7224,29064, 7248,9096, + 7256,13192, 7264,17288, 7272,21384, 7280,25480, 7288,29576, 7312,9608, + 7320,13704, 7328,17800, 7336,21896, 7344,25992, 7352,30088, 7376,10120, + 7384,14216, 7392,18312, 7400,22408, 7408,26504, 7416,30600, 7440,10632, + 7448,14728, 7456,18824, 7464,22920, 7472,27016, 7480,31112, 7504,11144, + 7512,15240, 7520,19336, 7528,23432, 7536,27528, 7544,31624, 7568,11656, + 7576,15752, 7584,19848, 7592,23944, 7600,28040, 7608,32136, 7624,8072, + 7632,12168, 7640,16264, 7648,20360, 7656,24456, 7664,28552, 7672,32648, + 7696,8648, 7704,12744, 7712,16840, 7720,20936, 7728,25032, 7736,29128, + 7760,9160, 7768,13256, 7776,17352, 7784,21448, 7792,25544, 7800,29640, + 7824,9672, 7832,13768, 7840,17864, 7848,21960, 7856,26056, 7864,30152, + 7888,10184, 7896,14280, 7904,18376, 7912,22472, 7920,26568, 7928,30664, + 7952,10696, 7960,14792, 7968,18888, 7976,22984, 7984,27080, 7992,31176, + 8016,11208, 8024,15304, 8032,19400, 8040,23496, 8048,27592, 8056,31688, + 8080,11720, 8088,15816, 8096,19912, 8104,24008, 8112,28104, 8120,32200, + 8144,12232, 8152,16328, 8160,20424, 8168,24520, 8176,28616, 8184,32712, + 8216,12304, 8224,16400, 8232,20496, 8240,24592, 8248,28688, 8272,8720, + 8280,12816, 8288,16912, 8296,21008, 8304,25104, 8312,29200, 8336,9232, + 8344,13328, 8352,17424, 8360,21520, 8368,25616, 8376,29712, 8400,9744, + 8408,13840, 8416,17936, 8424,22032, 8432,26128, 8440,30224, 8464,10256, + 8472,14352, 8480,18448, 8488,22544, 8496,26640, 8504,30736, 8528,10768, + 8536,14864, 8544,18960, 8552,23056, 8560,27152, 8568,31248, 8592,11280, + 8600,15376, 8608,19472, 8616,23568, 8624,27664, 8632,31760, 8656,11792, + 8664,15888, 8672,19984, 8680,24080, 8688,28176, 8696,32272, 8728,12368, + 8736,16464, 8744,20560, 8752,24656, 8760,28752, 8792,12880, 8800,16976, + 8808,21072, 8816,25168, 8824,29264, 8848,9296, 8856,13392, 8864,17488, + 8872,21584, 8880,25680, 8888,29776, 8912,9808, 8920,13904, 8928,18000, + 8936,22096, 8944,26192, 8952,30288, 8976,10320, 8984,14416, 8992,18512, + 9000,22608, 9008,26704, 9016,30800, 9040,10832, 9048,14928, 9056,19024, + 9064,23120, 9072,27216, 9080,31312, 9104,11344, 9112,15440, 9120,19536, + 9128,23632, 9136,27728, 9144,31824, 9168,11856, 9176,15952, 9184,20048, + 9192,24144, 9200,28240, 9208,32336, 9240,12432, 9248,16528, 9256,20624, + 9264,24720, 9272,28816, 9304,12944, 9312,17040, 9320,21136, 9328,25232, + 9336,29328, 9368,13456, 9376,17552, 9384,21648, 9392,25744, 9400,29840, + 9424,9872, 9432,13968, 9440,18064, 9448,22160, 9456,26256, 9464,30352, + 9488,10384, 9496,14480, 9504,18576, 9512,22672, 9520,26768, 9528,30864, + 9552,10896, 9560,14992, 9568,19088, 9576,23184, 9584,27280, 9592,31376, + 9616,11408, 9624,15504, 9632,19600, 9640,23696, 9648,27792, 9656,31888, + 9680,11920, 9688,16016, 9696,20112, 9704,24208, 9712,28304, 9720,32400, + 9752,12496, 9760,16592, 9768,20688, 9776,24784, 9784,28880, 9816,13008, + 9824,17104, 9832,21200, 9840,25296, 9848,29392, 9880,13520, 9888,17616, + 9896,21712, 9904,25808, 9912,29904, 9944,14032, 9952,18128, 9960,22224, + 9968,26320, 9976,30416, 10000,10448, 10008,14544, 10016,18640, 10024,22736, + 10032,26832, 10040,30928, 10064,10960, 10072,15056, 10080,19152, + 10088,23248, 10096,27344, 10104,31440, 10128,11472, 10136,15568, + 10144,19664, 10152,23760, 10160,27856, 10168,31952, 10192,11984, + 10200,16080, 10208,20176, 10216,24272, 10224,28368, 10232,32464, + 10264,12560, 10272,16656, 10280,20752, 10288,24848, 10296,28944, + 10328,13072, 10336,17168, 10344,21264, 10352,25360, 10360,29456, + 10392,13584, 10400,17680, 10408,21776, 10416,25872, 10424,29968, + 10456,14096, 10464,18192, 10472,22288, 10480,26384, 10488,30480, + 10520,14608, 10528,18704, 10536,22800, 10544,26896, 10552,30992, + 10576,11024, 10584,15120, 10592,19216, 10600,23312, 10608,27408, + 10616,31504, 10640,11536, 10648,15632, 10656,19728, 10664,23824, + 10672,27920, 10680,32016, 10704,12048, 10712,16144, 10720,20240, + 10728,24336, 10736,28432, 10744,32528, 10776,12624, 10784,16720, + 10792,20816, 10800,24912, 10808,29008, 10840,13136, 10848,17232, + 10856,21328, 10864,25424, 10872,29520, 10904,13648, 10912,17744, + 10920,21840, 10928,25936, 10936,30032, 10968,14160, 10976,18256, + 10984,22352, 10992,26448, 11000,30544, 11032,14672, 11040,18768, + 11048,22864, 11056,26960, 11064,31056, 11096,15184, 11104,19280, + 11112,23376, 11120,27472, 11128,31568, 11152,11600, 11160,15696, + 11168,19792, 11176,23888, 11184,27984, 11192,32080, 11216,12112, + 11224,16208, 11232,20304, 11240,24400, 11248,28496, 11256,32592, + 11288,12688, 11296,16784, 11304,20880, 11312,24976, 11320,29072, + 11352,13200, 11360,17296, 11368,21392, 11376,25488, 11384,29584, + 11416,13712, 11424,17808, 11432,21904, 11440,26000, 11448,30096, + 11480,14224, 11488,18320, 11496,22416, 11504,26512, 11512,30608, + 11544,14736, 11552,18832, 11560,22928, 11568,27024, 11576,31120, + 11608,15248, 11616,19344, 11624,23440, 11632,27536, 11640,31632, + 11672,15760, 11680,19856, 11688,23952, 11696,28048, 11704,32144, + 11728,12176, 11736,16272, 11744,20368, 11752,24464, 11760,28560, + 11768,32656, 11800,12752, 11808,16848, 11816,20944, 11824,25040, + 11832,29136, 11864,13264, 11872,17360, 11880,21456, 11888,25552, + 11896,29648, 11928,13776, 11936,17872, 11944,21968, 11952,26064, + 11960,30160, 11992,14288, 12000,18384, 12008,22480, 12016,26576, + 12024,30672, 12056,14800, 12064,18896, 12072,22992, 12080,27088, + 12088,31184, 12120,15312, 12128,19408, 12136,23504, 12144,27600, + 12152,31696, 12184,15824, 12192,19920, 12200,24016, 12208,28112, + 12216,32208, 12248,16336, 12256,20432, 12264,24528, 12272,28624, + 12280,32720, 12320,16408, 12328,20504, 12336,24600, 12344,28696, + 12376,12824, 12384,16920, 12392,21016, 12400,25112, 12408,29208, + 12440,13336, 12448,17432, 12456,21528, 12464,25624, 12472,29720, + 12504,13848, 12512,17944, 12520,22040, 12528,26136, 12536,30232, + 12568,14360, 12576,18456, 12584,22552, 12592,26648, 12600,30744, + 12632,14872, 12640,18968, 12648,23064, 12656,27160, 12664,31256, + 12696,15384, 12704,19480, 12712,23576, 12720,27672, 12728,31768, + 12760,15896, 12768,19992, 12776,24088, 12784,28184, 12792,32280, + 12832,16472, 12840,20568, 12848,24664, 12856,28760, 12896,16984, + 12904,21080, 12912,25176, 12920,29272, 12952,13400, 12960,17496, + 12968,21592, 12976,25688, 12984,29784, 13016,13912, 13024,18008, + 13032,22104, 13040,26200, 13048,30296, 13080,14424, 13088,18520, + 13096,22616, 13104,26712, 13112,30808, 13144,14936, 13152,19032, + 13160,23128, 13168,27224, 13176,31320, 13208,15448, 13216,19544, + 13224,23640, 13232,27736, 13240,31832, 13272,15960, 13280,20056, + 13288,24152, 13296,28248, 13304,32344, 13344,16536, 13352,20632, + 13360,24728, 13368,28824, 13408,17048, 13416,21144, 13424,25240, + 13432,29336, 13472,17560, 13480,21656, 13488,25752, 13496,29848, + 13528,13976, 13536,18072, 13544,22168, 13552,26264, 13560,30360, + 13592,14488, 13600,18584, 13608,22680, 13616,26776, 13624,30872, + 13656,15000, 13664,19096, 13672,23192, 13680,27288, 13688,31384, + 13720,15512, 13728,19608, 13736,23704, 13744,27800, 13752,31896, + 13784,16024, 13792,20120, 13800,24216, 13808,28312, 13816,32408, + 13856,16600, 13864,20696, 13872,24792, 13880,28888, 13920,17112, + 13928,21208, 13936,25304, 13944,29400, 13984,17624, 13992,21720, + 14000,25816, 14008,29912, 14048,18136, 14056,22232, 14064,26328, + 14072,30424, 14104,14552, 14112,18648, 14120,22744, 14128,26840, + 14136,30936, 14168,15064, 14176,19160, 14184,23256, 14192,27352, + 14200,31448, 14232,15576, 14240,19672, 14248,23768, 14256,27864, + 14264,31960, 14296,16088, 14304,20184, 14312,24280, 14320,28376, + 14328,32472, 14368,16664, 14376,20760, 14384,24856, 14392,28952, + 14432,17176, 14440,21272, 14448,25368, 14456,29464, 14496,17688, + 14504,21784, 14512,25880, 14520,29976, 14560,18200, 14568,22296, + 14576,26392, 14584,30488, 14624,18712, 14632,22808, 14640,26904, + 14648,31000, 14680,15128, 14688,19224, 14696,23320, 14704,27416, + 14712,31512, 14744,15640, 14752,19736, 14760,23832, 14768,27928, + 14776,32024, 14808,16152, 14816,20248, 14824,24344, 14832,28440, + 14840,32536, 14880,16728, 14888,20824, 14896,24920, 14904,29016, + 14944,17240, 14952,21336, 14960,25432, 14968,29528, 15008,17752, + 15016,21848, 15024,25944, 15032,30040, 15072,18264, 15080,22360, + 15088,26456, 15096,30552, 15136,18776, 15144,22872, 15152,26968, + 15160,31064, 15200,19288, 15208,23384, 15216,27480, 15224,31576, + 15256,15704, 15264,19800, 15272,23896, 15280,27992, 15288,32088, + 15320,16216, 15328,20312, 15336,24408, 15344,28504, 15352,32600, + 15392,16792, 15400,20888, 15408,24984, 15416,29080, 15456,17304, + 15464,21400, 15472,25496, 15480,29592, 15520,17816, 15528,21912, + 15536,26008, 15544,30104, 15584,18328, 15592,22424, 15600,26520, + 15608,30616, 15648,18840, 15656,22936, 15664,27032, 15672,31128, + 15712,19352, 15720,23448, 15728,27544, 15736,31640, 15776,19864, + 15784,23960, 15792,28056, 15800,32152, 15832,16280, 15840,20376, + 15848,24472, 15856,28568, 15864,32664, 15904,16856, 15912,20952, + 15920,25048, 15928,29144, 15968,17368, 15976,21464, 15984,25560, + 15992,29656, 16032,17880, 16040,21976, 16048,26072, 16056,30168, + 16096,18392, 16104,22488, 16112,26584, 16120,30680, 16160,18904, + 16168,23000, 16176,27096, 16184,31192, 16224,19416, 16232,23512, + 16240,27608, 16248,31704, 16288,19928, 16296,24024, 16304,28120, + 16312,32216, 16352,20440, 16360,24536, 16368,28632, 16376,32728, + 16424,20512, 16432,24608, 16440,28704, 16480,16928, 16488,21024, + 16496,25120, 16504,29216, 16544,17440, 16552,21536, 16560,25632, + 16568,29728, 16608,17952, 16616,22048, 16624,26144, 16632,30240, + 16672,18464, 16680,22560, 16688,26656, 16696,30752, 16736,18976, + 16744,23072, 16752,27168, 16760,31264, 16800,19488, 16808,23584, + 16816,27680, 16824,31776, 16864,20000, 16872,24096, 16880,28192, + 16888,32288, 16936,20576, 16944,24672, 16952,28768, 17000,21088, + 17008,25184, 17016,29280, 17056,17504, 17064,21600, 17072,25696, + 17080,29792, 17120,18016, 17128,22112, 17136,26208, 17144,30304, + 17184,18528, 17192,22624, 17200,26720, 17208,30816, 17248,19040, + 17256,23136, 17264,27232, 17272,31328, 17312,19552, 17320,23648, + 17328,27744, 17336,31840, 17376,20064, 17384,24160, 17392,28256, + 17400,32352, 17448,20640, 17456,24736, 17464,28832, 17512,21152, + 17520,25248, 17528,29344, 17576,21664, 17584,25760, 17592,29856, + 17632,18080, 17640,22176, 17648,26272, 17656,30368, 17696,18592, + 17704,22688, 17712,26784, 17720,30880, 17760,19104, 17768,23200, + 17776,27296, 17784,31392, 17824,19616, 17832,23712, 17840,27808, + 17848,31904, 17888,20128, 17896,24224, 17904,28320, 17912,32416, + 17960,20704, 17968,24800, 17976,28896, 18024,21216, 18032,25312, + 18040,29408, 18088,21728, 18096,25824, 18104,29920, 18152,22240, + 18160,26336, 18168,30432, 18208,18656, 18216,22752, 18224,26848, + 18232,30944, 18272,19168, 18280,23264, 18288,27360, 18296,31456, + 18336,19680, 18344,23776, 18352,27872, 18360,31968, 18400,20192, + 18408,24288, 18416,28384, 18424,32480, 18472,20768, 18480,24864, + 18488,28960, 18536,21280, 18544,25376, 18552,29472, 18600,21792, + 18608,25888, 18616,29984, 18664,22304, 18672,26400, 18680,30496, + 18728,22816, 18736,26912, 18744,31008, 18784,19232, 18792,23328, + 18800,27424, 18808,31520, 18848,19744, 18856,23840, 18864,27936, + 18872,32032, 18912,20256, 18920,24352, 18928,28448, 18936,32544, + 18984,20832, 18992,24928, 19000,29024, 19048,21344, 19056,25440, + 19064,29536, 19112,21856, 19120,25952, 19128,30048, 19176,22368, + 19184,26464, 19192,30560, 19240,22880, 19248,26976, 19256,31072, + 19304,23392, 19312,27488, 19320,31584, 19360,19808, 19368,23904, + 19376,28000, 19384,32096, 19424,20320, 19432,24416, 19440,28512, + 19448,32608, 19496,20896, 19504,24992, 19512,29088, 19560,21408, + 19568,25504, 19576,29600, 19624,21920, 19632,26016, 19640,30112, + 19688,22432, 19696,26528, 19704,30624, 19752,22944, 19760,27040, + 19768,31136, 19816,23456, 19824,27552, 19832,31648, 19880,23968, + 19888,28064, 19896,32160, 19936,20384, 19944,24480, 19952,28576, + 19960,32672, 20008,20960, 20016,25056, 20024,29152, 20072,21472, + 20080,25568, 20088,29664, 20136,21984, 20144,26080, 20152,30176, + 20200,22496, 20208,26592, 20216,30688, 20264,23008, 20272,27104, + 20280,31200, 20328,23520, 20336,27616, 20344,31712, 20392,24032, + 20400,28128, 20408,32224, 20456,24544, 20464,28640, 20472,32736, + 20528,24616, 20536,28712, 20584,21032, 20592,25128, 20600,29224, + 20648,21544, 20656,25640, 20664,29736, 20712,22056, 20720,26152, + 20728,30248, 20776,22568, 20784,26664, 20792,30760, 20840,23080, + 20848,27176, 20856,31272, 20904,23592, 20912,27688, 20920,31784, + 20968,24104, 20976,28200, 20984,32296, 21040,24680, 21048,28776, + 21104,25192, 21112,29288, 21160,21608, 21168,25704, 21176,29800, + 21224,22120, 21232,26216, 21240,30312, 21288,22632, 21296,26728, + 21304,30824, 21352,23144, 21360,27240, 21368,31336, 21416,23656, + 21424,27752, 21432,31848, 21480,24168, 21488,28264, 21496,32360, + 21552,24744, 21560,28840, 21616,25256, 21624,29352, 21680,25768, + 21688,29864, 21736,22184, 21744,26280, 21752,30376, 21800,22696, + 21808,26792, 21816,30888, 21864,23208, 21872,27304, 21880,31400, + 21928,23720, 21936,27816, 21944,31912, 21992,24232, 22000,28328, + 22008,32424, 22064,24808, 22072,28904, 22128,25320, 22136,29416, + 22192,25832, 22200,29928, 22256,26344, 22264,30440, 22312,22760, + 22320,26856, 22328,30952, 22376,23272, 22384,27368, 22392,31464, + 22440,23784, 22448,27880, 22456,31976, 22504,24296, 22512,28392, + 22520,32488, 22576,24872, 22584,28968, 22640,25384, 22648,29480, + 22704,25896, 22712,29992, 22768,26408, 22776,30504, 22832,26920, + 22840,31016, 22888,23336, 22896,27432, 22904,31528, 22952,23848, + 22960,27944, 22968,32040, 23016,24360, 23024,28456, 23032,32552, + 23088,24936, 23096,29032, 23152,25448, 23160,29544, 23216,25960, + 23224,30056, 23280,26472, 23288,30568, 23344,26984, 23352,31080, + 23408,27496, 23416,31592, 23464,23912, 23472,28008, 23480,32104, + 23528,24424, 23536,28520, 23544,32616, 23600,25000, 23608,29096, + 23664,25512, 23672,29608, 23728,26024, 23736,30120, 23792,26536, + 23800,30632, 23856,27048, 23864,31144, 23920,27560, 23928,31656, + 23984,28072, 23992,32168, 24040,24488, 24048,28584, 24056,32680, + 24112,25064, 24120,29160, 24176,25576, 24184,29672, 24240,26088, + 24248,30184, 24304,26600, 24312,30696, 24368,27112, 24376,31208, + 24432,27624, 24440,31720, 24496,28136, 24504,32232, 24560,28648, + 24568,32744, 24632,28720, 24688,25136, 24696,29232, 24752,25648, + 24760,29744, 24816,26160, 24824,30256, 24880,26672, 24888,30768, + 24944,27184, 24952,31280, 25008,27696, 25016,31792, 25072,28208, + 25080,32304, 25144,28784, 25208,29296, 25264,25712, 25272,29808, + 25328,26224, 25336,30320, 25392,26736, 25400,30832, 25456,27248, + 25464,31344, 25520,27760, 25528,31856, 25584,28272, 25592,32368, + 25656,28848, 25720,29360, 25784,29872, 25840,26288, 25848,30384, + 25904,26800, 25912,30896, 25968,27312, 25976,31408, 26032,27824, + 26040,31920, 26096,28336, 26104,32432, 26168,28912, 26232,29424, + 26296,29936, 26360,30448, 26416,26864, 26424,30960, 26480,27376, + 26488,31472, 26544,27888, 26552,31984, 26608,28400, 26616,32496, + 26680,28976, 26744,29488, 26808,30000, 26872,30512, 26936,31024, + 26992,27440, 27000,31536, 27056,27952, 27064,32048, 27120,28464, + 27128,32560, 27192,29040, 27256,29552, 27320,30064, 27384,30576, + 27448,31088, 27512,31600, 27568,28016, 27576,32112, 27632,28528, + 27640,32624, 27704,29104, 27768,29616, 27832,30128, 27896,30640, + 27960,31152, 28024,31664, 28088,32176, 28144,28592, 28152,32688, + 28216,29168, 28280,29680, 28344,30192, 28408,30704, 28472,31216, + 28536,31728, 28600,32240, 28664,32752, 28792,29240, 28856,29752, + 28920,30264, 28984,30776, 29048,31288, 29112,31800, 29176,32312, + 29368,29816, 29432,30328, 29496,30840, 29560,31352, 29624,31864, + 29688,32376, 29944,30392, 30008,30904, 30072,31416, 30136,31928, + 30200,32440, 30520,30968, 30584,31480, 30648,31992, 30712,32504, + 31096,31544, 31160,32056, 31224,32568, 31672,32120, 31736,32632, + 32248,32696 +}; + + +const uint16_t armBitRevIndexTable_fixed_16[ARMBITREVINDEXTABLE_FIXED_16_TABLE_LENGTH] = +{ + /* radix 4, size 12 */ + 8,64, 16,32, 24,96, 40,80, 56,112, 88,104 +}; + +const uint16_t armBitRevIndexTable_fixed_32[ARMBITREVINDEXTABLE_FIXED_32_TABLE_LENGTH] = +{ + /* 4x2, size 24 */ + 8,128, 16,64, 24,192, 40,160, 48,96, 56,224, 72,144, + 88,208, 104,176, 120,240, 152,200, 184,232 +}; + +const uint16_t armBitRevIndexTable_fixed_64[ARMBITREVINDEXTABLE_FIXED_64_TABLE_LENGTH] = +{ + /* radix 4, size 56 */ + 8,256, 16,128, 24,384, 32,64, 40,320, 48,192, 56,448, 72,288, 80,160, 88,416, 104,352, + 112,224, 120,480, 136,272, 152,400, 168,336, 176,208, 184,464, 200,304, 216,432, + 232,368, 248,496, 280,392, 296,328, 312,456, 344,424, 376,488, 440,472 +}; + +const uint16_t armBitRevIndexTable_fixed_128[ARMBITREVINDEXTABLE_FIXED_128_TABLE_LENGTH] = +{ + /* 4x2, size 112 */ + 8,512, 16,256, 24,768, 32,128, 40,640, 48,384, 56,896, 72,576, 80,320, 88,832, 96,192, + 104,704, 112,448, 120,960, 136,544, 144,288, 152,800, 168,672, 176,416, 184,928, 200,608, + 208,352, 216,864, 232,736, 240,480, 248,992, 264,528, 280,784, 296,656, 304,400, 312,912, + 328,592, 344,848, 360,720, 368,464, 376,976, 392,560, 408,816, 424,688, 440,944, 456,624, + 472,880, 488,752, 504,1008, 536,776, 552,648, 568,904, 600,840, 616,712, 632,968, + 664,808, 696,936, 728,872, 760,1000, 824,920, 888,984 +}; + +const uint16_t armBitRevIndexTable_fixed_256[ARMBITREVINDEXTABLE_FIXED_256_TABLE_LENGTH] = +{ + /* radix 4, size 240 */ + 8,1024, 16,512, 24,1536, 32,256, 40,1280, 48,768, 56,1792, 64,128, 72,1152, 80,640, + 88,1664, 96,384, 104,1408, 112,896, 120,1920, 136,1088, 144,576, 152,1600, 160,320, + 168,1344, 176,832, 184,1856, 200,1216, 208,704, 216,1728, 224,448, 232,1472, 240,960, + 248,1984, 264,1056, 272,544, 280,1568, 296,1312, 304,800, 312,1824, 328,1184, 336,672, + 344,1696, 352,416, 360,1440, 368,928, 376,1952, 392,1120, 400,608, 408,1632, 424,1376, + 432,864, 440,1888, 456,1248, 464,736, 472,1760, 488,1504, 496,992, 504,2016, 520,1040, + 536,1552, 552,1296, 560,784, 568,1808, 584,1168, 592,656, 600,1680, 616,1424, 624,912, + 632,1936, 648,1104, 664,1616, 680,1360, 688,848, 696,1872, 712,1232, 728,1744, 744,1488, + 752,976, 760,2000, 776,1072, 792,1584, 808,1328, 824,1840, 840,1200, 856,1712, 872,1456, + 880,944, 888,1968, 904,1136, 920,1648, 936,1392, 952,1904, 968,1264, 984,1776, 1000,1520, + 1016,2032, 1048,1544, 1064,1288, 1080,1800, 1096,1160, 1112,1672, 1128,1416, 1144,1928, + 1176,1608, 1192,1352, 1208,1864, 1240,1736, 1256,1480, 1272,1992, 1304,1576, 1336,1832, + 1368,1704, 1384,1448, 1400,1960, 1432,1640, 1464,1896, 1496,1768, 1528,2024, 1592,1816, + 1624,1688, 1656,1944, 1720,1880, 1784,2008, 1912,1976 +}; + +const uint16_t armBitRevIndexTable_fixed_512[ARMBITREVINDEXTABLE_FIXED_512_TABLE_LENGTH] = +{ + /* 4x2, size 480 */ + 8,2048, 16,1024, 24,3072, 32,512, 40,2560, 48,1536, 56,3584, 64,256, 72,2304, 80,1280, + 88,3328, 96,768, 104,2816, 112,1792, 120,3840, 136,2176, 144,1152, 152,3200, 160,640, + 168,2688, 176,1664, 184,3712, 192,384, 200,2432, 208,1408, 216,3456, 224,896, 232,2944, + 240,1920, 248,3968, 264,2112, 272,1088, 280,3136, 288,576, 296,2624, 304,1600, 312,3648, + 328,2368, 336,1344, 344,3392, 352,832, 360,2880, 368,1856, 376,3904, 392,2240, 400,1216, + 408,3264, 416,704, 424,2752, 432,1728, 440,3776, 456,2496, 464,1472, 472,3520, 480,960, + 488,3008, 496,1984, 504,4032, 520,2080, 528,1056, 536,3104, 552,2592, 560,1568, 568,3616, + 584,2336, 592,1312, 600,3360, 608,800, 616,2848, 624,1824, 632,3872, 648,2208, 656,1184, + 664,3232, 680,2720, 688,1696, 696,3744, 712,2464, 720,1440, 728,3488, 736,928, 744,2976, + 752,1952, 760,4000, 776,2144, 784,1120, 792,3168, 808,2656, 816,1632, 824,3680, 840,2400, + 848,1376, 856,3424, 872,2912, 880,1888, 888,3936, 904,2272, 912,1248, 920,3296, 936,2784, + 944,1760, 952,3808, 968,2528, 976,1504, 984,3552, 1000,3040, 1008,2016, 1016,4064, + 1032,2064, 1048,3088, 1064,2576, 1072,1552, 1080,3600, 1096,2320, 1104,1296, 1112,3344, + 1128,2832, 1136,1808, 1144,3856, 1160,2192, 1176,3216, 1192,2704, 1200,1680, 1208,3728, + 1224,2448, 1232,1424, 1240,3472, 1256,2960, 1264,1936, 1272,3984, 1288,2128, 1304,3152, + 1320,2640, 1328,1616, 1336,3664, 1352,2384, 1368,3408, 1384,2896, 1392,1872, 1400,3920, + 1416,2256, 1432,3280, 1448,2768, 1456,1744, 1464,3792, 1480,2512, 1496,3536, 1512,3024, + 1520,2000, 1528,4048, 1544,2096, 1560,3120, 1576,2608, 1592,3632, 1608,2352, 1624,3376, + 1640,2864, 1648,1840, 1656,3888, 1672,2224, 1688,3248, 1704,2736, 1720,3760, 1736,2480, + 1752,3504, 1768,2992, 1776,1968, 1784,4016, 1800,2160, 1816,3184, 1832,2672, 1848,3696, + 1864,2416, 1880,3440, 1896,2928, 1912,3952, 1928,2288, 1944,3312, 1960,2800, 1976,3824, + 1992,2544, 2008,3568, 2024,3056, 2040,4080, 2072,3080, 2088,2568, 2104,3592, 2120,2312, + 2136,3336, 2152,2824, 2168,3848, 2200,3208, 2216,2696, 2232,3720, 2248,2440, 2264,3464, + 2280,2952, 2296,3976, 2328,3144, 2344,2632, 2360,3656, 2392,3400, 2408,2888, 2424,3912, + 2456,3272, 2472,2760, 2488,3784, 2520,3528, 2536,3016, 2552,4040, 2584,3112, 2616,3624, + 2648,3368, 2664,2856, 2680,3880, 2712,3240, 2744,3752, 2776,3496, 2792,2984, 2808,4008, + 2840,3176, 2872,3688, 2904,3432, 2936,3944, 2968,3304, 3000,3816, 3032,3560, 3064,4072, + 3128,3608, 3160,3352, 3192,3864, 3256,3736, 3288,3480, 3320,3992, 3384,3672, 3448,3928, + 3512,3800, 3576,4056, 3704,3896, 3832,4024 +}; + +const uint16_t armBitRevIndexTable_fixed_1024[ARMBITREVINDEXTABLE_FIXED_1024_TABLE_LENGTH] = +{ + /* radix 4, size 992 */ + 8,4096, 16,2048, 24,6144, 32,1024, 40,5120, 48,3072, 56,7168, 64,512, 72,4608, + 80,2560, 88,6656, 96,1536, 104,5632, 112,3584, 120,7680, 128,256, 136,4352, + 144,2304, 152,6400, 160,1280, 168,5376, 176,3328, 184,7424, 192,768, 200,4864, + 208,2816, 216,6912, 224,1792, 232,5888, 240,3840, 248,7936, 264,4224, 272,2176, + 280,6272, 288,1152, 296,5248, 304,3200, 312,7296, 320,640, 328,4736, 336,2688, + 344,6784, 352,1664, 360,5760, 368,3712, 376,7808, 392,4480, 400,2432, 408,6528, + 416,1408, 424,5504, 432,3456, 440,7552, 448,896, 456,4992, 464,2944, 472,7040, + 480,1920, 488,6016, 496,3968, 504,8064, 520,4160, 528,2112, 536,6208, 544,1088, + 552,5184, 560,3136, 568,7232, 584,4672, 592,2624, 600,6720, 608,1600, 616,5696, + 624,3648, 632,7744, 648,4416, 656,2368, 664,6464, 672,1344, 680,5440, 688,3392, + 696,7488, 704,832, 712,4928, 720,2880, 728,6976, 736,1856, 744,5952, 752,3904, + 760,8000, 776,4288, 784,2240, 792,6336, 800,1216, 808,5312, 816,3264, 824,7360, + 840,4800, 848,2752, 856,6848, 864,1728, 872,5824, 880,3776, 888,7872, 904,4544, + 912,2496, 920,6592, 928,1472, 936,5568, 944,3520, 952,7616, 968,5056, 976,3008, + 984,7104, 992,1984, 1000,6080, 1008,4032, 1016,8128, 1032,4128, 1040,2080, + 1048,6176, 1064,5152, 1072,3104, 1080,7200, 1096,4640, 1104,2592, 1112,6688, + 1120,1568, 1128,5664, 1136,3616, 1144,7712, 1160,4384, 1168,2336, 1176,6432, + 1184,1312, 1192,5408, 1200,3360, 1208,7456, 1224,4896, 1232,2848, 1240,6944, + 1248,1824, 1256,5920, 1264,3872, 1272,7968, 1288,4256, 1296,2208, 1304,6304, + 1320,5280, 1328,3232, 1336,7328, 1352,4768, 1360,2720, 1368,6816, 1376,1696, + 1384,5792, 1392,3744, 1400,7840, 1416,4512, 1424,2464, 1432,6560, 1448,5536, + 1456,3488, 1464,7584, 1480,5024, 1488,2976, 1496,7072, 1504,1952, 1512,6048, + 1520,4000, 1528,8096, 1544,4192, 1552,2144, 1560,6240, 1576,5216, 1584,3168, + 1592,7264, 1608,4704, 1616,2656, 1624,6752, 1640,5728, 1648,3680, 1656,7776, + 1672,4448, 1680,2400, 1688,6496, 1704,5472, 1712,3424, 1720,7520, 1736,4960, + 1744,2912, 1752,7008, 1760,1888, 1768,5984, 1776,3936, 1784,8032, 1800,4320, + 1808,2272, 1816,6368, 1832,5344, 1840,3296, 1848,7392, 1864,4832, 1872,2784, + 1880,6880, 1896,5856, 1904,3808, 1912,7904, 1928,4576, 1936,2528, 1944,6624, + 1960,5600, 1968,3552, 1976,7648, 1992,5088, 2000,3040, 2008,7136, 2024,6112, + 2032,4064, 2040,8160, 2056,4112, 2072,6160, 2088,5136, 2096,3088, 2104,7184, + 2120,4624, 2128,2576, 2136,6672, 2152,5648, 2160,3600, 2168,7696, 2184,4368, + 2192,2320, 2200,6416, 2216,5392, 2224,3344, 2232,7440, 2248,4880, 2256,2832, + 2264,6928, 2280,5904, 2288,3856, 2296,7952, 2312,4240, 2328,6288, 2344,5264, + 2352,3216, 2360,7312, 2376,4752, 2384,2704, 2392,6800, 2408,5776, 2416,3728, + 2424,7824, 2440,4496, 2456,6544, 2472,5520, 2480,3472, 2488,7568, 2504,5008, + 2512,2960, 2520,7056, 2536,6032, 2544,3984, 2552,8080, 2568,4176, 2584,6224, + 2600,5200, 2608,3152, 2616,7248, 2632,4688, 2648,6736, 2664,5712, 2672,3664, + 2680,7760, 2696,4432, 2712,6480, 2728,5456, 2736,3408, 2744,7504, 2760,4944, + 2768,2896, 2776,6992, 2792,5968, 2800,3920, 2808,8016, 2824,4304, 2840,6352, + 2856,5328, 2864,3280, 2872,7376, 2888,4816, 2904,6864, 2920,5840, 2928,3792, + 2936,7888, 2952,4560, 2968,6608, 2984,5584, 2992,3536, 3000,7632, 3016,5072, + 3032,7120, 3048,6096, 3056,4048, 3064,8144, 3080,4144, 3096,6192, 3112,5168, + 3128,7216, 3144,4656, 3160,6704, 3176,5680, 3184,3632, 3192,7728, 3208,4400, + 3224,6448, 3240,5424, 3248,3376, 3256,7472, 3272,4912, 3288,6960, 3304,5936, + 3312,3888, 3320,7984, 3336,4272, 3352,6320, 3368,5296, 3384,7344, 3400,4784, + 3416,6832, 3432,5808, 3440,3760, 3448,7856, 3464,4528, 3480,6576, 3496,5552, + 3512,7600, 3528,5040, 3544,7088, 3560,6064, 3568,4016, 3576,8112, 3592,4208, + 3608,6256, 3624,5232, 3640,7280, 3656,4720, 3672,6768, 3688,5744, 3704,7792, + 3720,4464, 3736,6512, 3752,5488, 3768,7536, 3784,4976, 3800,7024, 3816,6000, + 3824,3952, 3832,8048, 3848,4336, 3864,6384, 3880,5360, 3896,7408, 3912,4848, + 3928,6896, 3944,5872, 3960,7920, 3976,4592, 3992,6640, 4008,5616, 4024,7664, + 4040,5104, 4056,7152, 4072,6128, 4088,8176, 4120,6152, 4136,5128, 4152,7176, + 4168,4616, 4184,6664, 4200,5640, 4216,7688, 4232,4360, 4248,6408, 4264,5384, + 4280,7432, 4296,4872, 4312,6920, 4328,5896, 4344,7944, 4376,6280, 4392,5256, + 4408,7304, 4424,4744, 4440,6792, 4456,5768, 4472,7816, 4504,6536, 4520,5512, + 4536,7560, 4552,5000, 4568,7048, 4584,6024, 4600,8072, 4632,6216, 4648,5192, + 4664,7240, 4696,6728, 4712,5704, 4728,7752, 4760,6472, 4776,5448, 4792,7496, + 4808,4936, 4824,6984, 4840,5960, 4856,8008, 4888,6344, 4904,5320, 4920,7368, + 4952,6856, 4968,5832, 4984,7880, 5016,6600, 5032,5576, 5048,7624, 5080,7112, + 5096,6088, 5112,8136, 5144,6184, 5176,7208, 5208,6696, 5224,5672, 5240,7720, + 5272,6440, 5288,5416, 5304,7464, 5336,6952, 5352,5928, 5368,7976, 5400,6312, + 5432,7336, 5464,6824, 5480,5800, 5496,7848, 5528,6568, 5560,7592, 5592,7080, + 5608,6056, 5624,8104, 5656,6248, 5688,7272, 5720,6760, 5752,7784, 5784,6504, + 5816,7528, 5848,7016, 5864,5992, 5880,8040, 5912,6376, 5944,7400, 5976,6888, + 6008,7912, 6040,6632, 6072,7656, 6104,7144, 6136,8168, 6200,7192, 6232,6680, + 6264,7704, 6296,6424, 6328,7448, 6360,6936, 6392,7960, 6456,7320, 6488,6808, + 6520,7832, 6584,7576, 6616,7064, 6648,8088, 6712,7256, 6776,7768, 6840,7512, + 6872,7000, 6904,8024, 6968,7384, 7032,7896, 7096,7640, 7160,8152, 7288,7736, + 7352,7480, 7416,7992, 7544,7864, 7672,8120, 7928,8056 +}; + +const uint16_t armBitRevIndexTable_fixed_2048[ARMBITREVINDEXTABLE_FIXED_2048_TABLE_LENGTH] = +{ + /* 4x2, size 1984 */ + 8,8192, 16,4096, 24,12288, 32,2048, 40,10240, 48,6144, 56,14336, 64,1024, + 72,9216, 80,5120, 88,13312, 96,3072, 104,11264, 112,7168, 120,15360, 128,512, + 136,8704, 144,4608, 152,12800, 160,2560, 168,10752, 176,6656, 184,14848, + 192,1536, 200,9728, 208,5632, 216,13824, 224,3584, 232,11776, 240,7680, + 248,15872, 264,8448, 272,4352, 280,12544, 288,2304, 296,10496, 304,6400, + 312,14592, 320,1280, 328,9472, 336,5376, 344,13568, 352,3328, 360,11520, + 368,7424, 376,15616, 384,768, 392,8960, 400,4864, 408,13056, 416,2816, + 424,11008, 432,6912, 440,15104, 448,1792, 456,9984, 464,5888, 472,14080, + 480,3840, 488,12032, 496,7936, 504,16128, 520,8320, 528,4224, 536,12416, + 544,2176, 552,10368, 560,6272, 568,14464, 576,1152, 584,9344, 592,5248, + 600,13440, 608,3200, 616,11392, 624,7296, 632,15488, 648,8832, 656,4736, + 664,12928, 672,2688, 680,10880, 688,6784, 696,14976, 704,1664, 712,9856, + 720,5760, 728,13952, 736,3712, 744,11904, 752,7808, 760,16000, 776,8576, + 784,4480, 792,12672, 800,2432, 808,10624, 816,6528, 824,14720, 832,1408, + 840,9600, 848,5504, 856,13696, 864,3456, 872,11648, 880,7552, 888,15744, + 904,9088, 912,4992, 920,13184, 928,2944, 936,11136, 944,7040, 952,15232, + 960,1920, 968,10112, 976,6016, 984,14208, 992,3968, 1000,12160, 1008,8064, + 1016,16256, 1032,8256, 1040,4160, 1048,12352, 1056,2112, 1064,10304, 1072,6208, + 1080,14400, 1096,9280, 1104,5184, 1112,13376, 1120,3136, 1128,11328, 1136,7232, + 1144,15424, 1160,8768, 1168,4672, 1176,12864, 1184,2624, 1192,10816, 1200,6720, + 1208,14912, 1216,1600, 1224,9792, 1232,5696, 1240,13888, 1248,3648, 1256,11840, + 1264,7744, 1272,15936, 1288,8512, 1296,4416, 1304,12608, 1312,2368, 1320,10560, + 1328,6464, 1336,14656, 1352,9536, 1360,5440, 1368,13632, 1376,3392, 1384,11584, + 1392,7488, 1400,15680, 1416,9024, 1424,4928, 1432,13120, 1440,2880, 1448,11072, + 1456,6976, 1464,15168, 1472,1856, 1480,10048, 1488,5952, 1496,14144, 1504,3904, + 1512,12096, 1520,8000, 1528,16192, 1544,8384, 1552,4288, 1560,12480, 1568,2240, + 1576,10432, 1584,6336, 1592,14528, 1608,9408, 1616,5312, 1624,13504, 1632,3264, + 1640,11456, 1648,7360, 1656,15552, 1672,8896, 1680,4800, 1688,12992, 1696,2752, + 1704,10944, 1712,6848, 1720,15040, 1736,9920, 1744,5824, 1752,14016, 1760,3776, + 1768,11968, 1776,7872, 1784,16064, 1800,8640, 1808,4544, 1816,12736, 1824,2496, + 1832,10688, 1840,6592, 1848,14784, 1864,9664, 1872,5568, 1880,13760, 1888,3520, + 1896,11712, 1904,7616, 1912,15808, 1928,9152, 1936,5056, 1944,13248, 1952,3008, + 1960,11200, 1968,7104, 1976,15296, 1992,10176, 2000,6080, 2008,14272, 2016,4032, + 2024,12224, 2032,8128, 2040,16320, 2056,8224, 2064,4128, 2072,12320, 2088,10272, + 2096,6176, 2104,14368, 2120,9248, 2128,5152, 2136,13344, 2144,3104, 2152,11296, + 2160,7200, 2168,15392, 2184,8736, 2192,4640, 2200,12832, 2208,2592, 2216,10784, + 2224,6688, 2232,14880, 2248,9760, 2256,5664, 2264,13856, 2272,3616, 2280,11808, + 2288,7712, 2296,15904, 2312,8480, 2320,4384, 2328,12576, 2344,10528, 2352,6432, + 2360,14624, 2376,9504, 2384,5408, 2392,13600, 2400,3360, 2408,11552, 2416,7456, + 2424,15648, 2440,8992, 2448,4896, 2456,13088, 2464,2848, 2472,11040, 2480,6944, + 2488,15136, 2504,10016, 2512,5920, 2520,14112, 2528,3872, 2536,12064, 2544,7968, + 2552,16160, 2568,8352, 2576,4256, 2584,12448, 2600,10400, 2608,6304, 2616,14496, + 2632,9376, 2640,5280, 2648,13472, 2656,3232, 2664,11424, 2672,7328, 2680,15520, + 2696,8864, 2704,4768, 2712,12960, 2728,10912, 2736,6816, 2744,15008, 2760,9888, + 2768,5792, 2776,13984, 2784,3744, 2792,11936, 2800,7840, 2808,16032, 2824,8608, + 2832,4512, 2840,12704, 2856,10656, 2864,6560, 2872,14752, 2888,9632, 2896,5536, + 2904,13728, 2912,3488, 2920,11680, 2928,7584, 2936,15776, 2952,9120, 2960,5024, + 2968,13216, 2984,11168, 2992,7072, 3000,15264, 3016,10144, 3024,6048, + 3032,14240, 3040,4000, 3048,12192, 3056,8096, 3064,16288, 3080,8288, 3088,4192, + 3096,12384, 3112,10336, 3120,6240, 3128,14432, 3144,9312, 3152,5216, 3160,13408, + 3176,11360, 3184,7264, 3192,15456, 3208,8800, 3216,4704, 3224,12896, 3240,10848, + 3248,6752, 3256,14944, 3272,9824, 3280,5728, 3288,13920, 3296,3680, 3304,11872, + 3312,7776, 3320,15968, 3336,8544, 3344,4448, 3352,12640, 3368,10592, 3376,6496, + 3384,14688, 3400,9568, 3408,5472, 3416,13664, 3432,11616, 3440,7520, 3448,15712, + 3464,9056, 3472,4960, 3480,13152, 3496,11104, 3504,7008, 3512,15200, 3528,10080, + 3536,5984, 3544,14176, 3552,3936, 3560,12128, 3568,8032, 3576,16224, 3592,8416, + 3600,4320, 3608,12512, 3624,10464, 3632,6368, 3640,14560, 3656,9440, 3664,5344, + 3672,13536, 3688,11488, 3696,7392, 3704,15584, 3720,8928, 3728,4832, 3736,13024, + 3752,10976, 3760,6880, 3768,15072, 3784,9952, 3792,5856, 3800,14048, 3816,12000, + 3824,7904, 3832,16096, 3848,8672, 3856,4576, 3864,12768, 3880,10720, 3888,6624, + 3896,14816, 3912,9696, 3920,5600, 3928,13792, 3944,11744, 3952,7648, 3960,15840, + 3976,9184, 3984,5088, 3992,13280, 4008,11232, 4016,7136, 4024,15328, 4040,10208, + 4048,6112, 4056,14304, 4072,12256, 4080,8160, 4088,16352, 4104,8208, 4120,12304, + 4136,10256, 4144,6160, 4152,14352, 4168,9232, 4176,5136, 4184,13328, 4200,11280, + 4208,7184, 4216,15376, 4232,8720, 4240,4624, 4248,12816, 4264,10768, 4272,6672, + 4280,14864, 4296,9744, 4304,5648, 4312,13840, 4328,11792, 4336,7696, 4344,15888, + 4360,8464, 4376,12560, 4392,10512, 4400,6416, 4408,14608, 4424,9488, 4432,5392, + 4440,13584, 4456,11536, 4464,7440, 4472,15632, 4488,8976, 4496,4880, 4504,13072, + 4520,11024, 4528,6928, 4536,15120, 4552,10000, 4560,5904, 4568,14096, + 4584,12048, 4592,7952, 4600,16144, 4616,8336, 4632,12432, 4648,10384, 4656,6288, + 4664,14480, 4680,9360, 4688,5264, 4696,13456, 4712,11408, 4720,7312, 4728,15504, + 4744,8848, 4760,12944, 4776,10896, 4784,6800, 4792,14992, 4808,9872, 4816,5776, + 4824,13968, 4840,11920, 4848,7824, 4856,16016, 4872,8592, 4888,12688, + 4904,10640, 4912,6544, 4920,14736, 4936,9616, 4944,5520, 4952,13712, 4968,11664, + 4976,7568, 4984,15760, 5000,9104, 5016,13200, 5032,11152, 5040,7056, 5048,15248, + 5064,10128, 5072,6032, 5080,14224, 5096,12176, 5104,8080, 5112,16272, 5128,8272, + 5144,12368, 5160,10320, 5168,6224, 5176,14416, 5192,9296, 5208,13392, + 5224,11344, 5232,7248, 5240,15440, 5256,8784, 5272,12880, 5288,10832, 5296,6736, + 5304,14928, 5320,9808, 5328,5712, 5336,13904, 5352,11856, 5360,7760, 5368,15952, + 5384,8528, 5400,12624, 5416,10576, 5424,6480, 5432,14672, 5448,9552, 5464,13648, + 5480,11600, 5488,7504, 5496,15696, 5512,9040, 5528,13136, 5544,11088, 5552,6992, + 5560,15184, 5576,10064, 5584,5968, 5592,14160, 5608,12112, 5616,8016, + 5624,16208, 5640,8400, 5656,12496, 5672,10448, 5680,6352, 5688,14544, 5704,9424, + 5720,13520, 5736,11472, 5744,7376, 5752,15568, 5768,8912, 5784,13008, + 5800,10960, 5808,6864, 5816,15056, 5832,9936, 5848,14032, 5864,11984, 5872,7888, + 5880,16080, 5896,8656, 5912,12752, 5928,10704, 5936,6608, 5944,14800, 5960,9680, + 5976,13776, 5992,11728, 6000,7632, 6008,15824, 6024,9168, 6040,13264, + 6056,11216, 6064,7120, 6072,15312, 6088,10192, 6104,14288, 6120,12240, + 6128,8144, 6136,16336, 6152,8240, 6168,12336, 6184,10288, 6200,14384, 6216,9264, + 6232,13360, 6248,11312, 6256,7216, 6264,15408, 6280,8752, 6296,12848, + 6312,10800, 6320,6704, 6328,14896, 6344,9776, 6360,13872, 6376,11824, 6384,7728, + 6392,15920, 6408,8496, 6424,12592, 6440,10544, 6456,14640, 6472,9520, + 6488,13616, 6504,11568, 6512,7472, 6520,15664, 6536,9008, 6552,13104, + 6568,11056, 6576,6960, 6584,15152, 6600,10032, 6616,14128, 6632,12080, + 6640,7984, 6648,16176, 6664,8368, 6680,12464, 6696,10416, 6712,14512, 6728,9392, + 6744,13488, 6760,11440, 6768,7344, 6776,15536, 6792,8880, 6808,12976, + 6824,10928, 6840,15024, 6856,9904, 6872,14000, 6888,11952, 6896,7856, + 6904,16048, 6920,8624, 6936,12720, 6952,10672, 6968,14768, 6984,9648, + 7000,13744, 7016,11696, 7024,7600, 7032,15792, 7048,9136, 7064,13232, + 7080,11184, 7096,15280, 7112,10160, 7128,14256, 7144,12208, 7152,8112, + 7160,16304, 7176,8304, 7192,12400, 7208,10352, 7224,14448, 7240,9328, + 7256,13424, 7272,11376, 7288,15472, 7304,8816, 7320,12912, 7336,10864, + 7352,14960, 7368,9840, 7384,13936, 7400,11888, 7408,7792, 7416,15984, 7432,8560, + 7448,12656, 7464,10608, 7480,14704, 7496,9584, 7512,13680, 7528,11632, + 7544,15728, 7560,9072, 7576,13168, 7592,11120, 7608,15216, 7624,10096, + 7640,14192, 7656,12144, 7664,8048, 7672,16240, 7688,8432, 7704,12528, + 7720,10480, 7736,14576, 7752,9456, 7768,13552, 7784,11504, 7800,15600, + 7816,8944, 7832,13040, 7848,10992, 7864,15088, 7880,9968, 7896,14064, + 7912,12016, 7928,16112, 7944,8688, 7960,12784, 7976,10736, 7992,14832, + 8008,9712, 8024,13808, 8040,11760, 8056,15856, 8072,9200, 8088,13296, + 8104,11248, 8120,15344, 8136,10224, 8152,14320, 8168,12272, 8184,16368, + 8216,12296, 8232,10248, 8248,14344, 8264,9224, 8280,13320, 8296,11272, + 8312,15368, 8328,8712, 8344,12808, 8360,10760, 8376,14856, 8392,9736, + 8408,13832, 8424,11784, 8440,15880, 8472,12552, 8488,10504, 8504,14600, + 8520,9480, 8536,13576, 8552,11528, 8568,15624, 8584,8968, 8600,13064, + 8616,11016, 8632,15112, 8648,9992, 8664,14088, 8680,12040, 8696,16136, + 8728,12424, 8744,10376, 8760,14472, 8776,9352, 8792,13448, 8808,11400, + 8824,15496, 8856,12936, 8872,10888, 8888,14984, 8904,9864, 8920,13960, + 8936,11912, 8952,16008, 8984,12680, 9000,10632, 9016,14728, 9032,9608, + 9048,13704, 9064,11656, 9080,15752, 9112,13192, 9128,11144, 9144,15240, + 9160,10120, 9176,14216, 9192,12168, 9208,16264, 9240,12360, 9256,10312, + 9272,14408, 9304,13384, 9320,11336, 9336,15432, 9368,12872, 9384,10824, + 9400,14920, 9416,9800, 9432,13896, 9448,11848, 9464,15944, 9496,12616, + 9512,10568, 9528,14664, 9560,13640, 9576,11592, 9592,15688, 9624,13128, + 9640,11080, 9656,15176, 9672,10056, 9688,14152, 9704,12104, 9720,16200, + 9752,12488, 9768,10440, 9784,14536, 9816,13512, 9832,11464, 9848,15560, + 9880,13000, 9896,10952, 9912,15048, 9944,14024, 9960,11976, 9976,16072, + 10008,12744, 10024,10696, 10040,14792, 10072,13768, 10088,11720, 10104,15816, + 10136,13256, 10152,11208, 10168,15304, 10200,14280, 10216,12232, 10232,16328, + 10264,12328, 10296,14376, 10328,13352, 10344,11304, 10360,15400, 10392,12840, + 10408,10792, 10424,14888, 10456,13864, 10472,11816, 10488,15912, 10520,12584, + 10552,14632, 10584,13608, 10600,11560, 10616,15656, 10648,13096, 10664,11048, + 10680,15144, 10712,14120, 10728,12072, 10744,16168, 10776,12456, 10808,14504, + 10840,13480, 10856,11432, 10872,15528, 10904,12968, 10936,15016, 10968,13992, + 10984,11944, 11000,16040, 11032,12712, 11064,14760, 11096,13736, 11112,11688, + 11128,15784, 11160,13224, 11192,15272, 11224,14248, 11240,12200, 11256,16296, + 11288,12392, 11320,14440, 11352,13416, 11384,15464, 11416,12904, 11448,14952, + 11480,13928, 11496,11880, 11512,15976, 11544,12648, 11576,14696, 11608,13672, + 11640,15720, 11672,13160, 11704,15208, 11736,14184, 11752,12136, 11768,16232, + 11800,12520, 11832,14568, 11864,13544, 11896,15592, 11928,13032, 11960,15080, + 11992,14056, 12024,16104, 12056,12776, 12088,14824, 12120,13800, 12152,15848, + 12184,13288, 12216,15336, 12248,14312, 12280,16360, 12344,14360, 12376,13336, + 12408,15384, 12440,12824, 12472,14872, 12504,13848, 12536,15896, 12600,14616, + 12632,13592, 12664,15640, 12696,13080, 12728,15128, 12760,14104, 12792,16152, + 12856,14488, 12888,13464, 12920,15512, 12984,15000, 13016,13976, 13048,16024, + 13112,14744, 13144,13720, 13176,15768, 13240,15256, 13272,14232, 13304,16280, + 13368,14424, 13432,15448, 13496,14936, 13528,13912, 13560,15960, 13624,14680, + 13688,15704, 13752,15192, 13784,14168, 13816,16216, 13880,14552, 13944,15576, + 14008,15064, 14072,16088, 14136,14808, 14200,15832, 14264,15320, 14328,16344, + 14456,15416, 14520,14904, 14584,15928, 14712,15672, 14776,15160, 14840,16184, + 14968,15544, 15096,16056, 15224,15800, 15352,16312, 15608,15992, 15864,16248 +}; + +const uint16_t armBitRevIndexTable_fixed_4096[ARMBITREVINDEXTABLE_FIXED_4096_TABLE_LENGTH] = +{ + /* radix 4, size 4032 */ + 8,16384, 16,8192, 24,24576, 32,4096, 40,20480, 48,12288, 56,28672, 64,2048, + 72,18432, 80,10240, 88,26624, 96,6144, 104,22528, 112,14336, 120,30720, + 128,1024, 136,17408, 144,9216, 152,25600, 160,5120, 168,21504, 176,13312, + 184,29696, 192,3072, 200,19456, 208,11264, 216,27648, 224,7168, 232,23552, + 240,15360, 248,31744, 256,512, 264,16896, 272,8704, 280,25088, 288,4608, + 296,20992, 304,12800, 312,29184, 320,2560, 328,18944, 336,10752, 344,27136, + 352,6656, 360,23040, 368,14848, 376,31232, 384,1536, 392,17920, 400,9728, + 408,26112, 416,5632, 424,22016, 432,13824, 440,30208, 448,3584, 456,19968, + 464,11776, 472,28160, 480,7680, 488,24064, 496,15872, 504,32256, 520,16640, + 528,8448, 536,24832, 544,4352, 552,20736, 560,12544, 568,28928, 576,2304, + 584,18688, 592,10496, 600,26880, 608,6400, 616,22784, 624,14592, 632,30976, + 640,1280, 648,17664, 656,9472, 664,25856, 672,5376, 680,21760, 688,13568, + 696,29952, 704,3328, 712,19712, 720,11520, 728,27904, 736,7424, 744,23808, + 752,15616, 760,32000, 776,17152, 784,8960, 792,25344, 800,4864, 808,21248, + 816,13056, 824,29440, 832,2816, 840,19200, 848,11008, 856,27392, 864,6912, + 872,23296, 880,15104, 888,31488, 896,1792, 904,18176, 912,9984, 920,26368, + 928,5888, 936,22272, 944,14080, 952,30464, 960,3840, 968,20224, 976,12032, + 984,28416, 992,7936, 1000,24320, 1008,16128, 1016,32512, 1032,16512, 1040,8320, + 1048,24704, 1056,4224, 1064,20608, 1072,12416, 1080,28800, 1088,2176, + 1096,18560, 1104,10368, 1112,26752, 1120,6272, 1128,22656, 1136,14464, + 1144,30848, 1160,17536, 1168,9344, 1176,25728, 1184,5248, 1192,21632, + 1200,13440, 1208,29824, 1216,3200, 1224,19584, 1232,11392, 1240,27776, + 1248,7296, 1256,23680, 1264,15488, 1272,31872, 1288,17024, 1296,8832, + 1304,25216, 1312,4736, 1320,21120, 1328,12928, 1336,29312, 1344,2688, + 1352,19072, 1360,10880, 1368,27264, 1376,6784, 1384,23168, 1392,14976, + 1400,31360, 1408,1664, 1416,18048, 1424,9856, 1432,26240, 1440,5760, 1448,22144, + 1456,13952, 1464,30336, 1472,3712, 1480,20096, 1488,11904, 1496,28288, + 1504,7808, 1512,24192, 1520,16000, 1528,32384, 1544,16768, 1552,8576, + 1560,24960, 1568,4480, 1576,20864, 1584,12672, 1592,29056, 1600,2432, + 1608,18816, 1616,10624, 1624,27008, 1632,6528, 1640,22912, 1648,14720, + 1656,31104, 1672,17792, 1680,9600, 1688,25984, 1696,5504, 1704,21888, + 1712,13696, 1720,30080, 1728,3456, 1736,19840, 1744,11648, 1752,28032, + 1760,7552, 1768,23936, 1776,15744, 1784,32128, 1800,17280, 1808,9088, + 1816,25472, 1824,4992, 1832,21376, 1840,13184, 1848,29568, 1856,2944, + 1864,19328, 1872,11136, 1880,27520, 1888,7040, 1896,23424, 1904,15232, + 1912,31616, 1928,18304, 1936,10112, 1944,26496, 1952,6016, 1960,22400, + 1968,14208, 1976,30592, 1984,3968, 1992,20352, 2000,12160, 2008,28544, + 2016,8064, 2024,24448, 2032,16256, 2040,32640, 2056,16448, 2064,8256, + 2072,24640, 2080,4160, 2088,20544, 2096,12352, 2104,28736, 2120,18496, + 2128,10304, 2136,26688, 2144,6208, 2152,22592, 2160,14400, 2168,30784, + 2184,17472, 2192,9280, 2200,25664, 2208,5184, 2216,21568, 2224,13376, + 2232,29760, 2240,3136, 2248,19520, 2256,11328, 2264,27712, 2272,7232, + 2280,23616, 2288,15424, 2296,31808, 2312,16960, 2320,8768, 2328,25152, + 2336,4672, 2344,21056, 2352,12864, 2360,29248, 2368,2624, 2376,19008, + 2384,10816, 2392,27200, 2400,6720, 2408,23104, 2416,14912, 2424,31296, + 2440,17984, 2448,9792, 2456,26176, 2464,5696, 2472,22080, 2480,13888, + 2488,30272, 2496,3648, 2504,20032, 2512,11840, 2520,28224, 2528,7744, + 2536,24128, 2544,15936, 2552,32320, 2568,16704, 2576,8512, 2584,24896, + 2592,4416, 2600,20800, 2608,12608, 2616,28992, 2632,18752, 2640,10560, + 2648,26944, 2656,6464, 2664,22848, 2672,14656, 2680,31040, 2696,17728, + 2704,9536, 2712,25920, 2720,5440, 2728,21824, 2736,13632, 2744,30016, 2752,3392, + 2760,19776, 2768,11584, 2776,27968, 2784,7488, 2792,23872, 2800,15680, + 2808,32064, 2824,17216, 2832,9024, 2840,25408, 2848,4928, 2856,21312, + 2864,13120, 2872,29504, 2888,19264, 2896,11072, 2904,27456, 2912,6976, + 2920,23360, 2928,15168, 2936,31552, 2952,18240, 2960,10048, 2968,26432, + 2976,5952, 2984,22336, 2992,14144, 3000,30528, 3008,3904, 3016,20288, + 3024,12096, 3032,28480, 3040,8000, 3048,24384, 3056,16192, 3064,32576, + 3080,16576, 3088,8384, 3096,24768, 3104,4288, 3112,20672, 3120,12480, + 3128,28864, 3144,18624, 3152,10432, 3160,26816, 3168,6336, 3176,22720, + 3184,14528, 3192,30912, 3208,17600, 3216,9408, 3224,25792, 3232,5312, + 3240,21696, 3248,13504, 3256,29888, 3272,19648, 3280,11456, 3288,27840, + 3296,7360, 3304,23744, 3312,15552, 3320,31936, 3336,17088, 3344,8896, + 3352,25280, 3360,4800, 3368,21184, 3376,12992, 3384,29376, 3400,19136, + 3408,10944, 3416,27328, 3424,6848, 3432,23232, 3440,15040, 3448,31424, + 3464,18112, 3472,9920, 3480,26304, 3488,5824, 3496,22208, 3504,14016, + 3512,30400, 3520,3776, 3528,20160, 3536,11968, 3544,28352, 3552,7872, + 3560,24256, 3568,16064, 3576,32448, 3592,16832, 3600,8640, 3608,25024, + 3616,4544, 3624,20928, 3632,12736, 3640,29120, 3656,18880, 3664,10688, + 3672,27072, 3680,6592, 3688,22976, 3696,14784, 3704,31168, 3720,17856, + 3728,9664, 3736,26048, 3744,5568, 3752,21952, 3760,13760, 3768,30144, + 3784,19904, 3792,11712, 3800,28096, 3808,7616, 3816,24000, 3824,15808, + 3832,32192, 3848,17344, 3856,9152, 3864,25536, 3872,5056, 3880,21440, + 3888,13248, 3896,29632, 3912,19392, 3920,11200, 3928,27584, 3936,7104, + 3944,23488, 3952,15296, 3960,31680, 3976,18368, 3984,10176, 3992,26560, + 4000,6080, 4008,22464, 4016,14272, 4024,30656, 4040,20416, 4048,12224, + 4056,28608, 4064,8128, 4072,24512, 4080,16320, 4088,32704, 4104,16416, + 4112,8224, 4120,24608, 4136,20512, 4144,12320, 4152,28704, 4168,18464, + 4176,10272, 4184,26656, 4192,6176, 4200,22560, 4208,14368, 4216,30752, + 4232,17440, 4240,9248, 4248,25632, 4256,5152, 4264,21536, 4272,13344, + 4280,29728, 4296,19488, 4304,11296, 4312,27680, 4320,7200, 4328,23584, + 4336,15392, 4344,31776, 4360,16928, 4368,8736, 4376,25120, 4384,4640, + 4392,21024, 4400,12832, 4408,29216, 4424,18976, 4432,10784, 4440,27168, + 4448,6688, 4456,23072, 4464,14880, 4472,31264, 4488,17952, 4496,9760, + 4504,26144, 4512,5664, 4520,22048, 4528,13856, 4536,30240, 4552,20000, + 4560,11808, 4568,28192, 4576,7712, 4584,24096, 4592,15904, 4600,32288, + 4616,16672, 4624,8480, 4632,24864, 4648,20768, 4656,12576, 4664,28960, + 4680,18720, 4688,10528, 4696,26912, 4704,6432, 4712,22816, 4720,14624, + 4728,31008, 4744,17696, 4752,9504, 4760,25888, 4768,5408, 4776,21792, + 4784,13600, 4792,29984, 4808,19744, 4816,11552, 4824,27936, 4832,7456, + 4840,23840, 4848,15648, 4856,32032, 4872,17184, 4880,8992, 4888,25376, + 4904,21280, 4912,13088, 4920,29472, 4936,19232, 4944,11040, 4952,27424, + 4960,6944, 4968,23328, 4976,15136, 4984,31520, 5000,18208, 5008,10016, + 5016,26400, 5024,5920, 5032,22304, 5040,14112, 5048,30496, 5064,20256, + 5072,12064, 5080,28448, 5088,7968, 5096,24352, 5104,16160, 5112,32544, + 5128,16544, 5136,8352, 5144,24736, 5160,20640, 5168,12448, 5176,28832, + 5192,18592, 5200,10400, 5208,26784, 5216,6304, 5224,22688, 5232,14496, + 5240,30880, 5256,17568, 5264,9376, 5272,25760, 5288,21664, 5296,13472, + 5304,29856, 5320,19616, 5328,11424, 5336,27808, 5344,7328, 5352,23712, + 5360,15520, 5368,31904, 5384,17056, 5392,8864, 5400,25248, 5416,21152, + 5424,12960, 5432,29344, 5448,19104, 5456,10912, 5464,27296, 5472,6816, + 5480,23200, 5488,15008, 5496,31392, 5512,18080, 5520,9888, 5528,26272, + 5536,5792, 5544,22176, 5552,13984, 5560,30368, 5576,20128, 5584,11936, + 5592,28320, 5600,7840, 5608,24224, 5616,16032, 5624,32416, 5640,16800, + 5648,8608, 5656,24992, 5672,20896, 5680,12704, 5688,29088, 5704,18848, + 5712,10656, 5720,27040, 5728,6560, 5736,22944, 5744,14752, 5752,31136, + 5768,17824, 5776,9632, 5784,26016, 5800,21920, 5808,13728, 5816,30112, + 5832,19872, 5840,11680, 5848,28064, 5856,7584, 5864,23968, 5872,15776, + 5880,32160, 5896,17312, 5904,9120, 5912,25504, 5928,21408, 5936,13216, + 5944,29600, 5960,19360, 5968,11168, 5976,27552, 5984,7072, 5992,23456, + 6000,15264, 6008,31648, 6024,18336, 6032,10144, 6040,26528, 6056,22432, + 6064,14240, 6072,30624, 6088,20384, 6096,12192, 6104,28576, 6112,8096, + 6120,24480, 6128,16288, 6136,32672, 6152,16480, 6160,8288, 6168,24672, + 6184,20576, 6192,12384, 6200,28768, 6216,18528, 6224,10336, 6232,26720, + 6248,22624, 6256,14432, 6264,30816, 6280,17504, 6288,9312, 6296,25696, + 6312,21600, 6320,13408, 6328,29792, 6344,19552, 6352,11360, 6360,27744, + 6368,7264, 6376,23648, 6384,15456, 6392,31840, 6408,16992, 6416,8800, + 6424,25184, 6440,21088, 6448,12896, 6456,29280, 6472,19040, 6480,10848, + 6488,27232, 6496,6752, 6504,23136, 6512,14944, 6520,31328, 6536,18016, + 6544,9824, 6552,26208, 6568,22112, 6576,13920, 6584,30304, 6600,20064, + 6608,11872, 6616,28256, 6624,7776, 6632,24160, 6640,15968, 6648,32352, + 6664,16736, 6672,8544, 6680,24928, 6696,20832, 6704,12640, 6712,29024, + 6728,18784, 6736,10592, 6744,26976, 6760,22880, 6768,14688, 6776,31072, + 6792,17760, 6800,9568, 6808,25952, 6824,21856, 6832,13664, 6840,30048, + 6856,19808, 6864,11616, 6872,28000, 6880,7520, 6888,23904, 6896,15712, + 6904,32096, 6920,17248, 6928,9056, 6936,25440, 6952,21344, 6960,13152, + 6968,29536, 6984,19296, 6992,11104, 7000,27488, 7016,23392, 7024,15200, + 7032,31584, 7048,18272, 7056,10080, 7064,26464, 7080,22368, 7088,14176, + 7096,30560, 7112,20320, 7120,12128, 7128,28512, 7136,8032, 7144,24416, + 7152,16224, 7160,32608, 7176,16608, 7184,8416, 7192,24800, 7208,20704, + 7216,12512, 7224,28896, 7240,18656, 7248,10464, 7256,26848, 7272,22752, + 7280,14560, 7288,30944, 7304,17632, 7312,9440, 7320,25824, 7336,21728, + 7344,13536, 7352,29920, 7368,19680, 7376,11488, 7384,27872, 7400,23776, + 7408,15584, 7416,31968, 7432,17120, 7440,8928, 7448,25312, 7464,21216, + 7472,13024, 7480,29408, 7496,19168, 7504,10976, 7512,27360, 7528,23264, + 7536,15072, 7544,31456, 7560,18144, 7568,9952, 7576,26336, 7592,22240, + 7600,14048, 7608,30432, 7624,20192, 7632,12000, 7640,28384, 7648,7904, + 7656,24288, 7664,16096, 7672,32480, 7688,16864, 7696,8672, 7704,25056, + 7720,20960, 7728,12768, 7736,29152, 7752,18912, 7760,10720, 7768,27104, + 7784,23008, 7792,14816, 7800,31200, 7816,17888, 7824,9696, 7832,26080, + 7848,21984, 7856,13792, 7864,30176, 7880,19936, 7888,11744, 7896,28128, + 7912,24032, 7920,15840, 7928,32224, 7944,17376, 7952,9184, 7960,25568, + 7976,21472, 7984,13280, 7992,29664, 8008,19424, 8016,11232, 8024,27616, + 8040,23520, 8048,15328, 8056,31712, 8072,18400, 8080,10208, 8088,26592, + 8104,22496, 8112,14304, 8120,30688, 8136,20448, 8144,12256, 8152,28640, + 8168,24544, 8176,16352, 8184,32736, 8200,16400, 8216,24592, 8232,20496, + 8240,12304, 8248,28688, 8264,18448, 8272,10256, 8280,26640, 8296,22544, + 8304,14352, 8312,30736, 8328,17424, 8336,9232, 8344,25616, 8360,21520, + 8368,13328, 8376,29712, 8392,19472, 8400,11280, 8408,27664, 8424,23568, + 8432,15376, 8440,31760, 8456,16912, 8464,8720, 8472,25104, 8488,21008, + 8496,12816, 8504,29200, 8520,18960, 8528,10768, 8536,27152, 8552,23056, + 8560,14864, 8568,31248, 8584,17936, 8592,9744, 8600,26128, 8616,22032, + 8624,13840, 8632,30224, 8648,19984, 8656,11792, 8664,28176, 8680,24080, + 8688,15888, 8696,32272, 8712,16656, 8728,24848, 8744,20752, 8752,12560, + 8760,28944, 8776,18704, 8784,10512, 8792,26896, 8808,22800, 8816,14608, + 8824,30992, 8840,17680, 8848,9488, 8856,25872, 8872,21776, 8880,13584, + 8888,29968, 8904,19728, 8912,11536, 8920,27920, 8936,23824, 8944,15632, + 8952,32016, 8968,17168, 8984,25360, 9000,21264, 9008,13072, 9016,29456, + 9032,19216, 9040,11024, 9048,27408, 9064,23312, 9072,15120, 9080,31504, + 9096,18192, 9104,10000, 9112,26384, 9128,22288, 9136,14096, 9144,30480, + 9160,20240, 9168,12048, 9176,28432, 9192,24336, 9200,16144, 9208,32528, + 9224,16528, 9240,24720, 9256,20624, 9264,12432, 9272,28816, 9288,18576, + 9296,10384, 9304,26768, 9320,22672, 9328,14480, 9336,30864, 9352,17552, + 9368,25744, 9384,21648, 9392,13456, 9400,29840, 9416,19600, 9424,11408, + 9432,27792, 9448,23696, 9456,15504, 9464,31888, 9480,17040, 9496,25232, + 9512,21136, 9520,12944, 9528,29328, 9544,19088, 9552,10896, 9560,27280, + 9576,23184, 9584,14992, 9592,31376, 9608,18064, 9616,9872, 9624,26256, + 9640,22160, 9648,13968, 9656,30352, 9672,20112, 9680,11920, 9688,28304, + 9704,24208, 9712,16016, 9720,32400, 9736,16784, 9752,24976, 9768,20880, + 9776,12688, 9784,29072, 9800,18832, 9808,10640, 9816,27024, 9832,22928, + 9840,14736, 9848,31120, 9864,17808, 9880,26000, 9896,21904, 9904,13712, + 9912,30096, 9928,19856, 9936,11664, 9944,28048, 9960,23952, 9968,15760, + 9976,32144, 9992,17296, 10008,25488, 10024,21392, 10032,13200, 10040,29584, + 10056,19344, 10064,11152, 10072,27536, 10088,23440, 10096,15248, 10104,31632, + 10120,18320, 10136,26512, 10152,22416, 10160,14224, 10168,30608, 10184,20368, + 10192,12176, 10200,28560, 10216,24464, 10224,16272, 10232,32656, 10248,16464, + 10264,24656, 10280,20560, 10288,12368, 10296,28752, 10312,18512, 10328,26704, + 10344,22608, 10352,14416, 10360,30800, 10376,17488, 10392,25680, 10408,21584, + 10416,13392, 10424,29776, 10440,19536, 10448,11344, 10456,27728, 10472,23632, + 10480,15440, 10488,31824, 10504,16976, 10520,25168, 10536,21072, 10544,12880, + 10552,29264, 10568,19024, 10576,10832, 10584,27216, 10600,23120, 10608,14928, + 10616,31312, 10632,18000, 10648,26192, 10664,22096, 10672,13904, 10680,30288, + 10696,20048, 10704,11856, 10712,28240, 10728,24144, 10736,15952, 10744,32336, + 10760,16720, 10776,24912, 10792,20816, 10800,12624, 10808,29008, 10824,18768, + 10840,26960, 10856,22864, 10864,14672, 10872,31056, 10888,17744, 10904,25936, + 10920,21840, 10928,13648, 10936,30032, 10952,19792, 10960,11600, 10968,27984, + 10984,23888, 10992,15696, 11000,32080, 11016,17232, 11032,25424, 11048,21328, + 11056,13136, 11064,29520, 11080,19280, 11096,27472, 11112,23376, 11120,15184, + 11128,31568, 11144,18256, 11160,26448, 11176,22352, 11184,14160, 11192,30544, + 11208,20304, 11216,12112, 11224,28496, 11240,24400, 11248,16208, 11256,32592, + 11272,16592, 11288,24784, 11304,20688, 11312,12496, 11320,28880, 11336,18640, + 11352,26832, 11368,22736, 11376,14544, 11384,30928, 11400,17616, 11416,25808, + 11432,21712, 11440,13520, 11448,29904, 11464,19664, 11480,27856, 11496,23760, + 11504,15568, 11512,31952, 11528,17104, 11544,25296, 11560,21200, 11568,13008, + 11576,29392, 11592,19152, 11608,27344, 11624,23248, 11632,15056, 11640,31440, + 11656,18128, 11672,26320, 11688,22224, 11696,14032, 11704,30416, 11720,20176, + 11728,11984, 11736,28368, 11752,24272, 11760,16080, 11768,32464, 11784,16848, + 11800,25040, 11816,20944, 11824,12752, 11832,29136, 11848,18896, 11864,27088, + 11880,22992, 11888,14800, 11896,31184, 11912,17872, 11928,26064, 11944,21968, + 11952,13776, 11960,30160, 11976,19920, 11992,28112, 12008,24016, 12016,15824, + 12024,32208, 12040,17360, 12056,25552, 12072,21456, 12080,13264, 12088,29648, + 12104,19408, 12120,27600, 12136,23504, 12144,15312, 12152,31696, 12168,18384, + 12184,26576, 12200,22480, 12208,14288, 12216,30672, 12232,20432, 12248,28624, + 12264,24528, 12272,16336, 12280,32720, 12296,16432, 12312,24624, 12328,20528, + 12344,28720, 12360,18480, 12376,26672, 12392,22576, 12400,14384, 12408,30768, + 12424,17456, 12440,25648, 12456,21552, 12464,13360, 12472,29744, 12488,19504, + 12504,27696, 12520,23600, 12528,15408, 12536,31792, 12552,16944, 12568,25136, + 12584,21040, 12592,12848, 12600,29232, 12616,18992, 12632,27184, 12648,23088, + 12656,14896, 12664,31280, 12680,17968, 12696,26160, 12712,22064, 12720,13872, + 12728,30256, 12744,20016, 12760,28208, 12776,24112, 12784,15920, 12792,32304, + 12808,16688, 12824,24880, 12840,20784, 12856,28976, 12872,18736, 12888,26928, + 12904,22832, 12912,14640, 12920,31024, 12936,17712, 12952,25904, 12968,21808, + 12976,13616, 12984,30000, 13000,19760, 13016,27952, 13032,23856, 13040,15664, + 13048,32048, 13064,17200, 13080,25392, 13096,21296, 13112,29488, 13128,19248, + 13144,27440, 13160,23344, 13168,15152, 13176,31536, 13192,18224, 13208,26416, + 13224,22320, 13232,14128, 13240,30512, 13256,20272, 13272,28464, 13288,24368, + 13296,16176, 13304,32560, 13320,16560, 13336,24752, 13352,20656, 13368,28848, + 13384,18608, 13400,26800, 13416,22704, 13424,14512, 13432,30896, 13448,17584, + 13464,25776, 13480,21680, 13496,29872, 13512,19632, 13528,27824, 13544,23728, + 13552,15536, 13560,31920, 13576,17072, 13592,25264, 13608,21168, 13624,29360, + 13640,19120, 13656,27312, 13672,23216, 13680,15024, 13688,31408, 13704,18096, + 13720,26288, 13736,22192, 13744,14000, 13752,30384, 13768,20144, 13784,28336, + 13800,24240, 13808,16048, 13816,32432, 13832,16816, 13848,25008, 13864,20912, + 13880,29104, 13896,18864, 13912,27056, 13928,22960, 13936,14768, 13944,31152, + 13960,17840, 13976,26032, 13992,21936, 14008,30128, 14024,19888, 14040,28080, + 14056,23984, 14064,15792, 14072,32176, 14088,17328, 14104,25520, 14120,21424, + 14136,29616, 14152,19376, 14168,27568, 14184,23472, 14192,15280, 14200,31664, + 14216,18352, 14232,26544, 14248,22448, 14264,30640, 14280,20400, 14296,28592, + 14312,24496, 14320,16304, 14328,32688, 14344,16496, 14360,24688, 14376,20592, + 14392,28784, 14408,18544, 14424,26736, 14440,22640, 14456,30832, 14472,17520, + 14488,25712, 14504,21616, 14520,29808, 14536,19568, 14552,27760, 14568,23664, + 14576,15472, 14584,31856, 14600,17008, 14616,25200, 14632,21104, 14648,29296, + 14664,19056, 14680,27248, 14696,23152, 14704,14960, 14712,31344, 14728,18032, + 14744,26224, 14760,22128, 14776,30320, 14792,20080, 14808,28272, 14824,24176, + 14832,15984, 14840,32368, 14856,16752, 14872,24944, 14888,20848, 14904,29040, + 14920,18800, 14936,26992, 14952,22896, 14968,31088, 14984,17776, 15000,25968, + 15016,21872, 15032,30064, 15048,19824, 15064,28016, 15080,23920, 15088,15728, + 15096,32112, 15112,17264, 15128,25456, 15144,21360, 15160,29552, 15176,19312, + 15192,27504, 15208,23408, 15224,31600, 15240,18288, 15256,26480, 15272,22384, + 15288,30576, 15304,20336, 15320,28528, 15336,24432, 15344,16240, 15352,32624, + 15368,16624, 15384,24816, 15400,20720, 15416,28912, 15432,18672, 15448,26864, + 15464,22768, 15480,30960, 15496,17648, 15512,25840, 15528,21744, 15544,29936, + 15560,19696, 15576,27888, 15592,23792, 15608,31984, 15624,17136, 15640,25328, + 15656,21232, 15672,29424, 15688,19184, 15704,27376, 15720,23280, 15736,31472, + 15752,18160, 15768,26352, 15784,22256, 15800,30448, 15816,20208, 15832,28400, + 15848,24304, 15856,16112, 15864,32496, 15880,16880, 15896,25072, 15912,20976, + 15928,29168, 15944,18928, 15960,27120, 15976,23024, 15992,31216, 16008,17904, + 16024,26096, 16040,22000, 16056,30192, 16072,19952, 16088,28144, 16104,24048, + 16120,32240, 16136,17392, 16152,25584, 16168,21488, 16184,29680, 16200,19440, + 16216,27632, 16232,23536, 16248,31728, 16264,18416, 16280,26608, 16296,22512, + 16312,30704, 16328,20464, 16344,28656, 16360,24560, 16376,32752, 16408,24584, + 16424,20488, 16440,28680, 16456,18440, 16472,26632, 16488,22536, 16504,30728, + 16520,17416, 16536,25608, 16552,21512, 16568,29704, 16584,19464, 16600,27656, + 16616,23560, 16632,31752, 16648,16904, 16664,25096, 16680,21000, 16696,29192, + 16712,18952, 16728,27144, 16744,23048, 16760,31240, 16776,17928, 16792,26120, + 16808,22024, 16824,30216, 16840,19976, 16856,28168, 16872,24072, 16888,32264, + 16920,24840, 16936,20744, 16952,28936, 16968,18696, 16984,26888, 17000,22792, + 17016,30984, 17032,17672, 17048,25864, 17064,21768, 17080,29960, 17096,19720, + 17112,27912, 17128,23816, 17144,32008, 17176,25352, 17192,21256, 17208,29448, + 17224,19208, 17240,27400, 17256,23304, 17272,31496, 17288,18184, 17304,26376, + 17320,22280, 17336,30472, 17352,20232, 17368,28424, 17384,24328, 17400,32520, + 17432,24712, 17448,20616, 17464,28808, 17480,18568, 17496,26760, 17512,22664, + 17528,30856, 17560,25736, 17576,21640, 17592,29832, 17608,19592, 17624,27784, + 17640,23688, 17656,31880, 17688,25224, 17704,21128, 17720,29320, 17736,19080, + 17752,27272, 17768,23176, 17784,31368, 17800,18056, 17816,26248, 17832,22152, + 17848,30344, 17864,20104, 17880,28296, 17896,24200, 17912,32392, 17944,24968, + 17960,20872, 17976,29064, 17992,18824, 18008,27016, 18024,22920, 18040,31112, + 18072,25992, 18088,21896, 18104,30088, 18120,19848, 18136,28040, 18152,23944, + 18168,32136, 18200,25480, 18216,21384, 18232,29576, 18248,19336, 18264,27528, + 18280,23432, 18296,31624, 18328,26504, 18344,22408, 18360,30600, 18376,20360, + 18392,28552, 18408,24456, 18424,32648, 18456,24648, 18472,20552, 18488,28744, + 18520,26696, 18536,22600, 18552,30792, 18584,25672, 18600,21576, 18616,29768, + 18632,19528, 18648,27720, 18664,23624, 18680,31816, 18712,25160, 18728,21064, + 18744,29256, 18760,19016, 18776,27208, 18792,23112, 18808,31304, 18840,26184, + 18856,22088, 18872,30280, 18888,20040, 18904,28232, 18920,24136, 18936,32328, + 18968,24904, 18984,20808, 19000,29000, 19032,26952, 19048,22856, 19064,31048, + 19096,25928, 19112,21832, 19128,30024, 19144,19784, 19160,27976, 19176,23880, + 19192,32072, 19224,25416, 19240,21320, 19256,29512, 19288,27464, 19304,23368, + 19320,31560, 19352,26440, 19368,22344, 19384,30536, 19400,20296, 19416,28488, + 19432,24392, 19448,32584, 19480,24776, 19496,20680, 19512,28872, 19544,26824, + 19560,22728, 19576,30920, 19608,25800, 19624,21704, 19640,29896, 19672,27848, + 19688,23752, 19704,31944, 19736,25288, 19752,21192, 19768,29384, 19800,27336, + 19816,23240, 19832,31432, 19864,26312, 19880,22216, 19896,30408, 19912,20168, + 19928,28360, 19944,24264, 19960,32456, 19992,25032, 20008,20936, 20024,29128, + 20056,27080, 20072,22984, 20088,31176, 20120,26056, 20136,21960, 20152,30152, + 20184,28104, 20200,24008, 20216,32200, 20248,25544, 20264,21448, 20280,29640, + 20312,27592, 20328,23496, 20344,31688, 20376,26568, 20392,22472, 20408,30664, + 20440,28616, 20456,24520, 20472,32712, 20504,24616, 20536,28712, 20568,26664, + 20584,22568, 20600,30760, 20632,25640, 20648,21544, 20664,29736, 20696,27688, + 20712,23592, 20728,31784, 20760,25128, 20776,21032, 20792,29224, 20824,27176, + 20840,23080, 20856,31272, 20888,26152, 20904,22056, 20920,30248, 20952,28200, + 20968,24104, 20984,32296, 21016,24872, 21048,28968, 21080,26920, 21096,22824, + 21112,31016, 21144,25896, 21160,21800, 21176,29992, 21208,27944, 21224,23848, + 21240,32040, 21272,25384, 21304,29480, 21336,27432, 21352,23336, 21368,31528, + 21400,26408, 21416,22312, 21432,30504, 21464,28456, 21480,24360, 21496,32552, + 21528,24744, 21560,28840, 21592,26792, 21608,22696, 21624,30888, 21656,25768, + 21688,29864, 21720,27816, 21736,23720, 21752,31912, 21784,25256, 21816,29352, + 21848,27304, 21864,23208, 21880,31400, 21912,26280, 21928,22184, 21944,30376, + 21976,28328, 21992,24232, 22008,32424, 22040,25000, 22072,29096, 22104,27048, + 22120,22952, 22136,31144, 22168,26024, 22200,30120, 22232,28072, 22248,23976, + 22264,32168, 22296,25512, 22328,29608, 22360,27560, 22376,23464, 22392,31656, + 22424,26536, 22456,30632, 22488,28584, 22504,24488, 22520,32680, 22552,24680, + 22584,28776, 22616,26728, 22648,30824, 22680,25704, 22712,29800, 22744,27752, + 22760,23656, 22776,31848, 22808,25192, 22840,29288, 22872,27240, 22888,23144, + 22904,31336, 22936,26216, 22968,30312, 23000,28264, 23016,24168, 23032,32360, + 23064,24936, 23096,29032, 23128,26984, 23160,31080, 23192,25960, 23224,30056, + 23256,28008, 23272,23912, 23288,32104, 23320,25448, 23352,29544, 23384,27496, + 23416,31592, 23448,26472, 23480,30568, 23512,28520, 23528,24424, 23544,32616, + 23576,24808, 23608,28904, 23640,26856, 23672,30952, 23704,25832, 23736,29928, + 23768,27880, 23800,31976, 23832,25320, 23864,29416, 23896,27368, 23928,31464, + 23960,26344, 23992,30440, 24024,28392, 24040,24296, 24056,32488, 24088,25064, + 24120,29160, 24152,27112, 24184,31208, 24216,26088, 24248,30184, 24280,28136, + 24312,32232, 24344,25576, 24376,29672, 24408,27624, 24440,31720, 24472,26600, + 24504,30696, 24536,28648, 24568,32744, 24632,28696, 24664,26648, 24696,30744, + 24728,25624, 24760,29720, 24792,27672, 24824,31768, 24856,25112, 24888,29208, + 24920,27160, 24952,31256, 24984,26136, 25016,30232, 25048,28184, 25080,32280, + 25144,28952, 25176,26904, 25208,31000, 25240,25880, 25272,29976, 25304,27928, + 25336,32024, 25400,29464, 25432,27416, 25464,31512, 25496,26392, 25528,30488, + 25560,28440, 25592,32536, 25656,28824, 25688,26776, 25720,30872, 25784,29848, + 25816,27800, 25848,31896, 25912,29336, 25944,27288, 25976,31384, 26008,26264, + 26040,30360, 26072,28312, 26104,32408, 26168,29080, 26200,27032, 26232,31128, + 26296,30104, 26328,28056, 26360,32152, 26424,29592, 26456,27544, 26488,31640, + 26552,30616, 26584,28568, 26616,32664, 26680,28760, 26744,30808, 26808,29784, + 26840,27736, 26872,31832, 26936,29272, 26968,27224, 27000,31320, 27064,30296, + 27096,28248, 27128,32344, 27192,29016, 27256,31064, 27320,30040, 27352,27992, + 27384,32088, 27448,29528, 27512,31576, 27576,30552, 27608,28504, 27640,32600, + 27704,28888, 27768,30936, 27832,29912, 27896,31960, 27960,29400, 28024,31448, + 28088,30424, 28120,28376, 28152,32472, 28216,29144, 28280,31192, 28344,30168, + 28408,32216, 28472,29656, 28536,31704, 28600,30680, 28664,32728, 28792,30776, + 28856,29752, 28920,31800, 28984,29240, 29048,31288, 29112,30264, 29176,32312, + 29304,31032, 29368,30008, 29432,32056, 29560,31544, 29624,30520, 29688,32568, + 29816,30904, 29944,31928, 30072,31416, 30136,30392, 30200,32440, 30328,31160, + 30456,32184, 30584,31672, 30712,32696, 30968,31864, 31096,31352, 31224,32376, + 31480,32120, 31736,32632, 32248,32504 +}; + +/** +* \par +* Example code for Floating-point RFFT Twiddle factors Generation: +* \par +*
TW = exp(2*pi*i*[0:L/2-1]/L - pi/2*i).' 
+* \par +* Real and Imag values are in interleaved fashion +*/ +const float32_t twiddleCoef_rfft_32[32] = { + 0.000000000f, 1.000000000f, + 0.195090322f, 0.980785280f, + 0.382683432f, 0.923879533f, + 0.555570233f, 0.831469612f, + 0.707106781f, 0.707106781f, + 0.831469612f, 0.555570233f, + 0.923879533f, 0.382683432f, + 0.980785280f, 0.195090322f, + 1.000000000f, 0.000000000f, + 0.980785280f, -0.195090322f, + 0.923879533f, -0.382683432f, + 0.831469612f, -0.555570233f, + 0.707106781f, -0.707106781f, + 0.555570233f, -0.831469612f, + 0.382683432f, -0.923879533f, + 0.195090322f, -0.980785280f +}; + +const float32_t twiddleCoef_rfft_64[64] = { + 0.000000000000000f, 1.000000000000000f, + 0.098017140329561f, 0.995184726672197f, + 0.195090322016128f, 0.980785280403230f, + 0.290284677254462f, 0.956940335732209f, + 0.382683432365090f, 0.923879532511287f, + 0.471396736825998f, 0.881921264348355f, + 0.555570233019602f, 0.831469612302545f, + 0.634393284163645f, 0.773010453362737f, + 0.707106781186547f, 0.707106781186548f, + 0.773010453362737f, 0.634393284163645f, + 0.831469612302545f, 0.555570233019602f, + 0.881921264348355f, 0.471396736825998f, + 0.923879532511287f, 0.382683432365090f, + 0.956940335732209f, 0.290284677254462f, + 0.980785280403230f, 0.195090322016128f, + 0.995184726672197f, 0.098017140329561f, + 1.000000000000000f, 0.000000000000000f, + 0.995184726672197f, -0.098017140329561f, + 0.980785280403230f, -0.195090322016128f, + 0.956940335732209f, -0.290284677254462f, + 0.923879532511287f, -0.382683432365090f, + 0.881921264348355f, -0.471396736825998f, + 0.831469612302545f, -0.555570233019602f, + 0.773010453362737f, -0.634393284163645f, + 0.707106781186548f, -0.707106781186547f, + 0.634393284163645f, -0.773010453362737f, + 0.555570233019602f, -0.831469612302545f, + 0.471396736825998f, -0.881921264348355f, + 0.382683432365090f, -0.923879532511287f, + 0.290284677254462f, -0.956940335732209f, + 0.195090322016129f, -0.980785280403230f, + 0.098017140329561f, -0.995184726672197f +}; + +const float32_t twiddleCoef_rfft_128[128] = { + 0.000000000f, 1.000000000f, + 0.049067674f, 0.998795456f, + 0.098017140f, 0.995184727f, + 0.146730474f, 0.989176510f, + 0.195090322f, 0.980785280f, + 0.242980180f, 0.970031253f, + 0.290284677f, 0.956940336f, + 0.336889853f, 0.941544065f, + 0.382683432f, 0.923879533f, + 0.427555093f, 0.903989293f, + 0.471396737f, 0.881921264f, + 0.514102744f, 0.857728610f, + 0.555570233f, 0.831469612f, + 0.595699304f, 0.803207531f, + 0.634393284f, 0.773010453f, + 0.671558955f, 0.740951125f, + 0.707106781f, 0.707106781f, + 0.740951125f, 0.671558955f, + 0.773010453f, 0.634393284f, + 0.803207531f, 0.595699304f, + 0.831469612f, 0.555570233f, + 0.857728610f, 0.514102744f, + 0.881921264f, 0.471396737f, + 0.903989293f, 0.427555093f, + 0.923879533f, 0.382683432f, + 0.941544065f, 0.336889853f, + 0.956940336f, 0.290284677f, + 0.970031253f, 0.242980180f, + 0.980785280f, 0.195090322f, + 0.989176510f, 0.146730474f, + 0.995184727f, 0.098017140f, + 0.998795456f, 0.049067674f, + 1.000000000f, 0.000000000f, + 0.998795456f, -0.049067674f, + 0.995184727f, -0.098017140f, + 0.989176510f, -0.146730474f, + 0.980785280f, -0.195090322f, + 0.970031253f, -0.242980180f, + 0.956940336f, -0.290284677f, + 0.941544065f, -0.336889853f, + 0.923879533f, -0.382683432f, + 0.903989293f, -0.427555093f, + 0.881921264f, -0.471396737f, + 0.857728610f, -0.514102744f, + 0.831469612f, -0.555570233f, + 0.803207531f, -0.595699304f, + 0.773010453f, -0.634393284f, + 0.740951125f, -0.671558955f, + 0.707106781f, -0.707106781f, + 0.671558955f, -0.740951125f, + 0.634393284f, -0.773010453f, + 0.595699304f, -0.803207531f, + 0.555570233f, -0.831469612f, + 0.514102744f, -0.857728610f, + 0.471396737f, -0.881921264f, + 0.427555093f, -0.903989293f, + 0.382683432f, -0.923879533f, + 0.336889853f, -0.941544065f, + 0.290284677f, -0.956940336f, + 0.242980180f, -0.970031253f, + 0.195090322f, -0.980785280f, + 0.146730474f, -0.989176510f, + 0.098017140f, -0.995184727f, + 0.049067674f, -0.998795456f +}; + +const float32_t twiddleCoef_rfft_256[256] = { + 0.000000000f, 1.000000000f, + 0.024541229f, 0.999698819f, + 0.049067674f, 0.998795456f, + 0.073564564f, 0.997290457f, + 0.098017140f, 0.995184727f, + 0.122410675f, 0.992479535f, + 0.146730474f, 0.989176510f, + 0.170961889f, 0.985277642f, + 0.195090322f, 0.980785280f, + 0.219101240f, 0.975702130f, + 0.242980180f, 0.970031253f, + 0.266712757f, 0.963776066f, + 0.290284677f, 0.956940336f, + 0.313681740f, 0.949528181f, + 0.336889853f, 0.941544065f, + 0.359895037f, 0.932992799f, + 0.382683432f, 0.923879533f, + 0.405241314f, 0.914209756f, + 0.427555093f, 0.903989293f, + 0.449611330f, 0.893224301f, + 0.471396737f, 0.881921264f, + 0.492898192f, 0.870086991f, + 0.514102744f, 0.857728610f, + 0.534997620f, 0.844853565f, + 0.555570233f, 0.831469612f, + 0.575808191f, 0.817584813f, + 0.595699304f, 0.803207531f, + 0.615231591f, 0.788346428f, + 0.634393284f, 0.773010453f, + 0.653172843f, 0.757208847f, + 0.671558955f, 0.740951125f, + 0.689540545f, 0.724247083f, + 0.707106781f, 0.707106781f, + 0.724247083f, 0.689540545f, + 0.740951125f, 0.671558955f, + 0.757208847f, 0.653172843f, + 0.773010453f, 0.634393284f, + 0.788346428f, 0.615231591f, + 0.803207531f, 0.595699304f, + 0.817584813f, 0.575808191f, + 0.831469612f, 0.555570233f, + 0.844853565f, 0.534997620f, + 0.857728610f, 0.514102744f, + 0.870086991f, 0.492898192f, + 0.881921264f, 0.471396737f, + 0.893224301f, 0.449611330f, + 0.903989293f, 0.427555093f, + 0.914209756f, 0.405241314f, + 0.923879533f, 0.382683432f, + 0.932992799f, 0.359895037f, + 0.941544065f, 0.336889853f, + 0.949528181f, 0.313681740f, + 0.956940336f, 0.290284677f, + 0.963776066f, 0.266712757f, + 0.970031253f, 0.242980180f, + 0.975702130f, 0.219101240f, + 0.980785280f, 0.195090322f, + 0.985277642f, 0.170961889f, + 0.989176510f, 0.146730474f, + 0.992479535f, 0.122410675f, + 0.995184727f, 0.098017140f, + 0.997290457f, 0.073564564f, + 0.998795456f, 0.049067674f, + 0.999698819f, 0.024541229f, + 1.000000000f, 0.000000000f, + 0.999698819f, -0.024541229f, + 0.998795456f, -0.049067674f, + 0.997290457f, -0.073564564f, + 0.995184727f, -0.098017140f, + 0.992479535f, -0.122410675f, + 0.989176510f, -0.146730474f, + 0.985277642f, -0.170961889f, + 0.980785280f, -0.195090322f, + 0.975702130f, -0.219101240f, + 0.970031253f, -0.242980180f, + 0.963776066f, -0.266712757f, + 0.956940336f, -0.290284677f, + 0.949528181f, -0.313681740f, + 0.941544065f, -0.336889853f, + 0.932992799f, -0.359895037f, + 0.923879533f, -0.382683432f, + 0.914209756f, -0.405241314f, + 0.903989293f, -0.427555093f, + 0.893224301f, -0.449611330f, + 0.881921264f, -0.471396737f, + 0.870086991f, -0.492898192f, + 0.857728610f, -0.514102744f, + 0.844853565f, -0.534997620f, + 0.831469612f, -0.555570233f, + 0.817584813f, -0.575808191f, + 0.803207531f, -0.595699304f, + 0.788346428f, -0.615231591f, + 0.773010453f, -0.634393284f, + 0.757208847f, -0.653172843f, + 0.740951125f, -0.671558955f, + 0.724247083f, -0.689540545f, + 0.707106781f, -0.707106781f, + 0.689540545f, -0.724247083f, + 0.671558955f, -0.740951125f, + 0.653172843f, -0.757208847f, + 0.634393284f, -0.773010453f, + 0.615231591f, -0.788346428f, + 0.595699304f, -0.803207531f, + 0.575808191f, -0.817584813f, + 0.555570233f, -0.831469612f, + 0.534997620f, -0.844853565f, + 0.514102744f, -0.857728610f, + 0.492898192f, -0.870086991f, + 0.471396737f, -0.881921264f, + 0.449611330f, -0.893224301f, + 0.427555093f, -0.903989293f, + 0.405241314f, -0.914209756f, + 0.382683432f, -0.923879533f, + 0.359895037f, -0.932992799f, + 0.336889853f, -0.941544065f, + 0.313681740f, -0.949528181f, + 0.290284677f, -0.956940336f, + 0.266712757f, -0.963776066f, + 0.242980180f, -0.970031253f, + 0.219101240f, -0.975702130f, + 0.195090322f, -0.980785280f, + 0.170961889f, -0.985277642f, + 0.146730474f, -0.989176510f, + 0.122410675f, -0.992479535f, + 0.098017140f, -0.995184727f, + 0.073564564f, -0.997290457f, + 0.049067674f, -0.998795456f, + 0.024541229f, -0.999698819f +}; + +const float32_t twiddleCoef_rfft_512[512] = { + 0.000000000f, 1.000000000f, + 0.012271538f, 0.999924702f, + 0.024541229f, 0.999698819f, + 0.036807223f, 0.999322385f, + 0.049067674f, 0.998795456f, + 0.061320736f, 0.998118113f, + 0.073564564f, 0.997290457f, + 0.085797312f, 0.996312612f, + 0.098017140f, 0.995184727f, + 0.110222207f, 0.993906970f, + 0.122410675f, 0.992479535f, + 0.134580709f, 0.990902635f, + 0.146730474f, 0.989176510f, + 0.158858143f, 0.987301418f, + 0.170961889f, 0.985277642f, + 0.183039888f, 0.983105487f, + 0.195090322f, 0.980785280f, + 0.207111376f, 0.978317371f, + 0.219101240f, 0.975702130f, + 0.231058108f, 0.972939952f, + 0.242980180f, 0.970031253f, + 0.254865660f, 0.966976471f, + 0.266712757f, 0.963776066f, + 0.278519689f, 0.960430519f, + 0.290284677f, 0.956940336f, + 0.302005949f, 0.953306040f, + 0.313681740f, 0.949528181f, + 0.325310292f, 0.945607325f, + 0.336889853f, 0.941544065f, + 0.348418680f, 0.937339012f, + 0.359895037f, 0.932992799f, + 0.371317194f, 0.928506080f, + 0.382683432f, 0.923879533f, + 0.393992040f, 0.919113852f, + 0.405241314f, 0.914209756f, + 0.416429560f, 0.909167983f, + 0.427555093f, 0.903989293f, + 0.438616239f, 0.898674466f, + 0.449611330f, 0.893224301f, + 0.460538711f, 0.887639620f, + 0.471396737f, 0.881921264f, + 0.482183772f, 0.876070094f, + 0.492898192f, 0.870086991f, + 0.503538384f, 0.863972856f, + 0.514102744f, 0.857728610f, + 0.524589683f, 0.851355193f, + 0.534997620f, 0.844853565f, + 0.545324988f, 0.838224706f, + 0.555570233f, 0.831469612f, + 0.565731811f, 0.824589303f, + 0.575808191f, 0.817584813f, + 0.585797857f, 0.810457198f, + 0.595699304f, 0.803207531f, + 0.605511041f, 0.795836905f, + 0.615231591f, 0.788346428f, + 0.624859488f, 0.780737229f, + 0.634393284f, 0.773010453f, + 0.643831543f, 0.765167266f, + 0.653172843f, 0.757208847f, + 0.662415778f, 0.749136395f, + 0.671558955f, 0.740951125f, + 0.680600998f, 0.732654272f, + 0.689540545f, 0.724247083f, + 0.698376249f, 0.715730825f, + 0.707106781f, 0.707106781f, + 0.715730825f, 0.698376249f, + 0.724247083f, 0.689540545f, + 0.732654272f, 0.680600998f, + 0.740951125f, 0.671558955f, + 0.749136395f, 0.662415778f, + 0.757208847f, 0.653172843f, + 0.765167266f, 0.643831543f, + 0.773010453f, 0.634393284f, + 0.780737229f, 0.624859488f, + 0.788346428f, 0.615231591f, + 0.795836905f, 0.605511041f, + 0.803207531f, 0.595699304f, + 0.810457198f, 0.585797857f, + 0.817584813f, 0.575808191f, + 0.824589303f, 0.565731811f, + 0.831469612f, 0.555570233f, + 0.838224706f, 0.545324988f, + 0.844853565f, 0.534997620f, + 0.851355193f, 0.524589683f, + 0.857728610f, 0.514102744f, + 0.863972856f, 0.503538384f, + 0.870086991f, 0.492898192f, + 0.876070094f, 0.482183772f, + 0.881921264f, 0.471396737f, + 0.887639620f, 0.460538711f, + 0.893224301f, 0.449611330f, + 0.898674466f, 0.438616239f, + 0.903989293f, 0.427555093f, + 0.909167983f, 0.416429560f, + 0.914209756f, 0.405241314f, + 0.919113852f, 0.393992040f, + 0.923879533f, 0.382683432f, + 0.928506080f, 0.371317194f, + 0.932992799f, 0.359895037f, + 0.937339012f, 0.348418680f, + 0.941544065f, 0.336889853f, + 0.945607325f, 0.325310292f, + 0.949528181f, 0.313681740f, + 0.953306040f, 0.302005949f, + 0.956940336f, 0.290284677f, + 0.960430519f, 0.278519689f, + 0.963776066f, 0.266712757f, + 0.966976471f, 0.254865660f, + 0.970031253f, 0.242980180f, + 0.972939952f, 0.231058108f, + 0.975702130f, 0.219101240f, + 0.978317371f, 0.207111376f, + 0.980785280f, 0.195090322f, + 0.983105487f, 0.183039888f, + 0.985277642f, 0.170961889f, + 0.987301418f, 0.158858143f, + 0.989176510f, 0.146730474f, + 0.990902635f, 0.134580709f, + 0.992479535f, 0.122410675f, + 0.993906970f, 0.110222207f, + 0.995184727f, 0.098017140f, + 0.996312612f, 0.085797312f, + 0.997290457f, 0.073564564f, + 0.998118113f, 0.061320736f, + 0.998795456f, 0.049067674f, + 0.999322385f, 0.036807223f, + 0.999698819f, 0.024541229f, + 0.999924702f, 0.012271538f, + 1.000000000f, 0.000000000f, + 0.999924702f, -0.012271538f, + 0.999698819f, -0.024541229f, + 0.999322385f, -0.036807223f, + 0.998795456f, -0.049067674f, + 0.998118113f, -0.061320736f, + 0.997290457f, -0.073564564f, + 0.996312612f, -0.085797312f, + 0.995184727f, -0.098017140f, + 0.993906970f, -0.110222207f, + 0.992479535f, -0.122410675f, + 0.990902635f, -0.134580709f, + 0.989176510f, -0.146730474f, + 0.987301418f, -0.158858143f, + 0.985277642f, -0.170961889f, + 0.983105487f, -0.183039888f, + 0.980785280f, -0.195090322f, + 0.978317371f, -0.207111376f, + 0.975702130f, -0.219101240f, + 0.972939952f, -0.231058108f, + 0.970031253f, -0.242980180f, + 0.966976471f, -0.254865660f, + 0.963776066f, -0.266712757f, + 0.960430519f, -0.278519689f, + 0.956940336f, -0.290284677f, + 0.953306040f, -0.302005949f, + 0.949528181f, -0.313681740f, + 0.945607325f, -0.325310292f, + 0.941544065f, -0.336889853f, + 0.937339012f, -0.348418680f, + 0.932992799f, -0.359895037f, + 0.928506080f, -0.371317194f, + 0.923879533f, -0.382683432f, + 0.919113852f, -0.393992040f, + 0.914209756f, -0.405241314f, + 0.909167983f, -0.416429560f, + 0.903989293f, -0.427555093f, + 0.898674466f, -0.438616239f, + 0.893224301f, -0.449611330f, + 0.887639620f, -0.460538711f, + 0.881921264f, -0.471396737f, + 0.876070094f, -0.482183772f, + 0.870086991f, -0.492898192f, + 0.863972856f, -0.503538384f, + 0.857728610f, -0.514102744f, + 0.851355193f, -0.524589683f, + 0.844853565f, -0.534997620f, + 0.838224706f, -0.545324988f, + 0.831469612f, -0.555570233f, + 0.824589303f, -0.565731811f, + 0.817584813f, -0.575808191f, + 0.810457198f, -0.585797857f, + 0.803207531f, -0.595699304f, + 0.795836905f, -0.605511041f, + 0.788346428f, -0.615231591f, + 0.780737229f, -0.624859488f, + 0.773010453f, -0.634393284f, + 0.765167266f, -0.643831543f, + 0.757208847f, -0.653172843f, + 0.749136395f, -0.662415778f, + 0.740951125f, -0.671558955f, + 0.732654272f, -0.680600998f, + 0.724247083f, -0.689540545f, + 0.715730825f, -0.698376249f, + 0.707106781f, -0.707106781f, + 0.698376249f, -0.715730825f, + 0.689540545f, -0.724247083f, + 0.680600998f, -0.732654272f, + 0.671558955f, -0.740951125f, + 0.662415778f, -0.749136395f, + 0.653172843f, -0.757208847f, + 0.643831543f, -0.765167266f, + 0.634393284f, -0.773010453f, + 0.624859488f, -0.780737229f, + 0.615231591f, -0.788346428f, + 0.605511041f, -0.795836905f, + 0.595699304f, -0.803207531f, + 0.585797857f, -0.810457198f, + 0.575808191f, -0.817584813f, + 0.565731811f, -0.824589303f, + 0.555570233f, -0.831469612f, + 0.545324988f, -0.838224706f, + 0.534997620f, -0.844853565f, + 0.524589683f, -0.851355193f, + 0.514102744f, -0.857728610f, + 0.503538384f, -0.863972856f, + 0.492898192f, -0.870086991f, + 0.482183772f, -0.876070094f, + 0.471396737f, -0.881921264f, + 0.460538711f, -0.887639620f, + 0.449611330f, -0.893224301f, + 0.438616239f, -0.898674466f, + 0.427555093f, -0.903989293f, + 0.416429560f, -0.909167983f, + 0.405241314f, -0.914209756f, + 0.393992040f, -0.919113852f, + 0.382683432f, -0.923879533f, + 0.371317194f, -0.928506080f, + 0.359895037f, -0.932992799f, + 0.348418680f, -0.937339012f, + 0.336889853f, -0.941544065f, + 0.325310292f, -0.945607325f, + 0.313681740f, -0.949528181f, + 0.302005949f, -0.953306040f, + 0.290284677f, -0.956940336f, + 0.278519689f, -0.960430519f, + 0.266712757f, -0.963776066f, + 0.254865660f, -0.966976471f, + 0.242980180f, -0.970031253f, + 0.231058108f, -0.972939952f, + 0.219101240f, -0.975702130f, + 0.207111376f, -0.978317371f, + 0.195090322f, -0.980785280f, + 0.183039888f, -0.983105487f, + 0.170961889f, -0.985277642f, + 0.158858143f, -0.987301418f, + 0.146730474f, -0.989176510f, + 0.134580709f, -0.990902635f, + 0.122410675f, -0.992479535f, + 0.110222207f, -0.993906970f, + 0.098017140f, -0.995184727f, + 0.085797312f, -0.996312612f, + 0.073564564f, -0.997290457f, + 0.061320736f, -0.998118113f, + 0.049067674f, -0.998795456f, + 0.036807223f, -0.999322385f, + 0.024541229f, -0.999698819f, + 0.012271538f, -0.999924702f +}; + +const float32_t twiddleCoef_rfft_1024[1024] = { + 0.000000000f, 1.000000000f, + 0.006135885f, 0.999981175f, + 0.012271538f, 0.999924702f, + 0.018406730f, 0.999830582f, + 0.024541229f, 0.999698819f, + 0.030674803f, 0.999529418f, + 0.036807223f, 0.999322385f, + 0.042938257f, 0.999077728f, + 0.049067674f, 0.998795456f, + 0.055195244f, 0.998475581f, + 0.061320736f, 0.998118113f, + 0.067443920f, 0.997723067f, + 0.073564564f, 0.997290457f, + 0.079682438f, 0.996820299f, + 0.085797312f, 0.996312612f, + 0.091908956f, 0.995767414f, + 0.098017140f, 0.995184727f, + 0.104121634f, 0.994564571f, + 0.110222207f, 0.993906970f, + 0.116318631f, 0.993211949f, + 0.122410675f, 0.992479535f, + 0.128498111f, 0.991709754f, + 0.134580709f, 0.990902635f, + 0.140658239f, 0.990058210f, + 0.146730474f, 0.989176510f, + 0.152797185f, 0.988257568f, + 0.158858143f, 0.987301418f, + 0.164913120f, 0.986308097f, + 0.170961889f, 0.985277642f, + 0.177004220f, 0.984210092f, + 0.183039888f, 0.983105487f, + 0.189068664f, 0.981963869f, + 0.195090322f, 0.980785280f, + 0.201104635f, 0.979569766f, + 0.207111376f, 0.978317371f, + 0.213110320f, 0.977028143f, + 0.219101240f, 0.975702130f, + 0.225083911f, 0.974339383f, + 0.231058108f, 0.972939952f, + 0.237023606f, 0.971503891f, + 0.242980180f, 0.970031253f, + 0.248927606f, 0.968522094f, + 0.254865660f, 0.966976471f, + 0.260794118f, 0.965394442f, + 0.266712757f, 0.963776066f, + 0.272621355f, 0.962121404f, + 0.278519689f, 0.960430519f, + 0.284407537f, 0.958703475f, + 0.290284677f, 0.956940336f, + 0.296150888f, 0.955141168f, + 0.302005949f, 0.953306040f, + 0.307849640f, 0.951435021f, + 0.313681740f, 0.949528181f, + 0.319502031f, 0.947585591f, + 0.325310292f, 0.945607325f, + 0.331106306f, 0.943593458f, + 0.336889853f, 0.941544065f, + 0.342660717f, 0.939459224f, + 0.348418680f, 0.937339012f, + 0.354163525f, 0.935183510f, + 0.359895037f, 0.932992799f, + 0.365612998f, 0.930766961f, + 0.371317194f, 0.928506080f, + 0.377007410f, 0.926210242f, + 0.382683432f, 0.923879533f, + 0.388345047f, 0.921514039f, + 0.393992040f, 0.919113852f, + 0.399624200f, 0.916679060f, + 0.405241314f, 0.914209756f, + 0.410843171f, 0.911706032f, + 0.416429560f, 0.909167983f, + 0.422000271f, 0.906595705f, + 0.427555093f, 0.903989293f, + 0.433093819f, 0.901348847f, + 0.438616239f, 0.898674466f, + 0.444122145f, 0.895966250f, + 0.449611330f, 0.893224301f, + 0.455083587f, 0.890448723f, + 0.460538711f, 0.887639620f, + 0.465976496f, 0.884797098f, + 0.471396737f, 0.881921264f, + 0.476799230f, 0.879012226f, + 0.482183772f, 0.876070094f, + 0.487550160f, 0.873094978f, + 0.492898192f, 0.870086991f, + 0.498227667f, 0.867046246f, + 0.503538384f, 0.863972856f, + 0.508830143f, 0.860866939f, + 0.514102744f, 0.857728610f, + 0.519355990f, 0.854557988f, + 0.524589683f, 0.851355193f, + 0.529803625f, 0.848120345f, + 0.534997620f, 0.844853565f, + 0.540171473f, 0.841554977f, + 0.545324988f, 0.838224706f, + 0.550457973f, 0.834862875f, + 0.555570233f, 0.831469612f, + 0.560661576f, 0.828045045f, + 0.565731811f, 0.824589303f, + 0.570780746f, 0.821102515f, + 0.575808191f, 0.817584813f, + 0.580813958f, 0.814036330f, + 0.585797857f, 0.810457198f, + 0.590759702f, 0.806847554f, + 0.595699304f, 0.803207531f, + 0.600616479f, 0.799537269f, + 0.605511041f, 0.795836905f, + 0.610382806f, 0.792106577f, + 0.615231591f, 0.788346428f, + 0.620057212f, 0.784556597f, + 0.624859488f, 0.780737229f, + 0.629638239f, 0.776888466f, + 0.634393284f, 0.773010453f, + 0.639124445f, 0.769103338f, + 0.643831543f, 0.765167266f, + 0.648514401f, 0.761202385f, + 0.653172843f, 0.757208847f, + 0.657806693f, 0.753186799f, + 0.662415778f, 0.749136395f, + 0.666999922f, 0.745057785f, + 0.671558955f, 0.740951125f, + 0.676092704f, 0.736816569f, + 0.680600998f, 0.732654272f, + 0.685083668f, 0.728464390f, + 0.689540545f, 0.724247083f, + 0.693971461f, 0.720002508f, + 0.698376249f, 0.715730825f, + 0.702754744f, 0.711432196f, + 0.707106781f, 0.707106781f, + 0.711432196f, 0.702754744f, + 0.715730825f, 0.698376249f, + 0.720002508f, 0.693971461f, + 0.724247083f, 0.689540545f, + 0.728464390f, 0.685083668f, + 0.732654272f, 0.680600998f, + 0.736816569f, 0.676092704f, + 0.740951125f, 0.671558955f, + 0.745057785f, 0.666999922f, + 0.749136395f, 0.662415778f, + 0.753186799f, 0.657806693f, + 0.757208847f, 0.653172843f, + 0.761202385f, 0.648514401f, + 0.765167266f, 0.643831543f, + 0.769103338f, 0.639124445f, + 0.773010453f, 0.634393284f, + 0.776888466f, 0.629638239f, + 0.780737229f, 0.624859488f, + 0.784556597f, 0.620057212f, + 0.788346428f, 0.615231591f, + 0.792106577f, 0.610382806f, + 0.795836905f, 0.605511041f, + 0.799537269f, 0.600616479f, + 0.803207531f, 0.595699304f, + 0.806847554f, 0.590759702f, + 0.810457198f, 0.585797857f, + 0.814036330f, 0.580813958f, + 0.817584813f, 0.575808191f, + 0.821102515f, 0.570780746f, + 0.824589303f, 0.565731811f, + 0.828045045f, 0.560661576f, + 0.831469612f, 0.555570233f, + 0.834862875f, 0.550457973f, + 0.838224706f, 0.545324988f, + 0.841554977f, 0.540171473f, + 0.844853565f, 0.534997620f, + 0.848120345f, 0.529803625f, + 0.851355193f, 0.524589683f, + 0.854557988f, 0.519355990f, + 0.857728610f, 0.514102744f, + 0.860866939f, 0.508830143f, + 0.863972856f, 0.503538384f, + 0.867046246f, 0.498227667f, + 0.870086991f, 0.492898192f, + 0.873094978f, 0.487550160f, + 0.876070094f, 0.482183772f, + 0.879012226f, 0.476799230f, + 0.881921264f, 0.471396737f, + 0.884797098f, 0.465976496f, + 0.887639620f, 0.460538711f, + 0.890448723f, 0.455083587f, + 0.893224301f, 0.449611330f, + 0.895966250f, 0.444122145f, + 0.898674466f, 0.438616239f, + 0.901348847f, 0.433093819f, + 0.903989293f, 0.427555093f, + 0.906595705f, 0.422000271f, + 0.909167983f, 0.416429560f, + 0.911706032f, 0.410843171f, + 0.914209756f, 0.405241314f, + 0.916679060f, 0.399624200f, + 0.919113852f, 0.393992040f, + 0.921514039f, 0.388345047f, + 0.923879533f, 0.382683432f, + 0.926210242f, 0.377007410f, + 0.928506080f, 0.371317194f, + 0.930766961f, 0.365612998f, + 0.932992799f, 0.359895037f, + 0.935183510f, 0.354163525f, + 0.937339012f, 0.348418680f, + 0.939459224f, 0.342660717f, + 0.941544065f, 0.336889853f, + 0.943593458f, 0.331106306f, + 0.945607325f, 0.325310292f, + 0.947585591f, 0.319502031f, + 0.949528181f, 0.313681740f, + 0.951435021f, 0.307849640f, + 0.953306040f, 0.302005949f, + 0.955141168f, 0.296150888f, + 0.956940336f, 0.290284677f, + 0.958703475f, 0.284407537f, + 0.960430519f, 0.278519689f, + 0.962121404f, 0.272621355f, + 0.963776066f, 0.266712757f, + 0.965394442f, 0.260794118f, + 0.966976471f, 0.254865660f, + 0.968522094f, 0.248927606f, + 0.970031253f, 0.242980180f, + 0.971503891f, 0.237023606f, + 0.972939952f, 0.231058108f, + 0.974339383f, 0.225083911f, + 0.975702130f, 0.219101240f, + 0.977028143f, 0.213110320f, + 0.978317371f, 0.207111376f, + 0.979569766f, 0.201104635f, + 0.980785280f, 0.195090322f, + 0.981963869f, 0.189068664f, + 0.983105487f, 0.183039888f, + 0.984210092f, 0.177004220f, + 0.985277642f, 0.170961889f, + 0.986308097f, 0.164913120f, + 0.987301418f, 0.158858143f, + 0.988257568f, 0.152797185f, + 0.989176510f, 0.146730474f, + 0.990058210f, 0.140658239f, + 0.990902635f, 0.134580709f, + 0.991709754f, 0.128498111f, + 0.992479535f, 0.122410675f, + 0.993211949f, 0.116318631f, + 0.993906970f, 0.110222207f, + 0.994564571f, 0.104121634f, + 0.995184727f, 0.098017140f, + 0.995767414f, 0.091908956f, + 0.996312612f, 0.085797312f, + 0.996820299f, 0.079682438f, + 0.997290457f, 0.073564564f, + 0.997723067f, 0.067443920f, + 0.998118113f, 0.061320736f, + 0.998475581f, 0.055195244f, + 0.998795456f, 0.049067674f, + 0.999077728f, 0.042938257f, + 0.999322385f, 0.036807223f, + 0.999529418f, 0.030674803f, + 0.999698819f, 0.024541229f, + 0.999830582f, 0.018406730f, + 0.999924702f, 0.012271538f, + 0.999981175f, 0.006135885f, + 1.000000000f, 0.000000000f, + 0.999981175f, -0.006135885f, + 0.999924702f, -0.012271538f, + 0.999830582f, -0.018406730f, + 0.999698819f, -0.024541229f, + 0.999529418f, -0.030674803f, + 0.999322385f, -0.036807223f, + 0.999077728f, -0.042938257f, + 0.998795456f, -0.049067674f, + 0.998475581f, -0.055195244f, + 0.998118113f, -0.061320736f, + 0.997723067f, -0.067443920f, + 0.997290457f, -0.073564564f, + 0.996820299f, -0.079682438f, + 0.996312612f, -0.085797312f, + 0.995767414f, -0.091908956f, + 0.995184727f, -0.098017140f, + 0.994564571f, -0.104121634f, + 0.993906970f, -0.110222207f, + 0.993211949f, -0.116318631f, + 0.992479535f, -0.122410675f, + 0.991709754f, -0.128498111f, + 0.990902635f, -0.134580709f, + 0.990058210f, -0.140658239f, + 0.989176510f, -0.146730474f, + 0.988257568f, -0.152797185f, + 0.987301418f, -0.158858143f, + 0.986308097f, -0.164913120f, + 0.985277642f, -0.170961889f, + 0.984210092f, -0.177004220f, + 0.983105487f, -0.183039888f, + 0.981963869f, -0.189068664f, + 0.980785280f, -0.195090322f, + 0.979569766f, -0.201104635f, + 0.978317371f, -0.207111376f, + 0.977028143f, -0.213110320f, + 0.975702130f, -0.219101240f, + 0.974339383f, -0.225083911f, + 0.972939952f, -0.231058108f, + 0.971503891f, -0.237023606f, + 0.970031253f, -0.242980180f, + 0.968522094f, -0.248927606f, + 0.966976471f, -0.254865660f, + 0.965394442f, -0.260794118f, + 0.963776066f, -0.266712757f, + 0.962121404f, -0.272621355f, + 0.960430519f, -0.278519689f, + 0.958703475f, -0.284407537f, + 0.956940336f, -0.290284677f, + 0.955141168f, -0.296150888f, + 0.953306040f, -0.302005949f, + 0.951435021f, -0.307849640f, + 0.949528181f, -0.313681740f, + 0.947585591f, -0.319502031f, + 0.945607325f, -0.325310292f, + 0.943593458f, -0.331106306f, + 0.941544065f, -0.336889853f, + 0.939459224f, -0.342660717f, + 0.937339012f, -0.348418680f, + 0.935183510f, -0.354163525f, + 0.932992799f, -0.359895037f, + 0.930766961f, -0.365612998f, + 0.928506080f, -0.371317194f, + 0.926210242f, -0.377007410f, + 0.923879533f, -0.382683432f, + 0.921514039f, -0.388345047f, + 0.919113852f, -0.393992040f, + 0.916679060f, -0.399624200f, + 0.914209756f, -0.405241314f, + 0.911706032f, -0.410843171f, + 0.909167983f, -0.416429560f, + 0.906595705f, -0.422000271f, + 0.903989293f, -0.427555093f, + 0.901348847f, -0.433093819f, + 0.898674466f, -0.438616239f, + 0.895966250f, -0.444122145f, + 0.893224301f, -0.449611330f, + 0.890448723f, -0.455083587f, + 0.887639620f, -0.460538711f, + 0.884797098f, -0.465976496f, + 0.881921264f, -0.471396737f, + 0.879012226f, -0.476799230f, + 0.876070094f, -0.482183772f, + 0.873094978f, -0.487550160f, + 0.870086991f, -0.492898192f, + 0.867046246f, -0.498227667f, + 0.863972856f, -0.503538384f, + 0.860866939f, -0.508830143f, + 0.857728610f, -0.514102744f, + 0.854557988f, -0.519355990f, + 0.851355193f, -0.524589683f, + 0.848120345f, -0.529803625f, + 0.844853565f, -0.534997620f, + 0.841554977f, -0.540171473f, + 0.838224706f, -0.545324988f, + 0.834862875f, -0.550457973f, + 0.831469612f, -0.555570233f, + 0.828045045f, -0.560661576f, + 0.824589303f, -0.565731811f, + 0.821102515f, -0.570780746f, + 0.817584813f, -0.575808191f, + 0.814036330f, -0.580813958f, + 0.810457198f, -0.585797857f, + 0.806847554f, -0.590759702f, + 0.803207531f, -0.595699304f, + 0.799537269f, -0.600616479f, + 0.795836905f, -0.605511041f, + 0.792106577f, -0.610382806f, + 0.788346428f, -0.615231591f, + 0.784556597f, -0.620057212f, + 0.780737229f, -0.624859488f, + 0.776888466f, -0.629638239f, + 0.773010453f, -0.634393284f, + 0.769103338f, -0.639124445f, + 0.765167266f, -0.643831543f, + 0.761202385f, -0.648514401f, + 0.757208847f, -0.653172843f, + 0.753186799f, -0.657806693f, + 0.749136395f, -0.662415778f, + 0.745057785f, -0.666999922f, + 0.740951125f, -0.671558955f, + 0.736816569f, -0.676092704f, + 0.732654272f, -0.680600998f, + 0.728464390f, -0.685083668f, + 0.724247083f, -0.689540545f, + 0.720002508f, -0.693971461f, + 0.715730825f, -0.698376249f, + 0.711432196f, -0.702754744f, + 0.707106781f, -0.707106781f, + 0.702754744f, -0.711432196f, + 0.698376249f, -0.715730825f, + 0.693971461f, -0.720002508f, + 0.689540545f, -0.724247083f, + 0.685083668f, -0.728464390f, + 0.680600998f, -0.732654272f, + 0.676092704f, -0.736816569f, + 0.671558955f, -0.740951125f, + 0.666999922f, -0.745057785f, + 0.662415778f, -0.749136395f, + 0.657806693f, -0.753186799f, + 0.653172843f, -0.757208847f, + 0.648514401f, -0.761202385f, + 0.643831543f, -0.765167266f, + 0.639124445f, -0.769103338f, + 0.634393284f, -0.773010453f, + 0.629638239f, -0.776888466f, + 0.624859488f, -0.780737229f, + 0.620057212f, -0.784556597f, + 0.615231591f, -0.788346428f, + 0.610382806f, -0.792106577f, + 0.605511041f, -0.795836905f, + 0.600616479f, -0.799537269f, + 0.595699304f, -0.803207531f, + 0.590759702f, -0.806847554f, + 0.585797857f, -0.810457198f, + 0.580813958f, -0.814036330f, + 0.575808191f, -0.817584813f, + 0.570780746f, -0.821102515f, + 0.565731811f, -0.824589303f, + 0.560661576f, -0.828045045f, + 0.555570233f, -0.831469612f, + 0.550457973f, -0.834862875f, + 0.545324988f, -0.838224706f, + 0.540171473f, -0.841554977f, + 0.534997620f, -0.844853565f, + 0.529803625f, -0.848120345f, + 0.524589683f, -0.851355193f, + 0.519355990f, -0.854557988f, + 0.514102744f, -0.857728610f, + 0.508830143f, -0.860866939f, + 0.503538384f, -0.863972856f, + 0.498227667f, -0.867046246f, + 0.492898192f, -0.870086991f, + 0.487550160f, -0.873094978f, + 0.482183772f, -0.876070094f, + 0.476799230f, -0.879012226f, + 0.471396737f, -0.881921264f, + 0.465976496f, -0.884797098f, + 0.460538711f, -0.887639620f, + 0.455083587f, -0.890448723f, + 0.449611330f, -0.893224301f, + 0.444122145f, -0.895966250f, + 0.438616239f, -0.898674466f, + 0.433093819f, -0.901348847f, + 0.427555093f, -0.903989293f, + 0.422000271f, -0.906595705f, + 0.416429560f, -0.909167983f, + 0.410843171f, -0.911706032f, + 0.405241314f, -0.914209756f, + 0.399624200f, -0.916679060f, + 0.393992040f, -0.919113852f, + 0.388345047f, -0.921514039f, + 0.382683432f, -0.923879533f, + 0.377007410f, -0.926210242f, + 0.371317194f, -0.928506080f, + 0.365612998f, -0.930766961f, + 0.359895037f, -0.932992799f, + 0.354163525f, -0.935183510f, + 0.348418680f, -0.937339012f, + 0.342660717f, -0.939459224f, + 0.336889853f, -0.941544065f, + 0.331106306f, -0.943593458f, + 0.325310292f, -0.945607325f, + 0.319502031f, -0.947585591f, + 0.313681740f, -0.949528181f, + 0.307849640f, -0.951435021f, + 0.302005949f, -0.953306040f, + 0.296150888f, -0.955141168f, + 0.290284677f, -0.956940336f, + 0.284407537f, -0.958703475f, + 0.278519689f, -0.960430519f, + 0.272621355f, -0.962121404f, + 0.266712757f, -0.963776066f, + 0.260794118f, -0.965394442f, + 0.254865660f, -0.966976471f, + 0.248927606f, -0.968522094f, + 0.242980180f, -0.970031253f, + 0.237023606f, -0.971503891f, + 0.231058108f, -0.972939952f, + 0.225083911f, -0.974339383f, + 0.219101240f, -0.975702130f, + 0.213110320f, -0.977028143f, + 0.207111376f, -0.978317371f, + 0.201104635f, -0.979569766f, + 0.195090322f, -0.980785280f, + 0.189068664f, -0.981963869f, + 0.183039888f, -0.983105487f, + 0.177004220f, -0.984210092f, + 0.170961889f, -0.985277642f, + 0.164913120f, -0.986308097f, + 0.158858143f, -0.987301418f, + 0.152797185f, -0.988257568f, + 0.146730474f, -0.989176510f, + 0.140658239f, -0.990058210f, + 0.134580709f, -0.990902635f, + 0.128498111f, -0.991709754f, + 0.122410675f, -0.992479535f, + 0.116318631f, -0.993211949f, + 0.110222207f, -0.993906970f, + 0.104121634f, -0.994564571f, + 0.098017140f, -0.995184727f, + 0.091908956f, -0.995767414f, + 0.085797312f, -0.996312612f, + 0.079682438f, -0.996820299f, + 0.073564564f, -0.997290457f, + 0.067443920f, -0.997723067f, + 0.061320736f, -0.998118113f, + 0.055195244f, -0.998475581f, + 0.049067674f, -0.998795456f, + 0.042938257f, -0.999077728f, + 0.036807223f, -0.999322385f, + 0.030674803f, -0.999529418f, + 0.024541229f, -0.999698819f, + 0.018406730f, -0.999830582f, + 0.012271538f, -0.999924702f, + 0.006135885f, -0.999981175f +}; + +const float32_t twiddleCoef_rfft_2048[2048] = { + 0.000000000f, 1.000000000f, + 0.003067957f, 0.999995294f, + 0.006135885f, 0.999981175f, + 0.009203755f, 0.999957645f, + 0.012271538f, 0.999924702f, + 0.015339206f, 0.999882347f, + 0.018406730f, 0.999830582f, + 0.021474080f, 0.999769405f, + 0.024541229f, 0.999698819f, + 0.027608146f, 0.999618822f, + 0.030674803f, 0.999529418f, + 0.033741172f, 0.999430605f, + 0.036807223f, 0.999322385f, + 0.039872928f, 0.999204759f, + 0.042938257f, 0.999077728f, + 0.046003182f, 0.998941293f, + 0.049067674f, 0.998795456f, + 0.052131705f, 0.998640218f, + 0.055195244f, 0.998475581f, + 0.058258265f, 0.998301545f, + 0.061320736f, 0.998118113f, + 0.064382631f, 0.997925286f, + 0.067443920f, 0.997723067f, + 0.070504573f, 0.997511456f, + 0.073564564f, 0.997290457f, + 0.076623861f, 0.997060070f, + 0.079682438f, 0.996820299f, + 0.082740265f, 0.996571146f, + 0.085797312f, 0.996312612f, + 0.088853553f, 0.996044701f, + 0.091908956f, 0.995767414f, + 0.094963495f, 0.995480755f, + 0.098017140f, 0.995184727f, + 0.101069863f, 0.994879331f, + 0.104121634f, 0.994564571f, + 0.107172425f, 0.994240449f, + 0.110222207f, 0.993906970f, + 0.113270952f, 0.993564136f, + 0.116318631f, 0.993211949f, + 0.119365215f, 0.992850414f, + 0.122410675f, 0.992479535f, + 0.125454983f, 0.992099313f, + 0.128498111f, 0.991709754f, + 0.131540029f, 0.991310860f, + 0.134580709f, 0.990902635f, + 0.137620122f, 0.990485084f, + 0.140658239f, 0.990058210f, + 0.143695033f, 0.989622017f, + 0.146730474f, 0.989176510f, + 0.149764535f, 0.988721692f, + 0.152797185f, 0.988257568f, + 0.155828398f, 0.987784142f, + 0.158858143f, 0.987301418f, + 0.161886394f, 0.986809402f, + 0.164913120f, 0.986308097f, + 0.167938295f, 0.985797509f, + 0.170961889f, 0.985277642f, + 0.173983873f, 0.984748502f, + 0.177004220f, 0.984210092f, + 0.180022901f, 0.983662419f, + 0.183039888f, 0.983105487f, + 0.186055152f, 0.982539302f, + 0.189068664f, 0.981963869f, + 0.192080397f, 0.981379193f, + 0.195090322f, 0.980785280f, + 0.198098411f, 0.980182136f, + 0.201104635f, 0.979569766f, + 0.204108966f, 0.978948175f, + 0.207111376f, 0.978317371f, + 0.210111837f, 0.977677358f, + 0.213110320f, 0.977028143f, + 0.216106797f, 0.976369731f, + 0.219101240f, 0.975702130f, + 0.222093621f, 0.975025345f, + 0.225083911f, 0.974339383f, + 0.228072083f, 0.973644250f, + 0.231058108f, 0.972939952f, + 0.234041959f, 0.972226497f, + 0.237023606f, 0.971503891f, + 0.240003022f, 0.970772141f, + 0.242980180f, 0.970031253f, + 0.245955050f, 0.969281235f, + 0.248927606f, 0.968522094f, + 0.251897818f, 0.967753837f, + 0.254865660f, 0.966976471f, + 0.257831102f, 0.966190003f, + 0.260794118f, 0.965394442f, + 0.263754679f, 0.964589793f, + 0.266712757f, 0.963776066f, + 0.269668326f, 0.962953267f, + 0.272621355f, 0.962121404f, + 0.275571819f, 0.961280486f, + 0.278519689f, 0.960430519f, + 0.281464938f, 0.959571513f, + 0.284407537f, 0.958703475f, + 0.287347460f, 0.957826413f, + 0.290284677f, 0.956940336f, + 0.293219163f, 0.956045251f, + 0.296150888f, 0.955141168f, + 0.299079826f, 0.954228095f, + 0.302005949f, 0.953306040f, + 0.304929230f, 0.952375013f, + 0.307849640f, 0.951435021f, + 0.310767153f, 0.950486074f, + 0.313681740f, 0.949528181f, + 0.316593376f, 0.948561350f, + 0.319502031f, 0.947585591f, + 0.322407679f, 0.946600913f, + 0.325310292f, 0.945607325f, + 0.328209844f, 0.944604837f, + 0.331106306f, 0.943593458f, + 0.333999651f, 0.942573198f, + 0.336889853f, 0.941544065f, + 0.339776884f, 0.940506071f, + 0.342660717f, 0.939459224f, + 0.345541325f, 0.938403534f, + 0.348418680f, 0.937339012f, + 0.351292756f, 0.936265667f, + 0.354163525f, 0.935183510f, + 0.357030961f, 0.934092550f, + 0.359895037f, 0.932992799f, + 0.362755724f, 0.931884266f, + 0.365612998f, 0.930766961f, + 0.368466830f, 0.929640896f, + 0.371317194f, 0.928506080f, + 0.374164063f, 0.927362526f, + 0.377007410f, 0.926210242f, + 0.379847209f, 0.925049241f, + 0.382683432f, 0.923879533f, + 0.385516054f, 0.922701128f, + 0.388345047f, 0.921514039f, + 0.391170384f, 0.920318277f, + 0.393992040f, 0.919113852f, + 0.396809987f, 0.917900776f, + 0.399624200f, 0.916679060f, + 0.402434651f, 0.915448716f, + 0.405241314f, 0.914209756f, + 0.408044163f, 0.912962190f, + 0.410843171f, 0.911706032f, + 0.413638312f, 0.910441292f, + 0.416429560f, 0.909167983f, + 0.419216888f, 0.907886116f, + 0.422000271f, 0.906595705f, + 0.424779681f, 0.905296759f, + 0.427555093f, 0.903989293f, + 0.430326481f, 0.902673318f, + 0.433093819f, 0.901348847f, + 0.435857080f, 0.900015892f, + 0.438616239f, 0.898674466f, + 0.441371269f, 0.897324581f, + 0.444122145f, 0.895966250f, + 0.446868840f, 0.894599486f, + 0.449611330f, 0.893224301f, + 0.452349587f, 0.891840709f, + 0.455083587f, 0.890448723f, + 0.457813304f, 0.889048356f, + 0.460538711f, 0.887639620f, + 0.463259784f, 0.886222530f, + 0.465976496f, 0.884797098f, + 0.468688822f, 0.883363339f, + 0.471396737f, 0.881921264f, + 0.474100215f, 0.880470889f, + 0.476799230f, 0.879012226f, + 0.479493758f, 0.877545290f, + 0.482183772f, 0.876070094f, + 0.484869248f, 0.874586652f, + 0.487550160f, 0.873094978f, + 0.490226483f, 0.871595087f, + 0.492898192f, 0.870086991f, + 0.495565262f, 0.868570706f, + 0.498227667f, 0.867046246f, + 0.500885383f, 0.865513624f, + 0.503538384f, 0.863972856f, + 0.506186645f, 0.862423956f, + 0.508830143f, 0.860866939f, + 0.511468850f, 0.859301818f, + 0.514102744f, 0.857728610f, + 0.516731799f, 0.856147328f, + 0.519355990f, 0.854557988f, + 0.521975293f, 0.852960605f, + 0.524589683f, 0.851355193f, + 0.527199135f, 0.849741768f, + 0.529803625f, 0.848120345f, + 0.532403128f, 0.846490939f, + 0.534997620f, 0.844853565f, + 0.537587076f, 0.843208240f, + 0.540171473f, 0.841554977f, + 0.542750785f, 0.839893794f, + 0.545324988f, 0.838224706f, + 0.547894059f, 0.836547727f, + 0.550457973f, 0.834862875f, + 0.553016706f, 0.833170165f, + 0.555570233f, 0.831469612f, + 0.558118531f, 0.829761234f, + 0.560661576f, 0.828045045f, + 0.563199344f, 0.826321063f, + 0.565731811f, 0.824589303f, + 0.568258953f, 0.822849781f, + 0.570780746f, 0.821102515f, + 0.573297167f, 0.819347520f, + 0.575808191f, 0.817584813f, + 0.578313796f, 0.815814411f, + 0.580813958f, 0.814036330f, + 0.583308653f, 0.812250587f, + 0.585797857f, 0.810457198f, + 0.588281548f, 0.808656182f, + 0.590759702f, 0.806847554f, + 0.593232295f, 0.805031331f, + 0.595699304f, 0.803207531f, + 0.598160707f, 0.801376172f, + 0.600616479f, 0.799537269f, + 0.603066599f, 0.797690841f, + 0.605511041f, 0.795836905f, + 0.607949785f, 0.793975478f, + 0.610382806f, 0.792106577f, + 0.612810082f, 0.790230221f, + 0.615231591f, 0.788346428f, + 0.617647308f, 0.786455214f, + 0.620057212f, 0.784556597f, + 0.622461279f, 0.782650596f, + 0.624859488f, 0.780737229f, + 0.627251815f, 0.778816512f, + 0.629638239f, 0.776888466f, + 0.632018736f, 0.774953107f, + 0.634393284f, 0.773010453f, + 0.636761861f, 0.771060524f, + 0.639124445f, 0.769103338f, + 0.641481013f, 0.767138912f, + 0.643831543f, 0.765167266f, + 0.646176013f, 0.763188417f, + 0.648514401f, 0.761202385f, + 0.650846685f, 0.759209189f, + 0.653172843f, 0.757208847f, + 0.655492853f, 0.755201377f, + 0.657806693f, 0.753186799f, + 0.660114342f, 0.751165132f, + 0.662415778f, 0.749136395f, + 0.664710978f, 0.747100606f, + 0.666999922f, 0.745057785f, + 0.669282588f, 0.743007952f, + 0.671558955f, 0.740951125f, + 0.673829000f, 0.738887324f, + 0.676092704f, 0.736816569f, + 0.678350043f, 0.734738878f, + 0.680600998f, 0.732654272f, + 0.682845546f, 0.730562769f, + 0.685083668f, 0.728464390f, + 0.687315341f, 0.726359155f, + 0.689540545f, 0.724247083f, + 0.691759258f, 0.722128194f, + 0.693971461f, 0.720002508f, + 0.696177131f, 0.717870045f, + 0.698376249f, 0.715730825f, + 0.700568794f, 0.713584869f, + 0.702754744f, 0.711432196f, + 0.704934080f, 0.709272826f, + 0.707106781f, 0.707106781f, + 0.709272826f, 0.704934080f, + 0.711432196f, 0.702754744f, + 0.713584869f, 0.700568794f, + 0.715730825f, 0.698376249f, + 0.717870045f, 0.696177131f, + 0.720002508f, 0.693971461f, + 0.722128194f, 0.691759258f, + 0.724247083f, 0.689540545f, + 0.726359155f, 0.687315341f, + 0.728464390f, 0.685083668f, + 0.730562769f, 0.682845546f, + 0.732654272f, 0.680600998f, + 0.734738878f, 0.678350043f, + 0.736816569f, 0.676092704f, + 0.738887324f, 0.673829000f, + 0.740951125f, 0.671558955f, + 0.743007952f, 0.669282588f, + 0.745057785f, 0.666999922f, + 0.747100606f, 0.664710978f, + 0.749136395f, 0.662415778f, + 0.751165132f, 0.660114342f, + 0.753186799f, 0.657806693f, + 0.755201377f, 0.655492853f, + 0.757208847f, 0.653172843f, + 0.759209189f, 0.650846685f, + 0.761202385f, 0.648514401f, + 0.763188417f, 0.646176013f, + 0.765167266f, 0.643831543f, + 0.767138912f, 0.641481013f, + 0.769103338f, 0.639124445f, + 0.771060524f, 0.636761861f, + 0.773010453f, 0.634393284f, + 0.774953107f, 0.632018736f, + 0.776888466f, 0.629638239f, + 0.778816512f, 0.627251815f, + 0.780737229f, 0.624859488f, + 0.782650596f, 0.622461279f, + 0.784556597f, 0.620057212f, + 0.786455214f, 0.617647308f, + 0.788346428f, 0.615231591f, + 0.790230221f, 0.612810082f, + 0.792106577f, 0.610382806f, + 0.793975478f, 0.607949785f, + 0.795836905f, 0.605511041f, + 0.797690841f, 0.603066599f, + 0.799537269f, 0.600616479f, + 0.801376172f, 0.598160707f, + 0.803207531f, 0.595699304f, + 0.805031331f, 0.593232295f, + 0.806847554f, 0.590759702f, + 0.808656182f, 0.588281548f, + 0.810457198f, 0.585797857f, + 0.812250587f, 0.583308653f, + 0.814036330f, 0.580813958f, + 0.815814411f, 0.578313796f, + 0.817584813f, 0.575808191f, + 0.819347520f, 0.573297167f, + 0.821102515f, 0.570780746f, + 0.822849781f, 0.568258953f, + 0.824589303f, 0.565731811f, + 0.826321063f, 0.563199344f, + 0.828045045f, 0.560661576f, + 0.829761234f, 0.558118531f, + 0.831469612f, 0.555570233f, + 0.833170165f, 0.553016706f, + 0.834862875f, 0.550457973f, + 0.836547727f, 0.547894059f, + 0.838224706f, 0.545324988f, + 0.839893794f, 0.542750785f, + 0.841554977f, 0.540171473f, + 0.843208240f, 0.537587076f, + 0.844853565f, 0.534997620f, + 0.846490939f, 0.532403128f, + 0.848120345f, 0.529803625f, + 0.849741768f, 0.527199135f, + 0.851355193f, 0.524589683f, + 0.852960605f, 0.521975293f, + 0.854557988f, 0.519355990f, + 0.856147328f, 0.516731799f, + 0.857728610f, 0.514102744f, + 0.859301818f, 0.511468850f, + 0.860866939f, 0.508830143f, + 0.862423956f, 0.506186645f, + 0.863972856f, 0.503538384f, + 0.865513624f, 0.500885383f, + 0.867046246f, 0.498227667f, + 0.868570706f, 0.495565262f, + 0.870086991f, 0.492898192f, + 0.871595087f, 0.490226483f, + 0.873094978f, 0.487550160f, + 0.874586652f, 0.484869248f, + 0.876070094f, 0.482183772f, + 0.877545290f, 0.479493758f, + 0.879012226f, 0.476799230f, + 0.880470889f, 0.474100215f, + 0.881921264f, 0.471396737f, + 0.883363339f, 0.468688822f, + 0.884797098f, 0.465976496f, + 0.886222530f, 0.463259784f, + 0.887639620f, 0.460538711f, + 0.889048356f, 0.457813304f, + 0.890448723f, 0.455083587f, + 0.891840709f, 0.452349587f, + 0.893224301f, 0.449611330f, + 0.894599486f, 0.446868840f, + 0.895966250f, 0.444122145f, + 0.897324581f, 0.441371269f, + 0.898674466f, 0.438616239f, + 0.900015892f, 0.435857080f, + 0.901348847f, 0.433093819f, + 0.902673318f, 0.430326481f, + 0.903989293f, 0.427555093f, + 0.905296759f, 0.424779681f, + 0.906595705f, 0.422000271f, + 0.907886116f, 0.419216888f, + 0.909167983f, 0.416429560f, + 0.910441292f, 0.413638312f, + 0.911706032f, 0.410843171f, + 0.912962190f, 0.408044163f, + 0.914209756f, 0.405241314f, + 0.915448716f, 0.402434651f, + 0.916679060f, 0.399624200f, + 0.917900776f, 0.396809987f, + 0.919113852f, 0.393992040f, + 0.920318277f, 0.391170384f, + 0.921514039f, 0.388345047f, + 0.922701128f, 0.385516054f, + 0.923879533f, 0.382683432f, + 0.925049241f, 0.379847209f, + 0.926210242f, 0.377007410f, + 0.927362526f, 0.374164063f, + 0.928506080f, 0.371317194f, + 0.929640896f, 0.368466830f, + 0.930766961f, 0.365612998f, + 0.931884266f, 0.362755724f, + 0.932992799f, 0.359895037f, + 0.934092550f, 0.357030961f, + 0.935183510f, 0.354163525f, + 0.936265667f, 0.351292756f, + 0.937339012f, 0.348418680f, + 0.938403534f, 0.345541325f, + 0.939459224f, 0.342660717f, + 0.940506071f, 0.339776884f, + 0.941544065f, 0.336889853f, + 0.942573198f, 0.333999651f, + 0.943593458f, 0.331106306f, + 0.944604837f, 0.328209844f, + 0.945607325f, 0.325310292f, + 0.946600913f, 0.322407679f, + 0.947585591f, 0.319502031f, + 0.948561350f, 0.316593376f, + 0.949528181f, 0.313681740f, + 0.950486074f, 0.310767153f, + 0.951435021f, 0.307849640f, + 0.952375013f, 0.304929230f, + 0.953306040f, 0.302005949f, + 0.954228095f, 0.299079826f, + 0.955141168f, 0.296150888f, + 0.956045251f, 0.293219163f, + 0.956940336f, 0.290284677f, + 0.957826413f, 0.287347460f, + 0.958703475f, 0.284407537f, + 0.959571513f, 0.281464938f, + 0.960430519f, 0.278519689f, + 0.961280486f, 0.275571819f, + 0.962121404f, 0.272621355f, + 0.962953267f, 0.269668326f, + 0.963776066f, 0.266712757f, + 0.964589793f, 0.263754679f, + 0.965394442f, 0.260794118f, + 0.966190003f, 0.257831102f, + 0.966976471f, 0.254865660f, + 0.967753837f, 0.251897818f, + 0.968522094f, 0.248927606f, + 0.969281235f, 0.245955050f, + 0.970031253f, 0.242980180f, + 0.970772141f, 0.240003022f, + 0.971503891f, 0.237023606f, + 0.972226497f, 0.234041959f, + 0.972939952f, 0.231058108f, + 0.973644250f, 0.228072083f, + 0.974339383f, 0.225083911f, + 0.975025345f, 0.222093621f, + 0.975702130f, 0.219101240f, + 0.976369731f, 0.216106797f, + 0.977028143f, 0.213110320f, + 0.977677358f, 0.210111837f, + 0.978317371f, 0.207111376f, + 0.978948175f, 0.204108966f, + 0.979569766f, 0.201104635f, + 0.980182136f, 0.198098411f, + 0.980785280f, 0.195090322f, + 0.981379193f, 0.192080397f, + 0.981963869f, 0.189068664f, + 0.982539302f, 0.186055152f, + 0.983105487f, 0.183039888f, + 0.983662419f, 0.180022901f, + 0.984210092f, 0.177004220f, + 0.984748502f, 0.173983873f, + 0.985277642f, 0.170961889f, + 0.985797509f, 0.167938295f, + 0.986308097f, 0.164913120f, + 0.986809402f, 0.161886394f, + 0.987301418f, 0.158858143f, + 0.987784142f, 0.155828398f, + 0.988257568f, 0.152797185f, + 0.988721692f, 0.149764535f, + 0.989176510f, 0.146730474f, + 0.989622017f, 0.143695033f, + 0.990058210f, 0.140658239f, + 0.990485084f, 0.137620122f, + 0.990902635f, 0.134580709f, + 0.991310860f, 0.131540029f, + 0.991709754f, 0.128498111f, + 0.992099313f, 0.125454983f, + 0.992479535f, 0.122410675f, + 0.992850414f, 0.119365215f, + 0.993211949f, 0.116318631f, + 0.993564136f, 0.113270952f, + 0.993906970f, 0.110222207f, + 0.994240449f, 0.107172425f, + 0.994564571f, 0.104121634f, + 0.994879331f, 0.101069863f, + 0.995184727f, 0.098017140f, + 0.995480755f, 0.094963495f, + 0.995767414f, 0.091908956f, + 0.996044701f, 0.088853553f, + 0.996312612f, 0.085797312f, + 0.996571146f, 0.082740265f, + 0.996820299f, 0.079682438f, + 0.997060070f, 0.076623861f, + 0.997290457f, 0.073564564f, + 0.997511456f, 0.070504573f, + 0.997723067f, 0.067443920f, + 0.997925286f, 0.064382631f, + 0.998118113f, 0.061320736f, + 0.998301545f, 0.058258265f, + 0.998475581f, 0.055195244f, + 0.998640218f, 0.052131705f, + 0.998795456f, 0.049067674f, + 0.998941293f, 0.046003182f, + 0.999077728f, 0.042938257f, + 0.999204759f, 0.039872928f, + 0.999322385f, 0.036807223f, + 0.999430605f, 0.033741172f, + 0.999529418f, 0.030674803f, + 0.999618822f, 0.027608146f, + 0.999698819f, 0.024541229f, + 0.999769405f, 0.021474080f, + 0.999830582f, 0.018406730f, + 0.999882347f, 0.015339206f, + 0.999924702f, 0.012271538f, + 0.999957645f, 0.009203755f, + 0.999981175f, 0.006135885f, + 0.999995294f, 0.003067957f, + 1.000000000f, 0.000000000f, + 0.999995294f, -0.003067957f, + 0.999981175f, -0.006135885f, + 0.999957645f, -0.009203755f, + 0.999924702f, -0.012271538f, + 0.999882347f, -0.015339206f, + 0.999830582f, -0.018406730f, + 0.999769405f, -0.021474080f, + 0.999698819f, -0.024541229f, + 0.999618822f, -0.027608146f, + 0.999529418f, -0.030674803f, + 0.999430605f, -0.033741172f, + 0.999322385f, -0.036807223f, + 0.999204759f, -0.039872928f, + 0.999077728f, -0.042938257f, + 0.998941293f, -0.046003182f, + 0.998795456f, -0.049067674f, + 0.998640218f, -0.052131705f, + 0.998475581f, -0.055195244f, + 0.998301545f, -0.058258265f, + 0.998118113f, -0.061320736f, + 0.997925286f, -0.064382631f, + 0.997723067f, -0.067443920f, + 0.997511456f, -0.070504573f, + 0.997290457f, -0.073564564f, + 0.997060070f, -0.076623861f, + 0.996820299f, -0.079682438f, + 0.996571146f, -0.082740265f, + 0.996312612f, -0.085797312f, + 0.996044701f, -0.088853553f, + 0.995767414f, -0.091908956f, + 0.995480755f, -0.094963495f, + 0.995184727f, -0.098017140f, + 0.994879331f, -0.101069863f, + 0.994564571f, -0.104121634f, + 0.994240449f, -0.107172425f, + 0.993906970f, -0.110222207f, + 0.993564136f, -0.113270952f, + 0.993211949f, -0.116318631f, + 0.992850414f, -0.119365215f, + 0.992479535f, -0.122410675f, + 0.992099313f, -0.125454983f, + 0.991709754f, -0.128498111f, + 0.991310860f, -0.131540029f, + 0.990902635f, -0.134580709f, + 0.990485084f, -0.137620122f, + 0.990058210f, -0.140658239f, + 0.989622017f, -0.143695033f, + 0.989176510f, -0.146730474f, + 0.988721692f, -0.149764535f, + 0.988257568f, -0.152797185f, + 0.987784142f, -0.155828398f, + 0.987301418f, -0.158858143f, + 0.986809402f, -0.161886394f, + 0.986308097f, -0.164913120f, + 0.985797509f, -0.167938295f, + 0.985277642f, -0.170961889f, + 0.984748502f, -0.173983873f, + 0.984210092f, -0.177004220f, + 0.983662419f, -0.180022901f, + 0.983105487f, -0.183039888f, + 0.982539302f, -0.186055152f, + 0.981963869f, -0.189068664f, + 0.981379193f, -0.192080397f, + 0.980785280f, -0.195090322f, + 0.980182136f, -0.198098411f, + 0.979569766f, -0.201104635f, + 0.978948175f, -0.204108966f, + 0.978317371f, -0.207111376f, + 0.977677358f, -0.210111837f, + 0.977028143f, -0.213110320f, + 0.976369731f, -0.216106797f, + 0.975702130f, -0.219101240f, + 0.975025345f, -0.222093621f, + 0.974339383f, -0.225083911f, + 0.973644250f, -0.228072083f, + 0.972939952f, -0.231058108f, + 0.972226497f, -0.234041959f, + 0.971503891f, -0.237023606f, + 0.970772141f, -0.240003022f, + 0.970031253f, -0.242980180f, + 0.969281235f, -0.245955050f, + 0.968522094f, -0.248927606f, + 0.967753837f, -0.251897818f, + 0.966976471f, -0.254865660f, + 0.966190003f, -0.257831102f, + 0.965394442f, -0.260794118f, + 0.964589793f, -0.263754679f, + 0.963776066f, -0.266712757f, + 0.962953267f, -0.269668326f, + 0.962121404f, -0.272621355f, + 0.961280486f, -0.275571819f, + 0.960430519f, -0.278519689f, + 0.959571513f, -0.281464938f, + 0.958703475f, -0.284407537f, + 0.957826413f, -0.287347460f, + 0.956940336f, -0.290284677f, + 0.956045251f, -0.293219163f, + 0.955141168f, -0.296150888f, + 0.954228095f, -0.299079826f, + 0.953306040f, -0.302005949f, + 0.952375013f, -0.304929230f, + 0.951435021f, -0.307849640f, + 0.950486074f, -0.310767153f, + 0.949528181f, -0.313681740f, + 0.948561350f, -0.316593376f, + 0.947585591f, -0.319502031f, + 0.946600913f, -0.322407679f, + 0.945607325f, -0.325310292f, + 0.944604837f, -0.328209844f, + 0.943593458f, -0.331106306f, + 0.942573198f, -0.333999651f, + 0.941544065f, -0.336889853f, + 0.940506071f, -0.339776884f, + 0.939459224f, -0.342660717f, + 0.938403534f, -0.345541325f, + 0.937339012f, -0.348418680f, + 0.936265667f, -0.351292756f, + 0.935183510f, -0.354163525f, + 0.934092550f, -0.357030961f, + 0.932992799f, -0.359895037f, + 0.931884266f, -0.362755724f, + 0.930766961f, -0.365612998f, + 0.929640896f, -0.368466830f, + 0.928506080f, -0.371317194f, + 0.927362526f, -0.374164063f, + 0.926210242f, -0.377007410f, + 0.925049241f, -0.379847209f, + 0.923879533f, -0.382683432f, + 0.922701128f, -0.385516054f, + 0.921514039f, -0.388345047f, + 0.920318277f, -0.391170384f, + 0.919113852f, -0.393992040f, + 0.917900776f, -0.396809987f, + 0.916679060f, -0.399624200f, + 0.915448716f, -0.402434651f, + 0.914209756f, -0.405241314f, + 0.912962190f, -0.408044163f, + 0.911706032f, -0.410843171f, + 0.910441292f, -0.413638312f, + 0.909167983f, -0.416429560f, + 0.907886116f, -0.419216888f, + 0.906595705f, -0.422000271f, + 0.905296759f, -0.424779681f, + 0.903989293f, -0.427555093f, + 0.902673318f, -0.430326481f, + 0.901348847f, -0.433093819f, + 0.900015892f, -0.435857080f, + 0.898674466f, -0.438616239f, + 0.897324581f, -0.441371269f, + 0.895966250f, -0.444122145f, + 0.894599486f, -0.446868840f, + 0.893224301f, -0.449611330f, + 0.891840709f, -0.452349587f, + 0.890448723f, -0.455083587f, + 0.889048356f, -0.457813304f, + 0.887639620f, -0.460538711f, + 0.886222530f, -0.463259784f, + 0.884797098f, -0.465976496f, + 0.883363339f, -0.468688822f, + 0.881921264f, -0.471396737f, + 0.880470889f, -0.474100215f, + 0.879012226f, -0.476799230f, + 0.877545290f, -0.479493758f, + 0.876070094f, -0.482183772f, + 0.874586652f, -0.484869248f, + 0.873094978f, -0.487550160f, + 0.871595087f, -0.490226483f, + 0.870086991f, -0.492898192f, + 0.868570706f, -0.495565262f, + 0.867046246f, -0.498227667f, + 0.865513624f, -0.500885383f, + 0.863972856f, -0.503538384f, + 0.862423956f, -0.506186645f, + 0.860866939f, -0.508830143f, + 0.859301818f, -0.511468850f, + 0.857728610f, -0.514102744f, + 0.856147328f, -0.516731799f, + 0.854557988f, -0.519355990f, + 0.852960605f, -0.521975293f, + 0.851355193f, -0.524589683f, + 0.849741768f, -0.527199135f, + 0.848120345f, -0.529803625f, + 0.846490939f, -0.532403128f, + 0.844853565f, -0.534997620f, + 0.843208240f, -0.537587076f, + 0.841554977f, -0.540171473f, + 0.839893794f, -0.542750785f, + 0.838224706f, -0.545324988f, + 0.836547727f, -0.547894059f, + 0.834862875f, -0.550457973f, + 0.833170165f, -0.553016706f, + 0.831469612f, -0.555570233f, + 0.829761234f, -0.558118531f, + 0.828045045f, -0.560661576f, + 0.826321063f, -0.563199344f, + 0.824589303f, -0.565731811f, + 0.822849781f, -0.568258953f, + 0.821102515f, -0.570780746f, + 0.819347520f, -0.573297167f, + 0.817584813f, -0.575808191f, + 0.815814411f, -0.578313796f, + 0.814036330f, -0.580813958f, + 0.812250587f, -0.583308653f, + 0.810457198f, -0.585797857f, + 0.808656182f, -0.588281548f, + 0.806847554f, -0.590759702f, + 0.805031331f, -0.593232295f, + 0.803207531f, -0.595699304f, + 0.801376172f, -0.598160707f, + 0.799537269f, -0.600616479f, + 0.797690841f, -0.603066599f, + 0.795836905f, -0.605511041f, + 0.793975478f, -0.607949785f, + 0.792106577f, -0.610382806f, + 0.790230221f, -0.612810082f, + 0.788346428f, -0.615231591f, + 0.786455214f, -0.617647308f, + 0.784556597f, -0.620057212f, + 0.782650596f, -0.622461279f, + 0.780737229f, -0.624859488f, + 0.778816512f, -0.627251815f, + 0.776888466f, -0.629638239f, + 0.774953107f, -0.632018736f, + 0.773010453f, -0.634393284f, + 0.771060524f, -0.636761861f, + 0.769103338f, -0.639124445f, + 0.767138912f, -0.641481013f, + 0.765167266f, -0.643831543f, + 0.763188417f, -0.646176013f, + 0.761202385f, -0.648514401f, + 0.759209189f, -0.650846685f, + 0.757208847f, -0.653172843f, + 0.755201377f, -0.655492853f, + 0.753186799f, -0.657806693f, + 0.751165132f, -0.660114342f, + 0.749136395f, -0.662415778f, + 0.747100606f, -0.664710978f, + 0.745057785f, -0.666999922f, + 0.743007952f, -0.669282588f, + 0.740951125f, -0.671558955f, + 0.738887324f, -0.673829000f, + 0.736816569f, -0.676092704f, + 0.734738878f, -0.678350043f, + 0.732654272f, -0.680600998f, + 0.730562769f, -0.682845546f, + 0.728464390f, -0.685083668f, + 0.726359155f, -0.687315341f, + 0.724247083f, -0.689540545f, + 0.722128194f, -0.691759258f, + 0.720002508f, -0.693971461f, + 0.717870045f, -0.696177131f, + 0.715730825f, -0.698376249f, + 0.713584869f, -0.700568794f, + 0.711432196f, -0.702754744f, + 0.709272826f, -0.704934080f, + 0.707106781f, -0.707106781f, + 0.704934080f, -0.709272826f, + 0.702754744f, -0.711432196f, + 0.700568794f, -0.713584869f, + 0.698376249f, -0.715730825f, + 0.696177131f, -0.717870045f, + 0.693971461f, -0.720002508f, + 0.691759258f, -0.722128194f, + 0.689540545f, -0.724247083f, + 0.687315341f, -0.726359155f, + 0.685083668f, -0.728464390f, + 0.682845546f, -0.730562769f, + 0.680600998f, -0.732654272f, + 0.678350043f, -0.734738878f, + 0.676092704f, -0.736816569f, + 0.673829000f, -0.738887324f, + 0.671558955f, -0.740951125f, + 0.669282588f, -0.743007952f, + 0.666999922f, -0.745057785f, + 0.664710978f, -0.747100606f, + 0.662415778f, -0.749136395f, + 0.660114342f, -0.751165132f, + 0.657806693f, -0.753186799f, + 0.655492853f, -0.755201377f, + 0.653172843f, -0.757208847f, + 0.650846685f, -0.759209189f, + 0.648514401f, -0.761202385f, + 0.646176013f, -0.763188417f, + 0.643831543f, -0.765167266f, + 0.641481013f, -0.767138912f, + 0.639124445f, -0.769103338f, + 0.636761861f, -0.771060524f, + 0.634393284f, -0.773010453f, + 0.632018736f, -0.774953107f, + 0.629638239f, -0.776888466f, + 0.627251815f, -0.778816512f, + 0.624859488f, -0.780737229f, + 0.622461279f, -0.782650596f, + 0.620057212f, -0.784556597f, + 0.617647308f, -0.786455214f, + 0.615231591f, -0.788346428f, + 0.612810082f, -0.790230221f, + 0.610382806f, -0.792106577f, + 0.607949785f, -0.793975478f, + 0.605511041f, -0.795836905f, + 0.603066599f, -0.797690841f, + 0.600616479f, -0.799537269f, + 0.598160707f, -0.801376172f, + 0.595699304f, -0.803207531f, + 0.593232295f, -0.805031331f, + 0.590759702f, -0.806847554f, + 0.588281548f, -0.808656182f, + 0.585797857f, -0.810457198f, + 0.583308653f, -0.812250587f, + 0.580813958f, -0.814036330f, + 0.578313796f, -0.815814411f, + 0.575808191f, -0.817584813f, + 0.573297167f, -0.819347520f, + 0.570780746f, -0.821102515f, + 0.568258953f, -0.822849781f, + 0.565731811f, -0.824589303f, + 0.563199344f, -0.826321063f, + 0.560661576f, -0.828045045f, + 0.558118531f, -0.829761234f, + 0.555570233f, -0.831469612f, + 0.553016706f, -0.833170165f, + 0.550457973f, -0.834862875f, + 0.547894059f, -0.836547727f, + 0.545324988f, -0.838224706f, + 0.542750785f, -0.839893794f, + 0.540171473f, -0.841554977f, + 0.537587076f, -0.843208240f, + 0.534997620f, -0.844853565f, + 0.532403128f, -0.846490939f, + 0.529803625f, -0.848120345f, + 0.527199135f, -0.849741768f, + 0.524589683f, -0.851355193f, + 0.521975293f, -0.852960605f, + 0.519355990f, -0.854557988f, + 0.516731799f, -0.856147328f, + 0.514102744f, -0.857728610f, + 0.511468850f, -0.859301818f, + 0.508830143f, -0.860866939f, + 0.506186645f, -0.862423956f, + 0.503538384f, -0.863972856f, + 0.500885383f, -0.865513624f, + 0.498227667f, -0.867046246f, + 0.495565262f, -0.868570706f, + 0.492898192f, -0.870086991f, + 0.490226483f, -0.871595087f, + 0.487550160f, -0.873094978f, + 0.484869248f, -0.874586652f, + 0.482183772f, -0.876070094f, + 0.479493758f, -0.877545290f, + 0.476799230f, -0.879012226f, + 0.474100215f, -0.880470889f, + 0.471396737f, -0.881921264f, + 0.468688822f, -0.883363339f, + 0.465976496f, -0.884797098f, + 0.463259784f, -0.886222530f, + 0.460538711f, -0.887639620f, + 0.457813304f, -0.889048356f, + 0.455083587f, -0.890448723f, + 0.452349587f, -0.891840709f, + 0.449611330f, -0.893224301f, + 0.446868840f, -0.894599486f, + 0.444122145f, -0.895966250f, + 0.441371269f, -0.897324581f, + 0.438616239f, -0.898674466f, + 0.435857080f, -0.900015892f, + 0.433093819f, -0.901348847f, + 0.430326481f, -0.902673318f, + 0.427555093f, -0.903989293f, + 0.424779681f, -0.905296759f, + 0.422000271f, -0.906595705f, + 0.419216888f, -0.907886116f, + 0.416429560f, -0.909167983f, + 0.413638312f, -0.910441292f, + 0.410843171f, -0.911706032f, + 0.408044163f, -0.912962190f, + 0.405241314f, -0.914209756f, + 0.402434651f, -0.915448716f, + 0.399624200f, -0.916679060f, + 0.396809987f, -0.917900776f, + 0.393992040f, -0.919113852f, + 0.391170384f, -0.920318277f, + 0.388345047f, -0.921514039f, + 0.385516054f, -0.922701128f, + 0.382683432f, -0.923879533f, + 0.379847209f, -0.925049241f, + 0.377007410f, -0.926210242f, + 0.374164063f, -0.927362526f, + 0.371317194f, -0.928506080f, + 0.368466830f, -0.929640896f, + 0.365612998f, -0.930766961f, + 0.362755724f, -0.931884266f, + 0.359895037f, -0.932992799f, + 0.357030961f, -0.934092550f, + 0.354163525f, -0.935183510f, + 0.351292756f, -0.936265667f, + 0.348418680f, -0.937339012f, + 0.345541325f, -0.938403534f, + 0.342660717f, -0.939459224f, + 0.339776884f, -0.940506071f, + 0.336889853f, -0.941544065f, + 0.333999651f, -0.942573198f, + 0.331106306f, -0.943593458f, + 0.328209844f, -0.944604837f, + 0.325310292f, -0.945607325f, + 0.322407679f, -0.946600913f, + 0.319502031f, -0.947585591f, + 0.316593376f, -0.948561350f, + 0.313681740f, -0.949528181f, + 0.310767153f, -0.950486074f, + 0.307849640f, -0.951435021f, + 0.304929230f, -0.952375013f, + 0.302005949f, -0.953306040f, + 0.299079826f, -0.954228095f, + 0.296150888f, -0.955141168f, + 0.293219163f, -0.956045251f, + 0.290284677f, -0.956940336f, + 0.287347460f, -0.957826413f, + 0.284407537f, -0.958703475f, + 0.281464938f, -0.959571513f, + 0.278519689f, -0.960430519f, + 0.275571819f, -0.961280486f, + 0.272621355f, -0.962121404f, + 0.269668326f, -0.962953267f, + 0.266712757f, -0.963776066f, + 0.263754679f, -0.964589793f, + 0.260794118f, -0.965394442f, + 0.257831102f, -0.966190003f, + 0.254865660f, -0.966976471f, + 0.251897818f, -0.967753837f, + 0.248927606f, -0.968522094f, + 0.245955050f, -0.969281235f, + 0.242980180f, -0.970031253f, + 0.240003022f, -0.970772141f, + 0.237023606f, -0.971503891f, + 0.234041959f, -0.972226497f, + 0.231058108f, -0.972939952f, + 0.228072083f, -0.973644250f, + 0.225083911f, -0.974339383f, + 0.222093621f, -0.975025345f, + 0.219101240f, -0.975702130f, + 0.216106797f, -0.976369731f, + 0.213110320f, -0.977028143f, + 0.210111837f, -0.977677358f, + 0.207111376f, -0.978317371f, + 0.204108966f, -0.978948175f, + 0.201104635f, -0.979569766f, + 0.198098411f, -0.980182136f, + 0.195090322f, -0.980785280f, + 0.192080397f, -0.981379193f, + 0.189068664f, -0.981963869f, + 0.186055152f, -0.982539302f, + 0.183039888f, -0.983105487f, + 0.180022901f, -0.983662419f, + 0.177004220f, -0.984210092f, + 0.173983873f, -0.984748502f, + 0.170961889f, -0.985277642f, + 0.167938295f, -0.985797509f, + 0.164913120f, -0.986308097f, + 0.161886394f, -0.986809402f, + 0.158858143f, -0.987301418f, + 0.155828398f, -0.987784142f, + 0.152797185f, -0.988257568f, + 0.149764535f, -0.988721692f, + 0.146730474f, -0.989176510f, + 0.143695033f, -0.989622017f, + 0.140658239f, -0.990058210f, + 0.137620122f, -0.990485084f, + 0.134580709f, -0.990902635f, + 0.131540029f, -0.991310860f, + 0.128498111f, -0.991709754f, + 0.125454983f, -0.992099313f, + 0.122410675f, -0.992479535f, + 0.119365215f, -0.992850414f, + 0.116318631f, -0.993211949f, + 0.113270952f, -0.993564136f, + 0.110222207f, -0.993906970f, + 0.107172425f, -0.994240449f, + 0.104121634f, -0.994564571f, + 0.101069863f, -0.994879331f, + 0.098017140f, -0.995184727f, + 0.094963495f, -0.995480755f, + 0.091908956f, -0.995767414f, + 0.088853553f, -0.996044701f, + 0.085797312f, -0.996312612f, + 0.082740265f, -0.996571146f, + 0.079682438f, -0.996820299f, + 0.076623861f, -0.997060070f, + 0.073564564f, -0.997290457f, + 0.070504573f, -0.997511456f, + 0.067443920f, -0.997723067f, + 0.064382631f, -0.997925286f, + 0.061320736f, -0.998118113f, + 0.058258265f, -0.998301545f, + 0.055195244f, -0.998475581f, + 0.052131705f, -0.998640218f, + 0.049067674f, -0.998795456f, + 0.046003182f, -0.998941293f, + 0.042938257f, -0.999077728f, + 0.039872928f, -0.999204759f, + 0.036807223f, -0.999322385f, + 0.033741172f, -0.999430605f, + 0.030674803f, -0.999529418f, + 0.027608146f, -0.999618822f, + 0.024541229f, -0.999698819f, + 0.021474080f, -0.999769405f, + 0.018406730f, -0.999830582f, + 0.015339206f, -0.999882347f, + 0.012271538f, -0.999924702f, + 0.009203755f, -0.999957645f, + 0.006135885f, -0.999981175f, + 0.003067957f, -0.999995294f +}; + +const float32_t twiddleCoef_rfft_4096[4096] = { + 0.000000000f, 1.000000000f, + 0.001533980f, 0.999998823f, + 0.003067957f, 0.999995294f, + 0.004601926f, 0.999989411f, + 0.006135885f, 0.999981175f, + 0.007669829f, 0.999970586f, + 0.009203755f, 0.999957645f, + 0.010737659f, 0.999942350f, + 0.012271538f, 0.999924702f, + 0.013805389f, 0.999904701f, + 0.015339206f, 0.999882347f, + 0.016872988f, 0.999857641f, + 0.018406730f, 0.999830582f, + 0.019940429f, 0.999801170f, + 0.021474080f, 0.999769405f, + 0.023007681f, 0.999735288f, + 0.024541229f, 0.999698819f, + 0.026074718f, 0.999659997f, + 0.027608146f, 0.999618822f, + 0.029141509f, 0.999575296f, + 0.030674803f, 0.999529418f, + 0.032208025f, 0.999481187f, + 0.033741172f, 0.999430605f, + 0.035274239f, 0.999377670f, + 0.036807223f, 0.999322385f, + 0.038340120f, 0.999264747f, + 0.039872928f, 0.999204759f, + 0.041405641f, 0.999142419f, + 0.042938257f, 0.999077728f, + 0.044470772f, 0.999010686f, + 0.046003182f, 0.998941293f, + 0.047535484f, 0.998869550f, + 0.049067674f, 0.998795456f, + 0.050599749f, 0.998719012f, + 0.052131705f, 0.998640218f, + 0.053663538f, 0.998559074f, + 0.055195244f, 0.998475581f, + 0.056726821f, 0.998389737f, + 0.058258265f, 0.998301545f, + 0.059789571f, 0.998211003f, + 0.061320736f, 0.998118113f, + 0.062851758f, 0.998022874f, + 0.064382631f, 0.997925286f, + 0.065913353f, 0.997825350f, + 0.067443920f, 0.997723067f, + 0.068974328f, 0.997618435f, + 0.070504573f, 0.997511456f, + 0.072034653f, 0.997402130f, + 0.073564564f, 0.997290457f, + 0.075094301f, 0.997176437f, + 0.076623861f, 0.997060070f, + 0.078153242f, 0.996941358f, + 0.079682438f, 0.996820299f, + 0.081211447f, 0.996696895f, + 0.082740265f, 0.996571146f, + 0.084268888f, 0.996443051f, + 0.085797312f, 0.996312612f, + 0.087325535f, 0.996179829f, + 0.088853553f, 0.996044701f, + 0.090381361f, 0.995907229f, + 0.091908956f, 0.995767414f, + 0.093436336f, 0.995625256f, + 0.094963495f, 0.995480755f, + 0.096490431f, 0.995333912f, + 0.098017140f, 0.995184727f, + 0.099543619f, 0.995033199f, + 0.101069863f, 0.994879331f, + 0.102595869f, 0.994723121f, + 0.104121634f, 0.994564571f, + 0.105647154f, 0.994403680f, + 0.107172425f, 0.994240449f, + 0.108697444f, 0.994074879f, + 0.110222207f, 0.993906970f, + 0.111746711f, 0.993736722f, + 0.113270952f, 0.993564136f, + 0.114794927f, 0.993389211f, + 0.116318631f, 0.993211949f, + 0.117842062f, 0.993032350f, + 0.119365215f, 0.992850414f, + 0.120888087f, 0.992666142f, + 0.122410675f, 0.992479535f, + 0.123932975f, 0.992290591f, + 0.125454983f, 0.992099313f, + 0.126976696f, 0.991905700f, + 0.128498111f, 0.991709754f, + 0.130019223f, 0.991511473f, + 0.131540029f, 0.991310860f, + 0.133060525f, 0.991107914f, + 0.134580709f, 0.990902635f, + 0.136100575f, 0.990695025f, + 0.137620122f, 0.990485084f, + 0.139139344f, 0.990272812f, + 0.140658239f, 0.990058210f, + 0.142176804f, 0.989841278f, + 0.143695033f, 0.989622017f, + 0.145212925f, 0.989400428f, + 0.146730474f, 0.989176510f, + 0.148247679f, 0.988950265f, + 0.149764535f, 0.988721692f, + 0.151281038f, 0.988490793f, + 0.152797185f, 0.988257568f, + 0.154312973f, 0.988022017f, + 0.155828398f, 0.987784142f, + 0.157343456f, 0.987543942f, + 0.158858143f, 0.987301418f, + 0.160372457f, 0.987056571f, + 0.161886394f, 0.986809402f, + 0.163399949f, 0.986559910f, + 0.164913120f, 0.986308097f, + 0.166425904f, 0.986053963f, + 0.167938295f, 0.985797509f, + 0.169450291f, 0.985538735f, + 0.170961889f, 0.985277642f, + 0.172473084f, 0.985014231f, + 0.173983873f, 0.984748502f, + 0.175494253f, 0.984480455f, + 0.177004220f, 0.984210092f, + 0.178513771f, 0.983937413f, + 0.180022901f, 0.983662419f, + 0.181531608f, 0.983385110f, + 0.183039888f, 0.983105487f, + 0.184547737f, 0.982823551f, + 0.186055152f, 0.982539302f, + 0.187562129f, 0.982252741f, + 0.189068664f, 0.981963869f, + 0.190574755f, 0.981672686f, + 0.192080397f, 0.981379193f, + 0.193585587f, 0.981083391f, + 0.195090322f, 0.980785280f, + 0.196594598f, 0.980484862f, + 0.198098411f, 0.980182136f, + 0.199601758f, 0.979877104f, + 0.201104635f, 0.979569766f, + 0.202607039f, 0.979260123f, + 0.204108966f, 0.978948175f, + 0.205610413f, 0.978633924f, + 0.207111376f, 0.978317371f, + 0.208611852f, 0.977998515f, + 0.210111837f, 0.977677358f, + 0.211611327f, 0.977353900f, + 0.213110320f, 0.977028143f, + 0.214608811f, 0.976700086f, + 0.216106797f, 0.976369731f, + 0.217604275f, 0.976037079f, + 0.219101240f, 0.975702130f, + 0.220597690f, 0.975364885f, + 0.222093621f, 0.975025345f, + 0.223589029f, 0.974683511f, + 0.225083911f, 0.974339383f, + 0.226578264f, 0.973992962f, + 0.228072083f, 0.973644250f, + 0.229565366f, 0.973293246f, + 0.231058108f, 0.972939952f, + 0.232550307f, 0.972584369f, + 0.234041959f, 0.972226497f, + 0.235533059f, 0.971866337f, + 0.237023606f, 0.971503891f, + 0.238513595f, 0.971139158f, + 0.240003022f, 0.970772141f, + 0.241491885f, 0.970402839f, + 0.242980180f, 0.970031253f, + 0.244467903f, 0.969657385f, + 0.245955050f, 0.969281235f, + 0.247441619f, 0.968902805f, + 0.248927606f, 0.968522094f, + 0.250413007f, 0.968139105f, + 0.251897818f, 0.967753837f, + 0.253382037f, 0.967366292f, + 0.254865660f, 0.966976471f, + 0.256348682f, 0.966584374f, + 0.257831102f, 0.966190003f, + 0.259312915f, 0.965793359f, + 0.260794118f, 0.965394442f, + 0.262274707f, 0.964993253f, + 0.263754679f, 0.964589793f, + 0.265234030f, 0.964184064f, + 0.266712757f, 0.963776066f, + 0.268190857f, 0.963365800f, + 0.269668326f, 0.962953267f, + 0.271145160f, 0.962538468f, + 0.272621355f, 0.962121404f, + 0.274096910f, 0.961702077f, + 0.275571819f, 0.961280486f, + 0.277046080f, 0.960856633f, + 0.278519689f, 0.960430519f, + 0.279992643f, 0.960002146f, + 0.281464938f, 0.959571513f, + 0.282936570f, 0.959138622f, + 0.284407537f, 0.958703475f, + 0.285877835f, 0.958266071f, + 0.287347460f, 0.957826413f, + 0.288816408f, 0.957384501f, + 0.290284677f, 0.956940336f, + 0.291752263f, 0.956493919f, + 0.293219163f, 0.956045251f, + 0.294685372f, 0.955594334f, + 0.296150888f, 0.955141168f, + 0.297615707f, 0.954685755f, + 0.299079826f, 0.954228095f, + 0.300543241f, 0.953768190f, + 0.302005949f, 0.953306040f, + 0.303467947f, 0.952841648f, + 0.304929230f, 0.952375013f, + 0.306389795f, 0.951906137f, + 0.307849640f, 0.951435021f, + 0.309308760f, 0.950961666f, + 0.310767153f, 0.950486074f, + 0.312224814f, 0.950008245f, + 0.313681740f, 0.949528181f, + 0.315137929f, 0.949045882f, + 0.316593376f, 0.948561350f, + 0.318048077f, 0.948074586f, + 0.319502031f, 0.947585591f, + 0.320955232f, 0.947094366f, + 0.322407679f, 0.946600913f, + 0.323859367f, 0.946105232f, + 0.325310292f, 0.945607325f, + 0.326760452f, 0.945107193f, + 0.328209844f, 0.944604837f, + 0.329658463f, 0.944100258f, + 0.331106306f, 0.943593458f, + 0.332553370f, 0.943084437f, + 0.333999651f, 0.942573198f, + 0.335445147f, 0.942059740f, + 0.336889853f, 0.941544065f, + 0.338333767f, 0.941026175f, + 0.339776884f, 0.940506071f, + 0.341219202f, 0.939983753f, + 0.342660717f, 0.939459224f, + 0.344101426f, 0.938932484f, + 0.345541325f, 0.938403534f, + 0.346980411f, 0.937872376f, + 0.348418680f, 0.937339012f, + 0.349856130f, 0.936803442f, + 0.351292756f, 0.936265667f, + 0.352728556f, 0.935725689f, + 0.354163525f, 0.935183510f, + 0.355597662f, 0.934639130f, + 0.357030961f, 0.934092550f, + 0.358463421f, 0.933543773f, + 0.359895037f, 0.932992799f, + 0.361325806f, 0.932439629f, + 0.362755724f, 0.931884266f, + 0.364184790f, 0.931326709f, + 0.365612998f, 0.930766961f, + 0.367040346f, 0.930205023f, + 0.368466830f, 0.929640896f, + 0.369892447f, 0.929074581f, + 0.371317194f, 0.928506080f, + 0.372741067f, 0.927935395f, + 0.374164063f, 0.927362526f, + 0.375586178f, 0.926787474f, + 0.377007410f, 0.926210242f, + 0.378427755f, 0.925630831f, + 0.379847209f, 0.925049241f, + 0.381265769f, 0.924465474f, + 0.382683432f, 0.923879533f, + 0.384100195f, 0.923291417f, + 0.385516054f, 0.922701128f, + 0.386931006f, 0.922108669f, + 0.388345047f, 0.921514039f, + 0.389758174f, 0.920917242f, + 0.391170384f, 0.920318277f, + 0.392581674f, 0.919717146f, + 0.393992040f, 0.919113852f, + 0.395401479f, 0.918508394f, + 0.396809987f, 0.917900776f, + 0.398217562f, 0.917290997f, + 0.399624200f, 0.916679060f, + 0.401029897f, 0.916064966f, + 0.402434651f, 0.915448716f, + 0.403838458f, 0.914830312f, + 0.405241314f, 0.914209756f, + 0.406643217f, 0.913587048f, + 0.408044163f, 0.912962190f, + 0.409444149f, 0.912335185f, + 0.410843171f, 0.911706032f, + 0.412241227f, 0.911074734f, + 0.413638312f, 0.910441292f, + 0.415034424f, 0.909805708f, + 0.416429560f, 0.909167983f, + 0.417823716f, 0.908528119f, + 0.419216888f, 0.907886116f, + 0.420609074f, 0.907241978f, + 0.422000271f, 0.906595705f, + 0.423390474f, 0.905947298f, + 0.424779681f, 0.905296759f, + 0.426167889f, 0.904644091f, + 0.427555093f, 0.903989293f, + 0.428941292f, 0.903332368f, + 0.430326481f, 0.902673318f, + 0.431710658f, 0.902012144f, + 0.433093819f, 0.901348847f, + 0.434475961f, 0.900683429f, + 0.435857080f, 0.900015892f, + 0.437237174f, 0.899346237f, + 0.438616239f, 0.898674466f, + 0.439994271f, 0.898000580f, + 0.441371269f, 0.897324581f, + 0.442747228f, 0.896646470f, + 0.444122145f, 0.895966250f, + 0.445496017f, 0.895283921f, + 0.446868840f, 0.894599486f, + 0.448240612f, 0.893912945f, + 0.449611330f, 0.893224301f, + 0.450980989f, 0.892533555f, + 0.452349587f, 0.891840709f, + 0.453717121f, 0.891145765f, + 0.455083587f, 0.890448723f, + 0.456448982f, 0.889749586f, + 0.457813304f, 0.889048356f, + 0.459176548f, 0.888345033f, + 0.460538711f, 0.887639620f, + 0.461899791f, 0.886932119f, + 0.463259784f, 0.886222530f, + 0.464618686f, 0.885510856f, + 0.465976496f, 0.884797098f, + 0.467333209f, 0.884081259f, + 0.468688822f, 0.883363339f, + 0.470043332f, 0.882643340f, + 0.471396737f, 0.881921264f, + 0.472749032f, 0.881197113f, + 0.474100215f, 0.880470889f, + 0.475450282f, 0.879742593f, + 0.476799230f, 0.879012226f, + 0.478147056f, 0.878279792f, + 0.479493758f, 0.877545290f, + 0.480839331f, 0.876808724f, + 0.482183772f, 0.876070094f, + 0.483527079f, 0.875329403f, + 0.484869248f, 0.874586652f, + 0.486210276f, 0.873841843f, + 0.487550160f, 0.873094978f, + 0.488888897f, 0.872346059f, + 0.490226483f, 0.871595087f, + 0.491562916f, 0.870842063f, + 0.492898192f, 0.870086991f, + 0.494232309f, 0.869329871f, + 0.495565262f, 0.868570706f, + 0.496897049f, 0.867809497f, + 0.498227667f, 0.867046246f, + 0.499557113f, 0.866280954f, + 0.500885383f, 0.865513624f, + 0.502212474f, 0.864744258f, + 0.503538384f, 0.863972856f, + 0.504863109f, 0.863199422f, + 0.506186645f, 0.862423956f, + 0.507508991f, 0.861646461f, + 0.508830143f, 0.860866939f, + 0.510150097f, 0.860085390f, + 0.511468850f, 0.859301818f, + 0.512786401f, 0.858516224f, + 0.514102744f, 0.857728610f, + 0.515417878f, 0.856938977f, + 0.516731799f, 0.856147328f, + 0.518044504f, 0.855353665f, + 0.519355990f, 0.854557988f, + 0.520666254f, 0.853760301f, + 0.521975293f, 0.852960605f, + 0.523283103f, 0.852158902f, + 0.524589683f, 0.851355193f, + 0.525895027f, 0.850549481f, + 0.527199135f, 0.849741768f, + 0.528502002f, 0.848932055f, + 0.529803625f, 0.848120345f, + 0.531104001f, 0.847306639f, + 0.532403128f, 0.846490939f, + 0.533701002f, 0.845673247f, + 0.534997620f, 0.844853565f, + 0.536292979f, 0.844031895f, + 0.537587076f, 0.843208240f, + 0.538879909f, 0.842382600f, + 0.540171473f, 0.841554977f, + 0.541461766f, 0.840725375f, + 0.542750785f, 0.839893794f, + 0.544038527f, 0.839060237f, + 0.545324988f, 0.838224706f, + 0.546610167f, 0.837387202f, + 0.547894059f, 0.836547727f, + 0.549176662f, 0.835706284f, + 0.550457973f, 0.834862875f, + 0.551737988f, 0.834017501f, + 0.553016706f, 0.833170165f, + 0.554294121f, 0.832320868f, + 0.555570233f, 0.831469612f, + 0.556845037f, 0.830616400f, + 0.558118531f, 0.829761234f, + 0.559390712f, 0.828904115f, + 0.560661576f, 0.828045045f, + 0.561931121f, 0.827184027f, + 0.563199344f, 0.826321063f, + 0.564466242f, 0.825456154f, + 0.565731811f, 0.824589303f, + 0.566996049f, 0.823720511f, + 0.568258953f, 0.822849781f, + 0.569520519f, 0.821977115f, + 0.570780746f, 0.821102515f, + 0.572039629f, 0.820225983f, + 0.573297167f, 0.819347520f, + 0.574553355f, 0.818467130f, + 0.575808191f, 0.817584813f, + 0.577061673f, 0.816700573f, + 0.578313796f, 0.815814411f, + 0.579564559f, 0.814926329f, + 0.580813958f, 0.814036330f, + 0.582061990f, 0.813144415f, + 0.583308653f, 0.812250587f, + 0.584553943f, 0.811354847f, + 0.585797857f, 0.810457198f, + 0.587040394f, 0.809557642f, + 0.588281548f, 0.808656182f, + 0.589521319f, 0.807752818f, + 0.590759702f, 0.806847554f, + 0.591996695f, 0.805940391f, + 0.593232295f, 0.805031331f, + 0.594466499f, 0.804120377f, + 0.595699304f, 0.803207531f, + 0.596930708f, 0.802292796f, + 0.598160707f, 0.801376172f, + 0.599389298f, 0.800457662f, + 0.600616479f, 0.799537269f, + 0.601842247f, 0.798614995f, + 0.603066599f, 0.797690841f, + 0.604289531f, 0.796764810f, + 0.605511041f, 0.795836905f, + 0.606731127f, 0.794907126f, + 0.607949785f, 0.793975478f, + 0.609167012f, 0.793041960f, + 0.610382806f, 0.792106577f, + 0.611597164f, 0.791169330f, + 0.612810082f, 0.790230221f, + 0.614021559f, 0.789289253f, + 0.615231591f, 0.788346428f, + 0.616440175f, 0.787401747f, + 0.617647308f, 0.786455214f, + 0.618852988f, 0.785506830f, + 0.620057212f, 0.784556597f, + 0.621259977f, 0.783604519f, + 0.622461279f, 0.782650596f, + 0.623661118f, 0.781694832f, + 0.624859488f, 0.780737229f, + 0.626056388f, 0.779777788f, + 0.627251815f, 0.778816512f, + 0.628445767f, 0.777853404f, + 0.629638239f, 0.776888466f, + 0.630829230f, 0.775921699f, + 0.632018736f, 0.774953107f, + 0.633206755f, 0.773982691f, + 0.634393284f, 0.773010453f, + 0.635578320f, 0.772036397f, + 0.636761861f, 0.771060524f, + 0.637943904f, 0.770082837f, + 0.639124445f, 0.769103338f, + 0.640303482f, 0.768122029f, + 0.641481013f, 0.767138912f, + 0.642657034f, 0.766153990f, + 0.643831543f, 0.765167266f, + 0.645004537f, 0.764178741f, + 0.646176013f, 0.763188417f, + 0.647345969f, 0.762196298f, + 0.648514401f, 0.761202385f, + 0.649681307f, 0.760206682f, + 0.650846685f, 0.759209189f, + 0.652010531f, 0.758209910f, + 0.653172843f, 0.757208847f, + 0.654333618f, 0.756206001f, + 0.655492853f, 0.755201377f, + 0.656650546f, 0.754194975f, + 0.657806693f, 0.753186799f, + 0.658961293f, 0.752176850f, + 0.660114342f, 0.751165132f, + 0.661265838f, 0.750151646f, + 0.662415778f, 0.749136395f, + 0.663564159f, 0.748119380f, + 0.664710978f, 0.747100606f, + 0.665856234f, 0.746080074f, + 0.666999922f, 0.745057785f, + 0.668142041f, 0.744033744f, + 0.669282588f, 0.743007952f, + 0.670421560f, 0.741980412f, + 0.671558955f, 0.740951125f, + 0.672694769f, 0.739920095f, + 0.673829000f, 0.738887324f, + 0.674961646f, 0.737852815f, + 0.676092704f, 0.736816569f, + 0.677222170f, 0.735778589f, + 0.678350043f, 0.734738878f, + 0.679476320f, 0.733697438f, + 0.680600998f, 0.732654272f, + 0.681724074f, 0.731609381f, + 0.682845546f, 0.730562769f, + 0.683965412f, 0.729514438f, + 0.685083668f, 0.728464390f, + 0.686200312f, 0.727412629f, + 0.687315341f, 0.726359155f, + 0.688428753f, 0.725303972f, + 0.689540545f, 0.724247083f, + 0.690650714f, 0.723188489f, + 0.691759258f, 0.722128194f, + 0.692866175f, 0.721066199f, + 0.693971461f, 0.720002508f, + 0.695075114f, 0.718937122f, + 0.696177131f, 0.717870045f, + 0.697277511f, 0.716801279f, + 0.698376249f, 0.715730825f, + 0.699473345f, 0.714658688f, + 0.700568794f, 0.713584869f, + 0.701662595f, 0.712509371f, + 0.702754744f, 0.711432196f, + 0.703845241f, 0.710353347f, + 0.704934080f, 0.709272826f, + 0.706021261f, 0.708190637f, + 0.707106781f, 0.707106781f, + 0.708190637f, 0.706021261f, + 0.709272826f, 0.704934080f, + 0.710353347f, 0.703845241f, + 0.711432196f, 0.702754744f, + 0.712509371f, 0.701662595f, + 0.713584869f, 0.700568794f, + 0.714658688f, 0.699473345f, + 0.715730825f, 0.698376249f, + 0.716801279f, 0.697277511f, + 0.717870045f, 0.696177131f, + 0.718937122f, 0.695075114f, + 0.720002508f, 0.693971461f, + 0.721066199f, 0.692866175f, + 0.722128194f, 0.691759258f, + 0.723188489f, 0.690650714f, + 0.724247083f, 0.689540545f, + 0.725303972f, 0.688428753f, + 0.726359155f, 0.687315341f, + 0.727412629f, 0.686200312f, + 0.728464390f, 0.685083668f, + 0.729514438f, 0.683965412f, + 0.730562769f, 0.682845546f, + 0.731609381f, 0.681724074f, + 0.732654272f, 0.680600998f, + 0.733697438f, 0.679476320f, + 0.734738878f, 0.678350043f, + 0.735778589f, 0.677222170f, + 0.736816569f, 0.676092704f, + 0.737852815f, 0.674961646f, + 0.738887324f, 0.673829000f, + 0.739920095f, 0.672694769f, + 0.740951125f, 0.671558955f, + 0.741980412f, 0.670421560f, + 0.743007952f, 0.669282588f, + 0.744033744f, 0.668142041f, + 0.745057785f, 0.666999922f, + 0.746080074f, 0.665856234f, + 0.747100606f, 0.664710978f, + 0.748119380f, 0.663564159f, + 0.749136395f, 0.662415778f, + 0.750151646f, 0.661265838f, + 0.751165132f, 0.660114342f, + 0.752176850f, 0.658961293f, + 0.753186799f, 0.657806693f, + 0.754194975f, 0.656650546f, + 0.755201377f, 0.655492853f, + 0.756206001f, 0.654333618f, + 0.757208847f, 0.653172843f, + 0.758209910f, 0.652010531f, + 0.759209189f, 0.650846685f, + 0.760206682f, 0.649681307f, + 0.761202385f, 0.648514401f, + 0.762196298f, 0.647345969f, + 0.763188417f, 0.646176013f, + 0.764178741f, 0.645004537f, + 0.765167266f, 0.643831543f, + 0.766153990f, 0.642657034f, + 0.767138912f, 0.641481013f, + 0.768122029f, 0.640303482f, + 0.769103338f, 0.639124445f, + 0.770082837f, 0.637943904f, + 0.771060524f, 0.636761861f, + 0.772036397f, 0.635578320f, + 0.773010453f, 0.634393284f, + 0.773982691f, 0.633206755f, + 0.774953107f, 0.632018736f, + 0.775921699f, 0.630829230f, + 0.776888466f, 0.629638239f, + 0.777853404f, 0.628445767f, + 0.778816512f, 0.627251815f, + 0.779777788f, 0.626056388f, + 0.780737229f, 0.624859488f, + 0.781694832f, 0.623661118f, + 0.782650596f, 0.622461279f, + 0.783604519f, 0.621259977f, + 0.784556597f, 0.620057212f, + 0.785506830f, 0.618852988f, + 0.786455214f, 0.617647308f, + 0.787401747f, 0.616440175f, + 0.788346428f, 0.615231591f, + 0.789289253f, 0.614021559f, + 0.790230221f, 0.612810082f, + 0.791169330f, 0.611597164f, + 0.792106577f, 0.610382806f, + 0.793041960f, 0.609167012f, + 0.793975478f, 0.607949785f, + 0.794907126f, 0.606731127f, + 0.795836905f, 0.605511041f, + 0.796764810f, 0.604289531f, + 0.797690841f, 0.603066599f, + 0.798614995f, 0.601842247f, + 0.799537269f, 0.600616479f, + 0.800457662f, 0.599389298f, + 0.801376172f, 0.598160707f, + 0.802292796f, 0.596930708f, + 0.803207531f, 0.595699304f, + 0.804120377f, 0.594466499f, + 0.805031331f, 0.593232295f, + 0.805940391f, 0.591996695f, + 0.806847554f, 0.590759702f, + 0.807752818f, 0.589521319f, + 0.808656182f, 0.588281548f, + 0.809557642f, 0.587040394f, + 0.810457198f, 0.585797857f, + 0.811354847f, 0.584553943f, + 0.812250587f, 0.583308653f, + 0.813144415f, 0.582061990f, + 0.814036330f, 0.580813958f, + 0.814926329f, 0.579564559f, + 0.815814411f, 0.578313796f, + 0.816700573f, 0.577061673f, + 0.817584813f, 0.575808191f, + 0.818467130f, 0.574553355f, + 0.819347520f, 0.573297167f, + 0.820225983f, 0.572039629f, + 0.821102515f, 0.570780746f, + 0.821977115f, 0.569520519f, + 0.822849781f, 0.568258953f, + 0.823720511f, 0.566996049f, + 0.824589303f, 0.565731811f, + 0.825456154f, 0.564466242f, + 0.826321063f, 0.563199344f, + 0.827184027f, 0.561931121f, + 0.828045045f, 0.560661576f, + 0.828904115f, 0.559390712f, + 0.829761234f, 0.558118531f, + 0.830616400f, 0.556845037f, + 0.831469612f, 0.555570233f, + 0.832320868f, 0.554294121f, + 0.833170165f, 0.553016706f, + 0.834017501f, 0.551737988f, + 0.834862875f, 0.550457973f, + 0.835706284f, 0.549176662f, + 0.836547727f, 0.547894059f, + 0.837387202f, 0.546610167f, + 0.838224706f, 0.545324988f, + 0.839060237f, 0.544038527f, + 0.839893794f, 0.542750785f, + 0.840725375f, 0.541461766f, + 0.841554977f, 0.540171473f, + 0.842382600f, 0.538879909f, + 0.843208240f, 0.537587076f, + 0.844031895f, 0.536292979f, + 0.844853565f, 0.534997620f, + 0.845673247f, 0.533701002f, + 0.846490939f, 0.532403128f, + 0.847306639f, 0.531104001f, + 0.848120345f, 0.529803625f, + 0.848932055f, 0.528502002f, + 0.849741768f, 0.527199135f, + 0.850549481f, 0.525895027f, + 0.851355193f, 0.524589683f, + 0.852158902f, 0.523283103f, + 0.852960605f, 0.521975293f, + 0.853760301f, 0.520666254f, + 0.854557988f, 0.519355990f, + 0.855353665f, 0.518044504f, + 0.856147328f, 0.516731799f, + 0.856938977f, 0.515417878f, + 0.857728610f, 0.514102744f, + 0.858516224f, 0.512786401f, + 0.859301818f, 0.511468850f, + 0.860085390f, 0.510150097f, + 0.860866939f, 0.508830143f, + 0.861646461f, 0.507508991f, + 0.862423956f, 0.506186645f, + 0.863199422f, 0.504863109f, + 0.863972856f, 0.503538384f, + 0.864744258f, 0.502212474f, + 0.865513624f, 0.500885383f, + 0.866280954f, 0.499557113f, + 0.867046246f, 0.498227667f, + 0.867809497f, 0.496897049f, + 0.868570706f, 0.495565262f, + 0.869329871f, 0.494232309f, + 0.870086991f, 0.492898192f, + 0.870842063f, 0.491562916f, + 0.871595087f, 0.490226483f, + 0.872346059f, 0.488888897f, + 0.873094978f, 0.487550160f, + 0.873841843f, 0.486210276f, + 0.874586652f, 0.484869248f, + 0.875329403f, 0.483527079f, + 0.876070094f, 0.482183772f, + 0.876808724f, 0.480839331f, + 0.877545290f, 0.479493758f, + 0.878279792f, 0.478147056f, + 0.879012226f, 0.476799230f, + 0.879742593f, 0.475450282f, + 0.880470889f, 0.474100215f, + 0.881197113f, 0.472749032f, + 0.881921264f, 0.471396737f, + 0.882643340f, 0.470043332f, + 0.883363339f, 0.468688822f, + 0.884081259f, 0.467333209f, + 0.884797098f, 0.465976496f, + 0.885510856f, 0.464618686f, + 0.886222530f, 0.463259784f, + 0.886932119f, 0.461899791f, + 0.887639620f, 0.460538711f, + 0.888345033f, 0.459176548f, + 0.889048356f, 0.457813304f, + 0.889749586f, 0.456448982f, + 0.890448723f, 0.455083587f, + 0.891145765f, 0.453717121f, + 0.891840709f, 0.452349587f, + 0.892533555f, 0.450980989f, + 0.893224301f, 0.449611330f, + 0.893912945f, 0.448240612f, + 0.894599486f, 0.446868840f, + 0.895283921f, 0.445496017f, + 0.895966250f, 0.444122145f, + 0.896646470f, 0.442747228f, + 0.897324581f, 0.441371269f, + 0.898000580f, 0.439994271f, + 0.898674466f, 0.438616239f, + 0.899346237f, 0.437237174f, + 0.900015892f, 0.435857080f, + 0.900683429f, 0.434475961f, + 0.901348847f, 0.433093819f, + 0.902012144f, 0.431710658f, + 0.902673318f, 0.430326481f, + 0.903332368f, 0.428941292f, + 0.903989293f, 0.427555093f, + 0.904644091f, 0.426167889f, + 0.905296759f, 0.424779681f, + 0.905947298f, 0.423390474f, + 0.906595705f, 0.422000271f, + 0.907241978f, 0.420609074f, + 0.907886116f, 0.419216888f, + 0.908528119f, 0.417823716f, + 0.909167983f, 0.416429560f, + 0.909805708f, 0.415034424f, + 0.910441292f, 0.413638312f, + 0.911074734f, 0.412241227f, + 0.911706032f, 0.410843171f, + 0.912335185f, 0.409444149f, + 0.912962190f, 0.408044163f, + 0.913587048f, 0.406643217f, + 0.914209756f, 0.405241314f, + 0.914830312f, 0.403838458f, + 0.915448716f, 0.402434651f, + 0.916064966f, 0.401029897f, + 0.916679060f, 0.399624200f, + 0.917290997f, 0.398217562f, + 0.917900776f, 0.396809987f, + 0.918508394f, 0.395401479f, + 0.919113852f, 0.393992040f, + 0.919717146f, 0.392581674f, + 0.920318277f, 0.391170384f, + 0.920917242f, 0.389758174f, + 0.921514039f, 0.388345047f, + 0.922108669f, 0.386931006f, + 0.922701128f, 0.385516054f, + 0.923291417f, 0.384100195f, + 0.923879533f, 0.382683432f, + 0.924465474f, 0.381265769f, + 0.925049241f, 0.379847209f, + 0.925630831f, 0.378427755f, + 0.926210242f, 0.377007410f, + 0.926787474f, 0.375586178f, + 0.927362526f, 0.374164063f, + 0.927935395f, 0.372741067f, + 0.928506080f, 0.371317194f, + 0.929074581f, 0.369892447f, + 0.929640896f, 0.368466830f, + 0.930205023f, 0.367040346f, + 0.930766961f, 0.365612998f, + 0.931326709f, 0.364184790f, + 0.931884266f, 0.362755724f, + 0.932439629f, 0.361325806f, + 0.932992799f, 0.359895037f, + 0.933543773f, 0.358463421f, + 0.934092550f, 0.357030961f, + 0.934639130f, 0.355597662f, + 0.935183510f, 0.354163525f, + 0.935725689f, 0.352728556f, + 0.936265667f, 0.351292756f, + 0.936803442f, 0.349856130f, + 0.937339012f, 0.348418680f, + 0.937872376f, 0.346980411f, + 0.938403534f, 0.345541325f, + 0.938932484f, 0.344101426f, + 0.939459224f, 0.342660717f, + 0.939983753f, 0.341219202f, + 0.940506071f, 0.339776884f, + 0.941026175f, 0.338333767f, + 0.941544065f, 0.336889853f, + 0.942059740f, 0.335445147f, + 0.942573198f, 0.333999651f, + 0.943084437f, 0.332553370f, + 0.943593458f, 0.331106306f, + 0.944100258f, 0.329658463f, + 0.944604837f, 0.328209844f, + 0.945107193f, 0.326760452f, + 0.945607325f, 0.325310292f, + 0.946105232f, 0.323859367f, + 0.946600913f, 0.322407679f, + 0.947094366f, 0.320955232f, + 0.947585591f, 0.319502031f, + 0.948074586f, 0.318048077f, + 0.948561350f, 0.316593376f, + 0.949045882f, 0.315137929f, + 0.949528181f, 0.313681740f, + 0.950008245f, 0.312224814f, + 0.950486074f, 0.310767153f, + 0.950961666f, 0.309308760f, + 0.951435021f, 0.307849640f, + 0.951906137f, 0.306389795f, + 0.952375013f, 0.304929230f, + 0.952841648f, 0.303467947f, + 0.953306040f, 0.302005949f, + 0.953768190f, 0.300543241f, + 0.954228095f, 0.299079826f, + 0.954685755f, 0.297615707f, + 0.955141168f, 0.296150888f, + 0.955594334f, 0.294685372f, + 0.956045251f, 0.293219163f, + 0.956493919f, 0.291752263f, + 0.956940336f, 0.290284677f, + 0.957384501f, 0.288816408f, + 0.957826413f, 0.287347460f, + 0.958266071f, 0.285877835f, + 0.958703475f, 0.284407537f, + 0.959138622f, 0.282936570f, + 0.959571513f, 0.281464938f, + 0.960002146f, 0.279992643f, + 0.960430519f, 0.278519689f, + 0.960856633f, 0.277046080f, + 0.961280486f, 0.275571819f, + 0.961702077f, 0.274096910f, + 0.962121404f, 0.272621355f, + 0.962538468f, 0.271145160f, + 0.962953267f, 0.269668326f, + 0.963365800f, 0.268190857f, + 0.963776066f, 0.266712757f, + 0.964184064f, 0.265234030f, + 0.964589793f, 0.263754679f, + 0.964993253f, 0.262274707f, + 0.965394442f, 0.260794118f, + 0.965793359f, 0.259312915f, + 0.966190003f, 0.257831102f, + 0.966584374f, 0.256348682f, + 0.966976471f, 0.254865660f, + 0.967366292f, 0.253382037f, + 0.967753837f, 0.251897818f, + 0.968139105f, 0.250413007f, + 0.968522094f, 0.248927606f, + 0.968902805f, 0.247441619f, + 0.969281235f, 0.245955050f, + 0.969657385f, 0.244467903f, + 0.970031253f, 0.242980180f, + 0.970402839f, 0.241491885f, + 0.970772141f, 0.240003022f, + 0.971139158f, 0.238513595f, + 0.971503891f, 0.237023606f, + 0.971866337f, 0.235533059f, + 0.972226497f, 0.234041959f, + 0.972584369f, 0.232550307f, + 0.972939952f, 0.231058108f, + 0.973293246f, 0.229565366f, + 0.973644250f, 0.228072083f, + 0.973992962f, 0.226578264f, + 0.974339383f, 0.225083911f, + 0.974683511f, 0.223589029f, + 0.975025345f, 0.222093621f, + 0.975364885f, 0.220597690f, + 0.975702130f, 0.219101240f, + 0.976037079f, 0.217604275f, + 0.976369731f, 0.216106797f, + 0.976700086f, 0.214608811f, + 0.977028143f, 0.213110320f, + 0.977353900f, 0.211611327f, + 0.977677358f, 0.210111837f, + 0.977998515f, 0.208611852f, + 0.978317371f, 0.207111376f, + 0.978633924f, 0.205610413f, + 0.978948175f, 0.204108966f, + 0.979260123f, 0.202607039f, + 0.979569766f, 0.201104635f, + 0.979877104f, 0.199601758f, + 0.980182136f, 0.198098411f, + 0.980484862f, 0.196594598f, + 0.980785280f, 0.195090322f, + 0.981083391f, 0.193585587f, + 0.981379193f, 0.192080397f, + 0.981672686f, 0.190574755f, + 0.981963869f, 0.189068664f, + 0.982252741f, 0.187562129f, + 0.982539302f, 0.186055152f, + 0.982823551f, 0.184547737f, + 0.983105487f, 0.183039888f, + 0.983385110f, 0.181531608f, + 0.983662419f, 0.180022901f, + 0.983937413f, 0.178513771f, + 0.984210092f, 0.177004220f, + 0.984480455f, 0.175494253f, + 0.984748502f, 0.173983873f, + 0.985014231f, 0.172473084f, + 0.985277642f, 0.170961889f, + 0.985538735f, 0.169450291f, + 0.985797509f, 0.167938295f, + 0.986053963f, 0.166425904f, + 0.986308097f, 0.164913120f, + 0.986559910f, 0.163399949f, + 0.986809402f, 0.161886394f, + 0.987056571f, 0.160372457f, + 0.987301418f, 0.158858143f, + 0.987543942f, 0.157343456f, + 0.987784142f, 0.155828398f, + 0.988022017f, 0.154312973f, + 0.988257568f, 0.152797185f, + 0.988490793f, 0.151281038f, + 0.988721692f, 0.149764535f, + 0.988950265f, 0.148247679f, + 0.989176510f, 0.146730474f, + 0.989400428f, 0.145212925f, + 0.989622017f, 0.143695033f, + 0.989841278f, 0.142176804f, + 0.990058210f, 0.140658239f, + 0.990272812f, 0.139139344f, + 0.990485084f, 0.137620122f, + 0.990695025f, 0.136100575f, + 0.990902635f, 0.134580709f, + 0.991107914f, 0.133060525f, + 0.991310860f, 0.131540029f, + 0.991511473f, 0.130019223f, + 0.991709754f, 0.128498111f, + 0.991905700f, 0.126976696f, + 0.992099313f, 0.125454983f, + 0.992290591f, 0.123932975f, + 0.992479535f, 0.122410675f, + 0.992666142f, 0.120888087f, + 0.992850414f, 0.119365215f, + 0.993032350f, 0.117842062f, + 0.993211949f, 0.116318631f, + 0.993389211f, 0.114794927f, + 0.993564136f, 0.113270952f, + 0.993736722f, 0.111746711f, + 0.993906970f, 0.110222207f, + 0.994074879f, 0.108697444f, + 0.994240449f, 0.107172425f, + 0.994403680f, 0.105647154f, + 0.994564571f, 0.104121634f, + 0.994723121f, 0.102595869f, + 0.994879331f, 0.101069863f, + 0.995033199f, 0.099543619f, + 0.995184727f, 0.098017140f, + 0.995333912f, 0.096490431f, + 0.995480755f, 0.094963495f, + 0.995625256f, 0.093436336f, + 0.995767414f, 0.091908956f, + 0.995907229f, 0.090381361f, + 0.996044701f, 0.088853553f, + 0.996179829f, 0.087325535f, + 0.996312612f, 0.085797312f, + 0.996443051f, 0.084268888f, + 0.996571146f, 0.082740265f, + 0.996696895f, 0.081211447f, + 0.996820299f, 0.079682438f, + 0.996941358f, 0.078153242f, + 0.997060070f, 0.076623861f, + 0.997176437f, 0.075094301f, + 0.997290457f, 0.073564564f, + 0.997402130f, 0.072034653f, + 0.997511456f, 0.070504573f, + 0.997618435f, 0.068974328f, + 0.997723067f, 0.067443920f, + 0.997825350f, 0.065913353f, + 0.997925286f, 0.064382631f, + 0.998022874f, 0.062851758f, + 0.998118113f, 0.061320736f, + 0.998211003f, 0.059789571f, + 0.998301545f, 0.058258265f, + 0.998389737f, 0.056726821f, + 0.998475581f, 0.055195244f, + 0.998559074f, 0.053663538f, + 0.998640218f, 0.052131705f, + 0.998719012f, 0.050599749f, + 0.998795456f, 0.049067674f, + 0.998869550f, 0.047535484f, + 0.998941293f, 0.046003182f, + 0.999010686f, 0.044470772f, + 0.999077728f, 0.042938257f, + 0.999142419f, 0.041405641f, + 0.999204759f, 0.039872928f, + 0.999264747f, 0.038340120f, + 0.999322385f, 0.036807223f, + 0.999377670f, 0.035274239f, + 0.999430605f, 0.033741172f, + 0.999481187f, 0.032208025f, + 0.999529418f, 0.030674803f, + 0.999575296f, 0.029141509f, + 0.999618822f, 0.027608146f, + 0.999659997f, 0.026074718f, + 0.999698819f, 0.024541229f, + 0.999735288f, 0.023007681f, + 0.999769405f, 0.021474080f, + 0.999801170f, 0.019940429f, + 0.999830582f, 0.018406730f, + 0.999857641f, 0.016872988f, + 0.999882347f, 0.015339206f, + 0.999904701f, 0.013805389f, + 0.999924702f, 0.012271538f, + 0.999942350f, 0.010737659f, + 0.999957645f, 0.009203755f, + 0.999970586f, 0.007669829f, + 0.999981175f, 0.006135885f, + 0.999989411f, 0.004601926f, + 0.999995294f, 0.003067957f, + 0.999998823f, 0.001533980f, + 1.000000000f, 0.000000000f, + 0.999998823f, -0.001533980f, + 0.999995294f, -0.003067957f, + 0.999989411f, -0.004601926f, + 0.999981175f, -0.006135885f, + 0.999970586f, -0.007669829f, + 0.999957645f, -0.009203755f, + 0.999942350f, -0.010737659f, + 0.999924702f, -0.012271538f, + 0.999904701f, -0.013805389f, + 0.999882347f, -0.015339206f, + 0.999857641f, -0.016872988f, + 0.999830582f, -0.018406730f, + 0.999801170f, -0.019940429f, + 0.999769405f, -0.021474080f, + 0.999735288f, -0.023007681f, + 0.999698819f, -0.024541229f, + 0.999659997f, -0.026074718f, + 0.999618822f, -0.027608146f, + 0.999575296f, -0.029141509f, + 0.999529418f, -0.030674803f, + 0.999481187f, -0.032208025f, + 0.999430605f, -0.033741172f, + 0.999377670f, -0.035274239f, + 0.999322385f, -0.036807223f, + 0.999264747f, -0.038340120f, + 0.999204759f, -0.039872928f, + 0.999142419f, -0.041405641f, + 0.999077728f, -0.042938257f, + 0.999010686f, -0.044470772f, + 0.998941293f, -0.046003182f, + 0.998869550f, -0.047535484f, + 0.998795456f, -0.049067674f, + 0.998719012f, -0.050599749f, + 0.998640218f, -0.052131705f, + 0.998559074f, -0.053663538f, + 0.998475581f, -0.055195244f, + 0.998389737f, -0.056726821f, + 0.998301545f, -0.058258265f, + 0.998211003f, -0.059789571f, + 0.998118113f, -0.061320736f, + 0.998022874f, -0.062851758f, + 0.997925286f, -0.064382631f, + 0.997825350f, -0.065913353f, + 0.997723067f, -0.067443920f, + 0.997618435f, -0.068974328f, + 0.997511456f, -0.070504573f, + 0.997402130f, -0.072034653f, + 0.997290457f, -0.073564564f, + 0.997176437f, -0.075094301f, + 0.997060070f, -0.076623861f, + 0.996941358f, -0.078153242f, + 0.996820299f, -0.079682438f, + 0.996696895f, -0.081211447f, + 0.996571146f, -0.082740265f, + 0.996443051f, -0.084268888f, + 0.996312612f, -0.085797312f, + 0.996179829f, -0.087325535f, + 0.996044701f, -0.088853553f, + 0.995907229f, -0.090381361f, + 0.995767414f, -0.091908956f, + 0.995625256f, -0.093436336f, + 0.995480755f, -0.094963495f, + 0.995333912f, -0.096490431f, + 0.995184727f, -0.098017140f, + 0.995033199f, -0.099543619f, + 0.994879331f, -0.101069863f, + 0.994723121f, -0.102595869f, + 0.994564571f, -0.104121634f, + 0.994403680f, -0.105647154f, + 0.994240449f, -0.107172425f, + 0.994074879f, -0.108697444f, + 0.993906970f, -0.110222207f, + 0.993736722f, -0.111746711f, + 0.993564136f, -0.113270952f, + 0.993389211f, -0.114794927f, + 0.993211949f, -0.116318631f, + 0.993032350f, -0.117842062f, + 0.992850414f, -0.119365215f, + 0.992666142f, -0.120888087f, + 0.992479535f, -0.122410675f, + 0.992290591f, -0.123932975f, + 0.992099313f, -0.125454983f, + 0.991905700f, -0.126976696f, + 0.991709754f, -0.128498111f, + 0.991511473f, -0.130019223f, + 0.991310860f, -0.131540029f, + 0.991107914f, -0.133060525f, + 0.990902635f, -0.134580709f, + 0.990695025f, -0.136100575f, + 0.990485084f, -0.137620122f, + 0.990272812f, -0.139139344f, + 0.990058210f, -0.140658239f, + 0.989841278f, -0.142176804f, + 0.989622017f, -0.143695033f, + 0.989400428f, -0.145212925f, + 0.989176510f, -0.146730474f, + 0.988950265f, -0.148247679f, + 0.988721692f, -0.149764535f, + 0.988490793f, -0.151281038f, + 0.988257568f, -0.152797185f, + 0.988022017f, -0.154312973f, + 0.987784142f, -0.155828398f, + 0.987543942f, -0.157343456f, + 0.987301418f, -0.158858143f, + 0.987056571f, -0.160372457f, + 0.986809402f, -0.161886394f, + 0.986559910f, -0.163399949f, + 0.986308097f, -0.164913120f, + 0.986053963f, -0.166425904f, + 0.985797509f, -0.167938295f, + 0.985538735f, -0.169450291f, + 0.985277642f, -0.170961889f, + 0.985014231f, -0.172473084f, + 0.984748502f, -0.173983873f, + 0.984480455f, -0.175494253f, + 0.984210092f, -0.177004220f, + 0.983937413f, -0.178513771f, + 0.983662419f, -0.180022901f, + 0.983385110f, -0.181531608f, + 0.983105487f, -0.183039888f, + 0.982823551f, -0.184547737f, + 0.982539302f, -0.186055152f, + 0.982252741f, -0.187562129f, + 0.981963869f, -0.189068664f, + 0.981672686f, -0.190574755f, + 0.981379193f, -0.192080397f, + 0.981083391f, -0.193585587f, + 0.980785280f, -0.195090322f, + 0.980484862f, -0.196594598f, + 0.980182136f, -0.198098411f, + 0.979877104f, -0.199601758f, + 0.979569766f, -0.201104635f, + 0.979260123f, -0.202607039f, + 0.978948175f, -0.204108966f, + 0.978633924f, -0.205610413f, + 0.978317371f, -0.207111376f, + 0.977998515f, -0.208611852f, + 0.977677358f, -0.210111837f, + 0.977353900f, -0.211611327f, + 0.977028143f, -0.213110320f, + 0.976700086f, -0.214608811f, + 0.976369731f, -0.216106797f, + 0.976037079f, -0.217604275f, + 0.975702130f, -0.219101240f, + 0.975364885f, -0.220597690f, + 0.975025345f, -0.222093621f, + 0.974683511f, -0.223589029f, + 0.974339383f, -0.225083911f, + 0.973992962f, -0.226578264f, + 0.973644250f, -0.228072083f, + 0.973293246f, -0.229565366f, + 0.972939952f, -0.231058108f, + 0.972584369f, -0.232550307f, + 0.972226497f, -0.234041959f, + 0.971866337f, -0.235533059f, + 0.971503891f, -0.237023606f, + 0.971139158f, -0.238513595f, + 0.970772141f, -0.240003022f, + 0.970402839f, -0.241491885f, + 0.970031253f, -0.242980180f, + 0.969657385f, -0.244467903f, + 0.969281235f, -0.245955050f, + 0.968902805f, -0.247441619f, + 0.968522094f, -0.248927606f, + 0.968139105f, -0.250413007f, + 0.967753837f, -0.251897818f, + 0.967366292f, -0.253382037f, + 0.966976471f, -0.254865660f, + 0.966584374f, -0.256348682f, + 0.966190003f, -0.257831102f, + 0.965793359f, -0.259312915f, + 0.965394442f, -0.260794118f, + 0.964993253f, -0.262274707f, + 0.964589793f, -0.263754679f, + 0.964184064f, -0.265234030f, + 0.963776066f, -0.266712757f, + 0.963365800f, -0.268190857f, + 0.962953267f, -0.269668326f, + 0.962538468f, -0.271145160f, + 0.962121404f, -0.272621355f, + 0.961702077f, -0.274096910f, + 0.961280486f, -0.275571819f, + 0.960856633f, -0.277046080f, + 0.960430519f, -0.278519689f, + 0.960002146f, -0.279992643f, + 0.959571513f, -0.281464938f, + 0.959138622f, -0.282936570f, + 0.958703475f, -0.284407537f, + 0.958266071f, -0.285877835f, + 0.957826413f, -0.287347460f, + 0.957384501f, -0.288816408f, + 0.956940336f, -0.290284677f, + 0.956493919f, -0.291752263f, + 0.956045251f, -0.293219163f, + 0.955594334f, -0.294685372f, + 0.955141168f, -0.296150888f, + 0.954685755f, -0.297615707f, + 0.954228095f, -0.299079826f, + 0.953768190f, -0.300543241f, + 0.953306040f, -0.302005949f, + 0.952841648f, -0.303467947f, + 0.952375013f, -0.304929230f, + 0.951906137f, -0.306389795f, + 0.951435021f, -0.307849640f, + 0.950961666f, -0.309308760f, + 0.950486074f, -0.310767153f, + 0.950008245f, -0.312224814f, + 0.949528181f, -0.313681740f, + 0.949045882f, -0.315137929f, + 0.948561350f, -0.316593376f, + 0.948074586f, -0.318048077f, + 0.947585591f, -0.319502031f, + 0.947094366f, -0.320955232f, + 0.946600913f, -0.322407679f, + 0.946105232f, -0.323859367f, + 0.945607325f, -0.325310292f, + 0.945107193f, -0.326760452f, + 0.944604837f, -0.328209844f, + 0.944100258f, -0.329658463f, + 0.943593458f, -0.331106306f, + 0.943084437f, -0.332553370f, + 0.942573198f, -0.333999651f, + 0.942059740f, -0.335445147f, + 0.941544065f, -0.336889853f, + 0.941026175f, -0.338333767f, + 0.940506071f, -0.339776884f, + 0.939983753f, -0.341219202f, + 0.939459224f, -0.342660717f, + 0.938932484f, -0.344101426f, + 0.938403534f, -0.345541325f, + 0.937872376f, -0.346980411f, + 0.937339012f, -0.348418680f, + 0.936803442f, -0.349856130f, + 0.936265667f, -0.351292756f, + 0.935725689f, -0.352728556f, + 0.935183510f, -0.354163525f, + 0.934639130f, -0.355597662f, + 0.934092550f, -0.357030961f, + 0.933543773f, -0.358463421f, + 0.932992799f, -0.359895037f, + 0.932439629f, -0.361325806f, + 0.931884266f, -0.362755724f, + 0.931326709f, -0.364184790f, + 0.930766961f, -0.365612998f, + 0.930205023f, -0.367040346f, + 0.929640896f, -0.368466830f, + 0.929074581f, -0.369892447f, + 0.928506080f, -0.371317194f, + 0.927935395f, -0.372741067f, + 0.927362526f, -0.374164063f, + 0.926787474f, -0.375586178f, + 0.926210242f, -0.377007410f, + 0.925630831f, -0.378427755f, + 0.925049241f, -0.379847209f, + 0.924465474f, -0.381265769f, + 0.923879533f, -0.382683432f, + 0.923291417f, -0.384100195f, + 0.922701128f, -0.385516054f, + 0.922108669f, -0.386931006f, + 0.921514039f, -0.388345047f, + 0.920917242f, -0.389758174f, + 0.920318277f, -0.391170384f, + 0.919717146f, -0.392581674f, + 0.919113852f, -0.393992040f, + 0.918508394f, -0.395401479f, + 0.917900776f, -0.396809987f, + 0.917290997f, -0.398217562f, + 0.916679060f, -0.399624200f, + 0.916064966f, -0.401029897f, + 0.915448716f, -0.402434651f, + 0.914830312f, -0.403838458f, + 0.914209756f, -0.405241314f, + 0.913587048f, -0.406643217f, + 0.912962190f, -0.408044163f, + 0.912335185f, -0.409444149f, + 0.911706032f, -0.410843171f, + 0.911074734f, -0.412241227f, + 0.910441292f, -0.413638312f, + 0.909805708f, -0.415034424f, + 0.909167983f, -0.416429560f, + 0.908528119f, -0.417823716f, + 0.907886116f, -0.419216888f, + 0.907241978f, -0.420609074f, + 0.906595705f, -0.422000271f, + 0.905947298f, -0.423390474f, + 0.905296759f, -0.424779681f, + 0.904644091f, -0.426167889f, + 0.903989293f, -0.427555093f, + 0.903332368f, -0.428941292f, + 0.902673318f, -0.430326481f, + 0.902012144f, -0.431710658f, + 0.901348847f, -0.433093819f, + 0.900683429f, -0.434475961f, + 0.900015892f, -0.435857080f, + 0.899346237f, -0.437237174f, + 0.898674466f, -0.438616239f, + 0.898000580f, -0.439994271f, + 0.897324581f, -0.441371269f, + 0.896646470f, -0.442747228f, + 0.895966250f, -0.444122145f, + 0.895283921f, -0.445496017f, + 0.894599486f, -0.446868840f, + 0.893912945f, -0.448240612f, + 0.893224301f, -0.449611330f, + 0.892533555f, -0.450980989f, + 0.891840709f, -0.452349587f, + 0.891145765f, -0.453717121f, + 0.890448723f, -0.455083587f, + 0.889749586f, -0.456448982f, + 0.889048356f, -0.457813304f, + 0.888345033f, -0.459176548f, + 0.887639620f, -0.460538711f, + 0.886932119f, -0.461899791f, + 0.886222530f, -0.463259784f, + 0.885510856f, -0.464618686f, + 0.884797098f, -0.465976496f, + 0.884081259f, -0.467333209f, + 0.883363339f, -0.468688822f, + 0.882643340f, -0.470043332f, + 0.881921264f, -0.471396737f, + 0.881197113f, -0.472749032f, + 0.880470889f, -0.474100215f, + 0.879742593f, -0.475450282f, + 0.879012226f, -0.476799230f, + 0.878279792f, -0.478147056f, + 0.877545290f, -0.479493758f, + 0.876808724f, -0.480839331f, + 0.876070094f, -0.482183772f, + 0.875329403f, -0.483527079f, + 0.874586652f, -0.484869248f, + 0.873841843f, -0.486210276f, + 0.873094978f, -0.487550160f, + 0.872346059f, -0.488888897f, + 0.871595087f, -0.490226483f, + 0.870842063f, -0.491562916f, + 0.870086991f, -0.492898192f, + 0.869329871f, -0.494232309f, + 0.868570706f, -0.495565262f, + 0.867809497f, -0.496897049f, + 0.867046246f, -0.498227667f, + 0.866280954f, -0.499557113f, + 0.865513624f, -0.500885383f, + 0.864744258f, -0.502212474f, + 0.863972856f, -0.503538384f, + 0.863199422f, -0.504863109f, + 0.862423956f, -0.506186645f, + 0.861646461f, -0.507508991f, + 0.860866939f, -0.508830143f, + 0.860085390f, -0.510150097f, + 0.859301818f, -0.511468850f, + 0.858516224f, -0.512786401f, + 0.857728610f, -0.514102744f, + 0.856938977f, -0.515417878f, + 0.856147328f, -0.516731799f, + 0.855353665f, -0.518044504f, + 0.854557988f, -0.519355990f, + 0.853760301f, -0.520666254f, + 0.852960605f, -0.521975293f, + 0.852158902f, -0.523283103f, + 0.851355193f, -0.524589683f, + 0.850549481f, -0.525895027f, + 0.849741768f, -0.527199135f, + 0.848932055f, -0.528502002f, + 0.848120345f, -0.529803625f, + 0.847306639f, -0.531104001f, + 0.846490939f, -0.532403128f, + 0.845673247f, -0.533701002f, + 0.844853565f, -0.534997620f, + 0.844031895f, -0.536292979f, + 0.843208240f, -0.537587076f, + 0.842382600f, -0.538879909f, + 0.841554977f, -0.540171473f, + 0.840725375f, -0.541461766f, + 0.839893794f, -0.542750785f, + 0.839060237f, -0.544038527f, + 0.838224706f, -0.545324988f, + 0.837387202f, -0.546610167f, + 0.836547727f, -0.547894059f, + 0.835706284f, -0.549176662f, + 0.834862875f, -0.550457973f, + 0.834017501f, -0.551737988f, + 0.833170165f, -0.553016706f, + 0.832320868f, -0.554294121f, + 0.831469612f, -0.555570233f, + 0.830616400f, -0.556845037f, + 0.829761234f, -0.558118531f, + 0.828904115f, -0.559390712f, + 0.828045045f, -0.560661576f, + 0.827184027f, -0.561931121f, + 0.826321063f, -0.563199344f, + 0.825456154f, -0.564466242f, + 0.824589303f, -0.565731811f, + 0.823720511f, -0.566996049f, + 0.822849781f, -0.568258953f, + 0.821977115f, -0.569520519f, + 0.821102515f, -0.570780746f, + 0.820225983f, -0.572039629f, + 0.819347520f, -0.573297167f, + 0.818467130f, -0.574553355f, + 0.817584813f, -0.575808191f, + 0.816700573f, -0.577061673f, + 0.815814411f, -0.578313796f, + 0.814926329f, -0.579564559f, + 0.814036330f, -0.580813958f, + 0.813144415f, -0.582061990f, + 0.812250587f, -0.583308653f, + 0.811354847f, -0.584553943f, + 0.810457198f, -0.585797857f, + 0.809557642f, -0.587040394f, + 0.808656182f, -0.588281548f, + 0.807752818f, -0.589521319f, + 0.806847554f, -0.590759702f, + 0.805940391f, -0.591996695f, + 0.805031331f, -0.593232295f, + 0.804120377f, -0.594466499f, + 0.803207531f, -0.595699304f, + 0.802292796f, -0.596930708f, + 0.801376172f, -0.598160707f, + 0.800457662f, -0.599389298f, + 0.799537269f, -0.600616479f, + 0.798614995f, -0.601842247f, + 0.797690841f, -0.603066599f, + 0.796764810f, -0.604289531f, + 0.795836905f, -0.605511041f, + 0.794907126f, -0.606731127f, + 0.793975478f, -0.607949785f, + 0.793041960f, -0.609167012f, + 0.792106577f, -0.610382806f, + 0.791169330f, -0.611597164f, + 0.790230221f, -0.612810082f, + 0.789289253f, -0.614021559f, + 0.788346428f, -0.615231591f, + 0.787401747f, -0.616440175f, + 0.786455214f, -0.617647308f, + 0.785506830f, -0.618852988f, + 0.784556597f, -0.620057212f, + 0.783604519f, -0.621259977f, + 0.782650596f, -0.622461279f, + 0.781694832f, -0.623661118f, + 0.780737229f, -0.624859488f, + 0.779777788f, -0.626056388f, + 0.778816512f, -0.627251815f, + 0.777853404f, -0.628445767f, + 0.776888466f, -0.629638239f, + 0.775921699f, -0.630829230f, + 0.774953107f, -0.632018736f, + 0.773982691f, -0.633206755f, + 0.773010453f, -0.634393284f, + 0.772036397f, -0.635578320f, + 0.771060524f, -0.636761861f, + 0.770082837f, -0.637943904f, + 0.769103338f, -0.639124445f, + 0.768122029f, -0.640303482f, + 0.767138912f, -0.641481013f, + 0.766153990f, -0.642657034f, + 0.765167266f, -0.643831543f, + 0.764178741f, -0.645004537f, + 0.763188417f, -0.646176013f, + 0.762196298f, -0.647345969f, + 0.761202385f, -0.648514401f, + 0.760206682f, -0.649681307f, + 0.759209189f, -0.650846685f, + 0.758209910f, -0.652010531f, + 0.757208847f, -0.653172843f, + 0.756206001f, -0.654333618f, + 0.755201377f, -0.655492853f, + 0.754194975f, -0.656650546f, + 0.753186799f, -0.657806693f, + 0.752176850f, -0.658961293f, + 0.751165132f, -0.660114342f, + 0.750151646f, -0.661265838f, + 0.749136395f, -0.662415778f, + 0.748119380f, -0.663564159f, + 0.747100606f, -0.664710978f, + 0.746080074f, -0.665856234f, + 0.745057785f, -0.666999922f, + 0.744033744f, -0.668142041f, + 0.743007952f, -0.669282588f, + 0.741980412f, -0.670421560f, + 0.740951125f, -0.671558955f, + 0.739920095f, -0.672694769f, + 0.738887324f, -0.673829000f, + 0.737852815f, -0.674961646f, + 0.736816569f, -0.676092704f, + 0.735778589f, -0.677222170f, + 0.734738878f, -0.678350043f, + 0.733697438f, -0.679476320f, + 0.732654272f, -0.680600998f, + 0.731609381f, -0.681724074f, + 0.730562769f, -0.682845546f, + 0.729514438f, -0.683965412f, + 0.728464390f, -0.685083668f, + 0.727412629f, -0.686200312f, + 0.726359155f, -0.687315341f, + 0.725303972f, -0.688428753f, + 0.724247083f, -0.689540545f, + 0.723188489f, -0.690650714f, + 0.722128194f, -0.691759258f, + 0.721066199f, -0.692866175f, + 0.720002508f, -0.693971461f, + 0.718937122f, -0.695075114f, + 0.717870045f, -0.696177131f, + 0.716801279f, -0.697277511f, + 0.715730825f, -0.698376249f, + 0.714658688f, -0.699473345f, + 0.713584869f, -0.700568794f, + 0.712509371f, -0.701662595f, + 0.711432196f, -0.702754744f, + 0.710353347f, -0.703845241f, + 0.709272826f, -0.704934080f, + 0.708190637f, -0.706021261f, + 0.707106781f, -0.707106781f, + 0.706021261f, -0.708190637f, + 0.704934080f, -0.709272826f, + 0.703845241f, -0.710353347f, + 0.702754744f, -0.711432196f, + 0.701662595f, -0.712509371f, + 0.700568794f, -0.713584869f, + 0.699473345f, -0.714658688f, + 0.698376249f, -0.715730825f, + 0.697277511f, -0.716801279f, + 0.696177131f, -0.717870045f, + 0.695075114f, -0.718937122f, + 0.693971461f, -0.720002508f, + 0.692866175f, -0.721066199f, + 0.691759258f, -0.722128194f, + 0.690650714f, -0.723188489f, + 0.689540545f, -0.724247083f, + 0.688428753f, -0.725303972f, + 0.687315341f, -0.726359155f, + 0.686200312f, -0.727412629f, + 0.685083668f, -0.728464390f, + 0.683965412f, -0.729514438f, + 0.682845546f, -0.730562769f, + 0.681724074f, -0.731609381f, + 0.680600998f, -0.732654272f, + 0.679476320f, -0.733697438f, + 0.678350043f, -0.734738878f, + 0.677222170f, -0.735778589f, + 0.676092704f, -0.736816569f, + 0.674961646f, -0.737852815f, + 0.673829000f, -0.738887324f, + 0.672694769f, -0.739920095f, + 0.671558955f, -0.740951125f, + 0.670421560f, -0.741980412f, + 0.669282588f, -0.743007952f, + 0.668142041f, -0.744033744f, + 0.666999922f, -0.745057785f, + 0.665856234f, -0.746080074f, + 0.664710978f, -0.747100606f, + 0.663564159f, -0.748119380f, + 0.662415778f, -0.749136395f, + 0.661265838f, -0.750151646f, + 0.660114342f, -0.751165132f, + 0.658961293f, -0.752176850f, + 0.657806693f, -0.753186799f, + 0.656650546f, -0.754194975f, + 0.655492853f, -0.755201377f, + 0.654333618f, -0.756206001f, + 0.653172843f, -0.757208847f, + 0.652010531f, -0.758209910f, + 0.650846685f, -0.759209189f, + 0.649681307f, -0.760206682f, + 0.648514401f, -0.761202385f, + 0.647345969f, -0.762196298f, + 0.646176013f, -0.763188417f, + 0.645004537f, -0.764178741f, + 0.643831543f, -0.765167266f, + 0.642657034f, -0.766153990f, + 0.641481013f, -0.767138912f, + 0.640303482f, -0.768122029f, + 0.639124445f, -0.769103338f, + 0.637943904f, -0.770082837f, + 0.636761861f, -0.771060524f, + 0.635578320f, -0.772036397f, + 0.634393284f, -0.773010453f, + 0.633206755f, -0.773982691f, + 0.632018736f, -0.774953107f, + 0.630829230f, -0.775921699f, + 0.629638239f, -0.776888466f, + 0.628445767f, -0.777853404f, + 0.627251815f, -0.778816512f, + 0.626056388f, -0.779777788f, + 0.624859488f, -0.780737229f, + 0.623661118f, -0.781694832f, + 0.622461279f, -0.782650596f, + 0.621259977f, -0.783604519f, + 0.620057212f, -0.784556597f, + 0.618852988f, -0.785506830f, + 0.617647308f, -0.786455214f, + 0.616440175f, -0.787401747f, + 0.615231591f, -0.788346428f, + 0.614021559f, -0.789289253f, + 0.612810082f, -0.790230221f, + 0.611597164f, -0.791169330f, + 0.610382806f, -0.792106577f, + 0.609167012f, -0.793041960f, + 0.607949785f, -0.793975478f, + 0.606731127f, -0.794907126f, + 0.605511041f, -0.795836905f, + 0.604289531f, -0.796764810f, + 0.603066599f, -0.797690841f, + 0.601842247f, -0.798614995f, + 0.600616479f, -0.799537269f, + 0.599389298f, -0.800457662f, + 0.598160707f, -0.801376172f, + 0.596930708f, -0.802292796f, + 0.595699304f, -0.803207531f, + 0.594466499f, -0.804120377f, + 0.593232295f, -0.805031331f, + 0.591996695f, -0.805940391f, + 0.590759702f, -0.806847554f, + 0.589521319f, -0.807752818f, + 0.588281548f, -0.808656182f, + 0.587040394f, -0.809557642f, + 0.585797857f, -0.810457198f, + 0.584553943f, -0.811354847f, + 0.583308653f, -0.812250587f, + 0.582061990f, -0.813144415f, + 0.580813958f, -0.814036330f, + 0.579564559f, -0.814926329f, + 0.578313796f, -0.815814411f, + 0.577061673f, -0.816700573f, + 0.575808191f, -0.817584813f, + 0.574553355f, -0.818467130f, + 0.573297167f, -0.819347520f, + 0.572039629f, -0.820225983f, + 0.570780746f, -0.821102515f, + 0.569520519f, -0.821977115f, + 0.568258953f, -0.822849781f, + 0.566996049f, -0.823720511f, + 0.565731811f, -0.824589303f, + 0.564466242f, -0.825456154f, + 0.563199344f, -0.826321063f, + 0.561931121f, -0.827184027f, + 0.560661576f, -0.828045045f, + 0.559390712f, -0.828904115f, + 0.558118531f, -0.829761234f, + 0.556845037f, -0.830616400f, + 0.555570233f, -0.831469612f, + 0.554294121f, -0.832320868f, + 0.553016706f, -0.833170165f, + 0.551737988f, -0.834017501f, + 0.550457973f, -0.834862875f, + 0.549176662f, -0.835706284f, + 0.547894059f, -0.836547727f, + 0.546610167f, -0.837387202f, + 0.545324988f, -0.838224706f, + 0.544038527f, -0.839060237f, + 0.542750785f, -0.839893794f, + 0.541461766f, -0.840725375f, + 0.540171473f, -0.841554977f, + 0.538879909f, -0.842382600f, + 0.537587076f, -0.843208240f, + 0.536292979f, -0.844031895f, + 0.534997620f, -0.844853565f, + 0.533701002f, -0.845673247f, + 0.532403128f, -0.846490939f, + 0.531104001f, -0.847306639f, + 0.529803625f, -0.848120345f, + 0.528502002f, -0.848932055f, + 0.527199135f, -0.849741768f, + 0.525895027f, -0.850549481f, + 0.524589683f, -0.851355193f, + 0.523283103f, -0.852158902f, + 0.521975293f, -0.852960605f, + 0.520666254f, -0.853760301f, + 0.519355990f, -0.854557988f, + 0.518044504f, -0.855353665f, + 0.516731799f, -0.856147328f, + 0.515417878f, -0.856938977f, + 0.514102744f, -0.857728610f, + 0.512786401f, -0.858516224f, + 0.511468850f, -0.859301818f, + 0.510150097f, -0.860085390f, + 0.508830143f, -0.860866939f, + 0.507508991f, -0.861646461f, + 0.506186645f, -0.862423956f, + 0.504863109f, -0.863199422f, + 0.503538384f, -0.863972856f, + 0.502212474f, -0.864744258f, + 0.500885383f, -0.865513624f, + 0.499557113f, -0.866280954f, + 0.498227667f, -0.867046246f, + 0.496897049f, -0.867809497f, + 0.495565262f, -0.868570706f, + 0.494232309f, -0.869329871f, + 0.492898192f, -0.870086991f, + 0.491562916f, -0.870842063f, + 0.490226483f, -0.871595087f, + 0.488888897f, -0.872346059f, + 0.487550160f, -0.873094978f, + 0.486210276f, -0.873841843f, + 0.484869248f, -0.874586652f, + 0.483527079f, -0.875329403f, + 0.482183772f, -0.876070094f, + 0.480839331f, -0.876808724f, + 0.479493758f, -0.877545290f, + 0.478147056f, -0.878279792f, + 0.476799230f, -0.879012226f, + 0.475450282f, -0.879742593f, + 0.474100215f, -0.880470889f, + 0.472749032f, -0.881197113f, + 0.471396737f, -0.881921264f, + 0.470043332f, -0.882643340f, + 0.468688822f, -0.883363339f, + 0.467333209f, -0.884081259f, + 0.465976496f, -0.884797098f, + 0.464618686f, -0.885510856f, + 0.463259784f, -0.886222530f, + 0.461899791f, -0.886932119f, + 0.460538711f, -0.887639620f, + 0.459176548f, -0.888345033f, + 0.457813304f, -0.889048356f, + 0.456448982f, -0.889749586f, + 0.455083587f, -0.890448723f, + 0.453717121f, -0.891145765f, + 0.452349587f, -0.891840709f, + 0.450980989f, -0.892533555f, + 0.449611330f, -0.893224301f, + 0.448240612f, -0.893912945f, + 0.446868840f, -0.894599486f, + 0.445496017f, -0.895283921f, + 0.444122145f, -0.895966250f, + 0.442747228f, -0.896646470f, + 0.441371269f, -0.897324581f, + 0.439994271f, -0.898000580f, + 0.438616239f, -0.898674466f, + 0.437237174f, -0.899346237f, + 0.435857080f, -0.900015892f, + 0.434475961f, -0.900683429f, + 0.433093819f, -0.901348847f, + 0.431710658f, -0.902012144f, + 0.430326481f, -0.902673318f, + 0.428941292f, -0.903332368f, + 0.427555093f, -0.903989293f, + 0.426167889f, -0.904644091f, + 0.424779681f, -0.905296759f, + 0.423390474f, -0.905947298f, + 0.422000271f, -0.906595705f, + 0.420609074f, -0.907241978f, + 0.419216888f, -0.907886116f, + 0.417823716f, -0.908528119f, + 0.416429560f, -0.909167983f, + 0.415034424f, -0.909805708f, + 0.413638312f, -0.910441292f, + 0.412241227f, -0.911074734f, + 0.410843171f, -0.911706032f, + 0.409444149f, -0.912335185f, + 0.408044163f, -0.912962190f, + 0.406643217f, -0.913587048f, + 0.405241314f, -0.914209756f, + 0.403838458f, -0.914830312f, + 0.402434651f, -0.915448716f, + 0.401029897f, -0.916064966f, + 0.399624200f, -0.916679060f, + 0.398217562f, -0.917290997f, + 0.396809987f, -0.917900776f, + 0.395401479f, -0.918508394f, + 0.393992040f, -0.919113852f, + 0.392581674f, -0.919717146f, + 0.391170384f, -0.920318277f, + 0.389758174f, -0.920917242f, + 0.388345047f, -0.921514039f, + 0.386931006f, -0.922108669f, + 0.385516054f, -0.922701128f, + 0.384100195f, -0.923291417f, + 0.382683432f, -0.923879533f, + 0.381265769f, -0.924465474f, + 0.379847209f, -0.925049241f, + 0.378427755f, -0.925630831f, + 0.377007410f, -0.926210242f, + 0.375586178f, -0.926787474f, + 0.374164063f, -0.927362526f, + 0.372741067f, -0.927935395f, + 0.371317194f, -0.928506080f, + 0.369892447f, -0.929074581f, + 0.368466830f, -0.929640896f, + 0.367040346f, -0.930205023f, + 0.365612998f, -0.930766961f, + 0.364184790f, -0.931326709f, + 0.362755724f, -0.931884266f, + 0.361325806f, -0.932439629f, + 0.359895037f, -0.932992799f, + 0.358463421f, -0.933543773f, + 0.357030961f, -0.934092550f, + 0.355597662f, -0.934639130f, + 0.354163525f, -0.935183510f, + 0.352728556f, -0.935725689f, + 0.351292756f, -0.936265667f, + 0.349856130f, -0.936803442f, + 0.348418680f, -0.937339012f, + 0.346980411f, -0.937872376f, + 0.345541325f, -0.938403534f, + 0.344101426f, -0.938932484f, + 0.342660717f, -0.939459224f, + 0.341219202f, -0.939983753f, + 0.339776884f, -0.940506071f, + 0.338333767f, -0.941026175f, + 0.336889853f, -0.941544065f, + 0.335445147f, -0.942059740f, + 0.333999651f, -0.942573198f, + 0.332553370f, -0.943084437f, + 0.331106306f, -0.943593458f, + 0.329658463f, -0.944100258f, + 0.328209844f, -0.944604837f, + 0.326760452f, -0.945107193f, + 0.325310292f, -0.945607325f, + 0.323859367f, -0.946105232f, + 0.322407679f, -0.946600913f, + 0.320955232f, -0.947094366f, + 0.319502031f, -0.947585591f, + 0.318048077f, -0.948074586f, + 0.316593376f, -0.948561350f, + 0.315137929f, -0.949045882f, + 0.313681740f, -0.949528181f, + 0.312224814f, -0.950008245f, + 0.310767153f, -0.950486074f, + 0.309308760f, -0.950961666f, + 0.307849640f, -0.951435021f, + 0.306389795f, -0.951906137f, + 0.304929230f, -0.952375013f, + 0.303467947f, -0.952841648f, + 0.302005949f, -0.953306040f, + 0.300543241f, -0.953768190f, + 0.299079826f, -0.954228095f, + 0.297615707f, -0.954685755f, + 0.296150888f, -0.955141168f, + 0.294685372f, -0.955594334f, + 0.293219163f, -0.956045251f, + 0.291752263f, -0.956493919f, + 0.290284677f, -0.956940336f, + 0.288816408f, -0.957384501f, + 0.287347460f, -0.957826413f, + 0.285877835f, -0.958266071f, + 0.284407537f, -0.958703475f, + 0.282936570f, -0.959138622f, + 0.281464938f, -0.959571513f, + 0.279992643f, -0.960002146f, + 0.278519689f, -0.960430519f, + 0.277046080f, -0.960856633f, + 0.275571819f, -0.961280486f, + 0.274096910f, -0.961702077f, + 0.272621355f, -0.962121404f, + 0.271145160f, -0.962538468f, + 0.269668326f, -0.962953267f, + 0.268190857f, -0.963365800f, + 0.266712757f, -0.963776066f, + 0.265234030f, -0.964184064f, + 0.263754679f, -0.964589793f, + 0.262274707f, -0.964993253f, + 0.260794118f, -0.965394442f, + 0.259312915f, -0.965793359f, + 0.257831102f, -0.966190003f, + 0.256348682f, -0.966584374f, + 0.254865660f, -0.966976471f, + 0.253382037f, -0.967366292f, + 0.251897818f, -0.967753837f, + 0.250413007f, -0.968139105f, + 0.248927606f, -0.968522094f, + 0.247441619f, -0.968902805f, + 0.245955050f, -0.969281235f, + 0.244467903f, -0.969657385f, + 0.242980180f, -0.970031253f, + 0.241491885f, -0.970402839f, + 0.240003022f, -0.970772141f, + 0.238513595f, -0.971139158f, + 0.237023606f, -0.971503891f, + 0.235533059f, -0.971866337f, + 0.234041959f, -0.972226497f, + 0.232550307f, -0.972584369f, + 0.231058108f, -0.972939952f, + 0.229565366f, -0.973293246f, + 0.228072083f, -0.973644250f, + 0.226578264f, -0.973992962f, + 0.225083911f, -0.974339383f, + 0.223589029f, -0.974683511f, + 0.222093621f, -0.975025345f, + 0.220597690f, -0.975364885f, + 0.219101240f, -0.975702130f, + 0.217604275f, -0.976037079f, + 0.216106797f, -0.976369731f, + 0.214608811f, -0.976700086f, + 0.213110320f, -0.977028143f, + 0.211611327f, -0.977353900f, + 0.210111837f, -0.977677358f, + 0.208611852f, -0.977998515f, + 0.207111376f, -0.978317371f, + 0.205610413f, -0.978633924f, + 0.204108966f, -0.978948175f, + 0.202607039f, -0.979260123f, + 0.201104635f, -0.979569766f, + 0.199601758f, -0.979877104f, + 0.198098411f, -0.980182136f, + 0.196594598f, -0.980484862f, + 0.195090322f, -0.980785280f, + 0.193585587f, -0.981083391f, + 0.192080397f, -0.981379193f, + 0.190574755f, -0.981672686f, + 0.189068664f, -0.981963869f, + 0.187562129f, -0.982252741f, + 0.186055152f, -0.982539302f, + 0.184547737f, -0.982823551f, + 0.183039888f, -0.983105487f, + 0.181531608f, -0.983385110f, + 0.180022901f, -0.983662419f, + 0.178513771f, -0.983937413f, + 0.177004220f, -0.984210092f, + 0.175494253f, -0.984480455f, + 0.173983873f, -0.984748502f, + 0.172473084f, -0.985014231f, + 0.170961889f, -0.985277642f, + 0.169450291f, -0.985538735f, + 0.167938295f, -0.985797509f, + 0.166425904f, -0.986053963f, + 0.164913120f, -0.986308097f, + 0.163399949f, -0.986559910f, + 0.161886394f, -0.986809402f, + 0.160372457f, -0.987056571f, + 0.158858143f, -0.987301418f, + 0.157343456f, -0.987543942f, + 0.155828398f, -0.987784142f, + 0.154312973f, -0.988022017f, + 0.152797185f, -0.988257568f, + 0.151281038f, -0.988490793f, + 0.149764535f, -0.988721692f, + 0.148247679f, -0.988950265f, + 0.146730474f, -0.989176510f, + 0.145212925f, -0.989400428f, + 0.143695033f, -0.989622017f, + 0.142176804f, -0.989841278f, + 0.140658239f, -0.990058210f, + 0.139139344f, -0.990272812f, + 0.137620122f, -0.990485084f, + 0.136100575f, -0.990695025f, + 0.134580709f, -0.990902635f, + 0.133060525f, -0.991107914f, + 0.131540029f, -0.991310860f, + 0.130019223f, -0.991511473f, + 0.128498111f, -0.991709754f, + 0.126976696f, -0.991905700f, + 0.125454983f, -0.992099313f, + 0.123932975f, -0.992290591f, + 0.122410675f, -0.992479535f, + 0.120888087f, -0.992666142f, + 0.119365215f, -0.992850414f, + 0.117842062f, -0.993032350f, + 0.116318631f, -0.993211949f, + 0.114794927f, -0.993389211f, + 0.113270952f, -0.993564136f, + 0.111746711f, -0.993736722f, + 0.110222207f, -0.993906970f, + 0.108697444f, -0.994074879f, + 0.107172425f, -0.994240449f, + 0.105647154f, -0.994403680f, + 0.104121634f, -0.994564571f, + 0.102595869f, -0.994723121f, + 0.101069863f, -0.994879331f, + 0.099543619f, -0.995033199f, + 0.098017140f, -0.995184727f, + 0.096490431f, -0.995333912f, + 0.094963495f, -0.995480755f, + 0.093436336f, -0.995625256f, + 0.091908956f, -0.995767414f, + 0.090381361f, -0.995907229f, + 0.088853553f, -0.996044701f, + 0.087325535f, -0.996179829f, + 0.085797312f, -0.996312612f, + 0.084268888f, -0.996443051f, + 0.082740265f, -0.996571146f, + 0.081211447f, -0.996696895f, + 0.079682438f, -0.996820299f, + 0.078153242f, -0.996941358f, + 0.076623861f, -0.997060070f, + 0.075094301f, -0.997176437f, + 0.073564564f, -0.997290457f, + 0.072034653f, -0.997402130f, + 0.070504573f, -0.997511456f, + 0.068974328f, -0.997618435f, + 0.067443920f, -0.997723067f, + 0.065913353f, -0.997825350f, + 0.064382631f, -0.997925286f, + 0.062851758f, -0.998022874f, + 0.061320736f, -0.998118113f, + 0.059789571f, -0.998211003f, + 0.058258265f, -0.998301545f, + 0.056726821f, -0.998389737f, + 0.055195244f, -0.998475581f, + 0.053663538f, -0.998559074f, + 0.052131705f, -0.998640218f, + 0.050599749f, -0.998719012f, + 0.049067674f, -0.998795456f, + 0.047535484f, -0.998869550f, + 0.046003182f, -0.998941293f, + 0.044470772f, -0.999010686f, + 0.042938257f, -0.999077728f, + 0.041405641f, -0.999142419f, + 0.039872928f, -0.999204759f, + 0.038340120f, -0.999264747f, + 0.036807223f, -0.999322385f, + 0.035274239f, -0.999377670f, + 0.033741172f, -0.999430605f, + 0.032208025f, -0.999481187f, + 0.030674803f, -0.999529418f, + 0.029141509f, -0.999575296f, + 0.027608146f, -0.999618822f, + 0.026074718f, -0.999659997f, + 0.024541229f, -0.999698819f, + 0.023007681f, -0.999735288f, + 0.021474080f, -0.999769405f, + 0.019940429f, -0.999801170f, + 0.018406730f, -0.999830582f, + 0.016872988f, -0.999857641f, + 0.015339206f, -0.999882347f, + 0.013805389f, -0.999904701f, + 0.012271538f, -0.999924702f, + 0.010737659f, -0.999942350f, + 0.009203755f, -0.999957645f, + 0.007669829f, -0.999970586f, + 0.006135885f, -0.999981175f, + 0.004601926f, -0.999989411f, + 0.003067957f, -0.999995294f, + 0.001533980f, -0.999998823f +}; + + +/** + * \par + * Example code for the generation of the floating-point sine table: + *
+ * tableSize = 512;
+ * for(n = 0; n < (tableSize + 1); n++)
+ * {
+ *	sinTable[n]=sin(2*pi*n/tableSize);
+ * }
+ * \par + * where pi value is 3.14159265358979 + */ + +const float32_t sinTable_f32[FAST_MATH_TABLE_SIZE + 1] = { + 0.00000000f, 0.01227154f, 0.02454123f, 0.03680722f, 0.04906767f, 0.06132074f, + 0.07356456f, 0.08579731f, 0.09801714f, 0.11022221f, 0.12241068f, 0.13458071f, + 0.14673047f, 0.15885814f, 0.17096189f, 0.18303989f, 0.19509032f, 0.20711138f, + 0.21910124f, 0.23105811f, 0.24298018f, 0.25486566f, 0.26671276f, 0.27851969f, + 0.29028468f, 0.30200595f, 0.31368174f, 0.32531029f, 0.33688985f, 0.34841868f, + 0.35989504f, 0.37131719f, 0.38268343f, 0.39399204f, 0.40524131f, 0.41642956f, + 0.42755509f, 0.43861624f, 0.44961133f, 0.46053871f, 0.47139674f, 0.48218377f, + 0.49289819f, 0.50353838f, 0.51410274f, 0.52458968f, 0.53499762f, 0.54532499f, + 0.55557023f, 0.56573181f, 0.57580819f, 0.58579786f, 0.59569930f, 0.60551104f, + 0.61523159f, 0.62485949f, 0.63439328f, 0.64383154f, 0.65317284f, 0.66241578f, + 0.67155895f, 0.68060100f, 0.68954054f, 0.69837625f, 0.70710678f, 0.71573083f, + 0.72424708f, 0.73265427f, 0.74095113f, 0.74913639f, 0.75720885f, 0.76516727f, + 0.77301045f, 0.78073723f, 0.78834643f, 0.79583690f, 0.80320753f, 0.81045720f, + 0.81758481f, 0.82458930f, 0.83146961f, 0.83822471f, 0.84485357f, 0.85135519f, + 0.85772861f, 0.86397286f, 0.87008699f, 0.87607009f, 0.88192126f, 0.88763962f, + 0.89322430f, 0.89867447f, 0.90398929f, 0.90916798f, 0.91420976f, 0.91911385f, + 0.92387953f, 0.92850608f, 0.93299280f, 0.93733901f, 0.94154407f, 0.94560733f, + 0.94952818f, 0.95330604f, 0.95694034f, 0.96043052f, 0.96377607f, 0.96697647f, + 0.97003125f, 0.97293995f, 0.97570213f, 0.97831737f, 0.98078528f, 0.98310549f, + 0.98527764f, 0.98730142f, 0.98917651f, 0.99090264f, 0.99247953f, 0.99390697f, + 0.99518473f, 0.99631261f, 0.99729046f, 0.99811811f, 0.99879546f, 0.99932238f, + 0.99969882f, 0.99992470f, 1.00000000f, 0.99992470f, 0.99969882f, 0.99932238f, + 0.99879546f, 0.99811811f, 0.99729046f, 0.99631261f, 0.99518473f, 0.99390697f, + 0.99247953f, 0.99090264f, 0.98917651f, 0.98730142f, 0.98527764f, 0.98310549f, + 0.98078528f, 0.97831737f, 0.97570213f, 0.97293995f, 0.97003125f, 0.96697647f, + 0.96377607f, 0.96043052f, 0.95694034f, 0.95330604f, 0.94952818f, 0.94560733f, + 0.94154407f, 0.93733901f, 0.93299280f, 0.92850608f, 0.92387953f, 0.91911385f, + 0.91420976f, 0.90916798f, 0.90398929f, 0.89867447f, 0.89322430f, 0.88763962f, + 0.88192126f, 0.87607009f, 0.87008699f, 0.86397286f, 0.85772861f, 0.85135519f, + 0.84485357f, 0.83822471f, 0.83146961f, 0.82458930f, 0.81758481f, 0.81045720f, + 0.80320753f, 0.79583690f, 0.78834643f, 0.78073723f, 0.77301045f, 0.76516727f, + 0.75720885f, 0.74913639f, 0.74095113f, 0.73265427f, 0.72424708f, 0.71573083f, + 0.70710678f, 0.69837625f, 0.68954054f, 0.68060100f, 0.67155895f, 0.66241578f, + 0.65317284f, 0.64383154f, 0.63439328f, 0.62485949f, 0.61523159f, 0.60551104f, + 0.59569930f, 0.58579786f, 0.57580819f, 0.56573181f, 0.55557023f, 0.54532499f, + 0.53499762f, 0.52458968f, 0.51410274f, 0.50353838f, 0.49289819f, 0.48218377f, + 0.47139674f, 0.46053871f, 0.44961133f, 0.43861624f, 0.42755509f, 0.41642956f, + 0.40524131f, 0.39399204f, 0.38268343f, 0.37131719f, 0.35989504f, 0.34841868f, + 0.33688985f, 0.32531029f, 0.31368174f, 0.30200595f, 0.29028468f, 0.27851969f, + 0.26671276f, 0.25486566f, 0.24298018f, 0.23105811f, 0.21910124f, 0.20711138f, + 0.19509032f, 0.18303989f, 0.17096189f, 0.15885814f, 0.14673047f, 0.13458071f, + 0.12241068f, 0.11022221f, 0.09801714f, 0.08579731f, 0.07356456f, 0.06132074f, + 0.04906767f, 0.03680722f, 0.02454123f, 0.01227154f, 0.00000000f, -0.01227154f, + -0.02454123f, -0.03680722f, -0.04906767f, -0.06132074f, -0.07356456f, + -0.08579731f, -0.09801714f, -0.11022221f, -0.12241068f, -0.13458071f, + -0.14673047f, -0.15885814f, -0.17096189f, -0.18303989f, -0.19509032f, + -0.20711138f, -0.21910124f, -0.23105811f, -0.24298018f, -0.25486566f, + -0.26671276f, -0.27851969f, -0.29028468f, -0.30200595f, -0.31368174f, + -0.32531029f, -0.33688985f, -0.34841868f, -0.35989504f, -0.37131719f, + -0.38268343f, -0.39399204f, -0.40524131f, -0.41642956f, -0.42755509f, + -0.43861624f, -0.44961133f, -0.46053871f, -0.47139674f, -0.48218377f, + -0.49289819f, -0.50353838f, -0.51410274f, -0.52458968f, -0.53499762f, + -0.54532499f, -0.55557023f, -0.56573181f, -0.57580819f, -0.58579786f, + -0.59569930f, -0.60551104f, -0.61523159f, -0.62485949f, -0.63439328f, + -0.64383154f, -0.65317284f, -0.66241578f, -0.67155895f, -0.68060100f, + -0.68954054f, -0.69837625f, -0.70710678f, -0.71573083f, -0.72424708f, + -0.73265427f, -0.74095113f, -0.74913639f, -0.75720885f, -0.76516727f, + -0.77301045f, -0.78073723f, -0.78834643f, -0.79583690f, -0.80320753f, + -0.81045720f, -0.81758481f, -0.82458930f, -0.83146961f, -0.83822471f, + -0.84485357f, -0.85135519f, -0.85772861f, -0.86397286f, -0.87008699f, + -0.87607009f, -0.88192126f, -0.88763962f, -0.89322430f, -0.89867447f, + -0.90398929f, -0.90916798f, -0.91420976f, -0.91911385f, -0.92387953f, + -0.92850608f, -0.93299280f, -0.93733901f, -0.94154407f, -0.94560733f, + -0.94952818f, -0.95330604f, -0.95694034f, -0.96043052f, -0.96377607f, + -0.96697647f, -0.97003125f, -0.97293995f, -0.97570213f, -0.97831737f, + -0.98078528f, -0.98310549f, -0.98527764f, -0.98730142f, -0.98917651f, + -0.99090264f, -0.99247953f, -0.99390697f, -0.99518473f, -0.99631261f, + -0.99729046f, -0.99811811f, -0.99879546f, -0.99932238f, -0.99969882f, + -0.99992470f, -1.00000000f, -0.99992470f, -0.99969882f, -0.99932238f, + -0.99879546f, -0.99811811f, -0.99729046f, -0.99631261f, -0.99518473f, + -0.99390697f, -0.99247953f, -0.99090264f, -0.98917651f, -0.98730142f, + -0.98527764f, -0.98310549f, -0.98078528f, -0.97831737f, -0.97570213f, + -0.97293995f, -0.97003125f, -0.96697647f, -0.96377607f, -0.96043052f, + -0.95694034f, -0.95330604f, -0.94952818f, -0.94560733f, -0.94154407f, + -0.93733901f, -0.93299280f, -0.92850608f, -0.92387953f, -0.91911385f, + -0.91420976f, -0.90916798f, -0.90398929f, -0.89867447f, -0.89322430f, + -0.88763962f, -0.88192126f, -0.87607009f, -0.87008699f, -0.86397286f, + -0.85772861f, -0.85135519f, -0.84485357f, -0.83822471f, -0.83146961f, + -0.82458930f, -0.81758481f, -0.81045720f, -0.80320753f, -0.79583690f, + -0.78834643f, -0.78073723f, -0.77301045f, -0.76516727f, -0.75720885f, + -0.74913639f, -0.74095113f, -0.73265427f, -0.72424708f, -0.71573083f, + -0.70710678f, -0.69837625f, -0.68954054f, -0.68060100f, -0.67155895f, + -0.66241578f, -0.65317284f, -0.64383154f, -0.63439328f, -0.62485949f, + -0.61523159f, -0.60551104f, -0.59569930f, -0.58579786f, -0.57580819f, + -0.56573181f, -0.55557023f, -0.54532499f, -0.53499762f, -0.52458968f, + -0.51410274f, -0.50353838f, -0.49289819f, -0.48218377f, -0.47139674f, + -0.46053871f, -0.44961133f, -0.43861624f, -0.42755509f, -0.41642956f, + -0.40524131f, -0.39399204f, -0.38268343f, -0.37131719f, -0.35989504f, + -0.34841868f, -0.33688985f, -0.32531029f, -0.31368174f, -0.30200595f, + -0.29028468f, -0.27851969f, -0.26671276f, -0.25486566f, -0.24298018f, + -0.23105811f, -0.21910124f, -0.20711138f, -0.19509032f, -0.18303989f, + -0.17096189f, -0.15885814f, -0.14673047f, -0.13458071f, -0.12241068f, + -0.11022221f, -0.09801714f, -0.08579731f, -0.07356456f, -0.06132074f, + -0.04906767f, -0.03680722f, -0.02454123f, -0.01227154f, -0.00000000f +}; + +/** + * \par + * Table values are in Q31 (1.31 fixed-point format) and generation is done in + * three steps. First, generate sin values in floating point: + *
+ * tableSize = 512;
+ * for(n = 0; n < (tableSize + 1); n++)
+ * {
+ *	sinTable[n]= sin(2*pi*n/tableSize);
+ * } 
+ * where pi value is 3.14159265358979 + * \par + * Second, convert floating-point to Q31 (Fixed point): + * (sinTable[i] * pow(2, 31)) + * \par + * Finally, round to the nearest integer value: + * sinTable[i] += (sinTable[i] > 0 ? 0.5 :-0.5); + */ +const q31_t sinTable_q31[FAST_MATH_TABLE_SIZE + 1] = { + 0L, 26352928L, 52701887L, 79042909L, 105372028L, 131685278L, 157978697L, + 184248325L, 210490206L, 236700388L, 262874923L, 289009871L, 315101295L, + 341145265L, 367137861L, 393075166L, 418953276L, 444768294L, 470516330L, + 496193509L, 521795963L, 547319836L, 572761285L, 598116479L, 623381598L, + 648552838L, 673626408L, 698598533L, 723465451L, 748223418L, 772868706L, + 797397602L, 821806413L, 846091463L, 870249095L, 894275671L, 918167572L, + 941921200L, 965532978L, 988999351L, 1012316784L, 1035481766L, 1058490808L, + 1081340445L, 1104027237L, 1126547765L, 1148898640L, 1171076495L, 1193077991L, + 1214899813L, 1236538675L, 1257991320L, 1279254516L, 1300325060L, 1321199781L, + 1341875533L, 1362349204L, 1382617710L, 1402678000L, 1422527051L, 1442161874L, + 1461579514L, 1480777044L, 1499751576L, 1518500250L, 1537020244L, 1555308768L, + 1573363068L, 1591180426L, 1608758157L, 1626093616L, 1643184191L, 1660027308L, + 1676620432L, 1692961062L, 1709046739L, 1724875040L, 1740443581L, 1755750017L, + 1770792044L, 1785567396L, 1800073849L, 1814309216L, 1828271356L, 1841958164L, + 1855367581L, 1868497586L, 1881346202L, 1893911494L, 1906191570L, 1918184581L, + 1929888720L, 1941302225L, 1952423377L, 1963250501L, 1973781967L, 1984016189L, + 1993951625L, 2003586779L, 2012920201L, 2021950484L, 2030676269L, 2039096241L, + 2047209133L, 2055013723L, 2062508835L, 2069693342L, 2076566160L, 2083126254L, + 2089372638L, 2095304370L, 2100920556L, 2106220352L, 2111202959L, 2115867626L, + 2120213651L, 2124240380L, 2127947206L, 2131333572L, 2134398966L, 2137142927L, + 2139565043L, 2141664948L, 2143442326L, 2144896910L, 2146028480L, 2146836866L, + 2147321946L, 2147483647L, 2147321946L, 2146836866L, 2146028480L, 2144896910L, + 2143442326L, 2141664948L, 2139565043L, 2137142927L, 2134398966L, 2131333572L, + 2127947206L, 2124240380L, 2120213651L, 2115867626L, 2111202959L, 2106220352L, + 2100920556L, 2095304370L, 2089372638L, 2083126254L, 2076566160L, 2069693342L, + 2062508835L, 2055013723L, 2047209133L, 2039096241L, 2030676269L, 2021950484L, + 2012920201L, 2003586779L, 1993951625L, 1984016189L, 1973781967L, 1963250501L, + 1952423377L, 1941302225L, 1929888720L, 1918184581L, 1906191570L, 1893911494L, + 1881346202L, 1868497586L, 1855367581L, 1841958164L, 1828271356L, 1814309216L, + 1800073849L, 1785567396L, 1770792044L, 1755750017L, 1740443581L, 1724875040L, + 1709046739L, 1692961062L, 1676620432L, 1660027308L, 1643184191L, 1626093616L, + 1608758157L, 1591180426L, 1573363068L, 1555308768L, 1537020244L, 1518500250L, + 1499751576L, 1480777044L, 1461579514L, 1442161874L, 1422527051L, 1402678000L, + 1382617710L, 1362349204L, 1341875533L, 1321199781L, 1300325060L, 1279254516L, + 1257991320L, 1236538675L, 1214899813L, 1193077991L, 1171076495L, 1148898640L, + 1126547765L, 1104027237L, 1081340445L, 1058490808L, 1035481766L, 1012316784L, + 988999351L, 965532978L, 941921200L, 918167572L, 894275671L, 870249095L, + 846091463L, 821806413L, 797397602L, 772868706L, 748223418L, 723465451L, + 698598533L, 673626408L, 648552838L, 623381598L, 598116479L, 572761285L, + 547319836L, 521795963L, 496193509L, 470516330L, 444768294L, 418953276L, + 393075166L, 367137861L, 341145265L, 315101295L, 289009871L, 262874923L, + 236700388L, 210490206L, 184248325L, 157978697L, 131685278L, 105372028L, + 79042909L, 52701887L, 26352928L, 0L, -26352928L, -52701887L, -79042909L, + -105372028L, -131685278L, -157978697L, -184248325L, -210490206L, -236700388L, + -262874923L, -289009871L, -315101295L, -341145265L, -367137861L, -393075166L, + -418953276L, -444768294L, -470516330L, -496193509L, -521795963L, -547319836L, + -572761285L, -598116479L, -623381598L, -648552838L, -673626408L, -698598533L, + -723465451L, -748223418L, -772868706L, -797397602L, -821806413L, -846091463L, + -870249095L, -894275671L, -918167572L, -941921200L, -965532978L, -988999351L, + -1012316784L, -1035481766L, -1058490808L, -1081340445L, -1104027237L, + -1126547765L, -1148898640L, -1171076495L, -1193077991L, -1214899813L, + -1236538675L, -1257991320L, -1279254516L, -1300325060L, -1321199781L, + -1341875533L, -1362349204L, -1382617710L, -1402678000L, -1422527051L, + -1442161874L, -1461579514L, -1480777044L, -1499751576L, -1518500250L, + -1537020244L, -1555308768L, -1573363068L, -1591180426L, -1608758157L, + -1626093616L, -1643184191L, -1660027308L, -1676620432L, -1692961062L, + -1709046739L, -1724875040L, -1740443581L, -1755750017L, -1770792044L, + -1785567396L, -1800073849L, -1814309216L, -1828271356L, -1841958164L, + -1855367581L, -1868497586L, -1881346202L, -1893911494L, -1906191570L, + -1918184581L, -1929888720L, -1941302225L, -1952423377L, -1963250501L, + -1973781967L, -1984016189L, -1993951625L, -2003586779L, -2012920201L, + -2021950484L, -2030676269L, -2039096241L, -2047209133L, -2055013723L, + -2062508835L, -2069693342L, -2076566160L, -2083126254L, -2089372638L, + -2095304370L, -2100920556L, -2106220352L, -2111202959L, -2115867626L, + -2120213651L, -2124240380L, -2127947206L, -2131333572L, -2134398966L, + -2137142927L, -2139565043L, -2141664948L, -2143442326L, -2144896910L, + -2146028480L, -2146836866L, -2147321946L, (q31_t)0x80000000, -2147321946L, + -2146836866L, -2146028480L, -2144896910L, -2143442326L, -2141664948L, + -2139565043L, -2137142927L, -2134398966L, -2131333572L, -2127947206L, + -2124240380L, -2120213651L, -2115867626L, -2111202959L, -2106220352L, + -2100920556L, -2095304370L, -2089372638L, -2083126254L, -2076566160L, + -2069693342L, -2062508835L, -2055013723L, -2047209133L, -2039096241L, + -2030676269L, -2021950484L, -2012920201L, -2003586779L, -1993951625L, + -1984016189L, -1973781967L, -1963250501L, -1952423377L, -1941302225L, + -1929888720L, -1918184581L, -1906191570L, -1893911494L, -1881346202L, + -1868497586L, -1855367581L, -1841958164L, -1828271356L, -1814309216L, + -1800073849L, -1785567396L, -1770792044L, -1755750017L, -1740443581L, + -1724875040L, -1709046739L, -1692961062L, -1676620432L, -1660027308L, + -1643184191L, -1626093616L, -1608758157L, -1591180426L, -1573363068L, + -1555308768L, -1537020244L, -1518500250L, -1499751576L, -1480777044L, + -1461579514L, -1442161874L, -1422527051L, -1402678000L, -1382617710L, + -1362349204L, -1341875533L, -1321199781L, -1300325060L, -1279254516L, + -1257991320L, -1236538675L, -1214899813L, -1193077991L, -1171076495L, + -1148898640L, -1126547765L, -1104027237L, -1081340445L, -1058490808L, + -1035481766L, -1012316784L, -988999351L, -965532978L, -941921200L, + -918167572L, -894275671L, -870249095L, -846091463L, -821806413L, -797397602L, + -772868706L, -748223418L, -723465451L, -698598533L, -673626408L, -648552838L, + -623381598L, -598116479L, -572761285L, -547319836L, -521795963L, -496193509L, + -470516330L, -444768294L, -418953276L, -393075166L, -367137861L, -341145265L, + -315101295L, -289009871L, -262874923L, -236700388L, -210490206L, -184248325L, + -157978697L, -131685278L, -105372028L, -79042909L, -52701887L, -26352928L, 0 +}; + +/** + * \par + * Table values are in Q15 (1.15 fixed-point format) and generation is done in + * three steps. First, generate sin values in floating point: + *
+ * tableSize = 512;
+ * for(n = 0; n < (tableSize + 1); n++)
+ * {
+ *	sinTable[n]= sin(2*pi*n/tableSize);
+ * } 
+ * where pi value is 3.14159265358979 + * \par + * Second, convert floating-point to Q15 (Fixed point): + * (sinTable[i] * pow(2, 15)) + * \par + * Finally, round to the nearest integer value: + * sinTable[i] += (sinTable[i] > 0 ? 0.5 :-0.5); + */ +const q15_t sinTable_q15[FAST_MATH_TABLE_SIZE + 1] = { + 0, 402, 804, 1206, 1608, 2009, 2411, 2811, 3212, 3612, 4011, 4410, 4808, + 5205, 5602, 5998, 6393, 6787, 7180, 7571, 7962, 8351, 8740, 9127, 9512, + 9896, 10279, 10660, 11039, 11417, 11793, 12167, 12540, 12910, 13279, + 13646, 14010, 14373, 14733, 15091, 15447, 15800, 16151, 16500, 16846, + 17190, 17531, 17869, 18205, 18538, 18868, 19195, 19520, 19841, 20160, + 20475, 20788, 21097, 21403, 21706, 22006, 22302, 22595, 22884, 23170, + 23453, 23732, 24008, 24279, 24548, 24812, 25073, 25330, 25583, 25833, + 26078, 26320, 26557, 26791, 27020, 27246, 27467, 27684, 27897, 28106, + 28311, 28511, 28707, 28899, 29086, 29269, 29448, 29622, 29792, 29957, + 30118, 30274, 30425, 30572, 30715, 30853, 30986, 31114, 31238, 31357, + 31471, 31581, 31686, 31786, 31881, 31972, 32058, 32138, 32214, 32286, + 32352, 32413, 32470, 32522, 32568, 32610, 32647, 32679, 32706, 32729, + 32746, 32758, 32766, 32767, 32766, 32758, 32746, 32729, 32706, 32679, + 32647, 32610, 32568, 32522, 32470, 32413, 32352, 32286, 32214, 32138, + 32058, 31972, 31881, 31786, 31686, 31581, 31471, 31357, 31238, 31114, + 30986, 30853, 30715, 30572, 30425, 30274, 30118, 29957, 29792, 29622, + 29448, 29269, 29086, 28899, 28707, 28511, 28311, 28106, 27897, 27684, + 27467, 27246, 27020, 26791, 26557, 26320, 26078, 25833, 25583, 25330, + 25073, 24812, 24548, 24279, 24008, 23732, 23453, 23170, 22884, 22595, + 22302, 22006, 21706, 21403, 21097, 20788, 20475, 20160, 19841, 19520, + 19195, 18868, 18538, 18205, 17869, 17531, 17190, 16846, 16500, 16151, + 15800, 15447, 15091, 14733, 14373, 14010, 13646, 13279, 12910, 12540, + 12167, 11793, 11417, 11039, 10660, 10279, 9896, 9512, 9127, 8740, 8351, + 7962, 7571, 7180, 6787, 6393, 5998, 5602, 5205, 4808, 4410, 4011, 3612, + 3212, 2811, 2411, 2009, 1608, 1206, 804, 402, 0, -402, -804, -1206, + -1608, -2009, -2411, -2811, -3212, -3612, -4011, -4410, -4808, -5205, + -5602, -5998, -6393, -6787, -7180, -7571, -7962, -8351, -8740, -9127, + -9512, -9896, -10279, -10660, -11039, -11417, -11793, -12167, -12540, + -12910, -13279, -13646, -14010, -14373, -14733, -15091, -15447, -15800, + -16151, -16500, -16846, -17190, -17531, -17869, -18205, -18538, -18868, + -19195, -19520, -19841, -20160, -20475, -20788, -21097, -21403, -21706, + -22006, -22302, -22595, -22884, -23170, -23453, -23732, -24008, -24279, + -24548, -24812, -25073, -25330, -25583, -25833, -26078, -26320, -26557, + -26791, -27020, -27246, -27467, -27684, -27897, -28106, -28311, -28511, + -28707, -28899, -29086, -29269, -29448, -29622, -29792, -29957, -30118, + -30274, -30425, -30572, -30715, -30853, -30986, -31114, -31238, -31357, + -31471, -31581, -31686, -31786, -31881, -31972, -32058, -32138, -32214, + -32286, -32352, -32413, -32470, -32522, -32568, -32610, -32647, -32679, + -32706, -32729, -32746, -32758, -32766, -32768, -32766, -32758, -32746, + -32729, -32706, -32679, -32647, -32610, -32568, -32522, -32470, -32413, + -32352, -32286, -32214, -32138, -32058, -31972, -31881, -31786, -31686, + -31581, -31471, -31357, -31238, -31114, -30986, -30853, -30715, -30572, + -30425, -30274, -30118, -29957, -29792, -29622, -29448, -29269, -29086, + -28899, -28707, -28511, -28311, -28106, -27897, -27684, -27467, -27246, + -27020, -26791, -26557, -26320, -26078, -25833, -25583, -25330, -25073, + -24812, -24548, -24279, -24008, -23732, -23453, -23170, -22884, -22595, + -22302, -22006, -21706, -21403, -21097, -20788, -20475, -20160, -19841, + -19520, -19195, -18868, -18538, -18205, -17869, -17531, -17190, -16846, + -16500, -16151, -15800, -15447, -15091, -14733, -14373, -14010, -13646, + -13279, -12910, -12540, -12167, -11793, -11417, -11039, -10660, -10279, + -9896, -9512, -9127, -8740, -8351, -7962, -7571, -7180, -6787, -6393, + -5998, -5602, -5205, -4808, -4410, -4011, -3612, -3212, -2811, -2411, + -2009, -1608, -1206, -804, -402, 0 +}; diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_const_structs.c b/Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_const_structs.c new file mode 100644 index 0000000..96808d3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/CommonTables/arm_const_structs.c @@ -0,0 +1,379 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_const_structs.c + * Description: Constant structs that are initialized for user convenience. + * For example, some can be given as arguments to the arm_cfft_f32() or arm_rfft_f32() functions. + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_const_structs.h" + +/* Floating-point structs */ +const arm_cfft_instance_f32 arm_cfft_sR_f32_len16 = { + 16, twiddleCoef_16, armBitRevIndexTable16, ARMBITREVINDEXTABLE_16_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len32 = { + 32, twiddleCoef_32, armBitRevIndexTable32, ARMBITREVINDEXTABLE_32_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len64 = { + 64, twiddleCoef_64, armBitRevIndexTable64, ARMBITREVINDEXTABLE_64_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len128 = { + 128, twiddleCoef_128, armBitRevIndexTable128, ARMBITREVINDEXTABLE_128_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len256 = { + 256, twiddleCoef_256, armBitRevIndexTable256, ARMBITREVINDEXTABLE_256_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len512 = { + 512, twiddleCoef_512, armBitRevIndexTable512, ARMBITREVINDEXTABLE_512_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len1024 = { + 1024, twiddleCoef_1024, armBitRevIndexTable1024, ARMBITREVINDEXTABLE_1024_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len2048 = { + 2048, twiddleCoef_2048, armBitRevIndexTable2048, ARMBITREVINDEXTABLE_2048_TABLE_LENGTH +}; + +const arm_cfft_instance_f32 arm_cfft_sR_f32_len4096 = { + 4096, twiddleCoef_4096, armBitRevIndexTable4096, ARMBITREVINDEXTABLE_4096_TABLE_LENGTH +}; + +/* Fixed-point structs */ +const arm_cfft_instance_q31 arm_cfft_sR_q31_len16 = { + 16, twiddleCoef_16_q31, armBitRevIndexTable_fixed_16, ARMBITREVINDEXTABLE_FIXED_16_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len32 = { + 32, twiddleCoef_32_q31, armBitRevIndexTable_fixed_32, ARMBITREVINDEXTABLE_FIXED_32_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len64 = { + 64, twiddleCoef_64_q31, armBitRevIndexTable_fixed_64, ARMBITREVINDEXTABLE_FIXED_64_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len128 = { + 128, twiddleCoef_128_q31, armBitRevIndexTable_fixed_128, ARMBITREVINDEXTABLE_FIXED_128_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len256 = { + 256, twiddleCoef_256_q31, armBitRevIndexTable_fixed_256, ARMBITREVINDEXTABLE_FIXED_256_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len512 = { + 512, twiddleCoef_512_q31, armBitRevIndexTable_fixed_512, ARMBITREVINDEXTABLE_FIXED_512_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len1024 = { + 1024, twiddleCoef_1024_q31, armBitRevIndexTable_fixed_1024, ARMBITREVINDEXTABLE_FIXED_1024_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len2048 = { + 2048, twiddleCoef_2048_q31, armBitRevIndexTable_fixed_2048, ARMBITREVINDEXTABLE_FIXED_2048_TABLE_LENGTH +}; + +const arm_cfft_instance_q31 arm_cfft_sR_q31_len4096 = { + 4096, twiddleCoef_4096_q31, armBitRevIndexTable_fixed_4096, ARMBITREVINDEXTABLE_FIXED_4096_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len16 = { + 16, twiddleCoef_16_q15, armBitRevIndexTable_fixed_16, ARMBITREVINDEXTABLE_FIXED_16_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len32 = { + 32, twiddleCoef_32_q15, armBitRevIndexTable_fixed_32, ARMBITREVINDEXTABLE_FIXED_32_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len64 = { + 64, twiddleCoef_64_q15, armBitRevIndexTable_fixed_64, ARMBITREVINDEXTABLE_FIXED_64_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len128 = { + 128, twiddleCoef_128_q15, armBitRevIndexTable_fixed_128, ARMBITREVINDEXTABLE_FIXED_128_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len256 = { + 256, twiddleCoef_256_q15, armBitRevIndexTable_fixed_256, ARMBITREVINDEXTABLE_FIXED_256_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len512 = { + 512, twiddleCoef_512_q15, armBitRevIndexTable_fixed_512, ARMBITREVINDEXTABLE_FIXED_512_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len1024 = { + 1024, twiddleCoef_1024_q15, armBitRevIndexTable_fixed_1024, ARMBITREVINDEXTABLE_FIXED_1024_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len2048 = { + 2048, twiddleCoef_2048_q15, armBitRevIndexTable_fixed_2048, ARMBITREVINDEXTABLE_FIXED_2048_TABLE_LENGTH +}; + +const arm_cfft_instance_q15 arm_cfft_sR_q15_len4096 = { + 4096, twiddleCoef_4096_q15, armBitRevIndexTable_fixed_4096, ARMBITREVINDEXTABLE_FIXED_4096_TABLE_LENGTH +}; + +/* Structure for real-value inputs */ +/* Floating-point structs */ +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len32 = { + { 16, twiddleCoef_32, armBitRevIndexTable32, ARMBITREVINDEXTABLE_16_TABLE_LENGTH }, + 32U, + (float32_t *)twiddleCoef_rfft_32 +}; + +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len64 = { + { 32, twiddleCoef_32, armBitRevIndexTable32, ARMBITREVINDEXTABLE_32_TABLE_LENGTH }, + 64U, + (float32_t *)twiddleCoef_rfft_64 +}; + +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len128 = { + { 64, twiddleCoef_64, armBitRevIndexTable64, ARMBITREVINDEXTABLE_64_TABLE_LENGTH }, + 128U, + (float32_t *)twiddleCoef_rfft_128 +}; + +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len256 = { + { 128, twiddleCoef_128, armBitRevIndexTable128, ARMBITREVINDEXTABLE_128_TABLE_LENGTH }, + 256U, + (float32_t *)twiddleCoef_rfft_256 +}; + +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len512 = { + { 256, twiddleCoef_256, armBitRevIndexTable256, ARMBITREVINDEXTABLE_256_TABLE_LENGTH }, + 512U, + (float32_t *)twiddleCoef_rfft_512 +}; + +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len1024 = { + { 512, twiddleCoef_512, armBitRevIndexTable512, ARMBITREVINDEXTABLE_512_TABLE_LENGTH }, + 1024U, + (float32_t *)twiddleCoef_rfft_1024 +}; + +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len2048 = { + { 1024, twiddleCoef_1024, armBitRevIndexTable1024, ARMBITREVINDEXTABLE_1024_TABLE_LENGTH }, + 2048U, + (float32_t *)twiddleCoef_rfft_2048 +}; + +const arm_rfft_fast_instance_f32 arm_rfft_fast_sR_f32_len4096 = { + { 2048, twiddleCoef_2048, armBitRevIndexTable2048, ARMBITREVINDEXTABLE_2048_TABLE_LENGTH }, + 4096U, + (float32_t *)twiddleCoef_rfft_4096 +}; + +/* Fixed-point structs */ +/* q31_t */ +extern const q31_t realCoefAQ31[8192]; +extern const q31_t realCoefBQ31[8192]; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len32 = { + 32U, + 0, + 1, + 256U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len16 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len64 = { + 64U, + 0, + 1, + 128U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len32 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len128 = { + 128U, + 0, + 1, + 64U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len64 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len256 = { + 256U, + 0, + 1, + 32U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len128 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len512 = { + 512U, + 0, + 1, + 16U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len256 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len1024 = { + 1024U, + 0, + 1, + 8U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len512 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len2048 = { + 2048U, + 0, + 1, + 4U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len1024 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len4096 = { + 4096U, + 0, + 1, + 2U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len2048 +}; + +const arm_rfft_instance_q31 arm_rfft_sR_q31_len8192 = { + 8192U, + 0, + 1, + 1U, + (q31_t*)realCoefAQ31, + (q31_t*)realCoefBQ31, + &arm_cfft_sR_q31_len4096 +}; + +/* q15_t */ +extern const q15_t realCoefAQ15[8192]; +extern const q15_t realCoefBQ15[8192]; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len32 = { + 32U, + 0, + 1, + 256U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len16 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len64 = { + 64U, + 0, + 1, + 128U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len32 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len128 = { + 128U, + 0, + 1, + 64U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len64 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len256 = { + 256U, + 0, + 1, + 32U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len128 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len512 = { + 512U, + 0, + 1, + 16U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len256 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len1024 = { + 1024U, + 0, + 1, + 8U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len512 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len2048 = { + 2048U, + 0, + 1, + 4U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len1024 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len4096 = { + 4096U, + 0, + 1, + 2U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len2048 +}; + +const arm_rfft_instance_q15 arm_rfft_sR_q15_len8192 = { + 8192U, + 0, + 1, + 1U, + (q15_t*)realCoefAQ15, + (q15_t*)realCoefBQ15, + &arm_cfft_sR_q15_len4096 +}; diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_f32.c new file mode 100644 index 0000000..29e74bc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_f32.c @@ -0,0 +1,171 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cmplx_conj_f32.c + * Description: Floating-point complex conjugate + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupCmplxMath + */ + +/** + * @defgroup cmplx_conj Complex Conjugate + * + * Conjugates the elements of a complex data vector. + * + * The pSrc points to the source data and + * pDst points to the where the result should be written. + * numSamples specifies the number of complex samples + * and the data in each array is stored in an interleaved fashion + * (real, imag, real, imag, ...). + * Each array has a total of 2*numSamples values. + * The underlying algorithm is used: + * + *
+ * for(n=0; n
+ *
+ * There are separate functions for floating-point, Q15, and Q31 data types.
+ */
+
+/**
+ * @addtogroup cmplx_conj
+ * @{
+ */
+
+/**
+ * @brief  Floating-point complex conjugate.
+ * @param  *pSrc points to the input vector
+ * @param  *pDst points to the output vector
+ * @param  numSamples number of complex samples in each vector
+ * @return none.
+ */
+
+void arm_cmplx_conj_f32(
+  float32_t * pSrc,
+  float32_t * pDst,
+  uint32_t numSamples)
+{
+  uint32_t blkCnt;                               /* loop counter */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  float32_t inR1, inR2, inR3, inR4;
+  float32_t inI1, inI2, inI3, inI4;
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[0]+jC[1] = A[0]+ j (-1) A[1] */
+    /* Calculate Complex Conjugate and then store the results in the destination buffer. */
+    /* read real input samples */
+    inR1 = pSrc[0];
+    /* store real samples to destination */
+    pDst[0] = inR1;
+    inR2 = pSrc[2];
+    pDst[2] = inR2;
+    inR3 = pSrc[4];
+    pDst[4] = inR3;
+    inR4 = pSrc[6];
+    pDst[6] = inR4;
+
+    /* read imaginary input samples */
+    inI1 = pSrc[1];
+    inI2 = pSrc[3];
+
+    /* conjugate input */
+    inI1 = -inI1;
+
+    /* read imaginary input samples */
+    inI3 = pSrc[5];
+
+    /* conjugate input */
+    inI2 = -inI2;
+
+    /* read imaginary input samples */
+    inI4 = pSrc[7];
+
+    /* conjugate input */
+    inI3 = -inI3;
+
+    /* store imaginary samples to destination */
+    pDst[1] = inI1;
+    pDst[3] = inI2;
+
+    /* conjugate input */
+    inI4 = -inI4;
+
+    /* store imaginary samples to destination */
+    pDst[5] = inI3;
+
+    /* increment source pointer by 8 to process next sampels */
+    pSrc += 8U;
+
+    /* store imaginary sample to destination */
+    pDst[7] = inI4;
+
+    /* increment destination pointer by 8 to store next samples */
+    pDst += 8U;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+  blkCnt = numSamples;
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  while (blkCnt > 0U)
+  {
+    /* realOut + j (imagOut) = realIn + j (-1) imagIn */
+    /* Calculate Complex Conjugate and then store the results in the destination buffer. */
+    *pDst++ = *pSrc++;
+    *pDst++ = -*pSrc++;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+}
+
+/**
+ * @} end of cmplx_conj group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q15.c
new file mode 100644
index 0000000..1e371bd
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q15.c
@@ -0,0 +1,149 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_conj_q15.c
+ * Description:  Q15 complex conjugate
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_conj
+ * @{
+ */
+
+/**
+ * @brief  Q15 complex conjugate.
+ * @param  *pSrc points to the input vector
+ * @param  *pDst points to the output vector
+ * @param  numSamples number of complex samples in each vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function uses saturating arithmetic.
+ * The Q15 value -1 (0x8000) will be saturated to the maximum allowable positive value 0x7FFF.
+ */
+
+void arm_cmplx_conj_q15(
+  q15_t * pSrc,
+  q15_t * pDst,
+  uint32_t numSamples)
+{
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+  q31_t in1, in2, in3, in4;
+  q31_t zero = 0;
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[0]+jC[1] = A[0]+ j (-1) A[1] */
+    /* Calculate Complex Conjugate and then store the results in the destination buffer. */
+    in1 = *__SIMD32(pSrc)++;
+    in2 = *__SIMD32(pSrc)++;
+    in3 = *__SIMD32(pSrc)++;
+    in4 = *__SIMD32(pSrc)++;
+
+#ifndef ARM_MATH_BIG_ENDIAN
+
+    in1 = __QASX(zero, in1);
+    in2 = __QASX(zero, in2);
+    in3 = __QASX(zero, in3);
+    in4 = __QASX(zero, in4);
+
+#else
+
+    in1 = __QSAX(zero, in1);
+    in2 = __QSAX(zero, in2);
+    in3 = __QSAX(zero, in3);
+    in4 = __QSAX(zero, in4);
+
+#endif /* #ifndef ARM_MATH_BIG_ENDIAN */
+
+    in1 = ((uint32_t) in1 >> 16) | ((uint32_t) in1 << 16);
+    in2 = ((uint32_t) in2 >> 16) | ((uint32_t) in2 << 16);
+    in3 = ((uint32_t) in3 >> 16) | ((uint32_t) in3 << 16);
+    in4 = ((uint32_t) in4 >> 16) | ((uint32_t) in4 << 16);
+
+    *__SIMD32(pDst)++ = in1;
+    *__SIMD32(pDst)++ = in2;
+    *__SIMD32(pDst)++ = in3;
+    *__SIMD32(pDst)++ = in4;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[0]+jC[1] = A[0]+ j (-1) A[1] */
+    /* Calculate Complex Conjugate and then store the results in the destination buffer. */
+    *pDst++ = *pSrc++;
+    *pDst++ = __SSAT(-*pSrc++, 16);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  q15_t in;
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+    /* realOut + j (imagOut) = realIn+ j (-1) imagIn */
+    /* Calculate Complex Conjugate and then store the results in the destination buffer. */
+    *pDst++ = *pSrc++;
+    in = *pSrc++;
+    *pDst++ = (in == (q15_t) 0x8000) ? 0x7fff : -in;
+
+    /* Decrement the loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of cmplx_conj group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q31.c
new file mode 100644
index 0000000..af14414
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_conj_q31.c
@@ -0,0 +1,169 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_conj_q31.c
+ * Description:  Q31 complex conjugate
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_conj
+ * @{
+ */
+
+/**
+ * @brief  Q31 complex conjugate.
+ * @param  *pSrc points to the input vector
+ * @param  *pDst points to the output vector
+ * @param  numSamples number of complex samples in each vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function uses saturating arithmetic.
+ * The Q31 value -1 (0x80000000) will be saturated to the maximum allowable positive value 0x7FFFFFFF.
+ */
+
+void arm_cmplx_conj_q31(
+  q31_t * pSrc,
+  q31_t * pDst,
+  uint32_t numSamples)
+{
+  uint32_t blkCnt;                               /* loop counter */
+  q31_t in;                                      /* Input value */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  q31_t inR1, inR2, inR3, inR4;                  /* Temporary real variables */
+  q31_t inI1, inI2, inI3, inI4;                  /* Temporary imaginary variables */
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[0]+jC[1] = A[0]+ j (-1) A[1] */
+    /* Calculate Complex Conjugate and then store the results in the destination buffer. */
+    /* Saturated to 0x7fffffff if the input is -1(0x80000000) */
+    /* read real input sample */
+    inR1 = pSrc[0];
+    /* store real input sample */
+    pDst[0] = inR1;
+
+    /* read imaginary input sample */
+    inI1 = pSrc[1];
+
+    /* read real input sample */
+    inR2 = pSrc[2];
+    /* store real input sample */
+    pDst[2] = inR2;
+
+    /* read imaginary input sample */
+    inI2 = pSrc[3];
+
+    /* negate imaginary input sample */
+    inI1 = __QSUB(0, inI1);
+
+    /* read real input sample */
+    inR3 = pSrc[4];
+    /* store real input sample */
+    pDst[4] = inR3;
+
+    /* read imaginary input sample */
+    inI3 = pSrc[5];
+
+    /* negate imaginary input sample */
+    inI2 = __QSUB(0, inI2);
+
+    /* read real input sample */
+    inR4 = pSrc[6];
+    /* store real input sample */
+    pDst[6] = inR4;
+
+    /* negate imaginary input sample */
+    inI3 = __QSUB(0, inI3);
+
+    /* store imaginary input sample */
+    inI4 = pSrc[7];
+
+    /* store imaginary input samples */
+    pDst[1] = inI1;
+
+    /* negate imaginary input sample */
+    inI4 = __QSUB(0, inI4);
+
+    /* store imaginary input samples */
+    pDst[3] = inI2;
+
+    /* increment source pointer by 8 to proecess next samples */
+    pSrc += 8U;
+
+    /* store imaginary input samples */
+    pDst[5] = inI3;
+    pDst[7] = inI4;
+
+    /* increment destination pointer by 8 to process next samples */
+    pDst += 8U;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+  blkCnt = numSamples;
+
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  while (blkCnt > 0U)
+  {
+    /* C[0]+jC[1] = A[0]+ j (-1) A[1] */
+    /* Calculate Complex Conjugate and then store the results in the destination buffer. */
+    /* Saturated to 0x7fffffff if the input is -1(0x80000000) */
+    *pDst++ = *pSrc++;
+    in = *pSrc++;
+    *pDst++ = (in == INT32_MIN) ? INT32_MAX : -in;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+}
+
+/**
+ * @} end of cmplx_conj group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_f32.c
new file mode 100644
index 0000000..aac177f
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_f32.c
@@ -0,0 +1,191 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_dot_prod_f32.c
+ * Description:  Floating-point complex dot product
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @defgroup cmplx_dot_prod Complex Dot Product
+ *
+ * Computes the dot product of two complex vectors.
+ * The vectors are multiplied element-by-element and then summed.
+ *
+ * The pSrcA points to the first complex input vector and
+ * pSrcB points to the second complex input vector.
+ * numSamples specifies the number of complex samples
+ * and the data in each array is stored in an interleaved fashion
+ * (real, imag, real, imag, ...).
+ * Each array has a total of 2*numSamples values.
+ *
+ * The underlying algorithm is used:
+ * 
+ * realResult=0;
+ * imagResult=0;
+ * for(n=0; n
+ *
+ * There are separate functions for floating-point, Q15, and Q31 data types.
+ */
+
+/**
+ * @addtogroup cmplx_dot_prod
+ * @{
+ */
+
+/**
+ * @brief  Floating-point complex dot product
+ * @param  *pSrcA points to the first input vector
+ * @param  *pSrcB points to the second input vector
+ * @param  numSamples number of complex samples in each vector
+ * @param  *realResult real part of the result returned here
+ * @param  *imagResult imaginary part of the result returned here
+ * @return none.
+ */
+
+void arm_cmplx_dot_prod_f32(
+  float32_t * pSrcA,
+  float32_t * pSrcB,
+  uint32_t numSamples,
+  float32_t * realResult,
+  float32_t * imagResult)
+{
+  float32_t real_sum = 0.0f, imag_sum = 0.0f;    /* Temporary result storage */
+  float32_t a0,b0,c0,d0;
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += a0 * c0;
+      imag_sum += a0 * d0;
+      real_sum -= b0 * d0;
+      imag_sum += b0 * c0;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += a0 * c0;
+      imag_sum += a0 * d0;
+      real_sum -= b0 * d0;
+      imag_sum += b0 * c0;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += a0 * c0;
+      imag_sum += a0 * d0;
+      real_sum -= b0 * d0;
+      imag_sum += b0 * c0;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += a0 * c0;
+      imag_sum += a0 * d0;
+      real_sum -= b0 * d0;
+      imag_sum += b0 * c0;
+
+      /* Decrement the loop counter */
+      blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples & 0x3U;
+
+  while (blkCnt > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += a0 * c0;
+      imag_sum += a0 * d0;
+      real_sum -= b0 * d0;
+      imag_sum += b0 * c0;
+
+      /* Decrement the loop counter */
+      blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += a0 * c0;
+      imag_sum += a0 * d0;
+      real_sum -= b0 * d0;
+      imag_sum += b0 * c0;
+
+      /* Decrement the loop counter */
+      numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  /* Store the real and imaginary results in the destination buffers */
+  *realResult = real_sum;
+  *imagResult = imag_sum;
+}
+
+/**
+ * @} end of cmplx_dot_prod group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q15.c
new file mode 100644
index 0000000..efe72a2
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q15.c
@@ -0,0 +1,177 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_dot_prod_q15.c
+ * Description:  Processing function for the Q15 Complex Dot product
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_dot_prod
+ * @{
+ */
+
+/**
+ * @brief  Q15 complex dot product
+ * @param  *pSrcA points to the first input vector
+ * @param  *pSrcB points to the second input vector
+ * @param  numSamples number of complex samples in each vector
+ * @param  *realResult real part of the result returned here
+ * @param  *imagResult imaginary part of the result returned here
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function is implemented using an internal 64-bit accumulator.
+ * The intermediate 1.15 by 1.15 multiplications are performed with full precision and yield a 2.30 result.
+ * These are accumulated in a 64-bit accumulator with 34.30 precision.
+ * As a final step, the accumulators are converted to 8.24 format.
+ * The return results realResult and imagResult are in 8.24 format.
+ */
+
+void arm_cmplx_dot_prod_q15(
+  q15_t * pSrcA,
+  q15_t * pSrcB,
+  uint32_t numSamples,
+  q31_t * realResult,
+  q31_t * imagResult)
+{
+  q63_t real_sum = 0, imag_sum = 0;              /* Temporary result storage */
+  q15_t a0,b0,c0,d0;
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += (q31_t)a0 * c0;
+      imag_sum += (q31_t)a0 * d0;
+      real_sum -= (q31_t)b0 * d0;
+      imag_sum += (q31_t)b0 * c0;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += (q31_t)a0 * c0;
+      imag_sum += (q31_t)a0 * d0;
+      real_sum -= (q31_t)b0 * d0;
+      imag_sum += (q31_t)b0 * c0;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += (q31_t)a0 * c0;
+      imag_sum += (q31_t)a0 * d0;
+      real_sum -= (q31_t)b0 * d0;
+      imag_sum += (q31_t)b0 * c0;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += (q31_t)a0 * c0;
+      imag_sum += (q31_t)a0 * d0;
+      real_sum -= (q31_t)b0 * d0;
+      imag_sum += (q31_t)b0 * c0;
+
+      /* Decrement the loop counter */
+      blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += (q31_t)a0 * c0;
+      imag_sum += (q31_t)a0 * d0;
+      real_sum -= (q31_t)b0 * d0;
+      imag_sum += (q31_t)b0 * c0;
+
+      /* Decrement the loop counter */
+      blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += a0 * c0;
+      imag_sum += a0 * d0;
+      real_sum -= b0 * d0;
+      imag_sum += b0 * c0;
+
+
+      /* Decrement the loop counter */
+      numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  /* Store the real and imaginary results in 8.24 format  */
+  /* Convert real data in 34.30 to 8.24 by 6 right shifts */
+  *realResult = (q31_t) (real_sum >> 6);
+  /* Convert imaginary data in 34.30 to 8.24 by 6 right shifts */
+  *imagResult = (q31_t) (imag_sum >> 6);
+}
+
+/**
+ * @} end of cmplx_dot_prod group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q31.c
new file mode 100644
index 0000000..dfd3a4b
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_dot_prod_q31.c
@@ -0,0 +1,175 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_dot_prod_q31.c
+ * Description:  Q31 complex dot product
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_dot_prod
+ * @{
+ */
+
+/**
+ * @brief  Q31 complex dot product
+ * @param  *pSrcA points to the first input vector
+ * @param  *pSrcB points to the second input vector
+ * @param  numSamples number of complex samples in each vector
+ * @param  *realResult real part of the result returned here
+ * @param  *imagResult imaginary part of the result returned here
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function is implemented using an internal 64-bit accumulator.
+ * The intermediate 1.31 by 1.31 multiplications are performed with 64-bit precision and then shifted to 16.48 format.
+ * The internal real and imaginary accumulators are in 16.48 format and provide 15 guard bits.
+ * Additions are nonsaturating and no overflow will occur as long as numSamples is less than 32768.
+ * The return results realResult and imagResult are in 16.48 format.
+ * Input down scaling is not required.
+ */
+
+void arm_cmplx_dot_prod_q31(
+  q31_t * pSrcA,
+  q31_t * pSrcB,
+  uint32_t numSamples,
+  q63_t * realResult,
+  q63_t * imagResult)
+{
+  q63_t real_sum = 0, imag_sum = 0;              /* Temporary result storage */
+  q31_t a0,b0,c0,d0;
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += ((q63_t)a0 * c0) >> 14;
+      imag_sum += ((q63_t)a0 * d0) >> 14;
+      real_sum -= ((q63_t)b0 * d0) >> 14;
+      imag_sum += ((q63_t)b0 * c0) >> 14;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += ((q63_t)a0 * c0) >> 14;
+      imag_sum += ((q63_t)a0 * d0) >> 14;
+      real_sum -= ((q63_t)b0 * d0) >> 14;
+      imag_sum += ((q63_t)b0 * c0) >> 14;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += ((q63_t)a0 * c0) >> 14;
+      imag_sum += ((q63_t)a0 * d0) >> 14;
+      real_sum -= ((q63_t)b0 * d0) >> 14;
+      imag_sum += ((q63_t)b0 * c0) >> 14;
+
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += ((q63_t)a0 * c0) >> 14;
+      imag_sum += ((q63_t)a0 * d0) >> 14;
+      real_sum -= ((q63_t)b0 * d0) >> 14;
+      imag_sum += ((q63_t)b0 * c0) >> 14;
+
+      /* Decrement the loop counter */
+      blkCnt--;
+  }
+
+  /* If the numSamples  is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += ((q63_t)a0 * c0) >> 14;
+      imag_sum += ((q63_t)a0 * d0) >> 14;
+      real_sum -= ((q63_t)b0 * d0) >> 14;
+      imag_sum += ((q63_t)b0 * c0) >> 14;
+
+      /* Decrement the loop counter */
+      blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+      a0 = *pSrcA++;
+      b0 = *pSrcA++;
+      c0 = *pSrcB++;
+      d0 = *pSrcB++;
+
+      real_sum += ((q63_t)a0 * c0) >> 14;
+      imag_sum += ((q63_t)a0 * d0) >> 14;
+      real_sum -= ((q63_t)b0 * d0) >> 14;
+      imag_sum += ((q63_t)b0 * c0) >> 14;
+
+      /* Decrement the loop counter */
+      numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  /* Store the real and imaginary results in 16.48 format  */
+  *realResult = real_sum;
+  *imagResult = imag_sum;
+}
+
+/**
+ * @} end of cmplx_dot_prod group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_f32.c
new file mode 100644
index 0000000..6c8be8f
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_f32.c
@@ -0,0 +1,153 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mag_f32.c
+ * Description:  Floating-point complex magnitude
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @defgroup cmplx_mag Complex Magnitude
+ *
+ * Computes the magnitude of the elements of a complex data vector.
+ *
+ * The pSrc points to the source data and
+ * pDst points to the where the result should be written.
+ * numSamples specifies the number of complex samples
+ * in the input array and the data is stored in an interleaved fashion
+ * (real, imag, real, imag, ...).
+ * The input array has a total of 2*numSamples values;
+ * the output array has a total of numSamples values.
+ * The underlying algorithm is used:
+ *
+ * 
+ * for(n=0; n
+ *
+ * There are separate functions for floating-point, Q15, and Q31 data types.
+ */
+
+/**
+ * @addtogroup cmplx_mag
+ * @{
+ */
+/**
+ * @brief Floating-point complex magnitude.
+ * @param[in]       *pSrc points to complex input buffer
+ * @param[out]      *pDst points to real output buffer
+ * @param[in]       numSamples number of complex samples in the input vector
+ * @return none.
+ *
+ */
+
+
+void arm_cmplx_mag_f32(
+  float32_t * pSrc,
+  float32_t * pDst,
+  uint32_t numSamples)
+{
+  float32_t realIn, imagIn;                      /* Temporary variables to hold input values */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+
+    /* C[0] = sqrt(A[0] * A[0] + A[1] * A[1]) */
+    realIn = *pSrc++;
+    imagIn = *pSrc++;
+    /* store the result in the destination buffer. */
+    arm_sqrt_f32((realIn * realIn) + (imagIn * imagIn), pDst++);
+
+    realIn = *pSrc++;
+    imagIn = *pSrc++;
+    arm_sqrt_f32((realIn * realIn) + (imagIn * imagIn), pDst++);
+
+    realIn = *pSrc++;
+    imagIn = *pSrc++;
+    arm_sqrt_f32((realIn * realIn) + (imagIn * imagIn), pDst++);
+
+    realIn = *pSrc++;
+    imagIn = *pSrc++;
+    arm_sqrt_f32((realIn * realIn) + (imagIn * imagIn), pDst++);
+
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[0] = sqrt(A[0] * A[0] + A[1] * A[1]) */
+    realIn = *pSrc++;
+    imagIn = *pSrc++;
+    /* store the result in the destination buffer. */
+    arm_sqrt_f32((realIn * realIn) + (imagIn * imagIn), pDst++);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+    /* out = sqrt((real * real) + (imag * imag)) */
+    realIn = *pSrc++;
+    imagIn = *pSrc++;
+    /* store the result in the destination buffer. */
+    arm_sqrt_f32((realIn * realIn) + (imagIn * imagIn), pDst++);
+
+    /* Decrement the loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of cmplx_mag group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q15.c
new file mode 100644
index 0000000..445c996
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q15.c
@@ -0,0 +1,141 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mag_q15.c
+ * Description:  Q15 complex magnitude
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_mag
+ * @{
+ */
+
+
+/**
+ * @brief  Q15 complex magnitude
+ * @param  *pSrc points to the complex input vector
+ * @param  *pDst points to the real output vector
+ * @param  numSamples number of complex samples in the input vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function implements 1.15 by 1.15 multiplications and finally output is converted into 2.14 format.
+ */
+
+void arm_cmplx_mag_q15(
+  q15_t * pSrc,
+  q15_t * pDst,
+  uint32_t numSamples)
+{
+  q31_t acc0, acc1;                              /* Accumulators */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+  q31_t in1, in2, in3, in4;
+  q31_t acc2, acc3;
+
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+
+    /* C[0] = sqrt(A[0] * A[0] + A[1] * A[1]) */
+    in1 = *__SIMD32(pSrc)++;
+    in2 = *__SIMD32(pSrc)++;
+    in3 = *__SIMD32(pSrc)++;
+    in4 = *__SIMD32(pSrc)++;
+
+    acc0 = __SMUAD(in1, in1);
+    acc1 = __SMUAD(in2, in2);
+    acc2 = __SMUAD(in3, in3);
+    acc3 = __SMUAD(in4, in4);
+
+    /* store the result in 2.14 format in the destination buffer. */
+    arm_sqrt_q15((q15_t) ((acc0) >> 17), pDst++);
+    arm_sqrt_q15((q15_t) ((acc1) >> 17), pDst++);
+    arm_sqrt_q15((q15_t) ((acc2) >> 17), pDst++);
+    arm_sqrt_q15((q15_t) ((acc3) >> 17), pDst++);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[0] = sqrt(A[0] * A[0] + A[1] * A[1]) */
+    in1 = *__SIMD32(pSrc)++;
+    acc0 = __SMUAD(in1, in1);
+
+    /* store the result in 2.14 format in the destination buffer. */
+    arm_sqrt_q15((q15_t) (acc0 >> 17), pDst++);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+  q15_t real, imag;                              /* Temporary variables to hold input values */
+
+  while (numSamples > 0U)
+  {
+    /* out = sqrt(real * real + imag * imag) */
+    real = *pSrc++;
+    imag = *pSrc++;
+
+    acc0 = (real * real);
+    acc1 = (imag * imag);
+
+    /* store the result in 2.14 format in the destination buffer. */
+    arm_sqrt_q15((q15_t) (((q63_t) acc0 + acc1) >> 17), pDst++);
+
+    /* Decrement the loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of cmplx_mag group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q31.c
new file mode 100644
index 0000000..c1fdfdf
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_q31.c
@@ -0,0 +1,173 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mag_q31.c
+ * Description:  Q31 complex magnitude
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_mag
+ * @{
+ */
+
+/**
+ * @brief  Q31 complex magnitude
+ * @param  *pSrc points to the complex input vector
+ * @param  *pDst points to the real output vector
+ * @param  numSamples number of complex samples in the input vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function implements 1.31 by 1.31 multiplications and finally output is converted into 2.30 format.
+ * Input down scaling is not required.
+ */
+
+void arm_cmplx_mag_q31(
+  q31_t * pSrc,
+  q31_t * pDst,
+  uint32_t numSamples)
+{
+  q31_t real, imag;                              /* Temporary variables to hold input values */
+  q31_t acc0, acc1;                              /* Accumulators */
+  uint32_t blkCnt;                               /* loop counter */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  q31_t real1, real2, imag1, imag2;              /* Temporary variables to hold input values */
+  q31_t out1, out2, out3, out4;                  /* Accumulators */
+  q63_t mul1, mul2, mul3, mul4;                  /* Temporary variables */
+
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* read complex input from source buffer */
+    real1 = pSrc[0];
+    imag1 = pSrc[1];
+    real2 = pSrc[2];
+    imag2 = pSrc[3];
+
+    /* calculate power of input values */
+    mul1 = (q63_t) real1 *real1;
+    mul2 = (q63_t) imag1 *imag1;
+    mul3 = (q63_t) real2 *real2;
+    mul4 = (q63_t) imag2 *imag2;
+
+    /* get the result to 3.29 format */
+    out1 = (q31_t) (mul1 >> 33);
+    out2 = (q31_t) (mul2 >> 33);
+    out3 = (q31_t) (mul3 >> 33);
+    out4 = (q31_t) (mul4 >> 33);
+
+    /* add real and imaginary accumulators */
+    out1 = out1 + out2;
+    out3 = out3 + out4;
+
+    /* read complex input from source buffer */
+    real1 = pSrc[4];
+    imag1 = pSrc[5];
+    real2 = pSrc[6];
+    imag2 = pSrc[7];
+
+    /* calculate square root */
+    arm_sqrt_q31(out1, &pDst[0]);
+
+    /* calculate power of input values */
+    mul1 = (q63_t) real1 *real1;
+
+    /* calculate square root */
+    arm_sqrt_q31(out3, &pDst[1]);
+
+    /* calculate power of input values */
+    mul2 = (q63_t) imag1 *imag1;
+    mul3 = (q63_t) real2 *real2;
+    mul4 = (q63_t) imag2 *imag2;
+
+    /* get the result to 3.29 format */
+    out1 = (q31_t) (mul1 >> 33);
+    out2 = (q31_t) (mul2 >> 33);
+    out3 = (q31_t) (mul3 >> 33);
+    out4 = (q31_t) (mul4 >> 33);
+
+    /* add real and imaginary accumulators */
+    out1 = out1 + out2;
+    out3 = out3 + out4;
+
+    /* calculate square root */
+    arm_sqrt_q31(out1, &pDst[2]);
+
+    /* increment destination by 8 to process next samples */
+    pSrc += 8U;
+
+    /* calculate square root */
+    arm_sqrt_q31(out3, &pDst[3]);
+
+    /* increment destination by 4 to process next samples */
+    pDst += 4U;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+  blkCnt = numSamples;
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  while (blkCnt > 0U)
+  {
+    /* C[0] = sqrt(A[0] * A[0] + A[1] * A[1]) */
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (q31_t) (((q63_t) real * real) >> 33);
+    acc1 = (q31_t) (((q63_t) imag * imag) >> 33);
+    /* store the result in 2.30 format in the destination buffer. */
+    arm_sqrt_q31(acc0 + acc1, pDst++);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+}
+
+/**
+ * @} end of cmplx_mag group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_f32.c
new file mode 100644
index 0000000..a7a34a3
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_f32.c
@@ -0,0 +1,204 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mag_squared_f32.c
+ * Description:  Floating-point complex magnitude squared
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @defgroup cmplx_mag_squared Complex Magnitude Squared
+ *
+ * Computes the magnitude squared of the elements of a complex data vector.
+ *
+ * The pSrc points to the source data and
+ * pDst points to the where the result should be written.
+ * numSamples specifies the number of complex samples
+ * in the input array and the data is stored in an interleaved fashion
+ * (real, imag, real, imag, ...).
+ * The input array has a total of 2*numSamples values;
+ * the output array has a total of numSamples values.
+ *
+ * The underlying algorithm is used:
+ *
+ * 
+ * for(n=0; n
+ *
+ * There are separate functions for floating-point, Q15, and Q31 data types.
+ */
+
+/**
+ * @addtogroup cmplx_mag_squared
+ * @{
+ */
+
+
+/**
+ * @brief  Floating-point complex magnitude squared
+ * @param[in]  *pSrc points to the complex input vector
+ * @param[out]  *pDst points to the real output vector
+ * @param[in]  numSamples number of complex samples in the input vector
+ * @return none.
+ */
+
+void arm_cmplx_mag_squared_f32(
+  float32_t * pSrc,
+  float32_t * pDst,
+  uint32_t numSamples)
+{
+  float32_t real, imag;                          /* Temporary variables to store real and imaginary values */
+  uint32_t blkCnt;                               /* loop counter */
+
+#if defined (ARM_MATH_DSP)
+  float32_t real1, real2, real3, real4;          /* Temporary variables to hold real values */
+  float32_t imag1, imag2, imag3, imag4;          /* Temporary variables to hold imaginary values */
+  float32_t mul1, mul2, mul3, mul4;              /* Temporary variables */
+  float32_t mul5, mul6, mul7, mul8;              /* Temporary variables */
+  float32_t out1, out2, out3, out4;              /* Temporary variables to hold output values */
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[0] = (A[0] * A[0] + A[1] * A[1]) */
+    /* read real input sample from source buffer */
+    real1 = pSrc[0];
+    /* read imaginary input sample from source buffer */
+    imag1 = pSrc[1];
+
+    /* calculate power of real value */
+    mul1 = real1 * real1;
+
+    /* read real input sample from source buffer */
+    real2 = pSrc[2];
+
+    /* calculate power of imaginary value */
+    mul2 = imag1 * imag1;
+
+    /* read imaginary input sample from source buffer */
+    imag2 = pSrc[3];
+
+    /* calculate power of real value */
+    mul3 = real2 * real2;
+
+    /* read real input sample from source buffer */
+    real3 = pSrc[4];
+
+    /* calculate power of imaginary value */
+    mul4 = imag2 * imag2;
+
+    /* read imaginary input sample from source buffer */
+    imag3 = pSrc[5];
+
+    /* calculate power of real value */
+    mul5 = real3 * real3;
+    /* calculate power of imaginary value */
+    mul6 = imag3 * imag3;
+
+    /* read real input sample from source buffer */
+    real4 = pSrc[6];
+
+    /* accumulate real and imaginary powers */
+    out1 = mul1 + mul2;
+
+    /* read imaginary input sample from source buffer */
+    imag4 = pSrc[7];
+
+    /* accumulate real and imaginary powers */
+    out2 = mul3 + mul4;
+
+    /* calculate power of real value */
+    mul7 = real4 * real4;
+    /* calculate power of imaginary value */
+    mul8 = imag4 * imag4;
+
+    /* store output to destination */
+    pDst[0] = out1;
+
+    /* accumulate real and imaginary powers */
+    out3 = mul5 + mul6;
+
+    /* store output to destination */
+    pDst[1] = out2;
+
+    /* accumulate real and imaginary powers */
+    out4 = mul7 + mul8;
+
+    /* store output to destination */
+    pDst[2] = out3;
+
+    /* increment destination pointer by 8 to process next samples */
+    pSrc += 8U;
+
+    /* store output to destination */
+    pDst[3] = out4;
+
+    /* increment destination pointer by 4 to process next samples */
+    pDst += 4U;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  blkCnt = numSamples;
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  while (blkCnt > 0U)
+  {
+    /* C[0] = (A[0] * A[0] + A[1] * A[1]) */
+    real = *pSrc++;
+    imag = *pSrc++;
+
+    /* out = (real * real) + (imag * imag) */
+    /* store the result in the destination buffer. */
+    *pDst++ = (real * real) + (imag * imag);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+}
+
+/**
+ * @} end of cmplx_mag_squared group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q15.c
new file mode 100644
index 0000000..7876cdc
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q15.c
@@ -0,0 +1,136 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mag_squared_q15.c
+ * Description:  Q15 complex magnitude squared
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_mag_squared
+ * @{
+ */
+
+/**
+ * @brief  Q15 complex magnitude squared
+ * @param  *pSrc points to the complex input vector
+ * @param  *pDst points to the real output vector
+ * @param  numSamples number of complex samples in the input vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function implements 1.15 by 1.15 multiplications and finally output is converted into 3.13 format.
+ */
+
+void arm_cmplx_mag_squared_q15(
+  q15_t * pSrc,
+  q15_t * pDst,
+  uint32_t numSamples)
+{
+  q31_t acc0, acc1;                              /* Accumulators */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+  q31_t in1, in2, in3, in4;
+  q31_t acc2, acc3;
+
+  /*loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[0] = (A[0] * A[0] + A[1] * A[1]) */
+    in1 = *__SIMD32(pSrc)++;
+    in2 = *__SIMD32(pSrc)++;
+    in3 = *__SIMD32(pSrc)++;
+    in4 = *__SIMD32(pSrc)++;
+
+    acc0 = __SMUAD(in1, in1);
+    acc1 = __SMUAD(in2, in2);
+    acc2 = __SMUAD(in3, in3);
+    acc3 = __SMUAD(in4, in4);
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ = (q15_t) (acc0 >> 17);
+    *pDst++ = (q15_t) (acc1 >> 17);
+    *pDst++ = (q15_t) (acc2 >> 17);
+    *pDst++ = (q15_t) (acc3 >> 17);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[0] = (A[0] * A[0] + A[1] * A[1]) */
+    in1 = *__SIMD32(pSrc)++;
+    acc0 = __SMUAD(in1, in1);
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ = (q15_t) (acc0 >> 17);
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+  q15_t real, imag;                              /* Temporary variables to store real and imaginary values */
+
+  while (numSamples > 0U)
+  {
+    /* out = ((real * real) + (imag * imag)) */
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (real * real);
+    acc1 = (imag * imag);
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ = (q15_t) (((q63_t) acc0 + acc1) >> 17);
+
+    /* Decrement the loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of cmplx_mag_squared group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q31.c
new file mode 100644
index 0000000..b9c0c0c
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mag_squared_q31.c
@@ -0,0 +1,149 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mag_squared_q31.c
+ * Description:  Q31 complex magnitude squared
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup cmplx_mag_squared
+ * @{
+ */
+
+
+/**
+ * @brief  Q31 complex magnitude squared
+ * @param  *pSrc points to the complex input vector
+ * @param  *pDst points to the real output vector
+ * @param  numSamples number of complex samples in the input vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function implements 1.31 by 1.31 multiplications and finally output is converted into 3.29 format.
+ * Input down scaling is not required.
+ */
+
+void arm_cmplx_mag_squared_q31(
+  q31_t * pSrc,
+  q31_t * pDst,
+  uint32_t numSamples)
+{
+  q31_t real, imag;                              /* Temporary variables to store real and imaginary values */
+  q31_t acc0, acc1;                              /* Accumulators */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counter */
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[0] = (A[0] * A[0] + A[1] * A[1]) */
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (q31_t) (((q63_t) real * real) >> 33);
+    acc1 = (q31_t) (((q63_t) imag * imag) >> 33);
+    /* store the result in 3.29 format in the destination buffer. */
+    *pDst++ = acc0 + acc1;
+
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (q31_t) (((q63_t) real * real) >> 33);
+    acc1 = (q31_t) (((q63_t) imag * imag) >> 33);
+    /* store the result in 3.29 format in the destination buffer. */
+    *pDst++ = acc0 + acc1;
+
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (q31_t) (((q63_t) real * real) >> 33);
+    acc1 = (q31_t) (((q63_t) imag * imag) >> 33);
+    /* store the result in 3.29 format in the destination buffer. */
+    *pDst++ = acc0 + acc1;
+
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (q31_t) (((q63_t) real * real) >> 33);
+    acc1 = (q31_t) (((q63_t) imag * imag) >> 33);
+    /* store the result in 3.29 format in the destination buffer. */
+    *pDst++ = acc0 + acc1;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[0] = (A[0] * A[0] + A[1] * A[1]) */
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (q31_t) (((q63_t) real * real) >> 33);
+    acc1 = (q31_t) (((q63_t) imag * imag) >> 33);
+    /* store the result in 3.29 format in the destination buffer. */
+    *pDst++ = acc0 + acc1;
+
+    /* Decrement the loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+    /* out = ((real * real) + (imag * imag)) */
+    real = *pSrc++;
+    imag = *pSrc++;
+    acc0 = (q31_t) (((q63_t) real * real) >> 33);
+    acc1 = (q31_t) (((q63_t) imag * imag) >> 33);
+    /* store the result in 3.29 format in the destination buffer. */
+    *pDst++ = acc0 + acc1;
+
+    /* Decrement the loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of cmplx_mag_squared group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_f32.c
new file mode 100644
index 0000000..90af35a
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_f32.c
@@ -0,0 +1,196 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mult_cmplx_f32.c
+ * Description:  Floating-point complex-by-complex multiplication
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @defgroup CmplxByCmplxMult Complex-by-Complex Multiplication
+ *
+ * Multiplies a complex vector by another complex vector and generates a complex result.
+ * The data in the complex arrays is stored in an interleaved fashion
+ * (real, imag, real, imag, ...).
+ * The parameter numSamples represents the number of complex
+ * samples processed.  The complex arrays have a total of 2*numSamples
+ * real values.
+ *
+ * The underlying algorithm is used:
+ *
+ * 
+ * for(n=0; n
+ *
+ * There are separate functions for floating-point, Q15, and Q31 data types.
+ */
+
+/**
+ * @addtogroup CmplxByCmplxMult
+ * @{
+ */
+
+
+/**
+ * @brief  Floating-point complex-by-complex multiplication
+ * @param[in]  *pSrcA points to the first input vector
+ * @param[in]  *pSrcB points to the second input vector
+ * @param[out]  *pDst  points to the output vector
+ * @param[in]  numSamples number of complex samples in each vector
+ * @return none.
+ */
+
+void arm_cmplx_mult_cmplx_f32(
+  float32_t * pSrcA,
+  float32_t * pSrcB,
+  float32_t * pDst,
+  uint32_t numSamples)
+{
+  float32_t a1, b1, c1, d1;                      /* Temporary variables to store real and imaginary values */
+  uint32_t blkCnt;                               /* loop counters */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  float32_t a2, b2, c2, d2;                      /* Temporary variables to store real and imaginary values */
+  float32_t acc1, acc2, acc3, acc4;
+
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a1 = *pSrcA;                /* A[2 * i] */
+    c1 = *pSrcB;                /* B[2 * i] */
+
+    b1 = *(pSrcA + 1);          /* A[2 * i + 1] */
+    acc1 = a1 * c1;             /* acc1 = A[2 * i] * B[2 * i] */
+
+    a2 = *(pSrcA + 2);          /* A[2 * i + 2] */
+    acc2 = (b1 * c1);           /* acc2 = A[2 * i + 1] * B[2 * i] */
+
+    d1 = *(pSrcB + 1);          /* B[2 * i + 1] */
+    c2 = *(pSrcB + 2);          /* B[2 * i + 2] */
+    acc1 -= b1 * d1;            /* acc1 =      A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1] */
+
+    d2 = *(pSrcB + 3);          /* B[2 * i + 3] */
+    acc3 = a2 * c2;             /* acc3 =       A[2 * i + 2] * B[2 * i + 2] */
+
+    b2 = *(pSrcA + 3);          /* A[2 * i + 3] */
+    acc2 += (a1 * d1);          /* acc2 =      A[2 * i + 1] * B[2 * i] + A[2 * i] * B[2 * i + 1] */
+
+    a1 = *(pSrcA + 4);          /* A[2 * i + 4] */
+    acc4 = (a2 * d2);           /* acc4 =   A[2 * i + 2] * B[2 * i + 3] */
+
+    c1 = *(pSrcB + 4);          /* B[2 * i + 4] */
+    acc3 -= (b2 * d2);          /* acc3 =       A[2 * i + 2] * B[2 * i + 2] - A[2 * i + 3] * B[2 * i + 3] */
+    *pDst = acc1;               /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1] */
+
+    b1 = *(pSrcA + 5);          /* A[2 * i + 5] */
+    acc4 += b2 * c2;            /* acc4 =   A[2 * i + 2] * B[2 * i + 3] + A[2 * i + 3] * B[2 * i + 2] */
+
+    *(pDst + 1) = acc2;         /* C[2 * i + 1] = A[2 * i + 1] * B[2 * i] + A[2 * i] * B[2 * i + 1]  */
+    acc1 = (a1 * c1);
+
+    d1 = *(pSrcB + 5);
+    acc2 = (b1 * c1);
+
+    *(pDst + 2) = acc3;
+    *(pDst + 3) = acc4;
+
+    a2 = *(pSrcA + 6);
+    acc1 -= (b1 * d1);
+
+    c2 = *(pSrcB + 6);
+    acc2 += (a1 * d1);
+
+    b2 = *(pSrcA + 7);
+    acc3 = (a2 * c2);
+
+    d2 = *(pSrcB + 7);
+    acc4 = (b2 * c2);
+
+    *(pDst + 4) = acc1;
+    pSrcA += 8U;
+
+    acc3 -= (b2 * d2);
+    acc4 += (a2 * d2);
+
+    *(pDst + 5) = acc2;
+    pSrcB += 8U;
+
+    *(pDst + 6) = acc3;
+    *(pDst + 7) = acc4;
+
+    pDst += 8U;
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+  blkCnt = numSamples;
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a1 = *pSrcA++;
+    b1 = *pSrcA++;
+    c1 = *pSrcB++;
+    d1 = *pSrcB++;
+
+    /* store the result in the destination buffer. */
+    *pDst++ = (a1 * c1) - (b1 * d1);
+    *pDst++ = (a1 * d1) + (b1 * c1);
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+}
+
+/**
+ * @} end of CmplxByCmplxMult group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q15.c
new file mode 100644
index 0000000..1dce470
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q15.c
@@ -0,0 +1,181 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mult_cmplx_q15.c
+ * Description:  Q15 complex-by-complex multiplication
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup CmplxByCmplxMult
+ * @{
+ */
+
+/**
+ * @brief  Q15 complex-by-complex multiplication
+ * @param[in]  *pSrcA points to the first input vector
+ * @param[in]  *pSrcB points to the second input vector
+ * @param[out]  *pDst  points to the output vector
+ * @param[in]  numSamples number of complex samples in each vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function implements 1.15 by 1.15 multiplications and finally output is converted into 3.13 format.
+ */
+
+void arm_cmplx_mult_cmplx_q15(
+  q15_t * pSrcA,
+  q15_t * pSrcB,
+  q15_t * pDst,
+  uint32_t numSamples)
+{
+  q15_t a, b, c, d;                              /* Temporary variables to store real and imaginary values */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counters */
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * c) >> 17) - (((q31_t) b * d) >> 17);
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * d) >> 17) + (((q31_t) b * c) >> 17);
+
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * c) >> 17) - (((q31_t) b * d) >> 17);
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * d) >> 17) + (((q31_t) b * c) >> 17);
+
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * c) >> 17) - (((q31_t) b * d) >> 17);
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * d) >> 17) + (((q31_t) b * c) >> 17);
+
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * c) >> 17) - (((q31_t) b * d) >> 17);
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * d) >> 17) + (((q31_t) b * c) >> 17);
+
+    /* Decrement the blockSize loop counter */
+    blkCnt--;
+  }
+
+  /* If the blockSize is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * c) >> 17) - (((q31_t) b * d) >> 17);
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * d) >> 17) + (((q31_t) b * c) >> 17);
+
+    /* Decrement the blockSize loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * c) >> 17) - (((q31_t) b * d) >> 17);
+    /* store the result in 3.13 format in the destination buffer. */
+    *pDst++ =
+      (q15_t) (q31_t) (((q31_t) a * d) >> 17) + (((q31_t) b * c) >> 17);
+
+    /* Decrement the blockSize loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of CmplxByCmplxMult group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q31.c
new file mode 100644
index 0000000..2eed4e8
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_cmplx_q31.c
@@ -0,0 +1,314 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mult_cmplx_q31.c
+ * Description:  Q31 complex-by-complex multiplication
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup CmplxByCmplxMult
+ * @{
+ */
+
+
+/**
+ * @brief  Q31 complex-by-complex multiplication
+ * @param[in]  *pSrcA points to the first input vector
+ * @param[in]  *pSrcB points to the second input vector
+ * @param[out]  *pDst  points to the output vector
+ * @param[in]  numSamples number of complex samples in each vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function implements 1.31 by 1.31 multiplications and finally output is converted into 3.29 format.
+ * Input down scaling is not required.
+ */
+
+void arm_cmplx_mult_cmplx_q31(
+  q31_t * pSrcA,
+  q31_t * pSrcB,
+  q31_t * pDst,
+  uint32_t numSamples)
+{
+  q31_t a, b, c, d;                              /* Temporary variables to store real and imaginary values */
+  uint32_t blkCnt;                               /* loop counters */
+  q31_t mul1, mul2, mul3, mul4;
+  q31_t out1, out2;
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    /* Decrement the blockSize loop counter */
+    blkCnt--;
+  }
+
+  /* If the blockSize is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    /* Decrement the blockSize loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 1U;
+
+  /* First part of the processing with loop unrolling.  Compute 2 outputs at a time.
+   ** a second loop below computes the remaining 1 sample. */
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    /* Decrement the blockSize loop counter */
+    blkCnt--;
+  }
+
+  /* If the blockSize is not a multiple of 2, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x2U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[2 * i] - A[2 * i + 1] * B[2 * i + 1].  */
+    /* C[2 * i + 1] = A[2 * i] * B[2 * i + 1] + A[2 * i + 1] * B[2 * i].  */
+    a = *pSrcA++;
+    b = *pSrcA++;
+    c = *pSrcB++;
+    d = *pSrcB++;
+
+    mul1 = (q31_t) (((q63_t) a * c) >> 32);
+    mul2 = (q31_t) (((q63_t) b * d) >> 32);
+    mul3 = (q31_t) (((q63_t) a * d) >> 32);
+    mul4 = (q31_t) (((q63_t) b * c) >> 32);
+
+    mul1 = (mul1 >> 1);
+    mul2 = (mul2 >> 1);
+    mul3 = (mul3 >> 1);
+    mul4 = (mul4 >> 1);
+
+    out1 = mul1 - mul2;
+    out2 = mul3 + mul4;
+
+    /* store the real result in 3.29 format in the destination buffer. */
+    *pDst++ = out1;
+    /* store the imag result in 3.29 format in the destination buffer. */
+    *pDst++ = out2;
+
+    /* Decrement the blockSize loop counter */
+    blkCnt--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of CmplxByCmplxMult group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_f32.c
new file mode 100644
index 0000000..6f45804
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_f32.c
@@ -0,0 +1,213 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mult_real_f32.c
+ * Description:  Floating-point complex by real multiplication
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @defgroup CmplxByRealMult Complex-by-Real Multiplication
+ *
+ * Multiplies a complex vector by a real vector and generates a complex result.
+ * The data in the complex arrays is stored in an interleaved fashion
+ * (real, imag, real, imag, ...).
+ * The parameter numSamples represents the number of complex
+ * samples processed.  The complex arrays have a total of 2*numSamples
+ * real values while the real array has a total of numSamples
+ * real values.
+ *
+ * The underlying algorithm is used:
+ *
+ * 
+ * for(n=0; n
+ *
+ * There are separate functions for floating-point, Q15, and Q31 data types.
+ */
+
+/**
+ * @addtogroup CmplxByRealMult
+ * @{
+ */
+
+
+/**
+ * @brief  Floating-point complex-by-real multiplication
+ * @param[in]  *pSrcCmplx points to the complex input vector
+ * @param[in]  *pSrcReal points to the real input vector
+ * @param[out]  *pCmplxDst points to the complex output vector
+ * @param[in]  numSamples number of samples in each vector
+ * @return none.
+ */
+
+void arm_cmplx_mult_real_f32(
+  float32_t * pSrcCmplx,
+  float32_t * pSrcReal,
+  float32_t * pCmplxDst,
+  uint32_t numSamples)
+{
+  float32_t in;                                  /* Temporary variable to store input value */
+  uint32_t blkCnt;                               /* loop counters */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  float32_t inA1, inA2, inA3, inA4;              /* Temporary variables to hold input data */
+  float32_t inA5, inA6, inA7, inA8;              /* Temporary variables to hold input data */
+  float32_t inB1, inB2, inB3, inB4;              /* Temporary variables to hold input data */
+  float32_t out1, out2, out3, out4;              /* Temporary variables to hold output data */
+  float32_t out5, out6, out7, out8;              /* Temporary variables to hold output data */
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[i].            */
+    /* C[2 * i + 1] = A[2 * i + 1] * B[i].        */
+    /* read input from complex input buffer */
+    inA1 = pSrcCmplx[0];
+    inA2 = pSrcCmplx[1];
+    /* read input from real input buffer */
+    inB1 = pSrcReal[0];
+
+    /* read input from complex input buffer */
+    inA3 = pSrcCmplx[2];
+
+    /* multiply complex buffer real input with real buffer input */
+    out1 = inA1 * inB1;
+
+    /* read input from complex input buffer */
+    inA4 = pSrcCmplx[3];
+
+    /* multiply complex buffer imaginary input with real buffer input */
+    out2 = inA2 * inB1;
+
+    /* read input from real input buffer */
+    inB2 = pSrcReal[1];
+    /* read input from complex input buffer */
+    inA5 = pSrcCmplx[4];
+
+    /* multiply complex buffer real input with real buffer input */
+    out3 = inA3 * inB2;
+
+    /* read input from complex input buffer */
+    inA6 = pSrcCmplx[5];
+    /* read input from real input buffer */
+    inB3 = pSrcReal[2];
+
+    /* multiply complex buffer imaginary input with real buffer input */
+    out4 = inA4 * inB2;
+
+    /* read input from complex input buffer */
+    inA7 = pSrcCmplx[6];
+
+    /* multiply complex buffer real input with real buffer input */
+    out5 = inA5 * inB3;
+
+    /* read input from complex input buffer */
+    inA8 = pSrcCmplx[7];
+
+    /* multiply complex buffer imaginary input with real buffer input */
+    out6 = inA6 * inB3;
+
+    /* read input from real input buffer */
+    inB4 = pSrcReal[3];
+
+    /* store result to destination bufer */
+    pCmplxDst[0] = out1;
+
+    /* multiply complex buffer real input with real buffer input */
+    out7 = inA7 * inB4;
+
+    /* store result to destination bufer */
+    pCmplxDst[1] = out2;
+
+    /* multiply complex buffer imaginary input with real buffer input */
+    out8 = inA8 * inB4;
+
+    /* store result to destination bufer */
+    pCmplxDst[2] = out3;
+    pCmplxDst[3] = out4;
+    pCmplxDst[4] = out5;
+
+    /* incremnet complex input buffer by 8 to process next samples */
+    pSrcCmplx += 8U;
+
+    /* store result to destination bufer */
+    pCmplxDst[5] = out6;
+
+    /* increment real input buffer by 4 to process next samples */
+    pSrcReal += 4U;
+
+    /* store result to destination bufer */
+    pCmplxDst[6] = out7;
+    pCmplxDst[7] = out8;
+
+    /* increment destination buffer by 8 to process next sampels */
+    pCmplxDst += 8U;
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+  blkCnt = numSamples;
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[i].            */
+    /* C[2 * i + 1] = A[2 * i + 1] * B[i].        */
+    in = *pSrcReal++;
+    /* store the result in the destination buffer. */
+    *pCmplxDst++ = (*pSrcCmplx++) * (in);
+    *pCmplxDst++ = (*pSrcCmplx++) * (in);
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+}
+
+/**
+ * @} end of CmplxByRealMult group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q15.c
new file mode 100644
index 0000000..abafc3b
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q15.c
@@ -0,0 +1,191 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mult_real_q15.c
+ * Description:  Q15 complex by real multiplication
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup CmplxByRealMult
+ * @{
+ */
+
+
+/**
+ * @brief  Q15 complex-by-real multiplication
+ * @param[in]  *pSrcCmplx points to the complex input vector
+ * @param[in]  *pSrcReal points to the real input vector
+ * @param[out]  *pCmplxDst points to the complex output vector
+ * @param[in]  numSamples number of samples in each vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function uses saturating arithmetic.
+ * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated.
+ */
+
+void arm_cmplx_mult_real_q15(
+  q15_t * pSrcCmplx,
+  q15_t * pSrcReal,
+  q15_t * pCmplxDst,
+  uint32_t numSamples)
+{
+  q15_t in;                                      /* Temporary variable to store input value */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counters */
+  q31_t inA1, inA2;                              /* Temporary variables to hold input data */
+  q31_t inB1;                                    /* Temporary variables to hold input data */
+  q15_t out1, out2, out3, out4;                  /* Temporary variables to hold output data */
+  q31_t mul1, mul2, mul3, mul4;                  /* Temporary variables to hold intermediate data */
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[i].            */
+    /* C[2 * i + 1] = A[2 * i + 1] * B[i].        */
+    /* read complex number both real and imaginary from complex input buffer */
+    inA1 = *__SIMD32(pSrcCmplx)++;
+    /* read two real values at a time from real input buffer */
+    inB1 = *__SIMD32(pSrcReal)++;
+    /* read complex number both real and imaginary from complex input buffer */
+    inA2 = *__SIMD32(pSrcCmplx)++;
+
+    /* multiply complex number with real numbers */
+#ifndef ARM_MATH_BIG_ENDIAN
+
+    mul1 = (q31_t) ((q15_t) (inA1) * (q15_t) (inB1));
+    mul2 = (q31_t) ((q15_t) (inA1 >> 16) * (q15_t) (inB1));
+    mul3 = (q31_t) ((q15_t) (inA2) * (q15_t) (inB1 >> 16));
+    mul4 = (q31_t) ((q15_t) (inA2 >> 16) * (q15_t) (inB1 >> 16));
+
+#else
+
+    mul2 = (q31_t) ((q15_t) (inA1 >> 16) * (q15_t) (inB1 >> 16));
+    mul1 = (q31_t) ((q15_t) inA1 * (q15_t) (inB1 >> 16));
+    mul4 = (q31_t) ((q15_t) (inA2 >> 16) * (q15_t) inB1);
+    mul3 = (q31_t) ((q15_t) inA2 * (q15_t) inB1);
+
+#endif /* #ifndef ARM_MATH_BIG_ENDIAN */
+
+    /* saturate the result */
+    out1 = (q15_t) __SSAT(mul1 >> 15U, 16);
+    out2 = (q15_t) __SSAT(mul2 >> 15U, 16);
+    out3 = (q15_t) __SSAT(mul3 >> 15U, 16);
+    out4 = (q15_t) __SSAT(mul4 >> 15U, 16);
+
+    /* pack real and imaginary outputs and store them to destination */
+    *__SIMD32(pCmplxDst)++ = __PKHBT(out1, out2, 16);
+    *__SIMD32(pCmplxDst)++ = __PKHBT(out3, out4, 16);
+
+    inA1 = *__SIMD32(pSrcCmplx)++;
+    inB1 = *__SIMD32(pSrcReal)++;
+    inA2 = *__SIMD32(pSrcCmplx)++;
+
+#ifndef ARM_MATH_BIG_ENDIAN
+
+    mul1 = (q31_t) ((q15_t) (inA1) * (q15_t) (inB1));
+    mul2 = (q31_t) ((q15_t) (inA1 >> 16) * (q15_t) (inB1));
+    mul3 = (q31_t) ((q15_t) (inA2) * (q15_t) (inB1 >> 16));
+    mul4 = (q31_t) ((q15_t) (inA2 >> 16) * (q15_t) (inB1 >> 16));
+
+#else
+
+    mul2 = (q31_t) ((q15_t) (inA1 >> 16) * (q15_t) (inB1 >> 16));
+    mul1 = (q31_t) ((q15_t) inA1 * (q15_t) (inB1 >> 16));
+    mul4 = (q31_t) ((q15_t) (inA2 >> 16) * (q15_t) inB1);
+    mul3 = (q31_t) ((q15_t) inA2 * (q15_t) inB1);
+
+#endif /* #ifndef ARM_MATH_BIG_ENDIAN */
+
+    out1 = (q15_t) __SSAT(mul1 >> 15U, 16);
+    out2 = (q15_t) __SSAT(mul2 >> 15U, 16);
+    out3 = (q15_t) __SSAT(mul3 >> 15U, 16);
+    out4 = (q15_t) __SSAT(mul4 >> 15U, 16);
+
+    *__SIMD32(pCmplxDst)++ = __PKHBT(out1, out2, 16);
+    *__SIMD32(pCmplxDst)++ = __PKHBT(out3, out4, 16);
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[i].            */
+    /* C[2 * i + 1] = A[2 * i + 1] * B[i].        */
+    in = *pSrcReal++;
+    /* store the result in the destination buffer. */
+    *pCmplxDst++ =
+      (q15_t) __SSAT((((q31_t) (*pSrcCmplx++) * (in)) >> 15), 16);
+    *pCmplxDst++ =
+      (q15_t) __SSAT((((q31_t) (*pSrcCmplx++) * (in)) >> 15), 16);
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+    /* realOut = realA * realB.            */
+    /* imagOut = imagA * realB.                */
+    in = *pSrcReal++;
+    /* store the result in the destination buffer. */
+    *pCmplxDst++ =
+      (q15_t) __SSAT((((q31_t) (*pSrcCmplx++) * (in)) >> 15), 16);
+    *pCmplxDst++ =
+      (q15_t) __SSAT((((q31_t) (*pSrcCmplx++) * (in)) >> 15), 16);
+
+    /* Decrement the numSamples loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of CmplxByRealMult group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q31.c
new file mode 100644
index 0000000..aaa3ec0
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ComplexMathFunctions/arm_cmplx_mult_real_q31.c
@@ -0,0 +1,211 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cmplx_mult_real_q31.c
+ * Description:  Q31 complex by real multiplication
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+/**
+ * @ingroup groupCmplxMath
+ */
+
+/**
+ * @addtogroup CmplxByRealMult
+ * @{
+ */
+
+
+/**
+ * @brief  Q31 complex-by-real multiplication
+ * @param[in]  *pSrcCmplx points to the complex input vector
+ * @param[in]  *pSrcReal points to the real input vector
+ * @param[out]  *pCmplxDst points to the complex output vector
+ * @param[in]  numSamples number of samples in each vector
+ * @return none.
+ *
+ * Scaling and Overflow Behavior:
+ * \par
+ * The function uses saturating arithmetic.
+ * Results outside of the allowable Q31 range[0x80000000 0x7FFFFFFF] will be saturated.
+ */
+
+void arm_cmplx_mult_real_q31(
+  q31_t * pSrcCmplx,
+  q31_t * pSrcReal,
+  q31_t * pCmplxDst,
+  uint32_t numSamples)
+{
+  q31_t inA1;                                    /* Temporary variable to store input value */
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+  uint32_t blkCnt;                               /* loop counters */
+  q31_t inA2, inA3, inA4;                        /* Temporary variables to hold input data */
+  q31_t inB1, inB2;                              /* Temporary variabels to hold input data */
+  q31_t out1, out2, out3, out4;                  /* Temporary variables to hold output data */
+
+  /* loop Unrolling */
+  blkCnt = numSamples >> 2U;
+
+  /* First part of the processing with loop unrolling.  Compute 4 outputs at a time.
+   ** a second loop below computes the remaining 1 to 3 samples. */
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[i].            */
+    /* C[2 * i + 1] = A[2 * i + 1] * B[i].        */
+    /* read real input from complex input buffer */
+    inA1 = *pSrcCmplx++;
+    inA2 = *pSrcCmplx++;
+    /* read input from real input bufer */
+    inB1 = *pSrcReal++;
+    inB2 = *pSrcReal++;
+    /* read imaginary input from complex input buffer */
+    inA3 = *pSrcCmplx++;
+    inA4 = *pSrcCmplx++;
+
+    /* multiply complex input with real input */
+    out1 = ((q63_t) inA1 * inB1) >> 32;
+    out2 = ((q63_t) inA2 * inB1) >> 32;
+    out3 = ((q63_t) inA3 * inB2) >> 32;
+    out4 = ((q63_t) inA4 * inB2) >> 32;
+
+    /* sature the result */
+    out1 = __SSAT(out1, 31);
+    out2 = __SSAT(out2, 31);
+    out3 = __SSAT(out3, 31);
+    out4 = __SSAT(out4, 31);
+
+    /* get result in 1.31 format */
+    out1 = out1 << 1;
+    out2 = out2 << 1;
+    out3 = out3 << 1;
+    out4 = out4 << 1;
+
+    /* store the result to destination buffer */
+    *pCmplxDst++ = out1;
+    *pCmplxDst++ = out2;
+    *pCmplxDst++ = out3;
+    *pCmplxDst++ = out4;
+
+    /* read real input from complex input buffer */
+    inA1 = *pSrcCmplx++;
+    inA2 = *pSrcCmplx++;
+    /* read input from real input bufer */
+    inB1 = *pSrcReal++;
+    inB2 = *pSrcReal++;
+    /* read imaginary input from complex input buffer */
+    inA3 = *pSrcCmplx++;
+    inA4 = *pSrcCmplx++;
+
+    /* multiply complex input with real input */
+    out1 = ((q63_t) inA1 * inB1) >> 32;
+    out2 = ((q63_t) inA2 * inB1) >> 32;
+    out3 = ((q63_t) inA3 * inB2) >> 32;
+    out4 = ((q63_t) inA4 * inB2) >> 32;
+
+    /* sature the result */
+    out1 = __SSAT(out1, 31);
+    out2 = __SSAT(out2, 31);
+    out3 = __SSAT(out3, 31);
+    out4 = __SSAT(out4, 31);
+
+    /* get result in 1.31 format */
+    out1 = out1 << 1;
+    out2 = out2 << 1;
+    out3 = out3 << 1;
+    out4 = out4 << 1;
+
+    /* store the result to destination buffer */
+    *pCmplxDst++ = out1;
+    *pCmplxDst++ = out2;
+    *pCmplxDst++ = out3;
+    *pCmplxDst++ = out4;
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+
+  /* If the numSamples is not a multiple of 4, compute any remaining output samples here.
+   ** No loop unrolling is used. */
+  blkCnt = numSamples % 0x4U;
+
+  while (blkCnt > 0U)
+  {
+    /* C[2 * i] = A[2 * i] * B[i].            */
+    /* C[2 * i + 1] = A[2 * i + 1] * B[i].        */
+    /* read real input from complex input buffer */
+    inA1 = *pSrcCmplx++;
+    inA2 = *pSrcCmplx++;
+    /* read input from real input bufer */
+    inB1 = *pSrcReal++;
+
+    /* multiply complex input with real input */
+    out1 = ((q63_t) inA1 * inB1) >> 32;
+    out2 = ((q63_t) inA2 * inB1) >> 32;
+
+    /* sature the result */
+    out1 = __SSAT(out1, 31);
+    out2 = __SSAT(out2, 31);
+
+    /* get result in 1.31 format */
+    out1 = out1 << 1;
+    out2 = out2 << 1;
+
+    /* store the result to destination buffer */
+    *pCmplxDst++ = out1;
+    *pCmplxDst++ = out2;
+
+    /* Decrement the numSamples loop counter */
+    blkCnt--;
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  while (numSamples > 0U)
+  {
+    /* realOut = realA * realB.            */
+    /* imagReal = imagA * realB.               */
+    inA1 = *pSrcReal++;
+    /* store the result in the destination buffer. */
+    *pCmplxDst++ =
+      (q31_t) clip_q63_to_q31(((q63_t) * pSrcCmplx++ * inA1) >> 31);
+    *pCmplxDst++ =
+      (q31_t) clip_q63_to_q31(((q63_t) * pSrcCmplx++ * inA1) >> 31);
+
+    /* Decrement the numSamples loop counter */
+    numSamples--;
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of CmplxByRealMult group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_f32.c
new file mode 100644
index 0000000..e729500
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_f32.c
@@ -0,0 +1,74 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_pid_init_f32.c
+ * Description:  Floating-point PID Control initialization function
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+ /**
+ * @addtogroup PID
+ * @{
+ */
+
+/**
+ * @brief  Initialization function for the floating-point PID Control.
+ * @param[in,out] *S points to an instance of the PID structure.
+ * @param[in]     resetStateFlag  flag to reset the state. 0 = no change in state & 1 = reset the state.
+ * @return none.
+ * \par Description:
+ * \par
+ * The resetStateFlag specifies whether to set state to zero or not. \n
+ * The function computes the structure fields: A0, A1 A2
+ * using the proportional gain( \c Kp), integral gain( \c Ki) and derivative gain( \c Kd)
+ * also sets the state variables to all zeros.
+ */
+
+void arm_pid_init_f32(
+  arm_pid_instance_f32 * S,
+  int32_t resetStateFlag)
+{
+
+  /* Derived coefficient A0 */
+  S->A0 = S->Kp + S->Ki + S->Kd;
+
+  /* Derived coefficient A1 */
+  S->A1 = (-S->Kp) - ((float32_t) 2.0 * S->Kd);
+
+  /* Derived coefficient A2 */
+  S->A2 = S->Kd;
+
+  /* Check whether state needs reset or not */
+  if (resetStateFlag)
+  {
+    /* Clear the state buffer.  The size will be always 3 samples */
+    memset(S->state, 0, 3U * sizeof(float32_t));
+  }
+
+}
+
+/**
+ * @} end of PID group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q15.c
new file mode 100644
index 0000000..0f83f35
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q15.c
@@ -0,0 +1,110 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_pid_init_q15.c
+ * Description:  Q15 PID Control initialization function
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+ /**
+ * @addtogroup PID
+ * @{
+ */
+
+/**
+ * @details
+ * @param[in,out] *S points to an instance of the Q15 PID structure.
+ * @param[in]     resetStateFlag  flag to reset the state. 0 = no change in state 1 = reset the state.
+ * @return none.
+ * \par Description:
+ * \par
+ * The resetStateFlag specifies whether to set state to zero or not. \n
+ * The function computes the structure fields: A0, A1 A2
+ * using the proportional gain( \c Kp), integral gain( \c Ki) and derivative gain( \c Kd)
+ * also sets the state variables to all zeros.
+ */
+
+void arm_pid_init_q15(
+  arm_pid_instance_q15 * S,
+  int32_t resetStateFlag)
+{
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+
+  /* Derived coefficient A0 */
+  S->A0 = __QADD16(__QADD16(S->Kp, S->Ki), S->Kd);
+
+  /* Derived coefficients and pack into A1 */
+
+#ifndef  ARM_MATH_BIG_ENDIAN
+
+  S->A1 = __PKHBT(-__QADD16(__QADD16(S->Kd, S->Kd), S->Kp), S->Kd, 16);
+
+#else
+
+  S->A1 = __PKHBT(S->Kd, -__QADD16(__QADD16(S->Kd, S->Kd), S->Kp), 16);
+
+#endif /*      #ifndef  ARM_MATH_BIG_ENDIAN    */
+
+  /* Check whether state needs reset or not */
+  if (resetStateFlag)
+  {
+    /* Clear the state buffer.  The size will be always 3 samples */
+    memset(S->state, 0, 3U * sizeof(q15_t));
+  }
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  q31_t temp;                                    /*to store the sum */
+
+  /* Derived coefficient A0 */
+  temp = S->Kp + S->Ki + S->Kd;
+  S->A0 = (q15_t) __SSAT(temp, 16);
+
+  /* Derived coefficients and pack into A1 */
+  temp = -(S->Kd + S->Kd + S->Kp);
+  S->A1 = (q15_t) __SSAT(temp, 16);
+  S->A2 = S->Kd;
+
+
+
+  /* Check whether state needs reset or not */
+  if (resetStateFlag)
+  {
+    /* Clear the state buffer.  The size will be always 3 samples */
+    memset(S->state, 0, 3U * sizeof(q15_t));
+  }
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+}
+
+/**
+ * @} end of PID group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q31.c
new file mode 100644
index 0000000..ce2936e
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_init_q31.c
@@ -0,0 +1,95 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_pid_init_q31.c
+ * Description:  Q31 PID Control initialization function
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+ /**
+ * @addtogroup PID
+ * @{
+ */
+
+/**
+ * @brief  Initialization function for the Q31 PID Control.
+ * @param[in,out] *S points to an instance of the Q31 PID structure.
+ * @param[in]     resetStateFlag  flag to reset the state. 0 = no change in state 1 = reset the state.
+ * @return none.
+ * \par Description:
+ * \par
+ * The resetStateFlag specifies whether to set state to zero or not. \n
+ * The function computes the structure fields: A0, A1 A2
+ * using the proportional gain( \c Kp), integral gain( \c Ki) and derivative gain( \c Kd)
+ * also sets the state variables to all zeros.
+ */
+
+void arm_pid_init_q31(
+  arm_pid_instance_q31 * S,
+  int32_t resetStateFlag)
+{
+
+#if defined (ARM_MATH_DSP)
+
+  /* Run the below code for Cortex-M4 and Cortex-M3 */
+
+  /* Derived coefficient A0 */
+  S->A0 = __QADD(__QADD(S->Kp, S->Ki), S->Kd);
+
+  /* Derived coefficient A1 */
+  S->A1 = -__QADD(__QADD(S->Kd, S->Kd), S->Kp);
+
+
+#else
+
+  /* Run the below code for Cortex-M0 */
+
+  q31_t temp;
+
+  /* Derived coefficient A0 */
+  temp = clip_q63_to_q31((q63_t) S->Kp + S->Ki);
+  S->A0 = clip_q63_to_q31((q63_t) temp + S->Kd);
+
+  /* Derived coefficient A1 */
+  temp = clip_q63_to_q31((q63_t) S->Kd + S->Kd);
+  S->A1 = -clip_q63_to_q31((q63_t) temp + S->Kp);
+
+#endif /* #if defined (ARM_MATH_DSP) */
+
+  /* Derived coefficient A2 */
+  S->A2 = S->Kd;
+
+  /* Check whether state needs reset or not */
+  if (resetStateFlag)
+  {
+    /* Clear the state buffer.  The size will be always 3 samples */
+    memset(S->state, 0, 3U * sizeof(q31_t));
+  }
+
+}
+
+/**
+ * @} end of PID group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_f32.c
new file mode 100644
index 0000000..acc1709
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_f32.c
@@ -0,0 +1,53 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_pid_reset_f32.c
+ * Description:  Floating-point PID Control reset function
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+ /**
+ * @addtogroup PID
+ * @{
+ */
+
+/**
+* @brief  Reset function for the floating-point PID Control.
+* @param[in] *S	Instance pointer of PID control data structure.
+* @return none.
+* \par Description:
+* The function resets the state buffer to zeros.
+*/
+void arm_pid_reset_f32(
+  arm_pid_instance_f32 * S)
+{
+
+  /* Clear the state buffer.  The size will be always 3 samples */
+  memset(S->state, 0, 3U * sizeof(float32_t));
+}
+
+/**
+ * @} end of PID group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q15.c
new file mode 100644
index 0000000..59c4416
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q15.c
@@ -0,0 +1,52 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_pid_reset_q15.c
+ * Description:  Q15 PID Control reset function
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+ /**
+ * @addtogroup PID
+ * @{
+ */
+
+/**
+* @brief  Reset function for the Q15 PID Control.
+* @param[in] *S		Instance pointer of PID control data structure.
+* @return none.
+* \par Description:
+* The function resets the state buffer to zeros.
+*/
+void arm_pid_reset_q15(
+  arm_pid_instance_q15 * S)
+{
+  /* Reset state to zero, The size will be always 3 samples */
+  memset(S->state, 0, 3U * sizeof(q15_t));
+}
+
+/**
+ * @} end of PID group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q31.c
new file mode 100644
index 0000000..7112a77
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_pid_reset_q31.c
@@ -0,0 +1,53 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_pid_reset_q31.c
+ * Description:  Q31 PID Control reset function
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+
+ /**
+ * @addtogroup PID
+ * @{
+ */
+
+/**
+* @brief  Reset function for the Q31 PID Control.
+* @param[in] *S	Instance pointer of PID control data structure.
+* @return none.
+* \par Description:
+* The function resets the state buffer to zeros.
+*/
+void arm_pid_reset_q31(
+  arm_pid_instance_q31 * S)
+{
+
+  /* Clear the state buffer.  The size will be always 3 samples */
+  memset(S->state, 0, 3U * sizeof(q31_t));
+}
+
+/**
+ * @} end of PID group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_f32.c
new file mode 100644
index 0000000..2aff091
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_f32.c
@@ -0,0 +1,144 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_sin_cos_f32.c
+ * Description:  Sine and Cosine calculation for floating-point values
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+#include "arm_common_tables.h"
+
+/**
+ * @ingroup groupController
+ */
+
+/**
+ * @defgroup SinCos Sine Cosine
+ *
+ * Computes the trigonometric sine and cosine values using a combination of table lookup
+ * and linear interpolation.
+ * There are separate functions for Q31 and floating-point data types.
+ * The input to the floating-point version is in degrees while the
+ * fixed-point Q31 have a scaled input with the range
+ * [-1 0.9999] mapping to [-180 +180] degrees.
+ *
+ * The floating point function also allows values that are out of the usual range. When this happens, the function will
+ * take extra time to adjust the input value to the range of [-180 180].
+ *
+ * The result is accurate to 5 digits after the decimal point.
+ *
+ * The implementation is based on table lookup using 360 values together with linear interpolation.
+ * The steps used are:
+ *  -# Calculation of the nearest integer table index.
+ *  -# Compute the fractional portion (fract) of the input.
+ *  -# Fetch the value corresponding to \c index from sine table to \c y0 and also value from \c index+1 to \c y1.
+ *  -# Sine value is computed as  *psinVal = y0 + (fract * (y1 - y0)).
+ *  -# Fetch the value corresponding to \c index from cosine table to \c y0 and also value from \c index+1 to \c y1.
+ *  -# Cosine value is computed as  *pcosVal = y0 + (fract * (y1 - y0)).
+ */
+
+ /**
+ * @addtogroup SinCos
+ * @{
+ */
+
+/**
+ * @brief  Floating-point sin_cos function.
+ * @param[in]  theta    input value in degrees
+ * @param[out] *pSinVal points to the processed sine output.
+ * @param[out] *pCosVal points to the processed cos output.
+ * @return none.
+ */
+
+void arm_sin_cos_f32(
+                      float32_t theta,
+                      float32_t * pSinVal,
+                      float32_t * pCosVal)
+{
+    float32_t fract, in;                             /* Temporary variables for input, output */
+    uint16_t indexS, indexC;                         /* Index variable */
+    float32_t f1, f2, d1, d2;                        /* Two nearest output values */
+    float32_t findex, Dn, Df, temp;
+
+    /* input x is in degrees */
+    /* Scale the input, divide input by 360, for cosine add 0.25 (pi/2) to read sine table */
+    in = theta * 0.00277777777778f;
+
+    if (in < 0.0f)
+    {
+        in = -in;
+    }
+
+    in = in - (int32_t)in;
+
+    /* Calculation of index of the table */
+    findex = (float32_t) FAST_MATH_TABLE_SIZE * in;
+    indexS = ((uint16_t)findex) & 0x1ff;
+    indexC = (indexS + (FAST_MATH_TABLE_SIZE / 4)) & 0x1ff;
+
+    /* fractional value calculation */
+    fract = findex - (float32_t) indexS;
+
+    /* Read two nearest values of input value from the cos & sin tables */
+    f1 = sinTable_f32[indexC+0];
+    f2 = sinTable_f32[indexC+1];
+    d1 = -sinTable_f32[indexS+0];
+    d2 = -sinTable_f32[indexS+1];
+
+    temp = (1.0f - fract) * f1 + fract * f2;
+
+    Dn = 0.0122718463030f; // delta between the two points (fixed), in this case 2*pi/FAST_MATH_TABLE_SIZE
+    Df = f2 - f1;          // delta between the values of the functions
+
+    temp = Dn *(d1 + d2) - 2 * Df;
+    temp = fract * temp + (3 * Df - (d2 + 2 * d1) * Dn);
+    temp = fract * temp + d1 * Dn;
+
+    /* Calculation of cosine value */
+    *pCosVal = fract * temp + f1;
+
+    /* Read two nearest values of input value from the cos & sin tables */
+    f1 = sinTable_f32[indexS+0];
+    f2 = sinTable_f32[indexS+1];
+    d1 = sinTable_f32[indexC+0];
+    d2 = sinTable_f32[indexC+1];
+
+    temp = (1.0f - fract) * f1 + fract * f2;
+
+    Df = f2 - f1; // delta between the values of the functions
+    temp = Dn*(d1 + d2) - 2*Df;
+    temp = fract*temp + (3*Df - (d2 + 2*d1)*Dn);
+    temp = fract*temp + d1*Dn;
+
+    /* Calculation of sine value */
+    *pSinVal = fract*temp + f1;
+
+    if (theta < 0.0f)
+    {
+        *pSinVal = -*pSinVal;
+    }
+}
+/**
+ * @} end of SinCos group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_q31.c
new file mode 100644
index 0000000..c1c33ec
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/ControllerFunctions/arm_sin_cos_q31.c
@@ -0,0 +1,110 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_sin_cos_q31.c
+ * Description:  Cosine & Sine calculation for Q31 values
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+#include "arm_common_tables.h"
+
+/**
+ * @ingroup groupController
+ */
+
+ /**
+ * @addtogroup SinCos
+ * @{
+ */
+
+/**
+ * @brief  Q31 sin_cos function.
+ * @param[in]  theta    scaled input value in degrees
+ * @param[out] *pSinVal points to the processed sine output.
+ * @param[out] *pCosVal points to the processed cosine output.
+ * @return none.
+ *
+ * The Q31 input value is in the range [-1 0.999999] and is mapped to a degree value in the range [-180 179].
+ *
+ */
+
+void arm_sin_cos_q31(
+  q31_t theta,
+  q31_t * pSinVal,
+  q31_t * pCosVal)
+{
+  q31_t fract;                                 /* Temporary variables for input, output */
+  uint16_t indexS, indexC;                     /* Index variable */
+  q31_t f1, f2, d1, d2;                        /* Two nearest output values */
+  q31_t Dn, Df;
+  q63_t temp;
+
+  /* Calculate the nearest index */
+  indexS = (uint32_t)theta >> CONTROLLER_Q31_SHIFT;
+  indexC = (indexS + 128) & 0x1ff;
+
+  /* Calculation of fractional value */
+  fract = (theta - (indexS << CONTROLLER_Q31_SHIFT)) << 8;
+
+  /* Read two nearest values of input value from the cos & sin tables */
+  f1 = sinTable_q31[indexC+0];
+  f2 = sinTable_q31[indexC+1];
+  d1 = -sinTable_q31[indexS+0];
+  d2 = -sinTable_q31[indexS+1];
+
+  Dn = 0x1921FB5; // delta between the two points (fixed), in this case 2*pi/FAST_MATH_TABLE_SIZE
+  Df = f2 - f1; // delta between the values of the functions
+  temp = Dn*((q63_t)d1 + d2);
+  temp = temp - ((q63_t)Df << 32);
+  temp = (q63_t)fract*(temp >> 31);
+  temp = temp + ((3*(q63_t)Df << 31) - (d2 + ((q63_t)d1 << 1))*Dn);
+  temp = (q63_t)fract*(temp >> 31);
+  temp = temp + (q63_t)d1*Dn;
+  temp = (q63_t)fract*(temp >> 31);
+
+  /* Calculation of cosine value */
+  *pCosVal = clip_q63_to_q31((temp >> 31) + (q63_t)f1);
+
+  /* Read two nearest values of input value from the cos & sin tables */
+  f1 = sinTable_q31[indexS+0];
+  f2 = sinTable_q31[indexS+1];
+  d1 = sinTable_q31[indexC+0];
+  d2 = sinTable_q31[indexC+1];
+
+  Df = f2 - f1; // delta between the values of the functions
+  temp = Dn*((q63_t)d1 + d2);
+  temp = temp - ((q63_t)Df << 32);
+  temp = (q63_t)fract*(temp >> 31);
+  temp = temp + ((3*(q63_t)Df << 31) - (d2 + ((q63_t)d1 << 1))*Dn);
+  temp = (q63_t)fract*(temp >> 31);
+  temp = temp + (q63_t)d1*Dn;
+  temp = (q63_t)fract*(temp >> 31);
+
+  /* Calculation of sine value */
+  *pSinVal = clip_q63_to_q31((temp >> 31) + (q63_t)f1);
+}
+
+/**
+ * @} end of SinCos group
+ */
diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_f32.c
new file mode 100644
index 0000000..44efbd5
--- /dev/null
+++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_f32.c
@@ -0,0 +1,115 @@
+/* ----------------------------------------------------------------------
+ * Project:      CMSIS DSP Library
+ * Title:        arm_cos_f32.c
+ * Description:  Fast cosine calculation for floating-point values
+ *
+ * $Date:        27. January 2017
+ * $Revision:    V.1.5.1
+ *
+ * Target Processor: Cortex-M cores
+ * -------------------------------------------------------------------- */
+/*
+ * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved.
+ *
+ * SPDX-License-Identifier: Apache-2.0
+ *
+ * Licensed under the Apache License, Version 2.0 (the License); you may
+ * not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an AS IS BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include "arm_math.h"
+#include "arm_common_tables.h"
+/**
+ * @ingroup groupFastMath
+ */
+
+/**
+ * @defgroup cos Cosine
+ *
+ * Computes the trigonometric cosine function using a combination of table lookup
+ * and linear interpolation.  There are separate functions for
+ * Q15, Q31, and floating-point data types.
+ * The input to the floating-point version is in radians and in the range [0 2*pi) while the
+ * fixed-point Q15 and Q31 have a scaled input with the range
+ * [0 +0.9999] mapping to [0 2*pi).  The fixed-point range is chosen so that a
+ * value of 2*pi wraps around to 0.
+ *
+ * The implementation is based on table lookup using 256 values together with linear interpolation.
+ * The steps used are:
+ *  -# Calculation of the nearest integer table index
+ *  -# Compute the fractional portion (fract) of the table index.
+ *  -# The final result equals (1.0f-fract)*a + fract*b;
+ *
+ * where
+ * 
+ *    b=Table[index+0];
+ *    c=Table[index+1];
+ * 
+ */ + + /** + * @addtogroup cos + * @{ + */ + +/** + * @brief Fast approximation to the trigonometric cosine function for floating-point data. + * @param[in] x input value in radians. + * @return cos(x). + */ + +float32_t arm_cos_f32( + float32_t x) +{ + float32_t cosVal, fract, in; /* Temporary variables for input, output */ + uint16_t index; /* Index variable */ + float32_t a, b; /* Two nearest output values */ + int32_t n; + float32_t findex; + + /* input x is in radians */ + /* Scale the input to [0 1] range from [0 2*PI] , divide input by 2*pi, add 0.25 (pi/2) to read sine table */ + in = x * 0.159154943092f + 0.25f; + + /* Calculation of floor value of input */ + n = (int32_t) in; + + /* Make negative values towards -infinity */ + if (in < 0.0f) + { + n--; + } + + /* Map input value to [0 1] */ + in = in - (float32_t) n; + + /* Calculation of index of the table */ + findex = (float32_t) FAST_MATH_TABLE_SIZE * in; + index = ((uint16_t)findex) & 0x1ff; + + /* fractional value calculation */ + fract = findex - (float32_t) index; + + /* Read two nearest values of input value from the cos table */ + a = sinTable_f32[index]; + b = sinTable_f32[index+1]; + + /* Linear interpolation process */ + cosVal = (1.0f-fract)*a + fract*b; + + /* Return the output value */ + return (cosVal); +} + +/** + * @} end of cos group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q15.c new file mode 100644 index 0000000..036c5d7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q15.c @@ -0,0 +1,84 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cos_q15.c + * Description: Fast cosine calculation for Q15 values + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupFastMath + */ + + /** + * @addtogroup cos + * @{ + */ + +/** + * @brief Fast approximation to the trigonometric cosine function for Q15 data. + * @param[in] x Scaled input value in radians. + * @return cos(x). + * + * The Q15 input value is in the range [0 +0.9999] and is mapped to a radian + * value in the range [0 2*pi). + */ + +q15_t arm_cos_q15( + q15_t x) +{ + q15_t cosVal; /* Temporary variables for input, output */ + int32_t index; /* Index variables */ + q15_t a, b; /* Four nearest output values */ + q15_t fract; /* Temporary values for fractional values */ + + /* add 0.25 (pi/2) to read sine table */ + x = (uint16_t)x + 0x2000; + if (x < 0) + { /* convert negative numbers to corresponding positive ones */ + x = (uint16_t)x + 0x8000; + } + + /* Calculate the nearest index */ + index = (uint32_t)x >> FAST_MATH_Q15_SHIFT; + + /* Calculation of fractional value */ + fract = (x - (index << FAST_MATH_Q15_SHIFT)) << 9; + + /* Read two nearest values of input value from the sin table */ + a = sinTable_q15[index]; + b = sinTable_q15[index+1]; + + /* Linear interpolation process */ + cosVal = (q31_t)(0x8000-fract)*a >> 16; + cosVal = (q15_t)((((q31_t)cosVal << 16) + ((q31_t)fract*b)) >> 16); + + return cosVal << 1; +} + +/** + * @} end of cos group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q31.c new file mode 100644 index 0000000..105addb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_cos_q31.c @@ -0,0 +1,84 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cos_q31.c + * Description: Fast cosine calculation for Q31 values + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupFastMath + */ + + /** + * @addtogroup cos + * @{ + */ + +/** + * @brief Fast approximation to the trigonometric cosine function for Q31 data. + * @param[in] x Scaled input value in radians. + * @return cos(x). + * + * The Q31 input value is in the range [0 +0.9999] and is mapped to a radian + * value in the range [0 2*pi). + */ + +q31_t arm_cos_q31( + q31_t x) +{ + q31_t cosVal; /* Temporary variables for input, output */ + int32_t index; /* Index variables */ + q31_t a, b; /* Four nearest output values */ + q31_t fract; /* Temporary values for fractional values */ + + /* add 0.25 (pi/2) to read sine table */ + x = (uint32_t)x + 0x20000000; + if (x < 0) + { /* convert negative numbers to corresponding positive ones */ + x = (uint32_t)x + 0x80000000; + } + + /* Calculate the nearest index */ + index = (uint32_t)x >> FAST_MATH_Q31_SHIFT; + + /* Calculation of fractional value */ + fract = (x - (index << FAST_MATH_Q31_SHIFT)) << 9; + + /* Read two nearest values of input value from the sin table */ + a = sinTable_q31[index]; + b = sinTable_q31[index+1]; + + /* Linear interpolation process */ + cosVal = (q63_t)(0x80000000-fract)*a >> 32; + cosVal = (q31_t)((((q63_t)cosVal << 32) + ((q63_t)fract*b)) >> 32); + + return cosVal << 1; +} + +/** + * @} end of cos group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_f32.c new file mode 100644 index 0000000..3fb5153 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_f32.c @@ -0,0 +1,123 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sin_f32.c + * Description: Fast sine calculation for floating-point values + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" +#include + +/** + * @ingroup groupFastMath + */ + +/** + * @defgroup sin Sine + * + * Computes the trigonometric sine function using a combination of table lookup + * and linear interpolation. There are separate functions for + * Q15, Q31, and floating-point data types. + * The input to the floating-point version is in radians and in the range [0 2*pi) while the + * fixed-point Q15 and Q31 have a scaled input with the range + * [0 +0.9999] mapping to [0 2*pi). The fixed-point range is chosen so that a + * value of 2*pi wraps around to 0. + * + * The implementation is based on table lookup using 256 values together with linear interpolation. + * The steps used are: + * -# Calculation of the nearest integer table index + * -# Compute the fractional portion (fract) of the table index. + * -# The final result equals (1.0f-fract)*a + fract*b; + * + * where + *
+ *    b=Table[index+0];
+ *    c=Table[index+1];
+ * 
+ */ + +/** + * @addtogroup sin + * @{ + */ + +/** + * @brief Fast approximation to the trigonometric sine function for floating-point data. + * @param[in] x input value in radians. + * @return sin(x). + */ + +float32_t arm_sin_f32( + float32_t x) +{ + float32_t sinVal, fract, in; /* Temporary variables for input, output */ + uint16_t index; /* Index variable */ + float32_t a, b; /* Two nearest output values */ + int32_t n; + float32_t findex; + + /* Special case for small negative inputs */ + if ((x < 0.0f) && (x >= -1.9e-7f)) { + return x; + } + + /* input x is in radians */ + /* Scale the input to [0 1] range from [0 2*PI] , divide input by 2*pi */ + in = x * 0.159154943092f; + + /* Calculation of floor value of input */ + n = (int32_t) in; + + /* Make negative values towards -infinity */ + if (x < 0.0f) + { + n--; + } + + /* Map input value to [0 1] */ + in = in - (float32_t) n; + + /* Calculation of index of the table */ + findex = (float32_t) FAST_MATH_TABLE_SIZE * in; + + index = ((uint16_t)findex) & 0x1ff; + + /* fractional value calculation */ + fract = findex - (float32_t) index; + + /* Read two nearest values of input value from the sin table */ + a = sinTable_f32[index]; + b = sinTable_f32[index+1]; + + /* Linear interpolation process */ + sinVal = (1.0f-fract)*a + fract*b; + + /* Return the output value */ + return (sinVal); +} + +/** + * @} end of sin group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q15.c new file mode 100644 index 0000000..9eecaa9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q15.c @@ -0,0 +1,76 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sin_q15.c + * Description: Fast sine calculation for Q15 values + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupFastMath + */ + + /** + * @addtogroup sin + * @{ + */ + +/** + * @brief Fast approximation to the trigonometric sine function for Q15 data. + * @param[in] x Scaled input value in radians. + * @return sin(x). + * + * The Q15 input value is in the range [0 +0.9999] and is mapped to a radian value in the range [0 2*pi). + */ + +q15_t arm_sin_q15( + q15_t x) +{ + q15_t sinVal; /* Temporary variables for input, output */ + int32_t index; /* Index variables */ + q15_t a, b; /* Four nearest output values */ + q15_t fract; /* Temporary values for fractional values */ + + /* Calculate the nearest index */ + index = (uint32_t)x >> FAST_MATH_Q15_SHIFT; + + /* Calculation of fractional value */ + fract = (x - (index << FAST_MATH_Q15_SHIFT)) << 9; + + /* Read two nearest values of input value from the sin table */ + a = sinTable_q15[index]; + b = sinTable_q15[index+1]; + + /* Linear interpolation process */ + sinVal = (q31_t)(0x8000-fract)*a >> 16; + sinVal = (q15_t)((((q31_t)sinVal << 16) + ((q31_t)fract*b)) >> 16); + + return sinVal << 1; +} + +/** + * @} end of sin group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q31.c new file mode 100644 index 0000000..2119016 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sin_q31.c @@ -0,0 +1,75 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sin_q31.c + * Description: Fast sine calculation for Q31 values + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupFastMath + */ + + /** + * @addtogroup sin + * @{ + */ + +/** + * @brief Fast approximation to the trigonometric sine function for Q31 data. + * @param[in] x Scaled input value in radians. + * @return sin(x). + * + * The Q31 input value is in the range [0 +0.9999] and is mapped to a radian value in the range [0 2*pi). */ + +q31_t arm_sin_q31( + q31_t x) +{ + q31_t sinVal; /* Temporary variables for input, output */ + int32_t index; /* Index variables */ + q31_t a, b; /* Four nearest output values */ + q31_t fract; /* Temporary values for fractional values */ + + /* Calculate the nearest index */ + index = (uint32_t)x >> FAST_MATH_Q31_SHIFT; + + /* Calculation of fractional value */ + fract = (x - (index << FAST_MATH_Q31_SHIFT)) << 9; + + /* Read two nearest values of input value from the sin table */ + a = sinTable_q31[index]; + b = sinTable_q31[index+1]; + + /* Linear interpolation process */ + sinVal = (q63_t)(0x80000000-fract)*a >> 32; + sinVal = (q31_t)((((q63_t)sinVal << 32) + ((q63_t)fract*b)) >> 32); + + return sinVal << 1; +} + +/** + * @} end of sin group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q15.c new file mode 100644 index 0000000..83e4ddd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q15.c @@ -0,0 +1,144 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sqrt_q15.c + * Description: Q15 square root function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + + +/** + * @ingroup groupFastMath + */ + +/** + * @addtogroup SQRT + * @{ + */ + + /** + * @brief Q15 square root function. + * @param[in] in input value. The range of the input value is [0 +1) or 0x0000 to 0x7FFF. + * @param[out] *pOut square root of input value. + * @return The function returns ARM_MATH_SUCCESS if the input value is positive + * and ARM_MATH_ARGUMENT_ERROR if the input is negative. For + * negative inputs, the function returns *pOut = 0. + */ + +arm_status arm_sqrt_q15( + q15_t in, + q15_t * pOut) +{ + q15_t number, temp1, var1, signBits1, half; + q31_t bits_val1; + float32_t temp_float1; + union + { + q31_t fracval; + float32_t floatval; + } tempconv; + + number = in; + + /* If the input is a positive number then compute the signBits. */ + if (number > 0) + { + signBits1 = __CLZ(number) - 17; + + /* Shift by the number of signBits1 */ + if ((signBits1 % 2) == 0) + { + number = number << signBits1; + } + else + { + number = number << (signBits1 - 1); + } + + /* Calculate half value of the number */ + half = number >> 1; + /* Store the number for later use */ + temp1 = number; + + /* Convert to float */ + temp_float1 = number * 3.051757812500000e-005f; + /*Store as integer */ + tempconv.floatval = temp_float1; + bits_val1 = tempconv.fracval; + /* Subtract the shifted value from the magic number to give intial guess */ + bits_val1 = 0x5f3759df - (bits_val1 >> 1); /* gives initial guess */ + /* Store as float */ + tempconv.fracval = bits_val1; + temp_float1 = tempconv.floatval; + /* Convert to integer format */ + var1 = (q31_t) (temp_float1 * 16384); + + /* 1st iteration */ + var1 = ((q15_t) ((q31_t) var1 * (0x3000 - + ((q15_t) + ((((q15_t) + (((q31_t) var1 * var1) >> 15)) * + (q31_t) half) >> 15))) >> 15)) << 2; + /* 2nd iteration */ + var1 = ((q15_t) ((q31_t) var1 * (0x3000 - + ((q15_t) + ((((q15_t) + (((q31_t) var1 * var1) >> 15)) * + (q31_t) half) >> 15))) >> 15)) << 2; + /* 3rd iteration */ + var1 = ((q15_t) ((q31_t) var1 * (0x3000 - + ((q15_t) + ((((q15_t) + (((q31_t) var1 * var1) >> 15)) * + (q31_t) half) >> 15))) >> 15)) << 2; + + /* Multiply the inverse square root with the original value */ + var1 = ((q15_t) (((q31_t) temp1 * var1) >> 15)) << 1; + + /* Shift the output down accordingly */ + if ((signBits1 % 2) == 0) + { + var1 = var1 >> (signBits1 / 2); + } + else + { + var1 = var1 >> ((signBits1 - 1) / 2); + } + *pOut = var1; + + return (ARM_MATH_SUCCESS); + } + /* If the number is a negative number then store zero as its square root value */ + else + { + *pOut = 0; + return (ARM_MATH_ARGUMENT_ERROR); + } +} + +/** + * @} end of SQRT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q31.c new file mode 100644 index 0000000..de8c35f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FastMathFunctions/arm_sqrt_q31.c @@ -0,0 +1,142 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_sqrt_q31.c + * Description: Q31 square root function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupFastMath + */ + +/** + * @addtogroup SQRT + * @{ + */ + +/** + * @brief Q31 square root function. + * @param[in] in input value. The range of the input value is [0 +1) or 0x00000000 to 0x7FFFFFFF. + * @param[out] *pOut square root of input value. + * @return The function returns ARM_MATH_SUCCESS if the input value is positive + * and ARM_MATH_ARGUMENT_ERROR if the input is negative. For + * negative inputs, the function returns *pOut = 0. + */ + +arm_status arm_sqrt_q31( + q31_t in, + q31_t * pOut) +{ + q31_t number, temp1, bits_val1, var1, signBits1, half; + float32_t temp_float1; + union + { + q31_t fracval; + float32_t floatval; + } tempconv; + + number = in; + + /* If the input is a positive number then compute the signBits. */ + if (number > 0) + { + signBits1 = __CLZ(number) - 1; + + /* Shift by the number of signBits1 */ + if ((signBits1 % 2) == 0) + { + number = number << signBits1; + } + else + { + number = number << (signBits1 - 1); + } + + /* Calculate half value of the number */ + half = number >> 1; + /* Store the number for later use */ + temp1 = number; + + /*Convert to float */ + temp_float1 = number * 4.6566128731e-010f; + /*Store as integer */ + tempconv.floatval = temp_float1; + bits_val1 = tempconv.fracval; + /* Subtract the shifted value from the magic number to give intial guess */ + bits_val1 = 0x5f3759df - (bits_val1 >> 1); /* gives initial guess */ + /* Store as float */ + tempconv.fracval = bits_val1; + temp_float1 = tempconv.floatval; + /* Convert to integer format */ + var1 = (q31_t) (temp_float1 * 1073741824); + + /* 1st iteration */ + var1 = ((q31_t) ((q63_t) var1 * (0x30000000 - + ((q31_t) + ((((q31_t) + (((q63_t) var1 * var1) >> 31)) * + (q63_t) half) >> 31))) >> 31)) << 2; + /* 2nd iteration */ + var1 = ((q31_t) ((q63_t) var1 * (0x30000000 - + ((q31_t) + ((((q31_t) + (((q63_t) var1 * var1) >> 31)) * + (q63_t) half) >> 31))) >> 31)) << 2; + /* 3rd iteration */ + var1 = ((q31_t) ((q63_t) var1 * (0x30000000 - + ((q31_t) + ((((q31_t) + (((q63_t) var1 * var1) >> 31)) * + (q63_t) half) >> 31))) >> 31)) << 2; + + /* Multiply the inverse square root with the original value */ + var1 = ((q31_t) (((q63_t) temp1 * var1) >> 31)) << 1; + + /* Shift the output down accordingly */ + if ((signBits1 % 2) == 0) + { + var1 = var1 >> (signBits1 / 2); + } + else + { + var1 = var1 >> ((signBits1 - 1) / 2); + } + *pOut = var1; + + return (ARM_MATH_SUCCESS); + } + /* If the number is a negative number then store zero as its square root value */ + else + { + *pOut = 0; + return (ARM_MATH_ARGUMENT_ERROR); + } +} + +/** + * @} end of SQRT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_init_q31.c new file mode 100644 index 0000000..8a29213 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_init_q31.c @@ -0,0 +1,98 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_32x64_init_q31.c + * Description: High precision Q31 Biquad cascade filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1_32x64 + * @{ + */ + +/** + * @details + * + * @param[in,out] *S points to an instance of the high precision Q31 Biquad cascade filter structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] postShift Shift to be applied after the accumulator. Varies according to the coefficients format. + * @return none + * + * Coefficient and State Ordering: + * + * \par + * The coefficients are stored in the array pCoeffs in the following order: + *
+ *     {b10, b11, b12, a11, a12, b20, b21, b22, a21, a22, ...}
+ * 
+ * where b1x and a1x are the coefficients for the first stage, + * b2x and a2x are the coefficients for the second stage, + * and so on. The pCoeffs array contains a total of 5*numStages values. + * + * \par + * The pState points to state variables array and size of each state variable is 1.63 format. + * Each Biquad stage has 4 state variables x[n-1], x[n-2], y[n-1], and y[n-2]. + * The state variables are arranged in the state array as: + *
+ *     {x[n-1], x[n-2], y[n-1], y[n-2]}
+ * 
+ * The 4 state variables for stage 1 are first, then the 4 state variables for stage 2, and so on. + * The state array has a total length of 4*numStages values. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + */ + +void arm_biquad_cas_df1_32x64_init_q31( + arm_biquad_cas_df1_32x64_ins_q31 * S, + uint8_t numStages, + q31_t * pCoeffs, + q63_t * pState, + uint8_t postShift) +{ + /* Assign filter stages */ + S->numStages = numStages; + + /* Assign postShift to be applied to the output */ + S->postShift = postShift; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always 4 * numStages */ + memset(pState, 0, (4U * (uint32_t) numStages) * sizeof(q63_t)); + + /* Assign state pointer */ + S->pState = pState; +} + +/** + * @} end of BiquadCascadeDF1_32x64 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_q31.c new file mode 100644 index 0000000..d241f76 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_32x64_q31.c @@ -0,0 +1,549 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_32x64_q31.c + * Description: High precision Q31 Biquad cascade filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup BiquadCascadeDF1_32x64 High Precision Q31 Biquad Cascade Filter + * + * This function implements a high precision Biquad cascade filter which operates on + * Q31 data values. The filter coefficients are in 1.31 format and the state variables + * are in 1.63 format. The double precision state variables reduce quantization noise + * in the filter and provide a cleaner output. + * These filters are particularly useful when implementing filters in which the + * singularities are close to the unit circle. This is common for low pass or high + * pass filters with very low cutoff frequencies. + * + * The function operates on blocks of input and output data + * and each call to the function processes blockSize samples through + * the filter. pSrc and pDst points to input and output arrays + * containing blockSize Q31 values. + * + * \par Algorithm + * Each Biquad stage implements a second order filter using the difference equation: + *
+ *     y[n] = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2]
+ * 
+ * A Direct Form I algorithm is used with 5 coefficients and 4 state variables per stage. + * \image html Biquad.gif "Single Biquad filter stage" + * Coefficients b0, b1, and b2 multiply the input signal x[n] and are referred to as the feedforward coefficients. + * Coefficients a1 and a2 multiply the output signal y[n] and are referred to as the feedback coefficients. + * Pay careful attention to the sign of the feedback coefficients. + * Some design tools use the difference equation + *
+ *     y[n] = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] - a1 * y[n-1] - a2 * y[n-2]
+ * 
+ * In this case the feedback coefficients a1 and a2 must be negated when used with the CMSIS DSP Library. + * + * \par + * Higher order filters are realized as a cascade of second order sections. + * numStages refers to the number of second order stages used. + * For example, an 8th order filter would be realized with numStages=4 second order stages. + * \image html BiquadCascade.gif "8th order filter using a cascade of Biquad stages" + * A 9th order filter would be realized with numStages=5 second order stages with the coefficients for one of the stages configured as a first order filter (b2=0 and a2=0). + * + * \par + * The pState points to state variables array . + * Each Biquad stage has 4 state variables x[n-1], x[n-2], y[n-1], and y[n-2] and each state variable in 1.63 format to improve precision. + * The state variables are arranged in the array as: + *
+ *     {x[n-1], x[n-2], y[n-1], y[n-2]}
+ * 
+ * + * \par + * The 4 state variables for stage 1 are first, then the 4 state variables for stage 2, and so on. + * The state array has a total length of 4*numStages values of data in 1.63 format. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + * + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter. + * Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. + * + * \par Init Function + * There is also an associated initialization function which performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numStages, pCoeffs, postShift, pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * Set the values in the state buffer to zeros before static initialization. + * For example, to statically initialize the filter instance structure use + *
+ *     arm_biquad_cas_df1_32x64_ins_q31 S1 = {numStages, pState, pCoeffs, postShift};
+ * 
+ * where numStages is the number of Biquad stages in the filter; pState is the address of the state buffer; + * pCoeffs is the address of the coefficient buffer; postShift shift to be applied which is described in detail below. + * \par Fixed-Point Behavior + * Care must be taken while using Biquad Cascade 32x64 filter function. + * Following issues must be considered: + * - Scaling of coefficients + * - Filter gain + * - Overflow and saturation + * + * \par + * Filter coefficients are represented as fractional values and + * restricted to lie in the range [-1 +1). + * The processing function has an additional scaling parameter postShift + * which allows the filter coefficients to exceed the range [+1 -1). + * At the output of the filter's accumulator is a shift register which shifts the result by postShift bits. + * \image html BiquadPostshift.gif "Fixed-point Biquad with shift by postShift bits after accumulator" + * This essentially scales the filter coefficients by 2^postShift. + * For example, to realize the coefficients + *
+ *    {1.5, -0.8, 1.2, 1.6, -0.9}
+ * 
+ * set the Coefficient array to: + *
+ *    {0.75, -0.4, 0.6, 0.8, -0.45}
+ * 
+ * and set postShift=1 + * + * \par + * The second thing to keep in mind is the gain through the filter. + * The frequency response of a Biquad filter is a function of its coefficients. + * It is possible for the gain through the filter to exceed 1.0 meaning that the filter increases the amplitude of certain frequencies. + * This means that an input signal with amplitude < 1.0 may result in an output > 1.0 and these are saturated or overflowed based on the implementation of the filter. + * To avoid this behavior the filter needs to be scaled down such that its peak gain < 1.0 or the input signal must be scaled down so that the combination of input and filter are never overflowed. + * + * \par + * The third item to consider is the overflow and saturation behavior of the fixed-point Q31 version. + * This is described in the function specific documentation below. + */ + +/** + * @addtogroup BiquadCascadeDF1_32x64 + * @{ + */ + +/** + * @details + + * @param[in] *S points to an instance of the high precision Q31 Biquad cascade filter. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + * @return none. + * + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clip. + * In order to avoid overflows completely the input signal must be scaled down by 2 bits and lie in the range [-0.25 +0.25). + * After all 5 multiply-accumulates are performed, the 2.62 accumulator is shifted by postShift bits and the result truncated to + * 1.31 format by discarding the low 32 bits. + * + * \par + * Two related functions are provided in the CMSIS DSP library. + * arm_biquad_cascade_df1_q31() implements a Biquad cascade with 32-bit coefficients and state variables with a Q63 accumulator. + * arm_biquad_cascade_df1_fast_q31() implements a Biquad cascade with 32-bit coefficients and state variables with a Q31 accumulator. + */ + +void arm_biquad_cas_df1_32x64_q31( + const arm_biquad_cas_df1_32x64_ins_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pIn = pSrc; /* input pointer initialization */ + q31_t *pOut = pDst; /* output pointer initialization */ + q63_t *pState = S->pState; /* state pointer initialization */ + q31_t *pCoeffs = S->pCoeffs; /* coeff pointer initialization */ + q63_t acc; /* accumulator */ + q31_t Xn1, Xn2; /* Input Filter state variables */ + q63_t Yn1, Yn2; /* Output Filter state variables */ + q31_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q31_t Xn; /* temporary input */ + int32_t shift = (int32_t) S->postShift + 1; /* Shift to be applied to the output */ + uint32_t sample, stage = S->numStages; /* loop counters */ + q31_t acc_l, acc_h; /* temporary output */ + uint32_t uShift = ((uint32_t) S->postShift + 1U); + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = (q31_t) (pState[0]); + Xn2 = (q31_t) (pState[1]); + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* Apply loop unrolling and compute 4 output values simultaneously. */ + /* The variable acc hold output value that is being computed and + * stored in the destination buffer + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) Xn *b0; + + /* acc += b1 * x[n-1] */ + acc += (q63_t) Xn1 *b1; + + /* acc += b[2] * x[n-2] */ + acc += (q63_t) Xn2 *b2; + + /* acc += a1 * y[n-1] */ + acc += mult32x64(Yn1, a1); + + /* acc += a2 * y[n-2] */ + acc += mult32x64(Yn2, a2); + + /* The result is converted to 1.63 , Yn2 variable is reused */ + Yn2 = acc << shift; + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc_h = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer in 1.31 format. */ + *pOut = acc_h; + + /* Read the second input into Xn2, to reuse the value */ + Xn2 = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc += b1 * x[n-1] */ + acc = (q63_t) Xn *b1; + + /* acc = b0 * x[n] */ + acc += (q63_t) Xn2 *b0; + + /* acc += b[2] * x[n-2] */ + acc += (q63_t) Xn1 *b2; + + /* acc += a1 * y[n-1] */ + acc += mult32x64(Yn2, a1); + + /* acc += a2 * y[n-2] */ + acc += mult32x64(Yn1, a2); + + /* The result is converted to 1.63, Yn1 variable is reused */ + Yn1 = acc << shift; + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc_h = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Read the third input into Xn1, to reuse the value */ + Xn1 = *pIn++; + + /* The result is converted to 1.31 */ + /* Store the output in the destination buffer. */ + *(pOut + 1U) = acc_h; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) Xn1 *b0; + + /* acc += b1 * x[n-1] */ + acc += (q63_t) Xn2 *b1; + + /* acc += b[2] * x[n-2] */ + acc += (q63_t) Xn *b2; + + /* acc += a1 * y[n-1] */ + acc += mult32x64(Yn1, a1); + + /* acc += a2 * y[n-2] */ + acc += mult32x64(Yn2, a2); + + /* The result is converted to 1.63, Yn2 variable is reused */ + Yn2 = acc << shift; + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc_h = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer in 1.31 format. */ + *(pOut + 2U) = acc_h; + + /* Read the fourth input into Xn, to reuse the value */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + acc = (q63_t) Xn *b0; + + /* acc += b1 * x[n-1] */ + acc += (q63_t) Xn1 *b1; + + /* acc += b[2] * x[n-2] */ + acc += (q63_t) Xn2 *b2; + + /* acc += a1 * y[n-1] */ + acc += mult32x64(Yn2, a1); + + /* acc += a2 * y[n-2] */ + acc += mult32x64(Yn1, a2); + + /* The result is converted to 1.63, Yn1 variable is reused */ + Yn1 = acc << shift; + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc_h = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer in 1.31 format. */ + *(pOut + 3U) = acc_h; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + + /* update output pointer */ + pOut += 4U; + + /* decrement the loop counter */ + sample--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + sample = (blockSize & 0x3U); + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) Xn *b0; + /* acc += b1 * x[n-1] */ + acc += (q63_t) Xn1 *b1; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) Xn2 *b2; + /* acc += a1 * y[n-1] */ + acc += mult32x64(Yn1, a1); + /* acc += a2 * y[n-2] */ + acc += mult32x64(Yn2, a2); + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + /* The result is converted to 1.63, Yn1 variable is reused */ + Yn1 = acc << shift; + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc_h = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer in 1.31 format. */ + *pOut++ = acc_h; + /* Yn1 = acc << shift; */ + + /* Store the output in the destination buffer in 1.31 format. */ +/* *pOut++ = (q31_t) (acc >> (32 - shift)); */ + + /* decrement the loop counter */ + sample--; + } + + /* The first stage output is given as input to the second stage. */ + pIn = pDst; + + /* Reset to destination buffer working pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + /* Store the updated state variables back into the pState array */ + *pState++ = (q63_t) Xn1; + *pState++ = (q63_t) Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); + +#else + + /* Run the below code for Cortex-M0 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* The variable acc hold output value that is being computed and + * stored in the destination buffer + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + acc = (q63_t) Xn *b0; + /* acc += b1 * x[n-1] */ + acc += (q63_t) Xn1 *b1; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) Xn2 *b2; + /* acc += a1 * y[n-1] */ + acc += mult32x64(Yn1, a1); + /* acc += a2 * y[n-2] */ + acc += mult32x64(Yn2, a2); + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + + /* The result is converted to 1.63, Yn1 variable is reused */ + Yn1 = acc << shift; + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc_h = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer in 1.31 format. */ + *pOut++ = acc_h; + + /* Yn1 = acc << shift; */ + + /* Store the output in the destination buffer in 1.31 format. */ + /* *pOut++ = (q31_t) (acc >> (32 - shift)); */ + + /* decrement the loop counter */ + sample--; + } + + /* The first stage output is given as input to the second stage. */ + pIn = pDst; + + /* Reset to destination buffer working pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = (q63_t) Xn1; + *pState++ = (q63_t) Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); + +#endif /* #if defined (ARM_MATH_DSP) */ +} + + /** + * @} end of BiquadCascadeDF1_32x64 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_f32.c new file mode 100644 index 0000000..658e395 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_f32.c @@ -0,0 +1,412 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_f32.c + * Description: Processing function for the floating-point Biquad cascade DirectFormI(DF1) filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup BiquadCascadeDF1 Biquad Cascade IIR Filters Using Direct Form I Structure + * + * This set of functions implements arbitrary order recursive (IIR) filters. + * The filters are implemented as a cascade of second order Biquad sections. + * The functions support Q15, Q31 and floating-point data types. + * Fast version of Q15 and Q31 also supported on CortexM4 and Cortex-M3. + * + * The functions operate on blocks of input and output data and each call to the function + * processes blockSize samples through the filter. + * pSrc points to the array of input data and + * pDst points to the array of output data. + * Both arrays contain blockSize values. + * + * \par Algorithm + * Each Biquad stage implements a second order filter using the difference equation: + *
+ *     y[n] = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2]
+ * 
+ * A Direct Form I algorithm is used with 5 coefficients and 4 state variables per stage. + * \image html Biquad.gif "Single Biquad filter stage" + * Coefficients b0, b1 and b2 multiply the input signal x[n] and are referred to as the feedforward coefficients. + * Coefficients a1 and a2 multiply the output signal y[n] and are referred to as the feedback coefficients. + * Pay careful attention to the sign of the feedback coefficients. + * Some design tools use the difference equation + *
+ *     y[n] = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] - a1 * y[n-1] - a2 * y[n-2]
+ * 
+ * In this case the feedback coefficients a1 and a2 must be negated when used with the CMSIS DSP Library. + * + * \par + * Higher order filters are realized as a cascade of second order sections. + * numStages refers to the number of second order stages used. + * For example, an 8th order filter would be realized with numStages=4 second order stages. + * \image html BiquadCascade.gif "8th order filter using a cascade of Biquad stages" + * A 9th order filter would be realized with numStages=5 second order stages with the coefficients for one of the stages configured as a first order filter (b2=0 and a2=0). + * + * \par + * The pState points to state variables array. + * Each Biquad stage has 4 state variables x[n-1], x[n-2], y[n-1], and y[n-2]. + * The state variables are arranged in the pState array as: + *
+ *     {x[n-1], x[n-2], y[n-1], y[n-2]}
+ * 
+ * + * \par + * The 4 state variables for stage 1 are first, then the 4 state variables for stage 2, and so on. + * The state array has a total length of 4*numStages values. + * The state variables are updated after each block of data is processed, the coefficients are untouched. + * + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter. + * Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Init Functions + * There is also an associated initialization function for each data type. + * The initialization function performs following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numStages, pCoeffs, pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * Set the values in the state buffer to zeros before static initialization. + * The code below statically initializes each of the 3 different data type filter instance structures + *
+ *     arm_biquad_casd_df1_inst_f32 S1 = {numStages, pState, pCoeffs};
+ *     arm_biquad_casd_df1_inst_q15 S2 = {numStages, pState, pCoeffs, postShift};
+ *     arm_biquad_casd_df1_inst_q31 S3 = {numStages, pState, pCoeffs, postShift};
+ * 
+ * where numStages is the number of Biquad stages in the filter; pState is the address of the state buffer; + * pCoeffs is the address of the coefficient buffer; postShift shift to be applied. + * + * \par Fixed-Point Behavior + * Care must be taken when using the Q15 and Q31 versions of the Biquad Cascade filter functions. + * Following issues must be considered: + * - Scaling of coefficients + * - Filter gain + * - Overflow and saturation + * + * \par + * Scaling of coefficients: + * Filter coefficients are represented as fractional values and + * coefficients are restricted to lie in the range [-1 +1). + * The fixed-point functions have an additional scaling parameter postShift + * which allow the filter coefficients to exceed the range [+1 -1). + * At the output of the filter's accumulator is a shift register which shifts the result by postShift bits. + * \image html BiquadPostshift.gif "Fixed-point Biquad with shift by postShift bits after accumulator" + * This essentially scales the filter coefficients by 2^postShift. + * For example, to realize the coefficients + *
+ *    {1.5, -0.8, 1.2, 1.6, -0.9}
+ * 
+ * set the pCoeffs array to: + *
+ *    {0.75, -0.4, 0.6, 0.8, -0.45}
+ * 
+ * and set postShift=1 + * + * \par + * Filter gain: + * The frequency response of a Biquad filter is a function of its coefficients. + * It is possible for the gain through the filter to exceed 1.0 meaning that the filter increases the amplitude of certain frequencies. + * This means that an input signal with amplitude < 1.0 may result in an output > 1.0 and these are saturated or overflowed based on the implementation of the filter. + * To avoid this behavior the filter needs to be scaled down such that its peak gain < 1.0 or the input signal must be scaled down so that the combination of input and filter are never overflowed. + * + * \par + * Overflow and saturation: + * For Q15 and Q31 versions, it is described separately as part of the function specific documentation below. + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @param[in] *S points to an instance of the floating-point Biquad cascade structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + */ + +void arm_biquad_cascade_df1_f32( + const arm_biquad_casd_df1_inst_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pIn = pSrc; /* source pointer */ + float32_t *pOut = pDst; /* destination pointer */ + float32_t *pState = S->pState; /* pState pointer */ + float32_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float32_t acc; /* Simulates the accumulator */ + float32_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float32_t Xn1, Xn2, Yn1, Yn2; /* Filter pState variables */ + float32_t Xn; /* temporary input */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the pState values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* Apply loop unrolling and compute 4 output values simultaneously. */ + /* The variable acc hold output values that are being computed: + * + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (sample > 0U) + { + /* Read the first input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + Yn2 = (b0 * Xn) + (b1 * Xn1) + (b2 * Xn2) + (a1 * Yn1) + (a2 * Yn2); + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = Yn2; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + + /* Read the second input */ + Xn2 = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + Yn1 = (b0 * Xn2) + (b1 * Xn) + (b2 * Xn1) + (a1 * Yn2) + (a2 * Yn1); + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = Yn1; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + + /* Read the third input */ + Xn1 = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + Yn2 = (b0 * Xn1) + (b1 * Xn2) + (b2 * Xn) + (a1 * Yn1) + (a2 * Yn2); + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = Yn2; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + + /* Read the forth input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + Yn1 = (b0 * Xn) + (b1 * Xn1) + (b2 * Xn2) + (a1 * Yn2) + (a2 * Yn1); + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = Yn1; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + + /* decrement the loop counter */ + sample--; + + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + sample = blockSize & 0x3U; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + acc = (b0 * Xn) + (b1 * Xn1) + (b2 * Xn2) + (a1 * Yn1) + (a2 * Yn2); + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = acc; + + /* decrement the loop counter */ + sample--; + + } + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent numStages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset the output pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#else + + /* Run the below code for Cortex-M0 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the pState values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* The variables acc holds the output value that is computed: + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + acc = (b0 * Xn) + (b1 * Xn1) + (b2 * Xn2) + (a1 * Yn1) + (a2 * Yn2); + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = acc; + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent numStages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset the output pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + + + /** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q15.c new file mode 100644 index 0000000..2a08968 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q15.c @@ -0,0 +1,273 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_fast_q15.c + * Description: Fast processing function for the Q15 Biquad cascade filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @details + * @param[in] *S points to an instance of the Q15 Biquad cascade structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * This fast version uses a 32-bit accumulator with 2.30 format. + * The accumulator maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around and distorts the result. + * In order to avoid overflows completely the input signal must be scaled down by two bits and lie in the range [-0.25 +0.25). + * The 2.30 accumulator is then shifted by postShift bits and the result truncated to 1.15 format by discarding the low 16 bits. + * + * \par + * Refer to the function arm_biquad_cascade_df1_q15() for a slower implementation of this function which uses 64-bit accumulation to avoid wrap around distortion. Both the slow and the fast versions use the same instance structure. + * Use the function arm_biquad_cascade_df1_init_q15() to initialize the filter structure. + * + */ + +void arm_biquad_cascade_df1_fast_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pIn = pSrc; /* Source pointer */ + q15_t *pOut = pDst; /* Destination pointer */ + q31_t in; /* Temporary variable to hold input value */ + q31_t out; /* Temporary variable to hold output value */ + q31_t b0; /* Temporary variable to hold bo value */ + q31_t b1, a1; /* Filter coefficients */ + q31_t state_in, state_out; /* Filter state variables */ + q31_t acc; /* Accumulator */ + int32_t shift = (int32_t) (15 - S->postShift); /* Post shift */ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + uint32_t sample, stage = S->numStages; /* Stage loop counter */ + + + + do + { + + /* Read the b0 and 0 coefficients using SIMD */ + b0 = *__SIMD32(pCoeffs)++; + + /* Read the b1 and b2 coefficients using SIMD */ + b1 = *__SIMD32(pCoeffs)++; + + /* Read the a1 and a2 coefficients using SIMD */ + a1 = *__SIMD32(pCoeffs)++; + + /* Read the input state values from the state buffer: x[n-1], x[n-2] */ + state_in = *__SIMD32(pState)++; + + /* Read the output state values from the state buffer: y[n-1], y[n-2] */ + state_out = *__SIMD32(pState)--; + + /* Apply loop unrolling and compute 2 output values simultaneously. */ + /* The variable acc hold output values that are being computed: + * + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + sample = blockSize >> 1U; + + /* First part of the processing with loop unrolling. Compute 2 outputs at a time. + ** a second loop below computes the remaining 1 sample. */ + while (sample > 0U) + { + + /* Read the input */ + in = *__SIMD32(pIn)++; + + /* out = b0 * x[n] + 0 * 0 */ + out = __SMUAD(b0, in); + /* acc = b1 * x[n-1] + acc += b2 * x[n-2] + out */ + acc = __SMLAD(b1, state_in, out); + /* acc += a1 * y[n-1] + acc += a2 * y[n-2] */ + acc = __SMLAD(a1, state_out, acc); + + /* The result is converted from 3.29 to 1.31 and then saturation is applied */ + out = __SSAT((acc >> shift), 16); + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + /* x[n-N], x[n-N-1] are packed together to make state_in of type q31 */ + /* y[n-N], y[n-N-1] are packed together to make state_out of type q31 */ + +#ifndef ARM_MATH_BIG_ENDIAN + + state_in = __PKHBT(in, state_in, 16); + state_out = __PKHBT(out, state_out, 16); + +#else + + state_in = __PKHBT(state_in >> 16, (in >> 16), 16); + state_out = __PKHBT(state_out >> 16, (out), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* out = b0 * x[n] + 0 * 0 */ + out = __SMUADX(b0, in); + /* acc0 = b1 * x[n-1] , acc0 += b2 * x[n-2] + out */ + acc = __SMLAD(b1, state_in, out); + /* acc += a1 * y[n-1] + acc += a2 * y[n-2] */ + acc = __SMLAD(a1, state_out, acc); + + /* The result is converted from 3.29 to 1.31 and then saturation is applied */ + out = __SSAT((acc >> shift), 16); + + + /* Store the output in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = __PKHBT(state_out, out, 16); + +#else + + *__SIMD32(pOut)++ = __PKHBT(out, state_out >> 16, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + /* x[n-N], x[n-N-1] are packed together to make state_in of type q31 */ + /* y[n-N], y[n-N-1] are packed together to make state_out of type q31 */ + +#ifndef ARM_MATH_BIG_ENDIAN + + state_in = __PKHBT(in >> 16, state_in, 16); + state_out = __PKHBT(out, state_out, 16); + +#else + + state_in = __PKHBT(state_in >> 16, in, 16); + state_out = __PKHBT(state_out >> 16, out, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + + /* Decrement the loop counter */ + sample--; + + } + + /* If the blockSize is not a multiple of 2, compute any remaining output samples here. + ** No loop unrolling is used. */ + + if ((blockSize & 0x1U) != 0U) + { + /* Read the input */ + in = *pIn++; + + /* out = b0 * x[n] + 0 * 0 */ + +#ifndef ARM_MATH_BIG_ENDIAN + + out = __SMUAD(b0, in); + +#else + + out = __SMUADX(b0, in); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc = b1 * x[n-1], acc += b2 * x[n-2] + out */ + acc = __SMLAD(b1, state_in, out); + /* acc += a1 * y[n-1] + acc += a2 * y[n-2] */ + acc = __SMLAD(a1, state_out, acc); + + /* The result is converted from 3.29 to 1.31 and then saturation is applied */ + out = __SSAT((acc >> shift), 16); + + /* Store the output in the destination buffer. */ + *pOut++ = (q15_t) out; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + /* x[n-N], x[n-N-1] are packed together to make state_in of type q31 */ + /* y[n-N], y[n-N-1] are packed together to make state_out of type q31 */ + +#ifndef ARM_MATH_BIG_ENDIAN + + state_in = __PKHBT(in, state_in, 16); + state_out = __PKHBT(out, state_out, 16); + +#else + + state_in = __PKHBT(state_in >> 16, in, 16); + state_out = __PKHBT(state_out >> 16, out, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent (numStages - 1) occur in-place in the output buffer */ + pIn = pDst; + + /* Reset the output pointer */ + pOut = pDst; + + /* Store the updated state variables back into the state array */ + *__SIMD32(pState)++ = state_in; + *__SIMD32(pState)++ = state_out; + + + /* Decrement the loop counter */ + stage--; + + } while (stage > 0U); +} + + +/** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q31.c new file mode 100644 index 0000000..5e41faa --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_fast_q31.c @@ -0,0 +1,292 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_fast_q31.c + * Description: Processing function for the Q31 Fast Biquad cascade DirectFormI(DF1) filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @details + * + * @param[in] *S points to an instance of the Q31 Biquad cascade structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * This function is optimized for speed at the expense of fixed-point precision and overflow protection. + * The result of each 1.31 x 1.31 multiplication is truncated to 2.30 format. + * These intermediate results are added to a 2.30 accumulator. + * Finally, the accumulator is saturated and converted to a 1.31 result. + * The fast version has the same overflow behavior as the standard version and provides less precision since it discards the low 32 bits of each multiplication result. + * In order to avoid overflows completely the input signal must be scaled down by two bits and lie in the range [-0.25 +0.25). Use the intialization function + * arm_biquad_cascade_df1_init_q31() to initialize filter structure. + * + * \par + * Refer to the function arm_biquad_cascade_df1_q31() for a slower implementation of this function which uses 64-bit accumulation to provide higher precision. Both the slow and the fast versions use the same instance structure. + * Use the function arm_biquad_cascade_df1_init_q31() to initialize the filter structure. + */ + +void arm_biquad_cascade_df1_fast_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t acc = 0; /* accumulator */ + q31_t Xn1, Xn2, Yn1, Yn2; /* Filter state variables */ + q31_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q31_t *pIn = pSrc; /* input pointer initialization */ + q31_t *pOut = pDst; /* output pointer initialization */ + q31_t *pState = S->pState; /* pState pointer initialization */ + q31_t *pCoeffs = S->pCoeffs; /* coeff pointer initialization */ + q31_t Xn; /* temporary input */ + int32_t shift = (int32_t) S->postShift + 1; /* Shift to be applied to the output */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* Apply loop unrolling and compute 4 output values simultaneously. */ + /* The variables acc ... acc3 hold output values that are being computed: + * + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + /*acc = (q31_t) (((q63_t) b1 * Xn1) >> 32);*/ + mult_32x32_keep32_R(acc, b1, Xn1); + /* acc += b1 * x[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b0 * (Xn))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b0, Xn); + /* acc += b[2] * x[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b2 * (Xn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b2, Xn2); + /* acc += a1 * y[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a1 * (Yn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a1, Yn1); + /* acc += a2 * y[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a2 * (Yn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a2, Yn2); + + /* The result is converted to 1.31 , Yn2 variable is reused */ + Yn2 = acc << shift; + + /* Read the second input */ + Xn2 = *(pIn + 1U); + + /* Store the output in the destination buffer. */ + *pOut = Yn2; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + /*acc = (q31_t) (((q63_t) b0 * (Xn2)) >> 32);*/ + mult_32x32_keep32_R(acc, b0, Xn2); + /* acc += b1 * x[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b1 * (Xn))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b1, Xn); + /* acc += b[2] * x[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b2 * (Xn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b2, Xn1); + /* acc += a1 * y[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a1 * (Yn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a1, Yn2); + /* acc += a2 * y[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a2 * (Yn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a2, Yn1); + + /* The result is converted to 1.31, Yn1 variable is reused */ + Yn1 = acc << shift; + + /* Read the third input */ + Xn1 = *(pIn + 2U); + + /* Store the output in the destination buffer. */ + *(pOut + 1U) = Yn1; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + /*acc = (q31_t) (((q63_t) b0 * (Xn1)) >> 32);*/ + mult_32x32_keep32_R(acc, b0, Xn1); + /* acc += b1 * x[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b1 * (Xn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b1, Xn2); + /* acc += b[2] * x[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b2 * (Xn))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b2, Xn); + /* acc += a1 * y[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a1 * (Yn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a1, Yn1); + /* acc += a2 * y[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a2 * (Yn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a2, Yn2); + + /* The result is converted to 1.31, Yn2 variable is reused */ + Yn2 = acc << shift; + + /* Read the forth input */ + Xn = *(pIn + 3U); + + /* Store the output in the destination buffer. */ + *(pOut + 2U) = Yn2; + pIn += 4U; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + /*acc = (q31_t) (((q63_t) b0 * (Xn)) >> 32);*/ + mult_32x32_keep32_R(acc, b0, Xn); + /* acc += b1 * x[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b1 * (Xn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b1, Xn1); + /* acc += b[2] * x[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b2 * (Xn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b2, Xn2); + /* acc += a1 * y[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a1 * (Yn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a1, Yn2); + /* acc += a2 * y[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a2 * (Yn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a2, Yn1); + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + Xn2 = Xn1; + + /* The result is converted to 1.31, Yn1 variable is reused */ + Yn1 = acc << shift; + + /* Xn1 = Xn */ + Xn1 = Xn; + + /* Store the output in the destination buffer. */ + *(pOut + 3U) = Yn1; + pOut += 4U; + + /* decrement the loop counter */ + sample--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + sample = (blockSize & 0x3U); + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + /*acc = (q31_t) (((q63_t) b0 * (Xn)) >> 32);*/ + mult_32x32_keep32_R(acc, b0, Xn); + /* acc += b1 * x[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b1 * (Xn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b1, Xn1); + /* acc += b[2] * x[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) b2 * (Xn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, b2, Xn2); + /* acc += a1 * y[n-1] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a1 * (Yn1))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a1, Yn1); + /* acc += a2 * y[n-2] */ + /*acc = (q31_t) ((((q63_t) acc << 32) + ((q63_t) a2 * (Yn2))) >> 32);*/ + multAcc_32x32_keep32_R(acc, a2, Yn2); + + /* The result is converted to 1.31 */ + acc = acc << shift; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = acc; + + /* Store the output in the destination buffer. */ + *pOut++ = acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); +} + +/** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_f32.c new file mode 100644 index 0000000..147c8c5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_f32.c @@ -0,0 +1,97 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_init_f32.c + * Description: Floating-point Biquad cascade DirectFormI(DF1) filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @details + * @brief Initialization function for the floating-point Biquad cascade filter. + * @param[in,out] *S points to an instance of the floating-point Biquad cascade structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] *pCoeffs points to the filter coefficients array. + * @param[in] *pState points to the state array. + * @return none + * + * + * Coefficient and State Ordering: + * + * \par + * The coefficients are stored in the array pCoeffs in the following order: + *
+ *     {b10, b11, b12, a11, a12, b20, b21, b22, a21, a22, ...}
+ * 
+ * + * \par + * where b1x and a1x are the coefficients for the first stage, + * b2x and a2x are the coefficients for the second stage, + * and so on. The pCoeffs array contains a total of 5*numStages values. + * + * \par + * The pState is a pointer to state array. + * Each Biquad stage has 4 state variables x[n-1], x[n-2], y[n-1], and y[n-2]. + * The state variables are arranged in the pState array as: + *
+ *     {x[n-1], x[n-2], y[n-1], y[n-2]}
+ * 
+ * The 4 state variables for stage 1 are first, then the 4 state variables for stage 2, and so on. + * The state array has a total length of 4*numStages values. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + * + */ + +void arm_biquad_cascade_df1_init_f32( + arm_biquad_casd_df1_inst_f32 * S, + uint8_t numStages, + float32_t * pCoeffs, + float32_t * pState) +{ + /* Assign filter stages */ + S->numStages = numStages; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always 4 * numStages */ + memset(pState, 0, (4U * (uint32_t) numStages) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; +} + +/** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q15.c new file mode 100644 index 0000000..dd46fb4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q15.c @@ -0,0 +1,99 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_init_q15.c + * Description: Q15 Biquad cascade DirectFormI(DF1) filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @details + * + * @param[in,out] *S points to an instance of the Q15 Biquad cascade structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] postShift Shift to be applied to the accumulator result. Varies according to the coefficients format + * @return none + * + * Coefficient and State Ordering: + * + * \par + * The coefficients are stored in the array pCoeffs in the following order: + *
+ *     {b10, 0, b11, b12, a11, a12, b20, 0, b21, b22, a21, a22, ...}
+ * 
+ * where b1x and a1x are the coefficients for the first stage, + * b2x and a2x are the coefficients for the second stage, + * and so on. The pCoeffs array contains a total of 6*numStages values. + * The zero coefficient between b1 and b2 facilities use of 16-bit SIMD instructions on the Cortex-M4. + * + * \par + * The state variables are stored in the array pState. + * Each Biquad stage has 4 state variables x[n-1], x[n-2], y[n-1], and y[n-2]. + * The state variables are arranged in the pState array as: + *
+ *     {x[n-1], x[n-2], y[n-1], y[n-2]}
+ * 
+ * The 4 state variables for stage 1 are first, then the 4 state variables for stage 2, and so on. + * The state array has a total length of 4*numStages values. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + */ + +void arm_biquad_cascade_df1_init_q15( + arm_biquad_casd_df1_inst_q15 * S, + uint8_t numStages, + q15_t * pCoeffs, + q15_t * pState, + int8_t postShift) +{ + /* Assign filter stages */ + S->numStages = numStages; + + /* Assign postShift to be applied to the output */ + S->postShift = postShift; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always 4 * numStages */ + memset(pState, 0, (4U * (uint32_t) numStages) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; +} + +/** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q31.c new file mode 100644 index 0000000..10fb6bc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_init_q31.c @@ -0,0 +1,98 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_init_q31.c + * Description: Q31 Biquad cascade DirectFormI(DF1) filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @details + * + * @param[in,out] *S points to an instance of the Q31 Biquad cascade structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] *pCoeffs points to the filter coefficients buffer. + * @param[in] *pState points to the state buffer. + * @param[in] postShift Shift to be applied after the accumulator. Varies according to the coefficients format + * @return none + * + * Coefficient and State Ordering: + * + * \par + * The coefficients are stored in the array pCoeffs in the following order: + *
+ *     {b10, b11, b12, a11, a12, b20, b21, b22, a21, a22, ...}
+ * 
+ * where b1x and a1x are the coefficients for the first stage, + * b2x and a2x are the coefficients for the second stage, + * and so on. The pCoeffs array contains a total of 5*numStages values. + * + * \par + * The pState points to state variables array. + * Each Biquad stage has 4 state variables x[n-1], x[n-2], y[n-1], and y[n-2]. + * The state variables are arranged in the pState array as: + *
+ *     {x[n-1], x[n-2], y[n-1], y[n-2]}
+ * 
+ * The 4 state variables for stage 1 are first, then the 4 state variables for stage 2, and so on. + * The state array has a total length of 4*numStages values. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + */ + +void arm_biquad_cascade_df1_init_q31( + arm_biquad_casd_df1_inst_q31 * S, + uint8_t numStages, + q31_t * pCoeffs, + q31_t * pState, + int8_t postShift) +{ + /* Assign filter stages */ + S->numStages = numStages; + + /* Assign postShift to be applied to the output */ + S->postShift = postShift; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always 4 * numStages */ + memset(pState, 0, (4U * (uint32_t) numStages) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; +} + +/** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q15.c new file mode 100644 index 0000000..c524756 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q15.c @@ -0,0 +1,398 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_q15.c + * Description: Processing function for the Q15 Biquad cascade DirectFormI(DF1) filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @brief Processing function for the Q15 Biquad cascade filter. + * @param[in] *S points to an instance of the Q15 Biquad cascade structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both coefficients and state variables are represented in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * The accumulator is then shifted by postShift bits to truncate the result to 1.15 format by discarding the low 16 bits. + * Finally, the result is saturated to 1.15 format. + * + * \par + * Refer to the function arm_biquad_cascade_df1_fast_q15() for a faster but less precise implementation of this filter for Cortex-M3 and Cortex-M4. + */ + +void arm_biquad_cascade_df1_q15( + const arm_biquad_casd_df1_inst_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t *pIn = pSrc; /* Source pointer */ + q15_t *pOut = pDst; /* Destination pointer */ + q31_t in; /* Temporary variable to hold input value */ + q31_t out; /* Temporary variable to hold output value */ + q31_t b0; /* Temporary variable to hold bo value */ + q31_t b1, a1; /* Filter coefficients */ + q31_t state_in, state_out; /* Filter state variables */ + q31_t acc_l, acc_h; + q63_t acc; /* Accumulator */ + int32_t lShift = (15 - (int32_t) S->postShift); /* Post shift */ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + uint32_t sample, stage = (uint32_t) S->numStages; /* Stage loop counter */ + int32_t uShift = (32 - lShift); + + do + { + /* Read the b0 and 0 coefficients using SIMD */ + b0 = *__SIMD32(pCoeffs)++; + + /* Read the b1 and b2 coefficients using SIMD */ + b1 = *__SIMD32(pCoeffs)++; + + /* Read the a1 and a2 coefficients using SIMD */ + a1 = *__SIMD32(pCoeffs)++; + + /* Read the input state values from the state buffer: x[n-1], x[n-2] */ + state_in = *__SIMD32(pState)++; + + /* Read the output state values from the state buffer: y[n-1], y[n-2] */ + state_out = *__SIMD32(pState)--; + + /* Apply loop unrolling and compute 2 output values simultaneously. */ + /* The variable acc hold output values that are being computed: + * + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + sample = blockSize >> 1U; + + /* First part of the processing with loop unrolling. Compute 2 outputs at a time. + ** a second loop below computes the remaining 1 sample. */ + while (sample > 0U) + { + + /* Read the input */ + in = *__SIMD32(pIn)++; + + /* out = b0 * x[n] + 0 * 0 */ + out = __SMUAD(b0, in); + + /* acc += b1 * x[n-1] + b2 * x[n-2] + out */ + acc = __SMLALD(b1, state_in, out); + /* acc += a1 * y[n-1] + a2 * y[n-2] */ + acc = __SMLALD(a1, state_out, acc); + + /* The result is converted from 3.29 to 1.31 if postShift = 1, and then saturation is applied */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + out = (uint32_t) acc_l >> lShift | acc_h << uShift; + + out = __SSAT(out, 16); + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + /* x[n-N], x[n-N-1] are packed together to make state_in of type q31 */ + /* y[n-N], y[n-N-1] are packed together to make state_out of type q31 */ + +#ifndef ARM_MATH_BIG_ENDIAN + + state_in = __PKHBT(in, state_in, 16); + state_out = __PKHBT(out, state_out, 16); + +#else + + state_in = __PKHBT(state_in >> 16, (in >> 16), 16); + state_out = __PKHBT(state_out >> 16, (out), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* out = b0 * x[n] + 0 * 0 */ + out = __SMUADX(b0, in); + /* acc += b1 * x[n-1] + b2 * x[n-2] + out */ + acc = __SMLALD(b1, state_in, out); + /* acc += a1 * y[n-1] + a2 * y[n-2] */ + acc = __SMLALD(a1, state_out, acc); + + /* The result is converted from 3.29 to 1.31 if postShift = 1, and then saturation is applied */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + out = (uint32_t) acc_l >> lShift | acc_h << uShift; + + out = __SSAT(out, 16); + + /* Store the output in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = __PKHBT(state_out, out, 16); + +#else + + *__SIMD32(pOut)++ = __PKHBT(out, state_out >> 16, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + /* x[n-N], x[n-N-1] are packed together to make state_in of type q31 */ + /* y[n-N], y[n-N-1] are packed together to make state_out of type q31 */ +#ifndef ARM_MATH_BIG_ENDIAN + + state_in = __PKHBT(in >> 16, state_in, 16); + state_out = __PKHBT(out, state_out, 16); + +#else + + state_in = __PKHBT(state_in >> 16, in, 16); + state_out = __PKHBT(state_out >> 16, out, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + + /* Decrement the loop counter */ + sample--; + + } + + /* If the blockSize is not a multiple of 2, compute any remaining output samples here. + ** No loop unrolling is used. */ + + if ((blockSize & 0x1U) != 0U) + { + /* Read the input */ + in = *pIn++; + + /* out = b0 * x[n] + 0 * 0 */ + +#ifndef ARM_MATH_BIG_ENDIAN + + out = __SMUAD(b0, in); + +#else + + out = __SMUADX(b0, in); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc = b1 * x[n-1] + b2 * x[n-2] + out */ + acc = __SMLALD(b1, state_in, out); + /* acc += a1 * y[n-1] + a2 * y[n-2] */ + acc = __SMLALD(a1, state_out, acc); + + /* The result is converted from 3.29 to 1.31 if postShift = 1, and then saturation is applied */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + out = (uint32_t) acc_l >> lShift | acc_h << uShift; + + out = __SSAT(out, 16); + + /* Store the output in the destination buffer. */ + *pOut++ = (q15_t) out; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + /* x[n-N], x[n-N-1] are packed together to make state_in of type q31 */ + /* y[n-N], y[n-N-1] are packed together to make state_out of type q31 */ + +#ifndef ARM_MATH_BIG_ENDIAN + + state_in = __PKHBT(in, state_in, 16); + state_out = __PKHBT(out, state_out, 16); + +#else + + state_in = __PKHBT(state_in >> 16, in, 16); + state_out = __PKHBT(state_out >> 16, out, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + } + + /* The first stage goes from the input wire to the output wire. */ + /* Subsequent numStages occur in-place in the output wire */ + pIn = pDst; + + /* Reset the output pointer */ + pOut = pDst; + + /* Store the updated state variables back into the state array */ + *__SIMD32(pState)++ = state_in; + *__SIMD32(pState)++ = state_out; + + + /* Decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#else + + /* Run the below code for Cortex-M0 */ + + q15_t *pIn = pSrc; /* Source pointer */ + q15_t *pOut = pDst; /* Destination pointer */ + q15_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q15_t Xn1, Xn2, Yn1, Yn2; /* Filter state variables */ + q15_t Xn; /* temporary input */ + q63_t acc; /* Accumulator */ + int32_t shift = (15 - (int32_t) S->postShift); /* Post shift */ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + uint32_t sample, stage = (uint32_t) S->numStages; /* Stage loop counter */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + pCoeffs++; // skip the 0 coefficient + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* The variables acc holds the output value that is computed: + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + acc = (q31_t) b0 *Xn; + + /* acc += b1 * x[n-1] */ + acc += (q31_t) b1 *Xn1; + /* acc += b[2] * x[n-2] */ + acc += (q31_t) b2 *Xn2; + /* acc += a1 * y[n-1] */ + acc += (q31_t) a1 *Yn1; + /* acc += a2 * y[n-2] */ + acc += (q31_t) a2 *Yn2; + + /* The result is converted to 1.31 */ + acc = __SSAT((acc >> shift), 16); + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = (q15_t) acc; + + /* Store the output in the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + + +/** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q31.c new file mode 100644 index 0000000..da367ec --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df1_q31.c @@ -0,0 +1,392 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df1_q31.c + * Description: Processing function for the Q31 Biquad cascade filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF1 + * @{ + */ + +/** + * @brief Processing function for the Q31 Biquad cascade filter. + * @param[in] *S points to an instance of the Q31 Biquad cascade structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clip. + * In order to avoid overflows completely the input signal must be scaled down by 2 bits and lie in the range [-0.25 +0.25). + * After all 5 multiply-accumulates are performed, the 2.62 accumulator is shifted by postShift bits and the result truncated to + * 1.31 format by discarding the low 32 bits. + * + * \par + * Refer to the function arm_biquad_cascade_df1_fast_q31() for a faster but less precise implementation of this filter for Cortex-M3 and Cortex-M4. + */ + +void arm_biquad_cascade_df1_q31( + const arm_biquad_casd_df1_inst_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q63_t acc; /* accumulator */ + uint32_t uShift = ((uint32_t) S->postShift + 1U); + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + q31_t *pIn = pSrc; /* input pointer initialization */ + q31_t *pOut = pDst; /* output pointer initialization */ + q31_t *pState = S->pState; /* pState pointer initialization */ + q31_t *pCoeffs = S->pCoeffs; /* coeff pointer initialization */ + q31_t Xn1, Xn2, Yn1, Yn2; /* Filter state variables */ + q31_t b0, b1, b2, a1, a2; /* Filter coefficients */ + q31_t Xn; /* temporary input */ + uint32_t sample, stage = S->numStages; /* loop counters */ + + +#if defined (ARM_MATH_DSP) + + q31_t acc_l, acc_h; /* temporary output variables */ + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* Apply loop unrolling and compute 4 output values simultaneously. */ + /* The variable acc hold output values that are being computed: + * + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) b0 *Xn; + /* acc += b1 * x[n-1] */ + acc += (q63_t) b1 *Xn1; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) b2 *Xn2; + /* acc += a1 * y[n-1] */ + acc += (q63_t) a1 *Yn1; + /* acc += a2 * y[n-2] */ + acc += (q63_t) a2 *Yn2; + + /* The result is converted to 1.31 , Yn2 variable is reused */ + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + Yn2 = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer. */ + *pOut++ = Yn2; + + /* Read the second input */ + Xn2 = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) b0 *Xn2; + /* acc += b1 * x[n-1] */ + acc += (q63_t) b1 *Xn; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) b2 *Xn1; + /* acc += a1 * y[n-1] */ + acc += (q63_t) a1 *Yn2; + /* acc += a2 * y[n-2] */ + acc += (q63_t) a2 *Yn1; + + + /* The result is converted to 1.31, Yn1 variable is reused */ + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + + /* Apply shift for lower part of acc and upper part of acc */ + Yn1 = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer. */ + *pOut++ = Yn1; + + /* Read the third input */ + Xn1 = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) b0 *Xn1; + /* acc += b1 * x[n-1] */ + acc += (q63_t) b1 *Xn2; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) b2 *Xn; + /* acc += a1 * y[n-1] */ + acc += (q63_t) a1 *Yn1; + /* acc += a2 * y[n-2] */ + acc += (q63_t) a2 *Yn2; + + /* The result is converted to 1.31, Yn2 variable is reused */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + + /* Apply shift for lower part of acc and upper part of acc */ + Yn2 = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the output in the destination buffer. */ + *pOut++ = Yn2; + + /* Read the forth input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) b0 *Xn; + /* acc += b1 * x[n-1] */ + acc += (q63_t) b1 *Xn1; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) b2 *Xn2; + /* acc += a1 * y[n-1] */ + acc += (q63_t) a1 *Yn2; + /* acc += a2 * y[n-2] */ + acc += (q63_t) a2 *Yn1; + + /* The result is converted to 1.31, Yn1 variable is reused */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + Yn1 = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + + /* Store the output in the destination buffer. */ + *pOut++ = Yn1; + + /* decrement the loop counter */ + sample--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + sample = (blockSize & 0x3U); + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + + /* acc = b0 * x[n] */ + acc = (q63_t) b0 *Xn; + /* acc += b1 * x[n-1] */ + acc += (q63_t) b1 *Xn1; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) b2 *Xn2; + /* acc += a1 * y[n-1] */ + acc += (q63_t) a1 *Yn1; + /* acc += a2 * y[n-2] */ + acc += (q63_t) a2 *Yn2; + + /* The result is converted to 1.31 */ + acc = acc >> lShift; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = (q31_t) acc; + + /* Store the output in the destination buffer. */ + *pOut++ = (q31_t) acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); + +#else + + /* Run the below code for Cortex-M0 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /* Reading the state values */ + Xn1 = pState[0]; + Xn2 = pState[1]; + Yn1 = pState[2]; + Yn2 = pState[3]; + + /* The variables acc holds the output value that is computed: + * acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] + */ + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn = *pIn++; + + /* acc = b0 * x[n] + b1 * x[n-1] + b2 * x[n-2] + a1 * y[n-1] + a2 * y[n-2] */ + /* acc = b0 * x[n] */ + acc = (q63_t) b0 *Xn; + + /* acc += b1 * x[n-1] */ + acc += (q63_t) b1 *Xn1; + /* acc += b[2] * x[n-2] */ + acc += (q63_t) b2 *Xn2; + /* acc += a1 * y[n-1] */ + acc += (q63_t) a1 *Yn1; + /* acc += a2 * y[n-2] */ + acc += (q63_t) a2 *Yn2; + + /* The result is converted to 1.31 */ + acc = acc >> lShift; + + /* Every time after the output is computed state should be updated. */ + /* The states should be updated as: */ + /* Xn2 = Xn1 */ + /* Xn1 = Xn */ + /* Yn2 = Yn1 */ + /* Yn1 = acc */ + Xn2 = Xn1; + Xn1 = Xn; + Yn2 = Yn1; + Yn1 = (q31_t) acc; + + /* Store the output in the destination buffer. */ + *pOut++ = (q31_t) acc; + + /* decrement the loop counter */ + sample--; + } + + /* The first stage goes from the input buffer to the output buffer. */ + /* Subsequent stages occur in-place in the output buffer */ + pIn = pDst; + + /* Reset to destination pointer */ + pOut = pDst; + + /* Store the updated state variables back into the pState array */ + *pState++ = Xn1; + *pState++ = Xn2; + *pState++ = Yn1; + *pState++ = Yn2; + + } while (--stage); + +#endif /* #if defined (ARM_MATH_DSP) */ +} + + + + +/** + * @} end of BiquadCascadeDF1 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f32.c new file mode 100644 index 0000000..3f1ce03 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f32.c @@ -0,0 +1,590 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df2T_f32.c + * Description: Processing function for floating-point transposed direct form II Biquad cascade filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** +* @ingroup groupFilters +*/ + +/** +* @defgroup BiquadCascadeDF2T Biquad Cascade IIR Filters Using a Direct Form II Transposed Structure +* +* This set of functions implements arbitrary order recursive (IIR) filters using a transposed direct form II structure. +* The filters are implemented as a cascade of second order Biquad sections. +* These functions provide a slight memory savings as compared to the direct form I Biquad filter functions. +* Only floating-point data is supported. +* +* This function operate on blocks of input and output data and each call to the function +* processes blockSize samples through the filter. +* pSrc points to the array of input data and +* pDst points to the array of output data. +* Both arrays contain blockSize values. +* +* \par Algorithm +* Each Biquad stage implements a second order filter using the difference equation: +*
+*    y[n] = b0 * x[n] + d1
+*    d1 = b1 * x[n] + a1 * y[n] + d2
+*    d2 = b2 * x[n] + a2 * y[n]
+* 
+* where d1 and d2 represent the two state values. +* +* \par +* A Biquad filter using a transposed Direct Form II structure is shown below. +* \image html BiquadDF2Transposed.gif "Single transposed Direct Form II Biquad" +* Coefficients b0, b1, and b2 multiply the input signal x[n] and are referred to as the feedforward coefficients. +* Coefficients a1 and a2 multiply the output signal y[n] and are referred to as the feedback coefficients. +* Pay careful attention to the sign of the feedback coefficients. +* Some design tools flip the sign of the feedback coefficients: +*
+*    y[n] = b0 * x[n] + d1;
+*    d1 = b1 * x[n] - a1 * y[n] + d2;
+*    d2 = b2 * x[n] - a2 * y[n];
+* 
+* In this case the feedback coefficients a1 and a2 must be negated when used with the CMSIS DSP Library. +* +* \par +* Higher order filters are realized as a cascade of second order sections. +* numStages refers to the number of second order stages used. +* For example, an 8th order filter would be realized with numStages=4 second order stages. +* A 9th order filter would be realized with numStages=5 second order stages with the +* coefficients for one of the stages configured as a first order filter (b2=0 and a2=0). +* +* \par +* pState points to the state variable array. +* Each Biquad stage has 2 state variables d1 and d2. +* The state variables are arranged in the pState array as: +*
+*     {d11, d12, d21, d22, ...}
+* 
+* where d1x refers to the state variables for the first Biquad and +* d2x refers to the state variables for the second Biquad. +* The state array has a total length of 2*numStages values. +* The state variables are updated after each block of data is processed; the coefficients are untouched. +* +* \par +* The CMSIS library contains Biquad filters in both Direct Form I and transposed Direct Form II. +* The advantage of the Direct Form I structure is that it is numerically more robust for fixed-point data types. +* That is why the Direct Form I structure supports Q15 and Q31 data types. +* The transposed Direct Form II structure, on the other hand, requires a wide dynamic range for the state variables d1 and d2. +* Because of this, the CMSIS library only has a floating-point version of the Direct Form II Biquad. +* The advantage of the Direct Form II Biquad is that it requires half the number of state variables, 2 rather than 4, per Biquad stage. +* +* \par Instance Structure +* The coefficients and state variables for a filter are stored together in an instance data structure. +* A separate instance structure must be defined for each filter. +* Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. +* +* \par Init Functions +* There is also an associated initialization function. +* The initialization function performs following operations: +* - Sets the values of the internal structure fields. +* - Zeros out the values in the state buffer. +* To do this manually without calling the init function, assign the follow subfields of the instance structure: +* numStages, pCoeffs, pState. Also set all of the values in pState to zero. +* +* \par +* Use of the initialization function is optional. +* However, if the initialization function is used, then the instance structure cannot be placed into a const data section. +* To place an instance structure into a const data section, the instance structure must be manually initialized. +* Set the values in the state buffer to zeros before static initialization. +* For example, to statically initialize the instance structure use +*
+*     arm_biquad_cascade_df2T_instance_f32 S1 = {numStages, pState, pCoeffs};
+* 
+* where numStages is the number of Biquad stages in the filter; pState is the address of the state buffer. +* pCoeffs is the address of the coefficient buffer; +* +*/ + +/** +* @addtogroup BiquadCascadeDF2T +* @{ +*/ + +/** +* @brief Processing function for the floating-point transposed direct form II Biquad cascade filter. +* @param[in] *S points to an instance of the filter data structure. +* @param[in] *pSrc points to the block of input data. +* @param[out] *pDst points to the block of output data +* @param[in] blockSize number of samples to process. +* @return none. +*/ + + +LOW_OPTIMIZATION_ENTER +void arm_biquad_cascade_df2T_f32( +const arm_biquad_cascade_df2T_instance_f32 * S, +float32_t * pSrc, +float32_t * pDst, +uint32_t blockSize) +{ + + float32_t *pIn = pSrc; /* source pointer */ + float32_t *pOut = pDst; /* destination pointer */ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float32_t acc1; /* accumulator */ + float32_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float32_t Xn1; /* temporary input */ + float32_t d1, d2; /* state variables */ + uint32_t sample, stage = S->numStages; /* loop counters */ + +#if defined(ARM_MATH_CM7) + + float32_t Xn2, Xn3, Xn4, Xn5, Xn6, Xn7, Xn8; /* Input State variables */ + float32_t Xn9, Xn10, Xn11, Xn12, Xn13, Xn14, Xn15, Xn16; + float32_t acc2, acc3, acc4, acc5, acc6, acc7; /* Simulates the accumulator */ + float32_t acc8, acc9, acc10, acc11, acc12, acc13, acc14, acc15, acc16; + + do + { + /* Reading the coefficients */ + b0 = pCoeffs[0]; + b1 = pCoeffs[1]; + b2 = pCoeffs[2]; + a1 = pCoeffs[3]; + /* Apply loop unrolling and compute 16 output values simultaneously. */ + sample = blockSize >> 4U; + a2 = pCoeffs[4]; + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + pCoeffs += 5U; + + + /* First part of the processing with loop unrolling. Compute 16 outputs at a time. + ** a second loop below computes the remaining 1 to 15 samples. */ + while (sample > 0U) { + + /* y[n] = b0 * x[n] + d1 */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + /* d2 = b2 * x[n] + a2 * y[n] */ + + /* Read the first 2 inputs. 2 cycles */ + Xn1 = pIn[0 ]; + Xn2 = pIn[1 ]; + + /* Sample 1. 5 cycles */ + Xn3 = pIn[2 ]; + acc1 = b0 * Xn1 + d1; + + Xn4 = pIn[3 ]; + d1 = b1 * Xn1 + d2; + + Xn5 = pIn[4 ]; + d2 = b2 * Xn1; + + Xn6 = pIn[5 ]; + d1 += a1 * acc1; + + Xn7 = pIn[6 ]; + d2 += a2 * acc1; + + /* Sample 2. 5 cycles */ + Xn8 = pIn[7 ]; + acc2 = b0 * Xn2 + d1; + + Xn9 = pIn[8 ]; + d1 = b1 * Xn2 + d2; + + Xn10 = pIn[9 ]; + d2 = b2 * Xn2; + + Xn11 = pIn[10]; + d1 += a1 * acc2; + + Xn12 = pIn[11]; + d2 += a2 * acc2; + + /* Sample 3. 5 cycles */ + Xn13 = pIn[12]; + acc3 = b0 * Xn3 + d1; + + Xn14 = pIn[13]; + d1 = b1 * Xn3 + d2; + + Xn15 = pIn[14]; + d2 = b2 * Xn3; + + Xn16 = pIn[15]; + d1 += a1 * acc3; + + pIn += 16; + d2 += a2 * acc3; + + /* Sample 4. 5 cycles */ + acc4 = b0 * Xn4 + d1; + d1 = b1 * Xn4 + d2; + d2 = b2 * Xn4; + d1 += a1 * acc4; + d2 += a2 * acc4; + + /* Sample 5. 5 cycles */ + acc5 = b0 * Xn5 + d1; + d1 = b1 * Xn5 + d2; + d2 = b2 * Xn5; + d1 += a1 * acc5; + d2 += a2 * acc5; + + /* Sample 6. 5 cycles */ + acc6 = b0 * Xn6 + d1; + d1 = b1 * Xn6 + d2; + d2 = b2 * Xn6; + d1 += a1 * acc6; + d2 += a2 * acc6; + + /* Sample 7. 5 cycles */ + acc7 = b0 * Xn7 + d1; + d1 = b1 * Xn7 + d2; + d2 = b2 * Xn7; + d1 += a1 * acc7; + d2 += a2 * acc7; + + /* Sample 8. 5 cycles */ + acc8 = b0 * Xn8 + d1; + d1 = b1 * Xn8 + d2; + d2 = b2 * Xn8; + d1 += a1 * acc8; + d2 += a2 * acc8; + + /* Sample 9. 5 cycles */ + acc9 = b0 * Xn9 + d1; + d1 = b1 * Xn9 + d2; + d2 = b2 * Xn9; + d1 += a1 * acc9; + d2 += a2 * acc9; + + /* Sample 10. 5 cycles */ + acc10 = b0 * Xn10 + d1; + d1 = b1 * Xn10 + d2; + d2 = b2 * Xn10; + d1 += a1 * acc10; + d2 += a2 * acc10; + + /* Sample 11. 5 cycles */ + acc11 = b0 * Xn11 + d1; + d1 = b1 * Xn11 + d2; + d2 = b2 * Xn11; + d1 += a1 * acc11; + d2 += a2 * acc11; + + /* Sample 12. 5 cycles */ + acc12 = b0 * Xn12 + d1; + d1 = b1 * Xn12 + d2; + d2 = b2 * Xn12; + d1 += a1 * acc12; + d2 += a2 * acc12; + + /* Sample 13. 5 cycles */ + acc13 = b0 * Xn13 + d1; + d1 = b1 * Xn13 + d2; + d2 = b2 * Xn13; + + pOut[0 ] = acc1 ; + d1 += a1 * acc13; + + pOut[1 ] = acc2 ; + d2 += a2 * acc13; + + /* Sample 14. 5 cycles */ + pOut[2 ] = acc3 ; + acc14 = b0 * Xn14 + d1; + + pOut[3 ] = acc4 ; + d1 = b1 * Xn14 + d2; + + pOut[4 ] = acc5 ; + d2 = b2 * Xn14; + + pOut[5 ] = acc6 ; + d1 += a1 * acc14; + + pOut[6 ] = acc7 ; + d2 += a2 * acc14; + + /* Sample 15. 5 cycles */ + pOut[7 ] = acc8 ; + pOut[8 ] = acc9 ; + acc15 = b0 * Xn15 + d1; + + pOut[9 ] = acc10; + d1 = b1 * Xn15 + d2; + + pOut[10] = acc11; + d2 = b2 * Xn15; + + pOut[11] = acc12; + d1 += a1 * acc15; + + pOut[12] = acc13; + d2 += a2 * acc15; + + /* Sample 16. 5 cycles */ + pOut[13] = acc14; + acc16 = b0 * Xn16 + d1; + + pOut[14] = acc15; + d1 = b1 * Xn16 + d2; + + pOut[15] = acc16; + d2 = b2 * Xn16; + + sample--; + d1 += a1 * acc16; + + pOut += 16; + d2 += a2 * acc16; + } + + sample = blockSize & 0xFu; + while (sample > 0U) { + Xn1 = *pIn; + acc1 = b0 * Xn1 + d1; + + pIn++; + d1 = b1 * Xn1 + d2; + + *pOut = acc1; + d2 = b2 * Xn1; + + pOut++; + d1 += a1 * acc1; + + sample--; + d2 += a2 * acc1; + } + + /* Store the updated state variables back into the state array */ + pState[0] = d1; + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + pState[1] = d2; + /* decrement the loop counter */ + stage--; + + pState += 2U; + + /*Reset the output working pointer */ + pOut = pDst; + + } while (stage > 0U); + +#elif defined(ARM_MATH_CM0_FAMILY) + + /* Run the below code for Cortex-M0 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn1 = *pIn++; + + /* y[n] = b0 * x[n] + d1 */ + acc1 = (b0 * Xn1) + d1; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc1; + + /* Every time after the output is computed state should be updated. */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + d1 = ((b1 * Xn1) + (a1 * acc1)) + d2; + + /* d2 = b2 * x[n] + a2 * y[n] */ + d2 = (b2 * Xn1) + (a2 * acc1); + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1; + *pState++ = d2; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#else + + float32_t Xn2, Xn3, Xn4; /* Input State variables */ + float32_t acc2, acc3, acc4; /* accumulator */ + + + float32_t p0, p1, p2, p3, p4, A1; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + /* Apply loop unrolling and compute 4 output values simultaneously. */ + sample = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (sample > 0U) { + + /* y[n] = b0 * x[n] + d1 */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + /* d2 = b2 * x[n] + a2 * y[n] */ + + /* Read the four inputs */ + Xn1 = pIn[0]; + Xn2 = pIn[1]; + Xn3 = pIn[2]; + Xn4 = pIn[3]; + pIn += 4; + + p0 = b0 * Xn1; + p1 = b1 * Xn1; + acc1 = p0 + d1; + p0 = b0 * Xn2; + p3 = a1 * acc1; + p2 = b2 * Xn1; + A1 = p1 + p3; + p4 = a2 * acc1; + d1 = A1 + d2; + d2 = p2 + p4; + + p1 = b1 * Xn2; + acc2 = p0 + d1; + p0 = b0 * Xn3; + p3 = a1 * acc2; + p2 = b2 * Xn2; + A1 = p1 + p3; + p4 = a2 * acc2; + d1 = A1 + d2; + d2 = p2 + p4; + + p1 = b1 * Xn3; + acc3 = p0 + d1; + p0 = b0 * Xn4; + p3 = a1 * acc3; + p2 = b2 * Xn3; + A1 = p1 + p3; + p4 = a2 * acc3; + d1 = A1 + d2; + d2 = p2 + p4; + + acc4 = p0 + d1; + p1 = b1 * Xn4; + p3 = a1 * acc4; + p2 = b2 * Xn4; + A1 = p1 + p3; + p4 = a2 * acc4; + d1 = A1 + d2; + d2 = p2 + p4; + + pOut[0] = acc1; + pOut[1] = acc2; + pOut[2] = acc3; + pOut[3] = acc4; + pOut += 4; + + sample--; + } + + sample = blockSize & 0x3U; + while (sample > 0U) { + Xn1 = *pIn++; + + p0 = b0 * Xn1; + p1 = b1 * Xn1; + acc1 = p0 + d1; + p3 = a1 * acc1; + p2 = b2 * Xn1; + A1 = p1 + p3; + p4 = a2 * acc1; + d1 = A1 + d2; + d2 = p2 + p4; + + *pOut++ = acc1; + + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1; + *pState++ = d2; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#endif + +} +LOW_OPTIMIZATION_EXIT + +/** + * @} end of BiquadCascadeDF2T group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f64.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f64.c new file mode 100644 index 0000000..8f8a830 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_f64.c @@ -0,0 +1,590 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df2T_f64.c + * Description: Processing function for floating-point transposed direct form II Biquad cascade filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** +* @ingroup groupFilters +*/ + +/** +* @defgroup BiquadCascadeDF2T Biquad Cascade IIR Filters Using a Direct Form II Transposed Structure +* +* This set of functions implements arbitrary order recursive (IIR) filters using a transposed direct form II structure. +* The filters are implemented as a cascade of second order Biquad sections. +* These functions provide a slight memory savings as compared to the direct form I Biquad filter functions. +* Only floating-point data is supported. +* +* This function operate on blocks of input and output data and each call to the function +* processes blockSize samples through the filter. +* pSrc points to the array of input data and +* pDst points to the array of output data. +* Both arrays contain blockSize values. +* +* \par Algorithm +* Each Biquad stage implements a second order filter using the difference equation: +*
+*    y[n] = b0 * x[n] + d1
+*    d1 = b1 * x[n] + a1 * y[n] + d2
+*    d2 = b2 * x[n] + a2 * y[n]
+* 
+* where d1 and d2 represent the two state values. +* +* \par +* A Biquad filter using a transposed Direct Form II structure is shown below. +* \image html BiquadDF2Transposed.gif "Single transposed Direct Form II Biquad" +* Coefficients b0, b1, and b2 multiply the input signal x[n] and are referred to as the feedforward coefficients. +* Coefficients a1 and a2 multiply the output signal y[n] and are referred to as the feedback coefficients. +* Pay careful attention to the sign of the feedback coefficients. +* Some design tools flip the sign of the feedback coefficients: +*
+*    y[n] = b0 * x[n] + d1;
+*    d1 = b1 * x[n] - a1 * y[n] + d2;
+*    d2 = b2 * x[n] - a2 * y[n];
+* 
+* In this case the feedback coefficients a1 and a2 must be negated when used with the CMSIS DSP Library. +* +* \par +* Higher order filters are realized as a cascade of second order sections. +* numStages refers to the number of second order stages used. +* For example, an 8th order filter would be realized with numStages=4 second order stages. +* A 9th order filter would be realized with numStages=5 second order stages with the +* coefficients for one of the stages configured as a first order filter (b2=0 and a2=0). +* +* \par +* pState points to the state variable array. +* Each Biquad stage has 2 state variables d1 and d2. +* The state variables are arranged in the pState array as: +*
+*     {d11, d12, d21, d22, ...}
+* 
+* where d1x refers to the state variables for the first Biquad and +* d2x refers to the state variables for the second Biquad. +* The state array has a total length of 2*numStages values. +* The state variables are updated after each block of data is processed; the coefficients are untouched. +* +* \par +* The CMSIS library contains Biquad filters in both Direct Form I and transposed Direct Form II. +* The advantage of the Direct Form I structure is that it is numerically more robust for fixed-point data types. +* That is why the Direct Form I structure supports Q15 and Q31 data types. +* The transposed Direct Form II structure, on the other hand, requires a wide dynamic range for the state variables d1 and d2. +* Because of this, the CMSIS library only has a floating-point version of the Direct Form II Biquad. +* The advantage of the Direct Form II Biquad is that it requires half the number of state variables, 2 rather than 4, per Biquad stage. +* +* \par Instance Structure +* The coefficients and state variables for a filter are stored together in an instance data structure. +* A separate instance structure must be defined for each filter. +* Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. +* +* \par Init Functions +* There is also an associated initialization function. +* The initialization function performs following operations: +* - Sets the values of the internal structure fields. +* - Zeros out the values in the state buffer. +* To do this manually without calling the init function, assign the follow subfields of the instance structure: +* numStages, pCoeffs, pState. Also set all of the values in pState to zero. +* +* \par +* Use of the initialization function is optional. +* However, if the initialization function is used, then the instance structure cannot be placed into a const data section. +* To place an instance structure into a const data section, the instance structure must be manually initialized. +* Set the values in the state buffer to zeros before static initialization. +* For example, to statically initialize the instance structure use +*
+*     arm_biquad_cascade_df2T_instance_f64 S1 = {numStages, pState, pCoeffs};
+* 
+* where numStages is the number of Biquad stages in the filter; pState is the address of the state buffer. +* pCoeffs is the address of the coefficient buffer; +* +*/ + +/** +* @addtogroup BiquadCascadeDF2T +* @{ +*/ + +/** +* @brief Processing function for the floating-point transposed direct form II Biquad cascade filter. +* @param[in] *S points to an instance of the filter data structure. +* @param[in] *pSrc points to the block of input data. +* @param[out] *pDst points to the block of output data +* @param[in] blockSize number of samples to process. +* @return none. +*/ + + +LOW_OPTIMIZATION_ENTER +void arm_biquad_cascade_df2T_f64( +const arm_biquad_cascade_df2T_instance_f64 * S, +float64_t * pSrc, +float64_t * pDst, +uint32_t blockSize) +{ + + float64_t *pIn = pSrc; /* source pointer */ + float64_t *pOut = pDst; /* destination pointer */ + float64_t *pState = S->pState; /* State pointer */ + float64_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float64_t acc1; /* accumulator */ + float64_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float64_t Xn1; /* temporary input */ + float64_t d1, d2; /* state variables */ + uint32_t sample, stage = S->numStages; /* loop counters */ + +#if defined(ARM_MATH_CM7) + + float64_t Xn2, Xn3, Xn4, Xn5, Xn6, Xn7, Xn8; /* Input State variables */ + float64_t Xn9, Xn10, Xn11, Xn12, Xn13, Xn14, Xn15, Xn16; + float64_t acc2, acc3, acc4, acc5, acc6, acc7; /* Simulates the accumulator */ + float64_t acc8, acc9, acc10, acc11, acc12, acc13, acc14, acc15, acc16; + + do + { + /* Reading the coefficients */ + b0 = pCoeffs[0]; + b1 = pCoeffs[1]; + b2 = pCoeffs[2]; + a1 = pCoeffs[3]; + /* Apply loop unrolling and compute 16 output values simultaneously. */ + sample = blockSize >> 4U; + a2 = pCoeffs[4]; + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + pCoeffs += 5U; + + + /* First part of the processing with loop unrolling. Compute 16 outputs at a time. + ** a second loop below computes the remaining 1 to 15 samples. */ + while (sample > 0U) { + + /* y[n] = b0 * x[n] + d1 */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + /* d2 = b2 * x[n] + a2 * y[n] */ + + /* Read the first 2 inputs. 2 cycles */ + Xn1 = pIn[0 ]; + Xn2 = pIn[1 ]; + + /* Sample 1. 5 cycles */ + Xn3 = pIn[2 ]; + acc1 = b0 * Xn1 + d1; + + Xn4 = pIn[3 ]; + d1 = b1 * Xn1 + d2; + + Xn5 = pIn[4 ]; + d2 = b2 * Xn1; + + Xn6 = pIn[5 ]; + d1 += a1 * acc1; + + Xn7 = pIn[6 ]; + d2 += a2 * acc1; + + /* Sample 2. 5 cycles */ + Xn8 = pIn[7 ]; + acc2 = b0 * Xn2 + d1; + + Xn9 = pIn[8 ]; + d1 = b1 * Xn2 + d2; + + Xn10 = pIn[9 ]; + d2 = b2 * Xn2; + + Xn11 = pIn[10]; + d1 += a1 * acc2; + + Xn12 = pIn[11]; + d2 += a2 * acc2; + + /* Sample 3. 5 cycles */ + Xn13 = pIn[12]; + acc3 = b0 * Xn3 + d1; + + Xn14 = pIn[13]; + d1 = b1 * Xn3 + d2; + + Xn15 = pIn[14]; + d2 = b2 * Xn3; + + Xn16 = pIn[15]; + d1 += a1 * acc3; + + pIn += 16; + d2 += a2 * acc3; + + /* Sample 4. 5 cycles */ + acc4 = b0 * Xn4 + d1; + d1 = b1 * Xn4 + d2; + d2 = b2 * Xn4; + d1 += a1 * acc4; + d2 += a2 * acc4; + + /* Sample 5. 5 cycles */ + acc5 = b0 * Xn5 + d1; + d1 = b1 * Xn5 + d2; + d2 = b2 * Xn5; + d1 += a1 * acc5; + d2 += a2 * acc5; + + /* Sample 6. 5 cycles */ + acc6 = b0 * Xn6 + d1; + d1 = b1 * Xn6 + d2; + d2 = b2 * Xn6; + d1 += a1 * acc6; + d2 += a2 * acc6; + + /* Sample 7. 5 cycles */ + acc7 = b0 * Xn7 + d1; + d1 = b1 * Xn7 + d2; + d2 = b2 * Xn7; + d1 += a1 * acc7; + d2 += a2 * acc7; + + /* Sample 8. 5 cycles */ + acc8 = b0 * Xn8 + d1; + d1 = b1 * Xn8 + d2; + d2 = b2 * Xn8; + d1 += a1 * acc8; + d2 += a2 * acc8; + + /* Sample 9. 5 cycles */ + acc9 = b0 * Xn9 + d1; + d1 = b1 * Xn9 + d2; + d2 = b2 * Xn9; + d1 += a1 * acc9; + d2 += a2 * acc9; + + /* Sample 10. 5 cycles */ + acc10 = b0 * Xn10 + d1; + d1 = b1 * Xn10 + d2; + d2 = b2 * Xn10; + d1 += a1 * acc10; + d2 += a2 * acc10; + + /* Sample 11. 5 cycles */ + acc11 = b0 * Xn11 + d1; + d1 = b1 * Xn11 + d2; + d2 = b2 * Xn11; + d1 += a1 * acc11; + d2 += a2 * acc11; + + /* Sample 12. 5 cycles */ + acc12 = b0 * Xn12 + d1; + d1 = b1 * Xn12 + d2; + d2 = b2 * Xn12; + d1 += a1 * acc12; + d2 += a2 * acc12; + + /* Sample 13. 5 cycles */ + acc13 = b0 * Xn13 + d1; + d1 = b1 * Xn13 + d2; + d2 = b2 * Xn13; + + pOut[0 ] = acc1 ; + d1 += a1 * acc13; + + pOut[1 ] = acc2 ; + d2 += a2 * acc13; + + /* Sample 14. 5 cycles */ + pOut[2 ] = acc3 ; + acc14 = b0 * Xn14 + d1; + + pOut[3 ] = acc4 ; + d1 = b1 * Xn14 + d2; + + pOut[4 ] = acc5 ; + d2 = b2 * Xn14; + + pOut[5 ] = acc6 ; + d1 += a1 * acc14; + + pOut[6 ] = acc7 ; + d2 += a2 * acc14; + + /* Sample 15. 5 cycles */ + pOut[7 ] = acc8 ; + pOut[8 ] = acc9 ; + acc15 = b0 * Xn15 + d1; + + pOut[9 ] = acc10; + d1 = b1 * Xn15 + d2; + + pOut[10] = acc11; + d2 = b2 * Xn15; + + pOut[11] = acc12; + d1 += a1 * acc15; + + pOut[12] = acc13; + d2 += a2 * acc15; + + /* Sample 16. 5 cycles */ + pOut[13] = acc14; + acc16 = b0 * Xn16 + d1; + + pOut[14] = acc15; + d1 = b1 * Xn16 + d2; + + pOut[15] = acc16; + d2 = b2 * Xn16; + + sample--; + d1 += a1 * acc16; + + pOut += 16; + d2 += a2 * acc16; + } + + sample = blockSize & 0xFu; + while (sample > 0U) { + Xn1 = *pIn; + acc1 = b0 * Xn1 + d1; + + pIn++; + d1 = b1 * Xn1 + d2; + + *pOut = acc1; + d2 = b2 * Xn1; + + pOut++; + d1 += a1 * acc1; + + sample--; + d2 += a2 * acc1; + } + + /* Store the updated state variables back into the state array */ + pState[0] = d1; + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + pState[1] = d2; + /* decrement the loop counter */ + stage--; + + pState += 2U; + + /*Reset the output working pointer */ + pOut = pDst; + + } while (stage > 0U); + +#elif defined(ARM_MATH_CM0_FAMILY) + + /* Run the below code for Cortex-M0 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn1 = *pIn++; + + /* y[n] = b0 * x[n] + d1 */ + acc1 = (b0 * Xn1) + d1; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc1; + + /* Every time after the output is computed state should be updated. */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + d1 = ((b1 * Xn1) + (a1 * acc1)) + d2; + + /* d2 = b2 * x[n] + a2 * y[n] */ + d2 = (b2 * Xn1) + (a2 * acc1); + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1; + *pState++ = d2; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#else + + float64_t Xn2, Xn3, Xn4; /* Input State variables */ + float64_t acc2, acc3, acc4; /* accumulator */ + + + float64_t p0, p1, p2, p3, p4, A1; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + + /*Reading the state values */ + d1 = pState[0]; + d2 = pState[1]; + + /* Apply loop unrolling and compute 4 output values simultaneously. */ + sample = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (sample > 0U) { + + /* y[n] = b0 * x[n] + d1 */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + /* d2 = b2 * x[n] + a2 * y[n] */ + + /* Read the four inputs */ + Xn1 = pIn[0]; + Xn2 = pIn[1]; + Xn3 = pIn[2]; + Xn4 = pIn[3]; + pIn += 4; + + p0 = b0 * Xn1; + p1 = b1 * Xn1; + acc1 = p0 + d1; + p0 = b0 * Xn2; + p3 = a1 * acc1; + p2 = b2 * Xn1; + A1 = p1 + p3; + p4 = a2 * acc1; + d1 = A1 + d2; + d2 = p2 + p4; + + p1 = b1 * Xn2; + acc2 = p0 + d1; + p0 = b0 * Xn3; + p3 = a1 * acc2; + p2 = b2 * Xn2; + A1 = p1 + p3; + p4 = a2 * acc2; + d1 = A1 + d2; + d2 = p2 + p4; + + p1 = b1 * Xn3; + acc3 = p0 + d1; + p0 = b0 * Xn4; + p3 = a1 * acc3; + p2 = b2 * Xn3; + A1 = p1 + p3; + p4 = a2 * acc3; + d1 = A1 + d2; + d2 = p2 + p4; + + acc4 = p0 + d1; + p1 = b1 * Xn4; + p3 = a1 * acc4; + p2 = b2 * Xn4; + A1 = p1 + p3; + p4 = a2 * acc4; + d1 = A1 + d2; + d2 = p2 + p4; + + pOut[0] = acc1; + pOut[1] = acc2; + pOut[2] = acc3; + pOut[3] = acc4; + pOut += 4; + + sample--; + } + + sample = blockSize & 0x3U; + while (sample > 0U) { + Xn1 = *pIn++; + + p0 = b0 * Xn1; + p1 = b1 * Xn1; + acc1 = p0 + d1; + p3 = a1 * acc1; + p2 = b2 * Xn1; + A1 = p1 + p3; + p4 = a2 * acc1; + d1 = A1 + d2; + d2 = p2 + p4; + + *pOut++ = acc1; + + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1; + *pState++ = d2; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#endif + +} +LOW_OPTIMIZATION_EXIT + +/** + * @} end of BiquadCascadeDF2T group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f32.c new file mode 100644 index 0000000..6dfc985 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f32.c @@ -0,0 +1,89 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df2T_init_f32.c + * Description: Initialization function for floating-point transposed direct form II Biquad cascade filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF2T + * @{ + */ + +/** + * @brief Initialization function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in,out] *S points to an instance of the filter data structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @return none + * + * Coefficient and State Ordering: + * \par + * The coefficients are stored in the array pCoeffs in the following order: + *
+ *     {b10, b11, b12, a11, a12, b20, b21, b22, a21, a22, ...}
+ * 
+ * + * \par + * where b1x and a1x are the coefficients for the first stage, + * b2x and a2x are the coefficients for the second stage, + * and so on. The pCoeffs array contains a total of 5*numStages values. + * + * \par + * The pState is a pointer to state array. + * Each Biquad stage has 2 state variables d1, and d2. + * The 2 state variables for stage 1 are first, then the 2 state variables for stage 2, and so on. + * The state array has a total length of 2*numStages values. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + */ + +void arm_biquad_cascade_df2T_init_f32( + arm_biquad_cascade_df2T_instance_f32 * S, + uint8_t numStages, + float32_t * pCoeffs, + float32_t * pState) +{ + /* Assign filter stages */ + S->numStages = numStages; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always 2 * numStages */ + memset(pState, 0, (2U * (uint32_t) numStages) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; +} + +/** + * @} end of BiquadCascadeDF2T group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f64.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f64.c new file mode 100644 index 0000000..8141da5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_df2T_init_f64.c @@ -0,0 +1,89 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_df2T_init_f64.c + * Description: Initialization function for floating-point transposed direct form II Biquad cascade filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF2T + * @{ + */ + +/** + * @brief Initialization function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in,out] *S points to an instance of the filter data structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @return none + * + * Coefficient and State Ordering: + * \par + * The coefficients are stored in the array pCoeffs in the following order: + *
+ *     {b10, b11, b12, a11, a12, b20, b21, b22, a21, a22, ...}
+ * 
+ * + * \par + * where b1x and a1x are the coefficients for the first stage, + * b2x and a2x are the coefficients for the second stage, + * and so on. The pCoeffs array contains a total of 5*numStages values. + * + * \par + * The pState is a pointer to state array. + * Each Biquad stage has 2 state variables d1, and d2. + * The 2 state variables for stage 1 are first, then the 2 state variables for stage 2, and so on. + * The state array has a total length of 2*numStages values. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + */ + +void arm_biquad_cascade_df2T_init_f64( + arm_biquad_cascade_df2T_instance_f64 * S, + uint8_t numStages, + float64_t * pCoeffs, + float64_t * pState) +{ + /* Assign filter stages */ + S->numStages = numStages; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always 2 * numStages */ + memset(pState, 0, (2U * (uint32_t) numStages) * sizeof(float64_t)); + + /* Assign state pointer */ + S->pState = pState; +} + +/** + * @} end of BiquadCascadeDF2T group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_f32.c new file mode 100644 index 0000000..36084e5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_f32.c @@ -0,0 +1,670 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_stereo_df2T_f32.c + * Description: Processing function for floating-point transposed direct form II Biquad cascade filter. 2 channels + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** +* @ingroup groupFilters +*/ + +/** +* @defgroup BiquadCascadeDF2T Biquad Cascade IIR Filters Using a Direct Form II Transposed Structure +* +* This set of functions implements arbitrary order recursive (IIR) filters using a transposed direct form II structure. +* The filters are implemented as a cascade of second order Biquad sections. +* These functions provide a slight memory savings as compared to the direct form I Biquad filter functions. +* Only floating-point data is supported. +* +* This function operate on blocks of input and output data and each call to the function +* processes blockSize samples through the filter. +* pSrc points to the array of input data and +* pDst points to the array of output data. +* Both arrays contain blockSize values. +* +* \par Algorithm +* Each Biquad stage implements a second order filter using the difference equation: +*
+*    y[n] = b0 * x[n] + d1
+*    d1 = b1 * x[n] + a1 * y[n] + d2
+*    d2 = b2 * x[n] + a2 * y[n]
+* 
+* where d1 and d2 represent the two state values. +* +* \par +* A Biquad filter using a transposed Direct Form II structure is shown below. +* \image html BiquadDF2Transposed.gif "Single transposed Direct Form II Biquad" +* Coefficients b0, b1, and b2 multiply the input signal x[n] and are referred to as the feedforward coefficients. +* Coefficients a1 and a2 multiply the output signal y[n] and are referred to as the feedback coefficients. +* Pay careful attention to the sign of the feedback coefficients. +* Some design tools flip the sign of the feedback coefficients: +*
+*    y[n] = b0 * x[n] + d1;
+*    d1 = b1 * x[n] - a1 * y[n] + d2;
+*    d2 = b2 * x[n] - a2 * y[n];
+* 
+* In this case the feedback coefficients a1 and a2 must be negated when used with the CMSIS DSP Library. +* +* \par +* Higher order filters are realized as a cascade of second order sections. +* numStages refers to the number of second order stages used. +* For example, an 8th order filter would be realized with numStages=4 second order stages. +* A 9th order filter would be realized with numStages=5 second order stages with the +* coefficients for one of the stages configured as a first order filter (b2=0 and a2=0). +* +* \par +* pState points to the state variable array. +* Each Biquad stage has 2 state variables d1 and d2. +* The state variables are arranged in the pState array as: +*
+*     {d11, d12, d21, d22, ...}
+* 
+* where d1x refers to the state variables for the first Biquad and +* d2x refers to the state variables for the second Biquad. +* The state array has a total length of 2*numStages values. +* The state variables are updated after each block of data is processed; the coefficients are untouched. +* +* \par +* The CMSIS library contains Biquad filters in both Direct Form I and transposed Direct Form II. +* The advantage of the Direct Form I structure is that it is numerically more robust for fixed-point data types. +* That is why the Direct Form I structure supports Q15 and Q31 data types. +* The transposed Direct Form II structure, on the other hand, requires a wide dynamic range for the state variables d1 and d2. +* Because of this, the CMSIS library only has a floating-point version of the Direct Form II Biquad. +* The advantage of the Direct Form II Biquad is that it requires half the number of state variables, 2 rather than 4, per Biquad stage. +* +* \par Instance Structure +* The coefficients and state variables for a filter are stored together in an instance data structure. +* A separate instance structure must be defined for each filter. +* Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. +* +* \par Init Functions +* There is also an associated initialization function. +* The initialization function performs following operations: +* - Sets the values of the internal structure fields. +* - Zeros out the values in the state buffer. +* To do this manually without calling the init function, assign the follow subfields of the instance structure: +* numStages, pCoeffs, pState. Also set all of the values in pState to zero. +* +* \par +* Use of the initialization function is optional. +* However, if the initialization function is used, then the instance structure cannot be placed into a const data section. +* To place an instance structure into a const data section, the instance structure must be manually initialized. +* Set the values in the state buffer to zeros before static initialization. +* For example, to statically initialize the instance structure use +*
+*     arm_biquad_cascade_df2T_instance_f32 S1 = {numStages, pState, pCoeffs};
+* 
+* where numStages is the number of Biquad stages in the filter; pState is the address of the state buffer. +* pCoeffs is the address of the coefficient buffer; +* +*/ + +/** +* @addtogroup BiquadCascadeDF2T +* @{ +*/ + +/** +* @brief Processing function for the floating-point transposed direct form II Biquad cascade filter. +* @param[in] *S points to an instance of the filter data structure. +* @param[in] *pSrc points to the block of input data. +* @param[out] *pDst points to the block of output data +* @param[in] blockSize number of samples to process. +* @return none. +*/ + + +LOW_OPTIMIZATION_ENTER +void arm_biquad_cascade_stereo_df2T_f32( +const arm_biquad_cascade_stereo_df2T_instance_f32 * S, +float32_t * pSrc, +float32_t * pDst, +uint32_t blockSize) +{ + + float32_t *pIn = pSrc; /* source pointer */ + float32_t *pOut = pDst; /* destination pointer */ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* coefficient pointer */ + float32_t acc1a, acc1b; /* accumulator */ + float32_t b0, b1, b2, a1, a2; /* Filter coefficients */ + float32_t Xn1a, Xn1b; /* temporary input */ + float32_t d1a, d2a, d1b, d2b; /* state variables */ + uint32_t sample, stage = S->numStages; /* loop counters */ + +#if defined(ARM_MATH_CM7) + + float32_t Xn2a, Xn3a, Xn4a, Xn5a, Xn6a, Xn7a, Xn8a; /* Input State variables */ + float32_t Xn2b, Xn3b, Xn4b, Xn5b, Xn6b, Xn7b, Xn8b; /* Input State variables */ + float32_t acc2a, acc3a, acc4a, acc5a, acc6a, acc7a, acc8a; /* Simulates the accumulator */ + float32_t acc2b, acc3b, acc4b, acc5b, acc6b, acc7b, acc8b; /* Simulates the accumulator */ + + do + { + /* Reading the coefficients */ + b0 = pCoeffs[0]; + b1 = pCoeffs[1]; + b2 = pCoeffs[2]; + a1 = pCoeffs[3]; + /* Apply loop unrolling and compute 8 output values simultaneously. */ + sample = blockSize >> 3U; + a2 = pCoeffs[4]; + + /*Reading the state values */ + d1a = pState[0]; + d2a = pState[1]; + d1b = pState[2]; + d2b = pState[3]; + + pCoeffs += 5U; + + /* First part of the processing with loop unrolling. Compute 8 outputs at a time. + ** a second loop below computes the remaining 1 to 7 samples. */ + while (sample > 0U) { + + /* y[n] = b0 * x[n] + d1 */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + /* d2 = b2 * x[n] + a2 * y[n] */ + + /* Read the first 2 inputs. 2 cycles */ + Xn1a = pIn[0 ]; + Xn1b = pIn[1 ]; + + /* Sample 1. 5 cycles */ + Xn2a = pIn[2 ]; + acc1a = b0 * Xn1a + d1a; + + Xn2b = pIn[3 ]; + d1a = b1 * Xn1a + d2a; + + Xn3a = pIn[4 ]; + d2a = b2 * Xn1a; + + Xn3b = pIn[5 ]; + d1a += a1 * acc1a; + + Xn4a = pIn[6 ]; + d2a += a2 * acc1a; + + /* Sample 2. 5 cycles */ + Xn4b = pIn[7 ]; + acc1b = b0 * Xn1b + d1b; + + Xn5a = pIn[8 ]; + d1b = b1 * Xn1b + d2b; + + Xn5b = pIn[9 ]; + d2b = b2 * Xn1b; + + Xn6a = pIn[10]; + d1b += a1 * acc1b; + + Xn6b = pIn[11]; + d2b += a2 * acc1b; + + /* Sample 3. 5 cycles */ + Xn7a = pIn[12]; + acc2a = b0 * Xn2a + d1a; + + Xn7b = pIn[13]; + d1a = b1 * Xn2a + d2a; + + Xn8a = pIn[14]; + d2a = b2 * Xn2a; + + Xn8b = pIn[15]; + d1a += a1 * acc2a; + + pIn += 16; + d2a += a2 * acc2a; + + /* Sample 4. 5 cycles */ + acc2b = b0 * Xn2b + d1b; + d1b = b1 * Xn2b + d2b; + d2b = b2 * Xn2b; + d1b += a1 * acc2b; + d2b += a2 * acc2b; + + /* Sample 5. 5 cycles */ + acc3a = b0 * Xn3a + d1a; + d1a = b1 * Xn3a + d2a; + d2a = b2 * Xn3a; + d1a += a1 * acc3a; + d2a += a2 * acc3a; + + /* Sample 6. 5 cycles */ + acc3b = b0 * Xn3b + d1b; + d1b = b1 * Xn3b + d2b; + d2b = b2 * Xn3b; + d1b += a1 * acc3b; + d2b += a2 * acc3b; + + /* Sample 7. 5 cycles */ + acc4a = b0 * Xn4a + d1a; + d1a = b1 * Xn4a + d2a; + d2a = b2 * Xn4a; + d1a += a1 * acc4a; + d2a += a2 * acc4a; + + /* Sample 8. 5 cycles */ + acc4b = b0 * Xn4b + d1b; + d1b = b1 * Xn4b + d2b; + d2b = b2 * Xn4b; + d1b += a1 * acc4b; + d2b += a2 * acc4b; + + /* Sample 9. 5 cycles */ + acc5a = b0 * Xn5a + d1a; + d1a = b1 * Xn5a + d2a; + d2a = b2 * Xn5a; + d1a += a1 * acc5a; + d2a += a2 * acc5a; + + /* Sample 10. 5 cycles */ + acc5b = b0 * Xn5b + d1b; + d1b = b1 * Xn5b + d2b; + d2b = b2 * Xn5b; + d1b += a1 * acc5b; + d2b += a2 * acc5b; + + /* Sample 11. 5 cycles */ + acc6a = b0 * Xn6a + d1a; + d1a = b1 * Xn6a + d2a; + d2a = b2 * Xn6a; + d1a += a1 * acc6a; + d2a += a2 * acc6a; + + /* Sample 12. 5 cycles */ + acc6b = b0 * Xn6b + d1b; + d1b = b1 * Xn6b + d2b; + d2b = b2 * Xn6b; + d1b += a1 * acc6b; + d2b += a2 * acc6b; + + /* Sample 13. 5 cycles */ + acc7a = b0 * Xn7a + d1a; + d1a = b1 * Xn7a + d2a; + + pOut[0 ] = acc1a ; + d2a = b2 * Xn7a; + + pOut[1 ] = acc1b ; + d1a += a1 * acc7a; + + pOut[2 ] = acc2a ; + d2a += a2 * acc7a; + + /* Sample 14. 5 cycles */ + pOut[3 ] = acc2b ; + acc7b = b0 * Xn7b + d1b; + + pOut[4 ] = acc3a ; + d1b = b1 * Xn7b + d2b; + + pOut[5 ] = acc3b ; + d2b = b2 * Xn7b; + + pOut[6 ] = acc4a ; + d1b += a1 * acc7b; + + pOut[7 ] = acc4b ; + d2b += a2 * acc7b; + + /* Sample 15. 5 cycles */ + pOut[8 ] = acc5a ; + acc8a = b0 * Xn8a + d1a; + + pOut[9 ] = acc5b; + d1a = b1 * Xn8a + d2a; + + pOut[10] = acc6a; + d2a = b2 * Xn8a; + + pOut[11] = acc6b; + d1a += a1 * acc8a; + + pOut[12] = acc7a; + d2a += a2 * acc8a; + + /* Sample 16. 5 cycles */ + pOut[13] = acc7b; + acc8b = b0 * Xn8b + d1b; + + pOut[14] = acc8a; + d1b = b1 * Xn8b + d2b; + + pOut[15] = acc8b; + d2b = b2 * Xn8b; + + sample--; + d1b += a1 * acc8b; + + pOut += 16; + d2b += a2 * acc8b; + } + + sample = blockSize & 0x7U; + while (sample > 0U) { + /* Read the input */ + Xn1a = *pIn++; //Channel a + Xn1b = *pIn++; //Channel b + + /* y[n] = b0 * x[n] + d1 */ + acc1a = (b0 * Xn1a) + d1a; + acc1b = (b0 * Xn1b) + d1b; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc1a; + *pOut++ = acc1b; + + /* Every time after the output is computed state should be updated. */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + d1a = ((b1 * Xn1a) + (a1 * acc1a)) + d2a; + d1b = ((b1 * Xn1b) + (a1 * acc1b)) + d2b; + + /* d2 = b2 * x[n] + a2 * y[n] */ + d2a = (b2 * Xn1a) + (a2 * acc1a); + d2b = (b2 * Xn1b) + (a2 * acc1b); + + sample--; + } + + /* Store the updated state variables back into the state array */ + pState[0] = d1a; + pState[1] = d2a; + + pState[2] = d1b; + pState[3] = d2b; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + /* decrement the loop counter */ + stage--; + + pState += 4U; + /*Reset the output working pointer */ + pOut = pDst; + + } while (stage > 0U); + +#elif defined(ARM_MATH_CM0_FAMILY) + + /* Run the below code for Cortex-M0 */ + + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /*Reading the state values */ + d1a = pState[0]; + d2a = pState[1]; + d1b = pState[2]; + d2b = pState[3]; + + + sample = blockSize; + + while (sample > 0U) + { + /* Read the input */ + Xn1a = *pIn++; //Channel a + Xn1b = *pIn++; //Channel b + + /* y[n] = b0 * x[n] + d1 */ + acc1a = (b0 * Xn1a) + d1a; + acc1b = (b0 * Xn1b) + d1b; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc1a; + *pOut++ = acc1b; + + /* Every time after the output is computed state should be updated. */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + d1a = ((b1 * Xn1a) + (a1 * acc1a)) + d2a; + d1b = ((b1 * Xn1b) + (a1 * acc1b)) + d2b; + + /* d2 = b2 * x[n] + a2 * y[n] */ + d2a = (b2 * Xn1a) + (a2 * acc1a); + d2b = (b2 * Xn1b) + (a2 * acc1b); + + /* decrement the loop counter */ + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1a; + *pState++ = d2a; + *pState++ = d1b; + *pState++ = d2b; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#else + + float32_t Xn2a, Xn3a, Xn4a; /* Input State variables */ + float32_t Xn2b, Xn3b, Xn4b; /* Input State variables */ + float32_t acc2a, acc3a, acc4a; /* accumulator */ + float32_t acc2b, acc3b, acc4b; /* accumulator */ + float32_t p0a, p1a, p2a, p3a, p4a, A1a; + float32_t p0b, p1b, p2b, p3b, p4b, A1b; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + do + { + /* Reading the coefficients */ + b0 = *pCoeffs++; + b1 = *pCoeffs++; + b2 = *pCoeffs++; + a1 = *pCoeffs++; + a2 = *pCoeffs++; + + /*Reading the state values */ + d1a = pState[0]; + d2a = pState[1]; + d1b = pState[2]; + d2b = pState[3]; + + /* Apply loop unrolling and compute 4 output values simultaneously. */ + sample = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (sample > 0U) { + + /* y[n] = b0 * x[n] + d1 */ + /* d1 = b1 * x[n] + a1 * y[n] + d2 */ + /* d2 = b2 * x[n] + a2 * y[n] */ + + /* Read the four inputs */ + Xn1a = pIn[0]; + Xn1b = pIn[1]; + Xn2a = pIn[2]; + Xn2b = pIn[3]; + Xn3a = pIn[4]; + Xn3b = pIn[5]; + Xn4a = pIn[6]; + Xn4b = pIn[7]; + pIn += 8; + + p0a = b0 * Xn1a; + p0b = b0 * Xn1b; + p1a = b1 * Xn1a; + p1b = b1 * Xn1b; + acc1a = p0a + d1a; + acc1b = p0b + d1b; + p0a = b0 * Xn2a; + p0b = b0 * Xn2b; + p3a = a1 * acc1a; + p3b = a1 * acc1b; + p2a = b2 * Xn1a; + p2b = b2 * Xn1b; + A1a = p1a + p3a; + A1b = p1b + p3b; + p4a = a2 * acc1a; + p4b = a2 * acc1b; + d1a = A1a + d2a; + d1b = A1b + d2b; + d2a = p2a + p4a; + d2b = p2b + p4b; + + p1a = b1 * Xn2a; + p1b = b1 * Xn2b; + acc2a = p0a + d1a; + acc2b = p0b + d1b; + p0a = b0 * Xn3a; + p0b = b0 * Xn3b; + p3a = a1 * acc2a; + p3b = a1 * acc2b; + p2a = b2 * Xn2a; + p2b = b2 * Xn2b; + A1a = p1a + p3a; + A1b = p1b + p3b; + p4a = a2 * acc2a; + p4b = a2 * acc2b; + d1a = A1a + d2a; + d1b = A1b + d2b; + d2a = p2a + p4a; + d2b = p2b + p4b; + + p1a = b1 * Xn3a; + p1b = b1 * Xn3b; + acc3a = p0a + d1a; + acc3b = p0b + d1b; + p0a = b0 * Xn4a; + p0b = b0 * Xn4b; + p3a = a1 * acc3a; + p3b = a1 * acc3b; + p2a = b2 * Xn3a; + p2b = b2 * Xn3b; + A1a = p1a + p3a; + A1b = p1b + p3b; + p4a = a2 * acc3a; + p4b = a2 * acc3b; + d1a = A1a + d2a; + d1b = A1b + d2b; + d2a = p2a + p4a; + d2b = p2b + p4b; + + acc4a = p0a + d1a; + acc4b = p0b + d1b; + p1a = b1 * Xn4a; + p1b = b1 * Xn4b; + p3a = a1 * acc4a; + p3b = a1 * acc4b; + p2a = b2 * Xn4a; + p2b = b2 * Xn4b; + A1a = p1a + p3a; + A1b = p1b + p3b; + p4a = a2 * acc4a; + p4b = a2 * acc4b; + d1a = A1a + d2a; + d1b = A1b + d2b; + d2a = p2a + p4a; + d2b = p2b + p4b; + + pOut[0] = acc1a; + pOut[1] = acc1b; + pOut[2] = acc2a; + pOut[3] = acc2b; + pOut[4] = acc3a; + pOut[5] = acc3b; + pOut[6] = acc4a; + pOut[7] = acc4b; + pOut += 8; + + sample--; + } + + sample = blockSize & 0x3U; + while (sample > 0U) { + Xn1a = *pIn++; + Xn1b = *pIn++; + + p0a = b0 * Xn1a; + p0b = b0 * Xn1b; + p1a = b1 * Xn1a; + p1b = b1 * Xn1b; + acc1a = p0a + d1a; + acc1b = p0b + d1b; + p3a = a1 * acc1a; + p3b = a1 * acc1b; + p2a = b2 * Xn1a; + p2b = b2 * Xn1b; + A1a = p1a + p3a; + A1b = p1b + p3b; + p4a = a2 * acc1a; + p4b = a2 * acc1b; + d1a = A1a + d2a; + d1b = A1b + d2b; + d2a = p2a + p4a; + d2b = p2b + p4b; + + *pOut++ = acc1a; + *pOut++ = acc1b; + + sample--; + } + + /* Store the updated state variables back into the state array */ + *pState++ = d1a; + *pState++ = d2a; + *pState++ = d1b; + *pState++ = d2b; + + /* The current stage input is given as the output to the next stage */ + pIn = pDst; + + /*Reset the output working pointer */ + pOut = pDst; + + /* decrement the loop counter */ + stage--; + + } while (stage > 0U); + +#endif + +} +LOW_OPTIMIZATION_EXIT + +/** + * @} end of BiquadCascadeDF2T group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_init_f32.c new file mode 100644 index 0000000..b847c6e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_biquad_cascade_stereo_df2T_init_f32.c @@ -0,0 +1,89 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_biquad_cascade_stereo_df2T_init_f32.c + * Description: Initialization function for floating-point transposed direct form II Biquad cascade filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup BiquadCascadeDF2T + * @{ + */ + +/** + * @brief Initialization function for the floating-point transposed direct form II Biquad cascade filter. + * @param[in,out] *S points to an instance of the filter data structure. + * @param[in] numStages number of 2nd order stages in the filter. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @return none + * + * Coefficient and State Ordering: + * \par + * The coefficients are stored in the array pCoeffs in the following order: + *
+ *     {b10, b11, b12, a11, a12, b20, b21, b22, a21, a22, ...}
+ * 
+ * + * \par + * where b1x and a1x are the coefficients for the first stage, + * b2x and a2x are the coefficients for the second stage, + * and so on. The pCoeffs array contains a total of 5*numStages values. + * + * \par + * The pState is a pointer to state array. + * Each Biquad stage has 2 state variables d1, and d2 for each channel. + * The 2 state variables for stage 1 are first, then the 2 state variables for stage 2, and so on. + * The state array has a total length of 2*numStages values. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + */ + +void arm_biquad_cascade_stereo_df2T_init_f32( + arm_biquad_cascade_stereo_df2T_instance_f32 * S, + uint8_t numStages, + float32_t * pCoeffs, + float32_t * pState) +{ + /* Assign filter stages */ + S->numStages = numStages; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always 4 * numStages */ + memset(pState, 0, (4U * (uint32_t) numStages) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; +} + +/** + * @} end of BiquadCascadeDF2T group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_f32.c new file mode 100644 index 0000000..906f7ab --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_f32.c @@ -0,0 +1,635 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_f32.c + * Description: Convolution of floating-point sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup Conv Convolution + * + * Convolution is a mathematical operation that operates on two finite length vectors to generate a finite length output vector. + * Convolution is similar to correlation and is frequently used in filtering and data analysis. + * The CMSIS DSP library contains functions for convolving Q7, Q15, Q31, and floating-point data types. + * The library also provides fast versions of the Q15 and Q31 functions on Cortex-M4 and Cortex-M3. + * + * \par Algorithm + * Let a[n] and b[n] be sequences of length srcALen and srcBLen samples respectively. + * Then the convolution + * + *
+ *                   c[n] = a[n] * b[n]
+ * 
+ * + * \par + * is defined as + * \image html ConvolutionEquation.gif + * \par + * Note that c[n] is of length srcALen + srcBLen - 1 and is defined over the interval n=0, 1, 2, ..., srcALen + srcBLen - 2. + * pSrcA points to the first input vector of length srcALen and + * pSrcB points to the second input vector of length srcBLen. + * The output result is written to pDst and the calling function must allocate srcALen+srcBLen-1 words for the result. + * + * \par + * Conceptually, when two signals a[n] and b[n] are convolved, + * the signal b[n] slides over a[n]. + * For each offset \c n, the overlapping portions of a[n] and b[n] are multiplied and summed together. + * + * \par + * Note that convolution is a commutative operation: + * + *
+ *                   a[n] * b[n] = b[n] * a[n].
+ * 
+ * + * \par + * This means that switching the A and B arguments to the convolution functions has no effect. + * + * Fixed-Point Behavior + * + * \par + * Convolution requires summing up a large number of intermediate products. + * As such, the Q7, Q15, and Q31 functions run a risk of overflow and saturation. + * Refer to the function specific documentation below for further details of the particular algorithm used. + * + * + * Fast Versions + * + * \par + * Fast versions are supported for Q31 and Q15. Cycles for Fast versions are less compared to Q31 and Q15 of conv and the design requires + * the input signals should be scaled down to avoid intermediate overflows. + * + * + * Opt Versions + * + * \par + * Opt versions are supported for Q15 and Q7. Design uses internal scratch buffer for getting good optimisation. + * These versions are optimised in cycles and consumes more memory(Scratch memory) compared to Q15 and Q7 versions + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of floating-point sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @return none. + */ + +void arm_conv_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t *pIn1; /* inputA pointer */ + float32_t *pIn2; /* inputB pointer */ + float32_t *pOut = pDst; /* output pointer */ + float32_t *px; /* Intermediate inputA pointer */ + float32_t *py; /* Intermediate inputB pointer */ + float32_t *pSrc1, *pSrc2; /* Intermediate pointers */ + float32_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + float32_t x0, x1, x2, x3, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t j, k, count, blkCnt, blockSize1, blockSize2, blockSize3; /* loop counters */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* The algorithm is implemented in three stages. + The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 1] */ + sum += *px++ * *py--; + + /* x[1] * y[srcBLen - 2] */ + sum += *px++ * *py--; + + /* x[2] * y[srcBLen - 3] */ + sum += *px++ * *py--; + + /* x[3] * y[srcBLen - 4] */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0.0f; + acc1 = 0.0f; + acc2 = 0.0f; + acc3 = 0.0f; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py--); + + /* Read x[3] sample */ + x3 = *(px); + + /* Perform the multiply-accumulate */ + /* acc0 += x[0] * y[srcBLen - 1] */ + acc0 += x0 * c0; + + /* acc1 += x[1] * y[srcBLen - 1] */ + acc1 += x1 * c0; + + /* acc2 += x[2] * y[srcBLen - 1] */ + acc2 += x2 * c0; + + /* acc3 += x[3] * y[srcBLen - 1] */ + acc3 += x3 * c0; + + /* Read y[srcBLen - 2] sample */ + c0 = *(py--); + + /* Read x[4] sample */ + x0 = *(px + 1U); + + /* Perform the multiply-accumulate */ + /* acc0 += x[1] * y[srcBLen - 2] */ + acc0 += x1 * c0; + /* acc1 += x[2] * y[srcBLen - 2] */ + acc1 += x2 * c0; + /* acc2 += x[3] * y[srcBLen - 2] */ + acc2 += x3 * c0; + /* acc3 += x[4] * y[srcBLen - 2] */ + acc3 += x0 * c0; + + /* Read y[srcBLen - 3] sample */ + c0 = *(py--); + + /* Read x[5] sample */ + x1 = *(px + 2U); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[srcBLen - 3] */ + acc0 += x2 * c0; + /* acc1 += x[3] * y[srcBLen - 2] */ + acc1 += x3 * c0; + /* acc2 += x[4] * y[srcBLen - 2] */ + acc2 += x0 * c0; + /* acc3 += x[5] * y[srcBLen - 2] */ + acc3 += x1 * c0; + + /* Read y[srcBLen - 4] sample */ + c0 = *(py--); + + /* Read x[6] sample */ + x2 = *(px + 3U); + px += 4U; + + /* Perform the multiply-accumulates */ + /* acc0 += x[3] * y[srcBLen - 4] */ + acc0 += x3 * c0; + /* acc1 += x[4] * y[srcBLen - 4] */ + acc1 += x0 * c0; + /* acc2 += x[5] * y[srcBLen - 4] */ + acc2 += x1 * c0; + /* acc3 += x[6] * y[srcBLen - 4] */ + acc3 += x2 * c0; + + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 += x0 * c0; + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 += x1 * c0; + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 += x2 * c0; + /* acc3 += x[7] * y[srcBLen - 5] */ + acc3 += x3 * c0; + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc0; + *pOut++ = acc1; + *pOut++ = acc2; + *pOut++ = acc3; + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + + /* Decrement the loop counter */ + blkCnt--; + } + + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += *px++ * *py--; + sum += *px++ * *py--; + sum += *px++ * *py--; + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 1] * y[srcBLen - 1] */ + sum += *px++ * *py--; + + /* sum += x[srcALen - srcBLen + 2] * y[srcBLen - 2] */ + sum += *px++ * *py--; + + /* sum += x[srcALen - srcBLen + 3] * y[srcBLen - 3] */ + sum += *px++ * *py--; + + /* sum += x[srcALen - srcBLen + 4] * y[srcBLen - 4] */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = blockSize3 % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + float32_t *pIn1 = pSrcA; /* inputA pointer */ + float32_t *pIn2 = pSrcB; /* inputB pointer */ + float32_t sum; /* Accumulator */ + uint32_t i, j; /* loop counters */ + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i < ((srcALen + srcBLen) - 1U); i++) + { + /* Initialize sum with zero to carry out MAC operations */ + sum = 0.0f; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += pIn1[j] * pIn2[i - j]; + } + } + /* Store the output in the destination buffer */ + pDst[i] = sum; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_opt_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_opt_q15.c new file mode 100644 index 0000000..26c37f0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_opt_q15.c @@ -0,0 +1,531 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_fast_opt_q15.c + * Description: Fast Q15 Convolution + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @param[in] *pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] *pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + * @return none. + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch1 and scratch2 buffers should be aligned by 32-bit + * + * Scaling and Overflow Behavior: + * + * \par + * This fast version uses a 32-bit accumulator with 2.30 format. + * The accumulator maintains full precision of the intermediate multiplication results + * but provides only a single guard bit. There is no saturation on intermediate additions. + * Thus, if the accumulator overflows it wraps around and distorts the result. + * The input signals should be scaled down to avoid intermediate overflows. + * Scale down the inputs by log2(min(srcALen, srcBLen)) (log2 is read as log to the base 2) times to avoid overflows, + * as maximum of min(srcALen, srcBLen) number of additions are carried internally. + * The 2.30 accumulator is right shifted by 15 bits and then saturated to 1.15 format to yield the final result. + * + * \par + * See arm_conv_q15() for a slower implementation of this function which uses 64-bit accumulation to avoid wrap around distortion. + */ + +void arm_conv_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2) +{ + q31_t acc0, acc1, acc2, acc3; /* Accumulators */ + q31_t x1, x2, x3; /* Temporary variables to hold state and coefficient values */ + q31_t y1, y2; /* State variables */ + q15_t *pOut = pDst; /* output pointer */ + q15_t *pScr1 = pScratch1; /* Temporary pointer for scratch1 */ + q15_t *pScr2 = pScratch2; /* Temporary pointer for scratch1 */ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + uint32_t j, k, blkCnt; /* loop counter */ + uint32_t tapCnt; /* loop count */ +#ifdef UNALIGNED_SUPPORT_DISABLE + + q15_t a, b; + +#endif /* #ifdef UNALIGNED_SUPPORT_DISABLE */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Pointer to take end of scratch2 buffer */ + pScr2 = pScratch2 + srcBLen - 1; + + /* points to smaller length sequence */ + px = pIn2; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + + /* Copy smaller length input sequence in reverse order into second scratch buffer */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Assuming scratch1 buffer is aligned by 32-bit */ + /* Fill (srcBLen - 1U) zeros in scratch1 buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy bigger length sequence(srcALen) samples in scratch1 buffer */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Copy (srcALen) samples in scratch buffer */ + arm_copy_q15(pIn1, pScr1, srcALen); + + /* Update pointers */ + pScr1 += srcALen; + +#else + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update pointer */ + pScr1 += (srcBLen - 1U); + +#else + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = (srcBLen - 1U) % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + + /* Initialization of pIn2 pointer */ + pIn2 = py; + + /* First part of the processing with loop unrolling process 4 data points at a time. + ** a second loop below process for the remaining 1 to 3 samples. */ + + /* Actual convolution process starts here */ + blkCnt = (srcALen + srcBLen - 1U) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read next two samples from scratch1 buffer */ + x2 = *__SIMD32(pScr1)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pIn2); + y2 = _SIMD32_OFFSET(pIn2 + 2U); + + /* multiply and accumlate */ + acc0 = __SMLAD(x1, y1, acc0); + acc2 = __SMLAD(x2, y1, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + /* multiply and accumlate */ + acc1 = __SMLADX(x3, y1, acc1); + + /* Read next two samples from scratch1 buffer */ + x1 = _SIMD32_OFFSET(pScr1); + + /* multiply and accumlate */ + acc0 = __SMLAD(x2, y2, acc0); + acc2 = __SMLAD(x1, y2, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + acc1 = __SMLADX(x3, y2, acc1); + + x2 = _SIMD32_OFFSET(pScr1 + 2U); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y2, acc3); + +#else + + /* Read four samples from smaller buffer */ + a = *pIn2; + b = *(pIn2 + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + y1 = __PKHBT(a, b, 16); +#else + y1 = __PKHBT(b, a, 16); +#endif + + a = *(pIn2 + 2); + b = *(pIn2 + 3); +#ifndef ARM_MATH_BIG_ENDIAN + y2 = __PKHBT(a, b, 16); +#else + y2 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLAD(x1, y1, acc0); + + acc2 = __SMLAD(x2, y1, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc1 = __SMLADX(x3, y1, acc1); + + a = *pScr1; + b = *(pScr1 + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(a, b, 16); +#else + x1 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLAD(x2, y2, acc0); + + acc2 = __SMLAD(x1, y2, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + acc1 = __SMLADX(x3, y2, acc1); + + a = *(pScr1 + 2); + b = *(pScr1 + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + x2 = __PKHBT(a, b, 16); +#else + x2 = __PKHBT(b, a, 16); +#endif + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y2, acc3); + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* update scratch pointers */ + pIn2 += 4U; + pScr1 += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2); + acc1 += (*pScr1++ * *pIn2); + acc2 += (*pScr1++ * *pIn2); + acc3 += (*pScr1++ * *pIn2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + + +#else + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + + + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = (srcALen + srcBLen - 1U) & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + acc0 += (*pScr1++ * *pIn2++); + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* The result is in 2.30 format. Convert to 1.15 with saturation. + ** Then store the output in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 1U; + + } + +} + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q15.c new file mode 100644 index 0000000..16b0424 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q15.c @@ -0,0 +1,1398 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_fast_q15.c + * Description: Fast Q15 Convolution + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @return none. + * + * Scaling and Overflow Behavior: + * + * \par + * This fast version uses a 32-bit accumulator with 2.30 format. + * The accumulator maintains full precision of the intermediate multiplication results + * but provides only a single guard bit. There is no saturation on intermediate additions. + * Thus, if the accumulator overflows it wraps around and distorts the result. + * The input signals should be scaled down to avoid intermediate overflows. + * Scale down the inputs by log2(min(srcALen, srcBLen)) (log2 is read as log to the base 2) times to avoid overflows, + * as maximum of min(srcALen, srcBLen) number of additions are carried internally. + * The 2.30 accumulator is right shifted by 15 bits and then saturated to 1.15 format to yield the final result. + * + * \par + * See arm_conv_q15() for a slower implementation of this function which uses 64-bit accumulation to avoid wrap around distortion. + */ + +void arm_conv_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ +#ifndef UNALIGNED_SUPPORT_DISABLE + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t blockSize1, blockSize2, blockSize3, j, k, count, blkCnt; /* loop counter */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* The algorithm is implemented in three stages. + The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations less than 4 */ + /* Second part of this stage computes the MAC operations greater than or equal to 4 */ + + /* The first part of the stage starts here */ + while ((count < 4U) && (blockSize1 > 0U)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over number of MAC operations between + * inputA samples and inputB samples */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* The second part of the stage starts here */ + /* The internal loop, over count, is unrolled by 4 */ + /* To, read the last two inputB samples using SIMD: + * y[srcBLen] and y[srcBLen-1] coefficients, py is decremented by 1 */ + py = py - 1; + + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0], x[1] are multiplied with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[2], x[3] are multiplied with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + (count - 1U); + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is the index by which the pointer pIn1 to be incremented */ + count = 0U; + + + /* -------------------- + * Stage2 process + * -------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + py = py - 1U; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + + /* read x[0], x[1] samples */ + x0 = *__SIMD32(px); + /* read x[1], x[2] samples */ + x1 = _SIMD32_OFFSET(px+1); + px+= 2U; + + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the last two inputB samples using SIMD: + * y[srcBLen - 1] and y[srcBLen - 2] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLADX(x0, c0, acc0); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLADX(x1, c0, acc1); + + /* Read x[2], x[3] */ + x2 = *__SIMD32(px); + + /* Read x[3], x[4] */ + x3 = _SIMD32_OFFSET(px+1); + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLADX(x2, c0, acc2); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLADX(x3, c0, acc3); + + /* Read y[srcBLen - 3] and y[srcBLen - 4] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLADX(x2, c0, acc0); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLADX(x3, c0, acc1); + + /* Read x[4], x[5] */ + x0 = _SIMD32_OFFSET(px+2); + + /* Read x[5], x[6] */ + x1 = _SIMD32_OFFSET(px+3); + px += 4U; + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLADX(x0, c0, acc2); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLADX(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[srcBLen - 5] */ + c0 = *(py+1); + +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7] */ + x3 = *__SIMD32(px); + px++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLADX(x1, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + + /* Read y[srcBLen - 7] */ + c0 = *(py-1); +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[10] */ + x3 = _SIMD32_OFFSET(px+2); + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x1, c0, acc0); + acc1 = __SMLAD(x2, c0, acc1); + acc2 = __SMLADX(x2, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + /* Store the results in the accumulators in the destination buffer. */ +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = __PKHBT((acc0 >> 15), (acc1 >> 15), 16); + *__SIMD32(pOut)++ = __PKHBT((acc2 >> 15), (acc3 >> 15), 16); + +#else + + *__SIMD32(pOut)++ = __PKHBT((acc1 >> 15), (acc0 >> 15), 16); + *__SIMD32(pOut)++ = __PKHBT((acc3 >> 15), (acc2 >> 15), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + pIn2 = pSrc2 - 1U; + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations greater than 4 */ + /* Second part of this stage computes the MAC operations less than or equal to 4 */ + + /* The first part of the stage starts here */ + j = blockSize3 >> 2U; + + while ((j > 0U) && (blockSize3 > 0U)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[srcALen - srcBLen + 1], x[srcALen - srcBLen + 2] are multiplied + * with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[srcALen - srcBLen + 3], x[srcALen - srcBLen + 4] are multiplied + * with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = blockSize3 % 0x4U; + + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 5] * y[srcBLen - 5] */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the loop counter */ + blockSize3--; + + j--; + } + + /* The second part of the stage starts here */ + /* SIMD is not used for the next MAC operations, + * so pointer py is updated to read only one sample at a time */ + py = py + 1U; + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t blockSize1, blockSize2, blockSize3, j, k, count, blkCnt; /* loop counter */ + q15_t a, b; + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* The algorithm is implemented in three stages. + The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations less than 4 */ + /* Second part of this stage computes the MAC operations greater than or equal to 4 */ + + /* The first part of the stage starts here */ + while ((count < 4U) && (blockSize1 > 0U)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over number of MAC operations between + * inputA samples and inputB samples */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* The second part of the stage starts here */ + /* The internal loop, over count, is unrolled by 4 */ + /* To, read the last two inputB samples using SIMD: + * y[srcBLen] and y[srcBLen-1] coefficients, py is decremented by 1 */ + py = py - 1; + + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + py++; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + (count - 1U); + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is the index by which the pointer pIn1 to be incremented */ + count = 0U; + + + /* -------------------- + * Stage2 process + * -------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + py = py - 1U; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1] samples */ + a = *px++; + b = *px++; + +#ifndef ARM_MATH_BIG_ENDIAN + + x0 = __PKHBT(a, b, 16); + a = *px; + x1 = __PKHBT(b, a, 16); + +#else + + x0 = __PKHBT(b, a, 16); + a = *px; + x1 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the last two inputB samples using SIMD: + * y[srcBLen - 1] and y[srcBLen - 2] */ + a = *py; + b = *(py+1); + py -= 2; + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLADX(x0, c0, acc0); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLADX(x1, c0, acc1); + + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x2 = __PKHBT(a, b, 16); + a = *(px + 2); + x3 = __PKHBT(b, a, 16); + +#else + + x2 = __PKHBT(b, a, 16); + a = *(px + 2); + x3 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLADX(x2, c0, acc2); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLADX(x3, c0, acc3); + + /* Read y[srcBLen - 3] and y[srcBLen - 4] */ + a = *py; + b = *(py+1); + py -= 2; + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLADX(x2, c0, acc0); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLADX(x3, c0, acc1); + + /* Read x[4], x[5], x[6] */ + a = *(px + 2); + b = *(px + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + + x0 = __PKHBT(a, b, 16); + a = *(px + 4); + x1 = __PKHBT(b, a, 16); + +#else + + x0 = __PKHBT(b, a, 16); + a = *(px + 4); + x1 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 4U; + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLADX(x0, c0, acc2); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLADX(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[srcBLen - 5] */ + c0 = *(py+1); + +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7] */ + a = *px; + b = *(px+1); + px++; + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + +#else + + x3 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLADX(x1, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + a = *py; + b = *(py+1); + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7], x[8], x[9] */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + a = *(px + 2); + x2 = __PKHBT(b, a, 16); + +#else + + x3 = __PKHBT(b, a, 16); + a = *(px + 2); + x2 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + a = *py; + b = *(py+1); + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7], x[8], x[9] */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + a = *(px + 2); + x2 = __PKHBT(b, a, 16); + +#else + + x3 = __PKHBT(b, a, 16); + a = *(px + 2); + x2 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + + /* Read y[srcBLen - 7] */ + c0 = *(py-1); +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[10] */ + a = *(px+2); + b = *(px+3); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + +#else + + x3 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x1, c0, acc0); + acc1 = __SMLAD(x2, c0, acc1); + acc2 = __SMLADX(x2, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + /* Store the results in the accumulators in the destination buffer. */ + *pOut++ = (q15_t)(acc0 >> 15); + *pOut++ = (q15_t)(acc1 >> 15); + *pOut++ = (q15_t)(acc2 >> 15); + *pOut++ = (q15_t)(acc3 >> 15); + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + pIn2 = pSrc2 - 1U; + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations greater than 4 */ + /* Second part of this stage computes the MAC operations less than or equal to 4 */ + + /* The first part of the stage starts here */ + j = blockSize3 >> 2U; + + while ((j > 0U) && (blockSize3 > 0U)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + py++; + + while (k > 0U) + { + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + /* Decrement the loop counter */ + k--; + } + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = blockSize3 % 0x4U; + + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 5] * y[srcBLen - 5] */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the loop counter */ + blockSize3--; + + j--; + } + + /* The second part of the stage starts here */ + /* SIMD is not used for the next MAC operations, + * so pointer py is updated to read only one sample at a time */ + py = py + 1U; + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the loop counter */ + blockSize3--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ +} + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q31.c new file mode 100644 index 0000000..bc57221 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_fast_q31.c @@ -0,0 +1,565 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_fast_q31.c + * Description: Fast Q31 Convolution + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * This function is optimized for speed at the expense of fixed-point precision and overflow protection. + * The result of each 1.31 x 1.31 multiplication is truncated to 2.30 format. + * These intermediate results are accumulated in a 32-bit register in 2.30 format. + * Finally, the accumulator is saturated and converted to a 1.31 result. + * + * \par + * The fast version has the same overflow behavior as the standard version but provides less precision since it discards the low 32 bits of each multiplication result. + * In order to avoid overflows completely the input signals must be scaled down. + * Scale down the inputs by log2(min(srcALen, srcBLen)) (log2 is read as log to the base 2) times to avoid overflows, + * as maximum of min(srcALen, srcBLen) number of additions are carried internally. + * + * \par + * See arm_conv_q31() for a slower implementation of this function which uses 64-bit accumulation to provide higher precision. + */ + +void arm_conv_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + q31_t *pIn1; /* inputA pointer */ + q31_t *pIn2; /* inputB pointer */ + q31_t *pOut = pDst; /* output pointer */ + q31_t *px; /* Intermediate inputA pointer */ + q31_t *py; /* Intermediate inputB pointer */ + q31_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t x0, x1, x2, x3, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t j, k, count, blkCnt, blockSize1, blockSize2, blockSize3; /* loop counter */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* The algorithm is implemented in three stages. + The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* x[1] * y[srcBLen - 2] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* x[2] * y[srcBLen - 3] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* x[3] * y[srcBLen - 4] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py--); + + /* Read x[3] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[0] * y[srcBLen - 1] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* acc1 += x[1] * y[srcBLen - 1] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* acc2 += x[2] * y[srcBLen - 1] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x2 * c0)) >> 32); + + /* acc3 += x[3] * y[srcBLen - 1] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x3 * c0)) >> 32); + + /* Read y[srcBLen - 2] sample */ + c0 = *(py--); + + /* Read x[4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[1] * y[srcBLen - 2] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc1 += x[2] * y[srcBLen - 2] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc2 += x[3] * y[srcBLen - 2] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc3 += x[4] * y[srcBLen - 2] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Read y[srcBLen - 3] sample */ + c0 = *(py--); + + /* Read x[5] sample */ + x1 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[srcBLen - 3] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc1 += x[3] * y[srcBLen - 3] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc2 += x[4] * y[srcBLen - 3] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc3 += x[5] * y[srcBLen - 3] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* Read y[srcBLen - 4] sample */ + c0 = *(py--); + + /* Read x[6] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[3] * y[srcBLen - 4] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc1 += x[4] * y[srcBLen - 4] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc2 += x[5] * y[srcBLen - 4] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc3 += x[6] * y[srcBLen - 4] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x2 * c0)) >> 32); + + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc3 += x[7] * y[srcBLen - 5] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x3 * c0)) >> 32); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the results in the accumulators in the destination buffer. */ + *pOut++ = (q31_t) (acc0 << 1); + *pOut++ = (q31_t) (acc1 << 1); + *pOut++ = (q31_t) (acc2 << 1); + *pOut++ = (q31_t) (acc3 << 1); + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 1] * y[srcBLen - 1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* sum += x[srcALen - srcBLen + 2] * y[srcBLen - 2] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* sum += x[srcALen - srcBLen + 3] * y[srcBLen - 3] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* sum += x[srcALen - srcBLen + 4] * y[srcBLen - 4] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = blockSize3 % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the loop counter */ + blockSize3--; + } + +} + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q15.c new file mode 100644 index 0000000..47f6f84 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q15.c @@ -0,0 +1,533 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_opt_q15.c + * Description: Convolution of Q15 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of Q15 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @param[in] *pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] *pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + * @return none. + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch1 and scratch2 buffers should be aligned by 32-bit + * + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both inputs are in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * This approach provides 33 guard bits and there is no risk of overflow. + * The 34.30 result is then truncated to 34.15 format by discarding the low 15 bits and then saturated to 1.15 format. + * + * + * \par + * Refer to arm_conv_fast_q15() for a faster but less precise version of this function for Cortex-M3 and Cortex-M4. + * + * + */ + +void arm_conv_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2) +{ + q63_t acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t x1, x2, x3; /* Temporary variables to hold state and coefficient values */ + q31_t y1, y2; /* State variables */ + q15_t *pOut = pDst; /* output pointer */ + q15_t *pScr1 = pScratch1; /* Temporary pointer for scratch1 */ + q15_t *pScr2 = pScratch2; /* Temporary pointer for scratch1 */ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + uint32_t j, k, blkCnt; /* loop counter */ + uint32_t tapCnt; /* loop count */ +#ifdef UNALIGNED_SUPPORT_DISABLE + + q15_t a, b; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2 + srcBLen - 1; + + /* points to smaller length sequence */ + px = pIn2; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + /* Copy smaller length input sequence in reverse order into second scratch buffer */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Assuming scratch1 buffer is aligned by 32-bit */ + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy bigger length sequence(srcALen) samples in scratch1 buffer */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Copy (srcALen) samples in scratch buffer */ + arm_copy_q15(pIn1, pScr1, srcALen); + + /* Update pointers */ + pScr1 += srcALen; + +#else + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + +#endif + + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update pointer */ + pScr1 += (srcBLen - 1U); + +#else + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = (srcBLen - 1U) % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + +#endif + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + + /* Initialization of pIn2 pointer */ + pIn2 = py; + + /* First part of the processing with loop unrolling process 4 data points at a time. + ** a second loop below process for the remaining 1 to 3 samples. */ + + /* Actual convolution process starts here */ + blkCnt = (srcALen + srcBLen - 1U) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read next two samples from scratch1 buffer */ + x2 = *__SIMD32(pScr1)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pIn2); + y2 = _SIMD32_OFFSET(pIn2 + 2U); + + /* multiply and accumlate */ + acc0 = __SMLALD(x1, y1, acc0); + acc2 = __SMLALD(x2, y1, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + /* multiply and accumlate */ + acc1 = __SMLALDX(x3, y1, acc1); + + /* Read next two samples from scratch1 buffer */ + x1 = _SIMD32_OFFSET(pScr1); + + /* multiply and accumlate */ + acc0 = __SMLALD(x2, y2, acc0); + acc2 = __SMLALD(x1, y2, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLALDX(x3, y1, acc3); + acc1 = __SMLALDX(x3, y2, acc1); + + x2 = _SIMD32_OFFSET(pScr1 + 2U); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLALDX(x3, y2, acc3); + +#else + + /* Read four samples from smaller buffer */ + a = *pIn2; + b = *(pIn2 + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + y1 = __PKHBT(a, b, 16); +#else + y1 = __PKHBT(b, a, 16); +#endif + + a = *(pIn2 + 2); + b = *(pIn2 + 3); +#ifndef ARM_MATH_BIG_ENDIAN + y2 = __PKHBT(a, b, 16); +#else + y2 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLALD(x1, y1, acc0); + + acc2 = __SMLALD(x2, y1, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc1 = __SMLALDX(x3, y1, acc1); + + a = *pScr1; + b = *(pScr1 + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(a, b, 16); +#else + x1 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLALD(x2, y2, acc0); + + acc2 = __SMLALD(x1, y2, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLALDX(x3, y1, acc3); + + acc1 = __SMLALDX(x3, y2, acc1); + + a = *(pScr1 + 2); + b = *(pScr1 + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + x2 = __PKHBT(a, b, 16); +#else + x2 = __PKHBT(b, a, 16); +#endif + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLALDX(x3, y2, acc3); + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + pIn2 += 4U; + pScr1 += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2); + acc1 += (*pScr1++ * *pIn2); + acc2 += (*pScr1++ * *pIn2); + acc3 += (*pScr1++ * *pIn2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = (srcALen + srcBLen - 1U) & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + /* Read next two samples from scratch1 buffer */ + acc0 += (*pScr1++ * *pIn2++); + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* The result is in 2.30 format. Convert to 1.15 with saturation. + ** Then store the output in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 1U; + + } + +} + + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q7.c new file mode 100644 index 0000000..1dc2e49 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_opt_q7.c @@ -0,0 +1,423 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_opt_q7.c + * Description: Convolution of Q7 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of Q7 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @param[in] *pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] *pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen). + * @return none. + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch1 and scratch2 buffers should be aligned by 32-bit + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 32-bit internal accumulator. + * Both the inputs are represented in 1.7 format and multiplications yield a 2.14 result. + * The 2.14 intermediate results are accumulated in a 32-bit accumulator in 18.14 format. + * This approach provides 17 guard bits and there is no risk of overflow as long as max(srcALen, srcBLen)<131072. + * The 18.14 result is then truncated to 18.7 format by discarding the low 7 bits and then saturated to 1.7 format. + * + */ + +void arm_conv_opt_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2) +{ + + q15_t *pScr2, *pScr1; /* Intermediate pointers for scratch pointers */ + q15_t x4; /* Temporary input variable */ + q7_t *pIn1, *pIn2; /* inputA and inputB pointer */ + uint32_t j, k, blkCnt, tapCnt; /* loop counter */ + q7_t *px; /* Temporary input1 pointer */ + q15_t *py; /* Temporary input2 pointer */ + q31_t acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t x1, x2, x3, y1; /* Temporary input variables */ + q7_t *pOut = pDst; /* output pointer */ + q7_t out0, out1, out2, out3; /* temporary variables */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2; + + /* points to smaller length sequence */ + px = pIn2 + srcBLen - 1; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * px--; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy (srcALen) samples in scratch buffer */ + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update pointer */ + pScr1 += (srcBLen - 1U); + +#else + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = (srcBLen - 1U) % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + +#endif + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + /* Initialization of pIn2 pointer */ + pIn2 = (q7_t *) py; + + pScr2 = py; + + /* Actual convolution process starts here */ + blkCnt = (srcALen + srcBLen - 1U) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read next two samples from scratch1 buffer */ + x2 = *__SIMD32(pScr1)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pScr2); + + /* multiply and accumlate */ + acc0 = __SMLAD(x1, y1, acc0); + acc2 = __SMLAD(x2, y1, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + /* multiply and accumlate */ + acc1 = __SMLADX(x3, y1, acc1); + + /* Read next two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pScr2 + 2U); + + acc0 = __SMLAD(x2, y1, acc0); + + acc2 = __SMLAD(x1, y1, acc2); + + acc1 = __SMLADX(x3, y1, acc1); + + x2 = *__SIMD32(pScr1)++; + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + pScr2 += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2); + acc1 += (*pScr1++ * *pScr2); + acc2 += (*pScr1++ * *pScr2); + acc3 += (*pScr1++ * *pScr2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + out0 = (q7_t) (__SSAT(acc0 >> 7U, 8)); + out1 = (q7_t) (__SSAT(acc1 >> 7U, 8)); + out2 = (q7_t) (__SSAT(acc2 >> 7U, 8)); + out3 = (q7_t) (__SSAT(acc3 >> 7U, 8)); + + *__SIMD32(pOut)++ = __PACKq7(out0, out1, out2, out3); + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = (srcALen + srcBLen - 1U) & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + acc0 += (*pScr1++ * *pScr2++); + acc0 += (*pScr1++ * *pScr2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(acc0 >> 7U, 8)); + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 1U; + + } + +} + + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_f32.c new file mode 100644 index 0000000..9eae124 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_f32.c @@ -0,0 +1,678 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_f32.c + * Description: Partial convolution of floating-point sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup PartialConv Partial Convolution + * + * Partial Convolution is equivalent to Convolution except that a subset of the output samples is generated. + * Each function has two additional arguments. + * firstIndex specifies the starting index of the subset of output samples. + * numPoints is the number of output samples to compute. + * The function computes the output in the range + * [firstIndex, ..., firstIndex+numPoints-1]. + * The output array pDst contains numPoints values. + * + * The allowable range of output indices is [0 srcALen+srcBLen-2]. + * If the requested subset does not fall in this range then the functions return ARM_MATH_ARGUMENT_ERROR. + * Otherwise the functions return ARM_MATH_SUCCESS. + * \note Refer arm_conv_f32() for details on fixed point behavior. + * + * + * Fast Versions + * + * \par + * Fast versions are supported for Q31 and Q15 of partial convolution. Cycles for Fast versions are less compared to Q31 and Q15 of partial conv and the design requires + * the input signals should be scaled down to avoid intermediate overflows. + * + * + * Opt Versions + * + * \par + * Opt versions are supported for Q15 and Q7. Design uses internal scratch buffer for getting good optimisation. + * These versions are optimised in cycles and consumes more memory(Scratch memory) compared to Q15 and Q7 versions of partial convolution + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of floating-point sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + */ + +arm_status arm_conv_partial_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t *pIn1 = pSrcA; /* inputA pointer */ + float32_t *pIn2 = pSrcB; /* inputB pointer */ + float32_t *pOut = pDst; /* output pointer */ + float32_t *px; /* Intermediate inputA pointer */ + float32_t *py; /* Intermediate inputB pointer */ + float32_t *pSrc1, *pSrc2; /* Intermediate pointers */ + float32_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + float32_t x0, x1, x2, x3, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t j, k, count = 0U, blkCnt, check; + int32_t blockSize1, blockSize2, blockSize3; /* loop counters */ + arm_status status; /* status of Partial convolution */ + + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Conditions to check which loopCounter holds + * the first and last indices of the output samples to be calculated. */ + check = firstIndex + numPoints; + blockSize3 = ((int32_t)check > (int32_t)srcALen) ? (int32_t)check - (int32_t)srcALen : 0; + blockSize3 = ((int32_t)firstIndex > (int32_t)srcALen - 1) ? blockSize3 - (int32_t)firstIndex + (int32_t)srcALen : blockSize3; + blockSize1 = ((int32_t) srcBLen - 1) - (int32_t) firstIndex; + blockSize1 = (blockSize1 > 0) ? ((check > (srcBLen - 1U)) ? blockSize1 : + (int32_t) numPoints) : 0; + blockSize2 = ((int32_t) check - blockSize3) - + (blockSize1 + (int32_t) firstIndex); + blockSize2 = (blockSize2 > 0) ? blockSize2 : 0; + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* Set the output pointer to point to the firstIndex + * of the output sample to be calculated. */ + pOut = pDst + firstIndex; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed. + Since the partial convolution starts from from firstIndex + Number of Macs to be performed is firstIndex + 1 */ + count = 1U + firstIndex; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + firstIndex; + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 1] */ + sum += *px++ * *py--; + + /* x[1] * y[srcBLen - 2] */ + sum += *px++ * *py--; + + /* x[2] * y[srcBLen - 3] */ + sum += *px++ * *py--; + + /* x[3] * y[srcBLen - 4] */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc1; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1; + } + else + { + px = pIn1; + } + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = ((uint32_t) blockSize2 >> 2U); + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0.0f; + acc1 = 0.0f; + acc2 = 0.0f; + acc3 = 0.0f; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py--); + + /* Read x[3] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[0] * y[srcBLen - 1] */ + acc0 += x0 * c0; + + /* acc1 += x[1] * y[srcBLen - 1] */ + acc1 += x1 * c0; + + /* acc2 += x[2] * y[srcBLen - 1] */ + acc2 += x2 * c0; + + /* acc3 += x[3] * y[srcBLen - 1] */ + acc3 += x3 * c0; + + /* Read y[srcBLen - 2] sample */ + c0 = *(py--); + + /* Read x[4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[1] * y[srcBLen - 2] */ + acc0 += x1 * c0; + /* acc1 += x[2] * y[srcBLen - 2] */ + acc1 += x2 * c0; + /* acc2 += x[3] * y[srcBLen - 2] */ + acc2 += x3 * c0; + /* acc3 += x[4] * y[srcBLen - 2] */ + acc3 += x0 * c0; + + /* Read y[srcBLen - 3] sample */ + c0 = *(py--); + + /* Read x[5] sample */ + x1 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[srcBLen - 3] */ + acc0 += x2 * c0; + /* acc1 += x[3] * y[srcBLen - 2] */ + acc1 += x3 * c0; + /* acc2 += x[4] * y[srcBLen - 2] */ + acc2 += x0 * c0; + /* acc3 += x[5] * y[srcBLen - 2] */ + acc3 += x1 * c0; + + /* Read y[srcBLen - 4] sample */ + c0 = *(py--); + + /* Read x[6] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[3] * y[srcBLen - 4] */ + acc0 += x3 * c0; + /* acc1 += x[4] * y[srcBLen - 4] */ + acc1 += x0 * c0; + /* acc2 += x[5] * y[srcBLen - 4] */ + acc2 += x1 * c0; + /* acc3 += x[6] * y[srcBLen - 4] */ + acc3 += x2 * c0; + + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 += x0 * c0; + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 += x1 * c0; + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 += x2 * c0; + /* acc3 += x[7] * y[srcBLen - 5] */ + acc3 += x3 * c0; + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = acc0; + *pOut++ = acc1; + *pOut++ = acc2; + *pOut++ = acc3; + + /* Increment the pointer pIn1 index, count by 1 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = (uint32_t) blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += *px++ * *py--; + sum += *px++ * *py--; + sum += *px++ * *py--; + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = (uint32_t) blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + while (blockSize3 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 1] * y[srcBLen - 1] */ + sum += *px++ * *py--; + + /* sum += x[srcALen - srcBLen + 2] * y[srcBLen - 2] */ + sum += *px++ * *py--; + + /* sum += x[srcALen - srcBLen + 3] * y[srcBLen - 3] */ + sum += *px++ * *py--; + + /* sum += x[srcALen - srcBLen + 4] * y[srcBLen - 4] */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum += *px++ * *py--; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); + +#else + + /* Run the below code for Cortex-M0 */ + + float32_t *pIn1 = pSrcA; /* inputA pointer */ + float32_t *pIn2 = pSrcB; /* inputB pointer */ + float32_t sum; /* Accumulator */ + uint32_t i, j; /* loop counters */ + arm_status status; /* status of Partial convolution */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + /* Loop to calculate convolution for output length number of values */ + for (i = firstIndex; i <= (firstIndex + numPoints - 1); i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0.0f; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations for inputs */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += pIn1[j] * pIn2[i - j]; + } + } + /* Store the output in the destination buffer */ + pDst[i] = sum; + } + /* set status as ARM_SUCCESS as there are no argument errors */ + status = ARM_MATH_SUCCESS; + } + return (status); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_opt_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_opt_q15.c new file mode 100644 index 0000000..f469d1f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_opt_q15.c @@ -0,0 +1,756 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_fast_opt_q15.c + * Description: Fast Q15 Partial convolution + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @param[in] *pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] *pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * See arm_conv_partial_q15() for a slower implementation of this function which uses a 64-bit accumulator to avoid wrap around distortion. + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch1 and scratch2 buffers should be aligned by 32-bit + * + */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + +arm_status arm_conv_partial_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2) +{ + + q15_t *pOut = pDst; /* output pointer */ + q15_t *pScr1 = pScratch1; /* Temporary pointer for scratch1 */ + q15_t *pScr2 = pScratch2; /* Temporary pointer for scratch1 */ + q31_t acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t x1, x2, x3; /* Temporary variables to hold state and coefficient values */ + q31_t y1, y2; /* State variables */ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + uint32_t j, k, blkCnt; /* loop counter */ + arm_status status; + + uint32_t tapCnt; /* loop count */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2 + srcBLen - 1; + + /* points to smaller length sequence */ + px = pIn2; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + + /* Copy smaller length input sequence in reverse order into second scratch buffer */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Assuming scratch1 buffer is aligned by 32-bit */ + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy bigger length sequence(srcALen) samples in scratch1 buffer */ + + /* Copy (srcALen) samples in scratch buffer */ + arm_copy_q15(pIn1, pScr1, srcALen); + + /* Update pointers */ + pScr1 += srcALen; + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update pointer */ + pScr1 += (srcBLen - 1U); + + /* Initialization of pIn2 pointer */ + pIn2 = py; + + pScratch1 += firstIndex; + + pOut = pDst + firstIndex; + + /* First part of the processing with loop unrolling process 4 data points at a time. + ** a second loop below process for the remaining 1 to 3 samples. */ + + /* Actual convolution process starts here */ + blkCnt = (numPoints) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read next two samples from scratch1 buffer */ + x2 = *__SIMD32(pScr1)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pIn2); + y2 = _SIMD32_OFFSET(pIn2 + 2U); + + /* multiply and accumlate */ + acc0 = __SMLAD(x1, y1, acc0); + acc2 = __SMLAD(x2, y1, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + /* multiply and accumlate */ + acc1 = __SMLADX(x3, y1, acc1); + + /* Read next two samples from scratch1 buffer */ + x1 = _SIMD32_OFFSET(pScr1); + + /* multiply and accumlate */ + acc0 = __SMLAD(x2, y2, acc0); + + acc2 = __SMLAD(x1, y2, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + acc1 = __SMLADX(x3, y2, acc1); + + x2 = _SIMD32_OFFSET(pScr1 + 2U); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y2, acc3); + + /* update scratch pointers */ + pIn2 += 4U; + pScr1 += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2); + acc1 += (*pScr1++ * *pIn2); + acc2 += (*pScr1++ * *pIn2); + acc3 += (*pScr1++ * *pIn2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = numPoints & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + /* Read next two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read two samples from smaller buffer */ + y1 = *__SIMD32(pIn2)++; + + acc0 = __SMLAD(x1, y1, acc0); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* The result is in 2.30 format. Convert to 1.15 with saturation. + ** Then store the output in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 1U; + + } + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + /* Return to application */ + return (status); +} + +#else + +arm_status arm_conv_partial_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2) +{ + + q15_t *pOut = pDst; /* output pointer */ + q15_t *pScr1 = pScratch1; /* Temporary pointer for scratch1 */ + q15_t *pScr2 = pScratch2; /* Temporary pointer for scratch1 */ + q31_t acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + uint32_t j, k, blkCnt; /* loop counter */ + arm_status status; /* Status variable */ + uint32_t tapCnt; /* loop count */ + q15_t x10, x11, x20, x21; /* Temporary variables to hold srcA buffer */ + q15_t y10, y11; /* Temporary variables to hold srcB buffer */ + + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2 + srcBLen - 1; + + /* points to smaller length sequence */ + px = pIn2; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy bigger length sequence(srcALen) samples in scratch1 buffer */ + + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = (srcBLen - 1U) % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + + /* Initialization of pIn2 pointer */ + pIn2 = py; + + pScratch1 += firstIndex; + + pOut = pDst + firstIndex; + + /* Actual convolution process starts here */ + blkCnt = (numPoints) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x10 = *pScr1++; + x11 = *pScr1++; + + /* Read next two samples from scratch1 buffer */ + x20 = *pScr1++; + x21 = *pScr1++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read two samples from smaller buffer */ + y10 = *pIn2; + y11 = *(pIn2 + 1U); + + /* multiply and accumlate */ + acc0 += (q31_t) x10 *y10; + acc0 += (q31_t) x11 *y11; + acc2 += (q31_t) x20 *y10; + acc2 += (q31_t) x21 *y11; + + /* multiply and accumlate */ + acc1 += (q31_t) x11 *y10; + acc1 += (q31_t) x20 *y11; + + /* Read next two samples from scratch1 buffer */ + x10 = *pScr1; + x11 = *(pScr1 + 1U); + + /* multiply and accumlate */ + acc3 += (q31_t) x21 *y10; + acc3 += (q31_t) x10 *y11; + + /* Read next two samples from scratch2 buffer */ + y10 = *(pIn2 + 2U); + y11 = *(pIn2 + 3U); + + /* multiply and accumlate */ + acc0 += (q31_t) x20 *y10; + acc0 += (q31_t) x21 *y11; + acc2 += (q31_t) x10 *y10; + acc2 += (q31_t) x11 *y11; + acc1 += (q31_t) x21 *y10; + acc1 += (q31_t) x10 *y11; + + /* Read next two samples from scratch1 buffer */ + x20 = *(pScr1 + 2); + x21 = *(pScr1 + 3); + + /* multiply and accumlate */ + acc3 += (q31_t) x11 *y10; + acc3 += (q31_t) x20 *y11; + + /* update scratch pointers */ + pIn2 += 4U; + pScr1 += 4U; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2); + acc1 += (*pScr1++ * *pIn2); + acc2 += (*pScr1++ * *pIn2); + acc3 += (*pScr1++ * *pIn2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + *pOut++ = __SSAT((acc0 >> 15), 16); + *pOut++ = __SSAT((acc1 >> 15), 16); + *pOut++ = __SSAT((acc2 >> 15), 16); + *pOut++ = __SSAT((acc3 >> 15), 16); + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = numPoints & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + /* Read next two samples from scratch1 buffer */ + x10 = *pScr1++; + x11 = *pScr1++; + + /* Read two samples from smaller buffer */ + y10 = *pIn2++; + y11 = *pIn2++; + + /* multiply and accumlate */ + acc0 += (q31_t) x10 *y10; + acc0 += (q31_t) x11 *y11; + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 1U; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + } + + /* Return to application */ + return (status); +} + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q15.c new file mode 100644 index 0000000..0d4486a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q15.c @@ -0,0 +1,1494 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_fast_q15.c + * Description: Fast Q15 Partial convolution + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * See arm_conv_partial_q15() for a slower implementation of this function which uses a 64-bit accumulator to avoid wrap around distortion. + */ + + +arm_status arm_conv_partial_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ +#ifndef UNALIGNED_SUPPORT_DISABLE + + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; + uint32_t j, k, count, check, blkCnt; + int32_t blockSize1, blockSize2, blockSize3; /* loop counters */ + arm_status status; /* status of Partial convolution */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >=srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Conditions to check which loopCounter holds + * the first and last indices of the output samples to be calculated. */ + check = firstIndex + numPoints; + blockSize3 = ((int32_t)check > (int32_t)srcALen) ? (int32_t)check - (int32_t)srcALen : 0; + blockSize3 = ((int32_t)firstIndex > (int32_t)srcALen - 1) ? blockSize3 - (int32_t)firstIndex + (int32_t)srcALen : blockSize3; + blockSize1 = (((int32_t) srcBLen - 1) - (int32_t) firstIndex); + blockSize1 = (blockSize1 > 0) ? ((check > (srcBLen - 1U)) ? blockSize1 : + (int32_t) numPoints) : 0; + blockSize2 = (int32_t) check - ((blockSize3 + blockSize1) + + (int32_t) firstIndex); + blockSize2 = (blockSize2 > 0) ? blockSize2 : 0; + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* Set the output pointer to point to the firstIndex + * of the output sample to be calculated. */ + pOut = pDst + firstIndex; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed. + Since the partial convolution starts from firstIndex + Number of Macs to be performed is firstIndex + 1 */ + count = 1U + firstIndex; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + firstIndex; + py = pSrc2; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations less than 4 */ + /* Second part of this stage computes the MAC operations greater than or equal to 4 */ + + /* The first part of the stage starts here */ + while ((count < 4U) && (blockSize1 > 0)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over number of MAC operations between + * inputA samples and inputB samples */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* The second part of the stage starts here */ + /* The internal loop, over count, is unrolled by 4 */ + /* To, read the last two inputB samples using SIMD: + * y[srcBLen] and y[srcBLen-1] coefficients, py is decremented by 1 */ + py = py - 1; + + while (blockSize1 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0], x[1] are multiplied with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[2], x[3] are multiplied with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2 - 1U; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1; + } + else + { + px = pIn1; + } + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is the index by which the pointer pIn1 to be incremented */ + count = 0U; + + + /* -------------------- + * Stage2 process + * -------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = ((uint32_t) blockSize2 >> 2U); + + while (blkCnt > 0U) + { + py = py - 1U; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + + /* read x[0], x[1] samples */ + x0 = *__SIMD32(px); + /* read x[1], x[2] samples */ + x1 = _SIMD32_OFFSET(px+1); + px+= 2U; + + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the last two inputB samples using SIMD: + * y[srcBLen - 1] and y[srcBLen - 2] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLADX(x0, c0, acc0); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLADX(x1, c0, acc1); + + /* Read x[2], x[3] */ + x2 = *__SIMD32(px); + + /* Read x[3], x[4] */ + x3 = _SIMD32_OFFSET(px+1); + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLADX(x2, c0, acc2); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLADX(x3, c0, acc3); + + /* Read y[srcBLen - 3] and y[srcBLen - 4] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLADX(x2, c0, acc0); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLADX(x3, c0, acc1); + + /* Read x[4], x[5] */ + x0 = _SIMD32_OFFSET(px+2); + + /* Read x[5], x[6] */ + x1 = _SIMD32_OFFSET(px+3); + px += 4U; + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLADX(x0, c0, acc2); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLADX(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[srcBLen - 5] */ + c0 = *(py+1); +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7] */ + x3 = *__SIMD32(px); + px++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLADX(x1, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + + c0 = *(py-1); +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[10] */ + x3 = _SIMD32_OFFSET(px+2); + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x1, c0, acc0); + acc1 = __SMLAD(x2, c0, acc1); + acc2 = __SMLADX(x2, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + /* Store the results in the accumulators in the destination buffer. */ +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = __PKHBT(acc0 >> 15, acc1 >> 15, 16); + *__SIMD32(pOut)++ = __PKHBT(acc2 >> 15, acc3 >> 15, 16); + +#else + + *__SIMD32(pOut)++ = __PKHBT(acc1 >> 15, acc0 >> 15, 16); + *__SIMD32(pOut)++ = __PKHBT(acc3 >> 15, acc2 >> 15, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = (uint32_t) blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = (uint32_t) blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + pIn2 = pSrc2 - 1U; + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations greater than 4 */ + /* Second part of this stage computes the MAC operations less than or equal to 4 */ + + /* The first part of the stage starts here */ + j = count >> 2U; + + while ((j > 0U) && (blockSize3 > 0)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[srcALen - srcBLen + 1], x[srcALen - srcBLen + 2] are multiplied + * with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[srcALen - srcBLen + 3], x[srcALen - srcBLen + 4] are multiplied + * with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLADX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 5] * y[srcBLen - 5] */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + + j--; + } + + /* The second part of the stage starts here */ + /* SIMD is not used for the next MAC operations, + * so pointer py is updated to read only one sample at a time */ + py = py + 1U; + + while (blockSize3 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum = __SMLAD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); + +#else + + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; + uint32_t j, k, count, check, blkCnt; + int32_t blockSize1, blockSize2, blockSize3; /* loop counters */ + arm_status status; /* status of Partial convolution */ + q15_t a, b; + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >=srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Conditions to check which loopCounter holds + * the first and last indices of the output samples to be calculated. */ + check = firstIndex + numPoints; + blockSize3 = ((int32_t)check > (int32_t)srcALen) ? (int32_t)check - (int32_t)srcALen : 0; + blockSize3 = ((int32_t)firstIndex > (int32_t)srcALen - 1) ? blockSize3 - (int32_t)firstIndex + (int32_t)srcALen : blockSize3; + blockSize1 = ((int32_t) srcBLen - 1) - (int32_t) firstIndex; + blockSize1 = (blockSize1 > 0) ? ((check > (srcBLen - 1U)) ? blockSize1 : + (int32_t) numPoints) : 0; + blockSize2 = ((int32_t) check - blockSize3) - + (blockSize1 + (int32_t) firstIndex); + blockSize2 = (blockSize2 > 0) ? blockSize2 : 0; + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* Set the output pointer to point to the firstIndex + * of the output sample to be calculated. */ + pOut = pDst + firstIndex; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed. + Since the partial convolution starts from firstIndex + Number of Macs to be performed is firstIndex + 1 */ + count = 1U + firstIndex; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + firstIndex; + py = pSrc2; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations less than 4 */ + /* Second part of this stage computes the MAC operations greater than or equal to 4 */ + + /* The first part of the stage starts here */ + while ((count < 4U) && (blockSize1 > 0)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over number of MAC operations between + * inputA samples and inputB samples */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* The second part of the stage starts here */ + /* The internal loop, over count, is unrolled by 4 */ + /* To, read the last two inputB samples using SIMD: + * y[srcBLen] and y[srcBLen-1] coefficients, py is decremented by 1 */ + py = py - 1; + + while (blockSize1 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + py++; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2 - 1U; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1; + } + else + { + px = pIn1; + } + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is the index by which the pointer pIn1 to be incremented */ + count = 0U; + + + /* -------------------- + * Stage2 process + * -------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = ((uint32_t) blockSize2 >> 2U); + + while (blkCnt > 0U) + { + py = py - 1U; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1] samples */ + a = *px++; + b = *px++; + +#ifndef ARM_MATH_BIG_ENDIAN + + x0 = __PKHBT(a, b, 16); + a = *px; + x1 = __PKHBT(b, a, 16); + +#else + + x0 = __PKHBT(b, a, 16); + a = *px; + x1 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the last two inputB samples using SIMD: + * y[srcBLen - 1] and y[srcBLen - 2] */ + a = *py; + b = *(py+1); + py -= 2; + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLADX(x0, c0, acc0); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLADX(x1, c0, acc1); + + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x2 = __PKHBT(a, b, 16); + a = *(px + 2); + x3 = __PKHBT(b, a, 16); + +#else + + x2 = __PKHBT(b, a, 16); + a = *(px + 2); + x3 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLADX(x2, c0, acc2); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLADX(x3, c0, acc3); + + /* Read y[srcBLen - 3] and y[srcBLen - 4] */ + a = *py; + b = *(py+1); + py -= 2; + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLADX(x2, c0, acc0); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLADX(x3, c0, acc1); + + /* Read x[4], x[5], x[6] */ + a = *(px + 2); + b = *(px + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + + x0 = __PKHBT(a, b, 16); + a = *(px + 4); + x1 = __PKHBT(b, a, 16); + +#else + + x0 = __PKHBT(b, a, 16); + a = *(px + 4); + x1 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 4U; + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLADX(x0, c0, acc2); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLADX(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[srcBLen - 5] */ + c0 = *(py+1); + +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7] */ + a = *px; + b = *(px+1); + px++; + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + +#else + + x3 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLADX(x1, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + a = *py; + b = *(py+1); + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7], x[8], x[9] */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + a = *(px + 2); + x2 = __PKHBT(b, a, 16); + +#else + + x3 = __PKHBT(b, a, 16); + a = *(px + 2); + x2 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + a = *py; + b = *(py+1); + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7], x[8], x[9] */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + a = *(px + 2); + x2 = __PKHBT(b, a, 16); + +#else + + x3 = __PKHBT(b, a, 16); + a = *(px + 2); + x2 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x0, c0, acc0); + acc1 = __SMLADX(x1, c0, acc1); + acc2 = __SMLADX(x3, c0, acc2); + acc3 = __SMLADX(x2, c0, acc3); + + /* Read y[srcBLen - 7] */ + c0 = *(py-1); +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[10] */ + a = *(px+2); + b = *(px+3); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + +#else + + x3 = __PKHBT(b, a, 16);; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x1, c0, acc0); + acc1 = __SMLAD(x2, c0, acc1); + acc2 = __SMLADX(x2, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + /* Store the results in the accumulators in the destination buffer. */ + *pOut++ = (q15_t)(acc0 >> 15); + *pOut++ = (q15_t)(acc1 >> 15); + *pOut++ = (q15_t)(acc2 >> 15); + *pOut++ = (q15_t)(acc3 >> 15); + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = (uint32_t) blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = (uint32_t) blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + pIn2 = pSrc2 - 1U; + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations greater than 4 */ + /* Second part of this stage computes the MAC operations less than or equal to 4 */ + + /* The first part of the stage starts here */ + j = count >> 2U; + + while ((j > 0U) && (blockSize3 > 0)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + py++; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + sum += ((q31_t) * px++ * *py--); + /* Decrement the loop counter */ + k--; + } + + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + + j--; + } + + /* The second part of the stage starts here */ + /* SIMD is not used for the next MAC operations, + * so pointer py is updated to read only one sample at a time */ + py = py + 1U; + + while (blockSize3 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (sum >> 15); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ +} + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q31.c new file mode 100644 index 0000000..e845947 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_fast_q31.c @@ -0,0 +1,620 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_fast_q31.c + * Description: Fast Q31 Partial convolution + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * \par + * See arm_conv_partial_q31() for a slower implementation of this function which uses a 64-bit accumulator to provide higher precision. + */ + +arm_status arm_conv_partial_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + q31_t *pIn1; /* inputA pointer */ + q31_t *pIn2; /* inputB pointer */ + q31_t *pOut = pDst; /* output pointer */ + q31_t *px; /* Intermediate inputA pointer */ + q31_t *py; /* Intermediate inputB pointer */ + q31_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulators */ + q31_t x0, x1, x2, x3, c0; + uint32_t j, k, count, check, blkCnt; + int32_t blockSize1, blockSize2, blockSize3; /* loop counters */ + arm_status status; /* status of Partial convolution */ + + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Conditions to check which loopCounter holds + * the first and last indices of the output samples to be calculated. */ + check = firstIndex + numPoints; + blockSize3 = ((int32_t)check > (int32_t)srcALen) ? (int32_t)check - (int32_t)srcALen : 0; + blockSize3 = ((int32_t)firstIndex > (int32_t)srcALen - 1) ? blockSize3 - (int32_t)firstIndex + (int32_t)srcALen : blockSize3; + blockSize1 = (((int32_t) srcBLen - 1) - (int32_t) firstIndex); + blockSize1 = (blockSize1 > 0) ? ((check > (srcBLen - 1U)) ? blockSize1 : + (int32_t) numPoints) : 0; + blockSize2 = (int32_t) check - ((blockSize3 + blockSize1) + + (int32_t) firstIndex); + blockSize2 = (blockSize2 > 0) ? blockSize2 : 0; + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* Set the output pointer to point to the firstIndex + * of the output sample to be calculated. */ + pOut = pDst + firstIndex; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed. + Since the partial convolution starts from firstIndex + Number of Macs to be performed is firstIndex + 1 */ + count = 1U + firstIndex; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + firstIndex; + py = pSrc2; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first loop starts here */ + while (blockSize1 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* x[1] * y[srcBLen - 2] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* x[2] * y[srcBLen - 3] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* x[3] * y[srcBLen - 4] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1; + } + else + { + px = pIn1; + } + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2 */ + blkCnt = ((uint32_t) blockSize2 >> 2U); + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py--); + + /* Read x[3] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[0] * y[srcBLen - 1] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* acc1 += x[1] * y[srcBLen - 1] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* acc2 += x[2] * y[srcBLen - 1] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x2 * c0)) >> 32); + + /* acc3 += x[3] * y[srcBLen - 1] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x3 * c0)) >> 32); + + /* Read y[srcBLen - 2] sample */ + c0 = *(py--); + + /* Read x[4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[1] * y[srcBLen - 2] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc1 += x[2] * y[srcBLen - 2] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc2 += x[3] * y[srcBLen - 2] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc3 += x[4] * y[srcBLen - 2] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Read y[srcBLen - 3] sample */ + c0 = *(py--); + + /* Read x[5] sample */ + x1 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[srcBLen - 3] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc1 += x[3] * y[srcBLen - 2] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc2 += x[4] * y[srcBLen - 2] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc3 += x[5] * y[srcBLen - 2] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* Read y[srcBLen - 4] sample */ + c0 = *(py--); + + /* Read x[6] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[3] * y[srcBLen - 4] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc1 += x[4] * y[srcBLen - 4] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc2 += x[5] * y[srcBLen - 4] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc3 += x[6] * y[srcBLen - 4] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x2 * c0)) >> 32); + + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc3 += x[7] * y[srcBLen - 5] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x3 * c0)) >> 32); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (acc0 << 1); + *pOut++ = (q31_t) (acc1 << 1); + *pOut++ = (q31_t) (acc2 << 1); + *pOut++ = (q31_t) (acc3 << 1); + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = (uint32_t) blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = (uint32_t) blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 1] * y[srcBLen - 1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* sum += x[srcALen - srcBLen + 2] * y[srcBLen - 2] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* sum += x[srcALen - srcBLen + 3] * y[srcBLen - 3] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* sum += x[srcALen - srcBLen + 4] * y[srcBLen - 4] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py--))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = sum << 1; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); + +} + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q15.c new file mode 100644 index 0000000..78dd548 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q15.c @@ -0,0 +1,753 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_opt_q15.c + * Description: Partial convolution of Q15 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q15 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @param[in] *pScratch1 points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] *pScratch2 points to scratch buffer of size min(srcALen, srcBLen). + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, state buffers should be aligned by 32-bit + * + * Refer to arm_conv_partial_fast_q15() for a faster but less precise version of this function for Cortex-M3 and Cortex-M4. + * + * + */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + +arm_status arm_conv_partial_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2) +{ + + q15_t *pOut = pDst; /* output pointer */ + q15_t *pScr1 = pScratch1; /* Temporary pointer for scratch1 */ + q15_t *pScr2 = pScratch2; /* Temporary pointer for scratch1 */ + q63_t acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t x1, x2, x3; /* Temporary variables to hold state and coefficient values */ + q31_t y1, y2; /* State variables */ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + uint32_t j, k, blkCnt; /* loop counter */ + arm_status status; /* Status variable */ + uint32_t tapCnt; /* loop count */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2 + srcBLen - 1; + + /* points to smaller length sequence */ + px = pIn2; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy bigger length sequence(srcALen) samples in scratch1 buffer */ + + /* Copy (srcALen) samples in scratch buffer */ + arm_copy_q15(pIn1, pScr1, srcALen); + + /* Update pointers */ + pScr1 += srcALen; + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update pointer */ + pScr1 += (srcBLen - 1U); + + /* Initialization of pIn2 pointer */ + pIn2 = py; + + pScratch1 += firstIndex; + + pOut = pDst + firstIndex; + + /* Actual convolution process starts here */ + blkCnt = (numPoints) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read next two samples from scratch1 buffer */ + x2 = *__SIMD32(pScr1)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pIn2); + y2 = _SIMD32_OFFSET(pIn2 + 2U); + + /* multiply and accumlate */ + acc0 = __SMLALD(x1, y1, acc0); + acc2 = __SMLALD(x2, y1, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + /* multiply and accumlate */ + acc1 = __SMLALDX(x3, y1, acc1); + + /* Read next two samples from scratch1 buffer */ + x1 = _SIMD32_OFFSET(pScr1); + + /* multiply and accumlate */ + acc0 = __SMLALD(x2, y2, acc0); + acc2 = __SMLALD(x1, y2, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLALDX(x3, y1, acc3); + acc1 = __SMLALDX(x3, y2, acc1); + + x2 = _SIMD32_OFFSET(pScr1 + 2U); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLALDX(x3, y2, acc3); + + /* update scratch pointers */ + pIn2 += 4U; + pScr1 += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2); + acc1 += (*pScr1++ * *pIn2); + acc2 += (*pScr1++ * *pIn2); + acc3 += (*pScr1++ * *pIn2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = numPoints & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + /* Read next two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read two samples from smaller buffer */ + y1 = *__SIMD32(pIn2)++; + + acc0 = __SMLALD(x1, y1, acc0); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 1U; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + } + + /* Return to application */ + return (status); +} + +#else + +arm_status arm_conv_partial_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2) +{ + + q15_t *pOut = pDst; /* output pointer */ + q15_t *pScr1 = pScratch1; /* Temporary pointer for scratch1 */ + q15_t *pScr2 = pScratch2; /* Temporary pointer for scratch1 */ + q63_t acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + uint32_t j, k, blkCnt; /* loop counter */ + arm_status status; /* Status variable */ + uint32_t tapCnt; /* loop count */ + q15_t x10, x11, x20, x21; /* Temporary variables to hold srcA buffer */ + q15_t y10, y11; /* Temporary variables to hold srcB buffer */ + + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2 + srcBLen - 1; + + /* points to smaller length sequence */ + px = pIn2; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr2-- = *px++; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy bigger length sequence(srcALen) samples in scratch1 buffer */ + + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = *pIn1++; + + /* Decrement the loop counter */ + k--; + } + + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = (srcBLen - 1U) % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + + /* Initialization of pIn2 pointer */ + pIn2 = py; + + pScratch1 += firstIndex; + + pOut = pDst + firstIndex; + + /* Actual convolution process starts here */ + blkCnt = (numPoints) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x10 = *pScr1++; + x11 = *pScr1++; + + /* Read next two samples from scratch1 buffer */ + x20 = *pScr1++; + x21 = *pScr1++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read two samples from smaller buffer */ + y10 = *pIn2; + y11 = *(pIn2 + 1U); + + /* multiply and accumlate */ + acc0 += (q63_t) x10 *y10; + acc0 += (q63_t) x11 *y11; + acc2 += (q63_t) x20 *y10; + acc2 += (q63_t) x21 *y11; + + /* multiply and accumlate */ + acc1 += (q63_t) x11 *y10; + acc1 += (q63_t) x20 *y11; + + /* Read next two samples from scratch1 buffer */ + x10 = *pScr1; + x11 = *(pScr1 + 1U); + + /* multiply and accumlate */ + acc3 += (q63_t) x21 *y10; + acc3 += (q63_t) x10 *y11; + + /* Read next two samples from scratch2 buffer */ + y10 = *(pIn2 + 2U); + y11 = *(pIn2 + 3U); + + /* multiply and accumlate */ + acc0 += (q63_t) x20 *y10; + acc0 += (q63_t) x21 *y11; + acc2 += (q63_t) x10 *y10; + acc2 += (q63_t) x11 *y11; + acc1 += (q63_t) x21 *y10; + acc1 += (q63_t) x10 *y11; + + /* Read next two samples from scratch1 buffer */ + x20 = *(pScr1 + 2); + x21 = *(pScr1 + 3); + + /* multiply and accumlate */ + acc3 += (q63_t) x11 *y10; + acc3 += (q63_t) x20 *y11; + + /* update scratch pointers */ + pIn2 += 4U; + pScr1 += 4U; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2); + acc1 += (*pScr1++ * *pIn2); + acc2 += (*pScr1++ * *pIn2); + acc3 += (*pScr1++ * *pIn2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + *pOut++ = __SSAT((acc0 >> 15), 16); + *pOut++ = __SSAT((acc1 >> 15), 16); + *pOut++ = __SSAT((acc2 >> 15), 16); + *pOut++ = __SSAT((acc3 >> 15), 16); + + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = numPoints & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + /* Read next two samples from scratch1 buffer */ + x10 = *pScr1++; + x11 = *pScr1++; + + /* Read two samples from smaller buffer */ + y10 = *pIn2++; + y11 = *pIn2++; + + /* multiply and accumlate */ + acc0 += (q63_t) x10 *y10; + acc0 += (q63_t) x11 *y11; + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch1 += 1U; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + } + + /* Return to application */ + return (status); +} + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q7.c new file mode 100644 index 0000000..351c290 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_opt_q7.c @@ -0,0 +1,791 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_opt_q7.c + * Description: Partial convolution of Q7 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q7 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @param[in] *pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] *pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen). + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch1 and scratch2 buffers should be aligned by 32-bit + * + * + * + */ + + +#ifndef UNALIGNED_SUPPORT_DISABLE + +arm_status arm_conv_partial_opt_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2) +{ + + q15_t *pScr2, *pScr1; /* Intermediate pointers for scratch pointers */ + q15_t x4; /* Temporary input variable */ + q7_t *pIn1, *pIn2; /* inputA and inputB pointer */ + uint32_t j, k, blkCnt, tapCnt; /* loop counter */ + q7_t *px; /* Temporary input1 pointer */ + q15_t *py; /* Temporary input2 pointer */ + q31_t acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t x1, x2, x3, y1; /* Temporary input variables */ + arm_status status; + q7_t *pOut = pDst; /* output pointer */ + q7_t out0, out1, out2, out3; /* temporary variables */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2; + + /* points to smaller length sequence */ + px = pIn2 + srcBLen - 1; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * px--; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy (srcALen) samples in scratch buffer */ + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update pointer */ + pScr1 += (srcBLen - 1U); + + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + /* Initialization of pIn2 pointer */ + pIn2 = (q7_t *) py; + + pScr2 = py; + + pOut = pDst + firstIndex; + + pScratch1 += firstIndex; + + /* Actual convolution process starts here */ + blkCnt = (numPoints) >> 2; + + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read next two samples from scratch1 buffer */ + x2 = *__SIMD32(pScr1)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pScr2); + + /* multiply and accumlate */ + acc0 = __SMLAD(x1, y1, acc0); + acc2 = __SMLAD(x2, y1, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + /* multiply and accumlate */ + acc1 = __SMLADX(x3, y1, acc1); + + /* Read next two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pScr2 + 2U); + + acc0 = __SMLAD(x2, y1, acc0); + + acc2 = __SMLAD(x1, y1, acc2); + + acc1 = __SMLADX(x3, y1, acc1); + + x2 = *__SIMD32(pScr1)++; + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + pScr2 += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2); + acc1 += (*pScr1++ * *pScr2); + acc2 += (*pScr1++ * *pScr2); + acc3 += (*pScr1++ * *pScr2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + out0 = (q7_t) (__SSAT(acc0 >> 7U, 8)); + out1 = (q7_t) (__SSAT(acc1 >> 7U, 8)); + out2 = (q7_t) (__SSAT(acc2 >> 7U, 8)); + out3 = (q7_t) (__SSAT(acc3 >> 7U, 8)); + + *__SIMD32(pOut)++ = __PACKq7(out0, out1, out2, out3); + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 4U; + + } + + blkCnt = (numPoints) & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + /* Read next two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read two samples from smaller buffer */ + y1 = *__SIMD32(pScr2)++; + + acc0 = __SMLAD(x1, y1, acc0); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(acc0 >> 7U, 8)); + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 1U; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + + } + + return (status); + +} + +#else + +arm_status arm_conv_partial_opt_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + uint32_t firstIndex, + uint32_t numPoints, + q15_t * pScratch1, + q15_t * pScratch2) +{ + + q15_t *pScr2, *pScr1; /* Intermediate pointers for scratch pointers */ + q15_t x4; /* Temporary input variable */ + q7_t *pIn1, *pIn2; /* inputA and inputB pointer */ + uint32_t j, k, blkCnt, tapCnt; /* loop counter */ + q7_t *px; /* Temporary input1 pointer */ + q15_t *py; /* Temporary input2 pointer */ + q31_t acc0, acc1, acc2, acc3; /* Accumulator */ + arm_status status; + q7_t *pOut = pDst; /* output pointer */ + q15_t x10, x11, x20, x21; /* Temporary input variables */ + q15_t y10, y11; /* Temporary input variables */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* pointer to take end of scratch2 buffer */ + pScr2 = pScratch2; + + /* points to smaller length sequence */ + px = pIn2 + srcBLen - 1; + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + x4 = (q15_t) * px--; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * px--; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* Initialze temporary scratch pointer */ + pScr1 = pScratch1; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy (srcALen) samples in scratch buffer */ + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + k = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = (srcBLen - 1U) % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + + /* Temporary pointer for scratch2 */ + py = pScratch2; + + /* Initialization of pIn2 pointer */ + pIn2 = (q7_t *) py; + + pScr2 = py; + + pOut = pDst + firstIndex; + + pScratch1 += firstIndex; + + /* Actual convolution process starts here */ + blkCnt = (numPoints) >> 2; + + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x10 = *pScr1++; + x11 = *pScr1++; + + /* Read next two samples from scratch1 buffer */ + x20 = *pScr1++; + x21 = *pScr1++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read four samples from smaller buffer */ + y10 = *pScr2; + y11 = *(pScr2 + 1U); + + /* multiply and accumlate */ + acc0 += (q31_t) x10 *y10; + acc0 += (q31_t) x11 *y11; + acc2 += (q31_t) x20 *y10; + acc2 += (q31_t) x21 *y11; + + + acc1 += (q31_t) x11 *y10; + acc1 += (q31_t) x20 *y11; + + /* Read next two samples from scratch1 buffer */ + x10 = *pScr1; + x11 = *(pScr1 + 1U); + + /* multiply and accumlate */ + acc3 += (q31_t) x21 *y10; + acc3 += (q31_t) x10 *y11; + + /* Read next two samples from scratch2 buffer */ + y10 = *(pScr2 + 2U); + y11 = *(pScr2 + 3U); + + /* multiply and accumlate */ + acc0 += (q31_t) x20 *y10; + acc0 += (q31_t) x21 *y11; + acc2 += (q31_t) x10 *y10; + acc2 += (q31_t) x11 *y11; + acc1 += (q31_t) x21 *y10; + acc1 += (q31_t) x10 *y11; + + /* Read next two samples from scratch1 buffer */ + x20 = *(pScr1 + 2); + x21 = *(pScr1 + 3); + + /* multiply and accumlate */ + acc3 += (q31_t) x11 *y10; + acc3 += (q31_t) x20 *y11; + + /* update scratch pointers */ + + pScr1 += 4U; + pScr2 += 4U; + + /* Decrement the loop counter */ + tapCnt--; + } + + + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2); + acc1 += (*pScr1++ * *pScr2); + acc2 += (*pScr1++ * *pScr2); + acc3 += (*pScr1++ * *pScr2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(acc0 >> 7U, 8)); + *pOut++ = (q7_t) (__SSAT(acc1 >> 7U, 8)); + *pOut++ = (q7_t) (__SSAT(acc2 >> 7U, 8)); + *pOut++ = (q7_t) (__SSAT(acc3 >> 7U, 8)); + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 4U; + + } + + blkCnt = (numPoints) & 0x3; + + /* Calculate convolution for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + /* Read next two samples from scratch1 buffer */ + x10 = *pScr1++; + x11 = *pScr1++; + + /* Read two samples from smaller buffer */ + y10 = *pScr2++; + y11 = *pScr2++; + + /* multiply and accumlate */ + acc0 += (q31_t) x10 *y10; + acc0 += (q31_t) x11 *y11; + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(acc0 >> 7U, 8)); + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 1U; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + } + + return (status); + +} + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q15.c new file mode 100644 index 0000000..43d2b35 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q15.c @@ -0,0 +1,795 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_q15.c + * Description: Partial convolution of Q15 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q15 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * Refer to arm_conv_partial_fast_q15() for a faster but less precise version of this function for Cortex-M3 and Cortex-M4. + * + * \par + * Refer the function arm_conv_partial_opt_q15() for a faster implementation of this function using scratch buffers. + * + */ + +arm_status arm_conv_partial_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + + +#if (defined(ARM_MATH_CM7) || defined(ARM_MATH_CM4) || defined(ARM_MATH_CM3)) && !defined(UNALIGNED_SUPPORT_DISABLE) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q63_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; /* Temporary input variables */ + uint32_t j, k, count, check, blkCnt; + int32_t blockSize1, blockSize2, blockSize3; /* loop counter */ + arm_status status; /* status of Partial convolution */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Conditions to check which loopCounter holds + * the first and last indices of the output samples to be calculated. */ + check = firstIndex + numPoints; + blockSize3 = ((int32_t)check > (int32_t)srcALen) ? (int32_t)check - (int32_t)srcALen : 0; + blockSize3 = ((int32_t)firstIndex > (int32_t)srcALen - 1) ? blockSize3 - (int32_t)firstIndex + (int32_t)srcALen : blockSize3; + blockSize1 = (((int32_t) srcBLen - 1) - (int32_t) firstIndex); + blockSize1 = (blockSize1 > 0) ? ((check > (srcBLen - 1U)) ? blockSize1 : + (int32_t) numPoints) : 0; + blockSize2 = (int32_t) check - ((blockSize3 + blockSize1) + + (int32_t) firstIndex); + blockSize2 = (blockSize2 > 0) ? blockSize2 : 0; + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* Set the output pointer to point to the firstIndex + * of the output sample to be calculated. */ + pOut = pDst + firstIndex; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed. + Since the partial convolution starts from firstIndex + Number of Macs to be performed is firstIndex + 1 */ + count = 1U + firstIndex; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + firstIndex; + py = pSrc2; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations less than 4 */ + /* Second part of this stage computes the MAC operations greater than or equal to 4 */ + + /* The first part of the stage starts here */ + while ((count < 4U) && (blockSize1 > 0)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over number of MAC operations between + * inputA samples and inputB samples */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* The second part of the stage starts here */ + /* The internal loop, over count, is unrolled by 4 */ + /* To, read the last two inputB samples using SIMD: + * y[srcBLen] and y[srcBLen-1] coefficients, py is decremented by 1 */ + py = py - 1; + + while (blockSize1 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0], x[1] are multiplied with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[2], x[3] are multiplied with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2 - 1U; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1; + } + else + { + px = pIn1; + } + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is the index by which the pointer pIn1 to be incremented */ + count = 0U; + + + /* -------------------- + * Stage2 process + * -------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + py = py - 1U; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + + /* read x[0], x[1] samples */ + x0 = *__SIMD32(px); + /* read x[1], x[2] samples */ + x1 = _SIMD32_OFFSET(px+1); + px+= 2U; + + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the last two inputB samples using SIMD: + * y[srcBLen - 1] and y[srcBLen - 2] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLALDX(x0, c0, acc0); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLALDX(x1, c0, acc1); + + /* Read x[2], x[3] */ + x2 = *__SIMD32(px); + + /* Read x[3], x[4] */ + x3 = _SIMD32_OFFSET(px+1); + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLALDX(x2, c0, acc2); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLALDX(x3, c0, acc3); + + /* Read y[srcBLen - 3] and y[srcBLen - 4] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLALDX(x2, c0, acc0); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLALDX(x3, c0, acc1); + + /* Read x[4], x[5] */ + x0 = _SIMD32_OFFSET(px+2); + + /* Read x[5], x[6] */ + x1 = _SIMD32_OFFSET(px+3); + px += 4U; + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLALDX(x0, c0, acc2); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLALDX(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[srcBLen - 5] */ + c0 = *(py+1); + +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7] */ + x3 = *__SIMD32(px); + px++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALD(x0, c0, acc0); + acc1 = __SMLALD(x1, c0, acc1); + acc2 = __SMLALDX(x1, c0, acc2); + acc3 = __SMLALDX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALDX(x0, c0, acc0); + acc1 = __SMLALDX(x1, c0, acc1); + acc2 = __SMLALDX(x3, c0, acc2); + acc3 = __SMLALDX(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + + /* Perform the multiply-accumulates */ + acc0 = __SMLALDX(x0, c0, acc0); + acc1 = __SMLALDX(x1, c0, acc1); + acc2 = __SMLALDX(x3, c0, acc2); + acc3 = __SMLALDX(x2, c0, acc3); + + c0 = *(py-1); + +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[10] */ + x3 = _SIMD32_OFFSET(px+2); + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALDX(x1, c0, acc0); + acc1 = __SMLALD(x2, c0, acc1); + acc2 = __SMLALDX(x2, c0, acc2); + acc3 = __SMLALDX(x3, c0, acc3); + } + + + /* Store the results in the accumulators in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = (uint32_t) blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) ((q31_t) * px++ * *py--); + sum += (q63_t) ((q31_t) * px++ * *py--); + sum += (q63_t) ((q31_t) * px++ * *py--); + sum += (q63_t) ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT(sum >> 15, 16)); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = (uint32_t) blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT(sum >> 15, 16)); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + pIn2 = pSrc2 - 1U; + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations greater than 4 */ + /* Second part of this stage computes the MAC operations less than or equal to 4 */ + + /* The first part of the stage starts here */ + j = count >> 2U; + + while ((j > 0U) && (blockSize3 > 0)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[srcALen - srcBLen + 1], x[srcALen - srcBLen + 2] are multiplied + * with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[srcALen - srcBLen + 3], x[srcALen - srcBLen + 4] are multiplied + * with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 5] * y[srcBLen - 5] */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + + j--; + } + + /* The second part of the stage starts here */ + /* SIMD is not used for the next MAC operations, + * so pointer py is updated to read only one sample at a time */ + py = py + 1U; + + while (blockSize3 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); + +#else + + /* Run the below code for Cortex-M0 */ + + q15_t *pIn1 = pSrcA; /* inputA pointer */ + q15_t *pIn2 = pSrcB; /* inputB pointer */ + q63_t sum; /* Accumulator */ + uint32_t i, j; /* loop counters */ + arm_status status; /* status of Partial convolution */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + /* Loop to calculate convolution for output length number of values */ + for (i = firstIndex; i <= (firstIndex + numPoints - 1); i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if (((i - j) < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q31_t) pIn1[j] * (pIn2[i - j])); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q15_t) __SSAT((sum >> 15U), 16U); + } + /* set status as ARM_SUCCESS as there are no argument errors */ + status = ARM_MATH_SUCCESS; + } + return (status); + +#endif /* #if (defined(ARM_MATH_CM7) || defined(ARM_MATH_CM4) || defined(ARM_MATH_CM3)) && !defined(UNALIGNED_SUPPORT_DISABLE) */ + +} + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q31.c new file mode 100644 index 0000000..3a108e0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q31.c @@ -0,0 +1,616 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_q31.c + * Description: Partial convolution of Q31 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q31 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * See arm_conv_partial_fast_q31() for a faster but less precise implementation of this function for Cortex-M3 and Cortex-M4. + */ + +arm_status arm_conv_partial_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t *pIn1; /* inputA pointer */ + q31_t *pIn2; /* inputB pointer */ + q31_t *pOut = pDst; /* output pointer */ + q31_t *px; /* Intermediate inputA pointer */ + q31_t *py; /* Intermediate inputB pointer */ + q31_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q63_t sum, acc0, acc1, acc2; /* Accumulator */ + q31_t x0, x1, x2, c0; + uint32_t j, k, count, check, blkCnt; + int32_t blockSize1, blockSize2, blockSize3; /* loop counter */ + arm_status status; /* status of Partial convolution */ + + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Conditions to check which loopCounter holds + * the first and last indices of the output samples to be calculated. */ + check = firstIndex + numPoints; + blockSize3 = ((int32_t)check > (int32_t)srcALen) ? (int32_t)check - (int32_t)srcALen : 0; + blockSize3 = ((int32_t)firstIndex > (int32_t)srcALen - 1) ? blockSize3 - (int32_t)firstIndex + (int32_t)srcALen : blockSize3; + blockSize1 = (((int32_t) srcBLen - 1) - (int32_t) firstIndex); + blockSize1 = (blockSize1 > 0) ? ((check > (srcBLen - 1U)) ? blockSize1 : + (int32_t) numPoints) : 0; + blockSize2 = (int32_t) check - ((blockSize3 + blockSize1) + + (int32_t) firstIndex); + blockSize2 = (blockSize2 > 0) ? blockSize2 : 0; + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* Set the output pointer to point to the firstIndex + * of the output sample to be calculated. */ + pOut = pDst + firstIndex; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed. + Since the partial convolution starts from firstIndex + Number of Macs to be performed is firstIndex + 1 */ + count = 1U + firstIndex; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + firstIndex; + py = pSrc2; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first loop starts here */ + while (blockSize1 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 1] */ + sum += (q63_t) * px++ * (*py--); + /* x[1] * y[srcBLen - 2] */ + sum += (q63_t) * px++ * (*py--); + /* x[2] * y[srcBLen - 3] */ + sum += (q63_t) * px++ * (*py--); + /* x[3] * y[srcBLen - 4] */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1; + } + else + { + px = pIn1; + } + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blkCnt */ + + blkCnt = blockSize2 / 3; + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + + /* read x[0], x[1] samples */ + x0 = *(px++); + x1 = *(px++); + + /* Apply loop unrolling and compute 3 MACs simultaneously. */ + k = srcBLen / 3; + + /* First part of the processing with loop unrolling. Compute 3 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 2 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py); + + /* Read x[2] sample */ + x2 = *(px); + + /* Perform the multiply-accumulates */ + /* acc0 += x[0] * y[srcBLen - 1] */ + acc0 += (q63_t) x0 *c0; + /* acc1 += x[1] * y[srcBLen - 1] */ + acc1 += (q63_t) x1 *c0; + /* acc2 += x[2] * y[srcBLen - 1] */ + acc2 += (q63_t) x2 *c0; + + /* Read y[srcBLen - 2] sample */ + c0 = *(py - 1U); + + /* Read x[3] sample */ + x0 = *(px + 1U); + + /* Perform the multiply-accumulate */ + /* acc0 += x[1] * y[srcBLen - 2] */ + acc0 += (q63_t) x1 *c0; + /* acc1 += x[2] * y[srcBLen - 2] */ + acc1 += (q63_t) x2 *c0; + /* acc2 += x[3] * y[srcBLen - 2] */ + acc2 += (q63_t) x0 *c0; + + /* Read y[srcBLen - 3] sample */ + c0 = *(py - 2U); + + /* Read x[4] sample */ + x1 = *(px + 2U); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[srcBLen - 3] */ + acc0 += (q63_t) x2 *c0; + /* acc1 += x[3] * y[srcBLen - 2] */ + acc1 += (q63_t) x0 *c0; + /* acc2 += x[4] * y[srcBLen - 2] */ + acc2 += (q63_t) x1 *c0; + + + px += 3U; + + py -= 3U; + + } while (--k); + + /* If the srcBLen is not a multiple of 3, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen - (3 * (srcBLen / 3)); + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 += (q63_t) x0 *c0; + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 += (q63_t) x1 *c0; + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 += (q63_t) x2 *c0; + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (acc0 >> 31); + *pOut++ = (q31_t) (acc1 >> 31); + *pOut++ = (q31_t) (acc2 >> 31); + + /* Increment the pointer pIn1 index, count by 3 */ + count += 3U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 3, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 - 3 * (blockSize2 / 3); + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = (uint32_t) blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); + +#else + + /* Run the below code for Cortex-M0 */ + + q31_t *pIn1 = pSrcA; /* inputA pointer */ + q31_t *pIn2 = pSrcB; /* inputB pointer */ + q63_t sum; /* Accumulator */ + uint32_t i, j; /* loop counters */ + arm_status status; /* status of Partial convolution */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + /* Loop to calculate convolution for output length number of values */ + for (i = firstIndex; i <= (firstIndex + numPoints - 1); i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if (((i - j) < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q63_t) pIn1[j] * (pIn2[i - j])); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q31_t) (sum >> 31U); + } + /* set status as ARM_SUCCESS as there are no argument errors */ + status = ARM_MATH_SUCCESS; + } + return (status); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q7.c new file mode 100644 index 0000000..cb4c562 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_partial_q7.c @@ -0,0 +1,750 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_partial_q7.c + * Description: Partial convolution of Q7 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup PartialConv + * @{ + */ + +/** + * @brief Partial convolution of Q7 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] firstIndex is the first output sample to start with. + * @param[in] numPoints is the number of output points to be computed. + * @return Returns either ARM_MATH_SUCCESS if the function completed correctly or ARM_MATH_ARGUMENT_ERROR if the requested subset is not in the range [0 srcALen+srcBLen-2]. + * + * \par + * Refer the function arm_conv_partial_opt_q7() for a faster implementation of this function. + * + */ + +arm_status arm_conv_partial_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + uint32_t firstIndex, + uint32_t numPoints) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q7_t *pIn1; /* inputA pointer */ + q7_t *pIn2; /* inputB pointer */ + q7_t *pOut = pDst; /* output pointer */ + q7_t *px; /* Intermediate inputA pointer */ + q7_t *py; /* Intermediate inputB pointer */ + q7_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t input1, input2; + q15_t in1, in2; + q7_t x0, x1, x2, x3, c0, c1; + uint32_t j, k, count, check, blkCnt; + int32_t blockSize1, blockSize2, blockSize3; /* loop counter */ + arm_status status; + + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_MATH_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* Conditions to check which loopCounter holds + * the first and last indices of the output samples to be calculated. */ + check = firstIndex + numPoints; + blockSize3 = ((int32_t)check > (int32_t)srcALen) ? (int32_t)check - (int32_t)srcALen : 0; + blockSize3 = ((int32_t)firstIndex > (int32_t)srcALen - 1) ? blockSize3 - (int32_t)firstIndex + (int32_t)srcALen : blockSize3; + blockSize1 = (((int32_t) srcBLen - 1) - (int32_t) firstIndex); + blockSize1 = (blockSize1 > 0) ? ((check > (srcBLen - 1U)) ? blockSize1 : + (int32_t) numPoints) : 0; + blockSize2 = (int32_t) check - ((blockSize3 + blockSize1) + + (int32_t) firstIndex); + blockSize2 = (blockSize2 > 0) ? blockSize2 : 0; + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* Set the output pointer to point to the firstIndex + * of the output sample to be calculated. */ + pOut = pDst + firstIndex; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed. + Since the partial convolution starts from from firstIndex + Number of Macs to be performed is firstIndex + 1 */ + count = 1U + firstIndex; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + firstIndex; + py = pSrc2; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] , x[1] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[srcBLen - 1] , y[srcBLen - 2] */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* x[0] * y[srcBLen - 1] */ + /* x[1] * y[srcBLen - 2] */ + sum = __SMLAD(input1, input2, sum); + + /* x[2] , x[3] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[srcBLen - 3] , y[srcBLen - 4] */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* x[2] * y[srcBLen - 3] */ + /* x[3] * y[srcBLen - 4] */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7, 8)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = ++pSrc2; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1; + } + else + { + px = pIn1; + } + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = ((uint32_t) blockSize2 >> 2U); + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py--); + /* Read y[srcBLen - 2] sample */ + c1 = *(py--); + + /* Read x[3] sample */ + x3 = *(px++); + + /* x[0] and x[1] are packed */ + in1 = (q15_t) x0; + in2 = (q15_t) x1; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[srcBLen - 1] and y[srcBLen - 2] are packed */ + in1 = (q15_t) c0; + in2 = (q15_t) c1; + + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLAD(input1, input2, acc0); + + /* x[1] and x[2] are packed */ + in1 = (q15_t) x1; + in2 = (q15_t) x2; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLAD(input1, input2, acc1); + + /* x[2] and x[3] are packed */ + in1 = (q15_t) x2; + in2 = (q15_t) x3; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLAD(input1, input2, acc2); + + /* Read x[4] sample */ + x0 = *(px++); + + /* x[3] and x[4] are packed */ + in1 = (q15_t) x3; + in2 = (q15_t) x0; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLAD(input1, input2, acc3); + + /* Read y[srcBLen - 3] sample */ + c0 = *(py--); + /* Read y[srcBLen - 4] sample */ + c1 = *(py--); + + /* Read x[5] sample */ + x1 = *(px++); + + /* x[2] and x[3] are packed */ + in1 = (q15_t) x2; + in2 = (q15_t) x3; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[srcBLen - 3] and y[srcBLen - 4] are packed */ + in1 = (q15_t) c0; + in2 = (q15_t) c1; + + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLAD(input1, input2, acc0); + + /* x[3] and x[4] are packed */ + in1 = (q15_t) x3; + in2 = (q15_t) x0; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLAD(input1, input2, acc1); + + /* x[4] and x[5] are packed */ + in1 = (q15_t) x0; + in2 = (q15_t) x1; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLAD(input1, input2, acc2); + + /* Read x[6] sample */ + x2 = *(px++); + + /* x[5] and x[6] are packed */ + in1 = (q15_t) x1; + in2 = (q15_t) x2; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLAD(input1, input2, acc3); + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 += ((q31_t) x0 * c0); + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 += ((q31_t) x1 * c0); + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 += ((q31_t) x2 * c0); + /* acc3 += x[7] * y[srcBLen - 5] */ + acc3 += ((q31_t) x3 * c0); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(acc0 >> 7, 8)); + *pOut++ = (q7_t) (__SSAT(acc1 >> 7, 8)); + *pOut++ = (q7_t) (__SSAT(acc2 >> 7, 8)); + *pOut++ = (q7_t) (__SSAT(acc3 >> 7, 8)); + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = (uint32_t) blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + + /* Reading two inputs of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Reading two inputs of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Perform the multiply-accumulates */ + sum = __SMLAD(input1, input2, sum); + + /* Reading two inputs of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Reading two inputs of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Perform the multiply-accumulates */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7, 8)); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = (uint32_t) blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7, 8)); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + if ((int32_t)firstIndex - (int32_t)srcBLen + 1 > 0) + { + px = pIn1 + firstIndex - srcBLen + 1 + count; + } + else + { + px = pIn1 + count; + } + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Reading two inputs, x[srcALen - srcBLen + 1] and x[srcALen - srcBLen + 2] of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Reading two inputs, y[srcBLen - 1] and y[srcBLen - 2] of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* sum += x[srcALen - srcBLen + 1] * y[srcBLen - 1] */ + /* sum += x[srcALen - srcBLen + 2] * y[srcBLen - 2] */ + sum = __SMLAD(input1, input2, sum); + + /* Reading two inputs, x[srcALen - srcBLen + 3] and x[srcALen - srcBLen + 4] of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Reading two inputs, y[srcBLen - 3] and y[srcBLen - 4] of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* sum += x[srcALen - srcBLen + 3] * y[srcBLen - 3] */ + /* sum += x[srcALen - srcBLen + 4] * y[srcBLen - 4] */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum += ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7, 8)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); + +#else + + /* Run the below code for Cortex-M0 */ + + q7_t *pIn1 = pSrcA; /* inputA pointer */ + q7_t *pIn2 = pSrcB; /* inputB pointer */ + q31_t sum; /* Accumulator */ + uint32_t i, j; /* loop counters */ + arm_status status; /* status of Partial convolution */ + + /* Check for range of output samples to be calculated */ + if ((firstIndex + numPoints) > ((srcALen + (srcBLen - 1U)))) + { + /* Set status as ARM_ARGUMENT_ERROR */ + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + /* Loop to calculate convolution for output length number of values */ + for (i = firstIndex; i <= (firstIndex + numPoints - 1); i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if (((i - j) < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q15_t) pIn1[j] * (pIn2[i - j])); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q7_t) __SSAT((sum >> 7U), 8U); + } + /* set status as ARM_SUCCESS as there are no argument errors */ + status = ARM_MATH_SUCCESS; + } + return (status); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of PartialConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q15.c new file mode 100644 index 0000000..c6721e0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q15.c @@ -0,0 +1,722 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_q15.c + * Description: Convolution of Q15 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of Q15 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both inputs are in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * This approach provides 33 guard bits and there is no risk of overflow. + * The 34.30 result is then truncated to 34.15 format by discarding the low 15 bits and then saturated to 1.15 format. + * + * \par + * Refer to arm_conv_fast_q15() for a faster but less precise version of this function for Cortex-M3 and Cortex-M4. + * + * \par + * Refer the function arm_conv_opt_q15() for a faster implementation of this function using scratch buffers. + * + */ + +void arm_conv_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ + +#if (defined(ARM_MATH_CM7) || defined(ARM_MATH_CM4) || defined(ARM_MATH_CM3)) && !defined(UNALIGNED_SUPPORT_DISABLE) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q63_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t blockSize1, blockSize2, blockSize3, j, k, count, blkCnt; /* loop counter */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* The algorithm is implemented in three stages. + The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations less than 4 */ + /* Second part of this stage computes the MAC operations greater than or equal to 4 */ + + /* The first part of the stage starts here */ + while ((count < 4U) && (blockSize1 > 0U)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over number of MAC operations between + * inputA samples and inputB samples */ + k = count; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* The second part of the stage starts here */ + /* The internal loop, over count, is unrolled by 4 */ + /* To, read the last two inputB samples using SIMD: + * y[srcBLen] and y[srcBLen-1] coefficients, py is decremented by 1 */ + py = py - 1; + + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0], x[1] are multiplied with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[2], x[3] are multiplied with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + (count - 1U); + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is the index by which the pointer pIn1 to be incremented */ + count = 0U; + + + /* -------------------- + * Stage2 process + * -------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + py = py - 1U; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + + /* read x[0], x[1] samples */ + x0 = *__SIMD32(px); + /* read x[1], x[2] samples */ + x1 = _SIMD32_OFFSET(px+1); + px+= 2U; + + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the last two inputB samples using SIMD: + * y[srcBLen - 1] and y[srcBLen - 2] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLALDX(x0, c0, acc0); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLALDX(x1, c0, acc1); + + /* Read x[2], x[3] */ + x2 = *__SIMD32(px); + + /* Read x[3], x[4] */ + x3 = _SIMD32_OFFSET(px+1); + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLALDX(x2, c0, acc2); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLALDX(x3, c0, acc3); + + /* Read y[srcBLen - 3] and y[srcBLen - 4] */ + c0 = *__SIMD32(py)--; + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLALDX(x2, c0, acc0); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLALDX(x3, c0, acc1); + + /* Read x[4], x[5] */ + x0 = _SIMD32_OFFSET(px+2); + + /* Read x[5], x[6] */ + x1 = _SIMD32_OFFSET(px+3); + px += 4U; + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLALDX(x0, c0, acc2); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLALDX(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[srcBLen - 5] */ + c0 = *(py+1); + +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + /* Read x[7] */ + x3 = *__SIMD32(px); + px++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALD(x0, c0, acc0); + acc1 = __SMLALD(x1, c0, acc1); + acc2 = __SMLALDX(x1, c0, acc2); + acc3 = __SMLALDX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALDX(x0, c0, acc0); + acc1 = __SMLALDX(x1, c0, acc1); + acc2 = __SMLALDX(x3, c0, acc2); + acc3 = __SMLALDX(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[srcBLen - 5], y[srcBLen - 6] */ + c0 = _SIMD32_OFFSET(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px+1); + + /* Perform the multiply-accumulates */ + acc0 = __SMLALDX(x0, c0, acc0); + acc1 = __SMLALDX(x1, c0, acc1); + acc2 = __SMLALDX(x3, c0, acc2); + acc3 = __SMLALDX(x2, c0, acc3); + + c0 = *(py-1); + +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + /* Read x[10] */ + x3 = _SIMD32_OFFSET(px+2); + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALDX(x1, c0, acc0); + acc1 = __SMLALD(x2, c0, acc1); + acc2 = __SMLALDX(x2, c0, acc2); + acc3 = __SMLALDX(x3, c0, acc3); + } + + + /* Store the results in the accumulators in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + *__SIMD32(pOut)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) ((q31_t) * px++ * *py--); + sum += (q63_t) ((q31_t) * px++ * *py--); + sum += (q63_t) ((q31_t) * px++ * *py--); + sum += (q63_t) ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT(sum >> 15, 16)); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) ((q31_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT(sum >> 15, 16)); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + + blockSize3 = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + pIn2 = pSrc2 - 1U; + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + /* For loop unrolling by 4, this stage is divided into two. */ + /* First part of this stage computes the MAC operations greater than 4 */ + /* Second part of this stage computes the MAC operations less than or equal to 4 */ + + /* The first part of the stage starts here */ + j = blockSize3 >> 2U; + + while ((j > 0U) && (blockSize3 > 0U)) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[srcALen - srcBLen + 1], x[srcALen - srcBLen + 2] are multiplied + * with y[srcBLen - 1], y[srcBLen - 2] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + /* x[srcALen - srcBLen + 3], x[srcALen - srcBLen + 4] are multiplied + * with y[srcBLen - 3], y[srcBLen - 4] respectively */ + sum = __SMLALDX(*__SIMD32(px)++, *__SIMD32(py)--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* For the next MAC operations, the pointer py is used without SIMD + * So, py is incremented by 1 */ + py = py + 1U; + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = blockSize3 % 0x4U; + + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 5] * y[srcBLen - 5] */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the loop counter */ + blockSize3--; + + j--; + } + + /* The second part of the stage starts here */ + /* SIMD is not used for the next MAC operations, + * so pointer py is updated to read only one sample at a time */ + py = py + 1U; + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen-1] * y[srcBLen-1] */ + sum = __SMLALD(*px++, *py--, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + q15_t *pIn1 = pSrcA; /* input pointer */ + q15_t *pIn2 = pSrcB; /* coefficient pointer */ + q63_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < (srcALen + srcBLen - 1); i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if (((i - j) < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q31_t) pIn1[j] * (pIn2[i - j]); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q15_t) __SSAT((sum >> 15U), 16U); + } + +#endif /* #if (defined(ARM_MATH_CM7) || defined(ARM_MATH_CM4) || defined(ARM_MATH_CM3)) && !defined(UNALIGNED_SUPPORT_DISABLE) */ + +} + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q31.c new file mode 100644 index 0000000..14e5f86 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q31.c @@ -0,0 +1,553 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_q31.c + * Description: Convolution of Q31 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of Q31 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * There is no saturation on intermediate additions. + * Thus, if the accumulator overflows it wraps around and distorts the result. + * The input signals should be scaled down to avoid intermediate overflows. + * Scale down the inputs by log2(min(srcALen, srcBLen)) (log2 is read as log to the base 2) times to avoid overflows, + * as maximum of min(srcALen, srcBLen) number of additions are carried internally. + * The 2.62 accumulator is right shifted by 31 bits and saturated to 1.31 format to yield the final result. + * + * \par + * See arm_conv_fast_q31() for a faster but less precise implementation of this function for Cortex-M3 and Cortex-M4. + */ + +void arm_conv_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t *pIn1; /* inputA pointer */ + q31_t *pIn2; /* inputB pointer */ + q31_t *pOut = pDst; /* output pointer */ + q31_t *px; /* Intermediate inputA pointer */ + q31_t *py; /* Intermediate inputB pointer */ + q31_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q63_t sum; /* Accumulator */ + q63_t acc0, acc1, acc2; /* Accumulator */ + q31_t x0, x1, x2, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t j, k, count, blkCnt, blockSize1, blockSize2, blockSize3; /* loop counter */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (q31_t *) pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = (q31_t *) pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* The algorithm is implemented in three stages. + The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 1] */ + sum += (q63_t) * px++ * (*py--); + /* x[1] * y[srcBLen - 2] */ + sum += (q63_t) * px++ * (*py--); + /* x[2] * y[srcBLen - 3] */ + sum += (q63_t) * px++ * (*py--); + /* x[3] * y[srcBLen - 4] */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll by 3 */ + blkCnt = blockSize2 / 3; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + + /* Apply loop unrolling and compute 3 MACs simultaneously. */ + k = srcBLen / 3; + + /* First part of the processing with loop unrolling. Compute 3 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 2 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py); + + /* Read x[3] sample */ + x2 = *(px); + + /* Perform the multiply-accumulates */ + /* acc0 += x[0] * y[srcBLen - 1] */ + acc0 += ((q63_t) x0 * c0); + /* acc1 += x[1] * y[srcBLen - 1] */ + acc1 += ((q63_t) x1 * c0); + /* acc2 += x[2] * y[srcBLen - 1] */ + acc2 += ((q63_t) x2 * c0); + + /* Read y[srcBLen - 2] sample */ + c0 = *(py - 1U); + + /* Read x[4] sample */ + x0 = *(px + 1U); + + /* Perform the multiply-accumulate */ + /* acc0 += x[1] * y[srcBLen - 2] */ + acc0 += ((q63_t) x1 * c0); + /* acc1 += x[2] * y[srcBLen - 2] */ + acc1 += ((q63_t) x2 * c0); + /* acc2 += x[3] * y[srcBLen - 2] */ + acc2 += ((q63_t) x0 * c0); + + /* Read y[srcBLen - 3] sample */ + c0 = *(py - 2U); + + /* Read x[5] sample */ + x1 = *(px + 2U); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[srcBLen - 3] */ + acc0 += ((q63_t) x2 * c0); + /* acc1 += x[3] * y[srcBLen - 2] */ + acc1 += ((q63_t) x0 * c0); + /* acc2 += x[4] * y[srcBLen - 2] */ + acc2 += ((q63_t) x1 * c0); + + /* update scratch pointers */ + px += 3U; + py -= 3U; + + } while (--k); + + /* If the srcBLen is not a multiple of 3, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen - (3 * (srcBLen / 3)); + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 += ((q63_t) x0 * c0); + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 += ((q63_t) x1 * c0); + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 += ((q63_t) x2 * c0); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + + /* Decrement the loop counter */ + k--; + } + + /* Store the results in the accumulators in the destination buffer. */ + *pOut++ = (q31_t) (acc0 >> 31); + *pOut++ = (q31_t) (acc1 >> 31); + *pOut++ = (q31_t) (acc2 >> 31); + + /* Increment the pointer pIn1 index, count by 3 */ + count += 3U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 3, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 - 3 * (blockSize2 / 3); + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* sum += x[srcALen - srcBLen + 1] * y[srcBLen - 1] */ + sum += (q63_t) * px++ * (*py--); + /* sum += x[srcALen - srcBLen + 2] * y[srcBLen - 2] */ + sum += (q63_t) * px++ * (*py--); + /* sum += x[srcALen - srcBLen + 3] * y[srcBLen - 3] */ + sum += (q63_t) * px++ * (*py--); + /* sum += x[srcALen - srcBLen + 4] * y[srcBLen - 4] */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = blockSize3 % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q31_t) (sum >> 31); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + q31_t *pIn1 = pSrcA; /* input pointer */ + q31_t *pIn2 = pSrcB; /* coefficient pointer */ + q63_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < (srcALen + srcBLen - 1); i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if (((i - j) < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q63_t) pIn1[j] * (pIn2[i - j])); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q31_t) (sum >> 31U); + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q7.c new file mode 100644 index 0000000..6c4dd3c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_conv_q7.c @@ -0,0 +1,678 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_conv_q7.c + * Description: Convolution of Q7 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Conv + * @{ + */ + +/** + * @brief Convolution of Q7 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length srcALen+srcBLen-1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 32-bit internal accumulator. + * Both the inputs are represented in 1.7 format and multiplications yield a 2.14 result. + * The 2.14 intermediate results are accumulated in a 32-bit accumulator in 18.14 format. + * This approach provides 17 guard bits and there is no risk of overflow as long as max(srcALen, srcBLen)<131072. + * The 18.14 result is then truncated to 18.7 format by discarding the low 7 bits and then saturated to 1.7 format. + * + * \par + * Refer the function arm_conv_opt_q7() for a faster implementation of this function. + * + */ + +void arm_conv_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q7_t *pIn1; /* inputA pointer */ + q7_t *pIn2; /* inputB pointer */ + q7_t *pOut = pDst; /* output pointer */ + q7_t *px; /* Intermediate inputA pointer */ + q7_t *py; /* Intermediate inputB pointer */ + q7_t *pSrc1, *pSrc2; /* Intermediate pointers */ + q7_t x0, x1, x2, x3, c0, c1; /* Temporary variables to hold state and coefficient values */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulator */ + q31_t input1, input2; /* Temporary input variables */ + q15_t in1, in2; /* Temporary input variables */ + uint32_t j, k, count, blkCnt, blockSize1, blockSize2, blockSize3; /* loop counter */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + } + + /* conv(x,y) at n = x[n] * y[0] + x[n-1] * y[1] + x[n-2] * y[2] + ...+ x[n-N+1] * y[N -1] */ + /* The function is internally + * divided into three stages according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first stage of the + * algorithm, the multiplications increase by one for every iteration. + * In the second stage of the algorithm, srcBLen number of multiplications are done. + * In the third stage of the algorithm, the multiplications decrease by one + * for every iteration. */ + + /* The algorithm is implemented in three stages. + The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = (srcALen - srcBLen) + 1U; + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[0] + * sum = x[0] * y[1] + x[1] * y[0] + * .... + * sum = x[0] * y[srcBlen - 1] + x[1] * y[srcBlen - 2] +...+ x[srcBLen - 1] * y[0] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] , x[1] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* y[srcBLen - 1] , y[srcBLen - 2] */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* x[0] * y[srcBLen - 1] */ + /* x[1] * y[srcBLen - 2] */ + sum = __SMLAD(input1, input2, sum); + + /* x[2] , x[3] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* y[srcBLen - 3] , y[srcBLen - 4] */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* x[2] * y[srcBLen - 3] */ + /* x[3] * y[srcBLen - 4] */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q15_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7U, 8)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pIn2 + count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[srcBLen-1] + x[1] * y[srcBLen-2] +...+ x[srcBLen-1] * y[0] + * sum = x[1] * y[srcBLen-1] + x[2] * y[srcBLen-2] +...+ x[srcBLen] * y[0] + * .... + * sum = x[srcALen-srcBLen-2] * y[srcBLen-1] + x[srcALen] * y[srcBLen-2] +...+ x[srcALen-1] * y[0] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[srcBLen - 1] sample */ + c0 = *(py--); + /* Read y[srcBLen - 2] sample */ + c1 = *(py--); + + /* Read x[3] sample */ + x3 = *(px++); + + /* x[0] and x[1] are packed */ + in1 = (q15_t) x0; + in2 = (q15_t) x1; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* y[srcBLen - 1] and y[srcBLen - 2] are packed */ + in1 = (q15_t) c0; + in2 = (q15_t) c1; + + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc0 += x[0] * y[srcBLen - 1] + x[1] * y[srcBLen - 2] */ + acc0 = __SMLAD(input1, input2, acc0); + + /* x[1] and x[2] are packed */ + in1 = (q15_t) x1; + in2 = (q15_t) x2; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc1 += x[1] * y[srcBLen - 1] + x[2] * y[srcBLen - 2] */ + acc1 = __SMLAD(input1, input2, acc1); + + /* x[2] and x[3] are packed */ + in1 = (q15_t) x2; + in2 = (q15_t) x3; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc2 += x[2] * y[srcBLen - 1] + x[3] * y[srcBLen - 2] */ + acc2 = __SMLAD(input1, input2, acc2); + + /* Read x[4] sample */ + x0 = *(px++); + + /* x[3] and x[4] are packed */ + in1 = (q15_t) x3; + in2 = (q15_t) x0; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc3 += x[3] * y[srcBLen - 1] + x[4] * y[srcBLen - 2] */ + acc3 = __SMLAD(input1, input2, acc3); + + /* Read y[srcBLen - 3] sample */ + c0 = *(py--); + /* Read y[srcBLen - 4] sample */ + c1 = *(py--); + + /* Read x[5] sample */ + x1 = *(px++); + + /* x[2] and x[3] are packed */ + in1 = (q15_t) x2; + in2 = (q15_t) x3; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* y[srcBLen - 3] and y[srcBLen - 4] are packed */ + in1 = (q15_t) c0; + in2 = (q15_t) c1; + + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc0 += x[2] * y[srcBLen - 3] + x[3] * y[srcBLen - 4] */ + acc0 = __SMLAD(input1, input2, acc0); + + /* x[3] and x[4] are packed */ + in1 = (q15_t) x3; + in2 = (q15_t) x0; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc1 += x[3] * y[srcBLen - 3] + x[4] * y[srcBLen - 4] */ + acc1 = __SMLAD(input1, input2, acc1); + + /* x[4] and x[5] are packed */ + in1 = (q15_t) x0; + in2 = (q15_t) x1; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc2 += x[4] * y[srcBLen - 3] + x[5] * y[srcBLen - 4] */ + acc2 = __SMLAD(input1, input2, acc2); + + /* Read x[6] sample */ + x2 = *(px++); + + /* x[5] and x[6] are packed */ + in1 = (q15_t) x1; + in2 = (q15_t) x2; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* acc3 += x[5] * y[srcBLen - 3] + x[6] * y[srcBLen - 4] */ + acc3 = __SMLAD(input1, input2, acc3); + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[srcBLen - 5] sample */ + c0 = *(py--); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[srcBLen - 5] */ + acc0 += ((q15_t) x0 * c0); + /* acc1 += x[5] * y[srcBLen - 5] */ + acc1 += ((q15_t) x1 * c0); + /* acc2 += x[6] * y[srcBLen - 5] */ + acc2 += ((q15_t) x2 * c0); + /* acc3 += x[7] * y[srcBLen - 5] */ + acc3 += ((q15_t) x3 * c0); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(acc0 >> 7U, 8)); + *pOut++ = (q7_t) (__SSAT(acc1 >> 7U, 8)); + *pOut++ = (q7_t) (__SSAT(acc2 >> 7U, 8)); + *pOut++ = (q7_t) (__SSAT(acc3 >> 7U, 8)); + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + + /* Reading two inputs of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* Reading two inputs of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* Perform the multiply-accumulates */ + sum = __SMLAD(input1, input2, sum); + + /* Reading two inputs of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* Reading two inputs of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* Perform the multiply-accumulates */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q15_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7U, 8)); + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* srcBLen number of MACS should be performed */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q15_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7U, 8)); + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pSrc2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[srcBLen-1] + x[srcALen-srcBLen+2] * y[srcBLen-2] +...+ x[srcALen-1] * y[1] + * sum += x[srcALen-srcBLen+2] * y[srcBLen-1] + x[srcALen-srcBLen+3] * y[srcBLen-2] +...+ x[srcALen-1] * y[2] + * .... + * sum += x[srcALen-2] * y[srcBLen-1] + x[srcALen-1] * y[srcBLen-2] + * sum += x[srcALen-1] * y[srcBLen-1] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The blockSize3 variable holds the number of MAC operations performed */ + + /* Working pointer of inputA */ + pSrc1 = pIn1 + (srcALen - (srcBLen - 1U)); + px = pSrc1; + + /* Working pointer of inputB */ + pSrc2 = pIn2 + (srcBLen - 1U); + py = pSrc2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = blockSize3 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Reading two inputs, x[srcALen - srcBLen + 1] and x[srcALen - srcBLen + 2] of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* Reading two inputs, y[srcBLen - 1] and y[srcBLen - 2] of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* sum += x[srcALen - srcBLen + 1] * y[srcBLen - 1] */ + /* sum += x[srcALen - srcBLen + 2] * y[srcBLen - 2] */ + sum = __SMLAD(input1, input2, sum); + + /* Reading two inputs, x[srcALen - srcBLen + 3] and x[srcALen - srcBLen + 4] of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* Reading two inputs, y[srcBLen - 3] and y[srcBLen - 4] of SrcB buffer and packing */ + in1 = (q15_t) * py--; + in2 = (q15_t) * py--; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16U); + + /* sum += x[srcALen - srcBLen + 3] * y[srcBLen - 3] */ + /* sum += x[srcALen - srcBLen + 4] * y[srcBLen - 4] */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the blockSize3 is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = blockSize3 % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q15_t) * px++ * *py--); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut++ = (q7_t) (__SSAT(sum >> 7U, 8)); + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pSrc2; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + q7_t *pIn1 = pSrcA; /* input pointer */ + q7_t *pIn2 = pSrcB; /* coefficient pointer */ + q31_t sum; /* Accumulator */ + uint32_t i, j; /* loop counter */ + + /* Loop to calculate output of convolution for output length number of times */ + for (i = 0; i < (srcALen + srcBLen - 1); i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0; j <= i; j++) + { + /* Check the array limitations */ + if (((i - j) < srcBLen) && (j < srcALen)) + { + /* z[i] += x[i-j] * y[j] */ + sum += (q15_t) pIn1[j] * (pIn2[i - j]); + } + } + + /* Store the output in the destination buffer */ + pDst[i] = (q7_t) __SSAT((sum >> 7U), 8U); + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of Conv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_f32.c new file mode 100644 index 0000000..9451887 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_f32.c @@ -0,0 +1,727 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_f32.c + * Description: Correlation of floating-point sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup Corr Correlation + * + * Correlation is a mathematical operation that is similar to convolution. + * As with convolution, correlation uses two signals to produce a third signal. + * The underlying algorithms in correlation and convolution are identical except that one of the inputs is flipped in convolution. + * Correlation is commonly used to measure the similarity between two signals. + * It has applications in pattern recognition, cryptanalysis, and searching. + * The CMSIS library provides correlation functions for Q7, Q15, Q31 and floating-point data types. + * Fast versions of the Q15 and Q31 functions are also provided. + * + * \par Algorithm + * Let a[n] and b[n] be sequences of length srcALen and srcBLen samples respectively. + * The convolution of the two signals is denoted by + *
+ *                   c[n] = a[n] * b[n]
+ * 
+ * In correlation, one of the signals is flipped in time + *
+ *                   c[n] = a[n] * b[-n]
+ * 
+ * + * \par + * and this is mathematically defined as + * \image html CorrelateEquation.gif + * \par + * The pSrcA points to the first input vector of length srcALen and pSrcB points to the second input vector of length srcBLen. + * The result c[n] is of length 2 * max(srcALen, srcBLen) - 1 and is defined over the interval n=0, 1, 2, ..., (2 * max(srcALen, srcBLen) - 2). + * The output result is written to pDst and the calling function must allocate 2 * max(srcALen, srcBLen) - 1 words for the result. + * + * Note + * \par + * The pDst should be initialized to all zeros before being used. + * + * Fixed-Point Behavior + * \par + * Correlation requires summing up a large number of intermediate products. + * As such, the Q7, Q15, and Q31 functions run a risk of overflow and saturation. + * Refer to the function specific documentation below for further details of the particular algorithm used. + * + * + * Fast Versions + * + * \par + * Fast versions are supported for Q31 and Q15. Cycles for Fast versions are less compared to Q31 and Q15 of correlate and the design requires + * the input signals should be scaled down to avoid intermediate overflows. + * + * + * Opt Versions + * + * \par + * Opt versions are supported for Q15 and Q7. Design uses internal scratch buffer for getting good optimisation. + * These versions are optimised in cycles and consumes more memory(Scratch memory) compared to Q15 and Q7 versions of correlate + */ + +/** + * @addtogroup Corr + * @{ + */ +/** + * @brief Correlation of floating-point sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @return none. + */ + +void arm_correlate_f32( + float32_t * pSrcA, + uint32_t srcALen, + float32_t * pSrcB, + uint32_t srcBLen, + float32_t * pDst) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t *pIn1; /* inputA pointer */ + float32_t *pIn2; /* inputB pointer */ + float32_t *pOut = pDst; /* output pointer */ + float32_t *px; /* Intermediate inputA pointer */ + float32_t *py; /* Intermediate inputB pointer */ + float32_t *pSrc1; /* Intermediate pointers */ + float32_t sum, acc0, acc1, acc2, acc3; /* Accumulators */ + float32_t x0, x1, x2, x3, c0; /* temporary variables for holding input and coefficient values */ + uint32_t j, k = 0U, count, blkCnt, outBlockSize, blockSize1, blockSize2, blockSize3; /* loop counters */ + int32_t inc = 1; /* Destination address modifier */ + + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we assume zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = pSrcA; + + /* Initialization of inputB pointer */ + pIn2 = pSrcB; + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding has to be done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + //while (j > 0U) + //{ + // /* Zero is stored in the destination buffer */ + // *pOut++ = 0.0f; + + // /* Decrement the loop counter */ + // j--; + //} + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = pSrcB; + + /* Initialization of inputB pointer */ + pIn2 = pSrcA; + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + /* The function is internally + * divided into three parts according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first part of the + * algorithm, the multiplications increase by one for every iteration. + * In the second part of the algorithm, srcBLen number of multiplications are done. + * In the third part of the algorithm, the multiplications decrease by one + * for every iteration.*/ + /* The algorithm is implemented in three stages. + * The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[srcBlen - 1] + * sum = x[0] * y[srcBlen-2] + x[1] * y[srcBlen - 1] + * .... + * sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen - 1] * y[srcBLen - 1] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + (srcBLen - 1U); + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 4] */ + sum += *px++ * *py++; + /* x[1] * y[srcBLen - 3] */ + sum += *px++ * *py++; + /* x[2] * y[srcBLen - 2] */ + sum += *px++ * *py++; + /* x[3] * y[srcBLen - 1] */ + sum += *px++ * *py++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + /* x[0] * y[srcBLen - 1] */ + sum += *px++ * *py++; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pSrc1 - count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen-1] * y[srcBLen-1] + * sum = x[1] * y[0] + x[2] * y[1] +...+ x[srcBLen] * y[srcBLen-1] + * .... + * sum = x[srcALen-srcBLen-2] * y[0] + x[srcALen-srcBLen-1] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4, to loop unroll the srcBLen loop */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0.0f; + acc1 = 0.0f; + acc2 = 0.0f; + acc3 = 0.0f; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[0] sample */ + c0 = *(py++); + + /* Read x[3] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[0] * y[0] */ + acc0 += x0 * c0; + /* acc1 += x[1] * y[0] */ + acc1 += x1 * c0; + /* acc2 += x[2] * y[0] */ + acc2 += x2 * c0; + /* acc3 += x[3] * y[0] */ + acc3 += x3 * c0; + + /* Read y[1] sample */ + c0 = *(py++); + + /* Read x[4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[1] * y[1] */ + acc0 += x1 * c0; + /* acc1 += x[2] * y[1] */ + acc1 += x2 * c0; + /* acc2 += x[3] * y[1] */ + acc2 += x3 * c0; + /* acc3 += x[4] * y[1] */ + acc3 += x0 * c0; + + /* Read y[2] sample */ + c0 = *(py++); + + /* Read x[5] sample */ + x1 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[2] */ + acc0 += x2 * c0; + /* acc1 += x[3] * y[2] */ + acc1 += x3 * c0; + /* acc2 += x[4] * y[2] */ + acc2 += x0 * c0; + /* acc3 += x[5] * y[2] */ + acc3 += x1 * c0; + + /* Read y[3] sample */ + c0 = *(py++); + + /* Read x[6] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[3] * y[3] */ + acc0 += x3 * c0; + /* acc1 += x[4] * y[3] */ + acc1 += x0 * c0; + /* acc2 += x[5] * y[3] */ + acc2 += x1 * c0; + /* acc3 += x[6] * y[3] */ + acc3 += x2 * c0; + + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[4] sample */ + c0 = *(py++); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[4] */ + acc0 += x0 * c0; + /* acc1 += x[5] * y[4] */ + acc1 += x1 * c0; + /* acc2 += x[6] * y[4] */ + acc2 += x2 * c0; + /* acc3 += x[7] * y[4] */ + acc3 += x3 * c0; + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = acc0; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + *pOut = acc1; + pOut += inc; + + *pOut = acc2; + pOut += inc; + + *pOut = acc3; + pOut += inc; + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += *px++ * *py++; + sum += *px++ * *py++; + sum += *px++ * *py++; + sum += *px++ * *py++; + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += *px++ * *py++; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Loop over srcBLen */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += *px++ * *py++; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[0] + x[srcALen-srcBLen+2] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * sum += x[srcALen-srcBLen+2] * y[0] + x[srcALen-srcBLen+3] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * .... + * sum += x[srcALen-2] * y[0] + x[srcALen-1] * y[1] + * sum += x[srcALen-1] * y[0] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = pIn1 + (srcALen - (srcBLen - 1U)); + px = pSrc1; + + /* Working pointer of inputB */ + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0.0f; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen - srcBLen + 4] * y[3] */ + sum += *px++ * *py++; + /* sum += x[srcALen - srcBLen + 3] * y[2] */ + sum += *px++ * *py++; + /* sum += x[srcALen - srcBLen + 2] * y[1] */ + sum += *px++ * *py++; + /* sum += x[srcALen - srcBLen + 1] * y[0] */ + sum += *px++ * *py++; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += *px++ * *py++; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + float32_t *pIn1 = pSrcA; /* inputA pointer */ + float32_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + float32_t sum; /* Accumulator */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and a varaible, inv is set to 1 */ + /* If lengths are not equal then zero pad has to be done to make the two + * inputs of same length. But to improve the performance, we assume zeroes + * in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, (srcALen - srcBLen) zeroes has to included in the + * starting of the output buffer */ + /* If srcALen < srcBLen, (srcALen - srcBLen) zeroes has to included in the + * ending of the output buffer */ + /* Once the zero padding is done the remaining of the output is calcualted + * using convolution but with the shorter signal time shifted. */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0.0f; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += pIn1[j] * pIn2[-((int32_t) i - j)]; + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = sum; + else + *pDst++ = sum; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_opt_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_opt_q15.c new file mode 100644 index 0000000..baebc49 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_opt_q15.c @@ -0,0 +1,500 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_fast_opt_q15.c + * Description: Fast Q15 Correlation + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @param[in] *pScratch points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @return none. + * + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch buffers should be aligned by 32-bit + * + * + * Scaling and Overflow Behavior: + * + * \par + * This fast version uses a 32-bit accumulator with 2.30 format. + * The accumulator maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * There is no saturation on intermediate additions. + * Thus, if the accumulator overflows it wraps around and distorts the result. + * The input signals should be scaled down to avoid intermediate overflows. + * Scale down one of the inputs by 1/min(srcALen, srcBLen) to avoid overflow since a + * maximum of min(srcALen, srcBLen) number of additions is carried internally. + * The 2.30 accumulator is right shifted by 15 bits and then saturated to 1.15 format to yield the final result. + * + * \par + * See arm_correlate_q15() for a slower implementation of this function which uses a 64-bit accumulator to avoid wrap around distortion. + */ + +void arm_correlate_fast_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch) +{ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q31_t acc0, acc1, acc2, acc3; /* Accumulators */ + q15_t *py; /* Intermediate inputB pointer */ + q31_t x1, x2, x3; /* temporary variables for holding input and coefficient values */ + uint32_t j, blkCnt, outBlockSize; /* loop counter */ + int32_t inc = 1; /* Destination address modifier */ + uint32_t tapCnt; + q31_t y1, y2; + q15_t *pScr; /* Intermediate pointers */ + q15_t *pOut = pDst; /* output pointer */ +#ifdef UNALIGNED_SUPPORT_DISABLE + + q15_t a, b; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + pScr = pScratch; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr += (srcBLen - 1U); + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Copy (srcALen) samples in scratch buffer */ + arm_copy_q15(pIn1, pScr, srcALen); + + /* Update pointers */ + pScr += srcALen; + +#else + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + j = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (j > 0U) + { + /* copy second buffer in reversal manner */ + *pScr++ = *pIn1++; + *pScr++ = *pIn1++; + *pScr++ = *pIn1++; + *pScr++ = *pIn1++; + + /* Decrement the loop counter */ + j--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + j = srcALen % 0x4U; + + while (j > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr++ = *pIn1++; + + /* Decrement the loop counter */ + j--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr, (srcBLen - 1U)); + + /* Update pointer */ + pScr += (srcBLen - 1U); + +#else + +/* Apply loop unrolling and do 4 Copies simultaneously. */ + j = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (j > 0U) + { + /* copy second buffer in reversal manner */ + *pScr++ = 0; + *pScr++ = 0; + *pScr++ = 0; + *pScr++ = 0; + + /* Decrement the loop counter */ + j--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + j = (srcBLen - 1U) % 0x4U; + + while (j > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr++ = 0; + + /* Decrement the loop counter */ + j--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Temporary pointer for scratch2 */ + py = pIn2; + + + /* Actual correlation process starts here */ + blkCnt = (srcALen + srcBLen - 1U) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr = pScratch; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read four samples from scratch1 buffer */ + x1 = *__SIMD32(pScr)++; + + /* Read next four samples from scratch1 buffer */ + x2 = *__SIMD32(pScr)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pIn2); + y2 = _SIMD32_OFFSET(pIn2 + 2U); + + acc0 = __SMLAD(x1, y1, acc0); + + acc2 = __SMLAD(x2, y1, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc1 = __SMLADX(x3, y1, acc1); + + x1 = _SIMD32_OFFSET(pScr); + + acc0 = __SMLAD(x2, y2, acc0); + + acc2 = __SMLAD(x1, y2, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + acc1 = __SMLADX(x3, y2, acc1); + + x2 = _SIMD32_OFFSET(pScr + 2U); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y2, acc3); +#else + + /* Read four samples from smaller buffer */ + a = *pIn2; + b = *(pIn2 + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + y1 = __PKHBT(a, b, 16); +#else + y1 = __PKHBT(b, a, 16); +#endif + + a = *(pIn2 + 2); + b = *(pIn2 + 3); +#ifndef ARM_MATH_BIG_ENDIAN + y2 = __PKHBT(a, b, 16); +#else + y2 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLAD(x1, y1, acc0); + + acc2 = __SMLAD(x2, y1, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc1 = __SMLADX(x3, y1, acc1); + + a = *pScr; + b = *(pScr + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(a, b, 16); +#else + x1 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLAD(x2, y2, acc0); + + acc2 = __SMLAD(x1, y2, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + acc1 = __SMLADX(x3, y2, acc1); + + a = *(pScr + 2); + b = *(pScr + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + x2 = __PKHBT(a, b, 16); +#else + x2 = __PKHBT(b, a, 16); +#endif + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y2, acc3); + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + pIn2 += 4U; + + pScr += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr -= 4U; + + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr++ * *pIn2); + acc1 += (*pScr++ * *pIn2); + acc2 += (*pScr++ * *pIn2); + acc3 += (*pScr++ * *pIn2++); + + pScr -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + *pOut = (__SSAT(acc0 >> 15U, 16)); + pOut += inc; + *pOut = (__SSAT(acc1 >> 15U, 16)); + pOut += inc; + *pOut = (__SSAT(acc2 >> 15U, 16)); + pOut += inc; + *pOut = (__SSAT(acc3 >> 15U, 16)); + pOut += inc; + + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch += 4U; + + } + + + blkCnt = (srcALen + srcBLen - 1U) & 0x3; + + /* Calculate correlation for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr = pScratch; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + acc0 += (*pScr++ * *pIn2++); + acc0 += (*pScr++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + + *pOut = (q15_t) (__SSAT((acc0 >> 15), 16)); + + pOut += inc; + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch += 1U; + + } +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q15.c new file mode 100644 index 0000000..7b676d0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q15.c @@ -0,0 +1,1307 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_fast_q15.c + * Description: Fast Q15 Correlation + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q15 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @return none. + * + * Scaling and Overflow Behavior: + * + * \par + * This fast version uses a 32-bit accumulator with 2.30 format. + * The accumulator maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * There is no saturation on intermediate additions. + * Thus, if the accumulator overflows it wraps around and distorts the result. + * The input signals should be scaled down to avoid intermediate overflows. + * Scale down one of the inputs by 1/min(srcALen, srcBLen) to avoid overflow since a + * maximum of min(srcALen, srcBLen) number of additions is carried internally. + * The 2.30 accumulator is right shifted by 15 bits and then saturated to 1.15 format to yield the final result. + * + * \par + * See arm_correlate_q15() for a slower implementation of this function which uses a 64-bit accumulator to avoid wrap around distortion. + */ + +void arm_correlate_fast_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ +#ifndef UNALIGNED_SUPPORT_DISABLE + + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulators */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; /* temporary variables for holding input and coefficient values */ + uint32_t j, k = 0U, count, blkCnt, outBlockSize, blockSize1, blockSize2, blockSize3; /* loop counter */ + int32_t inc = 1; /* Destination address modifier */ + + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + /* The function is internally + * divided into three parts according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first part of the + * algorithm, the multiplications increase by one for every iteration. + * In the second part of the algorithm, srcBLen number of multiplications are done. + * In the third part of the algorithm, the multiplications decrease by one + * for every iteration.*/ + /* The algorithm is implemented in three stages. + * The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[srcBlen - 1] + * sum = x[0] * y[srcBlen - 2] + x[1] * y[srcBlen - 1] + * .... + * sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen - 1] * y[srcBLen - 1] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + (srcBLen - 1U); + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first loop starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 4] , x[1] * y[srcBLen - 3] */ + sum = __SMLAD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + /* x[3] * y[srcBLen - 1] , x[2] * y[srcBLen - 2] */ + sum = __SMLAD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0] * y[srcBLen - 1] */ + sum = __SMLAD(*px++, *py++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pSrc1 - count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen-1] * y[srcBLen-1] + * sum = x[1] * y[0] + x[2] * y[1] +...+ x[srcBLen] * y[srcBLen-1] + * .... + * sum = x[srcALen-srcBLen-2] * y[0] + x[srcALen-srcBLen-1] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4, to loop unroll the srcBLen loop */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1] samples */ + x0 = *__SIMD32(px); + /* read x[1], x[2] samples */ + x1 = _SIMD32_OFFSET(px + 1); + px += 2U; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the first two inputB samples using SIMD: + * y[0] and y[1] */ + c0 = *__SIMD32(py)++; + + /* acc0 += x[0] * y[0] + x[1] * y[1] */ + acc0 = __SMLAD(x0, c0, acc0); + + /* acc1 += x[1] * y[0] + x[2] * y[1] */ + acc1 = __SMLAD(x1, c0, acc1); + + /* Read x[2], x[3] */ + x2 = *__SIMD32(px); + + /* Read x[3], x[4] */ + x3 = _SIMD32_OFFSET(px + 1); + + /* acc2 += x[2] * y[0] + x[3] * y[1] */ + acc2 = __SMLAD(x2, c0, acc2); + + /* acc3 += x[3] * y[0] + x[4] * y[1] */ + acc3 = __SMLAD(x3, c0, acc3); + + /* Read y[2] and y[3] */ + c0 = *__SIMD32(py)++; + + /* acc0 += x[2] * y[2] + x[3] * y[3] */ + acc0 = __SMLAD(x2, c0, acc0); + + /* acc1 += x[3] * y[2] + x[4] * y[3] */ + acc1 = __SMLAD(x3, c0, acc1); + + /* Read x[4], x[5] */ + x0 = _SIMD32_OFFSET(px + 2); + + /* Read x[5], x[6] */ + x1 = _SIMD32_OFFSET(px + 3); + px += 4U; + + /* acc2 += x[4] * y[2] + x[5] * y[3] */ + acc2 = __SMLAD(x0, c0, acc2); + + /* acc3 += x[5] * y[2] + x[6] * y[3] */ + acc3 = __SMLAD(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[4] */ + c0 = *py; +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7] */ + x3 = *__SIMD32(px); + px++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLADX(x1, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[4], y[5] */ + c0 = *__SIMD32(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px + 1); + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLAD(x3, c0, acc2); + acc3 = __SMLAD(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[4], y[5] */ + c0 = *__SIMD32(py)++; + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px + 1); + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLAD(x3, c0, acc2); + acc3 = __SMLAD(x2, c0, acc3); + + c0 = (*py); + /* Read y[6] */ +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[10] */ + x3 = _SIMD32_OFFSET(px + 2); + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x1, c0, acc0); + acc1 = __SMLAD(x2, c0, acc1); + acc2 = __SMLADX(x2, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (acc0 >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + *pOut = (q15_t) (acc1 >> 15); + pOut += inc; + + *pOut = (q15_t) (acc2 >> 15); + pOut += inc; + + *pOut = (q15_t) (acc3 >> 15); + pOut += inc; + + /* Increment the pointer pIn1 index, count by 1 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over srcBLen */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[0] + x[srcALen-srcBLen+2] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * sum += x[srcALen-srcBLen+2] * y[0] + x[srcALen-srcBLen+3] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * .... + * sum += x[srcALen-2] * y[0] + x[srcALen-1] * y[1] + * sum += x[srcALen-1] * y[0] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen - srcBLen + 4] * y[3] , sum += x[srcALen - srcBLen + 3] * y[2] */ + sum = __SMLAD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + /* sum += x[srcALen - srcBLen + 2] * y[1] , sum += x[srcALen - srcBLen + 1] * y[0] */ + sum = __SMLAD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLAD(*px++, *py++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulators */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; /* temporary variables for holding input and coefficient values */ + uint32_t j, k = 0U, count, blkCnt, outBlockSize, blockSize1, blockSize2, blockSize3; /* loop counter */ + int32_t inc = 1; /* Destination address modifier */ + q15_t a, b; + + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + /* The function is internally + * divided into three parts according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first part of the + * algorithm, the multiplications increase by one for every iteration. + * In the second part of the algorithm, srcBLen number of multiplications are done. + * In the third part of the algorithm, the multiplications decrease by one + * for every iteration.*/ + /* The algorithm is implemented in three stages. + * The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[srcBlen - 1] + * sum = x[0] * y[srcBlen - 2] + x[1] * y[srcBlen - 1] + * .... + * sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen - 1] * y[srcBLen - 1] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + (srcBLen - 1U); + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first loop starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 4] , x[1] * y[srcBLen - 3] */ + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0] * y[srcBLen - 1] */ + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pSrc1 - count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen-1] * y[srcBLen-1] + * sum = x[1] * y[0] + x[2] * y[1] +...+ x[srcBLen] * y[srcBLen-1] + * .... + * sum = x[srcALen-srcBLen-2] * y[0] + x[srcALen-srcBLen-1] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4, to loop unroll the srcBLen loop */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1], x[2] samples */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x0 = __PKHBT(a, b, 16); + a = *(px + 2); + x1 = __PKHBT(b, a, 16); + +#else + + x0 = __PKHBT(b, a, 16); + a = *(px + 2); + x1 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 2U; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the first two inputB samples using SIMD: + * y[0] and y[1] */ + a = *py; + b = *(py + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc0 += x[0] * y[0] + x[1] * y[1] */ + acc0 = __SMLAD(x0, c0, acc0); + + /* acc1 += x[1] * y[0] + x[2] * y[1] */ + acc1 = __SMLAD(x1, c0, acc1); + + /* Read x[2], x[3], x[4] */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x2 = __PKHBT(a, b, 16); + a = *(px + 2); + x3 = __PKHBT(b, a, 16); + +#else + + x2 = __PKHBT(b, a, 16); + a = *(px + 2); + x3 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc2 += x[2] * y[0] + x[3] * y[1] */ + acc2 = __SMLAD(x2, c0, acc2); + + /* acc3 += x[3] * y[0] + x[4] * y[1] */ + acc3 = __SMLAD(x3, c0, acc3); + + /* Read y[2] and y[3] */ + a = *(py + 2); + b = *(py + 3); + + py += 4U; + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* acc0 += x[2] * y[2] + x[3] * y[3] */ + acc0 = __SMLAD(x2, c0, acc0); + + /* acc1 += x[3] * y[2] + x[4] * y[3] */ + acc1 = __SMLAD(x3, c0, acc1); + + /* Read x[4], x[5], x[6] */ + a = *(px + 2); + b = *(px + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + + x0 = __PKHBT(a, b, 16); + a = *(px + 4); + x1 = __PKHBT(b, a, 16); + +#else + + x0 = __PKHBT(b, a, 16); + a = *(px + 4); + x1 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 4U; + + /* acc2 += x[4] * y[2] + x[5] * y[3] */ + acc2 = __SMLAD(x0, c0, acc2); + + /* acc3 += x[5] * y[2] + x[6] * y[3] */ + acc3 = __SMLAD(x1, c0, acc3); + + } while (--k); + + /* For the next MAC operations, SIMD is not used + * So, the 16 bit pointer if inputB, py is updated */ + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[4] */ + c0 = *py; +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7] */ + a = *px; + b = *(px + 1); + + px++;; + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + +#else + + x3 = __PKHBT(b, a, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLADX(x1, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[4], y[5] */ + a = *py; + b = *(py + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Read x[7], x[8], x[9] */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + a = *(px + 2); + x2 = __PKHBT(b, a, 16); + +#else + + x3 = __PKHBT(b, a, 16); + a = *(px + 2); + x2 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLAD(x3, c0, acc2); + acc3 = __SMLAD(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[4], y[5] */ + a = *py; + b = *(py + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + c0 = __PKHBT(a, b, 16); + +#else + + c0 = __PKHBT(b, a, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + py += 2U; + + /* Read x[7], x[8], x[9] */ + a = *px; + b = *(px + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + a = *(px + 2); + x2 = __PKHBT(b, a, 16); + +#else + + x3 = __PKHBT(b, a, 16); + a = *(px + 2); + x2 = __PKHBT(a, b, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + acc2 = __SMLAD(x3, c0, acc2); + acc3 = __SMLAD(x2, c0, acc3); + + c0 = (*py); + /* Read y[6] */ +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + + /* Read x[10] */ + b = *(px + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + + x3 = __PKHBT(a, b, 16); + +#else + + x3 = __PKHBT(b, a, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLADX(x1, c0, acc0); + acc1 = __SMLAD(x2, c0, acc1); + acc2 = __SMLADX(x2, c0, acc2); + acc3 = __SMLADX(x3, c0, acc3); + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (acc0 >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + *pOut = (q15_t) (acc1 >> 15); + pOut += inc; + + *pOut = (q15_t) (acc2 >> 15); + pOut += inc; + + *pOut = (q15_t) (acc3 >> 15); + pOut += inc; + + /* Increment the pointer pIn1 index, count by 1 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over srcBLen */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[0] + x[srcALen-srcBLen+2] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * sum += x[srcALen-srcBLen+2] * y[0] + x[srcALen-srcBLen+3] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * .... + * sum += x[srcALen-2] * y[0] + x[srcALen-1] * y[1] + * sum += x[srcALen-1] * y[0] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q31_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (sum >> 15); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q31.c new file mode 100644 index 0000000..53373ac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_fast_q31.c @@ -0,0 +1,600 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_fast_q31.c + * Description: Fast Q31 Correlation + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q31 sequences (fast version) for Cortex-M3 and Cortex-M4. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * This function is optimized for speed at the expense of fixed-point precision and overflow protection. + * The result of each 1.31 x 1.31 multiplication is truncated to 2.30 format. + * These intermediate results are accumulated in a 32-bit register in 2.30 format. + * Finally, the accumulator is saturated and converted to a 1.31 result. + * + * \par + * The fast version has the same overflow behavior as the standard version but provides less precision since it discards the low 32 bits of each multiplication result. + * In order to avoid overflows completely the input signals must be scaled down. + * The input signals should be scaled down to avoid intermediate overflows. + * Scale down one of the inputs by 1/min(srcALen, srcBLen)to avoid overflows since a + * maximum of min(srcALen, srcBLen) number of additions is carried internally. + * + * \par + * See arm_correlate_q31() for a slower implementation of this function which uses 64-bit accumulation to provide higher precision. + */ + +void arm_correlate_fast_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + q31_t *pIn1; /* inputA pointer */ + q31_t *pIn2; /* inputB pointer */ + q31_t *pOut = pDst; /* output pointer */ + q31_t *px; /* Intermediate inputA pointer */ + q31_t *py; /* Intermediate inputB pointer */ + q31_t *pSrc1; /* Intermediate pointers */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulators */ + q31_t x0, x1, x2, x3, c0; /* temporary variables for holding input and coefficient values */ + uint32_t j, k = 0U, count, blkCnt, outBlockSize, blockSize1, blockSize2, blockSize3; /* loop counter */ + int32_t inc = 1; /* Destination address modifier */ + + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + /* The function is internally + * divided into three parts according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first part of the + * algorithm, the multiplications increase by one for every iteration. + * In the second part of the algorithm, srcBLen number of multiplications are done. + * In the third part of the algorithm, the multiplications decrease by one + * for every iteration.*/ + /* The algorithm is implemented in three stages. + * The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[srcBlen - 1] + * sum = x[0] * y[srcBlen - 2] + x[1] * y[srcBlen - 1] + * .... + * sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen - 1] * y[srcBLen - 1] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + (srcBLen - 1U); + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 4] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + /* x[1] * y[srcBLen - 3] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + /* x[2] * y[srcBLen - 2] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + /* x[3] * y[srcBLen - 1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0] * y[srcBLen - 1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum << 1; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pSrc1 - count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen-1] * y[srcBLen-1] + * sum = x[1] * y[0] + x[2] * y[1] +...+ x[srcBLen] * y[srcBLen-1] + * .... + * sum = x[srcALen-srcBLen-2] * y[0] + x[srcALen-srcBLen-1] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1], x[2] samples */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[0] sample */ + c0 = *(py++); + + /* Read x[3] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulate */ + /* acc0 += x[0] * y[0] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc1 += x[1] * y[0] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc2 += x[2] * y[0] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc3 += x[3] * y[0] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x3 * c0)) >> 32); + + /* Read y[1] sample */ + c0 = *(py++); + + /* Read x[4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[1] * y[1] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc1 += x[2] * y[1] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc2 += x[3] * y[1] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc3 += x[4] * y[1] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Read y[2] sample */ + c0 = *(py++); + + /* Read x[5] sample */ + x1 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[2] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc1 += x[3] * y[2] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc2 += x[4] * y[2] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc3 += x[5] * y[2] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* Read y[3] sample */ + c0 = *(py++); + + /* Read x[6] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[3] * y[3] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x3 * c0)) >> 32); + /* acc1 += x[4] * y[3] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc2 += x[5] * y[3] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc3 += x[6] * y[3] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x2 * c0)) >> 32); + + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[4] sample */ + c0 = *(py++); + + /* Read x[7] sample */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[4] */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + /* acc1 += x[5] * y[4] */ + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + /* acc2 += x[6] * y[4] */ + acc2 = (q31_t) ((((q63_t) acc2 << 32) + ((q63_t) x2 * c0)) >> 32); + /* acc3 += x[7] * y[4] */ + acc3 = (q31_t) ((((q63_t) acc3 << 32) + ((q63_t) x3 * c0)) >> 32); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q31_t) (acc0 << 1); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + *pOut = (q31_t) (acc1 << 1); + pOut += inc; + + *pOut = (q31_t) (acc2 << 1); + pOut += inc; + + *pOut = (q31_t) (acc3 << 1); + pOut += inc; + + /* Increment the pointer pIn1 index, count by 4 */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum << 1; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over srcBLen */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum << 1; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[0] + x[srcALen-srcBLen+2] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * sum += x[srcALen-srcBLen+2] * y[0] + x[srcALen-srcBLen+3] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * .... + * sum += x[srcALen-2] * y[0] + x[srcALen-1] * y[1] + * sum += x[srcALen-1] * y[0] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = ((pIn1 + srcALen) - srcBLen) + 1U; + px = pSrc1; + + /* Working pointer of inputB */ + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen - srcBLen + 4] * y[3] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + /* sum += x[srcALen - srcBLen + 3] * y[2] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + /* sum += x[srcALen - srcBLen + 2] * y[1] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + /* sum += x[srcALen - srcBLen + 1] * y[0] */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = (q31_t) ((((q63_t) sum << 32) + + ((q63_t) * px++ * (*py++))) >> 32); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = sum << 1; + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q15.c new file mode 100644 index 0000000..c021b05 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q15.c @@ -0,0 +1,501 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_opt_q15.c + * Description: Correlation of Q15 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q15 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @param[in] *pScratch points to scratch buffer of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @return none. + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch buffers should be aligned by 32-bit + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both inputs are in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * This approach provides 33 guard bits and there is no risk of overflow. + * The 34.30 result is then truncated to 34.15 format by discarding the low 15 bits and then saturated to 1.15 format. + * + * \par + * Refer to arm_correlate_fast_q15() for a faster but less precise version of this function for Cortex-M3 and Cortex-M4. + * + * + */ + + +void arm_correlate_opt_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst, + q15_t * pScratch) +{ + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q63_t acc0, acc1, acc2, acc3; /* Accumulators */ + q15_t *py; /* Intermediate inputB pointer */ + q31_t x1, x2, x3; /* temporary variables for holding input1 and input2 values */ + uint32_t j, blkCnt, outBlockSize; /* loop counter */ + int32_t inc = 1; /* output pointer increment */ + uint32_t tapCnt; + q31_t y1, y2; + q15_t *pScr; /* Intermediate pointers */ + q15_t *pOut = pDst; /* output pointer */ +#ifdef UNALIGNED_SUPPORT_DISABLE + + q15_t a, b; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + pScr = pScratch; + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr += (srcBLen - 1U); + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Copy (srcALen) samples in scratch buffer */ + arm_copy_q15(pIn1, pScr, srcALen); + + /* Update pointers */ + //pIn1 += srcALen; + pScr += srcALen; + +#else + + /* Apply loop unrolling and do 4 Copies simultaneously. */ + j = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (j > 0U) + { + /* copy second buffer in reversal manner */ + *pScr++ = *pIn1++; + *pScr++ = *pIn1++; + *pScr++ = *pIn1++; + *pScr++ = *pIn1++; + + /* Decrement the loop counter */ + j--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + j = srcALen % 0x4U; + + while (j > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr++ = *pIn1++; + + /* Decrement the loop counter */ + j--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr, (srcBLen - 1U)); + + /* Update pointer */ + pScr += (srcBLen - 1U); + +#else + +/* Apply loop unrolling and do 4 Copies simultaneously. */ + j = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (j > 0U) + { + /* copy second buffer in reversal manner */ + *pScr++ = 0; + *pScr++ = 0; + *pScr++ = 0; + *pScr++ = 0; + + /* Decrement the loop counter */ + j--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + j = (srcBLen - 1U) % 0x4U; + + while (j > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr++ = 0; + + /* Decrement the loop counter */ + j--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Temporary pointer for scratch2 */ + py = pIn2; + + + /* Actual correlation process starts here */ + blkCnt = (srcALen + srcBLen - 1U) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr = pScratch; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read four samples from scratch1 buffer */ + x1 = *__SIMD32(pScr)++; + + /* Read next four samples from scratch1 buffer */ + x2 = *__SIMD32(pScr)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pIn2); + y2 = _SIMD32_OFFSET(pIn2 + 2U); + + acc0 = __SMLALD(x1, y1, acc0); + + acc2 = __SMLALD(x2, y1, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc1 = __SMLALDX(x3, y1, acc1); + + x1 = _SIMD32_OFFSET(pScr); + + acc0 = __SMLALD(x2, y2, acc0); + + acc2 = __SMLALD(x1, y2, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLALDX(x3, y1, acc3); + + acc1 = __SMLALDX(x3, y2, acc1); + + x2 = _SIMD32_OFFSET(pScr + 2U); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLALDX(x3, y2, acc3); + +#else + + /* Read four samples from smaller buffer */ + a = *pIn2; + b = *(pIn2 + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + y1 = __PKHBT(a, b, 16); +#else + y1 = __PKHBT(b, a, 16); +#endif + + a = *(pIn2 + 2); + b = *(pIn2 + 3); +#ifndef ARM_MATH_BIG_ENDIAN + y2 = __PKHBT(a, b, 16); +#else + y2 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLALD(x1, y1, acc0); + + acc2 = __SMLALD(x2, y1, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc1 = __SMLALDX(x3, y1, acc1); + + a = *pScr; + b = *(pScr + 1); + +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(a, b, 16); +#else + x1 = __PKHBT(b, a, 16); +#endif + + acc0 = __SMLALD(x2, y2, acc0); + + acc2 = __SMLALD(x1, y2, acc2); + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLALDX(x3, y1, acc3); + + acc1 = __SMLALDX(x3, y2, acc1); + + a = *(pScr + 2); + b = *(pScr + 3); + +#ifndef ARM_MATH_BIG_ENDIAN + x2 = __PKHBT(a, b, 16); +#else + x2 = __PKHBT(b, a, 16); +#endif + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLALDX(x3, y2, acc3); + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + pIn2 += 4U; + + pScr += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr -= 4U; + + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr++ * *pIn2); + acc1 += (*pScr++ * *pIn2); + acc2 += (*pScr++ * *pIn2); + acc3 += (*pScr++ * *pIn2++); + + pScr -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + + /* Store the results in the accumulators in the destination buffer. */ + *pOut = (__SSAT(acc0 >> 15U, 16)); + pOut += inc; + *pOut = (__SSAT(acc1 >> 15U, 16)); + pOut += inc; + *pOut = (__SSAT(acc2 >> 15U, 16)); + pOut += inc; + *pOut = (__SSAT(acc3 >> 15U, 16)); + pOut += inc; + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch += 4U; + + } + + + blkCnt = (srcALen + srcBLen - 1U) & 0x3; + + /* Calculate correlation for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr = pScratch; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + + acc0 += (*pScr++ * *pIn2++); + acc0 += (*pScr++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr++ * *pIn2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (__SSAT((acc0 >> 15), 16)); + + pOut += inc; + + /* Initialization of inputB pointer */ + pIn2 = py; + + pScratch += 1U; + + } + + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q7.c new file mode 100644 index 0000000..dbffd5d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_opt_q7.c @@ -0,0 +1,452 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_opt_q7.c + * Description: Correlation of Q7 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q7 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @param[in] *pScratch1 points to scratch buffer(of type q15_t) of size max(srcALen, srcBLen) + 2*min(srcALen, srcBLen) - 2. + * @param[in] *pScratch2 points to scratch buffer (of type q15_t) of size min(srcALen, srcBLen). + * @return none. + * + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch1 and scratch2 buffers should be aligned by 32-bit + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 32-bit internal accumulator. + * Both the inputs are represented in 1.7 format and multiplications yield a 2.14 result. + * The 2.14 intermediate results are accumulated in a 32-bit accumulator in 18.14 format. + * This approach provides 17 guard bits and there is no risk of overflow as long as max(srcALen, srcBLen)<131072. + * The 18.14 result is then truncated to 18.7 format by discarding the low 7 bits and saturated to 1.7 format. + * + * + */ + + + +void arm_correlate_opt_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst, + q15_t * pScratch1, + q15_t * pScratch2) +{ + q7_t *pOut = pDst; /* output pointer */ + q15_t *pScr1 = pScratch1; /* Temporary pointer for scratch */ + q15_t *pScr2 = pScratch2; /* Temporary pointer for scratch */ + q7_t *pIn1; /* inputA pointer */ + q7_t *pIn2; /* inputB pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q31_t acc0, acc1, acc2, acc3; /* Accumulators */ + uint32_t j, k = 0U, blkCnt; /* loop counter */ + int32_t inc = 1; /* output pointer increment */ + uint32_t outBlockSize; /* loop counter */ + q15_t x4; /* Temporary input variable */ + uint32_t tapCnt; /* loop counter */ + q31_t x1, x2, x3, y1; /* Temporary input variables */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + + /* Copy (srcBLen) samples in scratch buffer */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * pIn2++; + *pScr2++ = x4; + x4 = (q15_t) * pIn2++; + *pScr2++ = x4; + x4 = (q15_t) * pIn2++; + *pScr2++ = x4; + x4 = (q15_t) * pIn2++; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * pIn2++; + *pScr2++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* Fill (srcBLen - 1U) zeros in scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update temporary scratch pointer */ + pScr1 += (srcBLen - 1U); + + /* Copy (srcALen) samples in scratch buffer */ + k = srcALen >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = srcALen % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + x4 = (q15_t) * pIn1++; + *pScr1++ = x4; + + /* Decrement the loop counter */ + k--; + } + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Fill (srcBLen - 1U) zeros at end of scratch buffer */ + arm_fill_q15(0, pScr1, (srcBLen - 1U)); + + /* Update pointer */ + pScr1 += (srcBLen - 1U); + +#else + +/* Apply loop unrolling and do 4 Copies simultaneously. */ + k = (srcBLen - 1U) >> 2U; + + /* First part of the processing with loop unrolling copies 4 data points at a time. + ** a second loop below copies for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* copy second buffer in reversal manner */ + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, copy remaining samples here. + ** No loop unrolling is used. */ + k = (srcBLen - 1U) % 0x4U; + + while (k > 0U) + { + /* copy second buffer in reversal manner for remaining samples */ + *pScr1++ = 0; + + /* Decrement the loop counter */ + k--; + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Temporary pointer for second sequence */ + py = pScratch2; + + /* Initialization of pScr2 pointer */ + pScr2 = pScratch2; + + /* Actual correlation process starts here */ + blkCnt = (srcALen + srcBLen - 1U) >> 2; + + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Read two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* Read next two samples from scratch1 buffer */ + x2 = *__SIMD32(pScr1)++; + + tapCnt = (srcBLen) >> 2U; + + while (tapCnt > 0U) + { + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pScr2); + + /* multiply and accumlate */ + acc0 = __SMLAD(x1, y1, acc0); + acc2 = __SMLAD(x2, y1, acc2); + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + /* multiply and accumlate */ + acc1 = __SMLADX(x3, y1, acc1); + + /* Read next two samples from scratch1 buffer */ + x1 = *__SIMD32(pScr1)++; + + /* pack input data */ +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x1, x2, 0); +#else + x3 = __PKHBT(x2, x1, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + /* Read four samples from smaller buffer */ + y1 = _SIMD32_OFFSET(pScr2 + 2U); + + acc0 = __SMLAD(x2, y1, acc0); + + acc2 = __SMLAD(x1, y1, acc2); + + acc1 = __SMLADX(x3, y1, acc1); + + x2 = *__SIMD32(pScr1)++; + +#ifndef ARM_MATH_BIG_ENDIAN + x3 = __PKHBT(x2, x1, 0); +#else + x3 = __PKHBT(x1, x2, 0); +#endif + + acc3 = __SMLADX(x3, y1, acc3); + + pScr2 += 4U; + + + /* Decrement the loop counter */ + tapCnt--; + } + + + + /* Update scratch pointer for remaining samples of smaller length sequence */ + pScr1 -= 4U; + + + /* apply same above for remaining samples of smaller length sequence */ + tapCnt = (srcBLen) & 3U; + + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2); + acc1 += (*pScr1++ * *pScr2); + acc2 += (*pScr1++ * *pScr2); + acc3 += (*pScr1++ * *pScr2++); + + pScr1 -= 3U; + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q7_t) (__SSAT(acc0 >> 7U, 8)); + pOut += inc; + *pOut = (q7_t) (__SSAT(acc1 >> 7U, 8)); + pOut += inc; + *pOut = (q7_t) (__SSAT(acc2 >> 7U, 8)); + pOut += inc; + *pOut = (q7_t) (__SSAT(acc3 >> 7U, 8)); + pOut += inc; + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 4U; + + } + + + blkCnt = (srcALen + srcBLen - 1U) & 0x3; + + /* Calculate correlation for remaining samples of Bigger length sequence */ + while (blkCnt > 0) + { + /* Initialze temporary scratch pointer as scratch1 */ + pScr1 = pScratch1; + + /* Clear Accumlators */ + acc0 = 0; + + tapCnt = (srcBLen) >> 1U; + + while (tapCnt > 0U) + { + acc0 += (*pScr1++ * *pScr2++); + acc0 += (*pScr1++ * *pScr2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (srcBLen) & 1U; + + /* apply same above for remaining samples of smaller length sequence */ + while (tapCnt > 0U) + { + + /* accumlate the results */ + acc0 += (*pScr1++ * *pScr2++); + + /* Decrement the loop counter */ + tapCnt--; + } + + blkCnt--; + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q7_t) (__SSAT(acc0 >> 7U, 8)); + + pOut += inc; + + /* Initialization of inputB pointer */ + pScr2 = py; + + pScratch1 += 1U; + + } + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q15.c new file mode 100644 index 0000000..fdff6db --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q15.c @@ -0,0 +1,707 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_q15.c + * Description: Correlation of Q15 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q15 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both inputs are in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * This approach provides 33 guard bits and there is no risk of overflow. + * The 34.30 result is then truncated to 34.15 format by discarding the low 15 bits and then saturated to 1.15 format. + * + * \par + * Refer to arm_correlate_fast_q15() for a faster but less precise version of this function for Cortex-M3 and Cortex-M4. + * + * \par + * Refer the function arm_correlate_opt_q15() for a faster implementation of this function using scratch buffers. + * + */ + +void arm_correlate_q15( + q15_t * pSrcA, + uint32_t srcALen, + q15_t * pSrcB, + uint32_t srcBLen, + q15_t * pDst) +{ + +#if (defined(ARM_MATH_CM7) || defined(ARM_MATH_CM4) || defined(ARM_MATH_CM3)) && !defined(UNALIGNED_SUPPORT_DISABLE) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t *pIn1; /* inputA pointer */ + q15_t *pIn2; /* inputB pointer */ + q15_t *pOut = pDst; /* output pointer */ + q63_t sum, acc0, acc1, acc2, acc3; /* Accumulators */ + q15_t *px; /* Intermediate inputA pointer */ + q15_t *py; /* Intermediate inputB pointer */ + q15_t *pSrc1; /* Intermediate pointers */ + q31_t x0, x1, x2, x3, c0; /* temporary variables for holding input and coefficient values */ + uint32_t j, k = 0U, count, blkCnt, outBlockSize, blockSize1, blockSize2, blockSize3; /* loop counter */ + int32_t inc = 1; /* Destination address modifier */ + + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + /* The function is internally + * divided into three parts according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first part of the + * algorithm, the multiplications increase by one for every iteration. + * In the second part of the algorithm, srcBLen number of multiplications are done. + * In the third part of the algorithm, the multiplications decrease by one + * for every iteration.*/ + /* The algorithm is implemented in three stages. + * The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[srcBlen - 1] + * sum = x[0] * y[srcBlen - 2] + x[1] * y[srcBlen - 1] + * .... + * sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen - 1] * y[srcBLen - 1] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + (srcBLen - 1U); + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first loop starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 4] , x[1] * y[srcBLen - 3] */ + sum = __SMLALD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + /* x[3] * y[srcBLen - 1] , x[2] * y[srcBLen - 2] */ + sum = __SMLALD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0] * y[srcBLen - 1] */ + sum = __SMLALD(*px++, *py++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (__SSAT((sum >> 15), 16)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pSrc1 - count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen-1] * y[srcBLen-1] + * sum = x[1] * y[0] + x[2] * y[1] +...+ x[srcBLen] * y[srcBLen-1] + * .... + * sum = x[srcALen-srcBLen-2] * y[0] + x[srcALen-srcBLen-1] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4, to loop unroll the srcBLen loop */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1] samples */ + x0 = *__SIMD32(px); + /* read x[1], x[2] samples */ + x1 = _SIMD32_OFFSET(px + 1); + px += 2U; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read the first two inputB samples using SIMD: + * y[0] and y[1] */ + c0 = *__SIMD32(py)++; + + /* acc0 += x[0] * y[0] + x[1] * y[1] */ + acc0 = __SMLALD(x0, c0, acc0); + + /* acc1 += x[1] * y[0] + x[2] * y[1] */ + acc1 = __SMLALD(x1, c0, acc1); + + /* Read x[2], x[3] */ + x2 = *__SIMD32(px); + + /* Read x[3], x[4] */ + x3 = _SIMD32_OFFSET(px + 1); + + /* acc2 += x[2] * y[0] + x[3] * y[1] */ + acc2 = __SMLALD(x2, c0, acc2); + + /* acc3 += x[3] * y[0] + x[4] * y[1] */ + acc3 = __SMLALD(x3, c0, acc3); + + /* Read y[2] and y[3] */ + c0 = *__SIMD32(py)++; + + /* acc0 += x[2] * y[2] + x[3] * y[3] */ + acc0 = __SMLALD(x2, c0, acc0); + + /* acc1 += x[3] * y[2] + x[4] * y[3] */ + acc1 = __SMLALD(x3, c0, acc1); + + /* Read x[4], x[5] */ + x0 = _SIMD32_OFFSET(px + 2); + + /* Read x[5], x[6] */ + x1 = _SIMD32_OFFSET(px + 3); + + px += 4U; + + /* acc2 += x[4] * y[2] + x[5] * y[3] */ + acc2 = __SMLALD(x0, c0, acc2); + + /* acc3 += x[5] * y[2] + x[6] * y[3] */ + acc3 = __SMLALD(x1, c0, acc3); + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + if (k == 1U) + { + /* Read y[4] */ + c0 = *py; +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; + +#else + + c0 = c0 & 0x0000FFFF; + +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + /* Read x[7] */ + x3 = *__SIMD32(px); + px++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALD(x0, c0, acc0); + acc1 = __SMLALD(x1, c0, acc1); + acc2 = __SMLALDX(x1, c0, acc2); + acc3 = __SMLALDX(x3, c0, acc3); + } + + if (k == 2U) + { + /* Read y[4], y[5] */ + c0 = *__SIMD32(py); + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px + 1); + px += 2U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALD(x0, c0, acc0); + acc1 = __SMLALD(x1, c0, acc1); + acc2 = __SMLALD(x3, c0, acc2); + acc3 = __SMLALD(x2, c0, acc3); + } + + if (k == 3U) + { + /* Read y[4], y[5] */ + c0 = *__SIMD32(py)++; + + /* Read x[7], x[8] */ + x3 = *__SIMD32(px); + + /* Read x[9] */ + x2 = _SIMD32_OFFSET(px + 1); + + /* Perform the multiply-accumulates */ + acc0 = __SMLALD(x0, c0, acc0); + acc1 = __SMLALD(x1, c0, acc1); + acc2 = __SMLALD(x3, c0, acc2); + acc3 = __SMLALD(x2, c0, acc3); + + c0 = (*py); + + /* Read y[6] */ +#ifdef ARM_MATH_BIG_ENDIAN + + c0 = c0 << 16U; +#else + + c0 = c0 & 0x0000FFFF; +#endif /* #ifdef ARM_MATH_BIG_ENDIAN */ + /* Read x[10] */ + x3 = _SIMD32_OFFSET(px + 2); + px += 3U; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALDX(x1, c0, acc0); + acc1 = __SMLALD(x2, c0, acc1); + acc2 = __SMLALDX(x2, c0, acc2); + acc3 = __SMLALDX(x3, c0, acc3); + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (__SSAT(acc0 >> 15, 16)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + *pOut = (q15_t) (__SSAT(acc1 >> 15, 16)); + pOut += inc; + + *pOut = (q15_t) (__SSAT(acc2 >> 15, 16)); + pOut += inc; + + *pOut = (q15_t) (__SSAT(acc3 >> 15, 16)); + pOut += inc; + + /* Increment the count by 4 as 4 output values are computed */ + count += 4U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q63_t) * px++ * *py++); + sum += ((q63_t) * px++ * *py++); + sum += ((q63_t) * px++ * *py++); + sum += ((q63_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q63_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (__SSAT(sum >> 15, 16)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment count by 1, as one output value is computed */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over srcBLen */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q63_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (__SSAT(sum >> 15, 16)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[0] + x[srcALen-srcBLen+2] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * sum += x[srcALen-srcBLen+2] * y[0] + x[srcALen-srcBLen+3] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * .... + * sum += x[srcALen-2] * y[0] + x[srcALen-1] * y[1] + * sum += x[srcALen-1] * y[0] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = (pIn1 + srcALen) - (srcBLen - 1U); + px = pSrc1; + + /* Working pointer of inputB */ + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen - srcBLen + 4] * y[3] , sum += x[srcALen - srcBLen + 3] * y[2] */ + sum = __SMLALD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + /* sum += x[srcALen - srcBLen + 2] * y[1] , sum += x[srcALen - srcBLen + 1] * y[0] */ + sum = __SMLALD(*__SIMD32(px)++, *__SIMD32(py)++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum = __SMLALD(*px++, *py++, sum); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q15_t) (__SSAT((sum >> 15), 16)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + q15_t *pIn1 = pSrcA; /* inputA pointer */ + q15_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q63_t sum; /* Accumulators */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and a varaible, inv is set to 1 */ + /* If lengths are not equal then zero pad has to be done to make the two + * inputs of same length. But to improve the performance, we include zeroes + * in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, (srcALen - srcBLen) zeroes has to included in the + * starting of the output buffer */ + /* If srcALen < srcBLen, (srcALen - srcBLen) zeroes has to included in the + * ending of the output buffer */ + /* Once the zero padding is done the remaining of the output is calcualted + * using convolution but with the shorter signal time shifted. */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q31_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q15_t) __SSAT((sum >> 15U), 16U); + else + *pDst++ = (q15_t) __SSAT((sum >> 15U), 16U); + } + +#endif /* #if (defined(ARM_MATH_CM7) || defined(ARM_MATH_CM4) || defined(ARM_MATH_CM3)) && !defined(UNALIGNED_SUPPORT_DISABLE) */ + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q31.c new file mode 100644 index 0000000..f2e946a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q31.c @@ -0,0 +1,653 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_q31.c + * Description: Correlation of Q31 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q31 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * There is no saturation on intermediate additions. + * Thus, if the accumulator overflows it wraps around and distorts the result. + * The input signals should be scaled down to avoid intermediate overflows. + * Scale down one of the inputs by 1/min(srcALen, srcBLen)to avoid overflows since a + * maximum of min(srcALen, srcBLen) number of additions is carried internally. + * The 2.62 accumulator is right shifted by 31 bits and saturated to 1.31 format to yield the final result. + * + * \par + * See arm_correlate_fast_q31() for a faster but less precise implementation of this function for Cortex-M3 and Cortex-M4. + */ + +void arm_correlate_q31( + q31_t * pSrcA, + uint32_t srcALen, + q31_t * pSrcB, + uint32_t srcBLen, + q31_t * pDst) +{ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t *pIn1; /* inputA pointer */ + q31_t *pIn2; /* inputB pointer */ + q31_t *pOut = pDst; /* output pointer */ + q31_t *px; /* Intermediate inputA pointer */ + q31_t *py; /* Intermediate inputB pointer */ + q31_t *pSrc1; /* Intermediate pointers */ + q63_t sum, acc0, acc1, acc2; /* Accumulators */ + q31_t x0, x1, x2, c0; /* temporary variables for holding input and coefficient values */ + uint32_t j, k = 0U, count, blkCnt, outBlockSize, blockSize1, blockSize2, blockSize3; /* loop counter */ + int32_t inc = 1; /* Destination address modifier */ + + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + /* The function is internally + * divided into three parts according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first part of the + * algorithm, the multiplications increase by one for every iteration. + * In the second part of the algorithm, srcBLen number of multiplications are done. + * In the third part of the algorithm, the multiplications decrease by one + * for every iteration.*/ + /* The algorithm is implemented in three stages. + * The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[srcBlen - 1] + * sum = x[0] * y[srcBlen - 2] + x[1] * y[srcBlen - 1] + * .... + * sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen - 1] * y[srcBLen - 1] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + (srcBLen - 1U); + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] * y[srcBLen - 4] */ + sum += (q63_t) * px++ * (*py++); + /* x[1] * y[srcBLen - 3] */ + sum += (q63_t) * px++ * (*py++); + /* x[2] * y[srcBLen - 2] */ + sum += (q63_t) * px++ * (*py++); + /* x[3] * y[srcBLen - 1] */ + sum += (q63_t) * px++ * (*py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0] * y[srcBLen - 1] */ + sum += (q63_t) * px++ * (*py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q31_t) (sum >> 31); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pSrc1 - count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen-1] * y[srcBLen-1] + * sum = x[1] * y[0] + x[2] * y[1] +...+ x[srcBLen] * y[srcBLen-1] + * .... + * sum = x[srcALen-srcBLen-2] * y[0] + x[srcALen-srcBLen-1] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll by 3 */ + blkCnt = blockSize2 / 3; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + + /* read x[0], x[1] samples */ + x0 = *(px++); + x1 = *(px++); + + /* Apply loop unrolling and compute 3 MACs simultaneously. */ + k = srcBLen / 3; + + /* First part of the processing with loop unrolling. Compute 3 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 2 samples. */ + do + { + /* Read y[0] sample */ + c0 = *(py); + + /* Read x[2] sample */ + x2 = *(px); + + /* Perform the multiply-accumulate */ + /* acc0 += x[0] * y[0] */ + acc0 += ((q63_t) x0 * c0); + /* acc1 += x[1] * y[0] */ + acc1 += ((q63_t) x1 * c0); + /* acc2 += x[2] * y[0] */ + acc2 += ((q63_t) x2 * c0); + + /* Read y[1] sample */ + c0 = *(py + 1U); + + /* Read x[3] sample */ + x0 = *(px + 1U); + + /* Perform the multiply-accumulates */ + /* acc0 += x[1] * y[1] */ + acc0 += ((q63_t) x1 * c0); + /* acc1 += x[2] * y[1] */ + acc1 += ((q63_t) x2 * c0); + /* acc2 += x[3] * y[1] */ + acc2 += ((q63_t) x0 * c0); + + /* Read y[2] sample */ + c0 = *(py + 2U); + + /* Read x[4] sample */ + x1 = *(px + 2U); + + /* Perform the multiply-accumulates */ + /* acc0 += x[2] * y[2] */ + acc0 += ((q63_t) x2 * c0); + /* acc1 += x[3] * y[2] */ + acc1 += ((q63_t) x0 * c0); + /* acc2 += x[4] * y[2] */ + acc2 += ((q63_t) x1 * c0); + + /* update scratch pointers */ + px += 3U; + py += 3U; + + } while (--k); + + /* If the srcBLen is not a multiple of 3, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen - (3 * (srcBLen / 3)); + + while (k > 0U) + { + /* Read y[4] sample */ + c0 = *(py++); + + /* Read x[7] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[4] */ + acc0 += ((q63_t) x0 * c0); + /* acc1 += x[5] * y[4] */ + acc1 += ((q63_t) x1 * c0); + /* acc2 += x[6] * y[4] */ + acc2 += ((q63_t) x2 * c0); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q31_t) (acc0 >> 31); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + *pOut = (q31_t) (acc1 >> 31); + pOut += inc; + + *pOut = (q31_t) (acc2 >> 31); + pOut += inc; + + /* Increment the pointer pIn1 index, count by 3 */ + count += 3U; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 3, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 - 3 * (blockSize2 / 3); + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) * px++ * (*py++); + sum += (q63_t) * px++ * (*py++); + sum += (q63_t) * px++ * (*py++); + sum += (q63_t) * px++ * (*py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q31_t) (sum >> 31); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over srcBLen */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += (q63_t) * px++ * (*py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q31_t) (sum >> 31); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[0] + x[srcALen-srcBLen+2] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * sum += x[srcALen-srcBLen+2] * y[0] + x[srcALen-srcBLen+3] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * .... + * sum += x[srcALen-2] * y[0] + x[srcALen-1] * y[1] + * sum += x[srcALen-1] * y[0] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = pIn1 + (srcALen - (srcBLen - 1U)); + px = pSrc1; + + /* Working pointer of inputB */ + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* sum += x[srcALen - srcBLen + 4] * y[3] */ + sum += (q63_t) * px++ * (*py++); + /* sum += x[srcALen - srcBLen + 3] * y[2] */ + sum += (q63_t) * px++ * (*py++); + /* sum += x[srcALen - srcBLen + 2] * y[1] */ + sum += (q63_t) * px++ * (*py++); + /* sum += x[srcALen - srcBLen + 1] * y[0] */ + sum += (q63_t) * px++ * (*py++); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += (q63_t) * px++ * (*py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q31_t) (sum >> 31); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + q31_t *pIn1 = pSrcA; /* inputA pointer */ + q31_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q63_t sum; /* Accumulators */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and a varaible, inv is set to 1 */ + /* If lengths are not equal then zero pad has to be done to make the two + * inputs of same length. But to improve the performance, we include zeroes + * in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, (srcALen - srcBLen) zeroes has to included in the + * starting of the output buffer */ + /* If srcALen < srcBLen, (srcALen - srcBLen) zeroes has to included in the + * ending of the output buffer */ + /* Once the zero padding is done the remaining of the output is calcualted + * using correlation but with the shorter signal time shifted. */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate correlation for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to correlation equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q63_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q31_t) (sum >> 31U); + else + *pDst++ = (q31_t) (sum >> 31U); + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q7.c new file mode 100644 index 0000000..f8b1df5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_correlate_q7.c @@ -0,0 +1,778 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_correlate_q7.c + * Description: Correlation of Q7 sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup Corr + * @{ + */ + +/** + * @brief Correlation of Q7 sequences. + * @param[in] *pSrcA points to the first input sequence. + * @param[in] srcALen length of the first input sequence. + * @param[in] *pSrcB points to the second input sequence. + * @param[in] srcBLen length of the second input sequence. + * @param[out] *pDst points to the location where the output result is written. Length 2 * max(srcALen, srcBLen) - 1. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 32-bit internal accumulator. + * Both the inputs are represented in 1.7 format and multiplications yield a 2.14 result. + * The 2.14 intermediate results are accumulated in a 32-bit accumulator in 18.14 format. + * This approach provides 17 guard bits and there is no risk of overflow as long as max(srcALen, srcBLen)<131072. + * The 18.14 result is then truncated to 18.7 format by discarding the low 7 bits and saturated to 1.7 format. + * + * \par + * Refer the function arm_correlate_opt_q7() for a faster implementation of this function. + * + */ + +void arm_correlate_q7( + q7_t * pSrcA, + uint32_t srcALen, + q7_t * pSrcB, + uint32_t srcBLen, + q7_t * pDst) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q7_t *pIn1; /* inputA pointer */ + q7_t *pIn2; /* inputB pointer */ + q7_t *pOut = pDst; /* output pointer */ + q7_t *px; /* Intermediate inputA pointer */ + q7_t *py; /* Intermediate inputB pointer */ + q7_t *pSrc1; /* Intermediate pointers */ + q31_t sum, acc0, acc1, acc2, acc3; /* Accumulators */ + q31_t input1, input2; /* temporary variables */ + q15_t in1, in2; /* temporary variables */ + q7_t x0, x1, x2, x3, c0, c1; /* temporary variables for holding input and coefficient values */ + uint32_t j, k = 0U, count, blkCnt, outBlockSize, blockSize1, blockSize2, blockSize3; /* loop counter */ + int32_t inc = 1; + + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and the destination pointer modifier, inc is set to -1 */ + /* If srcALen > srcBLen, zero pad has to be done to srcB to make the two inputs of same length */ + /* But to improve the performance, + * we include zeroes in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, + * (srcALen - srcBLen) zeroes has to included in the starting of the output buffer */ + /* If srcALen < srcBLen, + * (srcALen - srcBLen) zeroes has to included in the ending of the output buffer */ + if (srcALen >= srcBLen) + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcA); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcB); + + /* Number of output samples is calculated */ + outBlockSize = (2U * srcALen) - 1U; + + /* When srcALen > srcBLen, zero padding is done to srcB + * to make their lengths equal. + * Instead, (outBlockSize - (srcALen + srcBLen - 1)) + * number of output samples are made zero */ + j = outBlockSize - (srcALen + (srcBLen - 1U)); + + /* Updating the pointer position to non zero value */ + pOut += j; + + } + else + { + /* Initialization of inputA pointer */ + pIn1 = (pSrcB); + + /* Initialization of inputB pointer */ + pIn2 = (pSrcA); + + /* srcBLen is always considered as shorter or equal to srcALen */ + j = srcBLen; + srcBLen = srcALen; + srcALen = j; + + /* CORR(x, y) = Reverse order(CORR(y, x)) */ + /* Hence set the destination pointer to point to the last output sample */ + pOut = pDst + ((srcALen + srcBLen) - 2U); + + /* Destination address modifier is set to -1 */ + inc = -1; + + } + + /* The function is internally + * divided into three parts according to the number of multiplications that has to be + * taken place between inputA samples and inputB samples. In the first part of the + * algorithm, the multiplications increase by one for every iteration. + * In the second part of the algorithm, srcBLen number of multiplications are done. + * In the third part of the algorithm, the multiplications decrease by one + * for every iteration.*/ + /* The algorithm is implemented in three stages. + * The loop counters of each stage is initiated here. */ + blockSize1 = srcBLen - 1U; + blockSize2 = srcALen - (srcBLen - 1U); + blockSize3 = blockSize1; + + /* -------------------------- + * Initializations of stage1 + * -------------------------*/ + + /* sum = x[0] * y[srcBlen - 1] + * sum = x[0] * y[srcBlen - 2] + x[1] * y[srcBlen - 1] + * .... + * sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen - 1] * y[srcBLen - 1] + */ + + /* In this stage the MAC operations are increased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = 1U; + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + pSrc1 = pIn2 + (srcBLen - 1U); + py = pSrc1; + + /* ------------------------ + * Stage1 process + * ----------------------*/ + + /* The first stage starts here */ + while (blockSize1 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[0] , x[1] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[srcBLen - 4] , y[srcBLen - 3] */ + in1 = (q15_t) * py++; + in2 = (q15_t) * py++; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* x[0] * y[srcBLen - 4] */ + /* x[1] * y[srcBLen - 3] */ + sum = __SMLAD(input1, input2, sum); + + /* x[2] , x[3] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[srcBLen - 2] , y[srcBLen - 1] */ + in1 = (q15_t) * py++; + in2 = (q15_t) * py++; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* x[2] * y[srcBLen - 2] */ + /* x[3] * y[srcBLen - 1] */ + sum = __SMLAD(input1, input2, sum); + + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + /* x[0] * y[srcBLen - 1] */ + sum += (q31_t) ((q15_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q7_t) (__SSAT(sum >> 7, 8)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + py = pSrc1 - count; + px = pIn1; + + /* Increment the MAC count */ + count++; + + /* Decrement the loop counter */ + blockSize1--; + } + + /* -------------------------- + * Initializations of stage2 + * ------------------------*/ + + /* sum = x[0] * y[0] + x[1] * y[1] +...+ x[srcBLen-1] * y[srcBLen-1] + * sum = x[1] * y[0] + x[2] * y[1] +...+ x[srcBLen] * y[srcBLen-1] + * .... + * sum = x[srcALen-srcBLen-2] * y[0] + x[srcALen-srcBLen-1] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + */ + + /* Working pointer of inputA */ + px = pIn1; + + /* Working pointer of inputB */ + py = pIn2; + + /* count is index by which the pointer pIn1 to be incremented */ + count = 0U; + + /* ------------------- + * Stage2 process + * ------------------*/ + + /* Stage2 depends on srcBLen as in this stage srcBLen number of MACS are performed. + * So, to loop unroll over blockSize2, + * srcBLen should be greater than or equal to 4 */ + if (srcBLen >= 4U) + { + /* Loop unroll over blockSize2, by 4 */ + blkCnt = blockSize2 >> 2U; + + while (blkCnt > 0U) + { + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* read x[0], x[1], x[2] samples */ + x0 = *px++; + x1 = *px++; + x2 = *px++; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + do + { + /* Read y[0] sample */ + c0 = *py++; + /* Read y[1] sample */ + c1 = *py++; + + /* Read x[3] sample */ + x3 = *px++; + + /* x[0] and x[1] are packed */ + in1 = (q15_t) x0; + in2 = (q15_t) x1; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[0] and y[1] are packed */ + in1 = (q15_t) c0; + in2 = (q15_t) c1; + + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc0 += x[0] * y[0] + x[1] * y[1] */ + acc0 = __SMLAD(input1, input2, acc0); + + /* x[1] and x[2] are packed */ + in1 = (q15_t) x1; + in2 = (q15_t) x2; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc1 += x[1] * y[0] + x[2] * y[1] */ + acc1 = __SMLAD(input1, input2, acc1); + + /* x[2] and x[3] are packed */ + in1 = (q15_t) x2; + in2 = (q15_t) x3; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc2 += x[2] * y[0] + x[3] * y[1] */ + acc2 = __SMLAD(input1, input2, acc2); + + /* Read x[4] sample */ + x0 = *(px++); + + /* x[3] and x[4] are packed */ + in1 = (q15_t) x3; + in2 = (q15_t) x0; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc3 += x[3] * y[0] + x[4] * y[1] */ + acc3 = __SMLAD(input1, input2, acc3); + + /* Read y[2] sample */ + c0 = *py++; + /* Read y[3] sample */ + c1 = *py++; + + /* Read x[5] sample */ + x1 = *px++; + + /* x[2] and x[3] are packed */ + in1 = (q15_t) x2; + in2 = (q15_t) x3; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[2] and y[3] are packed */ + in1 = (q15_t) c0; + in2 = (q15_t) c1; + + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc0 += x[2] * y[2] + x[3] * y[3] */ + acc0 = __SMLAD(input1, input2, acc0); + + /* x[3] and x[4] are packed */ + in1 = (q15_t) x3; + in2 = (q15_t) x0; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc1 += x[3] * y[2] + x[4] * y[3] */ + acc1 = __SMLAD(input1, input2, acc1); + + /* x[4] and x[5] are packed */ + in1 = (q15_t) x0; + in2 = (q15_t) x1; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc2 += x[4] * y[2] + x[5] * y[3] */ + acc2 = __SMLAD(input1, input2, acc2); + + /* Read x[6] sample */ + x2 = *px++; + + /* x[5] and x[6] are packed */ + in1 = (q15_t) x1; + in2 = (q15_t) x2; + + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* acc3 += x[5] * y[2] + x[6] * y[3] */ + acc3 = __SMLAD(input1, input2, acc3); + + } while (--k); + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Read y[4] sample */ + c0 = *py++; + + /* Read x[7] sample */ + x3 = *px++; + + /* Perform the multiply-accumulates */ + /* acc0 += x[4] * y[4] */ + acc0 += ((q15_t) x0 * c0); + /* acc1 += x[5] * y[4] */ + acc1 += ((q15_t) x1 * c0); + /* acc2 += x[6] * y[4] */ + acc2 += ((q15_t) x2 * c0); + /* acc3 += x[7] * y[4] */ + acc3 += ((q15_t) x3 * c0); + + /* Reuse the present samples for the next MAC */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q7_t) (__SSAT(acc0 >> 7, 8)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + *pOut = (q7_t) (__SSAT(acc1 >> 7, 8)); + pOut += inc; + + *pOut = (q7_t) (__SSAT(acc2 >> 7, 8)); + pOut += inc; + + *pOut = (q7_t) (__SSAT(acc3 >> 7, 8)); + pOut += inc; + + count += 4U; + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize2 is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize2 % 0x4U; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = srcBLen >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* Reading two inputs of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Reading two inputs of SrcB buffer and packing */ + in1 = (q15_t) * py++; + in2 = (q15_t) * py++; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Perform the multiply-accumulates */ + sum = __SMLAD(input1, input2, sum); + + /* Reading two inputs of SrcA buffer and packing */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Reading two inputs of SrcB buffer and packing */ + in1 = (q15_t) * py++; + in2 = (q15_t) * py++; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* Perform the multiply-accumulates */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the srcBLen is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = srcBLen % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q15_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q7_t) (__SSAT(sum >> 7, 8)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the pointer pIn1 index, count by 1 */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + /* Decrement the loop counter */ + blkCnt--; + } + } + else + { + /* If the srcBLen is not a multiple of 4, + * the blockSize2 loop cannot be unrolled by 4 */ + blkCnt = blockSize2; + + while (blkCnt > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Loop over srcBLen */ + k = srcBLen; + + while (k > 0U) + { + /* Perform the multiply-accumulate */ + sum += ((q15_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q7_t) (__SSAT(sum >> 7, 8)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Increment the MAC count */ + count++; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = pIn1 + count; + py = pIn2; + + + /* Decrement the loop counter */ + blkCnt--; + } + } + + /* -------------------------- + * Initializations of stage3 + * -------------------------*/ + + /* sum += x[srcALen-srcBLen+1] * y[0] + x[srcALen-srcBLen+2] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * sum += x[srcALen-srcBLen+2] * y[0] + x[srcALen-srcBLen+3] * y[1] +...+ x[srcALen-1] * y[srcBLen-1] + * .... + * sum += x[srcALen-2] * y[0] + x[srcALen-1] * y[1] + * sum += x[srcALen-1] * y[0] + */ + + /* In this stage the MAC operations are decreased by 1 for every iteration. + The count variable holds the number of MAC operations performed */ + count = srcBLen - 1U; + + /* Working pointer of inputA */ + pSrc1 = pIn1 + (srcALen - (srcBLen - 1U)); + px = pSrc1; + + /* Working pointer of inputB */ + py = pIn2; + + /* ------------------- + * Stage3 process + * ------------------*/ + + while (blockSize3 > 0U) + { + /* Accumulator is made zero for every iteration */ + sum = 0; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + k = count >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 MACs at a time. + ** a second loop below computes MACs for the remaining 1 to 3 samples. */ + while (k > 0U) + { + /* x[srcALen - srcBLen + 1] , x[srcALen - srcBLen + 2] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[0] , y[1] */ + in1 = (q15_t) * py++; + in2 = (q15_t) * py++; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* sum += x[srcALen - srcBLen + 1] * y[0] */ + /* sum += x[srcALen - srcBLen + 2] * y[1] */ + sum = __SMLAD(input1, input2, sum); + + /* x[srcALen - srcBLen + 3] , x[srcALen - srcBLen + 4] */ + in1 = (q15_t) * px++; + in2 = (q15_t) * px++; + input1 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* y[2] , y[3] */ + in1 = (q15_t) * py++; + in2 = (q15_t) * py++; + input2 = ((q31_t) in1 & 0x0000FFFF) | ((q31_t) in2 << 16); + + /* sum += x[srcALen - srcBLen + 3] * y[2] */ + /* sum += x[srcALen - srcBLen + 4] * y[3] */ + sum = __SMLAD(input1, input2, sum); + + /* Decrement the loop counter */ + k--; + } + + /* If the count is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + k = count % 0x4U; + + while (k > 0U) + { + /* Perform the multiply-accumulates */ + sum += ((q15_t) * px++ * *py++); + + /* Decrement the loop counter */ + k--; + } + + /* Store the result in the accumulator in the destination buffer. */ + *pOut = (q7_t) (__SSAT(sum >> 7, 8)); + /* Destination pointer is updated according to the address modifier, inc */ + pOut += inc; + + /* Update the inputA and inputB pointers for next MAC calculation */ + px = ++pSrc1; + py = pIn2; + + /* Decrement the MAC count */ + count--; + + /* Decrement the loop counter */ + blockSize3--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + q7_t *pIn1 = pSrcA; /* inputA pointer */ + q7_t *pIn2 = pSrcB + (srcBLen - 1U); /* inputB pointer */ + q31_t sum; /* Accumulator */ + uint32_t i = 0U, j; /* loop counters */ + uint32_t inv = 0U; /* Reverse order flag */ + uint32_t tot = 0U; /* Length */ + + /* The algorithm implementation is based on the lengths of the inputs. */ + /* srcB is always made to slide across srcA. */ + /* So srcBLen is always considered as shorter or equal to srcALen */ + /* But CORR(x, y) is reverse of CORR(y, x) */ + /* So, when srcBLen > srcALen, output pointer is made to point to the end of the output buffer */ + /* and a varaible, inv is set to 1 */ + /* If lengths are not equal then zero pad has to be done to make the two + * inputs of same length. But to improve the performance, we include zeroes + * in the output instead of zero padding either of the the inputs*/ + /* If srcALen > srcBLen, (srcALen - srcBLen) zeroes has to included in the + * starting of the output buffer */ + /* If srcALen < srcBLen, (srcALen - srcBLen) zeroes has to included in the + * ending of the output buffer */ + /* Once the zero padding is done the remaining of the output is calcualted + * using convolution but with the shorter signal time shifted. */ + + /* Calculate the length of the remaining sequence */ + tot = ((srcALen + srcBLen) - 2U); + + if (srcALen > srcBLen) + { + /* Calculating the number of zeros to be padded to the output */ + j = srcALen - srcBLen; + + /* Initialise the pointer after zero padding */ + pDst += j; + } + + else if (srcALen < srcBLen) + { + /* Initialization to inputB pointer */ + pIn1 = pSrcB; + + /* Initialization to the end of inputA pointer */ + pIn2 = pSrcA + (srcALen - 1U); + + /* Initialisation of the pointer after zero padding */ + pDst = pDst + tot; + + /* Swapping the lengths */ + j = srcALen; + srcALen = srcBLen; + srcBLen = j; + + /* Setting the reverse flag */ + inv = 1; + + } + + /* Loop to calculate convolution for output length number of times */ + for (i = 0U; i <= tot; i++) + { + /* Initialize sum with zero to carry on MAC operations */ + sum = 0; + + /* Loop to perform MAC operations according to convolution equation */ + for (j = 0U; j <= i; j++) + { + /* Check the array limitations */ + if ((((i - j) < srcBLen) && (j < srcALen))) + { + /* z[i] += x[i-j] * y[j] */ + sum += ((q15_t) pIn1[j] * pIn2[-((int32_t) i - j)]); + } + } + /* Store the output in the destination buffer */ + if (inv == 1) + *pDst-- = (q7_t) __SSAT((sum >> 7U), 8U); + else + *pDst++ = (q7_t) __SSAT((sum >> 7U), 8U); + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of Corr group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_f32.c new file mode 100644 index 0000000..fd8e237 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_f32.c @@ -0,0 +1,512 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_f32.c + * Description: FIR decimation for floating-point sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup FIR_decimate Finite Impulse Response (FIR) Decimator + * + * These functions combine an FIR filter together with a decimator. + * They are used in multirate systems for reducing the sample rate of a signal without introducing aliasing distortion. + * Conceptually, the functions are equivalent to the block diagram below: + * \image html FIRDecimator.gif "Components included in the FIR Decimator functions" + * When decimating by a factor of M, the signal should be prefiltered by a lowpass filter with a normalized + * cutoff frequency of 1/M in order to prevent aliasing distortion. + * The user of the function is responsible for providing the filter coefficients. + * + * The FIR decimator functions provided in the CMSIS DSP Library combine the FIR filter and the decimator in an efficient manner. + * Instead of calculating all of the FIR filter outputs and discarding M-1 out of every M, only the + * samples output by the decimator are computed. + * The functions operate on blocks of input and output data. + * pSrc points to an array of blockSize input values and + * pDst points to an array of blockSize/M output values. + * In order to have an integer number of output samples blockSize + * must always be a multiple of the decimation factor M. + * + * The library provides separate functions for Q15, Q31 and floating-point data types. + * + * \par Algorithm: + * The FIR portion of the algorithm uses the standard form filter: + *
+ *    y[n] = b[0] * x[n] + b[1] * x[n-1] + b[2] * x[n-2] + ...+ b[numTaps-1] * x[n-numTaps+1]
+ * 
+ * where, b[n] are the filter coefficients. + * \par + * The pCoeffs points to a coefficient array of size numTaps. + * Coefficients are stored in time reversed order. + * \par + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to a state array of size numTaps + blockSize - 1. + * Samples in the state buffer are stored in the order: + * \par + *
+ *    {x[n-numTaps+1], x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2]....x[0], x[1], ..., x[blockSize-1]}
+ * 
+ * The state variables are updated after each block of data is processed, the coefficients are untouched. + * + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter. + * Coefficient arrays may be shared among several instances while state variable array should be allocated separately. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * - Checks to make sure that the size of the input is a multiple of the decimation factor. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numTaps, pCoeffs, M (decimation factor), pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * The code below statically initializes each of the 3 different data type filter instance structures + *
+ *arm_fir_decimate_instance_f32 S = {M, numTaps, pCoeffs, pState};
+ *arm_fir_decimate_instance_q31 S = {M, numTaps, pCoeffs, pState};
+ *arm_fir_decimate_instance_q15 S = {M, numTaps, pCoeffs, pState};
+ * 
+ * where M is the decimation factor; numTaps is the number of filter coefficients in the filter; + * pCoeffs is the address of the coefficient buffer; + * pState is the address of the state buffer. + * Be sure to set the values in the state buffer to zeros when doing static initialization. + * + * \par Fixed-Point Behavior + * Care must be taken when using the fixed-point versions of the FIR decimate filter functions. + * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + + /** + * @brief Processing function for the floating-point FIR decimator. + * @param[in] *S points to an instance of the floating-point FIR decimator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of input samples to process per call. + * @return none. + */ + +void arm_fir_decimate_f32( + const arm_fir_decimate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + float32_t sum0; /* Accumulator */ + float32_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, tapCnt, blkCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + +#if defined (ARM_MATH_DSP) + + uint32_t blkCntN4; + float32_t *px0, *px1, *px2, *px3; + float32_t acc0, acc1, acc2, acc3; + float32_t x1, x2, x3; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize / 4; + blkCntN4 = outBlockSize - (4 * blkCnt); + + while (blkCnt > 0U) + { + /* Copy 4 * decimation factor number of new input samples into the state buffer */ + i = 4 * S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulators to zero */ + acc0 = 0.0f; + acc1 = 0.0f; + acc2 = 0.0f; + acc3 = 0.0f; + + /* Initialize state pointer for all the samples */ + px0 = pState; + px1 = pState + S->M; + px2 = pState + 2 * S->M; + px3 = pState + 3 * S->M; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + + while (tapCnt > 0U) + { + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-1] sample for acc0 */ + x0 = *(px0++); + /* Read x[n-numTaps-1] sample for acc1 */ + x1 = *(px1++); + /* Read x[n-numTaps-1] sample for acc2 */ + x2 = *(px2++); + /* Read x[n-numTaps-1] sample for acc3 */ + x3 = *(px3++); + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-2] sample for acc0, acc1, acc2, acc3 */ + x0 = *(px0++); + x1 = *(px1++); + x2 = *(px2++); + x3 = *(px3++); + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + + /* Read the b[numTaps-3] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-3] sample acc0, acc1, acc2, acc3 */ + x0 = *(px0++); + x1 = *(px1++); + x2 = *(px2++); + x3 = *(px3++); + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-4] sample acc0, acc1, acc2, acc3 */ + x0 = *(px0++); + x1 = *(px1++); + x2 = *(px2++); + x3 = *(px3++); + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch state variables for acc0, acc1, acc2, acc3 */ + x0 = *(px0++); + x1 = *(px1++); + x2 = *(px2++); + x3 = *(px3++); + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + 4 * S->M; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = acc0; + *pDst++ = acc1; + *pDst++ = acc2; + *pDst++ = acc3; + + /* Decrement the loop counter */ + blkCnt--; + } + + while (blkCntN4 > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0.0f; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-1] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-2] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-3] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-3] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = sum0; + + /* Decrement the loop counter */ + blkCntN4--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (numTaps - 1U) >> 2; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + + i = (numTaps - 1U) % 0x04U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0.0f; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = sum0; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy numTaps number of values */ + i = (numTaps - 1U); + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q15.c new file mode 100644 index 0000000..684640e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q15.c @@ -0,0 +1,586 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_fast_q15.c + * Description: Fast Q15 FIR Decimator + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + +/** + * @brief Processing function for the Q15 FIR decimator (fast variant) for Cortex-M3 and Cortex-M4. + * @param[in] *S points to an instance of the Q15 FIR decimator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + * @return none + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, state buffers should be aligned by 32-bit + * + * Scaling and Overflow Behavior: + * \par + * This fast version uses a 32-bit accumulator with 2.30 format. + * The accumulator maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around and distorts the result. + * In order to avoid overflows completely the input signal must be scaled down by log2(numTaps) bits (log2 is read as log to the base 2). + * The 2.30 accumulator is then truncated to 2.15 format and saturated to yield the 1.15 result. + * + * \par + * Refer to the function arm_fir_decimate_q15() for a slower implementation of this function which uses 64-bit accumulation to avoid wrap around distortion. + * Both the slow and the fast versions use the same instance structure. + * Use the function arm_fir_decimate_init_q15() to initialize the filter structure. + */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + +void arm_fir_decimate_fast_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px; /* Temporary pointer for state buffer */ + q15_t *pb; /* Temporary pointer coefficient buffer */ + q31_t x0, x1, c0, c1; /* Temporary variables to hold state and coefficient values */ + q31_t sum0; /* Accumulators */ + q31_t acc0, acc1; + q15_t *px0, *px1; + uint32_t blkCntN3; + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt, tapCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize / 2; + blkCntN3 = outBlockSize - (2 * blkCnt); + + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = 2 * S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + acc0 = 0; + acc1 = 0; + + /* Initialize state pointer */ + px0 = pState; + + px1 = pState + S->M; + + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] and b[numTaps-2] coefficients */ + c0 = *__SIMD32(pb)++; + + /* Read x[n-numTaps-1] and x[n-numTaps-2]sample */ + x0 = *__SIMD32(px0)++; + + x1 = *__SIMD32(px1)++; + + /* Perform the multiply-accumulate */ + acc0 = __SMLAD(x0, c0, acc0); + + acc1 = __SMLAD(x1, c0, acc1); + + /* Read the b[numTaps-3] and b[numTaps-4] coefficient */ + c0 = *__SIMD32(pb)++; + + /* Read x[n-numTaps-2] and x[n-numTaps-3] sample */ + x0 = *__SIMD32(px0)++; + + x1 = *__SIMD32(px1)++; + + /* Perform the multiply-accumulate */ + acc0 = __SMLAD(x0, c0, acc0); + + acc1 = __SMLAD(x1, c0, acc1); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px0++; + + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 = __SMLAD(x0, c0, acc0); + acc1 = __SMLAD(x1, c0, acc1); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M * 2; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + *pDst++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + *pDst++ = (q15_t) (__SSAT((acc1 >> 15), 16)); + + /* Decrement the loop counter */ + blkCnt--; + } + + + + while (blkCntN3 > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /*Set sum to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] and b[numTaps-2] coefficients */ + c0 = *__SIMD32(pb)++; + + /* Read x[n-numTaps-1] and x[n-numTaps-2]sample */ + x0 = *__SIMD32(px)++; + + /* Read the b[numTaps-3] and b[numTaps-4] coefficient */ + c1 = *__SIMD32(pb)++; + + /* Perform the multiply-accumulate */ + sum0 = __SMLAD(x0, c0, sum0); + + /* Read x[n-numTaps-2] and x[n-numTaps-3] sample */ + x0 = *__SIMD32(px)++; + + /* Perform the multiply-accumulate */ + sum0 = __SMLAD(x0, c1, sum0); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 = __SMLAD(x0, c0, sum0); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + *pDst++ = (q15_t) (__SSAT((sum0 >> 15), 16)); + + /* Decrement the loop counter */ + blkCntN3--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (numTaps - 1U) >> 2U; + + /* copy data */ + while (i > 0U) + { + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + + /* Decrement the loop counter */ + i--; + } + + i = (numTaps - 1U) % 0x04U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +#else + + +void arm_fir_decimate_fast_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px; /* Temporary pointer for state buffer */ + q15_t *pb; /* Temporary pointer coefficient buffer */ + q15_t x0, x1, c0; /* Temporary variables to hold state and coefficient values */ + q31_t sum0; /* Accumulators */ + q31_t acc0, acc1; + q15_t *px0, *px1; + uint32_t blkCntN3; + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt, tapCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize / 2; + blkCntN3 = outBlockSize - (2 * blkCnt); + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = 2 * S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + acc0 = 0; + acc1 = 0; + + /* Initialize state pointer */ + px0 = pState; + + px1 = pState + S->M; + + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-1] for sample 0 and for sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-2] for sample 0 and sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Read the b[numTaps-3] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-3] for sample 0 and sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-4] for sample 0 and sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M * 2; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + + *pDst++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + *pDst++ = (q15_t) (__SSAT((acc1 >> 15), 16)); + + + /* Decrement the loop counter */ + blkCnt--; + } + + while (blkCntN3 > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /*Set sum to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-1] and sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-2] and sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-3] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-3] sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-4] sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + *pDst++ = (q15_t) (__SSAT((sum0 >> 15), 16)); + + /* Decrement the loop counter */ + blkCntN3--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (numTaps - 1U) >> 2U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + + i = (numTaps - 1U) % 0x04U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q31.c new file mode 100644 index 0000000..46b7d3d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_fast_q31.c @@ -0,0 +1,339 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_fast_q31.c + * Description: Fast Q31 FIR Decimator + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + +/** + * @brief Processing function for the Q31 FIR decimator (fast variant) for Cortex-M3 and Cortex-M4. + * @param[in] *S points to an instance of the Q31 FIR decimator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + * @return none + * + * Scaling and Overflow Behavior: + * + * \par + * This function is optimized for speed at the expense of fixed-point precision and overflow protection. + * The result of each 1.31 x 1.31 multiplication is truncated to 2.30 format. + * These intermediate results are added to a 2.30 accumulator. + * Finally, the accumulator is saturated and converted to a 1.31 result. + * The fast version has the same overflow behavior as the standard version and provides less precision since it discards the low 32 bits of each multiplication result. + * In order to avoid overflows completely the input signal must be scaled down by log2(numTaps) bits (where log2 is read as log to the base 2). + * + * \par + * Refer to the function arm_fir_decimate_q31() for a slower implementation of this function which uses a 64-bit accumulator to provide higher precision. + * Both the slow and the fast versions use the same instance structure. + * Use the function arm_fir_decimate_init_q31() to initialize the filter structure. + */ + +void arm_fir_decimate_fast_q31( + arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + q31_t *px; /* Temporary pointers for state buffer */ + q31_t *pb; /* Temporary pointers for coefficient buffer */ + q31_t sum0; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, tapCnt, blkCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + uint32_t blkCntN2; + q31_t x1; + q31_t acc0, acc1; + q31_t *px0, *px1; + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + /* Total number of output samples to be computed */ + + blkCnt = outBlockSize / 2; + blkCntN2 = outBlockSize - (2 * blkCnt); + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = 2 * S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + acc0 = 0; + acc1 = 0; + + /* Initialize state pointer */ + px0 = pState; + px1 = pState + S->M; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb); + + /* Read x[n-numTaps-1] for sample 0 sample 1 */ + x0 = *(px0); + x1 = *(px1); + + /* Perform the multiply-accumulate */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb + 1U); + + /* Read x[n-numTaps-2] for sample 0 sample 1 */ + x0 = *(px0 + 1U); + x1 = *(px1 + 1U); + + /* Perform the multiply-accumulate */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* Read the b[numTaps-3] coefficient */ + c0 = *(pb + 2U); + + /* Read x[n-numTaps-3] for sample 0 sample 1 */ + x0 = *(px0 + 2U); + x1 = *(px1 + 2U); + pb += 4U; + + /* Perform the multiply-accumulate */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb - 1U); + + /* Read x[n-numTaps-4] for sample 0 sample 1 */ + x0 = *(px0 + 3U); + x1 = *(px1 + 3U); + + + /* Perform the multiply-accumulate */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* update state pointers */ + px0 += 4U; + px1 += 4U; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x0 = *(px0++); + x1 = *(px1++); + + /* Perform the multiply-accumulate */ + acc0 = (q31_t) ((((q63_t) acc0 << 32) + ((q63_t) x0 * c0)) >> 32); + acc1 = (q31_t) ((((q63_t) acc1 << 32) + ((q63_t) x1 * c0)) >> 32); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M * 2; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (acc0 << 1); + *pDst++ = (q31_t) (acc1 << 1); + + /* Decrement the loop counter */ + blkCnt--; + } + + while (blkCntN2 > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-1] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 = (q31_t) ((((q63_t) sum0 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-2] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 = (q31_t) ((((q63_t) sum0 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Read the b[numTaps-3] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-3] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 = (q31_t) ((((q63_t) sum0 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 = (q31_t) ((((q63_t) sum0 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 = (q31_t) ((((q63_t) sum0 << 32) + ((q63_t) x0 * c0)) >> 32); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (sum0 << 1); + + /* Decrement the loop counter */ + blkCntN2--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (numTaps - 1U) >> 2U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + + i = (numTaps - 1U) % 0x04U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_f32.c new file mode 100644 index 0000000..45797dc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_f32.c @@ -0,0 +1,105 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_init_f32.c + * Description: Floating-point FIR Decimator initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + +/** + * @brief Initialization function for the floating-point FIR decimator. + * @param[in,out] *S points to an instance of the floating-point FIR decimator structure. + * @param[in] numTaps number of coefficients in the filter. + * @param[in] M decimation factor. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_LENGTH_ERROR if + * blockSize is not a multiple of M. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to the array of state variables. + * pState is of length numTaps+blockSize-1 words where blockSize is the number of input samples passed to arm_fir_decimate_f32(). + * M is the decimation factor. + */ + +arm_status arm_fir_decimate_init_f32( + arm_fir_decimate_instance_f32 * S, + uint16_t numTaps, + uint8_t M, + float32_t * pCoeffs, + float32_t * pState, + uint32_t blockSize) +{ + arm_status status; + + /* The size of the input block must be a multiple of the decimation factor */ + if ((blockSize % M) != 0U) + { + /* Set status as ARM_MATH_LENGTH_ERROR */ + status = ARM_MATH_LENGTH_ERROR; + } + else + { + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always (blockSize + numTaps - 1) */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Decimation Factor */ + S->M = M; + + status = ARM_MATH_SUCCESS; + } + + return (status); + +} + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q15.c new file mode 100644 index 0000000..7314711 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q15.c @@ -0,0 +1,107 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_init_q15.c + * Description: Initialization function for the Q15 FIR Decimator + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + +/** + * @brief Initialization function for the Q15 FIR decimator. + * @param[in,out] *S points to an instance of the Q15 FIR decimator structure. + * @param[in] numTaps number of coefficients in the filter. + * @param[in] M decimation factor. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_LENGTH_ERROR if + * blockSize is not a multiple of M. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to the array of state variables. + * pState is of length numTaps+blockSize-1 words where blockSize is the number of input samples + * to the call arm_fir_decimate_q15(). + * M is the decimation factor. + */ + +arm_status arm_fir_decimate_init_q15( + arm_fir_decimate_instance_q15 * S, + uint16_t numTaps, + uint8_t M, + q15_t * pCoeffs, + q15_t * pState, + uint32_t blockSize) +{ + + arm_status status; + + /* The size of the input block must be a multiple of the decimation factor */ + if ((blockSize % M) != 0U) + { + /* Set status as ARM_MATH_LENGTH_ERROR */ + status = ARM_MATH_LENGTH_ERROR; + } + else + { + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear the state buffer. The size of buffer is always (blockSize + numTaps - 1) */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Decimation factor */ + S->M = M; + + status = ARM_MATH_SUCCESS; + } + + return (status); + +} + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q31.c new file mode 100644 index 0000000..f6f3fb2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_init_q31.c @@ -0,0 +1,105 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_init_q31.c + * Description: Initialization function for Q31 FIR Decimation filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + +/** + * @brief Initialization function for the Q31 FIR decimator. + * @param[in,out] *S points to an instance of the Q31 FIR decimator structure. + * @param[in] numTaps number of coefficients in the filter. + * @param[in] M decimation factor. + * @param[in] *pCoeffs points to the filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_LENGTH_ERROR if + * blockSize is not a multiple of M. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to the array of state variables. + * pState is of length numTaps+blockSize-1 words where blockSize is the number of input samples passed to arm_fir_decimate_q31(). + * M is the decimation factor. + */ + +arm_status arm_fir_decimate_init_q31( + arm_fir_decimate_instance_q31 * S, + uint16_t numTaps, + uint8_t M, + q31_t * pCoeffs, + q31_t * pState, + uint32_t blockSize) +{ + arm_status status; + + /* The size of the input block must be a multiple of the decimation factor */ + if ((blockSize % M) != 0U) + { + /* Set status as ARM_MATH_LENGTH_ERROR */ + status = ARM_MATH_LENGTH_ERROR; + } + else + { + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear the state buffer. The size is always (blockSize + numTaps - 1) */ + memset(pState, 0, (numTaps + (blockSize - 1)) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Decimation factor */ + S->M = M; + + status = ARM_MATH_SUCCESS; + } + + return (status); + +} + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q15.c new file mode 100644 index 0000000..56f12fb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q15.c @@ -0,0 +1,684 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_q15.c + * Description: Q15 FIR Decimator + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + +/** + * @brief Processing function for the Q15 FIR decimator. + * @param[in] *S points to an instance of the Q15 FIR decimator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the location where the output result is written. + * @param[in] blockSize number of input samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both coefficients and state variables are represented in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * After all additions have been performed, the accumulator is truncated to 34.15 format by discarding low 15 bits. + * Lastly, the accumulator is saturated to yield a result in 1.15 format. + * + * \par + * Refer to the function arm_fir_decimate_fast_q15() for a faster but less precise implementation of this function for Cortex-M3 and Cortex-M4. + */ + +#if defined (ARM_MATH_DSP) + +#ifndef UNALIGNED_SUPPORT_DISABLE + +void arm_fir_decimate_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px; /* Temporary pointer for state buffer */ + q15_t *pb; /* Temporary pointer coefficient buffer */ + q31_t x0, x1, c0, c1; /* Temporary variables to hold state and coefficient values */ + q63_t sum0; /* Accumulators */ + q63_t acc0, acc1; + q15_t *px0, *px1; + uint32_t blkCntN3; + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt, tapCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize / 2; + blkCntN3 = outBlockSize - (2 * blkCnt); + + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = 2 * S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + acc0 = 0; + acc1 = 0; + + /* Initialize state pointer */ + px0 = pState; + + px1 = pState + S->M; + + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] and b[numTaps-2] coefficients */ + c0 = *__SIMD32(pb)++; + + /* Read x[n-numTaps-1] and x[n-numTaps-2]sample */ + x0 = *__SIMD32(px0)++; + + x1 = *__SIMD32(px1)++; + + /* Perform the multiply-accumulate */ + acc0 = __SMLALD(x0, c0, acc0); + + acc1 = __SMLALD(x1, c0, acc1); + + /* Read the b[numTaps-3] and b[numTaps-4] coefficient */ + c0 = *__SIMD32(pb)++; + + /* Read x[n-numTaps-2] and x[n-numTaps-3] sample */ + x0 = *__SIMD32(px0)++; + + x1 = *__SIMD32(px1)++; + + /* Perform the multiply-accumulate */ + acc0 = __SMLALD(x0, c0, acc0); + + acc1 = __SMLALD(x1, c0, acc1); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px0++; + + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 = __SMLALD(x0, c0, acc0); + acc1 = __SMLALD(x1, c0, acc1); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M * 2; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + *pDst++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + *pDst++ = (q15_t) (__SSAT((acc1 >> 15), 16)); + + /* Decrement the loop counter */ + blkCnt--; + } + + + + while (blkCntN3 > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /*Set sum to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] and b[numTaps-2] coefficients */ + c0 = *__SIMD32(pb)++; + + /* Read x[n-numTaps-1] and x[n-numTaps-2]sample */ + x0 = *__SIMD32(px)++; + + /* Read the b[numTaps-3] and b[numTaps-4] coefficient */ + c1 = *__SIMD32(pb)++; + + /* Perform the multiply-accumulate */ + sum0 = __SMLALD(x0, c0, sum0); + + /* Read x[n-numTaps-2] and x[n-numTaps-3] sample */ + x0 = *__SIMD32(px)++; + + /* Perform the multiply-accumulate */ + sum0 = __SMLALD(x0, c1, sum0); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 = __SMLALD(x0, c0, sum0); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + *pDst++ = (q15_t) (__SSAT((sum0 >> 15), 16)); + + /* Decrement the loop counter */ + blkCntN3--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (numTaps - 1U) >> 2U; + + /* copy data */ + while (i > 0U) + { + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + + /* Decrement the loop counter */ + i--; + } + + i = (numTaps - 1U) % 0x04U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +#else + + +void arm_fir_decimate_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px; /* Temporary pointer for state buffer */ + q15_t *pb; /* Temporary pointer coefficient buffer */ + q15_t x0, x1, c0; /* Temporary variables to hold state and coefficient values */ + q63_t sum0; /* Accumulators */ + q63_t acc0, acc1; + q15_t *px0, *px1; + uint32_t blkCntN3; + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt, tapCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize / 2; + blkCntN3 = outBlockSize - (2 * blkCnt); + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = 2 * S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + acc0 = 0; + acc1 = 0; + + /* Initialize state pointer */ + px0 = pState; + + px1 = pState + S->M; + + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-1] for sample 0 and for sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-2] for sample 0 and sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Read the b[numTaps-3] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-3] for sample 0 and sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-4] for sample 0 and sample 1 */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px0++; + x1 = *px1++; + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M * 2; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + + *pDst++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + *pDst++ = (q15_t) (__SSAT((acc1 >> 15), 16)); + + /* Decrement the loop counter */ + blkCnt--; + } + + while (blkCntN3 > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /*Set sum to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the Read b[numTaps-1] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-1] and sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-2] and sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-3] coefficients */ + c0 = *pb++; + + /* Read x[n-numTaps-3] sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *pb++; + + /* Read x[n-numTaps-4] sample */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* Store filter output, smlad returns the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + *pDst++ = (q15_t) (__SSAT((sum0 >> 15), 16)); + + /* Decrement the loop counter */ + blkCntN3--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (numTaps - 1U) >> 2U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + + i = (numTaps - 1U) % 0x04U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +#else + + +void arm_fir_decimate_q15( + const arm_fir_decimate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px; /* Temporary pointer for state buffer */ + q15_t *pb; /* Temporary pointer coefficient buffer */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + q63_t sum0; /* Accumulators */ + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, blkCnt, tapCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + + + +/* Run the below code for Cortex-M0 */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /*Set sum to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += (q31_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /*Store filter output , smlad will return the values in 2.14 format */ + /* so downsacle by 15 to get output in 1.15 */ + *pDst++ = (q15_t) (__SSAT((sum0 >> 15), 16)); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = numTaps - 1U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + + +} +#endif /* #if defined (ARM_MATH_DSP) */ + + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q31.c new file mode 100644 index 0000000..6a13cb5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_decimate_q31.c @@ -0,0 +1,299 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_decimate_q31.c + * Description: Q31 FIR Decimator + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_decimate + * @{ + */ + +/** + * @brief Processing function for the Q31 FIR decimator. + * @param[in] *S points to an instance of the Q31 FIR decimator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] blockSize number of input samples to process per call. + * @return none + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clip. + * In order to avoid overflows completely the input signal must be scaled down by log2(numTaps) bits (where log2 is read as log to the base 2). + * After all multiply-accumulates are performed, the 2.62 accumulator is truncated to 1.32 format and then saturated to 1.31 format. + * + * \par + * Refer to the function arm_fir_decimate_fast_q31() for a faster but less precise implementation of this function for Cortex-M3 and Cortex-M4. + */ + +void arm_fir_decimate_q31( + const arm_fir_decimate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + q31_t *px; /* Temporary pointers for state buffer */ + q31_t *pb; /* Temporary pointers for coefficient buffer */ + q63_t sum0; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Number of taps */ + uint32_t i, tapCnt, blkCnt, outBlockSize = blockSize / S->M; /* Loop counters */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + while (tapCnt > 0U) + { + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-1] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-2] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the b[numTaps-3] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-3] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (sum0 >> 31); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (numTaps - 1U) >> 2U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + + i = (numTaps - 1U) % 0x04U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + /* Total number of output samples to be computed */ + blkCnt = outBlockSize; + + while (blkCnt > 0U) + { + /* Copy decimation factor number of new input samples into the state buffer */ + i = S->M; + + do + { + *pStateCurnt++ = *pSrc++; + + } while (--i); + + /* Set accumulator to zero */ + sum0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = pCoeffs; + + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *pb++; + + /* Fetch 1 state variable */ + x0 = *px++; + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by the decimation factor + * to process the next group of decimation factor number samples */ + pState = pState + S->M; + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (sum0 >> 31); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = numTaps - 1U; + + /* copy data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_decimate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_f32.c new file mode 100644 index 0000000..812f9df --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_f32.c @@ -0,0 +1,985 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_f32.c + * Description: Floating-point FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** +* @ingroup groupFilters +*/ + +/** +* @defgroup FIR Finite Impulse Response (FIR) Filters +* +* This set of functions implements Finite Impulse Response (FIR) filters +* for Q7, Q15, Q31, and floating-point data types. Fast versions of Q15 and Q31 are also provided. +* The functions operate on blocks of input and output data and each call to the function processes +* blockSize samples through the filter. pSrc and +* pDst points to input and output arrays containing blockSize values. +* +* \par Algorithm: +* The FIR filter algorithm is based upon a sequence of multiply-accumulate (MAC) operations. +* Each filter coefficient b[n] is multiplied by a state variable which equals a previous input sample x[n]. +*
+*    y[n] = b[0] * x[n] + b[1] * x[n-1] + b[2] * x[n-2] + ...+ b[numTaps-1] * x[n-numTaps+1]
+* 
+* \par +* \image html FIR.gif "Finite Impulse Response filter" +* \par +* pCoeffs points to a coefficient array of size numTaps. +* Coefficients are stored in time reversed order. +* \par +*
+*    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+* 
+* \par +* pState points to a state array of size numTaps + blockSize - 1. +* Samples in the state buffer are stored in the following order. +* \par +*
+*    {x[n-numTaps+1], x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2]....x[0], x[1], ..., x[blockSize-1]}
+* 
+* \par +* Note that the length of the state buffer exceeds the length of the coefficient array by blockSize-1. +* The increased state buffer length allows circular addressing, which is traditionally used in the FIR filters, +* to be avoided and yields a significant speed improvement. +* The state variables are updated after each block of data is processed; the coefficients are untouched. +* \par Instance Structure +* The coefficients and state variables for a filter are stored together in an instance data structure. +* A separate instance structure must be defined for each filter. +* Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. +* There are separate instance structure declarations for each of the 4 supported data types. +* +* \par Initialization Functions +* There is also an associated initialization function for each data type. +* The initialization function performs the following operations: +* - Sets the values of the internal structure fields. +* - Zeros out the values in the state buffer. +* To do this manually without calling the init function, assign the follow subfields of the instance structure: +* numTaps, pCoeffs, pState. Also set all of the values in pState to zero. +* +* \par +* Use of the initialization function is optional. +* However, if the initialization function is used, then the instance structure cannot be placed into a const data section. +* To place an instance structure into a const data section, the instance structure must be manually initialized. +* Set the values in the state buffer to zeros before static initialization. +* The code below statically initializes each of the 4 different data type filter instance structures +*
+*arm_fir_instance_f32 S = {numTaps, pState, pCoeffs};
+*arm_fir_instance_q31 S = {numTaps, pState, pCoeffs};
+*arm_fir_instance_q15 S = {numTaps, pState, pCoeffs};
+*arm_fir_instance_q7 S =  {numTaps, pState, pCoeffs};
+* 
+* +* where numTaps is the number of filter coefficients in the filter; pState is the address of the state buffer; +* pCoeffs is the address of the coefficient buffer. +* +* \par Fixed-Point Behavior +* Care must be taken when using the fixed-point versions of the FIR filter functions. +* In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. +* Refer to the function specific documentation below for usage guidelines. +*/ + +/** +* @addtogroup FIR +* @{ +*/ + +/** +* +* @param[in] *S points to an instance of the floating-point FIR filter structure. +* @param[in] *pSrc points to the block of input data. +* @param[out] *pDst points to the block of output data. +* @param[in] blockSize number of samples to process per call. +* @return none. +* +*/ + +#if defined(ARM_MATH_CM7) + +void arm_fir_f32( +const arm_fir_instance_f32 * S, +float32_t * pSrc, +float32_t * pDst, +uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + float32_t acc0, acc1, acc2, acc3, acc4, acc5, acc6, acc7; /* Accumulators */ + float32_t x0, x1, x2, x3, x4, x5, x6, x7, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, tapCnt, blkCnt; /* Loop counters */ + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 8 output values simultaneously. + * The variables acc0 ... acc7 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + blkCnt = blockSize >> 3; + + /* First part of the processing with loop unrolling. Compute 8 outputs at a time. + ** a second loop below computes the remaining 1 to 7 samples. */ + while (blkCnt > 0U) + { + /* Copy four new input samples into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Set all accumulators to zero */ + acc0 = 0.0f; + acc1 = 0.0f; + acc2 = 0.0f; + acc3 = 0.0f; + acc4 = 0.0f; + acc5 = 0.0f; + acc6 = 0.0f; + acc7 = 0.0f; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* This is separated from the others to avoid + * a call to __aeabi_memmove which would be slower + */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Read the first seven samples from the state buffer: x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2] */ + x0 = *px++; + x1 = *px++; + x2 = *px++; + x3 = *px++; + x4 = *px++; + x5 = *px++; + x6 = *px++; + + /* Loop unrolling. Process 8 taps at a time. */ + tapCnt = numTaps >> 3U; + + /* Loop over the number of taps. Unroll by a factor of 8. + ** Repeat until we've computed numTaps-8 coefficients. */ + while (tapCnt > 0U) + { + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-3] sample */ + x7 = *(px++); + + /* acc0 += b[numTaps-1] * x[n-numTaps] */ + acc0 += x0 * c0; + + /* acc1 += b[numTaps-1] * x[n-numTaps-1] */ + acc1 += x1 * c0; + + /* acc2 += b[numTaps-1] * x[n-numTaps-2] */ + acc2 += x2 * c0; + + /* acc3 += b[numTaps-1] * x[n-numTaps-3] */ + acc3 += x3 * c0; + + /* acc4 += b[numTaps-1] * x[n-numTaps-4] */ + acc4 += x4 * c0; + + /* acc1 += b[numTaps-1] * x[n-numTaps-5] */ + acc5 += x5 * c0; + + /* acc2 += b[numTaps-1] * x[n-numTaps-6] */ + acc6 += x6 * c0; + + /* acc3 += b[numTaps-1] * x[n-numTaps-7] */ + acc7 += x7 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-4] sample */ + x0 = *(px++); + + /* Perform the multiply-accumulate */ + acc0 += x1 * c0; + acc1 += x2 * c0; + acc2 += x3 * c0; + acc3 += x4 * c0; + acc4 += x5 * c0; + acc5 += x6 * c0; + acc6 += x7 * c0; + acc7 += x0 * c0; + + /* Read the b[numTaps-3] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-5] sample */ + x1 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += x2 * c0; + acc1 += x3 * c0; + acc2 += x4 * c0; + acc3 += x5 * c0; + acc4 += x6 * c0; + acc5 += x7 * c0; + acc6 += x0 * c0; + acc7 += x1 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += x3 * c0; + acc1 += x4 * c0; + acc2 += x5 * c0; + acc3 += x6 * c0; + acc4 += x7 * c0; + acc5 += x0 * c0; + acc6 += x1 * c0; + acc7 += x2 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x3 = *(px++); + /* Perform the multiply-accumulates */ + acc0 += x4 * c0; + acc1 += x5 * c0; + acc2 += x6 * c0; + acc3 += x7 * c0; + acc4 += x0 * c0; + acc5 += x1 * c0; + acc6 += x2 * c0; + acc7 += x3 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x4 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += x5 * c0; + acc1 += x6 * c0; + acc2 += x7 * c0; + acc3 += x0 * c0; + acc4 += x1 * c0; + acc5 += x2 * c0; + acc6 += x3 * c0; + acc7 += x4 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x5 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += x6 * c0; + acc1 += x7 * c0; + acc2 += x0 * c0; + acc3 += x1 * c0; + acc4 += x2 * c0; + acc5 += x3 * c0; + acc6 += x4 * c0; + acc7 += x5 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x6 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += x7 * c0; + acc1 += x0 * c0; + acc2 += x1 * c0; + acc3 += x2 * c0; + acc4 += x3 * c0; + acc5 += x4 * c0; + acc6 += x5 * c0; + acc7 += x6 * c0; + + tapCnt--; + } + + /* If the filter length is not a multiple of 8, compute the remaining filter taps */ + tapCnt = numTaps % 0x8U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x7 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + acc4 += x4 * c0; + acc5 += x5 * c0; + acc6 += x6 * c0; + acc7 += x7 * c0; + + /* Reuse the present sample states for next sample */ + x0 = x1; + x1 = x2; + x2 = x3; + x3 = x4; + x4 = x5; + x5 = x6; + x6 = x7; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by 8 to process the next group of 8 samples */ + pState = pState + 8; + + /* The results in the 8 accumulators, store in the destination buffer. */ + *pDst++ = acc0; + *pDst++ = acc1; + *pDst++ = acc2; + *pDst++ = acc3; + *pDst++ = acc4; + *pDst++ = acc5; + *pDst++ = acc6; + *pDst++ = acc7; + + blkCnt--; + } + + /* If the blockSize is not a multiple of 8, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x8U; + + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0.0f; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = (pCoeffs); + + i = numTaps; + + /* Perform the multiply-accumulates */ + do + { + acc0 += *px++ * *pb++; + i--; + + } while (i > 0U); + + /* The result is store in the destination buffer. */ + *pDst++ = acc0; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +#elif defined(ARM_MATH_CM0_FAMILY) + +void arm_fir_f32( +const arm_fir_instance_f32 * S, +float32_t * pSrc, +float32_t * pDst, +uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, tapCnt, blkCnt; /* Loop counters */ + + /* Run the below code for Cortex-M0 */ + + float32_t acc; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Initialize blkCnt with blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0.0f; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = pCoeffs; + + i = numTaps; + + /* Perform the multiply-accumulates */ + do + { + /* acc = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] */ + acc += *px++ * *pb++; + i--; + + } while (i > 0U); + + /* The result is store in the destination buffer. */ + *pDst++ = acc; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the starting of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy numTaps number of values */ + tapCnt = numTaps - 1U; + + /* Copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +#else + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + +void arm_fir_f32( +const arm_fir_instance_f32 * S, +float32_t * pSrc, +float32_t * pDst, +uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + float32_t acc0, acc1, acc2, acc3, acc4, acc5, acc6, acc7; /* Accumulators */ + float32_t x0, x1, x2, x3, x4, x5, x6, x7, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, tapCnt, blkCnt; /* Loop counters */ + float32_t p0,p1,p2,p3,p4,p5,p6,p7; /* Temporary product values */ + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 8 output values simultaneously. + * The variables acc0 ... acc7 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + blkCnt = blockSize >> 3; + + /* First part of the processing with loop unrolling. Compute 8 outputs at a time. + ** a second loop below computes the remaining 1 to 7 samples. */ + while (blkCnt > 0U) + { + /* Copy four new input samples into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Set all accumulators to zero */ + acc0 = 0.0f; + acc1 = 0.0f; + acc2 = 0.0f; + acc3 = 0.0f; + acc4 = 0.0f; + acc5 = 0.0f; + acc6 = 0.0f; + acc7 = 0.0f; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* This is separated from the others to avoid + * a call to __aeabi_memmove which would be slower + */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Read the first seven samples from the state buffer: x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2] */ + x0 = *px++; + x1 = *px++; + x2 = *px++; + x3 = *px++; + x4 = *px++; + x5 = *px++; + x6 = *px++; + + /* Loop unrolling. Process 8 taps at a time. */ + tapCnt = numTaps >> 3U; + + /* Loop over the number of taps. Unroll by a factor of 8. + ** Repeat until we've computed numTaps-8 coefficients. */ + while (tapCnt > 0U) + { + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-3] sample */ + x7 = *(px++); + + /* acc0 += b[numTaps-1] * x[n-numTaps] */ + p0 = x0 * c0; + + /* acc1 += b[numTaps-1] * x[n-numTaps-1] */ + p1 = x1 * c0; + + /* acc2 += b[numTaps-1] * x[n-numTaps-2] */ + p2 = x2 * c0; + + /* acc3 += b[numTaps-1] * x[n-numTaps-3] */ + p3 = x3 * c0; + + /* acc4 += b[numTaps-1] * x[n-numTaps-4] */ + p4 = x4 * c0; + + /* acc1 += b[numTaps-1] * x[n-numTaps-5] */ + p5 = x5 * c0; + + /* acc2 += b[numTaps-1] * x[n-numTaps-6] */ + p6 = x6 * c0; + + /* acc3 += b[numTaps-1] * x[n-numTaps-7] */ + p7 = x7 * c0; + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-4] sample */ + x0 = *(px++); + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + + /* Perform the multiply-accumulate */ + p0 = x1 * c0; + p1 = x2 * c0; + p2 = x3 * c0; + p3 = x4 * c0; + p4 = x5 * c0; + p5 = x6 * c0; + p6 = x7 * c0; + p7 = x0 * c0; + + /* Read the b[numTaps-3] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-5] sample */ + x1 = *(px++); + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + /* Perform the multiply-accumulates */ + p0 = x2 * c0; + p1 = x3 * c0; + p2 = x4 * c0; + p3 = x5 * c0; + p4 = x6 * c0; + p5 = x7 * c0; + p6 = x0 * c0; + p7 = x1 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x2 = *(px++); + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + /* Perform the multiply-accumulates */ + p0 = x3 * c0; + p1 = x4 * c0; + p2 = x5 * c0; + p3 = x6 * c0; + p4 = x7 * c0; + p5 = x0 * c0; + p6 = x1 * c0; + p7 = x2 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x3 = *(px++); + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + /* Perform the multiply-accumulates */ + p0 = x4 * c0; + p1 = x5 * c0; + p2 = x6 * c0; + p3 = x7 * c0; + p4 = x0 * c0; + p5 = x1 * c0; + p6 = x2 * c0; + p7 = x3 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x4 = *(px++); + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + /* Perform the multiply-accumulates */ + p0 = x5 * c0; + p1 = x6 * c0; + p2 = x7 * c0; + p3 = x0 * c0; + p4 = x1 * c0; + p5 = x2 * c0; + p6 = x3 * c0; + p7 = x4 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x5 = *(px++); + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + /* Perform the multiply-accumulates */ + p0 = x6 * c0; + p1 = x7 * c0; + p2 = x0 * c0; + p3 = x1 * c0; + p4 = x2 * c0; + p5 = x3 * c0; + p6 = x4 * c0; + p7 = x5 * c0; + + /* Read the b[numTaps-4] coefficient */ + c0 = *(pb++); + + /* Read x[n-numTaps-6] sample */ + x6 = *(px++); + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + /* Perform the multiply-accumulates */ + p0 = x7 * c0; + p1 = x0 * c0; + p2 = x1 * c0; + p3 = x2 * c0; + p4 = x3 * c0; + p5 = x4 * c0; + p6 = x5 * c0; + p7 = x6 * c0; + + tapCnt--; + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + } + + /* If the filter length is not a multiple of 8, compute the remaining filter taps */ + tapCnt = numTaps % 0x8U; + + while (tapCnt > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x7 = *(px++); + + /* Perform the multiply-accumulates */ + p0 = x0 * c0; + p1 = x1 * c0; + p2 = x2 * c0; + p3 = x3 * c0; + p4 = x4 * c0; + p5 = x5 * c0; + p6 = x6 * c0; + p7 = x7 * c0; + + /* Reuse the present sample states for next sample */ + x0 = x1; + x1 = x2; + x2 = x3; + x3 = x4; + x4 = x5; + x5 = x6; + x6 = x7; + + acc0 += p0; + acc1 += p1; + acc2 += p2; + acc3 += p3; + acc4 += p4; + acc5 += p5; + acc6 += p6; + acc7 += p7; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance the state pointer by 8 to process the next group of 8 samples */ + pState = pState + 8; + + /* The results in the 8 accumulators, store in the destination buffer. */ + *pDst++ = acc0; + *pDst++ = acc1; + *pDst++ = acc2; + *pDst++ = acc3; + *pDst++ = acc4; + *pDst++ = acc5; + *pDst++ = acc6; + *pDst++ = acc7; + + blkCnt--; + } + + /* If the blockSize is not a multiple of 8, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x8U; + + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0.0f; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = (pCoeffs); + + i = numTaps; + + /* Perform the multiply-accumulates */ + do + { + acc0 += *px++ * *pb++; + i--; + + } while (i > 0U); + + /* The result is store in the destination buffer. */ + *pDst++ = acc0; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +#endif + +/** +* @} end of FIR group +*/ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q15.c new file mode 100644 index 0000000..35e431b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q15.c @@ -0,0 +1,333 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_fast_q15.c + * Description: Q15 Fast FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @param[in] *S points to an instance of the Q15 FIR filter structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * This fast version uses a 32-bit accumulator with 2.30 format. + * The accumulator maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around and distorts the result. + * In order to avoid overflows completely the input signal must be scaled down by log2(numTaps) bits. + * The 2.30 accumulator is then truncated to 2.15 format and saturated to yield the 1.15 result. + * + * \par + * Refer to the function arm_fir_q15() for a slower implementation of this function which uses 64-bit accumulation to avoid wrap around distortion. Both the slow and the fast versions use the same instance structure. + * Use the function arm_fir_init_q15() to initialize the filter structure. + */ + +void arm_fir_fast_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t acc0, acc1, acc2, acc3; /* Accumulators */ + q15_t *pb; /* Temporary pointer for coefficient buffer */ + q15_t *px; /* Temporary q31 pointer for SIMD state buffer accesses */ + q31_t x0, x1, x2, c0; /* Temporary variables to hold SIMD state and coefficient values */ + uint32_t numTaps = S->numTaps; /* Number of taps in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 4 output values simultaneously. + * The variables acc0 ... acc3 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + + blkCnt = blockSize >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Copy four new input samples into the state buffer. + ** Use 32-bit SIMD to move the 16-bit data. Only requires two copies. */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Typecast q15_t pointer to q31_t pointer for state reading in q31_t */ + px = pState; + + /* Typecast q15_t pointer to q31_t pointer for coefficient reading in q31_t */ + pb = pCoeffs; + + /* Read the first two samples from the state buffer: x[n-N], x[n-N-1] */ + x0 = *__SIMD32(px)++; + + /* Read the third and forth samples from the state buffer: x[n-N-2], x[n-N-3] */ + x2 = *__SIMD32(px)++; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(numTaps%4) coefficients. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0) + { + /* Read the first two coefficients using SIMD: b[N] and b[N-1] coefficients */ + c0 = *__SIMD32(pb)++; + + /* acc0 += b[N] * x[n-N] + b[N-1] * x[n-N-1] */ + acc0 = __SMLAD(x0, c0, acc0); + + /* acc2 += b[N] * x[n-N-2] + b[N-1] * x[n-N-3] */ + acc2 = __SMLAD(x2, c0, acc2); + + /* pack x[n-N-1] and x[n-N-2] */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x2, x0, 0); +#else + x1 = __PKHBT(x0, x2, 0); +#endif + + /* Read state x[n-N-4], x[n-N-5] */ + x0 = _SIMD32_OFFSET(px); + + /* acc1 += b[N] * x[n-N-1] + b[N-1] * x[n-N-2] */ + acc1 = __SMLADX(x1, c0, acc1); + + /* pack x[n-N-3] and x[n-N-4] */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x0, x2, 0); +#else + x1 = __PKHBT(x2, x0, 0); +#endif + + /* acc3 += b[N] * x[n-N-3] + b[N-1] * x[n-N-4] */ + acc3 = __SMLADX(x1, c0, acc3); + + /* Read coefficients b[N-2], b[N-3] */ + c0 = *__SIMD32(pb)++; + + /* acc0 += b[N-2] * x[n-N-2] + b[N-3] * x[n-N-3] */ + acc0 = __SMLAD(x2, c0, acc0); + + /* Read state x[n-N-6], x[n-N-7] with offset */ + x2 = _SIMD32_OFFSET(px + 2U); + + /* acc2 += b[N-2] * x[n-N-4] + b[N-3] * x[n-N-5] */ + acc2 = __SMLAD(x0, c0, acc2); + + /* acc1 += b[N-2] * x[n-N-3] + b[N-3] * x[n-N-4] */ + acc1 = __SMLADX(x1, c0, acc1); + + /* pack x[n-N-5] and x[n-N-6] */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x2, x0, 0); +#else + x1 = __PKHBT(x0, x2, 0); +#endif + + /* acc3 += b[N-2] * x[n-N-5] + b[N-3] * x[n-N-6] */ + acc3 = __SMLADX(x1, c0, acc3); + + /* Update state pointer for next state reading */ + px += 4U; + + /* Decrement tap count */ + tapCnt--; + + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps. + ** This is always be 2 taps since the filter length is even. */ + if ((numTaps & 0x3U) != 0U) + { + + /* Read last two coefficients */ + c0 = *__SIMD32(pb)++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLAD(x0, c0, acc0); + acc2 = __SMLAD(x2, c0, acc2); + + /* pack state variables */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x2, x0, 0); +#else + x1 = __PKHBT(x0, x2, 0); +#endif + + /* Read last state variables */ + x0 = *__SIMD32(px); + + /* Perform the multiply-accumulates */ + acc1 = __SMLADX(x1, c0, acc1); + + /* pack state variables */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x0, x2, 0); +#else + x1 = __PKHBT(x2, x0, 0); +#endif + + /* Perform the multiply-accumulates */ + acc3 = __SMLADX(x1, c0, acc3); + } + + /* The results in the 4 accumulators are in 2.30 format. Convert to 1.15 with saturation. + ** Then store the 4 outputs in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + while (blkCnt > 0U) + { + /* Copy two samples into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0; + + /* Use SIMD to hold states and coefficients */ + px = pState; + pb = pCoeffs; + + tapCnt = numTaps >> 1U; + + do + { + + acc0 += (q31_t) * px++ * *pb++; + acc0 += (q31_t) * px++ * *pb++; + + tapCnt--; + } + while (tapCnt > 0U); + + /* The result is in 2.30 format. Convert to 1.15 with saturation. + ** Then store the output in the destination buffer. */ + *pDst++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Calculation of count for copying integer writes */ + tapCnt = (numTaps - 1U) >> 2; + + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + tapCnt--; + + } + + /* Calculation of count for remaining q15_t data */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* copy remaining data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q31.c new file mode 100644 index 0000000..bd9c686 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_fast_q31.c @@ -0,0 +1,293 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_fast_q31.c + * Description: Processing function for the Q31 Fast FIR filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @param[in] *S points to an instance of the Q31 structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * + * \par + * This function is optimized for speed at the expense of fixed-point precision and overflow protection. + * The result of each 1.31 x 1.31 multiplication is truncated to 2.30 format. + * These intermediate results are added to a 2.30 accumulator. + * Finally, the accumulator is saturated and converted to a 1.31 result. + * The fast version has the same overflow behavior as the standard version and provides less precision since it discards the low 32 bits of each multiplication result. + * In order to avoid overflows completely the input signal must be scaled down by log2(numTaps) bits. + * + * \par + * Refer to the function arm_fir_q31() for a slower implementation of this function which uses a 64-bit accumulator to provide higher precision. Both the slow and the fast versions use the same instance structure. + * Use the function arm_fir_init_q31() to initialize the filter structure. + */ + +IAR_ONLY_LOW_OPTIMIZATION_ENTER +void arm_fir_fast_q31( + const arm_fir_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t x0, x1, x2, x3; /* Temporary variables to hold state */ + q31_t c0; /* Temporary variable to hold coefficient value */ + q31_t *px; /* Temporary pointer for state */ + q31_t *pb; /* Temporary pointer for coefficient buffer */ + q31_t acc0, acc1, acc2, acc3; /* Accumulators */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, tapCnt, blkCnt; /* Loop counters */ + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 4 output values simultaneously. + * The variables acc0 ... acc3 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + blkCnt = blockSize >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Copy four new input samples into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coefficient pointer */ + pb = pCoeffs; + + /* Read the first three samples from the state buffer: + * x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2] */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + i = tapCnt; + + while (i > 0U) + { + /* Read the b[numTaps] coefficient */ + c0 = *pb; + + /* Read x[n-numTaps-3] sample */ + x3 = *px; + + /* acc0 += b[numTaps] * x[n-numTaps] */ + multAcc_32x32_keep32_R(acc0, x0, c0); + + /* acc1 += b[numTaps] * x[n-numTaps-1] */ + multAcc_32x32_keep32_R(acc1, x1, c0); + + /* acc2 += b[numTaps] * x[n-numTaps-2] */ + multAcc_32x32_keep32_R(acc2, x2, c0); + + /* acc3 += b[numTaps] * x[n-numTaps-3] */ + multAcc_32x32_keep32_R(acc3, x3, c0); + + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb + 1U); + + /* Read x[n-numTaps-4] sample */ + x0 = *(px + 1U); + + /* Perform the multiply-accumulates */ + multAcc_32x32_keep32_R(acc0, x1, c0); + multAcc_32x32_keep32_R(acc1, x2, c0); + multAcc_32x32_keep32_R(acc2, x3, c0); + multAcc_32x32_keep32_R(acc3, x0, c0); + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb + 2U); + + /* Read x[n-numTaps-5] sample */ + x1 = *(px + 2U); + + /* Perform the multiply-accumulates */ + multAcc_32x32_keep32_R(acc0, x2, c0); + multAcc_32x32_keep32_R(acc1, x3, c0); + multAcc_32x32_keep32_R(acc2, x0, c0); + multAcc_32x32_keep32_R(acc3, x1, c0); + + /* Read the b[numTaps-3] coefficients */ + c0 = *(pb + 3U); + + /* Read x[n-numTaps-6] sample */ + x2 = *(px + 3U); + + /* Perform the multiply-accumulates */ + multAcc_32x32_keep32_R(acc0, x3, c0); + multAcc_32x32_keep32_R(acc1, x0, c0); + multAcc_32x32_keep32_R(acc2, x1, c0); + multAcc_32x32_keep32_R(acc3, x2, c0); + + /* update coefficient pointer */ + pb += 4U; + px += 4U; + + /* Decrement the loop counter */ + i--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + + i = numTaps - (tapCnt * 4U); + while (i > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + multAcc_32x32_keep32_R(acc0, x0, c0); + multAcc_32x32_keep32_R(acc1, x1, c0); + multAcc_32x32_keep32_R(acc2, x2, c0); + multAcc_32x32_keep32_R(acc3, x3, c0); + + /* Reuse the present sample states for next sample */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 4; + + /* The results in the 4 accumulators are in 2.30 format. Convert to 1.31 + ** Then store the 4 outputs in the destination buffer. */ + *pDst++ = (q31_t) (acc0 << 1); + *pDst++ = (q31_t) (acc1 << 1); + *pDst++ = (q31_t) (acc2 << 1); + *pDst++ = (q31_t) (acc3 << 1); + + /* Decrement the samples loop counter */ + blkCnt--; + } + + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 4U; + + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = (pCoeffs); + + i = numTaps; + + /* Perform the multiply-accumulates */ + do + { + multAcc_32x32_keep32_R(acc0, (*px++), (*(pb++))); + i--; + } while (i > 0U); + + /* The result is in 2.30 format. Convert to 1.31 + ** Then store the output in the destination buffer. */ + *pDst++ = (q31_t) (acc0 << 1); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the samples loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U); + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + +} +IAR_ONLY_LOW_OPTIMIZATION_EXIT +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_f32.c new file mode 100644 index 0000000..25fcb01 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_f32.c @@ -0,0 +1,84 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_init_f32.c + * Description: Floating-point FIR filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @details + * + * @param[in,out] *S points to an instance of the floating-point FIR filter structure. + * @param[in] numTaps Number of filter coefficients in the filter. + * @param[in] *pCoeffs points to the filter coefficients buffer. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of samples that are processed per call. + * @return none. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to the array of state variables. + * pState is of length numTaps+blockSize-1 samples, where blockSize is the number of input samples processed by each call to arm_fir_f32(). + */ + +void arm_fir_init_f32( + arm_fir_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and the size of state buffer is (blockSize + numTaps - 1) */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q15.c new file mode 100644 index 0000000..a5638d5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q15.c @@ -0,0 +1,142 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_init_q15.c + * Description: Q15 FIR filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @param[in,out] *S points to an instance of the Q15 FIR filter structure. + * @param[in] numTaps Number of filter coefficients in the filter. Must be even and greater than or equal to 4. + * @param[in] *pCoeffs points to the filter coefficients buffer. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize is number of samples processed per call. + * @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if + * numTaps is not greater than or equal to 4 and even. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * Note that numTaps must be even and greater than or equal to 4. + * To implement an odd length filter simply increase numTaps by 1 and set the last coefficient to zero. + * For example, to implement a filter with numTaps=3 and coefficients + *
+ *     {0.3, -0.8, 0.3}
+ * 
+ * set numTaps=4 and use the coefficients: + *
+ *     {0.3, -0.8, 0.3, 0}.
+ * 
+ * Similarly, to implement a two point filter + *
+ *     {0.3, -0.3}
+ * 
+ * set numTaps=4 and use the coefficients: + *
+ *     {0.3, -0.3, 0, 0}.
+ * 
+ * \par + * pState points to the array of state variables. + * pState is of length numTaps+blockSize, when running on Cortex-M4 and Cortex-M3 and is of length numTaps+blockSize-1, when running on Cortex-M0 where blockSize is the number of input samples processed by each call to arm_fir_q15(). + */ + +arm_status arm_fir_init_q15( + arm_fir_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + uint32_t blockSize) +{ + arm_status status; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* The Number of filter coefficients in the filter must be even and at least 4 */ + if (numTaps & 0x1U) + { + status = ARM_MATH_ARGUMENT_ERROR; + } + else + { + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear the state buffer. The size is always (blockSize + numTaps ) */ + memset(pState, 0, (numTaps + (blockSize)) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + + status = ARM_MATH_SUCCESS; + } + + return (status); + +#else + + /* Run the below code for Cortex-M0 */ + + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear the state buffer. The size is always (blockSize + numTaps - 1) */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + + status = ARM_MATH_SUCCESS; + + return (status); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q31.c new file mode 100644 index 0000000..2367a65 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q31.c @@ -0,0 +1,84 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_init_q31.c + * Description: Q31 FIR filter initialization function. + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @details + * + * @param[in,out] *S points to an instance of the Q31 FIR filter structure. + * @param[in] numTaps Number of filter coefficients in the filter. + * @param[in] *pCoeffs points to the filter coefficients buffer. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of samples that are processed per call. + * @return none. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to the array of state variables. + * pState is of length numTaps+blockSize-1 samples, where blockSize is the number of input samples processed by each call to arm_fir_q31(). + */ + +void arm_fir_init_q31( + arm_fir_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and state array size is (blockSize + numTaps - 1) */ + memset(pState, 0, (blockSize + ((uint32_t) numTaps - 1U)) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q7.c new file mode 100644 index 0000000..5a91fb8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_init_q7.c @@ -0,0 +1,82 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_init_q7.c + * Description: Q7 FIR filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ +/** + * @param[in,out] *S points to an instance of the Q7 FIR filter structure. + * @param[in] numTaps Number of filter coefficients in the filter. + * @param[in] *pCoeffs points to the filter coefficients buffer. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of samples that are processed per call. + * @return none + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to the array of state variables. + * pState is of length numTaps+blockSize-1 samples, where blockSize is the number of input samples processed by each call to arm_fir_q7(). + */ + +void arm_fir_init_q7( + arm_fir_instance_q7 * S, + uint16_t numTaps, + q7_t * pCoeffs, + q7_t * pState, + uint32_t blockSize) +{ + + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear the state buffer. The size is always (blockSize + numTaps - 1) */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(q7_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_f32.c new file mode 100644 index 0000000..5f9d19c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_f32.c @@ -0,0 +1,569 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_interpolate_f32.c + * Description: Floating-point FIR interpolation sequences + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @defgroup FIR_Interpolate Finite Impulse Response (FIR) Interpolator + * + * These functions combine an upsampler (zero stuffer) and an FIR filter. + * They are used in multirate systems for increasing the sample rate of a signal without introducing high frequency images. + * Conceptually, the functions are equivalent to the block diagram below: + * \image html FIRInterpolator.gif "Components included in the FIR Interpolator functions" + * After upsampling by a factor of L, the signal should be filtered by a lowpass filter with a normalized + * cutoff frequency of 1/L in order to eliminate high frequency copies of the spectrum. + * The user of the function is responsible for providing the filter coefficients. + * + * The FIR interpolator functions provided in the CMSIS DSP Library combine the upsampler and FIR filter in an efficient manner. + * The upsampler inserts L-1 zeros between each sample. + * Instead of multiplying by these zero values, the FIR filter is designed to skip them. + * This leads to an efficient implementation without any wasted effort. + * The functions operate on blocks of input and output data. + * pSrc points to an array of blockSize input values and + * pDst points to an array of blockSize*L output values. + * + * The library provides separate functions for Q15, Q31, and floating-point data types. + * + * \par Algorithm: + * The functions use a polyphase filter structure: + *
+ *    y[n] = b[0] * x[n] + b[L]   * x[n-1] + ... + b[L*(phaseLength-1)] * x[n-phaseLength+1]
+ *    y[n+1] = b[1] * x[n] + b[L+1] * x[n-1] + ... + b[L*(phaseLength-1)+1] * x[n-phaseLength+1]
+ *    ...
+ *    y[n+(L-1)] = b[L-1] * x[n] + b[2*L-1] * x[n-1] + ....+ b[L*(phaseLength-1)+(L-1)] * x[n-phaseLength+1]
+ * 
+ * This approach is more efficient than straightforward upsample-then-filter algorithms. + * With this method the computation is reduced by a factor of 1/L when compared to using a standard FIR filter. + * \par + * pCoeffs points to a coefficient array of size numTaps. + * numTaps must be a multiple of the interpolation factor L and this is checked by the + * initialization functions. + * Internally, the function divides the FIR filter's impulse response into shorter filters of length + * phaseLength=numTaps/L. + * Coefficients are stored in time reversed order. + * \par + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to a state array of size blockSize + phaseLength - 1. + * Samples in the state buffer are stored in the order: + * \par + *
+ *    {x[n-phaseLength+1], x[n-phaseLength], x[n-phaseLength-1], x[n-phaseLength-2]....x[0], x[1], ..., x[blockSize-1]}
+ * 
+ * The state variables are updated after each block of data is processed, the coefficients are untouched. + * + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter. + * Coefficient arrays may be shared among several instances while state variable array should be allocated separately. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * - Checks to make sure that the length of the filter is a multiple of the interpolation factor. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * L (interpolation factor), pCoeffs, phaseLength (numTaps / L), pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * The code below statically initializes each of the 3 different data type filter instance structures + *
+ * arm_fir_interpolate_instance_f32 S = {L, phaseLength, pCoeffs, pState};
+ * arm_fir_interpolate_instance_q31 S = {L, phaseLength, pCoeffs, pState};
+ * arm_fir_interpolate_instance_q15 S = {L, phaseLength, pCoeffs, pState};
+ * 
+ * where L is the interpolation factor; phaseLength=numTaps/L is the + * length of each of the shorter FIR filters used internally, + * pCoeffs is the address of the coefficient buffer; + * pState is the address of the state buffer. + * Be sure to set the values in the state buffer to zeros when doing static initialization. + * + * \par Fixed-Point Behavior + * Care must be taken when using the fixed-point versions of the FIR interpolate filter functions. + * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + +/** + * @addtogroup FIR_Interpolate + * @{ + */ + +/** + * @brief Processing function for the floating-point FIR interpolator. + * @param[in] *S points to an instance of the floating-point FIR interpolator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of input samples to process per call. + * @return none. + */ +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + +void arm_fir_interpolate_f32( + const arm_fir_interpolate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + float32_t sum0; /* Accumulators */ + float32_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t i, blkCnt, j; /* Loop counters */ + uint16_t phaseLen = S->phaseLength, tapCnt; /* Length of each polyphase filter component */ + float32_t acc0, acc1, acc2, acc3; + float32_t x1, x2, x3; + uint32_t blkCntN4; + float32_t c1, c2, c3; + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (phaseLen - 1U); + + /* Initialise blkCnt */ + blkCnt = blockSize / 4; + blkCntN4 = blockSize - (4 * blkCnt); + + /* Samples loop unrolled by 4 */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Address modifier index of coefficient buffer */ + j = 1U; + + /* Loop over the Interpolation factor. */ + i = (S->L); + + while (i > 0U) + { + /* Set accumulator to zero */ + acc0 = 0.0f; + acc1 = 0.0f; + acc2 = 0.0f; + acc3 = 0.0f; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (S->L - j); + + /* Loop over the polyPhase length. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(4*S->L) coefficients. */ + tapCnt = phaseLen >> 2U; + + x0 = *(ptr1++); + x1 = *(ptr1++); + x2 = *(ptr1++); + + while (tapCnt > 0U) + { + + /* Read the input sample */ + x3 = *(ptr1++); + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + + /* Read the coefficient */ + c1 = *(ptr2 + S->L); + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += x1 * c1; + acc1 += x2 * c1; + acc2 += x3 * c1; + acc3 += x0 * c1; + + /* Read the coefficient */ + c2 = *(ptr2 + S->L * 2); + + /* Read the input sample */ + x1 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += x2 * c2; + acc1 += x3 * c2; + acc2 += x0 * c2; + acc3 += x1 * c2; + + /* Read the coefficient */ + c3 = *(ptr2 + S->L * 3); + + /* Read the input sample */ + x2 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += x3 * c3; + acc1 += x0 * c3; + acc2 += x1 * c3; + acc3 += x2 * c3; + + + /* Upsampling is done by stuffing L-1 zeros between each sample. + * So instead of multiplying zeros with coefficients, + * Increment the coefficient pointer by interpolation factor times. */ + ptr2 += 4 * S->L; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the polyPhase length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = phaseLen % 0x4U; + + while (tapCnt > 0U) + { + + /* Read the input sample */ + x3 = *(ptr1++); + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Perform the multiply-accumulate */ + acc0 += x0 * c0; + acc1 += x1 * c0; + acc2 += x2 * c0; + acc3 += x3 * c0; + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* update states for next sample processing */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst = acc0; + *(pDst + S->L) = acc1; + *(pDst + 2 * S->L) = acc2; + *(pDst + 3 * S->L) = acc3; + + pDst++; + + /* Increment the address modifier index of coefficient buffer */ + j++; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 4; + + pDst += S->L * 3; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + + while (blkCntN4 > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Address modifier index of coefficient buffer */ + j = 1U; + + /* Loop over the Interpolation factor. */ + i = S->L; + while (i > 0U) + { + /* Set accumulator to zero */ + sum0 = 0.0f; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (S->L - j); + + /* Loop over the polyPhase length. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(4*S->L) coefficients. */ + tapCnt = phaseLen >> 2U; + while (tapCnt > 0U) + { + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Upsampling is done by stuffing L-1 zeros between each sample. + * So instead of multiplying zeros with coefficients, + * Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += x0 * c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the polyPhase length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = phaseLen % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum0 += *(ptr1++) * (*ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = sum0; + + /* Increment the address modifier index of coefficient buffer */ + j++; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCntN4--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = (phaseLen - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (phaseLen - 1U) % 0x04U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +#else + + /* Run the below code for Cortex-M0 */ + +void arm_fir_interpolate_f32( + const arm_fir_interpolate_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + + + float32_t sum; /* Accumulator */ + uint32_t i, blkCnt; /* Loop counters */ + uint16_t phaseLen = S->phaseLength, tapCnt; /* Length of each polyphase filter component */ + + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (phaseLen - 1U); + + /* Total number of intput samples */ + blkCnt = blockSize; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Loop over the Interpolation factor. */ + i = S->L; + + while (i > 0U) + { + /* Set accumulator to zero */ + sum = 0.0f; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (i - 1U); + + /* Loop over the polyPhase length */ + tapCnt = phaseLen; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += *ptr1++ * *ptr2; + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = sum; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = phaseLen - 1U; + + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +#endif /* #if defined (ARM_MATH_DSP) */ + + + + /** + * @} end of FIR_Interpolate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_f32.c new file mode 100644 index 0000000..415c8da --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_f32.c @@ -0,0 +1,109 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_interpolate_init_f32.c + * Description: Floating-point FIR interpolator initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Interpolate + * @{ + */ + +/** + * @brief Initialization function for the floating-point FIR interpolator. + * @param[in,out] *S points to an instance of the floating-point FIR interpolator structure. + * @param[in] L upsample factor. + * @param[in] numTaps number of filter coefficients in the filter. + * @param[in] *pCoeffs points to the filter coefficient buffer. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_LENGTH_ERROR if + * the filter length numTaps is not a multiple of the interpolation factor L. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[numTaps-2], ..., b[1], b[0]}
+ * 
+ * The length of the filter numTaps must be a multiple of the interpolation factor L. + * \par + * pState points to the array of state variables. + * pState is of length (numTaps/L)+blockSize-1 words + * where blockSize is the number of input samples processed by each call to arm_fir_interpolate_f32(). + */ + +arm_status arm_fir_interpolate_init_f32( + arm_fir_interpolate_instance_f32 * S, + uint8_t L, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + uint32_t blockSize) +{ + arm_status status; + + /* The filter length must be a multiple of the interpolation factor */ + if ((numTaps % L) != 0U) + { + /* Set status as ARM_MATH_LENGTH_ERROR */ + status = ARM_MATH_LENGTH_ERROR; + } + else + { + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Assign Interpolation factor */ + S->L = L; + + /* Assign polyPhaseLength */ + S->phaseLength = numTaps / L; + + /* Clear state buffer and size of state array is always phaseLength + blockSize - 1 */ + memset(pState, 0, + (blockSize + + ((uint32_t) S->phaseLength - 1U)) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + + status = ARM_MATH_SUCCESS; + } + + return (status); + +} + + /** + * @} end of FIR_Interpolate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q15.c new file mode 100644 index 0000000..6dce943 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q15.c @@ -0,0 +1,108 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_interpolate_init_q15.c + * Description: Q15 FIR interpolator initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Interpolate + * @{ + */ + +/** + * @brief Initialization function for the Q15 FIR interpolator. + * @param[in,out] *S points to an instance of the Q15 FIR interpolator structure. + * @param[in] L upsample factor. + * @param[in] numTaps number of filter coefficients in the filter. + * @param[in] *pCoeffs points to the filter coefficient buffer. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_LENGTH_ERROR if + * the filter length numTaps is not a multiple of the interpolation factor L. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[numTaps-2], ..., b[1], b[0]}
+ * 
+ * The length of the filter numTaps must be a multiple of the interpolation factor L. + * \par + * pState points to the array of state variables. + * pState is of length (numTaps/L)+blockSize-1 words + * where blockSize is the number of input samples processed by each call to arm_fir_interpolate_q15(). + */ + +arm_status arm_fir_interpolate_init_q15( + arm_fir_interpolate_instance_q15 * S, + uint8_t L, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + uint32_t blockSize) +{ + arm_status status; + + /* The filter length must be a multiple of the interpolation factor */ + if ((numTaps % L) != 0U) + { + /* Set status as ARM_MATH_LENGTH_ERROR */ + status = ARM_MATH_LENGTH_ERROR; + } + else + { + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Assign Interpolation factor */ + S->L = L; + + /* Assign polyPhaseLength */ + S->phaseLength = numTaps / L; + + /* Clear state buffer and size of buffer is always phaseLength + blockSize - 1 */ + memset(pState, 0, + (blockSize + ((uint32_t) S->phaseLength - 1U)) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + + status = ARM_MATH_SUCCESS; + } + + return (status); + +} + + /** + * @} end of FIR_Interpolate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q31.c new file mode 100644 index 0000000..9875aa8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_init_q31.c @@ -0,0 +1,109 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_interpolate_init_q31.c + * Description: Q31 FIR interpolator initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Interpolate + * @{ + */ + + +/** + * @brief Initialization function for the Q31 FIR interpolator. + * @param[in,out] *S points to an instance of the Q31 FIR interpolator structure. + * @param[in] L upsample factor. + * @param[in] numTaps number of filter coefficients in the filter. + * @param[in] *pCoeffs points to the filter coefficient buffer. + * @param[in] *pState points to the state buffer. + * @param[in] blockSize number of input samples to process per call. + * @return The function returns ARM_MATH_SUCCESS if initialization was successful or ARM_MATH_LENGTH_ERROR if + * the filter length numTaps is not a multiple of the interpolation factor L. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[numTaps-2], ..., b[1], b[0]}
+ * 
+ * The length of the filter numTaps must be a multiple of the interpolation factor L. + * \par + * pState points to the array of state variables. + * pState is of length (numTaps/L)+blockSize-1 words + * where blockSize is the number of input samples processed by each call to arm_fir_interpolate_q31(). + */ + +arm_status arm_fir_interpolate_init_q31( + arm_fir_interpolate_instance_q31 * S, + uint8_t L, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + uint32_t blockSize) +{ + arm_status status; + + /* The filter length must be a multiple of the interpolation factor */ + if ((numTaps % L) != 0U) + { + /* Set status as ARM_MATH_LENGTH_ERROR */ + status = ARM_MATH_LENGTH_ERROR; + } + else + { + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Assign Interpolation factor */ + S->L = L; + + /* Assign polyPhaseLength */ + S->phaseLength = numTaps / L; + + /* Clear state buffer and size of buffer is always phaseLength + blockSize - 1 */ + memset(pState, 0, + (blockSize + ((uint32_t) S->phaseLength - 1U)) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; + + status = ARM_MATH_SUCCESS; + } + + return (status); + +} + + /** + * @} end of FIR_Interpolate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q15.c new file mode 100644 index 0000000..1cedd25 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q15.c @@ -0,0 +1,496 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_interpolate_q15.c + * Description: Q15 FIR interpolation + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Interpolate + * @{ + */ + +/** + * @brief Processing function for the Q15 FIR interpolator. + * @param[in] *S points to an instance of the Q15 FIR interpolator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of input samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both coefficients and state variables are represented in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * After all additions have been performed, the accumulator is truncated to 34.15 format by discarding low 15 bits. + * Lastly, the accumulator is saturated to yield a result in 1.15 format. + */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + +void arm_fir_interpolate_q15( + const arm_fir_interpolate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + q63_t sum0; /* Accumulators */ + q15_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t i, blkCnt, j, tapCnt; /* Loop counters */ + uint16_t phaseLen = S->phaseLength; /* Length of each polyphase filter component */ + uint32_t blkCntN2; + q63_t acc0, acc1; + q15_t x1; + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + ((q31_t) phaseLen - 1); + + /* Initialise blkCnt */ + blkCnt = blockSize / 2; + blkCntN2 = blockSize - (2 * blkCnt); + + /* Samples loop unrolled by 2 */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Address modifier index of coefficient buffer */ + j = 1U; + + /* Loop over the Interpolation factor. */ + i = (S->L); + + while (i > 0U) + { + /* Set accumulator to zero */ + acc0 = 0; + acc1 = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (S->L - j); + + /* Loop over the polyPhase length. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(4*S->L) coefficients. */ + tapCnt = phaseLen >> 2U; + + x0 = *(ptr1++); + + while (tapCnt > 0U) + { + + /* Read the input sample */ + x1 = *(ptr1++); + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x0 *c0; + acc1 += (q63_t) x1 *c0; + + + /* Read the coefficient */ + c0 = *(ptr2 + S->L); + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x1 *c0; + acc1 += (q63_t) x0 *c0; + + + /* Read the coefficient */ + c0 = *(ptr2 + S->L * 2); + + /* Read the input sample */ + x1 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x0 *c0; + acc1 += (q63_t) x1 *c0; + + /* Read the coefficient */ + c0 = *(ptr2 + S->L * 3); + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x1 *c0; + acc1 += (q63_t) x0 *c0; + + + /* Upsampling is done by stuffing L-1 zeros between each sample. + * So instead of multiplying zeros with coefficients, + * Increment the coefficient pointer by interpolation factor times. */ + ptr2 += 4 * S->L; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the polyPhase length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = phaseLen % 0x4U; + + while (tapCnt > 0U) + { + + /* Read the input sample */ + x1 = *(ptr1++); + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x0 *c0; + acc1 += (q63_t) x1 *c0; + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* update states for next sample processing */ + x0 = x1; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst = (q15_t) (__SSAT((acc0 >> 15), 16)); + *(pDst + S->L) = (q15_t) (__SSAT((acc1 >> 15), 16)); + + pDst++; + + /* Increment the address modifier index of coefficient buffer */ + j++; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 2; + + pDst += S->L; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 2, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blkCntN2; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Address modifier index of coefficient buffer */ + j = 1U; + + /* Loop over the Interpolation factor. */ + i = S->L; + while (i > 0U) + { + /* Set accumulator to zero */ + sum0 = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (S->L - j); + + /* Loop over the polyPhase length. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(4*S->L) coefficients. */ + tapCnt = phaseLen >> 2; + while (tapCnt > 0U) + { + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Upsampling is done by stuffing L-1 zeros between each sample. + * So instead of multiplying zeros with coefficients, + * Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the polyPhase length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = phaseLen & 0x3U; + + while (tapCnt > 0U) + { + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q15_t) (__SSAT((sum0 >> 15), 16)); + + j++; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = ((uint32_t) phaseLen - 1U) >> 2U; + + /* copy data */ + while (i > 0U) + { +#ifndef UNALIGNED_SUPPORT_DISABLE + + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + +#else + + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the loop counter */ + i--; + } + + i = ((uint32_t) phaseLen - 1U) % 0x04U; + + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } +} + +#else + + /* Run the below code for Cortex-M0 */ + +void arm_fir_interpolate_q15( + const arm_fir_interpolate_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + q63_t sum; /* Accumulator */ + q15_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t i, blkCnt, tapCnt; /* Loop counters */ + uint16_t phaseLen = S->phaseLength; /* Length of each polyphase filter component */ + + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (phaseLen - 1U); + + /* Total number of intput samples */ + blkCnt = blockSize; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Loop over the Interpolation factor. */ + i = S->L; + + while (i > 0U) + { + /* Set accumulator to zero */ + sum = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (i - 1U); + + /* Loop over the polyPhase length */ + tapCnt = (uint32_t) phaseLen; + + while (tapCnt > 0U) + { + /* Read the coefficient */ + c0 = *ptr2; + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *ptr1++; + + /* Perform the multiply-accumulate */ + sum += ((q31_t) x0 * c0); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Store the result after converting to 1.15 format in the destination buffer */ + *pDst++ = (q15_t) (__SSAT((sum >> 15), 16)); + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the start of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + i = (uint32_t) phaseLen - 1U; + + while (i > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + i--; + } + +} + +#endif /* #if defined (ARM_MATH_DSP) */ + + + /** + * @} end of FIR_Interpolate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q31.c new file mode 100644 index 0000000..2c0f522 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_interpolate_q31.c @@ -0,0 +1,492 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_interpolate_q31.c + * Description: Q31 FIR interpolation + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Interpolate + * @{ + */ + +/** + * @brief Processing function for the Q31 FIR interpolator. + * @param[in] *S points to an instance of the Q31 FIR interpolator structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of input samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clip. + * In order to avoid overflows completely the input signal must be scaled down by 1/(numTaps/L). + * since numTaps/L additions occur per output sample. + * After all multiply-accumulates are performed, the 2.62 accumulator is truncated to 1.32 format and then saturated to 1.31 format. + */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + +void arm_fir_interpolate_q31( + const arm_fir_interpolate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + q63_t sum0; /* Accumulators */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t i, blkCnt, j; /* Loop counters */ + uint16_t phaseLen = S->phaseLength, tapCnt; /* Length of each polyphase filter component */ + + uint32_t blkCntN2; + q63_t acc0, acc1; + q31_t x1; + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + ((q31_t) phaseLen - 1); + + /* Initialise blkCnt */ + blkCnt = blockSize / 2; + blkCntN2 = blockSize - (2 * blkCnt); + + /* Samples loop unrolled by 2 */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Address modifier index of coefficient buffer */ + j = 1U; + + /* Loop over the Interpolation factor. */ + i = (S->L); + + while (i > 0U) + { + /* Set accumulator to zero */ + acc0 = 0; + acc1 = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (S->L - j); + + /* Loop over the polyPhase length. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(4*S->L) coefficients. */ + tapCnt = phaseLen >> 2U; + + x0 = *(ptr1++); + + while (tapCnt > 0U) + { + + /* Read the input sample */ + x1 = *(ptr1++); + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x0 *c0; + acc1 += (q63_t) x1 *c0; + + + /* Read the coefficient */ + c0 = *(ptr2 + S->L); + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x1 *c0; + acc1 += (q63_t) x0 *c0; + + + /* Read the coefficient */ + c0 = *(ptr2 + S->L * 2); + + /* Read the input sample */ + x1 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x0 *c0; + acc1 += (q63_t) x1 *c0; + + /* Read the coefficient */ + c0 = *(ptr2 + S->L * 3); + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x1 *c0; + acc1 += (q63_t) x0 *c0; + + + /* Upsampling is done by stuffing L-1 zeros between each sample. + * So instead of multiplying zeros with coefficients, + * Increment the coefficient pointer by interpolation factor times. */ + ptr2 += 4 * S->L; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the polyPhase length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = phaseLen % 0x4U; + + while (tapCnt > 0U) + { + + /* Read the input sample */ + x1 = *(ptr1++); + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Perform the multiply-accumulate */ + acc0 += (q63_t) x0 *c0; + acc1 += (q63_t) x1 *c0; + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* update states for next sample processing */ + x0 = x1; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst = (q31_t) (acc0 >> 31); + *(pDst + S->L) = (q31_t) (acc1 >> 31); + + + pDst++; + + /* Increment the address modifier index of coefficient buffer */ + j++; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 2; + + pDst += S->L; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 2, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blkCntN2; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Address modifier index of coefficient buffer */ + j = 1U; + + /* Loop over the Interpolation factor. */ + i = S->L; + while (i > 0U) + { + /* Set accumulator to zero */ + sum0 = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (S->L - j); + + /* Loop over the polyPhase length. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(4*S->L) coefficients. */ + tapCnt = phaseLen >> 2; + while (tapCnt > 0U) + { + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Upsampling is done by stuffing L-1 zeros between each sample. + * So instead of multiplying zeros with coefficients, + * Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the polyPhase length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = phaseLen & 0x3U; + + while (tapCnt > 0U) + { + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *(ptr1++); + + /* Perform the multiply-accumulate */ + sum0 += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (sum0 >> 31); + + /* Increment the address modifier index of coefficient buffer */ + j++; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = (phaseLen - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + tapCnt = (phaseLen - 1U) % 0x04U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + + +#else + +void arm_fir_interpolate_q31( + const arm_fir_interpolate_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t *ptr1, *ptr2; /* Temporary pointers for state and coefficient buffers */ + + /* Run the below code for Cortex-M0 */ + + q63_t sum; /* Accumulator */ + q31_t x0, c0; /* Temporary variables to hold state and coefficient values */ + uint32_t i, blkCnt; /* Loop counters */ + uint16_t phaseLen = S->phaseLength, tapCnt; /* Length of each polyphase filter component */ + + + /* S->pState buffer contains previous frame (phaseLen - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + ((q31_t) phaseLen - 1); + + /* Total number of intput samples */ + blkCnt = blockSize; + + /* Loop over the blockSize. */ + while (blkCnt > 0U) + { + /* Copy new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Loop over the Interpolation factor. */ + i = S->L; + + while (i > 0U) + { + /* Set accumulator to zero */ + sum = 0; + + /* Initialize state pointer */ + ptr1 = pState; + + /* Initialize coefficient pointer */ + ptr2 = pCoeffs + (i - 1U); + + tapCnt = phaseLen; + + while (tapCnt > 0U) + { + /* Read the coefficient */ + c0 = *(ptr2); + + /* Increment the coefficient pointer by interpolation factor times. */ + ptr2 += S->L; + + /* Read the input sample */ + x0 = *ptr1++; + + /* Perform the multiply-accumulate */ + sum += (q63_t) x0 *c0; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is in the accumulator, store in the destination buffer. */ + *pDst++ = (q31_t) (sum >> 31); + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 1 + * to process the next group of interpolation factor number samples */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last phaseLen - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = phaseLen - 1U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +#endif /* #if defined (ARM_MATH_DSP) */ + + /** + * @} end of FIR_Interpolate group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_f32.c new file mode 100644 index 0000000..1b6d0fb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_f32.c @@ -0,0 +1,494 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_lattice_f32.c + * Description: Processing function for the floating-point FIR Lattice filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup FIR_Lattice Finite Impulse Response (FIR) Lattice Filters + * + * This set of functions implements Finite Impulse Response (FIR) lattice filters + * for Q15, Q31 and floating-point data types. Lattice filters are used in a + * variety of adaptive filter applications. The filter structure is feedforward and + * the net impulse response is finite length. + * The functions operate on blocks + * of input and output data and each call to the function processes + * blockSize samples through the filter. pSrc and + * pDst point to input and output arrays containing blockSize values. + * + * \par Algorithm: + * \image html FIRLattice.gif "Finite Impulse Response Lattice filter" + * The following difference equation is implemented: + *
+ *    f0[n] = g0[n] = x[n]
+ *    fm[n] = fm-1[n] + km * gm-1[n-1] for m = 1, 2, ...M
+ *    gm[n] = km * fm-1[n] + gm-1[n-1] for m = 1, 2, ...M
+ *    y[n] = fM[n]
+ * 
+ * \par + * pCoeffs points to tha array of reflection coefficients of size numStages. + * Reflection Coefficients are stored in the following order. + * \par + *
+ *    {k1, k2, ..., kM}
+ * 
+ * where M is number of stages + * \par + * pState points to a state array of size numStages. + * The state variables (g values) hold previous inputs and are stored in the following order. + *
+ *    {g0[n], g1[n], g2[n] ...gM-1[n]}
+ * 
+ * The state variables are updated after each block of data is processed; the coefficients are untouched. + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter. + * Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numStages, pCoeffs, pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * Set the values in the state buffer to zeros and then manually initialize the instance structure as follows: + *
+ *arm_fir_lattice_instance_f32 S = {numStages, pState, pCoeffs};
+ *arm_fir_lattice_instance_q31 S = {numStages, pState, pCoeffs};
+ *arm_fir_lattice_instance_q15 S = {numStages, pState, pCoeffs};
+ * 
+ * \par + * where numStages is the number of stages in the filter; pState is the address of the state buffer; + * pCoeffs is the address of the coefficient buffer. + * \par Fixed-Point Behavior + * Care must be taken when using the fixed-point versions of the FIR Lattice filter functions. + * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + +/** + * @addtogroup FIR_Lattice + * @{ + */ + + + /** + * @brief Processing function for the floating-point FIR lattice filter. + * @param[in] *S points to an instance of the floating-point FIR lattice structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] blockSize number of samples to process. + * @return none. + */ + +void arm_fir_lattice_f32( + const arm_fir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t *pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *px; /* temporary state pointer */ + float32_t *pk; /* temporary coefficient pointer */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t fcurr1, fnext1, gcurr1, gnext1; /* temporary variables for first sample in loop unrolling */ + float32_t fcurr2, fnext2, gnext2; /* temporary variables for second sample in loop unrolling */ + float32_t fcurr3, fnext3, gnext3; /* temporary variables for third sample in loop unrolling */ + float32_t fcurr4, fnext4, gnext4; /* temporary variables for fourth sample in loop unrolling */ + uint32_t numStages = S->numStages; /* Number of stages in the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + gcurr1 = 0.0f; + pState = &S->pState[0]; + + blkCnt = blockSize >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + + /* Read two samples from input buffer */ + /* f0(n) = x(n) */ + fcurr1 = *pSrc++; + fcurr2 = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* Read g0(n-1) from state */ + gcurr1 = *px; + + /* Process first sample for first tap */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext1 = fcurr1 + ((*pk) * gcurr1); + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext1 = (fcurr1 * (*pk)) + gcurr1; + + /* Process second sample for first tap */ + /* for sample 2 processing */ + fnext2 = fcurr2 + ((*pk) * fcurr1); + gnext2 = (fcurr2 * (*pk)) + fcurr1; + + /* Read next two samples from input buffer */ + /* f0(n+2) = x(n+2) */ + fcurr3 = *pSrc++; + fcurr4 = *pSrc++; + + /* Copy only last input samples into the state buffer + which will be used for next four samples processing */ + *px++ = fcurr4; + + /* Process third sample for first tap */ + fnext3 = fcurr3 + ((*pk) * fcurr2); + gnext3 = (fcurr3 * (*pk)) + fcurr2; + + /* Process fourth sample for first tap */ + fnext4 = fcurr4 + ((*pk) * fcurr3); + gnext4 = (fcurr4 * (*pk++)) + fcurr3; + + /* Update of f values for next coefficient set processing */ + fcurr1 = fnext1; + fcurr2 = fnext2; + fcurr3 = fnext3; + fcurr4 = fnext4; + + /* Loop unrolling. Process 4 taps at a time . */ + stageCnt = (numStages - 1U) >> 2U; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numStages-3 coefficients. */ + + /* Process 2nd, 3rd, 4th and 5th taps ... here */ + while (stageCnt > 0U) + { + /* Read g1(n-1), g3(n-1) .... from state */ + gcurr1 = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext4; + + /* Process first sample for 2nd, 6th .. tap */ + /* Sample processing for K2, K6.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext1 = fcurr1 + ((*pk) * gcurr1); + /* Process second sample for 2nd, 6th .. tap */ + /* for sample 2 processing */ + fnext2 = fcurr2 + ((*pk) * gnext1); + /* Process third sample for 2nd, 6th .. tap */ + fnext3 = fcurr3 + ((*pk) * gnext2); + /* Process fourth sample for 2nd, 6th .. tap */ + fnext4 = fcurr4 + ((*pk) * gnext3); + + /* g2(n) = f1(n) * K2 + g1(n-1) */ + /* Calculation of state values for next stage */ + gnext4 = (fcurr4 * (*pk)) + gnext3; + gnext3 = (fcurr3 * (*pk)) + gnext2; + gnext2 = (fcurr2 * (*pk)) + gnext1; + gnext1 = (fcurr1 * (*pk++)) + gcurr1; + + + /* Read g2(n-1), g4(n-1) .... from state */ + gcurr1 = *px; + + /* save g2(n) in state buffer */ + *px++ = gnext4; + + /* Sample processing for K3, K7.... */ + /* Process first sample for 3rd, 7th .. tap */ + /* f3(n) = f2(n) + K3 * g2(n-1) */ + fcurr1 = fnext1 + ((*pk) * gcurr1); + /* Process second sample for 3rd, 7th .. tap */ + fcurr2 = fnext2 + ((*pk) * gnext1); + /* Process third sample for 3rd, 7th .. tap */ + fcurr3 = fnext3 + ((*pk) * gnext2); + /* Process fourth sample for 3rd, 7th .. tap */ + fcurr4 = fnext4 + ((*pk) * gnext3); + + /* Calculation of state values for next stage */ + /* g3(n) = f2(n) * K3 + g2(n-1) */ + gnext4 = (fnext4 * (*pk)) + gnext3; + gnext3 = (fnext3 * (*pk)) + gnext2; + gnext2 = (fnext2 * (*pk)) + gnext1; + gnext1 = (fnext1 * (*pk++)) + gcurr1; + + + /* Read g1(n-1), g3(n-1) .... from state */ + gcurr1 = *px; + + /* save g3(n) in state buffer */ + *px++ = gnext4; + + /* Sample processing for K4, K8.... */ + /* Process first sample for 4th, 8th .. tap */ + /* f4(n) = f3(n) + K4 * g3(n-1) */ + fnext1 = fcurr1 + ((*pk) * gcurr1); + /* Process second sample for 4th, 8th .. tap */ + /* for sample 2 processing */ + fnext2 = fcurr2 + ((*pk) * gnext1); + /* Process third sample for 4th, 8th .. tap */ + fnext3 = fcurr3 + ((*pk) * gnext2); + /* Process fourth sample for 4th, 8th .. tap */ + fnext4 = fcurr4 + ((*pk) * gnext3); + + /* g4(n) = f3(n) * K4 + g3(n-1) */ + /* Calculation of state values for next stage */ + gnext4 = (fcurr4 * (*pk)) + gnext3; + gnext3 = (fcurr3 * (*pk)) + gnext2; + gnext2 = (fcurr2 * (*pk)) + gnext1; + gnext1 = (fcurr1 * (*pk++)) + gcurr1; + + /* Read g2(n-1), g4(n-1) .... from state */ + gcurr1 = *px; + + /* save g4(n) in state buffer */ + *px++ = gnext4; + + /* Sample processing for K5, K9.... */ + /* Process first sample for 5th, 9th .. tap */ + /* f5(n) = f4(n) + K5 * g4(n-1) */ + fcurr1 = fnext1 + ((*pk) * gcurr1); + /* Process second sample for 5th, 9th .. tap */ + fcurr2 = fnext2 + ((*pk) * gnext1); + /* Process third sample for 5th, 9th .. tap */ + fcurr3 = fnext3 + ((*pk) * gnext2); + /* Process fourth sample for 5th, 9th .. tap */ + fcurr4 = fnext4 + ((*pk) * gnext3); + + /* Calculation of state values for next stage */ + /* g5(n) = f4(n) * K5 + g4(n-1) */ + gnext4 = (fnext4 * (*pk)) + gnext3; + gnext3 = (fnext3 * (*pk)) + gnext2; + gnext2 = (fnext2 * (*pk)) + gnext1; + gnext1 = (fnext1 * (*pk++)) + gcurr1; + + stageCnt--; + } + + /* If the (filter length -1) is not a multiple of 4, compute the remaining filter taps */ + stageCnt = (numStages - 1U) % 0x4U; + + while (stageCnt > 0U) + { + gcurr1 = *px; + + /* save g value in state buffer */ + *px++ = gnext4; + + /* Process four samples for last three taps here */ + fnext1 = fcurr1 + ((*pk) * gcurr1); + fnext2 = fcurr2 + ((*pk) * gnext1); + fnext3 = fcurr3 + ((*pk) * gnext2); + fnext4 = fcurr4 + ((*pk) * gnext3); + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext4 = (fcurr4 * (*pk)) + gnext3; + gnext3 = (fcurr3 * (*pk)) + gnext2; + gnext2 = (fcurr2 * (*pk)) + gnext1; + gnext1 = (fcurr1 * (*pk++)) + gcurr1; + + /* Update of f values for next coefficient set processing */ + fcurr1 = fnext1; + fcurr2 = fnext2; + fcurr3 = fnext3; + fcurr4 = fnext4; + + stageCnt--; + + } + + /* The results in the 4 accumulators, store in the destination buffer. */ + /* y(n) = fN(n) */ + *pDst++ = fcurr1; + *pDst++ = fcurr2; + *pDst++ = fcurr3; + *pDst++ = fcurr4; + + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurr1 = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* read g2(n) from state buffer */ + gcurr1 = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext1 = fcurr1 + ((*pk) * gcurr1); + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext1 = (fcurr1 * (*pk++)) + gcurr1; + + /* save g1(n) in state buffer */ + *px++ = fcurr1; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr1 = fnext1; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g2(n) from state buffer */ + gcurr1 = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext1; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext1 = fcurr1 + ((*pk) * gcurr1); + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext1 = (fcurr1 * (*pk++)) + gcurr1; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr1 = fnext1; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = fcurr1; + + blkCnt--; + + } + +#else + + /* Run the below code for Cortex-M0 */ + + float32_t fcurr, fnext, gcurr, gnext; /* temporary variables */ + uint32_t numStages = S->numStages; /* Length of the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + pState = &S->pState[0]; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize coeff pointer */ + pk = pCoeffs; + + /* Initialize state pointer */ + px = pState; + + /* read g0(n-1) from state buffer */ + gcurr = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext = fcurr + ((*pk) * gcurr); + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext = (fcurr * (*pk++)) + gcurr; + + /* save f0(n) in state buffer */ + *px++ = fcurr; + + /* f1(n) is saved in fcurr + for next stage processing */ + fcurr = fnext; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g2(n) from state buffer */ + gcurr = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext = fcurr + ((*pk) * gcurr); + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext = (fcurr * (*pk++)) + gcurr; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr = fnext; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = fcurr; + + blkCnt--; + + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_f32.c new file mode 100644 index 0000000..55520eb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_f32.c @@ -0,0 +1,71 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_lattice_init_f32.c + * Description: Floating-point FIR Lattice filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Lattice + * @{ + */ + +/** + * @brief Initialization function for the floating-point FIR lattice filter. + * @param[in] *S points to an instance of the floating-point FIR lattice structure. + * @param[in] numStages number of filter stages. + * @param[in] *pCoeffs points to the coefficient buffer. The array is of length numStages. + * @param[in] *pState points to the state buffer. The array is of length numStages. + * @return none. + */ + +void arm_fir_lattice_init_f32( + arm_fir_lattice_instance_f32 * S, + uint16_t numStages, + float32_t * pCoeffs, + float32_t * pState) +{ + /* Assign filter taps */ + S->numStages = numStages; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always numStages */ + memset(pState, 0, (numStages) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q15.c new file mode 100644 index 0000000..59cf496 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q15.c @@ -0,0 +1,71 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_lattice_init_q15.c + * Description: Q15 FIR Lattice filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Lattice + * @{ + */ + + /** + * @brief Initialization function for the Q15 FIR lattice filter. + * @param[in] *S points to an instance of the Q15 FIR lattice structure. + * @param[in] numStages number of filter stages. + * @param[in] *pCoeffs points to the coefficient buffer. The array is of length numStages. + * @param[in] *pState points to the state buffer. The array is of length numStages. + * @return none. + */ + +void arm_fir_lattice_init_q15( + arm_fir_lattice_instance_q15 * S, + uint16_t numStages, + q15_t * pCoeffs, + q15_t * pState) +{ + /* Assign filter taps */ + S->numStages = numStages; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always numStages */ + memset(pState, 0, (numStages) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q31.c new file mode 100644 index 0000000..abdd76f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_init_q31.c @@ -0,0 +1,71 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_lattice_init_q31.c + * Description: Q31 FIR lattice filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Lattice + * @{ + */ + + /** + * @brief Initialization function for the Q31 FIR lattice filter. + * @param[in] *S points to an instance of the Q31 FIR lattice structure. + * @param[in] numStages number of filter stages. + * @param[in] *pCoeffs points to the coefficient buffer. The array is of length numStages. + * @param[in] *pState points to the state buffer. The array is of length numStages. + * @return none. + */ + +void arm_fir_lattice_init_q31( + arm_fir_lattice_instance_q31 * S, + uint16_t numStages, + q31_t * pCoeffs, + q31_t * pState) +{ + /* Assign filter taps */ + S->numStages = numStages; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always numStages */ + memset(pState, 0, (numStages) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q15.c new file mode 100644 index 0000000..fb95ab6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q15.c @@ -0,0 +1,524 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_lattice_q15.c + * Description: Q15 FIR lattice filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Lattice + * @{ + */ + + +/** + * @brief Processing function for the Q15 FIR lattice filter. + * @param[in] *S points to an instance of the Q15 FIR lattice structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] blockSize number of samples to process. + * @return none. + */ + +void arm_fir_lattice_q15( + const arm_fir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *px; /* temporary state pointer */ + q15_t *pk; /* temporary coefficient pointer */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t fcurnt1, fnext1, gcurnt1 = 0, gnext1; /* temporary variables for first sample in loop unrolling */ + q31_t fcurnt2, fnext2, gnext2; /* temporary variables for second sample in loop unrolling */ + q31_t fcurnt3, fnext3, gnext3; /* temporary variables for third sample in loop unrolling */ + q31_t fcurnt4, fnext4, gnext4; /* temporary variables for fourth sample in loop unrolling */ + uint32_t numStages = S->numStages; /* Number of stages in the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + pState = &S->pState[0]; + + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + + /* Read two samples from input buffer */ + /* f0(n) = x(n) */ + fcurnt1 = *pSrc++; + fcurnt2 = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* Read g0(n-1) from state */ + gcurnt1 = *px; + + /* Process first sample for first tap */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext1 = (q31_t) ((gcurnt1 * (*pk)) >> 15U) + fcurnt1; + fnext1 = __SSAT(fnext1, 16); + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext1 = (q31_t) ((fcurnt1 * (*pk)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + /* Process second sample for first tap */ + /* for sample 2 processing */ + fnext2 = (q31_t) ((fcurnt1 * (*pk)) >> 15U) + fcurnt2; + fnext2 = __SSAT(fnext2, 16); + + gnext2 = (q31_t) ((fcurnt2 * (*pk)) >> 15U) + fcurnt1; + gnext2 = __SSAT(gnext2, 16); + + + /* Read next two samples from input buffer */ + /* f0(n+2) = x(n+2) */ + fcurnt3 = *pSrc++; + fcurnt4 = *pSrc++; + + /* Copy only last input samples into the state buffer + which is used for next four samples processing */ + *px++ = (q15_t) fcurnt4; + + /* Process third sample for first tap */ + fnext3 = (q31_t) ((fcurnt2 * (*pk)) >> 15U) + fcurnt3; + fnext3 = __SSAT(fnext3, 16); + gnext3 = (q31_t) ((fcurnt3 * (*pk)) >> 15U) + fcurnt2; + gnext3 = __SSAT(gnext3, 16); + + /* Process fourth sample for first tap */ + fnext4 = (q31_t) ((fcurnt3 * (*pk)) >> 15U) + fcurnt4; + fnext4 = __SSAT(fnext4, 16); + gnext4 = (q31_t) ((fcurnt4 * (*pk++)) >> 15U) + fcurnt3; + gnext4 = __SSAT(gnext4, 16); + + /* Update of f values for next coefficient set processing */ + fcurnt1 = fnext1; + fcurnt2 = fnext2; + fcurnt3 = fnext3; + fcurnt4 = fnext4; + + + /* Loop unrolling. Process 4 taps at a time . */ + stageCnt = (numStages - 1U) >> 2; + + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numStages-3 coefficients. */ + + /* Process 2nd, 3rd, 4th and 5th taps ... here */ + while (stageCnt > 0U) + { + /* Read g1(n-1), g3(n-1) .... from state */ + gcurnt1 = *px; + + /* save g1(n) in state buffer */ + *px++ = (q15_t) gnext4; + + /* Process first sample for 2nd, 6th .. tap */ + /* Sample processing for K2, K6.... */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext1 = (q31_t) ((gcurnt1 * (*pk)) >> 15U) + fcurnt1; + fnext1 = __SSAT(fnext1, 16); + + + /* Process second sample for 2nd, 6th .. tap */ + /* for sample 2 processing */ + fnext2 = (q31_t) ((gnext1 * (*pk)) >> 15U) + fcurnt2; + fnext2 = __SSAT(fnext2, 16); + /* Process third sample for 2nd, 6th .. tap */ + fnext3 = (q31_t) ((gnext2 * (*pk)) >> 15U) + fcurnt3; + fnext3 = __SSAT(fnext3, 16); + /* Process fourth sample for 2nd, 6th .. tap */ + /* fnext4 = fcurnt4 + (*pk) * gnext3; */ + fnext4 = (q31_t) ((gnext3 * (*pk)) >> 15U) + fcurnt4; + fnext4 = __SSAT(fnext4, 16); + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + /* Calculation of state values for next stage */ + gnext4 = (q31_t) ((fcurnt4 * (*pk)) >> 15U) + gnext3; + gnext4 = __SSAT(gnext4, 16); + gnext3 = (q31_t) ((fcurnt3 * (*pk)) >> 15U) + gnext2; + gnext3 = __SSAT(gnext3, 16); + + gnext2 = (q31_t) ((fcurnt2 * (*pk)) >> 15U) + gnext1; + gnext2 = __SSAT(gnext2, 16); + + gnext1 = (q31_t) ((fcurnt1 * (*pk++)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + + /* Read g2(n-1), g4(n-1) .... from state */ + gcurnt1 = *px; + + /* save g1(n) in state buffer */ + *px++ = (q15_t) gnext4; + + /* Sample processing for K3, K7.... */ + /* Process first sample for 3rd, 7th .. tap */ + /* f3(n) = f2(n) + K3 * g2(n-1) */ + fcurnt1 = (q31_t) ((gcurnt1 * (*pk)) >> 15U) + fnext1; + fcurnt1 = __SSAT(fcurnt1, 16); + + /* Process second sample for 3rd, 7th .. tap */ + fcurnt2 = (q31_t) ((gnext1 * (*pk)) >> 15U) + fnext2; + fcurnt2 = __SSAT(fcurnt2, 16); + + /* Process third sample for 3rd, 7th .. tap */ + fcurnt3 = (q31_t) ((gnext2 * (*pk)) >> 15U) + fnext3; + fcurnt3 = __SSAT(fcurnt3, 16); + + /* Process fourth sample for 3rd, 7th .. tap */ + fcurnt4 = (q31_t) ((gnext3 * (*pk)) >> 15U) + fnext4; + fcurnt4 = __SSAT(fcurnt4, 16); + + /* Calculation of state values for next stage */ + /* g3(n) = f2(n) * K3 + g2(n-1) */ + gnext4 = (q31_t) ((fnext4 * (*pk)) >> 15U) + gnext3; + gnext4 = __SSAT(gnext4, 16); + + gnext3 = (q31_t) ((fnext3 * (*pk)) >> 15U) + gnext2; + gnext3 = __SSAT(gnext3, 16); + + gnext2 = (q31_t) ((fnext2 * (*pk)) >> 15U) + gnext1; + gnext2 = __SSAT(gnext2, 16); + + gnext1 = (q31_t) ((fnext1 * (*pk++)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + /* Read g1(n-1), g3(n-1) .... from state */ + gcurnt1 = *px; + + /* save g1(n) in state buffer */ + *px++ = (q15_t) gnext4; + + /* Sample processing for K4, K8.... */ + /* Process first sample for 4th, 8th .. tap */ + /* f4(n) = f3(n) + K4 * g3(n-1) */ + fnext1 = (q31_t) ((gcurnt1 * (*pk)) >> 15U) + fcurnt1; + fnext1 = __SSAT(fnext1, 16); + + /* Process second sample for 4th, 8th .. tap */ + /* for sample 2 processing */ + fnext2 = (q31_t) ((gnext1 * (*pk)) >> 15U) + fcurnt2; + fnext2 = __SSAT(fnext2, 16); + + /* Process third sample for 4th, 8th .. tap */ + fnext3 = (q31_t) ((gnext2 * (*pk)) >> 15U) + fcurnt3; + fnext3 = __SSAT(fnext3, 16); + + /* Process fourth sample for 4th, 8th .. tap */ + fnext4 = (q31_t) ((gnext3 * (*pk)) >> 15U) + fcurnt4; + fnext4 = __SSAT(fnext4, 16); + + /* g4(n) = f3(n) * K4 + g3(n-1) */ + /* Calculation of state values for next stage */ + gnext4 = (q31_t) ((fcurnt4 * (*pk)) >> 15U) + gnext3; + gnext4 = __SSAT(gnext4, 16); + + gnext3 = (q31_t) ((fcurnt3 * (*pk)) >> 15U) + gnext2; + gnext3 = __SSAT(gnext3, 16); + + gnext2 = (q31_t) ((fcurnt2 * (*pk)) >> 15U) + gnext1; + gnext2 = __SSAT(gnext2, 16); + gnext1 = (q31_t) ((fcurnt1 * (*pk++)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + + /* Read g2(n-1), g4(n-1) .... from state */ + gcurnt1 = *px; + + /* save g4(n) in state buffer */ + *px++ = (q15_t) gnext4; + + /* Sample processing for K5, K9.... */ + /* Process first sample for 5th, 9th .. tap */ + /* f5(n) = f4(n) + K5 * g4(n-1) */ + fcurnt1 = (q31_t) ((gcurnt1 * (*pk)) >> 15U) + fnext1; + fcurnt1 = __SSAT(fcurnt1, 16); + + /* Process second sample for 5th, 9th .. tap */ + fcurnt2 = (q31_t) ((gnext1 * (*pk)) >> 15U) + fnext2; + fcurnt2 = __SSAT(fcurnt2, 16); + + /* Process third sample for 5th, 9th .. tap */ + fcurnt3 = (q31_t) ((gnext2 * (*pk)) >> 15U) + fnext3; + fcurnt3 = __SSAT(fcurnt3, 16); + + /* Process fourth sample for 5th, 9th .. tap */ + fcurnt4 = (q31_t) ((gnext3 * (*pk)) >> 15U) + fnext4; + fcurnt4 = __SSAT(fcurnt4, 16); + + /* Calculation of state values for next stage */ + /* g5(n) = f4(n) * K5 + g4(n-1) */ + gnext4 = (q31_t) ((fnext4 * (*pk)) >> 15U) + gnext3; + gnext4 = __SSAT(gnext4, 16); + gnext3 = (q31_t) ((fnext3 * (*pk)) >> 15U) + gnext2; + gnext3 = __SSAT(gnext3, 16); + gnext2 = (q31_t) ((fnext2 * (*pk)) >> 15U) + gnext1; + gnext2 = __SSAT(gnext2, 16); + gnext1 = (q31_t) ((fnext1 * (*pk++)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + stageCnt--; + } + + /* If the (filter length -1) is not a multiple of 4, compute the remaining filter taps */ + stageCnt = (numStages - 1U) % 0x4U; + + while (stageCnt > 0U) + { + gcurnt1 = *px; + + /* save g value in state buffer */ + *px++ = (q15_t) gnext4; + + /* Process four samples for last three taps here */ + fnext1 = (q31_t) ((gcurnt1 * (*pk)) >> 15U) + fcurnt1; + fnext1 = __SSAT(fnext1, 16); + fnext2 = (q31_t) ((gnext1 * (*pk)) >> 15U) + fcurnt2; + fnext2 = __SSAT(fnext2, 16); + + fnext3 = (q31_t) ((gnext2 * (*pk)) >> 15U) + fcurnt3; + fnext3 = __SSAT(fnext3, 16); + + fnext4 = (q31_t) ((gnext3 * (*pk)) >> 15U) + fcurnt4; + fnext4 = __SSAT(fnext4, 16); + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext4 = (q31_t) ((fcurnt4 * (*pk)) >> 15U) + gnext3; + gnext4 = __SSAT(gnext4, 16); + gnext3 = (q31_t) ((fcurnt3 * (*pk)) >> 15U) + gnext2; + gnext3 = __SSAT(gnext3, 16); + gnext2 = (q31_t) ((fcurnt2 * (*pk)) >> 15U) + gnext1; + gnext2 = __SSAT(gnext2, 16); + gnext1 = (q31_t) ((fcurnt1 * (*pk++)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + /* Update of f values for next coefficient set processing */ + fcurnt1 = fnext1; + fcurnt2 = fnext2; + fcurnt3 = fnext3; + fcurnt4 = fnext4; + + stageCnt--; + + } + + /* The results in the 4 accumulators, store in the destination buffer. */ + /* y(n) = fN(n) */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = __PKHBT(fcurnt1, fcurnt2, 16); + *__SIMD32(pDst)++ = __PKHBT(fcurnt3, fcurnt4, 16); + +#else + + *__SIMD32(pDst)++ = __PKHBT(fcurnt2, fcurnt1, 16); + *__SIMD32(pDst)++ = __PKHBT(fcurnt4, fcurnt3, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurnt1 = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* read g2(n) from state buffer */ + gcurnt1 = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext1 = (((q31_t) gcurnt1 * (*pk)) >> 15U) + fcurnt1; + fnext1 = __SSAT(fnext1, 16); + + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext1 = (((q31_t) fcurnt1 * (*pk++)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + /* save g1(n) in state buffer */ + *px++ = (q15_t) fcurnt1; + + /* f1(n) is saved in fcurnt1 + for next stage processing */ + fcurnt1 = fnext1; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g2(n) from state buffer */ + gcurnt1 = *px; + + /* save g1(n) in state buffer */ + *px++ = (q15_t) gnext1; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext1 = (((q31_t) gcurnt1 * (*pk)) >> 15U) + fcurnt1; + fnext1 = __SSAT(fnext1, 16); + + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext1 = (((q31_t) fcurnt1 * (*pk++)) >> 15U) + gcurnt1; + gnext1 = __SSAT(gnext1, 16); + + + /* f1(n) is saved in fcurnt1 + for next stage processing */ + fcurnt1 = fnext1; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = __SSAT(fcurnt1, 16); + + + blkCnt--; + + } + +#else + + /* Run the below code for Cortex-M0 */ + + q31_t fcurnt, fnext, gcurnt, gnext; /* temporary variables */ + uint32_t numStages = S->numStages; /* Length of the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + pState = &S->pState[0]; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurnt = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* read g0(n-1) from state buffer */ + gcurnt = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext = ((gcurnt * (*pk)) >> 15U) + fcurnt; + fnext = __SSAT(fnext, 16); + + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext = ((fcurnt * (*pk++)) >> 15U) + gcurnt; + gnext = __SSAT(gnext, 16); + + /* save f0(n) in state buffer */ + *px++ = (q15_t) fcurnt; + + /* f1(n) is saved in fcurnt + for next stage processing */ + fcurnt = fnext; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g1(n-1) from state buffer */ + gcurnt = *px; + + /* save g0(n-1) in state buffer */ + *px++ = (q15_t) gnext; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext = ((gcurnt * (*pk)) >> 15U) + fcurnt; + fnext = __SSAT(fnext, 16); + + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext = ((fcurnt * (*pk++)) >> 15U) + gcurnt; + gnext = __SSAT(gnext, 16); + + + /* f1(n) is saved in fcurnt + for next stage processing */ + fcurnt = fnext; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = __SSAT(fcurnt, 16); + + + blkCnt--; + + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q31.c new file mode 100644 index 0000000..9d52bbc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_lattice_q31.c @@ -0,0 +1,341 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_lattice_q31.c + * Description: Q31 FIR lattice filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Lattice + * @{ + */ + + +/** + * @brief Processing function for the Q31 FIR lattice filter. + * @param[in] *S points to an instance of the Q31 FIR lattice structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] blockSize number of samples to process. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * In order to avoid overflows the input signal must be scaled down by 2*log2(numStages) bits. + */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + +void arm_fir_lattice_q31( + const arm_fir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *px; /* temporary state pointer */ + q31_t *pk; /* temporary coefficient pointer */ + q31_t fcurr1, fnext1, gcurr1 = 0, gnext1; /* temporary variables for first sample in loop unrolling */ + q31_t fcurr2, fnext2, gnext2; /* temporary variables for second sample in loop unrolling */ + uint32_t numStages = S->numStages; /* Length of the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + q31_t k; + + pState = &S->pState[0]; + + blkCnt = blockSize >> 1U; + + /* First part of the processing with loop unrolling. Compute 2 outputs at a time. + a second loop below computes the remaining 1 sample. */ + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurr1 = *pSrc++; + + /* f0(n) = x(n) */ + fcurr2 = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* read g0(n - 1) from state buffer */ + gcurr1 = *px; + + /* Read the reflection coefficient */ + k = *pk++; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext1 = (q31_t) (((q63_t) gcurr1 * k) >> 32); + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext1 = (q31_t) (((q63_t) fcurr1 * (k)) >> 32); + fnext1 = fcurr1 + (fnext1 << 1U); + gnext1 = gcurr1 + (gnext1 << 1U); + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext2 = (q31_t) (((q63_t) fcurr1 * k) >> 32); + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext2 = (q31_t) (((q63_t) fcurr2 * (k)) >> 32); + fnext2 = fcurr2 + (fnext2 << 1U); + gnext2 = fcurr1 + (gnext2 << 1U); + + /* save g1(n) in state buffer */ + *px++ = fcurr2; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr1 = fnext1; + fcurr2 = fnext2; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + + /* Read the reflection coefficient */ + k = *pk++; + + /* read g2(n) from state buffer */ + gcurr1 = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext2; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext1 = (q31_t) (((q63_t) gcurr1 * k) >> 32); + fnext2 = (q31_t) (((q63_t) gnext1 * k) >> 32); + + fnext1 = fcurr1 + (fnext1 << 1U); + fnext2 = fcurr2 + (fnext2 << 1U); + + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext2 = (q31_t) (((q63_t) fcurr2 * (k)) >> 32); + gnext2 = gnext1 + (gnext2 << 1U); + + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext1 = (q31_t) (((q63_t) fcurr1 * (k)) >> 32); + gnext1 = gcurr1 + (gnext1 << 1U); + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr1 = fnext1; + fcurr2 = fnext2; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = fcurr1; + *pDst++ = fcurr2; + + blkCnt--; + + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x2U; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurr1 = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* read g0(n - 1) from state buffer */ + gcurr1 = *px; + + /* Read the reflection coefficient */ + k = *pk++; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext1 = (q31_t) (((q63_t) gcurr1 * k) >> 32); + fnext1 = fcurr1 + (fnext1 << 1U); + + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext1 = (q31_t) (((q63_t) fcurr1 * (k)) >> 32); + gnext1 = gcurr1 + (gnext1 << 1U); + + /* save g1(n) in state buffer */ + *px++ = fcurr1; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr1 = fnext1; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* Read the reflection coefficient */ + k = *pk++; + + /* read g2(n) from state buffer */ + gcurr1 = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext1; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext1 = (q31_t) (((q63_t) gcurr1 * k) >> 32); + fnext1 = fcurr1 + (fnext1 << 1U); + + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext1 = (q31_t) (((q63_t) fcurr1 * (k)) >> 32); + gnext1 = gcurr1 + (gnext1 << 1U); + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr1 = fnext1; + + stageCnt--; + + } + + + /* y(n) = fN(n) */ + *pDst++ = fcurr1; + + blkCnt--; + + } + + +} + + +#else + +/* Run the below code for Cortex-M0 */ + +void arm_fir_lattice_q31( + const arm_fir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *px; /* temporary state pointer */ + q31_t *pk; /* temporary coefficient pointer */ + q31_t fcurr, fnext, gcurr, gnext; /* temporary variables */ + uint32_t numStages = S->numStages; /* Length of the filter */ + uint32_t blkCnt, stageCnt; /* temporary variables for counts */ + + pState = &S->pState[0]; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* f0(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize coeff pointer */ + pk = (pCoeffs); + + /* Initialize state pointer */ + px = pState; + + /* read g0(n-1) from state buffer */ + gcurr = *px; + + /* for sample 1 processing */ + /* f1(n) = f0(n) + K1 * g0(n-1) */ + fnext = (q31_t) (((q63_t) gcurr * (*pk)) >> 31) + fcurr; + /* g1(n) = f0(n) * K1 + g0(n-1) */ + gnext = (q31_t) (((q63_t) fcurr * (*pk++)) >> 31) + gcurr; + /* save g1(n) in state buffer */ + *px++ = fcurr; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr = fnext; + + stageCnt = (numStages - 1U); + + /* stage loop */ + while (stageCnt > 0U) + { + /* read g2(n) from state buffer */ + gcurr = *px; + + /* save g1(n) in state buffer */ + *px++ = gnext; + + /* Sample processing for K2, K3.... */ + /* f2(n) = f1(n) + K2 * g1(n-1) */ + fnext = (q31_t) (((q63_t) gcurr * (*pk)) >> 31) + fcurr; + /* g2(n) = f1(n) * K2 + g1(n-1) */ + gnext = (q31_t) (((q63_t) fcurr * (*pk++)) >> 31) + gcurr; + + /* f1(n) is saved in fcurr1 + for next stage processing */ + fcurr = fnext; + + stageCnt--; + + } + + /* y(n) = fN(n) */ + *pDst++ = fcurr; + + blkCnt--; + + } + +} + +#endif /* #if defined (ARM_MATH_DSP) */ + + +/** + * @} end of FIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q15.c new file mode 100644 index 0000000..a979783 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q15.c @@ -0,0 +1,679 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_q15.c + * Description: Q15 FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @brief Processing function for the Q15 FIR filter. + * @param[in] *S points to an instance of the Q15 FIR structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, state buffers should be aligned by 32-bit + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both coefficients and state variables are represented in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * After all additions have been performed, the accumulator is truncated to 34.15 format by discarding low 15 bits. + * Lastly, the accumulator is saturated to yield a result in 1.15 format. + * + * \par + * Refer to the function arm_fir_fast_q15() for a faster but less precise implementation of this function. + */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + +void arm_fir_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px1; /* Temporary q15 pointer for state buffer */ + q15_t *pb; /* Temporary pointer for coefficient buffer */ + q31_t x0, x1, x2, x3, c0; /* Temporary variables to hold SIMD state and coefficient values */ + q63_t acc0, acc1, acc2, acc3; /* Accumulators */ + uint32_t numTaps = S->numTaps; /* Number of taps in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 4 output values simultaneously. + * The variables acc0 ... acc3 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + + blkCnt = blockSize >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Copy four new input samples into the state buffer. + ** Use 32-bit SIMD to move the 16-bit data. Only requires two copies. */ + *__SIMD32(pStateCurnt)++ = *__SIMD32(pSrc)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pSrc)++; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Initialize state pointer of type q15 */ + px1 = pState; + + /* Initialize coeff pointer of type q31 */ + pb = pCoeffs; + + /* Read the first two samples from the state buffer: x[n-N], x[n-N-1] */ + x0 = _SIMD32_OFFSET(px1); + + /* Read the third and forth samples from the state buffer: x[n-N-1], x[n-N-2] */ + x1 = _SIMD32_OFFSET(px1 + 1U); + + px1 += 2U; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-4 coefficients. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0U) + { + /* Read the first two coefficients using SIMD: b[N] and b[N-1] coefficients */ + c0 = *__SIMD32(pb)++; + + /* acc0 += b[N] * x[n-N] + b[N-1] * x[n-N-1] */ + acc0 = __SMLALD(x0, c0, acc0); + + /* acc1 += b[N] * x[n-N-1] + b[N-1] * x[n-N-2] */ + acc1 = __SMLALD(x1, c0, acc1); + + /* Read state x[n-N-2], x[n-N-3] */ + x2 = _SIMD32_OFFSET(px1); + + /* Read state x[n-N-3], x[n-N-4] */ + x3 = _SIMD32_OFFSET(px1 + 1U); + + /* acc2 += b[N] * x[n-N-2] + b[N-1] * x[n-N-3] */ + acc2 = __SMLALD(x2, c0, acc2); + + /* acc3 += b[N] * x[n-N-3] + b[N-1] * x[n-N-4] */ + acc3 = __SMLALD(x3, c0, acc3); + + /* Read coefficients b[N-2], b[N-3] */ + c0 = *__SIMD32(pb)++; + + /* acc0 += b[N-2] * x[n-N-2] + b[N-3] * x[n-N-3] */ + acc0 = __SMLALD(x2, c0, acc0); + + /* acc1 += b[N-2] * x[n-N-3] + b[N-3] * x[n-N-4] */ + acc1 = __SMLALD(x3, c0, acc1); + + /* Read state x[n-N-4], x[n-N-5] */ + x0 = _SIMD32_OFFSET(px1 + 2U); + + /* Read state x[n-N-5], x[n-N-6] */ + x1 = _SIMD32_OFFSET(px1 + 3U); + + /* acc2 += b[N-2] * x[n-N-4] + b[N-3] * x[n-N-5] */ + acc2 = __SMLALD(x0, c0, acc2); + + /* acc3 += b[N-2] * x[n-N-5] + b[N-3] * x[n-N-6] */ + acc3 = __SMLALD(x1, c0, acc3); + + px1 += 4U; + + tapCnt--; + + } + + + /* If the filter length is not a multiple of 4, compute the remaining filter taps. + ** This is always be 2 taps since the filter length is even. */ + if ((numTaps & 0x3U) != 0U) + { + /* Read 2 coefficients */ + c0 = *__SIMD32(pb)++; + + /* Fetch 4 state variables */ + x2 = _SIMD32_OFFSET(px1); + + x3 = _SIMD32_OFFSET(px1 + 1U); + + /* Perform the multiply-accumulates */ + acc0 = __SMLALD(x0, c0, acc0); + + px1 += 2U; + + acc1 = __SMLALD(x1, c0, acc1); + acc2 = __SMLALD(x2, c0, acc2); + acc3 = __SMLALD(x3, c0, acc3); + } + + /* The results in the 4 accumulators are in 2.30 format. Convert to 1.15 with saturation. + ** Then store the 4 outputs in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + while (blkCnt > 0U) + { + /* Copy two samples into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0; + + /* Initialize state pointer of type q15 */ + px1 = pState; + + /* Initialize coeff pointer of type q31 */ + pb = pCoeffs; + + tapCnt = numTaps >> 1; + + do + { + + c0 = *__SIMD32(pb)++; + x0 = *__SIMD32(px1)++; + + acc0 = __SMLALD(x0, c0, acc0); + tapCnt--; + } + while (tapCnt > 0U); + + /* The result is in 2.30 format. Convert to 1.15 with saturation. + ** Then store the output in the destination buffer. */ + *pDst++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Calculation of count for copying integer writes */ + tapCnt = (numTaps - 1U) >> 2; + + while (tapCnt > 0U) + { + + /* Copy state values to start of state buffer */ + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + + tapCnt--; + + } + + /* Calculation of count for remaining q15_t data */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* copy remaining data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +#else /* UNALIGNED_SUPPORT_DISABLE */ + +void arm_fir_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q63_t acc0, acc1, acc2, acc3; /* Accumulators */ + q15_t *pb; /* Temporary pointer for coefficient buffer */ + q15_t *px; /* Temporary q31 pointer for SIMD state buffer accesses */ + q31_t x0, x1, x2, c0; /* Temporary variables to hold SIMD state and coefficient values */ + uint32_t numTaps = S->numTaps; /* Number of taps in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 4 output values simultaneously. + * The variables acc0 ... acc3 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + + blkCnt = blockSize >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Copy four new input samples into the state buffer. + ** Use 32-bit SIMD to move the 16-bit data. Only requires two copies. */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Typecast q15_t pointer to q31_t pointer for state reading in q31_t */ + px = pState; + + /* Typecast q15_t pointer to q31_t pointer for coefficient reading in q31_t */ + pb = pCoeffs; + + /* Read the first two samples from the state buffer: x[n-N], x[n-N-1] */ + x0 = *__SIMD32(px)++; + + /* Read the third and forth samples from the state buffer: x[n-N-2], x[n-N-3] */ + x2 = *__SIMD32(px)++; + + /* Loop over the number of taps. Unroll by a factor of 4. + ** Repeat until we've computed numTaps-(numTaps%4) coefficients. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0) + { + /* Read the first two coefficients using SIMD: b[N] and b[N-1] coefficients */ + c0 = *__SIMD32(pb)++; + + /* acc0 += b[N] * x[n-N] + b[N-1] * x[n-N-1] */ + acc0 = __SMLALD(x0, c0, acc0); + + /* acc2 += b[N] * x[n-N-2] + b[N-1] * x[n-N-3] */ + acc2 = __SMLALD(x2, c0, acc2); + + /* pack x[n-N-1] and x[n-N-2] */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x2, x0, 0); +#else + x1 = __PKHBT(x0, x2, 0); +#endif + + /* Read state x[n-N-4], x[n-N-5] */ + x0 = _SIMD32_OFFSET(px); + + /* acc1 += b[N] * x[n-N-1] + b[N-1] * x[n-N-2] */ + acc1 = __SMLALDX(x1, c0, acc1); + + /* pack x[n-N-3] and x[n-N-4] */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x0, x2, 0); +#else + x1 = __PKHBT(x2, x0, 0); +#endif + + /* acc3 += b[N] * x[n-N-3] + b[N-1] * x[n-N-4] */ + acc3 = __SMLALDX(x1, c0, acc3); + + /* Read coefficients b[N-2], b[N-3] */ + c0 = *__SIMD32(pb)++; + + /* acc0 += b[N-2] * x[n-N-2] + b[N-3] * x[n-N-3] */ + acc0 = __SMLALD(x2, c0, acc0); + + /* Read state x[n-N-6], x[n-N-7] with offset */ + x2 = _SIMD32_OFFSET(px + 2U); + + /* acc2 += b[N-2] * x[n-N-4] + b[N-3] * x[n-N-5] */ + acc2 = __SMLALD(x0, c0, acc2); + + /* acc1 += b[N-2] * x[n-N-3] + b[N-3] * x[n-N-4] */ + acc1 = __SMLALDX(x1, c0, acc1); + + /* pack x[n-N-5] and x[n-N-6] */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x2, x0, 0); +#else + x1 = __PKHBT(x0, x2, 0); +#endif + + /* acc3 += b[N-2] * x[n-N-5] + b[N-3] * x[n-N-6] */ + acc3 = __SMLALDX(x1, c0, acc3); + + /* Update state pointer for next state reading */ + px += 4U; + + /* Decrement tap count */ + tapCnt--; + + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps. + ** This is always be 2 taps since the filter length is even. */ + if ((numTaps & 0x3U) != 0U) + { + + /* Read last two coefficients */ + c0 = *__SIMD32(pb)++; + + /* Perform the multiply-accumulates */ + acc0 = __SMLALD(x0, c0, acc0); + acc2 = __SMLALD(x2, c0, acc2); + + /* pack state variables */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x2, x0, 0); +#else + x1 = __PKHBT(x0, x2, 0); +#endif + + /* Read last state variables */ + x0 = *__SIMD32(px); + + /* Perform the multiply-accumulates */ + acc1 = __SMLALDX(x1, c0, acc1); + + /* pack state variables */ +#ifndef ARM_MATH_BIG_ENDIAN + x1 = __PKHBT(x0, x2, 0); +#else + x1 = __PKHBT(x2, x0, 0); +#endif + + /* Perform the multiply-accumulates */ + acc3 = __SMLALDX(x1, c0, acc3); + } + + /* The results in the 4 accumulators are in 2.30 format. Convert to 1.15 with saturation. + ** Then store the 4 outputs in the destination buffer. */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc0 >> 15), 16), __SSAT((acc1 >> 15), 16), 16); + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc2 >> 15), 16), __SSAT((acc3 >> 15), 16), 16); + +#else + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc1 >> 15), 16), __SSAT((acc0 >> 15), 16), 16); + + *__SIMD32(pDst)++ = + __PKHBT(__SSAT((acc3 >> 15), 16), __SSAT((acc2 >> 15), 16), 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + while (blkCnt > 0U) + { + /* Copy two samples into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0; + + /* Use SIMD to hold states and coefficients */ + px = pState; + pb = pCoeffs; + + tapCnt = numTaps >> 1U; + + do + { + acc0 += (q31_t) * px++ * *pb++; + acc0 += (q31_t) * px++ * *pb++; + tapCnt--; + } + while (tapCnt > 0U); + + /* The result is in 2.30 format. Convert to 1.15 with saturation. + ** Then store the output in the destination buffer. */ + *pDst++ = (q15_t) (__SSAT((acc0 >> 15), 16)); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Calculation of count for copying integer writes */ + tapCnt = (numTaps - 1U) >> 2; + + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + tapCnt--; + + } + + /* Calculation of count for remaining q15_t data */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* copy remaining data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +#else /* ARM_MATH_CM0_FAMILY */ + + +/* Run the below code for Cortex-M0 */ + +void arm_fir_q15( + const arm_fir_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + + + + q15_t *px; /* Temporary pointer for state buffer */ + q15_t *pb; /* Temporary pointer for coefficient buffer */ + q63_t acc; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Number of nTaps in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Initialize blkCnt with blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = pCoeffs; + + tapCnt = numTaps; + + /* Perform the multiply-accumulates */ + do + { + /* acc = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] */ + acc += (q31_t) * px++ * *pb++; + tapCnt--; + } while (tapCnt > 0U); + + /* The result is in 2.30 format. Convert to 1.15 + ** Then store the output in the destination buffer. */ + *pDst++ = (q15_t) __SSAT((acc >> 15U), 16); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the samples loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy numTaps number of values */ + tapCnt = (numTaps - 1U); + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +#endif /* #if defined (ARM_MATH_DSP) */ + + + + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q31.c new file mode 100644 index 0000000..b0a2723 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q31.c @@ -0,0 +1,353 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_q31.c + * Description: Q31 FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @param[in] *S points to an instance of the Q31 FIR filter structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clip. + * In order to avoid overflows completely the input signal must be scaled down by log2(numTaps) bits. + * After all multiply-accumulates are performed, the 2.62 accumulator is right shifted by 31 bits and saturated to 1.31 format to yield the final result. + * + * \par + * Refer to the function arm_fir_fast_q31() for a faster but less precise implementation of this filter for Cortex-M3 and Cortex-M4. + */ + +void arm_fir_q31( + const arm_fir_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t x0, x1, x2; /* Temporary variables to hold state */ + q31_t c0; /* Temporary variable to hold coefficient value */ + q31_t *px; /* Temporary pointer for state */ + q31_t *pb; /* Temporary pointer for coefficient buffer */ + q63_t acc0, acc1, acc2; /* Accumulators */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, tapCnt, blkCnt, tapCntN3; /* Loop counters */ + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 4 output values simultaneously. + * The variables acc0 ... acc3 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + blkCnt = blockSize / 3; + blockSize = blockSize - (3 * blkCnt); + + tapCnt = numTaps / 3; + tapCntN3 = numTaps - (3 * tapCnt); + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Copy three new input samples into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coefficient pointer */ + pb = pCoeffs; + + /* Read the first two samples from the state buffer: + * x[n-numTaps], x[n-numTaps-1] */ + x0 = *(px++); + x1 = *(px++); + + /* Loop unrolling. Process 3 taps at a time. */ + i = tapCnt; + + while (i > 0U) + { + /* Read the b[numTaps] coefficient */ + c0 = *pb; + + /* Read x[n-numTaps-2] sample */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += ((q63_t) x0 * c0); + acc1 += ((q63_t) x1 * c0); + acc2 += ((q63_t) x2 * c0); + + /* Read the coefficient and state */ + c0 = *(pb + 1U); + x0 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += ((q63_t) x1 * c0); + acc1 += ((q63_t) x2 * c0); + acc2 += ((q63_t) x0 * c0); + + /* Read the coefficient and state */ + c0 = *(pb + 2U); + x1 = *(px++); + + /* update coefficient pointer */ + pb += 3U; + + /* Perform the multiply-accumulates */ + acc0 += ((q63_t) x2 * c0); + acc1 += ((q63_t) x0 * c0); + acc2 += ((q63_t) x1 * c0); + + /* Decrement the loop counter */ + i--; + } + + /* If the filter length is not a multiple of 3, compute the remaining filter taps */ + + i = tapCntN3; + + while (i > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x2 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += ((q63_t) x0 * c0); + acc1 += ((q63_t) x1 * c0); + acc2 += ((q63_t) x2 * c0); + + /* Reuse the present sample states for next sample */ + x0 = x1; + x1 = x2; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 3 to process the next group of 3 samples */ + pState = pState + 3; + + /* The results in the 3 accumulators are in 2.30 format. Convert to 1.31 + ** Then store the 3 outputs in the destination buffer. */ + *pDst++ = (q31_t) (acc0 >> 31U); + *pDst++ = (q31_t) (acc1 >> 31U); + *pDst++ = (q31_t) (acc2 >> 31U); + + /* Decrement the samples loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 3, compute any remaining output samples here. + ** No loop unrolling is used. */ + + while (blockSize > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = (pCoeffs); + + i = numTaps; + + /* Perform the multiply-accumulates */ + do + { + acc0 += (q63_t) * (px++) * (*(pb++)); + i--; + } while (i > 0U); + + /* The result is in 2.62 format. Convert to 1.31 + ** Then store the output in the destination buffer. */ + *pDst++ = (q31_t) (acc0 >> 31U); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the samples loop counter */ + blockSize--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + q31_t *px; /* Temporary pointer for state */ + q31_t *pb; /* Temporary pointer for coefficient buffer */ + q63_t acc; /* Accumulator */ + uint32_t numTaps = S->numTaps; /* Length of the filter */ + uint32_t i, tapCnt, blkCnt; /* Loop counters */ + + /* S->pState buffer contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Initialize blkCnt with blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = pCoeffs; + + i = numTaps; + + /* Perform the multiply-accumulates */ + do + { + /* acc = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] */ + acc += (q63_t) * px++ * *pb++; + i--; + } while (i > 0U); + + /* The result is in 2.62 format. Convert to 1.31 + ** Then store the output in the destination buffer. */ + *pDst++ = (q31_t) (acc >> 31U); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the samples loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the starting of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + /* Copy numTaps number of values */ + tapCnt = numTaps - 1U; + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q7.c new file mode 100644 index 0000000..4f795d7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_q7.c @@ -0,0 +1,385 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_q7.c + * Description: Q7 FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR + * @{ + */ + +/** + * @param[in] *S points to an instance of the Q7 FIR filter structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 32-bit internal accumulator. + * Both coefficients and state variables are represented in 1.7 format and multiplications yield a 2.14 result. + * The 2.14 intermediate results are accumulated in a 32-bit accumulator in 18.14 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * The accumulator is converted to 18.7 format by discarding the low 7 bits. + * Finally, the result is truncated to 1.7 format. + */ + +void arm_fir_q7( + const arm_fir_instance_q7 * S, + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q7_t *pState = S->pState; /* State pointer */ + q7_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q7_t *pStateCurnt; /* Points to the current sample of the state */ + q7_t x0, x1, x2, x3; /* Temporary variables to hold state */ + q7_t c0; /* Temporary variable to hold coefficient value */ + q7_t *px; /* Temporary pointer for state */ + q7_t *pb; /* Temporary pointer for coefficient buffer */ + q31_t acc0, acc1, acc2, acc3; /* Accumulators */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t i, tapCnt, blkCnt; /* Loop counters */ + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Apply loop unrolling and compute 4 output values simultaneously. + * The variables acc0 ... acc3 hold output values that are being computed: + * + * acc0 = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] + * acc1 = b[numTaps-1] * x[n-numTaps] + b[numTaps-2] * x[n-numTaps-1] + b[numTaps-3] * x[n-numTaps-2] +...+ b[0] * x[1] + * acc2 = b[numTaps-1] * x[n-numTaps+1] + b[numTaps-2] * x[n-numTaps] + b[numTaps-3] * x[n-numTaps-1] +...+ b[0] * x[2] + * acc3 = b[numTaps-1] * x[n-numTaps+2] + b[numTaps-2] * x[n-numTaps+1] + b[numTaps-3] * x[n-numTaps] +...+ b[0] * x[3] + */ + blkCnt = blockSize >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Copy four new input samples into the state buffer */ + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + *pStateCurnt++ = *pSrc++; + + /* Set all accumulators to zero */ + acc0 = 0; + acc1 = 0; + acc2 = 0; + acc3 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coefficient pointer */ + pb = pCoeffs; + + /* Read the first three samples from the state buffer: + * x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2] */ + x0 = *(px++); + x1 = *(px++); + x2 = *(px++); + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + i = tapCnt; + + while (i > 0U) + { + /* Read the b[numTaps] coefficient */ + c0 = *pb; + + /* Read x[n-numTaps-3] sample */ + x3 = *px; + + /* acc0 += b[numTaps] * x[n-numTaps] */ + acc0 += ((q15_t) x0 * c0); + + /* acc1 += b[numTaps] * x[n-numTaps-1] */ + acc1 += ((q15_t) x1 * c0); + + /* acc2 += b[numTaps] * x[n-numTaps-2] */ + acc2 += ((q15_t) x2 * c0); + + /* acc3 += b[numTaps] * x[n-numTaps-3] */ + acc3 += ((q15_t) x3 * c0); + + /* Read the b[numTaps-1] coefficient */ + c0 = *(pb + 1U); + + /* Read x[n-numTaps-4] sample */ + x0 = *(px + 1U); + + /* Perform the multiply-accumulates */ + acc0 += ((q15_t) x1 * c0); + acc1 += ((q15_t) x2 * c0); + acc2 += ((q15_t) x3 * c0); + acc3 += ((q15_t) x0 * c0); + + /* Read the b[numTaps-2] coefficient */ + c0 = *(pb + 2U); + + /* Read x[n-numTaps-5] sample */ + x1 = *(px + 2U); + + /* Perform the multiply-accumulates */ + acc0 += ((q15_t) x2 * c0); + acc1 += ((q15_t) x3 * c0); + acc2 += ((q15_t) x0 * c0); + acc3 += ((q15_t) x1 * c0); + + /* Read the b[numTaps-3] coefficients */ + c0 = *(pb + 3U); + + /* Read x[n-numTaps-6] sample */ + x2 = *(px + 3U); + + /* Perform the multiply-accumulates */ + acc0 += ((q15_t) x3 * c0); + acc1 += ((q15_t) x0 * c0); + acc2 += ((q15_t) x1 * c0); + acc3 += ((q15_t) x2 * c0); + + /* update coefficient pointer */ + pb += 4U; + px += 4U; + + /* Decrement the loop counter */ + i--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + + i = numTaps - (tapCnt * 4U); + while (i > 0U) + { + /* Read coefficients */ + c0 = *(pb++); + + /* Fetch 1 state variable */ + x3 = *(px++); + + /* Perform the multiply-accumulates */ + acc0 += ((q15_t) x0 * c0); + acc1 += ((q15_t) x1 * c0); + acc2 += ((q15_t) x2 * c0); + acc3 += ((q15_t) x3 * c0); + + /* Reuse the present sample states for next sample */ + x0 = x1; + x1 = x2; + x2 = x3; + + /* Decrement the loop counter */ + i--; + } + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 4; + + /* The results in the 4 accumulators are in 2.62 format. Convert to 1.31 + ** Then store the 4 outputs in the destination buffer. */ + acc0 = __SSAT((acc0 >> 7U), 8); + *pDst++ = acc0; + acc1 = __SSAT((acc1 >> 7U), 8); + *pDst++ = acc1; + acc2 = __SSAT((acc2 >> 7U), 8); + *pDst++ = acc2; + acc3 = __SSAT((acc3 >> 7U), 8); + *pDst++ = acc3; + + /* Decrement the samples loop counter */ + blkCnt--; + } + + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 4U; + + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set the accumulator to zero */ + acc0 = 0; + + /* Initialize state pointer */ + px = pState; + + /* Initialize Coefficient pointer */ + pb = (pCoeffs); + + i = numTaps; + + /* Perform the multiply-accumulates */ + do + { + acc0 += (q15_t) * (px++) * (*(pb++)); + i--; + } while (i > 0U); + + /* The result is in 2.14 format. Convert to 1.7 + ** Then store the output in the destination buffer. */ + *pDst++ = __SSAT((acc0 >> 7U), 8); + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the samples loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + uint32_t numTaps = S->numTaps; /* Number of taps in the filter */ + uint32_t i, blkCnt; /* Loop counters */ + q7_t *pState = S->pState; /* State pointer */ + q7_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q7_t *px, *pb; /* Temporary pointers to state and coeff */ + q31_t acc = 0; /* Accumlator */ + q7_t *pStateCurnt; /* Points to the current sample of the state */ + + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = S->pState + (numTaps - 1U); + + /* Initialize blkCnt with blockSize */ + blkCnt = blockSize; + + /* Perform filtering upto BlockSize - BlockSize%4 */ + while (blkCnt > 0U) + { + /* Copy one sample at a time into state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Set accumulator to zero */ + acc = 0; + + /* Initialize state pointer of type q7 */ + px = pState; + + /* Initialize coeff pointer of type q7 */ + pb = pCoeffs; + + + i = numTaps; + + while (i > 0U) + { + /* acc = b[numTaps-1] * x[n-numTaps-1] + b[numTaps-2] * x[n-numTaps-2] + b[numTaps-3] * x[n-numTaps-3] +...+ b[0] * x[0] */ + acc += (q15_t) * px++ * *pb++; + i--; + } + + /* Store the 1.7 format filter output in destination buffer */ + *pDst++ = (q7_t) __SSAT((acc >> 7), 8); + + /* Advance the state pointer by 1 to process the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. + ** Now copy the last numTaps - 1 samples to the satrt of the state buffer. + ** This prepares the state buffer for the next function call. */ + + + /* Points to the start of the state buffer */ + pStateCurnt = S->pState; + + + /* Copy numTaps number of values */ + i = (numTaps - 1U); + + /* Copy q7_t data */ + while (i > 0U) + { + *pStateCurnt++ = *pState++; + i--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_f32.c new file mode 100644 index 0000000..fe9aacd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_f32.c @@ -0,0 +1,433 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_f32.c + * Description: Floating-point sparse FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup FIR_Sparse Finite Impulse Response (FIR) Sparse Filters + * + * This group of functions implements sparse FIR filters. + * Sparse FIR filters are equivalent to standard FIR filters except that most of the coefficients are equal to zero. + * Sparse filters are used for simulating reflections in communications and audio applications. + * + * There are separate functions for Q7, Q15, Q31, and floating-point data types. + * The functions operate on blocks of input and output data and each call to the function processes + * blockSize samples through the filter. pSrc and + * pDst points to input and output arrays respectively containing blockSize values. + * + * \par Algorithm: + * The sparse filter instant structure contains an array of tap indices pTapDelay which specifies the locations of the non-zero coefficients. + * This is in addition to the coefficient array b. + * The implementation essentially skips the multiplications by zero and leads to an efficient realization. + *
+ *     y[n] = b[0] * x[n-pTapDelay[0]] + b[1] * x[n-pTapDelay[1]] + b[2] * x[n-pTapDelay[2]] + ...+ b[numTaps-1] * x[n-pTapDelay[numTaps-1]]
+ * 
+ * \par + * \image html FIRSparse.gif "Sparse FIR filter. b[n] represents the filter coefficients" + * \par + * pCoeffs points to a coefficient array of size numTaps; + * pTapDelay points to an array of nonzero indices and is also of size numTaps; + * pState points to a state array of size maxDelay + blockSize, where + * maxDelay is the largest offset value that is ever used in the pTapDelay array. + * Some of the processing functions also require temporary working buffers. + * + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter. + * Coefficient and offset arrays may be shared among several instances while state variable arrays cannot be shared. + * There are separate instance structure declarations for each of the 4 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numTaps, pCoeffs, pTapDelay, maxDelay, stateIndex, pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * Set the values in the state buffer to zeros before static initialization. + * The code below statically initializes each of the 4 different data type filter instance structures + *
+ *arm_fir_sparse_instance_f32 S = {numTaps, 0, pState, pCoeffs, maxDelay, pTapDelay};
+ *arm_fir_sparse_instance_q31 S = {numTaps, 0, pState, pCoeffs, maxDelay, pTapDelay};
+ *arm_fir_sparse_instance_q15 S = {numTaps, 0, pState, pCoeffs, maxDelay, pTapDelay};
+ *arm_fir_sparse_instance_q7 S =  {numTaps, 0, pState, pCoeffs, maxDelay, pTapDelay};
+ * 
+ * \par + * + * \par Fixed-Point Behavior + * Care must be taken when using the fixed-point versions of the sparse FIR filter functions. + * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + +/** + * @addtogroup FIR_Sparse + * @{ + */ + +/** + * @brief Processing function for the floating-point sparse FIR filter. + * @param[in] *S points to an instance of the floating-point sparse FIR structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] *pScratchIn points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + * @return none. + */ + +void arm_fir_sparse_f32( + arm_fir_sparse_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + float32_t * pScratchIn, + uint32_t blockSize) +{ + + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *px; /* Scratch buffer pointer */ + float32_t *py = pState; /* Temporary pointers for state buffer */ + float32_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + float32_t *pOut; /* Destination pointer */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + float32_t coeff = *pCoeffs++; /* Read the first coefficient value */ + + + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_f32((int32_t *) py, delaySize, &S->stateIndex, 1, + (int32_t *) pSrc, 1, blockSize); + + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer */ + px = pb; + + /* Working pointer for destination buffer */ + pOut = pDst; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 Multiplications at a time. */ + blkCnt = blockSize >> 2U; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in destination buffer */ + *pOut++ = *px++ * coeff; + *pOut++ = *px++ * coeff; + *pOut++ = *px++ * coeff; + *pOut++ = *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in destination buffer */ + *pOut++ = *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer */ + px = pb; + + /* Working pointer for destination buffer */ + pOut = pDst; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pOut++ += *px++ * coeff; + *pOut++ += *px++ * coeff; + *pOut++ += *px++ * coeff; + *pOut++ += *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pOut++ += *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - + (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer */ + px = pb; + + /* Working pointer for destination buffer */ + pOut = pDst; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pOut++ += *px++ * coeff; + *pOut++ += *px++ * coeff; + *pOut++ += *px++ * coeff; + *pOut++ += *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pOut++ += *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + +/* Run the below code for Cortex-M0 */ + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in destination buffer */ + *pOut++ = *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer */ + px = pb; + + /* Working pointer for destination buffer */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pOut++ += *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = + ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer */ + px = pb; + + /* Working pointer for destination buffer */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pOut++ += *px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_f32.c new file mode 100644 index 0000000..191f8bb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_f32.c @@ -0,0 +1,95 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_init_f32.c + * Description: Floating-point sparse FIR filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Sparse + * @{ + */ + +/** + * @brief Initialization function for the floating-point sparse FIR filter. + * @param[in,out] *S points to an instance of the floating-point sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] *pCoeffs points to the array of filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] *pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + * @return none + * + * Description: + * \par + * pCoeffs holds the filter coefficients and has length numTaps. + * pState holds the filter's state variables and must be of length + * maxDelay + blockSize, where maxDelay + * is the maximum number of delay line values. + * blockSize is the + * number of samples processed by the arm_fir_sparse_f32() function. + */ + +void arm_fir_sparse_init_f32( + arm_fir_sparse_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Assign TapDelay pointer */ + S->pTapDelay = pTapDelay; + + /* Assign MaxDelay */ + S->maxDelay = maxDelay; + + /* reset the stateIndex to 0 */ + S->stateIndex = 0U; + + /* Clear state buffer and size is always maxDelay + blockSize */ + memset(pState, 0, (maxDelay + blockSize) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q15.c new file mode 100644 index 0000000..297c5fa --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q15.c @@ -0,0 +1,95 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_init_q15.c + * Description: Q15 sparse FIR filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Sparse + * @{ + */ + +/** + * @brief Initialization function for the Q15 sparse FIR filter. + * @param[in,out] *S points to an instance of the Q15 sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] *pCoeffs points to the array of filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] *pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + * @return none + * + * Description: + * \par + * pCoeffs holds the filter coefficients and has length numTaps. + * pState holds the filter's state variables and must be of length + * maxDelay + blockSize, where maxDelay + * is the maximum number of delay line values. + * blockSize is the + * number of words processed by arm_fir_sparse_q15() function. + */ + +void arm_fir_sparse_init_q15( + arm_fir_sparse_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Assign TapDelay pointer */ + S->pTapDelay = pTapDelay; + + /* Assign MaxDelay */ + S->maxDelay = maxDelay; + + /* reset the stateIndex to 0 */ + S->stateIndex = 0U; + + /* Clear state buffer and size is always maxDelay + blockSize */ + memset(pState, 0, (maxDelay + blockSize) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q31.c new file mode 100644 index 0000000..3eb8d47 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q31.c @@ -0,0 +1,94 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_init_q31.c + * Description: Q31 sparse FIR filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Sparse + * @{ + */ + +/** + * @brief Initialization function for the Q31 sparse FIR filter. + * @param[in,out] *S points to an instance of the Q31 sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] *pCoeffs points to the array of filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] *pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + * @return none + * + * Description: + * \par + * pCoeffs holds the filter coefficients and has length numTaps. + * pState holds the filter's state variables and must be of length + * maxDelay + blockSize, where maxDelay + * is the maximum number of delay line values. + * blockSize is the number of words processed by arm_fir_sparse_q31() function. + */ + +void arm_fir_sparse_init_q31( + arm_fir_sparse_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Assign TapDelay pointer */ + S->pTapDelay = pTapDelay; + + /* Assign MaxDelay */ + S->maxDelay = maxDelay; + + /* reset the stateIndex to 0 */ + S->stateIndex = 0U; + + /* Clear state buffer and size is always maxDelay + blockSize */ + memset(pState, 0, (maxDelay + blockSize) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q7.c new file mode 100644 index 0000000..c2cb7b0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_init_q7.c @@ -0,0 +1,95 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_init_q7.c + * Description: Q7 sparse FIR filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Sparse + * @{ + */ + +/** + * @brief Initialization function for the Q7 sparse FIR filter. + * @param[in,out] *S points to an instance of the Q7 sparse FIR structure. + * @param[in] numTaps number of nonzero coefficients in the filter. + * @param[in] *pCoeffs points to the array of filter coefficients. + * @param[in] *pState points to the state buffer. + * @param[in] *pTapDelay points to the array of offset times. + * @param[in] maxDelay maximum offset time supported. + * @param[in] blockSize number of samples that will be processed per block. + * @return none + * + * Description: + * \par + * pCoeffs holds the filter coefficients and has length numTaps. + * pState holds the filter's state variables and must be of length + * maxDelay + blockSize, where maxDelay + * is the maximum number of delay line values. + * blockSize is the + * number of samples processed by the arm_fir_sparse_q7() function. + */ + +void arm_fir_sparse_init_q7( + arm_fir_sparse_instance_q7 * S, + uint16_t numTaps, + q7_t * pCoeffs, + q7_t * pState, + int32_t * pTapDelay, + uint16_t maxDelay, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Assign TapDelay pointer */ + S->pTapDelay = pTapDelay; + + /* Assign MaxDelay */ + S->maxDelay = maxDelay; + + /* reset the stateIndex to 0 */ + S->stateIndex = 0U; + + /* Clear state buffer and size is always maxDelay + blockSize */ + memset(pState, 0, (maxDelay + blockSize) * sizeof(q7_t)); + + /* Assign state pointer */ + S->pState = pState; + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q15.c new file mode 100644 index 0000000..663b6e0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q15.c @@ -0,0 +1,470 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_q15.c + * Description: Q15 sparse FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @addtogroup FIR_Sparse + * @{ + */ + +/** + * @brief Processing function for the Q15 sparse FIR filter. + * @param[in] *S points to an instance of the Q15 sparse FIR structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] *pScratchIn points to a temporary buffer of size blockSize. + * @param[in] *pScratchOut points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 32-bit accumulator. + * The 1.15 x 1.15 multiplications yield a 2.30 result and these are added to a 2.30 accumulator. + * Thus the full precision of the multiplications is maintained but there is only a single guard bit in the accumulator. + * If the accumulator result overflows it will wrap around rather than saturate. + * After all multiply-accumulates are performed, the 2.30 accumulator is truncated to 2.15 format and then saturated to 1.15 format. + * In order to avoid overflows the input signal or coefficients must be scaled down by log2(numTaps) bits. + */ + + +void arm_fir_sparse_q15( + arm_fir_sparse_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + q15_t * pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize) +{ + + q15_t *pState = S->pState; /* State pointer */ + q15_t *pIn = pSrc; /* Working pointer for input */ + q15_t *pOut = pDst; /* Working pointer for output */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *px; /* Temporary pointers for scratch buffer */ + q15_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + q15_t *py = pState; /* Temporary pointers for state buffer */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Filter order */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + q15_t coeff = *pCoeffs++; /* Read the first coefficient value */ + q31_t *pScr2 = pScratchOut; /* Working pointer for pScratchOut */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in1, in2; /* Temporary variables */ + + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_q15(py, delaySize, &S->stateIndex, 1, pIn, 1, blockSize); + + /* Loop over the number of taps. */ + tapCnt = numTaps; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 multiplications at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + *pScratchOut++ = ((q31_t) * px++ * coeff); + *pScratchOut++ = ((q31_t) * px++ * coeff); + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pScratchOut++ += (q31_t) * px++ * coeff; + *pScratchOut++ += (q31_t) * px++ * coeff; + *pScratchOut++ += (q31_t) * px++ * coeff; + *pScratchOut++ += (q31_t) * px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pScratchOut++ += (q31_t) * px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pScratchOut++ += (q31_t) * px++ * coeff; + *pScratchOut++ += (q31_t) * px++ * coeff; + *pScratchOut++ += (q31_t) * px++ * coeff; + *pScratchOut++ += (q31_t) * px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pScratchOut++ += (q31_t) * px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* All the output values are in pScratchOut buffer. + Convert them into 1.15 format, saturate and store in the destination buffer. */ + /* Loop over the blockSize. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + in1 = *pScr2++; + in2 = *pScr2++; + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT((q15_t) __SSAT(in1 >> 15, 16), (q15_t) __SSAT(in2 >> 15, 16), + 16); + +#else + *__SIMD32(pOut)++ = + __PKHBT((q15_t) __SSAT(in2 >> 15, 16), (q15_t) __SSAT(in1 >> 15, 16), + 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + in1 = *pScr2++; + + in2 = *pScr2++; + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pOut)++ = + __PKHBT((q15_t) __SSAT(in1 >> 15, 16), (q15_t) __SSAT(in2 >> 15, 16), + 16); + +#else + + *__SIMD32(pOut)++ = + __PKHBT((q15_t) __SSAT(in2 >> 15, 16), (q15_t) __SSAT(in1 >> 15, 16), + 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + + blkCnt--; + + } + + /* If the blockSize is not a multiple of 4, + remaining samples are processed in the below loop */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + *pOut++ = (q15_t) __SSAT(*pScr2++ >> 15, 16); + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_q15(py, delaySize, &S->stateIndex, 1, pIn, 1, blockSize); + + /* Loop over the number of taps. */ + tapCnt = numTaps; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pScratchOut++ += (q31_t) * px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q15(py, delaySize, &readIndex, 1, + pb, pb, blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + *pScratchOut++ += (q31_t) * px++ * coeff; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* All the output values are in pScratchOut buffer. + Convert them into 1.15 format, saturate and store in the destination buffer. */ + /* Loop over the blockSize. */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + *pOut++ = (q15_t) __SSAT(*pScr2++ >> 15, 16); + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q31.c new file mode 100644 index 0000000..3fd3da0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q31.c @@ -0,0 +1,450 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_q31.c + * Description: Q31 sparse FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + + +/** + * @addtogroup FIR_Sparse + * @{ + */ + +/** + * @brief Processing function for the Q31 sparse FIR filter. + * @param[in] *S points to an instance of the Q31 sparse FIR structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] *pScratchIn points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 32-bit accumulator. + * The 1.31 x 1.31 multiplications are truncated to 2.30 format. + * This leads to loss of precision on the intermediate multiplications and provides only a single guard bit. + * If the accumulator result overflows, it wraps around rather than saturate. + * In order to avoid overflows the input signal or coefficients must be scaled down by log2(numTaps) bits. + */ + +void arm_fir_sparse_q31( + arm_fir_sparse_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + q31_t * pScratchIn, + uint32_t blockSize) +{ + + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *px; /* Scratch buffer pointer */ + q31_t *py = pState; /* Temporary pointers for state buffer */ + q31_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + q31_t *pOut; /* Destination pointer */ + q63_t out; /* Temporary output variable */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Filter order */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + q31_t coeff = *pCoeffs++; /* Read the first coefficient value */ + q31_t in; + + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_f32((int32_t *) py, delaySize, &S->stateIndex, 1, + (int32_t *) pSrc, 1, blockSize); + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (int32_t) (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pOut = pDst; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 Multiplications at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in the destination buffer */ + *pOut++ = (q31_t) (((q63_t) * px++ * coeff) >> 32); + *pOut++ = (q31_t) (((q63_t) * px++ * coeff) >> 32); + *pOut++ = (q31_t) (((q63_t) * px++ * coeff) >> 32); + *pOut++ = (q31_t) (((q63_t) * px++ * coeff) >> 32); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in the destination buffer */ + *pOut++ = (q31_t) (((q63_t) * px++ * coeff) >> 32); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (int32_t) (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pOut = pDst; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (int32_t) (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pOut = pDst; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Working output pointer is updated */ + pOut = pDst; + + /* Output is converted into 1.31 format. */ + /* Loop over the blockSize. Unroll by a factor of 4. + * process 4 output samples at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + in = *pOut << 1; + *pOut++ = in; + in = *pOut << 1; + *pOut++ = in; + in = *pOut << 1; + *pOut++ = in; + in = *pOut << 1; + *pOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * process the remaining output samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + in = *pOut << 1; + *pOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiplications and store in the destination buffer */ + *pOut++ = (q31_t) (((q63_t) * px++ * coeff) >> 32); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (int32_t) (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = (int32_t) (S->stateIndex - blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_f32((int32_t *) py, delaySize, &readIndex, 1, + (int32_t *) pb, (int32_t *) pb, blockSize, 1, + blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pOut = pDst; + + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + out = *pOut; + out += ((q63_t) * px++ * coeff) >> 32; + *pOut++ = (q31_t) (out); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Working output pointer is updated */ + pOut = pDst; + + /* Output is converted into 1.31 format. */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + in = *pOut << 1; + *pOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q7.c new file mode 100644 index 0000000..252ba95 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_fir_sparse_q7.c @@ -0,0 +1,469 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fir_sparse_q7.c + * Description: Q7 sparse FIR filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup FIR_Sparse + * @{ + */ + + +/** + * @brief Processing function for the Q7 sparse FIR filter. + * @param[in] *S points to an instance of the Q7 sparse FIR structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data + * @param[in] *pScratchIn points to a temporary buffer of size blockSize. + * @param[in] *pScratchOut points to a temporary buffer of size blockSize. + * @param[in] blockSize number of input samples to process per call. + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 32-bit internal accumulator. + * Both coefficients and state variables are represented in 1.7 format and multiplications yield a 2.14 result. + * The 2.14 intermediate results are accumulated in a 32-bit accumulator in 18.14 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * The accumulator is then converted to 18.7 format by discarding the low 7 bits. + * Finally, the result is truncated to 1.7 format. + */ + +void arm_fir_sparse_q7( + arm_fir_sparse_instance_q7 * S, + q7_t * pSrc, + q7_t * pDst, + q7_t * pScratchIn, + q31_t * pScratchOut, + uint32_t blockSize) +{ + + q7_t *pState = S->pState; /* State pointer */ + q7_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q7_t *px; /* Scratch buffer pointer */ + q7_t *py = pState; /* Temporary pointers for state buffer */ + q7_t *pb = pScratchIn; /* Temporary pointers for scratch buffer */ + q7_t *pOut = pDst; /* Destination pointer */ + int32_t *pTapDelay = S->pTapDelay; /* Pointer to the array containing offset of the non-zero tap values. */ + uint32_t delaySize = S->maxDelay + blockSize; /* state length */ + uint16_t numTaps = S->numTaps; /* Filter order */ + int32_t readIndex; /* Read index of the state buffer */ + uint32_t tapCnt, blkCnt; /* loop counters */ + q7_t coeff = *pCoeffs++; /* Read the coefficient value */ + q31_t *pScr2 = pScratchOut; /* Working pointer for scratch buffer of output values */ + q31_t in; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q7_t in1, in2, in3, in4; + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_q7(py, (int32_t) delaySize, &S->stateIndex, 1, pSrc, 1, + blockSize); + + /* Loop over the number of taps. */ + tapCnt = numTaps; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 multiplications at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + *pScratchOut++ = ((q31_t) * px++ * coeff); + *pScratchOut++ = ((q31_t) * px++ * coeff); + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - + (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize. Unroll by a factor of 4. + * Compute 4 MACS at a time. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + * compute the remaining samples */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* All the output values are in pScratchOut buffer. + Convert them into 1.15 format, saturate and store in the destination buffer. */ + /* Loop over the blockSize. */ + blkCnt = blockSize >> 2; + + while (blkCnt > 0U) + { + in1 = (q7_t) __SSAT(*pScr2++ >> 7, 8); + in2 = (q7_t) __SSAT(*pScr2++ >> 7, 8); + in3 = (q7_t) __SSAT(*pScr2++ >> 7, 8); + in4 = (q7_t) __SSAT(*pScr2++ >> 7, 8); + + *__SIMD32(pOut)++ = __PACKq7(in1, in2, in3, in4); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, + remaining samples are processed in the below loop */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + *pOut++ = (q7_t) __SSAT(*pScr2++ >> 7, 8); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* BlockSize of Input samples are copied into the state buffer */ + /* StateIndex points to the starting position to write in the state buffer */ + arm_circularWrite_q7(py, (int32_t) delaySize, &S->stateIndex, 1, pSrc, 1, + blockSize); + + /* Loop over the number of taps. */ + tapCnt = numTaps; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform multiplication and store in the scratch buffer */ + *pScratchOut++ = ((q31_t) * px++ * coeff); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Loop over the number of taps. */ + tapCnt = (uint32_t) numTaps - 2U; + + while (tapCnt > 0U) + { + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Load the coefficient value and + * increment the coefficient buffer for the next set of state values */ + coeff = *pCoeffs++; + + /* Read Index, from where the state buffer should be read, is calculated. */ + readIndex = + ((int32_t) S->stateIndex - (int32_t) blockSize) - *pTapDelay++; + + /* Wraparound of readIndex */ + if (readIndex < 0) + { + readIndex += (int32_t) delaySize; + } + + /* Decrement the tap loop counter */ + tapCnt--; + } + + /* Compute last tap without the final read of pTapDelay */ + + /* Working pointer for state buffer is updated */ + py = pState; + + /* blockSize samples are read from the state buffer */ + arm_circularRead_q7(py, (int32_t) delaySize, &readIndex, 1, pb, pb, + (int32_t) blockSize, 1, blockSize); + + /* Working pointer for the scratch buffer of state values */ + px = pb; + + /* Working pointer for scratch buffer of output values */ + pScratchOut = pScr2; + + /* Loop over the blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Perform Multiply-Accumulate */ + in = *pScratchOut + ((q31_t) * px++ * coeff); + *pScratchOut++ = in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* All the output values are in pScratchOut buffer. + Convert them into 1.15 format, saturate and store in the destination buffer. */ + /* Loop over the blockSize. */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + *pOut++ = (q7_t) __SSAT(*pScr2++ >> 7, 8); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of FIR_Sparse group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_f32.c new file mode 100644 index 0000000..7cccd4a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_f32.c @@ -0,0 +1,435 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_iir_lattice_f32.c + * Description: Floating-point IIR Lattice filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup IIR_Lattice Infinite Impulse Response (IIR) Lattice Filters + * + * This set of functions implements lattice filters + * for Q15, Q31 and floating-point data types. Lattice filters are used in a + * variety of adaptive filter applications. The filter structure has feedforward and + * feedback components and the net impulse response is infinite length. + * The functions operate on blocks + * of input and output data and each call to the function processes + * blockSize samples through the filter. pSrc and + * pDst point to input and output arrays containing blockSize values. + + * \par Algorithm: + * \image html IIRLattice.gif "Infinite Impulse Response Lattice filter" + *
+ *    fN(n)   =  x(n)
+ *    fm-1(n) = fm(n) - km * gm-1(n-1)   for m = N, N-1, ...1
+ *    gm(n)   = km * fm-1(n) + gm-1(n-1) for m = N, N-1, ...1
+ *    y(n)    = vN * gN(n) + vN-1 * gN-1(n) + ...+ v0 * g0(n)
+ * 
+ * \par + * pkCoeffs points to array of reflection coefficients of size numStages. + * Reflection coefficients are stored in time-reversed order. + * \par + *
+ *    {kN, kN-1, ....k1}
+ * 
+ * pvCoeffs points to the array of ladder coefficients of size (numStages+1). + * Ladder coefficients are stored in time-reversed order. + * \par + *
+ *    {vN, vN-1, ...v0}
+ * 
+ * pState points to a state array of size numStages + blockSize. + * The state variables shown in the figure above (the g values) are stored in the pState array. + * The state variables are updated after each block of data is processed; the coefficients are untouched. + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter. + * Coefficient arrays may be shared among several instances while state variable arrays cannot be shared. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numStages, pkCoeffs, pvCoeffs, pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * Set the values in the state buffer to zeros and then manually initialize the instance structure as follows: + *
+ *arm_iir_lattice_instance_f32 S = {numStages, pState, pkCoeffs, pvCoeffs};
+ *arm_iir_lattice_instance_q31 S = {numStages, pState, pkCoeffs, pvCoeffs};
+ *arm_iir_lattice_instance_q15 S = {numStages, pState, pkCoeffs, pvCoeffs};
+ * 
+ * \par + * where numStages is the number of stages in the filter; pState points to the state buffer array; + * pkCoeffs points to array of the reflection coefficients; pvCoeffs points to the array of ladder coefficients. + * \par Fixed-Point Behavior + * Care must be taken when using the fixed-point versions of the IIR lattice filter functions. + * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + +/** + * @addtogroup IIR_Lattice + * @{ + */ + +/** + * @brief Processing function for the floating-point IIR lattice filter. + * @param[in] *S points to an instance of the floating-point IIR lattice structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + * @return none. + */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + +void arm_iir_lattice_f32( + const arm_iir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t fnext1, gcurr1, gnext; /* Temporary variables for lattice stages */ + float32_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* temporary variables for counts */ + float32_t *px1, *px2, *pk, *pv; /* temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + float32_t *pState; /* State pointer */ + float32_t *pStateCurnt; /* State current pointer */ + float32_t k1, k2; + float32_t v1, v2, v3, v4; + float32_t gcurr2; + float32_t fnext2; + + /* initialise loop count */ + blkCnt = blockSize; + + /* initialise state pointer */ + pState = &S->pState[0]; + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fnext2 = *pSrc++; + + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + + /* Set accumulator to zero */ + acc = 0.0; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = (numStages) >> 2; + + while (tapCnt > 0U) + { + /* Read gN-1(n-1) from state buffer */ + gcurr1 = *px1; + + /* read reflection coefficient kN */ + k1 = *pk; + + /* fN-1(n) = fN(n) - kN * gN-1(n-1) */ + fnext1 = fnext2 - (k1 * gcurr1); + + /* read ladder coefficient vN */ + v1 = *pv; + + /* read next reflection coefficient kN-1 */ + k2 = *(pk + 1U); + + /* Read gN-2(n-1) from state buffer */ + gcurr2 = *(px1 + 1U); + + /* read next ladder coefficient vN-1 */ + v2 = *(pv + 1U); + + /* fN-2(n) = fN-1(n) - kN-1 * gN-2(n-1) */ + fnext2 = fnext1 - (k2 * gcurr2); + + /* gN(n) = kN * fN-1(n) + gN-1(n-1) */ + gnext = gcurr1 + (k1 * fnext1); + + /* read reflection coefficient kN-2 */ + k1 = *(pk + 2U); + + /* write gN(n) into state for next sample processing */ + *px2++ = gnext; + + /* Read gN-3(n-1) from state buffer */ + gcurr1 = *(px1 + 2U); + + /* y(n) += gN(n) * vN */ + acc += (gnext * v1); + + /* fN-3(n) = fN-2(n) - kN-2 * gN-3(n-1) */ + fnext1 = fnext2 - (k1 * gcurr1); + + /* gN-1(n) = kN-1 * fN-2(n) + gN-2(n-1) */ + gnext = gcurr2 + (k2 * fnext2); + + /* Read gN-4(n-1) from state buffer */ + gcurr2 = *(px1 + 3U); + + /* y(n) += gN-1(n) * vN-1 */ + acc += (gnext * v2); + + /* read reflection coefficient kN-3 */ + k2 = *(pk + 3U); + + /* write gN-1(n) into state for next sample processing */ + *px2++ = gnext; + + /* fN-4(n) = fN-3(n) - kN-3 * gN-4(n-1) */ + fnext2 = fnext1 - (k2 * gcurr2); + + /* gN-2(n) = kN-2 * fN-3(n) + gN-3(n-1) */ + gnext = gcurr1 + (k1 * fnext1); + + /* read ladder coefficient vN-2 */ + v3 = *(pv + 2U); + + /* y(n) += gN-2(n) * vN-2 */ + acc += (gnext * v3); + + /* write gN-2(n) into state for next sample processing */ + *px2++ = gnext; + + /* update pointer */ + pk += 4U; + + /* gN-3(n) = kN-3 * fN-4(n) + gN-4(n-1) */ + gnext = (fnext2 * k2) + gcurr2; + + /* read next ladder coefficient vN-3 */ + v4 = *(pv + 3U); + + /* y(n) += gN-4(n) * vN-4 */ + acc += (gnext * v4); + + /* write gN-3(n) into state for next sample processing */ + *px2++ = gnext; + + /* update pointers */ + px1 += 4U; + pv += 4U; + + tapCnt--; + + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = (numStages) % 0x4U; + + while (tapCnt > 0U) + { + gcurr1 = *px1++; + /* Process sample for last taps */ + fnext1 = fnext2 - ((*pk) * gcurr1); + gnext = (fnext1 * (*pk++)) + gcurr1; + /* Output samples for last taps */ + acc += (gnext * (*pv++)); + *px2++ = gnext; + fnext2 = fnext1; + + tapCnt--; + + } + + /* y(n) += g0(n) * v0 */ + acc += (fnext2 * (*pv)); + + *px2++ = fnext2; + + /* write out into pDst */ + *pDst++ = acc; + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 1U; + + blkCnt--; + + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + tapCnt = numStages >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + + } + + /* Calculate remaining number of copies */ + tapCnt = (numStages) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } +} + +#else + +void arm_iir_lattice_f32( + const arm_iir_lattice_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + float32_t fcurr, fnext = 0, gcurr, gnext; /* Temporary variables for lattice stages */ + float32_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* temporary variables for counts */ + float32_t *px1, *px2, *pk, *pv; /* temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + float32_t *pState; /* State pointer */ + float32_t *pStateCurnt; /* State current pointer */ + + + /* Run the below code for Cortex-M0 */ + + blkCnt = blockSize; + + pState = &S->pState[0]; + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0.0f; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + + /* Process sample for numStages */ + tapCnt = numStages; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample for last taps */ + fnext = fcurr - ((*pk) * gcurr); + gnext = (fnext * (*pk++)) + gcurr; + + /* Output samples for last taps */ + acc += (gnext * (*pv++)); + *px2++ = gnext; + fcurr = fnext; + + /* Decrementing loop counter */ + tapCnt--; + + } + + /* y(n) += g0(n) * v0 */ + acc += (fnext * (*pv)); + + *px2++ = fnext; + + /* write out into pDst */ + *pDst++ = acc; + + /* Advance the state pointer by 1 to process the next group of samples */ + pState = pState + 1U; + blkCnt--; + + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + tapCnt = numStages; + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +} + +#endif /* #if defined (ARM_MATH_DSP) */ + + +/** + * @} end of IIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_f32.c new file mode 100644 index 0000000..f20a21b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_f32.c @@ -0,0 +1,79 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_iir_lattice_init_f32.c + * Description: Floating-point IIR lattice filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup IIR_Lattice + * @{ + */ + +/** + * @brief Initialization function for the floating-point IIR lattice filter. + * @param[in] *S points to an instance of the floating-point IIR lattice structure. + * @param[in] numStages number of stages in the filter. + * @param[in] *pkCoeffs points to the reflection coefficient buffer. The array is of length numStages. + * @param[in] *pvCoeffs points to the ladder coefficient buffer. The array is of length numStages+1. + * @param[in] *pState points to the state buffer. The array is of length numStages+blockSize. + * @param[in] blockSize number of samples to process. + * @return none. + */ + +void arm_iir_lattice_init_f32( + arm_iir_lattice_instance_f32 * S, + uint16_t numStages, + float32_t * pkCoeffs, + float32_t * pvCoeffs, + float32_t * pState, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numStages = numStages; + + /* Assign reflection coefficient pointer */ + S->pkCoeffs = pkCoeffs; + + /* Assign ladder coefficient pointer */ + S->pvCoeffs = pvCoeffs; + + /* Clear state buffer and size is always blockSize + numStages */ + memset(pState, 0, (numStages + blockSize) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + + +} + + /** + * @} end of IIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q15.c new file mode 100644 index 0000000..6cae944 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q15.c @@ -0,0 +1,79 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_iir_lattice_init_q15.c + * Description: Q15 IIR lattice filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup IIR_Lattice + * @{ + */ + + /** + * @brief Initialization function for the Q15 IIR lattice filter. + * @param[in] *S points to an instance of the Q15 IIR lattice structure. + * @param[in] numStages number of stages in the filter. + * @param[in] *pkCoeffs points to reflection coefficient buffer. The array is of length numStages. + * @param[in] *pvCoeffs points to ladder coefficient buffer. The array is of length numStages+1. + * @param[in] *pState points to state buffer. The array is of length numStages+blockSize. + * @param[in] blockSize number of samples to process per call. + * @return none. + */ + +void arm_iir_lattice_init_q15( + arm_iir_lattice_instance_q15 * S, + uint16_t numStages, + q15_t * pkCoeffs, + q15_t * pvCoeffs, + q15_t * pState, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numStages = numStages; + + /* Assign reflection coefficient pointer */ + S->pkCoeffs = pkCoeffs; + + /* Assign ladder coefficient pointer */ + S->pvCoeffs = pvCoeffs; + + /* Clear state buffer and size is always blockSize + numStages */ + memset(pState, 0, (numStages + blockSize) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + + +} + +/** + * @} end of IIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q31.c new file mode 100644 index 0000000..fe9869e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_init_q31.c @@ -0,0 +1,79 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_iir_lattice_init_q31.c + * Description: Initialization function for the Q31 IIR lattice filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup IIR_Lattice + * @{ + */ + + /** + * @brief Initialization function for the Q31 IIR lattice filter. + * @param[in] *S points to an instance of the Q31 IIR lattice structure. + * @param[in] numStages number of stages in the filter. + * @param[in] *pkCoeffs points to the reflection coefficient buffer. The array is of length numStages. + * @param[in] *pvCoeffs points to the ladder coefficient buffer. The array is of length numStages+1. + * @param[in] *pState points to the state buffer. The array is of length numStages+blockSize. + * @param[in] blockSize number of samples to process. + * @return none. + */ + +void arm_iir_lattice_init_q31( + arm_iir_lattice_instance_q31 * S, + uint16_t numStages, + q31_t * pkCoeffs, + q31_t * pvCoeffs, + q31_t * pState, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numStages = numStages; + + /* Assign reflection coefficient pointer */ + S->pkCoeffs = pkCoeffs; + + /* Assign ladder coefficient pointer */ + S->pvCoeffs = pvCoeffs; + + /* Clear state buffer and size is always blockSize + numStages */ + memset(pState, 0, (numStages + blockSize) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; + + +} + +/** + * @} end of IIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q15.c new file mode 100644 index 0000000..9c70b68 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q15.c @@ -0,0 +1,452 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_iir_lattice_q15.c + * Description: Q15 IIR lattice filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup IIR_Lattice + * @{ + */ + +/** + * @brief Processing function for the Q15 IIR lattice filter. + * @param[in] *S points to an instance of the Q15 IIR lattice structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 64-bit internal accumulator. + * Both coefficients and state variables are represented in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * After all additions have been performed, the accumulator is truncated to 34.15 format by discarding low 15 bits. + * Lastly, the accumulator is saturated to yield a result in 1.15 format. + */ + +void arm_iir_lattice_q15( + const arm_iir_lattice_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t fcurr, fnext, gcurr = 0, gnext; /* Temporary variables for lattice stages */ + q15_t gnext1, gnext2; /* Temporary variables for lattice stages */ + uint32_t stgCnt; /* Temporary variables for counts */ + q63_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* Temporary variables for counts */ + q15_t *px1, *px2, *pk, *pv; /* temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + q15_t *pState; /* State pointer */ + q15_t *pStateCurnt; /* State current pointer */ + q15_t out; /* Temporary variable for output */ + q31_t v; /* Temporary variable for ladder coefficient */ +#ifdef UNALIGNED_SUPPORT_DISABLE + q15_t v1, v2; +#endif + + + blkCnt = blockSize; + + pState = &S->pState[0]; + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + + /* Process sample for first tap */ + gcurr = *px1++; + /* fN-1(n) = fN(n) - kN * gN-1(n-1) */ + fnext = fcurr - (((q31_t) gcurr * (*pk)) >> 15); + fnext = __SSAT(fnext, 16); + /* gN(n) = kN * fN-1(n) + gN-1(n-1) */ + gnext = (((q31_t) fnext * (*pk++)) >> 15) + gcurr; + gnext = __SSAT(gnext, 16); + /* write gN(n) into state for next sample processing */ + *px2++ = (q15_t) gnext; + /* y(n) += gN(n) * vN */ + acc += (q31_t) ((gnext * (*pv++))); + + + /* Update f values for next coefficient processing */ + fcurr = fnext; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = (numStages - 1U) >> 2; + + while (tapCnt > 0U) + { + + /* Process sample for 2nd, 6th ...taps */ + /* Read gN-2(n-1) from state buffer */ + gcurr = *px1++; + /* Process sample for 2nd, 6th .. taps */ + /* fN-2(n) = fN-1(n) - kN-1 * gN-2(n-1) */ + fnext = fcurr - (((q31_t) gcurr * (*pk)) >> 15); + fnext = __SSAT(fnext, 16); + /* gN-1(n) = kN-1 * fN-2(n) + gN-2(n-1) */ + gnext = (((q31_t) fnext * (*pk++)) >> 15) + gcurr; + gnext1 = (q15_t) __SSAT(gnext, 16); + /* write gN-1(n) into state */ + *px2++ = (q15_t) gnext1; + + + /* Process sample for 3nd, 7th ...taps */ + /* Read gN-3(n-1) from state */ + gcurr = *px1++; + /* Process sample for 3rd, 7th .. taps */ + /* fN-3(n) = fN-2(n) - kN-2 * gN-3(n-1) */ + fcurr = fnext - (((q31_t) gcurr * (*pk)) >> 15); + fcurr = __SSAT(fcurr, 16); + /* gN-2(n) = kN-2 * fN-3(n) + gN-3(n-1) */ + gnext = (((q31_t) fcurr * (*pk++)) >> 15) + gcurr; + gnext2 = (q15_t) __SSAT(gnext, 16); + /* write gN-2(n) into state */ + *px2++ = (q15_t) gnext2; + + /* Read vN-1 and vN-2 at a time */ +#ifndef UNALIGNED_SUPPORT_DISABLE + + v = *__SIMD32(pv)++; + +#else + + v1 = *pv++; + v2 = *pv++; + +#ifndef ARM_MATH_BIG_ENDIAN + + v = __PKHBT(v1, v2, 16); + +#else + + v = __PKHBT(v2, v1, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + + /* Pack gN-1(n) and gN-2(n) */ + +#ifndef ARM_MATH_BIG_ENDIAN + + gnext = __PKHBT(gnext1, gnext2, 16); + +#else + + gnext = __PKHBT(gnext2, gnext1, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* y(n) += gN-1(n) * vN-1 */ + /* process for gN-5(n) * vN-5, gN-9(n) * vN-9 ... */ + /* y(n) += gN-2(n) * vN-2 */ + /* process for gN-6(n) * vN-6, gN-10(n) * vN-10 ... */ + acc = __SMLALD(gnext, v, acc); + + + /* Process sample for 4th, 8th ...taps */ + /* Read gN-4(n-1) from state */ + gcurr = *px1++; + /* Process sample for 4th, 8th .. taps */ + /* fN-4(n) = fN-3(n) - kN-3 * gN-4(n-1) */ + fnext = fcurr - (((q31_t) gcurr * (*pk)) >> 15); + fnext = __SSAT(fnext, 16); + /* gN-3(n) = kN-3 * fN-1(n) + gN-1(n-1) */ + gnext = (((q31_t) fnext * (*pk++)) >> 15) + gcurr; + gnext1 = (q15_t) __SSAT(gnext, 16); + /* write gN-3(n) for the next sample process */ + *px2++ = (q15_t) gnext1; + + + /* Process sample for 5th, 9th ...taps */ + /* Read gN-5(n-1) from state */ + gcurr = *px1++; + /* Process sample for 5th, 9th .. taps */ + /* fN-5(n) = fN-4(n) - kN-4 * gN-5(n-1) */ + fcurr = fnext - (((q31_t) gcurr * (*pk)) >> 15); + fcurr = __SSAT(fcurr, 16); + /* gN-4(n) = kN-4 * fN-5(n) + gN-5(n-1) */ + gnext = (((q31_t) fcurr * (*pk++)) >> 15) + gcurr; + gnext2 = (q15_t) __SSAT(gnext, 16); + /* write gN-4(n) for the next sample process */ + *px2++ = (q15_t) gnext2; + + /* Read vN-3 and vN-4 at a time */ +#ifndef UNALIGNED_SUPPORT_DISABLE + + v = *__SIMD32(pv)++; + +#else + + v1 = *pv++; + v2 = *pv++; + +#ifndef ARM_MATH_BIG_ENDIAN + + v = __PKHBT(v1, v2, 16); + +#else + + v = __PKHBT(v2, v1, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + + /* Pack gN-3(n) and gN-4(n) */ +#ifndef ARM_MATH_BIG_ENDIAN + + gnext = __PKHBT(gnext1, gnext2, 16); + +#else + + gnext = __PKHBT(gnext2, gnext1, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* y(n) += gN-4(n) * vN-4 */ + /* process for gN-8(n) * vN-8, gN-12(n) * vN-12 ... */ + /* y(n) += gN-3(n) * vN-3 */ + /* process for gN-7(n) * vN-7, gN-11(n) * vN-11 ... */ + acc = __SMLALD(gnext, v, acc); + + tapCnt--; + + } + + fnext = fcurr; + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = (numStages - 1U) % 0x4U; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample for last taps */ + fnext = fcurr - (((q31_t) gcurr * (*pk)) >> 15); + fnext = __SSAT(fnext, 16); + gnext = (((q31_t) fnext * (*pk++)) >> 15) + gcurr; + gnext = __SSAT(gnext, 16); + /* Output samples for last taps */ + acc += (q31_t) (((q31_t) gnext * (*pv++))); + *px2++ = (q15_t) gnext; + fcurr = fnext; + + tapCnt--; + } + + /* y(n) += g0(n) * v0 */ + acc += (q31_t) (((q31_t) fnext * (*pv++))); + + out = (q15_t) __SSAT(acc >> 15, 16); + *px2++ = (q15_t) fnext; + + /* write out into pDst */ + *pDst++ = out; + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 1U; + blkCnt--; + + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + stgCnt = (numStages >> 2U); + + /* copy data */ + while (stgCnt > 0U) + { +#ifndef UNALIGNED_SUPPORT_DISABLE + + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + +#else + + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the loop counter */ + stgCnt--; + + } + + /* Calculation of count for remaining q15_t data */ + stgCnt = (numStages) % 0x4U; + + /* copy data */ + while (stgCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + stgCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + q31_t fcurr, fnext = 0, gcurr = 0, gnext; /* Temporary variables for lattice stages */ + uint32_t stgCnt; /* Temporary variables for counts */ + q63_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* Temporary variables for counts */ + q15_t *px1, *px2, *pk, *pv; /* temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + q15_t *pState; /* State pointer */ + q15_t *pStateCurnt; /* State current pointer */ + q15_t out; /* Temporary variable for output */ + + + blkCnt = blockSize; + + pState = &S->pState[0]; + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + tapCnt = numStages; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample */ + /* fN-1(n) = fN(n) - kN * gN-1(n-1) */ + fnext = fcurr - ((gcurr * (*pk)) >> 15); + fnext = __SSAT(fnext, 16); + /* gN(n) = kN * fN-1(n) + gN-1(n-1) */ + gnext = ((fnext * (*pk++)) >> 15) + gcurr; + gnext = __SSAT(gnext, 16); + /* Output samples */ + /* y(n) += gN(n) * vN */ + acc += (q31_t) ((gnext * (*pv++))); + /* write gN(n) into state for next sample processing */ + *px2++ = (q15_t) gnext; + /* Update f values for next coefficient processing */ + fcurr = fnext; + + tapCnt--; + } + + /* y(n) += g0(n) * v0 */ + acc += (q31_t) ((fnext * (*pv++))); + + out = (q15_t) __SSAT(acc >> 15, 16); + *px2++ = (q15_t) fnext; + + /* write out into pDst */ + *pDst++ = out; + + /* Advance the state pointer by 1 to process the next group of samples */ + pState = pState + 1U; + blkCnt--; + + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + stgCnt = numStages; + + /* copy data */ + while (stgCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + stgCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + + + + +/** + * @} end of IIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q31.c new file mode 100644 index 0000000..736cbc0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_iir_lattice_q31.c @@ -0,0 +1,338 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_iir_lattice_q31.c + * Description: Q31 IIR lattice filter processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup IIR_Lattice + * @{ + */ + +/** + * @brief Processing function for the Q31 IIR lattice filter. + * @param[in] *S points to an instance of the Q31 IIR lattice structure. + * @param[in] *pSrc points to the block of input data. + * @param[out] *pDst points to the block of output data. + * @param[in] blockSize number of samples to process. + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clip. + * In order to avoid overflows completely the input signal must be scaled down by 2*log2(numStages) bits. + * After all multiply-accumulates are performed, the 2.62 accumulator is saturated to 1.32 format and then truncated to 1.31 format. + */ + +void arm_iir_lattice_q31( + const arm_iir_lattice_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q31_t fcurr, fnext = 0, gcurr = 0, gnext; /* Temporary variables for lattice stages */ + q63_t acc; /* Accumlator */ + uint32_t blkCnt, tapCnt; /* Temporary variables for counts */ + q31_t *px1, *px2, *pk, *pv; /* Temporary pointers for state and coef */ + uint32_t numStages = S->numStages; /* number of stages */ + q31_t *pState; /* State pointer */ + q31_t *pStateCurnt; /* State current pointer */ + + blkCnt = blockSize; + + pState = &S->pState[0]; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + + /* Process sample for first tap */ + gcurr = *px1++; + /* fN-1(n) = fN(n) - kN * gN-1(n-1) */ + fnext = __QSUB(fcurr, (q31_t) (((q63_t) gcurr * (*pk)) >> 31)); + /* gN(n) = kN * fN-1(n) + gN-1(n-1) */ + gnext = __QADD(gcurr, (q31_t) (((q63_t) fnext * (*pk++)) >> 31)); + /* write gN-1(n-1) into state for next sample processing */ + *px2++ = gnext; + /* y(n) += gN(n) * vN */ + acc += ((q63_t) gnext * *pv++); + + /* Update f values for next coefficient processing */ + fcurr = fnext; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = (numStages - 1U) >> 2; + + while (tapCnt > 0U) + { + + /* Process sample for 2nd, 6th .. taps */ + /* Read gN-2(n-1) from state buffer */ + gcurr = *px1++; + /* fN-2(n) = fN-1(n) - kN-1 * gN-2(n-1) */ + fnext = __QSUB(fcurr, (q31_t) (((q63_t) gcurr * (*pk)) >> 31)); + /* gN-1(n) = kN-1 * fN-2(n) + gN-2(n-1) */ + gnext = __QADD(gcurr, (q31_t) (((q63_t) fnext * (*pk++)) >> 31)); + /* y(n) += gN-1(n) * vN-1 */ + /* process for gN-5(n) * vN-5, gN-9(n) * vN-9 ... */ + acc += ((q63_t) gnext * *pv++); + /* write gN-1(n) into state for next sample processing */ + *px2++ = gnext; + + /* Process sample for 3nd, 7th ...taps */ + /* Read gN-3(n-1) from state buffer */ + gcurr = *px1++; + /* Process sample for 3rd, 7th .. taps */ + /* fN-3(n) = fN-2(n) - kN-2 * gN-3(n-1) */ + fcurr = __QSUB(fnext, (q31_t) (((q63_t) gcurr * (*pk)) >> 31)); + /* gN-2(n) = kN-2 * fN-3(n) + gN-3(n-1) */ + gnext = __QADD(gcurr, (q31_t) (((q63_t) fcurr * (*pk++)) >> 31)); + /* y(n) += gN-2(n) * vN-2 */ + /* process for gN-6(n) * vN-6, gN-10(n) * vN-10 ... */ + acc += ((q63_t) gnext * *pv++); + /* write gN-2(n) into state for next sample processing */ + *px2++ = gnext; + + + /* Process sample for 4th, 8th ...taps */ + /* Read gN-4(n-1) from state buffer */ + gcurr = *px1++; + /* Process sample for 4th, 8th .. taps */ + /* fN-4(n) = fN-3(n) - kN-3 * gN-4(n-1) */ + fnext = __QSUB(fcurr, (q31_t) (((q63_t) gcurr * (*pk)) >> 31)); + /* gN-3(n) = kN-3 * fN-4(n) + gN-4(n-1) */ + gnext = __QADD(gcurr, (q31_t) (((q63_t) fnext * (*pk++)) >> 31)); + /* y(n) += gN-3(n) * vN-3 */ + /* process for gN-7(n) * vN-7, gN-11(n) * vN-11 ... */ + acc += ((q63_t) gnext * *pv++); + /* write gN-3(n) into state for next sample processing */ + *px2++ = gnext; + + + /* Process sample for 5th, 9th ...taps */ + /* Read gN-5(n-1) from state buffer */ + gcurr = *px1++; + /* Process sample for 5th, 9th .. taps */ + /* fN-5(n) = fN-4(n) - kN-4 * gN-1(n-1) */ + fcurr = __QSUB(fnext, (q31_t) (((q63_t) gcurr * (*pk)) >> 31)); + /* gN-4(n) = kN-4 * fN-5(n) + gN-5(n-1) */ + gnext = __QADD(gcurr, (q31_t) (((q63_t) fcurr * (*pk++)) >> 31)); + /* y(n) += gN-4(n) * vN-4 */ + /* process for gN-8(n) * vN-8, gN-12(n) * vN-12 ... */ + acc += ((q63_t) gnext * *pv++); + /* write gN-4(n) into state for next sample processing */ + *px2++ = gnext; + + tapCnt--; + + } + + fnext = fcurr; + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = (numStages - 1U) % 0x4U; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample for last taps */ + fnext = __QSUB(fcurr, (q31_t) (((q63_t) gcurr * (*pk)) >> 31)); + gnext = __QADD(gcurr, (q31_t) (((q63_t) fnext * (*pk++)) >> 31)); + /* Output samples for last taps */ + acc += ((q63_t) gnext * *pv++); + *px2++ = gnext; + fcurr = fnext; + + tapCnt--; + + } + + /* y(n) += g0(n) * v0 */ + acc += (q63_t) fnext *( + *pv++); + + *px2++ = fnext; + + /* write out into pDst */ + *pDst++ = (q31_t) (acc >> 31U); + + /* Advance the state pointer by 4 to process the next group of 4 samples */ + pState = pState + 1U; + blkCnt--; + + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + tapCnt = numStages >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + + } + + /* Calculate remaining number of copies */ + tapCnt = (numStages) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + }; + +#else + + /* Run the below code for Cortex-M0 */ + /* Sample processing */ + while (blkCnt > 0U) + { + /* Read Sample from input buffer */ + /* fN(n) = x(n) */ + fcurr = *pSrc++; + + /* Initialize state read pointer */ + px1 = pState; + /* Initialize state write pointer */ + px2 = pState; + /* Set accumulator to zero */ + acc = 0; + /* Initialize Ladder coeff pointer */ + pv = &S->pvCoeffs[0]; + /* Initialize Reflection coeff pointer */ + pk = &S->pkCoeffs[0]; + + tapCnt = numStages; + + while (tapCnt > 0U) + { + gcurr = *px1++; + /* Process sample */ + /* fN-1(n) = fN(n) - kN * gN-1(n-1) */ + fnext = + clip_q63_to_q31(((q63_t) fcurr - + ((q31_t) (((q63_t) gcurr * (*pk)) >> 31)))); + /* gN(n) = kN * fN-1(n) + gN-1(n-1) */ + gnext = + clip_q63_to_q31(((q63_t) gcurr + + ((q31_t) (((q63_t) fnext * (*pk++)) >> 31)))); + /* Output samples */ + /* y(n) += gN(n) * vN */ + acc += ((q63_t) gnext * *pv++); + /* write gN-1(n-1) into state for next sample processing */ + *px2++ = gnext; + /* Update f values for next coefficient processing */ + fcurr = fnext; + + tapCnt--; + } + + /* y(n) += g0(n) * v0 */ + acc += (q63_t) fnext *( + *pv++); + + *px2++ = fnext; + + /* write out into pDst */ + *pDst++ = (q31_t) (acc >> 31U); + + /* Advance the state pointer by 1 to process the next group of samples */ + pState = pState + 1U; + blkCnt--; + + } + + /* Processing is complete. Now copy last S->numStages samples to start of the buffer + for the preperation of next frame process */ + + /* Points to the start of the state buffer */ + pStateCurnt = &S->pState[0]; + pState = &S->pState[blockSize]; + + tapCnt = numStages; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + + + + +/** + * @} end of IIR_Lattice group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_f32.c new file mode 100644 index 0000000..3975f00 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_f32.c @@ -0,0 +1,430 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_f32.c + * Description: Processing function for the floating-point LMS filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup LMS Least Mean Square (LMS) Filters + * + * LMS filters are a class of adaptive filters that are able to "learn" an unknown transfer functions. + * LMS filters use a gradient descent method in which the filter coefficients are updated based on the instantaneous error signal. + * Adaptive filters are often used in communication systems, equalizers, and noise removal. + * The CMSIS DSP Library contains LMS filter functions that operate on Q15, Q31, and floating-point data types. + * The library also contains normalized LMS filters in which the filter coefficient adaptation is indepedent of the level of the input signal. + * + * An LMS filter consists of two components as shown below. + * The first component is a standard transversal or FIR filter. + * The second component is a coefficient update mechanism. + * The LMS filter has two input signals. + * The "input" feeds the FIR filter while the "reference input" corresponds to the desired output of the FIR filter. + * That is, the FIR filter coefficients are updated so that the output of the FIR filter matches the reference input. + * The filter coefficient update mechanism is based on the difference between the FIR filter output and the reference input. + * This "error signal" tends towards zero as the filter adapts. + * The LMS processing functions accept the input and reference input signals and generate the filter output and error signal. + * \image html LMS.gif "Internal structure of the Least Mean Square filter" + * + * The functions operate on blocks of data and each call to the function processes + * blockSize samples through the filter. + * pSrc points to input signal, pRef points to reference signal, + * pOut points to output signal and pErr points to error signal. + * All arrays contain blockSize values. + * + * The functions operate on a block-by-block basis. + * Internally, the filter coefficients b[n] are updated on a sample-by-sample basis. + * The convergence of the LMS filter is slower compared to the normalized LMS algorithm. + * + * \par Algorithm: + * The output signal y[n] is computed by a standard FIR filter: + *
+ *     y[n] = b[0] * x[n] + b[1] * x[n-1] + b[2] * x[n-2] + ...+ b[numTaps-1] * x[n-numTaps+1]
+ * 
+ * + * \par + * The error signal equals the difference between the reference signal d[n] and the filter output: + *
+ *     e[n] = d[n] - y[n].
+ * 
+ * + * \par + * After each sample of the error signal is computed, the filter coefficients b[k] are updated on a sample-by-sample basis: + *
+ *     b[k] = b[k] + e[n] * mu * x[n-k],  for k=0, 1, ..., numTaps-1
+ * 
+ * where mu is the step size and controls the rate of coefficient convergence. + *\par + * In the APIs, pCoeffs points to a coefficient array of size numTaps. + * Coefficients are stored in time reversed order. + * \par + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to a state array of size numTaps + blockSize - 1. + * Samples in the state buffer are stored in the order: + * \par + *
+ *    {x[n-numTaps+1], x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2]....x[0], x[1], ..., x[blockSize-1]}
+ * 
+ * \par + * Note that the length of the state buffer exceeds the length of the coefficient array by blockSize-1 samples. + * The increased state buffer length allows circular addressing, which is traditionally used in FIR filters, + * to be avoided and yields a significant speed improvement. + * The state variables are updated after each block of data is processed. + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter and + * coefficient and state arrays cannot be shared among instances. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numTaps, pCoeffs, mu, postShift (not for f32), pState. Also set all of the values in pState to zero. + * + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * Set the values in the state buffer to zeros before static initialization. + * The code below statically initializes each of the 3 different data type filter instance structures + *
+ *    arm_lms_instance_f32 S = {numTaps, pState, pCoeffs, mu};
+ *    arm_lms_instance_q31 S = {numTaps, pState, pCoeffs, mu, postShift};
+ *    arm_lms_instance_q15 S = {numTaps, pState, pCoeffs, mu, postShift};
+ * 
+ * where numTaps is the number of filter coefficients in the filter; pState is the address of the state buffer; + * pCoeffs is the address of the coefficient buffer; mu is the step size parameter; and postShift is the shift applied to coefficients. + * + * \par Fixed-Point Behavior: + * Care must be taken when using the Q15 and Q31 versions of the LMS filter. + * The following issues must be considered: + * - Scaling of coefficients + * - Overflow and saturation + * + * \par Scaling of Coefficients: + * Filter coefficients are represented as fractional values and + * coefficients are restricted to lie in the range [-1 +1). + * The fixed-point functions have an additional scaling parameter postShift. + * At the output of the filter's accumulator is a shift register which shifts the result by postShift bits. + * This essentially scales the filter coefficients by 2^postShift and + * allows the filter coefficients to exceed the range [+1 -1). + * The value of postShift is set by the user based on the expected gain through the system being modeled. + * + * \par Overflow and Saturation: + * Overflow and saturation behavior of the fixed-point Q15 and Q31 versions are + * described separately as part of the function specific documentation below. + */ + +/** + * @addtogroup LMS + * @{ + */ + +/** + * @details + * This function operates on floating-point data types. + * + * @brief Processing function for floating-point LMS filter. + * @param[in] *S points to an instance of the floating-point LMS filter structure. + * @param[in] *pSrc points to the block of input data. + * @param[in] *pRef points to the block of reference data. + * @param[out] *pOut points to the block of output data. + * @param[out] *pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + * @return none. + */ + +void arm_lms_f32( + const arm_lms_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + float32_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + float32_t sum, e, d; /* accumulator, error, reference data sample */ + float32_t w = 0.0f; /* weight factor */ + + e = 0.0f; + d = 0.0f; + + /* S->pState points to state array which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + blkCnt = blockSize; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Set the accumulator to zero */ + sum = 0.0f; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += (*px++) * (*pb++); + sum += (*px++) * (*pb++); + sum += (*px++) * (*pb++); + sum += (*px++) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += (*px++) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result in the accumulator, store in the destination buffer. */ + *pOut++ = sum; + + /* Compute and store error */ + d = (float32_t) (*pRef++); + e = d - sum; + *pErr++ = e; + + /* Calculation of Weighting factor for the updating filter coefficients */ + w = e * mu; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Update filter coefficients */ + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + *pb = *pb + (w * (*px++)); + pb++; + + *pb = *pb + (w * (*px++)); + pb++; + + *pb = *pb + (w * (*px++)); + pb++; + + *pb = *pb + (w * (*px++)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + *pb = *pb + (w * (*px++)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Loop unrolling for (numTaps - 1U) samples copy */ + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Set the accumulator to zero */ + sum = 0.0f; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += (*px++) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result is stored in the destination buffer. */ + *pOut++ = sum; + + /* Compute and store error */ + d = (float32_t) (*pRef++); + e = d - sum; + *pErr++ = e; + + /* Weighting factor for the LMS version */ + w = e * mu; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + *pb = *pb + (w * (*px++)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + * start of the state buffer. This prepares the state buffer for the + * next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Copy (numTaps - 1U) samples */ + tapCnt = (numTaps - 1U); + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of LMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_f32.c new file mode 100644 index 0000000..73158bb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_f32.c @@ -0,0 +1,83 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_init_f32.c + * Description: Floating-point LMS filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @addtogroup LMS + * @{ + */ + + /** + * @brief Initialization function for floating-point LMS filter. + * @param[in] *S points to an instance of the floating-point LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] *pCoeffs points to the coefficient buffer. + * @param[in] *pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @return none. + */ + +/** + * \par Description: + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * The initial filter coefficients serve as a starting point for the adaptive filter. + * pState points to an array of length numTaps+blockSize-1 samples, where blockSize is the number of input samples processed by each call to arm_lms_f32(). + */ + +void arm_lms_init_f32( + arm_lms_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + float32_t mu, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always blockSize + numTaps */ + memset(pState, 0, (numTaps + (blockSize - 1)) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Step size value */ + S->mu = mu; +} + +/** + * @} end of LMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q15.c new file mode 100644 index 0000000..001287d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q15.c @@ -0,0 +1,93 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_init_q15.c + * Description: Q15 LMS filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup LMS + * @{ + */ + +/** +* @brief Initialization function for the Q15 LMS filter. +* @param[in] *S points to an instance of the Q15 LMS filter structure. +* @param[in] numTaps number of filter coefficients. +* @param[in] *pCoeffs points to the coefficient buffer. +* @param[in] *pState points to the state buffer. +* @param[in] mu step size that controls filter coefficient updates. +* @param[in] blockSize number of samples to process. +* @param[in] postShift bit shift applied to coefficients. +* @return none. +* +* \par Description: +* pCoeffs points to the array of filter coefficients stored in time reversed order: +*
+*    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+* 
+* The initial filter coefficients serve as a starting point for the adaptive filter. +* pState points to the array of state variables and size of array is +* numTaps+blockSize-1 samples, where blockSize is the number of +* input samples processed by each call to arm_lms_q15(). +*/ + +void arm_lms_init_q15( + arm_lms_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + q15_t mu, + uint32_t blockSize, + uint32_t postShift) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always blockSize + numTaps - 1 */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(q15_t)); + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Step size value */ + S->mu = mu; + + /* Assign postShift value to be applied */ + S->postShift = postShift; + +} + +/** + * @} end of LMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q31.c new file mode 100644 index 0000000..7d95d97 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_init_q31.c @@ -0,0 +1,93 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_init_q31.c + * Description: Q31 LMS filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup LMS + * @{ + */ + + /** + * @brief Initialization function for Q31 LMS filter. + * @param[in] *S points to an instance of the Q31 LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] *pCoeffs points to coefficient buffer. + * @param[in] *pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @param[in] postShift bit shift applied to coefficients. + * @return none. + * + * \par Description: + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * The initial filter coefficients serve as a starting point for the adaptive filter. + * pState points to an array of length numTaps+blockSize-1 samples, + * where blockSize is the number of input samples processed by each call to + * arm_lms_q31(). + */ + +void arm_lms_init_q31( + arm_lms_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + q31_t mu, + uint32_t blockSize, + uint32_t postShift) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always blockSize + numTaps - 1 */ + memset(pState, 0, ((uint32_t) numTaps + (blockSize - 1U)) * sizeof(q31_t)); + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Step size value */ + S->mu = mu; + + /* Assign postShift value to be applied */ + S->postShift = postShift; + +} + +/** + * @} end of LMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_f32.c new file mode 100644 index 0000000..a365b33 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_f32.c @@ -0,0 +1,454 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_norm_f32.c + * Description: Processing function for the floating-point Normalised LMS + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @defgroup LMS_NORM Normalized LMS Filters + * + * This set of functions implements a commonly used adaptive filter. + * It is related to the Least Mean Square (LMS) adaptive filter and includes an additional normalization + * factor which increases the adaptation rate of the filter. + * The CMSIS DSP Library contains normalized LMS filter functions that operate on Q15, Q31, and floating-point data types. + * + * A normalized least mean square (NLMS) filter consists of two components as shown below. + * The first component is a standard transversal or FIR filter. + * The second component is a coefficient update mechanism. + * The NLMS filter has two input signals. + * The "input" feeds the FIR filter while the "reference input" corresponds to the desired output of the FIR filter. + * That is, the FIR filter coefficients are updated so that the output of the FIR filter matches the reference input. + * The filter coefficient update mechanism is based on the difference between the FIR filter output and the reference input. + * This "error signal" tends towards zero as the filter adapts. + * The NLMS processing functions accept the input and reference input signals and generate the filter output and error signal. + * \image html LMS.gif "Internal structure of the NLMS adaptive filter" + * + * The functions operate on blocks of data and each call to the function processes + * blockSize samples through the filter. + * pSrc points to input signal, pRef points to reference signal, + * pOut points to output signal and pErr points to error signal. + * All arrays contain blockSize values. + * + * The functions operate on a block-by-block basis. + * Internally, the filter coefficients b[n] are updated on a sample-by-sample basis. + * The convergence of the LMS filter is slower compared to the normalized LMS algorithm. + * + * \par Algorithm: + * The output signal y[n] is computed by a standard FIR filter: + *
+ *     y[n] = b[0] * x[n] + b[1] * x[n-1] + b[2] * x[n-2] + ...+ b[numTaps-1] * x[n-numTaps+1]
+ * 
+ * + * \par + * The error signal equals the difference between the reference signal d[n] and the filter output: + *
+ *     e[n] = d[n] - y[n].
+ * 
+ * + * \par + * After each sample of the error signal is computed the instanteous energy of the filter state variables is calculated: + *
+ *    E = x[n]^2 + x[n-1]^2 + ... + x[n-numTaps+1]^2.
+ * 
+ * The filter coefficients b[k] are then updated on a sample-by-sample basis: + *
+ *     b[k] = b[k] + e[n] * (mu/E) * x[n-k],  for k=0, 1, ..., numTaps-1
+ * 
+ * where mu is the step size and controls the rate of coefficient convergence. + *\par + * In the APIs, pCoeffs points to a coefficient array of size numTaps. + * Coefficients are stored in time reversed order. + * \par + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * \par + * pState points to a state array of size numTaps + blockSize - 1. + * Samples in the state buffer are stored in the order: + * \par + *
+ *    {x[n-numTaps+1], x[n-numTaps], x[n-numTaps-1], x[n-numTaps-2]....x[0], x[1], ..., x[blockSize-1]}
+ * 
+ * \par + * Note that the length of the state buffer exceeds the length of the coefficient array by blockSize-1 samples. + * The increased state buffer length allows circular addressing, which is traditionally used in FIR filters, + * to be avoided and yields a significant speed improvement. + * The state variables are updated after each block of data is processed. + * \par Instance Structure + * The coefficients and state variables for a filter are stored together in an instance data structure. + * A separate instance structure must be defined for each filter and + * coefficient and state arrays cannot be shared among instances. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Zeros out the values in the state buffer. + * To do this manually without calling the init function, assign the follow subfields of the instance structure: + * numTaps, pCoeffs, mu, energy, x0, pState. Also set all of the values in pState to zero. + * For Q7, Q15, and Q31 the following fields must also be initialized; + * recipTable, postShift + * + * \par + * Instance structure cannot be placed into a const data section and it is recommended to use the initialization function. + * \par Fixed-Point Behavior: + * Care must be taken when using the Q15 and Q31 versions of the normalised LMS filter. + * The following issues must be considered: + * - Scaling of coefficients + * - Overflow and saturation + * + * \par Scaling of Coefficients: + * Filter coefficients are represented as fractional values and + * coefficients are restricted to lie in the range [-1 +1). + * The fixed-point functions have an additional scaling parameter postShift. + * At the output of the filter's accumulator is a shift register which shifts the result by postShift bits. + * This essentially scales the filter coefficients by 2^postShift and + * allows the filter coefficients to exceed the range [+1 -1). + * The value of postShift is set by the user based on the expected gain through the system being modeled. + * + * \par Overflow and Saturation: + * Overflow and saturation behavior of the fixed-point Q15 and Q31 versions are + * described separately as part of the function specific documentation below. + */ + + +/** + * @addtogroup LMS_NORM + * @{ + */ + + + /** + * @brief Processing function for floating-point normalized LMS filter. + * @param[in] *S points to an instance of the floating-point normalized LMS filter structure. + * @param[in] *pSrc points to the block of input data. + * @param[in] *pRef points to the block of reference data. + * @param[out] *pOut points to the block of output data. + * @param[out] *pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + * @return none. + */ + +void arm_lms_norm_f32( + arm_lms_norm_instance_f32 * S, + float32_t * pSrc, + float32_t * pRef, + float32_t * pOut, + float32_t * pErr, + uint32_t blockSize) +{ + float32_t *pState = S->pState; /* State pointer */ + float32_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + float32_t *pStateCurnt; /* Points to the current sample of the state */ + float32_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + float32_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + float32_t energy; /* Energy of the input */ + float32_t sum, e, d; /* accumulator, error, reference data sample */ + float32_t w, x0, in; /* weight factor, temporary variable to hold input sample and state */ + + /* Initializations of error, difference, Coefficient update */ + e = 0.0f; + d = 0.0f; + w = 0.0f; + + energy = S->energy; + x0 = S->x0; + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy -= x0 * x0; + energy += in * in; + + /* Set the accumulator to zero */ + sum = 0.0f; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += (*px++) * (*pb++); + sum += (*px++) * (*pb++); + sum += (*px++) * (*pb++); + sum += (*px++) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += (*px++) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result in the accumulator, store in the destination buffer. */ + *pOut++ = sum; + + /* Compute and store error */ + d = (float32_t) (*pRef++); + e = d - sum; + *pErr++ = e; + + /* Calculation of Weighting factor for updating filter coefficients */ + /* epsilon value 0.000000119209289f */ + w = (e * mu) / (energy + 0.000000119209289f); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Update filter coefficients */ + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + *pb += w * (*px++); + pb++; + + *pb += w * (*px++); + pb++; + + *pb += w * (*px++); + pb++; + + *pb += w * (*px++); + pb++; + + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + *pb += w * (*px++); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + S->energy = energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Loop unrolling for (numTaps - 1U)/4 samples copy */ + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy -= x0 * x0; + energy += in * in; + + /* Set the accumulator to zero */ + sum = 0.0f; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + sum += (*px++) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* The result in the accumulator is stored in the destination buffer. */ + *pOut++ = sum; + + /* Compute and store error */ + d = (float32_t) (*pRef++); + e = d - sum; + *pErr++ = e; + + /* Calculation of Weighting factor for updating filter coefficients */ + /* epsilon value 0.000000119209289f */ + w = (e * mu) / (energy + 0.000000119209289f); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCcoeffs pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + *pb += w * (*px++); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + S->energy = energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Copy (numTaps - 1U) samples */ + tapCnt = (numTaps - 1U); + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of LMS_NORM group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_f32.c new file mode 100644 index 0000000..49272f8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_f32.c @@ -0,0 +1,93 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_norm_init_f32.c + * Description: Floating-point NLMS filter initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup LMS_NORM + * @{ + */ + + /** + * @brief Initialization function for floating-point normalized LMS filter. + * @param[in] *S points to an instance of the floating-point LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] *pCoeffs points to coefficient buffer. + * @param[in] *pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @return none. + * + * \par Description: + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * The initial filter coefficients serve as a starting point for the adaptive filter. + * pState points to an array of length numTaps+blockSize-1 samples, + * where blockSize is the number of input samples processed by each call to arm_lms_norm_f32(). + */ + +void arm_lms_norm_init_f32( + arm_lms_norm_instance_f32 * S, + uint16_t numTaps, + float32_t * pCoeffs, + float32_t * pState, + float32_t mu, + uint32_t blockSize) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always blockSize + numTaps - 1 */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(float32_t)); + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Step size value */ + S->mu = mu; + + /* Initialise Energy to zero */ + S->energy = 0.0f; + + /* Initialise x0 to zero */ + S->x0 = 0.0f; + +} + +/** + * @} end of LMS_NORM group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q15.c new file mode 100644 index 0000000..0624222 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q15.c @@ -0,0 +1,100 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_norm_init_q15.c + * Description: Q15 NLMS initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @addtogroup LMS_NORM + * @{ + */ + + /** + * @brief Initialization function for Q15 normalized LMS filter. + * @param[in] *S points to an instance of the Q15 normalized LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] *pCoeffs points to coefficient buffer. + * @param[in] *pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @param[in] postShift bit shift applied to coefficients. + * @return none. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * The initial filter coefficients serve as a starting point for the adaptive filter. + * pState points to the array of state variables and size of array is + * numTaps+blockSize-1 samples, where blockSize is the number of input samples processed + * by each call to arm_lms_norm_q15(). + */ + +void arm_lms_norm_init_q15( + arm_lms_norm_instance_q15 * S, + uint16_t numTaps, + q15_t * pCoeffs, + q15_t * pState, + q15_t mu, + uint32_t blockSize, + uint8_t postShift) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always blockSize + numTaps - 1 */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(q15_t)); + + /* Assign post Shift value applied to coefficients */ + S->postShift = postShift; + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Step size value */ + S->mu = mu; + + /* Initialize reciprocal pointer table */ + S->recipTable = (q15_t *) armRecipTableQ15; + + /* Initialise Energy to zero */ + S->energy = 0; + + /* Initialise x0 to zero */ + S->x0 = 0; + +} + +/** + * @} end of LMS_NORM group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q31.c new file mode 100644 index 0000000..4f70408 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_init_q31.c @@ -0,0 +1,99 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_norm_init_q31.c + * Description: Q31 NLMS initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @addtogroup LMS_NORM + * @{ + */ + + /** + * @brief Initialization function for Q31 normalized LMS filter. + * @param[in] *S points to an instance of the Q31 normalized LMS filter structure. + * @param[in] numTaps number of filter coefficients. + * @param[in] *pCoeffs points to coefficient buffer. + * @param[in] *pState points to state buffer. + * @param[in] mu step size that controls filter coefficient updates. + * @param[in] blockSize number of samples to process. + * @param[in] postShift bit shift applied to coefficients. + * @return none. + * + * Description: + * \par + * pCoeffs points to the array of filter coefficients stored in time reversed order: + *
+ *    {b[numTaps-1], b[numTaps-2], b[N-2], ..., b[1], b[0]}
+ * 
+ * The initial filter coefficients serve as a starting point for the adaptive filter. + * pState points to an array of length numTaps+blockSize-1 samples, + * where blockSize is the number of input samples processed by each call to arm_lms_norm_q31(). + */ + +void arm_lms_norm_init_q31( + arm_lms_norm_instance_q31 * S, + uint16_t numTaps, + q31_t * pCoeffs, + q31_t * pState, + q31_t mu, + uint32_t blockSize, + uint8_t postShift) +{ + /* Assign filter taps */ + S->numTaps = numTaps; + + /* Assign coefficient pointer */ + S->pCoeffs = pCoeffs; + + /* Clear state buffer and size is always blockSize + numTaps - 1 */ + memset(pState, 0, (numTaps + (blockSize - 1U)) * sizeof(q31_t)); + + /* Assign post Shift value applied to coefficients */ + S->postShift = postShift; + + /* Assign state pointer */ + S->pState = pState; + + /* Assign Step size value */ + S->mu = mu; + + /* Initialize reciprocal pointer table */ + S->recipTable = (q31_t *) armRecipTableQ31; + + /* Initialise Energy to zero */ + S->energy = 0; + + /* Initialise x0 to zero */ + S->x0 = 0; + +} + +/** + * @} end of LMS_NORM group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q15.c new file mode 100644 index 0000000..00bde39 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q15.c @@ -0,0 +1,428 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_norm_q15.c + * Description: Q15 NLMS filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup LMS_NORM + * @{ + */ + +/** +* @brief Processing function for Q15 normalized LMS filter. +* @param[in] *S points to an instance of the Q15 normalized LMS filter structure. +* @param[in] *pSrc points to the block of input data. +* @param[in] *pRef points to the block of reference data. +* @param[out] *pOut points to the block of output data. +* @param[out] *pErr points to the block of error data. +* @param[in] blockSize number of samples to process. +* @return none. +* +* Scaling and Overflow Behavior: +* \par +* The function is implemented using a 64-bit internal accumulator. +* Both coefficients and state variables are represented in 1.15 format and +* multiplications yield a 2.30 result. The 2.30 intermediate results are +* accumulated in a 64-bit accumulator in 34.30 format. +* There is no risk of internal overflow with this approach and the full +* precision of intermediate multiplications is preserved. After all additions +* have been performed, the accumulator is truncated to 34.15 format by +* discarding low 15 bits. Lastly, the accumulator is saturated to yield a +* result in 1.15 format. +* +* \par +* In this filter, filter coefficients are updated for each sample and the updation of filter cofficients are saturted. +* + */ + +void arm_lms_norm_q15( + arm_lms_norm_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + q15_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q31_t energy; /* Energy of the input */ + q63_t acc; /* Accumulator */ + q15_t e = 0, d = 0; /* error, reference data sample */ + q15_t w = 0, in; /* weight factor and state */ + q15_t x0; /* temporary variable to hold input sample */ + //uint32_t shift = (uint32_t) S->postShift + 1U; /* Shift to be applied to the output */ + q15_t errorXmu, oneByEnergy; /* Temporary variables to store error and mu product and reciprocal of energy */ + q15_t postShift; /* Post shift to be applied to weight after reciprocal calculation */ + q31_t coef; /* Teporary variable for coefficient */ + q31_t acc_l, acc_h; + int32_t lShift = (15 - (int32_t) S->postShift); /* Post shift */ + int32_t uShift = (32 - lShift); + + energy = S->energy; + x0 = S->x0; + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy -= (((q31_t) x0 * (x0)) >> 15); + energy += (((q31_t) in * (in)) >> 15); + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0U) + { + + /* Perform the multiply-accumulate */ +#ifndef UNALIGNED_SUPPORT_DISABLE + + acc = __SMLALD(*__SIMD32(px)++, (*__SIMD32(pb)++), acc); + acc = __SMLALD(*__SIMD32(px)++, (*__SIMD32(pb)++), acc); + +#else + + acc += (((q31_t) * px++ * (*pb++))); + acc += (((q31_t) * px++ * (*pb++))); + acc += (((q31_t) * px++ * (*pb++))); + acc += (((q31_t) * px++ * (*pb++))); + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += (((q31_t) * px++ * (*pb++))); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Converting the result to 1.15 format and saturate the output */ + acc = __SSAT(acc, 16U); + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* Compute and store error */ + d = *pRef++; + e = d - (q15_t) acc; + *pErr++ = e; + + /* Calculation of 1/energy */ + postShift = arm_recip_q15((q15_t) energy + DELTA_Q15, + &oneByEnergy, S->recipTable); + + /* Calculation of e * mu value */ + errorXmu = (q15_t) (((q31_t) e * mu) >> 15); + + /* Calculation of (e * mu) * (1/energy) value */ + acc = (((q31_t) errorXmu * oneByEnergy) >> (15 - postShift)); + + /* Weighting factor for the normalized version */ + w = (q15_t) __SSAT((q31_t) acc, 16); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Update filter coefficients */ + while (tapCnt > 0U) + { + coef = *pb + (((q31_t) w * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + coef = *pb + (((q31_t) w * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + coef = *pb + (((q31_t) w * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + coef = *pb + (((q31_t) w * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = *pb + (((q31_t) w * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Read the sample from state buffer */ + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Save energy and x0 values for the next frame */ + S->energy = (q15_t) energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Calculation of count for copying integer writes */ + tapCnt = (numTaps - 1U) >> 2; + + while (tapCnt > 0U) + { + +#ifndef UNALIGNED_SUPPORT_DISABLE + + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + +#else + + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + +#endif + + tapCnt--; + + } + + /* Calculation of count for remaining q15_t data */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy -= (((q31_t) x0 * (x0)) >> 15); + energy += (((q31_t) in * (in)) >> 15); + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += (((q31_t) * px++ * (*pb++))); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Converting the result to 1.15 format and saturate the output */ + acc = __SSAT(acc, 16U); + + /* Converting the result to 1.15 format */ + //acc = __SSAT((acc >> (16U - shift)), 16U); + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* Compute and store error */ + d = *pRef++; + e = d - (q15_t) acc; + *pErr++ = e; + + /* Calculation of 1/energy */ + postShift = arm_recip_q15((q15_t) energy + DELTA_Q15, + &oneByEnergy, S->recipTable); + + /* Calculation of e * mu value */ + errorXmu = (q15_t) (((q31_t) e * mu) >> 15); + + /* Calculation of (e * mu) * (1/energy) value */ + acc = (((q31_t) errorXmu * oneByEnergy) >> (15 - postShift)); + + /* Weighting factor for the normalized version */ + w = (q15_t) __SSAT((q31_t) acc, 16); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = *pb + (((q31_t) w * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Read the sample from state buffer */ + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Save energy and x0 values for the next frame */ + S->energy = (q15_t) energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* copy (numTaps - 1U) data */ + tapCnt = (numTaps - 1U); + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + + +/** + * @} end of LMS_NORM group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q31.c new file mode 100644 index 0000000..bc65fa6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_norm_q31.c @@ -0,0 +1,419 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_norm_q31.c + * Description: Processing function for the Q31 NLMS filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup LMS_NORM + * @{ + */ + +/** +* @brief Processing function for Q31 normalized LMS filter. +* @param[in] *S points to an instance of the Q31 normalized LMS filter structure. +* @param[in] *pSrc points to the block of input data. +* @param[in] *pRef points to the block of reference data. +* @param[out] *pOut points to the block of output data. +* @param[out] *pErr points to the block of error data. +* @param[in] blockSize number of samples to process. +* @return none. +* +* Scaling and Overflow Behavior: +* \par +* The function is implemented using an internal 64-bit accumulator. +* The accumulator has a 2.62 format and maintains full precision of the intermediate +* multiplication results but provides only a single guard bit. +* Thus, if the accumulator result overflows it wraps around rather than clip. +* In order to avoid overflows completely the input signal must be scaled down by +* log2(numTaps) bits. The reference signal should not be scaled down. +* After all multiply-accumulates are performed, the 2.62 accumulator is shifted +* and saturated to 1.31 format to yield the final result. +* The output signal and error signal are in 1.31 format. +* +* \par +* In this filter, filter coefficients are updated for each sample and the +* updation of filter cofficients are saturted. +* +*/ + +void arm_lms_norm_q31( + arm_lms_norm_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t *px, *pb; /* Temporary pointers for state and coefficient buffers */ + q31_t mu = S->mu; /* Adaptive factor */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q63_t energy; /* Energy of the input */ + q63_t acc; /* Accumulator */ + q31_t e = 0, d = 0; /* error, reference data sample */ + q31_t w = 0, in; /* weight factor and state */ + q31_t x0; /* temporary variable to hold input sample */ +// uint32_t shift = 32U - ((uint32_t) S->postShift + 1U); /* Shift to be applied to the output */ + q31_t errorXmu, oneByEnergy; /* Temporary variables to store error and mu product and reciprocal of energy */ + q31_t postShift; /* Post shift to be applied to weight after reciprocal calculation */ + q31_t coef; /* Temporary variable for coef */ + q31_t acc_l, acc_h; /* temporary input */ + uint32_t uShift = ((uint32_t) S->postShift + 1U); + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + + energy = S->energy; + x0 = S->x0; + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + while (blkCnt > 0U) + { + + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy = (q31_t) ((((q63_t) energy << 32) - + (((q63_t) x0 * x0) << 1)) >> 32); + energy = (q31_t) (((((q63_t) in * in) << 1) + (energy << 32)) >> 32); + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += ((q63_t) (*px++)) * (*pb++); + acc += ((q63_t) (*px++)) * (*pb++); + acc += ((q63_t) (*px++)) * (*pb++); + acc += ((q63_t) (*px++)) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Converting the result to 1.31 format */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q31_t) acc; + + /* Compute and store error */ + d = *pRef++; + e = d - (q31_t) acc; + *pErr++ = e; + + /* Calculates the reciprocal of energy */ + postShift = arm_recip_q31(energy + DELTA_Q31, + &oneByEnergy, &S->recipTable[0]); + + /* Calculation of product of (e * mu) */ + errorXmu = (q31_t) (((q63_t) e * mu) >> 31); + + /* Weighting factor for the normalized version */ + w = clip_q63_to_q31(((q63_t) errorXmu * oneByEnergy) >> (31 - postShift)); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Update filter coefficients */ + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + + /* coef is in 2.30 format */ + coef = (q31_t) (((q63_t) w * (*px++)) >> (32)); + /* get coef in 1.31 format by left shifting */ + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + /* update coefficient buffer to next coefficient */ + pb++; + + coef = (q31_t) (((q63_t) w * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + coef = (q31_t) (((q63_t) w * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + coef = (q31_t) (((q63_t) w * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = (q31_t) (((q63_t) w * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Read the sample from state buffer */ + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Save energy and x0 values for the next frame */ + S->energy = (q31_t) energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Loop unrolling for (numTaps - 1U) samples copy */ + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + while (blkCnt > 0U) + { + + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Read the sample from input buffer */ + in = *pSrc++; + + /* Update the energy calculation */ + energy = + (q31_t) ((((q63_t) energy << 32) - (((q63_t) x0 * x0) << 1)) >> 32); + energy = (q31_t) (((((q63_t) in * in) << 1) + (energy << 32)) >> 32); + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Converting the result to 1.31 format */ + /* Converting the result to 1.31 format */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + + //acc = (q31_t) (acc >> shift); + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q31_t) acc; + + /* Compute and store error */ + d = *pRef++; + e = d - (q31_t) acc; + *pErr++ = e; + + /* Calculates the reciprocal of energy */ + postShift = + arm_recip_q31(energy + DELTA_Q31, &oneByEnergy, &S->recipTable[0]); + + /* Calculation of product of (e * mu) */ + errorXmu = (q31_t) (((q63_t) e * mu) >> 31); + + /* Weighting factor for the normalized version */ + w = clip_q63_to_q31(((q63_t) errorXmu * oneByEnergy) >> (31 - postShift)); + + /* Initialize pState pointer */ + px = pState; + + /* Initialize coeff pointer */ + pb = (pCoeffs); + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + /* coef is in 2.30 format */ + coef = (q31_t) (((q63_t) w * (*px++)) >> (32)); + /* get coef in 1.31 format by left shifting */ + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + /* update coefficient buffer to next coefficient */ + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Read the sample from state buffer */ + x0 = *pState; + + /* Advance state pointer by 1 for the next sample */ + pState = pState + 1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Save energy and x0 values for the next frame */ + S->energy = (q31_t) energy; + S->x0 = x0; + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + start of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Loop for (numTaps - 1U) samples copy */ + tapCnt = (numTaps - 1U); + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of LMS_NORM group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q15.c new file mode 100644 index 0000000..8d5226e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q15.c @@ -0,0 +1,368 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_q15.c + * Description: Processing function for the Q15 LMS filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup LMS + * @{ + */ + + /** + * @brief Processing function for Q15 LMS filter. + * @param[in] *S points to an instance of the Q15 LMS filter structure. + * @param[in] *pSrc points to the block of input data. + * @param[in] *pRef points to the block of reference data. + * @param[out] *pOut points to the block of output data. + * @param[out] *pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + * @return none. + * + * \par Scaling and Overflow Behavior: + * The function is implemented using a 64-bit internal accumulator. + * Both coefficients and state variables are represented in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate results are accumulated in a 64-bit accumulator in 34.30 format. + * There is no risk of internal overflow with this approach and the full precision of intermediate multiplications is preserved. + * After all additions have been performed, the accumulator is truncated to 34.15 format by discarding low 15 bits. + * Lastly, the accumulator is saturated to yield a result in 1.15 format. + * + * \par + * In this filter, filter coefficients are updated for each sample and the updation of filter cofficients are saturted. + * + */ + +void arm_lms_q15( + const arm_lms_instance_q15 * S, + q15_t * pSrc, + q15_t * pRef, + q15_t * pOut, + q15_t * pErr, + uint32_t blockSize) +{ + q15_t *pState = S->pState; /* State pointer */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + q15_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q15_t *pStateCurnt; /* Points to the current sample of the state */ + q15_t mu = S->mu; /* Adaptive factor */ + q15_t *px; /* Temporary pointer for state */ + q15_t *pb; /* Temporary pointer for coefficient buffer */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q63_t acc; /* Accumulator */ + q15_t e = 0; /* error of data sample */ + q15_t alpha; /* Intermediate constant for taps update */ + q31_t coef; /* Teporary variable for coefficient */ + q31_t acc_l, acc_h; + int32_t lShift = (15 - (int32_t) S->postShift); /* Post shift */ + int32_t uShift = (32 - lShift); + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Initializing blkCnt with blockSize */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coefficient pointer */ + pb = pCoeffs; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2U; + + while (tapCnt > 0U) + { + /* acc += b[N] * x[n-N] + b[N-1] * x[n-N-1] */ + /* Perform the multiply-accumulate */ +#ifndef UNALIGNED_SUPPORT_DISABLE + + acc = __SMLALD(*__SIMD32(px)++, (*__SIMD32(pb)++), acc); + acc = __SMLALD(*__SIMD32(px)++, (*__SIMD32(pb)++), acc); + +#else + + acc += (q63_t) (((q31_t) (*px++) * (*pb++))); + acc += (q63_t) (((q31_t) (*px++) * (*pb++))); + acc += (q63_t) (((q31_t) (*px++) * (*pb++))); + acc += (q63_t) (((q31_t) (*px++) * (*pb++))); + + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += (q63_t) (((q31_t) (*px++) * (*pb++))); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Converting the result to 1.15 format and saturate the output */ + acc = __SSAT(acc, 16); + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* Compute and store error */ + e = *pRef++ - (q15_t) acc; + + *pErr++ = (q15_t) e; + + /* Compute alpha i.e. intermediate constant for taps update */ + alpha = (q15_t) (((q31_t) e * (mu)) >> 15); + + /* Initialize state pointer */ + /* Advance state pointer by 1 for the next sample */ + px = pState++; + + /* Initialize coefficient pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2U; + + /* Update filter coefficients */ + while (tapCnt > 0U) + { + coef = (q31_t) * pb + (((q31_t) alpha * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + coef = (q31_t) * pb + (((q31_t) alpha * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + coef = (q31_t) * pb + (((q31_t) alpha * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + coef = (q31_t) * pb + (((q31_t) alpha * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = (q31_t) * pb + (((q31_t) alpha * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Decrement the loop counter */ + blkCnt--; + + } + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Calculation of count for copying integer writes */ + tapCnt = (numTaps - 1U) >> 2; + + while (tapCnt > 0U) + { + +#ifndef UNALIGNED_SUPPORT_DISABLE + + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; + *__SIMD32(pStateCurnt)++ = *__SIMD32(pState)++; +#else + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; +#endif + + tapCnt--; + + } + + /* Calculation of count for remaining q15_t data */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += (q63_t) ((q31_t) (*px++) * (*pb++)); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + /* Apply shift for lower part of acc and upper part of acc */ + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Converting the result to 1.15 format and saturate the output */ + acc = __SSAT(acc, 16); + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q15_t) acc; + + /* Compute and store error */ + e = *pRef++ - (q15_t) acc; + + *pErr++ = (q15_t) e; + + /* Compute alpha i.e. intermediate constant for taps update */ + alpha = (q15_t) (((q31_t) e * (mu)) >> 15); + + /* Initialize pState pointer */ + /* Advance state pointer by 1 for the next sample */ + px = pState++; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = (q31_t) * pb + (((q31_t) alpha * (*px++)) >> 15); + *pb++ = (q15_t) __SSAT((coef), 16); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Decrement the loop counter */ + blkCnt--; + + } + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + start of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Copy (numTaps - 1U) samples */ + tapCnt = (numTaps - 1U); + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of LMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q31.c new file mode 100644 index 0000000..66b2a91 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/FilteringFunctions/arm_lms_q31.c @@ -0,0 +1,357 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_lms_q31.c + * Description: Processing function for the Q31 LMS filter + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +/** + * @ingroup groupFilters + */ + +/** + * @addtogroup LMS + * @{ + */ + + /** + * @brief Processing function for Q31 LMS filter. + * @param[in] *S points to an instance of the Q15 LMS filter structure. + * @param[in] *pSrc points to the block of input data. + * @param[in] *pRef points to the block of reference data. + * @param[out] *pOut points to the block of output data. + * @param[out] *pErr points to the block of error data. + * @param[in] blockSize number of samples to process. + * @return none. + * + * \par Scaling and Overflow Behavior: + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate + * multiplication results but provides only a single guard bit. + * Thus, if the accumulator result overflows it wraps around rather than clips. + * In order to avoid overflows completely the input signal must be scaled down by + * log2(numTaps) bits. + * The reference signal should not be scaled down. + * After all multiply-accumulates are performed, the 2.62 accumulator is shifted + * and saturated to 1.31 format to yield the final result. + * The output signal and error signal are in 1.31 format. + * + * \par + * In this filter, filter coefficients are updated for each sample and the updation of filter cofficients are saturted. + */ + +void arm_lms_q31( + const arm_lms_instance_q31 * S, + q31_t * pSrc, + q31_t * pRef, + q31_t * pOut, + q31_t * pErr, + uint32_t blockSize) +{ + q31_t *pState = S->pState; /* State pointer */ + uint32_t numTaps = S->numTaps; /* Number of filter coefficients in the filter */ + q31_t *pCoeffs = S->pCoeffs; /* Coefficient pointer */ + q31_t *pStateCurnt; /* Points to the current sample of the state */ + q31_t mu = S->mu; /* Adaptive factor */ + q31_t *px; /* Temporary pointer for state */ + q31_t *pb; /* Temporary pointer for coefficient buffer */ + uint32_t tapCnt, blkCnt; /* Loop counters */ + q63_t acc; /* Accumulator */ + q31_t e = 0; /* error of data sample */ + q31_t alpha; /* Intermediate constant for taps update */ + q31_t coef; /* Temporary variable for coef */ + q31_t acc_l, acc_h; /* temporary input */ + uint32_t uShift = ((uint32_t) S->postShift + 1U); + uint32_t lShift = 32U - uShift; /* Shift to be applied to the output */ + + /* S->pState points to buffer which contains previous frame (numTaps - 1) samples */ + /* pStateCurnt points to the location where the new input data should be written */ + pStateCurnt = &(S->pState[(numTaps - 1U)]); + + /* Initializing blkCnt with blockSize */ + blkCnt = blockSize; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize state pointer */ + px = pState; + + /* Initialize coefficient pointer */ + pb = pCoeffs; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + /* acc += b[N] * x[n-N] */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* acc += b[N-1] * x[n-N-1] */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* acc += b[N-2] * x[n-N-2] */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* acc += b[N-3] * x[n-N-3] */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Converting the result to 1.31 format */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + /* Store the result from accumulator into the destination buffer. */ + *pOut++ = (q31_t) acc; + + /* Compute and store error */ + e = *pRef++ - (q31_t) acc; + + *pErr++ = (q31_t) e; + + /* Compute alpha i.e. intermediate constant for taps update */ + alpha = (q31_t) (((q63_t) e * mu) >> 31); + + /* Initialize state pointer */ + /* Advance state pointer by 1 for the next sample */ + px = pState++; + + /* Initialize coefficient pointer */ + pb = pCoeffs; + + /* Loop unrolling. Process 4 taps at a time. */ + tapCnt = numTaps >> 2; + + /* Update filter coefficients */ + while (tapCnt > 0U) + { + /* coef is in 2.30 format */ + coef = (q31_t) (((q63_t) alpha * (*px++)) >> (32)); + /* get coef in 1.31 format by left shifting */ + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + /* update coefficient buffer to next coefficient */ + pb++; + + coef = (q31_t) (((q63_t) alpha * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + coef = (q31_t) (((q63_t) alpha * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + coef = (q31_t) (((q63_t) alpha * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* If the filter length is not a multiple of 4, compute the remaining filter taps */ + tapCnt = numTaps % 0x4U; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = (q31_t) (((q63_t) alpha * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + satrt of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Loop unrolling for (numTaps - 1U) samples copy */ + tapCnt = (numTaps - 1U) >> 2U; + + /* copy data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Calculate remaining number of copies */ + tapCnt = (numTaps - 1U) % 0x4U; + + /* Copy the remaining q31_t data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + while (blkCnt > 0U) + { + /* Copy the new input sample into the state buffer */ + *pStateCurnt++ = *pSrc++; + + /* Initialize pState pointer */ + px = pState; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Set the accumulator to zero */ + acc = 0; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + acc += ((q63_t) (*px++)) * (*pb++); + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Converting the result to 1.31 format */ + /* Store the result from accumulator into the destination buffer. */ + /* Calc lower part of acc */ + acc_l = acc & 0xffffffff; + + /* Calc upper part of acc */ + acc_h = (acc >> 32) & 0xffffffff; + + acc = (uint32_t) acc_l >> lShift | acc_h << uShift; + + *pOut++ = (q31_t) acc; + + /* Compute and store error */ + e = *pRef++ - (q31_t) acc; + + *pErr++ = (q31_t) e; + + /* Weighting factor for the LMS version */ + alpha = (q31_t) (((q63_t) e * mu) >> 31); + + /* Initialize pState pointer */ + /* Advance state pointer by 1 for the next sample */ + px = pState++; + + /* Initialize pCoeffs pointer */ + pb = pCoeffs; + + /* Loop over numTaps number of values */ + tapCnt = numTaps; + + while (tapCnt > 0U) + { + /* Perform the multiply-accumulate */ + coef = (q31_t) (((q63_t) alpha * (*px++)) >> (32)); + *pb = clip_q63_to_q31((q63_t) * pb + (coef << 1U)); + pb++; + + /* Decrement the loop counter */ + tapCnt--; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Processing is complete. Now copy the last numTaps - 1 samples to the + start of the state buffer. This prepares the state buffer for the + next function call. */ + + /* Points to the start of the pState buffer */ + pStateCurnt = S->pState; + + /* Copy (numTaps - 1U) samples */ + tapCnt = (numTaps - 1U); + + /* Copy the data */ + while (tapCnt > 0U) + { + *pStateCurnt++ = *pState++; + + /* Decrement the loop counter */ + tapCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of LMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_f32.c new file mode 100644 index 0000000..9b609be --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_f32.c @@ -0,0 +1,196 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_add_f32.c + * Description: Floating-point matrix addition + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixAdd Matrix Addition + * + * Adds two matrices. + * \image html MatrixAddition.gif "Addition of two 3 x 3 matrices" + * + * The functions check to make sure that + * pSrcA, pSrcB, and pDst have the same + * number of rows and columns. + */ + +/** + * @addtogroup MatrixAdd + * @{ + */ + + +/** + * @brief Floating-point matrix addition. + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + +arm_status arm_mat_add_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + float32_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + float32_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + float32_t *pOut = pDst->pData; /* output data matrix pointer */ + +#if defined (ARM_MATH_DSP) + + float32_t inA1, inA2, inB1, inB2, out1, out2; /* temporary variables */ + +#endif // #if defined (ARM_MATH_DSP) + + uint32_t numSamples; /* total number of elements in the matrix */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix addition */ + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrcA->numRows != pSrcB->numRows) || + (pSrcA->numCols != pSrcB->numCols) || + (pSrcA->numRows != pDst->numRows) || (pSrcA->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif + { + + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + +#if defined (ARM_MATH_DSP) + + /* Loop unrolling */ + blkCnt = numSamples >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) + B(m,n) */ + /* Add and then store the results in the destination buffer. */ + /* Read values from source A */ + inA1 = pIn1[0]; + + /* Read values from source B */ + inB1 = pIn2[0]; + + /* Read values from source A */ + inA2 = pIn1[1]; + + /* out = sourceA + sourceB */ + out1 = inA1 + inB1; + + /* Read values from source B */ + inB2 = pIn2[1]; + + /* Read values from source A */ + inA1 = pIn1[2]; + + /* out = sourceA + sourceB */ + out2 = inA2 + inB2; + + /* Read values from source B */ + inB1 = pIn2[2]; + + /* Store result in destination */ + pOut[0] = out1; + pOut[1] = out2; + + /* Read values from source A */ + inA2 = pIn1[3]; + + /* Read values from source B */ + inB2 = pIn2[3]; + + /* out = sourceA + sourceB */ + out1 = inA1 + inB1; + + /* out = sourceA + sourceB */ + out2 = inA2 + inB2; + + /* Store result in destination */ + pOut[2] = out1; + + /* Store result in destination */ + pOut[3] = out2; + + + /* update pointers to process next sampels */ + pIn1 += 4U; + pIn2 += 4U; + pOut += 4U; + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the numSamples is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) + B(m,n) */ + /* Add and then store the results in the destination buffer. */ + *pOut++ = (*pIn1++) + (*pIn2++); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixAdd group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q15.c new file mode 100644 index 0000000..e6737fa --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q15.c @@ -0,0 +1,151 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_add_q15.c + * Description: Q15 matrix addition + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixAdd + * @{ + */ + +/** + * @brief Q15 matrix addition. + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +arm_status arm_mat_add_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst) +{ + q15_t *pInA = pSrcA->pData; /* input data matrix pointer A */ + q15_t *pInB = pSrcB->pData; /* input data matrix pointer B */ + q15_t *pOut = pDst->pData; /* output data matrix pointer */ + uint16_t numSamples; /* total number of elements in the matrix */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix addition */ + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrcA->numRows != pSrcB->numRows) || + (pSrcA->numCols != pSrcB->numCols) || + (pSrcA->numRows != pDst->numRows) || (pSrcA->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Total number of samples in the input matrix */ + numSamples = (uint16_t) (pSrcA->numRows * pSrcA->numCols); + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop unrolling */ + blkCnt = (uint32_t) numSamples >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) + B(m,n) */ + /* Add, Saturate and then store the results in the destination buffer. */ + *__SIMD32(pOut)++ = __QADD16(*__SIMD32(pInA)++, *__SIMD32(pInB)++); + *__SIMD32(pOut)++ = __QADD16(*__SIMD32(pInA)++, *__SIMD32(pInB)++); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = (uint32_t) numSamples % 0x4U; + + /* q15 pointers of input and output are initialized */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) + B(m,n) */ + /* Add, Saturate and then store the results in the destination buffer. */ + *pOut++ = (q15_t) __QADD16(*pInA++, *pInB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = (uint32_t) numSamples; + + + /* q15 pointers of input and output are initialized */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) + B(m,n) */ + /* Add, Saturate and then store the results in the destination buffer. */ + *pOut++ = (q15_t) __SSAT(((q31_t) * pInA++ + *pInB++), 16); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixAdd group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q31.c new file mode 100644 index 0000000..4119563 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_add_q31.c @@ -0,0 +1,195 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_add_q31.c + * Description: Q31 matrix addition + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixAdd + * @{ + */ + +/** + * @brief Q31 matrix addition. + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range [0x80000000 0x7FFFFFFF] will be saturated. + */ + +arm_status arm_mat_add_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + q31_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + q31_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + q31_t *pOut = pDst->pData; /* output data matrix pointer */ + q31_t inA1, inB1; /* temporary variables */ + +#if defined (ARM_MATH_DSP) + + q31_t inA2, inB2; /* temporary variables */ + q31_t out1, out2; /* temporary variables */ + +#endif // #if defined (ARM_MATH_DSP) + + uint32_t numSamples; /* total number of elements in the matrix */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix addition */ + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrcA->numRows != pSrcB->numRows) || + (pSrcA->numCols != pSrcB->numCols) || + (pSrcA->numRows != pDst->numRows) || (pSrcA->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif + { + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop Unrolling */ + blkCnt = numSamples >> 2U; + + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) + B(m,n) */ + /* Add, saturate and then store the results in the destination buffer. */ + /* Read values from source A */ + inA1 = pIn1[0]; + + /* Read values from source B */ + inB1 = pIn2[0]; + + /* Read values from source A */ + inA2 = pIn1[1]; + + /* Add and saturate */ + out1 = __QADD(inA1, inB1); + + /* Read values from source B */ + inB2 = pIn2[1]; + + /* Read values from source A */ + inA1 = pIn1[2]; + + /* Add and saturate */ + out2 = __QADD(inA2, inB2); + + /* Read values from source B */ + inB1 = pIn2[2]; + + /* Store result in destination */ + pOut[0] = out1; + pOut[1] = out2; + + /* Read values from source A */ + inA2 = pIn1[3]; + + /* Read values from source B */ + inB2 = pIn2[3]; + + /* Add and saturate */ + out1 = __QADD(inA1, inB1); + out2 = __QADD(inA2, inB2); + + /* Store result in destination */ + pOut[2] = out1; + pOut[3] = out2; + + /* update pointers to process next sampels */ + pIn1 += 4U; + pIn2 += 4U; + pOut += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the numSamples is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) + B(m,n) */ + /* Add, saturate and then store the results in the destination buffer. */ + inA1 = *pIn1++; + inB1 = *pIn2++; + + inA1 = __QADD(inA1, inB1); + + /* Decrement the loop counter */ + blkCnt--; + + *pOut++ = inA1; + + } + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixAdd group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_f32.c new file mode 100644 index 0000000..9b2f532 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_f32.c @@ -0,0 +1,272 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_cmplx_mult_f32.c + * Description: Floating-point matrix multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup CmplxMatrixMult Complex Matrix Multiplication + * + * Complex Matrix multiplication is only defined if the number of columns of the + * first matrix equals the number of rows of the second matrix. + * Multiplying an M x N matrix with an N x P matrix results + * in an M x P matrix. + * When matrix size checking is enabled, the functions check: (1) that the inner dimensions of + * pSrcA and pSrcB are equal; and (2) that the size of the output + * matrix equals the outer dimensions of pSrcA and pSrcB. + */ + + +/** + * @addtogroup CmplxMatrixMult + * @{ + */ + +/** + * @brief Floating-point Complex matrix multiplication. + * @param[in] *pSrcA points to the first input complex matrix structure + * @param[in] *pSrcB points to the second input complex matrix structure + * @param[out] *pDst points to output complex matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + +arm_status arm_mat_cmplx_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + float32_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + float32_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + float32_t *pInA = pSrcA->pData; /* input data matrix pointer A */ + float32_t *pOut = pDst->pData; /* output data matrix pointer */ + float32_t *px; /* Temporary output data matrix pointer */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + float32_t sumReal1, sumImag1; /* accumulator */ + float32_t a0, b0, c0, d0; + float32_t a1, b1, c1, d1; + float32_t sumReal2, sumImag2; /* accumulator */ + + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + uint16_t col, i = 0U, j, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* Output pointer is set to starting address of the row being processed */ + px = pOut + 2 * i; + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pIn2 = pSrcB->pData; + + j = 0U; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sumReal1 = 0.0f; + sumImag1 = 0.0f; + + sumReal2 = 0.0f; + sumImag2 = 0.0f; + + /* Initiate the pointer pIn1 to point to the starting address of the column being processed */ + pIn1 = pInA; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + colCnt = numColsA >> 2; + + /* matrix multiplication */ + while (colCnt > 0U) + { + + /* Reading real part of complex matrix A */ + a0 = *pIn1; + + /* Reading real part of complex matrix B */ + c0 = *pIn2; + + /* Reading imaginary part of complex matrix A */ + b0 = *(pIn1 + 1U); + + /* Reading imaginary part of complex matrix B */ + d0 = *(pIn2 + 1U); + + sumReal1 += a0 * c0; + sumImag1 += b0 * c0; + + pIn1 += 2U; + pIn2 += 2 * numColsB; + + sumReal2 -= b0 * d0; + sumImag2 += a0 * d0; + + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + + a1 = *pIn1; + c1 = *pIn2; + + b1 = *(pIn1 + 1U); + d1 = *(pIn2 + 1U); + + sumReal1 += a1 * c1; + sumImag1 += b1 * c1; + + pIn1 += 2U; + pIn2 += 2 * numColsB; + + sumReal2 -= b1 * d1; + sumImag2 += a1 * d1; + + a0 = *pIn1; + c0 = *pIn2; + + b0 = *(pIn1 + 1U); + d0 = *(pIn2 + 1U); + + sumReal1 += a0 * c0; + sumImag1 += b0 * c0; + + pIn1 += 2U; + pIn2 += 2 * numColsB; + + sumReal2 -= b0 * d0; + sumImag2 += a0 * d0; + + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + + a1 = *pIn1; + c1 = *pIn2; + + b1 = *(pIn1 + 1U); + d1 = *(pIn2 + 1U); + + sumReal1 += a1 * c1; + sumImag1 += b1 * c1; + + pIn1 += 2U; + pIn2 += 2 * numColsB; + + sumReal2 -= b1 * d1; + sumImag2 += a1 * d1; + + /* Decrement the loop count */ + colCnt--; + } + + /* If the columns of pSrcA is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + colCnt = numColsA % 0x4U; + + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + a1 = *pIn1; + c1 = *pIn2; + + b1 = *(pIn1 + 1U); + d1 = *(pIn2 + 1U); + + sumReal1 += a1 * c1; + sumImag1 += b1 * c1; + + pIn1 += 2U; + pIn2 += 2 * numColsB; + + sumReal2 -= b1 * d1; + sumImag2 += a1 * d1; + + /* Decrement the loop counter */ + colCnt--; + } + + sumReal1 += sumReal2; + sumImag1 += sumImag2; + + /* Store the result in the destination buffer */ + *px++ = sumReal1; + *px++ = sumImag1; + + /* Update the pointer pIn2 to point to the starting address of the next column */ + j++; + pIn2 = pSrcB->pData + 2U * j; + + /* Decrement the column loop counter */ + col--; + + } while (col > 0U); + + /* Update the pointer pInA to point to the starting address of the next row */ + i = i + numColsB; + pInA = pInA + 2 * numColsA; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q15.c new file mode 100644 index 0000000..b1578a5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q15.c @@ -0,0 +1,413 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cmplx_mat_mult_q15.c + * Description: Q15 complex matrix multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup CmplxMatrixMult + * @{ + */ + + +/** + * @brief Q15 Complex matrix multiplication + * @param[in] *pSrcA points to the first input complex matrix structure + * @param[in] *pSrcB points to the second input complex matrix structure + * @param[out] *pDst points to output complex matrix structure + * @param[in] *pScratch points to the array for storing intermediate results + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * \par Conditions for optimum performance + * Input, output and state buffers should be aligned by 32-bit + * + * \par Restrictions + * If the silicon does not support unaligned memory access enable the macro UNALIGNED_SUPPORT_DISABLE + * In this case input, output, scratch buffers should be aligned by 32-bit + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. The inputs to the + * multiplications are in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate + * results are accumulated in a 64-bit accumulator in 34.30 format. This approach + * provides 33 guard bits and there is no risk of overflow. The 34.30 result is then + * truncated to 34.15 format by discarding the low 15 bits and then saturated to + * 1.15 format. + * + * \par + * Refer to arm_mat_mult_fast_q15() for a faster but less precise version of this function. + * + */ + + + + +arm_status arm_mat_cmplx_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst, + q15_t * pScratch) +{ + /* accumulator */ + q15_t *pSrcBT = pScratch; /* input data matrix pointer for transpose */ + q15_t *pInA = pSrcA->pData; /* input data matrix pointer A of Q15 type */ + q15_t *pInB = pSrcB->pData; /* input data matrix pointer B of Q15 type */ + q15_t *px; /* Temporary output data matrix pointer */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + uint16_t numRowsB = pSrcB->numRows; /* number of rows of input matrix A */ + uint16_t col, i = 0U, row = numRowsB, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + q63_t sumReal, sumImag; + +#ifdef UNALIGNED_SUPPORT_DISABLE + q15_t in; /* Temporary variable to hold the input value */ + q15_t a, b, c, d; +#else + q31_t in; /* Temporary variable to hold the input value */ + q31_t prod1, prod2; + q31_t pSourceA, pSourceB; +#endif + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif + { + /* Matrix transpose */ + do + { + /* Apply loop unrolling and exchange the columns with row elements */ + col = numColsB >> 2; + + /* The pointer px is set to starting address of the column being processed */ + px = pSrcBT + i; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (col > 0U) + { +#ifdef UNALIGNED_SUPPORT_DISABLE + /* Read two elements from the row */ + in = *pInB++; + *px = in; + in = *pInB++; + px[1] = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Read two elements from the row */ + in = *pInB++; + *px = in; + in = *pInB++; + px[1] = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Read two elements from the row */ + in = *pInB++; + *px = in; + in = *pInB++; + px[1] = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Read two elements from the row */ + in = *pInB++; + *px = in; + in = *pInB++; + px[1] = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Decrement the column loop counter */ + col--; + } + + /* If the columns of pSrcB is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + col = numColsB % 0x4U; + + while (col > 0U) + { + /* Read two elements from the row */ + in = *pInB++; + *px = in; + in = *pInB++; + px[1] = in; +#else + + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + *__SIMD32(px) = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + *__SIMD32(px) = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + *__SIMD32(px) = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + *__SIMD32(px) = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Decrement the column loop counter */ + col--; + } + + /* If the columns of pSrcB is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + col = numColsB % 0x4U; + + while (col > 0U) + { + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + *__SIMD32(px) = in; +#endif + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB * 2; + + /* Decrement the column loop counter */ + col--; + } + + i = i + 2U; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* Reset the variables for the usage in the following multiplication process */ + row = numRowsA; + i = 0U; + px = pDst->pData; + + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the transposed pSrcB data */ + pInB = pSrcBT; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sumReal = 0; + sumImag = 0; + + /* Apply loop unrolling and compute 2 MACs simultaneously. */ + colCnt = numColsA >> 1; + + /* Initiate the pointer pIn1 to point to the starting address of the column being processed */ + pInA = pSrcA->pData + i * 2; + + + /* matrix multiplication */ + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + +#ifdef UNALIGNED_SUPPORT_DISABLE + + /* read real and imag values from pSrcA buffer */ + a = *pInA; + b = *(pInA + 1U); + /* read real and imag values from pSrcB buffer */ + c = *pInB; + d = *(pInB + 1U); + + /* Multiply and Accumlates */ + sumReal += (q31_t) a *c; + sumImag += (q31_t) a *d; + sumReal -= (q31_t) b *d; + sumImag += (q31_t) b *c; + + /* read next real and imag values from pSrcA buffer */ + a = *(pInA + 2U); + b = *(pInA + 3U); + /* read next real and imag values from pSrcB buffer */ + c = *(pInB + 2U); + d = *(pInB + 3U); + + /* update pointer */ + pInA += 4U; + + /* Multiply and Accumlates */ + sumReal += (q31_t) a *c; + sumImag += (q31_t) a *d; + sumReal -= (q31_t) b *d; + sumImag += (q31_t) b *c; + /* update pointer */ + pInB += 4U; +#else + /* read real and imag values from pSrcA and pSrcB buffer */ + pSourceA = *__SIMD32(pInA)++; + pSourceB = *__SIMD32(pInB)++; + + /* Multiply and Accumlates */ +#ifdef ARM_MATH_BIG_ENDIAN + prod1 = -__SMUSD(pSourceA, pSourceB); +#else + prod1 = __SMUSD(pSourceA, pSourceB); +#endif + prod2 = __SMUADX(pSourceA, pSourceB); + sumReal += (q63_t) prod1; + sumImag += (q63_t) prod2; + + /* read real and imag values from pSrcA and pSrcB buffer */ + pSourceA = *__SIMD32(pInA)++; + pSourceB = *__SIMD32(pInB)++; + + /* Multiply and Accumlates */ +#ifdef ARM_MATH_BIG_ENDIAN + prod1 = -__SMUSD(pSourceA, pSourceB); +#else + prod1 = __SMUSD(pSourceA, pSourceB); +#endif + prod2 = __SMUADX(pSourceA, pSourceB); + sumReal += (q63_t) prod1; + sumImag += (q63_t) prod2; + +#endif /* #ifdef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the loop counter */ + colCnt--; + } + + /* process odd column samples */ + if ((numColsA & 0x1U) > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + +#ifdef UNALIGNED_SUPPORT_DISABLE + + /* read real and imag values from pSrcA and pSrcB buffer */ + a = *pInA++; + b = *pInA++; + c = *pInB++; + d = *pInB++; + + /* Multiply and Accumlates */ + sumReal += (q31_t) a *c; + sumImag += (q31_t) a *d; + sumReal -= (q31_t) b *d; + sumImag += (q31_t) b *c; + +#else + /* read real and imag values from pSrcA and pSrcB buffer */ + pSourceA = *__SIMD32(pInA)++; + pSourceB = *__SIMD32(pInB)++; + + /* Multiply and Accumlates */ +#ifdef ARM_MATH_BIG_ENDIAN + prod1 = -__SMUSD(pSourceA, pSourceB); +#else + prod1 = __SMUSD(pSourceA, pSourceB); +#endif + prod2 = __SMUADX(pSourceA, pSourceB); + sumReal += (q63_t) prod1; + sumImag += (q63_t) prod2; + +#endif /* #ifdef UNALIGNED_SUPPORT_DISABLE */ + + } + + /* Saturate and store the result in the destination buffer */ + + *px++ = (q15_t) (__SSAT(sumReal >> 15, 16)); + *px++ = (q15_t) (__SSAT(sumImag >> 15, 16)); + + /* Decrement the column loop counter */ + col--; + + } while (col > 0U); + + i = i + numColsA; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q31.c new file mode 100644 index 0000000..a05440e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_cmplx_mult_q31.c @@ -0,0 +1,282 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_cmplx_mult_q31.c + * Description: Floating-point matrix multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup CmplxMatrixMult + * @{ + */ + +/** + * @brief Q31 Complex matrix multiplication + * @param[in] *pSrcA points to the first input complex matrix structure + * @param[in] *pSrcB points to the second input complex matrix structure + * @param[out] *pDst points to output complex matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate + * multiplication results but provides only a single guard bit. There is no saturation + * on intermediate additions. Thus, if the accumulator overflows it wraps around and + * distorts the result. The input signals should be scaled down to avoid intermediate + * overflows. The input is thus scaled down by log2(numColsA) bits + * to avoid overflows, as a total of numColsA additions are performed internally. + * The 2.62 accumulator is right shifted by 31 bits and saturated to 1.31 format to yield the final result. + * + * + */ + +arm_status arm_mat_cmplx_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + q31_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + q31_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + q31_t *pInA = pSrcA->pData; /* input data matrix pointer A */ + q31_t *pOut = pDst->pData; /* output data matrix pointer */ + q31_t *px; /* Temporary output data matrix pointer */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + q63_t sumReal1, sumImag1; /* accumulator */ + q31_t a0, b0, c0, d0; + q31_t a1, b1, c1, d1; + + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + uint16_t col, i = 0U, j, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* Output pointer is set to starting address of the row being processed */ + px = pOut + 2 * i; + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pIn2 = pSrcB->pData; + + j = 0U; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sumReal1 = 0.0; + sumImag1 = 0.0; + + /* Initiate the pointer pIn1 to point to the starting address of the column being processed */ + pIn1 = pInA; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + colCnt = numColsA >> 2; + + /* matrix multiplication */ + while (colCnt > 0U) + { + + /* Reading real part of complex matrix A */ + a0 = *pIn1; + + /* Reading real part of complex matrix B */ + c0 = *pIn2; + + /* Reading imaginary part of complex matrix A */ + b0 = *(pIn1 + 1U); + + /* Reading imaginary part of complex matrix B */ + d0 = *(pIn2 + 1U); + + /* Multiply and Accumlates */ + sumReal1 += (q63_t) a0 *c0; + sumImag1 += (q63_t) b0 *c0; + + /* update pointers */ + pIn1 += 2U; + pIn2 += 2 * numColsB; + + /* Multiply and Accumlates */ + sumReal1 -= (q63_t) b0 *d0; + sumImag1 += (q63_t) a0 *d0; + + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + + /* read real and imag values from pSrcA and pSrcB buffer */ + a1 = *pIn1; + c1 = *pIn2; + b1 = *(pIn1 + 1U); + d1 = *(pIn2 + 1U); + + /* Multiply and Accumlates */ + sumReal1 += (q63_t) a1 *c1; + sumImag1 += (q63_t) b1 *c1; + + /* update pointers */ + pIn1 += 2U; + pIn2 += 2 * numColsB; + + /* Multiply and Accumlates */ + sumReal1 -= (q63_t) b1 *d1; + sumImag1 += (q63_t) a1 *d1; + + a0 = *pIn1; + c0 = *pIn2; + + b0 = *(pIn1 + 1U); + d0 = *(pIn2 + 1U); + + /* Multiply and Accumlates */ + sumReal1 += (q63_t) a0 *c0; + sumImag1 += (q63_t) b0 *c0; + + /* update pointers */ + pIn1 += 2U; + pIn2 += 2 * numColsB; + + /* Multiply and Accumlates */ + sumReal1 -= (q63_t) b0 *d0; + sumImag1 += (q63_t) a0 *d0; + + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + + a1 = *pIn1; + c1 = *pIn2; + + b1 = *(pIn1 + 1U); + d1 = *(pIn2 + 1U); + + /* Multiply and Accumlates */ + sumReal1 += (q63_t) a1 *c1; + sumImag1 += (q63_t) b1 *c1; + + /* update pointers */ + pIn1 += 2U; + pIn2 += 2 * numColsB; + + /* Multiply and Accumlates */ + sumReal1 -= (q63_t) b1 *d1; + sumImag1 += (q63_t) a1 *d1; + + /* Decrement the loop count */ + colCnt--; + } + + /* If the columns of pSrcA is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + colCnt = numColsA % 0x4U; + + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + a1 = *pIn1; + c1 = *pIn2; + + b1 = *(pIn1 + 1U); + d1 = *(pIn2 + 1U); + + /* Multiply and Accumlates */ + sumReal1 += (q63_t) a1 *c1; + sumImag1 += (q63_t) b1 *c1; + + /* update pointers */ + pIn1 += 2U; + pIn2 += 2 * numColsB; + + /* Multiply and Accumlates */ + sumReal1 -= (q63_t) b1 *d1; + sumImag1 += (q63_t) a1 *d1; + + /* Decrement the loop counter */ + colCnt--; + } + + /* Store the result in the destination buffer */ + *px++ = (q31_t) clip_q63_to_q31(sumReal1 >> 31); + *px++ = (q31_t) clip_q63_to_q31(sumImag1 >> 31); + + /* Update the pointer pIn2 to point to the starting address of the next column */ + j++; + pIn2 = pSrcB->pData + 2U * j; + + /* Decrement the column loop counter */ + col--; + + } while (col > 0U); + + /* Update the pointer pInA to point to the starting address of the next row */ + i = i + numColsB; + pInA = pInA + 2 * numColsA; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_f32.c new file mode 100644 index 0000000..34399c7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_f32.c @@ -0,0 +1,76 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_init_f32.c + * Description: Floating-point matrix initialization + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixInit Matrix Initialization + * + * Initializes the underlying matrix data structure. + * The functions set the numRows, + * numCols, and pData fields + * of the matrix data structure. + */ + +/** + * @addtogroup MatrixInit + * @{ + */ + +/** + * @brief Floating-point matrix initialization. + * @param[in,out] *S points to an instance of the floating-point matrix structure. + * @param[in] nRows number of rows in the matrix. + * @param[in] nColumns number of columns in the matrix. + * @param[in] *pData points to the matrix data array. + * @return none + */ + +void arm_mat_init_f32( + arm_matrix_instance_f32 * S, + uint16_t nRows, + uint16_t nColumns, + float32_t * pData) +{ + /* Assign Number of Rows */ + S->numRows = nRows; + + /* Assign Number of Columns */ + S->numCols = nColumns; + + /* Assign Data pointer */ + S->pData = pData; +} + +/** + * @} end of MatrixInit group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q15.c new file mode 100644 index 0000000..6be7387 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q15.c @@ -0,0 +1,67 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_init_q15.c + * Description: Q15 matrix initialization + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixInit + * @{ + */ + + /** + * @brief Q15 matrix initialization. + * @param[in,out] *S points to an instance of the floating-point matrix structure. + * @param[in] nRows number of rows in the matrix. + * @param[in] nColumns number of columns in the matrix. + * @param[in] *pData points to the matrix data array. + * @return none + */ + +void arm_mat_init_q15( + arm_matrix_instance_q15 * S, + uint16_t nRows, + uint16_t nColumns, + q15_t * pData) +{ + /* Assign Number of Rows */ + S->numRows = nRows; + + /* Assign Number of Columns */ + S->numCols = nColumns; + + /* Assign Data pointer */ + S->pData = pData; +} + +/** + * @} end of MatrixInit group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q31.c new file mode 100644 index 0000000..c8a0839 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_init_q31.c @@ -0,0 +1,72 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_init_q31.c + * Description: Q31 matrix initialization + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixInit Matrix Initialization + * + */ + +/** + * @addtogroup MatrixInit + * @{ + */ + + /** + * @brief Q31 matrix initialization. + * @param[in,out] *S points to an instance of the floating-point matrix structure. + * @param[in] nRows number of rows in the matrix. + * @param[in] nColumns number of columns in the matrix. + * @param[in] *pData points to the matrix data array. + * @return none + */ + +void arm_mat_init_q31( + arm_matrix_instance_q31 * S, + uint16_t nRows, + uint16_t nColumns, + q31_t * pData) +{ + /* Assign Number of Rows */ + S->numRows = nRows; + + /* Assign Number of Columns */ + S->numCols = nColumns; + + /* Assign Data pointer */ + S->pData = pData; +} + +/** + * @} end of MatrixInit group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f32.c new file mode 100644 index 0000000..c0f8fc4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f32.c @@ -0,0 +1,691 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_inverse_f32.c + * Description: Floating-point matrix inverse + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixInv Matrix Inverse + * + * Computes the inverse of a matrix. + * + * The inverse is defined only if the input matrix is square and non-singular (the determinant + * is non-zero). The function checks that the input and output matrices are square and of the + * same size. + * + * Matrix inversion is numerically sensitive and the CMSIS DSP library only supports matrix + * inversion of floating-point matrices. + * + * \par Algorithm + * The Gauss-Jordan method is used to find the inverse. + * The algorithm performs a sequence of elementary row-operations until it + * reduces the input matrix to an identity matrix. Applying the same sequence + * of elementary row-operations to an identity matrix yields the inverse matrix. + * If the input matrix is singular, then the algorithm terminates and returns error status + * ARM_MATH_SINGULAR. + * \image html MatrixInverse.gif "Matrix Inverse of a 3 x 3 matrix using Gauss-Jordan Method" + */ + +/** + * @addtogroup MatrixInv + * @{ + */ + +/** + * @brief Floating-point matrix inverse. + * @param[in] *pSrc points to input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns + * ARM_MATH_SIZE_MISMATCH if the input matrix is not square or if the size + * of the output matrix does not match the size of the input matrix. + * If the input matrix is found to be singular (non-invertible), then the function returns + * ARM_MATH_SINGULAR. Otherwise, the function returns ARM_MATH_SUCCESS. + */ + +arm_status arm_mat_inverse_f32( + const arm_matrix_instance_f32 * pSrc, + arm_matrix_instance_f32 * pDst) +{ + float32_t *pIn = pSrc->pData; /* input data matrix pointer */ + float32_t *pOut = pDst->pData; /* output data matrix pointer */ + float32_t *pInT1, *pInT2; /* Temporary input data matrix pointer */ + float32_t *pOutT1, *pOutT2; /* Temporary output data matrix pointer */ + float32_t *pPivotRowIn, *pPRT_in, *pPivotRowDst, *pPRT_pDst; /* Temporary input and output data matrix pointer */ + uint32_t numRows = pSrc->numRows; /* Number of rows in the matrix */ + uint32_t numCols = pSrc->numCols; /* Number of Cols in the matrix */ + +#if defined (ARM_MATH_DSP) + float32_t maxC; /* maximum value in the column */ + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t Xchg, in = 0.0f, in1; /* Temporary input values */ + uint32_t i, rowCnt, flag = 0U, j, loopCnt, k, l; /* loop counters */ + arm_status status; /* status of matrix inverse */ + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pSrc->numCols) || (pDst->numRows != pDst->numCols) + || (pSrc->numRows != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + + /*-------------------------------------------------------------------------------------------------------------- + * Matrix Inverse can be solved using elementary row operations. + * + * Gauss-Jordan Method: + * + * 1. First combine the identity matrix and the input matrix separated by a bar to form an + * augmented matrix as follows: + * _ _ _ _ + * | a11 a12 | 1 0 | | X11 X12 | + * | | | = | | + * |_ a21 a22 | 0 1 _| |_ X21 X21 _| + * + * 2. In our implementation, pDst Matrix is used as identity matrix. + * + * 3. Begin with the first row. Let i = 1. + * + * 4. Check to see if the pivot for column i is the greatest of the column. + * The pivot is the element of the main diagonal that is on the current row. + * For instance, if working with row i, then the pivot element is aii. + * If the pivot is not the most significant of the columns, exchange that row with a row + * below it that does contain the most significant value in column i. If the most + * significant value of the column is zero, then an inverse to that matrix does not exist. + * The most significant value of the column is the absolute maximum. + * + * 5. Divide every element of row i by the pivot. + * + * 6. For every row below and row i, replace that row with the sum of that row and + * a multiple of row i so that each new element in column i below row i is zero. + * + * 7. Move to the next row and column and repeat steps 2 through 5 until you have zeros + * for every element below and above the main diagonal. + * + * 8. Now an identical matrix is formed to the left of the bar(input matrix, pSrc). + * Therefore, the matrix to the right of the bar is our solution(pDst matrix, pDst). + *----------------------------------------------------------------------------------------------------------------*/ + + /* Working pointer for destination matrix */ + pOutT1 = pOut; + + /* Loop over the number of rows */ + rowCnt = numRows; + + /* Making the destination matrix as identity matrix */ + while (rowCnt > 0U) + { + /* Writing all zeroes in lower triangle of the destination matrix */ + j = numRows - rowCnt; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Writing all ones in the diagonal of the destination matrix */ + *pOutT1++ = 1.0f; + + /* Writing all zeroes in upper triangle of the destination matrix */ + j = rowCnt - 1U; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Decrement the loop counter */ + rowCnt--; + } + + /* Loop over the number of columns of the input matrix. + All the elements in each column are processed by the row operations */ + loopCnt = numCols; + + /* Index modifier to navigate through the columns */ + l = 0U; + + while (loopCnt > 0U) + { + /* Check if the pivot element is zero.. + * If it is zero then interchange the row with non zero row below. + * If there is no non zero element to replace in the rows below, + * then the matrix is Singular. */ + + /* Working pointer for the input matrix that points + * to the pivot element of the particular row */ + pInT1 = pIn + (l * numCols); + + /* Working pointer for the destination matrix that points + * to the pivot element of the particular row */ + pOutT1 = pOut + (l * numCols); + + /* Temporary variable to hold the pivot value */ + in = *pInT1; + + /* Grab the most significant value from column l */ + maxC = 0; + for (i = l; i < numRows; i++) + { + maxC = *pInT1 > 0 ? (*pInT1 > maxC ? *pInT1 : maxC) : (-*pInT1 > maxC ? -*pInT1 : maxC); + pInT1 += numCols; + } + + /* Update the status if the matrix is singular */ + if (maxC == 0.0f) + { + return ARM_MATH_SINGULAR; + } + + /* Restore pInT1 */ + pInT1 = pIn; + + /* Destination pointer modifier */ + k = 1U; + + /* Check if the pivot element is the most significant of the column */ + if ( (in > 0.0f ? in : -in) != maxC) + { + /* Loop over the number rows present below */ + i = numRows - (l + 1U); + + while (i > 0U) + { + /* Update the input and destination pointers */ + pInT2 = pInT1 + (numCols * l); + pOutT2 = pOutT1 + (numCols * k); + + /* Look for the most significant element to + * replace in the rows below */ + if ((*pInT2 > 0.0f ? *pInT2: -*pInT2) == maxC) + { + /* Loop over number of columns + * to the right of the pilot element */ + j = numCols - l; + + while (j > 0U) + { + /* Exchange the row elements of the input matrix */ + Xchg = *pInT2; + *pInT2++ = *pInT1; + *pInT1++ = Xchg; + + /* Decrement the loop counter */ + j--; + } + + /* Loop over number of columns of the destination matrix */ + j = numCols; + + while (j > 0U) + { + /* Exchange the row elements of the destination matrix */ + Xchg = *pOutT2; + *pOutT2++ = *pOutT1; + *pOutT1++ = Xchg; + + /* Decrement the loop counter */ + j--; + } + + /* Flag to indicate whether exchange is done or not */ + flag = 1U; + + /* Break after exchange is done */ + break; + } + + /* Update the destination pointer modifier */ + k++; + + /* Decrement the loop counter */ + i--; + } + } + + /* Update the status if the matrix is singular */ + if ((flag != 1U) && (in == 0.0f)) + { + return ARM_MATH_SINGULAR; + } + + /* Points to the pivot row of input and destination matrices */ + pPivotRowIn = pIn + (l * numCols); + pPivotRowDst = pOut + (l * numCols); + + /* Temporary pointers to the pivot row pointers */ + pInT1 = pPivotRowIn; + pInT2 = pPivotRowDst; + + /* Pivot element of the row */ + in = *pPivotRowIn; + + /* Loop over number of columns + * to the right of the pilot element */ + j = (numCols - l); + + while (j > 0U) + { + /* Divide each element of the row of the input matrix + * by the pivot element */ + in1 = *pInT1; + *pInT1++ = in1 / in; + + /* Decrement the loop counter */ + j--; + } + + /* Loop over number of columns of the destination matrix */ + j = numCols; + + while (j > 0U) + { + /* Divide each element of the row of the destination matrix + * by the pivot element */ + in1 = *pInT2; + *pInT2++ = in1 / in; + + /* Decrement the loop counter */ + j--; + } + + /* Replace the rows with the sum of that row and a multiple of row i + * so that each new element in column i above row i is zero.*/ + + /* Temporary pointers for input and destination matrices */ + pInT1 = pIn; + pInT2 = pOut; + + /* index used to check for pivot element */ + i = 0U; + + /* Loop over number of rows */ + /* to be replaced by the sum of that row and a multiple of row i */ + k = numRows; + + while (k > 0U) + { + /* Check for the pivot element */ + if (i == l) + { + /* If the processing element is the pivot element, + only the columns to the right are to be processed */ + pInT1 += numCols - l; + + pInT2 += numCols; + } + else + { + /* Element of the reference row */ + in = *pInT1; + + /* Working pointers for input and destination pivot rows */ + pPRT_in = pPivotRowIn; + pPRT_pDst = pPivotRowDst; + + /* Loop over the number of columns to the right of the pivot element, + to replace the elements in the input matrix */ + j = (numCols - l); + + while (j > 0U) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + in1 = *pInT1; + *pInT1++ = in1 - (in * *pPRT_in++); + + /* Decrement the loop counter */ + j--; + } + + /* Loop over the number of columns to + replace the elements in the destination matrix */ + j = numCols; + + while (j > 0U) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + in1 = *pInT2; + *pInT2++ = in1 - (in * *pPRT_pDst++); + + /* Decrement the loop counter */ + j--; + } + + } + + /* Increment the temporary input pointer */ + pInT1 = pInT1 + l; + + /* Decrement the loop counter */ + k--; + + /* Increment the pivot index */ + i++; + } + + /* Increment the input pointer */ + pIn++; + + /* Decrement the loop counter */ + loopCnt--; + + /* Increment the index modifier */ + l++; + } + + +#else + + /* Run the below code for Cortex-M0 */ + + float32_t Xchg, in = 0.0f; /* Temporary input values */ + uint32_t i, rowCnt, flag = 0U, j, loopCnt, k, l; /* loop counters */ + arm_status status; /* status of matrix inverse */ + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pSrc->numCols) || (pDst->numRows != pDst->numCols) + || (pSrc->numRows != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + { + + /*-------------------------------------------------------------------------------------------------------------- + * Matrix Inverse can be solved using elementary row operations. + * + * Gauss-Jordan Method: + * + * 1. First combine the identity matrix and the input matrix separated by a bar to form an + * augmented matrix as follows: + * _ _ _ _ _ _ _ _ + * | | a11 a12 | | | 1 0 | | | X11 X12 | + * | | | | | | | = | | + * |_ |_ a21 a22 _| | |_0 1 _| _| |_ X21 X21 _| + * + * 2. In our implementation, pDst Matrix is used as identity matrix. + * + * 3. Begin with the first row. Let i = 1. + * + * 4. Check to see if the pivot for row i is zero. + * The pivot is the element of the main diagonal that is on the current row. + * For instance, if working with row i, then the pivot element is aii. + * If the pivot is zero, exchange that row with a row below it that does not + * contain a zero in column i. If this is not possible, then an inverse + * to that matrix does not exist. + * + * 5. Divide every element of row i by the pivot. + * + * 6. For every row below and row i, replace that row with the sum of that row and + * a multiple of row i so that each new element in column i below row i is zero. + * + * 7. Move to the next row and column and repeat steps 2 through 5 until you have zeros + * for every element below and above the main diagonal. + * + * 8. Now an identical matrix is formed to the left of the bar(input matrix, src). + * Therefore, the matrix to the right of the bar is our solution(dst matrix, dst). + *----------------------------------------------------------------------------------------------------------------*/ + + /* Working pointer for destination matrix */ + pOutT1 = pOut; + + /* Loop over the number of rows */ + rowCnt = numRows; + + /* Making the destination matrix as identity matrix */ + while (rowCnt > 0U) + { + /* Writing all zeroes in lower triangle of the destination matrix */ + j = numRows - rowCnt; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Writing all ones in the diagonal of the destination matrix */ + *pOutT1++ = 1.0f; + + /* Writing all zeroes in upper triangle of the destination matrix */ + j = rowCnt - 1U; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Decrement the loop counter */ + rowCnt--; + } + + /* Loop over the number of columns of the input matrix. + All the elements in each column are processed by the row operations */ + loopCnt = numCols; + + /* Index modifier to navigate through the columns */ + l = 0U; + //for(loopCnt = 0U; loopCnt < numCols; loopCnt++) + while (loopCnt > 0U) + { + /* Check if the pivot element is zero.. + * If it is zero then interchange the row with non zero row below. + * If there is no non zero element to replace in the rows below, + * then the matrix is Singular. */ + + /* Working pointer for the input matrix that points + * to the pivot element of the particular row */ + pInT1 = pIn + (l * numCols); + + /* Working pointer for the destination matrix that points + * to the pivot element of the particular row */ + pOutT1 = pOut + (l * numCols); + + /* Temporary variable to hold the pivot value */ + in = *pInT1; + + /* Destination pointer modifier */ + k = 1U; + + /* Check if the pivot element is zero */ + if (*pInT1 == 0.0f) + { + /* Loop over the number rows present below */ + for (i = (l + 1U); i < numRows; i++) + { + /* Update the input and destination pointers */ + pInT2 = pInT1 + (numCols * l); + pOutT2 = pOutT1 + (numCols * k); + + /* Check if there is a non zero pivot element to + * replace in the rows below */ + if (*pInT2 != 0.0f) + { + /* Loop over number of columns + * to the right of the pilot element */ + for (j = 0U; j < (numCols - l); j++) + { + /* Exchange the row elements of the input matrix */ + Xchg = *pInT2; + *pInT2++ = *pInT1; + *pInT1++ = Xchg; + } + + for (j = 0U; j < numCols; j++) + { + Xchg = *pOutT2; + *pOutT2++ = *pOutT1; + *pOutT1++ = Xchg; + } + + /* Flag to indicate whether exchange is done or not */ + flag = 1U; + + /* Break after exchange is done */ + break; + } + + /* Update the destination pointer modifier */ + k++; + } + } + + /* Update the status if the matrix is singular */ + if ((flag != 1U) && (in == 0.0f)) + { + return ARM_MATH_SINGULAR; + } + + /* Points to the pivot row of input and destination matrices */ + pPivotRowIn = pIn + (l * numCols); + pPivotRowDst = pOut + (l * numCols); + + /* Temporary pointers to the pivot row pointers */ + pInT1 = pPivotRowIn; + pOutT1 = pPivotRowDst; + + /* Pivot element of the row */ + in = *(pIn + (l * numCols)); + + /* Loop over number of columns + * to the right of the pilot element */ + for (j = 0U; j < (numCols - l); j++) + { + /* Divide each element of the row of the input matrix + * by the pivot element */ + *pInT1 = *pInT1 / in; + pInT1++; + } + for (j = 0U; j < numCols; j++) + { + /* Divide each element of the row of the destination matrix + * by the pivot element */ + *pOutT1 = *pOutT1 / in; + pOutT1++; + } + + /* Replace the rows with the sum of that row and a multiple of row i + * so that each new element in column i above row i is zero.*/ + + /* Temporary pointers for input and destination matrices */ + pInT1 = pIn; + pOutT1 = pOut; + + for (i = 0U; i < numRows; i++) + { + /* Check for the pivot element */ + if (i == l) + { + /* If the processing element is the pivot element, + only the columns to the right are to be processed */ + pInT1 += numCols - l; + pOutT1 += numCols; + } + else + { + /* Element of the reference row */ + in = *pInT1; + + /* Working pointers for input and destination pivot rows */ + pPRT_in = pPivotRowIn; + pPRT_pDst = pPivotRowDst; + + /* Loop over the number of columns to the right of the pivot element, + to replace the elements in the input matrix */ + for (j = 0U; j < (numCols - l); j++) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + *pInT1 = *pInT1 - (in * *pPRT_in++); + pInT1++; + } + /* Loop over the number of columns to + replace the elements in the destination matrix */ + for (j = 0U; j < numCols; j++) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + *pOutT1 = *pOutT1 - (in * *pPRT_pDst++); + pOutT1++; + } + + } + /* Increment the temporary input pointer */ + pInT1 = pInT1 + l; + } + /* Increment the input pointer */ + pIn++; + + /* Decrement the loop counter */ + loopCnt--; + /* Increment the index modifier */ + l++; + } + + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + if ((flag != 1U) && (in == 0.0f)) + { + pIn = pSrc->pData; + for (i = 0; i < numRows * numCols; i++) + { + if (pIn[i] != 0.0f) + break; + } + + if (i == numRows * numCols) + status = ARM_MATH_SINGULAR; + } + } + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixInv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f64.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f64.c new file mode 100644 index 0000000..441376b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_inverse_f64.c @@ -0,0 +1,691 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_inverse_f64.c + * Description: Floating-point matrix inverse + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixInv Matrix Inverse + * + * Computes the inverse of a matrix. + * + * The inverse is defined only if the input matrix is square and non-singular (the determinant + * is non-zero). The function checks that the input and output matrices are square and of the + * same size. + * + * Matrix inversion is numerically sensitive and the CMSIS DSP library only supports matrix + * inversion of floating-point matrices. + * + * \par Algorithm + * The Gauss-Jordan method is used to find the inverse. + * The algorithm performs a sequence of elementary row-operations until it + * reduces the input matrix to an identity matrix. Applying the same sequence + * of elementary row-operations to an identity matrix yields the inverse matrix. + * If the input matrix is singular, then the algorithm terminates and returns error status + * ARM_MATH_SINGULAR. + * \image html MatrixInverse.gif "Matrix Inverse of a 3 x 3 matrix using Gauss-Jordan Method" + */ + +/** + * @addtogroup MatrixInv + * @{ + */ + +/** + * @brief Floating-point matrix inverse. + * @param[in] *pSrc points to input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns + * ARM_MATH_SIZE_MISMATCH if the input matrix is not square or if the size + * of the output matrix does not match the size of the input matrix. + * If the input matrix is found to be singular (non-invertible), then the function returns + * ARM_MATH_SINGULAR. Otherwise, the function returns ARM_MATH_SUCCESS. + */ + +arm_status arm_mat_inverse_f64( + const arm_matrix_instance_f64 * pSrc, + arm_matrix_instance_f64 * pDst) +{ + float64_t *pIn = pSrc->pData; /* input data matrix pointer */ + float64_t *pOut = pDst->pData; /* output data matrix pointer */ + float64_t *pInT1, *pInT2; /* Temporary input data matrix pointer */ + float64_t *pOutT1, *pOutT2; /* Temporary output data matrix pointer */ + float64_t *pPivotRowIn, *pPRT_in, *pPivotRowDst, *pPRT_pDst; /* Temporary input and output data matrix pointer */ + uint32_t numRows = pSrc->numRows; /* Number of rows in the matrix */ + uint32_t numCols = pSrc->numCols; /* Number of Cols in the matrix */ + +#if defined (ARM_MATH_DSP) + float64_t maxC; /* maximum value in the column */ + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float64_t Xchg, in = 0.0f, in1; /* Temporary input values */ + uint32_t i, rowCnt, flag = 0U, j, loopCnt, k, l; /* loop counters */ + arm_status status; /* status of matrix inverse */ + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pSrc->numCols) || (pDst->numRows != pDst->numCols) + || (pSrc->numRows != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + + /*-------------------------------------------------------------------------------------------------------------- + * Matrix Inverse can be solved using elementary row operations. + * + * Gauss-Jordan Method: + * + * 1. First combine the identity matrix and the input matrix separated by a bar to form an + * augmented matrix as follows: + * _ _ _ _ + * | a11 a12 | 1 0 | | X11 X12 | + * | | | = | | + * |_ a21 a22 | 0 1 _| |_ X21 X21 _| + * + * 2. In our implementation, pDst Matrix is used as identity matrix. + * + * 3. Begin with the first row. Let i = 1. + * + * 4. Check to see if the pivot for column i is the greatest of the column. + * The pivot is the element of the main diagonal that is on the current row. + * For instance, if working with row i, then the pivot element is aii. + * If the pivot is not the most significant of the columns, exchange that row with a row + * below it that does contain the most significant value in column i. If the most + * significant value of the column is zero, then an inverse to that matrix does not exist. + * The most significant value of the column is the absolute maximum. + * + * 5. Divide every element of row i by the pivot. + * + * 6. For every row below and row i, replace that row with the sum of that row and + * a multiple of row i so that each new element in column i below row i is zero. + * + * 7. Move to the next row and column and repeat steps 2 through 5 until you have zeros + * for every element below and above the main diagonal. + * + * 8. Now an identical matrix is formed to the left of the bar(input matrix, pSrc). + * Therefore, the matrix to the right of the bar is our solution(pDst matrix, pDst). + *----------------------------------------------------------------------------------------------------------------*/ + + /* Working pointer for destination matrix */ + pOutT1 = pOut; + + /* Loop over the number of rows */ + rowCnt = numRows; + + /* Making the destination matrix as identity matrix */ + while (rowCnt > 0U) + { + /* Writing all zeroes in lower triangle of the destination matrix */ + j = numRows - rowCnt; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Writing all ones in the diagonal of the destination matrix */ + *pOutT1++ = 1.0f; + + /* Writing all zeroes in upper triangle of the destination matrix */ + j = rowCnt - 1U; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Decrement the loop counter */ + rowCnt--; + } + + /* Loop over the number of columns of the input matrix. + All the elements in each column are processed by the row operations */ + loopCnt = numCols; + + /* Index modifier to navigate through the columns */ + l = 0U; + + while (loopCnt > 0U) + { + /* Check if the pivot element is zero.. + * If it is zero then interchange the row with non zero row below. + * If there is no non zero element to replace in the rows below, + * then the matrix is Singular. */ + + /* Working pointer for the input matrix that points + * to the pivot element of the particular row */ + pInT1 = pIn + (l * numCols); + + /* Working pointer for the destination matrix that points + * to the pivot element of the particular row */ + pOutT1 = pOut + (l * numCols); + + /* Temporary variable to hold the pivot value */ + in = *pInT1; + + /* Grab the most significant value from column l */ + maxC = 0; + for (i = l; i < numRows; i++) + { + maxC = *pInT1 > 0 ? (*pInT1 > maxC ? *pInT1 : maxC) : (-*pInT1 > maxC ? -*pInT1 : maxC); + pInT1 += numCols; + } + + /* Update the status if the matrix is singular */ + if (maxC == 0.0f) + { + return ARM_MATH_SINGULAR; + } + + /* Restore pInT1 */ + pInT1 = pIn; + + /* Destination pointer modifier */ + k = 1U; + + /* Check if the pivot element is the most significant of the column */ + if ( (in > 0.0f ? in : -in) != maxC) + { + /* Loop over the number rows present below */ + i = numRows - (l + 1U); + + while (i > 0U) + { + /* Update the input and destination pointers */ + pInT2 = pInT1 + (numCols * l); + pOutT2 = pOutT1 + (numCols * k); + + /* Look for the most significant element to + * replace in the rows below */ + if ((*pInT2 > 0.0f ? *pInT2: -*pInT2) == maxC) + { + /* Loop over number of columns + * to the right of the pilot element */ + j = numCols - l; + + while (j > 0U) + { + /* Exchange the row elements of the input matrix */ + Xchg = *pInT2; + *pInT2++ = *pInT1; + *pInT1++ = Xchg; + + /* Decrement the loop counter */ + j--; + } + + /* Loop over number of columns of the destination matrix */ + j = numCols; + + while (j > 0U) + { + /* Exchange the row elements of the destination matrix */ + Xchg = *pOutT2; + *pOutT2++ = *pOutT1; + *pOutT1++ = Xchg; + + /* Decrement the loop counter */ + j--; + } + + /* Flag to indicate whether exchange is done or not */ + flag = 1U; + + /* Break after exchange is done */ + break; + } + + /* Update the destination pointer modifier */ + k++; + + /* Decrement the loop counter */ + i--; + } + } + + /* Update the status if the matrix is singular */ + if ((flag != 1U) && (in == 0.0f)) + { + return ARM_MATH_SINGULAR; + } + + /* Points to the pivot row of input and destination matrices */ + pPivotRowIn = pIn + (l * numCols); + pPivotRowDst = pOut + (l * numCols); + + /* Temporary pointers to the pivot row pointers */ + pInT1 = pPivotRowIn; + pInT2 = pPivotRowDst; + + /* Pivot element of the row */ + in = *pPivotRowIn; + + /* Loop over number of columns + * to the right of the pilot element */ + j = (numCols - l); + + while (j > 0U) + { + /* Divide each element of the row of the input matrix + * by the pivot element */ + in1 = *pInT1; + *pInT1++ = in1 / in; + + /* Decrement the loop counter */ + j--; + } + + /* Loop over number of columns of the destination matrix */ + j = numCols; + + while (j > 0U) + { + /* Divide each element of the row of the destination matrix + * by the pivot element */ + in1 = *pInT2; + *pInT2++ = in1 / in; + + /* Decrement the loop counter */ + j--; + } + + /* Replace the rows with the sum of that row and a multiple of row i + * so that each new element in column i above row i is zero.*/ + + /* Temporary pointers for input and destination matrices */ + pInT1 = pIn; + pInT2 = pOut; + + /* index used to check for pivot element */ + i = 0U; + + /* Loop over number of rows */ + /* to be replaced by the sum of that row and a multiple of row i */ + k = numRows; + + while (k > 0U) + { + /* Check for the pivot element */ + if (i == l) + { + /* If the processing element is the pivot element, + only the columns to the right are to be processed */ + pInT1 += numCols - l; + + pInT2 += numCols; + } + else + { + /* Element of the reference row */ + in = *pInT1; + + /* Working pointers for input and destination pivot rows */ + pPRT_in = pPivotRowIn; + pPRT_pDst = pPivotRowDst; + + /* Loop over the number of columns to the right of the pivot element, + to replace the elements in the input matrix */ + j = (numCols - l); + + while (j > 0U) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + in1 = *pInT1; + *pInT1++ = in1 - (in * *pPRT_in++); + + /* Decrement the loop counter */ + j--; + } + + /* Loop over the number of columns to + replace the elements in the destination matrix */ + j = numCols; + + while (j > 0U) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + in1 = *pInT2; + *pInT2++ = in1 - (in * *pPRT_pDst++); + + /* Decrement the loop counter */ + j--; + } + + } + + /* Increment the temporary input pointer */ + pInT1 = pInT1 + l; + + /* Decrement the loop counter */ + k--; + + /* Increment the pivot index */ + i++; + } + + /* Increment the input pointer */ + pIn++; + + /* Decrement the loop counter */ + loopCnt--; + + /* Increment the index modifier */ + l++; + } + + +#else + + /* Run the below code for Cortex-M0 */ + + float64_t Xchg, in = 0.0f; /* Temporary input values */ + uint32_t i, rowCnt, flag = 0U, j, loopCnt, k, l; /* loop counters */ + arm_status status; /* status of matrix inverse */ + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pSrc->numCols) || (pDst->numRows != pDst->numCols) + || (pSrc->numRows != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + { + + /*-------------------------------------------------------------------------------------------------------------- + * Matrix Inverse can be solved using elementary row operations. + * + * Gauss-Jordan Method: + * + * 1. First combine the identity matrix and the input matrix separated by a bar to form an + * augmented matrix as follows: + * _ _ _ _ _ _ _ _ + * | | a11 a12 | | | 1 0 | | | X11 X12 | + * | | | | | | | = | | + * |_ |_ a21 a22 _| | |_0 1 _| _| |_ X21 X21 _| + * + * 2. In our implementation, pDst Matrix is used as identity matrix. + * + * 3. Begin with the first row. Let i = 1. + * + * 4. Check to see if the pivot for row i is zero. + * The pivot is the element of the main diagonal that is on the current row. + * For instance, if working with row i, then the pivot element is aii. + * If the pivot is zero, exchange that row with a row below it that does not + * contain a zero in column i. If this is not possible, then an inverse + * to that matrix does not exist. + * + * 5. Divide every element of row i by the pivot. + * + * 6. For every row below and row i, replace that row with the sum of that row and + * a multiple of row i so that each new element in column i below row i is zero. + * + * 7. Move to the next row and column and repeat steps 2 through 5 until you have zeros + * for every element below and above the main diagonal. + * + * 8. Now an identical matrix is formed to the left of the bar(input matrix, src). + * Therefore, the matrix to the right of the bar is our solution(dst matrix, dst). + *----------------------------------------------------------------------------------------------------------------*/ + + /* Working pointer for destination matrix */ + pOutT1 = pOut; + + /* Loop over the number of rows */ + rowCnt = numRows; + + /* Making the destination matrix as identity matrix */ + while (rowCnt > 0U) + { + /* Writing all zeroes in lower triangle of the destination matrix */ + j = numRows - rowCnt; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Writing all ones in the diagonal of the destination matrix */ + *pOutT1++ = 1.0f; + + /* Writing all zeroes in upper triangle of the destination matrix */ + j = rowCnt - 1U; + while (j > 0U) + { + *pOutT1++ = 0.0f; + j--; + } + + /* Decrement the loop counter */ + rowCnt--; + } + + /* Loop over the number of columns of the input matrix. + All the elements in each column are processed by the row operations */ + loopCnt = numCols; + + /* Index modifier to navigate through the columns */ + l = 0U; + //for(loopCnt = 0U; loopCnt < numCols; loopCnt++) + while (loopCnt > 0U) + { + /* Check if the pivot element is zero.. + * If it is zero then interchange the row with non zero row below. + * If there is no non zero element to replace in the rows below, + * then the matrix is Singular. */ + + /* Working pointer for the input matrix that points + * to the pivot element of the particular row */ + pInT1 = pIn + (l * numCols); + + /* Working pointer for the destination matrix that points + * to the pivot element of the particular row */ + pOutT1 = pOut + (l * numCols); + + /* Temporary variable to hold the pivot value */ + in = *pInT1; + + /* Destination pointer modifier */ + k = 1U; + + /* Check if the pivot element is zero */ + if (*pInT1 == 0.0f) + { + /* Loop over the number rows present below */ + for (i = (l + 1U); i < numRows; i++) + { + /* Update the input and destination pointers */ + pInT2 = pInT1 + (numCols * l); + pOutT2 = pOutT1 + (numCols * k); + + /* Check if there is a non zero pivot element to + * replace in the rows below */ + if (*pInT2 != 0.0f) + { + /* Loop over number of columns + * to the right of the pilot element */ + for (j = 0U; j < (numCols - l); j++) + { + /* Exchange the row elements of the input matrix */ + Xchg = *pInT2; + *pInT2++ = *pInT1; + *pInT1++ = Xchg; + } + + for (j = 0U; j < numCols; j++) + { + Xchg = *pOutT2; + *pOutT2++ = *pOutT1; + *pOutT1++ = Xchg; + } + + /* Flag to indicate whether exchange is done or not */ + flag = 1U; + + /* Break after exchange is done */ + break; + } + + /* Update the destination pointer modifier */ + k++; + } + } + + /* Update the status if the matrix is singular */ + if ((flag != 1U) && (in == 0.0f)) + { + return ARM_MATH_SINGULAR; + } + + /* Points to the pivot row of input and destination matrices */ + pPivotRowIn = pIn + (l * numCols); + pPivotRowDst = pOut + (l * numCols); + + /* Temporary pointers to the pivot row pointers */ + pInT1 = pPivotRowIn; + pOutT1 = pPivotRowDst; + + /* Pivot element of the row */ + in = *(pIn + (l * numCols)); + + /* Loop over number of columns + * to the right of the pilot element */ + for (j = 0U; j < (numCols - l); j++) + { + /* Divide each element of the row of the input matrix + * by the pivot element */ + *pInT1 = *pInT1 / in; + pInT1++; + } + for (j = 0U; j < numCols; j++) + { + /* Divide each element of the row of the destination matrix + * by the pivot element */ + *pOutT1 = *pOutT1 / in; + pOutT1++; + } + + /* Replace the rows with the sum of that row and a multiple of row i + * so that each new element in column i above row i is zero.*/ + + /* Temporary pointers for input and destination matrices */ + pInT1 = pIn; + pOutT1 = pOut; + + for (i = 0U; i < numRows; i++) + { + /* Check for the pivot element */ + if (i == l) + { + /* If the processing element is the pivot element, + only the columns to the right are to be processed */ + pInT1 += numCols - l; + pOutT1 += numCols; + } + else + { + /* Element of the reference row */ + in = *pInT1; + + /* Working pointers for input and destination pivot rows */ + pPRT_in = pPivotRowIn; + pPRT_pDst = pPivotRowDst; + + /* Loop over the number of columns to the right of the pivot element, + to replace the elements in the input matrix */ + for (j = 0U; j < (numCols - l); j++) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + *pInT1 = *pInT1 - (in * *pPRT_in++); + pInT1++; + } + /* Loop over the number of columns to + replace the elements in the destination matrix */ + for (j = 0U; j < numCols; j++) + { + /* Replace the element by the sum of that row + and a multiple of the reference row */ + *pOutT1 = *pOutT1 - (in * *pPRT_pDst++); + pOutT1++; + } + + } + /* Increment the temporary input pointer */ + pInT1 = pInT1 + l; + } + /* Increment the input pointer */ + pIn++; + + /* Decrement the loop counter */ + loopCnt--; + /* Increment the index modifier */ + l++; + } + + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + + if ((flag != 1U) && (in == 0.0f)) + { + pIn = pSrc->pData; + for (i = 0; i < numRows * numCols; i++) + { + if (pIn[i] != 0.0f) + break; + } + + if (i == numRows * numCols) + status = ARM_MATH_SINGULAR; + } + } + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixInv group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_f32.c new file mode 100644 index 0000000..fa9f03f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_f32.c @@ -0,0 +1,274 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_mult_f32.c + * Description: Floating-point matrix multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixMult Matrix Multiplication + * + * Multiplies two matrices. + * + * \image html MatrixMultiplication.gif "Multiplication of two 3 x 3 matrices" + + * Matrix multiplication is only defined if the number of columns of the + * first matrix equals the number of rows of the second matrix. + * Multiplying an M x N matrix with an N x P matrix results + * in an M x P matrix. + * When matrix size checking is enabled, the functions check: (1) that the inner dimensions of + * pSrcA and pSrcB are equal; and (2) that the size of the output + * matrix equals the outer dimensions of pSrcA and pSrcB. + */ + + +/** + * @addtogroup MatrixMult + * @{ + */ + +/** + * @brief Floating-point matrix multiplication. + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + +arm_status arm_mat_mult_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + float32_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + float32_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + float32_t *pInA = pSrcA->pData; /* input data matrix pointer A */ + float32_t *pOut = pDst->pData; /* output data matrix pointer */ + float32_t *px; /* Temporary output data matrix pointer */ + float32_t sum; /* Accumulator */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t in1, in2, in3, in4; + uint16_t col, i = 0U, j, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* Output pointer is set to starting address of the row being processed */ + px = pOut + i; + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pIn2 = pSrcB->pData; + + j = 0U; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0.0f; + + /* Initiate the pointer pIn1 to point to the starting address of the column being processed */ + pIn1 = pInA; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + colCnt = numColsA >> 2U; + + /* matrix multiplication */ + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + in3 = *pIn2; + pIn2 += numColsB; + in1 = pIn1[0]; + in2 = pIn1[1]; + sum += in1 * in3; + in4 = *pIn2; + pIn2 += numColsB; + sum += in2 * in4; + + in3 = *pIn2; + pIn2 += numColsB; + in1 = pIn1[2]; + in2 = pIn1[3]; + sum += in1 * in3; + in4 = *pIn2; + pIn2 += numColsB; + sum += in2 * in4; + pIn1 += 4U; + + /* Decrement the loop count */ + colCnt--; + } + + /* If the columns of pSrcA is not a multiple of 4, compute any remaining MACs here. + ** No loop unrolling is used. */ + colCnt = numColsA % 0x4U; + + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + sum += *pIn1++ * (*pIn2); + pIn2 += numColsB; + + /* Decrement the loop counter */ + colCnt--; + } + + /* Store the result in the destination buffer */ + *px++ = sum; + + /* Update the pointer pIn2 to point to the starting address of the next column */ + j++; + pIn2 = pSrcB->pData + j; + + /* Decrement the column loop counter */ + col--; + + } while (col > 0U); + +#else + + /* Run the below code for Cortex-M0 */ + + float32_t *pInB = pSrcB->pData; /* input data matrix pointer B */ + uint16_t col, i = 0U, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* The following loop performs the dot-product of each row in pInA with each column in pInB */ + /* row loop */ + do + { + /* Output pointer is set to starting address of the row being processed */ + px = pOut + i; + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pIn2 = pSrcB->pData; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0.0f; + + /* Initialize the pointer pIn1 to point to the starting address of the row being processed */ + pIn1 = pInA; + + /* Matrix A columns number of MAC operations are to be performed */ + colCnt = numColsA; + + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + sum += *pIn1++ * (*pIn2); + pIn2 += numColsB; + + /* Decrement the loop counter */ + colCnt--; + } + + /* Store the result in the destination buffer */ + *px++ = sum; + + /* Decrement the column loop counter */ + col--; + + /* Update the pointer pIn2 to point to the starting address of the next column */ + pIn2 = pInB + (numColsB - col); + + } while (col > 0U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Update the pointer pInA to point to the starting address of the next row */ + i = i + numColsB; + pInA = pInA + numColsA; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q15.c new file mode 100644 index 0000000..796df88 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q15.c @@ -0,0 +1,525 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_mult_fast_q15.c + * Description: Q15 matrix multiplication (fast variant) + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixMult + * @{ + */ + + +/** + * @brief Q15 matrix multiplication (fast variant) for Cortex-M3 and Cortex-M4 + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @param[in] *pState points to the array for storing intermediate results + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The difference between the function arm_mat_mult_q15() and this fast variant is that + * the fast variant use a 32-bit rather than a 64-bit accumulator. + * The result of each 1.15 x 1.15 multiplication is truncated to + * 2.30 format. These intermediate results are accumulated in a 32-bit register in 2.30 + * format. Finally, the accumulator is saturated and converted to a 1.15 result. + * + * \par + * The fast version has the same overflow behavior as the standard version but provides + * less precision since it discards the low 16 bits of each multiplication result. + * In order to avoid overflows completely the input signals must be scaled down. + * Scale down one of the input matrices by log2(numColsA) bits to + * avoid overflows, as a total of numColsA additions are computed internally for each + * output element. + * + * \par + * See arm_mat_mult_q15() for a slower implementation of this function + * which uses 64-bit accumulation to provide higher precision. + */ + +arm_status arm_mat_mult_fast_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst, + q15_t * pState) +{ + q31_t sum; /* accumulator */ + q15_t *pSrcBT = pState; /* input data matrix pointer for transpose */ + q15_t *pInA = pSrcA->pData; /* input data matrix pointer A of Q15 type */ + q15_t *pInB = pSrcB->pData; /* input data matrix pointer B of Q15 type */ + q15_t *px; /* Temporary output data matrix pointer */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + uint16_t numRowsB = pSrcB->numRows; /* number of rows of input matrix A */ + uint32_t col, i = 0U, row = numRowsB, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + q31_t in; /* Temporary variable to hold the input value */ + q31_t inA1, inA2, inB1, inB2; + q31_t sum2, sum3, sum4; + q15_t *pInA2, *pInB2, *px2; + uint32_t j = 0; + +#else + + q15_t in; /* Temporary variable to hold the input value */ + q15_t inA1, inA2, inB1, inB2; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif + { + /* Matrix transpose */ + do + { + /* Apply loop unrolling and exchange the columns with row elements */ + col = numColsB >> 2; + + /* The pointer px is set to starting address of the column being processed */ + px = pSrcBT + i; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (col > 0U) + { +#ifndef UNALIGNED_SUPPORT_DISABLE + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + /* Unpack and store one element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) in; + +#else + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Unpack and store the second element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#else + + *px = (q15_t) in; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + /* Unpack and store one element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) in; + +#else + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Unpack and store the second element in the destination */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#else + + *px = (q15_t) in; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + +#else + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Decrement the column loop counter */ + col--; + } + + /* If the columns of pSrcB is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + col = numColsB % 0x4U; + + while (col > 0U) + { + /* Read and store the input element in the destination */ + *px = *pInB++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Decrement the column loop counter */ + col--; + } + + i++; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* Reset the variables for the usage in the following multiplication process */ + row = numRowsA; + i = 0U; + px = pDst->pData; + +#ifndef UNALIGNED_SUPPORT_DISABLE + /* Process two rows from matrix A at a time and output two rows at a time */ + row = row >> 1; + px2 = px + numColsB; +#endif + + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + while (row > 0U) + { + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the transposed pSrcB data */ + pInB = pSrcBT; + +#ifndef UNALIGNED_SUPPORT_DISABLE + /* Process two (transposed) columns from matrix B at a time */ + col = col >> 1; + j = 0; +#endif + + /* column loop */ + while (col > 0U) + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Initiate the pointer pInA to point to the starting address of the column being processed */ + pInA = pSrcA->pData + i; + +#ifndef UNALIGNED_SUPPORT_DISABLE + sum2 = 0; + sum3 = 0; + sum4 = 0; + pInB = pSrcBT + j; + pInA2 = pInA + numColsA; + pInB2 = pInB + numRowsB; + + /* Read in two elements at once - alows dual MAC instruction */ + colCnt = numColsA >> 1; +#else + colCnt = numColsA >> 2; +#endif + + /* matrix multiplication */ + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ +#ifndef UNALIGNED_SUPPORT_DISABLE + + inA1 = *__SIMD32(pInA)++; + inB1 = *__SIMD32(pInB)++; + inA2 = *__SIMD32(pInA2)++; + inB2 = *__SIMD32(pInB2)++; + + sum = __SMLAD(inA1, inB1, sum); + sum2 = __SMLAD(inA1, inB2, sum2); + sum3 = __SMLAD(inA2, inB1, sum3); + sum4 = __SMLAD(inA2, inB2, sum4); + +#else + + inA1 = *pInA; + inB1 = *pInB; + sum += inA1 * inB1; + + inA2 = pInA[1]; + inB2 = pInB[1]; + sum += inA2 * inB2; + + inA1 = pInA[2]; + inB1 = pInB[2]; + sum += inA1 * inB1; + + inA2 = pInA[3]; + inB2 = pInB[3]; + sum += inA2 * inB2; + + pInA += 4; + pInB += 4; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the loop counter */ + colCnt--; + } + + /* process odd column samples */ +#ifndef UNALIGNED_SUPPORT_DISABLE + if (numColsA & 1U) { + inA1 = *pInA++; + inB1 = *pInB++; + inA2 = *pInA2++; + inB2 = *pInB2++; + sum += inA1 * inB1; + sum2 += inA1 * inB2; + sum3 += inA2 * inB1; + sum4 += inA2 * inB2; + } +#else + colCnt = numColsA % 0x4U; + + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + sum += (q31_t) (*pInA++) * (*pInB++); + + colCnt--; + } +#endif + + /* Saturate and store the result in the destination buffer */ + *px++ = (q15_t) (sum >> 15); + +#ifndef UNALIGNED_SUPPORT_DISABLE + *px++ = (q15_t) (sum2 >> 15); + *px2++ = (q15_t) (sum3 >> 15); + *px2++ = (q15_t) (sum4 >> 15); + j += numRowsB * 2; +#endif + + /* Decrement the column loop counter */ + col--; + + } + + i = i + numColsA; + +#ifndef UNALIGNED_SUPPORT_DISABLE + i = i + numColsA; + px = px2 + (numColsB & 1U); + px2 = px + numColsB; +#endif + + /* Decrement the row loop counter */ + row--; + + } + + /* Compute any remaining odd row/column below */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Compute remaining output column */ + if (numColsB & 1U) { + + /* Avoid redundant computation of last element */ + row = numRowsA & (~0x1); + + /* Point to remaining unfilled column in output matrix */ + px = pDst->pData+numColsB-1; + pInA = pSrcA->pData; + + /* row loop */ + while (row > 0) + { + + /* point to last column in matrix B */ + pInB = pSrcBT + numRowsB*(numColsB-1); + + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Compute 4 columns at once */ + colCnt = numColsA >> 2; + + /* matrix multiplication */ + while (colCnt > 0U) + { + inA1 = *__SIMD32(pInA)++; + inA2 = *__SIMD32(pInA)++; + inB1 = *__SIMD32(pInB)++; + inB2 = *__SIMD32(pInB)++; + + sum = __SMLAD(inA1, inB1, sum); + sum = __SMLAD(inA2, inB2, sum); + + /* Decrement the loop counter */ + colCnt--; + } + + colCnt = numColsA & 3U; + while (colCnt > 0U) { + sum += (q31_t) (*pInA++) * (*pInB++); + colCnt--; + } + + /* Store the result in the destination buffer */ + *px = (q15_t) (sum >> 15); + px += numColsB; + + /* Decrement the row loop counter */ + row--; + } + } + + /* Compute remaining output row */ + if (numRowsA & 1U) { + + /* point to last row in output matrix */ + px = pDst->pData+(numColsB)*(numRowsA-1); + + pInB = pSrcBT; + col = numColsB; + i = 0U; + + /* col loop */ + while (col > 0) + { + + /* point to last row in matrix A */ + pInA = pSrcA->pData + (numRowsA-1)*numColsA; + + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Compute 4 columns at once */ + colCnt = numColsA >> 2; + + /* matrix multiplication */ + while (colCnt > 0U) + { + inA1 = *__SIMD32(pInA)++; + inA2 = *__SIMD32(pInA)++; + inB1 = *__SIMD32(pInB)++; + inB2 = *__SIMD32(pInB)++; + + sum = __SMLAD(inA1, inB1, sum); + sum = __SMLAD(inA2, inB2, sum); + + /* Decrement the loop counter */ + colCnt--; + } + + colCnt = numColsA & 3U; + while (colCnt > 0U) { + sum += (q31_t) (*pInA++) * (*pInB++); + colCnt--; + } + + /* Store the result in the destination buffer */ + *px++ = (q15_t) (sum >> 15); + + /* Decrement the col loop counter */ + col--; + } + } + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q31.c new file mode 100644 index 0000000..bff3177 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_fast_q31.c @@ -0,0 +1,384 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_mult_fast_q31.c + * Description: Q31 matrix multiplication (fast variant) + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixMult + * @{ + */ + +/** + * @brief Q31 matrix multiplication (fast variant) for Cortex-M3 and Cortex-M4 + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The difference between the function arm_mat_mult_q31() and this fast variant is that + * the fast variant use a 32-bit rather than a 64-bit accumulator. + * The result of each 1.31 x 1.31 multiplication is truncated to + * 2.30 format. These intermediate results are accumulated in a 32-bit register in 2.30 + * format. Finally, the accumulator is saturated and converted to a 1.31 result. + * + * \par + * The fast version has the same overflow behavior as the standard version but provides + * less precision since it discards the low 32 bits of each multiplication result. + * In order to avoid overflows completely the input signals must be scaled down. + * Scale down one of the input matrices by log2(numColsA) bits to + * avoid overflows, as a total of numColsA additions are computed internally for each + * output element. + * + * \par + * See arm_mat_mult_q31() for a slower implementation of this function + * which uses 64-bit accumulation to provide higher precision. + */ + +arm_status arm_mat_mult_fast_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + q31_t *pInA = pSrcA->pData; /* input data matrix pointer A */ + q31_t *pInB = pSrcB->pData; /* input data matrix pointer B */ + q31_t *px; /* Temporary output data matrix pointer */ + q31_t sum; /* Accumulator */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + uint32_t col, i = 0U, j, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + q31_t inA1, inB1; + +#if defined (ARM_MATH_DSP) + + q31_t sum2, sum3, sum4; + q31_t inA2, inB2; + q31_t *pInA2; + q31_t *px2; + +#endif + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + + px = pDst->pData; + +#if defined (ARM_MATH_DSP) + row = row >> 1; + px2 = px + numColsB; +#endif + + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + while (row > 0U) + { + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pInB = pSrcB->pData; + + j = 0U; + +#if defined (ARM_MATH_DSP) + col = col >> 1; +#endif + + /* column loop */ + while (col > 0U) + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Initiate data pointers */ + pInA = pSrcA->pData + i; + pInB = pSrcB->pData + j; + +#if defined (ARM_MATH_DSP) + sum2 = 0; + sum3 = 0; + sum4 = 0; + pInA2 = pInA + numColsA; + colCnt = numColsA; +#else + colCnt = numColsA >> 2; +#endif + + /* matrix multiplication */ + while (colCnt > 0U) + { + +#if defined (ARM_MATH_DSP) + inA1 = *pInA++; + inB1 = pInB[0]; + inA2 = *pInA2++; + inB2 = pInB[1]; + pInB += numColsB; + + sum = __SMMLA(inA1, inB1, sum); + sum2 = __SMMLA(inA1, inB2, sum2); + sum3 = __SMMLA(inA2, inB1, sum3); + sum4 = __SMMLA(inA2, inB2, sum4); +#else + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + /* Perform the multiply-accumulates */ + inB1 = *pInB; + pInB += numColsB; + inA1 = pInA[0]; + sum = __SMMLA(inA1, inB1, sum); + + inB1 = *pInB; + pInB += numColsB; + inA1 = pInA[1]; + sum = __SMMLA(inA1, inB1, sum); + + inB1 = *pInB; + pInB += numColsB; + inA1 = pInA[2]; + sum = __SMMLA(inA1, inB1, sum); + + inB1 = *pInB; + pInB += numColsB; + inA1 = pInA[3]; + sum = __SMMLA(inA1, inB1, sum); + + pInA += 4U; +#endif + + /* Decrement the loop counter */ + colCnt--; + } + +#ifdef ARM_MATH_CM0_FAMILY + /* If the columns of pSrcA is not a multiple of 4, compute any remaining output samples here. */ + colCnt = numColsA % 0x4U; + while (colCnt > 0U) + { + sum = __SMMLA(*pInA++, *pInB, sum); + pInB += numColsB; + colCnt--; + } + j++; +#endif + + /* Convert the result from 2.30 to 1.31 format and store in destination buffer */ + *px++ = sum << 1; + +#if defined (ARM_MATH_DSP) + *px++ = sum2 << 1; + *px2++ = sum3 << 1; + *px2++ = sum4 << 1; + j += 2; +#endif + + /* Decrement the column loop counter */ + col--; + + } + + i = i + numColsA; + +#if defined (ARM_MATH_DSP) + i = i + numColsA; + px = px2 + (numColsB & 1U); + px2 = px + numColsB; +#endif + + /* Decrement the row loop counter */ + row--; + + } + + /* Compute any remaining odd row/column below */ + +#if defined (ARM_MATH_DSP) + + /* Compute remaining output column */ + if (numColsB & 1U) { + + /* Avoid redundant computation of last element */ + row = numRowsA & (~0x1); + + /* Point to remaining unfilled column in output matrix */ + px = pDst->pData+numColsB-1; + pInA = pSrcA->pData; + + /* row loop */ + while (row > 0) + { + + /* point to last column in matrix B */ + pInB = pSrcB->pData + numColsB-1; + + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Compute 4 columns at once */ + colCnt = numColsA >> 2; + + /* matrix multiplication */ + while (colCnt > 0U) + { + inA1 = *pInA++; + inA2 = *pInA++; + inB1 = *pInB; + pInB += numColsB; + inB2 = *pInB; + pInB += numColsB; + sum = __SMMLA(inA1, inB1, sum); + sum = __SMMLA(inA2, inB2, sum); + + inA1 = *pInA++; + inA2 = *pInA++; + inB1 = *pInB; + pInB += numColsB; + inB2 = *pInB; + pInB += numColsB; + sum = __SMMLA(inA1, inB1, sum); + sum = __SMMLA(inA2, inB2, sum); + + /* Decrement the loop counter */ + colCnt--; + } + + colCnt = numColsA & 3U; + while (colCnt > 0U) { + sum = __SMMLA(*pInA++, *pInB, sum); + pInB += numColsB; + colCnt--; + } + + /* Convert the result from 2.30 to 1.31 format and store in destination buffer */ + *px = sum << 1; + px += numColsB; + + /* Decrement the row loop counter */ + row--; + } + } + + /* Compute remaining output row */ + if (numRowsA & 1U) { + + /* point to last row in output matrix */ + px = pDst->pData+(numColsB)*(numRowsA-1); + + col = numColsB; + i = 0U; + + /* col loop */ + while (col > 0) + { + + /* point to last row in matrix A */ + pInA = pSrcA->pData + (numRowsA-1)*numColsA; + pInB = pSrcB->pData + i; + + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Compute 4 columns at once */ + colCnt = numColsA >> 2; + + /* matrix multiplication */ + while (colCnt > 0U) + { + inA1 = *pInA++; + inA2 = *pInA++; + inB1 = *pInB; + pInB += numColsB; + inB2 = *pInB; + pInB += numColsB; + sum = __SMMLA(inA1, inB1, sum); + sum = __SMMLA(inA2, inB2, sum); + + inA1 = *pInA++; + inA2 = *pInA++; + inB1 = *pInB; + pInB += numColsB; + inB2 = *pInB; + pInB += numColsB; + sum = __SMMLA(inA1, inB1, sum); + sum = __SMMLA(inA2, inB2, sum); + + /* Decrement the loop counter */ + colCnt--; + } + + colCnt = numColsA & 3U; + while (colCnt > 0U) { + sum = __SMMLA(*pInA++, *pInB, sum); + pInB += numColsB; + colCnt--; + } + + /* Saturate and store the result in the destination buffer */ + *px++ = sum << 1; + i++; + + /* Decrement the col loop counter */ + col--; + } + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q15.c new file mode 100644 index 0000000..abd55bd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q15.c @@ -0,0 +1,457 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_mult_q15.c + * Description: Q15 matrix multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixMult + * @{ + */ + + +/** + * @brief Q15 matrix multiplication + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @param[in] *pState points to the array for storing intermediate results (Unused) + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. The inputs to the + * multiplications are in 1.15 format and multiplications yield a 2.30 result. + * The 2.30 intermediate + * results are accumulated in a 64-bit accumulator in 34.30 format. This approach + * provides 33 guard bits and there is no risk of overflow. The 34.30 result is then + * truncated to 34.15 format by discarding the low 15 bits and then saturated to + * 1.15 format. + * + * \par + * Refer to arm_mat_mult_fast_q15() for a faster but less precise version of this function for Cortex-M3 and Cortex-M4. + * + */ + +arm_status arm_mat_mult_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst, + q15_t * pState) +{ + q63_t sum; /* accumulator */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t *pSrcBT = pState; /* input data matrix pointer for transpose */ + q15_t *pInA = pSrcA->pData; /* input data matrix pointer A of Q15 type */ + q15_t *pInB = pSrcB->pData; /* input data matrix pointer B of Q15 type */ + q15_t *px; /* Temporary output data matrix pointer */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + uint16_t numRowsB = pSrcB->numRows; /* number of rows of input matrix A */ + uint16_t col, i = 0U, row = numRowsB, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + +#ifndef UNALIGNED_SUPPORT_DISABLE + + q31_t in; /* Temporary variable to hold the input value */ + q31_t pSourceA1, pSourceB1, pSourceA2, pSourceB2; + +#else + + q15_t in; /* Temporary variable to hold the input value */ + q15_t inA1, inB1, inA2, inB2; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + { + /* Matrix transpose */ + do + { + /* Apply loop unrolling and exchange the columns with row elements */ + col = numColsB >> 2; + + /* The pointer px is set to starting address of the column being processed */ + px = pSrcBT + i; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (col > 0U) + { +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + /* Unpack and store one element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) in; + +#else + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Unpack and store the second element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#else + + *px = (q15_t) in; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read two elements from the row */ + in = *__SIMD32(pInB)++; + + /* Unpack and store one element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) in; + +#else + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Unpack and store the second element in the destination */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *px = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#else + + *px = (q15_t) in; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + +#else + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Read one element from the row */ + in = *pInB++; + + /* Store one element in the destination */ + *px = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the column loop counter */ + col--; + } + + /* If the columns of pSrcB is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + col = numColsB % 0x4U; + + while (col > 0U) + { + /* Read and store the input element in the destination */ + *px = *pInB++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += numRowsB; + + /* Decrement the column loop counter */ + col--; + } + + i++; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* Reset the variables for the usage in the following multiplication process */ + row = numRowsA; + i = 0U; + px = pDst->pData; + + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the transposed pSrcB data */ + pInB = pSrcBT; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Apply loop unrolling and compute 2 MACs simultaneously. */ + colCnt = numColsA >> 2; + + /* Initiate the pointer pIn1 to point to the starting address of the column being processed */ + pInA = pSrcA->pData + i; + + + /* matrix multiplication */ + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* read real and imag values from pSrcA and pSrcB buffer */ + pSourceA1 = *__SIMD32(pInA)++; + pSourceB1 = *__SIMD32(pInB)++; + + pSourceA2 = *__SIMD32(pInA)++; + pSourceB2 = *__SIMD32(pInB)++; + + /* Multiply and Accumlates */ + sum = __SMLALD(pSourceA1, pSourceB1, sum); + sum = __SMLALD(pSourceA2, pSourceB2, sum); + +#else + /* read real and imag values from pSrcA and pSrcB buffer */ + inA1 = *pInA++; + inB1 = *pInB++; + inA2 = *pInA++; + /* Multiply and Accumlates */ + sum += inA1 * inB1; + inB2 = *pInB++; + + inA1 = *pInA++; + inB1 = *pInB++; + /* Multiply and Accumlates */ + sum += inA2 * inB2; + inA2 = *pInA++; + inB2 = *pInB++; + + /* Multiply and Accumlates */ + sum += inA1 * inB1; + sum += inA2 * inB2; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Decrement the loop counter */ + colCnt--; + } + + /* process remaining column samples */ + colCnt = numColsA & 3U; + + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + sum += *pInA++ * *pInB++; + + /* Decrement the loop counter */ + colCnt--; + } + + /* Saturate and store the result in the destination buffer */ + *px = (q15_t) (__SSAT((sum >> 15), 16)); + px++; + + /* Decrement the column loop counter */ + col--; + + } while (col > 0U); + + i = i + numColsA; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + +#else + + /* Run the below code for Cortex-M0 */ + + q15_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + q15_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + q15_t *pInA = pSrcA->pData; /* input data matrix pointer A of Q15 type */ + q15_t *pInB = pSrcB->pData; /* input data matrix pointer B of Q15 type */ + q15_t *pOut = pDst->pData; /* output data matrix pointer */ + q15_t *px; /* Temporary output data matrix pointer */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t col, i = 0U, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* Output pointer is set to starting address of the row being processed */ + px = pOut + i; + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pIn2 = pSrcB->pData; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Initiate the pointer pIn1 to point to the starting address of pSrcA */ + pIn1 = pInA; + + /* Matrix A columns number of MAC operations are to be performed */ + colCnt = numColsA; + + /* matrix multiplication */ + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + /* Perform the multiply-accumulates */ + sum += (q31_t) * pIn1++ * *pIn2; + pIn2 += numColsB; + + /* Decrement the loop counter */ + colCnt--; + } + + /* Convert the result from 34.30 to 1.15 format and store the saturated value in destination buffer */ + /* Saturate and store the result in the destination buffer */ + *px++ = (q15_t) __SSAT((sum >> 15), 16); + + /* Decrement the column loop counter */ + col--; + + /* Update the pointer pIn2 to point to the starting address of the next column */ + pIn2 = pInB + (numColsB - col); + + } while (col > 0U); + + /* Update the pointer pSrcA to point to the starting address of the next row */ + i = i + numColsB; + pInA = pInA + numColsA; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + +#endif /* #if defined (ARM_MATH_DSP) */ + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q31.c new file mode 100644 index 0000000..2ce3637 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_mult_q31.c @@ -0,0 +1,282 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_mult_q31.c + * Description: Q31 matrix multiplication + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixMult + * @{ + */ + +/** + * @brief Q31 matrix multiplication + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using an internal 64-bit accumulator. + * The accumulator has a 2.62 format and maintains full precision of the intermediate + * multiplication results but provides only a single guard bit. There is no saturation + * on intermediate additions. Thus, if the accumulator overflows it wraps around and + * distorts the result. The input signals should be scaled down to avoid intermediate + * overflows. The input is thus scaled down by log2(numColsA) bits + * to avoid overflows, as a total of numColsA additions are performed internally. + * The 2.62 accumulator is right shifted by 31 bits and saturated to 1.31 format to yield the final result. + * + * \par + * See arm_mat_mult_fast_q31() for a faster but less precise implementation of this function for Cortex-M3 and Cortex-M4. + * + */ + +arm_status arm_mat_mult_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + q31_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + q31_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + q31_t *pInA = pSrcA->pData; /* input data matrix pointer A */ + q31_t *pOut = pDst->pData; /* output data matrix pointer */ + q31_t *px; /* Temporary output data matrix pointer */ + q63_t sum; /* Accumulator */ + uint16_t numRowsA = pSrcA->numRows; /* number of rows of input matrix A */ + uint16_t numColsB = pSrcB->numCols; /* number of columns of input matrix B */ + uint16_t numColsA = pSrcA->numCols; /* number of columns of input matrix A */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + uint16_t col, i = 0U, j, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + q31_t a0, a1, a2, a3, b0, b1, b2, b3; + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* Output pointer is set to starting address of the row being processed */ + px = pOut + i; + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pIn2 = pSrcB->pData; + + j = 0U; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Initiate the pointer pIn1 to point to the starting address of pInA */ + pIn1 = pInA; + + /* Apply loop unrolling and compute 4 MACs simultaneously. */ + colCnt = numColsA >> 2; + + + /* matrix multiplication */ + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + /* Perform the multiply-accumulates */ + b0 = *pIn2; + pIn2 += numColsB; + + a0 = *pIn1++; + a1 = *pIn1++; + + b1 = *pIn2; + pIn2 += numColsB; + b2 = *pIn2; + pIn2 += numColsB; + + sum += (q63_t) a0 *b0; + sum += (q63_t) a1 *b1; + + a2 = *pIn1++; + a3 = *pIn1++; + + b3 = *pIn2; + pIn2 += numColsB; + + sum += (q63_t) a2 *b2; + sum += (q63_t) a3 *b3; + + /* Decrement the loop counter */ + colCnt--; + } + + /* If the columns of pSrcA is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + colCnt = numColsA % 0x4U; + + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + /* Perform the multiply-accumulates */ + sum += (q63_t) * pIn1++ * *pIn2; + pIn2 += numColsB; + + /* Decrement the loop counter */ + colCnt--; + } + + /* Convert the result from 2.62 to 1.31 format and store in destination buffer */ + *px++ = (q31_t) (sum >> 31); + + /* Update the pointer pIn2 to point to the starting address of the next column */ + j++; + pIn2 = (pSrcB->pData) + j; + + /* Decrement the column loop counter */ + col--; + + } while (col > 0U); + +#else + + /* Run the below code for Cortex-M0 */ + + q31_t *pInB = pSrcB->pData; /* input data matrix pointer B */ + uint16_t col, i = 0U, row = numRowsA, colCnt; /* loop counters */ + arm_status status; /* status of matrix multiplication */ + + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrcA->numCols != pSrcB->numRows) || + (pSrcA->numRows != pDst->numRows) || (pSrcB->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* The following loop performs the dot-product of each row in pSrcA with each column in pSrcB */ + /* row loop */ + do + { + /* Output pointer is set to starting address of the row being processed */ + px = pOut + i; + + /* For every row wise process, the column loop counter is to be initiated */ + col = numColsB; + + /* For every row wise process, the pIn2 pointer is set + ** to the starting address of the pSrcB data */ + pIn2 = pSrcB->pData; + + /* column loop */ + do + { + /* Set the variable sum, that acts as accumulator, to zero */ + sum = 0; + + /* Initiate the pointer pIn1 to point to the starting address of pInA */ + pIn1 = pInA; + + /* Matrix A columns number of MAC operations are to be performed */ + colCnt = numColsA; + + /* matrix multiplication */ + while (colCnt > 0U) + { + /* c(m,n) = a(1,1)*b(1,1) + a(1,2) * b(2,1) + .... + a(m,p)*b(p,n) */ + /* Perform the multiply-accumulates */ + sum += (q63_t) * pIn1++ * *pIn2; + pIn2 += numColsB; + + /* Decrement the loop counter */ + colCnt--; + } + + /* Convert the result from 2.62 to 1.31 format and store in destination buffer */ + *px++ = (q31_t) clip_q63_to_q31(sum >> 31); + + /* Decrement the column loop counter */ + col--; + + /* Update the pointer pIn2 to point to the starting address of the next column */ + pIn2 = pInB + (numColsB - col); + + } while (col > 0U); + +#endif + + /* Update the pointer pInA to point to the starting address of the next row */ + i = i + numColsB; + pInA = pInA + numColsA; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixMult group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_f32.c new file mode 100644 index 0000000..3e4f5f7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_f32.c @@ -0,0 +1,169 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_scale_f32.c + * Description: Multiplies a floating-point matrix by a scalar + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixScale Matrix Scale + * + * Multiplies a matrix by a scalar. This is accomplished by multiplying each element in the + * matrix by the scalar. For example: + * \image html MatrixScale.gif "Matrix Scaling of a 3 x 3 matrix" + * + * The function checks to make sure that the input and output matrices are of the same size. + * + * In the fixed-point Q15 and Q31 functions, scale is represented by + * a fractional multiplication scaleFract and an arithmetic shift shift. + * The shift allows the gain of the scaling operation to exceed 1.0. + * The overall scale factor applied to the fixed-point data is + *
+ *     scale = scaleFract * 2^shift.
+ * 
+ */ + +/** + * @addtogroup MatrixScale + * @{ + */ + +/** + * @brief Floating-point matrix scaling. + * @param[in] *pSrc points to input matrix structure + * @param[in] scale scale factor to be applied + * @param[out] *pDst points to output matrix structure + * @return The function returns either ARM_MATH_SIZE_MISMATCH + * or ARM_MATH_SUCCESS based on the outcome of size checking. + * + */ + +arm_status arm_mat_scale_f32( + const arm_matrix_instance_f32 * pSrc, + float32_t scale, + arm_matrix_instance_f32 * pDst) +{ + float32_t *pIn = pSrc->pData; /* input data matrix pointer */ + float32_t *pOut = pDst->pData; /* output data matrix pointer */ + uint32_t numSamples; /* total number of elements in the matrix */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix scaling */ + +#if defined (ARM_MATH_DSP) + + float32_t in1, in2, in3, in4; /* temporary variables */ + float32_t out1, out2, out3, out4; /* temporary variables */ + +#endif // #if defined (ARM_MATH_DSP) + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pDst->numRows) || (pSrc->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + { + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrc->numRows * pSrc->numCols; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop Unrolling */ + blkCnt = numSamples >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) * scale */ + /* Scaling and results are stored in the destination buffer. */ + in1 = pIn[0]; + in2 = pIn[1]; + in3 = pIn[2]; + in4 = pIn[3]; + + out1 = in1 * scale; + out2 = in2 * scale; + out3 = in3 * scale; + out4 = in4 * scale; + + + pOut[0] = out1; + pOut[1] = out2; + pOut[2] = out3; + pOut[3] = out4; + + /* update pointers to process next sampels */ + pIn += 4U; + pOut += 4U; + + /* Decrement the numSamples loop counter */ + blkCnt--; + } + + /* If the numSamples is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) * scale */ + /* The results are stored in the destination buffer. */ + *pOut++ = (*pIn++) * scale; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixScale group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q15.c new file mode 100644 index 0000000..4eff925 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q15.c @@ -0,0 +1,171 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_scale_q15.c + * Description: Multiplies a Q15 matrix by a scalar + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixScale + * @{ + */ + +/** + * @brief Q15 matrix scaling. + * @param[in] *pSrc points to input matrix + * @param[in] scaleFract fractional portion of the scale factor + * @param[in] shift number of bits to shift the result by + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * Scaling and Overflow Behavior: + * \par + * The input data *pSrc and scaleFract are in 1.15 format. + * These are multiplied to yield a 2.30 intermediate result and this is shifted with saturation to 1.15 format. + */ + +arm_status arm_mat_scale_q15( + const arm_matrix_instance_q15 * pSrc, + q15_t scaleFract, + int32_t shift, + arm_matrix_instance_q15 * pDst) +{ + q15_t *pIn = pSrc->pData; /* input data matrix pointer */ + q15_t *pOut = pDst->pData; /* output data matrix pointer */ + uint32_t numSamples; /* total number of elements in the matrix */ + int32_t totShift = 15 - shift; /* total shift to apply after scaling */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix scaling */ + +#if defined (ARM_MATH_DSP) + + q15_t in1, in2, in3, in4; + q31_t out1, out2, out3, out4; + q31_t inA1, inA2; + +#endif // #if defined (ARM_MATH_DSP) + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch */ + if ((pSrc->numRows != pDst->numRows) || (pSrc->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif // #ifdef ARM_MATH_MATRIX_CHECK + { + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrc->numRows * pSrc->numCols; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + /* Loop Unrolling */ + blkCnt = numSamples >> 2; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) * k */ + /* Scale, saturate and then store the results in the destination buffer. */ + /* Reading 2 inputs from memory */ + inA1 = _SIMD32_OFFSET(pIn); + inA2 = _SIMD32_OFFSET(pIn + 2); + + /* C = A * scale */ + /* Scale the inputs and then store the 2 results in the destination buffer + * in single cycle by packing the outputs */ + out1 = (q31_t) ((q15_t) (inA1 >> 16) * scaleFract); + out2 = (q31_t) ((q15_t) inA1 * scaleFract); + out3 = (q31_t) ((q15_t) (inA2 >> 16) * scaleFract); + out4 = (q31_t) ((q15_t) inA2 * scaleFract); + + out1 = out1 >> totShift; + inA1 = _SIMD32_OFFSET(pIn + 4); + out2 = out2 >> totShift; + inA2 = _SIMD32_OFFSET(pIn + 6); + out3 = out3 >> totShift; + out4 = out4 >> totShift; + + in1 = (q15_t) (__SSAT(out1, 16)); + in2 = (q15_t) (__SSAT(out2, 16)); + in3 = (q15_t) (__SSAT(out3, 16)); + in4 = (q15_t) (__SSAT(out4, 16)); + + _SIMD32_OFFSET(pOut) = __PKHBT(in2, in1, 16); + _SIMD32_OFFSET(pOut + 2) = __PKHBT(in4, in3, 16); + + /* update pointers to process next sampels */ + pIn += 4U; + pOut += 4U; + + + /* Decrement the numSamples loop counter */ + blkCnt--; + } + + /* If the numSamples is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) * k */ + /* Scale, saturate and then store the results in the destination buffer. */ + *pOut++ = + (q15_t) (__SSAT(((q31_t) (*pIn++) * scaleFract) >> totShift, 16)); + + /* Decrement the numSamples loop counter */ + blkCnt--; + } + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixScale group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q31.c new file mode 100644 index 0000000..1b2b373 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_scale_q31.c @@ -0,0 +1,191 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_scale_q31.c + * Description: Multiplies a Q31 matrix by a scalar + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixScale + * @{ + */ + +/** + * @brief Q31 matrix scaling. + * @param[in] *pSrc points to input matrix + * @param[in] scaleFract fractional portion of the scale factor + * @param[in] shift number of bits to shift the result by + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * Scaling and Overflow Behavior: + * \par + * The input data *pSrc and scaleFract are in 1.31 format. + * These are multiplied to yield a 2.62 intermediate result and this is shifted with saturation to 1.31 format. + */ + +arm_status arm_mat_scale_q31( + const arm_matrix_instance_q31 * pSrc, + q31_t scaleFract, + int32_t shift, + arm_matrix_instance_q31 * pDst) +{ + q31_t *pIn = pSrc->pData; /* input data matrix pointer */ + q31_t *pOut = pDst->pData; /* output data matrix pointer */ + uint32_t numSamples; /* total number of elements in the matrix */ + int32_t totShift = shift + 1; /* shift to apply after scaling */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix scaling */ + q31_t in1, in2, out1; /* temporary variabels */ + +#if defined (ARM_MATH_DSP) + + q31_t in3, in4, out2, out3, out4; /* temporary variables */ + +#endif // #ifndef ARM_MAT_CM0 + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch */ + if ((pSrc->numRows != pDst->numRows) || (pSrc->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif // #ifdef ARM_MATH_MATRIX_CHECK + { + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrc->numRows * pSrc->numCols; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop Unrolling */ + blkCnt = numSamples >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) * k */ + /* Read values from input */ + in1 = *pIn; + in2 = *(pIn + 1); + in3 = *(pIn + 2); + in4 = *(pIn + 3); + + /* multiply input with scaler value */ + in1 = ((q63_t) in1 * scaleFract) >> 32; + in2 = ((q63_t) in2 * scaleFract) >> 32; + in3 = ((q63_t) in3 * scaleFract) >> 32; + in4 = ((q63_t) in4 * scaleFract) >> 32; + + /* apply shifting */ + out1 = in1 << totShift; + out2 = in2 << totShift; + + /* saturate the results. */ + if (in1 != (out1 >> totShift)) + out1 = 0x7FFFFFFF ^ (in1 >> 31); + + if (in2 != (out2 >> totShift)) + out2 = 0x7FFFFFFF ^ (in2 >> 31); + + out3 = in3 << totShift; + out4 = in4 << totShift; + + *pOut = out1; + *(pOut + 1) = out2; + + if (in3 != (out3 >> totShift)) + out3 = 0x7FFFFFFF ^ (in3 >> 31); + + if (in4 != (out4 >> totShift)) + out4 = 0x7FFFFFFF ^ (in4 >> 31); + + + *(pOut + 2) = out3; + *(pOut + 3) = out4; + + /* update pointers to process next sampels */ + pIn += 4U; + pOut += 4U; + + + /* Decrement the numSamples loop counter */ + blkCnt--; + } + + /* If the numSamples is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) * k */ + /* Scale, saturate and then store the results in the destination buffer. */ + in1 = *pIn++; + + in2 = ((q63_t) in1 * scaleFract) >> 32; + + out1 = in2 << totShift; + + if (in2 != (out1 >> totShift)) + out1 = 0x7FFFFFFF ^ (in2 >> 31); + + *pOut++ = out1; + + /* Decrement the numSamples loop counter */ + blkCnt--; + } + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixScale group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_f32.c new file mode 100644 index 0000000..42eaadb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_f32.c @@ -0,0 +1,197 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_sub_f32.c + * Description: Floating-point matrix subtraction + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @defgroup MatrixSub Matrix Subtraction + * + * Subtract two matrices. + * \image html MatrixSubtraction.gif "Subraction of two 3 x 3 matrices" + * + * The functions check to make sure that + * pSrcA, pSrcB, and pDst have the same + * number of rows and columns. + */ + +/** + * @addtogroup MatrixSub + * @{ + */ + +/** + * @brief Floating-point matrix subtraction + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + +arm_status arm_mat_sub_f32( + const arm_matrix_instance_f32 * pSrcA, + const arm_matrix_instance_f32 * pSrcB, + arm_matrix_instance_f32 * pDst) +{ + float32_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + float32_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + float32_t *pOut = pDst->pData; /* output data matrix pointer */ + +#if defined (ARM_MATH_DSP) + + float32_t inA1, inA2, inB1, inB2, out1, out2; /* temporary variables */ + +#endif // #if defined (ARM_MATH_DSP) + + uint32_t numSamples; /* total number of elements in the matrix */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix subtraction */ + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrcA->numRows != pSrcB->numRows) || + (pSrcA->numCols != pSrcB->numCols) || + (pSrcA->numRows != pDst->numRows) || (pSrcA->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + { + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop Unrolling */ + blkCnt = numSamples >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) - B(m,n) */ + /* Subtract and then store the results in the destination buffer. */ + /* Read values from source A */ + inA1 = pIn1[0]; + + /* Read values from source B */ + inB1 = pIn2[0]; + + /* Read values from source A */ + inA2 = pIn1[1]; + + /* out = sourceA - sourceB */ + out1 = inA1 - inB1; + + /* Read values from source B */ + inB2 = pIn2[1]; + + /* Read values from source A */ + inA1 = pIn1[2]; + + /* out = sourceA - sourceB */ + out2 = inA2 - inB2; + + /* Read values from source B */ + inB1 = pIn2[2]; + + /* Store result in destination */ + pOut[0] = out1; + pOut[1] = out2; + + /* Read values from source A */ + inA2 = pIn1[3]; + + /* Read values from source B */ + inB2 = pIn2[3]; + + /* out = sourceA - sourceB */ + out1 = inA1 - inB1; + + + /* out = sourceA - sourceB */ + out2 = inA2 - inB2; + + /* Store result in destination */ + pOut[2] = out1; + + /* Store result in destination */ + pOut[3] = out2; + + + /* update pointers to process next sampels */ + pIn1 += 4U; + pIn2 += 4U; + pOut += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the numSamples is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) - B(m,n) */ + /* Subtract and then store the results in the destination buffer. */ + *pOut++ = (*pIn1++) - (*pIn2++); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixSub group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q15.c new file mode 100644 index 0000000..07818dc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q15.c @@ -0,0 +1,148 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_sub_q15.c + * Description: Q15 Matrix subtraction + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixSub + * @{ + */ + +/** + * @brief Q15 matrix subtraction. + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +arm_status arm_mat_sub_q15( + const arm_matrix_instance_q15 * pSrcA, + const arm_matrix_instance_q15 * pSrcB, + arm_matrix_instance_q15 * pDst) +{ + q15_t *pInA = pSrcA->pData; /* input data matrix pointer A */ + q15_t *pInB = pSrcB->pData; /* input data matrix pointer B */ + q15_t *pOut = pDst->pData; /* output data matrix pointer */ + uint32_t numSamples; /* total number of elements in the matrix */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix subtraction */ + + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrcA->numRows != pSrcB->numRows) || + (pSrcA->numCols != pSrcB->numCols) || + (pSrcA->numRows != pDst->numRows) || (pSrcA->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Apply loop unrolling */ + blkCnt = numSamples >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) - B(m,n) */ + /* Subtract, Saturate and then store the results in the destination buffer. */ + *__SIMD32(pOut)++ = __QSUB16(*__SIMD32(pInA)++, *__SIMD32(pInB)++); + *__SIMD32(pOut)++ = __QSUB16(*__SIMD32(pInA)++, *__SIMD32(pInB)++); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) - B(m,n) */ + /* Subtract and then store the results in the destination buffer. */ + *pOut++ = (q15_t) __QSUB16(*pInA++, *pInB++); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) - B(m,n) */ + /* Subtract and then store the results in the destination buffer. */ + *pOut++ = (q15_t) __SSAT(((q31_t) * pInA++ - *pInB++), 16); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixSub group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q31.c new file mode 100644 index 0000000..ebfd09d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_sub_q31.c @@ -0,0 +1,196 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_sub_q31.c + * Description: Q31 matrix subtraction + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixSub + * @{ + */ + +/** + * @brief Q31 matrix subtraction. + * @param[in] *pSrcA points to the first input matrix structure + * @param[in] *pSrcB points to the second input matrix structure + * @param[out] *pDst points to output matrix structure + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range [0x80000000 0x7FFFFFFF] will be saturated. + */ + + +arm_status arm_mat_sub_q31( + const arm_matrix_instance_q31 * pSrcA, + const arm_matrix_instance_q31 * pSrcB, + arm_matrix_instance_q31 * pDst) +{ + q31_t *pIn1 = pSrcA->pData; /* input data matrix pointer A */ + q31_t *pIn2 = pSrcB->pData; /* input data matrix pointer B */ + q31_t *pOut = pDst->pData; /* output data matrix pointer */ + q31_t inA1, inB1; /* temporary variables */ + +#if defined (ARM_MATH_DSP) + + q31_t inA2, inB2; /* temporary variables */ + q31_t out1, out2; /* temporary variables */ + +#endif // #if defined (ARM_MATH_DSP) + + uint32_t numSamples; /* total number of elements in the matrix */ + uint32_t blkCnt; /* loop counters */ + arm_status status; /* status of matrix subtraction */ + + +#ifdef ARM_MATH_MATRIX_CHECK + /* Check for matrix mismatch condition */ + if ((pSrcA->numRows != pSrcB->numRows) || + (pSrcA->numCols != pSrcB->numCols) || + (pSrcA->numRows != pDst->numRows) || (pSrcA->numCols != pDst->numCols)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif + { + /* Total number of samples in the input matrix */ + numSamples = (uint32_t) pSrcA->numRows * pSrcA->numCols; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Loop Unrolling */ + blkCnt = numSamples >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) - B(m,n) */ + /* Subtract, saturate and then store the results in the destination buffer. */ + /* Read values from source A */ + inA1 = pIn1[0]; + + /* Read values from source B */ + inB1 = pIn2[0]; + + /* Read values from source A */ + inA2 = pIn1[1]; + + /* Subtract and saturate */ + out1 = __QSUB(inA1, inB1); + + /* Read values from source B */ + inB2 = pIn2[1]; + + /* Read values from source A */ + inA1 = pIn1[2]; + + /* Subtract and saturate */ + out2 = __QSUB(inA2, inB2); + + /* Read values from source B */ + inB1 = pIn2[2]; + + /* Store result in destination */ + pOut[0] = out1; + pOut[1] = out2; + + /* Read values from source A */ + inA2 = pIn1[3]; + + /* Read values from source B */ + inB2 = pIn2[3]; + + /* Subtract and saturate */ + out1 = __QSUB(inA1, inB1); + + /* Subtract and saturate */ + out2 = __QSUB(inA2, inB2); + + /* Store result in destination */ + pOut[2] = out1; + pOut[3] = out2; + + /* update pointers to process next samples */ + pIn1 += 4U; + pIn2 += 4U; + pOut += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the numSamples is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = numSamples % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = numSamples; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C(m,n) = A(m,n) - B(m,n) */ + /* Subtract, saturate and then store the results in the destination buffer. */ + inA1 = *pIn1++; + inB1 = *pIn2++; + + inA1 = __QSUB(inA1, inB1); + + *pOut++ = inA1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixSub group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_f32.c new file mode 100644 index 0000000..aaedb9d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_f32.c @@ -0,0 +1,206 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_trans_f32.c + * Description: Floating-point matrix transpose + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/** + * @defgroup MatrixTrans Matrix Transpose + * + * Tranposes a matrix. + * Transposing an M x N matrix flips it around the center diagonal and results in an N x M matrix. + * \image html MatrixTranspose.gif "Transpose of a 3 x 3 matrix" + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixTrans + * @{ + */ + +/** + * @brief Floating-point matrix transpose. + * @param[in] *pSrc points to the input matrix + * @param[out] *pDst points to the output matrix + * @return The function returns either ARM_MATH_SIZE_MISMATCH + * or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + + +arm_status arm_mat_trans_f32( + const arm_matrix_instance_f32 * pSrc, + arm_matrix_instance_f32 * pDst) +{ + float32_t *pIn = pSrc->pData; /* input data matrix pointer */ + float32_t *pOut = pDst->pData; /* output data matrix pointer */ + float32_t *px; /* Temporary output data matrix pointer */ + uint16_t nRows = pSrc->numRows; /* number of rows */ + uint16_t nColumns = pSrc->numCols; /* number of columns */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + uint16_t blkCnt, i = 0U, row = nRows; /* loop counters */ + arm_status status; /* status of matrix transpose */ + + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pDst->numCols) || (pSrc->numCols != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Matrix transpose by exchanging the rows with columns */ + /* row loop */ + do + { + /* Loop Unrolling */ + blkCnt = nColumns >> 2; + + /* The pointer px is set to starting address of the column being processed */ + px = pOut + i; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) /* column loop */ + { + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Decrement the column loop counter */ + blkCnt--; + } + + /* Perform matrix transpose for last 3 samples here. */ + blkCnt = nColumns % 0x4U; + + while (blkCnt > 0U) + { + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Decrement the column loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + uint16_t col, i = 0U, row = nRows; /* loop counters */ + arm_status status; /* status of matrix transpose */ + + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pDst->numCols) || (pSrc->numCols != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Matrix transpose by exchanging the rows with columns */ + /* row loop */ + do + { + /* The pointer px is set to starting address of the column being processed */ + px = pOut + i; + + /* Initialize column loop counter */ + col = nColumns; + + while (col > 0U) + { + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Decrement the column loop counter */ + col--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + i++; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); /* row loop end */ + + /* Set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixTrans group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q15.c new file mode 100644 index 0000000..817210c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q15.c @@ -0,0 +1,272 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_trans_q15.c + * Description: Q15 matrix transpose + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixTrans + * @{ + */ + +/* + * @brief Q15 matrix transpose. + * @param[in] *pSrc points to the input matrix + * @param[out] *pDst points to the output matrix + * @return The function returns either ARM_MATH_SIZE_MISMATCH + * or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + +arm_status arm_mat_trans_q15( + const arm_matrix_instance_q15 * pSrc, + arm_matrix_instance_q15 * pDst) +{ + q15_t *pSrcA = pSrc->pData; /* input data matrix pointer */ + q15_t *pOut = pDst->pData; /* output data matrix pointer */ + uint16_t nRows = pSrc->numRows; /* number of nRows */ + uint16_t nColumns = pSrc->numCols; /* number of nColumns */ + uint16_t col, row = nRows, i = 0U; /* row and column loop counters */ + arm_status status; /* status of matrix transpose */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ +#ifndef UNALIGNED_SUPPORT_DISABLE + + q31_t in; /* variable to hold temporary output */ + +#else + + q15_t in; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pDst->numCols) || (pSrc->numCols != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Matrix transpose by exchanging the rows with columns */ + /* row loop */ + do + { + + /* Apply loop unrolling and exchange the columns with row elements */ + col = nColumns >> 2U; + + /* The pointer pOut is set to starting address of the column being processed */ + pOut = pDst->pData + i; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (col > 0U) + { +#ifndef UNALIGNED_SUPPORT_DISABLE + + /* Read two elements from the row */ + in = *__SIMD32(pSrcA)++; + + /* Unpack and store one element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *pOut = (q15_t) in; + +#else + + *pOut = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer pOut to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Unpack and store the second element in the destination */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *pOut = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#else + + *pOut = (q15_t) in; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer pOut to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Read two elements from the row */ +#ifndef ARM_MATH_BIG_ENDIAN + + in = *__SIMD32(pSrcA)++; + +#else + + in = *__SIMD32(pSrcA)++; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Unpack and store one element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *pOut = (q15_t) in; + +#else + + *pOut = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Update the pointer pOut to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Unpack and store the second element in the destination */ +#ifndef ARM_MATH_BIG_ENDIAN + + *pOut = (q15_t) ((in & (q31_t) 0xffff0000) >> 16); + +#else + + *pOut = (q15_t) in; + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + +#else + /* Read one element from the row */ + in = *pSrcA++; + + /* Store one element in the destination */ + *pOut = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Read one element from the row */ + in = *pSrcA++; + + /* Store one element in the destination */ + *pOut = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Read one element from the row */ + in = *pSrcA++; + + /* Store one element in the destination */ + *pOut = in; + + /* Update the pointer px to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Read one element from the row */ + in = *pSrcA++; + + /* Store one element in the destination */ + *pOut = in; + +#endif /* #ifndef UNALIGNED_SUPPORT_DISABLE */ + + /* Update the pointer pOut to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Decrement the column loop counter */ + col--; + } + + /* Perform matrix transpose for last 3 samples here. */ + col = nColumns % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pDst->numCols) || (pSrc->numCols != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Matrix transpose by exchanging the rows with columns */ + /* row loop */ + do + { + /* The pointer pOut is set to starting address of the column being processed */ + pOut = pDst->pData + i; + + /* Initialize column loop counter */ + col = nColumns; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (col > 0U) + { + /* Read and store the input element in the destination */ + *pOut = *pSrcA++; + + /* Update the pointer pOut to point to the next row of the transposed matrix */ + pOut += nRows; + + /* Decrement the column loop counter */ + col--; + } + + i++; + + /* Decrement the row loop counter */ + row--; + + } while (row > 0U); + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixTrans group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q31.c new file mode 100644 index 0000000..9f94938 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/MatrixFunctions/arm_mat_trans_q31.c @@ -0,0 +1,198 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mat_trans_q31.c + * Description: Q31 matrix transpose + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupMatrix + */ + +/** + * @addtogroup MatrixTrans + * @{ + */ + +/* + * @brief Q31 matrix transpose. + * @param[in] *pSrc points to the input matrix + * @param[out] *pDst points to the output matrix + * @return The function returns either ARM_MATH_SIZE_MISMATCH + * or ARM_MATH_SUCCESS based on the outcome of size checking. + */ + +arm_status arm_mat_trans_q31( + const arm_matrix_instance_q31 * pSrc, + arm_matrix_instance_q31 * pDst) +{ + q31_t *pIn = pSrc->pData; /* input data matrix pointer */ + q31_t *pOut = pDst->pData; /* output data matrix pointer */ + q31_t *px; /* Temporary output data matrix pointer */ + uint16_t nRows = pSrc->numRows; /* number of nRows */ + uint16_t nColumns = pSrc->numCols; /* number of nColumns */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + uint16_t blkCnt, i = 0U, row = nRows; /* loop counters */ + arm_status status; /* status of matrix transpose */ + + +#ifdef ARM_MATH_MATRIX_CHECK + + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pDst->numCols) || (pSrc->numCols != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Matrix transpose by exchanging the rows with columns */ + /* row loop */ + do + { + /* Apply loop unrolling and exchange the columns with row elements */ + blkCnt = nColumns >> 2U; + + /* The pointer px is set to starting address of the column being processed */ + px = pOut + i; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Decrement the column loop counter */ + blkCnt--; + } + + /* Perform matrix transpose for last 3 samples here. */ + blkCnt = nColumns % 0x4U; + + while (blkCnt > 0U) + { + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Decrement the column loop counter */ + blkCnt--; + } + +#else + + /* Run the below code for Cortex-M0 */ + + uint16_t col, i = 0U, row = nRows; /* loop counters */ + arm_status status; /* status of matrix transpose */ + + +#ifdef ARM_MATH_MATRIX_CHECK + + /* Check for matrix mismatch condition */ + if ((pSrc->numRows != pDst->numCols) || (pSrc->numCols != pDst->numRows)) + { + /* Set status as ARM_MATH_SIZE_MISMATCH */ + status = ARM_MATH_SIZE_MISMATCH; + } + else +#endif /* #ifdef ARM_MATH_MATRIX_CHECK */ + + { + /* Matrix transpose by exchanging the rows with columns */ + /* row loop */ + do + { + /* The pointer px is set to starting address of the column being processed */ + px = pOut + i; + + /* Initialize column loop counter */ + col = nColumns; + + while (col > 0U) + { + /* Read and store the input element in the destination */ + *px = *pIn++; + + /* Update the pointer px to point to the next row of the transposed matrix */ + px += nRows; + + /* Decrement the column loop counter */ + col--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + i++; + + /* Decrement the row loop counter */ + row--; + + } + while (row > 0U); /* row loop end */ + + /* set status as ARM_MATH_SUCCESS */ + status = ARM_MATH_SUCCESS; + } + + /* Return to application */ + return (status); +} + +/** + * @} end of MatrixTrans group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_f32.c new file mode 100644 index 0000000..3a77a9f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_f32.c @@ -0,0 +1,170 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_max_f32.c + * Description: Maximum value of a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @defgroup Max Maximum + * + * Computes the maximum value of an array of data. + * The function returns both the maximum value and its position within the array. + * There are separate functions for floating-point, Q31, Q15, and Q7 data types. + */ + +/** + * @addtogroup Max + * @{ + */ + + +/** + * @brief Maximum value of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult maximum value returned here + * @param[out] *pIndex index of maximum value returned here + * @return none. + */ + +void arm_max_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t maxVal1, maxVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 1U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 2U; + } + + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 3U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + float32_t maxVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and it's index */ + out = maxVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the maximum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Max group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q15.c new file mode 100644 index 0000000..c2fead2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q15.c @@ -0,0 +1,162 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_max_q15.c + * Description: Maximum value of a Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup Max + * @{ + */ + + +/** + * @brief Maximum value of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult maximum value returned here + * @param[out] *pIndex index of maximum value returned here + * @return none. + */ + +void arm_max_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t maxVal1, maxVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 1U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 2U; + } + + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 3U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + q15_t maxVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and it's index */ + out = maxVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the maximum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Max group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q31.c new file mode 100644 index 0000000..5e90693 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q31.c @@ -0,0 +1,162 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_max_q31.c + * Description: Maximum value of a Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup Max + * @{ + */ + + +/** + * @brief Maximum value of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult maximum value returned here + * @param[out] *pIndex index of maximum value returned here + * @return none. + */ + +void arm_max_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t maxVal1, maxVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 1U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 2U; + } + + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 3U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + q31_t maxVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and it's index */ + out = maxVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the maximum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Max group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q7.c new file mode 100644 index 0000000..6cd6f60 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_max_q7.c @@ -0,0 +1,162 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_max_q7.c + * Description: Maximum value of a Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup Max + * @{ + */ + + +/** + * @brief Maximum value of a Q7 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult maximum value returned here + * @param[out] *pIndex index of maximum value returned here + * @return none. + */ + +void arm_max_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q7_t maxVal1, maxVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 1U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 2U; + } + + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + maxVal2 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and its index */ + out = maxVal1; + outIndex = count + 3U; + } + + /* compare for the maximum value */ + if (out < maxVal2) + { + /* Update the maximum value and its index */ + out = maxVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + q7_t maxVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize maxVal to the next consecutive values one by one */ + maxVal1 = *pSrc++; + + /* compare for the maximum value */ + if (out < maxVal1) + { + /* Update the maximum value and it's index */ + out = maxVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the maximum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Max group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_f32.c new file mode 100644 index 0000000..8a59188 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_f32.c @@ -0,0 +1,125 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mean_f32.c + * Description: Mean value of a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @defgroup mean Mean + * + * Calculates the mean of the input vector. Mean is defined as the average of the elements in the vector. + * The underlying algorithm is used: + * + *
+ * 	Result = (pSrc[0] + pSrc[1] + pSrc[2] + ... + pSrc[blockSize-1]) / blockSize;
+ * 
+ * + * There are separate functions for floating-point, Q31, Q15, and Q7 data types. + */ + +/** + * @addtogroup mean + * @{ + */ + + +/** + * @brief Mean value of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult mean value returned here + * @return none. + */ + +void arm_mean_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + float32_t sum = 0.0f; /* Temporary result storage */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t in1, in2, in3, in4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + sum += in1; + sum += in2; + sum += in3; + sum += in4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + sum += *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) / blockSize */ + /* Store the result to the destination */ + *pResult = sum / (float32_t) blockSize; +} + +/** + * @} end of mean group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q15.c new file mode 100644 index 0000000..9ef0914 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q15.c @@ -0,0 +1,120 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mean_q15.c + * Description: Mean value of a Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup mean + * @{ + */ + + +/** + * @brief Mean value of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult mean value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 32-bit internal accumulator. + * The input is represented in 1.15 format and is accumulated in a 32-bit + * accumulator in 17.15 format. + * There is no risk of internal overflow with this approach, and the + * full precision of intermediate result is preserved. + * Finally, the accumulator is saturated and truncated to yield a result of 1.15 format. + * + */ + +void arm_mean_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult) +{ + q31_t sum = 0; /* Temporary result storage */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + in = *__SIMD32(pSrc)++; + sum += ((in << 16U) >> 16U); + sum += (in >> 16U); + in = *__SIMD32(pSrc)++; + sum += ((in << 16U) >> 16U); + sum += (in >> 16U); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + sum += *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) / blockSize */ + /* Store the result to the destination */ + *pResult = (q15_t) (sum / (q31_t)blockSize); +} + +/** + * @} end of mean group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q31.c new file mode 100644 index 0000000..def314a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q31.c @@ -0,0 +1,123 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mean_q31.c + * Description: Mean value of a Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup mean + * @{ + */ + + +/** + * @brief Mean value of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult mean value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + *\par + * The function is implemented using a 64-bit internal accumulator. + * The input is represented in 1.31 format and is accumulated in a 64-bit + * accumulator in 33.31 format. + * There is no risk of internal overflow with this approach, and the + * full precision of intermediate result is preserved. + * Finally, the accumulator is truncated to yield a result of 1.31 format. + * + */ + +void arm_mean_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult) +{ + q63_t sum = 0; /* Temporary result storage */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in1, in2, in3, in4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + sum += in1; + sum += in2; + sum += in3; + sum += in4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + sum += *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) / blockSize */ + /* Store the result to the destination */ + *pResult = (q31_t) (sum / (int32_t) blockSize); +} + +/** + * @} end of mean group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q7.c new file mode 100644 index 0000000..ae60869 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_mean_q7.c @@ -0,0 +1,120 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_mean_q7.c + * Description: Mean value of a Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup mean + * @{ + */ + + +/** + * @brief Mean value of a Q7 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult mean value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * \par + * The function is implemented using a 32-bit internal accumulator. + * The input is represented in 1.7 format and is accumulated in a 32-bit + * accumulator in 25.7 format. + * There is no risk of internal overflow with this approach, and the + * full precision of intermediate result is preserved. + * Finally, the accumulator is truncated to yield a result of 1.7 format. + * + */ + +void arm_mean_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult) +{ + q31_t sum = 0; /* Temporary result storage */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + in = *__SIMD32(pSrc)++; + + sum += ((in << 24U) >> 24U); + sum += ((in << 16U) >> 24U); + sum += ((in << 8U) >> 24U); + sum += (in >> 24U); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + sum += *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) / blockSize */ + /* Store the result to the destination */ + *pResult = (q7_t) (sum / (int32_t) blockSize); +} + +/** + * @} end of mean group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_f32.c new file mode 100644 index 0000000..6ef11f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_f32.c @@ -0,0 +1,170 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_min_f32.c + * Description: Minimum value of a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @defgroup Min Minimum + * + * Computes the minimum value of an array of data. + * The function returns both the minimum value and its position within the array. + * There are separate functions for floating-point, Q31, Q15, and Q7 data types. + */ + +/** + * @addtogroup Min + * @{ + */ + + +/** + * @brief Minimum value of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult minimum value returned here + * @param[out] *pIndex index of minimum value returned here + * @return none. + */ + +void arm_min_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t minVal1, minVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 1U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 2U; + } + + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 3U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + float32_t minVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and it's index */ + out = minVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the minimum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Min group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q15.c new file mode 100644 index 0000000..aa7e424 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q15.c @@ -0,0 +1,163 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_min_q15.c + * Description: Minimum value of a Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + + +/** + * @addtogroup Min + * @{ + */ + + +/** + * @brief Minimum value of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult minimum value returned here + * @param[out] *pIndex index of minimum value returned here + * @return none. + */ + +void arm_min_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q15_t minVal1, minVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 1U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 2U; + } + + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 3U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + q15_t minVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and it's index */ + out = minVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the minimum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Min group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q31.c new file mode 100644 index 0000000..57dd195 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q31.c @@ -0,0 +1,163 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_min_q31.c + * Description: Minimum value of a Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + + +/** + * @addtogroup Min + * @{ + */ + + +/** + * @brief Minimum value of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult minimum value returned here + * @param[out] *pIndex index of minimum value returned here + * @return none. + */ + +void arm_min_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t minVal1, minVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 1U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 2U; + } + + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 3U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + q31_t minVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and it's index */ + out = minVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the minimum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Min group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q7.c new file mode 100644 index 0000000..ac96603 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_min_q7.c @@ -0,0 +1,163 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_min_q7.c + * Description: Minimum value of a Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + + +/** + * @addtogroup Min + * @{ + */ + + +/** + * @brief Minimum value of a Q7 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult minimum value returned here + * @param[out] *pIndex index of minimum value returned here + * @return none. + */ + +void arm_min_q7( + q7_t * pSrc, + uint32_t blockSize, + q7_t * pResult, + uint32_t * pIndex) +{ +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q7_t minVal1, minVal2, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex, count; /* loop counter */ + + /* Initialise the count value. */ + count = 0U; + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + /* Loop unrolling */ + blkCnt = (blockSize - 1U) >> 2U; + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 1U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 2U; + } + + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + minVal2 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and its index */ + out = minVal1; + outIndex = count + 3U; + } + + /* compare for the minimum value */ + if (out > minVal2) + { + /* Update the minimum value and its index */ + out = minVal2; + outIndex = count + 4U; + } + + count += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* if (blockSize - 1U) is not multiple of 4 */ + blkCnt = (blockSize - 1U) % 4U; + +#else + /* Run the below code for Cortex-M0 */ + + q7_t minVal1, out; /* Temporary variables to store the output value. */ + uint32_t blkCnt, outIndex; /* loop counter */ + + /* Initialise the index value to zero. */ + outIndex = 0U; + /* Load first input value that act as reference value for comparision */ + out = *pSrc++; + + blkCnt = (blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* Initialize minVal to the next consecutive values one by one */ + minVal1 = *pSrc++; + + /* compare for the minimum value */ + if (out > minVal1) + { + /* Update the minimum value and it's index */ + out = minVal1; + outIndex = blockSize - blkCnt; + } + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the minimum value and it's index into destination pointers */ + *pResult = out; + *pIndex = outIndex; +} + +/** + * @} end of Min group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_f32.c new file mode 100644 index 0000000..bfe4dd3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_f32.c @@ -0,0 +1,129 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_power_f32.c + * Description: Sum of the squares of the elements of a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @defgroup power Power + * + * Calculates the sum of the squares of the elements in the input vector. + * The underlying algorithm is used: + * + *
+ * 	Result = pSrc[0] * pSrc[0] + pSrc[1] * pSrc[1] + pSrc[2] * pSrc[2] + ... + pSrc[blockSize-1] * pSrc[blockSize-1];
+ * 
+ * + * There are separate functions for floating point, Q31, Q15, and Q7 data types. + */ + +/** + * @addtogroup power + * @{ + */ + + +/** + * @brief Sum of the squares of the elements of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult sum of the squares value returned here + * @return none. + * + */ + + +void arm_power_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + float32_t sum = 0.0f; /* accumulator */ + float32_t in; /* Temporary variable to store input value */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute Power and then store the result in a temporary variable, sum. */ + in = *pSrc++; + sum += in * in; + in = *pSrc++; + sum += in * in; + in = *pSrc++; + sum += in * in; + in = *pSrc++; + sum += in * in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* compute power and then store the result in a temporary variable, sum. */ + in = *pSrc++; + sum += in * in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the result to the destination */ + *pResult = sum; +} + +/** + * @} end of power group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q15.c new file mode 100644 index 0000000..fbe73d1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q15.c @@ -0,0 +1,138 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_power_q15.c + * Description: Sum of the squares of the elements of a Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup power + * @{ + */ + +/** + * @brief Sum of the squares of the elements of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult sum of the squares value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * The input is represented in 1.15 format. + * Intermediate multiplication yields a 2.30 format, and this + * result is added without saturation to a 64-bit accumulator in 34.30 format. + * With 33 guard bits in the accumulator, there is no risk of overflow, and the + * full precision of the intermediate multiplication is preserved. + * Finally, the return result is in 34.30 format. + * + */ + +void arm_power_q15( + q15_t * pSrc, + uint32_t blockSize, + q63_t * pResult) +{ + q63_t sum = 0; /* Temporary result storage */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in32; /* Temporary variable to store input value */ + q15_t in16; /* Temporary variable to store input value */ + uint32_t blkCnt; /* loop counter */ + + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute Power and then store the result in a temporary variable, sum. */ + in32 = *__SIMD32(pSrc)++; + sum = __SMLALD(in32, in32, sum); + in32 = *__SIMD32(pSrc)++; + sum = __SMLALD(in32, in32, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute Power and then store the result in a temporary variable, sum. */ + in16 = *pSrc++; + sum = __SMLALD(in16, in16, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + +#else + /* Run the below code for Cortex-M0 */ + + q15_t in; /* Temporary variable to store input value */ + uint32_t blkCnt; /* loop counter */ + + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute Power and then store the result in a temporary variable, sum. */ + in = *pSrc++; + sum += ((q31_t) in * in); + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Store the results in 34.30 format */ + *pResult = sum; +} + +/** + * @} end of power group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q31.c new file mode 100644 index 0000000..498face --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q31.c @@ -0,0 +1,129 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_power_q31.c + * Description: Sum of the squares of the elements of a Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup power + * @{ + */ + +/** + * @brief Sum of the squares of the elements of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult sum of the squares value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * The input is represented in 1.31 format. + * Intermediate multiplication yields a 2.62 format, and this + * result is truncated to 2.48 format by discarding the lower 14 bits. + * The 2.48 result is then added without saturation to a 64-bit accumulator in 16.48 format. + * With 15 guard bits in the accumulator, there is no risk of overflow, and the + * full precision of the intermediate multiplication is preserved. + * Finally, the return result is in 16.48 format. + * + */ + +void arm_power_q31( + q31_t * pSrc, + uint32_t blockSize, + q63_t * pResult) +{ + q63_t sum = 0; /* Temporary result storage */ + q31_t in; + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute Power then shift intermediate results by 14 bits to maintain 16.48 format and then store the result in a temporary variable sum, providing 15 guard bits. */ + in = *pSrc++; + sum += ((q63_t) in * in) >> 14U; + + in = *pSrc++; + sum += ((q63_t) in * in) >> 14U; + + in = *pSrc++; + sum += ((q63_t) in * in) >> 14U; + + in = *pSrc++; + sum += ((q63_t) in * in) >> 14U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute Power and then store the result in a temporary variable, sum. */ + in = *pSrc++; + sum += ((q63_t) in * in) >> 14U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the results in 16.48 format */ + *pResult = sum; +} + +/** + * @} end of power group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q7.c new file mode 100644 index 0000000..3b8335a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_power_q7.c @@ -0,0 +1,127 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_power_q7.c + * Description: Sum of the squares of the elements of a Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup power + * @{ + */ + +/** + * @brief Sum of the squares of the elements of a Q7 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult sum of the squares value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 32-bit internal accumulator. + * The input is represented in 1.7 format. + * Intermediate multiplication yields a 2.14 format, and this + * result is added without saturation to an accumulator in 18.14 format. + * With 17 guard bits in the accumulator, there is no risk of overflow, and the + * full precision of the intermediate multiplication is preserved. + * Finally, the return result is in 18.14 format. + * + */ + +void arm_power_q7( + q7_t * pSrc, + uint32_t blockSize, + q31_t * pResult) +{ + q31_t sum = 0; /* Temporary result storage */ + q7_t in; /* Temporary variable to store input */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t input1; /* Temporary variable to store packed input */ + q31_t in1, in2; /* Temporary variables to store input */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* Reading two inputs of pSrc vector and packing */ + input1 = *__SIMD32(pSrc)++; + + in1 = __SXTB16(__ROR(input1, 8)); + in2 = __SXTB16(input1); + + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* calculate power and accumulate to accumulator */ + sum = __SMLAD(in1, in1, sum); + sum = __SMLAD(in2, in2, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute Power and then store the result in a temporary variable, sum. */ + in = *pSrc++; + sum += ((q15_t) in * in); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Store the result in 18.14 format */ + *pResult = sum; +} + +/** + * @} end of power group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_f32.c new file mode 100644 index 0000000..3089d40 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_f32.c @@ -0,0 +1,127 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rms_f32.c + * Description: Root mean square value of an array of F32 type + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @defgroup RMS Root mean square (RMS) + * + * + * Calculates the Root Mean Sqaure of the elements in the input vector. + * The underlying algorithm is used: + * + *
+ * 	Result = sqrt(((pSrc[0] * pSrc[0] + pSrc[1] * pSrc[1] + ... + pSrc[blockSize-1] * pSrc[blockSize-1]) / blockSize));
+ * 
+ * + * There are separate functions for floating point, Q31, and Q15 data types. + */ + +/** + * @addtogroup RMS + * @{ + */ + + +/** + * @brief Root Mean Square of the elements of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult rms value returned here + * @return none. + * + */ + +void arm_rms_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + float32_t sum = 0.0f; /* Accumulator */ + float32_t in; /* Tempoprary variable to store input value */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute sum of the squares and then store the result in a temporary variable, sum */ + in = *pSrc++; + sum += in * in; + in = *pSrc++; + sum += in * in; + in = *pSrc++; + sum += in * in; + in = *pSrc++; + sum += in * in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute sum of the squares and then store the results in a temporary variable, sum */ + in = *pSrc++; + sum += in * in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Rms and store the result in the destination */ + arm_sqrt_f32(sum / (float32_t) blockSize, pResult); +} + +/** + * @} end of RMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q15.c new file mode 100644 index 0000000..7cc2e12 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q15.c @@ -0,0 +1,139 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rms_q15.c + * Description: Root Mean Square of the elements of a Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @addtogroup RMS + * @{ + */ + +/** + * @brief Root Mean Square of the elements of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult rms value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * The input is represented in 1.15 format. + * Intermediate multiplication yields a 2.30 format, and this + * result is added without saturation to a 64-bit accumulator in 34.30 format. + * With 33 guard bits in the accumulator, there is no risk of overflow, and the + * full precision of the intermediate multiplication is preserved. + * Finally, the 34.30 result is truncated to 34.15 format by discarding the lower + * 15 bits, and then saturated to yield a result in 1.15 format. + * + */ + +void arm_rms_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult) +{ + q63_t sum = 0; /* accumulator */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in; /* temporary variable to store the input value */ + q15_t in1; /* temporary variable to store the input value */ + uint32_t blkCnt; /* loop counter */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute sum of the squares and then store the results in a temporary variable, sum */ + in = *__SIMD32(pSrc)++; + sum = __SMLALD(in, in, sum); + in = *__SIMD32(pSrc)++; + sum = __SMLALD(in, in, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute sum of the squares and then store the results in a temporary variable, sum */ + in1 = *pSrc++; + sum = __SMLALD(in1, in1, sum); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Truncating and saturating the accumulator to 1.15 format */ + /* Store the result in the destination */ + arm_sqrt_q15(__SSAT((sum / (q63_t)blockSize) >> 15, 16), pResult); + +#else + /* Run the below code for Cortex-M0 */ + + q15_t in; /* temporary variable to store the input value */ + uint32_t blkCnt; /* loop counter */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute sum of the squares and then store the results in a temporary variable, sum */ + in = *pSrc++; + sum += ((q31_t) in * in); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Truncating and saturating the accumulator to 1.15 format */ + /* Store the result in the destination */ + arm_sqrt_q15(__SSAT((sum / (q63_t)blockSize) >> 15, 16), pResult); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of RMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q31.c new file mode 100644 index 0000000..7cb9149 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_rms_q31.c @@ -0,0 +1,137 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rms_q31.c + * Description: Root Mean Square of the elements of a Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @addtogroup RMS + * @{ + */ + + +/** + * @brief Root Mean Square of the elements of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult rms value returned here + * @return none. + * + * @details + * Scaling and Overflow Behavior: + * + *\par + * The function is implemented using an internal 64-bit accumulator. + * The input is represented in 1.31 format, and intermediate multiplication + * yields a 2.62 format. + * The accumulator maintains full precision of the intermediate multiplication results, + * but provides only a single guard bit. + * There is no saturation on intermediate additions. + * If the accumulator overflows, it wraps around and distorts the result. + * In order to avoid overflows completely, the input signal must be scaled down by + * log2(blockSize) bits, as a total of blockSize additions are performed internally. + * Finally, the 2.62 accumulator is right shifted by 31 bits to yield a 1.31 format value. + * + */ + +void arm_rms_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult) +{ + q63_t sum = 0; /* accumulator */ + q31_t in; /* Temporary variable to store the input */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t in1, in2, in3, in4; /* Temporary input variables */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 8 outputs at a time. + ** a second loop below computes the remaining 1 to 7 samples. */ + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute sum of the squares and then store the result in a temporary variable, sum */ + /* read two samples from source buffer */ + in1 = pSrc[0]; + in2 = pSrc[1]; + + /* calculate power and accumulate to accumulator */ + sum += (q63_t) in1 *in1; + sum += (q63_t) in2 *in2; + + /* read two samples from source buffer */ + in3 = pSrc[2]; + in4 = pSrc[3]; + + /* calculate power and accumulate to accumulator */ + sum += (q63_t) in3 *in3; + sum += (q63_t) in4 *in4; + + + /* update source buffer to process next samples */ + pSrc += 4U; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 8, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + /* Run the below code for Cortex-M0 */ + + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A[0] * A[0] + A[1] * A[1] + A[2] * A[2] + ... + A[blockSize-1] * A[blockSize-1] */ + /* Compute sum of the squares and then store the results in a temporary variable, sum */ + in = *pSrc++; + sum += (q63_t) in *in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Convert data in 2.62 to 1.31 by 31 right shifts and saturate */ + /* Compute Rms and store the result in the destination vector */ + arm_sqrt_q31(clip_q63_to_q31((sum / (q63_t) blockSize) >> 31), pResult); +} + +/** + * @} end of RMS group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_f32.c new file mode 100644 index 0000000..e082fc6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_f32.c @@ -0,0 +1,186 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_std_f32.c + * Description: Standard deviation of the elements of a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @defgroup STD Standard deviation + * + * Calculates the standard deviation of the elements in the input vector. + * The underlying algorithm is used: + * + *
+ *   Result = sqrt((sumOfSquares - sum2 / blockSize) / (blockSize - 1))
+ *
+ *     where, sumOfSquares = pSrc[0] * pSrc[0] + pSrc[1] * pSrc[1] + ... + pSrc[blockSize-1] * pSrc[blockSize-1]
+ *
+ *                     sum = pSrc[0] + pSrc[1] + pSrc[2] + ... + pSrc[blockSize-1]
+ * 
+ * + * There are separate functions for floating point, Q31, and Q15 data types. + */ + +/** + * @addtogroup STD + * @{ + */ + + +/** + * @brief Standard deviation of the elements of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult standard deviation value returned here + * @return none. + */ + +void arm_std_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + float32_t sum = 0.0f; /* Temporary result storage */ + float32_t sumOfSquares = 0.0f; /* Sum of squares */ + float32_t in; /* input value */ + uint32_t blkCnt; /* loop counter */ +#if defined (ARM_MATH_DSP) + float32_t meanOfSquares, mean, squareOfMean; /* Temporary variables */ +#else + float32_t squareOfSum; /* Square of Sum */ + float32_t var; /* Temporary varaince storage */ +#endif + + if (blockSize == 1U) + { + *pResult = 0; + return; + } + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *pSrc++; + sum += in; + sumOfSquares += in * in; + in = *pSrc++; + sum += in; + sumOfSquares += in * in; + in = *pSrc++; + sum += in; + sumOfSquares += in * in; + in = *pSrc++; + sum += in; + sumOfSquares += in * in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *pSrc++; + sum += in; + sumOfSquares += in * in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = sumOfSquares / ((float32_t) blockSize - 1.0f); + + /* Compute mean of all input values */ + mean = sum / (float32_t) blockSize; + + /* Compute square of mean */ + squareOfMean = (mean * mean) * (((float32_t) blockSize) / + ((float32_t) blockSize - 1.0f)); + + /* Compute standard deviation and then store the result to the destination */ + arm_sqrt_f32((meanOfSquares - squareOfMean), pResult); + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sumOfSquares. */ + in = *pSrc++; + sumOfSquares += in * in; + + /* C = (A[0] + A[1] + ... + A[blockSize-1]) */ + /* Compute Sum of the input samples + * and then store the result in a temporary variable, sum. */ + sum += in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute the square of sum */ + squareOfSum = ((sum * sum) / (float32_t) blockSize); + + /* Compute the variance */ + var = ((sumOfSquares - squareOfSum) / (float32_t) (blockSize - 1.0f)); + + /* Compute standard deviation and then store the result to the destination */ + arm_sqrt_f32(var, pResult); + +#endif /* #if defined (ARM_MATH_DSP) */ +} + +/** + * @} end of STD group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q15.c new file mode 100644 index 0000000..e3626d8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q15.c @@ -0,0 +1,174 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_std_q15.c + * Description: Standard deviation of an array of Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup STD + * @{ + */ + +/** + * @brief Standard deviation of the elements of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult standard deviation value returned here + * @return none. + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * The input is represented in 1.15 format. + * Intermediate multiplication yields a 2.30 format, and this + * result is added without saturation to a 64-bit accumulator in 34.30 format. + * With 33 guard bits in the accumulator, there is no risk of overflow, and the + * full precision of the intermediate multiplication is preserved. + * Finally, the 34.30 result is truncated to 34.15 format by discarding the lower + * 15 bits, and then saturated to yield a result in 1.15 format. + */ + +void arm_std_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult) +{ + q31_t sum = 0; /* Accumulator */ + q31_t meanOfSquares, squareOfMean; /* square of mean and mean of square */ + uint32_t blkCnt; /* loop counter */ + q63_t sumOfSquares = 0; /* Accumulator */ +#if defined (ARM_MATH_DSP) + q31_t in; /* input value */ + q15_t in1; /* input value */ +#else + q15_t in; /* input value */ +#endif + + if (blockSize == 1U) + { + *pResult = 0; + return; + } + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *__SIMD32(pSrc)++; + sum += ((in << 16U) >> 16U); + sum += (in >> 16U); + sumOfSquares = __SMLALD(in, in, sumOfSquares); + in = *__SIMD32(pSrc)++; + sum += ((in << 16U) >> 16U); + sum += (in >> 16U); + sumOfSquares = __SMLALD(in, in, sumOfSquares); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in1 = *pSrc++; + sumOfSquares = __SMLALD(in1, in1, sumOfSquares); + sum += in1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = (q31_t)(sumOfSquares / (q63_t)(blockSize - 1U)); + + /* Compute square of mean */ + squareOfMean = (q31_t)((q63_t)sum * sum / (q63_t)(blockSize * (blockSize - 1U))); + + /* mean of the squares minus the square of the mean. */ + /* Compute standard deviation and store the result to the destination */ + arm_sqrt_q15(__SSAT((meanOfSquares - squareOfMean) >> 15U, 16U), pResult); + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sumOfSquares. */ + in = *pSrc++; + sumOfSquares += (in * in); + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + /* Compute sum of all input values and then store the result in a temporary variable, sum. */ + sum += in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = (q31_t)(sumOfSquares / (q63_t)(blockSize - 1U)); + + /* Compute square of mean */ + squareOfMean = (q31_t)((q63_t)sum * sum / (q63_t)(blockSize * (blockSize - 1U))); + + /* mean of the squares minus the square of the mean. */ + /* Compute standard deviation and store the result to the destination */ + arm_sqrt_q15(__SSAT((meanOfSquares - squareOfMean) >> 15U, 16U), pResult); + +#endif /* #if defined (ARM_MATH_DSP) */ +} + +/** + * @} end of STD group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q31.c new file mode 100644 index 0000000..806a90e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_std_q31.c @@ -0,0 +1,169 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_std_q31.c + * Description: Standard deviation of an array of Q31 type. + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup STD + * @{ + */ + +/** + * @brief Standard deviation of the elements of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult standard deviation value returned here + * @return none. + * @details + * Scaling and Overflow Behavior: + * + *\par + * The function is implemented using an internal 64-bit accumulator. + * The input is represented in 1.31 format, which is then downshifted by 8 bits + * which yields 1.23, and intermediate multiplication yields a 2.46 format. + * The accumulator maintains full precision of the intermediate multiplication results, + * but provides only a 16 guard bits. + * There is no saturation on intermediate additions. + * If the accumulator overflows it wraps around and distorts the result. + * In order to avoid overflows completely the input signal must be scaled down by + * log2(blockSize)-8 bits, as a total of blockSize additions are performed internally. + * After division, internal variables should be Q18.46 + * Finally, the 18.46 accumulator is right shifted by 15 bits to yield a 1.31 format value. + * + */ + +void arm_std_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult) +{ + q63_t sum = 0; /* Accumulator */ + q63_t meanOfSquares, squareOfMean; /* square of mean and mean of square */ + q31_t in; /* input value */ + uint32_t blkCnt; /* loop counter */ + q63_t sumOfSquares = 0; /* Accumulator */ + + if (blockSize == 1U) + { + *pResult = 0; + return; + } + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = sumOfSquares / (q63_t)(blockSize - 1U); + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sumOfSquares. */ + in = *pSrc++ >> 8U; + sumOfSquares += ((q63_t) (in) * (in)); + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + /* Compute sum of all input values and then store the result in a temporary variable, sum. */ + sum += in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = sumOfSquares / (q63_t)(blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Compute square of mean */ + squareOfMean = sum * sum / (q63_t)(blockSize * (blockSize - 1U)); + + /* Compute standard deviation and then store the result to the destination */ + arm_sqrt_q31((meanOfSquares - squareOfMean) >> 15U, pResult); +} + +/** + * @} end of STD group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_f32.c new file mode 100644 index 0000000..a366f5c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_f32.c @@ -0,0 +1,181 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_var_f32.c + * Description: Variance of the elements of a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @defgroup variance Variance + * + * Calculates the variance of the elements in the input vector. + * The underlying algorithm used is the direct method sometimes referred to as the two-pass method: + * + *
+ *   Result = sum(element - meanOfElements)^2) / numElement - 1
+ *
+ *     where, meanOfElements = ( pSrc[0] * pSrc[0] + pSrc[1] * pSrc[1] + ... + pSrc[blockSize-1] ) / blockSize
+ *
+ * 
+ * + * There are separate functions for floating point, Q31, and Q15 data types. + */ + +/** + * @addtogroup variance + * @{ + */ + + +/** + * @brief Variance of the elements of a floating-point vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult variance value returned here + * @return none. + */ + +void arm_var_f32( + float32_t * pSrc, + uint32_t blockSize, + float32_t * pResult) +{ + float32_t fMean, fValue; + uint32_t blkCnt; /* loop counter */ + float32_t * pInput = pSrc; + float32_t sum = 0.0f; + float32_t fSum = 0.0f; + #if defined(ARM_MATH_DSP) + float32_t in1, in2, in3, in4; + #endif + + if (blockSize <= 1U) + { + *pResult = 0; + return; + } + + #if defined(ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M7 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + in1 = *pInput++; + in2 = *pInput++; + in3 = *pInput++; + in4 = *pInput++; + + sum += in1; + sum += in2; + sum += in3; + sum += in4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + #else + /* Run the below code for Cortex-M0 or Cortex-M3 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + #endif + + while (blkCnt > 0U) + { + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + sum += *pInput++; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) / blockSize */ + fMean = sum / (float32_t) blockSize; + + pInput = pSrc; + + #if defined(ARM_MATH_DSP) + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + fValue = *pInput++ - fMean; + fSum += fValue * fValue; + fValue = *pInput++ - fMean; + fSum += fValue * fValue; + fValue = *pInput++ - fMean; + fSum += fValue * fValue; + fValue = *pInput++ - fMean; + fSum += fValue * fValue; + + /* Decrement the loop counter */ + blkCnt--; + } + + blkCnt = blockSize % 0x4U; + #else + /* Run the below code for Cortex-M0 or Cortex-M3 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + #endif + + while (blkCnt > 0U) + { + fValue = *pInput++ - fMean; + fSum += fValue * fValue; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Variance */ + *pResult = fSum / (float32_t)(blockSize - 1.0f); +} + +/** + * @} end of variance group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q15.c new file mode 100644 index 0000000..ff9972a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q15.c @@ -0,0 +1,172 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_var_q15.c + * Description: Variance of an array of Q15 type + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup variance + * @{ + */ + +/** + * @brief Variance of the elements of a Q15 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult variance value returned here + * @return none. + * @details + * Scaling and Overflow Behavior: + * + * \par + * The function is implemented using a 64-bit internal accumulator. + * The input is represented in 1.15 format. + * Intermediate multiplication yields a 2.30 format, and this + * result is added without saturation to a 64-bit accumulator in 34.30 format. + * With 33 guard bits in the accumulator, there is no risk of overflow, and the + * full precision of the intermediate multiplication is preserved. + * Finally, the 34.30 result is truncated to 34.15 format by discarding the lower + * 15 bits, and then saturated to yield a result in 1.15 format. + */ + +void arm_var_q15( + q15_t * pSrc, + uint32_t blockSize, + q15_t * pResult) +{ + q31_t sum = 0; /* Accumulator */ + q31_t meanOfSquares, squareOfMean; /* square of mean and mean of square */ + uint32_t blkCnt; /* loop counter */ + q63_t sumOfSquares = 0; /* Accumulator */ +#if defined (ARM_MATH_DSP) + q31_t in; /* input value */ + q15_t in1; /* input value */ +#else + q15_t in; /* input value */ +#endif + + if (blockSize == 1U) + { + *pResult = 0; + return; + } + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *__SIMD32(pSrc)++; + sum += ((in << 16U) >> 16U); + sum += (in >> 16U); + sumOfSquares = __SMLALD(in, in, sumOfSquares); + in = *__SIMD32(pSrc)++; + sum += ((in << 16U) >> 16U); + sum += (in >> 16U); + sumOfSquares = __SMLALD(in, in, sumOfSquares); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in1 = *pSrc++; + sumOfSquares = __SMLALD(in1, in1, sumOfSquares); + sum += in1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = (q31_t)(sumOfSquares / (q63_t)(blockSize - 1U)); + + /* Compute square of mean */ + squareOfMean = (q31_t)((q63_t)sum * sum / (q63_t)(blockSize * (blockSize - 1U))); + + /* mean of the squares minus the square of the mean. */ + *pResult = (meanOfSquares - squareOfMean) >> 15U; + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sumOfSquares. */ + in = *pSrc++; + sumOfSquares += (in * in); + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + /* Compute sum of all input values and then store the result in a temporary variable, sum. */ + sum += in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = (q31_t)(sumOfSquares / (q63_t)(blockSize - 1U)); + + /* Compute square of mean */ + squareOfMean = (q31_t)((q63_t)sum * sum / (q63_t)(blockSize * (blockSize - 1U))); + + /* mean of the squares minus the square of the mean. */ + *pResult = (meanOfSquares - squareOfMean) >> 15; + +#endif /* #if defined (ARM_MATH_DSP) */ +} + +/** + * @} end of variance group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q31.c new file mode 100644 index 0000000..08e80fe --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/StatisticsFunctions/arm_var_q31.c @@ -0,0 +1,169 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_var_q31.c + * Description: Variance of an array of Q31 type + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupStats + */ + +/** + * @addtogroup variance + * @{ + */ + +/** + * @brief Variance of the elements of a Q31 vector. + * @param[in] *pSrc points to the input vector + * @param[in] blockSize length of the input vector + * @param[out] *pResult variance value returned here + * @return none. + * @details + * Scaling and Overflow Behavior: + * + *\par + * The function is implemented using an internal 64-bit accumulator. + * The input is represented in 1.31 format, which is then downshifted by 8 bits + * which yields 1.23, and intermediate multiplication yields a 2.46 format. + * The accumulator maintains full precision of the intermediate multiplication results, + * but provides only a 16 guard bits. + * There is no saturation on intermediate additions. + * If the accumulator overflows it wraps around and distorts the result. + * In order to avoid overflows completely the input signal must be scaled down by + * log2(blockSize)-8 bits, as a total of blockSize additions are performed internally. + * After division, internal variables should be Q18.46 + * Finally, the 18.46 accumulator is right shifted by 15 bits to yield a 1.31 format value. + * + */ + +void arm_var_q31( + q31_t * pSrc, + uint32_t blockSize, + q31_t * pResult) +{ + q63_t sum = 0; /* Accumulator */ + q63_t meanOfSquares, squareOfMean; /* square of mean and mean of square */ + q31_t in; /* input value */ + uint32_t blkCnt; /* loop counter */ + q63_t sumOfSquares = 0; /* Accumulator */ + + if (blockSize == 1U) + { + *pResult = 0; + return; + } + +#if defined (ARM_MATH_DSP) + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sum. */ + in = *pSrc++ >> 8U; + sum += in; + sumOfSquares += ((q63_t) (in) * (in)); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = sumOfSquares / (q63_t)(blockSize - 1U); + +#else + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + /* C = (A[0] * A[0] + A[1] * A[1] + ... + A[blockSize-1] * A[blockSize-1]) */ + /* Compute Sum of squares of the input samples + * and then store the result in a temporary variable, sumOfSquares. */ + in = *pSrc++ >> 8U; + sumOfSquares += ((q63_t) (in) * (in)); + + /* C = (A[0] + A[1] + A[2] + ... + A[blockSize-1]) */ + /* Compute sum of all input values and then store the result in a temporary variable, sum. */ + sum += in; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* Compute Mean of squares of the input samples + * and then store the result in a temporary variable, meanOfSquares. */ + meanOfSquares = sumOfSquares / (q63_t)(blockSize - 1U); + +#endif /* #if defined (ARM_MATH_DSP) */ + + /* Compute square of mean */ + squareOfMean = sum * sum / (q63_t)(blockSize * (blockSize - 1U)); + + /* Compute standard deviation and then store the result to the destination */ + *pResult = (meanOfSquares - squareOfMean) >> 15U; +} + +/** + * @} end of variance group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_f32.c new file mode 100644 index 0000000..13245b6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_f32.c @@ -0,0 +1,123 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_copy_f32.c + * Description: Copies the elements of a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @defgroup copy Vector Copy + * + * Copies sample by sample from source vector to destination vector. + * + *
+ * 	pDst[n] = pSrc[n];   0 <= n < blockSize.
+ * 
+ * + * There are separate functions for floating point, Q31, Q15, and Q7 data types. + */ + +/** + * @addtogroup copy + * @{ + */ + +/** + * @brief Copies the elements of a floating-point vector. + * @param[in] *pSrc points to input vector + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the input vector + * @return none. + * + */ + + +void arm_copy_f32( + float32_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t in1, in2, in3, in4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A */ + /* Copy and then store the results in the destination buffer */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + *pDst++ = in1; + *pDst++ = in2; + *pDst++ = in3; + *pDst++ = in4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A */ + /* Copy and then store the results in the destination buffer */ + *pDst++ = *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicCopy group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q15.c new file mode 100644 index 0000000..28b60d9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q15.c @@ -0,0 +1,102 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_copy_q15.c + * Description: Copies the elements of a Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup copy + * @{ + */ +/** + * @brief Copies the elements of a Q15 vector. + * @param[in] *pSrc points to input vector + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the input vector + * @return none. + * + */ + +void arm_copy_q15( + q15_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A */ + /* Read two inputs */ + *__SIMD32(pDst)++ = *__SIMD32(pSrc)++; + *__SIMD32(pDst)++ = *__SIMD32(pSrc)++; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A */ + /* Copy and then store the value in the destination buffer */ + *pDst++ = *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicCopy group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q31.c new file mode 100644 index 0000000..b0bdd05 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q31.c @@ -0,0 +1,111 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_copy_q31.c + * Description: Copies the elements of a Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup copy + * @{ + */ + +/** + * @brief Copies the elements of a Q31 vector. + * @param[in] *pSrc points to input vector + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the input vector + * @return none. + * + */ + +void arm_copy_q31( + q31_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2, in3, in4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A */ + /* Copy and then store the values in the destination buffer */ + in1 = *pSrc++; + in2 = *pSrc++; + in3 = *pSrc++; + in4 = *pSrc++; + + *pDst++ = in1; + *pDst++ = in2; + *pDst++ = in3; + *pDst++ = in4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = A */ + /* Copy and then store the value in the destination buffer */ + *pDst++ = *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicCopy group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q7.c new file mode 100644 index 0000000..a3afa36 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_copy_q7.c @@ -0,0 +1,103 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_copy_q7.c + * Description: Copies the elements of a Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup copy + * @{ + */ + +/** + * @brief Copies the elements of a Q7 vector. + * @param[in] *pSrc points to input vector + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the input vector + * @return none. + * + */ + +void arm_copy_q7( + q7_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A */ + /* Copy and then store the results in the destination buffer */ + /* 4 samples are copied and stored at a time using SIMD */ + *__SIMD32(pDst)++ = *__SIMD32(pSrc)++; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A */ + /* Copy and then store the results in the destination buffer */ + *pDst++ = *pSrc++; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of BasicCopy group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_f32.c new file mode 100644 index 0000000..5a70608 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_f32.c @@ -0,0 +1,122 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fill_f32.c + * Description: Fills a constant value into a floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @defgroup Fill Vector Fill + * + * Fills the destination vector with a constant value. + * + *
+ * 	pDst[n] = value;   0 <= n < blockSize.
+ * 
+ * + * There are separate functions for floating point, Q31, Q15, and Q7 data types. + */ + +/** + * @addtogroup Fill + * @{ + */ + +/** + * @brief Fills a constant value into a floating-point vector. + * @param[in] value input value to be filled + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the output vector + * @return none. + * + */ + + +void arm_fill_f32( + float32_t value, + float32_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + float32_t in1 = value; + float32_t in2 = value; + float32_t in3 = value; + float32_t in4 = value; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *pDst++ = in1; + *pDst++ = in2; + *pDst++ = in3; + *pDst++ = in4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *pDst++ = value; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of Fill group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q15.c new file mode 100644 index 0000000..8f27def --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q15.c @@ -0,0 +1,108 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fill_q15.c + * Description: Fills a constant value into a Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup Fill + * @{ + */ + +/** + * @brief Fills a constant value into a Q15 vector. + * @param[in] value input value to be filled + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the output vector + * @return none. + * + */ + +void arm_fill_q15( + q15_t value, + q15_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t packedValue; /* value packed to 32 bits */ + + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* Packing two 16 bit values to 32 bit value in order to use SIMD */ + packedValue = __PKHBT(value, value, 16U); + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *__SIMD32(pDst)++ = packedValue; + *__SIMD32(pDst)++ = packedValue; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *pDst++ = value; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of Fill group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q31.c new file mode 100644 index 0000000..3769f4d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q31.c @@ -0,0 +1,109 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fill_q31.c + * Description: Fills a constant value into a Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup Fill + * @{ + */ + +/** + * @brief Fills a constant value into a Q31 vector. + * @param[in] value input value to be filled + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the output vector + * @return none. + * + */ + +void arm_fill_q31( + q31_t value, + q31_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1 = value; + q31_t in2 = value; + q31_t in3 = value; + q31_t in4 = value; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *pDst++ = in1; + *pDst++ = in2; + *pDst++ = in3; + *pDst++ = in4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *pDst++ = value; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of Fill group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q7.c new file mode 100644 index 0000000..fa718b7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_fill_q7.c @@ -0,0 +1,106 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_fill_q7.c + * Description: Fills a constant value into a Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup Fill + * @{ + */ + +/** + * @brief Fills a constant value into a Q7 vector. + * @param[in] value input value to be filled + * @param[out] *pDst points to output vector + * @param[in] blockSize length of the output vector + * @return none. + * + */ + +void arm_fill_q7( + q7_t value, + q7_t * pDst, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t packedValue; /* value packed to 32 bits */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* Packing four 8 bit values to 32 bit value in order to use SIMD */ + packedValue = __PACKq7(value, value, value, value); + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *__SIMD32(pDst)++ = packedValue; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = value */ + /* Fill the value in the destination buffer */ + *pDst++ = value; + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of Fill group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q15.c new file mode 100644 index 0000000..b652e7c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q15.c @@ -0,0 +1,192 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_float_to_q15.c + * Description: Converts the elements of the floating-point vector to Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup float_to_x + * @{ + */ + +/** + * @brief Converts the elements of the floating-point vector to Q15 vector. + * @param[in] *pSrc points to the floating-point input vector + * @param[out] *pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * \par + * The equation used for the conversion process is: + *
+ * 	pDst[n] = (q15_t)(pSrc[n] * 32768);   0 <= n < blockSize.
+ * 
+ * \par Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + * \note + * In order to apply rounding, the library should be rebuilt with the ROUNDING macro + * defined in the preprocessor section of project options. + * + */ + + +void arm_float_to_q15( + float32_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + float32_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#ifdef ARM_MATH_ROUNDING + + float32_t in; + +#endif /* #ifdef ARM_MATH_ROUNDING */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + /* C = A * 32768 */ + /* convert from float to q15 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 32768.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q15_t) (__SSAT((q31_t) (in), 16)); + + in = *pIn++; + in = (in * 32768.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q15_t) (__SSAT((q31_t) (in), 16)); + + in = *pIn++; + in = (in * 32768.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q15_t) (__SSAT((q31_t) (in), 16)); + + in = *pIn++; + in = (in * 32768.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q15_t) (__SSAT((q31_t) (in), 16)); + +#else + + /* C = A * 32768 */ + /* convert from float to q15 and then store the results in the destination buffer */ + *pDst++ = (q15_t) __SSAT((q31_t) (*pIn++ * 32768.0f), 16); + *pDst++ = (q15_t) __SSAT((q31_t) (*pIn++ * 32768.0f), 16); + *pDst++ = (q15_t) __SSAT((q31_t) (*pIn++ * 32768.0f), 16); + *pDst++ = (q15_t) __SSAT((q31_t) (*pIn++ * 32768.0f), 16); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + /* C = A * 32768 */ + /* convert from float to q15 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 32768.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q15_t) (__SSAT((q31_t) (in), 16)); + +#else + + /* C = A * 32768 */ + /* convert from float to q15 and then store the results in the destination buffer */ + *pDst++ = (q15_t) __SSAT((q31_t) (*pIn++ * 32768.0f), 16); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + /* C = A * 32768 */ + /* convert from float to q15 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 32768.0f); + in += in > 0 ? 0.5f : -0.5f; + *pDst++ = (q15_t) (__SSAT((q31_t) (in), 16)); + +#else + + /* C = A * 32768 */ + /* convert from float to q15 and then store the results in the destination buffer */ + *pDst++ = (q15_t) __SSAT((q31_t) (*pIn++ * 32768.0f), 16); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of float_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q31.c new file mode 100644 index 0000000..7ce1402 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q31.c @@ -0,0 +1,199 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_float_to_q31.c + * Description: Converts the elements of the floating-point vector to Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @defgroup float_to_x Convert 32-bit floating point value + */ + +/** + * @addtogroup float_to_x + * @{ + */ + +/** + * @brief Converts the elements of the floating-point vector to Q31 vector. + * @param[in] *pSrc points to the floating-point input vector + * @param[out] *pDst points to the Q31 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + *\par Description: + * \par + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (q31_t)(pSrc[n] * 2147483648);   0 <= n < blockSize.
+ * 
+ * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q31 range[0x80000000 0x7FFFFFFF] will be saturated. + * + * \note In order to apply rounding, the library should be rebuilt with the ROUNDING macro + * defined in the preprocessor section of project options. + */ + + +void arm_float_to_q31( + float32_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + float32_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#ifdef ARM_MATH_ROUNDING + + float32_t in; + +#endif /* #ifdef ARM_MATH_ROUNDING */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + + /* C = A * 32768 */ + /* convert from float to Q31 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 2147483648.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = clip_q63_to_q31((q63_t) (in)); + + in = *pIn++; + in = (in * 2147483648.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = clip_q63_to_q31((q63_t) (in)); + + in = *pIn++; + in = (in * 2147483648.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = clip_q63_to_q31((q63_t) (in)); + + in = *pIn++; + in = (in * 2147483648.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = clip_q63_to_q31((q63_t) (in)); + +#else + + /* C = A * 2147483648 */ + /* convert from float to Q31 and then store the results in the destination buffer */ + *pDst++ = clip_q63_to_q31((q63_t) (*pIn++ * 2147483648.0f)); + *pDst++ = clip_q63_to_q31((q63_t) (*pIn++ * 2147483648.0f)); + *pDst++ = clip_q63_to_q31((q63_t) (*pIn++ * 2147483648.0f)); + *pDst++ = clip_q63_to_q31((q63_t) (*pIn++ * 2147483648.0f)); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + + /* C = A * 2147483648 */ + /* convert from float to Q31 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 2147483648.0f); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = clip_q63_to_q31((q63_t) (in)); + +#else + + /* C = A * 2147483648 */ + /* convert from float to Q31 and then store the results in the destination buffer */ + *pDst++ = clip_q63_to_q31((q63_t) (*pIn++ * 2147483648.0f)); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + + /* C = A * 2147483648 */ + /* convert from float to Q31 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 2147483648.0f); + in += in > 0 ? 0.5f : -0.5f; + *pDst++ = clip_q63_to_q31((q63_t) (in)); + +#else + + /* C = A * 2147483648 */ + /* convert from float to Q31 and then store the results in the destination buffer */ + *pDst++ = clip_q63_to_q31((q63_t) (*pIn++ * 2147483648.0f)); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of float_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q7.c new file mode 100644 index 0000000..7fd3f2c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_float_to_q7.c @@ -0,0 +1,191 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_float_to_q7.c + * Description: Converts the elements of the floating-point vector to Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup float_to_x + * @{ + */ + +/** + * @brief Converts the elements of the floating-point vector to Q7 vector. + * @param[in] *pSrc points to the floating-point input vector + * @param[out] *pDst points to the Q7 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + *\par Description: + * \par + * The equation used for the conversion process is: + *
+ * 	pDst[n] = (q7_t)(pSrc[n] * 128);   0 <= n < blockSize.
+ * 
+ * \par Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x80 0x7F] will be saturated. + * \note + * In order to apply rounding, the library should be rebuilt with the ROUNDING macro + * defined in the preprocessor section of project options. + */ + + +void arm_float_to_q7( + float32_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + float32_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#ifdef ARM_MATH_ROUNDING + + float32_t in; + +#endif /* #ifdef ARM_MATH_ROUNDING */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + /* C = A * 128 */ + /* convert from float to q7 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 128); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q7_t) (__SSAT((q15_t) (in), 8)); + + in = *pIn++; + in = (in * 128); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q7_t) (__SSAT((q15_t) (in), 8)); + + in = *pIn++; + in = (in * 128); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q7_t) (__SSAT((q15_t) (in), 8)); + + in = *pIn++; + in = (in * 128); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q7_t) (__SSAT((q15_t) (in), 8)); + +#else + + /* C = A * 128 */ + /* convert from float to q7 and then store the results in the destination buffer */ + *pDst++ = __SSAT((q31_t) (*pIn++ * 128.0f), 8); + *pDst++ = __SSAT((q31_t) (*pIn++ * 128.0f), 8); + *pDst++ = __SSAT((q31_t) (*pIn++ * 128.0f), 8); + *pDst++ = __SSAT((q31_t) (*pIn++ * 128.0f), 8); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + + while (blkCnt > 0U) + { + +#ifdef ARM_MATH_ROUNDING + /* C = A * 128 */ + /* convert from float to q7 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 128); + in += in > 0.0f ? 0.5f : -0.5f; + *pDst++ = (q7_t) (__SSAT((q15_t) (in), 8)); + +#else + + /* C = A * 128 */ + /* convert from float to q7 and then store the results in the destination buffer */ + *pDst++ = __SSAT((q31_t) (*pIn++ * 128.0f), 8); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + + +#else + + /* Run the below code for Cortex-M0 */ + + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + + while (blkCnt > 0U) + { +#ifdef ARM_MATH_ROUNDING + /* C = A * 128 */ + /* convert from float to q7 and then store the results in the destination buffer */ + in = *pIn++; + in = (in * 128.0f); + in += in > 0 ? 0.5f : -0.5f; + *pDst++ = (q7_t) (__SSAT((q31_t) (in), 8)); + +#else + + /* C = A * 128 */ + /* convert from float to q7 and then store the results in the destination buffer */ + *pDst++ = (q7_t) __SSAT((q31_t) (*pIn++ * 128.0f), 8); + +#endif /* #ifdef ARM_MATH_ROUNDING */ + + /* Decrement the loop counter */ + blkCnt--; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of float_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_float.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_float.c new file mode 100644 index 0000000..442ba9f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_float.c @@ -0,0 +1,122 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q15_to_float.c + * Description: Converts the elements of the Q15 vector to floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @defgroup q15_to_x Convert 16-bit Integer value + */ + +/** + * @addtogroup q15_to_x + * @{ + */ + + + + +/** + * @brief Converts the elements of the Q15 vector to floating-point vector. + * @param[in] *pSrc points to the Q15 input vector + * @param[out] *pDst points to the floating-point output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (float32_t) pSrc[n] / 32768;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q15_to_float( + q15_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + q15_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (float32_t) A / 32768 */ + /* convert from q15 to float and then store the results in the destination buffer */ + *pDst++ = ((float32_t) * pIn++ / 32768.0f); + *pDst++ = ((float32_t) * pIn++ / 32768.0f); + *pDst++ = ((float32_t) * pIn++ / 32768.0f); + *pDst++ = ((float32_t) * pIn++ / 32768.0f); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (float32_t) A / 32768 */ + /* convert from q15 to float and then store the results in the destination buffer */ + *pDst++ = ((float32_t) * pIn++ / 32768.0f); + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of q15_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q31.c new file mode 100644 index 0000000..2dff322 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q31.c @@ -0,0 +1,144 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q15_to_q31.c + * Description: Converts the elements of the Q15 vector to Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup q15_to_x + * @{ + */ + +/** + * @brief Converts the elements of the Q15 vector to Q31 vector. + * @param[in] *pSrc points to the Q15 input vector + * @param[out] *pDst points to the Q31 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (q31_t) pSrc[n] << 16;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q15_to_q31( + q15_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q15_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2; + q31_t out1, out2, out3, out4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (q31_t)A << 16 */ + /* convert from q15 to q31 and then store the results in the destination buffer */ + in1 = *__SIMD32(pIn)++; + in2 = *__SIMD32(pIn)++; + +#ifndef ARM_MATH_BIG_ENDIAN + + /* extract lower 16 bits to 32 bit result */ + out1 = in1 << 16U; + /* extract upper 16 bits to 32 bit result */ + out2 = in1 & 0xFFFF0000; + /* extract lower 16 bits to 32 bit result */ + out3 = in2 << 16U; + /* extract upper 16 bits to 32 bit result */ + out4 = in2 & 0xFFFF0000; + +#else + + /* extract upper 16 bits to 32 bit result */ + out1 = in1 & 0xFFFF0000; + /* extract lower 16 bits to 32 bit result */ + out2 = in1 << 16U; + /* extract upper 16 bits to 32 bit result */ + out3 = in2 & 0xFFFF0000; + /* extract lower 16 bits to 32 bit result */ + out4 = in2 << 16U; + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + *pDst++ = out1; + *pDst++ = out2; + *pDst++ = out3; + *pDst++ = out4; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (q31_t)A << 16 */ + /* convert from q15 to q31 and then store the results in the destination buffer */ + *pDst++ = (q31_t) * pIn++ << 16; + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of q15_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q7.c new file mode 100644 index 0000000..26a35e7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q15_to_q7.c @@ -0,0 +1,142 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q15_to_q7.c + * Description: Converts the elements of the Q15 vector to Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup q15_to_x + * @{ + */ + + +/** + * @brief Converts the elements of the Q15 vector to Q7 vector. + * @param[in] *pSrc points to the Q15 input vector + * @param[out] *pDst points to the Q7 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (q7_t) pSrc[n] >> 8;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q15_to_q7( + q15_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + q15_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2; + q31_t out1, out2; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (q7_t) A >> 8 */ + /* convert from q15 to q7 and then store the results in the destination buffer */ + in1 = *__SIMD32(pIn)++; + in2 = *__SIMD32(pIn)++; + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __PKHTB(in2, in1, 16); + out2 = __PKHBT(in2, in1, 16); + +#else + + out1 = __PKHTB(in1, in2, 16); + out2 = __PKHBT(in1, in2, 16); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + /* rotate packed value by 24 */ + out2 = ((uint32_t) out2 << 8) | ((uint32_t) out2 >> 24); + + /* anding with 0xff00ff00 to get two 8 bit values */ + out1 = out1 & 0xFF00FF00; + /* anding with 0x00ff00ff to get two 8 bit values */ + out2 = out2 & 0x00FF00FF; + + /* oring two values(contains two 8 bit values) to get four packed 8 bit values */ + out1 = out1 | out2; + + /* store 4 samples at a time to destiantion buffer */ + *__SIMD32(pDst)++ = out1; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (q7_t) A >> 8 */ + /* convert from q15 to q7 and then store the results in the destination buffer */ + *pDst++ = (q7_t) (*pIn++ >> 8); + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of q15_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_float.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_float.c new file mode 100644 index 0000000..b15d90e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_float.c @@ -0,0 +1,119 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q31_to_float.c + * Description: Converts the elements of the Q31 vector to floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @defgroup q31_to_x Convert 32-bit Integer value + */ + +/** + * @addtogroup q31_to_x + * @{ + */ + +/** + * @brief Converts the elements of the Q31 vector to floating-point vector. + * @param[in] *pSrc points to the Q31 input vector + * @param[out] *pDst points to the floating-point output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (float32_t) pSrc[n] / 2147483648;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q31_to_float( + q31_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + q31_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (float32_t) A / 2147483648 */ + /* convert from q31 to float and then store the results in the destination buffer */ + *pDst++ = ((float32_t) * pIn++ / 2147483648.0f); + *pDst++ = ((float32_t) * pIn++ / 2147483648.0f); + *pDst++ = ((float32_t) * pIn++ / 2147483648.0f); + *pDst++ = ((float32_t) * pIn++ / 2147483648.0f); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (float32_t) A / 2147483648 */ + /* convert from q31 to float and then store the results in the destination buffer */ + *pDst++ = ((float32_t) * pIn++ / 2147483648.0f); + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of q31_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q15.c new file mode 100644 index 0000000..2fd305b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q15.c @@ -0,0 +1,133 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q31_to_q15.c + * Description: Converts the elements of the Q31 vector to Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup q31_to_x + * @{ + */ + +/** + * @brief Converts the elements of the Q31 vector to Q15 vector. + * @param[in] *pSrc points to the Q31 input vector + * @param[out] *pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (q15_t) pSrc[n] >> 16;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q31_to_q15( + q31_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q31_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2, in3, in4; + q31_t out1, out2; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (q15_t) A >> 16 */ + /* convert from q31 to q15 and then store the results in the destination buffer */ + in1 = *pIn++; + in2 = *pIn++; + in3 = *pIn++; + in4 = *pIn++; + + /* pack two higher 16-bit values from two 32-bit values */ +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __PKHTB(in2, in1, 16); + out2 = __PKHTB(in4, in3, 16); + +#else + + out1 = __PKHTB(in1, in2, 16); + out2 = __PKHTB(in3, in4, 16); + +#endif // #ifdef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = out1; + *__SIMD32(pDst)++ = out2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (q15_t) A >> 16 */ + /* convert from q31 to q15 and then store the results in the destination buffer */ + *pDst++ = (q15_t) (*pIn++ >> 16); + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of q31_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q7.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q7.c new file mode 100644 index 0000000..6586861 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q31_to_q7.c @@ -0,0 +1,124 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q31_to_q7.c + * Description: Converts the elements of the Q31 vector to Q7 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup q31_to_x + * @{ + */ + +/** + * @brief Converts the elements of the Q31 vector to Q7 vector. + * @param[in] *pSrc points to the Q31 input vector + * @param[out] *pDst points to the Q7 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (q7_t) pSrc[n] >> 24;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q31_to_q7( + q31_t * pSrc, + q7_t * pDst, + uint32_t blockSize) +{ + q31_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t in1, in2, in3, in4; + q7_t out1, out2, out3, out4; + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (q7_t) A >> 24 */ + /* convert from q31 to q7 and then store the results in the destination buffer */ + in1 = *pIn++; + in2 = *pIn++; + in3 = *pIn++; + in4 = *pIn++; + + out1 = (q7_t) (in1 >> 24); + out2 = (q7_t) (in2 >> 24); + out3 = (q7_t) (in3 >> 24); + out4 = (q7_t) (in4 >> 24); + + *__SIMD32(pDst)++ = __PACKq7(out1, out2, out3, out4); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (q7_t) A >> 24 */ + /* convert from q31 to q7 and then store the results in the destination buffer */ + *pDst++ = (q7_t) (*pIn++ >> 24); + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of q31_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_float.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_float.c new file mode 100644 index 0000000..d866501 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_float.c @@ -0,0 +1,119 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q7_to_float.c + * Description: Converts the elements of the Q7 vector to floating-point vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @defgroup q7_to_x Convert 8-bit Integer value + */ + +/** + * @addtogroup q7_to_x + * @{ + */ + +/** + * @brief Converts the elements of the Q7 vector to floating-point vector. + * @param[in] *pSrc points to the Q7 input vector + * @param[out] *pDst points to the floating-point output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (float32_t) pSrc[n] / 128;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q7_to_float( + q7_t * pSrc, + float32_t * pDst, + uint32_t blockSize) +{ + q7_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (float32_t) A / 128 */ + /* convert from q7 to float and then store the results in the destination buffer */ + *pDst++ = ((float32_t) * pIn++ / 128.0f); + *pDst++ = ((float32_t) * pIn++ / 128.0f); + *pDst++ = ((float32_t) * pIn++ / 128.0f); + *pDst++ = ((float32_t) * pIn++ / 128.0f); + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (float32_t) A / 128 */ + /* convert from q7 to float and then store the results in the destination buffer */ + *pDst++ = ((float32_t) * pIn++ / 128.0f); + + /* Decrement the loop counter */ + blkCnt--; + } +} + +/** + * @} end of q7_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q15.c new file mode 100644 index 0000000..5bc5a56 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q15.c @@ -0,0 +1,145 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q7_to_q15.c + * Description: Converts the elements of the Q7 vector to Q15 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup q7_to_x + * @{ + */ + + + + +/** + * @brief Converts the elements of the Q7 vector to Q15 vector. + * @param[in] *pSrc points to the Q7 input vector + * @param[out] *pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (q15_t) pSrc[n] << 8;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q7_to_q15( + q7_t * pSrc, + q15_t * pDst, + uint32_t blockSize) +{ + q7_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + q31_t in; + q31_t in1, in2; + q31_t out1, out2; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (q15_t) A << 8 */ + /* convert from q7 to q15 and then store the results in the destination buffer */ + in = *__SIMD32(pIn)++; + + /* rotatate in by 8 and extend two q7_t values to q15_t values */ + in1 = __SXTB16(__ROR(in, 8)); + + /* extend remainig two q7_t values to q15_t values */ + in2 = __SXTB16(in); + + in1 = in1 << 8U; + in2 = in2 << 8U; + + in1 = in1 & 0xFF00FF00; + in2 = in2 & 0xFF00FF00; + +#ifndef ARM_MATH_BIG_ENDIAN + + out2 = __PKHTB(in1, in2, 16); + out1 = __PKHBT(in2, in1, 16); + +#else + + out1 = __PKHTB(in1, in2, 16); + out2 = __PKHBT(in2, in1, 16); + +#endif + + *__SIMD32(pDst)++ = out1; + *__SIMD32(pDst)++ = out2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (q15_t) A << 8 */ + /* convert from q7 to q15 and then store the results in the destination buffer */ + *pDst++ = (q15_t) * pIn++ << 8; + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of q7_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q31.c new file mode 100644 index 0000000..abbda7f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/SupportFunctions/arm_q7_to_q31.c @@ -0,0 +1,130 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_q7_to_q31.c + * Description: Converts the elements of the Q7 vector to Q31 vector + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup q7_to_x + * @{ + */ + +/** + * @brief Converts the elements of the Q7 vector to Q31 vector. + * @param[in] *pSrc points to the Q7 input vector + * @param[out] *pDst points to the Q31 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
+ * 	pDst[n] = (q31_t) pSrc[n] << 24;   0 <= n < blockSize.
+ * 
+ * + */ + + +void arm_q7_to_q31( + q7_t * pSrc, + q31_t * pDst, + uint32_t blockSize) +{ + q7_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#if defined (ARM_MATH_DSP) + + q31_t in; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = (q31_t) A << 24 */ + /* convert from q7 to q31 and then store the results in the destination buffer */ + in = *__SIMD32(pIn)++; + +#ifndef ARM_MATH_BIG_ENDIAN + + *pDst++ = (__ROR(in, 8)) & 0xFF000000; + *pDst++ = (__ROR(in, 16)) & 0xFF000000; + *pDst++ = (__ROR(in, 24)) & 0xFF000000; + *pDst++ = (in & 0xFF000000); + +#else + + *pDst++ = (in & 0xFF000000); + *pDst++ = (__ROR(in, 24)) & 0xFF000000; + *pDst++ = (__ROR(in, 16)) & 0xFF000000; + *pDst++ = (__ROR(in, 8)) & 0xFF000000; + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + while (blkCnt > 0U) + { + /* C = (q31_t) A << 24 */ + /* convert from q7 to q31 and then store the results in the destination buffer */ + *pDst++ = (q31_t) * pIn++ << 24; + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of q7_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal.c new file mode 100644 index 0000000..3119769 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal.c @@ -0,0 +1,230 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_bitreversal.c + * Description: Bitreversal functions + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/* +* @brief In-place bit reversal function. +* @param[in, out] *pSrc points to the in-place buffer of floating-point data type. +* @param[in] fftSize length of the FFT. +* @param[in] bitRevFactor bit reversal modifier that supports different size FFTs with the same bit reversal table. +* @param[in] *pBitRevTab points to the bit reversal table. +* @return none. +*/ + +void arm_bitreversal_f32( +float32_t * pSrc, +uint16_t fftSize, +uint16_t bitRevFactor, +uint16_t * pBitRevTab) +{ + uint16_t fftLenBy2, fftLenBy2p1; + uint16_t i, j; + float32_t in; + + /* Initializations */ + j = 0U; + fftLenBy2 = fftSize >> 1U; + fftLenBy2p1 = (fftSize >> 1U) + 1U; + + /* Bit Reversal Implementation */ + for (i = 0U; i <= (fftLenBy2 - 2U); i += 2U) + { + if (i < j) + { + /* pSrc[i] <-> pSrc[j]; */ + in = pSrc[2U * i]; + pSrc[2U * i] = pSrc[2U * j]; + pSrc[2U * j] = in; + + /* pSrc[i+1U] <-> pSrc[j+1U] */ + in = pSrc[(2U * i) + 1U]; + pSrc[(2U * i) + 1U] = pSrc[(2U * j) + 1U]; + pSrc[(2U * j) + 1U] = in; + + /* pSrc[i+fftLenBy2p1] <-> pSrc[j+fftLenBy2p1] */ + in = pSrc[2U * (i + fftLenBy2p1)]; + pSrc[2U * (i + fftLenBy2p1)] = pSrc[2U * (j + fftLenBy2p1)]; + pSrc[2U * (j + fftLenBy2p1)] = in; + + /* pSrc[i+fftLenBy2p1+1U] <-> pSrc[j+fftLenBy2p1+1U] */ + in = pSrc[(2U * (i + fftLenBy2p1)) + 1U]; + pSrc[(2U * (i + fftLenBy2p1)) + 1U] = + pSrc[(2U * (j + fftLenBy2p1)) + 1U]; + pSrc[(2U * (j + fftLenBy2p1)) + 1U] = in; + + } + + /* pSrc[i+1U] <-> pSrc[j+1U] */ + in = pSrc[2U * (i + 1U)]; + pSrc[2U * (i + 1U)] = pSrc[2U * (j + fftLenBy2)]; + pSrc[2U * (j + fftLenBy2)] = in; + + /* pSrc[i+2U] <-> pSrc[j+2U] */ + in = pSrc[(2U * (i + 1U)) + 1U]; + pSrc[(2U * (i + 1U)) + 1U] = pSrc[(2U * (j + fftLenBy2)) + 1U]; + pSrc[(2U * (j + fftLenBy2)) + 1U] = in; + + /* Reading the index for the bit reversal */ + j = *pBitRevTab; + + /* Updating the bit reversal index depending on the fft length */ + pBitRevTab += bitRevFactor; + } +} + + + +/* +* @brief In-place bit reversal function. +* @param[in, out] *pSrc points to the in-place buffer of Q31 data type. +* @param[in] fftLen length of the FFT. +* @param[in] bitRevFactor bit reversal modifier that supports different size FFTs with the same bit reversal table +* @param[in] *pBitRevTab points to bit reversal table. +* @return none. +*/ + +void arm_bitreversal_q31( +q31_t * pSrc, +uint32_t fftLen, +uint16_t bitRevFactor, +uint16_t * pBitRevTable) +{ + uint32_t fftLenBy2, fftLenBy2p1, i, j; + q31_t in; + + /* Initializations */ + j = 0U; + fftLenBy2 = fftLen / 2U; + fftLenBy2p1 = (fftLen / 2U) + 1U; + + /* Bit Reversal Implementation */ + for (i = 0U; i <= (fftLenBy2 - 2U); i += 2U) + { + if (i < j) + { + /* pSrc[i] <-> pSrc[j]; */ + in = pSrc[2U * i]; + pSrc[2U * i] = pSrc[2U * j]; + pSrc[2U * j] = in; + + /* pSrc[i+1U] <-> pSrc[j+1U] */ + in = pSrc[(2U * i) + 1U]; + pSrc[(2U * i) + 1U] = pSrc[(2U * j) + 1U]; + pSrc[(2U * j) + 1U] = in; + + /* pSrc[i+fftLenBy2p1] <-> pSrc[j+fftLenBy2p1] */ + in = pSrc[2U * (i + fftLenBy2p1)]; + pSrc[2U * (i + fftLenBy2p1)] = pSrc[2U * (j + fftLenBy2p1)]; + pSrc[2U * (j + fftLenBy2p1)] = in; + + /* pSrc[i+fftLenBy2p1+1U] <-> pSrc[j+fftLenBy2p1+1U] */ + in = pSrc[(2U * (i + fftLenBy2p1)) + 1U]; + pSrc[(2U * (i + fftLenBy2p1)) + 1U] = + pSrc[(2U * (j + fftLenBy2p1)) + 1U]; + pSrc[(2U * (j + fftLenBy2p1)) + 1U] = in; + + } + + /* pSrc[i+1U] <-> pSrc[j+1U] */ + in = pSrc[2U * (i + 1U)]; + pSrc[2U * (i + 1U)] = pSrc[2U * (j + fftLenBy2)]; + pSrc[2U * (j + fftLenBy2)] = in; + + /* pSrc[i+2U] <-> pSrc[j+2U] */ + in = pSrc[(2U * (i + 1U)) + 1U]; + pSrc[(2U * (i + 1U)) + 1U] = pSrc[(2U * (j + fftLenBy2)) + 1U]; + pSrc[(2U * (j + fftLenBy2)) + 1U] = in; + + /* Reading the index for the bit reversal */ + j = *pBitRevTable; + + /* Updating the bit reversal index depending on the fft length */ + pBitRevTable += bitRevFactor; + } +} + + + +/* + * @brief In-place bit reversal function. + * @param[in, out] *pSrc points to the in-place buffer of Q15 data type. + * @param[in] fftLen length of the FFT. + * @param[in] bitRevFactor bit reversal modifier that supports different size FFTs with the same bit reversal table + * @param[in] *pBitRevTab points to bit reversal table. + * @return none. +*/ + +void arm_bitreversal_q15( +q15_t * pSrc16, +uint32_t fftLen, +uint16_t bitRevFactor, +uint16_t * pBitRevTab) +{ + q31_t *pSrc = (q31_t *) pSrc16; + q31_t in; + uint32_t fftLenBy2, fftLenBy2p1; + uint32_t i, j; + + /* Initializations */ + j = 0U; + fftLenBy2 = fftLen / 2U; + fftLenBy2p1 = (fftLen / 2U) + 1U; + + /* Bit Reversal Implementation */ + for (i = 0U; i <= (fftLenBy2 - 2U); i += 2U) + { + if (i < j) + { + /* pSrc[i] <-> pSrc[j]; */ + /* pSrc[i+1U] <-> pSrc[j+1U] */ + in = pSrc[i]; + pSrc[i] = pSrc[j]; + pSrc[j] = in; + + /* pSrc[i + fftLenBy2p1] <-> pSrc[j + fftLenBy2p1]; */ + /* pSrc[i + fftLenBy2p1+1U] <-> pSrc[j + fftLenBy2p1+1U] */ + in = pSrc[i + fftLenBy2p1]; + pSrc[i + fftLenBy2p1] = pSrc[j + fftLenBy2p1]; + pSrc[j + fftLenBy2p1] = in; + } + + /* pSrc[i+1U] <-> pSrc[j+fftLenBy2]; */ + /* pSrc[i+2] <-> pSrc[j+fftLenBy2+1U] */ + in = pSrc[i + 1U]; + pSrc[i + 1U] = pSrc[j + fftLenBy2]; + pSrc[j + fftLenBy2] = in; + + /* Reading the index for the bit reversal */ + j = *pBitRevTab; + + /* Updating the bit reversal index depending on the fft length */ + pBitRevTab += bitRevFactor; + } +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal2.S b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal2.S new file mode 100644 index 0000000..cde264c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_bitreversal2.S @@ -0,0 +1,216 @@ +;/* ---------------------------------------------------------------------- +; * Project: CMSIS DSP Library +; * Title: arm_bitreversal2.S +; * Description: arm_bitreversal_32 function done in assembly for maximum speed. +; * Called after doing an fft to reorder the output. +; * The function is loop unrolled by 2. arm_bitreversal_16 as well. +; * +; * $Date: 27. January 2017 +; * $Revision: V.1.5.1 +; * +; * Target Processor: Cortex-M cores +; * -------------------------------------------------------------------- */ +;/* +; * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. +; * +; * SPDX-License-Identifier: Apache-2.0 +; * +; * Licensed under the Apache License, Version 2.0 (the License); you may +; * not use this file except in compliance with the License. +; * You may obtain a copy of the License at +; * +; * www.apache.org/licenses/LICENSE-2.0 +; * +; * Unless required by applicable law or agreed to in writing, software +; * distributed under the License is distributed on an AS IS BASIS, WITHOUT +; * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +; * See the License for the specific language governing permissions and +; * limitations under the License. +; */ + +#if defined ( __CC_ARM ) /* Keil */ + #define CODESECT AREA ||.text||, CODE, READONLY, ALIGN=2 + #define LABEL +#elif defined ( __IASMARM__ ) /* IAR */ + #define CODESECT SECTION `.text`:CODE + #define PROC + #define LABEL + #define ENDP + #define EXPORT PUBLIC +#elif defined ( __CSMC__ ) /* Cosmic */ + #define CODESECT switch .text + #define THUMB + #define EXPORT xdef + #define PROC : + #define LABEL : + #define ENDP + #define arm_bitreversal_32 _arm_bitreversal_32 +#elif defined ( __TI_ARM__ ) /* TI ARM */ + #define THUMB .thumb + #define CODESECT .text + #define EXPORT .global + #define PROC : .asmfunc + #define LABEL : + #define ENDP .endasmfunc + #define END +#elif defined ( __GNUC__ ) /* GCC */ + #define THUMB .thumb + #define CODESECT .section .text + #define EXPORT .global + #define PROC : + #define LABEL : + #define ENDP + #define END + + .syntax unified +#endif + + CODESECT + THUMB + +;/* +;* @brief In-place bit reversal function. +;* @param[in, out] *pSrc points to the in-place buffer of unknown 32-bit data type. +;* @param[in] bitRevLen bit reversal table length +;* @param[in] *pBitRevTab points to bit reversal table. +;* @return none. +;*/ + EXPORT arm_bitreversal_32 + EXPORT arm_bitreversal_16 + +#if defined ( __CC_ARM ) /* Keil */ +#elif defined ( __IASMARM__ ) /* IAR */ +#elif defined ( __CSMC__ ) /* Cosmic */ +#elif defined ( __TI_ARM__ ) /* TI ARM */ +#elif defined ( __GNUC__ ) /* GCC */ + .type arm_bitreversal_16, %function + .type arm_bitreversal_32, %function +#endif + +#if defined(ARM_MATH_CM0) || defined(ARM_MATH_CM0PLUS) || defined(ARM_MATH_ARMV8MBL) + +arm_bitreversal_32 PROC + ADDS r3,r1,#1 + PUSH {r4-r6} + ADDS r1,r2,#0 + LSRS r3,r3,#1 +arm_bitreversal_32_0 LABEL + LDRH r2,[r1,#2] + LDRH r6,[r1,#0] + ADD r2,r0,r2 + ADD r6,r0,r6 + LDR r5,[r2,#0] + LDR r4,[r6,#0] + STR r5,[r6,#0] + STR r4,[r2,#0] + LDR r5,[r2,#4] + LDR r4,[r6,#4] + STR r5,[r6,#4] + STR r4,[r2,#4] + ADDS r1,r1,#4 + SUBS r3,r3,#1 + BNE arm_bitreversal_32_0 + POP {r4-r6} + BX lr + ENDP + +arm_bitreversal_16 PROC + ADDS r3,r1,#1 + PUSH {r4-r6} + ADDS r1,r2,#0 + LSRS r3,r3,#1 +arm_bitreversal_16_0 LABEL + LDRH r2,[r1,#2] + LDRH r6,[r1,#0] + LSRS r2,r2,#1 + LSRS r6,r6,#1 + ADD r2,r0,r2 + ADD r6,r0,r6 + LDR r5,[r2,#0] + LDR r4,[r6,#0] + STR r5,[r6,#0] + STR r4,[r2,#0] + ADDS r1,r1,#4 + SUBS r3,r3,#1 + BNE arm_bitreversal_16_0 + POP {r4-r6} + BX lr + ENDP + +#else + +arm_bitreversal_32 PROC + ADDS r3,r1,#1 + CMP r3,#1 + IT LS + BXLS lr + PUSH {r4-r9} + ADDS r1,r2,#2 + LSRS r3,r3,#2 +arm_bitreversal_32_0 LABEL ;/* loop unrolled by 2 */ + LDRH r8,[r1,#4] + LDRH r9,[r1,#2] + LDRH r2,[r1,#0] + LDRH r12,[r1,#-2] + ADD r8,r0,r8 + ADD r9,r0,r9 + ADD r2,r0,r2 + ADD r12,r0,r12 + LDR r7,[r9,#0] + LDR r6,[r8,#0] + LDR r5,[r2,#0] + LDR r4,[r12,#0] + STR r6,[r9,#0] + STR r7,[r8,#0] + STR r5,[r12,#0] + STR r4,[r2,#0] + LDR r7,[r9,#4] + LDR r6,[r8,#4] + LDR r5,[r2,#4] + LDR r4,[r12,#4] + STR r6,[r9,#4] + STR r7,[r8,#4] + STR r5,[r12,#4] + STR r4,[r2,#4] + ADDS r1,r1,#8 + SUBS r3,r3,#1 + BNE arm_bitreversal_32_0 + POP {r4-r9} + BX lr + ENDP + +arm_bitreversal_16 PROC + ADDS r3,r1,#1 + CMP r3,#1 + IT LS + BXLS lr + PUSH {r4-r9} + ADDS r1,r2,#2 + LSRS r3,r3,#2 +arm_bitreversal_16_0 LABEL ;/* loop unrolled by 2 */ + LDRH r8,[r1,#4] + LDRH r9,[r1,#2] + LDRH r2,[r1,#0] + LDRH r12,[r1,#-2] + ADD r8,r0,r8,LSR #1 + ADD r9,r0,r9,LSR #1 + ADD r2,r0,r2,LSR #1 + ADD r12,r0,r12,LSR #1 + LDR r7,[r9,#0] + LDR r6,[r8,#0] + LDR r5,[r2,#0] + LDR r4,[r12,#0] + STR r6,[r9,#0] + STR r7,[r8,#0] + STR r5,[r12,#0] + STR r4,[r2,#0] + ADDS r1,r1,#8 + SUBS r3,r3,#1 + BNE arm_bitreversal_16_0 + POP {r4-r9} + BX lr + ENDP + +#endif + + END diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_f32.c new file mode 100644 index 0000000..2593202 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_f32.c @@ -0,0 +1,620 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_f32.c + * Description: Combined Radix Decimation in Frequency CFFT Floating point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +extern void arm_radix8_butterfly_f32( + float32_t * pSrc, + uint16_t fftLen, + const float32_t * pCoef, + uint16_t twidCoefModifier); + +extern void arm_bitreversal_32( + uint32_t * pSrc, + const uint16_t bitRevLen, + const uint16_t * pBitRevTable); + +/** +* @ingroup groupTransforms +*/ + +/** +* @defgroup ComplexFFT Complex FFT Functions +* +* \par +* The Fast Fourier Transform (FFT) is an efficient algorithm for computing the +* Discrete Fourier Transform (DFT). The FFT can be orders of magnitude faster +* than the DFT, especially for long lengths. +* The algorithms described in this section +* operate on complex data. A separate set of functions is devoted to handling +* of real sequences. +* \par +* There are separate algorithms for handling floating-point, Q15, and Q31 data +* types. The algorithms available for each data type are described next. +* \par +* The FFT functions operate in-place. That is, the array holding the input data +* will also be used to hold the corresponding result. The input data is complex +* and contains 2*fftLen interleaved values as shown below. +*
 {real[0], imag[0], real[1], imag[1],..} 
+* The FFT result will be contained in the same array and the frequency domain +* values will have the same interleaving. +* +* \par Floating-point +* The floating-point complex FFT uses a mixed-radix algorithm. Multiple radix-8 +* stages are performed along with a single radix-2 or radix-4 stage, as needed. +* The algorithm supports lengths of [16, 32, 64, ..., 4096] and each length uses +* a different twiddle factor table. +* \par +* The function uses the standard FFT definition and output values may grow by a +* factor of fftLen when computing the forward transform. The +* inverse transform includes a scale of 1/fftLen as part of the +* calculation and this matches the textbook definition of the inverse FFT. +* \par +* Pre-initialized data structures containing twiddle factors and bit reversal +* tables are provided and defined in arm_const_structs.h. Include +* this header in your function and then pass one of the constant structures as +* an argument to arm_cfft_f32. For example: +* \par +* arm_cfft_f32(arm_cfft_sR_f32_len64, pSrc, 1, 1) +* \par +* computes a 64-point inverse complex FFT including bit reversal. +* The data structures are treated as constant data and not modified during the +* calculation. The same data structure can be reused for multiple transforms +* including mixing forward and inverse transforms. +* \par +* Earlier releases of the library provided separate radix-2 and radix-4 +* algorithms that operated on floating-point data. These functions are still +* provided but are deprecated. The older functions are slower and less general +* than the new functions. +* \par +* An example of initialization of the constants for the arm_cfft_f32 function follows: +* \code +* const static arm_cfft_instance_f32 *S; +* ... +* switch (length) { +* case 16: +* S = &arm_cfft_sR_f32_len16; +* break; +* case 32: +* S = &arm_cfft_sR_f32_len32; +* break; +* case 64: +* S = &arm_cfft_sR_f32_len64; +* break; +* case 128: +* S = &arm_cfft_sR_f32_len128; +* break; +* case 256: +* S = &arm_cfft_sR_f32_len256; +* break; +* case 512: +* S = &arm_cfft_sR_f32_len512; +* break; +* case 1024: +* S = &arm_cfft_sR_f32_len1024; +* break; +* case 2048: +* S = &arm_cfft_sR_f32_len2048; +* break; +* case 4096: +* S = &arm_cfft_sR_f32_len4096; +* break; +* } +* \endcode +* \par Q15 and Q31 +* The floating-point complex FFT uses a mixed-radix algorithm. Multiple radix-4 +* stages are performed along with a single radix-2 stage, as needed. +* The algorithm supports lengths of [16, 32, 64, ..., 4096] and each length uses +* a different twiddle factor table. +* \par +* The function uses the standard FFT definition and output values may grow by a +* factor of fftLen when computing the forward transform. The +* inverse transform includes a scale of 1/fftLen as part of the +* calculation and this matches the textbook definition of the inverse FFT. +* \par +* Pre-initialized data structures containing twiddle factors and bit reversal +* tables are provided and defined in arm_const_structs.h. Include +* this header in your function and then pass one of the constant structures as +* an argument to arm_cfft_q31. For example: +* \par +* arm_cfft_q31(arm_cfft_sR_q31_len64, pSrc, 1, 1) +* \par +* computes a 64-point inverse complex FFT including bit reversal. +* The data structures are treated as constant data and not modified during the +* calculation. The same data structure can be reused for multiple transforms +* including mixing forward and inverse transforms. +* \par +* Earlier releases of the library provided separate radix-2 and radix-4 +* algorithms that operated on floating-point data. These functions are still +* provided but are deprecated. The older functions are slower and less general +* than the new functions. +* \par +* An example of initialization of the constants for the arm_cfft_q31 function follows: +* \code +* const static arm_cfft_instance_q31 *S; +* ... +* switch (length) { +* case 16: +* S = &arm_cfft_sR_q31_len16; +* break; +* case 32: +* S = &arm_cfft_sR_q31_len32; +* break; +* case 64: +* S = &arm_cfft_sR_q31_len64; +* break; +* case 128: +* S = &arm_cfft_sR_q31_len128; +* break; +* case 256: +* S = &arm_cfft_sR_q31_len256; +* break; +* case 512: +* S = &arm_cfft_sR_q31_len512; +* break; +* case 1024: +* S = &arm_cfft_sR_q31_len1024; +* break; +* case 2048: +* S = &arm_cfft_sR_q31_len2048; +* break; +* case 4096: +* S = &arm_cfft_sR_q31_len4096; +* break; +* } +* \endcode +* +*/ + +void arm_cfft_radix8by2_f32( arm_cfft_instance_f32 * S, float32_t * p1) +{ + uint32_t L = S->fftLen; + float32_t * pCol1, * pCol2, * pMid1, * pMid2; + float32_t * p2 = p1 + L; + const float32_t * tw = (float32_t *) S->pTwiddle; + float32_t t1[4], t2[4], t3[4], t4[4], twR, twI; + float32_t m0, m1, m2, m3; + uint32_t l; + + pCol1 = p1; + pCol2 = p2; + + // Define new length + L >>= 1; + // Initialize mid pointers + pMid1 = p1 + L; + pMid2 = p2 + L; + + // do two dot Fourier transform + for ( l = L >> 2; l > 0; l-- ) + { + t1[0] = p1[0]; + t1[1] = p1[1]; + t1[2] = p1[2]; + t1[3] = p1[3]; + + t2[0] = p2[0]; + t2[1] = p2[1]; + t2[2] = p2[2]; + t2[3] = p2[3]; + + t3[0] = pMid1[0]; + t3[1] = pMid1[1]; + t3[2] = pMid1[2]; + t3[3] = pMid1[3]; + + t4[0] = pMid2[0]; + t4[1] = pMid2[1]; + t4[2] = pMid2[2]; + t4[3] = pMid2[3]; + + *p1++ = t1[0] + t2[0]; + *p1++ = t1[1] + t2[1]; + *p1++ = t1[2] + t2[2]; + *p1++ = t1[3] + t2[3]; // col 1 + + t2[0] = t1[0] - t2[0]; + t2[1] = t1[1] - t2[1]; + t2[2] = t1[2] - t2[2]; + t2[3] = t1[3] - t2[3]; // for col 2 + + *pMid1++ = t3[0] + t4[0]; + *pMid1++ = t3[1] + t4[1]; + *pMid1++ = t3[2] + t4[2]; + *pMid1++ = t3[3] + t4[3]; // col 1 + + t4[0] = t4[0] - t3[0]; + t4[1] = t4[1] - t3[1]; + t4[2] = t4[2] - t3[2]; + t4[3] = t4[3] - t3[3]; // for col 2 + + twR = *tw++; + twI = *tw++; + + // multiply by twiddle factors + m0 = t2[0] * twR; + m1 = t2[1] * twI; + m2 = t2[1] * twR; + m3 = t2[0] * twI; + + // R = R * Tr - I * Ti + *p2++ = m0 + m1; + // I = I * Tr + R * Ti + *p2++ = m2 - m3; + + // use vertical symmetry + // 0.9988 - 0.0491i <==> -0.0491 - 0.9988i + m0 = t4[0] * twI; + m1 = t4[1] * twR; + m2 = t4[1] * twI; + m3 = t4[0] * twR; + + *pMid2++ = m0 - m1; + *pMid2++ = m2 + m3; + + twR = *tw++; + twI = *tw++; + + m0 = t2[2] * twR; + m1 = t2[3] * twI; + m2 = t2[3] * twR; + m3 = t2[2] * twI; + + *p2++ = m0 + m1; + *p2++ = m2 - m3; + + m0 = t4[2] * twI; + m1 = t4[3] * twR; + m2 = t4[3] * twI; + m3 = t4[2] * twR; + + *pMid2++ = m0 - m1; + *pMid2++ = m2 + m3; + } + + // first col + arm_radix8_butterfly_f32( pCol1, L, (float32_t *) S->pTwiddle, 2U); + // second col + arm_radix8_butterfly_f32( pCol2, L, (float32_t *) S->pTwiddle, 2U); +} + +void arm_cfft_radix8by4_f32( arm_cfft_instance_f32 * S, float32_t * p1) +{ + uint32_t L = S->fftLen >> 1; + float32_t * pCol1, *pCol2, *pCol3, *pCol4, *pEnd1, *pEnd2, *pEnd3, *pEnd4; + const float32_t *tw2, *tw3, *tw4; + float32_t * p2 = p1 + L; + float32_t * p3 = p2 + L; + float32_t * p4 = p3 + L; + float32_t t2[4], t3[4], t4[4], twR, twI; + float32_t p1ap3_0, p1sp3_0, p1ap3_1, p1sp3_1; + float32_t m0, m1, m2, m3; + uint32_t l, twMod2, twMod3, twMod4; + + pCol1 = p1; // points to real values by default + pCol2 = p2; + pCol3 = p3; + pCol4 = p4; + pEnd1 = p2 - 1; // points to imaginary values by default + pEnd2 = p3 - 1; + pEnd3 = p4 - 1; + pEnd4 = pEnd3 + L; + + tw2 = tw3 = tw4 = (float32_t *) S->pTwiddle; + + L >>= 1; + + // do four dot Fourier transform + + twMod2 = 2; + twMod3 = 4; + twMod4 = 6; + + // TOP + p1ap3_0 = p1[0] + p3[0]; + p1sp3_0 = p1[0] - p3[0]; + p1ap3_1 = p1[1] + p3[1]; + p1sp3_1 = p1[1] - p3[1]; + + // col 2 + t2[0] = p1sp3_0 + p2[1] - p4[1]; + t2[1] = p1sp3_1 - p2[0] + p4[0]; + // col 3 + t3[0] = p1ap3_0 - p2[0] - p4[0]; + t3[1] = p1ap3_1 - p2[1] - p4[1]; + // col 4 + t4[0] = p1sp3_0 - p2[1] + p4[1]; + t4[1] = p1sp3_1 + p2[0] - p4[0]; + // col 1 + *p1++ = p1ap3_0 + p2[0] + p4[0]; + *p1++ = p1ap3_1 + p2[1] + p4[1]; + + // Twiddle factors are ones + *p2++ = t2[0]; + *p2++ = t2[1]; + *p3++ = t3[0]; + *p3++ = t3[1]; + *p4++ = t4[0]; + *p4++ = t4[1]; + + tw2 += twMod2; + tw3 += twMod3; + tw4 += twMod4; + + for (l = (L - 2) >> 1; l > 0; l-- ) + { + // TOP + p1ap3_0 = p1[0] + p3[0]; + p1sp3_0 = p1[0] - p3[0]; + p1ap3_1 = p1[1] + p3[1]; + p1sp3_1 = p1[1] - p3[1]; + // col 2 + t2[0] = p1sp3_0 + p2[1] - p4[1]; + t2[1] = p1sp3_1 - p2[0] + p4[0]; + // col 3 + t3[0] = p1ap3_0 - p2[0] - p4[0]; + t3[1] = p1ap3_1 - p2[1] - p4[1]; + // col 4 + t4[0] = p1sp3_0 - p2[1] + p4[1]; + t4[1] = p1sp3_1 + p2[0] - p4[0]; + // col 1 - top + *p1++ = p1ap3_0 + p2[0] + p4[0]; + *p1++ = p1ap3_1 + p2[1] + p4[1]; + + // BOTTOM + p1ap3_1 = pEnd1[-1] + pEnd3[-1]; + p1sp3_1 = pEnd1[-1] - pEnd3[-1]; + p1ap3_0 = pEnd1[0] + pEnd3[0]; + p1sp3_0 = pEnd1[0] - pEnd3[0]; + // col 2 + t2[2] = pEnd2[0] - pEnd4[0] + p1sp3_1; + t2[3] = pEnd1[0] - pEnd3[0] - pEnd2[-1] + pEnd4[-1]; + // col 3 + t3[2] = p1ap3_1 - pEnd2[-1] - pEnd4[-1]; + t3[3] = p1ap3_0 - pEnd2[0] - pEnd4[0]; + // col 4 + t4[2] = pEnd2[0] - pEnd4[0] - p1sp3_1; + t4[3] = pEnd4[-1] - pEnd2[-1] - p1sp3_0; + // col 1 - Bottom + *pEnd1-- = p1ap3_0 + pEnd2[0] + pEnd4[0]; + *pEnd1-- = p1ap3_1 + pEnd2[-1] + pEnd4[-1]; + + // COL 2 + // read twiddle factors + twR = *tw2++; + twI = *tw2++; + // multiply by twiddle factors + // let Z1 = a + i(b), Z2 = c + i(d) + // => Z1 * Z2 = (a*c - b*d) + i(b*c + a*d) + + // Top + m0 = t2[0] * twR; + m1 = t2[1] * twI; + m2 = t2[1] * twR; + m3 = t2[0] * twI; + + *p2++ = m0 + m1; + *p2++ = m2 - m3; + // use vertical symmetry col 2 + // 0.9997 - 0.0245i <==> 0.0245 - 0.9997i + // Bottom + m0 = t2[3] * twI; + m1 = t2[2] * twR; + m2 = t2[2] * twI; + m3 = t2[3] * twR; + + *pEnd2-- = m0 - m1; + *pEnd2-- = m2 + m3; + + // COL 3 + twR = tw3[0]; + twI = tw3[1]; + tw3 += twMod3; + // Top + m0 = t3[0] * twR; + m1 = t3[1] * twI; + m2 = t3[1] * twR; + m3 = t3[0] * twI; + + *p3++ = m0 + m1; + *p3++ = m2 - m3; + // use vertical symmetry col 3 + // 0.9988 - 0.0491i <==> -0.9988 - 0.0491i + // Bottom + m0 = -t3[3] * twR; + m1 = t3[2] * twI; + m2 = t3[2] * twR; + m3 = t3[3] * twI; + + *pEnd3-- = m0 - m1; + *pEnd3-- = m3 - m2; + + // COL 4 + twR = tw4[0]; + twI = tw4[1]; + tw4 += twMod4; + // Top + m0 = t4[0] * twR; + m1 = t4[1] * twI; + m2 = t4[1] * twR; + m3 = t4[0] * twI; + + *p4++ = m0 + m1; + *p4++ = m2 - m3; + // use vertical symmetry col 4 + // 0.9973 - 0.0736i <==> -0.0736 + 0.9973i + // Bottom + m0 = t4[3] * twI; + m1 = t4[2] * twR; + m2 = t4[2] * twI; + m3 = t4[3] * twR; + + *pEnd4-- = m0 - m1; + *pEnd4-- = m2 + m3; + } + + //MIDDLE + // Twiddle factors are + // 1.0000 0.7071-0.7071i -1.0000i -0.7071-0.7071i + p1ap3_0 = p1[0] + p3[0]; + p1sp3_0 = p1[0] - p3[0]; + p1ap3_1 = p1[1] + p3[1]; + p1sp3_1 = p1[1] - p3[1]; + + // col 2 + t2[0] = p1sp3_0 + p2[1] - p4[1]; + t2[1] = p1sp3_1 - p2[0] + p4[0]; + // col 3 + t3[0] = p1ap3_0 - p2[0] - p4[0]; + t3[1] = p1ap3_1 - p2[1] - p4[1]; + // col 4 + t4[0] = p1sp3_0 - p2[1] + p4[1]; + t4[1] = p1sp3_1 + p2[0] - p4[0]; + // col 1 - Top + *p1++ = p1ap3_0 + p2[0] + p4[0]; + *p1++ = p1ap3_1 + p2[1] + p4[1]; + + // COL 2 + twR = tw2[0]; + twI = tw2[1]; + + m0 = t2[0] * twR; + m1 = t2[1] * twI; + m2 = t2[1] * twR; + m3 = t2[0] * twI; + + *p2++ = m0 + m1; + *p2++ = m2 - m3; + // COL 3 + twR = tw3[0]; + twI = tw3[1]; + + m0 = t3[0] * twR; + m1 = t3[1] * twI; + m2 = t3[1] * twR; + m3 = t3[0] * twI; + + *p3++ = m0 + m1; + *p3++ = m2 - m3; + // COL 4 + twR = tw4[0]; + twI = tw4[1]; + + m0 = t4[0] * twR; + m1 = t4[1] * twI; + m2 = t4[1] * twR; + m3 = t4[0] * twI; + + *p4++ = m0 + m1; + *p4++ = m2 - m3; + + // first col + arm_radix8_butterfly_f32( pCol1, L, (float32_t *) S->pTwiddle, 4U); + // second col + arm_radix8_butterfly_f32( pCol2, L, (float32_t *) S->pTwiddle, 4U); + // third col + arm_radix8_butterfly_f32( pCol3, L, (float32_t *) S->pTwiddle, 4U); + // fourth col + arm_radix8_butterfly_f32( pCol4, L, (float32_t *) S->pTwiddle, 4U); +} + +/** +* @addtogroup ComplexFFT +* @{ +*/ + +/** +* @details +* @brief Processing function for the floating-point complex FFT. +* @param[in] *S points to an instance of the floating-point CFFT structure. +* @param[in, out] *p1 points to the complex data buffer of size 2*fftLen. Processing occurs in-place. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return none. +*/ + +void arm_cfft_f32( + const arm_cfft_instance_f32 * S, + float32_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + uint32_t L = S->fftLen, l; + float32_t invL, * pSrc; + + if (ifftFlag == 1U) + { + /* Conjugate input data */ + pSrc = p1 + 1; + for(l=0; lpTwiddle, 1); + break; + } + + if ( bitReverseFlag ) + arm_bitreversal_32((uint32_t*)p1,S->bitRevLength,S->pBitRevTable); + + if (ifftFlag == 1U) + { + invL = 1.0f/(float32_t)L; + /* Conjugate and scale output data */ + pSrc = p1; + for(l=0; l2*fftLen. Processing occurs in-place. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return none. +*/ + +void arm_cfft_q15( + const arm_cfft_instance_q15 * S, + q15_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + uint32_t L = S->fftLen; + + if (ifftFlag == 1U) + { + switch (L) + { + case 16: + case 64: + case 256: + case 1024: + case 4096: + arm_radix4_butterfly_inverse_q15 ( p1, L, (q15_t*)S->pTwiddle, 1 ); + break; + + case 32: + case 128: + case 512: + case 2048: + arm_cfft_radix4by2_inverse_q15 ( p1, L, S->pTwiddle ); + break; + } + } + else + { + switch (L) + { + case 16: + case 64: + case 256: + case 1024: + case 4096: + arm_radix4_butterfly_q15 ( p1, L, (q15_t*)S->pTwiddle, 1 ); + break; + + case 32: + case 128: + case 512: + case 2048: + arm_cfft_radix4by2_q15 ( p1, L, S->pTwiddle ); + break; + } + } + + if ( bitReverseFlag ) + arm_bitreversal_16((uint16_t*)p1,S->bitRevLength,S->pBitRevTable); +} + +/** +* @} end of ComplexFFT group +*/ + +void arm_cfft_radix4by2_q15( + q15_t * pSrc, + uint32_t fftLen, + const q15_t * pCoef) +{ + uint32_t i; + uint32_t n2; + q15_t p0, p1, p2, p3; +#if defined (ARM_MATH_DSP) + q31_t T, S, R; + q31_t coeff, out1, out2; + const q15_t *pC = pCoef; + q15_t *pSi = pSrc; + q15_t *pSl = pSrc + fftLen; +#else + uint32_t ia, l; + q15_t xt, yt, cosVal, sinVal; +#endif + + n2 = fftLen >> 1; + +#if defined (ARM_MATH_DSP) + + for (i = n2; i > 0; i--) + { + coeff = _SIMD32_OFFSET(pC); + pC += 2; + + T = _SIMD32_OFFSET(pSi); + T = __SHADD16(T, 0); // this is just a SIMD arithmetic shift right by 1 + + S = _SIMD32_OFFSET(pSl); + S = __SHADD16(S, 0); // this is just a SIMD arithmetic shift right by 1 + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSi) = __SHADD16(T, S); + pSi += 2; + + #ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUAD(coeff, R) >> 16; + out2 = __SMUSDX(coeff, R); + + #else + + out1 = __SMUSDX(R, coeff) >> 16U; + out2 = __SMUAD(coeff, R); + + #endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSl) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSl += 2; + } + +#else // #if defined (ARM_MATH_DSP) + + ia = 0; + for (i = 0; i < n2; i++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia++; + + l = i + n2; + + xt = (pSrc[2 * i] >> 1U) - (pSrc[2 * l] >> 1U); + pSrc[2 * i] = ((pSrc[2 * i] >> 1U) + (pSrc[2 * l] >> 1U)) >> 1U; + + yt = (pSrc[2 * i + 1] >> 1U) - (pSrc[2 * l + 1] >> 1U); + pSrc[2 * i + 1] = + ((pSrc[2 * l + 1] >> 1U) + (pSrc[2 * i + 1] >> 1U)) >> 1U; + + pSrc[2U * l] = (((int16_t) (((q31_t) xt * cosVal) >> 16)) + + ((int16_t) (((q31_t) yt * sinVal) >> 16))); + + pSrc[2U * l + 1U] = (((int16_t) (((q31_t) yt * cosVal) >> 16)) - + ((int16_t) (((q31_t) xt * sinVal) >> 16))); + } + +#endif // #if defined (ARM_MATH_DSP) + + // first col + arm_radix4_butterfly_q15( pSrc, n2, (q15_t*)pCoef, 2U); + // second col + arm_radix4_butterfly_q15( pSrc + fftLen, n2, (q15_t*)pCoef, 2U); + + for (i = 0; i < fftLen >> 1; i++) + { + p0 = pSrc[4*i+0]; + p1 = pSrc[4*i+1]; + p2 = pSrc[4*i+2]; + p3 = pSrc[4*i+3]; + + p0 <<= 1; + p1 <<= 1; + p2 <<= 1; + p3 <<= 1; + + pSrc[4*i+0] = p0; + pSrc[4*i+1] = p1; + pSrc[4*i+2] = p2; + pSrc[4*i+3] = p3; + } +} + +void arm_cfft_radix4by2_inverse_q15( + q15_t * pSrc, + uint32_t fftLen, + const q15_t * pCoef) +{ + uint32_t i; + uint32_t n2; + q15_t p0, p1, p2, p3; +#if defined (ARM_MATH_DSP) + q31_t T, S, R; + q31_t coeff, out1, out2; + const q15_t *pC = pCoef; + q15_t *pSi = pSrc; + q15_t *pSl = pSrc + fftLen; +#else + uint32_t ia, l; + q15_t xt, yt, cosVal, sinVal; +#endif + + n2 = fftLen >> 1; + +#if defined (ARM_MATH_DSP) + + for (i = n2; i > 0; i--) + { + coeff = _SIMD32_OFFSET(pC); + pC += 2; + + T = _SIMD32_OFFSET(pSi); + T = __SHADD16(T, 0); // this is just a SIMD arithmetic shift right by 1 + + S = _SIMD32_OFFSET(pSl); + S = __SHADD16(S, 0); // this is just a SIMD arithmetic shift right by 1 + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSi) = __SHADD16(T, S); + pSi += 2; + + #ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUSD(coeff, R) >> 16; + out2 = __SMUADX(coeff, R); + #else + + out1 = __SMUADX(R, coeff) >> 16U; + out2 = __SMUSD(__QSUB(0, coeff), R); + + #endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSl) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSl += 2; + } + +#else // #if defined (ARM_MATH_DSP) + + ia = 0; + for (i = 0; i < n2; i++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia++; + + l = i + n2; + xt = (pSrc[2 * i] >> 1U) - (pSrc[2 * l] >> 1U); + pSrc[2 * i] = ((pSrc[2 * i] >> 1U) + (pSrc[2 * l] >> 1U)) >> 1U; + + yt = (pSrc[2 * i + 1] >> 1U) - (pSrc[2 * l + 1] >> 1U); + pSrc[2 * i + 1] = + ((pSrc[2 * l + 1] >> 1U) + (pSrc[2 * i + 1] >> 1U)) >> 1U; + + pSrc[2U * l] = (((int16_t) (((q31_t) xt * cosVal) >> 16)) - + ((int16_t) (((q31_t) yt * sinVal) >> 16))); + + pSrc[2U * l + 1U] = (((int16_t) (((q31_t) yt * cosVal) >> 16)) + + ((int16_t) (((q31_t) xt * sinVal) >> 16))); + } + +#endif // #if defined (ARM_MATH_DSP) + + // first col + arm_radix4_butterfly_inverse_q15( pSrc, n2, (q15_t*)pCoef, 2U); + // second col + arm_radix4_butterfly_inverse_q15( pSrc + fftLen, n2, (q15_t*)pCoef, 2U); + + for (i = 0; i < fftLen >> 1; i++) + { + p0 = pSrc[4*i+0]; + p1 = pSrc[4*i+1]; + p2 = pSrc[4*i+2]; + p3 = pSrc[4*i+3]; + + p0 <<= 1; + p1 <<= 1; + p2 <<= 1; + p3 <<= 1; + + pSrc[4*i+0] = p0; + pSrc[4*i+1] = p1; + pSrc[4*i+2] = p2; + pSrc[4*i+3] = p3; + } +} + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_q31.c new file mode 100644 index 0000000..934a3fc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_q31.c @@ -0,0 +1,252 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_q31.c + * Description: Combined Radix Decimation in Frequency CFFT fixed point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +extern void arm_radix4_butterfly_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pCoef, + uint32_t twidCoefModifier); + +extern void arm_radix4_butterfly_inverse_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pCoef, + uint32_t twidCoefModifier); + +extern void arm_bitreversal_32( + uint32_t * pSrc, + const uint16_t bitRevLen, + const uint16_t * pBitRevTable); + +void arm_cfft_radix4by2_q31( + q31_t * pSrc, + uint32_t fftLen, + const q31_t * pCoef); + +void arm_cfft_radix4by2_inverse_q31( + q31_t * pSrc, + uint32_t fftLen, + const q31_t * pCoef); + +/** +* @ingroup groupTransforms +*/ + +/** +* @addtogroup ComplexFFT +* @{ +*/ + +/** +* @details +* @brief Processing function for the fixed-point complex FFT in Q31 format. +* @param[in] *S points to an instance of the fixed-point CFFT structure. +* @param[in, out] *p1 points to the complex data buffer of size 2*fftLen. Processing occurs in-place. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return none. +*/ + +void arm_cfft_q31( + const arm_cfft_instance_q31 * S, + q31_t * p1, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + uint32_t L = S->fftLen; + + if (ifftFlag == 1U) + { + switch (L) + { + case 16: + case 64: + case 256: + case 1024: + case 4096: + arm_radix4_butterfly_inverse_q31 ( p1, L, (q31_t*)S->pTwiddle, 1 ); + break; + + case 32: + case 128: + case 512: + case 2048: + arm_cfft_radix4by2_inverse_q31 ( p1, L, S->pTwiddle ); + break; + } + } + else + { + switch (L) + { + case 16: + case 64: + case 256: + case 1024: + case 4096: + arm_radix4_butterfly_q31 ( p1, L, (q31_t*)S->pTwiddle, 1 ); + break; + + case 32: + case 128: + case 512: + case 2048: + arm_cfft_radix4by2_q31 ( p1, L, S->pTwiddle ); + break; + } + } + + if ( bitReverseFlag ) + arm_bitreversal_32((uint32_t*)p1,S->bitRevLength,S->pBitRevTable); +} + +/** +* @} end of ComplexFFT group +*/ + +void arm_cfft_radix4by2_q31( + q31_t * pSrc, + uint32_t fftLen, + const q31_t * pCoef) +{ + uint32_t i, l; + uint32_t n2, ia; + q31_t xt, yt, cosVal, sinVal; + q31_t p0, p1; + + n2 = fftLen >> 1; + ia = 0; + for (i = 0; i < n2; i++) + { + cosVal = pCoef[2*ia]; + sinVal = pCoef[2*ia + 1]; + ia++; + + l = i + n2; + xt = (pSrc[2 * i] >> 2) - (pSrc[2 * l] >> 2); + pSrc[2 * i] = (pSrc[2 * i] >> 2) + (pSrc[2 * l] >> 2); + + yt = (pSrc[2 * i + 1] >> 2) - (pSrc[2 * l + 1] >> 2); + pSrc[2 * i + 1] = (pSrc[2 * l + 1] >> 2) + (pSrc[2 * i + 1] >> 2); + + mult_32x32_keep32_R(p0, xt, cosVal); + mult_32x32_keep32_R(p1, yt, cosVal); + multAcc_32x32_keep32_R(p0, yt, sinVal); + multSub_32x32_keep32_R(p1, xt, sinVal); + + pSrc[2U * l] = p0 << 1; + pSrc[2U * l + 1U] = p1 << 1; + + } + + // first col + arm_radix4_butterfly_q31( pSrc, n2, (q31_t*)pCoef, 2U); + // second col + arm_radix4_butterfly_q31( pSrc + fftLen, n2, (q31_t*)pCoef, 2U); + + for (i = 0; i < fftLen >> 1; i++) + { + p0 = pSrc[4*i+0]; + p1 = pSrc[4*i+1]; + xt = pSrc[4*i+2]; + yt = pSrc[4*i+3]; + + p0 <<= 1; + p1 <<= 1; + xt <<= 1; + yt <<= 1; + + pSrc[4*i+0] = p0; + pSrc[4*i+1] = p1; + pSrc[4*i+2] = xt; + pSrc[4*i+3] = yt; + } + +} + +void arm_cfft_radix4by2_inverse_q31( + q31_t * pSrc, + uint32_t fftLen, + const q31_t * pCoef) +{ + uint32_t i, l; + uint32_t n2, ia; + q31_t xt, yt, cosVal, sinVal; + q31_t p0, p1; + + n2 = fftLen >> 1; + ia = 0; + for (i = 0; i < n2; i++) + { + cosVal = pCoef[2*ia]; + sinVal = pCoef[2*ia + 1]; + ia++; + + l = i + n2; + xt = (pSrc[2 * i] >> 2) - (pSrc[2 * l] >> 2); + pSrc[2 * i] = (pSrc[2 * i] >> 2) + (pSrc[2 * l] >> 2); + + yt = (pSrc[2 * i + 1] >> 2) - (pSrc[2 * l + 1] >> 2); + pSrc[2 * i + 1] = (pSrc[2 * l + 1] >> 2) + (pSrc[2 * i + 1] >> 2); + + mult_32x32_keep32_R(p0, xt, cosVal); + mult_32x32_keep32_R(p1, yt, cosVal); + multSub_32x32_keep32_R(p0, yt, sinVal); + multAcc_32x32_keep32_R(p1, xt, sinVal); + + pSrc[2U * l] = p0 << 1; + pSrc[2U * l + 1U] = p1 << 1; + + } + + // first col + arm_radix4_butterfly_inverse_q31( pSrc, n2, (q31_t*)pCoef, 2U); + // second col + arm_radix4_butterfly_inverse_q31( pSrc + fftLen, n2, (q31_t*)pCoef, 2U); + + for (i = 0; i < fftLen >> 1; i++) + { + p0 = pSrc[4*i+0]; + p1 = pSrc[4*i+1]; + xt = pSrc[4*i+2]; + yt = pSrc[4*i+3]; + + p0 <<= 1; + p1 <<= 1; + xt <<= 1; + yt <<= 1; + + pSrc[4*i+0] = p0; + pSrc[4*i+1] = p1; + pSrc[4*i+2] = xt; + pSrc[4*i+3] = yt; + } +} + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_f32.c new file mode 100644 index 0000000..45bcc3b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_f32.c @@ -0,0 +1,472 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix2_f32.c + * Description: Radix-2 Decimation in Frequency CFFT & CIFFT Floating point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +void arm_radix2_butterfly_f32( + float32_t * pSrc, + uint32_t fftLen, + float32_t * pCoef, + uint16_t twidCoefModifier); + +void arm_radix2_butterfly_inverse_f32( + float32_t * pSrc, + uint32_t fftLen, + float32_t * pCoef, + uint16_t twidCoefModifier, + float32_t onebyfftLen); + +extern void arm_bitreversal_f32( + float32_t * pSrc, + uint16_t fftSize, + uint16_t bitRevFactor, + uint16_t * pBitRevTab); + +/** +* @ingroup groupTransforms +*/ + +/** +* @addtogroup ComplexFFT +* @{ +*/ + +/** +* @details +* @brief Radix-2 CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_f32 and will be removed +* in the future. +* @param[in] *S points to an instance of the floating-point Radix-2 CFFT/CIFFT structure. +* @param[in, out] *pSrc points to the complex data buffer of size 2*fftLen. Processing occurs in-place. +* @return none. +*/ + +void arm_cfft_radix2_f32( +const arm_cfft_radix2_instance_f32 * S, +float32_t * pSrc) +{ + + if (S->ifftFlag == 1U) + { + /* Complex IFFT radix-2 */ + arm_radix2_butterfly_inverse_f32(pSrc, S->fftLen, S->pTwiddle, + S->twidCoefModifier, S->onebyfftLen); + } + else + { + /* Complex FFT radix-2 */ + arm_radix2_butterfly_f32(pSrc, S->fftLen, S->pTwiddle, + S->twidCoefModifier); + } + + if (S->bitReverseFlag == 1U) + { + /* Bit Reversal */ + arm_bitreversal_f32(pSrc, S->fftLen, S->bitRevFactor, S->pBitRevTable); + } + +} + + +/** +* @} end of ComplexFFT group +*/ + + + +/* ---------------------------------------------------------------------- +** Internal helper function used by the FFTs +** ------------------------------------------------------------------- */ + +/* +* @brief Core function for the floating-point CFFT butterfly process. +* @param[in, out] *pSrc points to the in-place buffer of floating-point data type. +* @param[in] fftLen length of the FFT. +* @param[in] *pCoef points to the twiddle coefficient buffer. +* @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @return none. +*/ + +void arm_radix2_butterfly_f32( +float32_t * pSrc, +uint32_t fftLen, +float32_t * pCoef, +uint16_t twidCoefModifier) +{ + + uint32_t i, j, k, l; + uint32_t n1, n2, ia; + float32_t xt, yt, cosVal, sinVal; + float32_t p0, p1, p2, p3; + float32_t a0, a1; + +#if defined (ARM_MATH_DSP) + + /* Initializations for the first stage */ + n2 = fftLen >> 1; + ia = 0; + i = 0; + + // loop for groups + for (k = n2; k > 0; k--) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + + /* Twiddle coefficients index modifier */ + ia += twidCoefModifier; + + /* index calculation for the input as, */ + /* pSrc[i + 0], pSrc[i + fftLen/1] */ + l = i + n2; + + /* Butterfly implementation */ + a0 = pSrc[2 * i] + pSrc[2 * l]; + xt = pSrc[2 * i] - pSrc[2 * l]; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + a1 = pSrc[2 * l + 1] + pSrc[2 * i + 1]; + + p0 = xt * cosVal; + p1 = yt * sinVal; + p2 = yt * cosVal; + p3 = xt * sinVal; + + pSrc[2 * i] = a0; + pSrc[2 * i + 1] = a1; + + pSrc[2 * l] = p0 + p1; + pSrc[2 * l + 1] = p2 - p3; + + i++; + } // groups loop end + + twidCoefModifier <<= 1U; + + // loop for stage + for (k = n2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + j = 0; + do + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia += twidCoefModifier; + + // loop for butterfly + i = j; + do + { + l = i + n2; + a0 = pSrc[2 * i] + pSrc[2 * l]; + xt = pSrc[2 * i] - pSrc[2 * l]; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + a1 = pSrc[2 * l + 1] + pSrc[2 * i + 1]; + + p0 = xt * cosVal; + p1 = yt * sinVal; + p2 = yt * cosVal; + p3 = xt * sinVal; + + pSrc[2 * i] = a0; + pSrc[2 * i + 1] = a1; + + pSrc[2 * l] = p0 + p1; + pSrc[2 * l + 1] = p2 - p3; + + i += n1; + } while ( i < fftLen ); // butterfly loop end + j++; + } while ( j < n2); // groups loop end + twidCoefModifier <<= 1U; + } // stages loop end + + // loop for butterfly + for (i = 0; i < fftLen; i += 2) + { + a0 = pSrc[2 * i] + pSrc[2 * i + 2]; + xt = pSrc[2 * i] - pSrc[2 * i + 2]; + + yt = pSrc[2 * i + 1] - pSrc[2 * i + 3]; + a1 = pSrc[2 * i + 3] + pSrc[2 * i + 1]; + + pSrc[2 * i] = a0; + pSrc[2 * i + 1] = a1; + pSrc[2 * i + 2] = xt; + pSrc[2 * i + 3] = yt; + } // groups loop end + +#else + + n2 = fftLen; + + // loop for stage + for (k = fftLen; k > 1; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + j = 0; + do + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia += twidCoefModifier; + + // loop for butterfly + i = j; + do + { + l = i + n2; + a0 = pSrc[2 * i] + pSrc[2 * l]; + xt = pSrc[2 * i] - pSrc[2 * l]; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + a1 = pSrc[2 * l + 1] + pSrc[2 * i + 1]; + + p0 = xt * cosVal; + p1 = yt * sinVal; + p2 = yt * cosVal; + p3 = xt * sinVal; + + pSrc[2 * i] = a0; + pSrc[2 * i + 1] = a1; + + pSrc[2 * l] = p0 + p1; + pSrc[2 * l + 1] = p2 - p3; + + i += n1; + } while (i < fftLen); + j++; + } while (j < n2); + twidCoefModifier <<= 1U; + } + +#endif // #if defined (ARM_MATH_DSP) + +} + + +void arm_radix2_butterfly_inverse_f32( +float32_t * pSrc, +uint32_t fftLen, +float32_t * pCoef, +uint16_t twidCoefModifier, +float32_t onebyfftLen) +{ + + uint32_t i, j, k, l; + uint32_t n1, n2, ia; + float32_t xt, yt, cosVal, sinVal; + float32_t p0, p1, p2, p3; + float32_t a0, a1; + +#if defined (ARM_MATH_DSP) + + n2 = fftLen >> 1; + ia = 0; + + // loop for groups + for (i = 0; i < n2; i++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia += twidCoefModifier; + + l = i + n2; + a0 = pSrc[2 * i] + pSrc[2 * l]; + xt = pSrc[2 * i] - pSrc[2 * l]; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + a1 = pSrc[2 * l + 1] + pSrc[2 * i + 1]; + + p0 = xt * cosVal; + p1 = yt * sinVal; + p2 = yt * cosVal; + p3 = xt * sinVal; + + pSrc[2 * i] = a0; + pSrc[2 * i + 1] = a1; + + pSrc[2 * l] = p0 - p1; + pSrc[2 * l + 1] = p2 + p3; + } // groups loop end + + twidCoefModifier <<= 1U; + + // loop for stage + for (k = fftLen / 2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + j = 0; + do + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia += twidCoefModifier; + + // loop for butterfly + i = j; + do + { + l = i + n2; + a0 = pSrc[2 * i] + pSrc[2 * l]; + xt = pSrc[2 * i] - pSrc[2 * l]; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + a1 = pSrc[2 * l + 1] + pSrc[2 * i + 1]; + + p0 = xt * cosVal; + p1 = yt * sinVal; + p2 = yt * cosVal; + p3 = xt * sinVal; + + pSrc[2 * i] = a0; + pSrc[2 * i + 1] = a1; + + pSrc[2 * l] = p0 - p1; + pSrc[2 * l + 1] = p2 + p3; + + i += n1; + } while ( i < fftLen ); // butterfly loop end + j++; + } while (j < n2); // groups loop end + + twidCoefModifier <<= 1U; + } // stages loop end + + // loop for butterfly + for (i = 0; i < fftLen; i += 2) + { + a0 = pSrc[2 * i] + pSrc[2 * i + 2]; + xt = pSrc[2 * i] - pSrc[2 * i + 2]; + + a1 = pSrc[2 * i + 3] + pSrc[2 * i + 1]; + yt = pSrc[2 * i + 1] - pSrc[2 * i + 3]; + + p0 = a0 * onebyfftLen; + p2 = xt * onebyfftLen; + p1 = a1 * onebyfftLen; + p3 = yt * onebyfftLen; + + pSrc[2 * i] = p0; + pSrc[2 * i + 1] = p1; + pSrc[2 * i + 2] = p2; + pSrc[2 * i + 3] = p3; + } // butterfly loop end + +#else + + n2 = fftLen; + + // loop for stage + for (k = fftLen; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + j = 0; + do + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + i = j; + do + { + l = i + n2; + a0 = pSrc[2 * i] + pSrc[2 * l]; + xt = pSrc[2 * i] - pSrc[2 * l]; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + a1 = pSrc[2 * l + 1] + pSrc[2 * i + 1]; + + p0 = xt * cosVal; + p1 = yt * sinVal; + p2 = yt * cosVal; + p3 = xt * sinVal; + + pSrc[2 * i] = a0; + pSrc[2 * i + 1] = a1; + + pSrc[2 * l] = p0 - p1; + pSrc[2 * l + 1] = p2 + p3; + + i += n1; + } while ( i < fftLen ); // butterfly loop end + j++; + } while ( j < n2 ); // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + } // stages loop end + + n1 = n2; + n2 = n2 >> 1; + + // loop for butterfly + for (i = 0; i < fftLen; i += n1) + { + l = i + n2; + + a0 = pSrc[2 * i] + pSrc[2 * l]; + xt = pSrc[2 * i] - pSrc[2 * l]; + + a1 = pSrc[2 * l + 1] + pSrc[2 * i + 1]; + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + + p0 = a0 * onebyfftLen; + p2 = xt * onebyfftLen; + p1 = a1 * onebyfftLen; + p3 = yt * onebyfftLen; + + pSrc[2 * i] = p0; + pSrc[2U * l] = p2; + + pSrc[2 * i + 1] = p1; + pSrc[2U * l + 1U] = p3; + } // butterfly loop end + +#endif // #if defined (ARM_MATH_DSP) + +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_f32.c new file mode 100644 index 0000000..0f423eb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_f32.c @@ -0,0 +1,192 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix2_init_f32.c + * Description: Radix-2 Decimation in Frequency Floating-point CFFT & CIFFT Initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup ComplexFFT + * @{ + */ + +/** +* @brief Initialization function for the floating-point CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_f32 and will be removed +* in the future. +* @param[in,out] *S points to an instance of the floating-point CFFT/CIFFT structure. +* @param[in] fftLen length of the FFT. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLen is not a supported value. +* +* \par Description: +* \par +* The parameter ifftFlag controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlag for calculation of CIFFT otherwise CFFT is calculated +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* The parameter fftLen Specifies length of CFFT/CIFFT process. Supported FFT Lengths are 16, 64, 256, 1024. +* \par +* This Function also initializes Twiddle factor table pointer and Bit reversal table pointer. +*/ +arm_status arm_cfft_radix2_init_f32( + arm_cfft_radix2_instance_f32 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initialise the FFT length */ + S->fftLen = fftLen; + + /* Initialise the Twiddle coefficient pointer */ + S->pTwiddle = (float32_t *) twiddleCoef; + + /* Initialise the Flag for selection of CFFT or CIFFT */ + S->ifftFlag = ifftFlag; + + /* Initialise the Flag for calculation Bit reversal or not */ + S->bitReverseFlag = bitReverseFlag; + + /* Initializations of structure parameters depending on the FFT length */ + switch (S->fftLen) + { + + case 4096U: + /* Initializations of structure parameters for 4096 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 1U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 1U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) armBitRevTable; + /* Initialise the 1/fftLen Value */ + S->onebyfftLen = 0.000244140625; + break; + + case 2048U: + /* Initializations of structure parameters for 2048 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 2U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 2U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[1]; + /* Initialise the 1/fftLen Value */ + S->onebyfftLen = 0.00048828125; + break; + + case 1024U: + /* Initializations of structure parameters for 1024 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 4U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 4U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[3]; + /* Initialise the 1/fftLen Value */ + S->onebyfftLen = 0.0009765625f; + break; + + case 512U: + /* Initializations of structure parameters for 512 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 8U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 8U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[7]; + /* Initialise the 1/fftLen Value */ + S->onebyfftLen = 0.001953125; + break; + + case 256U: + /* Initializations of structure parameters for 256 point FFT */ + S->twidCoefModifier = 16U; + S->bitRevFactor = 16U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[15]; + S->onebyfftLen = 0.00390625f; + break; + + case 128U: + /* Initializations of structure parameters for 128 point FFT */ + S->twidCoefModifier = 32U; + S->bitRevFactor = 32U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[31]; + S->onebyfftLen = 0.0078125; + break; + + case 64U: + /* Initializations of structure parameters for 64 point FFT */ + S->twidCoefModifier = 64U; + S->bitRevFactor = 64U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[63]; + S->onebyfftLen = 0.015625f; + break; + + case 32U: + /* Initializations of structure parameters for 64 point FFT */ + S->twidCoefModifier = 128U; + S->bitRevFactor = 128U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[127]; + S->onebyfftLen = 0.03125; + break; + + case 16U: + /* Initializations of structure parameters for 16 point FFT */ + S->twidCoefModifier = 256U; + S->bitRevFactor = 256U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[255]; + S->onebyfftLen = 0.0625f; + break; + + + default: + /* Reporting argument error if fftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + return (status); +} + +/** + * @} end of ComplexFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q15.c new file mode 100644 index 0000000..54f4e84 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q15.c @@ -0,0 +1,177 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix2_init_q15.c + * Description: Radix-2 Decimation in Frequency Q15 FFT & IFFT initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupTransforms + */ + + +/** + * @addtogroup ComplexFFT + * @{ + */ + +/** +* @brief Initialization function for the Q15 CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q15 and will be removed +* @param[in,out] *S points to an instance of the Q15 CFFT/CIFFT structure. +* @param[in] fftLen length of the FFT. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLen is not a supported value. +* +* \par Description: +* \par +* The parameter ifftFlag controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlag for calculation of CIFFT otherwise CFFT is calculated +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* The parameter fftLen Specifies length of CFFT/CIFFT process. Supported FFT Lengths are 16, 64, 256, 1024. +* \par +* This Function also initializes Twiddle factor table pointer and Bit reversal table pointer. +*/ + +arm_status arm_cfft_radix2_init_q15( + arm_cfft_radix2_instance_q15 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initialise the FFT length */ + S->fftLen = fftLen; + + /* Initialise the Twiddle coefficient pointer */ + S->pTwiddle = (q15_t *) twiddleCoef_4096_q15; + /* Initialise the Flag for selection of CFFT or CIFFT */ + S->ifftFlag = ifftFlag; + /* Initialise the Flag for calculation Bit reversal or not */ + S->bitReverseFlag = bitReverseFlag; + + /* Initializations of structure parameters depending on the FFT length */ + switch (S->fftLen) + { + case 4096U: + /* Initializations of structure parameters for 4096 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 1U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 1U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) armBitRevTable; + + break; + + case 2048U: + /* Initializations of structure parameters for 2048 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 2U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 2U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[1]; + + break; + + case 1024U: + /* Initializations of structure parameters for 1024 point FFT */ + S->twidCoefModifier = 4U; + S->bitRevFactor = 4U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[3]; + + break; + + case 512U: + /* Initializations of structure parameters for 512 point FFT */ + S->twidCoefModifier = 8U; + S->bitRevFactor = 8U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[7]; + + break; + + case 256U: + /* Initializations of structure parameters for 256 point FFT */ + S->twidCoefModifier = 16U; + S->bitRevFactor = 16U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[15]; + + break; + + case 128U: + /* Initializations of structure parameters for 128 point FFT */ + S->twidCoefModifier = 32U; + S->bitRevFactor = 32U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[31]; + + break; + + case 64U: + /* Initializations of structure parameters for 64 point FFT */ + S->twidCoefModifier = 64U; + S->bitRevFactor = 64U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[63]; + + break; + + case 32U: + /* Initializations of structure parameters for 32 point FFT */ + S->twidCoefModifier = 128U; + S->bitRevFactor = 128U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[127]; + + break; + + case 16U: + /* Initializations of structure parameters for 16 point FFT */ + S->twidCoefModifier = 256U; + S->bitRevFactor = 256U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[255]; + + break; + + default: + /* Reporting argument error if fftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + return (status); +} + +/** + * @} end of ComplexFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q31.c new file mode 100644 index 0000000..41ad965 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_init_q31.c @@ -0,0 +1,174 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix2_init_q31.c + * Description: Radix-2 Decimation in Frequency Fixed-point CFFT & CIFFT Initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup ComplexFFT + * @{ + */ + + +/** +* +* @brief Initialization function for the Q31 CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q31 and will be removed +* @param[in,out] *S points to an instance of the Q31 CFFT/CIFFT structure. +* @param[in] fftLen length of the FFT. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLen is not a supported value. +* +* \par Description: +* \par +* The parameter ifftFlag controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlag for calculation of CIFFT otherwise CFFT is calculated +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* The parameter fftLen Specifies length of CFFT/CIFFT process. Supported FFT Lengths are 16, 64, 256, 1024. +* \par +* This Function also initializes Twiddle factor table pointer and Bit reversal table pointer. +*/ + +arm_status arm_cfft_radix2_init_q31( + arm_cfft_radix2_instance_q31 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initialise the FFT length */ + S->fftLen = fftLen; + + /* Initialise the Twiddle coefficient pointer */ + S->pTwiddle = (q31_t *) twiddleCoef_4096_q31; + /* Initialise the Flag for selection of CFFT or CIFFT */ + S->ifftFlag = ifftFlag; + /* Initialise the Flag for calculation Bit reversal or not */ + S->bitReverseFlag = bitReverseFlag; + + /* Initializations of Instance structure depending on the FFT length */ + switch (S->fftLen) + { + /* Initializations of structure parameters for 4096 point FFT */ + case 4096U: + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 1U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 1U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) armBitRevTable; + break; + + /* Initializations of structure parameters for 2048 point FFT */ + case 2048U: + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 2U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 2U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[1]; + break; + + /* Initializations of structure parameters for 1024 point FFT */ + case 1024U: + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 4U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 4U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[3]; + break; + + /* Initializations of structure parameters for 512 point FFT */ + case 512U: + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 8U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 8U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[7]; + break; + + case 256U: + /* Initializations of structure parameters for 256 point FFT */ + S->twidCoefModifier = 16U; + S->bitRevFactor = 16U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[15]; + break; + + case 128U: + /* Initializations of structure parameters for 128 point FFT */ + S->twidCoefModifier = 32U; + S->bitRevFactor = 32U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[31]; + break; + + case 64U: + /* Initializations of structure parameters for 64 point FFT */ + S->twidCoefModifier = 64U; + S->bitRevFactor = 64U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[63]; + break; + + case 32U: + /* Initializations of structure parameters for 32 point FFT */ + S->twidCoefModifier = 128U; + S->bitRevFactor = 128U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[127]; + break; + + case 16U: + /* Initializations of structure parameters for 16 point FFT */ + S->twidCoefModifier = 256U; + S->bitRevFactor = 256U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[255]; + break; + + + default: + /* Reporting argument error if fftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + return (status); +} + +/** + * @} end of ComplexFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q15.c new file mode 100644 index 0000000..c7a9bdf --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q15.c @@ -0,0 +1,729 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix2_q15.c + * Description: Radix-2 Decimation in Frequency CFFT & CIFFT Fixed point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +void arm_radix2_butterfly_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pCoef, + uint16_t twidCoefModifier); + +void arm_radix2_butterfly_inverse_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pCoef, + uint16_t twidCoefModifier); + +void arm_bitreversal_q15( + q15_t * pSrc, + uint32_t fftLen, + uint16_t bitRevFactor, + uint16_t * pBitRevTab); + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup ComplexFFT + * @{ + */ + +/** + * @details + * @brief Processing function for the fixed-point CFFT/CIFFT. + * @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q15 and will be removed + * @param[in] *S points to an instance of the fixed-point CFFT/CIFFT structure. + * @param[in, out] *pSrc points to the complex data buffer of size 2*fftLen. Processing occurs in-place. + * @return none. + */ + +void arm_cfft_radix2_q15( + const arm_cfft_radix2_instance_q15 * S, + q15_t * pSrc) +{ + + if (S->ifftFlag == 1U) + { + arm_radix2_butterfly_inverse_q15(pSrc, S->fftLen, + S->pTwiddle, S->twidCoefModifier); + } + else + { + arm_radix2_butterfly_q15(pSrc, S->fftLen, + S->pTwiddle, S->twidCoefModifier); + } + + arm_bitreversal_q15(pSrc, S->fftLen, S->bitRevFactor, S->pBitRevTable); +} + +/** + * @} end of ComplexFFT group + */ + +void arm_radix2_butterfly_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pCoef, + uint16_t twidCoefModifier) +{ +#if defined (ARM_MATH_DSP) + + unsigned i, j, k, l; + unsigned n1, n2, ia; + q15_t in; + q31_t T, S, R; + q31_t coeff, out1, out2; + + //N = fftLen; + n2 = fftLen; + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (i = 0; i < n2; i++) + { + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + in = ((int16_t) (T & 0xFFFF)) >> 1; + T = ((T >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + in = ((int16_t) (S & 0xFFFF)) >> 1; + S = ((S >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUAD(coeff, R) >> 16; + out2 = __SMUSDX(coeff, R); + +#else + + out1 = __SMUSDX(R, coeff) >> 16U; + out2 = __SMUAD(coeff, R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + // loop for butterfly + i++; + l++; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + in = ((int16_t) (T & 0xFFFF)) >> 1; + T = ((T >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + in = ((int16_t) (S & 0xFFFF)) >> 1; + S = ((S >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUAD(coeff, R) >> 16; + out2 = __SMUSDX(coeff, R); + +#else + + out1 = __SMUSDX(R, coeff) >> 16U; + out2 = __SMUAD(coeff, R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + + // loop for stage + for (k = fftLen / 2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUAD(coeff, R) >> 16; + out2 = __SMUSDX(coeff, R); + +#else + + out1 = __SMUSDX(R, coeff) >> 16U; + out2 = __SMUAD(coeff, R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + i += n1; + + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUAD(coeff, R) >> 16; + out2 = __SMUSDX(coeff, R); + +#else + + out1 = __SMUSDX(R, coeff) >> 16U; + out2 = __SMUAD(coeff, R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + } // stages loop end + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = 0; i < fftLen; i += n1) + { + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __QADD16(T, S); + + _SIMD32_OFFSET(pSrc + (2U * l)) = R; + + i += n1; + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __QADD16(T, S); + + _SIMD32_OFFSET(pSrc + (2U * l)) = R; + + } // groups loop end + + +#else + + unsigned i, j, k, l; + unsigned n1, n2, ia; + q15_t xt, yt, cosVal, sinVal; + + + //N = fftLen; + n2 = fftLen; + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + xt = (pSrc[2 * i] >> 1U) - (pSrc[2 * l] >> 1U); + pSrc[2 * i] = ((pSrc[2 * i] >> 1U) + (pSrc[2 * l] >> 1U)) >> 1U; + + yt = (pSrc[2 * i + 1] >> 1U) - (pSrc[2 * l + 1] >> 1U); + pSrc[2 * i + 1] = + ((pSrc[2 * l + 1] >> 1U) + (pSrc[2 * i + 1] >> 1U)) >> 1U; + + pSrc[2U * l] = (((int16_t) (((q31_t) xt * cosVal) >> 16)) + + ((int16_t) (((q31_t) yt * sinVal) >> 16))); + + pSrc[2U * l + 1U] = (((int16_t) (((q31_t) yt * cosVal) >> 16)) - + ((int16_t) (((q31_t) xt * sinVal) >> 16))); + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + + // loop for stage + for (k = fftLen / 2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]) >> 1U; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]) >> 1U; + + pSrc[2U * l] = (((int16_t) (((q31_t) xt * cosVal) >> 16)) + + ((int16_t) (((q31_t) yt * sinVal) >> 16))); + + pSrc[2U * l + 1U] = (((int16_t) (((q31_t) yt * cosVal) >> 16)) - + ((int16_t) (((q31_t) xt * sinVal) >> 16))); + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + } // stages loop end + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]); + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]); + + pSrc[2U * l] = xt; + + pSrc[2U * l + 1U] = yt; + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + +#endif // #if defined (ARM_MATH_DSP) + +} + + +void arm_radix2_butterfly_inverse_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pCoef, + uint16_t twidCoefModifier) +{ +#if defined (ARM_MATH_DSP) + + unsigned i, j, k, l; + unsigned n1, n2, ia; + q15_t in; + q31_t T, S, R; + q31_t coeff, out1, out2; + + //N = fftLen; + n2 = fftLen; + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (i = 0; i < n2; i++) + { + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + in = ((int16_t) (T & 0xFFFF)) >> 1; + T = ((T >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + in = ((int16_t) (S & 0xFFFF)) >> 1; + S = ((S >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUSD(coeff, R) >> 16; + out2 = __SMUADX(coeff, R); +#else + + out1 = __SMUADX(R, coeff) >> 16U; + out2 = __SMUSD(__QSUB(0, coeff), R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + // loop for butterfly + i++; + l++; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + in = ((int16_t) (T & 0xFFFF)) >> 1; + T = ((T >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + in = ((int16_t) (S & 0xFFFF)) >> 1; + S = ((S >> 1) & 0xFFFF0000) | (in & 0xFFFF); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUSD(coeff, R) >> 16; + out2 = __SMUADX(coeff, R); +#else + + out1 = __SMUADX(R, coeff) >> 16U; + out2 = __SMUSD(__QSUB(0, coeff), R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + + // loop for stage + for (k = fftLen / 2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUSD(coeff, R) >> 16; + out2 = __SMUADX(coeff, R); + +#else + + out1 = __SMUADX(R, coeff) >> 16U; + out2 = __SMUSD(__QSUB(0, coeff), R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + i += n1; + + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __SHADD16(T, S); + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUSD(coeff, R) >> 16; + out2 = __SMUADX(coeff, R); +#else + + out1 = __SMUADX(R, coeff) >> 16U; + out2 = __SMUSD(__QSUB(0, coeff), R); + +#endif // #ifndef ARM_MATH_BIG_ENDIAN + + _SIMD32_OFFSET(pSrc + (2U * l)) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + } // stages loop end + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + coeff = _SIMD32_OFFSET(pCoef + (ia * 2U)); + + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + + T = _SIMD32_OFFSET(pSrc + (2 * i)); + + S = _SIMD32_OFFSET(pSrc + (2 * l)); + + R = __QSUB16(T, S); + + _SIMD32_OFFSET(pSrc + (2 * i)) = __QADD16(T, S); + + _SIMD32_OFFSET(pSrc + (2U * l)) = R; + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + +#else + + + unsigned i, j, k, l; + unsigned n1, n2, ia; + q15_t xt, yt, cosVal, sinVal; + + //N = fftLen; + n2 = fftLen; + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + xt = (pSrc[2 * i] >> 1U) - (pSrc[2 * l] >> 1U); + pSrc[2 * i] = ((pSrc[2 * i] >> 1U) + (pSrc[2 * l] >> 1U)) >> 1U; + + yt = (pSrc[2 * i + 1] >> 1U) - (pSrc[2 * l + 1] >> 1U); + pSrc[2 * i + 1] = + ((pSrc[2 * l + 1] >> 1U) + (pSrc[2 * i + 1] >> 1U)) >> 1U; + + pSrc[2U * l] = (((int16_t) (((q31_t) xt * cosVal) >> 16)) - + ((int16_t) (((q31_t) yt * sinVal) >> 16))); + + pSrc[2U * l + 1U] = (((int16_t) (((q31_t) yt * cosVal) >> 16)) + + ((int16_t) (((q31_t) xt * sinVal) >> 16))); + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + + // loop for stage + for (k = fftLen / 2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]) >> 1U; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]) >> 1U; + + pSrc[2U * l] = (((int16_t) (((q31_t) xt * cosVal) >> 16)) - + ((int16_t) (((q31_t) yt * sinVal) >> 16))); + + pSrc[2U * l + 1U] = (((int16_t) (((q31_t) yt * cosVal) >> 16)) + + ((int16_t) (((q31_t) xt * sinVal) >> 16))); + + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + } // stages loop end + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = 0; i < fftLen; i += n1) + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]); + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]); + + pSrc[2U * l] = xt; + + pSrc[2U * l + 1U] = yt; + + } // groups loop end + + +#endif // #if defined (ARM_MATH_DSP) + +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q31.c new file mode 100644 index 0000000..e69400c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix2_q31.c @@ -0,0 +1,338 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix2_q31.c + * Description: Radix-2 Decimation in Frequency CFFT & CIFFT Fixed point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +void arm_radix2_butterfly_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pCoef, + uint16_t twidCoefModifier); + +void arm_radix2_butterfly_inverse_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pCoef, + uint16_t twidCoefModifier); + +void arm_bitreversal_q31( + q31_t * pSrc, + uint32_t fftLen, + uint16_t bitRevFactor, + uint16_t * pBitRevTab); + +/** +* @ingroup groupTransforms +*/ + +/** +* @addtogroup ComplexFFT +* @{ +*/ + +/** +* @details +* @brief Processing function for the fixed-point CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q31 and will be removed +* @param[in] *S points to an instance of the fixed-point CFFT/CIFFT structure. +* @param[in, out] *pSrc points to the complex data buffer of size 2*fftLen. Processing occurs in-place. +* @return none. +*/ + +void arm_cfft_radix2_q31( +const arm_cfft_radix2_instance_q31 * S, +q31_t * pSrc) +{ + + if (S->ifftFlag == 1U) + { + arm_radix2_butterfly_inverse_q31(pSrc, S->fftLen, + S->pTwiddle, S->twidCoefModifier); + } + else + { + arm_radix2_butterfly_q31(pSrc, S->fftLen, + S->pTwiddle, S->twidCoefModifier); + } + + arm_bitreversal_q31(pSrc, S->fftLen, S->bitRevFactor, S->pBitRevTable); +} + +/** +* @} end of ComplexFFT group +*/ + +void arm_radix2_butterfly_q31( +q31_t * pSrc, +uint32_t fftLen, +q31_t * pCoef, +uint16_t twidCoefModifier) +{ + + unsigned i, j, k, l, m; + unsigned n1, n2, ia; + q31_t xt, yt, cosVal, sinVal; + q31_t p0, p1; + + //N = fftLen; + n2 = fftLen; + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (i = 0; i < n2; i++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + l = i + n2; + xt = (pSrc[2 * i] >> 1U) - (pSrc[2 * l] >> 1U); + pSrc[2 * i] = ((pSrc[2 * i] >> 1U) + (pSrc[2 * l] >> 1U)) >> 1U; + + yt = (pSrc[2 * i + 1] >> 1U) - (pSrc[2 * l + 1] >> 1U); + pSrc[2 * i + 1] = + ((pSrc[2 * l + 1] >> 1U) + (pSrc[2 * i + 1] >> 1U)) >> 1U; + + mult_32x32_keep32_R(p0, xt, cosVal); + mult_32x32_keep32_R(p1, yt, cosVal); + multAcc_32x32_keep32_R(p0, yt, sinVal); + multSub_32x32_keep32_R(p1, xt, sinVal); + + pSrc[2U * l] = p0; + pSrc[2U * l + 1U] = p1; + + } // groups loop end + + twidCoefModifier <<= 1U; + + // loop for stage + for (k = fftLen / 2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + i = j; + m = fftLen / n1; + do + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]) >> 1U; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]) >> 1U; + + mult_32x32_keep32_R(p0, xt, cosVal); + mult_32x32_keep32_R(p1, yt, cosVal); + multAcc_32x32_keep32_R(p0, yt, sinVal); + multSub_32x32_keep32_R(p1, xt, sinVal); + + pSrc[2U * l] = p0; + pSrc[2U * l + 1U] = p1; + i += n1; + m--; + } while ( m > 0); // butterfly loop end + + } // groups loop end + + twidCoefModifier <<= 1U; + } // stages loop end + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = 0; i < fftLen; i += n1) + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]); + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]); + + pSrc[2U * l] = xt; + + pSrc[2U * l + 1U] = yt; + + i += n1; + l = i + n2; + + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]); + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]); + + pSrc[2U * l] = xt; + + pSrc[2U * l + 1U] = yt; + + } // butterfly loop end + +} + + +void arm_radix2_butterfly_inverse_q31( +q31_t * pSrc, +uint32_t fftLen, +q31_t * pCoef, +uint16_t twidCoefModifier) +{ + + unsigned i, j, k, l; + unsigned n1, n2, ia; + q31_t xt, yt, cosVal, sinVal; + q31_t p0, p1; + + //N = fftLen; + n2 = fftLen; + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (i = 0; i < n2; i++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + l = i + n2; + xt = (pSrc[2 * i] >> 1U) - (pSrc[2 * l] >> 1U); + pSrc[2 * i] = ((pSrc[2 * i] >> 1U) + (pSrc[2 * l] >> 1U)) >> 1U; + + yt = (pSrc[2 * i + 1] >> 1U) - (pSrc[2 * l + 1] >> 1U); + pSrc[2 * i + 1] = + ((pSrc[2 * l + 1] >> 1U) + (pSrc[2 * i + 1] >> 1U)) >> 1U; + + mult_32x32_keep32_R(p0, xt, cosVal); + mult_32x32_keep32_R(p1, yt, cosVal); + multSub_32x32_keep32_R(p0, yt, sinVal); + multAcc_32x32_keep32_R(p1, xt, sinVal); + + pSrc[2U * l] = p0; + pSrc[2U * l + 1U] = p1; + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + + // loop for stage + for (k = fftLen / 2; k > 2; k = k >> 1) + { + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + // loop for groups + for (j = 0; j < n2; j++) + { + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = j; i < fftLen; i += n1) + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]) >> 1U; + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]) >> 1U; + + mult_32x32_keep32_R(p0, xt, cosVal); + mult_32x32_keep32_R(p1, yt, cosVal); + multSub_32x32_keep32_R(p0, yt, sinVal); + multAcc_32x32_keep32_R(p1, xt, sinVal); + + pSrc[2U * l] = p0; + pSrc[2U * l + 1U] = p1; + } // butterfly loop end + + } // groups loop end + + twidCoefModifier = twidCoefModifier << 1U; + } // stages loop end + + n1 = n2; + n2 = n2 >> 1; + ia = 0; + + cosVal = pCoef[ia * 2]; + sinVal = pCoef[(ia * 2) + 1]; + ia = ia + twidCoefModifier; + + // loop for butterfly + for (i = 0; i < fftLen; i += n1) + { + l = i + n2; + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]); + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]); + + pSrc[2U * l] = xt; + + pSrc[2U * l + 1U] = yt; + + i += n1; + l = i + n2; + + xt = pSrc[2 * i] - pSrc[2 * l]; + pSrc[2 * i] = (pSrc[2 * i] + pSrc[2 * l]); + + yt = pSrc[2 * i + 1] - pSrc[2 * l + 1]; + pSrc[2 * i + 1] = (pSrc[2 * l + 1] + pSrc[2 * i + 1]); + + pSrc[2U * l] = xt; + + pSrc[2U * l + 1U] = yt; + + } // butterfly loop end + +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_f32.c new file mode 100644 index 0000000..dbbcca7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_f32.c @@ -0,0 +1,1209 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix4_f32.c + * Description: Radix-4 Decimation in Frequency CFFT & CIFFT Floating point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +extern void arm_bitreversal_f32( +float32_t * pSrc, +uint16_t fftSize, +uint16_t bitRevFactor, +uint16_t * pBitRevTab); + +void arm_radix4_butterfly_f32( +float32_t * pSrc, +uint16_t fftLen, +float32_t * pCoef, +uint16_t twidCoefModifier); + +void arm_radix4_butterfly_inverse_f32( +float32_t * pSrc, +uint16_t fftLen, +float32_t * pCoef, +uint16_t twidCoefModifier, +float32_t onebyfftLen); + + +/** +* @ingroup groupTransforms +*/ + +/** +* @addtogroup ComplexFFT +* @{ +*/ + +/** +* @details +* @brief Processing function for the floating-point Radix-4 CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_f32 and will be removed +* in the future. +* @param[in] *S points to an instance of the floating-point Radix-4 CFFT/CIFFT structure. +* @param[in, out] *pSrc points to the complex data buffer of size 2*fftLen. Processing occurs in-place. +* @return none. +*/ + +void arm_cfft_radix4_f32( + const arm_cfft_radix4_instance_f32 * S, + float32_t * pSrc) +{ + if (S->ifftFlag == 1U) + { + /* Complex IFFT radix-4 */ + arm_radix4_butterfly_inverse_f32(pSrc, S->fftLen, S->pTwiddle, S->twidCoefModifier, S->onebyfftLen); + } + else + { + /* Complex FFT radix-4 */ + arm_radix4_butterfly_f32(pSrc, S->fftLen, S->pTwiddle, S->twidCoefModifier); + } + + if (S->bitReverseFlag == 1U) + { + /* Bit Reversal */ + arm_bitreversal_f32(pSrc, S->fftLen, S->bitRevFactor, S->pBitRevTable); + } + +} + +/** +* @} end of ComplexFFT group +*/ + +/* ---------------------------------------------------------------------- + * Internal helper function used by the FFTs + * ---------------------------------------------------------------------- */ + +/* +* @brief Core function for the floating-point CFFT butterfly process. +* @param[in, out] *pSrc points to the in-place buffer of floating-point data type. +* @param[in] fftLen length of the FFT. +* @param[in] *pCoef points to the twiddle coefficient buffer. +* @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @return none. +*/ + +void arm_radix4_butterfly_f32( +float32_t * pSrc, +uint16_t fftLen, +float32_t * pCoef, +uint16_t twidCoefModifier) +{ + + float32_t co1, co2, co3, si1, si2, si3; + uint32_t ia1, ia2, ia3; + uint32_t i0, i1, i2, i3; + uint32_t n1, n2, j, k; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + float32_t xaIn, yaIn, xbIn, ybIn, xcIn, ycIn, xdIn, ydIn; + float32_t Xaplusc, Xbplusd, Yaplusc, Ybplusd, Xaminusc, Xbminusd, Yaminusc, + Ybminusd; + float32_t Xb12C_out, Yb12C_out, Xc12C_out, Yc12C_out, Xd12C_out, Yd12C_out; + float32_t Xb12_out, Yb12_out, Xc12_out, Yc12_out, Xd12_out, Yd12_out; + float32_t *ptr1; + float32_t p0,p1,p2,p3,p4,p5; + float32_t a0,a1,a2,a3,a4,a5,a6,a7; + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + + /* n2 = fftLen/4 */ + n2 >>= 2U; + i0 = 0U; + ia1 = 0U; + + j = n2; + + /* Calculation of first stage */ + do + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + xaIn = pSrc[(2U * i0)]; + yaIn = pSrc[(2U * i0) + 1U]; + + xbIn = pSrc[(2U * i1)]; + ybIn = pSrc[(2U * i1) + 1U]; + + xcIn = pSrc[(2U * i2)]; + ycIn = pSrc[(2U * i2) + 1U]; + + xdIn = pSrc[(2U * i3)]; + ydIn = pSrc[(2U * i3) + 1U]; + + /* xa + xc */ + Xaplusc = xaIn + xcIn; + /* xb + xd */ + Xbplusd = xbIn + xdIn; + /* ya + yc */ + Yaplusc = yaIn + ycIn; + /* yb + yd */ + Ybplusd = ybIn + ydIn; + + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + + /* xa - xc */ + Xaminusc = xaIn - xcIn; + /* xb - xd */ + Xbminusd = xbIn - xdIn; + /* ya - yc */ + Yaminusc = yaIn - ycIn; + /* yb - yd */ + Ybminusd = ybIn - ydIn; + + /* xa' = xa + xb + xc + xd */ + pSrc[(2U * i0)] = Xaplusc + Xbplusd; + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = Yaplusc + Ybplusd; + + /* (xa - xc) + (yb - yd) */ + Xb12C_out = (Xaminusc + Ybminusd); + /* (ya - yc) + (xb - xd) */ + Yb12C_out = (Yaminusc - Xbminusd); + /* (xa + xc) - (xb + xd) */ + Xc12C_out = (Xaplusc - Xbplusd); + /* (ya + yc) - (yb + yd) */ + Yc12C_out = (Yaplusc - Ybplusd); + /* (xa - xc) - (yb - yd) */ + Xd12C_out = (Xaminusc - Ybminusd); + /* (ya - yc) + (xb - xd) */ + Yd12C_out = (Xbminusd + Yaminusc); + + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + + /* index calculation for the coefficients */ + ia3 = ia2 + ia1; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + Xb12_out = Xb12C_out * co1; + Yb12_out = Yb12C_out * co1; + Xc12_out = Xc12C_out * co2; + Yc12_out = Yc12C_out * co2; + Xd12_out = Xd12C_out * co3; + Yd12_out = Yd12C_out * co3; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + //Xb12_out -= Yb12C_out * si1; + p0 = Yb12C_out * si1; + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + //Yb12_out += Xb12C_out * si1; + p1 = Xb12C_out * si1; + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + //Xc12_out -= Yc12C_out * si2; + p2 = Yc12C_out * si2; + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + //Yc12_out += Xc12C_out * si2; + p3 = Xc12C_out * si2; + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + //Xd12_out -= Yd12C_out * si3; + p4 = Yd12C_out * si3; + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + //Yd12_out += Xd12C_out * si3; + p5 = Xd12C_out * si3; + + Xb12_out += p0; + Yb12_out -= p1; + Xc12_out += p2; + Yc12_out -= p3; + Xd12_out += p4; + Yd12_out -= p5; + + /* xc' = (xa-xb+xc-xd)co2 + (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = Xc12_out; + + /* yc' = (ya-yb+yc-yd)co2 - (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = Yc12_out; + + /* xb' = (xa+yb-xc-yd)co1 + (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = Xb12_out; + + /* yb' = (ya-xb-yc+xd)co1 - (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = Yb12_out; + + /* xd' = (xa-yb-xc+yd)co3 + (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = Xd12_out; + + /* yd' = (ya+xb-yc-xd)co3 - (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = Yd12_out; + + /* Twiddle coefficients index modifier */ + ia1 += twidCoefModifier; + + /* Updating input index */ + i0++; + + } + while (--j); + + twidCoefModifier <<= 2U; + + /* Calculation of second stage to excluding last stage */ + for (k = fftLen >> 2U; k > 4U; k >>= 2U) + { + /* Initializations for the first stage */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + /* Calculation of first stage */ + j = 0; + do + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* Twiddle coefficients index modifier */ + ia1 += twidCoefModifier; + + i0 = j; + do + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + xaIn = pSrc[(2U * i0)]; + yaIn = pSrc[(2U * i0) + 1U]; + + xbIn = pSrc[(2U * i1)]; + ybIn = pSrc[(2U * i1) + 1U]; + + xcIn = pSrc[(2U * i2)]; + ycIn = pSrc[(2U * i2) + 1U]; + + xdIn = pSrc[(2U * i3)]; + ydIn = pSrc[(2U * i3) + 1U]; + + /* xa - xc */ + Xaminusc = xaIn - xcIn; + /* (xb - xd) */ + Xbminusd = xbIn - xdIn; + /* ya - yc */ + Yaminusc = yaIn - ycIn; + /* (yb - yd) */ + Ybminusd = ybIn - ydIn; + + /* xa + xc */ + Xaplusc = xaIn + xcIn; + /* xb + xd */ + Xbplusd = xbIn + xdIn; + /* ya + yc */ + Yaplusc = yaIn + ycIn; + /* yb + yd */ + Ybplusd = ybIn + ydIn; + + /* (xa - xc) + (yb - yd) */ + Xb12C_out = (Xaminusc + Ybminusd); + /* (ya - yc) - (xb - xd) */ + Yb12C_out = (Yaminusc - Xbminusd); + /* xa + xc -(xb + xd) */ + Xc12C_out = (Xaplusc - Xbplusd); + /* (ya + yc) - (yb + yd) */ + Yc12C_out = (Yaplusc - Ybplusd); + /* (xa - xc) - (yb - yd) */ + Xd12C_out = (Xaminusc - Ybminusd); + /* (ya - yc) + (xb - xd) */ + Yd12C_out = (Xbminusd + Yaminusc); + + pSrc[(2U * i0)] = Xaplusc + Xbplusd; + pSrc[(2U * i0) + 1U] = Yaplusc + Ybplusd; + + Xb12_out = Xb12C_out * co1; + Yb12_out = Yb12C_out * co1; + Xc12_out = Xc12C_out * co2; + Yc12_out = Yc12C_out * co2; + Xd12_out = Xd12C_out * co3; + Yd12_out = Yd12C_out * co3; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + //Xb12_out -= Yb12C_out * si1; + p0 = Yb12C_out * si1; + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + //Yb12_out += Xb12C_out * si1; + p1 = Xb12C_out * si1; + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + //Xc12_out -= Yc12C_out * si2; + p2 = Yc12C_out * si2; + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + //Yc12_out += Xc12C_out * si2; + p3 = Xc12C_out * si2; + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + //Xd12_out -= Yd12C_out * si3; + p4 = Yd12C_out * si3; + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + //Yd12_out += Xd12C_out * si3; + p5 = Xd12C_out * si3; + + Xb12_out += p0; + Yb12_out -= p1; + Xc12_out += p2; + Yc12_out -= p3; + Xd12_out += p4; + Yd12_out -= p5; + + /* xc' = (xa-xb+xc-xd)co2 + (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = Xc12_out; + + /* yc' = (ya-yb+yc-yd)co2 - (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = Yc12_out; + + /* xb' = (xa+yb-xc-yd)co1 + (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = Xb12_out; + + /* yb' = (ya-xb-yc+xd)co1 - (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = Yb12_out; + + /* xd' = (xa-yb-xc+yd)co3 + (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = Xd12_out; + + /* yd' = (ya+xb-yc-xd)co3 - (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = Yd12_out; + + i0 += n1; + } while (i0 < fftLen); + j++; + } while (j <= (n2 - 1U)); + twidCoefModifier <<= 2U; + } + + j = fftLen >> 2; + ptr1 = &pSrc[0]; + + /* Calculations of last stage */ + do + { + xaIn = ptr1[0]; + yaIn = ptr1[1]; + xbIn = ptr1[2]; + ybIn = ptr1[3]; + xcIn = ptr1[4]; + ycIn = ptr1[5]; + xdIn = ptr1[6]; + ydIn = ptr1[7]; + + /* xa + xc */ + Xaplusc = xaIn + xcIn; + + /* xa - xc */ + Xaminusc = xaIn - xcIn; + + /* ya + yc */ + Yaplusc = yaIn + ycIn; + + /* ya - yc */ + Yaminusc = yaIn - ycIn; + + /* xb + xd */ + Xbplusd = xbIn + xdIn; + + /* yb + yd */ + Ybplusd = ybIn + ydIn; + + /* (xb-xd) */ + Xbminusd = xbIn - xdIn; + + /* (yb-yd) */ + Ybminusd = ybIn - ydIn; + + /* xa' = xa + xb + xc + xd */ + a0 = (Xaplusc + Xbplusd); + /* ya' = ya + yb + yc + yd */ + a1 = (Yaplusc + Ybplusd); + /* xc' = (xa-xb+xc-xd) */ + a2 = (Xaplusc - Xbplusd); + /* yc' = (ya-yb+yc-yd) */ + a3 = (Yaplusc - Ybplusd); + /* xb' = (xa+yb-xc-yd) */ + a4 = (Xaminusc + Ybminusd); + /* yb' = (ya-xb-yc+xd) */ + a5 = (Yaminusc - Xbminusd); + /* xd' = (xa-yb-xc+yd)) */ + a6 = (Xaminusc - Ybminusd); + /* yd' = (ya+xb-yc-xd) */ + a7 = (Xbminusd + Yaminusc); + + ptr1[0] = a0; + ptr1[1] = a1; + ptr1[2] = a2; + ptr1[3] = a3; + ptr1[4] = a4; + ptr1[5] = a5; + ptr1[6] = a6; + ptr1[7] = a7; + + /* increment pointer by 8 */ + ptr1 += 8U; + } while (--j); + +#else + + float32_t t1, t2, r1, r2, s1, s2; + + /* Run the below code for Cortex-M0 */ + + /* Initializations for the fft calculation */ + n2 = fftLen; + n1 = n2; + for (k = fftLen; k > 1U; k >>= 2U) + { + /* Initializations for the fft calculation */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + /* FFT Calculation */ + j = 0; + do + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + i0 = j; + do + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* xa + xc */ + r1 = pSrc[(2U * i0)] + pSrc[(2U * i2)]; + + /* xa - xc */ + r2 = pSrc[(2U * i0)] - pSrc[(2U * i2)]; + + /* ya + yc */ + s1 = pSrc[(2U * i0) + 1U] + pSrc[(2U * i2) + 1U]; + + /* ya - yc */ + s2 = pSrc[(2U * i0) + 1U] - pSrc[(2U * i2) + 1U]; + + /* xb + xd */ + t1 = pSrc[2U * i1] + pSrc[2U * i3]; + + /* xa' = xa + xb + xc + xd */ + pSrc[2U * i0] = r1 + t1; + + /* xa + xc -(xb + xd) */ + r1 = r1 - t1; + + /* yb + yd */ + t2 = pSrc[(2U * i1) + 1U] + pSrc[(2U * i3) + 1U]; + + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = s1 + t2; + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* (yb - yd) */ + t1 = pSrc[(2U * i1) + 1U] - pSrc[(2U * i3) + 1U]; + + /* (xb - xd) */ + t2 = pSrc[2U * i1] - pSrc[2U * i3]; + + /* xc' = (xa-xb+xc-xd)co2 + (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = (r1 * co2) + (s1 * si2); + + /* yc' = (ya-yb+yc-yd)co2 - (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = (s1 * co2) - (r1 * si2); + + /* (xa - xc) + (yb - yd) */ + r1 = r2 + t1; + + /* (xa - xc) - (yb - yd) */ + r2 = r2 - t1; + + /* (ya - yc) - (xb - xd) */ + s1 = s2 - t2; + + /* (ya - yc) + (xb - xd) */ + s2 = s2 + t2; + + /* xb' = (xa+yb-xc-yd)co1 + (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = (r1 * co1) + (s1 * si1); + + /* yb' = (ya-xb-yc+xd)co1 - (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = (s1 * co1) - (r1 * si1); + + /* xd' = (xa-yb-xc+yd)co3 + (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = (r2 * co3) + (s2 * si3); + + /* yd' = (ya+xb-yc-xd)co3 - (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = (s2 * co3) - (r2 * si3); + + i0 += n1; + } while ( i0 < fftLen); + j++; + } while (j <= (n2 - 1U)); + twidCoefModifier <<= 2U; + } + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/* +* @brief Core function for the floating-point CIFFT butterfly process. +* @param[in, out] *pSrc points to the in-place buffer of floating-point data type. +* @param[in] fftLen length of the FFT. +* @param[in] *pCoef points to twiddle coefficient buffer. +* @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @param[in] onebyfftLen value of 1/fftLen. +* @return none. +*/ + +void arm_radix4_butterfly_inverse_f32( +float32_t * pSrc, +uint16_t fftLen, +float32_t * pCoef, +uint16_t twidCoefModifier, +float32_t onebyfftLen) +{ + float32_t co1, co2, co3, si1, si2, si3; + uint32_t ia1, ia2, ia3; + uint32_t i0, i1, i2, i3; + uint32_t n1, n2, j, k; + +#if defined (ARM_MATH_DSP) + + float32_t xaIn, yaIn, xbIn, ybIn, xcIn, ycIn, xdIn, ydIn; + float32_t Xaplusc, Xbplusd, Yaplusc, Ybplusd, Xaminusc, Xbminusd, Yaminusc, + Ybminusd; + float32_t Xb12C_out, Yb12C_out, Xc12C_out, Yc12C_out, Xd12C_out, Yd12C_out; + float32_t Xb12_out, Yb12_out, Xc12_out, Yc12_out, Xd12_out, Yd12_out; + float32_t *ptr1; + float32_t p0,p1,p2,p3,p4,p5,p6,p7; + float32_t a0,a1,a2,a3,a4,a5,a6,a7; + + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + + /* n2 = fftLen/4 */ + n2 >>= 2U; + i0 = 0U; + ia1 = 0U; + + j = n2; + + /* Calculation of first stage */ + do + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Butterfly implementation */ + xaIn = pSrc[(2U * i0)]; + yaIn = pSrc[(2U * i0) + 1U]; + + xcIn = pSrc[(2U * i2)]; + ycIn = pSrc[(2U * i2) + 1U]; + + xbIn = pSrc[(2U * i1)]; + ybIn = pSrc[(2U * i1) + 1U]; + + xdIn = pSrc[(2U * i3)]; + ydIn = pSrc[(2U * i3) + 1U]; + + /* xa + xc */ + Xaplusc = xaIn + xcIn; + /* xb + xd */ + Xbplusd = xbIn + xdIn; + /* ya + yc */ + Yaplusc = yaIn + ycIn; + /* yb + yd */ + Ybplusd = ybIn + ydIn; + + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + + /* xa - xc */ + Xaminusc = xaIn - xcIn; + /* xb - xd */ + Xbminusd = xbIn - xdIn; + /* ya - yc */ + Yaminusc = yaIn - ycIn; + /* yb - yd */ + Ybminusd = ybIn - ydIn; + + /* xa' = xa + xb + xc + xd */ + pSrc[(2U * i0)] = Xaplusc + Xbplusd; + + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = Yaplusc + Ybplusd; + + /* (xa - xc) - (yb - yd) */ + Xb12C_out = (Xaminusc - Ybminusd); + /* (ya - yc) + (xb - xd) */ + Yb12C_out = (Yaminusc + Xbminusd); + /* (xa + xc) - (xb + xd) */ + Xc12C_out = (Xaplusc - Xbplusd); + /* (ya + yc) - (yb + yd) */ + Yc12C_out = (Yaplusc - Ybplusd); + /* (xa - xc) + (yb - yd) */ + Xd12C_out = (Xaminusc + Ybminusd); + /* (ya - yc) - (xb - xd) */ + Yd12C_out = (Yaminusc - Xbminusd); + + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + + /* index calculation for the coefficients */ + ia3 = ia2 + ia1; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + Xb12_out = Xb12C_out * co1; + Yb12_out = Yb12C_out * co1; + Xc12_out = Xc12C_out * co2; + Yc12_out = Yc12C_out * co2; + Xd12_out = Xd12C_out * co3; + Yd12_out = Yd12C_out * co3; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + //Xb12_out -= Yb12C_out * si1; + p0 = Yb12C_out * si1; + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + //Yb12_out += Xb12C_out * si1; + p1 = Xb12C_out * si1; + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + //Xc12_out -= Yc12C_out * si2; + p2 = Yc12C_out * si2; + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + //Yc12_out += Xc12C_out * si2; + p3 = Xc12C_out * si2; + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + //Xd12_out -= Yd12C_out * si3; + p4 = Yd12C_out * si3; + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + //Yd12_out += Xd12C_out * si3; + p5 = Xd12C_out * si3; + + Xb12_out -= p0; + Yb12_out += p1; + Xc12_out -= p2; + Yc12_out += p3; + Xd12_out -= p4; + Yd12_out += p5; + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = Xc12_out; + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = Yc12_out; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = Xb12_out; + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = Yb12_out; + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = Xd12_out; + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = Yd12_out; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + /* Updating input index */ + i0 = i0 + 1U; + + } while (--j); + + twidCoefModifier <<= 2U; + + /* Calculation of second stage to excluding last stage */ + for (k = fftLen >> 2U; k > 4U; k >>= 2U) + { + /* Initializations for the first stage */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + /* Calculation of first stage */ + j = 0; + do + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + i0 = j; + do + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + xaIn = pSrc[(2U * i0)]; + yaIn = pSrc[(2U * i0) + 1U]; + + xbIn = pSrc[(2U * i1)]; + ybIn = pSrc[(2U * i1) + 1U]; + + xcIn = pSrc[(2U * i2)]; + ycIn = pSrc[(2U * i2) + 1U]; + + xdIn = pSrc[(2U * i3)]; + ydIn = pSrc[(2U * i3) + 1U]; + + /* xa - xc */ + Xaminusc = xaIn - xcIn; + /* (xb - xd) */ + Xbminusd = xbIn - xdIn; + /* ya - yc */ + Yaminusc = yaIn - ycIn; + /* (yb - yd) */ + Ybminusd = ybIn - ydIn; + + /* xa + xc */ + Xaplusc = xaIn + xcIn; + /* xb + xd */ + Xbplusd = xbIn + xdIn; + /* ya + yc */ + Yaplusc = yaIn + ycIn; + /* yb + yd */ + Ybplusd = ybIn + ydIn; + + /* (xa - xc) - (yb - yd) */ + Xb12C_out = (Xaminusc - Ybminusd); + /* (ya - yc) + (xb - xd) */ + Yb12C_out = (Yaminusc + Xbminusd); + /* xa + xc -(xb + xd) */ + Xc12C_out = (Xaplusc - Xbplusd); + /* (ya + yc) - (yb + yd) */ + Yc12C_out = (Yaplusc - Ybplusd); + /* (xa - xc) + (yb - yd) */ + Xd12C_out = (Xaminusc + Ybminusd); + /* (ya - yc) - (xb - xd) */ + Yd12C_out = (Yaminusc - Xbminusd); + + pSrc[(2U * i0)] = Xaplusc + Xbplusd; + pSrc[(2U * i0) + 1U] = Yaplusc + Ybplusd; + + Xb12_out = Xb12C_out * co1; + Yb12_out = Yb12C_out * co1; + Xc12_out = Xc12C_out * co2; + Yc12_out = Yc12C_out * co2; + Xd12_out = Xd12C_out * co3; + Yd12_out = Yd12C_out * co3; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + //Xb12_out -= Yb12C_out * si1; + p0 = Yb12C_out * si1; + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + //Yb12_out += Xb12C_out * si1; + p1 = Xb12C_out * si1; + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + //Xc12_out -= Yc12C_out * si2; + p2 = Yc12C_out * si2; + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + //Yc12_out += Xc12C_out * si2; + p3 = Xc12C_out * si2; + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + //Xd12_out -= Yd12C_out * si3; + p4 = Yd12C_out * si3; + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + //Yd12_out += Xd12C_out * si3; + p5 = Xd12C_out * si3; + + Xb12_out -= p0; + Yb12_out += p1; + Xc12_out -= p2; + Yc12_out += p3; + Xd12_out -= p4; + Yd12_out += p5; + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = Xc12_out; + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = Yc12_out; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = Xb12_out; + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = Yb12_out; + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = Xd12_out; + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = Yd12_out; + + i0 += n1; + } while (i0 < fftLen); + j++; + } while (j <= (n2 - 1U)); + twidCoefModifier <<= 2U; + } + /* Initializations of last stage */ + + j = fftLen >> 2; + ptr1 = &pSrc[0]; + + /* Calculations of last stage */ + do + { + xaIn = ptr1[0]; + yaIn = ptr1[1]; + xbIn = ptr1[2]; + ybIn = ptr1[3]; + xcIn = ptr1[4]; + ycIn = ptr1[5]; + xdIn = ptr1[6]; + ydIn = ptr1[7]; + + /* Butterfly implementation */ + /* xa + xc */ + Xaplusc = xaIn + xcIn; + + /* xa - xc */ + Xaminusc = xaIn - xcIn; + + /* ya + yc */ + Yaplusc = yaIn + ycIn; + + /* ya - yc */ + Yaminusc = yaIn - ycIn; + + /* xb + xd */ + Xbplusd = xbIn + xdIn; + + /* yb + yd */ + Ybplusd = ybIn + ydIn; + + /* (xb-xd) */ + Xbminusd = xbIn - xdIn; + + /* (yb-yd) */ + Ybminusd = ybIn - ydIn; + + /* xa' = (xa+xb+xc+xd) * onebyfftLen */ + a0 = (Xaplusc + Xbplusd); + /* ya' = (ya+yb+yc+yd) * onebyfftLen */ + a1 = (Yaplusc + Ybplusd); + /* xc' = (xa-xb+xc-xd) * onebyfftLen */ + a2 = (Xaplusc - Xbplusd); + /* yc' = (ya-yb+yc-yd) * onebyfftLen */ + a3 = (Yaplusc - Ybplusd); + /* xb' = (xa-yb-xc+yd) * onebyfftLen */ + a4 = (Xaminusc - Ybminusd); + /* yb' = (ya+xb-yc-xd) * onebyfftLen */ + a5 = (Yaminusc + Xbminusd); + /* xd' = (xa-yb-xc+yd) * onebyfftLen */ + a6 = (Xaminusc + Ybminusd); + /* yd' = (ya-xb-yc+xd) * onebyfftLen */ + a7 = (Yaminusc - Xbminusd); + + p0 = a0 * onebyfftLen; + p1 = a1 * onebyfftLen; + p2 = a2 * onebyfftLen; + p3 = a3 * onebyfftLen; + p4 = a4 * onebyfftLen; + p5 = a5 * onebyfftLen; + p6 = a6 * onebyfftLen; + p7 = a7 * onebyfftLen; + + /* xa' = (xa+xb+xc+xd) * onebyfftLen */ + ptr1[0] = p0; + /* ya' = (ya+yb+yc+yd) * onebyfftLen */ + ptr1[1] = p1; + /* xc' = (xa-xb+xc-xd) * onebyfftLen */ + ptr1[2] = p2; + /* yc' = (ya-yb+yc-yd) * onebyfftLen */ + ptr1[3] = p3; + /* xb' = (xa-yb-xc+yd) * onebyfftLen */ + ptr1[4] = p4; + /* yb' = (ya+xb-yc-xd) * onebyfftLen */ + ptr1[5] = p5; + /* xd' = (xa-yb-xc+yd) * onebyfftLen */ + ptr1[6] = p6; + /* yd' = (ya-xb-yc+xd) * onebyfftLen */ + ptr1[7] = p7; + + /* increment source pointer by 8 for next calculations */ + ptr1 = ptr1 + 8U; + + } while (--j); + +#else + + float32_t t1, t2, r1, r2, s1, s2; + + /* Run the below code for Cortex-M0 */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + + /* Calculation of first stage */ + for (k = fftLen; k > 4U; k >>= 2U) + { + /* Initializations for the first stage */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + /* Calculation of first stage */ + j = 0; + do + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + i0 = j; + do + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* xa + xc */ + r1 = pSrc[(2U * i0)] + pSrc[(2U * i2)]; + + /* xa - xc */ + r2 = pSrc[(2U * i0)] - pSrc[(2U * i2)]; + + /* ya + yc */ + s1 = pSrc[(2U * i0) + 1U] + pSrc[(2U * i2) + 1U]; + + /* ya - yc */ + s2 = pSrc[(2U * i0) + 1U] - pSrc[(2U * i2) + 1U]; + + /* xb + xd */ + t1 = pSrc[2U * i1] + pSrc[2U * i3]; + + /* xa' = xa + xb + xc + xd */ + pSrc[2U * i0] = r1 + t1; + + /* xa + xc -(xb + xd) */ + r1 = r1 - t1; + + /* yb + yd */ + t2 = pSrc[(2U * i1) + 1U] + pSrc[(2U * i3) + 1U]; + + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = s1 + t2; + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* (yb - yd) */ + t1 = pSrc[(2U * i1) + 1U] - pSrc[(2U * i3) + 1U]; + + /* (xb - xd) */ + t2 = pSrc[2U * i1] - pSrc[2U * i3]; + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = (r1 * co2) - (s1 * si2); + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = (s1 * co2) + (r1 * si2); + + /* (xa - xc) - (yb - yd) */ + r1 = r2 - t1; + + /* (xa - xc) + (yb - yd) */ + r2 = r2 + t1; + + /* (ya - yc) + (xb - xd) */ + s1 = s2 + t2; + + /* (ya - yc) - (xb - xd) */ + s2 = s2 - t2; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = (r1 * co1) - (s1 * si1); + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = (s1 * co1) + (r1 * si1); + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = (r2 * co3) - (s2 * si3); + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = (s2 * co3) + (r2 * si3); + + i0 += n1; + } while ( i0 < fftLen); + j++; + } while (j <= (n2 - 1U)); + twidCoefModifier <<= 2U; + } + /* Initializations of last stage */ + n1 = n2; + n2 >>= 2U; + + /* Calculations of last stage */ + for (i0 = 0U; i0 <= (fftLen - n1); i0 += n1) + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Butterfly implementation */ + /* xa + xc */ + r1 = pSrc[2U * i0] + pSrc[2U * i2]; + + /* xa - xc */ + r2 = pSrc[2U * i0] - pSrc[2U * i2]; + + /* ya + yc */ + s1 = pSrc[(2U * i0) + 1U] + pSrc[(2U * i2) + 1U]; + + /* ya - yc */ + s2 = pSrc[(2U * i0) + 1U] - pSrc[(2U * i2) + 1U]; + + /* xc + xd */ + t1 = pSrc[2U * i1] + pSrc[2U * i3]; + + /* xa' = xa + xb + xc + xd */ + pSrc[2U * i0] = (r1 + t1) * onebyfftLen; + + /* (xa + xb) - (xc + xd) */ + r1 = r1 - t1; + + /* yb + yd */ + t2 = pSrc[(2U * i1) + 1U] + pSrc[(2U * i3) + 1U]; + + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = (s1 + t2) * onebyfftLen; + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* (yb-yd) */ + t1 = pSrc[(2U * i1) + 1U] - pSrc[(2U * i3) + 1U]; + + /* (xb-xd) */ + t2 = pSrc[2U * i1] - pSrc[2U * i3]; + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = r1 * onebyfftLen; + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = s1 * onebyfftLen; + + /* (xa - xc) - (yb-yd) */ + r1 = r2 - t1; + + /* (xa - xc) + (yb-yd) */ + r2 = r2 + t1; + + /* (ya - yc) + (xb-xd) */ + s1 = s2 + t2; + + /* (ya - yc) - (xb-xd) */ + s2 = s2 - t2; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = r1 * onebyfftLen; + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = s1 * onebyfftLen; + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = r2 * onebyfftLen; + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = s2 * onebyfftLen; + } + +#endif /* #if defined (ARM_MATH_DSP) */ +} + + diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_f32.c new file mode 100644 index 0000000..5383771 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_f32.c @@ -0,0 +1,152 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix4_init_f32.c + * Description: Radix-4 Decimation in Frequency Floating-point CFFT & CIFFT Initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup ComplexFFT + * @{ + */ + +/** +* @brief Initialization function for the floating-point CFFT/CIFFT. +* @deprecated Do not use this function. It has been superceded by \ref arm_cfft_f32 and will be removed +* in the future. +* @param[in,out] *S points to an instance of the floating-point CFFT/CIFFT structure. +* @param[in] fftLen length of the FFT. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLen is not a supported value. +* +* \par Description: +* \par +* The parameter ifftFlag controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlag for calculation of CIFFT otherwise CFFT is calculated +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* The parameter fftLen Specifies length of CFFT/CIFFT process. Supported FFT Lengths are 16, 64, 256, 1024. +* \par +* This Function also initializes Twiddle factor table pointer and Bit reversal table pointer. +*/ + +arm_status arm_cfft_radix4_init_f32( + arm_cfft_radix4_instance_f32 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initialise the FFT length */ + S->fftLen = fftLen; + + /* Initialise the Twiddle coefficient pointer */ + S->pTwiddle = (float32_t *) twiddleCoef; + + /* Initialise the Flag for selection of CFFT or CIFFT */ + S->ifftFlag = ifftFlag; + + /* Initialise the Flag for calculation Bit reversal or not */ + S->bitReverseFlag = bitReverseFlag; + + /* Initializations of structure parameters depending on the FFT length */ + switch (S->fftLen) + { + + case 4096U: + /* Initializations of structure parameters for 4096 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 1U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 1U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) armBitRevTable; + /* Initialise the 1/fftLen Value */ + S->onebyfftLen = 0.000244140625; + break; + + case 1024U: + /* Initializations of structure parameters for 1024 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 4U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 4U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[3]; + /* Initialise the 1/fftLen Value */ + S->onebyfftLen = 0.0009765625f; + break; + + + case 256U: + /* Initializations of structure parameters for 256 point FFT */ + S->twidCoefModifier = 16U; + S->bitRevFactor = 16U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[15]; + S->onebyfftLen = 0.00390625f; + break; + + case 64U: + /* Initializations of structure parameters for 64 point FFT */ + S->twidCoefModifier = 64U; + S->bitRevFactor = 64U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[63]; + S->onebyfftLen = 0.015625f; + break; + + case 16U: + /* Initializations of structure parameters for 16 point FFT */ + S->twidCoefModifier = 256U; + S->bitRevFactor = 256U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[255]; + S->onebyfftLen = 0.0625f; + break; + + + default: + /* Reporting argument error if fftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + return (status); +} + +/** + * @} end of ComplexFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q15.c new file mode 100644 index 0000000..b2e38b4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q15.c @@ -0,0 +1,140 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix4_init_q15.c + * Description: Radix-4 Decimation in Frequency Q15 FFT & IFFT initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupTransforms + */ + + +/** + * @addtogroup ComplexFFT + * @{ + */ + + +/** +* @brief Initialization function for the Q15 CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q15 and will be removed +* @param[in,out] *S points to an instance of the Q15 CFFT/CIFFT structure. +* @param[in] fftLen length of the FFT. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLen is not a supported value. +* +* \par Description: +* \par +* The parameter ifftFlag controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlag for calculation of CIFFT otherwise CFFT is calculated +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* The parameter fftLen Specifies length of CFFT/CIFFT process. Supported FFT Lengths are 16, 64, 256, 1024. +* \par +* This Function also initializes Twiddle factor table pointer and Bit reversal table pointer. +*/ + +arm_status arm_cfft_radix4_init_q15( + arm_cfft_radix4_instance_q15 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + /* Initialise the FFT length */ + S->fftLen = fftLen; + /* Initialise the Twiddle coefficient pointer */ + S->pTwiddle = (q15_t *) twiddleCoef_4096_q15; + /* Initialise the Flag for selection of CFFT or CIFFT */ + S->ifftFlag = ifftFlag; + /* Initialise the Flag for calculation Bit reversal or not */ + S->bitReverseFlag = bitReverseFlag; + + /* Initializations of structure parameters depending on the FFT length */ + switch (S->fftLen) + { + case 4096U: + /* Initializations of structure parameters for 4096 point FFT */ + + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 1U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 1U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) armBitRevTable; + + break; + + case 1024U: + /* Initializations of structure parameters for 1024 point FFT */ + S->twidCoefModifier = 4U; + S->bitRevFactor = 4U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[3]; + + break; + + case 256U: + /* Initializations of structure parameters for 256 point FFT */ + S->twidCoefModifier = 16U; + S->bitRevFactor = 16U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[15]; + + break; + + case 64U: + /* Initializations of structure parameters for 64 point FFT */ + S->twidCoefModifier = 64U; + S->bitRevFactor = 64U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[63]; + + break; + + case 16U: + /* Initializations of structure parameters for 16 point FFT */ + S->twidCoefModifier = 256U; + S->bitRevFactor = 256U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[255]; + + break; + + default: + /* Reporting argument error if fftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + return (status); +} + +/** + * @} end of ComplexFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q31.c new file mode 100644 index 0000000..9c11754 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_init_q31.c @@ -0,0 +1,136 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix4_init_q31.c + * Description: Radix-4 Decimation in Frequency Q31 FFT & IFFT initialization function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup ComplexFFT + * @{ + */ + +/** +* +* @brief Initialization function for the Q31 CFFT/CIFFT. +* @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q31 and will be removed +* @param[in,out] *S points to an instance of the Q31 CFFT/CIFFT structure. +* @param[in] fftLen length of the FFT. +* @param[in] ifftFlag flag that selects forward (ifftFlag=0) or inverse (ifftFlag=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLen is not a supported value. +* +* \par Description: +* \par +* The parameter ifftFlag controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlag for calculation of CIFFT otherwise CFFT is calculated +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* The parameter fftLen Specifies length of CFFT/CIFFT process. Supported FFT Lengths are 16, 64, 256, 1024. +* \par +* This Function also initializes Twiddle factor table pointer and Bit reversal table pointer. +*/ + +arm_status arm_cfft_radix4_init_q31( + arm_cfft_radix4_instance_q31 * S, + uint16_t fftLen, + uint8_t ifftFlag, + uint8_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + /* Initialise the FFT length */ + S->fftLen = fftLen; + /* Initialise the Twiddle coefficient pointer */ + S->pTwiddle = (q31_t *) twiddleCoef_4096_q31; + /* Initialise the Flag for selection of CFFT or CIFFT */ + S->ifftFlag = ifftFlag; + /* Initialise the Flag for calculation Bit reversal or not */ + S->bitReverseFlag = bitReverseFlag; + + /* Initializations of Instance structure depending on the FFT length */ + switch (S->fftLen) + { + /* Initializations of structure parameters for 4096 point FFT */ + case 4096U: + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 1U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 1U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) armBitRevTable; + break; + + /* Initializations of structure parameters for 1024 point FFT */ + case 1024U: + /* Initialise the twiddle coef modifier value */ + S->twidCoefModifier = 4U; + /* Initialise the bit reversal table modifier */ + S->bitRevFactor = 4U; + /* Initialise the bit reversal table pointer */ + S->pBitRevTable = (uint16_t *) & armBitRevTable[3]; + break; + + case 256U: + /* Initializations of structure parameters for 256 point FFT */ + S->twidCoefModifier = 16U; + S->bitRevFactor = 16U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[15]; + break; + + case 64U: + /* Initializations of structure parameters for 64 point FFT */ + S->twidCoefModifier = 64U; + S->bitRevFactor = 64U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[63]; + break; + + case 16U: + /* Initializations of structure parameters for 16 point FFT */ + S->twidCoefModifier = 256U; + S->bitRevFactor = 256U; + S->pBitRevTable = (uint16_t *) & armBitRevTable[255]; + break; + + default: + /* Reporting argument error if fftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + return (status); +} + +/** + * @} end of ComplexFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q15.c new file mode 100644 index 0000000..140fa53 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q15.c @@ -0,0 +1,1910 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix4_q15.c + * Description: This file has function definition of Radix-4 FFT & IFFT function and + * In-place bit reversal using bit reversal table + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + + +void arm_radix4_butterfly_q15( + q15_t * pSrc16, + uint32_t fftLen, + q15_t * pCoef16, + uint32_t twidCoefModifier); + +void arm_radix4_butterfly_inverse_q15( + q15_t * pSrc16, + uint32_t fftLen, + q15_t * pCoef16, + uint32_t twidCoefModifier); + +void arm_bitreversal_q15( + q15_t * pSrc, + uint32_t fftLen, + uint16_t bitRevFactor, + uint16_t * pBitRevTab); + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup ComplexFFT + * @{ + */ + + +/** + * @details + * @brief Processing function for the Q15 CFFT/CIFFT. + * @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q15 and will be removed + * @param[in] *S points to an instance of the Q15 CFFT/CIFFT structure. + * @param[in, out] *pSrc points to the complex data buffer. Processing occurs in-place. + * @return none. + * + * \par Input and output formats: + * \par + * Internally input is downscaled by 2 for every stage to avoid saturations inside CFFT/CIFFT process. + * Hence the output format is different for different FFT sizes. + * The input and output formats for different FFT sizes and number of bits to upscale are mentioned in the tables below for CFFT and CIFFT: + * \par + * \image html CFFTQ15.gif "Input and Output Formats for Q15 CFFT" + * \image html CIFFTQ15.gif "Input and Output Formats for Q15 CIFFT" + */ + +void arm_cfft_radix4_q15( + const arm_cfft_radix4_instance_q15 * S, + q15_t * pSrc) +{ + if (S->ifftFlag == 1U) + { + /* Complex IFFT radix-4 */ + arm_radix4_butterfly_inverse_q15(pSrc, S->fftLen, S->pTwiddle, S->twidCoefModifier); + } + else + { + /* Complex FFT radix-4 */ + arm_radix4_butterfly_q15(pSrc, S->fftLen, S->pTwiddle, S->twidCoefModifier); + } + + if (S->bitReverseFlag == 1U) + { + /* Bit Reversal */ + arm_bitreversal_q15(pSrc, S->fftLen, S->bitRevFactor, S->pBitRevTable); + } + +} + +/** + * @} end of ComplexFFT group + */ + +/* +* Radix-4 FFT algorithm used is : +* +* Input real and imaginary data: +* x(n) = xa + j * ya +* x(n+N/4 ) = xb + j * yb +* x(n+N/2 ) = xc + j * yc +* x(n+3N 4) = xd + j * yd +* +* +* Output real and imaginary data: +* x(4r) = xa'+ j * ya' +* x(4r+1) = xb'+ j * yb' +* x(4r+2) = xc'+ j * yc' +* x(4r+3) = xd'+ j * yd' +* +* +* Twiddle factors for radix-4 FFT: +* Wn = co1 + j * (- si1) +* W2n = co2 + j * (- si2) +* W3n = co3 + j * (- si3) + +* The real and imaginary output values for the radix-4 butterfly are +* xa' = xa + xb + xc + xd +* ya' = ya + yb + yc + yd +* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) +* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) +* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) +* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) +* xd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) +* yd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) +* +*/ + +/** + * @brief Core function for the Q15 CFFT butterfly process. + * @param[in, out] *pSrc16 points to the in-place buffer of Q15 data type. + * @param[in] fftLen length of the FFT. + * @param[in] *pCoef16 points to twiddle coefficient buffer. + * @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. + * @return none. + */ + +void arm_radix4_butterfly_q15( + q15_t * pSrc16, + uint32_t fftLen, + q15_t * pCoef16, + uint32_t twidCoefModifier) +{ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t R, S, T, U; + q31_t C1, C2, C3, out1, out2; + uint32_t n1, n2, ic, i0, j, k; + + q15_t *ptr1; + q15_t *pSi0; + q15_t *pSi1; + q15_t *pSi2; + q15_t *pSi3; + + q31_t xaya, xbyb, xcyc, xdyd; + + /* Total process is divided into three stages */ + + /* process first stage, middle stages, & last stage */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + + /* n2 = fftLen/4 */ + n2 >>= 2U; + + /* Index for twiddle coefficient */ + ic = 0U; + + /* Index for input read and output write */ + j = n2; + + pSi0 = pSrc16; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + /* Input is in 1.15(q15) format */ + + /* start of first stage process */ + do + { + /* Butterfly implementation */ + + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T = _SIMD32_OFFSET(pSi0); + T = __SHADD16(T, 0); // this is just a SIMD arithmetic shift right by 1 + T = __SHADD16(T, 0); // it turns out doing this twice is 2 cycles, the alternative takes 3 cycles + //in = ((int16_t) (T & 0xFFFF)) >> 2; // alternative code that takes 3 cycles + //T = ((T >> 2) & 0xFFFF0000) | (in & 0xFFFF); + + /* Read yc (real), xc(imag) input */ + S = _SIMD32_OFFSET(pSi2); + S = __SHADD16(S, 0); + S = __SHADD16(S, 0); + + /* R = packed((ya + yc), (xa + xc) ) */ + R = __QADD16(T, S); + + /* S = packed((ya - yc), (xa - xc) ) */ + S = __QSUB16(T, S); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T = _SIMD32_OFFSET(pSi1); + T = __SHADD16(T, 0); + T = __SHADD16(T, 0); + + /* Read yd (real), xd(imag) input */ + U = _SIMD32_OFFSET(pSi3); + U = __SHADD16(U, 0); + U = __SHADD16(U, 0); + + /* T = packed((yb + yd), (xb + xd) ) */ + T = __QADD16(T, U); + + /* writing the butterfly processed i0 sample */ + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + _SIMD32_OFFSET(pSi0) = __SHADD16(R, T); + pSi0 += 2; + + /* R = packed((ya + yc) - (yb + yd), (xa + xc)- (xb + xd)) */ + R = __QSUB16(R, T); + + /* co2 & si2 are read from SIMD Coefficient pointer */ + C2 = _SIMD32_OFFSET(pCoef16 + (4U * ic)); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + out1 = __SMUAD(C2, R) >> 16U; + /* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out2 = __SMUSDX(C2, R); + +#else + + /* xc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out1 = __SMUSDX(R, C2) >> 16U; + /* yc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + out2 = __SMUAD(C2, R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Reading i0+fftLen/4 */ + /* T = packed(yb, xb) */ + T = _SIMD32_OFFSET(pSi1); + T = __SHADD16(T, 0); + T = __SHADD16(T, 0); + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* writing output(xc', yc') in little endian format */ + _SIMD32_OFFSET(pSi1) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi1 += 2; + + /* Butterfly calculations */ + /* U = packed(yd, xd) */ + U = _SIMD32_OFFSET(pSi3); + U = __SHADD16(U, 0); + U = __SHADD16(U, 0); + + /* T = packed(yb-yd, xb-xd) */ + T = __QSUB16(T, U); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __QASX(S, T); + /* S = packed((ya-yc) - (xb- xd), (xa-xc) + (yb-yd)) */ + S = __QSAX(S, T); + +#else + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __QSAX(S, T); + /* S = packed((ya-yc) - (xb- xd), (xa-xc) + (yb-yd)) */ + S = __QASX(S, T); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* co1 & si1 are read from SIMD Coefficient pointer */ + C1 = _SIMD32_OFFSET(pCoef16 + (2U * ic)); + /* Butterfly process for the i0+fftLen/2 sample */ + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + out1 = __SMUAD(C1, S) >> 16U; + /* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + out2 = __SMUSDX(C1, S); + +#else + + /* xb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + out1 = __SMUSDX(S, C1) >> 16U; + /* yb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + out2 = __SMUAD(C1, S); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* writing output(xb', yb') in little endian format */ + _SIMD32_OFFSET(pSi2) = + ((out2) & 0xFFFF0000) | ((out1) & 0x0000FFFF); + pSi2 += 2; + + + /* co3 & si3 are read from SIMD Coefficient pointer */ + C3 = _SIMD32_OFFSET(pCoef16 + (6U * ic)); + /* Butterfly process for the i0+3fftLen/4 sample */ + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) */ + out1 = __SMUAD(C3, R) >> 16U; + /* yd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) */ + out2 = __SMUSDX(C3, R); + +#else + + /* xd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) */ + out1 = __SMUSDX(R, C3) >> 16U; + /* yd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) */ + out2 = __SMUAD(C3, R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* writing output(xd', yd') in little endian format */ + _SIMD32_OFFSET(pSi3) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi3 += 2; + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + } while (--j); + /* data is in 4.11(q11) format */ + + /* end of first stage process */ + + + /* start of middle stage process */ + + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + + /* Calculation of Middle stage */ + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the middle stage */ + n1 = n2; + n2 >>= 2U; + ic = 0U; + + for (j = 0U; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + C1 = _SIMD32_OFFSET(pCoef16 + (2U * ic)); + C2 = _SIMD32_OFFSET(pCoef16 + (4U * ic)); + C3 = _SIMD32_OFFSET(pCoef16 + (6U * ic)); + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + pSi0 = pSrc16 + 2 * j; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + /* Butterfly implementation */ + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T = _SIMD32_OFFSET(pSi0); + + /* Read yc (real), xc(imag) input */ + S = _SIMD32_OFFSET(pSi2); + + /* R = packed( (ya + yc), (xa + xc)) */ + R = __QADD16(T, S); + + /* S = packed((ya - yc), (xa - xc)) */ + S = __QSUB16(T, S); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T = _SIMD32_OFFSET(pSi1); + + /* Read yd (real), xd(imag) input */ + U = _SIMD32_OFFSET(pSi3); + + /* T = packed( (yb + yd), (xb + xd)) */ + T = __QADD16(T, U); + + /* writing the butterfly processed i0 sample */ + + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + out1 = __SHADD16(R, T); + out1 = __SHADD16(out1, 0); + _SIMD32_OFFSET(pSi0) = out1; + pSi0 += 2 * n1; + + /* R = packed( (ya + yc) - (yb + yd), (xa + xc) - (xb + xd)) */ + R = __SHSUB16(R, T); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* (ya-yb+yc-yd)* (si2) + (xa-xb+xc-xd)* co2 */ + out1 = __SMUAD(C2, R) >> 16U; + + /* (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out2 = __SMUSDX(C2, R); + +#else + + /* (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out1 = __SMUSDX(R, C2) >> 16U; + + /* (ya-yb+yc-yd)* (si2) + (xa-xb+xc-xd)* co2 */ + out2 = __SMUAD(C2, R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Reading i0+3fftLen/4 */ + /* Read yb (real), xb(imag) input */ + T = _SIMD32_OFFSET(pSi1); + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + /* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + _SIMD32_OFFSET(pSi1) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi1 += 2 * n1; + + /* Butterfly calculations */ + + /* Read yd (real), xd(imag) input */ + U = _SIMD32_OFFSET(pSi3); + + /* T = packed(yb-yd, xb-xd) */ + T = __QSUB16(T, U); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __SHASX(S, T); + + /* S = packed((ya-yc) - (xb- xd), (xa-xc) + (yb-yd)) */ + S = __SHSAX(S, T); + + + /* Butterfly process for the i0+fftLen/2 sample */ + out1 = __SMUAD(C1, S) >> 16U; + out2 = __SMUSDX(C1, S); + +#else + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __SHSAX(S, T); + + /* S = packed((ya-yc) - (xb- xd), (xa-xc) + (yb-yd)) */ + S = __SHASX(S, T); + + + /* Butterfly process for the i0+fftLen/2 sample */ + out1 = __SMUSDX(S, C1) >> 16U; + out2 = __SMUAD(C1, S); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + /* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + _SIMD32_OFFSET(pSi2) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi2 += 2 * n1; + + /* Butterfly process for the i0+3fftLen/4 sample */ + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUAD(C3, R) >> 16U; + out2 = __SMUSDX(C3, R); + +#else + + out1 = __SMUSDX(R, C3) >> 16U; + out2 = __SMUAD(C3, R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* xd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) */ + /* yd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) */ + _SIMD32_OFFSET(pSi3) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi3 += 2 * n1; + } + } + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + } + /* end of middle stage process */ + + + /* data is in 10.6(q6) format for the 1024 point */ + /* data is in 8.8(q8) format for the 256 point */ + /* data is in 6.10(q10) format for the 64 point */ + /* data is in 4.12(q12) format for the 16 point */ + + /* Initializations for the last stage */ + j = fftLen >> 2; + + ptr1 = &pSrc16[0]; + + /* start of last stage process */ + + /* Butterfly implementation */ + do + { + /* Read xa (real), ya(imag) input */ + xaya = *__SIMD32(ptr1)++; + + /* Read xb (real), yb(imag) input */ + xbyb = *__SIMD32(ptr1)++; + + /* Read xc (real), yc(imag) input */ + xcyc = *__SIMD32(ptr1)++; + + /* Read xd (real), yd(imag) input */ + xdyd = *__SIMD32(ptr1)++; + + /* R = packed((ya + yc), (xa + xc)) */ + R = __QADD16(xaya, xcyc); + + /* T = packed((yb + yd), (xb + xd)) */ + T = __QADD16(xbyb, xdyd); + + /* pointer updation for writing */ + ptr1 = ptr1 - 8U; + + + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + *__SIMD32(ptr1)++ = __SHADD16(R, T); + + /* T = packed((yb + yd), (xb + xd)) */ + T = __QADD16(xbyb, xdyd); + + /* xc' = (xa-xb+xc-xd) */ + /* yc' = (ya-yb+yc-yd) */ + *__SIMD32(ptr1)++ = __SHSUB16(R, T); + + /* S = packed((ya - yc), (xa - xc)) */ + S = __QSUB16(xaya, xcyc); + + /* Read yd (real), xd(imag) input */ + /* T = packed( (yb - yd), (xb - xd)) */ + U = __QSUB16(xbyb, xdyd); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xb' = (xa+yb-xc-yd) */ + /* yb' = (ya-xb-yc+xd) */ + *__SIMD32(ptr1)++ = __SHSAX(S, U); + + + /* xd' = (xa-yb-xc+yd) */ + /* yd' = (ya+xb-yc-xd) */ + *__SIMD32(ptr1)++ = __SHASX(S, U); + +#else + + /* xb' = (xa+yb-xc-yd) */ + /* yb' = (ya-xb-yc+xd) */ + *__SIMD32(ptr1)++ = __SHASX(S, U); + + + /* xd' = (xa-yb-xc+yd) */ + /* yd' = (ya+xb-yc-xd) */ + *__SIMD32(ptr1)++ = __SHSAX(S, U); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + } while (--j); + + /* end of last stage process */ + + /* output is in 11.5(q5) format for the 1024 point */ + /* output is in 9.7(q7) format for the 256 point */ + /* output is in 7.9(q9) format for the 64 point */ + /* output is in 5.11(q11) format for the 16 point */ + + +#else + + /* Run the below code for Cortex-M0 */ + + q15_t R0, R1, S0, S1, T0, T1, U0, U1; + q15_t Co1, Si1, Co2, Si2, Co3, Si3, out1, out2; + uint32_t n1, n2, ic, i0, i1, i2, i3, j, k; + + /* Total process is divided into three stages */ + + /* process first stage, middle stages, & last stage */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + + /* n2 = fftLen/4 */ + n2 >>= 2U; + + /* Index for twiddle coefficient */ + ic = 0U; + + /* Index for input read and output write */ + i0 = 0U; + j = n2; + + /* Input is in 1.15(q15) format */ + + /* start of first stage process */ + do + { + /* Butterfly implementation */ + + /* index calculation for the input as, */ + /* pSrc16[i0 + 0], pSrc16[i0 + fftLen/4], pSrc16[i0 + fftLen/2], pSrc16[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Reading i0, i0+fftLen/2 inputs */ + + /* input is down scale by 4 to avoid overflow */ + /* Read ya (real), xa(imag) input */ + T0 = pSrc16[i0 * 2U] >> 2U; + T1 = pSrc16[(i0 * 2U) + 1U] >> 2U; + + /* input is down scale by 4 to avoid overflow */ + /* Read yc (real), xc(imag) input */ + S0 = pSrc16[i2 * 2U] >> 2U; + S1 = pSrc16[(i2 * 2U) + 1U] >> 2U; + + /* R0 = (ya + yc) */ + R0 = __SSAT(T0 + S0, 16U); + /* R1 = (xa + xc) */ + R1 = __SSAT(T1 + S1, 16U); + + /* S0 = (ya - yc) */ + S0 = __SSAT(T0 - S0, 16); + /* S1 = (xa - xc) */ + S1 = __SSAT(T1 - S1, 16); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* input is down scale by 4 to avoid overflow */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U] >> 2U; + T1 = pSrc16[(i1 * 2U) + 1U] >> 2U; + + /* input is down scale by 4 to avoid overflow */ + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U] >> 2U; + U1 = pSrc16[(i3 * 2U) + 1] >> 2U; + + /* T0 = (yb + yd) */ + T0 = __SSAT(T0 + U0, 16U); + /* T1 = (xb + xd) */ + T1 = __SSAT(T1 + U1, 16U); + + /* writing the butterfly processed i0 sample */ + /* ya' = ya + yb + yc + yd */ + /* xa' = xa + xb + xc + xd */ + pSrc16[i0 * 2U] = (R0 >> 1U) + (T0 >> 1U); + pSrc16[(i0 * 2U) + 1U] = (R1 >> 1U) + (T1 >> 1U); + + /* R0 = (ya + yc) - (yb + yd) */ + /* R1 = (xa + xc) - (xb + xd) */ + R0 = __SSAT(R0 - T0, 16U); + R1 = __SSAT(R1 - T1, 16U); + + /* co2 & si2 are read from Coefficient pointer */ + Co2 = pCoef16[2U * ic * 2U]; + Si2 = pCoef16[(2U * ic * 2U) + 1]; + + /* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + out1 = (q15_t) ((Co2 * R0 + Si2 * R1) >> 16U); + /* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out2 = (q15_t) ((-Si2 * R0 + Co2 * R1) >> 16U); + + /* Reading i0+fftLen/4 */ + /* input is down scale by 4 to avoid overflow */ + /* T0 = yb, T1 = xb */ + T0 = pSrc16[i1 * 2U] >> 2; + T1 = pSrc16[(i1 * 2U) + 1] >> 2; + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* writing output(xc', yc') in little endian format */ + pSrc16[i1 * 2U] = out1; + pSrc16[(i1 * 2U) + 1] = out2; + + /* Butterfly calculations */ + /* input is down scale by 4 to avoid overflow */ + /* U0 = yd, U1 = xd */ + U0 = pSrc16[i3 * 2U] >> 2; + U1 = pSrc16[(i3 * 2U) + 1] >> 2; + /* T0 = yb-yd */ + T0 = __SSAT(T0 - U0, 16); + /* T1 = xb-xd */ + T1 = __SSAT(T1 - U1, 16); + + /* R1 = (ya-yc) + (xb- xd), R0 = (xa-xc) - (yb-yd)) */ + R0 = (q15_t) __SSAT((q31_t) (S0 - T1), 16); + R1 = (q15_t) __SSAT((q31_t) (S1 + T0), 16); + + /* S1 = (ya-yc) - (xb- xd), S0 = (xa-xc) + (yb-yd)) */ + S0 = (q15_t) __SSAT(((q31_t) S0 + T1), 16U); + S1 = (q15_t) __SSAT(((q31_t) S1 - T0), 16U); + + /* co1 & si1 are read from Coefficient pointer */ + Co1 = pCoef16[ic * 2U]; + Si1 = pCoef16[(ic * 2U) + 1]; + /* Butterfly process for the i0+fftLen/2 sample */ + /* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + out1 = (q15_t) ((Si1 * S1 + Co1 * S0) >> 16); + /* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + out2 = (q15_t) ((-Si1 * S0 + Co1 * S1) >> 16); + + /* writing output(xb', yb') in little endian format */ + pSrc16[i2 * 2U] = out1; + pSrc16[(i2 * 2U) + 1] = out2; + + /* Co3 & si3 are read from Coefficient pointer */ + Co3 = pCoef16[3U * (ic * 2U)]; + Si3 = pCoef16[(3U * (ic * 2U)) + 1]; + /* Butterfly process for the i0+3fftLen/4 sample */ + /* xd' = (xa-yb-xc+yd)* Co3 + (ya+xb-yc-xd)* (si3) */ + out1 = (q15_t) ((Si3 * R1 + Co3 * R0) >> 16U); + /* yd' = (ya+xb-yc-xd)* Co3 - (xa-yb-xc+yd)* (si3) */ + out2 = (q15_t) ((-Si3 * R0 + Co3 * R1) >> 16U); + /* writing output(xd', yd') in little endian format */ + pSrc16[i3 * 2U] = out1; + pSrc16[(i3 * 2U) + 1] = out2; + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + /* Updating input index */ + i0 = i0 + 1U; + + } while (--j); + /* data is in 4.11(q11) format */ + + /* end of first stage process */ + + + /* start of middle stage process */ + + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + + /* Calculation of Middle stage */ + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the middle stage */ + n1 = n2; + n2 >>= 2U; + ic = 0U; + + for (j = 0U; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + Co1 = pCoef16[ic * 2U]; + Si1 = pCoef16[(ic * 2U) + 1U]; + Co2 = pCoef16[2U * (ic * 2U)]; + Si2 = pCoef16[(2U * (ic * 2U)) + 1U]; + Co3 = pCoef16[3U * (ic * 2U)]; + Si3 = pCoef16[(3U * (ic * 2U)) + 1U]; + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + /* Butterfly implementation */ + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* index calculation for the input as, */ + /* pSrc16[i0 + 0], pSrc16[i0 + fftLen/4], pSrc16[i0 + fftLen/2], pSrc16[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T0 = pSrc16[i0 * 2U]; + T1 = pSrc16[(i0 * 2U) + 1U]; + + /* Read yc (real), xc(imag) input */ + S0 = pSrc16[i2 * 2U]; + S1 = pSrc16[(i2 * 2U) + 1U]; + + /* R0 = (ya + yc), R1 = (xa + xc) */ + R0 = __SSAT(T0 + S0, 16); + R1 = __SSAT(T1 + S1, 16); + + /* S0 = (ya - yc), S1 =(xa - xc) */ + S0 = __SSAT(T0 - S0, 16); + S1 = __SSAT(T1 - S1, 16); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + + + /* T0 = (yb + yd), T1 = (xb + xd) */ + T0 = __SSAT(T0 + U0, 16); + T1 = __SSAT(T1 + U1, 16); + + /* writing the butterfly processed i0 sample */ + + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + out1 = ((R0 >> 1U) + (T0 >> 1U)) >> 1U; + out2 = ((R1 >> 1U) + (T1 >> 1U)) >> 1U; + + pSrc16[i0 * 2U] = out1; + pSrc16[(2U * i0) + 1U] = out2; + + /* R0 = (ya + yc) - (yb + yd), R1 = (xa + xc) - (xb + xd) */ + R0 = (R0 >> 1U) - (T0 >> 1U); + R1 = (R1 >> 1U) - (T1 >> 1U); + + /* (ya-yb+yc-yd)* (si2) + (xa-xb+xc-xd)* co2 */ + out1 = (q15_t) ((Co2 * R0 + Si2 * R1) >> 16U); + + /* (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out2 = (q15_t) ((-Si2 * R0 + Co2 * R1) >> 16U); + + /* Reading i0+3fftLen/4 */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + /* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + pSrc16[i1 * 2U] = out1; + pSrc16[(i1 * 2U) + 1U] = out2; + + /* Butterfly calculations */ + + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + + /* T0 = yb-yd, T1 = xb-xd */ + T0 = __SSAT(T0 - U0, 16); + T1 = __SSAT(T1 - U1, 16); + + /* R0 = (ya-yc) + (xb- xd), R1 = (xa-xc) - (yb-yd)) */ + R0 = (S0 >> 1U) - (T1 >> 1U); + R1 = (S1 >> 1U) + (T0 >> 1U); + + /* S0 = (ya-yc) - (xb- xd), S1 = (xa-xc) + (yb-yd)) */ + S0 = (S0 >> 1U) + (T1 >> 1U); + S1 = (S1 >> 1U) - (T0 >> 1U); + + /* Butterfly process for the i0+fftLen/2 sample */ + out1 = (q15_t) ((Co1 * S0 + Si1 * S1) >> 16U); + + out2 = (q15_t) ((-Si1 * S0 + Co1 * S1) >> 16U); + + /* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + /* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + pSrc16[i2 * 2U] = out1; + pSrc16[(i2 * 2U) + 1U] = out2; + + /* Butterfly process for the i0+3fftLen/4 sample */ + out1 = (q15_t) ((Si3 * R1 + Co3 * R0) >> 16U); + + out2 = (q15_t) ((-Si3 * R0 + Co3 * R1) >> 16U); + /* xd' = (xa-yb-xc+yd)* Co3 + (ya+xb-yc-xd)* (si3) */ + /* yd' = (ya+xb-yc-xd)* Co3 - (xa-yb-xc+yd)* (si3) */ + pSrc16[i3 * 2U] = out1; + pSrc16[(i3 * 2U) + 1U] = out2; + } + } + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + } + /* end of middle stage process */ + + + /* data is in 10.6(q6) format for the 1024 point */ + /* data is in 8.8(q8) format for the 256 point */ + /* data is in 6.10(q10) format for the 64 point */ + /* data is in 4.12(q12) format for the 16 point */ + + /* Initializations for the last stage */ + n1 = n2; + n2 >>= 2U; + + /* start of last stage process */ + + /* Butterfly implementation */ + for (i0 = 0U; i0 <= (fftLen - n1); i0 += n1) + { + /* index calculation for the input as, */ + /* pSrc16[i0 + 0], pSrc16[i0 + fftLen/4], pSrc16[i0 + fftLen/2], pSrc16[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T0 = pSrc16[i0 * 2U]; + T1 = pSrc16[(i0 * 2U) + 1U]; + + /* Read yc (real), xc(imag) input */ + S0 = pSrc16[i2 * 2U]; + S1 = pSrc16[(i2 * 2U) + 1U]; + + /* R0 = (ya + yc), R1 = (xa + xc) */ + R0 = __SSAT(T0 + S0, 16U); + R1 = __SSAT(T1 + S1, 16U); + + /* S0 = (ya - yc), S1 = (xa - xc) */ + S0 = __SSAT(T0 - S0, 16U); + S1 = __SSAT(T1 - S1, 16U); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + + /* T0 = (yb + yd), T1 = (xb + xd)) */ + T0 = __SSAT(T0 + U0, 16U); + T1 = __SSAT(T1 + U1, 16U); + + /* writing the butterfly processed i0 sample */ + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + pSrc16[i0 * 2U] = (R0 >> 1U) + (T0 >> 1U); + pSrc16[(i0 * 2U) + 1U] = (R1 >> 1U) + (T1 >> 1U); + + /* R0 = (ya + yc) - (yb + yd), R1 = (xa + xc) - (xb + xd) */ + R0 = (R0 >> 1U) - (T0 >> 1U); + R1 = (R1 >> 1U) - (T1 >> 1U); + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* xc' = (xa-xb+xc-xd) */ + /* yc' = (ya-yb+yc-yd) */ + pSrc16[i1 * 2U] = R0; + pSrc16[(i1 * 2U) + 1U] = R1; + + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + /* T0 = (yb - yd), T1 = (xb - xd) */ + T0 = __SSAT(T0 - U0, 16U); + T1 = __SSAT(T1 - U1, 16U); + + /* writing the butterfly processed i0 + fftLen/2 sample */ + /* xb' = (xa+yb-xc-yd) */ + /* yb' = (ya-xb-yc+xd) */ + pSrc16[i2 * 2U] = (S0 >> 1U) + (T1 >> 1U); + pSrc16[(i2 * 2U) + 1U] = (S1 >> 1U) - (T0 >> 1U); + + /* writing the butterfly processed i0 + 3fftLen/4 sample */ + /* xd' = (xa-yb-xc+yd) */ + /* yd' = (ya+xb-yc-xd) */ + pSrc16[i3 * 2U] = (S0 >> 1U) - (T1 >> 1U); + pSrc16[(i3 * 2U) + 1U] = (S1 >> 1U) + (T0 >> 1U); + + } + + /* end of last stage process */ + + /* output is in 11.5(q5) format for the 1024 point */ + /* output is in 9.7(q7) format for the 256 point */ + /* output is in 7.9(q9) format for the 64 point */ + /* output is in 5.11(q11) format for the 16 point */ + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + + +/** + * @brief Core function for the Q15 CIFFT butterfly process. + * @param[in, out] *pSrc16 points to the in-place buffer of Q15 data type. + * @param[in] fftLen length of the FFT. + * @param[in] *pCoef16 points to twiddle coefficient buffer. + * @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. + * @return none. + */ + +/* +* Radix-4 IFFT algorithm used is : +* +* CIFFT uses same twiddle coefficients as CFFT function +* x[k] = x[n] + (j)k * x[n + fftLen/4] + (-1)k * x[n+fftLen/2] + (-j)k * x[n+3*fftLen/4] +* +* +* IFFT is implemented with following changes in equations from FFT +* +* Input real and imaginary data: +* x(n) = xa + j * ya +* x(n+N/4 ) = xb + j * yb +* x(n+N/2 ) = xc + j * yc +* x(n+3N 4) = xd + j * yd +* +* +* Output real and imaginary data: +* x(4r) = xa'+ j * ya' +* x(4r+1) = xb'+ j * yb' +* x(4r+2) = xc'+ j * yc' +* x(4r+3) = xd'+ j * yd' +* +* +* Twiddle factors for radix-4 IFFT: +* Wn = co1 + j * (si1) +* W2n = co2 + j * (si2) +* W3n = co3 + j * (si3) + +* The real and imaginary output values for the radix-4 butterfly are +* xa' = xa + xb + xc + xd +* ya' = ya + yb + yc + yd +* xb' = (xa-yb-xc+yd)* co1 - (ya+xb-yc-xd)* (si1) +* yb' = (ya+xb-yc-xd)* co1 + (xa-yb-xc+yd)* (si1) +* xc' = (xa-xb+xc-xd)* co2 - (ya-yb+yc-yd)* (si2) +* yc' = (ya-yb+yc-yd)* co2 + (xa-xb+xc-xd)* (si2) +* xd' = (xa+yb-xc-yd)* co3 - (ya-xb-yc+xd)* (si3) +* yd' = (ya-xb-yc+xd)* co3 + (xa+yb-xc-yd)* (si3) +* +*/ + +void arm_radix4_butterfly_inverse_q15( + q15_t * pSrc16, + uint32_t fftLen, + q15_t * pCoef16, + uint32_t twidCoefModifier) +{ + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + q31_t R, S, T, U; + q31_t C1, C2, C3, out1, out2; + uint32_t n1, n2, ic, i0, j, k; + + q15_t *ptr1; + q15_t *pSi0; + q15_t *pSi1; + q15_t *pSi2; + q15_t *pSi3; + + q31_t xaya, xbyb, xcyc, xdyd; + + /* Total process is divided into three stages */ + + /* process first stage, middle stages, & last stage */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + + /* n2 = fftLen/4 */ + n2 >>= 2U; + + /* Index for twiddle coefficient */ + ic = 0U; + + /* Index for input read and output write */ + j = n2; + + pSi0 = pSrc16; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + /* Input is in 1.15(q15) format */ + + /* start of first stage process */ + do + { + /* Butterfly implementation */ + + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T = _SIMD32_OFFSET(pSi0); + T = __SHADD16(T, 0); + T = __SHADD16(T, 0); + + /* Read yc (real), xc(imag) input */ + S = _SIMD32_OFFSET(pSi2); + S = __SHADD16(S, 0); + S = __SHADD16(S, 0); + + /* R = packed((ya + yc), (xa + xc) ) */ + R = __QADD16(T, S); + + /* S = packed((ya - yc), (xa - xc) ) */ + S = __QSUB16(T, S); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T = _SIMD32_OFFSET(pSi1); + T = __SHADD16(T, 0); + T = __SHADD16(T, 0); + + /* Read yd (real), xd(imag) input */ + U = _SIMD32_OFFSET(pSi3); + U = __SHADD16(U, 0); + U = __SHADD16(U, 0); + + /* T = packed((yb + yd), (xb + xd) ) */ + T = __QADD16(T, U); + + /* writing the butterfly processed i0 sample */ + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + _SIMD32_OFFSET(pSi0) = __SHADD16(R, T); + pSi0 += 2; + + /* R = packed((ya + yc) - (yb + yd), (xa + xc)- (xb + xd)) */ + R = __QSUB16(R, T); + + /* co2 & si2 are read from SIMD Coefficient pointer */ + C2 = _SIMD32_OFFSET(pCoef16 + (4U * ic)); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + out1 = __SMUSD(C2, R) >> 16U; + /* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out2 = __SMUADX(C2, R); + +#else + + /* xc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out1 = __SMUADX(C2, R) >> 16U; + /* yc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + out2 = __SMUSD(__QSUB16(0, C2), R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Reading i0+fftLen/4 */ + /* T = packed(yb, xb) */ + T = _SIMD32_OFFSET(pSi1); + T = __SHADD16(T, 0); + T = __SHADD16(T, 0); + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* writing output(xc', yc') in little endian format */ + _SIMD32_OFFSET(pSi1) = + (q31_t) ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi1 += 2; + + /* Butterfly calculations */ + /* U = packed(yd, xd) */ + U = _SIMD32_OFFSET(pSi3); + U = __SHADD16(U, 0); + U = __SHADD16(U, 0); + + /* T = packed(yb-yd, xb-xd) */ + T = __QSUB16(T, U); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __QSAX(S, T); + /* S = packed((ya-yc) + (xb- xd), (xa-xc) - (yb-yd)) */ + S = __QASX(S, T); + +#else + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __QASX(S, T); + /* S = packed((ya-yc) - (xb- xd), (xa-xc) + (yb-yd)) */ + S = __QSAX(S, T); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* co1 & si1 are read from SIMD Coefficient pointer */ + C1 = _SIMD32_OFFSET(pCoef16 + (2U * ic)); + /* Butterfly process for the i0+fftLen/2 sample */ + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + out1 = __SMUSD(C1, S) >> 16U; + /* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + out2 = __SMUADX(C1, S); + +#else + + /* xb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + out1 = __SMUADX(C1, S) >> 16U; + /* yb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + out2 = __SMUSD(__QSUB16(0, C1), S); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* writing output(xb', yb') in little endian format */ + _SIMD32_OFFSET(pSi2) = + ((out2) & 0xFFFF0000) | ((out1) & 0x0000FFFF); + pSi2 += 2; + + + /* co3 & si3 are read from SIMD Coefficient pointer */ + C3 = _SIMD32_OFFSET(pCoef16 + (6U * ic)); + /* Butterfly process for the i0+3fftLen/4 sample */ + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) */ + out1 = __SMUSD(C3, R) >> 16U; + /* yd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) */ + out2 = __SMUADX(C3, R); + +#else + + /* xd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) */ + out1 = __SMUADX(C3, R) >> 16U; + /* yd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) */ + out2 = __SMUSD(__QSUB16(0, C3), R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* writing output(xd', yd') in little endian format */ + _SIMD32_OFFSET(pSi3) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi3 += 2; + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + } while (--j); + /* data is in 4.11(q11) format */ + + /* end of first stage process */ + + + /* start of middle stage process */ + + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + + /* Calculation of Middle stage */ + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the middle stage */ + n1 = n2; + n2 >>= 2U; + ic = 0U; + + for (j = 0U; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + C1 = _SIMD32_OFFSET(pCoef16 + (2U * ic)); + C2 = _SIMD32_OFFSET(pCoef16 + (4U * ic)); + C3 = _SIMD32_OFFSET(pCoef16 + (6U * ic)); + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + pSi0 = pSrc16 + 2 * j; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + /* Butterfly implementation */ + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T = _SIMD32_OFFSET(pSi0); + + /* Read yc (real), xc(imag) input */ + S = _SIMD32_OFFSET(pSi2); + + /* R = packed( (ya + yc), (xa + xc)) */ + R = __QADD16(T, S); + + /* S = packed((ya - yc), (xa - xc)) */ + S = __QSUB16(T, S); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T = _SIMD32_OFFSET(pSi1); + + /* Read yd (real), xd(imag) input */ + U = _SIMD32_OFFSET(pSi3); + + /* T = packed( (yb + yd), (xb + xd)) */ + T = __QADD16(T, U); + + /* writing the butterfly processed i0 sample */ + + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + out1 = __SHADD16(R, T); + out1 = __SHADD16(out1, 0); + _SIMD32_OFFSET(pSi0) = out1; + pSi0 += 2 * n1; + + /* R = packed( (ya + yc) - (yb + yd), (xa + xc) - (xb + xd)) */ + R = __SHSUB16(R, T); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* (ya-yb+yc-yd)* (si2) + (xa-xb+xc-xd)* co2 */ + out1 = __SMUSD(C2, R) >> 16U; + + /* (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out2 = __SMUADX(C2, R); + +#else + + /* (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + out1 = __SMUADX(R, C2) >> 16U; + + /* (ya-yb+yc-yd)* (si2) + (xa-xb+xc-xd)* co2 */ + out2 = __SMUSD(__QSUB16(0, C2), R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Reading i0+3fftLen/4 */ + /* Read yb (real), xb(imag) input */ + T = _SIMD32_OFFSET(pSi1); + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) */ + /* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) */ + _SIMD32_OFFSET(pSi1) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi1 += 2 * n1; + + /* Butterfly calculations */ + + /* Read yd (real), xd(imag) input */ + U = _SIMD32_OFFSET(pSi3); + + /* T = packed(yb-yd, xb-xd) */ + T = __QSUB16(T, U); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __SHSAX(S, T); + + /* S = packed((ya-yc) - (xb- xd), (xa-xc) + (yb-yd)) */ + S = __SHASX(S, T); + + + /* Butterfly process for the i0+fftLen/2 sample */ + out1 = __SMUSD(C1, S) >> 16U; + out2 = __SMUADX(C1, S); + +#else + + /* R = packed((ya-yc) + (xb- xd) , (xa-xc) - (yb-yd)) */ + R = __SHASX(S, T); + + /* S = packed((ya-yc) - (xb- xd), (xa-xc) + (yb-yd)) */ + S = __SHSAX(S, T); + + + /* Butterfly process for the i0+fftLen/2 sample */ + out1 = __SMUADX(S, C1) >> 16U; + out2 = __SMUSD(__QSUB16(0, C1), S); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) */ + /* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) */ + _SIMD32_OFFSET(pSi2) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi2 += 2 * n1; + + /* Butterfly process for the i0+3fftLen/4 sample */ + +#ifndef ARM_MATH_BIG_ENDIAN + + out1 = __SMUSD(C3, R) >> 16U; + out2 = __SMUADX(C3, R); + +#else + + out1 = __SMUADX(C3, R) >> 16U; + out2 = __SMUSD(__QSUB16(0, C3), R); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* xd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) */ + /* yd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) */ + _SIMD32_OFFSET(pSi3) = + ((out2) & 0xFFFF0000) | (out1 & 0x0000FFFF); + pSi3 += 2 * n1; + } + } + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + } + /* end of middle stage process */ + + /* data is in 10.6(q6) format for the 1024 point */ + /* data is in 8.8(q8) format for the 256 point */ + /* data is in 6.10(q10) format for the 64 point */ + /* data is in 4.12(q12) format for the 16 point */ + + /* Initializations for the last stage */ + j = fftLen >> 2; + + ptr1 = &pSrc16[0]; + + /* start of last stage process */ + + /* Butterfly implementation */ + do + { + /* Read xa (real), ya(imag) input */ + xaya = *__SIMD32(ptr1)++; + + /* Read xb (real), yb(imag) input */ + xbyb = *__SIMD32(ptr1)++; + + /* Read xc (real), yc(imag) input */ + xcyc = *__SIMD32(ptr1)++; + + /* Read xd (real), yd(imag) input */ + xdyd = *__SIMD32(ptr1)++; + + /* R = packed((ya + yc), (xa + xc)) */ + R = __QADD16(xaya, xcyc); + + /* T = packed((yb + yd), (xb + xd)) */ + T = __QADD16(xbyb, xdyd); + + /* pointer updation for writing */ + ptr1 = ptr1 - 8U; + + + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + *__SIMD32(ptr1)++ = __SHADD16(R, T); + + /* T = packed((yb + yd), (xb + xd)) */ + T = __QADD16(xbyb, xdyd); + + /* xc' = (xa-xb+xc-xd) */ + /* yc' = (ya-yb+yc-yd) */ + *__SIMD32(ptr1)++ = __SHSUB16(R, T); + + /* S = packed((ya - yc), (xa - xc)) */ + S = __QSUB16(xaya, xcyc); + + /* Read yd (real), xd(imag) input */ + /* T = packed( (yb - yd), (xb - xd)) */ + U = __QSUB16(xbyb, xdyd); + +#ifndef ARM_MATH_BIG_ENDIAN + + /* xb' = (xa+yb-xc-yd) */ + /* yb' = (ya-xb-yc+xd) */ + *__SIMD32(ptr1)++ = __SHASX(S, U); + + + /* xd' = (xa-yb-xc+yd) */ + /* yd' = (ya+xb-yc-xd) */ + *__SIMD32(ptr1)++ = __SHSAX(S, U); + +#else + + /* xb' = (xa+yb-xc-yd) */ + /* yb' = (ya-xb-yc+xd) */ + *__SIMD32(ptr1)++ = __SHSAX(S, U); + + + /* xd' = (xa-yb-xc+yd) */ + /* yd' = (ya+xb-yc-xd) */ + *__SIMD32(ptr1)++ = __SHASX(S, U); + + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + } while (--j); + + /* end of last stage process */ + + /* output is in 11.5(q5) format for the 1024 point */ + /* output is in 9.7(q7) format for the 256 point */ + /* output is in 7.9(q9) format for the 64 point */ + /* output is in 5.11(q11) format for the 16 point */ + + +#else + + /* Run the below code for Cortex-M0 */ + + q15_t R0, R1, S0, S1, T0, T1, U0, U1; + q15_t Co1, Si1, Co2, Si2, Co3, Si3, out1, out2; + uint32_t n1, n2, ic, i0, i1, i2, i3, j, k; + + /* Total process is divided into three stages */ + + /* process first stage, middle stages, & last stage */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + + /* n2 = fftLen/4 */ + n2 >>= 2U; + + /* Index for twiddle coefficient */ + ic = 0U; + + /* Index for input read and output write */ + i0 = 0U; + + j = n2; + + /* Input is in 1.15(q15) format */ + + /* Start of first stage process */ + do + { + /* Butterfly implementation */ + + /* index calculation for the input as, */ + /* pSrc16[i0 + 0], pSrc16[i0 + fftLen/4], pSrc16[i0 + fftLen/2], pSrc16[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Reading i0, i0+fftLen/2 inputs */ + /* input is down scale by 4 to avoid overflow */ + /* Read ya (real), xa(imag) input */ + T0 = pSrc16[i0 * 2U] >> 2U; + T1 = pSrc16[(i0 * 2U) + 1U] >> 2U; + /* input is down scale by 4 to avoid overflow */ + /* Read yc (real), xc(imag) input */ + S0 = pSrc16[i2 * 2U] >> 2U; + S1 = pSrc16[(i2 * 2U) + 1U] >> 2U; + + /* R0 = (ya + yc), R1 = (xa + xc) */ + R0 = __SSAT(T0 + S0, 16U); + R1 = __SSAT(T1 + S1, 16U); + /* S0 = (ya - yc), S1 = (xa - xc) */ + S0 = __SSAT(T0 - S0, 16U); + S1 = __SSAT(T1 - S1, 16U); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* input is down scale by 4 to avoid overflow */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U] >> 2U; + T1 = pSrc16[(i1 * 2U) + 1U] >> 2U; + /* Read yd (real), xd(imag) input */ + /* input is down scale by 4 to avoid overflow */ + U0 = pSrc16[i3 * 2U] >> 2U; + U1 = pSrc16[(i3 * 2U) + 1U] >> 2U; + + /* T0 = (yb + yd), T1 = (xb + xd) */ + T0 = __SSAT(T0 + U0, 16U); + T1 = __SSAT(T1 + U1, 16U); + + /* writing the butterfly processed i0 sample */ + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + pSrc16[i0 * 2U] = (R0 >> 1U) + (T0 >> 1U); + pSrc16[(i0 * 2U) + 1U] = (R1 >> 1U) + (T1 >> 1U); + + /* R0 = (ya + yc) - (yb + yd), R1 = (xa + xc)- (xb + xd) */ + R0 = __SSAT(R0 - T0, 16U); + R1 = __SSAT(R1 - T1, 16U); + /* co2 & si2 are read from Coefficient pointer */ + Co2 = pCoef16[2U * ic * 2U]; + Si2 = pCoef16[(2U * ic * 2U) + 1U]; + /* xc' = (xa-xb+xc-xd)* co2 - (ya-yb+yc-yd)* (si2) */ + out1 = (q15_t) ((Co2 * R0 - Si2 * R1) >> 16U); + /* yc' = (ya-yb+yc-yd)* co2 + (xa-xb+xc-xd)* (si2) */ + out2 = (q15_t) ((Si2 * R0 + Co2 * R1) >> 16U); + + /* Reading i0+fftLen/4 */ + /* input is down scale by 4 to avoid overflow */ + /* T0 = yb, T1 = xb */ + T0 = pSrc16[i1 * 2U] >> 2U; + T1 = pSrc16[(i1 * 2U) + 1U] >> 2U; + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* writing output(xc', yc') in little endian format */ + pSrc16[i1 * 2U] = out1; + pSrc16[(i1 * 2U) + 1U] = out2; + + /* Butterfly calculations */ + /* input is down scale by 4 to avoid overflow */ + /* U0 = yd, U1 = xd) */ + U0 = pSrc16[i3 * 2U] >> 2U; + U1 = pSrc16[(i3 * 2U) + 1U] >> 2U; + + /* T0 = yb-yd, T1 = xb-xd) */ + T0 = __SSAT(T0 - U0, 16U); + T1 = __SSAT(T1 - U1, 16U); + /* R0 = (ya-yc) - (xb- xd) , R1 = (xa-xc) + (yb-yd) */ + R0 = (q15_t) __SSAT((q31_t) (S0 + T1), 16); + R1 = (q15_t) __SSAT((q31_t) (S1 - T0), 16); + /* S = (ya-yc) + (xb- xd), S1 = (xa-xc) - (yb-yd) */ + S0 = (q15_t) __SSAT((q31_t) (S0 - T1), 16); + S1 = (q15_t) __SSAT((q31_t) (S1 + T0), 16); + + /* co1 & si1 are read from Coefficient pointer */ + Co1 = pCoef16[ic * 2U]; + Si1 = pCoef16[(ic * 2U) + 1U]; + /* Butterfly process for the i0+fftLen/2 sample */ + /* xb' = (xa-yb-xc+yd)* co1 - (ya+xb-yc-xd)* (si1) */ + out1 = (q15_t) ((Co1 * S0 - Si1 * S1) >> 16U); + /* yb' = (ya+xb-yc-xd)* co1 + (xa-yb-xc+yd)* (si1) */ + out2 = (q15_t) ((Si1 * S0 + Co1 * S1) >> 16U); + /* writing output(xb', yb') in little endian format */ + pSrc16[i2 * 2U] = out1; + pSrc16[(i2 * 2U) + 1U] = out2; + + /* Co3 & si3 are read from Coefficient pointer */ + Co3 = pCoef16[3U * ic * 2U]; + Si3 = pCoef16[(3U * ic * 2U) + 1U]; + /* Butterfly process for the i0+3fftLen/4 sample */ + /* xd' = (xa+yb-xc-yd)* Co3 - (ya-xb-yc+xd)* (si3) */ + out1 = (q15_t) ((Co3 * R0 - Si3 * R1) >> 16U); + /* yd' = (ya-xb-yc+xd)* Co3 + (xa+yb-xc-yd)* (si3) */ + out2 = (q15_t) ((Si3 * R0 + Co3 * R1) >> 16U); + /* writing output(xd', yd') in little endian format */ + pSrc16[i3 * 2U] = out1; + pSrc16[(i3 * 2U) + 1U] = out2; + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + /* Updating input index */ + i0 = i0 + 1U; + + } while (--j); + + /* End of first stage process */ + + /* data is in 4.11(q11) format */ + + + /* Start of Middle stage process */ + + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + + /* Calculation of Middle stage */ + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the middle stage */ + n1 = n2; + n2 >>= 2U; + ic = 0U; + + for (j = 0U; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + Co1 = pCoef16[ic * 2U]; + Si1 = pCoef16[(ic * 2U) + 1U]; + Co2 = pCoef16[2U * ic * 2U]; + Si2 = pCoef16[2U * ic * 2U + 1U]; + Co3 = pCoef16[3U * ic * 2U]; + Si3 = pCoef16[(3U * ic * 2U) + 1U]; + + /* Twiddle coefficients index modifier */ + ic = ic + twidCoefModifier; + + /* Butterfly implementation */ + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* index calculation for the input as, */ + /* pSrc16[i0 + 0], pSrc16[i0 + fftLen/4], pSrc16[i0 + fftLen/2], pSrc16[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T0 = pSrc16[i0 * 2U]; + T1 = pSrc16[(i0 * 2U) + 1U]; + + /* Read yc (real), xc(imag) input */ + S0 = pSrc16[i2 * 2U]; + S1 = pSrc16[(i2 * 2U) + 1U]; + + + /* R0 = (ya + yc), R1 = (xa + xc) */ + R0 = __SSAT(T0 + S0, 16U); + R1 = __SSAT(T1 + S1, 16U); + /* S0 = (ya - yc), S1 = (xa - xc) */ + S0 = __SSAT(T0 - S0, 16U); + S1 = __SSAT(T1 - S1, 16U); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + + /* T0 = (yb + yd), T1 = (xb + xd) */ + T0 = __SSAT(T0 + U0, 16U); + T1 = __SSAT(T1 + U1, 16U); + + /* writing the butterfly processed i0 sample */ + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + pSrc16[i0 * 2U] = ((R0 >> 1U) + (T0 >> 1U)) >> 1U; + pSrc16[(i0 * 2U) + 1U] = ((R1 >> 1U) + (T1 >> 1U)) >> 1U; + + /* R0 = (ya + yc) - (yb + yd), R1 = (xa + xc) - (xb + xd) */ + R0 = (R0 >> 1U) - (T0 >> 1U); + R1 = (R1 >> 1U) - (T1 >> 1U); + + /* (ya-yb+yc-yd)* (si2) - (xa-xb+xc-xd)* co2 */ + out1 = (q15_t) ((Co2 * R0 - Si2 * R1) >> 16); + /* (ya-yb+yc-yd)* co2 + (xa-xb+xc-xd)* (si2) */ + out2 = (q15_t) ((Si2 * R0 + Co2 * R1) >> 16); + + /* Reading i0+3fftLen/4 */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* xc' = (xa-xb+xc-xd)* co2 - (ya-yb+yc-yd)* (si2) */ + /* yc' = (ya-yb+yc-yd)* co2 + (xa-xb+xc-xd)* (si2) */ + pSrc16[i1 * 2U] = out1; + pSrc16[(i1 * 2U) + 1U] = out2; + + /* Butterfly calculations */ + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + + /* T0 = yb-yd, T1 = xb-xd) */ + T0 = __SSAT(T0 - U0, 16U); + T1 = __SSAT(T1 - U1, 16U); + + /* R0 = (ya-yc) - (xb- xd) , R1 = (xa-xc) + (yb-yd) */ + R0 = (S0 >> 1U) + (T1 >> 1U); + R1 = (S1 >> 1U) - (T0 >> 1U); + + /* S1 = (ya-yc) + (xb- xd), S1 = (xa-xc) - (yb-yd) */ + S0 = (S0 >> 1U) - (T1 >> 1U); + S1 = (S1 >> 1U) + (T0 >> 1U); + + /* Butterfly process for the i0+fftLen/2 sample */ + out1 = (q15_t) ((Co1 * S0 - Si1 * S1) >> 16U); + out2 = (q15_t) ((Si1 * S0 + Co1 * S1) >> 16U); + /* xb' = (xa-yb-xc+yd)* co1 - (ya+xb-yc-xd)* (si1) */ + /* yb' = (ya+xb-yc-xd)* co1 + (xa-yb-xc+yd)* (si1) */ + pSrc16[i2 * 2U] = out1; + pSrc16[(i2 * 2U) + 1U] = out2; + + /* Butterfly process for the i0+3fftLen/4 sample */ + out1 = (q15_t) ((Co3 * R0 - Si3 * R1) >> 16U); + + out2 = (q15_t) ((Si3 * R0 + Co3 * R1) >> 16U); + /* xd' = (xa+yb-xc-yd)* Co3 - (ya-xb-yc+xd)* (si3) */ + /* yd' = (ya-xb-yc+xd)* Co3 + (xa+yb-xc-yd)* (si3) */ + pSrc16[i3 * 2U] = out1; + pSrc16[(i3 * 2U) + 1U] = out2; + + + } + } + /* Twiddle coefficients index modifier */ + twidCoefModifier <<= 2U; + } + /* End of Middle stages process */ + + + /* data is in 10.6(q6) format for the 1024 point */ + /* data is in 8.8(q8) format for the 256 point */ + /* data is in 6.10(q10) format for the 64 point */ + /* data is in 4.12(q12) format for the 16 point */ + + /* start of last stage process */ + + + /* Initializations for the last stage */ + n1 = n2; + n2 >>= 2U; + + /* Butterfly implementation */ + for (i0 = 0U; i0 <= (fftLen - n1); i0 += n1) + { + /* index calculation for the input as, */ + /* pSrc16[i0 + 0], pSrc16[i0 + fftLen/4], pSrc16[i0 + fftLen/2], pSrc16[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Reading i0, i0+fftLen/2 inputs */ + /* Read ya (real), xa(imag) input */ + T0 = pSrc16[i0 * 2U]; + T1 = pSrc16[(i0 * 2U) + 1U]; + /* Read yc (real), xc(imag) input */ + S0 = pSrc16[i2 * 2U]; + S1 = pSrc16[(i2 * 2U) + 1U]; + + /* R0 = (ya + yc), R1 = (xa + xc) */ + R0 = __SSAT(T0 + S0, 16U); + R1 = __SSAT(T1 + S1, 16U); + /* S0 = (ya - yc), S1 = (xa - xc) */ + S0 = __SSAT(T0 - S0, 16U); + S1 = __SSAT(T1 - S1, 16U); + + /* Reading i0+fftLen/4 , i0+3fftLen/4 inputs */ + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + + /* T0 = (yb + yd), T1 = (xb + xd) */ + T0 = __SSAT(T0 + U0, 16U); + T1 = __SSAT(T1 + U1, 16U); + + /* writing the butterfly processed i0 sample */ + /* xa' = xa + xb + xc + xd */ + /* ya' = ya + yb + yc + yd */ + pSrc16[i0 * 2U] = (R0 >> 1U) + (T0 >> 1U); + pSrc16[(i0 * 2U) + 1U] = (R1 >> 1U) + (T1 >> 1U); + + /* R0 = (ya + yc) - (yb + yd), R1 = (xa + xc) - (xb + xd) */ + R0 = (R0 >> 1U) - (T0 >> 1U); + R1 = (R1 >> 1U) - (T1 >> 1U); + + /* Read yb (real), xb(imag) input */ + T0 = pSrc16[i1 * 2U]; + T1 = pSrc16[(i1 * 2U) + 1U]; + + /* writing the butterfly processed i0 + fftLen/4 sample */ + /* xc' = (xa-xb+xc-xd) */ + /* yc' = (ya-yb+yc-yd) */ + pSrc16[i1 * 2U] = R0; + pSrc16[(i1 * 2U) + 1U] = R1; + + /* Read yd (real), xd(imag) input */ + U0 = pSrc16[i3 * 2U]; + U1 = pSrc16[(i3 * 2U) + 1U]; + /* T0 = (yb - yd), T1 = (xb - xd) */ + T0 = __SSAT(T0 - U0, 16U); + T1 = __SSAT(T1 - U1, 16U); + + /* writing the butterfly processed i0 + fftLen/2 sample */ + /* xb' = (xa-yb-xc+yd) */ + /* yb' = (ya+xb-yc-xd) */ + pSrc16[i2 * 2U] = (S0 >> 1U) - (T1 >> 1U); + pSrc16[(i2 * 2U) + 1U] = (S1 >> 1U) + (T0 >> 1U); + + + /* writing the butterfly processed i0 + 3fftLen/4 sample */ + /* xd' = (xa+yb-xc-yd) */ + /* yd' = (ya-xb-yc+xd) */ + pSrc16[i3 * 2U] = (S0 >> 1U) + (T1 >> 1U); + pSrc16[(i3 * 2U) + 1U] = (S1 >> 1U) - (T0 >> 1U); + } + /* end of last stage process */ + + /* output is in 11.5(q5) format for the 1024 point */ + /* output is in 9.7(q7) format for the 256 point */ + /* output is in 7.9(q9) format for the 64 point */ + /* output is in 5.11(q11) format for the 16 point */ + +#endif /* #if defined (ARM_MATH_DSP) */ + +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q31.c new file mode 100644 index 0000000..35025bb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix4_q31.c @@ -0,0 +1,1389 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix4_q31.c + * Description: This file has function definition of Radix-4 FFT & IFFT function and + * In-place bit reversal using bit reversal table + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +void arm_radix4_butterfly_inverse_q31( +q31_t * pSrc, +uint32_t fftLen, +q31_t * pCoef, +uint32_t twidCoefModifier); + +void arm_radix4_butterfly_q31( +q31_t * pSrc, +uint32_t fftLen, +q31_t * pCoef, +uint32_t twidCoefModifier); + +void arm_bitreversal_q31( +q31_t * pSrc, +uint32_t fftLen, +uint16_t bitRevFactor, +uint16_t * pBitRevTab); + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup ComplexFFT + * @{ + */ + +/** + * @details + * @brief Processing function for the Q31 CFFT/CIFFT. + * @deprecated Do not use this function. It has been superseded by \ref arm_cfft_q31 and will be removed + * @param[in] *S points to an instance of the Q31 CFFT/CIFFT structure. + * @param[in, out] *pSrc points to the complex data buffer of size 2*fftLen. Processing occurs in-place. + * @return none. + * + * \par Input and output formats: + * \par + * Internally input is downscaled by 2 for every stage to avoid saturations inside CFFT/CIFFT process. + * Hence the output format is different for different FFT sizes. + * The input and output formats for different FFT sizes and number of bits to upscale are mentioned in the tables below for CFFT and CIFFT: + * \par + * \image html CFFTQ31.gif "Input and Output Formats for Q31 CFFT" + * \image html CIFFTQ31.gif "Input and Output Formats for Q31 CIFFT" + * + */ + +void arm_cfft_radix4_q31( + const arm_cfft_radix4_instance_q31 * S, + q31_t * pSrc) +{ + if (S->ifftFlag == 1U) + { + /* Complex IFFT radix-4 */ + arm_radix4_butterfly_inverse_q31(pSrc, S->fftLen, S->pTwiddle, S->twidCoefModifier); + } + else + { + /* Complex FFT radix-4 */ + arm_radix4_butterfly_q31(pSrc, S->fftLen, S->pTwiddle, S->twidCoefModifier); + } + + if (S->bitReverseFlag == 1U) + { + /* Bit Reversal */ + arm_bitreversal_q31(pSrc, S->fftLen, S->bitRevFactor, S->pBitRevTable); + } + +} + +/** + * @} end of ComplexFFT group + */ + +/* +* Radix-4 FFT algorithm used is : +* +* Input real and imaginary data: +* x(n) = xa + j * ya +* x(n+N/4 ) = xb + j * yb +* x(n+N/2 ) = xc + j * yc +* x(n+3N 4) = xd + j * yd +* +* +* Output real and imaginary data: +* x(4r) = xa'+ j * ya' +* x(4r+1) = xb'+ j * yb' +* x(4r+2) = xc'+ j * yc' +* x(4r+3) = xd'+ j * yd' +* +* +* Twiddle factors for radix-4 FFT: +* Wn = co1 + j * (- si1) +* W2n = co2 + j * (- si2) +* W3n = co3 + j * (- si3) +* +* Butterfly implementation: +* xa' = xa + xb + xc + xd +* ya' = ya + yb + yc + yd +* xb' = (xa+yb-xc-yd)* co1 + (ya-xb-yc+xd)* (si1) +* yb' = (ya-xb-yc+xd)* co1 - (xa+yb-xc-yd)* (si1) +* xc' = (xa-xb+xc-xd)* co2 + (ya-yb+yc-yd)* (si2) +* yc' = (ya-yb+yc-yd)* co2 - (xa-xb+xc-xd)* (si2) +* xd' = (xa-yb-xc+yd)* co3 + (ya+xb-yc-xd)* (si3) +* yd' = (ya+xb-yc-xd)* co3 - (xa-yb-xc+yd)* (si3) +* +*/ + +/** + * @brief Core function for the Q31 CFFT butterfly process. + * @param[in, out] *pSrc points to the in-place buffer of Q31 data type. + * @param[in] fftLen length of the FFT. + * @param[in] *pCoef points to twiddle coefficient buffer. + * @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. + * @return none. + */ + +void arm_radix4_butterfly_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pCoef, + uint32_t twidCoefModifier) +{ +#if defined(ARM_MATH_CM7) + uint32_t n1, n2, ia1, ia2, ia3, i0, i1, i2, i3, j, k; + q31_t t1, t2, r1, r2, s1, s2, co1, co2, co3, si1, si2, si3; + + q31_t xa, xb, xc, xd; + q31_t ya, yb, yc, yd; + q31_t xa_out, xb_out, xc_out, xd_out; + q31_t ya_out, yb_out, yc_out, yd_out; + + q31_t *ptr1; + q63_t xaya, xbyb, xcyc, xdyd; + /* Total process is divided into three stages */ + + /* process first stage, middle stages, & last stage */ + + + /* start of first stage process */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + /* n2 = fftLen/4 */ + n2 >>= 2U; + i0 = 0U; + ia1 = 0U; + + j = n2; + + /* Calculation of first stage */ + do + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2U], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* input is in 1.31(q31) format and provide 4 guard bits for the input */ + + /* Butterfly implementation */ + /* xa + xc */ + r1 = (pSrc[(2U * i0)] >> 4U) + (pSrc[(2U * i2)] >> 4U); + /* xa - xc */ + r2 = (pSrc[2U * i0] >> 4U) - (pSrc[2U * i2] >> 4U); + + /* xb + xd */ + t1 = (pSrc[2U * i1] >> 4U) + (pSrc[2U * i3] >> 4U); + + /* ya + yc */ + s1 = (pSrc[(2U * i0) + 1U] >> 4U) + (pSrc[(2U * i2) + 1U] >> 4U); + /* ya - yc */ + s2 = (pSrc[(2U * i0) + 1U] >> 4U) - (pSrc[(2U * i2) + 1U] >> 4U); + + /* xa' = xa + xb + xc + xd */ + pSrc[2U * i0] = (r1 + t1); + /* (xa + xc) - (xb + xd) */ + r1 = r1 - t1; + /* yb + yd */ + t2 = (pSrc[(2U * i1) + 1U] >> 4U) + (pSrc[(2U * i3) + 1U] >> 4U); + + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = (s1 + t2); + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* yb - yd */ + t1 = (pSrc[(2U * i1) + 1U] >> 4U) - (pSrc[(2U * i3) + 1U] >> 4U); + /* xb - xd */ + t2 = (pSrc[2U * i1] >> 4U) - (pSrc[2U * i3] >> 4U); + + /* index calculation for the coefficients */ + ia2 = 2U * ia1; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + + /* xc' = (xa-xb+xc-xd)co2 + (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = (((int32_t) (((q63_t) r1 * co2) >> 32)) + + ((int32_t) (((q63_t) s1 * si2) >> 32))) << 1U; + + /* yc' = (ya-yb+yc-yd)co2 - (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = (((int32_t) (((q63_t) s1 * co2) >> 32)) - + ((int32_t) (((q63_t) r1 * si2) >> 32))) << 1U; + + /* (xa - xc) + (yb - yd) */ + r1 = r2 + t1; + /* (xa - xc) - (yb - yd) */ + r2 = r2 - t1; + + /* (ya - yc) - (xb - xd) */ + s1 = s2 - t2; + /* (ya - yc) + (xb - xd) */ + s2 = s2 + t2; + + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + + /* xb' = (xa+yb-xc-yd)co1 + (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = (((int32_t) (((q63_t) r1 * co1) >> 32)) + + ((int32_t) (((q63_t) s1 * si1) >> 32))) << 1U; + + /* yb' = (ya-xb-yc+xd)co1 - (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = (((int32_t) (((q63_t) s1 * co1) >> 32)) - + ((int32_t) (((q63_t) r1 * si1) >> 32))) << 1U; + + /* index calculation for the coefficients */ + ia3 = 3U * ia1; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* xd' = (xa-yb-xc+yd)co3 + (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = (((int32_t) (((q63_t) r2 * co3) >> 32)) + + ((int32_t) (((q63_t) s2 * si3) >> 32))) << 1U; + + /* yd' = (ya+xb-yc-xd)co3 - (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = (((int32_t) (((q63_t) s2 * co3) >> 32)) - + ((int32_t) (((q63_t) r2 * si3) >> 32))) << 1U; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + /* Updating input index */ + i0 = i0 + 1U; + + } while (--j); + + /* end of first stage process */ + + /* data is in 5.27(q27) format */ + + + /* start of Middle stages process */ + + + /* each stage in middle stages provides two down scaling of the input */ + + twidCoefModifier <<= 2U; + + + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the first stage */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + /* Calculation of first stage */ + for (j = 0U; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2U], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Butterfly implementation */ + /* xa + xc */ + r1 = pSrc[2U * i0] + pSrc[2U * i2]; + /* xa - xc */ + r2 = pSrc[2U * i0] - pSrc[2U * i2]; + + /* ya + yc */ + s1 = pSrc[(2U * i0) + 1U] + pSrc[(2U * i2) + 1U]; + /* ya - yc */ + s2 = pSrc[(2U * i0) + 1U] - pSrc[(2U * i2) + 1U]; + + /* xb + xd */ + t1 = pSrc[2U * i1] + pSrc[2U * i3]; + + /* xa' = xa + xb + xc + xd */ + pSrc[2U * i0] = (r1 + t1) >> 2U; + /* xa + xc -(xb + xd) */ + r1 = r1 - t1; + + /* yb + yd */ + t2 = pSrc[(2U * i1) + 1U] + pSrc[(2U * i3) + 1U]; + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = (s1 + t2) >> 2U; + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* (yb - yd) */ + t1 = pSrc[(2U * i1) + 1U] - pSrc[(2U * i3) + 1U]; + /* (xb - xd) */ + t2 = pSrc[2U * i1] - pSrc[2U * i3]; + + /* xc' = (xa-xb+xc-xd)co2 + (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = (((int32_t) (((q63_t) r1 * co2) >> 32)) + + ((int32_t) (((q63_t) s1 * si2) >> 32))) >> 1U; + + /* yc' = (ya-yb+yc-yd)co2 - (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = (((int32_t) (((q63_t) s1 * co2) >> 32)) - + ((int32_t) (((q63_t) r1 * si2) >> 32))) >> 1U; + + /* (xa - xc) + (yb - yd) */ + r1 = r2 + t1; + /* (xa - xc) - (yb - yd) */ + r2 = r2 - t1; + + /* (ya - yc) - (xb - xd) */ + s1 = s2 - t2; + /* (ya - yc) + (xb - xd) */ + s2 = s2 + t2; + + /* xb' = (xa+yb-xc-yd)co1 + (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = (((int32_t) (((q63_t) r1 * co1) >> 32)) + + ((int32_t) (((q63_t) s1 * si1) >> 32))) >> 1U; + + /* yb' = (ya-xb-yc+xd)co1 - (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = (((int32_t) (((q63_t) s1 * co1) >> 32)) - + ((int32_t) (((q63_t) r1 * si1) >> 32))) >> 1U; + + /* xd' = (xa-yb-xc+yd)co3 + (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = (((int32_t) (((q63_t) r2 * co3) >> 32)) + + ((int32_t) (((q63_t) s2 * si3) >> 32))) >> 1U; + + /* yd' = (ya+xb-yc-xd)co3 - (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = (((int32_t) (((q63_t) s2 * co3) >> 32)) - + ((int32_t) (((q63_t) r2 * si3) >> 32))) >> 1U; + } + } + twidCoefModifier <<= 2U; + } +#else + uint32_t n1, n2, ia1, ia2, ia3, i0, j, k; + q31_t t1, t2, r1, r2, s1, s2, co1, co2, co3, si1, si2, si3; + + q31_t xa, xb, xc, xd; + q31_t ya, yb, yc, yd; + q31_t xa_out, xb_out, xc_out, xd_out; + q31_t ya_out, yb_out, yc_out, yd_out; + + q31_t *ptr1; + q31_t *pSi0; + q31_t *pSi1; + q31_t *pSi2; + q31_t *pSi3; + q63_t xaya, xbyb, xcyc, xdyd; + /* Total process is divided into three stages */ + + /* process first stage, middle stages, & last stage */ + + + /* start of first stage process */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + /* n2 = fftLen/4 */ + n2 >>= 2U; + + ia1 = 0U; + + j = n2; + + pSi0 = pSrc; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + /* Calculation of first stage */ + do + { + /* input is in 1.31(q31) format and provide 4 guard bits for the input */ + + /* Butterfly implementation */ + /* xa + xc */ + r1 = (pSi0[0] >> 4U) + (pSi2[0] >> 4U); + /* xa - xc */ + r2 = (pSi0[0] >> 4U) - (pSi2[0] >> 4U); + + /* xb + xd */ + t1 = (pSi1[0] >> 4U) + (pSi3[0] >> 4U); + + /* ya + yc */ + s1 = (pSi0[1] >> 4U) + (pSi2[1] >> 4U); + /* ya - yc */ + s2 = (pSi0[1] >> 4U) - (pSi2[1] >> 4U); + + /* xa' = xa + xb + xc + xd */ + *pSi0++ = (r1 + t1); + /* (xa + xc) - (xb + xd) */ + r1 = r1 - t1; + /* yb + yd */ + t2 = (pSi1[1] >> 4U) + (pSi3[1] >> 4U); + + /* ya' = ya + yb + yc + yd */ + *pSi0++ = (s1 + t2); + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* yb - yd */ + t1 = (pSi1[1] >> 4U) - (pSi3[1] >> 4U); + /* xb - xd */ + t2 = (pSi1[0] >> 4U) - (pSi3[0] >> 4U); + + /* index calculation for the coefficients */ + ia2 = 2U * ia1; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + + /* xc' = (xa-xb+xc-xd)co2 + (ya-yb+yc-yd)(si2) */ + *pSi1++ = (((int32_t) (((q63_t) r1 * co2) >> 32)) + + ((int32_t) (((q63_t) s1 * si2) >> 32))) << 1U; + + /* yc' = (ya-yb+yc-yd)co2 - (xa-xb+xc-xd)(si2) */ + *pSi1++ = (((int32_t) (((q63_t) s1 * co2) >> 32)) - + ((int32_t) (((q63_t) r1 * si2) >> 32))) << 1U; + + /* (xa - xc) + (yb - yd) */ + r1 = r2 + t1; + /* (xa - xc) - (yb - yd) */ + r2 = r2 - t1; + + /* (ya - yc) - (xb - xd) */ + s1 = s2 - t2; + /* (ya - yc) + (xb - xd) */ + s2 = s2 + t2; + + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + + /* xb' = (xa+yb-xc-yd)co1 + (ya-xb-yc+xd)(si1) */ + *pSi2++ = (((int32_t) (((q63_t) r1 * co1) >> 32)) + + ((int32_t) (((q63_t) s1 * si1) >> 32))) << 1U; + + /* yb' = (ya-xb-yc+xd)co1 - (xa+yb-xc-yd)(si1) */ + *pSi2++ = (((int32_t) (((q63_t) s1 * co1) >> 32)) - + ((int32_t) (((q63_t) r1 * si1) >> 32))) << 1U; + + /* index calculation for the coefficients */ + ia3 = 3U * ia1; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* xd' = (xa-yb-xc+yd)co3 + (ya+xb-yc-xd)(si3) */ + *pSi3++ = (((int32_t) (((q63_t) r2 * co3) >> 32)) + + ((int32_t) (((q63_t) s2 * si3) >> 32))) << 1U; + + /* yd' = (ya+xb-yc-xd)co3 - (xa-yb-xc+yd)(si3) */ + *pSi3++ = (((int32_t) (((q63_t) s2 * co3) >> 32)) - + ((int32_t) (((q63_t) r2 * si3) >> 32))) << 1U; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + } while (--j); + + /* end of first stage process */ + + /* data is in 5.27(q27) format */ + + + /* start of Middle stages process */ + + + /* each stage in middle stages provides two down scaling of the input */ + + twidCoefModifier <<= 2U; + + + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the first stage */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + /* Calculation of first stage */ + for (j = 0U; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + pSi0 = pSrc + 2 * j; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* Butterfly implementation */ + /* xa + xc */ + r1 = pSi0[0] + pSi2[0]; + + /* xa - xc */ + r2 = pSi0[0] - pSi2[0]; + + + /* ya + yc */ + s1 = pSi0[1] + pSi2[1]; + + /* ya - yc */ + s2 = pSi0[1] - pSi2[1]; + + + /* xb + xd */ + t1 = pSi1[0] + pSi3[0]; + + + /* xa' = xa + xb + xc + xd */ + pSi0[0] = (r1 + t1) >> 2U; + /* xa + xc -(xb + xd) */ + r1 = r1 - t1; + + /* yb + yd */ + t2 = pSi1[1] + pSi3[1]; + + /* ya' = ya + yb + yc + yd */ + pSi0[1] = (s1 + t2) >> 2U; + pSi0 += 2 * n1; + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* (yb - yd) */ + t1 = pSi1[1] - pSi3[1]; + + /* (xb - xd) */ + t2 = pSi1[0] - pSi3[0]; + + + /* xc' = (xa-xb+xc-xd)co2 + (ya-yb+yc-yd)(si2) */ + pSi1[0] = (((int32_t) (((q63_t) r1 * co2) >> 32)) + + ((int32_t) (((q63_t) s1 * si2) >> 32))) >> 1U; + + /* yc' = (ya-yb+yc-yd)co2 - (xa-xb+xc-xd)(si2) */ + pSi1[1] = (((int32_t) (((q63_t) s1 * co2) >> 32)) - + ((int32_t) (((q63_t) r1 * si2) >> 32))) >> 1U; + pSi1 += 2 * n1; + + /* (xa - xc) + (yb - yd) */ + r1 = r2 + t1; + /* (xa - xc) - (yb - yd) */ + r2 = r2 - t1; + + /* (ya - yc) - (xb - xd) */ + s1 = s2 - t2; + /* (ya - yc) + (xb - xd) */ + s2 = s2 + t2; + + /* xb' = (xa+yb-xc-yd)co1 + (ya-xb-yc+xd)(si1) */ + pSi2[0] = (((int32_t) (((q63_t) r1 * co1) >> 32)) + + ((int32_t) (((q63_t) s1 * si1) >> 32))) >> 1U; + + /* yb' = (ya-xb-yc+xd)co1 - (xa+yb-xc-yd)(si1) */ + pSi2[1] = (((int32_t) (((q63_t) s1 * co1) >> 32)) - + ((int32_t) (((q63_t) r1 * si1) >> 32))) >> 1U; + pSi2 += 2 * n1; + + /* xd' = (xa-yb-xc+yd)co3 + (ya+xb-yc-xd)(si3) */ + pSi3[0] = (((int32_t) (((q63_t) r2 * co3) >> 32)) + + ((int32_t) (((q63_t) s2 * si3) >> 32))) >> 1U; + + /* yd' = (ya+xb-yc-xd)co3 - (xa-yb-xc+yd)(si3) */ + pSi3[1] = (((int32_t) (((q63_t) s2 * co3) >> 32)) - + ((int32_t) (((q63_t) r2 * si3) >> 32))) >> 1U; + pSi3 += 2 * n1; + } + } + twidCoefModifier <<= 2U; + } +#endif + + /* End of Middle stages process */ + + /* data is in 11.21(q21) format for the 1024 point as there are 3 middle stages */ + /* data is in 9.23(q23) format for the 256 point as there are 2 middle stages */ + /* data is in 7.25(q25) format for the 64 point as there are 1 middle stage */ + /* data is in 5.27(q27) format for the 16 point as there are no middle stages */ + + + /* start of Last stage process */ + /* Initializations for the last stage */ + j = fftLen >> 2; + ptr1 = &pSrc[0]; + + /* Calculations of last stage */ + do + { + +#ifndef ARM_MATH_BIG_ENDIAN + + /* Read xa (real), ya(imag) input */ + xaya = *__SIMD64(ptr1)++; + xa = (q31_t) xaya; + ya = (q31_t) (xaya >> 32); + + /* Read xb (real), yb(imag) input */ + xbyb = *__SIMD64(ptr1)++; + xb = (q31_t) xbyb; + yb = (q31_t) (xbyb >> 32); + + /* Read xc (real), yc(imag) input */ + xcyc = *__SIMD64(ptr1)++; + xc = (q31_t) xcyc; + yc = (q31_t) (xcyc >> 32); + + /* Read xc (real), yc(imag) input */ + xdyd = *__SIMD64(ptr1)++; + xd = (q31_t) xdyd; + yd = (q31_t) (xdyd >> 32); + +#else + + /* Read xa (real), ya(imag) input */ + xaya = *__SIMD64(ptr1)++; + ya = (q31_t) xaya; + xa = (q31_t) (xaya >> 32); + + /* Read xb (real), yb(imag) input */ + xbyb = *__SIMD64(ptr1)++; + yb = (q31_t) xbyb; + xb = (q31_t) (xbyb >> 32); + + /* Read xc (real), yc(imag) input */ + xcyc = *__SIMD64(ptr1)++; + yc = (q31_t) xcyc; + xc = (q31_t) (xcyc >> 32); + + /* Read xc (real), yc(imag) input */ + xdyd = *__SIMD64(ptr1)++; + yd = (q31_t) xdyd; + xd = (q31_t) (xdyd >> 32); + + +#endif + + /* xa' = xa + xb + xc + xd */ + xa_out = xa + xb + xc + xd; + + /* ya' = ya + yb + yc + yd */ + ya_out = ya + yb + yc + yd; + + /* pointer updation for writing */ + ptr1 = ptr1 - 8U; + + /* writing xa' and ya' */ + *ptr1++ = xa_out; + *ptr1++ = ya_out; + + xc_out = (xa - xb + xc - xd); + yc_out = (ya - yb + yc - yd); + + /* writing xc' and yc' */ + *ptr1++ = xc_out; + *ptr1++ = yc_out; + + xb_out = (xa + yb - xc - yd); + yb_out = (ya - xb - yc + xd); + + /* writing xb' and yb' */ + *ptr1++ = xb_out; + *ptr1++ = yb_out; + + xd_out = (xa - yb - xc + yd); + yd_out = (ya + xb - yc - xd); + + /* writing xd' and yd' */ + *ptr1++ = xd_out; + *ptr1++ = yd_out; + + + } while (--j); + + /* output is in 11.21(q21) format for the 1024 point */ + /* output is in 9.23(q23) format for the 256 point */ + /* output is in 7.25(q25) format for the 64 point */ + /* output is in 5.27(q27) format for the 16 point */ + + /* End of last stage process */ + +} + + +/** + * @brief Core function for the Q31 CIFFT butterfly process. + * @param[in, out] *pSrc points to the in-place buffer of Q31 data type. + * @param[in] fftLen length of the FFT. + * @param[in] *pCoef points to twiddle coefficient buffer. + * @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. + * @return none. + */ + + +/* +* Radix-4 IFFT algorithm used is : +* +* CIFFT uses same twiddle coefficients as CFFT Function +* x[k] = x[n] + (j)k * x[n + fftLen/4] + (-1)k * x[n+fftLen/2] + (-j)k * x[n+3*fftLen/4] +* +* +* IFFT is implemented with following changes in equations from FFT +* +* Input real and imaginary data: +* x(n) = xa + j * ya +* x(n+N/4 ) = xb + j * yb +* x(n+N/2 ) = xc + j * yc +* x(n+3N 4) = xd + j * yd +* +* +* Output real and imaginary data: +* x(4r) = xa'+ j * ya' +* x(4r+1) = xb'+ j * yb' +* x(4r+2) = xc'+ j * yc' +* x(4r+3) = xd'+ j * yd' +* +* +* Twiddle factors for radix-4 IFFT: +* Wn = co1 + j * (si1) +* W2n = co2 + j * (si2) +* W3n = co3 + j * (si3) + +* The real and imaginary output values for the radix-4 butterfly are +* xa' = xa + xb + xc + xd +* ya' = ya + yb + yc + yd +* xb' = (xa-yb-xc+yd)* co1 - (ya+xb-yc-xd)* (si1) +* yb' = (ya+xb-yc-xd)* co1 + (xa-yb-xc+yd)* (si1) +* xc' = (xa-xb+xc-xd)* co2 - (ya-yb+yc-yd)* (si2) +* yc' = (ya-yb+yc-yd)* co2 + (xa-xb+xc-xd)* (si2) +* xd' = (xa+yb-xc-yd)* co3 - (ya-xb-yc+xd)* (si3) +* yd' = (ya-xb-yc+xd)* co3 + (xa+yb-xc-yd)* (si3) +* +*/ + +void arm_radix4_butterfly_inverse_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pCoef, + uint32_t twidCoefModifier) +{ +#if defined(ARM_MATH_CM7) + uint32_t n1, n2, ia1, ia2, ia3, i0, i1, i2, i3, j, k; + q31_t t1, t2, r1, r2, s1, s2, co1, co2, co3, si1, si2, si3; + q31_t xa, xb, xc, xd; + q31_t ya, yb, yc, yd; + q31_t xa_out, xb_out, xc_out, xd_out; + q31_t ya_out, yb_out, yc_out, yd_out; + + q31_t *ptr1; + q63_t xaya, xbyb, xcyc, xdyd; + + /* input is be 1.31(q31) format for all FFT sizes */ + /* Total process is divided into three stages */ + /* process first stage, middle stages, & last stage */ + + /* Start of first stage process */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + /* n2 = fftLen/4 */ + n2 >>= 2U; + i0 = 0U; + ia1 = 0U; + + j = n2; + + do + { + + /* input is in 1.31(q31) format and provide 4 guard bits for the input */ + + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2U], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Butterfly implementation */ + /* xa + xc */ + r1 = (pSrc[2U * i0] >> 4U) + (pSrc[2U * i2] >> 4U); + /* xa - xc */ + r2 = (pSrc[2U * i0] >> 4U) - (pSrc[2U * i2] >> 4U); + + /* xb + xd */ + t1 = (pSrc[2U * i1] >> 4U) + (pSrc[2U * i3] >> 4U); + + /* ya + yc */ + s1 = (pSrc[(2U * i0) + 1U] >> 4U) + (pSrc[(2U * i2) + 1U] >> 4U); + /* ya - yc */ + s2 = (pSrc[(2U * i0) + 1U] >> 4U) - (pSrc[(2U * i2) + 1U] >> 4U); + + /* xa' = xa + xb + xc + xd */ + pSrc[2U * i0] = (r1 + t1); + /* (xa + xc) - (xb + xd) */ + r1 = r1 - t1; + /* yb + yd */ + t2 = (pSrc[(2U * i1) + 1U] >> 4U) + (pSrc[(2U * i3) + 1U] >> 4U); + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = (s1 + t2); + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* yb - yd */ + t1 = (pSrc[(2U * i1) + 1U] >> 4U) - (pSrc[(2U * i3) + 1U] >> 4U); + /* xb - xd */ + t2 = (pSrc[2U * i1] >> 4U) - (pSrc[2U * i3] >> 4U); + + /* index calculation for the coefficients */ + ia2 = 2U * ia1; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = (((int32_t) (((q63_t) r1 * co2) >> 32)) - + ((int32_t) (((q63_t) s1 * si2) >> 32))) << 1U; + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + pSrc[2U * i1 + 1U] = (((int32_t) (((q63_t) s1 * co2) >> 32)) + + ((int32_t) (((q63_t) r1 * si2) >> 32))) << 1U; + + /* (xa - xc) - (yb - yd) */ + r1 = r2 - t1; + /* (xa - xc) + (yb - yd) */ + r2 = r2 + t1; + + /* (ya - yc) + (xb - xd) */ + s1 = s2 + t2; + /* (ya - yc) - (xb - xd) */ + s2 = s2 - t2; + + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = (((int32_t) (((q63_t) r1 * co1) >> 32)) - + ((int32_t) (((q63_t) s1 * si1) >> 32))) << 1U; + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = (((int32_t) (((q63_t) s1 * co1) >> 32)) + + ((int32_t) (((q63_t) r1 * si1) >> 32))) << 1U; + + /* index calculation for the coefficients */ + ia3 = 3U * ia1; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + pSrc[2U * i3] = (((int32_t) (((q63_t) r2 * co3) >> 32)) - + ((int32_t) (((q63_t) s2 * si3) >> 32))) << 1U; + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = (((int32_t) (((q63_t) s2 * co3) >> 32)) + + ((int32_t) (((q63_t) r2 * si3) >> 32))) << 1U; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + /* Updating input index */ + i0 = i0 + 1U; + + } while (--j); + + /* data is in 5.27(q27) format */ + /* each stage provides two down scaling of the input */ + + + /* Start of Middle stages process */ + + twidCoefModifier <<= 2U; + + /* Calculation of second stage to excluding last stage */ + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the first stage */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + for (j = 0; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* index calculation for the input as, */ + /* pSrc[i0 + 0], pSrc[i0 + fftLen/4], pSrc[i0 + fftLen/2U], pSrc[i0 + 3fftLen/4] */ + i1 = i0 + n2; + i2 = i1 + n2; + i3 = i2 + n2; + + /* Butterfly implementation */ + /* xa + xc */ + r1 = pSrc[2U * i0] + pSrc[2U * i2]; + /* xa - xc */ + r2 = pSrc[2U * i0] - pSrc[2U * i2]; + + /* ya + yc */ + s1 = pSrc[(2U * i0) + 1U] + pSrc[(2U * i2) + 1U]; + /* ya - yc */ + s2 = pSrc[(2U * i0) + 1U] - pSrc[(2U * i2) + 1U]; + + /* xb + xd */ + t1 = pSrc[2U * i1] + pSrc[2U * i3]; + + /* xa' = xa + xb + xc + xd */ + pSrc[2U * i0] = (r1 + t1) >> 2U; + /* xa + xc -(xb + xd) */ + r1 = r1 - t1; + /* yb + yd */ + t2 = pSrc[(2U * i1) + 1U] + pSrc[(2U * i3) + 1U]; + /* ya' = ya + yb + yc + yd */ + pSrc[(2U * i0) + 1U] = (s1 + t2) >> 2U; + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* (yb - yd) */ + t1 = pSrc[(2U * i1) + 1U] - pSrc[(2U * i3) + 1U]; + /* (xb - xd) */ + t2 = pSrc[2U * i1] - pSrc[2U * i3]; + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + pSrc[2U * i1] = (((int32_t) (((q63_t) r1 * co2) >> 32U)) - + ((int32_t) (((q63_t) s1 * si2) >> 32U))) >> 1U; + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + pSrc[(2U * i1) + 1U] = + (((int32_t) (((q63_t) s1 * co2) >> 32U)) + + ((int32_t) (((q63_t) r1 * si2) >> 32U))) >> 1U; + + /* (xa - xc) - (yb - yd) */ + r1 = r2 - t1; + /* (xa - xc) + (yb - yd) */ + r2 = r2 + t1; + + /* (ya - yc) + (xb - xd) */ + s1 = s2 + t2; + /* (ya - yc) - (xb - xd) */ + s2 = s2 - t2; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + pSrc[2U * i2] = (((int32_t) (((q63_t) r1 * co1) >> 32)) - + ((int32_t) (((q63_t) s1 * si1) >> 32))) >> 1U; + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + pSrc[(2U * i2) + 1U] = (((int32_t) (((q63_t) s1 * co1) >> 32)) + + ((int32_t) (((q63_t) r1 * si1) >> 32))) >> 1U; + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + pSrc[(2U * i3)] = (((int32_t) (((q63_t) r2 * co3) >> 32)) - + ((int32_t) (((q63_t) s2 * si3) >> 32))) >> 1U; + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + pSrc[(2U * i3) + 1U] = (((int32_t) (((q63_t) s2 * co3) >> 32)) + + ((int32_t) (((q63_t) r2 * si3) >> 32))) >> 1U; + } + } + twidCoefModifier <<= 2U; + } +#else + uint32_t n1, n2, ia1, ia2, ia3, i0, j, k; + q31_t t1, t2, r1, r2, s1, s2, co1, co2, co3, si1, si2, si3; + q31_t xa, xb, xc, xd; + q31_t ya, yb, yc, yd; + q31_t xa_out, xb_out, xc_out, xd_out; + q31_t ya_out, yb_out, yc_out, yd_out; + + q31_t *ptr1; + q31_t *pSi0; + q31_t *pSi1; + q31_t *pSi2; + q31_t *pSi3; + q63_t xaya, xbyb, xcyc, xdyd; + + /* input is be 1.31(q31) format for all FFT sizes */ + /* Total process is divided into three stages */ + /* process first stage, middle stages, & last stage */ + + /* Start of first stage process */ + + /* Initializations for the first stage */ + n2 = fftLen; + n1 = n2; + /* n2 = fftLen/4 */ + n2 >>= 2U; + + ia1 = 0U; + + j = n2; + + pSi0 = pSrc; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + do + { + /* Butterfly implementation */ + /* xa + xc */ + r1 = (pSi0[0] >> 4U) + (pSi2[0] >> 4U); + /* xa - xc */ + r2 = (pSi0[0] >> 4U) - (pSi2[0] >> 4U); + + /* xb + xd */ + t1 = (pSi1[0] >> 4U) + (pSi3[0] >> 4U); + + /* ya + yc */ + s1 = (pSi0[1] >> 4U) + (pSi2[1] >> 4U); + /* ya - yc */ + s2 = (pSi0[1] >> 4U) - (pSi2[1] >> 4U); + + /* xa' = xa + xb + xc + xd */ + *pSi0++ = (r1 + t1); + /* (xa + xc) - (xb + xd) */ + r1 = r1 - t1; + /* yb + yd */ + t2 = (pSi1[1] >> 4U) + (pSi3[1] >> 4U); + /* ya' = ya + yb + yc + yd */ + *pSi0++ = (s1 + t2); + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* yb - yd */ + t1 = (pSi1[1] >> 4U) - (pSi3[1] >> 4U); + /* xb - xd */ + t2 = (pSi1[0] >> 4U) - (pSi3[0] >> 4U); + + /* index calculation for the coefficients */ + ia2 = 2U * ia1; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + *pSi1++ = (((int32_t) (((q63_t) r1 * co2) >> 32)) - + ((int32_t) (((q63_t) s1 * si2) >> 32))) << 1U; + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + *pSi1++ = (((int32_t) (((q63_t) s1 * co2) >> 32)) + + ((int32_t) (((q63_t) r1 * si2) >> 32))) << 1U; + + /* (xa - xc) - (yb - yd) */ + r1 = r2 - t1; + /* (xa - xc) + (yb - yd) */ + r2 = r2 + t1; + + /* (ya - yc) + (xb - xd) */ + s1 = s2 + t2; + /* (ya - yc) - (xb - xd) */ + s2 = s2 - t2; + + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + *pSi2++ = (((int32_t) (((q63_t) r1 * co1) >> 32)) - + ((int32_t) (((q63_t) s1 * si1) >> 32))) << 1U; + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + *pSi2++ = (((int32_t) (((q63_t) s1 * co1) >> 32)) + + ((int32_t) (((q63_t) r1 * si1) >> 32))) << 1U; + + /* index calculation for the coefficients */ + ia3 = 3U * ia1; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + *pSi3++ = (((int32_t) (((q63_t) r2 * co3) >> 32)) - + ((int32_t) (((q63_t) s2 * si3) >> 32))) << 1U; + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + *pSi3++ = (((int32_t) (((q63_t) s2 * co3) >> 32)) + + ((int32_t) (((q63_t) r2 * si3) >> 32))) << 1U; + + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + } while (--j); + + /* data is in 5.27(q27) format */ + /* each stage provides two down scaling of the input */ + + + /* Start of Middle stages process */ + + twidCoefModifier <<= 2U; + + /* Calculation of second stage to excluding last stage */ + for (k = fftLen / 4U; k > 4U; k >>= 2U) + { + /* Initializations for the first stage */ + n1 = n2; + n2 >>= 2U; + ia1 = 0U; + + for (j = 0; j <= (n2 - 1U); j++) + { + /* index calculation for the coefficients */ + ia2 = ia1 + ia1; + ia3 = ia2 + ia1; + co1 = pCoef[ia1 * 2U]; + si1 = pCoef[(ia1 * 2U) + 1U]; + co2 = pCoef[ia2 * 2U]; + si2 = pCoef[(ia2 * 2U) + 1U]; + co3 = pCoef[ia3 * 2U]; + si3 = pCoef[(ia3 * 2U) + 1U]; + /* Twiddle coefficients index modifier */ + ia1 = ia1 + twidCoefModifier; + + pSi0 = pSrc + 2 * j; + pSi1 = pSi0 + 2 * n2; + pSi2 = pSi1 + 2 * n2; + pSi3 = pSi2 + 2 * n2; + + for (i0 = j; i0 < fftLen; i0 += n1) + { + /* Butterfly implementation */ + /* xa + xc */ + r1 = pSi0[0] + pSi2[0]; + + /* xa - xc */ + r2 = pSi0[0] - pSi2[0]; + + + /* ya + yc */ + s1 = pSi0[1] + pSi2[1]; + + /* ya - yc */ + s2 = pSi0[1] - pSi2[1]; + + + /* xb + xd */ + t1 = pSi1[0] + pSi3[0]; + + + /* xa' = xa + xb + xc + xd */ + pSi0[0] = (r1 + t1) >> 2U; + /* xa + xc -(xb + xd) */ + r1 = r1 - t1; + /* yb + yd */ + t2 = pSi1[1] + pSi3[1]; + + /* ya' = ya + yb + yc + yd */ + pSi0[1] = (s1 + t2) >> 2U; + pSi0 += 2 * n1; + + /* (ya + yc) - (yb + yd) */ + s1 = s1 - t2; + + /* (yb - yd) */ + t1 = pSi1[1] - pSi3[1]; + + /* (xb - xd) */ + t2 = pSi1[0] - pSi3[0]; + + + /* xc' = (xa-xb+xc-xd)co2 - (ya-yb+yc-yd)(si2) */ + pSi1[0] = (((int32_t) (((q63_t) r1 * co2) >> 32U)) - + ((int32_t) (((q63_t) s1 * si2) >> 32U))) >> 1U; + + /* yc' = (ya-yb+yc-yd)co2 + (xa-xb+xc-xd)(si2) */ + pSi1[1] = + + (((int32_t) (((q63_t) s1 * co2) >> 32U)) + + ((int32_t) (((q63_t) r1 * si2) >> 32U))) >> 1U; + pSi1 += 2 * n1; + + /* (xa - xc) - (yb - yd) */ + r1 = r2 - t1; + /* (xa - xc) + (yb - yd) */ + r2 = r2 + t1; + + /* (ya - yc) + (xb - xd) */ + s1 = s2 + t2; + /* (ya - yc) - (xb - xd) */ + s2 = s2 - t2; + + /* xb' = (xa+yb-xc-yd)co1 - (ya-xb-yc+xd)(si1) */ + pSi2[0] = (((int32_t) (((q63_t) r1 * co1) >> 32)) - + ((int32_t) (((q63_t) s1 * si1) >> 32))) >> 1U; + + /* yb' = (ya-xb-yc+xd)co1 + (xa+yb-xc-yd)(si1) */ + pSi2[1] = (((int32_t) (((q63_t) s1 * co1) >> 32)) + + ((int32_t) (((q63_t) r1 * si1) >> 32))) >> 1U; + pSi2 += 2 * n1; + + /* xd' = (xa-yb-xc+yd)co3 - (ya+xb-yc-xd)(si3) */ + pSi3[0] = (((int32_t) (((q63_t) r2 * co3) >> 32)) - + ((int32_t) (((q63_t) s2 * si3) >> 32))) >> 1U; + + /* yd' = (ya+xb-yc-xd)co3 + (xa-yb-xc+yd)(si3) */ + pSi3[1] = (((int32_t) (((q63_t) s2 * co3) >> 32)) + + ((int32_t) (((q63_t) r2 * si3) >> 32))) >> 1U; + pSi3 += 2 * n1; + } + } + twidCoefModifier <<= 2U; + } +#endif + + /* End of Middle stages process */ + + /* data is in 11.21(q21) format for the 1024 point as there are 3 middle stages */ + /* data is in 9.23(q23) format for the 256 point as there are 2 middle stages */ + /* data is in 7.25(q25) format for the 64 point as there are 1 middle stage */ + /* data is in 5.27(q27) format for the 16 point as there are no middle stages */ + + + /* Start of last stage process */ + + + /* Initializations for the last stage */ + j = fftLen >> 2; + ptr1 = &pSrc[0]; + + /* Calculations of last stage */ + do + { +#ifndef ARM_MATH_BIG_ENDIAN + /* Read xa (real), ya(imag) input */ + xaya = *__SIMD64(ptr1)++; + xa = (q31_t) xaya; + ya = (q31_t) (xaya >> 32); + + /* Read xb (real), yb(imag) input */ + xbyb = *__SIMD64(ptr1)++; + xb = (q31_t) xbyb; + yb = (q31_t) (xbyb >> 32); + + /* Read xc (real), yc(imag) input */ + xcyc = *__SIMD64(ptr1)++; + xc = (q31_t) xcyc; + yc = (q31_t) (xcyc >> 32); + + /* Read xc (real), yc(imag) input */ + xdyd = *__SIMD64(ptr1)++; + xd = (q31_t) xdyd; + yd = (q31_t) (xdyd >> 32); + +#else + + /* Read xa (real), ya(imag) input */ + xaya = *__SIMD64(ptr1)++; + ya = (q31_t) xaya; + xa = (q31_t) (xaya >> 32); + + /* Read xb (real), yb(imag) input */ + xbyb = *__SIMD64(ptr1)++; + yb = (q31_t) xbyb; + xb = (q31_t) (xbyb >> 32); + + /* Read xc (real), yc(imag) input */ + xcyc = *__SIMD64(ptr1)++; + yc = (q31_t) xcyc; + xc = (q31_t) (xcyc >> 32); + + /* Read xc (real), yc(imag) input */ + xdyd = *__SIMD64(ptr1)++; + yd = (q31_t) xdyd; + xd = (q31_t) (xdyd >> 32); + + +#endif + + /* xa' = xa + xb + xc + xd */ + xa_out = xa + xb + xc + xd; + + /* ya' = ya + yb + yc + yd */ + ya_out = ya + yb + yc + yd; + + /* pointer updation for writing */ + ptr1 = ptr1 - 8U; + + /* writing xa' and ya' */ + *ptr1++ = xa_out; + *ptr1++ = ya_out; + + xc_out = (xa - xb + xc - xd); + yc_out = (ya - yb + yc - yd); + + /* writing xc' and yc' */ + *ptr1++ = xc_out; + *ptr1++ = yc_out; + + xb_out = (xa - yb - xc + yd); + yb_out = (ya + xb - yc - xd); + + /* writing xb' and yb' */ + *ptr1++ = xb_out; + *ptr1++ = yb_out; + + xd_out = (xa + yb - xc - yd); + yd_out = (ya - xb - yc + xd); + + /* writing xd' and yd' */ + *ptr1++ = xd_out; + *ptr1++ = yd_out; + + } while (--j); + + /* output is in 11.21(q21) format for the 1024 point */ + /* output is in 9.23(q23) format for the 256 point */ + /* output is in 7.25(q25) format for the 64 point */ + /* output is in 5.27(q27) format for the 16 point */ + + /* End of last stage process */ +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix8_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix8_f32.c new file mode 100644 index 0000000..69ed5a6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_cfft_radix8_f32.c @@ -0,0 +1,285 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_radix8_f32.c + * Description: Radix-8 Decimation in Frequency CFFT & CIFFT Floating point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + + +/* ---------------------------------------------------------------------- + * Internal helper function used by the FFTs + * -------------------------------------------------------------------- */ + +/* +* @brief Core function for the floating-point CFFT butterfly process. +* @param[in, out] *pSrc points to the in-place buffer of floating-point data type. +* @param[in] fftLen length of the FFT. +* @param[in] *pCoef points to the twiddle coefficient buffer. +* @param[in] twidCoefModifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @return none. +*/ + +void arm_radix8_butterfly_f32( +float32_t * pSrc, +uint16_t fftLen, +const float32_t * pCoef, +uint16_t twidCoefModifier) +{ + uint32_t ia1, ia2, ia3, ia4, ia5, ia6, ia7; + uint32_t i1, i2, i3, i4, i5, i6, i7, i8; + uint32_t id; + uint32_t n1, n2, j; + + float32_t r1, r2, r3, r4, r5, r6, r7, r8; + float32_t t1, t2; + float32_t s1, s2, s3, s4, s5, s6, s7, s8; + float32_t p1, p2, p3, p4; + float32_t co2, co3, co4, co5, co6, co7, co8; + float32_t si2, si3, si4, si5, si6, si7, si8; + const float32_t C81 = 0.70710678118f; + + n2 = fftLen; + + do + { + n1 = n2; + n2 = n2 >> 3; + i1 = 0; + + do + { + i2 = i1 + n2; + i3 = i2 + n2; + i4 = i3 + n2; + i5 = i4 + n2; + i6 = i5 + n2; + i7 = i6 + n2; + i8 = i7 + n2; + r1 = pSrc[2 * i1] + pSrc[2 * i5]; + r5 = pSrc[2 * i1] - pSrc[2 * i5]; + r2 = pSrc[2 * i2] + pSrc[2 * i6]; + r6 = pSrc[2 * i2] - pSrc[2 * i6]; + r3 = pSrc[2 * i3] + pSrc[2 * i7]; + r7 = pSrc[2 * i3] - pSrc[2 * i7]; + r4 = pSrc[2 * i4] + pSrc[2 * i8]; + r8 = pSrc[2 * i4] - pSrc[2 * i8]; + t1 = r1 - r3; + r1 = r1 + r3; + r3 = r2 - r4; + r2 = r2 + r4; + pSrc[2 * i1] = r1 + r2; + pSrc[2 * i5] = r1 - r2; + r1 = pSrc[2 * i1 + 1] + pSrc[2 * i5 + 1]; + s5 = pSrc[2 * i1 + 1] - pSrc[2 * i5 + 1]; + r2 = pSrc[2 * i2 + 1] + pSrc[2 * i6 + 1]; + s6 = pSrc[2 * i2 + 1] - pSrc[2 * i6 + 1]; + s3 = pSrc[2 * i3 + 1] + pSrc[2 * i7 + 1]; + s7 = pSrc[2 * i3 + 1] - pSrc[2 * i7 + 1]; + r4 = pSrc[2 * i4 + 1] + pSrc[2 * i8 + 1]; + s8 = pSrc[2 * i4 + 1] - pSrc[2 * i8 + 1]; + t2 = r1 - s3; + r1 = r1 + s3; + s3 = r2 - r4; + r2 = r2 + r4; + pSrc[2 * i1 + 1] = r1 + r2; + pSrc[2 * i5 + 1] = r1 - r2; + pSrc[2 * i3] = t1 + s3; + pSrc[2 * i7] = t1 - s3; + pSrc[2 * i3 + 1] = t2 - r3; + pSrc[2 * i7 + 1] = t2 + r3; + r1 = (r6 - r8) * C81; + r6 = (r6 + r8) * C81; + r2 = (s6 - s8) * C81; + s6 = (s6 + s8) * C81; + t1 = r5 - r1; + r5 = r5 + r1; + r8 = r7 - r6; + r7 = r7 + r6; + t2 = s5 - r2; + s5 = s5 + r2; + s8 = s7 - s6; + s7 = s7 + s6; + pSrc[2 * i2] = r5 + s7; + pSrc[2 * i8] = r5 - s7; + pSrc[2 * i6] = t1 + s8; + pSrc[2 * i4] = t1 - s8; + pSrc[2 * i2 + 1] = s5 - r7; + pSrc[2 * i8 + 1] = s5 + r7; + pSrc[2 * i6 + 1] = t2 - r8; + pSrc[2 * i4 + 1] = t2 + r8; + + i1 += n1; + } while (i1 < fftLen); + + if (n2 < 8) + break; + + ia1 = 0; + j = 1; + + do + { + /* index calculation for the coefficients */ + id = ia1 + twidCoefModifier; + ia1 = id; + ia2 = ia1 + id; + ia3 = ia2 + id; + ia4 = ia3 + id; + ia5 = ia4 + id; + ia6 = ia5 + id; + ia7 = ia6 + id; + + co2 = pCoef[2 * ia1]; + co3 = pCoef[2 * ia2]; + co4 = pCoef[2 * ia3]; + co5 = pCoef[2 * ia4]; + co6 = pCoef[2 * ia5]; + co7 = pCoef[2 * ia6]; + co8 = pCoef[2 * ia7]; + si2 = pCoef[2 * ia1 + 1]; + si3 = pCoef[2 * ia2 + 1]; + si4 = pCoef[2 * ia3 + 1]; + si5 = pCoef[2 * ia4 + 1]; + si6 = pCoef[2 * ia5 + 1]; + si7 = pCoef[2 * ia6 + 1]; + si8 = pCoef[2 * ia7 + 1]; + + i1 = j; + + do + { + /* index calculation for the input */ + i2 = i1 + n2; + i3 = i2 + n2; + i4 = i3 + n2; + i5 = i4 + n2; + i6 = i5 + n2; + i7 = i6 + n2; + i8 = i7 + n2; + r1 = pSrc[2 * i1] + pSrc[2 * i5]; + r5 = pSrc[2 * i1] - pSrc[2 * i5]; + r2 = pSrc[2 * i2] + pSrc[2 * i6]; + r6 = pSrc[2 * i2] - pSrc[2 * i6]; + r3 = pSrc[2 * i3] + pSrc[2 * i7]; + r7 = pSrc[2 * i3] - pSrc[2 * i7]; + r4 = pSrc[2 * i4] + pSrc[2 * i8]; + r8 = pSrc[2 * i4] - pSrc[2 * i8]; + t1 = r1 - r3; + r1 = r1 + r3; + r3 = r2 - r4; + r2 = r2 + r4; + pSrc[2 * i1] = r1 + r2; + r2 = r1 - r2; + s1 = pSrc[2 * i1 + 1] + pSrc[2 * i5 + 1]; + s5 = pSrc[2 * i1 + 1] - pSrc[2 * i5 + 1]; + s2 = pSrc[2 * i2 + 1] + pSrc[2 * i6 + 1]; + s6 = pSrc[2 * i2 + 1] - pSrc[2 * i6 + 1]; + s3 = pSrc[2 * i3 + 1] + pSrc[2 * i7 + 1]; + s7 = pSrc[2 * i3 + 1] - pSrc[2 * i7 + 1]; + s4 = pSrc[2 * i4 + 1] + pSrc[2 * i8 + 1]; + s8 = pSrc[2 * i4 + 1] - pSrc[2 * i8 + 1]; + t2 = s1 - s3; + s1 = s1 + s3; + s3 = s2 - s4; + s2 = s2 + s4; + r1 = t1 + s3; + t1 = t1 - s3; + pSrc[2 * i1 + 1] = s1 + s2; + s2 = s1 - s2; + s1 = t2 - r3; + t2 = t2 + r3; + p1 = co5 * r2; + p2 = si5 * s2; + p3 = co5 * s2; + p4 = si5 * r2; + pSrc[2 * i5] = p1 + p2; + pSrc[2 * i5 + 1] = p3 - p4; + p1 = co3 * r1; + p2 = si3 * s1; + p3 = co3 * s1; + p4 = si3 * r1; + pSrc[2 * i3] = p1 + p2; + pSrc[2 * i3 + 1] = p3 - p4; + p1 = co7 * t1; + p2 = si7 * t2; + p3 = co7 * t2; + p4 = si7 * t1; + pSrc[2 * i7] = p1 + p2; + pSrc[2 * i7 + 1] = p3 - p4; + r1 = (r6 - r8) * C81; + r6 = (r6 + r8) * C81; + s1 = (s6 - s8) * C81; + s6 = (s6 + s8) * C81; + t1 = r5 - r1; + r5 = r5 + r1; + r8 = r7 - r6; + r7 = r7 + r6; + t2 = s5 - s1; + s5 = s5 + s1; + s8 = s7 - s6; + s7 = s7 + s6; + r1 = r5 + s7; + r5 = r5 - s7; + r6 = t1 + s8; + t1 = t1 - s8; + s1 = s5 - r7; + s5 = s5 + r7; + s6 = t2 - r8; + t2 = t2 + r8; + p1 = co2 * r1; + p2 = si2 * s1; + p3 = co2 * s1; + p4 = si2 * r1; + pSrc[2 * i2] = p1 + p2; + pSrc[2 * i2 + 1] = p3 - p4; + p1 = co8 * r5; + p2 = si8 * s5; + p3 = co8 * s5; + p4 = si8 * r5; + pSrc[2 * i8] = p1 + p2; + pSrc[2 * i8 + 1] = p3 - p4; + p1 = co6 * r6; + p2 = si6 * s6; + p3 = co6 * s6; + p4 = si6 * r6; + pSrc[2 * i6] = p1 + p2; + pSrc[2 * i6 + 1] = p3 - p4; + p1 = co4 * t1; + p2 = si4 * t2; + p3 = co4 * t2; + p4 = si4 * t1; + pSrc[2 * i4] = p1 + p2; + pSrc[2 * i4 + 1] = p3 - p4; + + i1 += n1; + } while (i1 < fftLen); + + j++; + } while (j < n2); + + twidCoefModifier <<= 3; + } while (n2 > 7); +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_f32.c new file mode 100644 index 0000000..ccb3c52 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_f32.c @@ -0,0 +1,449 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dct4_f32.c + * Description: Processing function of DCT4 & IDCT4 F32 + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup groupTransforms + */ + +/** + * @defgroup DCT4_IDCT4 DCT Type IV Functions + * Representation of signals by minimum number of values is important for storage and transmission. + * The possibility of large discontinuity between the beginning and end of a period of a signal + * in DFT can be avoided by extending the signal so that it is even-symmetric. + * Discrete Cosine Transform (DCT) is constructed such that its energy is heavily concentrated in the lower part of the + * spectrum and is very widely used in signal and image coding applications. + * The family of DCTs (DCT type- 1,2,3,4) is the outcome of different combinations of homogeneous boundary conditions. + * DCT has an excellent energy-packing capability, hence has many applications and in data compression in particular. + * + * DCT is essentially the Discrete Fourier Transform(DFT) of an even-extended real signal. + * Reordering of the input data makes the computation of DCT just a problem of + * computing the DFT of a real signal with a few additional operations. + * This approach provides regular, simple, and very efficient DCT algorithms for practical hardware and software implementations. + * + * DCT type-II can be implemented using Fast fourier transform (FFT) internally, as the transform is applied on real values, Real FFT can be used. + * DCT4 is implemented using DCT2 as their implementations are similar except with some added pre-processing and post-processing. + * DCT2 implementation can be described in the following steps: + * - Re-ordering input + * - Calculating Real FFT + * - Multiplication of weights and Real FFT output and getting real part from the product. + * + * This process is explained by the block diagram below: + * \image html DCT4.gif "Discrete Cosine Transform - type-IV" + * + * \par Algorithm: + * The N-point type-IV DCT is defined as a real, linear transformation by the formula: + * \image html DCT4Equation.gif + * where k = 0,1,2,.....N-1 + *\par + * Its inverse is defined as follows: + * \image html IDCT4Equation.gif + * where n = 0,1,2,.....N-1 + *\par + * The DCT4 matrices become involutory (i.e. they are self-inverse) by multiplying with an overall scale factor of sqrt(2/N). + * The symmetry of the transform matrix indicates that the fast algorithms for the forward + * and inverse transform computation are identical. + * Note that the implementation of Inverse DCT4 and DCT4 is same, hence same process function can be used for both. + * + * \par Lengths supported by the transform: + * As DCT4 internally uses Real FFT, it supports all the lengths 128, 512, 2048 and 8192. + * The library provides separate functions for Q15, Q31, and floating-point data types. + * \par Instance Structure + * The instances for Real FFT and FFT, cosine values table and twiddle factor table are stored in an instance data structure. + * A separate instance structure must be defined for each transform. + * There are separate instance structure declarations for each of the 3 supported data types. + * + * \par Initialization Functions + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Initializes Real FFT as its process function is used internally in DCT4, by calling arm_rfft_init_f32(). + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure cannot be placed into a const data section. + * To place an instance structure into a const data section, the instance structure must be manually initialized. + * Manually initialize the instance structure as follows: + *
+ *arm_dct4_instance_f32 S = {N, Nby2, normalize, pTwiddle, pCosFactor, pRfft, pCfft};
+ *arm_dct4_instance_q31 S = {N, Nby2, normalize, pTwiddle, pCosFactor, pRfft, pCfft};
+ *arm_dct4_instance_q15 S = {N, Nby2, normalize, pTwiddle, pCosFactor, pRfft, pCfft};
+ * 
+ * where \c N is the length of the DCT4; \c Nby2 is half of the length of the DCT4; + * \c normalize is normalizing factor used and is equal to sqrt(2/N); + * \c pTwiddle points to the twiddle factor table; + * \c pCosFactor points to the cosFactor table; + * \c pRfft points to the real FFT instance; + * \c pCfft points to the complex FFT instance; + * The CFFT and RFFT structures also needs to be initialized, refer to arm_cfft_radix4_f32() + * and arm_rfft_f32() respectively for details regarding static initialization. + * + * \par Fixed-Point Behavior + * Care must be taken when using the fixed-point versions of the DCT4 transform functions. + * In particular, the overflow and saturation behavior of the accumulator used in each function must be considered. + * Refer to the function specific documentation below for usage guidelines. + */ + + /** + * @addtogroup DCT4_IDCT4 + * @{ + */ + +/** + * @brief Processing function for the floating-point DCT4/IDCT4. + * @param[in] *S points to an instance of the floating-point DCT4/IDCT4 structure. + * @param[in] *pState points to state buffer. + * @param[in,out] *pInlineBuffer points to the in-place input and output buffer. + * @return none. + */ + +void arm_dct4_f32( + const arm_dct4_instance_f32 * S, + float32_t * pState, + float32_t * pInlineBuffer) +{ + uint32_t i; /* Loop counter */ + float32_t *weights = S->pTwiddle; /* Pointer to the Weights table */ + float32_t *cosFact = S->pCosFactor; /* Pointer to the cos factors table */ + float32_t *pS1, *pS2, *pbuff; /* Temporary pointers for input buffer and pState buffer */ + float32_t in; /* Temporary variable */ + + + /* DCT4 computation involves DCT2 (which is calculated using RFFT) + * along with some pre-processing and post-processing. + * Computational procedure is explained as follows: + * (a) Pre-processing involves multiplying input with cos factor, + * r(n) = 2 * u(n) * cos(pi*(2*n+1)/(4*n)) + * where, + * r(n) -- output of preprocessing + * u(n) -- input to preprocessing(actual Source buffer) + * (b) Calculation of DCT2 using FFT is divided into three steps: + * Step1: Re-ordering of even and odd elements of input. + * Step2: Calculating FFT of the re-ordered input. + * Step3: Taking the real part of the product of FFT output and weights. + * (c) Post-processing - DCT4 can be obtained from DCT2 output using the following equation: + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * where, + * Y4 -- DCT4 output, Y2 -- DCT2 output + * (d) Multiplying the output with the normalizing factor sqrt(2/N). + */ + + /*-------- Pre-processing ------------*/ + /* Multiplying input with cos factor i.e. r(n) = 2 * x(n) * cos(pi*(2*n+1)/(4*n)) */ + arm_scale_f32(pInlineBuffer, 2.0f, pInlineBuffer, S->N); + arm_mult_f32(pInlineBuffer, cosFact, pInlineBuffer, S->N); + + /* ---------------------------------------------------------------- + * Step1: Re-ordering of even and odd elements as, + * pState[i] = pInlineBuffer[2*i] and + * pState[N-i-1] = pInlineBuffer[2*i+1] where i = 0 to N/2 + ---------------------------------------------------------------------*/ + + /* pS1 initialized to pState */ + pS1 = pState; + + /* pS2 initialized to pState+N-1, so that it points to the end of the state buffer */ + pS2 = pState + (S->N - 1U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Initializing the loop counter to N/2 >> 2 for loop unrolling by 4 */ + i = (uint32_t) S->Nby2 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + do + { + /* Re-ordering of even and odd elements */ + /* pState[i] = pInlineBuffer[2*i] */ + *pS1++ = *pbuff++; + /* pState[N-i-1] = pInlineBuffer[2*i+1] */ + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Initializing the loop counter to N/4 instead of N for loop unrolling */ + i = (uint32_t) S->N >> 2U; + + /* Processing with loop unrolling 4 times as N is always multiple of 4. + * Compute 4 outputs at a time */ + do + { + /* Writing the re-ordered output back to inplace input buffer */ + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + + /* --------------------------------------------------------- + * Step2: Calculate RFFT for N-point input + * ---------------------------------------------------------- */ + /* pInlineBuffer is real input of length N , pState is the complex output of length 2N */ + arm_rfft_f32(S->pRfft, pInlineBuffer, pState); + + /*---------------------------------------------------------------------- + * Step3: Multiply the FFT output with the weights. + *----------------------------------------------------------------------*/ + arm_cmplx_mult_cmplx_f32(pState, weights, pState, S->N); + + /* ----------- Post-processing ---------- */ + /* DCT-IV can be obtained from DCT-II by the equation, + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * Hence, Y4(0) = Y2(0)/2 */ + /* Getting only real part from the output and Converting to DCT-IV */ + + /* Initializing the loop counter to N >> 2 for loop unrolling by 4 */ + i = ((uint32_t) S->N - 1U) >> 2U; + + /* pbuff initialized to input buffer. */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Calculating Y4(0) from Y2(0) using Y4(0) = Y2(0)/2 */ + in = *pS1++ * (float32_t) 0.5; + /* input buffer acts as inplace, so output values are stored in the input itself. */ + *pbuff++ = in; + + /* pState pointer is incremented twice as the real values are located alternatively in the array */ + pS1++; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + do + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + i = ((uint32_t) S->N - 1U) % 0x4U; + + while (i > 0U) + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + /* Decrement the loop counter */ + i--; + } + + + /*------------ Normalizing the output by multiplying with the normalizing factor ----------*/ + + /* Initializing the loop counter to N/4 instead of N for loop unrolling */ + i = (uint32_t) S->N >> 2U; + + /* pbuff initialized to the pInlineBuffer(now contains the output values) */ + pbuff = pInlineBuffer; + + /* Processing with loop unrolling 4 times as N is always multiple of 4. Compute 4 outputs at a time */ + do + { + /* Multiplying pInlineBuffer with the normalizing factor sqrt(2/N) */ + in = *pbuff; + *pbuff++ = in * S->normalize; + + in = *pbuff; + *pbuff++ = in * S->normalize; + + in = *pbuff; + *pbuff++ = in * S->normalize; + + in = *pbuff; + *pbuff++ = in * S->normalize; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initializing the loop counter to N/2 */ + i = (uint32_t) S->Nby2; + + do + { + /* Re-ordering of even and odd elements */ + /* pState[i] = pInlineBuffer[2*i] */ + *pS1++ = *pbuff++; + /* pState[N-i-1] = pInlineBuffer[2*i+1] */ + *pS2-- = *pbuff++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Initializing the loop counter */ + i = (uint32_t) S->N; + + do + { + /* Writing the re-ordered output back to inplace input buffer */ + *pbuff++ = *pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + + /* --------------------------------------------------------- + * Step2: Calculate RFFT for N-point input + * ---------------------------------------------------------- */ + /* pInlineBuffer is real input of length N , pState is the complex output of length 2N */ + arm_rfft_f32(S->pRfft, pInlineBuffer, pState); + + /*---------------------------------------------------------------------- + * Step3: Multiply the FFT output with the weights. + *----------------------------------------------------------------------*/ + arm_cmplx_mult_cmplx_f32(pState, weights, pState, S->N); + + /* ----------- Post-processing ---------- */ + /* DCT-IV can be obtained from DCT-II by the equation, + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * Hence, Y4(0) = Y2(0)/2 */ + /* Getting only real part from the output and Converting to DCT-IV */ + + /* pbuff initialized to input buffer. */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Calculating Y4(0) from Y2(0) using Y4(0) = Y2(0)/2 */ + in = *pS1++ * (float32_t) 0.5; + /* input buffer acts as inplace, so output values are stored in the input itself. */ + *pbuff++ = in; + + /* pState pointer is incremented twice as the real values are located alternatively in the array */ + pS1++; + + /* Initializing the loop counter */ + i = ((uint32_t) S->N - 1U); + + do + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + + /*------------ Normalizing the output by multiplying with the normalizing factor ----------*/ + + /* Initializing the loop counter */ + i = (uint32_t) S->N; + + /* pbuff initialized to the pInlineBuffer(now contains the output values) */ + pbuff = pInlineBuffer; + + do + { + /* Multiplying pInlineBuffer with the normalizing factor sqrt(2/N) */ + in = *pbuff; + *pbuff++ = in * S->normalize; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of DCT4_IDCT4 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_f32.c new file mode 100644 index 0000000..19b46f5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_f32.c @@ -0,0 +1,16513 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dct4_init_f32.c + * Description: Initialization function of DCT-4 & IDCT4 F32 + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup DCT4_IDCT4 + */ + +/** + * @addtogroup DCT4_IDCT4_Table DCT Type IV Tables + * @{ + */ + +/* +* @brief Weights Table +*/ + +/** + * \par + * Weights tables are generated using the formula :
weights[n] = e^(-j*n*pi/(2*N))
+ * \par + * C command to generate the table + *
+ * for(i = 0; i< N; i++)
+ * {
+ *    weights[2*i]= cos(i*c);
+ *    weights[(2*i)+1]= -sin(i * c);
+ * } 
+ * \par + * Where N is the Number of weights to be calculated and c is pi/(2*N) + * \par + * In the tables below the real and imaginary values are placed alternatively, hence the + * array length is 2*N. + */ + +static const float32_t Weights_128[256] = { + 1.000000000000000000f, 0.000000000000000000f, 0.999924701839144500f, + -0.012271538285719925f, + 0.999698818696204250f, -0.024541228522912288f, 0.999322384588349540f, + -0.036807222941358832f, + 0.998795456205172410f, -0.049067674327418015f, 0.998118112900149180f, + -0.061320736302208578f, + 0.997290456678690210f, -0.073564563599667426f, 0.996312612182778000f, + -0.085797312344439894f, + 0.995184726672196930f, -0.098017140329560604f, 0.993906970002356060f, + -0.110222207293883060f, + 0.992479534598709970f, -0.122410675199216200f, 0.990902635427780010f, + -0.134580708507126170f, + 0.989176509964781010f, -0.146730474455361750f, 0.987301418157858430f, + -0.158858143333861450f, + 0.985277642388941220f, -0.170961888760301220f, 0.983105487431216290f, + -0.183039887955140950f, + 0.980785280403230430f, -0.195090322016128250f, 0.978317370719627650f, + -0.207111376192218560f, + 0.975702130038528570f, -0.219101240156869800f, 0.972939952205560180f, + -0.231058108280671110f, + 0.970031253194543970f, -0.242980179903263870f, 0.966976471044852070f, + -0.254865659604514570f, + 0.963776065795439840f, -0.266712757474898370f, 0.960430519415565790f, + -0.278519689385053060f, + 0.956940335732208820f, -0.290284677254462330f, 0.953306040354193860f, + -0.302005949319228080f, + 0.949528180593036670f, -0.313681740398891520f, 0.945607325380521280f, + -0.325310292162262930f, + 0.941544065183020810f, -0.336889853392220050f, 0.937339011912574960f, + -0.348418680249434560f, + 0.932992798834738960f, -0.359895036534988110f, 0.928506080473215590f, + -0.371317193951837540f, + 0.923879532511286740f, -0.382683432365089780f, 0.919113851690057770f, + -0.393992040061048100f, + 0.914209755703530690f, -0.405241314004989860f, 0.909167983090522380f, + -0.416429560097637150f, + 0.903989293123443340f, -0.427555093430282080f, 0.898674465693953820f, + -0.438616238538527660f, + 0.893224301195515320f, -0.449611329654606540f, 0.887639620402853930f, + -0.460538710958240010f, + 0.881921264348355050f, -0.471396736825997640f, 0.876070094195406600f, + -0.482183772079122720f, + 0.870086991108711460f, -0.492898192229784040f, 0.863972856121586810f, + -0.503538383725717580f, + 0.857728610000272120f, -0.514102744193221660f, 0.851355193105265200f, + -0.524589682678468950f, + 0.844853565249707120f, -0.534997619887097150f, 0.838224705554838080f, + -0.545324988422046460f, + 0.831469612302545240f, -0.555570233019602180f, 0.824589302785025290f, + -0.565731810783613120f, + 0.817584813151583710f, -0.575808191417845340f, 0.810457198252594770f, + -0.585797857456438860f, + 0.803207531480644940f, -0.595699304492433360f, 0.795836904608883570f, + -0.605511041404325550f, + 0.788346427626606340f, -0.615231590580626820f, 0.780737228572094490f, + -0.624859488142386340f, + 0.773010453362736990f, -0.634393284163645490f, 0.765167265622458960f, + -0.643831542889791390f, + 0.757208846506484570f, -0.653172842953776760f, 0.749136394523459370f, + -0.662415777590171780f, + 0.740951125354959110f, -0.671558954847018330f, 0.732654271672412820f, + -0.680600997795453020f, + 0.724247082951467000f, -0.689540544737066830f, 0.715730825283818590f, + -0.698376249408972920f, + 0.707106781186547570f, -0.707106781186547460f, 0.698376249408972920f, + -0.715730825283818590f, + 0.689540544737066940f, -0.724247082951466890f, 0.680600997795453130f, + -0.732654271672412820f, + 0.671558954847018330f, -0.740951125354959110f, 0.662415777590171780f, + -0.749136394523459260f, + 0.653172842953776760f, -0.757208846506484460f, 0.643831542889791500f, + -0.765167265622458960f, + 0.634393284163645490f, -0.773010453362736990f, 0.624859488142386450f, + -0.780737228572094380f, + 0.615231590580626820f, -0.788346427626606230f, 0.605511041404325550f, + -0.795836904608883460f, + 0.595699304492433470f, -0.803207531480644830f, 0.585797857456438860f, + -0.810457198252594770f, + 0.575808191417845340f, -0.817584813151583710f, 0.565731810783613230f, + -0.824589302785025290f, + 0.555570233019602290f, -0.831469612302545240f, 0.545324988422046460f, + -0.838224705554837970f, + 0.534997619887097260f, -0.844853565249707010f, 0.524589682678468840f, + -0.851355193105265200f, + 0.514102744193221660f, -0.857728610000272120f, 0.503538383725717580f, + -0.863972856121586700f, + 0.492898192229784090f, -0.870086991108711350f, 0.482183772079122830f, + -0.876070094195406600f, + 0.471396736825997810f, -0.881921264348354940f, 0.460538710958240010f, + -0.887639620402853930f, + 0.449611329654606600f, -0.893224301195515320f, 0.438616238538527710f, + -0.898674465693953820f, + 0.427555093430282200f, -0.903989293123443340f, 0.416429560097637320f, + -0.909167983090522270f, + 0.405241314004989860f, -0.914209755703530690f, 0.393992040061048100f, + -0.919113851690057770f, + 0.382683432365089840f, -0.923879532511286740f, 0.371317193951837600f, + -0.928506080473215480f, + 0.359895036534988280f, -0.932992798834738850f, 0.348418680249434510f, + -0.937339011912574960f, + 0.336889853392220050f, -0.941544065183020810f, 0.325310292162262980f, + -0.945607325380521280f, + 0.313681740398891570f, -0.949528180593036670f, 0.302005949319228200f, + -0.953306040354193750f, + 0.290284677254462330f, -0.956940335732208940f, 0.278519689385053060f, + -0.960430519415565790f, + 0.266712757474898420f, -0.963776065795439840f, 0.254865659604514630f, + -0.966976471044852070f, + 0.242980179903263980f, -0.970031253194543970f, 0.231058108280671280f, + -0.972939952205560070f, + 0.219101240156869770f, -0.975702130038528570f, 0.207111376192218560f, + -0.978317370719627650f, + 0.195090322016128330f, -0.980785280403230430f, 0.183039887955141060f, + -0.983105487431216290f, + 0.170961888760301360f, -0.985277642388941220f, 0.158858143333861390f, + -0.987301418157858430f, + 0.146730474455361750f, -0.989176509964781010f, 0.134580708507126220f, + -0.990902635427780010f, + 0.122410675199216280f, -0.992479534598709970f, 0.110222207293883180f, + -0.993906970002356060f, + 0.098017140329560770f, -0.995184726672196820f, 0.085797312344439880f, + -0.996312612182778000f, + 0.073564563599667454f, -0.997290456678690210f, 0.061320736302208648f, + -0.998118112900149180f, + 0.049067674327418126f, -0.998795456205172410f, 0.036807222941358991f, + -0.999322384588349540f, + 0.024541228522912264f, -0.999698818696204250f, 0.012271538285719944f, + -0.999924701839144500f +}; + +static const float32_t Weights_512[1024] = { + 1.000000000000000000f, 0.000000000000000000f, 0.999995293809576190f, + -0.003067956762965976f, + 0.999981175282601110f, -0.006135884649154475f, 0.999957644551963900f, + -0.009203754782059819f, + 0.999924701839144500f, -0.012271538285719925f, 0.999882347454212560f, + -0.015339206284988100f, + 0.999830581795823400f, -0.018406729905804820f, 0.999769405351215280f, + -0.021474080275469508f, + 0.999698818696204250f, -0.024541228522912288f, 0.999618822495178640f, + -0.027608145778965740f, + 0.999529417501093140f, -0.030674803176636626f, 0.999430604555461730f, + -0.033741171851377580f, + 0.999322384588349540f, -0.036807222941358832f, 0.999204758618363890f, + -0.039872927587739811f, + 0.999077727752645360f, -0.042938256934940820f, 0.998941293186856870f, + -0.046003182130914623f, + 0.998795456205172410f, -0.049067674327418015f, 0.998640218180265270f, + -0.052131704680283324f, + 0.998475580573294770f, -0.055195244349689934f, 0.998301544933892890f, + -0.058258264500435752f, + 0.998118112900149180f, -0.061320736302208578f, 0.997925286198596000f, + -0.064382630929857465f, + 0.997723066644191640f, -0.067443919563664051f, 0.997511456140303450f, + -0.070504573389613856f, + 0.997290456678690210f, -0.073564563599667426f, 0.997060070339482960f, + -0.076623861392031492f, + 0.996820299291165670f, -0.079682437971430126f, 0.996571145790554840f, + -0.082740264549375692f, + 0.996312612182778000f, -0.085797312344439894f, 0.996044700901251970f, + -0.088853552582524600f, + 0.995767414467659820f, -0.091908956497132724f, 0.995480755491926940f, + -0.094963495329638992f, + 0.995184726672196930f, -0.098017140329560604f, 0.994879330794805620f, + -0.101069862754827820f, + 0.994564570734255420f, -0.104121633872054590f, 0.994240449453187900f, + -0.107172424956808840f, + 0.993906970002356060f, -0.110222207293883060f, 0.993564135520595300f, + -0.113270952177564350f, + 0.993211949234794500f, -0.116318630911904750f, 0.992850414459865100f, + -0.119365214810991350f, + 0.992479534598709970f, -0.122410675199216200f, 0.992099313142191800f, + -0.125454983411546230f, + 0.991709753669099530f, -0.128498110793793170f, 0.991310859846115440f, + -0.131540028702883120f, + 0.990902635427780010f, -0.134580708507126170f, 0.990485084256457090f, + -0.137620121586486040f, + 0.990058210262297120f, -0.140658239332849210f, 0.989622017463200890f, + -0.143695033150294470f, + 0.989176509964781010f, -0.146730474455361750f, 0.988721691960323780f, + -0.149764534677321510f, + 0.988257567730749460f, -0.152797185258443440f, 0.987784141644572180f, + -0.155828397654265230f, + 0.987301418157858430f, -0.158858143333861450f, 0.986809401814185530f, + -0.161886393780111830f, + 0.986308097244598670f, -0.164913120489969890f, 0.985797509167567480f, + -0.167938294974731170f, + 0.985277642388941220f, -0.170961888760301220f, 0.984748501801904210f, + -0.173983873387463820f, + 0.984210092386929030f, -0.177004220412148750f, 0.983662419211730250f, + -0.180022901405699510f, + 0.983105487431216290f, -0.183039887955140950f, 0.982539302287441240f, + -0.186055151663446630f, + 0.981963869109555240f, -0.189068664149806190f, 0.981379193313754560f, + -0.192080397049892440f, + 0.980785280403230430f, -0.195090322016128250f, 0.980182135968117430f, + -0.198098410717953560f, + 0.979569765685440520f, -0.201104634842091900f, 0.978948175319062200f, + -0.204108966092816870f, + 0.978317370719627650f, -0.207111376192218560f, 0.977677357824509930f, + -0.210111836880469610f, + 0.977028142657754390f, -0.213110319916091360f, 0.976369731330021140f, + -0.216106797076219520f, + 0.975702130038528570f, -0.219101240156869800f, 0.975025345066994120f, + -0.222093620973203510f, + 0.974339382785575860f, -0.225083911359792830f, 0.973644249650811980f, + -0.228072083170885730f, + 0.972939952205560180f, -0.231058108280671110f, 0.972226497078936270f, + -0.234041958583543430f, + 0.971503890986251780f, -0.237023605994367200f, 0.970772140728950350f, + -0.240003022448741500f, + 0.970031253194543970f, -0.242980179903263870f, 0.969281235356548530f, + -0.245955050335794590f, + 0.968522094274417380f, -0.248927605745720150f, 0.967753837093475510f, + -0.251897818154216970f, + 0.966976471044852070f, -0.254865659604514570f, 0.966190003445412500f, + -0.257831102162158990f, + 0.965394441697689400f, -0.260794117915275510f, 0.964589793289812760f, + -0.263754678974831350f, + 0.963776065795439840f, -0.266712757474898370f, 0.962953266873683880f, + -0.269668325572915090f, + 0.962121404269041580f, -0.272621355449948980f, 0.961280485811320640f, + -0.275571819310958140f, + 0.960430519415565790f, -0.278519689385053060f, 0.959571513081984520f, + -0.281464937925757940f, + 0.958703474895871600f, -0.284407537211271880f, 0.957826413027532910f, + -0.287347459544729510f, + 0.956940335732208820f, -0.290284677254462330f, 0.956045251349996410f, + -0.293219162694258630f, + 0.955141168305770780f, -0.296150888243623790f, 0.954228095109105670f, + -0.299079826308040480f, + 0.953306040354193860f, -0.302005949319228080f, 0.952375012719765880f, + -0.304929229735402370f, + 0.951435020969008340f, -0.307849640041534870f, 0.950486073949481700f, + -0.310767152749611470f, + 0.949528180593036670f, -0.313681740398891520f, 0.948561349915730270f, + -0.316593375556165850f, + 0.947585591017741090f, -0.319502030816015690f, 0.946600913083283530f, + -0.322407678801069850f, + 0.945607325380521280f, -0.325310292162262930f, 0.944604837261480260f, + -0.328209843579092500f, + 0.943593458161960390f, -0.331106305759876430f, 0.942573197601446870f, + -0.333999651442009380f, + 0.941544065183020810f, -0.336889853392220050f, 0.940506070593268300f, + -0.339776884406826850f, + 0.939459223602189920f, -0.342660717311994380f, 0.938403534063108060f, + -0.345541324963989090f, + 0.937339011912574960f, -0.348418680249434560f, 0.936265667170278260f, + -0.351292756085567090f, + 0.935183509938947610f, -0.354163525420490340f, 0.934092550404258980f, + -0.357030961233429980f, + 0.932992798834738960f, -0.359895036534988110f, 0.931884265581668150f, + -0.362755724367397230f, + 0.930766961078983710f, -0.365612997804773850f, 0.929640895843181330f, + -0.368466829953372320f, + 0.928506080473215590f, -0.371317193951837540f, 0.927362525650401110f, + -0.374164062971457930f, + 0.926210242138311380f, -0.377007410216418260f, 0.925049240782677580f, + -0.379847208924051160f, + 0.923879532511286740f, -0.382683432365089780f, 0.922701128333878630f, + -0.385516053843918850f, + 0.921514039342042010f, -0.388345046698826250f, 0.920318276709110590f, + -0.391170384302253870f, + 0.919113851690057770f, -0.393992040061048100f, 0.917900775621390500f, + -0.396809987416710310f, + 0.916679059921042700f, -0.399624199845646790f, 0.915448716088267830f, + -0.402434650859418430f, + 0.914209755703530690f, -0.405241314004989860f, 0.912962190428398210f, + -0.408044162864978690f, + 0.911706032005429880f, -0.410843171057903910f, 0.910441292258067250f, + -0.413638312238434500f, + 0.909167983090522380f, -0.416429560097637150f, 0.907886116487666260f, + -0.419216888363223910f, + 0.906595704514915330f, -0.422000270799799680f, 0.905296759318118820f, + -0.424779681209108810f, + 0.903989293123443340f, -0.427555093430282080f, 0.902673318237258830f, + -0.430326481340082610f, + 0.901348847046022030f, -0.433093818853151960f, 0.900015892016160280f, + -0.435857079922255470f, + 0.898674465693953820f, -0.438616238538527660f, 0.897324580705418320f, + -0.441371268731716670f, + 0.895966249756185220f, -0.444122144570429200f, 0.894599485631382700f, + -0.446868840162374160f, + 0.893224301195515320f, -0.449611329654606540f, 0.891840709392342720f, + -0.452349587233770890f, + 0.890448723244757880f, -0.455083587126343840f, 0.889048355854664570f, + -0.457813303598877170f, + 0.887639620402853930f, -0.460538710958240010f, 0.886222530148880640f, + -0.463259783551860150f, + 0.884797098430937790f, -0.465976495767966180f, 0.883363338665731580f, + -0.468688822035827900f, + 0.881921264348355050f, -0.471396736825997640f, 0.880470889052160750f, + -0.474100214650549970f, + 0.879012226428633530f, -0.476799230063322090f, 0.877545290207261350f, + -0.479493757660153010f, + 0.876070094195406600f, -0.482183772079122720f, 0.874586652278176110f, + -0.484869248000791060f, + 0.873094978418290090f, -0.487550160148436000f, 0.871595086655950980f, + -0.490226483288291160f, + 0.870086991108711460f, -0.492898192229784040f, 0.868570705971340900f, + -0.495565261825772540f, + 0.867046245515692650f, -0.498227666972781870f, 0.865513624090569090f, + -0.500885382611240710f, + 0.863972856121586810f, -0.503538383725717580f, 0.862423956111040610f, + -0.506186645345155230f, + 0.860866938637767310f, -0.508830142543106990f, 0.859301818357008470f, + -0.511468850437970300f, + 0.857728610000272120f, -0.514102744193221660f, 0.856147328375194470f, + -0.516731799017649870f, + 0.854557988365400530f, -0.519355990165589640f, 0.852960604930363630f, + -0.521975292937154390f, + 0.851355193105265200f, -0.524589682678468950f, 0.849741768000852550f, + -0.527199134781901280f, + 0.848120344803297230f, -0.529803624686294610f, 0.846490938774052130f, + -0.532403127877197900f, + 0.844853565249707120f, -0.534997619887097150f, 0.843208239641845440f, + -0.537587076295645390f, + 0.841554977436898440f, -0.540171472729892850f, 0.839893794195999520f, + -0.542750784864515890f, + 0.838224705554838080f, -0.545324988422046460f, 0.836547727223512010f, + -0.547894059173100190f, + 0.834862874986380010f, -0.550457972936604810f, 0.833170164701913190f, + -0.553016705580027470f, + 0.831469612302545240f, -0.555570233019602180f, 0.829761233794523050f, + -0.558118531220556100f, + 0.828045045257755800f, -0.560661576197336030f, 0.826321062845663530f, + -0.563199344013834090f, + 0.824589302785025290f, -0.565731810783613120f, 0.822849781375826430f, + -0.568258952670131490f, + 0.821102514991104650f, -0.570780745886967260f, 0.819347520076796900f, + -0.573297166698042200f, + 0.817584813151583710f, -0.575808191417845340f, 0.815814410806733780f, + -0.578313796411655590f, + 0.814036329705948410f, -0.580813958095764530f, 0.812250586585203880f, + -0.583308652937698290f, + 0.810457198252594770f, -0.585797857456438860f, 0.808656181588174980f, + -0.588281548222645220f, + 0.806847553543799330f, -0.590759701858874160f, 0.805031331142963660f, + -0.593232295039799800f, + 0.803207531480644940f, -0.595699304492433360f, 0.801376171723140240f, + -0.598160706996342270f, + 0.799537269107905010f, -0.600616479383868970f, 0.797690840943391160f, + -0.603066598540348160f, + 0.795836904608883570f, -0.605511041404325550f, 0.793975477554337170f, + -0.607949784967773630f, + 0.792106577300212390f, -0.610382806276309480f, 0.790230221437310030f, + -0.612810082429409710f, + 0.788346427626606340f, -0.615231590580626820f, 0.786455213599085770f, + -0.617647307937803870f, + 0.784556597155575240f, -0.620057211763289100f, 0.782650596166575730f, + -0.622461279374149970f, + 0.780737228572094490f, -0.624859488142386340f, 0.778816512381475980f, + -0.627251815495144080f, + 0.776888465673232440f, -0.629638238914926980f, 0.774953106594873930f, + -0.632018735939809060f, + 0.773010453362736990f, -0.634393284163645490f, 0.771060524261813820f, + -0.636761861236284200f, + 0.769103337645579700f, -0.639124444863775730f, 0.767138911935820400f, + -0.641481012808583160f, + 0.765167265622458960f, -0.643831542889791390f, 0.763188417263381270f, + -0.646176012983316280f, + 0.761202385484261780f, -0.648514401022112440f, 0.759209188978388070f, + -0.650846684996380880f, + 0.757208846506484570f, -0.653172842953776760f, 0.755201376896536550f, + -0.655492852999615350f, + 0.753186799043612520f, -0.657806693297078640f, 0.751165131909686480f, + -0.660114342067420480f, + 0.749136394523459370f, -0.662415777590171780f, 0.747100605980180130f, + -0.664710978203344790f, + 0.745057785441466060f, -0.666999922303637470f, 0.743007952135121720f, + -0.669282588346636010f, + 0.740951125354959110f, -0.671558954847018330f, 0.738887324460615110f, + -0.673829000378756040f, + 0.736816568877369900f, -0.676092703575315920f, 0.734738878095963500f, + -0.678350043129861470f, + 0.732654271672412820f, -0.680600997795453020f, 0.730562769227827590f, + -0.682845546385248080f, + 0.728464390448225200f, -0.685083667772700360f, 0.726359155084346010f, + -0.687315340891759050f, + 0.724247082951467000f, -0.689540544737066830f, 0.722128193929215350f, + -0.691759258364157750f, + 0.720002507961381650f, -0.693971460889654000f, 0.717870045055731710f, + -0.696177131491462990f, + 0.715730825283818590f, -0.698376249408972920f, 0.713584868780793640f, + -0.700568793943248340f, + 0.711432195745216430f, -0.702754744457225300f, 0.709272826438865690f, + -0.704934080375904880f, + 0.707106781186547570f, -0.707106781186547460f, 0.704934080375904990f, + -0.709272826438865580f, + 0.702754744457225300f, -0.711432195745216430f, 0.700568793943248450f, + -0.713584868780793520f, + 0.698376249408972920f, -0.715730825283818590f, 0.696177131491462990f, + -0.717870045055731710f, + 0.693971460889654000f, -0.720002507961381650f, 0.691759258364157750f, + -0.722128193929215350f, + 0.689540544737066940f, -0.724247082951466890f, 0.687315340891759160f, + -0.726359155084346010f, + 0.685083667772700360f, -0.728464390448225200f, 0.682845546385248080f, + -0.730562769227827590f, + 0.680600997795453130f, -0.732654271672412820f, 0.678350043129861580f, + -0.734738878095963390f, + 0.676092703575316030f, -0.736816568877369790f, 0.673829000378756150f, + -0.738887324460615110f, + 0.671558954847018330f, -0.740951125354959110f, 0.669282588346636010f, + -0.743007952135121720f, + 0.666999922303637470f, -0.745057785441465950f, 0.664710978203344900f, + -0.747100605980180130f, + 0.662415777590171780f, -0.749136394523459260f, 0.660114342067420480f, + -0.751165131909686370f, + 0.657806693297078640f, -0.753186799043612410f, 0.655492852999615460f, + -0.755201376896536550f, + 0.653172842953776760f, -0.757208846506484460f, 0.650846684996380990f, + -0.759209188978387960f, + 0.648514401022112550f, -0.761202385484261780f, 0.646176012983316390f, + -0.763188417263381270f, + 0.643831542889791500f, -0.765167265622458960f, 0.641481012808583160f, + -0.767138911935820400f, + 0.639124444863775730f, -0.769103337645579590f, 0.636761861236284200f, + -0.771060524261813710f, + 0.634393284163645490f, -0.773010453362736990f, 0.632018735939809060f, + -0.774953106594873820f, + 0.629638238914927100f, -0.776888465673232440f, 0.627251815495144190f, + -0.778816512381475870f, + 0.624859488142386450f, -0.780737228572094380f, 0.622461279374150080f, + -0.782650596166575730f, + 0.620057211763289210f, -0.784556597155575240f, 0.617647307937803980f, + -0.786455213599085770f, + 0.615231590580626820f, -0.788346427626606230f, 0.612810082429409710f, + -0.790230221437310030f, + 0.610382806276309480f, -0.792106577300212390f, 0.607949784967773740f, + -0.793975477554337170f, + 0.605511041404325550f, -0.795836904608883460f, 0.603066598540348280f, + -0.797690840943391040f, + 0.600616479383868970f, -0.799537269107905010f, 0.598160706996342380f, + -0.801376171723140130f, + 0.595699304492433470f, -0.803207531480644830f, 0.593232295039799800f, + -0.805031331142963660f, + 0.590759701858874280f, -0.806847553543799220f, 0.588281548222645330f, + -0.808656181588174980f, + 0.585797857456438860f, -0.810457198252594770f, 0.583308652937698290f, + -0.812250586585203880f, + 0.580813958095764530f, -0.814036329705948300f, 0.578313796411655590f, + -0.815814410806733780f, + 0.575808191417845340f, -0.817584813151583710f, 0.573297166698042320f, + -0.819347520076796900f, + 0.570780745886967370f, -0.821102514991104650f, 0.568258952670131490f, + -0.822849781375826320f, + 0.565731810783613230f, -0.824589302785025290f, 0.563199344013834090f, + -0.826321062845663420f, + 0.560661576197336030f, -0.828045045257755800f, 0.558118531220556100f, + -0.829761233794523050f, + 0.555570233019602290f, -0.831469612302545240f, 0.553016705580027580f, + -0.833170164701913190f, + 0.550457972936604810f, -0.834862874986380010f, 0.547894059173100190f, + -0.836547727223511890f, + 0.545324988422046460f, -0.838224705554837970f, 0.542750784864516000f, + -0.839893794195999410f, + 0.540171472729892970f, -0.841554977436898330f, 0.537587076295645510f, + -0.843208239641845440f, + 0.534997619887097260f, -0.844853565249707010f, 0.532403127877198010f, + -0.846490938774052020f, + 0.529803624686294830f, -0.848120344803297120f, 0.527199134781901390f, + -0.849741768000852440f, + 0.524589682678468840f, -0.851355193105265200f, 0.521975292937154390f, + -0.852960604930363630f, + 0.519355990165589530f, -0.854557988365400530f, 0.516731799017649980f, + -0.856147328375194470f, + 0.514102744193221660f, -0.857728610000272120f, 0.511468850437970520f, + -0.859301818357008360f, + 0.508830142543106990f, -0.860866938637767310f, 0.506186645345155450f, + -0.862423956111040500f, + 0.503538383725717580f, -0.863972856121586700f, 0.500885382611240940f, + -0.865513624090568980f, + 0.498227666972781870f, -0.867046245515692650f, 0.495565261825772490f, + -0.868570705971340900f, + 0.492898192229784090f, -0.870086991108711350f, 0.490226483288291100f, + -0.871595086655951090f, + 0.487550160148436050f, -0.873094978418290090f, 0.484869248000791120f, + -0.874586652278176110f, + 0.482183772079122830f, -0.876070094195406600f, 0.479493757660153010f, + -0.877545290207261240f, + 0.476799230063322250f, -0.879012226428633410f, 0.474100214650550020f, + -0.880470889052160750f, + 0.471396736825997810f, -0.881921264348354940f, 0.468688822035827960f, + -0.883363338665731580f, + 0.465976495767966130f, -0.884797098430937790f, 0.463259783551860260f, + -0.886222530148880640f, + 0.460538710958240010f, -0.887639620402853930f, 0.457813303598877290f, + -0.889048355854664570f, + 0.455083587126343840f, -0.890448723244757880f, 0.452349587233771000f, + -0.891840709392342720f, + 0.449611329654606600f, -0.893224301195515320f, 0.446868840162374330f, + -0.894599485631382580f, + 0.444122144570429260f, -0.895966249756185110f, 0.441371268731716620f, + -0.897324580705418320f, + 0.438616238538527710f, -0.898674465693953820f, 0.435857079922255470f, + -0.900015892016160280f, + 0.433093818853152010f, -0.901348847046022030f, 0.430326481340082610f, + -0.902673318237258830f, + 0.427555093430282200f, -0.903989293123443340f, 0.424779681209108810f, + -0.905296759318118820f, + 0.422000270799799790f, -0.906595704514915330f, 0.419216888363223960f, + -0.907886116487666150f, + 0.416429560097637320f, -0.909167983090522270f, 0.413638312238434560f, + -0.910441292258067140f, + 0.410843171057903910f, -0.911706032005429880f, 0.408044162864978740f, + -0.912962190428398100f, + 0.405241314004989860f, -0.914209755703530690f, 0.402434650859418540f, + -0.915448716088267830f, + 0.399624199845646790f, -0.916679059921042700f, 0.396809987416710420f, + -0.917900775621390390f, + 0.393992040061048100f, -0.919113851690057770f, 0.391170384302253980f, + -0.920318276709110480f, + 0.388345046698826300f, -0.921514039342041900f, 0.385516053843919020f, + -0.922701128333878520f, + 0.382683432365089840f, -0.923879532511286740f, 0.379847208924051110f, + -0.925049240782677580f, + 0.377007410216418310f, -0.926210242138311270f, 0.374164062971457990f, + -0.927362525650401110f, + 0.371317193951837600f, -0.928506080473215480f, 0.368466829953372320f, + -0.929640895843181330f, + 0.365612997804773960f, -0.930766961078983710f, 0.362755724367397230f, + -0.931884265581668150f, + 0.359895036534988280f, -0.932992798834738850f, 0.357030961233430030f, + -0.934092550404258870f, + 0.354163525420490510f, -0.935183509938947500f, 0.351292756085567150f, + -0.936265667170278260f, + 0.348418680249434510f, -0.937339011912574960f, 0.345541324963989150f, + -0.938403534063108060f, + 0.342660717311994380f, -0.939459223602189920f, 0.339776884406826960f, + -0.940506070593268300f, + 0.336889853392220050f, -0.941544065183020810f, 0.333999651442009490f, + -0.942573197601446870f, + 0.331106305759876430f, -0.943593458161960390f, 0.328209843579092660f, + -0.944604837261480260f, + 0.325310292162262980f, -0.945607325380521280f, 0.322407678801070020f, + -0.946600913083283530f, + 0.319502030816015750f, -0.947585591017741090f, 0.316593375556165850f, + -0.948561349915730270f, + 0.313681740398891570f, -0.949528180593036670f, 0.310767152749611470f, + -0.950486073949481700f, + 0.307849640041534980f, -0.951435020969008340f, 0.304929229735402430f, + -0.952375012719765880f, + 0.302005949319228200f, -0.953306040354193750f, 0.299079826308040480f, + -0.954228095109105670f, + 0.296150888243623960f, -0.955141168305770670f, 0.293219162694258680f, + -0.956045251349996410f, + 0.290284677254462330f, -0.956940335732208940f, 0.287347459544729570f, + -0.957826413027532910f, + 0.284407537211271820f, -0.958703474895871600f, 0.281464937925758050f, + -0.959571513081984520f, + 0.278519689385053060f, -0.960430519415565790f, 0.275571819310958250f, + -0.961280485811320640f, + 0.272621355449948980f, -0.962121404269041580f, 0.269668325572915200f, + -0.962953266873683880f, + 0.266712757474898420f, -0.963776065795439840f, 0.263754678974831510f, + -0.964589793289812650f, + 0.260794117915275570f, -0.965394441697689400f, 0.257831102162158930f, + -0.966190003445412620f, + 0.254865659604514630f, -0.966976471044852070f, 0.251897818154216910f, + -0.967753837093475510f, + 0.248927605745720260f, -0.968522094274417270f, 0.245955050335794590f, + -0.969281235356548530f, + 0.242980179903263980f, -0.970031253194543970f, 0.240003022448741500f, + -0.970772140728950350f, + 0.237023605994367340f, -0.971503890986251780f, 0.234041958583543460f, + -0.972226497078936270f, + 0.231058108280671280f, -0.972939952205560070f, 0.228072083170885790f, + -0.973644249650811870f, + 0.225083911359792780f, -0.974339382785575860f, 0.222093620973203590f, + -0.975025345066994120f, + 0.219101240156869770f, -0.975702130038528570f, 0.216106797076219600f, + -0.976369731330021140f, + 0.213110319916091360f, -0.977028142657754390f, 0.210111836880469720f, + -0.977677357824509930f, + 0.207111376192218560f, -0.978317370719627650f, 0.204108966092817010f, + -0.978948175319062200f, + 0.201104634842091960f, -0.979569765685440520f, 0.198098410717953730f, + -0.980182135968117320f, + 0.195090322016128330f, -0.980785280403230430f, 0.192080397049892380f, + -0.981379193313754560f, + 0.189068664149806280f, -0.981963869109555240f, 0.186055151663446630f, + -0.982539302287441240f, + 0.183039887955141060f, -0.983105487431216290f, 0.180022901405699510f, + -0.983662419211730250f, + 0.177004220412148860f, -0.984210092386929030f, 0.173983873387463850f, + -0.984748501801904210f, + 0.170961888760301360f, -0.985277642388941220f, 0.167938294974731230f, + -0.985797509167567370f, + 0.164913120489970090f, -0.986308097244598670f, 0.161886393780111910f, + -0.986809401814185420f, + 0.158858143333861390f, -0.987301418157858430f, 0.155828397654265320f, + -0.987784141644572180f, + 0.152797185258443410f, -0.988257567730749460f, 0.149764534677321620f, + -0.988721691960323780f, + 0.146730474455361750f, -0.989176509964781010f, 0.143695033150294580f, + -0.989622017463200780f, + 0.140658239332849240f, -0.990058210262297120f, 0.137620121586486180f, + -0.990485084256456980f, + 0.134580708507126220f, -0.990902635427780010f, 0.131540028702883280f, + -0.991310859846115440f, + 0.128498110793793220f, -0.991709753669099530f, 0.125454983411546210f, + -0.992099313142191800f, + 0.122410675199216280f, -0.992479534598709970f, 0.119365214810991350f, + -0.992850414459865100f, + 0.116318630911904880f, -0.993211949234794500f, 0.113270952177564360f, + -0.993564135520595300f, + 0.110222207293883180f, -0.993906970002356060f, 0.107172424956808870f, + -0.994240449453187900f, + 0.104121633872054730f, -0.994564570734255420f, 0.101069862754827880f, + -0.994879330794805620f, + 0.098017140329560770f, -0.995184726672196820f, 0.094963495329639061f, + -0.995480755491926940f, + 0.091908956497132696f, -0.995767414467659820f, 0.088853552582524684f, + -0.996044700901251970f, + 0.085797312344439880f, -0.996312612182778000f, 0.082740264549375803f, + -0.996571145790554840f, + 0.079682437971430126f, -0.996820299291165670f, 0.076623861392031617f, + -0.997060070339482960f, + 0.073564563599667454f, -0.997290456678690210f, 0.070504573389614009f, + -0.997511456140303450f, + 0.067443919563664106f, -0.997723066644191640f, 0.064382630929857410f, + -0.997925286198596000f, + 0.061320736302208648f, -0.998118112900149180f, 0.058258264500435732f, + -0.998301544933892890f, + 0.055195244349690031f, -0.998475580573294770f, 0.052131704680283317f, + -0.998640218180265270f, + 0.049067674327418126f, -0.998795456205172410f, 0.046003182130914644f, + -0.998941293186856870f, + 0.042938256934940959f, -0.999077727752645360f, 0.039872927587739845f, + -0.999204758618363890f, + 0.036807222941358991f, -0.999322384588349540f, 0.033741171851377642f, + -0.999430604555461730f, + 0.030674803176636581f, -0.999529417501093140f, 0.027608145778965820f, + -0.999618822495178640f, + 0.024541228522912264f, -0.999698818696204250f, 0.021474080275469605f, + -0.999769405351215280f, + 0.018406729905804820f, -0.999830581795823400f, 0.015339206284988220f, + -0.999882347454212560f, + 0.012271538285719944f, -0.999924701839144500f, 0.009203754782059960f, + -0.999957644551963900f, + 0.006135884649154515f, -0.999981175282601110f, 0.003067956762966138f, + -0.999995293809576190f +}; + +static const float32_t Weights_2048[4096] = { + 1.000000000000000000f, 0.000000000000000000f, 0.999999705862882230f, + -0.000766990318742704f, + 0.999998823451701880f, -0.001533980186284766f, 0.999997352766978210f, + -0.002300969151425805f, + 0.999995293809576190f, -0.003067956762965976f, 0.999992646580707190f, + -0.003834942569706228f, + 0.999989411081928400f, -0.004601926120448571f, 0.999985587315143200f, + -0.005368906963996343f, + 0.999981175282601110f, -0.006135884649154475f, 0.999976174986897610f, + -0.006902858724729756f, + 0.999970586430974140f, -0.007669828739531097f, 0.999964409618118280f, + -0.008436794242369799f, + 0.999957644551963900f, -0.009203754782059819f, 0.999950291236490480f, + -0.009970709907418031f, + 0.999942349676023910f, -0.010737659167264491f, 0.999933819875236000f, + -0.011504602110422714f, + 0.999924701839144500f, -0.012271538285719925f, 0.999914995573113470f, + -0.013038467241987334f, + 0.999904701082852900f, -0.013805388528060391f, 0.999893818374418490f, + -0.014572301692779064f, + 0.999882347454212560f, -0.015339206284988100f, 0.999870288328982950f, + -0.016106101853537287f, + 0.999857641005823860f, -0.016872987947281710f, 0.999844405492175240f, + -0.017639864115082053f, + 0.999830581795823400f, -0.018406729905804820f, 0.999816169924900410f, + -0.019173584868322623f, + 0.999801169887884260f, -0.019940428551514441f, 0.999785581693599210f, + -0.020707260504265895f, + 0.999769405351215280f, -0.021474080275469508f, 0.999752640870248840f, + -0.022240887414024961f, + 0.999735288260561680f, -0.023007681468839369f, 0.999717347532362190f, + -0.023774461988827555f, + 0.999698818696204250f, -0.024541228522912288f, 0.999679701762987930f, + -0.025307980620024571f, + 0.999659996743959220f, -0.026074717829103901f, 0.999639703650710200f, + -0.026841439699098531f, + 0.999618822495178640f, -0.027608145778965740f, 0.999597353289648380f, + -0.028374835617672099f, + 0.999575296046749220f, -0.029141508764193722f, 0.999552650779456990f, + -0.029908164767516555f, + 0.999529417501093140f, -0.030674803176636626f, 0.999505596225325310f, + -0.031441423540560301f, + 0.999481186966166950f, -0.032208025408304586f, 0.999456189737977340f, + -0.032974608328897335f, + 0.999430604555461730f, -0.033741171851377580f, 0.999404431433671300f, + -0.034507715524795750f, + 0.999377670388002850f, -0.035274238898213947f, 0.999350321434199440f, + -0.036040741520706229f, + 0.999322384588349540f, -0.036807222941358832f, 0.999293859866887790f, + -0.037573682709270494f, + 0.999264747286594420f, -0.038340120373552694f, 0.999235046864595850f, + -0.039106535483329888f, + 0.999204758618363890f, -0.039872927587739811f, 0.999173882565716380f, + -0.040639296235933736f, + 0.999142418724816910f, -0.041405640977076739f, 0.999110367114174890f, + -0.042171961360347947f, + 0.999077727752645360f, -0.042938256934940820f, 0.999044500659429290f, + -0.043704527250063421f, + 0.999010685854073380f, -0.044470771854938668f, 0.998976283356469820f, + -0.045236990298804590f, + 0.998941293186856870f, -0.046003182130914623f, 0.998905715365818290f, + -0.046769346900537863f, + 0.998869549914283560f, -0.047535484156959303f, 0.998832796853527990f, + -0.048301593449480144f, + 0.998795456205172410f, -0.049067674327418015f, 0.998757527991183340f, + -0.049833726340107277f, + 0.998719012233872940f, -0.050599749036899282f, 0.998679908955899090f, + -0.051365741967162593f, + 0.998640218180265270f, -0.052131704680283324f, 0.998599939930320370f, + -0.052897636725665324f, + 0.998559074229759310f, -0.053663537652730520f, 0.998517621102622210f, + -0.054429407010919133f, + 0.998475580573294770f, -0.055195244349689934f, 0.998432952666508440f, + -0.055961049218520569f, + 0.998389737407340160f, -0.056726821166907748f, 0.998345934821212370f, + -0.057492559744367566f, + 0.998301544933892890f, -0.058258264500435752f, 0.998256567771495180f, + -0.059023934984667931f, + 0.998211003360478190f, -0.059789570746639868f, 0.998164851727646240f, + -0.060555171335947788f, + 0.998118112900149180f, -0.061320736302208578f, 0.998070786905482340f, + -0.062086265195060088f, + 0.998022873771486240f, -0.062851757564161406f, 0.997974373526346990f, + -0.063617212959193106f, + 0.997925286198596000f, -0.064382630929857465f, 0.997875611817110150f, + -0.065148011025878833f, + 0.997825350411111640f, -0.065913352797003805f, 0.997774502010167820f, + -0.066678655793001557f, + 0.997723066644191640f, -0.067443919563664051f, 0.997671044343441000f, + -0.068209143658806329f, + 0.997618435138519550f, -0.068974327628266746f, 0.997565239060375750f, + -0.069739471021907307f, + 0.997511456140303450f, -0.070504573389613856f, 0.997457086409941910f, + -0.071269634281296401f, + 0.997402129901275300f, -0.072034653246889332f, 0.997346586646633230f, + -0.072799629836351673f, + 0.997290456678690210f, -0.073564563599667426f, 0.997233740030466280f, + -0.074329454086845756f, + 0.997176436735326190f, -0.075094300847921305f, 0.997118546826979980f, + -0.075859103432954447f, + 0.997060070339482960f, -0.076623861392031492f, 0.997001007307235290f, + -0.077388574275265049f, + 0.996941357764982160f, -0.078153241632794232f, 0.996881121747813850f, + -0.078917863014784942f, + 0.996820299291165670f, -0.079682437971430126f, 0.996758890430818000f, + -0.080446966052950014f, + 0.996696895202896060f, -0.081211446809592441f, 0.996634313643869900f, + -0.081975879791633066f, + 0.996571145790554840f, -0.082740264549375692f, 0.996507391680110820f, + -0.083504600633152432f, + 0.996443051350042630f, -0.084268887593324071f, 0.996378124838200210f, + -0.085033124980280275f, + 0.996312612182778000f, -0.085797312344439894f, 0.996246513422315520f, + -0.086561449236251170f, + 0.996179828595696980f, -0.087325535206192059f, 0.996112557742151130f, + -0.088089569804770507f, + 0.996044700901251970f, -0.088853552582524600f, 0.995976258112917790f, + -0.089617483090022959f, + 0.995907229417411720f, -0.090381360877864983f, 0.995837614855341610f, + -0.091145185496681005f, + 0.995767414467659820f, -0.091908956497132724f, 0.995696628295663520f, + -0.092672673429913310f, + 0.995625256380994310f, -0.093436335845747787f, 0.995553298765638470f, + -0.094199943295393204f, + 0.995480755491926940f, -0.094963495329638992f, 0.995407626602534900f, + -0.095726991499307162f, + 0.995333912140482280f, -0.096490431355252593f, 0.995259612149133390f, + -0.097253814448363271f, + 0.995184726672196930f, -0.098017140329560604f, 0.995109255753726110f, + -0.098780408549799623f, + 0.995033199438118630f, -0.099543618660069319f, 0.994956557770116380f, + -0.100306770211392860f, + 0.994879330794805620f, -0.101069862754827820f, 0.994801518557617110f, + -0.101832895841466530f, + 0.994723121104325700f, -0.102595869022436280f, 0.994644138481050710f, + -0.103358781848899610f, + 0.994564570734255420f, -0.104121633872054590f, 0.994484417910747600f, + -0.104884424643134970f, + 0.994403680057679100f, -0.105647153713410620f, 0.994322357222545810f, + -0.106409820634187680f, + 0.994240449453187900f, -0.107172424956808840f, 0.994157956797789730f, + -0.107934966232653650f, + 0.994074879304879370f, -0.108697444013138720f, 0.993991217023329380f, + -0.109459857849717980f, + 0.993906970002356060f, -0.110222207293883060f, 0.993822138291519660f, + -0.110984491897163390f, + 0.993736721940724600f, -0.111746711211126590f, 0.993650721000219120f, + -0.112508864787378690f, + 0.993564135520595300f, -0.113270952177564350f, 0.993476965552789190f, + -0.114032972933367200f, + 0.993389211148080650f, -0.114794926606510080f, 0.993300872358093280f, + -0.115556812748755260f, + 0.993211949234794500f, -0.116318630911904750f, 0.993122441830495580f, + -0.117080380647800590f, + 0.993032350197851410f, -0.117842061508324980f, 0.992941674389860470f, + -0.118603673045400720f, + 0.992850414459865100f, -0.119365214810991350f, 0.992758570461551140f, + -0.120126686357101500f, + 0.992666142448948020f, -0.120888087235777080f, 0.992573130476428810f, + -0.121649416999105530f, + 0.992479534598709970f, -0.122410675199216200f, 0.992385354870851670f, + -0.123171861388280480f, + 0.992290591348257370f, -0.123932975118512160f, 0.992195244086673920f, + -0.124694015942167640f, + 0.992099313142191800f, -0.125454983411546230f, 0.992002798571244520f, + -0.126215877078990350f, + 0.991905700430609330f, -0.126976696496885870f, 0.991808018777406430f, + -0.127737441217662310f, + 0.991709753669099530f, -0.128498110793793170f, 0.991610905163495370f, + -0.129258704777796140f, + 0.991511473318743900f, -0.130019222722233350f, 0.991411458193338540f, + -0.130779664179711710f, + 0.991310859846115440f, -0.131540028702883120f, 0.991209678336254060f, + -0.132300315844444650f, + 0.991107913723276890f, -0.133060525157139060f, 0.991005566067049370f, + -0.133820656193754720f, + 0.990902635427780010f, -0.134580708507126170f, 0.990799121866020370f, + -0.135340681650134210f, + 0.990695025442664630f, -0.136100575175706200f, 0.990590346218950150f, + -0.136860388636816380f, + 0.990485084256457090f, -0.137620121586486040f, 0.990379239617108160f, + -0.138379773577783890f, + 0.990272812363169110f, -0.139139344163826200f, 0.990165802557248400f, + -0.139898832897777210f, + 0.990058210262297120f, -0.140658239332849210f, 0.989950035541608990f, + -0.141417563022303020f, + 0.989841278458820530f, -0.142176803519448030f, 0.989731939077910570f, + -0.142935960377642670f, + 0.989622017463200890f, -0.143695033150294470f, 0.989511513679355190f, + -0.144454021390860470f, + 0.989400427791380380f, -0.145212924652847460f, 0.989288759864625170f, + -0.145971742489812210f, + 0.989176509964781010f, -0.146730474455361750f, 0.989063678157881540f, + -0.147489120103153570f, + 0.988950264510302990f, -0.148247678986896030f, 0.988836269088763540f, + -0.149006150660348450f, + 0.988721691960323780f, -0.149764534677321510f, 0.988606533192386450f, + -0.150522830591677400f, + 0.988490792852696590f, -0.151281037957330220f, 0.988374471009341280f, + -0.152039156328246050f, + 0.988257567730749460f, -0.152797185258443440f, 0.988140083085692570f, + -0.153555124301993450f, + 0.988022017143283530f, -0.154312973013020100f, 0.987903369972977790f, + -0.155070730945700510f, + 0.987784141644572180f, -0.155828397654265230f, 0.987664332228205710f, + -0.156585972692998430f, + 0.987543941794359230f, -0.157343455616238250f, 0.987422970413855410f, + -0.158100845978376980f, + 0.987301418157858430f, -0.158858143333861450f, 0.987179285097874340f, + -0.159615347237193060f, + 0.987056571305750970f, -0.160372457242928280f, 0.986933276853677710f, + -0.161129472905678810f, + 0.986809401814185530f, -0.161886393780111830f, 0.986684946260146690f, + -0.162643219420950310f, + 0.986559910264775410f, -0.163399949382973230f, 0.986434293901627180f, + -0.164156583221015810f, + 0.986308097244598670f, -0.164913120489969890f, 0.986181320367928270f, + -0.165669560744784120f, + 0.986053963346195440f, -0.166425903540464100f, 0.985926026254321130f, + -0.167182148432072940f, + 0.985797509167567480f, -0.167938294974731170f, 0.985668412161537550f, + -0.168694342723617330f, + 0.985538735312176060f, -0.169450291233967960f, 0.985408478695768420f, + -0.170206140061078070f, + 0.985277642388941220f, -0.170961888760301220f, 0.985146226468662230f, + -0.171717536887049970f, + 0.985014231012239840f, -0.172473083996795950f, 0.984881656097323700f, + -0.173228529645070320f, + 0.984748501801904210f, -0.173983873387463820f, 0.984614768204312600f, + -0.174739114779627200f, + 0.984480455383220930f, -0.175494253377271430f, 0.984345563417641900f, + -0.176249288736167880f, + 0.984210092386929030f, -0.177004220412148750f, 0.984074042370776450f, + -0.177759047961107170f, + 0.983937413449218920f, -0.178513770938997510f, 0.983800205702631600f, + -0.179268388901835750f, + 0.983662419211730250f, -0.180022901405699510f, 0.983524054057571260f, + -0.180777308006728590f, + 0.983385110321551180f, -0.181531608261124970f, 0.983245588085407070f, + -0.182285801725153300f, + 0.983105487431216290f, -0.183039887955140950f, 0.982964808441396440f, + -0.183793866507478450f, + 0.982823551198705240f, -0.184547736938619620f, 0.982681715786240860f, + -0.185301498805081900f, + 0.982539302287441240f, -0.186055151663446630f, 0.982396310786084690f, + -0.186808695070359270f, + 0.982252741366289370f, -0.187562128582529600f, 0.982108594112513610f, + -0.188315451756732120f, + 0.981963869109555240f, -0.189068664149806190f, 0.981818566442552500f, + -0.189821765318656410f, + 0.981672686196983110f, -0.190574754820252740f, 0.981526228458664770f, + -0.191327632211630900f, + 0.981379193313754560f, -0.192080397049892440f, 0.981231580848749730f, + -0.192833048892205230f, + 0.981083391150486710f, -0.193585587295803610f, 0.980934624306141640f, + -0.194338011817988600f, + 0.980785280403230430f, -0.195090322016128250f, 0.980635359529608120f, + -0.195842517447657850f, + 0.980484861773469380f, -0.196594597670080220f, 0.980333787223347960f, + -0.197346562240965920f, + 0.980182135968117430f, -0.198098410717953560f, 0.980029908096990090f, + -0.198850142658750090f, + 0.979877103699517640f, -0.199601757621130970f, 0.979723722865591170f, + -0.200353255162940450f, + 0.979569765685440520f, -0.201104634842091900f, 0.979415232249634780f, + -0.201855896216568050f, + 0.979260122649082020f, -0.202607038844421130f, 0.979104436975029250f, + -0.203358062283773320f, + 0.978948175319062200f, -0.204108966092816870f, 0.978791337773105670f, + -0.204859749829814420f, + 0.978633924429423210f, -0.205610413053099240f, 0.978475935380616830f, + -0.206360955321075510f, + 0.978317370719627650f, -0.207111376192218560f, 0.978158230539735050f, + -0.207861675225075070f, + 0.977998514934557140f, -0.208611851978263490f, 0.977838223998050430f, + -0.209361906010474160f, + 0.977677357824509930f, -0.210111836880469610f, 0.977515916508569280f, + -0.210861644147084860f, + 0.977353900145199960f, -0.211611327369227550f, 0.977191308829712280f, + -0.212360886105878420f, + 0.977028142657754390f, -0.213110319916091360f, 0.976864401725312640f, + -0.213859628358993750f, + 0.976700086128711840f, -0.214608810993786760f, 0.976535195964614470f, + -0.215357867379745550f, + 0.976369731330021140f, -0.216106797076219520f, 0.976203692322270560f, + -0.216855599642632620f, + 0.976037079039039020f, -0.217604274638483640f, 0.975869891578341030f, + -0.218352821623346320f, + 0.975702130038528570f, -0.219101240156869800f, 0.975533794518291360f, + -0.219849529798778700f, + 0.975364885116656980f, -0.220597690108873510f, 0.975195401932990370f, + -0.221345720647030810f, + 0.975025345066994120f, -0.222093620973203510f, 0.974854714618708430f, + -0.222841390647421120f, + 0.974683510688510670f, -0.223589029229789990f, 0.974511733377115720f, + -0.224336536280493600f, + 0.974339382785575860f, -0.225083911359792830f, 0.974166459015280320f, + -0.225831154028026170f, + 0.973992962167955830f, -0.226578263845610000f, 0.973818892345666100f, + -0.227325240373038860f, + 0.973644249650811980f, -0.228072083170885730f, 0.973469034186131070f, + -0.228818791799802220f, + 0.973293246054698250f, -0.229565365820518870f, 0.973116885359925130f, + -0.230311804793845440f, + 0.972939952205560180f, -0.231058108280671110f, 0.972762446695688570f, + -0.231804275841964780f, + 0.972584368934732210f, -0.232550307038775240f, 0.972405719027449770f, + -0.233296201432231590f, + 0.972226497078936270f, -0.234041958583543430f, 0.972046703194623500f, + -0.234787578054000970f, + 0.971866337480279400f, -0.235533059404975490f, 0.971685400042008540f, + -0.236278402197919570f, + 0.971503890986251780f, -0.237023605994367200f, 0.971321810419786160f, + -0.237768670355934190f, + 0.971139158449725090f, -0.238513594844318420f, 0.970955935183517970f, + -0.239258379021299980f, + 0.970772140728950350f, -0.240003022448741500f, 0.970587775194143630f, + -0.240747524688588430f, + 0.970402838687555500f, -0.241491885302869330f, 0.970217331317979160f, + -0.242236103853696010f, + 0.970031253194543970f, -0.242980179903263870f, 0.969844604426714830f, + -0.243724113013852160f, + 0.969657385124292450f, -0.244467902747824150f, 0.969469595397413060f, + -0.245211548667627540f, + 0.969281235356548530f, -0.245955050335794590f, 0.969092305112506210f, + -0.246698407314942410f, + 0.968902804776428870f, -0.247441619167773270f, 0.968712734459794780f, + -0.248184685457074780f, + 0.968522094274417380f, -0.248927605745720150f, 0.968330884332445190f, + -0.249670379596668570f, + 0.968139104746362440f, -0.250413006572965220f, 0.967946755628987800f, + -0.251155486237741920f, + 0.967753837093475510f, -0.251897818154216970f, 0.967560349253314360f, + -0.252640001885695520f, + 0.967366292222328510f, -0.253382036995570160f, 0.967171666114676640f, + -0.254123923047320620f, + 0.966976471044852070f, -0.254865659604514570f, 0.966780707127683270f, + -0.255607246230807380f, + 0.966584374478333120f, -0.256348682489942910f, 0.966387473212298900f, + -0.257089967945753120f, + 0.966190003445412500f, -0.257831102162158990f, 0.965991965293840570f, + -0.258572084703170340f, + 0.965793358874083680f, -0.259312915132886230f, 0.965594184302976830f, + -0.260053593015495190f, + 0.965394441697689400f, -0.260794117915275510f, 0.965194131175724720f, + -0.261534489396595520f, + 0.964993252854920320f, -0.262274707023913590f, 0.964791806853447900f, + -0.263014770361779000f, + 0.964589793289812760f, -0.263754678974831350f, 0.964387212282854290f, + -0.264494432427801630f, + 0.964184063951745830f, -0.265234030285511790f, 0.963980348415994110f, + -0.265973472112875590f, + 0.963776065795439840f, -0.266712757474898370f, 0.963571216210257320f, + -0.267451885936677620f, + 0.963365799780954050f, -0.268190857063403180f, 0.963159816628371360f, + -0.268929670420357260f, + 0.962953266873683880f, -0.269668325572915090f, 0.962746150638399410f, + -0.270406822086544820f, + 0.962538468044359160f, -0.271145159526808010f, 0.962330219213737400f, + -0.271883337459359720f, + 0.962121404269041580f, -0.272621355449948980f, 0.961912023333112210f, + -0.273359213064418680f, + 0.961702076529122540f, -0.274096909868706380f, 0.961491563980579000f, + -0.274834445428843940f, + 0.961280485811320640f, -0.275571819310958140f, 0.961068842145519350f, + -0.276309031081271080f, + 0.960856633107679660f, -0.277046080306099900f, 0.960643858822638590f, + -0.277782966551857690f, + 0.960430519415565790f, -0.278519689385053060f, 0.960216615011963430f, + -0.279256248372291180f, + 0.960002145737665960f, -0.279992643080273220f, 0.959787111718839900f, + -0.280728873075797190f, + 0.959571513081984520f, -0.281464937925757940f, 0.959355349953930790f, + -0.282200837197147560f, + 0.959138622461841890f, -0.282936570457055390f, 0.958921330733213170f, + -0.283672137272668430f, + 0.958703474895871600f, -0.284407537211271880f, 0.958485055077976100f, + -0.285142769840248670f, + 0.958266071408017670f, -0.285877834727080620f, 0.958046524014818600f, + -0.286612731439347790f, + 0.957826413027532910f, -0.287347459544729510f, 0.957605738575646350f, + -0.288082018611004130f, + 0.957384500788975860f, -0.288816408206049480f, 0.957162699797670210f, + -0.289550627897843030f, + 0.956940335732208820f, -0.290284677254462330f, 0.956717408723403050f, + -0.291018555844085090f, + 0.956493918902395100f, -0.291752263234989260f, 0.956269866400658030f, + -0.292485798995553880f, + 0.956045251349996410f, -0.293219162694258630f, 0.955820073882545420f, + -0.293952353899684660f, + 0.955594334130771110f, -0.294685372180514330f, 0.955368032227470350f, + -0.295418217105532010f, + 0.955141168305770780f, -0.296150888243623790f, 0.954913742499130520f, + -0.296883385163778270f, + 0.954685754941338340f, -0.297615707435086200f, 0.954457205766513490f, + -0.298347854626741400f, + 0.954228095109105670f, -0.299079826308040480f, 0.953998423103894490f, + -0.299811622048383350f, + 0.953768189885990330f, -0.300543241417273450f, 0.953537395590833280f, + -0.301274683984317950f, + 0.953306040354193860f, -0.302005949319228080f, 0.953074124312172200f, + -0.302737036991819140f, + 0.952841647601198720f, -0.303467946572011320f, 0.952608610358033350f, + -0.304198677629829110f, + 0.952375012719765880f, -0.304929229735402370f, 0.952140854823815830f, + -0.305659602458966120f, + 0.951906136807932350f, -0.306389795370860920f, 0.951670858810193860f, + -0.307119808041533100f, + 0.951435020969008340f, -0.307849640041534870f, 0.951198623423113230f, + -0.308579290941525090f, + 0.950961666311575080f, -0.309308760312268730f, 0.950724149773789610f, + -0.310038047724637890f, + 0.950486073949481700f, -0.310767152749611470f, 0.950247438978705230f, + -0.311496074958275910f, + 0.950008245001843000f, -0.312224813921824880f, 0.949768492159606680f, + -0.312953369211560200f, + 0.949528180593036670f, -0.313681740398891520f, 0.949287310443502120f, + -0.314409927055336660f, + 0.949045881852700560f, -0.315137928752522440f, 0.948803894962658490f, + -0.315865745062183960f, + 0.948561349915730270f, -0.316593375556165850f, 0.948318246854599090f, + -0.317320819806421740f, + 0.948074585922276230f, -0.318048077385014950f, 0.947830367262101010f, + -0.318775147864118480f, + 0.947585591017741090f, -0.319502030816015690f, 0.947340257333192050f, + -0.320228725813099860f, + 0.947094366352777220f, -0.320955232427875210f, 0.946847918221148000f, + -0.321681550232956580f, + 0.946600913083283530f, -0.322407678801069850f, 0.946353351084490590f, + -0.323133617705052330f, + 0.946105232370403450f, -0.323859366517852850f, 0.945856557086983910f, + -0.324584924812532150f, + 0.945607325380521280f, -0.325310292162262930f, 0.945357537397632290f, + -0.326035468140330240f, + 0.945107193285260610f, -0.326760452320131730f, 0.944856293190677210f, + -0.327485244275178000f, + 0.944604837261480260f, -0.328209843579092500f, 0.944352825645594750f, + -0.328934249805612200f, + 0.944100258491272660f, -0.329658462528587490f, 0.943847135947092690f, + -0.330382481321982780f, + 0.943593458161960390f, -0.331106305759876430f, 0.943339225285107720f, + -0.331829935416461110f, + 0.943084437466093490f, -0.332553369866044220f, 0.942829094854802710f, + -0.333276608683047930f, + 0.942573197601446870f, -0.333999651442009380f, 0.942316745856563780f, + -0.334722497717581220f, + 0.942059739771017310f, -0.335445147084531600f, 0.941802179495997650f, + -0.336167599117744520f, + 0.941544065183020810f, -0.336889853392220050f, 0.941285396983928660f, + -0.337611909483074620f, + 0.941026175050889260f, -0.338333766965541130f, 0.940766399536396070f, + -0.339055425414969640f, + 0.940506070593268300f, -0.339776884406826850f, 0.940245188374650880f, + -0.340498143516697160f, + 0.939983753034014050f, -0.341219202320282360f, 0.939721764725153340f, + -0.341940060393402190f, + 0.939459223602189920f, -0.342660717311994380f, 0.939196129819569900f, + -0.343381172652115040f, + 0.938932483532064600f, -0.344101425989938810f, 0.938668284894770170f, + -0.344821476901759290f, + 0.938403534063108060f, -0.345541324963989090f, 0.938138231192824360f, + -0.346260969753160010f, + 0.937872376439989890f, -0.346980410845923680f, 0.937605969960999990f, + -0.347699647819051380f, + 0.937339011912574960f, -0.348418680249434560f, 0.937071502451759190f, + -0.349137507714084970f, + 0.936803441735921560f, -0.349856129790134920f, 0.936534829922755500f, + -0.350574546054837510f, + 0.936265667170278260f, -0.351292756085567090f, 0.935995953636831410f, + -0.352010759459819080f, + 0.935725689481080370f, -0.352728555755210730f, 0.935454874862014620f, + -0.353446144549480810f, + 0.935183509938947610f, -0.354163525420490340f, 0.934911594871516090f, + -0.354880697946222790f, + 0.934639129819680780f, -0.355597661704783850f, 0.934366114943725790f, + -0.356314416274402410f, + 0.934092550404258980f, -0.357030961233429980f, 0.933818436362210960f, + -0.357747296160341900f, + 0.933543772978836170f, -0.358463420633736540f, 0.933268560415712050f, + -0.359179334232336500f, + 0.932992798834738960f, -0.359895036534988110f, 0.932716488398140250f, + -0.360610527120662270f, + 0.932439629268462360f, -0.361325805568454280f, 0.932162221608574430f, + -0.362040871457584180f, + 0.931884265581668150f, -0.362755724367397230f, 0.931605761351257830f, + -0.363470363877363760f, + 0.931326709081180430f, -0.364184789567079890f, 0.931047108935595280f, + -0.364899001016267320f, + 0.930766961078983710f, -0.365612997804773850f, 0.930486265676149780f, + -0.366326779512573590f, + 0.930205022892219070f, -0.367040345719767180f, 0.929923232892639670f, + -0.367753696006581980f, + 0.929640895843181330f, -0.368466829953372320f, 0.929358011909935500f, + -0.369179747140620020f, + 0.929074581259315860f, -0.369892447148934100f, 0.928790604058057020f, + -0.370604929559051670f, + 0.928506080473215590f, -0.371317193951837540f, 0.928221010672169440f, + -0.372029239908285010f, + 0.927935394822617890f, -0.372741067009515760f, 0.927649233092581180f, + -0.373452674836780300f, + 0.927362525650401110f, -0.374164062971457930f, 0.927075272664740100f, + -0.374875230995057540f, + 0.926787474304581750f, -0.375586178489217220f, 0.926499130739230510f, + -0.376296905035704790f, + 0.926210242138311380f, -0.377007410216418260f, 0.925920808671770070f, + -0.377717693613385640f, + 0.925630830509872720f, -0.378427754808765560f, 0.925340307823206310f, + -0.379137593384847320f, + 0.925049240782677580f, -0.379847208924051160f, 0.924757629559513910f, + -0.380556601008928520f, + 0.924465474325262600f, -0.381265769222162380f, 0.924172775251791200f, + -0.381974713146567220f, + 0.923879532511286740f, -0.382683432365089780f, 0.923585746276256670f, + -0.383391926460808660f, + 0.923291416719527640f, -0.384100195016935040f, 0.922996544014246250f, + -0.384808237616812880f, + 0.922701128333878630f, -0.385516053843918850f, 0.922405169852209880f, + -0.386223643281862980f, + 0.922108668743345180f, -0.386931005514388580f, 0.921811625181708120f, + -0.387638140125372730f, + 0.921514039342042010f, -0.388345046698826250f, 0.921215911399408730f, + -0.389051724818894380f, + 0.920917241529189520f, -0.389758174069856410f, 0.920618029907083970f, + -0.390464394036126590f, + 0.920318276709110590f, -0.391170384302253870f, 0.920017982111606570f, + -0.391876144452922350f, + 0.919717146291227360f, -0.392581674072951470f, 0.919415769424947070f, + -0.393286972747296400f, + 0.919113851690057770f, -0.393992040061048100f, 0.918811393264170050f, + -0.394696875599433560f, + 0.918508394325212250f, -0.395401478947816350f, 0.918204855051430900f, + -0.396105849691696270f, + 0.917900775621390500f, -0.396809987416710310f, 0.917596156213972950f, + -0.397513891708632330f, + 0.917290997008377910f, -0.398217562153373560f, 0.916985298184123000f, + -0.398920998336982910f, + 0.916679059921042700f, -0.399624199845646790f, 0.916372282399289140f, + -0.400327166265690090f, + 0.916064965799331720f, -0.401029897183575620f, 0.915757110301956720f, + -0.401732392185905010f, + 0.915448716088267830f, -0.402434650859418430f, 0.915139783339685260f, + -0.403136672790995300f, + 0.914830312237946200f, -0.403838457567654070f, 0.914520302965104450f, + -0.404540004776553000f, + 0.914209755703530690f, -0.405241314004989860f, 0.913898670635911680f, + -0.405942384840402510f, + 0.913587047945250810f, -0.406643216870369030f, 0.913274887814867760f, + -0.407343809682607970f, + 0.912962190428398210f, -0.408044162864978690f, 0.912648955969793900f, + -0.408744276005481360f, + 0.912335184623322750f, -0.409444148692257590f, 0.912020876573568340f, + -0.410143780513590240f, + 0.911706032005429880f, -0.410843171057903910f, 0.911390651104122430f, + -0.411542319913765220f, + 0.911074734055176360f, -0.412241226669882890f, 0.910758281044437570f, + -0.412939890915108080f, + 0.910441292258067250f, -0.413638312238434500f, 0.910123767882541680f, + -0.414336490228999100f, + 0.909805708104652220f, -0.415034424476081630f, 0.909487113111505430f, + -0.415732114569105360f, + 0.909167983090522380f, -0.416429560097637150f, 0.908848318229439120f, + -0.417126760651387870f, + 0.908528118716306120f, -0.417823715820212270f, 0.908207384739488700f, + -0.418520425194109700f, + 0.907886116487666260f, -0.419216888363223910f, 0.907564314149832630f, + -0.419913104917843620f, + 0.907241977915295820f, -0.420609074448402510f, 0.906919107973678140f, + -0.421304796545479640f, + 0.906595704514915330f, -0.422000270799799680f, 0.906271767729257660f, + -0.422695496802232950f, + 0.905947297807268460f, -0.423390474143796050f, 0.905622294939825270f, + -0.424085202415651560f, + 0.905296759318118820f, -0.424779681209108810f, 0.904970691133653250f, + -0.425473910115623800f, + 0.904644090578246240f, -0.426167888726799620f, 0.904316957844028320f, + -0.426861616634386430f, + 0.903989293123443340f, -0.427555093430282080f, 0.903661096609247980f, + -0.428248318706531960f, + 0.903332368494511820f, -0.428941292055329490f, 0.903003108972617150f, + -0.429634013069016380f, + 0.902673318237258830f, -0.430326481340082610f, 0.902342996482444200f, + -0.431018696461167030f, + 0.902012143902493180f, -0.431710658025057260f, 0.901680760692037730f, + -0.432402365624690140f, + 0.901348847046022030f, -0.433093818853151960f, 0.901016403159702330f, + -0.433785017303678520f, + 0.900683429228646970f, -0.434475960569655650f, 0.900349925448735600f, + -0.435166648244619260f, + 0.900015892016160280f, -0.435857079922255470f, 0.899681329127423930f, + -0.436547255196401200f, + 0.899346236979341570f, -0.437237173661044090f, 0.899010615769039070f, + -0.437926834910322860f, + 0.898674465693953820f, -0.438616238538527660f, 0.898337786951834310f, + -0.439305384140099950f, + 0.898000579740739880f, -0.439994271309633260f, 0.897662844259040860f, + -0.440682899641872900f, + 0.897324580705418320f, -0.441371268731716670f, 0.896985789278863970f, + -0.442059378174214700f, + 0.896646470178680150f, -0.442747227564570020f, 0.896306623604479550f, + -0.443434816498138480f, + 0.895966249756185220f, -0.444122144570429200f, 0.895625348834030110f, + -0.444809211377104880f, + 0.895283921038557580f, -0.445496016513981740f, 0.894941966570620750f, + -0.446182559577030070f, + 0.894599485631382700f, -0.446868840162374160f, 0.894256478422316040f, + -0.447554857866293010f, + 0.893912945145203250f, -0.448240612285219890f, 0.893568886002135910f, + -0.448926103015743260f, + 0.893224301195515320f, -0.449611329654606540f, 0.892879190928051680f, + -0.450296291798708610f, + 0.892533555402764580f, -0.450980989045103860f, 0.892187394822982480f, + -0.451665420991002490f, + 0.891840709392342720f, -0.452349587233770890f, 0.891493499314791380f, + -0.453033487370931580f, + 0.891145764794583180f, -0.453717121000163870f, 0.890797506036281490f, + -0.454400487719303580f, + 0.890448723244757880f, -0.455083587126343840f, 0.890099416625192320f, + -0.455766418819434640f, + 0.889749586383072780f, -0.456448982396883920f, 0.889399232724195520f, + -0.457131277457156980f, + 0.889048355854664570f, -0.457813303598877170f, 0.888696955980891600f, + -0.458495060420826270f, + 0.888345033309596350f, -0.459176547521944090f, 0.887992588047805560f, + -0.459857764501329540f, + 0.887639620402853930f, -0.460538710958240010f, 0.887286130582383150f, + -0.461219386492092380f, + 0.886932118794342190f, -0.461899790702462730f, 0.886577585246987040f, + -0.462579923189086810f, + 0.886222530148880640f, -0.463259783551860150f, 0.885866953708892790f, + -0.463939371390838520f, + 0.885510856136199950f, -0.464618686306237820f, 0.885154237640285110f, + -0.465297727898434600f, + 0.884797098430937790f, -0.465976495767966180f, 0.884439438718253810f, + -0.466654989515530920f, + 0.884081258712634990f, -0.467333208741988420f, 0.883722558624789660f, + -0.468011153048359830f, + 0.883363338665731580f, -0.468688822035827900f, 0.883003599046780830f, + -0.469366215305737520f, + 0.882643339979562790f, -0.470043332459595620f, 0.882282561676008710f, + -0.470720173099071600f, + 0.881921264348355050f, -0.471396736825997640f, 0.881559448209143780f, + -0.472073023242368660f, + 0.881197113471222090f, -0.472749031950342790f, 0.880834260347742040f, + -0.473424762552241530f, + 0.880470889052160750f, -0.474100214650549970f, 0.880106999798240360f, + -0.474775387847917120f, + 0.879742592800047410f, -0.475450281747155870f, 0.879377668271953290f, + -0.476124895951243580f, + 0.879012226428633530f, -0.476799230063322090f, 0.878646267485068130f, + -0.477473283686698060f, + 0.878279791656541580f, -0.478147056424843010f, 0.877912799158641840f, + -0.478820547881393890f, + 0.877545290207261350f, -0.479493757660153010f, 0.877177265018595940f, + -0.480166685365088390f, + 0.876808723809145650f, -0.480839330600333960f, 0.876439666795713610f, + -0.481511692970189860f, + 0.876070094195406600f, -0.482183772079122720f, 0.875700006225634600f, + -0.482855567531765670f, + 0.875329403104110890f, -0.483527078932918740f, 0.874958285048851650f, + -0.484198305887549030f, + 0.874586652278176110f, -0.484869248000791060f, 0.874214505010706300f, + -0.485539904877946960f, + 0.873841843465366860f, -0.486210276124486420f, 0.873468667861384880f, + -0.486880361346047340f, + 0.873094978418290090f, -0.487550160148436000f, 0.872720775355914300f, + -0.488219672137626790f, + 0.872346058894391540f, -0.488888896919763170f, 0.871970829254157810f, + -0.489557834101157440f, + 0.871595086655950980f, -0.490226483288291160f, 0.871218831320811020f, + -0.490894844087815090f, + 0.870842063470078980f, -0.491562916106549900f, 0.870464783325397670f, + -0.492230698951486020f, + 0.870086991108711460f, -0.492898192229784040f, 0.869708687042265670f, + -0.493565395548774770f, + 0.869329871348606840f, -0.494232308515959670f, 0.868950544250582380f, + -0.494898930739011260f, + 0.868570705971340900f, -0.495565261825772540f, 0.868190356734331310f, + -0.496231301384258250f, + 0.867809496763303320f, -0.496897049022654470f, 0.867428126282306920f, + -0.497562504349319150f, + 0.867046245515692650f, -0.498227666972781870f, 0.866663854688111130f, + -0.498892536501744590f, + 0.866280954024512990f, -0.499557112545081840f, 0.865897543750148820f, + -0.500221394711840680f, + 0.865513624090569090f, -0.500885382611240710f, 0.865129195271623800f, + -0.501549075852675390f, + 0.864744257519462380f, -0.502212474045710790f, 0.864358811060534030f, + -0.502875576800086990f, + 0.863972856121586810f, -0.503538383725717580f, 0.863586392929668100f, + -0.504200894432690340f, + 0.863199421712124160f, -0.504863108531267590f, 0.862811942696600330f, + -0.505525025631885390f, + 0.862423956111040610f, -0.506186645345155230f, 0.862035462183687210f, + -0.506847967281863210f, + 0.861646461143081300f, -0.507508991052970870f, 0.861256953218062170f, + -0.508169716269614600f, + 0.860866938637767310f, -0.508830142543106990f, 0.860476417631632070f, + -0.509490269484936360f, + 0.860085390429390140f, -0.510150096706766810f, 0.859693857261072610f, + -0.510809623820439040f, + 0.859301818357008470f, -0.511468850437970300f, 0.858909273947823900f, + -0.512127776171554690f, + 0.858516224264442740f, -0.512786400633562960f, 0.858122669538086140f, + -0.513444723436543460f, + 0.857728610000272120f, -0.514102744193221660f, 0.857334045882815590f, + -0.514760462516501200f, + 0.856938977417828760f, -0.515417878019462930f, 0.856543404837719960f, + -0.516074990315366630f, + 0.856147328375194470f, -0.516731799017649870f, 0.855750748263253920f, + -0.517388303739929060f, + 0.855353664735196030f, -0.518044504095999340f, 0.854956078024614930f, + -0.518700399699834950f, + 0.854557988365400530f, -0.519355990165589640f, 0.854159395991738850f, + -0.520011275107596040f, + 0.853760301138111410f, -0.520666254140367160f, 0.853360704039295430f, + -0.521320926878595660f, + 0.852960604930363630f, -0.521975292937154390f, 0.852560004046684080f, + -0.522629351931096610f, + 0.852158901623919830f, -0.523283103475656430f, 0.851757297898029120f, + -0.523936547186248600f, + 0.851355193105265200f, -0.524589682678468950f, 0.850952587482175730f, + -0.525242509568094710f, + 0.850549481265603480f, -0.525895027471084630f, 0.850145874692685210f, + -0.526547236003579440f, + 0.849741768000852550f, -0.527199134781901280f, 0.849337161427830780f, + -0.527850723422555230f, + 0.848932055211639610f, -0.528502001542228480f, 0.848526449590592650f, + -0.529152968757790610f, + 0.848120344803297230f, -0.529803624686294610f, 0.847713741088654380f, + -0.530453968944976320f, + 0.847306638685858320f, -0.531104001151255000f, 0.846899037834397240f, + -0.531753720922733320f, + 0.846490938774052130f, -0.532403127877197900f, 0.846082341744897050f, + -0.533052221632619450f, + 0.845673246987299070f, -0.533701001807152960f, 0.845263654741918220f, + -0.534349468019137520f, + 0.844853565249707120f, -0.534997619887097150f, 0.844442978751910660f, + -0.535645457029741090f, + 0.844031895490066410f, -0.536292979065963180f, 0.843620315706004150f, + -0.536940185614842910f, + 0.843208239641845440f, -0.537587076295645390f, 0.842795667540004120f, + -0.538233650727821700f, + 0.842382599643185850f, -0.538879908531008420f, 0.841969036194387680f, + -0.539525849325028890f, + 0.841554977436898440f, -0.540171472729892850f, 0.841140423614298080f, + -0.540816778365796670f, + 0.840725374970458070f, -0.541461765853123440f, 0.840309831749540770f, + -0.542106434812443920f, + 0.839893794195999520f, -0.542750784864515890f, 0.839477262554578550f, + -0.543394815630284800f, + 0.839060237070312740f, -0.544038526730883820f, 0.838642717988527300f, + -0.544681917787634530f, + 0.838224705554838080f, -0.545324988422046460f, 0.837806200015150940f, + -0.545967738255817570f, + 0.837387201615661940f, -0.546610166910834860f, 0.836967710602857020f, + -0.547252274009174090f, + 0.836547727223512010f, -0.547894059173100190f, 0.836127251724692270f, + -0.548535522025067390f, + 0.835706284353752600f, -0.549176662187719660f, 0.835284825358337370f, + -0.549817479283890910f, + 0.834862874986380010f, -0.550457972936604810f, 0.834440433486103190f, + -0.551098142769075430f, + 0.834017501106018130f, -0.551737988404707340f, 0.833594078094925140f, + -0.552377509467096070f, + 0.833170164701913190f, -0.553016705580027470f, 0.832745761176359460f, + -0.553655576367479310f, + 0.832320867767929680f, -0.554294121453620000f, 0.831895484726577590f, + -0.554932340462810370f, + 0.831469612302545240f, -0.555570233019602180f, 0.831043250746362320f, + -0.556207798748739930f, + 0.830616400308846310f, -0.556845037275160100f, 0.830189061241102370f, + -0.557481948223991550f, + 0.829761233794523050f, -0.558118531220556100f, 0.829332918220788250f, + -0.558754785890368310f, + 0.828904114771864870f, -0.559390711859136140f, 0.828474823700007130f, + -0.560026308752760380f, + 0.828045045257755800f, -0.560661576197336030f, 0.827614779697938400f, + -0.561296513819151470f, + 0.827184027273669130f, -0.561931121244689470f, 0.826752788238348520f, + -0.562565398100626560f, + 0.826321062845663530f, -0.563199344013834090f, 0.825888851349586780f, + -0.563832958611378170f, + 0.825456154004377550f, -0.564466241520519500f, 0.825022971064580220f, + -0.565099192368713980f, + 0.824589302785025290f, -0.565731810783613120f, 0.824155149420828570f, + -0.566364096393063840f, + 0.823720511227391430f, -0.566996048825108680f, 0.823285388460400110f, + -0.567627667707986230f, + 0.822849781375826430f, -0.568258952670131490f, 0.822413690229926390f, + -0.568889903340175860f, + 0.821977115279241550f, -0.569520519346947140f, 0.821540056780597610f, + -0.570150800319470300f, + 0.821102514991104650f, -0.570780745886967260f, 0.820664490168157460f, + -0.571410355678857230f, + 0.820225982569434690f, -0.572039629324757050f, 0.819786992452898990f, + -0.572668566454481160f, + 0.819347520076796900f, -0.573297166698042200f, 0.818907565699658950f, + -0.573925429685650750f, + 0.818467129580298660f, -0.574553355047715760f, 0.818026211977813440f, + -0.575180942414845080f, + 0.817584813151583710f, -0.575808191417845340f, 0.817142933361272970f, + -0.576435101687721830f, + 0.816700572866827850f, -0.577061672855679440f, 0.816257731928477390f, + -0.577687904553122800f, + 0.815814410806733780f, -0.578313796411655590f, 0.815370609762391290f, + -0.578939348063081780f, + 0.814926329056526620f, -0.579564559139405630f, 0.814481568950498610f, + -0.580189429272831680f, + 0.814036329705948410f, -0.580813958095764530f, 0.813590611584798510f, + -0.581438145240810170f, + 0.813144414849253590f, -0.582061990340775440f, 0.812697739761799490f, + -0.582685493028668460f, + 0.812250586585203880f, -0.583308652937698290f, 0.811802955582515470f, + -0.583931469701276180f, + 0.811354847017063730f, -0.584553942953015330f, 0.810906261152459670f, + -0.585176072326730410f, + 0.810457198252594770f, -0.585797857456438860f, 0.810007658581641140f, + -0.586419297976360500f, + 0.809557642404051260f, -0.587040393520917970f, 0.809107149984558240f, + -0.587661143724736660f, + 0.808656181588174980f, -0.588281548222645220f, 0.808204737480194720f, + -0.588901606649675720f, + 0.807752817926190360f, -0.589521318641063940f, 0.807300423192014450f, + -0.590140683832248820f, + 0.806847553543799330f, -0.590759701858874160f, 0.806394209247956240f, + -0.591378372356787580f, + 0.805940390571176280f, -0.591996694962040990f, 0.805486097780429230f, + -0.592614669310891130f, + 0.805031331142963660f, -0.593232295039799800f, 0.804576090926307110f, + -0.593849571785433630f, + 0.804120377398265810f, -0.594466499184664430f, 0.803664190826924090f, + -0.595083076874569960f, + 0.803207531480644940f, -0.595699304492433360f, 0.802750399628069160f, + -0.596315181675743710f, + 0.802292795538115720f, -0.596930708062196500f, 0.801834719479981310f, + -0.597545883289693160f, + 0.801376171723140240f, -0.598160706996342270f, 0.800917152537344300f, + -0.598775178820458720f, + 0.800457662192622820f, -0.599389298400564540f, 0.799997700959281910f, + -0.600003065375388940f, + 0.799537269107905010f, -0.600616479383868970f, 0.799076366909352350f, + -0.601229540065148500f, + 0.798614994634760820f, -0.601842247058580030f, 0.798153152555543750f, + -0.602454600003723750f, + 0.797690840943391160f, -0.603066598540348160f, 0.797228060070268810f, + -0.603678242308430370f, + 0.796764810208418830f, -0.604289530948155960f, 0.796301091630359110f, + -0.604900464099919820f, + 0.795836904608883570f, -0.605511041404325550f, 0.795372249417061310f, + -0.606121262502186120f, + 0.794907126328237010f, -0.606731127034524480f, 0.794441535616030590f, + -0.607340634642572930f, + 0.793975477554337170f, -0.607949784967773630f, 0.793508952417326660f, + -0.608558577651779450f, + 0.793041960479443640f, -0.609167012336453210f, 0.792574502015407690f, + -0.609775088663868430f, + 0.792106577300212390f, -0.610382806276309480f, 0.791638186609125880f, + -0.610990164816271660f, + 0.791169330217690200f, -0.611597163926461910f, 0.790700008401721610f, + -0.612203803249797950f, + 0.790230221437310030f, -0.612810082429409710f, 0.789759969600819070f, + -0.613416001108638590f, + 0.789289253168885650f, -0.614021558931038380f, 0.788818072418420280f, + -0.614626755540375050f, + 0.788346427626606340f, -0.615231590580626820f, 0.787874319070900220f, + -0.615836063695985090f, + 0.787401747029031430f, -0.616440174530853650f, 0.786928711779001810f, + -0.617043922729849760f, + 0.786455213599085770f, -0.617647307937803870f, 0.785981252767830150f, + -0.618250329799760250f, + 0.785506829564053930f, -0.618852987960976320f, 0.785031944266848080f, + -0.619455282066924020f, + 0.784556597155575240f, -0.620057211763289100f, 0.784080788509869950f, + -0.620658776695972140f, + 0.783604518609638200f, -0.621259976511087550f, 0.783127787735057310f, + -0.621860810854965360f, + 0.782650596166575730f, -0.622461279374149970f, 0.782172944184913010f, + -0.623061381715401260f, + 0.781694832071059390f, -0.623661117525694530f, 0.781216260106276090f, + -0.624260486452220650f, + 0.780737228572094490f, -0.624859488142386340f, 0.780257737750316590f, + -0.625458122243814360f, + 0.779777787923014550f, -0.626056388404343520f, 0.779297379372530300f, + -0.626654286272029350f, + 0.778816512381475980f, -0.627251815495144080f, 0.778335187232733210f, + -0.627848975722176460f, + 0.777853404209453150f, -0.628445766601832710f, 0.777371163595056310f, + -0.629042187783036000f, + 0.776888465673232440f, -0.629638238914926980f, 0.776405310727940390f, + -0.630233919646864370f, + 0.775921699043407690f, -0.630829229628424470f, 0.775437630904130540f, + -0.631424168509401860f, + 0.774953106594873930f, -0.632018735939809060f, 0.774468126400670860f, + -0.632612931569877410f, + 0.773982690606822900f, -0.633206755050057190f, 0.773496799498899050f, + -0.633800206031017280f, + 0.773010453362736990f, -0.634393284163645490f, 0.772523652484441330f, + -0.634985989099049460f, + 0.772036397150384520f, -0.635578320488556110f, 0.771548687647206300f, + -0.636170277983712170f, + 0.771060524261813820f, -0.636761861236284200f, 0.770571907281380810f, + -0.637353069898259130f, + 0.770082836993347900f, -0.637943903621844060f, 0.769593313685422940f, + -0.638534362059466790f, + 0.769103337645579700f, -0.639124444863775730f, 0.768612909162058380f, + -0.639714151687640450f, + 0.768122028523365420f, -0.640303482184151670f, 0.767630696018273380f, + -0.640892436006621380f, + 0.767138911935820400f, -0.641481012808583160f, 0.766646676565310380f, + -0.642069212243792540f, + 0.766153990196312920f, -0.642657033966226860f, 0.765660853118662500f, + -0.643244477630085850f, + 0.765167265622458960f, -0.643831542889791390f, 0.764673227998067140f, + -0.644418229399988380f, + 0.764178740536116670f, -0.645004536815543930f, 0.763683803527501870f, + -0.645590464791548690f, + 0.763188417263381270f, -0.646176012983316280f, 0.762692582035177980f, + -0.646761181046383920f, + 0.762196298134578900f, -0.647345968636512060f, 0.761699565853535380f, + -0.647930375409685340f, + 0.761202385484261780f, -0.648514401022112440f, 0.760704757319236920f, + -0.649098045130225950f, + 0.760206681651202420f, -0.649681307390683190f, 0.759708158773163440f, + -0.650264187460365850f, + 0.759209188978388070f, -0.650846684996380880f, 0.758709772560407390f, + -0.651428799656059820f, + 0.758209909813015280f, -0.652010531096959500f, 0.757709601030268080f, + -0.652591878976862440f, + 0.757208846506484570f, -0.653172842953776760f, 0.756707646536245670f, + -0.653753422685936060f, + 0.756206001414394540f, -0.654333617831800440f, 0.755703911436035880f, + -0.654913428050056030f, + 0.755201376896536550f, -0.655492852999615350f, 0.754698398091524500f, + -0.656071892339617600f, + 0.754194975316889170f, -0.656650545729428940f, 0.753691108868781210f, + -0.657228812828642540f, + 0.753186799043612520f, -0.657806693297078640f, 0.752682046138055340f, + -0.658384186794785050f, + 0.752176850449042810f, -0.658961292982037320f, 0.751671212273768430f, + -0.659538011519338660f, + 0.751165131909686480f, -0.660114342067420480f, 0.750658609654510700f, + -0.660690284287242300f, + 0.750151645806215070f, -0.661265837839992270f, 0.749644240663033480f, + -0.661841002387086870f, + 0.749136394523459370f, -0.662415777590171780f, 0.748628107686245440f, + -0.662990163111121470f, + 0.748119380450403600f, -0.663564158612039770f, 0.747610213115205150f, + -0.664137763755260010f, + 0.747100605980180130f, -0.664710978203344790f, 0.746590559345117310f, + -0.665283801619087180f, + 0.746080073510063780f, -0.665856233665509720f, 0.745569148775325430f, + -0.666428274005865240f, + 0.745057785441466060f, -0.666999922303637470f, 0.744545983809307370f, + -0.667571178222540310f, + 0.744033744179929290f, -0.668142041426518450f, 0.743521066854669120f, + -0.668712511579747980f, + 0.743007952135121720f, -0.669282588346636010f, 0.742494400323139180f, + -0.669852271391821020f, + 0.741980411720831070f, -0.670421560380173090f, 0.741465986630563290f, + -0.670990454976794220f, + 0.740951125354959110f, -0.671558954847018330f, 0.740435828196898020f, + -0.672127059656411730f, + 0.739920095459516200f, -0.672694769070772860f, 0.739403927446205760f, + -0.673262082756132970f, + 0.738887324460615110f, -0.673829000378756040f, 0.738370286806648620f, + -0.674395521605139050f, + 0.737852814788465980f, -0.674961646102011930f, 0.737334908710482910f, + -0.675527373536338520f, + 0.736816568877369900f, -0.676092703575315920f, 0.736297795594053170f, + -0.676657635886374950f, + 0.735778589165713590f, -0.677222170137180330f, 0.735258949897786840f, + -0.677786305995631500f, + 0.734738878095963500f, -0.678350043129861470f, 0.734218374066188280f, + -0.678913381208238410f, + 0.733697438114660370f, -0.679476319899364970f, 0.733176070547832740f, + -0.680038858872078930f, + 0.732654271672412820f, -0.680600997795453020f, 0.732132041795361290f, + -0.681162736338795430f, + 0.731609381223892630f, -0.681724074171649710f, 0.731086290265474340f, + -0.682285010963795570f, + 0.730562769227827590f, -0.682845546385248080f, 0.730038818418926260f, + -0.683405680106258680f, + 0.729514438146997010f, -0.683965411797315400f, 0.728989628720519420f, + -0.684524741129142300f, + 0.728464390448225200f, -0.685083667772700360f, 0.727938723639098620f, + -0.685642191399187470f, + 0.727412628602375770f, -0.686200311680038590f, 0.726886105647544970f, + -0.686758028286925890f, + 0.726359155084346010f, -0.687315340891759050f, 0.725831777222770370f, + -0.687872249166685550f, + 0.725303972373060770f, -0.688428752784090440f, 0.724775740845711280f, + -0.688984851416597040f, + 0.724247082951467000f, -0.689540544737066830f, 0.723717999001323500f, + -0.690095832418599950f, + 0.723188489306527460f, -0.690650714134534600f, 0.722658554178575610f, + -0.691205189558448450f, + 0.722128193929215350f, -0.691759258364157750f, 0.721597408870443770f, + -0.692312920225718220f, + 0.721066199314508110f, -0.692866174817424630f, 0.720534565573905270f, + -0.693419021813811760f, + 0.720002507961381650f, -0.693971460889654000f, 0.719470026789932990f, + -0.694523491719965520f, + 0.718937122372804490f, -0.695075113980000880f, 0.718403795023489830f, + -0.695626327345254870f, + 0.717870045055731710f, -0.696177131491462990f, 0.717335872783521730f, + -0.696727526094601200f, + 0.716801278521099540f, -0.697277510830886520f, 0.716266262582953120f, + -0.697827085376777290f, + 0.715730825283818590f, -0.698376249408972920f, 0.715194966938680120f, + -0.698925002604414150f, + 0.714658687862769090f, -0.699473344640283770f, 0.714121988371564820f, + -0.700021275194006250f, + 0.713584868780793640f, -0.700568793943248340f, 0.713047329406429340f, + -0.701115900565918660f, + 0.712509370564692320f, -0.701662594740168450f, 0.711970992572050100f, + -0.702208876144391870f, + 0.711432195745216430f, -0.702754744457225300f, 0.710892980401151680f, + -0.703300199357548730f, + 0.710353346857062420f, -0.703845240524484940f, 0.709813295430400840f, + -0.704389867637400410f, + 0.709272826438865690f, -0.704934080375904880f, 0.708731940200400650f, + -0.705477878419852100f, + 0.708190637033195400f, -0.706021261449339740f, 0.707648917255684350f, + -0.706564229144709510f, + 0.707106781186547570f, -0.707106781186547460f, 0.706564229144709620f, + -0.707648917255684350f, + 0.706021261449339740f, -0.708190637033195290f, 0.705477878419852210f, + -0.708731940200400650f, + 0.704934080375904990f, -0.709272826438865580f, 0.704389867637400410f, + -0.709813295430400840f, + 0.703845240524484940f, -0.710353346857062310f, 0.703300199357548730f, + -0.710892980401151680f, + 0.702754744457225300f, -0.711432195745216430f, 0.702208876144391870f, + -0.711970992572049990f, + 0.701662594740168570f, -0.712509370564692320f, 0.701115900565918660f, + -0.713047329406429230f, + 0.700568793943248450f, -0.713584868780793520f, 0.700021275194006360f, + -0.714121988371564710f, + 0.699473344640283770f, -0.714658687862768980f, 0.698925002604414150f, + -0.715194966938680010f, + 0.698376249408972920f, -0.715730825283818590f, 0.697827085376777290f, + -0.716266262582953120f, + 0.697277510830886630f, -0.716801278521099540f, 0.696727526094601200f, + -0.717335872783521730f, + 0.696177131491462990f, -0.717870045055731710f, 0.695626327345254870f, + -0.718403795023489720f, + 0.695075113980000880f, -0.718937122372804380f, 0.694523491719965520f, + -0.719470026789932990f, + 0.693971460889654000f, -0.720002507961381650f, 0.693419021813811880f, + -0.720534565573905270f, + 0.692866174817424740f, -0.721066199314508110f, 0.692312920225718220f, + -0.721597408870443660f, + 0.691759258364157750f, -0.722128193929215350f, 0.691205189558448450f, + -0.722658554178575610f, + 0.690650714134534720f, -0.723188489306527350f, 0.690095832418599950f, + -0.723717999001323390f, + 0.689540544737066940f, -0.724247082951466890f, 0.688984851416597150f, + -0.724775740845711280f, + 0.688428752784090550f, -0.725303972373060660f, 0.687872249166685550f, + -0.725831777222770370f, + 0.687315340891759160f, -0.726359155084346010f, 0.686758028286925890f, + -0.726886105647544970f, + 0.686200311680038700f, -0.727412628602375770f, 0.685642191399187470f, + -0.727938723639098620f, + 0.685083667772700360f, -0.728464390448225200f, 0.684524741129142300f, + -0.728989628720519310f, + 0.683965411797315510f, -0.729514438146996900f, 0.683405680106258790f, + -0.730038818418926150f, + 0.682845546385248080f, -0.730562769227827590f, 0.682285010963795570f, + -0.731086290265474230f, + 0.681724074171649820f, -0.731609381223892520f, 0.681162736338795430f, + -0.732132041795361290f, + 0.680600997795453130f, -0.732654271672412820f, 0.680038858872079040f, + -0.733176070547832740f, + 0.679476319899365080f, -0.733697438114660260f, 0.678913381208238410f, + -0.734218374066188170f, + 0.678350043129861580f, -0.734738878095963390f, 0.677786305995631500f, + -0.735258949897786730f, + 0.677222170137180450f, -0.735778589165713480f, 0.676657635886374950f, + -0.736297795594053060f, + 0.676092703575316030f, -0.736816568877369790f, 0.675527373536338630f, + -0.737334908710482790f, + 0.674961646102012040f, -0.737852814788465980f, 0.674395521605139050f, + -0.738370286806648510f, + 0.673829000378756150f, -0.738887324460615110f, 0.673262082756132970f, + -0.739403927446205760f, + 0.672694769070772970f, -0.739920095459516090f, 0.672127059656411840f, + -0.740435828196898020f, + 0.671558954847018330f, -0.740951125354959110f, 0.670990454976794220f, + -0.741465986630563290f, + 0.670421560380173090f, -0.741980411720830960f, 0.669852271391821130f, + -0.742494400323139180f, + 0.669282588346636010f, -0.743007952135121720f, 0.668712511579748090f, + -0.743521066854669120f, + 0.668142041426518560f, -0.744033744179929180f, 0.667571178222540310f, + -0.744545983809307250f, + 0.666999922303637470f, -0.745057785441465950f, 0.666428274005865350f, + -0.745569148775325430f, + 0.665856233665509720f, -0.746080073510063780f, 0.665283801619087180f, + -0.746590559345117310f, + 0.664710978203344900f, -0.747100605980180130f, 0.664137763755260010f, + -0.747610213115205150f, + 0.663564158612039880f, -0.748119380450403490f, 0.662990163111121470f, + -0.748628107686245330f, + 0.662415777590171780f, -0.749136394523459260f, 0.661841002387086870f, + -0.749644240663033480f, + 0.661265837839992270f, -0.750151645806214960f, 0.660690284287242300f, + -0.750658609654510590f, + 0.660114342067420480f, -0.751165131909686370f, 0.659538011519338770f, + -0.751671212273768430f, + 0.658961292982037320f, -0.752176850449042700f, 0.658384186794785050f, + -0.752682046138055230f, + 0.657806693297078640f, -0.753186799043612410f, 0.657228812828642650f, + -0.753691108868781210f, + 0.656650545729429050f, -0.754194975316889170f, 0.656071892339617710f, + -0.754698398091524390f, + 0.655492852999615460f, -0.755201376896536550f, 0.654913428050056150f, + -0.755703911436035880f, + 0.654333617831800550f, -0.756206001414394540f, 0.653753422685936170f, + -0.756707646536245670f, + 0.653172842953776760f, -0.757208846506484460f, 0.652591878976862550f, + -0.757709601030268080f, + 0.652010531096959500f, -0.758209909813015280f, 0.651428799656059820f, + -0.758709772560407390f, + 0.650846684996380990f, -0.759209188978387960f, 0.650264187460365960f, + -0.759708158773163440f, + 0.649681307390683190f, -0.760206681651202420f, 0.649098045130226060f, + -0.760704757319236920f, + 0.648514401022112550f, -0.761202385484261780f, 0.647930375409685460f, + -0.761699565853535270f, + 0.647345968636512060f, -0.762196298134578900f, 0.646761181046383920f, + -0.762692582035177870f, + 0.646176012983316390f, -0.763188417263381270f, 0.645590464791548800f, + -0.763683803527501870f, + 0.645004536815544040f, -0.764178740536116670f, 0.644418229399988380f, + -0.764673227998067140f, + 0.643831542889791500f, -0.765167265622458960f, 0.643244477630085850f, + -0.765660853118662390f, + 0.642657033966226860f, -0.766153990196312810f, 0.642069212243792540f, + -0.766646676565310380f, + 0.641481012808583160f, -0.767138911935820400f, 0.640892436006621380f, + -0.767630696018273270f, + 0.640303482184151670f, -0.768122028523365310f, 0.639714151687640450f, + -0.768612909162058270f, + 0.639124444863775730f, -0.769103337645579590f, 0.638534362059466790f, + -0.769593313685422940f, + 0.637943903621844170f, -0.770082836993347900f, 0.637353069898259130f, + -0.770571907281380700f, + 0.636761861236284200f, -0.771060524261813710f, 0.636170277983712170f, + -0.771548687647206300f, + 0.635578320488556230f, -0.772036397150384410f, 0.634985989099049460f, + -0.772523652484441330f, + 0.634393284163645490f, -0.773010453362736990f, 0.633800206031017280f, + -0.773496799498899050f, + 0.633206755050057190f, -0.773982690606822790f, 0.632612931569877520f, + -0.774468126400670860f, + 0.632018735939809060f, -0.774953106594873820f, 0.631424168509401860f, + -0.775437630904130430f, + 0.630829229628424470f, -0.775921699043407580f, 0.630233919646864480f, + -0.776405310727940390f, + 0.629638238914927100f, -0.776888465673232440f, 0.629042187783036000f, + -0.777371163595056200f, + 0.628445766601832710f, -0.777853404209453040f, 0.627848975722176570f, + -0.778335187232733090f, + 0.627251815495144190f, -0.778816512381475870f, 0.626654286272029460f, + -0.779297379372530300f, + 0.626056388404343520f, -0.779777787923014440f, 0.625458122243814360f, + -0.780257737750316590f, + 0.624859488142386450f, -0.780737228572094380f, 0.624260486452220650f, + -0.781216260106276090f, + 0.623661117525694640f, -0.781694832071059390f, 0.623061381715401370f, + -0.782172944184912900f, + 0.622461279374150080f, -0.782650596166575730f, 0.621860810854965360f, + -0.783127787735057310f, + 0.621259976511087660f, -0.783604518609638200f, 0.620658776695972140f, + -0.784080788509869950f, + 0.620057211763289210f, -0.784556597155575240f, 0.619455282066924020f, + -0.785031944266848080f, + 0.618852987960976320f, -0.785506829564053930f, 0.618250329799760250f, + -0.785981252767830150f, + 0.617647307937803980f, -0.786455213599085770f, 0.617043922729849760f, + -0.786928711779001700f, + 0.616440174530853650f, -0.787401747029031320f, 0.615836063695985090f, + -0.787874319070900110f, + 0.615231590580626820f, -0.788346427626606230f, 0.614626755540375050f, + -0.788818072418420170f, + 0.614021558931038490f, -0.789289253168885650f, 0.613416001108638590f, + -0.789759969600819070f, + 0.612810082429409710f, -0.790230221437310030f, 0.612203803249798060f, + -0.790700008401721610f, + 0.611597163926462020f, -0.791169330217690090f, 0.610990164816271770f, + -0.791638186609125770f, + 0.610382806276309480f, -0.792106577300212390f, 0.609775088663868430f, + -0.792574502015407580f, + 0.609167012336453210f, -0.793041960479443640f, 0.608558577651779450f, + -0.793508952417326660f, + 0.607949784967773740f, -0.793975477554337170f, 0.607340634642572930f, + -0.794441535616030590f, + 0.606731127034524480f, -0.794907126328237010f, 0.606121262502186230f, + -0.795372249417061190f, + 0.605511041404325550f, -0.795836904608883460f, 0.604900464099919930f, + -0.796301091630359110f, + 0.604289530948156070f, -0.796764810208418720f, 0.603678242308430370f, + -0.797228060070268700f, + 0.603066598540348280f, -0.797690840943391040f, 0.602454600003723860f, + -0.798153152555543750f, + 0.601842247058580030f, -0.798614994634760820f, 0.601229540065148620f, + -0.799076366909352350f, + 0.600616479383868970f, -0.799537269107905010f, 0.600003065375389060f, + -0.799997700959281910f, + 0.599389298400564540f, -0.800457662192622710f, 0.598775178820458720f, + -0.800917152537344300f, + 0.598160706996342380f, -0.801376171723140130f, 0.597545883289693270f, + -0.801834719479981310f, + 0.596930708062196500f, -0.802292795538115720f, 0.596315181675743820f, + -0.802750399628069160f, + 0.595699304492433470f, -0.803207531480644830f, 0.595083076874569960f, + -0.803664190826924090f, + 0.594466499184664540f, -0.804120377398265700f, 0.593849571785433630f, + -0.804576090926307000f, + 0.593232295039799800f, -0.805031331142963660f, 0.592614669310891130f, + -0.805486097780429120f, + 0.591996694962040990f, -0.805940390571176280f, 0.591378372356787580f, + -0.806394209247956240f, + 0.590759701858874280f, -0.806847553543799220f, 0.590140683832248940f, + -0.807300423192014450f, + 0.589521318641063940f, -0.807752817926190360f, 0.588901606649675840f, + -0.808204737480194720f, + 0.588281548222645330f, -0.808656181588174980f, 0.587661143724736770f, + -0.809107149984558130f, + 0.587040393520918080f, -0.809557642404051260f, 0.586419297976360500f, + -0.810007658581641140f, + 0.585797857456438860f, -0.810457198252594770f, 0.585176072326730410f, + -0.810906261152459670f, + 0.584553942953015330f, -0.811354847017063730f, 0.583931469701276300f, + -0.811802955582515360f, + 0.583308652937698290f, -0.812250586585203880f, 0.582685493028668460f, + -0.812697739761799490f, + 0.582061990340775550f, -0.813144414849253590f, 0.581438145240810280f, + -0.813590611584798510f, + 0.580813958095764530f, -0.814036329705948300f, 0.580189429272831680f, + -0.814481568950498610f, + 0.579564559139405740f, -0.814926329056526620f, 0.578939348063081890f, + -0.815370609762391290f, + 0.578313796411655590f, -0.815814410806733780f, 0.577687904553122800f, + -0.816257731928477390f, + 0.577061672855679550f, -0.816700572866827850f, 0.576435101687721830f, + -0.817142933361272970f, + 0.575808191417845340f, -0.817584813151583710f, 0.575180942414845190f, + -0.818026211977813440f, + 0.574553355047715760f, -0.818467129580298660f, 0.573925429685650750f, + -0.818907565699658950f, + 0.573297166698042320f, -0.819347520076796900f, 0.572668566454481160f, + -0.819786992452898990f, + 0.572039629324757050f, -0.820225982569434690f, 0.571410355678857340f, + -0.820664490168157460f, + 0.570780745886967370f, -0.821102514991104650f, 0.570150800319470300f, + -0.821540056780597610f, + 0.569520519346947250f, -0.821977115279241550f, 0.568889903340175970f, + -0.822413690229926390f, + 0.568258952670131490f, -0.822849781375826320f, 0.567627667707986230f, + -0.823285388460400110f, + 0.566996048825108680f, -0.823720511227391320f, 0.566364096393063950f, + -0.824155149420828570f, + 0.565731810783613230f, -0.824589302785025290f, 0.565099192368714090f, + -0.825022971064580220f, + 0.564466241520519500f, -0.825456154004377440f, 0.563832958611378170f, + -0.825888851349586780f, + 0.563199344013834090f, -0.826321062845663420f, 0.562565398100626560f, + -0.826752788238348520f, + 0.561931121244689470f, -0.827184027273669020f, 0.561296513819151470f, + -0.827614779697938400f, + 0.560661576197336030f, -0.828045045257755800f, 0.560026308752760380f, + -0.828474823700007130f, + 0.559390711859136140f, -0.828904114771864870f, 0.558754785890368310f, + -0.829332918220788250f, + 0.558118531220556100f, -0.829761233794523050f, 0.557481948223991660f, + -0.830189061241102370f, + 0.556845037275160100f, -0.830616400308846200f, 0.556207798748739930f, + -0.831043250746362320f, + 0.555570233019602290f, -0.831469612302545240f, 0.554932340462810370f, + -0.831895484726577590f, + 0.554294121453620110f, -0.832320867767929680f, 0.553655576367479310f, + -0.832745761176359460f, + 0.553016705580027580f, -0.833170164701913190f, 0.552377509467096070f, + -0.833594078094925140f, + 0.551737988404707450f, -0.834017501106018130f, 0.551098142769075430f, + -0.834440433486103190f, + 0.550457972936604810f, -0.834862874986380010f, 0.549817479283891020f, + -0.835284825358337370f, + 0.549176662187719770f, -0.835706284353752600f, 0.548535522025067390f, + -0.836127251724692160f, + 0.547894059173100190f, -0.836547727223511890f, 0.547252274009174090f, + -0.836967710602857020f, + 0.546610166910834860f, -0.837387201615661940f, 0.545967738255817680f, + -0.837806200015150940f, + 0.545324988422046460f, -0.838224705554837970f, 0.544681917787634530f, + -0.838642717988527300f, + 0.544038526730883930f, -0.839060237070312630f, 0.543394815630284800f, + -0.839477262554578550f, + 0.542750784864516000f, -0.839893794195999410f, 0.542106434812444030f, + -0.840309831749540770f, + 0.541461765853123560f, -0.840725374970458070f, 0.540816778365796670f, + -0.841140423614298080f, + 0.540171472729892970f, -0.841554977436898330f, 0.539525849325029010f, + -0.841969036194387680f, + 0.538879908531008420f, -0.842382599643185960f, 0.538233650727821700f, + -0.842795667540004120f, + 0.537587076295645510f, -0.843208239641845440f, 0.536940185614843020f, + -0.843620315706004040f, + 0.536292979065963180f, -0.844031895490066410f, 0.535645457029741090f, + -0.844442978751910660f, + 0.534997619887097260f, -0.844853565249707010f, 0.534349468019137520f, + -0.845263654741918220f, + 0.533701001807152960f, -0.845673246987299070f, 0.533052221632619670f, + -0.846082341744896940f, + 0.532403127877198010f, -0.846490938774052020f, 0.531753720922733320f, + -0.846899037834397350f, + 0.531104001151255000f, -0.847306638685858320f, 0.530453968944976320f, + -0.847713741088654270f, + 0.529803624686294830f, -0.848120344803297120f, 0.529152968757790720f, + -0.848526449590592650f, + 0.528502001542228480f, -0.848932055211639610f, 0.527850723422555460f, + -0.849337161427830670f, + 0.527199134781901390f, -0.849741768000852440f, 0.526547236003579330f, + -0.850145874692685210f, + 0.525895027471084740f, -0.850549481265603370f, 0.525242509568094710f, + -0.850952587482175730f, + 0.524589682678468840f, -0.851355193105265200f, 0.523936547186248600f, + -0.851757297898029120f, + 0.523283103475656430f, -0.852158901623919830f, 0.522629351931096720f, + -0.852560004046683970f, + 0.521975292937154390f, -0.852960604930363630f, 0.521320926878595550f, + -0.853360704039295430f, + 0.520666254140367270f, -0.853760301138111300f, 0.520011275107596040f, + -0.854159395991738730f, + 0.519355990165589530f, -0.854557988365400530f, 0.518700399699835170f, + -0.854956078024614820f, + 0.518044504095999340f, -0.855353664735196030f, 0.517388303739929060f, + -0.855750748263253920f, + 0.516731799017649980f, -0.856147328375194470f, 0.516074990315366630f, + -0.856543404837719960f, + 0.515417878019463150f, -0.856938977417828650f, 0.514760462516501200f, + -0.857334045882815590f, + 0.514102744193221660f, -0.857728610000272120f, 0.513444723436543570f, + -0.858122669538086020f, + 0.512786400633563070f, -0.858516224264442740f, 0.512127776171554690f, + -0.858909273947823900f, + 0.511468850437970520f, -0.859301818357008360f, 0.510809623820439040f, + -0.859693857261072610f, + 0.510150096706766700f, -0.860085390429390140f, 0.509490269484936360f, + -0.860476417631632070f, + 0.508830142543106990f, -0.860866938637767310f, 0.508169716269614710f, + -0.861256953218062060f, + 0.507508991052970870f, -0.861646461143081300f, 0.506847967281863320f, + -0.862035462183687210f, + 0.506186645345155450f, -0.862423956111040500f, 0.505525025631885510f, + -0.862811942696600330f, + 0.504863108531267480f, -0.863199421712124160f, 0.504200894432690560f, + -0.863586392929667990f, + 0.503538383725717580f, -0.863972856121586700f, 0.502875576800086880f, + -0.864358811060534030f, + 0.502212474045710900f, -0.864744257519462380f, 0.501549075852675390f, + -0.865129195271623690f, + 0.500885382611240940f, -0.865513624090568980f, 0.500221394711840680f, + -0.865897543750148820f, + 0.499557112545081890f, -0.866280954024512990f, 0.498892536501744750f, + -0.866663854688111020f, + 0.498227666972781870f, -0.867046245515692650f, 0.497562504349319090f, + -0.867428126282306920f, + 0.496897049022654640f, -0.867809496763303210f, 0.496231301384258310f, + -0.868190356734331310f, + 0.495565261825772490f, -0.868570705971340900f, 0.494898930739011310f, + -0.868950544250582380f, + 0.494232308515959730f, -0.869329871348606730f, 0.493565395548774880f, + -0.869708687042265560f, + 0.492898192229784090f, -0.870086991108711350f, 0.492230698951486080f, + -0.870464783325397670f, + 0.491562916106550060f, -0.870842063470078860f, 0.490894844087815140f, + -0.871218831320810900f, + 0.490226483288291100f, -0.871595086655951090f, 0.489557834101157550f, + -0.871970829254157700f, + 0.488888896919763230f, -0.872346058894391540f, 0.488219672137626740f, + -0.872720775355914300f, + 0.487550160148436050f, -0.873094978418290090f, 0.486880361346047400f, + -0.873468667861384880f, + 0.486210276124486530f, -0.873841843465366750f, 0.485539904877947020f, + -0.874214505010706300f, + 0.484869248000791120f, -0.874586652278176110f, 0.484198305887549140f, + -0.874958285048851540f, + 0.483527078932918740f, -0.875329403104110780f, 0.482855567531765670f, + -0.875700006225634600f, + 0.482183772079122830f, -0.876070094195406600f, 0.481511692970189920f, + -0.876439666795713610f, + 0.480839330600333900f, -0.876808723809145760f, 0.480166685365088440f, + -0.877177265018595940f, + 0.479493757660153010f, -0.877545290207261240f, 0.478820547881394050f, + -0.877912799158641730f, + 0.478147056424843120f, -0.878279791656541460f, 0.477473283686698060f, + -0.878646267485068130f, + 0.476799230063322250f, -0.879012226428633410f, 0.476124895951243630f, + -0.879377668271953180f, + 0.475450281747155870f, -0.879742592800047410f, 0.474775387847917230f, + -0.880106999798240360f, + 0.474100214650550020f, -0.880470889052160750f, 0.473424762552241530f, + -0.880834260347742040f, + 0.472749031950342900f, -0.881197113471221980f, 0.472073023242368660f, + -0.881559448209143780f, + 0.471396736825997810f, -0.881921264348354940f, 0.470720173099071710f, + -0.882282561676008600f, + 0.470043332459595620f, -0.882643339979562790f, 0.469366215305737630f, + -0.883003599046780720f, + 0.468688822035827960f, -0.883363338665731580f, 0.468011153048359830f, + -0.883722558624789660f, + 0.467333208741988530f, -0.884081258712634990f, 0.466654989515530970f, + -0.884439438718253700f, + 0.465976495767966130f, -0.884797098430937790f, 0.465297727898434650f, + -0.885154237640285110f, + 0.464618686306237820f, -0.885510856136199950f, 0.463939371390838460f, + -0.885866953708892790f, + 0.463259783551860260f, -0.886222530148880640f, 0.462579923189086810f, + -0.886577585246987040f, + 0.461899790702462840f, -0.886932118794342080f, 0.461219386492092430f, + -0.887286130582383150f, + 0.460538710958240010f, -0.887639620402853930f, 0.459857764501329650f, + -0.887992588047805560f, + 0.459176547521944150f, -0.888345033309596240f, 0.458495060420826220f, + -0.888696955980891710f, + 0.457813303598877290f, -0.889048355854664570f, 0.457131277457156980f, + -0.889399232724195520f, + 0.456448982396883860f, -0.889749586383072890f, 0.455766418819434750f, + -0.890099416625192210f, + 0.455083587126343840f, -0.890448723244757880f, 0.454400487719303750f, + -0.890797506036281490f, + 0.453717121000163930f, -0.891145764794583180f, 0.453033487370931580f, + -0.891493499314791380f, + 0.452349587233771000f, -0.891840709392342720f, 0.451665420991002540f, + -0.892187394822982480f, + 0.450980989045103810f, -0.892533555402764690f, 0.450296291798708730f, + -0.892879190928051680f, + 0.449611329654606600f, -0.893224301195515320f, 0.448926103015743260f, + -0.893568886002136020f, + 0.448240612285220000f, -0.893912945145203250f, 0.447554857866293010f, + -0.894256478422316040f, + 0.446868840162374330f, -0.894599485631382580f, 0.446182559577030120f, + -0.894941966570620750f, + 0.445496016513981740f, -0.895283921038557580f, 0.444809211377105000f, + -0.895625348834030000f, + 0.444122144570429260f, -0.895966249756185110f, 0.443434816498138430f, + -0.896306623604479660f, + 0.442747227564570130f, -0.896646470178680150f, 0.442059378174214760f, + -0.896985789278863970f, + 0.441371268731716620f, -0.897324580705418320f, 0.440682899641873020f, + -0.897662844259040750f, + 0.439994271309633260f, -0.898000579740739880f, 0.439305384140100060f, + -0.898337786951834190f, + 0.438616238538527710f, -0.898674465693953820f, 0.437926834910322860f, + -0.899010615769039070f, + 0.437237173661044200f, -0.899346236979341460f, 0.436547255196401250f, + -0.899681329127423930f, + 0.435857079922255470f, -0.900015892016160280f, 0.435166648244619370f, + -0.900349925448735600f, + 0.434475960569655710f, -0.900683429228646860f, 0.433785017303678520f, + -0.901016403159702330f, + 0.433093818853152010f, -0.901348847046022030f, 0.432402365624690140f, + -0.901680760692037730f, + 0.431710658025057370f, -0.902012143902493070f, 0.431018696461167080f, + -0.902342996482444200f, + 0.430326481340082610f, -0.902673318237258830f, 0.429634013069016500f, + -0.903003108972617040f, + 0.428941292055329550f, -0.903332368494511820f, 0.428248318706531910f, + -0.903661096609247980f, + 0.427555093430282200f, -0.903989293123443340f, 0.426861616634386490f, + -0.904316957844028320f, + 0.426167888726799620f, -0.904644090578246240f, 0.425473910115623910f, + -0.904970691133653250f, + 0.424779681209108810f, -0.905296759318118820f, 0.424085202415651670f, + -0.905622294939825160f, + 0.423390474143796100f, -0.905947297807268460f, 0.422695496802232950f, + -0.906271767729257660f, + 0.422000270799799790f, -0.906595704514915330f, 0.421304796545479700f, + -0.906919107973678030f, + 0.420609074448402510f, -0.907241977915295930f, 0.419913104917843730f, + -0.907564314149832520f, + 0.419216888363223960f, -0.907886116487666150f, 0.418520425194109700f, + -0.908207384739488700f, + 0.417823715820212380f, -0.908528118716306120f, 0.417126760651387870f, + -0.908848318229439120f, + 0.416429560097637320f, -0.909167983090522270f, 0.415732114569105420f, + -0.909487113111505430f, + 0.415034424476081630f, -0.909805708104652220f, 0.414336490228999210f, + -0.910123767882541570f, + 0.413638312238434560f, -0.910441292258067140f, 0.412939890915108020f, + -0.910758281044437570f, + 0.412241226669883000f, -0.911074734055176250f, 0.411542319913765280f, + -0.911390651104122320f, + 0.410843171057903910f, -0.911706032005429880f, 0.410143780513590350f, + -0.912020876573568230f, + 0.409444148692257590f, -0.912335184623322750f, 0.408744276005481520f, + -0.912648955969793900f, + 0.408044162864978740f, -0.912962190428398100f, 0.407343809682607970f, + -0.913274887814867760f, + 0.406643216870369140f, -0.913587047945250810f, 0.405942384840402570f, + -0.913898670635911680f, + 0.405241314004989860f, -0.914209755703530690f, 0.404540004776553110f, + -0.914520302965104450f, + 0.403838457567654130f, -0.914830312237946090f, 0.403136672790995240f, + -0.915139783339685260f, + 0.402434650859418540f, -0.915448716088267830f, 0.401732392185905010f, + -0.915757110301956720f, + 0.401029897183575790f, -0.916064965799331610f, 0.400327166265690150f, + -0.916372282399289140f, + 0.399624199845646790f, -0.916679059921042700f, 0.398920998336983020f, + -0.916985298184122890f, + 0.398217562153373620f, -0.917290997008377910f, 0.397513891708632330f, + -0.917596156213972950f, + 0.396809987416710420f, -0.917900775621390390f, 0.396105849691696320f, + -0.918204855051430900f, + 0.395401478947816300f, -0.918508394325212250f, 0.394696875599433670f, + -0.918811393264169940f, + 0.393992040061048100f, -0.919113851690057770f, 0.393286972747296570f, + -0.919415769424946960f, + 0.392581674072951530f, -0.919717146291227360f, 0.391876144452922350f, + -0.920017982111606570f, + 0.391170384302253980f, -0.920318276709110480f, 0.390464394036126650f, + -0.920618029907083860f, + 0.389758174069856410f, -0.920917241529189520f, 0.389051724818894500f, + -0.921215911399408730f, + 0.388345046698826300f, -0.921514039342041900f, 0.387638140125372680f, + -0.921811625181708120f, + 0.386931005514388690f, -0.922108668743345070f, 0.386223643281862980f, + -0.922405169852209880f, + 0.385516053843919020f, -0.922701128333878520f, 0.384808237616812930f, + -0.922996544014246250f, + 0.384100195016935040f, -0.923291416719527640f, 0.383391926460808770f, + -0.923585746276256560f, + 0.382683432365089840f, -0.923879532511286740f, 0.381974713146567220f, + -0.924172775251791200f, + 0.381265769222162490f, -0.924465474325262600f, 0.380556601008928570f, + -0.924757629559513910f, + 0.379847208924051110f, -0.925049240782677580f, 0.379137593384847430f, + -0.925340307823206200f, + 0.378427754808765620f, -0.925630830509872720f, 0.377717693613385810f, + -0.925920808671769960f, + 0.377007410216418310f, -0.926210242138311270f, 0.376296905035704790f, + -0.926499130739230510f, + 0.375586178489217330f, -0.926787474304581750f, 0.374875230995057600f, + -0.927075272664740100f, + 0.374164062971457990f, -0.927362525650401110f, 0.373452674836780410f, + -0.927649233092581180f, + 0.372741067009515810f, -0.927935394822617890f, 0.372029239908284960f, + -0.928221010672169440f, + 0.371317193951837600f, -0.928506080473215480f, 0.370604929559051670f, + -0.928790604058057020f, + 0.369892447148934270f, -0.929074581259315750f, 0.369179747140620070f, + -0.929358011909935500f, + 0.368466829953372320f, -0.929640895843181330f, 0.367753696006582090f, + -0.929923232892639560f, + 0.367040345719767240f, -0.930205022892219070f, 0.366326779512573590f, + -0.930486265676149780f, + 0.365612997804773960f, -0.930766961078983710f, 0.364899001016267380f, + -0.931047108935595170f, + 0.364184789567079840f, -0.931326709081180430f, 0.363470363877363870f, + -0.931605761351257830f, + 0.362755724367397230f, -0.931884265581668150f, 0.362040871457584350f, + -0.932162221608574320f, + 0.361325805568454340f, -0.932439629268462360f, 0.360610527120662270f, + -0.932716488398140250f, + 0.359895036534988280f, -0.932992798834738850f, 0.359179334232336560f, + -0.933268560415712050f, + 0.358463420633736540f, -0.933543772978836170f, 0.357747296160342010f, + -0.933818436362210960f, + 0.357030961233430030f, -0.934092550404258870f, 0.356314416274402360f, + -0.934366114943725900f, + 0.355597661704783960f, -0.934639129819680780f, 0.354880697946222790f, + -0.934911594871516090f, + 0.354163525420490510f, -0.935183509938947500f, 0.353446144549480870f, + -0.935454874862014620f, + 0.352728555755210730f, -0.935725689481080370f, 0.352010759459819240f, + -0.935995953636831300f, + 0.351292756085567150f, -0.936265667170278260f, 0.350574546054837570f, + -0.936534829922755500f, + 0.349856129790135030f, -0.936803441735921560f, 0.349137507714085030f, + -0.937071502451759190f, + 0.348418680249434510f, -0.937339011912574960f, 0.347699647819051490f, + -0.937605969960999990f, + 0.346980410845923680f, -0.937872376439989890f, 0.346260969753160170f, + -0.938138231192824360f, + 0.345541324963989150f, -0.938403534063108060f, 0.344821476901759290f, + -0.938668284894770170f, + 0.344101425989938980f, -0.938932483532064490f, 0.343381172652115100f, + -0.939196129819569900f, + 0.342660717311994380f, -0.939459223602189920f, 0.341940060393402300f, + -0.939721764725153340f, + 0.341219202320282410f, -0.939983753034013940f, 0.340498143516697100f, + -0.940245188374650880f, + 0.339776884406826960f, -0.940506070593268300f, 0.339055425414969640f, + -0.940766399536396070f, + 0.338333766965541290f, -0.941026175050889260f, 0.337611909483074680f, + -0.941285396983928660f, + 0.336889853392220050f, -0.941544065183020810f, 0.336167599117744690f, + -0.941802179495997650f, + 0.335445147084531660f, -0.942059739771017310f, 0.334722497717581220f, + -0.942316745856563780f, + 0.333999651442009490f, -0.942573197601446870f, 0.333276608683047980f, + -0.942829094854802710f, + 0.332553369866044220f, -0.943084437466093490f, 0.331829935416461220f, + -0.943339225285107720f, + 0.331106305759876430f, -0.943593458161960390f, 0.330382481321982950f, + -0.943847135947092690f, + 0.329658462528587550f, -0.944100258491272660f, 0.328934249805612200f, + -0.944352825645594750f, + 0.328209843579092660f, -0.944604837261480260f, 0.327485244275178060f, + -0.944856293190677210f, + 0.326760452320131790f, -0.945107193285260610f, 0.326035468140330350f, + -0.945357537397632290f, + 0.325310292162262980f, -0.945607325380521280f, 0.324584924812532150f, + -0.945856557086983910f, + 0.323859366517852960f, -0.946105232370403340f, 0.323133617705052330f, + -0.946353351084490590f, + 0.322407678801070020f, -0.946600913083283530f, 0.321681550232956640f, + -0.946847918221148000f, + 0.320955232427875210f, -0.947094366352777220f, 0.320228725813100020f, + -0.947340257333191940f, + 0.319502030816015750f, -0.947585591017741090f, 0.318775147864118480f, + -0.947830367262101010f, + 0.318048077385015060f, -0.948074585922276230f, 0.317320819806421790f, + -0.948318246854599090f, + 0.316593375556165850f, -0.948561349915730270f, 0.315865745062184070f, + -0.948803894962658380f, + 0.315137928752522440f, -0.949045881852700560f, 0.314409927055336820f, + -0.949287310443502010f, + 0.313681740398891570f, -0.949528180593036670f, 0.312953369211560200f, + -0.949768492159606680f, + 0.312224813921825050f, -0.950008245001843000f, 0.311496074958275970f, + -0.950247438978705230f, + 0.310767152749611470f, -0.950486073949481700f, 0.310038047724638000f, + -0.950724149773789610f, + 0.309308760312268780f, -0.950961666311575080f, 0.308579290941525030f, + -0.951198623423113230f, + 0.307849640041534980f, -0.951435020969008340f, 0.307119808041533100f, + -0.951670858810193860f, + 0.306389795370861080f, -0.951906136807932230f, 0.305659602458966230f, + -0.952140854823815830f, + 0.304929229735402430f, -0.952375012719765880f, 0.304198677629829270f, + -0.952608610358033240f, + 0.303467946572011370f, -0.952841647601198720f, 0.302737036991819140f, + -0.953074124312172200f, + 0.302005949319228200f, -0.953306040354193750f, 0.301274683984318000f, + -0.953537395590833280f, + 0.300543241417273400f, -0.953768189885990330f, 0.299811622048383460f, + -0.953998423103894490f, + 0.299079826308040480f, -0.954228095109105670f, 0.298347854626741570f, + -0.954457205766513490f, + 0.297615707435086310f, -0.954685754941338340f, 0.296883385163778270f, + -0.954913742499130520f, + 0.296150888243623960f, -0.955141168305770670f, 0.295418217105532070f, + -0.955368032227470240f, + 0.294685372180514330f, -0.955594334130771110f, 0.293952353899684770f, + -0.955820073882545420f, + 0.293219162694258680f, -0.956045251349996410f, 0.292485798995553830f, + -0.956269866400658140f, + 0.291752263234989370f, -0.956493918902394990f, 0.291018555844085090f, + -0.956717408723403050f, + 0.290284677254462330f, -0.956940335732208940f, 0.289550627897843140f, + -0.957162699797670100f, + 0.288816408206049480f, -0.957384500788975860f, 0.288082018611004300f, + -0.957605738575646240f, + 0.287347459544729570f, -0.957826413027532910f, 0.286612731439347790f, + -0.958046524014818600f, + 0.285877834727080730f, -0.958266071408017670f, 0.285142769840248720f, + -0.958485055077976100f, + 0.284407537211271820f, -0.958703474895871600f, 0.283672137272668550f, + -0.958921330733213060f, + 0.282936570457055390f, -0.959138622461841890f, 0.282200837197147500f, + -0.959355349953930790f, + 0.281464937925758050f, -0.959571513081984520f, 0.280728873075797190f, + -0.959787111718839900f, + 0.279992643080273380f, -0.960002145737665850f, 0.279256248372291240f, + -0.960216615011963430f, + 0.278519689385053060f, -0.960430519415565790f, 0.277782966551857800f, + -0.960643858822638470f, + 0.277046080306099950f, -0.960856633107679660f, 0.276309031081271030f, + -0.961068842145519350f, + 0.275571819310958250f, -0.961280485811320640f, 0.274834445428843940f, + -0.961491563980579000f, + 0.274096909868706330f, -0.961702076529122540f, 0.273359213064418790f, + -0.961912023333112100f, + 0.272621355449948980f, -0.962121404269041580f, 0.271883337459359890f, + -0.962330219213737400f, + 0.271145159526808070f, -0.962538468044359160f, 0.270406822086544820f, + -0.962746150638399410f, + 0.269668325572915200f, -0.962953266873683880f, 0.268929670420357310f, + -0.963159816628371360f, + 0.268190857063403180f, -0.963365799780954050f, 0.267451885936677740f, + -0.963571216210257210f, + 0.266712757474898420f, -0.963776065795439840f, 0.265973472112875530f, + -0.963980348415994110f, + 0.265234030285511900f, -0.964184063951745720f, 0.264494432427801630f, + -0.964387212282854290f, + 0.263754678974831510f, -0.964589793289812650f, 0.263014770361779060f, + -0.964791806853447900f, + 0.262274707023913590f, -0.964993252854920320f, 0.261534489396595630f, + -0.965194131175724720f, + 0.260794117915275570f, -0.965394441697689400f, 0.260053593015495130f, + -0.965594184302976830f, + 0.259312915132886350f, -0.965793358874083570f, 0.258572084703170390f, + -0.965991965293840570f, + 0.257831102162158930f, -0.966190003445412620f, 0.257089967945753230f, + -0.966387473212298790f, + 0.256348682489942910f, -0.966584374478333120f, 0.255607246230807550f, + -0.966780707127683270f, + 0.254865659604514630f, -0.966976471044852070f, 0.254123923047320620f, + -0.967171666114676640f, + 0.253382036995570270f, -0.967366292222328510f, 0.252640001885695580f, + -0.967560349253314360f, + 0.251897818154216910f, -0.967753837093475510f, 0.251155486237742030f, + -0.967946755628987800f, + 0.250413006572965280f, -0.968139104746362330f, 0.249670379596668520f, + -0.968330884332445300f, + 0.248927605745720260f, -0.968522094274417270f, 0.248184685457074780f, + -0.968712734459794780f, + 0.247441619167773440f, -0.968902804776428870f, 0.246698407314942500f, + -0.969092305112506100f, + 0.245955050335794590f, -0.969281235356548530f, 0.245211548667627680f, + -0.969469595397412950f, + 0.244467902747824210f, -0.969657385124292450f, 0.243724113013852130f, + -0.969844604426714830f, + 0.242980179903263980f, -0.970031253194543970f, 0.242236103853696070f, + -0.970217331317979160f, + 0.241491885302869300f, -0.970402838687555500f, 0.240747524688588540f, + -0.970587775194143630f, + 0.240003022448741500f, -0.970772140728950350f, 0.239258379021300120f, + -0.970955935183517970f, + 0.238513594844318500f, -0.971139158449725090f, 0.237768670355934210f, + -0.971321810419786160f, + 0.237023605994367340f, -0.971503890986251780f, 0.236278402197919620f, + -0.971685400042008540f, + 0.235533059404975460f, -0.971866337480279400f, 0.234787578054001080f, + -0.972046703194623500f, + 0.234041958583543460f, -0.972226497078936270f, 0.233296201432231560f, + -0.972405719027449770f, + 0.232550307038775330f, -0.972584368934732210f, 0.231804275841964780f, + -0.972762446695688570f, + 0.231058108280671280f, -0.972939952205560070f, 0.230311804793845530f, + -0.973116885359925130f, + 0.229565365820518870f, -0.973293246054698250f, 0.228818791799802360f, + -0.973469034186130950f, + 0.228072083170885790f, -0.973644249650811870f, 0.227325240373038830f, + -0.973818892345666100f, + 0.226578263845610110f, -0.973992962167955830f, 0.225831154028026200f, + -0.974166459015280320f, + 0.225083911359792780f, -0.974339382785575860f, 0.224336536280493690f, + -0.974511733377115720f, + 0.223589029229790020f, -0.974683510688510670f, 0.222841390647421280f, + -0.974854714618708430f, + 0.222093620973203590f, -0.975025345066994120f, 0.221345720647030810f, + -0.975195401932990370f, + 0.220597690108873650f, -0.975364885116656870f, 0.219849529798778750f, + -0.975533794518291360f, + 0.219101240156869770f, -0.975702130038528570f, 0.218352821623346430f, + -0.975869891578341030f, + 0.217604274638483670f, -0.976037079039039020f, 0.216855599642632570f, + -0.976203692322270560f, + 0.216106797076219600f, -0.976369731330021140f, 0.215357867379745550f, + -0.976535195964614470f, + 0.214608810993786920f, -0.976700086128711840f, 0.213859628358993830f, + -0.976864401725312640f, + 0.213110319916091360f, -0.977028142657754390f, 0.212360886105878580f, + -0.977191308829712280f, + 0.211611327369227610f, -0.977353900145199960f, 0.210861644147084830f, + -0.977515916508569280f, + 0.210111836880469720f, -0.977677357824509930f, 0.209361906010474190f, + -0.977838223998050430f, + 0.208611851978263460f, -0.977998514934557140f, 0.207861675225075150f, + -0.978158230539735050f, + 0.207111376192218560f, -0.978317370719627650f, 0.206360955321075680f, + -0.978475935380616830f, + 0.205610413053099320f, -0.978633924429423100f, 0.204859749829814420f, + -0.978791337773105670f, + 0.204108966092817010f, -0.978948175319062200f, 0.203358062283773370f, + -0.979104436975029250f, + 0.202607038844421110f, -0.979260122649082020f, 0.201855896216568160f, + -0.979415232249634780f, + 0.201104634842091960f, -0.979569765685440520f, 0.200353255162940420f, + -0.979723722865591170f, + 0.199601757621131050f, -0.979877103699517640f, 0.198850142658750120f, + -0.980029908096989980f, + 0.198098410717953730f, -0.980182135968117320f, 0.197346562240966000f, + -0.980333787223347960f, + 0.196594597670080220f, -0.980484861773469380f, 0.195842517447657990f, + -0.980635359529608120f, + 0.195090322016128330f, -0.980785280403230430f, 0.194338011817988600f, + -0.980934624306141640f, + 0.193585587295803750f, -0.981083391150486590f, 0.192833048892205290f, + -0.981231580848749730f, + 0.192080397049892380f, -0.981379193313754560f, 0.191327632211630990f, + -0.981526228458664660f, + 0.190574754820252800f, -0.981672686196983110f, 0.189821765318656580f, + -0.981818566442552500f, + 0.189068664149806280f, -0.981963869109555240f, 0.188315451756732120f, + -0.982108594112513610f, + 0.187562128582529740f, -0.982252741366289370f, 0.186808695070359330f, + -0.982396310786084690f, + 0.186055151663446630f, -0.982539302287441240f, 0.185301498805082040f, + -0.982681715786240860f, + 0.184547736938619640f, -0.982823551198705240f, 0.183793866507478390f, + -0.982964808441396440f, + 0.183039887955141060f, -0.983105487431216290f, 0.182285801725153320f, + -0.983245588085407070f, + 0.181531608261125130f, -0.983385110321551180f, 0.180777308006728670f, + -0.983524054057571260f, + 0.180022901405699510f, -0.983662419211730250f, 0.179268388901835880f, + -0.983800205702631490f, + 0.178513770938997590f, -0.983937413449218920f, 0.177759047961107140f, + -0.984074042370776450f, + 0.177004220412148860f, -0.984210092386929030f, 0.176249288736167940f, + -0.984345563417641900f, + 0.175494253377271400f, -0.984480455383220930f, 0.174739114779627310f, + -0.984614768204312600f, + 0.173983873387463850f, -0.984748501801904210f, 0.173228529645070490f, + -0.984881656097323700f, + 0.172473083996796030f, -0.985014231012239840f, 0.171717536887049970f, + -0.985146226468662230f, + 0.170961888760301360f, -0.985277642388941220f, 0.170206140061078120f, + -0.985408478695768420f, + 0.169450291233967930f, -0.985538735312176060f, 0.168694342723617440f, + -0.985668412161537550f, + 0.167938294974731230f, -0.985797509167567370f, 0.167182148432072880f, + -0.985926026254321130f, + 0.166425903540464220f, -0.986053963346195440f, 0.165669560744784140f, + -0.986181320367928270f, + 0.164913120489970090f, -0.986308097244598670f, 0.164156583221015890f, + -0.986434293901627070f, + 0.163399949382973230f, -0.986559910264775410f, 0.162643219420950450f, + -0.986684946260146690f, + 0.161886393780111910f, -0.986809401814185420f, 0.161129472905678780f, + -0.986933276853677710f, + 0.160372457242928400f, -0.987056571305750970f, 0.159615347237193090f, + -0.987179285097874340f, + 0.158858143333861390f, -0.987301418157858430f, 0.158100845978377090f, + -0.987422970413855410f, + 0.157343455616238280f, -0.987543941794359230f, 0.156585972692998590f, + -0.987664332228205710f, + 0.155828397654265320f, -0.987784141644572180f, 0.155070730945700510f, + -0.987903369972977790f, + 0.154312973013020240f, -0.988022017143283530f, 0.153555124301993500f, + -0.988140083085692570f, + 0.152797185258443410f, -0.988257567730749460f, 0.152039156328246160f, + -0.988374471009341280f, + 0.151281037957330250f, -0.988490792852696590f, 0.150522830591677370f, + -0.988606533192386450f, + 0.149764534677321620f, -0.988721691960323780f, 0.149006150660348470f, + -0.988836269088763540f, + 0.148247678986896200f, -0.988950264510302990f, 0.147489120103153680f, + -0.989063678157881540f, + 0.146730474455361750f, -0.989176509964781010f, 0.145971742489812370f, + -0.989288759864625170f, + 0.145212924652847520f, -0.989400427791380380f, 0.144454021390860440f, + -0.989511513679355190f, + 0.143695033150294580f, -0.989622017463200780f, 0.142935960377642700f, + -0.989731939077910570f, + 0.142176803519448000f, -0.989841278458820530f, 0.141417563022303130f, + -0.989950035541608990f, + 0.140658239332849240f, -0.990058210262297120f, 0.139898832897777380f, + -0.990165802557248400f, + 0.139139344163826280f, -0.990272812363169110f, 0.138379773577783890f, + -0.990379239617108160f, + 0.137620121586486180f, -0.990485084256456980f, 0.136860388636816430f, + -0.990590346218950150f, + 0.136100575175706200f, -0.990695025442664630f, 0.135340681650134330f, + -0.990799121866020370f, + 0.134580708507126220f, -0.990902635427780010f, 0.133820656193754690f, + -0.991005566067049370f, + 0.133060525157139180f, -0.991107913723276780f, 0.132300315844444680f, + -0.991209678336254060f, + 0.131540028702883280f, -0.991310859846115440f, 0.130779664179711790f, + -0.991411458193338540f, + 0.130019222722233350f, -0.991511473318743900f, 0.129258704777796270f, + -0.991610905163495370f, + 0.128498110793793220f, -0.991709753669099530f, 0.127737441217662280f, + -0.991808018777406430f, + 0.126976696496885980f, -0.991905700430609330f, 0.126215877078990400f, + -0.992002798571244520f, + 0.125454983411546210f, -0.992099313142191800f, 0.124694015942167770f, + -0.992195244086673920f, + 0.123932975118512200f, -0.992290591348257370f, 0.123171861388280650f, + -0.992385354870851670f, + 0.122410675199216280f, -0.992479534598709970f, 0.121649416999105540f, + -0.992573130476428810f, + 0.120888087235777220f, -0.992666142448948020f, 0.120126686357101580f, + -0.992758570461551140f, + 0.119365214810991350f, -0.992850414459865100f, 0.118603673045400840f, + -0.992941674389860470f, + 0.117842061508325020f, -0.993032350197851410f, 0.117080380647800550f, + -0.993122441830495580f, + 0.116318630911904880f, -0.993211949234794500f, 0.115556812748755290f, + -0.993300872358093280f, + 0.114794926606510250f, -0.993389211148080650f, 0.114032972933367300f, + -0.993476965552789190f, + 0.113270952177564360f, -0.993564135520595300f, 0.112508864787378830f, + -0.993650721000219120f, + 0.111746711211126660f, -0.993736721940724600f, 0.110984491897163380f, + -0.993822138291519660f, + 0.110222207293883180f, -0.993906970002356060f, 0.109459857849718030f, + -0.993991217023329380f, + 0.108697444013138670f, -0.994074879304879370f, 0.107934966232653760f, + -0.994157956797789730f, + 0.107172424956808870f, -0.994240449453187900f, 0.106409820634187840f, + -0.994322357222545810f, + 0.105647153713410700f, -0.994403680057679100f, 0.104884424643134970f, + -0.994484417910747600f, + 0.104121633872054730f, -0.994564570734255420f, 0.103358781848899700f, + -0.994644138481050710f, + 0.102595869022436280f, -0.994723121104325700f, 0.101832895841466670f, + -0.994801518557617110f, + 0.101069862754827880f, -0.994879330794805620f, 0.100306770211392820f, + -0.994956557770116380f, + 0.099543618660069444f, -0.995033199438118630f, 0.098780408549799664f, + -0.995109255753726110f, + 0.098017140329560770f, -0.995184726672196820f, 0.097253814448363354f, + -0.995259612149133390f, + 0.096490431355252607f, -0.995333912140482280f, 0.095726991499307315f, + -0.995407626602534900f, + 0.094963495329639061f, -0.995480755491926940f, 0.094199943295393190f, + -0.995553298765638470f, + 0.093436335845747912f, -0.995625256380994310f, 0.092672673429913366f, + -0.995696628295663520f, + 0.091908956497132696f, -0.995767414467659820f, 0.091145185496681130f, + -0.995837614855341610f, + 0.090381360877865011f, -0.995907229417411720f, 0.089617483090022917f, + -0.995976258112917790f, + 0.088853552582524684f, -0.996044700901251970f, 0.088089569804770507f, + -0.996112557742151130f, + 0.087325535206192226f, -0.996179828595696870f, 0.086561449236251239f, + -0.996246513422315520f, + 0.085797312344439880f, -0.996312612182778000f, 0.085033124980280414f, + -0.996378124838200210f, + 0.084268887593324127f, -0.996443051350042630f, 0.083504600633152404f, + -0.996507391680110820f, + 0.082740264549375803f, -0.996571145790554840f, 0.081975879791633108f, + -0.996634313643869900f, + 0.081211446809592386f, -0.996696895202896060f, 0.080446966052950097f, + -0.996758890430818000f, + 0.079682437971430126f, -0.996820299291165670f, 0.078917863014785095f, + -0.996881121747813850f, + 0.078153241632794315f, -0.996941357764982160f, 0.077388574275265049f, + -0.997001007307235290f, + 0.076623861392031617f, -0.997060070339482960f, 0.075859103432954503f, + -0.997118546826979980f, + 0.075094300847921291f, -0.997176436735326190f, 0.074329454086845867f, + -0.997233740030466160f, + 0.073564563599667454f, -0.997290456678690210f, 0.072799629836351618f, + -0.997346586646633230f, + 0.072034653246889416f, -0.997402129901275300f, 0.071269634281296415f, + -0.997457086409941910f, + 0.070504573389614009f, -0.997511456140303450f, 0.069739471021907376f, + -0.997565239060375750f, + 0.068974327628266732f, -0.997618435138519550f, 0.068209143658806454f, + -0.997671044343441000f, + 0.067443919563664106f, -0.997723066644191640f, 0.066678655793001543f, + -0.997774502010167820f, + 0.065913352797003930f, -0.997825350411111640f, 0.065148011025878860f, + -0.997875611817110150f, + 0.064382630929857410f, -0.997925286198596000f, 0.063617212959193190f, + -0.997974373526346990f, + 0.062851757564161420f, -0.998022873771486240f, 0.062086265195060247f, + -0.998070786905482340f, + 0.061320736302208648f, -0.998118112900149180f, 0.060555171335947781f, + -0.998164851727646240f, + 0.059789570746640007f, -0.998211003360478190f, 0.059023934984667986f, + -0.998256567771495180f, + 0.058258264500435732f, -0.998301544933892890f, 0.057492559744367684f, + -0.998345934821212370f, + 0.056726821166907783f, -0.998389737407340160f, 0.055961049218520520f, + -0.998432952666508440f, + 0.055195244349690031f, -0.998475580573294770f, 0.054429407010919147f, + -0.998517621102622210f, + 0.053663537652730679f, -0.998559074229759310f, 0.052897636725665401f, + -0.998599939930320370f, + 0.052131704680283317f, -0.998640218180265270f, 0.051365741967162731f, + -0.998679908955899090f, + 0.050599749036899337f, -0.998719012233872940f, 0.049833726340107257f, + -0.998757527991183340f, + 0.049067674327418126f, -0.998795456205172410f, 0.048301593449480172f, + -0.998832796853527990f, + 0.047535484156959261f, -0.998869549914283560f, 0.046769346900537960f, + -0.998905715365818290f, + 0.046003182130914644f, -0.998941293186856870f, 0.045236990298804750f, + -0.998976283356469820f, + 0.044470771854938744f, -0.999010685854073380f, 0.043704527250063421f, + -0.999044500659429290f, + 0.042938256934940959f, -0.999077727752645360f, 0.042171961360348002f, + -0.999110367114174890f, + 0.041405640977076712f, -0.999142418724816910f, 0.040639296235933854f, + -0.999173882565716380f, + 0.039872927587739845f, -0.999204758618363890f, 0.039106535483329839f, + -0.999235046864595850f, + 0.038340120373552791f, -0.999264747286594420f, 0.037573682709270514f, + -0.999293859866887790f, + 0.036807222941358991f, -0.999322384588349540f, 0.036040741520706299f, + -0.999350321434199440f, + 0.035274238898213947f, -0.999377670388002850f, 0.034507715524795889f, + -0.999404431433671300f, + 0.033741171851377642f, -0.999430604555461730f, 0.032974608328897315f, + -0.999456189737977340f, + 0.032208025408304704f, -0.999481186966166950f, 0.031441423540560343f, + -0.999505596225325310f, + 0.030674803176636581f, -0.999529417501093140f, 0.029908164767516655f, + -0.999552650779456990f, + 0.029141508764193740f, -0.999575296046749220f, 0.028374835617672258f, + -0.999597353289648380f, + 0.027608145778965820f, -0.999618822495178640f, 0.026841439699098527f, + -0.999639703650710200f, + 0.026074717829104040f, -0.999659996743959220f, 0.025307980620024630f, + -0.999679701762987930f, + 0.024541228522912264f, -0.999698818696204250f, 0.023774461988827676f, + -0.999717347532362190f, + 0.023007681468839410f, -0.999735288260561680f, 0.022240887414024919f, + -0.999752640870248840f, + 0.021474080275469605f, -0.999769405351215280f, 0.020707260504265912f, + -0.999785581693599210f, + 0.019940428551514598f, -0.999801169887884260f, 0.019173584868322699f, + -0.999816169924900410f, + 0.018406729905804820f, -0.999830581795823400f, 0.017639864115082195f, + -0.999844405492175240f, + 0.016872987947281773f, -0.999857641005823860f, 0.016106101853537263f, + -0.999870288328982950f, + 0.015339206284988220f, -0.999882347454212560f, 0.014572301692779104f, + -0.999893818374418490f, + 0.013805388528060349f, -0.999904701082852900f, 0.013038467241987433f, + -0.999914995573113470f, + 0.012271538285719944f, -0.999924701839144500f, 0.011504602110422875f, + -0.999933819875236000f, + 0.010737659167264572f, -0.999942349676023910f, 0.009970709907418029f, + -0.999950291236490480f, + 0.009203754782059960f, -0.999957644551963900f, 0.008436794242369860f, + -0.999964409618118280f, + 0.007669828739531077f, -0.999970586430974140f, 0.006902858724729877f, + -0.999976174986897610f, + 0.006135884649154515f, -0.999981175282601110f, 0.005368906963996303f, + -0.999985587315143200f, + 0.004601926120448672f, -0.999989411081928400f, 0.003834942569706248f, + -0.999992646580707190f, + 0.003067956762966138f, -0.999995293809576190f, 0.002300969151425887f, + -0.999997352766978210f, + 0.001533980186284766f, -0.999998823451701880f, 0.000766990318742846f, + -0.999999705862882230f +}; + +static const float32_t Weights_8192[16384] = { + 1.000000000000000000f, -0.000000000000000000f, 0.999999981616429330f, + -0.000191747597310703f, + 0.999999926465717890f, -0.000383495187571396f, 0.999999834547867670f, + -0.000575242763732066f, + 0.999999705862882230f, -0.000766990318742704f, 0.999999540410766110f, + -0.000958737845553301f, + 0.999999338191525530f, -0.001150485337113849f, 0.999999099205167830f, + -0.001342232786374338f, + 0.999998823451701880f, -0.001533980186284766f, 0.999998510931137790f, + -0.001725727529795126f, + 0.999998161643486980f, -0.001917474809855419f, 0.999997775588762350f, + -0.002109222019415644f, + 0.999997352766978210f, -0.002300969151425805f, 0.999996893178149880f, + -0.002492716198835908f, + 0.999996396822294350f, -0.002684463154595962f, 0.999995863699429940f, + -0.002876210011655979f, + 0.999995293809576190f, -0.003067956762965976f, 0.999994687152754080f, + -0.003259703401475973f, + 0.999994043728985820f, -0.003451449920135994f, 0.999993363538295150f, + -0.003643196311896068f, + 0.999992646580707190f, -0.003834942569706228f, 0.999991892856248010f, + -0.004026688686516512f, + 0.999991102364945590f, -0.004218434655276963f, 0.999990275106828920f, + -0.004410180468937631f, + 0.999989411081928400f, -0.004601926120448571f, 0.999988510290275690f, + -0.004793671602759841f, + 0.999987572731904080f, -0.004985416908821511f, 0.999986598406848000f, + -0.005177162031583651f, + 0.999985587315143200f, -0.005368906963996343f, 0.999984539456826970f, + -0.005560651699009674f, + 0.999983454831937730f, -0.005752396229573736f, 0.999982333440515350f, + -0.005944140548638633f, + 0.999981175282601110f, -0.006135884649154475f, 0.999979980358237650f, + -0.006327628524071378f, + 0.999978748667468830f, -0.006519372166339468f, 0.999977480210339940f, + -0.006711115568908879f, + 0.999976174986897610f, -0.006902858724729756f, 0.999974832997189810f, + -0.007094601626752250f, + 0.999973454241265940f, -0.007286344267926521f, 0.999972038719176730f, + -0.007478086641202744f, + 0.999970586430974140f, -0.007669828739531097f, 0.999969097376711580f, + -0.007861570555861772f, + 0.999967571556443780f, -0.008053312083144972f, 0.999966008970226920f, + -0.008245053314330906f, + 0.999964409618118280f, -0.008436794242369799f, 0.999962773500176930f, + -0.008628534860211886f, + 0.999961100616462820f, -0.008820275160807412f, 0.999959390967037450f, + -0.009012015137106633f, + 0.999957644551963900f, -0.009203754782059819f, 0.999955861371306100f, + -0.009395494088617252f, + 0.999954041425129780f, -0.009587233049729225f, 0.999952184713501780f, + -0.009778971658346044f, + 0.999950291236490480f, -0.009970709907418031f, 0.999948360994165400f, + -0.010162447789895513f, + 0.999946393986597460f, -0.010354185298728842f, 0.999944390213859060f, + -0.010545922426868378f, + 0.999942349676023910f, -0.010737659167264491f, 0.999940272373166960f, + -0.010929395512867571f, + 0.999938158305364590f, -0.011121131456628021f, 0.999936007472694620f, + -0.011312866991496258f, + 0.999933819875236000f, -0.011504602110422714f, 0.999931595513069200f, + -0.011696336806357838f, + 0.999929334386276070f, -0.011888071072252092f, 0.999927036494939640f, + -0.012079804901055957f, + 0.999924701839144500f, -0.012271538285719925f, 0.999922330418976490f, + -0.012463271219194511f, + 0.999919922234522750f, -0.012655003694430242f, 0.999917477285871770f, + -0.012846735704377662f, + 0.999914995573113470f, -0.013038467241987334f, 0.999912477096339240f, + -0.013230198300209835f, + 0.999909921855641540f, -0.013421928871995765f, 0.999907329851114300f, + -0.013613658950295740f, + 0.999904701082852900f, -0.013805388528060391f, 0.999902035550953920f, + -0.013997117598240367f, + 0.999899333255515390f, -0.014188846153786345f, 0.999896594196636680f, + -0.014380574187649006f, + 0.999893818374418490f, -0.014572301692779064f, 0.999891005788962950f, + -0.014764028662127246f, + 0.999888156440373320f, -0.014955755088644296f, 0.999885270328754520f, + -0.015147480965280987f, + 0.999882347454212560f, -0.015339206284988100f, 0.999879387816854930f, + -0.015530931040716447f, + 0.999876391416790410f, -0.015722655225416857f, 0.999873358254129260f, + -0.015914378832040183f, + 0.999870288328982950f, -0.016106101853537287f, 0.999867181641464380f, + -0.016297824282859065f, + 0.999864038191687680f, -0.016489546112956437f, 0.999860857979768540f, + -0.016681267336780332f, + 0.999857641005823860f, -0.016872987947281710f, 0.999854387269971890f, + -0.017064707937411563f, + 0.999851096772332190f, -0.017256427300120877f, 0.999847769513025900f, + -0.017448146028360693f, + 0.999844405492175240f, -0.017639864115082053f, 0.999841004709904000f, + -0.017831581553236039f, + 0.999837567166337090f, -0.018023298335773746f, 0.999834092861600960f, + -0.018215014455646290f, + 0.999830581795823400f, -0.018406729905804820f, 0.999827033969133420f, + -0.018598444679200511f, + 0.999823449381661570f, -0.018790158768784555f, 0.999819828033539420f, + -0.018981872167508178f, + 0.999816169924900410f, -0.019173584868322623f, 0.999812475055878780f, + -0.019365296864179156f, + 0.999808743426610520f, -0.019557008148029083f, 0.999804975037232870f, + -0.019748718712823729f, + 0.999801169887884260f, -0.019940428551514441f, 0.999797327978704690f, + -0.020132137657052594f, + 0.999793449309835270f, -0.020323846022389593f, 0.999789533881418780f, + -0.020515553640476875f, + 0.999785581693599210f, -0.020707260504265895f, 0.999781592746521670f, + -0.020898966606708137f, + 0.999777567040332940f, -0.021090671940755121f, 0.999773504575180990f, + -0.021282376499358387f, + 0.999769405351215280f, -0.021474080275469508f, 0.999765269368586450f, + -0.021665783262040078f, + 0.999761096627446610f, -0.021857485452021735f, 0.999756887127949080f, + -0.022049186838366135f, + 0.999752640870248840f, -0.022240887414024961f, 0.999748357854501780f, + -0.022432587171949934f, + 0.999744038080865430f, -0.022624286105092803f, 0.999739681549498660f, + -0.022815984206405345f, + 0.999735288260561680f, -0.023007681468839369f, 0.999730858214216030f, + -0.023199377885346720f, + 0.999726391410624470f, -0.023391073448879258f, 0.999721887849951310f, + -0.023582768152388894f, + 0.999717347532362190f, -0.023774461988827555f, 0.999712770458023870f, + -0.023966154951147210f, + 0.999708156627104880f, -0.024157847032299864f, 0.999703506039774650f, + -0.024349538225237534f, + 0.999698818696204250f, -0.024541228522912288f, 0.999694094596566000f, + -0.024732917918276223f, + 0.999689333741033640f, -0.024924606404281468f, 0.999684536129782140f, + -0.025116293973880186f, + 0.999679701762987930f, -0.025307980620024571f, 0.999674830640828740f, + -0.025499666335666853f, + 0.999669922763483760f, -0.025691351113759295f, 0.999664978131133310f, + -0.025883034947254198f, + 0.999659996743959220f, -0.026074717829103901f, 0.999654978602144690f, + -0.026266399752260760f, + 0.999649923705874240f, -0.026458080709677187f, 0.999644832055333610f, + -0.026649760694305618f, + 0.999639703650710200f, -0.026841439699098531f, 0.999634538492192300f, + -0.027033117717008431f, + 0.999629336579970110f, -0.027224794740987875f, 0.999624097914234570f, + -0.027416470763989436f, + 0.999618822495178640f, -0.027608145778965740f, 0.999613510322995950f, + -0.027799819778869445f, + 0.999608161397882110f, -0.027991492756653243f, 0.999602775720033530f, + -0.028183164705269874f, + 0.999597353289648380f, -0.028374835617672099f, 0.999591894106925950f, + -0.028566505486812728f, + 0.999586398172067070f, -0.028758174305644615f, 0.999580865485273700f, + -0.028949842067120635f, + 0.999575296046749220f, -0.029141508764193722f, 0.999569689856698580f, + -0.029333174389816835f, + 0.999564046915327740f, -0.029524838936942976f, 0.999558367222844300f, + -0.029716502398525191f, + 0.999552650779456990f, -0.029908164767516555f, 0.999546897585375960f, + -0.030099826036870198f, + 0.999541107640812940f, -0.030291486199539284f, 0.999535280945980540f, + -0.030483145248477009f, + 0.999529417501093140f, -0.030674803176636626f, 0.999523517306366350f, + -0.030866459976971412f, + 0.999517580362016990f, -0.031058115642434700f, 0.999511606668263440f, + -0.031249770165979861f, + 0.999505596225325310f, -0.031441423540560301f, 0.999499549033423640f, + -0.031633075759129478f, + 0.999493465092780590f, -0.031824726814640887f, 0.999487344403620080f, + -0.032016376700048060f, + 0.999481186966166950f, -0.032208025408304586f, 0.999474992780647780f, + -0.032399672932364086f, + 0.999468761847290050f, -0.032591319265180226f, 0.999462494166323160f, + -0.032782964399706724f, + 0.999456189737977340f, -0.032974608328897335f, 0.999449848562484530f, + -0.033166251045705857f, + 0.999443470640077770f, -0.033357892543086139f, 0.999437055970991530f, + -0.033549532813992068f, + 0.999430604555461730f, -0.033741171851377580f, 0.999424116393725640f, + -0.033932809648196664f, + 0.999417591486021720f, -0.034124446197403326f, 0.999411029832589780f, + -0.034316081491951651f, + 0.999404431433671300f, -0.034507715524795750f, 0.999397796289508640f, + -0.034699348288889799f, + 0.999391124400346050f, -0.034890979777188004f, 0.999384415766428560f, + -0.035082609982644619f, + 0.999377670388002850f, -0.035274238898213947f, 0.999370888265317170f, + -0.035465866516850353f, + 0.999364069398620550f, -0.035657492831508222f, 0.999357213788164000f, + -0.035849117835142018f, + 0.999350321434199440f, -0.036040741520706229f, 0.999343392336980220f, + -0.036232363881155395f, + 0.999336426496761240f, -0.036423984909444110f, 0.999329423913798420f, + -0.036615604598527030f, + 0.999322384588349540f, -0.036807222941358832f, 0.999315308520673070f, + -0.036998839930894263f, + 0.999308195711029470f, -0.037190455560088119f, 0.999301046159680070f, + -0.037382069821895229f, + 0.999293859866887790f, -0.037573682709270494f, 0.999286636832916740f, + -0.037765294215168860f, + 0.999279377058032710f, -0.037956904332545310f, 0.999272080542502610f, + -0.038148513054354891f, + 0.999264747286594420f, -0.038340120373552694f, 0.999257377290578060f, + -0.038531726283093870f, + 0.999249970554724420f, -0.038723330775933623f, 0.999242527079305830f, + -0.038914933845027193f, + 0.999235046864595850f, -0.039106535483329888f, 0.999227529910869610f, + -0.039298135683797059f, + 0.999219976218403530f, -0.039489734439384118f, 0.999212385787475290f, + -0.039681331743046527f, + 0.999204758618363890f, -0.039872927587739811f, 0.999197094711349880f, + -0.040064521966419520f, + 0.999189394066714920f, -0.040256114872041282f, 0.999181656684742350f, + -0.040447706297560782f, + 0.999173882565716380f, -0.040639296235933736f, 0.999166071709923000f, + -0.040830884680115948f, + 0.999158224117649430f, -0.041022471623063238f, 0.999150339789184110f, + -0.041214057057731519f, + 0.999142418724816910f, -0.041405640977076739f, 0.999134460924839150f, + -0.041597223374054894f, + 0.999126466389543390f, -0.041788804241622061f, 0.999118435119223490f, + -0.041980383572734356f, + 0.999110367114174890f, -0.042171961360347947f, 0.999102262374694130f, + -0.042363537597419072f, + 0.999094120901079070f, -0.042555112276904020f, 0.999085942693629270f, + -0.042746685391759132f, + 0.999077727752645360f, -0.042938256934940820f, 0.999069476078429330f, + -0.043129826899405546f, + 0.999061187671284600f, -0.043321395278109825f, 0.999052862531515930f, + -0.043512962064010237f, + 0.999044500659429290f, -0.043704527250063421f, 0.999036102055332330f, + -0.043896090829226068f, + 0.999027666719533690f, -0.044087652794454944f, 0.999019194652343460f, + -0.044279213138706849f, + 0.999010685854073380f, -0.044470771854938668f, 0.999002140325035980f, + -0.044662328936107325f, + 0.998993558065545680f, -0.044853884375169815f, 0.998984939075918010f, + -0.045045438165083197f, + 0.998976283356469820f, -0.045236990298804590f, 0.998967590907519300f, + -0.045428540769291155f, + 0.998958861729386080f, -0.045620089569500144f, 0.998950095822391250f, + -0.045811636692388844f, + 0.998941293186856870f, -0.046003182130914623f, 0.998932453823106690f, + -0.046194725878034908f, + 0.998923577731465780f, -0.046386267926707157f, 0.998914664912260440f, + -0.046577808269888943f, + 0.998905715365818290f, -0.046769346900537863f, 0.998896729092468410f, + -0.046960883811611592f, + 0.998887706092541290f, -0.047152418996067869f, 0.998878646366368690f, + -0.047343952446864478f, + 0.998869549914283560f, -0.047535484156959303f, 0.998860416736620520f, + -0.047727014119310254f, + 0.998851246833715180f, -0.047918542326875327f, 0.998842040205904840f, + -0.048110068772612591f, + 0.998832796853527990f, -0.048301593449480144f, 0.998823516776924490f, + -0.048493116350436176f, + 0.998814199976435390f, -0.048684637468438943f, 0.998804846452403420f, + -0.048876156796446760f, + 0.998795456205172410f, -0.049067674327418015f, 0.998786029235087640f, + -0.049259190054311140f, + 0.998776565542495610f, -0.049450703970084664f, 0.998767065127744380f, + -0.049642216067697156f, + 0.998757527991183340f, -0.049833726340107277f, 0.998747954133162860f, + -0.050025234780273729f, + 0.998738343554035230f, -0.050216741381155311f, 0.998728696254153720f, + -0.050408246135710856f, + 0.998719012233872940f, -0.050599749036899282f, 0.998709291493549030f, + -0.050791250077679581f, + 0.998699534033539280f, -0.050982749251010803f, 0.998689739854202620f, + -0.051174246549852080f, + 0.998679908955899090f, -0.051365741967162593f, 0.998670041338990070f, + -0.051557235495901611f, + 0.998660137003838490f, -0.051748727129028456f, 0.998650195950808280f, + -0.051940216859502536f, + 0.998640218180265270f, -0.052131704680283324f, 0.998630203692576050f, + -0.052323190584330347f, + 0.998620152488108870f, -0.052514674564603223f, 0.998610064567233340f, + -0.052706156614061632f, + 0.998599939930320370f, -0.052897636725665324f, 0.998589778577742230f, + -0.053089114892374133f, + 0.998579580509872500f, -0.053280591107147945f, 0.998569345727086110f, + -0.053472065362946727f, + 0.998559074229759310f, -0.053663537652730520f, 0.998548766018269920f, + -0.053855007969459440f, + 0.998538421092996730f, -0.054046476306093660f, 0.998528039454320230f, + -0.054237942655593452f, + 0.998517621102622210f, -0.054429407010919133f, 0.998507166038285490f, + -0.054620869365031105f, + 0.998496674261694640f, -0.054812329710889854f, 0.998486145773235360f, + -0.055003788041455920f, + 0.998475580573294770f, -0.055195244349689934f, 0.998464978662261250f, + -0.055386698628552597f, + 0.998454340040524800f, -0.055578150871004678f, 0.998443664708476340f, + -0.055769601070007030f, + 0.998432952666508440f, -0.055961049218520569f, 0.998422203915015020f, + -0.056152495309506292f, + 0.998411418454391300f, -0.056343939335925290f, 0.998400596285033640f, + -0.056535381290738700f, + 0.998389737407340160f, -0.056726821166907748f, 0.998378841821709990f, + -0.056918258957393740f, + 0.998367909528543820f, -0.057109694655158062f, 0.998356940528243420f, + -0.057301128253162158f, + 0.998345934821212370f, -0.057492559744367566f, 0.998334892407855000f, + -0.057683989121735904f, + 0.998323813288577560f, -0.057875416378228857f, 0.998312697463787260f, + -0.058066841506808194f, + 0.998301544933892890f, -0.058258264500435752f, 0.998290355699304350f, + -0.058449685352073476f, + 0.998279129760433200f, -0.058641104054683341f, 0.998267867117692110f, + -0.058832520601227435f, + 0.998256567771495180f, -0.059023934984667931f, 0.998245231722257880f, + -0.059215347197967061f, + 0.998233858970396850f, -0.059406757234087150f, 0.998222449516330550f, + -0.059598165085990591f, + 0.998211003360478190f, -0.059789570746639868f, 0.998199520503260660f, + -0.059980974208997548f, + 0.998188000945100300f, -0.060172375466026259f, 0.998176444686420530f, + -0.060363774510688743f, + 0.998164851727646240f, -0.060555171335947788f, 0.998153222069203760f, + -0.060746565934766288f, + 0.998141555711520520f, -0.060937958300107203f, 0.998129852655025630f, + -0.061129348424933588f, + 0.998118112900149180f, -0.061320736302208578f, 0.998106336447323050f, + -0.061512121924895378f, + 0.998094523296980010f, -0.061703505285957298f, 0.998082673449554590f, + -0.061894886378357716f, + 0.998070786905482340f, -0.062086265195060088f, 0.998058863665200250f, + -0.062277641729027972f, + 0.998046903729146840f, -0.062469015973224996f, 0.998034907097761770f, + -0.062660387920614874f, + 0.998022873771486240f, -0.062851757564161406f, 0.998010803750762450f, + -0.063043124896828492f, + 0.997998697036034390f, -0.063234489911580066f, 0.997986553627747020f, + -0.063425852601380228f, + 0.997974373526346990f, -0.063617212959193106f, 0.997962156732281950f, + -0.063808570977982898f, + 0.997949903246001190f, -0.063999926650713940f, 0.997937613067955250f, + -0.064191279970350637f, + 0.997925286198596000f, -0.064382630929857465f, 0.997912922638376610f, + -0.064573979522198982f, + 0.997900522387751620f, -0.064765325740339885f, 0.997888085447177110f, + -0.064956669577244872f, + 0.997875611817110150f, -0.065148011025878833f, 0.997863101498009500f, + -0.065339350079206632f, + 0.997850554490335110f, -0.065530686730193327f, 0.997837970794548280f, + -0.065722020971803990f, + 0.997825350411111640f, -0.065913352797003805f, 0.997812693340489280f, + -0.066104682198758077f, + 0.997799999583146470f, -0.066296009170032130f, 0.997787269139549960f, + -0.066487333703791451f, + 0.997774502010167820f, -0.066678655793001557f, 0.997761698195469560f, + -0.066869975430628115f, + 0.997748857695925690f, -0.067061292609636822f, 0.997735980512008620f, + -0.067252607322993499f, + 0.997723066644191640f, -0.067443919563664051f, 0.997710116092949570f, + -0.067635229324614479f, + 0.997697128858758500f, -0.067826536598810869f, 0.997684104942096030f, + -0.068017841379219388f, + 0.997671044343441000f, -0.068209143658806329f, 0.997657947063273710f, + -0.068400443430538013f, + 0.997644813102075420f, -0.068591740687380942f, 0.997631642460329320f, + -0.068783035422301630f, + 0.997618435138519550f, -0.068974327628266746f, 0.997605191137131640f, + -0.069165617298242985f, + 0.997591910456652630f, -0.069356904425197208f, 0.997578593097570800f, + -0.069548189002096306f, + 0.997565239060375750f, -0.069739471021907307f, 0.997551848345558430f, + -0.069930750477597309f, + 0.997538420953611340f, -0.070122027362133521f, 0.997524956885027960f, + -0.070313301668483250f, + 0.997511456140303450f, -0.070504573389613856f, 0.997497918719934210f, + -0.070695842518492855f, + 0.997484344624417930f, -0.070887109048087801f, 0.997470733854253670f, + -0.071078372971366405f, + 0.997457086409941910f, -0.071269634281296401f, 0.997443402291984360f, + -0.071460892970845680f, + 0.997429681500884180f, -0.071652149032982212f, 0.997415924037145960f, + -0.071843402460674027f, + 0.997402129901275300f, -0.072034653246889332f, 0.997388299093779460f, + -0.072225901384596322f, + 0.997374431615167150f, -0.072417146866763413f, 0.997360527465947940f, + -0.072608389686358993f, + 0.997346586646633230f, -0.072799629836351673f, 0.997332609157735470f, + -0.072990867309710036f, + 0.997318594999768600f, -0.073182102099402888f, 0.997304544173247990f, + -0.073373334198399032f, + 0.997290456678690210f, -0.073564563599667426f, 0.997276332516613180f, + -0.073755790296177098f, + 0.997262171687536170f, -0.073947014280897200f, 0.997247974191979860f, + -0.074138235546796979f, + 0.997233740030466280f, -0.074329454086845756f, 0.997219469203518670f, + -0.074520669894013000f, + 0.997205161711661850f, -0.074711882961268211f, 0.997190817555421940f, + -0.074903093281581082f, + 0.997176436735326190f, -0.075094300847921305f, 0.997162019251903290f, + -0.075285505653258769f, + 0.997147565105683480f, -0.075476707690563388f, 0.997133074297198110f, + -0.075667906952805231f, + 0.997118546826979980f, -0.075859103432954447f, 0.997103982695563330f, + -0.076050297123981259f, + 0.997089381903483400f, -0.076241488018856066f, 0.997074744451277310f, + -0.076432676110549283f, + 0.997060070339482960f, -0.076623861392031492f, 0.997045359568640040f, + -0.076815043856273343f, + 0.997030612139289450f, -0.077006223496245640f, 0.997015828051973310f, + -0.077197400304919200f, + 0.997001007307235290f, -0.077388574275265049f, 0.996986149905620180f, + -0.077579745400254224f, + 0.996971255847674320f, -0.077770913672857947f, 0.996956325133945280f, + -0.077962079086047492f, + 0.996941357764982160f, -0.078153241632794232f, 0.996926353741335090f, + -0.078344401306069705f, + 0.996911313063555740f, -0.078535558098845479f, 0.996896235732197210f, + -0.078726712004093299f, + 0.996881121747813850f, -0.078917863014784942f, 0.996865971110961310f, + -0.079109011123892375f, + 0.996850783822196610f, -0.079300156324387597f, 0.996835559882078170f, + -0.079491298609242769f, + 0.996820299291165670f, -0.079682437971430126f, 0.996805002050020430f, + -0.079873574403921996f, + 0.996789668159204560f, -0.080064707899690890f, 0.996774297619282050f, + -0.080255838451709319f, + 0.996758890430818000f, -0.080446966052950014f, 0.996743446594378860f, + -0.080638090696385709f, + 0.996727966110532490f, -0.080829212374989329f, 0.996712448979848010f, + -0.081020331081733857f, + 0.996696895202896060f, -0.081211446809592441f, 0.996681304780248300f, + -0.081402559551538245f, + 0.996665677712478160f, -0.081593669300544652f, 0.996650014000160070f, + -0.081784776049585076f, + 0.996634313643869900f, -0.081975879791633066f, 0.996618576644185070f, + -0.082166980519662314f, + 0.996602803001684130f, -0.082358078226646536f, 0.996586992716946950f, + -0.082549172905559673f, + 0.996571145790554840f, -0.082740264549375692f, 0.996555262223090540f, + -0.082931353151068699f, + 0.996539342015137940f, -0.083122438703612911f, 0.996523385167282450f, + -0.083313521199982685f, + 0.996507391680110820f, -0.083504600633152432f, 0.996491361554210920f, + -0.083695676996096716f, + 0.996475294790172160f, -0.083886750281790226f, 0.996459191388585410f, + -0.084077820483207694f, + 0.996443051350042630f, -0.084268887593324071f, 0.996426874675137240f, + -0.084459951605114325f, + 0.996410661364464100f, -0.084651012511553617f, 0.996394411418619290f, + -0.084842070305617134f, + 0.996378124838200210f, -0.085033124980280275f, 0.996361801623805720f, + -0.085224176528518478f, + 0.996345441776035900f, -0.085415224943307333f, 0.996329045295492380f, + -0.085606270217622529f, + 0.996312612182778000f, -0.085797312344439894f, 0.996296142438496850f, + -0.085988351316735337f, + 0.996279636063254650f, -0.086179387127484894f, 0.996263093057658140f, + -0.086370419769664752f, + 0.996246513422315520f, -0.086561449236251170f, 0.996229897157836500f, + -0.086752475520220543f, + 0.996213244264832040f, -0.086943498614549378f, 0.996196554743914220f, + -0.087134518512214307f, + 0.996179828595696980f, -0.087325535206192059f, 0.996163065820794950f, + -0.087516548689459531f, + 0.996146266419824620f, -0.087707558954993659f, 0.996129430393403740f, + -0.087898565995771588f, + 0.996112557742151130f, -0.088089569804770507f, 0.996095648466687300f, + -0.088280570374967740f, + 0.996078702567633980f, -0.088471567699340767f, 0.996061720045614000f, + -0.088662561770867149f, + 0.996044700901251970f, -0.088853552582524600f, 0.996027645135173610f, + -0.089044540127290892f, + 0.996010552748005870f, -0.089235524398144014f, 0.995993423740377360f, + -0.089426505388061961f, + 0.995976258112917790f, -0.089617483090022959f, 0.995959055866258320f, + -0.089808457497005278f, + 0.995941817001031350f, -0.089999428601987341f, 0.995924541517870800f, + -0.090190396397947695f, + 0.995907229417411720f, -0.090381360877864983f, 0.995889880700290720f, + -0.090572322034717989f, + 0.995872495367145730f, -0.090763279861485621f, 0.995855073418615790f, + -0.090954234351146926f, + 0.995837614855341610f, -0.091145185496681005f, 0.995820119677964910f, + -0.091336133291067184f, + 0.995802587887129160f, -0.091527077727284828f, 0.995785019483478750f, + -0.091718018798313455f, + 0.995767414467659820f, -0.091908956497132724f, 0.995749772840319510f, + -0.092099890816722388f, + 0.995732094602106430f, -0.092290821750062355f, 0.995714379753670610f, + -0.092481749290132600f, + 0.995696628295663520f, -0.092672673429913310f, 0.995678840228737540f, + -0.092863594162384724f, + 0.995661015553546910f, -0.093054511480527249f, 0.995643154270746900f, + -0.093245425377321375f, + 0.995625256380994310f, -0.093436335845747787f, 0.995607321884947050f, + -0.093627242878787195f, + 0.995589350783264600f, -0.093818146469420549f, 0.995571343076607770f, + -0.094009046610628838f, + 0.995553298765638470f, -0.094199943295393204f, 0.995535217851020390f, + -0.094390836516694943f, + 0.995517100333418110f, -0.094581726267515445f, 0.995498946213497770f, + -0.094772612540836243f, + 0.995480755491926940f, -0.094963495329638992f, 0.995462528169374420f, + -0.095154374626905486f, + 0.995444264246510340f, -0.095345250425617617f, 0.995425963724006160f, + -0.095536122718757471f, + 0.995407626602534900f, -0.095726991499307162f, 0.995389252882770690f, + -0.095917856760249040f, + 0.995370842565388990f, -0.096108718494565509f, 0.995352395651066810f, + -0.096299576695239128f, + 0.995333912140482280f, -0.096490431355252593f, 0.995315392034315070f, + -0.096681282467588725f, + 0.995296835333246090f, -0.096872130025230471f, 0.995278242037957670f, + -0.097062974021160917f, + 0.995259612149133390f, -0.097253814448363271f, 0.995240945667458130f, + -0.097444651299820870f, + 0.995222242593618360f, -0.097635484568517200f, 0.995203502928301510f, + -0.097826314247435861f, + 0.995184726672196930f, -0.098017140329560604f, 0.995165913825994620f, + -0.098207962807875276f, + 0.995147064390386470f, -0.098398781675363881f, 0.995128178366065490f, + -0.098589596925010584f, + 0.995109255753726110f, -0.098780408549799623f, 0.995090296554064000f, + -0.098971216542715429f, + 0.995071300767776170f, -0.099162020896742503f, 0.995052268395561050f, + -0.099352821604865540f, + 0.995033199438118630f, -0.099543618660069319f, 0.995014093896149700f, + -0.099734412055338825f, + 0.994994951770357020f, -0.099925201783659073f, 0.994975773061444140f, + -0.100115987838015310f, + 0.994956557770116380f, -0.100306770211392860f, 0.994937305897080070f, + -0.100497548896777200f, + 0.994918017443043200f, -0.100688323887153960f, 0.994898692408714870f, + -0.100879095175508860f, + 0.994879330794805620f, -0.101069862754827820f, 0.994859932602027320f, + -0.101260626618096830f, + 0.994840497831093180f, -0.101451386758302080f, 0.994821026482717860f, + -0.101642143168429830f, + 0.994801518557617110f, -0.101832895841466530f, 0.994781974056508260f, + -0.102023644770398740f, + 0.994762392980109930f, -0.102214389948213210f, 0.994742775329142010f, + -0.102405131367896720f, + 0.994723121104325700f, -0.102595869022436280f, 0.994703430306383860f, + -0.102786602904819040f, + 0.994683702936040250f, -0.102977333008032220f, 0.994663938994020390f, + -0.103168059325063230f, + 0.994644138481050710f, -0.103358781848899610f, 0.994624301397859400f, + -0.103549500572529070f, + 0.994604427745175660f, -0.103740215488939370f, 0.994584517523730340f, + -0.103930926591118510f, + 0.994564570734255420f, -0.104121633872054590f, 0.994544587377484300f, + -0.104312337324735800f, + 0.994524567454151740f, -0.104503036942150570f, 0.994504510964993700f, + -0.104693732717287390f, + 0.994484417910747600f, -0.104884424643134970f, 0.994464288292152390f, + -0.105075112712682040f, + 0.994444122109948040f, -0.105265796918917600f, 0.994423919364875950f, + -0.105456477254830710f, + 0.994403680057679100f, -0.105647153713410620f, 0.994383404189101430f, + -0.105837826287646670f, + 0.994363091759888570f, -0.106028494970528410f, 0.994342742770787270f, + -0.106219159755045480f, + 0.994322357222545810f, -0.106409820634187680f, 0.994301935115913580f, + -0.106600477600944960f, + 0.994281476451641550f, -0.106791130648307390f, 0.994260981230481790f, + -0.106981779769265230f, + 0.994240449453187900f, -0.107172424956808840f, 0.994219881120514960f, + -0.107363066203928760f, + 0.994199276233218910f, -0.107553703503615620f, 0.994178634792057590f, + -0.107744336848860280f, + 0.994157956797789730f, -0.107934966232653650f, 0.994137242251175720f, + -0.108125591647986870f, + 0.994116491152977070f, -0.108316213087851170f, 0.994095703503956930f, + -0.108506830545237920f, + 0.994074879304879370f, -0.108697444013138720f, 0.994054018556510210f, + -0.108888053484545190f, + 0.994033121259616400f, -0.109078658952449240f, 0.994012187414966220f, + -0.109269260409842780f, + 0.993991217023329380f, -0.109459857849717980f, 0.993970210085476920f, + -0.109650451265067100f, + 0.993949166602181130f, -0.109841040648882600f, 0.993928086574215830f, + -0.110031625994157000f, + 0.993906970002356060f, -0.110222207293883060f, 0.993885816887378090f, + -0.110412784541053630f, + 0.993864627230059750f, -0.110603357728661730f, 0.993843401031180180f, + -0.110793926849700560f, + 0.993822138291519660f, -0.110984491897163390f, 0.993800839011860120f, + -0.111175052864043720f, + 0.993779503192984580f, -0.111365609743335160f, 0.993758130835677430f, + -0.111556162528031480f, + 0.993736721940724600f, -0.111746711211126590f, 0.993715276508913230f, + -0.111937255785614570f, + 0.993693794541031790f, -0.112127796244489640f, 0.993672276037870010f, + -0.112318332580746170f, + 0.993650721000219120f, -0.112508864787378690f, 0.993629129428871720f, + -0.112699392857381860f, + 0.993607501324621610f, -0.112889916783750520f, 0.993585836688263950f, + -0.113080436559479620f, + 0.993564135520595300f, -0.113270952177564350f, 0.993542397822413600f, + -0.113461463630999950f, + 0.993520623594518090f, -0.113651970912781870f, 0.993498812837709360f, + -0.113842474015905710f, + 0.993476965552789190f, -0.114032972933367200f, 0.993455081740560960f, + -0.114223467658162260f, + 0.993433161401829360f, -0.114413958183286920f, 0.993411204537400060f, + -0.114604444501737420f, + 0.993389211148080650f, -0.114794926606510080f, 0.993367181234679600f, + -0.114985404490601460f, + 0.993345114798006910f, -0.115175878147008190f, 0.993323011838873950f, + -0.115366347568727140f, + 0.993300872358093280f, -0.115556812748755260f, 0.993278696356479030f, + -0.115747273680089720f, + 0.993256483834846440f, -0.115937730355727780f, 0.993234234794012290f, + -0.116128182768666930f, + 0.993211949234794500f, -0.116318630911904750f, 0.993189627158012620f, + -0.116509074778439040f, + 0.993167268564487230f, -0.116699514361267690f, 0.993144873455040430f, + -0.116889949653388780f, + 0.993122441830495580f, -0.117080380647800590f, 0.993099973691677570f, + -0.117270807337501460f, + 0.993077469039412300f, -0.117461229715489990f, 0.993054927874527320f, + -0.117651647774764860f, + 0.993032350197851410f, -0.117842061508324980f, 0.993009736010214580f, + -0.118032470909169340f, + 0.992987085312448390f, -0.118222875970297170f, 0.992964398105385610f, + -0.118413276684707790f, + 0.992941674389860470f, -0.118603673045400720f, 0.992918914166708300f, + -0.118794065045375640f, + 0.992896117436765980f, -0.118984452677632340f, 0.992873284200871730f, + -0.119174835935170880f, + 0.992850414459865100f, -0.119365214810991350f, 0.992827508214586760f, + -0.119555589298094110f, + 0.992804565465879140f, -0.119745959389479600f, 0.992781586214585570f, + -0.119936325078148470f, + 0.992758570461551140f, -0.120126686357101500f, 0.992735518207621850f, + -0.120317043219339680f, + 0.992712429453645460f, -0.120507395657864130f, 0.992689304200470750f, + -0.120697743665676110f, + 0.992666142448948020f, -0.120888087235777080f, 0.992642944199928820f, + -0.121078426361168640f, + 0.992619709454266140f, -0.121268761034852600f, 0.992596438212814290f, + -0.121459091249830840f, + 0.992573130476428810f, -0.121649416999105530f, 0.992549786245966680f, + -0.121839738275678890f, + 0.992526405522286100f, -0.122030055072553360f, 0.992502988306246950f, + -0.122220367382731540f, + 0.992479534598709970f, -0.122410675199216200f, 0.992456044400537700f, + -0.122600978515010240f, + 0.992432517712593660f, -0.122791277323116770f, 0.992408954535742850f, + -0.122981571616539050f, + 0.992385354870851670f, -0.123171861388280480f, 0.992361718718787870f, + -0.123362146631344680f, + 0.992338046080420420f, -0.123552427338735370f, 0.992314336956619640f, + -0.123742703503456510f, + 0.992290591348257370f, -0.123932975118512160f, 0.992266809256206580f, + -0.124123242176906600f, + 0.992242990681341700f, -0.124313504671644230f, 0.992219135624538450f, + -0.124503762595729660f, + 0.992195244086673920f, -0.124694015942167640f, 0.992171316068626520f, + -0.124884264703963130f, + 0.992147351571276090f, -0.125074508874121170f, 0.992123350595503720f, + -0.125264748445647060f, + 0.992099313142191800f, -0.125454983411546230f, 0.992075239212224070f, + -0.125645213764824290f, + 0.992051128806485720f, -0.125835439498487000f, 0.992026981925863360f, + -0.126025660605540320f, + 0.992002798571244520f, -0.126215877078990350f, 0.991978578743518580f, + -0.126406088911843380f, + 0.991954322443575950f, -0.126596296097105850f, 0.991930029672308480f, + -0.126786498627784410f, + 0.991905700430609330f, -0.126976696496885870f, 0.991881334719373010f, + -0.127166889697417160f, + 0.991856932539495470f, -0.127357078222385400f, 0.991832493891873780f, + -0.127547262064797970f, + 0.991808018777406430f, -0.127737441217662310f, 0.991783507196993490f, + -0.127927615673986080f, + 0.991758959151536110f, -0.128117785426777130f, 0.991734374641936810f, + -0.128307950469043420f, + 0.991709753669099530f, -0.128498110793793170f, 0.991685096233929420f, + -0.128688266394034690f, + 0.991660402337333210f, -0.128878417262776550f, 0.991635671980218740f, + -0.129068563393027410f, + 0.991610905163495370f, -0.129258704777796140f, 0.991586101888073500f, + -0.129448841410091780f, + 0.991561262154865290f, -0.129638973282923560f, 0.991536385964783880f, + -0.129829100389300930f, + 0.991511473318743900f, -0.130019222722233350f, 0.991486524217661480f, + -0.130209340274730630f, + 0.991461538662453790f, -0.130399453039802690f, 0.991436516654039420f, + -0.130589561010459650f, + 0.991411458193338540f, -0.130779664179711710f, 0.991386363281272280f, + -0.130969762540569380f, + 0.991361231918763460f, -0.131159856086043270f, 0.991336064106736140f, + -0.131349944809144190f, + 0.991310859846115440f, -0.131540028702883120f, 0.991285619137828200f, + -0.131730107760271160f, + 0.991260341982802440f, -0.131920181974319790f, 0.991235028381967420f, + -0.132110251338040360f, + 0.991209678336254060f, -0.132300315844444650f, 0.991184291846594180f, + -0.132490375486544550f, + 0.991158868913921350f, -0.132680430257352070f, 0.991133409539170170f, + -0.132870480149879430f, + 0.991107913723276890f, -0.133060525157139060f, 0.991082381467178640f, + -0.133250565272143570f, + 0.991056812771814340f, -0.133440600487905680f, 0.991031207638124130f, + -0.133630630797438340f, + 0.991005566067049370f, -0.133820656193754720f, 0.990979888059532740f, + -0.134010676669868130f, + 0.990954173616518500f, -0.134200692218792020f, 0.990928422738951990f, + -0.134390702833540070f, + 0.990902635427780010f, -0.134580708507126170f, 0.990876811683950700f, + -0.134770709232564350f, + 0.990850951508413620f, -0.134960705002868750f, 0.990825054902119470f, + -0.135150695811053850f, + 0.990799121866020370f, -0.135340681650134210f, 0.990773152401069780f, + -0.135530662513124590f, + 0.990747146508222710f, -0.135720638393039910f, 0.990721104188435180f, + -0.135910609282895330f, + 0.990695025442664630f, -0.136100575175706200f, 0.990668910271870100f, + -0.136290536064487960f, + 0.990642758677011570f, -0.136480491942256280f, 0.990616570659050620f, + -0.136670442802027090f, + 0.990590346218950150f, -0.136860388636816380f, 0.990564085357674370f, + -0.137050329439640410f, + 0.990537788076188750f, -0.137240265203515590f, 0.990511454375460290f, + -0.137430195921458550f, + 0.990485084256457090f, -0.137620121586486040f, 0.990458677720148620f, + -0.137810042191615080f, + 0.990432234767505970f, -0.137999957729862790f, 0.990405755399501260f, + -0.138189868194246560f, + 0.990379239617108160f, -0.138379773577783890f, 0.990352687421301450f, + -0.138569673873492500f, + 0.990326098813057330f, -0.138759569074390350f, 0.990299473793353590f, + -0.138949459173495490f, + 0.990272812363169110f, -0.139139344163826200f, 0.990246114523483990f, + -0.139329224038400980f, + 0.990219380275280000f, -0.139519098790238490f, 0.990192609619540030f, + -0.139708968412357550f, + 0.990165802557248400f, -0.139898832897777210f, 0.990138959089390650f, + -0.140088692239516670f, + 0.990112079216953770f, -0.140278546430595420f, 0.990085162940925970f, + -0.140468395464033000f, + 0.990058210262297120f, -0.140658239332849210f, 0.990031221182058000f, + -0.140848078030064080f, + 0.990004195701200910f, -0.141037911548697710f, 0.989977133820719610f, + -0.141227739881770510f, + 0.989950035541608990f, -0.141417563022303020f, 0.989922900864865450f, + -0.141607380963316020f, + 0.989895729791486660f, -0.141797193697830390f, 0.989868522322471580f, + -0.141987001218867290f, + 0.989841278458820530f, -0.142176803519448030f, 0.989813998201535260f, + -0.142366600592594180f, + 0.989786681551618640f, -0.142556392431327340f, 0.989759328510075200f, + -0.142746179028669460f, + 0.989731939077910570f, -0.142935960377642670f, 0.989704513256131850f, + -0.143125736471269190f, + 0.989677051045747210f, -0.143315507302571500f, 0.989649552447766530f, + -0.143505272864572290f, + 0.989622017463200890f, -0.143695033150294470f, 0.989594446093062460f, + -0.143884788152760980f, + 0.989566838338365120f, -0.144074537864995160f, 0.989539194200123930f, + -0.144264282280020440f, + 0.989511513679355190f, -0.144454021390860470f, 0.989483796777076760f, + -0.144643755190539040f, + 0.989456043494307710f, -0.144833483672080210f, 0.989428253832068230f, + -0.145023206828508220f, + 0.989400427791380380f, -0.145212924652847460f, 0.989372565373267010f, + -0.145402637138122570f, + 0.989344666578752640f, -0.145592344277358340f, 0.989316731408863000f, + -0.145782046063579860f, + 0.989288759864625170f, -0.145971742489812210f, 0.989260751947067640f, + -0.146161433549080900f, + 0.989232707657220050f, -0.146351119234411460f, 0.989204626996113780f, + -0.146540799538829760f, + 0.989176509964781010f, -0.146730474455361750f, 0.989148356564255590f, + -0.146920143977033620f, + 0.989120166795572690f, -0.147109808096871820f, 0.989091940659768800f, + -0.147299466807902850f, + 0.989063678157881540f, -0.147489120103153570f, 0.989035379290950310f, + -0.147678767975650970f, + 0.989007044060015270f, -0.147868410418422220f, 0.988978672466118480f, + -0.148058047424494720f, + 0.988950264510302990f, -0.148247678986896030f, 0.988921820193613190f, + -0.148437305098653970f, + 0.988893339517095130f, -0.148626925752796540f, 0.988864822481795640f, + -0.148816540942351920f, + 0.988836269088763540f, -0.149006150660348450f, 0.988807679339048450f, + -0.149195754899814820f, + 0.988779053233701520f, -0.149385353653779720f, 0.988750390773775360f, + -0.149574946915272230f, + 0.988721691960323780f, -0.149764534677321510f, 0.988692956794401940f, + -0.149954116932956960f, + 0.988664185277066230f, -0.150143693675208190f, 0.988635377409374790f, + -0.150333264897105000f, + 0.988606533192386450f, -0.150522830591677400f, 0.988577652627162020f, + -0.150712390751955610f, + 0.988548735714763200f, -0.150901945370970040f, 0.988519782456253270f, + -0.151091494441751300f, + 0.988490792852696590f, -0.151281037957330220f, 0.988461766905159300f, + -0.151470575910737810f, + 0.988432704614708340f, -0.151660108295005310f, 0.988403605982412390f, + -0.151849635103164180f, + 0.988374471009341280f, -0.152039156328246050f, 0.988345299696566150f, + -0.152228671963282740f, + 0.988316092045159690f, -0.152418182001306330f, 0.988286848056195820f, + -0.152607686435349050f, + 0.988257567730749460f, -0.152797185258443440f, 0.988228251069897420f, + -0.152986678463622040f, + 0.988198898074717610f, -0.153176166043917840f, 0.988169508746289060f, + -0.153365647992363880f, + 0.988140083085692570f, -0.153555124301993450f, 0.988110621094009820f, + -0.153744594965840030f, + 0.988081122772324070f, -0.153934059976937350f, 0.988051588121720110f, + -0.154123519328319360f, + 0.988022017143283530f, -0.154312973013020100f, 0.987992409838101880f, + -0.154502421024073940f, + 0.987962766207263420f, -0.154691863354515430f, 0.987933086251858380f, + -0.154881299997379320f, + 0.987903369972977790f, -0.155070730945700510f, 0.987873617371714200f, + -0.155260156192514240f, + 0.987843828449161740f, -0.155449575730855850f, 0.987814003206415550f, + -0.155638989553760900f, + 0.987784141644572180f, -0.155828397654265230f, 0.987754243764729530f, + -0.156017800025404800f, + 0.987724309567986960f, -0.156207196660215900f, 0.987694339055445130f, + -0.156396587551734880f, + 0.987664332228205710f, -0.156585972692998430f, 0.987634289087372160f, + -0.156775352077043350f, + 0.987604209634049160f, -0.156964725696906780f, 0.987574093869342360f, + -0.157154093545625900f, + 0.987543941794359230f, -0.157343455616238250f, 0.987513753410208420f, + -0.157532811901781530f, + 0.987483528717999710f, -0.157722162395293630f, 0.987453267718844560f, + -0.157911507089812660f, + 0.987422970413855410f, -0.158100845978376980f, 0.987392636804146240f, + -0.158290179054025180f, + 0.987362266890832400f, -0.158479506309795960f, 0.987331860675030430f, + -0.158668827738728310f, + 0.987301418157858430f, -0.158858143333861450f, 0.987270939340435420f, + -0.159047453088234760f, + 0.987240424223882250f, -0.159236756994887850f, 0.987209872809320820f, + -0.159426055046860580f, + 0.987179285097874340f, -0.159615347237193060f, 0.987148661090667570f, + -0.159804633558925440f, + 0.987118000788826280f, -0.159993914005098270f, 0.987087304193477900f, + -0.160183188568752220f, + 0.987056571305750970f, -0.160372457242928280f, 0.987025802126775600f, + -0.160561720020667490f, + 0.986994996657682980f, -0.160750976895011220f, 0.986964154899605650f, + -0.160940227859001080f, + 0.986933276853677710f, -0.161129472905678810f, 0.986902362521034470f, + -0.161318712028086400f, + 0.986871411902812470f, -0.161507945219266120f, 0.986840425000149680f, + -0.161697172472260400f, + 0.986809401814185530f, -0.161886393780111830f, 0.986778342346060430f, + -0.162075609135863330f, + 0.986747246596916590f, -0.162264818532558000f, 0.986716114567897100f, + -0.162454021963239190f, + 0.986684946260146690f, -0.162643219420950310f, 0.986653741674811350f, + -0.162832410898735210f, + 0.986622500813038480f, -0.163021596389637840f, 0.986591223675976400f, + -0.163210775886702380f, + 0.986559910264775410f, -0.163399949382973230f, 0.986528560580586690f, + -0.163589116871495020f, + 0.986497174624562880f, -0.163778278345312670f, 0.986465752397857940f, + -0.163967433797471170f, + 0.986434293901627180f, -0.164156583221015810f, 0.986402799137027220f, + -0.164345726608992190f, + 0.986371268105216030f, -0.164534863954446000f, 0.986339700807353000f, + -0.164723995250423170f, + 0.986308097244598670f, -0.164913120489969890f, 0.986276457418115090f, + -0.165102239666132660f, + 0.986244781329065460f, -0.165291352771958000f, 0.986213068978614490f, + -0.165480459800492780f, + 0.986181320367928270f, -0.165669560744784120f, 0.986149535498173860f, + -0.165858655597879300f, + 0.986117714370520090f, -0.166047744352825790f, 0.986085856986136820f, + -0.166236827002671420f, + 0.986053963346195440f, -0.166425903540464100f, 0.986022033451868560f, + -0.166614973959252090f, + 0.985990067304330140f, -0.166804038252083730f, 0.985958064904755460f, + -0.166993096412007710f, + 0.985926026254321130f, -0.167182148432072940f, 0.985893951354205210f, + -0.167371194305328430f, + 0.985861840205586980f, -0.167560234024823560f, 0.985829692809647050f, + -0.167749267583607890f, + 0.985797509167567480f, -0.167938294974731170f, 0.985765289280531310f, + -0.168127316191243410f, + 0.985733033149723490f, -0.168316331226194830f, 0.985700740776329850f, + -0.168505340072635900f, + 0.985668412161537550f, -0.168694342723617330f, 0.985636047306535420f, + -0.168883339172189980f, + 0.985603646212513400f, -0.169072329411405010f, 0.985571208880662740f, + -0.169261313434313830f, + 0.985538735312176060f, -0.169450291233967960f, 0.985506225508247290f, + -0.169639262803419290f, + 0.985473679470071810f, -0.169828228135719850f, 0.985441097198846210f, + -0.170017187223921950f, + 0.985408478695768420f, -0.170206140061078070f, 0.985375823962037710f, + -0.170395086640240940f, + 0.985343132998854790f, -0.170584026954463590f, 0.985310405807421570f, + -0.170772960996799230f, + 0.985277642388941220f, -0.170961888760301220f, 0.985244842744618540f, + -0.171150810238023280f, + 0.985212006875659350f, -0.171339725423019310f, 0.985179134783271130f, + -0.171528634308343420f, + 0.985146226468662230f, -0.171717536887049970f, 0.985113281933042710f, + -0.171906433152193530f, + 0.985080301177623800f, -0.172095323096829010f, 0.985047284203618200f, + -0.172284206714011370f, + 0.985014231012239840f, -0.172473083996795950f, 0.984981141604703960f, + -0.172661954938238270f, + 0.984948015982227030f, -0.172850819531394080f, 0.984914854146027200f, + -0.173039677769319360f, + 0.984881656097323700f, -0.173228529645070320f, 0.984848421837337010f, + -0.173417375151703470f, + 0.984815151367289140f, -0.173606214282275410f, 0.984781844688403350f, + -0.173795047029843160f, + 0.984748501801904210f, -0.173983873387463820f, 0.984715122709017620f, + -0.174172693348194820f, + 0.984681707410970940f, -0.174361506905093750f, 0.984648255908992630f, + -0.174550314051218510f, + 0.984614768204312600f, -0.174739114779627200f, 0.984581244298162180f, + -0.174927909083378160f, + 0.984547684191773960f, -0.175116696955529920f, 0.984514087886381840f, + -0.175305478389141320f, + 0.984480455383220930f, -0.175494253377271430f, 0.984446786683527920f, + -0.175683021912979490f, + 0.984413081788540700f, -0.175871783989325040f, 0.984379340699498510f, + -0.176060539599367820f, + 0.984345563417641900f, -0.176249288736167880f, 0.984311749944212780f, + -0.176438031392785410f, + 0.984277900280454370f, -0.176626767562280880f, 0.984244014427611110f, + -0.176815497237715000f, + 0.984210092386929030f, -0.177004220412148750f, 0.984176134159655320f, + -0.177192937078643280f, + 0.984142139747038570f, -0.177381647230260040f, 0.984108109150328540f, + -0.177570350860060710f, + 0.984074042370776450f, -0.177759047961107170f, 0.984039939409634970f, + -0.177947738526461560f, + 0.984005800268157870f, -0.178136422549186300f, 0.983971624947600270f, + -0.178325100022344000f, + 0.983937413449218920f, -0.178513770938997510f, 0.983903165774271500f, + -0.178702435292209970f, + 0.983868881924017220f, -0.178891093075044720f, 0.983834561899716630f, + -0.179079744280565390f, + 0.983800205702631600f, -0.179268388901835750f, 0.983765813334025240f, + -0.179457026931919890f, + 0.983731384795162090f, -0.179645658363882160f, 0.983696920087308140f, + -0.179834283190787090f, + 0.983662419211730250f, -0.180022901405699510f, 0.983627882169697210f, + -0.180211513001684450f, + 0.983593308962478650f, -0.180400117971807240f, 0.983558699591345900f, + -0.180588716309133340f, + 0.983524054057571260f, -0.180777308006728590f, 0.983489372362428730f, + -0.180965893057658980f, + 0.983454654507193270f, -0.181154471454990810f, 0.983419900493141540f, + -0.181343043191790540f, + 0.983385110321551180f, -0.181531608261124970f, 0.983350283993701500f, + -0.181720166656061110f, + 0.983315421510872810f, -0.181908718369666160f, 0.983280522874346970f, + -0.182097263395007650f, + 0.983245588085407070f, -0.182285801725153300f, 0.983210617145337640f, + -0.182474333353171120f, + 0.983175610055424420f, -0.182662858272129270f, 0.983140566816954500f, + -0.182851376475096330f, + 0.983105487431216290f, -0.183039887955140950f, 0.983070371899499640f, + -0.183228392705332140f, + 0.983035220223095640f, -0.183416890718739100f, 0.983000032403296590f, + -0.183605381988431270f, + 0.982964808441396440f, -0.183793866507478450f, 0.982929548338690170f, + -0.183982344268950520f, + 0.982894252096474070f, -0.184170815265917720f, 0.982858919716046110f, + -0.184359279491450510f, + 0.982823551198705240f, -0.184547736938619620f, 0.982788146545751970f, + -0.184736187600495950f, + 0.982752705758487830f, -0.184924631470150790f, 0.982717228838215990f, + -0.185113068540655540f, + 0.982681715786240860f, -0.185301498805081900f, 0.982646166603868050f, + -0.185489922256501880f, + 0.982610581292404750f, -0.185678338887987630f, 0.982574959853159240f, + -0.185866748692611660f, + 0.982539302287441240f, -0.186055151663446630f, 0.982503608596561830f, + -0.186243547793565560f, + 0.982467878781833170f, -0.186431937076041610f, 0.982432112844569110f, + -0.186620319503948280f, + 0.982396310786084690f, -0.186808695070359270f, 0.982360472607696210f, + -0.186997063768348540f, + 0.982324598310721280f, -0.187185425590990330f, 0.982288687896478830f, + -0.187373780531359110f, + 0.982252741366289370f, -0.187562128582529600f, 0.982216758721474510f, + -0.187750469737576780f, + 0.982180739963357090f, -0.187938803989575910f, 0.982144685093261580f, + -0.188127131331602420f, + 0.982108594112513610f, -0.188315451756732120f, 0.982072467022440000f, + -0.188503765258040940f, + 0.982036303824369020f, -0.188692071828605230f, 0.982000104519630490f, + -0.188880371461501380f, + 0.981963869109555240f, -0.189068664149806190f, 0.981927597595475540f, + -0.189256949886596750f, + 0.981891289978725100f, -0.189445228664950230f, 0.981854946260638630f, + -0.189633500477944190f, + 0.981818566442552500f, -0.189821765318656410f, 0.981782150525804310f, + -0.190010023180164990f, + 0.981745698511732990f, -0.190198274055548150f, 0.981709210401678800f, + -0.190386517937884470f, + 0.981672686196983110f, -0.190574754820252740f, 0.981636125898989080f, + -0.190762984695732110f, + 0.981599529509040720f, -0.190951207557401800f, 0.981562897028483650f, + -0.191139423398341450f, + 0.981526228458664770f, -0.191327632211630900f, 0.981489523800932130f, + -0.191515833990350210f, + 0.981452783056635520f, -0.191704028727579800f, 0.981416006227125550f, + -0.191892216416400220f, + 0.981379193313754560f, -0.192080397049892440f, 0.981342344317876040f, + -0.192268570621137500f, + 0.981305459240844670f, -0.192456737123216840f, 0.981268538084016710f, + -0.192644896549212100f, + 0.981231580848749730f, -0.192833048892205230f, 0.981194587536402320f, + -0.193021194145278380f, + 0.981157558148334830f, -0.193209332301513960f, 0.981120492685908730f, + -0.193397463353994740f, + 0.981083391150486710f, -0.193585587295803610f, 0.981046253543432780f, + -0.193773704120023820f, + 0.981009079866112630f, -0.193961813819738840f, 0.980971870119892840f, + -0.194149916388032450f, + 0.980934624306141640f, -0.194338011817988600f, 0.980897342426228390f, + -0.194526100102691610f, + 0.980860024481523870f, -0.194714181235225960f, 0.980822670473400100f, + -0.194902255208676520f, + 0.980785280403230430f, -0.195090322016128250f, 0.980747854272389750f, + -0.195278381650666550f, + 0.980710392082253970f, -0.195466434105376980f, 0.980672893834200530f, + -0.195654479373345370f, + 0.980635359529608120f, -0.195842517447657850f, 0.980597789169856850f, + -0.196030548321400790f, + 0.980560182756327840f, -0.196218571987660880f, 0.980522540290404090f, + -0.196406588439524970f, + 0.980484861773469380f, -0.196594597670080220f, 0.980447147206909060f, + -0.196782599672414100f, + 0.980409396592109910f, -0.196970594439614340f, 0.980371609930459800f, + -0.197158581964768880f, + 0.980333787223347960f, -0.197346562240965920f, 0.980295928472165290f, + -0.197534535261294030f, + 0.980258033678303550f, -0.197722501018841920f, 0.980220102843156080f, + -0.197910459506698670f, + 0.980182135968117430f, -0.198098410717953560f, 0.980144133054583590f, + -0.198286354645696220f, + 0.980106094103951770f, -0.198474291283016390f, 0.980068019117620650f, + -0.198662220623004200f, + 0.980029908096990090f, -0.198850142658750090f, 0.979991761043461200f, + -0.199038057383344680f, + 0.979953577958436740f, -0.199225964789878830f, 0.979915358843320480f, + -0.199413864871443770f, + 0.979877103699517640f, -0.199601757621130970f, 0.979838812528434740f, + -0.199789643032032090f, + 0.979800485331479790f, -0.199977521097239150f, 0.979762122110061750f, + -0.200165391809844440f, + 0.979723722865591170f, -0.200353255162940450f, 0.979685287599479930f, + -0.200541111149619980f, + 0.979646816313141210f, -0.200728959762976140f, 0.979608309007989450f, + -0.200916800996102230f, + 0.979569765685440520f, -0.201104634842091900f, 0.979531186346911500f, + -0.201292461294039020f, + 0.979492570993820810f, -0.201480280345037730f, 0.979453919627588210f, + -0.201668091988182530f, + 0.979415232249634780f, -0.201855896216568050f, 0.979376508861383170f, + -0.202043693023289260f, + 0.979337749464256780f, -0.202231482401441450f, 0.979298954059681040f, + -0.202419264344120160f, + 0.979260122649082020f, -0.202607038844421130f, 0.979221255233887700f, + -0.202794805895440440f, + 0.979182351815526930f, -0.202982565490274440f, 0.979143412395430230f, + -0.203170317622019790f, + 0.979104436975029250f, -0.203358062283773320f, 0.979065425555756930f, + -0.203545799468632190f, + 0.979026378139047580f, -0.203733529169693920f, 0.978987294726337050f, + -0.203921251380056120f, + 0.978948175319062200f, -0.204108966092816870f, 0.978909019918661310f, + -0.204296673301074370f, + 0.978869828526574120f, -0.204484372997927240f, 0.978830601144241470f, + -0.204672065176474210f, + 0.978791337773105670f, -0.204859749829814420f, 0.978752038414610340f, + -0.205047426951047250f, + 0.978712703070200420f, -0.205235096533272350f, 0.978673331741322210f, + -0.205422758569589610f, + 0.978633924429423210f, -0.205610413053099240f, 0.978594481135952270f, + -0.205798059976901790f, + 0.978555001862359550f, -0.205985699334097910f, 0.978515486610096910f, + -0.206173331117788710f, + 0.978475935380616830f, -0.206360955321075510f, 0.978436348175373730f, + -0.206548571937059890f, + 0.978396724995823090f, -0.206736180958843690f, 0.978357065843421640f, + -0.206923782379529100f, + 0.978317370719627650f, -0.207111376192218560f, 0.978277639625900530f, + -0.207298962390014750f, + 0.978237872563701090f, -0.207486540966020650f, 0.978198069534491400f, + -0.207674111913339570f, + 0.978158230539735050f, -0.207861675225075070f, 0.978118355580896660f, + -0.208049230894330940f, + 0.978078444659442380f, -0.208236778914211330f, 0.978038497776839600f, + -0.208424319277820600f, + 0.977998514934557140f, -0.208611851978263490f, 0.977958496134064830f, + -0.208799377008644900f, + 0.977918441376834370f, -0.208986894362070070f, 0.977878350664338150f, + -0.209174404031644580f, + 0.977838223998050430f, -0.209361906010474160f, 0.977798061379446360f, + -0.209549400291664940f, + 0.977757862810002760f, -0.209736886868323290f, 0.977717628291197460f, + -0.209924365733555880f, + 0.977677357824509930f, -0.210111836880469610f, 0.977637051411420770f, + -0.210299300302171730f, + 0.977596709053411890f, -0.210486755991769720f, 0.977556330751966460f, + -0.210674203942371440f, + 0.977515916508569280f, -0.210861644147084860f, 0.977475466324706170f, + -0.211049076599018390f, + 0.977434980201864260f, -0.211236501291280710f, 0.977394458141532250f, + -0.211423918216980670f, + 0.977353900145199960f, -0.211611327369227550f, 0.977313306214358750f, + -0.211798728741130840f, + 0.977272676350500860f, -0.211986122325800330f, 0.977232010555120320f, + -0.212173508116346080f, + 0.977191308829712280f, -0.212360886105878420f, 0.977150571175773200f, + -0.212548256287508060f, + 0.977109797594800880f, -0.212735618654345930f, 0.977068988088294450f, + -0.212922973199503180f, + 0.977028142657754390f, -0.213110319916091360f, 0.976987261304682390f, + -0.213297658797222320f, + 0.976946344030581670f, -0.213484989836008050f, 0.976905390836956490f, + -0.213672313025560970f, + 0.976864401725312640f, -0.213859628358993750f, 0.976823376697157240f, + -0.214046935829419360f, + 0.976782315753998650f, -0.214234235429950990f, 0.976741218897346550f, + -0.214421527153702160f, + 0.976700086128711840f, -0.214608810993786760f, 0.976658917449606980f, + -0.214796086943318860f, + 0.976617712861545640f, -0.214983354995412820f, 0.976576472366042610f, + -0.215170615143183390f, + 0.976535195964614470f, -0.215357867379745550f, 0.976493883658778650f, + -0.215545111698214500f, + 0.976452535450054060f, -0.215732348091705880f, 0.976411151339961040f, + -0.215919576553335490f, + 0.976369731330021140f, -0.216106797076219520f, 0.976328275421757260f, + -0.216294009653474340f, + 0.976286783616693630f, -0.216481214278216730f, 0.976245255916355800f, + -0.216668410943563730f, + 0.976203692322270560f, -0.216855599642632620f, 0.976162092835966110f, + -0.217042780368540990f, + 0.976120457458971910f, -0.217229953114406790f, 0.976078786192818850f, + -0.217417117873348190f, + 0.976037079039039020f, -0.217604274638483640f, 0.975995335999165990f, + -0.217791423402931950f, + 0.975953557074734300f, -0.217978564159812200f, 0.975911742267280170f, + -0.218165696902243800f, + 0.975869891578341030f, -0.218352821623346320f, 0.975828005009455660f, + -0.218539938316239770f, + 0.975786082562163930f, -0.218727046974044440f, 0.975744124238007270f, + -0.218914147589880840f, + 0.975702130038528570f, -0.219101240156869800f, 0.975660099965271590f, + -0.219288324668132470f, + 0.975618034019781750f, -0.219475401116790310f, 0.975575932203605720f, + -0.219662469495965050f, + 0.975533794518291360f, -0.219849529798778700f, 0.975491620965388110f, + -0.220036582018353580f, + 0.975449411546446380f, -0.220223626147812380f, 0.975407166263018270f, + -0.220410662180277940f, + 0.975364885116656980f, -0.220597690108873510f, 0.975322568108916930f, + -0.220784709926722610f, + 0.975280215241354220f, -0.220971721626949110f, 0.975237826515525820f, + -0.221158725202677010f, + 0.975195401932990370f, -0.221345720647030810f, 0.975152941495307620f, + -0.221532707953135230f, + 0.975110445204038890f, -0.221719687114115220f, 0.975067913060746470f, + -0.221906658123096100f, + 0.975025345066994120f, -0.222093620973203510f, 0.974982741224347140f, + -0.222280575657563370f, + 0.974940101534371830f, -0.222467522169301880f, 0.974897425998635820f, + -0.222654460501545500f, + 0.974854714618708430f, -0.222841390647421120f, 0.974811967396159830f, + -0.223028312600055820f, + 0.974769184332561770f, -0.223215226352576980f, 0.974726365429487320f, + -0.223402131898112370f, + 0.974683510688510670f, -0.223589029229789990f, 0.974640620111207560f, + -0.223775918340738150f, + 0.974597693699155050f, -0.223962799224085460f, 0.974554731453931230f, + -0.224149671872960870f, + 0.974511733377115720f, -0.224336536280493600f, 0.974468699470289580f, + -0.224523392439813170f, + 0.974425629735034990f, -0.224710240344049430f, 0.974382524172935470f, + -0.224897079986332490f, + 0.974339382785575860f, -0.225083911359792830f, 0.974296205574542440f, + -0.225270734457561160f, + 0.974252992541422500f, -0.225457549272768540f, 0.974209743687805220f, + -0.225644355798546330f, + 0.974166459015280320f, -0.225831154028026170f, 0.974123138525439640f, + -0.226017943954340020f, + 0.974079782219875680f, -0.226204725570620190f, 0.974036390100182610f, + -0.226391498869999240f, + 0.973992962167955830f, -0.226578263845610000f, 0.973949498424792170f, + -0.226765020490585690f, + 0.973905998872289570f, -0.226951768798059810f, 0.973862463512047300f, + -0.227138508761166170f, + 0.973818892345666100f, -0.227325240373038860f, 0.973775285374748110f, + -0.227511963626812280f, + 0.973731642600896400f, -0.227698678515621170f, 0.973687964025715670f, + -0.227885385032600530f, + 0.973644249650811980f, -0.228072083170885730f, 0.973600499477792370f, + -0.228258772923612380f, + 0.973556713508265560f, -0.228445454283916470f, 0.973512891743841370f, + -0.228632127244934230f, + 0.973469034186131070f, -0.228818791799802220f, 0.973425140836747030f, + -0.229005447941657340f, + 0.973381211697303290f, -0.229192095663636770f, 0.973337246769414910f, + -0.229378734958878010f, + 0.973293246054698250f, -0.229565365820518870f, 0.973249209554771230f, + -0.229751988241697490f, + 0.973205137271252800f, -0.229938602215552210f, 0.973161029205763530f, + -0.230125207735221850f, + 0.973116885359925130f, -0.230311804793845440f, 0.973072705735360530f, + -0.230498393384562350f, + 0.973028490333694210f, -0.230684973500512200f, 0.972984239156551740f, + -0.230871545134835020f, + 0.972939952205560180f, -0.231058108280671110f, 0.972895629482347760f, + -0.231244662931161050f, + 0.972851270988544180f, -0.231431209079445750f, 0.972806876725780370f, + -0.231617746718666470f, + 0.972762446695688570f, -0.231804275841964780f, 0.972717980899902250f, + -0.231990796442482440f, + 0.972673479340056430f, -0.232177308513361710f, 0.972628942017787270f, + -0.232363812047745030f, + 0.972584368934732210f, -0.232550307038775240f, 0.972539760092530180f, + -0.232736793479595390f, + 0.972495115492821190f, -0.232923271363348980f, 0.972450435137246830f, + -0.233109740683179690f, + 0.972405719027449770f, -0.233296201432231590f, 0.972360967165074140f, + -0.233482653603649090f, + 0.972316179551765300f, -0.233669097190576820f, 0.972271356189170040f, + -0.233855532186159840f, + 0.972226497078936270f, -0.234041958583543430f, 0.972181602222713440f, + -0.234228376375873210f, + 0.972136671622152230f, -0.234414785556295160f, 0.972091705278904430f, + -0.234601186117955550f, + 0.972046703194623500f, -0.234787578054000970f, 0.972001665370963890f, + -0.234973961357578250f, + 0.971956591809581720f, -0.235160336021834730f, 0.971911482512134000f, + -0.235346702039917840f, + 0.971866337480279400f, -0.235533059404975490f, 0.971821156715677700f, + -0.235719408110155820f, + 0.971775940219990140f, -0.235905748148607370f, 0.971730687994879160f, + -0.236092079513478910f, + 0.971685400042008540f, -0.236278402197919570f, 0.971640076363043390f, + -0.236464716195078780f, + 0.971594716959650160f, -0.236651021498106380f, 0.971549321833496630f, + -0.236837318100152380f, + 0.971503890986251780f, -0.237023605994367200f, 0.971458424419585960f, + -0.237209885173901600f, + 0.971412922135170940f, -0.237396155631906610f, 0.971367384134679490f, + -0.237582417361533570f, + 0.971321810419786160f, -0.237768670355934190f, 0.971276200992166490f, + -0.237954914608260540f, + 0.971230555853497380f, -0.238141150111664840f, 0.971184875005457030f, + -0.238327376859299810f, + 0.971139158449725090f, -0.238513594844318420f, 0.971093406187982460f, + -0.238699804059873980f, + 0.971047618221911100f, -0.238886004499120040f, 0.971001794553194690f, + -0.239072196155210610f, + 0.970955935183517970f, -0.239258379021299980f, 0.970910040114567050f, + -0.239444553090542630f, + 0.970864109348029470f, -0.239630718356093560f, 0.970818142885593870f, + -0.239816874811108000f, + 0.970772140728950350f, -0.240003022448741500f, 0.970726102879790110f, + -0.240189161262149900f, + 0.970680029339806130f, -0.240375291244489450f, 0.970633920110692160f, + -0.240561412388916650f, + 0.970587775194143630f, -0.240747524688588430f, 0.970541594591857070f, + -0.240933628136661910f, + 0.970495378305530560f, -0.241119722726294590f, 0.970449126336863090f, + -0.241305808450644370f, + 0.970402838687555500f, -0.241491885302869330f, 0.970356515359309450f, + -0.241677953276128010f, + 0.970310156353828110f, -0.241864012363579180f, 0.970263761672816140f, + -0.242050062558382070f, + 0.970217331317979160f, -0.242236103853696010f, 0.970170865291024480f, + -0.242422136242680890f, + 0.970124363593660280f, -0.242608159718496810f, 0.970077826227596420f, + -0.242794174274304220f, + 0.970031253194543970f, -0.242980179903263870f, 0.969984644496215240f, + -0.243166176598536900f, + 0.969938000134323960f, -0.243352164353284740f, 0.969891320110585100f, + -0.243538143160669130f, + 0.969844604426714830f, -0.243724113013852160f, 0.969797853084430890f, + -0.243910073905996260f, + 0.969751066085452140f, -0.244096025830264210f, 0.969704243431498860f, + -0.244281968779819030f, + 0.969657385124292450f, -0.244467902747824150f, 0.969610491165555870f, + -0.244653827727443320f, + 0.969563561557013180f, -0.244839743711840670f, 0.969516596300390000f, + -0.245025650694180470f, + 0.969469595397413060f, -0.245211548667627540f, 0.969422558849810320f, + -0.245397437625346960f, + 0.969375486659311280f, -0.245583317560504060f, 0.969328378827646660f, + -0.245769188466264580f, + 0.969281235356548530f, -0.245955050335794590f, 0.969234056247750050f, + -0.246140903162260530f, + 0.969186841502985950f, -0.246326746938829030f, 0.969139591123992280f, + -0.246512581658667210f, + 0.969092305112506210f, -0.246698407314942410f, 0.969044983470266240f, + -0.246884223900822430f, + 0.968997626199012420f, -0.247070031409475250f, 0.968950233300485800f, + -0.247255829834069300f, + 0.968902804776428870f, -0.247441619167773270f, 0.968855340628585580f, + -0.247627399403756280f, + 0.968807840858700970f, -0.247813170535187670f, 0.968760305468521430f, + -0.247998932555237110f, + 0.968712734459794780f, -0.248184685457074780f, 0.968665127834270060f, + -0.248370429233870980f, + 0.968617485593697540f, -0.248556163878796560f, 0.968569807739828930f, + -0.248741889385022480f, + 0.968522094274417380f, -0.248927605745720150f, 0.968474345199216820f, + -0.249113312954061360f, + 0.968426560515983190f, -0.249299011003218190f, 0.968378740226473300f, + -0.249484699886362960f, + 0.968330884332445190f, -0.249670379596668550f, 0.968282992835658660f, + -0.249856050127307990f, + 0.968235065737874320f, -0.250041711471454650f, 0.968187103040854420f, + -0.250227363622282370f, + 0.968139104746362440f, -0.250413006572965220f, 0.968091070856162970f, + -0.250598640316677670f, + 0.968043001372022260f, -0.250784264846594500f, 0.967994896295707670f, + -0.250969880155890720f, + 0.967946755628987800f, -0.251155486237741920f, 0.967898579373632660f, + -0.251341083085323880f, + 0.967850367531413620f, -0.251526670691812610f, 0.967802120104103270f, + -0.251712249050384700f, + 0.967753837093475510f, -0.251897818154216970f, 0.967705518501305480f, + -0.252083377996486450f, + 0.967657164329369880f, -0.252268928570370810f, 0.967608774579446500f, + -0.252454469869047740f, + 0.967560349253314360f, -0.252640001885695520f, 0.967511888352754150f, + -0.252825524613492610f, + 0.967463391879547550f, -0.253011038045617860f, 0.967414859835477480f, + -0.253196542175250560f, + 0.967366292222328510f, -0.253382036995570160f, 0.967317689041886310f, + -0.253567522499756560f, + 0.967269050295937790f, -0.253752998680989990f, 0.967220375986271420f, + -0.253938465532451090f, + 0.967171666114676640f, -0.254123923047320620f, 0.967122920682944360f, + -0.254309371218780000f, + 0.967074139692867040f, -0.254494810040010730f, 0.967025323146238010f, + -0.254680239504194830f, + 0.966976471044852070f, -0.254865659604514570f, 0.966927583390505660f, + -0.255051070334152470f, + 0.966878660184995910f, -0.255236471686291710f, 0.966829701430121810f, + -0.255421863654115460f, + 0.966780707127683270f, -0.255607246230807380f, 0.966731677279481840f, + -0.255792619409551610f, + 0.966682611887320080f, -0.255977983183532430f, 0.966633510953002100f, + -0.256163337545934460f, + 0.966584374478333120f, -0.256348682489942910f, 0.966535202465119700f, + -0.256534018008743040f, + 0.966485994915169840f, -0.256719344095520660f, 0.966436751830292650f, + -0.256904660743461910f, + 0.966387473212298900f, -0.257089967945753120f, 0.966338159063000130f, + -0.257275265695581120f, + 0.966288809384209690f, -0.257460553986133100f, 0.966239424177741890f, + -0.257645832810596390f, + 0.966190003445412500f, -0.257831102162158990f, 0.966140547189038750f, + -0.258016362034009020f, + 0.966091055410438830f, -0.258201612419334870f, 0.966041528111432400f, + -0.258386853311325600f, + 0.965991965293840570f, -0.258572084703170340f, 0.965942366959485540f, + -0.258757306588058680f, + 0.965892733110190860f, -0.258942518959180520f, 0.965843063747781510f, + -0.259127721809726150f, + 0.965793358874083680f, -0.259312915132886230f, 0.965743618490924830f, + -0.259498098921851660f, + 0.965693842600133690f, -0.259683273169813770f, 0.965644031203540590f, + -0.259868437869964270f, + 0.965594184302976830f, -0.260053593015495190f, 0.965544301900275180f, + -0.260238738599598840f, + 0.965494383997269500f, -0.260423874615468010f, 0.965444430595795430f, + -0.260609001056295750f, + 0.965394441697689400f, -0.260794117915275510f, 0.965344417304789370f, + -0.260979225185601070f, + 0.965294357418934660f, -0.261164322860466480f, 0.965244262041965780f, + -0.261349410933066350f, + 0.965194131175724720f, -0.261534489396595520f, 0.965143964822054450f, + -0.261719558244249030f, + 0.965093762982799590f, -0.261904617469222610f, 0.965043525659805890f, + -0.262089667064712040f, + 0.964993252854920320f, -0.262274707023913590f, 0.964942944569991410f, + -0.262459737340023980f, + 0.964892600806868890f, -0.262644758006240040f, 0.964842221567403620f, + -0.262829769015759160f, + 0.964791806853447900f, -0.263014770361779000f, 0.964741356666855340f, + -0.263199762037497560f, + 0.964690871009481030f, -0.263384744036113280f, 0.964640349883180930f, + -0.263569716350824880f, + 0.964589793289812760f, -0.263754678974831350f, 0.964539201231235150f, + -0.263939631901332350f, + 0.964488573709308410f, -0.264124575123527550f, 0.964437910725893910f, + -0.264309508634617110f, + 0.964387212282854290f, -0.264494432427801630f, 0.964336478382053720f, + -0.264679346496281890f, + 0.964285709025357480f, -0.264864250833259260f, 0.964234904214632200f, + -0.265049145431935250f, + 0.964184063951745830f, -0.265234030285511790f, 0.964133188238567640f, + -0.265418905387191260f, + 0.964082277076968140f, -0.265603770730176330f, 0.964031330468819280f, + -0.265788626307669920f, + 0.963980348415994110f, -0.265973472112875590f, 0.963929330920367140f, + -0.266158308138996990f, + 0.963878277983814200f, -0.266343134379238180f, 0.963827189608212340f, + -0.266527950826803690f, + 0.963776065795439840f, -0.266712757474898370f, 0.963724906547376530f, + -0.266897554316727350f, + 0.963673711865903230f, -0.267082341345496300f, 0.963622481752902220f, + -0.267267118554410930f, + 0.963571216210257320f, -0.267451885936677620f, 0.963519915239853140f, + -0.267636643485503090f, + 0.963468578843575950f, -0.267821391194094150f, 0.963417207023313350f, + -0.268006129055658290f, + 0.963365799780954050f, -0.268190857063403180f, 0.963314357118388200f, + -0.268375575210536900f, + 0.963262879037507070f, -0.268560283490267890f, 0.963211365540203480f, + -0.268744981895804980f, + 0.963159816628371360f, -0.268929670420357260f, 0.963108232303906190f, + -0.269114349057134380f, + 0.963056612568704340f, -0.269299017799346120f, 0.963004957424663850f, + -0.269483676640202840f, + 0.962953266873683880f, -0.269668325572915090f, 0.962901540917665000f, + -0.269852964590693860f, + 0.962849779558509030f, -0.270037593686750570f, 0.962797982798119010f, + -0.270222212854296870f, + 0.962746150638399410f, -0.270406822086544820f, 0.962694283081255930f, + -0.270591421376706940f, + 0.962642380128595710f, -0.270776010717996010f, 0.962590441782326890f, + -0.270960590103625170f, + 0.962538468044359160f, -0.271145159526808010f, 0.962486458916603450f, + -0.271329718980758420f, + 0.962434414400972100f, -0.271514268458690700f, 0.962382334499378380f, + -0.271698807953819510f, + 0.962330219213737400f, -0.271883337459359720f, 0.962278068545965090f, + -0.272067856968526920f, + 0.962225882497979020f, -0.272252366474536710f, 0.962173661071697880f, + -0.272436865970605240f, + 0.962121404269041580f, -0.272621355449948980f, 0.962069112091931580f, + -0.272805834905784810f, + 0.962016784542290560f, -0.272990304331329920f, 0.961964421622042320f, + -0.273174763719801930f, + 0.961912023333112210f, -0.273359213064418680f, 0.961859589677426570f, + -0.273543652358398730f, + 0.961807120656913540f, -0.273728081594960540f, 0.961754616273502010f, + -0.273912500767323260f, + 0.961702076529122540f, -0.274096909868706380f, 0.961649501425706820f, + -0.274281308892329660f, + 0.961596890965187860f, -0.274465697831413220f, 0.961544245149499990f, + -0.274650076679177680f, + 0.961491563980579000f, -0.274834445428843940f, 0.961438847460361680f, + -0.275018804073633220f, + 0.961386095590786250f, -0.275203152606767310f, 0.961333308373792270f, + -0.275387491021468140f, + 0.961280485811320640f, -0.275571819310958140f, 0.961227627905313460f, + -0.275756137468460120f, + 0.961174734657714080f, -0.275940445487197150f, 0.961121806070467380f, + -0.276124743360392830f, + 0.961068842145519350f, -0.276309031081271080f, 0.961015842884817230f, + -0.276493308643055990f, + 0.960962808290309780f, -0.276677576038972420f, 0.960909738363946770f, + -0.276861833262245280f, + 0.960856633107679660f, -0.277046080306099900f, 0.960803492523460760f, + -0.277230317163762170f, + 0.960750316613243950f, -0.277414543828458090f, 0.960697105378984450f, + -0.277598760293414290f, + 0.960643858822638590f, -0.277782966551857690f, 0.960590576946164120f, + -0.277967162597015370f, + 0.960537259751520050f, -0.278151348422115090f, 0.960483907240666790f, + -0.278335524020384920f, + 0.960430519415565790f, -0.278519689385053060f, 0.960377096278180130f, + -0.278703844509348490f, + 0.960323637830473920f, -0.278887989386500280f, 0.960270144074412800f, + -0.279072124009737800f, + 0.960216615011963430f, -0.279256248372291180f, 0.960163050645094000f, + -0.279440362467390510f, + 0.960109450975773940f, -0.279624466288266590f, 0.960055816005973890f, + -0.279808559828150390f, + 0.960002145737665960f, -0.279992643080273220f, 0.959948440172823210f, + -0.280176716037866980f, + 0.959894699313420530f, -0.280360778694163810f, 0.959840923161433770f, + -0.280544831042396250f, + 0.959787111718839900f, -0.280728873075797190f, 0.959733264987617680f, + -0.280912904787600000f, + 0.959679382969746750f, -0.281096926171038260f, 0.959625465667208190f, + -0.281280937219346110f, + 0.959571513081984520f, -0.281464937925757940f, 0.959517525216059260f, + -0.281648928283508630f, + 0.959463502071417510f, -0.281832908285833350f, 0.959409443650045550f, + -0.282016877925967640f, + 0.959355349953930790f, -0.282200837197147560f, 0.959301220985062210f, + -0.282384786092609360f, + 0.959247056745430090f, -0.282568724605589740f, 0.959192857237025740f, + -0.282752652729325930f, + 0.959138622461841890f, -0.282936570457055390f, 0.959084352421872730f, + -0.283120477782015820f, + 0.959030047119113660f, -0.283304374697445740f, 0.958975706555561080f, + -0.283488261196583550f, + 0.958921330733213170f, -0.283672137272668430f, 0.958866919654069010f, + -0.283856002918939750f, + 0.958812473320129310f, -0.284039858128637190f, 0.958757991733395710f, + -0.284223702895001040f, + 0.958703474895871600f, -0.284407537211271880f, 0.958648922809561150f, + -0.284591361070690440f, + 0.958594335476470220f, -0.284775174466498300f, 0.958539712898605730f, + -0.284958977391937040f, + 0.958485055077976100f, -0.285142769840248670f, 0.958430362016590930f, + -0.285326551804675870f, + 0.958375633716461170f, -0.285510323278461260f, 0.958320870179598880f, + -0.285694084254848320f, + 0.958266071408017670f, -0.285877834727080620f, 0.958211237403732260f, + -0.286061574688402040f, + 0.958156368168758820f, -0.286245304132057120f, 0.958101463705114730f, + -0.286429023051290700f, + 0.958046524014818600f, -0.286612731439347790f, 0.957991549099890370f, + -0.286796429289474080f, + 0.957936538962351420f, -0.286980116594915570f, 0.957881493604224370f, + -0.287163793348918390f, + 0.957826413027532910f, -0.287347459544729510f, 0.957771297234302320f, + -0.287531115175595930f, + 0.957716146226558870f, -0.287714760234765170f, 0.957660960006330610f, + -0.287898394715485170f, + 0.957605738575646350f, -0.288082018611004130f, 0.957550481936536470f, + -0.288265631914570770f, + 0.957495190091032570f, -0.288449234619434220f, 0.957439863041167680f, + -0.288632826718843830f, + 0.957384500788975860f, -0.288816408206049480f, 0.957329103336492790f, + -0.288999979074301420f, + 0.957273670685755200f, -0.289183539316850200f, 0.957218202838801210f, + -0.289367088926947010f, + 0.957162699797670210f, -0.289550627897843030f, 0.957107161564402790f, + -0.289734156222790250f, + 0.957051588141040970f, -0.289917673895040750f, 0.956995979529628230f, + -0.290101180907847090f, + 0.956940335732208820f, -0.290284677254462330f, 0.956884656750828900f, + -0.290468162928139820f, + 0.956828942587535370f, -0.290651637922133220f, 0.956773193244376930f, + -0.290835102229696830f, + 0.956717408723403050f, -0.291018555844085090f, 0.956661589026665090f, + -0.291201998758552900f, + 0.956605734156215080f, -0.291385430966355660f, 0.956549844114106820f, + -0.291568852460749040f, + 0.956493918902395100f, -0.291752263234989260f, 0.956437958523136180f, + -0.291935663282332780f, + 0.956381962978387730f, -0.292119052596036380f, 0.956325932270208230f, + -0.292302431169357560f, + 0.956269866400658030f, -0.292485798995553880f, 0.956213765371798470f, + -0.292669156067883460f, + 0.956157629185692140f, -0.292852502379604810f, 0.956101457844403040f, + -0.293035837923976810f, + 0.956045251349996410f, -0.293219162694258630f, 0.955989009704538930f, + -0.293402476683710110f, + 0.955932732910098280f, -0.293585779885591200f, 0.955876420968743590f, + -0.293769072293162400f, + 0.955820073882545420f, -0.293952353899684660f, 0.955763691653575440f, + -0.294135624698419030f, + 0.955707274283906560f, -0.294318884682627400f, 0.955650821775613330f, + -0.294502133845571670f, + 0.955594334130771110f, -0.294685372180514330f, 0.955537811351456880f, + -0.294868599680718270f, + 0.955481253439748770f, -0.295051816339446720f, 0.955424660397726330f, + -0.295235022149963220f, + 0.955368032227470350f, -0.295418217105532010f, 0.955311368931062720f, + -0.295601401199417360f, + 0.955254670510586990f, -0.295784574424884260f, 0.955197936968127710f, + -0.295967736775197890f, + 0.955141168305770780f, -0.296150888243623790f, 0.955084364525603410f, + -0.296334028823428190f, + 0.955027525629714160f, -0.296517158507877470f, 0.954970651620192790f, + -0.296700277290238350f, + 0.954913742499130520f, -0.296883385163778270f, 0.954856798268619580f, + -0.297066482121764730f, + 0.954799818930753720f, -0.297249568157465840f, 0.954742804487627940f, + -0.297432643264150030f, + 0.954685754941338340f, -0.297615707435086200f, 0.954628670293982680f, + -0.297798760663543550f, + 0.954571550547659630f, -0.297981802942791810f, 0.954514395704469500f, + -0.298164834266100850f, + 0.954457205766513490f, -0.298347854626741400f, 0.954399980735894490f, + -0.298530864017984120f, + 0.954342720614716480f, -0.298713862433100330f, 0.954285425405084650f, + -0.298896849865361800f, + 0.954228095109105670f, -0.299079826308040480f, 0.954170729728887280f, + -0.299262791754408840f, + 0.954113329266538800f, -0.299445746197739890f, 0.954055893724170660f, + -0.299628689631306790f, + 0.953998423103894490f, -0.299811622048383350f, 0.953940917407823500f, + -0.299994543442243580f, + 0.953883376638071770f, -0.300177453806161950f, 0.953825800796755050f, + -0.300360353133413530f, + 0.953768189885990330f, -0.300543241417273450f, 0.953710543907895670f, + -0.300726118651017500f, + 0.953652862864590500f, -0.300908984827921890f, 0.953595146758195680f, + -0.301091839941263100f, + 0.953537395590833280f, -0.301274683984317950f, 0.953479609364626610f, + -0.301457516950363940f, + 0.953421788081700310f, -0.301640338832678770f, 0.953363931744180330f, + -0.301823149624540650f, + 0.953306040354193860f, -0.302005949319228080f, 0.953248113913869320f, + -0.302188737910019990f, + 0.953190152425336670f, -0.302371515390195970f, 0.953132155890726750f, + -0.302554281753035610f, + 0.953074124312172200f, -0.302737036991819140f, 0.953016057691806530f, + -0.302919781099827310f, + 0.952957956031764700f, -0.303102514070341060f, 0.952899819334182880f, + -0.303285235896641750f, + 0.952841647601198720f, -0.303467946572011320f, 0.952783440834950920f, + -0.303650646089731910f, + 0.952725199037579570f, -0.303833334443086360f, 0.952666922211226170f, + -0.304016011625357570f, + 0.952608610358033350f, -0.304198677629829110f, 0.952550263480144930f, + -0.304381332449784880f, + 0.952491881579706320f, -0.304563976078509100f, 0.952433464658864030f, + -0.304746608509286530f, + 0.952375012719765880f, -0.304929229735402370f, 0.952316525764560940f, + -0.305111839750142110f, + 0.952258003795399600f, -0.305294438546791670f, 0.952199446814433580f, + -0.305477026118637420f, + 0.952140854823815830f, -0.305659602458966120f, 0.952082227825700620f, + -0.305842167561065080f, + 0.952023565822243570f, -0.306024721418221790f, 0.951964868815601380f, + -0.306207264023724220f, + 0.951906136807932350f, -0.306389795370860920f, 0.951847369801395620f, + -0.306572315452920740f, + 0.951788567798152130f, -0.306754824263192780f, 0.951729730800363830f, + -0.306937321794966910f, + 0.951670858810193860f, -0.307119808041533100f, 0.951611951829806850f, + -0.307302282996181790f, + 0.951553009861368590f, -0.307484746652204100f, 0.951494032907046370f, + -0.307667199002891190f, + 0.951435020969008340f, -0.307849640041534870f, 0.951375974049424420f, + -0.308032069761427330f, + 0.951316892150465550f, -0.308214488155861050f, 0.951257775274304000f, + -0.308396895218129190f, + 0.951198623423113230f, -0.308579290941525090f, 0.951139436599068190f, + -0.308761675319342450f, + 0.951080214804345010f, -0.308944048344875710f, 0.951020958041121080f, + -0.309126410011419440f, + 0.950961666311575080f, -0.309308760312268730f, 0.950902339617887060f, + -0.309491099240719100f, + 0.950842977962238160f, -0.309673426790066380f, 0.950783581346811070f, + -0.309855742953607070f, + 0.950724149773789610f, -0.310038047724637890f, 0.950664683245358910f, + -0.310220341096455850f, + 0.950605181763705340f, -0.310402623062358720f, 0.950545645331016600f, + -0.310584893615644450f, + 0.950486073949481700f, -0.310767152749611470f, 0.950426467621290900f, + -0.310949400457558640f, + 0.950366826348635780f, -0.311131636732785270f, 0.950307150133709260f, + -0.311313861568590920f, + 0.950247438978705230f, -0.311496074958275910f, 0.950187692885819280f, + -0.311678276895140550f, + 0.950127911857248100f, -0.311860467372486020f, 0.950068095895189590f, + -0.312042646383613510f, + 0.950008245001843000f, -0.312224813921824880f, 0.949948359179409010f, + -0.312406969980422440f, + 0.949888438430089300f, -0.312589114552708710f, 0.949828482756087110f, + -0.312771247631986770f, + 0.949768492159606680f, -0.312953369211560200f, 0.949708466642853800f, + -0.313135479284732840f, + 0.949648406208035480f, -0.313317577844809010f, 0.949588310857359950f, + -0.313499664885093510f, + 0.949528180593036670f, -0.313681740398891520f, 0.949468015417276550f, + -0.313863804379508500f, + 0.949407815332291570f, -0.314045856820250710f, 0.949347580340295210f, + -0.314227897714424440f, + 0.949287310443502120f, -0.314409927055336660f, 0.949227005644128210f, + -0.314591944836294660f, + 0.949166665944390700f, -0.314773951050606070f, 0.949106291346508260f, + -0.314955945691579140f, + 0.949045881852700560f, -0.315137928752522440f, 0.948985437465188710f, + -0.315319900226744890f, + 0.948924958186195160f, -0.315501860107555990f, 0.948864444017943340f, + -0.315683808388265650f, + 0.948803894962658490f, -0.315865745062183960f, 0.948743311022566480f, + -0.316047670122621860f, + 0.948682692199895090f, -0.316229583562890330f, 0.948622038496872990f, + -0.316411485376300980f, + 0.948561349915730270f, -0.316593375556165850f, 0.948500626458698260f, + -0.316775254095797270f, + 0.948439868128009620f, -0.316957120988508150f, 0.948379074925898120f, + -0.317138976227611780f, + 0.948318246854599090f, -0.317320819806421740f, 0.948257383916349060f, + -0.317502651718252260f, + 0.948196486113385580f, -0.317684471956417970f, 0.948135553447947980f, + -0.317866280514233660f, + 0.948074585922276230f, -0.318048077385014950f, 0.948013583538612200f, + -0.318229862562077530f, + 0.947952546299198670f, -0.318411636038737790f, 0.947891474206279840f, + -0.318593397808312420f, + 0.947830367262101010f, -0.318775147864118480f, 0.947769225468909180f, + -0.318956886199473650f, + 0.947708048828952100f, -0.319138612807695900f, 0.947646837344479300f, + -0.319320327682103610f, + 0.947585591017741090f, -0.319502030816015690f, 0.947524309850989570f, + -0.319683722202751430f, + 0.947462993846477700f, -0.319865401835630500f, 0.947401643006459900f, + -0.320047069707973140f, + 0.947340257333192050f, -0.320228725813099860f, 0.947278836828930880f, + -0.320410370144331820f, + 0.947217381495934820f, -0.320592002694990330f, 0.947155891336463270f, + -0.320773623458397330f, + 0.947094366352777220f, -0.320955232427875210f, 0.947032806547138620f, + -0.321136829596746660f, + 0.946971211921810880f, -0.321318414958334850f, 0.946909582479058760f, + -0.321499988505963510f, + 0.946847918221148000f, -0.321681550232956580f, 0.946786219150346000f, + -0.321863100132638580f, + 0.946724485268921170f, -0.322044638198334510f, 0.946662716579143360f, + -0.322226164423369600f, + 0.946600913083283530f, -0.322407678801069850f, 0.946539074783614100f, + -0.322589181324761330f, + 0.946477201682408680f, -0.322770671987770710f, 0.946415293781942110f, + -0.322952150783425260f, + 0.946353351084490590f, -0.323133617705052330f, 0.946291373592331620f, + -0.323315072745979980f, + 0.946229361307743820f, -0.323496515899536710f, 0.946167314233007370f, + -0.323677947159051240f, + 0.946105232370403450f, -0.323859366517852850f, 0.946043115722214560f, + -0.324040773969271450f, + 0.945980964290724760f, -0.324222169506636960f, 0.945918778078219110f, + -0.324403553123280230f, + 0.945856557086983910f, -0.324584924812532150f, 0.945794301319306970f, + -0.324766284567724220f, + 0.945732010777477150f, -0.324947632382188430f, 0.945669685463784710f, + -0.325128968249257080f, + 0.945607325380521280f, -0.325310292162262930f, 0.945544930529979680f, + -0.325491604114539310f, + 0.945482500914453740f, -0.325672904099419850f, 0.945420036536239070f, + -0.325854192110238580f, + 0.945357537397632290f, -0.326035468140330240f, 0.945295003500931210f, + -0.326216732183029710f, + 0.945232434848435000f, -0.326397984231672490f, 0.945169831442444150f, + -0.326579224279594400f, + 0.945107193285260610f, -0.326760452320131730f, 0.945044520379187070f, + -0.326941668346621420f, + 0.944981812726528150f, -0.327122872352400510f, 0.944919070329589220f, + -0.327304064330806670f, + 0.944856293190677210f, -0.327485244275178000f, 0.944793481312100280f, + -0.327666412178853120f, + 0.944730634696167800f, -0.327847568035170840f, 0.944667753345190490f, + -0.328028711837470680f, + 0.944604837261480260f, -0.328209843579092500f, 0.944541886447350490f, + -0.328390963253376580f, + 0.944478900905115550f, -0.328572070853663740f, 0.944415880637091250f, + -0.328753166373294990f, + 0.944352825645594750f, -0.328934249805612200f, 0.944289735932944410f, + -0.329115321143957250f, + 0.944226611501459810f, -0.329296380381672750f, 0.944163452353461770f, + -0.329477427512101740f, + 0.944100258491272660f, -0.329658462528587490f, 0.944037029917215830f, + -0.329839485424473940f, + 0.943973766633615980f, -0.330020496193105420f, 0.943910468642799150f, + -0.330201494827826570f, + 0.943847135947092690f, -0.330382481321982780f, 0.943783768548825060f, + -0.330563455668919540f, + 0.943720366450326200f, -0.330744417861982890f, 0.943656929653927220f, + -0.330925367894519540f, + 0.943593458161960390f, -0.331106305759876430f, 0.943529951976759480f, + -0.331287231451400820f, + 0.943466411100659320f, -0.331468144962440870f, 0.943402835535996240f, + -0.331649046286344670f, + 0.943339225285107720f, -0.331829935416461110f, 0.943275580350332540f, + -0.332010812346139380f, + 0.943211900734010620f, -0.332191677068729150f, 0.943148186438483420f, + -0.332372529577580620f, + 0.943084437466093490f, -0.332553369866044220f, 0.943020653819184650f, + -0.332734197927471050f, + 0.942956835500102120f, -0.332915013755212650f, 0.942892982511192250f, + -0.333095817342620780f, + 0.942829094854802710f, -0.333276608683047930f, 0.942765172533282510f, + -0.333457387769846850f, + 0.942701215548981900f, -0.333638154596370860f, 0.942637223904252530f, + -0.333818909155973620f, + 0.942573197601446870f, -0.333999651442009380f, 0.942509136642919240f, + -0.334180381447832690f, + 0.942445041031024890f, -0.334361099166798740f, 0.942380910768120470f, + -0.334541804592262900f, + 0.942316745856563780f, -0.334722497717581220f, 0.942252546298714020f, + -0.334903178536110180f, + 0.942188312096931770f, -0.335083847041206580f, 0.942124043253578570f, + -0.335264503226227810f, + 0.942059739771017310f, -0.335445147084531600f, 0.941995401651612550f, + -0.335625778609476290f, + 0.941931028897729620f, -0.335806397794420450f, 0.941866621511735280f, + -0.335987004632723350f, + 0.941802179495997650f, -0.336167599117744520f, 0.941737702852886160f, + -0.336348181242844050f, + 0.941673191584771360f, -0.336528751001382410f, 0.941608645694025250f, + -0.336709308386720580f, + 0.941544065183020810f, -0.336889853392220050f, 0.941479450054132580f, + -0.337070386011242620f, + 0.941414800309736340f, -0.337250906237150590f, 0.941350115952208970f, + -0.337431414063306840f, + 0.941285396983928660f, -0.337611909483074620f, 0.941220643407275180f, + -0.337792392489817460f, + 0.941155855224629190f, -0.337972863076899720f, 0.941091032438372780f, + -0.338153321237685930f, + 0.941026175050889260f, -0.338333766965541130f, 0.940961283064563280f, + -0.338514200253830940f, + 0.940896356481780830f, -0.338694621095921190f, 0.940831395304928870f, + -0.338875029485178450f, + 0.940766399536396070f, -0.339055425414969640f, 0.940701369178571940f, + -0.339235808878661950f, + 0.940636304233847590f, -0.339416179869623360f, 0.940571204704615190f, + -0.339596538381222110f, + 0.940506070593268300f, -0.339776884406826850f, 0.940440901902201750f, + -0.339957217939806880f, + 0.940375698633811540f, -0.340137538973531720f, 0.940310460790495070f, + -0.340317847501371670f, + 0.940245188374650880f, -0.340498143516697160f, 0.940179881388678920f, + -0.340678427012879200f, + 0.940114539834980280f, -0.340858697983289440f, 0.940049163715957370f, + -0.341038956421299720f, + 0.939983753034014050f, -0.341219202320282360f, 0.939918307791555050f, + -0.341399435673610420f, + 0.939852827990986680f, -0.341579656474657160f, 0.939787313634716570f, + -0.341759864716796310f, + 0.939721764725153340f, -0.341940060393402190f, 0.939656181264707180f, + -0.342120243497849530f, + 0.939590563255789270f, -0.342300414023513520f, 0.939524910700812230f, + -0.342480571963769800f, + 0.939459223602189920f, -0.342660717311994380f, 0.939393501962337510f, + -0.342840850061563950f, + 0.939327745783671400f, -0.343020970205855540f, 0.939261955068609210f, + -0.343201077738246540f, + 0.939196129819569900f, -0.343381172652115040f, 0.939130270038973650f, + -0.343561254940839390f, + 0.939064375729241950f, -0.343741324597798490f, 0.938998446892797540f, + -0.343921381616371700f, + 0.938932483532064600f, -0.344101425989938810f, 0.938866485649468060f, + -0.344281457711880180f, + 0.938800453247434770f, -0.344461476775576540f, 0.938734386328392460f, + -0.344641483174408960f, + 0.938668284894770170f, -0.344821476901759290f, 0.938602148948998400f, + -0.345001457951009670f, + 0.938535978493508560f, -0.345181426315542550f, 0.938469773530733800f, + -0.345361381988741220f, + 0.938403534063108060f, -0.345541324963989090f, 0.938337260093066950f, + -0.345721255234670120f, + 0.938270951623047190f, -0.345901172794168990f, 0.938204608655486490f, + -0.346081077635870430f, + 0.938138231192824360f, -0.346260969753160010f, 0.938071819237501270f, + -0.346440849139423520f, + 0.938005372791958840f, -0.346620715788047320f, 0.937938891858640320f, + -0.346800569692418290f, + 0.937872376439989890f, -0.346980410845923680f, 0.937805826538453120f, + -0.347160239241951160f, + 0.937739242156476970f, -0.347340054873889140f, 0.937672623296509470f, + -0.347519857735126110f, + 0.937605969960999990f, -0.347699647819051380f, 0.937539282152399230f, + -0.347879425119054510f, + 0.937472559873159250f, -0.348059189628525610f, 0.937405803125732960f, + -0.348238941340855260f, + 0.937339011912574960f, -0.348418680249434560f, 0.937272186236140950f, + -0.348598406347654930f, + 0.937205326098887960f, -0.348778119628908420f, 0.937138431503274140f, + -0.348957820086587490f, + 0.937071502451759190f, -0.349137507714084970f, 0.937004538946803690f, + -0.349317182504794380f, + 0.936937540990869900f, -0.349496844452109550f, 0.936870508586420960f, + -0.349676493549424760f, + 0.936803441735921560f, -0.349856129790134920f, 0.936736340441837620f, + -0.350035753167635240f, + 0.936669204706636170f, -0.350215363675321580f, 0.936602034532785570f, + -0.350394961306590150f, + 0.936534829922755500f, -0.350574546054837510f, 0.936467590879016990f, + -0.350754117913461060f, + 0.936400317404042060f, -0.350933676875858360f, 0.936333009500304180f, + -0.351113222935427460f, + 0.936265667170278260f, -0.351292756085567090f, 0.936198290416440090f, + -0.351472276319676310f, + 0.936130879241267030f, -0.351651783631154570f, 0.936063433647237540f, + -0.351831278013402030f, + 0.935995953636831410f, -0.352010759459819080f, 0.935928439212529660f, + -0.352190227963806830f, + 0.935860890376814640f, -0.352369683518766630f, 0.935793307132169900f, + -0.352549126118100460f, + 0.935725689481080370f, -0.352728555755210730f, 0.935658037426032040f, + -0.352907972423500250f, + 0.935590350969512370f, -0.353087376116372480f, 0.935522630114009930f, + -0.353266766827231240f, + 0.935454874862014620f, -0.353446144549480810f, 0.935387085216017770f, + -0.353625509276525970f, + 0.935319261178511610f, -0.353804861001772050f, 0.935251402751989920f, + -0.353984199718624770f, + 0.935183509938947610f, -0.354163525420490340f, 0.935115582741880890f, + -0.354342838100775550f, + 0.935047621163287430f, -0.354522137752887430f, 0.934979625205665800f, + -0.354701424370233830f, + 0.934911594871516090f, -0.354880697946222790f, 0.934843530163339540f, + -0.355059958474262860f, + 0.934775431083638700f, -0.355239205947763310f, 0.934707297634917440f, + -0.355418440360133650f, + 0.934639129819680780f, -0.355597661704783850f, 0.934570927640435030f, + -0.355776869975124640f, + 0.934502691099687870f, -0.355956065164566850f, 0.934434420199948050f, + -0.356135247266522130f, + 0.934366114943725790f, -0.356314416274402410f, 0.934297775333532530f, + -0.356493572181620090f, + 0.934229401371880820f, -0.356672714981588260f, 0.934160993061284530f, + -0.356851844667720300f, + 0.934092550404258980f, -0.357030961233429980f, 0.934024073403320390f, + -0.357210064672131960f, + 0.933955562060986730f, -0.357389154977240940f, 0.933887016379776890f, + -0.357568232142172260f, + 0.933818436362210960f, -0.357747296160341900f, 0.933749822010810580f, + -0.357926347025166010f, + 0.933681173328098410f, -0.358105384730061590f, 0.933612490316598540f, + -0.358284409268445850f, + 0.933543772978836170f, -0.358463420633736540f, 0.933475021317337950f, + -0.358642418819351990f, + 0.933406235334631520f, -0.358821403818710860f, 0.933337415033246190f, + -0.359000375625232460f, + 0.933268560415712050f, -0.359179334232336500f, 0.933199671484560730f, + -0.359358279633443130f, + 0.933130748242325230f, -0.359537211821973070f, 0.933061790691539380f, + -0.359716130791347570f, + 0.932992798834738960f, -0.359895036534988110f, 0.932923772674460140f, + -0.360073929046317020f, + 0.932854712213241120f, -0.360252808318756890f, 0.932785617453621100f, + -0.360431674345730700f, + 0.932716488398140250f, -0.360610527120662270f, 0.932647325049340450f, + -0.360789366636975580f, + 0.932578127409764420f, -0.360968192888095230f, 0.932508895481956590f, + -0.361147005867446250f, + 0.932439629268462360f, -0.361325805568454280f, 0.932370328771828460f, + -0.361504591984545260f, + 0.932300993994602760f, -0.361683365109145840f, 0.932231624939334540f, + -0.361862124935682980f, + 0.932162221608574430f, -0.362040871457584180f, 0.932092784004874050f, + -0.362219604668277460f, + 0.932023312130786490f, -0.362398324561191310f, 0.931953805988866010f, + -0.362577031129754760f, + 0.931884265581668150f, -0.362755724367397230f, 0.931814690911749730f, + -0.362934404267548640f, + 0.931745081981668720f, -0.363113070823639470f, 0.931675438793984620f, + -0.363291724029100760f, + 0.931605761351257830f, -0.363470363877363760f, 0.931536049656050300f, + -0.363648990361860550f, + 0.931466303710925090f, -0.363827603476023500f, 0.931396523518446600f, + -0.364006203213285470f, + 0.931326709081180430f, -0.364184789567079890f, 0.931256860401693420f, + -0.364363362530840620f, + 0.931186977482553750f, -0.364541922098002120f, 0.931117060326330790f, + -0.364720468261999280f, + 0.931047108935595280f, -0.364899001016267320f, 0.930977123312918930f, + -0.365077520354242180f, + 0.930907103460875130f, -0.365256026269360320f, 0.930837049382038150f, + -0.365434518755058390f, + 0.930766961078983710f, -0.365612997804773850f, 0.930696838554288860f, + -0.365791463411944570f, + 0.930626681810531760f, -0.365969915570008740f, 0.930556490850291800f, + -0.366148354272405330f, + 0.930486265676149780f, -0.366326779512573590f, 0.930416006290687550f, + -0.366505191283953370f, + 0.930345712696488470f, -0.366683589579984930f, 0.930275384896137150f, + -0.366861974394109060f, + 0.930205022892219070f, -0.367040345719767180f, 0.930134626687321390f, + -0.367218703550400980f, + 0.930064196284032360f, -0.367397047879452710f, 0.929993731684941480f, + -0.367575378700365330f, + 0.929923232892639670f, -0.367753696006581980f, 0.929852699909718750f, + -0.367931999791546450f, + 0.929782132738772190f, -0.368110290048703050f, 0.929711531382394370f, + -0.368288566771496570f, + 0.929640895843181330f, -0.368466829953372320f, 0.929570226123729860f, + -0.368645079587776040f, + 0.929499522226638560f, -0.368823315668153910f, 0.929428784154506800f, + -0.369001538187952780f, + 0.929358011909935500f, -0.369179747140620020f, 0.929287205495526790f, + -0.369357942519603130f, + 0.929216364913884040f, -0.369536124318350650f, 0.929145490167611720f, + -0.369714292530311240f, + 0.929074581259315860f, -0.369892447148934100f, 0.929003638191603360f, + -0.370070588167669080f, + 0.928932660967082820f, -0.370248715579966360f, 0.928861649588363700f, + -0.370426829379276790f, + 0.928790604058057020f, -0.370604929559051670f, 0.928719524378774810f, + -0.370783016112742560f, + 0.928648410553130520f, -0.370961089033801980f, 0.928577262583738850f, + -0.371139148315682570f, + 0.928506080473215590f, -0.371317193951837540f, 0.928434864224177980f, + -0.371495225935720760f, + 0.928363613839244370f, -0.371673244260786520f, 0.928292329321034670f, + -0.371851248920489490f, + 0.928221010672169440f, -0.372029239908285010f, 0.928149657895271150f, + -0.372207217217628840f, + 0.928078270992963140f, -0.372385180841977360f, 0.928006849967869970f, + -0.372563130774787250f, + 0.927935394822617890f, -0.372741067009515760f, 0.927863905559833780f, + -0.372918989539620830f, + 0.927792382182146320f, -0.373096898358560640f, 0.927720824692185200f, + -0.373274793459793970f, + 0.927649233092581180f, -0.373452674836780300f, 0.927577607385966730f, + -0.373630542482979280f, + 0.927505947574975180f, -0.373808396391851210f, 0.927434253662241300f, + -0.373986236556857030f, + 0.927362525650401110f, -0.374164062971457930f, 0.927290763542091720f, + -0.374341875629115920f, + 0.927218967339951790f, -0.374519674523293210f, 0.927147137046620880f, + -0.374697459647452600f, + 0.927075272664740100f, -0.374875230995057540f, 0.927003374196951670f, + -0.375052988559571920f, + 0.926931441645899130f, -0.375230732334459920f, 0.926859475014227160f, + -0.375408462313186590f, + 0.926787474304581750f, -0.375586178489217220f, 0.926715439519610330f, + -0.375763880856017700f, + 0.926643370661961230f, -0.375941569407054420f, 0.926571267734284330f, + -0.376119244135794340f, + 0.926499130739230510f, -0.376296905035704790f, 0.926426959679452210f, + -0.376474552100253770f, + 0.926354754557602860f, -0.376652185322909560f, 0.926282515376337210f, + -0.376829804697141280f, + 0.926210242138311380f, -0.377007410216418260f, 0.926137934846182560f, + -0.377185001874210450f, + 0.926065593502609310f, -0.377362579663988340f, 0.925993218110251480f, + -0.377540143579222940f, + 0.925920808671770070f, -0.377717693613385640f, 0.925848365189827270f, + -0.377895229759948490f, + 0.925775887667086740f, -0.378072752012383990f, 0.925703376106213230f, + -0.378250260364165200f, + 0.925630830509872720f, -0.378427754808765560f, 0.925558250880732740f, + -0.378605235339659120f, + 0.925485637221461490f, -0.378782701950320540f, 0.925412989534729060f, + -0.378960154634224720f, + 0.925340307823206310f, -0.379137593384847320f, 0.925267592089565660f, + -0.379315018195664430f, + 0.925194842336480530f, -0.379492429060152630f, 0.925122058566625880f, + -0.379669825971788940f, + 0.925049240782677580f, -0.379847208924051160f, 0.924976388987313160f, + -0.380024577910417270f, + 0.924903503183210910f, -0.380201932924366050f, 0.924830583373050800f, + -0.380379273959376600f, + 0.924757629559513910f, -0.380556601008928520f, 0.924684641745282420f, + -0.380733914066502140f, + 0.924611619933039970f, -0.380911213125578070f, 0.924538564125471420f, + -0.381088498179637520f, + 0.924465474325262600f, -0.381265769222162380f, 0.924392350535101050f, + -0.381443026246634730f, + 0.924319192757675160f, -0.381620269246537360f, 0.924246000995674890f, + -0.381797498215353640f, + 0.924172775251791200f, -0.381974713146567220f, 0.924099515528716280f, + -0.382151914033662610f, + 0.924026221829143850f, -0.382329100870124510f, 0.923952894155768640f, + -0.382506273649438230f, + 0.923879532511286740f, -0.382683432365089780f, 0.923806136898395410f, + -0.382860577010565420f, + 0.923732707319793290f, -0.383037707579352020f, 0.923659243778179980f, + -0.383214824064937180f, + 0.923585746276256670f, -0.383391926460808660f, 0.923512214816725630f, + -0.383569014760454910f, + 0.923438649402290370f, -0.383746088957365010f, 0.923365050035655720f, + -0.383923149045028390f, + 0.923291416719527640f, -0.384100195016935040f, 0.923217749456613500f, + -0.384277226866575510f, + 0.923144048249621930f, -0.384454244587440820f, 0.923070313101262420f, + -0.384631248173022580f, + 0.922996544014246250f, -0.384808237616812880f, 0.922922740991285680f, + -0.384985212912304200f, + 0.922848904035094120f, -0.385162174052989860f, 0.922775033148386380f, + -0.385339121032363340f, + 0.922701128333878630f, -0.385516053843918850f, 0.922627189594287910f, + -0.385692972481151140f, + 0.922553216932332830f, -0.385869876937555310f, 0.922479210350733210f, + -0.386046767206627170f, + 0.922405169852209880f, -0.386223643281862980f, 0.922331095439485440f, + -0.386400505156759440f, + 0.922256987115283030f, -0.386577352824813920f, 0.922182844882327600f, + -0.386754186279524180f, + 0.922108668743345180f, -0.386931005514388580f, 0.922034458701062820f, + -0.387107810522905990f, + 0.921960214758209220f, -0.387284601298575840f, 0.921885936917513970f, + -0.387461377834897870f, + 0.921811625181708120f, -0.387638140125372730f, 0.921737279553523910f, + -0.387814888163501180f, + 0.921662900035694730f, -0.387991621942784860f, 0.921588486630955490f, + -0.388168341456725740f, + 0.921514039342042010f, -0.388345046698826250f, 0.921439558171691430f, + -0.388521737662589570f, + 0.921365043122642340f, -0.388698414341519190f, 0.921290494197634540f, + -0.388875076729119250f, + 0.921215911399408730f, -0.389051724818894380f, 0.921141294730707270f, + -0.389228358604349730f, + 0.921066644194273640f, -0.389404978078990940f, 0.920991959792852310f, + -0.389581583236324300f, + 0.920917241529189520f, -0.389758174069856410f, 0.920842489406032190f, + -0.389934750573094730f, + 0.920767703426128790f, -0.390111312739546910f, 0.920692883592229120f, + -0.390287860562721190f, + 0.920618029907083970f, -0.390464394036126590f, 0.920543142373445480f, + -0.390640913153272430f, + 0.920468220994067110f, -0.390817417907668500f, 0.920393265771703550f, + -0.390993908292825380f, + 0.920318276709110590f, -0.391170384302253870f, 0.920243253809045370f, + -0.391346845929465560f, + 0.920168197074266340f, -0.391523293167972410f, 0.920093106507533180f, + -0.391699726011286940f, + 0.920017982111606570f, -0.391876144452922350f, 0.919942823889248640f, + -0.392052548486392090f, + 0.919867631843222950f, -0.392228938105210310f, 0.919792405976293860f, + -0.392405313302891690f, + 0.919717146291227360f, -0.392581674072951470f, 0.919641852790790470f, + -0.392758020408905280f, + 0.919566525477751530f, -0.392934352304269490f, 0.919491164354880100f, + -0.393110669752560760f, + 0.919415769424947070f, -0.393286972747296400f, 0.919340340690724340f, + -0.393463261281994330f, + 0.919264878154985370f, -0.393639535350172880f, 0.919189381820504470f, + -0.393815794945351020f, + 0.919113851690057770f, -0.393992040061048100f, 0.919038287766422050f, + -0.394168270690784080f, + 0.918962690052375630f, -0.394344486828079600f, 0.918887058550697970f, + -0.394520688466455600f, + 0.918811393264170050f, -0.394696875599433560f, 0.918735694195573550f, + -0.394873048220535760f, + 0.918659961347691900f, -0.395049206323284770f, 0.918584194723309540f, + -0.395225349901203670f, + 0.918508394325212250f, -0.395401478947816350f, 0.918432560156186910f, + -0.395577593456646840f, + 0.918356692219021720f, -0.395753693421220080f, 0.918280790516506130f, + -0.395929778835061250f, + 0.918204855051430900f, -0.396105849691696270f, 0.918128885826588030f, + -0.396281905984651520f, + 0.918052882844770380f, -0.396457947707453910f, 0.917976846108772730f, + -0.396633974853630830f, + 0.917900775621390500f, -0.396809987416710310f, 0.917824671385420570f, + -0.396985985390220900f, + 0.917748533403661250f, -0.397161968767691610f, 0.917672361678911860f, + -0.397337937542652060f, + 0.917596156213972950f, -0.397513891708632330f, 0.917519917011646260f, + -0.397689831259163180f, + 0.917443644074735220f, -0.397865756187775750f, 0.917367337406043930f, + -0.398041666488001770f, + 0.917290997008377910f, -0.398217562153373560f, 0.917214622884544250f, + -0.398393443177423980f, + 0.917138215037350710f, -0.398569309553686300f, 0.917061773469606820f, + -0.398745161275694430f, + 0.916985298184123000f, -0.398920998336982910f, 0.916908789183710990f, + -0.399096820731086540f, + 0.916832246471183890f, -0.399272628451540990f, 0.916755670049355990f, + -0.399448421491882140f, + 0.916679059921042700f, -0.399624199845646790f, 0.916602416089060790f, + -0.399799963506371980f, + 0.916525738556228210f, -0.399975712467595330f, 0.916449027325364150f, + -0.400151446722855130f, + 0.916372282399289140f, -0.400327166265690090f, 0.916295503780824800f, + -0.400502871089639500f, + 0.916218691472794220f, -0.400678561188243240f, 0.916141845478021350f, + -0.400854236555041650f, + 0.916064965799331720f, -0.401029897183575620f, 0.915988052439551950f, + -0.401205543067386710f, + 0.915911105401509880f, -0.401381174200016790f, 0.915834124688034710f, + -0.401556790575008540f, + 0.915757110301956720f, -0.401732392185905010f, 0.915680062246107650f, + -0.401907979026249700f, + 0.915602980523320230f, -0.402083551089586990f, 0.915525865136428530f, + -0.402259108369461490f, + 0.915448716088267830f, -0.402434650859418430f, 0.915371533381674760f, + -0.402610178553003680f, + 0.915294317019487050f, -0.402785691443763530f, 0.915217067004543860f, + -0.402961189525244900f, + 0.915139783339685260f, -0.403136672790995300f, 0.915062466027752760f, + -0.403312141234562550f, + 0.914985115071589310f, -0.403487594849495310f, 0.914907730474038730f, + -0.403663033629342640f, + 0.914830312237946200f, -0.403838457567654070f, 0.914752860366158220f, + -0.404013866657979890f, + 0.914675374861522390f, -0.404189260893870690f, 0.914597855726887790f, + -0.404364640268877810f, + 0.914520302965104450f, -0.404540004776553000f, 0.914442716579023870f, + -0.404715354410448650f, + 0.914365096571498560f, -0.404890689164117580f, 0.914287442945382440f, + -0.405066009031113340f, + 0.914209755703530690f, -0.405241314004989860f, 0.914132034848799460f, + -0.405416604079301630f, + 0.914054280384046570f, -0.405591879247603870f, 0.913976492312130630f, + -0.405767139503452060f, + 0.913898670635911680f, -0.405942384840402510f, 0.913820815358251100f, + -0.406117615252011840f, + 0.913742926482011390f, -0.406292830731837360f, 0.913665004010056350f, + -0.406468031273437000f, + 0.913587047945250810f, -0.406643216870369030f, 0.913509058290461140f, + -0.406818387516192310f, + 0.913431035048554720f, -0.406993543204466510f, 0.913352978222400250f, + -0.407168683928751550f, + 0.913274887814867760f, -0.407343809682607970f, 0.913196763828828200f, + -0.407518920459596920f, + 0.913118606267154240f, -0.407694016253280110f, 0.913040415132719160f, + -0.407869097057219800f, + 0.912962190428398210f, -0.408044162864978690f, 0.912883932157067200f, + -0.408219213670120100f, + 0.912805640321603500f, -0.408394249466208000f, 0.912727314924885900f, + -0.408569270246806780f, + 0.912648955969793900f, -0.408744276005481360f, 0.912570563459208730f, + -0.408919266735797430f, + 0.912492137396012650f, -0.409094242431320980f, 0.912413677783089020f, + -0.409269203085618590f, + 0.912335184623322750f, -0.409444148692257590f, 0.912256657919599760f, + -0.409619079244805670f, + 0.912178097674807180f, -0.409793994736831150f, 0.912099503891833470f, + -0.409968895161902880f, + 0.912020876573568340f, -0.410143780513590240f, 0.911942215722902570f, + -0.410318650785463260f, + 0.911863521342728520f, -0.410493505971092410f, 0.911784793435939430f, + -0.410668346064048730f, + 0.911706032005429880f, -0.410843171057903910f, 0.911627237054095650f, + -0.411017980946230210f, + 0.911548408584833990f, -0.411192775722600160f, 0.911469546600543020f, + -0.411367555380587220f, + 0.911390651104122430f, -0.411542319913765220f, 0.911311722098472780f, + -0.411717069315708560f, + 0.911232759586496190f, -0.411891803579992170f, 0.911153763571095900f, + -0.412066522700191560f, + 0.911074734055176360f, -0.412241226669882890f, 0.910995671041643140f, + -0.412415915482642730f, + 0.910916574533403360f, -0.412590589132048210f, 0.910837444533365010f, + -0.412765247611677270f, + 0.910758281044437570f, -0.412939890915108080f, 0.910679084069531570f, + -0.413114519035919450f, + 0.910599853611558930f, -0.413289131967690960f, 0.910520589673432750f, + -0.413463729704002410f, + 0.910441292258067250f, -0.413638312238434500f, 0.910361961368377990f, + -0.413812879564568300f, + 0.910282597007281760f, -0.413987431675985400f, 0.910203199177696540f, + -0.414161968566268080f, + 0.910123767882541680f, -0.414336490228999100f, 0.910044303124737500f, + -0.414510996657761750f, + 0.909964804907205660f, -0.414685487846140010f, 0.909885273232869160f, + -0.414859963787718330f, + 0.909805708104652220f, -0.415034424476081630f, 0.909726109525480160f, + -0.415208869904815590f, + 0.909646477498279540f, -0.415383300067506230f, 0.909566812025978330f, + -0.415557714957740410f, + 0.909487113111505430f, -0.415732114569105360f, 0.909407380757791260f, + -0.415906498895188770f, + 0.909327614967767260f, -0.416080867929579210f, 0.909247815744366310f, + -0.416255221665865480f, + 0.909167983090522380f, -0.416429560097637150f, 0.909088117009170580f, + -0.416603883218484350f, + 0.909008217503247450f, -0.416778191021997650f, 0.908928284575690640f, + -0.416952483501768170f, + 0.908848318229439120f, -0.417126760651387870f, 0.908768318467432890f, + -0.417301022464448890f, + 0.908688285292613360f, -0.417475268934544290f, 0.908608218707923190f, + -0.417649500055267410f, + 0.908528118716306120f, -0.417823715820212270f, 0.908447985320707250f, + -0.417997916222973550f, + 0.908367818524072890f, -0.418172101257146320f, 0.908287618329350450f, + -0.418346270916326260f, + 0.908207384739488700f, -0.418520425194109700f, 0.908127117757437600f, + -0.418694564084093560f, + 0.908046817386148340f, -0.418868687579875050f, 0.907966483628573350f, + -0.419042795675052370f, + 0.907886116487666260f, -0.419216888363223910f, 0.907805715966381930f, + -0.419390965637988890f, + 0.907725282067676440f, -0.419565027492946880f, 0.907644814794507200f, + -0.419739073921698180f, + 0.907564314149832630f, -0.419913104917843620f, 0.907483780136612570f, + -0.420087120474984530f, + 0.907403212757808110f, -0.420261120586722880f, 0.907322612016381420f, + -0.420435105246661170f, + 0.907241977915295820f, -0.420609074448402510f, 0.907161310457516250f, + -0.420783028185550520f, + 0.907080609646008450f, -0.420956966451709440f, 0.906999875483739610f, + -0.421130889240483970f, + 0.906919107973678140f, -0.421304796545479640f, 0.906838307118793430f, + -0.421478688360302280f, + 0.906757472922056550f, -0.421652564678558330f, 0.906676605386439460f, + -0.421826425493854910f, + 0.906595704514915330f, -0.422000270799799680f, 0.906514770310458800f, + -0.422174100590000770f, + 0.906433802776045460f, -0.422347914858067050f, 0.906352801914652400f, + -0.422521713597607820f, + 0.906271767729257660f, -0.422695496802232950f, 0.906190700222840650f, + -0.422869264465553060f, + 0.906109599398381980f, -0.423043016581179040f, 0.906028465258863600f, + -0.423216753142722610f, + 0.905947297807268460f, -0.423390474143796050f, 0.905866097046580940f, + -0.423564179578011960f, + 0.905784862979786550f, -0.423737869438983840f, 0.905703595609872010f, + -0.423911543720325580f, + 0.905622294939825270f, -0.424085202415651560f, 0.905540960972635590f, + -0.424258845518576950f, + 0.905459593711293250f, -0.424432473022717420f, 0.905378193158790090f, + -0.424606084921689110f, + 0.905296759318118820f, -0.424779681209108810f, 0.905215292192273590f, + -0.424953261878593890f, + 0.905133791784249690f, -0.425126826923762360f, 0.905052258097043590f, + -0.425300376338232640f, + 0.904970691133653250f, -0.425473910115623800f, 0.904889090897077470f, + -0.425647428249555590f, + 0.904807457390316540f, -0.425820930733648240f, 0.904725790616371930f, + -0.425994417561522400f, + 0.904644090578246240f, -0.426167888726799620f, 0.904562357278943300f, + -0.426341344223101830f, + 0.904480590721468250f, -0.426514784044051520f, 0.904398790908827350f, + -0.426688208183271860f, + 0.904316957844028320f, -0.426861616634386430f, 0.904235091530079750f, + -0.427035009391019680f, + 0.904153191969991780f, -0.427208386446796320f, 0.904071259166775440f, + -0.427381747795341770f, + 0.903989293123443340f, -0.427555093430282080f, 0.903907293843009050f, + -0.427728423345243800f, + 0.903825261328487510f, -0.427901737533854080f, 0.903743195582894620f, + -0.428075035989740730f, + 0.903661096609247980f, -0.428248318706531960f, 0.903578964410566070f, + -0.428421585677856650f, + 0.903496798989868450f, -0.428594836897344400f, 0.903414600350176290f, + -0.428768072358625070f, + 0.903332368494511820f, -0.428941292055329490f, 0.903250103425898400f, + -0.429114495981088750f, + 0.903167805147360720f, -0.429287684129534610f, 0.903085473661924600f, + -0.429460856494299490f, + 0.903003108972617150f, -0.429634013069016380f, 0.902920711082466740f, + -0.429807153847318710f, + 0.902838279994502830f, -0.429980278822840620f, 0.902755815711756120f, + -0.430153387989216870f, + 0.902673318237258830f, -0.430326481340082610f, 0.902590787574043870f, + -0.430499558869073820f, + 0.902508223725145940f, -0.430672620569826800f, 0.902425626693600380f, + -0.430845666435978660f, + 0.902342996482444200f, -0.431018696461167030f, 0.902260333094715540f, + -0.431191710639029950f, + 0.902177636533453620f, -0.431364708963206330f, 0.902094906801698900f, + -0.431537691427335500f, + 0.902012143902493180f, -0.431710658025057260f, 0.901929347838879460f, + -0.431883608750012250f, + 0.901846518613901750f, -0.432056543595841500f, 0.901763656230605730f, + -0.432229462556186720f, + 0.901680760692037730f, -0.432402365624690140f, 0.901597832001245660f, + -0.432575252794994650f, + 0.901514870161278740f, -0.432748124060743700f, 0.901431875175186970f, + -0.432920979415581280f, + 0.901348847046022030f, -0.433093818853151960f, 0.901265785776836580f, + -0.433266642367100940f, + 0.901182691370684520f, -0.433439449951074090f, 0.901099563830620950f, + -0.433612241598717580f, + 0.901016403159702330f, -0.433785017303678520f, 0.900933209360986200f, + -0.433957777059604420f, + 0.900849982437531450f, -0.434130520860143310f, 0.900766722392397860f, + -0.434303248698943990f, + 0.900683429228646970f, -0.434475960569655650f, 0.900600102949340900f, + -0.434648656465928320f, + 0.900516743557543520f, -0.434821336381412290f, 0.900433351056319830f, + -0.434994000309758710f, + 0.900349925448735600f, -0.435166648244619260f, 0.900266466737858480f, + -0.435339280179646070f, + 0.900182974926756810f, -0.435511896108492000f, 0.900099450018500450f, + -0.435684496024810460f, + 0.900015892016160280f, -0.435857079922255470f, 0.899932300922808510f, + -0.436029647794481560f, + 0.899848676741518580f, -0.436202199635143950f, 0.899765019475365140f, + -0.436374735437898340f, + 0.899681329127423930f, -0.436547255196401200f, 0.899597605700772180f, + -0.436719758904309360f, + 0.899513849198487980f, -0.436892246555280360f, 0.899430059623650860f, + -0.437064718142972370f, + 0.899346236979341570f, -0.437237173661044090f, 0.899262381268642000f, + -0.437409613103154790f, + 0.899178492494635330f, -0.437582036462964400f, 0.899094570660405770f, + -0.437754443734133410f, + 0.899010615769039070f, -0.437926834910322860f, 0.898926627823621870f, + -0.438099209985194470f, + 0.898842606827242370f, -0.438271568952410430f, 0.898758552782989440f, + -0.438443911805633690f, + 0.898674465693953820f, -0.438616238538527660f, 0.898590345563227030f, + -0.438788549144756290f, + 0.898506192393901950f, -0.438960843617984320f, 0.898422006189072530f, + -0.439133121951876930f, + 0.898337786951834310f, -0.439305384140099950f, 0.898253534685283570f, + -0.439477630176319800f, + 0.898169249392518080f, -0.439649860054203480f, 0.898084931076636780f, + -0.439822073767418500f, + 0.898000579740739880f, -0.439994271309633260f, 0.897916195387928660f, + -0.440166452674516320f, + 0.897831778021305650f, -0.440338617855737250f, 0.897747327643974690f, + -0.440510766846965940f, + 0.897662844259040860f, -0.440682899641872900f, 0.897578327869610230f, + -0.440855016234129430f, + 0.897493778478790310f, -0.441027116617407230f, 0.897409196089689720f, + -0.441199200785378660f, + 0.897324580705418320f, -0.441371268731716670f, 0.897239932329087160f, + -0.441543320450094870f, + 0.897155250963808550f, -0.441715355934187310f, 0.897070536612695870f, + -0.441887375177668850f, + 0.896985789278863970f, -0.442059378174214700f, 0.896901008965428790f, + -0.442231364917500980f, + 0.896816195675507300f, -0.442403335401204080f, 0.896731349412217880f, + -0.442575289619001170f, + 0.896646470178680150f, -0.442747227564570020f, 0.896561557978014960f, + -0.442919149231588980f, + 0.896476612813344120f, -0.443091054613736880f, 0.896391634687790820f, + -0.443262943704693320f, + 0.896306623604479550f, -0.443434816498138480f, 0.896221579566536030f, + -0.443606672987752970f, + 0.896136502577086770f, -0.443778513167218220f, 0.896051392639260150f, + -0.443950337030216140f, + 0.895966249756185220f, -0.444122144570429200f, 0.895881073930992370f, + -0.444293935781540580f, + 0.895795865166813530f, -0.444465710657234000f, 0.895710623466781320f, + -0.444637469191193790f, + 0.895625348834030110f, -0.444809211377104880f, 0.895540041271694950f, + -0.444980937208652730f, + 0.895454700782912450f, -0.445152646679523640f, 0.895369327370820310f, + -0.445324339783404190f, + 0.895283921038557580f, -0.445496016513981740f, 0.895198481789264200f, + -0.445667676864944300f, + 0.895113009626081760f, -0.445839320829980290f, 0.895027504552152630f, + -0.446010948402778940f, + 0.894941966570620750f, -0.446182559577030070f, 0.894856395684631050f, + -0.446354154346423840f, + 0.894770791897329550f, -0.446525732704651350f, 0.894685155211863980f, + -0.446697294645404090f, + 0.894599485631382700f, -0.446868840162374160f, 0.894513783159035620f, + -0.447040369249254440f, + 0.894428047797973800f, -0.447211881899738320f, 0.894342279551349480f, + -0.447383378107519600f, + 0.894256478422316040f, -0.447554857866293010f, 0.894170644414028270f, + -0.447726321169753580f, + 0.894084777529641990f, -0.447897768011597310f, 0.893998877772314240f, + -0.448069198385520400f, + 0.893912945145203250f, -0.448240612285219890f, 0.893826979651468620f, + -0.448412009704393430f, + 0.893740981294271040f, -0.448583390636739240f, 0.893654950076772540f, + -0.448754755075955970f, + 0.893568886002135910f, -0.448926103015743260f, 0.893482789073525850f, + -0.449097434449801050f, + 0.893396659294107720f, -0.449268749371829920f, 0.893310496667048200f, + -0.449440047775531150f, + 0.893224301195515320f, -0.449611329654606540f, 0.893138072882678320f, + -0.449782595002758690f, + 0.893051811731707450f, -0.449953843813690520f, 0.892965517745774370f, + -0.450125076081105690f, + 0.892879190928051680f, -0.450296291798708610f, 0.892792831281713610f, + -0.450467490960204110f, + 0.892706438809935390f, -0.450638673559297600f, 0.892620013515893150f, + -0.450809839589695280f, + 0.892533555402764580f, -0.450980989045103860f, 0.892447064473728680f, + -0.451152121919230600f, + 0.892360540731965360f, -0.451323238205783520f, 0.892273984180655840f, + -0.451494337898471100f, + 0.892187394822982480f, -0.451665420991002490f, 0.892100772662129060f, + -0.451836487477087490f, + 0.892014117701280470f, -0.452007537350436420f, 0.891927429943622510f, + -0.452178570604760350f, + 0.891840709392342720f, -0.452349587233770890f, 0.891753956050629460f, + -0.452520587231180050f, + 0.891667169921672280f, -0.452691570590700920f, 0.891580351008662290f, + -0.452862537306046750f, + 0.891493499314791380f, -0.453033487370931580f, 0.891406614843252900f, + -0.453204420779070190f, + 0.891319697597241390f, -0.453375337524177750f, 0.891232747579952520f, + -0.453546237599970090f, + 0.891145764794583180f, -0.453717121000163870f, 0.891058749244331590f, + -0.453887987718476050f, + 0.890971700932396860f, -0.454058837748624430f, 0.890884619861979530f, + -0.454229671084327320f, + 0.890797506036281490f, -0.454400487719303580f, 0.890710359458505630f, + -0.454571287647272950f, + 0.890623180131855930f, -0.454742070861955450f, 0.890535968059537830f, + -0.454912837357071940f, + 0.890448723244757880f, -0.455083587126343840f, 0.890361445690723840f, + -0.455254320163493100f, + 0.890274135400644600f, -0.455425036462242360f, 0.890186792377730240f, + -0.455595736016314980f, + 0.890099416625192320f, -0.455766418819434640f, 0.890012008146243260f, + -0.455937084865326030f, + 0.889924566944096720f, -0.456107734147714110f, 0.889837093021967900f, + -0.456278366660324620f, + 0.889749586383072780f, -0.456448982396883920f, 0.889662047030628900f, + -0.456619581351118910f, + 0.889574474967854580f, -0.456790163516757160f, 0.889486870197969900f, + -0.456960728887526980f, + 0.889399232724195520f, -0.457131277457156980f, 0.889311562549753850f, + -0.457301809219376630f, + 0.889223859677868210f, -0.457472324167916060f, 0.889136124111763240f, + -0.457642822296505770f, + 0.889048355854664570f, -0.457813303598877170f, 0.888960554909799310f, + -0.457983768068762120f, + 0.888872721280395630f, -0.458154215699893060f, 0.888784854969682850f, + -0.458324646486003240f, + 0.888696955980891600f, -0.458495060420826270f, 0.888609024317253860f, + -0.458665457498096560f, + 0.888521059982002260f, -0.458835837711549120f, 0.888433062978371320f, + -0.459006201054919630f, + 0.888345033309596350f, -0.459176547521944090f, 0.888256970978913870f, + -0.459346877106359630f, + 0.888168875989561730f, -0.459517189801903480f, 0.888080748344778900f, + -0.459687485602313870f, + 0.887992588047805560f, -0.459857764501329540f, 0.887904395101883240f, + -0.460028026492689650f, + 0.887816169510254440f, -0.460198271570134320f, 0.887727911276163020f, + -0.460368499727404010f, + 0.887639620402853930f, -0.460538710958240010f, 0.887551296893573370f, + -0.460708905256384080f, + 0.887462940751568840f, -0.460879082615578690f, 0.887374551980088850f, + -0.461049243029566900f, + 0.887286130582383150f, -0.461219386492092380f, 0.887197676561702900f, + -0.461389512996899450f, + 0.887109189921300170f, -0.461559622537733080f, 0.887020670664428360f, + -0.461729715108338770f, + 0.886932118794342190f, -0.461899790702462730f, 0.886843534314297410f, + -0.462069849313851750f, + 0.886754917227550840f, -0.462239890936253340f, 0.886666267537361000f, + -0.462409915563415430f, + 0.886577585246987040f, -0.462579923189086810f, 0.886488870359689600f, + -0.462749913807016740f, + 0.886400122878730600f, -0.462919887410955080f, 0.886311342807372780f, + -0.463089843994652530f, + 0.886222530148880640f, -0.463259783551860150f, 0.886133684906519340f, + -0.463429706076329830f, + 0.886044807083555600f, -0.463599611561814010f, 0.885955896683257030f, + -0.463769500002065630f, + 0.885866953708892790f, -0.463939371390838520f, 0.885777978163732940f, + -0.464109225721886950f, + 0.885688970051048960f, -0.464279062988965760f, 0.885599929374113360f, + -0.464448883185830660f, + 0.885510856136199950f, -0.464618686306237820f, 0.885421750340583680f, + -0.464788472343943990f, + 0.885332611990540590f, -0.464958241292706690f, 0.885243441089348270f, + -0.465127993146283950f, + 0.885154237640285110f, -0.465297727898434600f, 0.885065001646630930f, + -0.465467445542917800f, + 0.884975733111666660f, -0.465637146073493660f, 0.884886432038674560f, + -0.465806829483922710f, + 0.884797098430937790f, -0.465976495767966180f, 0.884707732291741040f, + -0.466146144919385890f, + 0.884618333624369920f, -0.466315776931944430f, 0.884528902432111460f, + -0.466485391799404900f, + 0.884439438718253810f, -0.466654989515530920f, 0.884349942486086120f, + -0.466824570074086950f, + 0.884260413738899190f, -0.466994133468838000f, 0.884170852479984500f, + -0.467163679693549770f, + 0.884081258712634990f, -0.467333208741988420f, 0.883991632440144890f, + -0.467502720607920920f, + 0.883901973665809470f, -0.467672215285114770f, 0.883812282392925090f, + -0.467841692767338170f, + 0.883722558624789660f, -0.468011153048359830f, 0.883632802364701870f, + -0.468180596121949290f, + 0.883543013615961880f, -0.468350021981876530f, 0.883453192381870920f, + -0.468519430621912310f, + 0.883363338665731580f, -0.468688822035827900f, 0.883273452470847430f, + -0.468858196217395330f, + 0.883183533800523390f, -0.469027553160387130f, 0.883093582658065370f, + -0.469196892858576580f, + 0.883003599046780830f, -0.469366215305737520f, 0.882913582969978020f, + -0.469535520495644450f, + 0.882823534430966620f, -0.469704808422072460f, 0.882733453433057650f, + -0.469874079078797360f, + 0.882643339979562790f, -0.470043332459595620f, 0.882553194073795510f, + -0.470212568558244170f, + 0.882463015719070150f, -0.470381787368520650f, 0.882372804918702290f, + -0.470550988884203550f, + 0.882282561676008710f, -0.470720173099071600f, 0.882192285994307430f, + -0.470889340006904520f, + 0.882101977876917580f, -0.471058489601482500f, 0.882011637327159590f, + -0.471227621876586340f, + 0.881921264348355050f, -0.471396736825997640f, 0.881830858943826620f, + -0.471565834443498420f, + 0.881740421116898320f, -0.471734914722871430f, 0.881649950870895260f, + -0.471903977657900210f, + 0.881559448209143780f, -0.472073023242368660f, 0.881468913134971440f, + -0.472242051470061490f, + 0.881378345651706920f, -0.472411062334764040f, 0.881287745762680100f, + -0.472580055830262250f, + 0.881197113471222090f, -0.472749031950342790f, 0.881106448780665130f, + -0.472917990688792760f, + 0.881015751694342870f, -0.473086932039400050f, 0.880925022215589880f, + -0.473255855995953320f, + 0.880834260347742040f, -0.473424762552241530f, 0.880743466094136340f, + -0.473593651702054530f, + 0.880652639458111010f, -0.473762523439182850f, 0.880561780443005700f, + -0.473931377757417450f, + 0.880470889052160750f, -0.474100214650549970f, 0.880379965288918150f, + -0.474269034112372980f, + 0.880289009156621010f, -0.474437836136679230f, 0.880198020658613190f, + -0.474606620717262560f, + 0.880106999798240360f, -0.474775387847917120f, 0.880015946578849070f, + -0.474944137522437800f, + 0.879924861003786860f, -0.475112869734620300f, 0.879833743076402940f, + -0.475281584478260740f, + 0.879742592800047410f, -0.475450281747155870f, 0.879651410178071580f, + -0.475618961535103300f, + 0.879560195213827890f, -0.475787623835901120f, 0.879468947910670210f, + -0.475956268643348060f, + 0.879377668271953290f, -0.476124895951243580f, 0.879286356301033250f, + -0.476293505753387690f, + 0.879195012001267480f, -0.476462098043581190f, 0.879103635376014330f, + -0.476630672815625320f, + 0.879012226428633530f, -0.476799230063322090f, 0.878920785162485840f, + -0.476967769780474170f, + 0.878829311580933360f, -0.477136291960884810f, 0.878737805687339390f, + -0.477304796598357890f, + 0.878646267485068130f, -0.477473283686698060f, 0.878554696977485450f, + -0.477641753219710470f, + 0.878463094167957870f, -0.477810205191200990f, 0.878371459059853480f, + -0.477978639594976160f, + 0.878279791656541580f, -0.478147056424843010f, 0.878188091961392250f, + -0.478315455674609480f, + 0.878096359977777130f, -0.478483837338083970f, 0.878004595709069080f, + -0.478652201409075500f, + 0.877912799158641840f, -0.478820547881393890f, 0.877820970329870500f, + -0.478988876748849490f, + 0.877729109226131570f, -0.479157188005253310f, 0.877637215850802230f, + -0.479325481644417070f, + 0.877545290207261350f, -0.479493757660153010f, 0.877453332298888560f, + -0.479662016046274180f, + 0.877361342129065140f, -0.479830256796594190f, 0.877269319701173170f, + -0.479998479904927280f, + 0.877177265018595940f, -0.480166685365088390f, 0.877085178084718420f, + -0.480334873170893020f, + 0.876993058902925890f, -0.480503043316157510f, 0.876900907476605650f, + -0.480671195794698640f, + 0.876808723809145650f, -0.480839330600333960f, 0.876716507903935400f, + -0.481007447726881590f, + 0.876624259764365310f, -0.481175547168160300f, 0.876531979393827100f, + -0.481343628917989710f, + 0.876439666795713610f, -0.481511692970189860f, 0.876347321973419020f, + -0.481679739318581490f, + 0.876254944930338510f, -0.481847767956986030f, 0.876162535669868460f, + -0.482015778879225590f, + 0.876070094195406600f, -0.482183772079122720f, 0.875977620510351770f, + -0.482351747550500980f, + 0.875885114618103810f, -0.482519705287184350f, 0.875792576522063880f, + -0.482687645282997460f, + 0.875700006225634600f, -0.482855567531765670f, 0.875607403732219350f, + -0.483023472027314880f, + 0.875514769045222850f, -0.483191358763471860f, 0.875422102168050940f, + -0.483359227734063810f, + 0.875329403104110890f, -0.483527078932918740f, 0.875236671856810870f, + -0.483694912353865140f, + 0.875143908429560360f, -0.483862727990732270f, 0.875051112825769970f, + -0.484030525837350010f, + 0.874958285048851650f, -0.484198305887549030f, 0.874865425102218320f, + -0.484366068135160420f, + 0.874772532989284150f, -0.484533812574016180f, 0.874679608713464510f, + -0.484701539197948670f, + 0.874586652278176110f, -0.484869248000791060f, 0.874493663686836560f, + -0.485036938976377290f, + 0.874400642942864790f, -0.485204612118541820f, 0.874307590049680950f, + -0.485372267421119770f, + 0.874214505010706300f, -0.485539904877946960f, 0.874121387829363330f, + -0.485707524482859750f, + 0.874028238509075740f, -0.485875126229695250f, 0.873935057053268240f, + -0.486042710112291330f, + 0.873841843465366860f, -0.486210276124486420f, 0.873748597748798870f, + -0.486377824260119440f, + 0.873655319906992630f, -0.486545354513030270f, 0.873562009943377850f, + -0.486712866877059170f, + 0.873468667861384880f, -0.486880361346047340f, 0.873375293664446000f, + -0.487047837913836380f, + 0.873281887355994210f, -0.487215296574268760f, 0.873188448939463790f, + -0.487382737321187360f, + 0.873094978418290090f, -0.487550160148436000f, 0.873001475795909920f, + -0.487717565049858800f, + 0.872907941075761080f, -0.487884952019301040f, 0.872814374261282390f, + -0.488052321050608250f, + 0.872720775355914300f, -0.488219672137626790f, 0.872627144363097960f, + -0.488387005274203530f, + 0.872533481286276170f, -0.488554320454186180f, 0.872439786128892280f, + -0.488721617671423080f, + 0.872346058894391540f, -0.488888896919763170f, 0.872252299586219860f, + -0.489056158193056030f, + 0.872158508207824480f, -0.489223401485151980f, 0.872064684762653860f, + -0.489390626789901920f, + 0.871970829254157810f, -0.489557834101157440f, 0.871876941685786890f, + -0.489725023412770910f, + 0.871783022060993120f, -0.489892194718595190f, 0.871689070383229740f, + -0.490059348012483850f, + 0.871595086655950980f, -0.490226483288291160f, 0.871501070882612530f, + -0.490393600539871970f, + 0.871407023066670950f, -0.490560699761082020f, 0.871312943211584030f, + -0.490727780945777400f, + 0.871218831320811020f, -0.490894844087815090f, 0.871124687397811900f, + -0.491061889181052650f, + 0.871030511446048260f, -0.491228916219348280f, 0.870936303468982760f, + -0.491395925196560780f, + 0.870842063470078980f, -0.491562916106549900f, 0.870747791452801790f, + -0.491729888943175760f, + 0.870653487420617430f, -0.491896843700299290f, 0.870559151376993250f, + -0.492063780371782000f, + 0.870464783325397670f, -0.492230698951486020f, 0.870370383269300270f, + -0.492397599433274380f, + 0.870275951212171940f, -0.492564481811010590f, 0.870181487157484560f, + -0.492731346078558840f, + 0.870086991108711460f, -0.492898192229784040f, 0.869992463069326870f, + -0.493065020258551700f, + 0.869897903042806340f, -0.493231830158727900f, 0.869803311032626650f, + -0.493398621924179770f, + 0.869708687042265670f, -0.493565395548774770f, 0.869614031075202300f, + -0.493732151026381020f, + 0.869519343134916860f, -0.493898888350867480f, 0.869424623224890890f, + -0.494065607516103570f, + 0.869329871348606840f, -0.494232308515959670f, 0.869235087509548370f, + -0.494398991344306650f, + 0.869140271711200560f, -0.494565655995015950f, 0.869045423957049530f, + -0.494732302461959870f, + 0.868950544250582380f, -0.494898930739011260f, 0.868855632595287860f, + -0.495065540820043560f, + 0.868760688994655310f, -0.495232132698931180f, 0.868665713452175690f, + -0.495398706369549020f, + 0.868570705971340900f, -0.495565261825772540f, 0.868475666555644120f, + -0.495731799061477960f, + 0.868380595208579800f, -0.495898318070542190f, 0.868285491933643350f, + -0.496064818846842890f, + 0.868190356734331310f, -0.496231301384258250f, 0.868095189614141670f, + -0.496397765676667160f, + 0.867999990576573510f, -0.496564211717949290f, 0.867904759625126920f, + -0.496730639501984760f, + 0.867809496763303320f, -0.496897049022654470f, 0.867714201994605140f, + -0.497063440273840250f, + 0.867618875322536230f, -0.497229813249424220f, 0.867523516750601460f, + -0.497396167943289280f, + 0.867428126282306920f, -0.497562504349319150f, 0.867332703921159800f, + -0.497728822461397940f, + 0.867237249670668400f, -0.497895122273410870f, 0.867141763534342470f, + -0.498061403779243410f, + 0.867046245515692650f, -0.498227666972781870f, 0.866950695618230900f, + -0.498393911847913210f, + 0.866855113845470430f, -0.498560138398525140f, 0.866759500200925400f, + -0.498726346618505900f, + 0.866663854688111130f, -0.498892536501744590f, 0.866568177310544470f, + -0.499058708042130870f, + 0.866472468071743050f, -0.499224861233555080f, 0.866376726975225830f, + -0.499390996069908170f, + 0.866280954024512990f, -0.499557112545081840f, 0.866185149223125840f, + -0.499723210652968540f, + 0.866089312574586770f, -0.499889290387461330f, 0.865993444082419520f, + -0.500055351742453860f, + 0.865897543750148820f, -0.500221394711840680f, 0.865801611581300760f, + -0.500387419289516580f, + 0.865705647579402380f, -0.500553425469377420f, 0.865609651747981990f, + -0.500719413245319880f, + 0.865513624090569090f, -0.500885382611240710f, 0.865417564610694410f, + -0.501051333561038040f, + 0.865321473311889800f, -0.501217266088609950f, 0.865225350197688200f, + -0.501383180187855770f, + 0.865129195271623800f, -0.501549075852675390f, 0.865033008537231860f, + -0.501714953076969120f, + 0.864936789998049020f, -0.501880811854638290f, 0.864840539657612870f, + -0.502046652179584660f, + 0.864744257519462380f, -0.502212474045710790f, 0.864647943587137480f, + -0.502378277446919760f, + 0.864551597864179340f, -0.502544062377115690f, 0.864455220354130360f, + -0.502709828830202990f, + 0.864358811060534030f, -0.502875576800086990f, 0.864262369986934950f, + -0.503041306280673450f, + 0.864165897136879300f, -0.503207017265868920f, 0.864069392513913790f, + -0.503372709749581040f, + 0.863972856121586810f, -0.503538383725717580f, 0.863876287963447510f, + -0.503704039188187070f, + 0.863779688043046720f, -0.503869676130898950f, 0.863683056363935830f, + -0.504035294547763190f, + 0.863586392929668100f, -0.504200894432690340f, 0.863489697743797140f, + -0.504366475779592040f, + 0.863392970809878420f, -0.504532038582380270f, 0.863296212131468230f, + -0.504697582834967570f, + 0.863199421712124160f, -0.504863108531267590f, 0.863102599555404910f, + -0.505028615665194080f, + 0.863005745664870320f, -0.505194104230662240f, 0.862908860044081400f, + -0.505359574221587280f, + 0.862811942696600330f, -0.505525025631885390f, 0.862714993625990690f, + -0.505690458455473450f, + 0.862618012835816740f, -0.505855872686268860f, 0.862521000329644520f, + -0.506021268318189720f, + 0.862423956111040610f, -0.506186645345155230f, 0.862326880183573060f, + -0.506352003761084800f, + 0.862229772550811240f, -0.506517343559898530f, 0.862132633216325380f, + -0.506682664735517600f, + 0.862035462183687210f, -0.506847967281863210f, 0.861938259456469290f, + -0.507013251192858230f, + 0.861841025038245330f, -0.507178516462425180f, 0.861743758932590700f, + -0.507343763084487920f, + 0.861646461143081300f, -0.507508991052970870f, 0.861549131673294720f, + -0.507674200361798890f, + 0.861451770526809320f, -0.507839391004897720f, 0.861354377707204910f, + -0.508004562976194010f, + 0.861256953218062170f, -0.508169716269614600f, 0.861159497062963350f, + -0.508334850879087360f, + 0.861062009245491480f, -0.508499966798540930f, 0.860964489769231010f, + -0.508665064021904030f, + 0.860866938637767310f, -0.508830142543106990f, 0.860769355854687170f, + -0.508995202356080090f, + 0.860671741423578380f, -0.509160243454754640f, 0.860574095348029980f, + -0.509325265833062480f, + 0.860476417631632070f, -0.509490269484936360f, 0.860378708277976130f, + -0.509655254404309250f, + 0.860280967290654510f, -0.509820220585115450f, 0.860183194673260990f, + -0.509985168021289460f, + 0.860085390429390140f, -0.510150096706766810f, 0.859987554562638200f, + -0.510315006635483240f, + 0.859889687076602290f, -0.510479897801375700f, 0.859791787974880650f, + -0.510644770198381610f, + 0.859693857261072610f, -0.510809623820439040f, 0.859595894938779080f, + -0.510974458661486830f, + 0.859497901011601730f, -0.511139274715464390f, 0.859399875483143450f, + -0.511304071976312000f, + 0.859301818357008470f, -0.511468850437970300f, 0.859203729636801920f, + -0.511633610094381240f, + 0.859105609326130450f, -0.511798350939486890f, 0.859007457428601520f, + -0.511963072967230200f, + 0.858909273947823900f, -0.512127776171554690f, 0.858811058887407610f, + -0.512292460546404870f, + 0.858712812250963520f, -0.512457126085725690f, 0.858614534042104190f, + -0.512621772783462990f, + 0.858516224264442740f, -0.512786400633562960f, 0.858417882921593930f, + -0.512951009629972980f, + 0.858319510017173440f, -0.513115599766640560f, 0.858221105554798250f, + -0.513280171037514220f, + 0.858122669538086140f, -0.513444723436543460f, 0.858024201970656540f, + -0.513609256957677780f, + 0.857925702856129790f, -0.513773771594868030f, 0.857827172198127430f, + -0.513938267342065380f, + 0.857728610000272120f, -0.514102744193221660f, 0.857630016266187620f, + -0.514267202142289710f, + 0.857531390999499150f, -0.514431641183222820f, 0.857432734203832700f, + -0.514596061309975040f, + 0.857334045882815590f, -0.514760462516501200f, 0.857235326040076460f, + -0.514924844796756490f, + 0.857136574679244980f, -0.515089208144697160f, 0.857037791803951680f, + -0.515253552554280180f, + 0.856938977417828760f, -0.515417878019462930f, 0.856840131524509220f, + -0.515582184534203790f, + 0.856741254127627470f, -0.515746472092461380f, 0.856642345230818840f, + -0.515910740688195650f, + 0.856543404837719960f, -0.516074990315366630f, 0.856444432951968590f, + -0.516239220967935510f, + 0.856345429577203610f, -0.516403432639863990f, 0.856246394717065210f, + -0.516567625325114350f, + 0.856147328375194470f, -0.516731799017649870f, 0.856048230555233940f, + -0.516895953711434150f, + 0.855949101260826910f, -0.517060089400431910f, 0.855849940495618240f, + -0.517224206078608310f, + 0.855750748263253920f, -0.517388303739929060f, 0.855651524567380690f, + -0.517552382378360880f, + 0.855552269411646860f, -0.517716441987871150f, 0.855452982799701830f, + -0.517880482562427690f, + 0.855353664735196030f, -0.518044504095999340f, 0.855254315221780970f, + -0.518208506582555460f, + 0.855154934263109620f, -0.518372490016066110f, 0.855055521862835950f, + -0.518536454390502220f, + 0.854956078024614930f, -0.518700399699834950f, 0.854856602752102850f, + -0.518864325938036890f, + 0.854757096048957220f, -0.519028233099080860f, 0.854657557918836460f, + -0.519192121176940250f, + 0.854557988365400530f, -0.519355990165589640f, 0.854458387392310170f, + -0.519519840059003760f, + 0.854358755003227440f, -0.519683670851158410f, 0.854259091201815530f, + -0.519847482536030190f, + 0.854159395991738850f, -0.520011275107596040f, 0.854059669376662780f, + -0.520175048559833760f, + 0.853959911360254180f, -0.520338802886721960f, 0.853860121946180770f, + -0.520502538082239670f, + 0.853760301138111410f, -0.520666254140367160f, 0.853660448939716380f, + -0.520829951055084670f, + 0.853560565354666840f, -0.520993628820373920f, 0.853460650386635320f, + -0.521157287430216610f, + 0.853360704039295430f, -0.521320926878595660f, 0.853260726316321880f, + -0.521484547159494330f, + 0.853160717221390420f, -0.521648148266897090f, 0.853060676758178320f, + -0.521811730194788550f, + 0.852960604930363630f, -0.521975292937154390f, 0.852860501741625750f, + -0.522138836487980760f, + 0.852760367195645300f, -0.522302360841254590f, 0.852660201296103760f, + -0.522465865990963780f, + 0.852560004046684080f, -0.522629351931096610f, 0.852459775451070100f, + -0.522792818655642090f, + 0.852359515512947090f, -0.522956266158590140f, 0.852259224236001090f, + -0.523119694433931250f, + 0.852158901623919830f, -0.523283103475656430f, 0.852058547680391690f, + -0.523446493277757830f, + 0.851958162409106380f, -0.523609863834227920f, 0.851857745813754840f, + -0.523773215139060170f, + 0.851757297898029120f, -0.523936547186248600f, 0.851656818665622370f, + -0.524099859969787700f, + 0.851556308120228980f, -0.524263153483673360f, 0.851455766265544310f, + -0.524426427721901400f, + 0.851355193105265200f, -0.524589682678468950f, 0.851254588643089120f, + -0.524752918347373360f, + 0.851153952882715340f, -0.524916134722613000f, 0.851053285827843790f, + -0.525079331798186780f, + 0.850952587482175730f, -0.525242509568094710f, 0.850851857849413530f, + -0.525405668026336930f, + 0.850751096933260790f, -0.525568807166914680f, 0.850650304737422090f, + -0.525731926983829760f, + 0.850549481265603480f, -0.525895027471084630f, 0.850448626521511760f, + -0.526058108622682760f, + 0.850347740508854980f, -0.526221170432628060f, 0.850246823231342710f, + -0.526384212894925100f, + 0.850145874692685210f, -0.526547236003579440f, 0.850044894896594180f, + -0.526710239752597010f, + 0.849943883846782210f, -0.526873224135984590f, 0.849842841546963320f, + -0.527036189147750080f, + 0.849741768000852550f, -0.527199134781901280f, 0.849640663212165910f, + -0.527362061032447540f, + 0.849539527184620890f, -0.527524967893398200f, 0.849438359921936060f, + -0.527687855358763720f, + 0.849337161427830780f, -0.527850723422555230f, 0.849235931706025960f, + -0.528013572078784630f, + 0.849134670760243630f, -0.528176401321464370f, 0.849033378594206800f, + -0.528339211144607690f, + 0.848932055211639610f, -0.528502001542228480f, 0.848830700616267530f, + -0.528664772508341320f, + 0.848729314811817130f, -0.528827524036961870f, 0.848627897802015860f, + -0.528990256122106040f, + 0.848526449590592650f, -0.529152968757790610f, 0.848424970181277600f, + -0.529315661938033260f, + 0.848323459577801640f, -0.529478335656851980f, 0.848221917783896990f, + -0.529640989908265910f, + 0.848120344803297230f, -0.529803624686294610f, 0.848018740639736810f, + -0.529966239984958620f, + 0.847917105296951410f, -0.530128835798278960f, 0.847815438778677930f, + -0.530291412120277310f, + 0.847713741088654380f, -0.530453968944976320f, 0.847612012230619660f, + -0.530616506266399330f, + 0.847510252208314330f, -0.530779024078570140f, 0.847408461025479730f, + -0.530941522375513620f, + 0.847306638685858320f, -0.531104001151255000f, 0.847204785193194090f, + -0.531266460399820390f, + 0.847102900551231500f, -0.531428900115236800f, 0.847000984763716880f, + -0.531591320291531670f, + 0.846899037834397240f, -0.531753720922733320f, 0.846797059767020910f, + -0.531916102002870650f, + 0.846695050565337450f, -0.532078463525973540f, 0.846593010233097190f, + -0.532240805486072220f, + 0.846490938774052130f, -0.532403127877197900f, 0.846388836191954930f, + -0.532565430693382580f, + 0.846286702490559710f, -0.532727713928658810f, 0.846184537673621560f, + -0.532889977577059800f, + 0.846082341744897050f, -0.533052221632619450f, 0.845980114708143270f, + -0.533214446089372960f, + 0.845877856567119000f, -0.533376650941355330f, 0.845775567325584010f, + -0.533538836182603120f, + 0.845673246987299070f, -0.533701001807152960f, 0.845570895556026270f, + -0.533863147809042650f, + 0.845468513035528830f, -0.534025274182310380f, 0.845366099429570970f, + -0.534187380920995380f, + 0.845263654741918220f, -0.534349468019137520f, 0.845161178976337140f, + -0.534511535470777120f, + 0.845058672136595470f, -0.534673583269955510f, 0.844956134226462210f, + -0.534835611410714560f, + 0.844853565249707120f, -0.534997619887097150f, 0.844750965210101510f, + -0.535159608693146600f, + 0.844648334111417820f, -0.535321577822907120f, 0.844545671957429240f, + -0.535483527270423370f, + 0.844442978751910660f, -0.535645457029741090f, 0.844340254498637590f, + -0.535807367094906390f, + 0.844237499201387020f, -0.535969257459966710f, 0.844134712863936930f, + -0.536131128118969460f, + 0.844031895490066410f, -0.536292979065963180f, 0.843929047083555870f, + -0.536454810294997090f, + 0.843826167648186740f, -0.536616621800121040f, 0.843723257187741660f, + -0.536778413575385920f, + 0.843620315706004150f, -0.536940185614842910f, 0.843517343206759200f, + -0.537101937912544130f, + 0.843414339693792760f, -0.537263670462542530f, 0.843311305170892140f, + -0.537425383258891550f, + 0.843208239641845440f, -0.537587076295645390f, 0.843105143110442160f, + -0.537748749566859360f, + 0.843002015580472940f, -0.537910403066588880f, 0.842898857055729310f, + -0.538072036788890600f, + 0.842795667540004120f, -0.538233650727821700f, 0.842692447037091670f, + -0.538395244877439950f, + 0.842589195550786710f, -0.538556819231804100f, 0.842485913084885630f, + -0.538718373784973560f, + 0.842382599643185850f, -0.538879908531008420f, 0.842279255229485990f, + -0.539041423463969440f, + 0.842175879847585570f, -0.539202918577918240f, 0.842072473501285560f, + -0.539364393866917040f, + 0.841969036194387680f, -0.539525849325028890f, 0.841865567930695340f, + -0.539687284946317570f, + 0.841762068714012490f, -0.539848700724847590f, 0.841658538548144760f, + -0.540010096654684020f, + 0.841554977436898440f, -0.540171472729892850f, 0.841451385384081260f, + -0.540332828944540710f, + 0.841347762393501950f, -0.540494165292695230f, 0.841244108468970580f, + -0.540655481768424150f, + 0.841140423614298080f, -0.540816778365796670f, 0.841036707833296650f, + -0.540978055078882080f, + 0.840932961129779780f, -0.541139311901750800f, 0.840829183507561640f, + -0.541300548828474120f, + 0.840725374970458070f, -0.541461765853123440f, 0.840621535522285690f, + -0.541622962969771530f, + 0.840517665166862550f, -0.541784140172491550f, 0.840413763908007480f, + -0.541945297455357360f, + 0.840309831749540770f, -0.542106434812443920f, 0.840205868695283580f, + -0.542267552237826520f, + 0.840101874749058400f, -0.542428649725581250f, 0.839997849914688840f, + -0.542589727269785270f, + 0.839893794195999520f, -0.542750784864515890f, 0.839789707596816370f, + -0.542911822503851730f, + 0.839685590120966110f, -0.543072840181871740f, 0.839581441772277120f, + -0.543233837892655890f, + 0.839477262554578550f, -0.543394815630284800f, 0.839373052471700690f, + -0.543555773388839540f, + 0.839268811527475230f, -0.543716711162402280f, 0.839164539725734680f, + -0.543877628945055980f, + 0.839060237070312740f, -0.544038526730883820f, 0.838955903565044460f, + -0.544199404513970310f, + 0.838851539213765760f, -0.544360262288400400f, 0.838747144020313920f, + -0.544521100048259600f, + 0.838642717988527300f, -0.544681917787634530f, 0.838538261122245280f, + -0.544842715500612360f, + 0.838433773425308340f, -0.545003493181281160f, 0.838329254901558300f, + -0.545164250823729320f, + 0.838224705554838080f, -0.545324988422046460f, 0.838120125388991500f, + -0.545485705970322530f, + 0.838015514407863820f, -0.545646403462648590f, 0.837910872615301170f, + -0.545807080893116140f, + 0.837806200015150940f, -0.545967738255817570f, 0.837701496611261700f, + -0.546128375544845950f, + 0.837596762407483040f, -0.546288992754295210f, 0.837491997407665890f, + -0.546449589878259650f, + 0.837387201615661940f, -0.546610166910834860f, 0.837282375035324320f, + -0.546770723846116800f, + 0.837177517670507300f, -0.546931260678202190f, 0.837072629525066000f, + -0.547091777401188530f, + 0.836967710602857020f, -0.547252274009174090f, 0.836862760907737920f, + -0.547412750496257930f, + 0.836757780443567190f, -0.547573206856539760f, 0.836652769214204950f, + -0.547733643084120090f, + 0.836547727223512010f, -0.547894059173100190f, 0.836442654475350380f, + -0.548054455117581880f, + 0.836337550973583530f, -0.548214830911667780f, 0.836232416722075600f, + -0.548375186549461600f, + 0.836127251724692270f, -0.548535522025067390f, 0.836022055985299880f, + -0.548695837332590090f, + 0.835916829507766360f, -0.548856132466135290f, 0.835811572295960700f, + -0.549016407419809390f, + 0.835706284353752600f, -0.549176662187719660f, 0.835600965685013410f, + -0.549336896763974010f, + 0.835495616293615350f, -0.549497111142680960f, 0.835390236183431890f, + -0.549657305317949870f, + 0.835284825358337370f, -0.549817479283890910f, 0.835179383822207690f, + -0.549977633034614890f, + 0.835073911578919410f, -0.550137766564233630f, 0.834968408632350450f, + -0.550297879866859190f, + 0.834862874986380010f, -0.550457972936604810f, 0.834757310644888230f, + -0.550618045767584330f, + 0.834651715611756440f, -0.550778098353912120f, 0.834546089890866870f, + -0.550938130689703880f, + 0.834440433486103190f, -0.551098142769075430f, 0.834334746401350080f, + -0.551258134586143590f, + 0.834229028640493420f, -0.551418106135026060f, 0.834123280207420100f, + -0.551578057409841000f, + 0.834017501106018130f, -0.551737988404707340f, 0.833911691340176840f, + -0.551897899113745210f, + 0.833805850913786340f, -0.552057789531074980f, 0.833699979830738290f, + -0.552217659650817930f, + 0.833594078094925140f, -0.552377509467096070f, 0.833488145710240770f, + -0.552537338974032120f, + 0.833382182680579730f, -0.552697148165749770f, 0.833276189009838240f, + -0.552856937036373290f, + 0.833170164701913190f, -0.553016705580027470f, 0.833064109760702890f, + -0.553176453790838350f, + 0.832958024190106670f, -0.553336181662932300f, 0.832851907994025090f, + -0.553495889190436570f, + 0.832745761176359460f, -0.553655576367479310f, 0.832639583741012770f, + -0.553815243188189090f, + 0.832533375691888680f, -0.553974889646695500f, 0.832427137032892280f, + -0.554134515737128910f, + 0.832320867767929680f, -0.554294121453620000f, 0.832214567900907980f, + -0.554453706790300930f, + 0.832108237435735590f, -0.554613271741304040f, 0.832001876376321950f, + -0.554772816300762470f, + 0.831895484726577590f, -0.554932340462810370f, 0.831789062490414400f, + -0.555091844221582420f, + 0.831682609671745120f, -0.555251327571213980f, 0.831576126274483740f, + -0.555410790505841630f, + 0.831469612302545240f, -0.555570233019602180f, 0.831363067759845920f, + -0.555729655106633410f, + 0.831256492650303210f, -0.555889056761073810f, 0.831149886977835540f, + -0.556048437977062600f, + 0.831043250746362320f, -0.556207798748739930f, 0.830936583959804410f, + -0.556367139070246370f, + 0.830829886622083570f, -0.556526458935723610f, 0.830723158737122880f, + -0.556685758339313890f, + 0.830616400308846310f, -0.556845037275160100f, 0.830509611341179070f, + -0.557004295737405950f, + 0.830402791838047550f, -0.557163533720196220f, 0.830295941803379070f, + -0.557322751217676160f, + 0.830189061241102370f, -0.557481948223991550f, 0.830082150155146970f, + -0.557641124733289420f, + 0.829975208549443950f, -0.557800280739716990f, 0.829868236427924840f, + -0.557959416237422960f, + 0.829761233794523050f, -0.558118531220556100f, 0.829654200653172640f, + -0.558277625683266330f, + 0.829547137007808910f, -0.558436699619704100f, 0.829440042862368170f, + -0.558595753024020760f, + 0.829332918220788250f, -0.558754785890368310f, 0.829225763087007570f, + -0.558913798212899770f, + 0.829118577464965980f, -0.559072789985768480f, 0.829011361358604430f, + -0.559231761203128900f, + 0.828904114771864870f, -0.559390711859136140f, 0.828796837708690610f, + -0.559549641947945760f, + 0.828689530173025820f, -0.559708551463714680f, 0.828582192168815790f, + -0.559867440400600210f, + 0.828474823700007130f, -0.560026308752760380f, 0.828367424770547480f, + -0.560185156514354080f, + 0.828259995384385660f, -0.560343983679540860f, 0.828152535545471410f, + -0.560502790242481060f, + 0.828045045257755800f, -0.560661576197336030f, 0.827937524525190870f, + -0.560820341538267430f, + 0.827829973351729920f, -0.560979086259438150f, 0.827722391741327220f, + -0.561137810355011420f, + 0.827614779697938400f, -0.561296513819151470f, 0.827507137225519830f, + -0.561455196646023280f, + 0.827399464328029470f, -0.561613858829792420f, 0.827291761009425810f, + -0.561772500364625340f, + 0.827184027273669130f, -0.561931121244689470f, 0.827076263124720270f, + -0.562089721464152480f, + 0.826968468566541600f, -0.562248301017183150f, 0.826860643603096190f, + -0.562406859897951140f, + 0.826752788238348520f, -0.562565398100626560f, 0.826644902476264320f, + -0.562723915619380400f, + 0.826536986320809960f, -0.562882412448384440f, 0.826429039775953500f, + -0.563040888581811230f, + 0.826321062845663530f, -0.563199344013834090f, 0.826213055533910220f, + -0.563357778738627020f, + 0.826105017844664610f, -0.563516192750364800f, 0.825996949781899080f, + -0.563674586043223070f, + 0.825888851349586780f, -0.563832958611378170f, 0.825780722551702430f, + -0.563991310449006970f, + 0.825672563392221390f, -0.564149641550287680f, 0.825564373875120490f, + -0.564307951909398640f, + 0.825456154004377550f, -0.564466241520519500f, 0.825347903783971380f, + -0.564624510377830120f, + 0.825239623217882250f, -0.564782758475511400f, 0.825131312310091070f, + -0.564940985807745210f, + 0.825022971064580220f, -0.565099192368713980f, 0.824914599485333190f, + -0.565257378152600800f, + 0.824806197576334330f, -0.565415543153589660f, 0.824697765341569470f, + -0.565573687365865330f, + 0.824589302785025290f, -0.565731810783613120f, 0.824480809910689500f, + -0.565889913401019570f, + 0.824372286722551250f, -0.566047995212271450f, 0.824263733224600560f, + -0.566206056211556730f, + 0.824155149420828570f, -0.566364096393063840f, 0.824046535315227760f, + -0.566522115750982100f, + 0.823937890911791370f, -0.566680114279501600f, 0.823829216214513990f, + -0.566838091972813320f, + 0.823720511227391430f, -0.566996048825108680f, 0.823611775954420260f, + -0.567153984830580100f, + 0.823503010399598500f, -0.567311899983420800f, 0.823394214566925080f, + -0.567469794277824510f, + 0.823285388460400110f, -0.567627667707986230f, 0.823176532084024860f, + -0.567785520268101140f, + 0.823067645441801670f, -0.567943351952365560f, 0.822958728537734000f, + -0.568101162754976460f, + 0.822849781375826430f, -0.568258952670131490f, 0.822740803960084420f, + -0.568416721692029280f, + 0.822631796294514990f, -0.568574469814869140f, 0.822522758383125940f, + -0.568732197032851050f, + 0.822413690229926390f, -0.568889903340175860f, 0.822304591838926350f, + -0.569047588731045110f, + 0.822195463214137170f, -0.569205253199661200f, 0.822086304359571090f, + -0.569362896740227220f, + 0.821977115279241550f, -0.569520519346947140f, 0.821867895977163250f, + -0.569678121014025600f, + 0.821758646457351750f, -0.569835701735668000f, 0.821649366723823940f, + -0.569993261506080540f, + 0.821540056780597610f, -0.570150800319470300f, 0.821430716631691870f, + -0.570308318170044900f, + 0.821321346281126740f, -0.570465815052012990f, 0.821211945732923550f, + -0.570623290959583750f, + 0.821102514991104650f, -0.570780745886967260f, 0.820993054059693580f, + -0.570938179828374360f, + 0.820883562942714580f, -0.571095592778016690f, 0.820774041644193650f, + -0.571252984730106660f, + 0.820664490168157460f, -0.571410355678857230f, 0.820554908518633890f, + -0.571567705618482580f, + 0.820445296699652050f, -0.571725034543197120f, 0.820335654715241840f, + -0.571882342447216590f, + 0.820225982569434690f, -0.572039629324757050f, 0.820116280266262820f, + -0.572196895170035580f, + 0.820006547809759680f, -0.572354139977269920f, 0.819896785203959810f, + -0.572511363740678790f, + 0.819786992452898990f, -0.572668566454481160f, 0.819677169560613870f, + -0.572825748112897550f, + 0.819567316531142230f, -0.572982908710148560f, 0.819457433368523280f, + -0.573140048240455950f, + 0.819347520076796900f, -0.573297166698042200f, 0.819237576660004520f, + -0.573454264077130400f, + 0.819127603122188240f, -0.573611340371944610f, 0.819017599467391500f, + -0.573768395576709560f, + 0.818907565699658950f, -0.573925429685650750f, 0.818797501823036010f, + -0.574082442692994470f, + 0.818687407841569680f, -0.574239434592967890f, 0.818577283759307610f, + -0.574396405379798750f, + 0.818467129580298660f, -0.574553355047715760f, 0.818356945308593150f, + -0.574710283590948330f, + 0.818246730948242070f, -0.574867191003726740f, 0.818136486503297730f, + -0.575024077280281710f, + 0.818026211977813440f, -0.575180942414845080f, 0.817915907375843850f, + -0.575337786401649450f, + 0.817805572701444270f, -0.575494609234928120f, 0.817695207958671680f, + -0.575651410908915140f, + 0.817584813151583710f, -0.575808191417845340f, 0.817474388284239240f, + -0.575964950755954220f, + 0.817363933360698460f, -0.576121688917478280f, 0.817253448385022340f, + -0.576278405896654910f, + 0.817142933361272970f, -0.576435101687721830f, 0.817032388293513880f, + -0.576591776284917760f, + 0.816921813185809480f, -0.576748429682482410f, 0.816811208042225290f, + -0.576905061874655960f, + 0.816700572866827850f, -0.577061672855679440f, 0.816589907663684890f, + -0.577218262619794920f, + 0.816479212436865390f, -0.577374831161244880f, 0.816368487190439200f, + -0.577531378474272720f, + 0.816257731928477390f, -0.577687904553122800f, 0.816146946655052270f, + -0.577844409392039850f, + 0.816036131374236810f, -0.578000892985269910f, 0.815925286090105510f, + -0.578157355327059360f, + 0.815814410806733780f, -0.578313796411655590f, 0.815703505528198260f, + -0.578470216233306630f, + 0.815592570258576790f, -0.578626614786261430f, 0.815481605001947770f, + -0.578782992064769690f, + 0.815370609762391290f, -0.578939348063081780f, 0.815259584543988280f, + -0.579095682775449090f, + 0.815148529350820830f, -0.579251996196123550f, 0.815037444186972220f, + -0.579408288319357870f, + 0.814926329056526620f, -0.579564559139405630f, 0.814815183963569440f, + -0.579720808650521450f, + 0.814704008912187080f, -0.579877036846960350f, 0.814592803906467270f, + -0.580033243722978150f, + 0.814481568950498610f, -0.580189429272831680f, 0.814370304048371070f, + -0.580345593490778300f, + 0.814259009204175270f, -0.580501736371076490f, 0.814147684422003360f, + -0.580657857907985300f, + 0.814036329705948410f, -0.580813958095764530f, 0.813924945060104600f, + -0.580970036928674770f, + 0.813813530488567190f, -0.581126094400977620f, 0.813702085995432700f, + -0.581282130506935000f, + 0.813590611584798510f, -0.581438145240810170f, 0.813479107260763220f, + -0.581594138596866930f, + 0.813367573027426570f, -0.581750110569369650f, 0.813256008888889380f, + -0.581906061152583810f, + 0.813144414849253590f, -0.582061990340775440f, 0.813032790912622040f, + -0.582217898128211670f, + 0.812921137083098770f, -0.582373784509160110f, 0.812809453364789270f, + -0.582529649477889320f, + 0.812697739761799490f, -0.582685493028668460f, 0.812585996278237130f, + -0.582841315155767650f, + 0.812474222918210480f, -0.582997115853457700f, 0.812362419685829230f, + -0.583152895116010430f, + 0.812250586585203880f, -0.583308652937698290f, 0.812138723620446480f, + -0.583464389312794320f, + 0.812026830795669730f, -0.583620104235572760f, 0.811914908114987790f, + -0.583775797700308070f, + 0.811802955582515470f, -0.583931469701276180f, 0.811690973202369050f, + -0.584087120232753440f, + 0.811578960978665890f, -0.584242749289016980f, 0.811466918915524250f, + -0.584398356864344600f, + 0.811354847017063730f, -0.584553942953015330f, 0.811242745287404810f, + -0.584709507549308390f, + 0.811130613730669190f, -0.584865050647504490f, 0.811018452350979470f, + -0.585020572241884530f, + 0.810906261152459670f, -0.585176072326730410f, 0.810794040139234730f, + -0.585331550896324940f, + 0.810681789315430780f, -0.585487007944951340f, 0.810569508685174630f, + -0.585642443466894420f, + 0.810457198252594770f, -0.585797857456438860f, 0.810344858021820550f, + -0.585953249907870570f, + 0.810232487996982330f, -0.586108620815476430f, 0.810120088182211600f, + -0.586263970173543590f, + 0.810007658581641140f, -0.586419297976360500f, 0.809895199199404450f, + -0.586574604218216170f, + 0.809782710039636530f, -0.586729888893400390f, 0.809670191106473090f, + -0.586885151996203950f, + 0.809557642404051260f, -0.587040393520917970f, 0.809445063936509170f, + -0.587195613461834800f, + 0.809332455707985950f, -0.587350811813247660f, 0.809219817722621750f, + -0.587505988569450020f, + 0.809107149984558240f, -0.587661143724736660f, 0.808994452497937670f, + -0.587816277273402910f, + 0.808881725266903610f, -0.587971389209745010f, 0.808768968295600850f, + -0.588126479528059850f, + 0.808656181588174980f, -0.588281548222645220f, 0.808543365148773010f, + -0.588436595287799790f, + 0.808430518981542720f, -0.588591620717822890f, 0.808317643090633250f, + -0.588746624507014540f, + 0.808204737480194720f, -0.588901606649675720f, 0.808091802154378370f, + -0.589056567140108460f, + 0.807978837117336310f, -0.589211505972614960f, 0.807865842373222120f, + -0.589366423141498790f, + 0.807752817926190360f, -0.589521318641063940f, 0.807639763780396480f, + -0.589676192465615420f, + 0.807526679939997160f, -0.589831044609458790f, 0.807413566409150190f, + -0.589985875066900920f, + 0.807300423192014450f, -0.590140683832248820f, 0.807187250292749960f, + -0.590295470899810830f, + 0.807074047715517610f, -0.590450236263895810f, 0.806960815464479730f, + -0.590604979918813330f, + 0.806847553543799330f, -0.590759701858874160f, 0.806734261957640860f, + -0.590914402078389520f, + 0.806620940710169650f, -0.591069080571671400f, 0.806507589805552260f, + -0.591223737333032910f, + 0.806394209247956240f, -0.591378372356787580f, 0.806280799041550480f, + -0.591532985637249990f, + 0.806167359190504420f, -0.591687577168735430f, 0.806053889698989060f, + -0.591842146945560140f, + 0.805940390571176280f, -0.591996694962040990f, 0.805826861811239300f, + -0.592151221212495530f, + 0.805713303423352230f, -0.592305725691242290f, 0.805599715411690060f, + -0.592460208392600830f, + 0.805486097780429230f, -0.592614669310891130f, 0.805372450533747060f, + -0.592769108440434070f, + 0.805258773675822210f, -0.592923525775551300f, 0.805145067210834230f, + -0.593077921310565470f, + 0.805031331142963660f, -0.593232295039799800f, 0.804917565476392260f, + -0.593386646957578480f, + 0.804803770215302920f, -0.593540977058226390f, 0.804689945363879500f, + -0.593695285336069190f, + 0.804576090926307110f, -0.593849571785433630f, 0.804462206906771840f, + -0.594003836400646690f, + 0.804348293309460780f, -0.594158079176036800f, 0.804234350138562260f, + -0.594312300105932830f, + 0.804120377398265810f, -0.594466499184664430f, 0.804006375092761520f, + -0.594620676406562240f, + 0.803892343226241260f, -0.594774831765957580f, 0.803778281802897570f, + -0.594928965257182420f, + 0.803664190826924090f, -0.595083076874569960f, 0.803550070302515680f, + -0.595237166612453850f, + 0.803435920233868120f, -0.595391234465168730f, 0.803321740625178580f, + -0.595545280427049790f, + 0.803207531480644940f, -0.595699304492433360f, 0.803093292804466400f, + -0.595853306655656280f, + 0.802979024600843250f, -0.596007286911056530f, 0.802864726873976700f, + -0.596161245252972540f, + 0.802750399628069160f, -0.596315181675743710f, 0.802636042867324150f, + -0.596469096173710360f, + 0.802521656595946430f, -0.596622988741213220f, 0.802407240818141300f, + -0.596776859372594390f, + 0.802292795538115720f, -0.596930708062196500f, 0.802178320760077450f, + -0.597084534804362740f, + 0.802063816488235440f, -0.597238339593437420f, 0.801949282726799770f, + -0.597392122423765710f, + 0.801834719479981310f, -0.597545883289693160f, 0.801720126751992330f, + -0.597699622185566830f, + 0.801605504547046150f, -0.597853339105733910f, 0.801490852869356950f, + -0.598007034044542700f, + 0.801376171723140240f, -0.598160706996342270f, 0.801261461112612540f, + -0.598314357955482600f, + 0.801146721041991360f, -0.598467986916314310f, 0.801031951515495330f, + -0.598621593873188920f, + 0.800917152537344300f, -0.598775178820458720f, 0.800802324111759110f, + -0.598928741752476900f, + 0.800687466242961610f, -0.599082282663597310f, 0.800572578935174860f, + -0.599235801548174570f, + 0.800457662192622820f, -0.599389298400564540f, 0.800342716019530660f, + -0.599542773215123390f, + 0.800227740420124790f, -0.599696225986208310f, 0.800112735398632370f, + -0.599849656708177250f, + 0.799997700959281910f, -0.600003065375388940f, 0.799882637106302810f, + -0.600156451982203240f, + 0.799767543843925680f, -0.600309816522980430f, 0.799652421176382240f, + -0.600463158992081580f, + 0.799537269107905010f, -0.600616479383868970f, 0.799422087642728040f, + -0.600769777692705230f, + 0.799306876785086160f, -0.600923053912954090f, 0.799191636539215210f, + -0.601076308038980160f, + 0.799076366909352350f, -0.601229540065148500f, 0.798961067899735760f, + -0.601382749985825420f, + 0.798845739514604580f, -0.601535937795377730f, 0.798730381758199210f, + -0.601689103488172950f, + 0.798614994634760820f, -0.601842247058580030f, 0.798499578148532120f, + -0.601995368500968020f, + 0.798384132303756380f, -0.602148467809707210f, 0.798268657104678430f, + -0.602301544979168550f, + 0.798153152555543750f, -0.602454600003723750f, 0.798037618660599410f, + -0.602607632877745440f, + 0.797922055424093000f, -0.602760643595607220f, 0.797806462850273570f, + -0.602913632151683030f, + 0.797690840943391160f, -0.603066598540348160f, 0.797575189707696700f, + -0.603219542755978440f, + 0.797459509147442460f, -0.603372464792950260f, 0.797343799266881700f, + -0.603525364645641550f, + 0.797228060070268700f, -0.603678242308430370f, 0.797112291561858920f, + -0.603831097775695880f, + 0.796996493745908750f, -0.603983931041818020f, 0.796880666626675780f, + -0.604136742101177520f, + 0.796764810208418830f, -0.604289530948155960f, 0.796648924495397260f, + -0.604442297577135860f, + 0.796533009491872000f, -0.604595041982500360f, 0.796417065202104980f, + -0.604747764158633410f, + 0.796301091630359110f, -0.604900464099919820f, 0.796185088780898440f, + -0.605053141800745320f, + 0.796069056657987990f, -0.605205797255496500f, 0.795952995265893910f, + -0.605358430458560530f, + 0.795836904608883570f, -0.605511041404325550f, 0.795720784691225090f, + -0.605663630087180380f, + 0.795604635517188070f, -0.605816196501514970f, 0.795488457091042990f, + -0.605968740641719680f, + 0.795372249417061310f, -0.606121262502186120f, 0.795256012499515610f, + -0.606273762077306430f, + 0.795139746342679590f, -0.606426239361473550f, 0.795023450950828050f, + -0.606578694349081290f, + 0.794907126328237010f, -0.606731127034524480f, 0.794790772479183170f, + -0.606883537412198470f, + 0.794674389407944550f, -0.607035925476499650f, 0.794557977118800380f, + -0.607188291221825160f, + 0.794441535616030590f, -0.607340634642572930f, 0.794325064903916520f, + -0.607492955733141550f, + 0.794208564986740640f, -0.607645254487930830f, 0.794092035868785960f, + -0.607797530901341140f, + 0.793975477554337170f, -0.607949784967773630f, 0.793858890047679730f, + -0.608102016681630440f, + 0.793742273353100210f, -0.608254226037314490f, 0.793625627474886300f, + -0.608406413029229150f, + 0.793508952417326660f, -0.608558577651779450f, 0.793392248184711100f, + -0.608710719899370310f, + 0.793275514781330630f, -0.608862839766408200f, 0.793158752211477140f, + -0.609014937247299830f, + 0.793041960479443640f, -0.609167012336453210f, 0.792925139589524260f, + -0.609319065028276820f, + 0.792808289546014120f, -0.609471095317180240f, 0.792691410353209450f, + -0.609623103197573730f, + 0.792574502015407690f, -0.609775088663868430f, 0.792457564536907080f, + -0.609927051710476120f, + 0.792340597922007170f, -0.610078992331809620f, 0.792223602175008310f, + -0.610230910522282620f, + 0.792106577300212390f, -0.610382806276309480f, 0.791989523301921850f, + -0.610534679588305320f, + 0.791872440184440470f, -0.610686530452686280f, 0.791755327952073150f, + -0.610838358863869170f, + 0.791638186609125880f, -0.610990164816271660f, 0.791521016159905220f, + -0.611141948304312570f, + 0.791403816608719500f, -0.611293709322410890f, 0.791286587959877830f, + -0.611445447864987000f, + 0.791169330217690200f, -0.611597163926461910f, 0.791052043386467950f, + -0.611748857501257290f, + 0.790934727470523290f, -0.611900528583796070f, 0.790817382474169770f, + -0.612052177168501470f, + 0.790700008401721610f, -0.612203803249797950f, 0.790582605257494460f, + -0.612355406822110650f, + 0.790465173045804880f, -0.612506987879865570f, 0.790347711770970520f, + -0.612658546417489290f, + 0.790230221437310030f, -0.612810082429409710f, 0.790112702049143300f, + -0.612961595910055170f, + 0.789995153610791090f, -0.613113086853854910f, 0.789877576126575280f, + -0.613264555255239040f, + 0.789759969600819070f, -0.613416001108638590f, 0.789642334037846340f, + -0.613567424408485330f, + 0.789524669441982190f, -0.613718825149211720f, 0.789406975817552930f, + -0.613870203325251330f, + 0.789289253168885650f, -0.614021558931038380f, 0.789171501500308900f, + -0.614172891961007990f, + 0.789053720816151880f, -0.614324202409595950f, 0.788935911120745240f, + -0.614475490271239040f, + 0.788818072418420280f, -0.614626755540375050f, 0.788700204713509660f, + -0.614777998211442080f, + 0.788582308010347120f, -0.614929218278879590f, 0.788464382313267540f, + -0.615080415737127460f, + 0.788346427626606340f, -0.615231590580626820f, 0.788228443954700490f, + -0.615382742803819220f, + 0.788110431301888070f, -0.615533872401147320f, 0.787992389672507950f, + -0.615684979367054570f, + 0.787874319070900220f, -0.615836063695985090f, 0.787756219501406060f, + -0.615987125382383760f, + 0.787638090968367450f, -0.616138164420696910f, 0.787519933476127810f, + -0.616289180805370980f, + 0.787401747029031430f, -0.616440174530853650f, 0.787283531631423620f, + -0.616591145591593110f, + 0.787165287287651010f, -0.616742093982038720f, 0.787047014002060790f, + -0.616893019696640680f, + 0.786928711779001810f, -0.617043922729849760f, 0.786810380622823490f, + -0.617194803076117630f, + 0.786692020537876790f, -0.617345660729896830f, 0.786573631528513230f, + -0.617496495685640910f, + 0.786455213599085770f, -0.617647307937803870f, 0.786336766753948260f, + -0.617798097480841020f, + 0.786218290997455660f, -0.617948864309208150f, 0.786099786333963930f, + -0.618099608417362000f, + 0.785981252767830150f, -0.618250329799760250f, 0.785862690303412600f, + -0.618401028450860980f, + 0.785744098945070360f, -0.618551704365123740f, 0.785625478697163700f, + -0.618702357537008530f, + 0.785506829564053930f, -0.618852987960976320f, 0.785388151550103550f, + -0.619003595631488660f, + 0.785269444659675850f, -0.619154180543008410f, 0.785150708897135560f, + -0.619304742689998690f, + 0.785031944266848080f, -0.619455282066924020f, 0.784913150773180020f, + -0.619605798668249270f, + 0.784794328420499230f, -0.619756292488440660f, 0.784675477213174320f, + -0.619906763521964720f, + 0.784556597155575240f, -0.620057211763289100f, 0.784437688252072830f, + -0.620207637206882430f, + 0.784318750507038920f, -0.620358039847213720f, 0.784199783924846570f, + -0.620508419678753360f, + 0.784080788509869950f, -0.620658776695972140f, 0.783961764266484120f, + -0.620809110893341900f, + 0.783842711199065230f, -0.620959422265335180f, 0.783723629311990470f, + -0.621109710806425630f, + 0.783604518609638200f, -0.621259976511087550f, 0.783485379096387820f, + -0.621410219373796150f, + 0.783366210776619720f, -0.621560439389027160f, 0.783247013654715380f, + -0.621710636551257690f, + 0.783127787735057310f, -0.621860810854965360f, 0.783008533022029110f, + -0.622010962294628600f, + 0.782889249520015480f, -0.622161090864726820f, 0.782769937233402050f, + -0.622311196559740320f, + 0.782650596166575730f, -0.622461279374149970f, 0.782531226323924240f, + -0.622611339302437730f, + 0.782411827709836530f, -0.622761376339086350f, 0.782292400328702400f, + -0.622911390478579460f, + 0.782172944184913010f, -0.623061381715401260f, 0.782053459282860300f, + -0.623211350044037270f, + 0.781933945626937630f, -0.623361295458973230f, 0.781814403221538830f, + -0.623511217954696440f, + 0.781694832071059390f, -0.623661117525694530f, 0.781575232179895550f, + -0.623810994166456130f, + 0.781455603552444590f, -0.623960847871470660f, 0.781335946193104870f, + -0.624110678635228510f, + 0.781216260106276090f, -0.624260486452220650f, 0.781096545296358520f, + -0.624410271316939270f, + 0.780976801767753750f, -0.624560033223877210f, 0.780857029524864580f, + -0.624709772167528100f, + 0.780737228572094490f, -0.624859488142386340f, 0.780617398913848400f, + -0.625009181142947460f, + 0.780497540554531910f, -0.625158851163707620f, 0.780377653498552040f, + -0.625308498199164010f, + 0.780257737750316590f, -0.625458122243814360f, 0.780137793314234610f, + -0.625607723292157410f, + 0.780017820194715990f, -0.625757301338692900f, 0.779897818396172000f, + -0.625906856377921090f, + 0.779777787923014550f, -0.626056388404343520f, 0.779657728779656890f, + -0.626205897412462130f, + 0.779537640970513260f, -0.626355383396779990f, 0.779417524499998900f, + -0.626504846351800810f, + 0.779297379372530300f, -0.626654286272029350f, 0.779177205592524680f, + -0.626803703151971200f, + 0.779057003164400630f, -0.626953096986132660f, 0.778936772092577500f, + -0.627102467769020900f, + 0.778816512381475980f, -0.627251815495144080f, 0.778696224035517530f, + -0.627401140159011050f, + 0.778575907059125050f, -0.627550441755131530f, 0.778455561456721900f, + -0.627699720278016240f, + 0.778335187232733210f, -0.627848975722176460f, 0.778214784391584540f, + -0.627998208082124700f, + 0.778094352937702790f, -0.628147417352374000f, 0.777973892875516100f, + -0.628296603527438320f, + 0.777853404209453150f, -0.628445766601832710f, 0.777732886943944050f, + -0.628594906570072550f, + 0.777612341083420030f, -0.628744023426674680f, 0.777491766632313010f, + -0.628893117166156480f, + 0.777371163595056310f, -0.629042187783036000f, 0.777250531976084070f, + -0.629191235271832290f, + 0.777129871779831620f, -0.629340259627065630f, 0.777009183010735290f, + -0.629489260843256630f, + 0.776888465673232440f, -0.629638238914926980f, 0.776767719771761510f, + -0.629787193836599200f, + 0.776646945310762060f, -0.629936125602796440f, 0.776526142294674430f, + -0.630085034208043180f, + 0.776405310727940390f, -0.630233919646864370f, 0.776284450615002510f, + -0.630382781913785940f, + 0.776163561960304340f, -0.630531621003334600f, 0.776042644768290770f, + -0.630680436910037940f, + 0.775921699043407690f, -0.630829229628424470f, 0.775800724790101650f, + -0.630977999153023550f, + 0.775679722012820650f, -0.631126745478365340f, 0.775558690716013580f, + -0.631275468598980760f, + 0.775437630904130540f, -0.631424168509401860f, 0.775316542581622530f, + -0.631572845204161020f, + 0.775195425752941420f, -0.631721498677792260f, 0.775074280422540450f, + -0.631870128924829850f, + 0.774953106594873930f, -0.632018735939809060f, 0.774831904274396850f, + -0.632167319717265920f, + 0.774710673465565550f, -0.632315880251737570f, 0.774589414172837550f, + -0.632464417537761840f, + 0.774468126400670860f, -0.632612931569877410f, 0.774346810153525130f, + -0.632761422342624000f, + 0.774225465435860680f, -0.632909889850541750f, 0.774104092252139050f, + -0.633058334088172140f, + 0.773982690606822900f, -0.633206755050057190f, 0.773861260504375540f, + -0.633355152730739950f, + 0.773739801949261840f, -0.633503527124764320f, 0.773618314945947460f, + -0.633651878226674900f, + 0.773496799498899050f, -0.633800206031017280f, 0.773375255612584470f, + -0.633948510532337810f, + 0.773253683291472590f, -0.634096791725183740f, 0.773132082540033070f, + -0.634245049604103330f, + 0.773010453362736990f, -0.634393284163645490f, 0.772888795764056220f, + -0.634541495398360020f, + 0.772767109748463850f, -0.634689683302797740f, 0.772645395320433860f, + -0.634837847871509990f, + 0.772523652484441330f, -0.634985989099049460f, 0.772401881244962450f, + -0.635134106979969190f, + 0.772280081606474320f, -0.635282201508823420f, 0.772158253573455240f, + -0.635430272680167160f, + 0.772036397150384520f, -0.635578320488556110f, 0.771914512341742350f, + -0.635726344928547070f, + 0.771792599152010150f, -0.635874345994697720f, 0.771670657585670330f, + -0.636022323681566300f, + 0.771548687647206300f, -0.636170277983712170f, 0.771426689341102590f, + -0.636318208895695460f, + 0.771304662671844830f, -0.636466116412077180f, 0.771182607643919330f, + -0.636614000527419120f, + 0.771060524261813820f, -0.636761861236284200f, 0.770938412530016940f, + -0.636909698533235870f, + 0.770816272453018540f, -0.637057512412838590f, 0.770694104035309140f, + -0.637205302869657600f, + 0.770571907281380810f, -0.637353069898259130f, 0.770449682195725960f, + -0.637500813493210190f, + 0.770327428782838890f, -0.637648533649078810f, 0.770205147047214210f, + -0.637796230360433540f, + 0.770082836993347900f, -0.637943903621844060f, 0.769960498625737230f, + -0.638091553427880820f, + 0.769838131948879840f, -0.638239179773115280f, 0.769715736967275130f, + -0.638386782652119570f, + 0.769593313685422940f, -0.638534362059466790f, 0.769470862107824670f, + -0.638681917989730730f, + 0.769348382238982280f, -0.638829450437486290f, 0.769225874083399260f, + -0.638976959397309140f, + 0.769103337645579700f, -0.639124444863775730f, 0.768980772930028870f, + -0.639271906831463510f, + 0.768858179941253270f, -0.639419345294950700f, 0.768735558683760310f, + -0.639566760248816310f, + 0.768612909162058380f, -0.639714151687640450f, 0.768490231380656860f, + -0.639861519606003900f, + 0.768367525344066270f, -0.640008863998488440f, 0.768244791056798330f, + -0.640156184859676510f, + 0.768122028523365420f, -0.640303482184151670f, 0.767999237748281270f, + -0.640450755966498140f, + 0.767876418736060610f, -0.640598006201301030f, 0.767753571491219030f, + -0.640745232883146440f, + 0.767630696018273380f, -0.640892436006621380f, 0.767507792321741270f, + -0.641039615566313390f, + 0.767384860406141730f, -0.641186771556811250f, 0.767261900275994500f, + -0.641333903972704290f, + 0.767138911935820400f, -0.641481012808583160f, 0.767015895390141480f, + -0.641628098059038750f, + 0.766892850643480670f, -0.641775159718663500f, 0.766769777700361920f, + -0.641922197782050170f, + 0.766646676565310380f, -0.642069212243792540f, 0.766523547242852210f, + -0.642216203098485370f, + 0.766400389737514230f, -0.642363170340724320f, 0.766277204053824710f, + -0.642510113965105710f, + 0.766153990196312920f, -0.642657033966226860f, 0.766030748169509000f, + -0.642803930338685990f, + 0.765907477977944340f, -0.642950803077082080f, 0.765784179626150970f, + -0.643097652176015110f, + 0.765660853118662500f, -0.643244477630085850f, 0.765537498460013070f, + -0.643391279433895850f, + 0.765414115654738270f, -0.643538057582047740f, 0.765290704707374370f, + -0.643684812069144850f, + 0.765167265622458960f, -0.643831542889791390f, 0.765043798404530520f, + -0.643978250038592660f, + 0.764920303058128410f, -0.644124933510154540f, 0.764796779587793460f, + -0.644271593299083790f, + 0.764673227998067140f, -0.644418229399988380f, 0.764549648293492150f, + -0.644564841807476640f, + 0.764426040478612070f, -0.644711430516158310f, 0.764302404557971720f, + -0.644857995520643710f, + 0.764178740536116670f, -0.645004536815543930f, 0.764055048417593970f, + -0.645151054395471160f, + 0.763931328206951090f, -0.645297548255038380f, 0.763807579908737160f, + -0.645444018388859230f, + 0.763683803527501870f, -0.645590464791548690f, 0.763559999067796150f, + -0.645736887457722290f, + 0.763436166534172010f, -0.645883286381996320f, 0.763312305931182380f, + -0.646029661558988330f, + 0.763188417263381270f, -0.646176012983316280f, 0.763064500535323710f, + -0.646322340649599480f, + 0.762940555751565720f, -0.646468644552457780f, 0.762816582916664430f, + -0.646614924686512050f, + 0.762692582035177980f, -0.646761181046383920f, 0.762568553111665380f, + -0.646907413626696020f, + 0.762444496150687210f, -0.647053622422071540f, 0.762320411156804270f, + -0.647199807427135230f, + 0.762196298134578900f, -0.647345968636512060f, 0.762072157088574560f, + -0.647492106044828100f, + 0.761947988023355390f, -0.647638219646710310f, 0.761823790943486960f, + -0.647784309436786440f, + 0.761699565853535380f, -0.647930375409685340f, 0.761575312758068000f, + -0.648076417560036530f, + 0.761451031661653620f, -0.648222435882470420f, 0.761326722568861360f, + -0.648368430371618290f, + 0.761202385484261780f, -0.648514401022112440f, 0.761078020412426560f, + -0.648660347828585840f, + 0.760953627357928150f, -0.648806270785672550f, 0.760829206325340010f, + -0.648952169888007300f, + 0.760704757319236920f, -0.649098045130225950f, 0.760580280344194450f, + -0.649243896506964900f, + 0.760455775404789260f, -0.649389724012861660f, 0.760331242505599030f, + -0.649535527642554730f, + 0.760206681651202420f, -0.649681307390683190f, 0.760082092846179340f, + -0.649827063251887100f, + 0.759957476095110330f, -0.649972795220807530f, 0.759832831402577400f, + -0.650118503292086200f, + 0.759708158773163440f, -0.650264187460365850f, 0.759583458211452010f, + -0.650409847720290310f, + 0.759458729722028210f, -0.650555484066503880f, 0.759333973309477940f, + -0.650701096493652040f, + 0.759209188978388070f, -0.650846684996380880f, 0.759084376733346610f, + -0.650992249569337660f, + 0.758959536578942440f, -0.651137790207170330f, 0.758834668519765660f, + -0.651283306904527740f, + 0.758709772560407390f, -0.651428799656059820f, 0.758584848705459610f, + -0.651574268456416970f, + 0.758459896959515430f, -0.651719713300250910f, 0.758334917327168960f, + -0.651865134182213920f, + 0.758209909813015280f, -0.652010531096959500f, 0.758084874421650730f, + -0.652155904039141590f, + 0.757959811157672300f, -0.652301253003415460f, 0.757834720025678310f, + -0.652446577984436730f, + 0.757709601030268080f, -0.652591878976862440f, 0.757584454176041810f, + -0.652737155975350310f, + 0.757459279467600720f, -0.652882408974558850f, 0.757334076909547130f, + -0.653027637969147530f, + 0.757208846506484570f, -0.653172842953776760f, 0.757083588263017140f, + -0.653318023923107670f, + 0.756958302183750490f, -0.653463180871802330f, 0.756832988273290820f, + -0.653608313794523890f, + 0.756707646536245670f, -0.653753422685936060f, 0.756582276977223470f, + -0.653898507540703780f, + 0.756456879600833740f, -0.654043568353492640f, 0.756331454411686920f, + -0.654188605118969040f, + 0.756206001414394540f, -0.654333617831800440f, 0.756080520613569120f, + -0.654478606486655350f, + 0.755955012013824420f, -0.654623571078202680f, 0.755829475619774760f, + -0.654768511601112600f, + 0.755703911436035880f, -0.654913428050056030f, 0.755578319467224540f, + -0.655058320419704910f, + 0.755452699717958250f, -0.655203188704731820f, 0.755327052192855670f, + -0.655348032899810470f, + 0.755201376896536550f, -0.655492852999615350f, 0.755075673833621620f, + -0.655637648998821820f, + 0.754949943008732640f, -0.655782420892106030f, 0.754824184426492350f, + -0.655927168674145360f, + 0.754698398091524500f, -0.656071892339617600f, 0.754572584008453840f, + -0.656216591883201920f, + 0.754446742181906440f, -0.656361267299578000f, 0.754320872616508820f, + -0.656505918583426550f, + 0.754194975316889170f, -0.656650545729428940f, 0.754069050287676120f, + -0.656795148732268070f, + 0.753943097533499640f, -0.656939727586627110f, 0.753817117058990790f, + -0.657084282287190180f, + 0.753691108868781210f, -0.657228812828642540f, 0.753565072967504300f, + -0.657373319205670210f, + 0.753439009359793580f, -0.657517801412960120f, 0.753312918050284330f, + -0.657662259445200070f, + 0.753186799043612520f, -0.657806693297078640f, 0.753060652344415100f, + -0.657951102963285520f, + 0.752934477957330150f, -0.658095488438511180f, 0.752808275886996950f, + -0.658239849717446870f, + 0.752682046138055340f, -0.658384186794785050f, 0.752555788715146390f, + -0.658528499665218650f, + 0.752429503622912390f, -0.658672788323441890f, 0.752303190865996400f, + -0.658817052764149480f, + 0.752176850449042810f, -0.658961292982037320f, 0.752050482376696360f, + -0.659105508971802090f, + 0.751924086653603550f, -0.659249700728141490f, 0.751797663284411550f, + -0.659393868245753860f, + 0.751671212273768430f, -0.659538011519338660f, 0.751544733626323680f, + -0.659682130543596150f, + 0.751418227346727470f, -0.659826225313227320f, 0.751291693439630870f, + -0.659970295822934540f, + 0.751165131909686480f, -0.660114342067420480f, 0.751038542761547360f, + -0.660258364041389050f, + 0.750911925999867890f, -0.660402361739545030f, 0.750785281629303690f, + -0.660546335156593890f, + 0.750658609654510700f, -0.660690284287242300f, 0.750531910080146410f, + -0.660834209126197610f, + 0.750405182910869330f, -0.660978109668168060f, 0.750278428151338720f, + -0.661121985907862860f, + 0.750151645806215070f, -0.661265837839992270f, 0.750024835880159780f, + -0.661409665459266940f, + 0.749897998377835330f, -0.661553468760398890f, 0.749771133303905100f, + -0.661697247738101010f, + 0.749644240663033480f, -0.661841002387086870f, 0.749517320459886170f, + -0.661984732702070920f, + 0.749390372699129560f, -0.662128438677768720f, 0.749263397385431130f, + -0.662272120308896590f, + 0.749136394523459370f, -0.662415777590171780f, 0.749009364117883880f, + -0.662559410516312290f, + 0.748882306173375150f, -0.662703019082037440f, 0.748755220694604760f, + -0.662846603282066900f, + 0.748628107686245440f, -0.662990163111121470f, 0.748500967152970430f, + -0.663133698563923010f, + 0.748373799099454560f, -0.663277209635194100f, 0.748246603530373420f, + -0.663420696319658280f, + 0.748119380450403600f, -0.663564158612039770f, 0.747992129864222700f, + -0.663707596507064010f, + 0.747864851776509410f, -0.663851009999457340f, 0.747737546191943330f, + -0.663994399083946640f, + 0.747610213115205150f, -0.664137763755260010f, 0.747482852550976570f, + -0.664281104008126230f, + 0.747355464503940190f, -0.664424419837275180f, 0.747228048978779920f, + -0.664567711237437520f, + 0.747100605980180130f, -0.664710978203344790f, 0.746973135512826850f, + -0.664854220729729660f, + 0.746845637581406540f, -0.664997438811325340f, 0.746718112190607130f, + -0.665140632442866140f, + 0.746590559345117310f, -0.665283801619087180f, 0.746462979049626770f, + -0.665426946334724660f, + 0.746335371308826320f, -0.665570066584515450f, 0.746207736127407760f, + -0.665713162363197550f, + 0.746080073510063780f, -0.665856233665509720f, 0.745952383461488290f, + -0.665999280486191500f, + 0.745824665986376090f, -0.666142302819983540f, 0.745696921089422760f, + -0.666285300661627280f, + 0.745569148775325430f, -0.666428274005865240f, 0.745441349048781680f, + -0.666571222847440640f, + 0.745313521914490520f, -0.666714147181097670f, 0.745185667377151640f, + -0.666857047001581220f, + 0.745057785441466060f, -0.666999922303637470f, 0.744929876112135350f, + -0.667142773082013310f, + 0.744801939393862630f, -0.667285599331456370f, 0.744673975291351710f, + -0.667428401046715520f, + 0.744545983809307370f, -0.667571178222540310f, 0.744417964952435620f, + -0.667713930853681030f, + 0.744289918725443260f, -0.667856658934889320f, 0.744161845133038180f, + -0.667999362460917400f, + 0.744033744179929290f, -0.668142041426518450f, 0.743905615870826490f, + -0.668284695826446670f, + 0.743777460210440890f, -0.668427325655456820f, 0.743649277203484060f, + -0.668569930908304970f, + 0.743521066854669120f, -0.668712511579747980f, 0.743392829168709970f, + -0.668855067664543610f, + 0.743264564150321600f, -0.668997599157450270f, 0.743136271804219820f, + -0.669140106053227600f, + 0.743007952135121720f, -0.669282588346636010f, 0.742879605147745200f, + -0.669425046032436910f, + 0.742751230846809050f, -0.669567479105392490f, 0.742622829237033490f, + -0.669709887560265840f, + 0.742494400323139180f, -0.669852271391821020f, 0.742365944109848460f, + -0.669994630594823000f, + 0.742237460601884000f, -0.670136965164037650f, 0.742108949803969910f, + -0.670279275094231800f, + 0.741980411720831070f, -0.670421560380173090f, 0.741851846357193480f, + -0.670563821016630040f, + 0.741723253717784140f, -0.670706056998372160f, 0.741594633807331150f, + -0.670848268320169640f, + 0.741465986630563290f, -0.670990454976794220f, 0.741337312192210660f, + -0.671132616963017740f, + 0.741208610497004260f, -0.671274754273613490f, 0.741079881549676080f, + -0.671416866903355450f, + 0.740951125354959110f, -0.671558954847018330f, 0.740822341917587330f, + -0.671701018099378320f, + 0.740693531242295760f, -0.671843056655211930f, 0.740564693333820250f, + -0.671985070509296900f, + 0.740435828196898020f, -0.672127059656411730f, 0.740306935836266940f, + -0.672269024091335930f, + 0.740178016256666240f, -0.672410963808849790f, 0.740049069462835550f, + -0.672552878803734710f, + 0.739920095459516200f, -0.672694769070772860f, 0.739791094251449950f, + -0.672836634604747300f, + 0.739662065843380010f, -0.672978475400442090f, 0.739533010240050250f, + -0.673120291452642070f, + 0.739403927446205760f, -0.673262082756132970f, 0.739274817466592520f, + -0.673403849305701740f, + 0.739145680305957510f, -0.673545591096136100f, 0.739016515969048720f, + -0.673687308122224330f, + 0.738887324460615110f, -0.673829000378756040f, 0.738758105785406900f, + -0.673970667860521620f, + 0.738628859948174840f, -0.674112310562312360f, 0.738499586953671130f, + -0.674253928478920410f, + 0.738370286806648620f, -0.674395521605139050f, 0.738240959511861310f, + -0.674537089935762000f, + 0.738111605074064260f, -0.674678633465584540f, 0.737982223498013570f, + -0.674820152189402170f, + 0.737852814788465980f, -0.674961646102011930f, 0.737723378950179700f, + -0.675103115198211420f, + 0.737593915987913570f, -0.675244559472799270f, 0.737464425906427580f, + -0.675385978920574840f, + 0.737334908710482910f, -0.675527373536338520f, 0.737205364404841190f, + -0.675668743314891910f, + 0.737075792994265730f, -0.675810088251036940f, 0.736946194483520280f, + -0.675951408339577010f, + 0.736816568877369900f, -0.676092703575315920f, 0.736686916180580460f, + -0.676233973953058950f, + 0.736557236397919150f, -0.676375219467611590f, 0.736427529534153690f, + -0.676516440113781090f, + 0.736297795594053170f, -0.676657635886374950f, 0.736168034582387330f, + -0.676798806780201770f, + 0.736038246503927350f, -0.676939952790071130f, 0.735908431363445190f, + -0.677081073910793530f, + 0.735778589165713590f, -0.677222170137180330f, 0.735648719915506510f, + -0.677363241464043920f, + 0.735518823617598900f, -0.677504287886197430f, 0.735388900276766730f, + -0.677645309398454910f, + 0.735258949897786840f, -0.677786305995631500f, 0.735128972485437180f, + -0.677927277672543020f, + 0.734998968044496710f, -0.678068224424006600f, 0.734868936579745170f, + -0.678209146244839860f, + 0.734738878095963500f, -0.678350043129861470f, 0.734608792597933550f, + -0.678490915073891140f, + 0.734478680090438370f, -0.678631762071749360f, 0.734348540578261600f, + -0.678772584118257690f, + 0.734218374066188280f, -0.678913381208238410f, 0.734088180559004040f, + -0.679054153336514870f, + 0.733957960061495940f, -0.679194900497911200f, 0.733827712578451700f, + -0.679335622687252560f, + 0.733697438114660370f, -0.679476319899364970f, 0.733567136674911360f, + -0.679616992129075560f, + 0.733436808263995710f, -0.679757639371212030f, 0.733306452886705260f, + -0.679898261620603290f, + 0.733176070547832740f, -0.680038858872078930f, 0.733045661252172080f, + -0.680179431120469750f, + 0.732915225004517780f, -0.680319978360607200f, 0.732784761809665790f, + -0.680460500587323880f, + 0.732654271672412820f, -0.680600997795453020f, 0.732523754597556700f, + -0.680741469979829090f, + 0.732393210589896040f, -0.680881917135287230f, 0.732262639654230770f, + -0.681022339256663670f, + 0.732132041795361290f, -0.681162736338795430f, 0.732001417018089630f, + -0.681303108376520530f, + 0.731870765327218290f, -0.681443455364677870f, 0.731740086727550980f, + -0.681583777298107480f, + 0.731609381223892630f, -0.681724074171649710f, 0.731478648821048520f, + -0.681864345980146670f, + 0.731347889523825570f, -0.682004592718440830f, 0.731217103337031270f, + -0.682144814381375640f, + 0.731086290265474340f, -0.682285010963795570f, 0.730955450313964360f, + -0.682425182460546060f, + 0.730824583487312160f, -0.682565328866473250f, 0.730693689790329000f, + -0.682705450176424590f, + 0.730562769227827590f, -0.682845546385248080f, 0.730431821804621520f, + -0.682985617487792740f, + 0.730300847525525490f, -0.683125663478908680f, 0.730169846395354870f, + -0.683265684353446700f, + 0.730038818418926260f, -0.683405680106258680f, 0.729907763601057140f, + -0.683545650732197530f, + 0.729776681946566090f, -0.683685596226116580f, 0.729645573460272480f, + -0.683825516582870720f, + 0.729514438146997010f, -0.683965411797315400f, 0.729383276011561050f, + -0.684105281864307080f, + 0.729252087058786970f, -0.684245126778703080f, 0.729120871293498230f, + -0.684384946535361750f, + 0.728989628720519420f, -0.684524741129142300f, 0.728858359344675800f, + -0.684664510554904960f, + 0.728727063170793830f, -0.684804254807510620f, 0.728595740203700770f, + -0.684943973881821490f, + 0.728464390448225200f, -0.685083667772700360f, 0.728333013909196360f, + -0.685223336475011210f, + 0.728201610591444610f, -0.685362979983618730f, 0.728070180499801210f, + -0.685502598293388550f, + 0.727938723639098620f, -0.685642191399187470f, 0.727807240014169960f, + -0.685781759295883030f, + 0.727675729629849610f, -0.685921301978343560f, 0.727544192490972800f, + -0.686060819441438710f, + 0.727412628602375770f, -0.686200311680038590f, 0.727281037968895870f, + -0.686339778689014520f, + 0.727149420595371020f, -0.686479220463238950f, 0.727017776486640680f, + -0.686618636997584630f, + 0.726886105647544970f, -0.686758028286925890f, 0.726754408082925020f, + -0.686897394326137610f, + 0.726622683797622850f, -0.687036735110095660f, 0.726490932796481910f, + -0.687176050633676820f, + 0.726359155084346010f, -0.687315340891759050f, 0.726227350666060370f, + -0.687454605879221030f, + 0.726095519546471000f, -0.687593845590942170f, 0.725963661730424930f, + -0.687733060021803230f, + 0.725831777222770370f, -0.687872249166685550f, 0.725699866028356120f, + -0.688011413020471640f, + 0.725567928152032300f, -0.688150551578044830f, 0.725435963598649810f, + -0.688289664834289330f, + 0.725303972373060770f, -0.688428752784090440f, 0.725171954480117950f, + -0.688567815422334250f, + 0.725039909924675370f, -0.688706852743907750f, 0.724907838711587820f, + -0.688845864743699020f, + 0.724775740845711280f, -0.688984851416597040f, 0.724643616331902550f, + -0.689123812757491570f, + 0.724511465175019630f, -0.689262748761273470f, 0.724379287379921190f, + -0.689401659422834270f, + 0.724247082951467000f, -0.689540544737066830f, 0.724114851894517850f, + -0.689679404698864800f, + 0.723982594213935520f, -0.689818239303122470f, 0.723850309914582880f, + -0.689957048544735390f, + 0.723717999001323500f, -0.690095832418599950f, 0.723585661479022150f, + -0.690234590919613370f, + 0.723453297352544380f, -0.690373324042674040f, 0.723320906626756970f, + -0.690512031782681060f, + 0.723188489306527460f, -0.690650714134534600f, 0.723056045396724410f, + -0.690789371093135650f, + 0.722923574902217700f, -0.690928002653386160f, 0.722791077827877550f, + -0.691066608810189220f, + 0.722658554178575610f, -0.691205189558448450f, 0.722526003959184540f, + -0.691343744893068710f, + 0.722393427174577550f, -0.691482274808955850f, 0.722260823829629310f, + -0.691620779301016290f, + 0.722128193929215350f, -0.691759258364157750f, 0.721995537478211880f, + -0.691897711993288760f, + 0.721862854481496340f, -0.692036140183318720f, 0.721730144943947160f, + -0.692174542929158140f, + 0.721597408870443770f, -0.692312920225718220f, 0.721464646265866370f, + -0.692451272067911130f, + 0.721331857135096290f, -0.692589598450650380f, 0.721199041483015720f, + -0.692727899368849820f, + 0.721066199314508110f, -0.692866174817424630f, 0.720933330634457530f, + -0.693004424791290870f, + 0.720800435447749190f, -0.693142649285365400f, 0.720667513759269520f, + -0.693280848294566040f, + 0.720534565573905270f, -0.693419021813811760f, 0.720401590896544760f, + -0.693557169838022290f, + 0.720268589732077190f, -0.693695292362118240f, 0.720135562085392420f, + -0.693833389381021350f, + 0.720002507961381650f, -0.693971460889654000f, 0.719869427364936860f, + -0.694109506882939820f, + 0.719736320300951030f, -0.694247527355803310f, 0.719603186774318120f, + -0.694385522303169740f, + 0.719470026789932990f, -0.694523491719965520f, 0.719336840352691740f, + -0.694661435601117820f, + 0.719203627467491220f, -0.694799353941554900f, 0.719070388139229190f, + -0.694937246736205830f, + 0.718937122372804490f, -0.695075113980000880f, 0.718803830173116890f, + -0.695212955667870780f, + 0.718670511545067230f, -0.695350771794747690f, 0.718537166493557370f, + -0.695488562355564440f, + 0.718403795023489830f, -0.695626327345254870f, 0.718270397139768260f, + -0.695764066758753690f, + 0.718136972847297490f, -0.695901780590996830f, 0.718003522150983180f, + -0.696039468836920690f, + 0.717870045055731710f, -0.696177131491462990f, 0.717736541566450950f, + -0.696314768549562090f, + 0.717603011688049080f, -0.696452380006157830f, 0.717469455425435830f, + -0.696589965856190370f, + 0.717335872783521730f, -0.696727526094601200f, 0.717202263767218070f, + -0.696865060716332470f, + 0.717068628381437480f, -0.697002569716327460f, 0.716934966631093130f, + -0.697140053089530420f, + 0.716801278521099540f, -0.697277510830886520f, 0.716667564056371890f, + -0.697414942935341790f, + 0.716533823241826680f, -0.697552349397843160f, 0.716400056082381000f, + -0.697689730213338800f, + 0.716266262582953120f, -0.697827085376777290f, 0.716132442748462330f, + -0.697964414883108670f, + 0.715998596583828690f, -0.698101718727283770f, 0.715864724093973500f, + -0.698238996904254280f, + 0.715730825283818590f, -0.698376249408972920f, 0.715596900158287470f, + -0.698513476236393040f, + 0.715462948722303760f, -0.698650677381469460f, 0.715328970980792620f, + -0.698787852839157670f, + 0.715194966938680120f, -0.698925002604414150f, 0.715060936600893090f, + -0.699062126672196140f, + 0.714926879972359490f, -0.699199225037462120f, 0.714792797058008240f, + -0.699336297695171140f, + 0.714658687862769090f, -0.699473344640283770f, 0.714524552391572860f, + -0.699610365867761040f, + 0.714390390649351390f, -0.699747361372564990f, 0.714256202641037510f, + -0.699884331149658760f, + 0.714121988371564820f, -0.700021275194006250f, 0.713987747845867830f, + -0.700158193500572730f, + 0.713853481068882470f, -0.700295086064323780f, 0.713719188045545240f, + -0.700431952880226420f, + 0.713584868780793640f, -0.700568793943248340f, 0.713450523279566260f, + -0.700705609248358450f, + 0.713316151546802610f, -0.700842398790526120f, 0.713181753587443180f, + -0.700979162564722370f, + 0.713047329406429340f, -0.701115900565918660f, 0.712912879008703480f, + -0.701252612789087460f, + 0.712778402399208980f, -0.701389299229202230f, 0.712643899582890210f, + -0.701525959881237340f, + 0.712509370564692320f, -0.701662594740168450f, 0.712374815349561710f, + -0.701799203800971720f, + 0.712240233942445510f, -0.701935787058624360f, 0.712105626348291890f, + -0.702072344508104630f, + 0.711970992572050100f, -0.702208876144391870f, 0.711836332618670080f, + -0.702345381962465880f, + 0.711701646493102970f, -0.702481861957308000f, 0.711566934200300700f, + -0.702618316123900130f, + 0.711432195745216430f, -0.702754744457225300f, 0.711297431132803970f, + -0.702891146952267400f, + 0.711162640368018350f, -0.703027523604011220f, 0.711027823455815280f, + -0.703163874407442770f, + 0.710892980401151680f, -0.703300199357548730f, 0.710758111208985350f, + -0.703436498449316660f, + 0.710623215884275020f, -0.703572771677735580f, 0.710488294431980470f, + -0.703709019037794810f, + 0.710353346857062420f, -0.703845240524484940f, 0.710218373164482220f, + -0.703981436132797620f, + 0.710083373359202800f, -0.704117605857725310f, 0.709948347446187400f, + -0.704253749694261470f, + 0.709813295430400840f, -0.704389867637400410f, 0.709678217316808580f, + -0.704525959682137380f, + 0.709543113110376770f, -0.704662025823468820f, 0.709407982816072980f, + -0.704798066056391950f, + 0.709272826438865690f, -0.704934080375904880f, 0.709137643983724030f, + -0.705070068777006840f, + 0.709002435455618250f, -0.705206031254697830f, 0.708867200859519820f, + -0.705341967803978840f, + 0.708731940200400650f, -0.705477878419852100f, 0.708596653483234080f, + -0.705613763097320490f, + 0.708461340712994160f, -0.705749621831387790f, 0.708326001894655890f, + -0.705885454617058980f, + 0.708190637033195400f, -0.706021261449339740f, 0.708055246133589500f, + -0.706157042323237060f, + 0.707919829200816310f, -0.706292797233758480f, 0.707784386239854620f, + -0.706428526175912790f, + 0.707648917255684350f, -0.706564229144709510f, 0.707513422253286280f, + -0.706699906135159430f, + 0.707377901237642100f, -0.706835557142273750f, 0.707242354213734710f, + -0.706971182161065360f, + 0.707106781186547570f, -0.707106781186547460f, 0.706971182161065360f, + -0.707242354213734600f, + 0.706835557142273860f, -0.707377901237642100f, 0.706699906135159430f, + -0.707513422253286170f, + 0.706564229144709620f, -0.707648917255684350f, 0.706428526175912790f, + -0.707784386239854620f, + 0.706292797233758480f, -0.707919829200816310f, 0.706157042323237060f, + -0.708055246133589500f, + 0.706021261449339740f, -0.708190637033195290f, 0.705885454617058980f, + -0.708326001894655780f, + 0.705749621831387790f, -0.708461340712994050f, 0.705613763097320490f, + -0.708596653483234080f, + 0.705477878419852210f, -0.708731940200400650f, 0.705341967803978950f, + -0.708867200859519820f, + 0.705206031254697830f, -0.709002435455618250f, 0.705070068777006840f, + -0.709137643983723920f, + 0.704934080375904990f, -0.709272826438865580f, 0.704798066056391950f, + -0.709407982816072980f, + 0.704662025823468930f, -0.709543113110376770f, 0.704525959682137380f, + -0.709678217316808470f, + 0.704389867637400410f, -0.709813295430400840f, 0.704253749694261580f, + -0.709948347446187400f, + 0.704117605857725430f, -0.710083373359202690f, 0.703981436132797730f, + -0.710218373164482220f, + 0.703845240524484940f, -0.710353346857062310f, 0.703709019037794810f, + -0.710488294431980470f, + 0.703572771677735580f, -0.710623215884275020f, 0.703436498449316770f, + -0.710758111208985350f, + 0.703300199357548730f, -0.710892980401151680f, 0.703163874407442770f, + -0.711027823455815280f, + 0.703027523604011220f, -0.711162640368018350f, 0.702891146952267400f, + -0.711297431132803970f, + 0.702754744457225300f, -0.711432195745216430f, 0.702618316123900130f, + -0.711566934200300700f, + 0.702481861957308000f, -0.711701646493102970f, 0.702345381962465880f, + -0.711836332618670080f, + 0.702208876144391870f, -0.711970992572049990f, 0.702072344508104740f, + -0.712105626348291890f, + 0.701935787058624360f, -0.712240233942445510f, 0.701799203800971720f, + -0.712374815349561710f, + 0.701662594740168570f, -0.712509370564692320f, 0.701525959881237450f, + -0.712643899582890210f, + 0.701389299229202230f, -0.712778402399208870f, 0.701252612789087460f, + -0.712912879008703370f, + 0.701115900565918660f, -0.713047329406429230f, 0.700979162564722480f, + -0.713181753587443070f, + 0.700842398790526230f, -0.713316151546802610f, 0.700705609248358450f, + -0.713450523279566150f, + 0.700568793943248450f, -0.713584868780793520f, 0.700431952880226420f, + -0.713719188045545130f, + 0.700295086064323780f, -0.713853481068882470f, 0.700158193500572730f, + -0.713987747845867830f, + 0.700021275194006360f, -0.714121988371564710f, 0.699884331149658760f, + -0.714256202641037400f, + 0.699747361372564990f, -0.714390390649351390f, 0.699610365867761040f, + -0.714524552391572860f, + 0.699473344640283770f, -0.714658687862768980f, 0.699336297695171250f, + -0.714792797058008130f, + 0.699199225037462120f, -0.714926879972359370f, 0.699062126672196140f, + -0.715060936600892980f, + 0.698925002604414150f, -0.715194966938680010f, 0.698787852839157790f, + -0.715328970980792620f, + 0.698650677381469580f, -0.715462948722303650f, 0.698513476236393040f, + -0.715596900158287360f, + 0.698376249408972920f, -0.715730825283818590f, 0.698238996904254390f, + -0.715864724093973390f, + 0.698101718727283880f, -0.715998596583828690f, 0.697964414883108790f, + -0.716132442748462330f, + 0.697827085376777290f, -0.716266262582953120f, 0.697689730213338800f, + -0.716400056082380890f, + 0.697552349397843270f, -0.716533823241826570f, 0.697414942935341790f, + -0.716667564056371890f, + 0.697277510830886630f, -0.716801278521099540f, 0.697140053089530530f, + -0.716934966631093130f, + 0.697002569716327460f, -0.717068628381437480f, 0.696865060716332470f, + -0.717202263767218070f, + 0.696727526094601200f, -0.717335872783521730f, 0.696589965856190370f, + -0.717469455425435830f, + 0.696452380006157830f, -0.717603011688049080f, 0.696314768549562200f, + -0.717736541566450840f, + 0.696177131491462990f, -0.717870045055731710f, 0.696039468836920690f, + -0.718003522150983060f, + 0.695901780590996830f, -0.718136972847297490f, 0.695764066758753800f, + -0.718270397139768260f, + 0.695626327345254870f, -0.718403795023489720f, 0.695488562355564440f, + -0.718537166493557370f, + 0.695350771794747800f, -0.718670511545067230f, 0.695212955667870890f, + -0.718803830173116890f, + 0.695075113980000880f, -0.718937122372804380f, 0.694937246736205940f, + -0.719070388139229190f, + 0.694799353941554900f, -0.719203627467491220f, 0.694661435601117930f, + -0.719336840352691740f, + 0.694523491719965520f, -0.719470026789932990f, 0.694385522303169860f, + -0.719603186774318000f, + 0.694247527355803310f, -0.719736320300951030f, 0.694109506882939820f, + -0.719869427364936860f, + 0.693971460889654000f, -0.720002507961381650f, 0.693833389381021350f, + -0.720135562085392310f, + 0.693695292362118350f, -0.720268589732077080f, 0.693557169838022400f, + -0.720401590896544760f, + 0.693419021813811880f, -0.720534565573905270f, 0.693280848294566150f, + -0.720667513759269410f, + 0.693142649285365510f, -0.720800435447749190f, 0.693004424791290870f, + -0.720933330634457530f, + 0.692866174817424740f, -0.721066199314508110f, 0.692727899368849820f, + -0.721199041483015720f, + 0.692589598450650380f, -0.721331857135096180f, 0.692451272067911240f, + -0.721464646265866370f, + 0.692312920225718220f, -0.721597408870443660f, 0.692174542929158140f, + -0.721730144943947160f, + 0.692036140183318830f, -0.721862854481496340f, 0.691897711993288760f, + -0.721995537478211880f, + 0.691759258364157750f, -0.722128193929215350f, 0.691620779301016400f, + -0.722260823829629310f, + 0.691482274808955850f, -0.722393427174577550f, 0.691343744893068820f, + -0.722526003959184430f, + 0.691205189558448450f, -0.722658554178575610f, 0.691066608810189220f, + -0.722791077827877550f, + 0.690928002653386280f, -0.722923574902217700f, 0.690789371093135760f, + -0.723056045396724410f, + 0.690650714134534720f, -0.723188489306527350f, 0.690512031782681170f, + -0.723320906626756850f, + 0.690373324042674040f, -0.723453297352544380f, 0.690234590919613370f, + -0.723585661479022040f, + 0.690095832418599950f, -0.723717999001323390f, 0.689957048544735390f, + -0.723850309914582880f, + 0.689818239303122470f, -0.723982594213935520f, 0.689679404698864800f, + -0.724114851894517850f, + 0.689540544737066940f, -0.724247082951466890f, 0.689401659422834380f, + -0.724379287379921080f, + 0.689262748761273470f, -0.724511465175019520f, 0.689123812757491680f, + -0.724643616331902550f, + 0.688984851416597150f, -0.724775740845711280f, 0.688845864743699130f, + -0.724907838711587820f, + 0.688706852743907750f, -0.725039909924675370f, 0.688567815422334360f, + -0.725171954480117840f, + 0.688428752784090550f, -0.725303972373060660f, 0.688289664834289440f, + -0.725435963598649810f, + 0.688150551578044830f, -0.725567928152032300f, 0.688011413020471640f, + -0.725699866028356120f, + 0.687872249166685550f, -0.725831777222770370f, 0.687733060021803230f, + -0.725963661730424930f, + 0.687593845590942170f, -0.726095519546470890f, 0.687454605879221030f, + -0.726227350666060260f, + 0.687315340891759160f, -0.726359155084346010f, 0.687176050633676930f, + -0.726490932796481910f, + 0.687036735110095660f, -0.726622683797622850f, 0.686897394326137610f, + -0.726754408082924910f, + 0.686758028286925890f, -0.726886105647544970f, 0.686618636997584740f, + -0.727017776486640680f, + 0.686479220463238950f, -0.727149420595371020f, 0.686339778689014630f, + -0.727281037968895760f, + 0.686200311680038700f, -0.727412628602375770f, 0.686060819441438710f, + -0.727544192490972800f, + 0.685921301978343670f, -0.727675729629849610f, 0.685781759295883030f, + -0.727807240014169960f, + 0.685642191399187470f, -0.727938723639098620f, 0.685502598293388670f, + -0.728070180499801210f, + 0.685362979983618730f, -0.728201610591444500f, 0.685223336475011210f, + -0.728333013909196360f, + 0.685083667772700360f, -0.728464390448225200f, 0.684943973881821490f, + -0.728595740203700770f, + 0.684804254807510620f, -0.728727063170793720f, 0.684664510554904960f, + -0.728858359344675690f, + 0.684524741129142300f, -0.728989628720519310f, 0.684384946535361750f, + -0.729120871293498230f, + 0.684245126778703080f, -0.729252087058786970f, 0.684105281864307080f, + -0.729383276011561050f, + 0.683965411797315510f, -0.729514438146996900f, 0.683825516582870830f, + -0.729645573460272480f, + 0.683685596226116690f, -0.729776681946565970f, 0.683545650732197530f, + -0.729907763601057140f, + 0.683405680106258790f, -0.730038818418926150f, 0.683265684353446700f, + -0.730169846395354870f, + 0.683125663478908800f, -0.730300847525525380f, 0.682985617487792850f, + -0.730431821804621520f, + 0.682845546385248080f, -0.730562769227827590f, 0.682705450176424590f, + -0.730693689790328890f, + 0.682565328866473250f, -0.730824583487312050f, 0.682425182460546060f, + -0.730955450313964360f, + 0.682285010963795570f, -0.731086290265474230f, 0.682144814381375640f, + -0.731217103337031160f, + 0.682004592718440830f, -0.731347889523825460f, 0.681864345980146780f, + -0.731478648821048520f, + 0.681724074171649820f, -0.731609381223892520f, 0.681583777298107480f, + -0.731740086727550980f, + 0.681443455364677990f, -0.731870765327218290f, 0.681303108376520530f, + -0.732001417018089520f, + 0.681162736338795430f, -0.732132041795361290f, 0.681022339256663670f, + -0.732262639654230660f, + 0.680881917135287340f, -0.732393210589896040f, 0.680741469979829090f, + -0.732523754597556590f, + 0.680600997795453130f, -0.732654271672412820f, 0.680460500587323880f, + -0.732784761809665790f, + 0.680319978360607200f, -0.732915225004517780f, 0.680179431120469750f, + -0.733045661252171970f, + 0.680038858872079040f, -0.733176070547832740f, 0.679898261620603290f, + -0.733306452886705260f, + 0.679757639371212030f, -0.733436808263995710f, 0.679616992129075560f, + -0.733567136674911360f, + 0.679476319899365080f, -0.733697438114660260f, 0.679335622687252670f, + -0.733827712578451700f, + 0.679194900497911200f, -0.733957960061495940f, 0.679054153336514870f, + -0.734088180559004040f, + 0.678913381208238410f, -0.734218374066188170f, 0.678772584118257690f, + -0.734348540578261600f, + 0.678631762071749470f, -0.734478680090438370f, 0.678490915073891250f, + -0.734608792597933550f, + 0.678350043129861580f, -0.734738878095963390f, 0.678209146244839860f, + -0.734868936579745060f, + 0.678068224424006600f, -0.734998968044496600f, 0.677927277672543130f, + -0.735128972485437180f, + 0.677786305995631500f, -0.735258949897786730f, 0.677645309398454910f, + -0.735388900276766620f, + 0.677504287886197430f, -0.735518823617598900f, 0.677363241464044030f, + -0.735648719915506400f, + 0.677222170137180450f, -0.735778589165713480f, 0.677081073910793530f, + -0.735908431363445190f, + 0.676939952790071240f, -0.736038246503927350f, 0.676798806780201770f, + -0.736168034582387330f, + 0.676657635886374950f, -0.736297795594053060f, 0.676516440113781090f, + -0.736427529534153690f, + 0.676375219467611700f, -0.736557236397919150f, 0.676233973953058950f, + -0.736686916180580460f, + 0.676092703575316030f, -0.736816568877369790f, 0.675951408339577010f, + -0.736946194483520170f, + 0.675810088251037060f, -0.737075792994265620f, 0.675668743314891910f, + -0.737205364404841190f, + 0.675527373536338630f, -0.737334908710482790f, 0.675385978920574950f, + -0.737464425906427580f, + 0.675244559472799270f, -0.737593915987913460f, 0.675103115198211530f, + -0.737723378950179590f, + 0.674961646102012040f, -0.737852814788465980f, 0.674820152189402280f, + -0.737982223498013570f, + 0.674678633465584540f, -0.738111605074064260f, 0.674537089935762110f, + -0.738240959511861310f, + 0.674395521605139050f, -0.738370286806648510f, 0.674253928478920520f, + -0.738499586953671130f, + 0.674112310562312360f, -0.738628859948174840f, 0.673970667860521620f, + -0.738758105785406900f, + 0.673829000378756150f, -0.738887324460615110f, 0.673687308122224330f, + -0.739016515969048600f, + 0.673545591096136100f, -0.739145680305957400f, 0.673403849305701850f, + -0.739274817466592520f, + 0.673262082756132970f, -0.739403927446205760f, 0.673120291452642070f, + -0.739533010240050250f, + 0.672978475400442090f, -0.739662065843379900f, 0.672836634604747410f, + -0.739791094251449950f, + 0.672694769070772970f, -0.739920095459516090f, 0.672552878803734820f, + -0.740049069462835550f, + 0.672410963808849900f, -0.740178016256666240f, 0.672269024091336040f, + -0.740306935836266940f, + 0.672127059656411840f, -0.740435828196898020f, 0.671985070509296900f, + -0.740564693333820250f, + 0.671843056655211930f, -0.740693531242295640f, 0.671701018099378320f, + -0.740822341917587330f, + 0.671558954847018330f, -0.740951125354959110f, 0.671416866903355450f, + -0.741079881549676080f, + 0.671274754273613490f, -0.741208610497004260f, 0.671132616963017850f, + -0.741337312192210660f, + 0.670990454976794220f, -0.741465986630563290f, 0.670848268320169750f, + -0.741594633807331150f, + 0.670706056998372160f, -0.741723253717784140f, 0.670563821016630040f, + -0.741851846357193480f, + 0.670421560380173090f, -0.741980411720830960f, 0.670279275094231910f, + -0.742108949803969800f, + 0.670136965164037760f, -0.742237460601884000f, 0.669994630594823000f, + -0.742365944109848460f, + 0.669852271391821130f, -0.742494400323139180f, 0.669709887560265840f, + -0.742622829237033380f, + 0.669567479105392490f, -0.742751230846809050f, 0.669425046032436910f, + -0.742879605147745090f, + 0.669282588346636010f, -0.743007952135121720f, 0.669140106053227710f, + -0.743136271804219820f, + 0.668997599157450270f, -0.743264564150321490f, 0.668855067664543610f, + -0.743392829168709970f, + 0.668712511579748090f, -0.743521066854669120f, 0.668569930908305080f, + -0.743649277203484060f, + 0.668427325655456820f, -0.743777460210440780f, 0.668284695826446670f, + -0.743905615870826490f, + 0.668142041426518560f, -0.744033744179929180f, 0.667999362460917510f, + -0.744161845133038070f, + 0.667856658934889440f, -0.744289918725443140f, 0.667713930853681140f, + -0.744417964952435620f, + 0.667571178222540310f, -0.744545983809307250f, 0.667428401046715640f, + -0.744673975291351600f, + 0.667285599331456480f, -0.744801939393862630f, 0.667142773082013310f, + -0.744929876112135350f, + 0.666999922303637470f, -0.745057785441465950f, 0.666857047001581220f, + -0.745185667377151640f, + 0.666714147181097670f, -0.745313521914490410f, 0.666571222847440750f, + -0.745441349048781680f, + 0.666428274005865350f, -0.745569148775325430f, 0.666285300661627390f, + -0.745696921089422760f, + 0.666142302819983540f, -0.745824665986375980f, 0.665999280486191500f, + -0.745952383461488180f, + 0.665856233665509720f, -0.746080073510063780f, 0.665713162363197660f, + -0.746207736127407650f, + 0.665570066584515560f, -0.746335371308826320f, 0.665426946334724660f, + -0.746462979049626770f, + 0.665283801619087180f, -0.746590559345117310f, 0.665140632442866140f, + -0.746718112190607020f, + 0.664997438811325340f, -0.746845637581406540f, 0.664854220729729660f, + -0.746973135512826740f, + 0.664710978203344900f, -0.747100605980180130f, 0.664567711237437520f, + -0.747228048978779920f, + 0.664424419837275180f, -0.747355464503940190f, 0.664281104008126230f, + -0.747482852550976570f, + 0.664137763755260010f, -0.747610213115205150f, 0.663994399083946640f, + -0.747737546191943330f, + 0.663851009999457340f, -0.747864851776509410f, 0.663707596507064120f, + -0.747992129864222700f, + 0.663564158612039880f, -0.748119380450403490f, 0.663420696319658280f, + -0.748246603530373420f, + 0.663277209635194100f, -0.748373799099454560f, 0.663133698563923010f, + -0.748500967152970430f, + 0.662990163111121470f, -0.748628107686245330f, 0.662846603282066900f, + -0.748755220694604760f, + 0.662703019082037440f, -0.748882306173375030f, 0.662559410516312400f, + -0.749009364117883770f, + 0.662415777590171780f, -0.749136394523459260f, 0.662272120308896590f, + -0.749263397385431020f, + 0.662128438677768720f, -0.749390372699129560f, 0.661984732702071030f, + -0.749517320459886170f, + 0.661841002387086870f, -0.749644240663033480f, 0.661697247738101120f, + -0.749771133303904990f, + 0.661553468760399000f, -0.749897998377835220f, 0.661409665459266940f, + -0.750024835880159780f, + 0.661265837839992270f, -0.750151645806214960f, 0.661121985907862970f, + -0.750278428151338610f, + 0.660978109668168060f, -0.750405182910869220f, 0.660834209126197610f, + -0.750531910080146410f, + 0.660690284287242300f, -0.750658609654510590f, 0.660546335156593890f, + -0.750785281629303580f, + 0.660402361739545030f, -0.750911925999867890f, 0.660258364041389050f, + -0.751038542761547250f, + 0.660114342067420480f, -0.751165131909686370f, 0.659970295822934540f, + -0.751291693439630870f, + 0.659826225313227430f, -0.751418227346727360f, 0.659682130543596150f, + -0.751544733626323570f, + 0.659538011519338770f, -0.751671212273768430f, 0.659393868245753970f, + -0.751797663284411440f, + 0.659249700728141490f, -0.751924086653603550f, 0.659105508971802200f, + -0.752050482376696360f, + 0.658961292982037320f, -0.752176850449042700f, 0.658817052764149480f, + -0.752303190865996400f, + 0.658672788323441890f, -0.752429503622912390f, 0.658528499665218760f, + -0.752555788715146390f, + 0.658384186794785050f, -0.752682046138055230f, 0.658239849717446980f, + -0.752808275886996950f, + 0.658095488438511290f, -0.752934477957330150f, 0.657951102963285630f, + -0.753060652344415100f, + 0.657806693297078640f, -0.753186799043612410f, 0.657662259445200070f, + -0.753312918050284330f, + 0.657517801412960120f, -0.753439009359793580f, 0.657373319205670210f, + -0.753565072967504190f, + 0.657228812828642650f, -0.753691108868781210f, 0.657084282287190180f, + -0.753817117058990680f, + 0.656939727586627110f, -0.753943097533499640f, 0.656795148732268070f, + -0.754069050287676120f, + 0.656650545729429050f, -0.754194975316889170f, 0.656505918583426550f, + -0.754320872616508820f, + 0.656361267299578000f, -0.754446742181906330f, 0.656216591883202030f, + -0.754572584008453840f, + 0.656071892339617710f, -0.754698398091524390f, 0.655927168674145360f, + -0.754824184426492240f, + 0.655782420892106030f, -0.754949943008732640f, 0.655637648998821820f, + -0.755075673833621510f, + 0.655492852999615460f, -0.755201376896536550f, 0.655348032899810580f, + -0.755327052192855560f, + 0.655203188704731930f, -0.755452699717958140f, 0.655058320419704910f, + -0.755578319467224540f, + 0.654913428050056150f, -0.755703911436035880f, 0.654768511601112600f, + -0.755829475619774760f, + 0.654623571078202680f, -0.755955012013824310f, 0.654478606486655350f, + -0.756080520613569120f, + 0.654333617831800550f, -0.756206001414394540f, 0.654188605118969040f, + -0.756331454411686920f, + 0.654043568353492640f, -0.756456879600833630f, 0.653898507540703890f, + -0.756582276977223470f, + 0.653753422685936170f, -0.756707646536245670f, 0.653608313794523890f, + -0.756832988273290820f, + 0.653463180871802330f, -0.756958302183750490f, 0.653318023923107670f, + -0.757083588263017140f, + 0.653172842953776760f, -0.757208846506484460f, 0.653027637969147650f, + -0.757334076909547130f, + 0.652882408974558960f, -0.757459279467600720f, 0.652737155975350420f, + -0.757584454176041810f, + 0.652591878976862550f, -0.757709601030268080f, 0.652446577984436840f, + -0.757834720025678310f, + 0.652301253003415460f, -0.757959811157672300f, 0.652155904039141700f, + -0.758084874421650620f, + 0.652010531096959500f, -0.758209909813015280f, 0.651865134182214030f, + -0.758334917327168960f, + 0.651719713300251020f, -0.758459896959515320f, 0.651574268456417080f, + -0.758584848705459500f, + 0.651428799656059820f, -0.758709772560407390f, 0.651283306904527850f, + -0.758834668519765660f, + 0.651137790207170330f, -0.758959536578942440f, 0.650992249569337660f, + -0.759084376733346500f, + 0.650846684996380990f, -0.759209188978387960f, 0.650701096493652040f, + -0.759333973309477940f, + 0.650555484066503990f, -0.759458729722028210f, 0.650409847720290420f, + -0.759583458211452010f, + 0.650264187460365960f, -0.759708158773163440f, 0.650118503292086200f, + -0.759832831402577400f, + 0.649972795220807530f, -0.759957476095110330f, 0.649827063251887100f, + -0.760082092846179220f, + 0.649681307390683190f, -0.760206681651202420f, 0.649535527642554730f, + -0.760331242505599030f, + 0.649389724012861770f, -0.760455775404789260f, 0.649243896506965010f, + -0.760580280344194340f, + 0.649098045130226060f, -0.760704757319236920f, 0.648952169888007410f, + -0.760829206325340010f, + 0.648806270785672550f, -0.760953627357928040f, 0.648660347828585840f, + -0.761078020412426560f, + 0.648514401022112550f, -0.761202385484261780f, 0.648368430371618400f, + -0.761326722568861250f, + 0.648222435882470420f, -0.761451031661653510f, 0.648076417560036530f, + -0.761575312758068000f, + 0.647930375409685460f, -0.761699565853535270f, 0.647784309436786550f, + -0.761823790943486840f, + 0.647638219646710420f, -0.761947988023355390f, 0.647492106044828100f, + -0.762072157088574560f, + 0.647345968636512060f, -0.762196298134578900f, 0.647199807427135230f, + -0.762320411156804160f, + 0.647053622422071650f, -0.762444496150687100f, 0.646907413626696020f, + -0.762568553111665380f, + 0.646761181046383920f, -0.762692582035177870f, 0.646614924686512050f, + -0.762816582916664320f, + 0.646468644552457890f, -0.762940555751565720f, 0.646322340649599590f, + -0.763064500535323710f, + 0.646176012983316390f, -0.763188417263381270f, 0.646029661558988330f, + -0.763312305931182380f, + 0.645883286381996440f, -0.763436166534172010f, 0.645736887457722290f, + -0.763559999067796150f, + 0.645590464791548800f, -0.763683803527501870f, 0.645444018388859230f, + -0.763807579908737160f, + 0.645297548255038380f, -0.763931328206951090f, 0.645151054395471270f, + -0.764055048417593860f, + 0.645004536815544040f, -0.764178740536116670f, 0.644857995520643710f, + -0.764302404557971720f, + 0.644711430516158420f, -0.764426040478612070f, 0.644564841807476750f, + -0.764549648293492150f, + 0.644418229399988380f, -0.764673227998067140f, 0.644271593299083900f, + -0.764796779587793460f, + 0.644124933510154540f, -0.764920303058128410f, 0.643978250038592660f, + -0.765043798404530410f, + 0.643831542889791500f, -0.765167265622458960f, 0.643684812069144960f, + -0.765290704707374260f, + 0.643538057582047850f, -0.765414115654738160f, 0.643391279433895960f, + -0.765537498460013070f, + 0.643244477630085850f, -0.765660853118662390f, 0.643097652176015110f, + -0.765784179626150970f, + 0.642950803077082080f, -0.765907477977944230f, 0.642803930338686100f, + -0.766030748169509000f, + 0.642657033966226860f, -0.766153990196312810f, 0.642510113965105710f, + -0.766277204053824710f, + 0.642363170340724320f, -0.766400389737514120f, 0.642216203098485370f, + -0.766523547242852100f, + 0.642069212243792540f, -0.766646676565310380f, 0.641922197782050170f, + -0.766769777700361920f, + 0.641775159718663500f, -0.766892850643480670f, 0.641628098059038860f, + -0.767015895390141480f, + 0.641481012808583160f, -0.767138911935820400f, 0.641333903972704290f, + -0.767261900275994390f, + 0.641186771556811250f, -0.767384860406141620f, 0.641039615566313390f, + -0.767507792321741270f, + 0.640892436006621380f, -0.767630696018273270f, 0.640745232883146440f, + -0.767753571491219030f, + 0.640598006201301030f, -0.767876418736060610f, 0.640450755966498140f, + -0.767999237748281270f, + 0.640303482184151670f, -0.768122028523365310f, 0.640156184859676620f, + -0.768244791056798220f, + 0.640008863998488440f, -0.768367525344066270f, 0.639861519606004010f, + -0.768490231380656750f, + 0.639714151687640450f, -0.768612909162058270f, 0.639566760248816420f, + -0.768735558683760310f, + 0.639419345294950700f, -0.768858179941253270f, 0.639271906831463510f, + -0.768980772930028870f, + 0.639124444863775730f, -0.769103337645579590f, 0.638976959397309140f, + -0.769225874083399260f, + 0.638829450437486400f, -0.769348382238982280f, 0.638681917989730840f, + -0.769470862107824560f, + 0.638534362059466790f, -0.769593313685422940f, 0.638386782652119680f, + -0.769715736967275020f, + 0.638239179773115390f, -0.769838131948879840f, 0.638091553427880930f, + -0.769960498625737230f, + 0.637943903621844170f, -0.770082836993347900f, 0.637796230360433540f, + -0.770205147047214100f, + 0.637648533649078810f, -0.770327428782838770f, 0.637500813493210310f, + -0.770449682195725960f, + 0.637353069898259130f, -0.770571907281380700f, 0.637205302869657600f, + -0.770694104035309140f, + 0.637057512412838590f, -0.770816272453018430f, 0.636909698533235870f, + -0.770938412530016940f, + 0.636761861236284200f, -0.771060524261813710f, 0.636614000527419230f, + -0.771182607643919220f, + 0.636466116412077180f, -0.771304662671844720f, 0.636318208895695570f, + -0.771426689341102590f, + 0.636170277983712170f, -0.771548687647206300f, 0.636022323681566300f, + -0.771670657585670330f, + 0.635874345994697720f, -0.771792599152010150f, 0.635726344928547180f, + -0.771914512341742350f, + 0.635578320488556230f, -0.772036397150384410f, 0.635430272680167160f, + -0.772158253573455240f, + 0.635282201508823530f, -0.772280081606474320f, 0.635134106979969300f, + -0.772401881244962340f, + 0.634985989099049460f, -0.772523652484441330f, 0.634837847871510100f, + -0.772645395320433860f, + 0.634689683302797850f, -0.772767109748463740f, 0.634541495398360130f, + -0.772888795764056220f, + 0.634393284163645490f, -0.773010453362736990f, 0.634245049604103330f, + -0.773132082540033070f, + 0.634096791725183740f, -0.773253683291472590f, 0.633948510532337810f, + -0.773375255612584470f, + 0.633800206031017280f, -0.773496799498899050f, 0.633651878226674900f, + -0.773618314945947460f, + 0.633503527124764320f, -0.773739801949261840f, 0.633355152730740060f, + -0.773861260504375540f, + 0.633206755050057190f, -0.773982690606822790f, 0.633058334088172250f, + -0.774104092252138940f, + 0.632909889850541860f, -0.774225465435860570f, 0.632761422342624000f, + -0.774346810153525020f, + 0.632612931569877520f, -0.774468126400670860f, 0.632464417537761840f, + -0.774589414172837550f, + 0.632315880251737680f, -0.774710673465565550f, 0.632167319717266030f, + -0.774831904274396850f, + 0.632018735939809060f, -0.774953106594873820f, 0.631870128924829850f, + -0.775074280422540450f, + 0.631721498677792370f, -0.775195425752941310f, 0.631572845204161130f, + -0.775316542581622410f, + 0.631424168509401860f, -0.775437630904130430f, 0.631275468598980870f, + -0.775558690716013580f, + 0.631126745478365340f, -0.775679722012820540f, 0.630977999153023660f, + -0.775800724790101540f, + 0.630829229628424470f, -0.775921699043407580f, 0.630680436910038060f, + -0.776042644768290770f, + 0.630531621003334600f, -0.776163561960304340f, 0.630382781913785940f, + -0.776284450615002400f, + 0.630233919646864480f, -0.776405310727940390f, 0.630085034208043290f, + -0.776526142294674430f, + 0.629936125602796550f, -0.776646945310762060f, 0.629787193836599200f, + -0.776767719771761510f, + 0.629638238914927100f, -0.776888465673232440f, 0.629489260843256740f, + -0.777009183010735290f, + 0.629340259627065750f, -0.777129871779831620f, 0.629191235271832410f, + -0.777250531976084070f, + 0.629042187783036000f, -0.777371163595056200f, 0.628893117166156480f, + -0.777491766632312900f, + 0.628744023426674790f, -0.777612341083419920f, 0.628594906570072660f, + -0.777732886943944050f, + 0.628445766601832710f, -0.777853404209453040f, 0.628296603527438440f, + -0.777973892875515990f, + 0.628147417352374120f, -0.778094352937702790f, 0.627998208082124810f, + -0.778214784391584420f, + 0.627848975722176570f, -0.778335187232733090f, 0.627699720278016240f, + -0.778455561456721900f, + 0.627550441755131530f, -0.778575907059124940f, 0.627401140159011160f, + -0.778696224035517530f, + 0.627251815495144190f, -0.778816512381475870f, 0.627102467769021010f, + -0.778936772092577500f, + 0.626953096986132770f, -0.779057003164400630f, 0.626803703151971310f, + -0.779177205592524680f, + 0.626654286272029460f, -0.779297379372530300f, 0.626504846351800930f, + -0.779417524499998900f, + 0.626355383396779990f, -0.779537640970513150f, 0.626205897412462130f, + -0.779657728779656780f, + 0.626056388404343520f, -0.779777787923014440f, 0.625906856377921210f, + -0.779897818396171890f, + 0.625757301338692900f, -0.780017820194715990f, 0.625607723292157410f, + -0.780137793314234500f, + 0.625458122243814360f, -0.780257737750316590f, 0.625308498199164010f, + -0.780377653498552040f, + 0.625158851163707730f, -0.780497540554531910f, 0.625009181142947460f, + -0.780617398913848290f, + 0.624859488142386450f, -0.780737228572094380f, 0.624709772167528100f, + -0.780857029524864470f, + 0.624560033223877320f, -0.780976801767753750f, 0.624410271316939380f, + -0.781096545296358410f, + 0.624260486452220650f, -0.781216260106276090f, 0.624110678635228510f, + -0.781335946193104870f, + 0.623960847871470770f, -0.781455603552444480f, 0.623810994166456130f, + -0.781575232179895550f, + 0.623661117525694640f, -0.781694832071059390f, 0.623511217954696550f, + -0.781814403221538830f, + 0.623361295458973340f, -0.781933945626937630f, 0.623211350044037270f, + -0.782053459282860300f, + 0.623061381715401370f, -0.782172944184912900f, 0.622911390478579460f, + -0.782292400328702400f, + 0.622761376339086460f, -0.782411827709836420f, 0.622611339302437730f, + -0.782531226323924240f, + 0.622461279374150080f, -0.782650596166575730f, 0.622311196559740320f, + -0.782769937233402050f, + 0.622161090864726930f, -0.782889249520015480f, 0.622010962294628600f, + -0.783008533022029110f, + 0.621860810854965360f, -0.783127787735057310f, 0.621710636551257690f, + -0.783247013654715380f, + 0.621560439389027270f, -0.783366210776619720f, 0.621410219373796150f, + -0.783485379096387820f, + 0.621259976511087660f, -0.783604518609638200f, 0.621109710806425740f, + -0.783723629311990470f, + 0.620959422265335180f, -0.783842711199065230f, 0.620809110893341900f, + -0.783961764266484010f, + 0.620658776695972140f, -0.784080788509869950f, 0.620508419678753360f, + -0.784199783924846570f, + 0.620358039847213830f, -0.784318750507038920f, 0.620207637206882430f, + -0.784437688252072720f, + 0.620057211763289210f, -0.784556597155575240f, 0.619906763521964830f, + -0.784675477213174320f, + 0.619756292488440660f, -0.784794328420499230f, 0.619605798668249390f, + -0.784913150773180020f, + 0.619455282066924020f, -0.785031944266848080f, 0.619304742689998690f, + -0.785150708897135560f, + 0.619154180543008410f, -0.785269444659675850f, 0.619003595631488770f, + -0.785388151550103550f, + 0.618852987960976320f, -0.785506829564053930f, 0.618702357537008640f, + -0.785625478697163700f, + 0.618551704365123860f, -0.785744098945070360f, 0.618401028450860980f, + -0.785862690303412600f, + 0.618250329799760250f, -0.785981252767830150f, 0.618099608417362110f, + -0.786099786333963820f, + 0.617948864309208260f, -0.786218290997455550f, 0.617798097480841140f, + -0.786336766753948260f, + 0.617647307937803980f, -0.786455213599085770f, 0.617496495685640910f, + -0.786573631528513230f, + 0.617345660729896940f, -0.786692020537876680f, 0.617194803076117630f, + -0.786810380622823490f, + 0.617043922729849760f, -0.786928711779001700f, 0.616893019696640790f, + -0.787047014002060790f, + 0.616742093982038830f, -0.787165287287650890f, 0.616591145591593230f, + -0.787283531631423620f, + 0.616440174530853650f, -0.787401747029031320f, 0.616289180805370980f, + -0.787519933476127810f, + 0.616138164420696910f, -0.787638090968367450f, 0.615987125382383870f, + -0.787756219501405950f, + 0.615836063695985090f, -0.787874319070900110f, 0.615684979367054570f, + -0.787992389672507950f, + 0.615533872401147430f, -0.788110431301888070f, 0.615382742803819330f, + -0.788228443954700490f, + 0.615231590580626820f, -0.788346427626606230f, 0.615080415737127460f, + -0.788464382313267430f, + 0.614929218278879590f, -0.788582308010347120f, 0.614777998211442190f, + -0.788700204713509660f, + 0.614626755540375050f, -0.788818072418420170f, 0.614475490271239160f, + -0.788935911120745130f, + 0.614324202409595950f, -0.789053720816151880f, 0.614172891961007990f, + -0.789171501500308790f, + 0.614021558931038490f, -0.789289253168885650f, 0.613870203325251440f, + -0.789406975817552810f, + 0.613718825149211830f, -0.789524669441982190f, 0.613567424408485330f, + -0.789642334037846340f, + 0.613416001108638590f, -0.789759969600819070f, 0.613264555255239150f, + -0.789877576126575280f, + 0.613113086853854910f, -0.789995153610791090f, 0.612961595910055170f, + -0.790112702049143300f, + 0.612810082429409710f, -0.790230221437310030f, 0.612658546417489290f, + -0.790347711770970520f, + 0.612506987879865570f, -0.790465173045804880f, 0.612355406822110760f, + -0.790582605257494460f, + 0.612203803249798060f, -0.790700008401721610f, 0.612052177168501580f, + -0.790817382474169660f, + 0.611900528583796070f, -0.790934727470523290f, 0.611748857501257400f, + -0.791052043386467950f, + 0.611597163926462020f, -0.791169330217690090f, 0.611445447864987110f, + -0.791286587959877720f, + 0.611293709322411010f, -0.791403816608719500f, 0.611141948304312570f, + -0.791521016159905220f, + 0.610990164816271770f, -0.791638186609125770f, 0.610838358863869280f, + -0.791755327952073150f, + 0.610686530452686280f, -0.791872440184440470f, 0.610534679588305320f, + -0.791989523301921850f, + 0.610382806276309480f, -0.792106577300212390f, 0.610230910522282620f, + -0.792223602175008310f, + 0.610078992331809620f, -0.792340597922007060f, 0.609927051710476230f, + -0.792457564536906970f, + 0.609775088663868430f, -0.792574502015407580f, 0.609623103197573730f, + -0.792691410353209450f, + 0.609471095317180240f, -0.792808289546014120f, 0.609319065028276820f, + -0.792925139589524260f, + 0.609167012336453210f, -0.793041960479443640f, 0.609014937247299940f, + -0.793158752211477140f, + 0.608862839766408200f, -0.793275514781330630f, 0.608710719899370420f, + -0.793392248184711100f, + 0.608558577651779450f, -0.793508952417326660f, 0.608406413029229260f, + -0.793625627474886190f, + 0.608254226037314490f, -0.793742273353100100f, 0.608102016681630550f, + -0.793858890047679620f, + 0.607949784967773740f, -0.793975477554337170f, 0.607797530901341140f, + -0.794092035868785960f, + 0.607645254487930830f, -0.794208564986740640f, 0.607492955733141660f, + -0.794325064903916520f, + 0.607340634642572930f, -0.794441535616030590f, 0.607188291221825160f, + -0.794557977118800270f, + 0.607035925476499760f, -0.794674389407944550f, 0.606883537412198580f, + -0.794790772479183170f, + 0.606731127034524480f, -0.794907126328237010f, 0.606578694349081400f, + -0.795023450950828050f, + 0.606426239361473550f, -0.795139746342679590f, 0.606273762077306430f, + -0.795256012499515500f, + 0.606121262502186230f, -0.795372249417061190f, 0.605968740641719790f, + -0.795488457091042990f, + 0.605816196501515080f, -0.795604635517188070f, 0.605663630087180490f, + -0.795720784691225090f, + 0.605511041404325550f, -0.795836904608883460f, 0.605358430458560530f, + -0.795952995265893910f, + 0.605205797255496500f, -0.796069056657987990f, 0.605053141800745430f, + -0.796185088780898440f, + 0.604900464099919930f, -0.796301091630359110f, 0.604747764158633410f, + -0.796417065202104980f, + 0.604595041982500360f, -0.796533009491872000f, 0.604442297577135970f, + -0.796648924495397150f, + 0.604289530948156070f, -0.796764810208418720f, 0.604136742101177630f, + -0.796880666626675780f, + 0.603983931041818020f, -0.796996493745908750f, 0.603831097775695880f, + -0.797112291561858920f, + 0.603678242308430370f, -0.797228060070268700f, 0.603525364645641550f, + -0.797343799266881700f, + 0.603372464792950370f, -0.797459509147442460f, 0.603219542755978440f, + -0.797575189707696590f, + 0.603066598540348280f, -0.797690840943391040f, 0.602913632151683140f, + -0.797806462850273570f, + 0.602760643595607220f, -0.797922055424093000f, 0.602607632877745550f, + -0.798037618660599410f, + 0.602454600003723860f, -0.798153152555543750f, 0.602301544979168550f, + -0.798268657104678310f, + 0.602148467809707320f, -0.798384132303756380f, 0.601995368500968130f, + -0.798499578148532010f, + 0.601842247058580030f, -0.798614994634760820f, 0.601689103488173060f, + -0.798730381758199210f, + 0.601535937795377730f, -0.798845739514604580f, 0.601382749985825420f, + -0.798961067899735760f, + 0.601229540065148620f, -0.799076366909352350f, 0.601076308038980160f, + -0.799191636539215210f, + 0.600923053912954090f, -0.799306876785086160f, 0.600769777692705230f, + -0.799422087642728040f, + 0.600616479383868970f, -0.799537269107905010f, 0.600463158992081690f, + -0.799652421176382130f, + 0.600309816522980430f, -0.799767543843925680f, 0.600156451982203350f, + -0.799882637106302810f, + 0.600003065375389060f, -0.799997700959281910f, 0.599849656708177360f, + -0.800112735398632370f, + 0.599696225986208310f, -0.800227740420124790f, 0.599542773215123390f, + -0.800342716019530660f, + 0.599389298400564540f, -0.800457662192622710f, 0.599235801548174570f, + -0.800572578935174750f, + 0.599082282663597310f, -0.800687466242961500f, 0.598928741752476900f, + -0.800802324111759110f, + 0.598775178820458720f, -0.800917152537344300f, 0.598621593873188920f, + -0.801031951515495330f, + 0.598467986916314310f, -0.801146721041991250f, 0.598314357955482600f, + -0.801261461112612540f, + 0.598160706996342380f, -0.801376171723140130f, 0.598007034044542700f, + -0.801490852869356840f, + 0.597853339105733910f, -0.801605504547046040f, 0.597699622185566830f, + -0.801720126751992330f, + 0.597545883289693270f, -0.801834719479981310f, 0.597392122423765710f, + -0.801949282726799660f, + 0.597238339593437530f, -0.802063816488235440f, 0.597084534804362740f, + -0.802178320760077450f, + 0.596930708062196500f, -0.802292795538115720f, 0.596776859372594500f, + -0.802407240818141300f, + 0.596622988741213330f, -0.802521656595946320f, 0.596469096173710360f, + -0.802636042867324150f, + 0.596315181675743820f, -0.802750399628069160f, 0.596161245252972540f, + -0.802864726873976590f, + 0.596007286911056530f, -0.802979024600843140f, 0.595853306655656390f, + -0.803093292804466400f, + 0.595699304492433470f, -0.803207531480644830f, 0.595545280427049790f, + -0.803321740625178470f, + 0.595391234465168730f, -0.803435920233868120f, 0.595237166612453850f, + -0.803550070302515570f, + 0.595083076874569960f, -0.803664190826924090f, 0.594928965257182420f, + -0.803778281802897570f, + 0.594774831765957580f, -0.803892343226241260f, 0.594620676406562240f, + -0.804006375092761520f, + 0.594466499184664540f, -0.804120377398265700f, 0.594312300105932830f, + -0.804234350138562260f, + 0.594158079176036800f, -0.804348293309460780f, 0.594003836400646690f, + -0.804462206906771840f, + 0.593849571785433630f, -0.804576090926307000f, 0.593695285336069300f, + -0.804689945363879500f, + 0.593540977058226390f, -0.804803770215302810f, 0.593386646957578480f, + -0.804917565476392150f, + 0.593232295039799800f, -0.805031331142963660f, 0.593077921310565580f, + -0.805145067210834120f, + 0.592923525775551410f, -0.805258773675822210f, 0.592769108440434070f, + -0.805372450533747060f, + 0.592614669310891130f, -0.805486097780429120f, 0.592460208392600940f, + -0.805599715411689950f, + 0.592305725691242400f, -0.805713303423352120f, 0.592151221212495640f, + -0.805826861811239300f, + 0.591996694962040990f, -0.805940390571176280f, 0.591842146945560250f, + -0.806053889698988950f, + 0.591687577168735550f, -0.806167359190504310f, 0.591532985637249990f, + -0.806280799041550370f, + 0.591378372356787580f, -0.806394209247956240f, 0.591223737333032910f, + -0.806507589805552260f, + 0.591069080571671510f, -0.806620940710169650f, 0.590914402078389520f, + -0.806734261957640750f, + 0.590759701858874280f, -0.806847553543799220f, 0.590604979918813440f, + -0.806960815464479620f, + 0.590450236263895920f, -0.807074047715517610f, 0.590295470899810940f, + -0.807187250292749850f, + 0.590140683832248940f, -0.807300423192014450f, 0.589985875066900920f, + -0.807413566409150190f, + 0.589831044609458900f, -0.807526679939997160f, 0.589676192465615420f, + -0.807639763780396370f, + 0.589521318641063940f, -0.807752817926190360f, 0.589366423141498790f, + -0.807865842373222120f, + 0.589211505972615070f, -0.807978837117336310f, 0.589056567140108460f, + -0.808091802154378260f, + 0.588901606649675840f, -0.808204737480194720f, 0.588746624507014650f, + -0.808317643090633250f, + 0.588591620717822890f, -0.808430518981542720f, 0.588436595287799900f, + -0.808543365148773010f, + 0.588281548222645330f, -0.808656181588174980f, 0.588126479528059850f, + -0.808768968295600850f, + 0.587971389209745120f, -0.808881725266903610f, 0.587816277273403020f, + -0.808994452497937560f, + 0.587661143724736770f, -0.809107149984558130f, 0.587505988569450020f, + -0.809219817722621750f, + 0.587350811813247660f, -0.809332455707985840f, 0.587195613461834910f, + -0.809445063936509170f, + 0.587040393520918080f, -0.809557642404051260f, 0.586885151996203950f, + -0.809670191106473090f, + 0.586729888893400500f, -0.809782710039636420f, 0.586574604218216280f, + -0.809895199199404450f, + 0.586419297976360500f, -0.810007658581641140f, 0.586263970173543700f, + -0.810120088182211600f, + 0.586108620815476430f, -0.810232487996982330f, 0.585953249907870680f, + -0.810344858021820550f, + 0.585797857456438860f, -0.810457198252594770f, 0.585642443466894420f, + -0.810569508685174630f, + 0.585487007944951450f, -0.810681789315430670f, 0.585331550896324940f, + -0.810794040139234730f, + 0.585176072326730410f, -0.810906261152459670f, 0.585020572241884530f, + -0.811018452350979470f, + 0.584865050647504490f, -0.811130613730669190f, 0.584709507549308500f, + -0.811242745287404810f, + 0.584553942953015330f, -0.811354847017063730f, 0.584398356864344710f, + -0.811466918915524250f, + 0.584242749289016980f, -0.811578960978665890f, 0.584087120232753550f, + -0.811690973202369050f, + 0.583931469701276300f, -0.811802955582515360f, 0.583775797700308070f, + -0.811914908114987680f, + 0.583620104235572760f, -0.812026830795669730f, 0.583464389312794430f, + -0.812138723620446480f, + 0.583308652937698290f, -0.812250586585203880f, 0.583152895116010540f, + -0.812362419685829120f, + 0.582997115853457700f, -0.812474222918210480f, 0.582841315155767650f, + -0.812585996278237020f, + 0.582685493028668460f, -0.812697739761799490f, 0.582529649477889320f, + -0.812809453364789160f, + 0.582373784509160220f, -0.812921137083098770f, 0.582217898128211790f, + -0.813032790912621930f, + 0.582061990340775550f, -0.813144414849253590f, 0.581906061152583920f, + -0.813256008888889380f, + 0.581750110569369760f, -0.813367573027426570f, 0.581594138596866930f, + -0.813479107260763220f, + 0.581438145240810280f, -0.813590611584798510f, 0.581282130506935110f, + -0.813702085995432700f, + 0.581126094400977620f, -0.813813530488567190f, 0.580970036928674880f, + -0.813924945060104490f, + 0.580813958095764530f, -0.814036329705948300f, 0.580657857907985410f, + -0.814147684422003360f, + 0.580501736371076600f, -0.814259009204175270f, 0.580345593490778300f, + -0.814370304048371070f, + 0.580189429272831680f, -0.814481568950498610f, 0.580033243722978150f, + -0.814592803906467270f, + 0.579877036846960350f, -0.814704008912187080f, 0.579720808650521560f, + -0.814815183963569330f, + 0.579564559139405740f, -0.814926329056526620f, 0.579408288319357980f, + -0.815037444186972220f, + 0.579251996196123550f, -0.815148529350820830f, 0.579095682775449210f, + -0.815259584543988280f, + 0.578939348063081890f, -0.815370609762391290f, 0.578782992064769690f, + -0.815481605001947770f, + 0.578626614786261430f, -0.815592570258576680f, 0.578470216233306740f, + -0.815703505528198260f, + 0.578313796411655590f, -0.815814410806733780f, 0.578157355327059360f, + -0.815925286090105390f, + 0.578000892985269910f, -0.816036131374236700f, 0.577844409392039850f, + -0.816146946655052160f, + 0.577687904553122800f, -0.816257731928477390f, 0.577531378474272830f, + -0.816368487190439200f, + 0.577374831161244880f, -0.816479212436865390f, 0.577218262619794920f, + -0.816589907663684890f, + 0.577061672855679550f, -0.816700572866827850f, 0.576905061874655960f, + -0.816811208042225290f, + 0.576748429682482520f, -0.816921813185809480f, 0.576591776284917870f, + -0.817032388293513880f, + 0.576435101687721830f, -0.817142933361272970f, 0.576278405896654910f, + -0.817253448385022230f, + 0.576121688917478390f, -0.817363933360698460f, 0.575964950755954330f, + -0.817474388284239240f, + 0.575808191417845340f, -0.817584813151583710f, 0.575651410908915250f, + -0.817695207958671680f, + 0.575494609234928230f, -0.817805572701444270f, 0.575337786401649560f, + -0.817915907375843740f, + 0.575180942414845190f, -0.818026211977813440f, 0.575024077280281820f, + -0.818136486503297620f, + 0.574867191003726740f, -0.818246730948241960f, 0.574710283590948450f, + -0.818356945308593150f, + 0.574553355047715760f, -0.818467129580298660f, 0.574396405379798750f, + -0.818577283759307490f, + 0.574239434592967890f, -0.818687407841569570f, 0.574082442692994470f, + -0.818797501823036010f, + 0.573925429685650750f, -0.818907565699658950f, 0.573768395576709560f, + -0.819017599467391500f, + 0.573611340371944610f, -0.819127603122188240f, 0.573454264077130400f, + -0.819237576660004520f, + 0.573297166698042320f, -0.819347520076796900f, 0.573140048240456060f, + -0.819457433368523280f, + 0.572982908710148680f, -0.819567316531142230f, 0.572825748112897550f, + -0.819677169560613760f, + 0.572668566454481160f, -0.819786992452898990f, 0.572511363740678790f, + -0.819896785203959810f, + 0.572354139977270030f, -0.820006547809759680f, 0.572196895170035580f, + -0.820116280266262710f, + 0.572039629324757050f, -0.820225982569434690f, 0.571882342447216590f, + -0.820335654715241840f, + 0.571725034543197120f, -0.820445296699652050f, 0.571567705618482580f, + -0.820554908518633890f, + 0.571410355678857340f, -0.820664490168157460f, 0.571252984730106660f, + -0.820774041644193650f, + 0.571095592778016690f, -0.820883562942714580f, 0.570938179828374360f, + -0.820993054059693470f, + 0.570780745886967370f, -0.821102514991104650f, 0.570623290959583860f, + -0.821211945732923550f, + 0.570465815052012990f, -0.821321346281126740f, 0.570308318170045010f, + -0.821430716631691760f, + 0.570150800319470300f, -0.821540056780597610f, 0.569993261506080650f, + -0.821649366723823830f, + 0.569835701735668110f, -0.821758646457351640f, 0.569678121014025710f, + -0.821867895977163140f, + 0.569520519346947250f, -0.821977115279241550f, 0.569362896740227330f, + -0.822086304359571090f, + 0.569205253199661200f, -0.822195463214137170f, 0.569047588731045220f, + -0.822304591838926350f, + 0.568889903340175970f, -0.822413690229926390f, 0.568732197032851160f, + -0.822522758383125940f, + 0.568574469814869250f, -0.822631796294514990f, 0.568416721692029390f, + -0.822740803960084420f, + 0.568258952670131490f, -0.822849781375826320f, 0.568101162754976570f, + -0.822958728537734000f, + 0.567943351952365670f, -0.823067645441801670f, 0.567785520268101250f, + -0.823176532084024860f, + 0.567627667707986230f, -0.823285388460400110f, 0.567469794277824620f, + -0.823394214566925080f, + 0.567311899983420800f, -0.823503010399598390f, 0.567153984830580100f, + -0.823611775954420260f, + 0.566996048825108680f, -0.823720511227391320f, 0.566838091972813320f, + -0.823829216214513990f, + 0.566680114279501710f, -0.823937890911791370f, 0.566522115750982100f, + -0.824046535315227760f, + 0.566364096393063950f, -0.824155149420828570f, 0.566206056211556840f, + -0.824263733224600450f, + 0.566047995212271560f, -0.824372286722551250f, 0.565889913401019570f, + -0.824480809910689500f, + 0.565731810783613230f, -0.824589302785025290f, 0.565573687365865440f, + -0.824697765341569470f, + 0.565415543153589770f, -0.824806197576334330f, 0.565257378152600910f, + -0.824914599485333080f, + 0.565099192368714090f, -0.825022971064580220f, 0.564940985807745320f, + -0.825131312310090960f, + 0.564782758475511400f, -0.825239623217882130f, 0.564624510377830120f, + -0.825347903783971380f, + 0.564466241520519500f, -0.825456154004377440f, 0.564307951909398750f, + -0.825564373875120490f, + 0.564149641550287680f, -0.825672563392221390f, 0.563991310449007080f, + -0.825780722551702430f, + 0.563832958611378170f, -0.825888851349586780f, 0.563674586043223180f, + -0.825996949781898970f, + 0.563516192750364910f, -0.826105017844664610f, 0.563357778738627020f, + -0.826213055533910110f, + 0.563199344013834090f, -0.826321062845663420f, 0.563040888581811230f, + -0.826429039775953390f, + 0.562882412448384550f, -0.826536986320809960f, 0.562723915619380400f, + -0.826644902476264210f, + 0.562565398100626560f, -0.826752788238348520f, 0.562406859897951140f, + -0.826860643603096080f, + 0.562248301017183150f, -0.826968468566541490f, 0.562089721464152480f, + -0.827076263124720270f, + 0.561931121244689470f, -0.827184027273669020f, 0.561772500364625450f, + -0.827291761009425810f, + 0.561613858829792420f, -0.827399464328029350f, 0.561455196646023280f, + -0.827507137225519830f, + 0.561296513819151470f, -0.827614779697938400f, 0.561137810355011530f, + -0.827722391741327220f, + 0.560979086259438260f, -0.827829973351729810f, 0.560820341538267540f, + -0.827937524525190870f, + 0.560661576197336030f, -0.828045045257755800f, 0.560502790242481060f, + -0.828152535545471410f, + 0.560343983679540860f, -0.828259995384385550f, 0.560185156514354080f, + -0.828367424770547480f, + 0.560026308752760380f, -0.828474823700007130f, 0.559867440400600320f, + -0.828582192168815790f, + 0.559708551463714790f, -0.828689530173025710f, 0.559549641947945870f, + -0.828796837708690610f, + 0.559390711859136140f, -0.828904114771864870f, 0.559231761203129010f, + -0.829011361358604430f, + 0.559072789985768480f, -0.829118577464965980f, 0.558913798212899770f, + -0.829225763087007570f, + 0.558754785890368310f, -0.829332918220788250f, 0.558595753024020760f, + -0.829440042862368170f, + 0.558436699619704100f, -0.829547137007808800f, 0.558277625683266330f, + -0.829654200653172640f, + 0.558118531220556100f, -0.829761233794523050f, 0.557959416237422960f, + -0.829868236427924840f, + 0.557800280739717100f, -0.829975208549443840f, 0.557641124733289420f, + -0.830082150155146970f, + 0.557481948223991660f, -0.830189061241102370f, 0.557322751217676160f, + -0.830295941803379070f, + 0.557163533720196340f, -0.830402791838047550f, 0.557004295737406060f, + -0.830509611341179070f, + 0.556845037275160100f, -0.830616400308846200f, 0.556685758339313890f, + -0.830723158737122880f, + 0.556526458935723720f, -0.830829886622083570f, 0.556367139070246490f, + -0.830936583959804410f, + 0.556207798748739930f, -0.831043250746362320f, 0.556048437977062720f, + -0.831149886977835430f, + 0.555889056761073920f, -0.831256492650303210f, 0.555729655106633520f, + -0.831363067759845920f, + 0.555570233019602290f, -0.831469612302545240f, 0.555410790505841740f, + -0.831576126274483630f, + 0.555251327571214090f, -0.831682609671745120f, 0.555091844221582420f, + -0.831789062490414400f, + 0.554932340462810370f, -0.831895484726577590f, 0.554772816300762580f, + -0.832001876376321840f, + 0.554613271741304040f, -0.832108237435735480f, 0.554453706790301040f, + -0.832214567900907980f, + 0.554294121453620110f, -0.832320867767929680f, 0.554134515737128910f, + -0.832427137032892280f, + 0.553974889646695610f, -0.832533375691888680f, 0.553815243188189090f, + -0.832639583741012770f, + 0.553655576367479310f, -0.832745761176359460f, 0.553495889190436570f, + -0.832851907994024980f, + 0.553336181662932410f, -0.832958024190106670f, 0.553176453790838460f, + -0.833064109760702890f, + 0.553016705580027580f, -0.833170164701913190f, 0.552856937036373290f, + -0.833276189009838240f, + 0.552697148165749770f, -0.833382182680579730f, 0.552537338974032120f, + -0.833488145710240770f, + 0.552377509467096070f, -0.833594078094925140f, 0.552217659650817930f, + -0.833699979830738290f, + 0.552057789531074980f, -0.833805850913786340f, 0.551897899113745320f, + -0.833911691340176730f, + 0.551737988404707450f, -0.834017501106018130f, 0.551578057409841000f, + -0.834123280207419990f, + 0.551418106135026060f, -0.834229028640493420f, 0.551258134586143700f, + -0.834334746401350080f, + 0.551098142769075430f, -0.834440433486103190f, 0.550938130689703880f, + -0.834546089890866760f, + 0.550778098353912230f, -0.834651715611756330f, 0.550618045767584330f, + -0.834757310644888230f, + 0.550457972936604810f, -0.834862874986380010f, 0.550297879866859190f, + -0.834968408632350450f, + 0.550137766564233630f, -0.835073911578919300f, 0.549977633034615000f, + -0.835179383822207580f, + 0.549817479283891020f, -0.835284825358337370f, 0.549657305317949980f, + -0.835390236183431780f, + 0.549497111142680960f, -0.835495616293615350f, 0.549336896763974010f, + -0.835600965685013410f, + 0.549176662187719770f, -0.835706284353752600f, 0.549016407419809390f, + -0.835811572295960590f, + 0.548856132466135290f, -0.835916829507766360f, 0.548695837332590090f, + -0.836022055985299880f, + 0.548535522025067390f, -0.836127251724692160f, 0.548375186549461600f, + -0.836232416722075600f, + 0.548214830911667780f, -0.836337550973583530f, 0.548054455117581880f, + -0.836442654475350380f, + 0.547894059173100190f, -0.836547727223511890f, 0.547733643084120200f, + -0.836652769214204950f, + 0.547573206856539870f, -0.836757780443567190f, 0.547412750496257930f, + -0.836862760907737810f, + 0.547252274009174090f, -0.836967710602857020f, 0.547091777401188530f, + -0.837072629525066000f, + 0.546931260678202190f, -0.837177517670507190f, 0.546770723846116800f, + -0.837282375035324320f, + 0.546610166910834860f, -0.837387201615661940f, 0.546449589878259760f, + -0.837491997407665890f, + 0.546288992754295210f, -0.837596762407483040f, 0.546128375544846060f, + -0.837701496611261700f, + 0.545967738255817680f, -0.837806200015150940f, 0.545807080893116140f, + -0.837910872615301060f, + 0.545646403462648590f, -0.838015514407863700f, 0.545485705970322530f, + -0.838120125388991500f, + 0.545324988422046460f, -0.838224705554837970f, 0.545164250823729320f, + -0.838329254901558300f, + 0.545003493181281160f, -0.838433773425308340f, 0.544842715500612470f, + -0.838538261122245170f, + 0.544681917787634530f, -0.838642717988527300f, 0.544521100048259710f, + -0.838747144020313920f, + 0.544360262288400400f, -0.838851539213765760f, 0.544199404513970420f, + -0.838955903565044350f, + 0.544038526730883930f, -0.839060237070312630f, 0.543877628945055980f, + -0.839164539725734570f, + 0.543716711162402390f, -0.839268811527475230f, 0.543555773388839650f, + -0.839373052471700690f, + 0.543394815630284800f, -0.839477262554578550f, 0.543233837892656000f, + -0.839581441772277120f, + 0.543072840181871850f, -0.839685590120966110f, 0.542911822503851730f, + -0.839789707596816260f, + 0.542750784864516000f, -0.839893794195999410f, 0.542589727269785270f, + -0.839997849914688730f, + 0.542428649725581360f, -0.840101874749058400f, 0.542267552237826520f, + -0.840205868695283580f, + 0.542106434812444030f, -0.840309831749540770f, 0.541945297455357470f, + -0.840413763908007480f, + 0.541784140172491660f, -0.840517665166862440f, 0.541622962969771640f, + -0.840621535522285690f, + 0.541461765853123560f, -0.840725374970458070f, 0.541300548828474120f, + -0.840829183507561640f, + 0.541139311901750910f, -0.840932961129779670f, 0.540978055078882190f, + -0.841036707833296650f, + 0.540816778365796670f, -0.841140423614298080f, 0.540655481768424260f, + -0.841244108468970580f, + 0.540494165292695230f, -0.841347762393501950f, 0.540332828944540820f, + -0.841451385384081260f, + 0.540171472729892970f, -0.841554977436898330f, 0.540010096654684020f, + -0.841658538548144760f, + 0.539848700724847700f, -0.841762068714012490f, 0.539687284946317570f, + -0.841865567930695340f, + 0.539525849325029010f, -0.841969036194387680f, 0.539364393866917150f, + -0.842072473501285450f, + 0.539202918577918240f, -0.842175879847585570f, 0.539041423463969550f, + -0.842279255229485880f, + 0.538879908531008420f, -0.842382599643185960f, 0.538718373784973670f, + -0.842485913084885630f, + 0.538556819231804210f, -0.842589195550786600f, 0.538395244877439950f, + -0.842692447037091560f, + 0.538233650727821700f, -0.842795667540004120f, 0.538072036788890600f, + -0.842898857055729310f, + 0.537910403066588990f, -0.843002015580472830f, 0.537748749566859470f, + -0.843105143110442050f, + 0.537587076295645510f, -0.843208239641845440f, 0.537425383258891660f, + -0.843311305170892030f, + 0.537263670462542530f, -0.843414339693792760f, 0.537101937912544240f, + -0.843517343206759080f, + 0.536940185614843020f, -0.843620315706004040f, 0.536778413575385920f, + -0.843723257187741550f, + 0.536616621800121150f, -0.843826167648186740f, 0.536454810294997090f, + -0.843929047083555870f, + 0.536292979065963180f, -0.844031895490066410f, 0.536131128118969350f, + -0.844134712863936930f, + 0.535969257459966710f, -0.844237499201387020f, 0.535807367094906620f, + -0.844340254498637590f, + 0.535645457029741090f, -0.844442978751910660f, 0.535483527270423370f, + -0.844545671957429240f, + 0.535321577822907010f, -0.844648334111417820f, 0.535159608693146720f, + -0.844750965210101510f, + 0.534997619887097260f, -0.844853565249707010f, 0.534835611410714670f, + -0.844956134226462100f, + 0.534673583269955510f, -0.845058672136595470f, 0.534511535470777010f, + -0.845161178976337140f, + 0.534349468019137520f, -0.845263654741918220f, 0.534187380920995600f, + -0.845366099429570970f, + 0.534025274182310380f, -0.845468513035528830f, 0.533863147809042650f, + -0.845570895556026270f, + 0.533701001807152960f, -0.845673246987299070f, 0.533538836182603120f, + -0.845775567325583900f, + 0.533376650941355560f, -0.845877856567118890f, 0.533214446089372960f, + -0.845980114708143270f, + 0.533052221632619670f, -0.846082341744896940f, 0.532889977577059690f, + -0.846184537673621670f, + 0.532727713928658810f, -0.846286702490559710f, 0.532565430693382580f, + -0.846388836191954930f, + 0.532403127877198010f, -0.846490938774052020f, 0.532240805486072330f, + -0.846593010233097190f, + 0.532078463525973540f, -0.846695050565337450f, 0.531916102002870760f, + -0.846797059767020910f, + 0.531753720922733320f, -0.846899037834397350f, 0.531591320291531780f, + -0.847000984763716880f, + 0.531428900115236910f, -0.847102900551231500f, 0.531266460399820390f, + -0.847204785193193980f, + 0.531104001151255000f, -0.847306638685858320f, 0.530941522375513510f, + -0.847408461025479730f, + 0.530779024078570250f, -0.847510252208314330f, 0.530616506266399450f, + -0.847612012230619660f, + 0.530453968944976320f, -0.847713741088654270f, 0.530291412120277420f, + -0.847815438778677930f, + 0.530128835798278850f, -0.847917105296951410f, 0.529966239984958620f, + -0.848018740639736810f, + 0.529803624686294830f, -0.848120344803297120f, 0.529640989908265910f, + -0.848221917783896990f, + 0.529478335656852090f, -0.848323459577801530f, 0.529315661938033140f, + -0.848424970181277600f, + 0.529152968757790720f, -0.848526449590592650f, 0.528990256122106040f, + -0.848627897802015860f, + 0.528827524036961980f, -0.848729314811817010f, 0.528664772508341540f, + -0.848830700616267530f, + 0.528502001542228480f, -0.848932055211639610f, 0.528339211144607690f, + -0.849033378594206690f, + 0.528176401321464370f, -0.849134670760243630f, 0.528013572078784740f, + -0.849235931706025960f, + 0.527850723422555460f, -0.849337161427830670f, 0.527687855358763720f, + -0.849438359921935950f, + 0.527524967893398200f, -0.849539527184620890f, 0.527362061032447430f, + -0.849640663212165910f, + 0.527199134781901390f, -0.849741768000852440f, 0.527036189147750190f, + -0.849842841546963210f, + 0.526873224135984700f, -0.849943883846782210f, 0.526710239752597010f, + -0.850044894896594070f, + 0.526547236003579330f, -0.850145874692685210f, 0.526384212894925210f, + -0.850246823231342710f, + 0.526221170432628170f, -0.850347740508854980f, 0.526058108622682760f, + -0.850448626521511650f, + 0.525895027471084740f, -0.850549481265603370f, 0.525731926983829640f, + -0.850650304737422200f, + 0.525568807166914680f, -0.850751096933260790f, 0.525405668026336810f, + -0.850851857849413640f, + 0.525242509568094710f, -0.850952587482175730f, 0.525079331798186890f, + -0.851053285827843790f, + 0.524916134722612890f, -0.851153952882715340f, 0.524752918347373360f, + -0.851254588643089120f, + 0.524589682678468840f, -0.851355193105265200f, 0.524426427721901510f, + -0.851455766265544310f, + 0.524263153483673470f, -0.851556308120228870f, 0.524099859969787810f, + -0.851656818665622370f, + 0.523936547186248600f, -0.851757297898029120f, 0.523773215139060170f, + -0.851857745813754840f, + 0.523609863834228030f, -0.851958162409106380f, 0.523446493277757940f, + -0.852058547680391580f, + 0.523283103475656430f, -0.852158901623919830f, 0.523119694433931250f, + -0.852259224236001090f, + 0.522956266158590140f, -0.852359515512947090f, 0.522792818655642200f, + -0.852459775451070100f, + 0.522629351931096720f, -0.852560004046683970f, 0.522465865990963900f, + -0.852660201296103760f, + 0.522302360841254700f, -0.852760367195645300f, 0.522138836487980650f, + -0.852860501741625860f, + 0.521975292937154390f, -0.852960604930363630f, 0.521811730194788550f, + -0.853060676758178320f, + 0.521648148266897090f, -0.853160717221390420f, 0.521484547159494550f, + -0.853260726316321770f, + 0.521320926878595550f, -0.853360704039295430f, 0.521157287430216610f, + -0.853460650386635320f, + 0.520993628820373810f, -0.853560565354666840f, 0.520829951055084780f, + -0.853660448939716270f, + 0.520666254140367270f, -0.853760301138111300f, 0.520502538082239790f, + -0.853860121946180660f, + 0.520338802886721960f, -0.853959911360254060f, 0.520175048559833760f, + -0.854059669376662780f, + 0.520011275107596040f, -0.854159395991738730f, 0.519847482536030300f, + -0.854259091201815420f, + 0.519683670851158520f, -0.854358755003227440f, 0.519519840059003870f, + -0.854458387392310060f, + 0.519355990165589530f, -0.854557988365400530f, 0.519192121176940360f, + -0.854657557918836460f, + 0.519028233099080970f, -0.854757096048957110f, 0.518864325938037000f, + -0.854856602752102850f, + 0.518700399699835170f, -0.854956078024614820f, 0.518536454390502110f, + -0.855055521862835950f, + 0.518372490016066220f, -0.855154934263109620f, 0.518208506582555460f, + -0.855254315221781080f, + 0.518044504095999340f, -0.855353664735196030f, 0.517880482562427800f, + -0.855452982799701830f, + 0.517716441987871150f, -0.855552269411646970f, 0.517552382378360990f, + -0.855651524567380690f, + 0.517388303739929060f, -0.855750748263253920f, 0.517224206078608310f, + -0.855849940495618240f, + 0.517060089400432130f, -0.855949101260826790f, 0.516895953711434260f, + -0.856048230555233820f, + 0.516731799017649980f, -0.856147328375194470f, 0.516567625325114350f, + -0.856246394717065210f, + 0.516403432639863990f, -0.856345429577203610f, 0.516239220967935620f, + -0.856444432951968480f, + 0.516074990315366630f, -0.856543404837719960f, 0.515910740688195650f, + -0.856642345230818720f, + 0.515746472092461380f, -0.856741254127627470f, 0.515582184534203790f, + -0.856840131524509220f, + 0.515417878019463150f, -0.856938977417828650f, 0.515253552554280290f, + -0.857037791803951680f, + 0.515089208144697270f, -0.857136574679244870f, 0.514924844796756490f, + -0.857235326040076460f, + 0.514760462516501200f, -0.857334045882815590f, 0.514596061309975040f, + -0.857432734203832700f, + 0.514431641183222930f, -0.857531390999499040f, 0.514267202142289830f, + -0.857630016266187620f, + 0.514102744193221660f, -0.857728610000272120f, 0.513938267342065490f, + -0.857827172198127320f, + 0.513773771594868030f, -0.857925702856129790f, 0.513609256957677900f, + -0.858024201970656540f, + 0.513444723436543570f, -0.858122669538086020f, 0.513280171037514330f, + -0.858221105554798250f, + 0.513115599766640560f, -0.858319510017173440f, 0.512951009629972860f, + -0.858417882921594040f, + 0.512786400633563070f, -0.858516224264442740f, 0.512621772783463100f, + -0.858614534042104080f, + 0.512457126085725800f, -0.858712812250963520f, 0.512292460546404980f, + -0.858811058887407500f, + 0.512127776171554690f, -0.858909273947823900f, 0.511963072967230200f, + -0.859007457428601410f, + 0.511798350939487000f, -0.859105609326130340f, 0.511633610094381350f, + -0.859203729636801920f, + 0.511468850437970520f, -0.859301818357008360f, 0.511304071976311890f, + -0.859399875483143450f, + 0.511139274715464390f, -0.859497901011601620f, 0.510974458661486720f, + -0.859595894938779080f, + 0.510809623820439040f, -0.859693857261072610f, 0.510644770198381730f, + -0.859791787974880540f, + 0.510479897801375700f, -0.859889687076602290f, 0.510315006635483350f, + -0.859987554562638200f, + 0.510150096706766700f, -0.860085390429390140f, 0.509985168021289570f, + -0.860183194673260880f, + 0.509820220585115560f, -0.860280967290654510f, 0.509655254404309250f, + -0.860378708277976130f, + 0.509490269484936360f, -0.860476417631632070f, 0.509325265833062480f, + -0.860574095348029980f, + 0.509160243454754750f, -0.860671741423578380f, 0.508995202356080310f, + -0.860769355854687060f, + 0.508830142543106990f, -0.860866938637767310f, 0.508665064021904260f, + -0.860964489769230900f, + 0.508499966798540810f, -0.861062009245491480f, 0.508334850879087470f, + -0.861159497062963350f, + 0.508169716269614710f, -0.861256953218062060f, 0.508004562976194010f, + -0.861354377707204800f, + 0.507839391004897940f, -0.861451770526809210f, 0.507674200361798890f, + -0.861549131673294720f, + 0.507508991052970870f, -0.861646461143081300f, 0.507343763084487920f, + -0.861743758932590700f, + 0.507178516462425290f, -0.861841025038245330f, 0.507013251192858340f, + -0.861938259456469180f, + 0.506847967281863320f, -0.862035462183687210f, 0.506682664735517600f, + -0.862132633216325380f, + 0.506517343559898530f, -0.862229772550811240f, 0.506352003761084800f, + -0.862326880183573060f, + 0.506186645345155450f, -0.862423956111040500f, 0.506021268318189830f, + -0.862521000329644520f, + 0.505855872686268860f, -0.862618012835816740f, 0.505690458455473340f, + -0.862714993625990690f, + 0.505525025631885510f, -0.862811942696600330f, 0.505359574221587390f, + -0.862908860044081290f, + 0.505194104230662240f, -0.863005745664870210f, 0.505028615665194300f, + -0.863102599555404800f, + 0.504863108531267480f, -0.863199421712124160f, 0.504697582834967680f, + -0.863296212131468230f, + 0.504532038582380380f, -0.863392970809878310f, 0.504366475779592150f, + -0.863489697743797140f, + 0.504200894432690560f, -0.863586392929667990f, 0.504035294547763080f, + -0.863683056363935940f, + 0.503869676130898950f, -0.863779688043046610f, 0.503704039188186960f, + -0.863876287963447510f, + 0.503538383725717580f, -0.863972856121586700f, 0.503372709749581150f, + -0.864069392513913680f, + 0.503207017265869030f, -0.864165897136879300f, 0.503041306280673450f, + -0.864262369986934950f, + 0.502875576800086880f, -0.864358811060534030f, 0.502709828830203100f, + -0.864455220354130250f, + 0.502544062377115800f, -0.864551597864179230f, 0.502378277446919870f, + -0.864647943587137480f, + 0.502212474045710900f, -0.864744257519462380f, 0.502046652179584660f, + -0.864840539657612980f, + 0.501880811854638400f, -0.864936789998049020f, 0.501714953076969230f, + -0.865033008537231750f, + 0.501549075852675390f, -0.865129195271623690f, 0.501383180187855880f, + -0.865225350197688090f, + 0.501217266088609950f, -0.865321473311889800f, 0.501051333561038040f, + -0.865417564610694410f, + 0.500885382611240940f, -0.865513624090568980f, 0.500719413245319880f, + -0.865609651747981880f, + 0.500553425469377640f, -0.865705647579402270f, 0.500387419289516580f, + -0.865801611581300760f, + 0.500221394711840680f, -0.865897543750148820f, 0.500055351742453860f, + -0.865993444082419520f, + 0.499889290387461380f, -0.866089312574586770f, 0.499723210652968710f, + -0.866185149223125730f, + 0.499557112545081890f, -0.866280954024512990f, 0.499390996069908220f, + -0.866376726975225830f, + 0.499224861233555030f, -0.866472468071743050f, 0.499058708042130930f, + -0.866568177310544360f, + 0.498892536501744750f, -0.866663854688111020f, 0.498726346618505960f, + -0.866759500200925290f, + 0.498560138398525200f, -0.866855113845470320f, 0.498393911847913150f, + -0.866950695618231020f, + 0.498227666972781870f, -0.867046245515692650f, 0.498061403779243520f, + -0.867141763534342360f, + 0.497895122273410930f, -0.867237249670668400f, 0.497728822461398100f, + -0.867332703921159690f, + 0.497562504349319090f, -0.867428126282306920f, 0.497396167943289340f, + -0.867523516750601460f, + 0.497229813249424340f, -0.867618875322536230f, 0.497063440273840310f, + -0.867714201994605140f, + 0.496897049022654640f, -0.867809496763303210f, 0.496730639501984710f, + -0.867904759625126920f, + 0.496564211717949340f, -0.867999990576573400f, 0.496397765676667160f, + -0.868095189614141670f, + 0.496231301384258310f, -0.868190356734331310f, 0.496064818846843060f, + -0.868285491933643240f, + 0.495898318070542240f, -0.868380595208579800f, 0.495731799061478020f, + -0.868475666555644120f, + 0.495565261825772490f, -0.868570705971340900f, 0.495398706369549080f, + -0.868665713452175580f, + 0.495232132698931350f, -0.868760688994655190f, 0.495065540820043610f, + -0.868855632595287750f, + 0.494898930739011310f, -0.868950544250582380f, 0.494732302461959820f, + -0.869045423957049530f, + 0.494565655995016010f, -0.869140271711200560f, 0.494398991344306760f, + -0.869235087509548250f, + 0.494232308515959730f, -0.869329871348606730f, 0.494065607516103730f, + -0.869424623224890780f, + 0.493898888350867430f, -0.869519343134916970f, 0.493732151026381070f, + -0.869614031075202300f, + 0.493565395548774880f, -0.869708687042265560f, 0.493398621924179830f, + -0.869803311032626650f, + 0.493231830158728070f, -0.869897903042806340f, 0.493065020258551650f, + -0.869992463069326870f, + 0.492898192229784090f, -0.870086991108711350f, 0.492731346078558840f, + -0.870181487157484560f, + 0.492564481811010650f, -0.870275951212171830f, 0.492397599433274550f, + -0.870370383269300160f, + 0.492230698951486080f, -0.870464783325397670f, 0.492063780371782060f, + -0.870559151376993250f, + 0.491896843700299240f, -0.870653487420617540f, 0.491729888943175820f, + -0.870747791452801790f, + 0.491562916106550060f, -0.870842063470078860f, 0.491395925196560830f, + -0.870936303468982760f, + 0.491228916219348330f, -0.871030511446048260f, 0.491061889181052590f, + -0.871124687397811900f, + 0.490894844087815140f, -0.871218831320810900f, 0.490727780945777570f, + -0.871312943211583920f, + 0.490560699761082080f, -0.871407023066670950f, 0.490393600539872130f, + -0.871501070882612530f, + 0.490226483288291100f, -0.871595086655951090f, 0.490059348012483910f, + -0.871689070383229740f, + 0.489892194718595300f, -0.871783022060993010f, 0.489725023412770970f, + -0.871876941685786890f, + 0.489557834101157550f, -0.871970829254157700f, 0.489390626789901920f, + -0.872064684762653970f, + 0.489223401485152030f, -0.872158508207824480f, 0.489056158193055980f, + -0.872252299586219860f, + 0.488888896919763230f, -0.872346058894391540f, 0.488721617671423250f, + -0.872439786128892280f, + 0.488554320454186230f, -0.872533481286276060f, 0.488387005274203590f, + -0.872627144363097960f, + 0.488219672137626740f, -0.872720775355914300f, 0.488052321050608310f, + -0.872814374261282390f, + 0.487884952019301210f, -0.872907941075760970f, 0.487717565049858860f, + -0.873001475795909920f, + 0.487550160148436050f, -0.873094978418290090f, 0.487382737321187310f, + -0.873188448939463790f, + 0.487215296574268820f, -0.873281887355994210f, 0.487047837913836550f, + -0.873375293664446000f, + 0.486880361346047400f, -0.873468667861384880f, 0.486712866877059340f, + -0.873562009943377740f, + 0.486545354513030270f, -0.873655319906992630f, 0.486377824260119500f, + -0.873748597748798870f, + 0.486210276124486530f, -0.873841843465366750f, 0.486042710112291390f, + -0.873935057053268130f, + 0.485875126229695420f, -0.874028238509075630f, 0.485707524482859750f, + -0.874121387829363330f, + 0.485539904877947020f, -0.874214505010706300f, 0.485372267421119770f, + -0.874307590049680950f, + 0.485204612118541880f, -0.874400642942864790f, 0.485036938976377450f, + -0.874493663686836450f, + 0.484869248000791120f, -0.874586652278176110f, 0.484701539197948730f, + -0.874679608713464510f, + 0.484533812574016120f, -0.874772532989284150f, 0.484366068135160480f, + -0.874865425102218210f, + 0.484198305887549140f, -0.874958285048851540f, 0.484030525837350010f, + -0.875051112825769970f, + 0.483862727990732320f, -0.875143908429560250f, 0.483694912353865080f, + -0.875236671856810870f, + 0.483527078932918740f, -0.875329403104110780f, 0.483359227734063980f, + -0.875422102168050830f, + 0.483191358763471910f, -0.875514769045222740f, 0.483023472027315050f, + -0.875607403732219240f, + 0.482855567531765670f, -0.875700006225634600f, 0.482687645282997510f, + -0.875792576522063880f, + 0.482519705287184520f, -0.875885114618103700f, 0.482351747550501030f, + -0.875977620510351660f, + 0.482183772079122830f, -0.876070094195406600f, 0.482015778879225530f, + -0.876162535669868460f, + 0.481847767956986080f, -0.876254944930338400f, 0.481679739318581490f, + -0.876347321973419020f, + 0.481511692970189920f, -0.876439666795713610f, 0.481343628917989870f, + -0.876531979393827100f, + 0.481175547168160360f, -0.876624259764365310f, 0.481007447726881640f, + -0.876716507903935400f, + 0.480839330600333900f, -0.876808723809145760f, 0.480671195794698690f, + -0.876900907476605650f, + 0.480503043316157670f, -0.876993058902925780f, 0.480334873170893070f, + -0.877085178084718310f, + 0.480166685365088440f, -0.877177265018595940f, 0.479998479904927220f, + -0.877269319701173170f, + 0.479830256796594250f, -0.877361342129065140f, 0.479662016046274340f, + -0.877453332298888560f, + 0.479493757660153060f, -0.877545290207261240f, 0.479325481644417130f, + -0.877637215850802120f, + 0.479157188005253310f, -0.877729109226131570f, 0.478988876748849550f, + -0.877820970329870500f, + 0.478820547881394050f, -0.877912799158641730f, 0.478652201409075550f, + -0.878004595709069080f, + 0.478483837338084080f, -0.878096359977777130f, 0.478315455674609480f, + -0.878188091961392250f, + 0.478147056424843120f, -0.878279791656541460f, 0.477978639594976110f, + -0.878371459059853590f, + 0.477810205191201040f, -0.878463094167957870f, 0.477641753219710590f, + -0.878554696977485340f, + 0.477473283686698060f, -0.878646267485068130f, 0.477304796598358010f, + -0.878737805687339280f, + 0.477136291960884750f, -0.878829311580933360f, 0.476967769780474230f, + -0.878920785162485840f, + 0.476799230063322250f, -0.879012226428633410f, 0.476630672815625380f, + -0.879103635376014330f, + 0.476462098043581310f, -0.879195012001267370f, 0.476293505753387750f, + -0.879286356301033250f, + 0.476124895951243630f, -0.879377668271953180f, 0.475956268643348220f, + -0.879468947910670100f, + 0.475787623835901120f, -0.879560195213827890f, 0.475618961535103410f, + -0.879651410178071470f, + 0.475450281747155870f, -0.879742592800047410f, 0.475281584478260800f, + -0.879833743076402940f, + 0.475112869734620470f, -0.879924861003786860f, 0.474944137522437860f, + -0.880015946578848960f, + 0.474775387847917230f, -0.880106999798240360f, 0.474606620717262560f, + -0.880198020658613190f, + 0.474437836136679340f, -0.880289009156620890f, 0.474269034112372920f, + -0.880379965288918260f, + 0.474100214650550020f, -0.880470889052160750f, 0.473931377757417560f, + -0.880561780443005590f, + 0.473762523439182850f, -0.880652639458111010f, 0.473593651702054640f, + -0.880743466094136230f, + 0.473424762552241530f, -0.880834260347742040f, 0.473255855995953380f, + -0.880925022215589880f, + 0.473086932039400220f, -0.881015751694342760f, 0.472917990688792760f, + -0.881106448780665130f, + 0.472749031950342900f, -0.881197113471221980f, 0.472580055830262250f, + -0.881287745762680100f, + 0.472411062334764100f, -0.881378345651706810f, 0.472242051470061650f, + -0.881468913134971330f, + 0.472073023242368660f, -0.881559448209143780f, 0.471903977657900320f, + -0.881649950870895260f, + 0.471734914722871430f, -0.881740421116898320f, 0.471565834443498480f, + -0.881830858943826620f, + 0.471396736825997810f, -0.881921264348354940f, 0.471227621876586400f, + -0.882011637327159590f, + 0.471058489601482610f, -0.882101977876917580f, 0.470889340006904520f, + -0.882192285994307430f, + 0.470720173099071710f, -0.882282561676008600f, 0.470550988884203490f, + -0.882372804918702290f, + 0.470381787368520710f, -0.882463015719070040f, 0.470212568558244280f, + -0.882553194073795400f, + 0.470043332459595620f, -0.882643339979562790f, 0.469874079078797470f, + -0.882733453433057540f, + 0.469704808422072460f, -0.882823534430966730f, 0.469535520495644510f, + -0.882913582969978020f, + 0.469366215305737630f, -0.883003599046780720f, 0.469196892858576630f, + -0.883093582658065370f, + 0.469027553160387240f, -0.883183533800523280f, 0.468858196217395330f, + -0.883273452470847430f, + 0.468688822035827960f, -0.883363338665731580f, 0.468519430621912420f, + -0.883453192381870920f, + 0.468350021981876530f, -0.883543013615961880f, 0.468180596121949400f, + -0.883632802364701760f, + 0.468011153048359830f, -0.883722558624789660f, 0.467841692767338220f, + -0.883812282392925090f, + 0.467672215285114710f, -0.883901973665809470f, 0.467502720607920920f, + -0.883991632440144890f, + 0.467333208741988530f, -0.884081258712634990f, 0.467163679693549770f, + -0.884170852479984500f, + 0.466994133468838110f, -0.884260413738899080f, 0.466824570074086950f, + -0.884349942486086120f, + 0.466654989515530970f, -0.884439438718253700f, 0.466485391799405010f, + -0.884528902432111350f, + 0.466315776931944480f, -0.884618333624369920f, 0.466146144919386000f, + -0.884707732291740930f, + 0.465976495767966130f, -0.884797098430937790f, 0.465806829483922770f, + -0.884886432038674560f, + 0.465637146073493770f, -0.884975733111666660f, 0.465467445542917800f, + -0.885065001646630930f, + 0.465297727898434650f, -0.885154237640285110f, 0.465127993146283950f, + -0.885243441089348270f, + 0.464958241292706740f, -0.885332611990540590f, 0.464788472343944160f, + -0.885421750340583570f, + 0.464618686306237820f, -0.885510856136199950f, 0.464448883185830770f, + -0.885599929374113360f, + 0.464279062988965760f, -0.885688970051048960f, 0.464109225721887010f, + -0.885777978163732940f, + 0.463939371390838460f, -0.885866953708892790f, 0.463769500002065680f, + -0.885955896683257030f, + 0.463599611561814120f, -0.886044807083555490f, 0.463429706076329880f, + -0.886133684906519340f, + 0.463259783551860260f, -0.886222530148880640f, 0.463089843994652470f, + -0.886311342807372890f, + 0.462919887410955130f, -0.886400122878730490f, 0.462749913807016850f, + -0.886488870359689600f, + 0.462579923189086810f, -0.886577585246987040f, 0.462409915563415540f, + -0.886666267537360890f, + 0.462239890936253280f, -0.886754917227550950f, 0.462069849313851810f, + -0.886843534314297300f, + 0.461899790702462840f, -0.886932118794342080f, 0.461729715108338770f, + -0.887020670664428360f, + 0.461559622537733190f, -0.887109189921300060f, 0.461389512996899450f, + -0.887197676561702900f, + 0.461219386492092430f, -0.887286130582383150f, 0.461049243029567010f, + -0.887374551980088740f, + 0.460879082615578690f, -0.887462940751568840f, 0.460708905256384190f, + -0.887551296893573370f, + 0.460538710958240010f, -0.887639620402853930f, 0.460368499727404070f, + -0.887727911276163020f, + 0.460198271570134270f, -0.887816169510254550f, 0.460028026492689700f, + -0.887904395101883240f, + 0.459857764501329650f, -0.887992588047805560f, 0.459687485602313870f, + -0.888080748344778900f, + 0.459517189801903590f, -0.888168875989561620f, 0.459346877106359570f, + -0.888256970978913870f, + 0.459176547521944150f, -0.888345033309596240f, 0.459006201054919680f, + -0.888433062978371320f, + 0.458835837711549120f, -0.888521059982002260f, 0.458665457498096670f, + -0.888609024317253750f, + 0.458495060420826220f, -0.888696955980891710f, 0.458324646486003300f, + -0.888784854969682850f, + 0.458154215699893230f, -0.888872721280395520f, 0.457983768068762180f, + -0.888960554909799310f, + 0.457813303598877290f, -0.889048355854664570f, 0.457642822296505770f, + -0.889136124111763240f, + 0.457472324167916110f, -0.889223859677868210f, 0.457301809219376800f, + -0.889311562549753850f, + 0.457131277457156980f, -0.889399232724195520f, 0.456960728887527030f, + -0.889486870197969790f, + 0.456790163516757220f, -0.889574474967854580f, 0.456619581351118960f, + -0.889662047030628790f, + 0.456448982396883860f, -0.889749586383072890f, 0.456278366660324670f, + -0.889837093021967900f, + 0.456107734147714220f, -0.889924566944096720f, 0.455937084865326030f, + -0.890012008146243260f, + 0.455766418819434750f, -0.890099416625192210f, 0.455595736016314920f, + -0.890186792377730240f, + 0.455425036462242420f, -0.890274135400644480f, 0.455254320163493210f, + -0.890361445690723730f, + 0.455083587126343840f, -0.890448723244757880f, 0.454912837357072050f, + -0.890535968059537830f, + 0.454742070861955450f, -0.890623180131855930f, 0.454571287647273000f, + -0.890710359458505520f, + 0.454400487719303750f, -0.890797506036281490f, 0.454229671084327320f, + -0.890884619861979530f, + 0.454058837748624540f, -0.890971700932396750f, 0.453887987718476050f, + -0.891058749244331590f, + 0.453717121000163930f, -0.891145764794583180f, 0.453546237599970260f, + -0.891232747579952520f, + 0.453375337524177750f, -0.891319697597241390f, 0.453204420779070300f, + -0.891406614843252900f, + 0.453033487370931580f, -0.891493499314791380f, 0.452862537306046810f, + -0.891580351008662290f, + 0.452691570590700860f, -0.891667169921672390f, 0.452520587231180100f, + -0.891753956050629460f, + 0.452349587233771000f, -0.891840709392342720f, 0.452178570604760410f, + -0.891927429943622510f, + 0.452007537350436530f, -0.892014117701280360f, 0.451836487477087430f, + -0.892100772662129170f, + 0.451665420991002540f, -0.892187394822982480f, 0.451494337898471210f, + -0.892273984180655730f, + 0.451323238205783520f, -0.892360540731965360f, 0.451152121919230710f, + -0.892447064473728680f, + 0.450980989045103810f, -0.892533555402764690f, 0.450809839589695340f, + -0.892620013515893040f, + 0.450638673559297760f, -0.892706438809935280f, 0.450467490960204110f, + -0.892792831281713610f, + 0.450296291798708730f, -0.892879190928051680f, 0.450125076081105750f, + -0.892965517745774260f, + 0.449953843813690580f, -0.893051811731707450f, 0.449782595002758860f, + -0.893138072882678210f, + 0.449611329654606600f, -0.893224301195515320f, 0.449440047775531260f, + -0.893310496667048090f, + 0.449268749371829920f, -0.893396659294107610f, 0.449097434449801100f, + -0.893482789073525850f, + 0.448926103015743260f, -0.893568886002136020f, 0.448754755075956020f, + -0.893654950076772430f, + 0.448583390636739300f, -0.893740981294271040f, 0.448412009704393430f, + -0.893826979651468620f, + 0.448240612285220000f, -0.893912945145203250f, 0.448069198385520340f, + -0.893998877772314240f, + 0.447897768011597310f, -0.894084777529641990f, 0.447726321169753750f, + -0.894170644414028270f, + 0.447554857866293010f, -0.894256478422316040f, 0.447383378107519710f, + -0.894342279551349480f, + 0.447211881899738260f, -0.894428047797973800f, 0.447040369249254500f, + -0.894513783159035620f, + 0.446868840162374330f, -0.894599485631382580f, 0.446697294645404090f, + -0.894685155211863980f, + 0.446525732704651400f, -0.894770791897329550f, 0.446354154346423840f, + -0.894856395684630930f, + 0.446182559577030120f, -0.894941966570620750f, 0.446010948402779110f, + -0.895027504552152630f, + 0.445839320829980350f, -0.895113009626081760f, 0.445667676864944350f, + -0.895198481789264200f, + 0.445496016513981740f, -0.895283921038557580f, 0.445324339783404240f, + -0.895369327370820310f, + 0.445152646679523590f, -0.895454700782912450f, 0.444980937208652780f, + -0.895540041271694840f, + 0.444809211377105000f, -0.895625348834030000f, 0.444637469191193790f, + -0.895710623466781320f, + 0.444465710657234110f, -0.895795865166813420f, 0.444293935781540580f, + -0.895881073930992370f, + 0.444122144570429260f, -0.895966249756185110f, 0.443950337030216250f, + -0.896051392639260040f, + 0.443778513167218220f, -0.896136502577086770f, 0.443606672987753080f, + -0.896221579566535920f, + 0.443434816498138430f, -0.896306623604479660f, 0.443262943704693380f, + -0.896391634687790820f, + 0.443091054613736990f, -0.896476612813344010f, 0.442919149231588980f, + -0.896561557978014960f, + 0.442747227564570130f, -0.896646470178680150f, 0.442575289619001170f, + -0.896731349412217880f, + 0.442403335401204130f, -0.896816195675507190f, 0.442231364917501090f, + -0.896901008965428680f, + 0.442059378174214760f, -0.896985789278863970f, 0.441887375177668960f, + -0.897070536612695870f, + 0.441715355934187310f, -0.897155250963808550f, 0.441543320450094920f, + -0.897239932329087050f, + 0.441371268731716620f, -0.897324580705418320f, 0.441199200785378660f, + -0.897409196089689720f, + 0.441027116617407340f, -0.897493778478790190f, 0.440855016234129430f, + -0.897578327869610230f, + 0.440682899641873020f, -0.897662844259040750f, 0.440510766846965880f, + -0.897747327643974690f, + 0.440338617855737300f, -0.897831778021305650f, 0.440166452674516480f, + -0.897916195387928550f, + 0.439994271309633260f, -0.898000579740739880f, 0.439822073767418610f, + -0.898084931076636780f, + 0.439649860054203420f, -0.898169249392518080f, 0.439477630176319860f, + -0.898253534685283570f, + 0.439305384140100060f, -0.898337786951834190f, 0.439133121951876930f, + -0.898422006189072530f, + 0.438960843617984430f, -0.898506192393901840f, 0.438788549144756290f, + -0.898590345563227030f, + 0.438616238538527710f, -0.898674465693953820f, 0.438443911805633860f, + -0.898758552782989440f, + 0.438271568952410480f, -0.898842606827242260f, 0.438099209985194580f, + -0.898926627823621870f, + 0.437926834910322860f, -0.899010615769039070f, 0.437754443734133470f, + -0.899094570660405770f, + 0.437582036462964340f, -0.899178492494635330f, 0.437409613103154850f, + -0.899262381268642000f, + 0.437237173661044200f, -0.899346236979341460f, 0.437064718142972370f, + -0.899430059623650860f, + 0.436892246555280470f, -0.899513849198487870f, 0.436719758904309310f, + -0.899597605700772180f, + 0.436547255196401250f, -0.899681329127423930f, 0.436374735437898510f, + -0.899765019475365020f, + 0.436202199635143950f, -0.899848676741518580f, 0.436029647794481670f, + -0.899932300922808400f, + 0.435857079922255470f, -0.900015892016160280f, 0.435684496024810520f, + -0.900099450018500340f, + 0.435511896108492170f, -0.900182974926756700f, 0.435339280179646070f, + -0.900266466737858480f, + 0.435166648244619370f, -0.900349925448735600f, 0.434994000309758710f, + -0.900433351056319830f, + 0.434821336381412350f, -0.900516743557543520f, 0.434648656465928430f, + -0.900600102949340790f, + 0.434475960569655710f, -0.900683429228646860f, 0.434303248698944100f, + -0.900766722392397860f, + 0.434130520860143310f, -0.900849982437531450f, 0.433957777059604480f, + -0.900933209360986200f, + 0.433785017303678520f, -0.901016403159702330f, 0.433612241598717640f, + -0.901099563830620950f, + 0.433439449951074200f, -0.901182691370684410f, 0.433266642367100940f, + -0.901265785776836580f, + 0.433093818853152010f, -0.901348847046022030f, 0.432920979415581220f, + -0.901431875175186970f, + 0.432748124060743760f, -0.901514870161278630f, 0.432575252794994810f, + -0.901597832001245660f, + 0.432402365624690140f, -0.901680760692037730f, 0.432229462556186770f, + -0.901763656230605610f, + 0.432056543595841450f, -0.901846518613901860f, 0.431883608750012300f, + -0.901929347838879350f, + 0.431710658025057370f, -0.902012143902493070f, 0.431537691427335500f, + -0.902094906801698900f, + 0.431364708963206440f, -0.902177636533453510f, 0.431191710639030000f, + -0.902260333094715540f, + 0.431018696461167080f, -0.902342996482444200f, 0.430845666435978820f, + -0.902425626693600270f, + 0.430672620569826860f, -0.902508223725145830f, 0.430499558869073930f, + -0.902590787574043870f, + 0.430326481340082610f, -0.902673318237258830f, 0.430153387989216930f, + -0.902755815711756120f, + 0.429980278822840570f, -0.902838279994502830f, 0.429807153847318770f, + -0.902920711082466630f, + 0.429634013069016500f, -0.903003108972617040f, 0.429460856494299490f, + -0.903085473661924600f, + 0.429287684129534720f, -0.903167805147360610f, 0.429114495981088690f, + -0.903250103425898400f, + 0.428941292055329550f, -0.903332368494511820f, 0.428768072358625240f, + -0.903414600350176290f, + 0.428594836897344400f, -0.903496798989868450f, 0.428421585677856760f, + -0.903578964410565950f, + 0.428248318706531910f, -0.903661096609247980f, 0.428075035989740780f, + -0.903743195582894620f, + 0.427901737533854240f, -0.903825261328487390f, 0.427728423345243860f, + -0.903907293843009050f, + 0.427555093430282200f, -0.903989293123443340f, 0.427381747795341770f, + -0.904071259166775440f, + 0.427208386446796370f, -0.904153191969991670f, 0.427035009391019790f, + -0.904235091530079750f, + 0.426861616634386490f, -0.904316957844028320f, 0.426688208183271970f, + -0.904398790908827350f, + 0.426514784044051520f, -0.904480590721468250f, 0.426341344223101880f, + -0.904562357278943190f, + 0.426167888726799620f, -0.904644090578246240f, 0.425994417561522450f, + -0.904725790616371930f, + 0.425820930733648300f, -0.904807457390316540f, 0.425647428249555590f, + -0.904889090897077470f, + 0.425473910115623910f, -0.904970691133653250f, 0.425300376338232590f, + -0.905052258097043590f, + 0.425126826923762410f, -0.905133791784249580f, 0.424953261878594060f, + -0.905215292192273480f, + 0.424779681209108810f, -0.905296759318118820f, 0.424606084921689220f, + -0.905378193158789980f, + 0.424432473022717420f, -0.905459593711293250f, 0.424258845518577010f, + -0.905540960972635480f, + 0.424085202415651670f, -0.905622294939825160f, 0.423911543720325580f, + -0.905703595609872010f, + 0.423737869438983950f, -0.905784862979786440f, 0.423564179578011960f, + -0.905866097046580940f, + 0.423390474143796100f, -0.905947297807268460f, 0.423216753142722780f, + -0.906028465258863490f, + 0.423043016581179100f, -0.906109599398381980f, 0.422869264465553170f, + -0.906190700222840540f, + 0.422695496802232950f, -0.906271767729257660f, 0.422521713597607870f, + -0.906352801914652280f, + 0.422347914858067000f, -0.906433802776045460f, 0.422174100590000820f, + -0.906514770310458800f, + 0.422000270799799790f, -0.906595704514915330f, 0.421826425493854910f, + -0.906676605386439460f, + 0.421652564678558380f, -0.906757472922056550f, 0.421478688360302220f, + -0.906838307118793540f, + 0.421304796545479700f, -0.906919107973678030f, 0.421130889240484140f, + -0.906999875483739610f, + 0.420956966451709440f, -0.907080609646008450f, 0.420783028185550630f, + -0.907161310457516250f, + 0.420609074448402510f, -0.907241977915295930f, 0.420435105246661220f, + -0.907322612016381310f, + 0.420261120586723050f, -0.907403212757808000f, 0.420087120474984590f, + -0.907483780136612570f, + 0.419913104917843730f, -0.907564314149832520f, 0.419739073921698180f, + -0.907644814794507090f, + 0.419565027492946940f, -0.907725282067676330f, 0.419390965637989050f, + -0.907805715966381820f, + 0.419216888363223960f, -0.907886116487666150f, 0.419042795675052480f, + -0.907966483628573240f, + 0.418868687579875110f, -0.908046817386148340f, 0.418694564084093610f, + -0.908127117757437600f, + 0.418520425194109700f, -0.908207384739488700f, 0.418346270916326310f, + -0.908287618329350450f, + 0.418172101257146430f, -0.908367818524072780f, 0.417997916222973550f, + -0.908447985320707250f, + 0.417823715820212380f, -0.908528118716306120f, 0.417649500055267410f, + -0.908608218707923190f, + 0.417475268934544340f, -0.908688285292613360f, 0.417301022464449060f, + -0.908768318467432780f, + 0.417126760651387870f, -0.908848318229439120f, 0.416952483501768280f, + -0.908928284575690640f, + 0.416778191021997590f, -0.909008217503247450f, 0.416603883218484410f, + -0.909088117009170580f, + 0.416429560097637320f, -0.909167983090522270f, 0.416255221665865480f, + -0.909247815744366310f, + 0.416080867929579320f, -0.909327614967767260f, 0.415906498895188770f, + -0.909407380757791260f, + 0.415732114569105420f, -0.909487113111505430f, 0.415557714957740580f, + -0.909566812025978220f, + 0.415383300067506290f, -0.909646477498279540f, 0.415208869904815650f, + -0.909726109525480160f, + 0.415034424476081630f, -0.909805708104652220f, 0.414859963787718390f, + -0.909885273232869160f, + 0.414685487846140010f, -0.909964804907205660f, 0.414510996657761810f, + -0.910044303124737390f, + 0.414336490228999210f, -0.910123767882541570f, 0.414161968566268080f, + -0.910203199177696540f, + 0.413987431675985510f, -0.910282597007281760f, 0.413812879564568300f, + -0.910361961368377990f, + 0.413638312238434560f, -0.910441292258067140f, 0.413463729704002580f, + -0.910520589673432630f, + 0.413289131967690960f, -0.910599853611558930f, 0.413114519035919560f, + -0.910679084069531570f, + 0.412939890915108020f, -0.910758281044437570f, 0.412765247611677320f, + -0.910837444533365010f, + 0.412590589132048380f, -0.910916574533403240f, 0.412415915482642730f, + -0.910995671041643140f, + 0.412241226669883000f, -0.911074734055176250f, 0.412066522700191560f, + -0.911153763571095900f, + 0.411891803579992220f, -0.911232759586496190f, 0.411717069315708670f, + -0.911311722098472670f, + 0.411542319913765280f, -0.911390651104122320f, 0.411367555380587340f, + -0.911469546600543020f, + 0.411192775722600160f, -0.911548408584833990f, 0.411017980946230270f, + -0.911627237054095650f, + 0.410843171057903910f, -0.911706032005429880f, 0.410668346064048780f, + -0.911784793435939430f, + 0.410493505971092520f, -0.911863521342728520f, 0.410318650785463260f, + -0.911942215722902570f, + 0.410143780513590350f, -0.912020876573568230f, 0.409968895161902820f, + -0.912099503891833470f, + 0.409793994736831200f, -0.912178097674807060f, 0.409619079244805840f, + -0.912256657919599650f, + 0.409444148692257590f, -0.912335184623322750f, 0.409269203085618700f, + -0.912413677783089020f, + 0.409094242431320920f, -0.912492137396012650f, 0.408919266735797480f, + -0.912570563459208730f, + 0.408744276005481520f, -0.912648955969793900f, 0.408569270246806780f, + -0.912727314924885900f, + 0.408394249466208110f, -0.912805640321603500f, 0.408219213670120100f, + -0.912883932157067200f, + 0.408044162864978740f, -0.912962190428398100f, 0.407869097057219960f, + -0.913040415132719160f, + 0.407694016253280170f, -0.913118606267154130f, 0.407518920459597030f, + -0.913196763828828200f, + 0.407343809682607970f, -0.913274887814867760f, 0.407168683928751610f, + -0.913352978222400250f, + 0.406993543204466460f, -0.913431035048554720f, 0.406818387516192370f, + -0.913509058290461140f, + 0.406643216870369140f, -0.913587047945250810f, 0.406468031273437000f, + -0.913665004010056350f, + 0.406292830731837470f, -0.913742926482011390f, 0.406117615252011790f, + -0.913820815358251100f, + 0.405942384840402570f, -0.913898670635911680f, 0.405767139503452220f, + -0.913976492312130520f, + 0.405591879247603870f, -0.914054280384046460f, 0.405416604079301750f, + -0.914132034848799460f, + 0.405241314004989860f, -0.914209755703530690f, 0.405066009031113390f, + -0.914287442945382440f, + 0.404890689164117750f, -0.914365096571498450f, 0.404715354410448650f, + -0.914442716579023870f, + 0.404540004776553110f, -0.914520302965104450f, 0.404364640268877810f, + -0.914597855726887790f, + 0.404189260893870750f, -0.914675374861522390f, 0.404013866657980060f, + -0.914752860366158100f, + 0.403838457567654130f, -0.914830312237946090f, 0.403663033629342750f, + -0.914907730474038620f, + 0.403487594849495310f, -0.914985115071589310f, 0.403312141234562660f, + -0.915062466027752760f, + 0.403136672790995240f, -0.915139783339685260f, 0.402961189525244960f, + -0.915217067004543750f, + 0.402785691443763640f, -0.915294317019487050f, 0.402610178553003680f, + -0.915371533381674760f, + 0.402434650859418540f, -0.915448716088267830f, 0.402259108369461440f, + -0.915525865136428530f, + 0.402083551089587040f, -0.915602980523320230f, 0.401907979026249860f, + -0.915680062246107650f, + 0.401732392185905010f, -0.915757110301956720f, 0.401556790575008650f, + -0.915834124688034710f, + 0.401381174200016790f, -0.915911105401509880f, 0.401205543067386760f, + -0.915988052439551840f, + 0.401029897183575790f, -0.916064965799331610f, 0.400854236555041650f, + -0.916141845478021350f, + 0.400678561188243350f, -0.916218691472794110f, 0.400502871089639500f, + -0.916295503780824800f, + 0.400327166265690150f, -0.916372282399289140f, 0.400151446722855300f, + -0.916449027325364040f, + 0.399975712467595390f, -0.916525738556228100f, 0.399799963506372090f, + -0.916602416089060680f, + 0.399624199845646790f, -0.916679059921042700f, 0.399448421491882260f, + -0.916755670049355990f, + 0.399272628451540930f, -0.916832246471183890f, 0.399096820731086600f, + -0.916908789183710990f, + 0.398920998336983020f, -0.916985298184122890f, 0.398745161275694480f, + -0.917061773469606820f, + 0.398569309553686360f, -0.917138215037350710f, 0.398393443177423920f, + -0.917214622884544250f, + 0.398217562153373620f, -0.917290997008377910f, 0.398041666488001930f, + -0.917367337406043810f, + 0.397865756187775750f, -0.917443644074735220f, 0.397689831259163240f, + -0.917519917011646260f, + 0.397513891708632330f, -0.917596156213972950f, 0.397337937542652120f, + -0.917672361678911750f, + 0.397161968767691720f, -0.917748533403661250f, 0.396985985390220900f, + -0.917824671385420570f, + 0.396809987416710420f, -0.917900775621390390f, 0.396633974853630830f, + -0.917976846108772730f, + 0.396457947707453960f, -0.918052882844770380f, 0.396281905984651680f, + -0.918128885826587910f, + 0.396105849691696320f, -0.918204855051430900f, 0.395929778835061360f, + -0.918280790516506130f, + 0.395753693421220080f, -0.918356692219021720f, 0.395577593456646950f, + -0.918432560156186790f, + 0.395401478947816300f, -0.918508394325212250f, 0.395225349901203730f, + -0.918584194723309540f, + 0.395049206323284880f, -0.918659961347691900f, 0.394873048220535760f, + -0.918735694195573550f, + 0.394696875599433670f, -0.918811393264169940f, 0.394520688466455550f, + -0.918887058550697970f, + 0.394344486828079650f, -0.918962690052375630f, 0.394168270690784250f, + -0.919038287766421940f, + 0.393992040061048100f, -0.919113851690057770f, 0.393815794945351130f, + -0.919189381820504470f, + 0.393639535350172880f, -0.919264878154985250f, 0.393463261281994380f, + -0.919340340690724230f, + 0.393286972747296570f, -0.919415769424946960f, 0.393110669752560760f, + -0.919491164354880100f, + 0.392934352304269600f, -0.919566525477751530f, 0.392758020408905280f, + -0.919641852790790470f, + 0.392581674072951530f, -0.919717146291227360f, 0.392405313302891860f, + -0.919792405976293750f, + 0.392228938105210370f, -0.919867631843222950f, 0.392052548486392200f, + -0.919942823889248640f, + 0.391876144452922350f, -0.920017982111606570f, 0.391699726011287050f, + -0.920093106507533070f, + 0.391523293167972350f, -0.920168197074266450f, 0.391346845929465610f, + -0.920243253809045370f, + 0.391170384302253980f, -0.920318276709110480f, 0.390993908292825380f, + -0.920393265771703550f, + 0.390817417907668610f, -0.920468220994067110f, 0.390640913153272370f, + -0.920543142373445480f, + 0.390464394036126650f, -0.920618029907083860f, 0.390287860562721360f, + -0.920692883592229010f, + 0.390111312739546910f, -0.920767703426128790f, 0.389934750573094790f, + -0.920842489406032080f, + 0.389758174069856410f, -0.920917241529189520f, 0.389581583236324360f, + -0.920991959792852310f, + 0.389404978078991100f, -0.921066644194273530f, 0.389228358604349730f, + -0.921141294730707270f, + 0.389051724818894500f, -0.921215911399408730f, 0.388875076729119250f, + -0.921290494197634540f, + 0.388698414341519250f, -0.921365043122642340f, 0.388521737662589740f, + -0.921439558171691320f, + 0.388345046698826300f, -0.921514039342041900f, 0.388168341456725850f, + -0.921588486630955380f, + 0.387991621942784910f, -0.921662900035694730f, 0.387814888163501290f, + -0.921737279553523800f, + 0.387638140125372680f, -0.921811625181708120f, 0.387461377834897920f, + -0.921885936917513970f, + 0.387284601298575890f, -0.921960214758209110f, 0.387107810522905990f, + -0.922034458701062820f, + 0.386931005514388690f, -0.922108668743345070f, 0.386754186279524130f, + -0.922182844882327600f, + 0.386577352824813980f, -0.922256987115283030f, 0.386400505156759610f, + -0.922331095439485330f, + 0.386223643281862980f, -0.922405169852209880f, 0.386046767206627280f, + -0.922479210350733100f, + 0.385869876937555310f, -0.922553216932332830f, 0.385692972481151200f, + -0.922627189594287800f, + 0.385516053843919020f, -0.922701128333878520f, 0.385339121032363340f, + -0.922775033148386380f, + 0.385162174052989970f, -0.922848904035094120f, 0.384985212912304200f, + -0.922922740991285680f, + 0.384808237616812930f, -0.922996544014246250f, 0.384631248173022740f, + -0.923070313101262420f, + 0.384454244587440870f, -0.923144048249621820f, 0.384277226866575620f, + -0.923217749456613500f, + 0.384100195016935040f, -0.923291416719527640f, 0.383923149045028500f, + -0.923365050035655610f, + 0.383746088957365010f, -0.923438649402290370f, 0.383569014760454960f, + -0.923512214816725520f, + 0.383391926460808770f, -0.923585746276256560f, 0.383214824064937180f, + -0.923659243778179980f, + 0.383037707579352130f, -0.923732707319793180f, 0.382860577010565360f, + -0.923806136898395410f, + 0.382683432365089840f, -0.923879532511286740f, 0.382506273649438400f, + -0.923952894155768640f, + 0.382329100870124510f, -0.924026221829143850f, 0.382151914033662720f, + -0.924099515528716280f, + 0.381974713146567220f, -0.924172775251791200f, 0.381797498215353690f, + -0.924246000995674890f, + 0.381620269246537520f, -0.924319192757675160f, 0.381443026246634730f, + -0.924392350535101050f, + 0.381265769222162490f, -0.924465474325262600f, 0.381088498179637520f, + -0.924538564125471420f, + 0.380911213125578130f, -0.924611619933039970f, 0.380733914066502090f, + -0.924684641745282530f, + 0.380556601008928570f, -0.924757629559513910f, 0.380379273959376710f, + -0.924830583373050800f, + 0.380201932924366050f, -0.924903503183210910f, 0.380024577910417380f, + -0.924976388987313050f, + 0.379847208924051110f, -0.925049240782677580f, 0.379669825971789000f, + -0.925122058566625770f, + 0.379492429060152740f, -0.925194842336480420f, 0.379315018195664430f, + -0.925267592089565550f, + 0.379137593384847430f, -0.925340307823206200f, 0.378960154634224720f, + -0.925412989534729060f, + 0.378782701950320600f, -0.925485637221461490f, 0.378605235339659290f, + -0.925558250880732620f, + 0.378427754808765620f, -0.925630830509872720f, 0.378250260364165310f, + -0.925703376106213120f, + 0.378072752012383990f, -0.925775887667086740f, 0.377895229759948550f, + -0.925848365189827270f, + 0.377717693613385810f, -0.925920808671769960f, 0.377540143579222940f, + -0.925993218110251480f, + 0.377362579663988450f, -0.926065593502609310f, 0.377185001874210450f, + -0.926137934846182560f, + 0.377007410216418310f, -0.926210242138311270f, 0.376829804697141220f, + -0.926282515376337210f, + 0.376652185322909620f, -0.926354754557602860f, 0.376474552100253880f, + -0.926426959679452100f, + 0.376296905035704790f, -0.926499130739230510f, 0.376119244135794390f, + -0.926571267734284220f, + 0.375941569407054420f, -0.926643370661961230f, 0.375763880856017750f, + -0.926715439519610330f, + 0.375586178489217330f, -0.926787474304581750f, 0.375408462313186590f, + -0.926859475014227160f, + 0.375230732334460030f, -0.926931441645899130f, 0.375052988559571860f, + -0.927003374196951670f, + 0.374875230995057600f, -0.927075272664740100f, 0.374697459647452770f, + -0.927147137046620880f, + 0.374519674523293210f, -0.927218967339951790f, 0.374341875629116030f, + -0.927290763542091720f, + 0.374164062971457990f, -0.927362525650401110f, 0.373986236556857090f, + -0.927434253662241300f, + 0.373808396391851370f, -0.927505947574975180f, 0.373630542482979280f, + -0.927577607385966730f, + 0.373452674836780410f, -0.927649233092581180f, 0.373274793459794030f, + -0.927720824692185200f, + 0.373096898358560690f, -0.927792382182146320f, 0.372918989539620770f, + -0.927863905559833780f, + 0.372741067009515810f, -0.927935394822617890f, 0.372563130774787370f, + -0.928006849967869970f, + 0.372385180841977360f, -0.928078270992963140f, 0.372207217217628950f, + -0.928149657895271150f, + 0.372029239908284960f, -0.928221010672169440f, 0.371851248920489540f, + -0.928292329321034560f, + 0.371673244260786630f, -0.928363613839244370f, 0.371495225935720760f, + -0.928434864224177980f, + 0.371317193951837600f, -0.928506080473215480f, 0.371139148315682510f, + -0.928577262583738850f, + 0.370961089033802040f, -0.928648410553130520f, 0.370783016112742720f, + -0.928719524378774700f, + 0.370604929559051670f, -0.928790604058057020f, 0.370426829379276900f, + -0.928861649588363700f, + 0.370248715579966360f, -0.928932660967082820f, 0.370070588167669130f, + -0.929003638191603360f, + 0.369892447148934270f, -0.929074581259315750f, 0.369714292530311240f, + -0.929145490167611720f, + 0.369536124318350760f, -0.929216364913883930f, 0.369357942519603190f, + -0.929287205495526790f, + 0.369179747140620070f, -0.929358011909935500f, 0.369001538187952780f, + -0.929428784154506800f, + 0.368823315668153960f, -0.929499522226638560f, 0.368645079587776150f, + -0.929570226123729860f, + 0.368466829953372320f, -0.929640895843181330f, 0.368288566771496680f, + -0.929711531382394370f, + 0.368110290048703050f, -0.929782132738772190f, 0.367931999791546500f, + -0.929852699909718750f, + 0.367753696006582090f, -0.929923232892639560f, 0.367575378700365330f, + -0.929993731684941480f, + 0.367397047879452820f, -0.930064196284032360f, 0.367218703550400930f, + -0.930134626687321390f, + 0.367040345719767240f, -0.930205022892219070f, 0.366861974394109220f, + -0.930275384896137040f, + 0.366683589579984930f, -0.930345712696488470f, 0.366505191283953480f, + -0.930416006290687550f, + 0.366326779512573590f, -0.930486265676149780f, 0.366148354272405390f, + -0.930556490850291800f, + 0.365969915570008910f, -0.930626681810531650f, 0.365791463411944570f, + -0.930696838554288860f, + 0.365612997804773960f, -0.930766961078983710f, 0.365434518755058390f, + -0.930837049382038150f, + 0.365256026269360380f, -0.930907103460875020f, 0.365077520354242180f, + -0.930977123312918930f, + 0.364899001016267380f, -0.931047108935595170f, 0.364720468261999390f, + -0.931117060326330790f, + 0.364541922098002180f, -0.931186977482553750f, 0.364363362530840730f, + -0.931256860401693420f, + 0.364184789567079840f, -0.931326709081180430f, 0.364006203213285530f, + -0.931396523518446600f, + 0.363827603476023610f, -0.931466303710925090f, 0.363648990361860550f, + -0.931536049656050300f, + 0.363470363877363870f, -0.931605761351257830f, 0.363291724029100700f, + -0.931675438793984620f, + 0.363113070823639530f, -0.931745081981668720f, 0.362934404267548750f, + -0.931814690911749620f, + 0.362755724367397230f, -0.931884265581668150f, 0.362577031129754870f, + -0.931953805988865900f, + 0.362398324561191310f, -0.932023312130786490f, 0.362219604668277570f, + -0.932092784004874050f, + 0.362040871457584350f, -0.932162221608574320f, 0.361862124935682980f, + -0.932231624939334540f, + 0.361683365109145950f, -0.932300993994602640f, 0.361504591984545260f, + -0.932370328771828460f, + 0.361325805568454340f, -0.932439629268462360f, 0.361147005867446190f, + -0.932508895481956700f, + 0.360968192888095290f, -0.932578127409764420f, 0.360789366636975690f, + -0.932647325049340340f, + 0.360610527120662270f, -0.932716488398140250f, 0.360431674345730810f, + -0.932785617453620990f, + 0.360252808318756830f, -0.932854712213241230f, 0.360073929046317080f, + -0.932923772674460140f, + 0.359895036534988280f, -0.932992798834738850f, 0.359716130791347570f, + -0.933061790691539380f, + 0.359537211821973180f, -0.933130748242325110f, 0.359358279633443080f, + -0.933199671484560730f, + 0.359179334232336560f, -0.933268560415712050f, 0.359000375625232630f, + -0.933337415033246080f, + 0.358821403818710920f, -0.933406235334631520f, 0.358642418819352100f, + -0.933475021317337950f, + 0.358463420633736540f, -0.933543772978836170f, 0.358284409268445900f, + -0.933612490316598540f, + 0.358105384730061760f, -0.933681173328098300f, 0.357926347025166070f, + -0.933749822010810580f, + 0.357747296160342010f, -0.933818436362210960f, 0.357568232142172260f, + -0.933887016379776890f, + 0.357389154977241000f, -0.933955562060986730f, 0.357210064672131900f, + -0.934024073403320500f, + 0.357030961233430030f, -0.934092550404258870f, 0.356851844667720410f, + -0.934160993061284420f, + 0.356672714981588260f, -0.934229401371880820f, 0.356493572181620200f, + -0.934297775333532530f, + 0.356314416274402360f, -0.934366114943725900f, 0.356135247266522180f, + -0.934434420199948050f, + 0.355956065164567010f, -0.934502691099687870f, 0.355776869975124640f, + -0.934570927640435030f, + 0.355597661704783960f, -0.934639129819680780f, 0.355418440360133590f, + -0.934707297634917440f, + 0.355239205947763370f, -0.934775431083638700f, 0.355059958474263030f, + -0.934843530163339430f, + 0.354880697946222790f, -0.934911594871516090f, 0.354701424370233940f, + -0.934979625205665800f, + 0.354522137752887430f, -0.935047621163287430f, 0.354342838100775600f, + -0.935115582741880890f, + 0.354163525420490510f, -0.935183509938947500f, 0.353984199718624830f, + -0.935251402751989810f, + 0.353804861001772160f, -0.935319261178511500f, 0.353625509276525970f, + -0.935387085216017770f, + 0.353446144549480870f, -0.935454874862014620f, 0.353266766827231180f, + -0.935522630114009930f, + 0.353087376116372530f, -0.935590350969512370f, 0.352907972423500360f, + -0.935658037426032040f, + 0.352728555755210730f, -0.935725689481080370f, 0.352549126118100580f, + -0.935793307132169900f, + 0.352369683518766630f, -0.935860890376814640f, 0.352190227963806890f, + -0.935928439212529660f, + 0.352010759459819240f, -0.935995953636831300f, 0.351831278013402030f, + -0.936063433647237540f, + 0.351651783631154680f, -0.936130879241266920f, 0.351472276319676260f, + -0.936198290416440090f, + 0.351292756085567150f, -0.936265667170278260f, 0.351113222935427630f, + -0.936333009500304180f, + 0.350933676875858360f, -0.936400317404042060f, 0.350754117913461170f, + -0.936467590879016880f, + 0.350574546054837570f, -0.936534829922755500f, 0.350394961306590200f, + -0.936602034532785570f, + 0.350215363675321740f, -0.936669204706636060f, 0.350035753167635300f, + -0.936736340441837620f, + 0.349856129790135030f, -0.936803441735921560f, 0.349676493549424760f, + -0.936870508586420960f, + 0.349496844452109600f, -0.936937540990869900f, 0.349317182504794320f, + -0.937004538946803690f, + 0.349137507714085030f, -0.937071502451759190f, 0.348957820086587600f, + -0.937138431503274140f, + 0.348778119628908420f, -0.937205326098887960f, 0.348598406347655040f, + -0.937272186236140950f, + 0.348418680249434510f, -0.937339011912574960f, 0.348238941340855310f, + -0.937405803125732850f, + 0.348059189628525780f, -0.937472559873159140f, 0.347879425119054510f, + -0.937539282152399230f, + 0.347699647819051490f, -0.937605969960999990f, 0.347519857735126110f, + -0.937672623296509470f, + 0.347340054873889190f, -0.937739242156476970f, 0.347160239241951330f, + -0.937805826538453010f, + 0.346980410845923680f, -0.937872376439989890f, 0.346800569692418400f, + -0.937938891858640210f, + 0.346620715788047320f, -0.938005372791958840f, 0.346440849139423580f, + -0.938071819237501160f, + 0.346260969753160170f, -0.938138231192824360f, 0.346081077635870480f, + -0.938204608655486490f, + 0.345901172794169100f, -0.938270951623047080f, 0.345721255234670120f, + -0.938337260093066950f, + 0.345541324963989150f, -0.938403534063108060f, 0.345361381988741170f, + -0.938469773530733800f, + 0.345181426315542610f, -0.938535978493508560f, 0.345001457951009780f, + -0.938602148948998290f, + 0.344821476901759290f, -0.938668284894770170f, 0.344641483174409070f, + -0.938734386328392460f, + 0.344461476775576480f, -0.938800453247434770f, 0.344281457711880230f, + -0.938866485649468060f, + 0.344101425989938980f, -0.938932483532064490f, 0.343921381616371700f, + -0.938998446892797540f, + 0.343741324597798600f, -0.939064375729241950f, 0.343561254940839330f, + -0.939130270038973650f, + 0.343381172652115100f, -0.939196129819569900f, 0.343201077738246710f, + -0.939261955068609100f, + 0.343020970205855540f, -0.939327745783671400f, 0.342840850061564060f, + -0.939393501962337510f, + 0.342660717311994380f, -0.939459223602189920f, 0.342480571963769850f, + -0.939524910700812120f, + 0.342300414023513690f, -0.939590563255789160f, 0.342120243497849590f, + -0.939656181264707070f, + 0.341940060393402300f, -0.939721764725153340f, 0.341759864716796310f, + -0.939787313634716570f, + 0.341579656474657210f, -0.939852827990986680f, 0.341399435673610360f, + -0.939918307791555050f, + 0.341219202320282410f, -0.939983753034013940f, 0.341038956421299830f, + -0.940049163715957370f, + 0.340858697983289440f, -0.940114539834980280f, 0.340678427012879310f, + -0.940179881388678810f, + 0.340498143516697100f, -0.940245188374650880f, 0.340317847501371730f, + -0.940310460790495070f, + 0.340137538973531880f, -0.940375698633811540f, 0.339957217939806880f, + -0.940440901902201750f, + 0.339776884406826960f, -0.940506070593268300f, 0.339596538381222060f, + -0.940571204704615190f, + 0.339416179869623410f, -0.940636304233847590f, 0.339235808878662120f, + -0.940701369178571940f, + 0.339055425414969640f, -0.940766399536396070f, 0.338875029485178560f, + -0.940831395304928870f, + 0.338694621095921190f, -0.940896356481780830f, 0.338514200253831000f, + -0.940961283064563280f, + 0.338333766965541290f, -0.941026175050889260f, 0.338153321237685990f, + -0.941091032438372780f, + 0.337972863076899830f, -0.941155855224629190f, 0.337792392489817460f, + -0.941220643407275180f, + 0.337611909483074680f, -0.941285396983928660f, 0.337431414063306790f, + -0.941350115952208970f, + 0.337250906237150650f, -0.941414800309736230f, 0.337070386011242730f, + -0.941479450054132580f, + 0.336889853392220050f, -0.941544065183020810f, 0.336709308386720700f, + -0.941608645694025140f, + 0.336528751001382350f, -0.941673191584771360f, 0.336348181242844100f, + -0.941737702852886160f, + 0.336167599117744690f, -0.941802179495997650f, 0.335987004632723350f, + -0.941866621511735280f, + 0.335806397794420560f, -0.941931028897729510f, 0.335625778609476230f, + -0.941995401651612550f, + 0.335445147084531660f, -0.942059739771017310f, 0.335264503226227970f, + -0.942124043253578460f, + 0.335083847041206580f, -0.942188312096931770f, 0.334903178536110290f, + -0.942252546298714020f, + 0.334722497717581220f, -0.942316745856563780f, 0.334541804592262960f, + -0.942380910768120470f, + 0.334361099166798900f, -0.942445041031024890f, 0.334180381447832740f, + -0.942509136642919240f, + 0.333999651442009490f, -0.942573197601446870f, 0.333818909155973620f, + -0.942637223904252530f, + 0.333638154596370920f, -0.942701215548981900f, 0.333457387769846790f, + -0.942765172533282510f, + 0.333276608683047980f, -0.942829094854802710f, 0.333095817342620890f, + -0.942892982511192130f, + 0.332915013755212650f, -0.942956835500102120f, 0.332734197927471160f, + -0.943020653819184650f, + 0.332553369866044220f, -0.943084437466093490f, 0.332372529577580680f, + -0.943148186438483420f, + 0.332191677068729320f, -0.943211900734010620f, 0.332010812346139380f, + -0.943275580350332540f, + 0.331829935416461220f, -0.943339225285107720f, 0.331649046286344620f, + -0.943402835535996240f, + 0.331468144962440920f, -0.943466411100659320f, 0.331287231451400990f, + -0.943529951976759370f, + 0.331106305759876430f, -0.943593458161960390f, 0.330925367894519650f, + -0.943656929653927110f, + 0.330744417861982890f, -0.943720366450326200f, 0.330563455668919590f, + -0.943783768548825060f, + 0.330382481321982950f, -0.943847135947092690f, 0.330201494827826620f, + -0.943910468642799150f, + 0.330020496193105530f, -0.943973766633615980f, 0.329839485424473940f, + -0.944037029917215830f, + 0.329658462528587550f, -0.944100258491272660f, 0.329477427512101680f, + -0.944163452353461770f, + 0.329296380381672800f, -0.944226611501459810f, 0.329115321143957360f, + -0.944289735932944410f, + 0.328934249805612200f, -0.944352825645594750f, 0.328753166373295100f, + -0.944415880637091250f, + 0.328572070853663690f, -0.944478900905115550f, 0.328390963253376630f, + -0.944541886447350380f, + 0.328209843579092660f, -0.944604837261480260f, 0.328028711837470730f, + -0.944667753345190490f, + 0.327847568035170960f, -0.944730634696167800f, 0.327666412178853060f, + -0.944793481312100280f, + 0.327485244275178060f, -0.944856293190677210f, 0.327304064330806830f, + -0.944919070329589220f, + 0.327122872352400510f, -0.944981812726528150f, 0.326941668346621530f, + -0.945044520379187070f, + 0.326760452320131790f, -0.945107193285260610f, 0.326579224279594460f, + -0.945169831442444150f, + 0.326397984231672660f, -0.945232434848434890f, 0.326216732183029770f, + -0.945295003500931100f, + 0.326035468140330350f, -0.945357537397632290f, 0.325854192110238580f, + -0.945420036536239070f, + 0.325672904099419900f, -0.945482500914453740f, 0.325491604114539260f, + -0.945544930529979680f, + 0.325310292162262980f, -0.945607325380521280f, 0.325128968249257190f, + -0.945669685463784710f, + 0.324947632382188430f, -0.945732010777477150f, 0.324766284567724330f, + -0.945794301319306860f, + 0.324584924812532150f, -0.945856557086983910f, 0.324403553123280290f, + -0.945918778078219110f, + 0.324222169506637130f, -0.945980964290724760f, 0.324040773969271450f, + -0.946043115722214560f, + 0.323859366517852960f, -0.946105232370403340f, 0.323677947159051180f, + -0.946167314233007370f, + 0.323496515899536760f, -0.946229361307743820f, 0.323315072745980150f, + -0.946291373592331510f, + 0.323133617705052330f, -0.946353351084490590f, 0.322952150783425370f, + -0.946415293781942110f, + 0.322770671987770710f, -0.946477201682408680f, 0.322589181324761390f, + -0.946539074783614100f, + 0.322407678801070020f, -0.946600913083283530f, 0.322226164423369650f, + -0.946662716579143360f, + 0.322044638198334620f, -0.946724485268921170f, 0.321863100132638580f, + -0.946786219150346000f, + 0.321681550232956640f, -0.946847918221148000f, 0.321499988505963450f, + -0.946909582479058760f, + 0.321318414958334910f, -0.946971211921810880f, 0.321136829596746780f, + -0.947032806547138620f, + 0.320955232427875210f, -0.947094366352777220f, 0.320773623458397440f, + -0.947155891336463270f, + 0.320592002694990330f, -0.947217381495934820f, 0.320410370144331880f, + -0.947278836828930880f, + 0.320228725813100020f, -0.947340257333191940f, 0.320047069707973140f, + -0.947401643006459900f, + 0.319865401835630610f, -0.947462993846477700f, 0.319683722202751370f, + -0.947524309850989570f, + 0.319502030816015750f, -0.947585591017741090f, 0.319320327682103720f, + -0.947646837344479190f, + 0.319138612807695900f, -0.947708048828952100f, 0.318956886199473770f, + -0.947769225468909180f, + 0.318775147864118480f, -0.947830367262101010f, 0.318593397808312470f, + -0.947891474206279730f, + 0.318411636038737960f, -0.947952546299198560f, 0.318229862562077580f, + -0.948013583538612200f, + 0.318048077385015060f, -0.948074585922276230f, 0.317866280514233660f, + -0.948135553447947980f, + 0.317684471956418020f, -0.948196486113385580f, 0.317502651718252260f, + -0.948257383916349060f, + 0.317320819806421790f, -0.948318246854599090f, 0.317138976227611890f, + -0.948379074925898120f, + 0.316957120988508150f, -0.948439868128009620f, 0.316775254095797380f, + -0.948500626458698260f, + 0.316593375556165850f, -0.948561349915730270f, 0.316411485376301090f, + -0.948622038496872990f, + 0.316229583562890490f, -0.948682692199895090f, 0.316047670122621860f, + -0.948743311022566480f, + 0.315865745062184070f, -0.948803894962658380f, 0.315683808388265600f, + -0.948864444017943340f, + 0.315501860107556040f, -0.948924958186195160f, 0.315319900226745050f, + -0.948985437465188710f, + 0.315137928752522440f, -0.949045881852700560f, 0.314955945691579250f, + -0.949106291346508260f, + 0.314773951050606070f, -0.949166665944390700f, 0.314591944836294710f, + -0.949227005644128210f, + 0.314409927055336820f, -0.949287310443502010f, 0.314227897714424500f, + -0.949347580340295210f, + 0.314045856820250820f, -0.949407815332291460f, 0.313863804379508500f, + -0.949468015417276550f, + 0.313681740398891570f, -0.949528180593036670f, 0.313499664885093450f, + -0.949588310857359950f, + 0.313317577844809070f, -0.949648406208035480f, 0.313135479284732950f, + -0.949708466642853800f, + 0.312953369211560200f, -0.949768492159606680f, 0.312771247631986880f, + -0.949828482756087000f, + 0.312589114552708660f, -0.949888438430089300f, 0.312406969980422500f, + -0.949948359179409010f, + 0.312224813921825050f, -0.950008245001843000f, 0.312042646383613510f, + -0.950068095895189590f, + 0.311860467372486130f, -0.950127911857248100f, 0.311678276895140550f, + -0.950187692885819280f, + 0.311496074958275970f, -0.950247438978705230f, 0.311313861568591090f, + -0.950307150133709140f, + 0.311131636732785270f, -0.950366826348635780f, 0.310949400457558760f, + -0.950426467621290900f, + 0.310767152749611470f, -0.950486073949481700f, 0.310584893615644560f, + -0.950545645331016600f, + 0.310402623062358880f, -0.950605181763705230f, 0.310220341096455910f, + -0.950664683245358910f, + 0.310038047724638000f, -0.950724149773789610f, 0.309855742953607130f, + -0.950783581346811070f, + 0.309673426790066490f, -0.950842977962238160f, 0.309491099240719050f, + -0.950902339617887060f, + 0.309308760312268780f, -0.950961666311575080f, 0.309126410011419550f, + -0.951020958041121080f, + 0.308944048344875710f, -0.951080214804345010f, 0.308761675319342570f, + -0.951139436599068190f, + 0.308579290941525030f, -0.951198623423113230f, 0.308396895218129240f, + -0.951257775274304000f, + 0.308214488155861220f, -0.951316892150465550f, 0.308032069761427330f, + -0.951375974049424420f, + 0.307849640041534980f, -0.951435020969008340f, 0.307667199002891190f, + -0.951494032907046370f, + 0.307484746652204160f, -0.951553009861368590f, 0.307302282996181950f, + -0.951611951829806730f, + 0.307119808041533100f, -0.951670858810193860f, 0.306937321794967020f, + -0.951729730800363720f, + 0.306754824263192780f, -0.951788567798152130f, 0.306572315452920800f, + -0.951847369801395620f, + 0.306389795370861080f, -0.951906136807932230f, 0.306207264023724280f, + -0.951964868815601380f, + 0.306024721418221900f, -0.952023565822243570f, 0.305842167561065080f, + -0.952082227825700620f, + 0.305659602458966230f, -0.952140854823815830f, 0.305477026118637360f, + -0.952199446814433580f, + 0.305294438546791720f, -0.952258003795399600f, 0.305111839750142220f, + -0.952316525764560830f, + 0.304929229735402430f, -0.952375012719765880f, 0.304746608509286640f, + -0.952433464658864030f, + 0.304563976078509050f, -0.952491881579706320f, 0.304381332449784940f, + -0.952550263480144930f, + 0.304198677629829270f, -0.952608610358033240f, 0.304016011625357570f, + -0.952666922211226170f, + 0.303833334443086470f, -0.952725199037579570f, 0.303650646089731910f, + -0.952783440834950920f, + 0.303467946572011370f, -0.952841647601198720f, 0.303285235896641910f, + -0.952899819334182880f, + 0.303102514070341060f, -0.952957956031764700f, 0.302919781099827420f, + -0.953016057691806530f, + 0.302737036991819140f, -0.953074124312172200f, 0.302554281753035670f, + -0.953132155890726750f, + 0.302371515390196130f, -0.953190152425336560f, 0.302188737910020040f, + -0.953248113913869320f, + 0.302005949319228200f, -0.953306040354193750f, 0.301823149624540650f, + -0.953363931744180330f, + 0.301640338832678880f, -0.953421788081700310f, 0.301457516950363940f, + -0.953479609364626610f, + 0.301274683984318000f, -0.953537395590833280f, 0.301091839941263210f, + -0.953595146758195680f, + 0.300908984827921890f, -0.953652862864590500f, 0.300726118651017620f, + -0.953710543907895560f, + 0.300543241417273400f, -0.953768189885990330f, 0.300360353133413580f, + -0.953825800796755050f, + 0.300177453806162120f, -0.953883376638071770f, 0.299994543442243580f, + -0.953940917407823500f, + 0.299811622048383460f, -0.953998423103894490f, 0.299628689631306790f, + -0.954055893724170660f, + 0.299445746197739950f, -0.954113329266538800f, 0.299262791754409010f, + -0.954170729728887280f, + 0.299079826308040480f, -0.954228095109105670f, 0.298896849865361910f, + -0.954285425405084650f, + 0.298713862433100390f, -0.954342720614716480f, 0.298530864017984230f, + -0.954399980735894490f, + 0.298347854626741570f, -0.954457205766513490f, 0.298164834266100910f, + -0.954514395704469500f, + 0.297981802942791920f, -0.954571550547659630f, 0.297798760663543550f, + -0.954628670293982680f, + 0.297615707435086310f, -0.954685754941338340f, 0.297432643264150030f, + -0.954742804487627940f, + 0.297249568157465890f, -0.954799818930753720f, 0.297066482121764840f, + -0.954856798268619580f, + 0.296883385163778270f, -0.954913742499130520f, 0.296700277290238460f, + -0.954970651620192790f, + 0.296517158507877410f, -0.955027525629714160f, 0.296334028823428240f, + -0.955084364525603410f, + 0.296150888243623960f, -0.955141168305770670f, 0.295967736775197890f, + -0.955197936968127710f, + 0.295784574424884370f, -0.955254670510586990f, 0.295601401199417360f, + -0.955311368931062720f, + 0.295418217105532070f, -0.955368032227470240f, 0.295235022149963390f, + -0.955424660397726330f, + 0.295051816339446720f, -0.955481253439748770f, 0.294868599680718380f, + -0.955537811351456770f, + 0.294685372180514330f, -0.955594334130771110f, 0.294502133845571720f, + -0.955650821775613220f, + 0.294318884682627570f, -0.955707274283906560f, 0.294135624698419080f, + -0.955763691653575440f, + 0.293952353899684770f, -0.955820073882545420f, 0.293769072293162400f, + -0.955876420968743590f, + 0.293585779885591310f, -0.955932732910098170f, 0.293402476683710060f, + -0.955989009704538930f, + 0.293219162694258680f, -0.956045251349996410f, 0.293035837923976920f, + -0.956101457844403040f, + 0.292852502379604810f, -0.956157629185692140f, 0.292669156067883570f, + -0.956213765371798470f, + 0.292485798995553830f, -0.956269866400658140f, 0.292302431169357610f, + -0.956325932270208230f, + 0.292119052596036540f, -0.956381962978387620f, 0.291935663282332780f, + -0.956437958523136180f, + 0.291752263234989370f, -0.956493918902394990f, 0.291568852460749040f, + -0.956549844114106820f, + 0.291385430966355720f, -0.956605734156215080f, 0.291201998758553020f, + -0.956661589026664980f, + 0.291018555844085090f, -0.956717408723403050f, 0.290835102229696940f, + -0.956773193244376930f, + 0.290651637922133220f, -0.956828942587535370f, 0.290468162928139870f, + -0.956884656750828900f, + 0.290284677254462330f, -0.956940335732208940f, 0.290101180907847140f, + -0.956995979529628230f, + 0.289917673895040860f, -0.957051588141040970f, 0.289734156222790250f, + -0.957107161564402790f, + 0.289550627897843140f, -0.957162699797670100f, 0.289367088926946960f, + -0.957218202838801210f, + 0.289183539316850310f, -0.957273670685755200f, 0.288999979074301530f, + -0.957329103336492790f, + 0.288816408206049480f, -0.957384500788975860f, 0.288632826718843940f, + -0.957439863041167570f, + 0.288449234619434170f, -0.957495190091032570f, 0.288265631914570830f, + -0.957550481936536470f, + 0.288082018611004300f, -0.957605738575646240f, 0.287898394715485170f, + -0.957660960006330610f, + 0.287714760234765280f, -0.957716146226558870f, 0.287531115175595930f, + -0.957771297234302320f, + 0.287347459544729570f, -0.957826413027532910f, 0.287163793348918560f, + -0.957881493604224250f, + 0.286980116594915570f, -0.957936538962351420f, 0.286796429289474190f, + -0.957991549099890370f, + 0.286612731439347790f, -0.958046524014818600f, 0.286429023051290750f, + -0.958101463705114620f, + 0.286245304132057120f, -0.958156368168758820f, 0.286061574688402100f, + -0.958211237403732260f, + 0.285877834727080730f, -0.958266071408017670f, 0.285694084254848320f, + -0.958320870179598880f, + 0.285510323278461380f, -0.958375633716461170f, 0.285326551804675810f, + -0.958430362016591040f, + 0.285142769840248720f, -0.958485055077976100f, 0.284958977391937150f, + -0.958539712898605730f, + 0.284775174466498300f, -0.958594335476470220f, 0.284591361070690550f, + -0.958648922809561040f, + 0.284407537211271820f, -0.958703474895871600f, 0.284223702895001100f, + -0.958757991733395710f, + 0.284039858128637360f, -0.958812473320129200f, 0.283856002918939750f, + -0.958866919654069010f, + 0.283672137272668550f, -0.958921330733213060f, 0.283488261196583550f, + -0.958975706555561080f, + 0.283304374697445790f, -0.959030047119113550f, 0.283120477782015990f, + -0.959084352421872730f, + 0.282936570457055390f, -0.959138622461841890f, 0.282752652729326040f, + -0.959192857237025740f, + 0.282568724605589740f, -0.959247056745430090f, 0.282384786092609420f, + -0.959301220985062210f, + 0.282200837197147500f, -0.959355349953930790f, 0.282016877925967690f, + -0.959409443650045550f, + 0.281832908285833460f, -0.959463502071417510f, 0.281648928283508680f, + -0.959517525216059260f, + 0.281464937925758050f, -0.959571513081984520f, 0.281280937219346110f, + -0.959625465667208300f, + 0.281096926171038320f, -0.959679382969746750f, 0.280912904787600120f, + -0.959733264987617680f, + 0.280728873075797190f, -0.959787111718839900f, 0.280544831042396360f, + -0.959840923161433660f, + 0.280360778694163810f, -0.959894699313420530f, 0.280176716037867040f, + -0.959948440172823210f, + 0.279992643080273380f, -0.960002145737665850f, 0.279808559828150390f, + -0.960055816005973890f, + 0.279624466288266700f, -0.960109450975773940f, 0.279440362467390510f, + -0.960163050645094000f, + 0.279256248372291240f, -0.960216615011963430f, 0.279072124009737970f, + -0.960270144074412800f, + 0.278887989386500280f, -0.960323637830473920f, 0.278703844509348600f, + -0.960377096278180130f, + 0.278519689385053060f, -0.960430519415565790f, 0.278335524020384970f, + -0.960483907240666790f, + 0.278151348422115090f, -0.960537259751520050f, 0.277967162597015430f, + -0.960590576946164120f, + 0.277782966551857800f, -0.960643858822638470f, 0.277598760293414290f, + -0.960697105378984450f, + 0.277414543828458200f, -0.960750316613243950f, 0.277230317163762120f, + -0.960803492523460760f, + 0.277046080306099950f, -0.960856633107679660f, 0.276861833262245390f, + -0.960909738363946770f, + 0.276677576038972420f, -0.960962808290309780f, 0.276493308643056100f, + -0.961015842884817230f, + 0.276309031081271030f, -0.961068842145519350f, 0.276124743360392890f, + -0.961121806070467380f, + 0.275940445487197320f, -0.961174734657714080f, 0.275756137468460120f, + -0.961227627905313460f, + 0.275571819310958250f, -0.961280485811320640f, 0.275387491021468140f, + -0.961333308373792270f, + 0.275203152606767370f, -0.961386095590786250f, 0.275018804073633380f, + -0.961438847460361570f, + 0.274834445428843940f, -0.961491563980579000f, 0.274650076679177790f, + -0.961544245149499990f, + 0.274465697831413220f, -0.961596890965187860f, 0.274281308892329710f, + -0.961649501425706820f, + 0.274096909868706330f, -0.961702076529122540f, 0.273912500767323320f, + -0.961754616273502010f, + 0.273728081594960650f, -0.961807120656913540f, 0.273543652358398730f, + -0.961859589677426570f, + 0.273359213064418790f, -0.961912023333112100f, 0.273174763719801870f, + -0.961964421622042320f, + 0.272990304331329980f, -0.962016784542290560f, 0.272805834905784920f, + -0.962069112091931580f, + 0.272621355449948980f, -0.962121404269041580f, 0.272436865970605350f, + -0.962173661071697770f, + 0.272252366474536660f, -0.962225882497979020f, 0.272067856968526980f, + -0.962278068545965090f, + 0.271883337459359890f, -0.962330219213737400f, 0.271698807953819510f, + -0.962382334499378380f, + 0.271514268458690810f, -0.962434414400971990f, 0.271329718980758420f, + -0.962486458916603450f, + 0.271145159526808070f, -0.962538468044359160f, 0.270960590103625330f, + -0.962590441782326780f, + 0.270776010717996010f, -0.962642380128595710f, 0.270591421376707050f, + -0.962694283081255930f, + 0.270406822086544820f, -0.962746150638399410f, 0.270222212854296930f, + -0.962797982798119010f, + 0.270037593686750510f, -0.962849779558509030f, 0.269852964590693910f, + -0.962901540917665000f, + 0.269668325572915200f, -0.962953266873683880f, 0.269483676640202840f, + -0.963004957424663850f, + 0.269299017799346230f, -0.963056612568704340f, 0.269114349057134330f, + -0.963108232303906190f, + 0.268929670420357310f, -0.963159816628371360f, 0.268744981895805090f, + -0.963211365540203480f, + 0.268560283490267890f, -0.963262879037507070f, 0.268375575210537010f, + -0.963314357118388090f, + 0.268190857063403180f, -0.963365799780954050f, 0.268006129055658350f, + -0.963417207023313350f, + 0.267821391194094320f, -0.963468578843575950f, 0.267636643485503090f, + -0.963519915239853140f, + 0.267451885936677740f, -0.963571216210257210f, 0.267267118554410930f, + -0.963622481752902220f, + 0.267082341345496350f, -0.963673711865903230f, 0.266897554316727510f, + -0.963724906547376410f, + 0.266712757474898420f, -0.963776065795439840f, 0.266527950826803810f, + -0.963827189608212340f, + 0.266343134379238180f, -0.963878277983814200f, 0.266158308138997050f, + -0.963929330920367140f, + 0.265973472112875530f, -0.963980348415994110f, 0.265788626307669970f, + -0.964031330468819280f, + 0.265603770730176440f, -0.964082277076968140f, 0.265418905387191260f, + -0.964133188238567640f, + 0.265234030285511900f, -0.964184063951745720f, 0.265049145431935200f, + -0.964234904214632200f, + 0.264864250833259320f, -0.964285709025357370f, 0.264679346496282050f, + -0.964336478382053720f, + 0.264494432427801630f, -0.964387212282854290f, 0.264309508634617220f, + -0.964437910725893910f, + 0.264124575123527490f, -0.964488573709308410f, 0.263939631901332410f, + -0.964539201231235150f, + 0.263754678974831510f, -0.964589793289812650f, 0.263569716350824880f, + -0.964640349883180930f, + 0.263384744036113390f, -0.964690871009480920f, 0.263199762037497560f, + -0.964741356666855340f, + 0.263014770361779060f, -0.964791806853447900f, 0.262829769015759330f, + -0.964842221567403510f, + 0.262644758006240100f, -0.964892600806868890f, 0.262459737340024090f, + -0.964942944569991410f, + 0.262274707023913590f, -0.964993252854920320f, 0.262089667064712100f, + -0.965043525659805890f, + 0.261904617469222560f, -0.965093762982799590f, 0.261719558244249080f, + -0.965143964822054450f, + 0.261534489396595630f, -0.965194131175724720f, 0.261349410933066350f, + -0.965244262041965780f, + 0.261164322860466590f, -0.965294357418934660f, 0.260979225185601020f, + -0.965344417304789370f, + 0.260794117915275570f, -0.965394441697689400f, 0.260609001056295920f, + -0.965444430595795430f, + 0.260423874615468010f, -0.965494383997269500f, 0.260238738599598950f, + -0.965544301900275070f, + 0.260053593015495130f, -0.965594184302976830f, 0.259868437869964330f, + -0.965644031203540590f, + 0.259683273169813930f, -0.965693842600133690f, 0.259498098921851660f, + -0.965743618490924830f, + 0.259312915132886350f, -0.965793358874083570f, 0.259127721809726150f, + -0.965843063747781510f, + 0.258942518959180580f, -0.965892733110190860f, 0.258757306588058840f, + -0.965942366959485540f, + 0.258572084703170390f, -0.965991965293840570f, 0.258386853311325710f, + -0.966041528111432400f, + 0.258201612419334870f, -0.966091055410438830f, 0.258016362034009070f, + -0.966140547189038750f, + 0.257831102162158930f, -0.966190003445412620f, 0.257645832810596440f, + -0.966239424177741890f, + 0.257460553986133210f, -0.966288809384209580f, 0.257275265695581120f, + -0.966338159063000130f, + 0.257089967945753230f, -0.966387473212298790f, 0.256904660743461850f, + -0.966436751830292650f, + 0.256719344095520720f, -0.966485994915169840f, 0.256534018008743200f, + -0.966535202465119700f, + 0.256348682489942910f, -0.966584374478333120f, 0.256163337545934570f, + -0.966633510953002100f, + 0.255977983183532380f, -0.966682611887320190f, 0.255792619409551670f, + -0.966731677279481840f, + 0.255607246230807550f, -0.966780707127683270f, 0.255421863654115460f, + -0.966829701430121810f, + 0.255236471686291820f, -0.966878660184995910f, 0.255051070334152530f, + -0.966927583390505660f, + 0.254865659604514630f, -0.966976471044852070f, 0.254680239504194990f, + -0.967025323146237900f, + 0.254494810040010790f, -0.967074139692867040f, 0.254309371218780110f, + -0.967122920682944360f, + 0.254123923047320620f, -0.967171666114676640f, 0.253938465532451140f, + -0.967220375986271310f, + 0.253752998680989940f, -0.967269050295937790f, 0.253567522499756610f, + -0.967317689041886310f, + 0.253382036995570270f, -0.967366292222328510f, 0.253196542175250560f, + -0.967414859835477480f, + 0.253011038045617980f, -0.967463391879547440f, 0.252825524613492610f, + -0.967511888352754150f, + 0.252640001885695580f, -0.967560349253314360f, 0.252454469869047900f, + -0.967608774579446380f, + 0.252268928570370810f, -0.967657164329369880f, 0.252083377996486560f, + -0.967705518501305480f, + 0.251897818154216910f, -0.967753837093475510f, 0.251712249050384750f, + -0.967802120104103270f, + 0.251526670691812780f, -0.967850367531413620f, 0.251341083085323880f, + -0.967898579373632660f, + 0.251155486237742030f, -0.967946755628987800f, 0.250969880155890720f, + -0.967994896295707670f, + 0.250784264846594550f, -0.968043001372022260f, 0.250598640316677830f, + -0.968091070856162970f, + 0.250413006572965280f, -0.968139104746362330f, 0.250227363622282540f, + -0.968187103040854420f, + 0.250041711471454650f, -0.968235065737874320f, 0.249856050127308050f, + -0.968282992835658660f, + 0.249670379596668520f, -0.968330884332445300f, 0.249484699886363010f, + -0.968378740226473300f, + 0.249299011003218300f, -0.968426560515983190f, 0.249113312954061360f, + -0.968474345199216820f, + 0.248927605745720260f, -0.968522094274417270f, 0.248741889385022420f, + -0.968569807739828930f, + 0.248556163878796620f, -0.968617485593697540f, 0.248370429233871150f, + -0.968665127834269950f, + 0.248184685457074780f, -0.968712734459794780f, 0.247998932555237220f, + -0.968760305468521430f, + 0.247813170535187620f, -0.968807840858700970f, 0.247627399403756330f, + -0.968855340628585580f, + 0.247441619167773440f, -0.968902804776428870f, 0.247255829834069320f, + -0.968950233300485800f, + 0.247070031409475370f, -0.968997626199012310f, 0.246884223900822430f, + -0.969044983470266240f, + 0.246698407314942500f, -0.969092305112506100f, 0.246512581658667380f, + -0.969139591123992280f, + 0.246326746938829060f, -0.969186841502985950f, 0.246140903162260640f, + -0.969234056247750050f, + 0.245955050335794590f, -0.969281235356548530f, 0.245769188466264670f, + -0.969328378827646660f, + 0.245583317560504000f, -0.969375486659311280f, 0.245397437625346990f, + -0.969422558849810320f, + 0.245211548667627680f, -0.969469595397412950f, 0.245025650694180470f, + -0.969516596300390000f, + 0.244839743711840750f, -0.969563561557013180f, 0.244653827727443320f, + -0.969610491165555870f, + 0.244467902747824210f, -0.969657385124292450f, 0.244281968779819170f, + -0.969704243431498750f, + 0.244096025830264210f, -0.969751066085452140f, 0.243910073905996370f, + -0.969797853084430890f, + 0.243724113013852130f, -0.969844604426714830f, 0.243538143160669180f, + -0.969891320110585100f, + 0.243352164353284880f, -0.969938000134323960f, 0.243166176598536930f, + -0.969984644496215240f, + 0.242980179903263980f, -0.970031253194543970f, 0.242794174274304190f, + -0.970077826227596420f, + 0.242608159718496890f, -0.970124363593660280f, 0.242422136242681050f, + -0.970170865291024360f, + 0.242236103853696040f, -0.970217331317979160f, 0.242050062558382180f, + -0.970263761672816140f, + 0.241864012363579210f, -0.970310156353828110f, 0.241677953276128090f, + -0.970356515359309450f, + 0.241491885302869300f, -0.970402838687555500f, 0.241305808450644390f, + -0.970449126336863090f, + 0.241119722726294730f, -0.970495378305530450f, 0.240933628136661910f, + -0.970541594591857070f, + 0.240747524688588540f, -0.970587775194143630f, 0.240561412388916620f, + -0.970633920110692160f, + 0.240375291244489500f, -0.970680029339806130f, 0.240189161262150040f, + -0.970726102879790110f, + 0.240003022448741500f, -0.970772140728950350f, 0.239816874811108110f, + -0.970818142885593870f, + 0.239630718356093560f, -0.970864109348029470f, 0.239444553090542720f, + -0.970910040114567050f, + 0.239258379021300120f, -0.970955935183517970f, 0.239072196155210660f, + -0.971001794553194690f, + 0.238886004499120170f, -0.971047618221911100f, 0.238699804059873950f, + -0.971093406187982460f, + 0.238513594844318500f, -0.971139158449725090f, 0.238327376859299970f, + -0.971184875005457030f, + 0.238141150111664870f, -0.971230555853497380f, 0.237954914608260650f, + -0.971276200992166490f, + 0.237768670355934210f, -0.971321810419786160f, 0.237582417361533650f, + -0.971367384134679490f, + 0.237396155631906550f, -0.971412922135170940f, 0.237209885173901620f, + -0.971458424419585960f, + 0.237023605994367340f, -0.971503890986251780f, 0.236837318100152380f, + -0.971549321833496630f, + 0.236651021498106460f, -0.971594716959650160f, 0.236464716195078750f, + -0.971640076363043390f, + 0.236278402197919620f, -0.971685400042008540f, 0.236092079513479050f, + -0.971730687994879160f, + 0.235905748148607370f, -0.971775940219990140f, 0.235719408110155930f, + -0.971821156715677700f, + 0.235533059404975460f, -0.971866337480279400f, 0.235346702039917920f, + -0.971911482512134000f, + 0.235160336021834860f, -0.971956591809581600f, 0.234973961357578310f, + -0.972001665370963890f, + 0.234787578054001080f, -0.972046703194623380f, 0.234601186117955550f, + -0.972091705278904430f, + 0.234414785556295250f, -0.972136671622152120f, 0.234228376375873380f, + -0.972181602222713440f, + 0.234041958583543460f, -0.972226497078936270f, 0.233855532186159950f, + -0.972271356189170040f, + 0.233669097190576820f, -0.972316179551765300f, 0.233482653603649170f, + -0.972360967165074140f, + 0.233296201432231560f, -0.972405719027449770f, 0.233109740683179740f, + -0.972450435137246830f, + 0.232923271363349120f, -0.972495115492821190f, 0.232736793479595420f, + -0.972539760092530180f, + 0.232550307038775330f, -0.972584368934732210f, 0.232363812047745010f, + -0.972628942017787270f, + 0.232177308513361770f, -0.972673479340056430f, 0.231990796442482580f, + -0.972717980899902250f, + 0.231804275841964780f, -0.972762446695688570f, 0.231617746718666580f, + -0.972806876725780370f, + 0.231431209079445730f, -0.972851270988544180f, 0.231244662931161110f, + -0.972895629482347760f, + 0.231058108280671280f, -0.972939952205560070f, 0.230871545134835070f, + -0.972984239156551740f, + 0.230684973500512310f, -0.973028490333694100f, 0.230498393384562320f, + -0.973072705735360530f, + 0.230311804793845530f, -0.973116885359925130f, 0.230125207735222020f, + -0.973161029205763530f, + 0.229938602215552260f, -0.973205137271252800f, 0.229751988241697600f, + -0.973249209554771120f, + 0.229565365820518870f, -0.973293246054698250f, 0.229378734958878120f, + -0.973337246769414800f, + 0.229192095663636740f, -0.973381211697303290f, 0.229005447941657390f, + -0.973425140836747030f, + 0.228818791799802360f, -0.973469034186130950f, 0.228632127244934230f, + -0.973512891743841370f, + 0.228445454283916550f, -0.973556713508265560f, 0.228258772923612350f, + -0.973600499477792370f, + 0.228072083170885790f, -0.973644249650811870f, 0.227885385032600700f, + -0.973687964025715670f, + 0.227698678515621170f, -0.973731642600896400f, 0.227511963626812390f, + -0.973775285374748000f, + 0.227325240373038830f, -0.973818892345666100f, 0.227138508761166260f, + -0.973862463512047300f, + 0.226951768798059980f, -0.973905998872289460f, 0.226765020490585720f, + -0.973949498424792170f, + 0.226578263845610110f, -0.973992962167955830f, 0.226391498869999210f, + -0.974036390100182610f, + 0.226204725570620270f, -0.974079782219875680f, 0.226017943954340190f, + -0.974123138525439520f, + 0.225831154028026200f, -0.974166459015280320f, 0.225644355798546440f, + -0.974209743687805110f, + 0.225457549272768540f, -0.974252992541422500f, 0.225270734457561240f, + -0.974296205574542330f, + 0.225083911359792780f, -0.974339382785575860f, 0.224897079986332540f, + -0.974382524172935470f, + 0.224710240344049570f, -0.974425629735034990f, 0.224523392439813170f, + -0.974468699470289580f, + 0.224336536280493690f, -0.974511733377115720f, 0.224149671872960840f, + -0.974554731453931230f, + 0.223962799224085520f, -0.974597693699155050f, 0.223775918340738290f, + -0.974640620111207560f, + 0.223589029229790020f, -0.974683510688510670f, 0.223402131898112480f, + -0.974726365429487320f, + 0.223215226352576960f, -0.974769184332561770f, 0.223028312600055870f, + -0.974811967396159830f, + 0.222841390647421280f, -0.974854714618708430f, 0.222654460501545550f, + -0.974897425998635820f, + 0.222467522169301990f, -0.974940101534371720f, 0.222280575657563370f, + -0.974982741224347140f, + 0.222093620973203590f, -0.975025345066994120f, 0.221906658123096260f, + -0.975067913060746360f, + 0.221719687114115240f, -0.975110445204038890f, 0.221532707953135340f, + -0.975152941495307620f, + 0.221345720647030810f, -0.975195401932990370f, 0.221158725202677100f, + -0.975237826515525820f, + 0.220971721626949060f, -0.975280215241354220f, 0.220784709926722670f, + -0.975322568108916930f, + 0.220597690108873650f, -0.975364885116656870f, 0.220410662180277940f, + -0.975407166263018270f, + 0.220223626147812460f, -0.975449411546446380f, 0.220036582018353550f, + -0.975491620965388110f, + 0.219849529798778750f, -0.975533794518291360f, 0.219662469495965180f, + -0.975575932203605610f, + 0.219475401116790340f, -0.975618034019781750f, 0.219288324668132580f, + -0.975660099965271590f, + 0.219101240156869770f, -0.975702130038528570f, 0.218914147589880900f, + -0.975744124238007270f, + 0.218727046974044600f, -0.975786082562163930f, 0.218539938316239830f, + -0.975828005009455550f, + 0.218352821623346430f, -0.975869891578341030f, 0.218165696902243770f, + -0.975911742267280170f, + 0.217978564159812290f, -0.975953557074734300f, 0.217791423402932120f, + -0.975995335999165880f, + 0.217604274638483670f, -0.976037079039039020f, 0.217417117873348300f, + -0.976078786192818850f, + 0.217229953114406790f, -0.976120457458971910f, 0.217042780368541080f, + -0.976162092835966110f, + 0.216855599642632570f, -0.976203692322270560f, 0.216668410943563790f, + -0.976245255916355800f, + 0.216481214278216900f, -0.976286783616693630f, 0.216294009653474370f, + -0.976328275421757260f, + 0.216106797076219600f, -0.976369731330021140f, 0.215919576553335460f, + -0.976411151339961040f, + 0.215732348091705940f, -0.976452535450054060f, 0.215545111698214660f, + -0.976493883658778540f, + 0.215357867379745550f, -0.976535195964614470f, 0.215170615143183500f, + -0.976576472366042610f, + 0.214983354995412820f, -0.976617712861545640f, 0.214796086943318920f, + -0.976658917449606980f, + 0.214608810993786920f, -0.976700086128711840f, 0.214421527153702190f, + -0.976741218897346550f, + 0.214234235429951100f, -0.976782315753998650f, 0.214046935829419330f, + -0.976823376697157240f, + 0.213859628358993830f, -0.976864401725312640f, 0.213672313025561140f, + -0.976905390836956490f, + 0.213484989836008080f, -0.976946344030581560f, 0.213297658797222430f, + -0.976987261304682390f, + 0.213110319916091360f, -0.977028142657754390f, 0.212922973199503260f, + -0.977068988088294450f, + 0.212735618654345870f, -0.977109797594800880f, 0.212548256287508120f, + -0.977150571175773200f, + 0.212360886105878580f, -0.977191308829712280f, 0.212173508116346080f, + -0.977232010555120320f, + 0.211986122325800410f, -0.977272676350500860f, 0.211798728741130820f, + -0.977313306214358750f, + 0.211611327369227610f, -0.977353900145199960f, 0.211423918216980810f, + -0.977394458141532250f, + 0.211236501291280710f, -0.977434980201864260f, 0.211049076599018500f, + -0.977475466324706050f, + 0.210861644147084830f, -0.977515916508569280f, 0.210674203942371490f, + -0.977556330751966460f, + 0.210486755991769890f, -0.977596709053411780f, 0.210299300302171750f, + -0.977637051411420770f, + 0.210111836880469720f, -0.977677357824509930f, 0.209924365733555860f, + -0.977717628291197570f, + 0.209736886868323370f, -0.977757862810002760f, 0.209549400291665110f, + -0.977798061379446360f, + 0.209361906010474190f, -0.977838223998050430f, 0.209174404031644700f, + -0.977878350664338150f, + 0.208986894362070070f, -0.977918441376834370f, 0.208799377008644980f, + -0.977958496134064830f, + 0.208611851978263460f, -0.977998514934557140f, 0.208424319277820650f, + -0.978038497776839600f, + 0.208236778914211470f, -0.978078444659442380f, 0.208049230894330940f, + -0.978118355580896660f, + 0.207861675225075150f, -0.978158230539735050f, 0.207674111913339540f, + -0.978198069534491400f, + 0.207486540966020700f, -0.978237872563701090f, 0.207298962390014880f, + -0.978277639625900420f, + 0.207111376192218560f, -0.978317370719627650f, 0.206923782379529210f, + -0.978357065843421640f, + 0.206736180958843660f, -0.978396724995823090f, 0.206548571937059940f, + -0.978436348175373730f, + 0.206360955321075680f, -0.978475935380616830f, 0.206173331117788770f, + -0.978515486610096910f, + 0.205985699334098050f, -0.978555001862359550f, 0.205798059976901760f, + -0.978594481135952270f, + 0.205610413053099320f, -0.978633924429423100f, 0.205422758569589780f, + -0.978673331741322210f, + 0.205235096533272380f, -0.978712703070200420f, 0.205047426951047380f, + -0.978752038414610340f, + 0.204859749829814420f, -0.978791337773105670f, 0.204672065176474290f, + -0.978830601144241470f, + 0.204484372997927180f, -0.978869828526574120f, 0.204296673301074430f, + -0.978909019918661310f, + 0.204108966092817010f, -0.978948175319062200f, 0.203921251380056150f, + -0.978987294726337050f, + 0.203733529169694010f, -0.979026378139047580f, 0.203545799468632190f, + -0.979065425555756930f, + 0.203358062283773370f, -0.979104436975029250f, 0.203170317622019920f, + -0.979143412395430230f, + 0.202982565490274460f, -0.979182351815526930f, 0.202794805895440550f, + -0.979221255233887700f, + 0.202607038844421110f, -0.979260122649082020f, 0.202419264344120220f, + -0.979298954059681040f, + 0.202231482401441620f, -0.979337749464256780f, 0.202043693023289280f, + -0.979376508861383170f, + 0.201855896216568160f, -0.979415232249634780f, 0.201668091988182500f, + -0.979453919627588210f, + 0.201480280345037820f, -0.979492570993820700f, 0.201292461294039190f, + -0.979531186346911390f, + 0.201104634842091960f, -0.979569765685440520f, 0.200916800996102370f, + -0.979608309007989450f, + 0.200728959762976140f, -0.979646816313141210f, 0.200541111149620090f, + -0.979685287599479930f, + 0.200353255162940420f, -0.979723722865591170f, 0.200165391809844500f, + -0.979762122110061640f, + 0.199977521097239290f, -0.979800485331479680f, 0.199789643032032120f, + -0.979838812528434740f, + 0.199601757621131050f, -0.979877103699517640f, 0.199413864871443750f, + -0.979915358843320480f, + 0.199225964789878890f, -0.979953577958436740f, 0.199038057383344820f, + -0.979991761043461200f, + 0.198850142658750120f, -0.980029908096989980f, 0.198662220623004320f, + -0.980068019117620650f, + 0.198474291283016360f, -0.980106094103951770f, 0.198286354645696270f, + -0.980144133054583590f, + 0.198098410717953730f, -0.980182135968117320f, 0.197910459506698720f, + -0.980220102843155970f, + 0.197722501018842030f, -0.980258033678303550f, 0.197534535261294000f, + -0.980295928472165290f, + 0.197346562240966000f, -0.980333787223347960f, 0.197158581964769040f, + -0.980371609930459690f, + 0.196970594439614370f, -0.980409396592109910f, 0.196782599672414240f, + -0.980447147206909060f, + 0.196594597670080220f, -0.980484861773469380f, 0.196406588439525050f, + -0.980522540290404090f, + 0.196218571987660850f, -0.980560182756327950f, 0.196030548321400880f, + -0.980597789169856850f, + 0.195842517447657990f, -0.980635359529608120f, 0.195654479373345370f, + -0.980672893834200530f, + 0.195466434105377090f, -0.980710392082253970f, 0.195278381650666520f, + -0.980747854272389750f, + 0.195090322016128330f, -0.980785280403230430f, 0.194902255208676660f, + -0.980822670473399990f, + 0.194714181235225990f, -0.980860024481523870f, 0.194526100102691720f, + -0.980897342426228390f, + 0.194338011817988600f, -0.980934624306141640f, 0.194149916388032530f, + -0.980971870119892840f, + 0.193961813819739010f, -0.981009079866112630f, 0.193773704120023840f, + -0.981046253543432780f, + 0.193585587295803750f, -0.981083391150486590f, 0.193397463353994740f, + -0.981120492685908730f, + 0.193209332301514080f, -0.981157558148334830f, 0.193021194145278320f, + -0.981194587536402320f, + 0.192833048892205290f, -0.981231580848749730f, 0.192644896549212240f, + -0.981268538084016710f, + 0.192456737123216840f, -0.981305459240844670f, 0.192268570621137590f, + -0.981342344317875930f, + 0.192080397049892380f, -0.981379193313754560f, 0.191892216416400310f, + -0.981416006227125550f, + 0.191704028727579940f, -0.981452783056635520f, 0.191515833990350240f, + -0.981489523800932130f, + 0.191327632211630990f, -0.981526228458664660f, 0.191139423398341420f, + -0.981562897028483650f, + 0.190951207557401860f, -0.981599529509040720f, 0.190762984695732250f, + -0.981636125898989080f, + 0.190574754820252800f, -0.981672686196983110f, 0.190386517937884580f, + -0.981709210401678800f, + 0.190198274055548120f, -0.981745698511732990f, 0.190010023180165050f, + -0.981782150525804310f, + 0.189821765318656580f, -0.981818566442552500f, 0.189633500477944220f, + -0.981854946260638630f, + 0.189445228664950340f, -0.981891289978724990f, 0.189256949886596720f, + -0.981927597595475540f, + 0.189068664149806280f, -0.981963869109555240f, 0.188880371461501330f, + -0.982000104519630490f, + 0.188692071828605260f, -0.982036303824369020f, 0.188503765258041080f, + -0.982072467022439890f, + 0.188315451756732120f, -0.982108594112513610f, 0.188127131331602530f, + -0.982144685093261580f, + 0.187938803989575850f, -0.982180739963357200f, 0.187750469737576840f, + -0.982216758721474510f, + 0.187562128582529740f, -0.982252741366289370f, 0.187373780531359110f, + -0.982288687896478830f, + 0.187185425590990440f, -0.982324598310721160f, 0.186997063768348510f, + -0.982360472607696210f, + 0.186808695070359330f, -0.982396310786084690f, 0.186620319503948420f, + -0.982432112844569110f, + 0.186431937076041640f, -0.982467878781833170f, 0.186243547793565670f, + -0.982503608596561720f, + 0.186055151663446630f, -0.982539302287441240f, 0.185866748692611720f, + -0.982574959853159240f, + 0.185678338887987790f, -0.982610581292404750f, 0.185489922256501900f, + -0.982646166603868050f, + 0.185301498805082040f, -0.982681715786240860f, 0.185113068540655510f, + -0.982717228838215990f, + 0.184924631470150870f, -0.982752705758487830f, 0.184736187600495930f, + -0.982788146545751970f, + 0.184547736938619640f, -0.982823551198705240f, 0.184359279491450640f, + -0.982858919716046110f, + 0.184170815265917720f, -0.982894252096474070f, 0.183982344268950600f, + -0.982929548338690060f, + 0.183793866507478390f, -0.982964808441396440f, 0.183605381988431350f, + -0.983000032403296590f, + 0.183416890718739230f, -0.983035220223095640f, 0.183228392705332140f, + -0.983070371899499640f, + 0.183039887955141060f, -0.983105487431216290f, 0.182851376475096310f, + -0.983140566816954500f, + 0.182662858272129360f, -0.983175610055424420f, 0.182474333353171260f, + -0.983210617145337640f, + 0.182285801725153320f, -0.983245588085407070f, 0.182097263395007760f, + -0.983280522874346970f, + 0.181908718369666160f, -0.983315421510872810f, 0.181720166656061170f, + -0.983350283993701500f, + 0.181531608261125130f, -0.983385110321551180f, 0.181343043191790590f, + -0.983419900493141540f, + 0.181154471454990920f, -0.983454654507193270f, 0.180965893057658980f, + -0.983489372362428730f, + 0.180777308006728670f, -0.983524054057571260f, 0.180588716309133280f, + -0.983558699591345900f, + 0.180400117971807270f, -0.983593308962478650f, 0.180211513001684590f, + -0.983627882169697210f, + 0.180022901405699510f, -0.983662419211730250f, 0.179834283190787180f, + -0.983696920087308020f, + 0.179645658363882100f, -0.983731384795162090f, 0.179457026931919950f, + -0.983765813334025240f, + 0.179268388901835880f, -0.983800205702631490f, 0.179079744280565390f, + -0.983834561899716630f, + 0.178891093075044830f, -0.983868881924017220f, 0.178702435292209940f, + -0.983903165774271500f, + 0.178513770938997590f, -0.983937413449218920f, 0.178325100022344140f, + -0.983971624947600270f, + 0.178136422549186320f, -0.984005800268157870f, 0.177947738526461670f, + -0.984039939409634970f, + 0.177759047961107140f, -0.984074042370776450f, 0.177570350860060790f, + -0.984108109150328540f, + 0.177381647230260200f, -0.984142139747038570f, 0.177192937078643310f, + -0.984176134159655320f, + 0.177004220412148860f, -0.984210092386929030f, 0.176815497237715000f, + -0.984244014427611110f, + 0.176626767562280960f, -0.984277900280454370f, 0.176438031392785350f, + -0.984311749944212780f, + 0.176249288736167940f, -0.984345563417641900f, 0.176060539599367960f, + -0.984379340699498510f, + 0.175871783989325040f, -0.984413081788540700f, 0.175683021912979580f, + -0.984446786683527920f, + 0.175494253377271400f, -0.984480455383220930f, 0.175305478389141370f, + -0.984514087886381840f, + 0.175116696955530060f, -0.984547684191773960f, 0.174927909083378160f, + -0.984581244298162180f, + 0.174739114779627310f, -0.984614768204312600f, 0.174550314051218490f, + -0.984648255908992630f, + 0.174361506905093830f, -0.984681707410970940f, 0.174172693348194960f, + -0.984715122709017620f, + 0.173983873387463850f, -0.984748501801904210f, 0.173795047029843270f, + -0.984781844688403350f, + 0.173606214282275410f, -0.984815151367289140f, 0.173417375151703520f, + -0.984848421837337010f, + 0.173228529645070490f, -0.984881656097323700f, 0.173039677769319390f, + -0.984914854146027200f, + 0.172850819531394200f, -0.984948015982227030f, 0.172661954938238270f, + -0.984981141604703960f, + 0.172473083996796030f, -0.985014231012239840f, 0.172284206714011350f, + -0.985047284203618200f, + 0.172095323096829040f, -0.985080301177623800f, 0.171906433152193700f, + -0.985113281933042590f, + 0.171717536887049970f, -0.985146226468662230f, 0.171528634308343500f, + -0.985179134783271020f, + 0.171339725423019260f, -0.985212006875659460f, 0.171150810238023340f, + -0.985244842744618540f, + 0.170961888760301360f, -0.985277642388941220f, 0.170772960996799230f, + -0.985310405807421570f, + 0.170584026954463700f, -0.985343132998854790f, 0.170395086640240920f, + -0.985375823962037710f, + 0.170206140061078120f, -0.985408478695768420f, 0.170017187223922090f, + -0.985441097198846210f, + 0.169828228135719880f, -0.985473679470071810f, 0.169639262803419400f, + -0.985506225508247290f, + 0.169450291233967930f, -0.985538735312176060f, 0.169261313434313890f, + -0.985571208880662740f, + 0.169072329411405180f, -0.985603646212513400f, 0.168883339172190010f, + -0.985636047306535420f, + 0.168694342723617440f, -0.985668412161537550f, 0.168505340072635900f, + -0.985700740776329850f, + 0.168316331226194910f, -0.985733033149723490f, 0.168127316191243350f, + -0.985765289280531310f, + 0.167938294974731230f, -0.985797509167567370f, 0.167749267583608030f, + -0.985829692809647050f, + 0.167560234024823590f, -0.985861840205586980f, 0.167371194305328540f, + -0.985893951354205210f, + 0.167182148432072880f, -0.985926026254321130f, 0.166993096412007770f, + -0.985958064904755460f, + 0.166804038252083870f, -0.985990067304330030f, 0.166614973959252090f, + -0.986022033451868560f, + 0.166425903540464220f, -0.986053963346195440f, 0.166236827002671390f, + -0.986085856986136820f, + 0.166047744352825850f, -0.986117714370520090f, 0.165858655597879430f, + -0.986149535498173860f, + 0.165669560744784140f, -0.986181320367928270f, 0.165480459800492890f, + -0.986213068978614490f, + 0.165291352771957970f, -0.986244781329065460f, 0.165102239666132720f, + -0.986276457418114980f, + 0.164913120489970090f, -0.986308097244598670f, 0.164723995250423190f, + -0.986339700807353000f, + 0.164534863954446110f, -0.986371268105216030f, 0.164345726608992190f, + -0.986402799137027220f, + 0.164156583221015890f, -0.986434293901627070f, 0.163967433797471110f, + -0.986465752397857940f, + 0.163778278345312690f, -0.986497174624562880f, 0.163589116871495160f, + -0.986528560580586690f, + 0.163399949382973230f, -0.986559910264775410f, 0.163210775886702460f, + -0.986591223675976400f, + 0.163021596389637810f, -0.986622500813038480f, 0.162832410898735260f, + -0.986653741674811350f, + 0.162643219420950450f, -0.986684946260146690f, 0.162454021963239190f, + -0.986716114567897100f, + 0.162264818532558110f, -0.986747246596916480f, 0.162075609135863330f, + -0.986778342346060430f, + 0.161886393780111910f, -0.986809401814185420f, 0.161697172472260540f, + -0.986840425000149680f, + 0.161507945219266150f, -0.986871411902812470f, 0.161318712028086540f, + -0.986902362521034470f, + 0.161129472905678780f, -0.986933276853677710f, 0.160940227859001140f, + -0.986964154899605650f, + 0.160750976895011390f, -0.986994996657682870f, 0.160561720020667510f, + -0.987025802126775600f, + 0.160372457242928400f, -0.987056571305750970f, 0.160183188568752240f, + -0.987087304193477900f, + 0.159993914005098350f, -0.987118000788826280f, 0.159804633558925380f, + -0.987148661090667570f, + 0.159615347237193090f, -0.987179285097874340f, 0.159426055046860750f, + -0.987209872809320820f, + 0.159236756994887850f, -0.987240424223882250f, 0.159047453088234840f, + -0.987270939340435420f, + 0.158858143333861390f, -0.987301418157858430f, 0.158668827738728370f, + -0.987331860675030430f, + 0.158479506309796100f, -0.987362266890832400f, 0.158290179054025180f, + -0.987392636804146240f, + 0.158100845978377090f, -0.987422970413855410f, 0.157911507089812640f, + -0.987453267718844560f, + 0.157722162395293690f, -0.987483528717999710f, 0.157532811901781670f, + -0.987513753410208420f, + 0.157343455616238280f, -0.987543941794359230f, 0.157154093545626010f, + -0.987574093869342360f, + 0.156964725696906750f, -0.987604209634049160f, 0.156775352077043430f, + -0.987634289087372160f, + 0.156585972692998590f, -0.987664332228205710f, 0.156396587551734940f, + -0.987694339055445130f, + 0.156207196660216040f, -0.987724309567986960f, 0.156017800025404830f, + -0.987754243764729530f, + 0.155828397654265320f, -0.987784141644572180f, 0.155638989553760850f, + -0.987814003206415550f, + 0.155449575730855880f, -0.987843828449161740f, 0.155260156192514380f, + -0.987873617371714200f, + 0.155070730945700510f, -0.987903369972977790f, 0.154881299997379400f, + -0.987933086251858380f, + 0.154691863354515400f, -0.987962766207263420f, 0.154502421024073990f, + -0.987992409838101880f, + 0.154312973013020240f, -0.988022017143283530f, 0.154123519328319360f, + -0.988051588121720110f, + 0.153934059976937460f, -0.988081122772324070f, 0.153744594965840000f, + -0.988110621094009820f, + 0.153555124301993500f, -0.988140083085692570f, 0.153365647992364020f, + -0.988169508746289060f, + 0.153176166043917870f, -0.988198898074717610f, 0.152986678463622160f, + -0.988228251069897420f, + 0.152797185258443410f, -0.988257567730749460f, 0.152607686435349140f, + -0.988286848056195710f, + 0.152418182001306500f, -0.988316092045159690f, 0.152228671963282770f, + -0.988345299696566150f, + 0.152039156328246160f, -0.988374471009341280f, 0.151849635103164180f, + -0.988403605982412390f, + 0.151660108295005400f, -0.988432704614708340f, 0.151470575910737760f, + -0.988461766905159300f, + 0.151281037957330250f, -0.988490792852696590f, 0.151091494441751430f, + -0.988519782456253270f, + 0.150901945370970040f, -0.988548735714763200f, 0.150712390751955720f, + -0.988577652627162020f, + 0.150522830591677370f, -0.988606533192386450f, 0.150333264897105050f, + -0.988635377409374790f, + 0.150143693675208330f, -0.988664185277066230f, 0.149954116932956990f, + -0.988692956794401940f, + 0.149764534677321620f, -0.988721691960323780f, 0.149574946915272210f, + -0.988750390773775360f, + 0.149385353653779810f, -0.988779053233701520f, 0.149195754899814960f, + -0.988807679339048340f, + 0.149006150660348470f, -0.988836269088763540f, 0.148816540942352030f, + -0.988864822481795640f, + 0.148626925752796540f, -0.988893339517095130f, 0.148437305098654050f, + -0.988921820193613190f, + 0.148247678986896200f, -0.988950264510302990f, 0.148058047424494740f, + -0.988978672466118480f, + 0.147868410418422360f, -0.989007044060015270f, 0.147678767975650970f, + -0.989035379290950310f, + 0.147489120103153680f, -0.989063678157881540f, 0.147299466807902820f, + -0.989091940659768800f, + 0.147109808096871850f, -0.989120166795572690f, 0.146920143977033760f, + -0.989148356564255590f, + 0.146730474455361750f, -0.989176509964781010f, 0.146540799538829870f, + -0.989204626996113780f, + 0.146351119234411440f, -0.989232707657220050f, 0.146161433549080950f, + -0.989260751947067640f, + 0.145971742489812370f, -0.989288759864625170f, 0.145782046063579860f, + -0.989316731408863000f, + 0.145592344277358450f, -0.989344666578752640f, 0.145402637138122540f, + -0.989372565373267010f, + 0.145212924652847520f, -0.989400427791380380f, 0.145023206828508360f, + -0.989428253832068230f, + 0.144833483672080240f, -0.989456043494307710f, 0.144643755190539150f, + -0.989483796777076760f, + 0.144454021390860440f, -0.989511513679355190f, 0.144264282280020530f, + -0.989539194200123930f, + 0.144074537864995330f, -0.989566838338365120f, 0.143884788152761010f, + -0.989594446093062460f, + 0.143695033150294580f, -0.989622017463200780f, 0.143505272864572290f, + -0.989649552447766530f, + 0.143315507302571590f, -0.989677051045747210f, 0.143125736471269140f, + -0.989704513256131850f, + 0.142935960377642700f, -0.989731939077910570f, 0.142746179028669620f, + -0.989759328510075200f, + 0.142556392431327340f, -0.989786681551618640f, 0.142366600592594260f, + -0.989813998201535260f, + 0.142176803519448000f, -0.989841278458820530f, 0.141987001218867340f, + -0.989868522322471580f, + 0.141797193697830530f, -0.989895729791486660f, 0.141607380963316020f, + -0.989922900864865450f, + 0.141417563022303130f, -0.989950035541608990f, 0.141227739881770480f, + -0.989977133820719610f, + 0.141037911548697770f, -0.990004195701200910f, 0.140848078030064220f, + -0.990031221182058000f, + 0.140658239332849240f, -0.990058210262297120f, 0.140468395464033110f, + -0.990085162940925970f, + 0.140278546430595420f, -0.990112079216953770f, 0.140088692239516780f, + -0.990138959089390650f, + 0.139898832897777380f, -0.990165802557248400f, 0.139708968412357580f, + -0.990192609619540030f, + 0.139519098790238600f, -0.990219380275280000f, 0.139329224038400980f, + -0.990246114523483990f, + 0.139139344163826280f, -0.990272812363169110f, 0.138949459173495440f, + -0.990299473793353590f, + 0.138759569074390380f, -0.990326098813057330f, 0.138569673873492640f, + -0.990352687421301340f, + 0.138379773577783890f, -0.990379239617108160f, 0.138189868194246640f, + -0.990405755399501260f, + 0.137999957729862760f, -0.990432234767505970f, 0.137810042191615130f, + -0.990458677720148620f, + 0.137620121586486180f, -0.990485084256456980f, 0.137430195921458550f, + -0.990511454375460290f, + 0.137240265203515700f, -0.990537788076188750f, 0.137050329439640380f, + -0.990564085357674370f, + 0.136860388636816430f, -0.990590346218950150f, 0.136670442802027230f, + -0.990616570659050620f, + 0.136480491942256310f, -0.990642758677011570f, 0.136290536064488070f, + -0.990668910271869980f, + 0.136100575175706200f, -0.990695025442664630f, 0.135910609282895440f, + -0.990721104188435180f, + 0.135720638393040080f, -0.990747146508222710f, 0.135530662513124620f, + -0.990773152401069780f, + 0.135340681650134330f, -0.990799121866020370f, 0.135150695811053850f, + -0.990825054902119470f, + 0.134960705002868830f, -0.990850951508413620f, 0.134770709232564290f, + -0.990876811683950810f, + 0.134580708507126220f, -0.990902635427780010f, 0.134390702833540240f, + -0.990928422738951990f, + 0.134200692218792020f, -0.990954173616518500f, 0.134010676669868210f, + -0.990979888059532740f, + 0.133820656193754690f, -0.991005566067049370f, 0.133630630797438390f, + -0.991031207638124130f, + 0.133440600487905820f, -0.991056812771814340f, 0.133250565272143570f, + -0.991082381467178640f, + 0.133060525157139180f, -0.991107913723276780f, 0.132870480149879400f, + -0.991133409539170170f, + 0.132680430257352130f, -0.991158868913921350f, 0.132490375486544710f, + -0.991184291846594180f, + 0.132300315844444680f, -0.991209678336254060f, 0.132110251338040470f, + -0.991235028381967420f, + 0.131920181974319760f, -0.991260341982802440f, 0.131730107760271280f, + -0.991285619137828200f, + 0.131540028702883280f, -0.991310859846115440f, 0.131349944809144220f, + -0.991336064106736140f, + 0.131159856086043410f, -0.991361231918763460f, 0.130969762540569380f, + -0.991386363281272280f, + 0.130779664179711790f, -0.991411458193338540f, 0.130589561010459600f, + -0.991436516654039420f, + 0.130399453039802740f, -0.991461538662453790f, 0.130209340274730770f, + -0.991486524217661480f, + 0.130019222722233350f, -0.991511473318743900f, 0.129829100389301010f, + -0.991536385964783880f, + 0.129638973282923540f, -0.991561262154865290f, 0.129448841410091830f, + -0.991586101888073500f, + 0.129258704777796270f, -0.991610905163495370f, 0.129068563393027410f, + -0.991635671980218740f, + 0.128878417262776660f, -0.991660402337333210f, 0.128688266394034690f, + -0.991685096233929530f, + 0.128498110793793220f, -0.991709753669099530f, 0.128307950469043590f, + -0.991734374641936810f, + 0.128117785426777150f, -0.991758959151536110f, 0.127927615673986190f, + -0.991783507196993490f, + 0.127737441217662280f, -0.991808018777406430f, 0.127547262064798050f, + -0.991832493891873780f, + 0.127357078222385570f, -0.991856932539495360f, 0.127166889697417180f, + -0.991881334719373010f, + 0.126976696496885980f, -0.991905700430609330f, 0.126786498627784430f, + -0.991930029672308480f, + 0.126596296097105960f, -0.991954322443575950f, 0.126406088911843320f, + -0.991978578743518580f, + 0.126215877078990400f, -0.992002798571244520f, 0.126025660605540460f, + -0.992026981925863360f, + 0.125835439498487020f, -0.992051128806485720f, 0.125645213764824380f, + -0.992075239212224070f, + 0.125454983411546210f, -0.992099313142191800f, 0.125264748445647110f, + -0.992123350595503720f, + 0.125074508874121300f, -0.992147351571276090f, 0.124884264703963150f, + -0.992171316068626520f, + 0.124694015942167770f, -0.992195244086673920f, 0.124503762595729650f, + -0.992219135624538450f, + 0.124313504671644300f, -0.992242990681341700f, 0.124123242176906760f, + -0.992266809256206580f, + 0.123932975118512200f, -0.992290591348257370f, 0.123742703503456630f, + -0.992314336956619640f, + 0.123552427338735370f, -0.992338046080420420f, 0.123362146631344750f, + -0.992361718718787870f, + 0.123171861388280650f, -0.992385354870851670f, 0.122981571616539080f, + -0.992408954535742850f, + 0.122791277323116900f, -0.992432517712593550f, 0.122600978515010240f, + -0.992456044400537700f, + 0.122410675199216280f, -0.992479534598709970f, 0.122220367382731500f, + -0.992502988306246950f, + 0.122030055072553410f, -0.992526405522286100f, 0.121839738275679020f, + -0.992549786245966570f, + 0.121649416999105540f, -0.992573130476428810f, 0.121459091249830950f, + -0.992596438212814290f, + 0.121268761034852550f, -0.992619709454266140f, 0.121078426361168710f, + -0.992642944199928820f, + 0.120888087235777220f, -0.992666142448948020f, 0.120697743665676120f, + -0.992689304200470750f, + 0.120507395657864240f, -0.992712429453645460f, 0.120317043219339670f, + -0.992735518207621850f, + 0.120126686357101580f, -0.992758570461551140f, 0.119936325078148620f, + -0.992781586214585570f, + 0.119745959389479630f, -0.992804565465879140f, 0.119555589298094230f, + -0.992827508214586760f, + 0.119365214810991350f, -0.992850414459865100f, 0.119174835935170960f, + -0.992873284200871730f, + 0.118984452677632520f, -0.992896117436765980f, 0.118794065045375670f, + -0.992918914166708300f, + 0.118603673045400840f, -0.992941674389860470f, 0.118413276684707770f, + -0.992964398105385610f, + 0.118222875970297250f, -0.992987085312448390f, 0.118032470909169300f, + -0.993009736010214580f, + 0.117842061508325020f, -0.993032350197851410f, 0.117651647774765000f, + -0.993054927874527320f, + 0.117461229715489990f, -0.993077469039412300f, 0.117270807337501560f, + -0.993099973691677570f, + 0.117080380647800550f, -0.993122441830495580f, 0.116889949653388850f, + -0.993144873455040430f, + 0.116699514361267840f, -0.993167268564487230f, 0.116509074778439050f, + -0.993189627158012620f, + 0.116318630911904880f, -0.993211949234794500f, 0.116128182768666920f, + -0.993234234794012290f, + 0.115937730355727850f, -0.993256483834846440f, 0.115747273680089870f, + -0.993278696356479030f, + 0.115556812748755290f, -0.993300872358093280f, 0.115366347568727250f, + -0.993323011838873950f, + 0.115175878147008180f, -0.993345114798006910f, 0.114985404490601530f, + -0.993367181234679600f, + 0.114794926606510250f, -0.993389211148080650f, 0.114604444501737460f, + -0.993411204537400060f, + 0.114413958183287050f, -0.993433161401829360f, 0.114223467658162260f, + -0.993455081740560960f, + 0.114032972933367300f, -0.993476965552789190f, 0.113842474015905660f, + -0.993498812837709360f, + 0.113651970912781920f, -0.993520623594518090f, 0.113461463631000080f, + -0.993542397822413600f, + 0.113270952177564360f, -0.993564135520595300f, 0.113080436559479720f, + -0.993585836688263950f, + 0.112889916783750470f, -0.993607501324621610f, 0.112699392857381910f, + -0.993629129428871720f, + 0.112508864787378830f, -0.993650721000219120f, 0.112318332580746190f, + -0.993672276037870010f, + 0.112127796244489750f, -0.993693794541031680f, 0.111937255785614560f, + -0.993715276508913230f, + 0.111746711211126660f, -0.993736721940724600f, 0.111556162528031630f, + -0.993758130835677430f, + 0.111365609743335190f, -0.993779503192984580f, 0.111175052864043830f, + -0.993800839011860120f, + 0.110984491897163380f, -0.993822138291519660f, 0.110793926849700630f, + -0.993843401031180180f, + 0.110603357728661910f, -0.993864627230059750f, 0.110412784541053660f, + -0.993885816887378090f, + 0.110222207293883180f, -0.993906970002356060f, 0.110031625994157000f, + -0.993928086574215830f, + 0.109841040648882680f, -0.993949166602181130f, 0.109650451265067080f, + -0.993970210085476920f, + 0.109459857849718030f, -0.993991217023329380f, 0.109269260409842920f, + -0.994012187414966220f, + 0.109078658952449240f, -0.994033121259616400f, 0.108888053484545310f, + -0.994054018556510210f, + 0.108697444013138670f, -0.994074879304879370f, 0.108506830545237980f, + -0.994095703503956930f, + 0.108316213087851300f, -0.994116491152977070f, 0.108125591647986880f, + -0.994137242251175720f, + 0.107934966232653760f, -0.994157956797789730f, 0.107744336848860260f, + -0.994178634792057590f, + 0.107553703503615710f, -0.994199276233218910f, 0.107363066203928920f, + -0.994219881120514850f, + 0.107172424956808870f, -0.994240449453187900f, 0.106981779769265340f, + -0.994260981230481790f, + 0.106791130648307380f, -0.994281476451641550f, 0.106600477600945030f, + -0.994301935115913580f, + 0.106409820634187840f, -0.994322357222545810f, 0.106219159755045520f, + -0.994342742770787270f, + 0.106028494970528530f, -0.994363091759888570f, 0.105837826287646670f, + -0.994383404189101430f, + 0.105647153713410700f, -0.994403680057679100f, 0.105456477254830660f, + -0.994423919364875950f, + 0.105265796918917650f, -0.994444122109948040f, 0.105075112712682180f, + -0.994464288292152390f, + 0.104884424643134970f, -0.994484417910747600f, 0.104693732717287500f, + -0.994504510964993590f, + 0.104503036942150550f, -0.994524567454151740f, 0.104312337324735870f, + -0.994544587377484300f, + 0.104121633872054730f, -0.994564570734255420f, 0.103930926591118540f, + -0.994584517523730340f, + 0.103740215488939480f, -0.994604427745175660f, 0.103549500572529040f, + -0.994624301397859400f, + 0.103358781848899700f, -0.994644138481050710f, 0.103168059325063390f, + -0.994663938994020280f, + 0.102977333008032250f, -0.994683702936040250f, 0.102786602904819150f, + -0.994703430306383860f, + 0.102595869022436280f, -0.994723121104325700f, 0.102405131367896790f, + -0.994742775329142010f, + 0.102214389948213370f, -0.994762392980109930f, 0.102023644770398800f, + -0.994781974056508260f, + 0.101832895841466670f, -0.994801518557617110f, 0.101642143168429830f, + -0.994821026482717860f, + 0.101451386758302160f, -0.994840497831093180f, 0.101260626618096800f, + -0.994859932602027320f, + 0.101069862754827880f, -0.994879330794805620f, 0.100879095175509010f, + -0.994898692408714870f, + 0.100688323887153970f, -0.994918017443043200f, 0.100497548896777310f, + -0.994937305897080070f, + 0.100306770211392820f, -0.994956557770116380f, 0.100115987838015370f, + -0.994975773061444140f, + 0.099925201783659226f, -0.994994951770357020f, 0.099734412055338839f, + -0.995014093896149700f, + 0.099543618660069444f, -0.995033199438118630f, 0.099352821604865513f, + -0.995052268395561160f, + 0.099162020896742573f, -0.995071300767776170f, 0.098971216542715582f, + -0.995090296554063890f, + 0.098780408549799664f, -0.995109255753726110f, 0.098589596925010708f, + -0.995128178366065490f, + 0.098398781675363881f, -0.995147064390386470f, 0.098207962807875346f, + -0.995165913825994620f, + 0.098017140329560770f, -0.995184726672196820f, 0.097826314247435903f, + -0.995203502928301510f, + 0.097635484568517339f, -0.995222242593618240f, 0.097444651299820870f, + -0.995240945667458130f, + 0.097253814448363354f, -0.995259612149133390f, 0.097062974021160875f, + -0.995278242037957670f, + 0.096872130025230527f, -0.995296835333246090f, 0.096681282467588864f, + -0.995315392034315070f, + 0.096490431355252607f, -0.995333912140482280f, 0.096299576695239225f, + -0.995352395651066810f, + 0.096108718494565468f, -0.995370842565388990f, 0.095917856760249096f, + -0.995389252882770690f, + 0.095726991499307315f, -0.995407626602534900f, 0.095536122718757485f, + -0.995425963724006160f, + 0.095345250425617742f, -0.995444264246510340f, 0.095154374626905472f, + -0.995462528169374420f, + 0.094963495329639061f, -0.995480755491926940f, 0.094772612540836410f, + -0.995498946213497770f, + 0.094581726267515473f, -0.995517100333418110f, 0.094390836516695067f, + -0.995535217851020390f, + 0.094199943295393190f, -0.995553298765638470f, 0.094009046610628907f, + -0.995571343076607770f, + 0.093818146469420494f, -0.995589350783264600f, 0.093627242878787237f, + -0.995607321884947050f, + 0.093436335845747912f, -0.995625256380994310f, 0.093245425377321389f, + -0.995643154270746900f, + 0.093054511480527333f, -0.995661015553546910f, 0.092863594162384697f, + -0.995678840228737540f, + 0.092672673429913366f, -0.995696628295663520f, 0.092481749290132753f, + -0.995714379753670610f, + 0.092290821750062355f, -0.995732094602106430f, 0.092099890816722485f, + -0.995749772840319400f, + 0.091908956497132696f, -0.995767414467659820f, 0.091718018798313525f, + -0.995785019483478750f, + 0.091527077727284981f, -0.995802587887129160f, 0.091336133291067212f, + -0.995820119677964910f, + 0.091145185496681130f, -0.995837614855341610f, 0.090954234351146898f, + -0.995855073418615790f, + 0.090763279861485704f, -0.995872495367145730f, 0.090572322034718156f, + -0.995889880700290720f, + 0.090381360877865011f, -0.995907229417411720f, 0.090190396397947820f, + -0.995924541517870690f, + 0.089999428601987341f, -0.995941817001031350f, 0.089808457497005362f, + -0.995959055866258320f, + 0.089617483090022917f, -0.995976258112917790f, 0.089426505388062016f, + -0.995993423740377360f, + 0.089235524398144139f, -0.996010552748005870f, 0.089044540127290905f, + -0.996027645135173610f, + 0.088853552582524684f, -0.996044700901251970f, 0.088662561770867121f, + -0.996061720045614000f, + 0.088471567699340822f, -0.996078702567633980f, 0.088280570374967879f, + -0.996095648466687300f, + 0.088089569804770507f, -0.996112557742151130f, 0.087898565995771685f, + -0.996129430393403740f, + 0.087707558954993645f, -0.996146266419824620f, 0.087516548689459586f, + -0.996163065820794950f, + 0.087325535206192226f, -0.996179828595696870f, 0.087134518512214321f, + -0.996196554743914220f, + 0.086943498614549489f, -0.996213244264832040f, 0.086752475520220515f, + -0.996229897157836500f, + 0.086561449236251239f, -0.996246513422315520f, 0.086370419769664919f, + -0.996263093057658030f, + 0.086179387127484922f, -0.996279636063254650f, 0.085988351316735448f, + -0.996296142438496850f, + 0.085797312344439880f, -0.996312612182778000f, 0.085606270217622613f, + -0.996329045295492380f, + 0.085415224943307277f, -0.996345441776035900f, 0.085224176528518519f, + -0.996361801623805720f, + 0.085033124980280414f, -0.996378124838200210f, 0.084842070305617148f, + -0.996394411418619290f, + 0.084651012511553700f, -0.996410661364464100f, 0.084459951605114297f, + -0.996426874675137240f, + 0.084268887593324127f, -0.996443051350042630f, 0.084077820483207846f, + -0.996459191388585410f, + 0.083886750281790226f, -0.996475294790172160f, 0.083695676996096827f, + -0.996491361554210920f, + 0.083504600633152404f, -0.996507391680110820f, 0.083313521199982740f, + -0.996523385167282450f, + 0.083122438703613077f, -0.996539342015137940f, 0.082931353151068726f, + -0.996555262223090540f, + 0.082740264549375803f, -0.996571145790554840f, 0.082549172905559659f, + -0.996586992716946950f, + 0.082358078226646619f, -0.996602803001684130f, 0.082166980519662466f, + -0.996618576644185070f, + 0.081975879791633108f, -0.996634313643869900f, 0.081784776049585201f, + -0.996650014000160070f, + 0.081593669300544638f, -0.996665677712478160f, 0.081402559551538328f, + -0.996681304780248300f, + 0.081211446809592386f, -0.996696895202896060f, 0.081020331081733912f, + -0.996712448979848010f, + 0.080829212374989468f, -0.996727966110532490f, 0.080638090696385709f, + -0.996743446594378860f, + 0.080446966052950097f, -0.996758890430818000f, 0.080255838451709291f, + -0.996774297619282050f, + 0.080064707899690932f, -0.996789668159204560f, 0.079873574403922148f, + -0.996805002050020320f, + 0.079682437971430126f, -0.996820299291165670f, 0.079491298609242866f, + -0.996835559882078170f, + 0.079300156324387569f, -0.996850783822196610f, 0.079109011123892431f, + -0.996865971110961310f, + 0.078917863014785095f, -0.996881121747813850f, 0.078726712004093313f, + -0.996896235732197210f, + 0.078535558098845590f, -0.996911313063555740f, 0.078344401306069678f, + -0.996926353741335090f, + 0.078153241632794315f, -0.996941357764982160f, 0.077962079086047645f, + -0.996956325133945280f, + 0.077770913672857989f, -0.996971255847674320f, 0.077579745400254363f, + -0.996986149905620180f, + 0.077388574275265049f, -0.997001007307235290f, 0.077197400304919297f, + -0.997015828051973310f, + 0.077006223496245585f, -0.997030612139289450f, 0.076815043856273399f, + -0.997045359568640040f, + 0.076623861392031617f, -0.997060070339482960f, 0.076432676110549283f, + -0.997074744451277310f, + 0.076241488018856149f, -0.997089381903483400f, 0.076050297123981231f, + -0.997103982695563330f, + 0.075859103432954503f, -0.997118546826979980f, 0.075667906952805383f, + -0.997133074297198110f, + 0.075476707690563416f, -0.997147565105683480f, 0.075285505653258880f, + -0.997162019251903290f, + 0.075094300847921291f, -0.997176436735326190f, 0.074903093281581137f, + -0.997190817555421940f, + 0.074711882961268378f, -0.997205161711661850f, 0.074520669894013014f, + -0.997219469203518670f, + 0.074329454086845867f, -0.997233740030466160f, 0.074138235546796952f, + -0.997247974191979860f, + 0.073947014280897269f, -0.997262171687536170f, 0.073755790296177265f, + -0.997276332516613180f, + 0.073564563599667454f, -0.997290456678690210f, 0.073373334198399157f, + -0.997304544173247990f, + 0.073182102099402888f, -0.997318594999768600f, 0.072990867309710133f, + -0.997332609157735470f, + 0.072799629836351618f, -0.997346586646633230f, 0.072608389686359048f, + -0.997360527465947940f, + 0.072417146866763538f, -0.997374431615167030f, 0.072225901384596336f, + -0.997388299093779460f, + 0.072034653246889416f, -0.997402129901275300f, 0.071843402460674000f, + -0.997415924037145960f, + 0.071652149032982254f, -0.997429681500884180f, 0.071460892970845832f, + -0.997443402291984360f, + 0.071269634281296415f, -0.997457086409941910f, 0.071078372971366502f, + -0.997470733854253670f, + 0.070887109048087787f, -0.997484344624417930f, 0.070695842518492924f, + -0.997497918719934210f, + 0.070504573389614009f, -0.997511456140303450f, 0.070313301668483263f, + -0.997524956885027960f, + 0.070122027362133646f, -0.997538420953611230f, 0.069930750477597295f, + -0.997551848345558430f, + 0.069739471021907376f, -0.997565239060375750f, 0.069548189002096472f, + -0.997578593097570800f, + 0.069356904425197236f, -0.997591910456652630f, 0.069165617298243109f, + -0.997605191137131640f, + 0.068974327628266732f, -0.997618435138519550f, 0.068783035422301728f, + -0.997631642460329320f, + 0.068591740687380900f, -0.997644813102075420f, 0.068400443430538069f, + -0.997657947063273710f, + 0.068209143658806454f, -0.997671044343441000f, 0.068017841379219388f, + -0.997684104942096030f, + 0.067826536598810966f, -0.997697128858758500f, 0.067635229324614451f, + -0.997710116092949570f, + 0.067443919563664106f, -0.997723066644191640f, 0.067252607322993652f, + -0.997735980512008620f, + 0.067061292609636836f, -0.997748857695925690f, 0.066869975430628226f, + -0.997761698195469560f, + 0.066678655793001543f, -0.997774502010167820f, 0.066487333703791507f, + -0.997787269139549960f, + 0.066296009170032283f, -0.997799999583146470f, 0.066104682198758091f, + -0.997812693340489280f, + 0.065913352797003930f, -0.997825350411111640f, 0.065722020971803977f, + -0.997837970794548280f, + 0.065530686730193397f, -0.997850554490335110f, 0.065339350079206798f, + -0.997863101498009500f, + 0.065148011025878860f, -0.997875611817110150f, 0.064956669577245010f, + -0.997888085447177110f, + 0.064765325740339871f, -0.997900522387751620f, 0.064573979522199065f, + -0.997912922638376610f, + 0.064382630929857410f, -0.997925286198596000f, 0.064191279970350679f, + -0.997937613067955250f, + 0.063999926650714078f, -0.997949903246001190f, 0.063808570977982898f, + -0.997962156732281950f, + 0.063617212959193190f, -0.997974373526346990f, 0.063425852601380200f, + -0.997986553627747020f, + 0.063234489911580136f, -0.997998697036034390f, 0.063043124896828631f, + -0.998010803750762450f, + 0.062851757564161420f, -0.998022873771486240f, 0.062660387920614985f, + -0.998034907097761770f, + 0.062469015973224969f, -0.998046903729146840f, 0.062277641729028041f, + -0.998058863665200250f, + 0.062086265195060247f, -0.998070786905482340f, 0.061894886378357744f, + -0.998082673449554590f, + 0.061703505285957416f, -0.998094523296980010f, 0.061512121924895365f, + -0.998106336447323050f, + 0.061320736302208648f, -0.998118112900149180f, 0.061129348424933755f, + -0.998129852655025520f, + 0.060937958300107238f, -0.998141555711520520f, 0.060746565934766412f, + -0.998153222069203650f, + 0.060555171335947781f, -0.998164851727646240f, 0.060363774510688827f, + -0.998176444686420530f, + 0.060172375466026218f, -0.998188000945100300f, 0.059980974208997596f, + -0.998199520503260660f, + 0.059789570746640007f, -0.998211003360478190f, 0.059598165085990598f, + -0.998222449516330550f, + 0.059406757234087247f, -0.998233858970396850f, 0.059215347197967026f, + -0.998245231722257880f, + 0.059023934984667986f, -0.998256567771495180f, 0.058832520601227581f, + -0.998267867117692110f, + 0.058641104054683348f, -0.998279129760433200f, 0.058449685352073573f, + -0.998290355699304350f, + 0.058258264500435732f, -0.998301544933892890f, 0.058066841506808263f, + -0.998312697463787260f, + 0.057875416378229017f, -0.998323813288577560f, 0.057683989121735932f, + -0.998334892407855000f, + 0.057492559744367684f, -0.998345934821212370f, 0.057301128253162144f, + -0.998356940528243420f, + 0.057109694655158132f, -0.998367909528543820f, 0.056918258957393907f, + -0.998378841821709990f, + 0.056726821166907783f, -0.998389737407340160f, 0.056535381290738825f, + -0.998400596285033640f, + 0.056343939335925283f, -0.998411418454391300f, 0.056152495309506383f, + -0.998422203915015020f, + 0.055961049218520520f, -0.998432952666508440f, 0.055769601070007072f, + -0.998443664708476340f, + 0.055578150871004817f, -0.998454340040524800f, 0.055386698628552604f, + -0.998464978662261250f, + 0.055195244349690031f, -0.998475580573294770f, 0.055003788041455885f, + -0.998486145773235360f, + 0.054812329710889909f, -0.998496674261694640f, 0.054620869365031251f, + -0.998507166038285490f, + 0.054429407010919147f, -0.998517621102622210f, 0.054237942655593556f, + -0.998528039454320230f, + 0.054046476306093640f, -0.998538421092996730f, 0.053855007969459509f, + -0.998548766018269920f, + 0.053663537652730679f, -0.998559074229759310f, 0.053472065362946755f, + -0.998569345727086110f, + 0.053280591107148056f, -0.998579580509872500f, 0.053089114892374119f, + -0.998589778577742230f, + 0.052897636725665401f, -0.998599939930320370f, 0.052706156614061798f, + -0.998610064567233340f, + 0.052514674564603257f, -0.998620152488108870f, 0.052323190584330471f, + -0.998630203692576050f, + 0.052131704680283317f, -0.998640218180265270f, 0.051940216859502626f, + -0.998650195950808280f, + 0.051748727129028414f, -0.998660137003838490f, 0.051557235495901653f, + -0.998670041338990070f, + 0.051365741967162731f, -0.998679908955899090f, 0.051174246549852087f, + -0.998689739854202620f, + 0.050982749251010900f, -0.998699534033539280f, 0.050791250077679546f, + -0.998709291493549030f, + 0.050599749036899337f, -0.998719012233872940f, 0.050408246135710995f, + -0.998728696254153720f, + 0.050216741381155325f, -0.998738343554035230f, 0.050025234780273840f, + -0.998747954133162860f, + 0.049833726340107257f, -0.998757527991183340f, 0.049642216067697226f, + -0.998767065127744380f, + 0.049450703970084824f, -0.998776565542495610f, 0.049259190054311168f, + -0.998786029235087640f, + 0.049067674327418126f, -0.998795456205172410f, 0.048876156796446746f, + -0.998804846452403420f, + 0.048684637468439020f, -0.998814199976435390f, 0.048493116350436342f, + -0.998823516776924380f, + 0.048301593449480172f, -0.998832796853527990f, 0.048110068772612716f, + -0.998842040205904840f, + 0.047918542326875327f, -0.998851246833715180f, 0.047727014119310344f, + -0.998860416736620520f, + 0.047535484156959261f, -0.998869549914283560f, 0.047343952446864526f, + -0.998878646366368690f, + 0.047152418996068000f, -0.998887706092541290f, 0.046960883811611599f, + -0.998896729092468410f, + 0.046769346900537960f, -0.998905715365818290f, 0.046577808269888908f, + -0.998914664912260440f, + 0.046386267926707213f, -0.998923577731465780f, 0.046194725878035046f, + -0.998932453823106690f, + 0.046003182130914644f, -0.998941293186856870f, 0.045811636692388955f, + -0.998950095822391250f, + 0.045620089569500123f, -0.998958861729386080f, 0.045428540769291224f, + -0.998967590907519300f, + 0.045236990298804750f, -0.998976283356469820f, 0.045045438165083225f, + -0.998984939075918010f, + 0.044853884375169933f, -0.998993558065545680f, 0.044662328936107311f, + -0.999002140325035980f, + 0.044470771854938744f, -0.999010685854073380f, 0.044279213138707016f, + -0.999019194652343460f, + 0.044087652794454979f, -0.999027666719533690f, 0.043896090829226200f, + -0.999036102055332330f, + 0.043704527250063421f, -0.999044500659429290f, 0.043512962064010327f, + -0.999052862531515930f, + 0.043321395278109784f, -0.999061187671284600f, 0.043129826899405595f, + -0.999069476078429330f, + 0.042938256934940959f, -0.999077727752645360f, 0.042746685391759139f, + -0.999085942693629270f, + 0.042555112276904117f, -0.999094120901079070f, 0.042363537597419038f, + -0.999102262374694130f, + 0.042171961360348002f, -0.999110367114174890f, 0.041980383572734502f, + -0.999118435119223490f, + 0.041788804241622082f, -0.999126466389543390f, 0.041597223374055005f, + -0.999134460924839150f, + 0.041405640977076712f, -0.999142418724816910f, 0.041214057057731589f, + -0.999150339789184110f, + 0.041022471623063397f, -0.999158224117649430f, 0.040830884680115968f, + -0.999166071709923000f, + 0.040639296235933854f, -0.999173882565716380f, 0.040447706297560768f, + -0.999181656684742350f, + 0.040256114872041358f, -0.999189394066714920f, 0.040064521966419686f, + -0.999197094711349880f, + 0.039872927587739845f, -0.999204758618363890f, 0.039681331743046659f, + -0.999212385787475290f, + 0.039489734439384118f, -0.999219976218403530f, 0.039298135683797149f, + -0.999227529910869610f, + 0.039106535483329839f, -0.999235046864595850f, 0.038914933845027241f, + -0.999242527079305830f, + 0.038723330775933762f, -0.999249970554724420f, 0.038531726283093877f, + -0.999257377290578060f, + 0.038340120373552791f, -0.999264747286594420f, 0.038148513054354856f, + -0.999272080542502610f, + 0.037956904332545366f, -0.999279377058032710f, 0.037765294215169005f, + -0.999286636832916740f, + 0.037573682709270514f, -0.999293859866887790f, 0.037382069821895340f, + -0.999301046159680070f, + 0.037190455560088091f, -0.999308195711029470f, 0.036998839930894332f, + -0.999315308520673070f, + 0.036807222941358991f, -0.999322384588349540f, 0.036615604598527057f, + -0.999329423913798420f, + 0.036423984909444228f, -0.999336426496761240f, 0.036232363881155374f, + -0.999343392336980220f, + 0.036040741520706299f, -0.999350321434199440f, 0.035849117835142184f, + -0.999357213788164000f, + 0.035657492831508264f, -0.999364069398620550f, 0.035465866516850478f, + -0.999370888265317060f, + 0.035274238898213947f, -0.999377670388002850f, 0.035082609982644702f, + -0.999384415766428560f, + 0.034890979777187955f, -0.999391124400346050f, 0.034699348288889847f, + -0.999397796289508640f, + 0.034507715524795889f, -0.999404431433671300f, 0.034316081491951658f, + -0.999411029832589780f, + 0.034124446197403423f, -0.999417591486021720f, 0.033932809648196623f, + -0.999424116393725640f, + 0.033741171851377642f, -0.999430604555461730f, 0.033549532813992221f, + -0.999437055970991530f, + 0.033357892543086159f, -0.999443470640077770f, 0.033166251045705968f, + -0.999449848562484530f, + 0.032974608328897315f, -0.999456189737977340f, 0.032782964399706793f, + -0.999462494166323160f, + 0.032591319265180385f, -0.999468761847290050f, 0.032399672932364114f, + -0.999474992780647780f, + 0.032208025408304704f, -0.999481186966166950f, 0.032016376700048046f, + -0.999487344403620080f, + 0.031824726814640963f, -0.999493465092780590f, 0.031633075759129645f, + -0.999499549033423640f, + 0.031441423540560343f, -0.999505596225325310f, 0.031249770165979990f, + -0.999511606668263440f, + 0.031058115642434700f, -0.999517580362016990f, 0.030866459976971503f, + -0.999523517306366350f, + 0.030674803176636581f, -0.999529417501093140f, 0.030483145248477058f, + -0.999535280945980540f, + 0.030291486199539423f, -0.999541107640812940f, 0.030099826036870208f, + -0.999546897585375960f, + 0.029908164767516655f, -0.999552650779456990f, 0.029716502398525156f, + -0.999558367222844300f, + 0.029524838936943035f, -0.999564046915327740f, 0.029333174389816984f, + -0.999569689856698580f, + 0.029141508764193740f, -0.999575296046749220f, 0.028949842067120746f, + -0.999580865485273700f, + 0.028758174305644590f, -0.999586398172067070f, 0.028566505486812797f, + -0.999591894106925950f, + 0.028374835617672258f, -0.999597353289648380f, 0.028183164705269902f, + -0.999602775720033530f, + 0.027991492756653365f, -0.999608161397882110f, 0.027799819778869434f, + -0.999613510322995950f, + 0.027608145778965820f, -0.999618822495178640f, 0.027416470763989606f, + -0.999624097914234570f, + 0.027224794740987910f, -0.999629336579970110f, 0.027033117717008563f, + -0.999634538492192300f, + 0.026841439699098527f, -0.999639703650710200f, 0.026649760694305708f, + -0.999644832055333610f, + 0.026458080709677145f, -0.999649923705874240f, 0.026266399752260809f, + -0.999654978602144690f, + 0.026074717829104040f, -0.999659996743959220f, 0.025883034947254208f, + -0.999664978131133310f, + 0.025691351113759395f, -0.999669922763483760f, 0.025499666335666818f, + -0.999674830640828740f, + 0.025307980620024630f, -0.999679701762987930f, 0.025116293973880335f, + -0.999684536129782140f, + 0.024924606404281485f, -0.999689333741033640f, 0.024732917918276334f, + -0.999694094596566000f, + 0.024541228522912264f, -0.999698818696204250f, 0.024349538225237600f, + -0.999703506039774650f, + 0.024157847032300020f, -0.999708156627104880f, 0.023966154951147241f, + -0.999712770458023870f, + 0.023774461988827676f, -0.999717347532362190f, 0.023582768152388880f, + -0.999721887849951310f, + 0.023391073448879338f, -0.999726391410624470f, 0.023199377885346890f, + -0.999730858214216030f, + 0.023007681468839410f, -0.999735288260561680f, 0.022815984206405477f, + -0.999739681549498660f, + 0.022624286105092803f, -0.999744038080865430f, 0.022432587171950024f, + -0.999748357854501780f, + 0.022240887414024919f, -0.999752640870248840f, 0.022049186838366180f, + -0.999756887127949080f, + 0.021857485452021874f, -0.999761096627446610f, 0.021665783262040089f, + -0.999765269368586450f, + 0.021474080275469605f, -0.999769405351215280f, 0.021282376499358355f, + -0.999773504575180990f, + 0.021090671940755180f, -0.999777567040332940f, 0.020898966606708289f, + -0.999781592746521670f, + 0.020707260504265912f, -0.999785581693599210f, 0.020515553640476986f, + -0.999789533881418780f, + 0.020323846022389572f, -0.999793449309835270f, 0.020132137657052664f, + -0.999797327978704690f, + 0.019940428551514598f, -0.999801169887884260f, 0.019748718712823757f, + -0.999804975037232870f, + 0.019557008148029204f, -0.999808743426610520f, 0.019365296864179146f, + -0.999812475055878780f, + 0.019173584868322699f, -0.999816169924900410f, 0.018981872167508348f, + -0.999819828033539420f, + 0.018790158768784596f, -0.999823449381661570f, 0.018598444679200642f, + -0.999827033969133420f, + 0.018406729905804820f, -0.999830581795823400f, 0.018215014455646376f, + -0.999834092861600960f, + 0.018023298335773701f, -0.999837567166337090f, 0.017831581553236088f, + -0.999841004709904000f, + 0.017639864115082195f, -0.999844405492175240f, 0.017448146028360704f, + -0.999847769513025900f, + 0.017256427300120978f, -0.999851096772332190f, 0.017064707937411529f, + -0.999854387269971890f, + 0.016872987947281773f, -0.999857641005823860f, 0.016681267336780482f, + -0.999860857979768540f, + 0.016489546112956454f, -0.999864038191687680f, 0.016297824282859176f, + -0.999867181641464380f, + 0.016106101853537263f, -0.999870288328982950f, 0.015914378832040249f, + -0.999873358254129260f, + 0.015722655225417017f, -0.999876391416790410f, 0.015530931040716478f, + -0.999879387816854930f, + 0.015339206284988220f, -0.999882347454212560f, 0.015147480965280975f, + -0.999885270328754520f, + 0.014955755088644378f, -0.999888156440373320f, 0.014764028662127416f, + -0.999891005788962950f, + 0.014572301692779104f, -0.999893818374418490f, 0.014380574187649138f, + -0.999896594196636680f, + 0.014188846153786343f, -0.999899333255515390f, 0.013997117598240459f, + -0.999902035550953920f, + 0.013805388528060349f, -0.999904701082852900f, 0.013613658950295789f, + -0.999907329851114300f, + 0.013421928871995907f, -0.999909921855641540f, 0.013230198300209845f, + -0.999912477096339240f, + 0.013038467241987433f, -0.999914995573113470f, 0.012846735704377631f, + -0.999917477285871770f, + 0.012655003694430301f, -0.999919922234522750f, 0.012463271219194662f, + -0.999922330418976490f, + 0.012271538285719944f, -0.999924701839144500f, 0.012079804901056066f, + -0.999927036494939640f, + 0.011888071072252072f, -0.999929334386276070f, 0.011696336806357907f, + -0.999931595513069200f, + 0.011504602110422875f, -0.999933819875236000f, 0.011312866991496287f, + -0.999936007472694620f, + 0.011121131456628141f, -0.999938158305364590f, 0.010929395512867561f, + -0.999940272373166960f, + 0.010737659167264572f, -0.999942349676023910f, 0.010545922426868548f, + -0.999944390213859060f, + 0.010354185298728884f, -0.999946393986597460f, 0.010162447789895645f, + -0.999948360994165400f, + 0.009970709907418029f, -0.999950291236490480f, 0.009778971658346134f, + -0.999952184713501780f, + 0.009587233049729183f, -0.999954041425129780f, 0.009395494088617302f, + -0.999955861371306100f, + 0.009203754782059960f, -0.999957644551963900f, 0.009012015137106642f, + -0.999959390967037450f, + 0.008820275160807512f, -0.999961100616462820f, 0.008628534860211857f, + -0.999962773500176930f, + 0.008436794242369860f, -0.999964409618118280f, 0.008245053314331058f, + -0.999966008970226920f, + 0.008053312083144991f, -0.999967571556443780f, 0.007861570555861883f, + -0.999969097376711580f, + 0.007669828739531077f, -0.999970586430974140f, 0.007478086641202815f, + -0.999972038719176730f, + 0.007286344267926684f, -0.999973454241265940f, 0.007094601626752279f, + -0.999974832997189810f, + 0.006902858724729877f, -0.999976174986897610f, 0.006711115568908869f, + -0.999977480210339940f, + 0.006519372166339549f, -0.999978748667468830f, 0.006327628524071549f, + -0.999979980358237650f, + 0.006135884649154515f, -0.999981175282601110f, 0.005944140548638765f, + -0.999982333440515350f, + 0.005752396229573737f, -0.999983454831937730f, 0.005560651699009764f, + -0.999984539456826970f, + 0.005368906963996303f, -0.999985587315143200f, 0.005177162031583702f, + -0.999986598406848000f, + 0.004985416908821652f, -0.999987572731904080f, 0.004793671602759852f, + -0.999988510290275690f, + 0.004601926120448672f, -0.999989411081928400f, 0.004410180468937601f, + -0.999990275106828920f, + 0.004218434655277024f, -0.999991102364945590f, 0.004026688686516664f, + -0.999991892856248010f, + 0.003834942569706248f, -0.999992646580707190f, 0.003643196311896179f, + -0.999993363538295150f, + 0.003451449920135975f, -0.999994043728985820f, 0.003259703401476044f, + -0.999994687152754080f, + 0.003067956762966138f, -0.999995293809576190f, 0.002876210011656010f, + -0.999995863699429940f, + 0.002684463154596083f, -0.999996396822294350f, 0.002492716198835898f, + -0.999996893178149880f, + 0.002300969151425887f, -0.999997352766978210f, 0.002109222019415816f, + -0.999997775588762350f, + 0.001917474809855460f, -0.999998161643486980f, 0.001725727529795258f, + -0.999998510931137790f, + 0.001533980186284766f, -0.999998823451701880f, 0.001342232786374430f, + -0.999999099205167830f, + 0.001150485337113809f, -0.999999338191525530f, 0.000958737845553352f, + -0.999999540410766110f, + 0.000766990318742846f, -0.999999705862882230f, 0.000575242763732077f, + -0.999999834547867670f, + 0.000383495187571497f, -0.999999926465717890f, 0.000191747597310674f, + -0.999999981616429330f +}; + +/** +* \par +* cosFactor tables are generated using the formula :
cos_factors[n] = 2 * cos((2n+1)*pi/(4*N))
+* \par +* C command to generate the table +* \par +*
 for(i = 0; i< N; i++)
+* {
+*    cos_factors[i]= 2 * cos((2*i+1)*c/2);
+* } 
+* \par +* where N is the number of factors to generate and c is pi/(2*N) +*/ +static const float32_t cos_factors_128[128] = { + 0.999981175282601110f, 0.999830581795823400f, 0.999529417501093140f, + 0.999077727752645360f, + 0.998475580573294770f, 0.997723066644191640f, 0.996820299291165670f, + 0.995767414467659820f, + 0.994564570734255420f, 0.993211949234794500f, 0.991709753669099530f, + 0.990058210262297120f, + 0.988257567730749460f, 0.986308097244598670f, 0.984210092386929030f, + 0.981963869109555240f, + 0.979569765685440520f, 0.977028142657754390f, 0.974339382785575860f, + 0.971503890986251780f, + 0.968522094274417380f, 0.965394441697689400f, 0.962121404269041580f, + 0.958703474895871600f, + 0.955141168305770780f, 0.951435020969008340f, 0.947585591017741090f, + 0.943593458161960390f, + 0.939459223602189920f, 0.935183509938947610f, 0.930766961078983710f, + 0.926210242138311380f, + 0.921514039342042010f, 0.916679059921042700f, 0.911706032005429880f, + 0.906595704514915330f, + 0.901348847046022030f, 0.895966249756185220f, 0.890448723244757880f, + 0.884797098430937790f, + 0.879012226428633530f, 0.873094978418290090f, 0.867046245515692650f, + 0.860866938637767310f, + 0.854557988365400530f, 0.848120344803297230f, 0.841554977436898440f, + 0.834862874986380010f, + 0.828045045257755800f, 0.821102514991104650f, 0.814036329705948410f, + 0.806847553543799330f, + 0.799537269107905010f, 0.792106577300212390f, 0.784556597155575240f, + 0.776888465673232440f, + 0.769103337645579700f, 0.761202385484261780f, 0.753186799043612520f, + 0.745057785441466060f, + 0.736816568877369900f, 0.728464390448225200f, 0.720002507961381650f, + 0.711432195745216430f, + 0.702754744457225300f, 0.693971460889654000f, 0.685083667772700360f, + 0.676092703575316030f, + 0.666999922303637470f, 0.657806693297078640f, 0.648514401022112550f, + 0.639124444863775730f, + 0.629638238914927100f, 0.620057211763289210f, 0.610382806276309480f, + 0.600616479383868970f, + 0.590759701858874280f, 0.580813958095764530f, 0.570780745886967370f, + 0.560661576197336030f, + 0.550457972936604810f, 0.540171472729892970f, 0.529803624686294830f, + 0.519355990165589530f, + 0.508830142543106990f, 0.498227666972781870f, 0.487550160148436050f, + 0.476799230063322250f, + 0.465976495767966130f, 0.455083587126343840f, 0.444122144570429260f, + 0.433093818853152010f, + 0.422000270799799790f, 0.410843171057903910f, 0.399624199845646790f, + 0.388345046698826300f, + 0.377007410216418310f, 0.365612997804773960f, 0.354163525420490510f, + 0.342660717311994380f, + 0.331106305759876430f, 0.319502030816015750f, 0.307849640041534980f, + 0.296150888243623960f, + 0.284407537211271820f, 0.272621355449948980f, 0.260794117915275570f, + 0.248927605745720260f, + 0.237023605994367340f, 0.225083911359792780f, 0.213110319916091360f, + 0.201104634842091960f, + 0.189068664149806280f, 0.177004220412148860f, 0.164913120489970090f, + 0.152797185258443410f, + 0.140658239332849240f, 0.128498110793793220f, 0.116318630911904880f, + 0.104121633872054730f, + 0.091908956497132696f, 0.079682437971430126f, 0.067443919563664106f, + 0.055195244349690031f, + 0.042938256934940959f, 0.030674803176636581f, 0.018406729905804820f, + 0.006135884649154515f +}; + +static const float32_t cos_factors_512[512] = { + 0.999998823451701880f, 0.999989411081928400f, 0.999970586430974140f, + 0.999942349676023910f, + 0.999904701082852900f, 0.999857641005823860f, 0.999801169887884260f, + 0.999735288260561680f, + 0.999659996743959220f, 0.999575296046749220f, 0.999481186966166950f, + 0.999377670388002850f, + 0.999264747286594420f, 0.999142418724816910f, 0.999010685854073380f, + 0.998869549914283560f, + 0.998719012233872940f, 0.998559074229759310f, 0.998389737407340160f, + 0.998211003360478190f, + 0.998022873771486240f, 0.997825350411111640f, 0.997618435138519550f, + 0.997402129901275300f, + 0.997176436735326190f, 0.996941357764982160f, 0.996696895202896060f, + 0.996443051350042630f, + 0.996179828595696980f, 0.995907229417411720f, 0.995625256380994310f, + 0.995333912140482280f, + 0.995033199438118630f, 0.994723121104325700f, 0.994403680057679100f, + 0.994074879304879370f, + 0.993736721940724600f, 0.993389211148080650f, 0.993032350197851410f, + 0.992666142448948020f, + 0.992290591348257370f, 0.991905700430609330f, 0.991511473318743900f, + 0.991107913723276890f, + 0.990695025442664630f, 0.990272812363169110f, 0.989841278458820530f, + 0.989400427791380380f, + 0.988950264510302990f, 0.988490792852696590f, 0.988022017143283530f, + 0.987543941794359230f, + 0.987056571305750970f, 0.986559910264775410f, 0.986053963346195440f, + 0.985538735312176060f, + 0.985014231012239840f, 0.984480455383220930f, 0.983937413449218920f, + 0.983385110321551180f, + 0.982823551198705240f, 0.982252741366289370f, 0.981672686196983110f, + 0.981083391150486710f, + 0.980484861773469380f, 0.979877103699517640f, 0.979260122649082020f, + 0.978633924429423210f, + 0.977998514934557140f, 0.977353900145199960f, 0.976700086128711840f, + 0.976037079039039020f, + 0.975364885116656980f, 0.974683510688510670f, 0.973992962167955830f, + 0.973293246054698250f, + 0.972584368934732210f, 0.971866337480279400f, 0.971139158449725090f, + 0.970402838687555500f, + 0.969657385124292450f, 0.968902804776428870f, 0.968139104746362440f, + 0.967366292222328510f, + 0.966584374478333120f, 0.965793358874083680f, 0.964993252854920320f, + 0.964184063951745830f, + 0.963365799780954050f, 0.962538468044359160f, 0.961702076529122540f, + 0.960856633107679660f, + 0.960002145737665960f, 0.959138622461841890f, 0.958266071408017670f, + 0.957384500788975860f, + 0.956493918902395100f, 0.955594334130771110f, 0.954685754941338340f, + 0.953768189885990330f, + 0.952841647601198720f, 0.951906136807932350f, 0.950961666311575080f, + 0.950008245001843000f, + 0.949045881852700560f, 0.948074585922276230f, 0.947094366352777220f, + 0.946105232370403450f, + 0.945107193285260610f, 0.944100258491272660f, 0.943084437466093490f, + 0.942059739771017310f, + 0.941026175050889260f, 0.939983753034014050f, 0.938932483532064600f, + 0.937872376439989890f, + 0.936803441735921560f, 0.935725689481080370f, 0.934639129819680780f, + 0.933543772978836170f, + 0.932439629268462360f, 0.931326709081180430f, 0.930205022892219070f, + 0.929074581259315860f, + 0.927935394822617890f, 0.926787474304581750f, 0.925630830509872720f, + 0.924465474325262600f, + 0.923291416719527640f, 0.922108668743345180f, 0.920917241529189520f, + 0.919717146291227360f, + 0.918508394325212250f, 0.917290997008377910f, 0.916064965799331720f, + 0.914830312237946200f, + 0.913587047945250810f, 0.912335184623322750f, 0.911074734055176360f, + 0.909805708104652220f, + 0.908528118716306120f, 0.907241977915295820f, 0.905947297807268460f, + 0.904644090578246240f, + 0.903332368494511820f, 0.902012143902493180f, 0.900683429228646970f, + 0.899346236979341570f, + 0.898000579740739880f, 0.896646470178680150f, 0.895283921038557580f, + 0.893912945145203250f, + 0.892533555402764580f, 0.891145764794583180f, 0.889749586383072780f, + 0.888345033309596350f, + 0.886932118794342190f, 0.885510856136199950f, 0.884081258712634990f, + 0.882643339979562790f, + 0.881197113471222090f, 0.879742592800047410f, 0.878279791656541580f, + 0.876808723809145650f, + 0.875329403104110890f, 0.873841843465366860f, 0.872346058894391540f, + 0.870842063470078980f, + 0.869329871348606840f, 0.867809496763303320f, 0.866280954024512990f, + 0.864744257519462380f, + 0.863199421712124160f, 0.861646461143081300f, 0.860085390429390140f, + 0.858516224264442740f, + 0.856938977417828760f, 0.855353664735196030f, 0.853760301138111410f, + 0.852158901623919830f, + 0.850549481265603480f, 0.848932055211639610f, 0.847306638685858320f, + 0.845673246987299070f, + 0.844031895490066410f, 0.842382599643185850f, 0.840725374970458070f, + 0.839060237070312740f, + 0.837387201615661940f, 0.835706284353752600f, 0.834017501106018130f, + 0.832320867767929680f, + 0.830616400308846310f, 0.828904114771864870f, 0.827184027273669130f, + 0.825456154004377550f, + 0.823720511227391430f, 0.821977115279241550f, 0.820225982569434690f, + 0.818467129580298660f, + 0.816700572866827850f, 0.814926329056526620f, 0.813144414849253590f, + 0.811354847017063730f, + 0.809557642404051260f, 0.807752817926190360f, 0.805940390571176280f, + 0.804120377398265810f, + 0.802292795538115720f, 0.800457662192622820f, 0.798614994634760820f, + 0.796764810208418830f, + 0.794907126328237010f, 0.793041960479443640f, 0.791169330217690200f, + 0.789289253168885650f, + 0.787401747029031430f, 0.785506829564053930f, 0.783604518609638200f, + 0.781694832071059390f, + 0.779777787923014550f, 0.777853404209453150f, 0.775921699043407690f, + 0.773982690606822900f, + 0.772036397150384520f, 0.770082836993347900f, 0.768122028523365420f, + 0.766153990196312920f, + 0.764178740536116670f, 0.762196298134578900f, 0.760206681651202420f, + 0.758209909813015280f, + 0.756206001414394540f, 0.754194975316889170f, 0.752176850449042810f, + 0.750151645806215070f, + 0.748119380450403600f, 0.746080073510063780f, 0.744033744179929290f, + 0.741980411720831070f, + 0.739920095459516200f, 0.737852814788465980f, 0.735778589165713590f, + 0.733697438114660370f, + 0.731609381223892630f, 0.729514438146997010f, 0.727412628602375770f, + 0.725303972373060770f, + 0.723188489306527460f, 0.721066199314508110f, 0.718937122372804490f, + 0.716801278521099540f, + 0.714658687862769090f, 0.712509370564692320f, 0.710353346857062420f, + 0.708190637033195400f, + 0.706021261449339740f, 0.703845240524484940f, 0.701662594740168570f, + 0.699473344640283770f, + 0.697277510830886630f, 0.695075113980000880f, 0.692866174817424740f, + 0.690650714134534720f, + 0.688428752784090550f, 0.686200311680038700f, 0.683965411797315510f, + 0.681724074171649820f, + 0.679476319899365080f, 0.677222170137180450f, 0.674961646102012040f, + 0.672694769070772970f, + 0.670421560380173090f, 0.668142041426518560f, 0.665856233665509720f, + 0.663564158612039880f, + 0.661265837839992270f, 0.658961292982037320f, 0.656650545729429050f, + 0.654333617831800550f, + 0.652010531096959500f, 0.649681307390683190f, 0.647345968636512060f, + 0.645004536815544040f, + 0.642657033966226860f, 0.640303482184151670f, 0.637943903621844170f, + 0.635578320488556230f, + 0.633206755050057190f, 0.630829229628424470f, 0.628445766601832710f, + 0.626056388404343520f, + 0.623661117525694640f, 0.621259976511087660f, 0.618852987960976320f, + 0.616440174530853650f, + 0.614021558931038490f, 0.611597163926462020f, 0.609167012336453210f, + 0.606731127034524480f, + 0.604289530948156070f, 0.601842247058580030f, 0.599389298400564540f, + 0.596930708062196500f, + 0.594466499184664540f, 0.591996694962040990f, 0.589521318641063940f, + 0.587040393520918080f, + 0.584553942953015330f, 0.582061990340775550f, 0.579564559139405740f, + 0.577061672855679550f, + 0.574553355047715760f, 0.572039629324757050f, 0.569520519346947250f, + 0.566996048825108680f, + 0.564466241520519500f, 0.561931121244689470f, 0.559390711859136140f, + 0.556845037275160100f, + 0.554294121453620110f, 0.551737988404707450f, 0.549176662187719770f, + 0.546610166910834860f, + 0.544038526730883930f, 0.541461765853123560f, 0.538879908531008420f, + 0.536292979065963180f, + 0.533701001807152960f, 0.531104001151255000f, 0.528502001542228480f, + 0.525895027471084740f, + 0.523283103475656430f, 0.520666254140367270f, 0.518044504095999340f, + 0.515417878019463150f, + 0.512786400633563070f, 0.510150096706766700f, 0.507508991052970870f, + 0.504863108531267480f, + 0.502212474045710900f, 0.499557112545081890f, 0.496897049022654640f, + 0.494232308515959730f, + 0.491562916106550060f, 0.488888896919763230f, 0.486210276124486530f, + 0.483527078932918740f, + 0.480839330600333900f, 0.478147056424843120f, 0.475450281747155870f, + 0.472749031950342900f, + 0.470043332459595620f, 0.467333208741988530f, 0.464618686306237820f, + 0.461899790702462840f, + 0.459176547521944150f, 0.456448982396883860f, 0.453717121000163930f, + 0.450980989045103810f, + 0.448240612285220000f, 0.445496016513981740f, 0.442747227564570130f, + 0.439994271309633260f, + 0.437237173661044200f, 0.434475960569655710f, 0.431710658025057370f, + 0.428941292055329550f, + 0.426167888726799620f, 0.423390474143796100f, 0.420609074448402510f, + 0.417823715820212380f, + 0.415034424476081630f, 0.412241226669883000f, 0.409444148692257590f, + 0.406643216870369140f, + 0.403838457567654130f, 0.401029897183575790f, 0.398217562153373620f, + 0.395401478947816300f, + 0.392581674072951530f, 0.389758174069856410f, 0.386931005514388690f, + 0.384100195016935040f, + 0.381265769222162490f, 0.378427754808765620f, 0.375586178489217330f, + 0.372741067009515810f, + 0.369892447148934270f, 0.367040345719767240f, 0.364184789567079840f, + 0.361325805568454340f, + 0.358463420633736540f, 0.355597661704783960f, 0.352728555755210730f, + 0.349856129790135030f, + 0.346980410845923680f, 0.344101425989938980f, 0.341219202320282410f, + 0.338333766965541290f, + 0.335445147084531660f, 0.332553369866044220f, 0.329658462528587550f, + 0.326760452320131790f, + 0.323859366517852960f, 0.320955232427875210f, 0.318048077385015060f, + 0.315137928752522440f, + 0.312224813921825050f, 0.309308760312268780f, 0.306389795370861080f, + 0.303467946572011370f, + 0.300543241417273400f, 0.297615707435086310f, 0.294685372180514330f, + 0.291752263234989370f, + 0.288816408206049480f, 0.285877834727080730f, 0.282936570457055390f, + 0.279992643080273380f, + 0.277046080306099950f, 0.274096909868706330f, 0.271145159526808070f, + 0.268190857063403180f, + 0.265234030285511900f, 0.262274707023913590f, 0.259312915132886350f, + 0.256348682489942910f, + 0.253382036995570270f, 0.250413006572965280f, 0.247441619167773440f, + 0.244467902747824210f, + 0.241491885302869300f, 0.238513594844318500f, 0.235533059404975460f, + 0.232550307038775330f, + 0.229565365820518870f, 0.226578263845610110f, 0.223589029229790020f, + 0.220597690108873650f, + 0.217604274638483670f, 0.214608810993786920f, 0.211611327369227610f, + 0.208611851978263460f, + 0.205610413053099320f, 0.202607038844421110f, 0.199601757621131050f, + 0.196594597670080220f, + 0.193585587295803750f, 0.190574754820252800f, 0.187562128582529740f, + 0.184547736938619640f, + 0.181531608261125130f, 0.178513770938997590f, 0.175494253377271400f, + 0.172473083996796030f, + 0.169450291233967930f, 0.166425903540464220f, 0.163399949382973230f, + 0.160372457242928400f, + 0.157343455616238280f, 0.154312973013020240f, 0.151281037957330250f, + 0.148247678986896200f, + 0.145212924652847520f, 0.142176803519448000f, 0.139139344163826280f, + 0.136100575175706200f, + 0.133060525157139180f, 0.130019222722233350f, 0.126976696496885980f, + 0.123932975118512200f, + 0.120888087235777220f, 0.117842061508325020f, 0.114794926606510250f, + 0.111746711211126660f, + 0.108697444013138670f, 0.105647153713410700f, 0.102595869022436280f, + 0.099543618660069444f, + 0.096490431355252607f, 0.093436335845747912f, 0.090381360877865011f, + 0.087325535206192226f, + 0.084268887593324127f, 0.081211446809592386f, 0.078153241632794315f, + 0.075094300847921291f, + 0.072034653246889416f, 0.068974327628266732f, 0.065913352797003930f, + 0.062851757564161420f, + 0.059789570746640007f, 0.056726821166907783f, 0.053663537652730679f, + 0.050599749036899337f, + 0.047535484156959261f, 0.044470771854938744f, 0.041405640977076712f, + 0.038340120373552791f, + 0.035274238898213947f, 0.032208025408304704f, 0.029141508764193740f, + 0.026074717829104040f, + 0.023007681468839410f, 0.019940428551514598f, 0.016872987947281773f, + 0.013805388528060349f, + 0.010737659167264572f, 0.007669828739531077f, 0.004601926120448672f, + 0.001533980186284766f +}; + +static const float32_t cos_factors_2048[2048] = { + 0.999999926465717890f, 0.999999338191525530f, 0.999998161643486980f, + 0.999996396822294350f, + 0.999994043728985820f, 0.999991102364945590f, 0.999987572731904080f, + 0.999983454831937730f, + 0.999978748667468830f, 0.999973454241265940f, 0.999967571556443780f, + 0.999961100616462820f, + 0.999954041425129780f, 0.999946393986597460f, 0.999938158305364590f, + 0.999929334386276070f, + 0.999919922234522750f, 0.999909921855641540f, 0.999899333255515390f, + 0.999888156440373320f, + 0.999876391416790410f, 0.999864038191687680f, 0.999851096772332190f, + 0.999837567166337090f, + 0.999823449381661570f, 0.999808743426610520f, 0.999793449309835270f, + 0.999777567040332940f, + 0.999761096627446610f, 0.999744038080865430f, 0.999726391410624470f, + 0.999708156627104880f, + 0.999689333741033640f, 0.999669922763483760f, 0.999649923705874240f, + 0.999629336579970110f, + 0.999608161397882110f, 0.999586398172067070f, 0.999564046915327740f, + 0.999541107640812940f, + 0.999517580362016990f, 0.999493465092780590f, 0.999468761847290050f, + 0.999443470640077770f, + 0.999417591486021720f, 0.999391124400346050f, 0.999364069398620550f, + 0.999336426496761240f, + 0.999308195711029470f, 0.999279377058032710f, 0.999249970554724420f, + 0.999219976218403530f, + 0.999189394066714920f, 0.999158224117649430f, 0.999126466389543390f, + 0.999094120901079070f, + 0.999061187671284600f, 0.999027666719533690f, 0.998993558065545680f, + 0.998958861729386080f, + 0.998923577731465780f, 0.998887706092541290f, 0.998851246833715180f, + 0.998814199976435390f, + 0.998776565542495610f, 0.998738343554035230f, 0.998699534033539280f, + 0.998660137003838490f, + 0.998620152488108870f, 0.998579580509872500f, 0.998538421092996730f, + 0.998496674261694640f, + 0.998454340040524800f, 0.998411418454391300f, 0.998367909528543820f, + 0.998323813288577560f, + 0.998279129760433200f, 0.998233858970396850f, 0.998188000945100300f, + 0.998141555711520520f, + 0.998094523296980010f, 0.998046903729146840f, 0.997998697036034390f, + 0.997949903246001190f, + 0.997900522387751620f, 0.997850554490335110f, 0.997799999583146470f, + 0.997748857695925690f, + 0.997697128858758500f, 0.997644813102075420f, 0.997591910456652630f, + 0.997538420953611340f, + 0.997484344624417930f, 0.997429681500884180f, 0.997374431615167150f, + 0.997318594999768600f, + 0.997262171687536170f, 0.997205161711661850f, 0.997147565105683480f, + 0.997089381903483400f, + 0.997030612139289450f, 0.996971255847674320f, 0.996911313063555740f, + 0.996850783822196610f, + 0.996789668159204560f, 0.996727966110532490f, 0.996665677712478160f, + 0.996602803001684130f, + 0.996539342015137940f, 0.996475294790172160f, 0.996410661364464100f, + 0.996345441776035900f, + 0.996279636063254650f, 0.996213244264832040f, 0.996146266419824620f, + 0.996078702567633980f, + 0.996010552748005870f, 0.995941817001031350f, 0.995872495367145730f, + 0.995802587887129160f, + 0.995732094602106430f, 0.995661015553546910f, 0.995589350783264600f, + 0.995517100333418110f, + 0.995444264246510340f, 0.995370842565388990f, 0.995296835333246090f, + 0.995222242593618360f, + 0.995147064390386470f, 0.995071300767776170f, 0.994994951770357020f, + 0.994918017443043200f, + 0.994840497831093180f, 0.994762392980109930f, 0.994683702936040250f, + 0.994604427745175660f, + 0.994524567454151740f, 0.994444122109948040f, 0.994363091759888570f, + 0.994281476451641550f, + 0.994199276233218910f, 0.994116491152977070f, 0.994033121259616400f, + 0.993949166602181130f, + 0.993864627230059750f, 0.993779503192984580f, 0.993693794541031790f, + 0.993607501324621610f, + 0.993520623594518090f, 0.993433161401829360f, 0.993345114798006910f, + 0.993256483834846440f, + 0.993167268564487230f, 0.993077469039412300f, 0.992987085312448390f, + 0.992896117436765980f, + 0.992804565465879140f, 0.992712429453645460f, 0.992619709454266140f, + 0.992526405522286100f, + 0.992432517712593660f, 0.992338046080420420f, 0.992242990681341700f, + 0.992147351571276090f, + 0.992051128806485720f, 0.991954322443575950f, 0.991856932539495470f, + 0.991758959151536110f, + 0.991660402337333210f, 0.991561262154865290f, 0.991461538662453790f, + 0.991361231918763460f, + 0.991260341982802440f, 0.991158868913921350f, 0.991056812771814340f, + 0.990954173616518500f, + 0.990850951508413620f, 0.990747146508222710f, 0.990642758677011570f, + 0.990537788076188750f, + 0.990432234767505970f, 0.990326098813057330f, 0.990219380275280000f, + 0.990112079216953770f, + 0.990004195701200910f, 0.989895729791486660f, 0.989786681551618640f, + 0.989677051045747210f, + 0.989566838338365120f, 0.989456043494307710f, 0.989344666578752640f, + 0.989232707657220050f, + 0.989120166795572690f, 0.989007044060015270f, 0.988893339517095130f, + 0.988779053233701520f, + 0.988664185277066230f, 0.988548735714763200f, 0.988432704614708340f, + 0.988316092045159690f, + 0.988198898074717610f, 0.988081122772324070f, 0.987962766207263420f, + 0.987843828449161740f, + 0.987724309567986960f, 0.987604209634049160f, 0.987483528717999710f, + 0.987362266890832400f, + 0.987240424223882250f, 0.987118000788826280f, 0.986994996657682980f, + 0.986871411902812470f, + 0.986747246596916590f, 0.986622500813038480f, 0.986497174624562880f, + 0.986371268105216030f, + 0.986244781329065460f, 0.986117714370520090f, 0.985990067304330140f, + 0.985861840205586980f, + 0.985733033149723490f, 0.985603646212513400f, 0.985473679470071810f, + 0.985343132998854790f, + 0.985212006875659350f, 0.985080301177623800f, 0.984948015982227030f, + 0.984815151367289140f, + 0.984681707410970940f, 0.984547684191773960f, 0.984413081788540700f, + 0.984277900280454370f, + 0.984142139747038570f, 0.984005800268157870f, 0.983868881924017220f, + 0.983731384795162090f, + 0.983593308962478650f, 0.983454654507193270f, 0.983315421510872810f, + 0.983175610055424420f, + 0.983035220223095640f, 0.982894252096474070f, 0.982752705758487830f, + 0.982610581292404750f, + 0.982467878781833170f, 0.982324598310721280f, 0.982180739963357090f, + 0.982036303824369020f, + 0.981891289978725100f, 0.981745698511732990f, 0.981599529509040720f, + 0.981452783056635520f, + 0.981305459240844670f, 0.981157558148334830f, 0.981009079866112630f, + 0.980860024481523870f, + 0.980710392082253970f, 0.980560182756327840f, 0.980409396592109910f, + 0.980258033678303550f, + 0.980106094103951770f, 0.979953577958436740f, 0.979800485331479790f, + 0.979646816313141210f, + 0.979492570993820810f, 0.979337749464256780f, 0.979182351815526930f, + 0.979026378139047580f, + 0.978869828526574120f, 0.978712703070200420f, 0.978555001862359550f, + 0.978396724995823090f, + 0.978237872563701090f, 0.978078444659442380f, 0.977918441376834370f, + 0.977757862810002760f, + 0.977596709053411890f, 0.977434980201864260f, 0.977272676350500860f, + 0.977109797594800880f, + 0.976946344030581670f, 0.976782315753998650f, 0.976617712861545640f, + 0.976452535450054060f, + 0.976286783616693630f, 0.976120457458971910f, 0.975953557074734300f, + 0.975786082562163930f, + 0.975618034019781750f, 0.975449411546446380f, 0.975280215241354220f, + 0.975110445204038890f, + 0.974940101534371830f, 0.974769184332561770f, 0.974597693699155050f, + 0.974425629735034990f, + 0.974252992541422500f, 0.974079782219875680f, 0.973905998872289570f, + 0.973731642600896400f, + 0.973556713508265560f, 0.973381211697303290f, 0.973205137271252800f, + 0.973028490333694210f, + 0.972851270988544180f, 0.972673479340056430f, 0.972495115492821190f, + 0.972316179551765300f, + 0.972136671622152230f, 0.971956591809581720f, 0.971775940219990140f, + 0.971594716959650160f, + 0.971412922135170940f, 0.971230555853497380f, 0.971047618221911100f, + 0.970864109348029470f, + 0.970680029339806130f, 0.970495378305530560f, 0.970310156353828110f, + 0.970124363593660280f, + 0.969938000134323960f, 0.969751066085452140f, 0.969563561557013180f, + 0.969375486659311280f, + 0.969186841502985950f, 0.968997626199012420f, 0.968807840858700970f, + 0.968617485593697540f, + 0.968426560515983190f, 0.968235065737874320f, 0.968043001372022260f, + 0.967850367531413620f, + 0.967657164329369880f, 0.967463391879547550f, 0.967269050295937790f, + 0.967074139692867040f, + 0.966878660184995910f, 0.966682611887320080f, 0.966485994915169840f, + 0.966288809384209690f, + 0.966091055410438830f, 0.965892733110190860f, 0.965693842600133690f, + 0.965494383997269500f, + 0.965294357418934660f, 0.965093762982799590f, 0.964892600806868890f, + 0.964690871009481030f, + 0.964488573709308410f, 0.964285709025357480f, 0.964082277076968140f, + 0.963878277983814200f, + 0.963673711865903230f, 0.963468578843575950f, 0.963262879037507070f, + 0.963056612568704340f, + 0.962849779558509030f, 0.962642380128595710f, 0.962434414400972100f, + 0.962225882497979020f, + 0.962016784542290560f, 0.961807120656913540f, 0.961596890965187860f, + 0.961386095590786250f, + 0.961174734657714080f, 0.960962808290309780f, 0.960750316613243950f, + 0.960537259751520050f, + 0.960323637830473920f, 0.960109450975773940f, 0.959894699313420530f, + 0.959679382969746750f, + 0.959463502071417510f, 0.959247056745430090f, 0.959030047119113660f, + 0.958812473320129310f, + 0.958594335476470220f, 0.958375633716461170f, 0.958156368168758820f, + 0.957936538962351420f, + 0.957716146226558870f, 0.957495190091032570f, 0.957273670685755200f, + 0.957051588141040970f, + 0.956828942587535370f, 0.956605734156215080f, 0.956381962978387730f, + 0.956157629185692140f, + 0.955932732910098280f, 0.955707274283906560f, 0.955481253439748770f, + 0.955254670510586990f, + 0.955027525629714160f, 0.954799818930753720f, 0.954571550547659630f, + 0.954342720614716480f, + 0.954113329266538800f, 0.953883376638071770f, 0.953652862864590500f, + 0.953421788081700310f, + 0.953190152425336670f, 0.952957956031764700f, 0.952725199037579570f, + 0.952491881579706320f, + 0.952258003795399600f, 0.952023565822243570f, 0.951788567798152130f, + 0.951553009861368590f, + 0.951316892150465550f, 0.951080214804345010f, 0.950842977962238160f, + 0.950605181763705340f, + 0.950366826348635780f, 0.950127911857248100f, 0.949888438430089300f, + 0.949648406208035480f, + 0.949407815332291570f, 0.949166665944390700f, 0.948924958186195160f, + 0.948682692199895090f, + 0.948439868128009620f, 0.948196486113385580f, 0.947952546299198670f, + 0.947708048828952100f, + 0.947462993846477700f, 0.947217381495934820f, 0.946971211921810880f, + 0.946724485268921170f, + 0.946477201682408680f, 0.946229361307743820f, 0.945980964290724760f, + 0.945732010777477150f, + 0.945482500914453740f, 0.945232434848435000f, 0.944981812726528150f, + 0.944730634696167800f, + 0.944478900905115550f, 0.944226611501459810f, 0.943973766633615980f, + 0.943720366450326200f, + 0.943466411100659320f, 0.943211900734010620f, 0.942956835500102120f, + 0.942701215548981900f, + 0.942445041031024890f, 0.942188312096931770f, 0.941931028897729620f, + 0.941673191584771360f, + 0.941414800309736340f, 0.941155855224629190f, 0.940896356481780830f, + 0.940636304233847590f, + 0.940375698633811540f, 0.940114539834980280f, 0.939852827990986680f, + 0.939590563255789270f, + 0.939327745783671400f, 0.939064375729241950f, 0.938800453247434770f, + 0.938535978493508560f, + 0.938270951623047190f, 0.938005372791958840f, 0.937739242156476970f, + 0.937472559873159250f, + 0.937205326098887960f, 0.936937540990869900f, 0.936669204706636170f, + 0.936400317404042060f, + 0.936130879241267030f, 0.935860890376814640f, 0.935590350969512370f, + 0.935319261178511610f, + 0.935047621163287430f, 0.934775431083638700f, 0.934502691099687870f, + 0.934229401371880820f, + 0.933955562060986730f, 0.933681173328098410f, 0.933406235334631520f, + 0.933130748242325230f, + 0.932854712213241120f, 0.932578127409764420f, 0.932300993994602760f, + 0.932023312130786490f, + 0.931745081981668720f, 0.931466303710925090f, 0.931186977482553750f, + 0.930907103460875130f, + 0.930626681810531760f, 0.930345712696488470f, 0.930064196284032360f, + 0.929782132738772190f, + 0.929499522226638560f, 0.929216364913884040f, 0.928932660967082820f, + 0.928648410553130520f, + 0.928363613839244370f, 0.928078270992963140f, 0.927792382182146320f, + 0.927505947574975180f, + 0.927218967339951790f, 0.926931441645899130f, 0.926643370661961230f, + 0.926354754557602860f, + 0.926065593502609310f, 0.925775887667086740f, 0.925485637221461490f, + 0.925194842336480530f, + 0.924903503183210910f, 0.924611619933039970f, 0.924319192757675160f, + 0.924026221829143850f, + 0.923732707319793290f, 0.923438649402290370f, 0.923144048249621930f, + 0.922848904035094120f, + 0.922553216932332830f, 0.922256987115283030f, 0.921960214758209220f, + 0.921662900035694730f, + 0.921365043122642340f, 0.921066644194273640f, 0.920767703426128790f, + 0.920468220994067110f, + 0.920168197074266340f, 0.919867631843222950f, 0.919566525477751530f, + 0.919264878154985370f, + 0.918962690052375630f, 0.918659961347691900f, 0.918356692219021720f, + 0.918052882844770380f, + 0.917748533403661250f, 0.917443644074735220f, 0.917138215037350710f, + 0.916832246471183890f, + 0.916525738556228210f, 0.916218691472794220f, 0.915911105401509880f, + 0.915602980523320230f, + 0.915294317019487050f, 0.914985115071589310f, 0.914675374861522390f, + 0.914365096571498560f, + 0.914054280384046570f, 0.913742926482011390f, 0.913431035048554720f, + 0.913118606267154240f, + 0.912805640321603500f, 0.912492137396012650f, 0.912178097674807180f, + 0.911863521342728520f, + 0.911548408584833990f, 0.911232759586496190f, 0.910916574533403360f, + 0.910599853611558930f, + 0.910282597007281760f, 0.909964804907205660f, 0.909646477498279540f, + 0.909327614967767260f, + 0.909008217503247450f, 0.908688285292613360f, 0.908367818524072890f, + 0.908046817386148340f, + 0.907725282067676440f, 0.907403212757808110f, 0.907080609646008450f, + 0.906757472922056550f, + 0.906433802776045460f, 0.906109599398381980f, 0.905784862979786550f, + 0.905459593711293250f, + 0.905133791784249690f, 0.904807457390316540f, 0.904480590721468250f, + 0.904153191969991780f, + 0.903825261328487510f, 0.903496798989868450f, 0.903167805147360720f, + 0.902838279994502830f, + 0.902508223725145940f, 0.902177636533453620f, 0.901846518613901750f, + 0.901514870161278740f, + 0.901182691370684520f, 0.900849982437531450f, 0.900516743557543520f, + 0.900182974926756810f, + 0.899848676741518580f, 0.899513849198487980f, 0.899178492494635330f, + 0.898842606827242370f, + 0.898506192393901950f, 0.898169249392518080f, 0.897831778021305650f, + 0.897493778478790310f, + 0.897155250963808550f, 0.896816195675507300f, 0.896476612813344120f, + 0.896136502577086770f, + 0.895795865166813530f, 0.895454700782912450f, 0.895113009626081760f, + 0.894770791897329550f, + 0.894428047797973800f, 0.894084777529641990f, 0.893740981294271040f, + 0.893396659294107720f, + 0.893051811731707450f, 0.892706438809935390f, 0.892360540731965360f, + 0.892014117701280470f, + 0.891667169921672280f, 0.891319697597241390f, 0.890971700932396860f, + 0.890623180131855930f, + 0.890274135400644600f, 0.889924566944096720f, 0.889574474967854580f, + 0.889223859677868210f, + 0.888872721280395630f, 0.888521059982002260f, 0.888168875989561730f, + 0.887816169510254440f, + 0.887462940751568840f, 0.887109189921300170f, 0.886754917227550840f, + 0.886400122878730600f, + 0.886044807083555600f, 0.885688970051048960f, 0.885332611990540590f, + 0.884975733111666660f, + 0.884618333624369920f, 0.884260413738899190f, 0.883901973665809470f, + 0.883543013615961880f, + 0.883183533800523390f, 0.882823534430966620f, 0.882463015719070150f, + 0.882101977876917580f, + 0.881740421116898320f, 0.881378345651706920f, 0.881015751694342870f, + 0.880652639458111010f, + 0.880289009156621010f, 0.879924861003786860f, 0.879560195213827890f, + 0.879195012001267480f, + 0.878829311580933360f, 0.878463094167957870f, 0.878096359977777130f, + 0.877729109226131570f, + 0.877361342129065140f, 0.876993058902925890f, 0.876624259764365310f, + 0.876254944930338510f, + 0.875885114618103810f, 0.875514769045222850f, 0.875143908429560360f, + 0.874772532989284150f, + 0.874400642942864790f, 0.874028238509075740f, 0.873655319906992630f, + 0.873281887355994210f, + 0.872907941075761080f, 0.872533481286276170f, 0.872158508207824480f, + 0.871783022060993120f, + 0.871407023066670950f, 0.871030511446048260f, 0.870653487420617430f, + 0.870275951212171940f, + 0.869897903042806340f, 0.869519343134916860f, 0.869140271711200560f, + 0.868760688994655310f, + 0.868380595208579800f, 0.867999990576573510f, 0.867618875322536230f, + 0.867237249670668400f, + 0.866855113845470430f, 0.866472468071743050f, 0.866089312574586770f, + 0.865705647579402380f, + 0.865321473311889800f, 0.864936789998049020f, 0.864551597864179340f, + 0.864165897136879300f, + 0.863779688043046720f, 0.863392970809878420f, 0.863005745664870320f, + 0.862618012835816740f, + 0.862229772550811240f, 0.861841025038245330f, 0.861451770526809320f, + 0.861062009245491480f, + 0.860671741423578380f, 0.860280967290654510f, 0.859889687076602290f, + 0.859497901011601730f, + 0.859105609326130450f, 0.858712812250963520f, 0.858319510017173440f, + 0.857925702856129790f, + 0.857531390999499150f, 0.857136574679244980f, 0.856741254127627470f, + 0.856345429577203610f, + 0.855949101260826910f, 0.855552269411646860f, 0.855154934263109620f, + 0.854757096048957220f, + 0.854358755003227440f, 0.853959911360254180f, 0.853560565354666840f, + 0.853160717221390420f, + 0.852760367195645300f, 0.852359515512947090f, 0.851958162409106380f, + 0.851556308120228980f, + 0.851153952882715340f, 0.850751096933260790f, 0.850347740508854980f, + 0.849943883846782210f, + 0.849539527184620890f, 0.849134670760243630f, 0.848729314811817130f, + 0.848323459577801640f, + 0.847917105296951410f, 0.847510252208314330f, 0.847102900551231500f, + 0.846695050565337450f, + 0.846286702490559710f, 0.845877856567119000f, 0.845468513035528830f, + 0.845058672136595470f, + 0.844648334111417820f, 0.844237499201387020f, 0.843826167648186740f, + 0.843414339693792760f, + 0.843002015580472940f, 0.842589195550786710f, 0.842175879847585570f, + 0.841762068714012490f, + 0.841347762393501950f, 0.840932961129779780f, 0.840517665166862550f, + 0.840101874749058400f, + 0.839685590120966110f, 0.839268811527475230f, 0.838851539213765760f, + 0.838433773425308340f, + 0.838015514407863820f, 0.837596762407483040f, 0.837177517670507300f, + 0.836757780443567190f, + 0.836337550973583530f, 0.835916829507766360f, 0.835495616293615350f, + 0.835073911578919410f, + 0.834651715611756440f, 0.834229028640493420f, 0.833805850913786340f, + 0.833382182680579730f, + 0.832958024190106670f, 0.832533375691888680f, 0.832108237435735590f, + 0.831682609671745120f, + 0.831256492650303210f, 0.830829886622083570f, 0.830402791838047550f, + 0.829975208549443950f, + 0.829547137007808910f, 0.829118577464965980f, 0.828689530173025820f, + 0.828259995384385660f, + 0.827829973351729920f, 0.827399464328029470f, 0.826968468566541600f, + 0.826536986320809960f, + 0.826105017844664610f, 0.825672563392221390f, 0.825239623217882250f, + 0.824806197576334330f, + 0.824372286722551250f, 0.823937890911791370f, 0.823503010399598500f, + 0.823067645441801670f, + 0.822631796294514990f, 0.822195463214137170f, 0.821758646457351750f, + 0.821321346281126740f, + 0.820883562942714580f, 0.820445296699652050f, 0.820006547809759680f, + 0.819567316531142230f, + 0.819127603122188240f, 0.818687407841569680f, 0.818246730948242070f, + 0.817805572701444270f, + 0.817363933360698460f, 0.816921813185809480f, 0.816479212436865390f, + 0.816036131374236810f, + 0.815592570258576790f, 0.815148529350820830f, 0.814704008912187080f, + 0.814259009204175270f, + 0.813813530488567190f, 0.813367573027426570f, 0.812921137083098770f, + 0.812474222918210480f, + 0.812026830795669730f, 0.811578960978665890f, 0.811130613730669190f, + 0.810681789315430780f, + 0.810232487996982330f, 0.809782710039636530f, 0.809332455707985950f, + 0.808881725266903610f, + 0.808430518981542720f, 0.807978837117336310f, 0.807526679939997160f, + 0.807074047715517610f, + 0.806620940710169650f, 0.806167359190504420f, 0.805713303423352230f, + 0.805258773675822210f, + 0.804803770215302920f, 0.804348293309460780f, 0.803892343226241260f, + 0.803435920233868120f, + 0.802979024600843250f, 0.802521656595946430f, 0.802063816488235440f, + 0.801605504547046150f, + 0.801146721041991360f, 0.800687466242961610f, 0.800227740420124790f, + 0.799767543843925680f, + 0.799306876785086160f, 0.798845739514604580f, 0.798384132303756380f, + 0.797922055424093000f, + 0.797459509147442460f, 0.796996493745908750f, 0.796533009491872000f, + 0.796069056657987990f, + 0.795604635517188070f, 0.795139746342679590f, 0.794674389407944550f, + 0.794208564986740640f, + 0.793742273353100210f, 0.793275514781330630f, 0.792808289546014120f, + 0.792340597922007170f, + 0.791872440184440470f, 0.791403816608719500f, 0.790934727470523290f, + 0.790465173045804880f, + 0.789995153610791090f, 0.789524669441982190f, 0.789053720816151880f, + 0.788582308010347120f, + 0.788110431301888070f, 0.787638090968367450f, 0.787165287287651010f, + 0.786692020537876790f, + 0.786218290997455660f, 0.785744098945070360f, 0.785269444659675850f, + 0.784794328420499230f, + 0.784318750507038920f, 0.783842711199065230f, 0.783366210776619720f, + 0.782889249520015480f, + 0.782411827709836530f, 0.781933945626937630f, 0.781455603552444590f, + 0.780976801767753750f, + 0.780497540554531910f, 0.780017820194715990f, 0.779537640970513260f, + 0.779057003164400630f, + 0.778575907059125050f, 0.778094352937702790f, 0.777612341083420030f, + 0.777129871779831620f, + 0.776646945310762060f, 0.776163561960304340f, 0.775679722012820650f, + 0.775195425752941420f, + 0.774710673465565550f, 0.774225465435860680f, 0.773739801949261840f, + 0.773253683291472590f, + 0.772767109748463850f, 0.772280081606474320f, 0.771792599152010150f, + 0.771304662671844830f, + 0.770816272453018540f, 0.770327428782838890f, 0.769838131948879840f, + 0.769348382238982280f, + 0.768858179941253270f, 0.768367525344066270f, 0.767876418736060610f, + 0.767384860406141730f, + 0.766892850643480670f, 0.766400389737514230f, 0.765907477977944340f, + 0.765414115654738270f, + 0.764920303058128410f, 0.764426040478612070f, 0.763931328206951090f, + 0.763436166534172010f, + 0.762940555751565720f, 0.762444496150687210f, 0.761947988023355390f, + 0.761451031661653620f, + 0.760953627357928150f, 0.760455775404789260f, 0.759957476095110330f, + 0.759458729722028210f, + 0.758959536578942440f, 0.758459896959515430f, 0.757959811157672300f, + 0.757459279467600720f, + 0.756958302183750490f, 0.756456879600833740f, 0.755955012013824420f, + 0.755452699717958250f, + 0.754949943008732640f, 0.754446742181906440f, 0.753943097533499640f, + 0.753439009359793580f, + 0.752934477957330150f, 0.752429503622912390f, 0.751924086653603550f, + 0.751418227346727470f, + 0.750911925999867890f, 0.750405182910869330f, 0.749897998377835330f, + 0.749390372699129560f, + 0.748882306173375150f, 0.748373799099454560f, 0.747864851776509410f, + 0.747355464503940190f, + 0.746845637581406540f, 0.746335371308826320f, 0.745824665986376090f, + 0.745313521914490520f, + 0.744801939393862630f, 0.744289918725443260f, 0.743777460210440890f, + 0.743264564150321600f, + 0.742751230846809050f, 0.742237460601884000f, 0.741723253717784140f, + 0.741208610497004260f, + 0.740693531242295760f, 0.740178016256666240f, 0.739662065843380010f, + 0.739145680305957510f, + 0.738628859948174840f, 0.738111605074064260f, 0.737593915987913570f, + 0.737075792994265730f, + 0.736557236397919150f, 0.736038246503927350f, 0.735518823617598900f, + 0.734998968044496710f, + 0.734478680090438370f, 0.733957960061495940f, 0.733436808263995710f, + 0.732915225004517780f, + 0.732393210589896040f, 0.731870765327218290f, 0.731347889523825570f, + 0.730824583487312160f, + 0.730300847525525490f, 0.729776681946566090f, 0.729252087058786970f, + 0.728727063170793830f, + 0.728201610591444610f, 0.727675729629849610f, 0.727149420595371020f, + 0.726622683797622850f, + 0.726095519546471000f, 0.725567928152032300f, 0.725039909924675370f, + 0.724511465175019630f, + 0.723982594213935520f, 0.723453297352544380f, 0.722923574902217700f, + 0.722393427174577550f, + 0.721862854481496340f, 0.721331857135096290f, 0.720800435447749190f, + 0.720268589732077190f, + 0.719736320300951030f, 0.719203627467491220f, 0.718670511545067230f, + 0.718136972847297490f, + 0.717603011688049080f, 0.717068628381437480f, 0.716533823241826680f, + 0.715998596583828690f, + 0.715462948722303760f, 0.714926879972359490f, 0.714390390649351390f, + 0.713853481068882470f, + 0.713316151546802610f, 0.712778402399208980f, 0.712240233942445510f, + 0.711701646493102970f, + 0.711162640368018350f, 0.710623215884275020f, 0.710083373359202800f, + 0.709543113110376770f, + 0.709002435455618250f, 0.708461340712994160f, 0.707919829200816310f, + 0.707377901237642100f, + 0.706835557142273860f, 0.706292797233758480f, 0.705749621831387790f, + 0.705206031254697830f, + 0.704662025823468930f, 0.704117605857725430f, 0.703572771677735580f, + 0.703027523604011220f, + 0.702481861957308000f, 0.701935787058624360f, 0.701389299229202230f, + 0.700842398790526230f, + 0.700295086064323780f, 0.699747361372564990f, 0.699199225037462120f, + 0.698650677381469580f, + 0.698101718727283880f, 0.697552349397843270f, 0.697002569716327460f, + 0.696452380006157830f, + 0.695901780590996830f, 0.695350771794747800f, 0.694799353941554900f, + 0.694247527355803310f, + 0.693695292362118350f, 0.693142649285365510f, 0.692589598450650380f, + 0.692036140183318830f, + 0.691482274808955850f, 0.690928002653386280f, 0.690373324042674040f, + 0.689818239303122470f, + 0.689262748761273470f, 0.688706852743907750f, 0.688150551578044830f, + 0.687593845590942170f, + 0.687036735110095660f, 0.686479220463238950f, 0.685921301978343670f, + 0.685362979983618730f, + 0.684804254807510620f, 0.684245126778703080f, 0.683685596226116690f, + 0.683125663478908800f, + 0.682565328866473250f, 0.682004592718440830f, 0.681443455364677990f, + 0.680881917135287340f, + 0.680319978360607200f, 0.679757639371212030f, 0.679194900497911200f, + 0.678631762071749470f, + 0.678068224424006600f, 0.677504287886197430f, 0.676939952790071240f, + 0.676375219467611700f, + 0.675810088251037060f, 0.675244559472799270f, 0.674678633465584540f, + 0.674112310562312360f, + 0.673545591096136100f, 0.672978475400442090f, 0.672410963808849900f, + 0.671843056655211930f, + 0.671274754273613490f, 0.670706056998372160f, 0.670136965164037760f, + 0.669567479105392490f, + 0.668997599157450270f, 0.668427325655456820f, 0.667856658934889440f, + 0.667285599331456480f, + 0.666714147181097670f, 0.666142302819983540f, 0.665570066584515560f, + 0.664997438811325340f, + 0.664424419837275180f, 0.663851009999457340f, 0.663277209635194100f, + 0.662703019082037440f, + 0.662128438677768720f, 0.661553468760399000f, 0.660978109668168060f, + 0.660402361739545030f, + 0.659826225313227430f, 0.659249700728141490f, 0.658672788323441890f, + 0.658095488438511290f, + 0.657517801412960120f, 0.656939727586627110f, 0.656361267299578000f, + 0.655782420892106030f, + 0.655203188704731930f, 0.654623571078202680f, 0.654043568353492640f, + 0.653463180871802330f, + 0.652882408974558960f, 0.652301253003415460f, 0.651719713300251020f, + 0.651137790207170330f, + 0.650555484066503990f, 0.649972795220807530f, 0.649389724012861770f, + 0.648806270785672550f, + 0.648222435882470420f, 0.647638219646710420f, 0.647053622422071650f, + 0.646468644552457890f, + 0.645883286381996440f, 0.645297548255038380f, 0.644711430516158420f, + 0.644124933510154540f, + 0.643538057582047850f, 0.642950803077082080f, 0.642363170340724320f, + 0.641775159718663500f, + 0.641186771556811250f, 0.640598006201301030f, 0.640008863998488440f, + 0.639419345294950700f, + 0.638829450437486400f, 0.638239179773115390f, 0.637648533649078810f, + 0.637057512412838590f, + 0.636466116412077180f, 0.635874345994697720f, 0.635282201508823530f, + 0.634689683302797850f, + 0.634096791725183740f, 0.633503527124764320f, 0.632909889850541860f, + 0.632315880251737680f, + 0.631721498677792370f, 0.631126745478365340f, 0.630531621003334600f, + 0.629936125602796550f, + 0.629340259627065750f, 0.628744023426674790f, 0.628147417352374120f, + 0.627550441755131530f, + 0.626953096986132770f, 0.626355383396779990f, 0.625757301338692900f, + 0.625158851163707730f, + 0.624560033223877320f, 0.623960847871470770f, 0.623361295458973340f, + 0.622761376339086460f, + 0.622161090864726930f, 0.621560439389027270f, 0.620959422265335180f, + 0.620358039847213830f, + 0.619756292488440660f, 0.619154180543008410f, 0.618551704365123860f, + 0.617948864309208260f, + 0.617345660729896940f, 0.616742093982038830f, 0.616138164420696910f, + 0.615533872401147430f, + 0.614929218278879590f, 0.614324202409595950f, 0.613718825149211830f, + 0.613113086853854910f, + 0.612506987879865570f, 0.611900528583796070f, 0.611293709322411010f, + 0.610686530452686280f, + 0.610078992331809620f, 0.609471095317180240f, 0.608862839766408200f, + 0.608254226037314490f, + 0.607645254487930830f, 0.607035925476499760f, 0.606426239361473550f, + 0.605816196501515080f, + 0.605205797255496500f, 0.604595041982500360f, 0.603983931041818020f, + 0.603372464792950370f, + 0.602760643595607220f, 0.602148467809707320f, 0.601535937795377730f, + 0.600923053912954090f, + 0.600309816522980430f, 0.599696225986208310f, 0.599082282663597310f, + 0.598467986916314310f, + 0.597853339105733910f, 0.597238339593437530f, 0.596622988741213330f, + 0.596007286911056530f, + 0.595391234465168730f, 0.594774831765957580f, 0.594158079176036800f, + 0.593540977058226390f, + 0.592923525775551410f, 0.592305725691242400f, 0.591687577168735550f, + 0.591069080571671510f, + 0.590450236263895920f, 0.589831044609458900f, 0.589211505972615070f, + 0.588591620717822890f, + 0.587971389209745120f, 0.587350811813247660f, 0.586729888893400500f, + 0.586108620815476430f, + 0.585487007944951450f, 0.584865050647504490f, 0.584242749289016980f, + 0.583620104235572760f, + 0.582997115853457700f, 0.582373784509160220f, 0.581750110569369760f, + 0.581126094400977620f, + 0.580501736371076600f, 0.579877036846960350f, 0.579251996196123550f, + 0.578626614786261430f, + 0.578000892985269910f, 0.577374831161244880f, 0.576748429682482520f, + 0.576121688917478390f, + 0.575494609234928230f, 0.574867191003726740f, 0.574239434592967890f, + 0.573611340371944610f, + 0.572982908710148680f, 0.572354139977270030f, 0.571725034543197120f, + 0.571095592778016690f, + 0.570465815052012990f, 0.569835701735668110f, 0.569205253199661200f, + 0.568574469814869250f, + 0.567943351952365670f, 0.567311899983420800f, 0.566680114279501710f, + 0.566047995212271560f, + 0.565415543153589770f, 0.564782758475511400f, 0.564149641550287680f, + 0.563516192750364910f, + 0.562882412448384550f, 0.562248301017183150f, 0.561613858829792420f, + 0.560979086259438260f, + 0.560343983679540860f, 0.559708551463714790f, 0.559072789985768480f, + 0.558436699619704100f, + 0.557800280739717100f, 0.557163533720196340f, 0.556526458935723720f, + 0.555889056761073920f, + 0.555251327571214090f, 0.554613271741304040f, 0.553974889646695610f, + 0.553336181662932410f, + 0.552697148165749770f, 0.552057789531074980f, 0.551418106135026060f, + 0.550778098353912230f, + 0.550137766564233630f, 0.549497111142680960f, 0.548856132466135290f, + 0.548214830911667780f, + 0.547573206856539870f, 0.546931260678202190f, 0.546288992754295210f, + 0.545646403462648590f, + 0.545003493181281160f, 0.544360262288400400f, 0.543716711162402390f, + 0.543072840181871850f, + 0.542428649725581360f, 0.541784140172491660f, 0.541139311901750910f, + 0.540494165292695230f, + 0.539848700724847700f, 0.539202918577918240f, 0.538556819231804210f, + 0.537910403066588990f, + 0.537263670462542530f, 0.536616621800121150f, 0.535969257459966710f, + 0.535321577822907010f, + 0.534673583269955510f, 0.534025274182310380f, 0.533376650941355560f, + 0.532727713928658810f, + 0.532078463525973540f, 0.531428900115236910f, 0.530779024078570250f, + 0.530128835798278850f, + 0.529478335656852090f, 0.528827524036961980f, 0.528176401321464370f, + 0.527524967893398200f, + 0.526873224135984700f, 0.526221170432628170f, 0.525568807166914680f, + 0.524916134722612890f, + 0.524263153483673470f, 0.523609863834228030f, 0.522956266158590140f, + 0.522302360841254700f, + 0.521648148266897090f, 0.520993628820373810f, 0.520338802886721960f, + 0.519683670851158520f, + 0.519028233099080970f, 0.518372490016066220f, 0.517716441987871150f, + 0.517060089400432130f, + 0.516403432639863990f, 0.515746472092461380f, 0.515089208144697270f, + 0.514431641183222930f, + 0.513773771594868030f, 0.513115599766640560f, 0.512457126085725800f, + 0.511798350939487000f, + 0.511139274715464390f, 0.510479897801375700f, 0.509820220585115560f, + 0.509160243454754750f, + 0.508499966798540810f, 0.507839391004897940f, 0.507178516462425290f, + 0.506517343559898530f, + 0.505855872686268860f, 0.505194104230662240f, 0.504532038582380380f, + 0.503869676130898950f, + 0.503207017265869030f, 0.502544062377115800f, 0.501880811854638400f, + 0.501217266088609950f, + 0.500553425469377640f, 0.499889290387461380f, 0.499224861233555030f, + 0.498560138398525200f, + 0.497895122273410930f, 0.497229813249424340f, 0.496564211717949340f, + 0.495898318070542240f, + 0.495232132698931350f, 0.494565655995016010f, 0.493898888350867430f, + 0.493231830158728070f, + 0.492564481811010650f, 0.491896843700299240f, 0.491228916219348330f, + 0.490560699761082080f, + 0.489892194718595300f, 0.489223401485152030f, 0.488554320454186230f, + 0.487884952019301210f, + 0.487215296574268820f, 0.486545354513030270f, 0.485875126229695420f, + 0.485204612118541880f, + 0.484533812574016120f, 0.483862727990732320f, 0.483191358763471910f, + 0.482519705287184520f, + 0.481847767956986080f, 0.481175547168160360f, 0.480503043316157670f, + 0.479830256796594250f, + 0.479157188005253310f, 0.478483837338084080f, 0.477810205191201040f, + 0.477136291960884750f, + 0.476462098043581310f, 0.475787623835901120f, 0.475112869734620470f, + 0.474437836136679340f, + 0.473762523439182850f, 0.473086932039400220f, 0.472411062334764100f, + 0.471734914722871430f, + 0.471058489601482610f, 0.470381787368520710f, 0.469704808422072460f, + 0.469027553160387240f, + 0.468350021981876530f, 0.467672215285114710f, 0.466994133468838110f, + 0.466315776931944480f, + 0.465637146073493770f, 0.464958241292706740f, 0.464279062988965760f, + 0.463599611561814120f, + 0.462919887410955130f, 0.462239890936253280f, 0.461559622537733190f, + 0.460879082615578690f, + 0.460198271570134270f, 0.459517189801903590f, 0.458835837711549120f, + 0.458154215699893230f, + 0.457472324167916110f, 0.456790163516757220f, 0.456107734147714220f, + 0.455425036462242420f, + 0.454742070861955450f, 0.454058837748624540f, 0.453375337524177750f, + 0.452691570590700860f, + 0.452007537350436530f, 0.451323238205783520f, 0.450638673559297760f, + 0.449953843813690580f, + 0.449268749371829920f, 0.448583390636739300f, 0.447897768011597360f, + 0.447211881899738260f, + 0.446525732704651400f, 0.445839320829980350f, 0.445152646679523590f, + 0.444465710657234110f, + 0.443778513167218280f, 0.443091054613736990f, 0.442403335401204130f, + 0.441715355934187310f, + 0.441027116617407340f, 0.440338617855737300f, 0.439649860054203420f, + 0.438960843617984430f, + 0.438271568952410480f, 0.437582036462964340f, 0.436892246555280470f, + 0.436202199635143950f, + 0.435511896108492170f, 0.434821336381412350f, 0.434130520860143310f, + 0.433439449951074200f, + 0.432748124060743760f, 0.432056543595841450f, 0.431364708963206440f, + 0.430672620569826860f, + 0.429980278822840570f, 0.429287684129534720f, 0.428594836897344400f, + 0.427901737533854240f, + 0.427208386446796370f, 0.426514784044051520f, 0.425820930733648350f, + 0.425126826923762410f, + 0.424432473022717420f, 0.423737869438983950f, 0.423043016581179100f, + 0.422347914858067000f, + 0.421652564678558380f, 0.420956966451709440f, 0.420261120586723050f, + 0.419565027492946940f, + 0.418868687579875110f, 0.418172101257146430f, 0.417475268934544340f, + 0.416778191021997590f, + 0.416080867929579320f, 0.415383300067506290f, 0.414685487846140010f, + 0.413987431675985510f, + 0.413289131967690960f, 0.412590589132048380f, 0.411891803579992220f, + 0.411192775722600160f, + 0.410493505971092520f, 0.409793994736831200f, 0.409094242431320920f, + 0.408394249466208110f, + 0.407694016253280170f, 0.406993543204466460f, 0.406292830731837470f, + 0.405591879247603870f, + 0.404890689164117750f, 0.404189260893870750f, 0.403487594849495310f, + 0.402785691443763640f, + 0.402083551089587040f, 0.401381174200016790f, 0.400678561188243350f, + 0.399975712467595390f, + 0.399272628451540930f, 0.398569309553686360f, 0.397865756187775750f, + 0.397161968767691720f, + 0.396457947707453960f, 0.395753693421220080f, 0.395049206323284880f, + 0.394344486828079650f, + 0.393639535350172880f, 0.392934352304269600f, 0.392228938105210370f, + 0.391523293167972350f, + 0.390817417907668610f, 0.390111312739546910f, 0.389404978078991100f, + 0.388698414341519250f, + 0.387991621942784910f, 0.387284601298575890f, 0.386577352824813980f, + 0.385869876937555310f, + 0.385162174052989970f, 0.384454244587440870f, 0.383746088957365010f, + 0.383037707579352130f, + 0.382329100870124510f, 0.381620269246537520f, 0.380911213125578130f, + 0.380201932924366050f, + 0.379492429060152740f, 0.378782701950320600f, 0.378072752012383990f, + 0.377362579663988450f, + 0.376652185322909620f, 0.375941569407054420f, 0.375230732334460030f, + 0.374519674523293210f, + 0.373808396391851370f, 0.373096898358560690f, 0.372385180841977360f, + 0.371673244260786630f, + 0.370961089033802040f, 0.370248715579966360f, 0.369536124318350760f, + 0.368823315668153960f, + 0.368110290048703050f, 0.367397047879452820f, 0.366683589579984930f, + 0.365969915570008910f, + 0.365256026269360380f, 0.364541922098002180f, 0.363827603476023610f, + 0.363113070823639530f, + 0.362398324561191310f, 0.361683365109145950f, 0.360968192888095290f, + 0.360252808318756830f, + 0.359537211821973180f, 0.358821403818710860f, 0.358105384730061760f, + 0.357389154977241000f, + 0.356672714981588260f, 0.355956065164567010f, 0.355239205947763370f, + 0.354522137752887430f, + 0.353804861001772160f, 0.353087376116372530f, 0.352369683518766630f, + 0.351651783631154680f, + 0.350933676875858360f, 0.350215363675321740f, 0.349496844452109600f, + 0.348778119628908420f, + 0.348059189628525780f, 0.347340054873889190f, 0.346620715788047320f, + 0.345901172794169100f, + 0.345181426315542610f, 0.344461476775576480f, 0.343741324597798600f, + 0.343020970205855540f, + 0.342300414023513690f, 0.341579656474657210f, 0.340858697983289440f, + 0.340137538973531880f, + 0.339416179869623410f, 0.338694621095921190f, 0.337972863076899830f, + 0.337250906237150650f, + 0.336528751001382350f, 0.335806397794420560f, 0.335083847041206580f, + 0.334361099166798900f, + 0.333638154596370920f, 0.332915013755212650f, 0.332191677068729320f, + 0.331468144962440920f, + 0.330744417861982890f, 0.330020496193105530f, 0.329296380381672800f, + 0.328572070853663690f, + 0.327847568035170960f, 0.327122872352400510f, 0.326397984231672660f, + 0.325672904099419900f, + 0.324947632382188430f, 0.324222169506637130f, 0.323496515899536760f, + 0.322770671987770710f, + 0.322044638198334620f, 0.321318414958334910f, 0.320592002694990330f, + 0.319865401835630610f, + 0.319138612807695900f, 0.318411636038737960f, 0.317684471956418020f, + 0.316957120988508150f, + 0.316229583562890490f, 0.315501860107556040f, 0.314773951050606070f, + 0.314045856820250820f, + 0.313317577844809070f, 0.312589114552708660f, 0.311860467372486130f, + 0.311131636732785270f, + 0.310402623062358880f, 0.309673426790066490f, 0.308944048344875710f, + 0.308214488155861220f, + 0.307484746652204160f, 0.306754824263192780f, 0.306024721418221900f, + 0.305294438546791720f, + 0.304563976078509050f, 0.303833334443086470f, 0.303102514070341060f, + 0.302371515390196130f, + 0.301640338832678880f, 0.300908984827921890f, 0.300177453806162120f, + 0.299445746197739950f, + 0.298713862433100390f, 0.297981802942791920f, 0.297249568157465890f, + 0.296517158507877410f, + 0.295784574424884370f, 0.295051816339446720f, 0.294318884682627570f, + 0.293585779885591310f, + 0.292852502379604810f, 0.292119052596036540f, 0.291385430966355720f, + 0.290651637922133220f, + 0.289917673895040860f, 0.289183539316850310f, 0.288449234619434170f, + 0.287714760234765280f, + 0.286980116594915570f, 0.286245304132057120f, 0.285510323278461380f, + 0.284775174466498300f, + 0.284039858128637360f, 0.283304374697445790f, 0.282568724605589740f, + 0.281832908285833460f, + 0.281096926171038320f, 0.280360778694163810f, 0.279624466288266700f, + 0.278887989386500280f, + 0.278151348422115090f, 0.277414543828458200f, 0.276677576038972420f, + 0.275940445487197320f, + 0.275203152606767370f, 0.274465697831413220f, 0.273728081594960650f, + 0.272990304331329980f, + 0.272252366474536660f, 0.271514268458690810f, 0.270776010717996010f, + 0.270037593686750510f, + 0.269299017799346230f, 0.268560283490267890f, 0.267821391194094320f, + 0.267082341345496350f, + 0.266343134379238180f, 0.265603770730176440f, 0.264864250833259320f, + 0.264124575123527490f, + 0.263384744036113390f, 0.262644758006240100f, 0.261904617469222560f, + 0.261164322860466590f, + 0.260423874615468010f, 0.259683273169813930f, 0.258942518959180580f, + 0.258201612419334870f, + 0.257460553986133210f, 0.256719344095520720f, 0.255977983183532380f, + 0.255236471686291820f, + 0.254494810040010790f, 0.253752998680989940f, 0.253011038045617980f, + 0.252268928570370810f, + 0.251526670691812780f, 0.250784264846594550f, 0.250041711471454650f, + 0.249299011003218300f, + 0.248556163878796620f, 0.247813170535187620f, 0.247070031409475370f, + 0.246326746938829060f, + 0.245583317560504000f, 0.244839743711840750f, 0.244096025830264210f, + 0.243352164353284880f, + 0.242608159718496890f, 0.241864012363579210f, 0.241119722726294730f, + 0.240375291244489500f, + 0.239630718356093560f, 0.238886004499120170f, 0.238141150111664870f, + 0.237396155631906550f, + 0.236651021498106460f, 0.235905748148607370f, 0.235160336021834860f, + 0.234414785556295250f, + 0.233669097190576820f, 0.232923271363349120f, 0.232177308513361770f, + 0.231431209079445730f, + 0.230684973500512310f, 0.229938602215552260f, 0.229192095663636740f, + 0.228445454283916550f, + 0.227698678515621170f, 0.226951768798059980f, 0.226204725570620270f, + 0.225457549272768540f, + 0.224710240344049570f, 0.223962799224085520f, 0.223215226352576960f, + 0.222467522169301990f, + 0.221719687114115240f, 0.220971721626949060f, 0.220223626147812460f, + 0.219475401116790340f, + 0.218727046974044600f, 0.217978564159812290f, 0.217229953114406790f, + 0.216481214278216900f, + 0.215732348091705940f, 0.214983354995412820f, 0.214234235429951100f, + 0.213484989836008080f, + 0.212735618654345870f, 0.211986122325800410f, 0.211236501291280710f, + 0.210486755991769890f, + 0.209736886868323370f, 0.208986894362070070f, 0.208236778914211470f, + 0.207486540966020700f, + 0.206736180958843660f, 0.205985699334098050f, 0.205235096533272380f, + 0.204484372997927180f, + 0.203733529169694010f, 0.202982565490274460f, 0.202231482401441620f, + 0.201480280345037820f, + 0.200728959762976140f, 0.199977521097239290f, 0.199225964789878890f, + 0.198474291283016360f, + 0.197722501018842030f, 0.196970594439614370f, 0.196218571987660850f, + 0.195466434105377090f, + 0.194714181235225990f, 0.193961813819739010f, 0.193209332301514080f, + 0.192456737123216840f, + 0.191704028727579940f, 0.190951207557401860f, 0.190198274055548120f, + 0.189445228664950340f, + 0.188692071828605260f, 0.187938803989575850f, 0.187185425590990440f, + 0.186431937076041640f, + 0.185678338887987790f, 0.184924631470150870f, 0.184170815265917720f, + 0.183416890718739230f, + 0.182662858272129360f, 0.181908718369666160f, 0.181154471454990920f, + 0.180400117971807270f, + 0.179645658363882100f, 0.178891093075044830f, 0.178136422549186320f, + 0.177381647230260200f, + 0.176626767562280960f, 0.175871783989325040f, 0.175116696955530060f, + 0.174361506905093830f, + 0.173606214282275410f, 0.172850819531394200f, 0.172095323096829040f, + 0.171339725423019260f, + 0.170584026954463700f, 0.169828228135719880f, 0.169072329411405180f, + 0.168316331226194910f, + 0.167560234024823590f, 0.166804038252083870f, 0.166047744352825850f, + 0.165291352771957970f, + 0.164534863954446110f, 0.163778278345312690f, 0.163021596389637810f, + 0.162264818532558110f, + 0.161507945219266150f, 0.160750976895011390f, 0.159993914005098350f, + 0.159236756994887850f, + 0.158479506309796100f, 0.157722162395293690f, 0.156964725696906750f, + 0.156207196660216040f, + 0.155449575730855880f, 0.154691863354515400f, 0.153934059976937460f, + 0.153176166043917870f, + 0.152418182001306500f, 0.151660108295005400f, 0.150901945370970040f, + 0.150143693675208330f, + 0.149385353653779810f, 0.148626925752796540f, 0.147868410418422360f, + 0.147109808096871850f, + 0.146351119234411440f, 0.145592344277358450f, 0.144833483672080240f, + 0.144074537864995330f, + 0.143315507302571590f, 0.142556392431327340f, 0.141797193697830530f, + 0.141037911548697770f, + 0.140278546430595420f, 0.139519098790238600f, 0.138759569074390380f, + 0.137999957729862760f, + 0.137240265203515700f, 0.136480491942256310f, 0.135720638393040080f, + 0.134960705002868830f, + 0.134200692218792020f, 0.133440600487905820f, 0.132680430257352130f, + 0.131920181974319760f, + 0.131159856086043410f, 0.130399453039802740f, 0.129638973282923540f, + 0.128878417262776660f, + 0.128117785426777150f, 0.127357078222385570f, 0.126596296097105960f, + 0.125835439498487020f, + 0.125074508874121300f, 0.124313504671644300f, 0.123552427338735370f, + 0.122791277323116900f, + 0.122030055072553410f, 0.121268761034852550f, 0.120507395657864240f, + 0.119745959389479630f, + 0.118984452677632520f, 0.118222875970297250f, 0.117461229715489990f, + 0.116699514361267840f, + 0.115937730355727850f, 0.115175878147008180f, 0.114413958183287050f, + 0.113651970912781920f, + 0.112889916783750470f, 0.112127796244489750f, 0.111365609743335190f, + 0.110603357728661910f, + 0.109841040648882680f, 0.109078658952449240f, 0.108316213087851300f, + 0.107553703503615710f, + 0.106791130648307380f, 0.106028494970528530f, 0.105265796918917650f, + 0.104503036942150550f, + 0.103740215488939480f, 0.102977333008032250f, 0.102214389948213370f, + 0.101451386758302160f, + 0.100688323887153970f, 0.099925201783659226f, 0.099162020896742573f, + 0.098398781675363881f, + 0.097635484568517339f, 0.096872130025230527f, 0.096108718494565468f, + 0.095345250425617742f, + 0.094581726267515473f, 0.093818146469420494f, 0.093054511480527333f, + 0.092290821750062355f, + 0.091527077727284981f, 0.090763279861485704f, 0.089999428601987341f, + 0.089235524398144139f, + 0.088471567699340822f, 0.087707558954993645f, 0.086943498614549489f, + 0.086179387127484922f, + 0.085415224943307277f, 0.084651012511553700f, 0.083886750281790226f, + 0.083122438703613077f, + 0.082358078226646619f, 0.081593669300544638f, 0.080829212374989468f, + 0.080064707899690932f, + 0.079300156324387569f, 0.078535558098845590f, 0.077770913672857989f, + 0.077006223496245585f, + 0.076241488018856149f, 0.075476707690563416f, 0.074711882961268378f, + 0.073947014280897269f, + 0.073182102099402888f, 0.072417146866763538f, 0.071652149032982254f, + 0.070887109048087787f, + 0.070122027362133646f, 0.069356904425197236f, 0.068591740687380900f, + 0.067826536598810966f, + 0.067061292609636836f, 0.066296009170032283f, 0.065530686730193397f, + 0.064765325740339871f, + 0.063999926650714078f, 0.063234489911580136f, 0.062469015973224969f, + 0.061703505285957416f, + 0.060937958300107238f, 0.060172375466026218f, 0.059406757234087247f, + 0.058641104054683348f, + 0.057875416378229017f, 0.057109694655158132f, 0.056343939335925283f, + 0.055578150871004817f, + 0.054812329710889909f, 0.054046476306093640f, 0.053280591107148056f, + 0.052514674564603257f, + 0.051748727129028414f, 0.050982749251010900f, 0.050216741381155325f, + 0.049450703970084824f, + 0.048684637468439020f, 0.047918542326875327f, 0.047152418996068000f, + 0.046386267926707213f, + 0.045620089569500123f, 0.044853884375169933f, 0.044087652794454979f, + 0.043321395278109784f, + 0.042555112276904117f, 0.041788804241622082f, 0.041022471623063397f, + 0.040256114872041358f, + 0.039489734439384118f, 0.038723330775933762f, 0.037956904332545366f, + 0.037190455560088091f, + 0.036423984909444228f, 0.035657492831508264f, 0.034890979777187955f, + 0.034124446197403423f, + 0.033357892543086159f, 0.032591319265180385f, 0.031824726814640963f, + 0.031058115642434700f, + 0.030291486199539423f, 0.029524838936943035f, 0.028758174305644590f, + 0.027991492756653365f, + 0.027224794740987910f, 0.026458080709677145f, 0.025691351113759395f, + 0.024924606404281485f, + 0.024157847032300020f, 0.023391073448879338f, 0.022624286105092803f, + 0.021857485452021874f, + 0.021090671940755180f, 0.020323846022389572f, 0.019557008148029204f, + 0.018790158768784596f, + 0.018023298335773701f, 0.017256427300120978f, 0.016489546112956454f, + 0.015722655225417017f, + 0.014955755088644378f, 0.014188846153786343f, 0.013421928871995907f, + 0.012655003694430301f, + 0.011888071072252072f, 0.011121131456628141f, 0.010354185298728884f, + 0.009587233049729183f, + 0.008820275160807512f, 0.008053312083144991f, 0.007286344267926684f, + 0.006519372166339549f, + 0.005752396229573737f, 0.004985416908821652f, 0.004218434655277024f, + 0.003451449920135975f, + 0.002684463154596083f, 0.001917474809855460f, 0.001150485337113809f, + 0.000383495187571497f +}; + +static const float32_t cos_factors_8192[8192] = { + 1.999999990808214700f, 1.999999917273932200f, 1.999999770205369800f, + 1.999999549602533100f, + 1.999999255465430200f, 1.999998887794072000f, 1.999998446588471700f, + 1.999997931848645600f, + 1.999997343574612800f, 1.999996681766395000f, 1.999995946424016200f, + 1.999995137547503600f, + 1.999994255136887000f, 1.999993299192198700f, 1.999992269713474200f, + 1.999991166700750800f, + 1.999989990154069600f, 1.999988740073473500f, 1.999987416459008600f, + 1.999986019310723500f, + 1.999984548628669600f, 1.999983004412901000f, 1.999981386663474400f, + 1.999979695380449400f, + 1.999977930563888100f, 1.999976092213855400f, 1.999974180330418700f, + 1.999972194913648900f, + 1.999970135963618400f, 1.999968003480403000f, 1.999965797464081200f, + 1.999963517914734100f, + 1.999961164832445800f, 1.999958738217302300f, 1.999956238069392900f, + 1.999953664388809800f, + 1.999951017175647600f, 1.999948296430003500f, 1.999945502151977600f, + 1.999942634341672600f, + 1.999939692999193900f, 1.999936678124649700f, 1.999933589718150700f, + 1.999930427779810900f, + 1.999927192309745900f, 1.999923883308075200f, 1.999920500774920300f, + 1.999917044710405500f, + 1.999913515114657900f, 1.999909911987807200f, 1.999906235329986100f, + 1.999902485141329400f, + 1.999898661421975400f, 1.999894764172064600f, 1.999890793391740000f, + 1.999886749081147800f, + 1.999882631240436700f, 1.999878439869758200f, 1.999874174969266300f, + 1.999869836539117700f, + 1.999865424579472000f, 1.999860939090491600f, 1.999856380072341000f, + 1.999851747525188200f, + 1.999847041449203300f, 1.999842261844559700f, 1.999837408711432600f, + 1.999832482050000900f, + 1.999827481860445300f, 1.999822408142949900f, 1.999817260897701400f, + 1.999812040124888700f, + 1.999806745824704000f, 1.999801377997341800f, 1.999795936642999600f, + 1.999790421761877400f, + 1.999784833354177900f, 1.999779171420106700f, 1.999773435959872000f, + 1.999767626973684400f, + 1.999761744461757700f, 1.999755788424308200f, 1.999749758861554900f, + 1.999743655773719400f, + 1.999737479161026100f, 1.999731229023702200f, 1.999724905361977200f, + 1.999718508176084000f, + 1.999712037466257600f, 1.999705493232735800f, 1.999698875475759600f, + 1.999692184195571900f, + 1.999685419392419000f, 1.999678581066549400f, 1.999671669218214600f, + 1.999664683847668800f, + 1.999657624955168700f, 1.999650492540973900f, 1.999643286605346800f, + 1.999636007148552400f, + 1.999628654170857900f, 1.999621227672533800f, 1.999613727653853500f, + 1.999606154115092500f, + 1.999598507056529000f, 1.999590786478444600f, 1.999582992381123000f, + 1.999575124764850800f, + 1.999567183629917100f, 1.999559168976613900f, 1.999551080805236100f, + 1.999542919116081000f, + 1.999534683909448600f, 1.999526375185641800f, 1.999517992944965800f, + 1.999509537187729200f, + 1.999501007914242600f, 1.999492405124819700f, 1.999483728819776900f, + 1.999474978999432800f, + 1.999466155664109600f, 1.999457258814131500f, 1.999448288449825500f, + 1.999439244571521700f, + 1.999430127179552500f, 1.999420936274252800f, 1.999411671855960900f, + 1.999402333925017300f, + 1.999392922481765500f, 1.999383437526551300f, 1.999373879059723500f, + 1.999364247081633500f, + 1.999354541592635500f, 1.999344762593086500f, 1.999334910083345700f, + 1.999324984063775700f, + 1.999314984534741100f, 1.999304911496609700f, 1.999294764949752100f, + 1.999284544894541100f, + 1.999274251331352400f, 1.999263884260564600f, 1.999253443682558900f, + 1.999242929597719200f, + 1.999232342006432000f, 1.999221680909086400f, 1.999210946306074500f, + 1.999200138197791100f, + 1.999189256584633600f, 1.999178301467001900f, 1.999167272845298900f, + 1.999156170719930100f, + 1.999144995091303600f, 1.999133745959830600f, 1.999122423325924200f, + 1.999111027190001000f, + 1.999099557552479900f, 1.999088014413782800f, 1.999076397774334000f, + 1.999064707634560700f, + 1.999052943994892300f, 1.999041106855761900f, 1.999029196217604100f, + 1.999017212080857400f, + 1.999005154445962200f, 1.998993023313361700f, 1.998980818683502100f, + 1.998968540556831800f, + 1.998956188933802800f, 1.998943763814868800f, 1.998931265200486900f, + 1.998918693091116200f, + 1.998906047487219600f, 1.998893328389261400f, 1.998880535797709700f, + 1.998867669713034500f, + 1.998854730135709400f, 1.998841717066209400f, 1.998828630505013400f, + 1.998815470452602400f, + 1.998802236909460500f, 1.998788929876074100f, 1.998775549352932400f, + 1.998762095340527400f, + 1.998748567839354000f, 1.998734966849909000f, 1.998721292372693100f, + 1.998707544408208700f, + 1.998693722956961500f, 1.998679828019459300f, 1.998665859596213500f, + 1.998651817687737300f, + 1.998637702294547000f, 1.998623513417161700f, 1.998609251056103100f, + 1.998594915211895600f, + 1.998580505885066100f, 1.998566023076144600f, 1.998551466785663400f, + 1.998536837014157900f, + 1.998522133762165900f, 1.998507357030227900f, 1.998492506818887200f, + 1.998477583128690100f, + 1.998462585960185000f, 1.998447515313923400f, 1.998432371190459500f, + 1.998417153590349900f, + 1.998401862514154200f, 1.998386497962434800f, 1.998371059935756300f, + 1.998355548434686400f, + 1.998339963459795400f, 1.998324305011656600f, 1.998308573090845200f, + 1.998292767697940100f, + 1.998276888833522300f, 1.998260936498175400f, 1.998244910692486000f, + 1.998228811417043700f, + 1.998212638672439900f, 1.998196392459269400f, 1.998180072778129600f, + 1.998163679629620500f, + 1.998147213014344900f, 1.998130672932908000f, 1.998114059385918400f, + 1.998097372373986300f, + 1.998080611897725700f, 1.998063777957752600f, 1.998046870554686100f, + 1.998029889689147700f, + 1.998012835361761900f, 1.997995707573155600f, 1.997978506323958600f, + 1.997961231614803200f, + 1.997943883446324800f, 1.997926461819161000f, 1.997908966733952500f, + 1.997891398191342400f, + 1.997873756191977000f, 1.997856040736504500f, 1.997838251825576400f, + 1.997820389459846700f, + 1.997802453639972300f, 1.997784444366612600f, 1.997766361640429800f, + 1.997748205462088500f, + 1.997729975832256600f, 1.997711672751604200f, 1.997693296220804000f, + 1.997674846240532000f, + 1.997656322811466500f, 1.997637725934288300f, 1.997619055609681600f, + 1.997600311838332500f, + 1.997581494620930300f, 1.997562603958166600f, 1.997543639850736200f, + 1.997524602299336500f, + 1.997505491304667000f, 1.997486306867430900f, 1.997467048988333000f, + 1.997447717668082000f, + 1.997428312907388200f, 1.997408834706965000f, 1.997389283067528800f, + 1.997369657989798400f, + 1.997349959474495200f, 1.997330187522343700f, 1.997310342134070800f, + 1.997290423310406100f, + 1.997270431052081900f, 1.997250365359833200f, 1.997230226234397900f, + 1.997210013676516700f, + 1.997189727686932400f, 1.997169368266390900f, 1.997148935415640600f, + 1.997128429135433400f, + 1.997107849426522600f, 1.997087196289665000f, 1.997066469725620200f, + 1.997045669735150000f, + 1.997024796319019300f, 1.997003849477995600f, 1.996982829212848900f, + 1.996961735524351900f, + 1.996940568413280600f, 1.996919327880412900f, 1.996898013926530000f, + 1.996876626552415400f, + 1.996855165758855600f, 1.996833631546639300f, 1.996812023916558800f, + 1.996790342869408000f, + 1.996768588405984300f, 1.996746760527087700f, 1.996724859233520500f, + 1.996702884526087900f, + 1.996680836405598100f, 1.996658714872861800f, 1.996636519928692000f, + 1.996614251573904900f, + 1.996591909809319400f, 1.996569494635756600f, 1.996547006054041100f, + 1.996524444064999400f, + 1.996501808669461000f, 1.996479099868258400f, 1.996456317662226300f, + 1.996433462052202600f, + 1.996410533039027400f, 1.996387530623543900f, 1.996364454806597500f, + 1.996341305589037100f, + 1.996318082971713500f, 1.996294786955480800f, 1.996271417541195300f, + 1.996247974729716200f, + 1.996224458521905600f, 1.996200868918628100f, 1.996177205920750800f, + 1.996153469529144100f, + 1.996129659744680300f, 1.996105776568235100f, 1.996081820000686500f, + 1.996057790042915500f, + 1.996033686695805300f, 1.996009509960242400f, 1.995985259837115500f, + 1.995960936327316300f, + 1.995936539431739000f, 1.995912069151280800f, 1.995887525486841300f, + 1.995862908439323100f, + 1.995838218009630800f, 1.995813454198672700f, 1.995788617007359100f, + 1.995763706436603200f, + 1.995738722487320600f, 1.995713665160430600f, 1.995688534456853800f, + 1.995663330377514400f, + 1.995638052923339300f, 1.995612702095257400f, 1.995587277894201400f, + 1.995561780321105600f, + 1.995536209376907600f, 1.995510565062547800f, 1.995484847378968600f, + 1.995459056327116000f, + 1.995433191907938000f, 1.995407254122385700f, 1.995381242971412600f, + 1.995355158455975200f, + 1.995329000577032800f, 1.995302769335546500f, 1.995276464732481200f, + 1.995250086768804100f, + 1.995223635445484900f, 1.995197110763496000f, 1.995170512723813100f, + 1.995143841327413400f, + 1.995117096575278200f, 1.995090278468390600f, 1.995063387007736600f, + 1.995036422194304700f, + 1.995009384029086800f, 1.994982272513076600f, 1.994955087647271000f, + 1.994927829432669800f, + 1.994900497870274900f, 1.994873092961091200f, 1.994845614706126400f, + 1.994818063106391000f, + 1.994790438162897600f, 1.994762739876662100f, 1.994734968248702800f, + 1.994707123280041100f, + 1.994679204971700100f, 1.994651213324707000f, 1.994623148340090700f, + 1.994595010018883000f, + 1.994566798362118300f, 1.994538513370834200f, 1.994510155046070700f, + 1.994481723388870100f, + 1.994453218400277900f, 1.994424640081342100f, 1.994395988433113700f, + 1.994367263456646100f, + 1.994338465152995000f, 1.994309593523219600f, 1.994280648568381500f, + 1.994251630289544600f, + 1.994222538687776100f, 1.994193373764145500f, 1.994164135519725000f, + 1.994134823955589800f, + 1.994105439072817700f, 1.994075980872488800f, 1.994046449355686200f, + 1.994016844523496000f, + 1.993987166377006600f, 1.993957414917308700f, 1.993927590145496900f, + 1.993897692062667200f, + 1.993867720669919400f, 1.993837675968354700f, 1.993807557959078600f, + 1.993777366643197900f, + 1.993747102021822900f, 1.993716764096066200f, 1.993686352867043200f, + 1.993655868335872300f, + 1.993625310503674100f, 1.993594679371572200f, 1.993563974940692800f, + 1.993533197212164800f, + 1.993502346187119700f, 1.993471421866692200f, 1.993440424252018900f, + 1.993409353344239600f, + 1.993378209144496700f, 1.993346991653935300f, 1.993315700873703200f, + 1.993284336804950900f, + 1.993252899448831400f, 1.993221388806500900f, 1.993189804879117500f, + 1.993158147667842800f, + 1.993126417173840500f, 1.993094613398277400f, 1.993062736342323000f, + 1.993030786007148800f, + 1.992998762393930000f, 1.992966665503844000f, 1.992934495338070800f, + 1.992902251897793000f, + 1.992869935184196300f, 1.992837545198469000f, 1.992805081941801700f, + 1.992772545415388200f, + 1.992739935620424700f, 1.992707252558110200f, 1.992674496229646500f, + 1.992641666636237700f, + 1.992608763779091000f, 1.992575787659416100f, 1.992542738278425300f, + 1.992509615637334100f, + 1.992476419737359900f, 1.992443150579723500f, 1.992409808165648100f, + 1.992376392496359300f, + 1.992342903573086000f, 1.992309341397059600f, 1.992275705969513800f, + 1.992241997291685400f, + 1.992208215364813700f, 1.992174360190140900f, 1.992140431768911500f, + 1.992106430102373400f, + 1.992072355191776300f, 1.992038207038373300f, 1.992003985643419700f, + 1.991969691008174100f, + 1.991935323133897000f, 1.991900882021852200f, 1.991866367673306200f, + 1.991831780089527500f, + 1.991797119271788300f, 1.991762385221362600f, 1.991727577939527600f, + 1.991692697427563300f, + 1.991657743686751700f, 1.991622716718378400f, 1.991587616523731000f, + 1.991552443104099800f, + 1.991517196460778500f, 1.991481876595062800f, 1.991446483508251500f, + 1.991411017201645500f, + 1.991375477676549100f, 1.991339864934268800f, 1.991304178976114100f, + 1.991268419803397200f, + 1.991232587417432600f, 1.991196681819537900f, 1.991160703011033200f, + 1.991124650993241400f, + 1.991088525767488200f, 1.991052327335101300f, 1.991016055697411900f, + 1.990979710855753900f, + 1.990943292811463000f, 1.990906801565878600f, 1.990870237120342400f, + 1.990833599476198800f, + 1.990796888634794400f, 1.990760104597479400f, 1.990723247365606200f, + 1.990686316940529800f, + 1.990649313323608100f, 1.990612236516201300f, 1.990575086519673200f, + 1.990537863335389400f, + 1.990500566964718400f, 1.990463197409031700f, 1.990425754669703100f, + 1.990388238748109100f, + 1.990350649645629600f, 1.990312987363646000f, 1.990275251903543600f, + 1.990237443266709400f, + 1.990199561454533600f, 1.990161606468409300f, 1.990123578309731700f, + 1.990085476979899000f, + 1.990047302480312300f, 1.990009054812374800f, 1.989970733977493000f, + 1.989932339977075900f, + 1.989893872812535000f, 1.989855332485284800f, 1.989816718996742200f, + 1.989778032348326700f, + 1.989739272541461100f, 1.989700439577570400f, 1.989661533458082100f, + 1.989622554184426800f, + 1.989583501758037700f, 1.989544376180350600f, 1.989505177452804100f, + 1.989465905576839600f, + 1.989426560553900500f, 1.989387142385433900f, 1.989347651072888900f, + 1.989308086617717500f, + 1.989268449021374300f, 1.989228738285316900f, 1.989188954411005100f, + 1.989149097399901500f, + 1.989109167253472000f, 1.989069163973184300f, 1.989029087560509700f, + 1.988988938016921000f, + 1.988948715343894900f, 1.988908419542910100f, 1.988868050615448100f, + 1.988827608562993200f, + 1.988787093387032600f, 1.988746505089055600f, 1.988705843670554500f, + 1.988665109133024500f, + 1.988624301477963200f, 1.988583420706871100f, 1.988542466821251000f, + 1.988501439822608900f, + 1.988460339712453200f, 1.988419166492295000f, 1.988377920163648000f, + 1.988336600728029000f, + 1.988295208186956700f, 1.988253742541953800f, 1.988212203794544000f, + 1.988170591946255100f, + 1.988128906998616800f, 1.988087148953161700f, 1.988045317811425700f, + 1.988003413574946000f, + 1.987961436245263800f, 1.987919385823922400f, 1.987877262312467600f, + 1.987835065712448600f, + 1.987792796025416500f, 1.987750453252925500f, 1.987708037396532800f, + 1.987665548457797400f, + 1.987622986438281700f, 1.987580351339550700f, 1.987537643163171700f, + 1.987494861910715100f, + 1.987452007583754100f, 1.987409080183863800f, 1.987366079712622900f, + 1.987323006171612500f, + 1.987279859562415900f, 1.987236639886619700f, 1.987193347145813000f, + 1.987149981341587400f, + 1.987106542475537400f, 1.987063030549260300f, 1.987019445564355700f, + 1.986975787522426100f, + 1.986932056425076800f, 1.986888252273915500f, 1.986844375070552900f, + 1.986800424816602200f, + 1.986756401513679400f, 1.986712305163403000f, 1.986668135767394300f, + 1.986623893327277500f, + 1.986579577844678900f, 1.986535189321228000f, 1.986490727758556800f, + 1.986446193158300400f, + 1.986401585522095600f, 1.986356904851583000f, 1.986312151148405200f, + 1.986267324414207500f, + 1.986222424650638400f, 1.986177451859348200f, 1.986132406041990900f, + 1.986087287200222700f, + 1.986042095335702300f, 1.985996830450091200f, 1.985951492545054100f, + 1.985906081622257300f, + 1.985860597683371000f, 1.985815040730067200f, 1.985769410764020900f, + 1.985723707786909900f, + 1.985677931800414500f, 1.985632082806217900f, 1.985586160806005700f, + 1.985540165801466200f, + 1.985494097794290800f, 1.985447956786173100f, 1.985401742778809500f, + 1.985355455773899500f, + 1.985309095773144500f, 1.985262662778249300f, 1.985216156790921000f, + 1.985169577812869500f, + 1.985122925845807400f, 1.985076200891450000f, 1.985029402951515200f, + 1.984982532027723700f, + 1.984935588121798700f, 1.984888571235466200f, 1.984841481370454900f, + 1.984794318528496200f, + 1.984747082711324100f, 1.984699773920675300f, 1.984652392158289500f, + 1.984604937425908300f, + 1.984557409725276700f, 1.984509809058142300f, 1.984462135426255000f, + 1.984414388831367900f, + 1.984366569275236400f, 1.984318676759618400f, 1.984270711286275200f, + 1.984222672856969800f, + 1.984174561473469200f, 1.984126377137541700f, 1.984078119850959200f, + 1.984029789615495900f, + 1.983981386432928800f, 1.983932910305037400f, 1.983884361233604100f, + 1.983835739220414000f, + 1.983787044267254700f, 1.983738276375916800f, 1.983689435548192900f, + 1.983640521785879200f, + 1.983591535090773800f, 1.983542475464678000f, 1.983493342909395500f, + 1.983444137426732600f, + 1.983394859018498900f, 1.983345507686505900f, 1.983296083432567900f, + 1.983246586258502700f, + 1.983197016166129400f, 1.983147373157271300f, 1.983097657233753100f, + 1.983047868397403100f, + 1.982998006650051400f, 1.982948071993531700f, 1.982898064429679900f, + 1.982847983960334600f, + 1.982797830587336800f, 1.982747604312531200f, 1.982697305137763700f, + 1.982646933064884200f, + 1.982596488095744300f, 1.982545970232199000f, 1.982495379476105800f, + 1.982444715829324600f, + 1.982393979293718200f, 1.982343169871152000f, 1.982292287563494300f, + 1.982241332372615600f, + 1.982190304300389400f, 1.982139203348692200f, 1.982088029519402300f, + 1.982036782814401900f, + 1.981985463235574700f, 1.981934070784807400f, 1.981882605463990200f, + 1.981831067275015000f, + 1.981779456219776600f, 1.981727772300172500f, 1.981676015518103500f, + 1.981624185875472000f, + 1.981572283374183800f, 1.981520308016147200f, 1.981468259803273300f, + 1.981416138737475800f, + 1.981363944820670800f, 1.981311678054777500f, 1.981259338441717400f, + 1.981206925983415300f, + 1.981154440681797800f, 1.981101882538794900f, 1.981049251556338900f, + 1.980996547736364900f, + 1.980943771080810700f, 1.980890921591616600f, 1.980837999270726100f, + 1.980785004120084700f, + 1.980731936141640900f, 1.980678795337345900f, 1.980625581709153600f, + 1.980572295259020600f, + 1.980518935988905700f, 1.980465503900771000f, 1.980411998996581200f, + 1.980358421278303200f, + 1.980304770747907300f, 1.980251047407365600f, 1.980197251258653900f, + 1.980143382303749500f, + 1.980089440544633600f, 1.980035425983289300f, 1.979981338621702200f, + 1.979927178461861500f, + 1.979872945505758000f, 1.979818639755386100f, 1.979764261212742400f, + 1.979709809879825800f, + 1.979655285758638900f, 1.979600688851186100f, 1.979546019159474900f, + 1.979491276685515300f, + 1.979436461431320000f, 1.979381573398904400f, 1.979326612590286400f, + 1.979271579007487100f, + 1.979216472652529900f, 1.979161293527440500f, 1.979106041634248100f, + 1.979050716974983800f, + 1.978995319551682100f, 1.978939849366379700f, 1.978884306421115900f, + 1.978828690717932900f, + 1.978773002258875600f, 1.978717241045991700f, 1.978661407081331100f, + 1.978605500366946700f, + 1.978549520904894000f, 1.978493468697231300f, 1.978437343746019600f, + 1.978381146053322000f, + 1.978324875621205300f, 1.978268532451738200f, 1.978212116546992100f, + 1.978155627909041300f, + 1.978099066539962900f, 1.978042432441836400f, 1.977985725616743900f, + 1.977928946066770600f, + 1.977872093794004200f, 1.977815168800534500f, 1.977758171088455100f, + 1.977701100659861300f, + 1.977643957516851400f, 1.977586741661526500f, 1.977529453095990200f, + 1.977472091822348700f, + 1.977414657842711200f, 1.977357151159189400f, 1.977299571773897700f, + 1.977241919688953000f, + 1.977184194906475000f, 1.977126397428586000f, 1.977068527257411300f, + 1.977010584395078300f, + 1.976952568843717700f, 1.976894480605462500f, 1.976836319682448300f, + 1.976778086076813600f, + 1.976719779790699500f, 1.976661400826249500f, 1.976602949185610500f, + 1.976544424870931400f, + 1.976485827884363800f, 1.976427158228062100f, 1.976368415904183900f, + 1.976309600914888400f, + 1.976250713262338600f, 1.976191752948699200f, 1.976132719976138000f, + 1.976073614346825800f, + 1.976014436062935700f, 1.975955185126643300f, 1.975895861540127200f, + 1.975836465305568400f, + 1.975776996425151000f, 1.975717454901061400f, 1.975657840735488800f, + 1.975598153930624900f, + 1.975538394488664200f, 1.975478562411804100f, 1.975418657702244300f, + 1.975358680362187400f, + 1.975298630393838500f, 1.975238507799405500f, 1.975178312581099100f, + 1.975118044741132300f, + 1.975057704281721000f, 1.974997291205083700f, 1.974936805513442000f, + 1.974876247209019100f, + 1.974815616294042200f, 1.974754912770740200f, 1.974694136641345300f, + 1.974633287908091500f, + 1.974572366573216400f, 1.974511372638960000f, 1.974450306107564900f, + 1.974389166981275900f, + 1.974327955262341400f, 1.974266670953011400f, 1.974205314055540000f, + 1.974143884572182400f, + 1.974082382505197400f, 1.974020807856846400f, 1.973959160629393100f, + 1.973897440825104200f, + 1.973835648446248900f, 1.973773783495099500f, 1.973711845973930000f, + 1.973649835885018100f, + 1.973587753230643400f, 1.973525598013088800f, 1.973463370234639600f, + 1.973401069897583200f, + 1.973338697004211100f, 1.973276251556815600f, 1.973213733557693400f, + 1.973151143009142800f, + 1.973088479913465100f, 1.973025744272964200f, 1.972962936089946800f, + 1.972900055366722000f, + 1.972837102105601900f, 1.972774076308901200f, 1.972710977978936900f, + 1.972647807118029300f, + 1.972584563728500700f, 1.972521247812676600f, 1.972457859372884500f, + 1.972394398411455800f, + 1.972330864930723200f, 1.972267258933022600f, 1.972203580420693000f, + 1.972139829396075200f, + 1.972076005861513700f, 1.972012109819354600f, 1.971948141271947500f, + 1.971884100221644300f, + 1.971819986670799500f, 1.971755800621770400f, 1.971691542076916800f, + 1.971627211038601500f, + 1.971562807509189800f, 1.971498331491049700f, 1.971433782986551400f, + 1.971369161998068400f, + 1.971304468527976800f, 1.971239702578655000f, 1.971174864152484400f, + 1.971109953251848600f, + 1.971044969879134600f, 1.970979914036731500f, 1.970914785727030800f, + 1.970849584952427900f, + 1.970784311715319400f, 1.970718966018105500f, 1.970653547863188600f, + 1.970588057252973900f, + 1.970522494189869800f, 1.970456858676286300f, 1.970391150714636800f, + 1.970325370307337100f, + 1.970259517456806100f, 1.970193592165464700f, 1.970127594435737000f, + 1.970061524270049400f, + 1.969995381670831100f, 1.969929166640514100f, 1.969862879181532700f, + 1.969796519296324300f, + 1.969730086987328900f, 1.969663582256988600f, 1.969597005107748900f, + 1.969530355542057800f, + 1.969463633562365400f, 1.969396839171125200f, 1.969329972370792700f, + 1.969263033163826800f, + 1.969196021552688500f, 1.969128937539841500f, 1.969061781127752400f, + 1.968994552318890300f, + 1.968927251115727200f, 1.968859877520737300f, 1.968792431536398000f, + 1.968724913165188900f, + 1.968657322409592500f, 1.968589659272094000f, 1.968521923755181000f, + 1.968454115861344000f, + 1.968386235593076300f, 1.968318282952873600f, 1.968250257943234200f, + 1.968182160566659000f, + 1.968113990825652200f, 1.968045748722719900f, 1.967977434260371300f, + 1.967909047441118100f, + 1.967840588267474500f, 1.967772056741957900f, 1.967703452867087800f, + 1.967634776645386600f, + 1.967566028079379200f, 1.967497207171593500f, 1.967428313924559600f, + 1.967359348340810700f, + 1.967290310422882700f, 1.967221200173313400f, 1.967152017594644200f, + 1.967082762689418500f, + 1.967013435460182700f, 1.966944035909485600f, 1.966874564039879300f, + 1.966805019853917500f, + 1.966735403354157500f, 1.966665714543159000f, 1.966595953423483800f, + 1.966526119997697100f, + 1.966456214268366600f, 1.966386236238062200f, 1.966316185909357200f, + 1.966246063284826700f, + 1.966175868367049400f, 1.966105601158605600f, 1.966035261662079300f, + 1.965964849880056600f, + 1.965894365815126000f, 1.965823809469879400f, 1.965753180846910900f, + 1.965682479948817100f, + 1.965611706778197700f, 1.965540861337654600f, 1.965469943629792700f, + 1.965398953657219600f, + 1.965327891422544900f, 1.965256756928382100f, 1.965185550177345900f, + 1.965114271172054800f, + 1.965042919915129400f, 1.964971496409193100f, 1.964900000656872000f, + 1.964828432660794500f, + 1.964756792423592200f, 1.964685079947899200f, 1.964613295236352000f, + 1.964541438291590000f, + 1.964469509116255000f, 1.964397507712991800f, 1.964325434084447600f, + 1.964253288233272400f, + 1.964181070162119000f, 1.964108779873642100f, 1.964036417370500300f, + 1.963963982655353400f, + 1.963891475730865400f, 1.963818896599701400f, 1.963746245264530700f, + 1.963673521728023900f, + 1.963600725992855200f, 1.963527858061700600f, 1.963454917937239800f, + 1.963381905622154400f, + 1.963308821119128700f, 1.963235664430850200f, 1.963162435560008100f, + 1.963089134509295300f, + 1.963015761281406800f, 1.962942315879040000f, 1.962868798304895400f, + 1.962795208561676200f, + 1.962721546652088200f, 1.962647812578839400f, 1.962574006344640900f, + 1.962500127952206300f, + 1.962426177404252200f, 1.962352154703497200f, 1.962278059852663000f, + 1.962203892854473800f, + 1.962129653711656800f, 1.962055342426941400f, 1.961980959003059500f, + 1.961906503442746300f, + 1.961831975748739200f, 1.961757375923778700f, 1.961682703970607100f, + 1.961607959891970200f, + 1.961533143690616000f, 1.961458255369295400f, 1.961383294930761700f, + 1.961308262377770900f, + 1.961233157713082200f, 1.961157980939456400f, 1.961082732059657800f, + 1.961007411076453000f, + 1.960932017992611500f, 1.960856552810905200f, 1.960781015534108800f, + 1.960705406164999300f, + 1.960629724706357100f, 1.960553971160964500f, 1.960478145531606700f, + 1.960402247821071900f, + 1.960326278032150200f, 1.960250236167635100f, 1.960174122230322400f, + 1.960097936223010400f, + 1.960021678148500500f, 1.959945348009596500f, 1.959868945809104500f, + 1.959792471549834000f, + 1.959715925234596600f, 1.959639306866206600f, 1.959562616447480900f, + 1.959485853981239600f, + 1.959409019470304700f, 1.959332112917501400f, 1.959255134325657000f, + 1.959178083697602300f, + 1.959100961036169800f, 1.959023766344195200f, 1.958946499624516700f, + 1.958869160879975500f, + 1.958791750113414700f, 1.958714267327680500f, 1.958636712525621900f, + 1.958559085710090500f, + 1.958481386883940100f, 1.958403616050027600f, 1.958325773211212300f, + 1.958247858370356400f, + 1.958169871530324600f, 1.958091812693984400f, 1.958013681864205500f, + 1.957935479043860600f, + 1.957857204235825100f, 1.957778857442976900f, 1.957700438668196700f, + 1.957621947914367500f, + 1.957543385184375300f, 1.957464750481108700f, 1.957386043807458800f, + 1.957307265166319500f, + 1.957228414560587200f, 1.957149491993160900f, 1.957070497466942400f, + 1.956991430984836400f, + 1.956912292549749500f, 1.956833082164591600f, 1.956753799832275300f, + 1.956674445555715000f, + 1.956595019337829000f, 1.956515521181537000f, 1.956435951089762200f, + 1.956356309065430100f, + 1.956276595111468900f, 1.956196809230809500f, 1.956116951426385600f, + 1.956037021701132900f, + 1.955957020057990500f, 1.955876946499899700f, 1.955796801029804800f, + 1.955716583650652000f, + 1.955636294365391300f, 1.955555933176974300f, 1.955475500088355900f, + 1.955394995102493100f, + 1.955314418222346100f, 1.955233769450877200f, 1.955153048791052000f, + 1.955072256245838000f, + 1.954991391818206000f, 1.954910455511129000f, 1.954829447327582900f, + 1.954748367270545900f, + 1.954667215342999600f, 1.954585991547927100f, 1.954504695888315000f, + 1.954423328367152600f, + 1.954341888987431100f, 1.954260377752145000f, 1.954178794664291200f, + 1.954097139726869600f, + 1.954015412942881900f, 1.953933614315333200f, 1.953851743847231100f, + 1.953769801541585400f, + 1.953687787401409400f, 1.953605701429718100f, 1.953523543629529700f, + 1.953441314003864900f, + 1.953359012555747200f, 1.953276639288202400f, 1.953194194204259200f, + 1.953111677306948800f, + 1.953029088599305100f, 1.952946428084364900f, 1.952863695765167100f, + 1.952780891644753500f, + 1.952698015726169100f, 1.952615068012460300f, 1.952532048506677300f, + 1.952448957211872200f, + 1.952365794131100300f, 1.952282559267419100f, 1.952199252623889200f, + 1.952115874203572900f, + 1.952032424009536600f, 1.951948902044847900f, 1.951865308312577900f, + 1.951781642815800100f, + 1.951697905557590700f, 1.951614096541028500f, 1.951530215769194700f, + 1.951446263245173500f, + 1.951362238972051500f, 1.951278142952918200f, 1.951193975190865600f, + 1.951109735688987900f, + 1.951025424450382900f, 1.950941041478150100f, 1.950856586775392200f, + 1.950772060345214300f, + 1.950687462190724200f, 1.950602792315032200f, 1.950518050721251600f, + 1.950433237412498000f, + 1.950348352391889600f, 1.950263395662547700f, 1.950178367227595900f, + 1.950093267090159800f, + 1.950008095253369200f, 1.949922851720355100f, 1.949837536494251700f, + 1.949752149578196000f, + 1.949666690975327100f, 1.949581160688787400f, 1.949495558721721500f, + 1.949409885077276500f, + 1.949324139758602700f, 1.949238322768852800f, 1.949152434111181700f, + 1.949066473788747300f, + 1.948980441804710300f, 1.948894338162233900f, 1.948808162864483600f, + 1.948721915914628100f, + 1.948635597315838200f, 1.948549207071288000f, 1.948462745184153400f, + 1.948376211657613500f, + 1.948289606494849800f, 1.948202929699046800f, 1.948116181273391100f, + 1.948029361221072400f, + 1.947942469545282500f, 1.947855506249216700f, 1.947768471336071700f, + 1.947681364809048100f, + 1.947594186671348000f, 1.947506936926177300f, 1.947419615576743600f, + 1.947332222626257500f, + 1.947244758077932200f, 1.947157221934983500f, 1.947069614200629900f, + 1.946981934878092300f, + 1.946894183970594900f, 1.946806361481363500f, 1.946718467413627300f, + 1.946630501770618000f, + 1.946542464555569800f, 1.946454355771719300f, 1.946366175422306500f, + 1.946277923510573200f, + 1.946189600039764300f, 1.946101205013127000f, 1.946012738433911600f, + 1.945924200305370700f, + 1.945835590630759400f, 1.945746909413335900f, 1.945658156656360700f, + 1.945569332363096700f, + 1.945480436536810100f, 1.945391469180769200f, 1.945302430298244900f, + 1.945213319892511200f, + 1.945124137966844200f, 1.945034884524523100f, 1.944945559568829200f, + 1.944856163103046800f, + 1.944766695130463000f, 1.944677155654366900f, 1.944587544678050900f, + 1.944497862204809900f, + 1.944408108237940700f, 1.944318282780743900f, 1.944228385836521700f, + 1.944138417408579400f, + 1.944048377500225100f, 1.943958266114769200f, 1.943868083255524800f, + 1.943777828925807600f, + 1.943687503128936200f, 1.943597105868231500f, 1.943506637147017300f, + 1.943416096968619400f, + 1.943325485336367300f, 1.943234802253592400f, 1.943144047723628400f, + 1.943053221749812400f, + 1.942962324335484100f, 1.942871355483985200f, 1.942780315198660200f, + 1.942689203482856900f, + 1.942598020339924700f, 1.942506765773216500f, 1.942415439786087300f, + 1.942324042381895000f, + 1.942232573564000000f, 1.942141033335765400f, 1.942049421700556600f, + 1.941957738661741900f, + 1.941865984222692900f, 1.941774158386782200f, 1.941682261157386700f, + 1.941590292537884700f, + 1.941498252531658200f, 1.941406141142090600f, 1.941313958372568900f, + 1.941221704226482500f, + 1.941129378707223000f, 1.941036981818185400f, 1.940944513562766300f, + 1.940851973944365900f, + 1.940759362966386600f, 1.940666680632233200f, 1.940573926945313700f, + 1.940481101909038200f, + 1.940388205526819600f, 1.940295237802073500f, 1.940202198738217900f, + 1.940109088338673600f, + 1.940015906606864300f, 1.939922653546215500f, 1.939829329160156500f, + 1.939735933452118000f, + 1.939642466425534300f, 1.939548928083841800f, 1.939455318430479500f, + 1.939361637468889100f, + 1.939267885202515400f, 1.939174061634805000f, 1.939080166769207700f, + 1.938986200609175600f, + 1.938892163158163700f, 1.938798054419629500f, 1.938703874397032800f, + 1.938609623093837000f, + 1.938515300513506700f, 1.938420906659510600f, 1.938326441535318500f, + 1.938231905144404400f, + 1.938137297490243500f, 1.938042618576314400f, 1.937947868406098500f, + 1.937853046983079300f, + 1.937758154310742900f, 1.937663190392578500f, 1.937568155232077600f, + 1.937473048832734500f, + 1.937377871198045600f, 1.937282622331510500f, 1.937187302236631500f, + 1.937091910916912900f, + 1.936996448375861900f, 1.936900914616988900f, 1.936805309643805800f, + 1.936709633459828200f, + 1.936613886068573500f, 1.936518067473562300f, 1.936422177678317300f, + 1.936326216686364400f, + 1.936230184501231500f, 1.936134081126449800f, 1.936037906565552400f, + 1.935941660822075600f, + 1.935845343899558000f, 1.935748955801540800f, 1.935652496531568000f, + 1.935555966093186300f, + 1.935459364489944500f, 1.935362691725394500f, 1.935265947803090900f, + 1.935169132726590500f, + 1.935072246499453000f, 1.934975289125240500f, 1.934878260607517900f, + 1.934781160949852600f, + 1.934683990155814800f, 1.934586748228977100f, 1.934489435172914900f, + 1.934392050991206300f, + 1.934294595687431300f, 1.934197069265173500f, 1.934099471728018700f, + 1.934001803079554700f, + 1.933904063323373300f, 1.933806252463067500f, 1.933708370502233800f, + 1.933610417444471000f, + 1.933512393293380600f, 1.933414298052566600f, 1.933316131725635800f, + 1.933217894316197300f, + 1.933119585827862900f, 1.933021206264247600f, 1.932922755628968100f, + 1.932824233925644300f, + 1.932725641157898600f, 1.932626977329356100f, 1.932528242443643900f, + 1.932429436504392800f, + 1.932330559515235100f, 1.932231611479806800f, 1.932132592401745400f, + 1.932033502284691700f, + 1.931934341132289100f, 1.931835108948183300f, 1.931735805736022800f, + 1.931636431499459000f, + 1.931536986242145200f, 1.931437469967737900f, 1.931337882679895900f, + 1.931238224382281000f, + 1.931138495078557300f, 1.931038694772391200f, 1.930938823467452500f, + 1.930838881167413100f, + 1.930738867875947400f, 1.930638783596732700f, 1.930538628333448900f, + 1.930438402089778200f, + 1.930338104869405900f, 1.930237736676019500f, 1.930137297513309300f, + 1.930036787384968200f, + 1.929936206294691400f, 1.929835554246177400f, 1.929734831243126600f, + 1.929634037289242400f, + 1.929533172388230700f, 1.929432236543799900f, 1.929331229759661200f, + 1.929230152039528500f, + 1.929129003387117800f, 1.929027783806148300f, 1.928926493300341400f, + 1.928825131873421500f, + 1.928723699529115000f, 1.928622196271151800f, 1.928520622103263400f, + 1.928418977029184600f, + 1.928317261052652700f, 1.928215474177407100f, 1.928113616407190600f, + 1.928011687745748300f, + 1.927909688196827400f, 1.927807617764178300f, 1.927705476451554000f, + 1.927603264262709900f, + 1.927500981201404100f, 1.927398627271397000f, 1.927296202476451900f, + 1.927193706820335100f, + 1.927091140306814500f, 1.926988502939661400f, 1.926885794722649600f, + 1.926783015659555300f, + 1.926680165754157500f, 1.926577245010237400f, 1.926474253431579500f, + 1.926371191021970100f, + 1.926268057785198700f, 1.926164853725057300f, 1.926061578845340600f, + 1.925958233149845000f, + 1.925854816642371000f, 1.925751329326720600f, 1.925647771206698600f, + 1.925544142286112800f, + 1.925440442568773000f, 1.925336672058492300f, 1.925232830759086000f, + 1.925128918674371900f, + 1.925024935808170600f, 1.924920882164305300f, 1.924816757746601800f, + 1.924712562558888100f, + 1.924608296604995800f, 1.924503959888757900f, 1.924399552414010700f, + 1.924295074184593000f, + 1.924190525204346300f, 1.924085905477114400f, 1.923981215006744100f, + 1.923876453797084300f, + 1.923771621851986700f, 1.923666719175306100f, 1.923561745770898900f, + 1.923456701642625200f, + 1.923351586794346900f, 1.923246401229928600f, 1.923141144953238300f, + 1.923035817968145300f, + 1.922930420278522500f, 1.922824951888245000f, 1.922719412801190600f, + 1.922613803021239600f, + 1.922508122552275100f, 1.922402371398182600f, 1.922296549562850100f, + 1.922190657050168800f, + 1.922084693864031700f, 1.921978660008334600f, 1.921872555486976700f, + 1.921766380303858500f, + 1.921660134462884100f, 1.921553817967959900f, 1.921447430822994500f, + 1.921340973031900000f, + 1.921234444598590100f, 1.921127845526981600f, 1.921021175820994100f, + 1.920914435484549100f, + 1.920807624521571700f, 1.920700742935988600f, 1.920593790731729600f, + 1.920486767912727300f, + 1.920379674482916500f, 1.920272510446234400f, 1.920165275806621400f, + 1.920057970568020100f, + 1.919950594734376000f, 1.919843148309637000f, 1.919735631297753400f, + 1.919628043702678300f, + 1.919520385528367300f, 1.919412656778779000f, 1.919304857457874200f, + 1.919196987569616200f, + 1.919089047117971100f, 1.918981036106907700f, 1.918872954540397300f, + 1.918764802422413500f, + 1.918656579756932800f, 1.918548286547934400f, 1.918439922799399800f, + 1.918331488515313300f, + 1.918222983699661600f, 1.918114408356434300f, 1.918005762489623400f, + 1.917897046103223200f, + 1.917788259201231200f, 1.917679401787647100f, 1.917570473866473200f, + 1.917461475441714500f, + 1.917352406517378600f, 1.917243267097475700f, 1.917134057186018300f, + 1.917024776787022100f, + 1.916915425904504700f, 1.916806004542486800f, 1.916696512704991500f, + 1.916586950396044400f, + 1.916477317619674100f, 1.916367614379911100f, 1.916257840680788900f, + 1.916147996526343700f, + 1.916038081920614400f, 1.915928096867641800f, 1.915818041371470000f, + 1.915707915436145200f, + 1.915597719065716700f, 1.915487452264236000f, 1.915377115035757200f, + 1.915266707384337200f, + 1.915156229314035200f, 1.915045680828913400f, 1.914935061933036300f, + 1.914824372630470800f, + 1.914713612925287100f, 1.914602782821557000f, 1.914491882323355700f, + 1.914380911434760500f, + 1.914269870159851700f, 1.914158758502712000f, 1.914047576467426500f, + 1.913936324058083100f, + 1.913825001278772100f, 1.913713608133586600f, 1.913602144626622500f, + 1.913490610761977600f, + 1.913379006543752800f, 1.913267331976051400f, 1.913155587062979500f, + 1.913043771808645700f, + 1.912931886217160900f, 1.912819930292639000f, 1.912707904039196300f, + 1.912595807460951500f, + 1.912483640562026200f, 1.912371403346544400f, 1.912259095818632700f, + 1.912146717982420500f, + 1.912034269842039600f, 1.911921751401624200f, 1.911809162665311500f, + 1.911696503637241100f, + 1.911583774321554700f, 1.911470974722397500f, 1.911358104843916500f, + 1.911245164690262000f, + 1.911132154265586100f, 1.911019073574044200f, 1.910905922619793800f, + 1.910792701406995000f, + 1.910679409939810600f, 1.910566048222406300f, 1.910452616258949900f, + 1.910339114053611900f, + 1.910225541610565800f, 1.910111898933986900f, 1.909998186028053700f, + 1.909884402896947100f, + 1.909770549544850500f, 1.909656625975950200f, 1.909542632194434700f, + 1.909428568204495100f, + 1.909314434010325400f, 1.909200229616121700f, 1.909085955026083200f, + 1.908971610244411600f, + 1.908857195275310800f, 1.908742710122987700f, 1.908628154791651300f, + 1.908513529285513500f, + 1.908398833608789100f, 1.908284067765694900f, 1.908169231760450400f, + 1.908054325597278200f, + 1.907939349280402400f, 1.907824302814050900f, 1.907709186202453600f, + 1.907593999449842800f, + 1.907478742560453600f, 1.907363415538523700f, 1.907248018388293400f, + 1.907132551114005600f, + 1.907017013719905600f, 1.906901406210241200f, 1.906785728589263300f, + 1.906669980861224900f, + 1.906554163030381500f, 1.906438275100991600f, 1.906322317077316300f, + 1.906206288963618700f, + 1.906090190764164700f, 1.905974022483223300f, 1.905857784125065500f, + 1.905741475693964800f, + 1.905625097194197900f, 1.905508648630043700f, 1.905392130005783400f, + 1.905275541325701400f, + 1.905158882594083900f, 1.905042153815220700f, 1.904925354993402900f, + 1.904808486132925300f, + 1.904691547238084800f, 1.904574538313180700f, 1.904457459362515200f, + 1.904340310390393100f, + 1.904223091401121600f, 1.904105802399010300f, 1.903988443388371600f, + 1.903871014373520700f, + 1.903753515358774800f, 1.903635946348454500f, 1.903518307346881800f, + 1.903400598358382600f, + 1.903282819387284200f, 1.903164970437917400f, 1.903047051514615000f, + 1.902929062621712600f, + 1.902811003763547900f, 1.902692874944462300f, 1.902574676168798700f, + 1.902456407440902700f, + 1.902338068765123200f, 1.902219660145810800f, 1.902101181587319000f, + 1.901982633094004200f, + 1.901864014670225000f, 1.901745326320342500f, 1.901626568048721000f, + 1.901507739859726200f, + 1.901388841757727600f, 1.901269873747096600f, 1.901150835832207100f, + 1.901031728017436300f, + 1.900912550307162700f, 1.900793302705768900f, 1.900673985217638900f, + 1.900554597847159400f, + 1.900435140598720500f, 1.900315613476714100f, 1.900196016485534700f, + 1.900076349629579600f, + 1.899956612913248800f, 1.899836806340944300f, 1.899716929917071500f, + 1.899596983646037600f, + 1.899476967532252900f, 1.899356881580129800f, 1.899236725794083600f, + 1.899116500178532200f, + 1.898996204737895900f, 1.898875839476597700f, 1.898755404399062900f, + 1.898634899509719500f, + 1.898514324812998300f, 1.898393680313332600f, 1.898272966015157800f, + 1.898152181922912600f, + 1.898031328041037700f, 1.897910404373976500f, 1.897789410926175000f, + 1.897668347702081900f, + 1.897547214706148300f, 1.897426011942827900f, 1.897304739416577200f, + 1.897183397131854600f, + 1.897061985093121800f, 1.896940503304842800f, 1.896818951771484000f, + 1.896697330497514800f, + 1.896575639487406300f, 1.896453878745633100f, 1.896332048276672100f, + 1.896210148085002400f, + 1.896088178175106200f, 1.895966138551467700f, 1.895844029218574100f, + 1.895721850180915000f, + 1.895599601442982600f, 1.895477283009271400f, 1.895354894884279100f, + 1.895232437072505300f, + 1.895109909578452500f, 1.894987312406625700f, 1.894864645561532100f, + 1.894741909047682500f, + 1.894619102869589100f, 1.894496227031767100f, 1.894373281538734400f, + 1.894250266395011600f, + 1.894127181605121100f, 1.894004027173588700f, 1.893880803104942600f, + 1.893757509403713100f, + 1.893634146074433500f, 1.893510713121639300f, 1.893387210549869000f, + 1.893263638363663400f, + 1.893139996567565900f, 1.893016285166122500f, 1.892892504163881600f, + 1.892768653565394300f, + 1.892644733375214300f, 1.892520743597897700f, 1.892396684238003300f, + 1.892272555300092300f, + 1.892148356788728700f, 1.892024088708479200f, 1.891899751063912200f, + 1.891775343859599400f, + 1.891650867100115300f, 1.891526320790036100f, 1.891401704933941100f, + 1.891277019536412400f, + 1.891152264602033800f, 1.891027440135392600f, 1.890902546141078000f, + 1.890777582623682300f, + 1.890652549587799700f, 1.890527447038027300f, 1.890402274978965100f, + 1.890277033415215200f, + 1.890151722351382200f, 1.890026341792073500f, 1.889900891741899100f, + 1.889775372205471300f, + 1.889649783187405100f, 1.889524124692318200f, 1.889398396724830500f, + 1.889272599289564900f, + 1.889146732391146400f, 1.889020796034202700f, 1.888894790223364600f, + 1.888768714963264400f, + 1.888642570258537700f, 1.888516356113822700f, 1.888390072533759700f, + 1.888263719522991900f, + 1.888137297086165000f, 1.888010805227927000f, 1.887884243952928600f, + 1.887757613265823400f, + 1.887630913171267000f, 1.887504143673917700f, 1.887377304778437000f, + 1.887250396489487800f, + 1.887123418811736500f, 1.886996371749851700f, 1.886869255308504200f, + 1.886742069492368000f, + 1.886614814306119400f, 1.886487489754437300f, 1.886360095842002600f, + 1.886232632573499700f, + 1.886105099953614900f, 1.885977497987037000f, 1.885849826678457800f, + 1.885722086032571200f, + 1.885594276054074300f, 1.885466396747665700f, 1.885338448118047700f, + 1.885210430169924200f, + 1.885082342908002400f, 1.884954186336991400f, 1.884825960461603100f, + 1.884697665286552400f, + 1.884569300816556000f, 1.884440867056333700f, 1.884312364010607600f, + 1.884183791684102400f, + 1.884055150081545200f, 1.883926439207665800f, 1.883797659067196800f, + 1.883668809664872600f, + 1.883539891005431100f, 1.883410903093611900f, 1.883281845934157800f, + 1.883152719531813800f, + 1.883023523891327300f, 1.882894259017448900f, 1.882764924914930700f, + 1.882635521588528400f, + 1.882506049042999700f, 1.882376507283104900f, 1.882246896313606800f, + 1.882117216139270700f, + 1.881987466764865100f, 1.881857648195159900f, 1.881727760434928500f, + 1.881597803488946500f, + 1.881467777361992100f, 1.881337682058845700f, 1.881207517584290600f, + 1.881077283943112900f, + 1.880946981140100500f, 1.880816609180044700f, 1.880686168067738500f, + 1.880555657807977800f, + 1.880425078405561600f, 1.880294429865290600f, 1.880163712191968300f, + 1.880032925390400900f, + 1.879902069465397200f, 1.879771144421768200f, 1.879640150264327600f, + 1.879509086997891900f, + 1.879377954627279700f, 1.879246753157312700f, 1.879115482592814500f, + 1.878984142938611600f, + 1.878852734199532900f, 1.878721256380410100f, 1.878589709486077300f, + 1.878458093521370800f, + 1.878326408491130200f, 1.878194654400196600f, 1.878062831253414900f, + 1.877930939055631100f, + 1.877798977811695200f, 1.877666947526458700f, 1.877534848204775800f, + 1.877402679851504000f, + 1.877270442471502100f, 1.877138136069632400f, 1.877005760650759500f, + 1.876873316219750200f, + 1.876740802781474500f, 1.876608220340804100f, 1.876475568902614000f, + 1.876342848471781200f, + 1.876210059053185600f, 1.876077200651709500f, 1.875944273272237800f, + 1.875811276919657500f, + 1.875678211598858800f, 1.875545077314734000f, 1.875411874072178100f, + 1.875278601876088700f, + 1.875145260731365700f, 1.875011850642911600f, 1.874878371615631900f, + 1.874744823654434000f, + 1.874611206764227800f, 1.874477520949926500f, 1.874343766216444800f, + 1.874209942568701100f, + 1.874076050011615400f, 1.873942088550110400f, 1.873808058189111700f, + 1.873673958933546900f, + 1.873539790788347100f, 1.873405553758444600f, 1.873271247848775400f, + 1.873136873064277000f, + 1.873002429409890600f, 1.872867916890558900f, 1.872733335511227700f, + 1.872598685276845000f, + 1.872463966192361900f, 1.872329178262731200f, 1.872194321492908700f, + 1.872059395887852900f, + 1.871924401452524700f, 1.871789338191887100f, 1.871654206110906500f, + 1.871519005214550700f, + 1.871383735507791100f, 1.871248396995601300f, 1.871112989682956800f, + 1.870977513574836500f, + 1.870841968676221400f, 1.870706354992095000f, 1.870570672527443600f, + 1.870434921287255700f, + 1.870299101276522400f, 1.870163212500237900f, 1.870027254963397800f, + 1.869891228671001200f, + 1.869755133628049600f, 1.869618969839546500f, 1.869482737310498100f, + 1.869346436045913800f, + 1.869210066050804600f, 1.869073627330184700f, 1.868937119889070300f, + 1.868800543732480600f, + 1.868663898865437200f, 1.868527185292963700f, 1.868390403020087100f, + 1.868253552051836200f, + 1.868116632393243000f, 1.867979644049341200f, 1.867842587025167800f, + 1.867705461325761800f, + 1.867568266956164800f, 1.867431003921421500f, 1.867293672226578300f, + 1.867156271876684500f, + 1.867018802876792200f, 1.866881265231955500f, 1.866743658947231300f, + 1.866605984027679000f, + 1.866468240478360600f, 1.866330428304340300f, 1.866192547510685300f, + 1.866054598102465000f, + 1.865916580084751500f, 1.865778493462619100f, 1.865640338241145100f, + 1.865502114425408900f, + 1.865363822020492700f, 1.865225461031480900f, 1.865087031463460900f, + 1.864948533321522300f, + 1.864809966610757400f, 1.864671331336260600f, 1.864532627503129100f, + 1.864393855116463200f, + 1.864255014181364500f, 1.864116104702938000f, 1.863977126686291200f, + 1.863838080136534000f, + 1.863698965058778300f, 1.863559781458139300f, 1.863420529339734100f, + 1.863281208708683000f, + 1.863141819570107900f, 1.863002361929134500f, 1.862862835790889400f, + 1.862723241160503300f, + 1.862583578043108100f, 1.862443846443839300f, 1.862304046367834200f, + 1.862164177820232700f, + 1.862024240806177800f, 1.861884235330814300f, 1.861744161399289600f, + 1.861604019016754200f, + 1.861463808188360500f, 1.861323528919263800f, 1.861183181214621600f, + 1.861042765079594200f, + 1.860902280519344500f, 1.860761727539037300f, 1.860621106143840500f, + 1.860480416338924600f, + 1.860339658129461800f, 1.860198831520627900f, 1.860057936517600700f, + 1.859916973125560000f, + 1.859775941349689000f, 1.859634841195173100f, 1.859493672667199800f, + 1.859352435770959900f, + 1.859211130511645900f, 1.859069756894453400f, 1.858928314924580300f, + 1.858786804607227100f, + 1.858645225947596300f, 1.858503578950893900f, 1.858361863622327400f, + 1.858220079967107600f, + 1.858078227990447300f, 1.857936307697561900f, 1.857794319093669900f, + 1.857652262183991000f, + 1.857510136973749000f, 1.857367943468169100f, 1.857225681672479300f, + 1.857083351591910300f, + 1.856940953231694900f, 1.856798486597069000f, 1.856655951693270600f, + 1.856513348525540300f, + 1.856370677099121100f, 1.856227937419258700f, 1.856085129491201100f, + 1.855942253320199200f, + 1.855799308911506100f, 1.855656296270377300f, 1.855513215402071000f, + 1.855370066311848000f, + 1.855226849004971500f, 1.855083563486706900f, 1.854940209762322700f, + 1.854796787837089500f, + 1.854653297716280400f, 1.854509739405171300f, 1.854366112909040300f, + 1.854222418233168400f, + 1.854078655382838300f, 1.853934824363336200f, 1.853790925179950500f, + 1.853646957837971500f, + 1.853502922342692600f, 1.853358818699409900f, 1.853214646913421200f, + 1.853070406990027500f, + 1.852926098934532200f, 1.852781722752241000f, 1.852637278448462200f, + 1.852492766028506400f, + 1.852348185497687300f, 1.852203536861320600f, 1.852058820124724300f, + 1.851914035293219700f, + 1.851769182372129600f, 1.851624261366780400f, 1.851479272282500000f, + 1.851334215124619300f, + 1.851189089898471800f, 1.851043896609393400f, 1.850898635262721900f, + 1.850753305863798800f, + 1.850607908417967200f, 1.850462442930572900f, 1.850316909406964200f, + 1.850171307852492200f, + 1.850025638272510000f, 1.849879900672373600f, 1.849734095057441200f, + 1.849588221433073700f, + 1.849442279804634600f, 1.849296270177489800f, 1.849150192557007300f, + 1.849004046948558200f, + 1.848857833357515900f, 1.848711551789256300f, 1.848565202249157400f, + 1.848418784742600400f, + 1.848272299274968500f, 1.848125745851647800f, 1.847979124478026100f, + 1.847832435159495000f, + 1.847685677901447200f, 1.847538852709279100f, 1.847391959588388300f, + 1.847244998544176300f, + 1.847097969582046200f, 1.846950872707404000f, 1.846803707925657600f, + 1.846656475242218300f, + 1.846509174662499300f, 1.846361806191916000f, 1.846214369835887500f, + 1.846066865599834000f, + 1.845919293489179000f, 1.845771653509348200f, 1.845623945665770100f, + 1.845476169963875500f, + 1.845328326409097400f, 1.845180415006871800f, 1.845032435762637100f, + 1.844884388681833800f, + 1.844736273769905300f, 1.844588091032297400f, 1.844439840474458200f, + 1.844291522101838800f, + 1.844143135919891900f, 1.843994681934073600f, 1.843846160149842200f, + 1.843697570572658200f, + 1.843548913207985000f, 1.843400188061288000f, 1.843251395138035800f, + 1.843102534443698900f, + 1.842953605983750400f, 1.842804609763666100f, 1.842655545788924000f, + 1.842506414065004900f, + 1.842357214597392100f, 1.842207947391570900f, 1.842058612453029600f, + 1.841909209787258900f, + 1.841759739399751800f, 1.841610201296003800f, 1.841460595481513100f, + 1.841310921961780500f, + 1.841161180742308500f, 1.841011371828603200f, 1.840861495226172600f, + 1.840711550940526700f, + 1.840561538977179200f, 1.840411459341645400f, 1.840261312039443100f, + 1.840111097076092800f, + 1.839960814457117600f, 1.839810464188043100f, 1.839660046274397100f, + 1.839509560721709800f, + 1.839359007535514400f, 1.839208386721346500f, 1.839057698284743500f, + 1.838906942231246100f, + 1.838756118566397200f, 1.838605227295741800f, 1.838454268424828400f, + 1.838303241959206700f, + 1.838152147904429800f, 1.838000986266052900f, 1.837849757049633900f, + 1.837698460260732900f, + 1.837547095904912700f, 1.837395663987738700f, 1.837244164514778600f, + 1.837092597491602100f, + 1.836940962923782700f, 1.836789260816895000f, 1.836637491176516600f, + 1.836485654008228200f, + 1.836333749317611700f, 1.836181777110252900f, 1.836029737391738700f, + 1.835877630167659800f, + 1.835725455443608200f, 1.835573213225179400f, 1.835420903517970500f, + 1.835268526327581900f, + 1.835116081659615700f, 1.834963569519677100f, 1.834810989913373500f, + 1.834658342846314800f, + 1.834505628324113200f, 1.834352846352383700f, 1.834199996936744000f, + 1.834047080082813300f, + 1.833894095796214400f, 1.833741044082571900f, 1.833587924947513100f, + 1.833434738396668000f, + 1.833281484435668400f, 1.833128163070149300f, 1.832974774305747600f, + 1.832821318148103500f, + 1.832667794602858400f, 1.832514203675657600f, 1.832360545372147900f, + 1.832206819697979000f, + 1.832053026658802700f, 1.831899166260273700f, 1.831745238508049300f, + 1.831591243407788300f, + 1.831437180965153100f, 1.831283051185808300f, 1.831128854075420500f, + 1.830974589639659000f, + 1.830820257884196100f, 1.830665858814705600f, 1.830511392436864800f, + 1.830356858756352800f, + 1.830202257778851300f, 1.830047589510044500f, 1.829892853955619200f, + 1.829738051121264600f, + 1.829583181012672400f, 1.829428243635536500f, 1.829273238995553700f, + 1.829118167098423100f, + 1.828963027949846100f, 1.828807821555527000f, 1.828652547921171900f, + 1.828497207052490100f, + 1.828341798955192900f, 1.828186323634994200f, 1.828030781097610400f, + 1.827875171348760400f, + 1.827719494394165500f, 1.827563750239549400f, 1.827407938890638600f, + 1.827252060353161500f, + 1.827096114632849700f, 1.826940101735436500f, 1.826784021666658400f, + 1.826627874432253700f, + 1.826471660037963800f, 1.826315378489531800f, 1.826159029792704400f, + 1.826002613953229500f, + 1.825846130976858100f, 1.825689580869344100f, 1.825532963636443000f, + 1.825376279283913200f, + 1.825219527817515800f, 1.825062709243013800f, 1.824905823566173000f, + 1.824748870792761900f, + 1.824591850928550800f, 1.824434763979313300f, 1.824277609950824700f, + 1.824120388848863300f, + 1.823963100679209600f, 1.823805745447646600f, 1.823648323159960100f, + 1.823490833821937600f, + 1.823333277439369600f, 1.823175654018049300f, 1.823017963563772000f, + 1.822860206082335300f, + 1.822702381579539800f, 1.822544490061187800f, 1.822386531533084900f, + 1.822228506001038800f, + 1.822070413470859600f, 1.821912253948359700f, 1.821754027439354400f, + 1.821595733949661100f, + 1.821437373485099900f, 1.821278946051493100f, 1.821120451654665700f, + 1.820961890300445400f, + 1.820803261994661500f, 1.820644566743146800f, 1.820485804551735800f, + 1.820326975426265600f, + 1.820168079372576300f, 1.820009116396509800f, 1.819850086503910700f, + 1.819690989700625900f, + 1.819531825992505500f, 1.819372595385401000f, 1.819213297885166900f, + 1.819053933497660300f, + 1.818894502228740600f, 1.818735004084269600f, 1.818575439070111200f, + 1.818415807192132600f, + 1.818256108456203000f, 1.818096342868193800f, 1.817936510433979300f, + 1.817776611159436000f, + 1.817616645050443000f, 1.817456612112881900f, 1.817296512352636300f, + 1.817136345775592900f, + 1.816976112387640700f, 1.816815812194670700f, 1.816655445202576700f, + 1.816495011417255300f, + 1.816334510844604700f, 1.816173943490526400f, 1.816013309360923900f, + 1.815852608461703300f, + 1.815691840798773000f, 1.815531006378043900f, 1.815370105205429600f, + 1.815209137286846200f, + 1.815048102628211500f, 1.814887001235446600f, 1.814725833114474700f, + 1.814564598271221300f, + 1.814403296711615000f, 1.814241928441585800f, 1.814080493467067300f, + 1.813918991793994900f, + 1.813757423428306000f, 1.813595788375941700f, 1.813434086642844400f, + 1.813272318234959700f, + 1.813110483158235400f, 1.812948581418621500f, 1.812786613022070700f, + 1.812624577974538000f, + 1.812462476281981200f, 1.812300307950360300f, 1.812138072985637800f, + 1.811975771393778300f, + 1.811813403180749300f, 1.811650968352521000f, 1.811488466915065000f, + 1.811325898874356800f, + 1.811163264236372900f, 1.811000563007093100f, 1.810837795192499400f, + 1.810674960798576600f, + 1.810512059831311400f, 1.810349092296693400f, 1.810186058200714100f, + 1.810022957549368000f, + 1.809859790348652200f, 1.809696556604565300f, 1.809533256323109200f, + 1.809369889510288100f, + 1.809206456172108200f, 1.809042956314578900f, 1.808879389943711200f, + 1.808715757065519200f, + 1.808552057686019200f, 1.808388291811230000f, 1.808224459447172800f, + 1.808060560599871200f, + 1.807896595275351200f, 1.807732563479641300f, 1.807568465218772900f, + 1.807404300498778800f, + 1.807240069325695400f, 1.807075771705560800f, 1.806911407644415700f, + 1.806746977148303300f, + 1.806582480223269500f, 1.806417916875362000f, 1.806253287110631600f, + 1.806088590935131000f, + 1.805923828354915900f, 1.805758999376044100f, 1.805594104004575800f, + 1.805429142246573600f, + 1.805264114108102900f, 1.805099019595231200f, 1.804933858714028700f, + 1.804768631470567500f, + 1.804603337870923000f, 1.804437977921172300f, 1.804272551627395400f, + 1.804107058995674500f, + 1.803941500032094200f, 1.803775874742741500f, 1.803610183133706400f, + 1.803444425211080400f, + 1.803278600980958300f, 1.803112710449436900f, 1.802946753622615400f, + 1.802780730506595700f, + 1.802614641107481900f, 1.802448485431380900f, 1.802282263484401300f, + 1.802115975272655000f, + 1.801949620802255600f, 1.801783200079319900f, 1.801616713109966300f, + 1.801450159900316300f, + 1.801283540456493700f, 1.801116854784624400f, 1.800950102890836800f, + 1.800783284781262200f, + 1.800616400462033800f, 1.800449449939287800f, 1.800282433219162000f, + 1.800115350307797600f, + 1.799948201211337500f, 1.799780985935927300f, 1.799613704487715200f, + 1.799446356872851400f, + 1.799278943097489100f, 1.799111463167783400f, 1.798943917089892000f, + 1.798776304869975200f, + 1.798608626514195800f, 1.798440882028718500f, 1.798273071419711000f, + 1.798105194693343500f, + 1.797937251855787700f, 1.797769242913218800f, 1.797601167871813800f, + 1.797433026737752700f, + 1.797264819517217200f, 1.797096546216391900f, 1.796928206841463800f, + 1.796759801398622100f, + 1.796591329894058800f, 1.796422792333968000f, 1.796254188724546500f, + 1.796085519071992900f, + 1.795916783382509200f, 1.795747981662299200f, 1.795579113917569200f, + 1.795410180154527900f, + 1.795241180379386800f, 1.795072114598359200f, 1.794902982817661500f, + 1.794733785043511900f, + 1.794564521282131300f, 1.794395191539743400f, 1.794225795822573600f, + 1.794056334136850300f, + 1.793886806488804100f, 1.793717212884667900f, 1.793547553330677300f, + 1.793377827833070100f, + 1.793208036398086900f, 1.793038179031970000f, 1.792868255740965000f, + 1.792698266531319400f, + 1.792528211409282900f, 1.792358090381108300f, 1.792187903453050100f, + 1.792017650631366100f, + 1.791847331922315600f, 1.791676947332161000f, 1.791506496867166600f, + 1.791335980533599300f, + 1.791165398337728900f, 1.790994750285827000f, 1.790824036384167900f, + 1.790653256639028100f, + 1.790482411056686800f, 1.790311499643425500f, 1.790140522405528200f, + 1.789969479349281100f, + 1.789798370480973000f, 1.789627195806895200f, 1.789455955333341100f, + 1.789284649066606800f, + 1.789113277012990900f, 1.788941839178794100f, 1.788770335570319700f, + 1.788598766193873600f, + 1.788427131055763600f, 1.788255430162300400f, 1.788083663519796800f, + 1.787911831134568300f, + 1.787739933012932900f, 1.787567969161210300f, 1.787395939585723500f, + 1.787223844292797500f, + 1.787051683288759500f, 1.786879456579939700f, 1.786707164172670200f, + 1.786534806073285700f, + 1.786362382288123400f, 1.786189892823522700f, 1.786017337685825700f, + 1.785844716881376700f, + 1.785672030416522300f, 1.785499278297612000f, 1.785326460530997300f, + 1.785153577123032000f, + 1.784980628080072900f, 1.784807613408478300f, 1.784634533114609800f, + 1.784461387204831400f, + 1.784288175685508700f, 1.784114898563010200f, 1.783941555843707100f, + 1.783768147533972200f, + 1.783594673640181800f, 1.783421134168713800f, 1.783247529125948900f, + 1.783073858518269700f, + 1.782900122352062000f, 1.782726320633713200f, 1.782552453369613800f, + 1.782378520566156200f, + 1.782204522229735600f, 1.782030458366749200f, 1.781856328983596900f, + 1.781682134086680900f, + 1.781507873682406200f, 1.781333547777179200f, 1.781159156377410100f, + 1.780984699489510200f, + 1.780810177119894100f, 1.780635589274978600f, 1.780460935961182300f, + 1.780286217184927000f, + 1.780111432952636600f, 1.779936583270737400f, 1.779761668145658300f, + 1.779586687583830200f, + 1.779411641591686500f, 1.779236530175663600f, 1.779061353342199500f, + 1.778886111097735000f, + 1.778710803448713400f, 1.778535430401580100f, 1.778359991962783000f, + 1.778184488138772900f, + 1.778008918936002000f, 1.777833284360925900f, 1.777657584420002000f, + 1.777481819119690200f, + 1.777305988466453000f, 1.777130092466755200f, 1.776954131127064200f, + 1.776778104453849100f, + 1.776602012453582400f, 1.776425855132738100f, 1.776249632497793200f, + 1.776073344555227000f, + 1.775896991311520800f, 1.775720572773158900f, 1.775544088946627600f, + 1.775367539838415700f, + 1.775190925455014400f, 1.775014245802917200f, 1.774837500888620400f, + 1.774660690718622000f, + 1.774483815299423100f, 1.774306874637527000f, 1.774129868739439100f, + 1.773952797611667100f, + 1.773775661260722100f, 1.773598459693116500f, 1.773421192915365400f, + 1.773243860933986400f, + 1.773066463755499800f, 1.772889001386427800f, 1.772711473833295200f, + 1.772533881102629000f, + 1.772356223200959100f, 1.772178500134817100f, 1.772000711910737700f, + 1.771822858535257600f, + 1.771644940014915700f, 1.771466956356254000f, 1.771288907565816000f, + 1.771110793650148500f, + 1.770932614615799800f, 1.770754370469321400f, 1.770576061217266500f, + 1.770397686866191300f, + 1.770219247422653700f, 1.770040742893215000f, 1.769862173284438000f, + 1.769683538602888000f, + 1.769504838855133100f, 1.769326074047743700f, 1.769147244187292200f, + 1.768968349280353800f, + 1.768789389333506000f, 1.768610364353328600f, 1.768431274346403900f, + 1.768252119319316400f, + 1.768072899278653200f, 1.767893614231003800f, 1.767714264182959500f, + 1.767534849141115100f, + 1.767355369112067100f, 1.767175824102414000f, 1.766996214118757800f, + 1.766816539167701800f, + 1.766636799255852300f, 1.766456994389817600f, 1.766277124576209000f, + 1.766097189821639300f, + 1.765917190132724600f, 1.765737125516083000f, 1.765556995978334800f, + 1.765376801526102700f, + 1.765196542166012100f, 1.765016217904690900f, 1.764835828748768400f, + 1.764655374704877700f, + 1.764474855779653200f, 1.764294271979732100f, 1.764113623311754000f, + 1.763932909782361100f, + 1.763752131398197200f, 1.763571288165909400f, 1.763390380092146400f, + 1.763209407183560200f, + 1.763028369446804500f, 1.762847266888535100f, 1.762666099515411100f, + 1.762484867334093400f, + 1.762303570351245300f, 1.762122208573532600f, 1.761940782007623600f, + 1.761759290660188400f, + 1.761577734537900500f, 1.761396113647435000f, 1.761214427995469100f, + 1.761032677588683800f, + 1.760850862433760700f, 1.760668982537384900f, 1.760487037906243600f, + 1.760305028547026500f, + 1.760122954466425600f, 1.759940815671135100f, 1.759758612167851700f, + 1.759576343963274600f, + 1.759394011064105100f, 1.759211613477047200f, 1.759029151208807400f, + 1.758846624266093800f, + 1.758664032655617500f, 1.758481376384092500f, 1.758298655458233600f, + 1.758115869884759700f, + 1.757933019670390800f, 1.757750104821850000f, 1.757567125345862700f, + 1.757384081249156100f, + 1.757200972538460700f, 1.757017799220508500f, 1.756834561302034400f, + 1.756651258789775800f, + 1.756467891690471700f, 1.756284460010864200f, 1.756100963757697900f, + 1.755917402937718900f, + 1.755733777557676500f, 1.755550087624322000f, 1.755366333144409200f, + 1.755182514124693900f, + 1.754998630571935200f, 1.754814682492893600f, 1.754630669894332600f, + 1.754446592783017500f, + 1.754262451165716300f, 1.754078245049199600f, 1.753893974440240000f, + 1.753709639345612600f, + 1.753525239772095100f, 1.753340775726466700f, 1.753156247215510400f, + 1.752971654246010300f, + 1.752786996824753600f, 1.752602274958529500f, 1.752417488654129700f, + 1.752232637918348200f, + 1.752047722757981600f, 1.751862743179828600f, 1.751677699190690400f, + 1.751492590797370600f, + 1.751307418006674800f, 1.751122180825411800f, 1.750936879260391700f, + 1.750751513318427700f, + 1.750566083006335600f, 1.750380588330932500f, 1.750195029299038900f, + 1.750009405917477100f, + 1.749823718193071800f, 1.749637966132650900f, 1.749452149743043100f, + 1.749266269031080700f, + 1.749080324003598100f, 1.748894314667431800f, 1.748708241029421000f, + 1.748522103096407300f, + 1.748335900875233900f, 1.748149634372747200f, 1.747963303595795500f, + 1.747776908551230000f, + 1.747590449245904000f, 1.747403925686672500f, 1.747217337880393900f, + 1.747030685833928200f, + 1.746843969554138200f, 1.746657189047889200f, 1.746470344322048200f, + 1.746283435383485100f, + 1.746096462239072000f, 1.745909424895683200f, 1.745722323360195900f, + 1.745535157639489100f, + 1.745347927740444200f, 1.745160633669945200f, 1.744973275434878300f, + 1.744785853042132300f, + 1.744598366498598200f, 1.744410815811169300f, 1.744223200986741100f, + 1.744035522032211900f, + 1.743847778954482000f, 1.743659971760454200f, 1.743472100457033700f, + 1.743284165051127700f, + 1.743096165549646400f, 1.742908101959502100f, 1.742719974287608900f, + 1.742531782540884100f, + 1.742343526726246800f, 1.742155206850618800f, 1.741966822920923800f, + 1.741778374944088000f, + 1.741589862927040800f, 1.741401286876712800f, 1.741212646800037300f, + 1.741023942703950200f, + 1.740835174595389600f, 1.740646342481295900f, 1.740457446368612000f, + 1.740268486264283200f, + 1.740079462175256900f, 1.739890374108482600f, 1.739701222070913200f, + 1.739512006069502800f, + 1.739322726111208500f, 1.739133382202989500f, 1.738943974351807600f, + 1.738754502564626700f, + 1.738564966848413100f, 1.738375367210135400f, 1.738185703656765200f, + 1.737995976195275000f, + 1.737806184832640900f, 1.737616329575841300f, 1.737426410431856200f, + 1.737236427407668800f, + 1.737046380510263800f, 1.736856269746629000f, 1.736666095123754000f, + 1.736475856648631400f, + 1.736285554328254900f, 1.736095188169622500f, 1.735904758179732400f, + 1.735714264365586700f, + 1.735523706734189100f, 1.735333085292545900f, 1.735142400047666100f, + 1.734951651006560100f, + 1.734760838176241400f, 1.734569961563725600f, 1.734379021176030600f, + 1.734188017020177100f, + 1.733996949103187500f, 1.733805817432086900f, 1.733614622013902600f, + 1.733423362855664100f, + 1.733232039964403900f, 1.733040653347156300f, 1.732849203010957900f, + 1.732657688962847600f, + 1.732466111209867200f, 1.732274469759060200f, 1.732082764617472800f, + 1.731890995792153600f, + 1.731699163290153100f, 1.731507267118524500f, 1.731315307284323700f, + 1.731123283794607800f, + 1.730931196656437600f, 1.730739045876875200f, 1.730546831462985500f, + 1.730354553421835600f, + 1.730162211760495300f, 1.729969806486036500f, 1.729777337605533000f, + 1.729584805126061400f, + 1.729392209054700900f, 1.729199549398532400f, 1.729006826164639400f, + 1.728814039360108100f, + 1.728621188992026400f, 1.728428275067485100f, 1.728235297593577100f, + 1.728042256577397200f, + 1.727849152026043500f, 1.727655983946615700f, 1.727462752346216000f, + 1.727269457231948900f, + 1.727076098610921500f, 1.726882676490243000f, 1.726689190877025000f, + 1.726495641778381200f, + 1.726302029201427900f, 1.726108353153283900f, 1.725914613641069900f, + 1.725720810671909300f, + 1.725526944252927700f, 1.725333014391252900f, 1.725139021094015200f, + 1.724944964368347000f, + 1.724750844221383500f, 1.724556660660261800f, 1.724362413692121400f, + 1.724168103324104300f, + 1.723973729563354600f, 1.723779292417019200f, 1.723584791892246700f, + 1.723390227996188600f, + 1.723195600735998100f, 1.723000910118831300f, 1.722806156151846400f, + 1.722611338842204000f, + 1.722416458197066900f, 1.722221514223600100f, 1.722026506928971500f, + 1.721831436320350800f, + 1.721636302404910200f, 1.721441105189824000f, 1.721245844682269600f, + 1.721050520889425600f, + 1.720855133818473900f, 1.720659683476597900f, 1.720464169870984200f, + 1.720268593008821100f, + 1.720072952897299100f, 1.719877249543611900f, 1.719681482954954500f, + 1.719485653138524800f, + 1.719289760101522900f, 1.719093803851151400f, 1.718897784394614900f, + 1.718701701739120400f, + 1.718505555891877400f, 1.718309346860097600f, 1.718113074650995200f, + 1.717916739271786500f, + 1.717720340729689700f, 1.717523879031926500f, 1.717327354185719900f, + 1.717130766198295700f, + 1.716934115076881800f, 1.716737400828708400f, 1.716540623461008100f, + 1.716343782981016200f, + 1.716146879395969500f, 1.715949912713108100f, 1.715752882939673300f, + 1.715555790082909900f, + 1.715358634150064000f, 1.715161415148384500f, 1.714964133085122900f, + 1.714766787967532600f, + 1.714569379802868900f, 1.714371908598390800f, 1.714174374361358000f, + 1.713976777099033700f, + 1.713779116818682900f, 1.713581393527573000f, 1.713383607232973600f, + 1.713185757942156800f, + 1.712987845662396800f, 1.712789870400970700f, 1.712591832165157200f, + 1.712393730962237500f, + 1.712195566799495500f, 1.711997339684216700f, 1.711799049623689900f, + 1.711600696625205300f, + 1.711402280696055800f, 1.711203801843536700f, 1.711005260074945200f, + 1.710806655397581600f, + 1.710607987818747700f, 1.710409257345748100f, 1.710210463985889500f, + 1.710011607746480600f, + 1.709812688634833300f, 1.709613706658261100f, 1.709414661824080000f, + 1.709215554139608400f, + 1.709016383612166600f, 1.708817150249077900f, 1.708617854057667300f, + 1.708418495045262300f, + 1.708219073219193300f, 1.708019588586791700f, 1.707820041155392500f, + 1.707620430932332400f, + 1.707420757924950300f, 1.707221022140587900f, 1.707021223586588700f, + 1.706821362270298600f, + 1.706621438199066300f, 1.706421451380242000f, 1.706221401821179200f, + 1.706021289529232800f, + 1.705821114511760300f, 1.705620876776121600f, 1.705420576329679000f, + 1.705220213179796900f, + 1.705019787333842200f, 1.704819298799183700f, 1.704618747583193100f, + 1.704418133693243800f, + 1.704217457136711900f, 1.704016717920976000f, 1.703815916053416300f, + 1.703615051541415900f, + 1.703414124392360000f, 1.703213134613636100f, 1.703012082212634000f, + 1.702810967196746000f, + 1.702609789573366300f, 1.702408549349891500f, 1.702207246533721000f, + 1.702005881132255800f, + 1.701804453152900000f, 1.701602962603059100f, 1.701401409490141300f, + 1.701199793821557300f, + 1.700998115604720000f, 1.700796374847044300f, 1.700594571555948100f, + 1.700392705738850400f, + 1.700190777403173700f, 1.699988786556342300f, 1.699786733205783000f, + 1.699584617358924400f, + 1.699382439023197700f, 1.699180198206036600f, 1.698977894914877100f, + 1.698775529157156700f, + 1.698573100940316400f, 1.698370610271798800f, 1.698168057159048700f, + 1.697965441609513300f, + 1.697762763630642700f, 1.697560023229888200f, 1.697357220414704500f, + 1.697154355192547900f, + 1.696951427570877000f, 1.696748437557152900f, 1.696545385158839200f, + 1.696342270383401200f, + 1.696139093238307400f, 1.695935853731027600f, 1.695732551869034300f, + 1.695529187659802400f, + 1.695325761110809200f, 1.695122272229534000f, 1.694918721023458600f, + 1.694715107500066800f, + 1.694511431666845000f, 1.694307693531282000f, 1.694103893100868100f, + 1.693900030383096900f, + 1.693696105385463800f, 1.693492118115466500f, 1.693288068580604900f, + 1.693083956788381500f, + 1.692879782746300700f, 1.692675546461869900f, 1.692471247942597600f, + 1.692266887195995600f, + 1.692062464229577600f, 1.691857979050859900f, 1.691653431667360600f, + 1.691448822086600400f, + 1.691244150316102000f, 1.691039416363390800f, 1.690834620235994300f, + 1.690629761941442100f, + 1.690424841487266700f, 1.690219858881001800f, 1.690014814130184300f, + 1.689809707242353200f, + 1.689604538225049700f, 1.689399307085817300f, 1.689194013832201500f, + 1.688988658471750600f, + 1.688783241012014700f, 1.688577761460546800f, 1.688372219824901400f, + 1.688166616112636100f, + 1.687960950331309800f, 1.687755222488484600f, 1.687549432591724400f, + 1.687343580648595700f, + 1.687137666666667100f, 1.686931690653509000f, 1.686725652616694900f, + 1.686519552563800400f, + 1.686313390502403000f, 1.686107166440082600f, 1.685900880384421800f, + 1.685694532343004600f, + 1.685488122323418400f, 1.685281650333251900f, 1.685075116380096800f, + 1.684868520471546600f, + 1.684661862615197000f, 1.684455142818646700f, 1.684248361089495800f, + 1.684041517435347400f, + 1.683834611863806100f, 1.683627644382479800f, 1.683420614998977900f, + 1.683213523720911800f, + 1.683006370555896400f, 1.682799155511547600f, 1.682591878595484300f, + 1.682384539815327400f, + 1.682177139178700400f, 1.681969676693228600f, 1.681762152366539600f, + 1.681554566206263900f, + 1.681346918220033800f, 1.681139208415483700f, 1.680931436800250600f, + 1.680723603381973500f, + 1.680515708168294200f, 1.680307751166856300f, 1.680099732385305300f, + 1.679891651831290100f, + 1.679683509512460900f, 1.679475305436470600f, 1.679267039610974300f, + 1.679058712043629300f, + 1.678850322742095200f, 1.678641871714033900f, 1.678433358967109400f, + 1.678224784508988400f, + 1.678016148347339300f, 1.677807450489833300f, 1.677598690944143400f, + 1.677389869717945000f, + 1.677180986818916300f, 1.676972042254736900f, 1.676763036033089600f, + 1.676553968161658600f, + 1.676344838648130600f, 1.676135647500194700f, 1.675926394725542700f, + 1.675717080331867900f, + 1.675507704326866200f, 1.675298266718235900f, 1.675088767513677200f, + 1.674879206720892900f, + 1.674669584347587800f, 1.674459900401469700f, 1.674250154890247300f, + 1.674040347821632800f, + 1.673830479203340000f, 1.673620549043085500f, 1.673410557348587600f, + 1.673200504127567000f, + 1.672990389387746700f, 1.672780213136852300f, 1.672569975382611300f, + 1.672359676132753500f, + 1.672149315395010900f, 1.671938893177118000f, 1.671728409486811500f, + 1.671517864331830000f, + 1.671307257719914800f, 1.671096589658809500f, 1.670885860156259300f, + 1.670675069220012500f, + 1.670464216857819200f, 1.670253303077431800f, 1.670042327886605200f, + 1.669831291293095900f, + 1.669620193304663500f, 1.669409033929069500f, 1.669197813174077200f, + 1.668986531047453000f, + 1.668775187556965000f, 1.668563782710383600f, 1.668352316515481700f, + 1.668140788980034400f, + 1.667929200111818400f, 1.667717549918614100f, 1.667505838408202700f, + 1.667294065588368100f, + 1.667082231466896900f, 1.666870336051577800f, 1.666658379350201000f, + 1.666446361370560000f, + 1.666234282120450100f, 1.666022141607668600f, 1.665809939840015500f, + 1.665597676825292700f, + 1.665385352571304500f, 1.665172967085857700f, 1.664960520376761000f, + 1.664748012451825200f, + 1.664535443318863900f, 1.664322812985692600f, 1.664110121460129000f, + 1.663897368749993400f, + 1.663684554863107800f, 1.663471679807296800f, 1.663258743590387400f, + 1.663045746220208600f, + 1.662832687704591800f, 1.662619568051370500f, 1.662406387268380100f, + 1.662193145363459100f, + 1.661979842344447600f, 1.661766478219188300f, 1.661553052995526000f, + 1.661339566681307600f, + 1.661126019284382200f, 1.660912410812601900f, 1.660698741273819700f, + 1.660485010675892400f, + 1.660271219026677700f, 1.660057366334036300f, 1.659843452605831200f, + 1.659629477849926800f, + 1.659415442074190900f, 1.659201345286492900f, 1.658987187494704200f, + 1.658772968706699000f, + 1.658558688930353400f, 1.658344348173546300f, 1.658129946444157700f, + 1.657915483750071100f, + 1.657700960099171200f, 1.657486375499345900f, 1.657271729958484500f, + 1.657057023484479000f, + 1.656842256085223800f, 1.656627427768615000f, 1.656412538542551200f, + 1.656197588414933600f, + 1.655982577393664700f, 1.655767505486650500f, 1.655552372701798200f, + 1.655337179047017700f, + 1.655121924530220900f, 1.654906609159322500f, 1.654691232942238500f, + 1.654475795886888300f, + 1.654260298001192200f, 1.654044739293073900f, 1.653829119770458900f, + 1.653613439441274500f, + 1.653397698313451300f, 1.653181896394921000f, 1.652966033693617800f, + 1.652750110217479100f, + 1.652534125974443000f, 1.652318080972451400f, 1.652101975219447200f, + 1.651885808723375900f, + 1.651669581492185300f, 1.651453293533826000f, 1.651236944856249600f, + 1.651020535467411200f, + 1.650804065375267400f, 1.650587534587776700f, 1.650370943112901000f, + 1.650154290958603300f, + 1.649937578132849400f, 1.649720804643607400f, 1.649503970498847200f, + 1.649287075706541200f, + 1.649070120274664000f, 1.648853104211192700f, 1.648636027524106100f, + 1.648418890221385400f, + 1.648201692311014300f, 1.647984433800978600f, 1.647767114699266100f, + 1.647549735013867000f, + 1.647332294752774200f, 1.647114793923981600f, 1.646897232535486500f, + 1.646679610595287900f, + 1.646461928111387300f, 1.646244185091788400f, 1.646026381544496400f, + 1.645808517477519700f, + 1.645590592898868600f, 1.645372607816555400f, 1.645154562238594800f, + 1.644936456173004000f, + 1.644718289627801600f, 1.644500062611009300f, 1.644281775130650900f, + 1.644063427194751600f, + 1.643845018811340300f, 1.643626549988446200f, 1.643408020734102600f, + 1.643189431056343700f, + 1.642970780963206800f, 1.642752070462730800f, 1.642533299562957100f, + 1.642314468271929300f, + 1.642095576597693200f, 1.641876624548297000f, 1.641657612131790500f, + 1.641438539356226500f, + 1.641219406229659700f, 1.641000212760146800f, 1.640780958955747200f, + 1.640561644824521700f, + 1.640342270374534500f, 1.640122835613851100f, 1.639903340550539200f, + 1.639683785192669600f, + 1.639464169548314100f, 1.639244493625547900f, 1.639024757432447500f, + 1.638804960977092100f, + 1.638585104267562800f, 1.638365187311943400f, 1.638145210118319400f, + 1.637925172694778800f, + 1.637705075049411800f, 1.637484917190310800f, 1.637264699125570200f, + 1.637044420863286600f, + 1.636824082411559600f, 1.636603683778490100f, 1.636383224972181500f, + 1.636162706000739300f, + 1.635942126872271800f, 1.635721487594888400f, 1.635500788176702100f, + 1.635280028625826900f, + 1.635059208950379700f, 1.634838329158479200f, 1.634617389258246700f, + 1.634396389257805700f, + 1.634175329165281400f, 1.633954208988801700f, 1.633733028736496400f, + 1.633511788416498000f, + 1.633290488036940500f, 1.633069127605960800f, 1.632847707131697600f, + 1.632626226622291700f, + 1.632404686085886300f, 1.632183085530627200f, 1.631961424964661700f, + 1.631739704396139900f, + 1.631517923833213400f, 1.631296083284036900f, 1.631074182756766300f, + 1.630852222259560700f, + 1.630630201800580900f, 1.630408121387990000f, 1.630185981029953000f, + 1.629963780734637400f, + 1.629741520510213000f, 1.629519200364851800f, 1.629296820306727700f, + 1.629074380344017100f, + 1.628851880484898200f, 1.628629320737551700f, 1.628406701110161100f, + 1.628184021610910700f, + 1.627961282247988300f, 1.627738483029583100f, 1.627515623963887000f, + 1.627292705059093700f, + 1.627069726323399500f, 1.626846687765002700f, 1.626623589392103500f, + 1.626400431212904800f, + 1.626177213235611400f, 1.625953935468430500f, 1.625730597919571300f, + 1.625507200597245500f, + 1.625283743509666300f, 1.625060226665050000f, 1.624836650071614500f, + 1.624613013737580000f, + 1.624389317671169500f, 1.624165561880607000f, 1.623941746374119500f, + 1.623717871159936300f, + 1.623493936246288300f, 1.623269941641409400f, 1.623045887353534900f, + 1.622821773390902700f, + 1.622597599761753000f, 1.622373366474327800f, 1.622149073536871800f, + 1.621924720957631300f, + 1.621700308744855200f, 1.621475836906794500f, 1.621251305451702400f, + 1.621026714387834300f, + 1.620802063723447700f, 1.620577353466802700f, 1.620352583626160500f, + 1.620127754209786100f, + 1.619902865225945300f, 1.619677916682906700f, 1.619452908588941300f, + 1.619227840952321800f, + 1.619002713781323200f, 1.618777527084222800f, 1.618552280869300300f, + 1.618326975144837000f, + 1.618101609919117200f, 1.617876185200426600f, 1.617650700997053500f, + 1.617425157317288200f, + 1.617199554169423500f, 1.616973891561754200f, 1.616748169502577200f, + 1.616522388000191500f, + 1.616296547062898500f, 1.616070646699001800f, 1.615844686916807300f, + 1.615618667724622700f, + 1.615392589130757900f, 1.615166451143525300f, 1.614940253771239400f, + 1.614713997022216900f, + 1.614487680904776600f, 1.614261305427239200f, 1.614034870597928400f, + 1.613808376425168900f, + 1.613581822917288900f, 1.613355210082617800f, 1.613128537929487500f, + 1.612901806466232200f, + 1.612675015701188000f, 1.612448165642693400f, 1.612221256299089200f, + 1.611994287678718100f, + 1.611767259789925100f, 1.611540172641057200f, 1.611313026240463800f, + 1.611085820596496600f, + 1.610858555717509200f, 1.610631231611857800f, 1.610403848287899700f, + 1.610176405753995800f, + 1.609948904018508200f, 1.609721343089801600f, 1.609493722976242900f, + 1.609266043686200700f, + 1.609038305228046400f, 1.608810507610153100f, 1.608582650840896200f, + 1.608354734928653800f, + 1.608126759881805400f, 1.607898725708732900f, 1.607670632417820500f, + 1.607442480017454700f, + 1.607214268516024000f, 1.606985997921919000f, 1.606757668243532500f, + 1.606529279489259600f, + 1.606300831667497600f, 1.606072324786645500f, 1.605843758855105300f, + 1.605615133881280700f, + 1.605386449873577300f, 1.605157706840403300f, 1.604928904790168700f, + 1.604700043731286200f, + 1.604471123672170500f, 1.604242144621237800f, 1.604013106586907400f, + 1.603784009577600100f, + 1.603554853601739700f, 1.603325638667751000f, 1.603096364784061900f, + 1.602867031959102100f, + 1.602637640201303400f, 1.602408189519099800f, 1.602178679920927900f, + 1.601949111415226000f, + 1.601719484010434300f, 1.601489797714996000f, 1.601260052537355700f, + 1.601030248485960900f, + 1.600800385569260300f, 1.600570463795705700f, 1.600340483173750400f, + 1.600110443711850300f, + 1.599880345418463100f, 1.599650188302049100f, 1.599419972371070500f, + 1.599189697633991400f, + 1.598959364099278700f, 1.598728971775401000f, 1.598498520670828900f, + 1.598268010794035900f, + 1.598037442153496900f, 1.597806814757689200f, 1.597576128615092200f, + 1.597345383734188000f, + 1.597114580123460100f, 1.596883717791394800f, 1.596652796746479600f, + 1.596421816997205500f, + 1.596190778552064800f, 1.595959681419551800f, 1.595728525608163700f, + 1.595497311126399300f, + 1.595266037982759500f, 1.595034706185747500f, 1.594803315743869000f, + 1.594571866665631700f, + 1.594340358959544800f, 1.594108792634120600f, 1.593877167697873100f, + 1.593645484159318200f, + 1.593413742026974500f, 1.593181941309362400f, 1.592950082015004700f, + 1.592718164152426000f, + 1.592486187730153300f, 1.592254152756715600f, 1.592022059240644400f, + 1.591789907190473100f, + 1.591557696614737100f, 1.591325427521974100f, 1.591093099920724200f, + 1.590860713819529400f, + 1.590628269226933600f, 1.590395766151483400f, 1.590163204601727100f, + 1.589930584586215500f, + 1.589697906113501000f, 1.589465169192139100f, 1.589232373830686400f, + 1.588999520037702300f, + 1.588766607821748200f, 1.588533637191387400f, 1.588300608155185600f, + 1.588067520721711000f, + 1.587834374899533400f, 1.587601170697224600f, 1.587367908123358900f, + 1.587134587186513000f, + 1.586901207895265300f, 1.586667770258196600f, 1.586434274283889500f, + 1.586200719980929200f, + 1.585967107357902700f, 1.585733436423399000f, 1.585499707186010200f, + 1.585265919654329300f, + 1.585032073836952100f, 1.584798169742476400f, 1.584564207379502500f, + 1.584330186756632200f, + 1.584096107882470000f, 1.583861970765622100f, 1.583627775414697000f, + 1.583393521838305700f, + 1.583159210045060900f, 1.582924840043577400f, 1.582690411842472700f, + 1.582455925450365600f, + 1.582221380875877800f, 1.581986778127632700f, 1.581752117214255900f, + 1.581517398144375800f, + 1.581282620926621300f, 1.581047785569625400f, 1.580812892082021900f, + 1.580577940472447200f, + 1.580342930749539800f, 1.580107862921940700f, 1.579872736998292100f, + 1.579637552987239100f, + 1.579402310897428900f, 1.579167010737510600f, 1.578931652516135700f, + 1.578696236241957200f, + 1.578460761923630800f, 1.578225229569814700f, 1.577989639189168100f, + 1.577753990790353500f, + 1.577518284382034800f, 1.577282519972878200f, 1.577046697571552000f, + 1.576810817186727000f, + 1.576574878827075700f, 1.576338882501273000f, 1.576102828217995600f, + 1.575866715985922500f, + 1.575630545813735200f, 1.575394317710116600f, 1.575158031683752300f, + 1.574921687743330300f, + 1.574685285897539800f, 1.574448826155072400f, 1.574212308524622500f, + 1.573975733014886000f, + 1.573739099634561500f, 1.573502408392348600f, 1.573265659296950300f, + 1.573028852357070800f, + 1.572791987581417100f, 1.572555064978698100f, 1.572318084557624800f, + 1.572081046326909900f, + 1.571843950295269000f, 1.571606796471419100f, 1.571369584864080100f, + 1.571132315481973200f, + 1.570894988333822400f, 1.570657603428353300f, 1.570420160774294000f, + 1.570182660380374600f, + 1.569945102255327200f, 1.569707486407886600f, 1.569469812846788500f, + 1.569232081580771900f, + 1.568994292618577400f, 1.568756445968948000f, 1.568518541640628400f, + 1.568280579642366000f, + 1.568042559982909500f, 1.567804482671010500f, 1.567566347715422500f, + 1.567328155124900800f, + 1.567089904908203200f, 1.566851597074089500f, 1.566613231631321500f, + 1.566374808588663300f, + 1.566136327954881000f, 1.565897789738742900f, 1.565659193949019400f, + 1.565420540594482800f, + 1.565181829683907700f, 1.564943061226071100f, 1.564704235229751500f, + 1.564465351703730400f, + 1.564226410656790000f, 1.563987412097716200f, 1.563748356035296000f, + 1.563509242478319000f, + 1.563270071435576500f, 1.563030842915862100f, 1.562791556927971800f, + 1.562552213480703300f, + 1.562312812582856500f, 1.562073354243233700f, 1.561833838470639200f, + 1.561594265273878800f, + 1.561354634661761300f, 1.561114946643096900f, 1.560875201226698900f, + 1.560635398421381400f, + 1.560395538235961800f, 1.560155620679258400f, 1.559915645760092900f, + 1.559675613487288200f, + 1.559435523869669500f, 1.559195376916064700f, 1.558955172635302800f, + 1.558714911036215700f, + 1.558474592127637100f, 1.558234215918402600f, 1.557993782417350400f, + 1.557753291633320500f, + 1.557512743575155000f, 1.557272138251698300f, 1.557031475671796400f, + 1.556790755844298400f, + 1.556549978778054300f, 1.556309144481917300f, 1.556068252964741600f, + 1.555827304235384500f, + 1.555586298302704900f, 1.555345235175563900f, 1.555104114862824600f, + 1.554862937373352500f, + 1.554621702716015000f, 1.554380410899681300f, 1.554139061933223200f, + 1.553897655825514600f, + 1.553656192585431100f, 1.553414672221850700f, 1.553173094743653300f, + 1.552931460159721100f, + 1.552689768478938500f, 1.552448019710191300f, 1.552206213862368500f, + 1.551964350944360100f, + 1.551722430965059000f, 1.551480453933359800f, 1.551238419858159700f, + 1.550996328748356800f, + 1.550754180612852900f, 1.550511975460550500f, 1.550269713300355100f, + 1.550027394141174000f, + 1.549785017991916400f, 1.549542584861493900f, 1.549300094758820000f, + 1.549057547692810600f, + 1.548814943672383300f, 1.548572282706457900f, 1.548329564803956300f, + 1.548086789973802700f, + 1.547843958224923000f, 1.547601069566245900f, 1.547358124006701400f, + 1.547115121555221700f, + 1.546872062220741700f, 1.546628946012197800f, 1.546385772938528600f, + 1.546142543008675300f, + 1.545899256231580300f, 1.545655912616188800f, 1.545412512171447700f, + 1.545169054906306200f, + 1.544925540829715600f, 1.544681969950629300f, 1.544438342278002600f, + 1.544194657820792800f, + 1.543950916587959700f, 1.543707118588464800f, 1.543463263831272000f, + 1.543219352325347200f, + 1.542975384079658300f, 1.542731359103175300f, 1.542487277404870100f, + 1.542243138993717000f, + 1.541998943878692300f, 1.541754692068774600f, 1.541510383572944000f, + 1.541266018400183200f, + 1.541021596559476700f, 1.540777118059811100f, 1.540532582910175500f, + 1.540287991119560600f, + 1.540043342696959100f, 1.539798637651366400f, 1.539553875991779300f, + 1.539309057727197300f, + 1.539064182866621400f, 1.538819251419055100f, 1.538574263393503800f, + 1.538329218798974800f, + 1.538084117644477900f, 1.537838959939025200f, 1.537593745691629500f, + 1.537348474911307300f, + 1.537103147607076200f, 1.536857763787956400f, 1.536612323462969800f, + 1.536366826641140800f, + 1.536121273331495300f, 1.535875663543061700f, 1.535629997284870400f, + 1.535384274565953600f, + 1.535138495395346400f, 1.534892659782085100f, 1.534646767735208000f, + 1.534400819263756400f, + 1.534154814376772700f, 1.533908753083302200f, 1.533662635392391700f, + 1.533416461313090100f, + 1.533170230854448400f, 1.532923944025520200f, 1.532677600835360600f, + 1.532431201293027000f, + 1.532184745407578500f, 1.531938233188077100f, 1.531691664643585900f, + 1.531445039783170500f, + 1.531198358615898800f, 1.530951621150840700f, 1.530704827397067800f, + 1.530457977363654000f, + 1.530211071059675200f, 1.529964108494209700f, 1.529717089676337500f, + 1.529470014615140800f, + 1.529222883319703700f, 1.528975695799112500f, 1.528728452062455600f, + 1.528481152118823700f, + 1.528233795977309400f, 1.527986383647006500f, 1.527738915137012400f, + 1.527491390456425600f, + 1.527243809614346600f, 1.526996172619878900f, 1.526748479482126700f, + 1.526500730210197200f, + 1.526252924813199500f, 1.526005063300244900f, 1.525757145680446200f, + 1.525509171962918800f, + 1.525261142156779900f, 1.525013056271149000f, 1.524764914315147200f, + 1.524516716297898300f, + 1.524268462228527900f, 1.524020152116163200f, 1.523771785969934000f, + 1.523523363798972000f, + 1.523274885612411200f, 1.523026351419387100f, 1.522777761229038100f, + 1.522529115050503600f, + 1.522280412892925900f, 1.522031654765448900f, 1.521782840677218700f, + 1.521533970637383800f, + 1.521285044655094300f, 1.521036062739502300f, 1.520787024899762100f, + 1.520537931145030400f, + 1.520288781484465700f, 1.520039575927228500f, 1.519790314482481100f, + 1.519540997159388300f, + 1.519291623967116600f, 1.519042194914835200f, 1.518792710011714500f, + 1.518543169266927600f, + 1.518293572689648900f, 1.518043920289055900f, 1.517794212074327500f, + 1.517544448054644500f, + 1.517294628239190400f, 1.517044752637150000f, 1.516794821257710500f, + 1.516544834110061600f, + 1.516294791203394200f, 1.516044692546901800f, 1.515794538149779700f, + 1.515544328021225500f, + 1.515294062170438700f, 1.515043740606620800f, 1.514793363338975600f, + 1.514542930376708600f, + 1.514292441729027300f, 1.514041897405141700f, 1.513791297414263800f, + 1.513540641765606800f, + 1.513289930468387300f, 1.513039163531823000f, 1.512788340965133500f, + 1.512537462777541200f, + 1.512286528978270300f, 1.512035539576546600f, 1.511784494581598600f, + 1.511533394002656100f, + 1.511282237848951400f, 1.511031026129719100f, 1.510779758854195400f, + 1.510528436031618900f, + 1.510277057671229400f, 1.510025623782270000f, 1.509774134373984800f, + 1.509522589455620600f, + 1.509270989036425800f, 1.509019333125651200f, 1.508767621732549400f, + 1.508515854866375100f, + 1.508264032536385000f, 1.508012154751837700f, 1.507760221521994700f, + 1.507508232856118200f, + 1.507256188763473200f, 1.507004089253327000f, 1.506751934334948000f, + 1.506499724017607900f, + 1.506247458310579400f, 1.505995137223137500f, 1.505742760764559300f, + 1.505490328944124200f, + 1.505237841771113200f, 1.504985299254809800f, 1.504732701404498900f, + 1.504480048229468000f, + 1.504227339739006500f, 1.503974575942405700f, 1.503721756848958700f, + 1.503468882467961600f, + 1.503215952808711500f, 1.502962967880507600f, 1.502709927692651900f, + 1.502456832254447600f, + 1.502203681575200700f, 1.501950475664218600f, 1.501697214530810700f, + 1.501443898184289200f, + 1.501190526633967600f, 1.500937099889161600f, 1.500683617959188900f, + 1.500430080853369500f, + 1.500176488581024900f, 1.499922841151479600f, 1.499669138574058800f, + 1.499415380858090800f, + 1.499161568012905300f, 1.498907700047834600f, 1.498653776972212600f, + 1.498399798795375000f, + 1.498145765526660300f, 1.497891677175408500f, 1.497637533750961300f, + 1.497383335262663300f, + 1.497129081719860400f, 1.496874773131900800f, 1.496620409508134800f, + 1.496365990857914600f, + 1.496111517190594300f, 1.495856988515530400f, 1.495602404842080800f, + 1.495347766179606400f, + 1.495093072537469100f, 1.494838323925033400f, 1.494583520351665500f, + 1.494328661826734200f, + 1.494073748359609600f, 1.493818779959664300f, 1.493563756636272500f, + 1.493308678398810800f, + 1.493053545256657800f, 1.492798357219194100f, 1.492543114295801900f, + 1.492287816495866200f, + 1.492032463828773200f, 1.491777056303911700f, 1.491521593930672100f, + 1.491266076718446900f, + 1.491010504676631500f, 1.490754877814621800f, 1.490499196141816600f, + 1.490243459667616600f, + 1.489987668401424800f, 1.489731822352645500f, 1.489475921530685900f, + 1.489219965944954300f, + 1.488963955604861500f, 1.488707890519820600f, 1.488451770699245900f, + 1.488195596152554800f, + 1.487939366889165600f, 1.487683082918499300f, 1.487426744249978400f, + 1.487170350893028500f, + 1.486913902857075700f, 1.486657400151549600f, 1.486400842785880100f, + 1.486144230769501000f, + 1.485887564111846500f, 1.485630842822354100f, 1.485374066910462500f, + 1.485117236385612200f, + 1.484860351257246500f, 1.484603411534810300f, 1.484346417227750700f, + 1.484089368345516300f, + 1.483832264897558400f, 1.483575106893329600f, 1.483317894342285100f, + 1.483060627253882000f, + 1.482803305637578900f, 1.482545929502837100f, 1.482288498859119400f, + 1.482031013715890700f, + 1.481773474082618300f, 1.481515879968770900f, 1.481258231383819800f, + 1.481000528337237800f, + 1.480742770838499900f, 1.480484958897083200f, 1.480227092522466500f, + 1.479969171724131200f, + 1.479711196511560100f, 1.479453166894238100f, 1.479195082881652200f, + 1.478936944483291600f, + 1.478678751708647000f, 1.478420504567211900f, 1.478162203068481100f, + 1.477903847221951400f, + 1.477645437037121900f, 1.477386972523493800f, 1.477128453690569800f, + 1.476869880547855300f, + 1.476611253104856700f, 1.476352571371083700f, 1.476093835356046700f, + 1.475835045069259000f, + 1.475576200520235500f, 1.475317301718493300f, 1.475058348673551100f, + 1.474799341394929900f, + 1.474540279892153000f, 1.474281164174744900f, 1.474021994252233000f, + 1.473762770134145800f, + 1.473503491830014300f, 1.473244159349371700f, 1.472984772701752900f, + 1.472725331896694400f, + 1.472465836943735600f, 1.472206287852416900f, 1.471946684632281500f, + 1.471687027292874400f, + 1.471427315843742100f, 1.471167550294433700f, 1.470907730654499800f, + 1.470647856933493300f, + 1.470387929140969200f, 1.470127947286484100f, 1.469867911379596900f, + 1.469607821429868500f, + 1.469347677446861500f, 1.469087479440140300f, 1.468827227419272200f, + 1.468566921393825700f, + 1.468306561373371900f, 1.468046147367482600f, 1.467785679385733300f, + 1.467525157437700200f, + 1.467264581532962100f, 1.467003951681099800f, 1.466743267891695800f, + 1.466482530174334500f, + 1.466221738538602500f, 1.465960892994088800f, 1.465699993550383400f, + 1.465439040217079400f, + 1.465178033003770700f, 1.464916971920054100f, 1.464655856975527900f, + 1.464394688179792900f, + 1.464133465542451200f, 1.463872189073107500f, 1.463610858781367900f, + 1.463349474676840700f, + 1.463088036769136600f, 1.462826545067867700f, 1.462564999582648600f, + 1.462303400323095000f, + 1.462041747298825900f, 1.461780040519460800f, 1.461518279994622200f, + 1.461256465733934400f, + 1.460994597747023600f, 1.460732676043517800f, 1.460470700633046800f, + 1.460208671525243400f, + 1.459946588729741100f, 1.459684452256176300f, 1.459422262114186800f, + 1.459160018313412400f, + 1.458897720863495500f, 1.458635369774079500f, 1.458372965054810700f, + 1.458110506715337000f, + 1.457847994765308200f, 1.457585429214375700f, 1.457322810072193800f, + 1.457060137348418000f, + 1.456797411052706200f, 1.456534631194717800f, 1.456271797784114900f, + 1.456008910830560500f, + 1.455745970343720800f, 1.455482976333263100f, 1.455219928808857200f, + 1.454956827780174100f, + 1.454693673256887600f, 1.454430465248673300f, 1.454167203765208000f, + 1.453903888816171900f, + 1.453640520411245900f, 1.453377098560113100f, 1.453113623272459100f, + 1.452850094557971000f, + 1.452586512426338000f, 1.452322876887251400f, 1.452059187950404100f, + 1.451795445625491300f, + 1.451531649922210200f, 1.451267800850259500f, 1.451003898419340500f, + 1.450739942639155800f, + 1.450475933519410400f, 1.450211871069811300f, 1.449947755300067500f, + 1.449683586219889400f, + 1.449419363838989800f, 1.449155088167083600f, 1.448890759213887100f, + 1.448626376989119400f, + 1.448361941502500900f, 1.448097452763754000f, 1.447832910782603100f, + 1.447568315568775100f, + 1.447303667131997900f, 1.447038965482002200f, 1.446774210628520200f, + 1.446509402581286400f, + 1.446244541350036700f, 1.445979626944509300f, 1.445714659374444500f, + 1.445449638649584500f, + 1.445184564779673500f, 1.444919437774456700f, 1.444654257643682900f, + 1.444389024397101600f, + 1.444123738044464900f, 1.443858398595526400f, 1.443593006060042100f, + 1.443327560447769600f, + 1.443062061768468400f, 1.442796510031900500f, 1.442530905247829200f, + 1.442265247426020200f, + 1.441999536576240800f, 1.441733772708260600f, 1.441467955831850800f, + 1.441202085956784900f, + 1.440936163092837900f, 1.440670187249787600f, 1.440404158437412500f, + 1.440138076665494100f, + 1.439871941943815300f, 1.439605754282161400f, 1.439339513690319100f, + 1.439073220178077400f, + 1.438806873755226900f, 1.438540474431560600f, 1.438274022216873500f, + 1.438007517120961900f, + 1.437740959153624500f, 1.437474348324662100f, 1.437207684643876800f, + 1.436940968121073600f, + 1.436674198766058500f, 1.436407376588640000f, 1.436140501598628400f, + 1.435873573805835900f, + 1.435606593220076600f, 1.435339559851166500f, 1.435072473708924000f, + 1.434805334803169100f, + 1.434538143143723200f, 1.434270898740410700f, 1.434003601603057300f, + 1.433736251741490700f, + 1.433468849165540500f, 1.433201393885038500f, 1.432933885909818000f, + 1.432666325249714700f, + 1.432398711914566200f, 1.432131045914211600f, 1.431863327258492400f, + 1.431595555957251700f, + 1.431327732020334800f, 1.431059855457588600f, 1.430791926278862400f, + 1.430523944494007400f, + 1.430255910112876000f, 1.429987823145323100f, 1.429719683601205800f, + 1.429451491490382900f, + 1.429183246822714800f, 1.428914949608064200f, 1.428646599856295400f, + 1.428378197577275100f, + 1.428109742780871800f, 1.427841235476955400f, 1.427572675675398600f, + 1.427304063386075200f, + 1.427035398618861500f, 1.426766681383635500f, 1.426497911690277000f, + 1.426229089548668200f, + 1.425960214968693000f, 1.425691287960236600f, 1.425422308533187200f, + 1.425153276697434000f, + 1.424884192462868800f, 1.424615055839385300f, 1.424345866836878200f, + 1.424076625465245500f, + 1.423807331734385800f, 1.423537985654200800f, 1.423268587234593400f, + 1.422999136485468600f, + 1.422729633416733200f, 1.422460078038296300f, 1.422190470360068300f, + 1.421920810391962500f, + 1.421651098143893000f, 1.421381333625776600f, 1.421111516847531700f, + 1.420841647819078600f, + 1.420571726550339700f, 1.420301753051239400f, 1.420031727331703800f, + 1.419761649401660500f, + 1.419491519271040000f, 1.419221336949774100f, 1.418951102447796800f, + 1.418680815775043500f, + 1.418410476941452100f, 1.418140085956961900f, 1.417869642831514700f, + 1.417599147575054000f, + 1.417328600197524900f, 1.417058000708874700f, 1.416787349119052600f, + 1.416516645438009600f, + 1.416245889675698900f, 1.415975081842075300f, 1.415704221947095700f, + 1.415433310000718600f, + 1.415162346012905000f, 1.414891329993617200f, 1.414620261952819600f, + 1.414349141900479000f, + 1.414077969846563500f, 1.413806745801043500f, 1.413535469773890700f, + 1.413264141775079300f, + 1.412992761814585400f, 1.412721329902386900f, 1.412449846048463600f, + 1.412178310262796900f, + 1.411906722555370500f, 1.411635082936170100f, 1.411363391415182900f, + 1.411091648002398500f, + 1.410819852707807700f, 1.410548005541404100f, 1.410276106513182400f, + 1.410004155633139500f, + 1.409732152911274500f, 1.409460098357588200f, 1.409187991982083100f, + 1.408915833794763800f, + 1.408643623805636800f, 1.408371362024710500f, 1.408099048461995300f, + 1.407826683127503000f, + 1.407554266031248100f, 1.407281797183246500f, 1.407009276593515800f, + 1.406736704272076400f, + 1.406464080228949600f, 1.406191404474159000f, 1.405918677017730100f, + 1.405645897869690400f, + 1.405373067040069300f, 1.405100184538898000f, 1.404827250376209400f, + 1.404554264562038400f, + 1.404281227106422400f, 1.404008138019399800f, 1.403734997311011600f, + 1.403461804991300100f, + 1.403188561070310100f, 1.402915265558087700f, 1.402641918464681400f, + 1.402368519800141200f, + 1.402095069574519800f, 1.401821567797870300f, 1.401548014480249000f, + 1.401274409631713600f, + 1.401000753262323900f, 1.400727045382141400f, 1.400453286001229800f, + 1.400179475129653700f, + 1.399905612777481200f, 1.399631698954780800f, 1.399357733671623900f, + 1.399083716938083600f, + 1.398809648764234100f, 1.398535529160152400f, 1.398261358135917300f, + 1.397987135701609200f, + 1.397712861867310300f, 1.397438536643105000f, 1.397164160039079200f, + 1.396889732065321300f, + 1.396615252731921100f, 1.396340722048970300f, 1.396066140026562800f, + 1.395791506674794100f, + 1.395516822003761700f, 1.395242086023564800f, 1.394967298744304900f, + 1.394692460176085300f, + 1.394417570329010700f, 1.394142629213188000f, 1.393867636838725900f, + 1.393592593215735600f, + 1.393317498354329300f, 1.393042352264621600f, 1.392767154956728400f, + 1.392491906440768600f, + 1.392216606726861800f, 1.391941255825130100f, 1.391665853745697400f, + 1.391390400498689700f, + 1.391114896094234100f, 1.390839340542460600f, 1.390563733853500200f, + 1.390288076037486500f, + 1.390012367104554600f, 1.389736607064841100f, 1.389460795928485500f, + 1.389184933705628300f, + 1.388909020406412100f, 1.388633056040981600f, 1.388357040619483200f, + 1.388080974152065200f, + 1.387804856648877600f, 1.387528688120072600f, 1.387252468575804100f, + 1.386976198026228100f, + 1.386699876481501900f, 1.386423503951785200f, 1.386147080447239600f, + 1.385870605978028100f, + 1.385594080554316100f, 1.385317504186270900f, 1.385040876884061000f, + 1.384764198657857200f, + 1.384487469517832200f, 1.384210689474160600f, 1.383933858537019100f, + 1.383656976716585600f, + 1.383380044023040400f, 1.383103060466565300f, 1.382826026057344600f, + 1.382548940805563800f, + 1.382271804721410600f, 1.381994617815074400f, 1.381717380096746800f, + 1.381440091576620700f, + 1.381162752264891500f, 1.380885362171756300f, 1.380607921307413400f, + 1.380330429682064000f, + 1.380052887305910400f, 1.379775294189157000f, 1.379497650342010400f, + 1.379219955774678700f, + 1.378942210497371600f, 1.378664414520301500f, 1.378386567853681700f, + 1.378108670507728300f, + 1.377830722492658500f, 1.377552723818691500f, 1.377274674496048700f, + 1.376996574534953300f, + 1.376718423945630000f, 1.376440222738305700f, 1.376161970923209400f, + 1.375883668510570900f, + 1.375605315510623200f, 1.375326911933600200f, 1.375048457789738400f, + 1.374769953089275400f, + 1.374491397842451100f, 1.374212792059507100f, 1.373934135750687100f, + 1.373655428926236400f, + 1.373376671596402400f, 1.373097863771434200f, 1.372819005461582500f, + 1.372540096677100200f, + 1.372261137428242300f, 1.371982127725264800f, 1.371703067578426700f, + 1.371423956997988000f, + 1.371144795994210500f, 1.370865584577358300f, 1.370586322757697500f, + 1.370307010545495500f, + 1.370027647951022100f, 1.369748234984548000f, 1.369468771656347200f, + 1.369189257976694200f, + 1.368909693955866000f, 1.368630079604142000f, 1.368350414931802000f, + 1.368070699949128800f, + 1.367790934666406600f, 1.367511119093921800f, 1.367231253241962200f, + 1.366951337120818000f, + 1.366671370740780500f, 1.366391354112143500f, 1.366111287245202400f, + 1.365831170150254300f, + 1.365551002837598600f, 1.365270785317536100f, 1.364990517600369400f, + 1.364710199696403300f, + 1.364429831615944200f, 1.364149413369300600f, 1.363868944966782900f, + 1.363588426418702600f, + 1.363307857735373900f, 1.363027238927112300f, 1.362746570004235400f, + 1.362465850977062900f, + 1.362185081855915600f, 1.361904262651116900f, 1.361623393372991300f, + 1.361342474031866000f, + 1.361061504638069400f, 1.360780485201932300f, 1.360499415733786400f, + 1.360218296243966200f, + 1.359937126742807300f, 1.359655907240648000f, 1.359374637747827700f, + 1.359093318274687800f, + 1.358811948831571500f, 1.358530529428824400f, 1.358249060076792900f, + 1.357967540785826300f, + 1.357685971566275200f, 1.357404352428492000f, 1.357122683382830900f, + 1.356840964439648200f, + 1.356559195609301700f, 1.356277376902151900f, 1.355995508328559500f, + 1.355713589898888800f, + 1.355431621623504700f, 1.355149603512774400f, 1.354867535577067200f, + 1.354585417826753800f, + 1.354303250272206500f, 1.354021032923800300f, 1.353738765791911100f, + 1.353456448886917200f, + 1.353174082219199100f, 1.352891665799137900f, 1.352609199637117500f, + 1.352326683743523300f, + 1.352044118128742600f, 1.351761502803164900f, 1.351478837777180700f, + 1.351196123061183100f, + 1.350913358665566400f, 1.350630544600727200f, 1.350347680877063800f, + 1.350064767504976400f, + 1.349781804494866600f, 1.349498791857138400f, 1.349215729602197400f, + 1.348932617740450600f, + 1.348649456282307700f, 1.348366245238179500f, 1.348082984618478800f, + 1.347799674433620500f, + 1.347516314694020800f, 1.347232905410098200f, 1.346949446592273100f, + 1.346665938250967100f, + 1.346382380396604000f, 1.346098773039609700f, 1.345815116190411300f, + 1.345531409859438200f, + 1.345247654057121700f, 1.344963848793894200f, 1.344679994080190800f, + 1.344396089926448000f, + 1.344112136343103900f, 1.343828133340598800f, 1.343544080929374800f, + 1.343259979119875600f, + 1.342975827922546600f, 1.342691627347835500f, 1.342407377406191500f, + 1.342123078108065700f, + 1.341838729463910900f, 1.341554331484181600f, 1.341269884179334700f, + 1.340985387559828100f, + 1.340700841636122400f, 1.340416246418678800f, 1.340131601917961900f, + 1.339846908144436600f, + 1.339562165108570700f, 1.339277372820833400f, 1.338992531291695500f, + 1.338707640531629800f, + 1.338422700551110900f, 1.338137711360615200f, 1.337852672970621300f, + 1.337567585391608900f, + 1.337282448634059800f, 1.336997262708457900f, 1.336712027625288600f, + 1.336426743395039000f, + 1.336141410028198500f, 1.335856027535258000f, 1.335570595926709700f, + 1.335285115213048500f, + 1.334999585404770700f, 1.334714006512374400f, 1.334428378546359500f, + 1.334142701517227600f, + 1.333856975435482300f, 1.333571200311629100f, 1.333285376156174700f, + 1.332999502979628700f, + 1.332713580792501500f, 1.332427609605305400f, 1.332141589428554900f, + 1.331855520272766200f, + 1.331569402148457400f, 1.331283235066148100f, 1.330997019036359800f, + 1.330710754069615700f, + 1.330424440176441300f, 1.330138077367363200f, 1.329851665652910500f, + 1.329565205043613800f, + 1.329278695550004700f, 1.328992137182618100f, 1.328705529951989400f, + 1.328418873868656900f, + 1.328132168943159800f, 1.327845415186039000f, 1.327558612607838500f, + 1.327271761219102500f, + 1.326984861030378000f, 1.326697912052213500f, 1.326410914295159400f, + 1.326123867769767500f, + 1.325836772486591800f, 1.325549628456188100f, 1.325262435689113600f, + 1.324975194195928000f, + 1.324687903987191900f, 1.324400565073468300f, 1.324113177465321900f, + 1.323825741173318700f, + 1.323538256208027800f, 1.323250722580018500f, 1.322963140299862500f, + 1.322675509378133900f, + 1.322387829825407700f, 1.322100101652261100f, 1.321812324869273500f, + 1.321524499487024800f, + 1.321236625516098100f, 1.320948702967077400f, 1.320660731850549000f, + 1.320372712177100700f, + 1.320084643957322400f, 1.319796527201805300f, 1.319508361921142500f, + 1.319220148125929100f, + 1.318931885826762000f, 1.318643575034239800f, 1.318355215758962900f, + 1.318066808011533200f, + 1.317778351802554800f, 1.317489847142633300f, 1.317201294042376300f, + 1.316912692512393300f, + 1.316624042563294900f, 1.316335344205694200f, 1.316046597450205800f, + 1.315757802307445900f, + 1.315468958788033000f, 1.315180066902586800f, 1.314891126661728900f, + 1.314602138076083300f, + 1.314313101156274800f, 1.314024015912930600f, 1.313734882356679900f, + 1.313445700498152800f, + 1.313156470347981900f, 1.312867191916801100f, 1.312577865215246900f, + 1.312288490253956900f, + 1.311999067043570200f, 1.311709595594728000f, 1.311420075918073900f, + 1.311130508024252400f, + 1.310840891923910100f, 1.310551227627695400f, 1.310261515146258200f, + 1.309971754490250700f, + 1.309681945670326400f, 1.309392088697140900f, 1.309102183581351200f, + 1.308812230333616500f, + 1.308522228964597500f, 1.308232179484956500f, 1.307942081905358000f, + 1.307651936236467800f, + 1.307361742488954300f, 1.307071500673486800f, 1.306781210800736200f, + 1.306490872881376200f, + 1.306200486926081700f, 1.305910052945529200f, 1.305619570950396800f, + 1.305329040951365100f, + 1.305038462959116100f, 1.304747836984333300f, 1.304457163037702200f, + 1.304166441129910300f, + 1.303875671271646400f, 1.303584853473601200f, 1.303293987746467300f, + 1.303003074100939100f, + 1.302712112547712800f, 1.302421103097485900f, 1.302130045760958100f, + 1.301838940548830600f, + 1.301547787471806900f, 1.301256586540591600f, 1.300965337765891600f, + 1.300674041158414800f, + 1.300382696728871400f, 1.300091304487973800f, 1.299799864446435200f, + 1.299508376614971500f, + 1.299216841004299200f, 1.298925257625137800f, 1.298633626488207500f, + 1.298341947604231300f, + 1.298050220983932900f, 1.297758446638038700f, 1.297466624577275900f, + 1.297174754812374400f, + 1.296882837354065100f, 1.296590872213081200f, 1.296298859400157700f, + 1.296006798926030200f, + 1.295714690801437600f, 1.295422535037119800f, 1.295130331643818500f, + 1.294838080632277000f, + 1.294545782013240900f, 1.294253435797456900f, 1.293961041995673700f, + 1.293668600618642000f, + 1.293376111677113900f, 1.293083575181843500f, 1.292790991143586200f, + 1.292498359573099700f, + 1.292205680481143500f, 1.291912953878477900f, 1.291620179775866400f, + 1.291327358184073200f, + 1.291034489113864100f, 1.290741572576007400f, 1.290448608581273000f, + 1.290155597140431700f, + 1.289862538264257700f, 1.289569431963524900f, 1.289276278249010600f, + 1.288983077131493000f, + 1.288689828621752300f, 1.288396532730570400f, 1.288103189468731400f, + 1.287809798847019800f, + 1.287516360876223500f, 1.287222875567130900f, 1.286929342930532800f, + 1.286635762977221800f, + 1.286342135717991600f, 1.286048461163638000f, 1.285754739324958900f, + 1.285460970212753500f, + 1.285167153837822900f, 1.284873290210969900f, 1.284579379342998700f, + 1.284285421244715900f, + 1.283991415926929400f, 1.283697363400448900f, 1.283403263676086100f, + 1.283109116764654000f, + 1.282814922676967400f, 1.282520681423843000f, 1.282226393016099500f, + 1.281932057464557000f, + 1.281637674780037100f, 1.281343244973363700f, 1.281048768055361900f, + 1.280754244036858900f, + 1.280459672928683500f, 1.280165054741666300f, 1.279870389486639400f, + 1.279575677174437100f, + 1.279280917815894600f, 1.278986111421849900f, 1.278691258003142000f, + 1.278396357570611900f, + 1.278101410135101800f, 1.277806415707456700f, 1.277511374298522200f, + 1.277216285919146500f, + 1.276921150580179200f, 1.276625968292471000f, 1.276330739066875400f, + 1.276035462914247000f, + 1.275740139845442400f, 1.275444769871319600f, 1.275149353002738700f, + 1.274853889250561200f, + 1.274558378625650200f, 1.274262821138871300f, 1.273967216801090900f, + 1.273671565623178100f, + 1.273375867616002300f, 1.273080122790436000f, 1.272784331157352800f, + 1.272488492727628100f, + 1.272192607512139300f, 1.271896675521764900f, 1.271600696767385400f, + 1.271304671259883200f, + 1.271008599010142500f, 1.270712480029048800f, 1.270416314327489800f, + 1.270120101916354600f, + 1.269823842806533800f, 1.269527537008920300f, 1.269231184534408200f, + 1.268934785393893700f, + 1.268638339598274500f, 1.268341847158450200f, 1.268045308085321800f, + 1.267748722389792100f, + 1.267452090082765900f, 1.267155411175149500f, 1.266858685677851000f, + 1.266561913601780100f, + 1.266265094957848000f, 1.265968229756968100f, 1.265671318010055400f, + 1.265374359728026500f, + 1.265077354921799300f, 1.264780303602294200f, 1.264483205780432700f, + 1.264186061467138500f, + 1.263888870673336400f, 1.263591633409954000f, 1.263294349687918800f, + 1.262997019518161700f, + 1.262699642911614600f, 1.262402219879211300f, 1.262104750431887000f, + 1.261807234580578900f, + 1.261509672336225600f, 1.261212063709767900f, 1.260914408712147800f, + 1.260616707354309500f, + 1.260318959647198400f, 1.260021165601761900f, 1.259723325228949000f, + 1.259425438539710300f, + 1.259127505544998600f, 1.258829526255768000f, 1.258531500682973800f, + 1.258233428837574300f, + 1.257935310730528000f, 1.257637146372796400f, 1.257338935775342200f, + 1.257040678949129500f, + 1.256742375905124400f, 1.256444026654294400f, 1.256145631207609400f, + 1.255847189576040100f, + 1.255548701770560000f, 1.255250167802143000f, 1.254951587681765600f, + 1.254652961420405600f, + 1.254354289029042900f, 1.254055570518658500f, 1.253756805900235700f, + 1.253457995184759300f, + 1.253159138383215200f, 1.252860235506592100f, 1.252561286565879300f, + 1.252262291572068900f, + 1.251963250536153500f, 1.251664163469128300f, 1.251365030381989700f, + 1.251065851285736200f, + 1.250766626191367500f, 1.250467355109885500f, 1.250168038052293500f, + 1.249868675029596200f, + 1.249569266052800800f, 1.249269811132915200f, 1.248970310280950200f, + 1.248670763507917100f, + 1.248371170824829300f, 1.248071532242702100f, 1.247771847772552300f, + 1.247472117425398700f, + 1.247172341212261500f, 1.246872519144162300f, 1.246572651232124700f, + 1.246272737487174300f, + 1.245972777920338000f, 1.245672772542644400f, 1.245372721365123600f, + 1.245072624398807900f, + 1.244772481654731000f, 1.244472293143928300f, 1.244172058877436800f, + 1.243871778866295400f, + 1.243571453121544000f, 1.243271081654225400f, 1.242970664475383100f, + 1.242670201596062700f, + 1.242369693027311200f, 1.242069138780177400f, 1.241768538865712000f, + 1.241467893294967200f, + 1.241167202078996800f, 1.240866465228856100f, 1.240565682755603100f, + 1.240264854670295900f, + 1.239963980983995300f, 1.239663061707763700f, 1.239362096852665300f, + 1.239061086429765300f, + 1.238760030450130900f, 1.238458928924831600f, 1.238157781864937400f, + 1.237856589281521000f, + 1.237555351185656500f, 1.237254067588419400f, 1.236952738500886900f, + 1.236651363934138300f, + 1.236349943899254000f, 1.236048478407316500f, 1.235746967469409900f, + 1.235445411096619500f, + 1.235143809300033300f, 1.234842162090739700f, 1.234540469479829900f, + 1.234238731478396000f, + 1.233936948097532400f, 1.233635119348334400f, 1.233333245241899200f, + 1.233031325789326400f, + 1.232729361001716500f, 1.232427350890172000f, 1.232125295465796600f, + 1.231823194739696300f, + 1.231521048722978200f, 1.231218857426751700f, 1.230916620862127400f, + 1.230614339040217800f, + 1.230312011972136500f, 1.230009639668999500f, 1.229707222141924100f, + 1.229404759402029400f, + 1.229102251460436400f, 1.228799698328266700f, 1.228497100016644900f, + 1.228194456536696500f, + 1.227891767899548700f, 1.227589034116330700f, 1.227286255198173100f, + 1.226983431156208200f, + 1.226680562001569900f, 1.226377647745394000f, 1.226074688398817600f, + 1.225771683972980200f, + 1.225468634479021500f, 1.225165539928084300f, 1.224862400331312400f, + 1.224559215699851500f, + 1.224255986044848500f, 1.223952711377453100f, 1.223649391708814700f, + 1.223346027050086400f, + 1.223042617412421600f, 1.222739162806975900f, 1.222435663244906700f, + 1.222132118737372400f, + 1.221828529295533800f, 1.221524894930552800f, 1.221221215653593100f, + 1.220917491475820500f, + 1.220613722408401900f, 1.220309908462505800f, 1.220006049649302800f, + 1.219702145979964600f, + 1.219398197465665400f, 1.219094204117580300f, 1.218790165946886100f, + 1.218486082964761500f, + 1.218181955182386500f, 1.217877782610943700f, 1.217573565261616000f, + 1.217269303145589000f, + 1.216964996274049400f, 1.216660644658185600f, 1.216356248309187600f, + 1.216051807238247800f, + 1.215747321456559300f, 1.215442790975316700f, 1.215138215805717300f, + 1.214833595958959300f, + 1.214528931446242600f, 1.214224222278769100f, 1.213919468467741900f, + 1.213614670024366000f, + 1.213309826959847700f, 1.213004939285395400f, 1.212700007012219100f, + 1.212395030151530300f, + 1.212090008714541600f, 1.211784942712468300f, 1.211479832156526800f, + 1.211174677057934800f, + 1.210869477427912300f, 1.210564233277680500f, 1.210258944618462200f, + 1.209953611461482200f, + 1.209648233817966600f, 1.209342811699143600f, 1.209037345116242400f, + 1.208731834080493800f, + 1.208426278603131200f, 1.208120678695388600f, 1.207815034368502100f, + 1.207509345633709600f, + 1.207203612502250300f, 1.206897834985365000f, 1.206592013094296200f, + 1.206286146840288300f, + 1.205980236234587100f, 1.205674281288440000f, 1.205368282013096200f, + 1.205062238419806200f, + 1.204756150519822300f, 1.204450018324398900f, 1.204143841844791200f, + 1.203837621092256800f, + 1.203531356078054100f, 1.203225046813444000f, 1.202918693309688300f, + 1.202612295578050900f, + 1.202305853629797500f, 1.201999367476194400f, 1.201692837128510700f, + 1.201386262598016500f, + 1.201079643895983700f, 1.200772981033685800f, 1.200466274022397900f, + 1.200159522873396800f, + 1.199852727597960700f, 1.199545888207369700f, 1.199239004712905300f, + 1.198932077125851100f, + 1.198625105457491700f, 1.198318089719113200f, 1.198011029922004400f, + 1.197703926077454200f, + 1.197396778196754700f, 1.197089586291198500f, 1.196782350372080300f, + 1.196475070450696100f, + 1.196167746538343600f, 1.195860378646322700f, 1.195552966785933900f, + 1.195245510968480300f, + 1.194938011205265900f, 1.194630467507596500f, 1.194322879886780000f, + 1.194015248354125100f, + 1.193707572920943000f, 1.193399853598545500f, 1.193092090398246900f, + 1.192784283331362700f, + 1.192476432409210100f, 1.192168537643107900f, 1.191860599044376500f, + 1.191552616624337800f, + 1.191244590394315400f, 1.190936520365635000f, 1.190628406549622900f, + 1.190320248957608100f, + 1.190012047600920200f, 1.189703802490891000f, 1.189395513638853900f, + 1.189087181056143900f, + 1.188778804754097300f, 1.188470384744052100f, 1.188161921037348400f, + 1.187853413645327100f, + 1.187544862579331500f, 1.187236267850706000f, 1.186927629470796900f, + 1.186618947450951600f, + 1.186310221802519900f, 1.186001452536852300f, 1.185692639665301600f, + 1.185383783199222000f, + 1.185074883149969100f, 1.184765939528900500f, 1.184456952347374900f, + 1.184147921616753200f, + 1.183838847348397400f, 1.183529729553671500f, 1.183220568243940300f, + 1.182911363430571200f, + 1.182602115124932900f, 1.182292823338395100f, 1.181983488082330300f, + 1.181674109368111300f, + 1.181364687207113100f, 1.181055221610712400f, 1.180745712590287400f, + 1.180436160157217800f, + 1.180126564322885100f, 1.179816925098671900f, 1.179507242495962900f, + 1.179197516526144600f, + 1.178887747200604300f, 1.178577934530731700f, 1.178268078527917200f, + 1.177958179203553800f, + 1.177648236569035300f, 1.177338250635757700f, 1.177028221415118200f, + 1.176718148918515700f, + 1.176408033157350300f, 1.176097874143024600f, 1.175787671886942000f, + 1.175477426400507700f, + 1.175167137695128900f, 1.174856805782213500f, 1.174546430673171900f, + 1.174236012379415600f, + 1.173925550912357800f, 1.173615046283413200f, 1.173304498503998400f, + 1.172993907585530900f, + 1.172683273539430800f, 1.172372596377118800f, 1.172061876110017700f, + 1.171751112749551900f, + 1.171440306307147200f, 1.171129456794231200f, 1.170818564222232800f, + 1.170507628602582800f, + 1.170196649946713100f, 1.169885628266057900f, 1.169574563572052300f, + 1.169263455876133200f, + 1.168952305189739200f, 1.168641111524310700f, 1.168329874891289400f, + 1.168018595302118000f, + 1.167707272768241800f, 1.167395907301107100f, 1.167084498912162300f, + 1.166773047612856400f, + 1.166461553414641000f, 1.166150016328968600f, 1.165838436367293800f, + 1.165526813541072100f, + 1.165215147861761400f, 1.164903439340820900f, 1.164591687989710500f, + 1.164279893819892800f, + 1.163968056842831700f, 1.163656177069992500f, 1.163344254512841800f, + 1.163032289182848800f, + 1.162720281091483000f, 1.162408230250216100f, 1.162096136670521600f, + 1.161784000363874000f, + 1.161471821341749900f, 1.161159599615627000f, 1.160847335196984800f, + 1.160535028097304600f, + 1.160222678328068700f, 1.159910285900761700f, 1.159597850826869200f, + 1.159285373117878500f, + 1.158972852785278500f, 1.158660289840559800f, 1.158347684295214300f, + 1.158035036160735900f, + 1.157722345448619400f, 1.157409612170361600f, 1.157096836337461000f, + 1.156784017961417500f, + 1.156471157053732300f, 1.156158253625908700f, 1.155845307689450800f, + 1.155532319255865300f, + 1.155219288336659400f, 1.154906214943342700f, 1.154593099087426000f, + 1.154279940780421400f, + 1.153966740033842900f, 1.153653496859206000f, 1.153340211268028000f, + 1.153026883271827300f, + 1.152713512882124400f, 1.152400100110440700f, 1.152086644968299400f, + 1.151773147467225300f, + 1.151459607618745300f, 1.151146025434387000f, 1.150832400925680100f, + 1.150518734104155400f, + 1.150205024981345800f, 1.149891273568785400f, 1.149577479878009800f, + 1.149263643920556800f, + 1.148949765707964600f, 1.148635845251773800f, 1.148321882563526400f, + 1.148007877654766200f, + 1.147693830537038100f, 1.147379741221888500f, 1.147065609720865600f, + 1.146751436045519300f, + 1.146437220207400700f, 1.146122962218062600f, 1.145808662089060000f, + 1.145494319831947800f, + 1.145179935458284100f, 1.144865508979627800f, 1.144551040407539400f, + 1.144236529753581000f, + 1.143921977029316500f, 1.143607382246310600f, 1.143292745416130600f, + 1.142978066550344400f, + 1.142663345660522000f, 1.142348582758234900f, 1.142033777855056000f, + 1.141718930962559500f, + 1.141404042092321500f, 1.141089111255919800f, 1.140774138464933700f, + 1.140459123730943200f, + 1.140144067065530700f, 1.139828968480280300f, 1.139513827986776900f, + 1.139198645596607400f, + 1.138883421321360600f, 1.138568155172625700f, 1.138252847161994400f, + 1.137937497301059600f, + 1.137622105601416000f, 1.137306672074659900f, 1.136991196732388200f, + 1.136675679586200500f, + 1.136360120647697200f, 1.136044519928480800f, 1.135728877440154800f, + 1.135413193194324800f, + 1.135097467202597100f, 1.134781699476580300f, 1.134465890027884300f, + 1.134150038868120500f, + 1.133834146008902100f, 1.133518211461843200f, 1.133202235238559800f, + 1.132886217350669500f, + 1.132570157809791500f, 1.132254056627546300f, 1.131937913815556300f, + 1.131621729385444900f, + 1.131305503348837300f, 1.130989235717360100f, 1.130672926502642100f, + 1.130356575716312500f, + 1.130040183370002900f, 1.129723749475346000f, 1.129407274043976200f, + 1.129090757087529500f, + 1.128774198617643200f, 1.128457598645956600f, 1.128140957184109700f, + 1.127824274243744500f, + 1.127507549836505000f, 1.127190783974035800f, 1.126873976667983800f, + 1.126557127929996800f, + 1.126240237771724700f, 1.125923306204818400f, 1.125606333240930700f, + 1.125289318891715900f, + 1.124972263168829500f, 1.124655166083928800f, 1.124338027648672500f, + 1.124020847874721100f, + 1.123703626773736100f, 1.123386364357381200f, 1.123069060637320600f, + 1.122751715625221400f, + 1.122434329332750800f, 1.122116901771578400f, 1.121799432953375600f, + 1.121481922889814300f, + 1.121164371592568300f, 1.120846779073313400f, 1.120529145343726500f, + 1.120211470415486200f, + 1.119893754300272300f, 1.119575997009766300f, 1.119258198555651300f, + 1.118940358949611900f, + 1.118622478203333800f, 1.118304556328505200f, 1.117986593336814700f, + 1.117668589239953200f, + 1.117350544049612300f, 1.117032457777486200f, 1.116714330435269600f, + 1.116396162034659600f, + 1.116077952587353600f, 1.115759702105052000f, 1.115441410599455500f, + 1.115123078082267000f, + 1.114804704565190500f, 1.114486290059931900f, 1.114167834578198200f, + 1.113849338131698300f, + 1.113530800732142100f, 1.113212222391241500f, 1.112893603120710000f, + 1.112574942932261600f, + 1.112256241837613000f, 1.111937499848481900f, 1.111618716976587700f, + 1.111299893233650600f, + 1.110981028631393700f, 1.110662123181539900f, 1.110343176895814500f, + 1.110024189785944900f, + 1.109705161863658600f, 1.109386093140686000f, 1.109066983628758100f, + 1.108747833339607200f, + 1.108428642284968100f, 1.108109410476576300f, 1.107790137926169200f, + 1.107470824645485600f, + 1.107151470646265300f, 1.106832075940250600f, 1.106512640539184100f, + 1.106193164454811100f, + 1.105873647698877300f, 1.105554090283131100f, 1.105234492219321100f, + 1.104914853519198400f, + 1.104595174194514800f, 1.104275454257024300f, 1.103955693718482200f, + 1.103635892590644900f, + 1.103316050885270600f, 1.102996168614119000f, 1.102676245788951400f, + 1.102356282421530300f, + 1.102036278523620000f, 1.101716234106985700f, 1.101396149183395000f, + 1.101076023764616400f, + 1.100755857862419700f, 1.100435651488577100f, 1.100115404654861100f, + 1.099795117373046200f, + 1.099474789654909100f, 1.099154421512226600f, 1.098834012956778200f, + 1.098513564000344300f, + 1.098193074654706800f, 1.097872544931649100f, 1.097551974842956500f, + 1.097231364400415000f, + 1.096910713615813200f, 1.096590022500939700f, 1.096269291067585700f, + 1.095948519327543800f, + 1.095627707292607700f, 1.095306854974572800f, 1.094985962385235800f, + 1.094665029536395100f, + 1.094344056439850600f, 1.094023043107403200f, 1.093701989550856000f, + 1.093380895782013000f, + 1.093059761812680100f, 1.092738587654664300f, 1.092417373319774200f, + 1.092096118819820200f, + 1.091774824166613600f, 1.091453489371968100f, 1.091132114447697300f, + 1.090810699405617900f, + 1.090489244257547300f, 1.090167749015304300f, 1.089846213690709900f, + 1.089524638295585400f, + 1.089203022841754400f, 1.088881367341041800f, 1.088559671805274100f, + 1.088237936246279100f, + 1.087916160675885800f, 1.087594345105925300f, 1.087272489548229700f, + 1.086950594014632700f, + 1.086628658516969500f, 1.086306683067076900f, 1.085984667676792600f, + 1.085662612357956500f, + 1.085340517122409800f, 1.085018381981994500f, 1.084696206948555300f, + 1.084373992033937000f, + 1.084051737249986900f, 1.083729442608553300f, 1.083407108121486000f, + 1.083084733800636200f, + 1.082762319657857100f, 1.082439865705002500f, 1.082117371953928300f, + 1.081794838416491700f, + 1.081472265104551200f, 1.081149652029967000f, 1.080826999204601100f, + 1.080504306640315500f, + 1.080181574348975500f, 1.079858802342446900f, 1.079535990632596800f, + 1.079213139231294500f, + 1.078890248150409700f, 1.078567317401815100f, 1.078244346997383300f, + 1.077921336948988600f, + 1.077598287268508400f, 1.077275197967819000f, 1.076952069058800400f, + 1.076628900553332700f, + 1.076305692463297900f, 1.075982444800579700f, 1.075659157577062200f, + 1.075335830804633000f, + 1.075012464495178800f, 1.074689058660589700f, 1.074365613312755900f, + 1.074042128463569500f, + 1.073718604124924500f, 1.073395040308715400f, 1.073071437026839500f, + 1.072747794291194300f, + 1.072424112113678600f, 1.072100390506194500f, 1.071776629480643500f, + 1.071452829048929800f, + 1.071128989222958500f, 1.070805110014635900f, 1.070481191435870500f, + 1.070157233498571600f, + 1.069833236214650800f, 1.069509199596019800f, 1.069185123654592600f, + 1.068861008402285200f, + 1.068536853851013600f, 1.068212660012696700f, 1.067888426899253500f, + 1.067564154522606000f, + 1.067239842894676100f, 1.066915492027387600f, 1.066591101932666800f, + 1.066266672622439700f, + 1.065942204108635300f, 1.065617696403183400f, 1.065293149518014500f, + 1.064968563465062100f, + 1.064643938256259400f, 1.064319273903543000f, 1.063994570418849400f, + 1.063669827814116300f, + 1.063345046101285000f, 1.063020225292295300f, 1.062695365399091200f, + 1.062370466433616400f, + 1.062045528407815900f, 1.061720551333637600f, 1.061395535223029500f, + 1.061070480087941800f, + 1.060745385940325500f, 1.060420252792134000f, 1.060095080655320900f, + 1.059769869541841800f, + 1.059444619463654400f, 1.059119330432716700f, 1.058794002460989000f, + 1.058468635560432500f, + 1.058143229743009600f, 1.057817785020685100f, 1.057492301405424500f, + 1.057166778909195000f, + 1.056841217543965200f, 1.056515617321704500f, 1.056189978254385100f, + 1.055864300353978900f, + 1.055538583632461100f, 1.055212828101807200f, 1.054887033773993300f, + 1.054561200660999200f, + 1.054235328774803900f, 1.053909418127389400f, 1.053583468730738200f, + 1.053257480596834700f, + 1.052931453737664600f, 1.052605388165214700f, 1.052279283891473600f, + 1.051953140928431100f, + 1.051626959288079100f, 1.051300738982409800f, 1.050974480023417500f, + 1.050648182423098000f, + 1.050321846193448000f, 1.049995471346466300f, 1.049669057894152800f, + 1.049342605848508200f, + 1.049016115221536000f, 1.048689586025239700f, 1.048363018271625300f, + 1.048036411972699500f, + 1.047709767140470500f, 1.047383083786948700f, 1.047056361924144400f, + 1.046729601564071200f, + 1.046402802718742400f, 1.046075965400174300f, 1.045749089620383200f, + 1.045422175391386800f, + 1.045095222725206200f, 1.044768231633861100f, 1.044441202129375200f, + 1.044114134223771900f, + 1.043787027929076000f, 1.043459883257315400f, 1.043132700220517300f, + 1.042805478830712200f, + 1.042478219099930400f, 1.042150921040204200f, 1.041823584663568200f, + 1.041496209982056600f, + 1.041168797007707000f, 1.040841345752557200f, 1.040513856228645800f, + 1.040186328448014800f, + 1.039858762422705600f, 1.039531158164762400f, 1.039203515686230000f, + 1.038875834999155100f, + 1.038548116115585800f, 1.038220359047570500f, 1.037892563807160800f, + 1.037564730406408200f, + 1.037236858857366600f, 1.036908949172090900f, 1.036581001362636600f, + 1.036253015441062700f, + 1.035924991419427100f, 1.035596929309791300f, 1.035268829124216700f, + 1.034940690874766300f, + 1.034612514573505700f, 1.034284300232500000f, 1.033956047863817500f, + 1.033627757479526700f, + 1.033299429091697700f, 1.032971062712402700f, 1.032642658353714300f, + 1.032314216027707700f, + 1.031985735746457900f, 1.031657217522042900f, 1.031328661366541300f, + 1.031000067292032300f, + 1.030671435310598600f, 1.030342765434322200f, 1.030014057675287900f, + 1.029685312045581100f, + 1.029356528557288300f, 1.029027707222499100f, 1.028698848053302100f, + 1.028369951061789600f, + 1.028041016260053500f, 1.027712043660187600f, 1.027383033274288400f, + 1.027053985114451100f, + 1.026724899192775300f, 1.026395775521359500f, 1.026066614112305600f, + 1.025737414977715200f, + 1.025408178129692000f, 1.025078903580341600f, 1.024749591341769700f, + 1.024420241426085200f, + 1.024090853845396800f, 1.023761428611814600f, 1.023431965737451800f, + 1.023102465234420700f, + 1.022772927114837100f, 1.022443351390816400f, 1.022113738074476300f, + 1.021784087177936000f, + 1.021454398713315600f, 1.021124672692737000f, 1.020794909128323000f, + 1.020465108032198300f, + 1.020135269416488700f, 1.019805393293321100f, 1.019475479674824900f, + 1.019145528573129000f, + 1.018815540000365800f, 1.018485513968667500f, 1.018155450490168000f, + 1.017825349577003300f, + 1.017495211241309800f, 1.017165035495226400f, 1.016834822350892300f, + 1.016504571820448000f, + 1.016174283916036800f, 1.015843958649801600f, 1.015513596033888400f, + 1.015183196080442900f, + 1.014852758801613200f, 1.014522284209548900f, 1.014191772316400000f, + 1.013861223134318900f, + 1.013530636675459100f, 1.013200012951974700f, 1.012869351976022300f, + 1.012538653759758900f, + 1.012207918315344300f, 1.011877145654937400f, 1.011546335790700600f, + 1.011215488734796800f, + 1.010884604499389800f, 1.010553683096645900f, 1.010222724538731600f, + 1.009891728837815700f, + 1.009560696006067900f, 1.009229626055658800f, 1.008898518998761800f, + 1.008567374847549900f, + 1.008236193614199000f, 1.007904975310885300f, 1.007573719949786700f, + 1.007242427543082900f, + 1.006911098102953900f, 1.006579731641582500f, 1.006248328171152100f, + 1.005916887703846500f, + 1.005585410251852700f, 1.005253895827357800f, 1.004922344442551000f, + 1.004590756109621900f, + 1.004259130840762700f, 1.003927468648166100f, 1.003595769544025900f, + 1.003264033540538500f, + 1.002932260649900000f, 1.002600450884309800f, 1.002268604255967200f, + 1.001936720777072400f, + 1.001604800459829000f, 1.001272843316440000f, 1.000940849359111000f, + 1.000608818600048100f, + 1.000276751051459200f, 0.999944646725553720f, 0.999612505634541740f, + 0.999280327790635690f, + 0.998948113206048590f, 0.998615861892994560f, 0.998283573863690270f, + 0.997951249130352380f, + 0.997618887705200020f, 0.997286489600452630f, 0.996954054828332210f, + 0.996621583401061110f, + 0.996289075330862860f, 0.995956530629963810f, 0.995623949310589620f, + 0.995291331384969390f, + 0.994958676865332010f, 0.994625985763907820f, 0.994293258092929790f, + 0.993960493864630480f, + 0.993627693091245660f, 0.993294855785010760f, 0.992961981958163210f, + 0.992629071622942340f, + 0.992296124791587690f, 0.991963141476341460f, 0.991630121689446090f, + 0.991297065443145440f, + 0.990963972749685840f, 0.990630843621313260f, 0.990297678070276800f, + 0.989964476108825210f, + 0.989631237749210020f, 0.989297963003683330f, 0.988964651884498000f, + 0.988631304403909890f, + 0.988297920574174430f, 0.987964500407549910f, 0.987631043916294970f, + 0.987297551112669370f, + 0.986964022008935520f, 0.986630456617355380f, 0.986296854950194260f, + 0.985963217019717120f, + 0.985629542838190490f, 0.985295832417883540f, 0.984962085771065030f, + 0.984628302910006580f, + 0.984294483846980150f, 0.983960628594258810f, 0.983626737164118190f, + 0.983292809568833910f, + 0.982958845820684270f, 0.982624845931947320f, 0.982290809914904140f, + 0.981956737781835790f, + 0.981622629545024770f, 0.981288485216756160f, 0.980954304809314670f, + 0.980620088334987930f, + 0.980285835806063770f, 0.979951547234831130f, 0.979617222633581860f, + 0.979282862014607240f, + 0.978948465390201530f, 0.978614032772659240f, 0.978279564174275860f, + 0.977945059607349900f, + 0.977610519084179290f, 0.977275942617064740f, 0.976941330218307540f, + 0.976606681900209830f, + 0.976271997675076550f, 0.975937277555212310f, 0.975602521552924600f, + 0.975267729680520560f, + 0.974932901950310350f, 0.974598038374604350f, 0.974263138965714040f, + 0.973928203735953460f, + 0.973593232697636530f, 0.973258225863079970f, 0.972923183244600480f, + 0.972588104854516410f, + 0.972252990705148370f, 0.971917840808816710f, 0.971582655177844700f, + 0.971247433824555920f, + 0.970912176761274950f, 0.970576884000329040f, 0.970241555554045230f, + 0.969906191434753320f, + 0.969570791654783330f, 0.969235356226466500f, 0.968899885162136650f, + 0.968564378474127350f, + 0.968228836174775060f, 0.967893258276415700f, 0.967557644791388500f, + 0.967221995732032490f, + 0.966886311110688230f, 0.966550590939698640f, 0.966214835231406500f, + 0.965879043998157160f, + 0.965543217252296420f, 0.965207355006171270f, 0.964871457272131190f, + 0.964535524062525410f, + 0.964199555389706030f, 0.963863551266025300f, 0.963527511703836660f, + 0.963191436715496120f, + 0.962855326313359350f, 0.962519180509785130f, 0.962182999317132030f, + 0.961846782747760140f, + 0.961510530814032040f, 0.961174243528309820f, 0.960837920902958720f, + 0.960501562950343390f, + 0.960165169682831830f, 0.959828741112791590f, 0.959492277252591900f, + 0.959155778114604400f, + 0.958819243711200310f, 0.958482674054753960f, 0.958146069157639560f, + 0.957809429032232760f, + 0.957472753690911670f, 0.957136043146054050f, 0.956799297410040440f, + 0.956462516495251940f, + 0.956125700414070300f, 0.955788849178880300f, 0.955451962802066120f, + 0.955115041296014880f, + 0.954778084673113870f, 0.954441092945751630f, 0.954104066126319150f, + 0.953767004227207060f, + 0.953429907260809120f, 0.953092775239518630f, 0.952755608175731570f, + 0.952418406081844360f, + 0.952081168970254520f, 0.951743896853362140f, 0.951406589743566950f, + 0.951069247653271500f, + 0.950731870594878510f, 0.950394458580791970f, 0.950057011623418380f, + 0.949719529735163940f, + 0.949382012928437600f, 0.949044461215648560f, 0.948706874609207220f, + 0.948369253121526420f, + 0.948031596765018910f, 0.947693905552099870f, 0.947356179495185020f, + 0.947018418606691230f, + 0.946680622899037650f, 0.946342792384643360f, 0.946004927075930090f, + 0.945667026985319680f, + 0.945329092125236190f, 0.944991122508104350f, 0.944653118146349890f, + 0.944315079052401090f, + 0.943977005238685770f, 0.943638896717634900f, 0.943300753501679190f, + 0.942962575603250920f, + 0.942624363034784580f, 0.942286115808714690f, 0.941947833937478270f, + 0.941609517433512730f, + 0.941271166309256450f, 0.940932780577150460f, 0.940594360249635500f, + 0.940255905339155150f, + 0.939917415858152920f, 0.939578891819073720f, 0.939240333234364950f, + 0.938901740116473540f, + 0.938563112477849630f, 0.938224450330942590f, 0.937885753688204820f, + 0.937547022562088990f, + 0.937208256965048840f, 0.936869456909540490f, 0.936530622408019990f, + 0.936191753472946030f, + 0.935852850116777430f, 0.935513912351974450f, 0.935174940190999560f, + 0.934835933646314900f, + 0.934496892730385720f, 0.934157817455677160f, 0.933818707834655590f, + 0.933479563879790030f, + 0.933140385603548840f, 0.932801173018403480f, 0.932461926136825660f, + 0.932122644971287830f, + 0.931783329534265240f, 0.931443979838232900f, 0.931104595895668410f, + 0.930765177719049210f, + 0.930425725320855430f, 0.930086238713567440f, 0.929746717909666790f, + 0.929407162921637610f, + 0.929067573761963250f, 0.928727950443130500f, 0.928388292977625930f, + 0.928048601377937210f, + 0.927708875656554800f, 0.927369115825968480f, 0.927029321898671270f, + 0.926689493887155820f, + 0.926349631803916270f, 0.926009735661449170f, 0.925669805472250860f, + 0.925329841248820340f, + 0.924989843003656610f, 0.924649810749260110f, 0.924309744498133750f, + 0.923969644262779830f, + 0.923629510055703820f, 0.923289341889410480f, 0.922949139776407800f, + 0.922608903729203570f, + 0.922268633760306990f, 0.921928329882229390f, 0.921587992107482210f, + 0.921247620448579440f, + 0.920907214918035070f, 0.920566775528364410f, 0.920226302292085460f, + 0.919885795221715540f, + 0.919545254329774850f, 0.919204679628783720f, 0.918864071131263780f, + 0.918523428849739030f, + 0.918182752796733110f, 0.917842042984772340f, 0.917501299426383480f, + 0.917160522134094160f, + 0.916819711120434700f, 0.916478866397934850f, 0.916137987979127270f, + 0.915797075876544350f, + 0.915456130102721200f, 0.915115150670193110f, 0.914774137591496510f, + 0.914433090879170130f, + 0.914092010545752620f, 0.913750896603785280f, 0.913409749065809520f, + 0.913068567944367970f, + 0.912727353252005710f, 0.912386105001267270f, 0.912044823204700370f, + 0.911703507874852440f, + 0.911362159024272310f, 0.911020776665511290f, 0.910679360811120000f, + 0.910337911473652390f, + 0.909996428665661990f, 0.909654912399703860f, 0.909313362688335290f, + 0.908971779544113350f, + 0.908630162979597760f, 0.908288513007348140f, 0.907946829639926790f, + 0.907605112889895870f, + 0.907263362769819000f, 0.906921579292262250f, 0.906579762469791110f, + 0.906237912314974080f, + 0.905896028840379560f, 0.905554112058577170f, 0.905212161982139160f, + 0.904870178623637170f, + 0.904528161995645670f, 0.904186112110739510f, 0.903844028981494190f, + 0.903501912620488070f, + 0.903159763040298880f, 0.902817580253507450f, 0.902475364272694370f, + 0.902133115110441470f, + 0.901790832779333250f, 0.901448517291953520f, 0.901106168660889110f, + 0.900763786898726380f, + 0.900421372018054500f, 0.900078924031462610f, 0.899736442951541320f, + 0.899393928790883420f, + 0.899051381562081310f, 0.898708801277730340f, 0.898366187950425780f, + 0.898023541592764210f, + 0.897680862217344440f, 0.897338149836764960f, 0.896995404463627350f, + 0.896652626110532870f, + 0.896309814790084090f, 0.895966970514885940f, 0.895624093297543110f, + 0.895281183150662960f, + 0.894938240086852970f, 0.894595264118721810f, 0.894252255258880410f, + 0.893909213519939460f, + 0.893566138914512420f, 0.893223031455212530f, 0.892879891154655380f, + 0.892536718025457090f, + 0.892193512080234670f, 0.891850273331607600f, 0.891507001792195000f, + 0.891163697474618880f, + 0.890820360391500920f, 0.890476990555464480f, 0.890133587979135000f, + 0.889790152675137610f, + 0.889446684656100330f, 0.889103183934650930f, 0.888759650523418650f, + 0.888416084435035060f, + 0.888072485682131150f, 0.887728854277341050f, 0.887385190233298650f, + 0.887041493562639060f, + 0.886697764277999840f, 0.886354002392018110f, 0.886010207917333760f, + 0.885666380866586560f, + 0.885322521252418610f, 0.884978629087472270f, 0.884634704384391180f, + 0.884290747155821230f, + 0.883946757414407980f, 0.883602735172799640f, 0.883258680443644530f, + 0.882914593239592320f, + 0.882570473573294660f, 0.882226321457403320f, 0.881882136904572400f, + 0.881537919927456340f, + 0.881193670538710450f, 0.880849388750992610f, 0.880505074576960370f, + 0.880160728029273920f, + 0.879816349120593590f, 0.879471937863580690f, 0.879127494270899090f, + 0.878783018355212220f, + 0.878438510129186170f, 0.878093969605486800f, 0.877749396796782770f, + 0.877404791715742370f, + 0.877060154375035710f, 0.876715484787334630f, 0.876370782965310900f, + 0.876026048921639160f, + 0.875681282668993700f, 0.875336484220050390f, 0.874991653587487090f, + 0.874646790783981660f, + 0.874301895822214290f, 0.873956968714865500f, 0.873612009474616810f, + 0.873267018114152300f, + 0.872921994646155390f, 0.872576939083312460f, 0.872231851438309840f, + 0.871886731723835020f, + 0.871541579952577750f, 0.871196396137227660f, 0.870851180290476810f, + 0.870505932425017060f, + 0.870160652553543020f, 0.869815340688749220f, 0.869469996843331370f, + 0.869124621029987670f, + 0.868779213261415610f, 0.868433773550315810f, 0.868088301909388680f, + 0.867742798351335720f, + 0.867397262888861100f, 0.867051695534668210f, 0.866706096301463340f, + 0.866360465201952980f, + 0.866014802248844420f, 0.865669107454847490f, 0.865323380832671800f, + 0.864977622395029290f, + 0.864631832154632240f, 0.864286010124194040f, 0.863940156316430170f, + 0.863594270744056040f, + 0.863248353419789670f, 0.862902404356348570f, 0.862556423566453230f, + 0.862210411062823810f, + 0.861864366858181910f, 0.861518290965251340f, 0.861172183396755500f, + 0.860826044165420630f, + 0.860479873283972910f, 0.860133670765139580f, 0.859787436621650360f, + 0.859441170866234390f, + 0.859094873511623840f, 0.858748544570550610f, 0.858402184055747750f, + 0.858055791979950740f, + 0.857709368355894840f, 0.857362913196317630f, 0.857016426513956930f, + 0.856669908321551650f, + 0.856323358631843170f, 0.855976777457572280f, 0.855630164811482460f, + 0.855283520706317080f, + 0.854936845154821930f, 0.854590138169742830f, 0.854243399763827020f, + 0.853896629949823630f, + 0.853549828740481690f, 0.853202996148552880f, 0.852856132186788910f, + 0.852509236867942440f, + 0.852162310204768740f, 0.851815352210022470f, 0.851468362896461110f, + 0.851121342276842110f, + 0.850774290363923820f, 0.850427207170467380f, 0.850080092709233130f, + 0.849732946992984290f, + 0.849385770034483680f, 0.849038561846496730f, 0.848691322441788910f, + 0.848344051833126780f, + 0.847996750033279350f, 0.847649417055015060f, 0.847302052911105160f, + 0.846954657614320980f, + 0.846607231177434640f, 0.846259773613221020f, 0.845912284934454140f, + 0.845564765153910990f, + 0.845217214284368690f, 0.844869632338605130f, 0.844522019329400630f, + 0.844174375269535320f, + 0.843826700171791620f, 0.843478994048952440f, 0.843131256913801420f, + 0.842783488779124570f, + 0.842435689657707650f, 0.842087859562339000f, 0.841739998505806610f, + 0.841392106500900900f, + 0.841044183560412770f, 0.840696229697133760f, 0.840348244923857960f, + 0.840000229253379030f, + 0.839652182698493290f, 0.839304105271996950f, 0.838955996986687550f, + 0.838607857855364740f, + 0.838259687890827830f, 0.837911487105878820f, 0.837563255513319780f, + 0.837214993125953600f, + 0.836866699956585690f, 0.836518376018021260f, 0.836170021323067610f, + 0.835821635884532730f, + 0.835473219715225040f, 0.835124772827955830f, 0.834776295235535540f, + 0.834427786950777460f, + 0.834079247986494690f, 0.833730678355502630f, 0.833382078070616820f, + 0.833033447144653880f, + 0.832684785590432690f, 0.832336093420771970f, 0.831987370648492710f, + 0.831638617286416190f, + 0.831289833347364620f, 0.830941018844162600f, 0.830592173789634240f, + 0.830243298196606360f, + 0.829894392077905720f, 0.829545455446360270f, 0.829196488314800080f, + 0.828847490696055010f, + 0.828498462602957340f, 0.828149404048339590f, 0.827800315045035150f, + 0.827451195605879990f, + 0.827102045743709160f, 0.826752865471360950f, 0.826403654801672770f, + 0.826054413747485010f, + 0.825705142321637720f, 0.825355840536972420f, 0.825006508406332490f, + 0.824657145942561230f, + 0.824307753158504460f, 0.823958330067008030f, 0.823608876680918760f, + 0.823259393013085820f, + 0.822909879076357930f, 0.822560334883586490f, 0.822210760447622980f, + 0.821861155781319800f, + 0.821511520897531660f, 0.821161855809112830f, 0.820812160528920360f, + 0.820462435069811090f, + 0.820112679444643060f, 0.819762893666276530f, 0.819413077747571440f, + 0.819063231701390170f, + 0.818713355540594880f, 0.818363449278050270f, 0.818013512926620940f, + 0.817663546499172720f, + 0.817313550008573640f, 0.816963523467691410f, 0.816613466889396070f, + 0.816263380286557980f, + 0.815913263672048310f, 0.815563117058740630f, 0.815212940459508210f, + 0.814862733887226740f, + 0.814512497354771830f, 0.814162230875020380f, 0.813811934460851430f, + 0.813461608125143560f, + 0.813111251880778150f, 0.812760865740636440f, 0.812410449717600570f, + 0.812060003824555230f, + 0.811709528074384460f, 0.811359022479975040f, 0.811008487054213360f, + 0.810657921809988410f, + 0.810307326760189020f, 0.809956701917705080f, 0.809606047295428950f, + 0.809255362906252440f, + 0.808904648763069890f, 0.808553904878775760f, 0.808203131266265420f, + 0.807852327938436750f, + 0.807501494908186900f, 0.807150632188415760f, 0.806799739792023240f, + 0.806448817731910130f, + 0.806097866020979660f, 0.805746884672134620f, 0.805395873698280360f, + 0.805044833112322000f, + 0.804693762927166100f, 0.804342663155721230f, 0.803991533810895500f, + 0.803640374905599810f, + 0.803289186452744390f, 0.802937968465242240f, 0.802586720956006250f, + 0.802235443937950320f, + 0.801884137423990890f, 0.801532801427043530f, 0.801181435960026780f, + 0.800830041035858750f, + 0.800478616667459010f, 0.800127162867749210f, 0.799775679649650460f, + 0.799424167026086540f, + 0.799072625009981330f, 0.798721053614259490f, 0.798369452851848020f, + 0.798017822735673680f, + 0.797666163278665570f, 0.797314474493752810f, 0.796962756393865600f, + 0.796611008991936490f, + 0.796259232300897350f, 0.795907426333682830f, 0.795555591103226930f, + 0.795203726622466520f, + 0.794851832904338360f, 0.794499909961779990f, 0.794147957807731400f, + 0.793795976455132220f, + 0.793443965916924570f, 0.793091926206050400f, 0.792739857335452710f, + 0.792387759318077150f, + 0.792035632166868230f, 0.791683475894773720f, 0.791331290514740830f, + 0.790979076039718180f, + 0.790626832482656310f, 0.790274559856505520f, 0.789922258174218570f, + 0.789569927448748320f, + 0.789217567693048520f, 0.788865178920075130f, 0.788512761142783790f, + 0.788160314374132590f, + 0.787807838627079260f, 0.787455333914584220f, 0.787102800249607550f, + 0.786750237645110430f, + 0.786397646114056490f, 0.786045025669408700f, 0.785692376324132690f, + 0.785339698091194080f, + 0.784986990983559170f, 0.784634255014197040f, 0.784281490196075850f, + 0.783928696542166680f, + 0.783575874065440270f, 0.783223022778868350f, 0.782870142695425320f, + 0.782517233828084580f, + 0.782164296189822530f, 0.781811329793615120f, 0.781458334652439630f, + 0.781105310779275470f, + 0.780752258187101480f, 0.780399176888899150f, 0.780046066897649550f, + 0.779692928226336290f, + 0.779339760887942880f, 0.778986564895453810f, 0.778633340261856040f, + 0.778280087000135730f, + 0.777926805123281830f, 0.777573494644283050f, 0.777220155576129220f, + 0.776866787931812410f, + 0.776513391724324210f, 0.776159966966658680f, 0.775806513671809860f, + 0.775453031852772920f, + 0.775099521522545020f, 0.774745982694123090f, 0.774392415380506400f, + 0.774038819594694230f, + 0.773685195349686940f, 0.773331542658487140f, 0.772977861534096640f, + 0.772624151989520280f, + 0.772270414037761980f, 0.771916647691828660f, 0.771562852964726710f, + 0.771209029869463940f, + 0.770855178419050050f, 0.770501298626494410f, 0.770147390504808960f, + 0.769793454067005500f, + 0.769439489326096850f, 0.769085496295098040f, 0.768731474987023660f, + 0.768377425414890850f, + 0.768023347591716640f, 0.767669241530518850f, 0.767315107244318060f, + 0.766960944746133740f, + 0.766606754048988260f, 0.766252535165903970f, 0.765898288109903900f, + 0.765544012894013530f, + 0.765189709531257760f, 0.764835378034664170f, 0.764481018417259680f, + 0.764126630692073870f, + 0.763772214872136200f, 0.763417770970477140f, 0.763063299000129260f, + 0.762708798974124800f, + 0.762354270905498450f, 0.761999714807284790f, 0.761645130692519490f, + 0.761290518574240350f, + 0.760935878465484720f, 0.760581210379292380f, 0.760226514328703140f, + 0.759871790326757670f, + 0.759517038386499090f, 0.759162258520969860f, 0.758807450743214760f, + 0.758452615066278920f, + 0.758097751503208020f, 0.757742860067050380f, 0.757387940770853360f, + 0.757032993627667290f, + 0.756678018650541630f, 0.756323015852528700f, 0.755967985246680520f, + 0.755612926846050080f, + 0.755257840663692730f, 0.754902726712663120f, 0.754547585006018600f, + 0.754192415556816380f, + 0.753837218378114460f, 0.753481993482973400f, 0.753126740884452970f, + 0.752771460595615500f, + 0.752416152629523330f, 0.752060816999239660f, 0.751705453717829930f, + 0.751350062798359140f, + 0.750994644253894730f, 0.750639198097504010f, 0.750283724342255320f, + 0.749928223001219310f, + 0.749572694087465850f, 0.749217137614067500f, 0.748861553594096340f, + 0.748505942040627040f, + 0.748150302966733790f, 0.747794636385492150f, 0.747438942309979870f, + 0.747083220753273820f, + 0.746727471728453770f, 0.746371695248599140f, 0.746015891326790470f, + 0.745660059976110400f, + 0.745304201209641030f, 0.744948315040467210f, 0.744592401481673270f, + 0.744236460546344850f, + 0.743880492247569580f, 0.743524496598434670f, 0.743168473612029980f, + 0.742812423301444810f, + 0.742456345679769810f, 0.742100240760097840f, 0.741744108555520860f, + 0.741387949079133860f, + 0.741031762344030790f, 0.740675548363308620f, 0.740319307150063780f, + 0.739963038717393880f, + 0.739606743078398690f, 0.739250420246177380f, 0.738894070233831800f, + 0.738537693054463370f, + 0.738181288721174830f, 0.737824857247070810f, 0.737468398645255490f, + 0.737111912928835710f, + 0.736755400110918000f, 0.736398860204609870f, 0.736042293223021060f, + 0.735685699179260850f, + 0.735329078086440880f, 0.734972429957672760f, 0.734615754806068890f, + 0.734259052644744230f, + 0.733902323486812610f, 0.733545567345390890f, 0.733188784233595240f, + 0.732831974164544150f, + 0.732475137151356370f, 0.732118273207151170f, 0.731761382345050280f, + 0.731404464578174760f, + 0.731047519919648340f, 0.730690548382594280f, 0.730333549980137110f, + 0.729976524725403530f, + 0.729619472631519270f, 0.729262393711613280f, 0.728905287978813600f, + 0.728548155446249730f, + 0.728190996127053180f, 0.727833810034354990f, 0.727476597181288540f, + 0.727119357580987220f, + 0.726762091246585200f, 0.726404798191218950f, 0.726047478428024420f, + 0.725690131970139980f, + 0.725332758830703360f, 0.724975359022855150f, 0.724617932559735390f, + 0.724260479454485130f, + 0.723902999720247850f, 0.723545493370166160f, 0.723187960417385530f, + 0.722830400875050790f, + 0.722472814756308090f, 0.722115202074305680f, 0.721757562842191060f, + 0.721399897073114470f, + 0.721042204780225960f, 0.720684485976676230f, 0.720326740675618530f, + 0.719968968890205230f, + 0.719611170633591480f, 0.719253345918932090f, 0.718895494759382860f, + 0.718537617168101610f, + 0.718179713158245800f, 0.717821782742975370f, 0.717463825935449550f, + 0.717105842748830160f, + 0.716747833196278770f, 0.716389797290958090f, 0.716031735046032900f, + 0.715673646474667140f, + 0.715315531590027700f, 0.714957390405280950f, 0.714599222933594240f, + 0.714241029188137260f, + 0.713882809182079030f, 0.713524562928591010f, 0.713166290440844450f, + 0.712807991732011590f, + 0.712449666815266890f, 0.712091315703784260f, 0.711732938410739810f, + 0.711374534949309800f, + 0.711016105332671340f, 0.710657649574003460f, 0.710299167686484930f, + 0.709940659683296890f, + 0.709582125577619790f, 0.709223565382636760f, 0.708864979111530680f, + 0.708506366777485130f, + 0.708147728393686340f, 0.707789063973319310f, 0.707430373529572170f, + 0.707071657075632460f, + 0.706712914624688770f, 0.706354146189931750f, 0.705995351784551530f, + 0.705636531421740880f, + 0.705277685114692020f, 0.704918812876598410f, 0.704559914720655490f, + 0.704200990660058150f, + 0.703842040708003820f, 0.703483064877689630f, 0.703124063182313690f, + 0.702765035635076310f, + 0.702405982249177160f, 0.702046903037818250f, 0.701687798014201110f, + 0.701328667191529980f, + 0.700969510583008600f, 0.700610328201841660f, 0.700251120061236020f, + 0.699891886174398130f, + 0.699532626554536630f, 0.699173341214860190f, 0.698814030168578240f, + 0.698454693428902320f, + 0.698095331009043640f, 0.697735942922215520f, 0.697376529181631400f, + 0.697017089800505250f, + 0.696657624792053730f, 0.696298134169492380f, 0.695938617946039510f, + 0.695579076134912990f, + 0.695219508749331800f, 0.694859915802517050f, 0.694500297307689140f, + 0.694140653278070950f, + 0.693780983726884790f, 0.693421288667355530f, 0.693061568112707690f, + 0.692701822076166820f, + 0.692342050570960430f, 0.691982253610315510f, 0.691622431207461700f, + 0.691262583375628180f, + 0.690902710128045050f, 0.690542811477944610f, 0.690182887438558710f, + 0.689822938023121220f, + 0.689462963244866330f, 0.689102963117028790f, 0.688742937652845550f, + 0.688382886865552930f, + 0.688022810768389670f, 0.687662709374594510f, 0.687302582697406850f, + 0.686942430750068330f, + 0.686582253545819920f, 0.686222051097905130f, 0.685861823419566700f, + 0.685501570524050140f, + 0.685141292424600310f, 0.684780989134463280f, 0.684420660666887120f, + 0.684060307035119440f, + 0.683699928252410110f, 0.683339524332008840f, 0.682979095287166160f, + 0.682618641131135020f, + 0.682258161877167370f, 0.681897657538517720f, 0.681537128128440470f, + 0.681176573660190910f, + 0.680815994147026320f, 0.680455389602203310f, 0.680094760038981280f, + 0.679734105470619080f, + 0.679373425910376310f, 0.679012721371515250f, 0.678651991867297080f, + 0.678291237410985510f, + 0.677930458015843620f, 0.677569653695137220f, 0.677208824462131490f, + 0.676847970330092700f, + 0.676487091312289350f, 0.676126187421989040f, 0.675765258672461950f, + 0.675404305076978020f, + 0.675043326648808170f, 0.674682323401225250f, 0.674321295347501510f, + 0.673960242500911690f, + 0.673599164874730370f, 0.673238062482232950f, 0.672876935336696900f, + 0.672515783451398950f, + 0.672154606839618470f, 0.671793405514634180f, 0.671432179489727110f, + 0.671070928778178090f, + 0.670709653393269050f, 0.670348353348283690f, 0.669987028656505170f, + 0.669625679331219300f, + 0.669264305385711360f, 0.668902906833267590f, 0.668541483687176590f, + 0.668180035960725840f, + 0.667818563667205600f, 0.667457066819905800f, 0.667095545432117240f, + 0.666733999517132860f, + 0.666372429088244790f, 0.666010834158747840f, 0.665649214741936390f, + 0.665287570851105680f, + 0.664925902499553190f, 0.664564209700575500f, 0.664202492467472090f, + 0.663840750813541210f, + 0.663478984752084110f, 0.663117194296401260f, 0.662755379459794350f, + 0.662393540255567070f, + 0.662031676697022450f, 0.661669788797465960f, 0.661307876570202740f, + 0.660945940028538900f, + 0.660583979185782600f, 0.660221994055241400f, 0.659859984650225110f, + 0.659497950984043510f, + 0.659135893070007080f, 0.658773810921428500f, 0.658411704551619570f, + 0.658049573973894850f, + 0.657687419201568260f, 0.657325240247955020f, 0.656963037126372160f, + 0.656600809850135910f, + 0.656238558432565400f, 0.655876282886978410f, 0.655513983226695960f, + 0.655151659465038060f, + 0.654789311615326050f, 0.654426939690883280f, 0.654064543705032310f, + 0.653702123671098150f, + 0.653339679602405470f, 0.652977211512280050f, 0.652614719414049580f, + 0.652252203321041060f, + 0.651889663246583930f, 0.651527099204007310f, 0.651164511206641320f, + 0.650801899267818060f, + 0.650439263400868990f, 0.650076603619127890f, 0.649713919935928420f, + 0.649351212364604910f, + 0.648988480918494040f, 0.648625725610931460f, 0.648262946455255510f, + 0.647900143464803730f, + 0.647537316652916140f, 0.647174466032932490f, 0.646811591618193350f, + 0.646448693422041360f, + 0.646085771457818310f, 0.645722825738868860f, 0.645359856278536980f, + 0.644996863090167570f, + 0.644633846187107620f, 0.644270805582703550f, 0.643907741290304040f, + 0.643544653323257610f, + 0.643181541694913480f, 0.642818406418622980f, 0.642455247507736860f, + 0.642092064975608220f, + 0.641728858835589830f, 0.641365629101035340f, 0.641002375785300500f, + 0.640639098901740200f, + 0.640275798463712080f, 0.639912474484572560f, 0.639549126977681070f, + 0.639185755956396480f, + 0.638822361434078330f, 0.638458943424088490f, 0.638095501939787920f, + 0.637732036994540290f, + 0.637368548601708660f, 0.637005036774657030f, 0.636641501526751590f, + 0.636277942871357530f, + 0.635914360821842830f, 0.635550755391574910f, 0.635187126593922070f, + 0.634823474442254840f, + 0.634459798949942640f, 0.634096100130357660f, 0.633732377996871770f, + 0.633368632562857470f, + 0.633004863841689520f, 0.632641071846741790f, 0.632277256591390780f, + 0.631913418089012020f, + 0.631549556352983710f, 0.631185671396683470f, 0.630821763233490040f, + 0.630457831876783950f, + 0.630093877339945260f, 0.629729899636356280f, 0.629365898779399080f, + 0.629001874782456500f, + 0.628637827658913300f, 0.628273757422153860f, 0.627909664085564810f, + 0.627545547662532230f, + 0.627181408166443410f, 0.626817245610687520f, 0.626453060008652860f, + 0.626088851373730380f, + 0.625724619719310480f, 0.625360365058784670f, 0.624996087405546350f, + 0.624631786772988030f, + 0.624267463174504880f, 0.623903116623491180f, 0.623538747133343780f, + 0.623174354717459190f, + 0.622809939389234460f, 0.622445501162069090f, 0.622081040049361490f, + 0.621716556064512820f, + 0.621352049220923570f, 0.620987519531995270f, 0.620622967011131400f, + 0.620258391671734690f, + 0.619893793527210410f, 0.619529172590963410f, 0.619164528876399280f, + 0.618799862396925750f, + 0.618435173165949760f, 0.618070461196880800f, 0.617705726503127720f, + 0.617340969098100430f, + 0.616976188995210780f, 0.616611386207870040f, 0.616246560749491690f, + 0.615881712633488340f, + 0.615516841873275490f, 0.615151948482267840f, 0.614787032473881110f, + 0.614422093861533010f, + 0.614057132658640590f, 0.613692148878623000f, 0.613327142534899510f, + 0.612962113640889710f, + 0.612597062210015750f, 0.612231988255698470f, 0.611866891791361560f, + 0.611501772830428060f, + 0.611136631386322020f, 0.610771467472469460f, 0.610406281102295440f, + 0.610041072289227990f, + 0.609675841046694030f, 0.609310587388121830f, 0.608945311326941520f, + 0.608580012876582370f, + 0.608214692050476290f, 0.607849348862054220f, 0.607483983324749510f, + 0.607118595451995420f, + 0.606753185257225550f, 0.606387752753876020f, 0.606022297955381760f, + 0.605656820875180360f, + 0.605291321526709060f, 0.604925799923405670f, 0.604560256078710220f, + 0.604194690006061960f, + 0.603829101718902580f, 0.603463491230673220f, 0.603097858554815790f, + 0.602732203704774650f, + 0.602366526693992930f, 0.602000827535916330f, 0.601635106243990190f, + 0.601269362831660550f, + 0.600903597312375640f, 0.600537809699582810f, 0.600172000006731770f, + 0.599806168247271620f, + 0.599440314434653620f, 0.599074438582328780f, 0.598708540703749010f, + 0.598342620812368000f, + 0.597976678921638860f, 0.597610715045016950f, 0.597244729195957500f, + 0.596878721387916090f, + 0.596512691634350830f, 0.596146639948718640f, 0.595780566344478960f, + 0.595414470835091030f, + 0.595048353434014630f, 0.594682214154711790f, 0.594316053010643270f, + 0.593949870015273000f, + 0.593583665182063740f, 0.593217438524479500f, 0.592851190055986300f, + 0.592484919790049140f, + 0.592118627740135460f, 0.591752313919712170f, 0.591385978342248260f, + 0.591019621021212420f, + 0.590653241970074180f, 0.590286841202305120f, 0.589920418731375800f, + 0.589553974570759530f, + 0.589187508733928890f, 0.588821021234357310f, 0.588454512085520460f, + 0.588087981300892900f, + 0.587721428893951850f, 0.587354854878173850f, 0.586988259267036350f, + 0.586621642074019120f, + 0.586255003312600500f, 0.585888342996261690f, 0.585521661138483250f, + 0.585154957752746730f, + 0.584788232852535560f, 0.584421486451332410f, 0.584054718562622140f, + 0.583687929199888990f, + 0.583321118376619710f, 0.582954286106300290f, 0.582587432402417840f, + 0.582220557278461340f, + 0.581853660747918780f, 0.581486742824280810f, 0.581119803521037650f, + 0.580752842851679940f, + 0.580385860829700780f, 0.580018857468592270f, 0.579651832781848730f, + 0.579284786782964360f, + 0.578917719485433800f, 0.578550630902754050f, 0.578183521048421080f, + 0.577816389935933090f, + 0.577449237578788300f, 0.577082063990485340f, 0.576714869184524860f, + 0.576347653174406840f, + 0.575980415973633590f, 0.575613157595706530f, 0.575245878054129520f, + 0.574878577362406000f, + 0.574511255534040030f, 0.574143912582537940f, 0.573776548521405030f, + 0.573409163364148930f, + 0.573041757124277180f, 0.572674329815297640f, 0.572306881450720390f, + 0.571939412044054740f, + 0.571571921608812320f, 0.571204410158504090f, 0.570836877706642270f, + 0.570469324266740570f, + 0.570101749852312100f, 0.569734154476872480f, 0.569366538153936560f, + 0.568998900897020210f, + 0.568631242719641270f, 0.568263563635316600f, 0.567895863657565500f, + 0.567528142799906490f, + 0.567160401075860410f, 0.566792638498947680f, 0.566424855082689470f, + 0.566057050840608870f, + 0.565689225786228160f, 0.565321379933072190f, 0.564953513294665140f, + 0.564585625884531870f, + 0.564217717716199550f, 0.563849788803194140f, 0.563481839159044150f, + 0.563113868797277870f, + 0.562745877731423820f, 0.562377865975012940f, 0.562009833541575080f, + 0.561641780444642640f, + 0.561273706697747450f, 0.560905612314422150f, 0.560537497308201240f, + 0.560169361692618440f, + 0.559801205481210040f, 0.559433028687510990f, 0.559064831325059240f, + 0.558696613407391630f, + 0.558328374948046320f, 0.557960115960563050f, 0.557591836458480870f, + 0.557223536455341280f, + 0.556855215964685120f, 0.556486875000054000f, 0.556118513574991650f, + 0.555750131703040880f, + 0.555381729397746880f, 0.555013306672654360f, 0.554644863541308600f, + 0.554276400017257090f, + 0.553907916114046440f, 0.553539411845225590f, 0.553170887224342820f, + 0.552802342264947400f, + 0.552433776980590490f, 0.552065191384822350f, 0.551696585491195710f, + 0.551327959313262280f, + 0.550959312864576220f, 0.550590646158691240f, 0.550221959209161620f, + 0.549853252029543830f, + 0.549484524633393480f, 0.549115777034268170f, 0.548747009245725500f, + 0.548378221281323520f, + 0.548009413154622370f, 0.547640584879181100f, 0.547271736468561530f, + 0.546902867936324590f, + 0.546533979296032200f, 0.546165070561248080f, 0.545796141745535150f, + 0.545427192862458780f, + 0.545058223925583670f, 0.544689234948475210f, 0.544320225944701200f, + 0.543951196927828010f, + 0.543582147911424560f, 0.543213078909059120f, 0.542843989934301940f, + 0.542474881000723050f, + 0.542105752121893050f, 0.541736603311384620f, 0.541367434582769480f, + 0.540998245949621760f, + 0.540629037425515050f, 0.540259809024023600f, 0.539890560758723770f, + 0.539521292643190930f, + 0.539152004691002770f, 0.538782696915736770f, 0.538413369330970610f, + 0.538044021950284450f, + 0.537674654787257180f, 0.537305267855470390f, 0.536935861168504670f, + 0.536566434739941920f, + 0.536196988583365510f, 0.535827522712358230f, 0.535458037140505110f, + 0.535088531881390050f, + 0.534719006948599860f, 0.534349462355720230f, 0.533979898116337950f, + 0.533610314244041710f, + 0.533240710752419080f, 0.532871087655060300f, 0.532501444965554960f, + 0.532131782697493170f, + 0.531762100864467290f, 0.531392399480068670f, 0.531022678557890980f, + 0.530652938111527360f, + 0.530283178154571710f, 0.529913398700619820f, 0.529543599763266700f, + 0.529173781356109600f, + 0.528803943492745180f, 0.528434086186771010f, 0.528064209451786560f, + 0.527694313301390160f, + 0.527324397749182720f, 0.526954462808764120f, 0.526584508493736840f, + 0.526214534817702310f, + 0.525844541794263210f, 0.525474529437023890f, 0.525104497759587900f, + 0.524734446775560910f, + 0.524364376498548390f, 0.523994286942156220f, 0.523624178119992400f, + 0.523254050045663940f, + 0.522883902732780290f, 0.522513736194950230f, 0.522143550445783310f, + 0.521773345498891090f, + 0.521403121367884030f, 0.521032878066375100f, 0.520662615607976660f, + 0.520292334006301820f, + 0.519922033274965560f, 0.519551713427582000f, 0.519181374477767470f, + 0.518811016439137520f, + 0.518440639325310040f, 0.518070243149902240f, 0.517699827926532130f, + 0.517329393668819580f, + 0.516958940390383700f, 0.516588468104845820f, 0.516217976825826600f, + 0.515847466566947580f, + 0.515476937341832310f, 0.515106389164103120f, 0.514735822047384990f, + 0.514365236005302040f, + 0.513994631051479240f, 0.513624007199543600f, 0.513253364463121090f, + 0.512882702855839920f, + 0.512512022391327980f, 0.512141323083213470f, 0.511770604945127050f, + 0.511399867990697920f, + 0.511029112233557960f, 0.510658337687338040f, 0.510287544365671140f, + 0.509916732282189920f, + 0.509545901450527690f, 0.509175051884319660f, 0.508804183597200140f, + 0.508433296602805670f, + 0.508062390914772230f, 0.507691466546736580f, 0.507320523512337470f, + 0.506949561825212450f, + 0.506578581499001590f, 0.506207582547344550f, 0.505836564983881190f, + 0.505465528822253710f, + 0.505094474076103310f, 0.504723400759073290f, 0.504352308884806750f, + 0.503981198466947000f, + 0.503610069519139780f, 0.503238922055029400f, 0.502867756088262840f, + 0.502496571632486070f, + 0.502125368701347050f, 0.501754147308493770f, 0.501382907467574190f, + 0.501011649192238950f, + 0.500640372496137020f, 0.500269077392920150f, 0.499897763896239410f, + 0.499526432019746450f, + 0.499155081777094940f, 0.498783713181937540f, 0.498412326247929250f, + 0.498040920988724490f, + 0.497669497417978280f, 0.497298055549347750f, 0.496926595396488870f, + 0.496555116973059980f, + 0.496183620292718900f, 0.495812105369124070f, 0.495440572215935850f, + 0.495069020846813650f, + 0.494697451275419140f, 0.494325863515413130f, 0.493954257580458580f, + 0.493582633484217940f, + 0.493210991240354450f, 0.492839330862533120f, 0.492467652364417970f, + 0.492095955759675460f, + 0.491724241061971320f, 0.491352508284972070f, 0.490980757442346090f, + 0.490608988547760690f, + 0.490237201614885710f, 0.489865396657390210f, 0.489493573688943970f, + 0.489121732723218740f, + 0.488749873773885120f, 0.488377996854616250f, 0.488006101979084450f, + 0.487634189160962910f, + 0.487262258413926560f, 0.486890309751649490f, 0.486518343187807900f, + 0.486146358736077200f, + 0.485774356410135000f, 0.485402336223658360f, 0.485030298190324950f, + 0.484658242323814380f, + 0.484286168637805270f, 0.483914077145978560f, 0.483541967862014480f, + 0.483169840799594130f, + 0.482797695972400300f, 0.482425533394114920f, 0.482053353078422120f, + 0.481681155039005550f, + 0.481308939289549380f, 0.480936705843739820f, 0.480564454715261990f, + 0.480192185917803270f, + 0.479819899465050160f, 0.479447595370691370f, 0.479075273648415010f, + 0.478702934311909910f, + 0.478330577374866780f, 0.477958202850975230f, 0.477585810753927250f, + 0.477213401097414220f, + 0.476840973895128200f, 0.476468529160763100f, 0.476096066908011760f, + 0.475723587150569390f, + 0.475351089902130650f, 0.474978575176390750f, 0.474606042987046840f, + 0.474233493347795020f, + 0.473860926272333670f, 0.473488341774360670f, 0.473115739867574380f, + 0.472743120565675250f, + 0.472370483882362520f, 0.471997829831337810f, 0.471625158426301700f, + 0.471252469680957190f, + 0.470879763609006460f, 0.470507040224152460f, 0.470134299540099940f, + 0.469761541570552780f, + 0.469388766329217000f, 0.469015973829798090f, 0.468643164086002100f, + 0.468270337111537040f, + 0.467897492920109850f, 0.467524631525429830f, 0.467151752941205530f, + 0.466778857181146260f, + 0.466405944258963200f, 0.466033014188366350f, 0.465660066983068220f, + 0.465287102656780530f, + 0.464914121223215740f, 0.464541122696088100f, 0.464168107089110940f, + 0.463795074415999760f, + 0.463422024690469060f, 0.463048957926235630f, 0.462675874137015720f, + 0.462302773336526080f, + 0.461929655538485470f, 0.461556520756611410f, 0.461183369004623920f, + 0.460810200296242310f, + 0.460437014645186440f, 0.460063812065178160f, 0.459690592569938270f, + 0.459317356173189750f, + 0.458944102888655060f, 0.458570832730057170f, 0.458197545711121090f, + 0.457824241845570630f, + 0.457450921147131930f, 0.457077583629530550f, 0.456704229306492570f, + 0.456330858191746010f, + 0.455957470299017840f, 0.455584065642037350f, 0.455210644234532610f, + 0.454837206090234200f, + 0.454463751222871910f, 0.454090279646176210f, 0.453716791373879380f, + 0.453343286419712720f, + 0.452969764797409750f, 0.452596226520703360f, 0.452222671603327130f, + 0.451849100059016350f, + 0.451475511901505420f, 0.451101907144530910f, 0.450728285801828830f, + 0.450354647887135640f, + 0.449980993414189900f, 0.449607322396728900f, 0.449233634848492320f, + 0.448859930783219170f, + 0.448486210214649020f, 0.448112473156523420f, 0.447738719622582710f, + 0.447364949626569590f, + 0.446991163182225700f, 0.446617360303294910f, 0.446243541003520480f, + 0.445869705296646270f, + 0.445495853196417930f, 0.445121984716580210f, 0.444748099870879880f, + 0.444374198673063330f, + 0.444000281136877280f, 0.443626347276070590f, 0.443252397104390790f, + 0.442878430635587910f, + 0.442504447883411090f, 0.442130448861610240f, 0.441756433583937120f, + 0.441382402064142250f, + 0.441008354315978680f, 0.440634290353198510f, 0.440260210189554690f, + 0.439886113838801880f, + 0.439512001314693700f, 0.439137872630986080f, 0.438763727801433690f, + 0.438389566839793740f, + 0.438015389759822630f, 0.437641196575277220f, 0.437266987299916590f, + 0.436892761947498260f, + 0.436518520531782470f, 0.436144263066528480f, 0.435769989565496290f, + 0.435395700042447710f, + 0.435021394511143410f, 0.434647072985346380f, 0.434272735478819010f, + 0.433898382005324050f, + 0.433524012578626440f, 0.433149627212489670f, 0.432775225920679740f, + 0.432400808716961900f, + 0.432026375615101930f, 0.431651926628867530f, 0.431277461772025310f, + 0.430902981058344070f, + 0.430528484501591540f, 0.430153972115537800f, 0.429779443913952170f, + 0.429404899910604490f, + 0.429030340119266550f, 0.428655764553708960f, 0.428281173227704760f, + 0.427906566155026040f, + 0.427531943349445720f, 0.427157304824738350f, 0.426782650594677570f, + 0.426407980673039090f, + 0.426033295073598160f, 0.425658593810130330f, 0.425283876896413280f, + 0.424909144346223290f, + 0.424534396173339160f, 0.424159632391538870f, 0.423784853014600950f, + 0.423410058056305830f, + 0.423035247530432810f, 0.422660421450763490f, 0.422285579831078230f, + 0.421910722685159720f, + 0.421535850026790060f, 0.421160961869751720f, 0.420786058227829220f, + 0.420411139114805770f, + 0.420036204544466940f, 0.419661254530597550f, 0.419286289086983070f, + 0.418911308227410740f, + 0.418536311965666650f, 0.418161300315539220f, 0.417786273290816130f, + 0.417411230905285650f, + 0.417036173172737830f, 0.416661100106961610f, 0.416286011721748230f, + 0.415910908030888200f, + 0.415535789048172620f, 0.415160654787394280f, 0.414785505262345030f, + 0.414410340486818910f, + 0.414035160474608700f, 0.413659965239509710f, 0.413284754795316230f, + 0.412909529155823300f, + 0.412534288334827750f, 0.412159032346125280f, 0.411783761203513790f, + 0.411408474920790520f, + 0.411033173511753220f, 0.410657856990201580f, 0.410282525369933980f, + 0.409907178664751180f, + 0.409531816888453190f, 0.409156440054840590f, 0.408781048177715660f, + 0.408405641270879690f, + 0.408030219348136270f, 0.407654782423288010f, 0.407279330510138260f, + 0.406903863622492260f, + 0.406528381774153900f, 0.406152884978929480f, 0.405777373250624070f, + 0.405401846603045010f, + 0.405026305049998980f, 0.404650748605293040f, 0.404275177282736260f, + 0.403899591096136380f, + 0.403523990059303620f, 0.403148374186047210f, 0.402772743490177110f, + 0.402397097985504990f, + 0.402021437685841480f, 0.401645762604999350f, 0.401270072756790610f, + 0.400894368155027990f, + 0.400518648813525830f, 0.400142914746097480f, 0.399767165966558420f, + 0.399391402488723400f, + 0.399015624326407800f, 0.398639831493428740f, 0.398264024003602220f, + 0.397888201870746420f, + 0.397512365108678430f, 0.397136513731217500f, 0.396760647752182230f, + 0.396384767185391620f, + 0.396008872044666730f, 0.395632962343827170f, 0.395257038096694990f, + 0.394881099317091370f, + 0.394505146018838130f, 0.394129178215758820f, 0.393753195921675850f, + 0.393377199150413860f, + 0.393001187915796750f, 0.392625162231649010f, 0.392249122111796800f, + 0.391873067570065240f, + 0.391496998620281590f, 0.391120915276272410f, 0.390744817551864850f, + 0.390368705460887750f, + 0.389992579017168830f, 0.389616438234538010f, 0.389240283126824070f, + 0.388864113707858060f, + 0.388487929991470140f, 0.388111731991491180f, 0.387735519721753690f, + 0.387359293196089140f, + 0.386983052428331030f, 0.386606797432312350f, 0.386230528221866430f, + 0.385854244810828530f, + 0.385477947213032580f, 0.385101635442314900f, 0.384725309512510880f, + 0.384348969437456610f, + 0.383972615230989860f, 0.383596246906947210f, 0.383219864479167560f, + 0.382843467961488940f, + 0.382467057367749940f, 0.382090632711791060f, 0.381714194007451380f, + 0.381337741268572390f, + 0.380961274508994250f, 0.380584793742559550f, 0.380208298983109930f, + 0.379831790244487540f, + 0.379455267540536490f, 0.379078730885099520f, 0.378702180292021630f, + 0.378325615775147170f, + 0.377949037348320800f, 0.377572445025389230f, 0.377195838820197690f, + 0.376819218746593910f, + 0.376442584818424570f, 0.376065937049537060f, 0.375689275453780500f, + 0.375312600045002780f, + 0.374935910837054080f, 0.374559207843783660f, 0.374182491079041500f, + 0.373805760556679190f, + 0.373429016290547200f, 0.373052258294498230f, 0.372675486582383640f, + 0.372298701168057190f, + 0.371921902065371730f, 0.371545089288180640f, 0.371168262850339210f, + 0.370791422765701320f, + 0.370414569048123140f, 0.370037701711460170f, 0.369660820769568240f, + 0.369283926236305070f, + 0.368907018125527120f, 0.368530096451093140f, 0.368153161226860980f, + 0.367776212466689010f, + 0.367399250184437480f, 0.367022274393965340f, 0.366645285109133750f, + 0.366268282343803150f, + 0.365891266111834370f, 0.365514236427090080f, 0.365137193303431750f, + 0.364760136754723020f, + 0.364383066794826350f, 0.364005983437606320f, 0.363628886696926890f, + 0.363251776586652310f, + 0.362874653120648700f, 0.362497516312780990f, 0.362120366176916230f, + 0.361743202726920790f, + 0.361366025976661450f, 0.360988835940006750f, 0.360611632630824020f, + 0.360234416062982840f, + 0.359857186250351960f, 0.359479943206800550f, 0.359102686946199680f, + 0.358725417482419150f, + 0.358348134829330870f, 0.357970839000806010f, 0.357593530010716310f, + 0.357216207872935120f, + 0.356838872601334680f, 0.356461524209789380f, 0.356084162712172360f, + 0.355706788122359060f, + 0.355329400454223950f, 0.354951999721642100f, 0.354574585938490280f, + 0.354197159118644080f, + 0.353819719275981330f, 0.353442266424378930f, 0.353064800577714280f, + 0.352687321749866610f, + 0.352309829954713830f, 0.351932325206136210f, 0.351554807518012990f, + 0.351177276904224070f, + 0.350799733378650890f, 0.350422176955173910f, 0.350044607647675640f, + 0.349667025470037810f, + 0.349289430436142520f, 0.348911822559873850f, 0.348534201855114360f, + 0.348156568335749040f, + 0.347778922015661520f, 0.347401262908737570f, 0.347023591028862320f, + 0.346645906389921150f, + 0.346268209005801410f, 0.345890498890388980f, 0.345512776057572080f, + 0.345135040521238170f, + 0.344757292295274910f, 0.344379531393571970f, 0.344001757830017680f, + 0.343623971618502560f, + 0.343246172772916250f, 0.342868361307148980f, 0.342490537235092600f, + 0.342112700570637750f, + 0.341734851327677280f, 0.341356989520103240f, 0.340979115161808070f, + 0.340601228266685980f, + 0.340223328848629880f, 0.339845416921535030f, 0.339467492499295200f, + 0.339089555595806560f, + 0.338711606224964210f, 0.338333644400663940f, 0.337955670136803170f, + 0.337577683447278010f, + 0.337199684345986910f, 0.336821672846827290f, 0.336443648963697160f, + 0.336065612710496290f, + 0.335687564101123050f, 0.335309503149478110f, 0.334931429869461230f, + 0.334553344274972690f, + 0.334175246379914470f, 0.333797136198187240f, 0.333419013743693980f, + 0.333040879030336690f, + 0.332662732072017800f, 0.332284572882641680f, 0.331906401476111280f, + 0.331528217866331690f, + 0.331150022067206780f, 0.330771814092642610f, 0.330393593956544440f, + 0.330015361672817750f, + 0.329637117255370090f, 0.329258860718107450f, 0.328880592074938190f, + 0.328502311339769700f, + 0.328124018526509800f, 0.327745713649068180f, 0.327367396721353070f, + 0.326989067757275040f, + 0.326610726770743760f, 0.326232373775669270f, 0.325854008785963320f, + 0.325475631815536570f, + 0.325097242878301660f, 0.324718841988170470f, 0.324340429159055250f, + 0.323962004404870050f, + 0.323583567739527570f, 0.323205119176942720f, 0.322826658731029110f, + 0.322448186415702550f, + 0.322069702244877910f, 0.321691206232470550f, 0.321312698392397570f, + 0.320934178738574720f, + 0.320555647284919980f, 0.320177104045350440f, 0.319798549033783570f, + 0.319419982264138650f, + 0.319041403750333630f, 0.318662813506288670f, 0.318284211545923010f, + 0.317905597883156250f, + 0.317526972531909870f, 0.317148335506103940f, 0.316769686819660780f, + 0.316391026486501690f, + 0.316012354520548600f, 0.315633670935725030f, 0.315254975745953180f, + 0.314876268965157470f, + 0.314497550607261090f, 0.314118820686189180f, 0.313740079215866160f, + 0.313361326210216840f, + 0.312982561683167790f, 0.312603785648644220f, 0.312224998120573420f, + 0.311846199112882030f, + 0.311467388639496860f, 0.311088566714346650f, 0.310709733351358600f, + 0.310330888564462340f, + 0.309952032367586390f, 0.309573164774659850f, 0.309194285799613390f, + 0.308815395456376430f, + 0.308436493758880660f, 0.308057580721056660f, 0.307678656356835560f, + 0.307299720680150270f, + 0.306920773704932260f, 0.306541815445115160f, 0.306162845914631390f, + 0.305783865127415400f, + 0.305404873097400780f, 0.305025869838521590f, 0.304646855364713530f, + 0.304267829689911010f, + 0.303888792828050650f, 0.303509744793068030f, 0.303130685598899270f, + 0.302751615259482190f, + 0.302372533788753170f, 0.301993441200650910f, 0.301614337509113100f, + 0.301235222728077840f, + 0.300856096871485010f, 0.300476959953273060f, 0.300097811987382670f, + 0.299718652987753580f, + 0.299339482968325970f, 0.298960301943041680f, 0.298581109925841300f, + 0.298201906930667390f, + 0.297822692971461410f, 0.297443468062166820f, 0.297064232216726120f, + 0.296684985449082390f, + 0.296305727773180260f, 0.295926459202963120f, 0.295547179752376430f, + 0.295167889435364820f, + 0.294788588265873170f, 0.294409276257848300f, 0.294029953425235520f, + 0.293650619781982260f, + 0.293271275342035120f, 0.292891920119341120f, 0.292512554127848930f, + 0.292133177381505850f, + 0.291753789894261320f, 0.291374391680063520f, 0.290994982752862730f, + 0.290615563126608250f, + 0.290236132815249790f, 0.289856691832738880f, 0.289477240193025510f, + 0.289097777910061970f, + 0.288718304997799550f, 0.288338821470189910f, 0.287959327341186510f, + 0.287579822624741350f, + 0.287200307334808670f, 0.286820781485341620f, 0.286441245090293950f, + 0.286061698163620930f, + 0.285682140719276560f, 0.285302572771216960f, 0.284922994333397350f, + 0.284543405419773240f, + 0.284163806044301910f, 0.283784196220939370f, 0.283404575963643550f, + 0.283024945286371230f, + 0.282645304203081090f, 0.282265652727731130f, 0.281885990874279570f, + 0.281506318656686290f, + 0.281126636088910030f, 0.280746943184911340f, 0.280367239958650150f, + 0.279987526424086530f, + 0.279607802595182420f, 0.279228068485898210f, 0.278848324110196550f, + 0.278468569482039130f, + 0.278088804615388040f, 0.277709029524206950f, 0.277329244222458250f, + 0.276949448724106480f, + 0.276569643043115150f, 0.276189827193448200f, 0.275810001189071290f, + 0.275430165043948570f, + 0.275050318772046500f, 0.274670462387330010f, 0.274290595903766200f, + 0.273910719335321300f, + 0.273530832695961790f, 0.273150935999655950f, 0.272771029260370560f, + 0.272391112492074590f, + 0.272011185708736060f, 0.271631248924323390f, 0.271251302152806570f, + 0.270871345408154380f, + 0.270491378704337540f, 0.270111402055325910f, 0.269731415475089780f, + 0.269351418977600950f, + 0.268971412576829990f, 0.268591396286749500f, 0.268211370121331170f, + 0.267831334094547010f, + 0.267451288220370730f, 0.267071232512774700f, 0.266691166985733360f, + 0.266311091653219700f, + 0.265931006529208920f, 0.265550911627675250f, 0.265170806962593210f, + 0.264790692547939020f, + 0.264410568397687560f, 0.264030434525815760f, 0.263650290946299660f, + 0.263270137673115630f, + 0.262889974720241610f, 0.262509802101654310f, 0.262129619831332370f, + 0.261749427923253670f, + 0.261369226391396310f, 0.260989015249740050f, 0.260608794512263380f, + 0.260228564192946710f, + 0.259848324305769600f, 0.259468074864711960f, 0.259087815883755400f, + 0.258707547376880010f, + 0.258327269358068100f, 0.257946981841300490f, 0.257566684840560170f, + 0.257186378369829110f, + 0.256806062443089680f, 0.256425737074325920f, 0.256045402277520320f, + 0.255665058066657680f, + 0.255284704455721660f, 0.254904341458696390f, 0.254523969089567590f, + 0.254143587362319620f, + 0.253763196290938850f, 0.253382795889410710f, 0.253002386171721110f, + 0.252621967151857420f, + 0.252241538843805680f, 0.251861101261554090f, 0.251480654419089730f, + 0.251100198330400150f, + 0.250719733009474530f, 0.250339258470300590f, 0.249958774726868170f, + 0.249578281793165680f, + 0.249197779683183660f, 0.248817268410911650f, 0.248436747990339490f, + 0.248056218435458720f, + 0.247675679760259450f, 0.247295131978733870f, 0.246914575104873220f, + 0.246534009152669040f, + 0.246153434136114490f, 0.245772850069201410f, 0.245392256965923620f, + 0.245011654840274010f, + 0.244631043706245800f, 0.244250423577833860f, 0.243869794469031620f, + 0.243489156393834590f, + 0.243108509366237320f, 0.242727853400234670f, 0.242347188509823150f, + 0.241966514708997830f, + 0.241585832011755900f, 0.241205140432093070f, 0.240824439984007180f, + 0.240443730681495050f, + 0.240063012538553830f, 0.239682285569182310f, 0.239301549787377890f, + 0.238920805207139960f, + 0.238540051842467020f, 0.238159289707357810f, 0.237778518815812740f, + 0.237397739181830820f, + 0.237016950819413100f, 0.236636153742559610f, 0.236255347965270780f, + 0.235874533501548580f, + 0.235493710365393630f, 0.235112878570808560f, 0.234732038131795020f, + 0.234351189062355030f, + 0.233970331376492150f, 0.233589465088208580f, 0.233208590211508550f, + 0.232827706760394850f, + 0.232446814748872410f, 0.232065914190945020f, 0.231685005100616930f, + 0.231304087491893930f, + 0.230923161378780380f, 0.230542226775282770f, 0.230161283695406500f, + 0.229780332153157300f, + 0.229399372162542610f, 0.229018403737568290f, 0.228637426892242400f, + 0.228256441640571880f, + 0.227875447996564060f, 0.227494445974227850f, 0.227113435587570770f, + 0.226732416850602300f, + 0.226351389777330990f, 0.225970354381765690f, 0.225589310677916880f, + 0.225208258679793520f, + 0.224827198401406690f, 0.224446129856766040f, 0.224065053059883250f, + 0.223683968024768950f, + 0.223302874765434120f, 0.222921773295891380f, 0.222540663630151820f, + 0.222159545782228660f, + 0.221778419766134050f, 0.221397285595880480f, 0.221016143285482050f, + 0.220634992848951380f, + 0.220253834300303180f, 0.219872667653551100f, 0.219491492922709110f, + 0.219110310121792800f, + 0.218729119264816280f, 0.218347920365795780f, 0.217966713438746380f, + 0.217585498497683580f, + 0.217204275556624420f, 0.216823044629584520f, 0.216441805730581500f, + 0.216060558873631570f, + 0.215679304072752960f, 0.215298041341962870f, 0.214916770695278810f, + 0.214535492146719880f, + 0.214154205710303750f, 0.213772911400050090f, 0.213391609229977570f, + 0.213010299214105140f, + 0.212628981366453330f, 0.212247655701041290f, 0.211866322231890090f, + 0.211484980973019880f, + 0.211103631938451000f, 0.210722275142205480f, 0.210340910598303870f, + 0.209959538320768660f, + 0.209578158323621420f, 0.209196770620883960f, 0.208815375226579670f, + 0.208433972154730530f, + 0.208052561419360520f, 0.207671143034492080f, 0.207289717014149830f, + 0.206908283372357230f, + 0.206526842123138070f, 0.206145393280517730f, 0.205763936858520150f, + 0.205382472871171230f, + 0.205001001332495910f, 0.204619522256519300f, 0.204238035657268250f, + 0.203856541548768030f, + 0.203475039945045950f, 0.203093530860128300f, 0.202712014308041620f, + 0.202330490302814110f, + 0.201948958858472420f, 0.201567419989045200f, 0.201185873708560170f, + 0.200804320031045230f, + 0.200422758970529910f, 0.200041190541042220f, 0.199659614756612230f, + 0.199278031631268500f, + 0.198896441179041650f, 0.198514843413961220f, 0.198133238350057030f, + 0.197751626001360480f, + 0.197370006381901520f, 0.196988379505712050f, 0.196606745386822960f, + 0.196225104039265410f, + 0.195843455477072190f, 0.195461799714274460f, 0.195080136764905570f, + 0.194698466642997730f, + 0.194316789362583340f, 0.193935104937696560f, 0.193553413382369890f, + 0.193171714710637930f, + 0.192790008936534220f, 0.192408296074092570f, 0.192026576137348330f, + 0.191644849140335360f, + 0.191263115097089540f, 0.190881374021645320f, 0.190499625928039040f, + 0.190117870830306100f, + 0.189736108742482030f, 0.189354339678604100f, 0.188972563652707950f, + 0.188590780678831250f, + 0.188208990771010640f, 0.187827193943283040f, 0.187445390209686870f, + 0.187063579584259070f, + 0.186681762081038650f, 0.186299937714063470f, 0.185918106497371700f, + 0.185536268445003070f, + 0.185154423570995760f, 0.184772571889390000f, 0.184390713414225000f, + 0.184008848159540110f, + 0.183626976139376310f, 0.183245097367773090f, 0.182863211858771880f, + 0.182481319626412670f, + 0.182099420684737420f, 0.181717515047787020f, 0.181335602729602590f, + 0.180953683744226880f, + 0.180571758105701030f, 0.180189825828068250f, 0.179807886925370670f, + 0.179425941411650660f, + 0.179043989300952110f, 0.178662030607317450f, 0.178280065344791100f, + 0.177898093527416370f, + 0.177516115169236820f, 0.177134130284297610f, 0.176752138886642350f, + 0.176370140990316640f, + 0.175988136609365020f, 0.175606125757832240f, 0.175224108449764660f, + 0.174842084699207030f, + 0.174460054520206240f, 0.174078017926807490f, 0.173695974933058080f, + 0.173313925553004180f, + 0.172931869800692250f, 0.172549807690170230f, 0.172167739235484620f, + 0.171785664450683800f, + 0.171403583349815180f, 0.171021495946926340f, 0.170639402256066410f, + 0.170257302291283000f, + 0.169875196066625710f, 0.169493083596143100f, 0.169110964893883830f, + 0.168728839973898290f, + 0.168346708850235140f, 0.167964571536945220f, 0.167582428048078130f, + 0.167200278397683750f, + 0.166818122599813570f, 0.166435960668517400f, 0.166053792617847200f, + 0.165671618461853270f, + 0.165289438214587970f, 0.164907251890102520f, 0.164525059502448390f, + 0.164142861065678550f, + 0.163760656593844480f, 0.163378446100999640f, 0.162996229601196390f, + 0.162614007108487250f, + 0.162231778636926370f, 0.161849544200566300f, 0.161467303813461580f, + 0.161085057489665670f, + 0.160702805243232240f, 0.160320547088216470f, 0.159938283038672050f, + 0.159556013108654580f, + 0.159173737312218650f, 0.158791455663418930f, 0.158409168176311760f, + 0.158026874864951870f, + 0.157644575743395960f, 0.157262270825699210f, 0.156879960125918730f, + 0.156497643658110590f, + 0.156115321436331000f, 0.155732993474637760f, 0.155350659787087090f, + 0.154968320387737170f, + 0.154585975290645110f, 0.154203624509868190f, 0.153821268059465250f, + 0.153438905953493550f, + 0.153056538206012340f, 0.152674164831079730f, 0.152291785842754070f, + 0.151909401255095250f, + 0.151527011082161540f, 0.151144615338013210f, 0.150762214036709470f, + 0.150379807192309620f, + 0.149997394818874590f, 0.149614976930463660f, 0.149232553541138180f, + 0.148850124664957870f, + 0.148467690315984390f, 0.148085250508278370f, 0.147702805255900570f, + 0.147320354572913260f, + 0.146937898473377210f, 0.146555436971355090f, 0.146172970080908520f, + 0.145790497816099230f, + 0.145408020190990560f, 0.145025537219644170f, 0.144643048916123810f, + 0.144260555294492000f, + 0.143878056368811510f, 0.143495552153146630f, 0.143113042661560050f, + 0.142730527908116440f, + 0.142348007906879320f, 0.141965482671912420f, 0.141582952217280980f, + 0.141200416557048680f, + 0.140817875705281120f, 0.140435329676042390f, 0.140052778483398480f, + 0.139670222141414250f, + 0.139287660664154770f, 0.138905094065686600f, 0.138522522360074780f, + 0.138139945561386200f, + 0.137757363683686740f, 0.137374776741042340f, 0.136992184747520560f, + 0.136609587717187310f, + 0.136226985664110460f, 0.135844378602356760f, 0.135461766545993150f, + 0.135079149509088060f, + 0.134696527505708320f, 0.134313900549922760f, 0.133931268655799020f, + 0.133548631837404950f, + 0.133165990108809860f, 0.132783343484081580f, 0.132400691977289760f, + 0.132018035602502530f, + 0.131635374373789940f, 0.131252708305220960f, 0.130870037410864640f, + 0.130487361704791580f, + 0.130104681201070800f, 0.129721995913773260f, 0.129339305856968730f, + 0.128956611044727220f, + 0.128573911491120210f, 0.128191207210217570f, 0.127808498216091110f, + 0.127425784522811530f, + 0.127043066144449680f, 0.126660343095077900f, 0.126277615388766920f, + 0.125894883039589430f, + 0.125512146061616980f, 0.125129404468921260f, 0.124746658275575490f, + 0.124363907495651240f, + 0.123981152143222060f, 0.123598392232359880f, 0.123215627777138580f, + 0.122832858791630880f, + 0.122450085289909640f, 0.122067307286049230f, 0.121684524794122440f, + 0.121301737828203960f, + 0.120918946402367330f, 0.120536150530686250f, 0.120153350227235940f, + 0.119770545506089950f, + 0.119387736381323830f, 0.119004922867011920f, 0.118622104977228730f, + 0.118239282726050290f, + 0.117856456127550970f, 0.117473625195807100f, 0.117090789944893860f, + 0.116707950388886520f, + 0.116325106541861910f, 0.115942258417895240f, 0.115559406031063570f, + 0.115176549395442460f, + 0.114793688525109290f, 0.114410823434140360f, 0.114027954136612060f, + 0.113645080646602280f, + 0.113262202978187320f, 0.112879321145445350f, 0.112496435162453430f, + 0.112113545043288730f, + 0.111730650802029900f, 0.111347752452754000f, 0.110964850009539970f, + 0.110581943486465610f, + 0.110199032897608850f, 0.109816118257049110f, 0.109433199578864170f, + 0.109050276877133770f, + 0.108667350165936400f, 0.108284419459350770f, 0.107901484771457020f, + 0.107518546116333660f, + 0.107135603508061170f, 0.106752656960718350f, 0.106369706488385940f, + 0.105986752105143480f, + 0.105603793825070680f, 0.105220831662248700f, 0.104837865630757090f, + 0.104454895744677270f, + 0.104071922018089540f, 0.103688944465074300f, 0.103305963099713400f, + 0.102922977936087120f, + 0.102539988988277600f, 0.102156996270365800f, 0.101773999796432830f, + 0.101390999580561250f, + 0.101007995636832020f, 0.100624987979327970f, 0.100241976622130760f, + 0.099858961579322170f, + 0.099475942864985456f, 0.099092920493202258f, 0.098709894478056073f, + 0.098326864833628791f, + 0.097943831574004214f, 0.097560794713264939f, 0.097177754265493674f, + 0.096794710244774623f, + 0.096411662665190329f, 0.096028611540825232f, 0.095645556885762609f, + 0.095262498714085819f, + 0.094879437039879722f, 0.094496371877227495f, 0.094113303240214247f, + 0.093730231142923864f, + 0.093347155599440373f, 0.092964076623849271f, 0.092580994230234359f, + 0.092197908432681386f, + 0.091814819245274432f, 0.091431726682099479f, 0.091048630757241303f, + 0.090665531484784803f, + 0.090282428878816323f, 0.089899322953420582f, 0.089516213722684160f, + 0.089133101200692441f, + 0.088749985401530951f, 0.088366866339286629f, 0.087983744028044805f, + 0.087600618481892656f, + 0.087217489714916191f, 0.086834357741201490f, 0.086451222574836131f, + 0.086068084229906014f, + 0.085684942720498897f, 0.085301798060701386f, 0.084918650264600160f, + 0.084535499346283349f, + 0.084152345319837438f, 0.083769188199350780f, 0.083386027998910095f, + 0.083002864732603973f, + 0.082619698414519799f, 0.082236529058745025f, 0.081853356679368619f, + 0.081470181290477811f, + 0.081087002906161790f, 0.080703821540508452f, 0.080320637207605849f, + 0.079937449921543474f, + 0.079554259696409127f, 0.079171066546292510f, 0.078787870485282088f, + 0.078404671527466441f, + 0.078021469686935602f, 0.077638264977777913f, 0.077255057414083589f, + 0.076871847009941652f, + 0.076488633779441206f, 0.076105417736672773f, 0.075722198895725248f, + 0.075338977270689375f, + 0.074955752875654230f, 0.074572525724710764f, 0.074189295831948693f, + 0.073806063211457842f, + 0.073422827877329483f, 0.073039589843653177f, 0.072656349124520389f, + 0.072273105734021334f, + 0.071889859686246352f, 0.071506610995287156f, 0.071123359675233852f, + 0.070740105740178361f, + 0.070356849204211397f, 0.069973590081423773f, 0.069590328385907715f, + 0.069207064131753759f, + 0.068823797333054326f, 0.068440528003900616f, 0.068057256158383886f, + 0.067673981810596848f, + 0.067290704974630494f, 0.066907425664577733f, 0.066524143894529736f, + 0.066140859678579578f, + 0.065757573030819083f, 0.065374283965340146f, 0.064990992496236119f, + 0.064607698637598646f, + 0.064224402403521202f, 0.063841103808096086f, 0.063457802865415636f, + 0.063074499589573618f, + 0.062691193994662109f, 0.062307886094775049f, 0.061924575904005130f, + 0.061541263436445129f, + 0.061157948706189229f, 0.060774631727329942f, 0.060391312513961619f, + 0.060007991080177375f, + 0.059624667440070382f, 0.059241341607735261f, 0.058858013597264912f, + 0.058474683422754095f, + 0.058091351098295878f, 0.057708016637985186f, 0.057324680055915692f, + 0.056941341366181127f, + 0.056558000582876661f, 0.056174657720095743f, 0.055791312791933681f, + 0.055407965812484541f, + 0.055024616795842439f, 0.054641265756102911f, 0.054257912707359794f, + 0.053874557663708772f, + 0.053491200639244271f, 0.053107841648060788f, 0.052724480704254229f, + 0.052341117821918783f, + 0.051957753015150501f, 0.051574386298044173f, 0.051191017684694640f, + 0.050807647189198162f, + 0.050424274825649297f, 0.050040900608144430f, 0.049657524550778251f, + 0.049274146667647289f, + 0.048890766972846805f, 0.048507385480472134f, 0.048124002204620014f, + 0.047740617159385448f, + 0.047357230358865306f, 0.046973841817155179f, 0.046590451548350717f, + 0.046207059566548990f, + 0.045823665885845313f, 0.045440270520336883f, 0.045056873484119603f, + 0.044673474791289434f, + 0.044290074455943754f, 0.043906672492178188f, 0.043523268914090238f, + 0.043139863735776100f, + 0.042756456971332048f, 0.042373048634855741f, 0.041989638740443119f, + 0.041606227302191955f, + 0.041222814334198304f, 0.040839399850560058f, 0.040455983865373815f, + 0.040072566392736257f, + 0.039689147446745419f, 0.039305727041497644f, 0.038922305191091085f, + 0.038538881909622631f, + 0.038155457211189216f, 0.037772031109889144f, 0.037388603619819022f, + 0.037005174755077273f, + 0.036621744529761024f, 0.036238312957967478f, 0.035854880053795196f, + 0.035471445831341021f, + 0.035088010304703626f, 0.034704573487980395f, 0.034321135395268765f, + 0.033937696040667535f, + 0.033554255438273790f, 0.033170813602186440f, 0.032787370546502645f, + 0.032403926285321405f, + 0.032020480832740429f, 0.031637034202857461f, 0.031253586409771626f, + 0.030870137467580314f, + 0.030486687390382738f, 0.030103236192276818f, 0.029719783887360508f, + 0.029336330489733147f, + 0.028952876013492331f, 0.028569420472737472f, 0.028185963881566689f, + 0.027802506254078142f, + 0.027419047604371360f, 0.027035587946544135f, 0.026652127294696067f, + 0.026268665662925468f, + 0.025885203065330677f, 0.025501739516011413f, 0.025118275029065638f, + 0.024734809618593138f, + 0.024351343298691951f, 0.023967876083461924f, 0.023584407987001611f, + 0.023200939023409587f, + 0.022817469206785804f, 0.022433998551228459f, 0.022050527070837558f, + 0.021667054779711814f, + 0.021283581691949955f, 0.020900107821652084f, 0.020516633182916549f, + 0.020133157789843505f, + 0.019749681656531803f, 0.019366204797080316f, 0.018982727225589285f, + 0.018599248956157190f, + 0.018215770002884327f, 0.017832290379869671f, 0.017448810101212228f, + 0.017065329181012358f, + 0.016681847633368677f, 0.016298365472381587f, 0.015914882712149747f, + 0.015531399366773606f, + 0.015147915450352307f, 0.014764430976985016f, 0.014380945960772247f, + 0.013997460415812761f, + 0.013613974356207112f, 0.013230487796054543f, 0.012847000749454314f, + 0.012463513230507034f, + 0.012080025253311559f, 0.011696536831968529f, 0.011313047980577277f, + 0.010929558713237145f, + 0.010546069044048827f, 0.010162578987111254f, 0.009779088556525145f, + 0.009395597766389905f, + 0.009012106630804949f, 0.008628615163871038f, 0.008245123379687167f, + 0.007861631292354124f, + 0.007478138915970929f, 0.007094646264638386f, 0.006711153352455981f, + 0.006327660193523208f, + 0.005944166801940901f, 0.005560673191808128f, 0.005177179377225743f, + 0.004793685372293270f, + 0.004410191191110246f, 0.004026696847777542f, 0.003643202356394263f, + 0.003259707731061291f, + 0.002876212985878184f, 0.002492718134944503f, 0.002109223192361147f, + 0.001725728172227238f, + 0.001342233088643682f, 0.000958737955710053f, 0.000575242787525925f, + 0.000191747598192208f +}; + +/** + * @} end of DCT4_IDCT4_Table group + */ + +/** + * @addtogroup DCT4_IDCT4 + * @{ + */ + +/** + * @brief Initialization function for the floating-point DCT4/IDCT4. + * @param[in,out] *S points to an instance of floating-point DCT4/IDCT4 structure. + * @param[in] *S_RFFT points to an instance of floating-point RFFT/RIFFT structure. + * @param[in] *S_CFFT points to an instance of floating-point CFFT/CIFFT structure. + * @param[in] N length of the DCT4. + * @param[in] Nby2 half of the length of the DCT4. + * @param[in] normalize normalizing factor. + * @return arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLenReal is not a supported transform length. + * \par Normalizing factor: + * The normalizing factor is sqrt(2/N), which depends on the size of transform N. + * Floating-point normalizing factors are mentioned in the table below for different DCT sizes: + * \image html dct4NormalizingF32Table.gif + */ + +arm_status arm_dct4_init_f32( + arm_dct4_instance_f32 * S, + arm_rfft_instance_f32 * S_RFFT, + arm_cfft_radix4_instance_f32 * S_CFFT, + uint16_t N, + uint16_t Nby2, + float32_t normalize) +{ + /* Initialize the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initializing the pointer array with the weight table base addresses of different lengths */ + float32_t *twiddlePtr[4] = + { (float32_t *) Weights_128, (float32_t *) Weights_512, + (float32_t *) Weights_2048, (float32_t *) Weights_8192 + }; + + /* Initializing the pointer array with the cos factor table base addresses of different lengths */ + float32_t *pCosFactor[4] = + { (float32_t *) cos_factors_128, (float32_t *) cos_factors_512, + (float32_t *) cos_factors_2048, (float32_t *) cos_factors_8192 + }; + + /* Initialize the DCT4 length */ + S->N = N; + + /* Initialize the half of DCT4 length */ + S->Nby2 = Nby2; + + /* Initialize the DCT4 Normalizing factor */ + S->normalize = normalize; + + /* Initialize Real FFT Instance */ + S->pRfft = S_RFFT; + + /* Initialize Complex FFT Instance */ + S->pCfft = S_CFFT; + + switch (N) + { + /* Initialize the table modifier values */ + case 8192U: + S->pTwiddle = twiddlePtr[3]; + S->pCosFactor = pCosFactor[3]; + break; + case 2048U: + S->pTwiddle = twiddlePtr[2]; + S->pCosFactor = pCosFactor[2]; + break; + case 512U: + S->pTwiddle = twiddlePtr[1]; + S->pCosFactor = pCosFactor[1]; + break; + case 128U: + S->pTwiddle = twiddlePtr[0]; + S->pCosFactor = pCosFactor[0]; + break; + default: + status = ARM_MATH_ARGUMENT_ERROR; + } + + /* Initialize the RFFT/RIFFT */ + arm_rfft_init_f32(S->pRfft, S->pCfft, S->N, 0U, 1U); + + /* return the status of DCT4 Init function */ + return (status); +} + +/** + * @} end of DCT4_IDCT4 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q15.c new file mode 100644 index 0000000..d3401bc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q15.c @@ -0,0 +1,4280 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dct4_init_q15.c + * Description: Initialization function of DCT-4 & IDCT4 Q15 + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup DCT4_IDCT4 + */ + +/** + * @addtogroup DCT4_IDCT4_Table DCT Type IV Tables + * @{ + */ + +/* +* @brief Weights Table +*/ + +/** + * \par + * Weights tables are generated using the formula :
weights[n] = e^(-j*n*pi/(2*N))
+ * \par + * C command to generate the table + *
+ * for(i = 0; i< N; i++)
+ * {
+ *   weights[2*i]= cos(i*c);
+ *   weights[(2*i)+1]= -sin(i * c);
+ * } 
+ * \par + * where N is the Number of weights to be calculated and c is pi/(2*N) + * \par + * Converted the output to q15 format by multiplying with 2^31 and saturated if required. + * \par + * In the tables below the real and imaginary values are placed alternatively, hence the + * array length is 2*N. + */ + +static const q15_t ALIGN4 WeightsQ15_128[256] = { + (q15_t)0x7fff, (q15_t)0x0, (q15_t)0x7ffd, (q15_t)0xfe6e, (q15_t)0x7ff6, (q15_t)0xfcdc, (q15_t)0x7fe9, (q15_t)0xfb4a, + (q15_t)0x7fd8, (q15_t)0xf9b9, (q15_t)0x7fc2, (q15_t)0xf827, (q15_t)0x7fa7, (q15_t)0xf696, (q15_t)0x7f87, (q15_t)0xf505, + (q15_t)0x7f62, (q15_t)0xf375, (q15_t)0x7f38, (q15_t)0xf1e5, (q15_t)0x7f09, (q15_t)0xf055, (q15_t)0x7ed5, (q15_t)0xeec7, + (q15_t)0x7e9d, (q15_t)0xed38, (q15_t)0x7e5f, (q15_t)0xebab, (q15_t)0x7e1d, (q15_t)0xea1e, (q15_t)0x7dd6, (q15_t)0xe893, + (q15_t)0x7d8a, (q15_t)0xe708, (q15_t)0x7d39, (q15_t)0xe57e, (q15_t)0x7ce3, (q15_t)0xe3f5, (q15_t)0x7c89, (q15_t)0xe26d, + (q15_t)0x7c29, (q15_t)0xe0e7, (q15_t)0x7bc5, (q15_t)0xdf61, (q15_t)0x7b5d, (q15_t)0xdddd, (q15_t)0x7aef, (q15_t)0xdc5a, + (q15_t)0x7a7d, (q15_t)0xdad8, (q15_t)0x7a05, (q15_t)0xd958, (q15_t)0x798a, (q15_t)0xd7da, (q15_t)0x7909, (q15_t)0xd65d, + (q15_t)0x7884, (q15_t)0xd4e1, (q15_t)0x77fa, (q15_t)0xd368, (q15_t)0x776c, (q15_t)0xd1ef, (q15_t)0x76d9, (q15_t)0xd079, + (q15_t)0x7641, (q15_t)0xcf05, (q15_t)0x75a5, (q15_t)0xcd92, (q15_t)0x7504, (q15_t)0xcc22, (q15_t)0x745f, (q15_t)0xcab3, + (q15_t)0x73b5, (q15_t)0xc946, (q15_t)0x7307, (q15_t)0xc7dc, (q15_t)0x7255, (q15_t)0xc674, (q15_t)0x719e, (q15_t)0xc50e, + (q15_t)0x70e2, (q15_t)0xc3aa, (q15_t)0x7023, (q15_t)0xc248, (q15_t)0x6f5f, (q15_t)0xc0e9, (q15_t)0x6e96, (q15_t)0xbf8d, + (q15_t)0x6dca, (q15_t)0xbe32, (q15_t)0x6cf9, (q15_t)0xbcdb, (q15_t)0x6c24, (q15_t)0xbb86, (q15_t)0x6b4a, (q15_t)0xba33, + (q15_t)0x6a6d, (q15_t)0xb8e4, (q15_t)0x698c, (q15_t)0xb797, (q15_t)0x68a6, (q15_t)0xb64c, (q15_t)0x67bd, (q15_t)0xb505, + (q15_t)0x66cf, (q15_t)0xb3c1, (q15_t)0x65dd, (q15_t)0xb27f, (q15_t)0x64e8, (q15_t)0xb141, (q15_t)0x63ef, (q15_t)0xb005, + (q15_t)0x62f2, (q15_t)0xaecd, (q15_t)0x61f1, (q15_t)0xad97, (q15_t)0x60ec, (q15_t)0xac65, (q15_t)0x5fe3, (q15_t)0xab36, + (q15_t)0x5ed7, (q15_t)0xaa0b, (q15_t)0x5dc7, (q15_t)0xa8e3, (q15_t)0x5cb4, (q15_t)0xa7be, (q15_t)0x5b9d, (q15_t)0xa69c, + (q15_t)0x5a82, (q15_t)0xa57e, (q15_t)0x5964, (q15_t)0xa463, (q15_t)0x5842, (q15_t)0xa34c, (q15_t)0x571d, (q15_t)0xa239, + (q15_t)0x55f5, (q15_t)0xa129, (q15_t)0x54ca, (q15_t)0xa01d, (q15_t)0x539b, (q15_t)0x9f14, (q15_t)0x5269, (q15_t)0x9e0f, + (q15_t)0x5133, (q15_t)0x9d0e, (q15_t)0x4ffb, (q15_t)0x9c11, (q15_t)0x4ebf, (q15_t)0x9b18, (q15_t)0x4d81, (q15_t)0x9a23, + (q15_t)0x4c3f, (q15_t)0x9931, (q15_t)0x4afb, (q15_t)0x9843, (q15_t)0x49b4, (q15_t)0x975a, (q15_t)0x4869, (q15_t)0x9674, + (q15_t)0x471c, (q15_t)0x9593, (q15_t)0x45cd, (q15_t)0x94b6, (q15_t)0x447a, (q15_t)0x93dc, (q15_t)0x4325, (q15_t)0x9307, + (q15_t)0x41ce, (q15_t)0x9236, (q15_t)0x4073, (q15_t)0x916a, (q15_t)0x3f17, (q15_t)0x90a1, (q15_t)0x3db8, (q15_t)0x8fdd, + (q15_t)0x3c56, (q15_t)0x8f1e, (q15_t)0x3af2, (q15_t)0x8e62, (q15_t)0x398c, (q15_t)0x8dab, (q15_t)0x3824, (q15_t)0x8cf9, + (q15_t)0x36ba, (q15_t)0x8c4b, (q15_t)0x354d, (q15_t)0x8ba1, (q15_t)0x33de, (q15_t)0x8afc, (q15_t)0x326e, (q15_t)0x8a5b, + (q15_t)0x30fb, (q15_t)0x89bf, (q15_t)0x2f87, (q15_t)0x8927, (q15_t)0x2e11, (q15_t)0x8894, (q15_t)0x2c98, (q15_t)0x8806, + (q15_t)0x2b1f, (q15_t)0x877c, (q15_t)0x29a3, (q15_t)0x86f7, (q15_t)0x2826, (q15_t)0x8676, (q15_t)0x26a8, (q15_t)0x85fb, + (q15_t)0x2528, (q15_t)0x8583, (q15_t)0x23a6, (q15_t)0x8511, (q15_t)0x2223, (q15_t)0x84a3, (q15_t)0x209f, (q15_t)0x843b, + (q15_t)0x1f19, (q15_t)0x83d7, (q15_t)0x1d93, (q15_t)0x8377, (q15_t)0x1c0b, (q15_t)0x831d, (q15_t)0x1a82, (q15_t)0x82c7, + (q15_t)0x18f8, (q15_t)0x8276, (q15_t)0x176d, (q15_t)0x822a, (q15_t)0x15e2, (q15_t)0x81e3, (q15_t)0x1455, (q15_t)0x81a1, + (q15_t)0x12c8, (q15_t)0x8163, (q15_t)0x1139, (q15_t)0x812b, (q15_t)0xfab, (q15_t)0x80f7, (q15_t)0xe1b, (q15_t)0x80c8, + (q15_t)0xc8b, (q15_t)0x809e, (q15_t)0xafb, (q15_t)0x8079, (q15_t)0x96a, (q15_t)0x8059, (q15_t)0x7d9, (q15_t)0x803e, + (q15_t)0x647, (q15_t)0x8028, (q15_t)0x4b6, (q15_t)0x8017, (q15_t)0x324, (q15_t)0x800a, (q15_t)0x192, (q15_t)0x8003 +}; + +static const q15_t ALIGN4 WeightsQ15_512[1024] = { + (q15_t)0x7fff, (q15_t)0x0, (q15_t)0x7fff, (q15_t)0xff9c, (q15_t)0x7fff, (q15_t)0xff37, (q15_t)0x7ffe, (q15_t)0xfed3, + (q15_t)0x7ffd, (q15_t)0xfe6e, (q15_t)0x7ffc, (q15_t)0xfe0a, (q15_t)0x7ffa, (q15_t)0xfda5, (q15_t)0x7ff8, (q15_t)0xfd41, + (q15_t)0x7ff6, (q15_t)0xfcdc, (q15_t)0x7ff3, (q15_t)0xfc78, (q15_t)0x7ff0, (q15_t)0xfc13, (q15_t)0x7fed, (q15_t)0xfbaf, + (q15_t)0x7fe9, (q15_t)0xfb4a, (q15_t)0x7fe5, (q15_t)0xfae6, (q15_t)0x7fe1, (q15_t)0xfa81, (q15_t)0x7fdd, (q15_t)0xfa1d, + (q15_t)0x7fd8, (q15_t)0xf9b9, (q15_t)0x7fd3, (q15_t)0xf954, (q15_t)0x7fce, (q15_t)0xf8f0, (q15_t)0x7fc8, (q15_t)0xf88b, + (q15_t)0x7fc2, (q15_t)0xf827, (q15_t)0x7fbc, (q15_t)0xf7c3, (q15_t)0x7fb5, (q15_t)0xf75e, (q15_t)0x7fae, (q15_t)0xf6fa, + (q15_t)0x7fa7, (q15_t)0xf696, (q15_t)0x7f9f, (q15_t)0xf632, (q15_t)0x7f97, (q15_t)0xf5cd, (q15_t)0x7f8f, (q15_t)0xf569, + (q15_t)0x7f87, (q15_t)0xf505, (q15_t)0x7f7e, (q15_t)0xf4a1, (q15_t)0x7f75, (q15_t)0xf43d, (q15_t)0x7f6b, (q15_t)0xf3d9, + (q15_t)0x7f62, (q15_t)0xf375, (q15_t)0x7f58, (q15_t)0xf311, (q15_t)0x7f4d, (q15_t)0xf2ad, (q15_t)0x7f43, (q15_t)0xf249, + (q15_t)0x7f38, (q15_t)0xf1e5, (q15_t)0x7f2d, (q15_t)0xf181, (q15_t)0x7f21, (q15_t)0xf11d, (q15_t)0x7f15, (q15_t)0xf0b9, + (q15_t)0x7f09, (q15_t)0xf055, (q15_t)0x7efd, (q15_t)0xeff2, (q15_t)0x7ef0, (q15_t)0xef8e, (q15_t)0x7ee3, (q15_t)0xef2a, + (q15_t)0x7ed5, (q15_t)0xeec7, (q15_t)0x7ec8, (q15_t)0xee63, (q15_t)0x7eba, (q15_t)0xedff, (q15_t)0x7eab, (q15_t)0xed9c, + (q15_t)0x7e9d, (q15_t)0xed38, (q15_t)0x7e8e, (q15_t)0xecd5, (q15_t)0x7e7f, (q15_t)0xec72, (q15_t)0x7e6f, (q15_t)0xec0e, + (q15_t)0x7e5f, (q15_t)0xebab, (q15_t)0x7e4f, (q15_t)0xeb48, (q15_t)0x7e3f, (q15_t)0xeae5, (q15_t)0x7e2e, (q15_t)0xea81, + (q15_t)0x7e1d, (q15_t)0xea1e, (q15_t)0x7e0c, (q15_t)0xe9bb, (q15_t)0x7dfa, (q15_t)0xe958, (q15_t)0x7de8, (q15_t)0xe8f6, + (q15_t)0x7dd6, (q15_t)0xe893, (q15_t)0x7dc3, (q15_t)0xe830, (q15_t)0x7db0, (q15_t)0xe7cd, (q15_t)0x7d9d, (q15_t)0xe76a, + (q15_t)0x7d8a, (q15_t)0xe708, (q15_t)0x7d76, (q15_t)0xe6a5, (q15_t)0x7d62, (q15_t)0xe643, (q15_t)0x7d4e, (q15_t)0xe5e0, + (q15_t)0x7d39, (q15_t)0xe57e, (q15_t)0x7d24, (q15_t)0xe51c, (q15_t)0x7d0f, (q15_t)0xe4b9, (q15_t)0x7cf9, (q15_t)0xe457, + (q15_t)0x7ce3, (q15_t)0xe3f5, (q15_t)0x7ccd, (q15_t)0xe393, (q15_t)0x7cb7, (q15_t)0xe331, (q15_t)0x7ca0, (q15_t)0xe2cf, + (q15_t)0x7c89, (q15_t)0xe26d, (q15_t)0x7c71, (q15_t)0xe20b, (q15_t)0x7c5a, (q15_t)0xe1aa, (q15_t)0x7c42, (q15_t)0xe148, + (q15_t)0x7c29, (q15_t)0xe0e7, (q15_t)0x7c11, (q15_t)0xe085, (q15_t)0x7bf8, (q15_t)0xe024, (q15_t)0x7bdf, (q15_t)0xdfc2, + (q15_t)0x7bc5, (q15_t)0xdf61, (q15_t)0x7bac, (q15_t)0xdf00, (q15_t)0x7b92, (q15_t)0xde9f, (q15_t)0x7b77, (q15_t)0xde3e, + (q15_t)0x7b5d, (q15_t)0xdddd, (q15_t)0x7b42, (q15_t)0xdd7c, (q15_t)0x7b26, (q15_t)0xdd1b, (q15_t)0x7b0b, (q15_t)0xdcbb, + (q15_t)0x7aef, (q15_t)0xdc5a, (q15_t)0x7ad3, (q15_t)0xdbf9, (q15_t)0x7ab6, (q15_t)0xdb99, (q15_t)0x7a9a, (q15_t)0xdb39, + (q15_t)0x7a7d, (q15_t)0xdad8, (q15_t)0x7a5f, (q15_t)0xda78, (q15_t)0x7a42, (q15_t)0xda18, (q15_t)0x7a24, (q15_t)0xd9b8, + (q15_t)0x7a05, (q15_t)0xd958, (q15_t)0x79e7, (q15_t)0xd8f9, (q15_t)0x79c8, (q15_t)0xd899, (q15_t)0x79a9, (q15_t)0xd839, + (q15_t)0x798a, (q15_t)0xd7da, (q15_t)0x796a, (q15_t)0xd77a, (q15_t)0x794a, (q15_t)0xd71b, (q15_t)0x792a, (q15_t)0xd6bc, + (q15_t)0x7909, (q15_t)0xd65d, (q15_t)0x78e8, (q15_t)0xd5fe, (q15_t)0x78c7, (q15_t)0xd59f, (q15_t)0x78a6, (q15_t)0xd540, + (q15_t)0x7884, (q15_t)0xd4e1, (q15_t)0x7862, (q15_t)0xd483, (q15_t)0x7840, (q15_t)0xd424, (q15_t)0x781d, (q15_t)0xd3c6, + (q15_t)0x77fa, (q15_t)0xd368, (q15_t)0x77d7, (q15_t)0xd309, (q15_t)0x77b4, (q15_t)0xd2ab, (q15_t)0x7790, (q15_t)0xd24d, + (q15_t)0x776c, (q15_t)0xd1ef, (q15_t)0x7747, (q15_t)0xd192, (q15_t)0x7723, (q15_t)0xd134, (q15_t)0x76fe, (q15_t)0xd0d7, + (q15_t)0x76d9, (q15_t)0xd079, (q15_t)0x76b3, (q15_t)0xd01c, (q15_t)0x768e, (q15_t)0xcfbf, (q15_t)0x7668, (q15_t)0xcf62, + (q15_t)0x7641, (q15_t)0xcf05, (q15_t)0x761b, (q15_t)0xcea8, (q15_t)0x75f4, (q15_t)0xce4b, (q15_t)0x75cc, (q15_t)0xcdef, + (q15_t)0x75a5, (q15_t)0xcd92, (q15_t)0x757d, (q15_t)0xcd36, (q15_t)0x7555, (q15_t)0xccda, (q15_t)0x752d, (q15_t)0xcc7e, + (q15_t)0x7504, (q15_t)0xcc22, (q15_t)0x74db, (q15_t)0xcbc6, (q15_t)0x74b2, (q15_t)0xcb6a, (q15_t)0x7489, (q15_t)0xcb0e, + (q15_t)0x745f, (q15_t)0xcab3, (q15_t)0x7435, (q15_t)0xca58, (q15_t)0x740b, (q15_t)0xc9fc, (q15_t)0x73e0, (q15_t)0xc9a1, + (q15_t)0x73b5, (q15_t)0xc946, (q15_t)0x738a, (q15_t)0xc8ec, (q15_t)0x735f, (q15_t)0xc891, (q15_t)0x7333, (q15_t)0xc836, + (q15_t)0x7307, (q15_t)0xc7dc, (q15_t)0x72db, (q15_t)0xc782, (q15_t)0x72af, (q15_t)0xc728, (q15_t)0x7282, (q15_t)0xc6ce, + (q15_t)0x7255, (q15_t)0xc674, (q15_t)0x7227, (q15_t)0xc61a, (q15_t)0x71fa, (q15_t)0xc5c0, (q15_t)0x71cc, (q15_t)0xc567, + (q15_t)0x719e, (q15_t)0xc50e, (q15_t)0x716f, (q15_t)0xc4b4, (q15_t)0x7141, (q15_t)0xc45b, (q15_t)0x7112, (q15_t)0xc403, + (q15_t)0x70e2, (q15_t)0xc3aa, (q15_t)0x70b3, (q15_t)0xc351, (q15_t)0x7083, (q15_t)0xc2f9, (q15_t)0x7053, (q15_t)0xc2a0, + (q15_t)0x7023, (q15_t)0xc248, (q15_t)0x6ff2, (q15_t)0xc1f0, (q15_t)0x6fc1, (q15_t)0xc198, (q15_t)0x6f90, (q15_t)0xc141, + (q15_t)0x6f5f, (q15_t)0xc0e9, (q15_t)0x6f2d, (q15_t)0xc092, (q15_t)0x6efb, (q15_t)0xc03b, (q15_t)0x6ec9, (q15_t)0xbfe3, + (q15_t)0x6e96, (q15_t)0xbf8d, (q15_t)0x6e63, (q15_t)0xbf36, (q15_t)0x6e30, (q15_t)0xbedf, (q15_t)0x6dfd, (q15_t)0xbe89, + (q15_t)0x6dca, (q15_t)0xbe32, (q15_t)0x6d96, (q15_t)0xbddc, (q15_t)0x6d62, (q15_t)0xbd86, (q15_t)0x6d2d, (q15_t)0xbd30, + (q15_t)0x6cf9, (q15_t)0xbcdb, (q15_t)0x6cc4, (q15_t)0xbc85, (q15_t)0x6c8f, (q15_t)0xbc30, (q15_t)0x6c59, (q15_t)0xbbdb, + (q15_t)0x6c24, (q15_t)0xbb86, (q15_t)0x6bee, (q15_t)0xbb31, (q15_t)0x6bb8, (q15_t)0xbadc, (q15_t)0x6b81, (q15_t)0xba88, + (q15_t)0x6b4a, (q15_t)0xba33, (q15_t)0x6b13, (q15_t)0xb9df, (q15_t)0x6adc, (q15_t)0xb98b, (q15_t)0x6aa5, (q15_t)0xb937, + (q15_t)0x6a6d, (q15_t)0xb8e4, (q15_t)0x6a35, (q15_t)0xb890, (q15_t)0x69fd, (q15_t)0xb83d, (q15_t)0x69c4, (q15_t)0xb7ea, + (q15_t)0x698c, (q15_t)0xb797, (q15_t)0x6953, (q15_t)0xb744, (q15_t)0x6919, (q15_t)0xb6f1, (q15_t)0x68e0, (q15_t)0xb69f, + (q15_t)0x68a6, (q15_t)0xb64c, (q15_t)0x686c, (q15_t)0xb5fa, (q15_t)0x6832, (q15_t)0xb5a8, (q15_t)0x67f7, (q15_t)0xb557, + (q15_t)0x67bd, (q15_t)0xb505, (q15_t)0x6782, (q15_t)0xb4b4, (q15_t)0x6746, (q15_t)0xb462, (q15_t)0x670b, (q15_t)0xb411, + (q15_t)0x66cf, (q15_t)0xb3c1, (q15_t)0x6693, (q15_t)0xb370, (q15_t)0x6657, (q15_t)0xb31f, (q15_t)0x661a, (q15_t)0xb2cf, + (q15_t)0x65dd, (q15_t)0xb27f, (q15_t)0x65a0, (q15_t)0xb22f, (q15_t)0x6563, (q15_t)0xb1df, (q15_t)0x6526, (q15_t)0xb190, + (q15_t)0x64e8, (q15_t)0xb141, (q15_t)0x64aa, (q15_t)0xb0f1, (q15_t)0x646c, (q15_t)0xb0a2, (q15_t)0x642d, (q15_t)0xb054, + (q15_t)0x63ef, (q15_t)0xb005, (q15_t)0x63b0, (q15_t)0xafb7, (q15_t)0x6371, (q15_t)0xaf69, (q15_t)0x6331, (q15_t)0xaf1b, + (q15_t)0x62f2, (q15_t)0xaecd, (q15_t)0x62b2, (q15_t)0xae7f, (q15_t)0x6271, (q15_t)0xae32, (q15_t)0x6231, (q15_t)0xade4, + (q15_t)0x61f1, (q15_t)0xad97, (q15_t)0x61b0, (q15_t)0xad4b, (q15_t)0x616f, (q15_t)0xacfe, (q15_t)0x612d, (q15_t)0xacb2, + (q15_t)0x60ec, (q15_t)0xac65, (q15_t)0x60aa, (q15_t)0xac19, (q15_t)0x6068, (q15_t)0xabcd, (q15_t)0x6026, (q15_t)0xab82, + (q15_t)0x5fe3, (q15_t)0xab36, (q15_t)0x5fa0, (q15_t)0xaaeb, (q15_t)0x5f5e, (q15_t)0xaaa0, (q15_t)0x5f1a, (q15_t)0xaa55, + (q15_t)0x5ed7, (q15_t)0xaa0b, (q15_t)0x5e93, (q15_t)0xa9c0, (q15_t)0x5e50, (q15_t)0xa976, (q15_t)0x5e0b, (q15_t)0xa92c, + (q15_t)0x5dc7, (q15_t)0xa8e3, (q15_t)0x5d83, (q15_t)0xa899, (q15_t)0x5d3e, (q15_t)0xa850, (q15_t)0x5cf9, (q15_t)0xa807, + (q15_t)0x5cb4, (q15_t)0xa7be, (q15_t)0x5c6e, (q15_t)0xa775, (q15_t)0x5c29, (q15_t)0xa72c, (q15_t)0x5be3, (q15_t)0xa6e4, + (q15_t)0x5b9d, (q15_t)0xa69c, (q15_t)0x5b56, (q15_t)0xa654, (q15_t)0x5b10, (q15_t)0xa60d, (q15_t)0x5ac9, (q15_t)0xa5c5, + (q15_t)0x5a82, (q15_t)0xa57e, (q15_t)0x5a3b, (q15_t)0xa537, (q15_t)0x59f3, (q15_t)0xa4f0, (q15_t)0x59ac, (q15_t)0xa4aa, + (q15_t)0x5964, (q15_t)0xa463, (q15_t)0x591c, (q15_t)0xa41d, (q15_t)0x58d4, (q15_t)0xa3d7, (q15_t)0x588b, (q15_t)0xa392, + (q15_t)0x5842, (q15_t)0xa34c, (q15_t)0x57f9, (q15_t)0xa307, (q15_t)0x57b0, (q15_t)0xa2c2, (q15_t)0x5767, (q15_t)0xa27d, + (q15_t)0x571d, (q15_t)0xa239, (q15_t)0x56d4, (q15_t)0xa1f5, (q15_t)0x568a, (q15_t)0xa1b0, (q15_t)0x5640, (q15_t)0xa16d, + (q15_t)0x55f5, (q15_t)0xa129, (q15_t)0x55ab, (q15_t)0xa0e6, (q15_t)0x5560, (q15_t)0xa0a2, (q15_t)0x5515, (q15_t)0xa060, + (q15_t)0x54ca, (q15_t)0xa01d, (q15_t)0x547e, (q15_t)0x9fda, (q15_t)0x5433, (q15_t)0x9f98, (q15_t)0x53e7, (q15_t)0x9f56, + (q15_t)0x539b, (q15_t)0x9f14, (q15_t)0x534e, (q15_t)0x9ed3, (q15_t)0x5302, (q15_t)0x9e91, (q15_t)0x52b5, (q15_t)0x9e50, + (q15_t)0x5269, (q15_t)0x9e0f, (q15_t)0x521c, (q15_t)0x9dcf, (q15_t)0x51ce, (q15_t)0x9d8f, (q15_t)0x5181, (q15_t)0x9d4e, + (q15_t)0x5133, (q15_t)0x9d0e, (q15_t)0x50e5, (q15_t)0x9ccf, (q15_t)0x5097, (q15_t)0x9c8f, (q15_t)0x5049, (q15_t)0x9c50, + (q15_t)0x4ffb, (q15_t)0x9c11, (q15_t)0x4fac, (q15_t)0x9bd3, (q15_t)0x4f5e, (q15_t)0x9b94, (q15_t)0x4f0f, (q15_t)0x9b56, + (q15_t)0x4ebf, (q15_t)0x9b18, (q15_t)0x4e70, (q15_t)0x9ada, (q15_t)0x4e21, (q15_t)0x9a9d, (q15_t)0x4dd1, (q15_t)0x9a60, + (q15_t)0x4d81, (q15_t)0x9a23, (q15_t)0x4d31, (q15_t)0x99e6, (q15_t)0x4ce1, (q15_t)0x99a9, (q15_t)0x4c90, (q15_t)0x996d, + (q15_t)0x4c3f, (q15_t)0x9931, (q15_t)0x4bef, (q15_t)0x98f5, (q15_t)0x4b9e, (q15_t)0x98ba, (q15_t)0x4b4c, (q15_t)0x987e, + (q15_t)0x4afb, (q15_t)0x9843, (q15_t)0x4aa9, (q15_t)0x9809, (q15_t)0x4a58, (q15_t)0x97ce, (q15_t)0x4a06, (q15_t)0x9794, + (q15_t)0x49b4, (q15_t)0x975a, (q15_t)0x4961, (q15_t)0x9720, (q15_t)0x490f, (q15_t)0x96e7, (q15_t)0x48bc, (q15_t)0x96ad, + (q15_t)0x4869, (q15_t)0x9674, (q15_t)0x4816, (q15_t)0x963c, (q15_t)0x47c3, (q15_t)0x9603, (q15_t)0x4770, (q15_t)0x95cb, + (q15_t)0x471c, (q15_t)0x9593, (q15_t)0x46c9, (q15_t)0x955b, (q15_t)0x4675, (q15_t)0x9524, (q15_t)0x4621, (q15_t)0x94ed, + (q15_t)0x45cd, (q15_t)0x94b6, (q15_t)0x4578, (q15_t)0x947f, (q15_t)0x4524, (q15_t)0x9448, (q15_t)0x44cf, (q15_t)0x9412, + (q15_t)0x447a, (q15_t)0x93dc, (q15_t)0x4425, (q15_t)0x93a7, (q15_t)0x43d0, (q15_t)0x9371, (q15_t)0x437b, (q15_t)0x933c, + (q15_t)0x4325, (q15_t)0x9307, (q15_t)0x42d0, (q15_t)0x92d3, (q15_t)0x427a, (q15_t)0x929e, (q15_t)0x4224, (q15_t)0x926a, + (q15_t)0x41ce, (q15_t)0x9236, (q15_t)0x4177, (q15_t)0x9203, (q15_t)0x4121, (q15_t)0x91d0, (q15_t)0x40ca, (q15_t)0x919d, + (q15_t)0x4073, (q15_t)0x916a, (q15_t)0x401d, (q15_t)0x9137, (q15_t)0x3fc5, (q15_t)0x9105, (q15_t)0x3f6e, (q15_t)0x90d3, + (q15_t)0x3f17, (q15_t)0x90a1, (q15_t)0x3ebf, (q15_t)0x9070, (q15_t)0x3e68, (q15_t)0x903f, (q15_t)0x3e10, (q15_t)0x900e, + (q15_t)0x3db8, (q15_t)0x8fdd, (q15_t)0x3d60, (q15_t)0x8fad, (q15_t)0x3d07, (q15_t)0x8f7d, (q15_t)0x3caf, (q15_t)0x8f4d, + (q15_t)0x3c56, (q15_t)0x8f1e, (q15_t)0x3bfd, (q15_t)0x8eee, (q15_t)0x3ba5, (q15_t)0x8ebf, (q15_t)0x3b4c, (q15_t)0x8e91, + (q15_t)0x3af2, (q15_t)0x8e62, (q15_t)0x3a99, (q15_t)0x8e34, (q15_t)0x3a40, (q15_t)0x8e06, (q15_t)0x39e6, (q15_t)0x8dd9, + (q15_t)0x398c, (q15_t)0x8dab, (q15_t)0x3932, (q15_t)0x8d7e, (q15_t)0x38d8, (q15_t)0x8d51, (q15_t)0x387e, (q15_t)0x8d25, + (q15_t)0x3824, (q15_t)0x8cf9, (q15_t)0x37ca, (q15_t)0x8ccd, (q15_t)0x376f, (q15_t)0x8ca1, (q15_t)0x3714, (q15_t)0x8c76, + (q15_t)0x36ba, (q15_t)0x8c4b, (q15_t)0x365f, (q15_t)0x8c20, (q15_t)0x3604, (q15_t)0x8bf5, (q15_t)0x35a8, (q15_t)0x8bcb, + (q15_t)0x354d, (q15_t)0x8ba1, (q15_t)0x34f2, (q15_t)0x8b77, (q15_t)0x3496, (q15_t)0x8b4e, (q15_t)0x343a, (q15_t)0x8b25, + (q15_t)0x33de, (q15_t)0x8afc, (q15_t)0x3382, (q15_t)0x8ad3, (q15_t)0x3326, (q15_t)0x8aab, (q15_t)0x32ca, (q15_t)0x8a83, + (q15_t)0x326e, (q15_t)0x8a5b, (q15_t)0x3211, (q15_t)0x8a34, (q15_t)0x31b5, (q15_t)0x8a0c, (q15_t)0x3158, (q15_t)0x89e5, + (q15_t)0x30fb, (q15_t)0x89bf, (q15_t)0x309e, (q15_t)0x8998, (q15_t)0x3041, (q15_t)0x8972, (q15_t)0x2fe4, (q15_t)0x894d, + (q15_t)0x2f87, (q15_t)0x8927, (q15_t)0x2f29, (q15_t)0x8902, (q15_t)0x2ecc, (q15_t)0x88dd, (q15_t)0x2e6e, (q15_t)0x88b9, + (q15_t)0x2e11, (q15_t)0x8894, (q15_t)0x2db3, (q15_t)0x8870, (q15_t)0x2d55, (q15_t)0x884c, (q15_t)0x2cf7, (q15_t)0x8829, + (q15_t)0x2c98, (q15_t)0x8806, (q15_t)0x2c3a, (q15_t)0x87e3, (q15_t)0x2bdc, (q15_t)0x87c0, (q15_t)0x2b7d, (q15_t)0x879e, + (q15_t)0x2b1f, (q15_t)0x877c, (q15_t)0x2ac0, (q15_t)0x875a, (q15_t)0x2a61, (q15_t)0x8739, (q15_t)0x2a02, (q15_t)0x8718, + (q15_t)0x29a3, (q15_t)0x86f7, (q15_t)0x2944, (q15_t)0x86d6, (q15_t)0x28e5, (q15_t)0x86b6, (q15_t)0x2886, (q15_t)0x8696, + (q15_t)0x2826, (q15_t)0x8676, (q15_t)0x27c7, (q15_t)0x8657, (q15_t)0x2767, (q15_t)0x8638, (q15_t)0x2707, (q15_t)0x8619, + (q15_t)0x26a8, (q15_t)0x85fb, (q15_t)0x2648, (q15_t)0x85dc, (q15_t)0x25e8, (q15_t)0x85be, (q15_t)0x2588, (q15_t)0x85a1, + (q15_t)0x2528, (q15_t)0x8583, (q15_t)0x24c7, (q15_t)0x8566, (q15_t)0x2467, (q15_t)0x854a, (q15_t)0x2407, (q15_t)0x852d, + (q15_t)0x23a6, (q15_t)0x8511, (q15_t)0x2345, (q15_t)0x84f5, (q15_t)0x22e5, (q15_t)0x84da, (q15_t)0x2284, (q15_t)0x84be, + (q15_t)0x2223, (q15_t)0x84a3, (q15_t)0x21c2, (q15_t)0x8489, (q15_t)0x2161, (q15_t)0x846e, (q15_t)0x2100, (q15_t)0x8454, + (q15_t)0x209f, (q15_t)0x843b, (q15_t)0x203e, (q15_t)0x8421, (q15_t)0x1fdc, (q15_t)0x8408, (q15_t)0x1f7b, (q15_t)0x83ef, + (q15_t)0x1f19, (q15_t)0x83d7, (q15_t)0x1eb8, (q15_t)0x83be, (q15_t)0x1e56, (q15_t)0x83a6, (q15_t)0x1df5, (q15_t)0x838f, + (q15_t)0x1d93, (q15_t)0x8377, (q15_t)0x1d31, (q15_t)0x8360, (q15_t)0x1ccf, (q15_t)0x8349, (q15_t)0x1c6d, (q15_t)0x8333, + (q15_t)0x1c0b, (q15_t)0x831d, (q15_t)0x1ba9, (q15_t)0x8307, (q15_t)0x1b47, (q15_t)0x82f1, (q15_t)0x1ae4, (q15_t)0x82dc, + (q15_t)0x1a82, (q15_t)0x82c7, (q15_t)0x1a20, (q15_t)0x82b2, (q15_t)0x19bd, (q15_t)0x829e, (q15_t)0x195b, (q15_t)0x828a, + (q15_t)0x18f8, (q15_t)0x8276, (q15_t)0x1896, (q15_t)0x8263, (q15_t)0x1833, (q15_t)0x8250, (q15_t)0x17d0, (q15_t)0x823d, + (q15_t)0x176d, (q15_t)0x822a, (q15_t)0x170a, (q15_t)0x8218, (q15_t)0x16a8, (q15_t)0x8206, (q15_t)0x1645, (q15_t)0x81f4, + (q15_t)0x15e2, (q15_t)0x81e3, (q15_t)0x157f, (q15_t)0x81d2, (q15_t)0x151b, (q15_t)0x81c1, (q15_t)0x14b8, (q15_t)0x81b1, + (q15_t)0x1455, (q15_t)0x81a1, (q15_t)0x13f2, (q15_t)0x8191, (q15_t)0x138e, (q15_t)0x8181, (q15_t)0x132b, (q15_t)0x8172, + (q15_t)0x12c8, (q15_t)0x8163, (q15_t)0x1264, (q15_t)0x8155, (q15_t)0x1201, (q15_t)0x8146, (q15_t)0x119d, (q15_t)0x8138, + (q15_t)0x1139, (q15_t)0x812b, (q15_t)0x10d6, (q15_t)0x811d, (q15_t)0x1072, (q15_t)0x8110, (q15_t)0x100e, (q15_t)0x8103, + (q15_t)0xfab, (q15_t)0x80f7, (q15_t)0xf47, (q15_t)0x80eb, (q15_t)0xee3, (q15_t)0x80df, (q15_t)0xe7f, (q15_t)0x80d3, + (q15_t)0xe1b, (q15_t)0x80c8, (q15_t)0xdb7, (q15_t)0x80bd, (q15_t)0xd53, (q15_t)0x80b3, (q15_t)0xcef, (q15_t)0x80a8, + (q15_t)0xc8b, (q15_t)0x809e, (q15_t)0xc27, (q15_t)0x8095, (q15_t)0xbc3, (q15_t)0x808b, (q15_t)0xb5f, (q15_t)0x8082, + (q15_t)0xafb, (q15_t)0x8079, (q15_t)0xa97, (q15_t)0x8071, (q15_t)0xa33, (q15_t)0x8069, (q15_t)0x9ce, (q15_t)0x8061, + (q15_t)0x96a, (q15_t)0x8059, (q15_t)0x906, (q15_t)0x8052, (q15_t)0x8a2, (q15_t)0x804b, (q15_t)0x83d, (q15_t)0x8044, + (q15_t)0x7d9, (q15_t)0x803e, (q15_t)0x775, (q15_t)0x8038, (q15_t)0x710, (q15_t)0x8032, (q15_t)0x6ac, (q15_t)0x802d, + (q15_t)0x647, (q15_t)0x8028, (q15_t)0x5e3, (q15_t)0x8023, (q15_t)0x57f, (q15_t)0x801f, (q15_t)0x51a, (q15_t)0x801b, + (q15_t)0x4b6, (q15_t)0x8017, (q15_t)0x451, (q15_t)0x8013, (q15_t)0x3ed, (q15_t)0x8010, (q15_t)0x388, (q15_t)0x800d, + (q15_t)0x324, (q15_t)0x800a, (q15_t)0x2bf, (q15_t)0x8008, (q15_t)0x25b, (q15_t)0x8006, (q15_t)0x1f6, (q15_t)0x8004, + (q15_t)0x192, (q15_t)0x8003, (q15_t)0x12d, (q15_t)0x8002, (q15_t)0xc9, (q15_t)0x8001, (q15_t)0x64, (q15_t)0x8001 +}; + +static const q15_t ALIGN4 WeightsQ15_2048[4096] = { + (q15_t)0x7fff, (q15_t)0x0, (q15_t)0x7fff, (q15_t)0xffe7, (q15_t)0x7fff, (q15_t)0xffce, (q15_t)0x7fff, (q15_t)0xffb5, + (q15_t)0x7fff, (q15_t)0xff9c, (q15_t)0x7fff, (q15_t)0xff83, (q15_t)0x7fff, (q15_t)0xff6a, (q15_t)0x7fff, (q15_t)0xff51, + (q15_t)0x7fff, (q15_t)0xff37, (q15_t)0x7fff, (q15_t)0xff1e, (q15_t)0x7fff, (q15_t)0xff05, (q15_t)0x7ffe, (q15_t)0xfeec, + (q15_t)0x7ffe, (q15_t)0xfed3, (q15_t)0x7ffe, (q15_t)0xfeba, (q15_t)0x7ffe, (q15_t)0xfea1, (q15_t)0x7ffd, (q15_t)0xfe88, + (q15_t)0x7ffd, (q15_t)0xfe6e, (q15_t)0x7ffd, (q15_t)0xfe55, (q15_t)0x7ffc, (q15_t)0xfe3c, (q15_t)0x7ffc, (q15_t)0xfe23, + (q15_t)0x7ffc, (q15_t)0xfe0a, (q15_t)0x7ffb, (q15_t)0xfdf1, (q15_t)0x7ffb, (q15_t)0xfdd8, (q15_t)0x7ffa, (q15_t)0xfdbe, + (q15_t)0x7ffa, (q15_t)0xfda5, (q15_t)0x7ff9, (q15_t)0xfd8c, (q15_t)0x7ff9, (q15_t)0xfd73, (q15_t)0x7ff8, (q15_t)0xfd5a, + (q15_t)0x7ff8, (q15_t)0xfd41, (q15_t)0x7ff7, (q15_t)0xfd28, (q15_t)0x7ff7, (q15_t)0xfd0f, (q15_t)0x7ff6, (q15_t)0xfcf5, + (q15_t)0x7ff6, (q15_t)0xfcdc, (q15_t)0x7ff5, (q15_t)0xfcc3, (q15_t)0x7ff4, (q15_t)0xfcaa, (q15_t)0x7ff4, (q15_t)0xfc91, + (q15_t)0x7ff3, (q15_t)0xfc78, (q15_t)0x7ff2, (q15_t)0xfc5f, (q15_t)0x7ff2, (q15_t)0xfc46, (q15_t)0x7ff1, (q15_t)0xfc2c, + (q15_t)0x7ff0, (q15_t)0xfc13, (q15_t)0x7fef, (q15_t)0xfbfa, (q15_t)0x7fee, (q15_t)0xfbe1, (q15_t)0x7fee, (q15_t)0xfbc8, + (q15_t)0x7fed, (q15_t)0xfbaf, (q15_t)0x7fec, (q15_t)0xfb96, (q15_t)0x7feb, (q15_t)0xfb7d, (q15_t)0x7fea, (q15_t)0xfb64, + (q15_t)0x7fe9, (q15_t)0xfb4a, (q15_t)0x7fe8, (q15_t)0xfb31, (q15_t)0x7fe7, (q15_t)0xfb18, (q15_t)0x7fe6, (q15_t)0xfaff, + (q15_t)0x7fe5, (q15_t)0xfae6, (q15_t)0x7fe4, (q15_t)0xfacd, (q15_t)0x7fe3, (q15_t)0xfab4, (q15_t)0x7fe2, (q15_t)0xfa9b, + (q15_t)0x7fe1, (q15_t)0xfa81, (q15_t)0x7fe0, (q15_t)0xfa68, (q15_t)0x7fdf, (q15_t)0xfa4f, (q15_t)0x7fde, (q15_t)0xfa36, + (q15_t)0x7fdd, (q15_t)0xfa1d, (q15_t)0x7fdc, (q15_t)0xfa04, (q15_t)0x7fda, (q15_t)0xf9eb, (q15_t)0x7fd9, (q15_t)0xf9d2, + (q15_t)0x7fd8, (q15_t)0xf9b9, (q15_t)0x7fd7, (q15_t)0xf9a0, (q15_t)0x7fd6, (q15_t)0xf986, (q15_t)0x7fd4, (q15_t)0xf96d, + (q15_t)0x7fd3, (q15_t)0xf954, (q15_t)0x7fd2, (q15_t)0xf93b, (q15_t)0x7fd0, (q15_t)0xf922, (q15_t)0x7fcf, (q15_t)0xf909, + (q15_t)0x7fce, (q15_t)0xf8f0, (q15_t)0x7fcc, (q15_t)0xf8d7, (q15_t)0x7fcb, (q15_t)0xf8be, (q15_t)0x7fc9, (q15_t)0xf8a5, + (q15_t)0x7fc8, (q15_t)0xf88b, (q15_t)0x7fc6, (q15_t)0xf872, (q15_t)0x7fc5, (q15_t)0xf859, (q15_t)0x7fc3, (q15_t)0xf840, + (q15_t)0x7fc2, (q15_t)0xf827, (q15_t)0x7fc0, (q15_t)0xf80e, (q15_t)0x7fbf, (q15_t)0xf7f5, (q15_t)0x7fbd, (q15_t)0xf7dc, + (q15_t)0x7fbc, (q15_t)0xf7c3, (q15_t)0x7fba, (q15_t)0xf7aa, (q15_t)0x7fb8, (q15_t)0xf791, (q15_t)0x7fb7, (q15_t)0xf778, + (q15_t)0x7fb5, (q15_t)0xf75e, (q15_t)0x7fb3, (q15_t)0xf745, (q15_t)0x7fb1, (q15_t)0xf72c, (q15_t)0x7fb0, (q15_t)0xf713, + (q15_t)0x7fae, (q15_t)0xf6fa, (q15_t)0x7fac, (q15_t)0xf6e1, (q15_t)0x7faa, (q15_t)0xf6c8, (q15_t)0x7fa9, (q15_t)0xf6af, + (q15_t)0x7fa7, (q15_t)0xf696, (q15_t)0x7fa5, (q15_t)0xf67d, (q15_t)0x7fa3, (q15_t)0xf664, (q15_t)0x7fa1, (q15_t)0xf64b, + (q15_t)0x7f9f, (q15_t)0xf632, (q15_t)0x7f9d, (q15_t)0xf619, (q15_t)0x7f9b, (q15_t)0xf600, (q15_t)0x7f99, (q15_t)0xf5e7, + (q15_t)0x7f97, (q15_t)0xf5cd, (q15_t)0x7f95, (q15_t)0xf5b4, (q15_t)0x7f93, (q15_t)0xf59b, (q15_t)0x7f91, (q15_t)0xf582, + (q15_t)0x7f8f, (q15_t)0xf569, (q15_t)0x7f8d, (q15_t)0xf550, (q15_t)0x7f8b, (q15_t)0xf537, (q15_t)0x7f89, (q15_t)0xf51e, + (q15_t)0x7f87, (q15_t)0xf505, (q15_t)0x7f85, (q15_t)0xf4ec, (q15_t)0x7f82, (q15_t)0xf4d3, (q15_t)0x7f80, (q15_t)0xf4ba, + (q15_t)0x7f7e, (q15_t)0xf4a1, (q15_t)0x7f7c, (q15_t)0xf488, (q15_t)0x7f79, (q15_t)0xf46f, (q15_t)0x7f77, (q15_t)0xf456, + (q15_t)0x7f75, (q15_t)0xf43d, (q15_t)0x7f72, (q15_t)0xf424, (q15_t)0x7f70, (q15_t)0xf40b, (q15_t)0x7f6e, (q15_t)0xf3f2, + (q15_t)0x7f6b, (q15_t)0xf3d9, (q15_t)0x7f69, (q15_t)0xf3c0, (q15_t)0x7f67, (q15_t)0xf3a7, (q15_t)0x7f64, (q15_t)0xf38e, + (q15_t)0x7f62, (q15_t)0xf375, (q15_t)0x7f5f, (q15_t)0xf35c, (q15_t)0x7f5d, (q15_t)0xf343, (q15_t)0x7f5a, (q15_t)0xf32a, + (q15_t)0x7f58, (q15_t)0xf311, (q15_t)0x7f55, (q15_t)0xf2f8, (q15_t)0x7f53, (q15_t)0xf2df, (q15_t)0x7f50, (q15_t)0xf2c6, + (q15_t)0x7f4d, (q15_t)0xf2ad, (q15_t)0x7f4b, (q15_t)0xf294, (q15_t)0x7f48, (q15_t)0xf27b, (q15_t)0x7f45, (q15_t)0xf262, + (q15_t)0x7f43, (q15_t)0xf249, (q15_t)0x7f40, (q15_t)0xf230, (q15_t)0x7f3d, (q15_t)0xf217, (q15_t)0x7f3b, (q15_t)0xf1fe, + (q15_t)0x7f38, (q15_t)0xf1e5, (q15_t)0x7f35, (q15_t)0xf1cc, (q15_t)0x7f32, (q15_t)0xf1b3, (q15_t)0x7f2f, (q15_t)0xf19a, + (q15_t)0x7f2d, (q15_t)0xf181, (q15_t)0x7f2a, (q15_t)0xf168, (q15_t)0x7f27, (q15_t)0xf14f, (q15_t)0x7f24, (q15_t)0xf136, + (q15_t)0x7f21, (q15_t)0xf11d, (q15_t)0x7f1e, (q15_t)0xf104, (q15_t)0x7f1b, (q15_t)0xf0eb, (q15_t)0x7f18, (q15_t)0xf0d2, + (q15_t)0x7f15, (q15_t)0xf0b9, (q15_t)0x7f12, (q15_t)0xf0a0, (q15_t)0x7f0f, (q15_t)0xf087, (q15_t)0x7f0c, (q15_t)0xf06e, + (q15_t)0x7f09, (q15_t)0xf055, (q15_t)0x7f06, (q15_t)0xf03c, (q15_t)0x7f03, (q15_t)0xf023, (q15_t)0x7f00, (q15_t)0xf00b, + (q15_t)0x7efd, (q15_t)0xeff2, (q15_t)0x7ef9, (q15_t)0xefd9, (q15_t)0x7ef6, (q15_t)0xefc0, (q15_t)0x7ef3, (q15_t)0xefa7, + (q15_t)0x7ef0, (q15_t)0xef8e, (q15_t)0x7eed, (q15_t)0xef75, (q15_t)0x7ee9, (q15_t)0xef5c, (q15_t)0x7ee6, (q15_t)0xef43, + (q15_t)0x7ee3, (q15_t)0xef2a, (q15_t)0x7edf, (q15_t)0xef11, (q15_t)0x7edc, (q15_t)0xeef8, (q15_t)0x7ed9, (q15_t)0xeedf, + (q15_t)0x7ed5, (q15_t)0xeec7, (q15_t)0x7ed2, (q15_t)0xeeae, (q15_t)0x7ecf, (q15_t)0xee95, (q15_t)0x7ecb, (q15_t)0xee7c, + (q15_t)0x7ec8, (q15_t)0xee63, (q15_t)0x7ec4, (q15_t)0xee4a, (q15_t)0x7ec1, (q15_t)0xee31, (q15_t)0x7ebd, (q15_t)0xee18, + (q15_t)0x7eba, (q15_t)0xedff, (q15_t)0x7eb6, (q15_t)0xede7, (q15_t)0x7eb3, (q15_t)0xedce, (q15_t)0x7eaf, (q15_t)0xedb5, + (q15_t)0x7eab, (q15_t)0xed9c, (q15_t)0x7ea8, (q15_t)0xed83, (q15_t)0x7ea4, (q15_t)0xed6a, (q15_t)0x7ea1, (q15_t)0xed51, + (q15_t)0x7e9d, (q15_t)0xed38, (q15_t)0x7e99, (q15_t)0xed20, (q15_t)0x7e95, (q15_t)0xed07, (q15_t)0x7e92, (q15_t)0xecee, + (q15_t)0x7e8e, (q15_t)0xecd5, (q15_t)0x7e8a, (q15_t)0xecbc, (q15_t)0x7e86, (q15_t)0xeca3, (q15_t)0x7e83, (q15_t)0xec8a, + (q15_t)0x7e7f, (q15_t)0xec72, (q15_t)0x7e7b, (q15_t)0xec59, (q15_t)0x7e77, (q15_t)0xec40, (q15_t)0x7e73, (q15_t)0xec27, + (q15_t)0x7e6f, (q15_t)0xec0e, (q15_t)0x7e6b, (q15_t)0xebf5, (q15_t)0x7e67, (q15_t)0xebdd, (q15_t)0x7e63, (q15_t)0xebc4, + (q15_t)0x7e5f, (q15_t)0xebab, (q15_t)0x7e5b, (q15_t)0xeb92, (q15_t)0x7e57, (q15_t)0xeb79, (q15_t)0x7e53, (q15_t)0xeb61, + (q15_t)0x7e4f, (q15_t)0xeb48, (q15_t)0x7e4b, (q15_t)0xeb2f, (q15_t)0x7e47, (q15_t)0xeb16, (q15_t)0x7e43, (q15_t)0xeafd, + (q15_t)0x7e3f, (q15_t)0xeae5, (q15_t)0x7e3b, (q15_t)0xeacc, (q15_t)0x7e37, (q15_t)0xeab3, (q15_t)0x7e32, (q15_t)0xea9a, + (q15_t)0x7e2e, (q15_t)0xea81, (q15_t)0x7e2a, (q15_t)0xea69, (q15_t)0x7e26, (q15_t)0xea50, (q15_t)0x7e21, (q15_t)0xea37, + (q15_t)0x7e1d, (q15_t)0xea1e, (q15_t)0x7e19, (q15_t)0xea06, (q15_t)0x7e14, (q15_t)0xe9ed, (q15_t)0x7e10, (q15_t)0xe9d4, + (q15_t)0x7e0c, (q15_t)0xe9bb, (q15_t)0x7e07, (q15_t)0xe9a3, (q15_t)0x7e03, (q15_t)0xe98a, (q15_t)0x7dff, (q15_t)0xe971, + (q15_t)0x7dfa, (q15_t)0xe958, (q15_t)0x7df6, (q15_t)0xe940, (q15_t)0x7df1, (q15_t)0xe927, (q15_t)0x7ded, (q15_t)0xe90e, + (q15_t)0x7de8, (q15_t)0xe8f6, (q15_t)0x7de4, (q15_t)0xe8dd, (q15_t)0x7ddf, (q15_t)0xe8c4, (q15_t)0x7dda, (q15_t)0xe8ab, + (q15_t)0x7dd6, (q15_t)0xe893, (q15_t)0x7dd1, (q15_t)0xe87a, (q15_t)0x7dcd, (q15_t)0xe861, (q15_t)0x7dc8, (q15_t)0xe849, + (q15_t)0x7dc3, (q15_t)0xe830, (q15_t)0x7dbf, (q15_t)0xe817, (q15_t)0x7dba, (q15_t)0xe7fe, (q15_t)0x7db5, (q15_t)0xe7e6, + (q15_t)0x7db0, (q15_t)0xe7cd, (q15_t)0x7dac, (q15_t)0xe7b4, (q15_t)0x7da7, (q15_t)0xe79c, (q15_t)0x7da2, (q15_t)0xe783, + (q15_t)0x7d9d, (q15_t)0xe76a, (q15_t)0x7d98, (q15_t)0xe752, (q15_t)0x7d94, (q15_t)0xe739, (q15_t)0x7d8f, (q15_t)0xe720, + (q15_t)0x7d8a, (q15_t)0xe708, (q15_t)0x7d85, (q15_t)0xe6ef, (q15_t)0x7d80, (q15_t)0xe6d6, (q15_t)0x7d7b, (q15_t)0xe6be, + (q15_t)0x7d76, (q15_t)0xe6a5, (q15_t)0x7d71, (q15_t)0xe68d, (q15_t)0x7d6c, (q15_t)0xe674, (q15_t)0x7d67, (q15_t)0xe65b, + (q15_t)0x7d62, (q15_t)0xe643, (q15_t)0x7d5d, (q15_t)0xe62a, (q15_t)0x7d58, (q15_t)0xe611, (q15_t)0x7d53, (q15_t)0xe5f9, + (q15_t)0x7d4e, (q15_t)0xe5e0, (q15_t)0x7d49, (q15_t)0xe5c8, (q15_t)0x7d43, (q15_t)0xe5af, (q15_t)0x7d3e, (q15_t)0xe596, + (q15_t)0x7d39, (q15_t)0xe57e, (q15_t)0x7d34, (q15_t)0xe565, (q15_t)0x7d2f, (q15_t)0xe54d, (q15_t)0x7d29, (q15_t)0xe534, + (q15_t)0x7d24, (q15_t)0xe51c, (q15_t)0x7d1f, (q15_t)0xe503, (q15_t)0x7d19, (q15_t)0xe4ea, (q15_t)0x7d14, (q15_t)0xe4d2, + (q15_t)0x7d0f, (q15_t)0xe4b9, (q15_t)0x7d09, (q15_t)0xe4a1, (q15_t)0x7d04, (q15_t)0xe488, (q15_t)0x7cff, (q15_t)0xe470, + (q15_t)0x7cf9, (q15_t)0xe457, (q15_t)0x7cf4, (q15_t)0xe43f, (q15_t)0x7cee, (q15_t)0xe426, (q15_t)0x7ce9, (q15_t)0xe40e, + (q15_t)0x7ce3, (q15_t)0xe3f5, (q15_t)0x7cde, (q15_t)0xe3dc, (q15_t)0x7cd8, (q15_t)0xe3c4, (q15_t)0x7cd3, (q15_t)0xe3ab, + (q15_t)0x7ccd, (q15_t)0xe393, (q15_t)0x7cc8, (q15_t)0xe37a, (q15_t)0x7cc2, (q15_t)0xe362, (q15_t)0x7cbc, (q15_t)0xe349, + (q15_t)0x7cb7, (q15_t)0xe331, (q15_t)0x7cb1, (q15_t)0xe318, (q15_t)0x7cab, (q15_t)0xe300, (q15_t)0x7ca6, (q15_t)0xe2e8, + (q15_t)0x7ca0, (q15_t)0xe2cf, (q15_t)0x7c9a, (q15_t)0xe2b7, (q15_t)0x7c94, (q15_t)0xe29e, (q15_t)0x7c8f, (q15_t)0xe286, + (q15_t)0x7c89, (q15_t)0xe26d, (q15_t)0x7c83, (q15_t)0xe255, (q15_t)0x7c7d, (q15_t)0xe23c, (q15_t)0x7c77, (q15_t)0xe224, + (q15_t)0x7c71, (q15_t)0xe20b, (q15_t)0x7c6c, (q15_t)0xe1f3, (q15_t)0x7c66, (q15_t)0xe1db, (q15_t)0x7c60, (q15_t)0xe1c2, + (q15_t)0x7c5a, (q15_t)0xe1aa, (q15_t)0x7c54, (q15_t)0xe191, (q15_t)0x7c4e, (q15_t)0xe179, (q15_t)0x7c48, (q15_t)0xe160, + (q15_t)0x7c42, (q15_t)0xe148, (q15_t)0x7c3c, (q15_t)0xe130, (q15_t)0x7c36, (q15_t)0xe117, (q15_t)0x7c30, (q15_t)0xe0ff, + (q15_t)0x7c29, (q15_t)0xe0e7, (q15_t)0x7c23, (q15_t)0xe0ce, (q15_t)0x7c1d, (q15_t)0xe0b6, (q15_t)0x7c17, (q15_t)0xe09d, + (q15_t)0x7c11, (q15_t)0xe085, (q15_t)0x7c0b, (q15_t)0xe06d, (q15_t)0x7c05, (q15_t)0xe054, (q15_t)0x7bfe, (q15_t)0xe03c, + (q15_t)0x7bf8, (q15_t)0xe024, (q15_t)0x7bf2, (q15_t)0xe00b, (q15_t)0x7beb, (q15_t)0xdff3, (q15_t)0x7be5, (q15_t)0xdfdb, + (q15_t)0x7bdf, (q15_t)0xdfc2, (q15_t)0x7bd9, (q15_t)0xdfaa, (q15_t)0x7bd2, (q15_t)0xdf92, (q15_t)0x7bcc, (q15_t)0xdf79, + (q15_t)0x7bc5, (q15_t)0xdf61, (q15_t)0x7bbf, (q15_t)0xdf49, (q15_t)0x7bb9, (q15_t)0xdf30, (q15_t)0x7bb2, (q15_t)0xdf18, + (q15_t)0x7bac, (q15_t)0xdf00, (q15_t)0x7ba5, (q15_t)0xdee8, (q15_t)0x7b9f, (q15_t)0xdecf, (q15_t)0x7b98, (q15_t)0xdeb7, + (q15_t)0x7b92, (q15_t)0xde9f, (q15_t)0x7b8b, (q15_t)0xde87, (q15_t)0x7b84, (q15_t)0xde6e, (q15_t)0x7b7e, (q15_t)0xde56, + (q15_t)0x7b77, (q15_t)0xde3e, (q15_t)0x7b71, (q15_t)0xde26, (q15_t)0x7b6a, (q15_t)0xde0d, (q15_t)0x7b63, (q15_t)0xddf5, + (q15_t)0x7b5d, (q15_t)0xdddd, (q15_t)0x7b56, (q15_t)0xddc5, (q15_t)0x7b4f, (q15_t)0xddac, (q15_t)0x7b48, (q15_t)0xdd94, + (q15_t)0x7b42, (q15_t)0xdd7c, (q15_t)0x7b3b, (q15_t)0xdd64, (q15_t)0x7b34, (q15_t)0xdd4c, (q15_t)0x7b2d, (q15_t)0xdd33, + (q15_t)0x7b26, (q15_t)0xdd1b, (q15_t)0x7b1f, (q15_t)0xdd03, (q15_t)0x7b19, (q15_t)0xdceb, (q15_t)0x7b12, (q15_t)0xdcd3, + (q15_t)0x7b0b, (q15_t)0xdcbb, (q15_t)0x7b04, (q15_t)0xdca2, (q15_t)0x7afd, (q15_t)0xdc8a, (q15_t)0x7af6, (q15_t)0xdc72, + (q15_t)0x7aef, (q15_t)0xdc5a, (q15_t)0x7ae8, (q15_t)0xdc42, (q15_t)0x7ae1, (q15_t)0xdc2a, (q15_t)0x7ada, (q15_t)0xdc12, + (q15_t)0x7ad3, (q15_t)0xdbf9, (q15_t)0x7acc, (q15_t)0xdbe1, (q15_t)0x7ac5, (q15_t)0xdbc9, (q15_t)0x7abd, (q15_t)0xdbb1, + (q15_t)0x7ab6, (q15_t)0xdb99, (q15_t)0x7aaf, (q15_t)0xdb81, (q15_t)0x7aa8, (q15_t)0xdb69, (q15_t)0x7aa1, (q15_t)0xdb51, + (q15_t)0x7a9a, (q15_t)0xdb39, (q15_t)0x7a92, (q15_t)0xdb21, (q15_t)0x7a8b, (q15_t)0xdb09, (q15_t)0x7a84, (q15_t)0xdaf1, + (q15_t)0x7a7d, (q15_t)0xdad8, (q15_t)0x7a75, (q15_t)0xdac0, (q15_t)0x7a6e, (q15_t)0xdaa8, (q15_t)0x7a67, (q15_t)0xda90, + (q15_t)0x7a5f, (q15_t)0xda78, (q15_t)0x7a58, (q15_t)0xda60, (q15_t)0x7a50, (q15_t)0xda48, (q15_t)0x7a49, (q15_t)0xda30, + (q15_t)0x7a42, (q15_t)0xda18, (q15_t)0x7a3a, (q15_t)0xda00, (q15_t)0x7a33, (q15_t)0xd9e8, (q15_t)0x7a2b, (q15_t)0xd9d0, + (q15_t)0x7a24, (q15_t)0xd9b8, (q15_t)0x7a1c, (q15_t)0xd9a0, (q15_t)0x7a15, (q15_t)0xd988, (q15_t)0x7a0d, (q15_t)0xd970, + (q15_t)0x7a05, (q15_t)0xd958, (q15_t)0x79fe, (q15_t)0xd940, (q15_t)0x79f6, (q15_t)0xd928, (q15_t)0x79ef, (q15_t)0xd911, + (q15_t)0x79e7, (q15_t)0xd8f9, (q15_t)0x79df, (q15_t)0xd8e1, (q15_t)0x79d8, (q15_t)0xd8c9, (q15_t)0x79d0, (q15_t)0xd8b1, + (q15_t)0x79c8, (q15_t)0xd899, (q15_t)0x79c0, (q15_t)0xd881, (q15_t)0x79b9, (q15_t)0xd869, (q15_t)0x79b1, (q15_t)0xd851, + (q15_t)0x79a9, (q15_t)0xd839, (q15_t)0x79a1, (q15_t)0xd821, (q15_t)0x7999, (q15_t)0xd80a, (q15_t)0x7992, (q15_t)0xd7f2, + (q15_t)0x798a, (q15_t)0xd7da, (q15_t)0x7982, (q15_t)0xd7c2, (q15_t)0x797a, (q15_t)0xd7aa, (q15_t)0x7972, (q15_t)0xd792, + (q15_t)0x796a, (q15_t)0xd77a, (q15_t)0x7962, (q15_t)0xd763, (q15_t)0x795a, (q15_t)0xd74b, (q15_t)0x7952, (q15_t)0xd733, + (q15_t)0x794a, (q15_t)0xd71b, (q15_t)0x7942, (q15_t)0xd703, (q15_t)0x793a, (q15_t)0xd6eb, (q15_t)0x7932, (q15_t)0xd6d4, + (q15_t)0x792a, (q15_t)0xd6bc, (q15_t)0x7922, (q15_t)0xd6a4, (q15_t)0x7919, (q15_t)0xd68c, (q15_t)0x7911, (q15_t)0xd675, + (q15_t)0x7909, (q15_t)0xd65d, (q15_t)0x7901, (q15_t)0xd645, (q15_t)0x78f9, (q15_t)0xd62d, (q15_t)0x78f1, (q15_t)0xd615, + (q15_t)0x78e8, (q15_t)0xd5fe, (q15_t)0x78e0, (q15_t)0xd5e6, (q15_t)0x78d8, (q15_t)0xd5ce, (q15_t)0x78cf, (q15_t)0xd5b7, + (q15_t)0x78c7, (q15_t)0xd59f, (q15_t)0x78bf, (q15_t)0xd587, (q15_t)0x78b6, (q15_t)0xd56f, (q15_t)0x78ae, (q15_t)0xd558, + (q15_t)0x78a6, (q15_t)0xd540, (q15_t)0x789d, (q15_t)0xd528, (q15_t)0x7895, (q15_t)0xd511, (q15_t)0x788c, (q15_t)0xd4f9, + (q15_t)0x7884, (q15_t)0xd4e1, (q15_t)0x787c, (q15_t)0xd4ca, (q15_t)0x7873, (q15_t)0xd4b2, (q15_t)0x786b, (q15_t)0xd49a, + (q15_t)0x7862, (q15_t)0xd483, (q15_t)0x7859, (q15_t)0xd46b, (q15_t)0x7851, (q15_t)0xd453, (q15_t)0x7848, (q15_t)0xd43c, + (q15_t)0x7840, (q15_t)0xd424, (q15_t)0x7837, (q15_t)0xd40d, (q15_t)0x782e, (q15_t)0xd3f5, (q15_t)0x7826, (q15_t)0xd3dd, + (q15_t)0x781d, (q15_t)0xd3c6, (q15_t)0x7814, (q15_t)0xd3ae, (q15_t)0x780c, (q15_t)0xd397, (q15_t)0x7803, (q15_t)0xd37f, + (q15_t)0x77fa, (q15_t)0xd368, (q15_t)0x77f1, (q15_t)0xd350, (q15_t)0x77e9, (q15_t)0xd338, (q15_t)0x77e0, (q15_t)0xd321, + (q15_t)0x77d7, (q15_t)0xd309, (q15_t)0x77ce, (q15_t)0xd2f2, (q15_t)0x77c5, (q15_t)0xd2da, (q15_t)0x77bc, (q15_t)0xd2c3, + (q15_t)0x77b4, (q15_t)0xd2ab, (q15_t)0x77ab, (q15_t)0xd294, (q15_t)0x77a2, (q15_t)0xd27c, (q15_t)0x7799, (q15_t)0xd265, + (q15_t)0x7790, (q15_t)0xd24d, (q15_t)0x7787, (q15_t)0xd236, (q15_t)0x777e, (q15_t)0xd21e, (q15_t)0x7775, (q15_t)0xd207, + (q15_t)0x776c, (q15_t)0xd1ef, (q15_t)0x7763, (q15_t)0xd1d8, (q15_t)0x775a, (q15_t)0xd1c1, (q15_t)0x7751, (q15_t)0xd1a9, + (q15_t)0x7747, (q15_t)0xd192, (q15_t)0x773e, (q15_t)0xd17a, (q15_t)0x7735, (q15_t)0xd163, (q15_t)0x772c, (q15_t)0xd14b, + (q15_t)0x7723, (q15_t)0xd134, (q15_t)0x771a, (q15_t)0xd11d, (q15_t)0x7710, (q15_t)0xd105, (q15_t)0x7707, (q15_t)0xd0ee, + (q15_t)0x76fe, (q15_t)0xd0d7, (q15_t)0x76f5, (q15_t)0xd0bf, (q15_t)0x76eb, (q15_t)0xd0a8, (q15_t)0x76e2, (q15_t)0xd091, + (q15_t)0x76d9, (q15_t)0xd079, (q15_t)0x76cf, (q15_t)0xd062, (q15_t)0x76c6, (q15_t)0xd04b, (q15_t)0x76bd, (q15_t)0xd033, + (q15_t)0x76b3, (q15_t)0xd01c, (q15_t)0x76aa, (q15_t)0xd005, (q15_t)0x76a0, (q15_t)0xcfed, (q15_t)0x7697, (q15_t)0xcfd6, + (q15_t)0x768e, (q15_t)0xcfbf, (q15_t)0x7684, (q15_t)0xcfa7, (q15_t)0x767b, (q15_t)0xcf90, (q15_t)0x7671, (q15_t)0xcf79, + (q15_t)0x7668, (q15_t)0xcf62, (q15_t)0x765e, (q15_t)0xcf4a, (q15_t)0x7654, (q15_t)0xcf33, (q15_t)0x764b, (q15_t)0xcf1c, + (q15_t)0x7641, (q15_t)0xcf05, (q15_t)0x7638, (q15_t)0xceee, (q15_t)0x762e, (q15_t)0xced6, (q15_t)0x7624, (q15_t)0xcebf, + (q15_t)0x761b, (q15_t)0xcea8, (q15_t)0x7611, (q15_t)0xce91, (q15_t)0x7607, (q15_t)0xce7a, (q15_t)0x75fd, (q15_t)0xce62, + (q15_t)0x75f4, (q15_t)0xce4b, (q15_t)0x75ea, (q15_t)0xce34, (q15_t)0x75e0, (q15_t)0xce1d, (q15_t)0x75d6, (q15_t)0xce06, + (q15_t)0x75cc, (q15_t)0xcdef, (q15_t)0x75c3, (q15_t)0xcdd8, (q15_t)0x75b9, (q15_t)0xcdc0, (q15_t)0x75af, (q15_t)0xcda9, + (q15_t)0x75a5, (q15_t)0xcd92, (q15_t)0x759b, (q15_t)0xcd7b, (q15_t)0x7591, (q15_t)0xcd64, (q15_t)0x7587, (q15_t)0xcd4d, + (q15_t)0x757d, (q15_t)0xcd36, (q15_t)0x7573, (q15_t)0xcd1f, (q15_t)0x7569, (q15_t)0xcd08, (q15_t)0x755f, (q15_t)0xccf1, + (q15_t)0x7555, (q15_t)0xccda, (q15_t)0x754b, (q15_t)0xccc3, (q15_t)0x7541, (q15_t)0xccac, (q15_t)0x7537, (q15_t)0xcc95, + (q15_t)0x752d, (q15_t)0xcc7e, (q15_t)0x7523, (q15_t)0xcc67, (q15_t)0x7519, (q15_t)0xcc50, (q15_t)0x750f, (q15_t)0xcc39, + (q15_t)0x7504, (q15_t)0xcc22, (q15_t)0x74fa, (q15_t)0xcc0b, (q15_t)0x74f0, (q15_t)0xcbf4, (q15_t)0x74e6, (q15_t)0xcbdd, + (q15_t)0x74db, (q15_t)0xcbc6, (q15_t)0x74d1, (q15_t)0xcbaf, (q15_t)0x74c7, (q15_t)0xcb98, (q15_t)0x74bd, (q15_t)0xcb81, + (q15_t)0x74b2, (q15_t)0xcb6a, (q15_t)0x74a8, (q15_t)0xcb53, (q15_t)0x749e, (q15_t)0xcb3c, (q15_t)0x7493, (q15_t)0xcb25, + (q15_t)0x7489, (q15_t)0xcb0e, (q15_t)0x747e, (q15_t)0xcaf8, (q15_t)0x7474, (q15_t)0xcae1, (q15_t)0x746a, (q15_t)0xcaca, + (q15_t)0x745f, (q15_t)0xcab3, (q15_t)0x7455, (q15_t)0xca9c, (q15_t)0x744a, (q15_t)0xca85, (q15_t)0x7440, (q15_t)0xca6e, + (q15_t)0x7435, (q15_t)0xca58, (q15_t)0x742b, (q15_t)0xca41, (q15_t)0x7420, (q15_t)0xca2a, (q15_t)0x7415, (q15_t)0xca13, + (q15_t)0x740b, (q15_t)0xc9fc, (q15_t)0x7400, (q15_t)0xc9e6, (q15_t)0x73f6, (q15_t)0xc9cf, (q15_t)0x73eb, (q15_t)0xc9b8, + (q15_t)0x73e0, (q15_t)0xc9a1, (q15_t)0x73d6, (q15_t)0xc98b, (q15_t)0x73cb, (q15_t)0xc974, (q15_t)0x73c0, (q15_t)0xc95d, + (q15_t)0x73b5, (q15_t)0xc946, (q15_t)0x73ab, (q15_t)0xc930, (q15_t)0x73a0, (q15_t)0xc919, (q15_t)0x7395, (q15_t)0xc902, + (q15_t)0x738a, (q15_t)0xc8ec, (q15_t)0x737f, (q15_t)0xc8d5, (q15_t)0x7375, (q15_t)0xc8be, (q15_t)0x736a, (q15_t)0xc8a8, + (q15_t)0x735f, (q15_t)0xc891, (q15_t)0x7354, (q15_t)0xc87a, (q15_t)0x7349, (q15_t)0xc864, (q15_t)0x733e, (q15_t)0xc84d, + (q15_t)0x7333, (q15_t)0xc836, (q15_t)0x7328, (q15_t)0xc820, (q15_t)0x731d, (q15_t)0xc809, (q15_t)0x7312, (q15_t)0xc7f3, + (q15_t)0x7307, (q15_t)0xc7dc, (q15_t)0x72fc, (q15_t)0xc7c5, (q15_t)0x72f1, (q15_t)0xc7af, (q15_t)0x72e6, (q15_t)0xc798, + (q15_t)0x72db, (q15_t)0xc782, (q15_t)0x72d0, (q15_t)0xc76b, (q15_t)0x72c5, (q15_t)0xc755, (q15_t)0x72ba, (q15_t)0xc73e, + (q15_t)0x72af, (q15_t)0xc728, (q15_t)0x72a3, (q15_t)0xc711, (q15_t)0x7298, (q15_t)0xc6fa, (q15_t)0x728d, (q15_t)0xc6e4, + (q15_t)0x7282, (q15_t)0xc6ce, (q15_t)0x7276, (q15_t)0xc6b7, (q15_t)0x726b, (q15_t)0xc6a1, (q15_t)0x7260, (q15_t)0xc68a, + (q15_t)0x7255, (q15_t)0xc674, (q15_t)0x7249, (q15_t)0xc65d, (q15_t)0x723e, (q15_t)0xc647, (q15_t)0x7233, (q15_t)0xc630, + (q15_t)0x7227, (q15_t)0xc61a, (q15_t)0x721c, (q15_t)0xc603, (q15_t)0x7211, (q15_t)0xc5ed, (q15_t)0x7205, (q15_t)0xc5d7, + (q15_t)0x71fa, (q15_t)0xc5c0, (q15_t)0x71ee, (q15_t)0xc5aa, (q15_t)0x71e3, (q15_t)0xc594, (q15_t)0x71d7, (q15_t)0xc57d, + (q15_t)0x71cc, (q15_t)0xc567, (q15_t)0x71c0, (q15_t)0xc551, (q15_t)0x71b5, (q15_t)0xc53a, (q15_t)0x71a9, (q15_t)0xc524, + (q15_t)0x719e, (q15_t)0xc50e, (q15_t)0x7192, (q15_t)0xc4f7, (q15_t)0x7186, (q15_t)0xc4e1, (q15_t)0x717b, (q15_t)0xc4cb, + (q15_t)0x716f, (q15_t)0xc4b4, (q15_t)0x7164, (q15_t)0xc49e, (q15_t)0x7158, (q15_t)0xc488, (q15_t)0x714c, (q15_t)0xc472, + (q15_t)0x7141, (q15_t)0xc45b, (q15_t)0x7135, (q15_t)0xc445, (q15_t)0x7129, (q15_t)0xc42f, (q15_t)0x711d, (q15_t)0xc419, + (q15_t)0x7112, (q15_t)0xc403, (q15_t)0x7106, (q15_t)0xc3ec, (q15_t)0x70fa, (q15_t)0xc3d6, (q15_t)0x70ee, (q15_t)0xc3c0, + (q15_t)0x70e2, (q15_t)0xc3aa, (q15_t)0x70d6, (q15_t)0xc394, (q15_t)0x70cb, (q15_t)0xc37d, (q15_t)0x70bf, (q15_t)0xc367, + (q15_t)0x70b3, (q15_t)0xc351, (q15_t)0x70a7, (q15_t)0xc33b, (q15_t)0x709b, (q15_t)0xc325, (q15_t)0x708f, (q15_t)0xc30f, + (q15_t)0x7083, (q15_t)0xc2f9, (q15_t)0x7077, (q15_t)0xc2e3, (q15_t)0x706b, (q15_t)0xc2cd, (q15_t)0x705f, (q15_t)0xc2b7, + (q15_t)0x7053, (q15_t)0xc2a0, (q15_t)0x7047, (q15_t)0xc28a, (q15_t)0x703b, (q15_t)0xc274, (q15_t)0x702f, (q15_t)0xc25e, + (q15_t)0x7023, (q15_t)0xc248, (q15_t)0x7016, (q15_t)0xc232, (q15_t)0x700a, (q15_t)0xc21c, (q15_t)0x6ffe, (q15_t)0xc206, + (q15_t)0x6ff2, (q15_t)0xc1f0, (q15_t)0x6fe6, (q15_t)0xc1da, (q15_t)0x6fda, (q15_t)0xc1c4, (q15_t)0x6fcd, (q15_t)0xc1ae, + (q15_t)0x6fc1, (q15_t)0xc198, (q15_t)0x6fb5, (q15_t)0xc183, (q15_t)0x6fa9, (q15_t)0xc16d, (q15_t)0x6f9c, (q15_t)0xc157, + (q15_t)0x6f90, (q15_t)0xc141, (q15_t)0x6f84, (q15_t)0xc12b, (q15_t)0x6f77, (q15_t)0xc115, (q15_t)0x6f6b, (q15_t)0xc0ff, + (q15_t)0x6f5f, (q15_t)0xc0e9, (q15_t)0x6f52, (q15_t)0xc0d3, (q15_t)0x6f46, (q15_t)0xc0bd, (q15_t)0x6f39, (q15_t)0xc0a8, + (q15_t)0x6f2d, (q15_t)0xc092, (q15_t)0x6f20, (q15_t)0xc07c, (q15_t)0x6f14, (q15_t)0xc066, (q15_t)0x6f07, (q15_t)0xc050, + (q15_t)0x6efb, (q15_t)0xc03b, (q15_t)0x6eee, (q15_t)0xc025, (q15_t)0x6ee2, (q15_t)0xc00f, (q15_t)0x6ed5, (q15_t)0xbff9, + (q15_t)0x6ec9, (q15_t)0xbfe3, (q15_t)0x6ebc, (q15_t)0xbfce, (q15_t)0x6eaf, (q15_t)0xbfb8, (q15_t)0x6ea3, (q15_t)0xbfa2, + (q15_t)0x6e96, (q15_t)0xbf8d, (q15_t)0x6e89, (q15_t)0xbf77, (q15_t)0x6e7d, (q15_t)0xbf61, (q15_t)0x6e70, (q15_t)0xbf4b, + (q15_t)0x6e63, (q15_t)0xbf36, (q15_t)0x6e57, (q15_t)0xbf20, (q15_t)0x6e4a, (q15_t)0xbf0a, (q15_t)0x6e3d, (q15_t)0xbef5, + (q15_t)0x6e30, (q15_t)0xbedf, (q15_t)0x6e24, (q15_t)0xbeca, (q15_t)0x6e17, (q15_t)0xbeb4, (q15_t)0x6e0a, (q15_t)0xbe9e, + (q15_t)0x6dfd, (q15_t)0xbe89, (q15_t)0x6df0, (q15_t)0xbe73, (q15_t)0x6de3, (q15_t)0xbe5e, (q15_t)0x6dd6, (q15_t)0xbe48, + (q15_t)0x6dca, (q15_t)0xbe32, (q15_t)0x6dbd, (q15_t)0xbe1d, (q15_t)0x6db0, (q15_t)0xbe07, (q15_t)0x6da3, (q15_t)0xbdf2, + (q15_t)0x6d96, (q15_t)0xbddc, (q15_t)0x6d89, (q15_t)0xbdc7, (q15_t)0x6d7c, (q15_t)0xbdb1, (q15_t)0x6d6f, (q15_t)0xbd9c, + (q15_t)0x6d62, (q15_t)0xbd86, (q15_t)0x6d55, (q15_t)0xbd71, (q15_t)0x6d48, (q15_t)0xbd5b, (q15_t)0x6d3a, (q15_t)0xbd46, + (q15_t)0x6d2d, (q15_t)0xbd30, (q15_t)0x6d20, (q15_t)0xbd1b, (q15_t)0x6d13, (q15_t)0xbd06, (q15_t)0x6d06, (q15_t)0xbcf0, + (q15_t)0x6cf9, (q15_t)0xbcdb, (q15_t)0x6cec, (q15_t)0xbcc5, (q15_t)0x6cde, (q15_t)0xbcb0, (q15_t)0x6cd1, (q15_t)0xbc9b, + (q15_t)0x6cc4, (q15_t)0xbc85, (q15_t)0x6cb7, (q15_t)0xbc70, (q15_t)0x6ca9, (q15_t)0xbc5b, (q15_t)0x6c9c, (q15_t)0xbc45, + (q15_t)0x6c8f, (q15_t)0xbc30, (q15_t)0x6c81, (q15_t)0xbc1b, (q15_t)0x6c74, (q15_t)0xbc05, (q15_t)0x6c67, (q15_t)0xbbf0, + (q15_t)0x6c59, (q15_t)0xbbdb, (q15_t)0x6c4c, (q15_t)0xbbc5, (q15_t)0x6c3f, (q15_t)0xbbb0, (q15_t)0x6c31, (q15_t)0xbb9b, + (q15_t)0x6c24, (q15_t)0xbb86, (q15_t)0x6c16, (q15_t)0xbb70, (q15_t)0x6c09, (q15_t)0xbb5b, (q15_t)0x6bfb, (q15_t)0xbb46, + (q15_t)0x6bee, (q15_t)0xbb31, (q15_t)0x6be0, (q15_t)0xbb1c, (q15_t)0x6bd3, (q15_t)0xbb06, (q15_t)0x6bc5, (q15_t)0xbaf1, + (q15_t)0x6bb8, (q15_t)0xbadc, (q15_t)0x6baa, (q15_t)0xbac7, (q15_t)0x6b9c, (q15_t)0xbab2, (q15_t)0x6b8f, (q15_t)0xba9d, + (q15_t)0x6b81, (q15_t)0xba88, (q15_t)0x6b73, (q15_t)0xba73, (q15_t)0x6b66, (q15_t)0xba5d, (q15_t)0x6b58, (q15_t)0xba48, + (q15_t)0x6b4a, (q15_t)0xba33, (q15_t)0x6b3d, (q15_t)0xba1e, (q15_t)0x6b2f, (q15_t)0xba09, (q15_t)0x6b21, (q15_t)0xb9f4, + (q15_t)0x6b13, (q15_t)0xb9df, (q15_t)0x6b06, (q15_t)0xb9ca, (q15_t)0x6af8, (q15_t)0xb9b5, (q15_t)0x6aea, (q15_t)0xb9a0, + (q15_t)0x6adc, (q15_t)0xb98b, (q15_t)0x6ace, (q15_t)0xb976, (q15_t)0x6ac1, (q15_t)0xb961, (q15_t)0x6ab3, (q15_t)0xb94c, + (q15_t)0x6aa5, (q15_t)0xb937, (q15_t)0x6a97, (q15_t)0xb922, (q15_t)0x6a89, (q15_t)0xb90d, (q15_t)0x6a7b, (q15_t)0xb8f8, + (q15_t)0x6a6d, (q15_t)0xb8e4, (q15_t)0x6a5f, (q15_t)0xb8cf, (q15_t)0x6a51, (q15_t)0xb8ba, (q15_t)0x6a43, (q15_t)0xb8a5, + (q15_t)0x6a35, (q15_t)0xb890, (q15_t)0x6a27, (q15_t)0xb87b, (q15_t)0x6a19, (q15_t)0xb866, (q15_t)0x6a0b, (q15_t)0xb852, + (q15_t)0x69fd, (q15_t)0xb83d, (q15_t)0x69ef, (q15_t)0xb828, (q15_t)0x69e1, (q15_t)0xb813, (q15_t)0x69d3, (q15_t)0xb7fe, + (q15_t)0x69c4, (q15_t)0xb7ea, (q15_t)0x69b6, (q15_t)0xb7d5, (q15_t)0x69a8, (q15_t)0xb7c0, (q15_t)0x699a, (q15_t)0xb7ab, + (q15_t)0x698c, (q15_t)0xb797, (q15_t)0x697d, (q15_t)0xb782, (q15_t)0x696f, (q15_t)0xb76d, (q15_t)0x6961, (q15_t)0xb758, + (q15_t)0x6953, (q15_t)0xb744, (q15_t)0x6944, (q15_t)0xb72f, (q15_t)0x6936, (q15_t)0xb71a, (q15_t)0x6928, (q15_t)0xb706, + (q15_t)0x6919, (q15_t)0xb6f1, (q15_t)0x690b, (q15_t)0xb6dd, (q15_t)0x68fd, (q15_t)0xb6c8, (q15_t)0x68ee, (q15_t)0xb6b3, + (q15_t)0x68e0, (q15_t)0xb69f, (q15_t)0x68d1, (q15_t)0xb68a, (q15_t)0x68c3, (q15_t)0xb676, (q15_t)0x68b5, (q15_t)0xb661, + (q15_t)0x68a6, (q15_t)0xb64c, (q15_t)0x6898, (q15_t)0xb638, (q15_t)0x6889, (q15_t)0xb623, (q15_t)0x687b, (q15_t)0xb60f, + (q15_t)0x686c, (q15_t)0xb5fa, (q15_t)0x685e, (q15_t)0xb5e6, (q15_t)0x684f, (q15_t)0xb5d1, (q15_t)0x6840, (q15_t)0xb5bd, + (q15_t)0x6832, (q15_t)0xb5a8, (q15_t)0x6823, (q15_t)0xb594, (q15_t)0x6815, (q15_t)0xb57f, (q15_t)0x6806, (q15_t)0xb56b, + (q15_t)0x67f7, (q15_t)0xb557, (q15_t)0x67e9, (q15_t)0xb542, (q15_t)0x67da, (q15_t)0xb52e, (q15_t)0x67cb, (q15_t)0xb519, + (q15_t)0x67bd, (q15_t)0xb505, (q15_t)0x67ae, (q15_t)0xb4f1, (q15_t)0x679f, (q15_t)0xb4dc, (q15_t)0x6790, (q15_t)0xb4c8, + (q15_t)0x6782, (q15_t)0xb4b4, (q15_t)0x6773, (q15_t)0xb49f, (q15_t)0x6764, (q15_t)0xb48b, (q15_t)0x6755, (q15_t)0xb477, + (q15_t)0x6746, (q15_t)0xb462, (q15_t)0x6737, (q15_t)0xb44e, (q15_t)0x6729, (q15_t)0xb43a, (q15_t)0x671a, (q15_t)0xb426, + (q15_t)0x670b, (q15_t)0xb411, (q15_t)0x66fc, (q15_t)0xb3fd, (q15_t)0x66ed, (q15_t)0xb3e9, (q15_t)0x66de, (q15_t)0xb3d5, + (q15_t)0x66cf, (q15_t)0xb3c1, (q15_t)0x66c0, (q15_t)0xb3ac, (q15_t)0x66b1, (q15_t)0xb398, (q15_t)0x66a2, (q15_t)0xb384, + (q15_t)0x6693, (q15_t)0xb370, (q15_t)0x6684, (q15_t)0xb35c, (q15_t)0x6675, (q15_t)0xb348, (q15_t)0x6666, (q15_t)0xb334, + (q15_t)0x6657, (q15_t)0xb31f, (q15_t)0x6648, (q15_t)0xb30b, (q15_t)0x6639, (q15_t)0xb2f7, (q15_t)0x6629, (q15_t)0xb2e3, + (q15_t)0x661a, (q15_t)0xb2cf, (q15_t)0x660b, (q15_t)0xb2bb, (q15_t)0x65fc, (q15_t)0xb2a7, (q15_t)0x65ed, (q15_t)0xb293, + (q15_t)0x65dd, (q15_t)0xb27f, (q15_t)0x65ce, (q15_t)0xb26b, (q15_t)0x65bf, (q15_t)0xb257, (q15_t)0x65b0, (q15_t)0xb243, + (q15_t)0x65a0, (q15_t)0xb22f, (q15_t)0x6591, (q15_t)0xb21b, (q15_t)0x6582, (q15_t)0xb207, (q15_t)0x6573, (q15_t)0xb1f3, + (q15_t)0x6563, (q15_t)0xb1df, (q15_t)0x6554, (q15_t)0xb1cc, (q15_t)0x6545, (q15_t)0xb1b8, (q15_t)0x6535, (q15_t)0xb1a4, + (q15_t)0x6526, (q15_t)0xb190, (q15_t)0x6516, (q15_t)0xb17c, (q15_t)0x6507, (q15_t)0xb168, (q15_t)0x64f7, (q15_t)0xb154, + (q15_t)0x64e8, (q15_t)0xb141, (q15_t)0x64d9, (q15_t)0xb12d, (q15_t)0x64c9, (q15_t)0xb119, (q15_t)0x64ba, (q15_t)0xb105, + (q15_t)0x64aa, (q15_t)0xb0f1, (q15_t)0x649b, (q15_t)0xb0de, (q15_t)0x648b, (q15_t)0xb0ca, (q15_t)0x647b, (q15_t)0xb0b6, + (q15_t)0x646c, (q15_t)0xb0a2, (q15_t)0x645c, (q15_t)0xb08f, (q15_t)0x644d, (q15_t)0xb07b, (q15_t)0x643d, (q15_t)0xb067, + (q15_t)0x642d, (q15_t)0xb054, (q15_t)0x641e, (q15_t)0xb040, (q15_t)0x640e, (q15_t)0xb02c, (q15_t)0x63fe, (q15_t)0xb019, + (q15_t)0x63ef, (q15_t)0xb005, (q15_t)0x63df, (q15_t)0xaff1, (q15_t)0x63cf, (q15_t)0xafde, (q15_t)0x63c0, (q15_t)0xafca, + (q15_t)0x63b0, (q15_t)0xafb7, (q15_t)0x63a0, (q15_t)0xafa3, (q15_t)0x6390, (q15_t)0xaf90, (q15_t)0x6380, (q15_t)0xaf7c, + (q15_t)0x6371, (q15_t)0xaf69, (q15_t)0x6361, (q15_t)0xaf55, (q15_t)0x6351, (q15_t)0xaf41, (q15_t)0x6341, (q15_t)0xaf2e, + (q15_t)0x6331, (q15_t)0xaf1b, (q15_t)0x6321, (q15_t)0xaf07, (q15_t)0x6311, (q15_t)0xaef4, (q15_t)0x6301, (q15_t)0xaee0, + (q15_t)0x62f2, (q15_t)0xaecd, (q15_t)0x62e2, (q15_t)0xaeb9, (q15_t)0x62d2, (q15_t)0xaea6, (q15_t)0x62c2, (q15_t)0xae92, + (q15_t)0x62b2, (q15_t)0xae7f, (q15_t)0x62a2, (q15_t)0xae6c, (q15_t)0x6292, (q15_t)0xae58, (q15_t)0x6282, (q15_t)0xae45, + (q15_t)0x6271, (q15_t)0xae32, (q15_t)0x6261, (q15_t)0xae1e, (q15_t)0x6251, (q15_t)0xae0b, (q15_t)0x6241, (q15_t)0xadf8, + (q15_t)0x6231, (q15_t)0xade4, (q15_t)0x6221, (q15_t)0xadd1, (q15_t)0x6211, (q15_t)0xadbe, (q15_t)0x6201, (q15_t)0xadab, + (q15_t)0x61f1, (q15_t)0xad97, (q15_t)0x61e0, (q15_t)0xad84, (q15_t)0x61d0, (q15_t)0xad71, (q15_t)0x61c0, (q15_t)0xad5e, + (q15_t)0x61b0, (q15_t)0xad4b, (q15_t)0x619f, (q15_t)0xad37, (q15_t)0x618f, (q15_t)0xad24, (q15_t)0x617f, (q15_t)0xad11, + (q15_t)0x616f, (q15_t)0xacfe, (q15_t)0x615e, (q15_t)0xaceb, (q15_t)0x614e, (q15_t)0xacd8, (q15_t)0x613e, (q15_t)0xacc5, + (q15_t)0x612d, (q15_t)0xacb2, (q15_t)0x611d, (q15_t)0xac9e, (q15_t)0x610d, (q15_t)0xac8b, (q15_t)0x60fc, (q15_t)0xac78, + (q15_t)0x60ec, (q15_t)0xac65, (q15_t)0x60db, (q15_t)0xac52, (q15_t)0x60cb, (q15_t)0xac3f, (q15_t)0x60ba, (q15_t)0xac2c, + (q15_t)0x60aa, (q15_t)0xac19, (q15_t)0x6099, (q15_t)0xac06, (q15_t)0x6089, (q15_t)0xabf3, (q15_t)0x6078, (q15_t)0xabe0, + (q15_t)0x6068, (q15_t)0xabcd, (q15_t)0x6057, (q15_t)0xabbb, (q15_t)0x6047, (q15_t)0xaba8, (q15_t)0x6036, (q15_t)0xab95, + (q15_t)0x6026, (q15_t)0xab82, (q15_t)0x6015, (q15_t)0xab6f, (q15_t)0x6004, (q15_t)0xab5c, (q15_t)0x5ff4, (q15_t)0xab49, + (q15_t)0x5fe3, (q15_t)0xab36, (q15_t)0x5fd3, (q15_t)0xab24, (q15_t)0x5fc2, (q15_t)0xab11, (q15_t)0x5fb1, (q15_t)0xaafe, + (q15_t)0x5fa0, (q15_t)0xaaeb, (q15_t)0x5f90, (q15_t)0xaad8, (q15_t)0x5f7f, (q15_t)0xaac6, (q15_t)0x5f6e, (q15_t)0xaab3, + (q15_t)0x5f5e, (q15_t)0xaaa0, (q15_t)0x5f4d, (q15_t)0xaa8e, (q15_t)0x5f3c, (q15_t)0xaa7b, (q15_t)0x5f2b, (q15_t)0xaa68, + (q15_t)0x5f1a, (q15_t)0xaa55, (q15_t)0x5f0a, (q15_t)0xaa43, (q15_t)0x5ef9, (q15_t)0xaa30, (q15_t)0x5ee8, (q15_t)0xaa1d, + (q15_t)0x5ed7, (q15_t)0xaa0b, (q15_t)0x5ec6, (q15_t)0xa9f8, (q15_t)0x5eb5, (q15_t)0xa9e6, (q15_t)0x5ea4, (q15_t)0xa9d3, + (q15_t)0x5e93, (q15_t)0xa9c0, (q15_t)0x5e82, (q15_t)0xa9ae, (q15_t)0x5e71, (q15_t)0xa99b, (q15_t)0x5e60, (q15_t)0xa989, + (q15_t)0x5e50, (q15_t)0xa976, (q15_t)0x5e3f, (q15_t)0xa964, (q15_t)0x5e2d, (q15_t)0xa951, (q15_t)0x5e1c, (q15_t)0xa93f, + (q15_t)0x5e0b, (q15_t)0xa92c, (q15_t)0x5dfa, (q15_t)0xa91a, (q15_t)0x5de9, (q15_t)0xa907, (q15_t)0x5dd8, (q15_t)0xa8f5, + (q15_t)0x5dc7, (q15_t)0xa8e3, (q15_t)0x5db6, (q15_t)0xa8d0, (q15_t)0x5da5, (q15_t)0xa8be, (q15_t)0x5d94, (q15_t)0xa8ab, + (q15_t)0x5d83, (q15_t)0xa899, (q15_t)0x5d71, (q15_t)0xa887, (q15_t)0x5d60, (q15_t)0xa874, (q15_t)0x5d4f, (q15_t)0xa862, + (q15_t)0x5d3e, (q15_t)0xa850, (q15_t)0x5d2d, (q15_t)0xa83d, (q15_t)0x5d1b, (q15_t)0xa82b, (q15_t)0x5d0a, (q15_t)0xa819, + (q15_t)0x5cf9, (q15_t)0xa807, (q15_t)0x5ce8, (q15_t)0xa7f4, (q15_t)0x5cd6, (q15_t)0xa7e2, (q15_t)0x5cc5, (q15_t)0xa7d0, + (q15_t)0x5cb4, (q15_t)0xa7be, (q15_t)0x5ca2, (q15_t)0xa7ab, (q15_t)0x5c91, (q15_t)0xa799, (q15_t)0x5c80, (q15_t)0xa787, + (q15_t)0x5c6e, (q15_t)0xa775, (q15_t)0x5c5d, (q15_t)0xa763, (q15_t)0x5c4b, (q15_t)0xa751, (q15_t)0x5c3a, (q15_t)0xa73f, + (q15_t)0x5c29, (q15_t)0xa72c, (q15_t)0x5c17, (q15_t)0xa71a, (q15_t)0x5c06, (q15_t)0xa708, (q15_t)0x5bf4, (q15_t)0xa6f6, + (q15_t)0x5be3, (q15_t)0xa6e4, (q15_t)0x5bd1, (q15_t)0xa6d2, (q15_t)0x5bc0, (q15_t)0xa6c0, (q15_t)0x5bae, (q15_t)0xa6ae, + (q15_t)0x5b9d, (q15_t)0xa69c, (q15_t)0x5b8b, (q15_t)0xa68a, (q15_t)0x5b79, (q15_t)0xa678, (q15_t)0x5b68, (q15_t)0xa666, + (q15_t)0x5b56, (q15_t)0xa654, (q15_t)0x5b45, (q15_t)0xa642, (q15_t)0x5b33, (q15_t)0xa630, (q15_t)0x5b21, (q15_t)0xa61f, + (q15_t)0x5b10, (q15_t)0xa60d, (q15_t)0x5afe, (q15_t)0xa5fb, (q15_t)0x5aec, (q15_t)0xa5e9, (q15_t)0x5adb, (q15_t)0xa5d7, + (q15_t)0x5ac9, (q15_t)0xa5c5, (q15_t)0x5ab7, (q15_t)0xa5b3, (q15_t)0x5aa5, (q15_t)0xa5a2, (q15_t)0x5a94, (q15_t)0xa590, + (q15_t)0x5a82, (q15_t)0xa57e, (q15_t)0x5a70, (q15_t)0xa56c, (q15_t)0x5a5e, (q15_t)0xa55b, (q15_t)0x5a4d, (q15_t)0xa549, + (q15_t)0x5a3b, (q15_t)0xa537, (q15_t)0x5a29, (q15_t)0xa525, (q15_t)0x5a17, (q15_t)0xa514, (q15_t)0x5a05, (q15_t)0xa502, + (q15_t)0x59f3, (q15_t)0xa4f0, (q15_t)0x59e1, (q15_t)0xa4df, (q15_t)0x59d0, (q15_t)0xa4cd, (q15_t)0x59be, (q15_t)0xa4bb, + (q15_t)0x59ac, (q15_t)0xa4aa, (q15_t)0x599a, (q15_t)0xa498, (q15_t)0x5988, (q15_t)0xa487, (q15_t)0x5976, (q15_t)0xa475, + (q15_t)0x5964, (q15_t)0xa463, (q15_t)0x5952, (q15_t)0xa452, (q15_t)0x5940, (q15_t)0xa440, (q15_t)0x592e, (q15_t)0xa42f, + (q15_t)0x591c, (q15_t)0xa41d, (q15_t)0x590a, (q15_t)0xa40c, (q15_t)0x58f8, (q15_t)0xa3fa, (q15_t)0x58e6, (q15_t)0xa3e9, + (q15_t)0x58d4, (q15_t)0xa3d7, (q15_t)0x58c1, (q15_t)0xa3c6, (q15_t)0x58af, (q15_t)0xa3b5, (q15_t)0x589d, (q15_t)0xa3a3, + (q15_t)0x588b, (q15_t)0xa392, (q15_t)0x5879, (q15_t)0xa380, (q15_t)0x5867, (q15_t)0xa36f, (q15_t)0x5855, (q15_t)0xa35e, + (q15_t)0x5842, (q15_t)0xa34c, (q15_t)0x5830, (q15_t)0xa33b, (q15_t)0x581e, (q15_t)0xa32a, (q15_t)0x580c, (q15_t)0xa318, + (q15_t)0x57f9, (q15_t)0xa307, (q15_t)0x57e7, (q15_t)0xa2f6, (q15_t)0x57d5, (q15_t)0xa2e5, (q15_t)0x57c3, (q15_t)0xa2d3, + (q15_t)0x57b0, (q15_t)0xa2c2, (q15_t)0x579e, (q15_t)0xa2b1, (q15_t)0x578c, (q15_t)0xa2a0, (q15_t)0x5779, (q15_t)0xa28f, + (q15_t)0x5767, (q15_t)0xa27d, (q15_t)0x5755, (q15_t)0xa26c, (q15_t)0x5742, (q15_t)0xa25b, (q15_t)0x5730, (q15_t)0xa24a, + (q15_t)0x571d, (q15_t)0xa239, (q15_t)0x570b, (q15_t)0xa228, (q15_t)0x56f9, (q15_t)0xa217, (q15_t)0x56e6, (q15_t)0xa206, + (q15_t)0x56d4, (q15_t)0xa1f5, (q15_t)0x56c1, (q15_t)0xa1e4, (q15_t)0x56af, (q15_t)0xa1d3, (q15_t)0x569c, (q15_t)0xa1c1, + (q15_t)0x568a, (q15_t)0xa1b0, (q15_t)0x5677, (q15_t)0xa1a0, (q15_t)0x5665, (q15_t)0xa18f, (q15_t)0x5652, (q15_t)0xa17e, + (q15_t)0x5640, (q15_t)0xa16d, (q15_t)0x562d, (q15_t)0xa15c, (q15_t)0x561a, (q15_t)0xa14b, (q15_t)0x5608, (q15_t)0xa13a, + (q15_t)0x55f5, (q15_t)0xa129, (q15_t)0x55e3, (q15_t)0xa118, (q15_t)0x55d0, (q15_t)0xa107, (q15_t)0x55bd, (q15_t)0xa0f6, + (q15_t)0x55ab, (q15_t)0xa0e6, (q15_t)0x5598, (q15_t)0xa0d5, (q15_t)0x5585, (q15_t)0xa0c4, (q15_t)0x5572, (q15_t)0xa0b3, + (q15_t)0x5560, (q15_t)0xa0a2, (q15_t)0x554d, (q15_t)0xa092, (q15_t)0x553a, (q15_t)0xa081, (q15_t)0x5528, (q15_t)0xa070, + (q15_t)0x5515, (q15_t)0xa060, (q15_t)0x5502, (q15_t)0xa04f, (q15_t)0x54ef, (q15_t)0xa03e, (q15_t)0x54dc, (q15_t)0xa02d, + (q15_t)0x54ca, (q15_t)0xa01d, (q15_t)0x54b7, (q15_t)0xa00c, (q15_t)0x54a4, (q15_t)0x9ffc, (q15_t)0x5491, (q15_t)0x9feb, + (q15_t)0x547e, (q15_t)0x9fda, (q15_t)0x546b, (q15_t)0x9fca, (q15_t)0x5458, (q15_t)0x9fb9, (q15_t)0x5445, (q15_t)0x9fa9, + (q15_t)0x5433, (q15_t)0x9f98, (q15_t)0x5420, (q15_t)0x9f88, (q15_t)0x540d, (q15_t)0x9f77, (q15_t)0x53fa, (q15_t)0x9f67, + (q15_t)0x53e7, (q15_t)0x9f56, (q15_t)0x53d4, (q15_t)0x9f46, (q15_t)0x53c1, (q15_t)0x9f35, (q15_t)0x53ae, (q15_t)0x9f25, + (q15_t)0x539b, (q15_t)0x9f14, (q15_t)0x5388, (q15_t)0x9f04, (q15_t)0x5375, (q15_t)0x9ef3, (q15_t)0x5362, (q15_t)0x9ee3, + (q15_t)0x534e, (q15_t)0x9ed3, (q15_t)0x533b, (q15_t)0x9ec2, (q15_t)0x5328, (q15_t)0x9eb2, (q15_t)0x5315, (q15_t)0x9ea2, + (q15_t)0x5302, (q15_t)0x9e91, (q15_t)0x52ef, (q15_t)0x9e81, (q15_t)0x52dc, (q15_t)0x9e71, (q15_t)0x52c9, (q15_t)0x9e61, + (q15_t)0x52b5, (q15_t)0x9e50, (q15_t)0x52a2, (q15_t)0x9e40, (q15_t)0x528f, (q15_t)0x9e30, (q15_t)0x527c, (q15_t)0x9e20, + (q15_t)0x5269, (q15_t)0x9e0f, (q15_t)0x5255, (q15_t)0x9dff, (q15_t)0x5242, (q15_t)0x9def, (q15_t)0x522f, (q15_t)0x9ddf, + (q15_t)0x521c, (q15_t)0x9dcf, (q15_t)0x5208, (q15_t)0x9dbf, (q15_t)0x51f5, (q15_t)0x9daf, (q15_t)0x51e2, (q15_t)0x9d9f, + (q15_t)0x51ce, (q15_t)0x9d8f, (q15_t)0x51bb, (q15_t)0x9d7e, (q15_t)0x51a8, (q15_t)0x9d6e, (q15_t)0x5194, (q15_t)0x9d5e, + (q15_t)0x5181, (q15_t)0x9d4e, (q15_t)0x516e, (q15_t)0x9d3e, (q15_t)0x515a, (q15_t)0x9d2e, (q15_t)0x5147, (q15_t)0x9d1e, + (q15_t)0x5133, (q15_t)0x9d0e, (q15_t)0x5120, (q15_t)0x9cff, (q15_t)0x510c, (q15_t)0x9cef, (q15_t)0x50f9, (q15_t)0x9cdf, + (q15_t)0x50e5, (q15_t)0x9ccf, (q15_t)0x50d2, (q15_t)0x9cbf, (q15_t)0x50bf, (q15_t)0x9caf, (q15_t)0x50ab, (q15_t)0x9c9f, + (q15_t)0x5097, (q15_t)0x9c8f, (q15_t)0x5084, (q15_t)0x9c80, (q15_t)0x5070, (q15_t)0x9c70, (q15_t)0x505d, (q15_t)0x9c60, + (q15_t)0x5049, (q15_t)0x9c50, (q15_t)0x5036, (q15_t)0x9c40, (q15_t)0x5022, (q15_t)0x9c31, (q15_t)0x500f, (q15_t)0x9c21, + (q15_t)0x4ffb, (q15_t)0x9c11, (q15_t)0x4fe7, (q15_t)0x9c02, (q15_t)0x4fd4, (q15_t)0x9bf2, (q15_t)0x4fc0, (q15_t)0x9be2, + (q15_t)0x4fac, (q15_t)0x9bd3, (q15_t)0x4f99, (q15_t)0x9bc3, (q15_t)0x4f85, (q15_t)0x9bb3, (q15_t)0x4f71, (q15_t)0x9ba4, + (q15_t)0x4f5e, (q15_t)0x9b94, (q15_t)0x4f4a, (q15_t)0x9b85, (q15_t)0x4f36, (q15_t)0x9b75, (q15_t)0x4f22, (q15_t)0x9b65, + (q15_t)0x4f0f, (q15_t)0x9b56, (q15_t)0x4efb, (q15_t)0x9b46, (q15_t)0x4ee7, (q15_t)0x9b37, (q15_t)0x4ed3, (q15_t)0x9b27, + (q15_t)0x4ebf, (q15_t)0x9b18, (q15_t)0x4eac, (q15_t)0x9b09, (q15_t)0x4e98, (q15_t)0x9af9, (q15_t)0x4e84, (q15_t)0x9aea, + (q15_t)0x4e70, (q15_t)0x9ada, (q15_t)0x4e5c, (q15_t)0x9acb, (q15_t)0x4e48, (q15_t)0x9abb, (q15_t)0x4e34, (q15_t)0x9aac, + (q15_t)0x4e21, (q15_t)0x9a9d, (q15_t)0x4e0d, (q15_t)0x9a8d, (q15_t)0x4df9, (q15_t)0x9a7e, (q15_t)0x4de5, (q15_t)0x9a6f, + (q15_t)0x4dd1, (q15_t)0x9a60, (q15_t)0x4dbd, (q15_t)0x9a50, (q15_t)0x4da9, (q15_t)0x9a41, (q15_t)0x4d95, (q15_t)0x9a32, + (q15_t)0x4d81, (q15_t)0x9a23, (q15_t)0x4d6d, (q15_t)0x9a13, (q15_t)0x4d59, (q15_t)0x9a04, (q15_t)0x4d45, (q15_t)0x99f5, + (q15_t)0x4d31, (q15_t)0x99e6, (q15_t)0x4d1d, (q15_t)0x99d7, (q15_t)0x4d09, (q15_t)0x99c7, (q15_t)0x4cf5, (q15_t)0x99b8, + (q15_t)0x4ce1, (q15_t)0x99a9, (q15_t)0x4ccc, (q15_t)0x999a, (q15_t)0x4cb8, (q15_t)0x998b, (q15_t)0x4ca4, (q15_t)0x997c, + (q15_t)0x4c90, (q15_t)0x996d, (q15_t)0x4c7c, (q15_t)0x995e, (q15_t)0x4c68, (q15_t)0x994f, (q15_t)0x4c54, (q15_t)0x9940, + (q15_t)0x4c3f, (q15_t)0x9931, (q15_t)0x4c2b, (q15_t)0x9922, (q15_t)0x4c17, (q15_t)0x9913, (q15_t)0x4c03, (q15_t)0x9904, + (q15_t)0x4bef, (q15_t)0x98f5, (q15_t)0x4bda, (q15_t)0x98e6, (q15_t)0x4bc6, (q15_t)0x98d7, (q15_t)0x4bb2, (q15_t)0x98c9, + (q15_t)0x4b9e, (q15_t)0x98ba, (q15_t)0x4b89, (q15_t)0x98ab, (q15_t)0x4b75, (q15_t)0x989c, (q15_t)0x4b61, (q15_t)0x988d, + (q15_t)0x4b4c, (q15_t)0x987e, (q15_t)0x4b38, (q15_t)0x9870, (q15_t)0x4b24, (q15_t)0x9861, (q15_t)0x4b0f, (q15_t)0x9852, + (q15_t)0x4afb, (q15_t)0x9843, (q15_t)0x4ae7, (q15_t)0x9835, (q15_t)0x4ad2, (q15_t)0x9826, (q15_t)0x4abe, (q15_t)0x9817, + (q15_t)0x4aa9, (q15_t)0x9809, (q15_t)0x4a95, (q15_t)0x97fa, (q15_t)0x4a81, (q15_t)0x97eb, (q15_t)0x4a6c, (q15_t)0x97dd, + (q15_t)0x4a58, (q15_t)0x97ce, (q15_t)0x4a43, (q15_t)0x97c0, (q15_t)0x4a2f, (q15_t)0x97b1, (q15_t)0x4a1a, (q15_t)0x97a2, + (q15_t)0x4a06, (q15_t)0x9794, (q15_t)0x49f1, (q15_t)0x9785, (q15_t)0x49dd, (q15_t)0x9777, (q15_t)0x49c8, (q15_t)0x9768, + (q15_t)0x49b4, (q15_t)0x975a, (q15_t)0x499f, (q15_t)0x974b, (q15_t)0x498a, (q15_t)0x973d, (q15_t)0x4976, (q15_t)0x972f, + (q15_t)0x4961, (q15_t)0x9720, (q15_t)0x494d, (q15_t)0x9712, (q15_t)0x4938, (q15_t)0x9703, (q15_t)0x4923, (q15_t)0x96f5, + (q15_t)0x490f, (q15_t)0x96e7, (q15_t)0x48fa, (q15_t)0x96d8, (q15_t)0x48e6, (q15_t)0x96ca, (q15_t)0x48d1, (q15_t)0x96bc, + (q15_t)0x48bc, (q15_t)0x96ad, (q15_t)0x48a8, (q15_t)0x969f, (q15_t)0x4893, (q15_t)0x9691, (q15_t)0x487e, (q15_t)0x9683, + (q15_t)0x4869, (q15_t)0x9674, (q15_t)0x4855, (q15_t)0x9666, (q15_t)0x4840, (q15_t)0x9658, (q15_t)0x482b, (q15_t)0x964a, + (q15_t)0x4816, (q15_t)0x963c, (q15_t)0x4802, (q15_t)0x962d, (q15_t)0x47ed, (q15_t)0x961f, (q15_t)0x47d8, (q15_t)0x9611, + (q15_t)0x47c3, (q15_t)0x9603, (q15_t)0x47ae, (q15_t)0x95f5, (q15_t)0x479a, (q15_t)0x95e7, (q15_t)0x4785, (q15_t)0x95d9, + (q15_t)0x4770, (q15_t)0x95cb, (q15_t)0x475b, (q15_t)0x95bd, (q15_t)0x4746, (q15_t)0x95af, (q15_t)0x4731, (q15_t)0x95a1, + (q15_t)0x471c, (q15_t)0x9593, (q15_t)0x4708, (q15_t)0x9585, (q15_t)0x46f3, (q15_t)0x9577, (q15_t)0x46de, (q15_t)0x9569, + (q15_t)0x46c9, (q15_t)0x955b, (q15_t)0x46b4, (q15_t)0x954d, (q15_t)0x469f, (q15_t)0x953f, (q15_t)0x468a, (q15_t)0x9532, + (q15_t)0x4675, (q15_t)0x9524, (q15_t)0x4660, (q15_t)0x9516, (q15_t)0x464b, (q15_t)0x9508, (q15_t)0x4636, (q15_t)0x94fa, + (q15_t)0x4621, (q15_t)0x94ed, (q15_t)0x460c, (q15_t)0x94df, (q15_t)0x45f7, (q15_t)0x94d1, (q15_t)0x45e2, (q15_t)0x94c3, + (q15_t)0x45cd, (q15_t)0x94b6, (q15_t)0x45b8, (q15_t)0x94a8, (q15_t)0x45a3, (q15_t)0x949a, (q15_t)0x458d, (q15_t)0x948d, + (q15_t)0x4578, (q15_t)0x947f, (q15_t)0x4563, (q15_t)0x9471, (q15_t)0x454e, (q15_t)0x9464, (q15_t)0x4539, (q15_t)0x9456, + (q15_t)0x4524, (q15_t)0x9448, (q15_t)0x450f, (q15_t)0x943b, (q15_t)0x44fa, (q15_t)0x942d, (q15_t)0x44e4, (q15_t)0x9420, + (q15_t)0x44cf, (q15_t)0x9412, (q15_t)0x44ba, (q15_t)0x9405, (q15_t)0x44a5, (q15_t)0x93f7, (q15_t)0x4490, (q15_t)0x93ea, + (q15_t)0x447a, (q15_t)0x93dc, (q15_t)0x4465, (q15_t)0x93cf, (q15_t)0x4450, (q15_t)0x93c1, (q15_t)0x443b, (q15_t)0x93b4, + (q15_t)0x4425, (q15_t)0x93a7, (q15_t)0x4410, (q15_t)0x9399, (q15_t)0x43fb, (q15_t)0x938c, (q15_t)0x43e5, (q15_t)0x937f, + (q15_t)0x43d0, (q15_t)0x9371, (q15_t)0x43bb, (q15_t)0x9364, (q15_t)0x43a5, (q15_t)0x9357, (q15_t)0x4390, (q15_t)0x9349, + (q15_t)0x437b, (q15_t)0x933c, (q15_t)0x4365, (q15_t)0x932f, (q15_t)0x4350, (q15_t)0x9322, (q15_t)0x433b, (q15_t)0x9314, + (q15_t)0x4325, (q15_t)0x9307, (q15_t)0x4310, (q15_t)0x92fa, (q15_t)0x42fa, (q15_t)0x92ed, (q15_t)0x42e5, (q15_t)0x92e0, + (q15_t)0x42d0, (q15_t)0x92d3, (q15_t)0x42ba, (q15_t)0x92c6, (q15_t)0x42a5, (q15_t)0x92b8, (q15_t)0x428f, (q15_t)0x92ab, + (q15_t)0x427a, (q15_t)0x929e, (q15_t)0x4264, (q15_t)0x9291, (q15_t)0x424f, (q15_t)0x9284, (q15_t)0x4239, (q15_t)0x9277, + (q15_t)0x4224, (q15_t)0x926a, (q15_t)0x420e, (q15_t)0x925d, (q15_t)0x41f9, (q15_t)0x9250, (q15_t)0x41e3, (q15_t)0x9243, + (q15_t)0x41ce, (q15_t)0x9236, (q15_t)0x41b8, (q15_t)0x922a, (q15_t)0x41a2, (q15_t)0x921d, (q15_t)0x418d, (q15_t)0x9210, + (q15_t)0x4177, (q15_t)0x9203, (q15_t)0x4162, (q15_t)0x91f6, (q15_t)0x414c, (q15_t)0x91e9, (q15_t)0x4136, (q15_t)0x91dc, + (q15_t)0x4121, (q15_t)0x91d0, (q15_t)0x410b, (q15_t)0x91c3, (q15_t)0x40f6, (q15_t)0x91b6, (q15_t)0x40e0, (q15_t)0x91a9, + (q15_t)0x40ca, (q15_t)0x919d, (q15_t)0x40b5, (q15_t)0x9190, (q15_t)0x409f, (q15_t)0x9183, (q15_t)0x4089, (q15_t)0x9177, + (q15_t)0x4073, (q15_t)0x916a, (q15_t)0x405e, (q15_t)0x915d, (q15_t)0x4048, (q15_t)0x9151, (q15_t)0x4032, (q15_t)0x9144, + (q15_t)0x401d, (q15_t)0x9137, (q15_t)0x4007, (q15_t)0x912b, (q15_t)0x3ff1, (q15_t)0x911e, (q15_t)0x3fdb, (q15_t)0x9112, + (q15_t)0x3fc5, (q15_t)0x9105, (q15_t)0x3fb0, (q15_t)0x90f9, (q15_t)0x3f9a, (q15_t)0x90ec, (q15_t)0x3f84, (q15_t)0x90e0, + (q15_t)0x3f6e, (q15_t)0x90d3, (q15_t)0x3f58, (q15_t)0x90c7, (q15_t)0x3f43, (q15_t)0x90ba, (q15_t)0x3f2d, (q15_t)0x90ae, + (q15_t)0x3f17, (q15_t)0x90a1, (q15_t)0x3f01, (q15_t)0x9095, (q15_t)0x3eeb, (q15_t)0x9089, (q15_t)0x3ed5, (q15_t)0x907c, + (q15_t)0x3ebf, (q15_t)0x9070, (q15_t)0x3ea9, (q15_t)0x9064, (q15_t)0x3e93, (q15_t)0x9057, (q15_t)0x3e7d, (q15_t)0x904b, + (q15_t)0x3e68, (q15_t)0x903f, (q15_t)0x3e52, (q15_t)0x9033, (q15_t)0x3e3c, (q15_t)0x9026, (q15_t)0x3e26, (q15_t)0x901a, + (q15_t)0x3e10, (q15_t)0x900e, (q15_t)0x3dfa, (q15_t)0x9002, (q15_t)0x3de4, (q15_t)0x8ff6, (q15_t)0x3dce, (q15_t)0x8fea, + (q15_t)0x3db8, (q15_t)0x8fdd, (q15_t)0x3da2, (q15_t)0x8fd1, (q15_t)0x3d8c, (q15_t)0x8fc5, (q15_t)0x3d76, (q15_t)0x8fb9, + (q15_t)0x3d60, (q15_t)0x8fad, (q15_t)0x3d49, (q15_t)0x8fa1, (q15_t)0x3d33, (q15_t)0x8f95, (q15_t)0x3d1d, (q15_t)0x8f89, + (q15_t)0x3d07, (q15_t)0x8f7d, (q15_t)0x3cf1, (q15_t)0x8f71, (q15_t)0x3cdb, (q15_t)0x8f65, (q15_t)0x3cc5, (q15_t)0x8f59, + (q15_t)0x3caf, (q15_t)0x8f4d, (q15_t)0x3c99, (q15_t)0x8f41, (q15_t)0x3c83, (q15_t)0x8f35, (q15_t)0x3c6c, (q15_t)0x8f2a, + (q15_t)0x3c56, (q15_t)0x8f1e, (q15_t)0x3c40, (q15_t)0x8f12, (q15_t)0x3c2a, (q15_t)0x8f06, (q15_t)0x3c14, (q15_t)0x8efa, + (q15_t)0x3bfd, (q15_t)0x8eee, (q15_t)0x3be7, (q15_t)0x8ee3, (q15_t)0x3bd1, (q15_t)0x8ed7, (q15_t)0x3bbb, (q15_t)0x8ecb, + (q15_t)0x3ba5, (q15_t)0x8ebf, (q15_t)0x3b8e, (q15_t)0x8eb4, (q15_t)0x3b78, (q15_t)0x8ea8, (q15_t)0x3b62, (q15_t)0x8e9c, + (q15_t)0x3b4c, (q15_t)0x8e91, (q15_t)0x3b35, (q15_t)0x8e85, (q15_t)0x3b1f, (q15_t)0x8e7a, (q15_t)0x3b09, (q15_t)0x8e6e, + (q15_t)0x3af2, (q15_t)0x8e62, (q15_t)0x3adc, (q15_t)0x8e57, (q15_t)0x3ac6, (q15_t)0x8e4b, (q15_t)0x3aaf, (q15_t)0x8e40, + (q15_t)0x3a99, (q15_t)0x8e34, (q15_t)0x3a83, (q15_t)0x8e29, (q15_t)0x3a6c, (q15_t)0x8e1d, (q15_t)0x3a56, (q15_t)0x8e12, + (q15_t)0x3a40, (q15_t)0x8e06, (q15_t)0x3a29, (q15_t)0x8dfb, (q15_t)0x3a13, (q15_t)0x8def, (q15_t)0x39fd, (q15_t)0x8de4, + (q15_t)0x39e6, (q15_t)0x8dd9, (q15_t)0x39d0, (q15_t)0x8dcd, (q15_t)0x39b9, (q15_t)0x8dc2, (q15_t)0x39a3, (q15_t)0x8db7, + (q15_t)0x398c, (q15_t)0x8dab, (q15_t)0x3976, (q15_t)0x8da0, (q15_t)0x395f, (q15_t)0x8d95, (q15_t)0x3949, (q15_t)0x8d8a, + (q15_t)0x3932, (q15_t)0x8d7e, (q15_t)0x391c, (q15_t)0x8d73, (q15_t)0x3906, (q15_t)0x8d68, (q15_t)0x38ef, (q15_t)0x8d5d, + (q15_t)0x38d8, (q15_t)0x8d51, (q15_t)0x38c2, (q15_t)0x8d46, (q15_t)0x38ab, (q15_t)0x8d3b, (q15_t)0x3895, (q15_t)0x8d30, + (q15_t)0x387e, (q15_t)0x8d25, (q15_t)0x3868, (q15_t)0x8d1a, (q15_t)0x3851, (q15_t)0x8d0f, (q15_t)0x383b, (q15_t)0x8d04, + (q15_t)0x3824, (q15_t)0x8cf9, (q15_t)0x380d, (q15_t)0x8cee, (q15_t)0x37f7, (q15_t)0x8ce3, (q15_t)0x37e0, (q15_t)0x8cd8, + (q15_t)0x37ca, (q15_t)0x8ccd, (q15_t)0x37b3, (q15_t)0x8cc2, (q15_t)0x379c, (q15_t)0x8cb7, (q15_t)0x3786, (q15_t)0x8cac, + (q15_t)0x376f, (q15_t)0x8ca1, (q15_t)0x3758, (q15_t)0x8c96, (q15_t)0x3742, (q15_t)0x8c8b, (q15_t)0x372b, (q15_t)0x8c81, + (q15_t)0x3714, (q15_t)0x8c76, (q15_t)0x36fe, (q15_t)0x8c6b, (q15_t)0x36e7, (q15_t)0x8c60, (q15_t)0x36d0, (q15_t)0x8c55, + (q15_t)0x36ba, (q15_t)0x8c4b, (q15_t)0x36a3, (q15_t)0x8c40, (q15_t)0x368c, (q15_t)0x8c35, (q15_t)0x3675, (q15_t)0x8c2a, + (q15_t)0x365f, (q15_t)0x8c20, (q15_t)0x3648, (q15_t)0x8c15, (q15_t)0x3631, (q15_t)0x8c0a, (q15_t)0x361a, (q15_t)0x8c00, + (q15_t)0x3604, (q15_t)0x8bf5, (q15_t)0x35ed, (q15_t)0x8beb, (q15_t)0x35d6, (q15_t)0x8be0, (q15_t)0x35bf, (q15_t)0x8bd5, + (q15_t)0x35a8, (q15_t)0x8bcb, (q15_t)0x3592, (q15_t)0x8bc0, (q15_t)0x357b, (q15_t)0x8bb6, (q15_t)0x3564, (q15_t)0x8bab, + (q15_t)0x354d, (q15_t)0x8ba1, (q15_t)0x3536, (q15_t)0x8b96, (q15_t)0x351f, (q15_t)0x8b8c, (q15_t)0x3508, (q15_t)0x8b82, + (q15_t)0x34f2, (q15_t)0x8b77, (q15_t)0x34db, (q15_t)0x8b6d, (q15_t)0x34c4, (q15_t)0x8b62, (q15_t)0x34ad, (q15_t)0x8b58, + (q15_t)0x3496, (q15_t)0x8b4e, (q15_t)0x347f, (q15_t)0x8b43, (q15_t)0x3468, (q15_t)0x8b39, (q15_t)0x3451, (q15_t)0x8b2f, + (q15_t)0x343a, (q15_t)0x8b25, (q15_t)0x3423, (q15_t)0x8b1a, (q15_t)0x340c, (q15_t)0x8b10, (q15_t)0x33f5, (q15_t)0x8b06, + (q15_t)0x33de, (q15_t)0x8afc, (q15_t)0x33c7, (q15_t)0x8af1, (q15_t)0x33b0, (q15_t)0x8ae7, (q15_t)0x3399, (q15_t)0x8add, + (q15_t)0x3382, (q15_t)0x8ad3, (q15_t)0x336b, (q15_t)0x8ac9, (q15_t)0x3354, (q15_t)0x8abf, (q15_t)0x333d, (q15_t)0x8ab5, + (q15_t)0x3326, (q15_t)0x8aab, (q15_t)0x330f, (q15_t)0x8aa1, (q15_t)0x32f8, (q15_t)0x8a97, (q15_t)0x32e1, (q15_t)0x8a8d, + (q15_t)0x32ca, (q15_t)0x8a83, (q15_t)0x32b3, (q15_t)0x8a79, (q15_t)0x329c, (q15_t)0x8a6f, (q15_t)0x3285, (q15_t)0x8a65, + (q15_t)0x326e, (q15_t)0x8a5b, (q15_t)0x3257, (q15_t)0x8a51, (q15_t)0x3240, (q15_t)0x8a47, (q15_t)0x3228, (q15_t)0x8a3d, + (q15_t)0x3211, (q15_t)0x8a34, (q15_t)0x31fa, (q15_t)0x8a2a, (q15_t)0x31e3, (q15_t)0x8a20, (q15_t)0x31cc, (q15_t)0x8a16, + (q15_t)0x31b5, (q15_t)0x8a0c, (q15_t)0x319e, (q15_t)0x8a03, (q15_t)0x3186, (q15_t)0x89f9, (q15_t)0x316f, (q15_t)0x89ef, + (q15_t)0x3158, (q15_t)0x89e5, (q15_t)0x3141, (q15_t)0x89dc, (q15_t)0x312a, (q15_t)0x89d2, (q15_t)0x3112, (q15_t)0x89c8, + (q15_t)0x30fb, (q15_t)0x89bf, (q15_t)0x30e4, (q15_t)0x89b5, (q15_t)0x30cd, (q15_t)0x89ac, (q15_t)0x30b6, (q15_t)0x89a2, + (q15_t)0x309e, (q15_t)0x8998, (q15_t)0x3087, (q15_t)0x898f, (q15_t)0x3070, (q15_t)0x8985, (q15_t)0x3059, (q15_t)0x897c, + (q15_t)0x3041, (q15_t)0x8972, (q15_t)0x302a, (q15_t)0x8969, (q15_t)0x3013, (q15_t)0x8960, (q15_t)0x2ffb, (q15_t)0x8956, + (q15_t)0x2fe4, (q15_t)0x894d, (q15_t)0x2fcd, (q15_t)0x8943, (q15_t)0x2fb5, (q15_t)0x893a, (q15_t)0x2f9e, (q15_t)0x8931, + (q15_t)0x2f87, (q15_t)0x8927, (q15_t)0x2f6f, (q15_t)0x891e, (q15_t)0x2f58, (q15_t)0x8915, (q15_t)0x2f41, (q15_t)0x890b, + (q15_t)0x2f29, (q15_t)0x8902, (q15_t)0x2f12, (q15_t)0x88f9, (q15_t)0x2efb, (q15_t)0x88f0, (q15_t)0x2ee3, (q15_t)0x88e6, + (q15_t)0x2ecc, (q15_t)0x88dd, (q15_t)0x2eb5, (q15_t)0x88d4, (q15_t)0x2e9d, (q15_t)0x88cb, (q15_t)0x2e86, (q15_t)0x88c2, + (q15_t)0x2e6e, (q15_t)0x88b9, (q15_t)0x2e57, (q15_t)0x88af, (q15_t)0x2e3f, (q15_t)0x88a6, (q15_t)0x2e28, (q15_t)0x889d, + (q15_t)0x2e11, (q15_t)0x8894, (q15_t)0x2df9, (q15_t)0x888b, (q15_t)0x2de2, (q15_t)0x8882, (q15_t)0x2dca, (q15_t)0x8879, + (q15_t)0x2db3, (q15_t)0x8870, (q15_t)0x2d9b, (q15_t)0x8867, (q15_t)0x2d84, (q15_t)0x885e, (q15_t)0x2d6c, (q15_t)0x8855, + (q15_t)0x2d55, (q15_t)0x884c, (q15_t)0x2d3d, (q15_t)0x8844, (q15_t)0x2d26, (q15_t)0x883b, (q15_t)0x2d0e, (q15_t)0x8832, + (q15_t)0x2cf7, (q15_t)0x8829, (q15_t)0x2cdf, (q15_t)0x8820, (q15_t)0x2cc8, (q15_t)0x8817, (q15_t)0x2cb0, (q15_t)0x880f, + (q15_t)0x2c98, (q15_t)0x8806, (q15_t)0x2c81, (q15_t)0x87fd, (q15_t)0x2c69, (q15_t)0x87f4, (q15_t)0x2c52, (q15_t)0x87ec, + (q15_t)0x2c3a, (q15_t)0x87e3, (q15_t)0x2c23, (q15_t)0x87da, (q15_t)0x2c0b, (q15_t)0x87d2, (q15_t)0x2bf3, (q15_t)0x87c9, + (q15_t)0x2bdc, (q15_t)0x87c0, (q15_t)0x2bc4, (q15_t)0x87b8, (q15_t)0x2bad, (q15_t)0x87af, (q15_t)0x2b95, (q15_t)0x87a7, + (q15_t)0x2b7d, (q15_t)0x879e, (q15_t)0x2b66, (q15_t)0x8795, (q15_t)0x2b4e, (q15_t)0x878d, (q15_t)0x2b36, (q15_t)0x8784, + (q15_t)0x2b1f, (q15_t)0x877c, (q15_t)0x2b07, (q15_t)0x8774, (q15_t)0x2aef, (q15_t)0x876b, (q15_t)0x2ad8, (q15_t)0x8763, + (q15_t)0x2ac0, (q15_t)0x875a, (q15_t)0x2aa8, (q15_t)0x8752, (q15_t)0x2a91, (q15_t)0x874a, (q15_t)0x2a79, (q15_t)0x8741, + (q15_t)0x2a61, (q15_t)0x8739, (q15_t)0x2a49, (q15_t)0x8731, (q15_t)0x2a32, (q15_t)0x8728, (q15_t)0x2a1a, (q15_t)0x8720, + (q15_t)0x2a02, (q15_t)0x8718, (q15_t)0x29eb, (q15_t)0x870f, (q15_t)0x29d3, (q15_t)0x8707, (q15_t)0x29bb, (q15_t)0x86ff, + (q15_t)0x29a3, (q15_t)0x86f7, (q15_t)0x298b, (q15_t)0x86ef, (q15_t)0x2974, (q15_t)0x86e7, (q15_t)0x295c, (q15_t)0x86de, + (q15_t)0x2944, (q15_t)0x86d6, (q15_t)0x292c, (q15_t)0x86ce, (q15_t)0x2915, (q15_t)0x86c6, (q15_t)0x28fd, (q15_t)0x86be, + (q15_t)0x28e5, (q15_t)0x86b6, (q15_t)0x28cd, (q15_t)0x86ae, (q15_t)0x28b5, (q15_t)0x86a6, (q15_t)0x289d, (q15_t)0x869e, + (q15_t)0x2886, (q15_t)0x8696, (q15_t)0x286e, (q15_t)0x868e, (q15_t)0x2856, (q15_t)0x8686, (q15_t)0x283e, (q15_t)0x867e, + (q15_t)0x2826, (q15_t)0x8676, (q15_t)0x280e, (q15_t)0x866e, (q15_t)0x27f6, (q15_t)0x8667, (q15_t)0x27df, (q15_t)0x865f, + (q15_t)0x27c7, (q15_t)0x8657, (q15_t)0x27af, (q15_t)0x864f, (q15_t)0x2797, (q15_t)0x8647, (q15_t)0x277f, (q15_t)0x8640, + (q15_t)0x2767, (q15_t)0x8638, (q15_t)0x274f, (q15_t)0x8630, (q15_t)0x2737, (q15_t)0x8628, (q15_t)0x271f, (q15_t)0x8621, + (q15_t)0x2707, (q15_t)0x8619, (q15_t)0x26ef, (q15_t)0x8611, (q15_t)0x26d8, (q15_t)0x860a, (q15_t)0x26c0, (q15_t)0x8602, + (q15_t)0x26a8, (q15_t)0x85fb, (q15_t)0x2690, (q15_t)0x85f3, (q15_t)0x2678, (q15_t)0x85eb, (q15_t)0x2660, (q15_t)0x85e4, + (q15_t)0x2648, (q15_t)0x85dc, (q15_t)0x2630, (q15_t)0x85d5, (q15_t)0x2618, (q15_t)0x85cd, (q15_t)0x2600, (q15_t)0x85c6, + (q15_t)0x25e8, (q15_t)0x85be, (q15_t)0x25d0, (q15_t)0x85b7, (q15_t)0x25b8, (q15_t)0x85b0, (q15_t)0x25a0, (q15_t)0x85a8, + (q15_t)0x2588, (q15_t)0x85a1, (q15_t)0x2570, (q15_t)0x8599, (q15_t)0x2558, (q15_t)0x8592, (q15_t)0x2540, (q15_t)0x858b, + (q15_t)0x2528, (q15_t)0x8583, (q15_t)0x250f, (q15_t)0x857c, (q15_t)0x24f7, (q15_t)0x8575, (q15_t)0x24df, (q15_t)0x856e, + (q15_t)0x24c7, (q15_t)0x8566, (q15_t)0x24af, (q15_t)0x855f, (q15_t)0x2497, (q15_t)0x8558, (q15_t)0x247f, (q15_t)0x8551, + (q15_t)0x2467, (q15_t)0x854a, (q15_t)0x244f, (q15_t)0x8543, (q15_t)0x2437, (q15_t)0x853b, (q15_t)0x241f, (q15_t)0x8534, + (q15_t)0x2407, (q15_t)0x852d, (q15_t)0x23ee, (q15_t)0x8526, (q15_t)0x23d6, (q15_t)0x851f, (q15_t)0x23be, (q15_t)0x8518, + (q15_t)0x23a6, (q15_t)0x8511, (q15_t)0x238e, (q15_t)0x850a, (q15_t)0x2376, (q15_t)0x8503, (q15_t)0x235e, (q15_t)0x84fc, + (q15_t)0x2345, (q15_t)0x84f5, (q15_t)0x232d, (q15_t)0x84ee, (q15_t)0x2315, (q15_t)0x84e7, (q15_t)0x22fd, (q15_t)0x84e1, + (q15_t)0x22e5, (q15_t)0x84da, (q15_t)0x22cd, (q15_t)0x84d3, (q15_t)0x22b4, (q15_t)0x84cc, (q15_t)0x229c, (q15_t)0x84c5, + (q15_t)0x2284, (q15_t)0x84be, (q15_t)0x226c, (q15_t)0x84b8, (q15_t)0x2254, (q15_t)0x84b1, (q15_t)0x223b, (q15_t)0x84aa, + (q15_t)0x2223, (q15_t)0x84a3, (q15_t)0x220b, (q15_t)0x849d, (q15_t)0x21f3, (q15_t)0x8496, (q15_t)0x21da, (q15_t)0x848f, + (q15_t)0x21c2, (q15_t)0x8489, (q15_t)0x21aa, (q15_t)0x8482, (q15_t)0x2192, (q15_t)0x847c, (q15_t)0x2179, (q15_t)0x8475, + (q15_t)0x2161, (q15_t)0x846e, (q15_t)0x2149, (q15_t)0x8468, (q15_t)0x2131, (q15_t)0x8461, (q15_t)0x2118, (q15_t)0x845b, + (q15_t)0x2100, (q15_t)0x8454, (q15_t)0x20e8, (q15_t)0x844e, (q15_t)0x20d0, (q15_t)0x8447, (q15_t)0x20b7, (q15_t)0x8441, + (q15_t)0x209f, (q15_t)0x843b, (q15_t)0x2087, (q15_t)0x8434, (q15_t)0x206e, (q15_t)0x842e, (q15_t)0x2056, (q15_t)0x8427, + (q15_t)0x203e, (q15_t)0x8421, (q15_t)0x2025, (q15_t)0x841b, (q15_t)0x200d, (q15_t)0x8415, (q15_t)0x1ff5, (q15_t)0x840e, + (q15_t)0x1fdc, (q15_t)0x8408, (q15_t)0x1fc4, (q15_t)0x8402, (q15_t)0x1fac, (q15_t)0x83fb, (q15_t)0x1f93, (q15_t)0x83f5, + (q15_t)0x1f7b, (q15_t)0x83ef, (q15_t)0x1f63, (q15_t)0x83e9, (q15_t)0x1f4a, (q15_t)0x83e3, (q15_t)0x1f32, (q15_t)0x83dd, + (q15_t)0x1f19, (q15_t)0x83d7, (q15_t)0x1f01, (q15_t)0x83d0, (q15_t)0x1ee9, (q15_t)0x83ca, (q15_t)0x1ed0, (q15_t)0x83c4, + (q15_t)0x1eb8, (q15_t)0x83be, (q15_t)0x1ea0, (q15_t)0x83b8, (q15_t)0x1e87, (q15_t)0x83b2, (q15_t)0x1e6f, (q15_t)0x83ac, + (q15_t)0x1e56, (q15_t)0x83a6, (q15_t)0x1e3e, (q15_t)0x83a0, (q15_t)0x1e25, (q15_t)0x839a, (q15_t)0x1e0d, (q15_t)0x8394, + (q15_t)0x1df5, (q15_t)0x838f, (q15_t)0x1ddc, (q15_t)0x8389, (q15_t)0x1dc4, (q15_t)0x8383, (q15_t)0x1dab, (q15_t)0x837d, + (q15_t)0x1d93, (q15_t)0x8377, (q15_t)0x1d7a, (q15_t)0x8371, (q15_t)0x1d62, (q15_t)0x836c, (q15_t)0x1d49, (q15_t)0x8366, + (q15_t)0x1d31, (q15_t)0x8360, (q15_t)0x1d18, (q15_t)0x835a, (q15_t)0x1d00, (q15_t)0x8355, (q15_t)0x1ce8, (q15_t)0x834f, + (q15_t)0x1ccf, (q15_t)0x8349, (q15_t)0x1cb7, (q15_t)0x8344, (q15_t)0x1c9e, (q15_t)0x833e, (q15_t)0x1c86, (q15_t)0x8338, + (q15_t)0x1c6d, (q15_t)0x8333, (q15_t)0x1c55, (q15_t)0x832d, (q15_t)0x1c3c, (q15_t)0x8328, (q15_t)0x1c24, (q15_t)0x8322, + (q15_t)0x1c0b, (q15_t)0x831d, (q15_t)0x1bf2, (q15_t)0x8317, (q15_t)0x1bda, (q15_t)0x8312, (q15_t)0x1bc1, (q15_t)0x830c, + (q15_t)0x1ba9, (q15_t)0x8307, (q15_t)0x1b90, (q15_t)0x8301, (q15_t)0x1b78, (q15_t)0x82fc, (q15_t)0x1b5f, (q15_t)0x82f7, + (q15_t)0x1b47, (q15_t)0x82f1, (q15_t)0x1b2e, (q15_t)0x82ec, (q15_t)0x1b16, (q15_t)0x82e7, (q15_t)0x1afd, (q15_t)0x82e1, + (q15_t)0x1ae4, (q15_t)0x82dc, (q15_t)0x1acc, (q15_t)0x82d7, (q15_t)0x1ab3, (q15_t)0x82d1, (q15_t)0x1a9b, (q15_t)0x82cc, + (q15_t)0x1a82, (q15_t)0x82c7, (q15_t)0x1a6a, (q15_t)0x82c2, (q15_t)0x1a51, (q15_t)0x82bd, (q15_t)0x1a38, (q15_t)0x82b7, + (q15_t)0x1a20, (q15_t)0x82b2, (q15_t)0x1a07, (q15_t)0x82ad, (q15_t)0x19ef, (q15_t)0x82a8, (q15_t)0x19d6, (q15_t)0x82a3, + (q15_t)0x19bd, (q15_t)0x829e, (q15_t)0x19a5, (q15_t)0x8299, (q15_t)0x198c, (q15_t)0x8294, (q15_t)0x1973, (q15_t)0x828f, + (q15_t)0x195b, (q15_t)0x828a, (q15_t)0x1942, (q15_t)0x8285, (q15_t)0x192a, (q15_t)0x8280, (q15_t)0x1911, (q15_t)0x827b, + (q15_t)0x18f8, (q15_t)0x8276, (q15_t)0x18e0, (q15_t)0x8271, (q15_t)0x18c7, (q15_t)0x826c, (q15_t)0x18ae, (q15_t)0x8268, + (q15_t)0x1896, (q15_t)0x8263, (q15_t)0x187d, (q15_t)0x825e, (q15_t)0x1864, (q15_t)0x8259, (q15_t)0x184c, (q15_t)0x8254, + (q15_t)0x1833, (q15_t)0x8250, (q15_t)0x181a, (q15_t)0x824b, (q15_t)0x1802, (q15_t)0x8246, (q15_t)0x17e9, (q15_t)0x8241, + (q15_t)0x17d0, (q15_t)0x823d, (q15_t)0x17b7, (q15_t)0x8238, (q15_t)0x179f, (q15_t)0x8233, (q15_t)0x1786, (q15_t)0x822f, + (q15_t)0x176d, (q15_t)0x822a, (q15_t)0x1755, (q15_t)0x8226, (q15_t)0x173c, (q15_t)0x8221, (q15_t)0x1723, (q15_t)0x821c, + (q15_t)0x170a, (q15_t)0x8218, (q15_t)0x16f2, (q15_t)0x8213, (q15_t)0x16d9, (q15_t)0x820f, (q15_t)0x16c0, (q15_t)0x820a, + (q15_t)0x16a8, (q15_t)0x8206, (q15_t)0x168f, (q15_t)0x8201, (q15_t)0x1676, (q15_t)0x81fd, (q15_t)0x165d, (q15_t)0x81f9, + (q15_t)0x1645, (q15_t)0x81f4, (q15_t)0x162c, (q15_t)0x81f0, (q15_t)0x1613, (q15_t)0x81ec, (q15_t)0x15fa, (q15_t)0x81e7, + (q15_t)0x15e2, (q15_t)0x81e3, (q15_t)0x15c9, (q15_t)0x81df, (q15_t)0x15b0, (q15_t)0x81da, (q15_t)0x1597, (q15_t)0x81d6, + (q15_t)0x157f, (q15_t)0x81d2, (q15_t)0x1566, (q15_t)0x81ce, (q15_t)0x154d, (q15_t)0x81c9, (q15_t)0x1534, (q15_t)0x81c5, + (q15_t)0x151b, (q15_t)0x81c1, (q15_t)0x1503, (q15_t)0x81bd, (q15_t)0x14ea, (q15_t)0x81b9, (q15_t)0x14d1, (q15_t)0x81b5, + (q15_t)0x14b8, (q15_t)0x81b1, (q15_t)0x149f, (q15_t)0x81ad, (q15_t)0x1487, (q15_t)0x81a9, (q15_t)0x146e, (q15_t)0x81a5, + (q15_t)0x1455, (q15_t)0x81a1, (q15_t)0x143c, (q15_t)0x819d, (q15_t)0x1423, (q15_t)0x8199, (q15_t)0x140b, (q15_t)0x8195, + (q15_t)0x13f2, (q15_t)0x8191, (q15_t)0x13d9, (q15_t)0x818d, (q15_t)0x13c0, (q15_t)0x8189, (q15_t)0x13a7, (q15_t)0x8185, + (q15_t)0x138e, (q15_t)0x8181, (q15_t)0x1376, (q15_t)0x817d, (q15_t)0x135d, (q15_t)0x817a, (q15_t)0x1344, (q15_t)0x8176, + (q15_t)0x132b, (q15_t)0x8172, (q15_t)0x1312, (q15_t)0x816e, (q15_t)0x12f9, (q15_t)0x816b, (q15_t)0x12e0, (q15_t)0x8167, + (q15_t)0x12c8, (q15_t)0x8163, (q15_t)0x12af, (q15_t)0x815f, (q15_t)0x1296, (q15_t)0x815c, (q15_t)0x127d, (q15_t)0x8158, + (q15_t)0x1264, (q15_t)0x8155, (q15_t)0x124b, (q15_t)0x8151, (q15_t)0x1232, (q15_t)0x814d, (q15_t)0x1219, (q15_t)0x814a, + (q15_t)0x1201, (q15_t)0x8146, (q15_t)0x11e8, (q15_t)0x8143, (q15_t)0x11cf, (q15_t)0x813f, (q15_t)0x11b6, (q15_t)0x813c, + (q15_t)0x119d, (q15_t)0x8138, (q15_t)0x1184, (q15_t)0x8135, (q15_t)0x116b, (q15_t)0x8131, (q15_t)0x1152, (q15_t)0x812e, + (q15_t)0x1139, (q15_t)0x812b, (q15_t)0x1121, (q15_t)0x8127, (q15_t)0x1108, (q15_t)0x8124, (q15_t)0x10ef, (q15_t)0x8121, + (q15_t)0x10d6, (q15_t)0x811d, (q15_t)0x10bd, (q15_t)0x811a, (q15_t)0x10a4, (q15_t)0x8117, (q15_t)0x108b, (q15_t)0x8113, + (q15_t)0x1072, (q15_t)0x8110, (q15_t)0x1059, (q15_t)0x810d, (q15_t)0x1040, (q15_t)0x810a, (q15_t)0x1027, (q15_t)0x8107, + (q15_t)0x100e, (q15_t)0x8103, (q15_t)0xff5, (q15_t)0x8100, (q15_t)0xfdd, (q15_t)0x80fd, (q15_t)0xfc4, (q15_t)0x80fa, + (q15_t)0xfab, (q15_t)0x80f7, (q15_t)0xf92, (q15_t)0x80f4, (q15_t)0xf79, (q15_t)0x80f1, (q15_t)0xf60, (q15_t)0x80ee, + (q15_t)0xf47, (q15_t)0x80eb, (q15_t)0xf2e, (q15_t)0x80e8, (q15_t)0xf15, (q15_t)0x80e5, (q15_t)0xefc, (q15_t)0x80e2, + (q15_t)0xee3, (q15_t)0x80df, (q15_t)0xeca, (q15_t)0x80dc, (q15_t)0xeb1, (q15_t)0x80d9, (q15_t)0xe98, (q15_t)0x80d6, + (q15_t)0xe7f, (q15_t)0x80d3, (q15_t)0xe66, (q15_t)0x80d1, (q15_t)0xe4d, (q15_t)0x80ce, (q15_t)0xe34, (q15_t)0x80cb, + (q15_t)0xe1b, (q15_t)0x80c8, (q15_t)0xe02, (q15_t)0x80c5, (q15_t)0xde9, (q15_t)0x80c3, (q15_t)0xdd0, (q15_t)0x80c0, + (q15_t)0xdb7, (q15_t)0x80bd, (q15_t)0xd9e, (q15_t)0x80bb, (q15_t)0xd85, (q15_t)0x80b8, (q15_t)0xd6c, (q15_t)0x80b5, + (q15_t)0xd53, (q15_t)0x80b3, (q15_t)0xd3a, (q15_t)0x80b0, (q15_t)0xd21, (q15_t)0x80ad, (q15_t)0xd08, (q15_t)0x80ab, + (q15_t)0xcef, (q15_t)0x80a8, (q15_t)0xcd6, (q15_t)0x80a6, (q15_t)0xcbd, (q15_t)0x80a3, (q15_t)0xca4, (q15_t)0x80a1, + (q15_t)0xc8b, (q15_t)0x809e, (q15_t)0xc72, (q15_t)0x809c, (q15_t)0xc59, (q15_t)0x8099, (q15_t)0xc40, (q15_t)0x8097, + (q15_t)0xc27, (q15_t)0x8095, (q15_t)0xc0e, (q15_t)0x8092, (q15_t)0xbf5, (q15_t)0x8090, (q15_t)0xbdc, (q15_t)0x808e, + (q15_t)0xbc3, (q15_t)0x808b, (q15_t)0xbaa, (q15_t)0x8089, (q15_t)0xb91, (q15_t)0x8087, (q15_t)0xb78, (q15_t)0x8084, + (q15_t)0xb5f, (q15_t)0x8082, (q15_t)0xb46, (q15_t)0x8080, (q15_t)0xb2d, (q15_t)0x807e, (q15_t)0xb14, (q15_t)0x807b, + (q15_t)0xafb, (q15_t)0x8079, (q15_t)0xae2, (q15_t)0x8077, (q15_t)0xac9, (q15_t)0x8075, (q15_t)0xab0, (q15_t)0x8073, + (q15_t)0xa97, (q15_t)0x8071, (q15_t)0xa7e, (q15_t)0x806f, (q15_t)0xa65, (q15_t)0x806d, (q15_t)0xa4c, (q15_t)0x806b, + (q15_t)0xa33, (q15_t)0x8069, (q15_t)0xa19, (q15_t)0x8067, (q15_t)0xa00, (q15_t)0x8065, (q15_t)0x9e7, (q15_t)0x8063, + (q15_t)0x9ce, (q15_t)0x8061, (q15_t)0x9b5, (q15_t)0x805f, (q15_t)0x99c, (q15_t)0x805d, (q15_t)0x983, (q15_t)0x805b, + (q15_t)0x96a, (q15_t)0x8059, (q15_t)0x951, (q15_t)0x8057, (q15_t)0x938, (q15_t)0x8056, (q15_t)0x91f, (q15_t)0x8054, + (q15_t)0x906, (q15_t)0x8052, (q15_t)0x8ed, (q15_t)0x8050, (q15_t)0x8d4, (q15_t)0x804f, (q15_t)0x8bb, (q15_t)0x804d, + (q15_t)0x8a2, (q15_t)0x804b, (q15_t)0x888, (q15_t)0x8049, (q15_t)0x86f, (q15_t)0x8048, (q15_t)0x856, (q15_t)0x8046, + (q15_t)0x83d, (q15_t)0x8044, (q15_t)0x824, (q15_t)0x8043, (q15_t)0x80b, (q15_t)0x8041, (q15_t)0x7f2, (q15_t)0x8040, + (q15_t)0x7d9, (q15_t)0x803e, (q15_t)0x7c0, (q15_t)0x803d, (q15_t)0x7a7, (q15_t)0x803b, (q15_t)0x78e, (q15_t)0x803a, + (q15_t)0x775, (q15_t)0x8038, (q15_t)0x75b, (q15_t)0x8037, (q15_t)0x742, (q15_t)0x8035, (q15_t)0x729, (q15_t)0x8034, + (q15_t)0x710, (q15_t)0x8032, (q15_t)0x6f7, (q15_t)0x8031, (q15_t)0x6de, (q15_t)0x8030, (q15_t)0x6c5, (q15_t)0x802e, + (q15_t)0x6ac, (q15_t)0x802d, (q15_t)0x693, (q15_t)0x802c, (q15_t)0x67a, (q15_t)0x802a, (q15_t)0x660, (q15_t)0x8029, + (q15_t)0x647, (q15_t)0x8028, (q15_t)0x62e, (q15_t)0x8027, (q15_t)0x615, (q15_t)0x8026, (q15_t)0x5fc, (q15_t)0x8024, + (q15_t)0x5e3, (q15_t)0x8023, (q15_t)0x5ca, (q15_t)0x8022, (q15_t)0x5b1, (q15_t)0x8021, (q15_t)0x598, (q15_t)0x8020, + (q15_t)0x57f, (q15_t)0x801f, (q15_t)0x565, (q15_t)0x801e, (q15_t)0x54c, (q15_t)0x801d, (q15_t)0x533, (q15_t)0x801c, + (q15_t)0x51a, (q15_t)0x801b, (q15_t)0x501, (q15_t)0x801a, (q15_t)0x4e8, (q15_t)0x8019, (q15_t)0x4cf, (q15_t)0x8018, + (q15_t)0x4b6, (q15_t)0x8017, (q15_t)0x49c, (q15_t)0x8016, (q15_t)0x483, (q15_t)0x8015, (q15_t)0x46a, (q15_t)0x8014, + (q15_t)0x451, (q15_t)0x8013, (q15_t)0x438, (q15_t)0x8012, (q15_t)0x41f, (q15_t)0x8012, (q15_t)0x406, (q15_t)0x8011, + (q15_t)0x3ed, (q15_t)0x8010, (q15_t)0x3d4, (q15_t)0x800f, (q15_t)0x3ba, (q15_t)0x800e, (q15_t)0x3a1, (q15_t)0x800e, + (q15_t)0x388, (q15_t)0x800d, (q15_t)0x36f, (q15_t)0x800c, (q15_t)0x356, (q15_t)0x800c, (q15_t)0x33d, (q15_t)0x800b, + (q15_t)0x324, (q15_t)0x800a, (q15_t)0x30b, (q15_t)0x800a, (q15_t)0x2f1, (q15_t)0x8009, (q15_t)0x2d8, (q15_t)0x8009, + (q15_t)0x2bf, (q15_t)0x8008, (q15_t)0x2a6, (q15_t)0x8008, (q15_t)0x28d, (q15_t)0x8007, (q15_t)0x274, (q15_t)0x8007, + (q15_t)0x25b, (q15_t)0x8006, (q15_t)0x242, (q15_t)0x8006, (q15_t)0x228, (q15_t)0x8005, (q15_t)0x20f, (q15_t)0x8005, + (q15_t)0x1f6, (q15_t)0x8004, (q15_t)0x1dd, (q15_t)0x8004, (q15_t)0x1c4, (q15_t)0x8004, (q15_t)0x1ab, (q15_t)0x8003, + (q15_t)0x192, (q15_t)0x8003, (q15_t)0x178, (q15_t)0x8003, (q15_t)0x15f, (q15_t)0x8002, (q15_t)0x146, (q15_t)0x8002, + (q15_t)0x12d, (q15_t)0x8002, (q15_t)0x114, (q15_t)0x8002, (q15_t)0xfb, (q15_t)0x8001, (q15_t)0xe2, (q15_t)0x8001, + (q15_t)0xc9, (q15_t)0x8001, (q15_t)0xaf, (q15_t)0x8001, (q15_t)0x96, (q15_t)0x8001, (q15_t)0x7d, (q15_t)0x8001, + (q15_t)0x64, (q15_t)0x8001, (q15_t)0x4b, (q15_t)0x8001, (q15_t)0x32, (q15_t)0x8001, (q15_t)0x19, (q15_t)0x8001 +}; + +static const q15_t ALIGN4 WeightsQ15_8192[16384] = { + (q15_t)0x7fff, (q15_t)0x0, (q15_t)0x7fff, (q15_t)0xfffa, (q15_t)0x7fff, (q15_t)0xfff4, (q15_t)0x7fff, (q15_t)0xffee, + (q15_t)0x7fff, (q15_t)0xffe7, (q15_t)0x7fff, (q15_t)0xffe1, (q15_t)0x7fff, (q15_t)0xffdb, (q15_t)0x7fff, (q15_t)0xffd5, + (q15_t)0x7fff, (q15_t)0xffce, (q15_t)0x7fff, (q15_t)0xffc8, (q15_t)0x7fff, (q15_t)0xffc2, (q15_t)0x7fff, (q15_t)0xffbb, + (q15_t)0x7fff, (q15_t)0xffb5, (q15_t)0x7fff, (q15_t)0xffaf, (q15_t)0x7fff, (q15_t)0xffa9, (q15_t)0x7fff, (q15_t)0xffa2, + (q15_t)0x7fff, (q15_t)0xff9c, (q15_t)0x7fff, (q15_t)0xff96, (q15_t)0x7fff, (q15_t)0xff8f, (q15_t)0x7fff, (q15_t)0xff89, + (q15_t)0x7fff, (q15_t)0xff83, (q15_t)0x7fff, (q15_t)0xff7d, (q15_t)0x7fff, (q15_t)0xff76, (q15_t)0x7fff, (q15_t)0xff70, + (q15_t)0x7fff, (q15_t)0xff6a, (q15_t)0x7fff, (q15_t)0xff63, (q15_t)0x7fff, (q15_t)0xff5d, (q15_t)0x7fff, (q15_t)0xff57, + (q15_t)0x7fff, (q15_t)0xff51, (q15_t)0x7fff, (q15_t)0xff4a, (q15_t)0x7fff, (q15_t)0xff44, (q15_t)0x7fff, (q15_t)0xff3e, + (q15_t)0x7fff, (q15_t)0xff37, (q15_t)0x7fff, (q15_t)0xff31, (q15_t)0x7fff, (q15_t)0xff2b, (q15_t)0x7fff, (q15_t)0xff25, + (q15_t)0x7fff, (q15_t)0xff1e, (q15_t)0x7fff, (q15_t)0xff18, (q15_t)0x7fff, (q15_t)0xff12, (q15_t)0x7fff, (q15_t)0xff0b, + (q15_t)0x7fff, (q15_t)0xff05, (q15_t)0x7ffe, (q15_t)0xfeff, (q15_t)0x7ffe, (q15_t)0xfef9, (q15_t)0x7ffe, (q15_t)0xfef2, + (q15_t)0x7ffe, (q15_t)0xfeec, (q15_t)0x7ffe, (q15_t)0xfee6, (q15_t)0x7ffe, (q15_t)0xfedf, (q15_t)0x7ffe, (q15_t)0xfed9, + (q15_t)0x7ffe, (q15_t)0xfed3, (q15_t)0x7ffe, (q15_t)0xfecd, (q15_t)0x7ffe, (q15_t)0xfec6, (q15_t)0x7ffe, (q15_t)0xfec0, + (q15_t)0x7ffe, (q15_t)0xfeba, (q15_t)0x7ffe, (q15_t)0xfeb3, (q15_t)0x7ffe, (q15_t)0xfead, (q15_t)0x7ffe, (q15_t)0xfea7, + (q15_t)0x7ffe, (q15_t)0xfea1, (q15_t)0x7ffe, (q15_t)0xfe9a, (q15_t)0x7ffd, (q15_t)0xfe94, (q15_t)0x7ffd, (q15_t)0xfe8e, + (q15_t)0x7ffd, (q15_t)0xfe88, (q15_t)0x7ffd, (q15_t)0xfe81, (q15_t)0x7ffd, (q15_t)0xfe7b, (q15_t)0x7ffd, (q15_t)0xfe75, + (q15_t)0x7ffd, (q15_t)0xfe6e, (q15_t)0x7ffd, (q15_t)0xfe68, (q15_t)0x7ffd, (q15_t)0xfe62, (q15_t)0x7ffd, (q15_t)0xfe5c, + (q15_t)0x7ffd, (q15_t)0xfe55, (q15_t)0x7ffd, (q15_t)0xfe4f, (q15_t)0x7ffd, (q15_t)0xfe49, (q15_t)0x7ffc, (q15_t)0xfe42, + (q15_t)0x7ffc, (q15_t)0xfe3c, (q15_t)0x7ffc, (q15_t)0xfe36, (q15_t)0x7ffc, (q15_t)0xfe30, (q15_t)0x7ffc, (q15_t)0xfe29, + (q15_t)0x7ffc, (q15_t)0xfe23, (q15_t)0x7ffc, (q15_t)0xfe1d, (q15_t)0x7ffc, (q15_t)0xfe16, (q15_t)0x7ffc, (q15_t)0xfe10, + (q15_t)0x7ffc, (q15_t)0xfe0a, (q15_t)0x7ffc, (q15_t)0xfe04, (q15_t)0x7ffb, (q15_t)0xfdfd, (q15_t)0x7ffb, (q15_t)0xfdf7, + (q15_t)0x7ffb, (q15_t)0xfdf1, (q15_t)0x7ffb, (q15_t)0xfdea, (q15_t)0x7ffb, (q15_t)0xfde4, (q15_t)0x7ffb, (q15_t)0xfdde, + (q15_t)0x7ffb, (q15_t)0xfdd8, (q15_t)0x7ffb, (q15_t)0xfdd1, (q15_t)0x7ffb, (q15_t)0xfdcb, (q15_t)0x7ffb, (q15_t)0xfdc5, + (q15_t)0x7ffa, (q15_t)0xfdbe, (q15_t)0x7ffa, (q15_t)0xfdb8, (q15_t)0x7ffa, (q15_t)0xfdb2, (q15_t)0x7ffa, (q15_t)0xfdac, + (q15_t)0x7ffa, (q15_t)0xfda5, (q15_t)0x7ffa, (q15_t)0xfd9f, (q15_t)0x7ffa, (q15_t)0xfd99, (q15_t)0x7ffa, (q15_t)0xfd93, + (q15_t)0x7ff9, (q15_t)0xfd8c, (q15_t)0x7ff9, (q15_t)0xfd86, (q15_t)0x7ff9, (q15_t)0xfd80, (q15_t)0x7ff9, (q15_t)0xfd79, + (q15_t)0x7ff9, (q15_t)0xfd73, (q15_t)0x7ff9, (q15_t)0xfd6d, (q15_t)0x7ff9, (q15_t)0xfd67, (q15_t)0x7ff9, (q15_t)0xfd60, + (q15_t)0x7ff8, (q15_t)0xfd5a, (q15_t)0x7ff8, (q15_t)0xfd54, (q15_t)0x7ff8, (q15_t)0xfd4d, (q15_t)0x7ff8, (q15_t)0xfd47, + (q15_t)0x7ff8, (q15_t)0xfd41, (q15_t)0x7ff8, (q15_t)0xfd3b, (q15_t)0x7ff8, (q15_t)0xfd34, (q15_t)0x7ff8, (q15_t)0xfd2e, + (q15_t)0x7ff7, (q15_t)0xfd28, (q15_t)0x7ff7, (q15_t)0xfd21, (q15_t)0x7ff7, (q15_t)0xfd1b, (q15_t)0x7ff7, (q15_t)0xfd15, + (q15_t)0x7ff7, (q15_t)0xfd0f, (q15_t)0x7ff7, (q15_t)0xfd08, (q15_t)0x7ff7, (q15_t)0xfd02, (q15_t)0x7ff6, (q15_t)0xfcfc, + (q15_t)0x7ff6, (q15_t)0xfcf5, (q15_t)0x7ff6, (q15_t)0xfcef, (q15_t)0x7ff6, (q15_t)0xfce9, (q15_t)0x7ff6, (q15_t)0xfce3, + (q15_t)0x7ff6, (q15_t)0xfcdc, (q15_t)0x7ff5, (q15_t)0xfcd6, (q15_t)0x7ff5, (q15_t)0xfcd0, (q15_t)0x7ff5, (q15_t)0xfcc9, + (q15_t)0x7ff5, (q15_t)0xfcc3, (q15_t)0x7ff5, (q15_t)0xfcbd, (q15_t)0x7ff5, (q15_t)0xfcb7, (q15_t)0x7ff5, (q15_t)0xfcb0, + (q15_t)0x7ff4, (q15_t)0xfcaa, (q15_t)0x7ff4, (q15_t)0xfca4, (q15_t)0x7ff4, (q15_t)0xfc9e, (q15_t)0x7ff4, (q15_t)0xfc97, + (q15_t)0x7ff4, (q15_t)0xfc91, (q15_t)0x7ff4, (q15_t)0xfc8b, (q15_t)0x7ff3, (q15_t)0xfc84, (q15_t)0x7ff3, (q15_t)0xfc7e, + (q15_t)0x7ff3, (q15_t)0xfc78, (q15_t)0x7ff3, (q15_t)0xfc72, (q15_t)0x7ff3, (q15_t)0xfc6b, (q15_t)0x7ff2, (q15_t)0xfc65, + (q15_t)0x7ff2, (q15_t)0xfc5f, (q15_t)0x7ff2, (q15_t)0xfc58, (q15_t)0x7ff2, (q15_t)0xfc52, (q15_t)0x7ff2, (q15_t)0xfc4c, + (q15_t)0x7ff2, (q15_t)0xfc46, (q15_t)0x7ff1, (q15_t)0xfc3f, (q15_t)0x7ff1, (q15_t)0xfc39, (q15_t)0x7ff1, (q15_t)0xfc33, + (q15_t)0x7ff1, (q15_t)0xfc2c, (q15_t)0x7ff1, (q15_t)0xfc26, (q15_t)0x7ff0, (q15_t)0xfc20, (q15_t)0x7ff0, (q15_t)0xfc1a, + (q15_t)0x7ff0, (q15_t)0xfc13, (q15_t)0x7ff0, (q15_t)0xfc0d, (q15_t)0x7ff0, (q15_t)0xfc07, (q15_t)0x7fef, (q15_t)0xfc01, + (q15_t)0x7fef, (q15_t)0xfbfa, (q15_t)0x7fef, (q15_t)0xfbf4, (q15_t)0x7fef, (q15_t)0xfbee, (q15_t)0x7fef, (q15_t)0xfbe7, + (q15_t)0x7fee, (q15_t)0xfbe1, (q15_t)0x7fee, (q15_t)0xfbdb, (q15_t)0x7fee, (q15_t)0xfbd5, (q15_t)0x7fee, (q15_t)0xfbce, + (q15_t)0x7fee, (q15_t)0xfbc8, (q15_t)0x7fed, (q15_t)0xfbc2, (q15_t)0x7fed, (q15_t)0xfbbb, (q15_t)0x7fed, (q15_t)0xfbb5, + (q15_t)0x7fed, (q15_t)0xfbaf, (q15_t)0x7fed, (q15_t)0xfba9, (q15_t)0x7fec, (q15_t)0xfba2, (q15_t)0x7fec, (q15_t)0xfb9c, + (q15_t)0x7fec, (q15_t)0xfb96, (q15_t)0x7fec, (q15_t)0xfb8f, (q15_t)0x7fec, (q15_t)0xfb89, (q15_t)0x7feb, (q15_t)0xfb83, + (q15_t)0x7feb, (q15_t)0xfb7d, (q15_t)0x7feb, (q15_t)0xfb76, (q15_t)0x7feb, (q15_t)0xfb70, (q15_t)0x7fea, (q15_t)0xfb6a, + (q15_t)0x7fea, (q15_t)0xfb64, (q15_t)0x7fea, (q15_t)0xfb5d, (q15_t)0x7fea, (q15_t)0xfb57, (q15_t)0x7fea, (q15_t)0xfb51, + (q15_t)0x7fe9, (q15_t)0xfb4a, (q15_t)0x7fe9, (q15_t)0xfb44, (q15_t)0x7fe9, (q15_t)0xfb3e, (q15_t)0x7fe9, (q15_t)0xfb38, + (q15_t)0x7fe8, (q15_t)0xfb31, (q15_t)0x7fe8, (q15_t)0xfb2b, (q15_t)0x7fe8, (q15_t)0xfb25, (q15_t)0x7fe8, (q15_t)0xfb1e, + (q15_t)0x7fe7, (q15_t)0xfb18, (q15_t)0x7fe7, (q15_t)0xfb12, (q15_t)0x7fe7, (q15_t)0xfb0c, (q15_t)0x7fe7, (q15_t)0xfb05, + (q15_t)0x7fe6, (q15_t)0xfaff, (q15_t)0x7fe6, (q15_t)0xfaf9, (q15_t)0x7fe6, (q15_t)0xfaf3, (q15_t)0x7fe6, (q15_t)0xfaec, + (q15_t)0x7fe5, (q15_t)0xfae6, (q15_t)0x7fe5, (q15_t)0xfae0, (q15_t)0x7fe5, (q15_t)0xfad9, (q15_t)0x7fe5, (q15_t)0xfad3, + (q15_t)0x7fe4, (q15_t)0xfacd, (q15_t)0x7fe4, (q15_t)0xfac7, (q15_t)0x7fe4, (q15_t)0xfac0, (q15_t)0x7fe4, (q15_t)0xfaba, + (q15_t)0x7fe3, (q15_t)0xfab4, (q15_t)0x7fe3, (q15_t)0xfaad, (q15_t)0x7fe3, (q15_t)0xfaa7, (q15_t)0x7fe3, (q15_t)0xfaa1, + (q15_t)0x7fe2, (q15_t)0xfa9b, (q15_t)0x7fe2, (q15_t)0xfa94, (q15_t)0x7fe2, (q15_t)0xfa8e, (q15_t)0x7fe2, (q15_t)0xfa88, + (q15_t)0x7fe1, (q15_t)0xfa81, (q15_t)0x7fe1, (q15_t)0xfa7b, (q15_t)0x7fe1, (q15_t)0xfa75, (q15_t)0x7fe0, (q15_t)0xfa6f, + (q15_t)0x7fe0, (q15_t)0xfa68, (q15_t)0x7fe0, (q15_t)0xfa62, (q15_t)0x7fe0, (q15_t)0xfa5c, (q15_t)0x7fdf, (q15_t)0xfa56, + (q15_t)0x7fdf, (q15_t)0xfa4f, (q15_t)0x7fdf, (q15_t)0xfa49, (q15_t)0x7fdf, (q15_t)0xfa43, (q15_t)0x7fde, (q15_t)0xfa3c, + (q15_t)0x7fde, (q15_t)0xfa36, (q15_t)0x7fde, (q15_t)0xfa30, (q15_t)0x7fdd, (q15_t)0xfa2a, (q15_t)0x7fdd, (q15_t)0xfa23, + (q15_t)0x7fdd, (q15_t)0xfa1d, (q15_t)0x7fdd, (q15_t)0xfa17, (q15_t)0x7fdc, (q15_t)0xfa11, (q15_t)0x7fdc, (q15_t)0xfa0a, + (q15_t)0x7fdc, (q15_t)0xfa04, (q15_t)0x7fdb, (q15_t)0xf9fe, (q15_t)0x7fdb, (q15_t)0xf9f7, (q15_t)0x7fdb, (q15_t)0xf9f1, + (q15_t)0x7fda, (q15_t)0xf9eb, (q15_t)0x7fda, (q15_t)0xf9e5, (q15_t)0x7fda, (q15_t)0xf9de, (q15_t)0x7fda, (q15_t)0xf9d8, + (q15_t)0x7fd9, (q15_t)0xf9d2, (q15_t)0x7fd9, (q15_t)0xf9cb, (q15_t)0x7fd9, (q15_t)0xf9c5, (q15_t)0x7fd8, (q15_t)0xf9bf, + (q15_t)0x7fd8, (q15_t)0xf9b9, (q15_t)0x7fd8, (q15_t)0xf9b2, (q15_t)0x7fd7, (q15_t)0xf9ac, (q15_t)0x7fd7, (q15_t)0xf9a6, + (q15_t)0x7fd7, (q15_t)0xf9a0, (q15_t)0x7fd6, (q15_t)0xf999, (q15_t)0x7fd6, (q15_t)0xf993, (q15_t)0x7fd6, (q15_t)0xf98d, + (q15_t)0x7fd6, (q15_t)0xf986, (q15_t)0x7fd5, (q15_t)0xf980, (q15_t)0x7fd5, (q15_t)0xf97a, (q15_t)0x7fd5, (q15_t)0xf974, + (q15_t)0x7fd4, (q15_t)0xf96d, (q15_t)0x7fd4, (q15_t)0xf967, (q15_t)0x7fd4, (q15_t)0xf961, (q15_t)0x7fd3, (q15_t)0xf95b, + (q15_t)0x7fd3, (q15_t)0xf954, (q15_t)0x7fd3, (q15_t)0xf94e, (q15_t)0x7fd2, (q15_t)0xf948, (q15_t)0x7fd2, (q15_t)0xf941, + (q15_t)0x7fd2, (q15_t)0xf93b, (q15_t)0x7fd1, (q15_t)0xf935, (q15_t)0x7fd1, (q15_t)0xf92f, (q15_t)0x7fd1, (q15_t)0xf928, + (q15_t)0x7fd0, (q15_t)0xf922, (q15_t)0x7fd0, (q15_t)0xf91c, (q15_t)0x7fd0, (q15_t)0xf916, (q15_t)0x7fcf, (q15_t)0xf90f, + (q15_t)0x7fcf, (q15_t)0xf909, (q15_t)0x7fcf, (q15_t)0xf903, (q15_t)0x7fce, (q15_t)0xf8fc, (q15_t)0x7fce, (q15_t)0xf8f6, + (q15_t)0x7fce, (q15_t)0xf8f0, (q15_t)0x7fcd, (q15_t)0xf8ea, (q15_t)0x7fcd, (q15_t)0xf8e3, (q15_t)0x7fcd, (q15_t)0xf8dd, + (q15_t)0x7fcc, (q15_t)0xf8d7, (q15_t)0x7fcc, (q15_t)0xf8d0, (q15_t)0x7fcb, (q15_t)0xf8ca, (q15_t)0x7fcb, (q15_t)0xf8c4, + (q15_t)0x7fcb, (q15_t)0xf8be, (q15_t)0x7fca, (q15_t)0xf8b7, (q15_t)0x7fca, (q15_t)0xf8b1, (q15_t)0x7fca, (q15_t)0xf8ab, + (q15_t)0x7fc9, (q15_t)0xf8a5, (q15_t)0x7fc9, (q15_t)0xf89e, (q15_t)0x7fc9, (q15_t)0xf898, (q15_t)0x7fc8, (q15_t)0xf892, + (q15_t)0x7fc8, (q15_t)0xf88b, (q15_t)0x7fc7, (q15_t)0xf885, (q15_t)0x7fc7, (q15_t)0xf87f, (q15_t)0x7fc7, (q15_t)0xf879, + (q15_t)0x7fc6, (q15_t)0xf872, (q15_t)0x7fc6, (q15_t)0xf86c, (q15_t)0x7fc6, (q15_t)0xf866, (q15_t)0x7fc5, (q15_t)0xf860, + (q15_t)0x7fc5, (q15_t)0xf859, (q15_t)0x7fc5, (q15_t)0xf853, (q15_t)0x7fc4, (q15_t)0xf84d, (q15_t)0x7fc4, (q15_t)0xf846, + (q15_t)0x7fc3, (q15_t)0xf840, (q15_t)0x7fc3, (q15_t)0xf83a, (q15_t)0x7fc3, (q15_t)0xf834, (q15_t)0x7fc2, (q15_t)0xf82d, + (q15_t)0x7fc2, (q15_t)0xf827, (q15_t)0x7fc1, (q15_t)0xf821, (q15_t)0x7fc1, (q15_t)0xf81b, (q15_t)0x7fc1, (q15_t)0xf814, + (q15_t)0x7fc0, (q15_t)0xf80e, (q15_t)0x7fc0, (q15_t)0xf808, (q15_t)0x7fc0, (q15_t)0xf802, (q15_t)0x7fbf, (q15_t)0xf7fb, + (q15_t)0x7fbf, (q15_t)0xf7f5, (q15_t)0x7fbe, (q15_t)0xf7ef, (q15_t)0x7fbe, (q15_t)0xf7e8, (q15_t)0x7fbe, (q15_t)0xf7e2, + (q15_t)0x7fbd, (q15_t)0xf7dc, (q15_t)0x7fbd, (q15_t)0xf7d6, (q15_t)0x7fbc, (q15_t)0xf7cf, (q15_t)0x7fbc, (q15_t)0xf7c9, + (q15_t)0x7fbc, (q15_t)0xf7c3, (q15_t)0x7fbb, (q15_t)0xf7bd, (q15_t)0x7fbb, (q15_t)0xf7b6, (q15_t)0x7fba, (q15_t)0xf7b0, + (q15_t)0x7fba, (q15_t)0xf7aa, (q15_t)0x7fb9, (q15_t)0xf7a3, (q15_t)0x7fb9, (q15_t)0xf79d, (q15_t)0x7fb9, (q15_t)0xf797, + (q15_t)0x7fb8, (q15_t)0xf791, (q15_t)0x7fb8, (q15_t)0xf78a, (q15_t)0x7fb7, (q15_t)0xf784, (q15_t)0x7fb7, (q15_t)0xf77e, + (q15_t)0x7fb7, (q15_t)0xf778, (q15_t)0x7fb6, (q15_t)0xf771, (q15_t)0x7fb6, (q15_t)0xf76b, (q15_t)0x7fb5, (q15_t)0xf765, + (q15_t)0x7fb5, (q15_t)0xf75e, (q15_t)0x7fb4, (q15_t)0xf758, (q15_t)0x7fb4, (q15_t)0xf752, (q15_t)0x7fb4, (q15_t)0xf74c, + (q15_t)0x7fb3, (q15_t)0xf745, (q15_t)0x7fb3, (q15_t)0xf73f, (q15_t)0x7fb2, (q15_t)0xf739, (q15_t)0x7fb2, (q15_t)0xf733, + (q15_t)0x7fb1, (q15_t)0xf72c, (q15_t)0x7fb1, (q15_t)0xf726, (q15_t)0x7fb1, (q15_t)0xf720, (q15_t)0x7fb0, (q15_t)0xf71a, + (q15_t)0x7fb0, (q15_t)0xf713, (q15_t)0x7faf, (q15_t)0xf70d, (q15_t)0x7faf, (q15_t)0xf707, (q15_t)0x7fae, (q15_t)0xf700, + (q15_t)0x7fae, (q15_t)0xf6fa, (q15_t)0x7fae, (q15_t)0xf6f4, (q15_t)0x7fad, (q15_t)0xf6ee, (q15_t)0x7fad, (q15_t)0xf6e7, + (q15_t)0x7fac, (q15_t)0xf6e1, (q15_t)0x7fac, (q15_t)0xf6db, (q15_t)0x7fab, (q15_t)0xf6d5, (q15_t)0x7fab, (q15_t)0xf6ce, + (q15_t)0x7faa, (q15_t)0xf6c8, (q15_t)0x7faa, (q15_t)0xf6c2, (q15_t)0x7fa9, (q15_t)0xf6bc, (q15_t)0x7fa9, (q15_t)0xf6b5, + (q15_t)0x7fa9, (q15_t)0xf6af, (q15_t)0x7fa8, (q15_t)0xf6a9, (q15_t)0x7fa8, (q15_t)0xf6a2, (q15_t)0x7fa7, (q15_t)0xf69c, + (q15_t)0x7fa7, (q15_t)0xf696, (q15_t)0x7fa6, (q15_t)0xf690, (q15_t)0x7fa6, (q15_t)0xf689, (q15_t)0x7fa5, (q15_t)0xf683, + (q15_t)0x7fa5, (q15_t)0xf67d, (q15_t)0x7fa4, (q15_t)0xf677, (q15_t)0x7fa4, (q15_t)0xf670, (q15_t)0x7fa3, (q15_t)0xf66a, + (q15_t)0x7fa3, (q15_t)0xf664, (q15_t)0x7fa3, (q15_t)0xf65e, (q15_t)0x7fa2, (q15_t)0xf657, (q15_t)0x7fa2, (q15_t)0xf651, + (q15_t)0x7fa1, (q15_t)0xf64b, (q15_t)0x7fa1, (q15_t)0xf644, (q15_t)0x7fa0, (q15_t)0xf63e, (q15_t)0x7fa0, (q15_t)0xf638, + (q15_t)0x7f9f, (q15_t)0xf632, (q15_t)0x7f9f, (q15_t)0xf62b, (q15_t)0x7f9e, (q15_t)0xf625, (q15_t)0x7f9e, (q15_t)0xf61f, + (q15_t)0x7f9d, (q15_t)0xf619, (q15_t)0x7f9d, (q15_t)0xf612, (q15_t)0x7f9c, (q15_t)0xf60c, (q15_t)0x7f9c, (q15_t)0xf606, + (q15_t)0x7f9b, (q15_t)0xf600, (q15_t)0x7f9b, (q15_t)0xf5f9, (q15_t)0x7f9a, (q15_t)0xf5f3, (q15_t)0x7f9a, (q15_t)0xf5ed, + (q15_t)0x7f99, (q15_t)0xf5e7, (q15_t)0x7f99, (q15_t)0xf5e0, (q15_t)0x7f98, (q15_t)0xf5da, (q15_t)0x7f98, (q15_t)0xf5d4, + (q15_t)0x7f97, (q15_t)0xf5cd, (q15_t)0x7f97, (q15_t)0xf5c7, (q15_t)0x7f96, (q15_t)0xf5c1, (q15_t)0x7f96, (q15_t)0xf5bb, + (q15_t)0x7f95, (q15_t)0xf5b4, (q15_t)0x7f95, (q15_t)0xf5ae, (q15_t)0x7f94, (q15_t)0xf5a8, (q15_t)0x7f94, (q15_t)0xf5a2, + (q15_t)0x7f93, (q15_t)0xf59b, (q15_t)0x7f93, (q15_t)0xf595, (q15_t)0x7f92, (q15_t)0xf58f, (q15_t)0x7f92, (q15_t)0xf589, + (q15_t)0x7f91, (q15_t)0xf582, (q15_t)0x7f91, (q15_t)0xf57c, (q15_t)0x7f90, (q15_t)0xf576, (q15_t)0x7f90, (q15_t)0xf570, + (q15_t)0x7f8f, (q15_t)0xf569, (q15_t)0x7f8f, (q15_t)0xf563, (q15_t)0x7f8e, (q15_t)0xf55d, (q15_t)0x7f8e, (q15_t)0xf556, + (q15_t)0x7f8d, (q15_t)0xf550, (q15_t)0x7f8d, (q15_t)0xf54a, (q15_t)0x7f8c, (q15_t)0xf544, (q15_t)0x7f8b, (q15_t)0xf53d, + (q15_t)0x7f8b, (q15_t)0xf537, (q15_t)0x7f8a, (q15_t)0xf531, (q15_t)0x7f8a, (q15_t)0xf52b, (q15_t)0x7f89, (q15_t)0xf524, + (q15_t)0x7f89, (q15_t)0xf51e, (q15_t)0x7f88, (q15_t)0xf518, (q15_t)0x7f88, (q15_t)0xf512, (q15_t)0x7f87, (q15_t)0xf50b, + (q15_t)0x7f87, (q15_t)0xf505, (q15_t)0x7f86, (q15_t)0xf4ff, (q15_t)0x7f86, (q15_t)0xf4f9, (q15_t)0x7f85, (q15_t)0xf4f2, + (q15_t)0x7f85, (q15_t)0xf4ec, (q15_t)0x7f84, (q15_t)0xf4e6, (q15_t)0x7f83, (q15_t)0xf4e0, (q15_t)0x7f83, (q15_t)0xf4d9, + (q15_t)0x7f82, (q15_t)0xf4d3, (q15_t)0x7f82, (q15_t)0xf4cd, (q15_t)0x7f81, (q15_t)0xf4c6, (q15_t)0x7f81, (q15_t)0xf4c0, + (q15_t)0x7f80, (q15_t)0xf4ba, (q15_t)0x7f80, (q15_t)0xf4b4, (q15_t)0x7f7f, (q15_t)0xf4ad, (q15_t)0x7f7e, (q15_t)0xf4a7, + (q15_t)0x7f7e, (q15_t)0xf4a1, (q15_t)0x7f7d, (q15_t)0xf49b, (q15_t)0x7f7d, (q15_t)0xf494, (q15_t)0x7f7c, (q15_t)0xf48e, + (q15_t)0x7f7c, (q15_t)0xf488, (q15_t)0x7f7b, (q15_t)0xf482, (q15_t)0x7f7b, (q15_t)0xf47b, (q15_t)0x7f7a, (q15_t)0xf475, + (q15_t)0x7f79, (q15_t)0xf46f, (q15_t)0x7f79, (q15_t)0xf469, (q15_t)0x7f78, (q15_t)0xf462, (q15_t)0x7f78, (q15_t)0xf45c, + (q15_t)0x7f77, (q15_t)0xf456, (q15_t)0x7f77, (q15_t)0xf450, (q15_t)0x7f76, (q15_t)0xf449, (q15_t)0x7f75, (q15_t)0xf443, + (q15_t)0x7f75, (q15_t)0xf43d, (q15_t)0x7f74, (q15_t)0xf437, (q15_t)0x7f74, (q15_t)0xf430, (q15_t)0x7f73, (q15_t)0xf42a, + (q15_t)0x7f72, (q15_t)0xf424, (q15_t)0x7f72, (q15_t)0xf41e, (q15_t)0x7f71, (q15_t)0xf417, (q15_t)0x7f71, (q15_t)0xf411, + (q15_t)0x7f70, (q15_t)0xf40b, (q15_t)0x7f70, (q15_t)0xf405, (q15_t)0x7f6f, (q15_t)0xf3fe, (q15_t)0x7f6e, (q15_t)0xf3f8, + (q15_t)0x7f6e, (q15_t)0xf3f2, (q15_t)0x7f6d, (q15_t)0xf3ec, (q15_t)0x7f6d, (q15_t)0xf3e5, (q15_t)0x7f6c, (q15_t)0xf3df, + (q15_t)0x7f6b, (q15_t)0xf3d9, (q15_t)0x7f6b, (q15_t)0xf3d2, (q15_t)0x7f6a, (q15_t)0xf3cc, (q15_t)0x7f6a, (q15_t)0xf3c6, + (q15_t)0x7f69, (q15_t)0xf3c0, (q15_t)0x7f68, (q15_t)0xf3b9, (q15_t)0x7f68, (q15_t)0xf3b3, (q15_t)0x7f67, (q15_t)0xf3ad, + (q15_t)0x7f67, (q15_t)0xf3a7, (q15_t)0x7f66, (q15_t)0xf3a0, (q15_t)0x7f65, (q15_t)0xf39a, (q15_t)0x7f65, (q15_t)0xf394, + (q15_t)0x7f64, (q15_t)0xf38e, (q15_t)0x7f64, (q15_t)0xf387, (q15_t)0x7f63, (q15_t)0xf381, (q15_t)0x7f62, (q15_t)0xf37b, + (q15_t)0x7f62, (q15_t)0xf375, (q15_t)0x7f61, (q15_t)0xf36e, (q15_t)0x7f60, (q15_t)0xf368, (q15_t)0x7f60, (q15_t)0xf362, + (q15_t)0x7f5f, (q15_t)0xf35c, (q15_t)0x7f5f, (q15_t)0xf355, (q15_t)0x7f5e, (q15_t)0xf34f, (q15_t)0x7f5d, (q15_t)0xf349, + (q15_t)0x7f5d, (q15_t)0xf343, (q15_t)0x7f5c, (q15_t)0xf33c, (q15_t)0x7f5b, (q15_t)0xf336, (q15_t)0x7f5b, (q15_t)0xf330, + (q15_t)0x7f5a, (q15_t)0xf32a, (q15_t)0x7f5a, (q15_t)0xf323, (q15_t)0x7f59, (q15_t)0xf31d, (q15_t)0x7f58, (q15_t)0xf317, + (q15_t)0x7f58, (q15_t)0xf311, (q15_t)0x7f57, (q15_t)0xf30a, (q15_t)0x7f56, (q15_t)0xf304, (q15_t)0x7f56, (q15_t)0xf2fe, + (q15_t)0x7f55, (q15_t)0xf2f8, (q15_t)0x7f55, (q15_t)0xf2f1, (q15_t)0x7f54, (q15_t)0xf2eb, (q15_t)0x7f53, (q15_t)0xf2e5, + (q15_t)0x7f53, (q15_t)0xf2df, (q15_t)0x7f52, (q15_t)0xf2d8, (q15_t)0x7f51, (q15_t)0xf2d2, (q15_t)0x7f51, (q15_t)0xf2cc, + (q15_t)0x7f50, (q15_t)0xf2c6, (q15_t)0x7f4f, (q15_t)0xf2bf, (q15_t)0x7f4f, (q15_t)0xf2b9, (q15_t)0x7f4e, (q15_t)0xf2b3, + (q15_t)0x7f4d, (q15_t)0xf2ad, (q15_t)0x7f4d, (q15_t)0xf2a6, (q15_t)0x7f4c, (q15_t)0xf2a0, (q15_t)0x7f4b, (q15_t)0xf29a, + (q15_t)0x7f4b, (q15_t)0xf294, (q15_t)0x7f4a, (q15_t)0xf28d, (q15_t)0x7f49, (q15_t)0xf287, (q15_t)0x7f49, (q15_t)0xf281, + (q15_t)0x7f48, (q15_t)0xf27b, (q15_t)0x7f47, (q15_t)0xf274, (q15_t)0x7f47, (q15_t)0xf26e, (q15_t)0x7f46, (q15_t)0xf268, + (q15_t)0x7f45, (q15_t)0xf262, (q15_t)0x7f45, (q15_t)0xf25b, (q15_t)0x7f44, (q15_t)0xf255, (q15_t)0x7f43, (q15_t)0xf24f, + (q15_t)0x7f43, (q15_t)0xf249, (q15_t)0x7f42, (q15_t)0xf242, (q15_t)0x7f41, (q15_t)0xf23c, (q15_t)0x7f41, (q15_t)0xf236, + (q15_t)0x7f40, (q15_t)0xf230, (q15_t)0x7f3f, (q15_t)0xf229, (q15_t)0x7f3f, (q15_t)0xf223, (q15_t)0x7f3e, (q15_t)0xf21d, + (q15_t)0x7f3d, (q15_t)0xf217, (q15_t)0x7f3d, (q15_t)0xf210, (q15_t)0x7f3c, (q15_t)0xf20a, (q15_t)0x7f3b, (q15_t)0xf204, + (q15_t)0x7f3b, (q15_t)0xf1fe, (q15_t)0x7f3a, (q15_t)0xf1f7, (q15_t)0x7f39, (q15_t)0xf1f1, (q15_t)0x7f39, (q15_t)0xf1eb, + (q15_t)0x7f38, (q15_t)0xf1e5, (q15_t)0x7f37, (q15_t)0xf1de, (q15_t)0x7f36, (q15_t)0xf1d8, (q15_t)0x7f36, (q15_t)0xf1d2, + (q15_t)0x7f35, (q15_t)0xf1cc, (q15_t)0x7f34, (q15_t)0xf1c6, (q15_t)0x7f34, (q15_t)0xf1bf, (q15_t)0x7f33, (q15_t)0xf1b9, + (q15_t)0x7f32, (q15_t)0xf1b3, (q15_t)0x7f32, (q15_t)0xf1ad, (q15_t)0x7f31, (q15_t)0xf1a6, (q15_t)0x7f30, (q15_t)0xf1a0, + (q15_t)0x7f2f, (q15_t)0xf19a, (q15_t)0x7f2f, (q15_t)0xf194, (q15_t)0x7f2e, (q15_t)0xf18d, (q15_t)0x7f2d, (q15_t)0xf187, + (q15_t)0x7f2d, (q15_t)0xf181, (q15_t)0x7f2c, (q15_t)0xf17b, (q15_t)0x7f2b, (q15_t)0xf174, (q15_t)0x7f2a, (q15_t)0xf16e, + (q15_t)0x7f2a, (q15_t)0xf168, (q15_t)0x7f29, (q15_t)0xf162, (q15_t)0x7f28, (q15_t)0xf15b, (q15_t)0x7f28, (q15_t)0xf155, + (q15_t)0x7f27, (q15_t)0xf14f, (q15_t)0x7f26, (q15_t)0xf149, (q15_t)0x7f25, (q15_t)0xf142, (q15_t)0x7f25, (q15_t)0xf13c, + (q15_t)0x7f24, (q15_t)0xf136, (q15_t)0x7f23, (q15_t)0xf130, (q15_t)0x7f23, (q15_t)0xf129, (q15_t)0x7f22, (q15_t)0xf123, + (q15_t)0x7f21, (q15_t)0xf11d, (q15_t)0x7f20, (q15_t)0xf117, (q15_t)0x7f20, (q15_t)0xf110, (q15_t)0x7f1f, (q15_t)0xf10a, + (q15_t)0x7f1e, (q15_t)0xf104, (q15_t)0x7f1d, (q15_t)0xf0fe, (q15_t)0x7f1d, (q15_t)0xf0f8, (q15_t)0x7f1c, (q15_t)0xf0f1, + (q15_t)0x7f1b, (q15_t)0xf0eb, (q15_t)0x7f1a, (q15_t)0xf0e5, (q15_t)0x7f1a, (q15_t)0xf0df, (q15_t)0x7f19, (q15_t)0xf0d8, + (q15_t)0x7f18, (q15_t)0xf0d2, (q15_t)0x7f17, (q15_t)0xf0cc, (q15_t)0x7f17, (q15_t)0xf0c6, (q15_t)0x7f16, (q15_t)0xf0bf, + (q15_t)0x7f15, (q15_t)0xf0b9, (q15_t)0x7f14, (q15_t)0xf0b3, (q15_t)0x7f14, (q15_t)0xf0ad, (q15_t)0x7f13, (q15_t)0xf0a6, + (q15_t)0x7f12, (q15_t)0xf0a0, (q15_t)0x7f11, (q15_t)0xf09a, (q15_t)0x7f11, (q15_t)0xf094, (q15_t)0x7f10, (q15_t)0xf08d, + (q15_t)0x7f0f, (q15_t)0xf087, (q15_t)0x7f0e, (q15_t)0xf081, (q15_t)0x7f0e, (q15_t)0xf07b, (q15_t)0x7f0d, (q15_t)0xf075, + (q15_t)0x7f0c, (q15_t)0xf06e, (q15_t)0x7f0b, (q15_t)0xf068, (q15_t)0x7f0b, (q15_t)0xf062, (q15_t)0x7f0a, (q15_t)0xf05c, + (q15_t)0x7f09, (q15_t)0xf055, (q15_t)0x7f08, (q15_t)0xf04f, (q15_t)0x7f08, (q15_t)0xf049, (q15_t)0x7f07, (q15_t)0xf043, + (q15_t)0x7f06, (q15_t)0xf03c, (q15_t)0x7f05, (q15_t)0xf036, (q15_t)0x7f04, (q15_t)0xf030, (q15_t)0x7f04, (q15_t)0xf02a, + (q15_t)0x7f03, (q15_t)0xf023, (q15_t)0x7f02, (q15_t)0xf01d, (q15_t)0x7f01, (q15_t)0xf017, (q15_t)0x7f01, (q15_t)0xf011, + (q15_t)0x7f00, (q15_t)0xf00b, (q15_t)0x7eff, (q15_t)0xf004, (q15_t)0x7efe, (q15_t)0xeffe, (q15_t)0x7efd, (q15_t)0xeff8, + (q15_t)0x7efd, (q15_t)0xeff2, (q15_t)0x7efc, (q15_t)0xefeb, (q15_t)0x7efb, (q15_t)0xefe5, (q15_t)0x7efa, (q15_t)0xefdf, + (q15_t)0x7ef9, (q15_t)0xefd9, (q15_t)0x7ef9, (q15_t)0xefd2, (q15_t)0x7ef8, (q15_t)0xefcc, (q15_t)0x7ef7, (q15_t)0xefc6, + (q15_t)0x7ef6, (q15_t)0xefc0, (q15_t)0x7ef5, (q15_t)0xefb9, (q15_t)0x7ef5, (q15_t)0xefb3, (q15_t)0x7ef4, (q15_t)0xefad, + (q15_t)0x7ef3, (q15_t)0xefa7, (q15_t)0x7ef2, (q15_t)0xefa1, (q15_t)0x7ef1, (q15_t)0xef9a, (q15_t)0x7ef1, (q15_t)0xef94, + (q15_t)0x7ef0, (q15_t)0xef8e, (q15_t)0x7eef, (q15_t)0xef88, (q15_t)0x7eee, (q15_t)0xef81, (q15_t)0x7eed, (q15_t)0xef7b, + (q15_t)0x7eed, (q15_t)0xef75, (q15_t)0x7eec, (q15_t)0xef6f, (q15_t)0x7eeb, (q15_t)0xef68, (q15_t)0x7eea, (q15_t)0xef62, + (q15_t)0x7ee9, (q15_t)0xef5c, (q15_t)0x7ee9, (q15_t)0xef56, (q15_t)0x7ee8, (q15_t)0xef50, (q15_t)0x7ee7, (q15_t)0xef49, + (q15_t)0x7ee6, (q15_t)0xef43, (q15_t)0x7ee5, (q15_t)0xef3d, (q15_t)0x7ee4, (q15_t)0xef37, (q15_t)0x7ee4, (q15_t)0xef30, + (q15_t)0x7ee3, (q15_t)0xef2a, (q15_t)0x7ee2, (q15_t)0xef24, (q15_t)0x7ee1, (q15_t)0xef1e, (q15_t)0x7ee0, (q15_t)0xef18, + (q15_t)0x7edf, (q15_t)0xef11, (q15_t)0x7edf, (q15_t)0xef0b, (q15_t)0x7ede, (q15_t)0xef05, (q15_t)0x7edd, (q15_t)0xeeff, + (q15_t)0x7edc, (q15_t)0xeef8, (q15_t)0x7edb, (q15_t)0xeef2, (q15_t)0x7eda, (q15_t)0xeeec, (q15_t)0x7eda, (q15_t)0xeee6, + (q15_t)0x7ed9, (q15_t)0xeedf, (q15_t)0x7ed8, (q15_t)0xeed9, (q15_t)0x7ed7, (q15_t)0xeed3, (q15_t)0x7ed6, (q15_t)0xeecd, + (q15_t)0x7ed5, (q15_t)0xeec7, (q15_t)0x7ed5, (q15_t)0xeec0, (q15_t)0x7ed4, (q15_t)0xeeba, (q15_t)0x7ed3, (q15_t)0xeeb4, + (q15_t)0x7ed2, (q15_t)0xeeae, (q15_t)0x7ed1, (q15_t)0xeea7, (q15_t)0x7ed0, (q15_t)0xeea1, (q15_t)0x7ecf, (q15_t)0xee9b, + (q15_t)0x7ecf, (q15_t)0xee95, (q15_t)0x7ece, (q15_t)0xee8f, (q15_t)0x7ecd, (q15_t)0xee88, (q15_t)0x7ecc, (q15_t)0xee82, + (q15_t)0x7ecb, (q15_t)0xee7c, (q15_t)0x7eca, (q15_t)0xee76, (q15_t)0x7ec9, (q15_t)0xee6f, (q15_t)0x7ec9, (q15_t)0xee69, + (q15_t)0x7ec8, (q15_t)0xee63, (q15_t)0x7ec7, (q15_t)0xee5d, (q15_t)0x7ec6, (q15_t)0xee57, (q15_t)0x7ec5, (q15_t)0xee50, + (q15_t)0x7ec4, (q15_t)0xee4a, (q15_t)0x7ec3, (q15_t)0xee44, (q15_t)0x7ec3, (q15_t)0xee3e, (q15_t)0x7ec2, (q15_t)0xee37, + (q15_t)0x7ec1, (q15_t)0xee31, (q15_t)0x7ec0, (q15_t)0xee2b, (q15_t)0x7ebf, (q15_t)0xee25, (q15_t)0x7ebe, (q15_t)0xee1f, + (q15_t)0x7ebd, (q15_t)0xee18, (q15_t)0x7ebc, (q15_t)0xee12, (q15_t)0x7ebb, (q15_t)0xee0c, (q15_t)0x7ebb, (q15_t)0xee06, + (q15_t)0x7eba, (q15_t)0xedff, (q15_t)0x7eb9, (q15_t)0xedf9, (q15_t)0x7eb8, (q15_t)0xedf3, (q15_t)0x7eb7, (q15_t)0xeded, + (q15_t)0x7eb6, (q15_t)0xede7, (q15_t)0x7eb5, (q15_t)0xede0, (q15_t)0x7eb4, (q15_t)0xedda, (q15_t)0x7eb4, (q15_t)0xedd4, + (q15_t)0x7eb3, (q15_t)0xedce, (q15_t)0x7eb2, (q15_t)0xedc7, (q15_t)0x7eb1, (q15_t)0xedc1, (q15_t)0x7eb0, (q15_t)0xedbb, + (q15_t)0x7eaf, (q15_t)0xedb5, (q15_t)0x7eae, (q15_t)0xedaf, (q15_t)0x7ead, (q15_t)0xeda8, (q15_t)0x7eac, (q15_t)0xeda2, + (q15_t)0x7eab, (q15_t)0xed9c, (q15_t)0x7eab, (q15_t)0xed96, (q15_t)0x7eaa, (q15_t)0xed8f, (q15_t)0x7ea9, (q15_t)0xed89, + (q15_t)0x7ea8, (q15_t)0xed83, (q15_t)0x7ea7, (q15_t)0xed7d, (q15_t)0x7ea6, (q15_t)0xed77, (q15_t)0x7ea5, (q15_t)0xed70, + (q15_t)0x7ea4, (q15_t)0xed6a, (q15_t)0x7ea3, (q15_t)0xed64, (q15_t)0x7ea2, (q15_t)0xed5e, (q15_t)0x7ea1, (q15_t)0xed58, + (q15_t)0x7ea1, (q15_t)0xed51, (q15_t)0x7ea0, (q15_t)0xed4b, (q15_t)0x7e9f, (q15_t)0xed45, (q15_t)0x7e9e, (q15_t)0xed3f, + (q15_t)0x7e9d, (q15_t)0xed38, (q15_t)0x7e9c, (q15_t)0xed32, (q15_t)0x7e9b, (q15_t)0xed2c, (q15_t)0x7e9a, (q15_t)0xed26, + (q15_t)0x7e99, (q15_t)0xed20, (q15_t)0x7e98, (q15_t)0xed19, (q15_t)0x7e97, (q15_t)0xed13, (q15_t)0x7e96, (q15_t)0xed0d, + (q15_t)0x7e95, (q15_t)0xed07, (q15_t)0x7e94, (q15_t)0xed01, (q15_t)0x7e94, (q15_t)0xecfa, (q15_t)0x7e93, (q15_t)0xecf4, + (q15_t)0x7e92, (q15_t)0xecee, (q15_t)0x7e91, (q15_t)0xece8, (q15_t)0x7e90, (q15_t)0xece1, (q15_t)0x7e8f, (q15_t)0xecdb, + (q15_t)0x7e8e, (q15_t)0xecd5, (q15_t)0x7e8d, (q15_t)0xeccf, (q15_t)0x7e8c, (q15_t)0xecc9, (q15_t)0x7e8b, (q15_t)0xecc2, + (q15_t)0x7e8a, (q15_t)0xecbc, (q15_t)0x7e89, (q15_t)0xecb6, (q15_t)0x7e88, (q15_t)0xecb0, (q15_t)0x7e87, (q15_t)0xecaa, + (q15_t)0x7e86, (q15_t)0xeca3, (q15_t)0x7e85, (q15_t)0xec9d, (q15_t)0x7e84, (q15_t)0xec97, (q15_t)0x7e84, (q15_t)0xec91, + (q15_t)0x7e83, (q15_t)0xec8a, (q15_t)0x7e82, (q15_t)0xec84, (q15_t)0x7e81, (q15_t)0xec7e, (q15_t)0x7e80, (q15_t)0xec78, + (q15_t)0x7e7f, (q15_t)0xec72, (q15_t)0x7e7e, (q15_t)0xec6b, (q15_t)0x7e7d, (q15_t)0xec65, (q15_t)0x7e7c, (q15_t)0xec5f, + (q15_t)0x7e7b, (q15_t)0xec59, (q15_t)0x7e7a, (q15_t)0xec53, (q15_t)0x7e79, (q15_t)0xec4c, (q15_t)0x7e78, (q15_t)0xec46, + (q15_t)0x7e77, (q15_t)0xec40, (q15_t)0x7e76, (q15_t)0xec3a, (q15_t)0x7e75, (q15_t)0xec34, (q15_t)0x7e74, (q15_t)0xec2d, + (q15_t)0x7e73, (q15_t)0xec27, (q15_t)0x7e72, (q15_t)0xec21, (q15_t)0x7e71, (q15_t)0xec1b, (q15_t)0x7e70, (q15_t)0xec15, + (q15_t)0x7e6f, (q15_t)0xec0e, (q15_t)0x7e6e, (q15_t)0xec08, (q15_t)0x7e6d, (q15_t)0xec02, (q15_t)0x7e6c, (q15_t)0xebfc, + (q15_t)0x7e6b, (q15_t)0xebf5, (q15_t)0x7e6a, (q15_t)0xebef, (q15_t)0x7e69, (q15_t)0xebe9, (q15_t)0x7e68, (q15_t)0xebe3, + (q15_t)0x7e67, (q15_t)0xebdd, (q15_t)0x7e66, (q15_t)0xebd6, (q15_t)0x7e65, (q15_t)0xebd0, (q15_t)0x7e64, (q15_t)0xebca, + (q15_t)0x7e63, (q15_t)0xebc4, (q15_t)0x7e62, (q15_t)0xebbe, (q15_t)0x7e61, (q15_t)0xebb7, (q15_t)0x7e60, (q15_t)0xebb1, + (q15_t)0x7e5f, (q15_t)0xebab, (q15_t)0x7e5e, (q15_t)0xeba5, (q15_t)0x7e5d, (q15_t)0xeb9f, (q15_t)0x7e5c, (q15_t)0xeb98, + (q15_t)0x7e5b, (q15_t)0xeb92, (q15_t)0x7e5a, (q15_t)0xeb8c, (q15_t)0x7e59, (q15_t)0xeb86, (q15_t)0x7e58, (q15_t)0xeb80, + (q15_t)0x7e57, (q15_t)0xeb79, (q15_t)0x7e56, (q15_t)0xeb73, (q15_t)0x7e55, (q15_t)0xeb6d, (q15_t)0x7e54, (q15_t)0xeb67, + (q15_t)0x7e53, (q15_t)0xeb61, (q15_t)0x7e52, (q15_t)0xeb5a, (q15_t)0x7e51, (q15_t)0xeb54, (q15_t)0x7e50, (q15_t)0xeb4e, + (q15_t)0x7e4f, (q15_t)0xeb48, (q15_t)0x7e4e, (q15_t)0xeb42, (q15_t)0x7e4d, (q15_t)0xeb3b, (q15_t)0x7e4c, (q15_t)0xeb35, + (q15_t)0x7e4b, (q15_t)0xeb2f, (q15_t)0x7e4a, (q15_t)0xeb29, (q15_t)0x7e49, (q15_t)0xeb23, (q15_t)0x7e48, (q15_t)0xeb1c, + (q15_t)0x7e47, (q15_t)0xeb16, (q15_t)0x7e46, (q15_t)0xeb10, (q15_t)0x7e45, (q15_t)0xeb0a, (q15_t)0x7e44, (q15_t)0xeb04, + (q15_t)0x7e43, (q15_t)0xeafd, (q15_t)0x7e42, (q15_t)0xeaf7, (q15_t)0x7e41, (q15_t)0xeaf1, (q15_t)0x7e40, (q15_t)0xeaeb, + (q15_t)0x7e3f, (q15_t)0xeae5, (q15_t)0x7e3e, (q15_t)0xeade, (q15_t)0x7e3d, (q15_t)0xead8, (q15_t)0x7e3c, (q15_t)0xead2, + (q15_t)0x7e3b, (q15_t)0xeacc, (q15_t)0x7e3a, (q15_t)0xeac6, (q15_t)0x7e39, (q15_t)0xeabf, (q15_t)0x7e38, (q15_t)0xeab9, + (q15_t)0x7e37, (q15_t)0xeab3, (q15_t)0x7e35, (q15_t)0xeaad, (q15_t)0x7e34, (q15_t)0xeaa7, (q15_t)0x7e33, (q15_t)0xeaa0, + (q15_t)0x7e32, (q15_t)0xea9a, (q15_t)0x7e31, (q15_t)0xea94, (q15_t)0x7e30, (q15_t)0xea8e, (q15_t)0x7e2f, (q15_t)0xea88, + (q15_t)0x7e2e, (q15_t)0xea81, (q15_t)0x7e2d, (q15_t)0xea7b, (q15_t)0x7e2c, (q15_t)0xea75, (q15_t)0x7e2b, (q15_t)0xea6f, + (q15_t)0x7e2a, (q15_t)0xea69, (q15_t)0x7e29, (q15_t)0xea63, (q15_t)0x7e28, (q15_t)0xea5c, (q15_t)0x7e27, (q15_t)0xea56, + (q15_t)0x7e26, (q15_t)0xea50, (q15_t)0x7e25, (q15_t)0xea4a, (q15_t)0x7e24, (q15_t)0xea44, (q15_t)0x7e22, (q15_t)0xea3d, + (q15_t)0x7e21, (q15_t)0xea37, (q15_t)0x7e20, (q15_t)0xea31, (q15_t)0x7e1f, (q15_t)0xea2b, (q15_t)0x7e1e, (q15_t)0xea25, + (q15_t)0x7e1d, (q15_t)0xea1e, (q15_t)0x7e1c, (q15_t)0xea18, (q15_t)0x7e1b, (q15_t)0xea12, (q15_t)0x7e1a, (q15_t)0xea0c, + (q15_t)0x7e19, (q15_t)0xea06, (q15_t)0x7e18, (q15_t)0xe9ff, (q15_t)0x7e17, (q15_t)0xe9f9, (q15_t)0x7e16, (q15_t)0xe9f3, + (q15_t)0x7e14, (q15_t)0xe9ed, (q15_t)0x7e13, (q15_t)0xe9e7, (q15_t)0x7e12, (q15_t)0xe9e1, (q15_t)0x7e11, (q15_t)0xe9da, + (q15_t)0x7e10, (q15_t)0xe9d4, (q15_t)0x7e0f, (q15_t)0xe9ce, (q15_t)0x7e0e, (q15_t)0xe9c8, (q15_t)0x7e0d, (q15_t)0xe9c2, + (q15_t)0x7e0c, (q15_t)0xe9bb, (q15_t)0x7e0b, (q15_t)0xe9b5, (q15_t)0x7e0a, (q15_t)0xe9af, (q15_t)0x7e08, (q15_t)0xe9a9, + (q15_t)0x7e07, (q15_t)0xe9a3, (q15_t)0x7e06, (q15_t)0xe99c, (q15_t)0x7e05, (q15_t)0xe996, (q15_t)0x7e04, (q15_t)0xe990, + (q15_t)0x7e03, (q15_t)0xe98a, (q15_t)0x7e02, (q15_t)0xe984, (q15_t)0x7e01, (q15_t)0xe97e, (q15_t)0x7e00, (q15_t)0xe977, + (q15_t)0x7dff, (q15_t)0xe971, (q15_t)0x7dfd, (q15_t)0xe96b, (q15_t)0x7dfc, (q15_t)0xe965, (q15_t)0x7dfb, (q15_t)0xe95f, + (q15_t)0x7dfa, (q15_t)0xe958, (q15_t)0x7df9, (q15_t)0xe952, (q15_t)0x7df8, (q15_t)0xe94c, (q15_t)0x7df7, (q15_t)0xe946, + (q15_t)0x7df6, (q15_t)0xe940, (q15_t)0x7df5, (q15_t)0xe93a, (q15_t)0x7df3, (q15_t)0xe933, (q15_t)0x7df2, (q15_t)0xe92d, + (q15_t)0x7df1, (q15_t)0xe927, (q15_t)0x7df0, (q15_t)0xe921, (q15_t)0x7def, (q15_t)0xe91b, (q15_t)0x7dee, (q15_t)0xe914, + (q15_t)0x7ded, (q15_t)0xe90e, (q15_t)0x7dec, (q15_t)0xe908, (q15_t)0x7dea, (q15_t)0xe902, (q15_t)0x7de9, (q15_t)0xe8fc, + (q15_t)0x7de8, (q15_t)0xe8f6, (q15_t)0x7de7, (q15_t)0xe8ef, (q15_t)0x7de6, (q15_t)0xe8e9, (q15_t)0x7de5, (q15_t)0xe8e3, + (q15_t)0x7de4, (q15_t)0xe8dd, (q15_t)0x7de2, (q15_t)0xe8d7, (q15_t)0x7de1, (q15_t)0xe8d0, (q15_t)0x7de0, (q15_t)0xe8ca, + (q15_t)0x7ddf, (q15_t)0xe8c4, (q15_t)0x7dde, (q15_t)0xe8be, (q15_t)0x7ddd, (q15_t)0xe8b8, (q15_t)0x7ddc, (q15_t)0xe8b2, + (q15_t)0x7dda, (q15_t)0xe8ab, (q15_t)0x7dd9, (q15_t)0xe8a5, (q15_t)0x7dd8, (q15_t)0xe89f, (q15_t)0x7dd7, (q15_t)0xe899, + (q15_t)0x7dd6, (q15_t)0xe893, (q15_t)0x7dd5, (q15_t)0xe88c, (q15_t)0x7dd4, (q15_t)0xe886, (q15_t)0x7dd2, (q15_t)0xe880, + (q15_t)0x7dd1, (q15_t)0xe87a, (q15_t)0x7dd0, (q15_t)0xe874, (q15_t)0x7dcf, (q15_t)0xe86e, (q15_t)0x7dce, (q15_t)0xe867, + (q15_t)0x7dcd, (q15_t)0xe861, (q15_t)0x7dcc, (q15_t)0xe85b, (q15_t)0x7dca, (q15_t)0xe855, (q15_t)0x7dc9, (q15_t)0xe84f, + (q15_t)0x7dc8, (q15_t)0xe849, (q15_t)0x7dc7, (q15_t)0xe842, (q15_t)0x7dc6, (q15_t)0xe83c, (q15_t)0x7dc5, (q15_t)0xe836, + (q15_t)0x7dc3, (q15_t)0xe830, (q15_t)0x7dc2, (q15_t)0xe82a, (q15_t)0x7dc1, (q15_t)0xe823, (q15_t)0x7dc0, (q15_t)0xe81d, + (q15_t)0x7dbf, (q15_t)0xe817, (q15_t)0x7dbd, (q15_t)0xe811, (q15_t)0x7dbc, (q15_t)0xe80b, (q15_t)0x7dbb, (q15_t)0xe805, + (q15_t)0x7dba, (q15_t)0xe7fe, (q15_t)0x7db9, (q15_t)0xe7f8, (q15_t)0x7db8, (q15_t)0xe7f2, (q15_t)0x7db6, (q15_t)0xe7ec, + (q15_t)0x7db5, (q15_t)0xe7e6, (q15_t)0x7db4, (q15_t)0xe7e0, (q15_t)0x7db3, (q15_t)0xe7d9, (q15_t)0x7db2, (q15_t)0xe7d3, + (q15_t)0x7db0, (q15_t)0xe7cd, (q15_t)0x7daf, (q15_t)0xe7c7, (q15_t)0x7dae, (q15_t)0xe7c1, (q15_t)0x7dad, (q15_t)0xe7bb, + (q15_t)0x7dac, (q15_t)0xe7b4, (q15_t)0x7dab, (q15_t)0xe7ae, (q15_t)0x7da9, (q15_t)0xe7a8, (q15_t)0x7da8, (q15_t)0xe7a2, + (q15_t)0x7da7, (q15_t)0xe79c, (q15_t)0x7da6, (q15_t)0xe796, (q15_t)0x7da5, (q15_t)0xe78f, (q15_t)0x7da3, (q15_t)0xe789, + (q15_t)0x7da2, (q15_t)0xe783, (q15_t)0x7da1, (q15_t)0xe77d, (q15_t)0x7da0, (q15_t)0xe777, (q15_t)0x7d9f, (q15_t)0xe771, + (q15_t)0x7d9d, (q15_t)0xe76a, (q15_t)0x7d9c, (q15_t)0xe764, (q15_t)0x7d9b, (q15_t)0xe75e, (q15_t)0x7d9a, (q15_t)0xe758, + (q15_t)0x7d98, (q15_t)0xe752, (q15_t)0x7d97, (q15_t)0xe74c, (q15_t)0x7d96, (q15_t)0xe745, (q15_t)0x7d95, (q15_t)0xe73f, + (q15_t)0x7d94, (q15_t)0xe739, (q15_t)0x7d92, (q15_t)0xe733, (q15_t)0x7d91, (q15_t)0xe72d, (q15_t)0x7d90, (q15_t)0xe727, + (q15_t)0x7d8f, (q15_t)0xe720, (q15_t)0x7d8e, (q15_t)0xe71a, (q15_t)0x7d8c, (q15_t)0xe714, (q15_t)0x7d8b, (q15_t)0xe70e, + (q15_t)0x7d8a, (q15_t)0xe708, (q15_t)0x7d89, (q15_t)0xe702, (q15_t)0x7d87, (q15_t)0xe6fb, (q15_t)0x7d86, (q15_t)0xe6f5, + (q15_t)0x7d85, (q15_t)0xe6ef, (q15_t)0x7d84, (q15_t)0xe6e9, (q15_t)0x7d82, (q15_t)0xe6e3, (q15_t)0x7d81, (q15_t)0xe6dd, + (q15_t)0x7d80, (q15_t)0xe6d6, (q15_t)0x7d7f, (q15_t)0xe6d0, (q15_t)0x7d7e, (q15_t)0xe6ca, (q15_t)0x7d7c, (q15_t)0xe6c4, + (q15_t)0x7d7b, (q15_t)0xe6be, (q15_t)0x7d7a, (q15_t)0xe6b8, (q15_t)0x7d79, (q15_t)0xe6b2, (q15_t)0x7d77, (q15_t)0xe6ab, + (q15_t)0x7d76, (q15_t)0xe6a5, (q15_t)0x7d75, (q15_t)0xe69f, (q15_t)0x7d74, (q15_t)0xe699, (q15_t)0x7d72, (q15_t)0xe693, + (q15_t)0x7d71, (q15_t)0xe68d, (q15_t)0x7d70, (q15_t)0xe686, (q15_t)0x7d6f, (q15_t)0xe680, (q15_t)0x7d6d, (q15_t)0xe67a, + (q15_t)0x7d6c, (q15_t)0xe674, (q15_t)0x7d6b, (q15_t)0xe66e, (q15_t)0x7d6a, (q15_t)0xe668, (q15_t)0x7d68, (q15_t)0xe661, + (q15_t)0x7d67, (q15_t)0xe65b, (q15_t)0x7d66, (q15_t)0xe655, (q15_t)0x7d65, (q15_t)0xe64f, (q15_t)0x7d63, (q15_t)0xe649, + (q15_t)0x7d62, (q15_t)0xe643, (q15_t)0x7d61, (q15_t)0xe63d, (q15_t)0x7d60, (q15_t)0xe636, (q15_t)0x7d5e, (q15_t)0xe630, + (q15_t)0x7d5d, (q15_t)0xe62a, (q15_t)0x7d5c, (q15_t)0xe624, (q15_t)0x7d5a, (q15_t)0xe61e, (q15_t)0x7d59, (q15_t)0xe618, + (q15_t)0x7d58, (q15_t)0xe611, (q15_t)0x7d57, (q15_t)0xe60b, (q15_t)0x7d55, (q15_t)0xe605, (q15_t)0x7d54, (q15_t)0xe5ff, + (q15_t)0x7d53, (q15_t)0xe5f9, (q15_t)0x7d52, (q15_t)0xe5f3, (q15_t)0x7d50, (q15_t)0xe5ed, (q15_t)0x7d4f, (q15_t)0xe5e6, + (q15_t)0x7d4e, (q15_t)0xe5e0, (q15_t)0x7d4c, (q15_t)0xe5da, (q15_t)0x7d4b, (q15_t)0xe5d4, (q15_t)0x7d4a, (q15_t)0xe5ce, + (q15_t)0x7d49, (q15_t)0xe5c8, (q15_t)0x7d47, (q15_t)0xe5c2, (q15_t)0x7d46, (q15_t)0xe5bb, (q15_t)0x7d45, (q15_t)0xe5b5, + (q15_t)0x7d43, (q15_t)0xe5af, (q15_t)0x7d42, (q15_t)0xe5a9, (q15_t)0x7d41, (q15_t)0xe5a3, (q15_t)0x7d3f, (q15_t)0xe59d, + (q15_t)0x7d3e, (q15_t)0xe596, (q15_t)0x7d3d, (q15_t)0xe590, (q15_t)0x7d3c, (q15_t)0xe58a, (q15_t)0x7d3a, (q15_t)0xe584, + (q15_t)0x7d39, (q15_t)0xe57e, (q15_t)0x7d38, (q15_t)0xe578, (q15_t)0x7d36, (q15_t)0xe572, (q15_t)0x7d35, (q15_t)0xe56b, + (q15_t)0x7d34, (q15_t)0xe565, (q15_t)0x7d32, (q15_t)0xe55f, (q15_t)0x7d31, (q15_t)0xe559, (q15_t)0x7d30, (q15_t)0xe553, + (q15_t)0x7d2f, (q15_t)0xe54d, (q15_t)0x7d2d, (q15_t)0xe547, (q15_t)0x7d2c, (q15_t)0xe540, (q15_t)0x7d2b, (q15_t)0xe53a, + (q15_t)0x7d29, (q15_t)0xe534, (q15_t)0x7d28, (q15_t)0xe52e, (q15_t)0x7d27, (q15_t)0xe528, (q15_t)0x7d25, (q15_t)0xe522, + (q15_t)0x7d24, (q15_t)0xe51c, (q15_t)0x7d23, (q15_t)0xe515, (q15_t)0x7d21, (q15_t)0xe50f, (q15_t)0x7d20, (q15_t)0xe509, + (q15_t)0x7d1f, (q15_t)0xe503, (q15_t)0x7d1d, (q15_t)0xe4fd, (q15_t)0x7d1c, (q15_t)0xe4f7, (q15_t)0x7d1b, (q15_t)0xe4f1, + (q15_t)0x7d19, (q15_t)0xe4ea, (q15_t)0x7d18, (q15_t)0xe4e4, (q15_t)0x7d17, (q15_t)0xe4de, (q15_t)0x7d15, (q15_t)0xe4d8, + (q15_t)0x7d14, (q15_t)0xe4d2, (q15_t)0x7d13, (q15_t)0xe4cc, (q15_t)0x7d11, (q15_t)0xe4c6, (q15_t)0x7d10, (q15_t)0xe4bf, + (q15_t)0x7d0f, (q15_t)0xe4b9, (q15_t)0x7d0d, (q15_t)0xe4b3, (q15_t)0x7d0c, (q15_t)0xe4ad, (q15_t)0x7d0b, (q15_t)0xe4a7, + (q15_t)0x7d09, (q15_t)0xe4a1, (q15_t)0x7d08, (q15_t)0xe49b, (q15_t)0x7d07, (q15_t)0xe494, (q15_t)0x7d05, (q15_t)0xe48e, + (q15_t)0x7d04, (q15_t)0xe488, (q15_t)0x7d03, (q15_t)0xe482, (q15_t)0x7d01, (q15_t)0xe47c, (q15_t)0x7d00, (q15_t)0xe476, + (q15_t)0x7cff, (q15_t)0xe470, (q15_t)0x7cfd, (q15_t)0xe46a, (q15_t)0x7cfc, (q15_t)0xe463, (q15_t)0x7cfb, (q15_t)0xe45d, + (q15_t)0x7cf9, (q15_t)0xe457, (q15_t)0x7cf8, (q15_t)0xe451, (q15_t)0x7cf6, (q15_t)0xe44b, (q15_t)0x7cf5, (q15_t)0xe445, + (q15_t)0x7cf4, (q15_t)0xe43f, (q15_t)0x7cf2, (q15_t)0xe438, (q15_t)0x7cf1, (q15_t)0xe432, (q15_t)0x7cf0, (q15_t)0xe42c, + (q15_t)0x7cee, (q15_t)0xe426, (q15_t)0x7ced, (q15_t)0xe420, (q15_t)0x7cec, (q15_t)0xe41a, (q15_t)0x7cea, (q15_t)0xe414, + (q15_t)0x7ce9, (q15_t)0xe40e, (q15_t)0x7ce7, (q15_t)0xe407, (q15_t)0x7ce6, (q15_t)0xe401, (q15_t)0x7ce5, (q15_t)0xe3fb, + (q15_t)0x7ce3, (q15_t)0xe3f5, (q15_t)0x7ce2, (q15_t)0xe3ef, (q15_t)0x7ce1, (q15_t)0xe3e9, (q15_t)0x7cdf, (q15_t)0xe3e3, + (q15_t)0x7cde, (q15_t)0xe3dc, (q15_t)0x7cdc, (q15_t)0xe3d6, (q15_t)0x7cdb, (q15_t)0xe3d0, (q15_t)0x7cda, (q15_t)0xe3ca, + (q15_t)0x7cd8, (q15_t)0xe3c4, (q15_t)0x7cd7, (q15_t)0xe3be, (q15_t)0x7cd5, (q15_t)0xe3b8, (q15_t)0x7cd4, (q15_t)0xe3b2, + (q15_t)0x7cd3, (q15_t)0xe3ab, (q15_t)0x7cd1, (q15_t)0xe3a5, (q15_t)0x7cd0, (q15_t)0xe39f, (q15_t)0x7ccf, (q15_t)0xe399, + (q15_t)0x7ccd, (q15_t)0xe393, (q15_t)0x7ccc, (q15_t)0xe38d, (q15_t)0x7cca, (q15_t)0xe387, (q15_t)0x7cc9, (q15_t)0xe381, + (q15_t)0x7cc8, (q15_t)0xe37a, (q15_t)0x7cc6, (q15_t)0xe374, (q15_t)0x7cc5, (q15_t)0xe36e, (q15_t)0x7cc3, (q15_t)0xe368, + (q15_t)0x7cc2, (q15_t)0xe362, (q15_t)0x7cc1, (q15_t)0xe35c, (q15_t)0x7cbf, (q15_t)0xe356, (q15_t)0x7cbe, (q15_t)0xe350, + (q15_t)0x7cbc, (q15_t)0xe349, (q15_t)0x7cbb, (q15_t)0xe343, (q15_t)0x7cb9, (q15_t)0xe33d, (q15_t)0x7cb8, (q15_t)0xe337, + (q15_t)0x7cb7, (q15_t)0xe331, (q15_t)0x7cb5, (q15_t)0xe32b, (q15_t)0x7cb4, (q15_t)0xe325, (q15_t)0x7cb2, (q15_t)0xe31f, + (q15_t)0x7cb1, (q15_t)0xe318, (q15_t)0x7cb0, (q15_t)0xe312, (q15_t)0x7cae, (q15_t)0xe30c, (q15_t)0x7cad, (q15_t)0xe306, + (q15_t)0x7cab, (q15_t)0xe300, (q15_t)0x7caa, (q15_t)0xe2fa, (q15_t)0x7ca8, (q15_t)0xe2f4, (q15_t)0x7ca7, (q15_t)0xe2ee, + (q15_t)0x7ca6, (q15_t)0xe2e8, (q15_t)0x7ca4, (q15_t)0xe2e1, (q15_t)0x7ca3, (q15_t)0xe2db, (q15_t)0x7ca1, (q15_t)0xe2d5, + (q15_t)0x7ca0, (q15_t)0xe2cf, (q15_t)0x7c9e, (q15_t)0xe2c9, (q15_t)0x7c9d, (q15_t)0xe2c3, (q15_t)0x7c9c, (q15_t)0xe2bd, + (q15_t)0x7c9a, (q15_t)0xe2b7, (q15_t)0x7c99, (q15_t)0xe2b0, (q15_t)0x7c97, (q15_t)0xe2aa, (q15_t)0x7c96, (q15_t)0xe2a4, + (q15_t)0x7c94, (q15_t)0xe29e, (q15_t)0x7c93, (q15_t)0xe298, (q15_t)0x7c91, (q15_t)0xe292, (q15_t)0x7c90, (q15_t)0xe28c, + (q15_t)0x7c8f, (q15_t)0xe286, (q15_t)0x7c8d, (q15_t)0xe280, (q15_t)0x7c8c, (q15_t)0xe279, (q15_t)0x7c8a, (q15_t)0xe273, + (q15_t)0x7c89, (q15_t)0xe26d, (q15_t)0x7c87, (q15_t)0xe267, (q15_t)0x7c86, (q15_t)0xe261, (q15_t)0x7c84, (q15_t)0xe25b, + (q15_t)0x7c83, (q15_t)0xe255, (q15_t)0x7c82, (q15_t)0xe24f, (q15_t)0x7c80, (q15_t)0xe249, (q15_t)0x7c7f, (q15_t)0xe242, + (q15_t)0x7c7d, (q15_t)0xe23c, (q15_t)0x7c7c, (q15_t)0xe236, (q15_t)0x7c7a, (q15_t)0xe230, (q15_t)0x7c79, (q15_t)0xe22a, + (q15_t)0x7c77, (q15_t)0xe224, (q15_t)0x7c76, (q15_t)0xe21e, (q15_t)0x7c74, (q15_t)0xe218, (q15_t)0x7c73, (q15_t)0xe212, + (q15_t)0x7c71, (q15_t)0xe20b, (q15_t)0x7c70, (q15_t)0xe205, (q15_t)0x7c6e, (q15_t)0xe1ff, (q15_t)0x7c6d, (q15_t)0xe1f9, + (q15_t)0x7c6c, (q15_t)0xe1f3, (q15_t)0x7c6a, (q15_t)0xe1ed, (q15_t)0x7c69, (q15_t)0xe1e7, (q15_t)0x7c67, (q15_t)0xe1e1, + (q15_t)0x7c66, (q15_t)0xe1db, (q15_t)0x7c64, (q15_t)0xe1d4, (q15_t)0x7c63, (q15_t)0xe1ce, (q15_t)0x7c61, (q15_t)0xe1c8, + (q15_t)0x7c60, (q15_t)0xe1c2, (q15_t)0x7c5e, (q15_t)0xe1bc, (q15_t)0x7c5d, (q15_t)0xe1b6, (q15_t)0x7c5b, (q15_t)0xe1b0, + (q15_t)0x7c5a, (q15_t)0xe1aa, (q15_t)0x7c58, (q15_t)0xe1a4, (q15_t)0x7c57, (q15_t)0xe19e, (q15_t)0x7c55, (q15_t)0xe197, + (q15_t)0x7c54, (q15_t)0xe191, (q15_t)0x7c52, (q15_t)0xe18b, (q15_t)0x7c51, (q15_t)0xe185, (q15_t)0x7c4f, (q15_t)0xe17f, + (q15_t)0x7c4e, (q15_t)0xe179, (q15_t)0x7c4c, (q15_t)0xe173, (q15_t)0x7c4b, (q15_t)0xe16d, (q15_t)0x7c49, (q15_t)0xe167, + (q15_t)0x7c48, (q15_t)0xe160, (q15_t)0x7c46, (q15_t)0xe15a, (q15_t)0x7c45, (q15_t)0xe154, (q15_t)0x7c43, (q15_t)0xe14e, + (q15_t)0x7c42, (q15_t)0xe148, (q15_t)0x7c40, (q15_t)0xe142, (q15_t)0x7c3f, (q15_t)0xe13c, (q15_t)0x7c3d, (q15_t)0xe136, + (q15_t)0x7c3c, (q15_t)0xe130, (q15_t)0x7c3a, (q15_t)0xe12a, (q15_t)0x7c39, (q15_t)0xe123, (q15_t)0x7c37, (q15_t)0xe11d, + (q15_t)0x7c36, (q15_t)0xe117, (q15_t)0x7c34, (q15_t)0xe111, (q15_t)0x7c33, (q15_t)0xe10b, (q15_t)0x7c31, (q15_t)0xe105, + (q15_t)0x7c30, (q15_t)0xe0ff, (q15_t)0x7c2e, (q15_t)0xe0f9, (q15_t)0x7c2d, (q15_t)0xe0f3, (q15_t)0x7c2b, (q15_t)0xe0ed, + (q15_t)0x7c29, (q15_t)0xe0e7, (q15_t)0x7c28, (q15_t)0xe0e0, (q15_t)0x7c26, (q15_t)0xe0da, (q15_t)0x7c25, (q15_t)0xe0d4, + (q15_t)0x7c23, (q15_t)0xe0ce, (q15_t)0x7c22, (q15_t)0xe0c8, (q15_t)0x7c20, (q15_t)0xe0c2, (q15_t)0x7c1f, (q15_t)0xe0bc, + (q15_t)0x7c1d, (q15_t)0xe0b6, (q15_t)0x7c1c, (q15_t)0xe0b0, (q15_t)0x7c1a, (q15_t)0xe0aa, (q15_t)0x7c19, (q15_t)0xe0a3, + (q15_t)0x7c17, (q15_t)0xe09d, (q15_t)0x7c16, (q15_t)0xe097, (q15_t)0x7c14, (q15_t)0xe091, (q15_t)0x7c12, (q15_t)0xe08b, + (q15_t)0x7c11, (q15_t)0xe085, (q15_t)0x7c0f, (q15_t)0xe07f, (q15_t)0x7c0e, (q15_t)0xe079, (q15_t)0x7c0c, (q15_t)0xe073, + (q15_t)0x7c0b, (q15_t)0xe06d, (q15_t)0x7c09, (q15_t)0xe067, (q15_t)0x7c08, (q15_t)0xe061, (q15_t)0x7c06, (q15_t)0xe05a, + (q15_t)0x7c05, (q15_t)0xe054, (q15_t)0x7c03, (q15_t)0xe04e, (q15_t)0x7c01, (q15_t)0xe048, (q15_t)0x7c00, (q15_t)0xe042, + (q15_t)0x7bfe, (q15_t)0xe03c, (q15_t)0x7bfd, (q15_t)0xe036, (q15_t)0x7bfb, (q15_t)0xe030, (q15_t)0x7bfa, (q15_t)0xe02a, + (q15_t)0x7bf8, (q15_t)0xe024, (q15_t)0x7bf6, (q15_t)0xe01e, (q15_t)0x7bf5, (q15_t)0xe017, (q15_t)0x7bf3, (q15_t)0xe011, + (q15_t)0x7bf2, (q15_t)0xe00b, (q15_t)0x7bf0, (q15_t)0xe005, (q15_t)0x7bef, (q15_t)0xdfff, (q15_t)0x7bed, (q15_t)0xdff9, + (q15_t)0x7beb, (q15_t)0xdff3, (q15_t)0x7bea, (q15_t)0xdfed, (q15_t)0x7be8, (q15_t)0xdfe7, (q15_t)0x7be7, (q15_t)0xdfe1, + (q15_t)0x7be5, (q15_t)0xdfdb, (q15_t)0x7be4, (q15_t)0xdfd5, (q15_t)0x7be2, (q15_t)0xdfce, (q15_t)0x7be0, (q15_t)0xdfc8, + (q15_t)0x7bdf, (q15_t)0xdfc2, (q15_t)0x7bdd, (q15_t)0xdfbc, (q15_t)0x7bdc, (q15_t)0xdfb6, (q15_t)0x7bda, (q15_t)0xdfb0, + (q15_t)0x7bd9, (q15_t)0xdfaa, (q15_t)0x7bd7, (q15_t)0xdfa4, (q15_t)0x7bd5, (q15_t)0xdf9e, (q15_t)0x7bd4, (q15_t)0xdf98, + (q15_t)0x7bd2, (q15_t)0xdf92, (q15_t)0x7bd1, (q15_t)0xdf8c, (q15_t)0x7bcf, (q15_t)0xdf86, (q15_t)0x7bcd, (q15_t)0xdf7f, + (q15_t)0x7bcc, (q15_t)0xdf79, (q15_t)0x7bca, (q15_t)0xdf73, (q15_t)0x7bc9, (q15_t)0xdf6d, (q15_t)0x7bc7, (q15_t)0xdf67, + (q15_t)0x7bc5, (q15_t)0xdf61, (q15_t)0x7bc4, (q15_t)0xdf5b, (q15_t)0x7bc2, (q15_t)0xdf55, (q15_t)0x7bc1, (q15_t)0xdf4f, + (q15_t)0x7bbf, (q15_t)0xdf49, (q15_t)0x7bbd, (q15_t)0xdf43, (q15_t)0x7bbc, (q15_t)0xdf3d, (q15_t)0x7bba, (q15_t)0xdf37, + (q15_t)0x7bb9, (q15_t)0xdf30, (q15_t)0x7bb7, (q15_t)0xdf2a, (q15_t)0x7bb5, (q15_t)0xdf24, (q15_t)0x7bb4, (q15_t)0xdf1e, + (q15_t)0x7bb2, (q15_t)0xdf18, (q15_t)0x7bb0, (q15_t)0xdf12, (q15_t)0x7baf, (q15_t)0xdf0c, (q15_t)0x7bad, (q15_t)0xdf06, + (q15_t)0x7bac, (q15_t)0xdf00, (q15_t)0x7baa, (q15_t)0xdefa, (q15_t)0x7ba8, (q15_t)0xdef4, (q15_t)0x7ba7, (q15_t)0xdeee, + (q15_t)0x7ba5, (q15_t)0xdee8, (q15_t)0x7ba3, (q15_t)0xdee2, (q15_t)0x7ba2, (q15_t)0xdedb, (q15_t)0x7ba0, (q15_t)0xded5, + (q15_t)0x7b9f, (q15_t)0xdecf, (q15_t)0x7b9d, (q15_t)0xdec9, (q15_t)0x7b9b, (q15_t)0xdec3, (q15_t)0x7b9a, (q15_t)0xdebd, + (q15_t)0x7b98, (q15_t)0xdeb7, (q15_t)0x7b96, (q15_t)0xdeb1, (q15_t)0x7b95, (q15_t)0xdeab, (q15_t)0x7b93, (q15_t)0xdea5, + (q15_t)0x7b92, (q15_t)0xde9f, (q15_t)0x7b90, (q15_t)0xde99, (q15_t)0x7b8e, (q15_t)0xde93, (q15_t)0x7b8d, (q15_t)0xde8d, + (q15_t)0x7b8b, (q15_t)0xde87, (q15_t)0x7b89, (q15_t)0xde80, (q15_t)0x7b88, (q15_t)0xde7a, (q15_t)0x7b86, (q15_t)0xde74, + (q15_t)0x7b84, (q15_t)0xde6e, (q15_t)0x7b83, (q15_t)0xde68, (q15_t)0x7b81, (q15_t)0xde62, (q15_t)0x7b7f, (q15_t)0xde5c, + (q15_t)0x7b7e, (q15_t)0xde56, (q15_t)0x7b7c, (q15_t)0xde50, (q15_t)0x7b7a, (q15_t)0xde4a, (q15_t)0x7b79, (q15_t)0xde44, + (q15_t)0x7b77, (q15_t)0xde3e, (q15_t)0x7b76, (q15_t)0xde38, (q15_t)0x7b74, (q15_t)0xde32, (q15_t)0x7b72, (q15_t)0xde2c, + (q15_t)0x7b71, (q15_t)0xde26, (q15_t)0x7b6f, (q15_t)0xde1f, (q15_t)0x7b6d, (q15_t)0xde19, (q15_t)0x7b6c, (q15_t)0xde13, + (q15_t)0x7b6a, (q15_t)0xde0d, (q15_t)0x7b68, (q15_t)0xde07, (q15_t)0x7b67, (q15_t)0xde01, (q15_t)0x7b65, (q15_t)0xddfb, + (q15_t)0x7b63, (q15_t)0xddf5, (q15_t)0x7b62, (q15_t)0xddef, (q15_t)0x7b60, (q15_t)0xdde9, (q15_t)0x7b5e, (q15_t)0xdde3, + (q15_t)0x7b5d, (q15_t)0xdddd, (q15_t)0x7b5b, (q15_t)0xddd7, (q15_t)0x7b59, (q15_t)0xddd1, (q15_t)0x7b57, (q15_t)0xddcb, + (q15_t)0x7b56, (q15_t)0xddc5, (q15_t)0x7b54, (q15_t)0xddbf, (q15_t)0x7b52, (q15_t)0xddb9, (q15_t)0x7b51, (q15_t)0xddb2, + (q15_t)0x7b4f, (q15_t)0xddac, (q15_t)0x7b4d, (q15_t)0xdda6, (q15_t)0x7b4c, (q15_t)0xdda0, (q15_t)0x7b4a, (q15_t)0xdd9a, + (q15_t)0x7b48, (q15_t)0xdd94, (q15_t)0x7b47, (q15_t)0xdd8e, (q15_t)0x7b45, (q15_t)0xdd88, (q15_t)0x7b43, (q15_t)0xdd82, + (q15_t)0x7b42, (q15_t)0xdd7c, (q15_t)0x7b40, (q15_t)0xdd76, (q15_t)0x7b3e, (q15_t)0xdd70, (q15_t)0x7b3c, (q15_t)0xdd6a, + (q15_t)0x7b3b, (q15_t)0xdd64, (q15_t)0x7b39, (q15_t)0xdd5e, (q15_t)0x7b37, (q15_t)0xdd58, (q15_t)0x7b36, (q15_t)0xdd52, + (q15_t)0x7b34, (q15_t)0xdd4c, (q15_t)0x7b32, (q15_t)0xdd46, (q15_t)0x7b31, (q15_t)0xdd40, (q15_t)0x7b2f, (q15_t)0xdd39, + (q15_t)0x7b2d, (q15_t)0xdd33, (q15_t)0x7b2b, (q15_t)0xdd2d, (q15_t)0x7b2a, (q15_t)0xdd27, (q15_t)0x7b28, (q15_t)0xdd21, + (q15_t)0x7b26, (q15_t)0xdd1b, (q15_t)0x7b25, (q15_t)0xdd15, (q15_t)0x7b23, (q15_t)0xdd0f, (q15_t)0x7b21, (q15_t)0xdd09, + (q15_t)0x7b1f, (q15_t)0xdd03, (q15_t)0x7b1e, (q15_t)0xdcfd, (q15_t)0x7b1c, (q15_t)0xdcf7, (q15_t)0x7b1a, (q15_t)0xdcf1, + (q15_t)0x7b19, (q15_t)0xdceb, (q15_t)0x7b17, (q15_t)0xdce5, (q15_t)0x7b15, (q15_t)0xdcdf, (q15_t)0x7b13, (q15_t)0xdcd9, + (q15_t)0x7b12, (q15_t)0xdcd3, (q15_t)0x7b10, (q15_t)0xdccd, (q15_t)0x7b0e, (q15_t)0xdcc7, (q15_t)0x7b0c, (q15_t)0xdcc1, + (q15_t)0x7b0b, (q15_t)0xdcbb, (q15_t)0x7b09, (q15_t)0xdcb5, (q15_t)0x7b07, (q15_t)0xdcae, (q15_t)0x7b06, (q15_t)0xdca8, + (q15_t)0x7b04, (q15_t)0xdca2, (q15_t)0x7b02, (q15_t)0xdc9c, (q15_t)0x7b00, (q15_t)0xdc96, (q15_t)0x7aff, (q15_t)0xdc90, + (q15_t)0x7afd, (q15_t)0xdc8a, (q15_t)0x7afb, (q15_t)0xdc84, (q15_t)0x7af9, (q15_t)0xdc7e, (q15_t)0x7af8, (q15_t)0xdc78, + (q15_t)0x7af6, (q15_t)0xdc72, (q15_t)0x7af4, (q15_t)0xdc6c, (q15_t)0x7af2, (q15_t)0xdc66, (q15_t)0x7af1, (q15_t)0xdc60, + (q15_t)0x7aef, (q15_t)0xdc5a, (q15_t)0x7aed, (q15_t)0xdc54, (q15_t)0x7aeb, (q15_t)0xdc4e, (q15_t)0x7aea, (q15_t)0xdc48, + (q15_t)0x7ae8, (q15_t)0xdc42, (q15_t)0x7ae6, (q15_t)0xdc3c, (q15_t)0x7ae4, (q15_t)0xdc36, (q15_t)0x7ae3, (q15_t)0xdc30, + (q15_t)0x7ae1, (q15_t)0xdc2a, (q15_t)0x7adf, (q15_t)0xdc24, (q15_t)0x7add, (q15_t)0xdc1e, (q15_t)0x7adc, (q15_t)0xdc18, + (q15_t)0x7ada, (q15_t)0xdc12, (q15_t)0x7ad8, (q15_t)0xdc0c, (q15_t)0x7ad6, (q15_t)0xdc06, (q15_t)0x7ad5, (q15_t)0xdbff, + (q15_t)0x7ad3, (q15_t)0xdbf9, (q15_t)0x7ad1, (q15_t)0xdbf3, (q15_t)0x7acf, (q15_t)0xdbed, (q15_t)0x7acd, (q15_t)0xdbe7, + (q15_t)0x7acc, (q15_t)0xdbe1, (q15_t)0x7aca, (q15_t)0xdbdb, (q15_t)0x7ac8, (q15_t)0xdbd5, (q15_t)0x7ac6, (q15_t)0xdbcf, + (q15_t)0x7ac5, (q15_t)0xdbc9, (q15_t)0x7ac3, (q15_t)0xdbc3, (q15_t)0x7ac1, (q15_t)0xdbbd, (q15_t)0x7abf, (q15_t)0xdbb7, + (q15_t)0x7abd, (q15_t)0xdbb1, (q15_t)0x7abc, (q15_t)0xdbab, (q15_t)0x7aba, (q15_t)0xdba5, (q15_t)0x7ab8, (q15_t)0xdb9f, + (q15_t)0x7ab6, (q15_t)0xdb99, (q15_t)0x7ab5, (q15_t)0xdb93, (q15_t)0x7ab3, (q15_t)0xdb8d, (q15_t)0x7ab1, (q15_t)0xdb87, + (q15_t)0x7aaf, (q15_t)0xdb81, (q15_t)0x7aad, (q15_t)0xdb7b, (q15_t)0x7aac, (q15_t)0xdb75, (q15_t)0x7aaa, (q15_t)0xdb6f, + (q15_t)0x7aa8, (q15_t)0xdb69, (q15_t)0x7aa6, (q15_t)0xdb63, (q15_t)0x7aa4, (q15_t)0xdb5d, (q15_t)0x7aa3, (q15_t)0xdb57, + (q15_t)0x7aa1, (q15_t)0xdb51, (q15_t)0x7a9f, (q15_t)0xdb4b, (q15_t)0x7a9d, (q15_t)0xdb45, (q15_t)0x7a9b, (q15_t)0xdb3f, + (q15_t)0x7a9a, (q15_t)0xdb39, (q15_t)0x7a98, (q15_t)0xdb33, (q15_t)0x7a96, (q15_t)0xdb2d, (q15_t)0x7a94, (q15_t)0xdb27, + (q15_t)0x7a92, (q15_t)0xdb21, (q15_t)0x7a91, (q15_t)0xdb1b, (q15_t)0x7a8f, (q15_t)0xdb15, (q15_t)0x7a8d, (q15_t)0xdb0f, + (q15_t)0x7a8b, (q15_t)0xdb09, (q15_t)0x7a89, (q15_t)0xdb03, (q15_t)0x7a87, (q15_t)0xdafd, (q15_t)0x7a86, (q15_t)0xdaf7, + (q15_t)0x7a84, (q15_t)0xdaf1, (q15_t)0x7a82, (q15_t)0xdaea, (q15_t)0x7a80, (q15_t)0xdae4, (q15_t)0x7a7e, (q15_t)0xdade, + (q15_t)0x7a7d, (q15_t)0xdad8, (q15_t)0x7a7b, (q15_t)0xdad2, (q15_t)0x7a79, (q15_t)0xdacc, (q15_t)0x7a77, (q15_t)0xdac6, + (q15_t)0x7a75, (q15_t)0xdac0, (q15_t)0x7a73, (q15_t)0xdaba, (q15_t)0x7a72, (q15_t)0xdab4, (q15_t)0x7a70, (q15_t)0xdaae, + (q15_t)0x7a6e, (q15_t)0xdaa8, (q15_t)0x7a6c, (q15_t)0xdaa2, (q15_t)0x7a6a, (q15_t)0xda9c, (q15_t)0x7a68, (q15_t)0xda96, + (q15_t)0x7a67, (q15_t)0xda90, (q15_t)0x7a65, (q15_t)0xda8a, (q15_t)0x7a63, (q15_t)0xda84, (q15_t)0x7a61, (q15_t)0xda7e, + (q15_t)0x7a5f, (q15_t)0xda78, (q15_t)0x7a5d, (q15_t)0xda72, (q15_t)0x7a5c, (q15_t)0xda6c, (q15_t)0x7a5a, (q15_t)0xda66, + (q15_t)0x7a58, (q15_t)0xda60, (q15_t)0x7a56, (q15_t)0xda5a, (q15_t)0x7a54, (q15_t)0xda54, (q15_t)0x7a52, (q15_t)0xda4e, + (q15_t)0x7a50, (q15_t)0xda48, (q15_t)0x7a4f, (q15_t)0xda42, (q15_t)0x7a4d, (q15_t)0xda3c, (q15_t)0x7a4b, (q15_t)0xda36, + (q15_t)0x7a49, (q15_t)0xda30, (q15_t)0x7a47, (q15_t)0xda2a, (q15_t)0x7a45, (q15_t)0xda24, (q15_t)0x7a43, (q15_t)0xda1e, + (q15_t)0x7a42, (q15_t)0xda18, (q15_t)0x7a40, (q15_t)0xda12, (q15_t)0x7a3e, (q15_t)0xda0c, (q15_t)0x7a3c, (q15_t)0xda06, + (q15_t)0x7a3a, (q15_t)0xda00, (q15_t)0x7a38, (q15_t)0xd9fa, (q15_t)0x7a36, (q15_t)0xd9f4, (q15_t)0x7a35, (q15_t)0xd9ee, + (q15_t)0x7a33, (q15_t)0xd9e8, (q15_t)0x7a31, (q15_t)0xd9e2, (q15_t)0x7a2f, (q15_t)0xd9dc, (q15_t)0x7a2d, (q15_t)0xd9d6, + (q15_t)0x7a2b, (q15_t)0xd9d0, (q15_t)0x7a29, (q15_t)0xd9ca, (q15_t)0x7a27, (q15_t)0xd9c4, (q15_t)0x7a26, (q15_t)0xd9be, + (q15_t)0x7a24, (q15_t)0xd9b8, (q15_t)0x7a22, (q15_t)0xd9b2, (q15_t)0x7a20, (q15_t)0xd9ac, (q15_t)0x7a1e, (q15_t)0xd9a6, + (q15_t)0x7a1c, (q15_t)0xd9a0, (q15_t)0x7a1a, (q15_t)0xd99a, (q15_t)0x7a18, (q15_t)0xd994, (q15_t)0x7a16, (q15_t)0xd98e, + (q15_t)0x7a15, (q15_t)0xd988, (q15_t)0x7a13, (q15_t)0xd982, (q15_t)0x7a11, (q15_t)0xd97c, (q15_t)0x7a0f, (q15_t)0xd976, + (q15_t)0x7a0d, (q15_t)0xd970, (q15_t)0x7a0b, (q15_t)0xd96a, (q15_t)0x7a09, (q15_t)0xd964, (q15_t)0x7a07, (q15_t)0xd95e, + (q15_t)0x7a05, (q15_t)0xd958, (q15_t)0x7a04, (q15_t)0xd952, (q15_t)0x7a02, (q15_t)0xd94c, (q15_t)0x7a00, (q15_t)0xd946, + (q15_t)0x79fe, (q15_t)0xd940, (q15_t)0x79fc, (q15_t)0xd93a, (q15_t)0x79fa, (q15_t)0xd934, (q15_t)0x79f8, (q15_t)0xd92e, + (q15_t)0x79f6, (q15_t)0xd928, (q15_t)0x79f4, (q15_t)0xd922, (q15_t)0x79f2, (q15_t)0xd91c, (q15_t)0x79f0, (q15_t)0xd917, + (q15_t)0x79ef, (q15_t)0xd911, (q15_t)0x79ed, (q15_t)0xd90b, (q15_t)0x79eb, (q15_t)0xd905, (q15_t)0x79e9, (q15_t)0xd8ff, + (q15_t)0x79e7, (q15_t)0xd8f9, (q15_t)0x79e5, (q15_t)0xd8f3, (q15_t)0x79e3, (q15_t)0xd8ed, (q15_t)0x79e1, (q15_t)0xd8e7, + (q15_t)0x79df, (q15_t)0xd8e1, (q15_t)0x79dd, (q15_t)0xd8db, (q15_t)0x79db, (q15_t)0xd8d5, (q15_t)0x79d9, (q15_t)0xd8cf, + (q15_t)0x79d8, (q15_t)0xd8c9, (q15_t)0x79d6, (q15_t)0xd8c3, (q15_t)0x79d4, (q15_t)0xd8bd, (q15_t)0x79d2, (q15_t)0xd8b7, + (q15_t)0x79d0, (q15_t)0xd8b1, (q15_t)0x79ce, (q15_t)0xd8ab, (q15_t)0x79cc, (q15_t)0xd8a5, (q15_t)0x79ca, (q15_t)0xd89f, + (q15_t)0x79c8, (q15_t)0xd899, (q15_t)0x79c6, (q15_t)0xd893, (q15_t)0x79c4, (q15_t)0xd88d, (q15_t)0x79c2, (q15_t)0xd887, + (q15_t)0x79c0, (q15_t)0xd881, (q15_t)0x79be, (q15_t)0xd87b, (q15_t)0x79bc, (q15_t)0xd875, (q15_t)0x79bb, (q15_t)0xd86f, + (q15_t)0x79b9, (q15_t)0xd869, (q15_t)0x79b7, (q15_t)0xd863, (q15_t)0x79b5, (q15_t)0xd85d, (q15_t)0x79b3, (q15_t)0xd857, + (q15_t)0x79b1, (q15_t)0xd851, (q15_t)0x79af, (q15_t)0xd84b, (q15_t)0x79ad, (q15_t)0xd845, (q15_t)0x79ab, (q15_t)0xd83f, + (q15_t)0x79a9, (q15_t)0xd839, (q15_t)0x79a7, (q15_t)0xd833, (q15_t)0x79a5, (q15_t)0xd82d, (q15_t)0x79a3, (q15_t)0xd827, + (q15_t)0x79a1, (q15_t)0xd821, (q15_t)0x799f, (q15_t)0xd81b, (q15_t)0x799d, (q15_t)0xd815, (q15_t)0x799b, (q15_t)0xd80f, + (q15_t)0x7999, (q15_t)0xd80a, (q15_t)0x7997, (q15_t)0xd804, (q15_t)0x7995, (q15_t)0xd7fe, (q15_t)0x7993, (q15_t)0xd7f8, + (q15_t)0x7992, (q15_t)0xd7f2, (q15_t)0x7990, (q15_t)0xd7ec, (q15_t)0x798e, (q15_t)0xd7e6, (q15_t)0x798c, (q15_t)0xd7e0, + (q15_t)0x798a, (q15_t)0xd7da, (q15_t)0x7988, (q15_t)0xd7d4, (q15_t)0x7986, (q15_t)0xd7ce, (q15_t)0x7984, (q15_t)0xd7c8, + (q15_t)0x7982, (q15_t)0xd7c2, (q15_t)0x7980, (q15_t)0xd7bc, (q15_t)0x797e, (q15_t)0xd7b6, (q15_t)0x797c, (q15_t)0xd7b0, + (q15_t)0x797a, (q15_t)0xd7aa, (q15_t)0x7978, (q15_t)0xd7a4, (q15_t)0x7976, (q15_t)0xd79e, (q15_t)0x7974, (q15_t)0xd798, + (q15_t)0x7972, (q15_t)0xd792, (q15_t)0x7970, (q15_t)0xd78c, (q15_t)0x796e, (q15_t)0xd786, (q15_t)0x796c, (q15_t)0xd780, + (q15_t)0x796a, (q15_t)0xd77a, (q15_t)0x7968, (q15_t)0xd774, (q15_t)0x7966, (q15_t)0xd76e, (q15_t)0x7964, (q15_t)0xd768, + (q15_t)0x7962, (q15_t)0xd763, (q15_t)0x7960, (q15_t)0xd75d, (q15_t)0x795e, (q15_t)0xd757, (q15_t)0x795c, (q15_t)0xd751, + (q15_t)0x795a, (q15_t)0xd74b, (q15_t)0x7958, (q15_t)0xd745, (q15_t)0x7956, (q15_t)0xd73f, (q15_t)0x7954, (q15_t)0xd739, + (q15_t)0x7952, (q15_t)0xd733, (q15_t)0x7950, (q15_t)0xd72d, (q15_t)0x794e, (q15_t)0xd727, (q15_t)0x794c, (q15_t)0xd721, + (q15_t)0x794a, (q15_t)0xd71b, (q15_t)0x7948, (q15_t)0xd715, (q15_t)0x7946, (q15_t)0xd70f, (q15_t)0x7944, (q15_t)0xd709, + (q15_t)0x7942, (q15_t)0xd703, (q15_t)0x7940, (q15_t)0xd6fd, (q15_t)0x793e, (q15_t)0xd6f7, (q15_t)0x793c, (q15_t)0xd6f1, + (q15_t)0x793a, (q15_t)0xd6eb, (q15_t)0x7938, (q15_t)0xd6e5, (q15_t)0x7936, (q15_t)0xd6e0, (q15_t)0x7934, (q15_t)0xd6da, + (q15_t)0x7932, (q15_t)0xd6d4, (q15_t)0x7930, (q15_t)0xd6ce, (q15_t)0x792e, (q15_t)0xd6c8, (q15_t)0x792c, (q15_t)0xd6c2, + (q15_t)0x792a, (q15_t)0xd6bc, (q15_t)0x7928, (q15_t)0xd6b6, (q15_t)0x7926, (q15_t)0xd6b0, (q15_t)0x7924, (q15_t)0xd6aa, + (q15_t)0x7922, (q15_t)0xd6a4, (q15_t)0x7920, (q15_t)0xd69e, (q15_t)0x791e, (q15_t)0xd698, (q15_t)0x791c, (q15_t)0xd692, + (q15_t)0x7919, (q15_t)0xd68c, (q15_t)0x7917, (q15_t)0xd686, (q15_t)0x7915, (q15_t)0xd680, (q15_t)0x7913, (q15_t)0xd67a, + (q15_t)0x7911, (q15_t)0xd675, (q15_t)0x790f, (q15_t)0xd66f, (q15_t)0x790d, (q15_t)0xd669, (q15_t)0x790b, (q15_t)0xd663, + (q15_t)0x7909, (q15_t)0xd65d, (q15_t)0x7907, (q15_t)0xd657, (q15_t)0x7905, (q15_t)0xd651, (q15_t)0x7903, (q15_t)0xd64b, + (q15_t)0x7901, (q15_t)0xd645, (q15_t)0x78ff, (q15_t)0xd63f, (q15_t)0x78fd, (q15_t)0xd639, (q15_t)0x78fb, (q15_t)0xd633, + (q15_t)0x78f9, (q15_t)0xd62d, (q15_t)0x78f7, (q15_t)0xd627, (q15_t)0x78f5, (q15_t)0xd621, (q15_t)0x78f3, (q15_t)0xd61b, + (q15_t)0x78f1, (q15_t)0xd615, (q15_t)0x78ee, (q15_t)0xd610, (q15_t)0x78ec, (q15_t)0xd60a, (q15_t)0x78ea, (q15_t)0xd604, + (q15_t)0x78e8, (q15_t)0xd5fe, (q15_t)0x78e6, (q15_t)0xd5f8, (q15_t)0x78e4, (q15_t)0xd5f2, (q15_t)0x78e2, (q15_t)0xd5ec, + (q15_t)0x78e0, (q15_t)0xd5e6, (q15_t)0x78de, (q15_t)0xd5e0, (q15_t)0x78dc, (q15_t)0xd5da, (q15_t)0x78da, (q15_t)0xd5d4, + (q15_t)0x78d8, (q15_t)0xd5ce, (q15_t)0x78d6, (q15_t)0xd5c8, (q15_t)0x78d4, (q15_t)0xd5c2, (q15_t)0x78d2, (q15_t)0xd5bc, + (q15_t)0x78cf, (q15_t)0xd5b7, (q15_t)0x78cd, (q15_t)0xd5b1, (q15_t)0x78cb, (q15_t)0xd5ab, (q15_t)0x78c9, (q15_t)0xd5a5, + (q15_t)0x78c7, (q15_t)0xd59f, (q15_t)0x78c5, (q15_t)0xd599, (q15_t)0x78c3, (q15_t)0xd593, (q15_t)0x78c1, (q15_t)0xd58d, + (q15_t)0x78bf, (q15_t)0xd587, (q15_t)0x78bd, (q15_t)0xd581, (q15_t)0x78bb, (q15_t)0xd57b, (q15_t)0x78b9, (q15_t)0xd575, + (q15_t)0x78b6, (q15_t)0xd56f, (q15_t)0x78b4, (q15_t)0xd569, (q15_t)0x78b2, (q15_t)0xd564, (q15_t)0x78b0, (q15_t)0xd55e, + (q15_t)0x78ae, (q15_t)0xd558, (q15_t)0x78ac, (q15_t)0xd552, (q15_t)0x78aa, (q15_t)0xd54c, (q15_t)0x78a8, (q15_t)0xd546, + (q15_t)0x78a6, (q15_t)0xd540, (q15_t)0x78a4, (q15_t)0xd53a, (q15_t)0x78a2, (q15_t)0xd534, (q15_t)0x789f, (q15_t)0xd52e, + (q15_t)0x789d, (q15_t)0xd528, (q15_t)0x789b, (q15_t)0xd522, (q15_t)0x7899, (q15_t)0xd51c, (q15_t)0x7897, (q15_t)0xd517, + (q15_t)0x7895, (q15_t)0xd511, (q15_t)0x7893, (q15_t)0xd50b, (q15_t)0x7891, (q15_t)0xd505, (q15_t)0x788f, (q15_t)0xd4ff, + (q15_t)0x788c, (q15_t)0xd4f9, (q15_t)0x788a, (q15_t)0xd4f3, (q15_t)0x7888, (q15_t)0xd4ed, (q15_t)0x7886, (q15_t)0xd4e7, + (q15_t)0x7884, (q15_t)0xd4e1, (q15_t)0x7882, (q15_t)0xd4db, (q15_t)0x7880, (q15_t)0xd4d5, (q15_t)0x787e, (q15_t)0xd4d0, + (q15_t)0x787c, (q15_t)0xd4ca, (q15_t)0x7879, (q15_t)0xd4c4, (q15_t)0x7877, (q15_t)0xd4be, (q15_t)0x7875, (q15_t)0xd4b8, + (q15_t)0x7873, (q15_t)0xd4b2, (q15_t)0x7871, (q15_t)0xd4ac, (q15_t)0x786f, (q15_t)0xd4a6, (q15_t)0x786d, (q15_t)0xd4a0, + (q15_t)0x786b, (q15_t)0xd49a, (q15_t)0x7868, (q15_t)0xd494, (q15_t)0x7866, (q15_t)0xd48f, (q15_t)0x7864, (q15_t)0xd489, + (q15_t)0x7862, (q15_t)0xd483, (q15_t)0x7860, (q15_t)0xd47d, (q15_t)0x785e, (q15_t)0xd477, (q15_t)0x785c, (q15_t)0xd471, + (q15_t)0x7859, (q15_t)0xd46b, (q15_t)0x7857, (q15_t)0xd465, (q15_t)0x7855, (q15_t)0xd45f, (q15_t)0x7853, (q15_t)0xd459, + (q15_t)0x7851, (q15_t)0xd453, (q15_t)0x784f, (q15_t)0xd44e, (q15_t)0x784d, (q15_t)0xd448, (q15_t)0x784a, (q15_t)0xd442, + (q15_t)0x7848, (q15_t)0xd43c, (q15_t)0x7846, (q15_t)0xd436, (q15_t)0x7844, (q15_t)0xd430, (q15_t)0x7842, (q15_t)0xd42a, + (q15_t)0x7840, (q15_t)0xd424, (q15_t)0x783e, (q15_t)0xd41e, (q15_t)0x783b, (q15_t)0xd418, (q15_t)0x7839, (q15_t)0xd412, + (q15_t)0x7837, (q15_t)0xd40d, (q15_t)0x7835, (q15_t)0xd407, (q15_t)0x7833, (q15_t)0xd401, (q15_t)0x7831, (q15_t)0xd3fb, + (q15_t)0x782e, (q15_t)0xd3f5, (q15_t)0x782c, (q15_t)0xd3ef, (q15_t)0x782a, (q15_t)0xd3e9, (q15_t)0x7828, (q15_t)0xd3e3, + (q15_t)0x7826, (q15_t)0xd3dd, (q15_t)0x7824, (q15_t)0xd3d7, (q15_t)0x7821, (q15_t)0xd3d2, (q15_t)0x781f, (q15_t)0xd3cc, + (q15_t)0x781d, (q15_t)0xd3c6, (q15_t)0x781b, (q15_t)0xd3c0, (q15_t)0x7819, (q15_t)0xd3ba, (q15_t)0x7817, (q15_t)0xd3b4, + (q15_t)0x7814, (q15_t)0xd3ae, (q15_t)0x7812, (q15_t)0xd3a8, (q15_t)0x7810, (q15_t)0xd3a2, (q15_t)0x780e, (q15_t)0xd39d, + (q15_t)0x780c, (q15_t)0xd397, (q15_t)0x780a, (q15_t)0xd391, (q15_t)0x7807, (q15_t)0xd38b, (q15_t)0x7805, (q15_t)0xd385, + (q15_t)0x7803, (q15_t)0xd37f, (q15_t)0x7801, (q15_t)0xd379, (q15_t)0x77ff, (q15_t)0xd373, (q15_t)0x77fc, (q15_t)0xd36d, + (q15_t)0x77fa, (q15_t)0xd368, (q15_t)0x77f8, (q15_t)0xd362, (q15_t)0x77f6, (q15_t)0xd35c, (q15_t)0x77f4, (q15_t)0xd356, + (q15_t)0x77f1, (q15_t)0xd350, (q15_t)0x77ef, (q15_t)0xd34a, (q15_t)0x77ed, (q15_t)0xd344, (q15_t)0x77eb, (q15_t)0xd33e, + (q15_t)0x77e9, (q15_t)0xd338, (q15_t)0x77e6, (q15_t)0xd333, (q15_t)0x77e4, (q15_t)0xd32d, (q15_t)0x77e2, (q15_t)0xd327, + (q15_t)0x77e0, (q15_t)0xd321, (q15_t)0x77de, (q15_t)0xd31b, (q15_t)0x77db, (q15_t)0xd315, (q15_t)0x77d9, (q15_t)0xd30f, + (q15_t)0x77d7, (q15_t)0xd309, (q15_t)0x77d5, (q15_t)0xd303, (q15_t)0x77d3, (q15_t)0xd2fe, (q15_t)0x77d0, (q15_t)0xd2f8, + (q15_t)0x77ce, (q15_t)0xd2f2, (q15_t)0x77cc, (q15_t)0xd2ec, (q15_t)0x77ca, (q15_t)0xd2e6, (q15_t)0x77c8, (q15_t)0xd2e0, + (q15_t)0x77c5, (q15_t)0xd2da, (q15_t)0x77c3, (q15_t)0xd2d4, (q15_t)0x77c1, (q15_t)0xd2cf, (q15_t)0x77bf, (q15_t)0xd2c9, + (q15_t)0x77bc, (q15_t)0xd2c3, (q15_t)0x77ba, (q15_t)0xd2bd, (q15_t)0x77b8, (q15_t)0xd2b7, (q15_t)0x77b6, (q15_t)0xd2b1, + (q15_t)0x77b4, (q15_t)0xd2ab, (q15_t)0x77b1, (q15_t)0xd2a5, (q15_t)0x77af, (q15_t)0xd2a0, (q15_t)0x77ad, (q15_t)0xd29a, + (q15_t)0x77ab, (q15_t)0xd294, (q15_t)0x77a8, (q15_t)0xd28e, (q15_t)0x77a6, (q15_t)0xd288, (q15_t)0x77a4, (q15_t)0xd282, + (q15_t)0x77a2, (q15_t)0xd27c, (q15_t)0x77a0, (q15_t)0xd276, (q15_t)0x779d, (q15_t)0xd271, (q15_t)0x779b, (q15_t)0xd26b, + (q15_t)0x7799, (q15_t)0xd265, (q15_t)0x7797, (q15_t)0xd25f, (q15_t)0x7794, (q15_t)0xd259, (q15_t)0x7792, (q15_t)0xd253, + (q15_t)0x7790, (q15_t)0xd24d, (q15_t)0x778e, (q15_t)0xd247, (q15_t)0x778b, (q15_t)0xd242, (q15_t)0x7789, (q15_t)0xd23c, + (q15_t)0x7787, (q15_t)0xd236, (q15_t)0x7785, (q15_t)0xd230, (q15_t)0x7782, (q15_t)0xd22a, (q15_t)0x7780, (q15_t)0xd224, + (q15_t)0x777e, (q15_t)0xd21e, (q15_t)0x777c, (q15_t)0xd219, (q15_t)0x7779, (q15_t)0xd213, (q15_t)0x7777, (q15_t)0xd20d, + (q15_t)0x7775, (q15_t)0xd207, (q15_t)0x7773, (q15_t)0xd201, (q15_t)0x7770, (q15_t)0xd1fb, (q15_t)0x776e, (q15_t)0xd1f5, + (q15_t)0x776c, (q15_t)0xd1ef, (q15_t)0x776a, (q15_t)0xd1ea, (q15_t)0x7767, (q15_t)0xd1e4, (q15_t)0x7765, (q15_t)0xd1de, + (q15_t)0x7763, (q15_t)0xd1d8, (q15_t)0x7760, (q15_t)0xd1d2, (q15_t)0x775e, (q15_t)0xd1cc, (q15_t)0x775c, (q15_t)0xd1c6, + (q15_t)0x775a, (q15_t)0xd1c1, (q15_t)0x7757, (q15_t)0xd1bb, (q15_t)0x7755, (q15_t)0xd1b5, (q15_t)0x7753, (q15_t)0xd1af, + (q15_t)0x7751, (q15_t)0xd1a9, (q15_t)0x774e, (q15_t)0xd1a3, (q15_t)0x774c, (q15_t)0xd19d, (q15_t)0x774a, (q15_t)0xd198, + (q15_t)0x7747, (q15_t)0xd192, (q15_t)0x7745, (q15_t)0xd18c, (q15_t)0x7743, (q15_t)0xd186, (q15_t)0x7741, (q15_t)0xd180, + (q15_t)0x773e, (q15_t)0xd17a, (q15_t)0x773c, (q15_t)0xd174, (q15_t)0x773a, (q15_t)0xd16f, (q15_t)0x7738, (q15_t)0xd169, + (q15_t)0x7735, (q15_t)0xd163, (q15_t)0x7733, (q15_t)0xd15d, (q15_t)0x7731, (q15_t)0xd157, (q15_t)0x772e, (q15_t)0xd151, + (q15_t)0x772c, (q15_t)0xd14b, (q15_t)0x772a, (q15_t)0xd146, (q15_t)0x7727, (q15_t)0xd140, (q15_t)0x7725, (q15_t)0xd13a, + (q15_t)0x7723, (q15_t)0xd134, (q15_t)0x7721, (q15_t)0xd12e, (q15_t)0x771e, (q15_t)0xd128, (q15_t)0x771c, (q15_t)0xd123, + (q15_t)0x771a, (q15_t)0xd11d, (q15_t)0x7717, (q15_t)0xd117, (q15_t)0x7715, (q15_t)0xd111, (q15_t)0x7713, (q15_t)0xd10b, + (q15_t)0x7710, (q15_t)0xd105, (q15_t)0x770e, (q15_t)0xd0ff, (q15_t)0x770c, (q15_t)0xd0fa, (q15_t)0x770a, (q15_t)0xd0f4, + (q15_t)0x7707, (q15_t)0xd0ee, (q15_t)0x7705, (q15_t)0xd0e8, (q15_t)0x7703, (q15_t)0xd0e2, (q15_t)0x7700, (q15_t)0xd0dc, + (q15_t)0x76fe, (q15_t)0xd0d7, (q15_t)0x76fc, (q15_t)0xd0d1, (q15_t)0x76f9, (q15_t)0xd0cb, (q15_t)0x76f7, (q15_t)0xd0c5, + (q15_t)0x76f5, (q15_t)0xd0bf, (q15_t)0x76f2, (q15_t)0xd0b9, (q15_t)0x76f0, (q15_t)0xd0b4, (q15_t)0x76ee, (q15_t)0xd0ae, + (q15_t)0x76eb, (q15_t)0xd0a8, (q15_t)0x76e9, (q15_t)0xd0a2, (q15_t)0x76e7, (q15_t)0xd09c, (q15_t)0x76e4, (q15_t)0xd096, + (q15_t)0x76e2, (q15_t)0xd091, (q15_t)0x76e0, (q15_t)0xd08b, (q15_t)0x76dd, (q15_t)0xd085, (q15_t)0x76db, (q15_t)0xd07f, + (q15_t)0x76d9, (q15_t)0xd079, (q15_t)0x76d6, (q15_t)0xd073, (q15_t)0x76d4, (q15_t)0xd06e, (q15_t)0x76d2, (q15_t)0xd068, + (q15_t)0x76cf, (q15_t)0xd062, (q15_t)0x76cd, (q15_t)0xd05c, (q15_t)0x76cb, (q15_t)0xd056, (q15_t)0x76c8, (q15_t)0xd050, + (q15_t)0x76c6, (q15_t)0xd04b, (q15_t)0x76c4, (q15_t)0xd045, (q15_t)0x76c1, (q15_t)0xd03f, (q15_t)0x76bf, (q15_t)0xd039, + (q15_t)0x76bd, (q15_t)0xd033, (q15_t)0x76ba, (q15_t)0xd02d, (q15_t)0x76b8, (q15_t)0xd028, (q15_t)0x76b6, (q15_t)0xd022, + (q15_t)0x76b3, (q15_t)0xd01c, (q15_t)0x76b1, (q15_t)0xd016, (q15_t)0x76af, (q15_t)0xd010, (q15_t)0x76ac, (q15_t)0xd00a, + (q15_t)0x76aa, (q15_t)0xd005, (q15_t)0x76a8, (q15_t)0xcfff, (q15_t)0x76a5, (q15_t)0xcff9, (q15_t)0x76a3, (q15_t)0xcff3, + (q15_t)0x76a0, (q15_t)0xcfed, (q15_t)0x769e, (q15_t)0xcfe7, (q15_t)0x769c, (q15_t)0xcfe2, (q15_t)0x7699, (q15_t)0xcfdc, + (q15_t)0x7697, (q15_t)0xcfd6, (q15_t)0x7695, (q15_t)0xcfd0, (q15_t)0x7692, (q15_t)0xcfca, (q15_t)0x7690, (q15_t)0xcfc5, + (q15_t)0x768e, (q15_t)0xcfbf, (q15_t)0x768b, (q15_t)0xcfb9, (q15_t)0x7689, (q15_t)0xcfb3, (q15_t)0x7686, (q15_t)0xcfad, + (q15_t)0x7684, (q15_t)0xcfa7, (q15_t)0x7682, (q15_t)0xcfa2, (q15_t)0x767f, (q15_t)0xcf9c, (q15_t)0x767d, (q15_t)0xcf96, + (q15_t)0x767b, (q15_t)0xcf90, (q15_t)0x7678, (q15_t)0xcf8a, (q15_t)0x7676, (q15_t)0xcf85, (q15_t)0x7673, (q15_t)0xcf7f, + (q15_t)0x7671, (q15_t)0xcf79, (q15_t)0x766f, (q15_t)0xcf73, (q15_t)0x766c, (q15_t)0xcf6d, (q15_t)0x766a, (q15_t)0xcf67, + (q15_t)0x7668, (q15_t)0xcf62, (q15_t)0x7665, (q15_t)0xcf5c, (q15_t)0x7663, (q15_t)0xcf56, (q15_t)0x7660, (q15_t)0xcf50, + (q15_t)0x765e, (q15_t)0xcf4a, (q15_t)0x765c, (q15_t)0xcf45, (q15_t)0x7659, (q15_t)0xcf3f, (q15_t)0x7657, (q15_t)0xcf39, + (q15_t)0x7654, (q15_t)0xcf33, (q15_t)0x7652, (q15_t)0xcf2d, (q15_t)0x7650, (q15_t)0xcf28, (q15_t)0x764d, (q15_t)0xcf22, + (q15_t)0x764b, (q15_t)0xcf1c, (q15_t)0x7648, (q15_t)0xcf16, (q15_t)0x7646, (q15_t)0xcf10, (q15_t)0x7644, (q15_t)0xcf0b, + (q15_t)0x7641, (q15_t)0xcf05, (q15_t)0x763f, (q15_t)0xceff, (q15_t)0x763c, (q15_t)0xcef9, (q15_t)0x763a, (q15_t)0xcef3, + (q15_t)0x7638, (q15_t)0xceee, (q15_t)0x7635, (q15_t)0xcee8, (q15_t)0x7633, (q15_t)0xcee2, (q15_t)0x7630, (q15_t)0xcedc, + (q15_t)0x762e, (q15_t)0xced6, (q15_t)0x762b, (q15_t)0xced1, (q15_t)0x7629, (q15_t)0xcecb, (q15_t)0x7627, (q15_t)0xcec5, + (q15_t)0x7624, (q15_t)0xcebf, (q15_t)0x7622, (q15_t)0xceb9, (q15_t)0x761f, (q15_t)0xceb4, (q15_t)0x761d, (q15_t)0xceae, + (q15_t)0x761b, (q15_t)0xcea8, (q15_t)0x7618, (q15_t)0xcea2, (q15_t)0x7616, (q15_t)0xce9c, (q15_t)0x7613, (q15_t)0xce97, + (q15_t)0x7611, (q15_t)0xce91, (q15_t)0x760e, (q15_t)0xce8b, (q15_t)0x760c, (q15_t)0xce85, (q15_t)0x760a, (q15_t)0xce7f, + (q15_t)0x7607, (q15_t)0xce7a, (q15_t)0x7605, (q15_t)0xce74, (q15_t)0x7602, (q15_t)0xce6e, (q15_t)0x7600, (q15_t)0xce68, + (q15_t)0x75fd, (q15_t)0xce62, (q15_t)0x75fb, (q15_t)0xce5d, (q15_t)0x75f9, (q15_t)0xce57, (q15_t)0x75f6, (q15_t)0xce51, + (q15_t)0x75f4, (q15_t)0xce4b, (q15_t)0x75f1, (q15_t)0xce45, (q15_t)0x75ef, (q15_t)0xce40, (q15_t)0x75ec, (q15_t)0xce3a, + (q15_t)0x75ea, (q15_t)0xce34, (q15_t)0x75e7, (q15_t)0xce2e, (q15_t)0x75e5, (q15_t)0xce28, (q15_t)0x75e3, (q15_t)0xce23, + (q15_t)0x75e0, (q15_t)0xce1d, (q15_t)0x75de, (q15_t)0xce17, (q15_t)0x75db, (q15_t)0xce11, (q15_t)0x75d9, (q15_t)0xce0c, + (q15_t)0x75d6, (q15_t)0xce06, (q15_t)0x75d4, (q15_t)0xce00, (q15_t)0x75d1, (q15_t)0xcdfa, (q15_t)0x75cf, (q15_t)0xcdf4, + (q15_t)0x75cc, (q15_t)0xcdef, (q15_t)0x75ca, (q15_t)0xcde9, (q15_t)0x75c8, (q15_t)0xcde3, (q15_t)0x75c5, (q15_t)0xcddd, + (q15_t)0x75c3, (q15_t)0xcdd8, (q15_t)0x75c0, (q15_t)0xcdd2, (q15_t)0x75be, (q15_t)0xcdcc, (q15_t)0x75bb, (q15_t)0xcdc6, + (q15_t)0x75b9, (q15_t)0xcdc0, (q15_t)0x75b6, (q15_t)0xcdbb, (q15_t)0x75b4, (q15_t)0xcdb5, (q15_t)0x75b1, (q15_t)0xcdaf, + (q15_t)0x75af, (q15_t)0xcda9, (q15_t)0x75ac, (q15_t)0xcda3, (q15_t)0x75aa, (q15_t)0xcd9e, (q15_t)0x75a7, (q15_t)0xcd98, + (q15_t)0x75a5, (q15_t)0xcd92, (q15_t)0x75a3, (q15_t)0xcd8c, (q15_t)0x75a0, (q15_t)0xcd87, (q15_t)0x759e, (q15_t)0xcd81, + (q15_t)0x759b, (q15_t)0xcd7b, (q15_t)0x7599, (q15_t)0xcd75, (q15_t)0x7596, (q15_t)0xcd70, (q15_t)0x7594, (q15_t)0xcd6a, + (q15_t)0x7591, (q15_t)0xcd64, (q15_t)0x758f, (q15_t)0xcd5e, (q15_t)0x758c, (q15_t)0xcd58, (q15_t)0x758a, (q15_t)0xcd53, + (q15_t)0x7587, (q15_t)0xcd4d, (q15_t)0x7585, (q15_t)0xcd47, (q15_t)0x7582, (q15_t)0xcd41, (q15_t)0x7580, (q15_t)0xcd3c, + (q15_t)0x757d, (q15_t)0xcd36, (q15_t)0x757b, (q15_t)0xcd30, (q15_t)0x7578, (q15_t)0xcd2a, (q15_t)0x7576, (q15_t)0xcd25, + (q15_t)0x7573, (q15_t)0xcd1f, (q15_t)0x7571, (q15_t)0xcd19, (q15_t)0x756e, (q15_t)0xcd13, (q15_t)0x756c, (q15_t)0xcd0d, + (q15_t)0x7569, (q15_t)0xcd08, (q15_t)0x7567, (q15_t)0xcd02, (q15_t)0x7564, (q15_t)0xccfc, (q15_t)0x7562, (q15_t)0xccf6, + (q15_t)0x755f, (q15_t)0xccf1, (q15_t)0x755d, (q15_t)0xcceb, (q15_t)0x755a, (q15_t)0xcce5, (q15_t)0x7558, (q15_t)0xccdf, + (q15_t)0x7555, (q15_t)0xccda, (q15_t)0x7553, (q15_t)0xccd4, (q15_t)0x7550, (q15_t)0xccce, (q15_t)0x754e, (q15_t)0xccc8, + (q15_t)0x754b, (q15_t)0xccc3, (q15_t)0x7549, (q15_t)0xccbd, (q15_t)0x7546, (q15_t)0xccb7, (q15_t)0x7544, (q15_t)0xccb1, + (q15_t)0x7541, (q15_t)0xccac, (q15_t)0x753f, (q15_t)0xcca6, (q15_t)0x753c, (q15_t)0xcca0, (q15_t)0x753a, (q15_t)0xcc9a, + (q15_t)0x7537, (q15_t)0xcc95, (q15_t)0x7535, (q15_t)0xcc8f, (q15_t)0x7532, (q15_t)0xcc89, (q15_t)0x752f, (q15_t)0xcc83, + (q15_t)0x752d, (q15_t)0xcc7e, (q15_t)0x752a, (q15_t)0xcc78, (q15_t)0x7528, (q15_t)0xcc72, (q15_t)0x7525, (q15_t)0xcc6c, + (q15_t)0x7523, (q15_t)0xcc67, (q15_t)0x7520, (q15_t)0xcc61, (q15_t)0x751e, (q15_t)0xcc5b, (q15_t)0x751b, (q15_t)0xcc55, + (q15_t)0x7519, (q15_t)0xcc50, (q15_t)0x7516, (q15_t)0xcc4a, (q15_t)0x7514, (q15_t)0xcc44, (q15_t)0x7511, (q15_t)0xcc3e, + (q15_t)0x750f, (q15_t)0xcc39, (q15_t)0x750c, (q15_t)0xcc33, (q15_t)0x7509, (q15_t)0xcc2d, (q15_t)0x7507, (q15_t)0xcc27, + (q15_t)0x7504, (q15_t)0xcc22, (q15_t)0x7502, (q15_t)0xcc1c, (q15_t)0x74ff, (q15_t)0xcc16, (q15_t)0x74fd, (q15_t)0xcc10, + (q15_t)0x74fa, (q15_t)0xcc0b, (q15_t)0x74f8, (q15_t)0xcc05, (q15_t)0x74f5, (q15_t)0xcbff, (q15_t)0x74f2, (q15_t)0xcbf9, + (q15_t)0x74f0, (q15_t)0xcbf4, (q15_t)0x74ed, (q15_t)0xcbee, (q15_t)0x74eb, (q15_t)0xcbe8, (q15_t)0x74e8, (q15_t)0xcbe2, + (q15_t)0x74e6, (q15_t)0xcbdd, (q15_t)0x74e3, (q15_t)0xcbd7, (q15_t)0x74e1, (q15_t)0xcbd1, (q15_t)0x74de, (q15_t)0xcbcb, + (q15_t)0x74db, (q15_t)0xcbc6, (q15_t)0x74d9, (q15_t)0xcbc0, (q15_t)0x74d6, (q15_t)0xcbba, (q15_t)0x74d4, (q15_t)0xcbb5, + (q15_t)0x74d1, (q15_t)0xcbaf, (q15_t)0x74cf, (q15_t)0xcba9, (q15_t)0x74cc, (q15_t)0xcba3, (q15_t)0x74c9, (q15_t)0xcb9e, + (q15_t)0x74c7, (q15_t)0xcb98, (q15_t)0x74c4, (q15_t)0xcb92, (q15_t)0x74c2, (q15_t)0xcb8c, (q15_t)0x74bf, (q15_t)0xcb87, + (q15_t)0x74bd, (q15_t)0xcb81, (q15_t)0x74ba, (q15_t)0xcb7b, (q15_t)0x74b7, (q15_t)0xcb75, (q15_t)0x74b5, (q15_t)0xcb70, + (q15_t)0x74b2, (q15_t)0xcb6a, (q15_t)0x74b0, (q15_t)0xcb64, (q15_t)0x74ad, (q15_t)0xcb5f, (q15_t)0x74ab, (q15_t)0xcb59, + (q15_t)0x74a8, (q15_t)0xcb53, (q15_t)0x74a5, (q15_t)0xcb4d, (q15_t)0x74a3, (q15_t)0xcb48, (q15_t)0x74a0, (q15_t)0xcb42, + (q15_t)0x749e, (q15_t)0xcb3c, (q15_t)0x749b, (q15_t)0xcb36, (q15_t)0x7498, (q15_t)0xcb31, (q15_t)0x7496, (q15_t)0xcb2b, + (q15_t)0x7493, (q15_t)0xcb25, (q15_t)0x7491, (q15_t)0xcb20, (q15_t)0x748e, (q15_t)0xcb1a, (q15_t)0x748b, (q15_t)0xcb14, + (q15_t)0x7489, (q15_t)0xcb0e, (q15_t)0x7486, (q15_t)0xcb09, (q15_t)0x7484, (q15_t)0xcb03, (q15_t)0x7481, (q15_t)0xcafd, + (q15_t)0x747e, (q15_t)0xcaf8, (q15_t)0x747c, (q15_t)0xcaf2, (q15_t)0x7479, (q15_t)0xcaec, (q15_t)0x7477, (q15_t)0xcae6, + (q15_t)0x7474, (q15_t)0xcae1, (q15_t)0x7471, (q15_t)0xcadb, (q15_t)0x746f, (q15_t)0xcad5, (q15_t)0x746c, (q15_t)0xcad0, + (q15_t)0x746a, (q15_t)0xcaca, (q15_t)0x7467, (q15_t)0xcac4, (q15_t)0x7464, (q15_t)0xcabe, (q15_t)0x7462, (q15_t)0xcab9, + (q15_t)0x745f, (q15_t)0xcab3, (q15_t)0x745c, (q15_t)0xcaad, (q15_t)0x745a, (q15_t)0xcaa8, (q15_t)0x7457, (q15_t)0xcaa2, + (q15_t)0x7455, (q15_t)0xca9c, (q15_t)0x7452, (q15_t)0xca96, (q15_t)0x744f, (q15_t)0xca91, (q15_t)0x744d, (q15_t)0xca8b, + (q15_t)0x744a, (q15_t)0xca85, (q15_t)0x7448, (q15_t)0xca80, (q15_t)0x7445, (q15_t)0xca7a, (q15_t)0x7442, (q15_t)0xca74, + (q15_t)0x7440, (q15_t)0xca6e, (q15_t)0x743d, (q15_t)0xca69, (q15_t)0x743a, (q15_t)0xca63, (q15_t)0x7438, (q15_t)0xca5d, + (q15_t)0x7435, (q15_t)0xca58, (q15_t)0x7432, (q15_t)0xca52, (q15_t)0x7430, (q15_t)0xca4c, (q15_t)0x742d, (q15_t)0xca46, + (q15_t)0x742b, (q15_t)0xca41, (q15_t)0x7428, (q15_t)0xca3b, (q15_t)0x7425, (q15_t)0xca35, (q15_t)0x7423, (q15_t)0xca30, + (q15_t)0x7420, (q15_t)0xca2a, (q15_t)0x741d, (q15_t)0xca24, (q15_t)0x741b, (q15_t)0xca1f, (q15_t)0x7418, (q15_t)0xca19, + (q15_t)0x7415, (q15_t)0xca13, (q15_t)0x7413, (q15_t)0xca0d, (q15_t)0x7410, (q15_t)0xca08, (q15_t)0x740d, (q15_t)0xca02, + (q15_t)0x740b, (q15_t)0xc9fc, (q15_t)0x7408, (q15_t)0xc9f7, (q15_t)0x7406, (q15_t)0xc9f1, (q15_t)0x7403, (q15_t)0xc9eb, + (q15_t)0x7400, (q15_t)0xc9e6, (q15_t)0x73fe, (q15_t)0xc9e0, (q15_t)0x73fb, (q15_t)0xc9da, (q15_t)0x73f8, (q15_t)0xc9d5, + (q15_t)0x73f6, (q15_t)0xc9cf, (q15_t)0x73f3, (q15_t)0xc9c9, (q15_t)0x73f0, (q15_t)0xc9c3, (q15_t)0x73ee, (q15_t)0xc9be, + (q15_t)0x73eb, (q15_t)0xc9b8, (q15_t)0x73e8, (q15_t)0xc9b2, (q15_t)0x73e6, (q15_t)0xc9ad, (q15_t)0x73e3, (q15_t)0xc9a7, + (q15_t)0x73e0, (q15_t)0xc9a1, (q15_t)0x73de, (q15_t)0xc99c, (q15_t)0x73db, (q15_t)0xc996, (q15_t)0x73d8, (q15_t)0xc990, + (q15_t)0x73d6, (q15_t)0xc98b, (q15_t)0x73d3, (q15_t)0xc985, (q15_t)0x73d0, (q15_t)0xc97f, (q15_t)0x73ce, (q15_t)0xc97a, + (q15_t)0x73cb, (q15_t)0xc974, (q15_t)0x73c8, (q15_t)0xc96e, (q15_t)0x73c6, (q15_t)0xc968, (q15_t)0x73c3, (q15_t)0xc963, + (q15_t)0x73c0, (q15_t)0xc95d, (q15_t)0x73bd, (q15_t)0xc957, (q15_t)0x73bb, (q15_t)0xc952, (q15_t)0x73b8, (q15_t)0xc94c, + (q15_t)0x73b5, (q15_t)0xc946, (q15_t)0x73b3, (q15_t)0xc941, (q15_t)0x73b0, (q15_t)0xc93b, (q15_t)0x73ad, (q15_t)0xc935, + (q15_t)0x73ab, (q15_t)0xc930, (q15_t)0x73a8, (q15_t)0xc92a, (q15_t)0x73a5, (q15_t)0xc924, (q15_t)0x73a3, (q15_t)0xc91f, + (q15_t)0x73a0, (q15_t)0xc919, (q15_t)0x739d, (q15_t)0xc913, (q15_t)0x739b, (q15_t)0xc90e, (q15_t)0x7398, (q15_t)0xc908, + (q15_t)0x7395, (q15_t)0xc902, (q15_t)0x7392, (q15_t)0xc8fd, (q15_t)0x7390, (q15_t)0xc8f7, (q15_t)0x738d, (q15_t)0xc8f1, + (q15_t)0x738a, (q15_t)0xc8ec, (q15_t)0x7388, (q15_t)0xc8e6, (q15_t)0x7385, (q15_t)0xc8e0, (q15_t)0x7382, (q15_t)0xc8db, + (q15_t)0x737f, (q15_t)0xc8d5, (q15_t)0x737d, (q15_t)0xc8cf, (q15_t)0x737a, (q15_t)0xc8ca, (q15_t)0x7377, (q15_t)0xc8c4, + (q15_t)0x7375, (q15_t)0xc8be, (q15_t)0x7372, (q15_t)0xc8b9, (q15_t)0x736f, (q15_t)0xc8b3, (q15_t)0x736c, (q15_t)0xc8ad, + (q15_t)0x736a, (q15_t)0xc8a8, (q15_t)0x7367, (q15_t)0xc8a2, (q15_t)0x7364, (q15_t)0xc89c, (q15_t)0x7362, (q15_t)0xc897, + (q15_t)0x735f, (q15_t)0xc891, (q15_t)0x735c, (q15_t)0xc88b, (q15_t)0x7359, (q15_t)0xc886, (q15_t)0x7357, (q15_t)0xc880, + (q15_t)0x7354, (q15_t)0xc87a, (q15_t)0x7351, (q15_t)0xc875, (q15_t)0x734f, (q15_t)0xc86f, (q15_t)0x734c, (q15_t)0xc869, + (q15_t)0x7349, (q15_t)0xc864, (q15_t)0x7346, (q15_t)0xc85e, (q15_t)0x7344, (q15_t)0xc858, (q15_t)0x7341, (q15_t)0xc853, + (q15_t)0x733e, (q15_t)0xc84d, (q15_t)0x733b, (q15_t)0xc847, (q15_t)0x7339, (q15_t)0xc842, (q15_t)0x7336, (q15_t)0xc83c, + (q15_t)0x7333, (q15_t)0xc836, (q15_t)0x7330, (q15_t)0xc831, (q15_t)0x732e, (q15_t)0xc82b, (q15_t)0x732b, (q15_t)0xc825, + (q15_t)0x7328, (q15_t)0xc820, (q15_t)0x7326, (q15_t)0xc81a, (q15_t)0x7323, (q15_t)0xc814, (q15_t)0x7320, (q15_t)0xc80f, + (q15_t)0x731d, (q15_t)0xc809, (q15_t)0x731b, (q15_t)0xc803, (q15_t)0x7318, (q15_t)0xc7fe, (q15_t)0x7315, (q15_t)0xc7f8, + (q15_t)0x7312, (q15_t)0xc7f3, (q15_t)0x7310, (q15_t)0xc7ed, (q15_t)0x730d, (q15_t)0xc7e7, (q15_t)0x730a, (q15_t)0xc7e2, + (q15_t)0x7307, (q15_t)0xc7dc, (q15_t)0x7305, (q15_t)0xc7d6, (q15_t)0x7302, (q15_t)0xc7d1, (q15_t)0x72ff, (q15_t)0xc7cb, + (q15_t)0x72fc, (q15_t)0xc7c5, (q15_t)0x72f9, (q15_t)0xc7c0, (q15_t)0x72f7, (q15_t)0xc7ba, (q15_t)0x72f4, (q15_t)0xc7b4, + (q15_t)0x72f1, (q15_t)0xc7af, (q15_t)0x72ee, (q15_t)0xc7a9, (q15_t)0x72ec, (q15_t)0xc7a3, (q15_t)0x72e9, (q15_t)0xc79e, + (q15_t)0x72e6, (q15_t)0xc798, (q15_t)0x72e3, (q15_t)0xc793, (q15_t)0x72e1, (q15_t)0xc78d, (q15_t)0x72de, (q15_t)0xc787, + (q15_t)0x72db, (q15_t)0xc782, (q15_t)0x72d8, (q15_t)0xc77c, (q15_t)0x72d5, (q15_t)0xc776, (q15_t)0x72d3, (q15_t)0xc771, + (q15_t)0x72d0, (q15_t)0xc76b, (q15_t)0x72cd, (q15_t)0xc765, (q15_t)0x72ca, (q15_t)0xc760, (q15_t)0x72c8, (q15_t)0xc75a, + (q15_t)0x72c5, (q15_t)0xc755, (q15_t)0x72c2, (q15_t)0xc74f, (q15_t)0x72bf, (q15_t)0xc749, (q15_t)0x72bc, (q15_t)0xc744, + (q15_t)0x72ba, (q15_t)0xc73e, (q15_t)0x72b7, (q15_t)0xc738, (q15_t)0x72b4, (q15_t)0xc733, (q15_t)0x72b1, (q15_t)0xc72d, + (q15_t)0x72af, (q15_t)0xc728, (q15_t)0x72ac, (q15_t)0xc722, (q15_t)0x72a9, (q15_t)0xc71c, (q15_t)0x72a6, (q15_t)0xc717, + (q15_t)0x72a3, (q15_t)0xc711, (q15_t)0x72a1, (q15_t)0xc70b, (q15_t)0x729e, (q15_t)0xc706, (q15_t)0x729b, (q15_t)0xc700, + (q15_t)0x7298, (q15_t)0xc6fa, (q15_t)0x7295, (q15_t)0xc6f5, (q15_t)0x7293, (q15_t)0xc6ef, (q15_t)0x7290, (q15_t)0xc6ea, + (q15_t)0x728d, (q15_t)0xc6e4, (q15_t)0x728a, (q15_t)0xc6de, (q15_t)0x7287, (q15_t)0xc6d9, (q15_t)0x7285, (q15_t)0xc6d3, + (q15_t)0x7282, (q15_t)0xc6ce, (q15_t)0x727f, (q15_t)0xc6c8, (q15_t)0x727c, (q15_t)0xc6c2, (q15_t)0x7279, (q15_t)0xc6bd, + (q15_t)0x7276, (q15_t)0xc6b7, (q15_t)0x7274, (q15_t)0xc6b1, (q15_t)0x7271, (q15_t)0xc6ac, (q15_t)0x726e, (q15_t)0xc6a6, + (q15_t)0x726b, (q15_t)0xc6a1, (q15_t)0x7268, (q15_t)0xc69b, (q15_t)0x7266, (q15_t)0xc695, (q15_t)0x7263, (q15_t)0xc690, + (q15_t)0x7260, (q15_t)0xc68a, (q15_t)0x725d, (q15_t)0xc684, (q15_t)0x725a, (q15_t)0xc67f, (q15_t)0x7257, (q15_t)0xc679, + (q15_t)0x7255, (q15_t)0xc674, (q15_t)0x7252, (q15_t)0xc66e, (q15_t)0x724f, (q15_t)0xc668, (q15_t)0x724c, (q15_t)0xc663, + (q15_t)0x7249, (q15_t)0xc65d, (q15_t)0x7247, (q15_t)0xc658, (q15_t)0x7244, (q15_t)0xc652, (q15_t)0x7241, (q15_t)0xc64c, + (q15_t)0x723e, (q15_t)0xc647, (q15_t)0x723b, (q15_t)0xc641, (q15_t)0x7238, (q15_t)0xc63c, (q15_t)0x7236, (q15_t)0xc636, + (q15_t)0x7233, (q15_t)0xc630, (q15_t)0x7230, (q15_t)0xc62b, (q15_t)0x722d, (q15_t)0xc625, (q15_t)0x722a, (q15_t)0xc620, + (q15_t)0x7227, (q15_t)0xc61a, (q15_t)0x7224, (q15_t)0xc614, (q15_t)0x7222, (q15_t)0xc60f, (q15_t)0x721f, (q15_t)0xc609, + (q15_t)0x721c, (q15_t)0xc603, (q15_t)0x7219, (q15_t)0xc5fe, (q15_t)0x7216, (q15_t)0xc5f8, (q15_t)0x7213, (q15_t)0xc5f3, + (q15_t)0x7211, (q15_t)0xc5ed, (q15_t)0x720e, (q15_t)0xc5e7, (q15_t)0x720b, (q15_t)0xc5e2, (q15_t)0x7208, (q15_t)0xc5dc, + (q15_t)0x7205, (q15_t)0xc5d7, (q15_t)0x7202, (q15_t)0xc5d1, (q15_t)0x71ff, (q15_t)0xc5cc, (q15_t)0x71fd, (q15_t)0xc5c6, + (q15_t)0x71fa, (q15_t)0xc5c0, (q15_t)0x71f7, (q15_t)0xc5bb, (q15_t)0x71f4, (q15_t)0xc5b5, (q15_t)0x71f1, (q15_t)0xc5b0, + (q15_t)0x71ee, (q15_t)0xc5aa, (q15_t)0x71eb, (q15_t)0xc5a4, (q15_t)0x71e9, (q15_t)0xc59f, (q15_t)0x71e6, (q15_t)0xc599, + (q15_t)0x71e3, (q15_t)0xc594, (q15_t)0x71e0, (q15_t)0xc58e, (q15_t)0x71dd, (q15_t)0xc588, (q15_t)0x71da, (q15_t)0xc583, + (q15_t)0x71d7, (q15_t)0xc57d, (q15_t)0x71d4, (q15_t)0xc578, (q15_t)0x71d2, (q15_t)0xc572, (q15_t)0x71cf, (q15_t)0xc56c, + (q15_t)0x71cc, (q15_t)0xc567, (q15_t)0x71c9, (q15_t)0xc561, (q15_t)0x71c6, (q15_t)0xc55c, (q15_t)0x71c3, (q15_t)0xc556, + (q15_t)0x71c0, (q15_t)0xc551, (q15_t)0x71bd, (q15_t)0xc54b, (q15_t)0x71bb, (q15_t)0xc545, (q15_t)0x71b8, (q15_t)0xc540, + (q15_t)0x71b5, (q15_t)0xc53a, (q15_t)0x71b2, (q15_t)0xc535, (q15_t)0x71af, (q15_t)0xc52f, (q15_t)0x71ac, (q15_t)0xc529, + (q15_t)0x71a9, (q15_t)0xc524, (q15_t)0x71a6, (q15_t)0xc51e, (q15_t)0x71a3, (q15_t)0xc519, (q15_t)0x71a1, (q15_t)0xc513, + (q15_t)0x719e, (q15_t)0xc50e, (q15_t)0x719b, (q15_t)0xc508, (q15_t)0x7198, (q15_t)0xc502, (q15_t)0x7195, (q15_t)0xc4fd, + (q15_t)0x7192, (q15_t)0xc4f7, (q15_t)0x718f, (q15_t)0xc4f2, (q15_t)0x718c, (q15_t)0xc4ec, (q15_t)0x7189, (q15_t)0xc4e7, + (q15_t)0x7186, (q15_t)0xc4e1, (q15_t)0x7184, (q15_t)0xc4db, (q15_t)0x7181, (q15_t)0xc4d6, (q15_t)0x717e, (q15_t)0xc4d0, + (q15_t)0x717b, (q15_t)0xc4cb, (q15_t)0x7178, (q15_t)0xc4c5, (q15_t)0x7175, (q15_t)0xc4c0, (q15_t)0x7172, (q15_t)0xc4ba, + (q15_t)0x716f, (q15_t)0xc4b4, (q15_t)0x716c, (q15_t)0xc4af, (q15_t)0x7169, (q15_t)0xc4a9, (q15_t)0x7167, (q15_t)0xc4a4, + (q15_t)0x7164, (q15_t)0xc49e, (q15_t)0x7161, (q15_t)0xc499, (q15_t)0x715e, (q15_t)0xc493, (q15_t)0x715b, (q15_t)0xc48d, + (q15_t)0x7158, (q15_t)0xc488, (q15_t)0x7155, (q15_t)0xc482, (q15_t)0x7152, (q15_t)0xc47d, (q15_t)0x714f, (q15_t)0xc477, + (q15_t)0x714c, (q15_t)0xc472, (q15_t)0x7149, (q15_t)0xc46c, (q15_t)0x7146, (q15_t)0xc467, (q15_t)0x7143, (q15_t)0xc461, + (q15_t)0x7141, (q15_t)0xc45b, (q15_t)0x713e, (q15_t)0xc456, (q15_t)0x713b, (q15_t)0xc450, (q15_t)0x7138, (q15_t)0xc44b, + (q15_t)0x7135, (q15_t)0xc445, (q15_t)0x7132, (q15_t)0xc440, (q15_t)0x712f, (q15_t)0xc43a, (q15_t)0x712c, (q15_t)0xc434, + (q15_t)0x7129, (q15_t)0xc42f, (q15_t)0x7126, (q15_t)0xc429, (q15_t)0x7123, (q15_t)0xc424, (q15_t)0x7120, (q15_t)0xc41e, + (q15_t)0x711d, (q15_t)0xc419, (q15_t)0x711a, (q15_t)0xc413, (q15_t)0x7117, (q15_t)0xc40e, (q15_t)0x7114, (q15_t)0xc408, + (q15_t)0x7112, (q15_t)0xc403, (q15_t)0x710f, (q15_t)0xc3fd, (q15_t)0x710c, (q15_t)0xc3f7, (q15_t)0x7109, (q15_t)0xc3f2, + (q15_t)0x7106, (q15_t)0xc3ec, (q15_t)0x7103, (q15_t)0xc3e7, (q15_t)0x7100, (q15_t)0xc3e1, (q15_t)0x70fd, (q15_t)0xc3dc, + (q15_t)0x70fa, (q15_t)0xc3d6, (q15_t)0x70f7, (q15_t)0xc3d1, (q15_t)0x70f4, (q15_t)0xc3cb, (q15_t)0x70f1, (q15_t)0xc3c5, + (q15_t)0x70ee, (q15_t)0xc3c0, (q15_t)0x70eb, (q15_t)0xc3ba, (q15_t)0x70e8, (q15_t)0xc3b5, (q15_t)0x70e5, (q15_t)0xc3af, + (q15_t)0x70e2, (q15_t)0xc3aa, (q15_t)0x70df, (q15_t)0xc3a4, (q15_t)0x70dc, (q15_t)0xc39f, (q15_t)0x70d9, (q15_t)0xc399, + (q15_t)0x70d6, (q15_t)0xc394, (q15_t)0x70d3, (q15_t)0xc38e, (q15_t)0x70d1, (q15_t)0xc389, (q15_t)0x70ce, (q15_t)0xc383, + (q15_t)0x70cb, (q15_t)0xc37d, (q15_t)0x70c8, (q15_t)0xc378, (q15_t)0x70c5, (q15_t)0xc372, (q15_t)0x70c2, (q15_t)0xc36d, + (q15_t)0x70bf, (q15_t)0xc367, (q15_t)0x70bc, (q15_t)0xc362, (q15_t)0x70b9, (q15_t)0xc35c, (q15_t)0x70b6, (q15_t)0xc357, + (q15_t)0x70b3, (q15_t)0xc351, (q15_t)0x70b0, (q15_t)0xc34c, (q15_t)0x70ad, (q15_t)0xc346, (q15_t)0x70aa, (q15_t)0xc341, + (q15_t)0x70a7, (q15_t)0xc33b, (q15_t)0x70a4, (q15_t)0xc336, (q15_t)0x70a1, (q15_t)0xc330, (q15_t)0x709e, (q15_t)0xc32a, + (q15_t)0x709b, (q15_t)0xc325, (q15_t)0x7098, (q15_t)0xc31f, (q15_t)0x7095, (q15_t)0xc31a, (q15_t)0x7092, (q15_t)0xc314, + (q15_t)0x708f, (q15_t)0xc30f, (q15_t)0x708c, (q15_t)0xc309, (q15_t)0x7089, (q15_t)0xc304, (q15_t)0x7086, (q15_t)0xc2fe, + (q15_t)0x7083, (q15_t)0xc2f9, (q15_t)0x7080, (q15_t)0xc2f3, (q15_t)0x707d, (q15_t)0xc2ee, (q15_t)0x707a, (q15_t)0xc2e8, + (q15_t)0x7077, (q15_t)0xc2e3, (q15_t)0x7074, (q15_t)0xc2dd, (q15_t)0x7071, (q15_t)0xc2d8, (q15_t)0x706e, (q15_t)0xc2d2, + (q15_t)0x706b, (q15_t)0xc2cd, (q15_t)0x7068, (q15_t)0xc2c7, (q15_t)0x7065, (q15_t)0xc2c2, (q15_t)0x7062, (q15_t)0xc2bc, + (q15_t)0x705f, (q15_t)0xc2b7, (q15_t)0x705c, (q15_t)0xc2b1, (q15_t)0x7059, (q15_t)0xc2ab, (q15_t)0x7056, (q15_t)0xc2a6, + (q15_t)0x7053, (q15_t)0xc2a0, (q15_t)0x7050, (q15_t)0xc29b, (q15_t)0x704d, (q15_t)0xc295, (q15_t)0x704a, (q15_t)0xc290, + (q15_t)0x7047, (q15_t)0xc28a, (q15_t)0x7044, (q15_t)0xc285, (q15_t)0x7041, (q15_t)0xc27f, (q15_t)0x703e, (q15_t)0xc27a, + (q15_t)0x703b, (q15_t)0xc274, (q15_t)0x7038, (q15_t)0xc26f, (q15_t)0x7035, (q15_t)0xc269, (q15_t)0x7032, (q15_t)0xc264, + (q15_t)0x702f, (q15_t)0xc25e, (q15_t)0x702c, (q15_t)0xc259, (q15_t)0x7029, (q15_t)0xc253, (q15_t)0x7026, (q15_t)0xc24e, + (q15_t)0x7023, (q15_t)0xc248, (q15_t)0x7020, (q15_t)0xc243, (q15_t)0x701d, (q15_t)0xc23d, (q15_t)0x7019, (q15_t)0xc238, + (q15_t)0x7016, (q15_t)0xc232, (q15_t)0x7013, (q15_t)0xc22d, (q15_t)0x7010, (q15_t)0xc227, (q15_t)0x700d, (q15_t)0xc222, + (q15_t)0x700a, (q15_t)0xc21c, (q15_t)0x7007, (q15_t)0xc217, (q15_t)0x7004, (q15_t)0xc211, (q15_t)0x7001, (q15_t)0xc20c, + (q15_t)0x6ffe, (q15_t)0xc206, (q15_t)0x6ffb, (q15_t)0xc201, (q15_t)0x6ff8, (q15_t)0xc1fb, (q15_t)0x6ff5, (q15_t)0xc1f6, + (q15_t)0x6ff2, (q15_t)0xc1f0, (q15_t)0x6fef, (q15_t)0xc1eb, (q15_t)0x6fec, (q15_t)0xc1e5, (q15_t)0x6fe9, (q15_t)0xc1e0, + (q15_t)0x6fe6, (q15_t)0xc1da, (q15_t)0x6fe3, (q15_t)0xc1d5, (q15_t)0x6fe0, (q15_t)0xc1cf, (q15_t)0x6fdd, (q15_t)0xc1ca, + (q15_t)0x6fda, (q15_t)0xc1c4, (q15_t)0x6fd6, (q15_t)0xc1bf, (q15_t)0x6fd3, (q15_t)0xc1b9, (q15_t)0x6fd0, (q15_t)0xc1b4, + (q15_t)0x6fcd, (q15_t)0xc1ae, (q15_t)0x6fca, (q15_t)0xc1a9, (q15_t)0x6fc7, (q15_t)0xc1a3, (q15_t)0x6fc4, (q15_t)0xc19e, + (q15_t)0x6fc1, (q15_t)0xc198, (q15_t)0x6fbe, (q15_t)0xc193, (q15_t)0x6fbb, (q15_t)0xc18d, (q15_t)0x6fb8, (q15_t)0xc188, + (q15_t)0x6fb5, (q15_t)0xc183, (q15_t)0x6fb2, (q15_t)0xc17d, (q15_t)0x6faf, (q15_t)0xc178, (q15_t)0x6fac, (q15_t)0xc172, + (q15_t)0x6fa9, (q15_t)0xc16d, (q15_t)0x6fa5, (q15_t)0xc167, (q15_t)0x6fa2, (q15_t)0xc162, (q15_t)0x6f9f, (q15_t)0xc15c, + (q15_t)0x6f9c, (q15_t)0xc157, (q15_t)0x6f99, (q15_t)0xc151, (q15_t)0x6f96, (q15_t)0xc14c, (q15_t)0x6f93, (q15_t)0xc146, + (q15_t)0x6f90, (q15_t)0xc141, (q15_t)0x6f8d, (q15_t)0xc13b, (q15_t)0x6f8a, (q15_t)0xc136, (q15_t)0x6f87, (q15_t)0xc130, + (q15_t)0x6f84, (q15_t)0xc12b, (q15_t)0x6f81, (q15_t)0xc125, (q15_t)0x6f7d, (q15_t)0xc120, (q15_t)0x6f7a, (q15_t)0xc11a, + (q15_t)0x6f77, (q15_t)0xc115, (q15_t)0x6f74, (q15_t)0xc10f, (q15_t)0x6f71, (q15_t)0xc10a, (q15_t)0x6f6e, (q15_t)0xc105, + (q15_t)0x6f6b, (q15_t)0xc0ff, (q15_t)0x6f68, (q15_t)0xc0fa, (q15_t)0x6f65, (q15_t)0xc0f4, (q15_t)0x6f62, (q15_t)0xc0ef, + (q15_t)0x6f5f, (q15_t)0xc0e9, (q15_t)0x6f5b, (q15_t)0xc0e4, (q15_t)0x6f58, (q15_t)0xc0de, (q15_t)0x6f55, (q15_t)0xc0d9, + (q15_t)0x6f52, (q15_t)0xc0d3, (q15_t)0x6f4f, (q15_t)0xc0ce, (q15_t)0x6f4c, (q15_t)0xc0c8, (q15_t)0x6f49, (q15_t)0xc0c3, + (q15_t)0x6f46, (q15_t)0xc0bd, (q15_t)0x6f43, (q15_t)0xc0b8, (q15_t)0x6f3f, (q15_t)0xc0b3, (q15_t)0x6f3c, (q15_t)0xc0ad, + (q15_t)0x6f39, (q15_t)0xc0a8, (q15_t)0x6f36, (q15_t)0xc0a2, (q15_t)0x6f33, (q15_t)0xc09d, (q15_t)0x6f30, (q15_t)0xc097, + (q15_t)0x6f2d, (q15_t)0xc092, (q15_t)0x6f2a, (q15_t)0xc08c, (q15_t)0x6f27, (q15_t)0xc087, (q15_t)0x6f23, (q15_t)0xc081, + (q15_t)0x6f20, (q15_t)0xc07c, (q15_t)0x6f1d, (q15_t)0xc077, (q15_t)0x6f1a, (q15_t)0xc071, (q15_t)0x6f17, (q15_t)0xc06c, + (q15_t)0x6f14, (q15_t)0xc066, (q15_t)0x6f11, (q15_t)0xc061, (q15_t)0x6f0e, (q15_t)0xc05b, (q15_t)0x6f0b, (q15_t)0xc056, + (q15_t)0x6f07, (q15_t)0xc050, (q15_t)0x6f04, (q15_t)0xc04b, (q15_t)0x6f01, (q15_t)0xc045, (q15_t)0x6efe, (q15_t)0xc040, + (q15_t)0x6efb, (q15_t)0xc03b, (q15_t)0x6ef8, (q15_t)0xc035, (q15_t)0x6ef5, (q15_t)0xc030, (q15_t)0x6ef1, (q15_t)0xc02a, + (q15_t)0x6eee, (q15_t)0xc025, (q15_t)0x6eeb, (q15_t)0xc01f, (q15_t)0x6ee8, (q15_t)0xc01a, (q15_t)0x6ee5, (q15_t)0xc014, + (q15_t)0x6ee2, (q15_t)0xc00f, (q15_t)0x6edf, (q15_t)0xc00a, (q15_t)0x6edc, (q15_t)0xc004, (q15_t)0x6ed8, (q15_t)0xbfff, + (q15_t)0x6ed5, (q15_t)0xbff9, (q15_t)0x6ed2, (q15_t)0xbff4, (q15_t)0x6ecf, (q15_t)0xbfee, (q15_t)0x6ecc, (q15_t)0xbfe9, + (q15_t)0x6ec9, (q15_t)0xbfe3, (q15_t)0x6ec6, (q15_t)0xbfde, (q15_t)0x6ec2, (q15_t)0xbfd9, (q15_t)0x6ebf, (q15_t)0xbfd3, + (q15_t)0x6ebc, (q15_t)0xbfce, (q15_t)0x6eb9, (q15_t)0xbfc8, (q15_t)0x6eb6, (q15_t)0xbfc3, (q15_t)0x6eb3, (q15_t)0xbfbd, + (q15_t)0x6eaf, (q15_t)0xbfb8, (q15_t)0x6eac, (q15_t)0xbfb3, (q15_t)0x6ea9, (q15_t)0xbfad, (q15_t)0x6ea6, (q15_t)0xbfa8, + (q15_t)0x6ea3, (q15_t)0xbfa2, (q15_t)0x6ea0, (q15_t)0xbf9d, (q15_t)0x6e9c, (q15_t)0xbf97, (q15_t)0x6e99, (q15_t)0xbf92, + (q15_t)0x6e96, (q15_t)0xbf8d, (q15_t)0x6e93, (q15_t)0xbf87, (q15_t)0x6e90, (q15_t)0xbf82, (q15_t)0x6e8d, (q15_t)0xbf7c, + (q15_t)0x6e89, (q15_t)0xbf77, (q15_t)0x6e86, (q15_t)0xbf71, (q15_t)0x6e83, (q15_t)0xbf6c, (q15_t)0x6e80, (q15_t)0xbf67, + (q15_t)0x6e7d, (q15_t)0xbf61, (q15_t)0x6e7a, (q15_t)0xbf5c, (q15_t)0x6e76, (q15_t)0xbf56, (q15_t)0x6e73, (q15_t)0xbf51, + (q15_t)0x6e70, (q15_t)0xbf4b, (q15_t)0x6e6d, (q15_t)0xbf46, (q15_t)0x6e6a, (q15_t)0xbf41, (q15_t)0x6e67, (q15_t)0xbf3b, + (q15_t)0x6e63, (q15_t)0xbf36, (q15_t)0x6e60, (q15_t)0xbf30, (q15_t)0x6e5d, (q15_t)0xbf2b, (q15_t)0x6e5a, (q15_t)0xbf26, + (q15_t)0x6e57, (q15_t)0xbf20, (q15_t)0x6e53, (q15_t)0xbf1b, (q15_t)0x6e50, (q15_t)0xbf15, (q15_t)0x6e4d, (q15_t)0xbf10, + (q15_t)0x6e4a, (q15_t)0xbf0a, (q15_t)0x6e47, (q15_t)0xbf05, (q15_t)0x6e44, (q15_t)0xbf00, (q15_t)0x6e40, (q15_t)0xbefa, + (q15_t)0x6e3d, (q15_t)0xbef5, (q15_t)0x6e3a, (q15_t)0xbeef, (q15_t)0x6e37, (q15_t)0xbeea, (q15_t)0x6e34, (q15_t)0xbee5, + (q15_t)0x6e30, (q15_t)0xbedf, (q15_t)0x6e2d, (q15_t)0xbeda, (q15_t)0x6e2a, (q15_t)0xbed4, (q15_t)0x6e27, (q15_t)0xbecf, + (q15_t)0x6e24, (q15_t)0xbeca, (q15_t)0x6e20, (q15_t)0xbec4, (q15_t)0x6e1d, (q15_t)0xbebf, (q15_t)0x6e1a, (q15_t)0xbeb9, + (q15_t)0x6e17, (q15_t)0xbeb4, (q15_t)0x6e14, (q15_t)0xbeae, (q15_t)0x6e10, (q15_t)0xbea9, (q15_t)0x6e0d, (q15_t)0xbea4, + (q15_t)0x6e0a, (q15_t)0xbe9e, (q15_t)0x6e07, (q15_t)0xbe99, (q15_t)0x6e04, (q15_t)0xbe93, (q15_t)0x6e00, (q15_t)0xbe8e, + (q15_t)0x6dfd, (q15_t)0xbe89, (q15_t)0x6dfa, (q15_t)0xbe83, (q15_t)0x6df7, (q15_t)0xbe7e, (q15_t)0x6df3, (q15_t)0xbe78, + (q15_t)0x6df0, (q15_t)0xbe73, (q15_t)0x6ded, (q15_t)0xbe6e, (q15_t)0x6dea, (q15_t)0xbe68, (q15_t)0x6de7, (q15_t)0xbe63, + (q15_t)0x6de3, (q15_t)0xbe5e, (q15_t)0x6de0, (q15_t)0xbe58, (q15_t)0x6ddd, (q15_t)0xbe53, (q15_t)0x6dda, (q15_t)0xbe4d, + (q15_t)0x6dd6, (q15_t)0xbe48, (q15_t)0x6dd3, (q15_t)0xbe43, (q15_t)0x6dd0, (q15_t)0xbe3d, (q15_t)0x6dcd, (q15_t)0xbe38, + (q15_t)0x6dca, (q15_t)0xbe32, (q15_t)0x6dc6, (q15_t)0xbe2d, (q15_t)0x6dc3, (q15_t)0xbe28, (q15_t)0x6dc0, (q15_t)0xbe22, + (q15_t)0x6dbd, (q15_t)0xbe1d, (q15_t)0x6db9, (q15_t)0xbe17, (q15_t)0x6db6, (q15_t)0xbe12, (q15_t)0x6db3, (q15_t)0xbe0d, + (q15_t)0x6db0, (q15_t)0xbe07, (q15_t)0x6dac, (q15_t)0xbe02, (q15_t)0x6da9, (q15_t)0xbdfd, (q15_t)0x6da6, (q15_t)0xbdf7, + (q15_t)0x6da3, (q15_t)0xbdf2, (q15_t)0x6d9f, (q15_t)0xbdec, (q15_t)0x6d9c, (q15_t)0xbde7, (q15_t)0x6d99, (q15_t)0xbde2, + (q15_t)0x6d96, (q15_t)0xbddc, (q15_t)0x6d92, (q15_t)0xbdd7, (q15_t)0x6d8f, (q15_t)0xbdd1, (q15_t)0x6d8c, (q15_t)0xbdcc, + (q15_t)0x6d89, (q15_t)0xbdc7, (q15_t)0x6d85, (q15_t)0xbdc1, (q15_t)0x6d82, (q15_t)0xbdbc, (q15_t)0x6d7f, (q15_t)0xbdb7, + (q15_t)0x6d7c, (q15_t)0xbdb1, (q15_t)0x6d78, (q15_t)0xbdac, (q15_t)0x6d75, (q15_t)0xbda6, (q15_t)0x6d72, (q15_t)0xbda1, + (q15_t)0x6d6f, (q15_t)0xbd9c, (q15_t)0x6d6b, (q15_t)0xbd96, (q15_t)0x6d68, (q15_t)0xbd91, (q15_t)0x6d65, (q15_t)0xbd8c, + (q15_t)0x6d62, (q15_t)0xbd86, (q15_t)0x6d5e, (q15_t)0xbd81, (q15_t)0x6d5b, (q15_t)0xbd7c, (q15_t)0x6d58, (q15_t)0xbd76, + (q15_t)0x6d55, (q15_t)0xbd71, (q15_t)0x6d51, (q15_t)0xbd6b, (q15_t)0x6d4e, (q15_t)0xbd66, (q15_t)0x6d4b, (q15_t)0xbd61, + (q15_t)0x6d48, (q15_t)0xbd5b, (q15_t)0x6d44, (q15_t)0xbd56, (q15_t)0x6d41, (q15_t)0xbd51, (q15_t)0x6d3e, (q15_t)0xbd4b, + (q15_t)0x6d3a, (q15_t)0xbd46, (q15_t)0x6d37, (q15_t)0xbd40, (q15_t)0x6d34, (q15_t)0xbd3b, (q15_t)0x6d31, (q15_t)0xbd36, + (q15_t)0x6d2d, (q15_t)0xbd30, (q15_t)0x6d2a, (q15_t)0xbd2b, (q15_t)0x6d27, (q15_t)0xbd26, (q15_t)0x6d23, (q15_t)0xbd20, + (q15_t)0x6d20, (q15_t)0xbd1b, (q15_t)0x6d1d, (q15_t)0xbd16, (q15_t)0x6d1a, (q15_t)0xbd10, (q15_t)0x6d16, (q15_t)0xbd0b, + (q15_t)0x6d13, (q15_t)0xbd06, (q15_t)0x6d10, (q15_t)0xbd00, (q15_t)0x6d0c, (q15_t)0xbcfb, (q15_t)0x6d09, (q15_t)0xbcf5, + (q15_t)0x6d06, (q15_t)0xbcf0, (q15_t)0x6d03, (q15_t)0xbceb, (q15_t)0x6cff, (q15_t)0xbce5, (q15_t)0x6cfc, (q15_t)0xbce0, + (q15_t)0x6cf9, (q15_t)0xbcdb, (q15_t)0x6cf5, (q15_t)0xbcd5, (q15_t)0x6cf2, (q15_t)0xbcd0, (q15_t)0x6cef, (q15_t)0xbccb, + (q15_t)0x6cec, (q15_t)0xbcc5, (q15_t)0x6ce8, (q15_t)0xbcc0, (q15_t)0x6ce5, (q15_t)0xbcbb, (q15_t)0x6ce2, (q15_t)0xbcb5, + (q15_t)0x6cde, (q15_t)0xbcb0, (q15_t)0x6cdb, (q15_t)0xbcab, (q15_t)0x6cd8, (q15_t)0xbca5, (q15_t)0x6cd4, (q15_t)0xbca0, + (q15_t)0x6cd1, (q15_t)0xbc9b, (q15_t)0x6cce, (q15_t)0xbc95, (q15_t)0x6cca, (q15_t)0xbc90, (q15_t)0x6cc7, (q15_t)0xbc8b, + (q15_t)0x6cc4, (q15_t)0xbc85, (q15_t)0x6cc1, (q15_t)0xbc80, (q15_t)0x6cbd, (q15_t)0xbc7b, (q15_t)0x6cba, (q15_t)0xbc75, + (q15_t)0x6cb7, (q15_t)0xbc70, (q15_t)0x6cb3, (q15_t)0xbc6b, (q15_t)0x6cb0, (q15_t)0xbc65, (q15_t)0x6cad, (q15_t)0xbc60, + (q15_t)0x6ca9, (q15_t)0xbc5b, (q15_t)0x6ca6, (q15_t)0xbc55, (q15_t)0x6ca3, (q15_t)0xbc50, (q15_t)0x6c9f, (q15_t)0xbc4b, + (q15_t)0x6c9c, (q15_t)0xbc45, (q15_t)0x6c99, (q15_t)0xbc40, (q15_t)0x6c95, (q15_t)0xbc3b, (q15_t)0x6c92, (q15_t)0xbc35, + (q15_t)0x6c8f, (q15_t)0xbc30, (q15_t)0x6c8b, (q15_t)0xbc2b, (q15_t)0x6c88, (q15_t)0xbc25, (q15_t)0x6c85, (q15_t)0xbc20, + (q15_t)0x6c81, (q15_t)0xbc1b, (q15_t)0x6c7e, (q15_t)0xbc15, (q15_t)0x6c7b, (q15_t)0xbc10, (q15_t)0x6c77, (q15_t)0xbc0b, + (q15_t)0x6c74, (q15_t)0xbc05, (q15_t)0x6c71, (q15_t)0xbc00, (q15_t)0x6c6d, (q15_t)0xbbfb, (q15_t)0x6c6a, (q15_t)0xbbf5, + (q15_t)0x6c67, (q15_t)0xbbf0, (q15_t)0x6c63, (q15_t)0xbbeb, (q15_t)0x6c60, (q15_t)0xbbe5, (q15_t)0x6c5d, (q15_t)0xbbe0, + (q15_t)0x6c59, (q15_t)0xbbdb, (q15_t)0x6c56, (q15_t)0xbbd5, (q15_t)0x6c53, (q15_t)0xbbd0, (q15_t)0x6c4f, (q15_t)0xbbcb, + (q15_t)0x6c4c, (q15_t)0xbbc5, (q15_t)0x6c49, (q15_t)0xbbc0, (q15_t)0x6c45, (q15_t)0xbbbb, (q15_t)0x6c42, (q15_t)0xbbb5, + (q15_t)0x6c3f, (q15_t)0xbbb0, (q15_t)0x6c3b, (q15_t)0xbbab, (q15_t)0x6c38, (q15_t)0xbba6, (q15_t)0x6c34, (q15_t)0xbba0, + (q15_t)0x6c31, (q15_t)0xbb9b, (q15_t)0x6c2e, (q15_t)0xbb96, (q15_t)0x6c2a, (q15_t)0xbb90, (q15_t)0x6c27, (q15_t)0xbb8b, + (q15_t)0x6c24, (q15_t)0xbb86, (q15_t)0x6c20, (q15_t)0xbb80, (q15_t)0x6c1d, (q15_t)0xbb7b, (q15_t)0x6c1a, (q15_t)0xbb76, + (q15_t)0x6c16, (q15_t)0xbb70, (q15_t)0x6c13, (q15_t)0xbb6b, (q15_t)0x6c0f, (q15_t)0xbb66, (q15_t)0x6c0c, (q15_t)0xbb61, + (q15_t)0x6c09, (q15_t)0xbb5b, (q15_t)0x6c05, (q15_t)0xbb56, (q15_t)0x6c02, (q15_t)0xbb51, (q15_t)0x6bff, (q15_t)0xbb4b, + (q15_t)0x6bfb, (q15_t)0xbb46, (q15_t)0x6bf8, (q15_t)0xbb41, (q15_t)0x6bf5, (q15_t)0xbb3b, (q15_t)0x6bf1, (q15_t)0xbb36, + (q15_t)0x6bee, (q15_t)0xbb31, (q15_t)0x6bea, (q15_t)0xbb2c, (q15_t)0x6be7, (q15_t)0xbb26, (q15_t)0x6be4, (q15_t)0xbb21, + (q15_t)0x6be0, (q15_t)0xbb1c, (q15_t)0x6bdd, (q15_t)0xbb16, (q15_t)0x6bd9, (q15_t)0xbb11, (q15_t)0x6bd6, (q15_t)0xbb0c, + (q15_t)0x6bd3, (q15_t)0xbb06, (q15_t)0x6bcf, (q15_t)0xbb01, (q15_t)0x6bcc, (q15_t)0xbafc, (q15_t)0x6bc9, (q15_t)0xbaf7, + (q15_t)0x6bc5, (q15_t)0xbaf1, (q15_t)0x6bc2, (q15_t)0xbaec, (q15_t)0x6bbe, (q15_t)0xbae7, (q15_t)0x6bbb, (q15_t)0xbae1, + (q15_t)0x6bb8, (q15_t)0xbadc, (q15_t)0x6bb4, (q15_t)0xbad7, (q15_t)0x6bb1, (q15_t)0xbad2, (q15_t)0x6bad, (q15_t)0xbacc, + (q15_t)0x6baa, (q15_t)0xbac7, (q15_t)0x6ba7, (q15_t)0xbac2, (q15_t)0x6ba3, (q15_t)0xbabc, (q15_t)0x6ba0, (q15_t)0xbab7, + (q15_t)0x6b9c, (q15_t)0xbab2, (q15_t)0x6b99, (q15_t)0xbaad, (q15_t)0x6b96, (q15_t)0xbaa7, (q15_t)0x6b92, (q15_t)0xbaa2, + (q15_t)0x6b8f, (q15_t)0xba9d, (q15_t)0x6b8b, (q15_t)0xba97, (q15_t)0x6b88, (q15_t)0xba92, (q15_t)0x6b85, (q15_t)0xba8d, + (q15_t)0x6b81, (q15_t)0xba88, (q15_t)0x6b7e, (q15_t)0xba82, (q15_t)0x6b7a, (q15_t)0xba7d, (q15_t)0x6b77, (q15_t)0xba78, + (q15_t)0x6b73, (q15_t)0xba73, (q15_t)0x6b70, (q15_t)0xba6d, (q15_t)0x6b6d, (q15_t)0xba68, (q15_t)0x6b69, (q15_t)0xba63, + (q15_t)0x6b66, (q15_t)0xba5d, (q15_t)0x6b62, (q15_t)0xba58, (q15_t)0x6b5f, (q15_t)0xba53, (q15_t)0x6b5c, (q15_t)0xba4e, + (q15_t)0x6b58, (q15_t)0xba48, (q15_t)0x6b55, (q15_t)0xba43, (q15_t)0x6b51, (q15_t)0xba3e, (q15_t)0x6b4e, (q15_t)0xba39, + (q15_t)0x6b4a, (q15_t)0xba33, (q15_t)0x6b47, (q15_t)0xba2e, (q15_t)0x6b44, (q15_t)0xba29, (q15_t)0x6b40, (q15_t)0xba23, + (q15_t)0x6b3d, (q15_t)0xba1e, (q15_t)0x6b39, (q15_t)0xba19, (q15_t)0x6b36, (q15_t)0xba14, (q15_t)0x6b32, (q15_t)0xba0e, + (q15_t)0x6b2f, (q15_t)0xba09, (q15_t)0x6b2c, (q15_t)0xba04, (q15_t)0x6b28, (q15_t)0xb9ff, (q15_t)0x6b25, (q15_t)0xb9f9, + (q15_t)0x6b21, (q15_t)0xb9f4, (q15_t)0x6b1e, (q15_t)0xb9ef, (q15_t)0x6b1a, (q15_t)0xb9ea, (q15_t)0x6b17, (q15_t)0xb9e4, + (q15_t)0x6b13, (q15_t)0xb9df, (q15_t)0x6b10, (q15_t)0xb9da, (q15_t)0x6b0d, (q15_t)0xb9d5, (q15_t)0x6b09, (q15_t)0xb9cf, + (q15_t)0x6b06, (q15_t)0xb9ca, (q15_t)0x6b02, (q15_t)0xb9c5, (q15_t)0x6aff, (q15_t)0xb9c0, (q15_t)0x6afb, (q15_t)0xb9ba, + (q15_t)0x6af8, (q15_t)0xb9b5, (q15_t)0x6af4, (q15_t)0xb9b0, (q15_t)0x6af1, (q15_t)0xb9ab, (q15_t)0x6aee, (q15_t)0xb9a5, + (q15_t)0x6aea, (q15_t)0xb9a0, (q15_t)0x6ae7, (q15_t)0xb99b, (q15_t)0x6ae3, (q15_t)0xb996, (q15_t)0x6ae0, (q15_t)0xb990, + (q15_t)0x6adc, (q15_t)0xb98b, (q15_t)0x6ad9, (q15_t)0xb986, (q15_t)0x6ad5, (q15_t)0xb981, (q15_t)0x6ad2, (q15_t)0xb97b, + (q15_t)0x6ace, (q15_t)0xb976, (q15_t)0x6acb, (q15_t)0xb971, (q15_t)0x6ac8, (q15_t)0xb96c, (q15_t)0x6ac4, (q15_t)0xb966, + (q15_t)0x6ac1, (q15_t)0xb961, (q15_t)0x6abd, (q15_t)0xb95c, (q15_t)0x6aba, (q15_t)0xb957, (q15_t)0x6ab6, (q15_t)0xb951, + (q15_t)0x6ab3, (q15_t)0xb94c, (q15_t)0x6aaf, (q15_t)0xb947, (q15_t)0x6aac, (q15_t)0xb942, (q15_t)0x6aa8, (q15_t)0xb93c, + (q15_t)0x6aa5, (q15_t)0xb937, (q15_t)0x6aa1, (q15_t)0xb932, (q15_t)0x6a9e, (q15_t)0xb92d, (q15_t)0x6a9a, (q15_t)0xb928, + (q15_t)0x6a97, (q15_t)0xb922, (q15_t)0x6a93, (q15_t)0xb91d, (q15_t)0x6a90, (q15_t)0xb918, (q15_t)0x6a8c, (q15_t)0xb913, + (q15_t)0x6a89, (q15_t)0xb90d, (q15_t)0x6a86, (q15_t)0xb908, (q15_t)0x6a82, (q15_t)0xb903, (q15_t)0x6a7f, (q15_t)0xb8fe, + (q15_t)0x6a7b, (q15_t)0xb8f8, (q15_t)0x6a78, (q15_t)0xb8f3, (q15_t)0x6a74, (q15_t)0xb8ee, (q15_t)0x6a71, (q15_t)0xb8e9, + (q15_t)0x6a6d, (q15_t)0xb8e4, (q15_t)0x6a6a, (q15_t)0xb8de, (q15_t)0x6a66, (q15_t)0xb8d9, (q15_t)0x6a63, (q15_t)0xb8d4, + (q15_t)0x6a5f, (q15_t)0xb8cf, (q15_t)0x6a5c, (q15_t)0xb8c9, (q15_t)0x6a58, (q15_t)0xb8c4, (q15_t)0x6a55, (q15_t)0xb8bf, + (q15_t)0x6a51, (q15_t)0xb8ba, (q15_t)0x6a4e, (q15_t)0xb8b5, (q15_t)0x6a4a, (q15_t)0xb8af, (q15_t)0x6a47, (q15_t)0xb8aa, + (q15_t)0x6a43, (q15_t)0xb8a5, (q15_t)0x6a40, (q15_t)0xb8a0, (q15_t)0x6a3c, (q15_t)0xb89b, (q15_t)0x6a39, (q15_t)0xb895, + (q15_t)0x6a35, (q15_t)0xb890, (q15_t)0x6a32, (q15_t)0xb88b, (q15_t)0x6a2e, (q15_t)0xb886, (q15_t)0x6a2b, (q15_t)0xb880, + (q15_t)0x6a27, (q15_t)0xb87b, (q15_t)0x6a24, (q15_t)0xb876, (q15_t)0x6a20, (q15_t)0xb871, (q15_t)0x6a1d, (q15_t)0xb86c, + (q15_t)0x6a19, (q15_t)0xb866, (q15_t)0x6a16, (q15_t)0xb861, (q15_t)0x6a12, (q15_t)0xb85c, (q15_t)0x6a0e, (q15_t)0xb857, + (q15_t)0x6a0b, (q15_t)0xb852, (q15_t)0x6a07, (q15_t)0xb84c, (q15_t)0x6a04, (q15_t)0xb847, (q15_t)0x6a00, (q15_t)0xb842, + (q15_t)0x69fd, (q15_t)0xb83d, (q15_t)0x69f9, (q15_t)0xb838, (q15_t)0x69f6, (q15_t)0xb832, (q15_t)0x69f2, (q15_t)0xb82d, + (q15_t)0x69ef, (q15_t)0xb828, (q15_t)0x69eb, (q15_t)0xb823, (q15_t)0x69e8, (q15_t)0xb81e, (q15_t)0x69e4, (q15_t)0xb818, + (q15_t)0x69e1, (q15_t)0xb813, (q15_t)0x69dd, (q15_t)0xb80e, (q15_t)0x69da, (q15_t)0xb809, (q15_t)0x69d6, (q15_t)0xb804, + (q15_t)0x69d3, (q15_t)0xb7fe, (q15_t)0x69cf, (q15_t)0xb7f9, (q15_t)0x69cb, (q15_t)0xb7f4, (q15_t)0x69c8, (q15_t)0xb7ef, + (q15_t)0x69c4, (q15_t)0xb7ea, (q15_t)0x69c1, (q15_t)0xb7e4, (q15_t)0x69bd, (q15_t)0xb7df, (q15_t)0x69ba, (q15_t)0xb7da, + (q15_t)0x69b6, (q15_t)0xb7d5, (q15_t)0x69b3, (q15_t)0xb7d0, (q15_t)0x69af, (q15_t)0xb7ca, (q15_t)0x69ac, (q15_t)0xb7c5, + (q15_t)0x69a8, (q15_t)0xb7c0, (q15_t)0x69a5, (q15_t)0xb7bb, (q15_t)0x69a1, (q15_t)0xb7b6, (q15_t)0x699d, (q15_t)0xb7b1, + (q15_t)0x699a, (q15_t)0xb7ab, (q15_t)0x6996, (q15_t)0xb7a6, (q15_t)0x6993, (q15_t)0xb7a1, (q15_t)0x698f, (q15_t)0xb79c, + (q15_t)0x698c, (q15_t)0xb797, (q15_t)0x6988, (q15_t)0xb791, (q15_t)0x6985, (q15_t)0xb78c, (q15_t)0x6981, (q15_t)0xb787, + (q15_t)0x697d, (q15_t)0xb782, (q15_t)0x697a, (q15_t)0xb77d, (q15_t)0x6976, (q15_t)0xb778, (q15_t)0x6973, (q15_t)0xb772, + (q15_t)0x696f, (q15_t)0xb76d, (q15_t)0x696c, (q15_t)0xb768, (q15_t)0x6968, (q15_t)0xb763, (q15_t)0x6964, (q15_t)0xb75e, + (q15_t)0x6961, (q15_t)0xb758, (q15_t)0x695d, (q15_t)0xb753, (q15_t)0x695a, (q15_t)0xb74e, (q15_t)0x6956, (q15_t)0xb749, + (q15_t)0x6953, (q15_t)0xb744, (q15_t)0x694f, (q15_t)0xb73f, (q15_t)0x694b, (q15_t)0xb739, (q15_t)0x6948, (q15_t)0xb734, + (q15_t)0x6944, (q15_t)0xb72f, (q15_t)0x6941, (q15_t)0xb72a, (q15_t)0x693d, (q15_t)0xb725, (q15_t)0x693a, (q15_t)0xb720, + (q15_t)0x6936, (q15_t)0xb71a, (q15_t)0x6932, (q15_t)0xb715, (q15_t)0x692f, (q15_t)0xb710, (q15_t)0x692b, (q15_t)0xb70b, + (q15_t)0x6928, (q15_t)0xb706, (q15_t)0x6924, (q15_t)0xb701, (q15_t)0x6921, (q15_t)0xb6fb, (q15_t)0x691d, (q15_t)0xb6f6, + (q15_t)0x6919, (q15_t)0xb6f1, (q15_t)0x6916, (q15_t)0xb6ec, (q15_t)0x6912, (q15_t)0xb6e7, (q15_t)0x690f, (q15_t)0xb6e2, + (q15_t)0x690b, (q15_t)0xb6dd, (q15_t)0x6907, (q15_t)0xb6d7, (q15_t)0x6904, (q15_t)0xb6d2, (q15_t)0x6900, (q15_t)0xb6cd, + (q15_t)0x68fd, (q15_t)0xb6c8, (q15_t)0x68f9, (q15_t)0xb6c3, (q15_t)0x68f5, (q15_t)0xb6be, (q15_t)0x68f2, (q15_t)0xb6b8, + (q15_t)0x68ee, (q15_t)0xb6b3, (q15_t)0x68eb, (q15_t)0xb6ae, (q15_t)0x68e7, (q15_t)0xb6a9, (q15_t)0x68e3, (q15_t)0xb6a4, + (q15_t)0x68e0, (q15_t)0xb69f, (q15_t)0x68dc, (q15_t)0xb69a, (q15_t)0x68d9, (q15_t)0xb694, (q15_t)0x68d5, (q15_t)0xb68f, + (q15_t)0x68d1, (q15_t)0xb68a, (q15_t)0x68ce, (q15_t)0xb685, (q15_t)0x68ca, (q15_t)0xb680, (q15_t)0x68c7, (q15_t)0xb67b, + (q15_t)0x68c3, (q15_t)0xb676, (q15_t)0x68bf, (q15_t)0xb670, (q15_t)0x68bc, (q15_t)0xb66b, (q15_t)0x68b8, (q15_t)0xb666, + (q15_t)0x68b5, (q15_t)0xb661, (q15_t)0x68b1, (q15_t)0xb65c, (q15_t)0x68ad, (q15_t)0xb657, (q15_t)0x68aa, (q15_t)0xb652, + (q15_t)0x68a6, (q15_t)0xb64c, (q15_t)0x68a3, (q15_t)0xb647, (q15_t)0x689f, (q15_t)0xb642, (q15_t)0x689b, (q15_t)0xb63d, + (q15_t)0x6898, (q15_t)0xb638, (q15_t)0x6894, (q15_t)0xb633, (q15_t)0x6890, (q15_t)0xb62e, (q15_t)0x688d, (q15_t)0xb628, + (q15_t)0x6889, (q15_t)0xb623, (q15_t)0x6886, (q15_t)0xb61e, (q15_t)0x6882, (q15_t)0xb619, (q15_t)0x687e, (q15_t)0xb614, + (q15_t)0x687b, (q15_t)0xb60f, (q15_t)0x6877, (q15_t)0xb60a, (q15_t)0x6873, (q15_t)0xb605, (q15_t)0x6870, (q15_t)0xb5ff, + (q15_t)0x686c, (q15_t)0xb5fa, (q15_t)0x6868, (q15_t)0xb5f5, (q15_t)0x6865, (q15_t)0xb5f0, (q15_t)0x6861, (q15_t)0xb5eb, + (q15_t)0x685e, (q15_t)0xb5e6, (q15_t)0x685a, (q15_t)0xb5e1, (q15_t)0x6856, (q15_t)0xb5dc, (q15_t)0x6853, (q15_t)0xb5d6, + (q15_t)0x684f, (q15_t)0xb5d1, (q15_t)0x684b, (q15_t)0xb5cc, (q15_t)0x6848, (q15_t)0xb5c7, (q15_t)0x6844, (q15_t)0xb5c2, + (q15_t)0x6840, (q15_t)0xb5bd, (q15_t)0x683d, (q15_t)0xb5b8, (q15_t)0x6839, (q15_t)0xb5b3, (q15_t)0x6835, (q15_t)0xb5ae, + (q15_t)0x6832, (q15_t)0xb5a8, (q15_t)0x682e, (q15_t)0xb5a3, (q15_t)0x682b, (q15_t)0xb59e, (q15_t)0x6827, (q15_t)0xb599, + (q15_t)0x6823, (q15_t)0xb594, (q15_t)0x6820, (q15_t)0xb58f, (q15_t)0x681c, (q15_t)0xb58a, (q15_t)0x6818, (q15_t)0xb585, + (q15_t)0x6815, (q15_t)0xb57f, (q15_t)0x6811, (q15_t)0xb57a, (q15_t)0x680d, (q15_t)0xb575, (q15_t)0x680a, (q15_t)0xb570, + (q15_t)0x6806, (q15_t)0xb56b, (q15_t)0x6802, (q15_t)0xb566, (q15_t)0x67ff, (q15_t)0xb561, (q15_t)0x67fb, (q15_t)0xb55c, + (q15_t)0x67f7, (q15_t)0xb557, (q15_t)0x67f4, (q15_t)0xb552, (q15_t)0x67f0, (q15_t)0xb54c, (q15_t)0x67ec, (q15_t)0xb547, + (q15_t)0x67e9, (q15_t)0xb542, (q15_t)0x67e5, (q15_t)0xb53d, (q15_t)0x67e1, (q15_t)0xb538, (q15_t)0x67de, (q15_t)0xb533, + (q15_t)0x67da, (q15_t)0xb52e, (q15_t)0x67d6, (q15_t)0xb529, (q15_t)0x67d3, (q15_t)0xb524, (q15_t)0x67cf, (q15_t)0xb51f, + (q15_t)0x67cb, (q15_t)0xb519, (q15_t)0x67c8, (q15_t)0xb514, (q15_t)0x67c4, (q15_t)0xb50f, (q15_t)0x67c0, (q15_t)0xb50a, + (q15_t)0x67bd, (q15_t)0xb505, (q15_t)0x67b9, (q15_t)0xb500, (q15_t)0x67b5, (q15_t)0xb4fb, (q15_t)0x67b2, (q15_t)0xb4f6, + (q15_t)0x67ae, (q15_t)0xb4f1, (q15_t)0x67aa, (q15_t)0xb4ec, (q15_t)0x67a6, (q15_t)0xb4e7, (q15_t)0x67a3, (q15_t)0xb4e1, + (q15_t)0x679f, (q15_t)0xb4dc, (q15_t)0x679b, (q15_t)0xb4d7, (q15_t)0x6798, (q15_t)0xb4d2, (q15_t)0x6794, (q15_t)0xb4cd, + (q15_t)0x6790, (q15_t)0xb4c8, (q15_t)0x678d, (q15_t)0xb4c3, (q15_t)0x6789, (q15_t)0xb4be, (q15_t)0x6785, (q15_t)0xb4b9, + (q15_t)0x6782, (q15_t)0xb4b4, (q15_t)0x677e, (q15_t)0xb4af, (q15_t)0x677a, (q15_t)0xb4aa, (q15_t)0x6776, (q15_t)0xb4a4, + (q15_t)0x6773, (q15_t)0xb49f, (q15_t)0x676f, (q15_t)0xb49a, (q15_t)0x676b, (q15_t)0xb495, (q15_t)0x6768, (q15_t)0xb490, + (q15_t)0x6764, (q15_t)0xb48b, (q15_t)0x6760, (q15_t)0xb486, (q15_t)0x675d, (q15_t)0xb481, (q15_t)0x6759, (q15_t)0xb47c, + (q15_t)0x6755, (q15_t)0xb477, (q15_t)0x6751, (q15_t)0xb472, (q15_t)0x674e, (q15_t)0xb46d, (q15_t)0x674a, (q15_t)0xb468, + (q15_t)0x6746, (q15_t)0xb462, (q15_t)0x6743, (q15_t)0xb45d, (q15_t)0x673f, (q15_t)0xb458, (q15_t)0x673b, (q15_t)0xb453, + (q15_t)0x6737, (q15_t)0xb44e, (q15_t)0x6734, (q15_t)0xb449, (q15_t)0x6730, (q15_t)0xb444, (q15_t)0x672c, (q15_t)0xb43f, + (q15_t)0x6729, (q15_t)0xb43a, (q15_t)0x6725, (q15_t)0xb435, (q15_t)0x6721, (q15_t)0xb430, (q15_t)0x671d, (q15_t)0xb42b, + (q15_t)0x671a, (q15_t)0xb426, (q15_t)0x6716, (q15_t)0xb421, (q15_t)0x6712, (q15_t)0xb41c, (q15_t)0x670e, (q15_t)0xb417, + (q15_t)0x670b, (q15_t)0xb411, (q15_t)0x6707, (q15_t)0xb40c, (q15_t)0x6703, (q15_t)0xb407, (q15_t)0x6700, (q15_t)0xb402, + (q15_t)0x66fc, (q15_t)0xb3fd, (q15_t)0x66f8, (q15_t)0xb3f8, (q15_t)0x66f4, (q15_t)0xb3f3, (q15_t)0x66f1, (q15_t)0xb3ee, + (q15_t)0x66ed, (q15_t)0xb3e9, (q15_t)0x66e9, (q15_t)0xb3e4, (q15_t)0x66e5, (q15_t)0xb3df, (q15_t)0x66e2, (q15_t)0xb3da, + (q15_t)0x66de, (q15_t)0xb3d5, (q15_t)0x66da, (q15_t)0xb3d0, (q15_t)0x66d6, (q15_t)0xb3cb, (q15_t)0x66d3, (q15_t)0xb3c6, + (q15_t)0x66cf, (q15_t)0xb3c1, (q15_t)0x66cb, (q15_t)0xb3bc, (q15_t)0x66c8, (q15_t)0xb3b7, (q15_t)0x66c4, (q15_t)0xb3b1, + (q15_t)0x66c0, (q15_t)0xb3ac, (q15_t)0x66bc, (q15_t)0xb3a7, (q15_t)0x66b9, (q15_t)0xb3a2, (q15_t)0x66b5, (q15_t)0xb39d, + (q15_t)0x66b1, (q15_t)0xb398, (q15_t)0x66ad, (q15_t)0xb393, (q15_t)0x66aa, (q15_t)0xb38e, (q15_t)0x66a6, (q15_t)0xb389, + (q15_t)0x66a2, (q15_t)0xb384, (q15_t)0x669e, (q15_t)0xb37f, (q15_t)0x669b, (q15_t)0xb37a, (q15_t)0x6697, (q15_t)0xb375, + (q15_t)0x6693, (q15_t)0xb370, (q15_t)0x668f, (q15_t)0xb36b, (q15_t)0x668b, (q15_t)0xb366, (q15_t)0x6688, (q15_t)0xb361, + (q15_t)0x6684, (q15_t)0xb35c, (q15_t)0x6680, (q15_t)0xb357, (q15_t)0x667c, (q15_t)0xb352, (q15_t)0x6679, (q15_t)0xb34d, + (q15_t)0x6675, (q15_t)0xb348, (q15_t)0x6671, (q15_t)0xb343, (q15_t)0x666d, (q15_t)0xb33e, (q15_t)0x666a, (q15_t)0xb339, + (q15_t)0x6666, (q15_t)0xb334, (q15_t)0x6662, (q15_t)0xb32f, (q15_t)0x665e, (q15_t)0xb32a, (q15_t)0x665b, (q15_t)0xb325, + (q15_t)0x6657, (q15_t)0xb31f, (q15_t)0x6653, (q15_t)0xb31a, (q15_t)0x664f, (q15_t)0xb315, (q15_t)0x664b, (q15_t)0xb310, + (q15_t)0x6648, (q15_t)0xb30b, (q15_t)0x6644, (q15_t)0xb306, (q15_t)0x6640, (q15_t)0xb301, (q15_t)0x663c, (q15_t)0xb2fc, + (q15_t)0x6639, (q15_t)0xb2f7, (q15_t)0x6635, (q15_t)0xb2f2, (q15_t)0x6631, (q15_t)0xb2ed, (q15_t)0x662d, (q15_t)0xb2e8, + (q15_t)0x6629, (q15_t)0xb2e3, (q15_t)0x6626, (q15_t)0xb2de, (q15_t)0x6622, (q15_t)0xb2d9, (q15_t)0x661e, (q15_t)0xb2d4, + (q15_t)0x661a, (q15_t)0xb2cf, (q15_t)0x6616, (q15_t)0xb2ca, (q15_t)0x6613, (q15_t)0xb2c5, (q15_t)0x660f, (q15_t)0xb2c0, + (q15_t)0x660b, (q15_t)0xb2bb, (q15_t)0x6607, (q15_t)0xb2b6, (q15_t)0x6603, (q15_t)0xb2b1, (q15_t)0x6600, (q15_t)0xb2ac, + (q15_t)0x65fc, (q15_t)0xb2a7, (q15_t)0x65f8, (q15_t)0xb2a2, (q15_t)0x65f4, (q15_t)0xb29d, (q15_t)0x65f0, (q15_t)0xb298, + (q15_t)0x65ed, (q15_t)0xb293, (q15_t)0x65e9, (q15_t)0xb28e, (q15_t)0x65e5, (q15_t)0xb289, (q15_t)0x65e1, (q15_t)0xb284, + (q15_t)0x65dd, (q15_t)0xb27f, (q15_t)0x65da, (q15_t)0xb27a, (q15_t)0x65d6, (q15_t)0xb275, (q15_t)0x65d2, (q15_t)0xb270, + (q15_t)0x65ce, (q15_t)0xb26b, (q15_t)0x65ca, (q15_t)0xb266, (q15_t)0x65c7, (q15_t)0xb261, (q15_t)0x65c3, (q15_t)0xb25c, + (q15_t)0x65bf, (q15_t)0xb257, (q15_t)0x65bb, (q15_t)0xb252, (q15_t)0x65b7, (q15_t)0xb24d, (q15_t)0x65b4, (q15_t)0xb248, + (q15_t)0x65b0, (q15_t)0xb243, (q15_t)0x65ac, (q15_t)0xb23e, (q15_t)0x65a8, (q15_t)0xb239, (q15_t)0x65a4, (q15_t)0xb234, + (q15_t)0x65a0, (q15_t)0xb22f, (q15_t)0x659d, (q15_t)0xb22a, (q15_t)0x6599, (q15_t)0xb225, (q15_t)0x6595, (q15_t)0xb220, + (q15_t)0x6591, (q15_t)0xb21b, (q15_t)0x658d, (q15_t)0xb216, (q15_t)0x658a, (q15_t)0xb211, (q15_t)0x6586, (q15_t)0xb20c, + (q15_t)0x6582, (q15_t)0xb207, (q15_t)0x657e, (q15_t)0xb202, (q15_t)0x657a, (q15_t)0xb1fd, (q15_t)0x6576, (q15_t)0xb1f8, + (q15_t)0x6573, (q15_t)0xb1f3, (q15_t)0x656f, (q15_t)0xb1ee, (q15_t)0x656b, (q15_t)0xb1e9, (q15_t)0x6567, (q15_t)0xb1e4, + (q15_t)0x6563, (q15_t)0xb1df, (q15_t)0x655f, (q15_t)0xb1da, (q15_t)0x655c, (q15_t)0xb1d6, (q15_t)0x6558, (q15_t)0xb1d1, + (q15_t)0x6554, (q15_t)0xb1cc, (q15_t)0x6550, (q15_t)0xb1c7, (q15_t)0x654c, (q15_t)0xb1c2, (q15_t)0x6548, (q15_t)0xb1bd, + (q15_t)0x6545, (q15_t)0xb1b8, (q15_t)0x6541, (q15_t)0xb1b3, (q15_t)0x653d, (q15_t)0xb1ae, (q15_t)0x6539, (q15_t)0xb1a9, + (q15_t)0x6535, (q15_t)0xb1a4, (q15_t)0x6531, (q15_t)0xb19f, (q15_t)0x652d, (q15_t)0xb19a, (q15_t)0x652a, (q15_t)0xb195, + (q15_t)0x6526, (q15_t)0xb190, (q15_t)0x6522, (q15_t)0xb18b, (q15_t)0x651e, (q15_t)0xb186, (q15_t)0x651a, (q15_t)0xb181, + (q15_t)0x6516, (q15_t)0xb17c, (q15_t)0x6513, (q15_t)0xb177, (q15_t)0x650f, (q15_t)0xb172, (q15_t)0x650b, (q15_t)0xb16d, + (q15_t)0x6507, (q15_t)0xb168, (q15_t)0x6503, (q15_t)0xb163, (q15_t)0x64ff, (q15_t)0xb15e, (q15_t)0x64fb, (q15_t)0xb159, + (q15_t)0x64f7, (q15_t)0xb154, (q15_t)0x64f4, (q15_t)0xb14f, (q15_t)0x64f0, (q15_t)0xb14a, (q15_t)0x64ec, (q15_t)0xb146, + (q15_t)0x64e8, (q15_t)0xb141, (q15_t)0x64e4, (q15_t)0xb13c, (q15_t)0x64e0, (q15_t)0xb137, (q15_t)0x64dc, (q15_t)0xb132, + (q15_t)0x64d9, (q15_t)0xb12d, (q15_t)0x64d5, (q15_t)0xb128, (q15_t)0x64d1, (q15_t)0xb123, (q15_t)0x64cd, (q15_t)0xb11e, + (q15_t)0x64c9, (q15_t)0xb119, (q15_t)0x64c5, (q15_t)0xb114, (q15_t)0x64c1, (q15_t)0xb10f, (q15_t)0x64bd, (q15_t)0xb10a, + (q15_t)0x64ba, (q15_t)0xb105, (q15_t)0x64b6, (q15_t)0xb100, (q15_t)0x64b2, (q15_t)0xb0fb, (q15_t)0x64ae, (q15_t)0xb0f6, + (q15_t)0x64aa, (q15_t)0xb0f1, (q15_t)0x64a6, (q15_t)0xb0ec, (q15_t)0x64a2, (q15_t)0xb0e8, (q15_t)0x649e, (q15_t)0xb0e3, + (q15_t)0x649b, (q15_t)0xb0de, (q15_t)0x6497, (q15_t)0xb0d9, (q15_t)0x6493, (q15_t)0xb0d4, (q15_t)0x648f, (q15_t)0xb0cf, + (q15_t)0x648b, (q15_t)0xb0ca, (q15_t)0x6487, (q15_t)0xb0c5, (q15_t)0x6483, (q15_t)0xb0c0, (q15_t)0x647f, (q15_t)0xb0bb, + (q15_t)0x647b, (q15_t)0xb0b6, (q15_t)0x6478, (q15_t)0xb0b1, (q15_t)0x6474, (q15_t)0xb0ac, (q15_t)0x6470, (q15_t)0xb0a7, + (q15_t)0x646c, (q15_t)0xb0a2, (q15_t)0x6468, (q15_t)0xb09e, (q15_t)0x6464, (q15_t)0xb099, (q15_t)0x6460, (q15_t)0xb094, + (q15_t)0x645c, (q15_t)0xb08f, (q15_t)0x6458, (q15_t)0xb08a, (q15_t)0x6454, (q15_t)0xb085, (q15_t)0x6451, (q15_t)0xb080, + (q15_t)0x644d, (q15_t)0xb07b, (q15_t)0x6449, (q15_t)0xb076, (q15_t)0x6445, (q15_t)0xb071, (q15_t)0x6441, (q15_t)0xb06c, + (q15_t)0x643d, (q15_t)0xb067, (q15_t)0x6439, (q15_t)0xb062, (q15_t)0x6435, (q15_t)0xb05e, (q15_t)0x6431, (q15_t)0xb059, + (q15_t)0x642d, (q15_t)0xb054, (q15_t)0x6429, (q15_t)0xb04f, (q15_t)0x6426, (q15_t)0xb04a, (q15_t)0x6422, (q15_t)0xb045, + (q15_t)0x641e, (q15_t)0xb040, (q15_t)0x641a, (q15_t)0xb03b, (q15_t)0x6416, (q15_t)0xb036, (q15_t)0x6412, (q15_t)0xb031, + (q15_t)0x640e, (q15_t)0xb02c, (q15_t)0x640a, (q15_t)0xb027, (q15_t)0x6406, (q15_t)0xb023, (q15_t)0x6402, (q15_t)0xb01e, + (q15_t)0x63fe, (q15_t)0xb019, (q15_t)0x63fa, (q15_t)0xb014, (q15_t)0x63f7, (q15_t)0xb00f, (q15_t)0x63f3, (q15_t)0xb00a, + (q15_t)0x63ef, (q15_t)0xb005, (q15_t)0x63eb, (q15_t)0xb000, (q15_t)0x63e7, (q15_t)0xaffb, (q15_t)0x63e3, (q15_t)0xaff6, + (q15_t)0x63df, (q15_t)0xaff1, (q15_t)0x63db, (q15_t)0xafed, (q15_t)0x63d7, (q15_t)0xafe8, (q15_t)0x63d3, (q15_t)0xafe3, + (q15_t)0x63cf, (q15_t)0xafde, (q15_t)0x63cb, (q15_t)0xafd9, (q15_t)0x63c7, (q15_t)0xafd4, (q15_t)0x63c3, (q15_t)0xafcf, + (q15_t)0x63c0, (q15_t)0xafca, (q15_t)0x63bc, (q15_t)0xafc5, (q15_t)0x63b8, (q15_t)0xafc1, (q15_t)0x63b4, (q15_t)0xafbc, + (q15_t)0x63b0, (q15_t)0xafb7, (q15_t)0x63ac, (q15_t)0xafb2, (q15_t)0x63a8, (q15_t)0xafad, (q15_t)0x63a4, (q15_t)0xafa8, + (q15_t)0x63a0, (q15_t)0xafa3, (q15_t)0x639c, (q15_t)0xaf9e, (q15_t)0x6398, (q15_t)0xaf99, (q15_t)0x6394, (q15_t)0xaf94, + (q15_t)0x6390, (q15_t)0xaf90, (q15_t)0x638c, (q15_t)0xaf8b, (q15_t)0x6388, (q15_t)0xaf86, (q15_t)0x6384, (q15_t)0xaf81, + (q15_t)0x6380, (q15_t)0xaf7c, (q15_t)0x637c, (q15_t)0xaf77, (q15_t)0x6378, (q15_t)0xaf72, (q15_t)0x6375, (q15_t)0xaf6d, + (q15_t)0x6371, (q15_t)0xaf69, (q15_t)0x636d, (q15_t)0xaf64, (q15_t)0x6369, (q15_t)0xaf5f, (q15_t)0x6365, (q15_t)0xaf5a, + (q15_t)0x6361, (q15_t)0xaf55, (q15_t)0x635d, (q15_t)0xaf50, (q15_t)0x6359, (q15_t)0xaf4b, (q15_t)0x6355, (q15_t)0xaf46, + (q15_t)0x6351, (q15_t)0xaf41, (q15_t)0x634d, (q15_t)0xaf3d, (q15_t)0x6349, (q15_t)0xaf38, (q15_t)0x6345, (q15_t)0xaf33, + (q15_t)0x6341, (q15_t)0xaf2e, (q15_t)0x633d, (q15_t)0xaf29, (q15_t)0x6339, (q15_t)0xaf24, (q15_t)0x6335, (q15_t)0xaf1f, + (q15_t)0x6331, (q15_t)0xaf1b, (q15_t)0x632d, (q15_t)0xaf16, (q15_t)0x6329, (q15_t)0xaf11, (q15_t)0x6325, (q15_t)0xaf0c, + (q15_t)0x6321, (q15_t)0xaf07, (q15_t)0x631d, (q15_t)0xaf02, (q15_t)0x6319, (q15_t)0xaefd, (q15_t)0x6315, (q15_t)0xaef8, + (q15_t)0x6311, (q15_t)0xaef4, (q15_t)0x630d, (q15_t)0xaeef, (q15_t)0x6309, (q15_t)0xaeea, (q15_t)0x6305, (q15_t)0xaee5, + (q15_t)0x6301, (q15_t)0xaee0, (q15_t)0x62fd, (q15_t)0xaedb, (q15_t)0x62f9, (q15_t)0xaed6, (q15_t)0x62f5, (q15_t)0xaed2, + (q15_t)0x62f2, (q15_t)0xaecd, (q15_t)0x62ee, (q15_t)0xaec8, (q15_t)0x62ea, (q15_t)0xaec3, (q15_t)0x62e6, (q15_t)0xaebe, + (q15_t)0x62e2, (q15_t)0xaeb9, (q15_t)0x62de, (q15_t)0xaeb4, (q15_t)0x62da, (q15_t)0xaeb0, (q15_t)0x62d6, (q15_t)0xaeab, + (q15_t)0x62d2, (q15_t)0xaea6, (q15_t)0x62ce, (q15_t)0xaea1, (q15_t)0x62ca, (q15_t)0xae9c, (q15_t)0x62c6, (q15_t)0xae97, + (q15_t)0x62c2, (q15_t)0xae92, (q15_t)0x62be, (q15_t)0xae8e, (q15_t)0x62ba, (q15_t)0xae89, (q15_t)0x62b6, (q15_t)0xae84, + (q15_t)0x62b2, (q15_t)0xae7f, (q15_t)0x62ae, (q15_t)0xae7a, (q15_t)0x62aa, (q15_t)0xae75, (q15_t)0x62a6, (q15_t)0xae71, + (q15_t)0x62a2, (q15_t)0xae6c, (q15_t)0x629e, (q15_t)0xae67, (q15_t)0x629a, (q15_t)0xae62, (q15_t)0x6296, (q15_t)0xae5d, + (q15_t)0x6292, (q15_t)0xae58, (q15_t)0x628e, (q15_t)0xae54, (q15_t)0x628a, (q15_t)0xae4f, (q15_t)0x6286, (q15_t)0xae4a, + (q15_t)0x6282, (q15_t)0xae45, (q15_t)0x627e, (q15_t)0xae40, (q15_t)0x627a, (q15_t)0xae3b, (q15_t)0x6275, (q15_t)0xae37, + (q15_t)0x6271, (q15_t)0xae32, (q15_t)0x626d, (q15_t)0xae2d, (q15_t)0x6269, (q15_t)0xae28, (q15_t)0x6265, (q15_t)0xae23, + (q15_t)0x6261, (q15_t)0xae1e, (q15_t)0x625d, (q15_t)0xae1a, (q15_t)0x6259, (q15_t)0xae15, (q15_t)0x6255, (q15_t)0xae10, + (q15_t)0x6251, (q15_t)0xae0b, (q15_t)0x624d, (q15_t)0xae06, (q15_t)0x6249, (q15_t)0xae01, (q15_t)0x6245, (q15_t)0xadfd, + (q15_t)0x6241, (q15_t)0xadf8, (q15_t)0x623d, (q15_t)0xadf3, (q15_t)0x6239, (q15_t)0xadee, (q15_t)0x6235, (q15_t)0xade9, + (q15_t)0x6231, (q15_t)0xade4, (q15_t)0x622d, (q15_t)0xade0, (q15_t)0x6229, (q15_t)0xaddb, (q15_t)0x6225, (q15_t)0xadd6, + (q15_t)0x6221, (q15_t)0xadd1, (q15_t)0x621d, (q15_t)0xadcc, (q15_t)0x6219, (q15_t)0xadc8, (q15_t)0x6215, (q15_t)0xadc3, + (q15_t)0x6211, (q15_t)0xadbe, (q15_t)0x620d, (q15_t)0xadb9, (q15_t)0x6209, (q15_t)0xadb4, (q15_t)0x6205, (q15_t)0xadaf, + (q15_t)0x6201, (q15_t)0xadab, (q15_t)0x61fd, (q15_t)0xada6, (q15_t)0x61f9, (q15_t)0xada1, (q15_t)0x61f5, (q15_t)0xad9c, + (q15_t)0x61f1, (q15_t)0xad97, (q15_t)0x61ec, (q15_t)0xad93, (q15_t)0x61e8, (q15_t)0xad8e, (q15_t)0x61e4, (q15_t)0xad89, + (q15_t)0x61e0, (q15_t)0xad84, (q15_t)0x61dc, (q15_t)0xad7f, (q15_t)0x61d8, (q15_t)0xad7b, (q15_t)0x61d4, (q15_t)0xad76, + (q15_t)0x61d0, (q15_t)0xad71, (q15_t)0x61cc, (q15_t)0xad6c, (q15_t)0x61c8, (q15_t)0xad67, (q15_t)0x61c4, (q15_t)0xad63, + (q15_t)0x61c0, (q15_t)0xad5e, (q15_t)0x61bc, (q15_t)0xad59, (q15_t)0x61b8, (q15_t)0xad54, (q15_t)0x61b4, (q15_t)0xad4f, + (q15_t)0x61b0, (q15_t)0xad4b, (q15_t)0x61ac, (q15_t)0xad46, (q15_t)0x61a8, (q15_t)0xad41, (q15_t)0x61a3, (q15_t)0xad3c, + (q15_t)0x619f, (q15_t)0xad37, (q15_t)0x619b, (q15_t)0xad33, (q15_t)0x6197, (q15_t)0xad2e, (q15_t)0x6193, (q15_t)0xad29, + (q15_t)0x618f, (q15_t)0xad24, (q15_t)0x618b, (q15_t)0xad1f, (q15_t)0x6187, (q15_t)0xad1b, (q15_t)0x6183, (q15_t)0xad16, + (q15_t)0x617f, (q15_t)0xad11, (q15_t)0x617b, (q15_t)0xad0c, (q15_t)0x6177, (q15_t)0xad08, (q15_t)0x6173, (q15_t)0xad03, + (q15_t)0x616f, (q15_t)0xacfe, (q15_t)0x616b, (q15_t)0xacf9, (q15_t)0x6166, (q15_t)0xacf4, (q15_t)0x6162, (q15_t)0xacf0, + (q15_t)0x615e, (q15_t)0xaceb, (q15_t)0x615a, (q15_t)0xace6, (q15_t)0x6156, (q15_t)0xace1, (q15_t)0x6152, (q15_t)0xacdd, + (q15_t)0x614e, (q15_t)0xacd8, (q15_t)0x614a, (q15_t)0xacd3, (q15_t)0x6146, (q15_t)0xacce, (q15_t)0x6142, (q15_t)0xacc9, + (q15_t)0x613e, (q15_t)0xacc5, (q15_t)0x613a, (q15_t)0xacc0, (q15_t)0x6135, (q15_t)0xacbb, (q15_t)0x6131, (q15_t)0xacb6, + (q15_t)0x612d, (q15_t)0xacb2, (q15_t)0x6129, (q15_t)0xacad, (q15_t)0x6125, (q15_t)0xaca8, (q15_t)0x6121, (q15_t)0xaca3, + (q15_t)0x611d, (q15_t)0xac9e, (q15_t)0x6119, (q15_t)0xac9a, (q15_t)0x6115, (q15_t)0xac95, (q15_t)0x6111, (q15_t)0xac90, + (q15_t)0x610d, (q15_t)0xac8b, (q15_t)0x6108, (q15_t)0xac87, (q15_t)0x6104, (q15_t)0xac82, (q15_t)0x6100, (q15_t)0xac7d, + (q15_t)0x60fc, (q15_t)0xac78, (q15_t)0x60f8, (q15_t)0xac74, (q15_t)0x60f4, (q15_t)0xac6f, (q15_t)0x60f0, (q15_t)0xac6a, + (q15_t)0x60ec, (q15_t)0xac65, (q15_t)0x60e8, (q15_t)0xac61, (q15_t)0x60e4, (q15_t)0xac5c, (q15_t)0x60df, (q15_t)0xac57, + (q15_t)0x60db, (q15_t)0xac52, (q15_t)0x60d7, (q15_t)0xac4e, (q15_t)0x60d3, (q15_t)0xac49, (q15_t)0x60cf, (q15_t)0xac44, + (q15_t)0x60cb, (q15_t)0xac3f, (q15_t)0x60c7, (q15_t)0xac3b, (q15_t)0x60c3, (q15_t)0xac36, (q15_t)0x60bf, (q15_t)0xac31, + (q15_t)0x60ba, (q15_t)0xac2c, (q15_t)0x60b6, (q15_t)0xac28, (q15_t)0x60b2, (q15_t)0xac23, (q15_t)0x60ae, (q15_t)0xac1e, + (q15_t)0x60aa, (q15_t)0xac19, (q15_t)0x60a6, (q15_t)0xac15, (q15_t)0x60a2, (q15_t)0xac10, (q15_t)0x609e, (q15_t)0xac0b, + (q15_t)0x6099, (q15_t)0xac06, (q15_t)0x6095, (q15_t)0xac02, (q15_t)0x6091, (q15_t)0xabfd, (q15_t)0x608d, (q15_t)0xabf8, + (q15_t)0x6089, (q15_t)0xabf3, (q15_t)0x6085, (q15_t)0xabef, (q15_t)0x6081, (q15_t)0xabea, (q15_t)0x607d, (q15_t)0xabe5, + (q15_t)0x6078, (q15_t)0xabe0, (q15_t)0x6074, (q15_t)0xabdc, (q15_t)0x6070, (q15_t)0xabd7, (q15_t)0x606c, (q15_t)0xabd2, + (q15_t)0x6068, (q15_t)0xabcd, (q15_t)0x6064, (q15_t)0xabc9, (q15_t)0x6060, (q15_t)0xabc4, (q15_t)0x605c, (q15_t)0xabbf, + (q15_t)0x6057, (q15_t)0xabbb, (q15_t)0x6053, (q15_t)0xabb6, (q15_t)0x604f, (q15_t)0xabb1, (q15_t)0x604b, (q15_t)0xabac, + (q15_t)0x6047, (q15_t)0xaba8, (q15_t)0x6043, (q15_t)0xaba3, (q15_t)0x603f, (q15_t)0xab9e, (q15_t)0x603a, (q15_t)0xab99, + (q15_t)0x6036, (q15_t)0xab95, (q15_t)0x6032, (q15_t)0xab90, (q15_t)0x602e, (q15_t)0xab8b, (q15_t)0x602a, (q15_t)0xab87, + (q15_t)0x6026, (q15_t)0xab82, (q15_t)0x6022, (q15_t)0xab7d, (q15_t)0x601d, (q15_t)0xab78, (q15_t)0x6019, (q15_t)0xab74, + (q15_t)0x6015, (q15_t)0xab6f, (q15_t)0x6011, (q15_t)0xab6a, (q15_t)0x600d, (q15_t)0xab66, (q15_t)0x6009, (q15_t)0xab61, + (q15_t)0x6004, (q15_t)0xab5c, (q15_t)0x6000, (q15_t)0xab57, (q15_t)0x5ffc, (q15_t)0xab53, (q15_t)0x5ff8, (q15_t)0xab4e, + (q15_t)0x5ff4, (q15_t)0xab49, (q15_t)0x5ff0, (q15_t)0xab45, (q15_t)0x5fec, (q15_t)0xab40, (q15_t)0x5fe7, (q15_t)0xab3b, + (q15_t)0x5fe3, (q15_t)0xab36, (q15_t)0x5fdf, (q15_t)0xab32, (q15_t)0x5fdb, (q15_t)0xab2d, (q15_t)0x5fd7, (q15_t)0xab28, + (q15_t)0x5fd3, (q15_t)0xab24, (q15_t)0x5fce, (q15_t)0xab1f, (q15_t)0x5fca, (q15_t)0xab1a, (q15_t)0x5fc6, (q15_t)0xab16, + (q15_t)0x5fc2, (q15_t)0xab11, (q15_t)0x5fbe, (q15_t)0xab0c, (q15_t)0x5fba, (q15_t)0xab07, (q15_t)0x5fb5, (q15_t)0xab03, + (q15_t)0x5fb1, (q15_t)0xaafe, (q15_t)0x5fad, (q15_t)0xaaf9, (q15_t)0x5fa9, (q15_t)0xaaf5, (q15_t)0x5fa5, (q15_t)0xaaf0, + (q15_t)0x5fa0, (q15_t)0xaaeb, (q15_t)0x5f9c, (q15_t)0xaae7, (q15_t)0x5f98, (q15_t)0xaae2, (q15_t)0x5f94, (q15_t)0xaadd, + (q15_t)0x5f90, (q15_t)0xaad8, (q15_t)0x5f8c, (q15_t)0xaad4, (q15_t)0x5f87, (q15_t)0xaacf, (q15_t)0x5f83, (q15_t)0xaaca, + (q15_t)0x5f7f, (q15_t)0xaac6, (q15_t)0x5f7b, (q15_t)0xaac1, (q15_t)0x5f77, (q15_t)0xaabc, (q15_t)0x5f72, (q15_t)0xaab8, + (q15_t)0x5f6e, (q15_t)0xaab3, (q15_t)0x5f6a, (q15_t)0xaaae, (q15_t)0x5f66, (q15_t)0xaaaa, (q15_t)0x5f62, (q15_t)0xaaa5, + (q15_t)0x5f5e, (q15_t)0xaaa0, (q15_t)0x5f59, (q15_t)0xaa9c, (q15_t)0x5f55, (q15_t)0xaa97, (q15_t)0x5f51, (q15_t)0xaa92, + (q15_t)0x5f4d, (q15_t)0xaa8e, (q15_t)0x5f49, (q15_t)0xaa89, (q15_t)0x5f44, (q15_t)0xaa84, (q15_t)0x5f40, (q15_t)0xaa7f, + (q15_t)0x5f3c, (q15_t)0xaa7b, (q15_t)0x5f38, (q15_t)0xaa76, (q15_t)0x5f34, (q15_t)0xaa71, (q15_t)0x5f2f, (q15_t)0xaa6d, + (q15_t)0x5f2b, (q15_t)0xaa68, (q15_t)0x5f27, (q15_t)0xaa63, (q15_t)0x5f23, (q15_t)0xaa5f, (q15_t)0x5f1f, (q15_t)0xaa5a, + (q15_t)0x5f1a, (q15_t)0xaa55, (q15_t)0x5f16, (q15_t)0xaa51, (q15_t)0x5f12, (q15_t)0xaa4c, (q15_t)0x5f0e, (q15_t)0xaa47, + (q15_t)0x5f0a, (q15_t)0xaa43, (q15_t)0x5f05, (q15_t)0xaa3e, (q15_t)0x5f01, (q15_t)0xaa39, (q15_t)0x5efd, (q15_t)0xaa35, + (q15_t)0x5ef9, (q15_t)0xaa30, (q15_t)0x5ef5, (q15_t)0xaa2b, (q15_t)0x5ef0, (q15_t)0xaa27, (q15_t)0x5eec, (q15_t)0xaa22, + (q15_t)0x5ee8, (q15_t)0xaa1d, (q15_t)0x5ee4, (q15_t)0xaa19, (q15_t)0x5edf, (q15_t)0xaa14, (q15_t)0x5edb, (q15_t)0xaa10, + (q15_t)0x5ed7, (q15_t)0xaa0b, (q15_t)0x5ed3, (q15_t)0xaa06, (q15_t)0x5ecf, (q15_t)0xaa02, (q15_t)0x5eca, (q15_t)0xa9fd, + (q15_t)0x5ec6, (q15_t)0xa9f8, (q15_t)0x5ec2, (q15_t)0xa9f4, (q15_t)0x5ebe, (q15_t)0xa9ef, (q15_t)0x5eb9, (q15_t)0xa9ea, + (q15_t)0x5eb5, (q15_t)0xa9e6, (q15_t)0x5eb1, (q15_t)0xa9e1, (q15_t)0x5ead, (q15_t)0xa9dc, (q15_t)0x5ea9, (q15_t)0xa9d8, + (q15_t)0x5ea4, (q15_t)0xa9d3, (q15_t)0x5ea0, (q15_t)0xa9ce, (q15_t)0x5e9c, (q15_t)0xa9ca, (q15_t)0x5e98, (q15_t)0xa9c5, + (q15_t)0x5e93, (q15_t)0xa9c0, (q15_t)0x5e8f, (q15_t)0xa9bc, (q15_t)0x5e8b, (q15_t)0xa9b7, (q15_t)0x5e87, (q15_t)0xa9b3, + (q15_t)0x5e82, (q15_t)0xa9ae, (q15_t)0x5e7e, (q15_t)0xa9a9, (q15_t)0x5e7a, (q15_t)0xa9a5, (q15_t)0x5e76, (q15_t)0xa9a0, + (q15_t)0x5e71, (q15_t)0xa99b, (q15_t)0x5e6d, (q15_t)0xa997, (q15_t)0x5e69, (q15_t)0xa992, (q15_t)0x5e65, (q15_t)0xa98d, + (q15_t)0x5e60, (q15_t)0xa989, (q15_t)0x5e5c, (q15_t)0xa984, (q15_t)0x5e58, (q15_t)0xa980, (q15_t)0x5e54, (q15_t)0xa97b, + (q15_t)0x5e50, (q15_t)0xa976, (q15_t)0x5e4b, (q15_t)0xa972, (q15_t)0x5e47, (q15_t)0xa96d, (q15_t)0x5e43, (q15_t)0xa968, + (q15_t)0x5e3f, (q15_t)0xa964, (q15_t)0x5e3a, (q15_t)0xa95f, (q15_t)0x5e36, (q15_t)0xa95b, (q15_t)0x5e32, (q15_t)0xa956, + (q15_t)0x5e2d, (q15_t)0xa951, (q15_t)0x5e29, (q15_t)0xa94d, (q15_t)0x5e25, (q15_t)0xa948, (q15_t)0x5e21, (q15_t)0xa943, + (q15_t)0x5e1c, (q15_t)0xa93f, (q15_t)0x5e18, (q15_t)0xa93a, (q15_t)0x5e14, (q15_t)0xa936, (q15_t)0x5e10, (q15_t)0xa931, + (q15_t)0x5e0b, (q15_t)0xa92c, (q15_t)0x5e07, (q15_t)0xa928, (q15_t)0x5e03, (q15_t)0xa923, (q15_t)0x5dff, (q15_t)0xa91e, + (q15_t)0x5dfa, (q15_t)0xa91a, (q15_t)0x5df6, (q15_t)0xa915, (q15_t)0x5df2, (q15_t)0xa911, (q15_t)0x5dee, (q15_t)0xa90c, + (q15_t)0x5de9, (q15_t)0xa907, (q15_t)0x5de5, (q15_t)0xa903, (q15_t)0x5de1, (q15_t)0xa8fe, (q15_t)0x5ddc, (q15_t)0xa8fa, + (q15_t)0x5dd8, (q15_t)0xa8f5, (q15_t)0x5dd4, (q15_t)0xa8f0, (q15_t)0x5dd0, (q15_t)0xa8ec, (q15_t)0x5dcb, (q15_t)0xa8e7, + (q15_t)0x5dc7, (q15_t)0xa8e3, (q15_t)0x5dc3, (q15_t)0xa8de, (q15_t)0x5dbf, (q15_t)0xa8d9, (q15_t)0x5dba, (q15_t)0xa8d5, + (q15_t)0x5db6, (q15_t)0xa8d0, (q15_t)0x5db2, (q15_t)0xa8cc, (q15_t)0x5dad, (q15_t)0xa8c7, (q15_t)0x5da9, (q15_t)0xa8c2, + (q15_t)0x5da5, (q15_t)0xa8be, (q15_t)0x5da1, (q15_t)0xa8b9, (q15_t)0x5d9c, (q15_t)0xa8b5, (q15_t)0x5d98, (q15_t)0xa8b0, + (q15_t)0x5d94, (q15_t)0xa8ab, (q15_t)0x5d8f, (q15_t)0xa8a7, (q15_t)0x5d8b, (q15_t)0xa8a2, (q15_t)0x5d87, (q15_t)0xa89e, + (q15_t)0x5d83, (q15_t)0xa899, (q15_t)0x5d7e, (q15_t)0xa894, (q15_t)0x5d7a, (q15_t)0xa890, (q15_t)0x5d76, (q15_t)0xa88b, + (q15_t)0x5d71, (q15_t)0xa887, (q15_t)0x5d6d, (q15_t)0xa882, (q15_t)0x5d69, (q15_t)0xa87d, (q15_t)0x5d65, (q15_t)0xa879, + (q15_t)0x5d60, (q15_t)0xa874, (q15_t)0x5d5c, (q15_t)0xa870, (q15_t)0x5d58, (q15_t)0xa86b, (q15_t)0x5d53, (q15_t)0xa867, + (q15_t)0x5d4f, (q15_t)0xa862, (q15_t)0x5d4b, (q15_t)0xa85d, (q15_t)0x5d46, (q15_t)0xa859, (q15_t)0x5d42, (q15_t)0xa854, + (q15_t)0x5d3e, (q15_t)0xa850, (q15_t)0x5d3a, (q15_t)0xa84b, (q15_t)0x5d35, (q15_t)0xa847, (q15_t)0x5d31, (q15_t)0xa842, + (q15_t)0x5d2d, (q15_t)0xa83d, (q15_t)0x5d28, (q15_t)0xa839, (q15_t)0x5d24, (q15_t)0xa834, (q15_t)0x5d20, (q15_t)0xa830, + (q15_t)0x5d1b, (q15_t)0xa82b, (q15_t)0x5d17, (q15_t)0xa827, (q15_t)0x5d13, (q15_t)0xa822, (q15_t)0x5d0e, (q15_t)0xa81d, + (q15_t)0x5d0a, (q15_t)0xa819, (q15_t)0x5d06, (q15_t)0xa814, (q15_t)0x5d01, (q15_t)0xa810, (q15_t)0x5cfd, (q15_t)0xa80b, + (q15_t)0x5cf9, (q15_t)0xa807, (q15_t)0x5cf5, (q15_t)0xa802, (q15_t)0x5cf0, (q15_t)0xa7fd, (q15_t)0x5cec, (q15_t)0xa7f9, + (q15_t)0x5ce8, (q15_t)0xa7f4, (q15_t)0x5ce3, (q15_t)0xa7f0, (q15_t)0x5cdf, (q15_t)0xa7eb, (q15_t)0x5cdb, (q15_t)0xa7e7, + (q15_t)0x5cd6, (q15_t)0xa7e2, (q15_t)0x5cd2, (q15_t)0xa7de, (q15_t)0x5cce, (q15_t)0xa7d9, (q15_t)0x5cc9, (q15_t)0xa7d4, + (q15_t)0x5cc5, (q15_t)0xa7d0, (q15_t)0x5cc1, (q15_t)0xa7cb, (q15_t)0x5cbc, (q15_t)0xa7c7, (q15_t)0x5cb8, (q15_t)0xa7c2, + (q15_t)0x5cb4, (q15_t)0xa7be, (q15_t)0x5caf, (q15_t)0xa7b9, (q15_t)0x5cab, (q15_t)0xa7b5, (q15_t)0x5ca7, (q15_t)0xa7b0, + (q15_t)0x5ca2, (q15_t)0xa7ab, (q15_t)0x5c9e, (q15_t)0xa7a7, (q15_t)0x5c9a, (q15_t)0xa7a2, (q15_t)0x5c95, (q15_t)0xa79e, + (q15_t)0x5c91, (q15_t)0xa799, (q15_t)0x5c8d, (q15_t)0xa795, (q15_t)0x5c88, (q15_t)0xa790, (q15_t)0x5c84, (q15_t)0xa78c, + (q15_t)0x5c80, (q15_t)0xa787, (q15_t)0x5c7b, (q15_t)0xa783, (q15_t)0x5c77, (q15_t)0xa77e, (q15_t)0x5c73, (q15_t)0xa779, + (q15_t)0x5c6e, (q15_t)0xa775, (q15_t)0x5c6a, (q15_t)0xa770, (q15_t)0x5c66, (q15_t)0xa76c, (q15_t)0x5c61, (q15_t)0xa767, + (q15_t)0x5c5d, (q15_t)0xa763, (q15_t)0x5c58, (q15_t)0xa75e, (q15_t)0x5c54, (q15_t)0xa75a, (q15_t)0x5c50, (q15_t)0xa755, + (q15_t)0x5c4b, (q15_t)0xa751, (q15_t)0x5c47, (q15_t)0xa74c, (q15_t)0x5c43, (q15_t)0xa748, (q15_t)0x5c3e, (q15_t)0xa743, + (q15_t)0x5c3a, (q15_t)0xa73f, (q15_t)0x5c36, (q15_t)0xa73a, (q15_t)0x5c31, (q15_t)0xa735, (q15_t)0x5c2d, (q15_t)0xa731, + (q15_t)0x5c29, (q15_t)0xa72c, (q15_t)0x5c24, (q15_t)0xa728, (q15_t)0x5c20, (q15_t)0xa723, (q15_t)0x5c1b, (q15_t)0xa71f, + (q15_t)0x5c17, (q15_t)0xa71a, (q15_t)0x5c13, (q15_t)0xa716, (q15_t)0x5c0e, (q15_t)0xa711, (q15_t)0x5c0a, (q15_t)0xa70d, + (q15_t)0x5c06, (q15_t)0xa708, (q15_t)0x5c01, (q15_t)0xa704, (q15_t)0x5bfd, (q15_t)0xa6ff, (q15_t)0x5bf9, (q15_t)0xa6fb, + (q15_t)0x5bf4, (q15_t)0xa6f6, (q15_t)0x5bf0, (q15_t)0xa6f2, (q15_t)0x5beb, (q15_t)0xa6ed, (q15_t)0x5be7, (q15_t)0xa6e9, + (q15_t)0x5be3, (q15_t)0xa6e4, (q15_t)0x5bde, (q15_t)0xa6e0, (q15_t)0x5bda, (q15_t)0xa6db, (q15_t)0x5bd6, (q15_t)0xa6d7, + (q15_t)0x5bd1, (q15_t)0xa6d2, (q15_t)0x5bcd, (q15_t)0xa6ce, (q15_t)0x5bc8, (q15_t)0xa6c9, (q15_t)0x5bc4, (q15_t)0xa6c5, + (q15_t)0x5bc0, (q15_t)0xa6c0, (q15_t)0x5bbb, (q15_t)0xa6bc, (q15_t)0x5bb7, (q15_t)0xa6b7, (q15_t)0x5bb2, (q15_t)0xa6b3, + (q15_t)0x5bae, (q15_t)0xa6ae, (q15_t)0x5baa, (q15_t)0xa6aa, (q15_t)0x5ba5, (q15_t)0xa6a5, (q15_t)0x5ba1, (q15_t)0xa6a1, + (q15_t)0x5b9d, (q15_t)0xa69c, (q15_t)0x5b98, (q15_t)0xa698, (q15_t)0x5b94, (q15_t)0xa693, (q15_t)0x5b8f, (q15_t)0xa68f, + (q15_t)0x5b8b, (q15_t)0xa68a, (q15_t)0x5b87, (q15_t)0xa686, (q15_t)0x5b82, (q15_t)0xa681, (q15_t)0x5b7e, (q15_t)0xa67d, + (q15_t)0x5b79, (q15_t)0xa678, (q15_t)0x5b75, (q15_t)0xa674, (q15_t)0x5b71, (q15_t)0xa66f, (q15_t)0x5b6c, (q15_t)0xa66b, + (q15_t)0x5b68, (q15_t)0xa666, (q15_t)0x5b63, (q15_t)0xa662, (q15_t)0x5b5f, (q15_t)0xa65d, (q15_t)0x5b5b, (q15_t)0xa659, + (q15_t)0x5b56, (q15_t)0xa654, (q15_t)0x5b52, (q15_t)0xa650, (q15_t)0x5b4d, (q15_t)0xa64b, (q15_t)0x5b49, (q15_t)0xa647, + (q15_t)0x5b45, (q15_t)0xa642, (q15_t)0x5b40, (q15_t)0xa63e, (q15_t)0x5b3c, (q15_t)0xa639, (q15_t)0x5b37, (q15_t)0xa635, + (q15_t)0x5b33, (q15_t)0xa630, (q15_t)0x5b2f, (q15_t)0xa62c, (q15_t)0x5b2a, (q15_t)0xa627, (q15_t)0x5b26, (q15_t)0xa623, + (q15_t)0x5b21, (q15_t)0xa61f, (q15_t)0x5b1d, (q15_t)0xa61a, (q15_t)0x5b19, (q15_t)0xa616, (q15_t)0x5b14, (q15_t)0xa611, + (q15_t)0x5b10, (q15_t)0xa60d, (q15_t)0x5b0b, (q15_t)0xa608, (q15_t)0x5b07, (q15_t)0xa604, (q15_t)0x5b02, (q15_t)0xa5ff, + (q15_t)0x5afe, (q15_t)0xa5fb, (q15_t)0x5afa, (q15_t)0xa5f6, (q15_t)0x5af5, (q15_t)0xa5f2, (q15_t)0x5af1, (q15_t)0xa5ed, + (q15_t)0x5aec, (q15_t)0xa5e9, (q15_t)0x5ae8, (q15_t)0xa5e4, (q15_t)0x5ae4, (q15_t)0xa5e0, (q15_t)0x5adf, (q15_t)0xa5dc, + (q15_t)0x5adb, (q15_t)0xa5d7, (q15_t)0x5ad6, (q15_t)0xa5d3, (q15_t)0x5ad2, (q15_t)0xa5ce, (q15_t)0x5acd, (q15_t)0xa5ca, + (q15_t)0x5ac9, (q15_t)0xa5c5, (q15_t)0x5ac5, (q15_t)0xa5c1, (q15_t)0x5ac0, (q15_t)0xa5bc, (q15_t)0x5abc, (q15_t)0xa5b8, + (q15_t)0x5ab7, (q15_t)0xa5b3, (q15_t)0x5ab3, (q15_t)0xa5af, (q15_t)0x5aae, (q15_t)0xa5aa, (q15_t)0x5aaa, (q15_t)0xa5a6, + (q15_t)0x5aa5, (q15_t)0xa5a2, (q15_t)0x5aa1, (q15_t)0xa59d, (q15_t)0x5a9d, (q15_t)0xa599, (q15_t)0x5a98, (q15_t)0xa594, + (q15_t)0x5a94, (q15_t)0xa590, (q15_t)0x5a8f, (q15_t)0xa58b, (q15_t)0x5a8b, (q15_t)0xa587, (q15_t)0x5a86, (q15_t)0xa582, + (q15_t)0x5a82, (q15_t)0xa57e, (q15_t)0x5a7e, (q15_t)0xa57a, (q15_t)0x5a79, (q15_t)0xa575, (q15_t)0x5a75, (q15_t)0xa571, + (q15_t)0x5a70, (q15_t)0xa56c, (q15_t)0x5a6c, (q15_t)0xa568, (q15_t)0x5a67, (q15_t)0xa563, (q15_t)0x5a63, (q15_t)0xa55f, + (q15_t)0x5a5e, (q15_t)0xa55b, (q15_t)0x5a5a, (q15_t)0xa556, (q15_t)0x5a56, (q15_t)0xa552, (q15_t)0x5a51, (q15_t)0xa54d, + (q15_t)0x5a4d, (q15_t)0xa549, (q15_t)0x5a48, (q15_t)0xa544, (q15_t)0x5a44, (q15_t)0xa540, (q15_t)0x5a3f, (q15_t)0xa53b, + (q15_t)0x5a3b, (q15_t)0xa537, (q15_t)0x5a36, (q15_t)0xa533, (q15_t)0x5a32, (q15_t)0xa52e, (q15_t)0x5a2d, (q15_t)0xa52a, + (q15_t)0x5a29, (q15_t)0xa525, (q15_t)0x5a24, (q15_t)0xa521, (q15_t)0x5a20, (q15_t)0xa51c, (q15_t)0x5a1c, (q15_t)0xa518, + (q15_t)0x5a17, (q15_t)0xa514, (q15_t)0x5a13, (q15_t)0xa50f, (q15_t)0x5a0e, (q15_t)0xa50b, (q15_t)0x5a0a, (q15_t)0xa506, + (q15_t)0x5a05, (q15_t)0xa502, (q15_t)0x5a01, (q15_t)0xa4fe, (q15_t)0x59fc, (q15_t)0xa4f9, (q15_t)0x59f8, (q15_t)0xa4f5, + (q15_t)0x59f3, (q15_t)0xa4f0, (q15_t)0x59ef, (q15_t)0xa4ec, (q15_t)0x59ea, (q15_t)0xa4e7, (q15_t)0x59e6, (q15_t)0xa4e3, + (q15_t)0x59e1, (q15_t)0xa4df, (q15_t)0x59dd, (q15_t)0xa4da, (q15_t)0x59d9, (q15_t)0xa4d6, (q15_t)0x59d4, (q15_t)0xa4d1, + (q15_t)0x59d0, (q15_t)0xa4cd, (q15_t)0x59cb, (q15_t)0xa4c9, (q15_t)0x59c7, (q15_t)0xa4c4, (q15_t)0x59c2, (q15_t)0xa4c0, + (q15_t)0x59be, (q15_t)0xa4bb, (q15_t)0x59b9, (q15_t)0xa4b7, (q15_t)0x59b5, (q15_t)0xa4b3, (q15_t)0x59b0, (q15_t)0xa4ae, + (q15_t)0x59ac, (q15_t)0xa4aa, (q15_t)0x59a7, (q15_t)0xa4a5, (q15_t)0x59a3, (q15_t)0xa4a1, (q15_t)0x599e, (q15_t)0xa49d, + (q15_t)0x599a, (q15_t)0xa498, (q15_t)0x5995, (q15_t)0xa494, (q15_t)0x5991, (q15_t)0xa48f, (q15_t)0x598c, (q15_t)0xa48b, + (q15_t)0x5988, (q15_t)0xa487, (q15_t)0x5983, (q15_t)0xa482, (q15_t)0x597f, (q15_t)0xa47e, (q15_t)0x597a, (q15_t)0xa479, + (q15_t)0x5976, (q15_t)0xa475, (q15_t)0x5971, (q15_t)0xa471, (q15_t)0x596d, (q15_t)0xa46c, (q15_t)0x5968, (q15_t)0xa468, + (q15_t)0x5964, (q15_t)0xa463, (q15_t)0x595f, (q15_t)0xa45f, (q15_t)0x595b, (q15_t)0xa45b, (q15_t)0x5956, (q15_t)0xa456, + (q15_t)0x5952, (q15_t)0xa452, (q15_t)0x594d, (q15_t)0xa44e, (q15_t)0x5949, (q15_t)0xa449, (q15_t)0x5944, (q15_t)0xa445, + (q15_t)0x5940, (q15_t)0xa440, (q15_t)0x593b, (q15_t)0xa43c, (q15_t)0x5937, (q15_t)0xa438, (q15_t)0x5932, (q15_t)0xa433, + (q15_t)0x592e, (q15_t)0xa42f, (q15_t)0x5929, (q15_t)0xa42a, (q15_t)0x5925, (q15_t)0xa426, (q15_t)0x5920, (q15_t)0xa422, + (q15_t)0x591c, (q15_t)0xa41d, (q15_t)0x5917, (q15_t)0xa419, (q15_t)0x5913, (q15_t)0xa415, (q15_t)0x590e, (q15_t)0xa410, + (q15_t)0x590a, (q15_t)0xa40c, (q15_t)0x5905, (q15_t)0xa407, (q15_t)0x5901, (q15_t)0xa403, (q15_t)0x58fc, (q15_t)0xa3ff, + (q15_t)0x58f8, (q15_t)0xa3fa, (q15_t)0x58f3, (q15_t)0xa3f6, (q15_t)0x58ef, (q15_t)0xa3f2, (q15_t)0x58ea, (q15_t)0xa3ed, + (q15_t)0x58e6, (q15_t)0xa3e9, (q15_t)0x58e1, (q15_t)0xa3e5, (q15_t)0x58dd, (q15_t)0xa3e0, (q15_t)0x58d8, (q15_t)0xa3dc, + (q15_t)0x58d4, (q15_t)0xa3d7, (q15_t)0x58cf, (q15_t)0xa3d3, (q15_t)0x58cb, (q15_t)0xa3cf, (q15_t)0x58c6, (q15_t)0xa3ca, + (q15_t)0x58c1, (q15_t)0xa3c6, (q15_t)0x58bd, (q15_t)0xa3c2, (q15_t)0x58b8, (q15_t)0xa3bd, (q15_t)0x58b4, (q15_t)0xa3b9, + (q15_t)0x58af, (q15_t)0xa3b5, (q15_t)0x58ab, (q15_t)0xa3b0, (q15_t)0x58a6, (q15_t)0xa3ac, (q15_t)0x58a2, (q15_t)0xa3a8, + (q15_t)0x589d, (q15_t)0xa3a3, (q15_t)0x5899, (q15_t)0xa39f, (q15_t)0x5894, (q15_t)0xa39a, (q15_t)0x5890, (q15_t)0xa396, + (q15_t)0x588b, (q15_t)0xa392, (q15_t)0x5887, (q15_t)0xa38d, (q15_t)0x5882, (q15_t)0xa389, (q15_t)0x587d, (q15_t)0xa385, + (q15_t)0x5879, (q15_t)0xa380, (q15_t)0x5874, (q15_t)0xa37c, (q15_t)0x5870, (q15_t)0xa378, (q15_t)0x586b, (q15_t)0xa373, + (q15_t)0x5867, (q15_t)0xa36f, (q15_t)0x5862, (q15_t)0xa36b, (q15_t)0x585e, (q15_t)0xa366, (q15_t)0x5859, (q15_t)0xa362, + (q15_t)0x5855, (q15_t)0xa35e, (q15_t)0x5850, (q15_t)0xa359, (q15_t)0x584b, (q15_t)0xa355, (q15_t)0x5847, (q15_t)0xa351, + (q15_t)0x5842, (q15_t)0xa34c, (q15_t)0x583e, (q15_t)0xa348, (q15_t)0x5839, (q15_t)0xa344, (q15_t)0x5835, (q15_t)0xa33f, + (q15_t)0x5830, (q15_t)0xa33b, (q15_t)0x582c, (q15_t)0xa337, (q15_t)0x5827, (q15_t)0xa332, (q15_t)0x5822, (q15_t)0xa32e, + (q15_t)0x581e, (q15_t)0xa32a, (q15_t)0x5819, (q15_t)0xa325, (q15_t)0x5815, (q15_t)0xa321, (q15_t)0x5810, (q15_t)0xa31d, + (q15_t)0x580c, (q15_t)0xa318, (q15_t)0x5807, (q15_t)0xa314, (q15_t)0x5803, (q15_t)0xa310, (q15_t)0x57fe, (q15_t)0xa30b, + (q15_t)0x57f9, (q15_t)0xa307, (q15_t)0x57f5, (q15_t)0xa303, (q15_t)0x57f0, (q15_t)0xa2ff, (q15_t)0x57ec, (q15_t)0xa2fa, + (q15_t)0x57e7, (q15_t)0xa2f6, (q15_t)0x57e3, (q15_t)0xa2f2, (q15_t)0x57de, (q15_t)0xa2ed, (q15_t)0x57d9, (q15_t)0xa2e9, + (q15_t)0x57d5, (q15_t)0xa2e5, (q15_t)0x57d0, (q15_t)0xa2e0, (q15_t)0x57cc, (q15_t)0xa2dc, (q15_t)0x57c7, (q15_t)0xa2d8, + (q15_t)0x57c3, (q15_t)0xa2d3, (q15_t)0x57be, (q15_t)0xa2cf, (q15_t)0x57b9, (q15_t)0xa2cb, (q15_t)0x57b5, (q15_t)0xa2c6, + (q15_t)0x57b0, (q15_t)0xa2c2, (q15_t)0x57ac, (q15_t)0xa2be, (q15_t)0x57a7, (q15_t)0xa2ba, (q15_t)0x57a3, (q15_t)0xa2b5, + (q15_t)0x579e, (q15_t)0xa2b1, (q15_t)0x5799, (q15_t)0xa2ad, (q15_t)0x5795, (q15_t)0xa2a8, (q15_t)0x5790, (q15_t)0xa2a4, + (q15_t)0x578c, (q15_t)0xa2a0, (q15_t)0x5787, (q15_t)0xa29b, (q15_t)0x5783, (q15_t)0xa297, (q15_t)0x577e, (q15_t)0xa293, + (q15_t)0x5779, (q15_t)0xa28f, (q15_t)0x5775, (q15_t)0xa28a, (q15_t)0x5770, (q15_t)0xa286, (q15_t)0x576c, (q15_t)0xa282, + (q15_t)0x5767, (q15_t)0xa27d, (q15_t)0x5762, (q15_t)0xa279, (q15_t)0x575e, (q15_t)0xa275, (q15_t)0x5759, (q15_t)0xa271, + (q15_t)0x5755, (q15_t)0xa26c, (q15_t)0x5750, (q15_t)0xa268, (q15_t)0x574b, (q15_t)0xa264, (q15_t)0x5747, (q15_t)0xa25f, + (q15_t)0x5742, (q15_t)0xa25b, (q15_t)0x573e, (q15_t)0xa257, (q15_t)0x5739, (q15_t)0xa253, (q15_t)0x5734, (q15_t)0xa24e, + (q15_t)0x5730, (q15_t)0xa24a, (q15_t)0x572b, (q15_t)0xa246, (q15_t)0x5727, (q15_t)0xa241, (q15_t)0x5722, (q15_t)0xa23d, + (q15_t)0x571d, (q15_t)0xa239, (q15_t)0x5719, (q15_t)0xa235, (q15_t)0x5714, (q15_t)0xa230, (q15_t)0x5710, (q15_t)0xa22c, + (q15_t)0x570b, (q15_t)0xa228, (q15_t)0x5706, (q15_t)0xa224, (q15_t)0x5702, (q15_t)0xa21f, (q15_t)0x56fd, (q15_t)0xa21b, + (q15_t)0x56f9, (q15_t)0xa217, (q15_t)0x56f4, (q15_t)0xa212, (q15_t)0x56ef, (q15_t)0xa20e, (q15_t)0x56eb, (q15_t)0xa20a, + (q15_t)0x56e6, (q15_t)0xa206, (q15_t)0x56e2, (q15_t)0xa201, (q15_t)0x56dd, (q15_t)0xa1fd, (q15_t)0x56d8, (q15_t)0xa1f9, + (q15_t)0x56d4, (q15_t)0xa1f5, (q15_t)0x56cf, (q15_t)0xa1f0, (q15_t)0x56ca, (q15_t)0xa1ec, (q15_t)0x56c6, (q15_t)0xa1e8, + (q15_t)0x56c1, (q15_t)0xa1e4, (q15_t)0x56bd, (q15_t)0xa1df, (q15_t)0x56b8, (q15_t)0xa1db, (q15_t)0x56b3, (q15_t)0xa1d7, + (q15_t)0x56af, (q15_t)0xa1d3, (q15_t)0x56aa, (q15_t)0xa1ce, (q15_t)0x56a5, (q15_t)0xa1ca, (q15_t)0x56a1, (q15_t)0xa1c6, + (q15_t)0x569c, (q15_t)0xa1c1, (q15_t)0x5698, (q15_t)0xa1bd, (q15_t)0x5693, (q15_t)0xa1b9, (q15_t)0x568e, (q15_t)0xa1b5, + (q15_t)0x568a, (q15_t)0xa1b0, (q15_t)0x5685, (q15_t)0xa1ac, (q15_t)0x5680, (q15_t)0xa1a8, (q15_t)0x567c, (q15_t)0xa1a4, + (q15_t)0x5677, (q15_t)0xa1a0, (q15_t)0x5673, (q15_t)0xa19b, (q15_t)0x566e, (q15_t)0xa197, (q15_t)0x5669, (q15_t)0xa193, + (q15_t)0x5665, (q15_t)0xa18f, (q15_t)0x5660, (q15_t)0xa18a, (q15_t)0x565b, (q15_t)0xa186, (q15_t)0x5657, (q15_t)0xa182, + (q15_t)0x5652, (q15_t)0xa17e, (q15_t)0x564d, (q15_t)0xa179, (q15_t)0x5649, (q15_t)0xa175, (q15_t)0x5644, (q15_t)0xa171, + (q15_t)0x5640, (q15_t)0xa16d, (q15_t)0x563b, (q15_t)0xa168, (q15_t)0x5636, (q15_t)0xa164, (q15_t)0x5632, (q15_t)0xa160, + (q15_t)0x562d, (q15_t)0xa15c, (q15_t)0x5628, (q15_t)0xa157, (q15_t)0x5624, (q15_t)0xa153, (q15_t)0x561f, (q15_t)0xa14f, + (q15_t)0x561a, (q15_t)0xa14b, (q15_t)0x5616, (q15_t)0xa147, (q15_t)0x5611, (q15_t)0xa142, (q15_t)0x560c, (q15_t)0xa13e, + (q15_t)0x5608, (q15_t)0xa13a, (q15_t)0x5603, (q15_t)0xa136, (q15_t)0x55fe, (q15_t)0xa131, (q15_t)0x55fa, (q15_t)0xa12d, + (q15_t)0x55f5, (q15_t)0xa129, (q15_t)0x55f0, (q15_t)0xa125, (q15_t)0x55ec, (q15_t)0xa121, (q15_t)0x55e7, (q15_t)0xa11c, + (q15_t)0x55e3, (q15_t)0xa118, (q15_t)0x55de, (q15_t)0xa114, (q15_t)0x55d9, (q15_t)0xa110, (q15_t)0x55d5, (q15_t)0xa10b, + (q15_t)0x55d0, (q15_t)0xa107, (q15_t)0x55cb, (q15_t)0xa103, (q15_t)0x55c7, (q15_t)0xa0ff, (q15_t)0x55c2, (q15_t)0xa0fb, + (q15_t)0x55bd, (q15_t)0xa0f6, (q15_t)0x55b9, (q15_t)0xa0f2, (q15_t)0x55b4, (q15_t)0xa0ee, (q15_t)0x55af, (q15_t)0xa0ea, + (q15_t)0x55ab, (q15_t)0xa0e6, (q15_t)0x55a6, (q15_t)0xa0e1, (q15_t)0x55a1, (q15_t)0xa0dd, (q15_t)0x559d, (q15_t)0xa0d9, + (q15_t)0x5598, (q15_t)0xa0d5, (q15_t)0x5593, (q15_t)0xa0d1, (q15_t)0x558f, (q15_t)0xa0cc, (q15_t)0x558a, (q15_t)0xa0c8, + (q15_t)0x5585, (q15_t)0xa0c4, (q15_t)0x5581, (q15_t)0xa0c0, (q15_t)0x557c, (q15_t)0xa0bc, (q15_t)0x5577, (q15_t)0xa0b7, + (q15_t)0x5572, (q15_t)0xa0b3, (q15_t)0x556e, (q15_t)0xa0af, (q15_t)0x5569, (q15_t)0xa0ab, (q15_t)0x5564, (q15_t)0xa0a7, + (q15_t)0x5560, (q15_t)0xa0a2, (q15_t)0x555b, (q15_t)0xa09e, (q15_t)0x5556, (q15_t)0xa09a, (q15_t)0x5552, (q15_t)0xa096, + (q15_t)0x554d, (q15_t)0xa092, (q15_t)0x5548, (q15_t)0xa08e, (q15_t)0x5544, (q15_t)0xa089, (q15_t)0x553f, (q15_t)0xa085, + (q15_t)0x553a, (q15_t)0xa081, (q15_t)0x5536, (q15_t)0xa07d, (q15_t)0x5531, (q15_t)0xa079, (q15_t)0x552c, (q15_t)0xa074, + (q15_t)0x5528, (q15_t)0xa070, (q15_t)0x5523, (q15_t)0xa06c, (q15_t)0x551e, (q15_t)0xa068, (q15_t)0x5519, (q15_t)0xa064, + (q15_t)0x5515, (q15_t)0xa060, (q15_t)0x5510, (q15_t)0xa05b, (q15_t)0x550b, (q15_t)0xa057, (q15_t)0x5507, (q15_t)0xa053, + (q15_t)0x5502, (q15_t)0xa04f, (q15_t)0x54fd, (q15_t)0xa04b, (q15_t)0x54f9, (q15_t)0xa046, (q15_t)0x54f4, (q15_t)0xa042, + (q15_t)0x54ef, (q15_t)0xa03e, (q15_t)0x54ea, (q15_t)0xa03a, (q15_t)0x54e6, (q15_t)0xa036, (q15_t)0x54e1, (q15_t)0xa032, + (q15_t)0x54dc, (q15_t)0xa02d, (q15_t)0x54d8, (q15_t)0xa029, (q15_t)0x54d3, (q15_t)0xa025, (q15_t)0x54ce, (q15_t)0xa021, + (q15_t)0x54ca, (q15_t)0xa01d, (q15_t)0x54c5, (q15_t)0xa019, (q15_t)0x54c0, (q15_t)0xa014, (q15_t)0x54bb, (q15_t)0xa010, + (q15_t)0x54b7, (q15_t)0xa00c, (q15_t)0x54b2, (q15_t)0xa008, (q15_t)0x54ad, (q15_t)0xa004, (q15_t)0x54a9, (q15_t)0xa000, + (q15_t)0x54a4, (q15_t)0x9ffc, (q15_t)0x549f, (q15_t)0x9ff7, (q15_t)0x549a, (q15_t)0x9ff3, (q15_t)0x5496, (q15_t)0x9fef, + (q15_t)0x5491, (q15_t)0x9feb, (q15_t)0x548c, (q15_t)0x9fe7, (q15_t)0x5488, (q15_t)0x9fe3, (q15_t)0x5483, (q15_t)0x9fde, + (q15_t)0x547e, (q15_t)0x9fda, (q15_t)0x5479, (q15_t)0x9fd6, (q15_t)0x5475, (q15_t)0x9fd2, (q15_t)0x5470, (q15_t)0x9fce, + (q15_t)0x546b, (q15_t)0x9fca, (q15_t)0x5467, (q15_t)0x9fc6, (q15_t)0x5462, (q15_t)0x9fc1, (q15_t)0x545d, (q15_t)0x9fbd, + (q15_t)0x5458, (q15_t)0x9fb9, (q15_t)0x5454, (q15_t)0x9fb5, (q15_t)0x544f, (q15_t)0x9fb1, (q15_t)0x544a, (q15_t)0x9fad, + (q15_t)0x5445, (q15_t)0x9fa9, (q15_t)0x5441, (q15_t)0x9fa4, (q15_t)0x543c, (q15_t)0x9fa0, (q15_t)0x5437, (q15_t)0x9f9c, + (q15_t)0x5433, (q15_t)0x9f98, (q15_t)0x542e, (q15_t)0x9f94, (q15_t)0x5429, (q15_t)0x9f90, (q15_t)0x5424, (q15_t)0x9f8c, + (q15_t)0x5420, (q15_t)0x9f88, (q15_t)0x541b, (q15_t)0x9f83, (q15_t)0x5416, (q15_t)0x9f7f, (q15_t)0x5411, (q15_t)0x9f7b, + (q15_t)0x540d, (q15_t)0x9f77, (q15_t)0x5408, (q15_t)0x9f73, (q15_t)0x5403, (q15_t)0x9f6f, (q15_t)0x53fe, (q15_t)0x9f6b, + (q15_t)0x53fa, (q15_t)0x9f67, (q15_t)0x53f5, (q15_t)0x9f62, (q15_t)0x53f0, (q15_t)0x9f5e, (q15_t)0x53eb, (q15_t)0x9f5a, + (q15_t)0x53e7, (q15_t)0x9f56, (q15_t)0x53e2, (q15_t)0x9f52, (q15_t)0x53dd, (q15_t)0x9f4e, (q15_t)0x53d8, (q15_t)0x9f4a, + (q15_t)0x53d4, (q15_t)0x9f46, (q15_t)0x53cf, (q15_t)0x9f41, (q15_t)0x53ca, (q15_t)0x9f3d, (q15_t)0x53c5, (q15_t)0x9f39, + (q15_t)0x53c1, (q15_t)0x9f35, (q15_t)0x53bc, (q15_t)0x9f31, (q15_t)0x53b7, (q15_t)0x9f2d, (q15_t)0x53b2, (q15_t)0x9f29, + (q15_t)0x53ae, (q15_t)0x9f25, (q15_t)0x53a9, (q15_t)0x9f21, (q15_t)0x53a4, (q15_t)0x9f1c, (q15_t)0x539f, (q15_t)0x9f18, + (q15_t)0x539b, (q15_t)0x9f14, (q15_t)0x5396, (q15_t)0x9f10, (q15_t)0x5391, (q15_t)0x9f0c, (q15_t)0x538c, (q15_t)0x9f08, + (q15_t)0x5388, (q15_t)0x9f04, (q15_t)0x5383, (q15_t)0x9f00, (q15_t)0x537e, (q15_t)0x9efc, (q15_t)0x5379, (q15_t)0x9ef8, + (q15_t)0x5375, (q15_t)0x9ef3, (q15_t)0x5370, (q15_t)0x9eef, (q15_t)0x536b, (q15_t)0x9eeb, (q15_t)0x5366, (q15_t)0x9ee7, + (q15_t)0x5362, (q15_t)0x9ee3, (q15_t)0x535d, (q15_t)0x9edf, (q15_t)0x5358, (q15_t)0x9edb, (q15_t)0x5353, (q15_t)0x9ed7, + (q15_t)0x534e, (q15_t)0x9ed3, (q15_t)0x534a, (q15_t)0x9ecf, (q15_t)0x5345, (q15_t)0x9ecb, (q15_t)0x5340, (q15_t)0x9ec6, + (q15_t)0x533b, (q15_t)0x9ec2, (q15_t)0x5337, (q15_t)0x9ebe, (q15_t)0x5332, (q15_t)0x9eba, (q15_t)0x532d, (q15_t)0x9eb6, + (q15_t)0x5328, (q15_t)0x9eb2, (q15_t)0x5323, (q15_t)0x9eae, (q15_t)0x531f, (q15_t)0x9eaa, (q15_t)0x531a, (q15_t)0x9ea6, + (q15_t)0x5315, (q15_t)0x9ea2, (q15_t)0x5310, (q15_t)0x9e9e, (q15_t)0x530c, (q15_t)0x9e9a, (q15_t)0x5307, (q15_t)0x9e95, + (q15_t)0x5302, (q15_t)0x9e91, (q15_t)0x52fd, (q15_t)0x9e8d, (q15_t)0x52f8, (q15_t)0x9e89, (q15_t)0x52f4, (q15_t)0x9e85, + (q15_t)0x52ef, (q15_t)0x9e81, (q15_t)0x52ea, (q15_t)0x9e7d, (q15_t)0x52e5, (q15_t)0x9e79, (q15_t)0x52e1, (q15_t)0x9e75, + (q15_t)0x52dc, (q15_t)0x9e71, (q15_t)0x52d7, (q15_t)0x9e6d, (q15_t)0x52d2, (q15_t)0x9e69, (q15_t)0x52cd, (q15_t)0x9e65, + (q15_t)0x52c9, (q15_t)0x9e61, (q15_t)0x52c4, (q15_t)0x9e5d, (q15_t)0x52bf, (q15_t)0x9e58, (q15_t)0x52ba, (q15_t)0x9e54, + (q15_t)0x52b5, (q15_t)0x9e50, (q15_t)0x52b1, (q15_t)0x9e4c, (q15_t)0x52ac, (q15_t)0x9e48, (q15_t)0x52a7, (q15_t)0x9e44, + (q15_t)0x52a2, (q15_t)0x9e40, (q15_t)0x529d, (q15_t)0x9e3c, (q15_t)0x5299, (q15_t)0x9e38, (q15_t)0x5294, (q15_t)0x9e34, + (q15_t)0x528f, (q15_t)0x9e30, (q15_t)0x528a, (q15_t)0x9e2c, (q15_t)0x5285, (q15_t)0x9e28, (q15_t)0x5281, (q15_t)0x9e24, + (q15_t)0x527c, (q15_t)0x9e20, (q15_t)0x5277, (q15_t)0x9e1c, (q15_t)0x5272, (q15_t)0x9e18, (q15_t)0x526d, (q15_t)0x9e14, + (q15_t)0x5269, (q15_t)0x9e0f, (q15_t)0x5264, (q15_t)0x9e0b, (q15_t)0x525f, (q15_t)0x9e07, (q15_t)0x525a, (q15_t)0x9e03, + (q15_t)0x5255, (q15_t)0x9dff, (q15_t)0x5251, (q15_t)0x9dfb, (q15_t)0x524c, (q15_t)0x9df7, (q15_t)0x5247, (q15_t)0x9df3, + (q15_t)0x5242, (q15_t)0x9def, (q15_t)0x523d, (q15_t)0x9deb, (q15_t)0x5238, (q15_t)0x9de7, (q15_t)0x5234, (q15_t)0x9de3, + (q15_t)0x522f, (q15_t)0x9ddf, (q15_t)0x522a, (q15_t)0x9ddb, (q15_t)0x5225, (q15_t)0x9dd7, (q15_t)0x5220, (q15_t)0x9dd3, + (q15_t)0x521c, (q15_t)0x9dcf, (q15_t)0x5217, (q15_t)0x9dcb, (q15_t)0x5212, (q15_t)0x9dc7, (q15_t)0x520d, (q15_t)0x9dc3, + (q15_t)0x5208, (q15_t)0x9dbf, (q15_t)0x5203, (q15_t)0x9dbb, (q15_t)0x51ff, (q15_t)0x9db7, (q15_t)0x51fa, (q15_t)0x9db3, + (q15_t)0x51f5, (q15_t)0x9daf, (q15_t)0x51f0, (q15_t)0x9dab, (q15_t)0x51eb, (q15_t)0x9da7, (q15_t)0x51e6, (q15_t)0x9da3, + (q15_t)0x51e2, (q15_t)0x9d9f, (q15_t)0x51dd, (q15_t)0x9d9b, (q15_t)0x51d8, (q15_t)0x9d97, (q15_t)0x51d3, (q15_t)0x9d93, + (q15_t)0x51ce, (q15_t)0x9d8f, (q15_t)0x51c9, (q15_t)0x9d8b, (q15_t)0x51c5, (q15_t)0x9d86, (q15_t)0x51c0, (q15_t)0x9d82, + (q15_t)0x51bb, (q15_t)0x9d7e, (q15_t)0x51b6, (q15_t)0x9d7a, (q15_t)0x51b1, (q15_t)0x9d76, (q15_t)0x51ac, (q15_t)0x9d72, + (q15_t)0x51a8, (q15_t)0x9d6e, (q15_t)0x51a3, (q15_t)0x9d6a, (q15_t)0x519e, (q15_t)0x9d66, (q15_t)0x5199, (q15_t)0x9d62, + (q15_t)0x5194, (q15_t)0x9d5e, (q15_t)0x518f, (q15_t)0x9d5a, (q15_t)0x518b, (q15_t)0x9d56, (q15_t)0x5186, (q15_t)0x9d52, + (q15_t)0x5181, (q15_t)0x9d4e, (q15_t)0x517c, (q15_t)0x9d4a, (q15_t)0x5177, (q15_t)0x9d46, (q15_t)0x5172, (q15_t)0x9d42, + (q15_t)0x516e, (q15_t)0x9d3e, (q15_t)0x5169, (q15_t)0x9d3a, (q15_t)0x5164, (q15_t)0x9d36, (q15_t)0x515f, (q15_t)0x9d32, + (q15_t)0x515a, (q15_t)0x9d2e, (q15_t)0x5155, (q15_t)0x9d2a, (q15_t)0x5150, (q15_t)0x9d26, (q15_t)0x514c, (q15_t)0x9d22, + (q15_t)0x5147, (q15_t)0x9d1e, (q15_t)0x5142, (q15_t)0x9d1a, (q15_t)0x513d, (q15_t)0x9d16, (q15_t)0x5138, (q15_t)0x9d12, + (q15_t)0x5133, (q15_t)0x9d0e, (q15_t)0x512e, (q15_t)0x9d0b, (q15_t)0x512a, (q15_t)0x9d07, (q15_t)0x5125, (q15_t)0x9d03, + (q15_t)0x5120, (q15_t)0x9cff, (q15_t)0x511b, (q15_t)0x9cfb, (q15_t)0x5116, (q15_t)0x9cf7, (q15_t)0x5111, (q15_t)0x9cf3, + (q15_t)0x510c, (q15_t)0x9cef, (q15_t)0x5108, (q15_t)0x9ceb, (q15_t)0x5103, (q15_t)0x9ce7, (q15_t)0x50fe, (q15_t)0x9ce3, + (q15_t)0x50f9, (q15_t)0x9cdf, (q15_t)0x50f4, (q15_t)0x9cdb, (q15_t)0x50ef, (q15_t)0x9cd7, (q15_t)0x50ea, (q15_t)0x9cd3, + (q15_t)0x50e5, (q15_t)0x9ccf, (q15_t)0x50e1, (q15_t)0x9ccb, (q15_t)0x50dc, (q15_t)0x9cc7, (q15_t)0x50d7, (q15_t)0x9cc3, + (q15_t)0x50d2, (q15_t)0x9cbf, (q15_t)0x50cd, (q15_t)0x9cbb, (q15_t)0x50c8, (q15_t)0x9cb7, (q15_t)0x50c3, (q15_t)0x9cb3, + (q15_t)0x50bf, (q15_t)0x9caf, (q15_t)0x50ba, (q15_t)0x9cab, (q15_t)0x50b5, (q15_t)0x9ca7, (q15_t)0x50b0, (q15_t)0x9ca3, + (q15_t)0x50ab, (q15_t)0x9c9f, (q15_t)0x50a6, (q15_t)0x9c9b, (q15_t)0x50a1, (q15_t)0x9c97, (q15_t)0x509c, (q15_t)0x9c93, + (q15_t)0x5097, (q15_t)0x9c8f, (q15_t)0x5093, (q15_t)0x9c8b, (q15_t)0x508e, (q15_t)0x9c88, (q15_t)0x5089, (q15_t)0x9c84, + (q15_t)0x5084, (q15_t)0x9c80, (q15_t)0x507f, (q15_t)0x9c7c, (q15_t)0x507a, (q15_t)0x9c78, (q15_t)0x5075, (q15_t)0x9c74, + (q15_t)0x5070, (q15_t)0x9c70, (q15_t)0x506c, (q15_t)0x9c6c, (q15_t)0x5067, (q15_t)0x9c68, (q15_t)0x5062, (q15_t)0x9c64, + (q15_t)0x505d, (q15_t)0x9c60, (q15_t)0x5058, (q15_t)0x9c5c, (q15_t)0x5053, (q15_t)0x9c58, (q15_t)0x504e, (q15_t)0x9c54, + (q15_t)0x5049, (q15_t)0x9c50, (q15_t)0x5044, (q15_t)0x9c4c, (q15_t)0x503f, (q15_t)0x9c48, (q15_t)0x503b, (q15_t)0x9c44, + (q15_t)0x5036, (q15_t)0x9c40, (q15_t)0x5031, (q15_t)0x9c3d, (q15_t)0x502c, (q15_t)0x9c39, (q15_t)0x5027, (q15_t)0x9c35, + (q15_t)0x5022, (q15_t)0x9c31, (q15_t)0x501d, (q15_t)0x9c2d, (q15_t)0x5018, (q15_t)0x9c29, (q15_t)0x5013, (q15_t)0x9c25, + (q15_t)0x500f, (q15_t)0x9c21, (q15_t)0x500a, (q15_t)0x9c1d, (q15_t)0x5005, (q15_t)0x9c19, (q15_t)0x5000, (q15_t)0x9c15, + (q15_t)0x4ffb, (q15_t)0x9c11, (q15_t)0x4ff6, (q15_t)0x9c0d, (q15_t)0x4ff1, (q15_t)0x9c09, (q15_t)0x4fec, (q15_t)0x9c06, + (q15_t)0x4fe7, (q15_t)0x9c02, (q15_t)0x4fe2, (q15_t)0x9bfe, (q15_t)0x4fdd, (q15_t)0x9bfa, (q15_t)0x4fd9, (q15_t)0x9bf6, + (q15_t)0x4fd4, (q15_t)0x9bf2, (q15_t)0x4fcf, (q15_t)0x9bee, (q15_t)0x4fca, (q15_t)0x9bea, (q15_t)0x4fc5, (q15_t)0x9be6, + (q15_t)0x4fc0, (q15_t)0x9be2, (q15_t)0x4fbb, (q15_t)0x9bde, (q15_t)0x4fb6, (q15_t)0x9bda, (q15_t)0x4fb1, (q15_t)0x9bd7, + (q15_t)0x4fac, (q15_t)0x9bd3, (q15_t)0x4fa7, (q15_t)0x9bcf, (q15_t)0x4fa2, (q15_t)0x9bcb, (q15_t)0x4f9e, (q15_t)0x9bc7, + (q15_t)0x4f99, (q15_t)0x9bc3, (q15_t)0x4f94, (q15_t)0x9bbf, (q15_t)0x4f8f, (q15_t)0x9bbb, (q15_t)0x4f8a, (q15_t)0x9bb7, + (q15_t)0x4f85, (q15_t)0x9bb3, (q15_t)0x4f80, (q15_t)0x9baf, (q15_t)0x4f7b, (q15_t)0x9bac, (q15_t)0x4f76, (q15_t)0x9ba8, + (q15_t)0x4f71, (q15_t)0x9ba4, (q15_t)0x4f6c, (q15_t)0x9ba0, (q15_t)0x4f67, (q15_t)0x9b9c, (q15_t)0x4f62, (q15_t)0x9b98, + (q15_t)0x4f5e, (q15_t)0x9b94, (q15_t)0x4f59, (q15_t)0x9b90, (q15_t)0x4f54, (q15_t)0x9b8c, (q15_t)0x4f4f, (q15_t)0x9b88, + (q15_t)0x4f4a, (q15_t)0x9b85, (q15_t)0x4f45, (q15_t)0x9b81, (q15_t)0x4f40, (q15_t)0x9b7d, (q15_t)0x4f3b, (q15_t)0x9b79, + (q15_t)0x4f36, (q15_t)0x9b75, (q15_t)0x4f31, (q15_t)0x9b71, (q15_t)0x4f2c, (q15_t)0x9b6d, (q15_t)0x4f27, (q15_t)0x9b69, + (q15_t)0x4f22, (q15_t)0x9b65, (q15_t)0x4f1d, (q15_t)0x9b62, (q15_t)0x4f18, (q15_t)0x9b5e, (q15_t)0x4f14, (q15_t)0x9b5a, + (q15_t)0x4f0f, (q15_t)0x9b56, (q15_t)0x4f0a, (q15_t)0x9b52, (q15_t)0x4f05, (q15_t)0x9b4e, (q15_t)0x4f00, (q15_t)0x9b4a, + (q15_t)0x4efb, (q15_t)0x9b46, (q15_t)0x4ef6, (q15_t)0x9b43, (q15_t)0x4ef1, (q15_t)0x9b3f, (q15_t)0x4eec, (q15_t)0x9b3b, + (q15_t)0x4ee7, (q15_t)0x9b37, (q15_t)0x4ee2, (q15_t)0x9b33, (q15_t)0x4edd, (q15_t)0x9b2f, (q15_t)0x4ed8, (q15_t)0x9b2b, + (q15_t)0x4ed3, (q15_t)0x9b27, (q15_t)0x4ece, (q15_t)0x9b24, (q15_t)0x4ec9, (q15_t)0x9b20, (q15_t)0x4ec4, (q15_t)0x9b1c, + (q15_t)0x4ebf, (q15_t)0x9b18, (q15_t)0x4eba, (q15_t)0x9b14, (q15_t)0x4eb6, (q15_t)0x9b10, (q15_t)0x4eb1, (q15_t)0x9b0c, + (q15_t)0x4eac, (q15_t)0x9b09, (q15_t)0x4ea7, (q15_t)0x9b05, (q15_t)0x4ea2, (q15_t)0x9b01, (q15_t)0x4e9d, (q15_t)0x9afd, + (q15_t)0x4e98, (q15_t)0x9af9, (q15_t)0x4e93, (q15_t)0x9af5, (q15_t)0x4e8e, (q15_t)0x9af1, (q15_t)0x4e89, (q15_t)0x9aed, + (q15_t)0x4e84, (q15_t)0x9aea, (q15_t)0x4e7f, (q15_t)0x9ae6, (q15_t)0x4e7a, (q15_t)0x9ae2, (q15_t)0x4e75, (q15_t)0x9ade, + (q15_t)0x4e70, (q15_t)0x9ada, (q15_t)0x4e6b, (q15_t)0x9ad6, (q15_t)0x4e66, (q15_t)0x9ad3, (q15_t)0x4e61, (q15_t)0x9acf, + (q15_t)0x4e5c, (q15_t)0x9acb, (q15_t)0x4e57, (q15_t)0x9ac7, (q15_t)0x4e52, (q15_t)0x9ac3, (q15_t)0x4e4d, (q15_t)0x9abf, + (q15_t)0x4e48, (q15_t)0x9abb, (q15_t)0x4e43, (q15_t)0x9ab8, (q15_t)0x4e3e, (q15_t)0x9ab4, (q15_t)0x4e39, (q15_t)0x9ab0, + (q15_t)0x4e34, (q15_t)0x9aac, (q15_t)0x4e2f, (q15_t)0x9aa8, (q15_t)0x4e2a, (q15_t)0x9aa4, (q15_t)0x4e26, (q15_t)0x9aa1, + (q15_t)0x4e21, (q15_t)0x9a9d, (q15_t)0x4e1c, (q15_t)0x9a99, (q15_t)0x4e17, (q15_t)0x9a95, (q15_t)0x4e12, (q15_t)0x9a91, + (q15_t)0x4e0d, (q15_t)0x9a8d, (q15_t)0x4e08, (q15_t)0x9a8a, (q15_t)0x4e03, (q15_t)0x9a86, (q15_t)0x4dfe, (q15_t)0x9a82, + (q15_t)0x4df9, (q15_t)0x9a7e, (q15_t)0x4df4, (q15_t)0x9a7a, (q15_t)0x4def, (q15_t)0x9a76, (q15_t)0x4dea, (q15_t)0x9a73, + (q15_t)0x4de5, (q15_t)0x9a6f, (q15_t)0x4de0, (q15_t)0x9a6b, (q15_t)0x4ddb, (q15_t)0x9a67, (q15_t)0x4dd6, (q15_t)0x9a63, + (q15_t)0x4dd1, (q15_t)0x9a60, (q15_t)0x4dcc, (q15_t)0x9a5c, (q15_t)0x4dc7, (q15_t)0x9a58, (q15_t)0x4dc2, (q15_t)0x9a54, + (q15_t)0x4dbd, (q15_t)0x9a50, (q15_t)0x4db8, (q15_t)0x9a4c, (q15_t)0x4db3, (q15_t)0x9a49, (q15_t)0x4dae, (q15_t)0x9a45, + (q15_t)0x4da9, (q15_t)0x9a41, (q15_t)0x4da4, (q15_t)0x9a3d, (q15_t)0x4d9f, (q15_t)0x9a39, (q15_t)0x4d9a, (q15_t)0x9a36, + (q15_t)0x4d95, (q15_t)0x9a32, (q15_t)0x4d90, (q15_t)0x9a2e, (q15_t)0x4d8b, (q15_t)0x9a2a, (q15_t)0x4d86, (q15_t)0x9a26, + (q15_t)0x4d81, (q15_t)0x9a23, (q15_t)0x4d7c, (q15_t)0x9a1f, (q15_t)0x4d77, (q15_t)0x9a1b, (q15_t)0x4d72, (q15_t)0x9a17, + (q15_t)0x4d6d, (q15_t)0x9a13, (q15_t)0x4d68, (q15_t)0x9a10, (q15_t)0x4d63, (q15_t)0x9a0c, (q15_t)0x4d5e, (q15_t)0x9a08, + (q15_t)0x4d59, (q15_t)0x9a04, (q15_t)0x4d54, (q15_t)0x9a00, (q15_t)0x4d4f, (q15_t)0x99fd, (q15_t)0x4d4a, (q15_t)0x99f9, + (q15_t)0x4d45, (q15_t)0x99f5, (q15_t)0x4d40, (q15_t)0x99f1, (q15_t)0x4d3b, (q15_t)0x99ed, (q15_t)0x4d36, (q15_t)0x99ea, + (q15_t)0x4d31, (q15_t)0x99e6, (q15_t)0x4d2c, (q15_t)0x99e2, (q15_t)0x4d27, (q15_t)0x99de, (q15_t)0x4d22, (q15_t)0x99da, + (q15_t)0x4d1d, (q15_t)0x99d7, (q15_t)0x4d18, (q15_t)0x99d3, (q15_t)0x4d13, (q15_t)0x99cf, (q15_t)0x4d0e, (q15_t)0x99cb, + (q15_t)0x4d09, (q15_t)0x99c7, (q15_t)0x4d04, (q15_t)0x99c4, (q15_t)0x4cff, (q15_t)0x99c0, (q15_t)0x4cfa, (q15_t)0x99bc, + (q15_t)0x4cf5, (q15_t)0x99b8, (q15_t)0x4cf0, (q15_t)0x99b5, (q15_t)0x4ceb, (q15_t)0x99b1, (q15_t)0x4ce6, (q15_t)0x99ad, + (q15_t)0x4ce1, (q15_t)0x99a9, (q15_t)0x4cdb, (q15_t)0x99a5, (q15_t)0x4cd6, (q15_t)0x99a2, (q15_t)0x4cd1, (q15_t)0x999e, + (q15_t)0x4ccc, (q15_t)0x999a, (q15_t)0x4cc7, (q15_t)0x9996, (q15_t)0x4cc2, (q15_t)0x9993, (q15_t)0x4cbd, (q15_t)0x998f, + (q15_t)0x4cb8, (q15_t)0x998b, (q15_t)0x4cb3, (q15_t)0x9987, (q15_t)0x4cae, (q15_t)0x9984, (q15_t)0x4ca9, (q15_t)0x9980, + (q15_t)0x4ca4, (q15_t)0x997c, (q15_t)0x4c9f, (q15_t)0x9978, (q15_t)0x4c9a, (q15_t)0x9975, (q15_t)0x4c95, (q15_t)0x9971, + (q15_t)0x4c90, (q15_t)0x996d, (q15_t)0x4c8b, (q15_t)0x9969, (q15_t)0x4c86, (q15_t)0x9965, (q15_t)0x4c81, (q15_t)0x9962, + (q15_t)0x4c7c, (q15_t)0x995e, (q15_t)0x4c77, (q15_t)0x995a, (q15_t)0x4c72, (q15_t)0x9956, (q15_t)0x4c6d, (q15_t)0x9953, + (q15_t)0x4c68, (q15_t)0x994f, (q15_t)0x4c63, (q15_t)0x994b, (q15_t)0x4c5e, (q15_t)0x9947, (q15_t)0x4c59, (q15_t)0x9944, + (q15_t)0x4c54, (q15_t)0x9940, (q15_t)0x4c4f, (q15_t)0x993c, (q15_t)0x4c49, (q15_t)0x9938, (q15_t)0x4c44, (q15_t)0x9935, + (q15_t)0x4c3f, (q15_t)0x9931, (q15_t)0x4c3a, (q15_t)0x992d, (q15_t)0x4c35, (q15_t)0x992a, (q15_t)0x4c30, (q15_t)0x9926, + (q15_t)0x4c2b, (q15_t)0x9922, (q15_t)0x4c26, (q15_t)0x991e, (q15_t)0x4c21, (q15_t)0x991b, (q15_t)0x4c1c, (q15_t)0x9917, + (q15_t)0x4c17, (q15_t)0x9913, (q15_t)0x4c12, (q15_t)0x990f, (q15_t)0x4c0d, (q15_t)0x990c, (q15_t)0x4c08, (q15_t)0x9908, + (q15_t)0x4c03, (q15_t)0x9904, (q15_t)0x4bfe, (q15_t)0x9900, (q15_t)0x4bf9, (q15_t)0x98fd, (q15_t)0x4bf4, (q15_t)0x98f9, + (q15_t)0x4bef, (q15_t)0x98f5, (q15_t)0x4be9, (q15_t)0x98f2, (q15_t)0x4be4, (q15_t)0x98ee, (q15_t)0x4bdf, (q15_t)0x98ea, + (q15_t)0x4bda, (q15_t)0x98e6, (q15_t)0x4bd5, (q15_t)0x98e3, (q15_t)0x4bd0, (q15_t)0x98df, (q15_t)0x4bcb, (q15_t)0x98db, + (q15_t)0x4bc6, (q15_t)0x98d7, (q15_t)0x4bc1, (q15_t)0x98d4, (q15_t)0x4bbc, (q15_t)0x98d0, (q15_t)0x4bb7, (q15_t)0x98cc, + (q15_t)0x4bb2, (q15_t)0x98c9, (q15_t)0x4bad, (q15_t)0x98c5, (q15_t)0x4ba8, (q15_t)0x98c1, (q15_t)0x4ba3, (q15_t)0x98bd, + (q15_t)0x4b9e, (q15_t)0x98ba, (q15_t)0x4b98, (q15_t)0x98b6, (q15_t)0x4b93, (q15_t)0x98b2, (q15_t)0x4b8e, (q15_t)0x98af, + (q15_t)0x4b89, (q15_t)0x98ab, (q15_t)0x4b84, (q15_t)0x98a7, (q15_t)0x4b7f, (q15_t)0x98a3, (q15_t)0x4b7a, (q15_t)0x98a0, + (q15_t)0x4b75, (q15_t)0x989c, (q15_t)0x4b70, (q15_t)0x9898, (q15_t)0x4b6b, (q15_t)0x9895, (q15_t)0x4b66, (q15_t)0x9891, + (q15_t)0x4b61, (q15_t)0x988d, (q15_t)0x4b5c, (q15_t)0x988a, (q15_t)0x4b56, (q15_t)0x9886, (q15_t)0x4b51, (q15_t)0x9882, + (q15_t)0x4b4c, (q15_t)0x987e, (q15_t)0x4b47, (q15_t)0x987b, (q15_t)0x4b42, (q15_t)0x9877, (q15_t)0x4b3d, (q15_t)0x9873, + (q15_t)0x4b38, (q15_t)0x9870, (q15_t)0x4b33, (q15_t)0x986c, (q15_t)0x4b2e, (q15_t)0x9868, (q15_t)0x4b29, (q15_t)0x9865, + (q15_t)0x4b24, (q15_t)0x9861, (q15_t)0x4b1f, (q15_t)0x985d, (q15_t)0x4b19, (q15_t)0x985a, (q15_t)0x4b14, (q15_t)0x9856, + (q15_t)0x4b0f, (q15_t)0x9852, (q15_t)0x4b0a, (q15_t)0x984e, (q15_t)0x4b05, (q15_t)0x984b, (q15_t)0x4b00, (q15_t)0x9847, + (q15_t)0x4afb, (q15_t)0x9843, (q15_t)0x4af6, (q15_t)0x9840, (q15_t)0x4af1, (q15_t)0x983c, (q15_t)0x4aec, (q15_t)0x9838, + (q15_t)0x4ae7, (q15_t)0x9835, (q15_t)0x4ae1, (q15_t)0x9831, (q15_t)0x4adc, (q15_t)0x982d, (q15_t)0x4ad7, (q15_t)0x982a, + (q15_t)0x4ad2, (q15_t)0x9826, (q15_t)0x4acd, (q15_t)0x9822, (q15_t)0x4ac8, (q15_t)0x981f, (q15_t)0x4ac3, (q15_t)0x981b, + (q15_t)0x4abe, (q15_t)0x9817, (q15_t)0x4ab9, (q15_t)0x9814, (q15_t)0x4ab4, (q15_t)0x9810, (q15_t)0x4aae, (q15_t)0x980c, + (q15_t)0x4aa9, (q15_t)0x9809, (q15_t)0x4aa4, (q15_t)0x9805, (q15_t)0x4a9f, (q15_t)0x9801, (q15_t)0x4a9a, (q15_t)0x97fe, + (q15_t)0x4a95, (q15_t)0x97fa, (q15_t)0x4a90, (q15_t)0x97f6, (q15_t)0x4a8b, (q15_t)0x97f3, (q15_t)0x4a86, (q15_t)0x97ef, + (q15_t)0x4a81, (q15_t)0x97eb, (q15_t)0x4a7b, (q15_t)0x97e8, (q15_t)0x4a76, (q15_t)0x97e4, (q15_t)0x4a71, (q15_t)0x97e0, + (q15_t)0x4a6c, (q15_t)0x97dd, (q15_t)0x4a67, (q15_t)0x97d9, (q15_t)0x4a62, (q15_t)0x97d5, (q15_t)0x4a5d, (q15_t)0x97d2, + (q15_t)0x4a58, (q15_t)0x97ce, (q15_t)0x4a52, (q15_t)0x97cb, (q15_t)0x4a4d, (q15_t)0x97c7, (q15_t)0x4a48, (q15_t)0x97c3, + (q15_t)0x4a43, (q15_t)0x97c0, (q15_t)0x4a3e, (q15_t)0x97bc, (q15_t)0x4a39, (q15_t)0x97b8, (q15_t)0x4a34, (q15_t)0x97b5, + (q15_t)0x4a2f, (q15_t)0x97b1, (q15_t)0x4a2a, (q15_t)0x97ad, (q15_t)0x4a24, (q15_t)0x97aa, (q15_t)0x4a1f, (q15_t)0x97a6, + (q15_t)0x4a1a, (q15_t)0x97a2, (q15_t)0x4a15, (q15_t)0x979f, (q15_t)0x4a10, (q15_t)0x979b, (q15_t)0x4a0b, (q15_t)0x9798, + (q15_t)0x4a06, (q15_t)0x9794, (q15_t)0x4a01, (q15_t)0x9790, (q15_t)0x49fb, (q15_t)0x978d, (q15_t)0x49f6, (q15_t)0x9789, + (q15_t)0x49f1, (q15_t)0x9785, (q15_t)0x49ec, (q15_t)0x9782, (q15_t)0x49e7, (q15_t)0x977e, (q15_t)0x49e2, (q15_t)0x977a, + (q15_t)0x49dd, (q15_t)0x9777, (q15_t)0x49d8, (q15_t)0x9773, (q15_t)0x49d2, (q15_t)0x9770, (q15_t)0x49cd, (q15_t)0x976c, + (q15_t)0x49c8, (q15_t)0x9768, (q15_t)0x49c3, (q15_t)0x9765, (q15_t)0x49be, (q15_t)0x9761, (q15_t)0x49b9, (q15_t)0x975d, + (q15_t)0x49b4, (q15_t)0x975a, (q15_t)0x49ae, (q15_t)0x9756, (q15_t)0x49a9, (q15_t)0x9753, (q15_t)0x49a4, (q15_t)0x974f, + (q15_t)0x499f, (q15_t)0x974b, (q15_t)0x499a, (q15_t)0x9748, (q15_t)0x4995, (q15_t)0x9744, (q15_t)0x4990, (q15_t)0x9741, + (q15_t)0x498a, (q15_t)0x973d, (q15_t)0x4985, (q15_t)0x9739, (q15_t)0x4980, (q15_t)0x9736, (q15_t)0x497b, (q15_t)0x9732, + (q15_t)0x4976, (q15_t)0x972f, (q15_t)0x4971, (q15_t)0x972b, (q15_t)0x496c, (q15_t)0x9727, (q15_t)0x4966, (q15_t)0x9724, + (q15_t)0x4961, (q15_t)0x9720, (q15_t)0x495c, (q15_t)0x971d, (q15_t)0x4957, (q15_t)0x9719, (q15_t)0x4952, (q15_t)0x9715, + (q15_t)0x494d, (q15_t)0x9712, (q15_t)0x4948, (q15_t)0x970e, (q15_t)0x4942, (q15_t)0x970b, (q15_t)0x493d, (q15_t)0x9707, + (q15_t)0x4938, (q15_t)0x9703, (q15_t)0x4933, (q15_t)0x9700, (q15_t)0x492e, (q15_t)0x96fc, (q15_t)0x4929, (q15_t)0x96f9, + (q15_t)0x4923, (q15_t)0x96f5, (q15_t)0x491e, (q15_t)0x96f1, (q15_t)0x4919, (q15_t)0x96ee, (q15_t)0x4914, (q15_t)0x96ea, + (q15_t)0x490f, (q15_t)0x96e7, (q15_t)0x490a, (q15_t)0x96e3, (q15_t)0x4905, (q15_t)0x96df, (q15_t)0x48ff, (q15_t)0x96dc, + (q15_t)0x48fa, (q15_t)0x96d8, (q15_t)0x48f5, (q15_t)0x96d5, (q15_t)0x48f0, (q15_t)0x96d1, (q15_t)0x48eb, (q15_t)0x96ce, + (q15_t)0x48e6, (q15_t)0x96ca, (q15_t)0x48e0, (q15_t)0x96c6, (q15_t)0x48db, (q15_t)0x96c3, (q15_t)0x48d6, (q15_t)0x96bf, + (q15_t)0x48d1, (q15_t)0x96bc, (q15_t)0x48cc, (q15_t)0x96b8, (q15_t)0x48c7, (q15_t)0x96b5, (q15_t)0x48c1, (q15_t)0x96b1, + (q15_t)0x48bc, (q15_t)0x96ad, (q15_t)0x48b7, (q15_t)0x96aa, (q15_t)0x48b2, (q15_t)0x96a6, (q15_t)0x48ad, (q15_t)0x96a3, + (q15_t)0x48a8, (q15_t)0x969f, (q15_t)0x48a2, (q15_t)0x969c, (q15_t)0x489d, (q15_t)0x9698, (q15_t)0x4898, (q15_t)0x9694, + (q15_t)0x4893, (q15_t)0x9691, (q15_t)0x488e, (q15_t)0x968d, (q15_t)0x4888, (q15_t)0x968a, (q15_t)0x4883, (q15_t)0x9686, + (q15_t)0x487e, (q15_t)0x9683, (q15_t)0x4879, (q15_t)0x967f, (q15_t)0x4874, (q15_t)0x967b, (q15_t)0x486f, (q15_t)0x9678, + (q15_t)0x4869, (q15_t)0x9674, (q15_t)0x4864, (q15_t)0x9671, (q15_t)0x485f, (q15_t)0x966d, (q15_t)0x485a, (q15_t)0x966a, + (q15_t)0x4855, (q15_t)0x9666, (q15_t)0x484f, (q15_t)0x9663, (q15_t)0x484a, (q15_t)0x965f, (q15_t)0x4845, (q15_t)0x965b, + (q15_t)0x4840, (q15_t)0x9658, (q15_t)0x483b, (q15_t)0x9654, (q15_t)0x4836, (q15_t)0x9651, (q15_t)0x4830, (q15_t)0x964d, + (q15_t)0x482b, (q15_t)0x964a, (q15_t)0x4826, (q15_t)0x9646, (q15_t)0x4821, (q15_t)0x9643, (q15_t)0x481c, (q15_t)0x963f, + (q15_t)0x4816, (q15_t)0x963c, (q15_t)0x4811, (q15_t)0x9638, (q15_t)0x480c, (q15_t)0x9635, (q15_t)0x4807, (q15_t)0x9631, + (q15_t)0x4802, (q15_t)0x962d, (q15_t)0x47fc, (q15_t)0x962a, (q15_t)0x47f7, (q15_t)0x9626, (q15_t)0x47f2, (q15_t)0x9623, + (q15_t)0x47ed, (q15_t)0x961f, (q15_t)0x47e8, (q15_t)0x961c, (q15_t)0x47e2, (q15_t)0x9618, (q15_t)0x47dd, (q15_t)0x9615, + (q15_t)0x47d8, (q15_t)0x9611, (q15_t)0x47d3, (q15_t)0x960e, (q15_t)0x47ce, (q15_t)0x960a, (q15_t)0x47c8, (q15_t)0x9607, + (q15_t)0x47c3, (q15_t)0x9603, (q15_t)0x47be, (q15_t)0x9600, (q15_t)0x47b9, (q15_t)0x95fc, (q15_t)0x47b4, (q15_t)0x95f9, + (q15_t)0x47ae, (q15_t)0x95f5, (q15_t)0x47a9, (q15_t)0x95f2, (q15_t)0x47a4, (q15_t)0x95ee, (q15_t)0x479f, (q15_t)0x95ea, + (q15_t)0x479a, (q15_t)0x95e7, (q15_t)0x4794, (q15_t)0x95e3, (q15_t)0x478f, (q15_t)0x95e0, (q15_t)0x478a, (q15_t)0x95dc, + (q15_t)0x4785, (q15_t)0x95d9, (q15_t)0x4780, (q15_t)0x95d5, (q15_t)0x477a, (q15_t)0x95d2, (q15_t)0x4775, (q15_t)0x95ce, + (q15_t)0x4770, (q15_t)0x95cb, (q15_t)0x476b, (q15_t)0x95c7, (q15_t)0x4765, (q15_t)0x95c4, (q15_t)0x4760, (q15_t)0x95c0, + (q15_t)0x475b, (q15_t)0x95bd, (q15_t)0x4756, (q15_t)0x95b9, (q15_t)0x4751, (q15_t)0x95b6, (q15_t)0x474b, (q15_t)0x95b2, + (q15_t)0x4746, (q15_t)0x95af, (q15_t)0x4741, (q15_t)0x95ab, (q15_t)0x473c, (q15_t)0x95a8, (q15_t)0x4737, (q15_t)0x95a4, + (q15_t)0x4731, (q15_t)0x95a1, (q15_t)0x472c, (q15_t)0x959d, (q15_t)0x4727, (q15_t)0x959a, (q15_t)0x4722, (q15_t)0x9596, + (q15_t)0x471c, (q15_t)0x9593, (q15_t)0x4717, (q15_t)0x958f, (q15_t)0x4712, (q15_t)0x958c, (q15_t)0x470d, (q15_t)0x9588, + (q15_t)0x4708, (q15_t)0x9585, (q15_t)0x4702, (q15_t)0x9581, (q15_t)0x46fd, (q15_t)0x957e, (q15_t)0x46f8, (q15_t)0x957a, + (q15_t)0x46f3, (q15_t)0x9577, (q15_t)0x46ed, (q15_t)0x9574, (q15_t)0x46e8, (q15_t)0x9570, (q15_t)0x46e3, (q15_t)0x956d, + (q15_t)0x46de, (q15_t)0x9569, (q15_t)0x46d8, (q15_t)0x9566, (q15_t)0x46d3, (q15_t)0x9562, (q15_t)0x46ce, (q15_t)0x955f, + (q15_t)0x46c9, (q15_t)0x955b, (q15_t)0x46c4, (q15_t)0x9558, (q15_t)0x46be, (q15_t)0x9554, (q15_t)0x46b9, (q15_t)0x9551, + (q15_t)0x46b4, (q15_t)0x954d, (q15_t)0x46af, (q15_t)0x954a, (q15_t)0x46a9, (q15_t)0x9546, (q15_t)0x46a4, (q15_t)0x9543, + (q15_t)0x469f, (q15_t)0x953f, (q15_t)0x469a, (q15_t)0x953c, (q15_t)0x4694, (q15_t)0x9538, (q15_t)0x468f, (q15_t)0x9535, + (q15_t)0x468a, (q15_t)0x9532, (q15_t)0x4685, (q15_t)0x952e, (q15_t)0x467f, (q15_t)0x952b, (q15_t)0x467a, (q15_t)0x9527, + (q15_t)0x4675, (q15_t)0x9524, (q15_t)0x4670, (q15_t)0x9520, (q15_t)0x466a, (q15_t)0x951d, (q15_t)0x4665, (q15_t)0x9519, + (q15_t)0x4660, (q15_t)0x9516, (q15_t)0x465b, (q15_t)0x9512, (q15_t)0x4655, (q15_t)0x950f, (q15_t)0x4650, (q15_t)0x950c, + (q15_t)0x464b, (q15_t)0x9508, (q15_t)0x4646, (q15_t)0x9505, (q15_t)0x4640, (q15_t)0x9501, (q15_t)0x463b, (q15_t)0x94fe, + (q15_t)0x4636, (q15_t)0x94fa, (q15_t)0x4631, (q15_t)0x94f7, (q15_t)0x462b, (q15_t)0x94f3, (q15_t)0x4626, (q15_t)0x94f0, + (q15_t)0x4621, (q15_t)0x94ed, (q15_t)0x461c, (q15_t)0x94e9, (q15_t)0x4616, (q15_t)0x94e6, (q15_t)0x4611, (q15_t)0x94e2, + (q15_t)0x460c, (q15_t)0x94df, (q15_t)0x4607, (q15_t)0x94db, (q15_t)0x4601, (q15_t)0x94d8, (q15_t)0x45fc, (q15_t)0x94d4, + (q15_t)0x45f7, (q15_t)0x94d1, (q15_t)0x45f2, (q15_t)0x94ce, (q15_t)0x45ec, (q15_t)0x94ca, (q15_t)0x45e7, (q15_t)0x94c7, + (q15_t)0x45e2, (q15_t)0x94c3, (q15_t)0x45dd, (q15_t)0x94c0, (q15_t)0x45d7, (q15_t)0x94bc, (q15_t)0x45d2, (q15_t)0x94b9, + (q15_t)0x45cd, (q15_t)0x94b6, (q15_t)0x45c7, (q15_t)0x94b2, (q15_t)0x45c2, (q15_t)0x94af, (q15_t)0x45bd, (q15_t)0x94ab, + (q15_t)0x45b8, (q15_t)0x94a8, (q15_t)0x45b2, (q15_t)0x94a4, (q15_t)0x45ad, (q15_t)0x94a1, (q15_t)0x45a8, (q15_t)0x949e, + (q15_t)0x45a3, (q15_t)0x949a, (q15_t)0x459d, (q15_t)0x9497, (q15_t)0x4598, (q15_t)0x9493, (q15_t)0x4593, (q15_t)0x9490, + (q15_t)0x458d, (q15_t)0x948d, (q15_t)0x4588, (q15_t)0x9489, (q15_t)0x4583, (q15_t)0x9486, (q15_t)0x457e, (q15_t)0x9482, + (q15_t)0x4578, (q15_t)0x947f, (q15_t)0x4573, (q15_t)0x947b, (q15_t)0x456e, (q15_t)0x9478, (q15_t)0x4569, (q15_t)0x9475, + (q15_t)0x4563, (q15_t)0x9471, (q15_t)0x455e, (q15_t)0x946e, (q15_t)0x4559, (q15_t)0x946a, (q15_t)0x4553, (q15_t)0x9467, + (q15_t)0x454e, (q15_t)0x9464, (q15_t)0x4549, (q15_t)0x9460, (q15_t)0x4544, (q15_t)0x945d, (q15_t)0x453e, (q15_t)0x9459, + (q15_t)0x4539, (q15_t)0x9456, (q15_t)0x4534, (q15_t)0x9453, (q15_t)0x452e, (q15_t)0x944f, (q15_t)0x4529, (q15_t)0x944c, + (q15_t)0x4524, (q15_t)0x9448, (q15_t)0x451f, (q15_t)0x9445, (q15_t)0x4519, (q15_t)0x9442, (q15_t)0x4514, (q15_t)0x943e, + (q15_t)0x450f, (q15_t)0x943b, (q15_t)0x4509, (q15_t)0x9437, (q15_t)0x4504, (q15_t)0x9434, (q15_t)0x44ff, (q15_t)0x9431, + (q15_t)0x44fa, (q15_t)0x942d, (q15_t)0x44f4, (q15_t)0x942a, (q15_t)0x44ef, (q15_t)0x9427, (q15_t)0x44ea, (q15_t)0x9423, + (q15_t)0x44e4, (q15_t)0x9420, (q15_t)0x44df, (q15_t)0x941c, (q15_t)0x44da, (q15_t)0x9419, (q15_t)0x44d4, (q15_t)0x9416, + (q15_t)0x44cf, (q15_t)0x9412, (q15_t)0x44ca, (q15_t)0x940f, (q15_t)0x44c5, (q15_t)0x940b, (q15_t)0x44bf, (q15_t)0x9408, + (q15_t)0x44ba, (q15_t)0x9405, (q15_t)0x44b5, (q15_t)0x9401, (q15_t)0x44af, (q15_t)0x93fe, (q15_t)0x44aa, (q15_t)0x93fb, + (q15_t)0x44a5, (q15_t)0x93f7, (q15_t)0x449f, (q15_t)0x93f4, (q15_t)0x449a, (q15_t)0x93f1, (q15_t)0x4495, (q15_t)0x93ed, + (q15_t)0x4490, (q15_t)0x93ea, (q15_t)0x448a, (q15_t)0x93e6, (q15_t)0x4485, (q15_t)0x93e3, (q15_t)0x4480, (q15_t)0x93e0, + (q15_t)0x447a, (q15_t)0x93dc, (q15_t)0x4475, (q15_t)0x93d9, (q15_t)0x4470, (q15_t)0x93d6, (q15_t)0x446a, (q15_t)0x93d2, + (q15_t)0x4465, (q15_t)0x93cf, (q15_t)0x4460, (q15_t)0x93cc, (q15_t)0x445a, (q15_t)0x93c8, (q15_t)0x4455, (q15_t)0x93c5, + (q15_t)0x4450, (q15_t)0x93c1, (q15_t)0x444b, (q15_t)0x93be, (q15_t)0x4445, (q15_t)0x93bb, (q15_t)0x4440, (q15_t)0x93b7, + (q15_t)0x443b, (q15_t)0x93b4, (q15_t)0x4435, (q15_t)0x93b1, (q15_t)0x4430, (q15_t)0x93ad, (q15_t)0x442b, (q15_t)0x93aa, + (q15_t)0x4425, (q15_t)0x93a7, (q15_t)0x4420, (q15_t)0x93a3, (q15_t)0x441b, (q15_t)0x93a0, (q15_t)0x4415, (q15_t)0x939d, + (q15_t)0x4410, (q15_t)0x9399, (q15_t)0x440b, (q15_t)0x9396, (q15_t)0x4405, (q15_t)0x9393, (q15_t)0x4400, (q15_t)0x938f, + (q15_t)0x43fb, (q15_t)0x938c, (q15_t)0x43f5, (q15_t)0x9389, (q15_t)0x43f0, (q15_t)0x9385, (q15_t)0x43eb, (q15_t)0x9382, + (q15_t)0x43e5, (q15_t)0x937f, (q15_t)0x43e0, (q15_t)0x937b, (q15_t)0x43db, (q15_t)0x9378, (q15_t)0x43d5, (q15_t)0x9375, + (q15_t)0x43d0, (q15_t)0x9371, (q15_t)0x43cb, (q15_t)0x936e, (q15_t)0x43c5, (q15_t)0x936b, (q15_t)0x43c0, (q15_t)0x9367, + (q15_t)0x43bb, (q15_t)0x9364, (q15_t)0x43b5, (q15_t)0x9361, (q15_t)0x43b0, (q15_t)0x935d, (q15_t)0x43ab, (q15_t)0x935a, + (q15_t)0x43a5, (q15_t)0x9357, (q15_t)0x43a0, (q15_t)0x9353, (q15_t)0x439b, (q15_t)0x9350, (q15_t)0x4395, (q15_t)0x934d, + (q15_t)0x4390, (q15_t)0x9349, (q15_t)0x438b, (q15_t)0x9346, (q15_t)0x4385, (q15_t)0x9343, (q15_t)0x4380, (q15_t)0x933f, + (q15_t)0x437b, (q15_t)0x933c, (q15_t)0x4375, (q15_t)0x9339, (q15_t)0x4370, (q15_t)0x9336, (q15_t)0x436b, (q15_t)0x9332, + (q15_t)0x4365, (q15_t)0x932f, (q15_t)0x4360, (q15_t)0x932c, (q15_t)0x435b, (q15_t)0x9328, (q15_t)0x4355, (q15_t)0x9325, + (q15_t)0x4350, (q15_t)0x9322, (q15_t)0x434b, (q15_t)0x931e, (q15_t)0x4345, (q15_t)0x931b, (q15_t)0x4340, (q15_t)0x9318, + (q15_t)0x433b, (q15_t)0x9314, (q15_t)0x4335, (q15_t)0x9311, (q15_t)0x4330, (q15_t)0x930e, (q15_t)0x432b, (q15_t)0x930b, + (q15_t)0x4325, (q15_t)0x9307, (q15_t)0x4320, (q15_t)0x9304, (q15_t)0x431b, (q15_t)0x9301, (q15_t)0x4315, (q15_t)0x92fd, + (q15_t)0x4310, (q15_t)0x92fa, (q15_t)0x430b, (q15_t)0x92f7, (q15_t)0x4305, (q15_t)0x92f4, (q15_t)0x4300, (q15_t)0x92f0, + (q15_t)0x42fa, (q15_t)0x92ed, (q15_t)0x42f5, (q15_t)0x92ea, (q15_t)0x42f0, (q15_t)0x92e6, (q15_t)0x42ea, (q15_t)0x92e3, + (q15_t)0x42e5, (q15_t)0x92e0, (q15_t)0x42e0, (q15_t)0x92dd, (q15_t)0x42da, (q15_t)0x92d9, (q15_t)0x42d5, (q15_t)0x92d6, + (q15_t)0x42d0, (q15_t)0x92d3, (q15_t)0x42ca, (q15_t)0x92cf, (q15_t)0x42c5, (q15_t)0x92cc, (q15_t)0x42c0, (q15_t)0x92c9, + (q15_t)0x42ba, (q15_t)0x92c6, (q15_t)0x42b5, (q15_t)0x92c2, (q15_t)0x42af, (q15_t)0x92bf, (q15_t)0x42aa, (q15_t)0x92bc, + (q15_t)0x42a5, (q15_t)0x92b8, (q15_t)0x429f, (q15_t)0x92b5, (q15_t)0x429a, (q15_t)0x92b2, (q15_t)0x4295, (q15_t)0x92af, + (q15_t)0x428f, (q15_t)0x92ab, (q15_t)0x428a, (q15_t)0x92a8, (q15_t)0x4284, (q15_t)0x92a5, (q15_t)0x427f, (q15_t)0x92a2, + (q15_t)0x427a, (q15_t)0x929e, (q15_t)0x4274, (q15_t)0x929b, (q15_t)0x426f, (q15_t)0x9298, (q15_t)0x426a, (q15_t)0x9295, + (q15_t)0x4264, (q15_t)0x9291, (q15_t)0x425f, (q15_t)0x928e, (q15_t)0x425a, (q15_t)0x928b, (q15_t)0x4254, (q15_t)0x9288, + (q15_t)0x424f, (q15_t)0x9284, (q15_t)0x4249, (q15_t)0x9281, (q15_t)0x4244, (q15_t)0x927e, (q15_t)0x423f, (q15_t)0x927b, + (q15_t)0x4239, (q15_t)0x9277, (q15_t)0x4234, (q15_t)0x9274, (q15_t)0x422f, (q15_t)0x9271, (q15_t)0x4229, (q15_t)0x926e, + (q15_t)0x4224, (q15_t)0x926a, (q15_t)0x421e, (q15_t)0x9267, (q15_t)0x4219, (q15_t)0x9264, (q15_t)0x4214, (q15_t)0x9261, + (q15_t)0x420e, (q15_t)0x925d, (q15_t)0x4209, (q15_t)0x925a, (q15_t)0x4203, (q15_t)0x9257, (q15_t)0x41fe, (q15_t)0x9254, + (q15_t)0x41f9, (q15_t)0x9250, (q15_t)0x41f3, (q15_t)0x924d, (q15_t)0x41ee, (q15_t)0x924a, (q15_t)0x41e9, (q15_t)0x9247, + (q15_t)0x41e3, (q15_t)0x9243, (q15_t)0x41de, (q15_t)0x9240, (q15_t)0x41d8, (q15_t)0x923d, (q15_t)0x41d3, (q15_t)0x923a, + (q15_t)0x41ce, (q15_t)0x9236, (q15_t)0x41c8, (q15_t)0x9233, (q15_t)0x41c3, (q15_t)0x9230, (q15_t)0x41bd, (q15_t)0x922d, + (q15_t)0x41b8, (q15_t)0x922a, (q15_t)0x41b3, (q15_t)0x9226, (q15_t)0x41ad, (q15_t)0x9223, (q15_t)0x41a8, (q15_t)0x9220, + (q15_t)0x41a2, (q15_t)0x921d, (q15_t)0x419d, (q15_t)0x9219, (q15_t)0x4198, (q15_t)0x9216, (q15_t)0x4192, (q15_t)0x9213, + (q15_t)0x418d, (q15_t)0x9210, (q15_t)0x4188, (q15_t)0x920d, (q15_t)0x4182, (q15_t)0x9209, (q15_t)0x417d, (q15_t)0x9206, + (q15_t)0x4177, (q15_t)0x9203, (q15_t)0x4172, (q15_t)0x9200, (q15_t)0x416d, (q15_t)0x91fc, (q15_t)0x4167, (q15_t)0x91f9, + (q15_t)0x4162, (q15_t)0x91f6, (q15_t)0x415c, (q15_t)0x91f3, (q15_t)0x4157, (q15_t)0x91f0, (q15_t)0x4152, (q15_t)0x91ec, + (q15_t)0x414c, (q15_t)0x91e9, (q15_t)0x4147, (q15_t)0x91e6, (q15_t)0x4141, (q15_t)0x91e3, (q15_t)0x413c, (q15_t)0x91e0, + (q15_t)0x4136, (q15_t)0x91dc, (q15_t)0x4131, (q15_t)0x91d9, (q15_t)0x412c, (q15_t)0x91d6, (q15_t)0x4126, (q15_t)0x91d3, + (q15_t)0x4121, (q15_t)0x91d0, (q15_t)0x411b, (q15_t)0x91cc, (q15_t)0x4116, (q15_t)0x91c9, (q15_t)0x4111, (q15_t)0x91c6, + (q15_t)0x410b, (q15_t)0x91c3, (q15_t)0x4106, (q15_t)0x91c0, (q15_t)0x4100, (q15_t)0x91bc, (q15_t)0x40fb, (q15_t)0x91b9, + (q15_t)0x40f6, (q15_t)0x91b6, (q15_t)0x40f0, (q15_t)0x91b3, (q15_t)0x40eb, (q15_t)0x91b0, (q15_t)0x40e5, (q15_t)0x91ad, + (q15_t)0x40e0, (q15_t)0x91a9, (q15_t)0x40da, (q15_t)0x91a6, (q15_t)0x40d5, (q15_t)0x91a3, (q15_t)0x40d0, (q15_t)0x91a0, + (q15_t)0x40ca, (q15_t)0x919d, (q15_t)0x40c5, (q15_t)0x9199, (q15_t)0x40bf, (q15_t)0x9196, (q15_t)0x40ba, (q15_t)0x9193, + (q15_t)0x40b5, (q15_t)0x9190, (q15_t)0x40af, (q15_t)0x918d, (q15_t)0x40aa, (q15_t)0x918a, (q15_t)0x40a4, (q15_t)0x9186, + (q15_t)0x409f, (q15_t)0x9183, (q15_t)0x4099, (q15_t)0x9180, (q15_t)0x4094, (q15_t)0x917d, (q15_t)0x408f, (q15_t)0x917a, + (q15_t)0x4089, (q15_t)0x9177, (q15_t)0x4084, (q15_t)0x9173, (q15_t)0x407e, (q15_t)0x9170, (q15_t)0x4079, (q15_t)0x916d, + (q15_t)0x4073, (q15_t)0x916a, (q15_t)0x406e, (q15_t)0x9167, (q15_t)0x4069, (q15_t)0x9164, (q15_t)0x4063, (q15_t)0x9160, + (q15_t)0x405e, (q15_t)0x915d, (q15_t)0x4058, (q15_t)0x915a, (q15_t)0x4053, (q15_t)0x9157, (q15_t)0x404d, (q15_t)0x9154, + (q15_t)0x4048, (q15_t)0x9151, (q15_t)0x4043, (q15_t)0x914d, (q15_t)0x403d, (q15_t)0x914a, (q15_t)0x4038, (q15_t)0x9147, + (q15_t)0x4032, (q15_t)0x9144, (q15_t)0x402d, (q15_t)0x9141, (q15_t)0x4027, (q15_t)0x913e, (q15_t)0x4022, (q15_t)0x913a, + (q15_t)0x401d, (q15_t)0x9137, (q15_t)0x4017, (q15_t)0x9134, (q15_t)0x4012, (q15_t)0x9131, (q15_t)0x400c, (q15_t)0x912e, + (q15_t)0x4007, (q15_t)0x912b, (q15_t)0x4001, (q15_t)0x9128, (q15_t)0x3ffc, (q15_t)0x9124, (q15_t)0x3ff6, (q15_t)0x9121, + (q15_t)0x3ff1, (q15_t)0x911e, (q15_t)0x3fec, (q15_t)0x911b, (q15_t)0x3fe6, (q15_t)0x9118, (q15_t)0x3fe1, (q15_t)0x9115, + (q15_t)0x3fdb, (q15_t)0x9112, (q15_t)0x3fd6, (q15_t)0x910f, (q15_t)0x3fd0, (q15_t)0x910b, (q15_t)0x3fcb, (q15_t)0x9108, + (q15_t)0x3fc5, (q15_t)0x9105, (q15_t)0x3fc0, (q15_t)0x9102, (q15_t)0x3fbb, (q15_t)0x90ff, (q15_t)0x3fb5, (q15_t)0x90fc, + (q15_t)0x3fb0, (q15_t)0x90f9, (q15_t)0x3faa, (q15_t)0x90f5, (q15_t)0x3fa5, (q15_t)0x90f2, (q15_t)0x3f9f, (q15_t)0x90ef, + (q15_t)0x3f9a, (q15_t)0x90ec, (q15_t)0x3f94, (q15_t)0x90e9, (q15_t)0x3f8f, (q15_t)0x90e6, (q15_t)0x3f89, (q15_t)0x90e3, + (q15_t)0x3f84, (q15_t)0x90e0, (q15_t)0x3f7f, (q15_t)0x90dd, (q15_t)0x3f79, (q15_t)0x90d9, (q15_t)0x3f74, (q15_t)0x90d6, + (q15_t)0x3f6e, (q15_t)0x90d3, (q15_t)0x3f69, (q15_t)0x90d0, (q15_t)0x3f63, (q15_t)0x90cd, (q15_t)0x3f5e, (q15_t)0x90ca, + (q15_t)0x3f58, (q15_t)0x90c7, (q15_t)0x3f53, (q15_t)0x90c4, (q15_t)0x3f4d, (q15_t)0x90c1, (q15_t)0x3f48, (q15_t)0x90bd, + (q15_t)0x3f43, (q15_t)0x90ba, (q15_t)0x3f3d, (q15_t)0x90b7, (q15_t)0x3f38, (q15_t)0x90b4, (q15_t)0x3f32, (q15_t)0x90b1, + (q15_t)0x3f2d, (q15_t)0x90ae, (q15_t)0x3f27, (q15_t)0x90ab, (q15_t)0x3f22, (q15_t)0x90a8, (q15_t)0x3f1c, (q15_t)0x90a5, + (q15_t)0x3f17, (q15_t)0x90a1, (q15_t)0x3f11, (q15_t)0x909e, (q15_t)0x3f0c, (q15_t)0x909b, (q15_t)0x3f06, (q15_t)0x9098, + (q15_t)0x3f01, (q15_t)0x9095, (q15_t)0x3efb, (q15_t)0x9092, (q15_t)0x3ef6, (q15_t)0x908f, (q15_t)0x3ef1, (q15_t)0x908c, + (q15_t)0x3eeb, (q15_t)0x9089, (q15_t)0x3ee6, (q15_t)0x9086, (q15_t)0x3ee0, (q15_t)0x9083, (q15_t)0x3edb, (q15_t)0x907f, + (q15_t)0x3ed5, (q15_t)0x907c, (q15_t)0x3ed0, (q15_t)0x9079, (q15_t)0x3eca, (q15_t)0x9076, (q15_t)0x3ec5, (q15_t)0x9073, + (q15_t)0x3ebf, (q15_t)0x9070, (q15_t)0x3eba, (q15_t)0x906d, (q15_t)0x3eb4, (q15_t)0x906a, (q15_t)0x3eaf, (q15_t)0x9067, + (q15_t)0x3ea9, (q15_t)0x9064, (q15_t)0x3ea4, (q15_t)0x9061, (q15_t)0x3e9e, (q15_t)0x905e, (q15_t)0x3e99, (q15_t)0x905b, + (q15_t)0x3e93, (q15_t)0x9057, (q15_t)0x3e8e, (q15_t)0x9054, (q15_t)0x3e88, (q15_t)0x9051, (q15_t)0x3e83, (q15_t)0x904e, + (q15_t)0x3e7d, (q15_t)0x904b, (q15_t)0x3e78, (q15_t)0x9048, (q15_t)0x3e73, (q15_t)0x9045, (q15_t)0x3e6d, (q15_t)0x9042, + (q15_t)0x3e68, (q15_t)0x903f, (q15_t)0x3e62, (q15_t)0x903c, (q15_t)0x3e5d, (q15_t)0x9039, (q15_t)0x3e57, (q15_t)0x9036, + (q15_t)0x3e52, (q15_t)0x9033, (q15_t)0x3e4c, (q15_t)0x9030, (q15_t)0x3e47, (q15_t)0x902d, (q15_t)0x3e41, (q15_t)0x902a, + (q15_t)0x3e3c, (q15_t)0x9026, (q15_t)0x3e36, (q15_t)0x9023, (q15_t)0x3e31, (q15_t)0x9020, (q15_t)0x3e2b, (q15_t)0x901d, + (q15_t)0x3e26, (q15_t)0x901a, (q15_t)0x3e20, (q15_t)0x9017, (q15_t)0x3e1b, (q15_t)0x9014, (q15_t)0x3e15, (q15_t)0x9011, + (q15_t)0x3e10, (q15_t)0x900e, (q15_t)0x3e0a, (q15_t)0x900b, (q15_t)0x3e05, (q15_t)0x9008, (q15_t)0x3dff, (q15_t)0x9005, + (q15_t)0x3dfa, (q15_t)0x9002, (q15_t)0x3df4, (q15_t)0x8fff, (q15_t)0x3def, (q15_t)0x8ffc, (q15_t)0x3de9, (q15_t)0x8ff9, + (q15_t)0x3de4, (q15_t)0x8ff6, (q15_t)0x3dde, (q15_t)0x8ff3, (q15_t)0x3dd9, (q15_t)0x8ff0, (q15_t)0x3dd3, (q15_t)0x8fed, + (q15_t)0x3dce, (q15_t)0x8fea, (q15_t)0x3dc8, (q15_t)0x8fe7, (q15_t)0x3dc3, (q15_t)0x8fe3, (q15_t)0x3dbd, (q15_t)0x8fe0, + (q15_t)0x3db8, (q15_t)0x8fdd, (q15_t)0x3db2, (q15_t)0x8fda, (q15_t)0x3dad, (q15_t)0x8fd7, (q15_t)0x3da7, (q15_t)0x8fd4, + (q15_t)0x3da2, (q15_t)0x8fd1, (q15_t)0x3d9c, (q15_t)0x8fce, (q15_t)0x3d97, (q15_t)0x8fcb, (q15_t)0x3d91, (q15_t)0x8fc8, + (q15_t)0x3d8c, (q15_t)0x8fc5, (q15_t)0x3d86, (q15_t)0x8fc2, (q15_t)0x3d81, (q15_t)0x8fbf, (q15_t)0x3d7b, (q15_t)0x8fbc, + (q15_t)0x3d76, (q15_t)0x8fb9, (q15_t)0x3d70, (q15_t)0x8fb6, (q15_t)0x3d6b, (q15_t)0x8fb3, (q15_t)0x3d65, (q15_t)0x8fb0, + (q15_t)0x3d60, (q15_t)0x8fad, (q15_t)0x3d5a, (q15_t)0x8faa, (q15_t)0x3d55, (q15_t)0x8fa7, (q15_t)0x3d4f, (q15_t)0x8fa4, + (q15_t)0x3d49, (q15_t)0x8fa1, (q15_t)0x3d44, (q15_t)0x8f9e, (q15_t)0x3d3e, (q15_t)0x8f9b, (q15_t)0x3d39, (q15_t)0x8f98, + (q15_t)0x3d33, (q15_t)0x8f95, (q15_t)0x3d2e, (q15_t)0x8f92, (q15_t)0x3d28, (q15_t)0x8f8f, (q15_t)0x3d23, (q15_t)0x8f8c, + (q15_t)0x3d1d, (q15_t)0x8f89, (q15_t)0x3d18, (q15_t)0x8f86, (q15_t)0x3d12, (q15_t)0x8f83, (q15_t)0x3d0d, (q15_t)0x8f80, + (q15_t)0x3d07, (q15_t)0x8f7d, (q15_t)0x3d02, (q15_t)0x8f7a, (q15_t)0x3cfc, (q15_t)0x8f77, (q15_t)0x3cf7, (q15_t)0x8f74, + (q15_t)0x3cf1, (q15_t)0x8f71, (q15_t)0x3cec, (q15_t)0x8f6e, (q15_t)0x3ce6, (q15_t)0x8f6b, (q15_t)0x3ce1, (q15_t)0x8f68, + (q15_t)0x3cdb, (q15_t)0x8f65, (q15_t)0x3cd6, (q15_t)0x8f62, (q15_t)0x3cd0, (q15_t)0x8f5f, (q15_t)0x3cca, (q15_t)0x8f5c, + (q15_t)0x3cc5, (q15_t)0x8f59, (q15_t)0x3cbf, (q15_t)0x8f56, (q15_t)0x3cba, (q15_t)0x8f53, (q15_t)0x3cb4, (q15_t)0x8f50, + (q15_t)0x3caf, (q15_t)0x8f4d, (q15_t)0x3ca9, (q15_t)0x8f4a, (q15_t)0x3ca4, (q15_t)0x8f47, (q15_t)0x3c9e, (q15_t)0x8f44, + (q15_t)0x3c99, (q15_t)0x8f41, (q15_t)0x3c93, (q15_t)0x8f3e, (q15_t)0x3c8e, (q15_t)0x8f3b, (q15_t)0x3c88, (q15_t)0x8f38, + (q15_t)0x3c83, (q15_t)0x8f35, (q15_t)0x3c7d, (q15_t)0x8f32, (q15_t)0x3c77, (q15_t)0x8f2f, (q15_t)0x3c72, (q15_t)0x8f2d, + (q15_t)0x3c6c, (q15_t)0x8f2a, (q15_t)0x3c67, (q15_t)0x8f27, (q15_t)0x3c61, (q15_t)0x8f24, (q15_t)0x3c5c, (q15_t)0x8f21, + (q15_t)0x3c56, (q15_t)0x8f1e, (q15_t)0x3c51, (q15_t)0x8f1b, (q15_t)0x3c4b, (q15_t)0x8f18, (q15_t)0x3c46, (q15_t)0x8f15, + (q15_t)0x3c40, (q15_t)0x8f12, (q15_t)0x3c3b, (q15_t)0x8f0f, (q15_t)0x3c35, (q15_t)0x8f0c, (q15_t)0x3c2f, (q15_t)0x8f09, + (q15_t)0x3c2a, (q15_t)0x8f06, (q15_t)0x3c24, (q15_t)0x8f03, (q15_t)0x3c1f, (q15_t)0x8f00, (q15_t)0x3c19, (q15_t)0x8efd, + (q15_t)0x3c14, (q15_t)0x8efa, (q15_t)0x3c0e, (q15_t)0x8ef7, (q15_t)0x3c09, (q15_t)0x8ef4, (q15_t)0x3c03, (q15_t)0x8ef1, + (q15_t)0x3bfd, (q15_t)0x8eee, (q15_t)0x3bf8, (q15_t)0x8eec, (q15_t)0x3bf2, (q15_t)0x8ee9, (q15_t)0x3bed, (q15_t)0x8ee6, + (q15_t)0x3be7, (q15_t)0x8ee3, (q15_t)0x3be2, (q15_t)0x8ee0, (q15_t)0x3bdc, (q15_t)0x8edd, (q15_t)0x3bd7, (q15_t)0x8eda, + (q15_t)0x3bd1, (q15_t)0x8ed7, (q15_t)0x3bcc, (q15_t)0x8ed4, (q15_t)0x3bc6, (q15_t)0x8ed1, (q15_t)0x3bc0, (q15_t)0x8ece, + (q15_t)0x3bbb, (q15_t)0x8ecb, (q15_t)0x3bb5, (q15_t)0x8ec8, (q15_t)0x3bb0, (q15_t)0x8ec5, (q15_t)0x3baa, (q15_t)0x8ec2, + (q15_t)0x3ba5, (q15_t)0x8ebf, (q15_t)0x3b9f, (q15_t)0x8ebd, (q15_t)0x3b99, (q15_t)0x8eba, (q15_t)0x3b94, (q15_t)0x8eb7, + (q15_t)0x3b8e, (q15_t)0x8eb4, (q15_t)0x3b89, (q15_t)0x8eb1, (q15_t)0x3b83, (q15_t)0x8eae, (q15_t)0x3b7e, (q15_t)0x8eab, + (q15_t)0x3b78, (q15_t)0x8ea8, (q15_t)0x3b73, (q15_t)0x8ea5, (q15_t)0x3b6d, (q15_t)0x8ea2, (q15_t)0x3b67, (q15_t)0x8e9f, + (q15_t)0x3b62, (q15_t)0x8e9c, (q15_t)0x3b5c, (q15_t)0x8e99, (q15_t)0x3b57, (q15_t)0x8e97, (q15_t)0x3b51, (q15_t)0x8e94, + (q15_t)0x3b4c, (q15_t)0x8e91, (q15_t)0x3b46, (q15_t)0x8e8e, (q15_t)0x3b40, (q15_t)0x8e8b, (q15_t)0x3b3b, (q15_t)0x8e88, + (q15_t)0x3b35, (q15_t)0x8e85, (q15_t)0x3b30, (q15_t)0x8e82, (q15_t)0x3b2a, (q15_t)0x8e7f, (q15_t)0x3b25, (q15_t)0x8e7c, + (q15_t)0x3b1f, (q15_t)0x8e7a, (q15_t)0x3b19, (q15_t)0x8e77, (q15_t)0x3b14, (q15_t)0x8e74, (q15_t)0x3b0e, (q15_t)0x8e71, + (q15_t)0x3b09, (q15_t)0x8e6e, (q15_t)0x3b03, (q15_t)0x8e6b, (q15_t)0x3afe, (q15_t)0x8e68, (q15_t)0x3af8, (q15_t)0x8e65, + (q15_t)0x3af2, (q15_t)0x8e62, (q15_t)0x3aed, (q15_t)0x8e5f, (q15_t)0x3ae7, (q15_t)0x8e5d, (q15_t)0x3ae2, (q15_t)0x8e5a, + (q15_t)0x3adc, (q15_t)0x8e57, (q15_t)0x3ad7, (q15_t)0x8e54, (q15_t)0x3ad1, (q15_t)0x8e51, (q15_t)0x3acb, (q15_t)0x8e4e, + (q15_t)0x3ac6, (q15_t)0x8e4b, (q15_t)0x3ac0, (q15_t)0x8e48, (q15_t)0x3abb, (q15_t)0x8e45, (q15_t)0x3ab5, (q15_t)0x8e43, + (q15_t)0x3aaf, (q15_t)0x8e40, (q15_t)0x3aaa, (q15_t)0x8e3d, (q15_t)0x3aa4, (q15_t)0x8e3a, (q15_t)0x3a9f, (q15_t)0x8e37, + (q15_t)0x3a99, (q15_t)0x8e34, (q15_t)0x3a94, (q15_t)0x8e31, (q15_t)0x3a8e, (q15_t)0x8e2e, (q15_t)0x3a88, (q15_t)0x8e2c, + (q15_t)0x3a83, (q15_t)0x8e29, (q15_t)0x3a7d, (q15_t)0x8e26, (q15_t)0x3a78, (q15_t)0x8e23, (q15_t)0x3a72, (q15_t)0x8e20, + (q15_t)0x3a6c, (q15_t)0x8e1d, (q15_t)0x3a67, (q15_t)0x8e1a, (q15_t)0x3a61, (q15_t)0x8e17, (q15_t)0x3a5c, (q15_t)0x8e15, + (q15_t)0x3a56, (q15_t)0x8e12, (q15_t)0x3a50, (q15_t)0x8e0f, (q15_t)0x3a4b, (q15_t)0x8e0c, (q15_t)0x3a45, (q15_t)0x8e09, + (q15_t)0x3a40, (q15_t)0x8e06, (q15_t)0x3a3a, (q15_t)0x8e03, (q15_t)0x3a34, (q15_t)0x8e01, (q15_t)0x3a2f, (q15_t)0x8dfe, + (q15_t)0x3a29, (q15_t)0x8dfb, (q15_t)0x3a24, (q15_t)0x8df8, (q15_t)0x3a1e, (q15_t)0x8df5, (q15_t)0x3a19, (q15_t)0x8df2, + (q15_t)0x3a13, (q15_t)0x8def, (q15_t)0x3a0d, (q15_t)0x8ded, (q15_t)0x3a08, (q15_t)0x8dea, (q15_t)0x3a02, (q15_t)0x8de7, + (q15_t)0x39fd, (q15_t)0x8de4, (q15_t)0x39f7, (q15_t)0x8de1, (q15_t)0x39f1, (q15_t)0x8dde, (q15_t)0x39ec, (q15_t)0x8ddc, + (q15_t)0x39e6, (q15_t)0x8dd9, (q15_t)0x39e0, (q15_t)0x8dd6, (q15_t)0x39db, (q15_t)0x8dd3, (q15_t)0x39d5, (q15_t)0x8dd0, + (q15_t)0x39d0, (q15_t)0x8dcd, (q15_t)0x39ca, (q15_t)0x8dca, (q15_t)0x39c4, (q15_t)0x8dc8, (q15_t)0x39bf, (q15_t)0x8dc5, + (q15_t)0x39b9, (q15_t)0x8dc2, (q15_t)0x39b4, (q15_t)0x8dbf, (q15_t)0x39ae, (q15_t)0x8dbc, (q15_t)0x39a8, (q15_t)0x8db9, + (q15_t)0x39a3, (q15_t)0x8db7, (q15_t)0x399d, (q15_t)0x8db4, (q15_t)0x3998, (q15_t)0x8db1, (q15_t)0x3992, (q15_t)0x8dae, + (q15_t)0x398c, (q15_t)0x8dab, (q15_t)0x3987, (q15_t)0x8da9, (q15_t)0x3981, (q15_t)0x8da6, (q15_t)0x397c, (q15_t)0x8da3, + (q15_t)0x3976, (q15_t)0x8da0, (q15_t)0x3970, (q15_t)0x8d9d, (q15_t)0x396b, (q15_t)0x8d9a, (q15_t)0x3965, (q15_t)0x8d98, + (q15_t)0x395f, (q15_t)0x8d95, (q15_t)0x395a, (q15_t)0x8d92, (q15_t)0x3954, (q15_t)0x8d8f, (q15_t)0x394f, (q15_t)0x8d8c, + (q15_t)0x3949, (q15_t)0x8d8a, (q15_t)0x3943, (q15_t)0x8d87, (q15_t)0x393e, (q15_t)0x8d84, (q15_t)0x3938, (q15_t)0x8d81, + (q15_t)0x3932, (q15_t)0x8d7e, (q15_t)0x392d, (q15_t)0x8d7b, (q15_t)0x3927, (q15_t)0x8d79, (q15_t)0x3922, (q15_t)0x8d76, + (q15_t)0x391c, (q15_t)0x8d73, (q15_t)0x3916, (q15_t)0x8d70, (q15_t)0x3911, (q15_t)0x8d6d, (q15_t)0x390b, (q15_t)0x8d6b, + (q15_t)0x3906, (q15_t)0x8d68, (q15_t)0x3900, (q15_t)0x8d65, (q15_t)0x38fa, (q15_t)0x8d62, (q15_t)0x38f5, (q15_t)0x8d5f, + (q15_t)0x38ef, (q15_t)0x8d5d, (q15_t)0x38e9, (q15_t)0x8d5a, (q15_t)0x38e4, (q15_t)0x8d57, (q15_t)0x38de, (q15_t)0x8d54, + (q15_t)0x38d8, (q15_t)0x8d51, (q15_t)0x38d3, (q15_t)0x8d4f, (q15_t)0x38cd, (q15_t)0x8d4c, (q15_t)0x38c8, (q15_t)0x8d49, + (q15_t)0x38c2, (q15_t)0x8d46, (q15_t)0x38bc, (q15_t)0x8d44, (q15_t)0x38b7, (q15_t)0x8d41, (q15_t)0x38b1, (q15_t)0x8d3e, + (q15_t)0x38ab, (q15_t)0x8d3b, (q15_t)0x38a6, (q15_t)0x8d38, (q15_t)0x38a0, (q15_t)0x8d36, (q15_t)0x389b, (q15_t)0x8d33, + (q15_t)0x3895, (q15_t)0x8d30, (q15_t)0x388f, (q15_t)0x8d2d, (q15_t)0x388a, (q15_t)0x8d2b, (q15_t)0x3884, (q15_t)0x8d28, + (q15_t)0x387e, (q15_t)0x8d25, (q15_t)0x3879, (q15_t)0x8d22, (q15_t)0x3873, (q15_t)0x8d1f, (q15_t)0x386d, (q15_t)0x8d1d, + (q15_t)0x3868, (q15_t)0x8d1a, (q15_t)0x3862, (q15_t)0x8d17, (q15_t)0x385d, (q15_t)0x8d14, (q15_t)0x3857, (q15_t)0x8d12, + (q15_t)0x3851, (q15_t)0x8d0f, (q15_t)0x384c, (q15_t)0x8d0c, (q15_t)0x3846, (q15_t)0x8d09, (q15_t)0x3840, (q15_t)0x8d07, + (q15_t)0x383b, (q15_t)0x8d04, (q15_t)0x3835, (q15_t)0x8d01, (q15_t)0x382f, (q15_t)0x8cfe, (q15_t)0x382a, (q15_t)0x8cfb, + (q15_t)0x3824, (q15_t)0x8cf9, (q15_t)0x381e, (q15_t)0x8cf6, (q15_t)0x3819, (q15_t)0x8cf3, (q15_t)0x3813, (q15_t)0x8cf0, + (q15_t)0x380d, (q15_t)0x8cee, (q15_t)0x3808, (q15_t)0x8ceb, (q15_t)0x3802, (q15_t)0x8ce8, (q15_t)0x37fd, (q15_t)0x8ce5, + (q15_t)0x37f7, (q15_t)0x8ce3, (q15_t)0x37f1, (q15_t)0x8ce0, (q15_t)0x37ec, (q15_t)0x8cdd, (q15_t)0x37e6, (q15_t)0x8cda, + (q15_t)0x37e0, (q15_t)0x8cd8, (q15_t)0x37db, (q15_t)0x8cd5, (q15_t)0x37d5, (q15_t)0x8cd2, (q15_t)0x37cf, (q15_t)0x8cd0, + (q15_t)0x37ca, (q15_t)0x8ccd, (q15_t)0x37c4, (q15_t)0x8cca, (q15_t)0x37be, (q15_t)0x8cc7, (q15_t)0x37b9, (q15_t)0x8cc5, + (q15_t)0x37b3, (q15_t)0x8cc2, (q15_t)0x37ad, (q15_t)0x8cbf, (q15_t)0x37a8, (q15_t)0x8cbc, (q15_t)0x37a2, (q15_t)0x8cba, + (q15_t)0x379c, (q15_t)0x8cb7, (q15_t)0x3797, (q15_t)0x8cb4, (q15_t)0x3791, (q15_t)0x8cb1, (q15_t)0x378b, (q15_t)0x8caf, + (q15_t)0x3786, (q15_t)0x8cac, (q15_t)0x3780, (q15_t)0x8ca9, (q15_t)0x377a, (q15_t)0x8ca7, (q15_t)0x3775, (q15_t)0x8ca4, + (q15_t)0x376f, (q15_t)0x8ca1, (q15_t)0x3769, (q15_t)0x8c9e, (q15_t)0x3764, (q15_t)0x8c9c, (q15_t)0x375e, (q15_t)0x8c99, + (q15_t)0x3758, (q15_t)0x8c96, (q15_t)0x3753, (q15_t)0x8c94, (q15_t)0x374d, (q15_t)0x8c91, (q15_t)0x3747, (q15_t)0x8c8e, + (q15_t)0x3742, (q15_t)0x8c8b, (q15_t)0x373c, (q15_t)0x8c89, (q15_t)0x3736, (q15_t)0x8c86, (q15_t)0x3731, (q15_t)0x8c83, + (q15_t)0x372b, (q15_t)0x8c81, (q15_t)0x3725, (q15_t)0x8c7e, (q15_t)0x3720, (q15_t)0x8c7b, (q15_t)0x371a, (q15_t)0x8c78, + (q15_t)0x3714, (q15_t)0x8c76, (q15_t)0x370f, (q15_t)0x8c73, (q15_t)0x3709, (q15_t)0x8c70, (q15_t)0x3703, (q15_t)0x8c6e, + (q15_t)0x36fe, (q15_t)0x8c6b, (q15_t)0x36f8, (q15_t)0x8c68, (q15_t)0x36f2, (q15_t)0x8c65, (q15_t)0x36ed, (q15_t)0x8c63, + (q15_t)0x36e7, (q15_t)0x8c60, (q15_t)0x36e1, (q15_t)0x8c5d, (q15_t)0x36dc, (q15_t)0x8c5b, (q15_t)0x36d6, (q15_t)0x8c58, + (q15_t)0x36d0, (q15_t)0x8c55, (q15_t)0x36cb, (q15_t)0x8c53, (q15_t)0x36c5, (q15_t)0x8c50, (q15_t)0x36bf, (q15_t)0x8c4d, + (q15_t)0x36ba, (q15_t)0x8c4b, (q15_t)0x36b4, (q15_t)0x8c48, (q15_t)0x36ae, (q15_t)0x8c45, (q15_t)0x36a9, (q15_t)0x8c43, + (q15_t)0x36a3, (q15_t)0x8c40, (q15_t)0x369d, (q15_t)0x8c3d, (q15_t)0x3698, (q15_t)0x8c3a, (q15_t)0x3692, (q15_t)0x8c38, + (q15_t)0x368c, (q15_t)0x8c35, (q15_t)0x3686, (q15_t)0x8c32, (q15_t)0x3681, (q15_t)0x8c30, (q15_t)0x367b, (q15_t)0x8c2d, + (q15_t)0x3675, (q15_t)0x8c2a, (q15_t)0x3670, (q15_t)0x8c28, (q15_t)0x366a, (q15_t)0x8c25, (q15_t)0x3664, (q15_t)0x8c22, + (q15_t)0x365f, (q15_t)0x8c20, (q15_t)0x3659, (q15_t)0x8c1d, (q15_t)0x3653, (q15_t)0x8c1a, (q15_t)0x364e, (q15_t)0x8c18, + (q15_t)0x3648, (q15_t)0x8c15, (q15_t)0x3642, (q15_t)0x8c12, (q15_t)0x363d, (q15_t)0x8c10, (q15_t)0x3637, (q15_t)0x8c0d, + (q15_t)0x3631, (q15_t)0x8c0a, (q15_t)0x362b, (q15_t)0x8c08, (q15_t)0x3626, (q15_t)0x8c05, (q15_t)0x3620, (q15_t)0x8c02, + (q15_t)0x361a, (q15_t)0x8c00, (q15_t)0x3615, (q15_t)0x8bfd, (q15_t)0x360f, (q15_t)0x8bfa, (q15_t)0x3609, (q15_t)0x8bf8, + (q15_t)0x3604, (q15_t)0x8bf5, (q15_t)0x35fe, (q15_t)0x8bf3, (q15_t)0x35f8, (q15_t)0x8bf0, (q15_t)0x35f3, (q15_t)0x8bed, + (q15_t)0x35ed, (q15_t)0x8beb, (q15_t)0x35e7, (q15_t)0x8be8, (q15_t)0x35e1, (q15_t)0x8be5, (q15_t)0x35dc, (q15_t)0x8be3, + (q15_t)0x35d6, (q15_t)0x8be0, (q15_t)0x35d0, (q15_t)0x8bdd, (q15_t)0x35cb, (q15_t)0x8bdb, (q15_t)0x35c5, (q15_t)0x8bd8, + (q15_t)0x35bf, (q15_t)0x8bd5, (q15_t)0x35ba, (q15_t)0x8bd3, (q15_t)0x35b4, (q15_t)0x8bd0, (q15_t)0x35ae, (q15_t)0x8bce, + (q15_t)0x35a8, (q15_t)0x8bcb, (q15_t)0x35a3, (q15_t)0x8bc8, (q15_t)0x359d, (q15_t)0x8bc6, (q15_t)0x3597, (q15_t)0x8bc3, + (q15_t)0x3592, (q15_t)0x8bc0, (q15_t)0x358c, (q15_t)0x8bbe, (q15_t)0x3586, (q15_t)0x8bbb, (q15_t)0x3580, (q15_t)0x8bb8, + (q15_t)0x357b, (q15_t)0x8bb6, (q15_t)0x3575, (q15_t)0x8bb3, (q15_t)0x356f, (q15_t)0x8bb1, (q15_t)0x356a, (q15_t)0x8bae, + (q15_t)0x3564, (q15_t)0x8bab, (q15_t)0x355e, (q15_t)0x8ba9, (q15_t)0x3558, (q15_t)0x8ba6, (q15_t)0x3553, (q15_t)0x8ba4, + (q15_t)0x354d, (q15_t)0x8ba1, (q15_t)0x3547, (q15_t)0x8b9e, (q15_t)0x3542, (q15_t)0x8b9c, (q15_t)0x353c, (q15_t)0x8b99, + (q15_t)0x3536, (q15_t)0x8b96, (q15_t)0x3530, (q15_t)0x8b94, (q15_t)0x352b, (q15_t)0x8b91, (q15_t)0x3525, (q15_t)0x8b8f, + (q15_t)0x351f, (q15_t)0x8b8c, (q15_t)0x351a, (q15_t)0x8b89, (q15_t)0x3514, (q15_t)0x8b87, (q15_t)0x350e, (q15_t)0x8b84, + (q15_t)0x3508, (q15_t)0x8b82, (q15_t)0x3503, (q15_t)0x8b7f, (q15_t)0x34fd, (q15_t)0x8b7c, (q15_t)0x34f7, (q15_t)0x8b7a, + (q15_t)0x34f2, (q15_t)0x8b77, (q15_t)0x34ec, (q15_t)0x8b75, (q15_t)0x34e6, (q15_t)0x8b72, (q15_t)0x34e0, (q15_t)0x8b6f, + (q15_t)0x34db, (q15_t)0x8b6d, (q15_t)0x34d5, (q15_t)0x8b6a, (q15_t)0x34cf, (q15_t)0x8b68, (q15_t)0x34ca, (q15_t)0x8b65, + (q15_t)0x34c4, (q15_t)0x8b62, (q15_t)0x34be, (q15_t)0x8b60, (q15_t)0x34b8, (q15_t)0x8b5d, (q15_t)0x34b3, (q15_t)0x8b5b, + (q15_t)0x34ad, (q15_t)0x8b58, (q15_t)0x34a7, (q15_t)0x8b55, (q15_t)0x34a1, (q15_t)0x8b53, (q15_t)0x349c, (q15_t)0x8b50, + (q15_t)0x3496, (q15_t)0x8b4e, (q15_t)0x3490, (q15_t)0x8b4b, (q15_t)0x348b, (q15_t)0x8b49, (q15_t)0x3485, (q15_t)0x8b46, + (q15_t)0x347f, (q15_t)0x8b43, (q15_t)0x3479, (q15_t)0x8b41, (q15_t)0x3474, (q15_t)0x8b3e, (q15_t)0x346e, (q15_t)0x8b3c, + (q15_t)0x3468, (q15_t)0x8b39, (q15_t)0x3462, (q15_t)0x8b37, (q15_t)0x345d, (q15_t)0x8b34, (q15_t)0x3457, (q15_t)0x8b31, + (q15_t)0x3451, (q15_t)0x8b2f, (q15_t)0x344b, (q15_t)0x8b2c, (q15_t)0x3446, (q15_t)0x8b2a, (q15_t)0x3440, (q15_t)0x8b27, + (q15_t)0x343a, (q15_t)0x8b25, (q15_t)0x3435, (q15_t)0x8b22, (q15_t)0x342f, (q15_t)0x8b1f, (q15_t)0x3429, (q15_t)0x8b1d, + (q15_t)0x3423, (q15_t)0x8b1a, (q15_t)0x341e, (q15_t)0x8b18, (q15_t)0x3418, (q15_t)0x8b15, (q15_t)0x3412, (q15_t)0x8b13, + (q15_t)0x340c, (q15_t)0x8b10, (q15_t)0x3407, (q15_t)0x8b0e, (q15_t)0x3401, (q15_t)0x8b0b, (q15_t)0x33fb, (q15_t)0x8b08, + (q15_t)0x33f5, (q15_t)0x8b06, (q15_t)0x33f0, (q15_t)0x8b03, (q15_t)0x33ea, (q15_t)0x8b01, (q15_t)0x33e4, (q15_t)0x8afe, + (q15_t)0x33de, (q15_t)0x8afc, (q15_t)0x33d9, (q15_t)0x8af9, (q15_t)0x33d3, (q15_t)0x8af7, (q15_t)0x33cd, (q15_t)0x8af4, + (q15_t)0x33c7, (q15_t)0x8af1, (q15_t)0x33c2, (q15_t)0x8aef, (q15_t)0x33bc, (q15_t)0x8aec, (q15_t)0x33b6, (q15_t)0x8aea, + (q15_t)0x33b0, (q15_t)0x8ae7, (q15_t)0x33ab, (q15_t)0x8ae5, (q15_t)0x33a5, (q15_t)0x8ae2, (q15_t)0x339f, (q15_t)0x8ae0, + (q15_t)0x3399, (q15_t)0x8add, (q15_t)0x3394, (q15_t)0x8adb, (q15_t)0x338e, (q15_t)0x8ad8, (q15_t)0x3388, (q15_t)0x8ad6, + (q15_t)0x3382, (q15_t)0x8ad3, (q15_t)0x337d, (q15_t)0x8ad1, (q15_t)0x3377, (q15_t)0x8ace, (q15_t)0x3371, (q15_t)0x8acb, + (q15_t)0x336b, (q15_t)0x8ac9, (q15_t)0x3366, (q15_t)0x8ac6, (q15_t)0x3360, (q15_t)0x8ac4, (q15_t)0x335a, (q15_t)0x8ac1, + (q15_t)0x3354, (q15_t)0x8abf, (q15_t)0x334f, (q15_t)0x8abc, (q15_t)0x3349, (q15_t)0x8aba, (q15_t)0x3343, (q15_t)0x8ab7, + (q15_t)0x333d, (q15_t)0x8ab5, (q15_t)0x3338, (q15_t)0x8ab2, (q15_t)0x3332, (q15_t)0x8ab0, (q15_t)0x332c, (q15_t)0x8aad, + (q15_t)0x3326, (q15_t)0x8aab, (q15_t)0x3321, (q15_t)0x8aa8, (q15_t)0x331b, (q15_t)0x8aa6, (q15_t)0x3315, (q15_t)0x8aa3, + (q15_t)0x330f, (q15_t)0x8aa1, (q15_t)0x330a, (q15_t)0x8a9e, (q15_t)0x3304, (q15_t)0x8a9c, (q15_t)0x32fe, (q15_t)0x8a99, + (q15_t)0x32f8, (q15_t)0x8a97, (q15_t)0x32f3, (q15_t)0x8a94, (q15_t)0x32ed, (q15_t)0x8a92, (q15_t)0x32e7, (q15_t)0x8a8f, + (q15_t)0x32e1, (q15_t)0x8a8d, (q15_t)0x32db, (q15_t)0x8a8a, (q15_t)0x32d6, (q15_t)0x8a88, (q15_t)0x32d0, (q15_t)0x8a85, + (q15_t)0x32ca, (q15_t)0x8a83, (q15_t)0x32c4, (q15_t)0x8a80, (q15_t)0x32bf, (q15_t)0x8a7e, (q15_t)0x32b9, (q15_t)0x8a7b, + (q15_t)0x32b3, (q15_t)0x8a79, (q15_t)0x32ad, (q15_t)0x8a76, (q15_t)0x32a8, (q15_t)0x8a74, (q15_t)0x32a2, (q15_t)0x8a71, + (q15_t)0x329c, (q15_t)0x8a6f, (q15_t)0x3296, (q15_t)0x8a6c, (q15_t)0x3290, (q15_t)0x8a6a, (q15_t)0x328b, (q15_t)0x8a67, + (q15_t)0x3285, (q15_t)0x8a65, (q15_t)0x327f, (q15_t)0x8a62, (q15_t)0x3279, (q15_t)0x8a60, (q15_t)0x3274, (q15_t)0x8a5d, + (q15_t)0x326e, (q15_t)0x8a5b, (q15_t)0x3268, (q15_t)0x8a59, (q15_t)0x3262, (q15_t)0x8a56, (q15_t)0x325d, (q15_t)0x8a54, + (q15_t)0x3257, (q15_t)0x8a51, (q15_t)0x3251, (q15_t)0x8a4f, (q15_t)0x324b, (q15_t)0x8a4c, (q15_t)0x3245, (q15_t)0x8a4a, + (q15_t)0x3240, (q15_t)0x8a47, (q15_t)0x323a, (q15_t)0x8a45, (q15_t)0x3234, (q15_t)0x8a42, (q15_t)0x322e, (q15_t)0x8a40, + (q15_t)0x3228, (q15_t)0x8a3d, (q15_t)0x3223, (q15_t)0x8a3b, (q15_t)0x321d, (q15_t)0x8a38, (q15_t)0x3217, (q15_t)0x8a36, + (q15_t)0x3211, (q15_t)0x8a34, (q15_t)0x320c, (q15_t)0x8a31, (q15_t)0x3206, (q15_t)0x8a2f, (q15_t)0x3200, (q15_t)0x8a2c, + (q15_t)0x31fa, (q15_t)0x8a2a, (q15_t)0x31f4, (q15_t)0x8a27, (q15_t)0x31ef, (q15_t)0x8a25, (q15_t)0x31e9, (q15_t)0x8a22, + (q15_t)0x31e3, (q15_t)0x8a20, (q15_t)0x31dd, (q15_t)0x8a1d, (q15_t)0x31d8, (q15_t)0x8a1b, (q15_t)0x31d2, (q15_t)0x8a19, + (q15_t)0x31cc, (q15_t)0x8a16, (q15_t)0x31c6, (q15_t)0x8a14, (q15_t)0x31c0, (q15_t)0x8a11, (q15_t)0x31bb, (q15_t)0x8a0f, + (q15_t)0x31b5, (q15_t)0x8a0c, (q15_t)0x31af, (q15_t)0x8a0a, (q15_t)0x31a9, (q15_t)0x8a07, (q15_t)0x31a3, (q15_t)0x8a05, + (q15_t)0x319e, (q15_t)0x8a03, (q15_t)0x3198, (q15_t)0x8a00, (q15_t)0x3192, (q15_t)0x89fe, (q15_t)0x318c, (q15_t)0x89fb, + (q15_t)0x3186, (q15_t)0x89f9, (q15_t)0x3181, (q15_t)0x89f6, (q15_t)0x317b, (q15_t)0x89f4, (q15_t)0x3175, (q15_t)0x89f2, + (q15_t)0x316f, (q15_t)0x89ef, (q15_t)0x3169, (q15_t)0x89ed, (q15_t)0x3164, (q15_t)0x89ea, (q15_t)0x315e, (q15_t)0x89e8, + (q15_t)0x3158, (q15_t)0x89e5, (q15_t)0x3152, (q15_t)0x89e3, (q15_t)0x314c, (q15_t)0x89e1, (q15_t)0x3147, (q15_t)0x89de, + (q15_t)0x3141, (q15_t)0x89dc, (q15_t)0x313b, (q15_t)0x89d9, (q15_t)0x3135, (q15_t)0x89d7, (q15_t)0x312f, (q15_t)0x89d5, + (q15_t)0x312a, (q15_t)0x89d2, (q15_t)0x3124, (q15_t)0x89d0, (q15_t)0x311e, (q15_t)0x89cd, (q15_t)0x3118, (q15_t)0x89cb, + (q15_t)0x3112, (q15_t)0x89c8, (q15_t)0x310d, (q15_t)0x89c6, (q15_t)0x3107, (q15_t)0x89c4, (q15_t)0x3101, (q15_t)0x89c1, + (q15_t)0x30fb, (q15_t)0x89bf, (q15_t)0x30f5, (q15_t)0x89bc, (q15_t)0x30f0, (q15_t)0x89ba, (q15_t)0x30ea, (q15_t)0x89b8, + (q15_t)0x30e4, (q15_t)0x89b5, (q15_t)0x30de, (q15_t)0x89b3, (q15_t)0x30d8, (q15_t)0x89b0, (q15_t)0x30d3, (q15_t)0x89ae, + (q15_t)0x30cd, (q15_t)0x89ac, (q15_t)0x30c7, (q15_t)0x89a9, (q15_t)0x30c1, (q15_t)0x89a7, (q15_t)0x30bb, (q15_t)0x89a4, + (q15_t)0x30b6, (q15_t)0x89a2, (q15_t)0x30b0, (q15_t)0x89a0, (q15_t)0x30aa, (q15_t)0x899d, (q15_t)0x30a4, (q15_t)0x899b, + (q15_t)0x309e, (q15_t)0x8998, (q15_t)0x3099, (q15_t)0x8996, (q15_t)0x3093, (q15_t)0x8994, (q15_t)0x308d, (q15_t)0x8991, + (q15_t)0x3087, (q15_t)0x898f, (q15_t)0x3081, (q15_t)0x898d, (q15_t)0x307b, (q15_t)0x898a, (q15_t)0x3076, (q15_t)0x8988, + (q15_t)0x3070, (q15_t)0x8985, (q15_t)0x306a, (q15_t)0x8983, (q15_t)0x3064, (q15_t)0x8981, (q15_t)0x305e, (q15_t)0x897e, + (q15_t)0x3059, (q15_t)0x897c, (q15_t)0x3053, (q15_t)0x897a, (q15_t)0x304d, (q15_t)0x8977, (q15_t)0x3047, (q15_t)0x8975, + (q15_t)0x3041, (q15_t)0x8972, (q15_t)0x303b, (q15_t)0x8970, (q15_t)0x3036, (q15_t)0x896e, (q15_t)0x3030, (q15_t)0x896b, + (q15_t)0x302a, (q15_t)0x8969, (q15_t)0x3024, (q15_t)0x8967, (q15_t)0x301e, (q15_t)0x8964, (q15_t)0x3019, (q15_t)0x8962, + (q15_t)0x3013, (q15_t)0x8960, (q15_t)0x300d, (q15_t)0x895d, (q15_t)0x3007, (q15_t)0x895b, (q15_t)0x3001, (q15_t)0x8958, + (q15_t)0x2ffb, (q15_t)0x8956, (q15_t)0x2ff6, (q15_t)0x8954, (q15_t)0x2ff0, (q15_t)0x8951, (q15_t)0x2fea, (q15_t)0x894f, + (q15_t)0x2fe4, (q15_t)0x894d, (q15_t)0x2fde, (q15_t)0x894a, (q15_t)0x2fd8, (q15_t)0x8948, (q15_t)0x2fd3, (q15_t)0x8946, + (q15_t)0x2fcd, (q15_t)0x8943, (q15_t)0x2fc7, (q15_t)0x8941, (q15_t)0x2fc1, (q15_t)0x893f, (q15_t)0x2fbb, (q15_t)0x893c, + (q15_t)0x2fb5, (q15_t)0x893a, (q15_t)0x2fb0, (q15_t)0x8938, (q15_t)0x2faa, (q15_t)0x8935, (q15_t)0x2fa4, (q15_t)0x8933, + (q15_t)0x2f9e, (q15_t)0x8931, (q15_t)0x2f98, (q15_t)0x892e, (q15_t)0x2f92, (q15_t)0x892c, (q15_t)0x2f8d, (q15_t)0x892a, + (q15_t)0x2f87, (q15_t)0x8927, (q15_t)0x2f81, (q15_t)0x8925, (q15_t)0x2f7b, (q15_t)0x8923, (q15_t)0x2f75, (q15_t)0x8920, + (q15_t)0x2f6f, (q15_t)0x891e, (q15_t)0x2f6a, (q15_t)0x891c, (q15_t)0x2f64, (q15_t)0x8919, (q15_t)0x2f5e, (q15_t)0x8917, + (q15_t)0x2f58, (q15_t)0x8915, (q15_t)0x2f52, (q15_t)0x8912, (q15_t)0x2f4c, (q15_t)0x8910, (q15_t)0x2f47, (q15_t)0x890e, + (q15_t)0x2f41, (q15_t)0x890b, (q15_t)0x2f3b, (q15_t)0x8909, (q15_t)0x2f35, (q15_t)0x8907, (q15_t)0x2f2f, (q15_t)0x8904, + (q15_t)0x2f29, (q15_t)0x8902, (q15_t)0x2f24, (q15_t)0x8900, (q15_t)0x2f1e, (q15_t)0x88fd, (q15_t)0x2f18, (q15_t)0x88fb, + (q15_t)0x2f12, (q15_t)0x88f9, (q15_t)0x2f0c, (q15_t)0x88f6, (q15_t)0x2f06, (q15_t)0x88f4, (q15_t)0x2f01, (q15_t)0x88f2, + (q15_t)0x2efb, (q15_t)0x88f0, (q15_t)0x2ef5, (q15_t)0x88ed, (q15_t)0x2eef, (q15_t)0x88eb, (q15_t)0x2ee9, (q15_t)0x88e9, + (q15_t)0x2ee3, (q15_t)0x88e6, (q15_t)0x2edd, (q15_t)0x88e4, (q15_t)0x2ed8, (q15_t)0x88e2, (q15_t)0x2ed2, (q15_t)0x88df, + (q15_t)0x2ecc, (q15_t)0x88dd, (q15_t)0x2ec6, (q15_t)0x88db, (q15_t)0x2ec0, (q15_t)0x88d9, (q15_t)0x2eba, (q15_t)0x88d6, + (q15_t)0x2eb5, (q15_t)0x88d4, (q15_t)0x2eaf, (q15_t)0x88d2, (q15_t)0x2ea9, (q15_t)0x88cf, (q15_t)0x2ea3, (q15_t)0x88cd, + (q15_t)0x2e9d, (q15_t)0x88cb, (q15_t)0x2e97, (q15_t)0x88c8, (q15_t)0x2e91, (q15_t)0x88c6, (q15_t)0x2e8c, (q15_t)0x88c4, + (q15_t)0x2e86, (q15_t)0x88c2, (q15_t)0x2e80, (q15_t)0x88bf, (q15_t)0x2e7a, (q15_t)0x88bd, (q15_t)0x2e74, (q15_t)0x88bb, + (q15_t)0x2e6e, (q15_t)0x88b9, (q15_t)0x2e68, (q15_t)0x88b6, (q15_t)0x2e63, (q15_t)0x88b4, (q15_t)0x2e5d, (q15_t)0x88b2, + (q15_t)0x2e57, (q15_t)0x88af, (q15_t)0x2e51, (q15_t)0x88ad, (q15_t)0x2e4b, (q15_t)0x88ab, (q15_t)0x2e45, (q15_t)0x88a9, + (q15_t)0x2e3f, (q15_t)0x88a6, (q15_t)0x2e3a, (q15_t)0x88a4, (q15_t)0x2e34, (q15_t)0x88a2, (q15_t)0x2e2e, (q15_t)0x88a0, + (q15_t)0x2e28, (q15_t)0x889d, (q15_t)0x2e22, (q15_t)0x889b, (q15_t)0x2e1c, (q15_t)0x8899, (q15_t)0x2e16, (q15_t)0x8896, + (q15_t)0x2e11, (q15_t)0x8894, (q15_t)0x2e0b, (q15_t)0x8892, (q15_t)0x2e05, (q15_t)0x8890, (q15_t)0x2dff, (q15_t)0x888d, + (q15_t)0x2df9, (q15_t)0x888b, (q15_t)0x2df3, (q15_t)0x8889, (q15_t)0x2ded, (q15_t)0x8887, (q15_t)0x2de7, (q15_t)0x8884, + (q15_t)0x2de2, (q15_t)0x8882, (q15_t)0x2ddc, (q15_t)0x8880, (q15_t)0x2dd6, (q15_t)0x887e, (q15_t)0x2dd0, (q15_t)0x887b, + (q15_t)0x2dca, (q15_t)0x8879, (q15_t)0x2dc4, (q15_t)0x8877, (q15_t)0x2dbe, (q15_t)0x8875, (q15_t)0x2db9, (q15_t)0x8872, + (q15_t)0x2db3, (q15_t)0x8870, (q15_t)0x2dad, (q15_t)0x886e, (q15_t)0x2da7, (q15_t)0x886c, (q15_t)0x2da1, (q15_t)0x8869, + (q15_t)0x2d9b, (q15_t)0x8867, (q15_t)0x2d95, (q15_t)0x8865, (q15_t)0x2d8f, (q15_t)0x8863, (q15_t)0x2d8a, (q15_t)0x8860, + (q15_t)0x2d84, (q15_t)0x885e, (q15_t)0x2d7e, (q15_t)0x885c, (q15_t)0x2d78, (q15_t)0x885a, (q15_t)0x2d72, (q15_t)0x8858, + (q15_t)0x2d6c, (q15_t)0x8855, (q15_t)0x2d66, (q15_t)0x8853, (q15_t)0x2d60, (q15_t)0x8851, (q15_t)0x2d5b, (q15_t)0x884f, + (q15_t)0x2d55, (q15_t)0x884c, (q15_t)0x2d4f, (q15_t)0x884a, (q15_t)0x2d49, (q15_t)0x8848, (q15_t)0x2d43, (q15_t)0x8846, + (q15_t)0x2d3d, (q15_t)0x8844, (q15_t)0x2d37, (q15_t)0x8841, (q15_t)0x2d31, (q15_t)0x883f, (q15_t)0x2d2c, (q15_t)0x883d, + (q15_t)0x2d26, (q15_t)0x883b, (q15_t)0x2d20, (q15_t)0x8838, (q15_t)0x2d1a, (q15_t)0x8836, (q15_t)0x2d14, (q15_t)0x8834, + (q15_t)0x2d0e, (q15_t)0x8832, (q15_t)0x2d08, (q15_t)0x8830, (q15_t)0x2d02, (q15_t)0x882d, (q15_t)0x2cfd, (q15_t)0x882b, + (q15_t)0x2cf7, (q15_t)0x8829, (q15_t)0x2cf1, (q15_t)0x8827, (q15_t)0x2ceb, (q15_t)0x8825, (q15_t)0x2ce5, (q15_t)0x8822, + (q15_t)0x2cdf, (q15_t)0x8820, (q15_t)0x2cd9, (q15_t)0x881e, (q15_t)0x2cd3, (q15_t)0x881c, (q15_t)0x2ccd, (q15_t)0x881a, + (q15_t)0x2cc8, (q15_t)0x8817, (q15_t)0x2cc2, (q15_t)0x8815, (q15_t)0x2cbc, (q15_t)0x8813, (q15_t)0x2cb6, (q15_t)0x8811, + (q15_t)0x2cb0, (q15_t)0x880f, (q15_t)0x2caa, (q15_t)0x880c, (q15_t)0x2ca4, (q15_t)0x880a, (q15_t)0x2c9e, (q15_t)0x8808, + (q15_t)0x2c98, (q15_t)0x8806, (q15_t)0x2c93, (q15_t)0x8804, (q15_t)0x2c8d, (q15_t)0x8801, (q15_t)0x2c87, (q15_t)0x87ff, + (q15_t)0x2c81, (q15_t)0x87fd, (q15_t)0x2c7b, (q15_t)0x87fb, (q15_t)0x2c75, (q15_t)0x87f9, (q15_t)0x2c6f, (q15_t)0x87f6, + (q15_t)0x2c69, (q15_t)0x87f4, (q15_t)0x2c63, (q15_t)0x87f2, (q15_t)0x2c5e, (q15_t)0x87f0, (q15_t)0x2c58, (q15_t)0x87ee, + (q15_t)0x2c52, (q15_t)0x87ec, (q15_t)0x2c4c, (q15_t)0x87e9, (q15_t)0x2c46, (q15_t)0x87e7, (q15_t)0x2c40, (q15_t)0x87e5, + (q15_t)0x2c3a, (q15_t)0x87e3, (q15_t)0x2c34, (q15_t)0x87e1, (q15_t)0x2c2e, (q15_t)0x87df, (q15_t)0x2c29, (q15_t)0x87dc, + (q15_t)0x2c23, (q15_t)0x87da, (q15_t)0x2c1d, (q15_t)0x87d8, (q15_t)0x2c17, (q15_t)0x87d6, (q15_t)0x2c11, (q15_t)0x87d4, + (q15_t)0x2c0b, (q15_t)0x87d2, (q15_t)0x2c05, (q15_t)0x87cf, (q15_t)0x2bff, (q15_t)0x87cd, (q15_t)0x2bf9, (q15_t)0x87cb, + (q15_t)0x2bf3, (q15_t)0x87c9, (q15_t)0x2bee, (q15_t)0x87c7, (q15_t)0x2be8, (q15_t)0x87c5, (q15_t)0x2be2, (q15_t)0x87c2, + (q15_t)0x2bdc, (q15_t)0x87c0, (q15_t)0x2bd6, (q15_t)0x87be, (q15_t)0x2bd0, (q15_t)0x87bc, (q15_t)0x2bca, (q15_t)0x87ba, + (q15_t)0x2bc4, (q15_t)0x87b8, (q15_t)0x2bbe, (q15_t)0x87b6, (q15_t)0x2bb8, (q15_t)0x87b3, (q15_t)0x2bb2, (q15_t)0x87b1, + (q15_t)0x2bad, (q15_t)0x87af, (q15_t)0x2ba7, (q15_t)0x87ad, (q15_t)0x2ba1, (q15_t)0x87ab, (q15_t)0x2b9b, (q15_t)0x87a9, + (q15_t)0x2b95, (q15_t)0x87a7, (q15_t)0x2b8f, (q15_t)0x87a4, (q15_t)0x2b89, (q15_t)0x87a2, (q15_t)0x2b83, (q15_t)0x87a0, + (q15_t)0x2b7d, (q15_t)0x879e, (q15_t)0x2b77, (q15_t)0x879c, (q15_t)0x2b71, (q15_t)0x879a, (q15_t)0x2b6c, (q15_t)0x8798, + (q15_t)0x2b66, (q15_t)0x8795, (q15_t)0x2b60, (q15_t)0x8793, (q15_t)0x2b5a, (q15_t)0x8791, (q15_t)0x2b54, (q15_t)0x878f, + (q15_t)0x2b4e, (q15_t)0x878d, (q15_t)0x2b48, (q15_t)0x878b, (q15_t)0x2b42, (q15_t)0x8789, (q15_t)0x2b3c, (q15_t)0x8787, + (q15_t)0x2b36, (q15_t)0x8784, (q15_t)0x2b30, (q15_t)0x8782, (q15_t)0x2b2b, (q15_t)0x8780, (q15_t)0x2b25, (q15_t)0x877e, + (q15_t)0x2b1f, (q15_t)0x877c, (q15_t)0x2b19, (q15_t)0x877a, (q15_t)0x2b13, (q15_t)0x8778, (q15_t)0x2b0d, (q15_t)0x8776, + (q15_t)0x2b07, (q15_t)0x8774, (q15_t)0x2b01, (q15_t)0x8771, (q15_t)0x2afb, (q15_t)0x876f, (q15_t)0x2af5, (q15_t)0x876d, + (q15_t)0x2aef, (q15_t)0x876b, (q15_t)0x2ae9, (q15_t)0x8769, (q15_t)0x2ae4, (q15_t)0x8767, (q15_t)0x2ade, (q15_t)0x8765, + (q15_t)0x2ad8, (q15_t)0x8763, (q15_t)0x2ad2, (q15_t)0x8761, (q15_t)0x2acc, (q15_t)0x875e, (q15_t)0x2ac6, (q15_t)0x875c, + (q15_t)0x2ac0, (q15_t)0x875a, (q15_t)0x2aba, (q15_t)0x8758, (q15_t)0x2ab4, (q15_t)0x8756, (q15_t)0x2aae, (q15_t)0x8754, + (q15_t)0x2aa8, (q15_t)0x8752, (q15_t)0x2aa2, (q15_t)0x8750, (q15_t)0x2a9c, (q15_t)0x874e, (q15_t)0x2a97, (q15_t)0x874c, + (q15_t)0x2a91, (q15_t)0x874a, (q15_t)0x2a8b, (q15_t)0x8747, (q15_t)0x2a85, (q15_t)0x8745, (q15_t)0x2a7f, (q15_t)0x8743, + (q15_t)0x2a79, (q15_t)0x8741, (q15_t)0x2a73, (q15_t)0x873f, (q15_t)0x2a6d, (q15_t)0x873d, (q15_t)0x2a67, (q15_t)0x873b, + (q15_t)0x2a61, (q15_t)0x8739, (q15_t)0x2a5b, (q15_t)0x8737, (q15_t)0x2a55, (q15_t)0x8735, (q15_t)0x2a4f, (q15_t)0x8733, + (q15_t)0x2a49, (q15_t)0x8731, (q15_t)0x2a44, (q15_t)0x872e, (q15_t)0x2a3e, (q15_t)0x872c, (q15_t)0x2a38, (q15_t)0x872a, + (q15_t)0x2a32, (q15_t)0x8728, (q15_t)0x2a2c, (q15_t)0x8726, (q15_t)0x2a26, (q15_t)0x8724, (q15_t)0x2a20, (q15_t)0x8722, + (q15_t)0x2a1a, (q15_t)0x8720, (q15_t)0x2a14, (q15_t)0x871e, (q15_t)0x2a0e, (q15_t)0x871c, (q15_t)0x2a08, (q15_t)0x871a, + (q15_t)0x2a02, (q15_t)0x8718, (q15_t)0x29fc, (q15_t)0x8716, (q15_t)0x29f6, (q15_t)0x8714, (q15_t)0x29f0, (q15_t)0x8712, + (q15_t)0x29eb, (q15_t)0x870f, (q15_t)0x29e5, (q15_t)0x870d, (q15_t)0x29df, (q15_t)0x870b, (q15_t)0x29d9, (q15_t)0x8709, + (q15_t)0x29d3, (q15_t)0x8707, (q15_t)0x29cd, (q15_t)0x8705, (q15_t)0x29c7, (q15_t)0x8703, (q15_t)0x29c1, (q15_t)0x8701, + (q15_t)0x29bb, (q15_t)0x86ff, (q15_t)0x29b5, (q15_t)0x86fd, (q15_t)0x29af, (q15_t)0x86fb, (q15_t)0x29a9, (q15_t)0x86f9, + (q15_t)0x29a3, (q15_t)0x86f7, (q15_t)0x299d, (q15_t)0x86f5, (q15_t)0x2997, (q15_t)0x86f3, (q15_t)0x2991, (q15_t)0x86f1, + (q15_t)0x298b, (q15_t)0x86ef, (q15_t)0x2986, (q15_t)0x86ed, (q15_t)0x2980, (q15_t)0x86eb, (q15_t)0x297a, (q15_t)0x86e9, + (q15_t)0x2974, (q15_t)0x86e7, (q15_t)0x296e, (q15_t)0x86e4, (q15_t)0x2968, (q15_t)0x86e2, (q15_t)0x2962, (q15_t)0x86e0, + (q15_t)0x295c, (q15_t)0x86de, (q15_t)0x2956, (q15_t)0x86dc, (q15_t)0x2950, (q15_t)0x86da, (q15_t)0x294a, (q15_t)0x86d8, + (q15_t)0x2944, (q15_t)0x86d6, (q15_t)0x293e, (q15_t)0x86d4, (q15_t)0x2938, (q15_t)0x86d2, (q15_t)0x2932, (q15_t)0x86d0, + (q15_t)0x292c, (q15_t)0x86ce, (q15_t)0x2926, (q15_t)0x86cc, (q15_t)0x2920, (q15_t)0x86ca, (q15_t)0x291b, (q15_t)0x86c8, + (q15_t)0x2915, (q15_t)0x86c6, (q15_t)0x290f, (q15_t)0x86c4, (q15_t)0x2909, (q15_t)0x86c2, (q15_t)0x2903, (q15_t)0x86c0, + (q15_t)0x28fd, (q15_t)0x86be, (q15_t)0x28f7, (q15_t)0x86bc, (q15_t)0x28f1, (q15_t)0x86ba, (q15_t)0x28eb, (q15_t)0x86b8, + (q15_t)0x28e5, (q15_t)0x86b6, (q15_t)0x28df, (q15_t)0x86b4, (q15_t)0x28d9, (q15_t)0x86b2, (q15_t)0x28d3, (q15_t)0x86b0, + (q15_t)0x28cd, (q15_t)0x86ae, (q15_t)0x28c7, (q15_t)0x86ac, (q15_t)0x28c1, (q15_t)0x86aa, (q15_t)0x28bb, (q15_t)0x86a8, + (q15_t)0x28b5, (q15_t)0x86a6, (q15_t)0x28af, (q15_t)0x86a4, (q15_t)0x28a9, (q15_t)0x86a2, (q15_t)0x28a3, (q15_t)0x86a0, + (q15_t)0x289d, (q15_t)0x869e, (q15_t)0x2898, (q15_t)0x869c, (q15_t)0x2892, (q15_t)0x869a, (q15_t)0x288c, (q15_t)0x8698, + (q15_t)0x2886, (q15_t)0x8696, (q15_t)0x2880, (q15_t)0x8694, (q15_t)0x287a, (q15_t)0x8692, (q15_t)0x2874, (q15_t)0x8690, + (q15_t)0x286e, (q15_t)0x868e, (q15_t)0x2868, (q15_t)0x868c, (q15_t)0x2862, (q15_t)0x868a, (q15_t)0x285c, (q15_t)0x8688, + (q15_t)0x2856, (q15_t)0x8686, (q15_t)0x2850, (q15_t)0x8684, (q15_t)0x284a, (q15_t)0x8682, (q15_t)0x2844, (q15_t)0x8680, + (q15_t)0x283e, (q15_t)0x867e, (q15_t)0x2838, (q15_t)0x867c, (q15_t)0x2832, (q15_t)0x867a, (q15_t)0x282c, (q15_t)0x8678, + (q15_t)0x2826, (q15_t)0x8676, (q15_t)0x2820, (q15_t)0x8674, (q15_t)0x281a, (q15_t)0x8672, (q15_t)0x2814, (q15_t)0x8670, + (q15_t)0x280e, (q15_t)0x866e, (q15_t)0x2808, (q15_t)0x866d, (q15_t)0x2802, (q15_t)0x866b, (q15_t)0x27fc, (q15_t)0x8669, + (q15_t)0x27f6, (q15_t)0x8667, (q15_t)0x27f1, (q15_t)0x8665, (q15_t)0x27eb, (q15_t)0x8663, (q15_t)0x27e5, (q15_t)0x8661, + (q15_t)0x27df, (q15_t)0x865f, (q15_t)0x27d9, (q15_t)0x865d, (q15_t)0x27d3, (q15_t)0x865b, (q15_t)0x27cd, (q15_t)0x8659, + (q15_t)0x27c7, (q15_t)0x8657, (q15_t)0x27c1, (q15_t)0x8655, (q15_t)0x27bb, (q15_t)0x8653, (q15_t)0x27b5, (q15_t)0x8651, + (q15_t)0x27af, (q15_t)0x864f, (q15_t)0x27a9, (q15_t)0x864d, (q15_t)0x27a3, (q15_t)0x864b, (q15_t)0x279d, (q15_t)0x8649, + (q15_t)0x2797, (q15_t)0x8647, (q15_t)0x2791, (q15_t)0x8645, (q15_t)0x278b, (q15_t)0x8644, (q15_t)0x2785, (q15_t)0x8642, + (q15_t)0x277f, (q15_t)0x8640, (q15_t)0x2779, (q15_t)0x863e, (q15_t)0x2773, (q15_t)0x863c, (q15_t)0x276d, (q15_t)0x863a, + (q15_t)0x2767, (q15_t)0x8638, (q15_t)0x2761, (q15_t)0x8636, (q15_t)0x275b, (q15_t)0x8634, (q15_t)0x2755, (q15_t)0x8632, + (q15_t)0x274f, (q15_t)0x8630, (q15_t)0x2749, (q15_t)0x862e, (q15_t)0x2743, (q15_t)0x862c, (q15_t)0x273d, (q15_t)0x862a, + (q15_t)0x2737, (q15_t)0x8628, (q15_t)0x2731, (q15_t)0x8627, (q15_t)0x272b, (q15_t)0x8625, (q15_t)0x2725, (q15_t)0x8623, + (q15_t)0x271f, (q15_t)0x8621, (q15_t)0x2719, (q15_t)0x861f, (q15_t)0x2713, (q15_t)0x861d, (q15_t)0x270d, (q15_t)0x861b, + (q15_t)0x2707, (q15_t)0x8619, (q15_t)0x2701, (q15_t)0x8617, (q15_t)0x26fb, (q15_t)0x8615, (q15_t)0x26f5, (q15_t)0x8613, + (q15_t)0x26ef, (q15_t)0x8611, (q15_t)0x26e9, (q15_t)0x8610, (q15_t)0x26e4, (q15_t)0x860e, (q15_t)0x26de, (q15_t)0x860c, + (q15_t)0x26d8, (q15_t)0x860a, (q15_t)0x26d2, (q15_t)0x8608, (q15_t)0x26cc, (q15_t)0x8606, (q15_t)0x26c6, (q15_t)0x8604, + (q15_t)0x26c0, (q15_t)0x8602, (q15_t)0x26ba, (q15_t)0x8600, (q15_t)0x26b4, (q15_t)0x85fe, (q15_t)0x26ae, (q15_t)0x85fc, + (q15_t)0x26a8, (q15_t)0x85fb, (q15_t)0x26a2, (q15_t)0x85f9, (q15_t)0x269c, (q15_t)0x85f7, (q15_t)0x2696, (q15_t)0x85f5, + (q15_t)0x2690, (q15_t)0x85f3, (q15_t)0x268a, (q15_t)0x85f1, (q15_t)0x2684, (q15_t)0x85ef, (q15_t)0x267e, (q15_t)0x85ed, + (q15_t)0x2678, (q15_t)0x85eb, (q15_t)0x2672, (q15_t)0x85ea, (q15_t)0x266c, (q15_t)0x85e8, (q15_t)0x2666, (q15_t)0x85e6, + (q15_t)0x2660, (q15_t)0x85e4, (q15_t)0x265a, (q15_t)0x85e2, (q15_t)0x2654, (q15_t)0x85e0, (q15_t)0x264e, (q15_t)0x85de, + (q15_t)0x2648, (q15_t)0x85dc, (q15_t)0x2642, (q15_t)0x85da, (q15_t)0x263c, (q15_t)0x85d9, (q15_t)0x2636, (q15_t)0x85d7, + (q15_t)0x2630, (q15_t)0x85d5, (q15_t)0x262a, (q15_t)0x85d3, (q15_t)0x2624, (q15_t)0x85d1, (q15_t)0x261e, (q15_t)0x85cf, + (q15_t)0x2618, (q15_t)0x85cd, (q15_t)0x2612, (q15_t)0x85cb, (q15_t)0x260c, (q15_t)0x85ca, (q15_t)0x2606, (q15_t)0x85c8, + (q15_t)0x2600, (q15_t)0x85c6, (q15_t)0x25fa, (q15_t)0x85c4, (q15_t)0x25f4, (q15_t)0x85c2, (q15_t)0x25ee, (q15_t)0x85c0, + (q15_t)0x25e8, (q15_t)0x85be, (q15_t)0x25e2, (q15_t)0x85bd, (q15_t)0x25dc, (q15_t)0x85bb, (q15_t)0x25d6, (q15_t)0x85b9, + (q15_t)0x25d0, (q15_t)0x85b7, (q15_t)0x25ca, (q15_t)0x85b5, (q15_t)0x25c4, (q15_t)0x85b3, (q15_t)0x25be, (q15_t)0x85b1, + (q15_t)0x25b8, (q15_t)0x85b0, (q15_t)0x25b2, (q15_t)0x85ae, (q15_t)0x25ac, (q15_t)0x85ac, (q15_t)0x25a6, (q15_t)0x85aa, + (q15_t)0x25a0, (q15_t)0x85a8, (q15_t)0x259a, (q15_t)0x85a6, (q15_t)0x2594, (q15_t)0x85a4, (q15_t)0x258e, (q15_t)0x85a3, + (q15_t)0x2588, (q15_t)0x85a1, (q15_t)0x2582, (q15_t)0x859f, (q15_t)0x257c, (q15_t)0x859d, (q15_t)0x2576, (q15_t)0x859b, + (q15_t)0x2570, (q15_t)0x8599, (q15_t)0x256a, (q15_t)0x8598, (q15_t)0x2564, (q15_t)0x8596, (q15_t)0x255e, (q15_t)0x8594, + (q15_t)0x2558, (q15_t)0x8592, (q15_t)0x2552, (q15_t)0x8590, (q15_t)0x254c, (q15_t)0x858e, (q15_t)0x2546, (q15_t)0x858d, + (q15_t)0x2540, (q15_t)0x858b, (q15_t)0x253a, (q15_t)0x8589, (q15_t)0x2534, (q15_t)0x8587, (q15_t)0x252e, (q15_t)0x8585, + (q15_t)0x2528, (q15_t)0x8583, (q15_t)0x2522, (q15_t)0x8582, (q15_t)0x251c, (q15_t)0x8580, (q15_t)0x2516, (q15_t)0x857e, + (q15_t)0x250f, (q15_t)0x857c, (q15_t)0x2509, (q15_t)0x857a, (q15_t)0x2503, (q15_t)0x8579, (q15_t)0x24fd, (q15_t)0x8577, + (q15_t)0x24f7, (q15_t)0x8575, (q15_t)0x24f1, (q15_t)0x8573, (q15_t)0x24eb, (q15_t)0x8571, (q15_t)0x24e5, (q15_t)0x856f, + (q15_t)0x24df, (q15_t)0x856e, (q15_t)0x24d9, (q15_t)0x856c, (q15_t)0x24d3, (q15_t)0x856a, (q15_t)0x24cd, (q15_t)0x8568, + (q15_t)0x24c7, (q15_t)0x8566, (q15_t)0x24c1, (q15_t)0x8565, (q15_t)0x24bb, (q15_t)0x8563, (q15_t)0x24b5, (q15_t)0x8561, + (q15_t)0x24af, (q15_t)0x855f, (q15_t)0x24a9, (q15_t)0x855d, (q15_t)0x24a3, (q15_t)0x855c, (q15_t)0x249d, (q15_t)0x855a, + (q15_t)0x2497, (q15_t)0x8558, (q15_t)0x2491, (q15_t)0x8556, (q15_t)0x248b, (q15_t)0x8554, (q15_t)0x2485, (q15_t)0x8553, + (q15_t)0x247f, (q15_t)0x8551, (q15_t)0x2479, (q15_t)0x854f, (q15_t)0x2473, (q15_t)0x854d, (q15_t)0x246d, (q15_t)0x854b, + (q15_t)0x2467, (q15_t)0x854a, (q15_t)0x2461, (q15_t)0x8548, (q15_t)0x245b, (q15_t)0x8546, (q15_t)0x2455, (q15_t)0x8544, + (q15_t)0x244f, (q15_t)0x8543, (q15_t)0x2449, (q15_t)0x8541, (q15_t)0x2443, (q15_t)0x853f, (q15_t)0x243d, (q15_t)0x853d, + (q15_t)0x2437, (q15_t)0x853b, (q15_t)0x2431, (q15_t)0x853a, (q15_t)0x242b, (q15_t)0x8538, (q15_t)0x2425, (q15_t)0x8536, + (q15_t)0x241f, (q15_t)0x8534, (q15_t)0x2419, (q15_t)0x8533, (q15_t)0x2413, (q15_t)0x8531, (q15_t)0x240d, (q15_t)0x852f, + (q15_t)0x2407, (q15_t)0x852d, (q15_t)0x2401, (q15_t)0x852b, (q15_t)0x23fa, (q15_t)0x852a, (q15_t)0x23f4, (q15_t)0x8528, + (q15_t)0x23ee, (q15_t)0x8526, (q15_t)0x23e8, (q15_t)0x8524, (q15_t)0x23e2, (q15_t)0x8523, (q15_t)0x23dc, (q15_t)0x8521, + (q15_t)0x23d6, (q15_t)0x851f, (q15_t)0x23d0, (q15_t)0x851d, (q15_t)0x23ca, (q15_t)0x851c, (q15_t)0x23c4, (q15_t)0x851a, + (q15_t)0x23be, (q15_t)0x8518, (q15_t)0x23b8, (q15_t)0x8516, (q15_t)0x23b2, (q15_t)0x8515, (q15_t)0x23ac, (q15_t)0x8513, + (q15_t)0x23a6, (q15_t)0x8511, (q15_t)0x23a0, (q15_t)0x850f, (q15_t)0x239a, (q15_t)0x850e, (q15_t)0x2394, (q15_t)0x850c, + (q15_t)0x238e, (q15_t)0x850a, (q15_t)0x2388, (q15_t)0x8508, (q15_t)0x2382, (q15_t)0x8507, (q15_t)0x237c, (q15_t)0x8505, + (q15_t)0x2376, (q15_t)0x8503, (q15_t)0x2370, (q15_t)0x8501, (q15_t)0x236a, (q15_t)0x8500, (q15_t)0x2364, (q15_t)0x84fe, + (q15_t)0x235e, (q15_t)0x84fc, (q15_t)0x2358, (q15_t)0x84fa, (q15_t)0x2352, (q15_t)0x84f9, (q15_t)0x234b, (q15_t)0x84f7, + (q15_t)0x2345, (q15_t)0x84f5, (q15_t)0x233f, (q15_t)0x84f4, (q15_t)0x2339, (q15_t)0x84f2, (q15_t)0x2333, (q15_t)0x84f0, + (q15_t)0x232d, (q15_t)0x84ee, (q15_t)0x2327, (q15_t)0x84ed, (q15_t)0x2321, (q15_t)0x84eb, (q15_t)0x231b, (q15_t)0x84e9, + (q15_t)0x2315, (q15_t)0x84e7, (q15_t)0x230f, (q15_t)0x84e6, (q15_t)0x2309, (q15_t)0x84e4, (q15_t)0x2303, (q15_t)0x84e2, + (q15_t)0x22fd, (q15_t)0x84e1, (q15_t)0x22f7, (q15_t)0x84df, (q15_t)0x22f1, (q15_t)0x84dd, (q15_t)0x22eb, (q15_t)0x84db, + (q15_t)0x22e5, (q15_t)0x84da, (q15_t)0x22df, (q15_t)0x84d8, (q15_t)0x22d9, (q15_t)0x84d6, (q15_t)0x22d3, (q15_t)0x84d5, + (q15_t)0x22cd, (q15_t)0x84d3, (q15_t)0x22c7, (q15_t)0x84d1, (q15_t)0x22c0, (q15_t)0x84cf, (q15_t)0x22ba, (q15_t)0x84ce, + (q15_t)0x22b4, (q15_t)0x84cc, (q15_t)0x22ae, (q15_t)0x84ca, (q15_t)0x22a8, (q15_t)0x84c9, (q15_t)0x22a2, (q15_t)0x84c7, + (q15_t)0x229c, (q15_t)0x84c5, (q15_t)0x2296, (q15_t)0x84c4, (q15_t)0x2290, (q15_t)0x84c2, (q15_t)0x228a, (q15_t)0x84c0, + (q15_t)0x2284, (q15_t)0x84be, (q15_t)0x227e, (q15_t)0x84bd, (q15_t)0x2278, (q15_t)0x84bb, (q15_t)0x2272, (q15_t)0x84b9, + (q15_t)0x226c, (q15_t)0x84b8, (q15_t)0x2266, (q15_t)0x84b6, (q15_t)0x2260, (q15_t)0x84b4, (q15_t)0x225a, (q15_t)0x84b3, + (q15_t)0x2254, (q15_t)0x84b1, (q15_t)0x224e, (q15_t)0x84af, (q15_t)0x2247, (q15_t)0x84ae, (q15_t)0x2241, (q15_t)0x84ac, + (q15_t)0x223b, (q15_t)0x84aa, (q15_t)0x2235, (q15_t)0x84a9, (q15_t)0x222f, (q15_t)0x84a7, (q15_t)0x2229, (q15_t)0x84a5, + (q15_t)0x2223, (q15_t)0x84a3, (q15_t)0x221d, (q15_t)0x84a2, (q15_t)0x2217, (q15_t)0x84a0, (q15_t)0x2211, (q15_t)0x849e, + (q15_t)0x220b, (q15_t)0x849d, (q15_t)0x2205, (q15_t)0x849b, (q15_t)0x21ff, (q15_t)0x8499, (q15_t)0x21f9, (q15_t)0x8498, + (q15_t)0x21f3, (q15_t)0x8496, (q15_t)0x21ed, (q15_t)0x8494, (q15_t)0x21e7, (q15_t)0x8493, (q15_t)0x21e1, (q15_t)0x8491, + (q15_t)0x21da, (q15_t)0x848f, (q15_t)0x21d4, (q15_t)0x848e, (q15_t)0x21ce, (q15_t)0x848c, (q15_t)0x21c8, (q15_t)0x848a, + (q15_t)0x21c2, (q15_t)0x8489, (q15_t)0x21bc, (q15_t)0x8487, (q15_t)0x21b6, (q15_t)0x8486, (q15_t)0x21b0, (q15_t)0x8484, + (q15_t)0x21aa, (q15_t)0x8482, (q15_t)0x21a4, (q15_t)0x8481, (q15_t)0x219e, (q15_t)0x847f, (q15_t)0x2198, (q15_t)0x847d, + (q15_t)0x2192, (q15_t)0x847c, (q15_t)0x218c, (q15_t)0x847a, (q15_t)0x2186, (q15_t)0x8478, (q15_t)0x2180, (q15_t)0x8477, + (q15_t)0x2179, (q15_t)0x8475, (q15_t)0x2173, (q15_t)0x8473, (q15_t)0x216d, (q15_t)0x8472, (q15_t)0x2167, (q15_t)0x8470, + (q15_t)0x2161, (q15_t)0x846e, (q15_t)0x215b, (q15_t)0x846d, (q15_t)0x2155, (q15_t)0x846b, (q15_t)0x214f, (q15_t)0x846a, + (q15_t)0x2149, (q15_t)0x8468, (q15_t)0x2143, (q15_t)0x8466, (q15_t)0x213d, (q15_t)0x8465, (q15_t)0x2137, (q15_t)0x8463, + (q15_t)0x2131, (q15_t)0x8461, (q15_t)0x212b, (q15_t)0x8460, (q15_t)0x2125, (q15_t)0x845e, (q15_t)0x211e, (q15_t)0x845d, + (q15_t)0x2118, (q15_t)0x845b, (q15_t)0x2112, (q15_t)0x8459, (q15_t)0x210c, (q15_t)0x8458, (q15_t)0x2106, (q15_t)0x8456, + (q15_t)0x2100, (q15_t)0x8454, (q15_t)0x20fa, (q15_t)0x8453, (q15_t)0x20f4, (q15_t)0x8451, (q15_t)0x20ee, (q15_t)0x8450, + (q15_t)0x20e8, (q15_t)0x844e, (q15_t)0x20e2, (q15_t)0x844c, (q15_t)0x20dc, (q15_t)0x844b, (q15_t)0x20d6, (q15_t)0x8449, + (q15_t)0x20d0, (q15_t)0x8447, (q15_t)0x20c9, (q15_t)0x8446, (q15_t)0x20c3, (q15_t)0x8444, (q15_t)0x20bd, (q15_t)0x8443, + (q15_t)0x20b7, (q15_t)0x8441, (q15_t)0x20b1, (q15_t)0x843f, (q15_t)0x20ab, (q15_t)0x843e, (q15_t)0x20a5, (q15_t)0x843c, + (q15_t)0x209f, (q15_t)0x843b, (q15_t)0x2099, (q15_t)0x8439, (q15_t)0x2093, (q15_t)0x8437, (q15_t)0x208d, (q15_t)0x8436, + (q15_t)0x2087, (q15_t)0x8434, (q15_t)0x2081, (q15_t)0x8433, (q15_t)0x207a, (q15_t)0x8431, (q15_t)0x2074, (q15_t)0x842f, + (q15_t)0x206e, (q15_t)0x842e, (q15_t)0x2068, (q15_t)0x842c, (q15_t)0x2062, (q15_t)0x842b, (q15_t)0x205c, (q15_t)0x8429, + (q15_t)0x2056, (q15_t)0x8427, (q15_t)0x2050, (q15_t)0x8426, (q15_t)0x204a, (q15_t)0x8424, (q15_t)0x2044, (q15_t)0x8423, + (q15_t)0x203e, (q15_t)0x8421, (q15_t)0x2038, (q15_t)0x8420, (q15_t)0x2032, (q15_t)0x841e, (q15_t)0x202b, (q15_t)0x841c, + (q15_t)0x2025, (q15_t)0x841b, (q15_t)0x201f, (q15_t)0x8419, (q15_t)0x2019, (q15_t)0x8418, (q15_t)0x2013, (q15_t)0x8416, + (q15_t)0x200d, (q15_t)0x8415, (q15_t)0x2007, (q15_t)0x8413, (q15_t)0x2001, (q15_t)0x8411, (q15_t)0x1ffb, (q15_t)0x8410, + (q15_t)0x1ff5, (q15_t)0x840e, (q15_t)0x1fef, (q15_t)0x840d, (q15_t)0x1fe9, (q15_t)0x840b, (q15_t)0x1fe2, (q15_t)0x840a, + (q15_t)0x1fdc, (q15_t)0x8408, (q15_t)0x1fd6, (q15_t)0x8406, (q15_t)0x1fd0, (q15_t)0x8405, (q15_t)0x1fca, (q15_t)0x8403, + (q15_t)0x1fc4, (q15_t)0x8402, (q15_t)0x1fbe, (q15_t)0x8400, (q15_t)0x1fb8, (q15_t)0x83ff, (q15_t)0x1fb2, (q15_t)0x83fd, + (q15_t)0x1fac, (q15_t)0x83fb, (q15_t)0x1fa6, (q15_t)0x83fa, (q15_t)0x1f9f, (q15_t)0x83f8, (q15_t)0x1f99, (q15_t)0x83f7, + (q15_t)0x1f93, (q15_t)0x83f5, (q15_t)0x1f8d, (q15_t)0x83f4, (q15_t)0x1f87, (q15_t)0x83f2, (q15_t)0x1f81, (q15_t)0x83f1, + (q15_t)0x1f7b, (q15_t)0x83ef, (q15_t)0x1f75, (q15_t)0x83ee, (q15_t)0x1f6f, (q15_t)0x83ec, (q15_t)0x1f69, (q15_t)0x83ea, + (q15_t)0x1f63, (q15_t)0x83e9, (q15_t)0x1f5d, (q15_t)0x83e7, (q15_t)0x1f56, (q15_t)0x83e6, (q15_t)0x1f50, (q15_t)0x83e4, + (q15_t)0x1f4a, (q15_t)0x83e3, (q15_t)0x1f44, (q15_t)0x83e1, (q15_t)0x1f3e, (q15_t)0x83e0, (q15_t)0x1f38, (q15_t)0x83de, + (q15_t)0x1f32, (q15_t)0x83dd, (q15_t)0x1f2c, (q15_t)0x83db, (q15_t)0x1f26, (q15_t)0x83da, (q15_t)0x1f20, (q15_t)0x83d8, + (q15_t)0x1f19, (q15_t)0x83d7, (q15_t)0x1f13, (q15_t)0x83d5, (q15_t)0x1f0d, (q15_t)0x83d3, (q15_t)0x1f07, (q15_t)0x83d2, + (q15_t)0x1f01, (q15_t)0x83d0, (q15_t)0x1efb, (q15_t)0x83cf, (q15_t)0x1ef5, (q15_t)0x83cd, (q15_t)0x1eef, (q15_t)0x83cc, + (q15_t)0x1ee9, (q15_t)0x83ca, (q15_t)0x1ee3, (q15_t)0x83c9, (q15_t)0x1edd, (q15_t)0x83c7, (q15_t)0x1ed6, (q15_t)0x83c6, + (q15_t)0x1ed0, (q15_t)0x83c4, (q15_t)0x1eca, (q15_t)0x83c3, (q15_t)0x1ec4, (q15_t)0x83c1, (q15_t)0x1ebe, (q15_t)0x83c0, + (q15_t)0x1eb8, (q15_t)0x83be, (q15_t)0x1eb2, (q15_t)0x83bd, (q15_t)0x1eac, (q15_t)0x83bb, (q15_t)0x1ea6, (q15_t)0x83ba, + (q15_t)0x1ea0, (q15_t)0x83b8, (q15_t)0x1e99, (q15_t)0x83b7, (q15_t)0x1e93, (q15_t)0x83b5, (q15_t)0x1e8d, (q15_t)0x83b4, + (q15_t)0x1e87, (q15_t)0x83b2, (q15_t)0x1e81, (q15_t)0x83b1, (q15_t)0x1e7b, (q15_t)0x83af, (q15_t)0x1e75, (q15_t)0x83ae, + (q15_t)0x1e6f, (q15_t)0x83ac, (q15_t)0x1e69, (q15_t)0x83ab, (q15_t)0x1e62, (q15_t)0x83a9, (q15_t)0x1e5c, (q15_t)0x83a8, + (q15_t)0x1e56, (q15_t)0x83a6, (q15_t)0x1e50, (q15_t)0x83a5, (q15_t)0x1e4a, (q15_t)0x83a3, (q15_t)0x1e44, (q15_t)0x83a2, + (q15_t)0x1e3e, (q15_t)0x83a0, (q15_t)0x1e38, (q15_t)0x839f, (q15_t)0x1e32, (q15_t)0x839d, (q15_t)0x1e2c, (q15_t)0x839c, + (q15_t)0x1e25, (q15_t)0x839a, (q15_t)0x1e1f, (q15_t)0x8399, (q15_t)0x1e19, (q15_t)0x8397, (q15_t)0x1e13, (q15_t)0x8396, + (q15_t)0x1e0d, (q15_t)0x8394, (q15_t)0x1e07, (q15_t)0x8393, (q15_t)0x1e01, (q15_t)0x8392, (q15_t)0x1dfb, (q15_t)0x8390, + (q15_t)0x1df5, (q15_t)0x838f, (q15_t)0x1dee, (q15_t)0x838d, (q15_t)0x1de8, (q15_t)0x838c, (q15_t)0x1de2, (q15_t)0x838a, + (q15_t)0x1ddc, (q15_t)0x8389, (q15_t)0x1dd6, (q15_t)0x8387, (q15_t)0x1dd0, (q15_t)0x8386, (q15_t)0x1dca, (q15_t)0x8384, + (q15_t)0x1dc4, (q15_t)0x8383, (q15_t)0x1dbe, (q15_t)0x8381, (q15_t)0x1db7, (q15_t)0x8380, (q15_t)0x1db1, (q15_t)0x837e, + (q15_t)0x1dab, (q15_t)0x837d, (q15_t)0x1da5, (q15_t)0x837c, (q15_t)0x1d9f, (q15_t)0x837a, (q15_t)0x1d99, (q15_t)0x8379, + (q15_t)0x1d93, (q15_t)0x8377, (q15_t)0x1d8d, (q15_t)0x8376, (q15_t)0x1d87, (q15_t)0x8374, (q15_t)0x1d80, (q15_t)0x8373, + (q15_t)0x1d7a, (q15_t)0x8371, (q15_t)0x1d74, (q15_t)0x8370, (q15_t)0x1d6e, (q15_t)0x836f, (q15_t)0x1d68, (q15_t)0x836d, + (q15_t)0x1d62, (q15_t)0x836c, (q15_t)0x1d5c, (q15_t)0x836a, (q15_t)0x1d56, (q15_t)0x8369, (q15_t)0x1d50, (q15_t)0x8367, + (q15_t)0x1d49, (q15_t)0x8366, (q15_t)0x1d43, (q15_t)0x8364, (q15_t)0x1d3d, (q15_t)0x8363, (q15_t)0x1d37, (q15_t)0x8362, + (q15_t)0x1d31, (q15_t)0x8360, (q15_t)0x1d2b, (q15_t)0x835f, (q15_t)0x1d25, (q15_t)0x835d, (q15_t)0x1d1f, (q15_t)0x835c, + (q15_t)0x1d18, (q15_t)0x835a, (q15_t)0x1d12, (q15_t)0x8359, (q15_t)0x1d0c, (q15_t)0x8358, (q15_t)0x1d06, (q15_t)0x8356, + (q15_t)0x1d00, (q15_t)0x8355, (q15_t)0x1cfa, (q15_t)0x8353, (q15_t)0x1cf4, (q15_t)0x8352, (q15_t)0x1cee, (q15_t)0x8350, + (q15_t)0x1ce8, (q15_t)0x834f, (q15_t)0x1ce1, (q15_t)0x834e, (q15_t)0x1cdb, (q15_t)0x834c, (q15_t)0x1cd5, (q15_t)0x834b, + (q15_t)0x1ccf, (q15_t)0x8349, (q15_t)0x1cc9, (q15_t)0x8348, (q15_t)0x1cc3, (q15_t)0x8347, (q15_t)0x1cbd, (q15_t)0x8345, + (q15_t)0x1cb7, (q15_t)0x8344, (q15_t)0x1cb0, (q15_t)0x8342, (q15_t)0x1caa, (q15_t)0x8341, (q15_t)0x1ca4, (q15_t)0x833f, + (q15_t)0x1c9e, (q15_t)0x833e, (q15_t)0x1c98, (q15_t)0x833d, (q15_t)0x1c92, (q15_t)0x833b, (q15_t)0x1c8c, (q15_t)0x833a, + (q15_t)0x1c86, (q15_t)0x8338, (q15_t)0x1c7f, (q15_t)0x8337, (q15_t)0x1c79, (q15_t)0x8336, (q15_t)0x1c73, (q15_t)0x8334, + (q15_t)0x1c6d, (q15_t)0x8333, (q15_t)0x1c67, (q15_t)0x8331, (q15_t)0x1c61, (q15_t)0x8330, (q15_t)0x1c5b, (q15_t)0x832f, + (q15_t)0x1c55, (q15_t)0x832d, (q15_t)0x1c4e, (q15_t)0x832c, (q15_t)0x1c48, (q15_t)0x832b, (q15_t)0x1c42, (q15_t)0x8329, + (q15_t)0x1c3c, (q15_t)0x8328, (q15_t)0x1c36, (q15_t)0x8326, (q15_t)0x1c30, (q15_t)0x8325, (q15_t)0x1c2a, (q15_t)0x8324, + (q15_t)0x1c24, (q15_t)0x8322, (q15_t)0x1c1d, (q15_t)0x8321, (q15_t)0x1c17, (q15_t)0x831f, (q15_t)0x1c11, (q15_t)0x831e, + (q15_t)0x1c0b, (q15_t)0x831d, (q15_t)0x1c05, (q15_t)0x831b, (q15_t)0x1bff, (q15_t)0x831a, (q15_t)0x1bf9, (q15_t)0x8319, + (q15_t)0x1bf2, (q15_t)0x8317, (q15_t)0x1bec, (q15_t)0x8316, (q15_t)0x1be6, (q15_t)0x8314, (q15_t)0x1be0, (q15_t)0x8313, + (q15_t)0x1bda, (q15_t)0x8312, (q15_t)0x1bd4, (q15_t)0x8310, (q15_t)0x1bce, (q15_t)0x830f, (q15_t)0x1bc8, (q15_t)0x830e, + (q15_t)0x1bc1, (q15_t)0x830c, (q15_t)0x1bbb, (q15_t)0x830b, (q15_t)0x1bb5, (q15_t)0x830a, (q15_t)0x1baf, (q15_t)0x8308, + (q15_t)0x1ba9, (q15_t)0x8307, (q15_t)0x1ba3, (q15_t)0x8305, (q15_t)0x1b9d, (q15_t)0x8304, (q15_t)0x1b96, (q15_t)0x8303, + (q15_t)0x1b90, (q15_t)0x8301, (q15_t)0x1b8a, (q15_t)0x8300, (q15_t)0x1b84, (q15_t)0x82ff, (q15_t)0x1b7e, (q15_t)0x82fd, + (q15_t)0x1b78, (q15_t)0x82fc, (q15_t)0x1b72, (q15_t)0x82fb, (q15_t)0x1b6c, (q15_t)0x82f9, (q15_t)0x1b65, (q15_t)0x82f8, + (q15_t)0x1b5f, (q15_t)0x82f7, (q15_t)0x1b59, (q15_t)0x82f5, (q15_t)0x1b53, (q15_t)0x82f4, (q15_t)0x1b4d, (q15_t)0x82f3, + (q15_t)0x1b47, (q15_t)0x82f1, (q15_t)0x1b41, (q15_t)0x82f0, (q15_t)0x1b3a, (q15_t)0x82ef, (q15_t)0x1b34, (q15_t)0x82ed, + (q15_t)0x1b2e, (q15_t)0x82ec, (q15_t)0x1b28, (q15_t)0x82eb, (q15_t)0x1b22, (q15_t)0x82e9, (q15_t)0x1b1c, (q15_t)0x82e8, + (q15_t)0x1b16, (q15_t)0x82e7, (q15_t)0x1b0f, (q15_t)0x82e5, (q15_t)0x1b09, (q15_t)0x82e4, (q15_t)0x1b03, (q15_t)0x82e3, + (q15_t)0x1afd, (q15_t)0x82e1, (q15_t)0x1af7, (q15_t)0x82e0, (q15_t)0x1af1, (q15_t)0x82df, (q15_t)0x1aeb, (q15_t)0x82dd, + (q15_t)0x1ae4, (q15_t)0x82dc, (q15_t)0x1ade, (q15_t)0x82db, (q15_t)0x1ad8, (q15_t)0x82d9, (q15_t)0x1ad2, (q15_t)0x82d8, + (q15_t)0x1acc, (q15_t)0x82d7, (q15_t)0x1ac6, (q15_t)0x82d5, (q15_t)0x1ac0, (q15_t)0x82d4, (q15_t)0x1ab9, (q15_t)0x82d3, + (q15_t)0x1ab3, (q15_t)0x82d1, (q15_t)0x1aad, (q15_t)0x82d0, (q15_t)0x1aa7, (q15_t)0x82cf, (q15_t)0x1aa1, (q15_t)0x82ce, + (q15_t)0x1a9b, (q15_t)0x82cc, (q15_t)0x1a95, (q15_t)0x82cb, (q15_t)0x1a8e, (q15_t)0x82ca, (q15_t)0x1a88, (q15_t)0x82c8, + (q15_t)0x1a82, (q15_t)0x82c7, (q15_t)0x1a7c, (q15_t)0x82c6, (q15_t)0x1a76, (q15_t)0x82c4, (q15_t)0x1a70, (q15_t)0x82c3, + (q15_t)0x1a6a, (q15_t)0x82c2, (q15_t)0x1a63, (q15_t)0x82c1, (q15_t)0x1a5d, (q15_t)0x82bf, (q15_t)0x1a57, (q15_t)0x82be, + (q15_t)0x1a51, (q15_t)0x82bd, (q15_t)0x1a4b, (q15_t)0x82bb, (q15_t)0x1a45, (q15_t)0x82ba, (q15_t)0x1a3e, (q15_t)0x82b9, + (q15_t)0x1a38, (q15_t)0x82b7, (q15_t)0x1a32, (q15_t)0x82b6, (q15_t)0x1a2c, (q15_t)0x82b5, (q15_t)0x1a26, (q15_t)0x82b4, + (q15_t)0x1a20, (q15_t)0x82b2, (q15_t)0x1a1a, (q15_t)0x82b1, (q15_t)0x1a13, (q15_t)0x82b0, (q15_t)0x1a0d, (q15_t)0x82ae, + (q15_t)0x1a07, (q15_t)0x82ad, (q15_t)0x1a01, (q15_t)0x82ac, (q15_t)0x19fb, (q15_t)0x82ab, (q15_t)0x19f5, (q15_t)0x82a9, + (q15_t)0x19ef, (q15_t)0x82a8, (q15_t)0x19e8, (q15_t)0x82a7, (q15_t)0x19e2, (q15_t)0x82a6, (q15_t)0x19dc, (q15_t)0x82a4, + (q15_t)0x19d6, (q15_t)0x82a3, (q15_t)0x19d0, (q15_t)0x82a2, (q15_t)0x19ca, (q15_t)0x82a0, (q15_t)0x19c3, (q15_t)0x829f, + (q15_t)0x19bd, (q15_t)0x829e, (q15_t)0x19b7, (q15_t)0x829d, (q15_t)0x19b1, (q15_t)0x829b, (q15_t)0x19ab, (q15_t)0x829a, + (q15_t)0x19a5, (q15_t)0x8299, (q15_t)0x199f, (q15_t)0x8298, (q15_t)0x1998, (q15_t)0x8296, (q15_t)0x1992, (q15_t)0x8295, + (q15_t)0x198c, (q15_t)0x8294, (q15_t)0x1986, (q15_t)0x8293, (q15_t)0x1980, (q15_t)0x8291, (q15_t)0x197a, (q15_t)0x8290, + (q15_t)0x1973, (q15_t)0x828f, (q15_t)0x196d, (q15_t)0x828e, (q15_t)0x1967, (q15_t)0x828c, (q15_t)0x1961, (q15_t)0x828b, + (q15_t)0x195b, (q15_t)0x828a, (q15_t)0x1955, (q15_t)0x8289, (q15_t)0x194e, (q15_t)0x8287, (q15_t)0x1948, (q15_t)0x8286, + (q15_t)0x1942, (q15_t)0x8285, (q15_t)0x193c, (q15_t)0x8284, (q15_t)0x1936, (q15_t)0x8282, (q15_t)0x1930, (q15_t)0x8281, + (q15_t)0x192a, (q15_t)0x8280, (q15_t)0x1923, (q15_t)0x827f, (q15_t)0x191d, (q15_t)0x827e, (q15_t)0x1917, (q15_t)0x827c, + (q15_t)0x1911, (q15_t)0x827b, (q15_t)0x190b, (q15_t)0x827a, (q15_t)0x1905, (q15_t)0x8279, (q15_t)0x18fe, (q15_t)0x8277, + (q15_t)0x18f8, (q15_t)0x8276, (q15_t)0x18f2, (q15_t)0x8275, (q15_t)0x18ec, (q15_t)0x8274, (q15_t)0x18e6, (q15_t)0x8272, + (q15_t)0x18e0, (q15_t)0x8271, (q15_t)0x18d9, (q15_t)0x8270, (q15_t)0x18d3, (q15_t)0x826f, (q15_t)0x18cd, (q15_t)0x826e, + (q15_t)0x18c7, (q15_t)0x826c, (q15_t)0x18c1, (q15_t)0x826b, (q15_t)0x18bb, (q15_t)0x826a, (q15_t)0x18b4, (q15_t)0x8269, + (q15_t)0x18ae, (q15_t)0x8268, (q15_t)0x18a8, (q15_t)0x8266, (q15_t)0x18a2, (q15_t)0x8265, (q15_t)0x189c, (q15_t)0x8264, + (q15_t)0x1896, (q15_t)0x8263, (q15_t)0x188f, (q15_t)0x8261, (q15_t)0x1889, (q15_t)0x8260, (q15_t)0x1883, (q15_t)0x825f, + (q15_t)0x187d, (q15_t)0x825e, (q15_t)0x1877, (q15_t)0x825d, (q15_t)0x1871, (q15_t)0x825b, (q15_t)0x186a, (q15_t)0x825a, + (q15_t)0x1864, (q15_t)0x8259, (q15_t)0x185e, (q15_t)0x8258, (q15_t)0x1858, (q15_t)0x8257, (q15_t)0x1852, (q15_t)0x8255, + (q15_t)0x184c, (q15_t)0x8254, (q15_t)0x1845, (q15_t)0x8253, (q15_t)0x183f, (q15_t)0x8252, (q15_t)0x1839, (q15_t)0x8251, + (q15_t)0x1833, (q15_t)0x8250, (q15_t)0x182d, (q15_t)0x824e, (q15_t)0x1827, (q15_t)0x824d, (q15_t)0x1820, (q15_t)0x824c, + (q15_t)0x181a, (q15_t)0x824b, (q15_t)0x1814, (q15_t)0x824a, (q15_t)0x180e, (q15_t)0x8248, (q15_t)0x1808, (q15_t)0x8247, + (q15_t)0x1802, (q15_t)0x8246, (q15_t)0x17fb, (q15_t)0x8245, (q15_t)0x17f5, (q15_t)0x8244, (q15_t)0x17ef, (q15_t)0x8243, + (q15_t)0x17e9, (q15_t)0x8241, (q15_t)0x17e3, (q15_t)0x8240, (q15_t)0x17dd, (q15_t)0x823f, (q15_t)0x17d6, (q15_t)0x823e, + (q15_t)0x17d0, (q15_t)0x823d, (q15_t)0x17ca, (q15_t)0x823b, (q15_t)0x17c4, (q15_t)0x823a, (q15_t)0x17be, (q15_t)0x8239, + (q15_t)0x17b7, (q15_t)0x8238, (q15_t)0x17b1, (q15_t)0x8237, (q15_t)0x17ab, (q15_t)0x8236, (q15_t)0x17a5, (q15_t)0x8234, + (q15_t)0x179f, (q15_t)0x8233, (q15_t)0x1799, (q15_t)0x8232, (q15_t)0x1792, (q15_t)0x8231, (q15_t)0x178c, (q15_t)0x8230, + (q15_t)0x1786, (q15_t)0x822f, (q15_t)0x1780, (q15_t)0x822e, (q15_t)0x177a, (q15_t)0x822c, (q15_t)0x1774, (q15_t)0x822b, + (q15_t)0x176d, (q15_t)0x822a, (q15_t)0x1767, (q15_t)0x8229, (q15_t)0x1761, (q15_t)0x8228, (q15_t)0x175b, (q15_t)0x8227, + (q15_t)0x1755, (q15_t)0x8226, (q15_t)0x174e, (q15_t)0x8224, (q15_t)0x1748, (q15_t)0x8223, (q15_t)0x1742, (q15_t)0x8222, + (q15_t)0x173c, (q15_t)0x8221, (q15_t)0x1736, (q15_t)0x8220, (q15_t)0x1730, (q15_t)0x821f, (q15_t)0x1729, (q15_t)0x821e, + (q15_t)0x1723, (q15_t)0x821c, (q15_t)0x171d, (q15_t)0x821b, (q15_t)0x1717, (q15_t)0x821a, (q15_t)0x1711, (q15_t)0x8219, + (q15_t)0x170a, (q15_t)0x8218, (q15_t)0x1704, (q15_t)0x8217, (q15_t)0x16fe, (q15_t)0x8216, (q15_t)0x16f8, (q15_t)0x8214, + (q15_t)0x16f2, (q15_t)0x8213, (q15_t)0x16ec, (q15_t)0x8212, (q15_t)0x16e5, (q15_t)0x8211, (q15_t)0x16df, (q15_t)0x8210, + (q15_t)0x16d9, (q15_t)0x820f, (q15_t)0x16d3, (q15_t)0x820e, (q15_t)0x16cd, (q15_t)0x820d, (q15_t)0x16c6, (q15_t)0x820b, + (q15_t)0x16c0, (q15_t)0x820a, (q15_t)0x16ba, (q15_t)0x8209, (q15_t)0x16b4, (q15_t)0x8208, (q15_t)0x16ae, (q15_t)0x8207, + (q15_t)0x16a8, (q15_t)0x8206, (q15_t)0x16a1, (q15_t)0x8205, (q15_t)0x169b, (q15_t)0x8204, (q15_t)0x1695, (q15_t)0x8203, + (q15_t)0x168f, (q15_t)0x8201, (q15_t)0x1689, (q15_t)0x8200, (q15_t)0x1682, (q15_t)0x81ff, (q15_t)0x167c, (q15_t)0x81fe, + (q15_t)0x1676, (q15_t)0x81fd, (q15_t)0x1670, (q15_t)0x81fc, (q15_t)0x166a, (q15_t)0x81fb, (q15_t)0x1664, (q15_t)0x81fa, + (q15_t)0x165d, (q15_t)0x81f9, (q15_t)0x1657, (q15_t)0x81f8, (q15_t)0x1651, (q15_t)0x81f6, (q15_t)0x164b, (q15_t)0x81f5, + (q15_t)0x1645, (q15_t)0x81f4, (q15_t)0x163e, (q15_t)0x81f3, (q15_t)0x1638, (q15_t)0x81f2, (q15_t)0x1632, (q15_t)0x81f1, + (q15_t)0x162c, (q15_t)0x81f0, (q15_t)0x1626, (q15_t)0x81ef, (q15_t)0x161f, (q15_t)0x81ee, (q15_t)0x1619, (q15_t)0x81ed, + (q15_t)0x1613, (q15_t)0x81ec, (q15_t)0x160d, (q15_t)0x81ea, (q15_t)0x1607, (q15_t)0x81e9, (q15_t)0x1601, (q15_t)0x81e8, + (q15_t)0x15fa, (q15_t)0x81e7, (q15_t)0x15f4, (q15_t)0x81e6, (q15_t)0x15ee, (q15_t)0x81e5, (q15_t)0x15e8, (q15_t)0x81e4, + (q15_t)0x15e2, (q15_t)0x81e3, (q15_t)0x15db, (q15_t)0x81e2, (q15_t)0x15d5, (q15_t)0x81e1, (q15_t)0x15cf, (q15_t)0x81e0, + (q15_t)0x15c9, (q15_t)0x81df, (q15_t)0x15c3, (q15_t)0x81de, (q15_t)0x15bc, (q15_t)0x81dc, (q15_t)0x15b6, (q15_t)0x81db, + (q15_t)0x15b0, (q15_t)0x81da, (q15_t)0x15aa, (q15_t)0x81d9, (q15_t)0x15a4, (q15_t)0x81d8, (q15_t)0x159d, (q15_t)0x81d7, + (q15_t)0x1597, (q15_t)0x81d6, (q15_t)0x1591, (q15_t)0x81d5, (q15_t)0x158b, (q15_t)0x81d4, (q15_t)0x1585, (q15_t)0x81d3, + (q15_t)0x157f, (q15_t)0x81d2, (q15_t)0x1578, (q15_t)0x81d1, (q15_t)0x1572, (q15_t)0x81d0, (q15_t)0x156c, (q15_t)0x81cf, + (q15_t)0x1566, (q15_t)0x81ce, (q15_t)0x1560, (q15_t)0x81cd, (q15_t)0x1559, (q15_t)0x81cc, (q15_t)0x1553, (q15_t)0x81cb, + (q15_t)0x154d, (q15_t)0x81c9, (q15_t)0x1547, (q15_t)0x81c8, (q15_t)0x1541, (q15_t)0x81c7, (q15_t)0x153a, (q15_t)0x81c6, + (q15_t)0x1534, (q15_t)0x81c5, (q15_t)0x152e, (q15_t)0x81c4, (q15_t)0x1528, (q15_t)0x81c3, (q15_t)0x1522, (q15_t)0x81c2, + (q15_t)0x151b, (q15_t)0x81c1, (q15_t)0x1515, (q15_t)0x81c0, (q15_t)0x150f, (q15_t)0x81bf, (q15_t)0x1509, (q15_t)0x81be, + (q15_t)0x1503, (q15_t)0x81bd, (q15_t)0x14fc, (q15_t)0x81bc, (q15_t)0x14f6, (q15_t)0x81bb, (q15_t)0x14f0, (q15_t)0x81ba, + (q15_t)0x14ea, (q15_t)0x81b9, (q15_t)0x14e4, (q15_t)0x81b8, (q15_t)0x14dd, (q15_t)0x81b7, (q15_t)0x14d7, (q15_t)0x81b6, + (q15_t)0x14d1, (q15_t)0x81b5, (q15_t)0x14cb, (q15_t)0x81b4, (q15_t)0x14c5, (q15_t)0x81b3, (q15_t)0x14be, (q15_t)0x81b2, + (q15_t)0x14b8, (q15_t)0x81b1, (q15_t)0x14b2, (q15_t)0x81b0, (q15_t)0x14ac, (q15_t)0x81af, (q15_t)0x14a6, (q15_t)0x81ae, + (q15_t)0x149f, (q15_t)0x81ad, (q15_t)0x1499, (q15_t)0x81ac, (q15_t)0x1493, (q15_t)0x81ab, (q15_t)0x148d, (q15_t)0x81aa, + (q15_t)0x1487, (q15_t)0x81a9, (q15_t)0x1480, (q15_t)0x81a8, (q15_t)0x147a, (q15_t)0x81a7, (q15_t)0x1474, (q15_t)0x81a6, + (q15_t)0x146e, (q15_t)0x81a5, (q15_t)0x1468, (q15_t)0x81a4, (q15_t)0x1461, (q15_t)0x81a3, (q15_t)0x145b, (q15_t)0x81a2, + (q15_t)0x1455, (q15_t)0x81a1, (q15_t)0x144f, (q15_t)0x81a0, (q15_t)0x1449, (q15_t)0x819f, (q15_t)0x1442, (q15_t)0x819e, + (q15_t)0x143c, (q15_t)0x819d, (q15_t)0x1436, (q15_t)0x819c, (q15_t)0x1430, (q15_t)0x819b, (q15_t)0x142a, (q15_t)0x819a, + (q15_t)0x1423, (q15_t)0x8199, (q15_t)0x141d, (q15_t)0x8198, (q15_t)0x1417, (q15_t)0x8197, (q15_t)0x1411, (q15_t)0x8196, + (q15_t)0x140b, (q15_t)0x8195, (q15_t)0x1404, (q15_t)0x8194, (q15_t)0x13fe, (q15_t)0x8193, (q15_t)0x13f8, (q15_t)0x8192, + (q15_t)0x13f2, (q15_t)0x8191, (q15_t)0x13eb, (q15_t)0x8190, (q15_t)0x13e5, (q15_t)0x818f, (q15_t)0x13df, (q15_t)0x818e, + (q15_t)0x13d9, (q15_t)0x818d, (q15_t)0x13d3, (q15_t)0x818c, (q15_t)0x13cc, (q15_t)0x818b, (q15_t)0x13c6, (q15_t)0x818a, + (q15_t)0x13c0, (q15_t)0x8189, (q15_t)0x13ba, (q15_t)0x8188, (q15_t)0x13b4, (q15_t)0x8187, (q15_t)0x13ad, (q15_t)0x8186, + (q15_t)0x13a7, (q15_t)0x8185, (q15_t)0x13a1, (q15_t)0x8184, (q15_t)0x139b, (q15_t)0x8183, (q15_t)0x1395, (q15_t)0x8182, + (q15_t)0x138e, (q15_t)0x8181, (q15_t)0x1388, (q15_t)0x8180, (q15_t)0x1382, (q15_t)0x817f, (q15_t)0x137c, (q15_t)0x817e, + (q15_t)0x1376, (q15_t)0x817d, (q15_t)0x136f, (q15_t)0x817c, (q15_t)0x1369, (q15_t)0x817c, (q15_t)0x1363, (q15_t)0x817b, + (q15_t)0x135d, (q15_t)0x817a, (q15_t)0x1356, (q15_t)0x8179, (q15_t)0x1350, (q15_t)0x8178, (q15_t)0x134a, (q15_t)0x8177, + (q15_t)0x1344, (q15_t)0x8176, (q15_t)0x133e, (q15_t)0x8175, (q15_t)0x1337, (q15_t)0x8174, (q15_t)0x1331, (q15_t)0x8173, + (q15_t)0x132b, (q15_t)0x8172, (q15_t)0x1325, (q15_t)0x8171, (q15_t)0x131f, (q15_t)0x8170, (q15_t)0x1318, (q15_t)0x816f, + (q15_t)0x1312, (q15_t)0x816e, (q15_t)0x130c, (q15_t)0x816d, (q15_t)0x1306, (q15_t)0x816c, (q15_t)0x12ff, (q15_t)0x816c, + (q15_t)0x12f9, (q15_t)0x816b, (q15_t)0x12f3, (q15_t)0x816a, (q15_t)0x12ed, (q15_t)0x8169, (q15_t)0x12e7, (q15_t)0x8168, + (q15_t)0x12e0, (q15_t)0x8167, (q15_t)0x12da, (q15_t)0x8166, (q15_t)0x12d4, (q15_t)0x8165, (q15_t)0x12ce, (q15_t)0x8164, + (q15_t)0x12c8, (q15_t)0x8163, (q15_t)0x12c1, (q15_t)0x8162, (q15_t)0x12bb, (q15_t)0x8161, (q15_t)0x12b5, (q15_t)0x8160, + (q15_t)0x12af, (q15_t)0x815f, (q15_t)0x12a8, (q15_t)0x815f, (q15_t)0x12a2, (q15_t)0x815e, (q15_t)0x129c, (q15_t)0x815d, + (q15_t)0x1296, (q15_t)0x815c, (q15_t)0x1290, (q15_t)0x815b, (q15_t)0x1289, (q15_t)0x815a, (q15_t)0x1283, (q15_t)0x8159, + (q15_t)0x127d, (q15_t)0x8158, (q15_t)0x1277, (q15_t)0x8157, (q15_t)0x1271, (q15_t)0x8156, (q15_t)0x126a, (q15_t)0x8155, + (q15_t)0x1264, (q15_t)0x8155, (q15_t)0x125e, (q15_t)0x8154, (q15_t)0x1258, (q15_t)0x8153, (q15_t)0x1251, (q15_t)0x8152, + (q15_t)0x124b, (q15_t)0x8151, (q15_t)0x1245, (q15_t)0x8150, (q15_t)0x123f, (q15_t)0x814f, (q15_t)0x1239, (q15_t)0x814e, + (q15_t)0x1232, (q15_t)0x814d, (q15_t)0x122c, (q15_t)0x814c, (q15_t)0x1226, (q15_t)0x814c, (q15_t)0x1220, (q15_t)0x814b, + (q15_t)0x1219, (q15_t)0x814a, (q15_t)0x1213, (q15_t)0x8149, (q15_t)0x120d, (q15_t)0x8148, (q15_t)0x1207, (q15_t)0x8147, + (q15_t)0x1201, (q15_t)0x8146, (q15_t)0x11fa, (q15_t)0x8145, (q15_t)0x11f4, (q15_t)0x8145, (q15_t)0x11ee, (q15_t)0x8144, + (q15_t)0x11e8, (q15_t)0x8143, (q15_t)0x11e1, (q15_t)0x8142, (q15_t)0x11db, (q15_t)0x8141, (q15_t)0x11d5, (q15_t)0x8140, + (q15_t)0x11cf, (q15_t)0x813f, (q15_t)0x11c9, (q15_t)0x813e, (q15_t)0x11c2, (q15_t)0x813d, (q15_t)0x11bc, (q15_t)0x813d, + (q15_t)0x11b6, (q15_t)0x813c, (q15_t)0x11b0, (q15_t)0x813b, (q15_t)0x11a9, (q15_t)0x813a, (q15_t)0x11a3, (q15_t)0x8139, + (q15_t)0x119d, (q15_t)0x8138, (q15_t)0x1197, (q15_t)0x8137, (q15_t)0x1191, (q15_t)0x8137, (q15_t)0x118a, (q15_t)0x8136, + (q15_t)0x1184, (q15_t)0x8135, (q15_t)0x117e, (q15_t)0x8134, (q15_t)0x1178, (q15_t)0x8133, (q15_t)0x1171, (q15_t)0x8132, + (q15_t)0x116b, (q15_t)0x8131, (q15_t)0x1165, (q15_t)0x8131, (q15_t)0x115f, (q15_t)0x8130, (q15_t)0x1159, (q15_t)0x812f, + (q15_t)0x1152, (q15_t)0x812e, (q15_t)0x114c, (q15_t)0x812d, (q15_t)0x1146, (q15_t)0x812c, (q15_t)0x1140, (q15_t)0x812b, + (q15_t)0x1139, (q15_t)0x812b, (q15_t)0x1133, (q15_t)0x812a, (q15_t)0x112d, (q15_t)0x8129, (q15_t)0x1127, (q15_t)0x8128, + (q15_t)0x1121, (q15_t)0x8127, (q15_t)0x111a, (q15_t)0x8126, (q15_t)0x1114, (q15_t)0x8126, (q15_t)0x110e, (q15_t)0x8125, + (q15_t)0x1108, (q15_t)0x8124, (q15_t)0x1101, (q15_t)0x8123, (q15_t)0x10fb, (q15_t)0x8122, (q15_t)0x10f5, (q15_t)0x8121, + (q15_t)0x10ef, (q15_t)0x8121, (q15_t)0x10e8, (q15_t)0x8120, (q15_t)0x10e2, (q15_t)0x811f, (q15_t)0x10dc, (q15_t)0x811e, + (q15_t)0x10d6, (q15_t)0x811d, (q15_t)0x10d0, (q15_t)0x811c, (q15_t)0x10c9, (q15_t)0x811c, (q15_t)0x10c3, (q15_t)0x811b, + (q15_t)0x10bd, (q15_t)0x811a, (q15_t)0x10b7, (q15_t)0x8119, (q15_t)0x10b0, (q15_t)0x8118, (q15_t)0x10aa, (q15_t)0x8117, + (q15_t)0x10a4, (q15_t)0x8117, (q15_t)0x109e, (q15_t)0x8116, (q15_t)0x1098, (q15_t)0x8115, (q15_t)0x1091, (q15_t)0x8114, + (q15_t)0x108b, (q15_t)0x8113, (q15_t)0x1085, (q15_t)0x8113, (q15_t)0x107f, (q15_t)0x8112, (q15_t)0x1078, (q15_t)0x8111, + (q15_t)0x1072, (q15_t)0x8110, (q15_t)0x106c, (q15_t)0x810f, (q15_t)0x1066, (q15_t)0x810f, (q15_t)0x105f, (q15_t)0x810e, + (q15_t)0x1059, (q15_t)0x810d, (q15_t)0x1053, (q15_t)0x810c, (q15_t)0x104d, (q15_t)0x810b, (q15_t)0x1047, (q15_t)0x810b, + (q15_t)0x1040, (q15_t)0x810a, (q15_t)0x103a, (q15_t)0x8109, (q15_t)0x1034, (q15_t)0x8108, (q15_t)0x102e, (q15_t)0x8107, + (q15_t)0x1027, (q15_t)0x8107, (q15_t)0x1021, (q15_t)0x8106, (q15_t)0x101b, (q15_t)0x8105, (q15_t)0x1015, (q15_t)0x8104, + (q15_t)0x100e, (q15_t)0x8103, (q15_t)0x1008, (q15_t)0x8103, (q15_t)0x1002, (q15_t)0x8102, (q15_t)0xffc, (q15_t)0x8101, + (q15_t)0xff5, (q15_t)0x8100, (q15_t)0xfef, (q15_t)0x80ff, (q15_t)0xfe9, (q15_t)0x80ff, (q15_t)0xfe3, (q15_t)0x80fe, + (q15_t)0xfdd, (q15_t)0x80fd, (q15_t)0xfd6, (q15_t)0x80fc, (q15_t)0xfd0, (q15_t)0x80fc, (q15_t)0xfca, (q15_t)0x80fb, + (q15_t)0xfc4, (q15_t)0x80fa, (q15_t)0xfbd, (q15_t)0x80f9, (q15_t)0xfb7, (q15_t)0x80f8, (q15_t)0xfb1, (q15_t)0x80f8, + (q15_t)0xfab, (q15_t)0x80f7, (q15_t)0xfa4, (q15_t)0x80f6, (q15_t)0xf9e, (q15_t)0x80f5, (q15_t)0xf98, (q15_t)0x80f5, + (q15_t)0xf92, (q15_t)0x80f4, (q15_t)0xf8b, (q15_t)0x80f3, (q15_t)0xf85, (q15_t)0x80f2, (q15_t)0xf7f, (q15_t)0x80f2, + (q15_t)0xf79, (q15_t)0x80f1, (q15_t)0xf73, (q15_t)0x80f0, (q15_t)0xf6c, (q15_t)0x80ef, (q15_t)0xf66, (q15_t)0x80ef, + (q15_t)0xf60, (q15_t)0x80ee, (q15_t)0xf5a, (q15_t)0x80ed, (q15_t)0xf53, (q15_t)0x80ec, (q15_t)0xf4d, (q15_t)0x80ec, + (q15_t)0xf47, (q15_t)0x80eb, (q15_t)0xf41, (q15_t)0x80ea, (q15_t)0xf3a, (q15_t)0x80e9, (q15_t)0xf34, (q15_t)0x80e9, + (q15_t)0xf2e, (q15_t)0x80e8, (q15_t)0xf28, (q15_t)0x80e7, (q15_t)0xf21, (q15_t)0x80e6, (q15_t)0xf1b, (q15_t)0x80e6, + (q15_t)0xf15, (q15_t)0x80e5, (q15_t)0xf0f, (q15_t)0x80e4, (q15_t)0xf08, (q15_t)0x80e3, (q15_t)0xf02, (q15_t)0x80e3, + (q15_t)0xefc, (q15_t)0x80e2, (q15_t)0xef6, (q15_t)0x80e1, (q15_t)0xef0, (q15_t)0x80e0, (q15_t)0xee9, (q15_t)0x80e0, + (q15_t)0xee3, (q15_t)0x80df, (q15_t)0xedd, (q15_t)0x80de, (q15_t)0xed7, (q15_t)0x80dd, (q15_t)0xed0, (q15_t)0x80dd, + (q15_t)0xeca, (q15_t)0x80dc, (q15_t)0xec4, (q15_t)0x80db, (q15_t)0xebe, (q15_t)0x80db, (q15_t)0xeb7, (q15_t)0x80da, + (q15_t)0xeb1, (q15_t)0x80d9, (q15_t)0xeab, (q15_t)0x80d8, (q15_t)0xea5, (q15_t)0x80d8, (q15_t)0xe9e, (q15_t)0x80d7, + (q15_t)0xe98, (q15_t)0x80d6, (q15_t)0xe92, (q15_t)0x80d6, (q15_t)0xe8c, (q15_t)0x80d5, (q15_t)0xe85, (q15_t)0x80d4, + (q15_t)0xe7f, (q15_t)0x80d3, (q15_t)0xe79, (q15_t)0x80d3, (q15_t)0xe73, (q15_t)0x80d2, (q15_t)0xe6c, (q15_t)0x80d1, + (q15_t)0xe66, (q15_t)0x80d1, (q15_t)0xe60, (q15_t)0x80d0, (q15_t)0xe5a, (q15_t)0x80cf, (q15_t)0xe53, (q15_t)0x80ce, + (q15_t)0xe4d, (q15_t)0x80ce, (q15_t)0xe47, (q15_t)0x80cd, (q15_t)0xe41, (q15_t)0x80cc, (q15_t)0xe3a, (q15_t)0x80cc, + (q15_t)0xe34, (q15_t)0x80cb, (q15_t)0xe2e, (q15_t)0x80ca, (q15_t)0xe28, (q15_t)0x80ca, (q15_t)0xe22, (q15_t)0x80c9, + (q15_t)0xe1b, (q15_t)0x80c8, (q15_t)0xe15, (q15_t)0x80c7, (q15_t)0xe0f, (q15_t)0x80c7, (q15_t)0xe09, (q15_t)0x80c6, + (q15_t)0xe02, (q15_t)0x80c5, (q15_t)0xdfc, (q15_t)0x80c5, (q15_t)0xdf6, (q15_t)0x80c4, (q15_t)0xdf0, (q15_t)0x80c3, + (q15_t)0xde9, (q15_t)0x80c3, (q15_t)0xde3, (q15_t)0x80c2, (q15_t)0xddd, (q15_t)0x80c1, (q15_t)0xdd7, (q15_t)0x80c1, + (q15_t)0xdd0, (q15_t)0x80c0, (q15_t)0xdca, (q15_t)0x80bf, (q15_t)0xdc4, (q15_t)0x80bf, (q15_t)0xdbe, (q15_t)0x80be, + (q15_t)0xdb7, (q15_t)0x80bd, (q15_t)0xdb1, (q15_t)0x80bd, (q15_t)0xdab, (q15_t)0x80bc, (q15_t)0xda5, (q15_t)0x80bb, + (q15_t)0xd9e, (q15_t)0x80bb, (q15_t)0xd98, (q15_t)0x80ba, (q15_t)0xd92, (q15_t)0x80b9, (q15_t)0xd8c, (q15_t)0x80b9, + (q15_t)0xd85, (q15_t)0x80b8, (q15_t)0xd7f, (q15_t)0x80b7, (q15_t)0xd79, (q15_t)0x80b7, (q15_t)0xd73, (q15_t)0x80b6, + (q15_t)0xd6c, (q15_t)0x80b5, (q15_t)0xd66, (q15_t)0x80b5, (q15_t)0xd60, (q15_t)0x80b4, (q15_t)0xd5a, (q15_t)0x80b3, + (q15_t)0xd53, (q15_t)0x80b3, (q15_t)0xd4d, (q15_t)0x80b2, (q15_t)0xd47, (q15_t)0x80b1, (q15_t)0xd41, (q15_t)0x80b1, + (q15_t)0xd3a, (q15_t)0x80b0, (q15_t)0xd34, (q15_t)0x80af, (q15_t)0xd2e, (q15_t)0x80af, (q15_t)0xd28, (q15_t)0x80ae, + (q15_t)0xd21, (q15_t)0x80ad, (q15_t)0xd1b, (q15_t)0x80ad, (q15_t)0xd15, (q15_t)0x80ac, (q15_t)0xd0f, (q15_t)0x80ab, + (q15_t)0xd08, (q15_t)0x80ab, (q15_t)0xd02, (q15_t)0x80aa, (q15_t)0xcfc, (q15_t)0x80aa, (q15_t)0xcf6, (q15_t)0x80a9, + (q15_t)0xcef, (q15_t)0x80a8, (q15_t)0xce9, (q15_t)0x80a8, (q15_t)0xce3, (q15_t)0x80a7, (q15_t)0xcdd, (q15_t)0x80a6, + (q15_t)0xcd6, (q15_t)0x80a6, (q15_t)0xcd0, (q15_t)0x80a5, (q15_t)0xcca, (q15_t)0x80a5, (q15_t)0xcc4, (q15_t)0x80a4, + (q15_t)0xcbd, (q15_t)0x80a3, (q15_t)0xcb7, (q15_t)0x80a3, (q15_t)0xcb1, (q15_t)0x80a2, (q15_t)0xcab, (q15_t)0x80a1, + (q15_t)0xca4, (q15_t)0x80a1, (q15_t)0xc9e, (q15_t)0x80a0, (q15_t)0xc98, (q15_t)0x80a0, (q15_t)0xc92, (q15_t)0x809f, + (q15_t)0xc8b, (q15_t)0x809e, (q15_t)0xc85, (q15_t)0x809e, (q15_t)0xc7f, (q15_t)0x809d, (q15_t)0xc79, (q15_t)0x809c, + (q15_t)0xc72, (q15_t)0x809c, (q15_t)0xc6c, (q15_t)0x809b, (q15_t)0xc66, (q15_t)0x809b, (q15_t)0xc60, (q15_t)0x809a, + (q15_t)0xc59, (q15_t)0x8099, (q15_t)0xc53, (q15_t)0x8099, (q15_t)0xc4d, (q15_t)0x8098, (q15_t)0xc47, (q15_t)0x8098, + (q15_t)0xc40, (q15_t)0x8097, (q15_t)0xc3a, (q15_t)0x8096, (q15_t)0xc34, (q15_t)0x8096, (q15_t)0xc2e, (q15_t)0x8095, + (q15_t)0xc27, (q15_t)0x8095, (q15_t)0xc21, (q15_t)0x8094, (q15_t)0xc1b, (q15_t)0x8093, (q15_t)0xc14, (q15_t)0x8093, + (q15_t)0xc0e, (q15_t)0x8092, (q15_t)0xc08, (q15_t)0x8092, (q15_t)0xc02, (q15_t)0x8091, (q15_t)0xbfb, (q15_t)0x8090, + (q15_t)0xbf5, (q15_t)0x8090, (q15_t)0xbef, (q15_t)0x808f, (q15_t)0xbe9, (q15_t)0x808f, (q15_t)0xbe2, (q15_t)0x808e, + (q15_t)0xbdc, (q15_t)0x808e, (q15_t)0xbd6, (q15_t)0x808d, (q15_t)0xbd0, (q15_t)0x808c, (q15_t)0xbc9, (q15_t)0x808c, + (q15_t)0xbc3, (q15_t)0x808b, (q15_t)0xbbd, (q15_t)0x808b, (q15_t)0xbb7, (q15_t)0x808a, (q15_t)0xbb0, (q15_t)0x8089, + (q15_t)0xbaa, (q15_t)0x8089, (q15_t)0xba4, (q15_t)0x8088, (q15_t)0xb9e, (q15_t)0x8088, (q15_t)0xb97, (q15_t)0x8087, + (q15_t)0xb91, (q15_t)0x8087, (q15_t)0xb8b, (q15_t)0x8086, (q15_t)0xb85, (q15_t)0x8085, (q15_t)0xb7e, (q15_t)0x8085, + (q15_t)0xb78, (q15_t)0x8084, (q15_t)0xb72, (q15_t)0x8084, (q15_t)0xb6c, (q15_t)0x8083, (q15_t)0xb65, (q15_t)0x8083, + (q15_t)0xb5f, (q15_t)0x8082, (q15_t)0xb59, (q15_t)0x8082, (q15_t)0xb53, (q15_t)0x8081, (q15_t)0xb4c, (q15_t)0x8080, + (q15_t)0xb46, (q15_t)0x8080, (q15_t)0xb40, (q15_t)0x807f, (q15_t)0xb3a, (q15_t)0x807f, (q15_t)0xb33, (q15_t)0x807e, + (q15_t)0xb2d, (q15_t)0x807e, (q15_t)0xb27, (q15_t)0x807d, (q15_t)0xb20, (q15_t)0x807d, (q15_t)0xb1a, (q15_t)0x807c, + (q15_t)0xb14, (q15_t)0x807b, (q15_t)0xb0e, (q15_t)0x807b, (q15_t)0xb07, (q15_t)0x807a, (q15_t)0xb01, (q15_t)0x807a, + (q15_t)0xafb, (q15_t)0x8079, (q15_t)0xaf5, (q15_t)0x8079, (q15_t)0xaee, (q15_t)0x8078, (q15_t)0xae8, (q15_t)0x8078, + (q15_t)0xae2, (q15_t)0x8077, (q15_t)0xadc, (q15_t)0x8077, (q15_t)0xad5, (q15_t)0x8076, (q15_t)0xacf, (q15_t)0x8076, + (q15_t)0xac9, (q15_t)0x8075, (q15_t)0xac3, (q15_t)0x8075, (q15_t)0xabc, (q15_t)0x8074, (q15_t)0xab6, (q15_t)0x8073, + (q15_t)0xab0, (q15_t)0x8073, (q15_t)0xaaa, (q15_t)0x8072, (q15_t)0xaa3, (q15_t)0x8072, (q15_t)0xa9d, (q15_t)0x8071, + (q15_t)0xa97, (q15_t)0x8071, (q15_t)0xa90, (q15_t)0x8070, (q15_t)0xa8a, (q15_t)0x8070, (q15_t)0xa84, (q15_t)0x806f, + (q15_t)0xa7e, (q15_t)0x806f, (q15_t)0xa77, (q15_t)0x806e, (q15_t)0xa71, (q15_t)0x806e, (q15_t)0xa6b, (q15_t)0x806d, + (q15_t)0xa65, (q15_t)0x806d, (q15_t)0xa5e, (q15_t)0x806c, (q15_t)0xa58, (q15_t)0x806c, (q15_t)0xa52, (q15_t)0x806b, + (q15_t)0xa4c, (q15_t)0x806b, (q15_t)0xa45, (q15_t)0x806a, (q15_t)0xa3f, (q15_t)0x806a, (q15_t)0xa39, (q15_t)0x8069, + (q15_t)0xa33, (q15_t)0x8069, (q15_t)0xa2c, (q15_t)0x8068, (q15_t)0xa26, (q15_t)0x8068, (q15_t)0xa20, (q15_t)0x8067, + (q15_t)0xa19, (q15_t)0x8067, (q15_t)0xa13, (q15_t)0x8066, (q15_t)0xa0d, (q15_t)0x8066, (q15_t)0xa07, (q15_t)0x8065, + (q15_t)0xa00, (q15_t)0x8065, (q15_t)0x9fa, (q15_t)0x8064, (q15_t)0x9f4, (q15_t)0x8064, (q15_t)0x9ee, (q15_t)0x8063, + (q15_t)0x9e7, (q15_t)0x8063, (q15_t)0x9e1, (q15_t)0x8062, (q15_t)0x9db, (q15_t)0x8062, (q15_t)0x9d5, (q15_t)0x8061, + (q15_t)0x9ce, (q15_t)0x8061, (q15_t)0x9c8, (q15_t)0x8060, (q15_t)0x9c2, (q15_t)0x8060, (q15_t)0x9bc, (q15_t)0x805f, + (q15_t)0x9b5, (q15_t)0x805f, (q15_t)0x9af, (q15_t)0x805e, (q15_t)0x9a9, (q15_t)0x805e, (q15_t)0x9a2, (q15_t)0x805d, + (q15_t)0x99c, (q15_t)0x805d, (q15_t)0x996, (q15_t)0x805d, (q15_t)0x990, (q15_t)0x805c, (q15_t)0x989, (q15_t)0x805c, + (q15_t)0x983, (q15_t)0x805b, (q15_t)0x97d, (q15_t)0x805b, (q15_t)0x977, (q15_t)0x805a, (q15_t)0x970, (q15_t)0x805a, + (q15_t)0x96a, (q15_t)0x8059, (q15_t)0x964, (q15_t)0x8059, (q15_t)0x95e, (q15_t)0x8058, (q15_t)0x957, (q15_t)0x8058, + (q15_t)0x951, (q15_t)0x8057, (q15_t)0x94b, (q15_t)0x8057, (q15_t)0x944, (q15_t)0x8057, (q15_t)0x93e, (q15_t)0x8056, + (q15_t)0x938, (q15_t)0x8056, (q15_t)0x932, (q15_t)0x8055, (q15_t)0x92b, (q15_t)0x8055, (q15_t)0x925, (q15_t)0x8054, + (q15_t)0x91f, (q15_t)0x8054, (q15_t)0x919, (q15_t)0x8053, (q15_t)0x912, (q15_t)0x8053, (q15_t)0x90c, (q15_t)0x8052, + (q15_t)0x906, (q15_t)0x8052, (q15_t)0x900, (q15_t)0x8052, (q15_t)0x8f9, (q15_t)0x8051, (q15_t)0x8f3, (q15_t)0x8051, + (q15_t)0x8ed, (q15_t)0x8050, (q15_t)0x8e6, (q15_t)0x8050, (q15_t)0x8e0, (q15_t)0x804f, (q15_t)0x8da, (q15_t)0x804f, + (q15_t)0x8d4, (q15_t)0x804f, (q15_t)0x8cd, (q15_t)0x804e, (q15_t)0x8c7, (q15_t)0x804e, (q15_t)0x8c1, (q15_t)0x804d, + (q15_t)0x8bb, (q15_t)0x804d, (q15_t)0x8b4, (q15_t)0x804c, (q15_t)0x8ae, (q15_t)0x804c, (q15_t)0x8a8, (q15_t)0x804c, + (q15_t)0x8a2, (q15_t)0x804b, (q15_t)0x89b, (q15_t)0x804b, (q15_t)0x895, (q15_t)0x804a, (q15_t)0x88f, (q15_t)0x804a, + (q15_t)0x888, (q15_t)0x8049, (q15_t)0x882, (q15_t)0x8049, (q15_t)0x87c, (q15_t)0x8049, (q15_t)0x876, (q15_t)0x8048, + (q15_t)0x86f, (q15_t)0x8048, (q15_t)0x869, (q15_t)0x8047, (q15_t)0x863, (q15_t)0x8047, (q15_t)0x85d, (q15_t)0x8047, + (q15_t)0x856, (q15_t)0x8046, (q15_t)0x850, (q15_t)0x8046, (q15_t)0x84a, (q15_t)0x8045, (q15_t)0x843, (q15_t)0x8045, + (q15_t)0x83d, (q15_t)0x8044, (q15_t)0x837, (q15_t)0x8044, (q15_t)0x831, (q15_t)0x8044, (q15_t)0x82a, (q15_t)0x8043, + (q15_t)0x824, (q15_t)0x8043, (q15_t)0x81e, (q15_t)0x8042, (q15_t)0x818, (q15_t)0x8042, (q15_t)0x811, (q15_t)0x8042, + (q15_t)0x80b, (q15_t)0x8041, (q15_t)0x805, (q15_t)0x8041, (q15_t)0x7fe, (q15_t)0x8040, (q15_t)0x7f8, (q15_t)0x8040, + (q15_t)0x7f2, (q15_t)0x8040, (q15_t)0x7ec, (q15_t)0x803f, (q15_t)0x7e5, (q15_t)0x803f, (q15_t)0x7df, (q15_t)0x803f, + (q15_t)0x7d9, (q15_t)0x803e, (q15_t)0x7d3, (q15_t)0x803e, (q15_t)0x7cc, (q15_t)0x803d, (q15_t)0x7c6, (q15_t)0x803d, + (q15_t)0x7c0, (q15_t)0x803d, (q15_t)0x7ba, (q15_t)0x803c, (q15_t)0x7b3, (q15_t)0x803c, (q15_t)0x7ad, (q15_t)0x803b, + (q15_t)0x7a7, (q15_t)0x803b, (q15_t)0x7a0, (q15_t)0x803b, (q15_t)0x79a, (q15_t)0x803a, (q15_t)0x794, (q15_t)0x803a, + (q15_t)0x78e, (q15_t)0x803a, (q15_t)0x787, (q15_t)0x8039, (q15_t)0x781, (q15_t)0x8039, (q15_t)0x77b, (q15_t)0x8039, + (q15_t)0x775, (q15_t)0x8038, (q15_t)0x76e, (q15_t)0x8038, (q15_t)0x768, (q15_t)0x8037, (q15_t)0x762, (q15_t)0x8037, + (q15_t)0x75b, (q15_t)0x8037, (q15_t)0x755, (q15_t)0x8036, (q15_t)0x74f, (q15_t)0x8036, (q15_t)0x749, (q15_t)0x8036, + (q15_t)0x742, (q15_t)0x8035, (q15_t)0x73c, (q15_t)0x8035, (q15_t)0x736, (q15_t)0x8035, (q15_t)0x730, (q15_t)0x8034, + (q15_t)0x729, (q15_t)0x8034, (q15_t)0x723, (q15_t)0x8033, (q15_t)0x71d, (q15_t)0x8033, (q15_t)0x716, (q15_t)0x8033, + (q15_t)0x710, (q15_t)0x8032, (q15_t)0x70a, (q15_t)0x8032, (q15_t)0x704, (q15_t)0x8032, (q15_t)0x6fd, (q15_t)0x8031, + (q15_t)0x6f7, (q15_t)0x8031, (q15_t)0x6f1, (q15_t)0x8031, (q15_t)0x6ea, (q15_t)0x8030, (q15_t)0x6e4, (q15_t)0x8030, + (q15_t)0x6de, (q15_t)0x8030, (q15_t)0x6d8, (q15_t)0x802f, (q15_t)0x6d1, (q15_t)0x802f, (q15_t)0x6cb, (q15_t)0x802f, + (q15_t)0x6c5, (q15_t)0x802e, (q15_t)0x6bf, (q15_t)0x802e, (q15_t)0x6b8, (q15_t)0x802e, (q15_t)0x6b2, (q15_t)0x802d, + (q15_t)0x6ac, (q15_t)0x802d, (q15_t)0x6a5, (q15_t)0x802d, (q15_t)0x69f, (q15_t)0x802c, (q15_t)0x699, (q15_t)0x802c, + (q15_t)0x693, (q15_t)0x802c, (q15_t)0x68c, (q15_t)0x802b, (q15_t)0x686, (q15_t)0x802b, (q15_t)0x680, (q15_t)0x802b, + (q15_t)0x67a, (q15_t)0x802a, (q15_t)0x673, (q15_t)0x802a, (q15_t)0x66d, (q15_t)0x802a, (q15_t)0x667, (q15_t)0x802a, + (q15_t)0x660, (q15_t)0x8029, (q15_t)0x65a, (q15_t)0x8029, (q15_t)0x654, (q15_t)0x8029, (q15_t)0x64e, (q15_t)0x8028, + (q15_t)0x647, (q15_t)0x8028, (q15_t)0x641, (q15_t)0x8028, (q15_t)0x63b, (q15_t)0x8027, (q15_t)0x635, (q15_t)0x8027, + (q15_t)0x62e, (q15_t)0x8027, (q15_t)0x628, (q15_t)0x8026, (q15_t)0x622, (q15_t)0x8026, (q15_t)0x61b, (q15_t)0x8026, + (q15_t)0x615, (q15_t)0x8026, (q15_t)0x60f, (q15_t)0x8025, (q15_t)0x609, (q15_t)0x8025, (q15_t)0x602, (q15_t)0x8025, + (q15_t)0x5fc, (q15_t)0x8024, (q15_t)0x5f6, (q15_t)0x8024, (q15_t)0x5ef, (q15_t)0x8024, (q15_t)0x5e9, (q15_t)0x8023, + (q15_t)0x5e3, (q15_t)0x8023, (q15_t)0x5dd, (q15_t)0x8023, (q15_t)0x5d6, (q15_t)0x8023, (q15_t)0x5d0, (q15_t)0x8022, + (q15_t)0x5ca, (q15_t)0x8022, (q15_t)0x5c4, (q15_t)0x8022, (q15_t)0x5bd, (q15_t)0x8021, (q15_t)0x5b7, (q15_t)0x8021, + (q15_t)0x5b1, (q15_t)0x8021, (q15_t)0x5aa, (q15_t)0x8021, (q15_t)0x5a4, (q15_t)0x8020, (q15_t)0x59e, (q15_t)0x8020, + (q15_t)0x598, (q15_t)0x8020, (q15_t)0x591, (q15_t)0x8020, (q15_t)0x58b, (q15_t)0x801f, (q15_t)0x585, (q15_t)0x801f, + (q15_t)0x57f, (q15_t)0x801f, (q15_t)0x578, (q15_t)0x801e, (q15_t)0x572, (q15_t)0x801e, (q15_t)0x56c, (q15_t)0x801e, + (q15_t)0x565, (q15_t)0x801e, (q15_t)0x55f, (q15_t)0x801d, (q15_t)0x559, (q15_t)0x801d, (q15_t)0x553, (q15_t)0x801d, + (q15_t)0x54c, (q15_t)0x801d, (q15_t)0x546, (q15_t)0x801c, (q15_t)0x540, (q15_t)0x801c, (q15_t)0x539, (q15_t)0x801c, + (q15_t)0x533, (q15_t)0x801c, (q15_t)0x52d, (q15_t)0x801b, (q15_t)0x527, (q15_t)0x801b, (q15_t)0x520, (q15_t)0x801b, + (q15_t)0x51a, (q15_t)0x801b, (q15_t)0x514, (q15_t)0x801a, (q15_t)0x50d, (q15_t)0x801a, (q15_t)0x507, (q15_t)0x801a, + (q15_t)0x501, (q15_t)0x801a, (q15_t)0x4fb, (q15_t)0x8019, (q15_t)0x4f4, (q15_t)0x8019, (q15_t)0x4ee, (q15_t)0x8019, + (q15_t)0x4e8, (q15_t)0x8019, (q15_t)0x4e2, (q15_t)0x8018, (q15_t)0x4db, (q15_t)0x8018, (q15_t)0x4d5, (q15_t)0x8018, + (q15_t)0x4cf, (q15_t)0x8018, (q15_t)0x4c8, (q15_t)0x8017, (q15_t)0x4c2, (q15_t)0x8017, (q15_t)0x4bc, (q15_t)0x8017, + (q15_t)0x4b6, (q15_t)0x8017, (q15_t)0x4af, (q15_t)0x8016, (q15_t)0x4a9, (q15_t)0x8016, (q15_t)0x4a3, (q15_t)0x8016, + (q15_t)0x49c, (q15_t)0x8016, (q15_t)0x496, (q15_t)0x8016, (q15_t)0x490, (q15_t)0x8015, (q15_t)0x48a, (q15_t)0x8015, + (q15_t)0x483, (q15_t)0x8015, (q15_t)0x47d, (q15_t)0x8015, (q15_t)0x477, (q15_t)0x8014, (q15_t)0x471, (q15_t)0x8014, + (q15_t)0x46a, (q15_t)0x8014, (q15_t)0x464, (q15_t)0x8014, (q15_t)0x45e, (q15_t)0x8014, (q15_t)0x457, (q15_t)0x8013, + (q15_t)0x451, (q15_t)0x8013, (q15_t)0x44b, (q15_t)0x8013, (q15_t)0x445, (q15_t)0x8013, (q15_t)0x43e, (q15_t)0x8013, + (q15_t)0x438, (q15_t)0x8012, (q15_t)0x432, (q15_t)0x8012, (q15_t)0x42b, (q15_t)0x8012, (q15_t)0x425, (q15_t)0x8012, + (q15_t)0x41f, (q15_t)0x8012, (q15_t)0x419, (q15_t)0x8011, (q15_t)0x412, (q15_t)0x8011, (q15_t)0x40c, (q15_t)0x8011, + (q15_t)0x406, (q15_t)0x8011, (q15_t)0x3ff, (q15_t)0x8011, (q15_t)0x3f9, (q15_t)0x8010, (q15_t)0x3f3, (q15_t)0x8010, + (q15_t)0x3ed, (q15_t)0x8010, (q15_t)0x3e6, (q15_t)0x8010, (q15_t)0x3e0, (q15_t)0x8010, (q15_t)0x3da, (q15_t)0x800f, + (q15_t)0x3d4, (q15_t)0x800f, (q15_t)0x3cd, (q15_t)0x800f, (q15_t)0x3c7, (q15_t)0x800f, (q15_t)0x3c1, (q15_t)0x800f, + (q15_t)0x3ba, (q15_t)0x800e, (q15_t)0x3b4, (q15_t)0x800e, (q15_t)0x3ae, (q15_t)0x800e, (q15_t)0x3a8, (q15_t)0x800e, + (q15_t)0x3a1, (q15_t)0x800e, (q15_t)0x39b, (q15_t)0x800e, (q15_t)0x395, (q15_t)0x800d, (q15_t)0x38e, (q15_t)0x800d, + (q15_t)0x388, (q15_t)0x800d, (q15_t)0x382, (q15_t)0x800d, (q15_t)0x37c, (q15_t)0x800d, (q15_t)0x375, (q15_t)0x800c, + (q15_t)0x36f, (q15_t)0x800c, (q15_t)0x369, (q15_t)0x800c, (q15_t)0x362, (q15_t)0x800c, (q15_t)0x35c, (q15_t)0x800c, + (q15_t)0x356, (q15_t)0x800c, (q15_t)0x350, (q15_t)0x800b, (q15_t)0x349, (q15_t)0x800b, (q15_t)0x343, (q15_t)0x800b, + (q15_t)0x33d, (q15_t)0x800b, (q15_t)0x337, (q15_t)0x800b, (q15_t)0x330, (q15_t)0x800b, (q15_t)0x32a, (q15_t)0x800b, + (q15_t)0x324, (q15_t)0x800a, (q15_t)0x31d, (q15_t)0x800a, (q15_t)0x317, (q15_t)0x800a, (q15_t)0x311, (q15_t)0x800a, + (q15_t)0x30b, (q15_t)0x800a, (q15_t)0x304, (q15_t)0x800a, (q15_t)0x2fe, (q15_t)0x8009, (q15_t)0x2f8, (q15_t)0x8009, + (q15_t)0x2f1, (q15_t)0x8009, (q15_t)0x2eb, (q15_t)0x8009, (q15_t)0x2e5, (q15_t)0x8009, (q15_t)0x2df, (q15_t)0x8009, + (q15_t)0x2d8, (q15_t)0x8009, (q15_t)0x2d2, (q15_t)0x8008, (q15_t)0x2cc, (q15_t)0x8008, (q15_t)0x2c5, (q15_t)0x8008, + (q15_t)0x2bf, (q15_t)0x8008, (q15_t)0x2b9, (q15_t)0x8008, (q15_t)0x2b3, (q15_t)0x8008, (q15_t)0x2ac, (q15_t)0x8008, + (q15_t)0x2a6, (q15_t)0x8008, (q15_t)0x2a0, (q15_t)0x8007, (q15_t)0x299, (q15_t)0x8007, (q15_t)0x293, (q15_t)0x8007, + (q15_t)0x28d, (q15_t)0x8007, (q15_t)0x287, (q15_t)0x8007, (q15_t)0x280, (q15_t)0x8007, (q15_t)0x27a, (q15_t)0x8007, + (q15_t)0x274, (q15_t)0x8007, (q15_t)0x26d, (q15_t)0x8006, (q15_t)0x267, (q15_t)0x8006, (q15_t)0x261, (q15_t)0x8006, + (q15_t)0x25b, (q15_t)0x8006, (q15_t)0x254, (q15_t)0x8006, (q15_t)0x24e, (q15_t)0x8006, (q15_t)0x248, (q15_t)0x8006, + (q15_t)0x242, (q15_t)0x8006, (q15_t)0x23b, (q15_t)0x8005, (q15_t)0x235, (q15_t)0x8005, (q15_t)0x22f, (q15_t)0x8005, + (q15_t)0x228, (q15_t)0x8005, (q15_t)0x222, (q15_t)0x8005, (q15_t)0x21c, (q15_t)0x8005, (q15_t)0x216, (q15_t)0x8005, + (q15_t)0x20f, (q15_t)0x8005, (q15_t)0x209, (q15_t)0x8005, (q15_t)0x203, (q15_t)0x8005, (q15_t)0x1fc, (q15_t)0x8004, + (q15_t)0x1f6, (q15_t)0x8004, (q15_t)0x1f0, (q15_t)0x8004, (q15_t)0x1ea, (q15_t)0x8004, (q15_t)0x1e3, (q15_t)0x8004, + (q15_t)0x1dd, (q15_t)0x8004, (q15_t)0x1d7, (q15_t)0x8004, (q15_t)0x1d0, (q15_t)0x8004, (q15_t)0x1ca, (q15_t)0x8004, + (q15_t)0x1c4, (q15_t)0x8004, (q15_t)0x1be, (q15_t)0x8004, (q15_t)0x1b7, (q15_t)0x8003, (q15_t)0x1b1, (q15_t)0x8003, + (q15_t)0x1ab, (q15_t)0x8003, (q15_t)0x1a4, (q15_t)0x8003, (q15_t)0x19e, (q15_t)0x8003, (q15_t)0x198, (q15_t)0x8003, + (q15_t)0x192, (q15_t)0x8003, (q15_t)0x18b, (q15_t)0x8003, (q15_t)0x185, (q15_t)0x8003, (q15_t)0x17f, (q15_t)0x8003, + (q15_t)0x178, (q15_t)0x8003, (q15_t)0x172, (q15_t)0x8003, (q15_t)0x16c, (q15_t)0x8003, (q15_t)0x166, (q15_t)0x8002, + (q15_t)0x15f, (q15_t)0x8002, (q15_t)0x159, (q15_t)0x8002, (q15_t)0x153, (q15_t)0x8002, (q15_t)0x14d, (q15_t)0x8002, + (q15_t)0x146, (q15_t)0x8002, (q15_t)0x140, (q15_t)0x8002, (q15_t)0x13a, (q15_t)0x8002, (q15_t)0x133, (q15_t)0x8002, + (q15_t)0x12d, (q15_t)0x8002, (q15_t)0x127, (q15_t)0x8002, (q15_t)0x121, (q15_t)0x8002, (q15_t)0x11a, (q15_t)0x8002, + (q15_t)0x114, (q15_t)0x8002, (q15_t)0x10e, (q15_t)0x8002, (q15_t)0x107, (q15_t)0x8002, (q15_t)0x101, (q15_t)0x8002, + (q15_t)0xfb, (q15_t)0x8001, (q15_t)0xf5, (q15_t)0x8001, (q15_t)0xee, (q15_t)0x8001, (q15_t)0xe8, (q15_t)0x8001, + (q15_t)0xe2, (q15_t)0x8001, (q15_t)0xdb, (q15_t)0x8001, (q15_t)0xd5, (q15_t)0x8001, (q15_t)0xcf, (q15_t)0x8001, + (q15_t)0xc9, (q15_t)0x8001, (q15_t)0xc2, (q15_t)0x8001, (q15_t)0xbc, (q15_t)0x8001, (q15_t)0xb6, (q15_t)0x8001, + (q15_t)0xaf, (q15_t)0x8001, (q15_t)0xa9, (q15_t)0x8001, (q15_t)0xa3, (q15_t)0x8001, (q15_t)0x9d, (q15_t)0x8001, + (q15_t)0x96, (q15_t)0x8001, (q15_t)0x90, (q15_t)0x8001, (q15_t)0x8a, (q15_t)0x8001, (q15_t)0x83, (q15_t)0x8001, + (q15_t)0x7d, (q15_t)0x8001, (q15_t)0x77, (q15_t)0x8001, (q15_t)0x71, (q15_t)0x8001, (q15_t)0x6a, (q15_t)0x8001, + (q15_t)0x64, (q15_t)0x8001, (q15_t)0x5e, (q15_t)0x8001, (q15_t)0x57, (q15_t)0x8001, (q15_t)0x51, (q15_t)0x8001, + (q15_t)0x4b, (q15_t)0x8001, (q15_t)0x45, (q15_t)0x8001, (q15_t)0x3e, (q15_t)0x8001, (q15_t)0x38, (q15_t)0x8001, + (q15_t)0x32, (q15_t)0x8001, (q15_t)0x2b, (q15_t)0x8001, (q15_t)0x25, (q15_t)0x8001, (q15_t)0x1f, (q15_t)0x8001, + (q15_t)0x19, (q15_t)0x8001, (q15_t)0x12, (q15_t)0x8001, (q15_t)0xc, (q15_t)0x8001, (q15_t)0x6, (q15_t)0x8001 +}; + + +/** +* \par +* cosFactor tables are generated using the formula :
 cos_factors[n] = 2 * cos((2n+1)*pi/(4*N)) 
+* \par +* C command to generate the table +*
+* for(i = 0; i< N; i++)
+* {
+*   cos_factors[i]= 2 * cos((2*i+1)*c/2);
+* } 
+* \par +* where N is the number of factors to generate and c is pi/(2*N) +* \par +* Then converted to q15 format by multiplying with 2^31 and saturated if required. + +*/ + +static const q15_t ALIGN4 cos_factorsQ15_128[128] = { + (q15_t)0x7fff, (q15_t)0x7ffa, (q15_t)0x7ff0, (q15_t)0x7fe1, (q15_t)0x7fce, (q15_t)0x7fb5, (q15_t)0x7f97, (q15_t)0x7f75, + (q15_t)0x7f4d, (q15_t)0x7f21, (q15_t)0x7ef0, (q15_t)0x7eba, (q15_t)0x7e7f, (q15_t)0x7e3f, (q15_t)0x7dfa, (q15_t)0x7db0, + (q15_t)0x7d62, (q15_t)0x7d0f, (q15_t)0x7cb7, (q15_t)0x7c5a, (q15_t)0x7bf8, (q15_t)0x7b92, (q15_t)0x7b26, (q15_t)0x7ab6, + (q15_t)0x7a42, (q15_t)0x79c8, (q15_t)0x794a, (q15_t)0x78c7, (q15_t)0x7840, (q15_t)0x77b4, (q15_t)0x7723, (q15_t)0x768e, + (q15_t)0x75f4, (q15_t)0x7555, (q15_t)0x74b2, (q15_t)0x740b, (q15_t)0x735f, (q15_t)0x72af, (q15_t)0x71fa, (q15_t)0x7141, + (q15_t)0x7083, (q15_t)0x6fc1, (q15_t)0x6efb, (q15_t)0x6e30, (q15_t)0x6d62, (q15_t)0x6c8f, (q15_t)0x6bb8, (q15_t)0x6adc, + (q15_t)0x69fd, (q15_t)0x6919, (q15_t)0x6832, (q15_t)0x6746, (q15_t)0x6657, (q15_t)0x6563, (q15_t)0x646c, (q15_t)0x6371, + (q15_t)0x6271, (q15_t)0x616f, (q15_t)0x6068, (q15_t)0x5f5e, (q15_t)0x5e50, (q15_t)0x5d3e, (q15_t)0x5c29, (q15_t)0x5b10, + (q15_t)0x59f3, (q15_t)0x58d4, (q15_t)0x57b0, (q15_t)0x568a, (q15_t)0x5560, (q15_t)0x5433, (q15_t)0x5302, (q15_t)0x51ce, + (q15_t)0x5097, (q15_t)0x4f5e, (q15_t)0x4e21, (q15_t)0x4ce1, (q15_t)0x4b9e, (q15_t)0x4a58, (q15_t)0x490f, (q15_t)0x47c3, + (q15_t)0x4675, (q15_t)0x4524, (q15_t)0x43d0, (q15_t)0x427a, (q15_t)0x4121, (q15_t)0x3fc5, (q15_t)0x3e68, (q15_t)0x3d07, + (q15_t)0x3ba5, (q15_t)0x3a40, (q15_t)0x38d8, (q15_t)0x376f, (q15_t)0x3604, (q15_t)0x3496, (q15_t)0x3326, (q15_t)0x31b5, + (q15_t)0x3041, (q15_t)0x2ecc, (q15_t)0x2d55, (q15_t)0x2bdc, (q15_t)0x2a61, (q15_t)0x28e5, (q15_t)0x2767, (q15_t)0x25e8, + (q15_t)0x2467, (q15_t)0x22e5, (q15_t)0x2161, (q15_t)0x1fdc, (q15_t)0x1e56, (q15_t)0x1ccf, (q15_t)0x1b47, (q15_t)0x19bd, + (q15_t)0x1833, (q15_t)0x16a8, (q15_t)0x151b, (q15_t)0x138e, (q15_t)0x1201, (q15_t)0x1072, (q15_t)0xee3, (q15_t)0xd53, + (q15_t)0xbc3, (q15_t)0xa33, (q15_t)0x8a2, (q15_t)0x710, (q15_t)0x57f, (q15_t)0x3ed, (q15_t)0x25b, (q15_t)0xc9 +}; + +static const q15_t ALIGN4 cos_factorsQ15_512[512] = { + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7ffe, (q15_t)0x7ffc, (q15_t)0x7ffb, (q15_t)0x7ff9, (q15_t)0x7ff7, + (q15_t)0x7ff4, (q15_t)0x7ff2, (q15_t)0x7fee, (q15_t)0x7feb, (q15_t)0x7fe7, (q15_t)0x7fe3, (q15_t)0x7fdf, (q15_t)0x7fda, + (q15_t)0x7fd6, (q15_t)0x7fd0, (q15_t)0x7fcb, (q15_t)0x7fc5, (q15_t)0x7fbf, (q15_t)0x7fb8, (q15_t)0x7fb1, (q15_t)0x7faa, + (q15_t)0x7fa3, (q15_t)0x7f9b, (q15_t)0x7f93, (q15_t)0x7f8b, (q15_t)0x7f82, (q15_t)0x7f79, (q15_t)0x7f70, (q15_t)0x7f67, + (q15_t)0x7f5d, (q15_t)0x7f53, (q15_t)0x7f48, (q15_t)0x7f3d, (q15_t)0x7f32, (q15_t)0x7f27, (q15_t)0x7f1b, (q15_t)0x7f0f, + (q15_t)0x7f03, (q15_t)0x7ef6, (q15_t)0x7ee9, (q15_t)0x7edc, (q15_t)0x7ecf, (q15_t)0x7ec1, (q15_t)0x7eb3, (q15_t)0x7ea4, + (q15_t)0x7e95, (q15_t)0x7e86, (q15_t)0x7e77, (q15_t)0x7e67, (q15_t)0x7e57, (q15_t)0x7e47, (q15_t)0x7e37, (q15_t)0x7e26, + (q15_t)0x7e14, (q15_t)0x7e03, (q15_t)0x7df1, (q15_t)0x7ddf, (q15_t)0x7dcd, (q15_t)0x7dba, (q15_t)0x7da7, (q15_t)0x7d94, + (q15_t)0x7d80, (q15_t)0x7d6c, (q15_t)0x7d58, (q15_t)0x7d43, (q15_t)0x7d2f, (q15_t)0x7d19, (q15_t)0x7d04, (q15_t)0x7cee, + (q15_t)0x7cd8, (q15_t)0x7cc2, (q15_t)0x7cab, (q15_t)0x7c94, (q15_t)0x7c7d, (q15_t)0x7c66, (q15_t)0x7c4e, (q15_t)0x7c36, + (q15_t)0x7c1d, (q15_t)0x7c05, (q15_t)0x7beb, (q15_t)0x7bd2, (q15_t)0x7bb9, (q15_t)0x7b9f, (q15_t)0x7b84, (q15_t)0x7b6a, + (q15_t)0x7b4f, (q15_t)0x7b34, (q15_t)0x7b19, (q15_t)0x7afd, (q15_t)0x7ae1, (q15_t)0x7ac5, (q15_t)0x7aa8, (q15_t)0x7a8b, + (q15_t)0x7a6e, (q15_t)0x7a50, (q15_t)0x7a33, (q15_t)0x7a15, (q15_t)0x79f6, (q15_t)0x79d8, (q15_t)0x79b9, (q15_t)0x7999, + (q15_t)0x797a, (q15_t)0x795a, (q15_t)0x793a, (q15_t)0x7919, (q15_t)0x78f9, (q15_t)0x78d8, (q15_t)0x78b6, (q15_t)0x7895, + (q15_t)0x7873, (q15_t)0x7851, (q15_t)0x782e, (q15_t)0x780c, (q15_t)0x77e9, (q15_t)0x77c5, (q15_t)0x77a2, (q15_t)0x777e, + (q15_t)0x775a, (q15_t)0x7735, (q15_t)0x7710, (q15_t)0x76eb, (q15_t)0x76c6, (q15_t)0x76a0, (q15_t)0x767b, (q15_t)0x7654, + (q15_t)0x762e, (q15_t)0x7607, (q15_t)0x75e0, (q15_t)0x75b9, (q15_t)0x7591, (q15_t)0x7569, (q15_t)0x7541, (q15_t)0x7519, + (q15_t)0x74f0, (q15_t)0x74c7, (q15_t)0x749e, (q15_t)0x7474, (q15_t)0x744a, (q15_t)0x7420, (q15_t)0x73f6, (q15_t)0x73cb, + (q15_t)0x73a0, (q15_t)0x7375, (q15_t)0x7349, (q15_t)0x731d, (q15_t)0x72f1, (q15_t)0x72c5, (q15_t)0x7298, (q15_t)0x726b, + (q15_t)0x723e, (q15_t)0x7211, (q15_t)0x71e3, (q15_t)0x71b5, (q15_t)0x7186, (q15_t)0x7158, (q15_t)0x7129, (q15_t)0x70fa, + (q15_t)0x70cb, (q15_t)0x709b, (q15_t)0x706b, (q15_t)0x703b, (q15_t)0x700a, (q15_t)0x6fda, (q15_t)0x6fa9, (q15_t)0x6f77, + (q15_t)0x6f46, (q15_t)0x6f14, (q15_t)0x6ee2, (q15_t)0x6eaf, (q15_t)0x6e7d, (q15_t)0x6e4a, (q15_t)0x6e17, (q15_t)0x6de3, + (q15_t)0x6db0, (q15_t)0x6d7c, (q15_t)0x6d48, (q15_t)0x6d13, (q15_t)0x6cde, (q15_t)0x6ca9, (q15_t)0x6c74, (q15_t)0x6c3f, + (q15_t)0x6c09, (q15_t)0x6bd3, (q15_t)0x6b9c, (q15_t)0x6b66, (q15_t)0x6b2f, (q15_t)0x6af8, (q15_t)0x6ac1, (q15_t)0x6a89, + (q15_t)0x6a51, (q15_t)0x6a19, (q15_t)0x69e1, (q15_t)0x69a8, (q15_t)0x696f, (q15_t)0x6936, (q15_t)0x68fd, (q15_t)0x68c3, + (q15_t)0x6889, (q15_t)0x684f, (q15_t)0x6815, (q15_t)0x67da, (q15_t)0x679f, (q15_t)0x6764, (q15_t)0x6729, (q15_t)0x66ed, + (q15_t)0x66b1, (q15_t)0x6675, (q15_t)0x6639, (q15_t)0x65fc, (q15_t)0x65bf, (q15_t)0x6582, (q15_t)0x6545, (q15_t)0x6507, + (q15_t)0x64c9, (q15_t)0x648b, (q15_t)0x644d, (q15_t)0x640e, (q15_t)0x63cf, (q15_t)0x6390, (q15_t)0x6351, (q15_t)0x6311, + (q15_t)0x62d2, (q15_t)0x6292, (q15_t)0x6251, (q15_t)0x6211, (q15_t)0x61d0, (q15_t)0x618f, (q15_t)0x614e, (q15_t)0x610d, + (q15_t)0x60cb, (q15_t)0x6089, (q15_t)0x6047, (q15_t)0x6004, (q15_t)0x5fc2, (q15_t)0x5f7f, (q15_t)0x5f3c, (q15_t)0x5ef9, + (q15_t)0x5eb5, (q15_t)0x5e71, (q15_t)0x5e2d, (q15_t)0x5de9, (q15_t)0x5da5, (q15_t)0x5d60, (q15_t)0x5d1b, (q15_t)0x5cd6, + (q15_t)0x5c91, (q15_t)0x5c4b, (q15_t)0x5c06, (q15_t)0x5bc0, (q15_t)0x5b79, (q15_t)0x5b33, (q15_t)0x5aec, (q15_t)0x5aa5, + (q15_t)0x5a5e, (q15_t)0x5a17, (q15_t)0x59d0, (q15_t)0x5988, (q15_t)0x5940, (q15_t)0x58f8, (q15_t)0x58af, (q15_t)0x5867, + (q15_t)0x581e, (q15_t)0x57d5, (q15_t)0x578c, (q15_t)0x5742, (q15_t)0x56f9, (q15_t)0x56af, (q15_t)0x5665, (q15_t)0x561a, + (q15_t)0x55d0, (q15_t)0x5585, (q15_t)0x553a, (q15_t)0x54ef, (q15_t)0x54a4, (q15_t)0x5458, (q15_t)0x540d, (q15_t)0x53c1, + (q15_t)0x5375, (q15_t)0x5328, (q15_t)0x52dc, (q15_t)0x528f, (q15_t)0x5242, (q15_t)0x51f5, (q15_t)0x51a8, (q15_t)0x515a, + (q15_t)0x510c, (q15_t)0x50bf, (q15_t)0x5070, (q15_t)0x5022, (q15_t)0x4fd4, (q15_t)0x4f85, (q15_t)0x4f36, (q15_t)0x4ee7, + (q15_t)0x4e98, (q15_t)0x4e48, (q15_t)0x4df9, (q15_t)0x4da9, (q15_t)0x4d59, (q15_t)0x4d09, (q15_t)0x4cb8, (q15_t)0x4c68, + (q15_t)0x4c17, (q15_t)0x4bc6, (q15_t)0x4b75, (q15_t)0x4b24, (q15_t)0x4ad2, (q15_t)0x4a81, (q15_t)0x4a2f, (q15_t)0x49dd, + (q15_t)0x498a, (q15_t)0x4938, (q15_t)0x48e6, (q15_t)0x4893, (q15_t)0x4840, (q15_t)0x47ed, (q15_t)0x479a, (q15_t)0x4746, + (q15_t)0x46f3, (q15_t)0x469f, (q15_t)0x464b, (q15_t)0x45f7, (q15_t)0x45a3, (q15_t)0x454e, (q15_t)0x44fa, (q15_t)0x44a5, + (q15_t)0x4450, (q15_t)0x43fb, (q15_t)0x43a5, (q15_t)0x4350, (q15_t)0x42fa, (q15_t)0x42a5, (q15_t)0x424f, (q15_t)0x41f9, + (q15_t)0x41a2, (q15_t)0x414c, (q15_t)0x40f6, (q15_t)0x409f, (q15_t)0x4048, (q15_t)0x3ff1, (q15_t)0x3f9a, (q15_t)0x3f43, + (q15_t)0x3eeb, (q15_t)0x3e93, (q15_t)0x3e3c, (q15_t)0x3de4, (q15_t)0x3d8c, (q15_t)0x3d33, (q15_t)0x3cdb, (q15_t)0x3c83, + (q15_t)0x3c2a, (q15_t)0x3bd1, (q15_t)0x3b78, (q15_t)0x3b1f, (q15_t)0x3ac6, (q15_t)0x3a6c, (q15_t)0x3a13, (q15_t)0x39b9, + (q15_t)0x395f, (q15_t)0x3906, (q15_t)0x38ab, (q15_t)0x3851, (q15_t)0x37f7, (q15_t)0x379c, (q15_t)0x3742, (q15_t)0x36e7, + (q15_t)0x368c, (q15_t)0x3631, (q15_t)0x35d6, (q15_t)0x357b, (q15_t)0x351f, (q15_t)0x34c4, (q15_t)0x3468, (q15_t)0x340c, + (q15_t)0x33b0, (q15_t)0x3354, (q15_t)0x32f8, (q15_t)0x329c, (q15_t)0x3240, (q15_t)0x31e3, (q15_t)0x3186, (q15_t)0x312a, + (q15_t)0x30cd, (q15_t)0x3070, (q15_t)0x3013, (q15_t)0x2fb5, (q15_t)0x2f58, (q15_t)0x2efb, (q15_t)0x2e9d, (q15_t)0x2e3f, + (q15_t)0x2de2, (q15_t)0x2d84, (q15_t)0x2d26, (q15_t)0x2cc8, (q15_t)0x2c69, (q15_t)0x2c0b, (q15_t)0x2bad, (q15_t)0x2b4e, + (q15_t)0x2aef, (q15_t)0x2a91, (q15_t)0x2a32, (q15_t)0x29d3, (q15_t)0x2974, (q15_t)0x2915, (q15_t)0x28b5, (q15_t)0x2856, + (q15_t)0x27f6, (q15_t)0x2797, (q15_t)0x2737, (q15_t)0x26d8, (q15_t)0x2678, (q15_t)0x2618, (q15_t)0x25b8, (q15_t)0x2558, + (q15_t)0x24f7, (q15_t)0x2497, (q15_t)0x2437, (q15_t)0x23d6, (q15_t)0x2376, (q15_t)0x2315, (q15_t)0x22b4, (q15_t)0x2254, + (q15_t)0x21f3, (q15_t)0x2192, (q15_t)0x2131, (q15_t)0x20d0, (q15_t)0x206e, (q15_t)0x200d, (q15_t)0x1fac, (q15_t)0x1f4a, + (q15_t)0x1ee9, (q15_t)0x1e87, (q15_t)0x1e25, (q15_t)0x1dc4, (q15_t)0x1d62, (q15_t)0x1d00, (q15_t)0x1c9e, (q15_t)0x1c3c, + (q15_t)0x1bda, (q15_t)0x1b78, (q15_t)0x1b16, (q15_t)0x1ab3, (q15_t)0x1a51, (q15_t)0x19ef, (q15_t)0x198c, (q15_t)0x192a, + (q15_t)0x18c7, (q15_t)0x1864, (q15_t)0x1802, (q15_t)0x179f, (q15_t)0x173c, (q15_t)0x16d9, (q15_t)0x1676, (q15_t)0x1613, + (q15_t)0x15b0, (q15_t)0x154d, (q15_t)0x14ea, (q15_t)0x1487, (q15_t)0x1423, (q15_t)0x13c0, (q15_t)0x135d, (q15_t)0x12f9, + (q15_t)0x1296, (q15_t)0x1232, (q15_t)0x11cf, (q15_t)0x116b, (q15_t)0x1108, (q15_t)0x10a4, (q15_t)0x1040, (q15_t)0xfdd, + (q15_t)0xf79, (q15_t)0xf15, (q15_t)0xeb1, (q15_t)0xe4d, (q15_t)0xde9, (q15_t)0xd85, (q15_t)0xd21, (q15_t)0xcbd, + (q15_t)0xc59, (q15_t)0xbf5, (q15_t)0xb91, (q15_t)0xb2d, (q15_t)0xac9, (q15_t)0xa65, (q15_t)0xa00, (q15_t)0x99c, + (q15_t)0x938, (q15_t)0x8d4, (q15_t)0x86f, (q15_t)0x80b, (q15_t)0x7a7, (q15_t)0x742, (q15_t)0x6de, (q15_t)0x67a, + (q15_t)0x615, (q15_t)0x5b1, (q15_t)0x54c, (q15_t)0x4e8, (q15_t)0x483, (q15_t)0x41f, (q15_t)0x3ba, (q15_t)0x356, + (q15_t)0x2f1, (q15_t)0x28d, (q15_t)0x228, (q15_t)0x1c4, (q15_t)0x15f, (q15_t)0xfb, (q15_t)0x96, (q15_t)0x32 +}; + +static const q15_t ALIGN4 cos_factorsQ15_2048[2048] = { + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffd, (q15_t)0x7ffd, + (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffc, (q15_t)0x7ffc, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffa, + (q15_t)0x7ffa, (q15_t)0x7ff9, (q15_t)0x7ff9, (q15_t)0x7ff8, (q15_t)0x7ff8, (q15_t)0x7ff7, (q15_t)0x7ff7, (q15_t)0x7ff6, + (q15_t)0x7ff5, (q15_t)0x7ff5, (q15_t)0x7ff4, (q15_t)0x7ff3, (q15_t)0x7ff3, (q15_t)0x7ff2, (q15_t)0x7ff1, (q15_t)0x7ff0, + (q15_t)0x7ff0, (q15_t)0x7fef, (q15_t)0x7fee, (q15_t)0x7fed, (q15_t)0x7fec, (q15_t)0x7fec, (q15_t)0x7feb, (q15_t)0x7fea, + (q15_t)0x7fe9, (q15_t)0x7fe8, (q15_t)0x7fe7, (q15_t)0x7fe6, (q15_t)0x7fe5, (q15_t)0x7fe4, (q15_t)0x7fe3, (q15_t)0x7fe2, + (q15_t)0x7fe1, (q15_t)0x7fe0, (q15_t)0x7fdf, (q15_t)0x7fdd, (q15_t)0x7fdc, (q15_t)0x7fdb, (q15_t)0x7fda, (q15_t)0x7fd9, + (q15_t)0x7fd7, (q15_t)0x7fd6, (q15_t)0x7fd5, (q15_t)0x7fd4, (q15_t)0x7fd2, (q15_t)0x7fd1, (q15_t)0x7fd0, (q15_t)0x7fce, + (q15_t)0x7fcd, (q15_t)0x7fcb, (q15_t)0x7fca, (q15_t)0x7fc9, (q15_t)0x7fc7, (q15_t)0x7fc6, (q15_t)0x7fc4, (q15_t)0x7fc3, + (q15_t)0x7fc1, (q15_t)0x7fc0, (q15_t)0x7fbe, (q15_t)0x7fbc, (q15_t)0x7fbb, (q15_t)0x7fb9, (q15_t)0x7fb7, (q15_t)0x7fb6, + (q15_t)0x7fb4, (q15_t)0x7fb2, (q15_t)0x7fb1, (q15_t)0x7faf, (q15_t)0x7fad, (q15_t)0x7fab, (q15_t)0x7fa9, (q15_t)0x7fa8, + (q15_t)0x7fa6, (q15_t)0x7fa4, (q15_t)0x7fa2, (q15_t)0x7fa0, (q15_t)0x7f9e, (q15_t)0x7f9c, (q15_t)0x7f9a, (q15_t)0x7f98, + (q15_t)0x7f96, (q15_t)0x7f94, (q15_t)0x7f92, (q15_t)0x7f90, (q15_t)0x7f8e, (q15_t)0x7f8c, (q15_t)0x7f8a, (q15_t)0x7f88, + (q15_t)0x7f86, (q15_t)0x7f83, (q15_t)0x7f81, (q15_t)0x7f7f, (q15_t)0x7f7d, (q15_t)0x7f7b, (q15_t)0x7f78, (q15_t)0x7f76, + (q15_t)0x7f74, (q15_t)0x7f71, (q15_t)0x7f6f, (q15_t)0x7f6d, (q15_t)0x7f6a, (q15_t)0x7f68, (q15_t)0x7f65, (q15_t)0x7f63, + (q15_t)0x7f60, (q15_t)0x7f5e, (q15_t)0x7f5b, (q15_t)0x7f59, (q15_t)0x7f56, (q15_t)0x7f54, (q15_t)0x7f51, (q15_t)0x7f4f, + (q15_t)0x7f4c, (q15_t)0x7f49, (q15_t)0x7f47, (q15_t)0x7f44, (q15_t)0x7f41, (q15_t)0x7f3f, (q15_t)0x7f3c, (q15_t)0x7f39, + (q15_t)0x7f36, (q15_t)0x7f34, (q15_t)0x7f31, (q15_t)0x7f2e, (q15_t)0x7f2b, (q15_t)0x7f28, (q15_t)0x7f25, (q15_t)0x7f23, + (q15_t)0x7f20, (q15_t)0x7f1d, (q15_t)0x7f1a, (q15_t)0x7f17, (q15_t)0x7f14, (q15_t)0x7f11, (q15_t)0x7f0e, (q15_t)0x7f0b, + (q15_t)0x7f08, (q15_t)0x7f04, (q15_t)0x7f01, (q15_t)0x7efe, (q15_t)0x7efb, (q15_t)0x7ef8, (q15_t)0x7ef5, (q15_t)0x7ef1, + (q15_t)0x7eee, (q15_t)0x7eeb, (q15_t)0x7ee8, (q15_t)0x7ee4, (q15_t)0x7ee1, (q15_t)0x7ede, (q15_t)0x7eda, (q15_t)0x7ed7, + (q15_t)0x7ed4, (q15_t)0x7ed0, (q15_t)0x7ecd, (q15_t)0x7ec9, (q15_t)0x7ec6, (q15_t)0x7ec3, (q15_t)0x7ebf, (q15_t)0x7ebb, + (q15_t)0x7eb8, (q15_t)0x7eb4, (q15_t)0x7eb1, (q15_t)0x7ead, (q15_t)0x7eaa, (q15_t)0x7ea6, (q15_t)0x7ea2, (q15_t)0x7e9f, + (q15_t)0x7e9b, (q15_t)0x7e97, (q15_t)0x7e94, (q15_t)0x7e90, (q15_t)0x7e8c, (q15_t)0x7e88, (q15_t)0x7e84, (q15_t)0x7e81, + (q15_t)0x7e7d, (q15_t)0x7e79, (q15_t)0x7e75, (q15_t)0x7e71, (q15_t)0x7e6d, (q15_t)0x7e69, (q15_t)0x7e65, (q15_t)0x7e61, + (q15_t)0x7e5d, (q15_t)0x7e59, (q15_t)0x7e55, (q15_t)0x7e51, (q15_t)0x7e4d, (q15_t)0x7e49, (q15_t)0x7e45, (q15_t)0x7e41, + (q15_t)0x7e3d, (q15_t)0x7e39, (q15_t)0x7e34, (q15_t)0x7e30, (q15_t)0x7e2c, (q15_t)0x7e28, (q15_t)0x7e24, (q15_t)0x7e1f, + (q15_t)0x7e1b, (q15_t)0x7e17, (q15_t)0x7e12, (q15_t)0x7e0e, (q15_t)0x7e0a, (q15_t)0x7e05, (q15_t)0x7e01, (q15_t)0x7dfc, + (q15_t)0x7df8, (q15_t)0x7df3, (q15_t)0x7def, (q15_t)0x7dea, (q15_t)0x7de6, (q15_t)0x7de1, (q15_t)0x7ddd, (q15_t)0x7dd8, + (q15_t)0x7dd4, (q15_t)0x7dcf, (q15_t)0x7dca, (q15_t)0x7dc6, (q15_t)0x7dc1, (q15_t)0x7dbc, (q15_t)0x7db8, (q15_t)0x7db3, + (q15_t)0x7dae, (q15_t)0x7da9, (q15_t)0x7da5, (q15_t)0x7da0, (q15_t)0x7d9b, (q15_t)0x7d96, (q15_t)0x7d91, (q15_t)0x7d8c, + (q15_t)0x7d87, (q15_t)0x7d82, (q15_t)0x7d7e, (q15_t)0x7d79, (q15_t)0x7d74, (q15_t)0x7d6f, (q15_t)0x7d6a, (q15_t)0x7d65, + (q15_t)0x7d60, (q15_t)0x7d5a, (q15_t)0x7d55, (q15_t)0x7d50, (q15_t)0x7d4b, (q15_t)0x7d46, (q15_t)0x7d41, (q15_t)0x7d3c, + (q15_t)0x7d36, (q15_t)0x7d31, (q15_t)0x7d2c, (q15_t)0x7d27, (q15_t)0x7d21, (q15_t)0x7d1c, (q15_t)0x7d17, (q15_t)0x7d11, + (q15_t)0x7d0c, (q15_t)0x7d07, (q15_t)0x7d01, (q15_t)0x7cfc, (q15_t)0x7cf6, (q15_t)0x7cf1, (q15_t)0x7cec, (q15_t)0x7ce6, + (q15_t)0x7ce1, (q15_t)0x7cdb, (q15_t)0x7cd5, (q15_t)0x7cd0, (q15_t)0x7cca, (q15_t)0x7cc5, (q15_t)0x7cbf, (q15_t)0x7cb9, + (q15_t)0x7cb4, (q15_t)0x7cae, (q15_t)0x7ca8, (q15_t)0x7ca3, (q15_t)0x7c9d, (q15_t)0x7c97, (q15_t)0x7c91, (q15_t)0x7c8c, + (q15_t)0x7c86, (q15_t)0x7c80, (q15_t)0x7c7a, (q15_t)0x7c74, (q15_t)0x7c6e, (q15_t)0x7c69, (q15_t)0x7c63, (q15_t)0x7c5d, + (q15_t)0x7c57, (q15_t)0x7c51, (q15_t)0x7c4b, (q15_t)0x7c45, (q15_t)0x7c3f, (q15_t)0x7c39, (q15_t)0x7c33, (q15_t)0x7c2d, + (q15_t)0x7c26, (q15_t)0x7c20, (q15_t)0x7c1a, (q15_t)0x7c14, (q15_t)0x7c0e, (q15_t)0x7c08, (q15_t)0x7c01, (q15_t)0x7bfb, + (q15_t)0x7bf5, (q15_t)0x7bef, (q15_t)0x7be8, (q15_t)0x7be2, (q15_t)0x7bdc, (q15_t)0x7bd5, (q15_t)0x7bcf, (q15_t)0x7bc9, + (q15_t)0x7bc2, (q15_t)0x7bbc, (q15_t)0x7bb5, (q15_t)0x7baf, (q15_t)0x7ba8, (q15_t)0x7ba2, (q15_t)0x7b9b, (q15_t)0x7b95, + (q15_t)0x7b8e, (q15_t)0x7b88, (q15_t)0x7b81, (q15_t)0x7b7a, (q15_t)0x7b74, (q15_t)0x7b6d, (q15_t)0x7b67, (q15_t)0x7b60, + (q15_t)0x7b59, (q15_t)0x7b52, (q15_t)0x7b4c, (q15_t)0x7b45, (q15_t)0x7b3e, (q15_t)0x7b37, (q15_t)0x7b31, (q15_t)0x7b2a, + (q15_t)0x7b23, (q15_t)0x7b1c, (q15_t)0x7b15, (q15_t)0x7b0e, (q15_t)0x7b07, (q15_t)0x7b00, (q15_t)0x7af9, (q15_t)0x7af2, + (q15_t)0x7aeb, (q15_t)0x7ae4, (q15_t)0x7add, (q15_t)0x7ad6, (q15_t)0x7acf, (q15_t)0x7ac8, (q15_t)0x7ac1, (q15_t)0x7aba, + (q15_t)0x7ab3, (q15_t)0x7aac, (q15_t)0x7aa4, (q15_t)0x7a9d, (q15_t)0x7a96, (q15_t)0x7a8f, (q15_t)0x7a87, (q15_t)0x7a80, + (q15_t)0x7a79, (q15_t)0x7a72, (q15_t)0x7a6a, (q15_t)0x7a63, (q15_t)0x7a5c, (q15_t)0x7a54, (q15_t)0x7a4d, (q15_t)0x7a45, + (q15_t)0x7a3e, (q15_t)0x7a36, (q15_t)0x7a2f, (q15_t)0x7a27, (q15_t)0x7a20, (q15_t)0x7a18, (q15_t)0x7a11, (q15_t)0x7a09, + (q15_t)0x7a02, (q15_t)0x79fa, (q15_t)0x79f2, (q15_t)0x79eb, (q15_t)0x79e3, (q15_t)0x79db, (q15_t)0x79d4, (q15_t)0x79cc, + (q15_t)0x79c4, (q15_t)0x79bc, (q15_t)0x79b5, (q15_t)0x79ad, (q15_t)0x79a5, (q15_t)0x799d, (q15_t)0x7995, (q15_t)0x798e, + (q15_t)0x7986, (q15_t)0x797e, (q15_t)0x7976, (q15_t)0x796e, (q15_t)0x7966, (q15_t)0x795e, (q15_t)0x7956, (q15_t)0x794e, + (q15_t)0x7946, (q15_t)0x793e, (q15_t)0x7936, (q15_t)0x792e, (q15_t)0x7926, (q15_t)0x791e, (q15_t)0x7915, (q15_t)0x790d, + (q15_t)0x7905, (q15_t)0x78fd, (q15_t)0x78f5, (q15_t)0x78ec, (q15_t)0x78e4, (q15_t)0x78dc, (q15_t)0x78d4, (q15_t)0x78cb, + (q15_t)0x78c3, (q15_t)0x78bb, (q15_t)0x78b2, (q15_t)0x78aa, (q15_t)0x78a2, (q15_t)0x7899, (q15_t)0x7891, (q15_t)0x7888, + (q15_t)0x7880, (q15_t)0x7877, (q15_t)0x786f, (q15_t)0x7866, (q15_t)0x785e, (q15_t)0x7855, (q15_t)0x784d, (q15_t)0x7844, + (q15_t)0x783b, (q15_t)0x7833, (q15_t)0x782a, (q15_t)0x7821, (q15_t)0x7819, (q15_t)0x7810, (q15_t)0x7807, (q15_t)0x77ff, + (q15_t)0x77f6, (q15_t)0x77ed, (q15_t)0x77e4, (q15_t)0x77db, (q15_t)0x77d3, (q15_t)0x77ca, (q15_t)0x77c1, (q15_t)0x77b8, + (q15_t)0x77af, (q15_t)0x77a6, (q15_t)0x779d, (q15_t)0x7794, (q15_t)0x778b, (q15_t)0x7782, (q15_t)0x7779, (q15_t)0x7770, + (q15_t)0x7767, (q15_t)0x775e, (q15_t)0x7755, (q15_t)0x774c, (q15_t)0x7743, (q15_t)0x773a, (q15_t)0x7731, (q15_t)0x7727, + (q15_t)0x771e, (q15_t)0x7715, (q15_t)0x770c, (q15_t)0x7703, (q15_t)0x76f9, (q15_t)0x76f0, (q15_t)0x76e7, (q15_t)0x76dd, + (q15_t)0x76d4, (q15_t)0x76cb, (q15_t)0x76c1, (q15_t)0x76b8, (q15_t)0x76af, (q15_t)0x76a5, (q15_t)0x769c, (q15_t)0x7692, + (q15_t)0x7689, (q15_t)0x767f, (q15_t)0x7676, (q15_t)0x766c, (q15_t)0x7663, (q15_t)0x7659, (q15_t)0x7650, (q15_t)0x7646, + (q15_t)0x763c, (q15_t)0x7633, (q15_t)0x7629, (q15_t)0x761f, (q15_t)0x7616, (q15_t)0x760c, (q15_t)0x7602, (q15_t)0x75f9, + (q15_t)0x75ef, (q15_t)0x75e5, (q15_t)0x75db, (q15_t)0x75d1, (q15_t)0x75c8, (q15_t)0x75be, (q15_t)0x75b4, (q15_t)0x75aa, + (q15_t)0x75a0, (q15_t)0x7596, (q15_t)0x758c, (q15_t)0x7582, (q15_t)0x7578, (q15_t)0x756e, (q15_t)0x7564, (q15_t)0x755a, + (q15_t)0x7550, (q15_t)0x7546, (q15_t)0x753c, (q15_t)0x7532, (q15_t)0x7528, (q15_t)0x751e, (q15_t)0x7514, (q15_t)0x7509, + (q15_t)0x74ff, (q15_t)0x74f5, (q15_t)0x74eb, (q15_t)0x74e1, (q15_t)0x74d6, (q15_t)0x74cc, (q15_t)0x74c2, (q15_t)0x74b7, + (q15_t)0x74ad, (q15_t)0x74a3, (q15_t)0x7498, (q15_t)0x748e, (q15_t)0x7484, (q15_t)0x7479, (q15_t)0x746f, (q15_t)0x7464, + (q15_t)0x745a, (q15_t)0x744f, (q15_t)0x7445, (q15_t)0x743a, (q15_t)0x7430, (q15_t)0x7425, (q15_t)0x741b, (q15_t)0x7410, + (q15_t)0x7406, (q15_t)0x73fb, (q15_t)0x73f0, (q15_t)0x73e6, (q15_t)0x73db, (q15_t)0x73d0, (q15_t)0x73c6, (q15_t)0x73bb, + (q15_t)0x73b0, (q15_t)0x73a5, (q15_t)0x739b, (q15_t)0x7390, (q15_t)0x7385, (q15_t)0x737a, (q15_t)0x736f, (q15_t)0x7364, + (q15_t)0x7359, (q15_t)0x734f, (q15_t)0x7344, (q15_t)0x7339, (q15_t)0x732e, (q15_t)0x7323, (q15_t)0x7318, (q15_t)0x730d, + (q15_t)0x7302, (q15_t)0x72f7, (q15_t)0x72ec, (q15_t)0x72e1, (q15_t)0x72d5, (q15_t)0x72ca, (q15_t)0x72bf, (q15_t)0x72b4, + (q15_t)0x72a9, (q15_t)0x729e, (q15_t)0x7293, (q15_t)0x7287, (q15_t)0x727c, (q15_t)0x7271, (q15_t)0x7266, (q15_t)0x725a, + (q15_t)0x724f, (q15_t)0x7244, (q15_t)0x7238, (q15_t)0x722d, (q15_t)0x7222, (q15_t)0x7216, (q15_t)0x720b, (q15_t)0x71ff, + (q15_t)0x71f4, (q15_t)0x71e9, (q15_t)0x71dd, (q15_t)0x71d2, (q15_t)0x71c6, (q15_t)0x71bb, (q15_t)0x71af, (q15_t)0x71a3, + (q15_t)0x7198, (q15_t)0x718c, (q15_t)0x7181, (q15_t)0x7175, (q15_t)0x7169, (q15_t)0x715e, (q15_t)0x7152, (q15_t)0x7146, + (q15_t)0x713b, (q15_t)0x712f, (q15_t)0x7123, (q15_t)0x7117, (q15_t)0x710c, (q15_t)0x7100, (q15_t)0x70f4, (q15_t)0x70e8, + (q15_t)0x70dc, (q15_t)0x70d1, (q15_t)0x70c5, (q15_t)0x70b9, (q15_t)0x70ad, (q15_t)0x70a1, (q15_t)0x7095, (q15_t)0x7089, + (q15_t)0x707d, (q15_t)0x7071, (q15_t)0x7065, (q15_t)0x7059, (q15_t)0x704d, (q15_t)0x7041, (q15_t)0x7035, (q15_t)0x7029, + (q15_t)0x701d, (q15_t)0x7010, (q15_t)0x7004, (q15_t)0x6ff8, (q15_t)0x6fec, (q15_t)0x6fe0, (q15_t)0x6fd3, (q15_t)0x6fc7, + (q15_t)0x6fbb, (q15_t)0x6faf, (q15_t)0x6fa2, (q15_t)0x6f96, (q15_t)0x6f8a, (q15_t)0x6f7d, (q15_t)0x6f71, (q15_t)0x6f65, + (q15_t)0x6f58, (q15_t)0x6f4c, (q15_t)0x6f3f, (q15_t)0x6f33, (q15_t)0x6f27, (q15_t)0x6f1a, (q15_t)0x6f0e, (q15_t)0x6f01, + (q15_t)0x6ef5, (q15_t)0x6ee8, (q15_t)0x6edc, (q15_t)0x6ecf, (q15_t)0x6ec2, (q15_t)0x6eb6, (q15_t)0x6ea9, (q15_t)0x6e9c, + (q15_t)0x6e90, (q15_t)0x6e83, (q15_t)0x6e76, (q15_t)0x6e6a, (q15_t)0x6e5d, (q15_t)0x6e50, (q15_t)0x6e44, (q15_t)0x6e37, + (q15_t)0x6e2a, (q15_t)0x6e1d, (q15_t)0x6e10, (q15_t)0x6e04, (q15_t)0x6df7, (q15_t)0x6dea, (q15_t)0x6ddd, (q15_t)0x6dd0, + (q15_t)0x6dc3, (q15_t)0x6db6, (q15_t)0x6da9, (q15_t)0x6d9c, (q15_t)0x6d8f, (q15_t)0x6d82, (q15_t)0x6d75, (q15_t)0x6d68, + (q15_t)0x6d5b, (q15_t)0x6d4e, (q15_t)0x6d41, (q15_t)0x6d34, (q15_t)0x6d27, (q15_t)0x6d1a, (q15_t)0x6d0c, (q15_t)0x6cff, + (q15_t)0x6cf2, (q15_t)0x6ce5, (q15_t)0x6cd8, (q15_t)0x6cca, (q15_t)0x6cbd, (q15_t)0x6cb0, (q15_t)0x6ca3, (q15_t)0x6c95, + (q15_t)0x6c88, (q15_t)0x6c7b, (q15_t)0x6c6d, (q15_t)0x6c60, (q15_t)0x6c53, (q15_t)0x6c45, (q15_t)0x6c38, (q15_t)0x6c2a, + (q15_t)0x6c1d, (q15_t)0x6c0f, (q15_t)0x6c02, (q15_t)0x6bf5, (q15_t)0x6be7, (q15_t)0x6bd9, (q15_t)0x6bcc, (q15_t)0x6bbe, + (q15_t)0x6bb1, (q15_t)0x6ba3, (q15_t)0x6b96, (q15_t)0x6b88, (q15_t)0x6b7a, (q15_t)0x6b6d, (q15_t)0x6b5f, (q15_t)0x6b51, + (q15_t)0x6b44, (q15_t)0x6b36, (q15_t)0x6b28, (q15_t)0x6b1a, (q15_t)0x6b0d, (q15_t)0x6aff, (q15_t)0x6af1, (q15_t)0x6ae3, + (q15_t)0x6ad5, (q15_t)0x6ac8, (q15_t)0x6aba, (q15_t)0x6aac, (q15_t)0x6a9e, (q15_t)0x6a90, (q15_t)0x6a82, (q15_t)0x6a74, + (q15_t)0x6a66, (q15_t)0x6a58, (q15_t)0x6a4a, (q15_t)0x6a3c, (q15_t)0x6a2e, (q15_t)0x6a20, (q15_t)0x6a12, (q15_t)0x6a04, + (q15_t)0x69f6, (q15_t)0x69e8, (q15_t)0x69da, (q15_t)0x69cb, (q15_t)0x69bd, (q15_t)0x69af, (q15_t)0x69a1, (q15_t)0x6993, + (q15_t)0x6985, (q15_t)0x6976, (q15_t)0x6968, (q15_t)0x695a, (q15_t)0x694b, (q15_t)0x693d, (q15_t)0x692f, (q15_t)0x6921, + (q15_t)0x6912, (q15_t)0x6904, (q15_t)0x68f5, (q15_t)0x68e7, (q15_t)0x68d9, (q15_t)0x68ca, (q15_t)0x68bc, (q15_t)0x68ad, + (q15_t)0x689f, (q15_t)0x6890, (q15_t)0x6882, (q15_t)0x6873, (q15_t)0x6865, (q15_t)0x6856, (q15_t)0x6848, (q15_t)0x6839, + (q15_t)0x682b, (q15_t)0x681c, (q15_t)0x680d, (q15_t)0x67ff, (q15_t)0x67f0, (q15_t)0x67e1, (q15_t)0x67d3, (q15_t)0x67c4, + (q15_t)0x67b5, (q15_t)0x67a6, (q15_t)0x6798, (q15_t)0x6789, (q15_t)0x677a, (q15_t)0x676b, (q15_t)0x675d, (q15_t)0x674e, + (q15_t)0x673f, (q15_t)0x6730, (q15_t)0x6721, (q15_t)0x6712, (q15_t)0x6703, (q15_t)0x66f4, (q15_t)0x66e5, (q15_t)0x66d6, + (q15_t)0x66c8, (q15_t)0x66b9, (q15_t)0x66aa, (q15_t)0x669b, (q15_t)0x668b, (q15_t)0x667c, (q15_t)0x666d, (q15_t)0x665e, + (q15_t)0x664f, (q15_t)0x6640, (q15_t)0x6631, (q15_t)0x6622, (q15_t)0x6613, (q15_t)0x6603, (q15_t)0x65f4, (q15_t)0x65e5, + (q15_t)0x65d6, (q15_t)0x65c7, (q15_t)0x65b7, (q15_t)0x65a8, (q15_t)0x6599, (q15_t)0x658a, (q15_t)0x657a, (q15_t)0x656b, + (q15_t)0x655c, (q15_t)0x654c, (q15_t)0x653d, (q15_t)0x652d, (q15_t)0x651e, (q15_t)0x650f, (q15_t)0x64ff, (q15_t)0x64f0, + (q15_t)0x64e0, (q15_t)0x64d1, (q15_t)0x64c1, (q15_t)0x64b2, (q15_t)0x64a2, (q15_t)0x6493, (q15_t)0x6483, (q15_t)0x6474, + (q15_t)0x6464, (q15_t)0x6454, (q15_t)0x6445, (q15_t)0x6435, (q15_t)0x6426, (q15_t)0x6416, (q15_t)0x6406, (q15_t)0x63f7, + (q15_t)0x63e7, (q15_t)0x63d7, (q15_t)0x63c7, (q15_t)0x63b8, (q15_t)0x63a8, (q15_t)0x6398, (q15_t)0x6388, (q15_t)0x6378, + (q15_t)0x6369, (q15_t)0x6359, (q15_t)0x6349, (q15_t)0x6339, (q15_t)0x6329, (q15_t)0x6319, (q15_t)0x6309, (q15_t)0x62f9, + (q15_t)0x62ea, (q15_t)0x62da, (q15_t)0x62ca, (q15_t)0x62ba, (q15_t)0x62aa, (q15_t)0x629a, (q15_t)0x628a, (q15_t)0x627a, + (q15_t)0x6269, (q15_t)0x6259, (q15_t)0x6249, (q15_t)0x6239, (q15_t)0x6229, (q15_t)0x6219, (q15_t)0x6209, (q15_t)0x61f9, + (q15_t)0x61e8, (q15_t)0x61d8, (q15_t)0x61c8, (q15_t)0x61b8, (q15_t)0x61a8, (q15_t)0x6197, (q15_t)0x6187, (q15_t)0x6177, + (q15_t)0x6166, (q15_t)0x6156, (q15_t)0x6146, (q15_t)0x6135, (q15_t)0x6125, (q15_t)0x6115, (q15_t)0x6104, (q15_t)0x60f4, + (q15_t)0x60e4, (q15_t)0x60d3, (q15_t)0x60c3, (q15_t)0x60b2, (q15_t)0x60a2, (q15_t)0x6091, (q15_t)0x6081, (q15_t)0x6070, + (q15_t)0x6060, (q15_t)0x604f, (q15_t)0x603f, (q15_t)0x602e, (q15_t)0x601d, (q15_t)0x600d, (q15_t)0x5ffc, (q15_t)0x5fec, + (q15_t)0x5fdb, (q15_t)0x5fca, (q15_t)0x5fba, (q15_t)0x5fa9, (q15_t)0x5f98, (q15_t)0x5f87, (q15_t)0x5f77, (q15_t)0x5f66, + (q15_t)0x5f55, (q15_t)0x5f44, (q15_t)0x5f34, (q15_t)0x5f23, (q15_t)0x5f12, (q15_t)0x5f01, (q15_t)0x5ef0, (q15_t)0x5edf, + (q15_t)0x5ecf, (q15_t)0x5ebe, (q15_t)0x5ead, (q15_t)0x5e9c, (q15_t)0x5e8b, (q15_t)0x5e7a, (q15_t)0x5e69, (q15_t)0x5e58, + (q15_t)0x5e47, (q15_t)0x5e36, (q15_t)0x5e25, (q15_t)0x5e14, (q15_t)0x5e03, (q15_t)0x5df2, (q15_t)0x5de1, (q15_t)0x5dd0, + (q15_t)0x5dbf, (q15_t)0x5dad, (q15_t)0x5d9c, (q15_t)0x5d8b, (q15_t)0x5d7a, (q15_t)0x5d69, (q15_t)0x5d58, (q15_t)0x5d46, + (q15_t)0x5d35, (q15_t)0x5d24, (q15_t)0x5d13, (q15_t)0x5d01, (q15_t)0x5cf0, (q15_t)0x5cdf, (q15_t)0x5cce, (q15_t)0x5cbc, + (q15_t)0x5cab, (q15_t)0x5c9a, (q15_t)0x5c88, (q15_t)0x5c77, (q15_t)0x5c66, (q15_t)0x5c54, (q15_t)0x5c43, (q15_t)0x5c31, + (q15_t)0x5c20, (q15_t)0x5c0e, (q15_t)0x5bfd, (q15_t)0x5beb, (q15_t)0x5bda, (q15_t)0x5bc8, (q15_t)0x5bb7, (q15_t)0x5ba5, + (q15_t)0x5b94, (q15_t)0x5b82, (q15_t)0x5b71, (q15_t)0x5b5f, (q15_t)0x5b4d, (q15_t)0x5b3c, (q15_t)0x5b2a, (q15_t)0x5b19, + (q15_t)0x5b07, (q15_t)0x5af5, (q15_t)0x5ae4, (q15_t)0x5ad2, (q15_t)0x5ac0, (q15_t)0x5aae, (q15_t)0x5a9d, (q15_t)0x5a8b, + (q15_t)0x5a79, (q15_t)0x5a67, (q15_t)0x5a56, (q15_t)0x5a44, (q15_t)0x5a32, (q15_t)0x5a20, (q15_t)0x5a0e, (q15_t)0x59fc, + (q15_t)0x59ea, (q15_t)0x59d9, (q15_t)0x59c7, (q15_t)0x59b5, (q15_t)0x59a3, (q15_t)0x5991, (q15_t)0x597f, (q15_t)0x596d, + (q15_t)0x595b, (q15_t)0x5949, (q15_t)0x5937, (q15_t)0x5925, (q15_t)0x5913, (q15_t)0x5901, (q15_t)0x58ef, (q15_t)0x58dd, + (q15_t)0x58cb, (q15_t)0x58b8, (q15_t)0x58a6, (q15_t)0x5894, (q15_t)0x5882, (q15_t)0x5870, (q15_t)0x585e, (q15_t)0x584b, + (q15_t)0x5839, (q15_t)0x5827, (q15_t)0x5815, (q15_t)0x5803, (q15_t)0x57f0, (q15_t)0x57de, (q15_t)0x57cc, (q15_t)0x57b9, + (q15_t)0x57a7, (q15_t)0x5795, (q15_t)0x5783, (q15_t)0x5770, (q15_t)0x575e, (q15_t)0x574b, (q15_t)0x5739, (q15_t)0x5727, + (q15_t)0x5714, (q15_t)0x5702, (q15_t)0x56ef, (q15_t)0x56dd, (q15_t)0x56ca, (q15_t)0x56b8, (q15_t)0x56a5, (q15_t)0x5693, + (q15_t)0x5680, (q15_t)0x566e, (q15_t)0x565b, (q15_t)0x5649, (q15_t)0x5636, (q15_t)0x5624, (q15_t)0x5611, (q15_t)0x55fe, + (q15_t)0x55ec, (q15_t)0x55d9, (q15_t)0x55c7, (q15_t)0x55b4, (q15_t)0x55a1, (q15_t)0x558f, (q15_t)0x557c, (q15_t)0x5569, + (q15_t)0x5556, (q15_t)0x5544, (q15_t)0x5531, (q15_t)0x551e, (q15_t)0x550b, (q15_t)0x54f9, (q15_t)0x54e6, (q15_t)0x54d3, + (q15_t)0x54c0, (q15_t)0x54ad, (q15_t)0x549a, (q15_t)0x5488, (q15_t)0x5475, (q15_t)0x5462, (q15_t)0x544f, (q15_t)0x543c, + (q15_t)0x5429, (q15_t)0x5416, (q15_t)0x5403, (q15_t)0x53f0, (q15_t)0x53dd, (q15_t)0x53ca, (q15_t)0x53b7, (q15_t)0x53a4, + (q15_t)0x5391, (q15_t)0x537e, (q15_t)0x536b, (q15_t)0x5358, (q15_t)0x5345, (q15_t)0x5332, (q15_t)0x531f, (q15_t)0x530c, + (q15_t)0x52f8, (q15_t)0x52e5, (q15_t)0x52d2, (q15_t)0x52bf, (q15_t)0x52ac, (q15_t)0x5299, (q15_t)0x5285, (q15_t)0x5272, + (q15_t)0x525f, (q15_t)0x524c, (q15_t)0x5238, (q15_t)0x5225, (q15_t)0x5212, (q15_t)0x51ff, (q15_t)0x51eb, (q15_t)0x51d8, + (q15_t)0x51c5, (q15_t)0x51b1, (q15_t)0x519e, (q15_t)0x518b, (q15_t)0x5177, (q15_t)0x5164, (q15_t)0x5150, (q15_t)0x513d, + (q15_t)0x512a, (q15_t)0x5116, (q15_t)0x5103, (q15_t)0x50ef, (q15_t)0x50dc, (q15_t)0x50c8, (q15_t)0x50b5, (q15_t)0x50a1, + (q15_t)0x508e, (q15_t)0x507a, (q15_t)0x5067, (q15_t)0x5053, (q15_t)0x503f, (q15_t)0x502c, (q15_t)0x5018, (q15_t)0x5005, + (q15_t)0x4ff1, (q15_t)0x4fdd, (q15_t)0x4fca, (q15_t)0x4fb6, (q15_t)0x4fa2, (q15_t)0x4f8f, (q15_t)0x4f7b, (q15_t)0x4f67, + (q15_t)0x4f54, (q15_t)0x4f40, (q15_t)0x4f2c, (q15_t)0x4f18, (q15_t)0x4f05, (q15_t)0x4ef1, (q15_t)0x4edd, (q15_t)0x4ec9, + (q15_t)0x4eb6, (q15_t)0x4ea2, (q15_t)0x4e8e, (q15_t)0x4e7a, (q15_t)0x4e66, (q15_t)0x4e52, (q15_t)0x4e3e, (q15_t)0x4e2a, + (q15_t)0x4e17, (q15_t)0x4e03, (q15_t)0x4def, (q15_t)0x4ddb, (q15_t)0x4dc7, (q15_t)0x4db3, (q15_t)0x4d9f, (q15_t)0x4d8b, + (q15_t)0x4d77, (q15_t)0x4d63, (q15_t)0x4d4f, (q15_t)0x4d3b, (q15_t)0x4d27, (q15_t)0x4d13, (q15_t)0x4cff, (q15_t)0x4ceb, + (q15_t)0x4cd6, (q15_t)0x4cc2, (q15_t)0x4cae, (q15_t)0x4c9a, (q15_t)0x4c86, (q15_t)0x4c72, (q15_t)0x4c5e, (q15_t)0x4c49, + (q15_t)0x4c35, (q15_t)0x4c21, (q15_t)0x4c0d, (q15_t)0x4bf9, (q15_t)0x4be4, (q15_t)0x4bd0, (q15_t)0x4bbc, (q15_t)0x4ba8, + (q15_t)0x4b93, (q15_t)0x4b7f, (q15_t)0x4b6b, (q15_t)0x4b56, (q15_t)0x4b42, (q15_t)0x4b2e, (q15_t)0x4b19, (q15_t)0x4b05, + (q15_t)0x4af1, (q15_t)0x4adc, (q15_t)0x4ac8, (q15_t)0x4ab4, (q15_t)0x4a9f, (q15_t)0x4a8b, (q15_t)0x4a76, (q15_t)0x4a62, + (q15_t)0x4a4d, (q15_t)0x4a39, (q15_t)0x4a24, (q15_t)0x4a10, (q15_t)0x49fb, (q15_t)0x49e7, (q15_t)0x49d2, (q15_t)0x49be, + (q15_t)0x49a9, (q15_t)0x4995, (q15_t)0x4980, (q15_t)0x496c, (q15_t)0x4957, (q15_t)0x4942, (q15_t)0x492e, (q15_t)0x4919, + (q15_t)0x4905, (q15_t)0x48f0, (q15_t)0x48db, (q15_t)0x48c7, (q15_t)0x48b2, (q15_t)0x489d, (q15_t)0x4888, (q15_t)0x4874, + (q15_t)0x485f, (q15_t)0x484a, (q15_t)0x4836, (q15_t)0x4821, (q15_t)0x480c, (q15_t)0x47f7, (q15_t)0x47e2, (q15_t)0x47ce, + (q15_t)0x47b9, (q15_t)0x47a4, (q15_t)0x478f, (q15_t)0x477a, (q15_t)0x4765, (q15_t)0x4751, (q15_t)0x473c, (q15_t)0x4727, + (q15_t)0x4712, (q15_t)0x46fd, (q15_t)0x46e8, (q15_t)0x46d3, (q15_t)0x46be, (q15_t)0x46a9, (q15_t)0x4694, (q15_t)0x467f, + (q15_t)0x466a, (q15_t)0x4655, (q15_t)0x4640, (q15_t)0x462b, (q15_t)0x4616, (q15_t)0x4601, (q15_t)0x45ec, (q15_t)0x45d7, + (q15_t)0x45c2, (q15_t)0x45ad, (q15_t)0x4598, (q15_t)0x4583, (q15_t)0x456e, (q15_t)0x4559, (q15_t)0x4544, (q15_t)0x452e, + (q15_t)0x4519, (q15_t)0x4504, (q15_t)0x44ef, (q15_t)0x44da, (q15_t)0x44c5, (q15_t)0x44af, (q15_t)0x449a, (q15_t)0x4485, + (q15_t)0x4470, (q15_t)0x445a, (q15_t)0x4445, (q15_t)0x4430, (q15_t)0x441b, (q15_t)0x4405, (q15_t)0x43f0, (q15_t)0x43db, + (q15_t)0x43c5, (q15_t)0x43b0, (q15_t)0x439b, (q15_t)0x4385, (q15_t)0x4370, (q15_t)0x435b, (q15_t)0x4345, (q15_t)0x4330, + (q15_t)0x431b, (q15_t)0x4305, (q15_t)0x42f0, (q15_t)0x42da, (q15_t)0x42c5, (q15_t)0x42af, (q15_t)0x429a, (q15_t)0x4284, + (q15_t)0x426f, (q15_t)0x425a, (q15_t)0x4244, (q15_t)0x422f, (q15_t)0x4219, (q15_t)0x4203, (q15_t)0x41ee, (q15_t)0x41d8, + (q15_t)0x41c3, (q15_t)0x41ad, (q15_t)0x4198, (q15_t)0x4182, (q15_t)0x416d, (q15_t)0x4157, (q15_t)0x4141, (q15_t)0x412c, + (q15_t)0x4116, (q15_t)0x4100, (q15_t)0x40eb, (q15_t)0x40d5, (q15_t)0x40bf, (q15_t)0x40aa, (q15_t)0x4094, (q15_t)0x407e, + (q15_t)0x4069, (q15_t)0x4053, (q15_t)0x403d, (q15_t)0x4027, (q15_t)0x4012, (q15_t)0x3ffc, (q15_t)0x3fe6, (q15_t)0x3fd0, + (q15_t)0x3fbb, (q15_t)0x3fa5, (q15_t)0x3f8f, (q15_t)0x3f79, (q15_t)0x3f63, (q15_t)0x3f4d, (q15_t)0x3f38, (q15_t)0x3f22, + (q15_t)0x3f0c, (q15_t)0x3ef6, (q15_t)0x3ee0, (q15_t)0x3eca, (q15_t)0x3eb4, (q15_t)0x3e9e, (q15_t)0x3e88, (q15_t)0x3e73, + (q15_t)0x3e5d, (q15_t)0x3e47, (q15_t)0x3e31, (q15_t)0x3e1b, (q15_t)0x3e05, (q15_t)0x3def, (q15_t)0x3dd9, (q15_t)0x3dc3, + (q15_t)0x3dad, (q15_t)0x3d97, (q15_t)0x3d81, (q15_t)0x3d6b, (q15_t)0x3d55, (q15_t)0x3d3e, (q15_t)0x3d28, (q15_t)0x3d12, + (q15_t)0x3cfc, (q15_t)0x3ce6, (q15_t)0x3cd0, (q15_t)0x3cba, (q15_t)0x3ca4, (q15_t)0x3c8e, (q15_t)0x3c77, (q15_t)0x3c61, + (q15_t)0x3c4b, (q15_t)0x3c35, (q15_t)0x3c1f, (q15_t)0x3c09, (q15_t)0x3bf2, (q15_t)0x3bdc, (q15_t)0x3bc6, (q15_t)0x3bb0, + (q15_t)0x3b99, (q15_t)0x3b83, (q15_t)0x3b6d, (q15_t)0x3b57, (q15_t)0x3b40, (q15_t)0x3b2a, (q15_t)0x3b14, (q15_t)0x3afe, + (q15_t)0x3ae7, (q15_t)0x3ad1, (q15_t)0x3abb, (q15_t)0x3aa4, (q15_t)0x3a8e, (q15_t)0x3a78, (q15_t)0x3a61, (q15_t)0x3a4b, + (q15_t)0x3a34, (q15_t)0x3a1e, (q15_t)0x3a08, (q15_t)0x39f1, (q15_t)0x39db, (q15_t)0x39c4, (q15_t)0x39ae, (q15_t)0x3998, + (q15_t)0x3981, (q15_t)0x396b, (q15_t)0x3954, (q15_t)0x393e, (q15_t)0x3927, (q15_t)0x3911, (q15_t)0x38fa, (q15_t)0x38e4, + (q15_t)0x38cd, (q15_t)0x38b7, (q15_t)0x38a0, (q15_t)0x388a, (q15_t)0x3873, (q15_t)0x385d, (q15_t)0x3846, (q15_t)0x382f, + (q15_t)0x3819, (q15_t)0x3802, (q15_t)0x37ec, (q15_t)0x37d5, (q15_t)0x37be, (q15_t)0x37a8, (q15_t)0x3791, (q15_t)0x377a, + (q15_t)0x3764, (q15_t)0x374d, (q15_t)0x3736, (q15_t)0x3720, (q15_t)0x3709, (q15_t)0x36f2, (q15_t)0x36dc, (q15_t)0x36c5, + (q15_t)0x36ae, (q15_t)0x3698, (q15_t)0x3681, (q15_t)0x366a, (q15_t)0x3653, (q15_t)0x363d, (q15_t)0x3626, (q15_t)0x360f, + (q15_t)0x35f8, (q15_t)0x35e1, (q15_t)0x35cb, (q15_t)0x35b4, (q15_t)0x359d, (q15_t)0x3586, (q15_t)0x356f, (q15_t)0x3558, + (q15_t)0x3542, (q15_t)0x352b, (q15_t)0x3514, (q15_t)0x34fd, (q15_t)0x34e6, (q15_t)0x34cf, (q15_t)0x34b8, (q15_t)0x34a1, + (q15_t)0x348b, (q15_t)0x3474, (q15_t)0x345d, (q15_t)0x3446, (q15_t)0x342f, (q15_t)0x3418, (q15_t)0x3401, (q15_t)0x33ea, + (q15_t)0x33d3, (q15_t)0x33bc, (q15_t)0x33a5, (q15_t)0x338e, (q15_t)0x3377, (q15_t)0x3360, (q15_t)0x3349, (q15_t)0x3332, + (q15_t)0x331b, (q15_t)0x3304, (q15_t)0x32ed, (q15_t)0x32d6, (q15_t)0x32bf, (q15_t)0x32a8, (q15_t)0x3290, (q15_t)0x3279, + (q15_t)0x3262, (q15_t)0x324b, (q15_t)0x3234, (q15_t)0x321d, (q15_t)0x3206, (q15_t)0x31ef, (q15_t)0x31d8, (q15_t)0x31c0, + (q15_t)0x31a9, (q15_t)0x3192, (q15_t)0x317b, (q15_t)0x3164, (q15_t)0x314c, (q15_t)0x3135, (q15_t)0x311e, (q15_t)0x3107, + (q15_t)0x30f0, (q15_t)0x30d8, (q15_t)0x30c1, (q15_t)0x30aa, (q15_t)0x3093, (q15_t)0x307b, (q15_t)0x3064, (q15_t)0x304d, + (q15_t)0x3036, (q15_t)0x301e, (q15_t)0x3007, (q15_t)0x2ff0, (q15_t)0x2fd8, (q15_t)0x2fc1, (q15_t)0x2faa, (q15_t)0x2f92, + (q15_t)0x2f7b, (q15_t)0x2f64, (q15_t)0x2f4c, (q15_t)0x2f35, (q15_t)0x2f1e, (q15_t)0x2f06, (q15_t)0x2eef, (q15_t)0x2ed8, + (q15_t)0x2ec0, (q15_t)0x2ea9, (q15_t)0x2e91, (q15_t)0x2e7a, (q15_t)0x2e63, (q15_t)0x2e4b, (q15_t)0x2e34, (q15_t)0x2e1c, + (q15_t)0x2e05, (q15_t)0x2ded, (q15_t)0x2dd6, (q15_t)0x2dbe, (q15_t)0x2da7, (q15_t)0x2d8f, (q15_t)0x2d78, (q15_t)0x2d60, + (q15_t)0x2d49, (q15_t)0x2d31, (q15_t)0x2d1a, (q15_t)0x2d02, (q15_t)0x2ceb, (q15_t)0x2cd3, (q15_t)0x2cbc, (q15_t)0x2ca4, + (q15_t)0x2c8d, (q15_t)0x2c75, (q15_t)0x2c5e, (q15_t)0x2c46, (q15_t)0x2c2e, (q15_t)0x2c17, (q15_t)0x2bff, (q15_t)0x2be8, + (q15_t)0x2bd0, (q15_t)0x2bb8, (q15_t)0x2ba1, (q15_t)0x2b89, (q15_t)0x2b71, (q15_t)0x2b5a, (q15_t)0x2b42, (q15_t)0x2b2b, + (q15_t)0x2b13, (q15_t)0x2afb, (q15_t)0x2ae4, (q15_t)0x2acc, (q15_t)0x2ab4, (q15_t)0x2a9c, (q15_t)0x2a85, (q15_t)0x2a6d, + (q15_t)0x2a55, (q15_t)0x2a3e, (q15_t)0x2a26, (q15_t)0x2a0e, (q15_t)0x29f6, (q15_t)0x29df, (q15_t)0x29c7, (q15_t)0x29af, + (q15_t)0x2997, (q15_t)0x2980, (q15_t)0x2968, (q15_t)0x2950, (q15_t)0x2938, (q15_t)0x2920, (q15_t)0x2909, (q15_t)0x28f1, + (q15_t)0x28d9, (q15_t)0x28c1, (q15_t)0x28a9, (q15_t)0x2892, (q15_t)0x287a, (q15_t)0x2862, (q15_t)0x284a, (q15_t)0x2832, + (q15_t)0x281a, (q15_t)0x2802, (q15_t)0x27eb, (q15_t)0x27d3, (q15_t)0x27bb, (q15_t)0x27a3, (q15_t)0x278b, (q15_t)0x2773, + (q15_t)0x275b, (q15_t)0x2743, (q15_t)0x272b, (q15_t)0x2713, (q15_t)0x26fb, (q15_t)0x26e4, (q15_t)0x26cc, (q15_t)0x26b4, + (q15_t)0x269c, (q15_t)0x2684, (q15_t)0x266c, (q15_t)0x2654, (q15_t)0x263c, (q15_t)0x2624, (q15_t)0x260c, (q15_t)0x25f4, + (q15_t)0x25dc, (q15_t)0x25c4, (q15_t)0x25ac, (q15_t)0x2594, (q15_t)0x257c, (q15_t)0x2564, (q15_t)0x254c, (q15_t)0x2534, + (q15_t)0x251c, (q15_t)0x2503, (q15_t)0x24eb, (q15_t)0x24d3, (q15_t)0x24bb, (q15_t)0x24a3, (q15_t)0x248b, (q15_t)0x2473, + (q15_t)0x245b, (q15_t)0x2443, (q15_t)0x242b, (q15_t)0x2413, (q15_t)0x23fa, (q15_t)0x23e2, (q15_t)0x23ca, (q15_t)0x23b2, + (q15_t)0x239a, (q15_t)0x2382, (q15_t)0x236a, (q15_t)0x2352, (q15_t)0x2339, (q15_t)0x2321, (q15_t)0x2309, (q15_t)0x22f1, + (q15_t)0x22d9, (q15_t)0x22c0, (q15_t)0x22a8, (q15_t)0x2290, (q15_t)0x2278, (q15_t)0x2260, (q15_t)0x2247, (q15_t)0x222f, + (q15_t)0x2217, (q15_t)0x21ff, (q15_t)0x21e7, (q15_t)0x21ce, (q15_t)0x21b6, (q15_t)0x219e, (q15_t)0x2186, (q15_t)0x216d, + (q15_t)0x2155, (q15_t)0x213d, (q15_t)0x2125, (q15_t)0x210c, (q15_t)0x20f4, (q15_t)0x20dc, (q15_t)0x20c3, (q15_t)0x20ab, + (q15_t)0x2093, (q15_t)0x207a, (q15_t)0x2062, (q15_t)0x204a, (q15_t)0x2032, (q15_t)0x2019, (q15_t)0x2001, (q15_t)0x1fe9, + (q15_t)0x1fd0, (q15_t)0x1fb8, (q15_t)0x1f9f, (q15_t)0x1f87, (q15_t)0x1f6f, (q15_t)0x1f56, (q15_t)0x1f3e, (q15_t)0x1f26, + (q15_t)0x1f0d, (q15_t)0x1ef5, (q15_t)0x1edd, (q15_t)0x1ec4, (q15_t)0x1eac, (q15_t)0x1e93, (q15_t)0x1e7b, (q15_t)0x1e62, + (q15_t)0x1e4a, (q15_t)0x1e32, (q15_t)0x1e19, (q15_t)0x1e01, (q15_t)0x1de8, (q15_t)0x1dd0, (q15_t)0x1db7, (q15_t)0x1d9f, + (q15_t)0x1d87, (q15_t)0x1d6e, (q15_t)0x1d56, (q15_t)0x1d3d, (q15_t)0x1d25, (q15_t)0x1d0c, (q15_t)0x1cf4, (q15_t)0x1cdb, + (q15_t)0x1cc3, (q15_t)0x1caa, (q15_t)0x1c92, (q15_t)0x1c79, (q15_t)0x1c61, (q15_t)0x1c48, (q15_t)0x1c30, (q15_t)0x1c17, + (q15_t)0x1bff, (q15_t)0x1be6, (q15_t)0x1bce, (q15_t)0x1bb5, (q15_t)0x1b9d, (q15_t)0x1b84, (q15_t)0x1b6c, (q15_t)0x1b53, + (q15_t)0x1b3a, (q15_t)0x1b22, (q15_t)0x1b09, (q15_t)0x1af1, (q15_t)0x1ad8, (q15_t)0x1ac0, (q15_t)0x1aa7, (q15_t)0x1a8e, + (q15_t)0x1a76, (q15_t)0x1a5d, (q15_t)0x1a45, (q15_t)0x1a2c, (q15_t)0x1a13, (q15_t)0x19fb, (q15_t)0x19e2, (q15_t)0x19ca, + (q15_t)0x19b1, (q15_t)0x1998, (q15_t)0x1980, (q15_t)0x1967, (q15_t)0x194e, (q15_t)0x1936, (q15_t)0x191d, (q15_t)0x1905, + (q15_t)0x18ec, (q15_t)0x18d3, (q15_t)0x18bb, (q15_t)0x18a2, (q15_t)0x1889, (q15_t)0x1871, (q15_t)0x1858, (q15_t)0x183f, + (q15_t)0x1827, (q15_t)0x180e, (q15_t)0x17f5, (q15_t)0x17dd, (q15_t)0x17c4, (q15_t)0x17ab, (q15_t)0x1792, (q15_t)0x177a, + (q15_t)0x1761, (q15_t)0x1748, (q15_t)0x1730, (q15_t)0x1717, (q15_t)0x16fe, (q15_t)0x16e5, (q15_t)0x16cd, (q15_t)0x16b4, + (q15_t)0x169b, (q15_t)0x1682, (q15_t)0x166a, (q15_t)0x1651, (q15_t)0x1638, (q15_t)0x161f, (q15_t)0x1607, (q15_t)0x15ee, + (q15_t)0x15d5, (q15_t)0x15bc, (q15_t)0x15a4, (q15_t)0x158b, (q15_t)0x1572, (q15_t)0x1559, (q15_t)0x1541, (q15_t)0x1528, + (q15_t)0x150f, (q15_t)0x14f6, (q15_t)0x14dd, (q15_t)0x14c5, (q15_t)0x14ac, (q15_t)0x1493, (q15_t)0x147a, (q15_t)0x1461, + (q15_t)0x1449, (q15_t)0x1430, (q15_t)0x1417, (q15_t)0x13fe, (q15_t)0x13e5, (q15_t)0x13cc, (q15_t)0x13b4, (q15_t)0x139b, + (q15_t)0x1382, (q15_t)0x1369, (q15_t)0x1350, (q15_t)0x1337, (q15_t)0x131f, (q15_t)0x1306, (q15_t)0x12ed, (q15_t)0x12d4, + (q15_t)0x12bb, (q15_t)0x12a2, (q15_t)0x1289, (q15_t)0x1271, (q15_t)0x1258, (q15_t)0x123f, (q15_t)0x1226, (q15_t)0x120d, + (q15_t)0x11f4, (q15_t)0x11db, (q15_t)0x11c2, (q15_t)0x11a9, (q15_t)0x1191, (q15_t)0x1178, (q15_t)0x115f, (q15_t)0x1146, + (q15_t)0x112d, (q15_t)0x1114, (q15_t)0x10fb, (q15_t)0x10e2, (q15_t)0x10c9, (q15_t)0x10b0, (q15_t)0x1098, (q15_t)0x107f, + (q15_t)0x1066, (q15_t)0x104d, (q15_t)0x1034, (q15_t)0x101b, (q15_t)0x1002, (q15_t)0xfe9, (q15_t)0xfd0, (q15_t)0xfb7, + (q15_t)0xf9e, (q15_t)0xf85, (q15_t)0xf6c, (q15_t)0xf53, (q15_t)0xf3a, (q15_t)0xf21, (q15_t)0xf08, (q15_t)0xef0, + (q15_t)0xed7, (q15_t)0xebe, (q15_t)0xea5, (q15_t)0xe8c, (q15_t)0xe73, (q15_t)0xe5a, (q15_t)0xe41, (q15_t)0xe28, + (q15_t)0xe0f, (q15_t)0xdf6, (q15_t)0xddd, (q15_t)0xdc4, (q15_t)0xdab, (q15_t)0xd92, (q15_t)0xd79, (q15_t)0xd60, + (q15_t)0xd47, (q15_t)0xd2e, (q15_t)0xd15, (q15_t)0xcfc, (q15_t)0xce3, (q15_t)0xcca, (q15_t)0xcb1, (q15_t)0xc98, + (q15_t)0xc7f, (q15_t)0xc66, (q15_t)0xc4d, (q15_t)0xc34, (q15_t)0xc1b, (q15_t)0xc02, (q15_t)0xbe9, (q15_t)0xbd0, + (q15_t)0xbb7, (q15_t)0xb9e, (q15_t)0xb85, (q15_t)0xb6c, (q15_t)0xb53, (q15_t)0xb3a, (q15_t)0xb20, (q15_t)0xb07, + (q15_t)0xaee, (q15_t)0xad5, (q15_t)0xabc, (q15_t)0xaa3, (q15_t)0xa8a, (q15_t)0xa71, (q15_t)0xa58, (q15_t)0xa3f, + (q15_t)0xa26, (q15_t)0xa0d, (q15_t)0x9f4, (q15_t)0x9db, (q15_t)0x9c2, (q15_t)0x9a9, (q15_t)0x990, (q15_t)0x977, + (q15_t)0x95e, (q15_t)0x944, (q15_t)0x92b, (q15_t)0x912, (q15_t)0x8f9, (q15_t)0x8e0, (q15_t)0x8c7, (q15_t)0x8ae, + (q15_t)0x895, (q15_t)0x87c, (q15_t)0x863, (q15_t)0x84a, (q15_t)0x831, (q15_t)0x818, (q15_t)0x7fe, (q15_t)0x7e5, + (q15_t)0x7cc, (q15_t)0x7b3, (q15_t)0x79a, (q15_t)0x781, (q15_t)0x768, (q15_t)0x74f, (q15_t)0x736, (q15_t)0x71d, + (q15_t)0x704, (q15_t)0x6ea, (q15_t)0x6d1, (q15_t)0x6b8, (q15_t)0x69f, (q15_t)0x686, (q15_t)0x66d, (q15_t)0x654, + (q15_t)0x63b, (q15_t)0x622, (q15_t)0x609, (q15_t)0x5ef, (q15_t)0x5d6, (q15_t)0x5bd, (q15_t)0x5a4, (q15_t)0x58b, + (q15_t)0x572, (q15_t)0x559, (q15_t)0x540, (q15_t)0x527, (q15_t)0x50d, (q15_t)0x4f4, (q15_t)0x4db, (q15_t)0x4c2, + (q15_t)0x4a9, (q15_t)0x490, (q15_t)0x477, (q15_t)0x45e, (q15_t)0x445, (q15_t)0x42b, (q15_t)0x412, (q15_t)0x3f9, + (q15_t)0x3e0, (q15_t)0x3c7, (q15_t)0x3ae, (q15_t)0x395, (q15_t)0x37c, (q15_t)0x362, (q15_t)0x349, (q15_t)0x330, + (q15_t)0x317, (q15_t)0x2fe, (q15_t)0x2e5, (q15_t)0x2cc, (q15_t)0x2b3, (q15_t)0x299, (q15_t)0x280, (q15_t)0x267, + (q15_t)0x24e, (q15_t)0x235, (q15_t)0x21c, (q15_t)0x203, (q15_t)0x1ea, (q15_t)0x1d0, (q15_t)0x1b7, (q15_t)0x19e, + (q15_t)0x185, (q15_t)0x16c, (q15_t)0x153, (q15_t)0x13a, (q15_t)0x121, (q15_t)0x107, (q15_t)0xee, (q15_t)0xd5, + (q15_t)0xbc, (q15_t)0xa3, (q15_t)0x8a, (q15_t)0x71, (q15_t)0x57, (q15_t)0x3e, (q15_t)0x25, (q15_t)0xc + +}; + +static const q15_t ALIGN4 cos_factorsQ15_8192[8192] = { + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, + (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, (q15_t)0x7fff, + (q15_t)0x7fff, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, + (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffe, + (q15_t)0x7ffe, (q15_t)0x7ffe, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, + (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffd, (q15_t)0x7ffc, + (q15_t)0x7ffc, (q15_t)0x7ffc, (q15_t)0x7ffc, (q15_t)0x7ffc, (q15_t)0x7ffc, (q15_t)0x7ffc, (q15_t)0x7ffc, (q15_t)0x7ffc, + (q15_t)0x7ffc, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffb, + (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffb, (q15_t)0x7ffa, (q15_t)0x7ffa, (q15_t)0x7ffa, (q15_t)0x7ffa, (q15_t)0x7ffa, + (q15_t)0x7ffa, (q15_t)0x7ffa, (q15_t)0x7ffa, (q15_t)0x7ffa, (q15_t)0x7ff9, (q15_t)0x7ff9, (q15_t)0x7ff9, (q15_t)0x7ff9, + (q15_t)0x7ff9, (q15_t)0x7ff9, (q15_t)0x7ff9, (q15_t)0x7ff9, (q15_t)0x7ff8, (q15_t)0x7ff8, (q15_t)0x7ff8, (q15_t)0x7ff8, + (q15_t)0x7ff8, (q15_t)0x7ff8, (q15_t)0x7ff8, (q15_t)0x7ff7, (q15_t)0x7ff7, (q15_t)0x7ff7, (q15_t)0x7ff7, (q15_t)0x7ff7, + (q15_t)0x7ff7, (q15_t)0x7ff7, (q15_t)0x7ff6, (q15_t)0x7ff6, (q15_t)0x7ff6, (q15_t)0x7ff6, (q15_t)0x7ff6, (q15_t)0x7ff6, + (q15_t)0x7ff6, (q15_t)0x7ff5, (q15_t)0x7ff5, (q15_t)0x7ff5, (q15_t)0x7ff5, (q15_t)0x7ff5, (q15_t)0x7ff5, (q15_t)0x7ff4, + (q15_t)0x7ff4, (q15_t)0x7ff4, (q15_t)0x7ff4, (q15_t)0x7ff4, (q15_t)0x7ff4, (q15_t)0x7ff3, (q15_t)0x7ff3, (q15_t)0x7ff3, + (q15_t)0x7ff3, (q15_t)0x7ff3, (q15_t)0x7ff3, (q15_t)0x7ff2, (q15_t)0x7ff2, (q15_t)0x7ff2, (q15_t)0x7ff2, (q15_t)0x7ff2, + (q15_t)0x7ff1, (q15_t)0x7ff1, (q15_t)0x7ff1, (q15_t)0x7ff1, (q15_t)0x7ff1, (q15_t)0x7ff1, (q15_t)0x7ff0, (q15_t)0x7ff0, + (q15_t)0x7ff0, (q15_t)0x7ff0, (q15_t)0x7ff0, (q15_t)0x7fef, (q15_t)0x7fef, (q15_t)0x7fef, (q15_t)0x7fef, (q15_t)0x7fef, + (q15_t)0x7fee, (q15_t)0x7fee, (q15_t)0x7fee, (q15_t)0x7fee, (q15_t)0x7fee, (q15_t)0x7fed, (q15_t)0x7fed, (q15_t)0x7fed, + (q15_t)0x7fed, (q15_t)0x7fed, (q15_t)0x7fec, (q15_t)0x7fec, (q15_t)0x7fec, (q15_t)0x7fec, (q15_t)0x7feb, (q15_t)0x7feb, + (q15_t)0x7feb, (q15_t)0x7feb, (q15_t)0x7feb, (q15_t)0x7fea, (q15_t)0x7fea, (q15_t)0x7fea, (q15_t)0x7fea, (q15_t)0x7fe9, + (q15_t)0x7fe9, (q15_t)0x7fe9, (q15_t)0x7fe9, (q15_t)0x7fe8, (q15_t)0x7fe8, (q15_t)0x7fe8, (q15_t)0x7fe8, (q15_t)0x7fe8, + (q15_t)0x7fe7, (q15_t)0x7fe7, (q15_t)0x7fe7, (q15_t)0x7fe7, (q15_t)0x7fe6, (q15_t)0x7fe6, (q15_t)0x7fe6, (q15_t)0x7fe6, + (q15_t)0x7fe5, (q15_t)0x7fe5, (q15_t)0x7fe5, (q15_t)0x7fe5, (q15_t)0x7fe4, (q15_t)0x7fe4, (q15_t)0x7fe4, (q15_t)0x7fe4, + (q15_t)0x7fe3, (q15_t)0x7fe3, (q15_t)0x7fe3, (q15_t)0x7fe2, (q15_t)0x7fe2, (q15_t)0x7fe2, (q15_t)0x7fe2, (q15_t)0x7fe1, + (q15_t)0x7fe1, (q15_t)0x7fe1, (q15_t)0x7fe1, (q15_t)0x7fe0, (q15_t)0x7fe0, (q15_t)0x7fe0, (q15_t)0x7fdf, (q15_t)0x7fdf, + (q15_t)0x7fdf, (q15_t)0x7fdf, (q15_t)0x7fde, (q15_t)0x7fde, (q15_t)0x7fde, (q15_t)0x7fde, (q15_t)0x7fdd, (q15_t)0x7fdd, + (q15_t)0x7fdd, (q15_t)0x7fdc, (q15_t)0x7fdc, (q15_t)0x7fdc, (q15_t)0x7fdb, (q15_t)0x7fdb, (q15_t)0x7fdb, (q15_t)0x7fdb, + (q15_t)0x7fda, (q15_t)0x7fda, (q15_t)0x7fda, (q15_t)0x7fd9, (q15_t)0x7fd9, (q15_t)0x7fd9, (q15_t)0x7fd8, (q15_t)0x7fd8, + (q15_t)0x7fd8, (q15_t)0x7fd8, (q15_t)0x7fd7, (q15_t)0x7fd7, (q15_t)0x7fd7, (q15_t)0x7fd6, (q15_t)0x7fd6, (q15_t)0x7fd6, + (q15_t)0x7fd5, (q15_t)0x7fd5, (q15_t)0x7fd5, (q15_t)0x7fd4, (q15_t)0x7fd4, (q15_t)0x7fd4, (q15_t)0x7fd3, (q15_t)0x7fd3, + (q15_t)0x7fd3, (q15_t)0x7fd2, (q15_t)0x7fd2, (q15_t)0x7fd2, (q15_t)0x7fd1, (q15_t)0x7fd1, (q15_t)0x7fd1, (q15_t)0x7fd0, + (q15_t)0x7fd0, (q15_t)0x7fd0, (q15_t)0x7fcf, (q15_t)0x7fcf, (q15_t)0x7fcf, (q15_t)0x7fce, (q15_t)0x7fce, (q15_t)0x7fce, + (q15_t)0x7fcd, (q15_t)0x7fcd, (q15_t)0x7fcd, (q15_t)0x7fcc, (q15_t)0x7fcc, (q15_t)0x7fcc, (q15_t)0x7fcb, (q15_t)0x7fcb, + (q15_t)0x7fcb, (q15_t)0x7fca, (q15_t)0x7fca, (q15_t)0x7fc9, (q15_t)0x7fc9, (q15_t)0x7fc9, (q15_t)0x7fc8, (q15_t)0x7fc8, + (q15_t)0x7fc8, (q15_t)0x7fc7, (q15_t)0x7fc7, (q15_t)0x7fc7, (q15_t)0x7fc6, (q15_t)0x7fc6, (q15_t)0x7fc5, (q15_t)0x7fc5, + (q15_t)0x7fc5, (q15_t)0x7fc4, (q15_t)0x7fc4, (q15_t)0x7fc4, (q15_t)0x7fc3, (q15_t)0x7fc3, (q15_t)0x7fc2, (q15_t)0x7fc2, + (q15_t)0x7fc2, (q15_t)0x7fc1, (q15_t)0x7fc1, (q15_t)0x7fc0, (q15_t)0x7fc0, (q15_t)0x7fc0, (q15_t)0x7fbf, (q15_t)0x7fbf, + (q15_t)0x7fbf, (q15_t)0x7fbe, (q15_t)0x7fbe, (q15_t)0x7fbd, (q15_t)0x7fbd, (q15_t)0x7fbd, (q15_t)0x7fbc, (q15_t)0x7fbc, + (q15_t)0x7fbb, (q15_t)0x7fbb, (q15_t)0x7fbb, (q15_t)0x7fba, (q15_t)0x7fba, (q15_t)0x7fb9, (q15_t)0x7fb9, (q15_t)0x7fb8, + (q15_t)0x7fb8, (q15_t)0x7fb8, (q15_t)0x7fb7, (q15_t)0x7fb7, (q15_t)0x7fb6, (q15_t)0x7fb6, (q15_t)0x7fb6, (q15_t)0x7fb5, + (q15_t)0x7fb5, (q15_t)0x7fb4, (q15_t)0x7fb4, (q15_t)0x7fb3, (q15_t)0x7fb3, (q15_t)0x7fb3, (q15_t)0x7fb2, (q15_t)0x7fb2, + (q15_t)0x7fb1, (q15_t)0x7fb1, (q15_t)0x7fb0, (q15_t)0x7fb0, (q15_t)0x7faf, (q15_t)0x7faf, (q15_t)0x7faf, (q15_t)0x7fae, + (q15_t)0x7fae, (q15_t)0x7fad, (q15_t)0x7fad, (q15_t)0x7fac, (q15_t)0x7fac, (q15_t)0x7fac, (q15_t)0x7fab, (q15_t)0x7fab, + (q15_t)0x7faa, (q15_t)0x7faa, (q15_t)0x7fa9, (q15_t)0x7fa9, (q15_t)0x7fa8, (q15_t)0x7fa8, (q15_t)0x7fa7, (q15_t)0x7fa7, + (q15_t)0x7fa6, (q15_t)0x7fa6, (q15_t)0x7fa6, (q15_t)0x7fa5, (q15_t)0x7fa5, (q15_t)0x7fa4, (q15_t)0x7fa4, (q15_t)0x7fa3, + (q15_t)0x7fa3, (q15_t)0x7fa2, (q15_t)0x7fa2, (q15_t)0x7fa1, (q15_t)0x7fa1, (q15_t)0x7fa0, (q15_t)0x7fa0, (q15_t)0x7f9f, + (q15_t)0x7f9f, (q15_t)0x7f9e, (q15_t)0x7f9e, (q15_t)0x7f9d, (q15_t)0x7f9d, (q15_t)0x7f9c, (q15_t)0x7f9c, (q15_t)0x7f9c, + (q15_t)0x7f9b, (q15_t)0x7f9b, (q15_t)0x7f9a, (q15_t)0x7f9a, (q15_t)0x7f99, (q15_t)0x7f99, (q15_t)0x7f98, (q15_t)0x7f98, + (q15_t)0x7f97, (q15_t)0x7f97, (q15_t)0x7f96, (q15_t)0x7f96, (q15_t)0x7f95, (q15_t)0x7f95, (q15_t)0x7f94, (q15_t)0x7f94, + (q15_t)0x7f93, (q15_t)0x7f92, (q15_t)0x7f92, (q15_t)0x7f91, (q15_t)0x7f91, (q15_t)0x7f90, (q15_t)0x7f90, (q15_t)0x7f8f, + (q15_t)0x7f8f, (q15_t)0x7f8e, (q15_t)0x7f8e, (q15_t)0x7f8d, (q15_t)0x7f8d, (q15_t)0x7f8c, (q15_t)0x7f8c, (q15_t)0x7f8b, + (q15_t)0x7f8b, (q15_t)0x7f8a, (q15_t)0x7f8a, (q15_t)0x7f89, (q15_t)0x7f89, (q15_t)0x7f88, (q15_t)0x7f87, (q15_t)0x7f87, + (q15_t)0x7f86, (q15_t)0x7f86, (q15_t)0x7f85, (q15_t)0x7f85, (q15_t)0x7f84, (q15_t)0x7f84, (q15_t)0x7f83, (q15_t)0x7f83, + (q15_t)0x7f82, (q15_t)0x7f81, (q15_t)0x7f81, (q15_t)0x7f80, (q15_t)0x7f80, (q15_t)0x7f7f, (q15_t)0x7f7f, (q15_t)0x7f7e, + (q15_t)0x7f7e, (q15_t)0x7f7d, (q15_t)0x7f7c, (q15_t)0x7f7c, (q15_t)0x7f7b, (q15_t)0x7f7b, (q15_t)0x7f7a, (q15_t)0x7f7a, + (q15_t)0x7f79, (q15_t)0x7f79, (q15_t)0x7f78, (q15_t)0x7f77, (q15_t)0x7f77, (q15_t)0x7f76, (q15_t)0x7f76, (q15_t)0x7f75, + (q15_t)0x7f75, (q15_t)0x7f74, (q15_t)0x7f73, (q15_t)0x7f73, (q15_t)0x7f72, (q15_t)0x7f72, (q15_t)0x7f71, (q15_t)0x7f70, + (q15_t)0x7f70, (q15_t)0x7f6f, (q15_t)0x7f6f, (q15_t)0x7f6e, (q15_t)0x7f6d, (q15_t)0x7f6d, (q15_t)0x7f6c, (q15_t)0x7f6c, + (q15_t)0x7f6b, (q15_t)0x7f6b, (q15_t)0x7f6a, (q15_t)0x7f69, (q15_t)0x7f69, (q15_t)0x7f68, (q15_t)0x7f68, (q15_t)0x7f67, + (q15_t)0x7f66, (q15_t)0x7f66, (q15_t)0x7f65, (q15_t)0x7f64, (q15_t)0x7f64, (q15_t)0x7f63, (q15_t)0x7f63, (q15_t)0x7f62, + (q15_t)0x7f61, (q15_t)0x7f61, (q15_t)0x7f60, (q15_t)0x7f60, (q15_t)0x7f5f, (q15_t)0x7f5e, (q15_t)0x7f5e, (q15_t)0x7f5d, + (q15_t)0x7f5c, (q15_t)0x7f5c, (q15_t)0x7f5b, (q15_t)0x7f5b, (q15_t)0x7f5a, (q15_t)0x7f59, (q15_t)0x7f59, (q15_t)0x7f58, + (q15_t)0x7f57, (q15_t)0x7f57, (q15_t)0x7f56, (q15_t)0x7f55, (q15_t)0x7f55, (q15_t)0x7f54, (q15_t)0x7f54, (q15_t)0x7f53, + (q15_t)0x7f52, (q15_t)0x7f52, (q15_t)0x7f51, (q15_t)0x7f50, (q15_t)0x7f50, (q15_t)0x7f4f, (q15_t)0x7f4e, (q15_t)0x7f4e, + (q15_t)0x7f4d, (q15_t)0x7f4c, (q15_t)0x7f4c, (q15_t)0x7f4b, (q15_t)0x7f4a, (q15_t)0x7f4a, (q15_t)0x7f49, (q15_t)0x7f48, + (q15_t)0x7f48, (q15_t)0x7f47, (q15_t)0x7f46, (q15_t)0x7f46, (q15_t)0x7f45, (q15_t)0x7f44, (q15_t)0x7f44, (q15_t)0x7f43, + (q15_t)0x7f42, (q15_t)0x7f42, (q15_t)0x7f41, (q15_t)0x7f40, (q15_t)0x7f40, (q15_t)0x7f3f, (q15_t)0x7f3e, (q15_t)0x7f3e, + (q15_t)0x7f3d, (q15_t)0x7f3c, (q15_t)0x7f3c, (q15_t)0x7f3b, (q15_t)0x7f3a, (q15_t)0x7f3a, (q15_t)0x7f39, (q15_t)0x7f38, + (q15_t)0x7f37, (q15_t)0x7f37, (q15_t)0x7f36, (q15_t)0x7f35, (q15_t)0x7f35, (q15_t)0x7f34, (q15_t)0x7f33, (q15_t)0x7f33, + (q15_t)0x7f32, (q15_t)0x7f31, (q15_t)0x7f31, (q15_t)0x7f30, (q15_t)0x7f2f, (q15_t)0x7f2e, (q15_t)0x7f2e, (q15_t)0x7f2d, + (q15_t)0x7f2c, (q15_t)0x7f2c, (q15_t)0x7f2b, (q15_t)0x7f2a, (q15_t)0x7f29, (q15_t)0x7f29, (q15_t)0x7f28, (q15_t)0x7f27, + (q15_t)0x7f27, (q15_t)0x7f26, (q15_t)0x7f25, (q15_t)0x7f24, (q15_t)0x7f24, (q15_t)0x7f23, (q15_t)0x7f22, (q15_t)0x7f21, + (q15_t)0x7f21, (q15_t)0x7f20, (q15_t)0x7f1f, (q15_t)0x7f1f, (q15_t)0x7f1e, (q15_t)0x7f1d, (q15_t)0x7f1c, (q15_t)0x7f1c, + (q15_t)0x7f1b, (q15_t)0x7f1a, (q15_t)0x7f19, (q15_t)0x7f19, (q15_t)0x7f18, (q15_t)0x7f17, (q15_t)0x7f16, (q15_t)0x7f16, + (q15_t)0x7f15, (q15_t)0x7f14, (q15_t)0x7f13, (q15_t)0x7f13, (q15_t)0x7f12, (q15_t)0x7f11, (q15_t)0x7f10, (q15_t)0x7f10, + (q15_t)0x7f0f, (q15_t)0x7f0e, (q15_t)0x7f0d, (q15_t)0x7f0d, (q15_t)0x7f0c, (q15_t)0x7f0b, (q15_t)0x7f0a, (q15_t)0x7f09, + (q15_t)0x7f09, (q15_t)0x7f08, (q15_t)0x7f07, (q15_t)0x7f06, (q15_t)0x7f06, (q15_t)0x7f05, (q15_t)0x7f04, (q15_t)0x7f03, + (q15_t)0x7f02, (q15_t)0x7f02, (q15_t)0x7f01, (q15_t)0x7f00, (q15_t)0x7eff, (q15_t)0x7eff, (q15_t)0x7efe, (q15_t)0x7efd, + (q15_t)0x7efc, (q15_t)0x7efb, (q15_t)0x7efb, (q15_t)0x7efa, (q15_t)0x7ef9, (q15_t)0x7ef8, (q15_t)0x7ef7, (q15_t)0x7ef7, + (q15_t)0x7ef6, (q15_t)0x7ef5, (q15_t)0x7ef4, (q15_t)0x7ef3, (q15_t)0x7ef3, (q15_t)0x7ef2, (q15_t)0x7ef1, (q15_t)0x7ef0, + (q15_t)0x7eef, (q15_t)0x7eef, (q15_t)0x7eee, (q15_t)0x7eed, (q15_t)0x7eec, (q15_t)0x7eeb, (q15_t)0x7eeb, (q15_t)0x7eea, + (q15_t)0x7ee9, (q15_t)0x7ee8, (q15_t)0x7ee7, (q15_t)0x7ee6, (q15_t)0x7ee6, (q15_t)0x7ee5, (q15_t)0x7ee4, (q15_t)0x7ee3, + (q15_t)0x7ee2, (q15_t)0x7ee2, (q15_t)0x7ee1, (q15_t)0x7ee0, (q15_t)0x7edf, (q15_t)0x7ede, (q15_t)0x7edd, (q15_t)0x7edd, + (q15_t)0x7edc, (q15_t)0x7edb, (q15_t)0x7eda, (q15_t)0x7ed9, (q15_t)0x7ed8, (q15_t)0x7ed8, (q15_t)0x7ed7, (q15_t)0x7ed6, + (q15_t)0x7ed5, (q15_t)0x7ed4, (q15_t)0x7ed3, (q15_t)0x7ed2, (q15_t)0x7ed2, (q15_t)0x7ed1, (q15_t)0x7ed0, (q15_t)0x7ecf, + (q15_t)0x7ece, (q15_t)0x7ecd, (q15_t)0x7ecc, (q15_t)0x7ecc, (q15_t)0x7ecb, (q15_t)0x7eca, (q15_t)0x7ec9, (q15_t)0x7ec8, + (q15_t)0x7ec7, (q15_t)0x7ec6, (q15_t)0x7ec6, (q15_t)0x7ec5, (q15_t)0x7ec4, (q15_t)0x7ec3, (q15_t)0x7ec2, (q15_t)0x7ec1, + (q15_t)0x7ec0, (q15_t)0x7ebf, (q15_t)0x7ebf, (q15_t)0x7ebe, (q15_t)0x7ebd, (q15_t)0x7ebc, (q15_t)0x7ebb, (q15_t)0x7eba, + (q15_t)0x7eb9, (q15_t)0x7eb8, (q15_t)0x7eb8, (q15_t)0x7eb7, (q15_t)0x7eb6, (q15_t)0x7eb5, (q15_t)0x7eb4, (q15_t)0x7eb3, + (q15_t)0x7eb2, (q15_t)0x7eb1, (q15_t)0x7eb0, (q15_t)0x7eaf, (q15_t)0x7eaf, (q15_t)0x7eae, (q15_t)0x7ead, (q15_t)0x7eac, + (q15_t)0x7eab, (q15_t)0x7eaa, (q15_t)0x7ea9, (q15_t)0x7ea8, (q15_t)0x7ea7, (q15_t)0x7ea6, (q15_t)0x7ea6, (q15_t)0x7ea5, + (q15_t)0x7ea4, (q15_t)0x7ea3, (q15_t)0x7ea2, (q15_t)0x7ea1, (q15_t)0x7ea0, (q15_t)0x7e9f, (q15_t)0x7e9e, (q15_t)0x7e9d, + (q15_t)0x7e9c, (q15_t)0x7e9b, (q15_t)0x7e9b, (q15_t)0x7e9a, (q15_t)0x7e99, (q15_t)0x7e98, (q15_t)0x7e97, (q15_t)0x7e96, + (q15_t)0x7e95, (q15_t)0x7e94, (q15_t)0x7e93, (q15_t)0x7e92, (q15_t)0x7e91, (q15_t)0x7e90, (q15_t)0x7e8f, (q15_t)0x7e8e, + (q15_t)0x7e8d, (q15_t)0x7e8d, (q15_t)0x7e8c, (q15_t)0x7e8b, (q15_t)0x7e8a, (q15_t)0x7e89, (q15_t)0x7e88, (q15_t)0x7e87, + (q15_t)0x7e86, (q15_t)0x7e85, (q15_t)0x7e84, (q15_t)0x7e83, (q15_t)0x7e82, (q15_t)0x7e81, (q15_t)0x7e80, (q15_t)0x7e7f, + (q15_t)0x7e7e, (q15_t)0x7e7d, (q15_t)0x7e7c, (q15_t)0x7e7b, (q15_t)0x7e7a, (q15_t)0x7e79, (q15_t)0x7e78, (q15_t)0x7e77, + (q15_t)0x7e77, (q15_t)0x7e76, (q15_t)0x7e75, (q15_t)0x7e74, (q15_t)0x7e73, (q15_t)0x7e72, (q15_t)0x7e71, (q15_t)0x7e70, + (q15_t)0x7e6f, (q15_t)0x7e6e, (q15_t)0x7e6d, (q15_t)0x7e6c, (q15_t)0x7e6b, (q15_t)0x7e6a, (q15_t)0x7e69, (q15_t)0x7e68, + (q15_t)0x7e67, (q15_t)0x7e66, (q15_t)0x7e65, (q15_t)0x7e64, (q15_t)0x7e63, (q15_t)0x7e62, (q15_t)0x7e61, (q15_t)0x7e60, + (q15_t)0x7e5f, (q15_t)0x7e5e, (q15_t)0x7e5d, (q15_t)0x7e5c, (q15_t)0x7e5b, (q15_t)0x7e5a, (q15_t)0x7e59, (q15_t)0x7e58, + (q15_t)0x7e57, (q15_t)0x7e56, (q15_t)0x7e55, (q15_t)0x7e54, (q15_t)0x7e53, (q15_t)0x7e52, (q15_t)0x7e51, (q15_t)0x7e50, + (q15_t)0x7e4f, (q15_t)0x7e4e, (q15_t)0x7e4d, (q15_t)0x7e4c, (q15_t)0x7e4b, (q15_t)0x7e4a, (q15_t)0x7e49, (q15_t)0x7e48, + (q15_t)0x7e47, (q15_t)0x7e46, (q15_t)0x7e45, (q15_t)0x7e43, (q15_t)0x7e42, (q15_t)0x7e41, (q15_t)0x7e40, (q15_t)0x7e3f, + (q15_t)0x7e3e, (q15_t)0x7e3d, (q15_t)0x7e3c, (q15_t)0x7e3b, (q15_t)0x7e3a, (q15_t)0x7e39, (q15_t)0x7e38, (q15_t)0x7e37, + (q15_t)0x7e36, (q15_t)0x7e35, (q15_t)0x7e34, (q15_t)0x7e33, (q15_t)0x7e32, (q15_t)0x7e31, (q15_t)0x7e30, (q15_t)0x7e2f, + (q15_t)0x7e2e, (q15_t)0x7e2d, (q15_t)0x7e2b, (q15_t)0x7e2a, (q15_t)0x7e29, (q15_t)0x7e28, (q15_t)0x7e27, (q15_t)0x7e26, + (q15_t)0x7e25, (q15_t)0x7e24, (q15_t)0x7e23, (q15_t)0x7e22, (q15_t)0x7e21, (q15_t)0x7e20, (q15_t)0x7e1f, (q15_t)0x7e1e, + (q15_t)0x7e1d, (q15_t)0x7e1b, (q15_t)0x7e1a, (q15_t)0x7e19, (q15_t)0x7e18, (q15_t)0x7e17, (q15_t)0x7e16, (q15_t)0x7e15, + (q15_t)0x7e14, (q15_t)0x7e13, (q15_t)0x7e12, (q15_t)0x7e11, (q15_t)0x7e10, (q15_t)0x7e0e, (q15_t)0x7e0d, (q15_t)0x7e0c, + (q15_t)0x7e0b, (q15_t)0x7e0a, (q15_t)0x7e09, (q15_t)0x7e08, (q15_t)0x7e07, (q15_t)0x7e06, (q15_t)0x7e05, (q15_t)0x7e04, + (q15_t)0x7e02, (q15_t)0x7e01, (q15_t)0x7e00, (q15_t)0x7dff, (q15_t)0x7dfe, (q15_t)0x7dfd, (q15_t)0x7dfc, (q15_t)0x7dfb, + (q15_t)0x7dfa, (q15_t)0x7df8, (q15_t)0x7df7, (q15_t)0x7df6, (q15_t)0x7df5, (q15_t)0x7df4, (q15_t)0x7df3, (q15_t)0x7df2, + (q15_t)0x7df1, (q15_t)0x7def, (q15_t)0x7dee, (q15_t)0x7ded, (q15_t)0x7dec, (q15_t)0x7deb, (q15_t)0x7dea, (q15_t)0x7de9, + (q15_t)0x7de8, (q15_t)0x7de6, (q15_t)0x7de5, (q15_t)0x7de4, (q15_t)0x7de3, (q15_t)0x7de2, (q15_t)0x7de1, (q15_t)0x7de0, + (q15_t)0x7dde, (q15_t)0x7ddd, (q15_t)0x7ddc, (q15_t)0x7ddb, (q15_t)0x7dda, (q15_t)0x7dd9, (q15_t)0x7dd8, (q15_t)0x7dd6, + (q15_t)0x7dd5, (q15_t)0x7dd4, (q15_t)0x7dd3, (q15_t)0x7dd2, (q15_t)0x7dd1, (q15_t)0x7dd0, (q15_t)0x7dce, (q15_t)0x7dcd, + (q15_t)0x7dcc, (q15_t)0x7dcb, (q15_t)0x7dca, (q15_t)0x7dc9, (q15_t)0x7dc7, (q15_t)0x7dc6, (q15_t)0x7dc5, (q15_t)0x7dc4, + (q15_t)0x7dc3, (q15_t)0x7dc2, (q15_t)0x7dc0, (q15_t)0x7dbf, (q15_t)0x7dbe, (q15_t)0x7dbd, (q15_t)0x7dbc, (q15_t)0x7dbb, + (q15_t)0x7db9, (q15_t)0x7db8, (q15_t)0x7db7, (q15_t)0x7db6, (q15_t)0x7db5, (q15_t)0x7db3, (q15_t)0x7db2, (q15_t)0x7db1, + (q15_t)0x7db0, (q15_t)0x7daf, (q15_t)0x7dae, (q15_t)0x7dac, (q15_t)0x7dab, (q15_t)0x7daa, (q15_t)0x7da9, (q15_t)0x7da8, + (q15_t)0x7da6, (q15_t)0x7da5, (q15_t)0x7da4, (q15_t)0x7da3, (q15_t)0x7da2, (q15_t)0x7da0, (q15_t)0x7d9f, (q15_t)0x7d9e, + (q15_t)0x7d9d, (q15_t)0x7d9c, (q15_t)0x7d9a, (q15_t)0x7d99, (q15_t)0x7d98, (q15_t)0x7d97, (q15_t)0x7d95, (q15_t)0x7d94, + (q15_t)0x7d93, (q15_t)0x7d92, (q15_t)0x7d91, (q15_t)0x7d8f, (q15_t)0x7d8e, (q15_t)0x7d8d, (q15_t)0x7d8c, (q15_t)0x7d8a, + (q15_t)0x7d89, (q15_t)0x7d88, (q15_t)0x7d87, (q15_t)0x7d86, (q15_t)0x7d84, (q15_t)0x7d83, (q15_t)0x7d82, (q15_t)0x7d81, + (q15_t)0x7d7f, (q15_t)0x7d7e, (q15_t)0x7d7d, (q15_t)0x7d7c, (q15_t)0x7d7a, (q15_t)0x7d79, (q15_t)0x7d78, (q15_t)0x7d77, + (q15_t)0x7d75, (q15_t)0x7d74, (q15_t)0x7d73, (q15_t)0x7d72, (q15_t)0x7d70, (q15_t)0x7d6f, (q15_t)0x7d6e, (q15_t)0x7d6d, + (q15_t)0x7d6b, (q15_t)0x7d6a, (q15_t)0x7d69, (q15_t)0x7d68, (q15_t)0x7d66, (q15_t)0x7d65, (q15_t)0x7d64, (q15_t)0x7d63, + (q15_t)0x7d61, (q15_t)0x7d60, (q15_t)0x7d5f, (q15_t)0x7d5e, (q15_t)0x7d5c, (q15_t)0x7d5b, (q15_t)0x7d5a, (q15_t)0x7d59, + (q15_t)0x7d57, (q15_t)0x7d56, (q15_t)0x7d55, (q15_t)0x7d53, (q15_t)0x7d52, (q15_t)0x7d51, (q15_t)0x7d50, (q15_t)0x7d4e, + (q15_t)0x7d4d, (q15_t)0x7d4c, (q15_t)0x7d4a, (q15_t)0x7d49, (q15_t)0x7d48, (q15_t)0x7d47, (q15_t)0x7d45, (q15_t)0x7d44, + (q15_t)0x7d43, (q15_t)0x7d41, (q15_t)0x7d40, (q15_t)0x7d3f, (q15_t)0x7d3e, (q15_t)0x7d3c, (q15_t)0x7d3b, (q15_t)0x7d3a, + (q15_t)0x7d38, (q15_t)0x7d37, (q15_t)0x7d36, (q15_t)0x7d34, (q15_t)0x7d33, (q15_t)0x7d32, (q15_t)0x7d31, (q15_t)0x7d2f, + (q15_t)0x7d2e, (q15_t)0x7d2d, (q15_t)0x7d2b, (q15_t)0x7d2a, (q15_t)0x7d29, (q15_t)0x7d27, (q15_t)0x7d26, (q15_t)0x7d25, + (q15_t)0x7d23, (q15_t)0x7d22, (q15_t)0x7d21, (q15_t)0x7d1f, (q15_t)0x7d1e, (q15_t)0x7d1d, (q15_t)0x7d1b, (q15_t)0x7d1a, + (q15_t)0x7d19, (q15_t)0x7d17, (q15_t)0x7d16, (q15_t)0x7d15, (q15_t)0x7d13, (q15_t)0x7d12, (q15_t)0x7d11, (q15_t)0x7d0f, + (q15_t)0x7d0e, (q15_t)0x7d0d, (q15_t)0x7d0b, (q15_t)0x7d0a, (q15_t)0x7d09, (q15_t)0x7d07, (q15_t)0x7d06, (q15_t)0x7d05, + (q15_t)0x7d03, (q15_t)0x7d02, (q15_t)0x7d01, (q15_t)0x7cff, (q15_t)0x7cfe, (q15_t)0x7cfd, (q15_t)0x7cfb, (q15_t)0x7cfa, + (q15_t)0x7cf9, (q15_t)0x7cf7, (q15_t)0x7cf6, (q15_t)0x7cf4, (q15_t)0x7cf3, (q15_t)0x7cf2, (q15_t)0x7cf0, (q15_t)0x7cef, + (q15_t)0x7cee, (q15_t)0x7cec, (q15_t)0x7ceb, (q15_t)0x7ce9, (q15_t)0x7ce8, (q15_t)0x7ce7, (q15_t)0x7ce5, (q15_t)0x7ce4, + (q15_t)0x7ce3, (q15_t)0x7ce1, (q15_t)0x7ce0, (q15_t)0x7cde, (q15_t)0x7cdd, (q15_t)0x7cdc, (q15_t)0x7cda, (q15_t)0x7cd9, + (q15_t)0x7cd8, (q15_t)0x7cd6, (q15_t)0x7cd5, (q15_t)0x7cd3, (q15_t)0x7cd2, (q15_t)0x7cd1, (q15_t)0x7ccf, (q15_t)0x7cce, + (q15_t)0x7ccc, (q15_t)0x7ccb, (q15_t)0x7cca, (q15_t)0x7cc8, (q15_t)0x7cc7, (q15_t)0x7cc5, (q15_t)0x7cc4, (q15_t)0x7cc3, + (q15_t)0x7cc1, (q15_t)0x7cc0, (q15_t)0x7cbe, (q15_t)0x7cbd, (q15_t)0x7cbc, (q15_t)0x7cba, (q15_t)0x7cb9, (q15_t)0x7cb7, + (q15_t)0x7cb6, (q15_t)0x7cb5, (q15_t)0x7cb3, (q15_t)0x7cb2, (q15_t)0x7cb0, (q15_t)0x7caf, (q15_t)0x7cad, (q15_t)0x7cac, + (q15_t)0x7cab, (q15_t)0x7ca9, (q15_t)0x7ca8, (q15_t)0x7ca6, (q15_t)0x7ca5, (q15_t)0x7ca3, (q15_t)0x7ca2, (q15_t)0x7ca1, + (q15_t)0x7c9f, (q15_t)0x7c9e, (q15_t)0x7c9c, (q15_t)0x7c9b, (q15_t)0x7c99, (q15_t)0x7c98, (q15_t)0x7c97, (q15_t)0x7c95, + (q15_t)0x7c94, (q15_t)0x7c92, (q15_t)0x7c91, (q15_t)0x7c8f, (q15_t)0x7c8e, (q15_t)0x7c8c, (q15_t)0x7c8b, (q15_t)0x7c8a, + (q15_t)0x7c88, (q15_t)0x7c87, (q15_t)0x7c85, (q15_t)0x7c84, (q15_t)0x7c82, (q15_t)0x7c81, (q15_t)0x7c7f, (q15_t)0x7c7e, + (q15_t)0x7c7c, (q15_t)0x7c7b, (q15_t)0x7c79, (q15_t)0x7c78, (q15_t)0x7c77, (q15_t)0x7c75, (q15_t)0x7c74, (q15_t)0x7c72, + (q15_t)0x7c71, (q15_t)0x7c6f, (q15_t)0x7c6e, (q15_t)0x7c6c, (q15_t)0x7c6b, (q15_t)0x7c69, (q15_t)0x7c68, (q15_t)0x7c66, + (q15_t)0x7c65, (q15_t)0x7c63, (q15_t)0x7c62, (q15_t)0x7c60, (q15_t)0x7c5f, (q15_t)0x7c5d, (q15_t)0x7c5c, (q15_t)0x7c5a, + (q15_t)0x7c59, (q15_t)0x7c58, (q15_t)0x7c56, (q15_t)0x7c55, (q15_t)0x7c53, (q15_t)0x7c52, (q15_t)0x7c50, (q15_t)0x7c4f, + (q15_t)0x7c4d, (q15_t)0x7c4c, (q15_t)0x7c4a, (q15_t)0x7c49, (q15_t)0x7c47, (q15_t)0x7c46, (q15_t)0x7c44, (q15_t)0x7c43, + (q15_t)0x7c41, (q15_t)0x7c3f, (q15_t)0x7c3e, (q15_t)0x7c3c, (q15_t)0x7c3b, (q15_t)0x7c39, (q15_t)0x7c38, (q15_t)0x7c36, + (q15_t)0x7c35, (q15_t)0x7c33, (q15_t)0x7c32, (q15_t)0x7c30, (q15_t)0x7c2f, (q15_t)0x7c2d, (q15_t)0x7c2c, (q15_t)0x7c2a, + (q15_t)0x7c29, (q15_t)0x7c27, (q15_t)0x7c26, (q15_t)0x7c24, (q15_t)0x7c23, (q15_t)0x7c21, (q15_t)0x7c20, (q15_t)0x7c1e, + (q15_t)0x7c1c, (q15_t)0x7c1b, (q15_t)0x7c19, (q15_t)0x7c18, (q15_t)0x7c16, (q15_t)0x7c15, (q15_t)0x7c13, (q15_t)0x7c12, + (q15_t)0x7c10, (q15_t)0x7c0f, (q15_t)0x7c0d, (q15_t)0x7c0b, (q15_t)0x7c0a, (q15_t)0x7c08, (q15_t)0x7c07, (q15_t)0x7c05, + (q15_t)0x7c04, (q15_t)0x7c02, (q15_t)0x7c01, (q15_t)0x7bff, (q15_t)0x7bfd, (q15_t)0x7bfc, (q15_t)0x7bfa, (q15_t)0x7bf9, + (q15_t)0x7bf7, (q15_t)0x7bf6, (q15_t)0x7bf4, (q15_t)0x7bf3, (q15_t)0x7bf1, (q15_t)0x7bef, (q15_t)0x7bee, (q15_t)0x7bec, + (q15_t)0x7beb, (q15_t)0x7be9, (q15_t)0x7be8, (q15_t)0x7be6, (q15_t)0x7be4, (q15_t)0x7be3, (q15_t)0x7be1, (q15_t)0x7be0, + (q15_t)0x7bde, (q15_t)0x7bdc, (q15_t)0x7bdb, (q15_t)0x7bd9, (q15_t)0x7bd8, (q15_t)0x7bd6, (q15_t)0x7bd5, (q15_t)0x7bd3, + (q15_t)0x7bd1, (q15_t)0x7bd0, (q15_t)0x7bce, (q15_t)0x7bcd, (q15_t)0x7bcb, (q15_t)0x7bc9, (q15_t)0x7bc8, (q15_t)0x7bc6, + (q15_t)0x7bc5, (q15_t)0x7bc3, (q15_t)0x7bc1, (q15_t)0x7bc0, (q15_t)0x7bbe, (q15_t)0x7bbd, (q15_t)0x7bbb, (q15_t)0x7bb9, + (q15_t)0x7bb8, (q15_t)0x7bb6, (q15_t)0x7bb5, (q15_t)0x7bb3, (q15_t)0x7bb1, (q15_t)0x7bb0, (q15_t)0x7bae, (q15_t)0x7bac, + (q15_t)0x7bab, (q15_t)0x7ba9, (q15_t)0x7ba8, (q15_t)0x7ba6, (q15_t)0x7ba4, (q15_t)0x7ba3, (q15_t)0x7ba1, (q15_t)0x7b9f, + (q15_t)0x7b9e, (q15_t)0x7b9c, (q15_t)0x7b9b, (q15_t)0x7b99, (q15_t)0x7b97, (q15_t)0x7b96, (q15_t)0x7b94, (q15_t)0x7b92, + (q15_t)0x7b91, (q15_t)0x7b8f, (q15_t)0x7b8d, (q15_t)0x7b8c, (q15_t)0x7b8a, (q15_t)0x7b89, (q15_t)0x7b87, (q15_t)0x7b85, + (q15_t)0x7b84, (q15_t)0x7b82, (q15_t)0x7b80, (q15_t)0x7b7f, (q15_t)0x7b7d, (q15_t)0x7b7b, (q15_t)0x7b7a, (q15_t)0x7b78, + (q15_t)0x7b76, (q15_t)0x7b75, (q15_t)0x7b73, (q15_t)0x7b71, (q15_t)0x7b70, (q15_t)0x7b6e, (q15_t)0x7b6c, (q15_t)0x7b6b, + (q15_t)0x7b69, (q15_t)0x7b67, (q15_t)0x7b66, (q15_t)0x7b64, (q15_t)0x7b62, (q15_t)0x7b61, (q15_t)0x7b5f, (q15_t)0x7b5d, + (q15_t)0x7b5c, (q15_t)0x7b5a, (q15_t)0x7b58, (q15_t)0x7b57, (q15_t)0x7b55, (q15_t)0x7b53, (q15_t)0x7b52, (q15_t)0x7b50, + (q15_t)0x7b4e, (q15_t)0x7b4d, (q15_t)0x7b4b, (q15_t)0x7b49, (q15_t)0x7b47, (q15_t)0x7b46, (q15_t)0x7b44, (q15_t)0x7b42, + (q15_t)0x7b41, (q15_t)0x7b3f, (q15_t)0x7b3d, (q15_t)0x7b3c, (q15_t)0x7b3a, (q15_t)0x7b38, (q15_t)0x7b37, (q15_t)0x7b35, + (q15_t)0x7b33, (q15_t)0x7b31, (q15_t)0x7b30, (q15_t)0x7b2e, (q15_t)0x7b2c, (q15_t)0x7b2b, (q15_t)0x7b29, (q15_t)0x7b27, + (q15_t)0x7b25, (q15_t)0x7b24, (q15_t)0x7b22, (q15_t)0x7b20, (q15_t)0x7b1f, (q15_t)0x7b1d, (q15_t)0x7b1b, (q15_t)0x7b19, + (q15_t)0x7b18, (q15_t)0x7b16, (q15_t)0x7b14, (q15_t)0x7b13, (q15_t)0x7b11, (q15_t)0x7b0f, (q15_t)0x7b0d, (q15_t)0x7b0c, + (q15_t)0x7b0a, (q15_t)0x7b08, (q15_t)0x7b06, (q15_t)0x7b05, (q15_t)0x7b03, (q15_t)0x7b01, (q15_t)0x7aff, (q15_t)0x7afe, + (q15_t)0x7afc, (q15_t)0x7afa, (q15_t)0x7af8, (q15_t)0x7af7, (q15_t)0x7af5, (q15_t)0x7af3, (q15_t)0x7af2, (q15_t)0x7af0, + (q15_t)0x7aee, (q15_t)0x7aec, (q15_t)0x7aeb, (q15_t)0x7ae9, (q15_t)0x7ae7, (q15_t)0x7ae5, (q15_t)0x7ae3, (q15_t)0x7ae2, + (q15_t)0x7ae0, (q15_t)0x7ade, (q15_t)0x7adc, (q15_t)0x7adb, (q15_t)0x7ad9, (q15_t)0x7ad7, (q15_t)0x7ad5, (q15_t)0x7ad4, + (q15_t)0x7ad2, (q15_t)0x7ad0, (q15_t)0x7ace, (q15_t)0x7acd, (q15_t)0x7acb, (q15_t)0x7ac9, (q15_t)0x7ac7, (q15_t)0x7ac5, + (q15_t)0x7ac4, (q15_t)0x7ac2, (q15_t)0x7ac0, (q15_t)0x7abe, (q15_t)0x7abd, (q15_t)0x7abb, (q15_t)0x7ab9, (q15_t)0x7ab7, + (q15_t)0x7ab5, (q15_t)0x7ab4, (q15_t)0x7ab2, (q15_t)0x7ab0, (q15_t)0x7aae, (q15_t)0x7aac, (q15_t)0x7aab, (q15_t)0x7aa9, + (q15_t)0x7aa7, (q15_t)0x7aa5, (q15_t)0x7aa3, (q15_t)0x7aa2, (q15_t)0x7aa0, (q15_t)0x7a9e, (q15_t)0x7a9c, (q15_t)0x7a9a, + (q15_t)0x7a99, (q15_t)0x7a97, (q15_t)0x7a95, (q15_t)0x7a93, (q15_t)0x7a91, (q15_t)0x7a90, (q15_t)0x7a8e, (q15_t)0x7a8c, + (q15_t)0x7a8a, (q15_t)0x7a88, (q15_t)0x7a87, (q15_t)0x7a85, (q15_t)0x7a83, (q15_t)0x7a81, (q15_t)0x7a7f, (q15_t)0x7a7d, + (q15_t)0x7a7c, (q15_t)0x7a7a, (q15_t)0x7a78, (q15_t)0x7a76, (q15_t)0x7a74, (q15_t)0x7a72, (q15_t)0x7a71, (q15_t)0x7a6f, + (q15_t)0x7a6d, (q15_t)0x7a6b, (q15_t)0x7a69, (q15_t)0x7a67, (q15_t)0x7a66, (q15_t)0x7a64, (q15_t)0x7a62, (q15_t)0x7a60, + (q15_t)0x7a5e, (q15_t)0x7a5c, (q15_t)0x7a5b, (q15_t)0x7a59, (q15_t)0x7a57, (q15_t)0x7a55, (q15_t)0x7a53, (q15_t)0x7a51, + (q15_t)0x7a4f, (q15_t)0x7a4e, (q15_t)0x7a4c, (q15_t)0x7a4a, (q15_t)0x7a48, (q15_t)0x7a46, (q15_t)0x7a44, (q15_t)0x7a42, + (q15_t)0x7a41, (q15_t)0x7a3f, (q15_t)0x7a3d, (q15_t)0x7a3b, (q15_t)0x7a39, (q15_t)0x7a37, (q15_t)0x7a35, (q15_t)0x7a34, + (q15_t)0x7a32, (q15_t)0x7a30, (q15_t)0x7a2e, (q15_t)0x7a2c, (q15_t)0x7a2a, (q15_t)0x7a28, (q15_t)0x7a26, (q15_t)0x7a25, + (q15_t)0x7a23, (q15_t)0x7a21, (q15_t)0x7a1f, (q15_t)0x7a1d, (q15_t)0x7a1b, (q15_t)0x7a19, (q15_t)0x7a17, (q15_t)0x7a16, + (q15_t)0x7a14, (q15_t)0x7a12, (q15_t)0x7a10, (q15_t)0x7a0e, (q15_t)0x7a0c, (q15_t)0x7a0a, (q15_t)0x7a08, (q15_t)0x7a06, + (q15_t)0x7a04, (q15_t)0x7a03, (q15_t)0x7a01, (q15_t)0x79ff, (q15_t)0x79fd, (q15_t)0x79fb, (q15_t)0x79f9, (q15_t)0x79f7, + (q15_t)0x79f5, (q15_t)0x79f3, (q15_t)0x79f1, (q15_t)0x79f0, (q15_t)0x79ee, (q15_t)0x79ec, (q15_t)0x79ea, (q15_t)0x79e8, + (q15_t)0x79e6, (q15_t)0x79e4, (q15_t)0x79e2, (q15_t)0x79e0, (q15_t)0x79de, (q15_t)0x79dc, (q15_t)0x79da, (q15_t)0x79d9, + (q15_t)0x79d7, (q15_t)0x79d5, (q15_t)0x79d3, (q15_t)0x79d1, (q15_t)0x79cf, (q15_t)0x79cd, (q15_t)0x79cb, (q15_t)0x79c9, + (q15_t)0x79c7, (q15_t)0x79c5, (q15_t)0x79c3, (q15_t)0x79c1, (q15_t)0x79bf, (q15_t)0x79bd, (q15_t)0x79bc, (q15_t)0x79ba, + (q15_t)0x79b8, (q15_t)0x79b6, (q15_t)0x79b4, (q15_t)0x79b2, (q15_t)0x79b0, (q15_t)0x79ae, (q15_t)0x79ac, (q15_t)0x79aa, + (q15_t)0x79a8, (q15_t)0x79a6, (q15_t)0x79a4, (q15_t)0x79a2, (q15_t)0x79a0, (q15_t)0x799e, (q15_t)0x799c, (q15_t)0x799a, + (q15_t)0x7998, (q15_t)0x7996, (q15_t)0x7994, (q15_t)0x7992, (q15_t)0x7991, (q15_t)0x798f, (q15_t)0x798d, (q15_t)0x798b, + (q15_t)0x7989, (q15_t)0x7987, (q15_t)0x7985, (q15_t)0x7983, (q15_t)0x7981, (q15_t)0x797f, (q15_t)0x797d, (q15_t)0x797b, + (q15_t)0x7979, (q15_t)0x7977, (q15_t)0x7975, (q15_t)0x7973, (q15_t)0x7971, (q15_t)0x796f, (q15_t)0x796d, (q15_t)0x796b, + (q15_t)0x7969, (q15_t)0x7967, (q15_t)0x7965, (q15_t)0x7963, (q15_t)0x7961, (q15_t)0x795f, (q15_t)0x795d, (q15_t)0x795b, + (q15_t)0x7959, (q15_t)0x7957, (q15_t)0x7955, (q15_t)0x7953, (q15_t)0x7951, (q15_t)0x794f, (q15_t)0x794d, (q15_t)0x794b, + (q15_t)0x7949, (q15_t)0x7947, (q15_t)0x7945, (q15_t)0x7943, (q15_t)0x7941, (q15_t)0x793f, (q15_t)0x793d, (q15_t)0x793b, + (q15_t)0x7939, (q15_t)0x7937, (q15_t)0x7935, (q15_t)0x7933, (q15_t)0x7931, (q15_t)0x792f, (q15_t)0x792d, (q15_t)0x792b, + (q15_t)0x7929, (q15_t)0x7927, (q15_t)0x7925, (q15_t)0x7923, (q15_t)0x7921, (q15_t)0x791f, (q15_t)0x791d, (q15_t)0x791a, + (q15_t)0x7918, (q15_t)0x7916, (q15_t)0x7914, (q15_t)0x7912, (q15_t)0x7910, (q15_t)0x790e, (q15_t)0x790c, (q15_t)0x790a, + (q15_t)0x7908, (q15_t)0x7906, (q15_t)0x7904, (q15_t)0x7902, (q15_t)0x7900, (q15_t)0x78fe, (q15_t)0x78fc, (q15_t)0x78fa, + (q15_t)0x78f8, (q15_t)0x78f6, (q15_t)0x78f4, (q15_t)0x78f2, (q15_t)0x78f0, (q15_t)0x78ed, (q15_t)0x78eb, (q15_t)0x78e9, + (q15_t)0x78e7, (q15_t)0x78e5, (q15_t)0x78e3, (q15_t)0x78e1, (q15_t)0x78df, (q15_t)0x78dd, (q15_t)0x78db, (q15_t)0x78d9, + (q15_t)0x78d7, (q15_t)0x78d5, (q15_t)0x78d3, (q15_t)0x78d1, (q15_t)0x78ce, (q15_t)0x78cc, (q15_t)0x78ca, (q15_t)0x78c8, + (q15_t)0x78c6, (q15_t)0x78c4, (q15_t)0x78c2, (q15_t)0x78c0, (q15_t)0x78be, (q15_t)0x78bc, (q15_t)0x78ba, (q15_t)0x78b8, + (q15_t)0x78b5, (q15_t)0x78b3, (q15_t)0x78b1, (q15_t)0x78af, (q15_t)0x78ad, (q15_t)0x78ab, (q15_t)0x78a9, (q15_t)0x78a7, + (q15_t)0x78a5, (q15_t)0x78a3, (q15_t)0x78a0, (q15_t)0x789e, (q15_t)0x789c, (q15_t)0x789a, (q15_t)0x7898, (q15_t)0x7896, + (q15_t)0x7894, (q15_t)0x7892, (q15_t)0x7890, (q15_t)0x788e, (q15_t)0x788b, (q15_t)0x7889, (q15_t)0x7887, (q15_t)0x7885, + (q15_t)0x7883, (q15_t)0x7881, (q15_t)0x787f, (q15_t)0x787d, (q15_t)0x787a, (q15_t)0x7878, (q15_t)0x7876, (q15_t)0x7874, + (q15_t)0x7872, (q15_t)0x7870, (q15_t)0x786e, (q15_t)0x786c, (q15_t)0x7869, (q15_t)0x7867, (q15_t)0x7865, (q15_t)0x7863, + (q15_t)0x7861, (q15_t)0x785f, (q15_t)0x785d, (q15_t)0x785b, (q15_t)0x7858, (q15_t)0x7856, (q15_t)0x7854, (q15_t)0x7852, + (q15_t)0x7850, (q15_t)0x784e, (q15_t)0x784c, (q15_t)0x7849, (q15_t)0x7847, (q15_t)0x7845, (q15_t)0x7843, (q15_t)0x7841, + (q15_t)0x783f, (q15_t)0x783c, (q15_t)0x783a, (q15_t)0x7838, (q15_t)0x7836, (q15_t)0x7834, (q15_t)0x7832, (q15_t)0x7830, + (q15_t)0x782d, (q15_t)0x782b, (q15_t)0x7829, (q15_t)0x7827, (q15_t)0x7825, (q15_t)0x7823, (q15_t)0x7820, (q15_t)0x781e, + (q15_t)0x781c, (q15_t)0x781a, (q15_t)0x7818, (q15_t)0x7816, (q15_t)0x7813, (q15_t)0x7811, (q15_t)0x780f, (q15_t)0x780d, + (q15_t)0x780b, (q15_t)0x7808, (q15_t)0x7806, (q15_t)0x7804, (q15_t)0x7802, (q15_t)0x7800, (q15_t)0x77fe, (q15_t)0x77fb, + (q15_t)0x77f9, (q15_t)0x77f7, (q15_t)0x77f5, (q15_t)0x77f3, (q15_t)0x77f0, (q15_t)0x77ee, (q15_t)0x77ec, (q15_t)0x77ea, + (q15_t)0x77e8, (q15_t)0x77e5, (q15_t)0x77e3, (q15_t)0x77e1, (q15_t)0x77df, (q15_t)0x77dd, (q15_t)0x77da, (q15_t)0x77d8, + (q15_t)0x77d6, (q15_t)0x77d4, (q15_t)0x77d2, (q15_t)0x77cf, (q15_t)0x77cd, (q15_t)0x77cb, (q15_t)0x77c9, (q15_t)0x77c6, + (q15_t)0x77c4, (q15_t)0x77c2, (q15_t)0x77c0, (q15_t)0x77be, (q15_t)0x77bb, (q15_t)0x77b9, (q15_t)0x77b7, (q15_t)0x77b5, + (q15_t)0x77b2, (q15_t)0x77b0, (q15_t)0x77ae, (q15_t)0x77ac, (q15_t)0x77aa, (q15_t)0x77a7, (q15_t)0x77a5, (q15_t)0x77a3, + (q15_t)0x77a1, (q15_t)0x779e, (q15_t)0x779c, (q15_t)0x779a, (q15_t)0x7798, (q15_t)0x7795, (q15_t)0x7793, (q15_t)0x7791, + (q15_t)0x778f, (q15_t)0x778c, (q15_t)0x778a, (q15_t)0x7788, (q15_t)0x7786, (q15_t)0x7783, (q15_t)0x7781, (q15_t)0x777f, + (q15_t)0x777d, (q15_t)0x777a, (q15_t)0x7778, (q15_t)0x7776, (q15_t)0x7774, (q15_t)0x7771, (q15_t)0x776f, (q15_t)0x776d, + (q15_t)0x776b, (q15_t)0x7768, (q15_t)0x7766, (q15_t)0x7764, (q15_t)0x7762, (q15_t)0x775f, (q15_t)0x775d, (q15_t)0x775b, + (q15_t)0x7759, (q15_t)0x7756, (q15_t)0x7754, (q15_t)0x7752, (q15_t)0x774f, (q15_t)0x774d, (q15_t)0x774b, (q15_t)0x7749, + (q15_t)0x7746, (q15_t)0x7744, (q15_t)0x7742, (q15_t)0x773f, (q15_t)0x773d, (q15_t)0x773b, (q15_t)0x7739, (q15_t)0x7736, + (q15_t)0x7734, (q15_t)0x7732, (q15_t)0x772f, (q15_t)0x772d, (q15_t)0x772b, (q15_t)0x7729, (q15_t)0x7726, (q15_t)0x7724, + (q15_t)0x7722, (q15_t)0x771f, (q15_t)0x771d, (q15_t)0x771b, (q15_t)0x7719, (q15_t)0x7716, (q15_t)0x7714, (q15_t)0x7712, + (q15_t)0x770f, (q15_t)0x770d, (q15_t)0x770b, (q15_t)0x7708, (q15_t)0x7706, (q15_t)0x7704, (q15_t)0x7701, (q15_t)0x76ff, + (q15_t)0x76fd, (q15_t)0x76fa, (q15_t)0x76f8, (q15_t)0x76f6, (q15_t)0x76f4, (q15_t)0x76f1, (q15_t)0x76ef, (q15_t)0x76ed, + (q15_t)0x76ea, (q15_t)0x76e8, (q15_t)0x76e6, (q15_t)0x76e3, (q15_t)0x76e1, (q15_t)0x76df, (q15_t)0x76dc, (q15_t)0x76da, + (q15_t)0x76d8, (q15_t)0x76d5, (q15_t)0x76d3, (q15_t)0x76d1, (q15_t)0x76ce, (q15_t)0x76cc, (q15_t)0x76ca, (q15_t)0x76c7, + (q15_t)0x76c5, (q15_t)0x76c3, (q15_t)0x76c0, (q15_t)0x76be, (q15_t)0x76bc, (q15_t)0x76b9, (q15_t)0x76b7, (q15_t)0x76b4, + (q15_t)0x76b2, (q15_t)0x76b0, (q15_t)0x76ad, (q15_t)0x76ab, (q15_t)0x76a9, (q15_t)0x76a6, (q15_t)0x76a4, (q15_t)0x76a2, + (q15_t)0x769f, (q15_t)0x769d, (q15_t)0x769b, (q15_t)0x7698, (q15_t)0x7696, (q15_t)0x7693, (q15_t)0x7691, (q15_t)0x768f, + (q15_t)0x768c, (q15_t)0x768a, (q15_t)0x7688, (q15_t)0x7685, (q15_t)0x7683, (q15_t)0x7681, (q15_t)0x767e, (q15_t)0x767c, + (q15_t)0x7679, (q15_t)0x7677, (q15_t)0x7675, (q15_t)0x7672, (q15_t)0x7670, (q15_t)0x766d, (q15_t)0x766b, (q15_t)0x7669, + (q15_t)0x7666, (q15_t)0x7664, (q15_t)0x7662, (q15_t)0x765f, (q15_t)0x765d, (q15_t)0x765a, (q15_t)0x7658, (q15_t)0x7656, + (q15_t)0x7653, (q15_t)0x7651, (q15_t)0x764e, (q15_t)0x764c, (q15_t)0x764a, (q15_t)0x7647, (q15_t)0x7645, (q15_t)0x7642, + (q15_t)0x7640, (q15_t)0x763e, (q15_t)0x763b, (q15_t)0x7639, (q15_t)0x7636, (q15_t)0x7634, (q15_t)0x7632, (q15_t)0x762f, + (q15_t)0x762d, (q15_t)0x762a, (q15_t)0x7628, (q15_t)0x7625, (q15_t)0x7623, (q15_t)0x7621, (q15_t)0x761e, (q15_t)0x761c, + (q15_t)0x7619, (q15_t)0x7617, (q15_t)0x7615, (q15_t)0x7612, (q15_t)0x7610, (q15_t)0x760d, (q15_t)0x760b, (q15_t)0x7608, + (q15_t)0x7606, (q15_t)0x7604, (q15_t)0x7601, (q15_t)0x75ff, (q15_t)0x75fc, (q15_t)0x75fa, (q15_t)0x75f7, (q15_t)0x75f5, + (q15_t)0x75f2, (q15_t)0x75f0, (q15_t)0x75ee, (q15_t)0x75eb, (q15_t)0x75e9, (q15_t)0x75e6, (q15_t)0x75e4, (q15_t)0x75e1, + (q15_t)0x75df, (q15_t)0x75dc, (q15_t)0x75da, (q15_t)0x75d8, (q15_t)0x75d5, (q15_t)0x75d3, (q15_t)0x75d0, (q15_t)0x75ce, + (q15_t)0x75cb, (q15_t)0x75c9, (q15_t)0x75c6, (q15_t)0x75c4, (q15_t)0x75c1, (q15_t)0x75bf, (q15_t)0x75bc, (q15_t)0x75ba, + (q15_t)0x75b8, (q15_t)0x75b5, (q15_t)0x75b3, (q15_t)0x75b0, (q15_t)0x75ae, (q15_t)0x75ab, (q15_t)0x75a9, (q15_t)0x75a6, + (q15_t)0x75a4, (q15_t)0x75a1, (q15_t)0x759f, (q15_t)0x759c, (q15_t)0x759a, (q15_t)0x7597, (q15_t)0x7595, (q15_t)0x7592, + (q15_t)0x7590, (q15_t)0x758d, (q15_t)0x758b, (q15_t)0x7588, (q15_t)0x7586, (q15_t)0x7584, (q15_t)0x7581, (q15_t)0x757f, + (q15_t)0x757c, (q15_t)0x757a, (q15_t)0x7577, (q15_t)0x7575, (q15_t)0x7572, (q15_t)0x7570, (q15_t)0x756d, (q15_t)0x756b, + (q15_t)0x7568, (q15_t)0x7566, (q15_t)0x7563, (q15_t)0x7561, (q15_t)0x755e, (q15_t)0x755c, (q15_t)0x7559, (q15_t)0x7556, + (q15_t)0x7554, (q15_t)0x7551, (q15_t)0x754f, (q15_t)0x754c, (q15_t)0x754a, (q15_t)0x7547, (q15_t)0x7545, (q15_t)0x7542, + (q15_t)0x7540, (q15_t)0x753d, (q15_t)0x753b, (q15_t)0x7538, (q15_t)0x7536, (q15_t)0x7533, (q15_t)0x7531, (q15_t)0x752e, + (q15_t)0x752c, (q15_t)0x7529, (q15_t)0x7527, (q15_t)0x7524, (q15_t)0x7522, (q15_t)0x751f, (q15_t)0x751c, (q15_t)0x751a, + (q15_t)0x7517, (q15_t)0x7515, (q15_t)0x7512, (q15_t)0x7510, (q15_t)0x750d, (q15_t)0x750b, (q15_t)0x7508, (q15_t)0x7506, + (q15_t)0x7503, (q15_t)0x7501, (q15_t)0x74fe, (q15_t)0x74fb, (q15_t)0x74f9, (q15_t)0x74f6, (q15_t)0x74f4, (q15_t)0x74f1, + (q15_t)0x74ef, (q15_t)0x74ec, (q15_t)0x74ea, (q15_t)0x74e7, (q15_t)0x74e4, (q15_t)0x74e2, (q15_t)0x74df, (q15_t)0x74dd, + (q15_t)0x74da, (q15_t)0x74d8, (q15_t)0x74d5, (q15_t)0x74d2, (q15_t)0x74d0, (q15_t)0x74cd, (q15_t)0x74cb, (q15_t)0x74c8, + (q15_t)0x74c6, (q15_t)0x74c3, (q15_t)0x74c0, (q15_t)0x74be, (q15_t)0x74bb, (q15_t)0x74b9, (q15_t)0x74b6, (q15_t)0x74b4, + (q15_t)0x74b1, (q15_t)0x74ae, (q15_t)0x74ac, (q15_t)0x74a9, (q15_t)0x74a7, (q15_t)0x74a4, (q15_t)0x74a1, (q15_t)0x749f, + (q15_t)0x749c, (q15_t)0x749a, (q15_t)0x7497, (q15_t)0x7495, (q15_t)0x7492, (q15_t)0x748f, (q15_t)0x748d, (q15_t)0x748a, + (q15_t)0x7488, (q15_t)0x7485, (q15_t)0x7482, (q15_t)0x7480, (q15_t)0x747d, (q15_t)0x747b, (q15_t)0x7478, (q15_t)0x7475, + (q15_t)0x7473, (q15_t)0x7470, (q15_t)0x746d, (q15_t)0x746b, (q15_t)0x7468, (q15_t)0x7466, (q15_t)0x7463, (q15_t)0x7460, + (q15_t)0x745e, (q15_t)0x745b, (q15_t)0x7459, (q15_t)0x7456, (q15_t)0x7453, (q15_t)0x7451, (q15_t)0x744e, (q15_t)0x744b, + (q15_t)0x7449, (q15_t)0x7446, (q15_t)0x7444, (q15_t)0x7441, (q15_t)0x743e, (q15_t)0x743c, (q15_t)0x7439, (q15_t)0x7436, + (q15_t)0x7434, (q15_t)0x7431, (q15_t)0x742f, (q15_t)0x742c, (q15_t)0x7429, (q15_t)0x7427, (q15_t)0x7424, (q15_t)0x7421, + (q15_t)0x741f, (q15_t)0x741c, (q15_t)0x7419, (q15_t)0x7417, (q15_t)0x7414, (q15_t)0x7411, (q15_t)0x740f, (q15_t)0x740c, + (q15_t)0x740a, (q15_t)0x7407, (q15_t)0x7404, (q15_t)0x7402, (q15_t)0x73ff, (q15_t)0x73fc, (q15_t)0x73fa, (q15_t)0x73f7, + (q15_t)0x73f4, (q15_t)0x73f2, (q15_t)0x73ef, (q15_t)0x73ec, (q15_t)0x73ea, (q15_t)0x73e7, (q15_t)0x73e4, (q15_t)0x73e2, + (q15_t)0x73df, (q15_t)0x73dc, (q15_t)0x73da, (q15_t)0x73d7, (q15_t)0x73d4, (q15_t)0x73d2, (q15_t)0x73cf, (q15_t)0x73cc, + (q15_t)0x73ca, (q15_t)0x73c7, (q15_t)0x73c4, (q15_t)0x73c1, (q15_t)0x73bf, (q15_t)0x73bc, (q15_t)0x73b9, (q15_t)0x73b7, + (q15_t)0x73b4, (q15_t)0x73b1, (q15_t)0x73af, (q15_t)0x73ac, (q15_t)0x73a9, (q15_t)0x73a7, (q15_t)0x73a4, (q15_t)0x73a1, + (q15_t)0x739f, (q15_t)0x739c, (q15_t)0x7399, (q15_t)0x7396, (q15_t)0x7394, (q15_t)0x7391, (q15_t)0x738e, (q15_t)0x738c, + (q15_t)0x7389, (q15_t)0x7386, (q15_t)0x7384, (q15_t)0x7381, (q15_t)0x737e, (q15_t)0x737b, (q15_t)0x7379, (q15_t)0x7376, + (q15_t)0x7373, (q15_t)0x7371, (q15_t)0x736e, (q15_t)0x736b, (q15_t)0x7368, (q15_t)0x7366, (q15_t)0x7363, (q15_t)0x7360, + (q15_t)0x735e, (q15_t)0x735b, (q15_t)0x7358, (q15_t)0x7355, (q15_t)0x7353, (q15_t)0x7350, (q15_t)0x734d, (q15_t)0x734a, + (q15_t)0x7348, (q15_t)0x7345, (q15_t)0x7342, (q15_t)0x7340, (q15_t)0x733d, (q15_t)0x733a, (q15_t)0x7337, (q15_t)0x7335, + (q15_t)0x7332, (q15_t)0x732f, (q15_t)0x732c, (q15_t)0x732a, (q15_t)0x7327, (q15_t)0x7324, (q15_t)0x7321, (q15_t)0x731f, + (q15_t)0x731c, (q15_t)0x7319, (q15_t)0x7316, (q15_t)0x7314, (q15_t)0x7311, (q15_t)0x730e, (q15_t)0x730b, (q15_t)0x7309, + (q15_t)0x7306, (q15_t)0x7303, (q15_t)0x7300, (q15_t)0x72fe, (q15_t)0x72fb, (q15_t)0x72f8, (q15_t)0x72f5, (q15_t)0x72f3, + (q15_t)0x72f0, (q15_t)0x72ed, (q15_t)0x72ea, (q15_t)0x72e8, (q15_t)0x72e5, (q15_t)0x72e2, (q15_t)0x72df, (q15_t)0x72dc, + (q15_t)0x72da, (q15_t)0x72d7, (q15_t)0x72d4, (q15_t)0x72d1, (q15_t)0x72cf, (q15_t)0x72cc, (q15_t)0x72c9, (q15_t)0x72c6, + (q15_t)0x72c3, (q15_t)0x72c1, (q15_t)0x72be, (q15_t)0x72bb, (q15_t)0x72b8, (q15_t)0x72b5, (q15_t)0x72b3, (q15_t)0x72b0, + (q15_t)0x72ad, (q15_t)0x72aa, (q15_t)0x72a8, (q15_t)0x72a5, (q15_t)0x72a2, (q15_t)0x729f, (q15_t)0x729c, (q15_t)0x729a, + (q15_t)0x7297, (q15_t)0x7294, (q15_t)0x7291, (q15_t)0x728e, (q15_t)0x728c, (q15_t)0x7289, (q15_t)0x7286, (q15_t)0x7283, + (q15_t)0x7280, (q15_t)0x727e, (q15_t)0x727b, (q15_t)0x7278, (q15_t)0x7275, (q15_t)0x7272, (q15_t)0x726f, (q15_t)0x726d, + (q15_t)0x726a, (q15_t)0x7267, (q15_t)0x7264, (q15_t)0x7261, (q15_t)0x725f, (q15_t)0x725c, (q15_t)0x7259, (q15_t)0x7256, + (q15_t)0x7253, (q15_t)0x7250, (q15_t)0x724e, (q15_t)0x724b, (q15_t)0x7248, (q15_t)0x7245, (q15_t)0x7242, (q15_t)0x723f, + (q15_t)0x723d, (q15_t)0x723a, (q15_t)0x7237, (q15_t)0x7234, (q15_t)0x7231, (q15_t)0x722e, (q15_t)0x722c, (q15_t)0x7229, + (q15_t)0x7226, (q15_t)0x7223, (q15_t)0x7220, (q15_t)0x721d, (q15_t)0x721b, (q15_t)0x7218, (q15_t)0x7215, (q15_t)0x7212, + (q15_t)0x720f, (q15_t)0x720c, (q15_t)0x7209, (q15_t)0x7207, (q15_t)0x7204, (q15_t)0x7201, (q15_t)0x71fe, (q15_t)0x71fb, + (q15_t)0x71f8, (q15_t)0x71f5, (q15_t)0x71f3, (q15_t)0x71f0, (q15_t)0x71ed, (q15_t)0x71ea, (q15_t)0x71e7, (q15_t)0x71e4, + (q15_t)0x71e1, (q15_t)0x71df, (q15_t)0x71dc, (q15_t)0x71d9, (q15_t)0x71d6, (q15_t)0x71d3, (q15_t)0x71d0, (q15_t)0x71cd, + (q15_t)0x71ca, (q15_t)0x71c8, (q15_t)0x71c5, (q15_t)0x71c2, (q15_t)0x71bf, (q15_t)0x71bc, (q15_t)0x71b9, (q15_t)0x71b6, + (q15_t)0x71b3, (q15_t)0x71b0, (q15_t)0x71ae, (q15_t)0x71ab, (q15_t)0x71a8, (q15_t)0x71a5, (q15_t)0x71a2, (q15_t)0x719f, + (q15_t)0x719c, (q15_t)0x7199, (q15_t)0x7196, (q15_t)0x7194, (q15_t)0x7191, (q15_t)0x718e, (q15_t)0x718b, (q15_t)0x7188, + (q15_t)0x7185, (q15_t)0x7182, (q15_t)0x717f, (q15_t)0x717c, (q15_t)0x7179, (q15_t)0x7177, (q15_t)0x7174, (q15_t)0x7171, + (q15_t)0x716e, (q15_t)0x716b, (q15_t)0x7168, (q15_t)0x7165, (q15_t)0x7162, (q15_t)0x715f, (q15_t)0x715c, (q15_t)0x7159, + (q15_t)0x7156, (q15_t)0x7154, (q15_t)0x7151, (q15_t)0x714e, (q15_t)0x714b, (q15_t)0x7148, (q15_t)0x7145, (q15_t)0x7142, + (q15_t)0x713f, (q15_t)0x713c, (q15_t)0x7139, (q15_t)0x7136, (q15_t)0x7133, (q15_t)0x7130, (q15_t)0x712d, (q15_t)0x712b, + (q15_t)0x7128, (q15_t)0x7125, (q15_t)0x7122, (q15_t)0x711f, (q15_t)0x711c, (q15_t)0x7119, (q15_t)0x7116, (q15_t)0x7113, + (q15_t)0x7110, (q15_t)0x710d, (q15_t)0x710a, (q15_t)0x7107, (q15_t)0x7104, (q15_t)0x7101, (q15_t)0x70fe, (q15_t)0x70fb, + (q15_t)0x70f8, (q15_t)0x70f6, (q15_t)0x70f3, (q15_t)0x70f0, (q15_t)0x70ed, (q15_t)0x70ea, (q15_t)0x70e7, (q15_t)0x70e4, + (q15_t)0x70e1, (q15_t)0x70de, (q15_t)0x70db, (q15_t)0x70d8, (q15_t)0x70d5, (q15_t)0x70d2, (q15_t)0x70cf, (q15_t)0x70cc, + (q15_t)0x70c9, (q15_t)0x70c6, (q15_t)0x70c3, (q15_t)0x70c0, (q15_t)0x70bd, (q15_t)0x70ba, (q15_t)0x70b7, (q15_t)0x70b4, + (q15_t)0x70b1, (q15_t)0x70ae, (q15_t)0x70ab, (q15_t)0x70a8, (q15_t)0x70a5, (q15_t)0x70a2, (q15_t)0x709f, (q15_t)0x709c, + (q15_t)0x7099, (q15_t)0x7096, (q15_t)0x7093, (q15_t)0x7090, (q15_t)0x708d, (q15_t)0x708a, (q15_t)0x7087, (q15_t)0x7084, + (q15_t)0x7081, (q15_t)0x707e, (q15_t)0x707b, (q15_t)0x7078, (q15_t)0x7075, (q15_t)0x7072, (q15_t)0x706f, (q15_t)0x706c, + (q15_t)0x7069, (q15_t)0x7066, (q15_t)0x7063, (q15_t)0x7060, (q15_t)0x705d, (q15_t)0x705a, (q15_t)0x7057, (q15_t)0x7054, + (q15_t)0x7051, (q15_t)0x704e, (q15_t)0x704b, (q15_t)0x7048, (q15_t)0x7045, (q15_t)0x7042, (q15_t)0x703f, (q15_t)0x703c, + (q15_t)0x7039, (q15_t)0x7036, (q15_t)0x7033, (q15_t)0x7030, (q15_t)0x702d, (q15_t)0x702a, (q15_t)0x7027, (q15_t)0x7024, + (q15_t)0x7021, (q15_t)0x701e, (q15_t)0x701b, (q15_t)0x7018, (q15_t)0x7015, (q15_t)0x7012, (q15_t)0x700f, (q15_t)0x700c, + (q15_t)0x7009, (q15_t)0x7006, (q15_t)0x7003, (q15_t)0x7000, (q15_t)0x6ffd, (q15_t)0x6ffa, (q15_t)0x6ff7, (q15_t)0x6ff3, + (q15_t)0x6ff0, (q15_t)0x6fed, (q15_t)0x6fea, (q15_t)0x6fe7, (q15_t)0x6fe4, (q15_t)0x6fe1, (q15_t)0x6fde, (q15_t)0x6fdb, + (q15_t)0x6fd8, (q15_t)0x6fd5, (q15_t)0x6fd2, (q15_t)0x6fcf, (q15_t)0x6fcc, (q15_t)0x6fc9, (q15_t)0x6fc6, (q15_t)0x6fc3, + (q15_t)0x6fc0, (q15_t)0x6fbc, (q15_t)0x6fb9, (q15_t)0x6fb6, (q15_t)0x6fb3, (q15_t)0x6fb0, (q15_t)0x6fad, (q15_t)0x6faa, + (q15_t)0x6fa7, (q15_t)0x6fa4, (q15_t)0x6fa1, (q15_t)0x6f9e, (q15_t)0x6f9b, (q15_t)0x6f98, (q15_t)0x6f95, (q15_t)0x6f91, + (q15_t)0x6f8e, (q15_t)0x6f8b, (q15_t)0x6f88, (q15_t)0x6f85, (q15_t)0x6f82, (q15_t)0x6f7f, (q15_t)0x6f7c, (q15_t)0x6f79, + (q15_t)0x6f76, (q15_t)0x6f73, (q15_t)0x6f70, (q15_t)0x6f6c, (q15_t)0x6f69, (q15_t)0x6f66, (q15_t)0x6f63, (q15_t)0x6f60, + (q15_t)0x6f5d, (q15_t)0x6f5a, (q15_t)0x6f57, (q15_t)0x6f54, (q15_t)0x6f51, (q15_t)0x6f4d, (q15_t)0x6f4a, (q15_t)0x6f47, + (q15_t)0x6f44, (q15_t)0x6f41, (q15_t)0x6f3e, (q15_t)0x6f3b, (q15_t)0x6f38, (q15_t)0x6f35, (q15_t)0x6f31, (q15_t)0x6f2e, + (q15_t)0x6f2b, (q15_t)0x6f28, (q15_t)0x6f25, (q15_t)0x6f22, (q15_t)0x6f1f, (q15_t)0x6f1c, (q15_t)0x6f19, (q15_t)0x6f15, + (q15_t)0x6f12, (q15_t)0x6f0f, (q15_t)0x6f0c, (q15_t)0x6f09, (q15_t)0x6f06, (q15_t)0x6f03, (q15_t)0x6f00, (q15_t)0x6efc, + (q15_t)0x6ef9, (q15_t)0x6ef6, (q15_t)0x6ef3, (q15_t)0x6ef0, (q15_t)0x6eed, (q15_t)0x6eea, (q15_t)0x6ee7, (q15_t)0x6ee3, + (q15_t)0x6ee0, (q15_t)0x6edd, (q15_t)0x6eda, (q15_t)0x6ed7, (q15_t)0x6ed4, (q15_t)0x6ed1, (q15_t)0x6ecd, (q15_t)0x6eca, + (q15_t)0x6ec7, (q15_t)0x6ec4, (q15_t)0x6ec1, (q15_t)0x6ebe, (q15_t)0x6eba, (q15_t)0x6eb7, (q15_t)0x6eb4, (q15_t)0x6eb1, + (q15_t)0x6eae, (q15_t)0x6eab, (q15_t)0x6ea8, (q15_t)0x6ea4, (q15_t)0x6ea1, (q15_t)0x6e9e, (q15_t)0x6e9b, (q15_t)0x6e98, + (q15_t)0x6e95, (q15_t)0x6e91, (q15_t)0x6e8e, (q15_t)0x6e8b, (q15_t)0x6e88, (q15_t)0x6e85, (q15_t)0x6e82, (q15_t)0x6e7e, + (q15_t)0x6e7b, (q15_t)0x6e78, (q15_t)0x6e75, (q15_t)0x6e72, (q15_t)0x6e6f, (q15_t)0x6e6b, (q15_t)0x6e68, (q15_t)0x6e65, + (q15_t)0x6e62, (q15_t)0x6e5f, (q15_t)0x6e5b, (q15_t)0x6e58, (q15_t)0x6e55, (q15_t)0x6e52, (q15_t)0x6e4f, (q15_t)0x6e4c, + (q15_t)0x6e48, (q15_t)0x6e45, (q15_t)0x6e42, (q15_t)0x6e3f, (q15_t)0x6e3c, (q15_t)0x6e38, (q15_t)0x6e35, (q15_t)0x6e32, + (q15_t)0x6e2f, (q15_t)0x6e2c, (q15_t)0x6e28, (q15_t)0x6e25, (q15_t)0x6e22, (q15_t)0x6e1f, (q15_t)0x6e1c, (q15_t)0x6e18, + (q15_t)0x6e15, (q15_t)0x6e12, (q15_t)0x6e0f, (q15_t)0x6e0c, (q15_t)0x6e08, (q15_t)0x6e05, (q15_t)0x6e02, (q15_t)0x6dff, + (q15_t)0x6dfb, (q15_t)0x6df8, (q15_t)0x6df5, (q15_t)0x6df2, (q15_t)0x6def, (q15_t)0x6deb, (q15_t)0x6de8, (q15_t)0x6de5, + (q15_t)0x6de2, (q15_t)0x6ddf, (q15_t)0x6ddb, (q15_t)0x6dd8, (q15_t)0x6dd5, (q15_t)0x6dd2, (q15_t)0x6dce, (q15_t)0x6dcb, + (q15_t)0x6dc8, (q15_t)0x6dc5, (q15_t)0x6dc1, (q15_t)0x6dbe, (q15_t)0x6dbb, (q15_t)0x6db8, (q15_t)0x6db5, (q15_t)0x6db1, + (q15_t)0x6dae, (q15_t)0x6dab, (q15_t)0x6da8, (q15_t)0x6da4, (q15_t)0x6da1, (q15_t)0x6d9e, (q15_t)0x6d9b, (q15_t)0x6d97, + (q15_t)0x6d94, (q15_t)0x6d91, (q15_t)0x6d8e, (q15_t)0x6d8a, (q15_t)0x6d87, (q15_t)0x6d84, (q15_t)0x6d81, (q15_t)0x6d7d, + (q15_t)0x6d7a, (q15_t)0x6d77, (q15_t)0x6d74, (q15_t)0x6d70, (q15_t)0x6d6d, (q15_t)0x6d6a, (q15_t)0x6d67, (q15_t)0x6d63, + (q15_t)0x6d60, (q15_t)0x6d5d, (q15_t)0x6d59, (q15_t)0x6d56, (q15_t)0x6d53, (q15_t)0x6d50, (q15_t)0x6d4c, (q15_t)0x6d49, + (q15_t)0x6d46, (q15_t)0x6d43, (q15_t)0x6d3f, (q15_t)0x6d3c, (q15_t)0x6d39, (q15_t)0x6d36, (q15_t)0x6d32, (q15_t)0x6d2f, + (q15_t)0x6d2c, (q15_t)0x6d28, (q15_t)0x6d25, (q15_t)0x6d22, (q15_t)0x6d1f, (q15_t)0x6d1b, (q15_t)0x6d18, (q15_t)0x6d15, + (q15_t)0x6d11, (q15_t)0x6d0e, (q15_t)0x6d0b, (q15_t)0x6d08, (q15_t)0x6d04, (q15_t)0x6d01, (q15_t)0x6cfe, (q15_t)0x6cfa, + (q15_t)0x6cf7, (q15_t)0x6cf4, (q15_t)0x6cf0, (q15_t)0x6ced, (q15_t)0x6cea, (q15_t)0x6ce7, (q15_t)0x6ce3, (q15_t)0x6ce0, + (q15_t)0x6cdd, (q15_t)0x6cd9, (q15_t)0x6cd6, (q15_t)0x6cd3, (q15_t)0x6ccf, (q15_t)0x6ccc, (q15_t)0x6cc9, (q15_t)0x6cc5, + (q15_t)0x6cc2, (q15_t)0x6cbf, (q15_t)0x6cbc, (q15_t)0x6cb8, (q15_t)0x6cb5, (q15_t)0x6cb2, (q15_t)0x6cae, (q15_t)0x6cab, + (q15_t)0x6ca8, (q15_t)0x6ca4, (q15_t)0x6ca1, (q15_t)0x6c9e, (q15_t)0x6c9a, (q15_t)0x6c97, (q15_t)0x6c94, (q15_t)0x6c90, + (q15_t)0x6c8d, (q15_t)0x6c8a, (q15_t)0x6c86, (q15_t)0x6c83, (q15_t)0x6c80, (q15_t)0x6c7c, (q15_t)0x6c79, (q15_t)0x6c76, + (q15_t)0x6c72, (q15_t)0x6c6f, (q15_t)0x6c6c, (q15_t)0x6c68, (q15_t)0x6c65, (q15_t)0x6c62, (q15_t)0x6c5e, (q15_t)0x6c5b, + (q15_t)0x6c58, (q15_t)0x6c54, (q15_t)0x6c51, (q15_t)0x6c4e, (q15_t)0x6c4a, (q15_t)0x6c47, (q15_t)0x6c44, (q15_t)0x6c40, + (q15_t)0x6c3d, (q15_t)0x6c39, (q15_t)0x6c36, (q15_t)0x6c33, (q15_t)0x6c2f, (q15_t)0x6c2c, (q15_t)0x6c29, (q15_t)0x6c25, + (q15_t)0x6c22, (q15_t)0x6c1f, (q15_t)0x6c1b, (q15_t)0x6c18, (q15_t)0x6c15, (q15_t)0x6c11, (q15_t)0x6c0e, (q15_t)0x6c0a, + (q15_t)0x6c07, (q15_t)0x6c04, (q15_t)0x6c00, (q15_t)0x6bfd, (q15_t)0x6bfa, (q15_t)0x6bf6, (q15_t)0x6bf3, (q15_t)0x6bef, + (q15_t)0x6bec, (q15_t)0x6be9, (q15_t)0x6be5, (q15_t)0x6be2, (q15_t)0x6bdf, (q15_t)0x6bdb, (q15_t)0x6bd8, (q15_t)0x6bd4, + (q15_t)0x6bd1, (q15_t)0x6bce, (q15_t)0x6bca, (q15_t)0x6bc7, (q15_t)0x6bc3, (q15_t)0x6bc0, (q15_t)0x6bbd, (q15_t)0x6bb9, + (q15_t)0x6bb6, (q15_t)0x6bb2, (q15_t)0x6baf, (q15_t)0x6bac, (q15_t)0x6ba8, (q15_t)0x6ba5, (q15_t)0x6ba1, (q15_t)0x6b9e, + (q15_t)0x6b9b, (q15_t)0x6b97, (q15_t)0x6b94, (q15_t)0x6b90, (q15_t)0x6b8d, (q15_t)0x6b8a, (q15_t)0x6b86, (q15_t)0x6b83, + (q15_t)0x6b7f, (q15_t)0x6b7c, (q15_t)0x6b79, (q15_t)0x6b75, (q15_t)0x6b72, (q15_t)0x6b6e, (q15_t)0x6b6b, (q15_t)0x6b68, + (q15_t)0x6b64, (q15_t)0x6b61, (q15_t)0x6b5d, (q15_t)0x6b5a, (q15_t)0x6b56, (q15_t)0x6b53, (q15_t)0x6b50, (q15_t)0x6b4c, + (q15_t)0x6b49, (q15_t)0x6b45, (q15_t)0x6b42, (q15_t)0x6b3e, (q15_t)0x6b3b, (q15_t)0x6b38, (q15_t)0x6b34, (q15_t)0x6b31, + (q15_t)0x6b2d, (q15_t)0x6b2a, (q15_t)0x6b26, (q15_t)0x6b23, (q15_t)0x6b20, (q15_t)0x6b1c, (q15_t)0x6b19, (q15_t)0x6b15, + (q15_t)0x6b12, (q15_t)0x6b0e, (q15_t)0x6b0b, (q15_t)0x6b07, (q15_t)0x6b04, (q15_t)0x6b01, (q15_t)0x6afd, (q15_t)0x6afa, + (q15_t)0x6af6, (q15_t)0x6af3, (q15_t)0x6aef, (q15_t)0x6aec, (q15_t)0x6ae8, (q15_t)0x6ae5, (q15_t)0x6ae1, (q15_t)0x6ade, + (q15_t)0x6adb, (q15_t)0x6ad7, (q15_t)0x6ad4, (q15_t)0x6ad0, (q15_t)0x6acd, (q15_t)0x6ac9, (q15_t)0x6ac6, (q15_t)0x6ac2, + (q15_t)0x6abf, (q15_t)0x6abb, (q15_t)0x6ab8, (q15_t)0x6ab4, (q15_t)0x6ab1, (q15_t)0x6aae, (q15_t)0x6aaa, (q15_t)0x6aa7, + (q15_t)0x6aa3, (q15_t)0x6aa0, (q15_t)0x6a9c, (q15_t)0x6a99, (q15_t)0x6a95, (q15_t)0x6a92, (q15_t)0x6a8e, (q15_t)0x6a8b, + (q15_t)0x6a87, (q15_t)0x6a84, (q15_t)0x6a80, (q15_t)0x6a7d, (q15_t)0x6a79, (q15_t)0x6a76, (q15_t)0x6a72, (q15_t)0x6a6f, + (q15_t)0x6a6b, (q15_t)0x6a68, (q15_t)0x6a64, (q15_t)0x6a61, (q15_t)0x6a5d, (q15_t)0x6a5a, (q15_t)0x6a56, (q15_t)0x6a53, + (q15_t)0x6a4f, (q15_t)0x6a4c, (q15_t)0x6a48, (q15_t)0x6a45, (q15_t)0x6a41, (q15_t)0x6a3e, (q15_t)0x6a3a, (q15_t)0x6a37, + (q15_t)0x6a33, (q15_t)0x6a30, (q15_t)0x6a2c, (q15_t)0x6a29, (q15_t)0x6a25, (q15_t)0x6a22, (q15_t)0x6a1e, (q15_t)0x6a1b, + (q15_t)0x6a17, (q15_t)0x6a14, (q15_t)0x6a10, (q15_t)0x6a0d, (q15_t)0x6a09, (q15_t)0x6a06, (q15_t)0x6a02, (q15_t)0x69ff, + (q15_t)0x69fb, (q15_t)0x69f8, (q15_t)0x69f4, (q15_t)0x69f1, (q15_t)0x69ed, (q15_t)0x69e9, (q15_t)0x69e6, (q15_t)0x69e2, + (q15_t)0x69df, (q15_t)0x69db, (q15_t)0x69d8, (q15_t)0x69d4, (q15_t)0x69d1, (q15_t)0x69cd, (q15_t)0x69ca, (q15_t)0x69c6, + (q15_t)0x69c3, (q15_t)0x69bf, (q15_t)0x69bc, (q15_t)0x69b8, (q15_t)0x69b4, (q15_t)0x69b1, (q15_t)0x69ad, (q15_t)0x69aa, + (q15_t)0x69a6, (q15_t)0x69a3, (q15_t)0x699f, (q15_t)0x699c, (q15_t)0x6998, (q15_t)0x6995, (q15_t)0x6991, (q15_t)0x698d, + (q15_t)0x698a, (q15_t)0x6986, (q15_t)0x6983, (q15_t)0x697f, (q15_t)0x697c, (q15_t)0x6978, (q15_t)0x6975, (q15_t)0x6971, + (q15_t)0x696d, (q15_t)0x696a, (q15_t)0x6966, (q15_t)0x6963, (q15_t)0x695f, (q15_t)0x695c, (q15_t)0x6958, (q15_t)0x6954, + (q15_t)0x6951, (q15_t)0x694d, (q15_t)0x694a, (q15_t)0x6946, (q15_t)0x6943, (q15_t)0x693f, (q15_t)0x693b, (q15_t)0x6938, + (q15_t)0x6934, (q15_t)0x6931, (q15_t)0x692d, (q15_t)0x692a, (q15_t)0x6926, (q15_t)0x6922, (q15_t)0x691f, (q15_t)0x691b, + (q15_t)0x6918, (q15_t)0x6914, (q15_t)0x6910, (q15_t)0x690d, (q15_t)0x6909, (q15_t)0x6906, (q15_t)0x6902, (q15_t)0x68fe, + (q15_t)0x68fb, (q15_t)0x68f7, (q15_t)0x68f4, (q15_t)0x68f0, (q15_t)0x68ec, (q15_t)0x68e9, (q15_t)0x68e5, (q15_t)0x68e2, + (q15_t)0x68de, (q15_t)0x68da, (q15_t)0x68d7, (q15_t)0x68d3, (q15_t)0x68d0, (q15_t)0x68cc, (q15_t)0x68c8, (q15_t)0x68c5, + (q15_t)0x68c1, (q15_t)0x68be, (q15_t)0x68ba, (q15_t)0x68b6, (q15_t)0x68b3, (q15_t)0x68af, (q15_t)0x68ac, (q15_t)0x68a8, + (q15_t)0x68a4, (q15_t)0x68a1, (q15_t)0x689d, (q15_t)0x6899, (q15_t)0x6896, (q15_t)0x6892, (q15_t)0x688f, (q15_t)0x688b, + (q15_t)0x6887, (q15_t)0x6884, (q15_t)0x6880, (q15_t)0x687c, (q15_t)0x6879, (q15_t)0x6875, (q15_t)0x6872, (q15_t)0x686e, + (q15_t)0x686a, (q15_t)0x6867, (q15_t)0x6863, (q15_t)0x685f, (q15_t)0x685c, (q15_t)0x6858, (q15_t)0x6854, (q15_t)0x6851, + (q15_t)0x684d, (q15_t)0x684a, (q15_t)0x6846, (q15_t)0x6842, (q15_t)0x683f, (q15_t)0x683b, (q15_t)0x6837, (q15_t)0x6834, + (q15_t)0x6830, (q15_t)0x682c, (q15_t)0x6829, (q15_t)0x6825, (q15_t)0x6821, (q15_t)0x681e, (q15_t)0x681a, (q15_t)0x6816, + (q15_t)0x6813, (q15_t)0x680f, (q15_t)0x680b, (q15_t)0x6808, (q15_t)0x6804, (q15_t)0x6800, (q15_t)0x67fd, (q15_t)0x67f9, + (q15_t)0x67f5, (q15_t)0x67f2, (q15_t)0x67ee, (q15_t)0x67ea, (q15_t)0x67e7, (q15_t)0x67e3, (q15_t)0x67df, (q15_t)0x67dc, + (q15_t)0x67d8, (q15_t)0x67d4, (q15_t)0x67d1, (q15_t)0x67cd, (q15_t)0x67c9, (q15_t)0x67c6, (q15_t)0x67c2, (q15_t)0x67be, + (q15_t)0x67bb, (q15_t)0x67b7, (q15_t)0x67b3, (q15_t)0x67b0, (q15_t)0x67ac, (q15_t)0x67a8, (q15_t)0x67a5, (q15_t)0x67a1, + (q15_t)0x679d, (q15_t)0x679a, (q15_t)0x6796, (q15_t)0x6792, (q15_t)0x678e, (q15_t)0x678b, (q15_t)0x6787, (q15_t)0x6783, + (q15_t)0x6780, (q15_t)0x677c, (q15_t)0x6778, (q15_t)0x6775, (q15_t)0x6771, (q15_t)0x676d, (q15_t)0x6769, (q15_t)0x6766, + (q15_t)0x6762, (q15_t)0x675e, (q15_t)0x675b, (q15_t)0x6757, (q15_t)0x6753, (q15_t)0x6750, (q15_t)0x674c, (q15_t)0x6748, + (q15_t)0x6744, (q15_t)0x6741, (q15_t)0x673d, (q15_t)0x6739, (q15_t)0x6736, (q15_t)0x6732, (q15_t)0x672e, (q15_t)0x672a, + (q15_t)0x6727, (q15_t)0x6723, (q15_t)0x671f, (q15_t)0x671c, (q15_t)0x6718, (q15_t)0x6714, (q15_t)0x6710, (q15_t)0x670d, + (q15_t)0x6709, (q15_t)0x6705, (q15_t)0x6701, (q15_t)0x66fe, (q15_t)0x66fa, (q15_t)0x66f6, (q15_t)0x66f3, (q15_t)0x66ef, + (q15_t)0x66eb, (q15_t)0x66e7, (q15_t)0x66e4, (q15_t)0x66e0, (q15_t)0x66dc, (q15_t)0x66d8, (q15_t)0x66d5, (q15_t)0x66d1, + (q15_t)0x66cd, (q15_t)0x66c9, (q15_t)0x66c6, (q15_t)0x66c2, (q15_t)0x66be, (q15_t)0x66ba, (q15_t)0x66b7, (q15_t)0x66b3, + (q15_t)0x66af, (q15_t)0x66ab, (q15_t)0x66a8, (q15_t)0x66a4, (q15_t)0x66a0, (q15_t)0x669c, (q15_t)0x6699, (q15_t)0x6695, + (q15_t)0x6691, (q15_t)0x668d, (q15_t)0x668a, (q15_t)0x6686, (q15_t)0x6682, (q15_t)0x667e, (q15_t)0x667b, (q15_t)0x6677, + (q15_t)0x6673, (q15_t)0x666f, (q15_t)0x666b, (q15_t)0x6668, (q15_t)0x6664, (q15_t)0x6660, (q15_t)0x665c, (q15_t)0x6659, + (q15_t)0x6655, (q15_t)0x6651, (q15_t)0x664d, (q15_t)0x664a, (q15_t)0x6646, (q15_t)0x6642, (q15_t)0x663e, (q15_t)0x663a, + (q15_t)0x6637, (q15_t)0x6633, (q15_t)0x662f, (q15_t)0x662b, (q15_t)0x6627, (q15_t)0x6624, (q15_t)0x6620, (q15_t)0x661c, + (q15_t)0x6618, (q15_t)0x6615, (q15_t)0x6611, (q15_t)0x660d, (q15_t)0x6609, (q15_t)0x6605, (q15_t)0x6602, (q15_t)0x65fe, + (q15_t)0x65fa, (q15_t)0x65f6, (q15_t)0x65f2, (q15_t)0x65ef, (q15_t)0x65eb, (q15_t)0x65e7, (q15_t)0x65e3, (q15_t)0x65df, + (q15_t)0x65dc, (q15_t)0x65d8, (q15_t)0x65d4, (q15_t)0x65d0, (q15_t)0x65cc, (q15_t)0x65c9, (q15_t)0x65c5, (q15_t)0x65c1, + (q15_t)0x65bd, (q15_t)0x65b9, (q15_t)0x65b5, (q15_t)0x65b2, (q15_t)0x65ae, (q15_t)0x65aa, (q15_t)0x65a6, (q15_t)0x65a2, + (q15_t)0x659f, (q15_t)0x659b, (q15_t)0x6597, (q15_t)0x6593, (q15_t)0x658f, (q15_t)0x658b, (q15_t)0x6588, (q15_t)0x6584, + (q15_t)0x6580, (q15_t)0x657c, (q15_t)0x6578, (q15_t)0x6574, (q15_t)0x6571, (q15_t)0x656d, (q15_t)0x6569, (q15_t)0x6565, + (q15_t)0x6561, (q15_t)0x655d, (q15_t)0x655a, (q15_t)0x6556, (q15_t)0x6552, (q15_t)0x654e, (q15_t)0x654a, (q15_t)0x6546, + (q15_t)0x6543, (q15_t)0x653f, (q15_t)0x653b, (q15_t)0x6537, (q15_t)0x6533, (q15_t)0x652f, (q15_t)0x652c, (q15_t)0x6528, + (q15_t)0x6524, (q15_t)0x6520, (q15_t)0x651c, (q15_t)0x6518, (q15_t)0x6514, (q15_t)0x6511, (q15_t)0x650d, (q15_t)0x6509, + (q15_t)0x6505, (q15_t)0x6501, (q15_t)0x64fd, (q15_t)0x64f9, (q15_t)0x64f6, (q15_t)0x64f2, (q15_t)0x64ee, (q15_t)0x64ea, + (q15_t)0x64e6, (q15_t)0x64e2, (q15_t)0x64de, (q15_t)0x64db, (q15_t)0x64d7, (q15_t)0x64d3, (q15_t)0x64cf, (q15_t)0x64cb, + (q15_t)0x64c7, (q15_t)0x64c3, (q15_t)0x64bf, (q15_t)0x64bc, (q15_t)0x64b8, (q15_t)0x64b4, (q15_t)0x64b0, (q15_t)0x64ac, + (q15_t)0x64a8, (q15_t)0x64a4, (q15_t)0x64a0, (q15_t)0x649c, (q15_t)0x6499, (q15_t)0x6495, (q15_t)0x6491, (q15_t)0x648d, + (q15_t)0x6489, (q15_t)0x6485, (q15_t)0x6481, (q15_t)0x647d, (q15_t)0x6479, (q15_t)0x6476, (q15_t)0x6472, (q15_t)0x646e, + (q15_t)0x646a, (q15_t)0x6466, (q15_t)0x6462, (q15_t)0x645e, (q15_t)0x645a, (q15_t)0x6456, (q15_t)0x6453, (q15_t)0x644f, + (q15_t)0x644b, (q15_t)0x6447, (q15_t)0x6443, (q15_t)0x643f, (q15_t)0x643b, (q15_t)0x6437, (q15_t)0x6433, (q15_t)0x642f, + (q15_t)0x642b, (q15_t)0x6428, (q15_t)0x6424, (q15_t)0x6420, (q15_t)0x641c, (q15_t)0x6418, (q15_t)0x6414, (q15_t)0x6410, + (q15_t)0x640c, (q15_t)0x6408, (q15_t)0x6404, (q15_t)0x6400, (q15_t)0x63fc, (q15_t)0x63f9, (q15_t)0x63f5, (q15_t)0x63f1, + (q15_t)0x63ed, (q15_t)0x63e9, (q15_t)0x63e5, (q15_t)0x63e1, (q15_t)0x63dd, (q15_t)0x63d9, (q15_t)0x63d5, (q15_t)0x63d1, + (q15_t)0x63cd, (q15_t)0x63c9, (q15_t)0x63c5, (q15_t)0x63c1, (q15_t)0x63be, (q15_t)0x63ba, (q15_t)0x63b6, (q15_t)0x63b2, + (q15_t)0x63ae, (q15_t)0x63aa, (q15_t)0x63a6, (q15_t)0x63a2, (q15_t)0x639e, (q15_t)0x639a, (q15_t)0x6396, (q15_t)0x6392, + (q15_t)0x638e, (q15_t)0x638a, (q15_t)0x6386, (q15_t)0x6382, (q15_t)0x637e, (q15_t)0x637a, (q15_t)0x6377, (q15_t)0x6373, + (q15_t)0x636f, (q15_t)0x636b, (q15_t)0x6367, (q15_t)0x6363, (q15_t)0x635f, (q15_t)0x635b, (q15_t)0x6357, (q15_t)0x6353, + (q15_t)0x634f, (q15_t)0x634b, (q15_t)0x6347, (q15_t)0x6343, (q15_t)0x633f, (q15_t)0x633b, (q15_t)0x6337, (q15_t)0x6333, + (q15_t)0x632f, (q15_t)0x632b, (q15_t)0x6327, (q15_t)0x6323, (q15_t)0x631f, (q15_t)0x631b, (q15_t)0x6317, (q15_t)0x6313, + (q15_t)0x630f, (q15_t)0x630b, (q15_t)0x6307, (q15_t)0x6303, (q15_t)0x62ff, (q15_t)0x62fb, (q15_t)0x62f7, (q15_t)0x62f3, + (q15_t)0x62f0, (q15_t)0x62ec, (q15_t)0x62e8, (q15_t)0x62e4, (q15_t)0x62e0, (q15_t)0x62dc, (q15_t)0x62d8, (q15_t)0x62d4, + (q15_t)0x62d0, (q15_t)0x62cc, (q15_t)0x62c8, (q15_t)0x62c4, (q15_t)0x62c0, (q15_t)0x62bc, (q15_t)0x62b8, (q15_t)0x62b4, + (q15_t)0x62b0, (q15_t)0x62ac, (q15_t)0x62a8, (q15_t)0x62a4, (q15_t)0x62a0, (q15_t)0x629c, (q15_t)0x6298, (q15_t)0x6294, + (q15_t)0x6290, (q15_t)0x628c, (q15_t)0x6288, (q15_t)0x6284, (q15_t)0x6280, (q15_t)0x627c, (q15_t)0x6278, (q15_t)0x6273, + (q15_t)0x626f, (q15_t)0x626b, (q15_t)0x6267, (q15_t)0x6263, (q15_t)0x625f, (q15_t)0x625b, (q15_t)0x6257, (q15_t)0x6253, + (q15_t)0x624f, (q15_t)0x624b, (q15_t)0x6247, (q15_t)0x6243, (q15_t)0x623f, (q15_t)0x623b, (q15_t)0x6237, (q15_t)0x6233, + (q15_t)0x622f, (q15_t)0x622b, (q15_t)0x6227, (q15_t)0x6223, (q15_t)0x621f, (q15_t)0x621b, (q15_t)0x6217, (q15_t)0x6213, + (q15_t)0x620f, (q15_t)0x620b, (q15_t)0x6207, (q15_t)0x6203, (q15_t)0x61ff, (q15_t)0x61fb, (q15_t)0x61f7, (q15_t)0x61f3, + (q15_t)0x61ee, (q15_t)0x61ea, (q15_t)0x61e6, (q15_t)0x61e2, (q15_t)0x61de, (q15_t)0x61da, (q15_t)0x61d6, (q15_t)0x61d2, + (q15_t)0x61ce, (q15_t)0x61ca, (q15_t)0x61c6, (q15_t)0x61c2, (q15_t)0x61be, (q15_t)0x61ba, (q15_t)0x61b6, (q15_t)0x61b2, + (q15_t)0x61ae, (q15_t)0x61aa, (q15_t)0x61a6, (q15_t)0x61a1, (q15_t)0x619d, (q15_t)0x6199, (q15_t)0x6195, (q15_t)0x6191, + (q15_t)0x618d, (q15_t)0x6189, (q15_t)0x6185, (q15_t)0x6181, (q15_t)0x617d, (q15_t)0x6179, (q15_t)0x6175, (q15_t)0x6171, + (q15_t)0x616d, (q15_t)0x6168, (q15_t)0x6164, (q15_t)0x6160, (q15_t)0x615c, (q15_t)0x6158, (q15_t)0x6154, (q15_t)0x6150, + (q15_t)0x614c, (q15_t)0x6148, (q15_t)0x6144, (q15_t)0x6140, (q15_t)0x613c, (q15_t)0x6137, (q15_t)0x6133, (q15_t)0x612f, + (q15_t)0x612b, (q15_t)0x6127, (q15_t)0x6123, (q15_t)0x611f, (q15_t)0x611b, (q15_t)0x6117, (q15_t)0x6113, (q15_t)0x610f, + (q15_t)0x610a, (q15_t)0x6106, (q15_t)0x6102, (q15_t)0x60fe, (q15_t)0x60fa, (q15_t)0x60f6, (q15_t)0x60f2, (q15_t)0x60ee, + (q15_t)0x60ea, (q15_t)0x60e6, (q15_t)0x60e1, (q15_t)0x60dd, (q15_t)0x60d9, (q15_t)0x60d5, (q15_t)0x60d1, (q15_t)0x60cd, + (q15_t)0x60c9, (q15_t)0x60c5, (q15_t)0x60c1, (q15_t)0x60bc, (q15_t)0x60b8, (q15_t)0x60b4, (q15_t)0x60b0, (q15_t)0x60ac, + (q15_t)0x60a8, (q15_t)0x60a4, (q15_t)0x60a0, (q15_t)0x609c, (q15_t)0x6097, (q15_t)0x6093, (q15_t)0x608f, (q15_t)0x608b, + (q15_t)0x6087, (q15_t)0x6083, (q15_t)0x607f, (q15_t)0x607b, (q15_t)0x6076, (q15_t)0x6072, (q15_t)0x606e, (q15_t)0x606a, + (q15_t)0x6066, (q15_t)0x6062, (q15_t)0x605e, (q15_t)0x6059, (q15_t)0x6055, (q15_t)0x6051, (q15_t)0x604d, (q15_t)0x6049, + (q15_t)0x6045, (q15_t)0x6041, (q15_t)0x603c, (q15_t)0x6038, (q15_t)0x6034, (q15_t)0x6030, (q15_t)0x602c, (q15_t)0x6028, + (q15_t)0x6024, (q15_t)0x601f, (q15_t)0x601b, (q15_t)0x6017, (q15_t)0x6013, (q15_t)0x600f, (q15_t)0x600b, (q15_t)0x6007, + (q15_t)0x6002, (q15_t)0x5ffe, (q15_t)0x5ffa, (q15_t)0x5ff6, (q15_t)0x5ff2, (q15_t)0x5fee, (q15_t)0x5fe9, (q15_t)0x5fe5, + (q15_t)0x5fe1, (q15_t)0x5fdd, (q15_t)0x5fd9, (q15_t)0x5fd5, (q15_t)0x5fd0, (q15_t)0x5fcc, (q15_t)0x5fc8, (q15_t)0x5fc4, + (q15_t)0x5fc0, (q15_t)0x5fbc, (q15_t)0x5fb7, (q15_t)0x5fb3, (q15_t)0x5faf, (q15_t)0x5fab, (q15_t)0x5fa7, (q15_t)0x5fa3, + (q15_t)0x5f9e, (q15_t)0x5f9a, (q15_t)0x5f96, (q15_t)0x5f92, (q15_t)0x5f8e, (q15_t)0x5f8a, (q15_t)0x5f85, (q15_t)0x5f81, + (q15_t)0x5f7d, (q15_t)0x5f79, (q15_t)0x5f75, (q15_t)0x5f70, (q15_t)0x5f6c, (q15_t)0x5f68, (q15_t)0x5f64, (q15_t)0x5f60, + (q15_t)0x5f5b, (q15_t)0x5f57, (q15_t)0x5f53, (q15_t)0x5f4f, (q15_t)0x5f4b, (q15_t)0x5f46, (q15_t)0x5f42, (q15_t)0x5f3e, + (q15_t)0x5f3a, (q15_t)0x5f36, (q15_t)0x5f31, (q15_t)0x5f2d, (q15_t)0x5f29, (q15_t)0x5f25, (q15_t)0x5f21, (q15_t)0x5f1c, + (q15_t)0x5f18, (q15_t)0x5f14, (q15_t)0x5f10, (q15_t)0x5f0c, (q15_t)0x5f07, (q15_t)0x5f03, (q15_t)0x5eff, (q15_t)0x5efb, + (q15_t)0x5ef7, (q15_t)0x5ef2, (q15_t)0x5eee, (q15_t)0x5eea, (q15_t)0x5ee6, (q15_t)0x5ee2, (q15_t)0x5edd, (q15_t)0x5ed9, + (q15_t)0x5ed5, (q15_t)0x5ed1, (q15_t)0x5ecc, (q15_t)0x5ec8, (q15_t)0x5ec4, (q15_t)0x5ec0, (q15_t)0x5ebc, (q15_t)0x5eb7, + (q15_t)0x5eb3, (q15_t)0x5eaf, (q15_t)0x5eab, (q15_t)0x5ea6, (q15_t)0x5ea2, (q15_t)0x5e9e, (q15_t)0x5e9a, (q15_t)0x5e95, + (q15_t)0x5e91, (q15_t)0x5e8d, (q15_t)0x5e89, (q15_t)0x5e85, (q15_t)0x5e80, (q15_t)0x5e7c, (q15_t)0x5e78, (q15_t)0x5e74, + (q15_t)0x5e6f, (q15_t)0x5e6b, (q15_t)0x5e67, (q15_t)0x5e63, (q15_t)0x5e5e, (q15_t)0x5e5a, (q15_t)0x5e56, (q15_t)0x5e52, + (q15_t)0x5e4d, (q15_t)0x5e49, (q15_t)0x5e45, (q15_t)0x5e41, (q15_t)0x5e3c, (q15_t)0x5e38, (q15_t)0x5e34, (q15_t)0x5e30, + (q15_t)0x5e2b, (q15_t)0x5e27, (q15_t)0x5e23, (q15_t)0x5e1f, (q15_t)0x5e1a, (q15_t)0x5e16, (q15_t)0x5e12, (q15_t)0x5e0e, + (q15_t)0x5e09, (q15_t)0x5e05, (q15_t)0x5e01, (q15_t)0x5dfd, (q15_t)0x5df8, (q15_t)0x5df4, (q15_t)0x5df0, (q15_t)0x5deb, + (q15_t)0x5de7, (q15_t)0x5de3, (q15_t)0x5ddf, (q15_t)0x5dda, (q15_t)0x5dd6, (q15_t)0x5dd2, (q15_t)0x5dce, (q15_t)0x5dc9, + (q15_t)0x5dc5, (q15_t)0x5dc1, (q15_t)0x5dbc, (q15_t)0x5db8, (q15_t)0x5db4, (q15_t)0x5db0, (q15_t)0x5dab, (q15_t)0x5da7, + (q15_t)0x5da3, (q15_t)0x5d9e, (q15_t)0x5d9a, (q15_t)0x5d96, (q15_t)0x5d92, (q15_t)0x5d8d, (q15_t)0x5d89, (q15_t)0x5d85, + (q15_t)0x5d80, (q15_t)0x5d7c, (q15_t)0x5d78, (q15_t)0x5d74, (q15_t)0x5d6f, (q15_t)0x5d6b, (q15_t)0x5d67, (q15_t)0x5d62, + (q15_t)0x5d5e, (q15_t)0x5d5a, (q15_t)0x5d55, (q15_t)0x5d51, (q15_t)0x5d4d, (q15_t)0x5d49, (q15_t)0x5d44, (q15_t)0x5d40, + (q15_t)0x5d3c, (q15_t)0x5d37, (q15_t)0x5d33, (q15_t)0x5d2f, (q15_t)0x5d2a, (q15_t)0x5d26, (q15_t)0x5d22, (q15_t)0x5d1e, + (q15_t)0x5d19, (q15_t)0x5d15, (q15_t)0x5d11, (q15_t)0x5d0c, (q15_t)0x5d08, (q15_t)0x5d04, (q15_t)0x5cff, (q15_t)0x5cfb, + (q15_t)0x5cf7, (q15_t)0x5cf2, (q15_t)0x5cee, (q15_t)0x5cea, (q15_t)0x5ce5, (q15_t)0x5ce1, (q15_t)0x5cdd, (q15_t)0x5cd8, + (q15_t)0x5cd4, (q15_t)0x5cd0, (q15_t)0x5ccb, (q15_t)0x5cc7, (q15_t)0x5cc3, (q15_t)0x5cbe, (q15_t)0x5cba, (q15_t)0x5cb6, + (q15_t)0x5cb1, (q15_t)0x5cad, (q15_t)0x5ca9, (q15_t)0x5ca4, (q15_t)0x5ca0, (q15_t)0x5c9c, (q15_t)0x5c97, (q15_t)0x5c93, + (q15_t)0x5c8f, (q15_t)0x5c8a, (q15_t)0x5c86, (q15_t)0x5c82, (q15_t)0x5c7d, (q15_t)0x5c79, (q15_t)0x5c75, (q15_t)0x5c70, + (q15_t)0x5c6c, (q15_t)0x5c68, (q15_t)0x5c63, (q15_t)0x5c5f, (q15_t)0x5c5b, (q15_t)0x5c56, (q15_t)0x5c52, (q15_t)0x5c4e, + (q15_t)0x5c49, (q15_t)0x5c45, (q15_t)0x5c41, (q15_t)0x5c3c, (q15_t)0x5c38, (q15_t)0x5c33, (q15_t)0x5c2f, (q15_t)0x5c2b, + (q15_t)0x5c26, (q15_t)0x5c22, (q15_t)0x5c1e, (q15_t)0x5c19, (q15_t)0x5c15, (q15_t)0x5c11, (q15_t)0x5c0c, (q15_t)0x5c08, + (q15_t)0x5c03, (q15_t)0x5bff, (q15_t)0x5bfb, (q15_t)0x5bf6, (q15_t)0x5bf2, (q15_t)0x5bee, (q15_t)0x5be9, (q15_t)0x5be5, + (q15_t)0x5be0, (q15_t)0x5bdc, (q15_t)0x5bd8, (q15_t)0x5bd3, (q15_t)0x5bcf, (q15_t)0x5bcb, (q15_t)0x5bc6, (q15_t)0x5bc2, + (q15_t)0x5bbd, (q15_t)0x5bb9, (q15_t)0x5bb5, (q15_t)0x5bb0, (q15_t)0x5bac, (q15_t)0x5ba8, (q15_t)0x5ba3, (q15_t)0x5b9f, + (q15_t)0x5b9a, (q15_t)0x5b96, (q15_t)0x5b92, (q15_t)0x5b8d, (q15_t)0x5b89, (q15_t)0x5b84, (q15_t)0x5b80, (q15_t)0x5b7c, + (q15_t)0x5b77, (q15_t)0x5b73, (q15_t)0x5b6e, (q15_t)0x5b6a, (q15_t)0x5b66, (q15_t)0x5b61, (q15_t)0x5b5d, (q15_t)0x5b58, + (q15_t)0x5b54, (q15_t)0x5b50, (q15_t)0x5b4b, (q15_t)0x5b47, (q15_t)0x5b42, (q15_t)0x5b3e, (q15_t)0x5b3a, (q15_t)0x5b35, + (q15_t)0x5b31, (q15_t)0x5b2c, (q15_t)0x5b28, (q15_t)0x5b24, (q15_t)0x5b1f, (q15_t)0x5b1b, (q15_t)0x5b16, (q15_t)0x5b12, + (q15_t)0x5b0e, (q15_t)0x5b09, (q15_t)0x5b05, (q15_t)0x5b00, (q15_t)0x5afc, (q15_t)0x5af7, (q15_t)0x5af3, (q15_t)0x5aef, + (q15_t)0x5aea, (q15_t)0x5ae6, (q15_t)0x5ae1, (q15_t)0x5add, (q15_t)0x5ad8, (q15_t)0x5ad4, (q15_t)0x5ad0, (q15_t)0x5acb, + (q15_t)0x5ac7, (q15_t)0x5ac2, (q15_t)0x5abe, (q15_t)0x5ab9, (q15_t)0x5ab5, (q15_t)0x5ab1, (q15_t)0x5aac, (q15_t)0x5aa8, + (q15_t)0x5aa3, (q15_t)0x5a9f, (q15_t)0x5a9a, (q15_t)0x5a96, (q15_t)0x5a92, (q15_t)0x5a8d, (q15_t)0x5a89, (q15_t)0x5a84, + (q15_t)0x5a80, (q15_t)0x5a7b, (q15_t)0x5a77, (q15_t)0x5a72, (q15_t)0x5a6e, (q15_t)0x5a6a, (q15_t)0x5a65, (q15_t)0x5a61, + (q15_t)0x5a5c, (q15_t)0x5a58, (q15_t)0x5a53, (q15_t)0x5a4f, (q15_t)0x5a4a, (q15_t)0x5a46, (q15_t)0x5a41, (q15_t)0x5a3d, + (q15_t)0x5a39, (q15_t)0x5a34, (q15_t)0x5a30, (q15_t)0x5a2b, (q15_t)0x5a27, (q15_t)0x5a22, (q15_t)0x5a1e, (q15_t)0x5a19, + (q15_t)0x5a15, (q15_t)0x5a10, (q15_t)0x5a0c, (q15_t)0x5a07, (q15_t)0x5a03, (q15_t)0x59ff, (q15_t)0x59fa, (q15_t)0x59f6, + (q15_t)0x59f1, (q15_t)0x59ed, (q15_t)0x59e8, (q15_t)0x59e4, (q15_t)0x59df, (q15_t)0x59db, (q15_t)0x59d6, (q15_t)0x59d2, + (q15_t)0x59cd, (q15_t)0x59c9, (q15_t)0x59c4, (q15_t)0x59c0, (q15_t)0x59bb, (q15_t)0x59b7, (q15_t)0x59b2, (q15_t)0x59ae, + (q15_t)0x59a9, (q15_t)0x59a5, (q15_t)0x59a1, (q15_t)0x599c, (q15_t)0x5998, (q15_t)0x5993, (q15_t)0x598f, (q15_t)0x598a, + (q15_t)0x5986, (q15_t)0x5981, (q15_t)0x597d, (q15_t)0x5978, (q15_t)0x5974, (q15_t)0x596f, (q15_t)0x596b, (q15_t)0x5966, + (q15_t)0x5962, (q15_t)0x595d, (q15_t)0x5959, (q15_t)0x5954, (q15_t)0x5950, (q15_t)0x594b, (q15_t)0x5947, (q15_t)0x5942, + (q15_t)0x593e, (q15_t)0x5939, (q15_t)0x5935, (q15_t)0x5930, (q15_t)0x592c, (q15_t)0x5927, (q15_t)0x5923, (q15_t)0x591e, + (q15_t)0x591a, (q15_t)0x5915, (q15_t)0x5911, (q15_t)0x590c, (q15_t)0x5908, (q15_t)0x5903, (q15_t)0x58fe, (q15_t)0x58fa, + (q15_t)0x58f5, (q15_t)0x58f1, (q15_t)0x58ec, (q15_t)0x58e8, (q15_t)0x58e3, (q15_t)0x58df, (q15_t)0x58da, (q15_t)0x58d6, + (q15_t)0x58d1, (q15_t)0x58cd, (q15_t)0x58c8, (q15_t)0x58c4, (q15_t)0x58bf, (q15_t)0x58bb, (q15_t)0x58b6, (q15_t)0x58b2, + (q15_t)0x58ad, (q15_t)0x58a9, (q15_t)0x58a4, (q15_t)0x589f, (q15_t)0x589b, (q15_t)0x5896, (q15_t)0x5892, (q15_t)0x588d, + (q15_t)0x5889, (q15_t)0x5884, (q15_t)0x5880, (q15_t)0x587b, (q15_t)0x5877, (q15_t)0x5872, (q15_t)0x586e, (q15_t)0x5869, + (q15_t)0x5864, (q15_t)0x5860, (q15_t)0x585b, (q15_t)0x5857, (q15_t)0x5852, (q15_t)0x584e, (q15_t)0x5849, (q15_t)0x5845, + (q15_t)0x5840, (q15_t)0x583c, (q15_t)0x5837, (q15_t)0x5832, (q15_t)0x582e, (q15_t)0x5829, (q15_t)0x5825, (q15_t)0x5820, + (q15_t)0x581c, (q15_t)0x5817, (q15_t)0x5813, (q15_t)0x580e, (q15_t)0x5809, (q15_t)0x5805, (q15_t)0x5800, (q15_t)0x57fc, + (q15_t)0x57f7, (q15_t)0x57f3, (q15_t)0x57ee, (q15_t)0x57e9, (q15_t)0x57e5, (q15_t)0x57e0, (q15_t)0x57dc, (q15_t)0x57d7, + (q15_t)0x57d3, (q15_t)0x57ce, (q15_t)0x57c9, (q15_t)0x57c5, (q15_t)0x57c0, (q15_t)0x57bc, (q15_t)0x57b7, (q15_t)0x57b3, + (q15_t)0x57ae, (q15_t)0x57a9, (q15_t)0x57a5, (q15_t)0x57a0, (q15_t)0x579c, (q15_t)0x5797, (q15_t)0x5793, (q15_t)0x578e, + (q15_t)0x5789, (q15_t)0x5785, (q15_t)0x5780, (q15_t)0x577c, (q15_t)0x5777, (q15_t)0x5772, (q15_t)0x576e, (q15_t)0x5769, + (q15_t)0x5765, (q15_t)0x5760, (q15_t)0x575c, (q15_t)0x5757, (q15_t)0x5752, (q15_t)0x574e, (q15_t)0x5749, (q15_t)0x5745, + (q15_t)0x5740, (q15_t)0x573b, (q15_t)0x5737, (q15_t)0x5732, (q15_t)0x572e, (q15_t)0x5729, (q15_t)0x5724, (q15_t)0x5720, + (q15_t)0x571b, (q15_t)0x5717, (q15_t)0x5712, (q15_t)0x570d, (q15_t)0x5709, (q15_t)0x5704, (q15_t)0x56ff, (q15_t)0x56fb, + (q15_t)0x56f6, (q15_t)0x56f2, (q15_t)0x56ed, (q15_t)0x56e8, (q15_t)0x56e4, (q15_t)0x56df, (q15_t)0x56db, (q15_t)0x56d6, + (q15_t)0x56d1, (q15_t)0x56cd, (q15_t)0x56c8, (q15_t)0x56c4, (q15_t)0x56bf, (q15_t)0x56ba, (q15_t)0x56b6, (q15_t)0x56b1, + (q15_t)0x56ac, (q15_t)0x56a8, (q15_t)0x56a3, (q15_t)0x569f, (q15_t)0x569a, (q15_t)0x5695, (q15_t)0x5691, (q15_t)0x568c, + (q15_t)0x5687, (q15_t)0x5683, (q15_t)0x567e, (q15_t)0x5679, (q15_t)0x5675, (q15_t)0x5670, (q15_t)0x566c, (q15_t)0x5667, + (q15_t)0x5662, (q15_t)0x565e, (q15_t)0x5659, (q15_t)0x5654, (q15_t)0x5650, (q15_t)0x564b, (q15_t)0x5646, (q15_t)0x5642, + (q15_t)0x563d, (q15_t)0x5639, (q15_t)0x5634, (q15_t)0x562f, (q15_t)0x562b, (q15_t)0x5626, (q15_t)0x5621, (q15_t)0x561d, + (q15_t)0x5618, (q15_t)0x5613, (q15_t)0x560f, (q15_t)0x560a, (q15_t)0x5605, (q15_t)0x5601, (q15_t)0x55fc, (q15_t)0x55f7, + (q15_t)0x55f3, (q15_t)0x55ee, (q15_t)0x55ea, (q15_t)0x55e5, (q15_t)0x55e0, (q15_t)0x55dc, (q15_t)0x55d7, (q15_t)0x55d2, + (q15_t)0x55ce, (q15_t)0x55c9, (q15_t)0x55c4, (q15_t)0x55c0, (q15_t)0x55bb, (q15_t)0x55b6, (q15_t)0x55b2, (q15_t)0x55ad, + (q15_t)0x55a8, (q15_t)0x55a4, (q15_t)0x559f, (q15_t)0x559a, (q15_t)0x5596, (q15_t)0x5591, (q15_t)0x558c, (q15_t)0x5588, + (q15_t)0x5583, (q15_t)0x557e, (q15_t)0x5579, (q15_t)0x5575, (q15_t)0x5570, (q15_t)0x556b, (q15_t)0x5567, (q15_t)0x5562, + (q15_t)0x555d, (q15_t)0x5559, (q15_t)0x5554, (q15_t)0x554f, (q15_t)0x554b, (q15_t)0x5546, (q15_t)0x5541, (q15_t)0x553d, + (q15_t)0x5538, (q15_t)0x5533, (q15_t)0x552f, (q15_t)0x552a, (q15_t)0x5525, (q15_t)0x5520, (q15_t)0x551c, (q15_t)0x5517, + (q15_t)0x5512, (q15_t)0x550e, (q15_t)0x5509, (q15_t)0x5504, (q15_t)0x5500, (q15_t)0x54fb, (q15_t)0x54f6, (q15_t)0x54f2, + (q15_t)0x54ed, (q15_t)0x54e8, (q15_t)0x54e3, (q15_t)0x54df, (q15_t)0x54da, (q15_t)0x54d5, (q15_t)0x54d1, (q15_t)0x54cc, + (q15_t)0x54c7, (q15_t)0x54c2, (q15_t)0x54be, (q15_t)0x54b9, (q15_t)0x54b4, (q15_t)0x54b0, (q15_t)0x54ab, (q15_t)0x54a6, + (q15_t)0x54a2, (q15_t)0x549d, (q15_t)0x5498, (q15_t)0x5493, (q15_t)0x548f, (q15_t)0x548a, (q15_t)0x5485, (q15_t)0x5480, + (q15_t)0x547c, (q15_t)0x5477, (q15_t)0x5472, (q15_t)0x546e, (q15_t)0x5469, (q15_t)0x5464, (q15_t)0x545f, (q15_t)0x545b, + (q15_t)0x5456, (q15_t)0x5451, (q15_t)0x544d, (q15_t)0x5448, (q15_t)0x5443, (q15_t)0x543e, (q15_t)0x543a, (q15_t)0x5435, + (q15_t)0x5430, (q15_t)0x542b, (q15_t)0x5427, (q15_t)0x5422, (q15_t)0x541d, (q15_t)0x5418, (q15_t)0x5414, (q15_t)0x540f, + (q15_t)0x540a, (q15_t)0x5406, (q15_t)0x5401, (q15_t)0x53fc, (q15_t)0x53f7, (q15_t)0x53f3, (q15_t)0x53ee, (q15_t)0x53e9, + (q15_t)0x53e4, (q15_t)0x53e0, (q15_t)0x53db, (q15_t)0x53d6, (q15_t)0x53d1, (q15_t)0x53cd, (q15_t)0x53c8, (q15_t)0x53c3, + (q15_t)0x53be, (q15_t)0x53ba, (q15_t)0x53b5, (q15_t)0x53b0, (q15_t)0x53ab, (q15_t)0x53a7, (q15_t)0x53a2, (q15_t)0x539d, + (q15_t)0x5398, (q15_t)0x5394, (q15_t)0x538f, (q15_t)0x538a, (q15_t)0x5385, (q15_t)0x5380, (q15_t)0x537c, (q15_t)0x5377, + (q15_t)0x5372, (q15_t)0x536d, (q15_t)0x5369, (q15_t)0x5364, (q15_t)0x535f, (q15_t)0x535a, (q15_t)0x5356, (q15_t)0x5351, + (q15_t)0x534c, (q15_t)0x5347, (q15_t)0x5343, (q15_t)0x533e, (q15_t)0x5339, (q15_t)0x5334, (q15_t)0x532f, (q15_t)0x532b, + (q15_t)0x5326, (q15_t)0x5321, (q15_t)0x531c, (q15_t)0x5318, (q15_t)0x5313, (q15_t)0x530e, (q15_t)0x5309, (q15_t)0x5304, + (q15_t)0x5300, (q15_t)0x52fb, (q15_t)0x52f6, (q15_t)0x52f1, (q15_t)0x52ec, (q15_t)0x52e8, (q15_t)0x52e3, (q15_t)0x52de, + (q15_t)0x52d9, (q15_t)0x52d5, (q15_t)0x52d0, (q15_t)0x52cb, (q15_t)0x52c6, (q15_t)0x52c1, (q15_t)0x52bd, (q15_t)0x52b8, + (q15_t)0x52b3, (q15_t)0x52ae, (q15_t)0x52a9, (q15_t)0x52a5, (q15_t)0x52a0, (q15_t)0x529b, (q15_t)0x5296, (q15_t)0x5291, + (q15_t)0x528d, (q15_t)0x5288, (q15_t)0x5283, (q15_t)0x527e, (q15_t)0x5279, (q15_t)0x5275, (q15_t)0x5270, (q15_t)0x526b, + (q15_t)0x5266, (q15_t)0x5261, (q15_t)0x525d, (q15_t)0x5258, (q15_t)0x5253, (q15_t)0x524e, (q15_t)0x5249, (q15_t)0x5244, + (q15_t)0x5240, (q15_t)0x523b, (q15_t)0x5236, (q15_t)0x5231, (q15_t)0x522c, (q15_t)0x5228, (q15_t)0x5223, (q15_t)0x521e, + (q15_t)0x5219, (q15_t)0x5214, (q15_t)0x520f, (q15_t)0x520b, (q15_t)0x5206, (q15_t)0x5201, (q15_t)0x51fc, (q15_t)0x51f7, + (q15_t)0x51f3, (q15_t)0x51ee, (q15_t)0x51e9, (q15_t)0x51e4, (q15_t)0x51df, (q15_t)0x51da, (q15_t)0x51d6, (q15_t)0x51d1, + (q15_t)0x51cc, (q15_t)0x51c7, (q15_t)0x51c2, (q15_t)0x51bd, (q15_t)0x51b9, (q15_t)0x51b4, (q15_t)0x51af, (q15_t)0x51aa, + (q15_t)0x51a5, (q15_t)0x51a0, (q15_t)0x519c, (q15_t)0x5197, (q15_t)0x5192, (q15_t)0x518d, (q15_t)0x5188, (q15_t)0x5183, + (q15_t)0x517e, (q15_t)0x517a, (q15_t)0x5175, (q15_t)0x5170, (q15_t)0x516b, (q15_t)0x5166, (q15_t)0x5161, (q15_t)0x515d, + (q15_t)0x5158, (q15_t)0x5153, (q15_t)0x514e, (q15_t)0x5149, (q15_t)0x5144, (q15_t)0x513f, (q15_t)0x513b, (q15_t)0x5136, + (q15_t)0x5131, (q15_t)0x512c, (q15_t)0x5127, (q15_t)0x5122, (q15_t)0x511d, (q15_t)0x5119, (q15_t)0x5114, (q15_t)0x510f, + (q15_t)0x510a, (q15_t)0x5105, (q15_t)0x5100, (q15_t)0x50fb, (q15_t)0x50f7, (q15_t)0x50f2, (q15_t)0x50ed, (q15_t)0x50e8, + (q15_t)0x50e3, (q15_t)0x50de, (q15_t)0x50d9, (q15_t)0x50d4, (q15_t)0x50d0, (q15_t)0x50cb, (q15_t)0x50c6, (q15_t)0x50c1, + (q15_t)0x50bc, (q15_t)0x50b7, (q15_t)0x50b2, (q15_t)0x50ad, (q15_t)0x50a9, (q15_t)0x50a4, (q15_t)0x509f, (q15_t)0x509a, + (q15_t)0x5095, (q15_t)0x5090, (q15_t)0x508b, (q15_t)0x5086, (q15_t)0x5082, (q15_t)0x507d, (q15_t)0x5078, (q15_t)0x5073, + (q15_t)0x506e, (q15_t)0x5069, (q15_t)0x5064, (q15_t)0x505f, (q15_t)0x505a, (q15_t)0x5056, (q15_t)0x5051, (q15_t)0x504c, + (q15_t)0x5047, (q15_t)0x5042, (q15_t)0x503d, (q15_t)0x5038, (q15_t)0x5033, (q15_t)0x502e, (q15_t)0x5029, (q15_t)0x5025, + (q15_t)0x5020, (q15_t)0x501b, (q15_t)0x5016, (q15_t)0x5011, (q15_t)0x500c, (q15_t)0x5007, (q15_t)0x5002, (q15_t)0x4ffd, + (q15_t)0x4ff8, (q15_t)0x4ff4, (q15_t)0x4fef, (q15_t)0x4fea, (q15_t)0x4fe5, (q15_t)0x4fe0, (q15_t)0x4fdb, (q15_t)0x4fd6, + (q15_t)0x4fd1, (q15_t)0x4fcc, (q15_t)0x4fc7, (q15_t)0x4fc2, (q15_t)0x4fbe, (q15_t)0x4fb9, (q15_t)0x4fb4, (q15_t)0x4faf, + (q15_t)0x4faa, (q15_t)0x4fa5, (q15_t)0x4fa0, (q15_t)0x4f9b, (q15_t)0x4f96, (q15_t)0x4f91, (q15_t)0x4f8c, (q15_t)0x4f87, + (q15_t)0x4f82, (q15_t)0x4f7e, (q15_t)0x4f79, (q15_t)0x4f74, (q15_t)0x4f6f, (q15_t)0x4f6a, (q15_t)0x4f65, (q15_t)0x4f60, + (q15_t)0x4f5b, (q15_t)0x4f56, (q15_t)0x4f51, (q15_t)0x4f4c, (q15_t)0x4f47, (q15_t)0x4f42, (q15_t)0x4f3d, (q15_t)0x4f39, + (q15_t)0x4f34, (q15_t)0x4f2f, (q15_t)0x4f2a, (q15_t)0x4f25, (q15_t)0x4f20, (q15_t)0x4f1b, (q15_t)0x4f16, (q15_t)0x4f11, + (q15_t)0x4f0c, (q15_t)0x4f07, (q15_t)0x4f02, (q15_t)0x4efd, (q15_t)0x4ef8, (q15_t)0x4ef3, (q15_t)0x4eee, (q15_t)0x4ee9, + (q15_t)0x4ee5, (q15_t)0x4ee0, (q15_t)0x4edb, (q15_t)0x4ed6, (q15_t)0x4ed1, (q15_t)0x4ecc, (q15_t)0x4ec7, (q15_t)0x4ec2, + (q15_t)0x4ebd, (q15_t)0x4eb8, (q15_t)0x4eb3, (q15_t)0x4eae, (q15_t)0x4ea9, (q15_t)0x4ea4, (q15_t)0x4e9f, (q15_t)0x4e9a, + (q15_t)0x4e95, (q15_t)0x4e90, (q15_t)0x4e8b, (q15_t)0x4e86, (q15_t)0x4e81, (q15_t)0x4e7c, (q15_t)0x4e78, (q15_t)0x4e73, + (q15_t)0x4e6e, (q15_t)0x4e69, (q15_t)0x4e64, (q15_t)0x4e5f, (q15_t)0x4e5a, (q15_t)0x4e55, (q15_t)0x4e50, (q15_t)0x4e4b, + (q15_t)0x4e46, (q15_t)0x4e41, (q15_t)0x4e3c, (q15_t)0x4e37, (q15_t)0x4e32, (q15_t)0x4e2d, (q15_t)0x4e28, (q15_t)0x4e23, + (q15_t)0x4e1e, (q15_t)0x4e19, (q15_t)0x4e14, (q15_t)0x4e0f, (q15_t)0x4e0a, (q15_t)0x4e05, (q15_t)0x4e00, (q15_t)0x4dfb, + (q15_t)0x4df6, (q15_t)0x4df1, (q15_t)0x4dec, (q15_t)0x4de7, (q15_t)0x4de2, (q15_t)0x4ddd, (q15_t)0x4dd8, (q15_t)0x4dd3, + (q15_t)0x4dce, (q15_t)0x4dc9, (q15_t)0x4dc4, (q15_t)0x4dbf, (q15_t)0x4dba, (q15_t)0x4db5, (q15_t)0x4db0, (q15_t)0x4dab, + (q15_t)0x4da6, (q15_t)0x4da1, (q15_t)0x4d9c, (q15_t)0x4d97, (q15_t)0x4d92, (q15_t)0x4d8d, (q15_t)0x4d88, (q15_t)0x4d83, + (q15_t)0x4d7e, (q15_t)0x4d79, (q15_t)0x4d74, (q15_t)0x4d6f, (q15_t)0x4d6a, (q15_t)0x4d65, (q15_t)0x4d60, (q15_t)0x4d5b, + (q15_t)0x4d56, (q15_t)0x4d51, (q15_t)0x4d4c, (q15_t)0x4d47, (q15_t)0x4d42, (q15_t)0x4d3d, (q15_t)0x4d38, (q15_t)0x4d33, + (q15_t)0x4d2e, (q15_t)0x4d29, (q15_t)0x4d24, (q15_t)0x4d1f, (q15_t)0x4d1a, (q15_t)0x4d15, (q15_t)0x4d10, (q15_t)0x4d0b, + (q15_t)0x4d06, (q15_t)0x4d01, (q15_t)0x4cfc, (q15_t)0x4cf7, (q15_t)0x4cf2, (q15_t)0x4ced, (q15_t)0x4ce8, (q15_t)0x4ce3, + (q15_t)0x4cde, (q15_t)0x4cd9, (q15_t)0x4cd4, (q15_t)0x4ccf, (q15_t)0x4cca, (q15_t)0x4cc5, (q15_t)0x4cc0, (q15_t)0x4cbb, + (q15_t)0x4cb6, (q15_t)0x4cb1, (q15_t)0x4cac, (q15_t)0x4ca7, (q15_t)0x4ca2, (q15_t)0x4c9d, (q15_t)0x4c98, (q15_t)0x4c93, + (q15_t)0x4c8e, (q15_t)0x4c88, (q15_t)0x4c83, (q15_t)0x4c7e, (q15_t)0x4c79, (q15_t)0x4c74, (q15_t)0x4c6f, (q15_t)0x4c6a, + (q15_t)0x4c65, (q15_t)0x4c60, (q15_t)0x4c5b, (q15_t)0x4c56, (q15_t)0x4c51, (q15_t)0x4c4c, (q15_t)0x4c47, (q15_t)0x4c42, + (q15_t)0x4c3d, (q15_t)0x4c38, (q15_t)0x4c33, (q15_t)0x4c2e, (q15_t)0x4c29, (q15_t)0x4c24, (q15_t)0x4c1f, (q15_t)0x4c1a, + (q15_t)0x4c14, (q15_t)0x4c0f, (q15_t)0x4c0a, (q15_t)0x4c05, (q15_t)0x4c00, (q15_t)0x4bfb, (q15_t)0x4bf6, (q15_t)0x4bf1, + (q15_t)0x4bec, (q15_t)0x4be7, (q15_t)0x4be2, (q15_t)0x4bdd, (q15_t)0x4bd8, (q15_t)0x4bd3, (q15_t)0x4bce, (q15_t)0x4bc9, + (q15_t)0x4bc4, (q15_t)0x4bbe, (q15_t)0x4bb9, (q15_t)0x4bb4, (q15_t)0x4baf, (q15_t)0x4baa, (q15_t)0x4ba5, (q15_t)0x4ba0, + (q15_t)0x4b9b, (q15_t)0x4b96, (q15_t)0x4b91, (q15_t)0x4b8c, (q15_t)0x4b87, (q15_t)0x4b82, (q15_t)0x4b7d, (q15_t)0x4b77, + (q15_t)0x4b72, (q15_t)0x4b6d, (q15_t)0x4b68, (q15_t)0x4b63, (q15_t)0x4b5e, (q15_t)0x4b59, (q15_t)0x4b54, (q15_t)0x4b4f, + (q15_t)0x4b4a, (q15_t)0x4b45, (q15_t)0x4b40, (q15_t)0x4b3b, (q15_t)0x4b35, (q15_t)0x4b30, (q15_t)0x4b2b, (q15_t)0x4b26, + (q15_t)0x4b21, (q15_t)0x4b1c, (q15_t)0x4b17, (q15_t)0x4b12, (q15_t)0x4b0d, (q15_t)0x4b08, (q15_t)0x4b03, (q15_t)0x4afd, + (q15_t)0x4af8, (q15_t)0x4af3, (q15_t)0x4aee, (q15_t)0x4ae9, (q15_t)0x4ae4, (q15_t)0x4adf, (q15_t)0x4ada, (q15_t)0x4ad5, + (q15_t)0x4ad0, (q15_t)0x4acb, (q15_t)0x4ac5, (q15_t)0x4ac0, (q15_t)0x4abb, (q15_t)0x4ab6, (q15_t)0x4ab1, (q15_t)0x4aac, + (q15_t)0x4aa7, (q15_t)0x4aa2, (q15_t)0x4a9d, (q15_t)0x4a97, (q15_t)0x4a92, (q15_t)0x4a8d, (q15_t)0x4a88, (q15_t)0x4a83, + (q15_t)0x4a7e, (q15_t)0x4a79, (q15_t)0x4a74, (q15_t)0x4a6f, (q15_t)0x4a6a, (q15_t)0x4a64, (q15_t)0x4a5f, (q15_t)0x4a5a, + (q15_t)0x4a55, (q15_t)0x4a50, (q15_t)0x4a4b, (q15_t)0x4a46, (q15_t)0x4a41, (q15_t)0x4a3b, (q15_t)0x4a36, (q15_t)0x4a31, + (q15_t)0x4a2c, (q15_t)0x4a27, (q15_t)0x4a22, (q15_t)0x4a1d, (q15_t)0x4a18, (q15_t)0x4a12, (q15_t)0x4a0d, (q15_t)0x4a08, + (q15_t)0x4a03, (q15_t)0x49fe, (q15_t)0x49f9, (q15_t)0x49f4, (q15_t)0x49ef, (q15_t)0x49e9, (q15_t)0x49e4, (q15_t)0x49df, + (q15_t)0x49da, (q15_t)0x49d5, (q15_t)0x49d0, (q15_t)0x49cb, (q15_t)0x49c6, (q15_t)0x49c0, (q15_t)0x49bb, (q15_t)0x49b6, + (q15_t)0x49b1, (q15_t)0x49ac, (q15_t)0x49a7, (q15_t)0x49a2, (q15_t)0x499c, (q15_t)0x4997, (q15_t)0x4992, (q15_t)0x498d, + (q15_t)0x4988, (q15_t)0x4983, (q15_t)0x497e, (q15_t)0x4978, (q15_t)0x4973, (q15_t)0x496e, (q15_t)0x4969, (q15_t)0x4964, + (q15_t)0x495f, (q15_t)0x495a, (q15_t)0x4954, (q15_t)0x494f, (q15_t)0x494a, (q15_t)0x4945, (q15_t)0x4940, (q15_t)0x493b, + (q15_t)0x4936, (q15_t)0x4930, (q15_t)0x492b, (q15_t)0x4926, (q15_t)0x4921, (q15_t)0x491c, (q15_t)0x4917, (q15_t)0x4911, + (q15_t)0x490c, (q15_t)0x4907, (q15_t)0x4902, (q15_t)0x48fd, (q15_t)0x48f8, (q15_t)0x48f2, (q15_t)0x48ed, (q15_t)0x48e8, + (q15_t)0x48e3, (q15_t)0x48de, (q15_t)0x48d9, (q15_t)0x48d3, (q15_t)0x48ce, (q15_t)0x48c9, (q15_t)0x48c4, (q15_t)0x48bf, + (q15_t)0x48ba, (q15_t)0x48b4, (q15_t)0x48af, (q15_t)0x48aa, (q15_t)0x48a5, (q15_t)0x48a0, (q15_t)0x489b, (q15_t)0x4895, + (q15_t)0x4890, (q15_t)0x488b, (q15_t)0x4886, (q15_t)0x4881, (q15_t)0x487c, (q15_t)0x4876, (q15_t)0x4871, (q15_t)0x486c, + (q15_t)0x4867, (q15_t)0x4862, (q15_t)0x485c, (q15_t)0x4857, (q15_t)0x4852, (q15_t)0x484d, (q15_t)0x4848, (q15_t)0x4843, + (q15_t)0x483d, (q15_t)0x4838, (q15_t)0x4833, (q15_t)0x482e, (q15_t)0x4829, (q15_t)0x4823, (q15_t)0x481e, (q15_t)0x4819, + (q15_t)0x4814, (q15_t)0x480f, (q15_t)0x4809, (q15_t)0x4804, (q15_t)0x47ff, (q15_t)0x47fa, (q15_t)0x47f5, (q15_t)0x47ef, + (q15_t)0x47ea, (q15_t)0x47e5, (q15_t)0x47e0, (q15_t)0x47db, (q15_t)0x47d5, (q15_t)0x47d0, (q15_t)0x47cb, (q15_t)0x47c6, + (q15_t)0x47c1, (q15_t)0x47bb, (q15_t)0x47b6, (q15_t)0x47b1, (q15_t)0x47ac, (q15_t)0x47a7, (q15_t)0x47a1, (q15_t)0x479c, + (q15_t)0x4797, (q15_t)0x4792, (q15_t)0x478d, (q15_t)0x4787, (q15_t)0x4782, (q15_t)0x477d, (q15_t)0x4778, (q15_t)0x4773, + (q15_t)0x476d, (q15_t)0x4768, (q15_t)0x4763, (q15_t)0x475e, (q15_t)0x4758, (q15_t)0x4753, (q15_t)0x474e, (q15_t)0x4749, + (q15_t)0x4744, (q15_t)0x473e, (q15_t)0x4739, (q15_t)0x4734, (q15_t)0x472f, (q15_t)0x4729, (q15_t)0x4724, (q15_t)0x471f, + (q15_t)0x471a, (q15_t)0x4715, (q15_t)0x470f, (q15_t)0x470a, (q15_t)0x4705, (q15_t)0x4700, (q15_t)0x46fa, (q15_t)0x46f5, + (q15_t)0x46f0, (q15_t)0x46eb, (q15_t)0x46e6, (q15_t)0x46e0, (q15_t)0x46db, (q15_t)0x46d6, (q15_t)0x46d1, (q15_t)0x46cb, + (q15_t)0x46c6, (q15_t)0x46c1, (q15_t)0x46bc, (q15_t)0x46b6, (q15_t)0x46b1, (q15_t)0x46ac, (q15_t)0x46a7, (q15_t)0x46a1, + (q15_t)0x469c, (q15_t)0x4697, (q15_t)0x4692, (q15_t)0x468d, (q15_t)0x4687, (q15_t)0x4682, (q15_t)0x467d, (q15_t)0x4678, + (q15_t)0x4672, (q15_t)0x466d, (q15_t)0x4668, (q15_t)0x4663, (q15_t)0x465d, (q15_t)0x4658, (q15_t)0x4653, (q15_t)0x464e, + (q15_t)0x4648, (q15_t)0x4643, (q15_t)0x463e, (q15_t)0x4639, (q15_t)0x4633, (q15_t)0x462e, (q15_t)0x4629, (q15_t)0x4624, + (q15_t)0x461e, (q15_t)0x4619, (q15_t)0x4614, (q15_t)0x460e, (q15_t)0x4609, (q15_t)0x4604, (q15_t)0x45ff, (q15_t)0x45f9, + (q15_t)0x45f4, (q15_t)0x45ef, (q15_t)0x45ea, (q15_t)0x45e4, (q15_t)0x45df, (q15_t)0x45da, (q15_t)0x45d5, (q15_t)0x45cf, + (q15_t)0x45ca, (q15_t)0x45c5, (q15_t)0x45c0, (q15_t)0x45ba, (q15_t)0x45b5, (q15_t)0x45b0, (q15_t)0x45aa, (q15_t)0x45a5, + (q15_t)0x45a0, (q15_t)0x459b, (q15_t)0x4595, (q15_t)0x4590, (q15_t)0x458b, (q15_t)0x4586, (q15_t)0x4580, (q15_t)0x457b, + (q15_t)0x4576, (q15_t)0x4570, (q15_t)0x456b, (q15_t)0x4566, (q15_t)0x4561, (q15_t)0x455b, (q15_t)0x4556, (q15_t)0x4551, + (q15_t)0x454b, (q15_t)0x4546, (q15_t)0x4541, (q15_t)0x453c, (q15_t)0x4536, (q15_t)0x4531, (q15_t)0x452c, (q15_t)0x4526, + (q15_t)0x4521, (q15_t)0x451c, (q15_t)0x4517, (q15_t)0x4511, (q15_t)0x450c, (q15_t)0x4507, (q15_t)0x4501, (q15_t)0x44fc, + (q15_t)0x44f7, (q15_t)0x44f2, (q15_t)0x44ec, (q15_t)0x44e7, (q15_t)0x44e2, (q15_t)0x44dc, (q15_t)0x44d7, (q15_t)0x44d2, + (q15_t)0x44cd, (q15_t)0x44c7, (q15_t)0x44c2, (q15_t)0x44bd, (q15_t)0x44b7, (q15_t)0x44b2, (q15_t)0x44ad, (q15_t)0x44a7, + (q15_t)0x44a2, (q15_t)0x449d, (q15_t)0x4497, (q15_t)0x4492, (q15_t)0x448d, (q15_t)0x4488, (q15_t)0x4482, (q15_t)0x447d, + (q15_t)0x4478, (q15_t)0x4472, (q15_t)0x446d, (q15_t)0x4468, (q15_t)0x4462, (q15_t)0x445d, (q15_t)0x4458, (q15_t)0x4452, + (q15_t)0x444d, (q15_t)0x4448, (q15_t)0x4443, (q15_t)0x443d, (q15_t)0x4438, (q15_t)0x4433, (q15_t)0x442d, (q15_t)0x4428, + (q15_t)0x4423, (q15_t)0x441d, (q15_t)0x4418, (q15_t)0x4413, (q15_t)0x440d, (q15_t)0x4408, (q15_t)0x4403, (q15_t)0x43fd, + (q15_t)0x43f8, (q15_t)0x43f3, (q15_t)0x43ed, (q15_t)0x43e8, (q15_t)0x43e3, (q15_t)0x43dd, (q15_t)0x43d8, (q15_t)0x43d3, + (q15_t)0x43cd, (q15_t)0x43c8, (q15_t)0x43c3, (q15_t)0x43bd, (q15_t)0x43b8, (q15_t)0x43b3, (q15_t)0x43ad, (q15_t)0x43a8, + (q15_t)0x43a3, (q15_t)0x439d, (q15_t)0x4398, (q15_t)0x4393, (q15_t)0x438d, (q15_t)0x4388, (q15_t)0x4383, (q15_t)0x437d, + (q15_t)0x4378, (q15_t)0x4373, (q15_t)0x436d, (q15_t)0x4368, (q15_t)0x4363, (q15_t)0x435d, (q15_t)0x4358, (q15_t)0x4353, + (q15_t)0x434d, (q15_t)0x4348, (q15_t)0x4343, (q15_t)0x433d, (q15_t)0x4338, (q15_t)0x4333, (q15_t)0x432d, (q15_t)0x4328, + (q15_t)0x4323, (q15_t)0x431d, (q15_t)0x4318, (q15_t)0x4313, (q15_t)0x430d, (q15_t)0x4308, (q15_t)0x4302, (q15_t)0x42fd, + (q15_t)0x42f8, (q15_t)0x42f2, (q15_t)0x42ed, (q15_t)0x42e8, (q15_t)0x42e2, (q15_t)0x42dd, (q15_t)0x42d8, (q15_t)0x42d2, + (q15_t)0x42cd, (q15_t)0x42c8, (q15_t)0x42c2, (q15_t)0x42bd, (q15_t)0x42b7, (q15_t)0x42b2, (q15_t)0x42ad, (q15_t)0x42a7, + (q15_t)0x42a2, (q15_t)0x429d, (q15_t)0x4297, (q15_t)0x4292, (q15_t)0x428d, (q15_t)0x4287, (q15_t)0x4282, (q15_t)0x427c, + (q15_t)0x4277, (q15_t)0x4272, (q15_t)0x426c, (q15_t)0x4267, (q15_t)0x4262, (q15_t)0x425c, (q15_t)0x4257, (q15_t)0x4251, + (q15_t)0x424c, (q15_t)0x4247, (q15_t)0x4241, (q15_t)0x423c, (q15_t)0x4237, (q15_t)0x4231, (q15_t)0x422c, (q15_t)0x4226, + (q15_t)0x4221, (q15_t)0x421c, (q15_t)0x4216, (q15_t)0x4211, (q15_t)0x420c, (q15_t)0x4206, (q15_t)0x4201, (q15_t)0x41fb, + (q15_t)0x41f6, (q15_t)0x41f1, (q15_t)0x41eb, (q15_t)0x41e6, (q15_t)0x41e0, (q15_t)0x41db, (q15_t)0x41d6, (q15_t)0x41d0, + (q15_t)0x41cb, (q15_t)0x41c6, (q15_t)0x41c0, (q15_t)0x41bb, (q15_t)0x41b5, (q15_t)0x41b0, (q15_t)0x41ab, (q15_t)0x41a5, + (q15_t)0x41a0, (q15_t)0x419a, (q15_t)0x4195, (q15_t)0x4190, (q15_t)0x418a, (q15_t)0x4185, (q15_t)0x417f, (q15_t)0x417a, + (q15_t)0x4175, (q15_t)0x416f, (q15_t)0x416a, (q15_t)0x4164, (q15_t)0x415f, (q15_t)0x415a, (q15_t)0x4154, (q15_t)0x414f, + (q15_t)0x4149, (q15_t)0x4144, (q15_t)0x413f, (q15_t)0x4139, (q15_t)0x4134, (q15_t)0x412e, (q15_t)0x4129, (q15_t)0x4124, + (q15_t)0x411e, (q15_t)0x4119, (q15_t)0x4113, (q15_t)0x410e, (q15_t)0x4108, (q15_t)0x4103, (q15_t)0x40fe, (q15_t)0x40f8, + (q15_t)0x40f3, (q15_t)0x40ed, (q15_t)0x40e8, (q15_t)0x40e3, (q15_t)0x40dd, (q15_t)0x40d8, (q15_t)0x40d2, (q15_t)0x40cd, + (q15_t)0x40c8, (q15_t)0x40c2, (q15_t)0x40bd, (q15_t)0x40b7, (q15_t)0x40b2, (q15_t)0x40ac, (q15_t)0x40a7, (q15_t)0x40a2, + (q15_t)0x409c, (q15_t)0x4097, (q15_t)0x4091, (q15_t)0x408c, (q15_t)0x4086, (q15_t)0x4081, (q15_t)0x407c, (q15_t)0x4076, + (q15_t)0x4071, (q15_t)0x406b, (q15_t)0x4066, (q15_t)0x4060, (q15_t)0x405b, (q15_t)0x4056, (q15_t)0x4050, (q15_t)0x404b, + (q15_t)0x4045, (q15_t)0x4040, (q15_t)0x403a, (q15_t)0x4035, (q15_t)0x4030, (q15_t)0x402a, (q15_t)0x4025, (q15_t)0x401f, + (q15_t)0x401a, (q15_t)0x4014, (q15_t)0x400f, (q15_t)0x4009, (q15_t)0x4004, (q15_t)0x3fff, (q15_t)0x3ff9, (q15_t)0x3ff4, + (q15_t)0x3fee, (q15_t)0x3fe9, (q15_t)0x3fe3, (q15_t)0x3fde, (q15_t)0x3fd8, (q15_t)0x3fd3, (q15_t)0x3fce, (q15_t)0x3fc8, + (q15_t)0x3fc3, (q15_t)0x3fbd, (q15_t)0x3fb8, (q15_t)0x3fb2, (q15_t)0x3fad, (q15_t)0x3fa7, (q15_t)0x3fa2, (q15_t)0x3f9d, + (q15_t)0x3f97, (q15_t)0x3f92, (q15_t)0x3f8c, (q15_t)0x3f87, (q15_t)0x3f81, (q15_t)0x3f7c, (q15_t)0x3f76, (q15_t)0x3f71, + (q15_t)0x3f6b, (q15_t)0x3f66, (q15_t)0x3f61, (q15_t)0x3f5b, (q15_t)0x3f56, (q15_t)0x3f50, (q15_t)0x3f4b, (q15_t)0x3f45, + (q15_t)0x3f40, (q15_t)0x3f3a, (q15_t)0x3f35, (q15_t)0x3f2f, (q15_t)0x3f2a, (q15_t)0x3f24, (q15_t)0x3f1f, (q15_t)0x3f1a, + (q15_t)0x3f14, (q15_t)0x3f0f, (q15_t)0x3f09, (q15_t)0x3f04, (q15_t)0x3efe, (q15_t)0x3ef9, (q15_t)0x3ef3, (q15_t)0x3eee, + (q15_t)0x3ee8, (q15_t)0x3ee3, (q15_t)0x3edd, (q15_t)0x3ed8, (q15_t)0x3ed2, (q15_t)0x3ecd, (q15_t)0x3ec7, (q15_t)0x3ec2, + (q15_t)0x3ebd, (q15_t)0x3eb7, (q15_t)0x3eb2, (q15_t)0x3eac, (q15_t)0x3ea7, (q15_t)0x3ea1, (q15_t)0x3e9c, (q15_t)0x3e96, + (q15_t)0x3e91, (q15_t)0x3e8b, (q15_t)0x3e86, (q15_t)0x3e80, (q15_t)0x3e7b, (q15_t)0x3e75, (q15_t)0x3e70, (q15_t)0x3e6a, + (q15_t)0x3e65, (q15_t)0x3e5f, (q15_t)0x3e5a, (q15_t)0x3e54, (q15_t)0x3e4f, (q15_t)0x3e49, (q15_t)0x3e44, (q15_t)0x3e3e, + (q15_t)0x3e39, (q15_t)0x3e33, (q15_t)0x3e2e, (q15_t)0x3e28, (q15_t)0x3e23, (q15_t)0x3e1d, (q15_t)0x3e18, (q15_t)0x3e12, + (q15_t)0x3e0d, (q15_t)0x3e07, (q15_t)0x3e02, (q15_t)0x3dfc, (q15_t)0x3df7, (q15_t)0x3df1, (q15_t)0x3dec, (q15_t)0x3de6, + (q15_t)0x3de1, (q15_t)0x3ddb, (q15_t)0x3dd6, (q15_t)0x3dd0, (q15_t)0x3dcb, (q15_t)0x3dc5, (q15_t)0x3dc0, (q15_t)0x3dba, + (q15_t)0x3db5, (q15_t)0x3daf, (q15_t)0x3daa, (q15_t)0x3da4, (q15_t)0x3d9f, (q15_t)0x3d99, (q15_t)0x3d94, (q15_t)0x3d8e, + (q15_t)0x3d89, (q15_t)0x3d83, (q15_t)0x3d7e, (q15_t)0x3d78, (q15_t)0x3d73, (q15_t)0x3d6d, (q15_t)0x3d68, (q15_t)0x3d62, + (q15_t)0x3d5d, (q15_t)0x3d57, (q15_t)0x3d52, (q15_t)0x3d4c, (q15_t)0x3d47, (q15_t)0x3d41, (q15_t)0x3d3c, (q15_t)0x3d36, + (q15_t)0x3d31, (q15_t)0x3d2b, (q15_t)0x3d26, (q15_t)0x3d20, (q15_t)0x3d1b, (q15_t)0x3d15, (q15_t)0x3d10, (q15_t)0x3d0a, + (q15_t)0x3d04, (q15_t)0x3cff, (q15_t)0x3cf9, (q15_t)0x3cf4, (q15_t)0x3cee, (q15_t)0x3ce9, (q15_t)0x3ce3, (q15_t)0x3cde, + (q15_t)0x3cd8, (q15_t)0x3cd3, (q15_t)0x3ccd, (q15_t)0x3cc8, (q15_t)0x3cc2, (q15_t)0x3cbd, (q15_t)0x3cb7, (q15_t)0x3cb2, + (q15_t)0x3cac, (q15_t)0x3ca7, (q15_t)0x3ca1, (q15_t)0x3c9b, (q15_t)0x3c96, (q15_t)0x3c90, (q15_t)0x3c8b, (q15_t)0x3c85, + (q15_t)0x3c80, (q15_t)0x3c7a, (q15_t)0x3c75, (q15_t)0x3c6f, (q15_t)0x3c6a, (q15_t)0x3c64, (q15_t)0x3c5f, (q15_t)0x3c59, + (q15_t)0x3c53, (q15_t)0x3c4e, (q15_t)0x3c48, (q15_t)0x3c43, (q15_t)0x3c3d, (q15_t)0x3c38, (q15_t)0x3c32, (q15_t)0x3c2d, + (q15_t)0x3c27, (q15_t)0x3c22, (q15_t)0x3c1c, (q15_t)0x3c16, (q15_t)0x3c11, (q15_t)0x3c0b, (q15_t)0x3c06, (q15_t)0x3c00, + (q15_t)0x3bfb, (q15_t)0x3bf5, (q15_t)0x3bf0, (q15_t)0x3bea, (q15_t)0x3be5, (q15_t)0x3bdf, (q15_t)0x3bd9, (q15_t)0x3bd4, + (q15_t)0x3bce, (q15_t)0x3bc9, (q15_t)0x3bc3, (q15_t)0x3bbe, (q15_t)0x3bb8, (q15_t)0x3bb3, (q15_t)0x3bad, (q15_t)0x3ba7, + (q15_t)0x3ba2, (q15_t)0x3b9c, (q15_t)0x3b97, (q15_t)0x3b91, (q15_t)0x3b8c, (q15_t)0x3b86, (q15_t)0x3b80, (q15_t)0x3b7b, + (q15_t)0x3b75, (q15_t)0x3b70, (q15_t)0x3b6a, (q15_t)0x3b65, (q15_t)0x3b5f, (q15_t)0x3b5a, (q15_t)0x3b54, (q15_t)0x3b4e, + (q15_t)0x3b49, (q15_t)0x3b43, (q15_t)0x3b3e, (q15_t)0x3b38, (q15_t)0x3b33, (q15_t)0x3b2d, (q15_t)0x3b27, (q15_t)0x3b22, + (q15_t)0x3b1c, (q15_t)0x3b17, (q15_t)0x3b11, (q15_t)0x3b0c, (q15_t)0x3b06, (q15_t)0x3b00, (q15_t)0x3afb, (q15_t)0x3af5, + (q15_t)0x3af0, (q15_t)0x3aea, (q15_t)0x3ae4, (q15_t)0x3adf, (q15_t)0x3ad9, (q15_t)0x3ad4, (q15_t)0x3ace, (q15_t)0x3ac9, + (q15_t)0x3ac3, (q15_t)0x3abd, (q15_t)0x3ab8, (q15_t)0x3ab2, (q15_t)0x3aad, (q15_t)0x3aa7, (q15_t)0x3aa2, (q15_t)0x3a9c, + (q15_t)0x3a96, (q15_t)0x3a91, (q15_t)0x3a8b, (q15_t)0x3a86, (q15_t)0x3a80, (q15_t)0x3a7a, (q15_t)0x3a75, (q15_t)0x3a6f, + (q15_t)0x3a6a, (q15_t)0x3a64, (q15_t)0x3a5e, (q15_t)0x3a59, (q15_t)0x3a53, (q15_t)0x3a4e, (q15_t)0x3a48, (q15_t)0x3a42, + (q15_t)0x3a3d, (q15_t)0x3a37, (q15_t)0x3a32, (q15_t)0x3a2c, (q15_t)0x3a26, (q15_t)0x3a21, (q15_t)0x3a1b, (q15_t)0x3a16, + (q15_t)0x3a10, (q15_t)0x3a0b, (q15_t)0x3a05, (q15_t)0x39ff, (q15_t)0x39fa, (q15_t)0x39f4, (q15_t)0x39ee, (q15_t)0x39e9, + (q15_t)0x39e3, (q15_t)0x39de, (q15_t)0x39d8, (q15_t)0x39d2, (q15_t)0x39cd, (q15_t)0x39c7, (q15_t)0x39c2, (q15_t)0x39bc, + (q15_t)0x39b6, (q15_t)0x39b1, (q15_t)0x39ab, (q15_t)0x39a6, (q15_t)0x39a0, (q15_t)0x399a, (q15_t)0x3995, (q15_t)0x398f, + (q15_t)0x398a, (q15_t)0x3984, (q15_t)0x397e, (q15_t)0x3979, (q15_t)0x3973, (q15_t)0x396d, (q15_t)0x3968, (q15_t)0x3962, + (q15_t)0x395d, (q15_t)0x3957, (q15_t)0x3951, (q15_t)0x394c, (q15_t)0x3946, (q15_t)0x3941, (q15_t)0x393b, (q15_t)0x3935, + (q15_t)0x3930, (q15_t)0x392a, (q15_t)0x3924, (q15_t)0x391f, (q15_t)0x3919, (q15_t)0x3914, (q15_t)0x390e, (q15_t)0x3908, + (q15_t)0x3903, (q15_t)0x38fd, (q15_t)0x38f7, (q15_t)0x38f2, (q15_t)0x38ec, (q15_t)0x38e7, (q15_t)0x38e1, (q15_t)0x38db, + (q15_t)0x38d6, (q15_t)0x38d0, (q15_t)0x38ca, (q15_t)0x38c5, (q15_t)0x38bf, (q15_t)0x38ba, (q15_t)0x38b4, (q15_t)0x38ae, + (q15_t)0x38a9, (q15_t)0x38a3, (q15_t)0x389d, (q15_t)0x3898, (q15_t)0x3892, (q15_t)0x388c, (q15_t)0x3887, (q15_t)0x3881, + (q15_t)0x387c, (q15_t)0x3876, (q15_t)0x3870, (q15_t)0x386b, (q15_t)0x3865, (q15_t)0x385f, (q15_t)0x385a, (q15_t)0x3854, + (q15_t)0x384e, (q15_t)0x3849, (q15_t)0x3843, (q15_t)0x383d, (q15_t)0x3838, (q15_t)0x3832, (q15_t)0x382d, (q15_t)0x3827, + (q15_t)0x3821, (q15_t)0x381c, (q15_t)0x3816, (q15_t)0x3810, (q15_t)0x380b, (q15_t)0x3805, (q15_t)0x37ff, (q15_t)0x37fa, + (q15_t)0x37f4, (q15_t)0x37ee, (q15_t)0x37e9, (q15_t)0x37e3, (q15_t)0x37dd, (q15_t)0x37d8, (q15_t)0x37d2, (q15_t)0x37cc, + (q15_t)0x37c7, (q15_t)0x37c1, (q15_t)0x37bc, (q15_t)0x37b6, (q15_t)0x37b0, (q15_t)0x37ab, (q15_t)0x37a5, (q15_t)0x379f, + (q15_t)0x379a, (q15_t)0x3794, (q15_t)0x378e, (q15_t)0x3789, (q15_t)0x3783, (q15_t)0x377d, (q15_t)0x3778, (q15_t)0x3772, + (q15_t)0x376c, (q15_t)0x3767, (q15_t)0x3761, (q15_t)0x375b, (q15_t)0x3756, (q15_t)0x3750, (q15_t)0x374a, (q15_t)0x3745, + (q15_t)0x373f, (q15_t)0x3739, (q15_t)0x3734, (q15_t)0x372e, (q15_t)0x3728, (q15_t)0x3723, (q15_t)0x371d, (q15_t)0x3717, + (q15_t)0x3712, (q15_t)0x370c, (q15_t)0x3706, (q15_t)0x3701, (q15_t)0x36fb, (q15_t)0x36f5, (q15_t)0x36f0, (q15_t)0x36ea, + (q15_t)0x36e4, (q15_t)0x36df, (q15_t)0x36d9, (q15_t)0x36d3, (q15_t)0x36ce, (q15_t)0x36c8, (q15_t)0x36c2, (q15_t)0x36bc, + (q15_t)0x36b7, (q15_t)0x36b1, (q15_t)0x36ab, (q15_t)0x36a6, (q15_t)0x36a0, (q15_t)0x369a, (q15_t)0x3695, (q15_t)0x368f, + (q15_t)0x3689, (q15_t)0x3684, (q15_t)0x367e, (q15_t)0x3678, (q15_t)0x3673, (q15_t)0x366d, (q15_t)0x3667, (q15_t)0x3662, + (q15_t)0x365c, (q15_t)0x3656, (q15_t)0x3650, (q15_t)0x364b, (q15_t)0x3645, (q15_t)0x363f, (q15_t)0x363a, (q15_t)0x3634, + (q15_t)0x362e, (q15_t)0x3629, (q15_t)0x3623, (q15_t)0x361d, (q15_t)0x3618, (q15_t)0x3612, (q15_t)0x360c, (q15_t)0x3606, + (q15_t)0x3601, (q15_t)0x35fb, (q15_t)0x35f5, (q15_t)0x35f0, (q15_t)0x35ea, (q15_t)0x35e4, (q15_t)0x35df, (q15_t)0x35d9, + (q15_t)0x35d3, (q15_t)0x35cd, (q15_t)0x35c8, (q15_t)0x35c2, (q15_t)0x35bc, (q15_t)0x35b7, (q15_t)0x35b1, (q15_t)0x35ab, + (q15_t)0x35a6, (q15_t)0x35a0, (q15_t)0x359a, (q15_t)0x3594, (q15_t)0x358f, (q15_t)0x3589, (q15_t)0x3583, (q15_t)0x357e, + (q15_t)0x3578, (q15_t)0x3572, (q15_t)0x356c, (q15_t)0x3567, (q15_t)0x3561, (q15_t)0x355b, (q15_t)0x3556, (q15_t)0x3550, + (q15_t)0x354a, (q15_t)0x3544, (q15_t)0x353f, (q15_t)0x3539, (q15_t)0x3533, (q15_t)0x352e, (q15_t)0x3528, (q15_t)0x3522, + (q15_t)0x351c, (q15_t)0x3517, (q15_t)0x3511, (q15_t)0x350b, (q15_t)0x3506, (q15_t)0x3500, (q15_t)0x34fa, (q15_t)0x34f4, + (q15_t)0x34ef, (q15_t)0x34e9, (q15_t)0x34e3, (q15_t)0x34de, (q15_t)0x34d8, (q15_t)0x34d2, (q15_t)0x34cc, (q15_t)0x34c7, + (q15_t)0x34c1, (q15_t)0x34bb, (q15_t)0x34b6, (q15_t)0x34b0, (q15_t)0x34aa, (q15_t)0x34a4, (q15_t)0x349f, (q15_t)0x3499, + (q15_t)0x3493, (q15_t)0x348d, (q15_t)0x3488, (q15_t)0x3482, (q15_t)0x347c, (q15_t)0x3476, (q15_t)0x3471, (q15_t)0x346b, + (q15_t)0x3465, (q15_t)0x3460, (q15_t)0x345a, (q15_t)0x3454, (q15_t)0x344e, (q15_t)0x3449, (q15_t)0x3443, (q15_t)0x343d, + (q15_t)0x3437, (q15_t)0x3432, (q15_t)0x342c, (q15_t)0x3426, (q15_t)0x3420, (q15_t)0x341b, (q15_t)0x3415, (q15_t)0x340f, + (q15_t)0x340a, (q15_t)0x3404, (q15_t)0x33fe, (q15_t)0x33f8, (q15_t)0x33f3, (q15_t)0x33ed, (q15_t)0x33e7, (q15_t)0x33e1, + (q15_t)0x33dc, (q15_t)0x33d6, (q15_t)0x33d0, (q15_t)0x33ca, (q15_t)0x33c5, (q15_t)0x33bf, (q15_t)0x33b9, (q15_t)0x33b3, + (q15_t)0x33ae, (q15_t)0x33a8, (q15_t)0x33a2, (q15_t)0x339c, (q15_t)0x3397, (q15_t)0x3391, (q15_t)0x338b, (q15_t)0x3385, + (q15_t)0x3380, (q15_t)0x337a, (q15_t)0x3374, (q15_t)0x336e, (q15_t)0x3369, (q15_t)0x3363, (q15_t)0x335d, (q15_t)0x3357, + (q15_t)0x3352, (q15_t)0x334c, (q15_t)0x3346, (q15_t)0x3340, (q15_t)0x333b, (q15_t)0x3335, (q15_t)0x332f, (q15_t)0x3329, + (q15_t)0x3324, (q15_t)0x331e, (q15_t)0x3318, (q15_t)0x3312, (q15_t)0x330c, (q15_t)0x3307, (q15_t)0x3301, (q15_t)0x32fb, + (q15_t)0x32f5, (q15_t)0x32f0, (q15_t)0x32ea, (q15_t)0x32e4, (q15_t)0x32de, (q15_t)0x32d9, (q15_t)0x32d3, (q15_t)0x32cd, + (q15_t)0x32c7, (q15_t)0x32c2, (q15_t)0x32bc, (q15_t)0x32b6, (q15_t)0x32b0, (q15_t)0x32aa, (q15_t)0x32a5, (q15_t)0x329f, + (q15_t)0x3299, (q15_t)0x3293, (q15_t)0x328e, (q15_t)0x3288, (q15_t)0x3282, (q15_t)0x327c, (q15_t)0x3276, (q15_t)0x3271, + (q15_t)0x326b, (q15_t)0x3265, (q15_t)0x325f, (q15_t)0x325a, (q15_t)0x3254, (q15_t)0x324e, (q15_t)0x3248, (q15_t)0x3243, + (q15_t)0x323d, (q15_t)0x3237, (q15_t)0x3231, (q15_t)0x322b, (q15_t)0x3226, (q15_t)0x3220, (q15_t)0x321a, (q15_t)0x3214, + (q15_t)0x320e, (q15_t)0x3209, (q15_t)0x3203, (q15_t)0x31fd, (q15_t)0x31f7, (q15_t)0x31f2, (q15_t)0x31ec, (q15_t)0x31e6, + (q15_t)0x31e0, (q15_t)0x31da, (q15_t)0x31d5, (q15_t)0x31cf, (q15_t)0x31c9, (q15_t)0x31c3, (q15_t)0x31bd, (q15_t)0x31b8, + (q15_t)0x31b2, (q15_t)0x31ac, (q15_t)0x31a6, (q15_t)0x31a1, (q15_t)0x319b, (q15_t)0x3195, (q15_t)0x318f, (q15_t)0x3189, + (q15_t)0x3184, (q15_t)0x317e, (q15_t)0x3178, (q15_t)0x3172, (q15_t)0x316c, (q15_t)0x3167, (q15_t)0x3161, (q15_t)0x315b, + (q15_t)0x3155, (q15_t)0x314f, (q15_t)0x314a, (q15_t)0x3144, (q15_t)0x313e, (q15_t)0x3138, (q15_t)0x3132, (q15_t)0x312d, + (q15_t)0x3127, (q15_t)0x3121, (q15_t)0x311b, (q15_t)0x3115, (q15_t)0x3110, (q15_t)0x310a, (q15_t)0x3104, (q15_t)0x30fe, + (q15_t)0x30f8, (q15_t)0x30f3, (q15_t)0x30ed, (q15_t)0x30e7, (q15_t)0x30e1, (q15_t)0x30db, (q15_t)0x30d6, (q15_t)0x30d0, + (q15_t)0x30ca, (q15_t)0x30c4, (q15_t)0x30be, (q15_t)0x30b8, (q15_t)0x30b3, (q15_t)0x30ad, (q15_t)0x30a7, (q15_t)0x30a1, + (q15_t)0x309b, (q15_t)0x3096, (q15_t)0x3090, (q15_t)0x308a, (q15_t)0x3084, (q15_t)0x307e, (q15_t)0x3079, (q15_t)0x3073, + (q15_t)0x306d, (q15_t)0x3067, (q15_t)0x3061, (q15_t)0x305b, (q15_t)0x3056, (q15_t)0x3050, (q15_t)0x304a, (q15_t)0x3044, + (q15_t)0x303e, (q15_t)0x3039, (q15_t)0x3033, (q15_t)0x302d, (q15_t)0x3027, (q15_t)0x3021, (q15_t)0x301b, (q15_t)0x3016, + (q15_t)0x3010, (q15_t)0x300a, (q15_t)0x3004, (q15_t)0x2ffe, (q15_t)0x2ff8, (q15_t)0x2ff3, (q15_t)0x2fed, (q15_t)0x2fe7, + (q15_t)0x2fe1, (q15_t)0x2fdb, (q15_t)0x2fd6, (q15_t)0x2fd0, (q15_t)0x2fca, (q15_t)0x2fc4, (q15_t)0x2fbe, (q15_t)0x2fb8, + (q15_t)0x2fb3, (q15_t)0x2fad, (q15_t)0x2fa7, (q15_t)0x2fa1, (q15_t)0x2f9b, (q15_t)0x2f95, (q15_t)0x2f90, (q15_t)0x2f8a, + (q15_t)0x2f84, (q15_t)0x2f7e, (q15_t)0x2f78, (q15_t)0x2f72, (q15_t)0x2f6d, (q15_t)0x2f67, (q15_t)0x2f61, (q15_t)0x2f5b, + (q15_t)0x2f55, (q15_t)0x2f4f, (q15_t)0x2f4a, (q15_t)0x2f44, (q15_t)0x2f3e, (q15_t)0x2f38, (q15_t)0x2f32, (q15_t)0x2f2c, + (q15_t)0x2f27, (q15_t)0x2f21, (q15_t)0x2f1b, (q15_t)0x2f15, (q15_t)0x2f0f, (q15_t)0x2f09, (q15_t)0x2f03, (q15_t)0x2efe, + (q15_t)0x2ef8, (q15_t)0x2ef2, (q15_t)0x2eec, (q15_t)0x2ee6, (q15_t)0x2ee0, (q15_t)0x2edb, (q15_t)0x2ed5, (q15_t)0x2ecf, + (q15_t)0x2ec9, (q15_t)0x2ec3, (q15_t)0x2ebd, (q15_t)0x2eb7, (q15_t)0x2eb2, (q15_t)0x2eac, (q15_t)0x2ea6, (q15_t)0x2ea0, + (q15_t)0x2e9a, (q15_t)0x2e94, (q15_t)0x2e8e, (q15_t)0x2e89, (q15_t)0x2e83, (q15_t)0x2e7d, (q15_t)0x2e77, (q15_t)0x2e71, + (q15_t)0x2e6b, (q15_t)0x2e65, (q15_t)0x2e60, (q15_t)0x2e5a, (q15_t)0x2e54, (q15_t)0x2e4e, (q15_t)0x2e48, (q15_t)0x2e42, + (q15_t)0x2e3c, (q15_t)0x2e37, (q15_t)0x2e31, (q15_t)0x2e2b, (q15_t)0x2e25, (q15_t)0x2e1f, (q15_t)0x2e19, (q15_t)0x2e13, + (q15_t)0x2e0e, (q15_t)0x2e08, (q15_t)0x2e02, (q15_t)0x2dfc, (q15_t)0x2df6, (q15_t)0x2df0, (q15_t)0x2dea, (q15_t)0x2de5, + (q15_t)0x2ddf, (q15_t)0x2dd9, (q15_t)0x2dd3, (q15_t)0x2dcd, (q15_t)0x2dc7, (q15_t)0x2dc1, (q15_t)0x2dbb, (q15_t)0x2db6, + (q15_t)0x2db0, (q15_t)0x2daa, (q15_t)0x2da4, (q15_t)0x2d9e, (q15_t)0x2d98, (q15_t)0x2d92, (q15_t)0x2d8d, (q15_t)0x2d87, + (q15_t)0x2d81, (q15_t)0x2d7b, (q15_t)0x2d75, (q15_t)0x2d6f, (q15_t)0x2d69, (q15_t)0x2d63, (q15_t)0x2d5e, (q15_t)0x2d58, + (q15_t)0x2d52, (q15_t)0x2d4c, (q15_t)0x2d46, (q15_t)0x2d40, (q15_t)0x2d3a, (q15_t)0x2d34, (q15_t)0x2d2f, (q15_t)0x2d29, + (q15_t)0x2d23, (q15_t)0x2d1d, (q15_t)0x2d17, (q15_t)0x2d11, (q15_t)0x2d0b, (q15_t)0x2d05, (q15_t)0x2cff, (q15_t)0x2cfa, + (q15_t)0x2cf4, (q15_t)0x2cee, (q15_t)0x2ce8, (q15_t)0x2ce2, (q15_t)0x2cdc, (q15_t)0x2cd6, (q15_t)0x2cd0, (q15_t)0x2ccb, + (q15_t)0x2cc5, (q15_t)0x2cbf, (q15_t)0x2cb9, (q15_t)0x2cb3, (q15_t)0x2cad, (q15_t)0x2ca7, (q15_t)0x2ca1, (q15_t)0x2c9b, + (q15_t)0x2c96, (q15_t)0x2c90, (q15_t)0x2c8a, (q15_t)0x2c84, (q15_t)0x2c7e, (q15_t)0x2c78, (q15_t)0x2c72, (q15_t)0x2c6c, + (q15_t)0x2c66, (q15_t)0x2c61, (q15_t)0x2c5b, (q15_t)0x2c55, (q15_t)0x2c4f, (q15_t)0x2c49, (q15_t)0x2c43, (q15_t)0x2c3d, + (q15_t)0x2c37, (q15_t)0x2c31, (q15_t)0x2c2b, (q15_t)0x2c26, (q15_t)0x2c20, (q15_t)0x2c1a, (q15_t)0x2c14, (q15_t)0x2c0e, + (q15_t)0x2c08, (q15_t)0x2c02, (q15_t)0x2bfc, (q15_t)0x2bf6, (q15_t)0x2bf0, (q15_t)0x2beb, (q15_t)0x2be5, (q15_t)0x2bdf, + (q15_t)0x2bd9, (q15_t)0x2bd3, (q15_t)0x2bcd, (q15_t)0x2bc7, (q15_t)0x2bc1, (q15_t)0x2bbb, (q15_t)0x2bb5, (q15_t)0x2bb0, + (q15_t)0x2baa, (q15_t)0x2ba4, (q15_t)0x2b9e, (q15_t)0x2b98, (q15_t)0x2b92, (q15_t)0x2b8c, (q15_t)0x2b86, (q15_t)0x2b80, + (q15_t)0x2b7a, (q15_t)0x2b74, (q15_t)0x2b6f, (q15_t)0x2b69, (q15_t)0x2b63, (q15_t)0x2b5d, (q15_t)0x2b57, (q15_t)0x2b51, + (q15_t)0x2b4b, (q15_t)0x2b45, (q15_t)0x2b3f, (q15_t)0x2b39, (q15_t)0x2b33, (q15_t)0x2b2d, (q15_t)0x2b28, (q15_t)0x2b22, + (q15_t)0x2b1c, (q15_t)0x2b16, (q15_t)0x2b10, (q15_t)0x2b0a, (q15_t)0x2b04, (q15_t)0x2afe, (q15_t)0x2af8, (q15_t)0x2af2, + (q15_t)0x2aec, (q15_t)0x2ae6, (q15_t)0x2ae1, (q15_t)0x2adb, (q15_t)0x2ad5, (q15_t)0x2acf, (q15_t)0x2ac9, (q15_t)0x2ac3, + (q15_t)0x2abd, (q15_t)0x2ab7, (q15_t)0x2ab1, (q15_t)0x2aab, (q15_t)0x2aa5, (q15_t)0x2a9f, (q15_t)0x2a99, (q15_t)0x2a94, + (q15_t)0x2a8e, (q15_t)0x2a88, (q15_t)0x2a82, (q15_t)0x2a7c, (q15_t)0x2a76, (q15_t)0x2a70, (q15_t)0x2a6a, (q15_t)0x2a64, + (q15_t)0x2a5e, (q15_t)0x2a58, (q15_t)0x2a52, (q15_t)0x2a4c, (q15_t)0x2a47, (q15_t)0x2a41, (q15_t)0x2a3b, (q15_t)0x2a35, + (q15_t)0x2a2f, (q15_t)0x2a29, (q15_t)0x2a23, (q15_t)0x2a1d, (q15_t)0x2a17, (q15_t)0x2a11, (q15_t)0x2a0b, (q15_t)0x2a05, + (q15_t)0x29ff, (q15_t)0x29f9, (q15_t)0x29f3, (q15_t)0x29ee, (q15_t)0x29e8, (q15_t)0x29e2, (q15_t)0x29dc, (q15_t)0x29d6, + (q15_t)0x29d0, (q15_t)0x29ca, (q15_t)0x29c4, (q15_t)0x29be, (q15_t)0x29b8, (q15_t)0x29b2, (q15_t)0x29ac, (q15_t)0x29a6, + (q15_t)0x29a0, (q15_t)0x299a, (q15_t)0x2994, (q15_t)0x298e, (q15_t)0x2989, (q15_t)0x2983, (q15_t)0x297d, (q15_t)0x2977, + (q15_t)0x2971, (q15_t)0x296b, (q15_t)0x2965, (q15_t)0x295f, (q15_t)0x2959, (q15_t)0x2953, (q15_t)0x294d, (q15_t)0x2947, + (q15_t)0x2941, (q15_t)0x293b, (q15_t)0x2935, (q15_t)0x292f, (q15_t)0x2929, (q15_t)0x2923, (q15_t)0x291d, (q15_t)0x2918, + (q15_t)0x2912, (q15_t)0x290c, (q15_t)0x2906, (q15_t)0x2900, (q15_t)0x28fa, (q15_t)0x28f4, (q15_t)0x28ee, (q15_t)0x28e8, + (q15_t)0x28e2, (q15_t)0x28dc, (q15_t)0x28d6, (q15_t)0x28d0, (q15_t)0x28ca, (q15_t)0x28c4, (q15_t)0x28be, (q15_t)0x28b8, + (q15_t)0x28b2, (q15_t)0x28ac, (q15_t)0x28a6, (q15_t)0x28a0, (q15_t)0x289a, (q15_t)0x2895, (q15_t)0x288f, (q15_t)0x2889, + (q15_t)0x2883, (q15_t)0x287d, (q15_t)0x2877, (q15_t)0x2871, (q15_t)0x286b, (q15_t)0x2865, (q15_t)0x285f, (q15_t)0x2859, + (q15_t)0x2853, (q15_t)0x284d, (q15_t)0x2847, (q15_t)0x2841, (q15_t)0x283b, (q15_t)0x2835, (q15_t)0x282f, (q15_t)0x2829, + (q15_t)0x2823, (q15_t)0x281d, (q15_t)0x2817, (q15_t)0x2811, (q15_t)0x280b, (q15_t)0x2805, (q15_t)0x27ff, (q15_t)0x27f9, + (q15_t)0x27f3, (q15_t)0x27ee, (q15_t)0x27e8, (q15_t)0x27e2, (q15_t)0x27dc, (q15_t)0x27d6, (q15_t)0x27d0, (q15_t)0x27ca, + (q15_t)0x27c4, (q15_t)0x27be, (q15_t)0x27b8, (q15_t)0x27b2, (q15_t)0x27ac, (q15_t)0x27a6, (q15_t)0x27a0, (q15_t)0x279a, + (q15_t)0x2794, (q15_t)0x278e, (q15_t)0x2788, (q15_t)0x2782, (q15_t)0x277c, (q15_t)0x2776, (q15_t)0x2770, (q15_t)0x276a, + (q15_t)0x2764, (q15_t)0x275e, (q15_t)0x2758, (q15_t)0x2752, (q15_t)0x274c, (q15_t)0x2746, (q15_t)0x2740, (q15_t)0x273a, + (q15_t)0x2734, (q15_t)0x272e, (q15_t)0x2728, (q15_t)0x2722, (q15_t)0x271c, (q15_t)0x2716, (q15_t)0x2710, (q15_t)0x270a, + (q15_t)0x2704, (q15_t)0x26fe, (q15_t)0x26f8, (q15_t)0x26f2, (q15_t)0x26ec, (q15_t)0x26e7, (q15_t)0x26e1, (q15_t)0x26db, + (q15_t)0x26d5, (q15_t)0x26cf, (q15_t)0x26c9, (q15_t)0x26c3, (q15_t)0x26bd, (q15_t)0x26b7, (q15_t)0x26b1, (q15_t)0x26ab, + (q15_t)0x26a5, (q15_t)0x269f, (q15_t)0x2699, (q15_t)0x2693, (q15_t)0x268d, (q15_t)0x2687, (q15_t)0x2681, (q15_t)0x267b, + (q15_t)0x2675, (q15_t)0x266f, (q15_t)0x2669, (q15_t)0x2663, (q15_t)0x265d, (q15_t)0x2657, (q15_t)0x2651, (q15_t)0x264b, + (q15_t)0x2645, (q15_t)0x263f, (q15_t)0x2639, (q15_t)0x2633, (q15_t)0x262d, (q15_t)0x2627, (q15_t)0x2621, (q15_t)0x261b, + (q15_t)0x2615, (q15_t)0x260f, (q15_t)0x2609, (q15_t)0x2603, (q15_t)0x25fd, (q15_t)0x25f7, (q15_t)0x25f1, (q15_t)0x25eb, + (q15_t)0x25e5, (q15_t)0x25df, (q15_t)0x25d9, (q15_t)0x25d3, (q15_t)0x25cd, (q15_t)0x25c7, (q15_t)0x25c1, (q15_t)0x25bb, + (q15_t)0x25b5, (q15_t)0x25af, (q15_t)0x25a9, (q15_t)0x25a3, (q15_t)0x259d, (q15_t)0x2597, (q15_t)0x2591, (q15_t)0x258b, + (q15_t)0x2585, (q15_t)0x257f, (q15_t)0x2579, (q15_t)0x2573, (q15_t)0x256d, (q15_t)0x2567, (q15_t)0x2561, (q15_t)0x255b, + (q15_t)0x2555, (q15_t)0x254f, (q15_t)0x2549, (q15_t)0x2543, (q15_t)0x253d, (q15_t)0x2537, (q15_t)0x2531, (q15_t)0x252b, + (q15_t)0x2525, (q15_t)0x251f, (q15_t)0x2519, (q15_t)0x2513, (q15_t)0x250c, (q15_t)0x2506, (q15_t)0x2500, (q15_t)0x24fa, + (q15_t)0x24f4, (q15_t)0x24ee, (q15_t)0x24e8, (q15_t)0x24e2, (q15_t)0x24dc, (q15_t)0x24d6, (q15_t)0x24d0, (q15_t)0x24ca, + (q15_t)0x24c4, (q15_t)0x24be, (q15_t)0x24b8, (q15_t)0x24b2, (q15_t)0x24ac, (q15_t)0x24a6, (q15_t)0x24a0, (q15_t)0x249a, + (q15_t)0x2494, (q15_t)0x248e, (q15_t)0x2488, (q15_t)0x2482, (q15_t)0x247c, (q15_t)0x2476, (q15_t)0x2470, (q15_t)0x246a, + (q15_t)0x2464, (q15_t)0x245e, (q15_t)0x2458, (q15_t)0x2452, (q15_t)0x244c, (q15_t)0x2446, (q15_t)0x2440, (q15_t)0x243a, + (q15_t)0x2434, (q15_t)0x242e, (q15_t)0x2428, (q15_t)0x2422, (q15_t)0x241c, (q15_t)0x2416, (q15_t)0x2410, (q15_t)0x240a, + (q15_t)0x2404, (q15_t)0x23fd, (q15_t)0x23f7, (q15_t)0x23f1, (q15_t)0x23eb, (q15_t)0x23e5, (q15_t)0x23df, (q15_t)0x23d9, + (q15_t)0x23d3, (q15_t)0x23cd, (q15_t)0x23c7, (q15_t)0x23c1, (q15_t)0x23bb, (q15_t)0x23b5, (q15_t)0x23af, (q15_t)0x23a9, + (q15_t)0x23a3, (q15_t)0x239d, (q15_t)0x2397, (q15_t)0x2391, (q15_t)0x238b, (q15_t)0x2385, (q15_t)0x237f, (q15_t)0x2379, + (q15_t)0x2373, (q15_t)0x236d, (q15_t)0x2367, (q15_t)0x2361, (q15_t)0x235b, (q15_t)0x2355, (q15_t)0x234e, (q15_t)0x2348, + (q15_t)0x2342, (q15_t)0x233c, (q15_t)0x2336, (q15_t)0x2330, (q15_t)0x232a, (q15_t)0x2324, (q15_t)0x231e, (q15_t)0x2318, + (q15_t)0x2312, (q15_t)0x230c, (q15_t)0x2306, (q15_t)0x2300, (q15_t)0x22fa, (q15_t)0x22f4, (q15_t)0x22ee, (q15_t)0x22e8, + (q15_t)0x22e2, (q15_t)0x22dc, (q15_t)0x22d6, (q15_t)0x22d0, (q15_t)0x22ca, (q15_t)0x22c4, (q15_t)0x22bd, (q15_t)0x22b7, + (q15_t)0x22b1, (q15_t)0x22ab, (q15_t)0x22a5, (q15_t)0x229f, (q15_t)0x2299, (q15_t)0x2293, (q15_t)0x228d, (q15_t)0x2287, + (q15_t)0x2281, (q15_t)0x227b, (q15_t)0x2275, (q15_t)0x226f, (q15_t)0x2269, (q15_t)0x2263, (q15_t)0x225d, (q15_t)0x2257, + (q15_t)0x2251, (q15_t)0x224a, (q15_t)0x2244, (q15_t)0x223e, (q15_t)0x2238, (q15_t)0x2232, (q15_t)0x222c, (q15_t)0x2226, + (q15_t)0x2220, (q15_t)0x221a, (q15_t)0x2214, (q15_t)0x220e, (q15_t)0x2208, (q15_t)0x2202, (q15_t)0x21fc, (q15_t)0x21f6, + (q15_t)0x21f0, (q15_t)0x21ea, (q15_t)0x21e4, (q15_t)0x21dd, (q15_t)0x21d7, (q15_t)0x21d1, (q15_t)0x21cb, (q15_t)0x21c5, + (q15_t)0x21bf, (q15_t)0x21b9, (q15_t)0x21b3, (q15_t)0x21ad, (q15_t)0x21a7, (q15_t)0x21a1, (q15_t)0x219b, (q15_t)0x2195, + (q15_t)0x218f, (q15_t)0x2189, (q15_t)0x2183, (q15_t)0x217c, (q15_t)0x2176, (q15_t)0x2170, (q15_t)0x216a, (q15_t)0x2164, + (q15_t)0x215e, (q15_t)0x2158, (q15_t)0x2152, (q15_t)0x214c, (q15_t)0x2146, (q15_t)0x2140, (q15_t)0x213a, (q15_t)0x2134, + (q15_t)0x212e, (q15_t)0x2128, (q15_t)0x2121, (q15_t)0x211b, (q15_t)0x2115, (q15_t)0x210f, (q15_t)0x2109, (q15_t)0x2103, + (q15_t)0x20fd, (q15_t)0x20f7, (q15_t)0x20f1, (q15_t)0x20eb, (q15_t)0x20e5, (q15_t)0x20df, (q15_t)0x20d9, (q15_t)0x20d3, + (q15_t)0x20cc, (q15_t)0x20c6, (q15_t)0x20c0, (q15_t)0x20ba, (q15_t)0x20b4, (q15_t)0x20ae, (q15_t)0x20a8, (q15_t)0x20a2, + (q15_t)0x209c, (q15_t)0x2096, (q15_t)0x2090, (q15_t)0x208a, (q15_t)0x2084, (q15_t)0x207e, (q15_t)0x2077, (q15_t)0x2071, + (q15_t)0x206b, (q15_t)0x2065, (q15_t)0x205f, (q15_t)0x2059, (q15_t)0x2053, (q15_t)0x204d, (q15_t)0x2047, (q15_t)0x2041, + (q15_t)0x203b, (q15_t)0x2035, (q15_t)0x202e, (q15_t)0x2028, (q15_t)0x2022, (q15_t)0x201c, (q15_t)0x2016, (q15_t)0x2010, + (q15_t)0x200a, (q15_t)0x2004, (q15_t)0x1ffe, (q15_t)0x1ff8, (q15_t)0x1ff2, (q15_t)0x1fec, (q15_t)0x1fe5, (q15_t)0x1fdf, + (q15_t)0x1fd9, (q15_t)0x1fd3, (q15_t)0x1fcd, (q15_t)0x1fc7, (q15_t)0x1fc1, (q15_t)0x1fbb, (q15_t)0x1fb5, (q15_t)0x1faf, + (q15_t)0x1fa9, (q15_t)0x1fa3, (q15_t)0x1f9c, (q15_t)0x1f96, (q15_t)0x1f90, (q15_t)0x1f8a, (q15_t)0x1f84, (q15_t)0x1f7e, + (q15_t)0x1f78, (q15_t)0x1f72, (q15_t)0x1f6c, (q15_t)0x1f66, (q15_t)0x1f60, (q15_t)0x1f59, (q15_t)0x1f53, (q15_t)0x1f4d, + (q15_t)0x1f47, (q15_t)0x1f41, (q15_t)0x1f3b, (q15_t)0x1f35, (q15_t)0x1f2f, (q15_t)0x1f29, (q15_t)0x1f23, (q15_t)0x1f1d, + (q15_t)0x1f16, (q15_t)0x1f10, (q15_t)0x1f0a, (q15_t)0x1f04, (q15_t)0x1efe, (q15_t)0x1ef8, (q15_t)0x1ef2, (q15_t)0x1eec, + (q15_t)0x1ee6, (q15_t)0x1ee0, (q15_t)0x1ed9, (q15_t)0x1ed3, (q15_t)0x1ecd, (q15_t)0x1ec7, (q15_t)0x1ec1, (q15_t)0x1ebb, + (q15_t)0x1eb5, (q15_t)0x1eaf, (q15_t)0x1ea9, (q15_t)0x1ea3, (q15_t)0x1e9c, (q15_t)0x1e96, (q15_t)0x1e90, (q15_t)0x1e8a, + (q15_t)0x1e84, (q15_t)0x1e7e, (q15_t)0x1e78, (q15_t)0x1e72, (q15_t)0x1e6c, (q15_t)0x1e66, (q15_t)0x1e5f, (q15_t)0x1e59, + (q15_t)0x1e53, (q15_t)0x1e4d, (q15_t)0x1e47, (q15_t)0x1e41, (q15_t)0x1e3b, (q15_t)0x1e35, (q15_t)0x1e2f, (q15_t)0x1e29, + (q15_t)0x1e22, (q15_t)0x1e1c, (q15_t)0x1e16, (q15_t)0x1e10, (q15_t)0x1e0a, (q15_t)0x1e04, (q15_t)0x1dfe, (q15_t)0x1df8, + (q15_t)0x1df2, (q15_t)0x1deb, (q15_t)0x1de5, (q15_t)0x1ddf, (q15_t)0x1dd9, (q15_t)0x1dd3, (q15_t)0x1dcd, (q15_t)0x1dc7, + (q15_t)0x1dc1, (q15_t)0x1dbb, (q15_t)0x1db4, (q15_t)0x1dae, (q15_t)0x1da8, (q15_t)0x1da2, (q15_t)0x1d9c, (q15_t)0x1d96, + (q15_t)0x1d90, (q15_t)0x1d8a, (q15_t)0x1d84, (q15_t)0x1d7d, (q15_t)0x1d77, (q15_t)0x1d71, (q15_t)0x1d6b, (q15_t)0x1d65, + (q15_t)0x1d5f, (q15_t)0x1d59, (q15_t)0x1d53, (q15_t)0x1d4c, (q15_t)0x1d46, (q15_t)0x1d40, (q15_t)0x1d3a, (q15_t)0x1d34, + (q15_t)0x1d2e, (q15_t)0x1d28, (q15_t)0x1d22, (q15_t)0x1d1c, (q15_t)0x1d15, (q15_t)0x1d0f, (q15_t)0x1d09, (q15_t)0x1d03, + (q15_t)0x1cfd, (q15_t)0x1cf7, (q15_t)0x1cf1, (q15_t)0x1ceb, (q15_t)0x1ce4, (q15_t)0x1cde, (q15_t)0x1cd8, (q15_t)0x1cd2, + (q15_t)0x1ccc, (q15_t)0x1cc6, (q15_t)0x1cc0, (q15_t)0x1cba, (q15_t)0x1cb3, (q15_t)0x1cad, (q15_t)0x1ca7, (q15_t)0x1ca1, + (q15_t)0x1c9b, (q15_t)0x1c95, (q15_t)0x1c8f, (q15_t)0x1c89, (q15_t)0x1c83, (q15_t)0x1c7c, (q15_t)0x1c76, (q15_t)0x1c70, + (q15_t)0x1c6a, (q15_t)0x1c64, (q15_t)0x1c5e, (q15_t)0x1c58, (q15_t)0x1c51, (q15_t)0x1c4b, (q15_t)0x1c45, (q15_t)0x1c3f, + (q15_t)0x1c39, (q15_t)0x1c33, (q15_t)0x1c2d, (q15_t)0x1c27, (q15_t)0x1c20, (q15_t)0x1c1a, (q15_t)0x1c14, (q15_t)0x1c0e, + (q15_t)0x1c08, (q15_t)0x1c02, (q15_t)0x1bfc, (q15_t)0x1bf6, (q15_t)0x1bef, (q15_t)0x1be9, (q15_t)0x1be3, (q15_t)0x1bdd, + (q15_t)0x1bd7, (q15_t)0x1bd1, (q15_t)0x1bcb, (q15_t)0x1bc4, (q15_t)0x1bbe, (q15_t)0x1bb8, (q15_t)0x1bb2, (q15_t)0x1bac, + (q15_t)0x1ba6, (q15_t)0x1ba0, (q15_t)0x1b9a, (q15_t)0x1b93, (q15_t)0x1b8d, (q15_t)0x1b87, (q15_t)0x1b81, (q15_t)0x1b7b, + (q15_t)0x1b75, (q15_t)0x1b6f, (q15_t)0x1b68, (q15_t)0x1b62, (q15_t)0x1b5c, (q15_t)0x1b56, (q15_t)0x1b50, (q15_t)0x1b4a, + (q15_t)0x1b44, (q15_t)0x1b3d, (q15_t)0x1b37, (q15_t)0x1b31, (q15_t)0x1b2b, (q15_t)0x1b25, (q15_t)0x1b1f, (q15_t)0x1b19, + (q15_t)0x1b13, (q15_t)0x1b0c, (q15_t)0x1b06, (q15_t)0x1b00, (q15_t)0x1afa, (q15_t)0x1af4, (q15_t)0x1aee, (q15_t)0x1ae8, + (q15_t)0x1ae1, (q15_t)0x1adb, (q15_t)0x1ad5, (q15_t)0x1acf, (q15_t)0x1ac9, (q15_t)0x1ac3, (q15_t)0x1abd, (q15_t)0x1ab6, + (q15_t)0x1ab0, (q15_t)0x1aaa, (q15_t)0x1aa4, (q15_t)0x1a9e, (q15_t)0x1a98, (q15_t)0x1a91, (q15_t)0x1a8b, (q15_t)0x1a85, + (q15_t)0x1a7f, (q15_t)0x1a79, (q15_t)0x1a73, (q15_t)0x1a6d, (q15_t)0x1a66, (q15_t)0x1a60, (q15_t)0x1a5a, (q15_t)0x1a54, + (q15_t)0x1a4e, (q15_t)0x1a48, (q15_t)0x1a42, (q15_t)0x1a3b, (q15_t)0x1a35, (q15_t)0x1a2f, (q15_t)0x1a29, (q15_t)0x1a23, + (q15_t)0x1a1d, (q15_t)0x1a17, (q15_t)0x1a10, (q15_t)0x1a0a, (q15_t)0x1a04, (q15_t)0x19fe, (q15_t)0x19f8, (q15_t)0x19f2, + (q15_t)0x19eb, (q15_t)0x19e5, (q15_t)0x19df, (q15_t)0x19d9, (q15_t)0x19d3, (q15_t)0x19cd, (q15_t)0x19c7, (q15_t)0x19c0, + (q15_t)0x19ba, (q15_t)0x19b4, (q15_t)0x19ae, (q15_t)0x19a8, (q15_t)0x19a2, (q15_t)0x199b, (q15_t)0x1995, (q15_t)0x198f, + (q15_t)0x1989, (q15_t)0x1983, (q15_t)0x197d, (q15_t)0x1977, (q15_t)0x1970, (q15_t)0x196a, (q15_t)0x1964, (q15_t)0x195e, + (q15_t)0x1958, (q15_t)0x1952, (q15_t)0x194b, (q15_t)0x1945, (q15_t)0x193f, (q15_t)0x1939, (q15_t)0x1933, (q15_t)0x192d, + (q15_t)0x1926, (q15_t)0x1920, (q15_t)0x191a, (q15_t)0x1914, (q15_t)0x190e, (q15_t)0x1908, (q15_t)0x1901, (q15_t)0x18fb, + (q15_t)0x18f5, (q15_t)0x18ef, (q15_t)0x18e9, (q15_t)0x18e3, (q15_t)0x18dc, (q15_t)0x18d6, (q15_t)0x18d0, (q15_t)0x18ca, + (q15_t)0x18c4, (q15_t)0x18be, (q15_t)0x18b8, (q15_t)0x18b1, (q15_t)0x18ab, (q15_t)0x18a5, (q15_t)0x189f, (q15_t)0x1899, + (q15_t)0x1893, (q15_t)0x188c, (q15_t)0x1886, (q15_t)0x1880, (q15_t)0x187a, (q15_t)0x1874, (q15_t)0x186e, (q15_t)0x1867, + (q15_t)0x1861, (q15_t)0x185b, (q15_t)0x1855, (q15_t)0x184f, (q15_t)0x1848, (q15_t)0x1842, (q15_t)0x183c, (q15_t)0x1836, + (q15_t)0x1830, (q15_t)0x182a, (q15_t)0x1823, (q15_t)0x181d, (q15_t)0x1817, (q15_t)0x1811, (q15_t)0x180b, (q15_t)0x1805, + (q15_t)0x17fe, (q15_t)0x17f8, (q15_t)0x17f2, (q15_t)0x17ec, (q15_t)0x17e6, (q15_t)0x17e0, (q15_t)0x17d9, (q15_t)0x17d3, + (q15_t)0x17cd, (q15_t)0x17c7, (q15_t)0x17c1, (q15_t)0x17bb, (q15_t)0x17b4, (q15_t)0x17ae, (q15_t)0x17a8, (q15_t)0x17a2, + (q15_t)0x179c, (q15_t)0x1795, (q15_t)0x178f, (q15_t)0x1789, (q15_t)0x1783, (q15_t)0x177d, (q15_t)0x1777, (q15_t)0x1770, + (q15_t)0x176a, (q15_t)0x1764, (q15_t)0x175e, (q15_t)0x1758, (q15_t)0x1752, (q15_t)0x174b, (q15_t)0x1745, (q15_t)0x173f, + (q15_t)0x1739, (q15_t)0x1733, (q15_t)0x172c, (q15_t)0x1726, (q15_t)0x1720, (q15_t)0x171a, (q15_t)0x1714, (q15_t)0x170e, + (q15_t)0x1707, (q15_t)0x1701, (q15_t)0x16fb, (q15_t)0x16f5, (q15_t)0x16ef, (q15_t)0x16e8, (q15_t)0x16e2, (q15_t)0x16dc, + (q15_t)0x16d6, (q15_t)0x16d0, (q15_t)0x16ca, (q15_t)0x16c3, (q15_t)0x16bd, (q15_t)0x16b7, (q15_t)0x16b1, (q15_t)0x16ab, + (q15_t)0x16a4, (q15_t)0x169e, (q15_t)0x1698, (q15_t)0x1692, (q15_t)0x168c, (q15_t)0x1686, (q15_t)0x167f, (q15_t)0x1679, + (q15_t)0x1673, (q15_t)0x166d, (q15_t)0x1667, (q15_t)0x1660, (q15_t)0x165a, (q15_t)0x1654, (q15_t)0x164e, (q15_t)0x1648, + (q15_t)0x1642, (q15_t)0x163b, (q15_t)0x1635, (q15_t)0x162f, (q15_t)0x1629, (q15_t)0x1623, (q15_t)0x161c, (q15_t)0x1616, + (q15_t)0x1610, (q15_t)0x160a, (q15_t)0x1604, (q15_t)0x15fd, (q15_t)0x15f7, (q15_t)0x15f1, (q15_t)0x15eb, (q15_t)0x15e5, + (q15_t)0x15de, (q15_t)0x15d8, (q15_t)0x15d2, (q15_t)0x15cc, (q15_t)0x15c6, (q15_t)0x15c0, (q15_t)0x15b9, (q15_t)0x15b3, + (q15_t)0x15ad, (q15_t)0x15a7, (q15_t)0x15a1, (q15_t)0x159a, (q15_t)0x1594, (q15_t)0x158e, (q15_t)0x1588, (q15_t)0x1582, + (q15_t)0x157b, (q15_t)0x1575, (q15_t)0x156f, (q15_t)0x1569, (q15_t)0x1563, (q15_t)0x155c, (q15_t)0x1556, (q15_t)0x1550, + (q15_t)0x154a, (q15_t)0x1544, (q15_t)0x153d, (q15_t)0x1537, (q15_t)0x1531, (q15_t)0x152b, (q15_t)0x1525, (q15_t)0x151e, + (q15_t)0x1518, (q15_t)0x1512, (q15_t)0x150c, (q15_t)0x1506, (q15_t)0x14ff, (q15_t)0x14f9, (q15_t)0x14f3, (q15_t)0x14ed, + (q15_t)0x14e7, (q15_t)0x14e0, (q15_t)0x14da, (q15_t)0x14d4, (q15_t)0x14ce, (q15_t)0x14c8, (q15_t)0x14c1, (q15_t)0x14bb, + (q15_t)0x14b5, (q15_t)0x14af, (q15_t)0x14a9, (q15_t)0x14a2, (q15_t)0x149c, (q15_t)0x1496, (q15_t)0x1490, (q15_t)0x148a, + (q15_t)0x1483, (q15_t)0x147d, (q15_t)0x1477, (q15_t)0x1471, (q15_t)0x146b, (q15_t)0x1464, (q15_t)0x145e, (q15_t)0x1458, + (q15_t)0x1452, (q15_t)0x144c, (q15_t)0x1445, (q15_t)0x143f, (q15_t)0x1439, (q15_t)0x1433, (q15_t)0x142d, (q15_t)0x1426, + (q15_t)0x1420, (q15_t)0x141a, (q15_t)0x1414, (q15_t)0x140e, (q15_t)0x1407, (q15_t)0x1401, (q15_t)0x13fb, (q15_t)0x13f5, + (q15_t)0x13ef, (q15_t)0x13e8, (q15_t)0x13e2, (q15_t)0x13dc, (q15_t)0x13d6, (q15_t)0x13d0, (q15_t)0x13c9, (q15_t)0x13c3, + (q15_t)0x13bd, (q15_t)0x13b7, (q15_t)0x13b1, (q15_t)0x13aa, (q15_t)0x13a4, (q15_t)0x139e, (q15_t)0x1398, (q15_t)0x1391, + (q15_t)0x138b, (q15_t)0x1385, (q15_t)0x137f, (q15_t)0x1379, (q15_t)0x1372, (q15_t)0x136c, (q15_t)0x1366, (q15_t)0x1360, + (q15_t)0x135a, (q15_t)0x1353, (q15_t)0x134d, (q15_t)0x1347, (q15_t)0x1341, (q15_t)0x133b, (q15_t)0x1334, (q15_t)0x132e, + (q15_t)0x1328, (q15_t)0x1322, (q15_t)0x131b, (q15_t)0x1315, (q15_t)0x130f, (q15_t)0x1309, (q15_t)0x1303, (q15_t)0x12fc, + (q15_t)0x12f6, (q15_t)0x12f0, (q15_t)0x12ea, (q15_t)0x12e4, (q15_t)0x12dd, (q15_t)0x12d7, (q15_t)0x12d1, (q15_t)0x12cb, + (q15_t)0x12c4, (q15_t)0x12be, (q15_t)0x12b8, (q15_t)0x12b2, (q15_t)0x12ac, (q15_t)0x12a5, (q15_t)0x129f, (q15_t)0x1299, + (q15_t)0x1293, (q15_t)0x128d, (q15_t)0x1286, (q15_t)0x1280, (q15_t)0x127a, (q15_t)0x1274, (q15_t)0x126d, (q15_t)0x1267, + (q15_t)0x1261, (q15_t)0x125b, (q15_t)0x1255, (q15_t)0x124e, (q15_t)0x1248, (q15_t)0x1242, (q15_t)0x123c, (q15_t)0x1235, + (q15_t)0x122f, (q15_t)0x1229, (q15_t)0x1223, (q15_t)0x121d, (q15_t)0x1216, (q15_t)0x1210, (q15_t)0x120a, (q15_t)0x1204, + (q15_t)0x11fd, (q15_t)0x11f7, (q15_t)0x11f1, (q15_t)0x11eb, (q15_t)0x11e5, (q15_t)0x11de, (q15_t)0x11d8, (q15_t)0x11d2, + (q15_t)0x11cc, (q15_t)0x11c5, (q15_t)0x11bf, (q15_t)0x11b9, (q15_t)0x11b3, (q15_t)0x11ad, (q15_t)0x11a6, (q15_t)0x11a0, + (q15_t)0x119a, (q15_t)0x1194, (q15_t)0x118d, (q15_t)0x1187, (q15_t)0x1181, (q15_t)0x117b, (q15_t)0x1175, (q15_t)0x116e, + (q15_t)0x1168, (q15_t)0x1162, (q15_t)0x115c, (q15_t)0x1155, (q15_t)0x114f, (q15_t)0x1149, (q15_t)0x1143, (q15_t)0x113d, + (q15_t)0x1136, (q15_t)0x1130, (q15_t)0x112a, (q15_t)0x1124, (q15_t)0x111d, (q15_t)0x1117, (q15_t)0x1111, (q15_t)0x110b, + (q15_t)0x1105, (q15_t)0x10fe, (q15_t)0x10f8, (q15_t)0x10f2, (q15_t)0x10ec, (q15_t)0x10e5, (q15_t)0x10df, (q15_t)0x10d9, + (q15_t)0x10d3, (q15_t)0x10cc, (q15_t)0x10c6, (q15_t)0x10c0, (q15_t)0x10ba, (q15_t)0x10b4, (q15_t)0x10ad, (q15_t)0x10a7, + (q15_t)0x10a1, (q15_t)0x109b, (q15_t)0x1094, (q15_t)0x108e, (q15_t)0x1088, (q15_t)0x1082, (q15_t)0x107b, (q15_t)0x1075, + (q15_t)0x106f, (q15_t)0x1069, (q15_t)0x1063, (q15_t)0x105c, (q15_t)0x1056, (q15_t)0x1050, (q15_t)0x104a, (q15_t)0x1043, + (q15_t)0x103d, (q15_t)0x1037, (q15_t)0x1031, (q15_t)0x102a, (q15_t)0x1024, (q15_t)0x101e, (q15_t)0x1018, (q15_t)0x1012, + (q15_t)0x100b, (q15_t)0x1005, (q15_t)0xfff, (q15_t)0xff9, (q15_t)0xff2, (q15_t)0xfec, (q15_t)0xfe6, (q15_t)0xfe0, + (q15_t)0xfd9, (q15_t)0xfd3, (q15_t)0xfcd, (q15_t)0xfc7, (q15_t)0xfc0, (q15_t)0xfba, (q15_t)0xfb4, (q15_t)0xfae, + (q15_t)0xfa8, (q15_t)0xfa1, (q15_t)0xf9b, (q15_t)0xf95, (q15_t)0xf8f, (q15_t)0xf88, (q15_t)0xf82, (q15_t)0xf7c, + (q15_t)0xf76, (q15_t)0xf6f, (q15_t)0xf69, (q15_t)0xf63, (q15_t)0xf5d, (q15_t)0xf56, (q15_t)0xf50, (q15_t)0xf4a, + (q15_t)0xf44, (q15_t)0xf3e, (q15_t)0xf37, (q15_t)0xf31, (q15_t)0xf2b, (q15_t)0xf25, (q15_t)0xf1e, (q15_t)0xf18, + (q15_t)0xf12, (q15_t)0xf0c, (q15_t)0xf05, (q15_t)0xeff, (q15_t)0xef9, (q15_t)0xef3, (q15_t)0xeec, (q15_t)0xee6, + (q15_t)0xee0, (q15_t)0xeda, (q15_t)0xed3, (q15_t)0xecd, (q15_t)0xec7, (q15_t)0xec1, (q15_t)0xeba, (q15_t)0xeb4, + (q15_t)0xeae, (q15_t)0xea8, (q15_t)0xea1, (q15_t)0xe9b, (q15_t)0xe95, (q15_t)0xe8f, (q15_t)0xe89, (q15_t)0xe82, + (q15_t)0xe7c, (q15_t)0xe76, (q15_t)0xe70, (q15_t)0xe69, (q15_t)0xe63, (q15_t)0xe5d, (q15_t)0xe57, (q15_t)0xe50, + (q15_t)0xe4a, (q15_t)0xe44, (q15_t)0xe3e, (q15_t)0xe37, (q15_t)0xe31, (q15_t)0xe2b, (q15_t)0xe25, (q15_t)0xe1e, + (q15_t)0xe18, (q15_t)0xe12, (q15_t)0xe0c, (q15_t)0xe05, (q15_t)0xdff, (q15_t)0xdf9, (q15_t)0xdf3, (q15_t)0xdec, + (q15_t)0xde6, (q15_t)0xde0, (q15_t)0xdda, (q15_t)0xdd3, (q15_t)0xdcd, (q15_t)0xdc7, (q15_t)0xdc1, (q15_t)0xdba, + (q15_t)0xdb4, (q15_t)0xdae, (q15_t)0xda8, (q15_t)0xda1, (q15_t)0xd9b, (q15_t)0xd95, (q15_t)0xd8f, (q15_t)0xd88, + (q15_t)0xd82, (q15_t)0xd7c, (q15_t)0xd76, (q15_t)0xd6f, (q15_t)0xd69, (q15_t)0xd63, (q15_t)0xd5d, (q15_t)0xd56, + (q15_t)0xd50, (q15_t)0xd4a, (q15_t)0xd44, (q15_t)0xd3d, (q15_t)0xd37, (q15_t)0xd31, (q15_t)0xd2b, (q15_t)0xd24, + (q15_t)0xd1e, (q15_t)0xd18, (q15_t)0xd12, (q15_t)0xd0b, (q15_t)0xd05, (q15_t)0xcff, (q15_t)0xcf9, (q15_t)0xcf2, + (q15_t)0xcec, (q15_t)0xce6, (q15_t)0xce0, (q15_t)0xcd9, (q15_t)0xcd3, (q15_t)0xccd, (q15_t)0xcc7, (q15_t)0xcc0, + (q15_t)0xcba, (q15_t)0xcb4, (q15_t)0xcae, (q15_t)0xca7, (q15_t)0xca1, (q15_t)0xc9b, (q15_t)0xc95, (q15_t)0xc8e, + (q15_t)0xc88, (q15_t)0xc82, (q15_t)0xc7c, (q15_t)0xc75, (q15_t)0xc6f, (q15_t)0xc69, (q15_t)0xc63, (q15_t)0xc5c, + (q15_t)0xc56, (q15_t)0xc50, (q15_t)0xc4a, (q15_t)0xc43, (q15_t)0xc3d, (q15_t)0xc37, (q15_t)0xc31, (q15_t)0xc2a, + (q15_t)0xc24, (q15_t)0xc1e, (q15_t)0xc18, (q15_t)0xc11, (q15_t)0xc0b, (q15_t)0xc05, (q15_t)0xbff, (q15_t)0xbf8, + (q15_t)0xbf2, (q15_t)0xbec, (q15_t)0xbe6, (q15_t)0xbdf, (q15_t)0xbd9, (q15_t)0xbd3, (q15_t)0xbcd, (q15_t)0xbc6, + (q15_t)0xbc0, (q15_t)0xbba, (q15_t)0xbb4, (q15_t)0xbad, (q15_t)0xba7, (q15_t)0xba1, (q15_t)0xb9b, (q15_t)0xb94, + (q15_t)0xb8e, (q15_t)0xb88, (q15_t)0xb81, (q15_t)0xb7b, (q15_t)0xb75, (q15_t)0xb6f, (q15_t)0xb68, (q15_t)0xb62, + (q15_t)0xb5c, (q15_t)0xb56, (q15_t)0xb4f, (q15_t)0xb49, (q15_t)0xb43, (q15_t)0xb3d, (q15_t)0xb36, (q15_t)0xb30, + (q15_t)0xb2a, (q15_t)0xb24, (q15_t)0xb1d, (q15_t)0xb17, (q15_t)0xb11, (q15_t)0xb0b, (q15_t)0xb04, (q15_t)0xafe, + (q15_t)0xaf8, (q15_t)0xaf2, (q15_t)0xaeb, (q15_t)0xae5, (q15_t)0xadf, (q15_t)0xad8, (q15_t)0xad2, (q15_t)0xacc, + (q15_t)0xac6, (q15_t)0xabf, (q15_t)0xab9, (q15_t)0xab3, (q15_t)0xaad, (q15_t)0xaa6, (q15_t)0xaa0, (q15_t)0xa9a, + (q15_t)0xa94, (q15_t)0xa8d, (q15_t)0xa87, (q15_t)0xa81, (q15_t)0xa7b, (q15_t)0xa74, (q15_t)0xa6e, (q15_t)0xa68, + (q15_t)0xa62, (q15_t)0xa5b, (q15_t)0xa55, (q15_t)0xa4f, (q15_t)0xa48, (q15_t)0xa42, (q15_t)0xa3c, (q15_t)0xa36, + (q15_t)0xa2f, (q15_t)0xa29, (q15_t)0xa23, (q15_t)0xa1d, (q15_t)0xa16, (q15_t)0xa10, (q15_t)0xa0a, (q15_t)0xa04, + (q15_t)0x9fd, (q15_t)0x9f7, (q15_t)0x9f1, (q15_t)0x9eb, (q15_t)0x9e4, (q15_t)0x9de, (q15_t)0x9d8, (q15_t)0x9d1, + (q15_t)0x9cb, (q15_t)0x9c5, (q15_t)0x9bf, (q15_t)0x9b8, (q15_t)0x9b2, (q15_t)0x9ac, (q15_t)0x9a6, (q15_t)0x99f, + (q15_t)0x999, (q15_t)0x993, (q15_t)0x98d, (q15_t)0x986, (q15_t)0x980, (q15_t)0x97a, (q15_t)0x973, (q15_t)0x96d, + (q15_t)0x967, (q15_t)0x961, (q15_t)0x95a, (q15_t)0x954, (q15_t)0x94e, (q15_t)0x948, (q15_t)0x941, (q15_t)0x93b, + (q15_t)0x935, (q15_t)0x92f, (q15_t)0x928, (q15_t)0x922, (q15_t)0x91c, (q15_t)0x915, (q15_t)0x90f, (q15_t)0x909, + (q15_t)0x903, (q15_t)0x8fc, (q15_t)0x8f6, (q15_t)0x8f0, (q15_t)0x8ea, (q15_t)0x8e3, (q15_t)0x8dd, (q15_t)0x8d7, + (q15_t)0x8d1, (q15_t)0x8ca, (q15_t)0x8c4, (q15_t)0x8be, (q15_t)0x8b7, (q15_t)0x8b1, (q15_t)0x8ab, (q15_t)0x8a5, + (q15_t)0x89e, (q15_t)0x898, (q15_t)0x892, (q15_t)0x88c, (q15_t)0x885, (q15_t)0x87f, (q15_t)0x879, (q15_t)0x872, + (q15_t)0x86c, (q15_t)0x866, (q15_t)0x860, (q15_t)0x859, (q15_t)0x853, (q15_t)0x84d, (q15_t)0x847, (q15_t)0x840, + (q15_t)0x83a, (q15_t)0x834, (q15_t)0x82e, (q15_t)0x827, (q15_t)0x821, (q15_t)0x81b, (q15_t)0x814, (q15_t)0x80e, + (q15_t)0x808, (q15_t)0x802, (q15_t)0x7fb, (q15_t)0x7f5, (q15_t)0x7ef, (q15_t)0x7e9, (q15_t)0x7e2, (q15_t)0x7dc, + (q15_t)0x7d6, (q15_t)0x7cf, (q15_t)0x7c9, (q15_t)0x7c3, (q15_t)0x7bd, (q15_t)0x7b6, (q15_t)0x7b0, (q15_t)0x7aa, + (q15_t)0x7a4, (q15_t)0x79d, (q15_t)0x797, (q15_t)0x791, (q15_t)0x78a, (q15_t)0x784, (q15_t)0x77e, (q15_t)0x778, + (q15_t)0x771, (q15_t)0x76b, (q15_t)0x765, (q15_t)0x75f, (q15_t)0x758, (q15_t)0x752, (q15_t)0x74c, (q15_t)0x745, + (q15_t)0x73f, (q15_t)0x739, (q15_t)0x733, (q15_t)0x72c, (q15_t)0x726, (q15_t)0x720, (q15_t)0x71a, (q15_t)0x713, + (q15_t)0x70d, (q15_t)0x707, (q15_t)0x700, (q15_t)0x6fa, (q15_t)0x6f4, (q15_t)0x6ee, (q15_t)0x6e7, (q15_t)0x6e1, + (q15_t)0x6db, (q15_t)0x6d5, (q15_t)0x6ce, (q15_t)0x6c8, (q15_t)0x6c2, (q15_t)0x6bb, (q15_t)0x6b5, (q15_t)0x6af, + (q15_t)0x6a9, (q15_t)0x6a2, (q15_t)0x69c, (q15_t)0x696, (q15_t)0x690, (q15_t)0x689, (q15_t)0x683, (q15_t)0x67d, + (q15_t)0x676, (q15_t)0x670, (q15_t)0x66a, (q15_t)0x664, (q15_t)0x65d, (q15_t)0x657, (q15_t)0x651, (q15_t)0x64a, + (q15_t)0x644, (q15_t)0x63e, (q15_t)0x638, (q15_t)0x631, (q15_t)0x62b, (q15_t)0x625, (q15_t)0x61f, (q15_t)0x618, + (q15_t)0x612, (q15_t)0x60c, (q15_t)0x605, (q15_t)0x5ff, (q15_t)0x5f9, (q15_t)0x5f3, (q15_t)0x5ec, (q15_t)0x5e6, + (q15_t)0x5e0, (q15_t)0x5da, (q15_t)0x5d3, (q15_t)0x5cd, (q15_t)0x5c7, (q15_t)0x5c0, (q15_t)0x5ba, (q15_t)0x5b4, + (q15_t)0x5ae, (q15_t)0x5a7, (q15_t)0x5a1, (q15_t)0x59b, (q15_t)0x594, (q15_t)0x58e, (q15_t)0x588, (q15_t)0x582, + (q15_t)0x57b, (q15_t)0x575, (q15_t)0x56f, (q15_t)0x569, (q15_t)0x562, (q15_t)0x55c, (q15_t)0x556, (q15_t)0x54f, + (q15_t)0x549, (q15_t)0x543, (q15_t)0x53d, (q15_t)0x536, (q15_t)0x530, (q15_t)0x52a, (q15_t)0x523, (q15_t)0x51d, + (q15_t)0x517, (q15_t)0x511, (q15_t)0x50a, (q15_t)0x504, (q15_t)0x4fe, (q15_t)0x4f8, (q15_t)0x4f1, (q15_t)0x4eb, + (q15_t)0x4e5, (q15_t)0x4de, (q15_t)0x4d8, (q15_t)0x4d2, (q15_t)0x4cc, (q15_t)0x4c5, (q15_t)0x4bf, (q15_t)0x4b9, + (q15_t)0x4b2, (q15_t)0x4ac, (q15_t)0x4a6, (q15_t)0x4a0, (q15_t)0x499, (q15_t)0x493, (q15_t)0x48d, (q15_t)0x487, + (q15_t)0x480, (q15_t)0x47a, (q15_t)0x474, (q15_t)0x46d, (q15_t)0x467, (q15_t)0x461, (q15_t)0x45b, (q15_t)0x454, + (q15_t)0x44e, (q15_t)0x448, (q15_t)0x441, (q15_t)0x43b, (q15_t)0x435, (q15_t)0x42f, (q15_t)0x428, (q15_t)0x422, + (q15_t)0x41c, (q15_t)0x415, (q15_t)0x40f, (q15_t)0x409, (q15_t)0x403, (q15_t)0x3fc, (q15_t)0x3f6, (q15_t)0x3f0, + (q15_t)0x3ea, (q15_t)0x3e3, (q15_t)0x3dd, (q15_t)0x3d7, (q15_t)0x3d0, (q15_t)0x3ca, (q15_t)0x3c4, (q15_t)0x3be, + (q15_t)0x3b7, (q15_t)0x3b1, (q15_t)0x3ab, (q15_t)0x3a4, (q15_t)0x39e, (q15_t)0x398, (q15_t)0x392, (q15_t)0x38b, + (q15_t)0x385, (q15_t)0x37f, (q15_t)0x378, (q15_t)0x372, (q15_t)0x36c, (q15_t)0x366, (q15_t)0x35f, (q15_t)0x359, + (q15_t)0x353, (q15_t)0x34c, (q15_t)0x346, (q15_t)0x340, (q15_t)0x33a, (q15_t)0x333, (q15_t)0x32d, (q15_t)0x327, + (q15_t)0x321, (q15_t)0x31a, (q15_t)0x314, (q15_t)0x30e, (q15_t)0x307, (q15_t)0x301, (q15_t)0x2fb, (q15_t)0x2f5, + (q15_t)0x2ee, (q15_t)0x2e8, (q15_t)0x2e2, (q15_t)0x2db, (q15_t)0x2d5, (q15_t)0x2cf, (q15_t)0x2c9, (q15_t)0x2c2, + (q15_t)0x2bc, (q15_t)0x2b6, (q15_t)0x2af, (q15_t)0x2a9, (q15_t)0x2a3, (q15_t)0x29d, (q15_t)0x296, (q15_t)0x290, + (q15_t)0x28a, (q15_t)0x283, (q15_t)0x27d, (q15_t)0x277, (q15_t)0x271, (q15_t)0x26a, (q15_t)0x264, (q15_t)0x25e, + (q15_t)0x258, (q15_t)0x251, (q15_t)0x24b, (q15_t)0x245, (q15_t)0x23e, (q15_t)0x238, (q15_t)0x232, (q15_t)0x22c, + (q15_t)0x225, (q15_t)0x21f, (q15_t)0x219, (q15_t)0x212, (q15_t)0x20c, (q15_t)0x206, (q15_t)0x200, (q15_t)0x1f9, + (q15_t)0x1f3, (q15_t)0x1ed, (q15_t)0x1e6, (q15_t)0x1e0, (q15_t)0x1da, (q15_t)0x1d4, (q15_t)0x1cd, (q15_t)0x1c7, + (q15_t)0x1c1, (q15_t)0x1ba, (q15_t)0x1b4, (q15_t)0x1ae, (q15_t)0x1a8, (q15_t)0x1a1, (q15_t)0x19b, (q15_t)0x195, + (q15_t)0x18e, (q15_t)0x188, (q15_t)0x182, (q15_t)0x17c, (q15_t)0x175, (q15_t)0x16f, (q15_t)0x169, (q15_t)0x162, + (q15_t)0x15c, (q15_t)0x156, (q15_t)0x150, (q15_t)0x149, (q15_t)0x143, (q15_t)0x13d, (q15_t)0x137, (q15_t)0x130, + (q15_t)0x12a, (q15_t)0x124, (q15_t)0x11d, (q15_t)0x117, (q15_t)0x111, (q15_t)0x10b, (q15_t)0x104, (q15_t)0xfe, + (q15_t)0xf8, (q15_t)0xf1, (q15_t)0xeb, (q15_t)0xe5, (q15_t)0xdf, (q15_t)0xd8, (q15_t)0xd2, (q15_t)0xcc, + (q15_t)0xc5, (q15_t)0xbf, (q15_t)0xb9, (q15_t)0xb3, (q15_t)0xac, (q15_t)0xa6, (q15_t)0xa0, (q15_t)0x99, + (q15_t)0x93, (q15_t)0x8d, (q15_t)0x87, (q15_t)0x80, (q15_t)0x7a, (q15_t)0x74, (q15_t)0x6d, (q15_t)0x67, + (q15_t)0x61, (q15_t)0x5b, (q15_t)0x54, (q15_t)0x4e, (q15_t)0x48, (q15_t)0x41, (q15_t)0x3b, (q15_t)0x35, + (q15_t)0x2f, (q15_t)0x28, (q15_t)0x22, (q15_t)0x1c, (q15_t)0x15, (q15_t)0xf, (q15_t)0x9, (q15_t)0x3 +}; + +/** + * @} end of DCT4_IDCT4_Table group + */ + +/** + * @addtogroup DCT4_IDCT4 + * @{ + */ + +/** + * @brief Initialization function for the Q15 DCT4/IDCT4. + * @param[in,out] *S points to an instance of Q15 DCT4/IDCT4 structure. + * @param[in] *S_RFFT points to an instance of Q15 RFFT/RIFFT structure. + * @param[in] *S_CFFT points to an instance of Q15 CFFT/CIFFT structure. + * @param[in] N length of the DCT4. + * @param[in] Nby2 half of the length of the DCT4. + * @param[in] normalize normalizing factor. + * @return arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if N is not a supported transform length. + * \par Normalizing factor: + * The normalizing factor is sqrt(2/N), which depends on the size of transform N. + * Normalizing factors in 1.15 format are mentioned in the table below for different DCT sizes: + * \image html dct4NormalizingQ15Table.gif + */ + +arm_status arm_dct4_init_q15( + arm_dct4_instance_q15 * S, + arm_rfft_instance_q15 * S_RFFT, + arm_cfft_radix4_instance_q15 * S_CFFT, + uint16_t N, + uint16_t Nby2, + q15_t normalize) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initializing the pointer array with the weight table base addresses of different lengths */ + q15_t *twiddlePtr[4] = { (q15_t *) WeightsQ15_128, (q15_t *) WeightsQ15_512, + (q15_t *) WeightsQ15_2048, (q15_t *) WeightsQ15_8192 + }; + + /* Initializing the pointer array with the cos factor table base addresses of different lengths */ + q15_t *pCosFactor[4] = + { (q15_t *) cos_factorsQ15_128, (q15_t *) cos_factorsQ15_512, + (q15_t *) cos_factorsQ15_2048, (q15_t *) cos_factorsQ15_8192 + }; + + /* Initialize the DCT4 length */ + S->N = N; + + /* Initialize the half of DCT4 length */ + S->Nby2 = Nby2; + + /* Initialize the DCT4 Normalizing factor */ + S->normalize = normalize; + + /* Initialize Real FFT Instance */ + S->pRfft = S_RFFT; + + /* Initialize Complex FFT Instance */ + S->pCfft = S_CFFT; + + switch (N) + { + /* Initialize the table modifier values */ + case 8192U: + S->pTwiddle = twiddlePtr[3]; + S->pCosFactor = pCosFactor[3]; + break; + case 2048U: + S->pTwiddle = twiddlePtr[2]; + S->pCosFactor = pCosFactor[2]; + break; + case 512U: + S->pTwiddle = twiddlePtr[1]; + S->pCosFactor = pCosFactor[1]; + break; + case 128U: + S->pTwiddle = twiddlePtr[0]; + S->pCosFactor = pCosFactor[0]; + break; + default: + status = ARM_MATH_ARGUMENT_ERROR; + } + + /* Initialize the RFFT/RIFFT */ + arm_rfft_init_q15(S->pRfft, S->N, 0U, 1U); + + /* return the status of DCT4 Init function */ + return (status); +} + +/** + * @} end of DCT4_IDCT4 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q31.c new file mode 100644 index 0000000..5873a33 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_init_q31.c @@ -0,0 +1,7686 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dct4_init_q31.c + * Description: Initialization function of DCT-4 & IDCT4 Q31 + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup DCT4_IDCT4 + */ + +/** + * @addtogroup DCT4_IDCT4_Table DCT Type IV Tables + * @{ + */ + +/* +* @brief Weights Table +*/ + +/** + * \par + * Weights tables are generated using the formula :
weights[n] = e^(-j*n*pi/(2*N))
+ * \par + * C command to generate the table + *
+ * for(i = 0; i< N; i++)
+ * {
+ *   weights[2*i]= cos(i*c);
+ *   weights[(2*i)+1]= -sin(i * c);
+ * } 
+ * \par + * where N is the Number of weights to be calculated and c is pi/(2*N) + * \par + * Convert the output to q31 format by multiplying with 2^31 and saturated if required. + * \par + * In the tables below the real and imaginary values are placed alternatively, hence the + * array length is 2*N. + */ + +static const q31_t WeightsQ31_128[256] = { + (q31_t)0x7fffffff, (q31_t)0x00000000, (q31_t)0x7ffd885a, (q31_t)0xfe6de2e0, (q31_t)0x7ff62182, (q31_t)0xfcdbd541, (q31_t)0x7fe9cbc0, (q31_t)0xfb49e6a3, + (q31_t)0x7fd8878e, (q31_t)0xf9b82684, (q31_t)0x7fc25596, (q31_t)0xf826a462, (q31_t)0x7fa736b4, (q31_t)0xf6956fb7, (q31_t)0x7f872bf3, (q31_t)0xf50497fb, + (q31_t)0x7f62368f, (q31_t)0xf3742ca2, (q31_t)0x7f3857f6, (q31_t)0xf1e43d1c, (q31_t)0x7f0991c4, (q31_t)0xf054d8d5, (q31_t)0x7ed5e5c6, (q31_t)0xeec60f31, + (q31_t)0x7e9d55fc, (q31_t)0xed37ef91, (q31_t)0x7e5fe493, (q31_t)0xebaa894f, (q31_t)0x7e1d93ea, (q31_t)0xea1debbb, (q31_t)0x7dd6668f, (q31_t)0xe8922622, + (q31_t)0x7d8a5f40, (q31_t)0xe70747c4, (q31_t)0x7d3980ec, (q31_t)0xe57d5fda, (q31_t)0x7ce3ceb2, (q31_t)0xe3f47d96, (q31_t)0x7c894bde, (q31_t)0xe26cb01b, + (q31_t)0x7c29fbee, (q31_t)0xe0e60685, (q31_t)0x7bc5e290, (q31_t)0xdf608fe4, (q31_t)0x7b5d039e, (q31_t)0xdddc5b3b, (q31_t)0x7aef6323, (q31_t)0xdc597781, + (q31_t)0x7a7d055b, (q31_t)0xdad7f3a2, (q31_t)0x7a05eead, (q31_t)0xd957de7a, (q31_t)0x798a23b1, (q31_t)0xd7d946d8, (q31_t)0x7909a92d, (q31_t)0xd65c3b7b, + (q31_t)0x78848414, (q31_t)0xd4e0cb15, (q31_t)0x77fab989, (q31_t)0xd3670446, (q31_t)0x776c4edb, (q31_t)0xd1eef59e, (q31_t)0x76d94989, (q31_t)0xd078ad9e, + (q31_t)0x7641af3d, (q31_t)0xcf043ab3, (q31_t)0x75a585cf, (q31_t)0xcd91ab39, (q31_t)0x7504d345, (q31_t)0xcc210d79, (q31_t)0x745f9dd1, (q31_t)0xcab26fa9, + (q31_t)0x73b5ebd1, (q31_t)0xc945dfec, (q31_t)0x7307c3d0, (q31_t)0xc7db6c50, (q31_t)0x72552c85, (q31_t)0xc67322ce, (q31_t)0x719e2cd2, (q31_t)0xc50d1149, + (q31_t)0x70e2cbc6, (q31_t)0xc3a94590, (q31_t)0x7023109a, (q31_t)0xc247cd5a, (q31_t)0x6f5f02b2, (q31_t)0xc0e8b648, (q31_t)0x6e96a99d, (q31_t)0xbf8c0de3, + (q31_t)0x6dca0d14, (q31_t)0xbe31e19b, (q31_t)0x6cf934fc, (q31_t)0xbcda3ecb, (q31_t)0x6c242960, (q31_t)0xbb8532b0, (q31_t)0x6b4af279, (q31_t)0xba32ca71, + (q31_t)0x6a6d98a4, (q31_t)0xb8e31319, (q31_t)0x698c246c, (q31_t)0xb796199b, (q31_t)0x68a69e81, (q31_t)0xb64beacd, (q31_t)0x67bd0fbd, (q31_t)0xb5049368, + (q31_t)0x66cf8120, (q31_t)0xb3c0200c, (q31_t)0x65ddfbd3, (q31_t)0xb27e9d3c, (q31_t)0x64e88926, (q31_t)0xb140175b, (q31_t)0x63ef3290, (q31_t)0xb0049ab3, + (q31_t)0x62f201ac, (q31_t)0xaecc336c, (q31_t)0x61f1003f, (q31_t)0xad96ed92, (q31_t)0x60ec3830, (q31_t)0xac64d510, (q31_t)0x5fe3b38d, (q31_t)0xab35f5b5, + (q31_t)0x5ed77c8a, (q31_t)0xaa0a5b2e, (q31_t)0x5dc79d7c, (q31_t)0xa8e21106, (q31_t)0x5cb420e0, (q31_t)0xa7bd22ac, (q31_t)0x5b9d1154, (q31_t)0xa69b9b68, + (q31_t)0x5a82799a, (q31_t)0xa57d8666, (q31_t)0x59646498, (q31_t)0xa462eeac, (q31_t)0x5842dd54, (q31_t)0xa34bdf20, (q31_t)0x571deefa, (q31_t)0xa2386284, + (q31_t)0x55f5a4d2, (q31_t)0xa1288376, (q31_t)0x54ca0a4b, (q31_t)0xa01c4c73, (q31_t)0x539b2af0, (q31_t)0x9f13c7d0, (q31_t)0x5269126e, (q31_t)0x9e0effc1, + (q31_t)0x5133cc94, (q31_t)0x9d0dfe54, (q31_t)0x4ffb654d, (q31_t)0x9c10cd70, (q31_t)0x4ebfe8a5, (q31_t)0x9b1776da, (q31_t)0x4d8162c4, (q31_t)0x9a22042d, + (q31_t)0x4c3fdff4, (q31_t)0x99307ee0, (q31_t)0x4afb6c98, (q31_t)0x9842f043, (q31_t)0x49b41533, (q31_t)0x9759617f, (q31_t)0x4869e665, (q31_t)0x9673db94, + (q31_t)0x471cece7, (q31_t)0x9592675c, (q31_t)0x45cd358f, (q31_t)0x94b50d87, (q31_t)0x447acd50, (q31_t)0x93dbd6a0, (q31_t)0x4325c135, (q31_t)0x9306cb04, + (q31_t)0x41ce1e65, (q31_t)0x9235f2ec, (q31_t)0x4073f21d, (q31_t)0x91695663, (q31_t)0x3f1749b8, (q31_t)0x90a0fd4e, (q31_t)0x3db832a6, (q31_t)0x8fdcef66, + (q31_t)0x3c56ba70, (q31_t)0x8f1d343a, (q31_t)0x3af2eeb7, (q31_t)0x8e61d32e, (q31_t)0x398cdd32, (q31_t)0x8daad37b, (q31_t)0x382493b0, (q31_t)0x8cf83c30, + (q31_t)0x36ba2014, (q31_t)0x8c4a142f, (q31_t)0x354d9057, (q31_t)0x8ba0622f, (q31_t)0x33def287, (q31_t)0x8afb2cbb, (q31_t)0x326e54c7, (q31_t)0x8a5a7a31, + (q31_t)0x30fbc54d, (q31_t)0x89be50c3, (q31_t)0x2f875262, (q31_t)0x8926b677, (q31_t)0x2e110a62, (q31_t)0x8893b125, (q31_t)0x2c98fbba, (q31_t)0x88054677, + (q31_t)0x2b1f34eb, (q31_t)0x877b7bec, (q31_t)0x29a3c485, (q31_t)0x86f656d3, (q31_t)0x2826b928, (q31_t)0x8675dc4f, (q31_t)0x26a82186, (q31_t)0x85fa1153, + (q31_t)0x25280c5e, (q31_t)0x8582faa5, (q31_t)0x23a6887f, (q31_t)0x85109cdd, (q31_t)0x2223a4c5, (q31_t)0x84a2fc62, (q31_t)0x209f701c, (q31_t)0x843a1d70, + (q31_t)0x1f19f97b, (q31_t)0x83d60412, (q31_t)0x1d934fe5, (q31_t)0x8376b422, (q31_t)0x1c0b826a, (q31_t)0x831c314e, (q31_t)0x1a82a026, (q31_t)0x82c67f14, + (q31_t)0x18f8b83c, (q31_t)0x8275a0c0, (q31_t)0x176dd9de, (q31_t)0x82299971, (q31_t)0x15e21445, (q31_t)0x81e26c16, (q31_t)0x145576b1, (q31_t)0x81a01b6d, + (q31_t)0x12c8106f, (q31_t)0x8162aa04, (q31_t)0x1139f0cf, (q31_t)0x812a1a3a, (q31_t)0xfab272b, (q31_t)0x80f66e3c, (q31_t)0xe1bc2e4, (q31_t)0x80c7a80a, + (q31_t)0xc8bd35e, (q31_t)0x809dc971, (q31_t)0xafb6805, (q31_t)0x8078d40d, (q31_t)0x96a9049, (q31_t)0x8058c94c, (q31_t)0x7d95b9e, (q31_t)0x803daa6a, + (q31_t)0x647d97c, (q31_t)0x80277872, (q31_t)0x4b6195d, (q31_t)0x80163440, (q31_t)0x3242abf, (q31_t)0x8009de7e, (q31_t)0x1921d20, (q31_t)0x800277a6 +}; + +static const q31_t WeightsQ31_512[1024] = { + (q31_t)0x7fffffff, (q31_t)0x00000000, (q31_t)0x7fffd886, (q31_t)0xff9b781d, (q31_t)0x7fff6216, (q31_t)0xff36f078, (q31_t)0x7ffe9cb2, (q31_t)0xfed2694f, + (q31_t)0x7ffd885a, (q31_t)0xfe6de2e0, (q31_t)0x7ffc250f, (q31_t)0xfe095d69, (q31_t)0x7ffa72d1, (q31_t)0xfda4d929, (q31_t)0x7ff871a2, (q31_t)0xfd40565c, + (q31_t)0x7ff62182, (q31_t)0xfcdbd541, (q31_t)0x7ff38274, (q31_t)0xfc775616, (q31_t)0x7ff09478, (q31_t)0xfc12d91a, (q31_t)0x7fed5791, (q31_t)0xfbae5e89, + (q31_t)0x7fe9cbc0, (q31_t)0xfb49e6a3, (q31_t)0x7fe5f108, (q31_t)0xfae571a4, (q31_t)0x7fe1c76b, (q31_t)0xfa80ffcb, (q31_t)0x7fdd4eec, (q31_t)0xfa1c9157, + (q31_t)0x7fd8878e, (q31_t)0xf9b82684, (q31_t)0x7fd37153, (q31_t)0xf953bf91, (q31_t)0x7fce0c3e, (q31_t)0xf8ef5cbb, (q31_t)0x7fc85854, (q31_t)0xf88afe42, + (q31_t)0x7fc25596, (q31_t)0xf826a462, (q31_t)0x7fbc040a, (q31_t)0xf7c24f59, (q31_t)0x7fb563b3, (q31_t)0xf75dff66, (q31_t)0x7fae7495, (q31_t)0xf6f9b4c6, + (q31_t)0x7fa736b4, (q31_t)0xf6956fb7, (q31_t)0x7f9faa15, (q31_t)0xf6313077, (q31_t)0x7f97cebd, (q31_t)0xf5ccf743, (q31_t)0x7f8fa4b0, (q31_t)0xf568c45b, + (q31_t)0x7f872bf3, (q31_t)0xf50497fb, (q31_t)0x7f7e648c, (q31_t)0xf4a07261, (q31_t)0x7f754e80, (q31_t)0xf43c53cb, (q31_t)0x7f6be9d4, (q31_t)0xf3d83c77, + (q31_t)0x7f62368f, (q31_t)0xf3742ca2, (q31_t)0x7f5834b7, (q31_t)0xf310248a, (q31_t)0x7f4de451, (q31_t)0xf2ac246e, (q31_t)0x7f434563, (q31_t)0xf2482c8a, + (q31_t)0x7f3857f6, (q31_t)0xf1e43d1c, (q31_t)0x7f2d1c0e, (q31_t)0xf1805662, (q31_t)0x7f2191b4, (q31_t)0xf11c789a, (q31_t)0x7f15b8ee, (q31_t)0xf0b8a401, + (q31_t)0x7f0991c4, (q31_t)0xf054d8d5, (q31_t)0x7efd1c3c, (q31_t)0xeff11753, (q31_t)0x7ef05860, (q31_t)0xef8d5fb8, (q31_t)0x7ee34636, (q31_t)0xef29b243, + (q31_t)0x7ed5e5c6, (q31_t)0xeec60f31, (q31_t)0x7ec8371a, (q31_t)0xee6276bf, (q31_t)0x7eba3a39, (q31_t)0xedfee92b, (q31_t)0x7eabef2c, (q31_t)0xed9b66b2, + (q31_t)0x7e9d55fc, (q31_t)0xed37ef91, (q31_t)0x7e8e6eb2, (q31_t)0xecd48407, (q31_t)0x7e7f3957, (q31_t)0xec71244f, (q31_t)0x7e6fb5f4, (q31_t)0xec0dd0a8, + (q31_t)0x7e5fe493, (q31_t)0xebaa894f, (q31_t)0x7e4fc53e, (q31_t)0xeb474e81, (q31_t)0x7e3f57ff, (q31_t)0xeae4207a, (q31_t)0x7e2e9cdf, (q31_t)0xea80ff7a, + (q31_t)0x7e1d93ea, (q31_t)0xea1debbb, (q31_t)0x7e0c3d29, (q31_t)0xe9bae57d, (q31_t)0x7dfa98a8, (q31_t)0xe957ecfb, (q31_t)0x7de8a670, (q31_t)0xe8f50273, + (q31_t)0x7dd6668f, (q31_t)0xe8922622, (q31_t)0x7dc3d90d, (q31_t)0xe82f5844, (q31_t)0x7db0fdf8, (q31_t)0xe7cc9917, (q31_t)0x7d9dd55a, (q31_t)0xe769e8d8, + (q31_t)0x7d8a5f40, (q31_t)0xe70747c4, (q31_t)0x7d769bb5, (q31_t)0xe6a4b616, (q31_t)0x7d628ac6, (q31_t)0xe642340d, (q31_t)0x7d4e2c7f, (q31_t)0xe5dfc1e5, + (q31_t)0x7d3980ec, (q31_t)0xe57d5fda, (q31_t)0x7d24881b, (q31_t)0xe51b0e2a, (q31_t)0x7d0f4218, (q31_t)0xe4b8cd11, (q31_t)0x7cf9aef0, (q31_t)0xe4569ccb, + (q31_t)0x7ce3ceb2, (q31_t)0xe3f47d96, (q31_t)0x7ccda169, (q31_t)0xe3926fad, (q31_t)0x7cb72724, (q31_t)0xe330734d, (q31_t)0x7ca05ff1, (q31_t)0xe2ce88b3, + (q31_t)0x7c894bde, (q31_t)0xe26cb01b, (q31_t)0x7c71eaf9, (q31_t)0xe20ae9c1, (q31_t)0x7c5a3d50, (q31_t)0xe1a935e2, (q31_t)0x7c4242f2, (q31_t)0xe14794ba, + (q31_t)0x7c29fbee, (q31_t)0xe0e60685, (q31_t)0x7c116853, (q31_t)0xe0848b7f, (q31_t)0x7bf88830, (q31_t)0xe02323e5, (q31_t)0x7bdf5b94, (q31_t)0xdfc1cff3, + (q31_t)0x7bc5e290, (q31_t)0xdf608fe4, (q31_t)0x7bac1d31, (q31_t)0xdeff63f4, (q31_t)0x7b920b89, (q31_t)0xde9e4c60, (q31_t)0x7b77ada8, (q31_t)0xde3d4964, + (q31_t)0x7b5d039e, (q31_t)0xdddc5b3b, (q31_t)0x7b420d7a, (q31_t)0xdd7b8220, (q31_t)0x7b26cb4f, (q31_t)0xdd1abe51, (q31_t)0x7b0b3d2c, (q31_t)0xdcba1008, + (q31_t)0x7aef6323, (q31_t)0xdc597781, (q31_t)0x7ad33d45, (q31_t)0xdbf8f4f8, (q31_t)0x7ab6cba4, (q31_t)0xdb9888a8, (q31_t)0x7a9a0e50, (q31_t)0xdb3832cd, + (q31_t)0x7a7d055b, (q31_t)0xdad7f3a2, (q31_t)0x7a5fb0d8, (q31_t)0xda77cb63, (q31_t)0x7a4210d8, (q31_t)0xda17ba4a, (q31_t)0x7a24256f, (q31_t)0xd9b7c094, + (q31_t)0x7a05eead, (q31_t)0xd957de7a, (q31_t)0x79e76ca7, (q31_t)0xd8f81439, (q31_t)0x79c89f6e, (q31_t)0xd898620c, (q31_t)0x79a98715, (q31_t)0xd838c82d, + (q31_t)0x798a23b1, (q31_t)0xd7d946d8, (q31_t)0x796a7554, (q31_t)0xd779de47, (q31_t)0x794a7c12, (q31_t)0xd71a8eb5, (q31_t)0x792a37fe, (q31_t)0xd6bb585e, + (q31_t)0x7909a92d, (q31_t)0xd65c3b7b, (q31_t)0x78e8cfb2, (q31_t)0xd5fd3848, (q31_t)0x78c7aba2, (q31_t)0xd59e4eff, (q31_t)0x78a63d11, (q31_t)0xd53f7fda, + (q31_t)0x78848414, (q31_t)0xd4e0cb15, (q31_t)0x786280bf, (q31_t)0xd48230e9, (q31_t)0x78403329, (q31_t)0xd423b191, (q31_t)0x781d9b65, (q31_t)0xd3c54d47, + (q31_t)0x77fab989, (q31_t)0xd3670446, (q31_t)0x77d78daa, (q31_t)0xd308d6c7, (q31_t)0x77b417df, (q31_t)0xd2aac504, (q31_t)0x7790583e, (q31_t)0xd24ccf39, + (q31_t)0x776c4edb, (q31_t)0xd1eef59e, (q31_t)0x7747fbce, (q31_t)0xd191386e, (q31_t)0x77235f2d, (q31_t)0xd13397e2, (q31_t)0x76fe790e, (q31_t)0xd0d61434, + (q31_t)0x76d94989, (q31_t)0xd078ad9e, (q31_t)0x76b3d0b4, (q31_t)0xd01b6459, (q31_t)0x768e0ea6, (q31_t)0xcfbe389f, (q31_t)0x76680376, (q31_t)0xcf612aaa, + (q31_t)0x7641af3d, (q31_t)0xcf043ab3, (q31_t)0x761b1211, (q31_t)0xcea768f2, (q31_t)0x75f42c0b, (q31_t)0xce4ab5a2, (q31_t)0x75ccfd42, (q31_t)0xcdee20fc, + (q31_t)0x75a585cf, (q31_t)0xcd91ab39, (q31_t)0x757dc5ca, (q31_t)0xcd355491, (q31_t)0x7555bd4c, (q31_t)0xccd91d3d, (q31_t)0x752d6c6c, (q31_t)0xcc7d0578, + (q31_t)0x7504d345, (q31_t)0xcc210d79, (q31_t)0x74dbf1ef, (q31_t)0xcbc53579, (q31_t)0x74b2c884, (q31_t)0xcb697db0, (q31_t)0x7489571c, (q31_t)0xcb0de658, + (q31_t)0x745f9dd1, (q31_t)0xcab26fa9, (q31_t)0x74359cbd, (q31_t)0xca5719db, (q31_t)0x740b53fb, (q31_t)0xc9fbe527, (q31_t)0x73e0c3a3, (q31_t)0xc9a0d1c5, + (q31_t)0x73b5ebd1, (q31_t)0xc945dfec, (q31_t)0x738acc9e, (q31_t)0xc8eb0fd6, (q31_t)0x735f6626, (q31_t)0xc89061ba, (q31_t)0x7333b883, (q31_t)0xc835d5d0, + (q31_t)0x7307c3d0, (q31_t)0xc7db6c50, (q31_t)0x72db8828, (q31_t)0xc7812572, (q31_t)0x72af05a7, (q31_t)0xc727016d, (q31_t)0x72823c67, (q31_t)0xc6cd0079, + (q31_t)0x72552c85, (q31_t)0xc67322ce, (q31_t)0x7227d61c, (q31_t)0xc61968a2, (q31_t)0x71fa3949, (q31_t)0xc5bfd22e, (q31_t)0x71cc5626, (q31_t)0xc5665fa9, + (q31_t)0x719e2cd2, (q31_t)0xc50d1149, (q31_t)0x716fbd68, (q31_t)0xc4b3e746, (q31_t)0x71410805, (q31_t)0xc45ae1d7, (q31_t)0x71120cc5, (q31_t)0xc4020133, + (q31_t)0x70e2cbc6, (q31_t)0xc3a94590, (q31_t)0x70b34525, (q31_t)0xc350af26, (q31_t)0x708378ff, (q31_t)0xc2f83e2a, (q31_t)0x70536771, (q31_t)0xc29ff2d4, + (q31_t)0x7023109a, (q31_t)0xc247cd5a, (q31_t)0x6ff27497, (q31_t)0xc1efcdf3, (q31_t)0x6fc19385, (q31_t)0xc197f4d4, (q31_t)0x6f906d84, (q31_t)0xc1404233, + (q31_t)0x6f5f02b2, (q31_t)0xc0e8b648, (q31_t)0x6f2d532c, (q31_t)0xc0915148, (q31_t)0x6efb5f12, (q31_t)0xc03a1368, (q31_t)0x6ec92683, (q31_t)0xbfe2fcdf, + (q31_t)0x6e96a99d, (q31_t)0xbf8c0de3, (q31_t)0x6e63e87f, (q31_t)0xbf3546a8, (q31_t)0x6e30e34a, (q31_t)0xbedea765, (q31_t)0x6dfd9a1c, (q31_t)0xbe88304f, + (q31_t)0x6dca0d14, (q31_t)0xbe31e19b, (q31_t)0x6d963c54, (q31_t)0xbddbbb7f, (q31_t)0x6d6227fa, (q31_t)0xbd85be30, (q31_t)0x6d2dd027, (q31_t)0xbd2fe9e2, + (q31_t)0x6cf934fc, (q31_t)0xbcda3ecb, (q31_t)0x6cc45698, (q31_t)0xbc84bd1f, (q31_t)0x6c8f351c, (q31_t)0xbc2f6513, (q31_t)0x6c59d0a9, (q31_t)0xbbda36dd, + (q31_t)0x6c242960, (q31_t)0xbb8532b0, (q31_t)0x6bee3f62, (q31_t)0xbb3058c0, (q31_t)0x6bb812d1, (q31_t)0xbadba943, (q31_t)0x6b81a3cd, (q31_t)0xba87246d, + (q31_t)0x6b4af279, (q31_t)0xba32ca71, (q31_t)0x6b13fef5, (q31_t)0xb9de9b83, (q31_t)0x6adcc964, (q31_t)0xb98a97d8, (q31_t)0x6aa551e9, (q31_t)0xb936bfa4, + (q31_t)0x6a6d98a4, (q31_t)0xb8e31319, (q31_t)0x6a359db9, (q31_t)0xb88f926d, (q31_t)0x69fd614a, (q31_t)0xb83c3dd1, (q31_t)0x69c4e37a, (q31_t)0xb7e9157a, + (q31_t)0x698c246c, (q31_t)0xb796199b, (q31_t)0x69532442, (q31_t)0xb7434a67, (q31_t)0x6919e320, (q31_t)0xb6f0a812, (q31_t)0x68e06129, (q31_t)0xb69e32cd, + (q31_t)0x68a69e81, (q31_t)0xb64beacd, (q31_t)0x686c9b4b, (q31_t)0xb5f9d043, (q31_t)0x683257ab, (q31_t)0xb5a7e362, (q31_t)0x67f7d3c5, (q31_t)0xb556245e, + (q31_t)0x67bd0fbd, (q31_t)0xb5049368, (q31_t)0x67820bb7, (q31_t)0xb4b330b3, (q31_t)0x6746c7d8, (q31_t)0xb461fc70, (q31_t)0x670b4444, (q31_t)0xb410f6d3, + (q31_t)0x66cf8120, (q31_t)0xb3c0200c, (q31_t)0x66937e91, (q31_t)0xb36f784f, (q31_t)0x66573cbb, (q31_t)0xb31effcc, (q31_t)0x661abbc5, (q31_t)0xb2ceb6b5, + (q31_t)0x65ddfbd3, (q31_t)0xb27e9d3c, (q31_t)0x65a0fd0b, (q31_t)0xb22eb392, (q31_t)0x6563bf92, (q31_t)0xb1def9e9, (q31_t)0x6526438f, (q31_t)0xb18f7071, + (q31_t)0x64e88926, (q31_t)0xb140175b, (q31_t)0x64aa907f, (q31_t)0xb0f0eeda, (q31_t)0x646c59bf, (q31_t)0xb0a1f71d, (q31_t)0x642de50d, (q31_t)0xb0533055, + (q31_t)0x63ef3290, (q31_t)0xb0049ab3, (q31_t)0x63b0426d, (q31_t)0xafb63667, (q31_t)0x637114cc, (q31_t)0xaf6803a2, (q31_t)0x6331a9d4, (q31_t)0xaf1a0293, + (q31_t)0x62f201ac, (q31_t)0xaecc336c, (q31_t)0x62b21c7b, (q31_t)0xae7e965b, (q31_t)0x6271fa69, (q31_t)0xae312b92, (q31_t)0x62319b9d, (q31_t)0xade3f33e, + (q31_t)0x61f1003f, (q31_t)0xad96ed92, (q31_t)0x61b02876, (q31_t)0xad4a1aba, (q31_t)0x616f146c, (q31_t)0xacfd7ae8, (q31_t)0x612dc447, (q31_t)0xacb10e4b, + (q31_t)0x60ec3830, (q31_t)0xac64d510, (q31_t)0x60aa7050, (q31_t)0xac18cf69, (q31_t)0x60686ccf, (q31_t)0xabccfd83, (q31_t)0x60262dd6, (q31_t)0xab815f8d, + (q31_t)0x5fe3b38d, (q31_t)0xab35f5b5, (q31_t)0x5fa0fe1f, (q31_t)0xaaeac02c, (q31_t)0x5f5e0db3, (q31_t)0xaa9fbf1e, (q31_t)0x5f1ae274, (q31_t)0xaa54f2ba, + (q31_t)0x5ed77c8a, (q31_t)0xaa0a5b2e, (q31_t)0x5e93dc1f, (q31_t)0xa9bff8a8, (q31_t)0x5e50015d, (q31_t)0xa975cb57, (q31_t)0x5e0bec6e, (q31_t)0xa92bd367, + (q31_t)0x5dc79d7c, (q31_t)0xa8e21106, (q31_t)0x5d8314b1, (q31_t)0xa8988463, (q31_t)0x5d3e5237, (q31_t)0xa84f2daa, (q31_t)0x5cf95638, (q31_t)0xa8060d08, + (q31_t)0x5cb420e0, (q31_t)0xa7bd22ac, (q31_t)0x5c6eb258, (q31_t)0xa7746ec0, (q31_t)0x5c290acc, (q31_t)0xa72bf174, (q31_t)0x5be32a67, (q31_t)0xa6e3aaf2, + (q31_t)0x5b9d1154, (q31_t)0xa69b9b68, (q31_t)0x5b56bfbd, (q31_t)0xa653c303, (q31_t)0x5b1035cf, (q31_t)0xa60c21ee, (q31_t)0x5ac973b5, (q31_t)0xa5c4b855, + (q31_t)0x5a82799a, (q31_t)0xa57d8666, (q31_t)0x5a3b47ab, (q31_t)0xa5368c4b, (q31_t)0x59f3de12, (q31_t)0xa4efca31, (q31_t)0x59ac3cfd, (q31_t)0xa4a94043, + (q31_t)0x59646498, (q31_t)0xa462eeac, (q31_t)0x591c550e, (q31_t)0xa41cd599, (q31_t)0x58d40e8c, (q31_t)0xa3d6f534, (q31_t)0x588b9140, (q31_t)0xa3914da8, + (q31_t)0x5842dd54, (q31_t)0xa34bdf20, (q31_t)0x57f9f2f8, (q31_t)0xa306a9c8, (q31_t)0x57b0d256, (q31_t)0xa2c1adc9, (q31_t)0x57677b9d, (q31_t)0xa27ceb4f, + (q31_t)0x571deefa, (q31_t)0xa2386284, (q31_t)0x56d42c99, (q31_t)0xa1f41392, (q31_t)0x568a34a9, (q31_t)0xa1affea3, (q31_t)0x56400758, (q31_t)0xa16c23e1, + (q31_t)0x55f5a4d2, (q31_t)0xa1288376, (q31_t)0x55ab0d46, (q31_t)0xa0e51d8c, (q31_t)0x556040e2, (q31_t)0xa0a1f24d, (q31_t)0x55153fd4, (q31_t)0xa05f01e1, + (q31_t)0x54ca0a4b, (q31_t)0xa01c4c73, (q31_t)0x547ea073, (q31_t)0x9fd9d22a, (q31_t)0x5433027d, (q31_t)0x9f979331, (q31_t)0x53e73097, (q31_t)0x9f558fb0, + (q31_t)0x539b2af0, (q31_t)0x9f13c7d0, (q31_t)0x534ef1b5, (q31_t)0x9ed23bb9, (q31_t)0x53028518, (q31_t)0x9e90eb94, (q31_t)0x52b5e546, (q31_t)0x9e4fd78a, + (q31_t)0x5269126e, (q31_t)0x9e0effc1, (q31_t)0x521c0cc2, (q31_t)0x9dce6463, (q31_t)0x51ced46e, (q31_t)0x9d8e0597, (q31_t)0x518169a5, (q31_t)0x9d4de385, + (q31_t)0x5133cc94, (q31_t)0x9d0dfe54, (q31_t)0x50e5fd6d, (q31_t)0x9cce562c, (q31_t)0x5097fc5e, (q31_t)0x9c8eeb34, (q31_t)0x5049c999, (q31_t)0x9c4fbd93, + (q31_t)0x4ffb654d, (q31_t)0x9c10cd70, (q31_t)0x4faccfab, (q31_t)0x9bd21af3, (q31_t)0x4f5e08e3, (q31_t)0x9b93a641, (q31_t)0x4f0f1126, (q31_t)0x9b556f81, + (q31_t)0x4ebfe8a5, (q31_t)0x9b1776da, (q31_t)0x4e708f8f, (q31_t)0x9ad9bc71, (q31_t)0x4e210617, (q31_t)0x9a9c406e, (q31_t)0x4dd14c6e, (q31_t)0x9a5f02f5, + (q31_t)0x4d8162c4, (q31_t)0x9a22042d, (q31_t)0x4d31494b, (q31_t)0x99e5443b, (q31_t)0x4ce10034, (q31_t)0x99a8c345, (q31_t)0x4c9087b1, (q31_t)0x996c816f, + (q31_t)0x4c3fdff4, (q31_t)0x99307ee0, (q31_t)0x4bef092d, (q31_t)0x98f4bbbc, (q31_t)0x4b9e0390, (q31_t)0x98b93828, (q31_t)0x4b4ccf4d, (q31_t)0x987df449, + (q31_t)0x4afb6c98, (q31_t)0x9842f043, (q31_t)0x4aa9dba2, (q31_t)0x98082c3b, (q31_t)0x4a581c9e, (q31_t)0x97cda855, (q31_t)0x4a062fbd, (q31_t)0x979364b5, + (q31_t)0x49b41533, (q31_t)0x9759617f, (q31_t)0x4961cd33, (q31_t)0x971f9ed7, (q31_t)0x490f57ee, (q31_t)0x96e61ce0, (q31_t)0x48bcb599, (q31_t)0x96acdbbe, + (q31_t)0x4869e665, (q31_t)0x9673db94, (q31_t)0x4816ea86, (q31_t)0x963b1c86, (q31_t)0x47c3c22f, (q31_t)0x96029eb6, (q31_t)0x47706d93, (q31_t)0x95ca6247, + (q31_t)0x471cece7, (q31_t)0x9592675c, (q31_t)0x46c9405c, (q31_t)0x955aae17, (q31_t)0x46756828, (q31_t)0x9523369c, (q31_t)0x4621647d, (q31_t)0x94ec010b, + (q31_t)0x45cd358f, (q31_t)0x94b50d87, (q31_t)0x4578db93, (q31_t)0x947e5c33, (q31_t)0x452456bd, (q31_t)0x9447ed2f, (q31_t)0x44cfa740, (q31_t)0x9411c09e, + (q31_t)0x447acd50, (q31_t)0x93dbd6a0, (q31_t)0x4425c923, (q31_t)0x93a62f57, (q31_t)0x43d09aed, (q31_t)0x9370cae4, (q31_t)0x437b42e1, (q31_t)0x933ba968, + (q31_t)0x4325c135, (q31_t)0x9306cb04, (q31_t)0x42d0161e, (q31_t)0x92d22fd9, (q31_t)0x427a41d0, (q31_t)0x929dd806, (q31_t)0x42244481, (q31_t)0x9269c3ac, + (q31_t)0x41ce1e65, (q31_t)0x9235f2ec, (q31_t)0x4177cfb1, (q31_t)0x920265e4, (q31_t)0x4121589b, (q31_t)0x91cf1cb6, (q31_t)0x40cab958, (q31_t)0x919c1781, + (q31_t)0x4073f21d, (q31_t)0x91695663, (q31_t)0x401d0321, (q31_t)0x9136d97d, (q31_t)0x3fc5ec98, (q31_t)0x9104a0ee, (q31_t)0x3f6eaeb8, (q31_t)0x90d2acd4, + (q31_t)0x3f1749b8, (q31_t)0x90a0fd4e, (q31_t)0x3ebfbdcd, (q31_t)0x906f927c, (q31_t)0x3e680b2c, (q31_t)0x903e6c7b, (q31_t)0x3e10320d, (q31_t)0x900d8b69, + (q31_t)0x3db832a6, (q31_t)0x8fdcef66, (q31_t)0x3d600d2c, (q31_t)0x8fac988f, (q31_t)0x3d07c1d6, (q31_t)0x8f7c8701, (q31_t)0x3caf50da, (q31_t)0x8f4cbadb, + (q31_t)0x3c56ba70, (q31_t)0x8f1d343a, (q31_t)0x3bfdfecd, (q31_t)0x8eedf33b, (q31_t)0x3ba51e29, (q31_t)0x8ebef7fb, (q31_t)0x3b4c18ba, (q31_t)0x8e904298, + (q31_t)0x3af2eeb7, (q31_t)0x8e61d32e, (q31_t)0x3a99a057, (q31_t)0x8e33a9da, (q31_t)0x3a402dd2, (q31_t)0x8e05c6b7, (q31_t)0x39e6975e, (q31_t)0x8dd829e4, + (q31_t)0x398cdd32, (q31_t)0x8daad37b, (q31_t)0x3932ff87, (q31_t)0x8d7dc399, (q31_t)0x38d8fe93, (q31_t)0x8d50fa59, (q31_t)0x387eda8e, (q31_t)0x8d2477d8, + (q31_t)0x382493b0, (q31_t)0x8cf83c30, (q31_t)0x37ca2a30, (q31_t)0x8ccc477d, (q31_t)0x376f9e46, (q31_t)0x8ca099da, (q31_t)0x3714f02a, (q31_t)0x8c753362, + (q31_t)0x36ba2014, (q31_t)0x8c4a142f, (q31_t)0x365f2e3b, (q31_t)0x8c1f3c5d, (q31_t)0x36041ad9, (q31_t)0x8bf4ac05, (q31_t)0x35a8e625, (q31_t)0x8bca6343, + (q31_t)0x354d9057, (q31_t)0x8ba0622f, (q31_t)0x34f219a8, (q31_t)0x8b76a8e4, (q31_t)0x34968250, (q31_t)0x8b4d377c, (q31_t)0x343aca87, (q31_t)0x8b240e11, + (q31_t)0x33def287, (q31_t)0x8afb2cbb, (q31_t)0x3382fa88, (q31_t)0x8ad29394, (q31_t)0x3326e2c3, (q31_t)0x8aaa42b4, (q31_t)0x32caab6f, (q31_t)0x8a823a36, + (q31_t)0x326e54c7, (q31_t)0x8a5a7a31, (q31_t)0x3211df04, (q31_t)0x8a3302be, (q31_t)0x31b54a5e, (q31_t)0x8a0bd3f5, (q31_t)0x3158970e, (q31_t)0x89e4edef, + (q31_t)0x30fbc54d, (q31_t)0x89be50c3, (q31_t)0x309ed556, (q31_t)0x8997fc8a, (q31_t)0x3041c761, (q31_t)0x8971f15a, (q31_t)0x2fe49ba7, (q31_t)0x894c2f4c, + (q31_t)0x2f875262, (q31_t)0x8926b677, (q31_t)0x2f29ebcc, (q31_t)0x890186f2, (q31_t)0x2ecc681e, (q31_t)0x88dca0d3, (q31_t)0x2e6ec792, (q31_t)0x88b80432, + (q31_t)0x2e110a62, (q31_t)0x8893b125, (q31_t)0x2db330c7, (q31_t)0x886fa7c2, (q31_t)0x2d553afc, (q31_t)0x884be821, (q31_t)0x2cf72939, (q31_t)0x88287256, + (q31_t)0x2c98fbba, (q31_t)0x88054677, (q31_t)0x2c3ab2b9, (q31_t)0x87e2649b, (q31_t)0x2bdc4e6f, (q31_t)0x87bfccd7, (q31_t)0x2b7dcf17, (q31_t)0x879d7f41, + (q31_t)0x2b1f34eb, (q31_t)0x877b7bec, (q31_t)0x2ac08026, (q31_t)0x8759c2ef, (q31_t)0x2a61b101, (q31_t)0x8738545e, (q31_t)0x2a02c7b8, (q31_t)0x8717304e, + (q31_t)0x29a3c485, (q31_t)0x86f656d3, (q31_t)0x2944a7a2, (q31_t)0x86d5c802, (q31_t)0x28e5714b, (q31_t)0x86b583ee, (q31_t)0x288621b9, (q31_t)0x86958aac, + (q31_t)0x2826b928, (q31_t)0x8675dc4f, (q31_t)0x27c737d3, (q31_t)0x865678eb, (q31_t)0x27679df4, (q31_t)0x86376092, (q31_t)0x2707ebc7, (q31_t)0x86189359, + (q31_t)0x26a82186, (q31_t)0x85fa1153, (q31_t)0x26483f6c, (q31_t)0x85dbda91, (q31_t)0x25e845b6, (q31_t)0x85bdef28, (q31_t)0x2588349d, (q31_t)0x85a04f28, + (q31_t)0x25280c5e, (q31_t)0x8582faa5, (q31_t)0x24c7cd33, (q31_t)0x8565f1b0, (q31_t)0x24677758, (q31_t)0x8549345c, (q31_t)0x24070b08, (q31_t)0x852cc2bb, + (q31_t)0x23a6887f, (q31_t)0x85109cdd, (q31_t)0x2345eff8, (q31_t)0x84f4c2d4, (q31_t)0x22e541af, (q31_t)0x84d934b1, (q31_t)0x22847de0, (q31_t)0x84bdf286, + (q31_t)0x2223a4c5, (q31_t)0x84a2fc62, (q31_t)0x21c2b69c, (q31_t)0x84885258, (q31_t)0x2161b3a0, (q31_t)0x846df477, (q31_t)0x21009c0c, (q31_t)0x8453e2cf, + (q31_t)0x209f701c, (q31_t)0x843a1d70, (q31_t)0x203e300d, (q31_t)0x8420a46c, (q31_t)0x1fdcdc1b, (q31_t)0x840777d0, (q31_t)0x1f7b7481, (q31_t)0x83ee97ad, + (q31_t)0x1f19f97b, (q31_t)0x83d60412, (q31_t)0x1eb86b46, (q31_t)0x83bdbd0e, (q31_t)0x1e56ca1e, (q31_t)0x83a5c2b0, (q31_t)0x1df5163f, (q31_t)0x838e1507, + (q31_t)0x1d934fe5, (q31_t)0x8376b422, (q31_t)0x1d31774d, (q31_t)0x835fa00f, (q31_t)0x1ccf8cb3, (q31_t)0x8348d8dc, (q31_t)0x1c6d9053, (q31_t)0x83325e97, + (q31_t)0x1c0b826a, (q31_t)0x831c314e, (q31_t)0x1ba96335, (q31_t)0x83065110, (q31_t)0x1b4732ef, (q31_t)0x82f0bde8, (q31_t)0x1ae4f1d6, (q31_t)0x82db77e5, + (q31_t)0x1a82a026, (q31_t)0x82c67f14, (q31_t)0x1a203e1b, (q31_t)0x82b1d381, (q31_t)0x19bdcbf3, (q31_t)0x829d753a, (q31_t)0x195b49ea, (q31_t)0x8289644b, + (q31_t)0x18f8b83c, (q31_t)0x8275a0c0, (q31_t)0x18961728, (q31_t)0x82622aa6, (q31_t)0x183366e9, (q31_t)0x824f0208, (q31_t)0x17d0a7bc, (q31_t)0x823c26f3, + (q31_t)0x176dd9de, (q31_t)0x82299971, (q31_t)0x170afd8d, (q31_t)0x82175990, (q31_t)0x16a81305, (q31_t)0x82056758, (q31_t)0x16451a83, (q31_t)0x81f3c2d7, + (q31_t)0x15e21445, (q31_t)0x81e26c16, (q31_t)0x157f0086, (q31_t)0x81d16321, (q31_t)0x151bdf86, (q31_t)0x81c0a801, (q31_t)0x14b8b17f, (q31_t)0x81b03ac2, + (q31_t)0x145576b1, (q31_t)0x81a01b6d, (q31_t)0x13f22f58, (q31_t)0x81904a0c, (q31_t)0x138edbb1, (q31_t)0x8180c6a9, (q31_t)0x132b7bf9, (q31_t)0x8171914e, + (q31_t)0x12c8106f, (q31_t)0x8162aa04, (q31_t)0x1264994e, (q31_t)0x815410d4, (q31_t)0x120116d5, (q31_t)0x8145c5c7, (q31_t)0x119d8941, (q31_t)0x8137c8e6, + (q31_t)0x1139f0cf, (q31_t)0x812a1a3a, (q31_t)0x10d64dbd, (q31_t)0x811cb9ca, (q31_t)0x1072a048, (q31_t)0x810fa7a0, (q31_t)0x100ee8ad, (q31_t)0x8102e3c4, + (q31_t)0xfab272b, (q31_t)0x80f66e3c, (q31_t)0xf475bff, (q31_t)0x80ea4712, (q31_t)0xee38766, (q31_t)0x80de6e4c, (q31_t)0xe7fa99e, (q31_t)0x80d2e3f2, + (q31_t)0xe1bc2e4, (q31_t)0x80c7a80a, (q31_t)0xdb7d376, (q31_t)0x80bcba9d, (q31_t)0xd53db92, (q31_t)0x80b21baf, (q31_t)0xcefdb76, (q31_t)0x80a7cb49, + (q31_t)0xc8bd35e, (q31_t)0x809dc971, (q31_t)0xc27c389, (q31_t)0x8094162c, (q31_t)0xbc3ac35, (q31_t)0x808ab180, (q31_t)0xb5f8d9f, (q31_t)0x80819b74, + (q31_t)0xafb6805, (q31_t)0x8078d40d, (q31_t)0xa973ba5, (q31_t)0x80705b50, (q31_t)0xa3308bd, (q31_t)0x80683143, (q31_t)0x9cecf89, (q31_t)0x806055eb, + (q31_t)0x96a9049, (q31_t)0x8058c94c, (q31_t)0x9064b3a, (q31_t)0x80518b6b, (q31_t)0x8a2009a, (q31_t)0x804a9c4d, (q31_t)0x83db0a7, (q31_t)0x8043fbf6, + (q31_t)0x7d95b9e, (q31_t)0x803daa6a, (q31_t)0x77501be, (q31_t)0x8037a7ac, (q31_t)0x710a345, (q31_t)0x8031f3c2, (q31_t)0x6ac406f, (q31_t)0x802c8ead, + (q31_t)0x647d97c, (q31_t)0x80277872, (q31_t)0x5e36ea9, (q31_t)0x8022b114, (q31_t)0x57f0035, (q31_t)0x801e3895, (q31_t)0x51a8e5c, (q31_t)0x801a0ef8, + (q31_t)0x4b6195d, (q31_t)0x80163440, (q31_t)0x451a177, (q31_t)0x8012a86f, (q31_t)0x3ed26e6, (q31_t)0x800f6b88, (q31_t)0x388a9ea, (q31_t)0x800c7d8c, + (q31_t)0x3242abf, (q31_t)0x8009de7e, (q31_t)0x2bfa9a4, (q31_t)0x80078e5e, (q31_t)0x25b26d7, (q31_t)0x80058d2f, (q31_t)0x1f6a297, (q31_t)0x8003daf1, + (q31_t)0x1921d20, (q31_t)0x800277a6, (q31_t)0x12d96b1, (q31_t)0x8001634e, (q31_t)0xc90f88, (q31_t)0x80009dea, (q31_t)0x6487e3, (q31_t)0x8000277a +}; + +static const q31_t WeightsQ31_2048[4096] = { + (q31_t)0x7fffffff, (q31_t)0x00000000, (q31_t)0x7ffffd88, (q31_t)0xffe6de05, (q31_t)0x7ffff621, (q31_t)0xffcdbc0b, (q31_t)0x7fffe9cb, (q31_t)0xffb49a12, + (q31_t)0x7fffd886, (q31_t)0xff9b781d, (q31_t)0x7fffc251, (q31_t)0xff82562c, (q31_t)0x7fffa72c, (q31_t)0xff69343f, (q31_t)0x7fff8719, (q31_t)0xff501258, + (q31_t)0x7fff6216, (q31_t)0xff36f078, (q31_t)0x7fff3824, (q31_t)0xff1dcea0, (q31_t)0x7fff0943, (q31_t)0xff04acd0, (q31_t)0x7ffed572, (q31_t)0xfeeb8b0a, + (q31_t)0x7ffe9cb2, (q31_t)0xfed2694f, (q31_t)0x7ffe5f03, (q31_t)0xfeb947a0, (q31_t)0x7ffe1c65, (q31_t)0xfea025fd, (q31_t)0x7ffdd4d7, (q31_t)0xfe870467, + (q31_t)0x7ffd885a, (q31_t)0xfe6de2e0, (q31_t)0x7ffd36ee, (q31_t)0xfe54c169, (q31_t)0x7ffce093, (q31_t)0xfe3ba002, (q31_t)0x7ffc8549, (q31_t)0xfe227eac, + (q31_t)0x7ffc250f, (q31_t)0xfe095d69, (q31_t)0x7ffbbfe6, (q31_t)0xfdf03c3a, (q31_t)0x7ffb55ce, (q31_t)0xfdd71b1e, (q31_t)0x7ffae6c7, (q31_t)0xfdbdfa18, + (q31_t)0x7ffa72d1, (q31_t)0xfda4d929, (q31_t)0x7ff9f9ec, (q31_t)0xfd8bb850, (q31_t)0x7ff97c18, (q31_t)0xfd729790, (q31_t)0x7ff8f954, (q31_t)0xfd5976e9, + (q31_t)0x7ff871a2, (q31_t)0xfd40565c, (q31_t)0x7ff7e500, (q31_t)0xfd2735ea, (q31_t)0x7ff75370, (q31_t)0xfd0e1594, (q31_t)0x7ff6bcf0, (q31_t)0xfcf4f55c, + (q31_t)0x7ff62182, (q31_t)0xfcdbd541, (q31_t)0x7ff58125, (q31_t)0xfcc2b545, (q31_t)0x7ff4dbd9, (q31_t)0xfca9956a, (q31_t)0x7ff4319d, (q31_t)0xfc9075af, + (q31_t)0x7ff38274, (q31_t)0xfc775616, (q31_t)0x7ff2ce5b, (q31_t)0xfc5e36a0, (q31_t)0x7ff21553, (q31_t)0xfc45174e, (q31_t)0x7ff1575d, (q31_t)0xfc2bf821, + (q31_t)0x7ff09478, (q31_t)0xfc12d91a, (q31_t)0x7fefcca4, (q31_t)0xfbf9ba39, (q31_t)0x7feeffe1, (q31_t)0xfbe09b80, (q31_t)0x7fee2e30, (q31_t)0xfbc77cf0, + (q31_t)0x7fed5791, (q31_t)0xfbae5e89, (q31_t)0x7fec7c02, (q31_t)0xfb95404d, (q31_t)0x7feb9b85, (q31_t)0xfb7c223d, (q31_t)0x7feab61a, (q31_t)0xfb630459, + (q31_t)0x7fe9cbc0, (q31_t)0xfb49e6a3, (q31_t)0x7fe8dc78, (q31_t)0xfb30c91b, (q31_t)0x7fe7e841, (q31_t)0xfb17abc2, (q31_t)0x7fe6ef1c, (q31_t)0xfafe8e9b, + (q31_t)0x7fe5f108, (q31_t)0xfae571a4, (q31_t)0x7fe4ee06, (q31_t)0xfacc54e0, (q31_t)0x7fe3e616, (q31_t)0xfab3384f, (q31_t)0x7fe2d938, (q31_t)0xfa9a1bf3, + (q31_t)0x7fe1c76b, (q31_t)0xfa80ffcb, (q31_t)0x7fe0b0b1, (q31_t)0xfa67e3da, (q31_t)0x7fdf9508, (q31_t)0xfa4ec821, (q31_t)0x7fde7471, (q31_t)0xfa35ac9f, + (q31_t)0x7fdd4eec, (q31_t)0xfa1c9157, (q31_t)0x7fdc247a, (q31_t)0xfa037648, (q31_t)0x7fdaf519, (q31_t)0xf9ea5b75, (q31_t)0x7fd9c0ca, (q31_t)0xf9d140de, + (q31_t)0x7fd8878e, (q31_t)0xf9b82684, (q31_t)0x7fd74964, (q31_t)0xf99f0c68, (q31_t)0x7fd6064c, (q31_t)0xf985f28a, (q31_t)0x7fd4be46, (q31_t)0xf96cd8ed, + (q31_t)0x7fd37153, (q31_t)0xf953bf91, (q31_t)0x7fd21f72, (q31_t)0xf93aa676, (q31_t)0x7fd0c8a3, (q31_t)0xf9218d9e, (q31_t)0x7fcf6ce8, (q31_t)0xf908750a, + (q31_t)0x7fce0c3e, (q31_t)0xf8ef5cbb, (q31_t)0x7fcca6a7, (q31_t)0xf8d644b2, (q31_t)0x7fcb3c23, (q31_t)0xf8bd2cef, (q31_t)0x7fc9ccb2, (q31_t)0xf8a41574, + (q31_t)0x7fc85854, (q31_t)0xf88afe42, (q31_t)0x7fc6df08, (q31_t)0xf871e759, (q31_t)0x7fc560cf, (q31_t)0xf858d0bb, (q31_t)0x7fc3dda9, (q31_t)0xf83fba68, + (q31_t)0x7fc25596, (q31_t)0xf826a462, (q31_t)0x7fc0c896, (q31_t)0xf80d8ea9, (q31_t)0x7fbf36aa, (q31_t)0xf7f4793e, (q31_t)0x7fbd9fd0, (q31_t)0xf7db6423, + (q31_t)0x7fbc040a, (q31_t)0xf7c24f59, (q31_t)0x7fba6357, (q31_t)0xf7a93ae0, (q31_t)0x7fb8bdb8, (q31_t)0xf79026b9, (q31_t)0x7fb7132b, (q31_t)0xf77712e5, + (q31_t)0x7fb563b3, (q31_t)0xf75dff66, (q31_t)0x7fb3af4e, (q31_t)0xf744ec3b, (q31_t)0x7fb1f5fc, (q31_t)0xf72bd967, (q31_t)0x7fb037bf, (q31_t)0xf712c6ea, + (q31_t)0x7fae7495, (q31_t)0xf6f9b4c6, (q31_t)0x7facac7f, (q31_t)0xf6e0a2fa, (q31_t)0x7faadf7c, (q31_t)0xf6c79188, (q31_t)0x7fa90d8e, (q31_t)0xf6ae8071, + (q31_t)0x7fa736b4, (q31_t)0xf6956fb7, (q31_t)0x7fa55aee, (q31_t)0xf67c5f59, (q31_t)0x7fa37a3c, (q31_t)0xf6634f59, (q31_t)0x7fa1949e, (q31_t)0xf64a3fb8, + (q31_t)0x7f9faa15, (q31_t)0xf6313077, (q31_t)0x7f9dbaa0, (q31_t)0xf6182196, (q31_t)0x7f9bc640, (q31_t)0xf5ff1318, (q31_t)0x7f99ccf4, (q31_t)0xf5e604fc, + (q31_t)0x7f97cebd, (q31_t)0xf5ccf743, (q31_t)0x7f95cb9a, (q31_t)0xf5b3e9f0, (q31_t)0x7f93c38c, (q31_t)0xf59add02, (q31_t)0x7f91b694, (q31_t)0xf581d07b, + (q31_t)0x7f8fa4b0, (q31_t)0xf568c45b, (q31_t)0x7f8d8de1, (q31_t)0xf54fb8a4, (q31_t)0x7f8b7227, (q31_t)0xf536ad56, (q31_t)0x7f895182, (q31_t)0xf51da273, + (q31_t)0x7f872bf3, (q31_t)0xf50497fb, (q31_t)0x7f850179, (q31_t)0xf4eb8def, (q31_t)0x7f82d214, (q31_t)0xf4d28451, (q31_t)0x7f809dc5, (q31_t)0xf4b97b21, + (q31_t)0x7f7e648c, (q31_t)0xf4a07261, (q31_t)0x7f7c2668, (q31_t)0xf4876a10, (q31_t)0x7f79e35a, (q31_t)0xf46e6231, (q31_t)0x7f779b62, (q31_t)0xf4555ac5, + (q31_t)0x7f754e80, (q31_t)0xf43c53cb, (q31_t)0x7f72fcb4, (q31_t)0xf4234d45, (q31_t)0x7f70a5fe, (q31_t)0xf40a4735, (q31_t)0x7f6e4a5e, (q31_t)0xf3f1419a, + (q31_t)0x7f6be9d4, (q31_t)0xf3d83c77, (q31_t)0x7f698461, (q31_t)0xf3bf37cb, (q31_t)0x7f671a05, (q31_t)0xf3a63398, (q31_t)0x7f64aabf, (q31_t)0xf38d2fe0, + (q31_t)0x7f62368f, (q31_t)0xf3742ca2, (q31_t)0x7f5fbd77, (q31_t)0xf35b29e0, (q31_t)0x7f5d3f75, (q31_t)0xf342279b, (q31_t)0x7f5abc8a, (q31_t)0xf32925d3, + (q31_t)0x7f5834b7, (q31_t)0xf310248a, (q31_t)0x7f55a7fa, (q31_t)0xf2f723c1, (q31_t)0x7f531655, (q31_t)0xf2de2379, (q31_t)0x7f507fc7, (q31_t)0xf2c523b2, + (q31_t)0x7f4de451, (q31_t)0xf2ac246e, (q31_t)0x7f4b43f2, (q31_t)0xf29325ad, (q31_t)0x7f489eaa, (q31_t)0xf27a2771, (q31_t)0x7f45f47b, (q31_t)0xf26129ba, + (q31_t)0x7f434563, (q31_t)0xf2482c8a, (q31_t)0x7f409164, (q31_t)0xf22f2fe1, (q31_t)0x7f3dd87c, (q31_t)0xf21633c0, (q31_t)0x7f3b1aad, (q31_t)0xf1fd3829, + (q31_t)0x7f3857f6, (q31_t)0xf1e43d1c, (q31_t)0x7f359057, (q31_t)0xf1cb429a, (q31_t)0x7f32c3d1, (q31_t)0xf1b248a5, (q31_t)0x7f2ff263, (q31_t)0xf1994f3d, + (q31_t)0x7f2d1c0e, (q31_t)0xf1805662, (q31_t)0x7f2a40d2, (q31_t)0xf1675e17, (q31_t)0x7f2760af, (q31_t)0xf14e665c, (q31_t)0x7f247ba5, (q31_t)0xf1356f32, + (q31_t)0x7f2191b4, (q31_t)0xf11c789a, (q31_t)0x7f1ea2dc, (q31_t)0xf1038295, (q31_t)0x7f1baf1e, (q31_t)0xf0ea8d24, (q31_t)0x7f18b679, (q31_t)0xf0d19848, + (q31_t)0x7f15b8ee, (q31_t)0xf0b8a401, (q31_t)0x7f12b67c, (q31_t)0xf09fb051, (q31_t)0x7f0faf25, (q31_t)0xf086bd39, (q31_t)0x7f0ca2e7, (q31_t)0xf06dcaba, + (q31_t)0x7f0991c4, (q31_t)0xf054d8d5, (q31_t)0x7f067bba, (q31_t)0xf03be78a, (q31_t)0x7f0360cb, (q31_t)0xf022f6da, (q31_t)0x7f0040f6, (q31_t)0xf00a06c8, + (q31_t)0x7efd1c3c, (q31_t)0xeff11753, (q31_t)0x7ef9f29d, (q31_t)0xefd8287c, (q31_t)0x7ef6c418, (q31_t)0xefbf3a45, (q31_t)0x7ef390ae, (q31_t)0xefa64cae, + (q31_t)0x7ef05860, (q31_t)0xef8d5fb8, (q31_t)0x7eed1b2c, (q31_t)0xef747365, (q31_t)0x7ee9d914, (q31_t)0xef5b87b5, (q31_t)0x7ee69217, (q31_t)0xef429caa, + (q31_t)0x7ee34636, (q31_t)0xef29b243, (q31_t)0x7edff570, (q31_t)0xef10c883, (q31_t)0x7edc9fc6, (q31_t)0xeef7df6a, (q31_t)0x7ed94538, (q31_t)0xeedef6f9, + (q31_t)0x7ed5e5c6, (q31_t)0xeec60f31, (q31_t)0x7ed28171, (q31_t)0xeead2813, (q31_t)0x7ecf1837, (q31_t)0xee9441a0, (q31_t)0x7ecbaa1a, (q31_t)0xee7b5bd9, + (q31_t)0x7ec8371a, (q31_t)0xee6276bf, (q31_t)0x7ec4bf36, (q31_t)0xee499253, (q31_t)0x7ec14270, (q31_t)0xee30ae96, (q31_t)0x7ebdc0c6, (q31_t)0xee17cb88, + (q31_t)0x7eba3a39, (q31_t)0xedfee92b, (q31_t)0x7eb6aeca, (q31_t)0xede60780, (q31_t)0x7eb31e78, (q31_t)0xedcd2687, (q31_t)0x7eaf8943, (q31_t)0xedb44642, + (q31_t)0x7eabef2c, (q31_t)0xed9b66b2, (q31_t)0x7ea85033, (q31_t)0xed8287d7, (q31_t)0x7ea4ac58, (q31_t)0xed69a9b3, (q31_t)0x7ea1039b, (q31_t)0xed50cc46, + (q31_t)0x7e9d55fc, (q31_t)0xed37ef91, (q31_t)0x7e99a37c, (q31_t)0xed1f1396, (q31_t)0x7e95ec1a, (q31_t)0xed063856, (q31_t)0x7e922fd6, (q31_t)0xeced5dd0, + (q31_t)0x7e8e6eb2, (q31_t)0xecd48407, (q31_t)0x7e8aa8ac, (q31_t)0xecbbaafb, (q31_t)0x7e86ddc6, (q31_t)0xeca2d2ad, (q31_t)0x7e830dff, (q31_t)0xec89fb1e, + (q31_t)0x7e7f3957, (q31_t)0xec71244f, (q31_t)0x7e7b5fce, (q31_t)0xec584e41, (q31_t)0x7e778166, (q31_t)0xec3f78f6, (q31_t)0x7e739e1d, (q31_t)0xec26a46d, + (q31_t)0x7e6fb5f4, (q31_t)0xec0dd0a8, (q31_t)0x7e6bc8eb, (q31_t)0xebf4fda8, (q31_t)0x7e67d703, (q31_t)0xebdc2b6e, (q31_t)0x7e63e03b, (q31_t)0xebc359fb, + (q31_t)0x7e5fe493, (q31_t)0xebaa894f, (q31_t)0x7e5be40c, (q31_t)0xeb91b96c, (q31_t)0x7e57dea7, (q31_t)0xeb78ea52, (q31_t)0x7e53d462, (q31_t)0xeb601c04, + (q31_t)0x7e4fc53e, (q31_t)0xeb474e81, (q31_t)0x7e4bb13c, (q31_t)0xeb2e81ca, (q31_t)0x7e47985b, (q31_t)0xeb15b5e1, (q31_t)0x7e437a9c, (q31_t)0xeafceac6, + (q31_t)0x7e3f57ff, (q31_t)0xeae4207a, (q31_t)0x7e3b3083, (q31_t)0xeacb56ff, (q31_t)0x7e37042a, (q31_t)0xeab28e56, (q31_t)0x7e32d2f4, (q31_t)0xea99c67e, + (q31_t)0x7e2e9cdf, (q31_t)0xea80ff7a, (q31_t)0x7e2a61ed, (q31_t)0xea683949, (q31_t)0x7e26221f, (q31_t)0xea4f73ee, (q31_t)0x7e21dd73, (q31_t)0xea36af69, + (q31_t)0x7e1d93ea, (q31_t)0xea1debbb, (q31_t)0x7e194584, (q31_t)0xea0528e5, (q31_t)0x7e14f242, (q31_t)0xe9ec66e8, (q31_t)0x7e109a24, (q31_t)0xe9d3a5c5, + (q31_t)0x7e0c3d29, (q31_t)0xe9bae57d, (q31_t)0x7e07db52, (q31_t)0xe9a22610, (q31_t)0x7e0374a0, (q31_t)0xe9896781, (q31_t)0x7dff0911, (q31_t)0xe970a9ce, + (q31_t)0x7dfa98a8, (q31_t)0xe957ecfb, (q31_t)0x7df62362, (q31_t)0xe93f3107, (q31_t)0x7df1a942, (q31_t)0xe92675f4, (q31_t)0x7ded2a47, (q31_t)0xe90dbbc2, + (q31_t)0x7de8a670, (q31_t)0xe8f50273, (q31_t)0x7de41dc0, (q31_t)0xe8dc4a07, (q31_t)0x7ddf9034, (q31_t)0xe8c39280, (q31_t)0x7ddafdce, (q31_t)0xe8aadbde, + (q31_t)0x7dd6668f, (q31_t)0xe8922622, (q31_t)0x7dd1ca75, (q31_t)0xe879714d, (q31_t)0x7dcd2981, (q31_t)0xe860bd61, (q31_t)0x7dc883b4, (q31_t)0xe8480a5d, + (q31_t)0x7dc3d90d, (q31_t)0xe82f5844, (q31_t)0x7dbf298d, (q31_t)0xe816a716, (q31_t)0x7dba7534, (q31_t)0xe7fdf6d4, (q31_t)0x7db5bc02, (q31_t)0xe7e5477f, + (q31_t)0x7db0fdf8, (q31_t)0xe7cc9917, (q31_t)0x7dac3b15, (q31_t)0xe7b3eb9f, (q31_t)0x7da77359, (q31_t)0xe79b3f16, (q31_t)0x7da2a6c6, (q31_t)0xe782937e, + (q31_t)0x7d9dd55a, (q31_t)0xe769e8d8, (q31_t)0x7d98ff17, (q31_t)0xe7513f25, (q31_t)0x7d9423fc, (q31_t)0xe7389665, (q31_t)0x7d8f4409, (q31_t)0xe71fee99, + (q31_t)0x7d8a5f40, (q31_t)0xe70747c4, (q31_t)0x7d85759f, (q31_t)0xe6eea1e4, (q31_t)0x7d808728, (q31_t)0xe6d5fcfc, (q31_t)0x7d7b93da, (q31_t)0xe6bd590d, + (q31_t)0x7d769bb5, (q31_t)0xe6a4b616, (q31_t)0x7d719eba, (q31_t)0xe68c141a, (q31_t)0x7d6c9ce9, (q31_t)0xe6737319, (q31_t)0x7d679642, (q31_t)0xe65ad315, + (q31_t)0x7d628ac6, (q31_t)0xe642340d, (q31_t)0x7d5d7a74, (q31_t)0xe6299604, (q31_t)0x7d58654d, (q31_t)0xe610f8f9, (q31_t)0x7d534b50, (q31_t)0xe5f85cef, + (q31_t)0x7d4e2c7f, (q31_t)0xe5dfc1e5, (q31_t)0x7d4908d9, (q31_t)0xe5c727dd, (q31_t)0x7d43e05e, (q31_t)0xe5ae8ed8, (q31_t)0x7d3eb30f, (q31_t)0xe595f6d7, + (q31_t)0x7d3980ec, (q31_t)0xe57d5fda, (q31_t)0x7d3449f5, (q31_t)0xe564c9e3, (q31_t)0x7d2f0e2b, (q31_t)0xe54c34f3, (q31_t)0x7d29cd8c, (q31_t)0xe533a10a, + (q31_t)0x7d24881b, (q31_t)0xe51b0e2a, (q31_t)0x7d1f3dd6, (q31_t)0xe5027c53, (q31_t)0x7d19eebf, (q31_t)0xe4e9eb87, (q31_t)0x7d149ad5, (q31_t)0xe4d15bc6, + (q31_t)0x7d0f4218, (q31_t)0xe4b8cd11, (q31_t)0x7d09e489, (q31_t)0xe4a03f69, (q31_t)0x7d048228, (q31_t)0xe487b2d0, (q31_t)0x7cff1af5, (q31_t)0xe46f2745, + (q31_t)0x7cf9aef0, (q31_t)0xe4569ccb, (q31_t)0x7cf43e1a, (q31_t)0xe43e1362, (q31_t)0x7ceec873, (q31_t)0xe4258b0a, (q31_t)0x7ce94dfb, (q31_t)0xe40d03c6, + (q31_t)0x7ce3ceb2, (q31_t)0xe3f47d96, (q31_t)0x7cde4a98, (q31_t)0xe3dbf87a, (q31_t)0x7cd8c1ae, (q31_t)0xe3c37474, (q31_t)0x7cd333f3, (q31_t)0xe3aaf184, + (q31_t)0x7ccda169, (q31_t)0xe3926fad, (q31_t)0x7cc80a0f, (q31_t)0xe379eeed, (q31_t)0x7cc26de5, (q31_t)0xe3616f48, (q31_t)0x7cbcccec, (q31_t)0xe348f0bd, + (q31_t)0x7cb72724, (q31_t)0xe330734d, (q31_t)0x7cb17c8d, (q31_t)0xe317f6fa, (q31_t)0x7cabcd28, (q31_t)0xe2ff7bc3, (q31_t)0x7ca618f3, (q31_t)0xe2e701ac, + (q31_t)0x7ca05ff1, (q31_t)0xe2ce88b3, (q31_t)0x7c9aa221, (q31_t)0xe2b610da, (q31_t)0x7c94df83, (q31_t)0xe29d9a23, (q31_t)0x7c8f1817, (q31_t)0xe285248d, + (q31_t)0x7c894bde, (q31_t)0xe26cb01b, (q31_t)0x7c837ad8, (q31_t)0xe2543ccc, (q31_t)0x7c7da505, (q31_t)0xe23bcaa2, (q31_t)0x7c77ca65, (q31_t)0xe223599e, + (q31_t)0x7c71eaf9, (q31_t)0xe20ae9c1, (q31_t)0x7c6c06c0, (q31_t)0xe1f27b0b, (q31_t)0x7c661dbc, (q31_t)0xe1da0d7e, (q31_t)0x7c602fec, (q31_t)0xe1c1a11b, + (q31_t)0x7c5a3d50, (q31_t)0xe1a935e2, (q31_t)0x7c5445e9, (q31_t)0xe190cbd4, (q31_t)0x7c4e49b7, (q31_t)0xe17862f3, (q31_t)0x7c4848ba, (q31_t)0xe15ffb3f, + (q31_t)0x7c4242f2, (q31_t)0xe14794ba, (q31_t)0x7c3c3860, (q31_t)0xe12f2f63, (q31_t)0x7c362904, (q31_t)0xe116cb3d, (q31_t)0x7c3014de, (q31_t)0xe0fe6848, + (q31_t)0x7c29fbee, (q31_t)0xe0e60685, (q31_t)0x7c23de35, (q31_t)0xe0cda5f5, (q31_t)0x7c1dbbb3, (q31_t)0xe0b54698, (q31_t)0x7c179467, (q31_t)0xe09ce871, + (q31_t)0x7c116853, (q31_t)0xe0848b7f, (q31_t)0x7c0b3777, (q31_t)0xe06c2fc4, (q31_t)0x7c0501d2, (q31_t)0xe053d541, (q31_t)0x7bfec765, (q31_t)0xe03b7bf6, + (q31_t)0x7bf88830, (q31_t)0xe02323e5, (q31_t)0x7bf24434, (q31_t)0xe00acd0e, (q31_t)0x7bebfb70, (q31_t)0xdff27773, (q31_t)0x7be5ade6, (q31_t)0xdfda2314, + (q31_t)0x7bdf5b94, (q31_t)0xdfc1cff3, (q31_t)0x7bd9047c, (q31_t)0xdfa97e0f, (q31_t)0x7bd2a89e, (q31_t)0xdf912d6b, (q31_t)0x7bcc47fa, (q31_t)0xdf78de07, + (q31_t)0x7bc5e290, (q31_t)0xdf608fe4, (q31_t)0x7bbf7860, (q31_t)0xdf484302, (q31_t)0x7bb9096b, (q31_t)0xdf2ff764, (q31_t)0x7bb295b0, (q31_t)0xdf17ad0a, + (q31_t)0x7bac1d31, (q31_t)0xdeff63f4, (q31_t)0x7ba59fee, (q31_t)0xdee71c24, (q31_t)0x7b9f1de6, (q31_t)0xdeced59b, (q31_t)0x7b989719, (q31_t)0xdeb69059, + (q31_t)0x7b920b89, (q31_t)0xde9e4c60, (q31_t)0x7b8b7b36, (q31_t)0xde8609b1, (q31_t)0x7b84e61f, (q31_t)0xde6dc84b, (q31_t)0x7b7e4c45, (q31_t)0xde558831, + (q31_t)0x7b77ada8, (q31_t)0xde3d4964, (q31_t)0x7b710a49, (q31_t)0xde250be3, (q31_t)0x7b6a6227, (q31_t)0xde0ccfb1, (q31_t)0x7b63b543, (q31_t)0xddf494ce, + (q31_t)0x7b5d039e, (q31_t)0xdddc5b3b, (q31_t)0x7b564d36, (q31_t)0xddc422f8, (q31_t)0x7b4f920e, (q31_t)0xddabec08, (q31_t)0x7b48d225, (q31_t)0xdd93b66a, + (q31_t)0x7b420d7a, (q31_t)0xdd7b8220, (q31_t)0x7b3b4410, (q31_t)0xdd634f2b, (q31_t)0x7b3475e5, (q31_t)0xdd4b1d8c, (q31_t)0x7b2da2fa, (q31_t)0xdd32ed43, + (q31_t)0x7b26cb4f, (q31_t)0xdd1abe51, (q31_t)0x7b1feee5, (q31_t)0xdd0290b8, (q31_t)0x7b190dbc, (q31_t)0xdcea6478, (q31_t)0x7b1227d3, (q31_t)0xdcd23993, + (q31_t)0x7b0b3d2c, (q31_t)0xdcba1008, (q31_t)0x7b044dc7, (q31_t)0xdca1e7da, (q31_t)0x7afd59a4, (q31_t)0xdc89c109, (q31_t)0x7af660c2, (q31_t)0xdc719b96, + (q31_t)0x7aef6323, (q31_t)0xdc597781, (q31_t)0x7ae860c7, (q31_t)0xdc4154cd, (q31_t)0x7ae159ae, (q31_t)0xdc293379, (q31_t)0x7ada4dd8, (q31_t)0xdc111388, + (q31_t)0x7ad33d45, (q31_t)0xdbf8f4f8, (q31_t)0x7acc27f7, (q31_t)0xdbe0d7cd, (q31_t)0x7ac50dec, (q31_t)0xdbc8bc06, (q31_t)0x7abdef25, (q31_t)0xdbb0a1a4, + (q31_t)0x7ab6cba4, (q31_t)0xdb9888a8, (q31_t)0x7aafa367, (q31_t)0xdb807114, (q31_t)0x7aa8766f, (q31_t)0xdb685ae9, (q31_t)0x7aa144bc, (q31_t)0xdb504626, + (q31_t)0x7a9a0e50, (q31_t)0xdb3832cd, (q31_t)0x7a92d329, (q31_t)0xdb2020e0, (q31_t)0x7a8b9348, (q31_t)0xdb08105e, (q31_t)0x7a844eae, (q31_t)0xdaf00149, + (q31_t)0x7a7d055b, (q31_t)0xdad7f3a2, (q31_t)0x7a75b74f, (q31_t)0xdabfe76a, (q31_t)0x7a6e648a, (q31_t)0xdaa7dca1, (q31_t)0x7a670d0d, (q31_t)0xda8fd349, + (q31_t)0x7a5fb0d8, (q31_t)0xda77cb63, (q31_t)0x7a584feb, (q31_t)0xda5fc4ef, (q31_t)0x7a50ea47, (q31_t)0xda47bfee, (q31_t)0x7a497feb, (q31_t)0xda2fbc61, + (q31_t)0x7a4210d8, (q31_t)0xda17ba4a, (q31_t)0x7a3a9d0f, (q31_t)0xd9ffb9a9, (q31_t)0x7a332490, (q31_t)0xd9e7ba7f, (q31_t)0x7a2ba75a, (q31_t)0xd9cfbccd, + (q31_t)0x7a24256f, (q31_t)0xd9b7c094, (q31_t)0x7a1c9ece, (q31_t)0xd99fc5d4, (q31_t)0x7a151378, (q31_t)0xd987cc90, (q31_t)0x7a0d836d, (q31_t)0xd96fd4c7, + (q31_t)0x7a05eead, (q31_t)0xd957de7a, (q31_t)0x79fe5539, (q31_t)0xd93fe9ab, (q31_t)0x79f6b711, (q31_t)0xd927f65b, (q31_t)0x79ef1436, (q31_t)0xd910048a, + (q31_t)0x79e76ca7, (q31_t)0xd8f81439, (q31_t)0x79dfc064, (q31_t)0xd8e0256a, (q31_t)0x79d80f6f, (q31_t)0xd8c8381d, (q31_t)0x79d059c8, (q31_t)0xd8b04c52, + (q31_t)0x79c89f6e, (q31_t)0xd898620c, (q31_t)0x79c0e062, (q31_t)0xd880794b, (q31_t)0x79b91ca4, (q31_t)0xd868920f, (q31_t)0x79b15435, (q31_t)0xd850ac5a, + (q31_t)0x79a98715, (q31_t)0xd838c82d, (q31_t)0x79a1b545, (q31_t)0xd820e589, (q31_t)0x7999dec4, (q31_t)0xd809046e, (q31_t)0x79920392, (q31_t)0xd7f124dd, + (q31_t)0x798a23b1, (q31_t)0xd7d946d8, (q31_t)0x79823f20, (q31_t)0xd7c16a5f, (q31_t)0x797a55e0, (q31_t)0xd7a98f73, (q31_t)0x797267f2, (q31_t)0xd791b616, + (q31_t)0x796a7554, (q31_t)0xd779de47, (q31_t)0x79627e08, (q31_t)0xd7620808, (q31_t)0x795a820e, (q31_t)0xd74a335b, (q31_t)0x79528167, (q31_t)0xd732603f, + (q31_t)0x794a7c12, (q31_t)0xd71a8eb5, (q31_t)0x79427210, (q31_t)0xd702bec0, (q31_t)0x793a6361, (q31_t)0xd6eaf05f, (q31_t)0x79325006, (q31_t)0xd6d32393, + (q31_t)0x792a37fe, (q31_t)0xd6bb585e, (q31_t)0x79221b4b, (q31_t)0xd6a38ec0, (q31_t)0x7919f9ec, (q31_t)0xd68bc6ba, (q31_t)0x7911d3e2, (q31_t)0xd674004e, + (q31_t)0x7909a92d, (q31_t)0xd65c3b7b, (q31_t)0x790179cd, (q31_t)0xd6447844, (q31_t)0x78f945c3, (q31_t)0xd62cb6a8, (q31_t)0x78f10d0f, (q31_t)0xd614f6a9, + (q31_t)0x78e8cfb2, (q31_t)0xd5fd3848, (q31_t)0x78e08dab, (q31_t)0xd5e57b85, (q31_t)0x78d846fb, (q31_t)0xd5cdc062, (q31_t)0x78cffba3, (q31_t)0xd5b606e0, + (q31_t)0x78c7aba2, (q31_t)0xd59e4eff, (q31_t)0x78bf56f9, (q31_t)0xd58698c0, (q31_t)0x78b6fda8, (q31_t)0xd56ee424, (q31_t)0x78ae9fb0, (q31_t)0xd557312d, + (q31_t)0x78a63d11, (q31_t)0xd53f7fda, (q31_t)0x789dd5cb, (q31_t)0xd527d02e, (q31_t)0x789569df, (q31_t)0xd5102228, (q31_t)0x788cf94c, (q31_t)0xd4f875ca, + (q31_t)0x78848414, (q31_t)0xd4e0cb15, (q31_t)0x787c0a36, (q31_t)0xd4c92209, (q31_t)0x78738bb3, (q31_t)0xd4b17aa8, (q31_t)0x786b088c, (q31_t)0xd499d4f2, + (q31_t)0x786280bf, (q31_t)0xd48230e9, (q31_t)0x7859f44f, (q31_t)0xd46a8e8d, (q31_t)0x7851633b, (q31_t)0xd452eddf, (q31_t)0x7848cd83, (q31_t)0xd43b4ee0, + (q31_t)0x78403329, (q31_t)0xd423b191, (q31_t)0x7837942b, (q31_t)0xd40c15f3, (q31_t)0x782ef08b, (q31_t)0xd3f47c06, (q31_t)0x78264849, (q31_t)0xd3dce3cd, + (q31_t)0x781d9b65, (q31_t)0xd3c54d47, (q31_t)0x7814e9df, (q31_t)0xd3adb876, (q31_t)0x780c33b8, (q31_t)0xd396255a, (q31_t)0x780378f1, (q31_t)0xd37e93f4, + (q31_t)0x77fab989, (q31_t)0xd3670446, (q31_t)0x77f1f581, (q31_t)0xd34f764f, (q31_t)0x77e92cd9, (q31_t)0xd337ea12, (q31_t)0x77e05f91, (q31_t)0xd3205f8f, + (q31_t)0x77d78daa, (q31_t)0xd308d6c7, (q31_t)0x77ceb725, (q31_t)0xd2f14fba, (q31_t)0x77c5dc01, (q31_t)0xd2d9ca6a, (q31_t)0x77bcfc3f, (q31_t)0xd2c246d8, + (q31_t)0x77b417df, (q31_t)0xd2aac504, (q31_t)0x77ab2ee2, (q31_t)0xd29344f0, (q31_t)0x77a24148, (q31_t)0xd27bc69c, (q31_t)0x77994f11, (q31_t)0xd2644a0a, + (q31_t)0x7790583e, (q31_t)0xd24ccf39, (q31_t)0x77875cce, (q31_t)0xd235562b, (q31_t)0x777e5cc3, (q31_t)0xd21ddee2, (q31_t)0x7775581d, (q31_t)0xd206695d, + (q31_t)0x776c4edb, (q31_t)0xd1eef59e, (q31_t)0x776340ff, (q31_t)0xd1d783a6, (q31_t)0x775a2e89, (q31_t)0xd1c01375, (q31_t)0x77511778, (q31_t)0xd1a8a50d, + (q31_t)0x7747fbce, (q31_t)0xd191386e, (q31_t)0x773edb8b, (q31_t)0xd179cd99, (q31_t)0x7735b6af, (q31_t)0xd1626490, (q31_t)0x772c8d3a, (q31_t)0xd14afd52, + (q31_t)0x77235f2d, (q31_t)0xd13397e2, (q31_t)0x771a2c88, (q31_t)0xd11c343f, (q31_t)0x7710f54c, (q31_t)0xd104d26b, (q31_t)0x7707b979, (q31_t)0xd0ed7267, + (q31_t)0x76fe790e, (q31_t)0xd0d61434, (q31_t)0x76f5340e, (q31_t)0xd0beb7d2, (q31_t)0x76ebea77, (q31_t)0xd0a75d42, (q31_t)0x76e29c4b, (q31_t)0xd0900486, + (q31_t)0x76d94989, (q31_t)0xd078ad9e, (q31_t)0x76cff232, (q31_t)0xd061588b, (q31_t)0x76c69647, (q31_t)0xd04a054e, (q31_t)0x76bd35c7, (q31_t)0xd032b3e7, + (q31_t)0x76b3d0b4, (q31_t)0xd01b6459, (q31_t)0x76aa670d, (q31_t)0xd00416a3, (q31_t)0x76a0f8d2, (q31_t)0xcfeccac7, (q31_t)0x76978605, (q31_t)0xcfd580c6, + (q31_t)0x768e0ea6, (q31_t)0xcfbe389f, (q31_t)0x768492b4, (q31_t)0xcfa6f255, (q31_t)0x767b1231, (q31_t)0xcf8fade9, (q31_t)0x76718d1c, (q31_t)0xcf786b5a, + (q31_t)0x76680376, (q31_t)0xcf612aaa, (q31_t)0x765e7540, (q31_t)0xcf49ebda, (q31_t)0x7654e279, (q31_t)0xcf32aeeb, (q31_t)0x764b4b23, (q31_t)0xcf1b73de, + (q31_t)0x7641af3d, (q31_t)0xcf043ab3, (q31_t)0x76380ec8, (q31_t)0xceed036b, (q31_t)0x762e69c4, (q31_t)0xced5ce08, (q31_t)0x7624c031, (q31_t)0xcebe9a8a, + (q31_t)0x761b1211, (q31_t)0xcea768f2, (q31_t)0x76115f63, (q31_t)0xce903942, (q31_t)0x7607a828, (q31_t)0xce790b79, (q31_t)0x75fdec60, (q31_t)0xce61df99, + (q31_t)0x75f42c0b, (q31_t)0xce4ab5a2, (q31_t)0x75ea672a, (q31_t)0xce338d97, (q31_t)0x75e09dbd, (q31_t)0xce1c6777, (q31_t)0x75d6cfc5, (q31_t)0xce054343, + (q31_t)0x75ccfd42, (q31_t)0xcdee20fc, (q31_t)0x75c32634, (q31_t)0xcdd700a4, (q31_t)0x75b94a9c, (q31_t)0xcdbfe23a, (q31_t)0x75af6a7b, (q31_t)0xcda8c5c1, + (q31_t)0x75a585cf, (q31_t)0xcd91ab39, (q31_t)0x759b9c9b, (q31_t)0xcd7a92a2, (q31_t)0x7591aedd, (q31_t)0xcd637bfe, (q31_t)0x7587bc98, (q31_t)0xcd4c674d, + (q31_t)0x757dc5ca, (q31_t)0xcd355491, (q31_t)0x7573ca75, (q31_t)0xcd1e43ca, (q31_t)0x7569ca99, (q31_t)0xcd0734f9, (q31_t)0x755fc635, (q31_t)0xccf0281f, + (q31_t)0x7555bd4c, (q31_t)0xccd91d3d, (q31_t)0x754bafdc, (q31_t)0xccc21455, (q31_t)0x75419de7, (q31_t)0xccab0d65, (q31_t)0x7537876c, (q31_t)0xcc940871, + (q31_t)0x752d6c6c, (q31_t)0xcc7d0578, (q31_t)0x75234ce8, (q31_t)0xcc66047b, (q31_t)0x751928e0, (q31_t)0xcc4f057c, (q31_t)0x750f0054, (q31_t)0xcc38087b, + (q31_t)0x7504d345, (q31_t)0xcc210d79, (q31_t)0x74faa1b3, (q31_t)0xcc0a1477, (q31_t)0x74f06b9e, (q31_t)0xcbf31d75, (q31_t)0x74e63108, (q31_t)0xcbdc2876, + (q31_t)0x74dbf1ef, (q31_t)0xcbc53579, (q31_t)0x74d1ae55, (q31_t)0xcbae447f, (q31_t)0x74c7663a, (q31_t)0xcb97558a, (q31_t)0x74bd199f, (q31_t)0xcb80689a, + (q31_t)0x74b2c884, (q31_t)0xcb697db0, (q31_t)0x74a872e8, (q31_t)0xcb5294ce, (q31_t)0x749e18cd, (q31_t)0xcb3badf3, (q31_t)0x7493ba34, (q31_t)0xcb24c921, + (q31_t)0x7489571c, (q31_t)0xcb0de658, (q31_t)0x747eef85, (q31_t)0xcaf7059a, (q31_t)0x74748371, (q31_t)0xcae026e8, (q31_t)0x746a12df, (q31_t)0xcac94a42, + (q31_t)0x745f9dd1, (q31_t)0xcab26fa9, (q31_t)0x74552446, (q31_t)0xca9b971e, (q31_t)0x744aa63f, (q31_t)0xca84c0a3, (q31_t)0x744023bc, (q31_t)0xca6dec37, + (q31_t)0x74359cbd, (q31_t)0xca5719db, (q31_t)0x742b1144, (q31_t)0xca404992, (q31_t)0x74208150, (q31_t)0xca297b5a, (q31_t)0x7415ece2, (q31_t)0xca12af37, + (q31_t)0x740b53fb, (q31_t)0xc9fbe527, (q31_t)0x7400b69a, (q31_t)0xc9e51d2d, (q31_t)0x73f614c0, (q31_t)0xc9ce5748, (q31_t)0x73eb6e6e, (q31_t)0xc9b7937a, + (q31_t)0x73e0c3a3, (q31_t)0xc9a0d1c5, (q31_t)0x73d61461, (q31_t)0xc98a1227, (q31_t)0x73cb60a8, (q31_t)0xc97354a4, (q31_t)0x73c0a878, (q31_t)0xc95c993a, + (q31_t)0x73b5ebd1, (q31_t)0xc945dfec, (q31_t)0x73ab2ab4, (q31_t)0xc92f28ba, (q31_t)0x73a06522, (q31_t)0xc91873a5, (q31_t)0x73959b1b, (q31_t)0xc901c0ae, + (q31_t)0x738acc9e, (q31_t)0xc8eb0fd6, (q31_t)0x737ff9ae, (q31_t)0xc8d4611d, (q31_t)0x73752249, (q31_t)0xc8bdb485, (q31_t)0x736a4671, (q31_t)0xc8a70a0e, + (q31_t)0x735f6626, (q31_t)0xc89061ba, (q31_t)0x73548168, (q31_t)0xc879bb89, (q31_t)0x73499838, (q31_t)0xc863177b, (q31_t)0x733eaa96, (q31_t)0xc84c7593, + (q31_t)0x7333b883, (q31_t)0xc835d5d0, (q31_t)0x7328c1ff, (q31_t)0xc81f3834, (q31_t)0x731dc70a, (q31_t)0xc8089cbf, (q31_t)0x7312c7a5, (q31_t)0xc7f20373, + (q31_t)0x7307c3d0, (q31_t)0xc7db6c50, (q31_t)0x72fcbb8c, (q31_t)0xc7c4d757, (q31_t)0x72f1aed9, (q31_t)0xc7ae4489, (q31_t)0x72e69db7, (q31_t)0xc797b3e7, + (q31_t)0x72db8828, (q31_t)0xc7812572, (q31_t)0x72d06e2b, (q31_t)0xc76a992a, (q31_t)0x72c54fc1, (q31_t)0xc7540f11, (q31_t)0x72ba2cea, (q31_t)0xc73d8727, + (q31_t)0x72af05a7, (q31_t)0xc727016d, (q31_t)0x72a3d9f7, (q31_t)0xc7107de4, (q31_t)0x7298a9dd, (q31_t)0xc6f9fc8d, (q31_t)0x728d7557, (q31_t)0xc6e37d69, + (q31_t)0x72823c67, (q31_t)0xc6cd0079, (q31_t)0x7276ff0d, (q31_t)0xc6b685bd, (q31_t)0x726bbd48, (q31_t)0xc6a00d37, (q31_t)0x7260771b, (q31_t)0xc68996e7, + (q31_t)0x72552c85, (q31_t)0xc67322ce, (q31_t)0x7249dd86, (q31_t)0xc65cb0ed, (q31_t)0x723e8a20, (q31_t)0xc6464144, (q31_t)0x72333251, (q31_t)0xc62fd3d6, + (q31_t)0x7227d61c, (q31_t)0xc61968a2, (q31_t)0x721c7580, (q31_t)0xc602ffaa, (q31_t)0x7211107e, (q31_t)0xc5ec98ee, (q31_t)0x7205a716, (q31_t)0xc5d6346f, + (q31_t)0x71fa3949, (q31_t)0xc5bfd22e, (q31_t)0x71eec716, (q31_t)0xc5a9722c, (q31_t)0x71e35080, (q31_t)0xc593146a, (q31_t)0x71d7d585, (q31_t)0xc57cb8e9, + (q31_t)0x71cc5626, (q31_t)0xc5665fa9, (q31_t)0x71c0d265, (q31_t)0xc55008ab, (q31_t)0x71b54a41, (q31_t)0xc539b3f1, (q31_t)0x71a9bdba, (q31_t)0xc523617a, + (q31_t)0x719e2cd2, (q31_t)0xc50d1149, (q31_t)0x71929789, (q31_t)0xc4f6c35d, (q31_t)0x7186fdde, (q31_t)0xc4e077b8, (q31_t)0x717b5fd3, (q31_t)0xc4ca2e5b, + (q31_t)0x716fbd68, (q31_t)0xc4b3e746, (q31_t)0x7164169d, (q31_t)0xc49da27a, (q31_t)0x71586b74, (q31_t)0xc4875ff9, (q31_t)0x714cbbeb, (q31_t)0xc4711fc2, + (q31_t)0x71410805, (q31_t)0xc45ae1d7, (q31_t)0x71354fc0, (q31_t)0xc444a639, (q31_t)0x7129931f, (q31_t)0xc42e6ce8, (q31_t)0x711dd220, (q31_t)0xc41835e6, + (q31_t)0x71120cc5, (q31_t)0xc4020133, (q31_t)0x7106430e, (q31_t)0xc3ebced0, (q31_t)0x70fa74fc, (q31_t)0xc3d59ebe, (q31_t)0x70eea28e, (q31_t)0xc3bf70fd, + (q31_t)0x70e2cbc6, (q31_t)0xc3a94590, (q31_t)0x70d6f0a4, (q31_t)0xc3931c76, (q31_t)0x70cb1128, (q31_t)0xc37cf5b0, (q31_t)0x70bf2d53, (q31_t)0xc366d140, + (q31_t)0x70b34525, (q31_t)0xc350af26, (q31_t)0x70a7589f, (q31_t)0xc33a8f62, (q31_t)0x709b67c0, (q31_t)0xc32471f7, (q31_t)0x708f728b, (q31_t)0xc30e56e4, + (q31_t)0x708378ff, (q31_t)0xc2f83e2a, (q31_t)0x70777b1c, (q31_t)0xc2e227cb, (q31_t)0x706b78e3, (q31_t)0xc2cc13c7, (q31_t)0x705f7255, (q31_t)0xc2b6021f, + (q31_t)0x70536771, (q31_t)0xc29ff2d4, (q31_t)0x70475839, (q31_t)0xc289e5e7, (q31_t)0x703b44ad, (q31_t)0xc273db58, (q31_t)0x702f2ccd, (q31_t)0xc25dd329, + (q31_t)0x7023109a, (q31_t)0xc247cd5a, (q31_t)0x7016f014, (q31_t)0xc231c9ec, (q31_t)0x700acb3c, (q31_t)0xc21bc8e1, (q31_t)0x6ffea212, (q31_t)0xc205ca38, + (q31_t)0x6ff27497, (q31_t)0xc1efcdf3, (q31_t)0x6fe642ca, (q31_t)0xc1d9d412, (q31_t)0x6fda0cae, (q31_t)0xc1c3dc97, (q31_t)0x6fcdd241, (q31_t)0xc1ade781, + (q31_t)0x6fc19385, (q31_t)0xc197f4d4, (q31_t)0x6fb5507a, (q31_t)0xc182048d, (q31_t)0x6fa90921, (q31_t)0xc16c16b0, (q31_t)0x6f9cbd79, (q31_t)0xc1562b3d, + (q31_t)0x6f906d84, (q31_t)0xc1404233, (q31_t)0x6f841942, (q31_t)0xc12a5b95, (q31_t)0x6f77c0b3, (q31_t)0xc1147764, (q31_t)0x6f6b63d8, (q31_t)0xc0fe959f, + (q31_t)0x6f5f02b2, (q31_t)0xc0e8b648, (q31_t)0x6f529d40, (q31_t)0xc0d2d960, (q31_t)0x6f463383, (q31_t)0xc0bcfee7, (q31_t)0x6f39c57d, (q31_t)0xc0a726df, + (q31_t)0x6f2d532c, (q31_t)0xc0915148, (q31_t)0x6f20dc92, (q31_t)0xc07b7e23, (q31_t)0x6f1461b0, (q31_t)0xc065ad70, (q31_t)0x6f07e285, (q31_t)0xc04fdf32, + (q31_t)0x6efb5f12, (q31_t)0xc03a1368, (q31_t)0x6eeed758, (q31_t)0xc0244a14, (q31_t)0x6ee24b57, (q31_t)0xc00e8336, (q31_t)0x6ed5bb10, (q31_t)0xbff8bece, + (q31_t)0x6ec92683, (q31_t)0xbfe2fcdf, (q31_t)0x6ebc8db0, (q31_t)0xbfcd3d69, (q31_t)0x6eaff099, (q31_t)0xbfb7806c, (q31_t)0x6ea34f3d, (q31_t)0xbfa1c5ea, + (q31_t)0x6e96a99d, (q31_t)0xbf8c0de3, (q31_t)0x6e89ffb9, (q31_t)0xbf765858, (q31_t)0x6e7d5193, (q31_t)0xbf60a54a, (q31_t)0x6e709f2a, (q31_t)0xbf4af4ba, + (q31_t)0x6e63e87f, (q31_t)0xbf3546a8, (q31_t)0x6e572d93, (q31_t)0xbf1f9b16, (q31_t)0x6e4a6e66, (q31_t)0xbf09f205, (q31_t)0x6e3daaf8, (q31_t)0xbef44b74, + (q31_t)0x6e30e34a, (q31_t)0xbedea765, (q31_t)0x6e24175c, (q31_t)0xbec905d9, (q31_t)0x6e174730, (q31_t)0xbeb366d1, (q31_t)0x6e0a72c5, (q31_t)0xbe9dca4e, + (q31_t)0x6dfd9a1c, (q31_t)0xbe88304f, (q31_t)0x6df0bd35, (q31_t)0xbe7298d7, (q31_t)0x6de3dc11, (q31_t)0xbe5d03e6, (q31_t)0x6dd6f6b1, (q31_t)0xbe47717c, + (q31_t)0x6dca0d14, (q31_t)0xbe31e19b, (q31_t)0x6dbd1f3c, (q31_t)0xbe1c5444, (q31_t)0x6db02d29, (q31_t)0xbe06c977, (q31_t)0x6da336dc, (q31_t)0xbdf14135, + (q31_t)0x6d963c54, (q31_t)0xbddbbb7f, (q31_t)0x6d893d93, (q31_t)0xbdc63856, (q31_t)0x6d7c3a98, (q31_t)0xbdb0b7bb, (q31_t)0x6d6f3365, (q31_t)0xbd9b39ad, + (q31_t)0x6d6227fa, (q31_t)0xbd85be30, (q31_t)0x6d551858, (q31_t)0xbd704542, (q31_t)0x6d48047e, (q31_t)0xbd5acee5, (q31_t)0x6d3aec6e, (q31_t)0xbd455b1a, + (q31_t)0x6d2dd027, (q31_t)0xbd2fe9e2, (q31_t)0x6d20afac, (q31_t)0xbd1a7b3d, (q31_t)0x6d138afb, (q31_t)0xbd050f2c, (q31_t)0x6d066215, (q31_t)0xbcefa5b0, + (q31_t)0x6cf934fc, (q31_t)0xbcda3ecb, (q31_t)0x6cec03af, (q31_t)0xbcc4da7b, (q31_t)0x6cdece2f, (q31_t)0xbcaf78c4, (q31_t)0x6cd1947c, (q31_t)0xbc9a19a5, + (q31_t)0x6cc45698, (q31_t)0xbc84bd1f, (q31_t)0x6cb71482, (q31_t)0xbc6f6333, (q31_t)0x6ca9ce3b, (q31_t)0xbc5a0be2, (q31_t)0x6c9c83c3, (q31_t)0xbc44b72c, + (q31_t)0x6c8f351c, (q31_t)0xbc2f6513, (q31_t)0x6c81e245, (q31_t)0xbc1a1598, (q31_t)0x6c748b3f, (q31_t)0xbc04c8ba, (q31_t)0x6c67300b, (q31_t)0xbbef7e7c, + (q31_t)0x6c59d0a9, (q31_t)0xbbda36dd, (q31_t)0x6c4c6d1a, (q31_t)0xbbc4f1df, (q31_t)0x6c3f055d, (q31_t)0xbbafaf82, (q31_t)0x6c319975, (q31_t)0xbb9a6fc7, + (q31_t)0x6c242960, (q31_t)0xbb8532b0, (q31_t)0x6c16b521, (q31_t)0xbb6ff83c, (q31_t)0x6c093cb6, (q31_t)0xbb5ac06d, (q31_t)0x6bfbc021, (q31_t)0xbb458b43, + (q31_t)0x6bee3f62, (q31_t)0xbb3058c0, (q31_t)0x6be0ba7b, (q31_t)0xbb1b28e4, (q31_t)0x6bd3316a, (q31_t)0xbb05fbb0, (q31_t)0x6bc5a431, (q31_t)0xbaf0d125, + (q31_t)0x6bb812d1, (q31_t)0xbadba943, (q31_t)0x6baa7d49, (q31_t)0xbac6840c, (q31_t)0x6b9ce39b, (q31_t)0xbab16180, (q31_t)0x6b8f45c7, (q31_t)0xba9c41a0, + (q31_t)0x6b81a3cd, (q31_t)0xba87246d, (q31_t)0x6b73fdae, (q31_t)0xba7209e7, (q31_t)0x6b66536b, (q31_t)0xba5cf210, (q31_t)0x6b58a503, (q31_t)0xba47dce8, + (q31_t)0x6b4af279, (q31_t)0xba32ca71, (q31_t)0x6b3d3bcb, (q31_t)0xba1dbaaa, (q31_t)0x6b2f80fb, (q31_t)0xba08ad95, (q31_t)0x6b21c208, (q31_t)0xb9f3a332, + (q31_t)0x6b13fef5, (q31_t)0xb9de9b83, (q31_t)0x6b0637c1, (q31_t)0xb9c99688, (q31_t)0x6af86c6c, (q31_t)0xb9b49442, (q31_t)0x6aea9cf8, (q31_t)0xb99f94b2, + (q31_t)0x6adcc964, (q31_t)0xb98a97d8, (q31_t)0x6acef1b2, (q31_t)0xb9759db6, (q31_t)0x6ac115e2, (q31_t)0xb960a64c, (q31_t)0x6ab335f4, (q31_t)0xb94bb19b, + (q31_t)0x6aa551e9, (q31_t)0xb936bfa4, (q31_t)0x6a9769c1, (q31_t)0xb921d067, (q31_t)0x6a897d7d, (q31_t)0xb90ce3e6, (q31_t)0x6a7b8d1e, (q31_t)0xb8f7fa21, + (q31_t)0x6a6d98a4, (q31_t)0xb8e31319, (q31_t)0x6a5fa010, (q31_t)0xb8ce2ecf, (q31_t)0x6a51a361, (q31_t)0xb8b94d44, (q31_t)0x6a43a29a, (q31_t)0xb8a46e78, + (q31_t)0x6a359db9, (q31_t)0xb88f926d, (q31_t)0x6a2794c1, (q31_t)0xb87ab922, (q31_t)0x6a1987b0, (q31_t)0xb865e299, (q31_t)0x6a0b7689, (q31_t)0xb8510ed4, + (q31_t)0x69fd614a, (q31_t)0xb83c3dd1, (q31_t)0x69ef47f6, (q31_t)0xb8276f93, (q31_t)0x69e12a8c, (q31_t)0xb812a41a, (q31_t)0x69d3090e, (q31_t)0xb7fddb67, + (q31_t)0x69c4e37a, (q31_t)0xb7e9157a, (q31_t)0x69b6b9d3, (q31_t)0xb7d45255, (q31_t)0x69a88c19, (q31_t)0xb7bf91f8, (q31_t)0x699a5a4c, (q31_t)0xb7aad465, + (q31_t)0x698c246c, (q31_t)0xb796199b, (q31_t)0x697dea7b, (q31_t)0xb781619c, (q31_t)0x696fac78, (q31_t)0xb76cac69, (q31_t)0x69616a65, (q31_t)0xb757fa01, + (q31_t)0x69532442, (q31_t)0xb7434a67, (q31_t)0x6944da10, (q31_t)0xb72e9d9b, (q31_t)0x69368bce, (q31_t)0xb719f39e, (q31_t)0x6928397e, (q31_t)0xb7054c6f, + (q31_t)0x6919e320, (q31_t)0xb6f0a812, (q31_t)0x690b88b5, (q31_t)0xb6dc0685, (q31_t)0x68fd2a3d, (q31_t)0xb6c767ca, (q31_t)0x68eec7b9, (q31_t)0xb6b2cbe2, + (q31_t)0x68e06129, (q31_t)0xb69e32cd, (q31_t)0x68d1f68f, (q31_t)0xb6899c8d, (q31_t)0x68c387e9, (q31_t)0xb6750921, (q31_t)0x68b5153a, (q31_t)0xb660788c, + (q31_t)0x68a69e81, (q31_t)0xb64beacd, (q31_t)0x689823bf, (q31_t)0xb6375fe5, (q31_t)0x6889a4f6, (q31_t)0xb622d7d6, (q31_t)0x687b2224, (q31_t)0xb60e529f, + (q31_t)0x686c9b4b, (q31_t)0xb5f9d043, (q31_t)0x685e106c, (q31_t)0xb5e550c1, (q31_t)0x684f8186, (q31_t)0xb5d0d41a, (q31_t)0x6840ee9b, (q31_t)0xb5bc5a50, + (q31_t)0x683257ab, (q31_t)0xb5a7e362, (q31_t)0x6823bcb7, (q31_t)0xb5936f53, (q31_t)0x68151dbe, (q31_t)0xb57efe22, (q31_t)0x68067ac3, (q31_t)0xb56a8fd0, + (q31_t)0x67f7d3c5, (q31_t)0xb556245e, (q31_t)0x67e928c5, (q31_t)0xb541bbcd, (q31_t)0x67da79c3, (q31_t)0xb52d561e, (q31_t)0x67cbc6c0, (q31_t)0xb518f351, + (q31_t)0x67bd0fbd, (q31_t)0xb5049368, (q31_t)0x67ae54ba, (q31_t)0xb4f03663, (q31_t)0x679f95b7, (q31_t)0xb4dbdc42, (q31_t)0x6790d2b6, (q31_t)0xb4c78507, + (q31_t)0x67820bb7, (q31_t)0xb4b330b3, (q31_t)0x677340ba, (q31_t)0xb49edf45, (q31_t)0x676471c0, (q31_t)0xb48a90c0, (q31_t)0x67559eca, (q31_t)0xb4764523, + (q31_t)0x6746c7d8, (q31_t)0xb461fc70, (q31_t)0x6737ecea, (q31_t)0xb44db6a8, (q31_t)0x67290e02, (q31_t)0xb43973ca, (q31_t)0x671a2b20, (q31_t)0xb42533d8, + (q31_t)0x670b4444, (q31_t)0xb410f6d3, (q31_t)0x66fc596f, (q31_t)0xb3fcbcbb, (q31_t)0x66ed6aa1, (q31_t)0xb3e88592, (q31_t)0x66de77dc, (q31_t)0xb3d45157, + (q31_t)0x66cf8120, (q31_t)0xb3c0200c, (q31_t)0x66c0866d, (q31_t)0xb3abf1b2, (q31_t)0x66b187c3, (q31_t)0xb397c649, (q31_t)0x66a28524, (q31_t)0xb3839dd3, + (q31_t)0x66937e91, (q31_t)0xb36f784f, (q31_t)0x66847408, (q31_t)0xb35b55bf, (q31_t)0x6675658c, (q31_t)0xb3473623, (q31_t)0x6666531d, (q31_t)0xb333197c, + (q31_t)0x66573cbb, (q31_t)0xb31effcc, (q31_t)0x66482267, (q31_t)0xb30ae912, (q31_t)0x66390422, (q31_t)0xb2f6d550, (q31_t)0x6629e1ec, (q31_t)0xb2e2c486, + (q31_t)0x661abbc5, (q31_t)0xb2ceb6b5, (q31_t)0x660b91af, (q31_t)0xb2baabde, (q31_t)0x65fc63a9, (q31_t)0xb2a6a402, (q31_t)0x65ed31b5, (q31_t)0xb2929f21, + (q31_t)0x65ddfbd3, (q31_t)0xb27e9d3c, (q31_t)0x65cec204, (q31_t)0xb26a9e54, (q31_t)0x65bf8447, (q31_t)0xb256a26a, (q31_t)0x65b0429f, (q31_t)0xb242a97e, + (q31_t)0x65a0fd0b, (q31_t)0xb22eb392, (q31_t)0x6591b38c, (q31_t)0xb21ac0a6, (q31_t)0x65826622, (q31_t)0xb206d0ba, (q31_t)0x657314cf, (q31_t)0xb1f2e3d0, + (q31_t)0x6563bf92, (q31_t)0xb1def9e9, (q31_t)0x6554666d, (q31_t)0xb1cb1304, (q31_t)0x6545095f, (q31_t)0xb1b72f23, (q31_t)0x6535a86b, (q31_t)0xb1a34e47, + (q31_t)0x6526438f, (q31_t)0xb18f7071, (q31_t)0x6516dacd, (q31_t)0xb17b95a0, (q31_t)0x65076e25, (q31_t)0xb167bdd7, (q31_t)0x64f7fd98, (q31_t)0xb153e915, + (q31_t)0x64e88926, (q31_t)0xb140175b, (q31_t)0x64d910d1, (q31_t)0xb12c48ab, (q31_t)0x64c99498, (q31_t)0xb1187d05, (q31_t)0x64ba147d, (q31_t)0xb104b46a, + (q31_t)0x64aa907f, (q31_t)0xb0f0eeda, (q31_t)0x649b08a0, (q31_t)0xb0dd2c56, (q31_t)0x648b7ce0, (q31_t)0xb0c96ce0, (q31_t)0x647bed3f, (q31_t)0xb0b5b077, + (q31_t)0x646c59bf, (q31_t)0xb0a1f71d, (q31_t)0x645cc260, (q31_t)0xb08e40d2, (q31_t)0x644d2722, (q31_t)0xb07a8d97, (q31_t)0x643d8806, (q31_t)0xb066dd6d, + (q31_t)0x642de50d, (q31_t)0xb0533055, (q31_t)0x641e3e38, (q31_t)0xb03f864f, (q31_t)0x640e9386, (q31_t)0xb02bdf5c, (q31_t)0x63fee4f8, (q31_t)0xb0183b7d, + (q31_t)0x63ef3290, (q31_t)0xb0049ab3, (q31_t)0x63df7c4d, (q31_t)0xaff0fcfe, (q31_t)0x63cfc231, (q31_t)0xafdd625f, (q31_t)0x63c0043b, (q31_t)0xafc9cad7, + (q31_t)0x63b0426d, (q31_t)0xafb63667, (q31_t)0x63a07cc7, (q31_t)0xafa2a50f, (q31_t)0x6390b34a, (q31_t)0xaf8f16d1, (q31_t)0x6380e5f6, (q31_t)0xaf7b8bac, + (q31_t)0x637114cc, (q31_t)0xaf6803a2, (q31_t)0x63613fcd, (q31_t)0xaf547eb3, (q31_t)0x635166f9, (q31_t)0xaf40fce1, (q31_t)0x63418a50, (q31_t)0xaf2d7e2b, + (q31_t)0x6331a9d4, (q31_t)0xaf1a0293, (q31_t)0x6321c585, (q31_t)0xaf068a1a, (q31_t)0x6311dd64, (q31_t)0xaef314c0, (q31_t)0x6301f171, (q31_t)0xaedfa285, + (q31_t)0x62f201ac, (q31_t)0xaecc336c, (q31_t)0x62e20e17, (q31_t)0xaeb8c774, (q31_t)0x62d216b3, (q31_t)0xaea55e9e, (q31_t)0x62c21b7e, (q31_t)0xae91f8eb, + (q31_t)0x62b21c7b, (q31_t)0xae7e965b, (q31_t)0x62a219aa, (q31_t)0xae6b36f0, (q31_t)0x6292130c, (q31_t)0xae57daab, (q31_t)0x628208a1, (q31_t)0xae44818b, + (q31_t)0x6271fa69, (q31_t)0xae312b92, (q31_t)0x6261e866, (q31_t)0xae1dd8c0, (q31_t)0x6251d298, (q31_t)0xae0a8916, (q31_t)0x6241b8ff, (q31_t)0xadf73c96, + (q31_t)0x62319b9d, (q31_t)0xade3f33e, (q31_t)0x62217a72, (q31_t)0xadd0ad12, (q31_t)0x6211557e, (q31_t)0xadbd6a10, (q31_t)0x62012cc2, (q31_t)0xadaa2a3b, + (q31_t)0x61f1003f, (q31_t)0xad96ed92, (q31_t)0x61e0cff5, (q31_t)0xad83b416, (q31_t)0x61d09be5, (q31_t)0xad707dc8, (q31_t)0x61c06410, (q31_t)0xad5d4aaa, + (q31_t)0x61b02876, (q31_t)0xad4a1aba, (q31_t)0x619fe918, (q31_t)0xad36edfc, (q31_t)0x618fa5f7, (q31_t)0xad23c46e, (q31_t)0x617f5f12, (q31_t)0xad109e12, + (q31_t)0x616f146c, (q31_t)0xacfd7ae8, (q31_t)0x615ec603, (q31_t)0xacea5af2, (q31_t)0x614e73da, (q31_t)0xacd73e30, (q31_t)0x613e1df0, (q31_t)0xacc424a3, + (q31_t)0x612dc447, (q31_t)0xacb10e4b, (q31_t)0x611d66de, (q31_t)0xac9dfb29, (q31_t)0x610d05b7, (q31_t)0xac8aeb3e, (q31_t)0x60fca0d2, (q31_t)0xac77de8b, + (q31_t)0x60ec3830, (q31_t)0xac64d510, (q31_t)0x60dbcbd1, (q31_t)0xac51cecf, (q31_t)0x60cb5bb7, (q31_t)0xac3ecbc7, (q31_t)0x60bae7e1, (q31_t)0xac2bcbfa, + (q31_t)0x60aa7050, (q31_t)0xac18cf69, (q31_t)0x6099f505, (q31_t)0xac05d613, (q31_t)0x60897601, (q31_t)0xabf2dffb, (q31_t)0x6078f344, (q31_t)0xabdfed1f, + (q31_t)0x60686ccf, (q31_t)0xabccfd83, (q31_t)0x6057e2a2, (q31_t)0xabba1125, (q31_t)0x604754bf, (q31_t)0xaba72807, (q31_t)0x6036c325, (q31_t)0xab944229, + (q31_t)0x60262dd6, (q31_t)0xab815f8d, (q31_t)0x601594d1, (q31_t)0xab6e8032, (q31_t)0x6004f819, (q31_t)0xab5ba41a, (q31_t)0x5ff457ad, (q31_t)0xab48cb46, + (q31_t)0x5fe3b38d, (q31_t)0xab35f5b5, (q31_t)0x5fd30bbc, (q31_t)0xab23236a, (q31_t)0x5fc26038, (q31_t)0xab105464, (q31_t)0x5fb1b104, (q31_t)0xaafd88a4, + (q31_t)0x5fa0fe1f, (q31_t)0xaaeac02c, (q31_t)0x5f90478a, (q31_t)0xaad7fafb, (q31_t)0x5f7f8d46, (q31_t)0xaac53912, (q31_t)0x5f6ecf53, (q31_t)0xaab27a73, + (q31_t)0x5f5e0db3, (q31_t)0xaa9fbf1e, (q31_t)0x5f4d4865, (q31_t)0xaa8d0713, (q31_t)0x5f3c7f6b, (q31_t)0xaa7a5253, (q31_t)0x5f2bb2c5, (q31_t)0xaa67a0e0, + (q31_t)0x5f1ae274, (q31_t)0xaa54f2ba, (q31_t)0x5f0a0e77, (q31_t)0xaa4247e1, (q31_t)0x5ef936d1, (q31_t)0xaa2fa056, (q31_t)0x5ee85b82, (q31_t)0xaa1cfc1a, + (q31_t)0x5ed77c8a, (q31_t)0xaa0a5b2e, (q31_t)0x5ec699e9, (q31_t)0xa9f7bd92, (q31_t)0x5eb5b3a2, (q31_t)0xa9e52347, (q31_t)0x5ea4c9b3, (q31_t)0xa9d28c4e, + (q31_t)0x5e93dc1f, (q31_t)0xa9bff8a8, (q31_t)0x5e82eae5, (q31_t)0xa9ad6855, (q31_t)0x5e71f606, (q31_t)0xa99adb56, (q31_t)0x5e60fd84, (q31_t)0xa98851ac, + (q31_t)0x5e50015d, (q31_t)0xa975cb57, (q31_t)0x5e3f0194, (q31_t)0xa9634858, (q31_t)0x5e2dfe29, (q31_t)0xa950c8b0, (q31_t)0x5e1cf71c, (q31_t)0xa93e4c5f, + (q31_t)0x5e0bec6e, (q31_t)0xa92bd367, (q31_t)0x5dfade20, (q31_t)0xa9195dc7, (q31_t)0x5de9cc33, (q31_t)0xa906eb82, (q31_t)0x5dd8b6a7, (q31_t)0xa8f47c97, + (q31_t)0x5dc79d7c, (q31_t)0xa8e21106, (q31_t)0x5db680b4, (q31_t)0xa8cfa8d2, (q31_t)0x5da5604f, (q31_t)0xa8bd43fa, (q31_t)0x5d943c4e, (q31_t)0xa8aae280, + (q31_t)0x5d8314b1, (q31_t)0xa8988463, (q31_t)0x5d71e979, (q31_t)0xa88629a5, (q31_t)0x5d60baa7, (q31_t)0xa873d246, (q31_t)0x5d4f883b, (q31_t)0xa8617e48, + (q31_t)0x5d3e5237, (q31_t)0xa84f2daa, (q31_t)0x5d2d189a, (q31_t)0xa83ce06e, (q31_t)0x5d1bdb65, (q31_t)0xa82a9693, (q31_t)0x5d0a9a9a, (q31_t)0xa818501c, + (q31_t)0x5cf95638, (q31_t)0xa8060d08, (q31_t)0x5ce80e41, (q31_t)0xa7f3cd59, (q31_t)0x5cd6c2b5, (q31_t)0xa7e1910f, (q31_t)0x5cc57394, (q31_t)0xa7cf582a, + (q31_t)0x5cb420e0, (q31_t)0xa7bd22ac, (q31_t)0x5ca2ca99, (q31_t)0xa7aaf094, (q31_t)0x5c9170bf, (q31_t)0xa798c1e5, (q31_t)0x5c801354, (q31_t)0xa786969e, + (q31_t)0x5c6eb258, (q31_t)0xa7746ec0, (q31_t)0x5c5d4dcc, (q31_t)0xa7624a4d, (q31_t)0x5c4be5b0, (q31_t)0xa7502943, (q31_t)0x5c3a7a05, (q31_t)0xa73e0ba5, + (q31_t)0x5c290acc, (q31_t)0xa72bf174, (q31_t)0x5c179806, (q31_t)0xa719daae, (q31_t)0x5c0621b2, (q31_t)0xa707c757, (q31_t)0x5bf4a7d2, (q31_t)0xa6f5b76d, + (q31_t)0x5be32a67, (q31_t)0xa6e3aaf2, (q31_t)0x5bd1a971, (q31_t)0xa6d1a1e7, (q31_t)0x5bc024f0, (q31_t)0xa6bf9c4b, (q31_t)0x5bae9ce7, (q31_t)0xa6ad9a21, + (q31_t)0x5b9d1154, (q31_t)0xa69b9b68, (q31_t)0x5b8b8239, (q31_t)0xa689a022, (q31_t)0x5b79ef96, (q31_t)0xa677a84e, (q31_t)0x5b68596d, (q31_t)0xa665b3ee, + (q31_t)0x5b56bfbd, (q31_t)0xa653c303, (q31_t)0x5b452288, (q31_t)0xa641d58c, (q31_t)0x5b3381ce, (q31_t)0xa62feb8b, (q31_t)0x5b21dd90, (q31_t)0xa61e0501, + (q31_t)0x5b1035cf, (q31_t)0xa60c21ee, (q31_t)0x5afe8a8b, (q31_t)0xa5fa4252, (q31_t)0x5aecdbc5, (q31_t)0xa5e8662f, (q31_t)0x5adb297d, (q31_t)0xa5d68d85, + (q31_t)0x5ac973b5, (q31_t)0xa5c4b855, (q31_t)0x5ab7ba6c, (q31_t)0xa5b2e6a0, (q31_t)0x5aa5fda5, (q31_t)0xa5a11866, (q31_t)0x5a943d5e, (q31_t)0xa58f4da8, + (q31_t)0x5a82799a, (q31_t)0xa57d8666, (q31_t)0x5a70b258, (q31_t)0xa56bc2a2, (q31_t)0x5a5ee79a, (q31_t)0xa55a025b, (q31_t)0x5a4d1960, (q31_t)0xa5484594, + (q31_t)0x5a3b47ab, (q31_t)0xa5368c4b, (q31_t)0x5a29727b, (q31_t)0xa524d683, (q31_t)0x5a1799d1, (q31_t)0xa513243b, (q31_t)0x5a05bdae, (q31_t)0xa5017575, + (q31_t)0x59f3de12, (q31_t)0xa4efca31, (q31_t)0x59e1faff, (q31_t)0xa4de2270, (q31_t)0x59d01475, (q31_t)0xa4cc7e32, (q31_t)0x59be2a74, (q31_t)0xa4badd78, + (q31_t)0x59ac3cfd, (q31_t)0xa4a94043, (q31_t)0x599a4c12, (q31_t)0xa497a693, (q31_t)0x598857b2, (q31_t)0xa486106a, (q31_t)0x59765fde, (q31_t)0xa4747dc7, + (q31_t)0x59646498, (q31_t)0xa462eeac, (q31_t)0x595265df, (q31_t)0xa4516319, (q31_t)0x594063b5, (q31_t)0xa43fdb10, (q31_t)0x592e5e19, (q31_t)0xa42e568f, + (q31_t)0x591c550e, (q31_t)0xa41cd599, (q31_t)0x590a4893, (q31_t)0xa40b582e, (q31_t)0x58f838a9, (q31_t)0xa3f9de4e, (q31_t)0x58e62552, (q31_t)0xa3e867fa, + (q31_t)0x58d40e8c, (q31_t)0xa3d6f534, (q31_t)0x58c1f45b, (q31_t)0xa3c585fb, (q31_t)0x58afd6bd, (q31_t)0xa3b41a50, (q31_t)0x589db5b3, (q31_t)0xa3a2b234, + (q31_t)0x588b9140, (q31_t)0xa3914da8, (q31_t)0x58796962, (q31_t)0xa37fecac, (q31_t)0x58673e1b, (q31_t)0xa36e8f41, (q31_t)0x58550f6c, (q31_t)0xa35d3567, + (q31_t)0x5842dd54, (q31_t)0xa34bdf20, (q31_t)0x5830a7d6, (q31_t)0xa33a8c6c, (q31_t)0x581e6ef1, (q31_t)0xa3293d4b, (q31_t)0x580c32a7, (q31_t)0xa317f1bf, + (q31_t)0x57f9f2f8, (q31_t)0xa306a9c8, (q31_t)0x57e7afe4, (q31_t)0xa2f56566, (q31_t)0x57d5696d, (q31_t)0xa2e4249b, (q31_t)0x57c31f92, (q31_t)0xa2d2e766, + (q31_t)0x57b0d256, (q31_t)0xa2c1adc9, (q31_t)0x579e81b8, (q31_t)0xa2b077c5, (q31_t)0x578c2dba, (q31_t)0xa29f4559, (q31_t)0x5779d65b, (q31_t)0xa28e1687, + (q31_t)0x57677b9d, (q31_t)0xa27ceb4f, (q31_t)0x57551d80, (q31_t)0xa26bc3b2, (q31_t)0x5742bc06, (q31_t)0xa25a9fb1, (q31_t)0x5730572e, (q31_t)0xa2497f4c, + (q31_t)0x571deefa, (q31_t)0xa2386284, (q31_t)0x570b8369, (q31_t)0xa2274959, (q31_t)0x56f9147e, (q31_t)0xa21633cd, (q31_t)0x56e6a239, (q31_t)0xa20521e0, + (q31_t)0x56d42c99, (q31_t)0xa1f41392, (q31_t)0x56c1b3a1, (q31_t)0xa1e308e4, (q31_t)0x56af3750, (q31_t)0xa1d201d7, (q31_t)0x569cb7a8, (q31_t)0xa1c0fe6c, + (q31_t)0x568a34a9, (q31_t)0xa1affea3, (q31_t)0x5677ae54, (q31_t)0xa19f027c, (q31_t)0x566524aa, (q31_t)0xa18e09fa, (q31_t)0x565297ab, (q31_t)0xa17d151b, + (q31_t)0x56400758, (q31_t)0xa16c23e1, (q31_t)0x562d73b2, (q31_t)0xa15b364d, (q31_t)0x561adcb9, (q31_t)0xa14a4c5e, (q31_t)0x5608426e, (q31_t)0xa1396617, + (q31_t)0x55f5a4d2, (q31_t)0xa1288376, (q31_t)0x55e303e6, (q31_t)0xa117a47e, (q31_t)0x55d05faa, (q31_t)0xa106c92f, (q31_t)0x55bdb81f, (q31_t)0xa0f5f189, + (q31_t)0x55ab0d46, (q31_t)0xa0e51d8c, (q31_t)0x55985f20, (q31_t)0xa0d44d3b, (q31_t)0x5585adad, (q31_t)0xa0c38095, (q31_t)0x5572f8ed, (q31_t)0xa0b2b79b, + (q31_t)0x556040e2, (q31_t)0xa0a1f24d, (q31_t)0x554d858d, (q31_t)0xa09130ad, (q31_t)0x553ac6ee, (q31_t)0xa08072ba, (q31_t)0x55280505, (q31_t)0xa06fb876, + (q31_t)0x55153fd4, (q31_t)0xa05f01e1, (q31_t)0x5502775c, (q31_t)0xa04e4efc, (q31_t)0x54efab9c, (q31_t)0xa03d9fc8, (q31_t)0x54dcdc96, (q31_t)0xa02cf444, + (q31_t)0x54ca0a4b, (q31_t)0xa01c4c73, (q31_t)0x54b734ba, (q31_t)0xa00ba853, (q31_t)0x54a45be6, (q31_t)0x9ffb07e7, (q31_t)0x54917fce, (q31_t)0x9fea6b2f, + (q31_t)0x547ea073, (q31_t)0x9fd9d22a, (q31_t)0x546bbdd7, (q31_t)0x9fc93cdb, (q31_t)0x5458d7f9, (q31_t)0x9fb8ab41, (q31_t)0x5445eedb, (q31_t)0x9fa81d5e, + (q31_t)0x5433027d, (q31_t)0x9f979331, (q31_t)0x542012e1, (q31_t)0x9f870cbc, (q31_t)0x540d2005, (q31_t)0x9f7689ff, (q31_t)0x53fa29ed, (q31_t)0x9f660afb, + (q31_t)0x53e73097, (q31_t)0x9f558fb0, (q31_t)0x53d43406, (q31_t)0x9f45181f, (q31_t)0x53c13439, (q31_t)0x9f34a449, (q31_t)0x53ae3131, (q31_t)0x9f24342f, + (q31_t)0x539b2af0, (q31_t)0x9f13c7d0, (q31_t)0x53882175, (q31_t)0x9f035f2e, (q31_t)0x537514c2, (q31_t)0x9ef2fa49, (q31_t)0x536204d7, (q31_t)0x9ee29922, + (q31_t)0x534ef1b5, (q31_t)0x9ed23bb9, (q31_t)0x533bdb5d, (q31_t)0x9ec1e210, (q31_t)0x5328c1d0, (q31_t)0x9eb18c26, (q31_t)0x5315a50e, (q31_t)0x9ea139fd, + (q31_t)0x53028518, (q31_t)0x9e90eb94, (q31_t)0x52ef61ee, (q31_t)0x9e80a0ee, (q31_t)0x52dc3b92, (q31_t)0x9e705a09, (q31_t)0x52c91204, (q31_t)0x9e6016e8, + (q31_t)0x52b5e546, (q31_t)0x9e4fd78a, (q31_t)0x52a2b556, (q31_t)0x9e3f9bf0, (q31_t)0x528f8238, (q31_t)0x9e2f641b, (q31_t)0x527c4bea, (q31_t)0x9e1f300b, + (q31_t)0x5269126e, (q31_t)0x9e0effc1, (q31_t)0x5255d5c5, (q31_t)0x9dfed33e, (q31_t)0x524295f0, (q31_t)0x9deeaa82, (q31_t)0x522f52ee, (q31_t)0x9dde858e, + (q31_t)0x521c0cc2, (q31_t)0x9dce6463, (q31_t)0x5208c36a, (q31_t)0x9dbe4701, (q31_t)0x51f576ea, (q31_t)0x9dae2d68, (q31_t)0x51e22740, (q31_t)0x9d9e179a, + (q31_t)0x51ced46e, (q31_t)0x9d8e0597, (q31_t)0x51bb7e75, (q31_t)0x9d7df75f, (q31_t)0x51a82555, (q31_t)0x9d6decf4, (q31_t)0x5194c910, (q31_t)0x9d5de656, + (q31_t)0x518169a5, (q31_t)0x9d4de385, (q31_t)0x516e0715, (q31_t)0x9d3de482, (q31_t)0x515aa162, (q31_t)0x9d2de94d, (q31_t)0x5147388c, (q31_t)0x9d1df1e9, + (q31_t)0x5133cc94, (q31_t)0x9d0dfe54, (q31_t)0x51205d7b, (q31_t)0x9cfe0e8f, (q31_t)0x510ceb40, (q31_t)0x9cee229c, (q31_t)0x50f975e6, (q31_t)0x9cde3a7b, + (q31_t)0x50e5fd6d, (q31_t)0x9cce562c, (q31_t)0x50d281d5, (q31_t)0x9cbe75b0, (q31_t)0x50bf031f, (q31_t)0x9cae9907, (q31_t)0x50ab814d, (q31_t)0x9c9ec033, + (q31_t)0x5097fc5e, (q31_t)0x9c8eeb34, (q31_t)0x50847454, (q31_t)0x9c7f1a0a, (q31_t)0x5070e92f, (q31_t)0x9c6f4cb6, (q31_t)0x505d5af1, (q31_t)0x9c5f8339, + (q31_t)0x5049c999, (q31_t)0x9c4fbd93, (q31_t)0x50363529, (q31_t)0x9c3ffbc5, (q31_t)0x50229da1, (q31_t)0x9c303dcf, (q31_t)0x500f0302, (q31_t)0x9c2083b3, + (q31_t)0x4ffb654d, (q31_t)0x9c10cd70, (q31_t)0x4fe7c483, (q31_t)0x9c011b08, (q31_t)0x4fd420a4, (q31_t)0x9bf16c7a, (q31_t)0x4fc079b1, (q31_t)0x9be1c1c8, + (q31_t)0x4faccfab, (q31_t)0x9bd21af3, (q31_t)0x4f992293, (q31_t)0x9bc277fa, (q31_t)0x4f857269, (q31_t)0x9bb2d8de, (q31_t)0x4f71bf2e, (q31_t)0x9ba33da0, + (q31_t)0x4f5e08e3, (q31_t)0x9b93a641, (q31_t)0x4f4a4f89, (q31_t)0x9b8412c1, (q31_t)0x4f369320, (q31_t)0x9b748320, (q31_t)0x4f22d3aa, (q31_t)0x9b64f760, + (q31_t)0x4f0f1126, (q31_t)0x9b556f81, (q31_t)0x4efb4b96, (q31_t)0x9b45eb83, (q31_t)0x4ee782fb, (q31_t)0x9b366b68, (q31_t)0x4ed3b755, (q31_t)0x9b26ef2f, + (q31_t)0x4ebfe8a5, (q31_t)0x9b1776da, (q31_t)0x4eac16eb, (q31_t)0x9b080268, (q31_t)0x4e984229, (q31_t)0x9af891db, (q31_t)0x4e846a60, (q31_t)0x9ae92533, + (q31_t)0x4e708f8f, (q31_t)0x9ad9bc71, (q31_t)0x4e5cb1b9, (q31_t)0x9aca5795, (q31_t)0x4e48d0dd, (q31_t)0x9abaf6a1, (q31_t)0x4e34ecfc, (q31_t)0x9aab9993, + (q31_t)0x4e210617, (q31_t)0x9a9c406e, (q31_t)0x4e0d1c30, (q31_t)0x9a8ceb31, (q31_t)0x4df92f46, (q31_t)0x9a7d99de, (q31_t)0x4de53f5a, (q31_t)0x9a6e4c74, + (q31_t)0x4dd14c6e, (q31_t)0x9a5f02f5, (q31_t)0x4dbd5682, (q31_t)0x9a4fbd61, (q31_t)0x4da95d96, (q31_t)0x9a407bb9, (q31_t)0x4d9561ac, (q31_t)0x9a313dfc, + (q31_t)0x4d8162c4, (q31_t)0x9a22042d, (q31_t)0x4d6d60df, (q31_t)0x9a12ce4b, (q31_t)0x4d595bfe, (q31_t)0x9a039c57, (q31_t)0x4d455422, (q31_t)0x99f46e51, + (q31_t)0x4d31494b, (q31_t)0x99e5443b, (q31_t)0x4d1d3b7a, (q31_t)0x99d61e14, (q31_t)0x4d092ab0, (q31_t)0x99c6fbde, (q31_t)0x4cf516ee, (q31_t)0x99b7dd99, + (q31_t)0x4ce10034, (q31_t)0x99a8c345, (q31_t)0x4ccce684, (q31_t)0x9999ace3, (q31_t)0x4cb8c9dd, (q31_t)0x998a9a74, (q31_t)0x4ca4aa41, (q31_t)0x997b8bf8, + (q31_t)0x4c9087b1, (q31_t)0x996c816f, (q31_t)0x4c7c622d, (q31_t)0x995d7adc, (q31_t)0x4c6839b7, (q31_t)0x994e783d, (q31_t)0x4c540e4e, (q31_t)0x993f7993, + (q31_t)0x4c3fdff4, (q31_t)0x99307ee0, (q31_t)0x4c2baea9, (q31_t)0x99218824, (q31_t)0x4c177a6e, (q31_t)0x9912955f, (q31_t)0x4c034345, (q31_t)0x9903a691, + (q31_t)0x4bef092d, (q31_t)0x98f4bbbc, (q31_t)0x4bdacc28, (q31_t)0x98e5d4e0, (q31_t)0x4bc68c36, (q31_t)0x98d6f1fe, (q31_t)0x4bb24958, (q31_t)0x98c81316, + (q31_t)0x4b9e0390, (q31_t)0x98b93828, (q31_t)0x4b89badd, (q31_t)0x98aa6136, (q31_t)0x4b756f40, (q31_t)0x989b8e40, (q31_t)0x4b6120bb, (q31_t)0x988cbf46, + (q31_t)0x4b4ccf4d, (q31_t)0x987df449, (q31_t)0x4b387af9, (q31_t)0x986f2d4a, (q31_t)0x4b2423be, (q31_t)0x98606a49, (q31_t)0x4b0fc99d, (q31_t)0x9851ab46, + (q31_t)0x4afb6c98, (q31_t)0x9842f043, (q31_t)0x4ae70caf, (q31_t)0x98343940, (q31_t)0x4ad2a9e2, (q31_t)0x9825863d, (q31_t)0x4abe4433, (q31_t)0x9816d73b, + (q31_t)0x4aa9dba2, (q31_t)0x98082c3b, (q31_t)0x4a957030, (q31_t)0x97f9853d, (q31_t)0x4a8101de, (q31_t)0x97eae242, (q31_t)0x4a6c90ad, (q31_t)0x97dc4349, + (q31_t)0x4a581c9e, (q31_t)0x97cda855, (q31_t)0x4a43a5b0, (q31_t)0x97bf1165, (q31_t)0x4a2f2be6, (q31_t)0x97b07e7a, (q31_t)0x4a1aaf3f, (q31_t)0x97a1ef94, + (q31_t)0x4a062fbd, (q31_t)0x979364b5, (q31_t)0x49f1ad61, (q31_t)0x9784dddc, (q31_t)0x49dd282a, (q31_t)0x97765b0a, (q31_t)0x49c8a01b, (q31_t)0x9767dc41, + (q31_t)0x49b41533, (q31_t)0x9759617f, (q31_t)0x499f8774, (q31_t)0x974aeac6, (q31_t)0x498af6df, (q31_t)0x973c7817, (q31_t)0x49766373, (q31_t)0x972e0971, + (q31_t)0x4961cd33, (q31_t)0x971f9ed7, (q31_t)0x494d341e, (q31_t)0x97113847, (q31_t)0x49389836, (q31_t)0x9702d5c3, (q31_t)0x4923f97b, (q31_t)0x96f4774b, + (q31_t)0x490f57ee, (q31_t)0x96e61ce0, (q31_t)0x48fab391, (q31_t)0x96d7c682, (q31_t)0x48e60c62, (q31_t)0x96c97432, (q31_t)0x48d16265, (q31_t)0x96bb25f0, + (q31_t)0x48bcb599, (q31_t)0x96acdbbe, (q31_t)0x48a805ff, (q31_t)0x969e959b, (q31_t)0x48935397, (q31_t)0x96905388, (q31_t)0x487e9e64, (q31_t)0x96821585, + (q31_t)0x4869e665, (q31_t)0x9673db94, (q31_t)0x48552b9b, (q31_t)0x9665a5b4, (q31_t)0x48406e08, (q31_t)0x965773e7, (q31_t)0x482badab, (q31_t)0x9649462d, + (q31_t)0x4816ea86, (q31_t)0x963b1c86, (q31_t)0x48022499, (q31_t)0x962cf6f2, (q31_t)0x47ed5be6, (q31_t)0x961ed574, (q31_t)0x47d8906d, (q31_t)0x9610b80a, + (q31_t)0x47c3c22f, (q31_t)0x96029eb6, (q31_t)0x47aef12c, (q31_t)0x95f48977, (q31_t)0x479a1d67, (q31_t)0x95e67850, (q31_t)0x478546de, (q31_t)0x95d86b3f, + (q31_t)0x47706d93, (q31_t)0x95ca6247, (q31_t)0x475b9188, (q31_t)0x95bc5d66, (q31_t)0x4746b2bc, (q31_t)0x95ae5c9f, (q31_t)0x4731d131, (q31_t)0x95a05ff0, + (q31_t)0x471cece7, (q31_t)0x9592675c, (q31_t)0x470805df, (q31_t)0x958472e2, (q31_t)0x46f31c1a, (q31_t)0x95768283, (q31_t)0x46de2f99, (q31_t)0x9568963f, + (q31_t)0x46c9405c, (q31_t)0x955aae17, (q31_t)0x46b44e65, (q31_t)0x954cca0c, (q31_t)0x469f59b4, (q31_t)0x953eea1e, (q31_t)0x468a624a, (q31_t)0x95310e4e, + (q31_t)0x46756828, (q31_t)0x9523369c, (q31_t)0x46606b4e, (q31_t)0x95156308, (q31_t)0x464b6bbe, (q31_t)0x95079394, (q31_t)0x46366978, (q31_t)0x94f9c83f, + (q31_t)0x4621647d, (q31_t)0x94ec010b, (q31_t)0x460c5cce, (q31_t)0x94de3df8, (q31_t)0x45f7526b, (q31_t)0x94d07f05, (q31_t)0x45e24556, (q31_t)0x94c2c435, + (q31_t)0x45cd358f, (q31_t)0x94b50d87, (q31_t)0x45b82318, (q31_t)0x94a75afd, (q31_t)0x45a30df0, (q31_t)0x9499ac95, (q31_t)0x458df619, (q31_t)0x948c0252, + (q31_t)0x4578db93, (q31_t)0x947e5c33, (q31_t)0x4563be60, (q31_t)0x9470ba39, (q31_t)0x454e9e80, (q31_t)0x94631c65, (q31_t)0x45397bf4, (q31_t)0x945582b7, + (q31_t)0x452456bd, (q31_t)0x9447ed2f, (q31_t)0x450f2edb, (q31_t)0x943a5bcf, (q31_t)0x44fa0450, (q31_t)0x942cce96, (q31_t)0x44e4d71c, (q31_t)0x941f4585, + (q31_t)0x44cfa740, (q31_t)0x9411c09e, (q31_t)0x44ba74bd, (q31_t)0x94043fdf, (q31_t)0x44a53f93, (q31_t)0x93f6c34a, (q31_t)0x449007c4, (q31_t)0x93e94adf, + (q31_t)0x447acd50, (q31_t)0x93dbd6a0, (q31_t)0x44659039, (q31_t)0x93ce668b, (q31_t)0x4450507e, (q31_t)0x93c0faa3, (q31_t)0x443b0e21, (q31_t)0x93b392e6, + (q31_t)0x4425c923, (q31_t)0x93a62f57, (q31_t)0x44108184, (q31_t)0x9398cff5, (q31_t)0x43fb3746, (q31_t)0x938b74c1, (q31_t)0x43e5ea68, (q31_t)0x937e1dbb, + (q31_t)0x43d09aed, (q31_t)0x9370cae4, (q31_t)0x43bb48d4, (q31_t)0x93637c3d, (q31_t)0x43a5f41e, (q31_t)0x935631c5, (q31_t)0x43909ccd, (q31_t)0x9348eb7e, + (q31_t)0x437b42e1, (q31_t)0x933ba968, (q31_t)0x4365e65b, (q31_t)0x932e6b84, (q31_t)0x4350873c, (q31_t)0x932131d1, (q31_t)0x433b2585, (q31_t)0x9313fc51, + (q31_t)0x4325c135, (q31_t)0x9306cb04, (q31_t)0x43105a50, (q31_t)0x92f99deb, (q31_t)0x42faf0d4, (q31_t)0x92ec7505, (q31_t)0x42e584c3, (q31_t)0x92df5054, + (q31_t)0x42d0161e, (q31_t)0x92d22fd9, (q31_t)0x42baa4e6, (q31_t)0x92c51392, (q31_t)0x42a5311b, (q31_t)0x92b7fb82, (q31_t)0x428fbabe, (q31_t)0x92aae7a8, + (q31_t)0x427a41d0, (q31_t)0x929dd806, (q31_t)0x4264c653, (q31_t)0x9290cc9b, (q31_t)0x424f4845, (q31_t)0x9283c568, (q31_t)0x4239c7aa, (q31_t)0x9276c26d, + (q31_t)0x42244481, (q31_t)0x9269c3ac, (q31_t)0x420ebecb, (q31_t)0x925cc924, (q31_t)0x41f93689, (q31_t)0x924fd2d7, (q31_t)0x41e3abbc, (q31_t)0x9242e0c4, + (q31_t)0x41ce1e65, (q31_t)0x9235f2ec, (q31_t)0x41b88e84, (q31_t)0x9229094f, (q31_t)0x41a2fc1a, (q31_t)0x921c23ef, (q31_t)0x418d6729, (q31_t)0x920f42cb, + (q31_t)0x4177cfb1, (q31_t)0x920265e4, (q31_t)0x416235b2, (q31_t)0x91f58d3b, (q31_t)0x414c992f, (q31_t)0x91e8b8d0, (q31_t)0x4136fa27, (q31_t)0x91dbe8a4, + (q31_t)0x4121589b, (q31_t)0x91cf1cb6, (q31_t)0x410bb48c, (q31_t)0x91c25508, (q31_t)0x40f60dfb, (q31_t)0x91b5919a, (q31_t)0x40e064ea, (q31_t)0x91a8d26d, + (q31_t)0x40cab958, (q31_t)0x919c1781, (q31_t)0x40b50b46, (q31_t)0x918f60d6, (q31_t)0x409f5ab6, (q31_t)0x9182ae6d, (q31_t)0x4089a7a8, (q31_t)0x91760047, + (q31_t)0x4073f21d, (q31_t)0x91695663, (q31_t)0x405e3a16, (q31_t)0x915cb0c3, (q31_t)0x40487f94, (q31_t)0x91500f67, (q31_t)0x4032c297, (q31_t)0x91437250, + (q31_t)0x401d0321, (q31_t)0x9136d97d, (q31_t)0x40074132, (q31_t)0x912a44f0, (q31_t)0x3ff17cca, (q31_t)0x911db4a9, (q31_t)0x3fdbb5ec, (q31_t)0x911128a8, + (q31_t)0x3fc5ec98, (q31_t)0x9104a0ee, (q31_t)0x3fb020ce, (q31_t)0x90f81d7b, (q31_t)0x3f9a5290, (q31_t)0x90eb9e50, (q31_t)0x3f8481dd, (q31_t)0x90df236e, + (q31_t)0x3f6eaeb8, (q31_t)0x90d2acd4, (q31_t)0x3f58d921, (q31_t)0x90c63a83, (q31_t)0x3f430119, (q31_t)0x90b9cc7d, (q31_t)0x3f2d26a0, (q31_t)0x90ad62c0, + (q31_t)0x3f1749b8, (q31_t)0x90a0fd4e, (q31_t)0x3f016a61, (q31_t)0x90949c28, (q31_t)0x3eeb889c, (q31_t)0x90883f4d, (q31_t)0x3ed5a46b, (q31_t)0x907be6be, + (q31_t)0x3ebfbdcd, (q31_t)0x906f927c, (q31_t)0x3ea9d4c3, (q31_t)0x90634287, (q31_t)0x3e93e950, (q31_t)0x9056f6df, (q31_t)0x3e7dfb73, (q31_t)0x904aaf86, + (q31_t)0x3e680b2c, (q31_t)0x903e6c7b, (q31_t)0x3e52187f, (q31_t)0x90322dbf, (q31_t)0x3e3c2369, (q31_t)0x9025f352, (q31_t)0x3e262bee, (q31_t)0x9019bd36, + (q31_t)0x3e10320d, (q31_t)0x900d8b69, (q31_t)0x3dfa35c8, (q31_t)0x90015dee, (q31_t)0x3de4371f, (q31_t)0x8ff534c4, (q31_t)0x3dce3614, (q31_t)0x8fe90fec, + (q31_t)0x3db832a6, (q31_t)0x8fdcef66, (q31_t)0x3da22cd7, (q31_t)0x8fd0d333, (q31_t)0x3d8c24a8, (q31_t)0x8fc4bb53, (q31_t)0x3d761a19, (q31_t)0x8fb8a7c7, + (q31_t)0x3d600d2c, (q31_t)0x8fac988f, (q31_t)0x3d49fde1, (q31_t)0x8fa08dab, (q31_t)0x3d33ec39, (q31_t)0x8f94871d, (q31_t)0x3d1dd835, (q31_t)0x8f8884e4, + (q31_t)0x3d07c1d6, (q31_t)0x8f7c8701, (q31_t)0x3cf1a91c, (q31_t)0x8f708d75, (q31_t)0x3cdb8e09, (q31_t)0x8f649840, (q31_t)0x3cc5709e, (q31_t)0x8f58a761, + (q31_t)0x3caf50da, (q31_t)0x8f4cbadb, (q31_t)0x3c992ec0, (q31_t)0x8f40d2ad, (q31_t)0x3c830a50, (q31_t)0x8f34eed8, (q31_t)0x3c6ce38a, (q31_t)0x8f290f5c, + (q31_t)0x3c56ba70, (q31_t)0x8f1d343a, (q31_t)0x3c408f03, (q31_t)0x8f115d72, (q31_t)0x3c2a6142, (q31_t)0x8f058b04, (q31_t)0x3c143130, (q31_t)0x8ef9bcf2, + (q31_t)0x3bfdfecd, (q31_t)0x8eedf33b, (q31_t)0x3be7ca1a, (q31_t)0x8ee22de0, (q31_t)0x3bd19318, (q31_t)0x8ed66ce1, (q31_t)0x3bbb59c7, (q31_t)0x8ecab040, + (q31_t)0x3ba51e29, (q31_t)0x8ebef7fb, (q31_t)0x3b8ee03e, (q31_t)0x8eb34415, (q31_t)0x3b78a007, (q31_t)0x8ea7948c, (q31_t)0x3b625d86, (q31_t)0x8e9be963, + (q31_t)0x3b4c18ba, (q31_t)0x8e904298, (q31_t)0x3b35d1a5, (q31_t)0x8e84a02d, (q31_t)0x3b1f8848, (q31_t)0x8e790222, (q31_t)0x3b093ca3, (q31_t)0x8e6d6877, + (q31_t)0x3af2eeb7, (q31_t)0x8e61d32e, (q31_t)0x3adc9e86, (q31_t)0x8e564246, (q31_t)0x3ac64c0f, (q31_t)0x8e4ab5bf, (q31_t)0x3aaff755, (q31_t)0x8e3f2d9b, + (q31_t)0x3a99a057, (q31_t)0x8e33a9da, (q31_t)0x3a834717, (q31_t)0x8e282a7b, (q31_t)0x3a6ceb96, (q31_t)0x8e1caf80, (q31_t)0x3a568dd4, (q31_t)0x8e1138ea, + (q31_t)0x3a402dd2, (q31_t)0x8e05c6b7, (q31_t)0x3a29cb91, (q31_t)0x8dfa58ea, (q31_t)0x3a136712, (q31_t)0x8deeef82, (q31_t)0x39fd0056, (q31_t)0x8de38a80, + (q31_t)0x39e6975e, (q31_t)0x8dd829e4, (q31_t)0x39d02c2a, (q31_t)0x8dcccdaf, (q31_t)0x39b9bebc, (q31_t)0x8dc175e0, (q31_t)0x39a34f13, (q31_t)0x8db6227a, + (q31_t)0x398cdd32, (q31_t)0x8daad37b, (q31_t)0x39766919, (q31_t)0x8d9f88e5, (q31_t)0x395ff2c9, (q31_t)0x8d9442b8, (q31_t)0x39497a43, (q31_t)0x8d8900f3, + (q31_t)0x3932ff87, (q31_t)0x8d7dc399, (q31_t)0x391c8297, (q31_t)0x8d728aa9, (q31_t)0x39060373, (q31_t)0x8d675623, (q31_t)0x38ef821c, (q31_t)0x8d5c2609, + (q31_t)0x38d8fe93, (q31_t)0x8d50fa59, (q31_t)0x38c278d9, (q31_t)0x8d45d316, (q31_t)0x38abf0ef, (q31_t)0x8d3ab03f, (q31_t)0x389566d6, (q31_t)0x8d2f91d5, + (q31_t)0x387eda8e, (q31_t)0x8d2477d8, (q31_t)0x38684c19, (q31_t)0x8d196249, (q31_t)0x3851bb77, (q31_t)0x8d0e5127, (q31_t)0x383b28a9, (q31_t)0x8d034474, + (q31_t)0x382493b0, (q31_t)0x8cf83c30, (q31_t)0x380dfc8d, (q31_t)0x8ced385b, (q31_t)0x37f76341, (q31_t)0x8ce238f6, (q31_t)0x37e0c7cc, (q31_t)0x8cd73e01, + (q31_t)0x37ca2a30, (q31_t)0x8ccc477d, (q31_t)0x37b38a6d, (q31_t)0x8cc1556a, (q31_t)0x379ce885, (q31_t)0x8cb667c8, (q31_t)0x37864477, (q31_t)0x8cab7e98, + (q31_t)0x376f9e46, (q31_t)0x8ca099da, (q31_t)0x3758f5f2, (q31_t)0x8c95b98f, (q31_t)0x37424b7b, (q31_t)0x8c8addb7, (q31_t)0x372b9ee3, (q31_t)0x8c800652, + (q31_t)0x3714f02a, (q31_t)0x8c753362, (q31_t)0x36fe3f52, (q31_t)0x8c6a64e5, (q31_t)0x36e78c5b, (q31_t)0x8c5f9ade, (q31_t)0x36d0d746, (q31_t)0x8c54d54c, + (q31_t)0x36ba2014, (q31_t)0x8c4a142f, (q31_t)0x36a366c6, (q31_t)0x8c3f5788, (q31_t)0x368cab5c, (q31_t)0x8c349f58, (q31_t)0x3675edd9, (q31_t)0x8c29eb9f, + (q31_t)0x365f2e3b, (q31_t)0x8c1f3c5d, (q31_t)0x36486c86, (q31_t)0x8c149192, (q31_t)0x3631a8b8, (q31_t)0x8c09eb40, (q31_t)0x361ae2d3, (q31_t)0x8bff4966, + (q31_t)0x36041ad9, (q31_t)0x8bf4ac05, (q31_t)0x35ed50c9, (q31_t)0x8bea131e, (q31_t)0x35d684a6, (q31_t)0x8bdf7eb0, (q31_t)0x35bfb66e, (q31_t)0x8bd4eebc, + (q31_t)0x35a8e625, (q31_t)0x8bca6343, (q31_t)0x359213c9, (q31_t)0x8bbfdc44, (q31_t)0x357b3f5d, (q31_t)0x8bb559c1, (q31_t)0x356468e2, (q31_t)0x8baadbba, + (q31_t)0x354d9057, (q31_t)0x8ba0622f, (q31_t)0x3536b5be, (q31_t)0x8b95ed21, (q31_t)0x351fd918, (q31_t)0x8b8b7c8f, (q31_t)0x3508fa66, (q31_t)0x8b81107b, + (q31_t)0x34f219a8, (q31_t)0x8b76a8e4, (q31_t)0x34db36df, (q31_t)0x8b6c45cc, (q31_t)0x34c4520d, (q31_t)0x8b61e733, (q31_t)0x34ad6b32, (q31_t)0x8b578d18, + (q31_t)0x34968250, (q31_t)0x8b4d377c, (q31_t)0x347f9766, (q31_t)0x8b42e661, (q31_t)0x3468aa76, (q31_t)0x8b3899c6, (q31_t)0x3451bb81, (q31_t)0x8b2e51ab, + (q31_t)0x343aca87, (q31_t)0x8b240e11, (q31_t)0x3423d78a, (q31_t)0x8b19cef8, (q31_t)0x340ce28b, (q31_t)0x8b0f9462, (q31_t)0x33f5eb89, (q31_t)0x8b055e4d, + (q31_t)0x33def287, (q31_t)0x8afb2cbb, (q31_t)0x33c7f785, (q31_t)0x8af0ffac, (q31_t)0x33b0fa84, (q31_t)0x8ae6d720, (q31_t)0x3399fb85, (q31_t)0x8adcb318, + (q31_t)0x3382fa88, (q31_t)0x8ad29394, (q31_t)0x336bf78f, (q31_t)0x8ac87894, (q31_t)0x3354f29b, (q31_t)0x8abe6219, (q31_t)0x333debab, (q31_t)0x8ab45024, + (q31_t)0x3326e2c3, (q31_t)0x8aaa42b4, (q31_t)0x330fd7e1, (q31_t)0x8aa039cb, (q31_t)0x32f8cb07, (q31_t)0x8a963567, (q31_t)0x32e1bc36, (q31_t)0x8a8c358b, + (q31_t)0x32caab6f, (q31_t)0x8a823a36, (q31_t)0x32b398b3, (q31_t)0x8a784368, (q31_t)0x329c8402, (q31_t)0x8a6e5123, (q31_t)0x32856d5e, (q31_t)0x8a646365, + (q31_t)0x326e54c7, (q31_t)0x8a5a7a31, (q31_t)0x32573a3f, (q31_t)0x8a509585, (q31_t)0x32401dc6, (q31_t)0x8a46b564, (q31_t)0x3228ff5c, (q31_t)0x8a3cd9cc, + (q31_t)0x3211df04, (q31_t)0x8a3302be, (q31_t)0x31fabcbd, (q31_t)0x8a29303b, (q31_t)0x31e39889, (q31_t)0x8a1f6243, (q31_t)0x31cc7269, (q31_t)0x8a1598d6, + (q31_t)0x31b54a5e, (q31_t)0x8a0bd3f5, (q31_t)0x319e2067, (q31_t)0x8a0213a0, (q31_t)0x3186f487, (q31_t)0x89f857d8, (q31_t)0x316fc6be, (q31_t)0x89eea09d, + (q31_t)0x3158970e, (q31_t)0x89e4edef, (q31_t)0x31416576, (q31_t)0x89db3fcf, (q31_t)0x312a31f8, (q31_t)0x89d1963c, (q31_t)0x3112fc95, (q31_t)0x89c7f138, + (q31_t)0x30fbc54d, (q31_t)0x89be50c3, (q31_t)0x30e48c22, (q31_t)0x89b4b4dd, (q31_t)0x30cd5115, (q31_t)0x89ab1d87, (q31_t)0x30b61426, (q31_t)0x89a18ac0, + (q31_t)0x309ed556, (q31_t)0x8997fc8a, (q31_t)0x308794a6, (q31_t)0x898e72e4, (q31_t)0x30705217, (q31_t)0x8984edcf, (q31_t)0x30590dab, (q31_t)0x897b6d4c, + (q31_t)0x3041c761, (q31_t)0x8971f15a, (q31_t)0x302a7f3a, (q31_t)0x896879fb, (q31_t)0x30133539, (q31_t)0x895f072e, (q31_t)0x2ffbe95d, (q31_t)0x895598f3, + (q31_t)0x2fe49ba7, (q31_t)0x894c2f4c, (q31_t)0x2fcd4c19, (q31_t)0x8942ca39, (q31_t)0x2fb5fab2, (q31_t)0x893969b9, (q31_t)0x2f9ea775, (q31_t)0x89300dce, + (q31_t)0x2f875262, (q31_t)0x8926b677, (q31_t)0x2f6ffb7a, (q31_t)0x891d63b5, (q31_t)0x2f58a2be, (q31_t)0x89141589, (q31_t)0x2f41482e, (q31_t)0x890acbf2, + (q31_t)0x2f29ebcc, (q31_t)0x890186f2, (q31_t)0x2f128d99, (q31_t)0x88f84687, (q31_t)0x2efb2d95, (q31_t)0x88ef0ab4, (q31_t)0x2ee3cbc1, (q31_t)0x88e5d378, + (q31_t)0x2ecc681e, (q31_t)0x88dca0d3, (q31_t)0x2eb502ae, (q31_t)0x88d372c6, (q31_t)0x2e9d9b70, (q31_t)0x88ca4951, (q31_t)0x2e863267, (q31_t)0x88c12475, + (q31_t)0x2e6ec792, (q31_t)0x88b80432, (q31_t)0x2e575af3, (q31_t)0x88aee888, (q31_t)0x2e3fec8b, (q31_t)0x88a5d177, (q31_t)0x2e287c5a, (q31_t)0x889cbf01, + (q31_t)0x2e110a62, (q31_t)0x8893b125, (q31_t)0x2df996a3, (q31_t)0x888aa7e3, (q31_t)0x2de2211e, (q31_t)0x8881a33d, (q31_t)0x2dcaa9d5, (q31_t)0x8878a332, + (q31_t)0x2db330c7, (q31_t)0x886fa7c2, (q31_t)0x2d9bb5f6, (q31_t)0x8866b0ef, (q31_t)0x2d843964, (q31_t)0x885dbeb8, (q31_t)0x2d6cbb10, (q31_t)0x8854d11e, + (q31_t)0x2d553afc, (q31_t)0x884be821, (q31_t)0x2d3db928, (q31_t)0x884303c1, (q31_t)0x2d263596, (q31_t)0x883a23ff, (q31_t)0x2d0eb046, (q31_t)0x883148db, + (q31_t)0x2cf72939, (q31_t)0x88287256, (q31_t)0x2cdfa071, (q31_t)0x881fa06f, (q31_t)0x2cc815ee, (q31_t)0x8816d327, (q31_t)0x2cb089b1, (q31_t)0x880e0a7f, + (q31_t)0x2c98fbba, (q31_t)0x88054677, (q31_t)0x2c816c0c, (q31_t)0x87fc870f, (q31_t)0x2c69daa6, (q31_t)0x87f3cc48, (q31_t)0x2c52478a, (q31_t)0x87eb1621, + (q31_t)0x2c3ab2b9, (q31_t)0x87e2649b, (q31_t)0x2c231c33, (q31_t)0x87d9b7b7, (q31_t)0x2c0b83fa, (q31_t)0x87d10f75, (q31_t)0x2bf3ea0d, (q31_t)0x87c86bd5, + (q31_t)0x2bdc4e6f, (q31_t)0x87bfccd7, (q31_t)0x2bc4b120, (q31_t)0x87b7327d, (q31_t)0x2bad1221, (q31_t)0x87ae9cc5, (q31_t)0x2b957173, (q31_t)0x87a60bb1, + (q31_t)0x2b7dcf17, (q31_t)0x879d7f41, (q31_t)0x2b662b0e, (q31_t)0x8794f774, (q31_t)0x2b4e8558, (q31_t)0x878c744d, (q31_t)0x2b36ddf7, (q31_t)0x8783f5ca, + (q31_t)0x2b1f34eb, (q31_t)0x877b7bec, (q31_t)0x2b078a36, (q31_t)0x877306b4, (q31_t)0x2aefddd8, (q31_t)0x876a9621, (q31_t)0x2ad82fd2, (q31_t)0x87622a35, + (q31_t)0x2ac08026, (q31_t)0x8759c2ef, (q31_t)0x2aa8ced3, (q31_t)0x87516050, (q31_t)0x2a911bdc, (q31_t)0x87490258, (q31_t)0x2a796740, (q31_t)0x8740a907, + (q31_t)0x2a61b101, (q31_t)0x8738545e, (q31_t)0x2a49f920, (q31_t)0x8730045d, (q31_t)0x2a323f9e, (q31_t)0x8727b905, (q31_t)0x2a1a847b, (q31_t)0x871f7255, + (q31_t)0x2a02c7b8, (q31_t)0x8717304e, (q31_t)0x29eb0957, (q31_t)0x870ef2f1, (q31_t)0x29d34958, (q31_t)0x8706ba3d, (q31_t)0x29bb87bc, (q31_t)0x86fe8633, + (q31_t)0x29a3c485, (q31_t)0x86f656d3, (q31_t)0x298bffb2, (q31_t)0x86ee2c1e, (q31_t)0x29743946, (q31_t)0x86e60614, (q31_t)0x295c7140, (q31_t)0x86dde4b5, + (q31_t)0x2944a7a2, (q31_t)0x86d5c802, (q31_t)0x292cdc6d, (q31_t)0x86cdaffa, (q31_t)0x29150fa1, (q31_t)0x86c59c9f, (q31_t)0x28fd4140, (q31_t)0x86bd8df0, + (q31_t)0x28e5714b, (q31_t)0x86b583ee, (q31_t)0x28cd9fc1, (q31_t)0x86ad7e99, (q31_t)0x28b5cca5, (q31_t)0x86a57df2, (q31_t)0x289df7f8, (q31_t)0x869d81f8, + (q31_t)0x288621b9, (q31_t)0x86958aac, (q31_t)0x286e49ea, (q31_t)0x868d980e, (q31_t)0x2856708d, (q31_t)0x8685aa20, (q31_t)0x283e95a1, (q31_t)0x867dc0e0, + (q31_t)0x2826b928, (q31_t)0x8675dc4f, (q31_t)0x280edb23, (q31_t)0x866dfc6e, (q31_t)0x27f6fb92, (q31_t)0x8666213c, (q31_t)0x27df1a77, (q31_t)0x865e4abb, + (q31_t)0x27c737d3, (q31_t)0x865678eb, (q31_t)0x27af53a6, (q31_t)0x864eabcb, (q31_t)0x27976df1, (q31_t)0x8646e35c, (q31_t)0x277f86b5, (q31_t)0x863f1f9e, + (q31_t)0x27679df4, (q31_t)0x86376092, (q31_t)0x274fb3ae, (q31_t)0x862fa638, (q31_t)0x2737c7e3, (q31_t)0x8627f091, (q31_t)0x271fda96, (q31_t)0x86203f9c, + (q31_t)0x2707ebc7, (q31_t)0x86189359, (q31_t)0x26effb76, (q31_t)0x8610ebca, (q31_t)0x26d809a5, (q31_t)0x860948ef, (q31_t)0x26c01655, (q31_t)0x8601aac7, + (q31_t)0x26a82186, (q31_t)0x85fa1153, (q31_t)0x26902b39, (q31_t)0x85f27c93, (q31_t)0x26783370, (q31_t)0x85eaec88, (q31_t)0x26603a2c, (q31_t)0x85e36132, + (q31_t)0x26483f6c, (q31_t)0x85dbda91, (q31_t)0x26304333, (q31_t)0x85d458a6, (q31_t)0x26184581, (q31_t)0x85ccdb70, (q31_t)0x26004657, (q31_t)0x85c562f1, + (q31_t)0x25e845b6, (q31_t)0x85bdef28, (q31_t)0x25d0439f, (q31_t)0x85b68015, (q31_t)0x25b84012, (q31_t)0x85af15b9, (q31_t)0x25a03b11, (q31_t)0x85a7b015, + (q31_t)0x2588349d, (q31_t)0x85a04f28, (q31_t)0x25702cb7, (q31_t)0x8598f2f3, (q31_t)0x2558235f, (q31_t)0x85919b76, (q31_t)0x25401896, (q31_t)0x858a48b1, + (q31_t)0x25280c5e, (q31_t)0x8582faa5, (q31_t)0x250ffeb7, (q31_t)0x857bb152, (q31_t)0x24f7efa2, (q31_t)0x85746cb8, (q31_t)0x24dfdf20, (q31_t)0x856d2cd7, + (q31_t)0x24c7cd33, (q31_t)0x8565f1b0, (q31_t)0x24afb9da, (q31_t)0x855ebb44, (q31_t)0x2497a517, (q31_t)0x85578991, (q31_t)0x247f8eec, (q31_t)0x85505c99, + (q31_t)0x24677758, (q31_t)0x8549345c, (q31_t)0x244f5e5c, (q31_t)0x854210db, (q31_t)0x243743fa, (q31_t)0x853af214, (q31_t)0x241f2833, (q31_t)0x8533d809, + (q31_t)0x24070b08, (q31_t)0x852cc2bb, (q31_t)0x23eeec78, (q31_t)0x8525b228, (q31_t)0x23d6cc87, (q31_t)0x851ea652, (q31_t)0x23beab33, (q31_t)0x85179f39, + (q31_t)0x23a6887f, (q31_t)0x85109cdd, (q31_t)0x238e646a, (q31_t)0x85099f3e, (q31_t)0x23763ef7, (q31_t)0x8502a65c, (q31_t)0x235e1826, (q31_t)0x84fbb239, + (q31_t)0x2345eff8, (q31_t)0x84f4c2d4, (q31_t)0x232dc66d, (q31_t)0x84edd82d, (q31_t)0x23159b88, (q31_t)0x84e6f244, (q31_t)0x22fd6f48, (q31_t)0x84e0111b, + (q31_t)0x22e541af, (q31_t)0x84d934b1, (q31_t)0x22cd12bd, (q31_t)0x84d25d06, (q31_t)0x22b4e274, (q31_t)0x84cb8a1b, (q31_t)0x229cb0d5, (q31_t)0x84c4bbf0, + (q31_t)0x22847de0, (q31_t)0x84bdf286, (q31_t)0x226c4996, (q31_t)0x84b72ddb, (q31_t)0x225413f8, (q31_t)0x84b06df2, (q31_t)0x223bdd08, (q31_t)0x84a9b2ca, + (q31_t)0x2223a4c5, (q31_t)0x84a2fc62, (q31_t)0x220b6b32, (q31_t)0x849c4abd, (q31_t)0x21f3304f, (q31_t)0x84959dd9, (q31_t)0x21daf41d, (q31_t)0x848ef5b7, + (q31_t)0x21c2b69c, (q31_t)0x84885258, (q31_t)0x21aa77cf, (q31_t)0x8481b3bb, (q31_t)0x219237b5, (q31_t)0x847b19e1, (q31_t)0x2179f64f, (q31_t)0x847484ca, + (q31_t)0x2161b3a0, (q31_t)0x846df477, (q31_t)0x21496fa7, (q31_t)0x846768e7, (q31_t)0x21312a65, (q31_t)0x8460e21a, (q31_t)0x2118e3dc, (q31_t)0x845a6012, + (q31_t)0x21009c0c, (q31_t)0x8453e2cf, (q31_t)0x20e852f6, (q31_t)0x844d6a50, (q31_t)0x20d0089c, (q31_t)0x8446f695, (q31_t)0x20b7bcfe, (q31_t)0x844087a0, + (q31_t)0x209f701c, (q31_t)0x843a1d70, (q31_t)0x208721f9, (q31_t)0x8433b806, (q31_t)0x206ed295, (q31_t)0x842d5762, (q31_t)0x205681f1, (q31_t)0x8426fb84, + (q31_t)0x203e300d, (q31_t)0x8420a46c, (q31_t)0x2025dcec, (q31_t)0x841a521a, (q31_t)0x200d888d, (q31_t)0x84140490, (q31_t)0x1ff532f2, (q31_t)0x840dbbcc, + (q31_t)0x1fdcdc1b, (q31_t)0x840777d0, (q31_t)0x1fc4840a, (q31_t)0x8401389b, (q31_t)0x1fac2abf, (q31_t)0x83fafe2e, (q31_t)0x1f93d03c, (q31_t)0x83f4c889, + (q31_t)0x1f7b7481, (q31_t)0x83ee97ad, (q31_t)0x1f63178f, (q31_t)0x83e86b99, (q31_t)0x1f4ab968, (q31_t)0x83e2444d, (q31_t)0x1f325a0b, (q31_t)0x83dc21cb, + (q31_t)0x1f19f97b, (q31_t)0x83d60412, (q31_t)0x1f0197b8, (q31_t)0x83cfeb22, (q31_t)0x1ee934c3, (q31_t)0x83c9d6fc, (q31_t)0x1ed0d09d, (q31_t)0x83c3c7a0, + (q31_t)0x1eb86b46, (q31_t)0x83bdbd0e, (q31_t)0x1ea004c1, (q31_t)0x83b7b746, (q31_t)0x1e879d0d, (q31_t)0x83b1b649, (q31_t)0x1e6f342c, (q31_t)0x83abba17, + (q31_t)0x1e56ca1e, (q31_t)0x83a5c2b0, (q31_t)0x1e3e5ee5, (q31_t)0x839fd014, (q31_t)0x1e25f282, (q31_t)0x8399e244, (q31_t)0x1e0d84f5, (q31_t)0x8393f940, + (q31_t)0x1df5163f, (q31_t)0x838e1507, (q31_t)0x1ddca662, (q31_t)0x8388359b, (q31_t)0x1dc4355e, (q31_t)0x83825afb, (q31_t)0x1dabc334, (q31_t)0x837c8528, + (q31_t)0x1d934fe5, (q31_t)0x8376b422, (q31_t)0x1d7adb73, (q31_t)0x8370e7e9, (q31_t)0x1d6265dd, (q31_t)0x836b207d, (q31_t)0x1d49ef26, (q31_t)0x83655ddf, + (q31_t)0x1d31774d, (q31_t)0x835fa00f, (q31_t)0x1d18fe54, (q31_t)0x8359e70d, (q31_t)0x1d00843d, (q31_t)0x835432d8, (q31_t)0x1ce80906, (q31_t)0x834e8373, + (q31_t)0x1ccf8cb3, (q31_t)0x8348d8dc, (q31_t)0x1cb70f43, (q31_t)0x83433314, (q31_t)0x1c9e90b8, (q31_t)0x833d921b, (q31_t)0x1c861113, (q31_t)0x8337f5f1, + (q31_t)0x1c6d9053, (q31_t)0x83325e97, (q31_t)0x1c550e7c, (q31_t)0x832ccc0d, (q31_t)0x1c3c8b8c, (q31_t)0x83273e52, (q31_t)0x1c240786, (q31_t)0x8321b568, + (q31_t)0x1c0b826a, (q31_t)0x831c314e, (q31_t)0x1bf2fc3a, (q31_t)0x8316b205, (q31_t)0x1bda74f6, (q31_t)0x8311378d, (q31_t)0x1bc1ec9e, (q31_t)0x830bc1e6, + (q31_t)0x1ba96335, (q31_t)0x83065110, (q31_t)0x1b90d8bb, (q31_t)0x8300e50b, (q31_t)0x1b784d30, (q31_t)0x82fb7dd8, (q31_t)0x1b5fc097, (q31_t)0x82f61b77, + (q31_t)0x1b4732ef, (q31_t)0x82f0bde8, (q31_t)0x1b2ea43a, (q31_t)0x82eb652b, (q31_t)0x1b161479, (q31_t)0x82e61141, (q31_t)0x1afd83ad, (q31_t)0x82e0c22a, + (q31_t)0x1ae4f1d6, (q31_t)0x82db77e5, (q31_t)0x1acc5ef6, (q31_t)0x82d63274, (q31_t)0x1ab3cb0d, (q31_t)0x82d0f1d5, (q31_t)0x1a9b361d, (q31_t)0x82cbb60b, + (q31_t)0x1a82a026, (q31_t)0x82c67f14, (q31_t)0x1a6a0929, (q31_t)0x82c14cf1, (q31_t)0x1a517128, (q31_t)0x82bc1fa2, (q31_t)0x1a38d823, (q31_t)0x82b6f727, + (q31_t)0x1a203e1b, (q31_t)0x82b1d381, (q31_t)0x1a07a311, (q31_t)0x82acb4b0, (q31_t)0x19ef0707, (q31_t)0x82a79ab3, (q31_t)0x19d669fc, (q31_t)0x82a2858c, + (q31_t)0x19bdcbf3, (q31_t)0x829d753a, (q31_t)0x19a52ceb, (q31_t)0x829869be, (q31_t)0x198c8ce7, (q31_t)0x82936317, (q31_t)0x1973ebe6, (q31_t)0x828e6146, + (q31_t)0x195b49ea, (q31_t)0x8289644b, (q31_t)0x1942a6f3, (q31_t)0x82846c26, (q31_t)0x192a0304, (q31_t)0x827f78d8, (q31_t)0x19115e1c, (q31_t)0x827a8a61, + (q31_t)0x18f8b83c, (q31_t)0x8275a0c0, (q31_t)0x18e01167, (q31_t)0x8270bbf7, (q31_t)0x18c7699b, (q31_t)0x826bdc04, (q31_t)0x18aec0db, (q31_t)0x826700e9, + (q31_t)0x18961728, (q31_t)0x82622aa6, (q31_t)0x187d6c82, (q31_t)0x825d593a, (q31_t)0x1864c0ea, (q31_t)0x82588ca7, (q31_t)0x184c1461, (q31_t)0x8253c4eb, + (q31_t)0x183366e9, (q31_t)0x824f0208, (q31_t)0x181ab881, (q31_t)0x824a43fe, (q31_t)0x1802092c, (q31_t)0x82458acc, (q31_t)0x17e958ea, (q31_t)0x8240d673, + (q31_t)0x17d0a7bc, (q31_t)0x823c26f3, (q31_t)0x17b7f5a3, (q31_t)0x82377c4c, (q31_t)0x179f429f, (q31_t)0x8232d67f, (q31_t)0x17868eb3, (q31_t)0x822e358b, + (q31_t)0x176dd9de, (q31_t)0x82299971, (q31_t)0x17552422, (q31_t)0x82250232, (q31_t)0x173c6d80, (q31_t)0x82206fcc, (q31_t)0x1723b5f9, (q31_t)0x821be240, + (q31_t)0x170afd8d, (q31_t)0x82175990, (q31_t)0x16f2443e, (q31_t)0x8212d5b9, (q31_t)0x16d98a0c, (q31_t)0x820e56be, (q31_t)0x16c0cef9, (q31_t)0x8209dc9e, + (q31_t)0x16a81305, (q31_t)0x82056758, (q31_t)0x168f5632, (q31_t)0x8200f6ef, (q31_t)0x1676987f, (q31_t)0x81fc8b60, (q31_t)0x165dd9f0, (q31_t)0x81f824ae, + (q31_t)0x16451a83, (q31_t)0x81f3c2d7, (q31_t)0x162c5a3b, (q31_t)0x81ef65dc, (q31_t)0x16139918, (q31_t)0x81eb0dbe, (q31_t)0x15fad71b, (q31_t)0x81e6ba7c, + (q31_t)0x15e21445, (q31_t)0x81e26c16, (q31_t)0x15c95097, (q31_t)0x81de228d, (q31_t)0x15b08c12, (q31_t)0x81d9dde1, (q31_t)0x1597c6b7, (q31_t)0x81d59e13, + (q31_t)0x157f0086, (q31_t)0x81d16321, (q31_t)0x15663982, (q31_t)0x81cd2d0c, (q31_t)0x154d71aa, (q31_t)0x81c8fbd6, (q31_t)0x1534a901, (q31_t)0x81c4cf7d, + (q31_t)0x151bdf86, (q31_t)0x81c0a801, (q31_t)0x1503153a, (q31_t)0x81bc8564, (q31_t)0x14ea4a1f, (q31_t)0x81b867a5, (q31_t)0x14d17e36, (q31_t)0x81b44ec4, + (q31_t)0x14b8b17f, (q31_t)0x81b03ac2, (q31_t)0x149fe3fc, (q31_t)0x81ac2b9e, (q31_t)0x148715ae, (q31_t)0x81a82159, (q31_t)0x146e4694, (q31_t)0x81a41bf4, + (q31_t)0x145576b1, (q31_t)0x81a01b6d, (q31_t)0x143ca605, (q31_t)0x819c1fc5, (q31_t)0x1423d492, (q31_t)0x819828fd, (q31_t)0x140b0258, (q31_t)0x81943715, + (q31_t)0x13f22f58, (q31_t)0x81904a0c, (q31_t)0x13d95b93, (q31_t)0x818c61e3, (q31_t)0x13c0870a, (q31_t)0x81887e9a, (q31_t)0x13a7b1bf, (q31_t)0x8184a032, + (q31_t)0x138edbb1, (q31_t)0x8180c6a9, (q31_t)0x137604e2, (q31_t)0x817cf201, (q31_t)0x135d2d53, (q31_t)0x8179223a, (q31_t)0x13445505, (q31_t)0x81755754, + (q31_t)0x132b7bf9, (q31_t)0x8171914e, (q31_t)0x1312a230, (q31_t)0x816dd02a, (q31_t)0x12f9c7aa, (q31_t)0x816a13e6, (q31_t)0x12e0ec6a, (q31_t)0x81665c84, + (q31_t)0x12c8106f, (q31_t)0x8162aa04, (q31_t)0x12af33ba, (q31_t)0x815efc65, (q31_t)0x1296564d, (q31_t)0x815b53a8, (q31_t)0x127d7829, (q31_t)0x8157afcd, + (q31_t)0x1264994e, (q31_t)0x815410d4, (q31_t)0x124bb9be, (q31_t)0x815076bd, (q31_t)0x1232d979, (q31_t)0x814ce188, (q31_t)0x1219f880, (q31_t)0x81495136, + (q31_t)0x120116d5, (q31_t)0x8145c5c7, (q31_t)0x11e83478, (q31_t)0x81423f3a, (q31_t)0x11cf516a, (q31_t)0x813ebd90, (q31_t)0x11b66dad, (q31_t)0x813b40ca, + (q31_t)0x119d8941, (q31_t)0x8137c8e6, (q31_t)0x1184a427, (q31_t)0x813455e6, (q31_t)0x116bbe60, (q31_t)0x8130e7c9, (q31_t)0x1152d7ed, (q31_t)0x812d7e8f, + (q31_t)0x1139f0cf, (q31_t)0x812a1a3a, (q31_t)0x11210907, (q31_t)0x8126bac8, (q31_t)0x11082096, (q31_t)0x8123603a, (q31_t)0x10ef377d, (q31_t)0x81200a90, + (q31_t)0x10d64dbd, (q31_t)0x811cb9ca, (q31_t)0x10bd6356, (q31_t)0x81196de9, (q31_t)0x10a4784b, (q31_t)0x811626ec, (q31_t)0x108b8c9b, (q31_t)0x8112e4d4, + (q31_t)0x1072a048, (q31_t)0x810fa7a0, (q31_t)0x1059b352, (q31_t)0x810c6f52, (q31_t)0x1040c5bb, (q31_t)0x81093be8, (q31_t)0x1027d784, (q31_t)0x81060d63, + (q31_t)0x100ee8ad, (q31_t)0x8102e3c4, (q31_t)0xff5f938, (q31_t)0x80ffbf0a, (q31_t)0xfdd0926, (q31_t)0x80fc9f35, (q31_t)0xfc41876, (q31_t)0x80f98446, + (q31_t)0xfab272b, (q31_t)0x80f66e3c, (q31_t)0xf923546, (q31_t)0x80f35d19, (q31_t)0xf7942c7, (q31_t)0x80f050db, (q31_t)0xf604faf, (q31_t)0x80ed4984, + (q31_t)0xf475bff, (q31_t)0x80ea4712, (q31_t)0xf2e67b8, (q31_t)0x80e74987, (q31_t)0xf1572dc, (q31_t)0x80e450e2, (q31_t)0xefc7d6b, (q31_t)0x80e15d24, + (q31_t)0xee38766, (q31_t)0x80de6e4c, (q31_t)0xeca90ce, (q31_t)0x80db845b, (q31_t)0xeb199a4, (q31_t)0x80d89f51, (q31_t)0xe98a1e9, (q31_t)0x80d5bf2e, + (q31_t)0xe7fa99e, (q31_t)0x80d2e3f2, (q31_t)0xe66b0c3, (q31_t)0x80d00d9d, (q31_t)0xe4db75b, (q31_t)0x80cd3c2f, (q31_t)0xe34bd66, (q31_t)0x80ca6fa9, + (q31_t)0xe1bc2e4, (q31_t)0x80c7a80a, (q31_t)0xe02c7d7, (q31_t)0x80c4e553, (q31_t)0xde9cc40, (q31_t)0x80c22784, (q31_t)0xdd0d01f, (q31_t)0x80bf6e9c, + (q31_t)0xdb7d376, (q31_t)0x80bcba9d, (q31_t)0xd9ed646, (q31_t)0x80ba0b85, (q31_t)0xd85d88f, (q31_t)0x80b76156, (q31_t)0xd6cda53, (q31_t)0x80b4bc0e, + (q31_t)0xd53db92, (q31_t)0x80b21baf, (q31_t)0xd3adc4e, (q31_t)0x80af8039, (q31_t)0xd21dc87, (q31_t)0x80ace9ab, (q31_t)0xd08dc3f, (q31_t)0x80aa5806, + (q31_t)0xcefdb76, (q31_t)0x80a7cb49, (q31_t)0xcd6da2d, (q31_t)0x80a54376, (q31_t)0xcbdd865, (q31_t)0x80a2c08b, (q31_t)0xca4d620, (q31_t)0x80a04289, + (q31_t)0xc8bd35e, (q31_t)0x809dc971, (q31_t)0xc72d020, (q31_t)0x809b5541, (q31_t)0xc59cc68, (q31_t)0x8098e5fb, (q31_t)0xc40c835, (q31_t)0x80967b9f, + (q31_t)0xc27c389, (q31_t)0x8094162c, (q31_t)0xc0ebe66, (q31_t)0x8091b5a2, (q31_t)0xbf5b8cb, (q31_t)0x808f5a02, (q31_t)0xbdcb2bb, (q31_t)0x808d034c, + (q31_t)0xbc3ac35, (q31_t)0x808ab180, (q31_t)0xbaaa53b, (q31_t)0x8088649e, (q31_t)0xb919dcf, (q31_t)0x80861ca6, (q31_t)0xb7895f0, (q31_t)0x8083d998, + (q31_t)0xb5f8d9f, (q31_t)0x80819b74, (q31_t)0xb4684df, (q31_t)0x807f623b, (q31_t)0xb2d7baf, (q31_t)0x807d2dec, (q31_t)0xb147211, (q31_t)0x807afe87, + (q31_t)0xafb6805, (q31_t)0x8078d40d, (q31_t)0xae25d8d, (q31_t)0x8076ae7e, (q31_t)0xac952aa, (q31_t)0x80748dd9, (q31_t)0xab0475c, (q31_t)0x8072721f, + (q31_t)0xa973ba5, (q31_t)0x80705b50, (q31_t)0xa7e2f85, (q31_t)0x806e496c, (q31_t)0xa6522fe, (q31_t)0x806c3c74, (q31_t)0xa4c1610, (q31_t)0x806a3466, + (q31_t)0xa3308bd, (q31_t)0x80683143, (q31_t)0xa19fb04, (q31_t)0x8066330c, (q31_t)0xa00ece8, (q31_t)0x806439c0, (q31_t)0x9e7de6a, (q31_t)0x80624560, + (q31_t)0x9cecf89, (q31_t)0x806055eb, (q31_t)0x9b5c048, (q31_t)0x805e6b62, (q31_t)0x99cb0a7, (q31_t)0x805c85c4, (q31_t)0x983a0a7, (q31_t)0x805aa512, + (q31_t)0x96a9049, (q31_t)0x8058c94c, (q31_t)0x9517f8f, (q31_t)0x8056f272, (q31_t)0x9386e78, (q31_t)0x80552084, (q31_t)0x91f5d06, (q31_t)0x80535381, + (q31_t)0x9064b3a, (q31_t)0x80518b6b, (q31_t)0x8ed3916, (q31_t)0x804fc841, (q31_t)0x8d42699, (q31_t)0x804e0a04, (q31_t)0x8bb13c5, (q31_t)0x804c50b2, + (q31_t)0x8a2009a, (q31_t)0x804a9c4d, (q31_t)0x888ed1b, (q31_t)0x8048ecd5, (q31_t)0x86fd947, (q31_t)0x80474248, (q31_t)0x856c520, (q31_t)0x80459ca9, + (q31_t)0x83db0a7, (q31_t)0x8043fbf6, (q31_t)0x8249bdd, (q31_t)0x80426030, (q31_t)0x80b86c2, (q31_t)0x8040c956, (q31_t)0x7f27157, (q31_t)0x803f376a, + (q31_t)0x7d95b9e, (q31_t)0x803daa6a, (q31_t)0x7c04598, (q31_t)0x803c2257, (q31_t)0x7a72f45, (q31_t)0x803a9f31, (q31_t)0x78e18a7, (q31_t)0x803920f8, + (q31_t)0x77501be, (q31_t)0x8037a7ac, (q31_t)0x75bea8c, (q31_t)0x8036334e, (q31_t)0x742d311, (q31_t)0x8034c3dd, (q31_t)0x729bb4e, (q31_t)0x80335959, + (q31_t)0x710a345, (q31_t)0x8031f3c2, (q31_t)0x6f78af6, (q31_t)0x80309318, (q31_t)0x6de7262, (q31_t)0x802f375d, (q31_t)0x6c5598a, (q31_t)0x802de08e, + (q31_t)0x6ac406f, (q31_t)0x802c8ead, (q31_t)0x6932713, (q31_t)0x802b41ba, (q31_t)0x67a0d76, (q31_t)0x8029f9b4, (q31_t)0x660f398, (q31_t)0x8028b69c, + (q31_t)0x647d97c, (q31_t)0x80277872, (q31_t)0x62ebf22, (q31_t)0x80263f36, (q31_t)0x615a48b, (q31_t)0x80250ae7, (q31_t)0x5fc89b8, (q31_t)0x8023db86, + (q31_t)0x5e36ea9, (q31_t)0x8022b114, (q31_t)0x5ca5361, (q31_t)0x80218b8f, (q31_t)0x5b137df, (q31_t)0x80206af8, (q31_t)0x5981c26, (q31_t)0x801f4f4f, + (q31_t)0x57f0035, (q31_t)0x801e3895, (q31_t)0x565e40d, (q31_t)0x801d26c8, (q31_t)0x54cc7b1, (q31_t)0x801c19ea, (q31_t)0x533ab20, (q31_t)0x801b11fa, + (q31_t)0x51a8e5c, (q31_t)0x801a0ef8, (q31_t)0x5017165, (q31_t)0x801910e4, (q31_t)0x4e8543e, (q31_t)0x801817bf, (q31_t)0x4cf36e5, (q31_t)0x80172388, + (q31_t)0x4b6195d, (q31_t)0x80163440, (q31_t)0x49cfba7, (q31_t)0x801549e6, (q31_t)0x483ddc3, (q31_t)0x8014647b, (q31_t)0x46abfb3, (q31_t)0x801383fe, + (q31_t)0x451a177, (q31_t)0x8012a86f, (q31_t)0x4388310, (q31_t)0x8011d1d0, (q31_t)0x41f6480, (q31_t)0x8011001f, (q31_t)0x40645c7, (q31_t)0x8010335c, + (q31_t)0x3ed26e6, (q31_t)0x800f6b88, (q31_t)0x3d407df, (q31_t)0x800ea8a3, (q31_t)0x3bae8b2, (q31_t)0x800deaad, (q31_t)0x3a1c960, (q31_t)0x800d31a5, + (q31_t)0x388a9ea, (q31_t)0x800c7d8c, (q31_t)0x36f8a51, (q31_t)0x800bce63, (q31_t)0x3566a96, (q31_t)0x800b2427, (q31_t)0x33d4abb, (q31_t)0x800a7edb, + (q31_t)0x3242abf, (q31_t)0x8009de7e, (q31_t)0x30b0aa4, (q31_t)0x80094310, (q31_t)0x2f1ea6c, (q31_t)0x8008ac90, (q31_t)0x2d8ca16, (q31_t)0x80081b00, + (q31_t)0x2bfa9a4, (q31_t)0x80078e5e, (q31_t)0x2a68917, (q31_t)0x800706ac, (q31_t)0x28d6870, (q31_t)0x800683e8, (q31_t)0x27447b0, (q31_t)0x80060614, + (q31_t)0x25b26d7, (q31_t)0x80058d2f, (q31_t)0x24205e8, (q31_t)0x80051939, (q31_t)0x228e4e2, (q31_t)0x8004aa32, (q31_t)0x20fc3c6, (q31_t)0x8004401a, + (q31_t)0x1f6a297, (q31_t)0x8003daf1, (q31_t)0x1dd8154, (q31_t)0x80037ab7, (q31_t)0x1c45ffe, (q31_t)0x80031f6d, (q31_t)0x1ab3e97, (q31_t)0x8002c912, + (q31_t)0x1921d20, (q31_t)0x800277a6, (q31_t)0x178fb99, (q31_t)0x80022b29, (q31_t)0x15fda03, (q31_t)0x8001e39b, (q31_t)0x146b860, (q31_t)0x8001a0fd, + (q31_t)0x12d96b1, (q31_t)0x8001634e, (q31_t)0x11474f6, (q31_t)0x80012a8e, (q31_t)0xfb5330, (q31_t)0x8000f6bd, (q31_t)0xe23160, (q31_t)0x8000c7dc, + (q31_t)0xc90f88, (q31_t)0x80009dea, (q31_t)0xafeda8, (q31_t)0x800078e7, (q31_t)0x96cbc1, (q31_t)0x800058d4, (q31_t)0x7da9d4, (q31_t)0x80003daf, + (q31_t)0x6487e3, (q31_t)0x8000277a, (q31_t)0x4b65ee, (q31_t)0x80001635, (q31_t)0x3243f5, (q31_t)0x800009df, (q31_t)0x1921fb, (q31_t)0x80000278 +}; + +static const q31_t WeightsQ31_8192[16384] = { + (q31_t)0x7fffffff, (q31_t)0x0, (q31_t)0x7fffffd9, (q31_t)0xfff9b781, (q31_t)0x7fffff62, (q31_t)0xfff36f02, (q31_t)0x7ffffe9d, + (q31_t)0xffed2684, + (q31_t)0x7ffffd88, (q31_t)0xffe6de05, (q31_t)0x7ffffc25, (q31_t)0xffe09586, (q31_t)0x7ffffa73, (q31_t)0xffda4d08, + (q31_t)0x7ffff872, (q31_t)0xffd40489, + (q31_t)0x7ffff621, (q31_t)0xffcdbc0b, (q31_t)0x7ffff382, (q31_t)0xffc7738c, (q31_t)0x7ffff094, (q31_t)0xffc12b0e, + (q31_t)0x7fffed57, (q31_t)0xffbae290, + (q31_t)0x7fffe9cb, (q31_t)0xffb49a12, (q31_t)0x7fffe5f0, (q31_t)0xffae5195, (q31_t)0x7fffe1c6, (q31_t)0xffa80917, + (q31_t)0x7fffdd4d, (q31_t)0xffa1c09a, + (q31_t)0x7fffd886, (q31_t)0xff9b781d, (q31_t)0x7fffd36f, (q31_t)0xff952fa0, (q31_t)0x7fffce09, (q31_t)0xff8ee724, + (q31_t)0x7fffc854, (q31_t)0xff889ea7, + (q31_t)0x7fffc251, (q31_t)0xff82562c, (q31_t)0x7fffbbfe, (q31_t)0xff7c0db0, (q31_t)0x7fffb55c, (q31_t)0xff75c535, + (q31_t)0x7fffae6c, (q31_t)0xff6f7cba, + (q31_t)0x7fffa72c, (q31_t)0xff69343f, (q31_t)0x7fff9f9e, (q31_t)0xff62ebc5, (q31_t)0x7fff97c1, (q31_t)0xff5ca34b, + (q31_t)0x7fff8f94, (q31_t)0xff565ad1, + (q31_t)0x7fff8719, (q31_t)0xff501258, (q31_t)0x7fff7e4f, (q31_t)0xff49c9df, (q31_t)0x7fff7536, (q31_t)0xff438167, + (q31_t)0x7fff6bcd, (q31_t)0xff3d38ef, + (q31_t)0x7fff6216, (q31_t)0xff36f078, (q31_t)0x7fff5810, (q31_t)0xff30a801, (q31_t)0x7fff4dbb, (q31_t)0xff2a5f8b, + (q31_t)0x7fff4317, (q31_t)0xff241715, + (q31_t)0x7fff3824, (q31_t)0xff1dcea0, (q31_t)0x7fff2ce2, (q31_t)0xff17862b, (q31_t)0x7fff2151, (q31_t)0xff113db7, + (q31_t)0x7fff1572, (q31_t)0xff0af543, + (q31_t)0x7fff0943, (q31_t)0xff04acd0, (q31_t)0x7ffefcc5, (q31_t)0xfefe645e, (q31_t)0x7ffeeff8, (q31_t)0xfef81bec, + (q31_t)0x7ffee2dd, (q31_t)0xfef1d37b, + (q31_t)0x7ffed572, (q31_t)0xfeeb8b0a, (q31_t)0x7ffec7b9, (q31_t)0xfee5429a, (q31_t)0x7ffeb9b0, (q31_t)0xfedefa2b, + (q31_t)0x7ffeab59, (q31_t)0xfed8b1bd, + (q31_t)0x7ffe9cb2, (q31_t)0xfed2694f, (q31_t)0x7ffe8dbd, (q31_t)0xfecc20e2, (q31_t)0x7ffe7e79, (q31_t)0xfec5d876, + (q31_t)0x7ffe6ee5, (q31_t)0xfebf900a, + (q31_t)0x7ffe5f03, (q31_t)0xfeb947a0, (q31_t)0x7ffe4ed2, (q31_t)0xfeb2ff36, (q31_t)0x7ffe3e52, (q31_t)0xfeacb6cc, + (q31_t)0x7ffe2d83, (q31_t)0xfea66e64, + (q31_t)0x7ffe1c65, (q31_t)0xfea025fd, (q31_t)0x7ffe0af8, (q31_t)0xfe99dd96, (q31_t)0x7ffdf93c, (q31_t)0xfe939530, + (q31_t)0x7ffde731, (q31_t)0xfe8d4ccb, + (q31_t)0x7ffdd4d7, (q31_t)0xfe870467, (q31_t)0x7ffdc22e, (q31_t)0xfe80bc04, (q31_t)0x7ffdaf37, (q31_t)0xfe7a73a2, + (q31_t)0x7ffd9bf0, (q31_t)0xfe742b41, + (q31_t)0x7ffd885a, (q31_t)0xfe6de2e0, (q31_t)0x7ffd7476, (q31_t)0xfe679a81, (q31_t)0x7ffd6042, (q31_t)0xfe615223, + (q31_t)0x7ffd4bc0, (q31_t)0xfe5b09c5, + (q31_t)0x7ffd36ee, (q31_t)0xfe54c169, (q31_t)0x7ffd21ce, (q31_t)0xfe4e790d, (q31_t)0x7ffd0c5f, (q31_t)0xfe4830b3, + (q31_t)0x7ffcf6a0, (q31_t)0xfe41e85a, + (q31_t)0x7ffce093, (q31_t)0xfe3ba002, (q31_t)0x7ffcca37, (q31_t)0xfe3557ab, (q31_t)0x7ffcb38c, (q31_t)0xfe2f0f55, + (q31_t)0x7ffc9c92, (q31_t)0xfe28c700, + (q31_t)0x7ffc8549, (q31_t)0xfe227eac, (q31_t)0x7ffc6db1, (q31_t)0xfe1c365a, (q31_t)0x7ffc55ca, (q31_t)0xfe15ee09, + (q31_t)0x7ffc3d94, (q31_t)0xfe0fa5b8, + (q31_t)0x7ffc250f, (q31_t)0xfe095d69, (q31_t)0x7ffc0c3b, (q31_t)0xfe03151c, (q31_t)0x7ffbf319, (q31_t)0xfdfccccf, + (q31_t)0x7ffbd9a7, (q31_t)0xfdf68484, + (q31_t)0x7ffbbfe6, (q31_t)0xfdf03c3a, (q31_t)0x7ffba5d7, (q31_t)0xfde9f3f1, (q31_t)0x7ffb8b78, (q31_t)0xfde3aba9, + (q31_t)0x7ffb70cb, (q31_t)0xfddd6363, + (q31_t)0x7ffb55ce, (q31_t)0xfdd71b1e, (q31_t)0x7ffb3a83, (q31_t)0xfdd0d2db, (q31_t)0x7ffb1ee9, (q31_t)0xfdca8a99, + (q31_t)0x7ffb0300, (q31_t)0xfdc44258, + (q31_t)0x7ffae6c7, (q31_t)0xfdbdfa18, (q31_t)0x7ffaca40, (q31_t)0xfdb7b1da, (q31_t)0x7ffaad6a, (q31_t)0xfdb1699e, + (q31_t)0x7ffa9045, (q31_t)0xfdab2162, + (q31_t)0x7ffa72d1, (q31_t)0xfda4d929, (q31_t)0x7ffa550e, (q31_t)0xfd9e90f0, (q31_t)0x7ffa36fc, (q31_t)0xfd9848b9, + (q31_t)0x7ffa189c, (q31_t)0xfd920084, + (q31_t)0x7ff9f9ec, (q31_t)0xfd8bb850, (q31_t)0x7ff9daed, (q31_t)0xfd85701e, (q31_t)0x7ff9bba0, (q31_t)0xfd7f27ed, + (q31_t)0x7ff99c03, (q31_t)0xfd78dfbd, + (q31_t)0x7ff97c18, (q31_t)0xfd729790, (q31_t)0x7ff95bdd, (q31_t)0xfd6c4f64, (q31_t)0x7ff93b54, (q31_t)0xfd660739, + (q31_t)0x7ff91a7b, (q31_t)0xfd5fbf10, + (q31_t)0x7ff8f954, (q31_t)0xfd5976e9, (q31_t)0x7ff8d7de, (q31_t)0xfd532ec3, (q31_t)0x7ff8b619, (q31_t)0xfd4ce69f, + (q31_t)0x7ff89405, (q31_t)0xfd469e7c, + (q31_t)0x7ff871a2, (q31_t)0xfd40565c, (q31_t)0x7ff84ef0, (q31_t)0xfd3a0e3d, (q31_t)0x7ff82bef, (q31_t)0xfd33c61f, + (q31_t)0x7ff8089f, (q31_t)0xfd2d7e04, + (q31_t)0x7ff7e500, (q31_t)0xfd2735ea, (q31_t)0x7ff7c113, (q31_t)0xfd20edd2, (q31_t)0x7ff79cd6, (q31_t)0xfd1aa5bc, + (q31_t)0x7ff7784a, (q31_t)0xfd145da7, + (q31_t)0x7ff75370, (q31_t)0xfd0e1594, (q31_t)0x7ff72e46, (q31_t)0xfd07cd83, (q31_t)0x7ff708ce, (q31_t)0xfd018574, + (q31_t)0x7ff6e307, (q31_t)0xfcfb3d67, + (q31_t)0x7ff6bcf0, (q31_t)0xfcf4f55c, (q31_t)0x7ff6968b, (q31_t)0xfceead52, (q31_t)0x7ff66fd7, (q31_t)0xfce8654b, + (q31_t)0x7ff648d4, (q31_t)0xfce21d45, + (q31_t)0x7ff62182, (q31_t)0xfcdbd541, (q31_t)0x7ff5f9e1, (q31_t)0xfcd58d3f, (q31_t)0x7ff5d1f1, (q31_t)0xfccf453f, + (q31_t)0x7ff5a9b2, (q31_t)0xfcc8fd41, + (q31_t)0x7ff58125, (q31_t)0xfcc2b545, (q31_t)0x7ff55848, (q31_t)0xfcbc6d4c, (q31_t)0x7ff52f1d, (q31_t)0xfcb62554, + (q31_t)0x7ff505a2, (q31_t)0xfcafdd5e, + (q31_t)0x7ff4dbd9, (q31_t)0xfca9956a, (q31_t)0x7ff4b1c0, (q31_t)0xfca34d78, (q31_t)0x7ff48759, (q31_t)0xfc9d0588, + (q31_t)0x7ff45ca3, (q31_t)0xfc96bd9b, + (q31_t)0x7ff4319d, (q31_t)0xfc9075af, (q31_t)0x7ff40649, (q31_t)0xfc8a2dc6, (q31_t)0x7ff3daa6, (q31_t)0xfc83e5de, + (q31_t)0x7ff3aeb4, (q31_t)0xfc7d9df9, + (q31_t)0x7ff38274, (q31_t)0xfc775616, (q31_t)0x7ff355e4, (q31_t)0xfc710e36, (q31_t)0x7ff32905, (q31_t)0xfc6ac657, + (q31_t)0x7ff2fbd7, (q31_t)0xfc647e7b, + (q31_t)0x7ff2ce5b, (q31_t)0xfc5e36a0, (q31_t)0x7ff2a08f, (q31_t)0xfc57eec9, (q31_t)0x7ff27275, (q31_t)0xfc51a6f3, + (q31_t)0x7ff2440b, (q31_t)0xfc4b5f20, + (q31_t)0x7ff21553, (q31_t)0xfc45174e, (q31_t)0x7ff1e64c, (q31_t)0xfc3ecf80, (q31_t)0x7ff1b6f6, (q31_t)0xfc3887b3, + (q31_t)0x7ff18751, (q31_t)0xfc323fe9, + (q31_t)0x7ff1575d, (q31_t)0xfc2bf821, (q31_t)0x7ff1271a, (q31_t)0xfc25b05c, (q31_t)0x7ff0f688, (q31_t)0xfc1f6899, + (q31_t)0x7ff0c5a7, (q31_t)0xfc1920d8, + (q31_t)0x7ff09478, (q31_t)0xfc12d91a, (q31_t)0x7ff062f9, (q31_t)0xfc0c915e, (q31_t)0x7ff0312c, (q31_t)0xfc0649a5, + (q31_t)0x7fefff0f, (q31_t)0xfc0001ee, + (q31_t)0x7fefcca4, (q31_t)0xfbf9ba39, (q31_t)0x7fef99ea, (q31_t)0xfbf37287, (q31_t)0x7fef66e1, (q31_t)0xfbed2ad8, + (q31_t)0x7fef3388, (q31_t)0xfbe6e32b, + (q31_t)0x7feeffe1, (q31_t)0xfbe09b80, (q31_t)0x7feecbec, (q31_t)0xfbda53d8, (q31_t)0x7fee97a7, (q31_t)0xfbd40c33, + (q31_t)0x7fee6313, (q31_t)0xfbcdc490, + (q31_t)0x7fee2e30, (q31_t)0xfbc77cf0, (q31_t)0x7fedf8ff, (q31_t)0xfbc13552, (q31_t)0x7fedc37e, (q31_t)0xfbbaedb7, + (q31_t)0x7fed8daf, (q31_t)0xfbb4a61f, + (q31_t)0x7fed5791, (q31_t)0xfbae5e89, (q31_t)0x7fed2123, (q31_t)0xfba816f6, (q31_t)0x7fecea67, (q31_t)0xfba1cf66, + (q31_t)0x7fecb35c, (q31_t)0xfb9b87d8, + (q31_t)0x7fec7c02, (q31_t)0xfb95404d, (q31_t)0x7fec4459, (q31_t)0xfb8ef8c5, (q31_t)0x7fec0c62, (q31_t)0xfb88b13f, + (q31_t)0x7febd41b, (q31_t)0xfb8269bd, + (q31_t)0x7feb9b85, (q31_t)0xfb7c223d, (q31_t)0x7feb62a1, (q31_t)0xfb75dac0, (q31_t)0x7feb296d, (q31_t)0xfb6f9345, + (q31_t)0x7feaefeb, (q31_t)0xfb694bce, + (q31_t)0x7feab61a, (q31_t)0xfb630459, (q31_t)0x7fea7bfa, (q31_t)0xfb5cbce7, (q31_t)0x7fea418b, (q31_t)0xfb567578, + (q31_t)0x7fea06cd, (q31_t)0xfb502e0c, + (q31_t)0x7fe9cbc0, (q31_t)0xfb49e6a3, (q31_t)0x7fe99064, (q31_t)0xfb439f3c, (q31_t)0x7fe954ba, (q31_t)0xfb3d57d9, + (q31_t)0x7fe918c0, (q31_t)0xfb371078, + (q31_t)0x7fe8dc78, (q31_t)0xfb30c91b, (q31_t)0x7fe89fe0, (q31_t)0xfb2a81c0, (q31_t)0x7fe862fa, (q31_t)0xfb243a69, + (q31_t)0x7fe825c5, (q31_t)0xfb1df314, + (q31_t)0x7fe7e841, (q31_t)0xfb17abc2, (q31_t)0x7fe7aa6e, (q31_t)0xfb116474, (q31_t)0x7fe76c4c, (q31_t)0xfb0b1d28, + (q31_t)0x7fe72ddb, (q31_t)0xfb04d5e0, + (q31_t)0x7fe6ef1c, (q31_t)0xfafe8e9b, (q31_t)0x7fe6b00d, (q31_t)0xfaf84758, (q31_t)0x7fe670b0, (q31_t)0xfaf20019, + (q31_t)0x7fe63103, (q31_t)0xfaebb8dd, + (q31_t)0x7fe5f108, (q31_t)0xfae571a4, (q31_t)0x7fe5b0be, (q31_t)0xfadf2a6e, (q31_t)0x7fe57025, (q31_t)0xfad8e33c, + (q31_t)0x7fe52f3d, (q31_t)0xfad29c0c, + (q31_t)0x7fe4ee06, (q31_t)0xfacc54e0, (q31_t)0x7fe4ac81, (q31_t)0xfac60db7, (q31_t)0x7fe46aac, (q31_t)0xfabfc691, + (q31_t)0x7fe42889, (q31_t)0xfab97f6e, + (q31_t)0x7fe3e616, (q31_t)0xfab3384f, (q31_t)0x7fe3a355, (q31_t)0xfaacf133, (q31_t)0x7fe36045, (q31_t)0xfaa6aa1a, + (q31_t)0x7fe31ce6, (q31_t)0xfaa06305, + (q31_t)0x7fe2d938, (q31_t)0xfa9a1bf3, (q31_t)0x7fe2953b, (q31_t)0xfa93d4e4, (q31_t)0x7fe250ef, (q31_t)0xfa8d8dd8, + (q31_t)0x7fe20c55, (q31_t)0xfa8746d0, + (q31_t)0x7fe1c76b, (q31_t)0xfa80ffcb, (q31_t)0x7fe18233, (q31_t)0xfa7ab8ca, (q31_t)0x7fe13cac, (q31_t)0xfa7471cc, + (q31_t)0x7fe0f6d6, (q31_t)0xfa6e2ad1, + (q31_t)0x7fe0b0b1, (q31_t)0xfa67e3da, (q31_t)0x7fe06a3d, (q31_t)0xfa619ce7, (q31_t)0x7fe0237a, (q31_t)0xfa5b55f7, + (q31_t)0x7fdfdc69, (q31_t)0xfa550f0a, + (q31_t)0x7fdf9508, (q31_t)0xfa4ec821, (q31_t)0x7fdf4d59, (q31_t)0xfa48813b, (q31_t)0x7fdf055a, (q31_t)0xfa423a59, + (q31_t)0x7fdebd0d, (q31_t)0xfa3bf37a, + (q31_t)0x7fde7471, (q31_t)0xfa35ac9f, (q31_t)0x7fde2b86, (q31_t)0xfa2f65c8, (q31_t)0x7fdde24d, (q31_t)0xfa291ef4, + (q31_t)0x7fdd98c4, (q31_t)0xfa22d823, + (q31_t)0x7fdd4eec, (q31_t)0xfa1c9157, (q31_t)0x7fdd04c6, (q31_t)0xfa164a8e, (q31_t)0x7fdcba51, (q31_t)0xfa1003c8, + (q31_t)0x7fdc6f8d, (q31_t)0xfa09bd06, + (q31_t)0x7fdc247a, (q31_t)0xfa037648, (q31_t)0x7fdbd918, (q31_t)0xf9fd2f8e, (q31_t)0x7fdb8d67, (q31_t)0xf9f6e8d7, + (q31_t)0x7fdb4167, (q31_t)0xf9f0a224, + (q31_t)0x7fdaf519, (q31_t)0xf9ea5b75, (q31_t)0x7fdaa87c, (q31_t)0xf9e414ca, (q31_t)0x7fda5b8f, (q31_t)0xf9ddce22, + (q31_t)0x7fda0e54, (q31_t)0xf9d7877e, + (q31_t)0x7fd9c0ca, (q31_t)0xf9d140de, (q31_t)0x7fd972f2, (q31_t)0xf9cafa42, (q31_t)0x7fd924ca, (q31_t)0xf9c4b3a9, + (q31_t)0x7fd8d653, (q31_t)0xf9be6d15, + (q31_t)0x7fd8878e, (q31_t)0xf9b82684, (q31_t)0x7fd8387a, (q31_t)0xf9b1dff7, (q31_t)0x7fd7e917, (q31_t)0xf9ab996e, + (q31_t)0x7fd79965, (q31_t)0xf9a552e9, + (q31_t)0x7fd74964, (q31_t)0xf99f0c68, (q31_t)0x7fd6f914, (q31_t)0xf998c5ea, (q31_t)0x7fd6a875, (q31_t)0xf9927f71, + (q31_t)0x7fd65788, (q31_t)0xf98c38fc, + (q31_t)0x7fd6064c, (q31_t)0xf985f28a, (q31_t)0x7fd5b4c1, (q31_t)0xf97fac1d, (q31_t)0x7fd562e7, (q31_t)0xf97965b4, + (q31_t)0x7fd510be, (q31_t)0xf9731f4e, + (q31_t)0x7fd4be46, (q31_t)0xf96cd8ed, (q31_t)0x7fd46b80, (q31_t)0xf9669290, (q31_t)0x7fd4186a, (q31_t)0xf9604c37, + (q31_t)0x7fd3c506, (q31_t)0xf95a05e2, + (q31_t)0x7fd37153, (q31_t)0xf953bf91, (q31_t)0x7fd31d51, (q31_t)0xf94d7944, (q31_t)0x7fd2c900, (q31_t)0xf94732fb, + (q31_t)0x7fd27460, (q31_t)0xf940ecb7, + (q31_t)0x7fd21f72, (q31_t)0xf93aa676, (q31_t)0x7fd1ca35, (q31_t)0xf934603a, (q31_t)0x7fd174a8, (q31_t)0xf92e1a02, + (q31_t)0x7fd11ecd, (q31_t)0xf927d3ce, + (q31_t)0x7fd0c8a3, (q31_t)0xf9218d9e, (q31_t)0x7fd0722b, (q31_t)0xf91b4773, (q31_t)0x7fd01b63, (q31_t)0xf915014c, + (q31_t)0x7fcfc44d, (q31_t)0xf90ebb29, + (q31_t)0x7fcf6ce8, (q31_t)0xf908750a, (q31_t)0x7fcf1533, (q31_t)0xf9022ef0, (q31_t)0x7fcebd31, (q31_t)0xf8fbe8da, + (q31_t)0x7fce64df, (q31_t)0xf8f5a2c9, + (q31_t)0x7fce0c3e, (q31_t)0xf8ef5cbb, (q31_t)0x7fcdb34f, (q31_t)0xf8e916b2, (q31_t)0x7fcd5a11, (q31_t)0xf8e2d0ae, + (q31_t)0x7fcd0083, (q31_t)0xf8dc8aae, + (q31_t)0x7fcca6a7, (q31_t)0xf8d644b2, (q31_t)0x7fcc4c7d, (q31_t)0xf8cffebb, (q31_t)0x7fcbf203, (q31_t)0xf8c9b8c8, + (q31_t)0x7fcb973b, (q31_t)0xf8c372d9, + (q31_t)0x7fcb3c23, (q31_t)0xf8bd2cef, (q31_t)0x7fcae0bd, (q31_t)0xf8b6e70a, (q31_t)0x7fca8508, (q31_t)0xf8b0a129, + (q31_t)0x7fca2905, (q31_t)0xf8aa5b4c, + (q31_t)0x7fc9ccb2, (q31_t)0xf8a41574, (q31_t)0x7fc97011, (q31_t)0xf89dcfa1, (q31_t)0x7fc91320, (q31_t)0xf89789d2, + (q31_t)0x7fc8b5e1, (q31_t)0xf8914407, + (q31_t)0x7fc85854, (q31_t)0xf88afe42, (q31_t)0x7fc7fa77, (q31_t)0xf884b880, (q31_t)0x7fc79c4b, (q31_t)0xf87e72c4, + (q31_t)0x7fc73dd1, (q31_t)0xf8782d0c, + (q31_t)0x7fc6df08, (q31_t)0xf871e759, (q31_t)0x7fc67ff0, (q31_t)0xf86ba1aa, (q31_t)0x7fc62089, (q31_t)0xf8655c00, + (q31_t)0x7fc5c0d3, (q31_t)0xf85f165b, + (q31_t)0x7fc560cf, (q31_t)0xf858d0bb, (q31_t)0x7fc5007c, (q31_t)0xf8528b1f, (q31_t)0x7fc49fda, (q31_t)0xf84c4588, + (q31_t)0x7fc43ee9, (q31_t)0xf845fff5, + (q31_t)0x7fc3dda9, (q31_t)0xf83fba68, (q31_t)0x7fc37c1b, (q31_t)0xf83974df, (q31_t)0x7fc31a3d, (q31_t)0xf8332f5b, + (q31_t)0x7fc2b811, (q31_t)0xf82ce9dc, + (q31_t)0x7fc25596, (q31_t)0xf826a462, (q31_t)0x7fc1f2cc, (q31_t)0xf8205eec, (q31_t)0x7fc18fb4, (q31_t)0xf81a197b, + (q31_t)0x7fc12c4d, (q31_t)0xf813d410, + (q31_t)0x7fc0c896, (q31_t)0xf80d8ea9, (q31_t)0x7fc06491, (q31_t)0xf8074947, (q31_t)0x7fc0003e, (q31_t)0xf80103ea, + (q31_t)0x7fbf9b9b, (q31_t)0xf7fabe92, + (q31_t)0x7fbf36aa, (q31_t)0xf7f4793e, (q31_t)0x7fbed16a, (q31_t)0xf7ee33f0, (q31_t)0x7fbe6bdb, (q31_t)0xf7e7eea7, + (q31_t)0x7fbe05fd, (q31_t)0xf7e1a963, + (q31_t)0x7fbd9fd0, (q31_t)0xf7db6423, (q31_t)0x7fbd3955, (q31_t)0xf7d51ee9, (q31_t)0x7fbcd28b, (q31_t)0xf7ced9b4, + (q31_t)0x7fbc6b72, (q31_t)0xf7c89484, + (q31_t)0x7fbc040a, (q31_t)0xf7c24f59, (q31_t)0x7fbb9c53, (q31_t)0xf7bc0a33, (q31_t)0x7fbb344e, (q31_t)0xf7b5c512, + (q31_t)0x7fbacbfa, (q31_t)0xf7af7ff6, + (q31_t)0x7fba6357, (q31_t)0xf7a93ae0, (q31_t)0x7fb9fa65, (q31_t)0xf7a2f5ce, (q31_t)0x7fb99125, (q31_t)0xf79cb0c2, + (q31_t)0x7fb92796, (q31_t)0xf7966bbb, + (q31_t)0x7fb8bdb8, (q31_t)0xf79026b9, (q31_t)0x7fb8538b, (q31_t)0xf789e1bc, (q31_t)0x7fb7e90f, (q31_t)0xf7839cc4, + (q31_t)0x7fb77e45, (q31_t)0xf77d57d2, + (q31_t)0x7fb7132b, (q31_t)0xf77712e5, (q31_t)0x7fb6a7c3, (q31_t)0xf770cdfd, (q31_t)0x7fb63c0d, (q31_t)0xf76a891b, + (q31_t)0x7fb5d007, (q31_t)0xf764443d, + (q31_t)0x7fb563b3, (q31_t)0xf75dff66, (q31_t)0x7fb4f710, (q31_t)0xf757ba93, (q31_t)0x7fb48a1e, (q31_t)0xf75175c6, + (q31_t)0x7fb41cdd, (q31_t)0xf74b30fe, + (q31_t)0x7fb3af4e, (q31_t)0xf744ec3b, (q31_t)0x7fb34170, (q31_t)0xf73ea77e, (q31_t)0x7fb2d343, (q31_t)0xf73862c6, + (q31_t)0x7fb264c7, (q31_t)0xf7321e14, + (q31_t)0x7fb1f5fc, (q31_t)0xf72bd967, (q31_t)0x7fb186e3, (q31_t)0xf72594c0, (q31_t)0x7fb1177b, (q31_t)0xf71f501e, + (q31_t)0x7fb0a7c4, (q31_t)0xf7190b81, + (q31_t)0x7fb037bf, (q31_t)0xf712c6ea, (q31_t)0x7fafc76a, (q31_t)0xf70c8259, (q31_t)0x7faf56c7, (q31_t)0xf7063dcd, + (q31_t)0x7faee5d5, (q31_t)0xf6fff946, + (q31_t)0x7fae7495, (q31_t)0xf6f9b4c6, (q31_t)0x7fae0305, (q31_t)0xf6f3704a, (q31_t)0x7fad9127, (q31_t)0xf6ed2bd4, + (q31_t)0x7fad1efa, (q31_t)0xf6e6e764, + (q31_t)0x7facac7f, (q31_t)0xf6e0a2fa, (q31_t)0x7fac39b4, (q31_t)0xf6da5e95, (q31_t)0x7fabc69b, (q31_t)0xf6d41a36, + (q31_t)0x7fab5333, (q31_t)0xf6cdd5dc, + (q31_t)0x7faadf7c, (q31_t)0xf6c79188, (q31_t)0x7faa6b77, (q31_t)0xf6c14d3a, (q31_t)0x7fa9f723, (q31_t)0xf6bb08f1, + (q31_t)0x7fa98280, (q31_t)0xf6b4c4ae, + (q31_t)0x7fa90d8e, (q31_t)0xf6ae8071, (q31_t)0x7fa8984e, (q31_t)0xf6a83c3a, (q31_t)0x7fa822bf, (q31_t)0xf6a1f808, + (q31_t)0x7fa7ace1, (q31_t)0xf69bb3dd, + (q31_t)0x7fa736b4, (q31_t)0xf6956fb7, (q31_t)0x7fa6c039, (q31_t)0xf68f2b96, (q31_t)0x7fa6496e, (q31_t)0xf688e77c, + (q31_t)0x7fa5d256, (q31_t)0xf682a367, + (q31_t)0x7fa55aee, (q31_t)0xf67c5f59, (q31_t)0x7fa4e338, (q31_t)0xf6761b50, (q31_t)0x7fa46b32, (q31_t)0xf66fd74d, + (q31_t)0x7fa3f2df, (q31_t)0xf6699350, + (q31_t)0x7fa37a3c, (q31_t)0xf6634f59, (q31_t)0x7fa3014b, (q31_t)0xf65d0b68, (q31_t)0x7fa2880b, (q31_t)0xf656c77c, + (q31_t)0x7fa20e7c, (q31_t)0xf6508397, + (q31_t)0x7fa1949e, (q31_t)0xf64a3fb8, (q31_t)0x7fa11a72, (q31_t)0xf643fbdf, (q31_t)0x7fa09ff7, (q31_t)0xf63db80b, + (q31_t)0x7fa0252e, (q31_t)0xf637743e, + (q31_t)0x7f9faa15, (q31_t)0xf6313077, (q31_t)0x7f9f2eae, (q31_t)0xf62aecb5, (q31_t)0x7f9eb2f8, (q31_t)0xf624a8fa, + (q31_t)0x7f9e36f4, (q31_t)0xf61e6545, + (q31_t)0x7f9dbaa0, (q31_t)0xf6182196, (q31_t)0x7f9d3dfe, (q31_t)0xf611dded, (q31_t)0x7f9cc10d, (q31_t)0xf60b9a4b, + (q31_t)0x7f9c43ce, (q31_t)0xf60556ae, + (q31_t)0x7f9bc640, (q31_t)0xf5ff1318, (q31_t)0x7f9b4863, (q31_t)0xf5f8cf87, (q31_t)0x7f9aca37, (q31_t)0xf5f28bfd, + (q31_t)0x7f9a4bbd, (q31_t)0xf5ec4879, + (q31_t)0x7f99ccf4, (q31_t)0xf5e604fc, (q31_t)0x7f994ddc, (q31_t)0xf5dfc184, (q31_t)0x7f98ce76, (q31_t)0xf5d97e13, + (q31_t)0x7f984ec1, (q31_t)0xf5d33aa8, + (q31_t)0x7f97cebd, (q31_t)0xf5ccf743, (q31_t)0x7f974e6a, (q31_t)0xf5c6b3e5, (q31_t)0x7f96cdc9, (q31_t)0xf5c0708d, + (q31_t)0x7f964cd9, (q31_t)0xf5ba2d3b, + (q31_t)0x7f95cb9a, (q31_t)0xf5b3e9f0, (q31_t)0x7f954a0d, (q31_t)0xf5ada6ab, (q31_t)0x7f94c831, (q31_t)0xf5a7636c, + (q31_t)0x7f944606, (q31_t)0xf5a12034, + (q31_t)0x7f93c38c, (q31_t)0xf59add02, (q31_t)0x7f9340c4, (q31_t)0xf59499d6, (q31_t)0x7f92bdad, (q31_t)0xf58e56b1, + (q31_t)0x7f923a48, (q31_t)0xf5881393, + (q31_t)0x7f91b694, (q31_t)0xf581d07b, (q31_t)0x7f913291, (q31_t)0xf57b8d69, (q31_t)0x7f90ae3f, (q31_t)0xf5754a5e, + (q31_t)0x7f90299f, (q31_t)0xf56f0759, + (q31_t)0x7f8fa4b0, (q31_t)0xf568c45b, (q31_t)0x7f8f1f72, (q31_t)0xf5628163, (q31_t)0x7f8e99e6, (q31_t)0xf55c3e72, + (q31_t)0x7f8e140a, (q31_t)0xf555fb88, + (q31_t)0x7f8d8de1, (q31_t)0xf54fb8a4, (q31_t)0x7f8d0768, (q31_t)0xf54975c6, (q31_t)0x7f8c80a1, (q31_t)0xf54332ef, + (q31_t)0x7f8bf98b, (q31_t)0xf53cf01f, + (q31_t)0x7f8b7227, (q31_t)0xf536ad56, (q31_t)0x7f8aea74, (q31_t)0xf5306a93, (q31_t)0x7f8a6272, (q31_t)0xf52a27d7, + (q31_t)0x7f89da21, (q31_t)0xf523e521, + (q31_t)0x7f895182, (q31_t)0xf51da273, (q31_t)0x7f88c894, (q31_t)0xf5175fca, (q31_t)0x7f883f58, (q31_t)0xf5111d29, + (q31_t)0x7f87b5cd, (q31_t)0xf50ada8f, + (q31_t)0x7f872bf3, (q31_t)0xf50497fb, (q31_t)0x7f86a1ca, (q31_t)0xf4fe556e, (q31_t)0x7f861753, (q31_t)0xf4f812e7, + (q31_t)0x7f858c8d, (q31_t)0xf4f1d068, + (q31_t)0x7f850179, (q31_t)0xf4eb8def, (q31_t)0x7f847616, (q31_t)0xf4e54b7d, (q31_t)0x7f83ea64, (q31_t)0xf4df0912, + (q31_t)0x7f835e64, (q31_t)0xf4d8c6ae, + (q31_t)0x7f82d214, (q31_t)0xf4d28451, (q31_t)0x7f824577, (q31_t)0xf4cc41fb, (q31_t)0x7f81b88a, (q31_t)0xf4c5ffab, + (q31_t)0x7f812b4f, (q31_t)0xf4bfbd63, + (q31_t)0x7f809dc5, (q31_t)0xf4b97b21, (q31_t)0x7f800fed, (q31_t)0xf4b338e7, (q31_t)0x7f7f81c6, (q31_t)0xf4acf6b3, + (q31_t)0x7f7ef350, (q31_t)0xf4a6b486, + (q31_t)0x7f7e648c, (q31_t)0xf4a07261, (q31_t)0x7f7dd579, (q31_t)0xf49a3042, (q31_t)0x7f7d4617, (q31_t)0xf493ee2b, + (q31_t)0x7f7cb667, (q31_t)0xf48dac1a, + (q31_t)0x7f7c2668, (q31_t)0xf4876a10, (q31_t)0x7f7b961b, (q31_t)0xf481280e, (q31_t)0x7f7b057e, (q31_t)0xf47ae613, + (q31_t)0x7f7a7494, (q31_t)0xf474a41f, + (q31_t)0x7f79e35a, (q31_t)0xf46e6231, (q31_t)0x7f7951d2, (q31_t)0xf468204b, (q31_t)0x7f78bffb, (q31_t)0xf461de6d, + (q31_t)0x7f782dd6, (q31_t)0xf45b9c95, + (q31_t)0x7f779b62, (q31_t)0xf4555ac5, (q31_t)0x7f77089f, (q31_t)0xf44f18fb, (q31_t)0x7f76758e, (q31_t)0xf448d739, + (q31_t)0x7f75e22e, (q31_t)0xf442957e, + (q31_t)0x7f754e80, (q31_t)0xf43c53cb, (q31_t)0x7f74ba83, (q31_t)0xf436121e, (q31_t)0x7f742637, (q31_t)0xf42fd079, + (q31_t)0x7f73919d, (q31_t)0xf4298edc, + (q31_t)0x7f72fcb4, (q31_t)0xf4234d45, (q31_t)0x7f72677c, (q31_t)0xf41d0bb6, (q31_t)0x7f71d1f6, (q31_t)0xf416ca2e, + (q31_t)0x7f713c21, (q31_t)0xf41088ae, + (q31_t)0x7f70a5fe, (q31_t)0xf40a4735, (q31_t)0x7f700f8c, (q31_t)0xf40405c3, (q31_t)0x7f6f78cb, (q31_t)0xf3fdc459, + (q31_t)0x7f6ee1bc, (q31_t)0xf3f782f6, + (q31_t)0x7f6e4a5e, (q31_t)0xf3f1419a, (q31_t)0x7f6db2b1, (q31_t)0xf3eb0046, (q31_t)0x7f6d1ab6, (q31_t)0xf3e4bef9, + (q31_t)0x7f6c826d, (q31_t)0xf3de7db4, + (q31_t)0x7f6be9d4, (q31_t)0xf3d83c77, (q31_t)0x7f6b50ed, (q31_t)0xf3d1fb40, (q31_t)0x7f6ab7b8, (q31_t)0xf3cbba12, + (q31_t)0x7f6a1e34, (q31_t)0xf3c578eb, + (q31_t)0x7f698461, (q31_t)0xf3bf37cb, (q31_t)0x7f68ea40, (q31_t)0xf3b8f6b3, (q31_t)0x7f684fd0, (q31_t)0xf3b2b5a3, + (q31_t)0x7f67b512, (q31_t)0xf3ac749a, + (q31_t)0x7f671a05, (q31_t)0xf3a63398, (q31_t)0x7f667ea9, (q31_t)0xf39ff29f, (q31_t)0x7f65e2ff, (q31_t)0xf399b1ad, + (q31_t)0x7f654706, (q31_t)0xf39370c2, + (q31_t)0x7f64aabf, (q31_t)0xf38d2fe0, (q31_t)0x7f640e29, (q31_t)0xf386ef05, (q31_t)0x7f637144, (q31_t)0xf380ae31, + (q31_t)0x7f62d411, (q31_t)0xf37a6d66, + (q31_t)0x7f62368f, (q31_t)0xf3742ca2, (q31_t)0x7f6198bf, (q31_t)0xf36debe6, (q31_t)0x7f60faa0, (q31_t)0xf367ab31, + (q31_t)0x7f605c33, (q31_t)0xf3616a85, + (q31_t)0x7f5fbd77, (q31_t)0xf35b29e0, (q31_t)0x7f5f1e6c, (q31_t)0xf354e943, (q31_t)0x7f5e7f13, (q31_t)0xf34ea8ae, + (q31_t)0x7f5ddf6b, (q31_t)0xf3486820, + (q31_t)0x7f5d3f75, (q31_t)0xf342279b, (q31_t)0x7f5c9f30, (q31_t)0xf33be71d, (q31_t)0x7f5bfe9d, (q31_t)0xf335a6a7, + (q31_t)0x7f5b5dbb, (q31_t)0xf32f6639, + (q31_t)0x7f5abc8a, (q31_t)0xf32925d3, (q31_t)0x7f5a1b0b, (q31_t)0xf322e575, (q31_t)0x7f59793e, (q31_t)0xf31ca51f, + (q31_t)0x7f58d721, (q31_t)0xf31664d1, + (q31_t)0x7f5834b7, (q31_t)0xf310248a, (q31_t)0x7f5791fd, (q31_t)0xf309e44c, (q31_t)0x7f56eef5, (q31_t)0xf303a416, + (q31_t)0x7f564b9f, (q31_t)0xf2fd63e8, + (q31_t)0x7f55a7fa, (q31_t)0xf2f723c1, (q31_t)0x7f550407, (q31_t)0xf2f0e3a3, (q31_t)0x7f545fc5, (q31_t)0xf2eaa38d, + (q31_t)0x7f53bb34, (q31_t)0xf2e4637f, + (q31_t)0x7f531655, (q31_t)0xf2de2379, (q31_t)0x7f527127, (q31_t)0xf2d7e37b, (q31_t)0x7f51cbab, (q31_t)0xf2d1a385, + (q31_t)0x7f5125e0, (q31_t)0xf2cb6398, + (q31_t)0x7f507fc7, (q31_t)0xf2c523b2, (q31_t)0x7f4fd95f, (q31_t)0xf2bee3d5, (q31_t)0x7f4f32a9, (q31_t)0xf2b8a400, + (q31_t)0x7f4e8ba4, (q31_t)0xf2b26433, + (q31_t)0x7f4de451, (q31_t)0xf2ac246e, (q31_t)0x7f4d3caf, (q31_t)0xf2a5e4b1, (q31_t)0x7f4c94be, (q31_t)0xf29fa4fd, + (q31_t)0x7f4bec7f, (q31_t)0xf2996551, + (q31_t)0x7f4b43f2, (q31_t)0xf29325ad, (q31_t)0x7f4a9b16, (q31_t)0xf28ce612, (q31_t)0x7f49f1eb, (q31_t)0xf286a67e, + (q31_t)0x7f494872, (q31_t)0xf28066f4, + (q31_t)0x7f489eaa, (q31_t)0xf27a2771, (q31_t)0x7f47f494, (q31_t)0xf273e7f7, (q31_t)0x7f474a30, (q31_t)0xf26da885, + (q31_t)0x7f469f7d, (q31_t)0xf267691b, + (q31_t)0x7f45f47b, (q31_t)0xf26129ba, (q31_t)0x7f45492b, (q31_t)0xf25aea61, (q31_t)0x7f449d8c, (q31_t)0xf254ab11, + (q31_t)0x7f43f19f, (q31_t)0xf24e6bc9, + (q31_t)0x7f434563, (q31_t)0xf2482c8a, (q31_t)0x7f4298d9, (q31_t)0xf241ed53, (q31_t)0x7f41ec01, (q31_t)0xf23bae24, + (q31_t)0x7f413ed9, (q31_t)0xf2356efe, + (q31_t)0x7f409164, (q31_t)0xf22f2fe1, (q31_t)0x7f3fe3a0, (q31_t)0xf228f0cc, (q31_t)0x7f3f358d, (q31_t)0xf222b1c0, + (q31_t)0x7f3e872c, (q31_t)0xf21c72bc, + (q31_t)0x7f3dd87c, (q31_t)0xf21633c0, (q31_t)0x7f3d297e, (q31_t)0xf20ff4ce, (q31_t)0x7f3c7a31, (q31_t)0xf209b5e4, + (q31_t)0x7f3bca96, (q31_t)0xf2037702, + (q31_t)0x7f3b1aad, (q31_t)0xf1fd3829, (q31_t)0x7f3a6a75, (q31_t)0xf1f6f959, (q31_t)0x7f39b9ee, (q31_t)0xf1f0ba91, + (q31_t)0x7f390919, (q31_t)0xf1ea7bd2, + (q31_t)0x7f3857f6, (q31_t)0xf1e43d1c, (q31_t)0x7f37a684, (q31_t)0xf1ddfe6f, (q31_t)0x7f36f4c3, (q31_t)0xf1d7bfca, + (q31_t)0x7f3642b4, (q31_t)0xf1d1812e, + (q31_t)0x7f359057, (q31_t)0xf1cb429a, (q31_t)0x7f34ddab, (q31_t)0xf1c50410, (q31_t)0x7f342ab1, (q31_t)0xf1bec58e, + (q31_t)0x7f337768, (q31_t)0xf1b88715, + (q31_t)0x7f32c3d1, (q31_t)0xf1b248a5, (q31_t)0x7f320feb, (q31_t)0xf1ac0a3e, (q31_t)0x7f315bb7, (q31_t)0xf1a5cbdf, + (q31_t)0x7f30a734, (q31_t)0xf19f8d89, + (q31_t)0x7f2ff263, (q31_t)0xf1994f3d, (q31_t)0x7f2f3d44, (q31_t)0xf19310f9, (q31_t)0x7f2e87d6, (q31_t)0xf18cd2be, + (q31_t)0x7f2dd219, (q31_t)0xf186948c, + (q31_t)0x7f2d1c0e, (q31_t)0xf1805662, (q31_t)0x7f2c65b5, (q31_t)0xf17a1842, (q31_t)0x7f2baf0d, (q31_t)0xf173da2b, + (q31_t)0x7f2af817, (q31_t)0xf16d9c1d, + (q31_t)0x7f2a40d2, (q31_t)0xf1675e17, (q31_t)0x7f29893f, (q31_t)0xf161201b, (q31_t)0x7f28d15d, (q31_t)0xf15ae228, + (q31_t)0x7f28192d, (q31_t)0xf154a43d, + (q31_t)0x7f2760af, (q31_t)0xf14e665c, (q31_t)0x7f26a7e2, (q31_t)0xf1482884, (q31_t)0x7f25eec7, (q31_t)0xf141eab5, + (q31_t)0x7f25355d, (q31_t)0xf13bacef, + (q31_t)0x7f247ba5, (q31_t)0xf1356f32, (q31_t)0x7f23c19e, (q31_t)0xf12f317e, (q31_t)0x7f230749, (q31_t)0xf128f3d4, + (q31_t)0x7f224ca6, (q31_t)0xf122b632, + (q31_t)0x7f2191b4, (q31_t)0xf11c789a, (q31_t)0x7f20d674, (q31_t)0xf1163b0b, (q31_t)0x7f201ae5, (q31_t)0xf10ffd85, + (q31_t)0x7f1f5f08, (q31_t)0xf109c009, + (q31_t)0x7f1ea2dc, (q31_t)0xf1038295, (q31_t)0x7f1de662, (q31_t)0xf0fd452b, (q31_t)0x7f1d299a, (q31_t)0xf0f707ca, + (q31_t)0x7f1c6c83, (q31_t)0xf0f0ca72, + (q31_t)0x7f1baf1e, (q31_t)0xf0ea8d24, (q31_t)0x7f1af16a, (q31_t)0xf0e44fdf, (q31_t)0x7f1a3368, (q31_t)0xf0de12a3, + (q31_t)0x7f197518, (q31_t)0xf0d7d571, + (q31_t)0x7f18b679, (q31_t)0xf0d19848, (q31_t)0x7f17f78c, (q31_t)0xf0cb5b28, (q31_t)0x7f173850, (q31_t)0xf0c51e12, + (q31_t)0x7f1678c6, (q31_t)0xf0bee105, + (q31_t)0x7f15b8ee, (q31_t)0xf0b8a401, (q31_t)0x7f14f8c7, (q31_t)0xf0b26707, (q31_t)0x7f143852, (q31_t)0xf0ac2a16, + (q31_t)0x7f13778e, (q31_t)0xf0a5ed2f, + (q31_t)0x7f12b67c, (q31_t)0xf09fb051, (q31_t)0x7f11f51c, (q31_t)0xf099737d, (q31_t)0x7f11336d, (q31_t)0xf09336b2, + (q31_t)0x7f107170, (q31_t)0xf08cf9f1, + (q31_t)0x7f0faf25, (q31_t)0xf086bd39, (q31_t)0x7f0eec8b, (q31_t)0xf080808b, (q31_t)0x7f0e29a3, (q31_t)0xf07a43e7, + (q31_t)0x7f0d666c, (q31_t)0xf074074c, + (q31_t)0x7f0ca2e7, (q31_t)0xf06dcaba, (q31_t)0x7f0bdf14, (q31_t)0xf0678e32, (q31_t)0x7f0b1af2, (q31_t)0xf06151b4, + (q31_t)0x7f0a5682, (q31_t)0xf05b1540, + (q31_t)0x7f0991c4, (q31_t)0xf054d8d5, (q31_t)0x7f08ccb7, (q31_t)0xf04e9c73, (q31_t)0x7f08075c, (q31_t)0xf048601c, + (q31_t)0x7f0741b2, (q31_t)0xf04223ce, + (q31_t)0x7f067bba, (q31_t)0xf03be78a, (q31_t)0x7f05b574, (q31_t)0xf035ab4f, (q31_t)0x7f04eedf, (q31_t)0xf02f6f1f, + (q31_t)0x7f0427fc, (q31_t)0xf02932f8, + (q31_t)0x7f0360cb, (q31_t)0xf022f6da, (q31_t)0x7f02994b, (q31_t)0xf01cbac7, (q31_t)0x7f01d17d, (q31_t)0xf0167ebd, + (q31_t)0x7f010961, (q31_t)0xf01042be, + (q31_t)0x7f0040f6, (q31_t)0xf00a06c8, (q31_t)0x7eff783d, (q31_t)0xf003cadc, (q31_t)0x7efeaf36, (q31_t)0xeffd8ef9, + (q31_t)0x7efde5e0, (q31_t)0xeff75321, + (q31_t)0x7efd1c3c, (q31_t)0xeff11753, (q31_t)0x7efc524a, (q31_t)0xefeadb8e, (q31_t)0x7efb8809, (q31_t)0xefe49fd3, + (q31_t)0x7efabd7a, (q31_t)0xefde6423, + (q31_t)0x7ef9f29d, (q31_t)0xefd8287c, (q31_t)0x7ef92771, (q31_t)0xefd1ecdf, (q31_t)0x7ef85bf7, (q31_t)0xefcbb14c, + (q31_t)0x7ef7902f, (q31_t)0xefc575c3, + (q31_t)0x7ef6c418, (q31_t)0xefbf3a45, (q31_t)0x7ef5f7b3, (q31_t)0xefb8fed0, (q31_t)0x7ef52b00, (q31_t)0xefb2c365, + (q31_t)0x7ef45dfe, (q31_t)0xefac8804, + (q31_t)0x7ef390ae, (q31_t)0xefa64cae, (q31_t)0x7ef2c310, (q31_t)0xefa01161, (q31_t)0x7ef1f524, (q31_t)0xef99d61f, + (q31_t)0x7ef126e9, (q31_t)0xef939ae6, + (q31_t)0x7ef05860, (q31_t)0xef8d5fb8, (q31_t)0x7eef8988, (q31_t)0xef872494, (q31_t)0x7eeeba62, (q31_t)0xef80e97a, + (q31_t)0x7eedeaee, (q31_t)0xef7aae6b, + (q31_t)0x7eed1b2c, (q31_t)0xef747365, (q31_t)0x7eec4b1b, (q31_t)0xef6e386a, (q31_t)0x7eeb7abc, (q31_t)0xef67fd79, + (q31_t)0x7eeaaa0f, (q31_t)0xef61c292, + (q31_t)0x7ee9d914, (q31_t)0xef5b87b5, (q31_t)0x7ee907ca, (q31_t)0xef554ce3, (q31_t)0x7ee83632, (q31_t)0xef4f121b, + (q31_t)0x7ee7644c, (q31_t)0xef48d75d, + (q31_t)0x7ee69217, (q31_t)0xef429caa, (q31_t)0x7ee5bf94, (q31_t)0xef3c6201, (q31_t)0x7ee4ecc3, (q31_t)0xef362762, + (q31_t)0x7ee419a3, (q31_t)0xef2feccd, + (q31_t)0x7ee34636, (q31_t)0xef29b243, (q31_t)0x7ee2727a, (q31_t)0xef2377c4, (q31_t)0x7ee19e6f, (q31_t)0xef1d3d4e, + (q31_t)0x7ee0ca17, (q31_t)0xef1702e4, + (q31_t)0x7edff570, (q31_t)0xef10c883, (q31_t)0x7edf207b, (q31_t)0xef0a8e2d, (q31_t)0x7ede4b38, (q31_t)0xef0453e2, + (q31_t)0x7edd75a6, (q31_t)0xeefe19a1, + (q31_t)0x7edc9fc6, (q31_t)0xeef7df6a, (q31_t)0x7edbc998, (q31_t)0xeef1a53e, (q31_t)0x7edaf31c, (q31_t)0xeeeb6b1c, + (q31_t)0x7eda1c51, (q31_t)0xeee53105, + (q31_t)0x7ed94538, (q31_t)0xeedef6f9, (q31_t)0x7ed86dd1, (q31_t)0xeed8bcf7, (q31_t)0x7ed7961c, (q31_t)0xeed28300, + (q31_t)0x7ed6be18, (q31_t)0xeecc4913, + (q31_t)0x7ed5e5c6, (q31_t)0xeec60f31, (q31_t)0x7ed50d26, (q31_t)0xeebfd55a, (q31_t)0x7ed43438, (q31_t)0xeeb99b8d, + (q31_t)0x7ed35afb, (q31_t)0xeeb361cb, + (q31_t)0x7ed28171, (q31_t)0xeead2813, (q31_t)0x7ed1a798, (q31_t)0xeea6ee66, (q31_t)0x7ed0cd70, (q31_t)0xeea0b4c4, + (q31_t)0x7ecff2fb, (q31_t)0xee9a7b2d, + (q31_t)0x7ecf1837, (q31_t)0xee9441a0, (q31_t)0x7ece3d25, (q31_t)0xee8e081e, (q31_t)0x7ecd61c5, (q31_t)0xee87cea7, + (q31_t)0x7ecc8617, (q31_t)0xee81953b, + (q31_t)0x7ecbaa1a, (q31_t)0xee7b5bd9, (q31_t)0x7ecacdd0, (q31_t)0xee752283, (q31_t)0x7ec9f137, (q31_t)0xee6ee937, + (q31_t)0x7ec9144f, (q31_t)0xee68aff6, + (q31_t)0x7ec8371a, (q31_t)0xee6276bf, (q31_t)0x7ec75996, (q31_t)0xee5c3d94, (q31_t)0x7ec67bc5, (q31_t)0xee560473, + (q31_t)0x7ec59da5, (q31_t)0xee4fcb5e, + (q31_t)0x7ec4bf36, (q31_t)0xee499253, (q31_t)0x7ec3e07a, (q31_t)0xee435953, (q31_t)0x7ec3016f, (q31_t)0xee3d205e, + (q31_t)0x7ec22217, (q31_t)0xee36e775, + (q31_t)0x7ec14270, (q31_t)0xee30ae96, (q31_t)0x7ec0627a, (q31_t)0xee2a75c2, (q31_t)0x7ebf8237, (q31_t)0xee243cf9, + (q31_t)0x7ebea1a6, (q31_t)0xee1e043b, + (q31_t)0x7ebdc0c6, (q31_t)0xee17cb88, (q31_t)0x7ebcdf98, (q31_t)0xee1192e0, (q31_t)0x7ebbfe1c, (q31_t)0xee0b5a43, + (q31_t)0x7ebb1c52, (q31_t)0xee0521b2, + (q31_t)0x7eba3a39, (q31_t)0xedfee92b, (q31_t)0x7eb957d2, (q31_t)0xedf8b0b0, (q31_t)0x7eb8751e, (q31_t)0xedf2783f, + (q31_t)0x7eb7921b, (q31_t)0xedec3fda, + (q31_t)0x7eb6aeca, (q31_t)0xede60780, (q31_t)0x7eb5cb2a, (q31_t)0xeddfcf31, (q31_t)0x7eb4e73d, (q31_t)0xedd996ed, + (q31_t)0x7eb40301, (q31_t)0xedd35eb5, + (q31_t)0x7eb31e78, (q31_t)0xedcd2687, (q31_t)0x7eb239a0, (q31_t)0xedc6ee65, (q31_t)0x7eb1547a, (q31_t)0xedc0b64e, + (q31_t)0x7eb06f05, (q31_t)0xedba7e43, + (q31_t)0x7eaf8943, (q31_t)0xedb44642, (q31_t)0x7eaea333, (q31_t)0xedae0e4d, (q31_t)0x7eadbcd4, (q31_t)0xeda7d664, + (q31_t)0x7eacd627, (q31_t)0xeda19e85, + (q31_t)0x7eabef2c, (q31_t)0xed9b66b2, (q31_t)0x7eab07e3, (q31_t)0xed952eea, (q31_t)0x7eaa204c, (q31_t)0xed8ef72e, + (q31_t)0x7ea93867, (q31_t)0xed88bf7d, + (q31_t)0x7ea85033, (q31_t)0xed8287d7, (q31_t)0x7ea767b2, (q31_t)0xed7c503d, (q31_t)0x7ea67ee2, (q31_t)0xed7618ae, + (q31_t)0x7ea595c4, (q31_t)0xed6fe12b, + (q31_t)0x7ea4ac58, (q31_t)0xed69a9b3, (q31_t)0x7ea3c29e, (q31_t)0xed637246, (q31_t)0x7ea2d896, (q31_t)0xed5d3ae5, + (q31_t)0x7ea1ee3f, (q31_t)0xed570390, + (q31_t)0x7ea1039b, (q31_t)0xed50cc46, (q31_t)0x7ea018a8, (q31_t)0xed4a9507, (q31_t)0x7e9f2d68, (q31_t)0xed445dd5, + (q31_t)0x7e9e41d9, (q31_t)0xed3e26ad, + (q31_t)0x7e9d55fc, (q31_t)0xed37ef91, (q31_t)0x7e9c69d1, (q31_t)0xed31b881, (q31_t)0x7e9b7d58, (q31_t)0xed2b817d, + (q31_t)0x7e9a9091, (q31_t)0xed254a84, + (q31_t)0x7e99a37c, (q31_t)0xed1f1396, (q31_t)0x7e98b618, (q31_t)0xed18dcb5, (q31_t)0x7e97c867, (q31_t)0xed12a5df, + (q31_t)0x7e96da67, (q31_t)0xed0c6f14, + (q31_t)0x7e95ec1a, (q31_t)0xed063856, (q31_t)0x7e94fd7e, (q31_t)0xed0001a3, (q31_t)0x7e940e94, (q31_t)0xecf9cafb, + (q31_t)0x7e931f5c, (q31_t)0xecf39460, + (q31_t)0x7e922fd6, (q31_t)0xeced5dd0, (q31_t)0x7e914002, (q31_t)0xece7274c, (q31_t)0x7e904fe0, (q31_t)0xece0f0d4, + (q31_t)0x7e8f5f70, (q31_t)0xecdaba67, + (q31_t)0x7e8e6eb2, (q31_t)0xecd48407, (q31_t)0x7e8d7da6, (q31_t)0xecce4db2, (q31_t)0x7e8c8c4b, (q31_t)0xecc81769, + (q31_t)0x7e8b9aa3, (q31_t)0xecc1e12c, + (q31_t)0x7e8aa8ac, (q31_t)0xecbbaafb, (q31_t)0x7e89b668, (q31_t)0xecb574d5, (q31_t)0x7e88c3d5, (q31_t)0xecaf3ebc, + (q31_t)0x7e87d0f5, (q31_t)0xeca908ae, + (q31_t)0x7e86ddc6, (q31_t)0xeca2d2ad, (q31_t)0x7e85ea49, (q31_t)0xec9c9cb7, (q31_t)0x7e84f67e, (q31_t)0xec9666cd, + (q31_t)0x7e840265, (q31_t)0xec9030f0, + (q31_t)0x7e830dff, (q31_t)0xec89fb1e, (q31_t)0x7e82194a, (q31_t)0xec83c558, (q31_t)0x7e812447, (q31_t)0xec7d8f9e, + (q31_t)0x7e802ef6, (q31_t)0xec7759f1, + (q31_t)0x7e7f3957, (q31_t)0xec71244f, (q31_t)0x7e7e436a, (q31_t)0xec6aeeba, (q31_t)0x7e7d4d2f, (q31_t)0xec64b930, + (q31_t)0x7e7c56a5, (q31_t)0xec5e83b3, + (q31_t)0x7e7b5fce, (q31_t)0xec584e41, (q31_t)0x7e7a68a9, (q31_t)0xec5218dc, (q31_t)0x7e797136, (q31_t)0xec4be383, + (q31_t)0x7e787975, (q31_t)0xec45ae36, + (q31_t)0x7e778166, (q31_t)0xec3f78f6, (q31_t)0x7e768908, (q31_t)0xec3943c1, (q31_t)0x7e75905d, (q31_t)0xec330e99, + (q31_t)0x7e749764, (q31_t)0xec2cd97d, + (q31_t)0x7e739e1d, (q31_t)0xec26a46d, (q31_t)0x7e72a488, (q31_t)0xec206f69, (q31_t)0x7e71aaa4, (q31_t)0xec1a3a72, + (q31_t)0x7e70b073, (q31_t)0xec140587, + (q31_t)0x7e6fb5f4, (q31_t)0xec0dd0a8, (q31_t)0x7e6ebb27, (q31_t)0xec079bd6, (q31_t)0x7e6dc00c, (q31_t)0xec01670f, + (q31_t)0x7e6cc4a2, (q31_t)0xebfb3256, + (q31_t)0x7e6bc8eb, (q31_t)0xebf4fda8, (q31_t)0x7e6acce6, (q31_t)0xebeec907, (q31_t)0x7e69d093, (q31_t)0xebe89472, + (q31_t)0x7e68d3f2, (q31_t)0xebe25fea, + (q31_t)0x7e67d703, (q31_t)0xebdc2b6e, (q31_t)0x7e66d9c6, (q31_t)0xebd5f6fe, (q31_t)0x7e65dc3b, (q31_t)0xebcfc29b, + (q31_t)0x7e64de62, (q31_t)0xebc98e45, + (q31_t)0x7e63e03b, (q31_t)0xebc359fb, (q31_t)0x7e62e1c6, (q31_t)0xebbd25bd, (q31_t)0x7e61e303, (q31_t)0xebb6f18c, + (q31_t)0x7e60e3f2, (q31_t)0xebb0bd67, + (q31_t)0x7e5fe493, (q31_t)0xebaa894f, (q31_t)0x7e5ee4e6, (q31_t)0xeba45543, (q31_t)0x7e5de4ec, (q31_t)0xeb9e2144, + (q31_t)0x7e5ce4a3, (q31_t)0xeb97ed52, + (q31_t)0x7e5be40c, (q31_t)0xeb91b96c, (q31_t)0x7e5ae328, (q31_t)0xeb8b8593, (q31_t)0x7e59e1f5, (q31_t)0xeb8551c6, + (q31_t)0x7e58e075, (q31_t)0xeb7f1e06, + (q31_t)0x7e57dea7, (q31_t)0xeb78ea52, (q31_t)0x7e56dc8a, (q31_t)0xeb72b6ac, (q31_t)0x7e55da20, (q31_t)0xeb6c8312, + (q31_t)0x7e54d768, (q31_t)0xeb664f84, + (q31_t)0x7e53d462, (q31_t)0xeb601c04, (q31_t)0x7e52d10e, (q31_t)0xeb59e890, (q31_t)0x7e51cd6c, (q31_t)0xeb53b529, + (q31_t)0x7e50c97c, (q31_t)0xeb4d81ce, + (q31_t)0x7e4fc53e, (q31_t)0xeb474e81, (q31_t)0x7e4ec0b2, (q31_t)0xeb411b40, (q31_t)0x7e4dbbd9, (q31_t)0xeb3ae80c, + (q31_t)0x7e4cb6b1, (q31_t)0xeb34b4e4, + (q31_t)0x7e4bb13c, (q31_t)0xeb2e81ca, (q31_t)0x7e4aab78, (q31_t)0xeb284ebc, (q31_t)0x7e49a567, (q31_t)0xeb221bbb, + (q31_t)0x7e489f08, (q31_t)0xeb1be8c8, + (q31_t)0x7e47985b, (q31_t)0xeb15b5e1, (q31_t)0x7e469160, (q31_t)0xeb0f8307, (q31_t)0x7e458a17, (q31_t)0xeb095039, + (q31_t)0x7e448281, (q31_t)0xeb031d79, + (q31_t)0x7e437a9c, (q31_t)0xeafceac6, (q31_t)0x7e427269, (q31_t)0xeaf6b81f, (q31_t)0x7e4169e9, (q31_t)0xeaf08586, + (q31_t)0x7e40611b, (q31_t)0xeaea52fa, + (q31_t)0x7e3f57ff, (q31_t)0xeae4207a, (q31_t)0x7e3e4e95, (q31_t)0xeaddee08, (q31_t)0x7e3d44dd, (q31_t)0xead7bba3, + (q31_t)0x7e3c3ad7, (q31_t)0xead1894b, + (q31_t)0x7e3b3083, (q31_t)0xeacb56ff, (q31_t)0x7e3a25e2, (q31_t)0xeac524c1, (q31_t)0x7e391af3, (q31_t)0xeabef290, + (q31_t)0x7e380fb5, (q31_t)0xeab8c06c, + (q31_t)0x7e37042a, (q31_t)0xeab28e56, (q31_t)0x7e35f851, (q31_t)0xeaac5c4c, (q31_t)0x7e34ec2b, (q31_t)0xeaa62a4f, + (q31_t)0x7e33dfb6, (q31_t)0xea9ff860, + (q31_t)0x7e32d2f4, (q31_t)0xea99c67e, (q31_t)0x7e31c5e3, (q31_t)0xea9394a9, (q31_t)0x7e30b885, (q31_t)0xea8d62e1, + (q31_t)0x7e2faad9, (q31_t)0xea873127, + (q31_t)0x7e2e9cdf, (q31_t)0xea80ff7a, (q31_t)0x7e2d8e97, (q31_t)0xea7acdda, (q31_t)0x7e2c8002, (q31_t)0xea749c47, + (q31_t)0x7e2b711f, (q31_t)0xea6e6ac2, + (q31_t)0x7e2a61ed, (q31_t)0xea683949, (q31_t)0x7e29526e, (q31_t)0xea6207df, (q31_t)0x7e2842a2, (q31_t)0xea5bd681, + (q31_t)0x7e273287, (q31_t)0xea55a531, + (q31_t)0x7e26221f, (q31_t)0xea4f73ee, (q31_t)0x7e251168, (q31_t)0xea4942b9, (q31_t)0x7e240064, (q31_t)0xea431191, + (q31_t)0x7e22ef12, (q31_t)0xea3ce077, + (q31_t)0x7e21dd73, (q31_t)0xea36af69, (q31_t)0x7e20cb85, (q31_t)0xea307e6a, (q31_t)0x7e1fb94a, (q31_t)0xea2a4d78, + (q31_t)0x7e1ea6c1, (q31_t)0xea241c93, + (q31_t)0x7e1d93ea, (q31_t)0xea1debbb, (q31_t)0x7e1c80c5, (q31_t)0xea17baf2, (q31_t)0x7e1b6d53, (q31_t)0xea118a35, + (q31_t)0x7e1a5992, (q31_t)0xea0b5987, + (q31_t)0x7e194584, (q31_t)0xea0528e5, (q31_t)0x7e183128, (q31_t)0xe9fef852, (q31_t)0x7e171c7f, (q31_t)0xe9f8c7cc, + (q31_t)0x7e160787, (q31_t)0xe9f29753, + (q31_t)0x7e14f242, (q31_t)0xe9ec66e8, (q31_t)0x7e13dcaf, (q31_t)0xe9e6368b, (q31_t)0x7e12c6ce, (q31_t)0xe9e0063c, + (q31_t)0x7e11b0a0, (q31_t)0xe9d9d5fa, + (q31_t)0x7e109a24, (q31_t)0xe9d3a5c5, (q31_t)0x7e0f835a, (q31_t)0xe9cd759f, (q31_t)0x7e0e6c42, (q31_t)0xe9c74586, + (q31_t)0x7e0d54dc, (q31_t)0xe9c1157a, + (q31_t)0x7e0c3d29, (q31_t)0xe9bae57d, (q31_t)0x7e0b2528, (q31_t)0xe9b4b58d, (q31_t)0x7e0a0cd9, (q31_t)0xe9ae85ab, + (q31_t)0x7e08f43d, (q31_t)0xe9a855d7, + (q31_t)0x7e07db52, (q31_t)0xe9a22610, (q31_t)0x7e06c21a, (q31_t)0xe99bf658, (q31_t)0x7e05a894, (q31_t)0xe995c6ad, + (q31_t)0x7e048ec1, (q31_t)0xe98f9710, + (q31_t)0x7e0374a0, (q31_t)0xe9896781, (q31_t)0x7e025a31, (q31_t)0xe98337ff, (q31_t)0x7e013f74, (q31_t)0xe97d088c, + (q31_t)0x7e00246a, (q31_t)0xe976d926, + (q31_t)0x7dff0911, (q31_t)0xe970a9ce, (q31_t)0x7dfded6c, (q31_t)0xe96a7a85, (q31_t)0x7dfcd178, (q31_t)0xe9644b49, + (q31_t)0x7dfbb537, (q31_t)0xe95e1c1b, + (q31_t)0x7dfa98a8, (q31_t)0xe957ecfb, (q31_t)0x7df97bcb, (q31_t)0xe951bde9, (q31_t)0x7df85ea0, (q31_t)0xe94b8ee5, + (q31_t)0x7df74128, (q31_t)0xe9455fef, + (q31_t)0x7df62362, (q31_t)0xe93f3107, (q31_t)0x7df5054f, (q31_t)0xe939022d, (q31_t)0x7df3e6ee, (q31_t)0xe932d361, + (q31_t)0x7df2c83f, (q31_t)0xe92ca4a4, + (q31_t)0x7df1a942, (q31_t)0xe92675f4, (q31_t)0x7df089f8, (q31_t)0xe9204752, (q31_t)0x7def6a60, (q31_t)0xe91a18bf, + (q31_t)0x7dee4a7a, (q31_t)0xe913ea39, + (q31_t)0x7ded2a47, (q31_t)0xe90dbbc2, (q31_t)0x7dec09c6, (q31_t)0xe9078d59, (q31_t)0x7deae8f7, (q31_t)0xe9015efe, + (q31_t)0x7de9c7da, (q31_t)0xe8fb30b1, + (q31_t)0x7de8a670, (q31_t)0xe8f50273, (q31_t)0x7de784b9, (q31_t)0xe8eed443, (q31_t)0x7de662b3, (q31_t)0xe8e8a621, + (q31_t)0x7de54060, (q31_t)0xe8e2780d, + (q31_t)0x7de41dc0, (q31_t)0xe8dc4a07, (q31_t)0x7de2fad1, (q31_t)0xe8d61c10, (q31_t)0x7de1d795, (q31_t)0xe8cfee27, + (q31_t)0x7de0b40b, (q31_t)0xe8c9c04c, + (q31_t)0x7ddf9034, (q31_t)0xe8c39280, (q31_t)0x7dde6c0f, (q31_t)0xe8bd64c2, (q31_t)0x7ddd479d, (q31_t)0xe8b73712, + (q31_t)0x7ddc22dc, (q31_t)0xe8b10971, + (q31_t)0x7ddafdce, (q31_t)0xe8aadbde, (q31_t)0x7dd9d873, (q31_t)0xe8a4ae59, (q31_t)0x7dd8b2ca, (q31_t)0xe89e80e3, + (q31_t)0x7dd78cd3, (q31_t)0xe898537b, + (q31_t)0x7dd6668f, (q31_t)0xe8922622, (q31_t)0x7dd53ffc, (q31_t)0xe88bf8d7, (q31_t)0x7dd4191d, (q31_t)0xe885cb9a, + (q31_t)0x7dd2f1f0, (q31_t)0xe87f9e6c, + (q31_t)0x7dd1ca75, (q31_t)0xe879714d, (q31_t)0x7dd0a2ac, (q31_t)0xe873443c, (q31_t)0x7dcf7a96, (q31_t)0xe86d173a, + (q31_t)0x7dce5232, (q31_t)0xe866ea46, + (q31_t)0x7dcd2981, (q31_t)0xe860bd61, (q31_t)0x7dcc0082, (q31_t)0xe85a908a, (q31_t)0x7dcad736, (q31_t)0xe85463c2, + (q31_t)0x7dc9ad9c, (q31_t)0xe84e3708, + (q31_t)0x7dc883b4, (q31_t)0xe8480a5d, (q31_t)0x7dc7597f, (q31_t)0xe841ddc1, (q31_t)0x7dc62efc, (q31_t)0xe83bb133, + (q31_t)0x7dc5042b, (q31_t)0xe83584b4, + (q31_t)0x7dc3d90d, (q31_t)0xe82f5844, (q31_t)0x7dc2ada2, (q31_t)0xe8292be3, (q31_t)0x7dc181e8, (q31_t)0xe822ff90, + (q31_t)0x7dc055e2, (q31_t)0xe81cd34b, + (q31_t)0x7dbf298d, (q31_t)0xe816a716, (q31_t)0x7dbdfceb, (q31_t)0xe8107aef, (q31_t)0x7dbccffc, (q31_t)0xe80a4ed7, + (q31_t)0x7dbba2bf, (q31_t)0xe80422ce, + (q31_t)0x7dba7534, (q31_t)0xe7fdf6d4, (q31_t)0x7db9475c, (q31_t)0xe7f7cae8, (q31_t)0x7db81936, (q31_t)0xe7f19f0c, + (q31_t)0x7db6eac3, (q31_t)0xe7eb733e, + (q31_t)0x7db5bc02, (q31_t)0xe7e5477f, (q31_t)0x7db48cf4, (q31_t)0xe7df1bcf, (q31_t)0x7db35d98, (q31_t)0xe7d8f02d, + (q31_t)0x7db22def, (q31_t)0xe7d2c49b, + (q31_t)0x7db0fdf8, (q31_t)0xe7cc9917, (q31_t)0x7dafcdb3, (q31_t)0xe7c66da3, (q31_t)0x7dae9d21, (q31_t)0xe7c0423d, + (q31_t)0x7dad6c42, (q31_t)0xe7ba16e7, + (q31_t)0x7dac3b15, (q31_t)0xe7b3eb9f, (q31_t)0x7dab099a, (q31_t)0xe7adc066, (q31_t)0x7da9d7d2, (q31_t)0xe7a7953d, + (q31_t)0x7da8a5bc, (q31_t)0xe7a16a22, + (q31_t)0x7da77359, (q31_t)0xe79b3f16, (q31_t)0x7da640a9, (q31_t)0xe795141a, (q31_t)0x7da50dab, (q31_t)0xe78ee92c, + (q31_t)0x7da3da5f, (q31_t)0xe788be4e, + (q31_t)0x7da2a6c6, (q31_t)0xe782937e, (q31_t)0x7da172df, (q31_t)0xe77c68be, (q31_t)0x7da03eab, (q31_t)0xe7763e0d, + (q31_t)0x7d9f0a29, (q31_t)0xe770136b, + (q31_t)0x7d9dd55a, (q31_t)0xe769e8d8, (q31_t)0x7d9ca03e, (q31_t)0xe763be55, (q31_t)0x7d9b6ad3, (q31_t)0xe75d93e0, + (q31_t)0x7d9a351c, (q31_t)0xe757697b, + (q31_t)0x7d98ff17, (q31_t)0xe7513f25, (q31_t)0x7d97c8c4, (q31_t)0xe74b14de, (q31_t)0x7d969224, (q31_t)0xe744eaa6, + (q31_t)0x7d955b37, (q31_t)0xe73ec07e, + (q31_t)0x7d9423fc, (q31_t)0xe7389665, (q31_t)0x7d92ec73, (q31_t)0xe7326c5b, (q31_t)0x7d91b49e, (q31_t)0xe72c4260, + (q31_t)0x7d907c7a, (q31_t)0xe7261875, + (q31_t)0x7d8f4409, (q31_t)0xe71fee99, (q31_t)0x7d8e0b4b, (q31_t)0xe719c4cd, (q31_t)0x7d8cd240, (q31_t)0xe7139b10, + (q31_t)0x7d8b98e6, (q31_t)0xe70d7162, + (q31_t)0x7d8a5f40, (q31_t)0xe70747c4, (q31_t)0x7d89254c, (q31_t)0xe7011e35, (q31_t)0x7d87eb0a, (q31_t)0xe6faf4b5, + (q31_t)0x7d86b07c, (q31_t)0xe6f4cb45, + (q31_t)0x7d85759f, (q31_t)0xe6eea1e4, (q31_t)0x7d843a76, (q31_t)0xe6e87893, (q31_t)0x7d82fefe, (q31_t)0xe6e24f51, + (q31_t)0x7d81c33a, (q31_t)0xe6dc261f, + (q31_t)0x7d808728, (q31_t)0xe6d5fcfc, (q31_t)0x7d7f4ac8, (q31_t)0xe6cfd3e9, (q31_t)0x7d7e0e1c, (q31_t)0xe6c9aae5, + (q31_t)0x7d7cd121, (q31_t)0xe6c381f1, + (q31_t)0x7d7b93da, (q31_t)0xe6bd590d, (q31_t)0x7d7a5645, (q31_t)0xe6b73038, (q31_t)0x7d791862, (q31_t)0xe6b10772, + (q31_t)0x7d77da32, (q31_t)0xe6aadebc, + (q31_t)0x7d769bb5, (q31_t)0xe6a4b616, (q31_t)0x7d755cea, (q31_t)0xe69e8d80, (q31_t)0x7d741dd2, (q31_t)0xe69864f9, + (q31_t)0x7d72de6d, (q31_t)0xe6923c82, + (q31_t)0x7d719eba, (q31_t)0xe68c141a, (q31_t)0x7d705eba, (q31_t)0xe685ebc2, (q31_t)0x7d6f1e6c, (q31_t)0xe67fc37a, + (q31_t)0x7d6dddd2, (q31_t)0xe6799b42, + (q31_t)0x7d6c9ce9, (q31_t)0xe6737319, (q31_t)0x7d6b5bb4, (q31_t)0xe66d4b01, (q31_t)0x7d6a1a31, (q31_t)0xe66722f7, + (q31_t)0x7d68d860, (q31_t)0xe660fafe, + (q31_t)0x7d679642, (q31_t)0xe65ad315, (q31_t)0x7d6653d7, (q31_t)0xe654ab3b, (q31_t)0x7d65111f, (q31_t)0xe64e8371, + (q31_t)0x7d63ce19, (q31_t)0xe6485bb7, + (q31_t)0x7d628ac6, (q31_t)0xe642340d, (q31_t)0x7d614725, (q31_t)0xe63c0c73, (q31_t)0x7d600338, (q31_t)0xe635e4e9, + (q31_t)0x7d5ebefc, (q31_t)0xe62fbd6e, + (q31_t)0x7d5d7a74, (q31_t)0xe6299604, (q31_t)0x7d5c359e, (q31_t)0xe6236ea9, (q31_t)0x7d5af07b, (q31_t)0xe61d475e, + (q31_t)0x7d59ab0a, (q31_t)0xe6172024, + (q31_t)0x7d58654d, (q31_t)0xe610f8f9, (q31_t)0x7d571f41, (q31_t)0xe60ad1de, (q31_t)0x7d55d8e9, (q31_t)0xe604aad4, + (q31_t)0x7d549243, (q31_t)0xe5fe83d9, + (q31_t)0x7d534b50, (q31_t)0xe5f85cef, (q31_t)0x7d520410, (q31_t)0xe5f23614, (q31_t)0x7d50bc82, (q31_t)0xe5ec0f4a, + (q31_t)0x7d4f74a7, (q31_t)0xe5e5e88f, + (q31_t)0x7d4e2c7f, (q31_t)0xe5dfc1e5, (q31_t)0x7d4ce409, (q31_t)0xe5d99b4b, (q31_t)0x7d4b9b46, (q31_t)0xe5d374c1, + (q31_t)0x7d4a5236, (q31_t)0xe5cd4e47, + (q31_t)0x7d4908d9, (q31_t)0xe5c727dd, (q31_t)0x7d47bf2e, (q31_t)0xe5c10184, (q31_t)0x7d467536, (q31_t)0xe5badb3a, + (q31_t)0x7d452af1, (q31_t)0xe5b4b501, + (q31_t)0x7d43e05e, (q31_t)0xe5ae8ed8, (q31_t)0x7d42957e, (q31_t)0xe5a868bf, (q31_t)0x7d414a51, (q31_t)0xe5a242b7, + (q31_t)0x7d3ffed7, (q31_t)0xe59c1cbf, + (q31_t)0x7d3eb30f, (q31_t)0xe595f6d7, (q31_t)0x7d3d66fa, (q31_t)0xe58fd0ff, (q31_t)0x7d3c1a98, (q31_t)0xe589ab38, + (q31_t)0x7d3acde9, (q31_t)0xe5838581, + (q31_t)0x7d3980ec, (q31_t)0xe57d5fda, (q31_t)0x7d3833a2, (q31_t)0xe5773a44, (q31_t)0x7d36e60b, (q31_t)0xe57114be, + (q31_t)0x7d359827, (q31_t)0xe56aef49, + (q31_t)0x7d3449f5, (q31_t)0xe564c9e3, (q31_t)0x7d32fb76, (q31_t)0xe55ea48f, (q31_t)0x7d31acaa, (q31_t)0xe5587f4a, + (q31_t)0x7d305d91, (q31_t)0xe5525a17, + (q31_t)0x7d2f0e2b, (q31_t)0xe54c34f3, (q31_t)0x7d2dbe77, (q31_t)0xe5460fe0, (q31_t)0x7d2c6e76, (q31_t)0xe53feade, + (q31_t)0x7d2b1e28, (q31_t)0xe539c5ec, + (q31_t)0x7d29cd8c, (q31_t)0xe533a10a, (q31_t)0x7d287ca4, (q31_t)0xe52d7c39, (q31_t)0x7d272b6e, (q31_t)0xe5275779, + (q31_t)0x7d25d9eb, (q31_t)0xe52132c9, + (q31_t)0x7d24881b, (q31_t)0xe51b0e2a, (q31_t)0x7d2335fe, (q31_t)0xe514e99b, (q31_t)0x7d21e393, (q31_t)0xe50ec51d, + (q31_t)0x7d2090db, (q31_t)0xe508a0b0, + (q31_t)0x7d1f3dd6, (q31_t)0xe5027c53, (q31_t)0x7d1dea84, (q31_t)0xe4fc5807, (q31_t)0x7d1c96e5, (q31_t)0xe4f633cc, + (q31_t)0x7d1b42f9, (q31_t)0xe4f00fa1, + (q31_t)0x7d19eebf, (q31_t)0xe4e9eb87, (q31_t)0x7d189a38, (q31_t)0xe4e3c77d, (q31_t)0x7d174564, (q31_t)0xe4dda385, + (q31_t)0x7d15f043, (q31_t)0xe4d77f9d, + (q31_t)0x7d149ad5, (q31_t)0xe4d15bc6, (q31_t)0x7d134519, (q31_t)0xe4cb37ff, (q31_t)0x7d11ef11, (q31_t)0xe4c5144a, + (q31_t)0x7d1098bb, (q31_t)0xe4bef0a5, + (q31_t)0x7d0f4218, (q31_t)0xe4b8cd11, (q31_t)0x7d0deb28, (q31_t)0xe4b2a98e, (q31_t)0x7d0c93eb, (q31_t)0xe4ac861b, + (q31_t)0x7d0b3c60, (q31_t)0xe4a662ba, + (q31_t)0x7d09e489, (q31_t)0xe4a03f69, (q31_t)0x7d088c64, (q31_t)0xe49a1c29, (q31_t)0x7d0733f3, (q31_t)0xe493f8fb, + (q31_t)0x7d05db34, (q31_t)0xe48dd5dd, + (q31_t)0x7d048228, (q31_t)0xe487b2d0, (q31_t)0x7d0328cf, (q31_t)0xe4818fd4, (q31_t)0x7d01cf29, (q31_t)0xe47b6ce9, + (q31_t)0x7d007535, (q31_t)0xe4754a0e, + (q31_t)0x7cff1af5, (q31_t)0xe46f2745, (q31_t)0x7cfdc068, (q31_t)0xe469048d, (q31_t)0x7cfc658d, (q31_t)0xe462e1e6, + (q31_t)0x7cfb0a65, (q31_t)0xe45cbf50, + (q31_t)0x7cf9aef0, (q31_t)0xe4569ccb, (q31_t)0x7cf8532f, (q31_t)0xe4507a57, (q31_t)0x7cf6f720, (q31_t)0xe44a57f4, + (q31_t)0x7cf59ac4, (q31_t)0xe44435a2, + (q31_t)0x7cf43e1a, (q31_t)0xe43e1362, (q31_t)0x7cf2e124, (q31_t)0xe437f132, (q31_t)0x7cf183e1, (q31_t)0xe431cf14, + (q31_t)0x7cf02651, (q31_t)0xe42bad07, + (q31_t)0x7ceec873, (q31_t)0xe4258b0a, (q31_t)0x7ced6a49, (q31_t)0xe41f6920, (q31_t)0x7cec0bd1, (q31_t)0xe4194746, + (q31_t)0x7ceaad0c, (q31_t)0xe413257d, + (q31_t)0x7ce94dfb, (q31_t)0xe40d03c6, (q31_t)0x7ce7ee9c, (q31_t)0xe406e220, (q31_t)0x7ce68ef0, (q31_t)0xe400c08b, + (q31_t)0x7ce52ef7, (q31_t)0xe3fa9f08, + (q31_t)0x7ce3ceb2, (q31_t)0xe3f47d96, (q31_t)0x7ce26e1f, (q31_t)0xe3ee5c35, (q31_t)0x7ce10d3f, (q31_t)0xe3e83ae5, + (q31_t)0x7cdfac12, (q31_t)0xe3e219a7, + (q31_t)0x7cde4a98, (q31_t)0xe3dbf87a, (q31_t)0x7cdce8d1, (q31_t)0xe3d5d75e, (q31_t)0x7cdb86bd, (q31_t)0xe3cfb654, + (q31_t)0x7cda245c, (q31_t)0xe3c9955b, + (q31_t)0x7cd8c1ae, (q31_t)0xe3c37474, (q31_t)0x7cd75eb3, (q31_t)0xe3bd539e, (q31_t)0x7cd5fb6a, (q31_t)0xe3b732d9, + (q31_t)0x7cd497d5, (q31_t)0xe3b11226, + (q31_t)0x7cd333f3, (q31_t)0xe3aaf184, (q31_t)0x7cd1cfc4, (q31_t)0xe3a4d0f4, (q31_t)0x7cd06b48, (q31_t)0xe39eb075, + (q31_t)0x7ccf067f, (q31_t)0xe3989008, + (q31_t)0x7ccda169, (q31_t)0xe3926fad, (q31_t)0x7ccc3c06, (q31_t)0xe38c4f63, (q31_t)0x7ccad656, (q31_t)0xe3862f2a, + (q31_t)0x7cc97059, (q31_t)0xe3800f03, + (q31_t)0x7cc80a0f, (q31_t)0xe379eeed, (q31_t)0x7cc6a378, (q31_t)0xe373ceea, (q31_t)0x7cc53c94, (q31_t)0xe36daef7, + (q31_t)0x7cc3d563, (q31_t)0xe3678f17, + (q31_t)0x7cc26de5, (q31_t)0xe3616f48, (q31_t)0x7cc1061a, (q31_t)0xe35b4f8b, (q31_t)0x7cbf9e03, (q31_t)0xe3552fdf, + (q31_t)0x7cbe359e, (q31_t)0xe34f1045, + (q31_t)0x7cbcccec, (q31_t)0xe348f0bd, (q31_t)0x7cbb63ee, (q31_t)0xe342d146, (q31_t)0x7cb9faa2, (q31_t)0xe33cb1e1, + (q31_t)0x7cb8910a, (q31_t)0xe336928e, + (q31_t)0x7cb72724, (q31_t)0xe330734d, (q31_t)0x7cb5bcf2, (q31_t)0xe32a541d, (q31_t)0x7cb45272, (q31_t)0xe3243500, + (q31_t)0x7cb2e7a6, (q31_t)0xe31e15f4, + (q31_t)0x7cb17c8d, (q31_t)0xe317f6fa, (q31_t)0x7cb01127, (q31_t)0xe311d811, (q31_t)0x7caea574, (q31_t)0xe30bb93b, + (q31_t)0x7cad3974, (q31_t)0xe3059a76, + (q31_t)0x7cabcd28, (q31_t)0xe2ff7bc3, (q31_t)0x7caa608e, (q31_t)0xe2f95d23, (q31_t)0x7ca8f3a7, (q31_t)0xe2f33e94, + (q31_t)0x7ca78674, (q31_t)0xe2ed2017, + (q31_t)0x7ca618f3, (q31_t)0xe2e701ac, (q31_t)0x7ca4ab26, (q31_t)0xe2e0e352, (q31_t)0x7ca33d0c, (q31_t)0xe2dac50b, + (q31_t)0x7ca1cea5, (q31_t)0xe2d4a6d6, + (q31_t)0x7ca05ff1, (q31_t)0xe2ce88b3, (q31_t)0x7c9ef0f0, (q31_t)0xe2c86aa2, (q31_t)0x7c9d81a3, (q31_t)0xe2c24ca2, + (q31_t)0x7c9c1208, (q31_t)0xe2bc2eb5, + (q31_t)0x7c9aa221, (q31_t)0xe2b610da, (q31_t)0x7c9931ec, (q31_t)0xe2aff311, (q31_t)0x7c97c16b, (q31_t)0xe2a9d55a, + (q31_t)0x7c96509d, (q31_t)0xe2a3b7b5, + (q31_t)0x7c94df83, (q31_t)0xe29d9a23, (q31_t)0x7c936e1b, (q31_t)0xe2977ca2, (q31_t)0x7c91fc66, (q31_t)0xe2915f34, + (q31_t)0x7c908a65, (q31_t)0xe28b41d7, + (q31_t)0x7c8f1817, (q31_t)0xe285248d, (q31_t)0x7c8da57c, (q31_t)0xe27f0755, (q31_t)0x7c8c3294, (q31_t)0xe278ea30, + (q31_t)0x7c8abf5f, (q31_t)0xe272cd1c, + (q31_t)0x7c894bde, (q31_t)0xe26cb01b, (q31_t)0x7c87d810, (q31_t)0xe266932c, (q31_t)0x7c8663f4, (q31_t)0xe260764f, + (q31_t)0x7c84ef8c, (q31_t)0xe25a5984, + (q31_t)0x7c837ad8, (q31_t)0xe2543ccc, (q31_t)0x7c8205d6, (q31_t)0xe24e2026, (q31_t)0x7c809088, (q31_t)0xe2480393, + (q31_t)0x7c7f1aed, (q31_t)0xe241e711, + (q31_t)0x7c7da505, (q31_t)0xe23bcaa2, (q31_t)0x7c7c2ed0, (q31_t)0xe235ae46, (q31_t)0x7c7ab84e, (q31_t)0xe22f91fc, + (q31_t)0x7c794180, (q31_t)0xe22975c4, + (q31_t)0x7c77ca65, (q31_t)0xe223599e, (q31_t)0x7c7652fd, (q31_t)0xe21d3d8b, (q31_t)0x7c74db48, (q31_t)0xe217218b, + (q31_t)0x7c736347, (q31_t)0xe211059d, + (q31_t)0x7c71eaf9, (q31_t)0xe20ae9c1, (q31_t)0x7c70725e, (q31_t)0xe204cdf8, (q31_t)0x7c6ef976, (q31_t)0xe1feb241, + (q31_t)0x7c6d8041, (q31_t)0xe1f8969d, + (q31_t)0x7c6c06c0, (q31_t)0xe1f27b0b, (q31_t)0x7c6a8cf2, (q31_t)0xe1ec5f8c, (q31_t)0x7c6912d7, (q31_t)0xe1e64420, + (q31_t)0x7c679870, (q31_t)0xe1e028c6, + (q31_t)0x7c661dbc, (q31_t)0xe1da0d7e, (q31_t)0x7c64a2bb, (q31_t)0xe1d3f24a, (q31_t)0x7c63276d, (q31_t)0xe1cdd727, + (q31_t)0x7c61abd3, (q31_t)0xe1c7bc18, + (q31_t)0x7c602fec, (q31_t)0xe1c1a11b, (q31_t)0x7c5eb3b8, (q31_t)0xe1bb8631, (q31_t)0x7c5d3737, (q31_t)0xe1b56b59, + (q31_t)0x7c5bba6a, (q31_t)0xe1af5094, + (q31_t)0x7c5a3d50, (q31_t)0xe1a935e2, (q31_t)0x7c58bfe9, (q31_t)0xe1a31b42, (q31_t)0x7c574236, (q31_t)0xe19d00b6, + (q31_t)0x7c55c436, (q31_t)0xe196e63c, + (q31_t)0x7c5445e9, (q31_t)0xe190cbd4, (q31_t)0x7c52c74f, (q31_t)0xe18ab180, (q31_t)0x7c514869, (q31_t)0xe184973e, + (q31_t)0x7c4fc936, (q31_t)0xe17e7d0f, + (q31_t)0x7c4e49b7, (q31_t)0xe17862f3, (q31_t)0x7c4cc9ea, (q31_t)0xe17248ea, (q31_t)0x7c4b49d2, (q31_t)0xe16c2ef4, + (q31_t)0x7c49c96c, (q31_t)0xe1661510, + (q31_t)0x7c4848ba, (q31_t)0xe15ffb3f, (q31_t)0x7c46c7bb, (q31_t)0xe159e182, (q31_t)0x7c45466f, (q31_t)0xe153c7d7, + (q31_t)0x7c43c4d7, (q31_t)0xe14dae3f, + (q31_t)0x7c4242f2, (q31_t)0xe14794ba, (q31_t)0x7c40c0c1, (q31_t)0xe1417b48, (q31_t)0x7c3f3e42, (q31_t)0xe13b61e9, + (q31_t)0x7c3dbb78, (q31_t)0xe135489d, + (q31_t)0x7c3c3860, (q31_t)0xe12f2f63, (q31_t)0x7c3ab4fc, (q31_t)0xe129163d, (q31_t)0x7c39314b, (q31_t)0xe122fd2a, + (q31_t)0x7c37ad4e, (q31_t)0xe11ce42a, + (q31_t)0x7c362904, (q31_t)0xe116cb3d, (q31_t)0x7c34a46d, (q31_t)0xe110b263, (q31_t)0x7c331f8a, (q31_t)0xe10a999c, + (q31_t)0x7c319a5a, (q31_t)0xe10480e9, + (q31_t)0x7c3014de, (q31_t)0xe0fe6848, (q31_t)0x7c2e8f15, (q31_t)0xe0f84fbb, (q31_t)0x7c2d08ff, (q31_t)0xe0f23740, + (q31_t)0x7c2b829d, (q31_t)0xe0ec1ed9, + (q31_t)0x7c29fbee, (q31_t)0xe0e60685, (q31_t)0x7c2874f3, (q31_t)0xe0dfee44, (q31_t)0x7c26edab, (q31_t)0xe0d9d616, + (q31_t)0x7c256616, (q31_t)0xe0d3bdfc, + (q31_t)0x7c23de35, (q31_t)0xe0cda5f5, (q31_t)0x7c225607, (q31_t)0xe0c78e01, (q31_t)0x7c20cd8d, (q31_t)0xe0c17620, + (q31_t)0x7c1f44c6, (q31_t)0xe0bb5e53, + (q31_t)0x7c1dbbb3, (q31_t)0xe0b54698, (q31_t)0x7c1c3253, (q31_t)0xe0af2ef2, (q31_t)0x7c1aa8a6, (q31_t)0xe0a9175e, + (q31_t)0x7c191ead, (q31_t)0xe0a2ffde, + (q31_t)0x7c179467, (q31_t)0xe09ce871, (q31_t)0x7c1609d5, (q31_t)0xe096d117, (q31_t)0x7c147ef6, (q31_t)0xe090b9d1, + (q31_t)0x7c12f3cb, (q31_t)0xe08aa29f, + (q31_t)0x7c116853, (q31_t)0xe0848b7f, (q31_t)0x7c0fdc8f, (q31_t)0xe07e7473, (q31_t)0x7c0e507e, (q31_t)0xe0785d7b, + (q31_t)0x7c0cc421, (q31_t)0xe0724696, + (q31_t)0x7c0b3777, (q31_t)0xe06c2fc4, (q31_t)0x7c09aa80, (q31_t)0xe0661906, (q31_t)0x7c081d3d, (q31_t)0xe060025c, + (q31_t)0x7c068fae, (q31_t)0xe059ebc5, + (q31_t)0x7c0501d2, (q31_t)0xe053d541, (q31_t)0x7c0373a9, (q31_t)0xe04dbed1, (q31_t)0x7c01e534, (q31_t)0xe047a875, + (q31_t)0x7c005673, (q31_t)0xe041922c, + (q31_t)0x7bfec765, (q31_t)0xe03b7bf6, (q31_t)0x7bfd380a, (q31_t)0xe03565d5, (q31_t)0x7bfba863, (q31_t)0xe02f4fc6, + (q31_t)0x7bfa1870, (q31_t)0xe02939cc, + (q31_t)0x7bf88830, (q31_t)0xe02323e5, (q31_t)0x7bf6f7a4, (q31_t)0xe01d0e12, (q31_t)0x7bf566cb, (q31_t)0xe016f852, + (q31_t)0x7bf3d5a6, (q31_t)0xe010e2a7, + (q31_t)0x7bf24434, (q31_t)0xe00acd0e, (q31_t)0x7bf0b276, (q31_t)0xe004b78a, (q31_t)0x7bef206b, (q31_t)0xdffea219, + (q31_t)0x7bed8e14, (q31_t)0xdff88cbc, + (q31_t)0x7bebfb70, (q31_t)0xdff27773, (q31_t)0x7bea6880, (q31_t)0xdfec623e, (q31_t)0x7be8d544, (q31_t)0xdfe64d1c, + (q31_t)0x7be741bb, (q31_t)0xdfe0380e, + (q31_t)0x7be5ade6, (q31_t)0xdfda2314, (q31_t)0x7be419c4, (q31_t)0xdfd40e2e, (q31_t)0x7be28556, (q31_t)0xdfcdf95c, + (q31_t)0x7be0f09b, (q31_t)0xdfc7e49d, + (q31_t)0x7bdf5b94, (q31_t)0xdfc1cff3, (q31_t)0x7bddc641, (q31_t)0xdfbbbb5c, (q31_t)0x7bdc30a1, (q31_t)0xdfb5a6d9, + (q31_t)0x7bda9ab5, (q31_t)0xdfaf926a, + (q31_t)0x7bd9047c, (q31_t)0xdfa97e0f, (q31_t)0x7bd76df7, (q31_t)0xdfa369c8, (q31_t)0x7bd5d726, (q31_t)0xdf9d5595, + (q31_t)0x7bd44008, (q31_t)0xdf974176, + (q31_t)0x7bd2a89e, (q31_t)0xdf912d6b, (q31_t)0x7bd110e8, (q31_t)0xdf8b1974, (q31_t)0x7bcf78e5, (q31_t)0xdf850591, + (q31_t)0x7bcde095, (q31_t)0xdf7ef1c2, + (q31_t)0x7bcc47fa, (q31_t)0xdf78de07, (q31_t)0x7bcaaf12, (q31_t)0xdf72ca60, (q31_t)0x7bc915dd, (q31_t)0xdf6cb6cd, + (q31_t)0x7bc77c5d, (q31_t)0xdf66a34e, + (q31_t)0x7bc5e290, (q31_t)0xdf608fe4, (q31_t)0x7bc44876, (q31_t)0xdf5a7c8d, (q31_t)0x7bc2ae10, (q31_t)0xdf54694b, + (q31_t)0x7bc1135e, (q31_t)0xdf4e561c, + (q31_t)0x7bbf7860, (q31_t)0xdf484302, (q31_t)0x7bbddd15, (q31_t)0xdf422ffd, (q31_t)0x7bbc417e, (q31_t)0xdf3c1d0b, + (q31_t)0x7bbaa59a, (q31_t)0xdf360a2d, + (q31_t)0x7bb9096b, (q31_t)0xdf2ff764, (q31_t)0x7bb76cef, (q31_t)0xdf29e4af, (q31_t)0x7bb5d026, (q31_t)0xdf23d20e, + (q31_t)0x7bb43311, (q31_t)0xdf1dbf82, + (q31_t)0x7bb295b0, (q31_t)0xdf17ad0a, (q31_t)0x7bb0f803, (q31_t)0xdf119aa6, (q31_t)0x7baf5a09, (q31_t)0xdf0b8856, + (q31_t)0x7badbbc3, (q31_t)0xdf05761b, + (q31_t)0x7bac1d31, (q31_t)0xdeff63f4, (q31_t)0x7baa7e53, (q31_t)0xdef951e2, (q31_t)0x7ba8df28, (q31_t)0xdef33fe3, + (q31_t)0x7ba73fb1, (q31_t)0xdeed2dfa, + (q31_t)0x7ba59fee, (q31_t)0xdee71c24, (q31_t)0x7ba3ffde, (q31_t)0xdee10a63, (q31_t)0x7ba25f82, (q31_t)0xdedaf8b7, + (q31_t)0x7ba0beda, (q31_t)0xded4e71f, + (q31_t)0x7b9f1de6, (q31_t)0xdeced59b, (q31_t)0x7b9d7ca5, (q31_t)0xdec8c42c, (q31_t)0x7b9bdb18, (q31_t)0xdec2b2d1, + (q31_t)0x7b9a393f, (q31_t)0xdebca18b, + (q31_t)0x7b989719, (q31_t)0xdeb69059, (q31_t)0x7b96f4a8, (q31_t)0xdeb07f3c, (q31_t)0x7b9551ea, (q31_t)0xdeaa6e34, + (q31_t)0x7b93aee0, (q31_t)0xdea45d40, + (q31_t)0x7b920b89, (q31_t)0xde9e4c60, (q31_t)0x7b9067e7, (q31_t)0xde983b95, (q31_t)0x7b8ec3f8, (q31_t)0xde922adf, + (q31_t)0x7b8d1fbd, (q31_t)0xde8c1a3e, + (q31_t)0x7b8b7b36, (q31_t)0xde8609b1, (q31_t)0x7b89d662, (q31_t)0xde7ff938, (q31_t)0x7b883143, (q31_t)0xde79e8d5, + (q31_t)0x7b868bd7, (q31_t)0xde73d886, + (q31_t)0x7b84e61f, (q31_t)0xde6dc84b, (q31_t)0x7b83401b, (q31_t)0xde67b826, (q31_t)0x7b8199ca, (q31_t)0xde61a815, + (q31_t)0x7b7ff32e, (q31_t)0xde5b9819, + (q31_t)0x7b7e4c45, (q31_t)0xde558831, (q31_t)0x7b7ca510, (q31_t)0xde4f785f, (q31_t)0x7b7afd8f, (q31_t)0xde4968a1, + (q31_t)0x7b7955c2, (q31_t)0xde4358f8, + (q31_t)0x7b77ada8, (q31_t)0xde3d4964, (q31_t)0x7b760542, (q31_t)0xde3739e4, (q31_t)0x7b745c91, (q31_t)0xde312a7a, + (q31_t)0x7b72b393, (q31_t)0xde2b1b24, + (q31_t)0x7b710a49, (q31_t)0xde250be3, (q31_t)0x7b6f60b2, (q31_t)0xde1efcb7, (q31_t)0x7b6db6d0, (q31_t)0xde18eda0, + (q31_t)0x7b6c0ca2, (q31_t)0xde12de9e, + (q31_t)0x7b6a6227, (q31_t)0xde0ccfb1, (q31_t)0x7b68b760, (q31_t)0xde06c0d9, (q31_t)0x7b670c4d, (q31_t)0xde00b216, + (q31_t)0x7b6560ee, (q31_t)0xddfaa367, + (q31_t)0x7b63b543, (q31_t)0xddf494ce, (q31_t)0x7b62094c, (q31_t)0xddee8649, (q31_t)0x7b605d09, (q31_t)0xdde877da, + (q31_t)0x7b5eb079, (q31_t)0xdde26980, + (q31_t)0x7b5d039e, (q31_t)0xdddc5b3b, (q31_t)0x7b5b5676, (q31_t)0xddd64d0a, (q31_t)0x7b59a902, (q31_t)0xddd03eef, + (q31_t)0x7b57fb42, (q31_t)0xddca30e9, + (q31_t)0x7b564d36, (q31_t)0xddc422f8, (q31_t)0x7b549ede, (q31_t)0xddbe151d, (q31_t)0x7b52f03a, (q31_t)0xddb80756, + (q31_t)0x7b51414a, (q31_t)0xddb1f9a4, + (q31_t)0x7b4f920e, (q31_t)0xddabec08, (q31_t)0x7b4de286, (q31_t)0xdda5de81, (q31_t)0x7b4c32b1, (q31_t)0xdd9fd10f, + (q31_t)0x7b4a8291, (q31_t)0xdd99c3b2, + (q31_t)0x7b48d225, (q31_t)0xdd93b66a, (q31_t)0x7b47216c, (q31_t)0xdd8da938, (q31_t)0x7b457068, (q31_t)0xdd879c1b, + (q31_t)0x7b43bf17, (q31_t)0xdd818f13, + (q31_t)0x7b420d7a, (q31_t)0xdd7b8220, (q31_t)0x7b405b92, (q31_t)0xdd757543, (q31_t)0x7b3ea95d, (q31_t)0xdd6f687b, + (q31_t)0x7b3cf6dc, (q31_t)0xdd695bc9, + (q31_t)0x7b3b4410, (q31_t)0xdd634f2b, (q31_t)0x7b3990f7, (q31_t)0xdd5d42a3, (q31_t)0x7b37dd92, (q31_t)0xdd573631, + (q31_t)0x7b3629e1, (q31_t)0xdd5129d4, + (q31_t)0x7b3475e5, (q31_t)0xdd4b1d8c, (q31_t)0x7b32c19c, (q31_t)0xdd451159, (q31_t)0x7b310d07, (q31_t)0xdd3f053c, + (q31_t)0x7b2f5826, (q31_t)0xdd38f935, + (q31_t)0x7b2da2fa, (q31_t)0xdd32ed43, (q31_t)0x7b2bed81, (q31_t)0xdd2ce166, (q31_t)0x7b2a37bc, (q31_t)0xdd26d59f, + (q31_t)0x7b2881ac, (q31_t)0xdd20c9ed, + (q31_t)0x7b26cb4f, (q31_t)0xdd1abe51, (q31_t)0x7b2514a6, (q31_t)0xdd14b2ca, (q31_t)0x7b235db2, (q31_t)0xdd0ea759, + (q31_t)0x7b21a671, (q31_t)0xdd089bfe, + (q31_t)0x7b1feee5, (q31_t)0xdd0290b8, (q31_t)0x7b1e370d, (q31_t)0xdcfc8588, (q31_t)0x7b1c7ee8, (q31_t)0xdcf67a6d, + (q31_t)0x7b1ac678, (q31_t)0xdcf06f68, + (q31_t)0x7b190dbc, (q31_t)0xdcea6478, (q31_t)0x7b1754b3, (q31_t)0xdce4599e, (q31_t)0x7b159b5f, (q31_t)0xdcde4eda, + (q31_t)0x7b13e1bf, (q31_t)0xdcd8442b, + (q31_t)0x7b1227d3, (q31_t)0xdcd23993, (q31_t)0x7b106d9b, (q31_t)0xdccc2f0f, (q31_t)0x7b0eb318, (q31_t)0xdcc624a2, + (q31_t)0x7b0cf848, (q31_t)0xdcc01a4a, + (q31_t)0x7b0b3d2c, (q31_t)0xdcba1008, (q31_t)0x7b0981c5, (q31_t)0xdcb405dc, (q31_t)0x7b07c612, (q31_t)0xdcadfbc5, + (q31_t)0x7b060a12, (q31_t)0xdca7f1c5, + (q31_t)0x7b044dc7, (q31_t)0xdca1e7da, (q31_t)0x7b029130, (q31_t)0xdc9bde05, (q31_t)0x7b00d44d, (q31_t)0xdc95d446, + (q31_t)0x7aff171e, (q31_t)0xdc8fca9c, + (q31_t)0x7afd59a4, (q31_t)0xdc89c109, (q31_t)0x7afb9bdd, (q31_t)0xdc83b78b, (q31_t)0x7af9ddcb, (q31_t)0xdc7dae23, + (q31_t)0x7af81f6c, (q31_t)0xdc77a4d2, + (q31_t)0x7af660c2, (q31_t)0xdc719b96, (q31_t)0x7af4a1cc, (q31_t)0xdc6b9270, (q31_t)0x7af2e28b, (q31_t)0xdc658960, + (q31_t)0x7af122fd, (q31_t)0xdc5f8066, + (q31_t)0x7aef6323, (q31_t)0xdc597781, (q31_t)0x7aeda2fe, (q31_t)0xdc536eb3, (q31_t)0x7aebe28d, (q31_t)0xdc4d65fb, + (q31_t)0x7aea21d0, (q31_t)0xdc475d59, + (q31_t)0x7ae860c7, (q31_t)0xdc4154cd, (q31_t)0x7ae69f73, (q31_t)0xdc3b4c57, (q31_t)0x7ae4ddd2, (q31_t)0xdc3543f7, + (q31_t)0x7ae31be6, (q31_t)0xdc2f3bad, + (q31_t)0x7ae159ae, (q31_t)0xdc293379, (q31_t)0x7adf972a, (q31_t)0xdc232b5c, (q31_t)0x7addd45b, (q31_t)0xdc1d2354, + (q31_t)0x7adc113f, (q31_t)0xdc171b63, + (q31_t)0x7ada4dd8, (q31_t)0xdc111388, (q31_t)0x7ad88a25, (q31_t)0xdc0b0bc2, (q31_t)0x7ad6c626, (q31_t)0xdc050414, + (q31_t)0x7ad501dc, (q31_t)0xdbfefc7b, + (q31_t)0x7ad33d45, (q31_t)0xdbf8f4f8, (q31_t)0x7ad17863, (q31_t)0xdbf2ed8c, (q31_t)0x7acfb336, (q31_t)0xdbece636, + (q31_t)0x7acdedbc, (q31_t)0xdbe6def6, + (q31_t)0x7acc27f7, (q31_t)0xdbe0d7cd, (q31_t)0x7aca61e6, (q31_t)0xdbdad0b9, (q31_t)0x7ac89b89, (q31_t)0xdbd4c9bc, + (q31_t)0x7ac6d4e0, (q31_t)0xdbcec2d6, + (q31_t)0x7ac50dec, (q31_t)0xdbc8bc06, (q31_t)0x7ac346ac, (q31_t)0xdbc2b54c, (q31_t)0x7ac17f20, (q31_t)0xdbbcaea8, + (q31_t)0x7abfb749, (q31_t)0xdbb6a81b, + (q31_t)0x7abdef25, (q31_t)0xdbb0a1a4, (q31_t)0x7abc26b7, (q31_t)0xdbaa9b43, (q31_t)0x7aba5dfc, (q31_t)0xdba494f9, + (q31_t)0x7ab894f6, (q31_t)0xdb9e8ec6, + (q31_t)0x7ab6cba4, (q31_t)0xdb9888a8, (q31_t)0x7ab50206, (q31_t)0xdb9282a2, (q31_t)0x7ab3381d, (q31_t)0xdb8c7cb1, + (q31_t)0x7ab16de7, (q31_t)0xdb8676d8, + (q31_t)0x7aafa367, (q31_t)0xdb807114, (q31_t)0x7aadd89a, (q31_t)0xdb7a6b68, (q31_t)0x7aac0d82, (q31_t)0xdb7465d1, + (q31_t)0x7aaa421e, (q31_t)0xdb6e6052, + (q31_t)0x7aa8766f, (q31_t)0xdb685ae9, (q31_t)0x7aa6aa74, (q31_t)0xdb625596, (q31_t)0x7aa4de2d, (q31_t)0xdb5c505a, + (q31_t)0x7aa3119a, (q31_t)0xdb564b35, + (q31_t)0x7aa144bc, (q31_t)0xdb504626, (q31_t)0x7a9f7793, (q31_t)0xdb4a412e, (q31_t)0x7a9daa1d, (q31_t)0xdb443c4c, + (q31_t)0x7a9bdc5c, (q31_t)0xdb3e3781, + (q31_t)0x7a9a0e50, (q31_t)0xdb3832cd, (q31_t)0x7a983ff7, (q31_t)0xdb322e30, (q31_t)0x7a967153, (q31_t)0xdb2c29a9, + (q31_t)0x7a94a264, (q31_t)0xdb262539, + (q31_t)0x7a92d329, (q31_t)0xdb2020e0, (q31_t)0x7a9103a2, (q31_t)0xdb1a1c9d, (q31_t)0x7a8f33d0, (q31_t)0xdb141871, + (q31_t)0x7a8d63b2, (q31_t)0xdb0e145c, + (q31_t)0x7a8b9348, (q31_t)0xdb08105e, (q31_t)0x7a89c293, (q31_t)0xdb020c77, (q31_t)0x7a87f192, (q31_t)0xdafc08a6, + (q31_t)0x7a862046, (q31_t)0xdaf604ec, + (q31_t)0x7a844eae, (q31_t)0xdaf00149, (q31_t)0x7a827ccb, (q31_t)0xdae9fdbd, (q31_t)0x7a80aa9c, (q31_t)0xdae3fa48, + (q31_t)0x7a7ed821, (q31_t)0xdaddf6ea, + (q31_t)0x7a7d055b, (q31_t)0xdad7f3a2, (q31_t)0x7a7b3249, (q31_t)0xdad1f072, (q31_t)0x7a795eec, (q31_t)0xdacbed58, + (q31_t)0x7a778b43, (q31_t)0xdac5ea56, + (q31_t)0x7a75b74f, (q31_t)0xdabfe76a, (q31_t)0x7a73e30f, (q31_t)0xdab9e495, (q31_t)0x7a720e84, (q31_t)0xdab3e1d8, + (q31_t)0x7a7039ad, (q31_t)0xdaaddf31, + (q31_t)0x7a6e648a, (q31_t)0xdaa7dca1, (q31_t)0x7a6c8f1c, (q31_t)0xdaa1da29, (q31_t)0x7a6ab963, (q31_t)0xda9bd7c7, + (q31_t)0x7a68e35e, (q31_t)0xda95d57d, + (q31_t)0x7a670d0d, (q31_t)0xda8fd349, (q31_t)0x7a653671, (q31_t)0xda89d12d, (q31_t)0x7a635f8a, (q31_t)0xda83cf28, + (q31_t)0x7a618857, (q31_t)0xda7dcd3a, + (q31_t)0x7a5fb0d8, (q31_t)0xda77cb63, (q31_t)0x7a5dd90e, (q31_t)0xda71c9a3, (q31_t)0x7a5c00f9, (q31_t)0xda6bc7fa, + (q31_t)0x7a5a2898, (q31_t)0xda65c669, + (q31_t)0x7a584feb, (q31_t)0xda5fc4ef, (q31_t)0x7a5676f3, (q31_t)0xda59c38c, (q31_t)0x7a549db0, (q31_t)0xda53c240, + (q31_t)0x7a52c421, (q31_t)0xda4dc10b, + (q31_t)0x7a50ea47, (q31_t)0xda47bfee, (q31_t)0x7a4f1021, (q31_t)0xda41bee8, (q31_t)0x7a4d35b0, (q31_t)0xda3bbdf9, + (q31_t)0x7a4b5af3, (q31_t)0xda35bd22, + (q31_t)0x7a497feb, (q31_t)0xda2fbc61, (q31_t)0x7a47a498, (q31_t)0xda29bbb9, (q31_t)0x7a45c8f9, (q31_t)0xda23bb27, + (q31_t)0x7a43ed0e, (q31_t)0xda1dbaad, + (q31_t)0x7a4210d8, (q31_t)0xda17ba4a, (q31_t)0x7a403457, (q31_t)0xda11b9ff, (q31_t)0x7a3e578b, (q31_t)0xda0bb9cb, + (q31_t)0x7a3c7a73, (q31_t)0xda05b9ae, + (q31_t)0x7a3a9d0f, (q31_t)0xd9ffb9a9, (q31_t)0x7a38bf60, (q31_t)0xd9f9b9bb, (q31_t)0x7a36e166, (q31_t)0xd9f3b9e5, + (q31_t)0x7a350321, (q31_t)0xd9edba26, + (q31_t)0x7a332490, (q31_t)0xd9e7ba7f, (q31_t)0x7a3145b3, (q31_t)0xd9e1baef, (q31_t)0x7a2f668c, (q31_t)0xd9dbbb77, + (q31_t)0x7a2d8719, (q31_t)0xd9d5bc16, + (q31_t)0x7a2ba75a, (q31_t)0xd9cfbccd, (q31_t)0x7a29c750, (q31_t)0xd9c9bd9b, (q31_t)0x7a27e6fb, (q31_t)0xd9c3be81, + (q31_t)0x7a26065b, (q31_t)0xd9bdbf7e, + (q31_t)0x7a24256f, (q31_t)0xd9b7c094, (q31_t)0x7a224437, (q31_t)0xd9b1c1c0, (q31_t)0x7a2062b5, (q31_t)0xd9abc305, + (q31_t)0x7a1e80e7, (q31_t)0xd9a5c461, + (q31_t)0x7a1c9ece, (q31_t)0xd99fc5d4, (q31_t)0x7a1abc69, (q31_t)0xd999c75f, (q31_t)0x7a18d9b9, (q31_t)0xd993c902, + (q31_t)0x7a16f6be, (q31_t)0xd98dcabd, + (q31_t)0x7a151378, (q31_t)0xd987cc90, (q31_t)0x7a132fe6, (q31_t)0xd981ce7a, (q31_t)0x7a114c09, (q31_t)0xd97bd07c, + (q31_t)0x7a0f67e0, (q31_t)0xd975d295, + (q31_t)0x7a0d836d, (q31_t)0xd96fd4c7, (q31_t)0x7a0b9eae, (q31_t)0xd969d710, (q31_t)0x7a09b9a4, (q31_t)0xd963d971, + (q31_t)0x7a07d44e, (q31_t)0xd95ddbea, + (q31_t)0x7a05eead, (q31_t)0xd957de7a, (q31_t)0x7a0408c1, (q31_t)0xd951e123, (q31_t)0x7a02228a, (q31_t)0xd94be3e3, + (q31_t)0x7a003c07, (q31_t)0xd945e6bb, + (q31_t)0x79fe5539, (q31_t)0xd93fe9ab, (q31_t)0x79fc6e20, (q31_t)0xd939ecb3, (q31_t)0x79fa86bc, (q31_t)0xd933efd3, + (q31_t)0x79f89f0c, (q31_t)0xd92df30b, + (q31_t)0x79f6b711, (q31_t)0xd927f65b, (q31_t)0x79f4cecb, (q31_t)0xd921f9c3, (q31_t)0x79f2e63a, (q31_t)0xd91bfd43, + (q31_t)0x79f0fd5d, (q31_t)0xd91600da, + (q31_t)0x79ef1436, (q31_t)0xd910048a, (q31_t)0x79ed2ac3, (q31_t)0xd90a0852, (q31_t)0x79eb4105, (q31_t)0xd9040c32, + (q31_t)0x79e956fb, (q31_t)0xd8fe1029, + (q31_t)0x79e76ca7, (q31_t)0xd8f81439, (q31_t)0x79e58207, (q31_t)0xd8f21861, (q31_t)0x79e3971c, (q31_t)0xd8ec1ca1, + (q31_t)0x79e1abe6, (q31_t)0xd8e620fa, + (q31_t)0x79dfc064, (q31_t)0xd8e0256a, (q31_t)0x79ddd498, (q31_t)0xd8da29f2, (q31_t)0x79dbe880, (q31_t)0xd8d42e93, + (q31_t)0x79d9fc1d, (q31_t)0xd8ce334c, + (q31_t)0x79d80f6f, (q31_t)0xd8c8381d, (q31_t)0x79d62276, (q31_t)0xd8c23d06, (q31_t)0x79d43532, (q31_t)0xd8bc4207, + (q31_t)0x79d247a2, (q31_t)0xd8b64720, + (q31_t)0x79d059c8, (q31_t)0xd8b04c52, (q31_t)0x79ce6ba2, (q31_t)0xd8aa519c, (q31_t)0x79cc7d31, (q31_t)0xd8a456ff, + (q31_t)0x79ca8e75, (q31_t)0xd89e5c79, + (q31_t)0x79c89f6e, (q31_t)0xd898620c, (q31_t)0x79c6b01b, (q31_t)0xd89267b7, (q31_t)0x79c4c07e, (q31_t)0xd88c6d7b, + (q31_t)0x79c2d095, (q31_t)0xd8867356, + (q31_t)0x79c0e062, (q31_t)0xd880794b, (q31_t)0x79beefe3, (q31_t)0xd87a7f57, (q31_t)0x79bcff19, (q31_t)0xd874857c, + (q31_t)0x79bb0e04, (q31_t)0xd86e8bb9, + (q31_t)0x79b91ca4, (q31_t)0xd868920f, (q31_t)0x79b72af9, (q31_t)0xd862987d, (q31_t)0x79b53903, (q31_t)0xd85c9f04, + (q31_t)0x79b346c2, (q31_t)0xd856a5a3, + (q31_t)0x79b15435, (q31_t)0xd850ac5a, (q31_t)0x79af615e, (q31_t)0xd84ab32a, (q31_t)0x79ad6e3c, (q31_t)0xd844ba13, + (q31_t)0x79ab7ace, (q31_t)0xd83ec114, + (q31_t)0x79a98715, (q31_t)0xd838c82d, (q31_t)0x79a79312, (q31_t)0xd832cf5f, (q31_t)0x79a59ec3, (q31_t)0xd82cd6aa, + (q31_t)0x79a3aa29, (q31_t)0xd826de0d, + (q31_t)0x79a1b545, (q31_t)0xd820e589, (q31_t)0x799fc015, (q31_t)0xd81aed1d, (q31_t)0x799dca9a, (q31_t)0xd814f4ca, + (q31_t)0x799bd4d4, (q31_t)0xd80efc8f, + (q31_t)0x7999dec4, (q31_t)0xd809046e, (q31_t)0x7997e868, (q31_t)0xd8030c64, (q31_t)0x7995f1c1, (q31_t)0xd7fd1474, + (q31_t)0x7993facf, (q31_t)0xd7f71c9c, + (q31_t)0x79920392, (q31_t)0xd7f124dd, (q31_t)0x79900c0a, (q31_t)0xd7eb2d37, (q31_t)0x798e1438, (q31_t)0xd7e535a9, + (q31_t)0x798c1c1a, (q31_t)0xd7df3e34, + (q31_t)0x798a23b1, (q31_t)0xd7d946d8, (q31_t)0x79882afd, (q31_t)0xd7d34f94, (q31_t)0x798631ff, (q31_t)0xd7cd586a, + (q31_t)0x798438b5, (q31_t)0xd7c76158, + (q31_t)0x79823f20, (q31_t)0xd7c16a5f, (q31_t)0x79804541, (q31_t)0xd7bb737f, (q31_t)0x797e4b16, (q31_t)0xd7b57cb7, + (q31_t)0x797c50a1, (q31_t)0xd7af8609, + (q31_t)0x797a55e0, (q31_t)0xd7a98f73, (q31_t)0x79785ad5, (q31_t)0xd7a398f6, (q31_t)0x79765f7f, (q31_t)0xd79da293, + (q31_t)0x797463de, (q31_t)0xd797ac48, + (q31_t)0x797267f2, (q31_t)0xd791b616, (q31_t)0x79706bbb, (q31_t)0xd78bbffc, (q31_t)0x796e6f39, (q31_t)0xd785c9fc, + (q31_t)0x796c726c, (q31_t)0xd77fd415, + (q31_t)0x796a7554, (q31_t)0xd779de47, (q31_t)0x796877f1, (q31_t)0xd773e892, (q31_t)0x79667a44, (q31_t)0xd76df2f6, + (q31_t)0x79647c4c, (q31_t)0xd767fd72, + (q31_t)0x79627e08, (q31_t)0xd7620808, (q31_t)0x79607f7a, (q31_t)0xd75c12b7, (q31_t)0x795e80a1, (q31_t)0xd7561d7f, + (q31_t)0x795c817d, (q31_t)0xd7502860, + (q31_t)0x795a820e, (q31_t)0xd74a335b, (q31_t)0x79588255, (q31_t)0xd7443e6e, (q31_t)0x79568250, (q31_t)0xd73e499a, + (q31_t)0x79548201, (q31_t)0xd73854e0, + (q31_t)0x79528167, (q31_t)0xd732603f, (q31_t)0x79508082, (q31_t)0xd72c6bb6, (q31_t)0x794e7f52, (q31_t)0xd7267748, + (q31_t)0x794c7dd7, (q31_t)0xd72082f2, + (q31_t)0x794a7c12, (q31_t)0xd71a8eb5, (q31_t)0x79487a01, (q31_t)0xd7149a92, (q31_t)0x794677a6, (q31_t)0xd70ea688, + (q31_t)0x79447500, (q31_t)0xd708b297, + (q31_t)0x79427210, (q31_t)0xd702bec0, (q31_t)0x79406ed4, (q31_t)0xd6fccb01, (q31_t)0x793e6b4e, (q31_t)0xd6f6d75d, + (q31_t)0x793c677d, (q31_t)0xd6f0e3d1, + (q31_t)0x793a6361, (q31_t)0xd6eaf05f, (q31_t)0x79385efa, (q31_t)0xd6e4fd06, (q31_t)0x79365a49, (q31_t)0xd6df09c6, + (q31_t)0x7934554d, (q31_t)0xd6d916a0, + (q31_t)0x79325006, (q31_t)0xd6d32393, (q31_t)0x79304a74, (q31_t)0xd6cd30a0, (q31_t)0x792e4497, (q31_t)0xd6c73dc6, + (q31_t)0x792c3e70, (q31_t)0xd6c14b05, + (q31_t)0x792a37fe, (q31_t)0xd6bb585e, (q31_t)0x79283141, (q31_t)0xd6b565d0, (q31_t)0x79262a3a, (q31_t)0xd6af735c, + (q31_t)0x792422e8, (q31_t)0xd6a98101, + (q31_t)0x79221b4b, (q31_t)0xd6a38ec0, (q31_t)0x79201363, (q31_t)0xd69d9c98, (q31_t)0x791e0b31, (q31_t)0xd697aa8a, + (q31_t)0x791c02b4, (q31_t)0xd691b895, + (q31_t)0x7919f9ec, (q31_t)0xd68bc6ba, (q31_t)0x7917f0d9, (q31_t)0xd685d4f9, (q31_t)0x7915e77c, (q31_t)0xd67fe351, + (q31_t)0x7913ddd4, (q31_t)0xd679f1c2, + (q31_t)0x7911d3e2, (q31_t)0xd674004e, (q31_t)0x790fc9a4, (q31_t)0xd66e0ef2, (q31_t)0x790dbf1d, (q31_t)0xd6681db1, + (q31_t)0x790bb44a, (q31_t)0xd6622c89, + (q31_t)0x7909a92d, (q31_t)0xd65c3b7b, (q31_t)0x79079dc5, (q31_t)0xd6564a87, (q31_t)0x79059212, (q31_t)0xd65059ac, + (q31_t)0x79038615, (q31_t)0xd64a68eb, + (q31_t)0x790179cd, (q31_t)0xd6447844, (q31_t)0x78ff6d3b, (q31_t)0xd63e87b6, (q31_t)0x78fd605d, (q31_t)0xd6389742, + (q31_t)0x78fb5336, (q31_t)0xd632a6e8, + (q31_t)0x78f945c3, (q31_t)0xd62cb6a8, (q31_t)0x78f73806, (q31_t)0xd626c681, (q31_t)0x78f529fe, (q31_t)0xd620d675, + (q31_t)0x78f31bac, (q31_t)0xd61ae682, + (q31_t)0x78f10d0f, (q31_t)0xd614f6a9, (q31_t)0x78eefe28, (q31_t)0xd60f06ea, (q31_t)0x78eceef6, (q31_t)0xd6091745, + (q31_t)0x78eadf79, (q31_t)0xd60327b9, + (q31_t)0x78e8cfb2, (q31_t)0xd5fd3848, (q31_t)0x78e6bfa0, (q31_t)0xd5f748f0, (q31_t)0x78e4af44, (q31_t)0xd5f159b3, + (q31_t)0x78e29e9d, (q31_t)0xd5eb6a8f, + (q31_t)0x78e08dab, (q31_t)0xd5e57b85, (q31_t)0x78de7c6f, (q31_t)0xd5df8c96, (q31_t)0x78dc6ae8, (q31_t)0xd5d99dc0, + (q31_t)0x78da5917, (q31_t)0xd5d3af04, + (q31_t)0x78d846fb, (q31_t)0xd5cdc062, (q31_t)0x78d63495, (q31_t)0xd5c7d1db, (q31_t)0x78d421e4, (q31_t)0xd5c1e36d, + (q31_t)0x78d20ee9, (q31_t)0xd5bbf519, + (q31_t)0x78cffba3, (q31_t)0xd5b606e0, (q31_t)0x78cde812, (q31_t)0xd5b018c0, (q31_t)0x78cbd437, (q31_t)0xd5aa2abb, + (q31_t)0x78c9c012, (q31_t)0xd5a43cd0, + (q31_t)0x78c7aba2, (q31_t)0xd59e4eff, (q31_t)0x78c596e7, (q31_t)0xd5986148, (q31_t)0x78c381e2, (q31_t)0xd59273ab, + (q31_t)0x78c16c93, (q31_t)0xd58c8628, + (q31_t)0x78bf56f9, (q31_t)0xd58698c0, (q31_t)0x78bd4114, (q31_t)0xd580ab72, (q31_t)0x78bb2ae5, (q31_t)0xd57abe3d, + (q31_t)0x78b9146c, (q31_t)0xd574d124, + (q31_t)0x78b6fda8, (q31_t)0xd56ee424, (q31_t)0x78b4e69a, (q31_t)0xd568f73f, (q31_t)0x78b2cf41, (q31_t)0xd5630a74, + (q31_t)0x78b0b79e, (q31_t)0xd55d1dc3, + (q31_t)0x78ae9fb0, (q31_t)0xd557312d, (q31_t)0x78ac8778, (q31_t)0xd55144b0, (q31_t)0x78aa6ef5, (q31_t)0xd54b584f, + (q31_t)0x78a85628, (q31_t)0xd5456c07, + (q31_t)0x78a63d11, (q31_t)0xd53f7fda, (q31_t)0x78a423af, (q31_t)0xd53993c7, (q31_t)0x78a20a03, (q31_t)0xd533a7cf, + (q31_t)0x789ff00c, (q31_t)0xd52dbbf1, + (q31_t)0x789dd5cb, (q31_t)0xd527d02e, (q31_t)0x789bbb3f, (q31_t)0xd521e484, (q31_t)0x7899a06a, (q31_t)0xd51bf8f6, + (q31_t)0x78978549, (q31_t)0xd5160d82, + (q31_t)0x789569df, (q31_t)0xd5102228, (q31_t)0x78934e2a, (q31_t)0xd50a36e9, (q31_t)0x7891322a, (q31_t)0xd5044bc4, + (q31_t)0x788f15e0, (q31_t)0xd4fe60ba, + (q31_t)0x788cf94c, (q31_t)0xd4f875ca, (q31_t)0x788adc6e, (q31_t)0xd4f28af5, (q31_t)0x7888bf45, (q31_t)0xd4eca03a, + (q31_t)0x7886a1d1, (q31_t)0xd4e6b59a, + (q31_t)0x78848414, (q31_t)0xd4e0cb15, (q31_t)0x7882660c, (q31_t)0xd4dae0aa, (q31_t)0x788047ba, (q31_t)0xd4d4f65a, + (q31_t)0x787e291d, (q31_t)0xd4cf0c24, + (q31_t)0x787c0a36, (q31_t)0xd4c92209, (q31_t)0x7879eb05, (q31_t)0xd4c33809, (q31_t)0x7877cb89, (q31_t)0xd4bd4e23, + (q31_t)0x7875abc3, (q31_t)0xd4b76458, + (q31_t)0x78738bb3, (q31_t)0xd4b17aa8, (q31_t)0x78716b59, (q31_t)0xd4ab9112, (q31_t)0x786f4ab4, (q31_t)0xd4a5a798, + (q31_t)0x786d29c5, (q31_t)0xd49fbe37, + (q31_t)0x786b088c, (q31_t)0xd499d4f2, (q31_t)0x7868e708, (q31_t)0xd493ebc8, (q31_t)0x7866c53a, (q31_t)0xd48e02b8, + (q31_t)0x7864a322, (q31_t)0xd48819c3, + (q31_t)0x786280bf, (q31_t)0xd48230e9, (q31_t)0x78605e13, (q31_t)0xd47c4829, (q31_t)0x785e3b1c, (q31_t)0xd4765f85, + (q31_t)0x785c17db, (q31_t)0xd47076fb, + (q31_t)0x7859f44f, (q31_t)0xd46a8e8d, (q31_t)0x7857d079, (q31_t)0xd464a639, (q31_t)0x7855ac5a, (q31_t)0xd45ebe00, + (q31_t)0x785387ef, (q31_t)0xd458d5e2, + (q31_t)0x7851633b, (q31_t)0xd452eddf, (q31_t)0x784f3e3c, (q31_t)0xd44d05f6, (q31_t)0x784d18f4, (q31_t)0xd4471e29, + (q31_t)0x784af361, (q31_t)0xd4413677, + (q31_t)0x7848cd83, (q31_t)0xd43b4ee0, (q31_t)0x7846a75c, (q31_t)0xd4356763, (q31_t)0x784480ea, (q31_t)0xd42f8002, + (q31_t)0x78425a2f, (q31_t)0xd42998bc, + (q31_t)0x78403329, (q31_t)0xd423b191, (q31_t)0x783e0bd9, (q31_t)0xd41dca81, (q31_t)0x783be43e, (q31_t)0xd417e38c, + (q31_t)0x7839bc5a, (q31_t)0xd411fcb2, + (q31_t)0x7837942b, (q31_t)0xd40c15f3, (q31_t)0x78356bb2, (q31_t)0xd4062f4f, (q31_t)0x783342ef, (q31_t)0xd40048c6, + (q31_t)0x783119e2, (q31_t)0xd3fa6259, + (q31_t)0x782ef08b, (q31_t)0xd3f47c06, (q31_t)0x782cc6ea, (q31_t)0xd3ee95cf, (q31_t)0x782a9cfe, (q31_t)0xd3e8afb3, + (q31_t)0x782872c8, (q31_t)0xd3e2c9b2, + (q31_t)0x78264849, (q31_t)0xd3dce3cd, (q31_t)0x78241d7f, (q31_t)0xd3d6fe03, (q31_t)0x7821f26b, (q31_t)0xd3d11853, + (q31_t)0x781fc70d, (q31_t)0xd3cb32c0, + (q31_t)0x781d9b65, (q31_t)0xd3c54d47, (q31_t)0x781b6f72, (q31_t)0xd3bf67ea, (q31_t)0x78194336, (q31_t)0xd3b982a8, + (q31_t)0x781716b0, (q31_t)0xd3b39d81, + (q31_t)0x7814e9df, (q31_t)0xd3adb876, (q31_t)0x7812bcc4, (q31_t)0xd3a7d385, (q31_t)0x78108f60, (q31_t)0xd3a1eeb1, + (q31_t)0x780e61b1, (q31_t)0xd39c09f7, + (q31_t)0x780c33b8, (q31_t)0xd396255a, (q31_t)0x780a0575, (q31_t)0xd39040d7, (q31_t)0x7807d6e9, (q31_t)0xd38a5c70, + (q31_t)0x7805a812, (q31_t)0xd3847824, + (q31_t)0x780378f1, (q31_t)0xd37e93f4, (q31_t)0x78014986, (q31_t)0xd378afdf, (q31_t)0x77ff19d1, (q31_t)0xd372cbe6, + (q31_t)0x77fce9d2, (q31_t)0xd36ce808, + (q31_t)0x77fab989, (q31_t)0xd3670446, (q31_t)0x77f888f6, (q31_t)0xd361209f, (q31_t)0x77f65819, (q31_t)0xd35b3d13, + (q31_t)0x77f426f2, (q31_t)0xd35559a4, + (q31_t)0x77f1f581, (q31_t)0xd34f764f, (q31_t)0x77efc3c5, (q31_t)0xd3499317, (q31_t)0x77ed91c0, (q31_t)0xd343affa, + (q31_t)0x77eb5f71, (q31_t)0xd33dccf8, + (q31_t)0x77e92cd9, (q31_t)0xd337ea12, (q31_t)0x77e6f9f6, (q31_t)0xd3320748, (q31_t)0x77e4c6c9, (q31_t)0xd32c2499, + (q31_t)0x77e29352, (q31_t)0xd3264206, + (q31_t)0x77e05f91, (q31_t)0xd3205f8f, (q31_t)0x77de2b86, (q31_t)0xd31a7d33, (q31_t)0x77dbf732, (q31_t)0xd3149af3, + (q31_t)0x77d9c293, (q31_t)0xd30eb8cf, + (q31_t)0x77d78daa, (q31_t)0xd308d6c7, (q31_t)0x77d55878, (q31_t)0xd302f4da, (q31_t)0x77d322fc, (q31_t)0xd2fd1309, + (q31_t)0x77d0ed35, (q31_t)0xd2f73154, + (q31_t)0x77ceb725, (q31_t)0xd2f14fba, (q31_t)0x77cc80cb, (q31_t)0xd2eb6e3c, (q31_t)0x77ca4a27, (q31_t)0xd2e58cdb, + (q31_t)0x77c81339, (q31_t)0xd2dfab95, + (q31_t)0x77c5dc01, (q31_t)0xd2d9ca6a, (q31_t)0x77c3a47f, (q31_t)0xd2d3e95c, (q31_t)0x77c16cb4, (q31_t)0xd2ce0869, + (q31_t)0x77bf349f, (q31_t)0xd2c82793, + (q31_t)0x77bcfc3f, (q31_t)0xd2c246d8, (q31_t)0x77bac396, (q31_t)0xd2bc6639, (q31_t)0x77b88aa3, (q31_t)0xd2b685b6, + (q31_t)0x77b65166, (q31_t)0xd2b0a54f, + (q31_t)0x77b417df, (q31_t)0xd2aac504, (q31_t)0x77b1de0f, (q31_t)0xd2a4e4d5, (q31_t)0x77afa3f5, (q31_t)0xd29f04c2, + (q31_t)0x77ad6990, (q31_t)0xd29924cb, + (q31_t)0x77ab2ee2, (q31_t)0xd29344f0, (q31_t)0x77a8f3ea, (q31_t)0xd28d6531, (q31_t)0x77a6b8a9, (q31_t)0xd287858e, + (q31_t)0x77a47d1d, (q31_t)0xd281a607, + (q31_t)0x77a24148, (q31_t)0xd27bc69c, (q31_t)0x77a00529, (q31_t)0xd275e74d, (q31_t)0x779dc8c0, (q31_t)0xd270081b, + (q31_t)0x779b8c0e, (q31_t)0xd26a2904, + (q31_t)0x77994f11, (q31_t)0xd2644a0a, (q31_t)0x779711cb, (q31_t)0xd25e6b2b, (q31_t)0x7794d43b, (q31_t)0xd2588c69, + (q31_t)0x77929661, (q31_t)0xd252adc3, + (q31_t)0x7790583e, (q31_t)0xd24ccf39, (q31_t)0x778e19d0, (q31_t)0xd246f0cb, (q31_t)0x778bdb19, (q31_t)0xd241127a, + (q31_t)0x77899c19, (q31_t)0xd23b3444, + (q31_t)0x77875cce, (q31_t)0xd235562b, (q31_t)0x77851d3a, (q31_t)0xd22f782f, (q31_t)0x7782dd5c, (q31_t)0xd2299a4e, + (q31_t)0x77809d35, (q31_t)0xd223bc8a, + (q31_t)0x777e5cc3, (q31_t)0xd21ddee2, (q31_t)0x777c1c08, (q31_t)0xd2180156, (q31_t)0x7779db03, (q31_t)0xd21223e7, + (q31_t)0x777799b5, (q31_t)0xd20c4694, + (q31_t)0x7775581d, (q31_t)0xd206695d, (q31_t)0x7773163b, (q31_t)0xd2008c43, (q31_t)0x7770d40f, (q31_t)0xd1faaf45, + (q31_t)0x776e919a, (q31_t)0xd1f4d263, + (q31_t)0x776c4edb, (q31_t)0xd1eef59e, (q31_t)0x776a0bd3, (q31_t)0xd1e918f5, (q31_t)0x7767c880, (q31_t)0xd1e33c69, + (q31_t)0x776584e5, (q31_t)0xd1dd5ff9, + (q31_t)0x776340ff, (q31_t)0xd1d783a6, (q31_t)0x7760fcd0, (q31_t)0xd1d1a76f, (q31_t)0x775eb857, (q31_t)0xd1cbcb54, + (q31_t)0x775c7395, (q31_t)0xd1c5ef56, + (q31_t)0x775a2e89, (q31_t)0xd1c01375, (q31_t)0x7757e933, (q31_t)0xd1ba37b0, (q31_t)0x7755a394, (q31_t)0xd1b45c08, + (q31_t)0x77535dab, (q31_t)0xd1ae807c, + (q31_t)0x77511778, (q31_t)0xd1a8a50d, (q31_t)0x774ed0fc, (q31_t)0xd1a2c9ba, (q31_t)0x774c8a36, (q31_t)0xd19cee84, + (q31_t)0x774a4327, (q31_t)0xd197136b, + (q31_t)0x7747fbce, (q31_t)0xd191386e, (q31_t)0x7745b42c, (q31_t)0xd18b5d8e, (q31_t)0x77436c40, (q31_t)0xd18582ca, + (q31_t)0x7741240a, (q31_t)0xd17fa823, + (q31_t)0x773edb8b, (q31_t)0xd179cd99, (q31_t)0x773c92c2, (q31_t)0xd173f32c, (q31_t)0x773a49b0, (q31_t)0xd16e18db, + (q31_t)0x77380054, (q31_t)0xd1683ea7, + (q31_t)0x7735b6af, (q31_t)0xd1626490, (q31_t)0x77336cc0, (q31_t)0xd15c8a95, (q31_t)0x77312287, (q31_t)0xd156b0b7, + (q31_t)0x772ed805, (q31_t)0xd150d6f6, + (q31_t)0x772c8d3a, (q31_t)0xd14afd52, (q31_t)0x772a4225, (q31_t)0xd14523cb, (q31_t)0x7727f6c6, (q31_t)0xd13f4a60, + (q31_t)0x7725ab1f, (q31_t)0xd1397113, + (q31_t)0x77235f2d, (q31_t)0xd13397e2, (q31_t)0x772112f2, (q31_t)0xd12dbece, (q31_t)0x771ec66e, (q31_t)0xd127e5d7, + (q31_t)0x771c79a0, (q31_t)0xd1220cfc, + (q31_t)0x771a2c88, (q31_t)0xd11c343f, (q31_t)0x7717df27, (q31_t)0xd1165b9f, (q31_t)0x7715917d, (q31_t)0xd110831b, + (q31_t)0x77134389, (q31_t)0xd10aaab5, + (q31_t)0x7710f54c, (q31_t)0xd104d26b, (q31_t)0x770ea6c5, (q31_t)0xd0fefa3f, (q31_t)0x770c57f5, (q31_t)0xd0f9222f, + (q31_t)0x770a08dc, (q31_t)0xd0f34a3d, + (q31_t)0x7707b979, (q31_t)0xd0ed7267, (q31_t)0x770569cc, (q31_t)0xd0e79aaf, (q31_t)0x770319d6, (q31_t)0xd0e1c313, + (q31_t)0x7700c997, (q31_t)0xd0dbeb95, + (q31_t)0x76fe790e, (q31_t)0xd0d61434, (q31_t)0x76fc283c, (q31_t)0xd0d03cf0, (q31_t)0x76f9d721, (q31_t)0xd0ca65c9, + (q31_t)0x76f785bc, (q31_t)0xd0c48ebf, + (q31_t)0x76f5340e, (q31_t)0xd0beb7d2, (q31_t)0x76f2e216, (q31_t)0xd0b8e102, (q31_t)0x76f08fd5, (q31_t)0xd0b30a50, + (q31_t)0x76ee3d4b, (q31_t)0xd0ad33ba, + (q31_t)0x76ebea77, (q31_t)0xd0a75d42, (q31_t)0x76e9975a, (q31_t)0xd0a186e7, (q31_t)0x76e743f4, (q31_t)0xd09bb0aa, + (q31_t)0x76e4f044, (q31_t)0xd095da89, + (q31_t)0x76e29c4b, (q31_t)0xd0900486, (q31_t)0x76e04808, (q31_t)0xd08a2ea0, (q31_t)0x76ddf37c, (q31_t)0xd08458d7, + (q31_t)0x76db9ea7, (q31_t)0xd07e832c, + (q31_t)0x76d94989, (q31_t)0xd078ad9e, (q31_t)0x76d6f421, (q31_t)0xd072d82d, (q31_t)0x76d49e70, (q31_t)0xd06d02da, + (q31_t)0x76d24876, (q31_t)0xd0672da3, + (q31_t)0x76cff232, (q31_t)0xd061588b, (q31_t)0x76cd9ba5, (q31_t)0xd05b838f, (q31_t)0x76cb44cf, (q31_t)0xd055aeb1, + (q31_t)0x76c8edb0, (q31_t)0xd04fd9f1, + (q31_t)0x76c69647, (q31_t)0xd04a054e, (q31_t)0x76c43e95, (q31_t)0xd04430c8, (q31_t)0x76c1e699, (q31_t)0xd03e5c60, + (q31_t)0x76bf8e55, (q31_t)0xd0388815, + (q31_t)0x76bd35c7, (q31_t)0xd032b3e7, (q31_t)0x76badcf0, (q31_t)0xd02cdfd8, (q31_t)0x76b883d0, (q31_t)0xd0270be5, + (q31_t)0x76b62a66, (q31_t)0xd0213810, + (q31_t)0x76b3d0b4, (q31_t)0xd01b6459, (q31_t)0x76b176b8, (q31_t)0xd01590bf, (q31_t)0x76af1c72, (q31_t)0xd00fbd43, + (q31_t)0x76acc1e4, (q31_t)0xd009e9e4, + (q31_t)0x76aa670d, (q31_t)0xd00416a3, (q31_t)0x76a80bec, (q31_t)0xcffe4380, (q31_t)0x76a5b082, (q31_t)0xcff8707a, + (q31_t)0x76a354cf, (q31_t)0xcff29d92, + (q31_t)0x76a0f8d2, (q31_t)0xcfeccac7, (q31_t)0x769e9c8d, (q31_t)0xcfe6f81a, (q31_t)0x769c3ffe, (q31_t)0xcfe1258b, + (q31_t)0x7699e326, (q31_t)0xcfdb531a, + (q31_t)0x76978605, (q31_t)0xcfd580c6, (q31_t)0x7695289b, (q31_t)0xcfcfae8f, (q31_t)0x7692cae8, (q31_t)0xcfc9dc77, + (q31_t)0x76906ceb, (q31_t)0xcfc40a7c, + (q31_t)0x768e0ea6, (q31_t)0xcfbe389f, (q31_t)0x768bb017, (q31_t)0xcfb866e0, (q31_t)0x7689513f, (q31_t)0xcfb2953f, + (q31_t)0x7686f21e, (q31_t)0xcfacc3bb, + (q31_t)0x768492b4, (q31_t)0xcfa6f255, (q31_t)0x76823301, (q31_t)0xcfa1210d, (q31_t)0x767fd304, (q31_t)0xcf9b4fe3, + (q31_t)0x767d72bf, (q31_t)0xcf957ed7, + (q31_t)0x767b1231, (q31_t)0xcf8fade9, (q31_t)0x7678b159, (q31_t)0xcf89dd18, (q31_t)0x76765038, (q31_t)0xcf840c65, + (q31_t)0x7673eecf, (q31_t)0xcf7e3bd1, + (q31_t)0x76718d1c, (q31_t)0xcf786b5a, (q31_t)0x766f2b20, (q31_t)0xcf729b01, (q31_t)0x766cc8db, (q31_t)0xcf6ccac6, + (q31_t)0x766a664d, (q31_t)0xcf66faa9, + (q31_t)0x76680376, (q31_t)0xcf612aaa, (q31_t)0x7665a056, (q31_t)0xcf5b5ac9, (q31_t)0x76633ced, (q31_t)0xcf558b06, + (q31_t)0x7660d93b, (q31_t)0xcf4fbb61, + (q31_t)0x765e7540, (q31_t)0xcf49ebda, (q31_t)0x765c10fc, (q31_t)0xcf441c71, (q31_t)0x7659ac6f, (q31_t)0xcf3e4d26, + (q31_t)0x76574798, (q31_t)0xcf387dfa, + (q31_t)0x7654e279, (q31_t)0xcf32aeeb, (q31_t)0x76527d11, (q31_t)0xcf2cdffa, (q31_t)0x76501760, (q31_t)0xcf271128, + (q31_t)0x764db166, (q31_t)0xcf214274, + (q31_t)0x764b4b23, (q31_t)0xcf1b73de, (q31_t)0x7648e497, (q31_t)0xcf15a566, (q31_t)0x76467dc2, (q31_t)0xcf0fd70c, + (q31_t)0x764416a4, (q31_t)0xcf0a08d0, + (q31_t)0x7641af3d, (q31_t)0xcf043ab3, (q31_t)0x763f478d, (q31_t)0xcefe6cb3, (q31_t)0x763cdf94, (q31_t)0xcef89ed2, + (q31_t)0x763a7752, (q31_t)0xcef2d110, + (q31_t)0x76380ec8, (q31_t)0xceed036b, (q31_t)0x7635a5f4, (q31_t)0xcee735e5, (q31_t)0x76333cd8, (q31_t)0xcee1687d, + (q31_t)0x7630d372, (q31_t)0xcedb9b33, + (q31_t)0x762e69c4, (q31_t)0xced5ce08, (q31_t)0x762bffcd, (q31_t)0xced000fb, (q31_t)0x7629958c, (q31_t)0xceca340c, + (q31_t)0x76272b03, (q31_t)0xcec4673c, + (q31_t)0x7624c031, (q31_t)0xcebe9a8a, (q31_t)0x76225517, (q31_t)0xceb8cdf7, (q31_t)0x761fe9b3, (q31_t)0xceb30181, + (q31_t)0x761d7e06, (q31_t)0xcead352b, + (q31_t)0x761b1211, (q31_t)0xcea768f2, (q31_t)0x7618a5d3, (q31_t)0xcea19cd8, (q31_t)0x7616394c, (q31_t)0xce9bd0dd, + (q31_t)0x7613cc7c, (q31_t)0xce960500, + (q31_t)0x76115f63, (q31_t)0xce903942, (q31_t)0x760ef201, (q31_t)0xce8a6da2, (q31_t)0x760c8457, (q31_t)0xce84a220, + (q31_t)0x760a1664, (q31_t)0xce7ed6bd, + (q31_t)0x7607a828, (q31_t)0xce790b79, (q31_t)0x760539a3, (q31_t)0xce734053, (q31_t)0x7602cad5, (q31_t)0xce6d754c, + (q31_t)0x76005bbf, (q31_t)0xce67aa63, + (q31_t)0x75fdec60, (q31_t)0xce61df99, (q31_t)0x75fb7cb8, (q31_t)0xce5c14ed, (q31_t)0x75f90cc7, (q31_t)0xce564a60, + (q31_t)0x75f69c8d, (q31_t)0xce507ff2, + (q31_t)0x75f42c0b, (q31_t)0xce4ab5a2, (q31_t)0x75f1bb40, (q31_t)0xce44eb71, (q31_t)0x75ef4a2c, (q31_t)0xce3f215f, + (q31_t)0x75ecd8cf, (q31_t)0xce39576c, + (q31_t)0x75ea672a, (q31_t)0xce338d97, (q31_t)0x75e7f53c, (q31_t)0xce2dc3e1, (q31_t)0x75e58305, (q31_t)0xce27fa49, + (q31_t)0x75e31086, (q31_t)0xce2230d0, + (q31_t)0x75e09dbd, (q31_t)0xce1c6777, (q31_t)0x75de2aac, (q31_t)0xce169e3b, (q31_t)0x75dbb753, (q31_t)0xce10d51f, + (q31_t)0x75d943b0, (q31_t)0xce0b0c21, + (q31_t)0x75d6cfc5, (q31_t)0xce054343, (q31_t)0x75d45b92, (q31_t)0xcdff7a83, (q31_t)0x75d1e715, (q31_t)0xcdf9b1e2, + (q31_t)0x75cf7250, (q31_t)0xcdf3e95f, + (q31_t)0x75ccfd42, (q31_t)0xcdee20fc, (q31_t)0x75ca87ec, (q31_t)0xcde858b8, (q31_t)0x75c8124d, (q31_t)0xcde29092, + (q31_t)0x75c59c65, (q31_t)0xcddcc88b, + (q31_t)0x75c32634, (q31_t)0xcdd700a4, (q31_t)0x75c0afbb, (q31_t)0xcdd138db, (q31_t)0x75be38fa, (q31_t)0xcdcb7131, + (q31_t)0x75bbc1ef, (q31_t)0xcdc5a9a6, + (q31_t)0x75b94a9c, (q31_t)0xcdbfe23a, (q31_t)0x75b6d301, (q31_t)0xcdba1aee, (q31_t)0x75b45b1d, (q31_t)0xcdb453c0, + (q31_t)0x75b1e2f0, (q31_t)0xcdae8cb1, + (q31_t)0x75af6a7b, (q31_t)0xcda8c5c1, (q31_t)0x75acf1bd, (q31_t)0xcda2fef0, (q31_t)0x75aa78b6, (q31_t)0xcd9d383f, + (q31_t)0x75a7ff67, (q31_t)0xcd9771ac, + (q31_t)0x75a585cf, (q31_t)0xcd91ab39, (q31_t)0x75a30bef, (q31_t)0xcd8be4e4, (q31_t)0x75a091c6, (q31_t)0xcd861eaf, + (q31_t)0x759e1755, (q31_t)0xcd805899, + (q31_t)0x759b9c9b, (q31_t)0xcd7a92a2, (q31_t)0x75992198, (q31_t)0xcd74ccca, (q31_t)0x7596a64d, (q31_t)0xcd6f0711, + (q31_t)0x75942ab9, (q31_t)0xcd694178, + (q31_t)0x7591aedd, (q31_t)0xcd637bfe, (q31_t)0x758f32b9, (q31_t)0xcd5db6a3, (q31_t)0x758cb64c, (q31_t)0xcd57f167, + (q31_t)0x758a3996, (q31_t)0xcd522c4a, + (q31_t)0x7587bc98, (q31_t)0xcd4c674d, (q31_t)0x75853f51, (q31_t)0xcd46a26f, (q31_t)0x7582c1c2, (q31_t)0xcd40ddb0, + (q31_t)0x758043ea, (q31_t)0xcd3b1911, + (q31_t)0x757dc5ca, (q31_t)0xcd355491, (q31_t)0x757b4762, (q31_t)0xcd2f9030, (q31_t)0x7578c8b0, (q31_t)0xcd29cbee, + (q31_t)0x757649b7, (q31_t)0xcd2407cc, + (q31_t)0x7573ca75, (q31_t)0xcd1e43ca, (q31_t)0x75714aea, (q31_t)0xcd187fe6, (q31_t)0x756ecb18, (q31_t)0xcd12bc22, + (q31_t)0x756c4afc, (q31_t)0xcd0cf87e, + (q31_t)0x7569ca99, (q31_t)0xcd0734f9, (q31_t)0x756749ec, (q31_t)0xcd017193, (q31_t)0x7564c8f8, (q31_t)0xccfbae4d, + (q31_t)0x756247bb, (q31_t)0xccf5eb26, + (q31_t)0x755fc635, (q31_t)0xccf0281f, (q31_t)0x755d4467, (q31_t)0xccea6538, (q31_t)0x755ac251, (q31_t)0xcce4a26f, + (q31_t)0x75583ff3, (q31_t)0xccdedfc7, + (q31_t)0x7555bd4c, (q31_t)0xccd91d3d, (q31_t)0x75533a5c, (q31_t)0xccd35ad4, (q31_t)0x7550b725, (q31_t)0xcccd988a, + (q31_t)0x754e33a4, (q31_t)0xccc7d65f, + (q31_t)0x754bafdc, (q31_t)0xccc21455, (q31_t)0x75492bcb, (q31_t)0xccbc5269, (q31_t)0x7546a772, (q31_t)0xccb6909e, + (q31_t)0x754422d0, (q31_t)0xccb0cef2, + (q31_t)0x75419de7, (q31_t)0xccab0d65, (q31_t)0x753f18b4, (q31_t)0xcca54bf9, (q31_t)0x753c933a, (q31_t)0xcc9f8aac, + (q31_t)0x753a0d77, (q31_t)0xcc99c97e, + (q31_t)0x7537876c, (q31_t)0xcc940871, (q31_t)0x75350118, (q31_t)0xcc8e4783, (q31_t)0x75327a7d, (q31_t)0xcc8886b5, + (q31_t)0x752ff399, (q31_t)0xcc82c607, + (q31_t)0x752d6c6c, (q31_t)0xcc7d0578, (q31_t)0x752ae4f8, (q31_t)0xcc774509, (q31_t)0x75285d3b, (q31_t)0xcc7184ba, + (q31_t)0x7525d536, (q31_t)0xcc6bc48b, + (q31_t)0x75234ce8, (q31_t)0xcc66047b, (q31_t)0x7520c453, (q31_t)0xcc60448c, (q31_t)0x751e3b75, (q31_t)0xcc5a84bc, + (q31_t)0x751bb24f, (q31_t)0xcc54c50c, + (q31_t)0x751928e0, (q31_t)0xcc4f057c, (q31_t)0x75169f2a, (q31_t)0xcc49460c, (q31_t)0x7514152b, (q31_t)0xcc4386bc, + (q31_t)0x75118ae4, (q31_t)0xcc3dc78b, + (q31_t)0x750f0054, (q31_t)0xcc38087b, (q31_t)0x750c757d, (q31_t)0xcc32498a, (q31_t)0x7509ea5d, (q31_t)0xcc2c8aba, + (q31_t)0x75075ef5, (q31_t)0xcc26cc09, + (q31_t)0x7504d345, (q31_t)0xcc210d79, (q31_t)0x7502474d, (q31_t)0xcc1b4f08, (q31_t)0x74ffbb0d, (q31_t)0xcc1590b8, + (q31_t)0x74fd2e84, (q31_t)0xcc0fd287, + (q31_t)0x74faa1b3, (q31_t)0xcc0a1477, (q31_t)0x74f8149a, (q31_t)0xcc045686, (q31_t)0x74f58739, (q31_t)0xcbfe98b6, + (q31_t)0x74f2f990, (q31_t)0xcbf8db05, + (q31_t)0x74f06b9e, (q31_t)0xcbf31d75, (q31_t)0x74eddd65, (q31_t)0xcbed6005, (q31_t)0x74eb4ee3, (q31_t)0xcbe7a2b5, + (q31_t)0x74e8c01a, (q31_t)0xcbe1e585, + (q31_t)0x74e63108, (q31_t)0xcbdc2876, (q31_t)0x74e3a1ae, (q31_t)0xcbd66b86, (q31_t)0x74e1120c, (q31_t)0xcbd0aeb7, + (q31_t)0x74de8221, (q31_t)0xcbcaf208, + (q31_t)0x74dbf1ef, (q31_t)0xcbc53579, (q31_t)0x74d96175, (q31_t)0xcbbf790a, (q31_t)0x74d6d0b2, (q31_t)0xcbb9bcbb, + (q31_t)0x74d43fa8, (q31_t)0xcbb4008d, + (q31_t)0x74d1ae55, (q31_t)0xcbae447f, (q31_t)0x74cf1cbb, (q31_t)0xcba88891, (q31_t)0x74cc8ad8, (q31_t)0xcba2ccc4, + (q31_t)0x74c9f8ad, (q31_t)0xcb9d1117, + (q31_t)0x74c7663a, (q31_t)0xcb97558a, (q31_t)0x74c4d380, (q31_t)0xcb919a1d, (q31_t)0x74c2407d, (q31_t)0xcb8bded1, + (q31_t)0x74bfad32, (q31_t)0xcb8623a5, + (q31_t)0x74bd199f, (q31_t)0xcb80689a, (q31_t)0x74ba85c4, (q31_t)0xcb7aadaf, (q31_t)0x74b7f1a1, (q31_t)0xcb74f2e4, + (q31_t)0x74b55d36, (q31_t)0xcb6f383a, + (q31_t)0x74b2c884, (q31_t)0xcb697db0, (q31_t)0x74b03389, (q31_t)0xcb63c347, (q31_t)0x74ad9e46, (q31_t)0xcb5e08fe, + (q31_t)0x74ab08bb, (q31_t)0xcb584ed6, + (q31_t)0x74a872e8, (q31_t)0xcb5294ce, (q31_t)0x74a5dccd, (q31_t)0xcb4cdae6, (q31_t)0x74a3466b, (q31_t)0xcb47211f, + (q31_t)0x74a0afc0, (q31_t)0xcb416779, + (q31_t)0x749e18cd, (q31_t)0xcb3badf3, (q31_t)0x749b8193, (q31_t)0xcb35f48d, (q31_t)0x7498ea11, (q31_t)0xcb303b49, + (q31_t)0x74965246, (q31_t)0xcb2a8224, + (q31_t)0x7493ba34, (q31_t)0xcb24c921, (q31_t)0x749121da, (q31_t)0xcb1f103e, (q31_t)0x748e8938, (q31_t)0xcb19577b, + (q31_t)0x748bf04d, (q31_t)0xcb139ed9, + (q31_t)0x7489571c, (q31_t)0xcb0de658, (q31_t)0x7486bda2, (q31_t)0xcb082df8, (q31_t)0x748423e0, (q31_t)0xcb0275b8, + (q31_t)0x748189d7, (q31_t)0xcafcbd99, + (q31_t)0x747eef85, (q31_t)0xcaf7059a, (q31_t)0x747c54ec, (q31_t)0xcaf14dbd, (q31_t)0x7479ba0b, (q31_t)0xcaeb9600, + (q31_t)0x74771ee2, (q31_t)0xcae5de64, + (q31_t)0x74748371, (q31_t)0xcae026e8, (q31_t)0x7471e7b8, (q31_t)0xcada6f8d, (q31_t)0x746f4bb8, (q31_t)0xcad4b853, + (q31_t)0x746caf70, (q31_t)0xcacf013a, + (q31_t)0x746a12df, (q31_t)0xcac94a42, (q31_t)0x74677608, (q31_t)0xcac3936b, (q31_t)0x7464d8e8, (q31_t)0xcabddcb4, + (q31_t)0x74623b80, (q31_t)0xcab8261e, + (q31_t)0x745f9dd1, (q31_t)0xcab26fa9, (q31_t)0x745cffda, (q31_t)0xcaacb955, (q31_t)0x745a619b, (q31_t)0xcaa70322, + (q31_t)0x7457c314, (q31_t)0xcaa14d10, + (q31_t)0x74552446, (q31_t)0xca9b971e, (q31_t)0x74528530, (q31_t)0xca95e14e, (q31_t)0x744fe5d2, (q31_t)0xca902b9f, + (q31_t)0x744d462c, (q31_t)0xca8a7610, + (q31_t)0x744aa63f, (q31_t)0xca84c0a3, (q31_t)0x7448060a, (q31_t)0xca7f0b56, (q31_t)0x7445658d, (q31_t)0xca79562b, + (q31_t)0x7442c4c8, (q31_t)0xca73a120, + (q31_t)0x744023bc, (q31_t)0xca6dec37, (q31_t)0x743d8268, (q31_t)0xca68376e, (q31_t)0x743ae0cc, (q31_t)0xca6282c7, + (q31_t)0x74383ee9, (q31_t)0xca5cce40, + (q31_t)0x74359cbd, (q31_t)0xca5719db, (q31_t)0x7432fa4b, (q31_t)0xca516597, (q31_t)0x74305790, (q31_t)0xca4bb174, + (q31_t)0x742db48e, (q31_t)0xca45fd72, + (q31_t)0x742b1144, (q31_t)0xca404992, (q31_t)0x74286db3, (q31_t)0xca3a95d2, (q31_t)0x7425c9da, (q31_t)0xca34e234, + (q31_t)0x742325b9, (q31_t)0xca2f2eb6, + (q31_t)0x74208150, (q31_t)0xca297b5a, (q31_t)0x741ddca0, (q31_t)0xca23c820, (q31_t)0x741b37a9, (q31_t)0xca1e1506, + (q31_t)0x74189269, (q31_t)0xca18620e, + (q31_t)0x7415ece2, (q31_t)0xca12af37, (q31_t)0x74134714, (q31_t)0xca0cfc81, (q31_t)0x7410a0fe, (q31_t)0xca0749ec, + (q31_t)0x740dfaa0, (q31_t)0xca019779, + (q31_t)0x740b53fb, (q31_t)0xc9fbe527, (q31_t)0x7408ad0e, (q31_t)0xc9f632f6, (q31_t)0x740605d9, (q31_t)0xc9f080e7, + (q31_t)0x74035e5d, (q31_t)0xc9eacef9, + (q31_t)0x7400b69a, (q31_t)0xc9e51d2d, (q31_t)0x73fe0e8f, (q31_t)0xc9df6b81, (q31_t)0x73fb663c, (q31_t)0xc9d9b9f7, + (q31_t)0x73f8bda2, (q31_t)0xc9d4088f, + (q31_t)0x73f614c0, (q31_t)0xc9ce5748, (q31_t)0x73f36b97, (q31_t)0xc9c8a622, (q31_t)0x73f0c226, (q31_t)0xc9c2f51e, + (q31_t)0x73ee186e, (q31_t)0xc9bd443c, + (q31_t)0x73eb6e6e, (q31_t)0xc9b7937a, (q31_t)0x73e8c426, (q31_t)0xc9b1e2db, (q31_t)0x73e61997, (q31_t)0xc9ac325d, + (q31_t)0x73e36ec1, (q31_t)0xc9a68200, + (q31_t)0x73e0c3a3, (q31_t)0xc9a0d1c5, (q31_t)0x73de183e, (q31_t)0xc99b21ab, (q31_t)0x73db6c91, (q31_t)0xc99571b3, + (q31_t)0x73d8c09d, (q31_t)0xc98fc1dc, + (q31_t)0x73d61461, (q31_t)0xc98a1227, (q31_t)0x73d367de, (q31_t)0xc9846294, (q31_t)0x73d0bb13, (q31_t)0xc97eb322, + (q31_t)0x73ce0e01, (q31_t)0xc97903d2, + (q31_t)0x73cb60a8, (q31_t)0xc97354a4, (q31_t)0x73c8b307, (q31_t)0xc96da597, (q31_t)0x73c6051f, (q31_t)0xc967f6ac, + (q31_t)0x73c356ef, (q31_t)0xc96247e2, + (q31_t)0x73c0a878, (q31_t)0xc95c993a, (q31_t)0x73bdf9b9, (q31_t)0xc956eab4, (q31_t)0x73bb4ab3, (q31_t)0xc9513c50, + (q31_t)0x73b89b66, (q31_t)0xc94b8e0d, + (q31_t)0x73b5ebd1, (q31_t)0xc945dfec, (q31_t)0x73b33bf5, (q31_t)0xc94031ed, (q31_t)0x73b08bd1, (q31_t)0xc93a8410, + (q31_t)0x73addb67, (q31_t)0xc934d654, + (q31_t)0x73ab2ab4, (q31_t)0xc92f28ba, (q31_t)0x73a879bb, (q31_t)0xc9297b42, (q31_t)0x73a5c87a, (q31_t)0xc923cdec, + (q31_t)0x73a316f2, (q31_t)0xc91e20b8, + (q31_t)0x73a06522, (q31_t)0xc91873a5, (q31_t)0x739db30b, (q31_t)0xc912c6b5, (q31_t)0x739b00ad, (q31_t)0xc90d19e6, + (q31_t)0x73984e07, (q31_t)0xc9076d39, + (q31_t)0x73959b1b, (q31_t)0xc901c0ae, (q31_t)0x7392e7e6, (q31_t)0xc8fc1445, (q31_t)0x7390346b, (q31_t)0xc8f667fe, + (q31_t)0x738d80a8, (q31_t)0xc8f0bbd9, + (q31_t)0x738acc9e, (q31_t)0xc8eb0fd6, (q31_t)0x7388184d, (q31_t)0xc8e563f5, (q31_t)0x738563b5, (q31_t)0xc8dfb836, + (q31_t)0x7382aed5, (q31_t)0xc8da0c99, + (q31_t)0x737ff9ae, (q31_t)0xc8d4611d, (q31_t)0x737d4440, (q31_t)0xc8ceb5c4, (q31_t)0x737a8e8a, (q31_t)0xc8c90a8d, + (q31_t)0x7377d88d, (q31_t)0xc8c35f78, + (q31_t)0x73752249, (q31_t)0xc8bdb485, (q31_t)0x73726bbe, (q31_t)0xc8b809b4, (q31_t)0x736fb4ec, (q31_t)0xc8b25f06, + (q31_t)0x736cfdd2, (q31_t)0xc8acb479, + (q31_t)0x736a4671, (q31_t)0xc8a70a0e, (q31_t)0x73678ec9, (q31_t)0xc8a15fc6, (q31_t)0x7364d6da, (q31_t)0xc89bb5a0, + (q31_t)0x73621ea4, (q31_t)0xc8960b9c, + (q31_t)0x735f6626, (q31_t)0xc89061ba, (q31_t)0x735cad61, (q31_t)0xc88ab7fa, (q31_t)0x7359f456, (q31_t)0xc8850e5d, + (q31_t)0x73573b03, (q31_t)0xc87f64e2, + (q31_t)0x73548168, (q31_t)0xc879bb89, (q31_t)0x7351c787, (q31_t)0xc8741252, (q31_t)0x734f0d5f, (q31_t)0xc86e693d, + (q31_t)0x734c52ef, (q31_t)0xc868c04b, + (q31_t)0x73499838, (q31_t)0xc863177b, (q31_t)0x7346dd3a, (q31_t)0xc85d6ece, (q31_t)0x734421f6, (q31_t)0xc857c642, + (q31_t)0x7341666a, (q31_t)0xc8521dd9, + (q31_t)0x733eaa96, (q31_t)0xc84c7593, (q31_t)0x733bee7c, (q31_t)0xc846cd6e, (q31_t)0x7339321b, (q31_t)0xc841256d, + (q31_t)0x73367572, (q31_t)0xc83b7d8d, + (q31_t)0x7333b883, (q31_t)0xc835d5d0, (q31_t)0x7330fb4d, (q31_t)0xc8302e35, (q31_t)0x732e3dcf, (q31_t)0xc82a86bd, + (q31_t)0x732b800a, (q31_t)0xc824df67, + (q31_t)0x7328c1ff, (q31_t)0xc81f3834, (q31_t)0x732603ac, (q31_t)0xc8199123, (q31_t)0x73234512, (q31_t)0xc813ea35, + (q31_t)0x73208632, (q31_t)0xc80e4369, + (q31_t)0x731dc70a, (q31_t)0xc8089cbf, (q31_t)0x731b079b, (q31_t)0xc802f638, (q31_t)0x731847e5, (q31_t)0xc7fd4fd4, + (q31_t)0x731587e8, (q31_t)0xc7f7a992, + (q31_t)0x7312c7a5, (q31_t)0xc7f20373, (q31_t)0x7310071a, (q31_t)0xc7ec5d76, (q31_t)0x730d4648, (q31_t)0xc7e6b79c, + (q31_t)0x730a8530, (q31_t)0xc7e111e5, + (q31_t)0x7307c3d0, (q31_t)0xc7db6c50, (q31_t)0x73050229, (q31_t)0xc7d5c6de, (q31_t)0x7302403c, (q31_t)0xc7d0218e, + (q31_t)0x72ff7e07, (q31_t)0xc7ca7c61, + (q31_t)0x72fcbb8c, (q31_t)0xc7c4d757, (q31_t)0x72f9f8c9, (q31_t)0xc7bf3270, (q31_t)0x72f735c0, (q31_t)0xc7b98dab, + (q31_t)0x72f47270, (q31_t)0xc7b3e909, + (q31_t)0x72f1aed9, (q31_t)0xc7ae4489, (q31_t)0x72eeeafb, (q31_t)0xc7a8a02c, (q31_t)0x72ec26d6, (q31_t)0xc7a2fbf3, + (q31_t)0x72e9626a, (q31_t)0xc79d57db, + (q31_t)0x72e69db7, (q31_t)0xc797b3e7, (q31_t)0x72e3d8be, (q31_t)0xc7921015, (q31_t)0x72e1137d, (q31_t)0xc78c6c67, + (q31_t)0x72de4df6, (q31_t)0xc786c8db, + (q31_t)0x72db8828, (q31_t)0xc7812572, (q31_t)0x72d8c213, (q31_t)0xc77b822b, (q31_t)0x72d5fbb7, (q31_t)0xc775df08, + (q31_t)0x72d33514, (q31_t)0xc7703c08, + (q31_t)0x72d06e2b, (q31_t)0xc76a992a, (q31_t)0x72cda6fb, (q31_t)0xc764f66f, (q31_t)0x72cadf83, (q31_t)0xc75f53d7, + (q31_t)0x72c817c6, (q31_t)0xc759b163, + (q31_t)0x72c54fc1, (q31_t)0xc7540f11, (q31_t)0x72c28775, (q31_t)0xc74e6ce2, (q31_t)0x72bfbee3, (q31_t)0xc748cad6, + (q31_t)0x72bcf60a, (q31_t)0xc74328ed, + (q31_t)0x72ba2cea, (q31_t)0xc73d8727, (q31_t)0x72b76383, (q31_t)0xc737e584, (q31_t)0x72b499d6, (q31_t)0xc7324404, + (q31_t)0x72b1cfe1, (q31_t)0xc72ca2a7, + (q31_t)0x72af05a7, (q31_t)0xc727016d, (q31_t)0x72ac3b25, (q31_t)0xc7216056, (q31_t)0x72a9705c, (q31_t)0xc71bbf62, + (q31_t)0x72a6a54d, (q31_t)0xc7161e92, + (q31_t)0x72a3d9f7, (q31_t)0xc7107de4, (q31_t)0x72a10e5b, (q31_t)0xc70add5a, (q31_t)0x729e4277, (q31_t)0xc7053cf2, + (q31_t)0x729b764d, (q31_t)0xc6ff9cae, + (q31_t)0x7298a9dd, (q31_t)0xc6f9fc8d, (q31_t)0x7295dd25, (q31_t)0xc6f45c8f, (q31_t)0x72931027, (q31_t)0xc6eebcb5, + (q31_t)0x729042e3, (q31_t)0xc6e91cfd, + (q31_t)0x728d7557, (q31_t)0xc6e37d69, (q31_t)0x728aa785, (q31_t)0xc6ddddf8, (q31_t)0x7287d96c, (q31_t)0xc6d83eab, + (q31_t)0x72850b0d, (q31_t)0xc6d29f80, + (q31_t)0x72823c67, (q31_t)0xc6cd0079, (q31_t)0x727f6d7a, (q31_t)0xc6c76195, (q31_t)0x727c9e47, (q31_t)0xc6c1c2d4, + (q31_t)0x7279cecd, (q31_t)0xc6bc2437, + (q31_t)0x7276ff0d, (q31_t)0xc6b685bd, (q31_t)0x72742f05, (q31_t)0xc6b0e767, (q31_t)0x72715eb8, (q31_t)0xc6ab4933, + (q31_t)0x726e8e23, (q31_t)0xc6a5ab23, + (q31_t)0x726bbd48, (q31_t)0xc6a00d37, (q31_t)0x7268ec27, (q31_t)0xc69a6f6e, (q31_t)0x72661abf, (q31_t)0xc694d1c8, + (q31_t)0x72634910, (q31_t)0xc68f3446, + (q31_t)0x7260771b, (q31_t)0xc68996e7, (q31_t)0x725da4df, (q31_t)0xc683f9ab, (q31_t)0x725ad25d, (q31_t)0xc67e5c93, + (q31_t)0x7257ff94, (q31_t)0xc678bf9f, + (q31_t)0x72552c85, (q31_t)0xc67322ce, (q31_t)0x7252592f, (q31_t)0xc66d8620, (q31_t)0x724f8593, (q31_t)0xc667e996, + (q31_t)0x724cb1b0, (q31_t)0xc6624d30, + (q31_t)0x7249dd86, (q31_t)0xc65cb0ed, (q31_t)0x72470916, (q31_t)0xc65714cd, (q31_t)0x72443460, (q31_t)0xc65178d1, + (q31_t)0x72415f63, (q31_t)0xc64bdcf9, + (q31_t)0x723e8a20, (q31_t)0xc6464144, (q31_t)0x723bb496, (q31_t)0xc640a5b3, (q31_t)0x7238dec5, (q31_t)0xc63b0a46, + (q31_t)0x723608af, (q31_t)0xc6356efc, + (q31_t)0x72333251, (q31_t)0xc62fd3d6, (q31_t)0x72305bae, (q31_t)0xc62a38d4, (q31_t)0x722d84c4, (q31_t)0xc6249df5, + (q31_t)0x722aad93, (q31_t)0xc61f033a, + (q31_t)0x7227d61c, (q31_t)0xc61968a2, (q31_t)0x7224fe5f, (q31_t)0xc613ce2f, (q31_t)0x7222265b, (q31_t)0xc60e33df, + (q31_t)0x721f4e11, (q31_t)0xc60899b2, + (q31_t)0x721c7580, (q31_t)0xc602ffaa, (q31_t)0x72199ca9, (q31_t)0xc5fd65c5, (q31_t)0x7216c38c, (q31_t)0xc5f7cc04, + (q31_t)0x7213ea28, (q31_t)0xc5f23267, + (q31_t)0x7211107e, (q31_t)0xc5ec98ee, (q31_t)0x720e368d, (q31_t)0xc5e6ff98, (q31_t)0x720b5c57, (q31_t)0xc5e16667, + (q31_t)0x720881d9, (q31_t)0xc5dbcd59, + (q31_t)0x7205a716, (q31_t)0xc5d6346f, (q31_t)0x7202cc0c, (q31_t)0xc5d09ba9, (q31_t)0x71fff0bc, (q31_t)0xc5cb0307, + (q31_t)0x71fd1525, (q31_t)0xc5c56a89, + (q31_t)0x71fa3949, (q31_t)0xc5bfd22e, (q31_t)0x71f75d25, (q31_t)0xc5ba39f8, (q31_t)0x71f480bc, (q31_t)0xc5b4a1e5, + (q31_t)0x71f1a40c, (q31_t)0xc5af09f7, + (q31_t)0x71eec716, (q31_t)0xc5a9722c, (q31_t)0x71ebe9da, (q31_t)0xc5a3da86, (q31_t)0x71e90c57, (q31_t)0xc59e4303, + (q31_t)0x71e62e8f, (q31_t)0xc598aba5, + (q31_t)0x71e35080, (q31_t)0xc593146a, (q31_t)0x71e0722a, (q31_t)0xc58d7d54, (q31_t)0x71dd938f, (q31_t)0xc587e661, + (q31_t)0x71dab4ad, (q31_t)0xc5824f93, + (q31_t)0x71d7d585, (q31_t)0xc57cb8e9, (q31_t)0x71d4f617, (q31_t)0xc5772263, (q31_t)0x71d21662, (q31_t)0xc5718c00, + (q31_t)0x71cf3667, (q31_t)0xc56bf5c2, + (q31_t)0x71cc5626, (q31_t)0xc5665fa9, (q31_t)0x71c9759f, (q31_t)0xc560c9b3, (q31_t)0x71c694d2, (q31_t)0xc55b33e2, + (q31_t)0x71c3b3bf, (q31_t)0xc5559e34, + (q31_t)0x71c0d265, (q31_t)0xc55008ab, (q31_t)0x71bdf0c5, (q31_t)0xc54a7346, (q31_t)0x71bb0edf, (q31_t)0xc544de05, + (q31_t)0x71b82cb3, (q31_t)0xc53f48e9, + (q31_t)0x71b54a41, (q31_t)0xc539b3f1, (q31_t)0x71b26788, (q31_t)0xc5341f1d, (q31_t)0x71af848a, (q31_t)0xc52e8a6d, + (q31_t)0x71aca145, (q31_t)0xc528f5e1, + (q31_t)0x71a9bdba, (q31_t)0xc523617a, (q31_t)0x71a6d9e9, (q31_t)0xc51dcd37, (q31_t)0x71a3f5d2, (q31_t)0xc5183919, + (q31_t)0x71a11175, (q31_t)0xc512a51f, + (q31_t)0x719e2cd2, (q31_t)0xc50d1149, (q31_t)0x719b47e9, (q31_t)0xc5077d97, (q31_t)0x719862b9, (q31_t)0xc501ea0a, + (q31_t)0x71957d44, (q31_t)0xc4fc56a2, + (q31_t)0x71929789, (q31_t)0xc4f6c35d, (q31_t)0x718fb187, (q31_t)0xc4f1303d, (q31_t)0x718ccb3f, (q31_t)0xc4eb9d42, + (q31_t)0x7189e4b2, (q31_t)0xc4e60a6b, + (q31_t)0x7186fdde, (q31_t)0xc4e077b8, (q31_t)0x718416c4, (q31_t)0xc4dae52a, (q31_t)0x71812f65, (q31_t)0xc4d552c1, + (q31_t)0x717e47bf, (q31_t)0xc4cfc07c, + (q31_t)0x717b5fd3, (q31_t)0xc4ca2e5b, (q31_t)0x717877a1, (q31_t)0xc4c49c5f, (q31_t)0x71758f29, (q31_t)0xc4bf0a87, + (q31_t)0x7172a66c, (q31_t)0xc4b978d4, + (q31_t)0x716fbd68, (q31_t)0xc4b3e746, (q31_t)0x716cd41e, (q31_t)0xc4ae55dc, (q31_t)0x7169ea8f, (q31_t)0xc4a8c497, + (q31_t)0x716700b9, (q31_t)0xc4a33376, + (q31_t)0x7164169d, (q31_t)0xc49da27a, (q31_t)0x71612c3c, (q31_t)0xc49811a3, (q31_t)0x715e4194, (q31_t)0xc49280f0, + (q31_t)0x715b56a7, (q31_t)0xc48cf062, + (q31_t)0x71586b74, (q31_t)0xc4875ff9, (q31_t)0x71557ffa, (q31_t)0xc481cfb4, (q31_t)0x7152943b, (q31_t)0xc47c3f94, + (q31_t)0x714fa836, (q31_t)0xc476af98, + (q31_t)0x714cbbeb, (q31_t)0xc4711fc2, (q31_t)0x7149cf5a, (q31_t)0xc46b9010, (q31_t)0x7146e284, (q31_t)0xc4660083, + (q31_t)0x7143f567, (q31_t)0xc460711b, + (q31_t)0x71410805, (q31_t)0xc45ae1d7, (q31_t)0x713e1a5c, (q31_t)0xc45552b8, (q31_t)0x713b2c6e, (q31_t)0xc44fc3be, + (q31_t)0x71383e3a, (q31_t)0xc44a34e9, + (q31_t)0x71354fc0, (q31_t)0xc444a639, (q31_t)0x71326101, (q31_t)0xc43f17ad, (q31_t)0x712f71fb, (q31_t)0xc4398947, + (q31_t)0x712c82b0, (q31_t)0xc433fb05, + (q31_t)0x7129931f, (q31_t)0xc42e6ce8, (q31_t)0x7126a348, (q31_t)0xc428def0, (q31_t)0x7123b32b, (q31_t)0xc423511d, + (q31_t)0x7120c2c8, (q31_t)0xc41dc36f, + (q31_t)0x711dd220, (q31_t)0xc41835e6, (q31_t)0x711ae132, (q31_t)0xc412a882, (q31_t)0x7117effe, (q31_t)0xc40d1b42, + (q31_t)0x7114fe84, (q31_t)0xc4078e28, + (q31_t)0x71120cc5, (q31_t)0xc4020133, (q31_t)0x710f1ac0, (q31_t)0xc3fc7462, (q31_t)0x710c2875, (q31_t)0xc3f6e7b7, + (q31_t)0x710935e4, (q31_t)0xc3f15b31, + (q31_t)0x7106430e, (q31_t)0xc3ebced0, (q31_t)0x71034ff2, (q31_t)0xc3e64294, (q31_t)0x71005c90, (q31_t)0xc3e0b67d, + (q31_t)0x70fd68e9, (q31_t)0xc3db2a8b, + (q31_t)0x70fa74fc, (q31_t)0xc3d59ebe, (q31_t)0x70f780c9, (q31_t)0xc3d01316, (q31_t)0x70f48c50, (q31_t)0xc3ca8793, + (q31_t)0x70f19792, (q31_t)0xc3c4fc36, + (q31_t)0x70eea28e, (q31_t)0xc3bf70fd, (q31_t)0x70ebad45, (q31_t)0xc3b9e5ea, (q31_t)0x70e8b7b5, (q31_t)0xc3b45afc, + (q31_t)0x70e5c1e1, (q31_t)0xc3aed034, + (q31_t)0x70e2cbc6, (q31_t)0xc3a94590, (q31_t)0x70dfd566, (q31_t)0xc3a3bb12, (q31_t)0x70dcdec0, (q31_t)0xc39e30b8, + (q31_t)0x70d9e7d5, (q31_t)0xc398a685, + (q31_t)0x70d6f0a4, (q31_t)0xc3931c76, (q31_t)0x70d3f92d, (q31_t)0xc38d928d, (q31_t)0x70d10171, (q31_t)0xc38808c9, + (q31_t)0x70ce096f, (q31_t)0xc3827f2a, + (q31_t)0x70cb1128, (q31_t)0xc37cf5b0, (q31_t)0x70c8189b, (q31_t)0xc3776c5c, (q31_t)0x70c51fc8, (q31_t)0xc371e32d, + (q31_t)0x70c226b0, (q31_t)0xc36c5a24, + (q31_t)0x70bf2d53, (q31_t)0xc366d140, (q31_t)0x70bc33b0, (q31_t)0xc3614881, (q31_t)0x70b939c7, (q31_t)0xc35bbfe8, + (q31_t)0x70b63f99, (q31_t)0xc3563774, + (q31_t)0x70b34525, (q31_t)0xc350af26, (q31_t)0x70b04a6b, (q31_t)0xc34b26fc, (q31_t)0x70ad4f6d, (q31_t)0xc3459ef9, + (q31_t)0x70aa5428, (q31_t)0xc340171b, + (q31_t)0x70a7589f, (q31_t)0xc33a8f62, (q31_t)0x70a45ccf, (q31_t)0xc33507cf, (q31_t)0x70a160ba, (q31_t)0xc32f8061, + (q31_t)0x709e6460, (q31_t)0xc329f919, + (q31_t)0x709b67c0, (q31_t)0xc32471f7, (q31_t)0x70986adb, (q31_t)0xc31eeaf9, (q31_t)0x70956db1, (q31_t)0xc3196422, + (q31_t)0x70927041, (q31_t)0xc313dd70, + (q31_t)0x708f728b, (q31_t)0xc30e56e4, (q31_t)0x708c7490, (q31_t)0xc308d07d, (q31_t)0x70897650, (q31_t)0xc3034a3c, + (q31_t)0x708677ca, (q31_t)0xc2fdc420, + (q31_t)0x708378ff, (q31_t)0xc2f83e2a, (q31_t)0x708079ee, (q31_t)0xc2f2b85a, (q31_t)0x707d7a98, (q31_t)0xc2ed32af, + (q31_t)0x707a7afd, (q31_t)0xc2e7ad2a, + (q31_t)0x70777b1c, (q31_t)0xc2e227cb, (q31_t)0x70747af6, (q31_t)0xc2dca291, (q31_t)0x70717a8a, (q31_t)0xc2d71d7e, + (q31_t)0x706e79d9, (q31_t)0xc2d1988f, + (q31_t)0x706b78e3, (q31_t)0xc2cc13c7, (q31_t)0x706877a7, (q31_t)0xc2c68f24, (q31_t)0x70657626, (q31_t)0xc2c10aa7, + (q31_t)0x70627460, (q31_t)0xc2bb8650, + (q31_t)0x705f7255, (q31_t)0xc2b6021f, (q31_t)0x705c7004, (q31_t)0xc2b07e14, (q31_t)0x70596d6d, (q31_t)0xc2aafa2e, + (q31_t)0x70566a92, (q31_t)0xc2a5766e, + (q31_t)0x70536771, (q31_t)0xc29ff2d4, (q31_t)0x7050640b, (q31_t)0xc29a6f60, (q31_t)0x704d6060, (q31_t)0xc294ec12, + (q31_t)0x704a5c6f, (q31_t)0xc28f68e9, + (q31_t)0x70475839, (q31_t)0xc289e5e7, (q31_t)0x704453be, (q31_t)0xc284630a, (q31_t)0x70414efd, (q31_t)0xc27ee054, + (q31_t)0x703e49f8, (q31_t)0xc2795dc3, + (q31_t)0x703b44ad, (q31_t)0xc273db58, (q31_t)0x70383f1d, (q31_t)0xc26e5913, (q31_t)0x70353947, (q31_t)0xc268d6f5, + (q31_t)0x7032332d, (q31_t)0xc26354fc, + (q31_t)0x702f2ccd, (q31_t)0xc25dd329, (q31_t)0x702c2628, (q31_t)0xc258517c, (q31_t)0x70291f3e, (q31_t)0xc252cff5, + (q31_t)0x7026180e, (q31_t)0xc24d4e95, + (q31_t)0x7023109a, (q31_t)0xc247cd5a, (q31_t)0x702008e0, (q31_t)0xc2424c46, (q31_t)0x701d00e1, (q31_t)0xc23ccb57, + (q31_t)0x7019f89d, (q31_t)0xc2374a8f, + (q31_t)0x7016f014, (q31_t)0xc231c9ec, (q31_t)0x7013e746, (q31_t)0xc22c4970, (q31_t)0x7010de32, (q31_t)0xc226c91a, + (q31_t)0x700dd4da, (q31_t)0xc22148ea, + (q31_t)0x700acb3c, (q31_t)0xc21bc8e1, (q31_t)0x7007c159, (q31_t)0xc21648fd, (q31_t)0x7004b731, (q31_t)0xc210c940, + (q31_t)0x7001acc4, (q31_t)0xc20b49a9, + (q31_t)0x6ffea212, (q31_t)0xc205ca38, (q31_t)0x6ffb971b, (q31_t)0xc2004aed, (q31_t)0x6ff88bde, (q31_t)0xc1facbc9, + (q31_t)0x6ff5805d, (q31_t)0xc1f54cca, + (q31_t)0x6ff27497, (q31_t)0xc1efcdf3, (q31_t)0x6fef688b, (q31_t)0xc1ea4f41, (q31_t)0x6fec5c3b, (q31_t)0xc1e4d0b6, + (q31_t)0x6fe94fa5, (q31_t)0xc1df5251, + (q31_t)0x6fe642ca, (q31_t)0xc1d9d412, (q31_t)0x6fe335ab, (q31_t)0xc1d455f9, (q31_t)0x6fe02846, (q31_t)0xc1ced807, + (q31_t)0x6fdd1a9c, (q31_t)0xc1c95a3c, + (q31_t)0x6fda0cae, (q31_t)0xc1c3dc97, (q31_t)0x6fd6fe7a, (q31_t)0xc1be5f18, (q31_t)0x6fd3f001, (q31_t)0xc1b8e1bf, + (q31_t)0x6fd0e144, (q31_t)0xc1b3648d, + (q31_t)0x6fcdd241, (q31_t)0xc1ade781, (q31_t)0x6fcac2fa, (q31_t)0xc1a86a9c, (q31_t)0x6fc7b36d, (q31_t)0xc1a2edde, + (q31_t)0x6fc4a39c, (q31_t)0xc19d7145, + (q31_t)0x6fc19385, (q31_t)0xc197f4d4, (q31_t)0x6fbe832a, (q31_t)0xc1927888, (q31_t)0x6fbb728a, (q31_t)0xc18cfc63, + (q31_t)0x6fb861a4, (q31_t)0xc1878065, + (q31_t)0x6fb5507a, (q31_t)0xc182048d, (q31_t)0x6fb23f0b, (q31_t)0xc17c88dc, (q31_t)0x6faf2d57, (q31_t)0xc1770d52, + (q31_t)0x6fac1b5f, (q31_t)0xc17191ee, + (q31_t)0x6fa90921, (q31_t)0xc16c16b0, (q31_t)0x6fa5f69e, (q31_t)0xc1669b99, (q31_t)0x6fa2e3d7, (q31_t)0xc16120a9, + (q31_t)0x6f9fd0cb, (q31_t)0xc15ba5df, + (q31_t)0x6f9cbd79, (q31_t)0xc1562b3d, (q31_t)0x6f99a9e3, (q31_t)0xc150b0c0, (q31_t)0x6f969608, (q31_t)0xc14b366b, + (q31_t)0x6f9381e9, (q31_t)0xc145bc3c, + (q31_t)0x6f906d84, (q31_t)0xc1404233, (q31_t)0x6f8d58db, (q31_t)0xc13ac852, (q31_t)0x6f8a43ed, (q31_t)0xc1354e97, + (q31_t)0x6f872eba, (q31_t)0xc12fd503, + (q31_t)0x6f841942, (q31_t)0xc12a5b95, (q31_t)0x6f810386, (q31_t)0xc124e24f, (q31_t)0x6f7ded84, (q31_t)0xc11f692f, + (q31_t)0x6f7ad73e, (q31_t)0xc119f036, + (q31_t)0x6f77c0b3, (q31_t)0xc1147764, (q31_t)0x6f74a9e4, (q31_t)0xc10efeb8, (q31_t)0x6f7192cf, (q31_t)0xc1098634, + (q31_t)0x6f6e7b76, (q31_t)0xc1040dd6, + (q31_t)0x6f6b63d8, (q31_t)0xc0fe959f, (q31_t)0x6f684bf6, (q31_t)0xc0f91d8f, (q31_t)0x6f6533ce, (q31_t)0xc0f3a5a6, + (q31_t)0x6f621b62, (q31_t)0xc0ee2de3, + (q31_t)0x6f5f02b2, (q31_t)0xc0e8b648, (q31_t)0x6f5be9bc, (q31_t)0xc0e33ed4, (q31_t)0x6f58d082, (q31_t)0xc0ddc786, + (q31_t)0x6f55b703, (q31_t)0xc0d8505f, + (q31_t)0x6f529d40, (q31_t)0xc0d2d960, (q31_t)0x6f4f8338, (q31_t)0xc0cd6287, (q31_t)0x6f4c68eb, (q31_t)0xc0c7ebd6, + (q31_t)0x6f494e5a, (q31_t)0xc0c2754b, + (q31_t)0x6f463383, (q31_t)0xc0bcfee7, (q31_t)0x6f431869, (q31_t)0xc0b788ab, (q31_t)0x6f3ffd09, (q31_t)0xc0b21295, + (q31_t)0x6f3ce165, (q31_t)0xc0ac9ca6, + (q31_t)0x6f39c57d, (q31_t)0xc0a726df, (q31_t)0x6f36a94f, (q31_t)0xc0a1b13e, (q31_t)0x6f338cde, (q31_t)0xc09c3bc5, + (q31_t)0x6f307027, (q31_t)0xc096c673, + (q31_t)0x6f2d532c, (q31_t)0xc0915148, (q31_t)0x6f2a35ed, (q31_t)0xc08bdc44, (q31_t)0x6f271868, (q31_t)0xc0866767, + (q31_t)0x6f23faa0, (q31_t)0xc080f2b1, + (q31_t)0x6f20dc92, (q31_t)0xc07b7e23, (q31_t)0x6f1dbe41, (q31_t)0xc07609bb, (q31_t)0x6f1a9faa, (q31_t)0xc070957b, + (q31_t)0x6f1780cf, (q31_t)0xc06b2162, + (q31_t)0x6f1461b0, (q31_t)0xc065ad70, (q31_t)0x6f11424c, (q31_t)0xc06039a6, (q31_t)0x6f0e22a3, (q31_t)0xc05ac603, + (q31_t)0x6f0b02b6, (q31_t)0xc0555287, + (q31_t)0x6f07e285, (q31_t)0xc04fdf32, (q31_t)0x6f04c20f, (q31_t)0xc04a6c05, (q31_t)0x6f01a155, (q31_t)0xc044f8fe, + (q31_t)0x6efe8056, (q31_t)0xc03f8620, + (q31_t)0x6efb5f12, (q31_t)0xc03a1368, (q31_t)0x6ef83d8a, (q31_t)0xc034a0d8, (q31_t)0x6ef51bbe, (q31_t)0xc02f2e6f, + (q31_t)0x6ef1f9ad, (q31_t)0xc029bc2e, + (q31_t)0x6eeed758, (q31_t)0xc0244a14, (q31_t)0x6eebb4bf, (q31_t)0xc01ed821, (q31_t)0x6ee891e1, (q31_t)0xc0196656, + (q31_t)0x6ee56ebe, (q31_t)0xc013f4b2, + (q31_t)0x6ee24b57, (q31_t)0xc00e8336, (q31_t)0x6edf27ac, (q31_t)0xc00911e1, (q31_t)0x6edc03bc, (q31_t)0xc003a0b3, + (q31_t)0x6ed8df88, (q31_t)0xbffe2fad, + (q31_t)0x6ed5bb10, (q31_t)0xbff8bece, (q31_t)0x6ed29653, (q31_t)0xbff34e17, (q31_t)0x6ecf7152, (q31_t)0xbfeddd88, + (q31_t)0x6ecc4c0d, (q31_t)0xbfe86d20, + (q31_t)0x6ec92683, (q31_t)0xbfe2fcdf, (q31_t)0x6ec600b5, (q31_t)0xbfdd8cc6, (q31_t)0x6ec2daa2, (q31_t)0xbfd81cd5, + (q31_t)0x6ebfb44b, (q31_t)0xbfd2ad0b, + (q31_t)0x6ebc8db0, (q31_t)0xbfcd3d69, (q31_t)0x6eb966d1, (q31_t)0xbfc7cdee, (q31_t)0x6eb63fad, (q31_t)0xbfc25e9b, + (q31_t)0x6eb31845, (q31_t)0xbfbcef70, + (q31_t)0x6eaff099, (q31_t)0xbfb7806c, (q31_t)0x6eacc8a8, (q31_t)0xbfb21190, (q31_t)0x6ea9a073, (q31_t)0xbfaca2dc, + (q31_t)0x6ea677fa, (q31_t)0xbfa7344f, + (q31_t)0x6ea34f3d, (q31_t)0xbfa1c5ea, (q31_t)0x6ea0263b, (q31_t)0xbf9c57ac, (q31_t)0x6e9cfcf5, (q31_t)0xbf96e997, + (q31_t)0x6e99d36b, (q31_t)0xbf917ba9, + (q31_t)0x6e96a99d, (q31_t)0xbf8c0de3, (q31_t)0x6e937f8a, (q31_t)0xbf86a044, (q31_t)0x6e905534, (q31_t)0xbf8132ce, + (q31_t)0x6e8d2a99, (q31_t)0xbf7bc57f, + (q31_t)0x6e89ffb9, (q31_t)0xbf765858, (q31_t)0x6e86d496, (q31_t)0xbf70eb59, (q31_t)0x6e83a92f, (q31_t)0xbf6b7e81, + (q31_t)0x6e807d83, (q31_t)0xbf6611d2, + (q31_t)0x6e7d5193, (q31_t)0xbf60a54a, (q31_t)0x6e7a255f, (q31_t)0xbf5b38ea, (q31_t)0x6e76f8e7, (q31_t)0xbf55ccb2, + (q31_t)0x6e73cc2b, (q31_t)0xbf5060a2, + (q31_t)0x6e709f2a, (q31_t)0xbf4af4ba, (q31_t)0x6e6d71e6, (q31_t)0xbf4588fa, (q31_t)0x6e6a445d, (q31_t)0xbf401d61, + (q31_t)0x6e671690, (q31_t)0xbf3ab1f1, + (q31_t)0x6e63e87f, (q31_t)0xbf3546a8, (q31_t)0x6e60ba2a, (q31_t)0xbf2fdb88, (q31_t)0x6e5d8b91, (q31_t)0xbf2a708f, + (q31_t)0x6e5a5cb4, (q31_t)0xbf2505bf, + (q31_t)0x6e572d93, (q31_t)0xbf1f9b16, (q31_t)0x6e53fe2e, (q31_t)0xbf1a3096, (q31_t)0x6e50ce84, (q31_t)0xbf14c63d, + (q31_t)0x6e4d9e97, (q31_t)0xbf0f5c0d, + (q31_t)0x6e4a6e66, (q31_t)0xbf09f205, (q31_t)0x6e473df0, (q31_t)0xbf048824, (q31_t)0x6e440d37, (q31_t)0xbeff1e6c, + (q31_t)0x6e40dc39, (q31_t)0xbef9b4dc, + (q31_t)0x6e3daaf8, (q31_t)0xbef44b74, (q31_t)0x6e3a7972, (q31_t)0xbeeee234, (q31_t)0x6e3747a9, (q31_t)0xbee9791c, + (q31_t)0x6e34159b, (q31_t)0xbee4102d, + (q31_t)0x6e30e34a, (q31_t)0xbedea765, (q31_t)0x6e2db0b4, (q31_t)0xbed93ec6, (q31_t)0x6e2a7ddb, (q31_t)0xbed3d64f, + (q31_t)0x6e274abe, (q31_t)0xbece6e00, + (q31_t)0x6e24175c, (q31_t)0xbec905d9, (q31_t)0x6e20e3b7, (q31_t)0xbec39ddb, (q31_t)0x6e1dafce, (q31_t)0xbebe3605, + (q31_t)0x6e1a7ba1, (q31_t)0xbeb8ce57, + (q31_t)0x6e174730, (q31_t)0xbeb366d1, (q31_t)0x6e14127b, (q31_t)0xbeadff74, (q31_t)0x6e10dd82, (q31_t)0xbea8983f, + (q31_t)0x6e0da845, (q31_t)0xbea33132, + (q31_t)0x6e0a72c5, (q31_t)0xbe9dca4e, (q31_t)0x6e073d00, (q31_t)0xbe986391, (q31_t)0x6e0406f8, (q31_t)0xbe92fcfe, + (q31_t)0x6e00d0ac, (q31_t)0xbe8d9692, + (q31_t)0x6dfd9a1c, (q31_t)0xbe88304f, (q31_t)0x6dfa6348, (q31_t)0xbe82ca35, (q31_t)0x6df72c30, (q31_t)0xbe7d6442, + (q31_t)0x6df3f4d4, (q31_t)0xbe77fe78, + (q31_t)0x6df0bd35, (q31_t)0xbe7298d7, (q31_t)0x6ded8552, (q31_t)0xbe6d335e, (q31_t)0x6dea4d2b, (q31_t)0xbe67ce0d, + (q31_t)0x6de714c0, (q31_t)0xbe6268e5, + (q31_t)0x6de3dc11, (q31_t)0xbe5d03e6, (q31_t)0x6de0a31f, (q31_t)0xbe579f0f, (q31_t)0x6ddd69e9, (q31_t)0xbe523a60, + (q31_t)0x6dda306f, (q31_t)0xbe4cd5da, + (q31_t)0x6dd6f6b1, (q31_t)0xbe47717c, (q31_t)0x6dd3bcaf, (q31_t)0xbe420d47, (q31_t)0x6dd0826a, (q31_t)0xbe3ca93b, + (q31_t)0x6dcd47e1, (q31_t)0xbe374557, + (q31_t)0x6dca0d14, (q31_t)0xbe31e19b, (q31_t)0x6dc6d204, (q31_t)0xbe2c7e09, (q31_t)0x6dc396b0, (q31_t)0xbe271a9f, + (q31_t)0x6dc05b18, (q31_t)0xbe21b75d, + (q31_t)0x6dbd1f3c, (q31_t)0xbe1c5444, (q31_t)0x6db9e31d, (q31_t)0xbe16f154, (q31_t)0x6db6a6ba, (q31_t)0xbe118e8c, + (q31_t)0x6db36a14, (q31_t)0xbe0c2bed, + (q31_t)0x6db02d29, (q31_t)0xbe06c977, (q31_t)0x6daceffb, (q31_t)0xbe01672a, (q31_t)0x6da9b28a, (q31_t)0xbdfc0505, + (q31_t)0x6da674d5, (q31_t)0xbdf6a309, + (q31_t)0x6da336dc, (q31_t)0xbdf14135, (q31_t)0x6d9ff89f, (q31_t)0xbdebdf8b, (q31_t)0x6d9cba1f, (q31_t)0xbde67e09, + (q31_t)0x6d997b5b, (q31_t)0xbde11cb0, + (q31_t)0x6d963c54, (q31_t)0xbddbbb7f, (q31_t)0x6d92fd09, (q31_t)0xbdd65a78, (q31_t)0x6d8fbd7a, (q31_t)0xbdd0f999, + (q31_t)0x6d8c7da8, (q31_t)0xbdcb98e3, + (q31_t)0x6d893d93, (q31_t)0xbdc63856, (q31_t)0x6d85fd39, (q31_t)0xbdc0d7f2, (q31_t)0x6d82bc9d, (q31_t)0xbdbb77b7, + (q31_t)0x6d7f7bbc, (q31_t)0xbdb617a4, + (q31_t)0x6d7c3a98, (q31_t)0xbdb0b7bb, (q31_t)0x6d78f931, (q31_t)0xbdab57fa, (q31_t)0x6d75b786, (q31_t)0xbda5f862, + (q31_t)0x6d727597, (q31_t)0xbda098f3, + (q31_t)0x6d6f3365, (q31_t)0xbd9b39ad, (q31_t)0x6d6bf0f0, (q31_t)0xbd95da91, (q31_t)0x6d68ae37, (q31_t)0xbd907b9d, + (q31_t)0x6d656b3a, (q31_t)0xbd8b1cd2, + (q31_t)0x6d6227fa, (q31_t)0xbd85be30, (q31_t)0x6d5ee477, (q31_t)0xbd805fb7, (q31_t)0x6d5ba0b0, (q31_t)0xbd7b0167, + (q31_t)0x6d585ca6, (q31_t)0xbd75a340, + (q31_t)0x6d551858, (q31_t)0xbd704542, (q31_t)0x6d51d3c6, (q31_t)0xbd6ae76d, (q31_t)0x6d4e8ef2, (q31_t)0xbd6589c1, + (q31_t)0x6d4b49da, (q31_t)0xbd602c3f, + (q31_t)0x6d48047e, (q31_t)0xbd5acee5, (q31_t)0x6d44bedf, (q31_t)0xbd5571b5, (q31_t)0x6d4178fd, (q31_t)0xbd5014ad, + (q31_t)0x6d3e32d7, (q31_t)0xbd4ab7cf, + (q31_t)0x6d3aec6e, (q31_t)0xbd455b1a, (q31_t)0x6d37a5c1, (q31_t)0xbd3ffe8e, (q31_t)0x6d345ed1, (q31_t)0xbd3aa22c, + (q31_t)0x6d31179e, (q31_t)0xbd3545f2, + (q31_t)0x6d2dd027, (q31_t)0xbd2fe9e2, (q31_t)0x6d2a886e, (q31_t)0xbd2a8dfb, (q31_t)0x6d274070, (q31_t)0xbd25323d, + (q31_t)0x6d23f830, (q31_t)0xbd1fd6a8, + (q31_t)0x6d20afac, (q31_t)0xbd1a7b3d, (q31_t)0x6d1d66e4, (q31_t)0xbd151ffb, (q31_t)0x6d1a1dda, (q31_t)0xbd0fc4e2, + (q31_t)0x6d16d48c, (q31_t)0xbd0a69f2, + (q31_t)0x6d138afb, (q31_t)0xbd050f2c, (q31_t)0x6d104126, (q31_t)0xbcffb48f, (q31_t)0x6d0cf70f, (q31_t)0xbcfa5a1b, + (q31_t)0x6d09acb4, (q31_t)0xbcf4ffd1, + (q31_t)0x6d066215, (q31_t)0xbcefa5b0, (q31_t)0x6d031734, (q31_t)0xbcea4bb9, (q31_t)0x6cffcc0f, (q31_t)0xbce4f1eb, + (q31_t)0x6cfc80a7, (q31_t)0xbcdf9846, + (q31_t)0x6cf934fc, (q31_t)0xbcda3ecb, (q31_t)0x6cf5e90d, (q31_t)0xbcd4e579, (q31_t)0x6cf29cdc, (q31_t)0xbccf8c50, + (q31_t)0x6cef5067, (q31_t)0xbcca3351, + (q31_t)0x6cec03af, (q31_t)0xbcc4da7b, (q31_t)0x6ce8b6b4, (q31_t)0xbcbf81cf, (q31_t)0x6ce56975, (q31_t)0xbcba294d, + (q31_t)0x6ce21bf4, (q31_t)0xbcb4d0f4, + (q31_t)0x6cdece2f, (q31_t)0xbcaf78c4, (q31_t)0x6cdb8027, (q31_t)0xbcaa20be, (q31_t)0x6cd831dc, (q31_t)0xbca4c8e1, + (q31_t)0x6cd4e34e, (q31_t)0xbc9f712e, + (q31_t)0x6cd1947c, (q31_t)0xbc9a19a5, (q31_t)0x6cce4568, (q31_t)0xbc94c245, (q31_t)0x6ccaf610, (q31_t)0xbc8f6b0f, + (q31_t)0x6cc7a676, (q31_t)0xbc8a1402, + (q31_t)0x6cc45698, (q31_t)0xbc84bd1f, (q31_t)0x6cc10677, (q31_t)0xbc7f6665, (q31_t)0x6cbdb613, (q31_t)0xbc7a0fd6, + (q31_t)0x6cba656c, (q31_t)0xbc74b96f, + (q31_t)0x6cb71482, (q31_t)0xbc6f6333, (q31_t)0x6cb3c355, (q31_t)0xbc6a0d20, (q31_t)0x6cb071e4, (q31_t)0xbc64b737, + (q31_t)0x6cad2031, (q31_t)0xbc5f6177, + (q31_t)0x6ca9ce3b, (q31_t)0xbc5a0be2, (q31_t)0x6ca67c01, (q31_t)0xbc54b676, (q31_t)0x6ca32985, (q31_t)0xbc4f6134, + (q31_t)0x6c9fd6c6, (q31_t)0xbc4a0c1b, + (q31_t)0x6c9c83c3, (q31_t)0xbc44b72c, (q31_t)0x6c99307e, (q31_t)0xbc3f6267, (q31_t)0x6c95dcf6, (q31_t)0xbc3a0dcc, + (q31_t)0x6c92892a, (q31_t)0xbc34b95b, + (q31_t)0x6c8f351c, (q31_t)0xbc2f6513, (q31_t)0x6c8be0cb, (q31_t)0xbc2a10f6, (q31_t)0x6c888c36, (q31_t)0xbc24bd02, + (q31_t)0x6c85375f, (q31_t)0xbc1f6938, + (q31_t)0x6c81e245, (q31_t)0xbc1a1598, (q31_t)0x6c7e8ce8, (q31_t)0xbc14c221, (q31_t)0x6c7b3748, (q31_t)0xbc0f6ed5, + (q31_t)0x6c77e165, (q31_t)0xbc0a1bb3, + (q31_t)0x6c748b3f, (q31_t)0xbc04c8ba, (q31_t)0x6c7134d7, (q31_t)0xbbff75ec, (q31_t)0x6c6dde2b, (q31_t)0xbbfa2347, + (q31_t)0x6c6a873d, (q31_t)0xbbf4d0cc, + (q31_t)0x6c67300b, (q31_t)0xbbef7e7c, (q31_t)0x6c63d897, (q31_t)0xbbea2c55, (q31_t)0x6c6080e0, (q31_t)0xbbe4da58, + (q31_t)0x6c5d28e6, (q31_t)0xbbdf8885, + (q31_t)0x6c59d0a9, (q31_t)0xbbda36dd, (q31_t)0x6c56782a, (q31_t)0xbbd4e55e, (q31_t)0x6c531f67, (q31_t)0xbbcf940a, + (q31_t)0x6c4fc662, (q31_t)0xbbca42df, + (q31_t)0x6c4c6d1a, (q31_t)0xbbc4f1df, (q31_t)0x6c49138f, (q31_t)0xbbbfa108, (q31_t)0x6c45b9c1, (q31_t)0xbbba505c, + (q31_t)0x6c425fb1, (q31_t)0xbbb4ffda, + (q31_t)0x6c3f055d, (q31_t)0xbbafaf82, (q31_t)0x6c3baac7, (q31_t)0xbbaa5f54, (q31_t)0x6c384fef, (q31_t)0xbba50f50, + (q31_t)0x6c34f4d3, (q31_t)0xbb9fbf77, + (q31_t)0x6c319975, (q31_t)0xbb9a6fc7, (q31_t)0x6c2e3dd4, (q31_t)0xbb952042, (q31_t)0x6c2ae1f0, (q31_t)0xbb8fd0e7, + (q31_t)0x6c2785ca, (q31_t)0xbb8a81b6, + (q31_t)0x6c242960, (q31_t)0xbb8532b0, (q31_t)0x6c20ccb4, (q31_t)0xbb7fe3d3, (q31_t)0x6c1d6fc6, (q31_t)0xbb7a9521, + (q31_t)0x6c1a1295, (q31_t)0xbb754699, + (q31_t)0x6c16b521, (q31_t)0xbb6ff83c, (q31_t)0x6c13576a, (q31_t)0xbb6aaa09, (q31_t)0x6c0ff971, (q31_t)0xbb655c00, + (q31_t)0x6c0c9b35, (q31_t)0xbb600e21, + (q31_t)0x6c093cb6, (q31_t)0xbb5ac06d, (q31_t)0x6c05ddf5, (q31_t)0xbb5572e3, (q31_t)0x6c027ef1, (q31_t)0xbb502583, + (q31_t)0x6bff1faa, (q31_t)0xbb4ad84e, + (q31_t)0x6bfbc021, (q31_t)0xbb458b43, (q31_t)0x6bf86055, (q31_t)0xbb403e63, (q31_t)0x6bf50047, (q31_t)0xbb3af1ad, + (q31_t)0x6bf19ff6, (q31_t)0xbb35a521, + (q31_t)0x6bee3f62, (q31_t)0xbb3058c0, (q31_t)0x6beade8c, (q31_t)0xbb2b0c8a, (q31_t)0x6be77d74, (q31_t)0xbb25c07d, + (q31_t)0x6be41c18, (q31_t)0xbb20749c, + (q31_t)0x6be0ba7b, (q31_t)0xbb1b28e4, (q31_t)0x6bdd589a, (q31_t)0xbb15dd57, (q31_t)0x6bd9f677, (q31_t)0xbb1091f5, + (q31_t)0x6bd69412, (q31_t)0xbb0b46bd, + (q31_t)0x6bd3316a, (q31_t)0xbb05fbb0, (q31_t)0x6bcfce80, (q31_t)0xbb00b0ce, (q31_t)0x6bcc6b53, (q31_t)0xbafb6615, + (q31_t)0x6bc907e3, (q31_t)0xbaf61b88, + (q31_t)0x6bc5a431, (q31_t)0xbaf0d125, (q31_t)0x6bc2403d, (q31_t)0xbaeb86ed, (q31_t)0x6bbedc06, (q31_t)0xbae63cdf, + (q31_t)0x6bbb778d, (q31_t)0xbae0f2fc, + (q31_t)0x6bb812d1, (q31_t)0xbadba943, (q31_t)0x6bb4add3, (q31_t)0xbad65fb5, (q31_t)0x6bb14892, (q31_t)0xbad11652, + (q31_t)0x6bade30f, (q31_t)0xbacbcd1a, + (q31_t)0x6baa7d49, (q31_t)0xbac6840c, (q31_t)0x6ba71741, (q31_t)0xbac13b29, (q31_t)0x6ba3b0f7, (q31_t)0xbabbf270, + (q31_t)0x6ba04a6a, (q31_t)0xbab6a9e3, + (q31_t)0x6b9ce39b, (q31_t)0xbab16180, (q31_t)0x6b997c8a, (q31_t)0xbaac1948, (q31_t)0x6b961536, (q31_t)0xbaa6d13a, + (q31_t)0x6b92ada0, (q31_t)0xbaa18958, + (q31_t)0x6b8f45c7, (q31_t)0xba9c41a0, (q31_t)0x6b8bddac, (q31_t)0xba96fa13, (q31_t)0x6b88754f, (q31_t)0xba91b2b1, + (q31_t)0x6b850caf, (q31_t)0xba8c6b79, + (q31_t)0x6b81a3cd, (q31_t)0xba87246d, (q31_t)0x6b7e3aa9, (q31_t)0xba81dd8b, (q31_t)0x6b7ad142, (q31_t)0xba7c96d4, + (q31_t)0x6b776799, (q31_t)0xba775048, + (q31_t)0x6b73fdae, (q31_t)0xba7209e7, (q31_t)0x6b709381, (q31_t)0xba6cc3b1, (q31_t)0x6b6d2911, (q31_t)0xba677da6, + (q31_t)0x6b69be5f, (q31_t)0xba6237c5, + (q31_t)0x6b66536b, (q31_t)0xba5cf210, (q31_t)0x6b62e834, (q31_t)0xba57ac86, (q31_t)0x6b5f7cbc, (q31_t)0xba526726, + (q31_t)0x6b5c1101, (q31_t)0xba4d21f2, + (q31_t)0x6b58a503, (q31_t)0xba47dce8, (q31_t)0x6b5538c4, (q31_t)0xba42980a, (q31_t)0x6b51cc42, (q31_t)0xba3d5356, + (q31_t)0x6b4e5f7f, (q31_t)0xba380ece, + (q31_t)0x6b4af279, (q31_t)0xba32ca71, (q31_t)0x6b478530, (q31_t)0xba2d863e, (q31_t)0x6b4417a6, (q31_t)0xba284237, + (q31_t)0x6b40a9d9, (q31_t)0xba22fe5b, + (q31_t)0x6b3d3bcb, (q31_t)0xba1dbaaa, (q31_t)0x6b39cd7a, (q31_t)0xba187724, (q31_t)0x6b365ee7, (q31_t)0xba1333c9, + (q31_t)0x6b32f012, (q31_t)0xba0df099, + (q31_t)0x6b2f80fb, (q31_t)0xba08ad95, (q31_t)0x6b2c11a1, (q31_t)0xba036abb, (q31_t)0x6b28a206, (q31_t)0xb9fe280d, + (q31_t)0x6b253228, (q31_t)0xb9f8e58a, + (q31_t)0x6b21c208, (q31_t)0xb9f3a332, (q31_t)0x6b1e51a7, (q31_t)0xb9ee6106, (q31_t)0x6b1ae103, (q31_t)0xb9e91f04, + (q31_t)0x6b17701d, (q31_t)0xb9e3dd2e, + (q31_t)0x6b13fef5, (q31_t)0xb9de9b83, (q31_t)0x6b108d8b, (q31_t)0xb9d95a03, (q31_t)0x6b0d1bdf, (q31_t)0xb9d418af, + (q31_t)0x6b09a9f1, (q31_t)0xb9ced786, + (q31_t)0x6b0637c1, (q31_t)0xb9c99688, (q31_t)0x6b02c54f, (q31_t)0xb9c455b6, (q31_t)0x6aff529a, (q31_t)0xb9bf150e, + (q31_t)0x6afbdfa4, (q31_t)0xb9b9d493, + (q31_t)0x6af86c6c, (q31_t)0xb9b49442, (q31_t)0x6af4f8f2, (q31_t)0xb9af541d, (q31_t)0x6af18536, (q31_t)0xb9aa1423, + (q31_t)0x6aee1138, (q31_t)0xb9a4d455, + (q31_t)0x6aea9cf8, (q31_t)0xb99f94b2, (q31_t)0x6ae72876, (q31_t)0xb99a553a, (q31_t)0x6ae3b3b2, (q31_t)0xb99515ee, + (q31_t)0x6ae03eac, (q31_t)0xb98fd6cd, + (q31_t)0x6adcc964, (q31_t)0xb98a97d8, (q31_t)0x6ad953db, (q31_t)0xb985590e, (q31_t)0x6ad5de0f, (q31_t)0xb9801a70, + (q31_t)0x6ad26802, (q31_t)0xb97adbfd, + (q31_t)0x6acef1b2, (q31_t)0xb9759db6, (q31_t)0x6acb7b21, (q31_t)0xb9705f9a, (q31_t)0x6ac8044e, (q31_t)0xb96b21aa, + (q31_t)0x6ac48d39, (q31_t)0xb965e3e5, + (q31_t)0x6ac115e2, (q31_t)0xb960a64c, (q31_t)0x6abd9e49, (q31_t)0xb95b68de, (q31_t)0x6aba266e, (q31_t)0xb9562b9c, + (q31_t)0x6ab6ae52, (q31_t)0xb950ee86, + (q31_t)0x6ab335f4, (q31_t)0xb94bb19b, (q31_t)0x6aafbd54, (q31_t)0xb94674dc, (q31_t)0x6aac4472, (q31_t)0xb9413848, + (q31_t)0x6aa8cb4e, (q31_t)0xb93bfbe0, + (q31_t)0x6aa551e9, (q31_t)0xb936bfa4, (q31_t)0x6aa1d841, (q31_t)0xb9318393, (q31_t)0x6a9e5e58, (q31_t)0xb92c47ae, + (q31_t)0x6a9ae42e, (q31_t)0xb9270bf5, + (q31_t)0x6a9769c1, (q31_t)0xb921d067, (q31_t)0x6a93ef13, (q31_t)0xb91c9505, (q31_t)0x6a907423, (q31_t)0xb91759cf, + (q31_t)0x6a8cf8f1, (q31_t)0xb9121ec5, + (q31_t)0x6a897d7d, (q31_t)0xb90ce3e6, (q31_t)0x6a8601c8, (q31_t)0xb907a933, (q31_t)0x6a8285d1, (q31_t)0xb9026eac, + (q31_t)0x6a7f0999, (q31_t)0xb8fd3451, + (q31_t)0x6a7b8d1e, (q31_t)0xb8f7fa21, (q31_t)0x6a781062, (q31_t)0xb8f2c01d, (q31_t)0x6a749365, (q31_t)0xb8ed8646, + (q31_t)0x6a711625, (q31_t)0xb8e84c99, + (q31_t)0x6a6d98a4, (q31_t)0xb8e31319, (q31_t)0x6a6a1ae2, (q31_t)0xb8ddd9c5, (q31_t)0x6a669cdd, (q31_t)0xb8d8a09d, + (q31_t)0x6a631e97, (q31_t)0xb8d367a0, + (q31_t)0x6a5fa010, (q31_t)0xb8ce2ecf, (q31_t)0x6a5c2147, (q31_t)0xb8c8f62b, (q31_t)0x6a58a23c, (q31_t)0xb8c3bdb2, + (q31_t)0x6a5522ef, (q31_t)0xb8be8565, + (q31_t)0x6a51a361, (q31_t)0xb8b94d44, (q31_t)0x6a4e2392, (q31_t)0xb8b4154f, (q31_t)0x6a4aa381, (q31_t)0xb8aedd86, + (q31_t)0x6a47232e, (q31_t)0xb8a9a5e9, + (q31_t)0x6a43a29a, (q31_t)0xb8a46e78, (q31_t)0x6a4021c4, (q31_t)0xb89f3733, (q31_t)0x6a3ca0ad, (q31_t)0xb89a001a, + (q31_t)0x6a391f54, (q31_t)0xb894c92d, + (q31_t)0x6a359db9, (q31_t)0xb88f926d, (q31_t)0x6a321bdd, (q31_t)0xb88a5bd8, (q31_t)0x6a2e99c0, (q31_t)0xb885256f, + (q31_t)0x6a2b1761, (q31_t)0xb87fef33, + (q31_t)0x6a2794c1, (q31_t)0xb87ab922, (q31_t)0x6a2411df, (q31_t)0xb875833e, (q31_t)0x6a208ebb, (q31_t)0xb8704d85, + (q31_t)0x6a1d0b57, (q31_t)0xb86b17f9, + (q31_t)0x6a1987b0, (q31_t)0xb865e299, (q31_t)0x6a1603c8, (q31_t)0xb860ad66, (q31_t)0x6a127f9f, (q31_t)0xb85b785e, + (q31_t)0x6a0efb35, (q31_t)0xb8564383, + (q31_t)0x6a0b7689, (q31_t)0xb8510ed4, (q31_t)0x6a07f19b, (q31_t)0xb84bda51, (q31_t)0x6a046c6c, (q31_t)0xb846a5fa, + (q31_t)0x6a00e6fc, (q31_t)0xb84171cf, + (q31_t)0x69fd614a, (q31_t)0xb83c3dd1, (q31_t)0x69f9db57, (q31_t)0xb83709ff, (q31_t)0x69f65523, (q31_t)0xb831d659, + (q31_t)0x69f2cead, (q31_t)0xb82ca2e0, + (q31_t)0x69ef47f6, (q31_t)0xb8276f93, (q31_t)0x69ebc0fe, (q31_t)0xb8223c72, (q31_t)0x69e839c4, (q31_t)0xb81d097e, + (q31_t)0x69e4b249, (q31_t)0xb817d6b6, + (q31_t)0x69e12a8c, (q31_t)0xb812a41a, (q31_t)0x69dda28f, (q31_t)0xb80d71aa, (q31_t)0x69da1a50, (q31_t)0xb8083f67, + (q31_t)0x69d691cf, (q31_t)0xb8030d51, + (q31_t)0x69d3090e, (q31_t)0xb7fddb67, (q31_t)0x69cf800b, (q31_t)0xb7f8a9a9, (q31_t)0x69cbf6c7, (q31_t)0xb7f37818, + (q31_t)0x69c86d41, (q31_t)0xb7ee46b3, + (q31_t)0x69c4e37a, (q31_t)0xb7e9157a, (q31_t)0x69c15973, (q31_t)0xb7e3e46e, (q31_t)0x69bdcf29, (q31_t)0xb7deb38f, + (q31_t)0x69ba449f, (q31_t)0xb7d982dc, + (q31_t)0x69b6b9d3, (q31_t)0xb7d45255, (q31_t)0x69b32ec7, (q31_t)0xb7cf21fb, (q31_t)0x69afa378, (q31_t)0xb7c9f1ce, + (q31_t)0x69ac17e9, (q31_t)0xb7c4c1cd, + (q31_t)0x69a88c19, (q31_t)0xb7bf91f8, (q31_t)0x69a50007, (q31_t)0xb7ba6251, (q31_t)0x69a173b5, (q31_t)0xb7b532d6, + (q31_t)0x699de721, (q31_t)0xb7b00387, + (q31_t)0x699a5a4c, (q31_t)0xb7aad465, (q31_t)0x6996cd35, (q31_t)0xb7a5a570, (q31_t)0x69933fde, (q31_t)0xb7a076a7, + (q31_t)0x698fb246, (q31_t)0xb79b480b, + (q31_t)0x698c246c, (q31_t)0xb796199b, (q31_t)0x69889651, (q31_t)0xb790eb58, (q31_t)0x698507f6, (q31_t)0xb78bbd42, + (q31_t)0x69817959, (q31_t)0xb7868f59, + (q31_t)0x697dea7b, (q31_t)0xb781619c, (q31_t)0x697a5b5c, (q31_t)0xb77c340c, (q31_t)0x6976cbfc, (q31_t)0xb77706a9, + (q31_t)0x69733c5b, (q31_t)0xb771d972, + (q31_t)0x696fac78, (q31_t)0xb76cac69, (q31_t)0x696c1c55, (q31_t)0xb7677f8c, (q31_t)0x69688bf1, (q31_t)0xb76252db, + (q31_t)0x6964fb4c, (q31_t)0xb75d2658, + (q31_t)0x69616a65, (q31_t)0xb757fa01, (q31_t)0x695dd93e, (q31_t)0xb752cdd8, (q31_t)0x695a47d6, (q31_t)0xb74da1db, + (q31_t)0x6956b62d, (q31_t)0xb748760b, + (q31_t)0x69532442, (q31_t)0xb7434a67, (q31_t)0x694f9217, (q31_t)0xb73e1ef1, (q31_t)0x694bffab, (q31_t)0xb738f3a7, + (q31_t)0x69486cfe, (q31_t)0xb733c88b, + (q31_t)0x6944da10, (q31_t)0xb72e9d9b, (q31_t)0x694146e1, (q31_t)0xb72972d8, (q31_t)0x693db371, (q31_t)0xb7244842, + (q31_t)0x693a1fc0, (q31_t)0xb71f1dd9, + (q31_t)0x69368bce, (q31_t)0xb719f39e, (q31_t)0x6932f79b, (q31_t)0xb714c98e, (q31_t)0x692f6328, (q31_t)0xb70f9fac, + (q31_t)0x692bce73, (q31_t)0xb70a75f7, + (q31_t)0x6928397e, (q31_t)0xb7054c6f, (q31_t)0x6924a448, (q31_t)0xb7002314, (q31_t)0x69210ed1, (q31_t)0xb6faf9e6, + (q31_t)0x691d7919, (q31_t)0xb6f5d0e5, + (q31_t)0x6919e320, (q31_t)0xb6f0a812, (q31_t)0x69164ce7, (q31_t)0xb6eb7f6b, (q31_t)0x6912b66c, (q31_t)0xb6e656f1, + (q31_t)0x690f1fb1, (q31_t)0xb6e12ea4, + (q31_t)0x690b88b5, (q31_t)0xb6dc0685, (q31_t)0x6907f178, (q31_t)0xb6d6de92, (q31_t)0x690459fb, (q31_t)0xb6d1b6cd, + (q31_t)0x6900c23c, (q31_t)0xb6cc8f35, + (q31_t)0x68fd2a3d, (q31_t)0xb6c767ca, (q31_t)0x68f991fd, (q31_t)0xb6c2408c, (q31_t)0x68f5f97d, (q31_t)0xb6bd197c, + (q31_t)0x68f260bb, (q31_t)0xb6b7f298, + (q31_t)0x68eec7b9, (q31_t)0xb6b2cbe2, (q31_t)0x68eb2e76, (q31_t)0xb6ada559, (q31_t)0x68e794f3, (q31_t)0xb6a87efd, + (q31_t)0x68e3fb2e, (q31_t)0xb6a358ce, + (q31_t)0x68e06129, (q31_t)0xb69e32cd, (q31_t)0x68dcc6e4, (q31_t)0xb6990cf9, (q31_t)0x68d92c5d, (q31_t)0xb693e752, + (q31_t)0x68d59196, (q31_t)0xb68ec1d9, + (q31_t)0x68d1f68f, (q31_t)0xb6899c8d, (q31_t)0x68ce5b46, (q31_t)0xb684776e, (q31_t)0x68cabfbd, (q31_t)0xb67f527c, + (q31_t)0x68c723f3, (q31_t)0xb67a2db8, + (q31_t)0x68c387e9, (q31_t)0xb6750921, (q31_t)0x68bfeb9e, (q31_t)0xb66fe4b8, (q31_t)0x68bc4f13, (q31_t)0xb66ac07c, + (q31_t)0x68b8b247, (q31_t)0xb6659c6d, + (q31_t)0x68b5153a, (q31_t)0xb660788c, (q31_t)0x68b177ed, (q31_t)0xb65b54d8, (q31_t)0x68adda5f, (q31_t)0xb6563151, + (q31_t)0x68aa3c90, (q31_t)0xb6510df8, + (q31_t)0x68a69e81, (q31_t)0xb64beacd, (q31_t)0x68a30031, (q31_t)0xb646c7ce, (q31_t)0x689f61a1, (q31_t)0xb641a4fe, + (q31_t)0x689bc2d1, (q31_t)0xb63c825b, + (q31_t)0x689823bf, (q31_t)0xb6375fe5, (q31_t)0x6894846e, (q31_t)0xb6323d9d, (q31_t)0x6890e4dc, (q31_t)0xb62d1b82, + (q31_t)0x688d4509, (q31_t)0xb627f995, + (q31_t)0x6889a4f6, (q31_t)0xb622d7d6, (q31_t)0x688604a2, (q31_t)0xb61db644, (q31_t)0x6882640e, (q31_t)0xb61894df, + (q31_t)0x687ec339, (q31_t)0xb61373a9, + (q31_t)0x687b2224, (q31_t)0xb60e529f, (q31_t)0x687780ce, (q31_t)0xb60931c4, (q31_t)0x6873df38, (q31_t)0xb6041116, + (q31_t)0x68703d62, (q31_t)0xb5fef095, + (q31_t)0x686c9b4b, (q31_t)0xb5f9d043, (q31_t)0x6868f8f4, (q31_t)0xb5f4b01e, (q31_t)0x6865565c, (q31_t)0xb5ef9026, + (q31_t)0x6861b384, (q31_t)0xb5ea705d, + (q31_t)0x685e106c, (q31_t)0xb5e550c1, (q31_t)0x685a6d13, (q31_t)0xb5e03153, (q31_t)0x6856c979, (q31_t)0xb5db1212, + (q31_t)0x685325a0, (q31_t)0xb5d5f2ff, + (q31_t)0x684f8186, (q31_t)0xb5d0d41a, (q31_t)0x684bdd2c, (q31_t)0xb5cbb563, (q31_t)0x68483891, (q31_t)0xb5c696da, + (q31_t)0x684493b6, (q31_t)0xb5c1787e, + (q31_t)0x6840ee9b, (q31_t)0xb5bc5a50, (q31_t)0x683d493f, (q31_t)0xb5b73c50, (q31_t)0x6839a3a4, (q31_t)0xb5b21e7e, + (q31_t)0x6835fdc7, (q31_t)0xb5ad00d9, + (q31_t)0x683257ab, (q31_t)0xb5a7e362, (q31_t)0x682eb14e, (q31_t)0xb5a2c61a, (q31_t)0x682b0ab1, (q31_t)0xb59da8ff, + (q31_t)0x682763d4, (q31_t)0xb5988c12, + (q31_t)0x6823bcb7, (q31_t)0xb5936f53, (q31_t)0x68201559, (q31_t)0xb58e52c2, (q31_t)0x681c6dbb, (q31_t)0xb589365e, + (q31_t)0x6818c5dd, (q31_t)0xb5841a29, + (q31_t)0x68151dbe, (q31_t)0xb57efe22, (q31_t)0x68117560, (q31_t)0xb579e248, (q31_t)0x680dccc1, (q31_t)0xb574c69d, + (q31_t)0x680a23e2, (q31_t)0xb56fab1f, + (q31_t)0x68067ac3, (q31_t)0xb56a8fd0, (q31_t)0x6802d164, (q31_t)0xb56574ae, (q31_t)0x67ff27c4, (q31_t)0xb56059bb, + (q31_t)0x67fb7de5, (q31_t)0xb55b3ef5, + (q31_t)0x67f7d3c5, (q31_t)0xb556245e, (q31_t)0x67f42965, (q31_t)0xb55109f5, (q31_t)0x67f07ec5, (q31_t)0xb54befba, + (q31_t)0x67ecd3e5, (q31_t)0xb546d5ac, + (q31_t)0x67e928c5, (q31_t)0xb541bbcd, (q31_t)0x67e57d64, (q31_t)0xb53ca21c, (q31_t)0x67e1d1c4, (q31_t)0xb5378899, + (q31_t)0x67de25e3, (q31_t)0xb5326f45, + (q31_t)0x67da79c3, (q31_t)0xb52d561e, (q31_t)0x67d6cd62, (q31_t)0xb5283d26, (q31_t)0x67d320c1, (q31_t)0xb523245b, + (q31_t)0x67cf73e1, (q31_t)0xb51e0bbf, + (q31_t)0x67cbc6c0, (q31_t)0xb518f351, (q31_t)0x67c8195f, (q31_t)0xb513db12, (q31_t)0x67c46bbe, (q31_t)0xb50ec300, + (q31_t)0x67c0bddd, (q31_t)0xb509ab1d, + (q31_t)0x67bd0fbd, (q31_t)0xb5049368, (q31_t)0x67b9615c, (q31_t)0xb4ff7be1, (q31_t)0x67b5b2bb, (q31_t)0xb4fa6489, + (q31_t)0x67b203da, (q31_t)0xb4f54d5f, + (q31_t)0x67ae54ba, (q31_t)0xb4f03663, (q31_t)0x67aaa559, (q31_t)0xb4eb1f95, (q31_t)0x67a6f5b8, (q31_t)0xb4e608f6, + (q31_t)0x67a345d8, (q31_t)0xb4e0f285, + (q31_t)0x679f95b7, (q31_t)0xb4dbdc42, (q31_t)0x679be557, (q31_t)0xb4d6c62e, (q31_t)0x679834b6, (q31_t)0xb4d1b048, + (q31_t)0x679483d6, (q31_t)0xb4cc9a90, + (q31_t)0x6790d2b6, (q31_t)0xb4c78507, (q31_t)0x678d2156, (q31_t)0xb4c26fad, (q31_t)0x67896fb6, (q31_t)0xb4bd5a80, + (q31_t)0x6785bdd6, (q31_t)0xb4b84582, + (q31_t)0x67820bb7, (q31_t)0xb4b330b3, (q31_t)0x677e5957, (q31_t)0xb4ae1c12, (q31_t)0x677aa6b8, (q31_t)0xb4a9079f, + (q31_t)0x6776f3d9, (q31_t)0xb4a3f35b, + (q31_t)0x677340ba, (q31_t)0xb49edf45, (q31_t)0x676f8d5b, (q31_t)0xb499cb5e, (q31_t)0x676bd9bd, (q31_t)0xb494b7a6, + (q31_t)0x676825de, (q31_t)0xb48fa41c, + (q31_t)0x676471c0, (q31_t)0xb48a90c0, (q31_t)0x6760bd62, (q31_t)0xb4857d93, (q31_t)0x675d08c4, (q31_t)0xb4806a95, + (q31_t)0x675953e7, (q31_t)0xb47b57c5, + (q31_t)0x67559eca, (q31_t)0xb4764523, (q31_t)0x6751e96d, (q31_t)0xb47132b1, (q31_t)0x674e33d0, (q31_t)0xb46c206d, + (q31_t)0x674a7df4, (q31_t)0xb4670e57, + (q31_t)0x6746c7d8, (q31_t)0xb461fc70, (q31_t)0x6743117c, (q31_t)0xb45ceab8, (q31_t)0x673f5ae0, (q31_t)0xb457d92f, + (q31_t)0x673ba405, (q31_t)0xb452c7d4, + (q31_t)0x6737ecea, (q31_t)0xb44db6a8, (q31_t)0x67343590, (q31_t)0xb448a5aa, (q31_t)0x67307df5, (q31_t)0xb44394db, + (q31_t)0x672cc61c, (q31_t)0xb43e843b, + (q31_t)0x67290e02, (q31_t)0xb43973ca, (q31_t)0x672555a9, (q31_t)0xb4346387, (q31_t)0x67219d10, (q31_t)0xb42f5373, + (q31_t)0x671de438, (q31_t)0xb42a438e, + (q31_t)0x671a2b20, (q31_t)0xb42533d8, (q31_t)0x671671c8, (q31_t)0xb4202451, (q31_t)0x6712b831, (q31_t)0xb41b14f8, + (q31_t)0x670efe5a, (q31_t)0xb41605ce, + (q31_t)0x670b4444, (q31_t)0xb410f6d3, (q31_t)0x670789ee, (q31_t)0xb40be807, (q31_t)0x6703cf58, (q31_t)0xb406d969, + (q31_t)0x67001483, (q31_t)0xb401cafb, + (q31_t)0x66fc596f, (q31_t)0xb3fcbcbb, (q31_t)0x66f89e1b, (q31_t)0xb3f7aeaa, (q31_t)0x66f4e287, (q31_t)0xb3f2a0c9, + (q31_t)0x66f126b4, (q31_t)0xb3ed9316, + (q31_t)0x66ed6aa1, (q31_t)0xb3e88592, (q31_t)0x66e9ae4f, (q31_t)0xb3e3783d, (q31_t)0x66e5f1be, (q31_t)0xb3de6b17, + (q31_t)0x66e234ed, (q31_t)0xb3d95e1f, + (q31_t)0x66de77dc, (q31_t)0xb3d45157, (q31_t)0x66daba8c, (q31_t)0xb3cf44be, (q31_t)0x66d6fcfd, (q31_t)0xb3ca3854, + (q31_t)0x66d33f2e, (q31_t)0xb3c52c19, + (q31_t)0x66cf8120, (q31_t)0xb3c0200c, (q31_t)0x66cbc2d2, (q31_t)0xb3bb142f, (q31_t)0x66c80445, (q31_t)0xb3b60881, + (q31_t)0x66c44579, (q31_t)0xb3b0fd02, + (q31_t)0x66c0866d, (q31_t)0xb3abf1b2, (q31_t)0x66bcc721, (q31_t)0xb3a6e691, (q31_t)0x66b90797, (q31_t)0xb3a1dba0, + (q31_t)0x66b547cd, (q31_t)0xb39cd0dd, + (q31_t)0x66b187c3, (q31_t)0xb397c649, (q31_t)0x66adc77b, (q31_t)0xb392bbe5, (q31_t)0x66aa06f3, (q31_t)0xb38db1b0, + (q31_t)0x66a6462b, (q31_t)0xb388a7aa, + (q31_t)0x66a28524, (q31_t)0xb3839dd3, (q31_t)0x669ec3de, (q31_t)0xb37e942b, (q31_t)0x669b0259, (q31_t)0xb3798ab2, + (q31_t)0x66974095, (q31_t)0xb3748169, + (q31_t)0x66937e91, (q31_t)0xb36f784f, (q31_t)0x668fbc4e, (q31_t)0xb36a6f64, (q31_t)0x668bf9cb, (q31_t)0xb36566a8, + (q31_t)0x66883709, (q31_t)0xb3605e1c, + (q31_t)0x66847408, (q31_t)0xb35b55bf, (q31_t)0x6680b0c8, (q31_t)0xb3564d91, (q31_t)0x667ced49, (q31_t)0xb3514592, + (q31_t)0x6679298a, (q31_t)0xb34c3dc3, + (q31_t)0x6675658c, (q31_t)0xb3473623, (q31_t)0x6671a14f, (q31_t)0xb3422eb2, (q31_t)0x666ddcd3, (q31_t)0xb33d2771, + (q31_t)0x666a1818, (q31_t)0xb338205f, + (q31_t)0x6666531d, (q31_t)0xb333197c, (q31_t)0x66628de4, (q31_t)0xb32e12c9, (q31_t)0x665ec86b, (q31_t)0xb3290c45, + (q31_t)0x665b02b3, (q31_t)0xb32405f1, + (q31_t)0x66573cbb, (q31_t)0xb31effcc, (q31_t)0x66537685, (q31_t)0xb319f9d6, (q31_t)0x664fb010, (q31_t)0xb314f410, + (q31_t)0x664be95b, (q31_t)0xb30fee79, + (q31_t)0x66482267, (q31_t)0xb30ae912, (q31_t)0x66445b35, (q31_t)0xb305e3da, (q31_t)0x664093c3, (q31_t)0xb300ded2, + (q31_t)0x663ccc12, (q31_t)0xb2fbd9f9, + (q31_t)0x66390422, (q31_t)0xb2f6d550, (q31_t)0x66353bf3, (q31_t)0xb2f1d0d6, (q31_t)0x66317385, (q31_t)0xb2eccc8c, + (q31_t)0x662daad8, (q31_t)0xb2e7c871, + (q31_t)0x6629e1ec, (q31_t)0xb2e2c486, (q31_t)0x662618c1, (q31_t)0xb2ddc0ca, (q31_t)0x66224f56, (q31_t)0xb2d8bd3e, + (q31_t)0x661e85ad, (q31_t)0xb2d3b9e2, + (q31_t)0x661abbc5, (q31_t)0xb2ceb6b5, (q31_t)0x6616f19e, (q31_t)0xb2c9b3b8, (q31_t)0x66132738, (q31_t)0xb2c4b0ea, + (q31_t)0x660f5c93, (q31_t)0xb2bfae4c, + (q31_t)0x660b91af, (q31_t)0xb2baabde, (q31_t)0x6607c68c, (q31_t)0xb2b5a99f, (q31_t)0x6603fb2a, (q31_t)0xb2b0a790, + (q31_t)0x66002f89, (q31_t)0xb2aba5b1, + (q31_t)0x65fc63a9, (q31_t)0xb2a6a402, (q31_t)0x65f8978b, (q31_t)0xb2a1a282, (q31_t)0x65f4cb2d, (q31_t)0xb29ca132, + (q31_t)0x65f0fe91, (q31_t)0xb297a011, + (q31_t)0x65ed31b5, (q31_t)0xb2929f21, (q31_t)0x65e9649b, (q31_t)0xb28d9e60, (q31_t)0x65e59742, (q31_t)0xb2889dcf, + (q31_t)0x65e1c9aa, (q31_t)0xb2839d6d, + (q31_t)0x65ddfbd3, (q31_t)0xb27e9d3c, (q31_t)0x65da2dbd, (q31_t)0xb2799d3a, (q31_t)0x65d65f69, (q31_t)0xb2749d68, + (q31_t)0x65d290d6, (q31_t)0xb26f9dc6, + (q31_t)0x65cec204, (q31_t)0xb26a9e54, (q31_t)0x65caf2f3, (q31_t)0xb2659f12, (q31_t)0x65c723a3, (q31_t)0xb2609fff, + (q31_t)0x65c35415, (q31_t)0xb25ba11d, + (q31_t)0x65bf8447, (q31_t)0xb256a26a, (q31_t)0x65bbb43b, (q31_t)0xb251a3e7, (q31_t)0x65b7e3f1, (q31_t)0xb24ca594, + (q31_t)0x65b41367, (q31_t)0xb247a771, + (q31_t)0x65b0429f, (q31_t)0xb242a97e, (q31_t)0x65ac7198, (q31_t)0xb23dabbb, (q31_t)0x65a8a052, (q31_t)0xb238ae28, + (q31_t)0x65a4cece, (q31_t)0xb233b0c5, + (q31_t)0x65a0fd0b, (q31_t)0xb22eb392, (q31_t)0x659d2b09, (q31_t)0xb229b68f, (q31_t)0x659958c9, (q31_t)0xb224b9bc, + (q31_t)0x6595864a, (q31_t)0xb21fbd19, + (q31_t)0x6591b38c, (q31_t)0xb21ac0a6, (q31_t)0x658de08f, (q31_t)0xb215c463, (q31_t)0x658a0d54, (q31_t)0xb210c850, + (q31_t)0x658639db, (q31_t)0xb20bcc6d, + (q31_t)0x65826622, (q31_t)0xb206d0ba, (q31_t)0x657e922b, (q31_t)0xb201d537, (q31_t)0x657abdf6, (q31_t)0xb1fcd9e5, + (q31_t)0x6576e982, (q31_t)0xb1f7dec2, + (q31_t)0x657314cf, (q31_t)0xb1f2e3d0, (q31_t)0x656f3fde, (q31_t)0xb1ede90e, (q31_t)0x656b6aae, (q31_t)0xb1e8ee7c, + (q31_t)0x6567953f, (q31_t)0xb1e3f41a, + (q31_t)0x6563bf92, (q31_t)0xb1def9e9, (q31_t)0x655fe9a7, (q31_t)0xb1d9ffe7, (q31_t)0x655c137d, (q31_t)0xb1d50616, + (q31_t)0x65583d14, (q31_t)0xb1d00c75, + (q31_t)0x6554666d, (q31_t)0xb1cb1304, (q31_t)0x65508f87, (q31_t)0xb1c619c3, (q31_t)0x654cb863, (q31_t)0xb1c120b3, + (q31_t)0x6548e101, (q31_t)0xb1bc27d3, + (q31_t)0x6545095f, (q31_t)0xb1b72f23, (q31_t)0x65413180, (q31_t)0xb1b236a4, (q31_t)0x653d5962, (q31_t)0xb1ad3e55, + (q31_t)0x65398105, (q31_t)0xb1a84636, + (q31_t)0x6535a86b, (q31_t)0xb1a34e47, (q31_t)0x6531cf91, (q31_t)0xb19e5689, (q31_t)0x652df679, (q31_t)0xb1995efb, + (q31_t)0x652a1d23, (q31_t)0xb194679e, + (q31_t)0x6526438f, (q31_t)0xb18f7071, (q31_t)0x652269bc, (q31_t)0xb18a7974, (q31_t)0x651e8faa, (q31_t)0xb18582a8, + (q31_t)0x651ab55b, (q31_t)0xb1808c0c, + (q31_t)0x6516dacd, (q31_t)0xb17b95a0, (q31_t)0x65130000, (q31_t)0xb1769f65, (q31_t)0x650f24f5, (q31_t)0xb171a95b, + (q31_t)0x650b49ac, (q31_t)0xb16cb380, + (q31_t)0x65076e25, (q31_t)0xb167bdd7, (q31_t)0x6503925f, (q31_t)0xb162c85d, (q31_t)0x64ffb65b, (q31_t)0xb15dd315, + (q31_t)0x64fbda18, (q31_t)0xb158ddfd, + (q31_t)0x64f7fd98, (q31_t)0xb153e915, (q31_t)0x64f420d9, (q31_t)0xb14ef45e, (q31_t)0x64f043dc, (q31_t)0xb149ffd7, + (q31_t)0x64ec66a0, (q31_t)0xb1450b81, + (q31_t)0x64e88926, (q31_t)0xb140175b, (q31_t)0x64e4ab6e, (q31_t)0xb13b2367, (q31_t)0x64e0cd78, (q31_t)0xb1362fa2, + (q31_t)0x64dcef44, (q31_t)0xb1313c0e, + (q31_t)0x64d910d1, (q31_t)0xb12c48ab, (q31_t)0x64d53220, (q31_t)0xb1275579, (q31_t)0x64d15331, (q31_t)0xb1226277, + (q31_t)0x64cd7404, (q31_t)0xb11d6fa6, + (q31_t)0x64c99498, (q31_t)0xb1187d05, (q31_t)0x64c5b4ef, (q31_t)0xb1138a95, (q31_t)0x64c1d507, (q31_t)0xb10e9856, + (q31_t)0x64bdf4e1, (q31_t)0xb109a648, + (q31_t)0x64ba147d, (q31_t)0xb104b46a, (q31_t)0x64b633da, (q31_t)0xb0ffc2bd, (q31_t)0x64b252fa, (q31_t)0xb0fad140, + (q31_t)0x64ae71dc, (q31_t)0xb0f5dff5, + (q31_t)0x64aa907f, (q31_t)0xb0f0eeda, (q31_t)0x64a6aee4, (q31_t)0xb0ebfdf0, (q31_t)0x64a2cd0c, (q31_t)0xb0e70d37, + (q31_t)0x649eeaf5, (q31_t)0xb0e21cae, + (q31_t)0x649b08a0, (q31_t)0xb0dd2c56, (q31_t)0x6497260d, (q31_t)0xb0d83c2f, (q31_t)0x6493433c, (q31_t)0xb0d34c39, + (q31_t)0x648f602d, (q31_t)0xb0ce5c74, + (q31_t)0x648b7ce0, (q31_t)0xb0c96ce0, (q31_t)0x64879955, (q31_t)0xb0c47d7c, (q31_t)0x6483b58c, (q31_t)0xb0bf8e4a, + (q31_t)0x647fd185, (q31_t)0xb0ba9f48, + (q31_t)0x647bed3f, (q31_t)0xb0b5b077, (q31_t)0x647808bc, (q31_t)0xb0b0c1d7, (q31_t)0x647423fb, (q31_t)0xb0abd368, + (q31_t)0x64703efc, (q31_t)0xb0a6e52a, + (q31_t)0x646c59bf, (q31_t)0xb0a1f71d, (q31_t)0x64687444, (q31_t)0xb09d0941, (q31_t)0x64648e8c, (q31_t)0xb0981b96, + (q31_t)0x6460a895, (q31_t)0xb0932e1b, + (q31_t)0x645cc260, (q31_t)0xb08e40d2, (q31_t)0x6458dbed, (q31_t)0xb08953ba, (q31_t)0x6454f53d, (q31_t)0xb08466d3, + (q31_t)0x64510e4e, (q31_t)0xb07f7a1c, + (q31_t)0x644d2722, (q31_t)0xb07a8d97, (q31_t)0x64493fb8, (q31_t)0xb075a143, (q31_t)0x64455810, (q31_t)0xb070b520, + (q31_t)0x6441702a, (q31_t)0xb06bc92e, + (q31_t)0x643d8806, (q31_t)0xb066dd6d, (q31_t)0x64399fa5, (q31_t)0xb061f1de, (q31_t)0x6435b706, (q31_t)0xb05d067f, + (q31_t)0x6431ce28, (q31_t)0xb0581b51, + (q31_t)0x642de50d, (q31_t)0xb0533055, (q31_t)0x6429fbb5, (q31_t)0xb04e458a, (q31_t)0x6426121e, (q31_t)0xb0495af0, + (q31_t)0x6422284a, (q31_t)0xb0447087, + (q31_t)0x641e3e38, (q31_t)0xb03f864f, (q31_t)0x641a53e8, (q31_t)0xb03a9c49, (q31_t)0x6416695a, (q31_t)0xb035b273, + (q31_t)0x64127e8f, (q31_t)0xb030c8cf, + (q31_t)0x640e9386, (q31_t)0xb02bdf5c, (q31_t)0x640aa83f, (q31_t)0xb026f61b, (q31_t)0x6406bcba, (q31_t)0xb0220d0a, + (q31_t)0x6402d0f8, (q31_t)0xb01d242b, + (q31_t)0x63fee4f8, (q31_t)0xb0183b7d, (q31_t)0x63faf8bb, (q31_t)0xb0135301, (q31_t)0x63f70c3f, (q31_t)0xb00e6ab5, + (q31_t)0x63f31f86, (q31_t)0xb009829c, + (q31_t)0x63ef3290, (q31_t)0xb0049ab3, (q31_t)0x63eb455c, (q31_t)0xafffb2fc, (q31_t)0x63e757ea, (q31_t)0xaffacb76, + (q31_t)0x63e36a3a, (q31_t)0xaff5e421, + (q31_t)0x63df7c4d, (q31_t)0xaff0fcfe, (q31_t)0x63db8e22, (q31_t)0xafec160c, (q31_t)0x63d79fba, (q31_t)0xafe72f4c, + (q31_t)0x63d3b114, (q31_t)0xafe248bd, + (q31_t)0x63cfc231, (q31_t)0xafdd625f, (q31_t)0x63cbd310, (q31_t)0xafd87c33, (q31_t)0x63c7e3b1, (q31_t)0xafd39638, + (q31_t)0x63c3f415, (q31_t)0xafceb06f, + (q31_t)0x63c0043b, (q31_t)0xafc9cad7, (q31_t)0x63bc1424, (q31_t)0xafc4e571, (q31_t)0x63b823cf, (q31_t)0xafc0003c, + (q31_t)0x63b4333d, (q31_t)0xafbb1b39, + (q31_t)0x63b0426d, (q31_t)0xafb63667, (q31_t)0x63ac5160, (q31_t)0xafb151c7, (q31_t)0x63a86015, (q31_t)0xafac6d58, + (q31_t)0x63a46e8d, (q31_t)0xafa7891b, + (q31_t)0x63a07cc7, (q31_t)0xafa2a50f, (q31_t)0x639c8ac4, (q31_t)0xaf9dc135, (q31_t)0x63989884, (q31_t)0xaf98dd8d, + (q31_t)0x6394a606, (q31_t)0xaf93fa16, + (q31_t)0x6390b34a, (q31_t)0xaf8f16d1, (q31_t)0x638cc051, (q31_t)0xaf8a33bd, (q31_t)0x6388cd1b, (q31_t)0xaf8550db, + (q31_t)0x6384d9a7, (q31_t)0xaf806e2b, + (q31_t)0x6380e5f6, (q31_t)0xaf7b8bac, (q31_t)0x637cf208, (q31_t)0xaf76a95f, (q31_t)0x6378fddc, (q31_t)0xaf71c743, + (q31_t)0x63750973, (q31_t)0xaf6ce55a, + (q31_t)0x637114cc, (q31_t)0xaf6803a2, (q31_t)0x636d1fe9, (q31_t)0xaf63221c, (q31_t)0x63692ac7, (q31_t)0xaf5e40c7, + (q31_t)0x63653569, (q31_t)0xaf595fa4, + (q31_t)0x63613fcd, (q31_t)0xaf547eb3, (q31_t)0x635d49f4, (q31_t)0xaf4f9df4, (q31_t)0x635953dd, (q31_t)0xaf4abd66, + (q31_t)0x63555d8a, (q31_t)0xaf45dd0b, + (q31_t)0x635166f9, (q31_t)0xaf40fce1, (q31_t)0x634d702b, (q31_t)0xaf3c1ce9, (q31_t)0x6349791f, (q31_t)0xaf373d22, + (q31_t)0x634581d6, (q31_t)0xaf325d8e, + (q31_t)0x63418a50, (q31_t)0xaf2d7e2b, (q31_t)0x633d928d, (q31_t)0xaf289efa, (q31_t)0x63399a8d, (q31_t)0xaf23bffb, + (q31_t)0x6335a24f, (q31_t)0xaf1ee12e, + (q31_t)0x6331a9d4, (q31_t)0xaf1a0293, (q31_t)0x632db11c, (q31_t)0xaf15242a, (q31_t)0x6329b827, (q31_t)0xaf1045f3, + (q31_t)0x6325bef5, (q31_t)0xaf0b67ed, + (q31_t)0x6321c585, (q31_t)0xaf068a1a, (q31_t)0x631dcbd9, (q31_t)0xaf01ac78, (q31_t)0x6319d1ef, (q31_t)0xaefccf09, + (q31_t)0x6315d7c8, (q31_t)0xaef7f1cb, + (q31_t)0x6311dd64, (q31_t)0xaef314c0, (q31_t)0x630de2c3, (q31_t)0xaeee37e6, (q31_t)0x6309e7e4, (q31_t)0xaee95b3f, + (q31_t)0x6305ecc9, (q31_t)0xaee47ec9, + (q31_t)0x6301f171, (q31_t)0xaedfa285, (q31_t)0x62fdf5db, (q31_t)0xaedac674, (q31_t)0x62f9fa09, (q31_t)0xaed5ea95, + (q31_t)0x62f5fdf9, (q31_t)0xaed10ee7, + (q31_t)0x62f201ac, (q31_t)0xaecc336c, (q31_t)0x62ee0523, (q31_t)0xaec75823, (q31_t)0x62ea085c, (q31_t)0xaec27d0c, + (q31_t)0x62e60b58, (q31_t)0xaebda227, + (q31_t)0x62e20e17, (q31_t)0xaeb8c774, (q31_t)0x62de109a, (q31_t)0xaeb3ecf3, (q31_t)0x62da12df, (q31_t)0xaeaf12a4, + (q31_t)0x62d614e7, (q31_t)0xaeaa3888, + (q31_t)0x62d216b3, (q31_t)0xaea55e9e, (q31_t)0x62ce1841, (q31_t)0xaea084e6, (q31_t)0x62ca1992, (q31_t)0xae9bab60, + (q31_t)0x62c61aa7, (q31_t)0xae96d20c, + (q31_t)0x62c21b7e, (q31_t)0xae91f8eb, (q31_t)0x62be1c19, (q31_t)0xae8d1ffb, (q31_t)0x62ba1c77, (q31_t)0xae88473e, + (q31_t)0x62b61c98, (q31_t)0xae836eb4, + (q31_t)0x62b21c7b, (q31_t)0xae7e965b, (q31_t)0x62ae1c23, (q31_t)0xae79be35, (q31_t)0x62aa1b8d, (q31_t)0xae74e641, + (q31_t)0x62a61aba, (q31_t)0xae700e80, + (q31_t)0x62a219aa, (q31_t)0xae6b36f0, (q31_t)0x629e185e, (q31_t)0xae665f93, (q31_t)0x629a16d5, (q31_t)0xae618869, + (q31_t)0x6296150f, (q31_t)0xae5cb171, + (q31_t)0x6292130c, (q31_t)0xae57daab, (q31_t)0x628e10cc, (q31_t)0xae530417, (q31_t)0x628a0e50, (q31_t)0xae4e2db6, + (q31_t)0x62860b97, (q31_t)0xae495787, + (q31_t)0x628208a1, (q31_t)0xae44818b, (q31_t)0x627e056e, (q31_t)0xae3fabc1, (q31_t)0x627a01fe, (q31_t)0xae3ad629, + (q31_t)0x6275fe52, (q31_t)0xae3600c4, + (q31_t)0x6271fa69, (q31_t)0xae312b92, (q31_t)0x626df643, (q31_t)0xae2c5691, (q31_t)0x6269f1e1, (q31_t)0xae2781c4, + (q31_t)0x6265ed42, (q31_t)0xae22ad29, + (q31_t)0x6261e866, (q31_t)0xae1dd8c0, (q31_t)0x625de34e, (q31_t)0xae19048a, (q31_t)0x6259ddf8, (q31_t)0xae143086, + (q31_t)0x6255d866, (q31_t)0xae0f5cb5, + (q31_t)0x6251d298, (q31_t)0xae0a8916, (q31_t)0x624dcc8d, (q31_t)0xae05b5aa, (q31_t)0x6249c645, (q31_t)0xae00e271, + (q31_t)0x6245bfc0, (q31_t)0xadfc0f6a, + (q31_t)0x6241b8ff, (q31_t)0xadf73c96, (q31_t)0x623db202, (q31_t)0xadf269f4, (q31_t)0x6239aac7, (q31_t)0xaded9785, + (q31_t)0x6235a351, (q31_t)0xade8c548, + (q31_t)0x62319b9d, (q31_t)0xade3f33e, (q31_t)0x622d93ad, (q31_t)0xaddf2167, (q31_t)0x62298b81, (q31_t)0xadda4fc3, + (q31_t)0x62258317, (q31_t)0xadd57e51, + (q31_t)0x62217a72, (q31_t)0xadd0ad12, (q31_t)0x621d7190, (q31_t)0xadcbdc05, (q31_t)0x62196871, (q31_t)0xadc70b2c, + (q31_t)0x62155f16, (q31_t)0xadc23a85, + (q31_t)0x6211557e, (q31_t)0xadbd6a10, (q31_t)0x620d4baa, (q31_t)0xadb899cf, (q31_t)0x62094199, (q31_t)0xadb3c9c0, + (q31_t)0x6205374c, (q31_t)0xadaef9e4, + (q31_t)0x62012cc2, (q31_t)0xadaa2a3b, (q31_t)0x61fd21fc, (q31_t)0xada55ac4, (q31_t)0x61f916f9, (q31_t)0xada08b80, + (q31_t)0x61f50bba, (q31_t)0xad9bbc70, + (q31_t)0x61f1003f, (q31_t)0xad96ed92, (q31_t)0x61ecf487, (q31_t)0xad921ee6, (q31_t)0x61e8e893, (q31_t)0xad8d506e, + (q31_t)0x61e4dc62, (q31_t)0xad888229, + (q31_t)0x61e0cff5, (q31_t)0xad83b416, (q31_t)0x61dcc34c, (q31_t)0xad7ee636, (q31_t)0x61d8b666, (q31_t)0xad7a1889, + (q31_t)0x61d4a944, (q31_t)0xad754b0f, + (q31_t)0x61d09be5, (q31_t)0xad707dc8, (q31_t)0x61cc8e4b, (q31_t)0xad6bb0b4, (q31_t)0x61c88074, (q31_t)0xad66e3d3, + (q31_t)0x61c47260, (q31_t)0xad621725, + (q31_t)0x61c06410, (q31_t)0xad5d4aaa, (q31_t)0x61bc5584, (q31_t)0xad587e61, (q31_t)0x61b846bc, (q31_t)0xad53b24c, + (q31_t)0x61b437b7, (q31_t)0xad4ee66a, + (q31_t)0x61b02876, (q31_t)0xad4a1aba, (q31_t)0x61ac18f9, (q31_t)0xad454f3e, (q31_t)0x61a80940, (q31_t)0xad4083f5, + (q31_t)0x61a3f94a, (q31_t)0xad3bb8df, + (q31_t)0x619fe918, (q31_t)0xad36edfc, (q31_t)0x619bd8aa, (q31_t)0xad32234b, (q31_t)0x6197c800, (q31_t)0xad2d58ce, + (q31_t)0x6193b719, (q31_t)0xad288e85, + (q31_t)0x618fa5f7, (q31_t)0xad23c46e, (q31_t)0x618b9498, (q31_t)0xad1efa8a, (q31_t)0x618782fd, (q31_t)0xad1a30d9, + (q31_t)0x61837126, (q31_t)0xad15675c, + (q31_t)0x617f5f12, (q31_t)0xad109e12, (q31_t)0x617b4cc3, (q31_t)0xad0bd4fb, (q31_t)0x61773a37, (q31_t)0xad070c17, + (q31_t)0x61732770, (q31_t)0xad024366, + (q31_t)0x616f146c, (q31_t)0xacfd7ae8, (q31_t)0x616b012c, (q31_t)0xacf8b29e, (q31_t)0x6166edb0, (q31_t)0xacf3ea87, + (q31_t)0x6162d9f8, (q31_t)0xacef22a3, + (q31_t)0x615ec603, (q31_t)0xacea5af2, (q31_t)0x615ab1d3, (q31_t)0xace59375, (q31_t)0x61569d67, (q31_t)0xace0cc2b, + (q31_t)0x615288be, (q31_t)0xacdc0514, + (q31_t)0x614e73da, (q31_t)0xacd73e30, (q31_t)0x614a5eba, (q31_t)0xacd27780, (q31_t)0x6146495d, (q31_t)0xaccdb103, + (q31_t)0x614233c5, (q31_t)0xacc8eab9, + (q31_t)0x613e1df0, (q31_t)0xacc424a3, (q31_t)0x613a07e0, (q31_t)0xacbf5ec0, (q31_t)0x6135f193, (q31_t)0xacba9910, + (q31_t)0x6131db0b, (q31_t)0xacb5d394, + (q31_t)0x612dc447, (q31_t)0xacb10e4b, (q31_t)0x6129ad46, (q31_t)0xacac4935, (q31_t)0x6125960a, (q31_t)0xaca78453, + (q31_t)0x61217e92, (q31_t)0xaca2bfa4, + (q31_t)0x611d66de, (q31_t)0xac9dfb29, (q31_t)0x61194eee, (q31_t)0xac9936e1, (q31_t)0x611536c2, (q31_t)0xac9472cd, + (q31_t)0x61111e5b, (q31_t)0xac8faeec, + (q31_t)0x610d05b7, (q31_t)0xac8aeb3e, (q31_t)0x6108ecd8, (q31_t)0xac8627c4, (q31_t)0x6104d3bc, (q31_t)0xac81647e, + (q31_t)0x6100ba65, (q31_t)0xac7ca16b, + (q31_t)0x60fca0d2, (q31_t)0xac77de8b, (q31_t)0x60f88703, (q31_t)0xac731bdf, (q31_t)0x60f46cf9, (q31_t)0xac6e5967, + (q31_t)0x60f052b2, (q31_t)0xac699722, + (q31_t)0x60ec3830, (q31_t)0xac64d510, (q31_t)0x60e81d72, (q31_t)0xac601333, (q31_t)0x60e40278, (q31_t)0xac5b5189, + (q31_t)0x60dfe743, (q31_t)0xac569012, + (q31_t)0x60dbcbd1, (q31_t)0xac51cecf, (q31_t)0x60d7b024, (q31_t)0xac4d0dc0, (q31_t)0x60d3943b, (q31_t)0xac484ce4, + (q31_t)0x60cf7817, (q31_t)0xac438c3c, + (q31_t)0x60cb5bb7, (q31_t)0xac3ecbc7, (q31_t)0x60c73f1b, (q31_t)0xac3a0b87, (q31_t)0x60c32243, (q31_t)0xac354b7a, + (q31_t)0x60bf0530, (q31_t)0xac308ba0, + (q31_t)0x60bae7e1, (q31_t)0xac2bcbfa, (q31_t)0x60b6ca56, (q31_t)0xac270c88, (q31_t)0x60b2ac8f, (q31_t)0xac224d4a, + (q31_t)0x60ae8e8d, (q31_t)0xac1d8e40, + (q31_t)0x60aa7050, (q31_t)0xac18cf69, (q31_t)0x60a651d7, (q31_t)0xac1410c6, (q31_t)0x60a23322, (q31_t)0xac0f5256, + (q31_t)0x609e1431, (q31_t)0xac0a941b, + (q31_t)0x6099f505, (q31_t)0xac05d613, (q31_t)0x6095d59d, (q31_t)0xac01183f, (q31_t)0x6091b5fa, (q31_t)0xabfc5a9f, + (q31_t)0x608d961b, (q31_t)0xabf79d33, + (q31_t)0x60897601, (q31_t)0xabf2dffb, (q31_t)0x608555ab, (q31_t)0xabee22f6, (q31_t)0x60813519, (q31_t)0xabe96625, + (q31_t)0x607d144c, (q31_t)0xabe4a988, + (q31_t)0x6078f344, (q31_t)0xabdfed1f, (q31_t)0x6074d200, (q31_t)0xabdb30ea, (q31_t)0x6070b080, (q31_t)0xabd674e9, + (q31_t)0x606c8ec5, (q31_t)0xabd1b91c, + (q31_t)0x60686ccf, (q31_t)0xabccfd83, (q31_t)0x60644a9d, (q31_t)0xabc8421d, (q31_t)0x6060282f, (q31_t)0xabc386ec, + (q31_t)0x605c0587, (q31_t)0xabbecbee, + (q31_t)0x6057e2a2, (q31_t)0xabba1125, (q31_t)0x6053bf82, (q31_t)0xabb5568f, (q31_t)0x604f9c27, (q31_t)0xabb09c2e, + (q31_t)0x604b7891, (q31_t)0xababe200, + (q31_t)0x604754bf, (q31_t)0xaba72807, (q31_t)0x604330b1, (q31_t)0xaba26e41, (q31_t)0x603f0c69, (q31_t)0xab9db4b0, + (q31_t)0x603ae7e5, (q31_t)0xab98fb52, + (q31_t)0x6036c325, (q31_t)0xab944229, (q31_t)0x60329e2a, (q31_t)0xab8f8934, (q31_t)0x602e78f4, (q31_t)0xab8ad073, + (q31_t)0x602a5383, (q31_t)0xab8617e6, + (q31_t)0x60262dd6, (q31_t)0xab815f8d, (q31_t)0x602207ee, (q31_t)0xab7ca768, (q31_t)0x601de1ca, (q31_t)0xab77ef77, + (q31_t)0x6019bb6b, (q31_t)0xab7337bb, + (q31_t)0x601594d1, (q31_t)0xab6e8032, (q31_t)0x60116dfc, (q31_t)0xab69c8de, (q31_t)0x600d46ec, (q31_t)0xab6511be, + (q31_t)0x60091fa0, (q31_t)0xab605ad2, + (q31_t)0x6004f819, (q31_t)0xab5ba41a, (q31_t)0x6000d057, (q31_t)0xab56ed97, (q31_t)0x5ffca859, (q31_t)0xab523748, + (q31_t)0x5ff88021, (q31_t)0xab4d812d, + (q31_t)0x5ff457ad, (q31_t)0xab48cb46, (q31_t)0x5ff02efe, (q31_t)0xab441593, (q31_t)0x5fec0613, (q31_t)0xab3f6015, + (q31_t)0x5fe7dcee, (q31_t)0xab3aaacb, + (q31_t)0x5fe3b38d, (q31_t)0xab35f5b5, (q31_t)0x5fdf89f2, (q31_t)0xab3140d4, (q31_t)0x5fdb601b, (q31_t)0xab2c8c27, + (q31_t)0x5fd73609, (q31_t)0xab27d7ae, + (q31_t)0x5fd30bbc, (q31_t)0xab23236a, (q31_t)0x5fcee133, (q31_t)0xab1e6f5a, (q31_t)0x5fcab670, (q31_t)0xab19bb7e, + (q31_t)0x5fc68b72, (q31_t)0xab1507d7, + (q31_t)0x5fc26038, (q31_t)0xab105464, (q31_t)0x5fbe34c4, (q31_t)0xab0ba125, (q31_t)0x5fba0914, (q31_t)0xab06ee1b, + (q31_t)0x5fb5dd29, (q31_t)0xab023b46, + (q31_t)0x5fb1b104, (q31_t)0xaafd88a4, (q31_t)0x5fad84a3, (q31_t)0xaaf8d637, (q31_t)0x5fa95807, (q31_t)0xaaf423ff, + (q31_t)0x5fa52b31, (q31_t)0xaaef71fb, + (q31_t)0x5fa0fe1f, (q31_t)0xaaeac02c, (q31_t)0x5f9cd0d2, (q31_t)0xaae60e91, (q31_t)0x5f98a34a, (q31_t)0xaae15d2a, + (q31_t)0x5f947588, (q31_t)0xaadcabf8, + (q31_t)0x5f90478a, (q31_t)0xaad7fafb, (q31_t)0x5f8c1951, (q31_t)0xaad34a32, (q31_t)0x5f87eade, (q31_t)0xaace999d, + (q31_t)0x5f83bc2f, (q31_t)0xaac9e93e, + (q31_t)0x5f7f8d46, (q31_t)0xaac53912, (q31_t)0x5f7b5e22, (q31_t)0xaac0891c, (q31_t)0x5f772ec2, (q31_t)0xaabbd959, + (q31_t)0x5f72ff28, (q31_t)0xaab729cc, + (q31_t)0x5f6ecf53, (q31_t)0xaab27a73, (q31_t)0x5f6a9f44, (q31_t)0xaaadcb4f, (q31_t)0x5f666ef9, (q31_t)0xaaa91c5f, + (q31_t)0x5f623e73, (q31_t)0xaaa46da4, + (q31_t)0x5f5e0db3, (q31_t)0xaa9fbf1e, (q31_t)0x5f59dcb8, (q31_t)0xaa9b10cc, (q31_t)0x5f55ab82, (q31_t)0xaa9662af, + (q31_t)0x5f517a11, (q31_t)0xaa91b4c7, + (q31_t)0x5f4d4865, (q31_t)0xaa8d0713, (q31_t)0x5f49167f, (q31_t)0xaa885994, (q31_t)0x5f44e45e, (q31_t)0xaa83ac4a, + (q31_t)0x5f40b202, (q31_t)0xaa7eff34, + (q31_t)0x5f3c7f6b, (q31_t)0xaa7a5253, (q31_t)0x5f384c9a, (q31_t)0xaa75a5a8, (q31_t)0x5f34198e, (q31_t)0xaa70f930, + (q31_t)0x5f2fe647, (q31_t)0xaa6c4cee, + (q31_t)0x5f2bb2c5, (q31_t)0xaa67a0e0, (q31_t)0x5f277f09, (q31_t)0xaa62f507, (q31_t)0x5f234b12, (q31_t)0xaa5e4963, + (q31_t)0x5f1f16e0, (q31_t)0xaa599df4, + (q31_t)0x5f1ae274, (q31_t)0xaa54f2ba, (q31_t)0x5f16adcc, (q31_t)0xaa5047b4, (q31_t)0x5f1278eb, (q31_t)0xaa4b9ce3, + (q31_t)0x5f0e43ce, (q31_t)0xaa46f248, + (q31_t)0x5f0a0e77, (q31_t)0xaa4247e1, (q31_t)0x5f05d8e6, (q31_t)0xaa3d9daf, (q31_t)0x5f01a31a, (q31_t)0xaa38f3b1, + (q31_t)0x5efd6d13, (q31_t)0xaa3449e9, + (q31_t)0x5ef936d1, (q31_t)0xaa2fa056, (q31_t)0x5ef50055, (q31_t)0xaa2af6f7, (q31_t)0x5ef0c99f, (q31_t)0xaa264dce, + (q31_t)0x5eec92ae, (q31_t)0xaa21a4d9, + (q31_t)0x5ee85b82, (q31_t)0xaa1cfc1a, (q31_t)0x5ee4241c, (q31_t)0xaa18538f, (q31_t)0x5edfec7b, (q31_t)0xaa13ab3a, + (q31_t)0x5edbb49f, (q31_t)0xaa0f0319, + (q31_t)0x5ed77c8a, (q31_t)0xaa0a5b2e, (q31_t)0x5ed34439, (q31_t)0xaa05b377, (q31_t)0x5ecf0baf, (q31_t)0xaa010bf6, + (q31_t)0x5ecad2e9, (q31_t)0xa9fc64a9, + (q31_t)0x5ec699e9, (q31_t)0xa9f7bd92, (q31_t)0x5ec260af, (q31_t)0xa9f316b0, (q31_t)0x5ebe273b, (q31_t)0xa9ee7002, + (q31_t)0x5eb9ed8b, (q31_t)0xa9e9c98a, + (q31_t)0x5eb5b3a2, (q31_t)0xa9e52347, (q31_t)0x5eb1797e, (q31_t)0xa9e07d39, (q31_t)0x5ead3f1f, (q31_t)0xa9dbd761, + (q31_t)0x5ea90487, (q31_t)0xa9d731bd, + (q31_t)0x5ea4c9b3, (q31_t)0xa9d28c4e, (q31_t)0x5ea08ea6, (q31_t)0xa9cde715, (q31_t)0x5e9c535e, (q31_t)0xa9c94211, + (q31_t)0x5e9817dc, (q31_t)0xa9c49d42, + (q31_t)0x5e93dc1f, (q31_t)0xa9bff8a8, (q31_t)0x5e8fa028, (q31_t)0xa9bb5444, (q31_t)0x5e8b63f7, (q31_t)0xa9b6b014, + (q31_t)0x5e87278b, (q31_t)0xa9b20c1a, + (q31_t)0x5e82eae5, (q31_t)0xa9ad6855, (q31_t)0x5e7eae05, (q31_t)0xa9a8c4c5, (q31_t)0x5e7a70ea, (q31_t)0xa9a4216b, + (q31_t)0x5e763395, (q31_t)0xa99f7e46, + (q31_t)0x5e71f606, (q31_t)0xa99adb56, (q31_t)0x5e6db83d, (q31_t)0xa996389b, (q31_t)0x5e697a39, (q31_t)0xa9919616, + (q31_t)0x5e653bfc, (q31_t)0xa98cf3c6, + (q31_t)0x5e60fd84, (q31_t)0xa98851ac, (q31_t)0x5e5cbed1, (q31_t)0xa983afc6, (q31_t)0x5e587fe5, (q31_t)0xa97f0e16, + (q31_t)0x5e5440be, (q31_t)0xa97a6c9c, + (q31_t)0x5e50015d, (q31_t)0xa975cb57, (q31_t)0x5e4bc1c2, (q31_t)0xa9712a47, (q31_t)0x5e4781ed, (q31_t)0xa96c896c, + (q31_t)0x5e4341de, (q31_t)0xa967e8c7, + (q31_t)0x5e3f0194, (q31_t)0xa9634858, (q31_t)0x5e3ac110, (q31_t)0xa95ea81d, (q31_t)0x5e368053, (q31_t)0xa95a0819, + (q31_t)0x5e323f5b, (q31_t)0xa9556849, + (q31_t)0x5e2dfe29, (q31_t)0xa950c8b0, (q31_t)0x5e29bcbd, (q31_t)0xa94c294b, (q31_t)0x5e257b17, (q31_t)0xa9478a1c, + (q31_t)0x5e213936, (q31_t)0xa942eb23, + (q31_t)0x5e1cf71c, (q31_t)0xa93e4c5f, (q31_t)0x5e18b4c8, (q31_t)0xa939add1, (q31_t)0x5e147239, (q31_t)0xa9350f78, + (q31_t)0x5e102f71, (q31_t)0xa9307155, + (q31_t)0x5e0bec6e, (q31_t)0xa92bd367, (q31_t)0x5e07a932, (q31_t)0xa92735af, (q31_t)0x5e0365bb, (q31_t)0xa922982c, + (q31_t)0x5dff220b, (q31_t)0xa91dfadf, + (q31_t)0x5dfade20, (q31_t)0xa9195dc7, (q31_t)0x5df699fc, (q31_t)0xa914c0e6, (q31_t)0x5df2559e, (q31_t)0xa9102439, + (q31_t)0x5dee1105, (q31_t)0xa90b87c3, + (q31_t)0x5de9cc33, (q31_t)0xa906eb82, (q31_t)0x5de58727, (q31_t)0xa9024f76, (q31_t)0x5de141e1, (q31_t)0xa8fdb3a1, + (q31_t)0x5ddcfc61, (q31_t)0xa8f91801, + (q31_t)0x5dd8b6a7, (q31_t)0xa8f47c97, (q31_t)0x5dd470b3, (q31_t)0xa8efe162, (q31_t)0x5dd02a85, (q31_t)0xa8eb4663, + (q31_t)0x5dcbe41d, (q31_t)0xa8e6ab9a, + (q31_t)0x5dc79d7c, (q31_t)0xa8e21106, (q31_t)0x5dc356a1, (q31_t)0xa8dd76a9, (q31_t)0x5dbf0f8c, (q31_t)0xa8d8dc81, + (q31_t)0x5dbac83d, (q31_t)0xa8d4428f, + (q31_t)0x5db680b4, (q31_t)0xa8cfa8d2, (q31_t)0x5db238f1, (q31_t)0xa8cb0f4b, (q31_t)0x5dadf0f5, (q31_t)0xa8c675fb, + (q31_t)0x5da9a8bf, (q31_t)0xa8c1dce0, + (q31_t)0x5da5604f, (q31_t)0xa8bd43fa, (q31_t)0x5da117a5, (q31_t)0xa8b8ab4b, (q31_t)0x5d9ccec2, (q31_t)0xa8b412d1, + (q31_t)0x5d9885a5, (q31_t)0xa8af7a8e, + (q31_t)0x5d943c4e, (q31_t)0xa8aae280, (q31_t)0x5d8ff2bd, (q31_t)0xa8a64aa8, (q31_t)0x5d8ba8f3, (q31_t)0xa8a1b306, + (q31_t)0x5d875eef, (q31_t)0xa89d1b99, + (q31_t)0x5d8314b1, (q31_t)0xa8988463, (q31_t)0x5d7eca39, (q31_t)0xa893ed63, (q31_t)0x5d7a7f88, (q31_t)0xa88f5698, + (q31_t)0x5d76349d, (q31_t)0xa88ac004, + (q31_t)0x5d71e979, (q31_t)0xa88629a5, (q31_t)0x5d6d9e1b, (q31_t)0xa881937c, (q31_t)0x5d695283, (q31_t)0xa87cfd8a, + (q31_t)0x5d6506b2, (q31_t)0xa87867cd, + (q31_t)0x5d60baa7, (q31_t)0xa873d246, (q31_t)0x5d5c6e62, (q31_t)0xa86f3cf6, (q31_t)0x5d5821e4, (q31_t)0xa86aa7db, + (q31_t)0x5d53d52d, (q31_t)0xa86612f6, + (q31_t)0x5d4f883b, (q31_t)0xa8617e48, (q31_t)0x5d4b3b10, (q31_t)0xa85ce9cf, (q31_t)0x5d46edac, (q31_t)0xa858558d, + (q31_t)0x5d42a00e, (q31_t)0xa853c180, + (q31_t)0x5d3e5237, (q31_t)0xa84f2daa, (q31_t)0x5d3a0426, (q31_t)0xa84a9a0a, (q31_t)0x5d35b5db, (q31_t)0xa84606a0, + (q31_t)0x5d316757, (q31_t)0xa841736c, + (q31_t)0x5d2d189a, (q31_t)0xa83ce06e, (q31_t)0x5d28c9a3, (q31_t)0xa8384da6, (q31_t)0x5d247a72, (q31_t)0xa833bb14, + (q31_t)0x5d202b09, (q31_t)0xa82f28b9, + (q31_t)0x5d1bdb65, (q31_t)0xa82a9693, (q31_t)0x5d178b89, (q31_t)0xa82604a4, (q31_t)0x5d133b72, (q31_t)0xa82172eb, + (q31_t)0x5d0eeb23, (q31_t)0xa81ce169, + (q31_t)0x5d0a9a9a, (q31_t)0xa818501c, (q31_t)0x5d0649d7, (q31_t)0xa813bf06, (q31_t)0x5d01f8dc, (q31_t)0xa80f2e26, + (q31_t)0x5cfda7a7, (q31_t)0xa80a9d7c, + (q31_t)0x5cf95638, (q31_t)0xa8060d08, (q31_t)0x5cf50490, (q31_t)0xa8017ccb, (q31_t)0x5cf0b2af, (q31_t)0xa7fcecc4, + (q31_t)0x5cec6095, (q31_t)0xa7f85cf3, + (q31_t)0x5ce80e41, (q31_t)0xa7f3cd59, (q31_t)0x5ce3bbb4, (q31_t)0xa7ef3df5, (q31_t)0x5cdf68ed, (q31_t)0xa7eaaec7, + (q31_t)0x5cdb15ed, (q31_t)0xa7e61fd0, + (q31_t)0x5cd6c2b5, (q31_t)0xa7e1910f, (q31_t)0x5cd26f42, (q31_t)0xa7dd0284, (q31_t)0x5cce1b97, (q31_t)0xa7d8742f, + (q31_t)0x5cc9c7b2, (q31_t)0xa7d3e611, + (q31_t)0x5cc57394, (q31_t)0xa7cf582a, (q31_t)0x5cc11f3d, (q31_t)0xa7caca79, (q31_t)0x5cbccaac, (q31_t)0xa7c63cfe, + (q31_t)0x5cb875e3, (q31_t)0xa7c1afb9, + (q31_t)0x5cb420e0, (q31_t)0xa7bd22ac, (q31_t)0x5cafcba4, (q31_t)0xa7b895d4, (q31_t)0x5cab762f, (q31_t)0xa7b40933, + (q31_t)0x5ca72080, (q31_t)0xa7af7cc8, + (q31_t)0x5ca2ca99, (q31_t)0xa7aaf094, (q31_t)0x5c9e7478, (q31_t)0xa7a66497, (q31_t)0x5c9a1e1e, (q31_t)0xa7a1d8d0, + (q31_t)0x5c95c78b, (q31_t)0xa79d4d3f, + (q31_t)0x5c9170bf, (q31_t)0xa798c1e5, (q31_t)0x5c8d19ba, (q31_t)0xa79436c1, (q31_t)0x5c88c27c, (q31_t)0xa78fabd4, + (q31_t)0x5c846b05, (q31_t)0xa78b211e, + (q31_t)0x5c801354, (q31_t)0xa786969e, (q31_t)0x5c7bbb6b, (q31_t)0xa7820c55, (q31_t)0x5c776348, (q31_t)0xa77d8242, + (q31_t)0x5c730aed, (q31_t)0xa778f866, + (q31_t)0x5c6eb258, (q31_t)0xa7746ec0, (q31_t)0x5c6a598b, (q31_t)0xa76fe551, (q31_t)0x5c660084, (q31_t)0xa76b5c19, + (q31_t)0x5c61a745, (q31_t)0xa766d317, + (q31_t)0x5c5d4dcc, (q31_t)0xa7624a4d, (q31_t)0x5c58f41a, (q31_t)0xa75dc1b8, (q31_t)0x5c549a30, (q31_t)0xa759395b, + (q31_t)0x5c50400d, (q31_t)0xa754b134, + (q31_t)0x5c4be5b0, (q31_t)0xa7502943, (q31_t)0x5c478b1b, (q31_t)0xa74ba18a, (q31_t)0x5c43304d, (q31_t)0xa7471a07, + (q31_t)0x5c3ed545, (q31_t)0xa74292bb, + (q31_t)0x5c3a7a05, (q31_t)0xa73e0ba5, (q31_t)0x5c361e8c, (q31_t)0xa73984c7, (q31_t)0x5c31c2db, (q31_t)0xa734fe1f, + (q31_t)0x5c2d66f0, (q31_t)0xa73077ae, + (q31_t)0x5c290acc, (q31_t)0xa72bf174, (q31_t)0x5c24ae70, (q31_t)0xa7276b70, (q31_t)0x5c2051db, (q31_t)0xa722e5a3, + (q31_t)0x5c1bf50d, (q31_t)0xa71e600d, + (q31_t)0x5c179806, (q31_t)0xa719daae, (q31_t)0x5c133ac6, (q31_t)0xa7155586, (q31_t)0x5c0edd4e, (q31_t)0xa710d095, + (q31_t)0x5c0a7f9c, (q31_t)0xa70c4bda, + (q31_t)0x5c0621b2, (q31_t)0xa707c757, (q31_t)0x5c01c38f, (q31_t)0xa703430a, (q31_t)0x5bfd6534, (q31_t)0xa6febef4, + (q31_t)0x5bf906a0, (q31_t)0xa6fa3b15, + (q31_t)0x5bf4a7d2, (q31_t)0xa6f5b76d, (q31_t)0x5bf048cd, (q31_t)0xa6f133fc, (q31_t)0x5bebe98e, (q31_t)0xa6ecb0c2, + (q31_t)0x5be78a17, (q31_t)0xa6e82dbe, + (q31_t)0x5be32a67, (q31_t)0xa6e3aaf2, (q31_t)0x5bdeca7f, (q31_t)0xa6df285d, (q31_t)0x5bda6a5d, (q31_t)0xa6daa5fe, + (q31_t)0x5bd60a03, (q31_t)0xa6d623d7, + (q31_t)0x5bd1a971, (q31_t)0xa6d1a1e7, (q31_t)0x5bcd48a6, (q31_t)0xa6cd202d, (q31_t)0x5bc8e7a2, (q31_t)0xa6c89eab, + (q31_t)0x5bc48666, (q31_t)0xa6c41d60, + (q31_t)0x5bc024f0, (q31_t)0xa6bf9c4b, (q31_t)0x5bbbc343, (q31_t)0xa6bb1b6e, (q31_t)0x5bb7615d, (q31_t)0xa6b69ac8, + (q31_t)0x5bb2ff3e, (q31_t)0xa6b21a59, + (q31_t)0x5bae9ce7, (q31_t)0xa6ad9a21, (q31_t)0x5baa3a57, (q31_t)0xa6a91a20, (q31_t)0x5ba5d78e, (q31_t)0xa6a49a56, + (q31_t)0x5ba1748d, (q31_t)0xa6a01ac4, + (q31_t)0x5b9d1154, (q31_t)0xa69b9b68, (q31_t)0x5b98ade2, (q31_t)0xa6971c44, (q31_t)0x5b944a37, (q31_t)0xa6929d57, + (q31_t)0x5b8fe654, (q31_t)0xa68e1ea1, + (q31_t)0x5b8b8239, (q31_t)0xa689a022, (q31_t)0x5b871de5, (q31_t)0xa68521da, (q31_t)0x5b82b958, (q31_t)0xa680a3ca, + (q31_t)0x5b7e5493, (q31_t)0xa67c25f0, + (q31_t)0x5b79ef96, (q31_t)0xa677a84e, (q31_t)0x5b758a60, (q31_t)0xa6732ae3, (q31_t)0x5b7124f2, (q31_t)0xa66eadb0, + (q31_t)0x5b6cbf4c, (q31_t)0xa66a30b3, + (q31_t)0x5b68596d, (q31_t)0xa665b3ee, (q31_t)0x5b63f355, (q31_t)0xa6613760, (q31_t)0x5b5f8d06, (q31_t)0xa65cbb0a, + (q31_t)0x5b5b267e, (q31_t)0xa6583eeb, + (q31_t)0x5b56bfbd, (q31_t)0xa653c303, (q31_t)0x5b5258c4, (q31_t)0xa64f4752, (q31_t)0x5b4df193, (q31_t)0xa64acbd9, + (q31_t)0x5b498a2a, (q31_t)0xa6465097, + (q31_t)0x5b452288, (q31_t)0xa641d58c, (q31_t)0x5b40baae, (q31_t)0xa63d5ab9, (q31_t)0x5b3c529c, (q31_t)0xa638e01d, + (q31_t)0x5b37ea51, (q31_t)0xa63465b9, + (q31_t)0x5b3381ce, (q31_t)0xa62feb8b, (q31_t)0x5b2f1913, (q31_t)0xa62b7196, (q31_t)0x5b2ab020, (q31_t)0xa626f7d7, + (q31_t)0x5b2646f4, (q31_t)0xa6227e50, + (q31_t)0x5b21dd90, (q31_t)0xa61e0501, (q31_t)0x5b1d73f4, (q31_t)0xa6198be9, (q31_t)0x5b190a20, (q31_t)0xa6151308, + (q31_t)0x5b14a014, (q31_t)0xa6109a5f, + (q31_t)0x5b1035cf, (q31_t)0xa60c21ee, (q31_t)0x5b0bcb52, (q31_t)0xa607a9b4, (q31_t)0x5b07609d, (q31_t)0xa60331b1, + (q31_t)0x5b02f5b0, (q31_t)0xa5feb9e6, + (q31_t)0x5afe8a8b, (q31_t)0xa5fa4252, (q31_t)0x5afa1f2e, (q31_t)0xa5f5caf6, (q31_t)0x5af5b398, (q31_t)0xa5f153d2, + (q31_t)0x5af147ca, (q31_t)0xa5ecdce5, + (q31_t)0x5aecdbc5, (q31_t)0xa5e8662f, (q31_t)0x5ae86f87, (q31_t)0xa5e3efb1, (q31_t)0x5ae40311, (q31_t)0xa5df796b, + (q31_t)0x5adf9663, (q31_t)0xa5db035c, + (q31_t)0x5adb297d, (q31_t)0xa5d68d85, (q31_t)0x5ad6bc5f, (q31_t)0xa5d217e6, (q31_t)0x5ad24f09, (q31_t)0xa5cda27e, + (q31_t)0x5acde17b, (q31_t)0xa5c92d4e, + (q31_t)0x5ac973b5, (q31_t)0xa5c4b855, (q31_t)0x5ac505b7, (q31_t)0xa5c04395, (q31_t)0x5ac09781, (q31_t)0xa5bbcf0b, + (q31_t)0x5abc2912, (q31_t)0xa5b75aba, + (q31_t)0x5ab7ba6c, (q31_t)0xa5b2e6a0, (q31_t)0x5ab34b8e, (q31_t)0xa5ae72be, (q31_t)0x5aaedc78, (q31_t)0xa5a9ff14, + (q31_t)0x5aaa6d2b, (q31_t)0xa5a58ba1, + (q31_t)0x5aa5fda5, (q31_t)0xa5a11866, (q31_t)0x5aa18de7, (q31_t)0xa59ca563, (q31_t)0x5a9d1df1, (q31_t)0xa5983297, + (q31_t)0x5a98adc4, (q31_t)0xa593c004, + (q31_t)0x5a943d5e, (q31_t)0xa58f4da8, (q31_t)0x5a8fccc1, (q31_t)0xa58adb84, (q31_t)0x5a8b5bec, (q31_t)0xa5866997, + (q31_t)0x5a86eadf, (q31_t)0xa581f7e3, + (q31_t)0x5a82799a, (q31_t)0xa57d8666, (q31_t)0x5a7e081d, (q31_t)0xa5791521, (q31_t)0x5a799669, (q31_t)0xa574a414, + (q31_t)0x5a75247c, (q31_t)0xa570333f, + (q31_t)0x5a70b258, (q31_t)0xa56bc2a2, (q31_t)0x5a6c3ffc, (q31_t)0xa567523c, (q31_t)0x5a67cd69, (q31_t)0xa562e20f, + (q31_t)0x5a635a9d, (q31_t)0xa55e7219, + (q31_t)0x5a5ee79a, (q31_t)0xa55a025b, (q31_t)0x5a5a745f, (q31_t)0xa55592d5, (q31_t)0x5a5600ec, (q31_t)0xa5512388, + (q31_t)0x5a518d42, (q31_t)0xa54cb472, + (q31_t)0x5a4d1960, (q31_t)0xa5484594, (q31_t)0x5a48a546, (q31_t)0xa543d6ee, (q31_t)0x5a4430f5, (q31_t)0xa53f687f, + (q31_t)0x5a3fbc6b, (q31_t)0xa53afa49, + (q31_t)0x5a3b47ab, (q31_t)0xa5368c4b, (q31_t)0x5a36d2b2, (q31_t)0xa5321e85, (q31_t)0x5a325d82, (q31_t)0xa52db0f7, + (q31_t)0x5a2de81a, (q31_t)0xa52943a1, + (q31_t)0x5a29727b, (q31_t)0xa524d683, (q31_t)0x5a24fca4, (q31_t)0xa520699d, (q31_t)0x5a208695, (q31_t)0xa51bfcef, + (q31_t)0x5a1c104f, (q31_t)0xa5179079, + (q31_t)0x5a1799d1, (q31_t)0xa513243b, (q31_t)0x5a13231b, (q31_t)0xa50eb836, (q31_t)0x5a0eac2e, (q31_t)0xa50a4c68, + (q31_t)0x5a0a350a, (q31_t)0xa505e0d2, + (q31_t)0x5a05bdae, (q31_t)0xa5017575, (q31_t)0x5a01461a, (q31_t)0xa4fd0a50, (q31_t)0x59fcce4f, (q31_t)0xa4f89f63, + (q31_t)0x59f8564c, (q31_t)0xa4f434ae, + (q31_t)0x59f3de12, (q31_t)0xa4efca31, (q31_t)0x59ef65a1, (q31_t)0xa4eb5fec, (q31_t)0x59eaecf8, (q31_t)0xa4e6f5e0, + (q31_t)0x59e67417, (q31_t)0xa4e28c0c, + (q31_t)0x59e1faff, (q31_t)0xa4de2270, (q31_t)0x59dd81b0, (q31_t)0xa4d9b90c, (q31_t)0x59d90829, (q31_t)0xa4d54fe0, + (q31_t)0x59d48e6a, (q31_t)0xa4d0e6ed, + (q31_t)0x59d01475, (q31_t)0xa4cc7e32, (q31_t)0x59cb9a47, (q31_t)0xa4c815af, (q31_t)0x59c71fe3, (q31_t)0xa4c3ad64, + (q31_t)0x59c2a547, (q31_t)0xa4bf4552, + (q31_t)0x59be2a74, (q31_t)0xa4badd78, (q31_t)0x59b9af69, (q31_t)0xa4b675d6, (q31_t)0x59b53427, (q31_t)0xa4b20e6d, + (q31_t)0x59b0b8ae, (q31_t)0xa4ada73c, + (q31_t)0x59ac3cfd, (q31_t)0xa4a94043, (q31_t)0x59a7c115, (q31_t)0xa4a4d982, (q31_t)0x59a344f6, (q31_t)0xa4a072fa, + (q31_t)0x599ec8a0, (q31_t)0xa49c0cab, + (q31_t)0x599a4c12, (q31_t)0xa497a693, (q31_t)0x5995cf4d, (q31_t)0xa49340b4, (q31_t)0x59915250, (q31_t)0xa48edb0e, + (q31_t)0x598cd51d, (q31_t)0xa48a75a0, + (q31_t)0x598857b2, (q31_t)0xa486106a, (q31_t)0x5983da10, (q31_t)0xa481ab6d, (q31_t)0x597f5c36, (q31_t)0xa47d46a8, + (q31_t)0x597ade26, (q31_t)0xa478e21b, + (q31_t)0x59765fde, (q31_t)0xa4747dc7, (q31_t)0x5971e15f, (q31_t)0xa47019ac, (q31_t)0x596d62a9, (q31_t)0xa46bb5c9, + (q31_t)0x5968e3bc, (q31_t)0xa467521e, + (q31_t)0x59646498, (q31_t)0xa462eeac, (q31_t)0x595fe53c, (q31_t)0xa45e8b73, (q31_t)0x595b65aa, (q31_t)0xa45a2872, + (q31_t)0x5956e5e0, (q31_t)0xa455c5a9, + (q31_t)0x595265df, (q31_t)0xa4516319, (q31_t)0x594de5a7, (q31_t)0xa44d00c2, (q31_t)0x59496538, (q31_t)0xa4489ea3, + (q31_t)0x5944e492, (q31_t)0xa4443cbd, + (q31_t)0x594063b5, (q31_t)0xa43fdb10, (q31_t)0x593be2a0, (q31_t)0xa43b799a, (q31_t)0x59376155, (q31_t)0xa437185e, + (q31_t)0x5932dfd3, (q31_t)0xa432b75a, + (q31_t)0x592e5e19, (q31_t)0xa42e568f, (q31_t)0x5929dc29, (q31_t)0xa429f5fd, (q31_t)0x59255a02, (q31_t)0xa42595a3, + (q31_t)0x5920d7a3, (q31_t)0xa4213581, + (q31_t)0x591c550e, (q31_t)0xa41cd599, (q31_t)0x5917d242, (q31_t)0xa41875e9, (q31_t)0x59134f3e, (q31_t)0xa4141672, + (q31_t)0x590ecc04, (q31_t)0xa40fb733, + (q31_t)0x590a4893, (q31_t)0xa40b582e, (q31_t)0x5905c4eb, (q31_t)0xa406f960, (q31_t)0x5901410c, (q31_t)0xa4029acc, + (q31_t)0x58fcbcf6, (q31_t)0xa3fe3c71, + (q31_t)0x58f838a9, (q31_t)0xa3f9de4e, (q31_t)0x58f3b426, (q31_t)0xa3f58064, (q31_t)0x58ef2f6b, (q31_t)0xa3f122b2, + (q31_t)0x58eaaa7a, (q31_t)0xa3ecc53a, + (q31_t)0x58e62552, (q31_t)0xa3e867fa, (q31_t)0x58e19ff3, (q31_t)0xa3e40af3, (q31_t)0x58dd1a5d, (q31_t)0xa3dfae25, + (q31_t)0x58d89490, (q31_t)0xa3db5190, + (q31_t)0x58d40e8c, (q31_t)0xa3d6f534, (q31_t)0x58cf8852, (q31_t)0xa3d29910, (q31_t)0x58cb01e1, (q31_t)0xa3ce3d25, + (q31_t)0x58c67b39, (q31_t)0xa3c9e174, + (q31_t)0x58c1f45b, (q31_t)0xa3c585fb, (q31_t)0x58bd6d45, (q31_t)0xa3c12abb, (q31_t)0x58b8e5f9, (q31_t)0xa3bccfb3, + (q31_t)0x58b45e76, (q31_t)0xa3b874e5, + (q31_t)0x58afd6bd, (q31_t)0xa3b41a50, (q31_t)0x58ab4ecc, (q31_t)0xa3afbff3, (q31_t)0x58a6c6a5, (q31_t)0xa3ab65d0, + (q31_t)0x58a23e48, (q31_t)0xa3a70be6, + (q31_t)0x589db5b3, (q31_t)0xa3a2b234, (q31_t)0x58992ce9, (q31_t)0xa39e58bb, (q31_t)0x5894a3e7, (q31_t)0xa399ff7c, + (q31_t)0x58901aaf, (q31_t)0xa395a675, + (q31_t)0x588b9140, (q31_t)0xa3914da8, (q31_t)0x5887079a, (q31_t)0xa38cf513, (q31_t)0x58827dbe, (q31_t)0xa3889cb8, + (q31_t)0x587df3ab, (q31_t)0xa3844495, + (q31_t)0x58796962, (q31_t)0xa37fecac, (q31_t)0x5874dee2, (q31_t)0xa37b94fb, (q31_t)0x5870542c, (q31_t)0xa3773d84, + (q31_t)0x586bc93f, (q31_t)0xa372e646, + (q31_t)0x58673e1b, (q31_t)0xa36e8f41, (q31_t)0x5862b2c1, (q31_t)0xa36a3875, (q31_t)0x585e2730, (q31_t)0xa365e1e2, + (q31_t)0x58599b69, (q31_t)0xa3618b88, + (q31_t)0x58550f6c, (q31_t)0xa35d3567, (q31_t)0x58508338, (q31_t)0xa358df80, (q31_t)0x584bf6cd, (q31_t)0xa35489d1, + (q31_t)0x58476a2c, (q31_t)0xa350345c, + (q31_t)0x5842dd54, (q31_t)0xa34bdf20, (q31_t)0x583e5047, (q31_t)0xa3478a1d, (q31_t)0x5839c302, (q31_t)0xa3433554, + (q31_t)0x58353587, (q31_t)0xa33ee0c3, + (q31_t)0x5830a7d6, (q31_t)0xa33a8c6c, (q31_t)0x582c19ef, (q31_t)0xa336384e, (q31_t)0x58278bd1, (q31_t)0xa331e469, + (q31_t)0x5822fd7c, (q31_t)0xa32d90be, + (q31_t)0x581e6ef1, (q31_t)0xa3293d4b, (q31_t)0x5819e030, (q31_t)0xa324ea13, (q31_t)0x58155139, (q31_t)0xa3209713, + (q31_t)0x5810c20b, (q31_t)0xa31c444c, + (q31_t)0x580c32a7, (q31_t)0xa317f1bf, (q31_t)0x5807a30d, (q31_t)0xa3139f6b, (q31_t)0x5803133c, (q31_t)0xa30f4d51, + (q31_t)0x57fe8335, (q31_t)0xa30afb70, + (q31_t)0x57f9f2f8, (q31_t)0xa306a9c8, (q31_t)0x57f56284, (q31_t)0xa3025859, (q31_t)0x57f0d1da, (q31_t)0xa2fe0724, + (q31_t)0x57ec40fa, (q31_t)0xa2f9b629, + (q31_t)0x57e7afe4, (q31_t)0xa2f56566, (q31_t)0x57e31e97, (q31_t)0xa2f114dd, (q31_t)0x57de8d15, (q31_t)0xa2ecc48e, + (q31_t)0x57d9fb5c, (q31_t)0xa2e87477, + (q31_t)0x57d5696d, (q31_t)0xa2e4249b, (q31_t)0x57d0d747, (q31_t)0xa2dfd4f7, (q31_t)0x57cc44ec, (q31_t)0xa2db858e, + (q31_t)0x57c7b25a, (q31_t)0xa2d7365d, + (q31_t)0x57c31f92, (q31_t)0xa2d2e766, (q31_t)0x57be8c94, (q31_t)0xa2ce98a9, (q31_t)0x57b9f960, (q31_t)0xa2ca4a25, + (q31_t)0x57b565f6, (q31_t)0xa2c5fbda, + (q31_t)0x57b0d256, (q31_t)0xa2c1adc9, (q31_t)0x57ac3e80, (q31_t)0xa2bd5ff2, (q31_t)0x57a7aa73, (q31_t)0xa2b91254, + (q31_t)0x57a31631, (q31_t)0xa2b4c4f0, + (q31_t)0x579e81b8, (q31_t)0xa2b077c5, (q31_t)0x5799ed0a, (q31_t)0xa2ac2ad3, (q31_t)0x57955825, (q31_t)0xa2a7de1c, + (q31_t)0x5790c30a, (q31_t)0xa2a3919e, + (q31_t)0x578c2dba, (q31_t)0xa29f4559, (q31_t)0x57879833, (q31_t)0xa29af94e, (q31_t)0x57830276, (q31_t)0xa296ad7d, + (q31_t)0x577e6c84, (q31_t)0xa29261e5, + (q31_t)0x5779d65b, (q31_t)0xa28e1687, (q31_t)0x57753ffc, (q31_t)0xa289cb63, (q31_t)0x5770a968, (q31_t)0xa2858078, + (q31_t)0x576c129d, (q31_t)0xa28135c7, + (q31_t)0x57677b9d, (q31_t)0xa27ceb4f, (q31_t)0x5762e467, (q31_t)0xa278a111, (q31_t)0x575e4cfa, (q31_t)0xa274570d, + (q31_t)0x5759b558, (q31_t)0xa2700d43, + (q31_t)0x57551d80, (q31_t)0xa26bc3b2, (q31_t)0x57508572, (q31_t)0xa2677a5b, (q31_t)0x574bed2f, (q31_t)0xa263313e, + (q31_t)0x574754b5, (q31_t)0xa25ee85b, + (q31_t)0x5742bc06, (q31_t)0xa25a9fb1, (q31_t)0x573e2320, (q31_t)0xa2565741, (q31_t)0x57398a05, (q31_t)0xa2520f0b, + (q31_t)0x5734f0b5, (q31_t)0xa24dc70f, + (q31_t)0x5730572e, (q31_t)0xa2497f4c, (q31_t)0x572bbd71, (q31_t)0xa24537c3, (q31_t)0x5727237f, (q31_t)0xa240f074, + (q31_t)0x57228957, (q31_t)0xa23ca95f, + (q31_t)0x571deefa, (q31_t)0xa2386284, (q31_t)0x57195466, (q31_t)0xa2341be3, (q31_t)0x5714b99d, (q31_t)0xa22fd57b, + (q31_t)0x57101e9e, (q31_t)0xa22b8f4d, + (q31_t)0x570b8369, (q31_t)0xa2274959, (q31_t)0x5706e7ff, (q31_t)0xa223039f, (q31_t)0x57024c5f, (q31_t)0xa21ebe1f, + (q31_t)0x56fdb08a, (q31_t)0xa21a78d9, + (q31_t)0x56f9147e, (q31_t)0xa21633cd, (q31_t)0x56f4783d, (q31_t)0xa211eefb, (q31_t)0x56efdbc7, (q31_t)0xa20daa62, + (q31_t)0x56eb3f1a, (q31_t)0xa2096604, + (q31_t)0x56e6a239, (q31_t)0xa20521e0, (q31_t)0x56e20521, (q31_t)0xa200ddf5, (q31_t)0x56dd67d4, (q31_t)0xa1fc9a45, + (q31_t)0x56d8ca51, (q31_t)0xa1f856ce, + (q31_t)0x56d42c99, (q31_t)0xa1f41392, (q31_t)0x56cf8eab, (q31_t)0xa1efd08f, (q31_t)0x56caf088, (q31_t)0xa1eb8dc7, + (q31_t)0x56c6522f, (q31_t)0xa1e74b38, + (q31_t)0x56c1b3a1, (q31_t)0xa1e308e4, (q31_t)0x56bd14dd, (q31_t)0xa1dec6ca, (q31_t)0x56b875e4, (q31_t)0xa1da84e9, + (q31_t)0x56b3d6b5, (q31_t)0xa1d64343, + (q31_t)0x56af3750, (q31_t)0xa1d201d7, (q31_t)0x56aa97b7, (q31_t)0xa1cdc0a5, (q31_t)0x56a5f7e7, (q31_t)0xa1c97fad, + (q31_t)0x56a157e3, (q31_t)0xa1c53ef0, + (q31_t)0x569cb7a8, (q31_t)0xa1c0fe6c, (q31_t)0x56981739, (q31_t)0xa1bcbe22, (q31_t)0x56937694, (q31_t)0xa1b87e13, + (q31_t)0x568ed5b9, (q31_t)0xa1b43e3e, + (q31_t)0x568a34a9, (q31_t)0xa1affea3, (q31_t)0x56859364, (q31_t)0xa1abbf42, (q31_t)0x5680f1ea, (q31_t)0xa1a7801b, + (q31_t)0x567c503a, (q31_t)0xa1a3412f, + (q31_t)0x5677ae54, (q31_t)0xa19f027c, (q31_t)0x56730c3a, (q31_t)0xa19ac404, (q31_t)0x566e69ea, (q31_t)0xa19685c7, + (q31_t)0x5669c765, (q31_t)0xa19247c3, + (q31_t)0x566524aa, (q31_t)0xa18e09fa, (q31_t)0x566081ba, (q31_t)0xa189cc6b, (q31_t)0x565bde95, (q31_t)0xa1858f16, + (q31_t)0x56573b3b, (q31_t)0xa18151fb, + (q31_t)0x565297ab, (q31_t)0xa17d151b, (q31_t)0x564df3e6, (q31_t)0xa178d875, (q31_t)0x56494fec, (q31_t)0xa1749c09, + (q31_t)0x5644abbc, (q31_t)0xa1705fd8, + (q31_t)0x56400758, (q31_t)0xa16c23e1, (q31_t)0x563b62be, (q31_t)0xa167e824, (q31_t)0x5636bdef, (q31_t)0xa163aca2, + (q31_t)0x563218eb, (q31_t)0xa15f715a, + (q31_t)0x562d73b2, (q31_t)0xa15b364d, (q31_t)0x5628ce43, (q31_t)0xa156fb79, (q31_t)0x5624289f, (q31_t)0xa152c0e1, + (q31_t)0x561f82c7, (q31_t)0xa14e8682, + (q31_t)0x561adcb9, (q31_t)0xa14a4c5e, (q31_t)0x56163676, (q31_t)0xa1461275, (q31_t)0x56118ffe, (q31_t)0xa141d8c5, + (q31_t)0x560ce950, (q31_t)0xa13d9f51, + (q31_t)0x5608426e, (q31_t)0xa1396617, (q31_t)0x56039b57, (q31_t)0xa1352d17, (q31_t)0x55fef40a, (q31_t)0xa130f451, + (q31_t)0x55fa4c89, (q31_t)0xa12cbbc7, + (q31_t)0x55f5a4d2, (q31_t)0xa1288376, (q31_t)0x55f0fce7, (q31_t)0xa1244b61, (q31_t)0x55ec54c6, (q31_t)0xa1201385, + (q31_t)0x55e7ac71, (q31_t)0xa11bdbe4, + (q31_t)0x55e303e6, (q31_t)0xa117a47e, (q31_t)0x55de5b27, (q31_t)0xa1136d52, (q31_t)0x55d9b232, (q31_t)0xa10f3661, + (q31_t)0x55d50909, (q31_t)0xa10affab, + (q31_t)0x55d05faa, (q31_t)0xa106c92f, (q31_t)0x55cbb617, (q31_t)0xa10292ed, (q31_t)0x55c70c4f, (q31_t)0xa0fe5ce6, + (q31_t)0x55c26251, (q31_t)0xa0fa271a, + (q31_t)0x55bdb81f, (q31_t)0xa0f5f189, (q31_t)0x55b90db8, (q31_t)0xa0f1bc32, (q31_t)0x55b4631d, (q31_t)0xa0ed8715, + (q31_t)0x55afb84c, (q31_t)0xa0e95234, + (q31_t)0x55ab0d46, (q31_t)0xa0e51d8c, (q31_t)0x55a6620c, (q31_t)0xa0e0e920, (q31_t)0x55a1b69d, (q31_t)0xa0dcb4ee, + (q31_t)0x559d0af9, (q31_t)0xa0d880f7, + (q31_t)0x55985f20, (q31_t)0xa0d44d3b, (q31_t)0x5593b312, (q31_t)0xa0d019b9, (q31_t)0x558f06d0, (q31_t)0xa0cbe672, + (q31_t)0x558a5a58, (q31_t)0xa0c7b366, + (q31_t)0x5585adad, (q31_t)0xa0c38095, (q31_t)0x558100cc, (q31_t)0xa0bf4dfe, (q31_t)0x557c53b6, (q31_t)0xa0bb1ba2, + (q31_t)0x5577a66c, (q31_t)0xa0b6e981, + (q31_t)0x5572f8ed, (q31_t)0xa0b2b79b, (q31_t)0x556e4b39, (q31_t)0xa0ae85ef, (q31_t)0x55699d51, (q31_t)0xa0aa547e, + (q31_t)0x5564ef34, (q31_t)0xa0a62348, + (q31_t)0x556040e2, (q31_t)0xa0a1f24d, (q31_t)0x555b925c, (q31_t)0xa09dc18d, (q31_t)0x5556e3a1, (q31_t)0xa0999107, + (q31_t)0x555234b1, (q31_t)0xa09560bc, + (q31_t)0x554d858d, (q31_t)0xa09130ad, (q31_t)0x5548d634, (q31_t)0xa08d00d8, (q31_t)0x554426a7, (q31_t)0xa088d13e, + (q31_t)0x553f76e4, (q31_t)0xa084a1de, + (q31_t)0x553ac6ee, (q31_t)0xa08072ba, (q31_t)0x553616c2, (q31_t)0xa07c43d1, (q31_t)0x55316663, (q31_t)0xa0781522, + (q31_t)0x552cb5ce, (q31_t)0xa073e6af, + (q31_t)0x55280505, (q31_t)0xa06fb876, (q31_t)0x55235408, (q31_t)0xa06b8a78, (q31_t)0x551ea2d6, (q31_t)0xa0675cb6, + (q31_t)0x5519f16f, (q31_t)0xa0632f2e, + (q31_t)0x55153fd4, (q31_t)0xa05f01e1, (q31_t)0x55108e05, (q31_t)0xa05ad4cf, (q31_t)0x550bdc01, (q31_t)0xa056a7f9, + (q31_t)0x550729c9, (q31_t)0xa0527b5d, + (q31_t)0x5502775c, (q31_t)0xa04e4efc, (q31_t)0x54fdc4ba, (q31_t)0xa04a22d7, (q31_t)0x54f911e5, (q31_t)0xa045f6ec, + (q31_t)0x54f45edb, (q31_t)0xa041cb3c, + (q31_t)0x54efab9c, (q31_t)0xa03d9fc8, (q31_t)0x54eaf829, (q31_t)0xa039748e, (q31_t)0x54e64482, (q31_t)0xa0354990, + (q31_t)0x54e190a6, (q31_t)0xa0311ecd, + (q31_t)0x54dcdc96, (q31_t)0xa02cf444, (q31_t)0x54d82852, (q31_t)0xa028c9f7, (q31_t)0x54d373d9, (q31_t)0xa0249fe5, + (q31_t)0x54cebf2c, (q31_t)0xa020760e, + (q31_t)0x54ca0a4b, (q31_t)0xa01c4c73, (q31_t)0x54c55535, (q31_t)0xa0182312, (q31_t)0x54c09feb, (q31_t)0xa013f9ed, + (q31_t)0x54bbea6d, (q31_t)0xa00fd102, + (q31_t)0x54b734ba, (q31_t)0xa00ba853, (q31_t)0x54b27ed3, (q31_t)0xa0077fdf, (q31_t)0x54adc8b8, (q31_t)0xa00357a7, + (q31_t)0x54a91269, (q31_t)0x9fff2fa9, + (q31_t)0x54a45be6, (q31_t)0x9ffb07e7, (q31_t)0x549fa52e, (q31_t)0x9ff6e060, (q31_t)0x549aee42, (q31_t)0x9ff2b914, + (q31_t)0x54963722, (q31_t)0x9fee9204, + (q31_t)0x54917fce, (q31_t)0x9fea6b2f, (q31_t)0x548cc845, (q31_t)0x9fe64495, (q31_t)0x54881089, (q31_t)0x9fe21e36, + (q31_t)0x54835898, (q31_t)0x9fddf812, + (q31_t)0x547ea073, (q31_t)0x9fd9d22a, (q31_t)0x5479e81a, (q31_t)0x9fd5ac7d, (q31_t)0x54752f8d, (q31_t)0x9fd1870c, + (q31_t)0x547076cc, (q31_t)0x9fcd61d6, + (q31_t)0x546bbdd7, (q31_t)0x9fc93cdb, (q31_t)0x546704ae, (q31_t)0x9fc5181b, (q31_t)0x54624b50, (q31_t)0x9fc0f397, + (q31_t)0x545d91bf, (q31_t)0x9fbccf4f, + (q31_t)0x5458d7f9, (q31_t)0x9fb8ab41, (q31_t)0x54541e00, (q31_t)0x9fb4876f, (q31_t)0x544f63d2, (q31_t)0x9fb063d9, + (q31_t)0x544aa971, (q31_t)0x9fac407e, + (q31_t)0x5445eedb, (q31_t)0x9fa81d5e, (q31_t)0x54413412, (q31_t)0x9fa3fa79, (q31_t)0x543c7914, (q31_t)0x9f9fd7d1, + (q31_t)0x5437bde3, (q31_t)0x9f9bb563, + (q31_t)0x5433027d, (q31_t)0x9f979331, (q31_t)0x542e46e4, (q31_t)0x9f93713b, (q31_t)0x54298b17, (q31_t)0x9f8f4f80, + (q31_t)0x5424cf16, (q31_t)0x9f8b2e00, + (q31_t)0x542012e1, (q31_t)0x9f870cbc, (q31_t)0x541b5678, (q31_t)0x9f82ebb4, (q31_t)0x541699db, (q31_t)0x9f7ecae7, + (q31_t)0x5411dd0a, (q31_t)0x9f7aaa55, + (q31_t)0x540d2005, (q31_t)0x9f7689ff, (q31_t)0x540862cd, (q31_t)0x9f7269e5, (q31_t)0x5403a561, (q31_t)0x9f6e4a06, + (q31_t)0x53fee7c1, (q31_t)0x9f6a2a63, + (q31_t)0x53fa29ed, (q31_t)0x9f660afb, (q31_t)0x53f56be5, (q31_t)0x9f61ebcf, (q31_t)0x53f0adaa, (q31_t)0x9f5dccde, + (q31_t)0x53ebef3a, (q31_t)0x9f59ae29, + (q31_t)0x53e73097, (q31_t)0x9f558fb0, (q31_t)0x53e271c0, (q31_t)0x9f517173, (q31_t)0x53ddb2b6, (q31_t)0x9f4d5371, + (q31_t)0x53d8f378, (q31_t)0x9f4935aa, + (q31_t)0x53d43406, (q31_t)0x9f45181f, (q31_t)0x53cf7460, (q31_t)0x9f40fad0, (q31_t)0x53cab486, (q31_t)0x9f3cddbd, + (q31_t)0x53c5f479, (q31_t)0x9f38c0e5, + (q31_t)0x53c13439, (q31_t)0x9f34a449, (q31_t)0x53bc73c4, (q31_t)0x9f3087e9, (q31_t)0x53b7b31c, (q31_t)0x9f2c6bc5, + (q31_t)0x53b2f240, (q31_t)0x9f284fdc, + (q31_t)0x53ae3131, (q31_t)0x9f24342f, (q31_t)0x53a96fee, (q31_t)0x9f2018bd, (q31_t)0x53a4ae77, (q31_t)0x9f1bfd88, + (q31_t)0x539feccd, (q31_t)0x9f17e28e, + (q31_t)0x539b2af0, (q31_t)0x9f13c7d0, (q31_t)0x539668de, (q31_t)0x9f0fad4e, (q31_t)0x5391a699, (q31_t)0x9f0b9307, + (q31_t)0x538ce421, (q31_t)0x9f0778fd, + (q31_t)0x53882175, (q31_t)0x9f035f2e, (q31_t)0x53835e95, (q31_t)0x9eff459b, (q31_t)0x537e9b82, (q31_t)0x9efb2c44, + (q31_t)0x5379d83c, (q31_t)0x9ef71328, + (q31_t)0x537514c2, (q31_t)0x9ef2fa49, (q31_t)0x53705114, (q31_t)0x9eeee1a5, (q31_t)0x536b8d33, (q31_t)0x9eeac93e, + (q31_t)0x5366c91f, (q31_t)0x9ee6b112, + (q31_t)0x536204d7, (q31_t)0x9ee29922, (q31_t)0x535d405c, (q31_t)0x9ede816e, (q31_t)0x53587bad, (q31_t)0x9eda69f6, + (q31_t)0x5353b6cb, (q31_t)0x9ed652ba, + (q31_t)0x534ef1b5, (q31_t)0x9ed23bb9, (q31_t)0x534a2c6c, (q31_t)0x9ece24f5, (q31_t)0x534566f0, (q31_t)0x9eca0e6d, + (q31_t)0x5340a140, (q31_t)0x9ec5f820, + (q31_t)0x533bdb5d, (q31_t)0x9ec1e210, (q31_t)0x53371547, (q31_t)0x9ebdcc3b, (q31_t)0x53324efd, (q31_t)0x9eb9b6a3, + (q31_t)0x532d8880, (q31_t)0x9eb5a146, + (q31_t)0x5328c1d0, (q31_t)0x9eb18c26, (q31_t)0x5323faec, (q31_t)0x9ead7742, (q31_t)0x531f33d5, (q31_t)0x9ea96299, + (q31_t)0x531a6c8b, (q31_t)0x9ea54e2d, + (q31_t)0x5315a50e, (q31_t)0x9ea139fd, (q31_t)0x5310dd5d, (q31_t)0x9e9d2608, (q31_t)0x530c1579, (q31_t)0x9e991250, + (q31_t)0x53074d62, (q31_t)0x9e94fed4, + (q31_t)0x53028518, (q31_t)0x9e90eb94, (q31_t)0x52fdbc9a, (q31_t)0x9e8cd890, (q31_t)0x52f8f3e9, (q31_t)0x9e88c5c9, + (q31_t)0x52f42b05, (q31_t)0x9e84b33d, + (q31_t)0x52ef61ee, (q31_t)0x9e80a0ee, (q31_t)0x52ea98a4, (q31_t)0x9e7c8eda, (q31_t)0x52e5cf27, (q31_t)0x9e787d03, + (q31_t)0x52e10576, (q31_t)0x9e746b68, + (q31_t)0x52dc3b92, (q31_t)0x9e705a09, (q31_t)0x52d7717b, (q31_t)0x9e6c48e7, (q31_t)0x52d2a732, (q31_t)0x9e683800, + (q31_t)0x52cddcb5, (q31_t)0x9e642756, + (q31_t)0x52c91204, (q31_t)0x9e6016e8, (q31_t)0x52c44721, (q31_t)0x9e5c06b6, (q31_t)0x52bf7c0b, (q31_t)0x9e57f6c0, + (q31_t)0x52bab0c2, (q31_t)0x9e53e707, + (q31_t)0x52b5e546, (q31_t)0x9e4fd78a, (q31_t)0x52b11996, (q31_t)0x9e4bc849, (q31_t)0x52ac4db4, (q31_t)0x9e47b944, + (q31_t)0x52a7819f, (q31_t)0x9e43aa7c, + (q31_t)0x52a2b556, (q31_t)0x9e3f9bf0, (q31_t)0x529de8db, (q31_t)0x9e3b8da0, (q31_t)0x52991c2d, (q31_t)0x9e377f8c, + (q31_t)0x52944f4c, (q31_t)0x9e3371b5, + (q31_t)0x528f8238, (q31_t)0x9e2f641b, (q31_t)0x528ab4f1, (q31_t)0x9e2b56bc, (q31_t)0x5285e777, (q31_t)0x9e27499a, + (q31_t)0x528119ca, (q31_t)0x9e233cb4, + (q31_t)0x527c4bea, (q31_t)0x9e1f300b, (q31_t)0x52777dd7, (q31_t)0x9e1b239e, (q31_t)0x5272af92, (q31_t)0x9e17176d, + (q31_t)0x526de11a, (q31_t)0x9e130b79, + (q31_t)0x5269126e, (q31_t)0x9e0effc1, (q31_t)0x52644390, (q31_t)0x9e0af446, (q31_t)0x525f7480, (q31_t)0x9e06e907, + (q31_t)0x525aa53c, (q31_t)0x9e02de04, + (q31_t)0x5255d5c5, (q31_t)0x9dfed33e, (q31_t)0x5251061c, (q31_t)0x9dfac8b4, (q31_t)0x524c3640, (q31_t)0x9df6be67, + (q31_t)0x52476631, (q31_t)0x9df2b456, + (q31_t)0x524295f0, (q31_t)0x9deeaa82, (q31_t)0x523dc57b, (q31_t)0x9deaa0ea, (q31_t)0x5238f4d4, (q31_t)0x9de6978f, + (q31_t)0x523423fb, (q31_t)0x9de28e70, + (q31_t)0x522f52ee, (q31_t)0x9dde858e, (q31_t)0x522a81af, (q31_t)0x9dda7ce9, (q31_t)0x5225b03d, (q31_t)0x9dd6747f, + (q31_t)0x5220de99, (q31_t)0x9dd26c53, + (q31_t)0x521c0cc2, (q31_t)0x9dce6463, (q31_t)0x52173ab8, (q31_t)0x9dca5caf, (q31_t)0x5212687b, (q31_t)0x9dc65539, + (q31_t)0x520d960c, (q31_t)0x9dc24dfe, + (q31_t)0x5208c36a, (q31_t)0x9dbe4701, (q31_t)0x5203f096, (q31_t)0x9dba4040, (q31_t)0x51ff1d8f, (q31_t)0x9db639bb, + (q31_t)0x51fa4a56, (q31_t)0x9db23373, + (q31_t)0x51f576ea, (q31_t)0x9dae2d68, (q31_t)0x51f0a34b, (q31_t)0x9daa279a, (q31_t)0x51ebcf7a, (q31_t)0x9da62208, + (q31_t)0x51e6fb76, (q31_t)0x9da21cb2, + (q31_t)0x51e22740, (q31_t)0x9d9e179a, (q31_t)0x51dd52d7, (q31_t)0x9d9a12be, (q31_t)0x51d87e3c, (q31_t)0x9d960e1f, + (q31_t)0x51d3a96f, (q31_t)0x9d9209bd, + (q31_t)0x51ced46e, (q31_t)0x9d8e0597, (q31_t)0x51c9ff3c, (q31_t)0x9d8a01ae, (q31_t)0x51c529d7, (q31_t)0x9d85fe02, + (q31_t)0x51c0543f, (q31_t)0x9d81fa92, + (q31_t)0x51bb7e75, (q31_t)0x9d7df75f, (q31_t)0x51b6a879, (q31_t)0x9d79f469, (q31_t)0x51b1d24a, (q31_t)0x9d75f1b0, + (q31_t)0x51acfbe9, (q31_t)0x9d71ef34, + (q31_t)0x51a82555, (q31_t)0x9d6decf4, (q31_t)0x51a34e8f, (q31_t)0x9d69eaf1, (q31_t)0x519e7797, (q31_t)0x9d65e92b, + (q31_t)0x5199a06d, (q31_t)0x9d61e7a2, + (q31_t)0x5194c910, (q31_t)0x9d5de656, (q31_t)0x518ff180, (q31_t)0x9d59e546, (q31_t)0x518b19bf, (q31_t)0x9d55e473, + (q31_t)0x518641cb, (q31_t)0x9d51e3dd, + (q31_t)0x518169a5, (q31_t)0x9d4de385, (q31_t)0x517c914c, (q31_t)0x9d49e368, (q31_t)0x5177b8c2, (q31_t)0x9d45e389, + (q31_t)0x5172e005, (q31_t)0x9d41e3e7, + (q31_t)0x516e0715, (q31_t)0x9d3de482, (q31_t)0x51692df4, (q31_t)0x9d39e559, (q31_t)0x516454a0, (q31_t)0x9d35e66e, + (q31_t)0x515f7b1a, (q31_t)0x9d31e7bf, + (q31_t)0x515aa162, (q31_t)0x9d2de94d, (q31_t)0x5155c778, (q31_t)0x9d29eb19, (q31_t)0x5150ed5c, (q31_t)0x9d25ed21, + (q31_t)0x514c130d, (q31_t)0x9d21ef66, + (q31_t)0x5147388c, (q31_t)0x9d1df1e9, (q31_t)0x51425dd9, (q31_t)0x9d19f4a8, (q31_t)0x513d82f4, (q31_t)0x9d15f7a4, + (q31_t)0x5138a7dd, (q31_t)0x9d11fadd, + (q31_t)0x5133cc94, (q31_t)0x9d0dfe54, (q31_t)0x512ef119, (q31_t)0x9d0a0207, (q31_t)0x512a156b, (q31_t)0x9d0605f7, + (q31_t)0x5125398c, (q31_t)0x9d020a25, + (q31_t)0x51205d7b, (q31_t)0x9cfe0e8f, (q31_t)0x511b8137, (q31_t)0x9cfa1337, (q31_t)0x5116a4c1, (q31_t)0x9cf6181c, + (q31_t)0x5111c81a, (q31_t)0x9cf21d3d, + (q31_t)0x510ceb40, (q31_t)0x9cee229c, (q31_t)0x51080e35, (q31_t)0x9cea2838, (q31_t)0x510330f7, (q31_t)0x9ce62e11, + (q31_t)0x50fe5388, (q31_t)0x9ce23427, + (q31_t)0x50f975e6, (q31_t)0x9cde3a7b, (q31_t)0x50f49813, (q31_t)0x9cda410b, (q31_t)0x50efba0d, (q31_t)0x9cd647d9, + (q31_t)0x50eadbd6, (q31_t)0x9cd24ee4, + (q31_t)0x50e5fd6d, (q31_t)0x9cce562c, (q31_t)0x50e11ed2, (q31_t)0x9cca5db1, (q31_t)0x50dc4005, (q31_t)0x9cc66573, + (q31_t)0x50d76106, (q31_t)0x9cc26d73, + (q31_t)0x50d281d5, (q31_t)0x9cbe75b0, (q31_t)0x50cda272, (q31_t)0x9cba7e2a, (q31_t)0x50c8c2de, (q31_t)0x9cb686e1, + (q31_t)0x50c3e317, (q31_t)0x9cb28fd5, + (q31_t)0x50bf031f, (q31_t)0x9cae9907, (q31_t)0x50ba22f5, (q31_t)0x9caaa276, (q31_t)0x50b5429a, (q31_t)0x9ca6ac23, + (q31_t)0x50b0620c, (q31_t)0x9ca2b60c, + (q31_t)0x50ab814d, (q31_t)0x9c9ec033, (q31_t)0x50a6a05c, (q31_t)0x9c9aca97, (q31_t)0x50a1bf39, (q31_t)0x9c96d539, + (q31_t)0x509cdde4, (q31_t)0x9c92e017, + (q31_t)0x5097fc5e, (q31_t)0x9c8eeb34, (q31_t)0x50931aa6, (q31_t)0x9c8af68d, (q31_t)0x508e38bd, (q31_t)0x9c870224, + (q31_t)0x508956a1, (q31_t)0x9c830df8, + (q31_t)0x50847454, (q31_t)0x9c7f1a0a, (q31_t)0x507f91d5, (q31_t)0x9c7b2659, (q31_t)0x507aaf25, (q31_t)0x9c7732e5, + (q31_t)0x5075cc43, (q31_t)0x9c733faf, + (q31_t)0x5070e92f, (q31_t)0x9c6f4cb6, (q31_t)0x506c05ea, (q31_t)0x9c6b59fa, (q31_t)0x50672273, (q31_t)0x9c67677c, + (q31_t)0x50623ecb, (q31_t)0x9c63753c, + (q31_t)0x505d5af1, (q31_t)0x9c5f8339, (q31_t)0x505876e5, (q31_t)0x9c5b9173, (q31_t)0x505392a8, (q31_t)0x9c579feb, + (q31_t)0x504eae39, (q31_t)0x9c53aea0, + (q31_t)0x5049c999, (q31_t)0x9c4fbd93, (q31_t)0x5044e4c7, (q31_t)0x9c4bccc3, (q31_t)0x503fffc4, (q31_t)0x9c47dc31, + (q31_t)0x503b1a8f, (q31_t)0x9c43ebdc, + (q31_t)0x50363529, (q31_t)0x9c3ffbc5, (q31_t)0x50314f91, (q31_t)0x9c3c0beb, (q31_t)0x502c69c8, (q31_t)0x9c381c4f, + (q31_t)0x502783cd, (q31_t)0x9c342cf0, + (q31_t)0x50229da1, (q31_t)0x9c303dcf, (q31_t)0x501db743, (q31_t)0x9c2c4eec, (q31_t)0x5018d0b4, (q31_t)0x9c286046, + (q31_t)0x5013e9f4, (q31_t)0x9c2471de, + (q31_t)0x500f0302, (q31_t)0x9c2083b3, (q31_t)0x500a1bdf, (q31_t)0x9c1c95c6, (q31_t)0x5005348a, (q31_t)0x9c18a816, + (q31_t)0x50004d04, (q31_t)0x9c14baa4, + (q31_t)0x4ffb654d, (q31_t)0x9c10cd70, (q31_t)0x4ff67d64, (q31_t)0x9c0ce07a, (q31_t)0x4ff1954b, (q31_t)0x9c08f3c1, + (q31_t)0x4fecacff, (q31_t)0x9c050745, + (q31_t)0x4fe7c483, (q31_t)0x9c011b08, (q31_t)0x4fe2dbd5, (q31_t)0x9bfd2f08, (q31_t)0x4fddf2f6, (q31_t)0x9bf94346, + (q31_t)0x4fd909e5, (q31_t)0x9bf557c1, + (q31_t)0x4fd420a4, (q31_t)0x9bf16c7a, (q31_t)0x4fcf3731, (q31_t)0x9bed8171, (q31_t)0x4fca4d8d, (q31_t)0x9be996a6, + (q31_t)0x4fc563b7, (q31_t)0x9be5ac18, + (q31_t)0x4fc079b1, (q31_t)0x9be1c1c8, (q31_t)0x4fbb8f79, (q31_t)0x9bddd7b6, (q31_t)0x4fb6a510, (q31_t)0x9bd9ede2, + (q31_t)0x4fb1ba76, (q31_t)0x9bd6044b, + (q31_t)0x4faccfab, (q31_t)0x9bd21af3, (q31_t)0x4fa7e4af, (q31_t)0x9bce31d8, (q31_t)0x4fa2f981, (q31_t)0x9bca48fa, + (q31_t)0x4f9e0e22, (q31_t)0x9bc6605b, + (q31_t)0x4f992293, (q31_t)0x9bc277fa, (q31_t)0x4f9436d2, (q31_t)0x9bbe8fd6, (q31_t)0x4f8f4ae0, (q31_t)0x9bbaa7f0, + (q31_t)0x4f8a5ebd, (q31_t)0x9bb6c048, + (q31_t)0x4f857269, (q31_t)0x9bb2d8de, (q31_t)0x4f8085e4, (q31_t)0x9baef1b2, (q31_t)0x4f7b992d, (q31_t)0x9bab0ac3, + (q31_t)0x4f76ac46, (q31_t)0x9ba72413, + (q31_t)0x4f71bf2e, (q31_t)0x9ba33da0, (q31_t)0x4f6cd1e5, (q31_t)0x9b9f576b, (q31_t)0x4f67e46a, (q31_t)0x9b9b7174, + (q31_t)0x4f62f6bf, (q31_t)0x9b978bbc, + (q31_t)0x4f5e08e3, (q31_t)0x9b93a641, (q31_t)0x4f591ad6, (q31_t)0x9b8fc104, (q31_t)0x4f542c98, (q31_t)0x9b8bdc05, + (q31_t)0x4f4f3e29, (q31_t)0x9b87f744, + (q31_t)0x4f4a4f89, (q31_t)0x9b8412c1, (q31_t)0x4f4560b8, (q31_t)0x9b802e7b, (q31_t)0x4f4071b6, (q31_t)0x9b7c4a74, + (q31_t)0x4f3b8284, (q31_t)0x9b7866ab, + (q31_t)0x4f369320, (q31_t)0x9b748320, (q31_t)0x4f31a38c, (q31_t)0x9b709fd3, (q31_t)0x4f2cb3c7, (q31_t)0x9b6cbcc4, + (q31_t)0x4f27c3d1, (q31_t)0x9b68d9f3, + (q31_t)0x4f22d3aa, (q31_t)0x9b64f760, (q31_t)0x4f1de352, (q31_t)0x9b61150b, (q31_t)0x4f18f2c9, (q31_t)0x9b5d32f4, + (q31_t)0x4f140210, (q31_t)0x9b59511c, + (q31_t)0x4f0f1126, (q31_t)0x9b556f81, (q31_t)0x4f0a200b, (q31_t)0x9b518e24, (q31_t)0x4f052ec0, (q31_t)0x9b4dad06, + (q31_t)0x4f003d43, (q31_t)0x9b49cc26, + (q31_t)0x4efb4b96, (q31_t)0x9b45eb83, (q31_t)0x4ef659b8, (q31_t)0x9b420b1f, (q31_t)0x4ef167aa, (q31_t)0x9b3e2af9, + (q31_t)0x4eec756b, (q31_t)0x9b3a4b11, + (q31_t)0x4ee782fb, (q31_t)0x9b366b68, (q31_t)0x4ee2905a, (q31_t)0x9b328bfc, (q31_t)0x4edd9d89, (q31_t)0x9b2eaccf, + (q31_t)0x4ed8aa87, (q31_t)0x9b2acde0, + (q31_t)0x4ed3b755, (q31_t)0x9b26ef2f, (q31_t)0x4ecec3f2, (q31_t)0x9b2310bc, (q31_t)0x4ec9d05e, (q31_t)0x9b1f3288, + (q31_t)0x4ec4dc99, (q31_t)0x9b1b5492, + (q31_t)0x4ebfe8a5, (q31_t)0x9b1776da, (q31_t)0x4ebaf47f, (q31_t)0x9b139960, (q31_t)0x4eb60029, (q31_t)0x9b0fbc24, + (q31_t)0x4eb10ba2, (q31_t)0x9b0bdf27, + (q31_t)0x4eac16eb, (q31_t)0x9b080268, (q31_t)0x4ea72203, (q31_t)0x9b0425e8, (q31_t)0x4ea22ceb, (q31_t)0x9b0049a5, + (q31_t)0x4e9d37a3, (q31_t)0x9afc6da1, + (q31_t)0x4e984229, (q31_t)0x9af891db, (q31_t)0x4e934c80, (q31_t)0x9af4b654, (q31_t)0x4e8e56a5, (q31_t)0x9af0db0b, + (q31_t)0x4e89609b, (q31_t)0x9aed0000, + (q31_t)0x4e846a60, (q31_t)0x9ae92533, (q31_t)0x4e7f73f4, (q31_t)0x9ae54aa5, (q31_t)0x4e7a7d58, (q31_t)0x9ae17056, + (q31_t)0x4e75868c, (q31_t)0x9add9644, + (q31_t)0x4e708f8f, (q31_t)0x9ad9bc71, (q31_t)0x4e6b9862, (q31_t)0x9ad5e2dd, (q31_t)0x4e66a105, (q31_t)0x9ad20987, + (q31_t)0x4e61a977, (q31_t)0x9ace306f, + (q31_t)0x4e5cb1b9, (q31_t)0x9aca5795, (q31_t)0x4e57b9ca, (q31_t)0x9ac67efb, (q31_t)0x4e52c1ab, (q31_t)0x9ac2a69e, + (q31_t)0x4e4dc95c, (q31_t)0x9abece80, + (q31_t)0x4e48d0dd, (q31_t)0x9abaf6a1, (q31_t)0x4e43d82d, (q31_t)0x9ab71eff, (q31_t)0x4e3edf4d, (q31_t)0x9ab3479d, + (q31_t)0x4e39e63d, (q31_t)0x9aaf7079, + (q31_t)0x4e34ecfc, (q31_t)0x9aab9993, (q31_t)0x4e2ff38b, (q31_t)0x9aa7c2ec, (q31_t)0x4e2af9ea, (q31_t)0x9aa3ec83, + (q31_t)0x4e260019, (q31_t)0x9aa01659, + (q31_t)0x4e210617, (q31_t)0x9a9c406e, (q31_t)0x4e1c0be6, (q31_t)0x9a986ac1, (q31_t)0x4e171184, (q31_t)0x9a949552, + (q31_t)0x4e1216f2, (q31_t)0x9a90c022, + (q31_t)0x4e0d1c30, (q31_t)0x9a8ceb31, (q31_t)0x4e08213e, (q31_t)0x9a89167e, (q31_t)0x4e03261b, (q31_t)0x9a85420a, + (q31_t)0x4dfe2ac9, (q31_t)0x9a816dd5, + (q31_t)0x4df92f46, (q31_t)0x9a7d99de, (q31_t)0x4df43393, (q31_t)0x9a79c625, (q31_t)0x4def37b0, (q31_t)0x9a75f2ac, + (q31_t)0x4dea3b9d, (q31_t)0x9a721f71, + (q31_t)0x4de53f5a, (q31_t)0x9a6e4c74, (q31_t)0x4de042e7, (q31_t)0x9a6a79b6, (q31_t)0x4ddb4644, (q31_t)0x9a66a737, + (q31_t)0x4dd64971, (q31_t)0x9a62d4f7, + (q31_t)0x4dd14c6e, (q31_t)0x9a5f02f5, (q31_t)0x4dcc4f3b, (q31_t)0x9a5b3132, (q31_t)0x4dc751d8, (q31_t)0x9a575fae, + (q31_t)0x4dc25445, (q31_t)0x9a538e68, + (q31_t)0x4dbd5682, (q31_t)0x9a4fbd61, (q31_t)0x4db8588f, (q31_t)0x9a4bec99, (q31_t)0x4db35a6c, (q31_t)0x9a481c0f, + (q31_t)0x4dae5c19, (q31_t)0x9a444bc5, + (q31_t)0x4da95d96, (q31_t)0x9a407bb9, (q31_t)0x4da45ee3, (q31_t)0x9a3cabeb, (q31_t)0x4d9f6001, (q31_t)0x9a38dc5d, + (q31_t)0x4d9a60ee, (q31_t)0x9a350d0d, + (q31_t)0x4d9561ac, (q31_t)0x9a313dfc, (q31_t)0x4d90623a, (q31_t)0x9a2d6f2a, (q31_t)0x4d8b6298, (q31_t)0x9a29a097, + (q31_t)0x4d8662c6, (q31_t)0x9a25d243, + (q31_t)0x4d8162c4, (q31_t)0x9a22042d, (q31_t)0x4d7c6293, (q31_t)0x9a1e3656, (q31_t)0x4d776231, (q31_t)0x9a1a68be, + (q31_t)0x4d7261a0, (q31_t)0x9a169b65, + (q31_t)0x4d6d60df, (q31_t)0x9a12ce4b, (q31_t)0x4d685fef, (q31_t)0x9a0f016f, (q31_t)0x4d635ece, (q31_t)0x9a0b34d3, + (q31_t)0x4d5e5d7e, (q31_t)0x9a076875, + (q31_t)0x4d595bfe, (q31_t)0x9a039c57, (q31_t)0x4d545a4f, (q31_t)0x99ffd077, (q31_t)0x4d4f5870, (q31_t)0x99fc04d6, + (q31_t)0x4d4a5661, (q31_t)0x99f83974, + (q31_t)0x4d455422, (q31_t)0x99f46e51, (q31_t)0x4d4051b4, (q31_t)0x99f0a36d, (q31_t)0x4d3b4f16, (q31_t)0x99ecd8c8, + (q31_t)0x4d364c48, (q31_t)0x99e90e62, + (q31_t)0x4d31494b, (q31_t)0x99e5443b, (q31_t)0x4d2c461e, (q31_t)0x99e17a53, (q31_t)0x4d2742c2, (q31_t)0x99ddb0aa, + (q31_t)0x4d223f36, (q31_t)0x99d9e73f, + (q31_t)0x4d1d3b7a, (q31_t)0x99d61e14, (q31_t)0x4d18378f, (q31_t)0x99d25528, (q31_t)0x4d133374, (q31_t)0x99ce8c7b, + (q31_t)0x4d0e2f2a, (q31_t)0x99cac40d, + (q31_t)0x4d092ab0, (q31_t)0x99c6fbde, (q31_t)0x4d042607, (q31_t)0x99c333ee, (q31_t)0x4cff212e, (q31_t)0x99bf6c3d, + (q31_t)0x4cfa1c26, (q31_t)0x99bba4cb, + (q31_t)0x4cf516ee, (q31_t)0x99b7dd99, (q31_t)0x4cf01187, (q31_t)0x99b416a5, (q31_t)0x4ceb0bf0, (q31_t)0x99b04ff0, + (q31_t)0x4ce6062a, (q31_t)0x99ac897b, + (q31_t)0x4ce10034, (q31_t)0x99a8c345, (q31_t)0x4cdbfa0f, (q31_t)0x99a4fd4d, (q31_t)0x4cd6f3bb, (q31_t)0x99a13795, + (q31_t)0x4cd1ed37, (q31_t)0x999d721c, + (q31_t)0x4ccce684, (q31_t)0x9999ace3, (q31_t)0x4cc7dfa1, (q31_t)0x9995e7e8, (q31_t)0x4cc2d88f, (q31_t)0x9992232d, + (q31_t)0x4cbdd14e, (q31_t)0x998e5eb1, + (q31_t)0x4cb8c9dd, (q31_t)0x998a9a74, (q31_t)0x4cb3c23d, (q31_t)0x9986d676, (q31_t)0x4caeba6e, (q31_t)0x998312b7, + (q31_t)0x4ca9b26f, (q31_t)0x997f4f38, + (q31_t)0x4ca4aa41, (q31_t)0x997b8bf8, (q31_t)0x4c9fa1e4, (q31_t)0x9977c8f7, (q31_t)0x4c9a9958, (q31_t)0x99740635, + (q31_t)0x4c95909c, (q31_t)0x997043b2, + (q31_t)0x4c9087b1, (q31_t)0x996c816f, (q31_t)0x4c8b7e97, (q31_t)0x9968bf6b, (q31_t)0x4c86754e, (q31_t)0x9964fda7, + (q31_t)0x4c816bd5, (q31_t)0x99613c22, + (q31_t)0x4c7c622d, (q31_t)0x995d7adc, (q31_t)0x4c775856, (q31_t)0x9959b9d5, (q31_t)0x4c724e50, (q31_t)0x9955f90d, + (q31_t)0x4c6d441b, (q31_t)0x99523885, + (q31_t)0x4c6839b7, (q31_t)0x994e783d, (q31_t)0x4c632f23, (q31_t)0x994ab833, (q31_t)0x4c5e2460, (q31_t)0x9946f869, + (q31_t)0x4c59196f, (q31_t)0x994338df, + (q31_t)0x4c540e4e, (q31_t)0x993f7993, (q31_t)0x4c4f02fe, (q31_t)0x993bba87, (q31_t)0x4c49f77f, (q31_t)0x9937fbbb, + (q31_t)0x4c44ebd1, (q31_t)0x99343d2e, + (q31_t)0x4c3fdff4, (q31_t)0x99307ee0, (q31_t)0x4c3ad3e7, (q31_t)0x992cc0d2, (q31_t)0x4c35c7ac, (q31_t)0x99290303, + (q31_t)0x4c30bb42, (q31_t)0x99254574, + (q31_t)0x4c2baea9, (q31_t)0x99218824, (q31_t)0x4c26a1e1, (q31_t)0x991dcb13, (q31_t)0x4c2194e9, (q31_t)0x991a0e42, + (q31_t)0x4c1c87c3, (q31_t)0x991651b1, + (q31_t)0x4c177a6e, (q31_t)0x9912955f, (q31_t)0x4c126cea, (q31_t)0x990ed94c, (q31_t)0x4c0d5f37, (q31_t)0x990b1d79, + (q31_t)0x4c085156, (q31_t)0x990761e5, + (q31_t)0x4c034345, (q31_t)0x9903a691, (q31_t)0x4bfe3505, (q31_t)0x98ffeb7d, (q31_t)0x4bf92697, (q31_t)0x98fc30a8, + (q31_t)0x4bf417f9, (q31_t)0x98f87612, + (q31_t)0x4bef092d, (q31_t)0x98f4bbbc, (q31_t)0x4be9fa32, (q31_t)0x98f101a6, (q31_t)0x4be4eb08, (q31_t)0x98ed47cf, + (q31_t)0x4bdfdbaf, (q31_t)0x98e98e38, + (q31_t)0x4bdacc28, (q31_t)0x98e5d4e0, (q31_t)0x4bd5bc72, (q31_t)0x98e21bc8, (q31_t)0x4bd0ac8d, (q31_t)0x98de62f0, + (q31_t)0x4bcb9c79, (q31_t)0x98daaa57, + (q31_t)0x4bc68c36, (q31_t)0x98d6f1fe, (q31_t)0x4bc17bc5, (q31_t)0x98d339e4, (q31_t)0x4bbc6b25, (q31_t)0x98cf820b, + (q31_t)0x4bb75a56, (q31_t)0x98cbca70, + (q31_t)0x4bb24958, (q31_t)0x98c81316, (q31_t)0x4bad382c, (q31_t)0x98c45bfb, (q31_t)0x4ba826d1, (q31_t)0x98c0a520, + (q31_t)0x4ba31548, (q31_t)0x98bcee84, + (q31_t)0x4b9e0390, (q31_t)0x98b93828, (q31_t)0x4b98f1a9, (q31_t)0x98b5820c, (q31_t)0x4b93df93, (q31_t)0x98b1cc30, + (q31_t)0x4b8ecd4f, (q31_t)0x98ae1693, + (q31_t)0x4b89badd, (q31_t)0x98aa6136, (q31_t)0x4b84a83b, (q31_t)0x98a6ac19, (q31_t)0x4b7f956b, (q31_t)0x98a2f73c, + (q31_t)0x4b7a826d, (q31_t)0x989f429e, + (q31_t)0x4b756f40, (q31_t)0x989b8e40, (q31_t)0x4b705be4, (q31_t)0x9897da22, (q31_t)0x4b6b485a, (q31_t)0x98942643, + (q31_t)0x4b6634a2, (q31_t)0x989072a5, + (q31_t)0x4b6120bb, (q31_t)0x988cbf46, (q31_t)0x4b5c0ca5, (q31_t)0x98890c27, (q31_t)0x4b56f861, (q31_t)0x98855948, + (q31_t)0x4b51e3ee, (q31_t)0x9881a6a9, + (q31_t)0x4b4ccf4d, (q31_t)0x987df449, (q31_t)0x4b47ba7e, (q31_t)0x987a422a, (q31_t)0x4b42a580, (q31_t)0x9876904a, + (q31_t)0x4b3d9053, (q31_t)0x9872deaa, + (q31_t)0x4b387af9, (q31_t)0x986f2d4a, (q31_t)0x4b336570, (q31_t)0x986b7c2a, (q31_t)0x4b2e4fb8, (q31_t)0x9867cb4a, + (q31_t)0x4b2939d2, (q31_t)0x98641aa9, + (q31_t)0x4b2423be, (q31_t)0x98606a49, (q31_t)0x4b1f0d7b, (q31_t)0x985cba28, (q31_t)0x4b19f70a, (q31_t)0x98590a48, + (q31_t)0x4b14e06b, (q31_t)0x98555aa7, + (q31_t)0x4b0fc99d, (q31_t)0x9851ab46, (q31_t)0x4b0ab2a1, (q31_t)0x984dfc26, (q31_t)0x4b059b77, (q31_t)0x984a4d45, + (q31_t)0x4b00841f, (q31_t)0x98469ea4, + (q31_t)0x4afb6c98, (q31_t)0x9842f043, (q31_t)0x4af654e3, (q31_t)0x983f4223, (q31_t)0x4af13d00, (q31_t)0x983b9442, + (q31_t)0x4aec24ee, (q31_t)0x9837e6a1, + (q31_t)0x4ae70caf, (q31_t)0x98343940, (q31_t)0x4ae1f441, (q31_t)0x98308c1f, (q31_t)0x4adcdba5, (q31_t)0x982cdf3f, + (q31_t)0x4ad7c2da, (q31_t)0x9829329e, + (q31_t)0x4ad2a9e2, (q31_t)0x9825863d, (q31_t)0x4acd90bb, (q31_t)0x9821da1d, (q31_t)0x4ac87767, (q31_t)0x981e2e3c, + (q31_t)0x4ac35de4, (q31_t)0x981a829c, + (q31_t)0x4abe4433, (q31_t)0x9816d73b, (q31_t)0x4ab92a54, (q31_t)0x98132c1b, (q31_t)0x4ab41046, (q31_t)0x980f813b, + (q31_t)0x4aaef60b, (q31_t)0x980bd69b, + (q31_t)0x4aa9dba2, (q31_t)0x98082c3b, (q31_t)0x4aa4c10b, (q31_t)0x9804821b, (q31_t)0x4a9fa645, (q31_t)0x9800d83c, + (q31_t)0x4a9a8b52, (q31_t)0x97fd2e9c, + (q31_t)0x4a957030, (q31_t)0x97f9853d, (q31_t)0x4a9054e1, (q31_t)0x97f5dc1e, (q31_t)0x4a8b3963, (q31_t)0x97f2333f, + (q31_t)0x4a861db8, (q31_t)0x97ee8aa0, + (q31_t)0x4a8101de, (q31_t)0x97eae242, (q31_t)0x4a7be5d7, (q31_t)0x97e73a23, (q31_t)0x4a76c9a2, (q31_t)0x97e39245, + (q31_t)0x4a71ad3e, (q31_t)0x97dfeaa7, + (q31_t)0x4a6c90ad, (q31_t)0x97dc4349, (q31_t)0x4a6773ee, (q31_t)0x97d89c2c, (q31_t)0x4a625701, (q31_t)0x97d4f54f, + (q31_t)0x4a5d39e6, (q31_t)0x97d14eb2, + (q31_t)0x4a581c9e, (q31_t)0x97cda855, (q31_t)0x4a52ff27, (q31_t)0x97ca0239, (q31_t)0x4a4de182, (q31_t)0x97c65c5c, + (q31_t)0x4a48c3b0, (q31_t)0x97c2b6c1, + (q31_t)0x4a43a5b0, (q31_t)0x97bf1165, (q31_t)0x4a3e8782, (q31_t)0x97bb6c4a, (q31_t)0x4a396926, (q31_t)0x97b7c76f, + (q31_t)0x4a344a9d, (q31_t)0x97b422d4, + (q31_t)0x4a2f2be6, (q31_t)0x97b07e7a, (q31_t)0x4a2a0d01, (q31_t)0x97acda60, (q31_t)0x4a24edee, (q31_t)0x97a93687, + (q31_t)0x4a1fcead, (q31_t)0x97a592ed, + (q31_t)0x4a1aaf3f, (q31_t)0x97a1ef94, (q31_t)0x4a158fa3, (q31_t)0x979e4c7c, (q31_t)0x4a106fda, (q31_t)0x979aa9a4, + (q31_t)0x4a0b4fe2, (q31_t)0x9797070c, + (q31_t)0x4a062fbd, (q31_t)0x979364b5, (q31_t)0x4a010f6b, (q31_t)0x978fc29e, (q31_t)0x49fbeeea, (q31_t)0x978c20c8, + (q31_t)0x49f6ce3c, (q31_t)0x97887f32, + (q31_t)0x49f1ad61, (q31_t)0x9784dddc, (q31_t)0x49ec8c57, (q31_t)0x97813cc7, (q31_t)0x49e76b21, (q31_t)0x977d9bf2, + (q31_t)0x49e249bc, (q31_t)0x9779fb5e, + (q31_t)0x49dd282a, (q31_t)0x97765b0a, (q31_t)0x49d8066b, (q31_t)0x9772baf7, (q31_t)0x49d2e47e, (q31_t)0x976f1b24, + (q31_t)0x49cdc263, (q31_t)0x976b7b92, + (q31_t)0x49c8a01b, (q31_t)0x9767dc41, (q31_t)0x49c37da5, (q31_t)0x97643d2f, (q31_t)0x49be5b02, (q31_t)0x97609e5f, + (q31_t)0x49b93832, (q31_t)0x975cffcf, + (q31_t)0x49b41533, (q31_t)0x9759617f, (q31_t)0x49aef208, (q31_t)0x9755c370, (q31_t)0x49a9ceaf, (q31_t)0x975225a1, + (q31_t)0x49a4ab28, (q31_t)0x974e8813, + (q31_t)0x499f8774, (q31_t)0x974aeac6, (q31_t)0x499a6393, (q31_t)0x97474db9, (q31_t)0x49953f84, (q31_t)0x9743b0ed, + (q31_t)0x49901b48, (q31_t)0x97401462, + (q31_t)0x498af6df, (q31_t)0x973c7817, (q31_t)0x4985d248, (q31_t)0x9738dc0d, (q31_t)0x4980ad84, (q31_t)0x97354043, + (q31_t)0x497b8892, (q31_t)0x9731a4ba, + (q31_t)0x49766373, (q31_t)0x972e0971, (q31_t)0x49713e27, (q31_t)0x972a6e6a, (q31_t)0x496c18ae, (q31_t)0x9726d3a3, + (q31_t)0x4966f307, (q31_t)0x9723391c, + (q31_t)0x4961cd33, (q31_t)0x971f9ed7, (q31_t)0x495ca732, (q31_t)0x971c04d2, (q31_t)0x49578103, (q31_t)0x97186b0d, + (q31_t)0x49525aa7, (q31_t)0x9714d18a, + (q31_t)0x494d341e, (q31_t)0x97113847, (q31_t)0x49480d68, (q31_t)0x970d9f45, (q31_t)0x4942e684, (q31_t)0x970a0683, + (q31_t)0x493dbf74, (q31_t)0x97066e03, + (q31_t)0x49389836, (q31_t)0x9702d5c3, (q31_t)0x493370cb, (q31_t)0x96ff3dc4, (q31_t)0x492e4933, (q31_t)0x96fba605, + (q31_t)0x4929216e, (q31_t)0x96f80e88, + (q31_t)0x4923f97b, (q31_t)0x96f4774b, (q31_t)0x491ed15c, (q31_t)0x96f0e04f, (q31_t)0x4919a90f, (q31_t)0x96ed4994, + (q31_t)0x49148095, (q31_t)0x96e9b319, + (q31_t)0x490f57ee, (q31_t)0x96e61ce0, (q31_t)0x490a2f1b, (q31_t)0x96e286e7, (q31_t)0x4905061a, (q31_t)0x96def12f, + (q31_t)0x48ffdcec, (q31_t)0x96db5bb8, + (q31_t)0x48fab391, (q31_t)0x96d7c682, (q31_t)0x48f58a09, (q31_t)0x96d4318d, (q31_t)0x48f06054, (q31_t)0x96d09cd8, + (q31_t)0x48eb3672, (q31_t)0x96cd0865, + (q31_t)0x48e60c62, (q31_t)0x96c97432, (q31_t)0x48e0e227, (q31_t)0x96c5e040, (q31_t)0x48dbb7be, (q31_t)0x96c24c8f, + (q31_t)0x48d68d28, (q31_t)0x96beb91f, + (q31_t)0x48d16265, (q31_t)0x96bb25f0, (q31_t)0x48cc3775, (q31_t)0x96b79302, (q31_t)0x48c70c59, (q31_t)0x96b40055, + (q31_t)0x48c1e10f, (q31_t)0x96b06de9, + (q31_t)0x48bcb599, (q31_t)0x96acdbbe, (q31_t)0x48b789f5, (q31_t)0x96a949d3, (q31_t)0x48b25e25, (q31_t)0x96a5b82a, + (q31_t)0x48ad3228, (q31_t)0x96a226c2, + (q31_t)0x48a805ff, (q31_t)0x969e959b, (q31_t)0x48a2d9a8, (q31_t)0x969b04b4, (q31_t)0x489dad25, (q31_t)0x9697740f, + (q31_t)0x48988074, (q31_t)0x9693e3ab, + (q31_t)0x48935397, (q31_t)0x96905388, (q31_t)0x488e268e, (q31_t)0x968cc3a5, (q31_t)0x4888f957, (q31_t)0x96893404, + (q31_t)0x4883cbf4, (q31_t)0x9685a4a4, + (q31_t)0x487e9e64, (q31_t)0x96821585, (q31_t)0x487970a7, (q31_t)0x967e86a7, (q31_t)0x487442be, (q31_t)0x967af80a, + (q31_t)0x486f14a8, (q31_t)0x967769af, + (q31_t)0x4869e665, (q31_t)0x9673db94, (q31_t)0x4864b7f5, (q31_t)0x96704dba, (q31_t)0x485f8959, (q31_t)0x966cc022, + (q31_t)0x485a5a90, (q31_t)0x966932cb, + (q31_t)0x48552b9b, (q31_t)0x9665a5b4, (q31_t)0x484ffc79, (q31_t)0x966218df, (q31_t)0x484acd2a, (q31_t)0x965e8c4b, + (q31_t)0x48459daf, (q31_t)0x965afff9, + (q31_t)0x48406e08, (q31_t)0x965773e7, (q31_t)0x483b3e33, (q31_t)0x9653e817, (q31_t)0x48360e32, (q31_t)0x96505c88, + (q31_t)0x4830de05, (q31_t)0x964cd139, + (q31_t)0x482badab, (q31_t)0x9649462d, (q31_t)0x48267d24, (q31_t)0x9645bb61, (q31_t)0x48214c71, (q31_t)0x964230d7, + (q31_t)0x481c1b92, (q31_t)0x963ea68d, + (q31_t)0x4816ea86, (q31_t)0x963b1c86, (q31_t)0x4811b94d, (q31_t)0x963792bf, (q31_t)0x480c87e8, (q31_t)0x96340939, + (q31_t)0x48075657, (q31_t)0x96307ff5, + (q31_t)0x48022499, (q31_t)0x962cf6f2, (q31_t)0x47fcf2af, (q31_t)0x96296e31, (q31_t)0x47f7c099, (q31_t)0x9625e5b0, + (q31_t)0x47f28e56, (q31_t)0x96225d71, + (q31_t)0x47ed5be6, (q31_t)0x961ed574, (q31_t)0x47e8294a, (q31_t)0x961b4db7, (q31_t)0x47e2f682, (q31_t)0x9617c63c, + (q31_t)0x47ddc38e, (q31_t)0x96143f02, + (q31_t)0x47d8906d, (q31_t)0x9610b80a, (q31_t)0x47d35d20, (q31_t)0x960d3153, (q31_t)0x47ce29a7, (q31_t)0x9609aadd, + (q31_t)0x47c8f601, (q31_t)0x960624a9, + (q31_t)0x47c3c22f, (q31_t)0x96029eb6, (q31_t)0x47be8e31, (q31_t)0x95ff1904, (q31_t)0x47b95a06, (q31_t)0x95fb9394, + (q31_t)0x47b425af, (q31_t)0x95f80e65, + (q31_t)0x47aef12c, (q31_t)0x95f48977, (q31_t)0x47a9bc7d, (q31_t)0x95f104cb, (q31_t)0x47a487a2, (q31_t)0x95ed8061, + (q31_t)0x479f529a, (q31_t)0x95e9fc38, + (q31_t)0x479a1d67, (q31_t)0x95e67850, (q31_t)0x4794e807, (q31_t)0x95e2f4a9, (q31_t)0x478fb27b, (q31_t)0x95df7145, + (q31_t)0x478a7cc2, (q31_t)0x95dbee21, + (q31_t)0x478546de, (q31_t)0x95d86b3f, (q31_t)0x478010cd, (q31_t)0x95d4e89f, (q31_t)0x477ada91, (q31_t)0x95d16640, + (q31_t)0x4775a428, (q31_t)0x95cde423, + (q31_t)0x47706d93, (q31_t)0x95ca6247, (q31_t)0x476b36d3, (q31_t)0x95c6e0ac, (q31_t)0x4765ffe6, (q31_t)0x95c35f53, + (q31_t)0x4760c8cd, (q31_t)0x95bfde3c, + (q31_t)0x475b9188, (q31_t)0x95bc5d66, (q31_t)0x47565a17, (q31_t)0x95b8dcd2, (q31_t)0x4751227a, (q31_t)0x95b55c7f, + (q31_t)0x474beab1, (q31_t)0x95b1dc6e, + (q31_t)0x4746b2bc, (q31_t)0x95ae5c9f, (q31_t)0x47417a9b, (q31_t)0x95aadd11, (q31_t)0x473c424e, (q31_t)0x95a75dc4, + (q31_t)0x473709d5, (q31_t)0x95a3deb9, + (q31_t)0x4731d131, (q31_t)0x95a05ff0, (q31_t)0x472c9860, (q31_t)0x959ce169, (q31_t)0x47275f63, (q31_t)0x95996323, + (q31_t)0x4722263b, (q31_t)0x9595e51e, + (q31_t)0x471cece7, (q31_t)0x9592675c, (q31_t)0x4717b367, (q31_t)0x958ee9db, (q31_t)0x471279ba, (q31_t)0x958b6c9b, + (q31_t)0x470d3fe3, (q31_t)0x9587ef9e, + (q31_t)0x470805df, (q31_t)0x958472e2, (q31_t)0x4702cbaf, (q31_t)0x9580f667, (q31_t)0x46fd9154, (q31_t)0x957d7a2f, + (q31_t)0x46f856cd, (q31_t)0x9579fe38, + (q31_t)0x46f31c1a, (q31_t)0x95768283, (q31_t)0x46ede13b, (q31_t)0x9573070f, (q31_t)0x46e8a631, (q31_t)0x956f8bdd, + (q31_t)0x46e36afb, (q31_t)0x956c10ed, + (q31_t)0x46de2f99, (q31_t)0x9568963f, (q31_t)0x46d8f40b, (q31_t)0x95651bd2, (q31_t)0x46d3b852, (q31_t)0x9561a1a8, + (q31_t)0x46ce7c6d, (q31_t)0x955e27bf, + (q31_t)0x46c9405c, (q31_t)0x955aae17, (q31_t)0x46c40420, (q31_t)0x955734b2, (q31_t)0x46bec7b8, (q31_t)0x9553bb8e, + (q31_t)0x46b98b24, (q31_t)0x955042ac, + (q31_t)0x46b44e65, (q31_t)0x954cca0c, (q31_t)0x46af117a, (q31_t)0x954951ae, (q31_t)0x46a9d464, (q31_t)0x9545d992, + (q31_t)0x46a49722, (q31_t)0x954261b7, + (q31_t)0x469f59b4, (q31_t)0x953eea1e, (q31_t)0x469a1c1b, (q31_t)0x953b72c7, (q31_t)0x4694de56, (q31_t)0x9537fbb2, + (q31_t)0x468fa066, (q31_t)0x953484df, + (q31_t)0x468a624a, (q31_t)0x95310e4e, (q31_t)0x46852403, (q31_t)0x952d97fe, (q31_t)0x467fe590, (q31_t)0x952a21f1, + (q31_t)0x467aa6f2, (q31_t)0x9526ac25, + (q31_t)0x46756828, (q31_t)0x9523369c, (q31_t)0x46702933, (q31_t)0x951fc154, (q31_t)0x466aea12, (q31_t)0x951c4c4e, + (q31_t)0x4665aac6, (q31_t)0x9518d78a, + (q31_t)0x46606b4e, (q31_t)0x95156308, (q31_t)0x465b2bab, (q31_t)0x9511eec8, (q31_t)0x4655ebdd, (q31_t)0x950e7aca, + (q31_t)0x4650abe3, (q31_t)0x950b070e, + (q31_t)0x464b6bbe, (q31_t)0x95079394, (q31_t)0x46462b6d, (q31_t)0x9504205c, (q31_t)0x4640eaf2, (q31_t)0x9500ad66, + (q31_t)0x463baa4a, (q31_t)0x94fd3ab1, + (q31_t)0x46366978, (q31_t)0x94f9c83f, (q31_t)0x4631287a, (q31_t)0x94f6560f, (q31_t)0x462be751, (q31_t)0x94f2e421, + (q31_t)0x4626a5fd, (q31_t)0x94ef7275, + (q31_t)0x4621647d, (q31_t)0x94ec010b, (q31_t)0x461c22d2, (q31_t)0x94e88fe3, (q31_t)0x4616e0fc, (q31_t)0x94e51efd, + (q31_t)0x46119efa, (q31_t)0x94e1ae59, + (q31_t)0x460c5cce, (q31_t)0x94de3df8, (q31_t)0x46071a76, (q31_t)0x94dacdd8, (q31_t)0x4601d7f3, (q31_t)0x94d75dfa, + (q31_t)0x45fc9545, (q31_t)0x94d3ee5f, + (q31_t)0x45f7526b, (q31_t)0x94d07f05, (q31_t)0x45f20f67, (q31_t)0x94cd0fee, (q31_t)0x45eccc37, (q31_t)0x94c9a119, + (q31_t)0x45e788dc, (q31_t)0x94c63286, + (q31_t)0x45e24556, (q31_t)0x94c2c435, (q31_t)0x45dd01a5, (q31_t)0x94bf5627, (q31_t)0x45d7bdc9, (q31_t)0x94bbe85a, + (q31_t)0x45d279c2, (q31_t)0x94b87ad0, + (q31_t)0x45cd358f, (q31_t)0x94b50d87, (q31_t)0x45c7f132, (q31_t)0x94b1a081, (q31_t)0x45c2acaa, (q31_t)0x94ae33be, + (q31_t)0x45bd67f6, (q31_t)0x94aac73c, + (q31_t)0x45b82318, (q31_t)0x94a75afd, (q31_t)0x45b2de0e, (q31_t)0x94a3eeff, (q31_t)0x45ad98da, (q31_t)0x94a08344, + (q31_t)0x45a8537a, (q31_t)0x949d17cc, + (q31_t)0x45a30df0, (q31_t)0x9499ac95, (q31_t)0x459dc83b, (q31_t)0x949641a1, (q31_t)0x4598825a, (q31_t)0x9492d6ef, + (q31_t)0x45933c4f, (q31_t)0x948f6c7f, + (q31_t)0x458df619, (q31_t)0x948c0252, (q31_t)0x4588afb8, (q31_t)0x94889867, (q31_t)0x4583692c, (q31_t)0x94852ebe, + (q31_t)0x457e2275, (q31_t)0x9481c557, + (q31_t)0x4578db93, (q31_t)0x947e5c33, (q31_t)0x45739487, (q31_t)0x947af351, (q31_t)0x456e4d4f, (q31_t)0x94778ab1, + (q31_t)0x456905ed, (q31_t)0x94742254, + (q31_t)0x4563be60, (q31_t)0x9470ba39, (q31_t)0x455e76a8, (q31_t)0x946d5260, (q31_t)0x45592ec6, (q31_t)0x9469eaca, + (q31_t)0x4553e6b8, (q31_t)0x94668376, + (q31_t)0x454e9e80, (q31_t)0x94631c65, (q31_t)0x4549561d, (q31_t)0x945fb596, (q31_t)0x45440d90, (q31_t)0x945c4f09, + (q31_t)0x453ec4d7, (q31_t)0x9458e8bf, + (q31_t)0x45397bf4, (q31_t)0x945582b7, (q31_t)0x453432e6, (q31_t)0x94521cf1, (q31_t)0x452ee9ae, (q31_t)0x944eb76e, + (q31_t)0x4529a04b, (q31_t)0x944b522d, + (q31_t)0x452456bd, (q31_t)0x9447ed2f, (q31_t)0x451f0d04, (q31_t)0x94448873, (q31_t)0x4519c321, (q31_t)0x944123fa, + (q31_t)0x45147913, (q31_t)0x943dbfc3, + (q31_t)0x450f2edb, (q31_t)0x943a5bcf, (q31_t)0x4509e478, (q31_t)0x9436f81d, (q31_t)0x450499eb, (q31_t)0x943394ad, + (q31_t)0x44ff4f32, (q31_t)0x94303180, + (q31_t)0x44fa0450, (q31_t)0x942cce96, (q31_t)0x44f4b943, (q31_t)0x94296bee, (q31_t)0x44ef6e0b, (q31_t)0x94260989, + (q31_t)0x44ea22a9, (q31_t)0x9422a766, + (q31_t)0x44e4d71c, (q31_t)0x941f4585, (q31_t)0x44df8b64, (q31_t)0x941be3e8, (q31_t)0x44da3f83, (q31_t)0x9418828c, + (q31_t)0x44d4f376, (q31_t)0x94152174, + (q31_t)0x44cfa740, (q31_t)0x9411c09e, (q31_t)0x44ca5adf, (q31_t)0x940e600a, (q31_t)0x44c50e53, (q31_t)0x940affb9, + (q31_t)0x44bfc19d, (q31_t)0x94079fab, + (q31_t)0x44ba74bd, (q31_t)0x94043fdf, (q31_t)0x44b527b2, (q31_t)0x9400e056, (q31_t)0x44afda7d, (q31_t)0x93fd810f, + (q31_t)0x44aa8d1d, (q31_t)0x93fa220b, + (q31_t)0x44a53f93, (q31_t)0x93f6c34a, (q31_t)0x449ff1df, (q31_t)0x93f364cb, (q31_t)0x449aa400, (q31_t)0x93f0068f, + (q31_t)0x449555f7, (q31_t)0x93eca896, + (q31_t)0x449007c4, (q31_t)0x93e94adf, (q31_t)0x448ab967, (q31_t)0x93e5ed6b, (q31_t)0x44856adf, (q31_t)0x93e2903a, + (q31_t)0x44801c2d, (q31_t)0x93df334c, + (q31_t)0x447acd50, (q31_t)0x93dbd6a0, (q31_t)0x44757e4a, (q31_t)0x93d87a36, (q31_t)0x44702f19, (q31_t)0x93d51e10, + (q31_t)0x446adfbe, (q31_t)0x93d1c22c, + (q31_t)0x44659039, (q31_t)0x93ce668b, (q31_t)0x44604089, (q31_t)0x93cb0b2d, (q31_t)0x445af0b0, (q31_t)0x93c7b011, + (q31_t)0x4455a0ac, (q31_t)0x93c45539, + (q31_t)0x4450507e, (q31_t)0x93c0faa3, (q31_t)0x444b0026, (q31_t)0x93bda04f, (q31_t)0x4445afa4, (q31_t)0x93ba463f, + (q31_t)0x44405ef8, (q31_t)0x93b6ec71, + (q31_t)0x443b0e21, (q31_t)0x93b392e6, (q31_t)0x4435bd21, (q31_t)0x93b0399e, (q31_t)0x44306bf6, (q31_t)0x93ace099, + (q31_t)0x442b1aa2, (q31_t)0x93a987d6, + (q31_t)0x4425c923, (q31_t)0x93a62f57, (q31_t)0x4420777b, (q31_t)0x93a2d71a, (q31_t)0x441b25a8, (q31_t)0x939f7f20, + (q31_t)0x4415d3ab, (q31_t)0x939c2769, + (q31_t)0x44108184, (q31_t)0x9398cff5, (q31_t)0x440b2f34, (q31_t)0x939578c3, (q31_t)0x4405dcb9, (q31_t)0x939221d5, + (q31_t)0x44008a14, (q31_t)0x938ecb29, + (q31_t)0x43fb3746, (q31_t)0x938b74c1, (q31_t)0x43f5e44d, (q31_t)0x93881e9b, (q31_t)0x43f0912b, (q31_t)0x9384c8b8, + (q31_t)0x43eb3ddf, (q31_t)0x93817318, + (q31_t)0x43e5ea68, (q31_t)0x937e1dbb, (q31_t)0x43e096c8, (q31_t)0x937ac8a1, (q31_t)0x43db42fe, (q31_t)0x937773ca, + (q31_t)0x43d5ef0a, (q31_t)0x93741f35, + (q31_t)0x43d09aed, (q31_t)0x9370cae4, (q31_t)0x43cb46a5, (q31_t)0x936d76d6, (q31_t)0x43c5f234, (q31_t)0x936a230a, + (q31_t)0x43c09d99, (q31_t)0x9366cf82, + (q31_t)0x43bb48d4, (q31_t)0x93637c3d, (q31_t)0x43b5f3e5, (q31_t)0x9360293a, (q31_t)0x43b09ecc, (q31_t)0x935cd67b, + (q31_t)0x43ab498a, (q31_t)0x935983ff, + (q31_t)0x43a5f41e, (q31_t)0x935631c5, (q31_t)0x43a09e89, (q31_t)0x9352dfcf, (q31_t)0x439b48c9, (q31_t)0x934f8e1c, + (q31_t)0x4395f2e0, (q31_t)0x934c3cab, + (q31_t)0x43909ccd, (q31_t)0x9348eb7e, (q31_t)0x438b4691, (q31_t)0x93459a94, (q31_t)0x4385f02a, (q31_t)0x934249ed, + (q31_t)0x4380999b, (q31_t)0x933ef989, + (q31_t)0x437b42e1, (q31_t)0x933ba968, (q31_t)0x4375ebfe, (q31_t)0x9338598a, (q31_t)0x437094f1, (q31_t)0x933509f0, + (q31_t)0x436b3dbb, (q31_t)0x9331ba98, + (q31_t)0x4365e65b, (q31_t)0x932e6b84, (q31_t)0x43608ed2, (q31_t)0x932b1cb2, (q31_t)0x435b371f, (q31_t)0x9327ce24, + (q31_t)0x4355df42, (q31_t)0x93247fd9, + (q31_t)0x4350873c, (q31_t)0x932131d1, (q31_t)0x434b2f0c, (q31_t)0x931de40c, (q31_t)0x4345d6b3, (q31_t)0x931a968b, + (q31_t)0x43407e31, (q31_t)0x9317494c, + (q31_t)0x433b2585, (q31_t)0x9313fc51, (q31_t)0x4335ccaf, (q31_t)0x9310af99, (q31_t)0x433073b0, (q31_t)0x930d6324, + (q31_t)0x432b1a87, (q31_t)0x930a16f3, + (q31_t)0x4325c135, (q31_t)0x9306cb04, (q31_t)0x432067ba, (q31_t)0x93037f59, (q31_t)0x431b0e15, (q31_t)0x930033f1, + (q31_t)0x4315b447, (q31_t)0x92fce8cc, + (q31_t)0x43105a50, (q31_t)0x92f99deb, (q31_t)0x430b002f, (q31_t)0x92f6534c, (q31_t)0x4305a5e5, (q31_t)0x92f308f1, + (q31_t)0x43004b71, (q31_t)0x92efbeda, + (q31_t)0x42faf0d4, (q31_t)0x92ec7505, (q31_t)0x42f5960e, (q31_t)0x92e92b74, (q31_t)0x42f03b1e, (q31_t)0x92e5e226, + (q31_t)0x42eae005, (q31_t)0x92e2991c, + (q31_t)0x42e584c3, (q31_t)0x92df5054, (q31_t)0x42e02958, (q31_t)0x92dc07d0, (q31_t)0x42dacdc3, (q31_t)0x92d8bf90, + (q31_t)0x42d57205, (q31_t)0x92d57792, + (q31_t)0x42d0161e, (q31_t)0x92d22fd9, (q31_t)0x42caba0e, (q31_t)0x92cee862, (q31_t)0x42c55dd4, (q31_t)0x92cba12f, + (q31_t)0x42c00172, (q31_t)0x92c85a3f, + (q31_t)0x42baa4e6, (q31_t)0x92c51392, (q31_t)0x42b54831, (q31_t)0x92c1cd29, (q31_t)0x42afeb53, (q31_t)0x92be8703, + (q31_t)0x42aa8e4b, (q31_t)0x92bb4121, + (q31_t)0x42a5311b, (q31_t)0x92b7fb82, (q31_t)0x429fd3c1, (q31_t)0x92b4b626, (q31_t)0x429a763f, (q31_t)0x92b1710e, + (q31_t)0x42951893, (q31_t)0x92ae2c3a, + (q31_t)0x428fbabe, (q31_t)0x92aae7a8, (q31_t)0x428a5cc0, (q31_t)0x92a7a35a, (q31_t)0x4284fe99, (q31_t)0x92a45f50, + (q31_t)0x427fa049, (q31_t)0x92a11b89, + (q31_t)0x427a41d0, (q31_t)0x929dd806, (q31_t)0x4274e32e, (q31_t)0x929a94c6, (q31_t)0x426f8463, (q31_t)0x929751c9, + (q31_t)0x426a256f, (q31_t)0x92940f10, + (q31_t)0x4264c653, (q31_t)0x9290cc9b, (q31_t)0x425f670d, (q31_t)0x928d8a69, (q31_t)0x425a079e, (q31_t)0x928a487a, + (q31_t)0x4254a806, (q31_t)0x928706cf, + (q31_t)0x424f4845, (q31_t)0x9283c568, (q31_t)0x4249e85c, (q31_t)0x92808444, (q31_t)0x42448849, (q31_t)0x927d4363, + (q31_t)0x423f280e, (q31_t)0x927a02c7, + (q31_t)0x4239c7aa, (q31_t)0x9276c26d, (q31_t)0x4234671d, (q31_t)0x92738258, (q31_t)0x422f0667, (q31_t)0x92704286, + (q31_t)0x4229a588, (q31_t)0x926d02f7, + (q31_t)0x42244481, (q31_t)0x9269c3ac, (q31_t)0x421ee350, (q31_t)0x926684a5, (q31_t)0x421981f7, (q31_t)0x926345e1, + (q31_t)0x42142075, (q31_t)0x92600761, + (q31_t)0x420ebecb, (q31_t)0x925cc924, (q31_t)0x42095cf7, (q31_t)0x92598b2b, (q31_t)0x4203fafb, (q31_t)0x92564d76, + (q31_t)0x41fe98d6, (q31_t)0x92531005, + (q31_t)0x41f93689, (q31_t)0x924fd2d7, (q31_t)0x41f3d413, (q31_t)0x924c95ec, (q31_t)0x41ee7174, (q31_t)0x92495946, + (q31_t)0x41e90eac, (q31_t)0x92461ce3, + (q31_t)0x41e3abbc, (q31_t)0x9242e0c4, (q31_t)0x41de48a3, (q31_t)0x923fa4e8, (q31_t)0x41d8e561, (q31_t)0x923c6950, + (q31_t)0x41d381f7, (q31_t)0x92392dfc, + (q31_t)0x41ce1e65, (q31_t)0x9235f2ec, (q31_t)0x41c8baa9, (q31_t)0x9232b81f, (q31_t)0x41c356c5, (q31_t)0x922f7d96, + (q31_t)0x41bdf2b9, (q31_t)0x922c4351, + (q31_t)0x41b88e84, (q31_t)0x9229094f, (q31_t)0x41b32a26, (q31_t)0x9225cf91, (q31_t)0x41adc5a0, (q31_t)0x92229617, + (q31_t)0x41a860f1, (q31_t)0x921f5ce1, + (q31_t)0x41a2fc1a, (q31_t)0x921c23ef, (q31_t)0x419d971b, (q31_t)0x9218eb40, (q31_t)0x419831f3, (q31_t)0x9215b2d5, + (q31_t)0x4192cca2, (q31_t)0x92127aae, + (q31_t)0x418d6729, (q31_t)0x920f42cb, (q31_t)0x41880188, (q31_t)0x920c0b2c, (q31_t)0x41829bbe, (q31_t)0x9208d3d0, + (q31_t)0x417d35cb, (q31_t)0x92059cb8, + (q31_t)0x4177cfb1, (q31_t)0x920265e4, (q31_t)0x4172696e, (q31_t)0x91ff2f54, (q31_t)0x416d0302, (q31_t)0x91fbf908, + (q31_t)0x41679c6f, (q31_t)0x91f8c300, + (q31_t)0x416235b2, (q31_t)0x91f58d3b, (q31_t)0x415ccece, (q31_t)0x91f257bb, (q31_t)0x415767c1, (q31_t)0x91ef227e, + (q31_t)0x4152008c, (q31_t)0x91ebed85, + (q31_t)0x414c992f, (q31_t)0x91e8b8d0, (q31_t)0x414731a9, (q31_t)0x91e5845f, (q31_t)0x4141c9fb, (q31_t)0x91e25032, + (q31_t)0x413c6225, (q31_t)0x91df1c49, + (q31_t)0x4136fa27, (q31_t)0x91dbe8a4, (q31_t)0x41319200, (q31_t)0x91d8b542, (q31_t)0x412c29b1, (q31_t)0x91d58225, + (q31_t)0x4126c13a, (q31_t)0x91d24f4c, + (q31_t)0x4121589b, (q31_t)0x91cf1cb6, (q31_t)0x411befd3, (q31_t)0x91cbea65, (q31_t)0x411686e4, (q31_t)0x91c8b857, + (q31_t)0x41111dcc, (q31_t)0x91c5868e, + (q31_t)0x410bb48c, (q31_t)0x91c25508, (q31_t)0x41064b24, (q31_t)0x91bf23c7, (q31_t)0x4100e194, (q31_t)0x91bbf2c9, + (q31_t)0x40fb77dc, (q31_t)0x91b8c210, + (q31_t)0x40f60dfb, (q31_t)0x91b5919a, (q31_t)0x40f0a3f3, (q31_t)0x91b26169, (q31_t)0x40eb39c3, (q31_t)0x91af317c, + (q31_t)0x40e5cf6a, (q31_t)0x91ac01d2, + (q31_t)0x40e064ea, (q31_t)0x91a8d26d, (q31_t)0x40dafa41, (q31_t)0x91a5a34c, (q31_t)0x40d58f71, (q31_t)0x91a2746f, + (q31_t)0x40d02478, (q31_t)0x919f45d6, + (q31_t)0x40cab958, (q31_t)0x919c1781, (q31_t)0x40c54e0f, (q31_t)0x9198e970, (q31_t)0x40bfe29f, (q31_t)0x9195bba3, + (q31_t)0x40ba7706, (q31_t)0x91928e1a, + (q31_t)0x40b50b46, (q31_t)0x918f60d6, (q31_t)0x40af9f5e, (q31_t)0x918c33d5, (q31_t)0x40aa334e, (q31_t)0x91890719, + (q31_t)0x40a4c716, (q31_t)0x9185daa1, + (q31_t)0x409f5ab6, (q31_t)0x9182ae6d, (q31_t)0x4099ee2e, (q31_t)0x917f827d, (q31_t)0x4094817f, (q31_t)0x917c56d1, + (q31_t)0x408f14a7, (q31_t)0x91792b6a, + (q31_t)0x4089a7a8, (q31_t)0x91760047, (q31_t)0x40843a81, (q31_t)0x9172d567, (q31_t)0x407ecd32, (q31_t)0x916faacc, + (q31_t)0x40795fbc, (q31_t)0x916c8076, + (q31_t)0x4073f21d, (q31_t)0x91695663, (q31_t)0x406e8457, (q31_t)0x91662c95, (q31_t)0x40691669, (q31_t)0x9163030b, + (q31_t)0x4063a854, (q31_t)0x915fd9c5, + (q31_t)0x405e3a16, (q31_t)0x915cb0c3, (q31_t)0x4058cbb1, (q31_t)0x91598806, (q31_t)0x40535d24, (q31_t)0x91565f8d, + (q31_t)0x404dee70, (q31_t)0x91533758, + (q31_t)0x40487f94, (q31_t)0x91500f67, (q31_t)0x40431090, (q31_t)0x914ce7bb, (q31_t)0x403da165, (q31_t)0x9149c053, + (q31_t)0x40383212, (q31_t)0x9146992f, + (q31_t)0x4032c297, (q31_t)0x91437250, (q31_t)0x402d52f5, (q31_t)0x91404bb5, (q31_t)0x4027e32b, (q31_t)0x913d255e, + (q31_t)0x4022733a, (q31_t)0x9139ff4b, + (q31_t)0x401d0321, (q31_t)0x9136d97d, (q31_t)0x401792e0, (q31_t)0x9133b3f3, (q31_t)0x40122278, (q31_t)0x91308eae, + (q31_t)0x400cb1e9, (q31_t)0x912d69ad, + (q31_t)0x40074132, (q31_t)0x912a44f0, (q31_t)0x4001d053, (q31_t)0x91272078, (q31_t)0x3ffc5f4d, (q31_t)0x9123fc44, + (q31_t)0x3ff6ee1f, (q31_t)0x9120d854, + (q31_t)0x3ff17cca, (q31_t)0x911db4a9, (q31_t)0x3fec0b4e, (q31_t)0x911a9142, (q31_t)0x3fe699aa, (q31_t)0x91176e1f, + (q31_t)0x3fe127df, (q31_t)0x91144b41, + (q31_t)0x3fdbb5ec, (q31_t)0x911128a8, (q31_t)0x3fd643d2, (q31_t)0x910e0653, (q31_t)0x3fd0d191, (q31_t)0x910ae442, + (q31_t)0x3fcb5f28, (q31_t)0x9107c276, + (q31_t)0x3fc5ec98, (q31_t)0x9104a0ee, (q31_t)0x3fc079e0, (q31_t)0x91017faa, (q31_t)0x3fbb0702, (q31_t)0x90fe5eab, + (q31_t)0x3fb593fb, (q31_t)0x90fb3df1, + (q31_t)0x3fb020ce, (q31_t)0x90f81d7b, (q31_t)0x3faaad79, (q31_t)0x90f4fd4a, (q31_t)0x3fa539fd, (q31_t)0x90f1dd5d, + (q31_t)0x3f9fc65a, (q31_t)0x90eebdb4, + (q31_t)0x3f9a5290, (q31_t)0x90eb9e50, (q31_t)0x3f94de9e, (q31_t)0x90e87f31, (q31_t)0x3f8f6a85, (q31_t)0x90e56056, + (q31_t)0x3f89f645, (q31_t)0x90e241bf, + (q31_t)0x3f8481dd, (q31_t)0x90df236e, (q31_t)0x3f7f0d4f, (q31_t)0x90dc0560, (q31_t)0x3f799899, (q31_t)0x90d8e798, + (q31_t)0x3f7423bc, (q31_t)0x90d5ca13, + (q31_t)0x3f6eaeb8, (q31_t)0x90d2acd4, (q31_t)0x3f69398d, (q31_t)0x90cf8fd9, (q31_t)0x3f63c43b, (q31_t)0x90cc7322, + (q31_t)0x3f5e4ec2, (q31_t)0x90c956b1, + (q31_t)0x3f58d921, (q31_t)0x90c63a83, (q31_t)0x3f53635a, (q31_t)0x90c31e9b, (q31_t)0x3f4ded6b, (q31_t)0x90c002f7, + (q31_t)0x3f487755, (q31_t)0x90bce797, + (q31_t)0x3f430119, (q31_t)0x90b9cc7d, (q31_t)0x3f3d8ab5, (q31_t)0x90b6b1a6, (q31_t)0x3f38142a, (q31_t)0x90b39715, + (q31_t)0x3f329d79, (q31_t)0x90b07cc8, + (q31_t)0x3f2d26a0, (q31_t)0x90ad62c0, (q31_t)0x3f27afa1, (q31_t)0x90aa48fd, (q31_t)0x3f22387a, (q31_t)0x90a72f7e, + (q31_t)0x3f1cc12c, (q31_t)0x90a41644, + (q31_t)0x3f1749b8, (q31_t)0x90a0fd4e, (q31_t)0x3f11d21d, (q31_t)0x909de49e, (q31_t)0x3f0c5a5a, (q31_t)0x909acc32, + (q31_t)0x3f06e271, (q31_t)0x9097b40a, + (q31_t)0x3f016a61, (q31_t)0x90949c28, (q31_t)0x3efbf22a, (q31_t)0x9091848a, (q31_t)0x3ef679cc, (q31_t)0x908e6d31, + (q31_t)0x3ef10148, (q31_t)0x908b561c, + (q31_t)0x3eeb889c, (q31_t)0x90883f4d, (q31_t)0x3ee60fca, (q31_t)0x908528c2, (q31_t)0x3ee096d1, (q31_t)0x9082127c, + (q31_t)0x3edb1db1, (q31_t)0x907efc7a, + (q31_t)0x3ed5a46b, (q31_t)0x907be6be, (q31_t)0x3ed02afd, (q31_t)0x9078d146, (q31_t)0x3ecab169, (q31_t)0x9075bc13, + (q31_t)0x3ec537ae, (q31_t)0x9072a725, + (q31_t)0x3ebfbdcd, (q31_t)0x906f927c, (q31_t)0x3eba43c4, (q31_t)0x906c7e17, (q31_t)0x3eb4c995, (q31_t)0x906969f8, + (q31_t)0x3eaf4f40, (q31_t)0x9066561d, + (q31_t)0x3ea9d4c3, (q31_t)0x90634287, (q31_t)0x3ea45a21, (q31_t)0x90602f35, (q31_t)0x3e9edf57, (q31_t)0x905d1c29, + (q31_t)0x3e996467, (q31_t)0x905a0962, + (q31_t)0x3e93e950, (q31_t)0x9056f6df, (q31_t)0x3e8e6e12, (q31_t)0x9053e4a1, (q31_t)0x3e88f2ae, (q31_t)0x9050d2a9, + (q31_t)0x3e837724, (q31_t)0x904dc0f5, + (q31_t)0x3e7dfb73, (q31_t)0x904aaf86, (q31_t)0x3e787f9b, (q31_t)0x90479e5c, (q31_t)0x3e73039d, (q31_t)0x90448d76, + (q31_t)0x3e6d8778, (q31_t)0x90417cd6, + (q31_t)0x3e680b2c, (q31_t)0x903e6c7b, (q31_t)0x3e628ebb, (q31_t)0x903b5c64, (q31_t)0x3e5d1222, (q31_t)0x90384c93, + (q31_t)0x3e579564, (q31_t)0x90353d06, + (q31_t)0x3e52187f, (q31_t)0x90322dbf, (q31_t)0x3e4c9b73, (q31_t)0x902f1ebc, (q31_t)0x3e471e41, (q31_t)0x902c0fff, + (q31_t)0x3e41a0e8, (q31_t)0x90290186, + (q31_t)0x3e3c2369, (q31_t)0x9025f352, (q31_t)0x3e36a5c4, (q31_t)0x9022e564, (q31_t)0x3e3127f9, (q31_t)0x901fd7ba, + (q31_t)0x3e2baa07, (q31_t)0x901cca55, + (q31_t)0x3e262bee, (q31_t)0x9019bd36, (q31_t)0x3e20adaf, (q31_t)0x9016b05b, (q31_t)0x3e1b2f4a, (q31_t)0x9013a3c5, + (q31_t)0x3e15b0bf, (q31_t)0x90109775, + (q31_t)0x3e10320d, (q31_t)0x900d8b69, (q31_t)0x3e0ab336, (q31_t)0x900a7fa3, (q31_t)0x3e053437, (q31_t)0x90077422, + (q31_t)0x3dffb513, (q31_t)0x900468e5, + (q31_t)0x3dfa35c8, (q31_t)0x90015dee, (q31_t)0x3df4b657, (q31_t)0x8ffe533c, (q31_t)0x3def36c0, (q31_t)0x8ffb48cf, + (q31_t)0x3de9b703, (q31_t)0x8ff83ea7, + (q31_t)0x3de4371f, (q31_t)0x8ff534c4, (q31_t)0x3ddeb716, (q31_t)0x8ff22b26, (q31_t)0x3dd936e6, (q31_t)0x8fef21ce, + (q31_t)0x3dd3b690, (q31_t)0x8fec18ba, + (q31_t)0x3dce3614, (q31_t)0x8fe90fec, (q31_t)0x3dc8b571, (q31_t)0x8fe60763, (q31_t)0x3dc334a9, (q31_t)0x8fe2ff1f, + (q31_t)0x3dbdb3ba, (q31_t)0x8fdff720, + (q31_t)0x3db832a6, (q31_t)0x8fdcef66, (q31_t)0x3db2b16b, (q31_t)0x8fd9e7f2, (q31_t)0x3dad300b, (q31_t)0x8fd6e0c2, + (q31_t)0x3da7ae84, (q31_t)0x8fd3d9d8, + (q31_t)0x3da22cd7, (q31_t)0x8fd0d333, (q31_t)0x3d9cab04, (q31_t)0x8fcdccd3, (q31_t)0x3d97290b, (q31_t)0x8fcac6b9, + (q31_t)0x3d91a6ed, (q31_t)0x8fc7c0e3, + (q31_t)0x3d8c24a8, (q31_t)0x8fc4bb53, (q31_t)0x3d86a23d, (q31_t)0x8fc1b608, (q31_t)0x3d811fac, (q31_t)0x8fbeb103, + (q31_t)0x3d7b9cf6, (q31_t)0x8fbbac42, + (q31_t)0x3d761a19, (q31_t)0x8fb8a7c7, (q31_t)0x3d709717, (q31_t)0x8fb5a391, (q31_t)0x3d6b13ee, (q31_t)0x8fb29fa0, + (q31_t)0x3d6590a0, (q31_t)0x8faf9bf5, + (q31_t)0x3d600d2c, (q31_t)0x8fac988f, (q31_t)0x3d5a8992, (q31_t)0x8fa9956e, (q31_t)0x3d5505d2, (q31_t)0x8fa69293, + (q31_t)0x3d4f81ec, (q31_t)0x8fa38ffc, + (q31_t)0x3d49fde1, (q31_t)0x8fa08dab, (q31_t)0x3d4479b0, (q31_t)0x8f9d8ba0, (q31_t)0x3d3ef559, (q31_t)0x8f9a89da, + (q31_t)0x3d3970dc, (q31_t)0x8f978859, + (q31_t)0x3d33ec39, (q31_t)0x8f94871d, (q31_t)0x3d2e6771, (q31_t)0x8f918627, (q31_t)0x3d28e282, (q31_t)0x8f8e8576, + (q31_t)0x3d235d6f, (q31_t)0x8f8b850a, + (q31_t)0x3d1dd835, (q31_t)0x8f8884e4, (q31_t)0x3d1852d6, (q31_t)0x8f858503, (q31_t)0x3d12cd51, (q31_t)0x8f828568, + (q31_t)0x3d0d47a6, (q31_t)0x8f7f8612, + (q31_t)0x3d07c1d6, (q31_t)0x8f7c8701, (q31_t)0x3d023be0, (q31_t)0x8f798836, (q31_t)0x3cfcb5c4, (q31_t)0x8f7689b0, + (q31_t)0x3cf72f83, (q31_t)0x8f738b70, + (q31_t)0x3cf1a91c, (q31_t)0x8f708d75, (q31_t)0x3cec2290, (q31_t)0x8f6d8fbf, (q31_t)0x3ce69bde, (q31_t)0x8f6a924f, + (q31_t)0x3ce11507, (q31_t)0x8f679525, + (q31_t)0x3cdb8e09, (q31_t)0x8f649840, (q31_t)0x3cd606e7, (q31_t)0x8f619ba0, (q31_t)0x3cd07f9f, (q31_t)0x8f5e9f46, + (q31_t)0x3ccaf831, (q31_t)0x8f5ba331, + (q31_t)0x3cc5709e, (q31_t)0x8f58a761, (q31_t)0x3cbfe8e5, (q31_t)0x8f55abd8, (q31_t)0x3cba6107, (q31_t)0x8f52b093, + (q31_t)0x3cb4d904, (q31_t)0x8f4fb595, + (q31_t)0x3caf50da, (q31_t)0x8f4cbadb, (q31_t)0x3ca9c88c, (q31_t)0x8f49c067, (q31_t)0x3ca44018, (q31_t)0x8f46c639, + (q31_t)0x3c9eb77f, (q31_t)0x8f43cc50, + (q31_t)0x3c992ec0, (q31_t)0x8f40d2ad, (q31_t)0x3c93a5dc, (q31_t)0x8f3dd950, (q31_t)0x3c8e1cd3, (q31_t)0x8f3ae038, + (q31_t)0x3c8893a4, (q31_t)0x8f37e765, + (q31_t)0x3c830a50, (q31_t)0x8f34eed8, (q31_t)0x3c7d80d6, (q31_t)0x8f31f691, (q31_t)0x3c77f737, (q31_t)0x8f2efe8f, + (q31_t)0x3c726d73, (q31_t)0x8f2c06d3, + (q31_t)0x3c6ce38a, (q31_t)0x8f290f5c, (q31_t)0x3c67597b, (q31_t)0x8f26182b, (q31_t)0x3c61cf48, (q31_t)0x8f232140, + (q31_t)0x3c5c44ee, (q31_t)0x8f202a9a, + (q31_t)0x3c56ba70, (q31_t)0x8f1d343a, (q31_t)0x3c512fcc, (q31_t)0x8f1a3e1f, (q31_t)0x3c4ba504, (q31_t)0x8f17484b, + (q31_t)0x3c461a16, (q31_t)0x8f1452bb, + (q31_t)0x3c408f03, (q31_t)0x8f115d72, (q31_t)0x3c3b03ca, (q31_t)0x8f0e686e, (q31_t)0x3c35786d, (q31_t)0x8f0b73b0, + (q31_t)0x3c2fecea, (q31_t)0x8f087f37, + (q31_t)0x3c2a6142, (q31_t)0x8f058b04, (q31_t)0x3c24d575, (q31_t)0x8f029717, (q31_t)0x3c1f4983, (q31_t)0x8effa370, + (q31_t)0x3c19bd6c, (q31_t)0x8efcb00e, + (q31_t)0x3c143130, (q31_t)0x8ef9bcf2, (q31_t)0x3c0ea4cf, (q31_t)0x8ef6ca1c, (q31_t)0x3c091849, (q31_t)0x8ef3d78b, + (q31_t)0x3c038b9e, (q31_t)0x8ef0e540, + (q31_t)0x3bfdfecd, (q31_t)0x8eedf33b, (q31_t)0x3bf871d8, (q31_t)0x8eeb017c, (q31_t)0x3bf2e4be, (q31_t)0x8ee81002, + (q31_t)0x3bed577e, (q31_t)0x8ee51ece, + (q31_t)0x3be7ca1a, (q31_t)0x8ee22de0, (q31_t)0x3be23c91, (q31_t)0x8edf3d38, (q31_t)0x3bdcaee3, (q31_t)0x8edc4cd5, + (q31_t)0x3bd72110, (q31_t)0x8ed95cb8, + (q31_t)0x3bd19318, (q31_t)0x8ed66ce1, (q31_t)0x3bcc04fb, (q31_t)0x8ed37d50, (q31_t)0x3bc676b9, (q31_t)0x8ed08e05, + (q31_t)0x3bc0e853, (q31_t)0x8ecd9eff, + (q31_t)0x3bbb59c7, (q31_t)0x8ecab040, (q31_t)0x3bb5cb17, (q31_t)0x8ec7c1c6, (q31_t)0x3bb03c42, (q31_t)0x8ec4d392, + (q31_t)0x3baaad48, (q31_t)0x8ec1e5a4, + (q31_t)0x3ba51e29, (q31_t)0x8ebef7fb, (q31_t)0x3b9f8ee5, (q31_t)0x8ebc0a99, (q31_t)0x3b99ff7d, (q31_t)0x8eb91d7c, + (q31_t)0x3b946ff0, (q31_t)0x8eb630a6, + (q31_t)0x3b8ee03e, (q31_t)0x8eb34415, (q31_t)0x3b895068, (q31_t)0x8eb057ca, (q31_t)0x3b83c06c, (q31_t)0x8ead6bc5, + (q31_t)0x3b7e304c, (q31_t)0x8eaa8006, + (q31_t)0x3b78a007, (q31_t)0x8ea7948c, (q31_t)0x3b730f9e, (q31_t)0x8ea4a959, (q31_t)0x3b6d7f10, (q31_t)0x8ea1be6c, + (q31_t)0x3b67ee5d, (q31_t)0x8e9ed3c4, + (q31_t)0x3b625d86, (q31_t)0x8e9be963, (q31_t)0x3b5ccc8a, (q31_t)0x8e98ff47, (q31_t)0x3b573b69, (q31_t)0x8e961571, + (q31_t)0x3b51aa24, (q31_t)0x8e932be2, + (q31_t)0x3b4c18ba, (q31_t)0x8e904298, (q31_t)0x3b46872c, (q31_t)0x8e8d5994, (q31_t)0x3b40f579, (q31_t)0x8e8a70d7, + (q31_t)0x3b3b63a1, (q31_t)0x8e87885f, + (q31_t)0x3b35d1a5, (q31_t)0x8e84a02d, (q31_t)0x3b303f84, (q31_t)0x8e81b841, (q31_t)0x3b2aad3f, (q31_t)0x8e7ed09b, + (q31_t)0x3b251ad6, (q31_t)0x8e7be93c, + (q31_t)0x3b1f8848, (q31_t)0x8e790222, (q31_t)0x3b19f595, (q31_t)0x8e761b4e, (q31_t)0x3b1462be, (q31_t)0x8e7334c1, + (q31_t)0x3b0ecfc3, (q31_t)0x8e704e79, + (q31_t)0x3b093ca3, (q31_t)0x8e6d6877, (q31_t)0x3b03a95e, (q31_t)0x8e6a82bc, (q31_t)0x3afe15f6, (q31_t)0x8e679d47, + (q31_t)0x3af88269, (q31_t)0x8e64b817, + (q31_t)0x3af2eeb7, (q31_t)0x8e61d32e, (q31_t)0x3aed5ae1, (q31_t)0x8e5eee8b, (q31_t)0x3ae7c6e7, (q31_t)0x8e5c0a2e, + (q31_t)0x3ae232c9, (q31_t)0x8e592617, + (q31_t)0x3adc9e86, (q31_t)0x8e564246, (q31_t)0x3ad70a1f, (q31_t)0x8e535ebb, (q31_t)0x3ad17593, (q31_t)0x8e507b76, + (q31_t)0x3acbe0e3, (q31_t)0x8e4d9878, + (q31_t)0x3ac64c0f, (q31_t)0x8e4ab5bf, (q31_t)0x3ac0b717, (q31_t)0x8e47d34d, (q31_t)0x3abb21fb, (q31_t)0x8e44f121, + (q31_t)0x3ab58cba, (q31_t)0x8e420f3b, + (q31_t)0x3aaff755, (q31_t)0x8e3f2d9b, (q31_t)0x3aaa61cc, (q31_t)0x8e3c4c41, (q31_t)0x3aa4cc1e, (q31_t)0x8e396b2e, + (q31_t)0x3a9f364d, (q31_t)0x8e368a61, + (q31_t)0x3a99a057, (q31_t)0x8e33a9da, (q31_t)0x3a940a3e, (q31_t)0x8e30c999, (q31_t)0x3a8e7400, (q31_t)0x8e2de99e, + (q31_t)0x3a88dd9d, (q31_t)0x8e2b09e9, + (q31_t)0x3a834717, (q31_t)0x8e282a7b, (q31_t)0x3a7db06d, (q31_t)0x8e254b53, (q31_t)0x3a78199f, (q31_t)0x8e226c71, + (q31_t)0x3a7282ac, (q31_t)0x8e1f8dd6, + (q31_t)0x3a6ceb96, (q31_t)0x8e1caf80, (q31_t)0x3a67545b, (q31_t)0x8e19d171, (q31_t)0x3a61bcfd, (q31_t)0x8e16f3a9, + (q31_t)0x3a5c257a, (q31_t)0x8e141626, + (q31_t)0x3a568dd4, (q31_t)0x8e1138ea, (q31_t)0x3a50f609, (q31_t)0x8e0e5bf4, (q31_t)0x3a4b5e1b, (q31_t)0x8e0b7f44, + (q31_t)0x3a45c608, (q31_t)0x8e08a2db, + (q31_t)0x3a402dd2, (q31_t)0x8e05c6b7, (q31_t)0x3a3a9577, (q31_t)0x8e02eadb, (q31_t)0x3a34fcf9, (q31_t)0x8e000f44, + (q31_t)0x3a2f6457, (q31_t)0x8dfd33f4, + (q31_t)0x3a29cb91, (q31_t)0x8dfa58ea, (q31_t)0x3a2432a7, (q31_t)0x8df77e27, (q31_t)0x3a1e9999, (q31_t)0x8df4a3a9, + (q31_t)0x3a190068, (q31_t)0x8df1c973, + (q31_t)0x3a136712, (q31_t)0x8deeef82, (q31_t)0x3a0dcd99, (q31_t)0x8dec15d8, (q31_t)0x3a0833fc, (q31_t)0x8de93c74, + (q31_t)0x3a029a3b, (q31_t)0x8de66357, + (q31_t)0x39fd0056, (q31_t)0x8de38a80, (q31_t)0x39f7664e, (q31_t)0x8de0b1ef, (q31_t)0x39f1cc21, (q31_t)0x8dddd9a5, + (q31_t)0x39ec31d1, (q31_t)0x8ddb01a1, + (q31_t)0x39e6975e, (q31_t)0x8dd829e4, (q31_t)0x39e0fcc6, (q31_t)0x8dd5526d, (q31_t)0x39db620b, (q31_t)0x8dd27b3c, + (q31_t)0x39d5c72c, (q31_t)0x8dcfa452, + (q31_t)0x39d02c2a, (q31_t)0x8dcccdaf, (q31_t)0x39ca9104, (q31_t)0x8dc9f751, (q31_t)0x39c4f5ba, (q31_t)0x8dc7213b, + (q31_t)0x39bf5a4d, (q31_t)0x8dc44b6a, + (q31_t)0x39b9bebc, (q31_t)0x8dc175e0, (q31_t)0x39b42307, (q31_t)0x8dbea09d, (q31_t)0x39ae872f, (q31_t)0x8dbbcba0, + (q31_t)0x39a8eb33, (q31_t)0x8db8f6ea, + (q31_t)0x39a34f13, (q31_t)0x8db6227a, (q31_t)0x399db2d0, (q31_t)0x8db34e50, (q31_t)0x3998166a, (q31_t)0x8db07a6d, + (q31_t)0x399279e0, (q31_t)0x8dada6d1, + (q31_t)0x398cdd32, (q31_t)0x8daad37b, (q31_t)0x39874061, (q31_t)0x8da8006c, (q31_t)0x3981a36d, (q31_t)0x8da52da3, + (q31_t)0x397c0655, (q31_t)0x8da25b21, + (q31_t)0x39766919, (q31_t)0x8d9f88e5, (q31_t)0x3970cbba, (q31_t)0x8d9cb6f0, (q31_t)0x396b2e38, (q31_t)0x8d99e541, + (q31_t)0x39659092, (q31_t)0x8d9713d9, + (q31_t)0x395ff2c9, (q31_t)0x8d9442b8, (q31_t)0x395a54dd, (q31_t)0x8d9171dd, (q31_t)0x3954b6cd, (q31_t)0x8d8ea148, + (q31_t)0x394f1899, (q31_t)0x8d8bd0fb, + (q31_t)0x39497a43, (q31_t)0x8d8900f3, (q31_t)0x3943dbc9, (q31_t)0x8d863133, (q31_t)0x393e3d2c, (q31_t)0x8d8361b9, + (q31_t)0x39389e6b, (q31_t)0x8d809286, + (q31_t)0x3932ff87, (q31_t)0x8d7dc399, (q31_t)0x392d6080, (q31_t)0x8d7af4f3, (q31_t)0x3927c155, (q31_t)0x8d782694, + (q31_t)0x39222208, (q31_t)0x8d75587b, + (q31_t)0x391c8297, (q31_t)0x8d728aa9, (q31_t)0x3916e303, (q31_t)0x8d6fbd1d, (q31_t)0x3911434b, (q31_t)0x8d6cefd9, + (q31_t)0x390ba371, (q31_t)0x8d6a22db, + (q31_t)0x39060373, (q31_t)0x8d675623, (q31_t)0x39006352, (q31_t)0x8d6489b3, (q31_t)0x38fac30e, (q31_t)0x8d61bd89, + (q31_t)0x38f522a6, (q31_t)0x8d5ef1a5, + (q31_t)0x38ef821c, (q31_t)0x8d5c2609, (q31_t)0x38e9e16e, (q31_t)0x8d595ab3, (q31_t)0x38e4409e, (q31_t)0x8d568fa4, + (q31_t)0x38de9faa, (q31_t)0x8d53c4db, + (q31_t)0x38d8fe93, (q31_t)0x8d50fa59, (q31_t)0x38d35d59, (q31_t)0x8d4e301f, (q31_t)0x38cdbbfc, (q31_t)0x8d4b662a, + (q31_t)0x38c81a7c, (q31_t)0x8d489c7d, + (q31_t)0x38c278d9, (q31_t)0x8d45d316, (q31_t)0x38bcd713, (q31_t)0x8d4309f6, (q31_t)0x38b7352a, (q31_t)0x8d40411d, + (q31_t)0x38b1931e, (q31_t)0x8d3d788b, + (q31_t)0x38abf0ef, (q31_t)0x8d3ab03f, (q31_t)0x38a64e9d, (q31_t)0x8d37e83a, (q31_t)0x38a0ac29, (q31_t)0x8d35207d, + (q31_t)0x389b0991, (q31_t)0x8d325905, + (q31_t)0x389566d6, (q31_t)0x8d2f91d5, (q31_t)0x388fc3f8, (q31_t)0x8d2ccaec, (q31_t)0x388a20f8, (q31_t)0x8d2a0449, + (q31_t)0x38847dd5, (q31_t)0x8d273ded, + (q31_t)0x387eda8e, (q31_t)0x8d2477d8, (q31_t)0x38793725, (q31_t)0x8d21b20a, (q31_t)0x38739399, (q31_t)0x8d1eec83, + (q31_t)0x386defeb, (q31_t)0x8d1c2742, + (q31_t)0x38684c19, (q31_t)0x8d196249, (q31_t)0x3862a825, (q31_t)0x8d169d96, (q31_t)0x385d040d, (q31_t)0x8d13d92a, + (q31_t)0x38575fd4, (q31_t)0x8d111505, + (q31_t)0x3851bb77, (q31_t)0x8d0e5127, (q31_t)0x384c16f7, (q31_t)0x8d0b8d90, (q31_t)0x38467255, (q31_t)0x8d08ca40, + (q31_t)0x3840cd90, (q31_t)0x8d060737, + (q31_t)0x383b28a9, (q31_t)0x8d034474, (q31_t)0x3835839f, (q31_t)0x8d0081f9, (q31_t)0x382fde72, (q31_t)0x8cfdbfc4, + (q31_t)0x382a3922, (q31_t)0x8cfafdd7, + (q31_t)0x382493b0, (q31_t)0x8cf83c30, (q31_t)0x381eee1b, (q31_t)0x8cf57ad0, (q31_t)0x38194864, (q31_t)0x8cf2b9b8, + (q31_t)0x3813a28a, (q31_t)0x8ceff8e6, + (q31_t)0x380dfc8d, (q31_t)0x8ced385b, (q31_t)0x3808566e, (q31_t)0x8cea7818, (q31_t)0x3802b02c, (q31_t)0x8ce7b81b, + (q31_t)0x37fd09c8, (q31_t)0x8ce4f865, + (q31_t)0x37f76341, (q31_t)0x8ce238f6, (q31_t)0x37f1bc97, (q31_t)0x8cdf79ce, (q31_t)0x37ec15cb, (q31_t)0x8cdcbaee, + (q31_t)0x37e66edd, (q31_t)0x8cd9fc54, + (q31_t)0x37e0c7cc, (q31_t)0x8cd73e01, (q31_t)0x37db2099, (q31_t)0x8cd47ff6, (q31_t)0x37d57943, (q31_t)0x8cd1c231, + (q31_t)0x37cfd1cb, (q31_t)0x8ccf04b3, + (q31_t)0x37ca2a30, (q31_t)0x8ccc477d, (q31_t)0x37c48273, (q31_t)0x8cc98a8e, (q31_t)0x37beda93, (q31_t)0x8cc6cde5, + (q31_t)0x37b93292, (q31_t)0x8cc41184, + (q31_t)0x37b38a6d, (q31_t)0x8cc1556a, (q31_t)0x37ade227, (q31_t)0x8cbe9996, (q31_t)0x37a839be, (q31_t)0x8cbbde0a, + (q31_t)0x37a29132, (q31_t)0x8cb922c6, + (q31_t)0x379ce885, (q31_t)0x8cb667c8, (q31_t)0x37973fb5, (q31_t)0x8cb3ad11, (q31_t)0x379196c3, (q31_t)0x8cb0f2a1, + (q31_t)0x378bedae, (q31_t)0x8cae3879, + (q31_t)0x37864477, (q31_t)0x8cab7e98, (q31_t)0x37809b1e, (q31_t)0x8ca8c4fd, (q31_t)0x377af1a3, (q31_t)0x8ca60baa, + (q31_t)0x37754806, (q31_t)0x8ca3529f, + (q31_t)0x376f9e46, (q31_t)0x8ca099da, (q31_t)0x3769f464, (q31_t)0x8c9de15c, (q31_t)0x37644a60, (q31_t)0x8c9b2926, + (q31_t)0x375ea03a, (q31_t)0x8c987137, + (q31_t)0x3758f5f2, (q31_t)0x8c95b98f, (q31_t)0x37534b87, (q31_t)0x8c93022e, (q31_t)0x374da0fa, (q31_t)0x8c904b14, + (q31_t)0x3747f64c, (q31_t)0x8c8d9442, + (q31_t)0x37424b7b, (q31_t)0x8c8addb7, (q31_t)0x373ca088, (q31_t)0x8c882773, (q31_t)0x3736f573, (q31_t)0x8c857176, + (q31_t)0x37314a3c, (q31_t)0x8c82bbc0, + (q31_t)0x372b9ee3, (q31_t)0x8c800652, (q31_t)0x3725f367, (q31_t)0x8c7d512b, (q31_t)0x372047ca, (q31_t)0x8c7a9c4b, + (q31_t)0x371a9c0b, (q31_t)0x8c77e7b3, + (q31_t)0x3714f02a, (q31_t)0x8c753362, (q31_t)0x370f4427, (q31_t)0x8c727f58, (q31_t)0x37099802, (q31_t)0x8c6fcb95, + (q31_t)0x3703ebbb, (q31_t)0x8c6d181a, + (q31_t)0x36fe3f52, (q31_t)0x8c6a64e5, (q31_t)0x36f892c7, (q31_t)0x8c67b1f9, (q31_t)0x36f2e61a, (q31_t)0x8c64ff53, + (q31_t)0x36ed394b, (q31_t)0x8c624cf5, + (q31_t)0x36e78c5b, (q31_t)0x8c5f9ade, (q31_t)0x36e1df48, (q31_t)0x8c5ce90e, (q31_t)0x36dc3214, (q31_t)0x8c5a3786, + (q31_t)0x36d684be, (q31_t)0x8c578645, + (q31_t)0x36d0d746, (q31_t)0x8c54d54c, (q31_t)0x36cb29ac, (q31_t)0x8c522499, (q31_t)0x36c57bf0, (q31_t)0x8c4f742f, + (q31_t)0x36bfce13, (q31_t)0x8c4cc40b, + (q31_t)0x36ba2014, (q31_t)0x8c4a142f, (q31_t)0x36b471f3, (q31_t)0x8c47649a, (q31_t)0x36aec3b0, (q31_t)0x8c44b54d, + (q31_t)0x36a9154c, (q31_t)0x8c420647, + (q31_t)0x36a366c6, (q31_t)0x8c3f5788, (q31_t)0x369db81e, (q31_t)0x8c3ca911, (q31_t)0x36980954, (q31_t)0x8c39fae1, + (q31_t)0x36925a69, (q31_t)0x8c374cf9, + (q31_t)0x368cab5c, (q31_t)0x8c349f58, (q31_t)0x3686fc2e, (q31_t)0x8c31f1ff, (q31_t)0x36814cde, (q31_t)0x8c2f44ed, + (q31_t)0x367b9d6c, (q31_t)0x8c2c9822, + (q31_t)0x3675edd9, (q31_t)0x8c29eb9f, (q31_t)0x36703e24, (q31_t)0x8c273f63, (q31_t)0x366a8e4d, (q31_t)0x8c24936f, + (q31_t)0x3664de55, (q31_t)0x8c21e7c2, + (q31_t)0x365f2e3b, (q31_t)0x8c1f3c5d, (q31_t)0x36597e00, (q31_t)0x8c1c913f, (q31_t)0x3653cda3, (q31_t)0x8c19e669, + (q31_t)0x364e1d25, (q31_t)0x8c173bda, + (q31_t)0x36486c86, (q31_t)0x8c149192, (q31_t)0x3642bbc4, (q31_t)0x8c11e792, (q31_t)0x363d0ae2, (q31_t)0x8c0f3dda, + (q31_t)0x363759de, (q31_t)0x8c0c9469, + (q31_t)0x3631a8b8, (q31_t)0x8c09eb40, (q31_t)0x362bf771, (q31_t)0x8c07425e, (q31_t)0x36264609, (q31_t)0x8c0499c4, + (q31_t)0x3620947f, (q31_t)0x8c01f171, + (q31_t)0x361ae2d3, (q31_t)0x8bff4966, (q31_t)0x36153107, (q31_t)0x8bfca1a3, (q31_t)0x360f7f19, (q31_t)0x8bf9fa27, + (q31_t)0x3609cd0a, (q31_t)0x8bf752f2, + (q31_t)0x36041ad9, (q31_t)0x8bf4ac05, (q31_t)0x35fe6887, (q31_t)0x8bf20560, (q31_t)0x35f8b614, (q31_t)0x8bef5f02, + (q31_t)0x35f3037f, (q31_t)0x8becb8ec, + (q31_t)0x35ed50c9, (q31_t)0x8bea131e, (q31_t)0x35e79df2, (q31_t)0x8be76d97, (q31_t)0x35e1eafa, (q31_t)0x8be4c857, + (q31_t)0x35dc37e0, (q31_t)0x8be22360, + (q31_t)0x35d684a6, (q31_t)0x8bdf7eb0, (q31_t)0x35d0d14a, (q31_t)0x8bdcda47, (q31_t)0x35cb1dcc, (q31_t)0x8bda3626, + (q31_t)0x35c56a2e, (q31_t)0x8bd7924d, + (q31_t)0x35bfb66e, (q31_t)0x8bd4eebc, (q31_t)0x35ba028e, (q31_t)0x8bd24b72, (q31_t)0x35b44e8c, (q31_t)0x8bcfa870, + (q31_t)0x35ae9a69, (q31_t)0x8bcd05b5, + (q31_t)0x35a8e625, (q31_t)0x8bca6343, (q31_t)0x35a331c0, (q31_t)0x8bc7c117, (q31_t)0x359d7d39, (q31_t)0x8bc51f34, + (q31_t)0x3597c892, (q31_t)0x8bc27d98, + (q31_t)0x359213c9, (q31_t)0x8bbfdc44, (q31_t)0x358c5ee0, (q31_t)0x8bbd3b38, (q31_t)0x3586a9d5, (q31_t)0x8bba9a73, + (q31_t)0x3580f4aa, (q31_t)0x8bb7f9f6, + (q31_t)0x357b3f5d, (q31_t)0x8bb559c1, (q31_t)0x357589f0, (q31_t)0x8bb2b9d4, (q31_t)0x356fd461, (q31_t)0x8bb01a2e, + (q31_t)0x356a1eb2, (q31_t)0x8bad7ad0, + (q31_t)0x356468e2, (q31_t)0x8baadbba, (q31_t)0x355eb2f0, (q31_t)0x8ba83cec, (q31_t)0x3558fcde, (q31_t)0x8ba59e65, + (q31_t)0x355346ab, (q31_t)0x8ba30026, + (q31_t)0x354d9057, (q31_t)0x8ba0622f, (q31_t)0x3547d9e2, (q31_t)0x8b9dc480, (q31_t)0x3542234c, (q31_t)0x8b9b2718, + (q31_t)0x353c6c95, (q31_t)0x8b9889f8, + (q31_t)0x3536b5be, (q31_t)0x8b95ed21, (q31_t)0x3530fec6, (q31_t)0x8b935090, (q31_t)0x352b47ad, (q31_t)0x8b90b448, + (q31_t)0x35259073, (q31_t)0x8b8e1848, + (q31_t)0x351fd918, (q31_t)0x8b8b7c8f, (q31_t)0x351a219c, (q31_t)0x8b88e11e, (q31_t)0x35146a00, (q31_t)0x8b8645f5, + (q31_t)0x350eb243, (q31_t)0x8b83ab14, + (q31_t)0x3508fa66, (q31_t)0x8b81107b, (q31_t)0x35034267, (q31_t)0x8b7e7629, (q31_t)0x34fd8a48, (q31_t)0x8b7bdc20, + (q31_t)0x34f7d208, (q31_t)0x8b79425e, + (q31_t)0x34f219a8, (q31_t)0x8b76a8e4, (q31_t)0x34ec6127, (q31_t)0x8b740fb3, (q31_t)0x34e6a885, (q31_t)0x8b7176c8, + (q31_t)0x34e0efc2, (q31_t)0x8b6ede26, + (q31_t)0x34db36df, (q31_t)0x8b6c45cc, (q31_t)0x34d57ddc, (q31_t)0x8b69adba, (q31_t)0x34cfc4b7, (q31_t)0x8b6715ef, + (q31_t)0x34ca0b73, (q31_t)0x8b647e6d, + (q31_t)0x34c4520d, (q31_t)0x8b61e733, (q31_t)0x34be9887, (q31_t)0x8b5f5040, (q31_t)0x34b8dee1, (q31_t)0x8b5cb995, + (q31_t)0x34b3251a, (q31_t)0x8b5a2333, + (q31_t)0x34ad6b32, (q31_t)0x8b578d18, (q31_t)0x34a7b12a, (q31_t)0x8b54f745, (q31_t)0x34a1f702, (q31_t)0x8b5261ba, + (q31_t)0x349c3cb9, (q31_t)0x8b4fcc77, + (q31_t)0x34968250, (q31_t)0x8b4d377c, (q31_t)0x3490c7c6, (q31_t)0x8b4aa2ca, (q31_t)0x348b0d1c, (q31_t)0x8b480e5f, + (q31_t)0x34855251, (q31_t)0x8b457a3c, + (q31_t)0x347f9766, (q31_t)0x8b42e661, (q31_t)0x3479dc5b, (q31_t)0x8b4052ce, (q31_t)0x3474212f, (q31_t)0x8b3dbf83, + (q31_t)0x346e65e3, (q31_t)0x8b3b2c80, + (q31_t)0x3468aa76, (q31_t)0x8b3899c6, (q31_t)0x3462eee9, (q31_t)0x8b360753, (q31_t)0x345d333c, (q31_t)0x8b337528, + (q31_t)0x3457776f, (q31_t)0x8b30e345, + (q31_t)0x3451bb81, (q31_t)0x8b2e51ab, (q31_t)0x344bff73, (q31_t)0x8b2bc058, (q31_t)0x34464345, (q31_t)0x8b292f4e, + (q31_t)0x344086f6, (q31_t)0x8b269e8b, + (q31_t)0x343aca87, (q31_t)0x8b240e11, (q31_t)0x34350df8, (q31_t)0x8b217ddf, (q31_t)0x342f5149, (q31_t)0x8b1eedf4, + (q31_t)0x3429947a, (q31_t)0x8b1c5e52, + (q31_t)0x3423d78a, (q31_t)0x8b19cef8, (q31_t)0x341e1a7b, (q31_t)0x8b173fe6, (q31_t)0x34185d4b, (q31_t)0x8b14b11d, + (q31_t)0x34129ffb, (q31_t)0x8b12229b, + (q31_t)0x340ce28b, (q31_t)0x8b0f9462, (q31_t)0x340724fb, (q31_t)0x8b0d0670, (q31_t)0x3401674a, (q31_t)0x8b0a78c7, + (q31_t)0x33fba97a, (q31_t)0x8b07eb66, + (q31_t)0x33f5eb89, (q31_t)0x8b055e4d, (q31_t)0x33f02d79, (q31_t)0x8b02d17c, (q31_t)0x33ea6f48, (q31_t)0x8b0044f3, + (q31_t)0x33e4b0f8, (q31_t)0x8afdb8b3, + (q31_t)0x33def287, (q31_t)0x8afb2cbb, (q31_t)0x33d933f7, (q31_t)0x8af8a10b, (q31_t)0x33d37546, (q31_t)0x8af615a3, + (q31_t)0x33cdb676, (q31_t)0x8af38a83, + (q31_t)0x33c7f785, (q31_t)0x8af0ffac, (q31_t)0x33c23875, (q31_t)0x8aee751c, (q31_t)0x33bc7944, (q31_t)0x8aebead5, + (q31_t)0x33b6b9f4, (q31_t)0x8ae960d6, + (q31_t)0x33b0fa84, (q31_t)0x8ae6d720, (q31_t)0x33ab3af4, (q31_t)0x8ae44db1, (q31_t)0x33a57b44, (q31_t)0x8ae1c48b, + (q31_t)0x339fbb74, (q31_t)0x8adf3bad, + (q31_t)0x3399fb85, (q31_t)0x8adcb318, (q31_t)0x33943b75, (q31_t)0x8ada2aca, (q31_t)0x338e7b46, (q31_t)0x8ad7a2c5, + (q31_t)0x3388baf7, (q31_t)0x8ad51b08, + (q31_t)0x3382fa88, (q31_t)0x8ad29394, (q31_t)0x337d39f9, (q31_t)0x8ad00c67, (q31_t)0x3377794b, (q31_t)0x8acd8583, + (q31_t)0x3371b87d, (q31_t)0x8acafee8, + (q31_t)0x336bf78f, (q31_t)0x8ac87894, (q31_t)0x33663682, (q31_t)0x8ac5f289, (q31_t)0x33607554, (q31_t)0x8ac36cc6, + (q31_t)0x335ab407, (q31_t)0x8ac0e74c, + (q31_t)0x3354f29b, (q31_t)0x8abe6219, (q31_t)0x334f310e, (q31_t)0x8abbdd30, (q31_t)0x33496f62, (q31_t)0x8ab9588e, + (q31_t)0x3343ad97, (q31_t)0x8ab6d435, + (q31_t)0x333debab, (q31_t)0x8ab45024, (q31_t)0x333829a1, (q31_t)0x8ab1cc5c, (q31_t)0x33326776, (q31_t)0x8aaf48db, + (q31_t)0x332ca52c, (q31_t)0x8aacc5a4, + (q31_t)0x3326e2c3, (q31_t)0x8aaa42b4, (q31_t)0x33212039, (q31_t)0x8aa7c00d, (q31_t)0x331b5d91, (q31_t)0x8aa53daf, + (q31_t)0x33159ac8, (q31_t)0x8aa2bb99, + (q31_t)0x330fd7e1, (q31_t)0x8aa039cb, (q31_t)0x330a14da, (q31_t)0x8a9db845, (q31_t)0x330451b3, (q31_t)0x8a9b3708, + (q31_t)0x32fe8e6d, (q31_t)0x8a98b614, + (q31_t)0x32f8cb07, (q31_t)0x8a963567, (q31_t)0x32f30782, (q31_t)0x8a93b504, (q31_t)0x32ed43de, (q31_t)0x8a9134e8, + (q31_t)0x32e7801a, (q31_t)0x8a8eb516, + (q31_t)0x32e1bc36, (q31_t)0x8a8c358b, (q31_t)0x32dbf834, (q31_t)0x8a89b649, (q31_t)0x32d63412, (q31_t)0x8a873750, + (q31_t)0x32d06fd0, (q31_t)0x8a84b89e, + (q31_t)0x32caab6f, (q31_t)0x8a823a36, (q31_t)0x32c4e6ef, (q31_t)0x8a7fbc16, (q31_t)0x32bf2250, (q31_t)0x8a7d3e3e, + (q31_t)0x32b95d91, (q31_t)0x8a7ac0af, + (q31_t)0x32b398b3, (q31_t)0x8a784368, (q31_t)0x32add3b6, (q31_t)0x8a75c66a, (q31_t)0x32a80e99, (q31_t)0x8a7349b4, + (q31_t)0x32a2495d, (q31_t)0x8a70cd47, + (q31_t)0x329c8402, (q31_t)0x8a6e5123, (q31_t)0x3296be88, (q31_t)0x8a6bd547, (q31_t)0x3290f8ef, (q31_t)0x8a6959b3, + (q31_t)0x328b3336, (q31_t)0x8a66de68, + (q31_t)0x32856d5e, (q31_t)0x8a646365, (q31_t)0x327fa767, (q31_t)0x8a61e8ab, (q31_t)0x3279e151, (q31_t)0x8a5f6e3a, + (q31_t)0x32741b1c, (q31_t)0x8a5cf411, + (q31_t)0x326e54c7, (q31_t)0x8a5a7a31, (q31_t)0x32688e54, (q31_t)0x8a580099, (q31_t)0x3262c7c1, (q31_t)0x8a55874a, + (q31_t)0x325d0110, (q31_t)0x8a530e43, + (q31_t)0x32573a3f, (q31_t)0x8a509585, (q31_t)0x3251734f, (q31_t)0x8a4e1d10, (q31_t)0x324bac40, (q31_t)0x8a4ba4e3, + (q31_t)0x3245e512, (q31_t)0x8a492cff, + (q31_t)0x32401dc6, (q31_t)0x8a46b564, (q31_t)0x323a565a, (q31_t)0x8a443e11, (q31_t)0x32348ecf, (q31_t)0x8a41c706, + (q31_t)0x322ec725, (q31_t)0x8a3f5045, + (q31_t)0x3228ff5c, (q31_t)0x8a3cd9cc, (q31_t)0x32233775, (q31_t)0x8a3a639b, (q31_t)0x321d6f6e, (q31_t)0x8a37edb3, + (q31_t)0x3217a748, (q31_t)0x8a357814, + (q31_t)0x3211df04, (q31_t)0x8a3302be, (q31_t)0x320c16a1, (q31_t)0x8a308db0, (q31_t)0x32064e1e, (q31_t)0x8a2e18eb, + (q31_t)0x3200857d, (q31_t)0x8a2ba46e, + (q31_t)0x31fabcbd, (q31_t)0x8a29303b, (q31_t)0x31f4f3df, (q31_t)0x8a26bc50, (q31_t)0x31ef2ae1, (q31_t)0x8a2448ad, + (q31_t)0x31e961c5, (q31_t)0x8a21d554, + (q31_t)0x31e39889, (q31_t)0x8a1f6243, (q31_t)0x31ddcf30, (q31_t)0x8a1cef7a, (q31_t)0x31d805b7, (q31_t)0x8a1a7cfb, + (q31_t)0x31d23c1f, (q31_t)0x8a180ac4, + (q31_t)0x31cc7269, (q31_t)0x8a1598d6, (q31_t)0x31c6a894, (q31_t)0x8a132731, (q31_t)0x31c0dea1, (q31_t)0x8a10b5d4, + (q31_t)0x31bb148f, (q31_t)0x8a0e44c0, + (q31_t)0x31b54a5e, (q31_t)0x8a0bd3f5, (q31_t)0x31af800e, (q31_t)0x8a096373, (q31_t)0x31a9b5a0, (q31_t)0x8a06f339, + (q31_t)0x31a3eb13, (q31_t)0x8a048348, + (q31_t)0x319e2067, (q31_t)0x8a0213a0, (q31_t)0x3198559d, (q31_t)0x89ffa441, (q31_t)0x31928ab4, (q31_t)0x89fd352b, + (q31_t)0x318cbfad, (q31_t)0x89fac65d, + (q31_t)0x3186f487, (q31_t)0x89f857d8, (q31_t)0x31812943, (q31_t)0x89f5e99c, (q31_t)0x317b5de0, (q31_t)0x89f37ba9, + (q31_t)0x3175925e, (q31_t)0x89f10dff, + (q31_t)0x316fc6be, (q31_t)0x89eea09d, (q31_t)0x3169fb00, (q31_t)0x89ec3384, (q31_t)0x31642f23, (q31_t)0x89e9c6b4, + (q31_t)0x315e6328, (q31_t)0x89e75a2d, + (q31_t)0x3158970e, (q31_t)0x89e4edef, (q31_t)0x3152cad5, (q31_t)0x89e281fa, (q31_t)0x314cfe7f, (q31_t)0x89e0164d, + (q31_t)0x31473209, (q31_t)0x89ddaae9, + (q31_t)0x31416576, (q31_t)0x89db3fcf, (q31_t)0x313b98c4, (q31_t)0x89d8d4fd, (q31_t)0x3135cbf4, (q31_t)0x89d66a74, + (q31_t)0x312fff05, (q31_t)0x89d40033, + (q31_t)0x312a31f8, (q31_t)0x89d1963c, (q31_t)0x312464cd, (q31_t)0x89cf2c8e, (q31_t)0x311e9783, (q31_t)0x89ccc328, + (q31_t)0x3118ca1b, (q31_t)0x89ca5a0c, + (q31_t)0x3112fc95, (q31_t)0x89c7f138, (q31_t)0x310d2ef0, (q31_t)0x89c588ae, (q31_t)0x3107612e, (q31_t)0x89c3206c, + (q31_t)0x3101934d, (q31_t)0x89c0b873, + (q31_t)0x30fbc54d, (q31_t)0x89be50c3, (q31_t)0x30f5f730, (q31_t)0x89bbe95c, (q31_t)0x30f028f4, (q31_t)0x89b9823e, + (q31_t)0x30ea5a9a, (q31_t)0x89b71b69, + (q31_t)0x30e48c22, (q31_t)0x89b4b4dd, (q31_t)0x30debd8c, (q31_t)0x89b24e9a, (q31_t)0x30d8eed8, (q31_t)0x89afe8a0, + (q31_t)0x30d32006, (q31_t)0x89ad82ef, + (q31_t)0x30cd5115, (q31_t)0x89ab1d87, (q31_t)0x30c78206, (q31_t)0x89a8b868, (q31_t)0x30c1b2da, (q31_t)0x89a65391, + (q31_t)0x30bbe38f, (q31_t)0x89a3ef04, + (q31_t)0x30b61426, (q31_t)0x89a18ac0, (q31_t)0x30b0449f, (q31_t)0x899f26c5, (q31_t)0x30aa74fa, (q31_t)0x899cc313, + (q31_t)0x30a4a537, (q31_t)0x899a5faa, + (q31_t)0x309ed556, (q31_t)0x8997fc8a, (q31_t)0x30990557, (q31_t)0x899599b3, (q31_t)0x3093353a, (q31_t)0x89933725, + (q31_t)0x308d64ff, (q31_t)0x8990d4e0, + (q31_t)0x308794a6, (q31_t)0x898e72e4, (q31_t)0x3081c42f, (q31_t)0x898c1131, (q31_t)0x307bf39b, (q31_t)0x8989afc8, + (q31_t)0x307622e8, (q31_t)0x89874ea7, + (q31_t)0x30705217, (q31_t)0x8984edcf, (q31_t)0x306a8129, (q31_t)0x89828d41, (q31_t)0x3064b01d, (q31_t)0x89802cfc, + (q31_t)0x305edef3, (q31_t)0x897dccff, + (q31_t)0x30590dab, (q31_t)0x897b6d4c, (q31_t)0x30533c45, (q31_t)0x89790de2, (q31_t)0x304d6ac1, (q31_t)0x8976aec1, + (q31_t)0x30479920, (q31_t)0x89744fe9, + (q31_t)0x3041c761, (q31_t)0x8971f15a, (q31_t)0x303bf584, (q31_t)0x896f9315, (q31_t)0x30362389, (q31_t)0x896d3518, + (q31_t)0x30305171, (q31_t)0x896ad765, + (q31_t)0x302a7f3a, (q31_t)0x896879fb, (q31_t)0x3024ace6, (q31_t)0x89661cda, (q31_t)0x301eda75, (q31_t)0x8963c002, + (q31_t)0x301907e6, (q31_t)0x89616373, + (q31_t)0x30133539, (q31_t)0x895f072e, (q31_t)0x300d626e, (q31_t)0x895cab31, (q31_t)0x30078f86, (q31_t)0x895a4f7e, + (q31_t)0x3001bc80, (q31_t)0x8957f414, + (q31_t)0x2ffbe95d, (q31_t)0x895598f3, (q31_t)0x2ff6161c, (q31_t)0x89533e1c, (q31_t)0x2ff042bd, (q31_t)0x8950e38e, + (q31_t)0x2fea6f41, (q31_t)0x894e8948, + (q31_t)0x2fe49ba7, (q31_t)0x894c2f4c, (q31_t)0x2fdec7f0, (q31_t)0x8949d59a, (q31_t)0x2fd8f41b, (q31_t)0x89477c30, + (q31_t)0x2fd32028, (q31_t)0x89452310, + (q31_t)0x2fcd4c19, (q31_t)0x8942ca39, (q31_t)0x2fc777eb, (q31_t)0x894071ab, (q31_t)0x2fc1a3a0, (q31_t)0x893e1967, + (q31_t)0x2fbbcf38, (q31_t)0x893bc16b, + (q31_t)0x2fb5fab2, (q31_t)0x893969b9, (q31_t)0x2fb0260f, (q31_t)0x89371250, (q31_t)0x2faa514f, (q31_t)0x8934bb31, + (q31_t)0x2fa47c71, (q31_t)0x8932645b, + (q31_t)0x2f9ea775, (q31_t)0x89300dce, (q31_t)0x2f98d25d, (q31_t)0x892db78a, (q31_t)0x2f92fd26, (q31_t)0x892b6190, + (q31_t)0x2f8d27d3, (q31_t)0x89290bdf, + (q31_t)0x2f875262, (q31_t)0x8926b677, (q31_t)0x2f817cd4, (q31_t)0x89246159, (q31_t)0x2f7ba729, (q31_t)0x89220c84, + (q31_t)0x2f75d160, (q31_t)0x891fb7f8, + (q31_t)0x2f6ffb7a, (q31_t)0x891d63b5, (q31_t)0x2f6a2577, (q31_t)0x891b0fbc, (q31_t)0x2f644f56, (q31_t)0x8918bc0c, + (q31_t)0x2f5e7919, (q31_t)0x891668a6, + (q31_t)0x2f58a2be, (q31_t)0x89141589, (q31_t)0x2f52cc46, (q31_t)0x8911c2b5, (q31_t)0x2f4cf5b0, (q31_t)0x890f702b, + (q31_t)0x2f471efe, (q31_t)0x890d1dea, + (q31_t)0x2f41482e, (q31_t)0x890acbf2, (q31_t)0x2f3b7141, (q31_t)0x89087a44, (q31_t)0x2f359a37, (q31_t)0x890628df, + (q31_t)0x2f2fc310, (q31_t)0x8903d7c4, + (q31_t)0x2f29ebcc, (q31_t)0x890186f2, (q31_t)0x2f24146b, (q31_t)0x88ff3669, (q31_t)0x2f1e3ced, (q31_t)0x88fce62a, + (q31_t)0x2f186551, (q31_t)0x88fa9634, + (q31_t)0x2f128d99, (q31_t)0x88f84687, (q31_t)0x2f0cb5c3, (q31_t)0x88f5f724, (q31_t)0x2f06ddd1, (q31_t)0x88f3a80b, + (q31_t)0x2f0105c1, (q31_t)0x88f1593b, + (q31_t)0x2efb2d95, (q31_t)0x88ef0ab4, (q31_t)0x2ef5554b, (q31_t)0x88ecbc77, (q31_t)0x2eef7ce5, (q31_t)0x88ea6e83, + (q31_t)0x2ee9a461, (q31_t)0x88e820d9, + (q31_t)0x2ee3cbc1, (q31_t)0x88e5d378, (q31_t)0x2eddf304, (q31_t)0x88e38660, (q31_t)0x2ed81a29, (q31_t)0x88e13992, + (q31_t)0x2ed24132, (q31_t)0x88deed0e, + (q31_t)0x2ecc681e, (q31_t)0x88dca0d3, (q31_t)0x2ec68eed, (q31_t)0x88da54e1, (q31_t)0x2ec0b5a0, (q31_t)0x88d8093a, + (q31_t)0x2ebadc35, (q31_t)0x88d5bddb, + (q31_t)0x2eb502ae, (q31_t)0x88d372c6, (q31_t)0x2eaf290a, (q31_t)0x88d127fb, (q31_t)0x2ea94f49, (q31_t)0x88cedd79, + (q31_t)0x2ea3756b, (q31_t)0x88cc9340, + (q31_t)0x2e9d9b70, (q31_t)0x88ca4951, (q31_t)0x2e97c159, (q31_t)0x88c7ffac, (q31_t)0x2e91e725, (q31_t)0x88c5b650, + (q31_t)0x2e8c0cd4, (q31_t)0x88c36d3e, + (q31_t)0x2e863267, (q31_t)0x88c12475, (q31_t)0x2e8057dd, (q31_t)0x88bedbf6, (q31_t)0x2e7a7d36, (q31_t)0x88bc93c0, + (q31_t)0x2e74a272, (q31_t)0x88ba4bd4, + (q31_t)0x2e6ec792, (q31_t)0x88b80432, (q31_t)0x2e68ec95, (q31_t)0x88b5bcd9, (q31_t)0x2e63117c, (q31_t)0x88b375ca, + (q31_t)0x2e5d3646, (q31_t)0x88b12f04, + (q31_t)0x2e575af3, (q31_t)0x88aee888, (q31_t)0x2e517f84, (q31_t)0x88aca255, (q31_t)0x2e4ba3f8, (q31_t)0x88aa5c6c, + (q31_t)0x2e45c850, (q31_t)0x88a816cd, + (q31_t)0x2e3fec8b, (q31_t)0x88a5d177, (q31_t)0x2e3a10aa, (q31_t)0x88a38c6b, (q31_t)0x2e3434ac, (q31_t)0x88a147a9, + (q31_t)0x2e2e5891, (q31_t)0x889f0330, + (q31_t)0x2e287c5a, (q31_t)0x889cbf01, (q31_t)0x2e22a007, (q31_t)0x889a7b1b, (q31_t)0x2e1cc397, (q31_t)0x88983780, + (q31_t)0x2e16e70b, (q31_t)0x8895f42d, + (q31_t)0x2e110a62, (q31_t)0x8893b125, (q31_t)0x2e0b2d9d, (q31_t)0x88916e66, (q31_t)0x2e0550bb, (q31_t)0x888f2bf1, + (q31_t)0x2dff73bd, (q31_t)0x888ce9c5, + (q31_t)0x2df996a3, (q31_t)0x888aa7e3, (q31_t)0x2df3b96c, (q31_t)0x8888664b, (q31_t)0x2deddc19, (q31_t)0x888624fd, + (q31_t)0x2de7feaa, (q31_t)0x8883e3f8, + (q31_t)0x2de2211e, (q31_t)0x8881a33d, (q31_t)0x2ddc4376, (q31_t)0x887f62cb, (q31_t)0x2dd665b2, (q31_t)0x887d22a4, + (q31_t)0x2dd087d1, (q31_t)0x887ae2c6, + (q31_t)0x2dcaa9d5, (q31_t)0x8878a332, (q31_t)0x2dc4cbbc, (q31_t)0x887663e7, (q31_t)0x2dbeed86, (q31_t)0x887424e7, + (q31_t)0x2db90f35, (q31_t)0x8871e630, + (q31_t)0x2db330c7, (q31_t)0x886fa7c2, (q31_t)0x2dad523d, (q31_t)0x886d699f, (q31_t)0x2da77397, (q31_t)0x886b2bc5, + (q31_t)0x2da194d5, (q31_t)0x8868ee35, + (q31_t)0x2d9bb5f6, (q31_t)0x8866b0ef, (q31_t)0x2d95d6fc, (q31_t)0x886473f2, (q31_t)0x2d8ff7e5, (q31_t)0x88623740, + (q31_t)0x2d8a18b3, (q31_t)0x885ffad7, + (q31_t)0x2d843964, (q31_t)0x885dbeb8, (q31_t)0x2d7e59f9, (q31_t)0x885b82e3, (q31_t)0x2d787a72, (q31_t)0x88594757, + (q31_t)0x2d729acf, (q31_t)0x88570c16, + (q31_t)0x2d6cbb10, (q31_t)0x8854d11e, (q31_t)0x2d66db35, (q31_t)0x88529670, (q31_t)0x2d60fb3e, (q31_t)0x88505c0b, + (q31_t)0x2d5b1b2b, (q31_t)0x884e21f1, + (q31_t)0x2d553afc, (q31_t)0x884be821, (q31_t)0x2d4f5ab1, (q31_t)0x8849ae9a, (q31_t)0x2d497a4a, (q31_t)0x8847755d, + (q31_t)0x2d4399c7, (q31_t)0x88453c6a, + (q31_t)0x2d3db928, (q31_t)0x884303c1, (q31_t)0x2d37d86d, (q31_t)0x8840cb61, (q31_t)0x2d31f797, (q31_t)0x883e934c, + (q31_t)0x2d2c16a4, (q31_t)0x883c5b81, + (q31_t)0x2d263596, (q31_t)0x883a23ff, (q31_t)0x2d20546b, (q31_t)0x8837ecc7, (q31_t)0x2d1a7325, (q31_t)0x8835b5d9, + (q31_t)0x2d1491c4, (q31_t)0x88337f35, + (q31_t)0x2d0eb046, (q31_t)0x883148db, (q31_t)0x2d08ceac, (q31_t)0x882f12cb, (q31_t)0x2d02ecf7, (q31_t)0x882cdd04, + (q31_t)0x2cfd0b26, (q31_t)0x882aa788, + (q31_t)0x2cf72939, (q31_t)0x88287256, (q31_t)0x2cf14731, (q31_t)0x88263d6d, (q31_t)0x2ceb650d, (q31_t)0x882408ce, + (q31_t)0x2ce582cd, (q31_t)0x8821d47a, + (q31_t)0x2cdfa071, (q31_t)0x881fa06f, (q31_t)0x2cd9bdfa, (q31_t)0x881d6cae, (q31_t)0x2cd3db67, (q31_t)0x881b3937, + (q31_t)0x2ccdf8b8, (q31_t)0x8819060a, + (q31_t)0x2cc815ee, (q31_t)0x8816d327, (q31_t)0x2cc23308, (q31_t)0x8814a08f, (q31_t)0x2cbc5006, (q31_t)0x88126e40, + (q31_t)0x2cb66ce9, (q31_t)0x88103c3b, + (q31_t)0x2cb089b1, (q31_t)0x880e0a7f, (q31_t)0x2caaa65c, (q31_t)0x880bd90e, (q31_t)0x2ca4c2ed, (q31_t)0x8809a7e7, + (q31_t)0x2c9edf61, (q31_t)0x8807770a, + (q31_t)0x2c98fbba, (q31_t)0x88054677, (q31_t)0x2c9317f8, (q31_t)0x8803162e, (q31_t)0x2c8d341a, (q31_t)0x8800e62f, + (q31_t)0x2c875021, (q31_t)0x87feb67a, + (q31_t)0x2c816c0c, (q31_t)0x87fc870f, (q31_t)0x2c7b87dc, (q31_t)0x87fa57ee, (q31_t)0x2c75a390, (q31_t)0x87f82917, + (q31_t)0x2c6fbf29, (q31_t)0x87f5fa8b, + (q31_t)0x2c69daa6, (q31_t)0x87f3cc48, (q31_t)0x2c63f609, (q31_t)0x87f19e4f, (q31_t)0x2c5e114f, (q31_t)0x87ef70a0, + (q31_t)0x2c582c7b, (q31_t)0x87ed433c, + (q31_t)0x2c52478a, (q31_t)0x87eb1621, (q31_t)0x2c4c627f, (q31_t)0x87e8e950, (q31_t)0x2c467d58, (q31_t)0x87e6bcca, + (q31_t)0x2c409816, (q31_t)0x87e4908e, + (q31_t)0x2c3ab2b9, (q31_t)0x87e2649b, (q31_t)0x2c34cd40, (q31_t)0x87e038f3, (q31_t)0x2c2ee7ad, (q31_t)0x87de0d95, + (q31_t)0x2c2901fd, (q31_t)0x87dbe281, + (q31_t)0x2c231c33, (q31_t)0x87d9b7b7, (q31_t)0x2c1d364e, (q31_t)0x87d78d38, (q31_t)0x2c17504d, (q31_t)0x87d56302, + (q31_t)0x2c116a31, (q31_t)0x87d33916, + (q31_t)0x2c0b83fa, (q31_t)0x87d10f75, (q31_t)0x2c059da7, (q31_t)0x87cee61e, (q31_t)0x2bffb73a, (q31_t)0x87ccbd11, + (q31_t)0x2bf9d0b1, (q31_t)0x87ca944e, + (q31_t)0x2bf3ea0d, (q31_t)0x87c86bd5, (q31_t)0x2bee034e, (q31_t)0x87c643a6, (q31_t)0x2be81c74, (q31_t)0x87c41bc2, + (q31_t)0x2be2357f, (q31_t)0x87c1f427, + (q31_t)0x2bdc4e6f, (q31_t)0x87bfccd7, (q31_t)0x2bd66744, (q31_t)0x87bda5d1, (q31_t)0x2bd07ffe, (q31_t)0x87bb7f16, + (q31_t)0x2bca989d, (q31_t)0x87b958a4, + (q31_t)0x2bc4b120, (q31_t)0x87b7327d, (q31_t)0x2bbec989, (q31_t)0x87b50c9f, (q31_t)0x2bb8e1d7, (q31_t)0x87b2e70c, + (q31_t)0x2bb2fa0a, (q31_t)0x87b0c1c4, + (q31_t)0x2bad1221, (q31_t)0x87ae9cc5, (q31_t)0x2ba72a1e, (q31_t)0x87ac7811, (q31_t)0x2ba14200, (q31_t)0x87aa53a6, + (q31_t)0x2b9b59c7, (q31_t)0x87a82f87, + (q31_t)0x2b957173, (q31_t)0x87a60bb1, (q31_t)0x2b8f8905, (q31_t)0x87a3e825, (q31_t)0x2b89a07b, (q31_t)0x87a1c4e4, + (q31_t)0x2b83b7d7, (q31_t)0x879fa1ed, + (q31_t)0x2b7dcf17, (q31_t)0x879d7f41, (q31_t)0x2b77e63d, (q31_t)0x879b5cde, (q31_t)0x2b71fd48, (q31_t)0x87993ac6, + (q31_t)0x2b6c1438, (q31_t)0x879718f8, + (q31_t)0x2b662b0e, (q31_t)0x8794f774, (q31_t)0x2b6041c9, (q31_t)0x8792d63b, (q31_t)0x2b5a5868, (q31_t)0x8790b54c, + (q31_t)0x2b546eee, (q31_t)0x878e94a7, + (q31_t)0x2b4e8558, (q31_t)0x878c744d, (q31_t)0x2b489ba8, (q31_t)0x878a543d, (q31_t)0x2b42b1dd, (q31_t)0x87883477, + (q31_t)0x2b3cc7f7, (q31_t)0x878614fb, + (q31_t)0x2b36ddf7, (q31_t)0x8783f5ca, (q31_t)0x2b30f3dc, (q31_t)0x8781d6e3, (q31_t)0x2b2b09a6, (q31_t)0x877fb846, + (q31_t)0x2b251f56, (q31_t)0x877d99f4, + (q31_t)0x2b1f34eb, (q31_t)0x877b7bec, (q31_t)0x2b194a66, (q31_t)0x87795e2f, (q31_t)0x2b135fc6, (q31_t)0x877740bb, + (q31_t)0x2b0d750b, (q31_t)0x87752392, + (q31_t)0x2b078a36, (q31_t)0x877306b4, (q31_t)0x2b019f46, (q31_t)0x8770ea20, (q31_t)0x2afbb43c, (q31_t)0x876ecdd6, + (q31_t)0x2af5c917, (q31_t)0x876cb1d6, + (q31_t)0x2aefddd8, (q31_t)0x876a9621, (q31_t)0x2ae9f27e, (q31_t)0x87687ab7, (q31_t)0x2ae4070a, (q31_t)0x87665f96, + (q31_t)0x2ade1b7c, (q31_t)0x876444c1, + (q31_t)0x2ad82fd2, (q31_t)0x87622a35, (q31_t)0x2ad2440f, (q31_t)0x87600ff4, (q31_t)0x2acc5831, (q31_t)0x875df5fd, + (q31_t)0x2ac66c39, (q31_t)0x875bdc51, + (q31_t)0x2ac08026, (q31_t)0x8759c2ef, (q31_t)0x2aba93f9, (q31_t)0x8757a9d8, (q31_t)0x2ab4a7b1, (q31_t)0x8755910b, + (q31_t)0x2aaebb50, (q31_t)0x87537888, + (q31_t)0x2aa8ced3, (q31_t)0x87516050, (q31_t)0x2aa2e23d, (q31_t)0x874f4862, (q31_t)0x2a9cf58c, (q31_t)0x874d30bf, + (q31_t)0x2a9708c1, (q31_t)0x874b1966, + (q31_t)0x2a911bdc, (q31_t)0x87490258, (q31_t)0x2a8b2edc, (q31_t)0x8746eb94, (q31_t)0x2a8541c3, (q31_t)0x8744d51b, + (q31_t)0x2a7f548e, (q31_t)0x8742beec, + (q31_t)0x2a796740, (q31_t)0x8740a907, (q31_t)0x2a7379d8, (q31_t)0x873e936d, (q31_t)0x2a6d8c55, (q31_t)0x873c7e1e, + (q31_t)0x2a679eb8, (q31_t)0x873a6919, + (q31_t)0x2a61b101, (q31_t)0x8738545e, (q31_t)0x2a5bc330, (q31_t)0x87363fee, (q31_t)0x2a55d545, (q31_t)0x87342bc9, + (q31_t)0x2a4fe740, (q31_t)0x873217ee, + (q31_t)0x2a49f920, (q31_t)0x8730045d, (q31_t)0x2a440ae7, (q31_t)0x872df117, (q31_t)0x2a3e1c93, (q31_t)0x872bde1c, + (q31_t)0x2a382e25, (q31_t)0x8729cb6b, + (q31_t)0x2a323f9e, (q31_t)0x8727b905, (q31_t)0x2a2c50fc, (q31_t)0x8725a6e9, (q31_t)0x2a266240, (q31_t)0x87239518, + (q31_t)0x2a20736a, (q31_t)0x87218391, + (q31_t)0x2a1a847b, (q31_t)0x871f7255, (q31_t)0x2a149571, (q31_t)0x871d6163, (q31_t)0x2a0ea64d, (q31_t)0x871b50bc, + (q31_t)0x2a08b710, (q31_t)0x87194060, + (q31_t)0x2a02c7b8, (q31_t)0x8717304e, (q31_t)0x29fcd847, (q31_t)0x87152087, (q31_t)0x29f6e8bb, (q31_t)0x8713110a, + (q31_t)0x29f0f916, (q31_t)0x871101d8, + (q31_t)0x29eb0957, (q31_t)0x870ef2f1, (q31_t)0x29e5197e, (q31_t)0x870ce454, (q31_t)0x29df298b, (q31_t)0x870ad602, + (q31_t)0x29d9397f, (q31_t)0x8708c7fa, + (q31_t)0x29d34958, (q31_t)0x8706ba3d, (q31_t)0x29cd5918, (q31_t)0x8704acca, (q31_t)0x29c768be, (q31_t)0x87029fa3, + (q31_t)0x29c1784a, (q31_t)0x870092c5, + (q31_t)0x29bb87bc, (q31_t)0x86fe8633, (q31_t)0x29b59715, (q31_t)0x86fc79eb, (q31_t)0x29afa654, (q31_t)0x86fa6dee, + (q31_t)0x29a9b579, (q31_t)0x86f8623b, + (q31_t)0x29a3c485, (q31_t)0x86f656d3, (q31_t)0x299dd377, (q31_t)0x86f44bb6, (q31_t)0x2997e24f, (q31_t)0x86f240e3, + (q31_t)0x2991f10e, (q31_t)0x86f0365c, + (q31_t)0x298bffb2, (q31_t)0x86ee2c1e, (q31_t)0x29860e3e, (q31_t)0x86ec222c, (q31_t)0x29801caf, (q31_t)0x86ea1884, + (q31_t)0x297a2b07, (q31_t)0x86e80f27, + (q31_t)0x29743946, (q31_t)0x86e60614, (q31_t)0x296e476b, (q31_t)0x86e3fd4c, (q31_t)0x29685576, (q31_t)0x86e1f4cf, + (q31_t)0x29626368, (q31_t)0x86dfec9d, + (q31_t)0x295c7140, (q31_t)0x86dde4b5, (q31_t)0x29567eff, (q31_t)0x86dbdd18, (q31_t)0x29508ca4, (q31_t)0x86d9d5c6, + (q31_t)0x294a9a30, (q31_t)0x86d7cebf, + (q31_t)0x2944a7a2, (q31_t)0x86d5c802, (q31_t)0x293eb4fb, (q31_t)0x86d3c190, (q31_t)0x2938c23a, (q31_t)0x86d1bb69, + (q31_t)0x2932cf60, (q31_t)0x86cfb58c, + (q31_t)0x292cdc6d, (q31_t)0x86cdaffa, (q31_t)0x2926e960, (q31_t)0x86cbaab3, (q31_t)0x2920f63a, (q31_t)0x86c9a5b7, + (q31_t)0x291b02fa, (q31_t)0x86c7a106, + (q31_t)0x29150fa1, (q31_t)0x86c59c9f, (q31_t)0x290f1c2f, (q31_t)0x86c39883, (q31_t)0x290928a3, (q31_t)0x86c194b2, + (q31_t)0x290334ff, (q31_t)0x86bf912c, + (q31_t)0x28fd4140, (q31_t)0x86bd8df0, (q31_t)0x28f74d69, (q31_t)0x86bb8b00, (q31_t)0x28f15978, (q31_t)0x86b9885a, + (q31_t)0x28eb656e, (q31_t)0x86b785ff, + (q31_t)0x28e5714b, (q31_t)0x86b583ee, (q31_t)0x28df7d0e, (q31_t)0x86b38229, (q31_t)0x28d988b8, (q31_t)0x86b180ae, + (q31_t)0x28d3944a, (q31_t)0x86af7f7e, + (q31_t)0x28cd9fc1, (q31_t)0x86ad7e99, (q31_t)0x28c7ab20, (q31_t)0x86ab7dff, (q31_t)0x28c1b666, (q31_t)0x86a97db0, + (q31_t)0x28bbc192, (q31_t)0x86a77dab, + (q31_t)0x28b5cca5, (q31_t)0x86a57df2, (q31_t)0x28afd7a0, (q31_t)0x86a37e83, (q31_t)0x28a9e281, (q31_t)0x86a17f5f, + (q31_t)0x28a3ed49, (q31_t)0x869f8086, + (q31_t)0x289df7f8, (q31_t)0x869d81f8, (q31_t)0x2898028e, (q31_t)0x869b83b4, (q31_t)0x28920d0a, (q31_t)0x869985bc, + (q31_t)0x288c176e, (q31_t)0x8697880f, + (q31_t)0x288621b9, (q31_t)0x86958aac, (q31_t)0x28802beb, (q31_t)0x86938d94, (q31_t)0x287a3604, (q31_t)0x869190c7, + (q31_t)0x28744004, (q31_t)0x868f9445, + (q31_t)0x286e49ea, (q31_t)0x868d980e, (q31_t)0x286853b8, (q31_t)0x868b9c22, (q31_t)0x28625d6d, (q31_t)0x8689a081, + (q31_t)0x285c670a, (q31_t)0x8687a52b, + (q31_t)0x2856708d, (q31_t)0x8685aa20, (q31_t)0x285079f7, (q31_t)0x8683af5f, (q31_t)0x284a8349, (q31_t)0x8681b4ea, + (q31_t)0x28448c81, (q31_t)0x867fbabf, + (q31_t)0x283e95a1, (q31_t)0x867dc0e0, (q31_t)0x28389ea8, (q31_t)0x867bc74b, (q31_t)0x2832a796, (q31_t)0x8679ce01, + (q31_t)0x282cb06c, (q31_t)0x8677d503, + (q31_t)0x2826b928, (q31_t)0x8675dc4f, (q31_t)0x2820c1cc, (q31_t)0x8673e3e6, (q31_t)0x281aca57, (q31_t)0x8671ebc8, + (q31_t)0x2814d2c9, (q31_t)0x866ff3f6, + (q31_t)0x280edb23, (q31_t)0x866dfc6e, (q31_t)0x2808e364, (q31_t)0x866c0531, (q31_t)0x2802eb8c, (q31_t)0x866a0e3f, + (q31_t)0x27fcf39c, (q31_t)0x86681798, + (q31_t)0x27f6fb92, (q31_t)0x8666213c, (q31_t)0x27f10371, (q31_t)0x86642b2c, (q31_t)0x27eb0b36, (q31_t)0x86623566, + (q31_t)0x27e512e3, (q31_t)0x86603feb, + (q31_t)0x27df1a77, (q31_t)0x865e4abb, (q31_t)0x27d921f3, (q31_t)0x865c55d7, (q31_t)0x27d32956, (q31_t)0x865a613d, + (q31_t)0x27cd30a1, (q31_t)0x86586cee, + (q31_t)0x27c737d3, (q31_t)0x865678eb, (q31_t)0x27c13eec, (q31_t)0x86548532, (q31_t)0x27bb45ed, (q31_t)0x865291c4, + (q31_t)0x27b54cd6, (q31_t)0x86509ea2, + (q31_t)0x27af53a6, (q31_t)0x864eabcb, (q31_t)0x27a95a5d, (q31_t)0x864cb93e, (q31_t)0x27a360fc, (q31_t)0x864ac6fd, + (q31_t)0x279d6783, (q31_t)0x8648d507, + (q31_t)0x27976df1, (q31_t)0x8646e35c, (q31_t)0x27917447, (q31_t)0x8644f1fc, (q31_t)0x278b7a84, (q31_t)0x864300e7, + (q31_t)0x278580a9, (q31_t)0x8641101d, + (q31_t)0x277f86b5, (q31_t)0x863f1f9e, (q31_t)0x27798caa, (q31_t)0x863d2f6b, (q31_t)0x27739285, (q31_t)0x863b3f82, + (q31_t)0x276d9849, (q31_t)0x86394fe5, + (q31_t)0x27679df4, (q31_t)0x86376092, (q31_t)0x2761a387, (q31_t)0x8635718b, (q31_t)0x275ba901, (q31_t)0x863382cf, + (q31_t)0x2755ae64, (q31_t)0x8631945e, + (q31_t)0x274fb3ae, (q31_t)0x862fa638, (q31_t)0x2749b8e0, (q31_t)0x862db85e, (q31_t)0x2743bdf9, (q31_t)0x862bcace, + (q31_t)0x273dc2fa, (q31_t)0x8629dd8a, + (q31_t)0x2737c7e3, (q31_t)0x8627f091, (q31_t)0x2731ccb4, (q31_t)0x862603e3, (q31_t)0x272bd16d, (q31_t)0x86241780, + (q31_t)0x2725d60e, (q31_t)0x86222b68, + (q31_t)0x271fda96, (q31_t)0x86203f9c, (q31_t)0x2719df06, (q31_t)0x861e541a, (q31_t)0x2713e35f, (q31_t)0x861c68e4, + (q31_t)0x270de79f, (q31_t)0x861a7df9, + (q31_t)0x2707ebc7, (q31_t)0x86189359, (q31_t)0x2701efd7, (q31_t)0x8616a905, (q31_t)0x26fbf3ce, (q31_t)0x8614befb, + (q31_t)0x26f5f7ae, (q31_t)0x8612d53d, + (q31_t)0x26effb76, (q31_t)0x8610ebca, (q31_t)0x26e9ff26, (q31_t)0x860f02a3, (q31_t)0x26e402bd, (q31_t)0x860d19c6, + (q31_t)0x26de063d, (q31_t)0x860b3135, + (q31_t)0x26d809a5, (q31_t)0x860948ef, (q31_t)0x26d20cf5, (q31_t)0x860760f4, (q31_t)0x26cc102d, (q31_t)0x86057944, + (q31_t)0x26c6134d, (q31_t)0x860391e0, + (q31_t)0x26c01655, (q31_t)0x8601aac7, (q31_t)0x26ba1945, (q31_t)0x85ffc3f9, (q31_t)0x26b41c1d, (q31_t)0x85fddd76, + (q31_t)0x26ae1edd, (q31_t)0x85fbf73f, + (q31_t)0x26a82186, (q31_t)0x85fa1153, (q31_t)0x26a22416, (q31_t)0x85f82bb2, (q31_t)0x269c268f, (q31_t)0x85f6465c, + (q31_t)0x269628f0, (q31_t)0x85f46152, + (q31_t)0x26902b39, (q31_t)0x85f27c93, (q31_t)0x268a2d6b, (q31_t)0x85f09820, (q31_t)0x26842f84, (q31_t)0x85eeb3f7, + (q31_t)0x267e3186, (q31_t)0x85ecd01a, + (q31_t)0x26783370, (q31_t)0x85eaec88, (q31_t)0x26723543, (q31_t)0x85e90942, (q31_t)0x266c36fe, (q31_t)0x85e72647, + (q31_t)0x266638a1, (q31_t)0x85e54397, + (q31_t)0x26603a2c, (q31_t)0x85e36132, (q31_t)0x265a3b9f, (q31_t)0x85e17f19, (q31_t)0x26543cfb, (q31_t)0x85df9d4b, + (q31_t)0x264e3e40, (q31_t)0x85ddbbc9, + (q31_t)0x26483f6c, (q31_t)0x85dbda91, (q31_t)0x26424082, (q31_t)0x85d9f9a5, (q31_t)0x263c417f, (q31_t)0x85d81905, + (q31_t)0x26364265, (q31_t)0x85d638b0, + (q31_t)0x26304333, (q31_t)0x85d458a6, (q31_t)0x262a43ea, (q31_t)0x85d278e7, (q31_t)0x26244489, (q31_t)0x85d09974, + (q31_t)0x261e4511, (q31_t)0x85ceba4d, + (q31_t)0x26184581, (q31_t)0x85ccdb70, (q31_t)0x261245da, (q31_t)0x85cafcdf, (q31_t)0x260c461b, (q31_t)0x85c91e9a, + (q31_t)0x26064645, (q31_t)0x85c740a0, + (q31_t)0x26004657, (q31_t)0x85c562f1, (q31_t)0x25fa4652, (q31_t)0x85c3858d, (q31_t)0x25f44635, (q31_t)0x85c1a875, + (q31_t)0x25ee4601, (q31_t)0x85bfcba9, + (q31_t)0x25e845b6, (q31_t)0x85bdef28, (q31_t)0x25e24553, (q31_t)0x85bc12f2, (q31_t)0x25dc44d9, (q31_t)0x85ba3707, + (q31_t)0x25d64447, (q31_t)0x85b85b68, + (q31_t)0x25d0439f, (q31_t)0x85b68015, (q31_t)0x25ca42de, (q31_t)0x85b4a50d, (q31_t)0x25c44207, (q31_t)0x85b2ca50, + (q31_t)0x25be4118, (q31_t)0x85b0efdf, + (q31_t)0x25b84012, (q31_t)0x85af15b9, (q31_t)0x25b23ef5, (q31_t)0x85ad3bdf, (q31_t)0x25ac3dc0, (q31_t)0x85ab6250, + (q31_t)0x25a63c74, (q31_t)0x85a9890d, + (q31_t)0x25a03b11, (q31_t)0x85a7b015, (q31_t)0x259a3997, (q31_t)0x85a5d768, (q31_t)0x25943806, (q31_t)0x85a3ff07, + (q31_t)0x258e365d, (q31_t)0x85a226f2, + (q31_t)0x2588349d, (q31_t)0x85a04f28, (q31_t)0x258232c6, (q31_t)0x859e77a9, (q31_t)0x257c30d8, (q31_t)0x859ca076, + (q31_t)0x25762ed3, (q31_t)0x859ac98f, + (q31_t)0x25702cb7, (q31_t)0x8598f2f3, (q31_t)0x256a2a83, (q31_t)0x85971ca2, (q31_t)0x25642839, (q31_t)0x8595469d, + (q31_t)0x255e25d7, (q31_t)0x859370e4, + (q31_t)0x2558235f, (q31_t)0x85919b76, (q31_t)0x255220cf, (q31_t)0x858fc653, (q31_t)0x254c1e28, (q31_t)0x858df17c, + (q31_t)0x25461b6b, (q31_t)0x858c1cf1, + (q31_t)0x25401896, (q31_t)0x858a48b1, (q31_t)0x253a15aa, (q31_t)0x858874bd, (q31_t)0x253412a8, (q31_t)0x8586a114, + (q31_t)0x252e0f8e, (q31_t)0x8584cdb7, + (q31_t)0x25280c5e, (q31_t)0x8582faa5, (q31_t)0x25220916, (q31_t)0x858127df, (q31_t)0x251c05b8, (q31_t)0x857f5564, + (q31_t)0x25160243, (q31_t)0x857d8335, + (q31_t)0x250ffeb7, (q31_t)0x857bb152, (q31_t)0x2509fb14, (q31_t)0x8579dfba, (q31_t)0x2503f75a, (q31_t)0x85780e6e, + (q31_t)0x24fdf389, (q31_t)0x85763d6d, + (q31_t)0x24f7efa2, (q31_t)0x85746cb8, (q31_t)0x24f1eba4, (q31_t)0x85729c4e, (q31_t)0x24ebe78f, (q31_t)0x8570cc30, + (q31_t)0x24e5e363, (q31_t)0x856efc5e, + (q31_t)0x24dfdf20, (q31_t)0x856d2cd7, (q31_t)0x24d9dac7, (q31_t)0x856b5d9c, (q31_t)0x24d3d657, (q31_t)0x85698ead, + (q31_t)0x24cdd1d0, (q31_t)0x8567c009, + (q31_t)0x24c7cd33, (q31_t)0x8565f1b0, (q31_t)0x24c1c87f, (q31_t)0x856423a4, (q31_t)0x24bbc3b4, (q31_t)0x856255e3, + (q31_t)0x24b5bed2, (q31_t)0x8560886d, + (q31_t)0x24afb9da, (q31_t)0x855ebb44, (q31_t)0x24a9b4cb, (q31_t)0x855cee66, (q31_t)0x24a3afa6, (q31_t)0x855b21d3, + (q31_t)0x249daa6a, (q31_t)0x8559558c, + (q31_t)0x2497a517, (q31_t)0x85578991, (q31_t)0x24919fae, (q31_t)0x8555bde2, (q31_t)0x248b9a2f, (q31_t)0x8553f27e, + (q31_t)0x24859498, (q31_t)0x85522766, + (q31_t)0x247f8eec, (q31_t)0x85505c99, (q31_t)0x24798928, (q31_t)0x854e9219, (q31_t)0x2473834f, (q31_t)0x854cc7e3, + (q31_t)0x246d7d5e, (q31_t)0x854afdfa, + (q31_t)0x24677758, (q31_t)0x8549345c, (q31_t)0x2461713a, (q31_t)0x85476b0a, (q31_t)0x245b6b07, (q31_t)0x8545a204, + (q31_t)0x245564bd, (q31_t)0x8543d949, + (q31_t)0x244f5e5c, (q31_t)0x854210db, (q31_t)0x244957e5, (q31_t)0x854048b7, (q31_t)0x24435158, (q31_t)0x853e80e0, + (q31_t)0x243d4ab4, (q31_t)0x853cb954, + (q31_t)0x243743fa, (q31_t)0x853af214, (q31_t)0x24313d2a, (q31_t)0x85392b20, (q31_t)0x242b3644, (q31_t)0x85376477, + (q31_t)0x24252f47, (q31_t)0x85359e1a, + (q31_t)0x241f2833, (q31_t)0x8533d809, (q31_t)0x2419210a, (q31_t)0x85321244, (q31_t)0x241319ca, (q31_t)0x85304cca, + (q31_t)0x240d1274, (q31_t)0x852e879d, + (q31_t)0x24070b08, (q31_t)0x852cc2bb, (q31_t)0x24010385, (q31_t)0x852afe24, (q31_t)0x23fafbec, (q31_t)0x852939da, + (q31_t)0x23f4f43e, (q31_t)0x852775db, + (q31_t)0x23eeec78, (q31_t)0x8525b228, (q31_t)0x23e8e49d, (q31_t)0x8523eec1, (q31_t)0x23e2dcac, (q31_t)0x85222ba5, + (q31_t)0x23dcd4a4, (q31_t)0x852068d6, + (q31_t)0x23d6cc87, (q31_t)0x851ea652, (q31_t)0x23d0c453, (q31_t)0x851ce41a, (q31_t)0x23cabc09, (q31_t)0x851b222e, + (q31_t)0x23c4b3a9, (q31_t)0x8519608d, + (q31_t)0x23beab33, (q31_t)0x85179f39, (q31_t)0x23b8a2a7, (q31_t)0x8515de30, (q31_t)0x23b29a05, (q31_t)0x85141d73, + (q31_t)0x23ac914d, (q31_t)0x85125d02, + (q31_t)0x23a6887f, (q31_t)0x85109cdd, (q31_t)0x23a07f9a, (q31_t)0x850edd03, (q31_t)0x239a76a0, (q31_t)0x850d1d75, + (q31_t)0x23946d90, (q31_t)0x850b5e34, + (q31_t)0x238e646a, (q31_t)0x85099f3e, (q31_t)0x23885b2e, (q31_t)0x8507e094, (q31_t)0x238251dd, (q31_t)0x85062235, + (q31_t)0x237c4875, (q31_t)0x85046423, + (q31_t)0x23763ef7, (q31_t)0x8502a65c, (q31_t)0x23703564, (q31_t)0x8500e8e2, (q31_t)0x236a2bba, (q31_t)0x84ff2bb3, + (q31_t)0x236421fb, (q31_t)0x84fd6ed0, + (q31_t)0x235e1826, (q31_t)0x84fbb239, (q31_t)0x23580e3b, (q31_t)0x84f9f5ee, (q31_t)0x2352043b, (q31_t)0x84f839ee, + (q31_t)0x234bfa24, (q31_t)0x84f67e3b, + (q31_t)0x2345eff8, (q31_t)0x84f4c2d4, (q31_t)0x233fe5b6, (q31_t)0x84f307b8, (q31_t)0x2339db5e, (q31_t)0x84f14ce8, + (q31_t)0x2333d0f1, (q31_t)0x84ef9265, + (q31_t)0x232dc66d, (q31_t)0x84edd82d, (q31_t)0x2327bbd5, (q31_t)0x84ec1e41, (q31_t)0x2321b126, (q31_t)0x84ea64a1, + (q31_t)0x231ba662, (q31_t)0x84e8ab4d, + (q31_t)0x23159b88, (q31_t)0x84e6f244, (q31_t)0x230f9098, (q31_t)0x84e53988, (q31_t)0x23098593, (q31_t)0x84e38118, + (q31_t)0x23037a78, (q31_t)0x84e1c8f3, + (q31_t)0x22fd6f48, (q31_t)0x84e0111b, (q31_t)0x22f76402, (q31_t)0x84de598f, (q31_t)0x22f158a7, (q31_t)0x84dca24e, + (q31_t)0x22eb4d36, (q31_t)0x84daeb5a, + (q31_t)0x22e541af, (q31_t)0x84d934b1, (q31_t)0x22df3613, (q31_t)0x84d77e54, (q31_t)0x22d92a61, (q31_t)0x84d5c844, + (q31_t)0x22d31e9a, (q31_t)0x84d4127f, + (q31_t)0x22cd12bd, (q31_t)0x84d25d06, (q31_t)0x22c706cb, (q31_t)0x84d0a7da, (q31_t)0x22c0fac4, (q31_t)0x84cef2f9, + (q31_t)0x22baeea7, (q31_t)0x84cd3e64, + (q31_t)0x22b4e274, (q31_t)0x84cb8a1b, (q31_t)0x22aed62c, (q31_t)0x84c9d61f, (q31_t)0x22a8c9cf, (q31_t)0x84c8226e, + (q31_t)0x22a2bd5d, (q31_t)0x84c66f09, + (q31_t)0x229cb0d5, (q31_t)0x84c4bbf0, (q31_t)0x2296a437, (q31_t)0x84c30924, (q31_t)0x22909785, (q31_t)0x84c156a3, + (q31_t)0x228a8abd, (q31_t)0x84bfa46e, + (q31_t)0x22847de0, (q31_t)0x84bdf286, (q31_t)0x227e70ed, (q31_t)0x84bc40e9, (q31_t)0x227863e5, (q31_t)0x84ba8f98, + (q31_t)0x227256c8, (q31_t)0x84b8de94, + (q31_t)0x226c4996, (q31_t)0x84b72ddb, (q31_t)0x22663c4e, (q31_t)0x84b57d6f, (q31_t)0x22602ef1, (q31_t)0x84b3cd4f, + (q31_t)0x225a217f, (q31_t)0x84b21d7a, + (q31_t)0x225413f8, (q31_t)0x84b06df2, (q31_t)0x224e065c, (q31_t)0x84aebeb6, (q31_t)0x2247f8aa, (q31_t)0x84ad0fc6, + (q31_t)0x2241eae3, (q31_t)0x84ab6122, + (q31_t)0x223bdd08, (q31_t)0x84a9b2ca, (q31_t)0x2235cf17, (q31_t)0x84a804be, (q31_t)0x222fc111, (q31_t)0x84a656fe, + (q31_t)0x2229b2f6, (q31_t)0x84a4a98a, + (q31_t)0x2223a4c5, (q31_t)0x84a2fc62, (q31_t)0x221d9680, (q31_t)0x84a14f87, (q31_t)0x22178826, (q31_t)0x849fa2f7, + (q31_t)0x221179b7, (q31_t)0x849df6b4, + (q31_t)0x220b6b32, (q31_t)0x849c4abd, (q31_t)0x22055c99, (q31_t)0x849a9f12, (q31_t)0x21ff4dea, (q31_t)0x8498f3b3, + (q31_t)0x21f93f27, (q31_t)0x849748a0, + (q31_t)0x21f3304f, (q31_t)0x84959dd9, (q31_t)0x21ed2162, (q31_t)0x8493f35e, (q31_t)0x21e71260, (q31_t)0x84924930, + (q31_t)0x21e10349, (q31_t)0x84909f4e, + (q31_t)0x21daf41d, (q31_t)0x848ef5b7, (q31_t)0x21d4e4dc, (q31_t)0x848d4c6d, (q31_t)0x21ced586, (q31_t)0x848ba36f, + (q31_t)0x21c8c61c, (q31_t)0x8489fabe, + (q31_t)0x21c2b69c, (q31_t)0x84885258, (q31_t)0x21bca708, (q31_t)0x8486aa3e, (q31_t)0x21b6975f, (q31_t)0x84850271, + (q31_t)0x21b087a1, (q31_t)0x84835af0, + (q31_t)0x21aa77cf, (q31_t)0x8481b3bb, (q31_t)0x21a467e7, (q31_t)0x84800cd2, (q31_t)0x219e57eb, (q31_t)0x847e6636, + (q31_t)0x219847da, (q31_t)0x847cbfe5, + (q31_t)0x219237b5, (q31_t)0x847b19e1, (q31_t)0x218c277a, (q31_t)0x84797429, (q31_t)0x2186172b, (q31_t)0x8477cebd, + (q31_t)0x218006c8, (q31_t)0x8476299e, + (q31_t)0x2179f64f, (q31_t)0x847484ca, (q31_t)0x2173e5c2, (q31_t)0x8472e043, (q31_t)0x216dd521, (q31_t)0x84713c08, + (q31_t)0x2167c46b, (q31_t)0x846f9819, + (q31_t)0x2161b3a0, (q31_t)0x846df477, (q31_t)0x215ba2c0, (q31_t)0x846c5120, (q31_t)0x215591cc, (q31_t)0x846aae16, + (q31_t)0x214f80c4, (q31_t)0x84690b58, + (q31_t)0x21496fa7, (q31_t)0x846768e7, (q31_t)0x21435e75, (q31_t)0x8465c6c1, (q31_t)0x213d4d2f, (q31_t)0x846424e8, + (q31_t)0x21373bd4, (q31_t)0x8462835b, + (q31_t)0x21312a65, (q31_t)0x8460e21a, (q31_t)0x212b18e1, (q31_t)0x845f4126, (q31_t)0x21250749, (q31_t)0x845da07e, + (q31_t)0x211ef59d, (q31_t)0x845c0022, + (q31_t)0x2118e3dc, (q31_t)0x845a6012, (q31_t)0x2112d206, (q31_t)0x8458c04f, (q31_t)0x210cc01d, (q31_t)0x845720d8, + (q31_t)0x2106ae1e, (q31_t)0x845581ad, + (q31_t)0x21009c0c, (q31_t)0x8453e2cf, (q31_t)0x20fa89e5, (q31_t)0x8452443d, (q31_t)0x20f477aa, (q31_t)0x8450a5f7, + (q31_t)0x20ee655a, (q31_t)0x844f07fd, + (q31_t)0x20e852f6, (q31_t)0x844d6a50, (q31_t)0x20e2407e, (q31_t)0x844bccef, (q31_t)0x20dc2df2, (q31_t)0x844a2fda, + (q31_t)0x20d61b51, (q31_t)0x84489311, + (q31_t)0x20d0089c, (q31_t)0x8446f695, (q31_t)0x20c9f5d3, (q31_t)0x84455a66, (q31_t)0x20c3e2f5, (q31_t)0x8443be82, + (q31_t)0x20bdd003, (q31_t)0x844222eb, + (q31_t)0x20b7bcfe, (q31_t)0x844087a0, (q31_t)0x20b1a9e4, (q31_t)0x843eeca2, (q31_t)0x20ab96b5, (q31_t)0x843d51f0, + (q31_t)0x20a58373, (q31_t)0x843bb78a, + (q31_t)0x209f701c, (q31_t)0x843a1d70, (q31_t)0x20995cb2, (q31_t)0x843883a3, (q31_t)0x20934933, (q31_t)0x8436ea23, + (q31_t)0x208d35a0, (q31_t)0x843550ee, + (q31_t)0x208721f9, (q31_t)0x8433b806, (q31_t)0x20810e3e, (q31_t)0x84321f6b, (q31_t)0x207afa6f, (q31_t)0x8430871b, + (q31_t)0x2074e68c, (q31_t)0x842eef18, + (q31_t)0x206ed295, (q31_t)0x842d5762, (q31_t)0x2068be8a, (q31_t)0x842bbff8, (q31_t)0x2062aa6b, (q31_t)0x842a28da, + (q31_t)0x205c9638, (q31_t)0x84289209, + (q31_t)0x205681f1, (q31_t)0x8426fb84, (q31_t)0x20506d96, (q31_t)0x8425654b, (q31_t)0x204a5927, (q31_t)0x8423cf5f, + (q31_t)0x204444a4, (q31_t)0x842239bf, + (q31_t)0x203e300d, (q31_t)0x8420a46c, (q31_t)0x20381b63, (q31_t)0x841f0f65, (q31_t)0x203206a4, (q31_t)0x841d7aaa, + (q31_t)0x202bf1d2, (q31_t)0x841be63c, + (q31_t)0x2025dcec, (q31_t)0x841a521a, (q31_t)0x201fc7f2, (q31_t)0x8418be45, (q31_t)0x2019b2e4, (q31_t)0x84172abc, + (q31_t)0x20139dc2, (q31_t)0x84159780, + (q31_t)0x200d888d, (q31_t)0x84140490, (q31_t)0x20077344, (q31_t)0x841271ec, (q31_t)0x20015de7, (q31_t)0x8410df95, + (q31_t)0x1ffb4876, (q31_t)0x840f4d8a, + (q31_t)0x1ff532f2, (q31_t)0x840dbbcc, (q31_t)0x1fef1d59, (q31_t)0x840c2a5a, (q31_t)0x1fe907ae, (q31_t)0x840a9935, + (q31_t)0x1fe2f1ee, (q31_t)0x8409085c, + (q31_t)0x1fdcdc1b, (q31_t)0x840777d0, (q31_t)0x1fd6c634, (q31_t)0x8405e790, (q31_t)0x1fd0b03a, (q31_t)0x8404579d, + (q31_t)0x1fca9a2b, (q31_t)0x8402c7f6, + (q31_t)0x1fc4840a, (q31_t)0x8401389b, (q31_t)0x1fbe6dd4, (q31_t)0x83ffa98d, (q31_t)0x1fb8578b, (q31_t)0x83fe1acc, + (q31_t)0x1fb2412f, (q31_t)0x83fc8c57, + (q31_t)0x1fac2abf, (q31_t)0x83fafe2e, (q31_t)0x1fa6143b, (q31_t)0x83f97052, (q31_t)0x1f9ffda4, (q31_t)0x83f7e2c3, + (q31_t)0x1f99e6fa, (q31_t)0x83f65580, + (q31_t)0x1f93d03c, (q31_t)0x83f4c889, (q31_t)0x1f8db96a, (q31_t)0x83f33bdf, (q31_t)0x1f87a285, (q31_t)0x83f1af82, + (q31_t)0x1f818b8d, (q31_t)0x83f02371, + (q31_t)0x1f7b7481, (q31_t)0x83ee97ad, (q31_t)0x1f755d61, (q31_t)0x83ed0c35, (q31_t)0x1f6f462f, (q31_t)0x83eb810a, + (q31_t)0x1f692ee9, (q31_t)0x83e9f62b, + (q31_t)0x1f63178f, (q31_t)0x83e86b99, (q31_t)0x1f5d0022, (q31_t)0x83e6e153, (q31_t)0x1f56e8a2, (q31_t)0x83e5575a, + (q31_t)0x1f50d10e, (q31_t)0x83e3cdad, + (q31_t)0x1f4ab968, (q31_t)0x83e2444d, (q31_t)0x1f44a1ad, (q31_t)0x83e0bb3a, (q31_t)0x1f3e89e0, (q31_t)0x83df3273, + (q31_t)0x1f3871ff, (q31_t)0x83dda9f9, + (q31_t)0x1f325a0b, (q31_t)0x83dc21cb, (q31_t)0x1f2c4204, (q31_t)0x83da99ea, (q31_t)0x1f2629ea, (q31_t)0x83d91255, + (q31_t)0x1f2011bc, (q31_t)0x83d78b0d, + (q31_t)0x1f19f97b, (q31_t)0x83d60412, (q31_t)0x1f13e127, (q31_t)0x83d47d63, (q31_t)0x1f0dc8c0, (q31_t)0x83d2f701, + (q31_t)0x1f07b045, (q31_t)0x83d170eb, + (q31_t)0x1f0197b8, (q31_t)0x83cfeb22, (q31_t)0x1efb7f17, (q31_t)0x83ce65a6, (q31_t)0x1ef56664, (q31_t)0x83cce076, + (q31_t)0x1eef4d9d, (q31_t)0x83cb5b93, + (q31_t)0x1ee934c3, (q31_t)0x83c9d6fc, (q31_t)0x1ee31bd6, (q31_t)0x83c852b2, (q31_t)0x1edd02d6, (q31_t)0x83c6ceb5, + (q31_t)0x1ed6e9c3, (q31_t)0x83c54b04, + (q31_t)0x1ed0d09d, (q31_t)0x83c3c7a0, (q31_t)0x1ecab763, (q31_t)0x83c24488, (q31_t)0x1ec49e17, (q31_t)0x83c0c1be, + (q31_t)0x1ebe84b8, (q31_t)0x83bf3f3f, + (q31_t)0x1eb86b46, (q31_t)0x83bdbd0e, (q31_t)0x1eb251c1, (q31_t)0x83bc3b29, (q31_t)0x1eac3829, (q31_t)0x83bab991, + (q31_t)0x1ea61e7e, (q31_t)0x83b93845, + (q31_t)0x1ea004c1, (q31_t)0x83b7b746, (q31_t)0x1e99eaf0, (q31_t)0x83b63694, (q31_t)0x1e93d10c, (q31_t)0x83b4b62e, + (q31_t)0x1e8db716, (q31_t)0x83b33616, + (q31_t)0x1e879d0d, (q31_t)0x83b1b649, (q31_t)0x1e8182f1, (q31_t)0x83b036ca, (q31_t)0x1e7b68c2, (q31_t)0x83aeb797, + (q31_t)0x1e754e80, (q31_t)0x83ad38b1, + (q31_t)0x1e6f342c, (q31_t)0x83abba17, (q31_t)0x1e6919c4, (q31_t)0x83aa3bca, (q31_t)0x1e62ff4a, (q31_t)0x83a8bdca, + (q31_t)0x1e5ce4be, (q31_t)0x83a74017, + (q31_t)0x1e56ca1e, (q31_t)0x83a5c2b0, (q31_t)0x1e50af6c, (q31_t)0x83a44596, (q31_t)0x1e4a94a7, (q31_t)0x83a2c8c9, + (q31_t)0x1e4479cf, (q31_t)0x83a14c48, + (q31_t)0x1e3e5ee5, (q31_t)0x839fd014, (q31_t)0x1e3843e8, (q31_t)0x839e542d, (q31_t)0x1e3228d9, (q31_t)0x839cd893, + (q31_t)0x1e2c0db6, (q31_t)0x839b5d45, + (q31_t)0x1e25f282, (q31_t)0x8399e244, (q31_t)0x1e1fd73a, (q31_t)0x83986790, (q31_t)0x1e19bbe0, (q31_t)0x8396ed29, + (q31_t)0x1e13a074, (q31_t)0x8395730e, + (q31_t)0x1e0d84f5, (q31_t)0x8393f940, (q31_t)0x1e076963, (q31_t)0x83927fbf, (q31_t)0x1e014dbf, (q31_t)0x8391068a, + (q31_t)0x1dfb3208, (q31_t)0x838f8da2, + (q31_t)0x1df5163f, (q31_t)0x838e1507, (q31_t)0x1deefa63, (q31_t)0x838c9cb9, (q31_t)0x1de8de75, (q31_t)0x838b24b8, + (q31_t)0x1de2c275, (q31_t)0x8389ad03, + (q31_t)0x1ddca662, (q31_t)0x8388359b, (q31_t)0x1dd68a3c, (q31_t)0x8386be80, (q31_t)0x1dd06e04, (q31_t)0x838547b2, + (q31_t)0x1dca51ba, (q31_t)0x8383d130, + (q31_t)0x1dc4355e, (q31_t)0x83825afb, (q31_t)0x1dbe18ef, (q31_t)0x8380e513, (q31_t)0x1db7fc6d, (q31_t)0x837f6f78, + (q31_t)0x1db1dfda, (q31_t)0x837dfa2a, + (q31_t)0x1dabc334, (q31_t)0x837c8528, (q31_t)0x1da5a67c, (q31_t)0x837b1074, (q31_t)0x1d9f89b1, (q31_t)0x83799c0c, + (q31_t)0x1d996cd4, (q31_t)0x837827f0, + (q31_t)0x1d934fe5, (q31_t)0x8376b422, (q31_t)0x1d8d32e4, (q31_t)0x837540a1, (q31_t)0x1d8715d0, (q31_t)0x8373cd6c, + (q31_t)0x1d80f8ab, (q31_t)0x83725a84, + (q31_t)0x1d7adb73, (q31_t)0x8370e7e9, (q31_t)0x1d74be29, (q31_t)0x836f759b, (q31_t)0x1d6ea0cc, (q31_t)0x836e039a, + (q31_t)0x1d68835e, (q31_t)0x836c91e5, + (q31_t)0x1d6265dd, (q31_t)0x836b207d, (q31_t)0x1d5c484b, (q31_t)0x8369af63, (q31_t)0x1d562aa6, (q31_t)0x83683e95, + (q31_t)0x1d500cef, (q31_t)0x8366ce14, + (q31_t)0x1d49ef26, (q31_t)0x83655ddf, (q31_t)0x1d43d14b, (q31_t)0x8363edf8, (q31_t)0x1d3db35e, (q31_t)0x83627e5d, + (q31_t)0x1d37955e, (q31_t)0x83610f10, + (q31_t)0x1d31774d, (q31_t)0x835fa00f, (q31_t)0x1d2b592a, (q31_t)0x835e315b, (q31_t)0x1d253af5, (q31_t)0x835cc2f4, + (q31_t)0x1d1f1cae, (q31_t)0x835b54da, + (q31_t)0x1d18fe54, (q31_t)0x8359e70d, (q31_t)0x1d12dfe9, (q31_t)0x8358798c, (q31_t)0x1d0cc16c, (q31_t)0x83570c59, + (q31_t)0x1d06a2dd, (q31_t)0x83559f72, + (q31_t)0x1d00843d, (q31_t)0x835432d8, (q31_t)0x1cfa658a, (q31_t)0x8352c68c, (q31_t)0x1cf446c5, (q31_t)0x83515a8c, + (q31_t)0x1cee27ef, (q31_t)0x834feed9, + (q31_t)0x1ce80906, (q31_t)0x834e8373, (q31_t)0x1ce1ea0c, (q31_t)0x834d185a, (q31_t)0x1cdbcb00, (q31_t)0x834bad8e, + (q31_t)0x1cd5abe3, (q31_t)0x834a430e, + (q31_t)0x1ccf8cb3, (q31_t)0x8348d8dc, (q31_t)0x1cc96d72, (q31_t)0x83476ef6, (q31_t)0x1cc34e1f, (q31_t)0x8346055e, + (q31_t)0x1cbd2eba, (q31_t)0x83449c12, + (q31_t)0x1cb70f43, (q31_t)0x83433314, (q31_t)0x1cb0efbb, (q31_t)0x8341ca62, (q31_t)0x1caad021, (q31_t)0x834061fd, + (q31_t)0x1ca4b075, (q31_t)0x833ef9e6, + (q31_t)0x1c9e90b8, (q31_t)0x833d921b, (q31_t)0x1c9870e9, (q31_t)0x833c2a9d, (q31_t)0x1c925109, (q31_t)0x833ac36c, + (q31_t)0x1c8c3116, (q31_t)0x83395c88, + (q31_t)0x1c861113, (q31_t)0x8337f5f1, (q31_t)0x1c7ff0fd, (q31_t)0x83368fa7, (q31_t)0x1c79d0d6, (q31_t)0x833529aa, + (q31_t)0x1c73b09d, (q31_t)0x8333c3fa, + (q31_t)0x1c6d9053, (q31_t)0x83325e97, (q31_t)0x1c676ff8, (q31_t)0x8330f981, (q31_t)0x1c614f8b, (q31_t)0x832f94b8, + (q31_t)0x1c5b2f0c, (q31_t)0x832e303c, + (q31_t)0x1c550e7c, (q31_t)0x832ccc0d, (q31_t)0x1c4eedda, (q31_t)0x832b682b, (q31_t)0x1c48cd27, (q31_t)0x832a0496, + (q31_t)0x1c42ac62, (q31_t)0x8328a14d, + (q31_t)0x1c3c8b8c, (q31_t)0x83273e52, (q31_t)0x1c366aa5, (q31_t)0x8325dba4, (q31_t)0x1c3049ac, (q31_t)0x83247943, + (q31_t)0x1c2a28a2, (q31_t)0x8323172f, + (q31_t)0x1c240786, (q31_t)0x8321b568, (q31_t)0x1c1de659, (q31_t)0x832053ee, (q31_t)0x1c17c51b, (q31_t)0x831ef2c1, + (q31_t)0x1c11a3cb, (q31_t)0x831d91e1, + (q31_t)0x1c0b826a, (q31_t)0x831c314e, (q31_t)0x1c0560f8, (q31_t)0x831ad109, (q31_t)0x1bff3f75, (q31_t)0x83197110, + (q31_t)0x1bf91de0, (q31_t)0x83181164, + (q31_t)0x1bf2fc3a, (q31_t)0x8316b205, (q31_t)0x1becda83, (q31_t)0x831552f4, (q31_t)0x1be6b8ba, (q31_t)0x8313f42f, + (q31_t)0x1be096e0, (q31_t)0x831295b7, + (q31_t)0x1bda74f6, (q31_t)0x8311378d, (q31_t)0x1bd452f9, (q31_t)0x830fd9af, (q31_t)0x1bce30ec, (q31_t)0x830e7c1f, + (q31_t)0x1bc80ece, (q31_t)0x830d1edc, + (q31_t)0x1bc1ec9e, (q31_t)0x830bc1e6, (q31_t)0x1bbbca5e, (q31_t)0x830a653c, (q31_t)0x1bb5a80c, (q31_t)0x830908e0, + (q31_t)0x1baf85a9, (q31_t)0x8307acd1, + (q31_t)0x1ba96335, (q31_t)0x83065110, (q31_t)0x1ba340b0, (q31_t)0x8304f59b, (q31_t)0x1b9d1e1a, (q31_t)0x83039a73, + (q31_t)0x1b96fb73, (q31_t)0x83023f98, + (q31_t)0x1b90d8bb, (q31_t)0x8300e50b, (q31_t)0x1b8ab5f2, (q31_t)0x82ff8acb, (q31_t)0x1b849317, (q31_t)0x82fe30d7, + (q31_t)0x1b7e702c, (q31_t)0x82fcd731, + (q31_t)0x1b784d30, (q31_t)0x82fb7dd8, (q31_t)0x1b722a23, (q31_t)0x82fa24cc, (q31_t)0x1b6c0705, (q31_t)0x82f8cc0d, + (q31_t)0x1b65e3d7, (q31_t)0x82f7739c, + (q31_t)0x1b5fc097, (q31_t)0x82f61b77, (q31_t)0x1b599d46, (q31_t)0x82f4c3a0, (q31_t)0x1b5379e5, (q31_t)0x82f36c15, + (q31_t)0x1b4d5672, (q31_t)0x82f214d8, + (q31_t)0x1b4732ef, (q31_t)0x82f0bde8, (q31_t)0x1b410f5b, (q31_t)0x82ef6745, (q31_t)0x1b3aebb6, (q31_t)0x82ee10ef, + (q31_t)0x1b34c801, (q31_t)0x82ecbae7, + (q31_t)0x1b2ea43a, (q31_t)0x82eb652b, (q31_t)0x1b288063, (q31_t)0x82ea0fbd, (q31_t)0x1b225c7b, (q31_t)0x82e8ba9c, + (q31_t)0x1b1c3883, (q31_t)0x82e765c8, + (q31_t)0x1b161479, (q31_t)0x82e61141, (q31_t)0x1b0ff05f, (q31_t)0x82e4bd07, (q31_t)0x1b09cc34, (q31_t)0x82e3691b, + (q31_t)0x1b03a7f9, (q31_t)0x82e2157c, + (q31_t)0x1afd83ad, (q31_t)0x82e0c22a, (q31_t)0x1af75f50, (q31_t)0x82df6f25, (q31_t)0x1af13ae3, (q31_t)0x82de1c6d, + (q31_t)0x1aeb1665, (q31_t)0x82dcca02, + (q31_t)0x1ae4f1d6, (q31_t)0x82db77e5, (q31_t)0x1adecd37, (q31_t)0x82da2615, (q31_t)0x1ad8a887, (q31_t)0x82d8d492, + (q31_t)0x1ad283c7, (q31_t)0x82d7835c, + (q31_t)0x1acc5ef6, (q31_t)0x82d63274, (q31_t)0x1ac63a14, (q31_t)0x82d4e1d8, (q31_t)0x1ac01522, (q31_t)0x82d3918a, + (q31_t)0x1ab9f020, (q31_t)0x82d24189, + (q31_t)0x1ab3cb0d, (q31_t)0x82d0f1d5, (q31_t)0x1aada5e9, (q31_t)0x82cfa26f, (q31_t)0x1aa780b6, (q31_t)0x82ce5356, + (q31_t)0x1aa15b71, (q31_t)0x82cd048a, + (q31_t)0x1a9b361d, (q31_t)0x82cbb60b, (q31_t)0x1a9510b7, (q31_t)0x82ca67d9, (q31_t)0x1a8eeb42, (q31_t)0x82c919f5, + (q31_t)0x1a88c5bc, (q31_t)0x82c7cc5e, + (q31_t)0x1a82a026, (q31_t)0x82c67f14, (q31_t)0x1a7c7a7f, (q31_t)0x82c53217, (q31_t)0x1a7654c8, (q31_t)0x82c3e568, + (q31_t)0x1a702f01, (q31_t)0x82c29906, + (q31_t)0x1a6a0929, (q31_t)0x82c14cf1, (q31_t)0x1a63e341, (q31_t)0x82c00129, (q31_t)0x1a5dbd49, (q31_t)0x82beb5af, + (q31_t)0x1a579741, (q31_t)0x82bd6a82, + (q31_t)0x1a517128, (q31_t)0x82bc1fa2, (q31_t)0x1a4b4aff, (q31_t)0x82bad50f, (q31_t)0x1a4524c6, (q31_t)0x82b98aca, + (q31_t)0x1a3efe7c, (q31_t)0x82b840d2, + (q31_t)0x1a38d823, (q31_t)0x82b6f727, (q31_t)0x1a32b1b9, (q31_t)0x82b5adca, (q31_t)0x1a2c8b3f, (q31_t)0x82b464ba, + (q31_t)0x1a2664b5, (q31_t)0x82b31bf7, + (q31_t)0x1a203e1b, (q31_t)0x82b1d381, (q31_t)0x1a1a1771, (q31_t)0x82b08b59, (q31_t)0x1a13f0b6, (q31_t)0x82af437e, + (q31_t)0x1a0dc9ec, (q31_t)0x82adfbf0, + (q31_t)0x1a07a311, (q31_t)0x82acb4b0, (q31_t)0x1a017c27, (q31_t)0x82ab6dbd, (q31_t)0x19fb552c, (q31_t)0x82aa2717, + (q31_t)0x19f52e22, (q31_t)0x82a8e0bf, + (q31_t)0x19ef0707, (q31_t)0x82a79ab3, (q31_t)0x19e8dfdc, (q31_t)0x82a654f6, (q31_t)0x19e2b8a2, (q31_t)0x82a50f85, + (q31_t)0x19dc9157, (q31_t)0x82a3ca62, + (q31_t)0x19d669fc, (q31_t)0x82a2858c, (q31_t)0x19d04292, (q31_t)0x82a14104, (q31_t)0x19ca1b17, (q31_t)0x829ffcc8, + (q31_t)0x19c3f38d, (q31_t)0x829eb8db, + (q31_t)0x19bdcbf3, (q31_t)0x829d753a, (q31_t)0x19b7a449, (q31_t)0x829c31e7, (q31_t)0x19b17c8f, (q31_t)0x829aeee1, + (q31_t)0x19ab54c5, (q31_t)0x8299ac29, + (q31_t)0x19a52ceb, (q31_t)0x829869be, (q31_t)0x199f0502, (q31_t)0x829727a0, (q31_t)0x1998dd09, (q31_t)0x8295e5cf, + (q31_t)0x1992b4ff, (q31_t)0x8294a44c, + (q31_t)0x198c8ce7, (q31_t)0x82936317, (q31_t)0x198664be, (q31_t)0x8292222e, (q31_t)0x19803c86, (q31_t)0x8290e194, + (q31_t)0x197a143e, (q31_t)0x828fa146, + (q31_t)0x1973ebe6, (q31_t)0x828e6146, (q31_t)0x196dc37e, (q31_t)0x828d2193, (q31_t)0x19679b07, (q31_t)0x828be22e, + (q31_t)0x19617280, (q31_t)0x828aa316, + (q31_t)0x195b49ea, (q31_t)0x8289644b, (q31_t)0x19552144, (q31_t)0x828825ce, (q31_t)0x194ef88e, (q31_t)0x8286e79e, + (q31_t)0x1948cfc8, (q31_t)0x8285a9bb, + (q31_t)0x1942a6f3, (q31_t)0x82846c26, (q31_t)0x193c7e0f, (q31_t)0x82832edf, (q31_t)0x1936551b, (q31_t)0x8281f1e4, + (q31_t)0x19302c17, (q31_t)0x8280b538, + (q31_t)0x192a0304, (q31_t)0x827f78d8, (q31_t)0x1923d9e1, (q31_t)0x827e3cc6, (q31_t)0x191db0af, (q31_t)0x827d0102, + (q31_t)0x1917876d, (q31_t)0x827bc58a, + (q31_t)0x19115e1c, (q31_t)0x827a8a61, (q31_t)0x190b34bb, (q31_t)0x82794f84, (q31_t)0x19050b4b, (q31_t)0x827814f6, + (q31_t)0x18fee1cb, (q31_t)0x8276dab4, + (q31_t)0x18f8b83c, (q31_t)0x8275a0c0, (q31_t)0x18f28e9e, (q31_t)0x8274671a, (q31_t)0x18ec64f0, (q31_t)0x82732dc0, + (q31_t)0x18e63b33, (q31_t)0x8271f4b5, + (q31_t)0x18e01167, (q31_t)0x8270bbf7, (q31_t)0x18d9e78b, (q31_t)0x826f8386, (q31_t)0x18d3bda0, (q31_t)0x826e4b62, + (q31_t)0x18cd93a5, (q31_t)0x826d138d, + (q31_t)0x18c7699b, (q31_t)0x826bdc04, (q31_t)0x18c13f82, (q31_t)0x826aa4c9, (q31_t)0x18bb155a, (q31_t)0x82696ddc, + (q31_t)0x18b4eb22, (q31_t)0x8268373c, + (q31_t)0x18aec0db, (q31_t)0x826700e9, (q31_t)0x18a89685, (q31_t)0x8265cae4, (q31_t)0x18a26c20, (q31_t)0x8264952d, + (q31_t)0x189c41ab, (q31_t)0x82635fc2, + (q31_t)0x18961728, (q31_t)0x82622aa6, (q31_t)0x188fec95, (q31_t)0x8260f5d7, (q31_t)0x1889c1f3, (q31_t)0x825fc155, + (q31_t)0x18839742, (q31_t)0x825e8d21, + (q31_t)0x187d6c82, (q31_t)0x825d593a, (q31_t)0x187741b2, (q31_t)0x825c25a1, (q31_t)0x187116d4, (q31_t)0x825af255, + (q31_t)0x186aebe6, (q31_t)0x8259bf57, + (q31_t)0x1864c0ea, (q31_t)0x82588ca7, (q31_t)0x185e95de, (q31_t)0x82575a44, (q31_t)0x18586ac3, (q31_t)0x8256282e, + (q31_t)0x18523f9a, (q31_t)0x8254f666, + (q31_t)0x184c1461, (q31_t)0x8253c4eb, (q31_t)0x1845e919, (q31_t)0x825293be, (q31_t)0x183fbdc3, (q31_t)0x825162df, + (q31_t)0x1839925d, (q31_t)0x8250324d, + (q31_t)0x183366e9, (q31_t)0x824f0208, (q31_t)0x182d3b65, (q31_t)0x824dd211, (q31_t)0x18270fd3, (q31_t)0x824ca268, + (q31_t)0x1820e431, (q31_t)0x824b730c, + (q31_t)0x181ab881, (q31_t)0x824a43fe, (q31_t)0x18148cc2, (q31_t)0x8249153d, (q31_t)0x180e60f4, (q31_t)0x8247e6ca, + (q31_t)0x18083518, (q31_t)0x8246b8a4, + (q31_t)0x1802092c, (q31_t)0x82458acc, (q31_t)0x17fbdd32, (q31_t)0x82445d41, (q31_t)0x17f5b129, (q31_t)0x82433004, + (q31_t)0x17ef8511, (q31_t)0x82420315, + (q31_t)0x17e958ea, (q31_t)0x8240d673, (q31_t)0x17e32cb5, (q31_t)0x823faa1e, (q31_t)0x17dd0070, (q31_t)0x823e7e18, + (q31_t)0x17d6d41d, (q31_t)0x823d525e, + (q31_t)0x17d0a7bc, (q31_t)0x823c26f3, (q31_t)0x17ca7b4c, (q31_t)0x823afbd5, (q31_t)0x17c44ecd, (q31_t)0x8239d104, + (q31_t)0x17be223f, (q31_t)0x8238a681, + (q31_t)0x17b7f5a3, (q31_t)0x82377c4c, (q31_t)0x17b1c8f8, (q31_t)0x82365264, (q31_t)0x17ab9c3e, (q31_t)0x823528ca, + (q31_t)0x17a56f76, (q31_t)0x8233ff7e, + (q31_t)0x179f429f, (q31_t)0x8232d67f, (q31_t)0x179915ba, (q31_t)0x8231adce, (q31_t)0x1792e8c6, (q31_t)0x8230856a, + (q31_t)0x178cbbc4, (q31_t)0x822f5d54, + (q31_t)0x17868eb3, (q31_t)0x822e358b, (q31_t)0x17806194, (q31_t)0x822d0e10, (q31_t)0x177a3466, (q31_t)0x822be6e3, + (q31_t)0x17740729, (q31_t)0x822ac004, + (q31_t)0x176dd9de, (q31_t)0x82299971, (q31_t)0x1767ac85, (q31_t)0x8228732d, (q31_t)0x17617f1d, (q31_t)0x82274d36, + (q31_t)0x175b51a7, (q31_t)0x8226278d, + (q31_t)0x17552422, (q31_t)0x82250232, (q31_t)0x174ef68f, (q31_t)0x8223dd24, (q31_t)0x1748c8ee, (q31_t)0x8222b863, + (q31_t)0x17429b3e, (q31_t)0x822193f1, + (q31_t)0x173c6d80, (q31_t)0x82206fcc, (q31_t)0x17363fb4, (q31_t)0x821f4bf5, (q31_t)0x173011d9, (q31_t)0x821e286b, + (q31_t)0x1729e3f0, (q31_t)0x821d052f, + (q31_t)0x1723b5f9, (q31_t)0x821be240, (q31_t)0x171d87f3, (q31_t)0x821abfa0, (q31_t)0x171759df, (q31_t)0x82199d4d, + (q31_t)0x17112bbd, (q31_t)0x82187b47, + (q31_t)0x170afd8d, (q31_t)0x82175990, (q31_t)0x1704cf4f, (q31_t)0x82163826, (q31_t)0x16fea102, (q31_t)0x82151709, + (q31_t)0x16f872a7, (q31_t)0x8213f63a, + (q31_t)0x16f2443e, (q31_t)0x8212d5b9, (q31_t)0x16ec15c7, (q31_t)0x8211b586, (q31_t)0x16e5e741, (q31_t)0x821095a0, + (q31_t)0x16dfb8ae, (q31_t)0x820f7608, + (q31_t)0x16d98a0c, (q31_t)0x820e56be, (q31_t)0x16d35b5c, (q31_t)0x820d37c1, (q31_t)0x16cd2c9f, (q31_t)0x820c1912, + (q31_t)0x16c6fdd3, (q31_t)0x820afab1, + (q31_t)0x16c0cef9, (q31_t)0x8209dc9e, (q31_t)0x16baa011, (q31_t)0x8208bed8, (q31_t)0x16b4711b, (q31_t)0x8207a160, + (q31_t)0x16ae4217, (q31_t)0x82068435, + (q31_t)0x16a81305, (q31_t)0x82056758, (q31_t)0x16a1e3e5, (q31_t)0x82044ac9, (q31_t)0x169bb4b7, (q31_t)0x82032e88, + (q31_t)0x1695857b, (q31_t)0x82021294, + (q31_t)0x168f5632, (q31_t)0x8200f6ef, (q31_t)0x168926da, (q31_t)0x81ffdb96, (q31_t)0x1682f774, (q31_t)0x81fec08c, + (q31_t)0x167cc801, (q31_t)0x81fda5cf, + (q31_t)0x1676987f, (q31_t)0x81fc8b60, (q31_t)0x167068f0, (q31_t)0x81fb713f, (q31_t)0x166a3953, (q31_t)0x81fa576c, + (q31_t)0x166409a8, (q31_t)0x81f93de6, + (q31_t)0x165dd9f0, (q31_t)0x81f824ae, (q31_t)0x1657aa29, (q31_t)0x81f70bc3, (q31_t)0x16517a55, (q31_t)0x81f5f327, + (q31_t)0x164b4a73, (q31_t)0x81f4dad8, + (q31_t)0x16451a83, (q31_t)0x81f3c2d7, (q31_t)0x163eea86, (q31_t)0x81f2ab24, (q31_t)0x1638ba7a, (q31_t)0x81f193be, + (q31_t)0x16328a61, (q31_t)0x81f07ca6, + (q31_t)0x162c5a3b, (q31_t)0x81ef65dc, (q31_t)0x16262a06, (q31_t)0x81ee4f60, (q31_t)0x161ff9c4, (q31_t)0x81ed3932, + (q31_t)0x1619c975, (q31_t)0x81ec2351, + (q31_t)0x16139918, (q31_t)0x81eb0dbe, (q31_t)0x160d68ad, (q31_t)0x81e9f879, (q31_t)0x16073834, (q31_t)0x81e8e381, + (q31_t)0x160107ae, (q31_t)0x81e7ced8, + (q31_t)0x15fad71b, (q31_t)0x81e6ba7c, (q31_t)0x15f4a679, (q31_t)0x81e5a66e, (q31_t)0x15ee75cb, (q31_t)0x81e492ad, + (q31_t)0x15e8450e, (q31_t)0x81e37f3b, + (q31_t)0x15e21445, (q31_t)0x81e26c16, (q31_t)0x15dbe36d, (q31_t)0x81e1593f, (q31_t)0x15d5b288, (q31_t)0x81e046b6, + (q31_t)0x15cf8196, (q31_t)0x81df347b, + (q31_t)0x15c95097, (q31_t)0x81de228d, (q31_t)0x15c31f89, (q31_t)0x81dd10ee, (q31_t)0x15bcee6f, (q31_t)0x81dbff9c, + (q31_t)0x15b6bd47, (q31_t)0x81daee98, + (q31_t)0x15b08c12, (q31_t)0x81d9dde1, (q31_t)0x15aa5acf, (q31_t)0x81d8cd79, (q31_t)0x15a4297f, (q31_t)0x81d7bd5e, + (q31_t)0x159df821, (q31_t)0x81d6ad92, + (q31_t)0x1597c6b7, (q31_t)0x81d59e13, (q31_t)0x1591953e, (q31_t)0x81d48ee1, (q31_t)0x158b63b9, (q31_t)0x81d37ffe, + (q31_t)0x15853226, (q31_t)0x81d27169, + (q31_t)0x157f0086, (q31_t)0x81d16321, (q31_t)0x1578ced9, (q31_t)0x81d05527, (q31_t)0x15729d1f, (q31_t)0x81cf477b, + (q31_t)0x156c6b57, (q31_t)0x81ce3a1d, + (q31_t)0x15663982, (q31_t)0x81cd2d0c, (q31_t)0x156007a0, (q31_t)0x81cc204a, (q31_t)0x1559d5b1, (q31_t)0x81cb13d5, + (q31_t)0x1553a3b4, (q31_t)0x81ca07af, + (q31_t)0x154d71aa, (q31_t)0x81c8fbd6, (q31_t)0x15473f94, (q31_t)0x81c7f04b, (q31_t)0x15410d70, (q31_t)0x81c6e50d, + (q31_t)0x153adb3f, (q31_t)0x81c5da1e, + (q31_t)0x1534a901, (q31_t)0x81c4cf7d, (q31_t)0x152e76b5, (q31_t)0x81c3c529, (q31_t)0x1528445d, (q31_t)0x81c2bb23, + (q31_t)0x152211f8, (q31_t)0x81c1b16b, + (q31_t)0x151bdf86, (q31_t)0x81c0a801, (q31_t)0x1515ad06, (q31_t)0x81bf9ee5, (q31_t)0x150f7a7a, (q31_t)0x81be9617, + (q31_t)0x150947e1, (q31_t)0x81bd8d97, + (q31_t)0x1503153a, (q31_t)0x81bc8564, (q31_t)0x14fce287, (q31_t)0x81bb7d7f, (q31_t)0x14f6afc7, (q31_t)0x81ba75e9, + (q31_t)0x14f07cf9, (q31_t)0x81b96ea0, + (q31_t)0x14ea4a1f, (q31_t)0x81b867a5, (q31_t)0x14e41738, (q31_t)0x81b760f8, (q31_t)0x14dde445, (q31_t)0x81b65a99, + (q31_t)0x14d7b144, (q31_t)0x81b55488, + (q31_t)0x14d17e36, (q31_t)0x81b44ec4, (q31_t)0x14cb4b1c, (q31_t)0x81b3494f, (q31_t)0x14c517f4, (q31_t)0x81b24427, + (q31_t)0x14bee4c0, (q31_t)0x81b13f4e, + (q31_t)0x14b8b17f, (q31_t)0x81b03ac2, (q31_t)0x14b27e32, (q31_t)0x81af3684, (q31_t)0x14ac4ad7, (q31_t)0x81ae3294, + (q31_t)0x14a61770, (q31_t)0x81ad2ef2, + (q31_t)0x149fe3fc, (q31_t)0x81ac2b9e, (q31_t)0x1499b07c, (q31_t)0x81ab2898, (q31_t)0x14937cee, (q31_t)0x81aa25e0, + (q31_t)0x148d4954, (q31_t)0x81a92376, + (q31_t)0x148715ae, (q31_t)0x81a82159, (q31_t)0x1480e1fa, (q31_t)0x81a71f8b, (q31_t)0x147aae3a, (q31_t)0x81a61e0b, + (q31_t)0x14747a6d, (q31_t)0x81a51cd8, + (q31_t)0x146e4694, (q31_t)0x81a41bf4, (q31_t)0x146812ae, (q31_t)0x81a31b5d, (q31_t)0x1461debc, (q31_t)0x81a21b14, + (q31_t)0x145baabd, (q31_t)0x81a11b1a, + (q31_t)0x145576b1, (q31_t)0x81a01b6d, (q31_t)0x144f4299, (q31_t)0x819f1c0e, (q31_t)0x14490e74, (q31_t)0x819e1cfd, + (q31_t)0x1442da43, (q31_t)0x819d1e3a, + (q31_t)0x143ca605, (q31_t)0x819c1fc5, (q31_t)0x143671bb, (q31_t)0x819b219e, (q31_t)0x14303d65, (q31_t)0x819a23c5, + (q31_t)0x142a0902, (q31_t)0x8199263a, + (q31_t)0x1423d492, (q31_t)0x819828fd, (q31_t)0x141da016, (q31_t)0x81972c0e, (q31_t)0x14176b8e, (q31_t)0x81962f6d, + (q31_t)0x141136f9, (q31_t)0x8195331a, + (q31_t)0x140b0258, (q31_t)0x81943715, (q31_t)0x1404cdaa, (q31_t)0x81933b5e, (q31_t)0x13fe98f1, (q31_t)0x81923ff4, + (q31_t)0x13f8642a, (q31_t)0x819144d9, + (q31_t)0x13f22f58, (q31_t)0x81904a0c, (q31_t)0x13ebfa79, (q31_t)0x818f4f8d, (q31_t)0x13e5c58e, (q31_t)0x818e555c, + (q31_t)0x13df9097, (q31_t)0x818d5b78, + (q31_t)0x13d95b93, (q31_t)0x818c61e3, (q31_t)0x13d32683, (q31_t)0x818b689c, (q31_t)0x13ccf167, (q31_t)0x818a6fa3, + (q31_t)0x13c6bc3f, (q31_t)0x818976f8, + (q31_t)0x13c0870a, (q31_t)0x81887e9a, (q31_t)0x13ba51ca, (q31_t)0x8187868b, (q31_t)0x13b41c7d, (q31_t)0x81868eca, + (q31_t)0x13ade724, (q31_t)0x81859757, + (q31_t)0x13a7b1bf, (q31_t)0x8184a032, (q31_t)0x13a17c4d, (q31_t)0x8183a95b, (q31_t)0x139b46d0, (q31_t)0x8182b2d1, + (q31_t)0x13951146, (q31_t)0x8181bc96, + (q31_t)0x138edbb1, (q31_t)0x8180c6a9, (q31_t)0x1388a60f, (q31_t)0x817fd10a, (q31_t)0x13827062, (q31_t)0x817edbb9, + (q31_t)0x137c3aa8, (q31_t)0x817de6b6, + (q31_t)0x137604e2, (q31_t)0x817cf201, (q31_t)0x136fcf10, (q31_t)0x817bfd9b, (q31_t)0x13699933, (q31_t)0x817b0982, + (q31_t)0x13636349, (q31_t)0x817a15b7, + (q31_t)0x135d2d53, (q31_t)0x8179223a, (q31_t)0x1356f752, (q31_t)0x81782f0b, (q31_t)0x1350c144, (q31_t)0x81773c2b, + (q31_t)0x134a8b2b, (q31_t)0x81764998, + (q31_t)0x13445505, (q31_t)0x81755754, (q31_t)0x133e1ed4, (q31_t)0x8174655d, (q31_t)0x1337e897, (q31_t)0x817373b5, + (q31_t)0x1331b24e, (q31_t)0x8172825a, + (q31_t)0x132b7bf9, (q31_t)0x8171914e, (q31_t)0x13254599, (q31_t)0x8170a090, (q31_t)0x131f0f2c, (q31_t)0x816fb020, + (q31_t)0x1318d8b4, (q31_t)0x816ebffe, + (q31_t)0x1312a230, (q31_t)0x816dd02a, (q31_t)0x130c6ba0, (q31_t)0x816ce0a4, (q31_t)0x13063505, (q31_t)0x816bf16c, + (q31_t)0x12fffe5d, (q31_t)0x816b0282, + (q31_t)0x12f9c7aa, (q31_t)0x816a13e6, (q31_t)0x12f390ec, (q31_t)0x81692599, (q31_t)0x12ed5a21, (q31_t)0x81683799, + (q31_t)0x12e7234b, (q31_t)0x816749e8, + (q31_t)0x12e0ec6a, (q31_t)0x81665c84, (q31_t)0x12dab57c, (q31_t)0x81656f6f, (q31_t)0x12d47e83, (q31_t)0x816482a8, + (q31_t)0x12ce477f, (q31_t)0x8163962f, + (q31_t)0x12c8106f, (q31_t)0x8162aa04, (q31_t)0x12c1d953, (q31_t)0x8161be27, (q31_t)0x12bba22b, (q31_t)0x8160d298, + (q31_t)0x12b56af9, (q31_t)0x815fe758, + (q31_t)0x12af33ba, (q31_t)0x815efc65, (q31_t)0x12a8fc70, (q31_t)0x815e11c1, (q31_t)0x12a2c51b, (q31_t)0x815d276a, + (q31_t)0x129c8dba, (q31_t)0x815c3d62, + (q31_t)0x1296564d, (q31_t)0x815b53a8, (q31_t)0x12901ed5, (q31_t)0x815a6a3c, (q31_t)0x1289e752, (q31_t)0x8159811e, + (q31_t)0x1283afc3, (q31_t)0x8158984e, + (q31_t)0x127d7829, (q31_t)0x8157afcd, (q31_t)0x12774083, (q31_t)0x8156c799, (q31_t)0x127108d2, (q31_t)0x8155dfb4, + (q31_t)0x126ad116, (q31_t)0x8154f81d, + (q31_t)0x1264994e, (q31_t)0x815410d4, (q31_t)0x125e617b, (q31_t)0x815329d9, (q31_t)0x1258299c, (q31_t)0x8152432c, + (q31_t)0x1251f1b3, (q31_t)0x81515ccd, + (q31_t)0x124bb9be, (q31_t)0x815076bd, (q31_t)0x124581bd, (q31_t)0x814f90fb, (q31_t)0x123f49b2, (q31_t)0x814eab86, + (q31_t)0x1239119b, (q31_t)0x814dc660, + (q31_t)0x1232d979, (q31_t)0x814ce188, (q31_t)0x122ca14b, (q31_t)0x814bfcff, (q31_t)0x12266913, (q31_t)0x814b18c3, + (q31_t)0x122030cf, (q31_t)0x814a34d6, + (q31_t)0x1219f880, (q31_t)0x81495136, (q31_t)0x1213c026, (q31_t)0x81486de5, (q31_t)0x120d87c1, (q31_t)0x81478ae2, + (q31_t)0x12074f50, (q31_t)0x8146a82e, + (q31_t)0x120116d5, (q31_t)0x8145c5c7, (q31_t)0x11fade4e, (q31_t)0x8144e3ae, (q31_t)0x11f4a5bd, (q31_t)0x814401e4, + (q31_t)0x11ee6d20, (q31_t)0x81432068, + (q31_t)0x11e83478, (q31_t)0x81423f3a, (q31_t)0x11e1fbc5, (q31_t)0x81415e5a, (q31_t)0x11dbc307, (q31_t)0x81407dc9, + (q31_t)0x11d58a3e, (q31_t)0x813f9d86, + (q31_t)0x11cf516a, (q31_t)0x813ebd90, (q31_t)0x11c9188b, (q31_t)0x813ddde9, (q31_t)0x11c2dfa2, (q31_t)0x813cfe91, + (q31_t)0x11bca6ad, (q31_t)0x813c1f86, + (q31_t)0x11b66dad, (q31_t)0x813b40ca, (q31_t)0x11b034a2, (q31_t)0x813a625b, (q31_t)0x11a9fb8d, (q31_t)0x8139843b, + (q31_t)0x11a3c26c, (q31_t)0x8138a66a, + (q31_t)0x119d8941, (q31_t)0x8137c8e6, (q31_t)0x1197500a, (q31_t)0x8136ebb1, (q31_t)0x119116c9, (q31_t)0x81360ec9, + (q31_t)0x118add7d, (q31_t)0x81353230, + (q31_t)0x1184a427, (q31_t)0x813455e6, (q31_t)0x117e6ac5, (q31_t)0x813379e9, (q31_t)0x11783159, (q31_t)0x81329e3b, + (q31_t)0x1171f7e2, (q31_t)0x8131c2db, + (q31_t)0x116bbe60, (q31_t)0x8130e7c9, (q31_t)0x116584d3, (q31_t)0x81300d05, (q31_t)0x115f4b3c, (q31_t)0x812f3290, + (q31_t)0x1159119a, (q31_t)0x812e5868, + (q31_t)0x1152d7ed, (q31_t)0x812d7e8f, (q31_t)0x114c9e35, (q31_t)0x812ca505, (q31_t)0x11466473, (q31_t)0x812bcbc8, + (q31_t)0x11402aa6, (q31_t)0x812af2da, + (q31_t)0x1139f0cf, (q31_t)0x812a1a3a, (q31_t)0x1133b6ed, (q31_t)0x812941e8, (q31_t)0x112d7d00, (q31_t)0x812869e4, + (q31_t)0x11274309, (q31_t)0x8127922f, + (q31_t)0x11210907, (q31_t)0x8126bac8, (q31_t)0x111acefb, (q31_t)0x8125e3af, (q31_t)0x111494e4, (q31_t)0x81250ce4, + (q31_t)0x110e5ac2, (q31_t)0x81243668, + (q31_t)0x11082096, (q31_t)0x8123603a, (q31_t)0x1101e65f, (q31_t)0x81228a5a, (q31_t)0x10fbac1e, (q31_t)0x8121b4c8, + (q31_t)0x10f571d3, (q31_t)0x8120df85, + (q31_t)0x10ef377d, (q31_t)0x81200a90, (q31_t)0x10e8fd1c, (q31_t)0x811f35e9, (q31_t)0x10e2c2b2, (q31_t)0x811e6191, + (q31_t)0x10dc883c, (q31_t)0x811d8d86, + (q31_t)0x10d64dbd, (q31_t)0x811cb9ca, (q31_t)0x10d01333, (q31_t)0x811be65d, (q31_t)0x10c9d89e, (q31_t)0x811b133d, + (q31_t)0x10c39dff, (q31_t)0x811a406c, + (q31_t)0x10bd6356, (q31_t)0x81196de9, (q31_t)0x10b728a3, (q31_t)0x81189bb4, (q31_t)0x10b0ede5, (q31_t)0x8117c9ce, + (q31_t)0x10aab31d, (q31_t)0x8116f836, + (q31_t)0x10a4784b, (q31_t)0x811626ec, (q31_t)0x109e3d6e, (q31_t)0x811555f1, (q31_t)0x10980287, (q31_t)0x81148544, + (q31_t)0x1091c796, (q31_t)0x8113b4e5, + (q31_t)0x108b8c9b, (q31_t)0x8112e4d4, (q31_t)0x10855195, (q31_t)0x81121512, (q31_t)0x107f1686, (q31_t)0x8111459e, + (q31_t)0x1078db6c, (q31_t)0x81107678, + (q31_t)0x1072a048, (q31_t)0x810fa7a0, (q31_t)0x106c651a, (q31_t)0x810ed917, (q31_t)0x106629e1, (q31_t)0x810e0adc, + (q31_t)0x105fee9f, (q31_t)0x810d3cf0, + (q31_t)0x1059b352, (q31_t)0x810c6f52, (q31_t)0x105377fc, (q31_t)0x810ba202, (q31_t)0x104d3c9b, (q31_t)0x810ad500, + (q31_t)0x10470130, (q31_t)0x810a084d, + (q31_t)0x1040c5bb, (q31_t)0x81093be8, (q31_t)0x103a8a3d, (q31_t)0x81086fd1, (q31_t)0x10344eb4, (q31_t)0x8107a409, + (q31_t)0x102e1321, (q31_t)0x8106d88f, + (q31_t)0x1027d784, (q31_t)0x81060d63, (q31_t)0x10219bdd, (q31_t)0x81054286, (q31_t)0x101b602d, (q31_t)0x810477f7, + (q31_t)0x10152472, (q31_t)0x8103adb6, + (q31_t)0x100ee8ad, (q31_t)0x8102e3c4, (q31_t)0x1008acdf, (q31_t)0x81021a20, (q31_t)0x10027107, (q31_t)0x810150ca, + (q31_t)0xffc3524, (q31_t)0x810087c3, + (q31_t)0xff5f938, (q31_t)0x80ffbf0a, (q31_t)0xfefbd42, (q31_t)0x80fef69f, (q31_t)0xfe98143, (q31_t)0x80fe2e83, + (q31_t)0xfe34539, (q31_t)0x80fd66b5, + (q31_t)0xfdd0926, (q31_t)0x80fc9f35, (q31_t)0xfd6cd08, (q31_t)0x80fbd804, (q31_t)0xfd090e1, (q31_t)0x80fb1121, + (q31_t)0xfca54b1, (q31_t)0x80fa4a8c, + (q31_t)0xfc41876, (q31_t)0x80f98446, (q31_t)0xfbddc32, (q31_t)0x80f8be4e, (q31_t)0xfb79fe4, (q31_t)0x80f7f8a4, + (q31_t)0xfb1638d, (q31_t)0x80f73349, + (q31_t)0xfab272b, (q31_t)0x80f66e3c, (q31_t)0xfa4eac0, (q31_t)0x80f5a97e, (q31_t)0xf9eae4c, (q31_t)0x80f4e50e, + (q31_t)0xf9871ce, (q31_t)0x80f420ec, + (q31_t)0xf923546, (q31_t)0x80f35d19, (q31_t)0xf8bf8b4, (q31_t)0x80f29994, (q31_t)0xf85bc19, (q31_t)0x80f1d65d, + (q31_t)0xf7f7f75, (q31_t)0x80f11375, + (q31_t)0xf7942c7, (q31_t)0x80f050db, (q31_t)0xf73060f, (q31_t)0x80ef8e90, (q31_t)0xf6cc94e, (q31_t)0x80eecc93, + (q31_t)0xf668c83, (q31_t)0x80ee0ae4, + (q31_t)0xf604faf, (q31_t)0x80ed4984, (q31_t)0xf5a12d1, (q31_t)0x80ec8872, (q31_t)0xf53d5ea, (q31_t)0x80ebc7ae, + (q31_t)0xf4d98f9, (q31_t)0x80eb0739, + (q31_t)0xf475bff, (q31_t)0x80ea4712, (q31_t)0xf411efb, (q31_t)0x80e9873a, (q31_t)0xf3ae1ee, (q31_t)0x80e8c7b0, + (q31_t)0xf34a4d8, (q31_t)0x80e80874, + (q31_t)0xf2e67b8, (q31_t)0x80e74987, (q31_t)0xf282a8f, (q31_t)0x80e68ae8, (q31_t)0xf21ed5d, (q31_t)0x80e5cc98, + (q31_t)0xf1bb021, (q31_t)0x80e50e96, + (q31_t)0xf1572dc, (q31_t)0x80e450e2, (q31_t)0xf0f358e, (q31_t)0x80e3937d, (q31_t)0xf08f836, (q31_t)0x80e2d666, + (q31_t)0xf02bad5, (q31_t)0x80e2199e, + (q31_t)0xefc7d6b, (q31_t)0x80e15d24, (q31_t)0xef63ff7, (q31_t)0x80e0a0f8, (q31_t)0xef0027b, (q31_t)0x80dfe51b, + (q31_t)0xee9c4f5, (q31_t)0x80df298c, + (q31_t)0xee38766, (q31_t)0x80de6e4c, (q31_t)0xedd49ce, (q31_t)0x80ddb35a, (q31_t)0xed70c2c, (q31_t)0x80dcf8b7, + (q31_t)0xed0ce82, (q31_t)0x80dc3e62, + (q31_t)0xeca90ce, (q31_t)0x80db845b, (q31_t)0xec45311, (q31_t)0x80dacaa3, (q31_t)0xebe154b, (q31_t)0x80da1139, + (q31_t)0xeb7d77c, (q31_t)0x80d9581e, + (q31_t)0xeb199a4, (q31_t)0x80d89f51, (q31_t)0xeab5bc3, (q31_t)0x80d7e6d3, (q31_t)0xea51dd8, (q31_t)0x80d72ea3, + (q31_t)0xe9edfe5, (q31_t)0x80d676c1, + (q31_t)0xe98a1e9, (q31_t)0x80d5bf2e, (q31_t)0xe9263e3, (q31_t)0x80d507e9, (q31_t)0xe8c25d5, (q31_t)0x80d450f3, + (q31_t)0xe85e7be, (q31_t)0x80d39a4b, + (q31_t)0xe7fa99e, (q31_t)0x80d2e3f2, (q31_t)0xe796b74, (q31_t)0x80d22de7, (q31_t)0xe732d42, (q31_t)0x80d1782a, + (q31_t)0xe6cef07, (q31_t)0x80d0c2bc, + (q31_t)0xe66b0c3, (q31_t)0x80d00d9d, (q31_t)0xe607277, (q31_t)0x80cf58cc, (q31_t)0xe5a3421, (q31_t)0x80cea449, + (q31_t)0xe53f5c2, (q31_t)0x80cdf015, + (q31_t)0xe4db75b, (q31_t)0x80cd3c2f, (q31_t)0xe4778eb, (q31_t)0x80cc8898, (q31_t)0xe413a72, (q31_t)0x80cbd54f, + (q31_t)0xe3afbf0, (q31_t)0x80cb2255, + (q31_t)0xe34bd66, (q31_t)0x80ca6fa9, (q31_t)0xe2e7ed2, (q31_t)0x80c9bd4c, (q31_t)0xe284036, (q31_t)0x80c90b3d, + (q31_t)0xe220191, (q31_t)0x80c8597c, + (q31_t)0xe1bc2e4, (q31_t)0x80c7a80a, (q31_t)0xe15842e, (q31_t)0x80c6f6e7, (q31_t)0xe0f456f, (q31_t)0x80c64612, + (q31_t)0xe0906a7, (q31_t)0x80c5958b, + (q31_t)0xe02c7d7, (q31_t)0x80c4e553, (q31_t)0xdfc88fe, (q31_t)0x80c4356a, (q31_t)0xdf64a1c, (q31_t)0x80c385cf, + (q31_t)0xdf00b32, (q31_t)0x80c2d682, + (q31_t)0xde9cc40, (q31_t)0x80c22784, (q31_t)0xde38d44, (q31_t)0x80c178d4, (q31_t)0xddd4e40, (q31_t)0x80c0ca73, + (q31_t)0xdd70f34, (q31_t)0x80c01c60, + (q31_t)0xdd0d01f, (q31_t)0x80bf6e9c, (q31_t)0xdca9102, (q31_t)0x80bec127, (q31_t)0xdc451dc, (q31_t)0x80be13ff, + (q31_t)0xdbe12ad, (q31_t)0x80bd6727, + (q31_t)0xdb7d376, (q31_t)0x80bcba9d, (q31_t)0xdb19437, (q31_t)0x80bc0e61, (q31_t)0xdab54ef, (q31_t)0x80bb6274, + (q31_t)0xda5159f, (q31_t)0x80bab6d5, + (q31_t)0xd9ed646, (q31_t)0x80ba0b85, (q31_t)0xd9896e5, (q31_t)0x80b96083, (q31_t)0xd92577b, (q31_t)0x80b8b5d0, + (q31_t)0xd8c1809, (q31_t)0x80b80b6c, + (q31_t)0xd85d88f, (q31_t)0x80b76156, (q31_t)0xd7f990c, (q31_t)0x80b6b78e, (q31_t)0xd795982, (q31_t)0x80b60e15, + (q31_t)0xd7319ee, (q31_t)0x80b564ea, + (q31_t)0xd6cda53, (q31_t)0x80b4bc0e, (q31_t)0xd669aaf, (q31_t)0x80b41381, (q31_t)0xd605b03, (q31_t)0x80b36b42, + (q31_t)0xd5a1b4f, (q31_t)0x80b2c351, + (q31_t)0xd53db92, (q31_t)0x80b21baf, (q31_t)0xd4d9bcd, (q31_t)0x80b1745c, (q31_t)0xd475c00, (q31_t)0x80b0cd57, + (q31_t)0xd411c2b, (q31_t)0x80b026a1, + (q31_t)0xd3adc4e, (q31_t)0x80af8039, (q31_t)0xd349c68, (q31_t)0x80aeda20, (q31_t)0xd2e5c7b, (q31_t)0x80ae3455, + (q31_t)0xd281c85, (q31_t)0x80ad8ed9, + (q31_t)0xd21dc87, (q31_t)0x80ace9ab, (q31_t)0xd1b9c81, (q31_t)0x80ac44cc, (q31_t)0xd155c73, (q31_t)0x80aba03b, + (q31_t)0xd0f1c5d, (q31_t)0x80aafbf9, + (q31_t)0xd08dc3f, (q31_t)0x80aa5806, (q31_t)0xd029c18, (q31_t)0x80a9b461, (q31_t)0xcfc5bea, (q31_t)0x80a9110b, + (q31_t)0xcf61bb4, (q31_t)0x80a86e03, + (q31_t)0xcefdb76, (q31_t)0x80a7cb49, (q31_t)0xce99b2f, (q31_t)0x80a728df, (q31_t)0xce35ae1, (q31_t)0x80a686c2, + (q31_t)0xcdd1a8b, (q31_t)0x80a5e4f5, + (q31_t)0xcd6da2d, (q31_t)0x80a54376, (q31_t)0xcd099c7, (q31_t)0x80a4a245, (q31_t)0xcca5959, (q31_t)0x80a40163, + (q31_t)0xcc418e3, (q31_t)0x80a360d0, + (q31_t)0xcbdd865, (q31_t)0x80a2c08b, (q31_t)0xcb797e0, (q31_t)0x80a22095, (q31_t)0xcb15752, (q31_t)0x80a180ed, + (q31_t)0xcab16bd, (q31_t)0x80a0e194, + (q31_t)0xca4d620, (q31_t)0x80a04289, (q31_t)0xc9e957b, (q31_t)0x809fa3cd, (q31_t)0xc9854cf, (q31_t)0x809f0560, + (q31_t)0xc92141a, (q31_t)0x809e6741, + (q31_t)0xc8bd35e, (q31_t)0x809dc971, (q31_t)0xc85929a, (q31_t)0x809d2bef, (q31_t)0xc7f51cf, (q31_t)0x809c8ebc, + (q31_t)0xc7910fb, (q31_t)0x809bf1d7, + (q31_t)0xc72d020, (q31_t)0x809b5541, (q31_t)0xc6c8f3e, (q31_t)0x809ab8fa, (q31_t)0xc664e53, (q31_t)0x809a1d01, + (q31_t)0xc600d61, (q31_t)0x80998157, + (q31_t)0xc59cc68, (q31_t)0x8098e5fb, (q31_t)0xc538b66, (q31_t)0x80984aee, (q31_t)0xc4d4a5d, (q31_t)0x8097b030, + (q31_t)0xc47094d, (q31_t)0x809715c0, + (q31_t)0xc40c835, (q31_t)0x80967b9f, (q31_t)0xc3a8715, (q31_t)0x8095e1cc, (q31_t)0xc3445ee, (q31_t)0x80954848, + (q31_t)0xc2e04c0, (q31_t)0x8094af13, + (q31_t)0xc27c389, (q31_t)0x8094162c, (q31_t)0xc21824c, (q31_t)0x80937d93, (q31_t)0xc1b4107, (q31_t)0x8092e54a, + (q31_t)0xc14ffba, (q31_t)0x80924d4f, + (q31_t)0xc0ebe66, (q31_t)0x8091b5a2, (q31_t)0xc087d0a, (q31_t)0x80911e44, (q31_t)0xc023ba7, (q31_t)0x80908735, + (q31_t)0xbfbfa3d, (q31_t)0x808ff074, + (q31_t)0xbf5b8cb, (q31_t)0x808f5a02, (q31_t)0xbef7752, (q31_t)0x808ec3df, (q31_t)0xbe935d2, (q31_t)0x808e2e0a, + (q31_t)0xbe2f44a, (q31_t)0x808d9884, + (q31_t)0xbdcb2bb, (q31_t)0x808d034c, (q31_t)0xbd67124, (q31_t)0x808c6e63, (q31_t)0xbd02f87, (q31_t)0x808bd9c9, + (q31_t)0xbc9ede2, (q31_t)0x808b457d, + (q31_t)0xbc3ac35, (q31_t)0x808ab180, (q31_t)0xbbd6a82, (q31_t)0x808a1dd2, (q31_t)0xbb728c7, (q31_t)0x80898a72, + (q31_t)0xbb0e705, (q31_t)0x8088f761, + (q31_t)0xbaaa53b, (q31_t)0x8088649e, (q31_t)0xba4636b, (q31_t)0x8087d22a, (q31_t)0xb9e2193, (q31_t)0x80874005, + (q31_t)0xb97dfb5, (q31_t)0x8086ae2e, + (q31_t)0xb919dcf, (q31_t)0x80861ca6, (q31_t)0xb8b5be1, (q31_t)0x80858b6c, (q31_t)0xb8519ed, (q31_t)0x8084fa82, + (q31_t)0xb7ed7f2, (q31_t)0x808469e5, + (q31_t)0xb7895f0, (q31_t)0x8083d998, (q31_t)0xb7253e6, (q31_t)0x80834999, (q31_t)0xb6c11d5, (q31_t)0x8082b9e9, + (q31_t)0xb65cfbe, (q31_t)0x80822a87, + (q31_t)0xb5f8d9f, (q31_t)0x80819b74, (q31_t)0xb594b7a, (q31_t)0x80810cb0, (q31_t)0xb53094d, (q31_t)0x80807e3a, + (q31_t)0xb4cc719, (q31_t)0x807ff013, + (q31_t)0xb4684df, (q31_t)0x807f623b, (q31_t)0xb40429d, (q31_t)0x807ed4b1, (q31_t)0xb3a0055, (q31_t)0x807e4776, + (q31_t)0xb33be05, (q31_t)0x807dba89, + (q31_t)0xb2d7baf, (q31_t)0x807d2dec, (q31_t)0xb273952, (q31_t)0x807ca19c, (q31_t)0xb20f6ee, (q31_t)0x807c159c, + (q31_t)0xb1ab483, (q31_t)0x807b89ea, + (q31_t)0xb147211, (q31_t)0x807afe87, (q31_t)0xb0e2f98, (q31_t)0x807a7373, (q31_t)0xb07ed19, (q31_t)0x8079e8ad, + (q31_t)0xb01aa92, (q31_t)0x80795e36, + (q31_t)0xafb6805, (q31_t)0x8078d40d, (q31_t)0xaf52571, (q31_t)0x80784a33, (q31_t)0xaeee2d7, (q31_t)0x8077c0a8, + (q31_t)0xae8a036, (q31_t)0x8077376c, + (q31_t)0xae25d8d, (q31_t)0x8076ae7e, (q31_t)0xadc1adf, (q31_t)0x807625df, (q31_t)0xad5d829, (q31_t)0x80759d8e, + (q31_t)0xacf956d, (q31_t)0x8075158c, + (q31_t)0xac952aa, (q31_t)0x80748dd9, (q31_t)0xac30fe1, (q31_t)0x80740675, (q31_t)0xabccd11, (q31_t)0x80737f5f, + (q31_t)0xab68a3a, (q31_t)0x8072f898, + (q31_t)0xab0475c, (q31_t)0x8072721f, (q31_t)0xaaa0478, (q31_t)0x8071ebf6, (q31_t)0xaa3c18e, (q31_t)0x8071661a, + (q31_t)0xa9d7e9d, (q31_t)0x8070e08e, + (q31_t)0xa973ba5, (q31_t)0x80705b50, (q31_t)0xa90f8a7, (q31_t)0x806fd661, (q31_t)0xa8ab5a2, (q31_t)0x806f51c1, + (q31_t)0xa847297, (q31_t)0x806ecd6f, + (q31_t)0xa7e2f85, (q31_t)0x806e496c, (q31_t)0xa77ec6d, (q31_t)0x806dc5b8, (q31_t)0xa71a94f, (q31_t)0x806d4253, + (q31_t)0xa6b662a, (q31_t)0x806cbf3c, + (q31_t)0xa6522fe, (q31_t)0x806c3c74, (q31_t)0xa5edfcc, (q31_t)0x806bb9fa, (q31_t)0xa589c94, (q31_t)0x806b37cf, + (q31_t)0xa525955, (q31_t)0x806ab5f3, + (q31_t)0xa4c1610, (q31_t)0x806a3466, (q31_t)0xa45d2c5, (q31_t)0x8069b327, (q31_t)0xa3f8f73, (q31_t)0x80693237, + (q31_t)0xa394c1b, (q31_t)0x8068b196, + (q31_t)0xa3308bd, (q31_t)0x80683143, (q31_t)0xa2cc558, (q31_t)0x8067b13f, (q31_t)0xa2681ed, (q31_t)0x8067318a, + (q31_t)0xa203e7c, (q31_t)0x8066b224, + (q31_t)0xa19fb04, (q31_t)0x8066330c, (q31_t)0xa13b787, (q31_t)0x8065b443, (q31_t)0xa0d7403, (q31_t)0x806535c9, + (q31_t)0xa073079, (q31_t)0x8064b79d, + (q31_t)0xa00ece8, (q31_t)0x806439c0, (q31_t)0x9faa952, (q31_t)0x8063bc32, (q31_t)0x9f465b5, (q31_t)0x80633ef3, + (q31_t)0x9ee2213, (q31_t)0x8062c202, + (q31_t)0x9e7de6a, (q31_t)0x80624560, (q31_t)0x9e19abb, (q31_t)0x8061c90c, (q31_t)0x9db5706, (q31_t)0x80614d08, + (q31_t)0x9d5134b, (q31_t)0x8060d152, + (q31_t)0x9cecf89, (q31_t)0x806055eb, (q31_t)0x9c88bc2, (q31_t)0x805fdad2, (q31_t)0x9c247f5, (q31_t)0x805f6009, + (q31_t)0x9bc0421, (q31_t)0x805ee58e, + (q31_t)0x9b5c048, (q31_t)0x805e6b62, (q31_t)0x9af7c69, (q31_t)0x805df184, (q31_t)0x9a93884, (q31_t)0x805d77f5, + (q31_t)0x9a2f498, (q31_t)0x805cfeb5, + (q31_t)0x99cb0a7, (q31_t)0x805c85c4, (q31_t)0x9966cb0, (q31_t)0x805c0d21, (q31_t)0x99028b3, (q31_t)0x805b94ce, + (q31_t)0x989e4b0, (q31_t)0x805b1cc8, + (q31_t)0x983a0a7, (q31_t)0x805aa512, (q31_t)0x97d5c99, (q31_t)0x805a2daa, (q31_t)0x9771884, (q31_t)0x8059b692, + (q31_t)0x970d46a, (q31_t)0x80593fc7, + (q31_t)0x96a9049, (q31_t)0x8058c94c, (q31_t)0x9644c23, (q31_t)0x8058531f, (q31_t)0x95e07f8, (q31_t)0x8057dd41, + (q31_t)0x957c3c6, (q31_t)0x805767b2, + (q31_t)0x9517f8f, (q31_t)0x8056f272, (q31_t)0x94b3b52, (q31_t)0x80567d80, (q31_t)0x944f70f, (q31_t)0x805608dd, + (q31_t)0x93eb2c6, (q31_t)0x80559489, + (q31_t)0x9386e78, (q31_t)0x80552084, (q31_t)0x9322a24, (q31_t)0x8054accd, (q31_t)0x92be5ca, (q31_t)0x80543965, + (q31_t)0x925a16b, (q31_t)0x8053c64c, + (q31_t)0x91f5d06, (q31_t)0x80535381, (q31_t)0x919189c, (q31_t)0x8052e106, (q31_t)0x912d42c, (q31_t)0x80526ed9, + (q31_t)0x90c8fb6, (q31_t)0x8051fcfb, + (q31_t)0x9064b3a, (q31_t)0x80518b6b, (q31_t)0x90006ba, (q31_t)0x80511a2b, (q31_t)0x8f9c233, (q31_t)0x8050a939, + (q31_t)0x8f37da7, (q31_t)0x80503896, + (q31_t)0x8ed3916, (q31_t)0x804fc841, (q31_t)0x8e6f47f, (q31_t)0x804f583c, (q31_t)0x8e0afe2, (q31_t)0x804ee885, + (q31_t)0x8da6b40, (q31_t)0x804e791d, + (q31_t)0x8d42699, (q31_t)0x804e0a04, (q31_t)0x8cde1ec, (q31_t)0x804d9b39, (q31_t)0x8c79d3a, (q31_t)0x804d2cbd, + (q31_t)0x8c15882, (q31_t)0x804cbe90, + (q31_t)0x8bb13c5, (q31_t)0x804c50b2, (q31_t)0x8b4cf02, (q31_t)0x804be323, (q31_t)0x8ae8a3a, (q31_t)0x804b75e2, + (q31_t)0x8a8456d, (q31_t)0x804b08f0, + (q31_t)0x8a2009a, (q31_t)0x804a9c4d, (q31_t)0x89bbbc3, (q31_t)0x804a2ff9, (q31_t)0x89576e5, (q31_t)0x8049c3f3, + (q31_t)0x88f3203, (q31_t)0x8049583d, + (q31_t)0x888ed1b, (q31_t)0x8048ecd5, (q31_t)0x882a82e, (q31_t)0x804881bb, (q31_t)0x87c633c, (q31_t)0x804816f1, + (q31_t)0x8761e44, (q31_t)0x8047ac75, + (q31_t)0x86fd947, (q31_t)0x80474248, (q31_t)0x8699445, (q31_t)0x8046d86a, (q31_t)0x8634f3e, (q31_t)0x80466edb, + (q31_t)0x85d0a32, (q31_t)0x8046059b, + (q31_t)0x856c520, (q31_t)0x80459ca9, (q31_t)0x850800a, (q31_t)0x80453406, (q31_t)0x84a3aee, (q31_t)0x8044cbb2, + (q31_t)0x843f5cd, (q31_t)0x804463ad, + (q31_t)0x83db0a7, (q31_t)0x8043fbf6, (q31_t)0x8376b7c, (q31_t)0x8043948e, (q31_t)0x831264c, (q31_t)0x80432d75, + (q31_t)0x82ae117, (q31_t)0x8042c6ab, + (q31_t)0x8249bdd, (q31_t)0x80426030, (q31_t)0x81e569d, (q31_t)0x8041fa03, (q31_t)0x8181159, (q31_t)0x80419425, + (q31_t)0x811cc10, (q31_t)0x80412e96, + (q31_t)0x80b86c2, (q31_t)0x8040c956, (q31_t)0x805416e, (q31_t)0x80406465, (q31_t)0x7fefc16, (q31_t)0x803fffc2, + (q31_t)0x7f8b6b9, (q31_t)0x803f9b6f, + (q31_t)0x7f27157, (q31_t)0x803f376a, (q31_t)0x7ec2bf0, (q31_t)0x803ed3b3, (q31_t)0x7e5e685, (q31_t)0x803e704c, + (q31_t)0x7dfa114, (q31_t)0x803e0d34, + (q31_t)0x7d95b9e, (q31_t)0x803daa6a, (q31_t)0x7d31624, (q31_t)0x803d47ef, (q31_t)0x7ccd0a5, (q31_t)0x803ce5c3, + (q31_t)0x7c68b21, (q31_t)0x803c83e5, + (q31_t)0x7c04598, (q31_t)0x803c2257, (q31_t)0x7ba000b, (q31_t)0x803bc117, (q31_t)0x7b3ba78, (q31_t)0x803b6026, + (q31_t)0x7ad74e1, (q31_t)0x803aff84, + (q31_t)0x7a72f45, (q31_t)0x803a9f31, (q31_t)0x7a0e9a5, (q31_t)0x803a3f2d, (q31_t)0x79aa400, (q31_t)0x8039df77, + (q31_t)0x7945e56, (q31_t)0x80398010, + (q31_t)0x78e18a7, (q31_t)0x803920f8, (q31_t)0x787d2f4, (q31_t)0x8038c22f, (q31_t)0x7818d3c, (q31_t)0x803863b5, + (q31_t)0x77b4780, (q31_t)0x80380589, + (q31_t)0x77501be, (q31_t)0x8037a7ac, (q31_t)0x76ebbf9, (q31_t)0x80374a1f, (q31_t)0x768762e, (q31_t)0x8036ece0, + (q31_t)0x762305f, (q31_t)0x80368fef, + (q31_t)0x75bea8c, (q31_t)0x8036334e, (q31_t)0x755a4b4, (q31_t)0x8035d6fb, (q31_t)0x74f5ed7, (q31_t)0x80357af8, + (q31_t)0x74918f6, (q31_t)0x80351f43, + (q31_t)0x742d311, (q31_t)0x8034c3dd, (q31_t)0x73c8d27, (q31_t)0x803468c5, (q31_t)0x7364738, (q31_t)0x80340dfd, + (q31_t)0x7300145, (q31_t)0x8033b383, + (q31_t)0x729bb4e, (q31_t)0x80335959, (q31_t)0x7237552, (q31_t)0x8032ff7d, (q31_t)0x71d2f52, (q31_t)0x8032a5ef, + (q31_t)0x716e94e, (q31_t)0x80324cb1, + (q31_t)0x710a345, (q31_t)0x8031f3c2, (q31_t)0x70a5d37, (q31_t)0x80319b21, (q31_t)0x7041726, (q31_t)0x803142cf, + (q31_t)0x6fdd110, (q31_t)0x8030eacd, + (q31_t)0x6f78af6, (q31_t)0x80309318, (q31_t)0x6f144d7, (q31_t)0x80303bb3, (q31_t)0x6eafeb4, (q31_t)0x802fe49d, + (q31_t)0x6e4b88d, (q31_t)0x802f8dd5, + (q31_t)0x6de7262, (q31_t)0x802f375d, (q31_t)0x6d82c32, (q31_t)0x802ee133, (q31_t)0x6d1e5fe, (q31_t)0x802e8b58, + (q31_t)0x6cb9fc6, (q31_t)0x802e35cb, + (q31_t)0x6c5598a, (q31_t)0x802de08e, (q31_t)0x6bf1349, (q31_t)0x802d8ba0, (q31_t)0x6b8cd05, (q31_t)0x802d3700, + (q31_t)0x6b286bc, (q31_t)0x802ce2af, + (q31_t)0x6ac406f, (q31_t)0x802c8ead, (q31_t)0x6a5fa1e, (q31_t)0x802c3afa, (q31_t)0x69fb3c9, (q31_t)0x802be796, + (q31_t)0x6996d70, (q31_t)0x802b9480, + (q31_t)0x6932713, (q31_t)0x802b41ba, (q31_t)0x68ce0b2, (q31_t)0x802aef42, (q31_t)0x6869a4c, (q31_t)0x802a9d19, + (q31_t)0x68053e3, (q31_t)0x802a4b3f, + (q31_t)0x67a0d76, (q31_t)0x8029f9b4, (q31_t)0x673c704, (q31_t)0x8029a878, (q31_t)0x66d808f, (q31_t)0x8029578b, + (q31_t)0x6673a16, (q31_t)0x802906ec, + (q31_t)0x660f398, (q31_t)0x8028b69c, (q31_t)0x65aad17, (q31_t)0x8028669b, (q31_t)0x6546692, (q31_t)0x802816e9, + (q31_t)0x64e2009, (q31_t)0x8027c786, + (q31_t)0x647d97c, (q31_t)0x80277872, (q31_t)0x64192eb, (q31_t)0x802729ad, (q31_t)0x63b4c57, (q31_t)0x8026db36, + (q31_t)0x63505be, (q31_t)0x80268d0e, + (q31_t)0x62ebf22, (q31_t)0x80263f36, (q31_t)0x6287882, (q31_t)0x8025f1ac, (q31_t)0x62231de, (q31_t)0x8025a471, + (q31_t)0x61beb36, (q31_t)0x80255784, + (q31_t)0x615a48b, (q31_t)0x80250ae7, (q31_t)0x60f5ddc, (q31_t)0x8024be99, (q31_t)0x6091729, (q31_t)0x80247299, + (q31_t)0x602d072, (q31_t)0x802426e8, + (q31_t)0x5fc89b8, (q31_t)0x8023db86, (q31_t)0x5f642fa, (q31_t)0x80239073, (q31_t)0x5effc38, (q31_t)0x802345af, + (q31_t)0x5e9b572, (q31_t)0x8022fb3a, + (q31_t)0x5e36ea9, (q31_t)0x8022b114, (q31_t)0x5dd27dd, (q31_t)0x8022673c, (q31_t)0x5d6e10c, (q31_t)0x80221db3, + (q31_t)0x5d09a38, (q31_t)0x8021d47a, + (q31_t)0x5ca5361, (q31_t)0x80218b8f, (q31_t)0x5c40c86, (q31_t)0x802142f3, (q31_t)0x5bdc5a7, (q31_t)0x8020faa6, + (q31_t)0x5b77ec5, (q31_t)0x8020b2a7, + (q31_t)0x5b137df, (q31_t)0x80206af8, (q31_t)0x5aaf0f6, (q31_t)0x80202397, (q31_t)0x5a4aa09, (q31_t)0x801fdc86, + (q31_t)0x59e6319, (q31_t)0x801f95c3, + (q31_t)0x5981c26, (q31_t)0x801f4f4f, (q31_t)0x591d52f, (q31_t)0x801f092a, (q31_t)0x58b8e34, (q31_t)0x801ec354, + (q31_t)0x5854736, (q31_t)0x801e7dcd, + (q31_t)0x57f0035, (q31_t)0x801e3895, (q31_t)0x578b930, (q31_t)0x801df3ab, (q31_t)0x5727228, (q31_t)0x801daf11, + (q31_t)0x56c2b1c, (q31_t)0x801d6ac5, + (q31_t)0x565e40d, (q31_t)0x801d26c8, (q31_t)0x55f9cfb, (q31_t)0x801ce31a, (q31_t)0x55955e6, (q31_t)0x801c9fbb, + (q31_t)0x5530ecd, (q31_t)0x801c5cab, + (q31_t)0x54cc7b1, (q31_t)0x801c19ea, (q31_t)0x5468092, (q31_t)0x801bd777, (q31_t)0x540396f, (q31_t)0x801b9554, + (q31_t)0x539f249, (q31_t)0x801b537f, + (q31_t)0x533ab20, (q31_t)0x801b11fa, (q31_t)0x52d63f4, (q31_t)0x801ad0c3, (q31_t)0x5271cc4, (q31_t)0x801a8fdb, + (q31_t)0x520d592, (q31_t)0x801a4f42, + (q31_t)0x51a8e5c, (q31_t)0x801a0ef8, (q31_t)0x5144723, (q31_t)0x8019cefd, (q31_t)0x50dffe7, (q31_t)0x80198f50, + (q31_t)0x507b8a8, (q31_t)0x80194ff3, + (q31_t)0x5017165, (q31_t)0x801910e4, (q31_t)0x4fb2a20, (q31_t)0x8018d225, (q31_t)0x4f4e2d8, (q31_t)0x801893b4, + (q31_t)0x4ee9b8c, (q31_t)0x80185592, + (q31_t)0x4e8543e, (q31_t)0x801817bf, (q31_t)0x4e20cec, (q31_t)0x8017da3b, (q31_t)0x4dbc597, (q31_t)0x80179d06, + (q31_t)0x4d57e40, (q31_t)0x80176020, + (q31_t)0x4cf36e5, (q31_t)0x80172388, (q31_t)0x4c8ef88, (q31_t)0x8016e740, (q31_t)0x4c2a827, (q31_t)0x8016ab46, + (q31_t)0x4bc60c4, (q31_t)0x80166f9c, + (q31_t)0x4b6195d, (q31_t)0x80163440, (q31_t)0x4afd1f4, (q31_t)0x8015f933, (q31_t)0x4a98a88, (q31_t)0x8015be75, + (q31_t)0x4a34319, (q31_t)0x80158406, + (q31_t)0x49cfba7, (q31_t)0x801549e6, (q31_t)0x496b432, (q31_t)0x80151015, (q31_t)0x4906cbb, (q31_t)0x8014d693, + (q31_t)0x48a2540, (q31_t)0x80149d5f, + (q31_t)0x483ddc3, (q31_t)0x8014647b, (q31_t)0x47d9643, (q31_t)0x80142be5, (q31_t)0x4774ec1, (q31_t)0x8013f39e, + (q31_t)0x471073b, (q31_t)0x8013bba7, + (q31_t)0x46abfb3, (q31_t)0x801383fe, (q31_t)0x4647828, (q31_t)0x80134ca4, (q31_t)0x45e309a, (q31_t)0x80131599, + (q31_t)0x457e90a, (q31_t)0x8012dedd, + (q31_t)0x451a177, (q31_t)0x8012a86f, (q31_t)0x44b59e1, (q31_t)0x80127251, (q31_t)0x4451249, (q31_t)0x80123c82, + (q31_t)0x43ecaae, (q31_t)0x80120701, + (q31_t)0x4388310, (q31_t)0x8011d1d0, (q31_t)0x4323b70, (q31_t)0x80119ced, (q31_t)0x42bf3cd, (q31_t)0x80116859, + (q31_t)0x425ac28, (q31_t)0x80113414, + (q31_t)0x41f6480, (q31_t)0x8011001f, (q31_t)0x4191cd5, (q31_t)0x8010cc78, (q31_t)0x412d528, (q31_t)0x8010991f, + (q31_t)0x40c8d79, (q31_t)0x80106616, + (q31_t)0x40645c7, (q31_t)0x8010335c, (q31_t)0x3fffe12, (q31_t)0x801000f1, (q31_t)0x3f9b65b, (q31_t)0x800fced4, + (q31_t)0x3f36ea2, (q31_t)0x800f9d07, + (q31_t)0x3ed26e6, (q31_t)0x800f6b88, (q31_t)0x3e6df28, (q31_t)0x800f3a59, (q31_t)0x3e09767, (q31_t)0x800f0978, + (q31_t)0x3da4fa4, (q31_t)0x800ed8e6, + (q31_t)0x3d407df, (q31_t)0x800ea8a3, (q31_t)0x3cdc017, (q31_t)0x800e78af, (q31_t)0x3c7784d, (q31_t)0x800e490a, + (q31_t)0x3c13080, (q31_t)0x800e19b4, + (q31_t)0x3bae8b2, (q31_t)0x800deaad, (q31_t)0x3b4a0e0, (q31_t)0x800dbbf5, (q31_t)0x3ae590d, (q31_t)0x800d8d8b, + (q31_t)0x3a81137, (q31_t)0x800d5f71, + (q31_t)0x3a1c960, (q31_t)0x800d31a5, (q31_t)0x39b8185, (q31_t)0x800d0429, (q31_t)0x39539a9, (q31_t)0x800cd6fb, + (q31_t)0x38ef1ca, (q31_t)0x800caa1c, + (q31_t)0x388a9ea, (q31_t)0x800c7d8c, (q31_t)0x3826207, (q31_t)0x800c514c, (q31_t)0x37c1a22, (q31_t)0x800c255a, + (q31_t)0x375d23a, (q31_t)0x800bf9b7, + (q31_t)0x36f8a51, (q31_t)0x800bce63, (q31_t)0x3694265, (q31_t)0x800ba35d, (q31_t)0x362fa78, (q31_t)0x800b78a7, + (q31_t)0x35cb288, (q31_t)0x800b4e40, + (q31_t)0x3566a96, (q31_t)0x800b2427, (q31_t)0x35022a2, (q31_t)0x800afa5e, (q31_t)0x349daac, (q31_t)0x800ad0e3, + (q31_t)0x34392b4, (q31_t)0x800aa7b8, + (q31_t)0x33d4abb, (q31_t)0x800a7edb, (q31_t)0x33702bf, (q31_t)0x800a564e, (q31_t)0x330bac1, (q31_t)0x800a2e0f, + (q31_t)0x32a72c1, (q31_t)0x800a061f, + (q31_t)0x3242abf, (q31_t)0x8009de7e, (q31_t)0x31de2bb, (q31_t)0x8009b72c, (q31_t)0x3179ab5, (q31_t)0x80099029, + (q31_t)0x31152ae, (q31_t)0x80096975, + (q31_t)0x30b0aa4, (q31_t)0x80094310, (q31_t)0x304c299, (q31_t)0x80091cf9, (q31_t)0x2fe7a8c, (q31_t)0x8008f732, + (q31_t)0x2f8327d, (q31_t)0x8008d1ba, + (q31_t)0x2f1ea6c, (q31_t)0x8008ac90, (q31_t)0x2eba259, (q31_t)0x800887b6, (q31_t)0x2e55a44, (q31_t)0x8008632a, + (q31_t)0x2df122e, (q31_t)0x80083eed, + (q31_t)0x2d8ca16, (q31_t)0x80081b00, (q31_t)0x2d281fc, (q31_t)0x8007f761, (q31_t)0x2cc39e1, (q31_t)0x8007d411, + (q31_t)0x2c5f1c3, (q31_t)0x8007b110, + (q31_t)0x2bfa9a4, (q31_t)0x80078e5e, (q31_t)0x2b96184, (q31_t)0x80076bfb, (q31_t)0x2b31961, (q31_t)0x800749e7, + (q31_t)0x2acd13d, (q31_t)0x80072822, + (q31_t)0x2a68917, (q31_t)0x800706ac, (q31_t)0x2a040f0, (q31_t)0x8006e585, (q31_t)0x299f8c7, (q31_t)0x8006c4ac, + (q31_t)0x293b09c, (q31_t)0x8006a423, + (q31_t)0x28d6870, (q31_t)0x800683e8, (q31_t)0x2872043, (q31_t)0x800663fd, (q31_t)0x280d813, (q31_t)0x80064460, + (q31_t)0x27a8fe2, (q31_t)0x80062513, + (q31_t)0x27447b0, (q31_t)0x80060614, (q31_t)0x26dff7c, (q31_t)0x8005e764, (q31_t)0x267b747, (q31_t)0x8005c904, + (q31_t)0x2616f10, (q31_t)0x8005aaf2, + (q31_t)0x25b26d7, (q31_t)0x80058d2f, (q31_t)0x254de9e, (q31_t)0x80056fbb, (q31_t)0x24e9662, (q31_t)0x80055296, + (q31_t)0x2484e26, (q31_t)0x800535c0, + (q31_t)0x24205e8, (q31_t)0x80051939, (q31_t)0x23bbda8, (q31_t)0x8004fd00, (q31_t)0x2357567, (q31_t)0x8004e117, + (q31_t)0x22f2d25, (q31_t)0x8004c57d, + (q31_t)0x228e4e2, (q31_t)0x8004aa32, (q31_t)0x2229c9d, (q31_t)0x80048f35, (q31_t)0x21c5457, (q31_t)0x80047488, + (q31_t)0x2160c0f, (q31_t)0x80045a29, + (q31_t)0x20fc3c6, (q31_t)0x8004401a, (q31_t)0x2097b7c, (q31_t)0x80042659, (q31_t)0x2033331, (q31_t)0x80040ce7, + (q31_t)0x1fceae4, (q31_t)0x8003f3c5, + (q31_t)0x1f6a297, (q31_t)0x8003daf1, (q31_t)0x1f05a48, (q31_t)0x8003c26c, (q31_t)0x1ea11f7, (q31_t)0x8003aa36, + (q31_t)0x1e3c9a6, (q31_t)0x8003924f, + (q31_t)0x1dd8154, (q31_t)0x80037ab7, (q31_t)0x1d73900, (q31_t)0x8003636e, (q31_t)0x1d0f0ab, (q31_t)0x80034c74, + (q31_t)0x1caa855, (q31_t)0x800335c9, + (q31_t)0x1c45ffe, (q31_t)0x80031f6d, (q31_t)0x1be17a6, (q31_t)0x80030960, (q31_t)0x1b7cf4d, (q31_t)0x8002f3a1, + (q31_t)0x1b186f3, (q31_t)0x8002de32, + (q31_t)0x1ab3e97, (q31_t)0x8002c912, (q31_t)0x1a4f63b, (q31_t)0x8002b440, (q31_t)0x19eaddd, (q31_t)0x80029fbe, + (q31_t)0x198657f, (q31_t)0x80028b8a, + (q31_t)0x1921d20, (q31_t)0x800277a6, (q31_t)0x18bd4bf, (q31_t)0x80026410, (q31_t)0x1858c5e, (q31_t)0x800250c9, + (q31_t)0x17f43fc, (q31_t)0x80023dd2, + (q31_t)0x178fb99, (q31_t)0x80022b29, (q31_t)0x172b335, (q31_t)0x800218cf, (q31_t)0x16c6ad0, (q31_t)0x800206c4, + (q31_t)0x166226a, (q31_t)0x8001f508, + (q31_t)0x15fda03, (q31_t)0x8001e39b, (q31_t)0x159919c, (q31_t)0x8001d27d, (q31_t)0x1534934, (q31_t)0x8001c1ae, + (q31_t)0x14d00ca, (q31_t)0x8001b12e, + (q31_t)0x146b860, (q31_t)0x8001a0fd, (q31_t)0x1406ff6, (q31_t)0x8001911b, (q31_t)0x13a278a, (q31_t)0x80018187, + (q31_t)0x133df1e, (q31_t)0x80017243, + (q31_t)0x12d96b1, (q31_t)0x8001634e, (q31_t)0x1274e43, (q31_t)0x800154a7, (q31_t)0x12105d5, (q31_t)0x80014650, + (q31_t)0x11abd66, (q31_t)0x80013847, + (q31_t)0x11474f6, (q31_t)0x80012a8e, (q31_t)0x10e2c85, (q31_t)0x80011d23, (q31_t)0x107e414, (q31_t)0x80011008, + (q31_t)0x1019ba2, (q31_t)0x8001033b, + (q31_t)0xfb5330, (q31_t)0x8000f6bd, (q31_t)0xf50abd, (q31_t)0x8000ea8e, (q31_t)0xeec249, (q31_t)0x8000deaf, (q31_t)0xe879d5, + (q31_t)0x8000d31e, + (q31_t)0xe23160, (q31_t)0x8000c7dc, (q31_t)0xdbe8eb, (q31_t)0x8000bce9, (q31_t)0xd5a075, (q31_t)0x8000b245, (q31_t)0xcf57ff, + (q31_t)0x8000a7f0, + (q31_t)0xc90f88, (q31_t)0x80009dea, (q31_t)0xc2c711, (q31_t)0x80009433, (q31_t)0xbc7e99, (q31_t)0x80008aca, (q31_t)0xb63621, + (q31_t)0x800081b1, + (q31_t)0xafeda8, (q31_t)0x800078e7, (q31_t)0xa9a52f, (q31_t)0x8000706c, (q31_t)0xa35cb5, (q31_t)0x8000683f, (q31_t)0x9d143b, + (q31_t)0x80006062, + (q31_t)0x96cbc1, (q31_t)0x800058d4, (q31_t)0x908346, (q31_t)0x80005194, (q31_t)0x8a3acb, (q31_t)0x80004aa4, (q31_t)0x83f250, + (q31_t)0x80004402, + (q31_t)0x7da9d4, (q31_t)0x80003daf, (q31_t)0x776159, (q31_t)0x800037ac, (q31_t)0x7118dc, (q31_t)0x800031f7, (q31_t)0x6ad060, + (q31_t)0x80002c91, + (q31_t)0x6487e3, (q31_t)0x8000277a, (q31_t)0x5e3f66, (q31_t)0x800022b3, (q31_t)0x57f6e9, (q31_t)0x80001e3a, (q31_t)0x51ae6b, + (q31_t)0x80001a10, + (q31_t)0x4b65ee, (q31_t)0x80001635, (q31_t)0x451d70, (q31_t)0x800012a9, (q31_t)0x3ed4f2, (q31_t)0x80000f6c, (q31_t)0x388c74, + (q31_t)0x80000c7e, + (q31_t)0x3243f5, (q31_t)0x800009df, (q31_t)0x2bfb77, (q31_t)0x8000078e, (q31_t)0x25b2f8, (q31_t)0x8000058d, (q31_t)0x1f6a7a, + (q31_t)0x800003db, + (q31_t)0x1921fb, (q31_t)0x80000278, (q31_t)0x12d97c, (q31_t)0x80000163, (q31_t)0xc90fe, (q31_t)0x8000009e, (q31_t)0x6487f, + (q31_t)0x80000027 + +}; + +/** +* \par +* cosFactor tables are generated using the formula :
cos_factors[n] = 2 * cos((2n+1)*pi/(4*N))
+* \par +* C command to generate the table +*
+* for(i = 0; i< N; i++)
+* {
+*   cos_factors[i]= 2 * cos((2*i+1)*c/2);
+* } 
+* \par +* where N is the number of factors to generate and c is pi/(2*N) +* \par +* Then converted to q31 format by multiplying with 2^31 and saturated if required. +*/ + + +static const q31_t cos_factorsQ31_128[128] = { + (q31_t)0x7fff6216, (q31_t)0x7ffa72d1, (q31_t)0x7ff09478, (q31_t)0x7fe1c76b, (q31_t)0x7fce0c3e, (q31_t)0x7fb563b3, + (q31_t)0x7f97cebd, (q31_t)0x7f754e80, + (q31_t)0x7f4de451, (q31_t)0x7f2191b4, (q31_t)0x7ef05860, (q31_t)0x7eba3a39, (q31_t)0x7e7f3957, (q31_t)0x7e3f57ff, + (q31_t)0x7dfa98a8, (q31_t)0x7db0fdf8, + (q31_t)0x7d628ac6, (q31_t)0x7d0f4218, (q31_t)0x7cb72724, (q31_t)0x7c5a3d50, (q31_t)0x7bf88830, (q31_t)0x7b920b89, + (q31_t)0x7b26cb4f, (q31_t)0x7ab6cba4, + (q31_t)0x7a4210d8, (q31_t)0x79c89f6e, (q31_t)0x794a7c12, (q31_t)0x78c7aba2, (q31_t)0x78403329, (q31_t)0x77b417df, + (q31_t)0x77235f2d, (q31_t)0x768e0ea6, + (q31_t)0x75f42c0b, (q31_t)0x7555bd4c, (q31_t)0x74b2c884, (q31_t)0x740b53fb, (q31_t)0x735f6626, (q31_t)0x72af05a7, + (q31_t)0x71fa3949, (q31_t)0x71410805, + (q31_t)0x708378ff, (q31_t)0x6fc19385, (q31_t)0x6efb5f12, (q31_t)0x6e30e34a, (q31_t)0x6d6227fa, (q31_t)0x6c8f351c, + (q31_t)0x6bb812d1, (q31_t)0x6adcc964, + (q31_t)0x69fd614a, (q31_t)0x6919e320, (q31_t)0x683257ab, (q31_t)0x6746c7d8, (q31_t)0x66573cbb, (q31_t)0x6563bf92, + (q31_t)0x646c59bf, (q31_t)0x637114cc, + (q31_t)0x6271fa69, (q31_t)0x616f146c, (q31_t)0x60686ccf, (q31_t)0x5f5e0db3, (q31_t)0x5e50015d, (q31_t)0x5d3e5237, + (q31_t)0x5c290acc, (q31_t)0x5b1035cf, + (q31_t)0x59f3de12, (q31_t)0x58d40e8c, (q31_t)0x57b0d256, (q31_t)0x568a34a9, (q31_t)0x556040e2, (q31_t)0x5433027d, + (q31_t)0x53028518, (q31_t)0x51ced46e, + (q31_t)0x5097fc5e, (q31_t)0x4f5e08e3, (q31_t)0x4e210617, (q31_t)0x4ce10034, (q31_t)0x4b9e0390, (q31_t)0x4a581c9e, + (q31_t)0x490f57ee, (q31_t)0x47c3c22f, + (q31_t)0x46756828, (q31_t)0x452456bd, (q31_t)0x43d09aed, (q31_t)0x427a41d0, (q31_t)0x4121589b, (q31_t)0x3fc5ec98, + (q31_t)0x3e680b2c, (q31_t)0x3d07c1d6, + (q31_t)0x3ba51e29, (q31_t)0x3a402dd2, (q31_t)0x38d8fe93, (q31_t)0x376f9e46, (q31_t)0x36041ad9, (q31_t)0x34968250, + (q31_t)0x3326e2c3, (q31_t)0x31b54a5e, + (q31_t)0x3041c761, (q31_t)0x2ecc681e, (q31_t)0x2d553afc, (q31_t)0x2bdc4e6f, (q31_t)0x2a61b101, (q31_t)0x28e5714b, + (q31_t)0x27679df4, (q31_t)0x25e845b6, + (q31_t)0x24677758, (q31_t)0x22e541af, (q31_t)0x2161b3a0, (q31_t)0x1fdcdc1b, (q31_t)0x1e56ca1e, (q31_t)0x1ccf8cb3, + (q31_t)0x1b4732ef, (q31_t)0x19bdcbf3, + (q31_t)0x183366e9, (q31_t)0x16a81305, (q31_t)0x151bdf86, (q31_t)0x138edbb1, (q31_t)0x120116d5, (q31_t)0x1072a048, + (q31_t)0xee38766, (q31_t)0xd53db92, + (q31_t)0xbc3ac35, (q31_t)0xa3308bd, (q31_t)0x8a2009a, (q31_t)0x710a345, (q31_t)0x57f0035, (q31_t)0x3ed26e6, (q31_t)0x25b26d7, + (q31_t)0xc90f88 +}; + +static const q31_t cos_factorsQ31_512[512] = { + (q31_t)0x7ffff621, (q31_t)0x7fffa72c, (q31_t)0x7fff0943, (q31_t)0x7ffe1c65, (q31_t)0x7ffce093, (q31_t)0x7ffb55ce, + (q31_t)0x7ff97c18, (q31_t)0x7ff75370, + (q31_t)0x7ff4dbd9, (q31_t)0x7ff21553, (q31_t)0x7feeffe1, (q31_t)0x7feb9b85, (q31_t)0x7fe7e841, (q31_t)0x7fe3e616, + (q31_t)0x7fdf9508, (q31_t)0x7fdaf519, + (q31_t)0x7fd6064c, (q31_t)0x7fd0c8a3, (q31_t)0x7fcb3c23, (q31_t)0x7fc560cf, (q31_t)0x7fbf36aa, (q31_t)0x7fb8bdb8, + (q31_t)0x7fb1f5fc, (q31_t)0x7faadf7c, + (q31_t)0x7fa37a3c, (q31_t)0x7f9bc640, (q31_t)0x7f93c38c, (q31_t)0x7f8b7227, (q31_t)0x7f82d214, (q31_t)0x7f79e35a, + (q31_t)0x7f70a5fe, (q31_t)0x7f671a05, + (q31_t)0x7f5d3f75, (q31_t)0x7f531655, (q31_t)0x7f489eaa, (q31_t)0x7f3dd87c, (q31_t)0x7f32c3d1, (q31_t)0x7f2760af, + (q31_t)0x7f1baf1e, (q31_t)0x7f0faf25, + (q31_t)0x7f0360cb, (q31_t)0x7ef6c418, (q31_t)0x7ee9d914, (q31_t)0x7edc9fc6, (q31_t)0x7ecf1837, (q31_t)0x7ec14270, + (q31_t)0x7eb31e78, (q31_t)0x7ea4ac58, + (q31_t)0x7e95ec1a, (q31_t)0x7e86ddc6, (q31_t)0x7e778166, (q31_t)0x7e67d703, (q31_t)0x7e57dea7, (q31_t)0x7e47985b, + (q31_t)0x7e37042a, (q31_t)0x7e26221f, + (q31_t)0x7e14f242, (q31_t)0x7e0374a0, (q31_t)0x7df1a942, (q31_t)0x7ddf9034, (q31_t)0x7dcd2981, (q31_t)0x7dba7534, + (q31_t)0x7da77359, (q31_t)0x7d9423fc, + (q31_t)0x7d808728, (q31_t)0x7d6c9ce9, (q31_t)0x7d58654d, (q31_t)0x7d43e05e, (q31_t)0x7d2f0e2b, (q31_t)0x7d19eebf, + (q31_t)0x7d048228, (q31_t)0x7ceec873, + (q31_t)0x7cd8c1ae, (q31_t)0x7cc26de5, (q31_t)0x7cabcd28, (q31_t)0x7c94df83, (q31_t)0x7c7da505, (q31_t)0x7c661dbc, + (q31_t)0x7c4e49b7, (q31_t)0x7c362904, + (q31_t)0x7c1dbbb3, (q31_t)0x7c0501d2, (q31_t)0x7bebfb70, (q31_t)0x7bd2a89e, (q31_t)0x7bb9096b, (q31_t)0x7b9f1de6, + (q31_t)0x7b84e61f, (q31_t)0x7b6a6227, + (q31_t)0x7b4f920e, (q31_t)0x7b3475e5, (q31_t)0x7b190dbc, (q31_t)0x7afd59a4, (q31_t)0x7ae159ae, (q31_t)0x7ac50dec, + (q31_t)0x7aa8766f, (q31_t)0x7a8b9348, + (q31_t)0x7a6e648a, (q31_t)0x7a50ea47, (q31_t)0x7a332490, (q31_t)0x7a151378, (q31_t)0x79f6b711, (q31_t)0x79d80f6f, + (q31_t)0x79b91ca4, (q31_t)0x7999dec4, + (q31_t)0x797a55e0, (q31_t)0x795a820e, (q31_t)0x793a6361, (q31_t)0x7919f9ec, (q31_t)0x78f945c3, (q31_t)0x78d846fb, + (q31_t)0x78b6fda8, (q31_t)0x789569df, + (q31_t)0x78738bb3, (q31_t)0x7851633b, (q31_t)0x782ef08b, (q31_t)0x780c33b8, (q31_t)0x77e92cd9, (q31_t)0x77c5dc01, + (q31_t)0x77a24148, (q31_t)0x777e5cc3, + (q31_t)0x775a2e89, (q31_t)0x7735b6af, (q31_t)0x7710f54c, (q31_t)0x76ebea77, (q31_t)0x76c69647, (q31_t)0x76a0f8d2, + (q31_t)0x767b1231, (q31_t)0x7654e279, + (q31_t)0x762e69c4, (q31_t)0x7607a828, (q31_t)0x75e09dbd, (q31_t)0x75b94a9c, (q31_t)0x7591aedd, (q31_t)0x7569ca99, + (q31_t)0x75419de7, (q31_t)0x751928e0, + (q31_t)0x74f06b9e, (q31_t)0x74c7663a, (q31_t)0x749e18cd, (q31_t)0x74748371, (q31_t)0x744aa63f, (q31_t)0x74208150, + (q31_t)0x73f614c0, (q31_t)0x73cb60a8, + (q31_t)0x73a06522, (q31_t)0x73752249, (q31_t)0x73499838, (q31_t)0x731dc70a, (q31_t)0x72f1aed9, (q31_t)0x72c54fc1, + (q31_t)0x7298a9dd, (q31_t)0x726bbd48, + (q31_t)0x723e8a20, (q31_t)0x7211107e, (q31_t)0x71e35080, (q31_t)0x71b54a41, (q31_t)0x7186fdde, (q31_t)0x71586b74, + (q31_t)0x7129931f, (q31_t)0x70fa74fc, + (q31_t)0x70cb1128, (q31_t)0x709b67c0, (q31_t)0x706b78e3, (q31_t)0x703b44ad, (q31_t)0x700acb3c, (q31_t)0x6fda0cae, + (q31_t)0x6fa90921, (q31_t)0x6f77c0b3, + (q31_t)0x6f463383, (q31_t)0x6f1461b0, (q31_t)0x6ee24b57, (q31_t)0x6eaff099, (q31_t)0x6e7d5193, (q31_t)0x6e4a6e66, + (q31_t)0x6e174730, (q31_t)0x6de3dc11, + (q31_t)0x6db02d29, (q31_t)0x6d7c3a98, (q31_t)0x6d48047e, (q31_t)0x6d138afb, (q31_t)0x6cdece2f, (q31_t)0x6ca9ce3b, + (q31_t)0x6c748b3f, (q31_t)0x6c3f055d, + (q31_t)0x6c093cb6, (q31_t)0x6bd3316a, (q31_t)0x6b9ce39b, (q31_t)0x6b66536b, (q31_t)0x6b2f80fb, (q31_t)0x6af86c6c, + (q31_t)0x6ac115e2, (q31_t)0x6a897d7d, + (q31_t)0x6a51a361, (q31_t)0x6a1987b0, (q31_t)0x69e12a8c, (q31_t)0x69a88c19, (q31_t)0x696fac78, (q31_t)0x69368bce, + (q31_t)0x68fd2a3d, (q31_t)0x68c387e9, + (q31_t)0x6889a4f6, (q31_t)0x684f8186, (q31_t)0x68151dbe, (q31_t)0x67da79c3, (q31_t)0x679f95b7, (q31_t)0x676471c0, + (q31_t)0x67290e02, (q31_t)0x66ed6aa1, + (q31_t)0x66b187c3, (q31_t)0x6675658c, (q31_t)0x66390422, (q31_t)0x65fc63a9, (q31_t)0x65bf8447, (q31_t)0x65826622, + (q31_t)0x6545095f, (q31_t)0x65076e25, + (q31_t)0x64c99498, (q31_t)0x648b7ce0, (q31_t)0x644d2722, (q31_t)0x640e9386, (q31_t)0x63cfc231, (q31_t)0x6390b34a, + (q31_t)0x635166f9, (q31_t)0x6311dd64, + (q31_t)0x62d216b3, (q31_t)0x6292130c, (q31_t)0x6251d298, (q31_t)0x6211557e, (q31_t)0x61d09be5, (q31_t)0x618fa5f7, + (q31_t)0x614e73da, (q31_t)0x610d05b7, + (q31_t)0x60cb5bb7, (q31_t)0x60897601, (q31_t)0x604754bf, (q31_t)0x6004f819, (q31_t)0x5fc26038, (q31_t)0x5f7f8d46, + (q31_t)0x5f3c7f6b, (q31_t)0x5ef936d1, + (q31_t)0x5eb5b3a2, (q31_t)0x5e71f606, (q31_t)0x5e2dfe29, (q31_t)0x5de9cc33, (q31_t)0x5da5604f, (q31_t)0x5d60baa7, + (q31_t)0x5d1bdb65, (q31_t)0x5cd6c2b5, + (q31_t)0x5c9170bf, (q31_t)0x5c4be5b0, (q31_t)0x5c0621b2, (q31_t)0x5bc024f0, (q31_t)0x5b79ef96, (q31_t)0x5b3381ce, + (q31_t)0x5aecdbc5, (q31_t)0x5aa5fda5, + (q31_t)0x5a5ee79a, (q31_t)0x5a1799d1, (q31_t)0x59d01475, (q31_t)0x598857b2, (q31_t)0x594063b5, (q31_t)0x58f838a9, + (q31_t)0x58afd6bd, (q31_t)0x58673e1b, + (q31_t)0x581e6ef1, (q31_t)0x57d5696d, (q31_t)0x578c2dba, (q31_t)0x5742bc06, (q31_t)0x56f9147e, (q31_t)0x56af3750, + (q31_t)0x566524aa, (q31_t)0x561adcb9, + (q31_t)0x55d05faa, (q31_t)0x5585adad, (q31_t)0x553ac6ee, (q31_t)0x54efab9c, (q31_t)0x54a45be6, (q31_t)0x5458d7f9, + (q31_t)0x540d2005, (q31_t)0x53c13439, + (q31_t)0x537514c2, (q31_t)0x5328c1d0, (q31_t)0x52dc3b92, (q31_t)0x528f8238, (q31_t)0x524295f0, (q31_t)0x51f576ea, + (q31_t)0x51a82555, (q31_t)0x515aa162, + (q31_t)0x510ceb40, (q31_t)0x50bf031f, (q31_t)0x5070e92f, (q31_t)0x50229da1, (q31_t)0x4fd420a4, (q31_t)0x4f857269, + (q31_t)0x4f369320, (q31_t)0x4ee782fb, + (q31_t)0x4e984229, (q31_t)0x4e48d0dd, (q31_t)0x4df92f46, (q31_t)0x4da95d96, (q31_t)0x4d595bfe, (q31_t)0x4d092ab0, + (q31_t)0x4cb8c9dd, (q31_t)0x4c6839b7, + (q31_t)0x4c177a6e, (q31_t)0x4bc68c36, (q31_t)0x4b756f40, (q31_t)0x4b2423be, (q31_t)0x4ad2a9e2, (q31_t)0x4a8101de, + (q31_t)0x4a2f2be6, (q31_t)0x49dd282a, + (q31_t)0x498af6df, (q31_t)0x49389836, (q31_t)0x48e60c62, (q31_t)0x48935397, (q31_t)0x48406e08, (q31_t)0x47ed5be6, + (q31_t)0x479a1d67, (q31_t)0x4746b2bc, + (q31_t)0x46f31c1a, (q31_t)0x469f59b4, (q31_t)0x464b6bbe, (q31_t)0x45f7526b, (q31_t)0x45a30df0, (q31_t)0x454e9e80, + (q31_t)0x44fa0450, (q31_t)0x44a53f93, + (q31_t)0x4450507e, (q31_t)0x43fb3746, (q31_t)0x43a5f41e, (q31_t)0x4350873c, (q31_t)0x42faf0d4, (q31_t)0x42a5311b, + (q31_t)0x424f4845, (q31_t)0x41f93689, + (q31_t)0x41a2fc1a, (q31_t)0x414c992f, (q31_t)0x40f60dfb, (q31_t)0x409f5ab6, (q31_t)0x40487f94, (q31_t)0x3ff17cca, + (q31_t)0x3f9a5290, (q31_t)0x3f430119, + (q31_t)0x3eeb889c, (q31_t)0x3e93e950, (q31_t)0x3e3c2369, (q31_t)0x3de4371f, (q31_t)0x3d8c24a8, (q31_t)0x3d33ec39, + (q31_t)0x3cdb8e09, (q31_t)0x3c830a50, + (q31_t)0x3c2a6142, (q31_t)0x3bd19318, (q31_t)0x3b78a007, (q31_t)0x3b1f8848, (q31_t)0x3ac64c0f, (q31_t)0x3a6ceb96, + (q31_t)0x3a136712, (q31_t)0x39b9bebc, + (q31_t)0x395ff2c9, (q31_t)0x39060373, (q31_t)0x38abf0ef, (q31_t)0x3851bb77, (q31_t)0x37f76341, (q31_t)0x379ce885, + (q31_t)0x37424b7b, (q31_t)0x36e78c5b, + (q31_t)0x368cab5c, (q31_t)0x3631a8b8, (q31_t)0x35d684a6, (q31_t)0x357b3f5d, (q31_t)0x351fd918, (q31_t)0x34c4520d, + (q31_t)0x3468aa76, (q31_t)0x340ce28b, + (q31_t)0x33b0fa84, (q31_t)0x3354f29b, (q31_t)0x32f8cb07, (q31_t)0x329c8402, (q31_t)0x32401dc6, (q31_t)0x31e39889, + (q31_t)0x3186f487, (q31_t)0x312a31f8, + (q31_t)0x30cd5115, (q31_t)0x30705217, (q31_t)0x30133539, (q31_t)0x2fb5fab2, (q31_t)0x2f58a2be, (q31_t)0x2efb2d95, + (q31_t)0x2e9d9b70, (q31_t)0x2e3fec8b, + (q31_t)0x2de2211e, (q31_t)0x2d843964, (q31_t)0x2d263596, (q31_t)0x2cc815ee, (q31_t)0x2c69daa6, (q31_t)0x2c0b83fa, + (q31_t)0x2bad1221, (q31_t)0x2b4e8558, + (q31_t)0x2aefddd8, (q31_t)0x2a911bdc, (q31_t)0x2a323f9e, (q31_t)0x29d34958, (q31_t)0x29743946, (q31_t)0x29150fa1, + (q31_t)0x28b5cca5, (q31_t)0x2856708d, + (q31_t)0x27f6fb92, (q31_t)0x27976df1, (q31_t)0x2737c7e3, (q31_t)0x26d809a5, (q31_t)0x26783370, (q31_t)0x26184581, + (q31_t)0x25b84012, (q31_t)0x2558235f, + (q31_t)0x24f7efa2, (q31_t)0x2497a517, (q31_t)0x243743fa, (q31_t)0x23d6cc87, (q31_t)0x23763ef7, (q31_t)0x23159b88, + (q31_t)0x22b4e274, (q31_t)0x225413f8, + (q31_t)0x21f3304f, (q31_t)0x219237b5, (q31_t)0x21312a65, (q31_t)0x20d0089c, (q31_t)0x206ed295, (q31_t)0x200d888d, + (q31_t)0x1fac2abf, (q31_t)0x1f4ab968, + (q31_t)0x1ee934c3, (q31_t)0x1e879d0d, (q31_t)0x1e25f282, (q31_t)0x1dc4355e, (q31_t)0x1d6265dd, (q31_t)0x1d00843d, + (q31_t)0x1c9e90b8, (q31_t)0x1c3c8b8c, + (q31_t)0x1bda74f6, (q31_t)0x1b784d30, (q31_t)0x1b161479, (q31_t)0x1ab3cb0d, (q31_t)0x1a517128, (q31_t)0x19ef0707, + (q31_t)0x198c8ce7, (q31_t)0x192a0304, + (q31_t)0x18c7699b, (q31_t)0x1864c0ea, (q31_t)0x1802092c, (q31_t)0x179f429f, (q31_t)0x173c6d80, (q31_t)0x16d98a0c, + (q31_t)0x1676987f, (q31_t)0x16139918, + (q31_t)0x15b08c12, (q31_t)0x154d71aa, (q31_t)0x14ea4a1f, (q31_t)0x148715ae, (q31_t)0x1423d492, (q31_t)0x13c0870a, + (q31_t)0x135d2d53, (q31_t)0x12f9c7aa, + (q31_t)0x1296564d, (q31_t)0x1232d979, (q31_t)0x11cf516a, (q31_t)0x116bbe60, (q31_t)0x11082096, (q31_t)0x10a4784b, + (q31_t)0x1040c5bb, (q31_t)0xfdd0926, + (q31_t)0xf7942c7, (q31_t)0xf1572dc, (q31_t)0xeb199a4, (q31_t)0xe4db75b, (q31_t)0xde9cc40, (q31_t)0xd85d88f, (q31_t)0xd21dc87, + (q31_t)0xcbdd865, + (q31_t)0xc59cc68, (q31_t)0xbf5b8cb, (q31_t)0xb919dcf, (q31_t)0xb2d7baf, (q31_t)0xac952aa, (q31_t)0xa6522fe, (q31_t)0xa00ece8, + (q31_t)0x99cb0a7, + (q31_t)0x9386e78, (q31_t)0x8d42699, (q31_t)0x86fd947, (q31_t)0x80b86c2, (q31_t)0x7a72f45, (q31_t)0x742d311, (q31_t)0x6de7262, + (q31_t)0x67a0d76, + (q31_t)0x615a48b, (q31_t)0x5b137df, (q31_t)0x54cc7b1, (q31_t)0x4e8543e, (q31_t)0x483ddc3, (q31_t)0x41f6480, (q31_t)0x3bae8b2, + (q31_t)0x3566a96, + (q31_t)0x2f1ea6c, (q31_t)0x28d6870, (q31_t)0x228e4e2, (q31_t)0x1c45ffe, (q31_t)0x15fda03, (q31_t)0xfb5330, (q31_t)0x96cbc1, + (q31_t)0x3243f5 +}; + +static const q31_t cos_factorsQ31_2048[2048] = { + (q31_t)0x7fffff62, (q31_t)0x7ffffa73, (q31_t)0x7ffff094, (q31_t)0x7fffe1c6, (q31_t)0x7fffce09, (q31_t)0x7fffb55c, + (q31_t)0x7fff97c1, (q31_t)0x7fff7536, + (q31_t)0x7fff4dbb, (q31_t)0x7fff2151, (q31_t)0x7ffeeff8, (q31_t)0x7ffeb9b0, (q31_t)0x7ffe7e79, (q31_t)0x7ffe3e52, + (q31_t)0x7ffdf93c, (q31_t)0x7ffdaf37, + (q31_t)0x7ffd6042, (q31_t)0x7ffd0c5f, (q31_t)0x7ffcb38c, (q31_t)0x7ffc55ca, (q31_t)0x7ffbf319, (q31_t)0x7ffb8b78, + (q31_t)0x7ffb1ee9, (q31_t)0x7ffaad6a, + (q31_t)0x7ffa36fc, (q31_t)0x7ff9bba0, (q31_t)0x7ff93b54, (q31_t)0x7ff8b619, (q31_t)0x7ff82bef, (q31_t)0x7ff79cd6, + (q31_t)0x7ff708ce, (q31_t)0x7ff66fd7, + (q31_t)0x7ff5d1f1, (q31_t)0x7ff52f1d, (q31_t)0x7ff48759, (q31_t)0x7ff3daa6, (q31_t)0x7ff32905, (q31_t)0x7ff27275, + (q31_t)0x7ff1b6f6, (q31_t)0x7ff0f688, + (q31_t)0x7ff0312c, (q31_t)0x7fef66e1, (q31_t)0x7fee97a7, (q31_t)0x7fedc37e, (q31_t)0x7fecea67, (q31_t)0x7fec0c62, + (q31_t)0x7feb296d, (q31_t)0x7fea418b, + (q31_t)0x7fe954ba, (q31_t)0x7fe862fa, (q31_t)0x7fe76c4c, (q31_t)0x7fe670b0, (q31_t)0x7fe57025, (q31_t)0x7fe46aac, + (q31_t)0x7fe36045, (q31_t)0x7fe250ef, + (q31_t)0x7fe13cac, (q31_t)0x7fe0237a, (q31_t)0x7fdf055a, (q31_t)0x7fdde24d, (q31_t)0x7fdcba51, (q31_t)0x7fdb8d67, + (q31_t)0x7fda5b8f, (q31_t)0x7fd924ca, + (q31_t)0x7fd7e917, (q31_t)0x7fd6a875, (q31_t)0x7fd562e7, (q31_t)0x7fd4186a, (q31_t)0x7fd2c900, (q31_t)0x7fd174a8, + (q31_t)0x7fd01b63, (q31_t)0x7fcebd31, + (q31_t)0x7fcd5a11, (q31_t)0x7fcbf203, (q31_t)0x7fca8508, (q31_t)0x7fc91320, (q31_t)0x7fc79c4b, (q31_t)0x7fc62089, + (q31_t)0x7fc49fda, (q31_t)0x7fc31a3d, + (q31_t)0x7fc18fb4, (q31_t)0x7fc0003e, (q31_t)0x7fbe6bdb, (q31_t)0x7fbcd28b, (q31_t)0x7fbb344e, (q31_t)0x7fb99125, + (q31_t)0x7fb7e90f, (q31_t)0x7fb63c0d, + (q31_t)0x7fb48a1e, (q31_t)0x7fb2d343, (q31_t)0x7fb1177b, (q31_t)0x7faf56c7, (q31_t)0x7fad9127, (q31_t)0x7fabc69b, + (q31_t)0x7fa9f723, (q31_t)0x7fa822bf, + (q31_t)0x7fa6496e, (q31_t)0x7fa46b32, (q31_t)0x7fa2880b, (q31_t)0x7fa09ff7, (q31_t)0x7f9eb2f8, (q31_t)0x7f9cc10d, + (q31_t)0x7f9aca37, (q31_t)0x7f98ce76, + (q31_t)0x7f96cdc9, (q31_t)0x7f94c831, (q31_t)0x7f92bdad, (q31_t)0x7f90ae3f, (q31_t)0x7f8e99e6, (q31_t)0x7f8c80a1, + (q31_t)0x7f8a6272, (q31_t)0x7f883f58, + (q31_t)0x7f861753, (q31_t)0x7f83ea64, (q31_t)0x7f81b88a, (q31_t)0x7f7f81c6, (q31_t)0x7f7d4617, (q31_t)0x7f7b057e, + (q31_t)0x7f78bffb, (q31_t)0x7f76758e, + (q31_t)0x7f742637, (q31_t)0x7f71d1f6, (q31_t)0x7f6f78cb, (q31_t)0x7f6d1ab6, (q31_t)0x7f6ab7b8, (q31_t)0x7f684fd0, + (q31_t)0x7f65e2ff, (q31_t)0x7f637144, + (q31_t)0x7f60faa0, (q31_t)0x7f5e7f13, (q31_t)0x7f5bfe9d, (q31_t)0x7f59793e, (q31_t)0x7f56eef5, (q31_t)0x7f545fc5, + (q31_t)0x7f51cbab, (q31_t)0x7f4f32a9, + (q31_t)0x7f4c94be, (q31_t)0x7f49f1eb, (q31_t)0x7f474a30, (q31_t)0x7f449d8c, (q31_t)0x7f41ec01, (q31_t)0x7f3f358d, + (q31_t)0x7f3c7a31, (q31_t)0x7f39b9ee, + (q31_t)0x7f36f4c3, (q31_t)0x7f342ab1, (q31_t)0x7f315bb7, (q31_t)0x7f2e87d6, (q31_t)0x7f2baf0d, (q31_t)0x7f28d15d, + (q31_t)0x7f25eec7, (q31_t)0x7f230749, + (q31_t)0x7f201ae5, (q31_t)0x7f1d299a, (q31_t)0x7f1a3368, (q31_t)0x7f173850, (q31_t)0x7f143852, (q31_t)0x7f11336d, + (q31_t)0x7f0e29a3, (q31_t)0x7f0b1af2, + (q31_t)0x7f08075c, (q31_t)0x7f04eedf, (q31_t)0x7f01d17d, (q31_t)0x7efeaf36, (q31_t)0x7efb8809, (q31_t)0x7ef85bf7, + (q31_t)0x7ef52b00, (q31_t)0x7ef1f524, + (q31_t)0x7eeeba62, (q31_t)0x7eeb7abc, (q31_t)0x7ee83632, (q31_t)0x7ee4ecc3, (q31_t)0x7ee19e6f, (q31_t)0x7ede4b38, + (q31_t)0x7edaf31c, (q31_t)0x7ed7961c, + (q31_t)0x7ed43438, (q31_t)0x7ed0cd70, (q31_t)0x7ecd61c5, (q31_t)0x7ec9f137, (q31_t)0x7ec67bc5, (q31_t)0x7ec3016f, + (q31_t)0x7ebf8237, (q31_t)0x7ebbfe1c, + (q31_t)0x7eb8751e, (q31_t)0x7eb4e73d, (q31_t)0x7eb1547a, (q31_t)0x7eadbcd4, (q31_t)0x7eaa204c, (q31_t)0x7ea67ee2, + (q31_t)0x7ea2d896, (q31_t)0x7e9f2d68, + (q31_t)0x7e9b7d58, (q31_t)0x7e97c867, (q31_t)0x7e940e94, (q31_t)0x7e904fe0, (q31_t)0x7e8c8c4b, (q31_t)0x7e88c3d5, + (q31_t)0x7e84f67e, (q31_t)0x7e812447, + (q31_t)0x7e7d4d2f, (q31_t)0x7e797136, (q31_t)0x7e75905d, (q31_t)0x7e71aaa4, (q31_t)0x7e6dc00c, (q31_t)0x7e69d093, + (q31_t)0x7e65dc3b, (q31_t)0x7e61e303, + (q31_t)0x7e5de4ec, (q31_t)0x7e59e1f5, (q31_t)0x7e55da20, (q31_t)0x7e51cd6c, (q31_t)0x7e4dbbd9, (q31_t)0x7e49a567, + (q31_t)0x7e458a17, (q31_t)0x7e4169e9, + (q31_t)0x7e3d44dd, (q31_t)0x7e391af3, (q31_t)0x7e34ec2b, (q31_t)0x7e30b885, (q31_t)0x7e2c8002, (q31_t)0x7e2842a2, + (q31_t)0x7e240064, (q31_t)0x7e1fb94a, + (q31_t)0x7e1b6d53, (q31_t)0x7e171c7f, (q31_t)0x7e12c6ce, (q31_t)0x7e0e6c42, (q31_t)0x7e0a0cd9, (q31_t)0x7e05a894, + (q31_t)0x7e013f74, (q31_t)0x7dfcd178, + (q31_t)0x7df85ea0, (q31_t)0x7df3e6ee, (q31_t)0x7def6a60, (q31_t)0x7deae8f7, (q31_t)0x7de662b3, (q31_t)0x7de1d795, + (q31_t)0x7ddd479d, (q31_t)0x7dd8b2ca, + (q31_t)0x7dd4191d, (q31_t)0x7dcf7a96, (q31_t)0x7dcad736, (q31_t)0x7dc62efc, (q31_t)0x7dc181e8, (q31_t)0x7dbccffc, + (q31_t)0x7db81936, (q31_t)0x7db35d98, + (q31_t)0x7dae9d21, (q31_t)0x7da9d7d2, (q31_t)0x7da50dab, (q31_t)0x7da03eab, (q31_t)0x7d9b6ad3, (q31_t)0x7d969224, + (q31_t)0x7d91b49e, (q31_t)0x7d8cd240, + (q31_t)0x7d87eb0a, (q31_t)0x7d82fefe, (q31_t)0x7d7e0e1c, (q31_t)0x7d791862, (q31_t)0x7d741dd2, (q31_t)0x7d6f1e6c, + (q31_t)0x7d6a1a31, (q31_t)0x7d65111f, + (q31_t)0x7d600338, (q31_t)0x7d5af07b, (q31_t)0x7d55d8e9, (q31_t)0x7d50bc82, (q31_t)0x7d4b9b46, (q31_t)0x7d467536, + (q31_t)0x7d414a51, (q31_t)0x7d3c1a98, + (q31_t)0x7d36e60b, (q31_t)0x7d31acaa, (q31_t)0x7d2c6e76, (q31_t)0x7d272b6e, (q31_t)0x7d21e393, (q31_t)0x7d1c96e5, + (q31_t)0x7d174564, (q31_t)0x7d11ef11, + (q31_t)0x7d0c93eb, (q31_t)0x7d0733f3, (q31_t)0x7d01cf29, (q31_t)0x7cfc658d, (q31_t)0x7cf6f720, (q31_t)0x7cf183e1, + (q31_t)0x7cec0bd1, (q31_t)0x7ce68ef0, + (q31_t)0x7ce10d3f, (q31_t)0x7cdb86bd, (q31_t)0x7cd5fb6a, (q31_t)0x7cd06b48, (q31_t)0x7ccad656, (q31_t)0x7cc53c94, + (q31_t)0x7cbf9e03, (q31_t)0x7cb9faa2, + (q31_t)0x7cb45272, (q31_t)0x7caea574, (q31_t)0x7ca8f3a7, (q31_t)0x7ca33d0c, (q31_t)0x7c9d81a3, (q31_t)0x7c97c16b, + (q31_t)0x7c91fc66, (q31_t)0x7c8c3294, + (q31_t)0x7c8663f4, (q31_t)0x7c809088, (q31_t)0x7c7ab84e, (q31_t)0x7c74db48, (q31_t)0x7c6ef976, (q31_t)0x7c6912d7, + (q31_t)0x7c63276d, (q31_t)0x7c5d3737, + (q31_t)0x7c574236, (q31_t)0x7c514869, (q31_t)0x7c4b49d2, (q31_t)0x7c45466f, (q31_t)0x7c3f3e42, (q31_t)0x7c39314b, + (q31_t)0x7c331f8a, (q31_t)0x7c2d08ff, + (q31_t)0x7c26edab, (q31_t)0x7c20cd8d, (q31_t)0x7c1aa8a6, (q31_t)0x7c147ef6, (q31_t)0x7c0e507e, (q31_t)0x7c081d3d, + (q31_t)0x7c01e534, (q31_t)0x7bfba863, + (q31_t)0x7bf566cb, (q31_t)0x7bef206b, (q31_t)0x7be8d544, (q31_t)0x7be28556, (q31_t)0x7bdc30a1, (q31_t)0x7bd5d726, + (q31_t)0x7bcf78e5, (q31_t)0x7bc915dd, + (q31_t)0x7bc2ae10, (q31_t)0x7bbc417e, (q31_t)0x7bb5d026, (q31_t)0x7baf5a09, (q31_t)0x7ba8df28, (q31_t)0x7ba25f82, + (q31_t)0x7b9bdb18, (q31_t)0x7b9551ea, + (q31_t)0x7b8ec3f8, (q31_t)0x7b883143, (q31_t)0x7b8199ca, (q31_t)0x7b7afd8f, (q31_t)0x7b745c91, (q31_t)0x7b6db6d0, + (q31_t)0x7b670c4d, (q31_t)0x7b605d09, + (q31_t)0x7b59a902, (q31_t)0x7b52f03a, (q31_t)0x7b4c32b1, (q31_t)0x7b457068, (q31_t)0x7b3ea95d, (q31_t)0x7b37dd92, + (q31_t)0x7b310d07, (q31_t)0x7b2a37bc, + (q31_t)0x7b235db2, (q31_t)0x7b1c7ee8, (q31_t)0x7b159b5f, (q31_t)0x7b0eb318, (q31_t)0x7b07c612, (q31_t)0x7b00d44d, + (q31_t)0x7af9ddcb, (q31_t)0x7af2e28b, + (q31_t)0x7aebe28d, (q31_t)0x7ae4ddd2, (q31_t)0x7addd45b, (q31_t)0x7ad6c626, (q31_t)0x7acfb336, (q31_t)0x7ac89b89, + (q31_t)0x7ac17f20, (q31_t)0x7aba5dfc, + (q31_t)0x7ab3381d, (q31_t)0x7aac0d82, (q31_t)0x7aa4de2d, (q31_t)0x7a9daa1d, (q31_t)0x7a967153, (q31_t)0x7a8f33d0, + (q31_t)0x7a87f192, (q31_t)0x7a80aa9c, + (q31_t)0x7a795eec, (q31_t)0x7a720e84, (q31_t)0x7a6ab963, (q31_t)0x7a635f8a, (q31_t)0x7a5c00f9, (q31_t)0x7a549db0, + (q31_t)0x7a4d35b0, (q31_t)0x7a45c8f9, + (q31_t)0x7a3e578b, (q31_t)0x7a36e166, (q31_t)0x7a2f668c, (q31_t)0x7a27e6fb, (q31_t)0x7a2062b5, (q31_t)0x7a18d9b9, + (q31_t)0x7a114c09, (q31_t)0x7a09b9a4, + (q31_t)0x7a02228a, (q31_t)0x79fa86bc, (q31_t)0x79f2e63a, (q31_t)0x79eb4105, (q31_t)0x79e3971c, (q31_t)0x79dbe880, + (q31_t)0x79d43532, (q31_t)0x79cc7d31, + (q31_t)0x79c4c07e, (q31_t)0x79bcff19, (q31_t)0x79b53903, (q31_t)0x79ad6e3c, (q31_t)0x79a59ec3, (q31_t)0x799dca9a, + (q31_t)0x7995f1c1, (q31_t)0x798e1438, + (q31_t)0x798631ff, (q31_t)0x797e4b16, (q31_t)0x79765f7f, (q31_t)0x796e6f39, (q31_t)0x79667a44, (q31_t)0x795e80a1, + (q31_t)0x79568250, (q31_t)0x794e7f52, + (q31_t)0x794677a6, (q31_t)0x793e6b4e, (q31_t)0x79365a49, (q31_t)0x792e4497, (q31_t)0x79262a3a, (q31_t)0x791e0b31, + (q31_t)0x7915e77c, (q31_t)0x790dbf1d, + (q31_t)0x79059212, (q31_t)0x78fd605d, (q31_t)0x78f529fe, (q31_t)0x78eceef6, (q31_t)0x78e4af44, (q31_t)0x78dc6ae8, + (q31_t)0x78d421e4, (q31_t)0x78cbd437, + (q31_t)0x78c381e2, (q31_t)0x78bb2ae5, (q31_t)0x78b2cf41, (q31_t)0x78aa6ef5, (q31_t)0x78a20a03, (q31_t)0x7899a06a, + (q31_t)0x7891322a, (q31_t)0x7888bf45, + (q31_t)0x788047ba, (q31_t)0x7877cb89, (q31_t)0x786f4ab4, (q31_t)0x7866c53a, (q31_t)0x785e3b1c, (q31_t)0x7855ac5a, + (q31_t)0x784d18f4, (q31_t)0x784480ea, + (q31_t)0x783be43e, (q31_t)0x783342ef, (q31_t)0x782a9cfe, (q31_t)0x7821f26b, (q31_t)0x78194336, (q31_t)0x78108f60, + (q31_t)0x7807d6e9, (q31_t)0x77ff19d1, + (q31_t)0x77f65819, (q31_t)0x77ed91c0, (q31_t)0x77e4c6c9, (q31_t)0x77dbf732, (q31_t)0x77d322fc, (q31_t)0x77ca4a27, + (q31_t)0x77c16cb4, (q31_t)0x77b88aa3, + (q31_t)0x77afa3f5, (q31_t)0x77a6b8a9, (q31_t)0x779dc8c0, (q31_t)0x7794d43b, (q31_t)0x778bdb19, (q31_t)0x7782dd5c, + (q31_t)0x7779db03, (q31_t)0x7770d40f, + (q31_t)0x7767c880, (q31_t)0x775eb857, (q31_t)0x7755a394, (q31_t)0x774c8a36, (q31_t)0x77436c40, (q31_t)0x773a49b0, + (q31_t)0x77312287, (q31_t)0x7727f6c6, + (q31_t)0x771ec66e, (q31_t)0x7715917d, (q31_t)0x770c57f5, (q31_t)0x770319d6, (q31_t)0x76f9d721, (q31_t)0x76f08fd5, + (q31_t)0x76e743f4, (q31_t)0x76ddf37c, + (q31_t)0x76d49e70, (q31_t)0x76cb44cf, (q31_t)0x76c1e699, (q31_t)0x76b883d0, (q31_t)0x76af1c72, (q31_t)0x76a5b082, + (q31_t)0x769c3ffe, (q31_t)0x7692cae8, + (q31_t)0x7689513f, (q31_t)0x767fd304, (q31_t)0x76765038, (q31_t)0x766cc8db, (q31_t)0x76633ced, (q31_t)0x7659ac6f, + (q31_t)0x76501760, (q31_t)0x76467dc2, + (q31_t)0x763cdf94, (q31_t)0x76333cd8, (q31_t)0x7629958c, (q31_t)0x761fe9b3, (q31_t)0x7616394c, (q31_t)0x760c8457, + (q31_t)0x7602cad5, (q31_t)0x75f90cc7, + (q31_t)0x75ef4a2c, (q31_t)0x75e58305, (q31_t)0x75dbb753, (q31_t)0x75d1e715, (q31_t)0x75c8124d, (q31_t)0x75be38fa, + (q31_t)0x75b45b1d, (q31_t)0x75aa78b6, + (q31_t)0x75a091c6, (q31_t)0x7596a64d, (q31_t)0x758cb64c, (q31_t)0x7582c1c2, (q31_t)0x7578c8b0, (q31_t)0x756ecb18, + (q31_t)0x7564c8f8, (q31_t)0x755ac251, + (q31_t)0x7550b725, (q31_t)0x7546a772, (q31_t)0x753c933a, (q31_t)0x75327a7d, (q31_t)0x75285d3b, (q31_t)0x751e3b75, + (q31_t)0x7514152b, (q31_t)0x7509ea5d, + (q31_t)0x74ffbb0d, (q31_t)0x74f58739, (q31_t)0x74eb4ee3, (q31_t)0x74e1120c, (q31_t)0x74d6d0b2, (q31_t)0x74cc8ad8, + (q31_t)0x74c2407d, (q31_t)0x74b7f1a1, + (q31_t)0x74ad9e46, (q31_t)0x74a3466b, (q31_t)0x7498ea11, (q31_t)0x748e8938, (q31_t)0x748423e0, (q31_t)0x7479ba0b, + (q31_t)0x746f4bb8, (q31_t)0x7464d8e8, + (q31_t)0x745a619b, (q31_t)0x744fe5d2, (q31_t)0x7445658d, (q31_t)0x743ae0cc, (q31_t)0x74305790, (q31_t)0x7425c9da, + (q31_t)0x741b37a9, (q31_t)0x7410a0fe, + (q31_t)0x740605d9, (q31_t)0x73fb663c, (q31_t)0x73f0c226, (q31_t)0x73e61997, (q31_t)0x73db6c91, (q31_t)0x73d0bb13, + (q31_t)0x73c6051f, (q31_t)0x73bb4ab3, + (q31_t)0x73b08bd1, (q31_t)0x73a5c87a, (q31_t)0x739b00ad, (q31_t)0x7390346b, (q31_t)0x738563b5, (q31_t)0x737a8e8a, + (q31_t)0x736fb4ec, (q31_t)0x7364d6da, + (q31_t)0x7359f456, (q31_t)0x734f0d5f, (q31_t)0x734421f6, (q31_t)0x7339321b, (q31_t)0x732e3dcf, (q31_t)0x73234512, + (q31_t)0x731847e5, (q31_t)0x730d4648, + (q31_t)0x7302403c, (q31_t)0x72f735c0, (q31_t)0x72ec26d6, (q31_t)0x72e1137d, (q31_t)0x72d5fbb7, (q31_t)0x72cadf83, + (q31_t)0x72bfbee3, (q31_t)0x72b499d6, + (q31_t)0x72a9705c, (q31_t)0x729e4277, (q31_t)0x72931027, (q31_t)0x7287d96c, (q31_t)0x727c9e47, (q31_t)0x72715eb8, + (q31_t)0x72661abf, (q31_t)0x725ad25d, + (q31_t)0x724f8593, (q31_t)0x72443460, (q31_t)0x7238dec5, (q31_t)0x722d84c4, (q31_t)0x7222265b, (q31_t)0x7216c38c, + (q31_t)0x720b5c57, (q31_t)0x71fff0bc, + (q31_t)0x71f480bc, (q31_t)0x71e90c57, (q31_t)0x71dd938f, (q31_t)0x71d21662, (q31_t)0x71c694d2, (q31_t)0x71bb0edf, + (q31_t)0x71af848a, (q31_t)0x71a3f5d2, + (q31_t)0x719862b9, (q31_t)0x718ccb3f, (q31_t)0x71812f65, (q31_t)0x71758f29, (q31_t)0x7169ea8f, (q31_t)0x715e4194, + (q31_t)0x7152943b, (q31_t)0x7146e284, + (q31_t)0x713b2c6e, (q31_t)0x712f71fb, (q31_t)0x7123b32b, (q31_t)0x7117effe, (q31_t)0x710c2875, (q31_t)0x71005c90, + (q31_t)0x70f48c50, (q31_t)0x70e8b7b5, + (q31_t)0x70dcdec0, (q31_t)0x70d10171, (q31_t)0x70c51fc8, (q31_t)0x70b939c7, (q31_t)0x70ad4f6d, (q31_t)0x70a160ba, + (q31_t)0x70956db1, (q31_t)0x70897650, + (q31_t)0x707d7a98, (q31_t)0x70717a8a, (q31_t)0x70657626, (q31_t)0x70596d6d, (q31_t)0x704d6060, (q31_t)0x70414efd, + (q31_t)0x70353947, (q31_t)0x70291f3e, + (q31_t)0x701d00e1, (q31_t)0x7010de32, (q31_t)0x7004b731, (q31_t)0x6ff88bde, (q31_t)0x6fec5c3b, (q31_t)0x6fe02846, + (q31_t)0x6fd3f001, (q31_t)0x6fc7b36d, + (q31_t)0x6fbb728a, (q31_t)0x6faf2d57, (q31_t)0x6fa2e3d7, (q31_t)0x6f969608, (q31_t)0x6f8a43ed, (q31_t)0x6f7ded84, + (q31_t)0x6f7192cf, (q31_t)0x6f6533ce, + (q31_t)0x6f58d082, (q31_t)0x6f4c68eb, (q31_t)0x6f3ffd09, (q31_t)0x6f338cde, (q31_t)0x6f271868, (q31_t)0x6f1a9faa, + (q31_t)0x6f0e22a3, (q31_t)0x6f01a155, + (q31_t)0x6ef51bbe, (q31_t)0x6ee891e1, (q31_t)0x6edc03bc, (q31_t)0x6ecf7152, (q31_t)0x6ec2daa2, (q31_t)0x6eb63fad, + (q31_t)0x6ea9a073, (q31_t)0x6e9cfcf5, + (q31_t)0x6e905534, (q31_t)0x6e83a92f, (q31_t)0x6e76f8e7, (q31_t)0x6e6a445d, (q31_t)0x6e5d8b91, (q31_t)0x6e50ce84, + (q31_t)0x6e440d37, (q31_t)0x6e3747a9, + (q31_t)0x6e2a7ddb, (q31_t)0x6e1dafce, (q31_t)0x6e10dd82, (q31_t)0x6e0406f8, (q31_t)0x6df72c30, (q31_t)0x6dea4d2b, + (q31_t)0x6ddd69e9, (q31_t)0x6dd0826a, + (q31_t)0x6dc396b0, (q31_t)0x6db6a6ba, (q31_t)0x6da9b28a, (q31_t)0x6d9cba1f, (q31_t)0x6d8fbd7a, (q31_t)0x6d82bc9d, + (q31_t)0x6d75b786, (q31_t)0x6d68ae37, + (q31_t)0x6d5ba0b0, (q31_t)0x6d4e8ef2, (q31_t)0x6d4178fd, (q31_t)0x6d345ed1, (q31_t)0x6d274070, (q31_t)0x6d1a1dda, + (q31_t)0x6d0cf70f, (q31_t)0x6cffcc0f, + (q31_t)0x6cf29cdc, (q31_t)0x6ce56975, (q31_t)0x6cd831dc, (q31_t)0x6ccaf610, (q31_t)0x6cbdb613, (q31_t)0x6cb071e4, + (q31_t)0x6ca32985, (q31_t)0x6c95dcf6, + (q31_t)0x6c888c36, (q31_t)0x6c7b3748, (q31_t)0x6c6dde2b, (q31_t)0x6c6080e0, (q31_t)0x6c531f67, (q31_t)0x6c45b9c1, + (q31_t)0x6c384fef, (q31_t)0x6c2ae1f0, + (q31_t)0x6c1d6fc6, (q31_t)0x6c0ff971, (q31_t)0x6c027ef1, (q31_t)0x6bf50047, (q31_t)0x6be77d74, (q31_t)0x6bd9f677, + (q31_t)0x6bcc6b53, (q31_t)0x6bbedc06, + (q31_t)0x6bb14892, (q31_t)0x6ba3b0f7, (q31_t)0x6b961536, (q31_t)0x6b88754f, (q31_t)0x6b7ad142, (q31_t)0x6b6d2911, + (q31_t)0x6b5f7cbc, (q31_t)0x6b51cc42, + (q31_t)0x6b4417a6, (q31_t)0x6b365ee7, (q31_t)0x6b28a206, (q31_t)0x6b1ae103, (q31_t)0x6b0d1bdf, (q31_t)0x6aff529a, + (q31_t)0x6af18536, (q31_t)0x6ae3b3b2, + (q31_t)0x6ad5de0f, (q31_t)0x6ac8044e, (q31_t)0x6aba266e, (q31_t)0x6aac4472, (q31_t)0x6a9e5e58, (q31_t)0x6a907423, + (q31_t)0x6a8285d1, (q31_t)0x6a749365, + (q31_t)0x6a669cdd, (q31_t)0x6a58a23c, (q31_t)0x6a4aa381, (q31_t)0x6a3ca0ad, (q31_t)0x6a2e99c0, (q31_t)0x6a208ebb, + (q31_t)0x6a127f9f, (q31_t)0x6a046c6c, + (q31_t)0x69f65523, (q31_t)0x69e839c4, (q31_t)0x69da1a50, (q31_t)0x69cbf6c7, (q31_t)0x69bdcf29, (q31_t)0x69afa378, + (q31_t)0x69a173b5, (q31_t)0x69933fde, + (q31_t)0x698507f6, (q31_t)0x6976cbfc, (q31_t)0x69688bf1, (q31_t)0x695a47d6, (q31_t)0x694bffab, (q31_t)0x693db371, + (q31_t)0x692f6328, (q31_t)0x69210ed1, + (q31_t)0x6912b66c, (q31_t)0x690459fb, (q31_t)0x68f5f97d, (q31_t)0x68e794f3, (q31_t)0x68d92c5d, (q31_t)0x68cabfbd, + (q31_t)0x68bc4f13, (q31_t)0x68adda5f, + (q31_t)0x689f61a1, (q31_t)0x6890e4dc, (q31_t)0x6882640e, (q31_t)0x6873df38, (q31_t)0x6865565c, (q31_t)0x6856c979, + (q31_t)0x68483891, (q31_t)0x6839a3a4, + (q31_t)0x682b0ab1, (q31_t)0x681c6dbb, (q31_t)0x680dccc1, (q31_t)0x67ff27c4, (q31_t)0x67f07ec5, (q31_t)0x67e1d1c4, + (q31_t)0x67d320c1, (q31_t)0x67c46bbe, + (q31_t)0x67b5b2bb, (q31_t)0x67a6f5b8, (q31_t)0x679834b6, (q31_t)0x67896fb6, (q31_t)0x677aa6b8, (q31_t)0x676bd9bd, + (q31_t)0x675d08c4, (q31_t)0x674e33d0, + (q31_t)0x673f5ae0, (q31_t)0x67307df5, (q31_t)0x67219d10, (q31_t)0x6712b831, (q31_t)0x6703cf58, (q31_t)0x66f4e287, + (q31_t)0x66e5f1be, (q31_t)0x66d6fcfd, + (q31_t)0x66c80445, (q31_t)0x66b90797, (q31_t)0x66aa06f3, (q31_t)0x669b0259, (q31_t)0x668bf9cb, (q31_t)0x667ced49, + (q31_t)0x666ddcd3, (q31_t)0x665ec86b, + (q31_t)0x664fb010, (q31_t)0x664093c3, (q31_t)0x66317385, (q31_t)0x66224f56, (q31_t)0x66132738, (q31_t)0x6603fb2a, + (q31_t)0x65f4cb2d, (q31_t)0x65e59742, + (q31_t)0x65d65f69, (q31_t)0x65c723a3, (q31_t)0x65b7e3f1, (q31_t)0x65a8a052, (q31_t)0x659958c9, (q31_t)0x658a0d54, + (q31_t)0x657abdf6, (q31_t)0x656b6aae, + (q31_t)0x655c137d, (q31_t)0x654cb863, (q31_t)0x653d5962, (q31_t)0x652df679, (q31_t)0x651e8faa, (q31_t)0x650f24f5, + (q31_t)0x64ffb65b, (q31_t)0x64f043dc, + (q31_t)0x64e0cd78, (q31_t)0x64d15331, (q31_t)0x64c1d507, (q31_t)0x64b252fa, (q31_t)0x64a2cd0c, (q31_t)0x6493433c, + (q31_t)0x6483b58c, (q31_t)0x647423fb, + (q31_t)0x64648e8c, (q31_t)0x6454f53d, (q31_t)0x64455810, (q31_t)0x6435b706, (q31_t)0x6426121e, (q31_t)0x6416695a, + (q31_t)0x6406bcba, (q31_t)0x63f70c3f, + (q31_t)0x63e757ea, (q31_t)0x63d79fba, (q31_t)0x63c7e3b1, (q31_t)0x63b823cf, (q31_t)0x63a86015, (q31_t)0x63989884, + (q31_t)0x6388cd1b, (q31_t)0x6378fddc, + (q31_t)0x63692ac7, (q31_t)0x635953dd, (q31_t)0x6349791f, (q31_t)0x63399a8d, (q31_t)0x6329b827, (q31_t)0x6319d1ef, + (q31_t)0x6309e7e4, (q31_t)0x62f9fa09, + (q31_t)0x62ea085c, (q31_t)0x62da12df, (q31_t)0x62ca1992, (q31_t)0x62ba1c77, (q31_t)0x62aa1b8d, (q31_t)0x629a16d5, + (q31_t)0x628a0e50, (q31_t)0x627a01fe, + (q31_t)0x6269f1e1, (q31_t)0x6259ddf8, (q31_t)0x6249c645, (q31_t)0x6239aac7, (q31_t)0x62298b81, (q31_t)0x62196871, + (q31_t)0x62094199, (q31_t)0x61f916f9, + (q31_t)0x61e8e893, (q31_t)0x61d8b666, (q31_t)0x61c88074, (q31_t)0x61b846bc, (q31_t)0x61a80940, (q31_t)0x6197c800, + (q31_t)0x618782fd, (q31_t)0x61773a37, + (q31_t)0x6166edb0, (q31_t)0x61569d67, (q31_t)0x6146495d, (q31_t)0x6135f193, (q31_t)0x6125960a, (q31_t)0x611536c2, + (q31_t)0x6104d3bc, (q31_t)0x60f46cf9, + (q31_t)0x60e40278, (q31_t)0x60d3943b, (q31_t)0x60c32243, (q31_t)0x60b2ac8f, (q31_t)0x60a23322, (q31_t)0x6091b5fa, + (q31_t)0x60813519, (q31_t)0x6070b080, + (q31_t)0x6060282f, (q31_t)0x604f9c27, (q31_t)0x603f0c69, (q31_t)0x602e78f4, (q31_t)0x601de1ca, (q31_t)0x600d46ec, + (q31_t)0x5ffca859, (q31_t)0x5fec0613, + (q31_t)0x5fdb601b, (q31_t)0x5fcab670, (q31_t)0x5fba0914, (q31_t)0x5fa95807, (q31_t)0x5f98a34a, (q31_t)0x5f87eade, + (q31_t)0x5f772ec2, (q31_t)0x5f666ef9, + (q31_t)0x5f55ab82, (q31_t)0x5f44e45e, (q31_t)0x5f34198e, (q31_t)0x5f234b12, (q31_t)0x5f1278eb, (q31_t)0x5f01a31a, + (q31_t)0x5ef0c99f, (q31_t)0x5edfec7b, + (q31_t)0x5ecf0baf, (q31_t)0x5ebe273b, (q31_t)0x5ead3f1f, (q31_t)0x5e9c535e, (q31_t)0x5e8b63f7, (q31_t)0x5e7a70ea, + (q31_t)0x5e697a39, (q31_t)0x5e587fe5, + (q31_t)0x5e4781ed, (q31_t)0x5e368053, (q31_t)0x5e257b17, (q31_t)0x5e147239, (q31_t)0x5e0365bb, (q31_t)0x5df2559e, + (q31_t)0x5de141e1, (q31_t)0x5dd02a85, + (q31_t)0x5dbf0f8c, (q31_t)0x5dadf0f5, (q31_t)0x5d9ccec2, (q31_t)0x5d8ba8f3, (q31_t)0x5d7a7f88, (q31_t)0x5d695283, + (q31_t)0x5d5821e4, (q31_t)0x5d46edac, + (q31_t)0x5d35b5db, (q31_t)0x5d247a72, (q31_t)0x5d133b72, (q31_t)0x5d01f8dc, (q31_t)0x5cf0b2af, (q31_t)0x5cdf68ed, + (q31_t)0x5cce1b97, (q31_t)0x5cbccaac, + (q31_t)0x5cab762f, (q31_t)0x5c9a1e1e, (q31_t)0x5c88c27c, (q31_t)0x5c776348, (q31_t)0x5c660084, (q31_t)0x5c549a30, + (q31_t)0x5c43304d, (q31_t)0x5c31c2db, + (q31_t)0x5c2051db, (q31_t)0x5c0edd4e, (q31_t)0x5bfd6534, (q31_t)0x5bebe98e, (q31_t)0x5bda6a5d, (q31_t)0x5bc8e7a2, + (q31_t)0x5bb7615d, (q31_t)0x5ba5d78e, + (q31_t)0x5b944a37, (q31_t)0x5b82b958, (q31_t)0x5b7124f2, (q31_t)0x5b5f8d06, (q31_t)0x5b4df193, (q31_t)0x5b3c529c, + (q31_t)0x5b2ab020, (q31_t)0x5b190a20, + (q31_t)0x5b07609d, (q31_t)0x5af5b398, (q31_t)0x5ae40311, (q31_t)0x5ad24f09, (q31_t)0x5ac09781, (q31_t)0x5aaedc78, + (q31_t)0x5a9d1df1, (q31_t)0x5a8b5bec, + (q31_t)0x5a799669, (q31_t)0x5a67cd69, (q31_t)0x5a5600ec, (q31_t)0x5a4430f5, (q31_t)0x5a325d82, (q31_t)0x5a208695, + (q31_t)0x5a0eac2e, (q31_t)0x59fcce4f, + (q31_t)0x59eaecf8, (q31_t)0x59d90829, (q31_t)0x59c71fe3, (q31_t)0x59b53427, (q31_t)0x59a344f6, (q31_t)0x59915250, + (q31_t)0x597f5c36, (q31_t)0x596d62a9, + (q31_t)0x595b65aa, (q31_t)0x59496538, (q31_t)0x59376155, (q31_t)0x59255a02, (q31_t)0x59134f3e, (q31_t)0x5901410c, + (q31_t)0x58ef2f6b, (q31_t)0x58dd1a5d, + (q31_t)0x58cb01e1, (q31_t)0x58b8e5f9, (q31_t)0x58a6c6a5, (q31_t)0x5894a3e7, (q31_t)0x58827dbe, (q31_t)0x5870542c, + (q31_t)0x585e2730, (q31_t)0x584bf6cd, + (q31_t)0x5839c302, (q31_t)0x58278bd1, (q31_t)0x58155139, (q31_t)0x5803133c, (q31_t)0x57f0d1da, (q31_t)0x57de8d15, + (q31_t)0x57cc44ec, (q31_t)0x57b9f960, + (q31_t)0x57a7aa73, (q31_t)0x57955825, (q31_t)0x57830276, (q31_t)0x5770a968, (q31_t)0x575e4cfa, (q31_t)0x574bed2f, + (q31_t)0x57398a05, (q31_t)0x5727237f, + (q31_t)0x5714b99d, (q31_t)0x57024c5f, (q31_t)0x56efdbc7, (q31_t)0x56dd67d4, (q31_t)0x56caf088, (q31_t)0x56b875e4, + (q31_t)0x56a5f7e7, (q31_t)0x56937694, + (q31_t)0x5680f1ea, (q31_t)0x566e69ea, (q31_t)0x565bde95, (q31_t)0x56494fec, (q31_t)0x5636bdef, (q31_t)0x5624289f, + (q31_t)0x56118ffe, (q31_t)0x55fef40a, + (q31_t)0x55ec54c6, (q31_t)0x55d9b232, (q31_t)0x55c70c4f, (q31_t)0x55b4631d, (q31_t)0x55a1b69d, (q31_t)0x558f06d0, + (q31_t)0x557c53b6, (q31_t)0x55699d51, + (q31_t)0x5556e3a1, (q31_t)0x554426a7, (q31_t)0x55316663, (q31_t)0x551ea2d6, (q31_t)0x550bdc01, (q31_t)0x54f911e5, + (q31_t)0x54e64482, (q31_t)0x54d373d9, + (q31_t)0x54c09feb, (q31_t)0x54adc8b8, (q31_t)0x549aee42, (q31_t)0x54881089, (q31_t)0x54752f8d, (q31_t)0x54624b50, + (q31_t)0x544f63d2, (q31_t)0x543c7914, + (q31_t)0x54298b17, (q31_t)0x541699db, (q31_t)0x5403a561, (q31_t)0x53f0adaa, (q31_t)0x53ddb2b6, (q31_t)0x53cab486, + (q31_t)0x53b7b31c, (q31_t)0x53a4ae77, + (q31_t)0x5391a699, (q31_t)0x537e9b82, (q31_t)0x536b8d33, (q31_t)0x53587bad, (q31_t)0x534566f0, (q31_t)0x53324efd, + (q31_t)0x531f33d5, (q31_t)0x530c1579, + (q31_t)0x52f8f3e9, (q31_t)0x52e5cf27, (q31_t)0x52d2a732, (q31_t)0x52bf7c0b, (q31_t)0x52ac4db4, (q31_t)0x52991c2d, + (q31_t)0x5285e777, (q31_t)0x5272af92, + (q31_t)0x525f7480, (q31_t)0x524c3640, (q31_t)0x5238f4d4, (q31_t)0x5225b03d, (q31_t)0x5212687b, (q31_t)0x51ff1d8f, + (q31_t)0x51ebcf7a, (q31_t)0x51d87e3c, + (q31_t)0x51c529d7, (q31_t)0x51b1d24a, (q31_t)0x519e7797, (q31_t)0x518b19bf, (q31_t)0x5177b8c2, (q31_t)0x516454a0, + (q31_t)0x5150ed5c, (q31_t)0x513d82f4, + (q31_t)0x512a156b, (q31_t)0x5116a4c1, (q31_t)0x510330f7, (q31_t)0x50efba0d, (q31_t)0x50dc4005, (q31_t)0x50c8c2de, + (q31_t)0x50b5429a, (q31_t)0x50a1bf39, + (q31_t)0x508e38bd, (q31_t)0x507aaf25, (q31_t)0x50672273, (q31_t)0x505392a8, (q31_t)0x503fffc4, (q31_t)0x502c69c8, + (q31_t)0x5018d0b4, (q31_t)0x5005348a, + (q31_t)0x4ff1954b, (q31_t)0x4fddf2f6, (q31_t)0x4fca4d8d, (q31_t)0x4fb6a510, (q31_t)0x4fa2f981, (q31_t)0x4f8f4ae0, + (q31_t)0x4f7b992d, (q31_t)0x4f67e46a, + (q31_t)0x4f542c98, (q31_t)0x4f4071b6, (q31_t)0x4f2cb3c7, (q31_t)0x4f18f2c9, (q31_t)0x4f052ec0, (q31_t)0x4ef167aa, + (q31_t)0x4edd9d89, (q31_t)0x4ec9d05e, + (q31_t)0x4eb60029, (q31_t)0x4ea22ceb, (q31_t)0x4e8e56a5, (q31_t)0x4e7a7d58, (q31_t)0x4e66a105, (q31_t)0x4e52c1ab, + (q31_t)0x4e3edf4d, (q31_t)0x4e2af9ea, + (q31_t)0x4e171184, (q31_t)0x4e03261b, (q31_t)0x4def37b0, (q31_t)0x4ddb4644, (q31_t)0x4dc751d8, (q31_t)0x4db35a6c, + (q31_t)0x4d9f6001, (q31_t)0x4d8b6298, + (q31_t)0x4d776231, (q31_t)0x4d635ece, (q31_t)0x4d4f5870, (q31_t)0x4d3b4f16, (q31_t)0x4d2742c2, (q31_t)0x4d133374, + (q31_t)0x4cff212e, (q31_t)0x4ceb0bf0, + (q31_t)0x4cd6f3bb, (q31_t)0x4cc2d88f, (q31_t)0x4caeba6e, (q31_t)0x4c9a9958, (q31_t)0x4c86754e, (q31_t)0x4c724e50, + (q31_t)0x4c5e2460, (q31_t)0x4c49f77f, + (q31_t)0x4c35c7ac, (q31_t)0x4c2194e9, (q31_t)0x4c0d5f37, (q31_t)0x4bf92697, (q31_t)0x4be4eb08, (q31_t)0x4bd0ac8d, + (q31_t)0x4bbc6b25, (q31_t)0x4ba826d1, + (q31_t)0x4b93df93, (q31_t)0x4b7f956b, (q31_t)0x4b6b485a, (q31_t)0x4b56f861, (q31_t)0x4b42a580, (q31_t)0x4b2e4fb8, + (q31_t)0x4b19f70a, (q31_t)0x4b059b77, + (q31_t)0x4af13d00, (q31_t)0x4adcdba5, (q31_t)0x4ac87767, (q31_t)0x4ab41046, (q31_t)0x4a9fa645, (q31_t)0x4a8b3963, + (q31_t)0x4a76c9a2, (q31_t)0x4a625701, + (q31_t)0x4a4de182, (q31_t)0x4a396926, (q31_t)0x4a24edee, (q31_t)0x4a106fda, (q31_t)0x49fbeeea, (q31_t)0x49e76b21, + (q31_t)0x49d2e47e, (q31_t)0x49be5b02, + (q31_t)0x49a9ceaf, (q31_t)0x49953f84, (q31_t)0x4980ad84, (q31_t)0x496c18ae, (q31_t)0x49578103, (q31_t)0x4942e684, + (q31_t)0x492e4933, (q31_t)0x4919a90f, + (q31_t)0x4905061a, (q31_t)0x48f06054, (q31_t)0x48dbb7be, (q31_t)0x48c70c59, (q31_t)0x48b25e25, (q31_t)0x489dad25, + (q31_t)0x4888f957, (q31_t)0x487442be, + (q31_t)0x485f8959, (q31_t)0x484acd2a, (q31_t)0x48360e32, (q31_t)0x48214c71, (q31_t)0x480c87e8, (q31_t)0x47f7c099, + (q31_t)0x47e2f682, (q31_t)0x47ce29a7, + (q31_t)0x47b95a06, (q31_t)0x47a487a2, (q31_t)0x478fb27b, (q31_t)0x477ada91, (q31_t)0x4765ffe6, (q31_t)0x4751227a, + (q31_t)0x473c424e, (q31_t)0x47275f63, + (q31_t)0x471279ba, (q31_t)0x46fd9154, (q31_t)0x46e8a631, (q31_t)0x46d3b852, (q31_t)0x46bec7b8, (q31_t)0x46a9d464, + (q31_t)0x4694de56, (q31_t)0x467fe590, + (q31_t)0x466aea12, (q31_t)0x4655ebdd, (q31_t)0x4640eaf2, (q31_t)0x462be751, (q31_t)0x4616e0fc, (q31_t)0x4601d7f3, + (q31_t)0x45eccc37, (q31_t)0x45d7bdc9, + (q31_t)0x45c2acaa, (q31_t)0x45ad98da, (q31_t)0x4598825a, (q31_t)0x4583692c, (q31_t)0x456e4d4f, (q31_t)0x45592ec6, + (q31_t)0x45440d90, (q31_t)0x452ee9ae, + (q31_t)0x4519c321, (q31_t)0x450499eb, (q31_t)0x44ef6e0b, (q31_t)0x44da3f83, (q31_t)0x44c50e53, (q31_t)0x44afda7d, + (q31_t)0x449aa400, (q31_t)0x44856adf, + (q31_t)0x44702f19, (q31_t)0x445af0b0, (q31_t)0x4445afa4, (q31_t)0x44306bf6, (q31_t)0x441b25a8, (q31_t)0x4405dcb9, + (q31_t)0x43f0912b, (q31_t)0x43db42fe, + (q31_t)0x43c5f234, (q31_t)0x43b09ecc, (q31_t)0x439b48c9, (q31_t)0x4385f02a, (q31_t)0x437094f1, (q31_t)0x435b371f, + (q31_t)0x4345d6b3, (q31_t)0x433073b0, + (q31_t)0x431b0e15, (q31_t)0x4305a5e5, (q31_t)0x42f03b1e, (q31_t)0x42dacdc3, (q31_t)0x42c55dd4, (q31_t)0x42afeb53, + (q31_t)0x429a763f, (q31_t)0x4284fe99, + (q31_t)0x426f8463, (q31_t)0x425a079e, (q31_t)0x42448849, (q31_t)0x422f0667, (q31_t)0x421981f7, (q31_t)0x4203fafb, + (q31_t)0x41ee7174, (q31_t)0x41d8e561, + (q31_t)0x41c356c5, (q31_t)0x41adc5a0, (q31_t)0x419831f3, (q31_t)0x41829bbe, (q31_t)0x416d0302, (q31_t)0x415767c1, + (q31_t)0x4141c9fb, (q31_t)0x412c29b1, + (q31_t)0x411686e4, (q31_t)0x4100e194, (q31_t)0x40eb39c3, (q31_t)0x40d58f71, (q31_t)0x40bfe29f, (q31_t)0x40aa334e, + (q31_t)0x4094817f, (q31_t)0x407ecd32, + (q31_t)0x40691669, (q31_t)0x40535d24, (q31_t)0x403da165, (q31_t)0x4027e32b, (q31_t)0x40122278, (q31_t)0x3ffc5f4d, + (q31_t)0x3fe699aa, (q31_t)0x3fd0d191, + (q31_t)0x3fbb0702, (q31_t)0x3fa539fd, (q31_t)0x3f8f6a85, (q31_t)0x3f799899, (q31_t)0x3f63c43b, (q31_t)0x3f4ded6b, + (q31_t)0x3f38142a, (q31_t)0x3f22387a, + (q31_t)0x3f0c5a5a, (q31_t)0x3ef679cc, (q31_t)0x3ee096d1, (q31_t)0x3ecab169, (q31_t)0x3eb4c995, (q31_t)0x3e9edf57, + (q31_t)0x3e88f2ae, (q31_t)0x3e73039d, + (q31_t)0x3e5d1222, (q31_t)0x3e471e41, (q31_t)0x3e3127f9, (q31_t)0x3e1b2f4a, (q31_t)0x3e053437, (q31_t)0x3def36c0, + (q31_t)0x3dd936e6, (q31_t)0x3dc334a9, + (q31_t)0x3dad300b, (q31_t)0x3d97290b, (q31_t)0x3d811fac, (q31_t)0x3d6b13ee, (q31_t)0x3d5505d2, (q31_t)0x3d3ef559, + (q31_t)0x3d28e282, (q31_t)0x3d12cd51, + (q31_t)0x3cfcb5c4, (q31_t)0x3ce69bde, (q31_t)0x3cd07f9f, (q31_t)0x3cba6107, (q31_t)0x3ca44018, (q31_t)0x3c8e1cd3, + (q31_t)0x3c77f737, (q31_t)0x3c61cf48, + (q31_t)0x3c4ba504, (q31_t)0x3c35786d, (q31_t)0x3c1f4983, (q31_t)0x3c091849, (q31_t)0x3bf2e4be, (q31_t)0x3bdcaee3, + (q31_t)0x3bc676b9, (q31_t)0x3bb03c42, + (q31_t)0x3b99ff7d, (q31_t)0x3b83c06c, (q31_t)0x3b6d7f10, (q31_t)0x3b573b69, (q31_t)0x3b40f579, (q31_t)0x3b2aad3f, + (q31_t)0x3b1462be, (q31_t)0x3afe15f6, + (q31_t)0x3ae7c6e7, (q31_t)0x3ad17593, (q31_t)0x3abb21fb, (q31_t)0x3aa4cc1e, (q31_t)0x3a8e7400, (q31_t)0x3a78199f, + (q31_t)0x3a61bcfd, (q31_t)0x3a4b5e1b, + (q31_t)0x3a34fcf9, (q31_t)0x3a1e9999, (q31_t)0x3a0833fc, (q31_t)0x39f1cc21, (q31_t)0x39db620b, (q31_t)0x39c4f5ba, + (q31_t)0x39ae872f, (q31_t)0x3998166a, + (q31_t)0x3981a36d, (q31_t)0x396b2e38, (q31_t)0x3954b6cd, (q31_t)0x393e3d2c, (q31_t)0x3927c155, (q31_t)0x3911434b, + (q31_t)0x38fac30e, (q31_t)0x38e4409e, + (q31_t)0x38cdbbfc, (q31_t)0x38b7352a, (q31_t)0x38a0ac29, (q31_t)0x388a20f8, (q31_t)0x38739399, (q31_t)0x385d040d, + (q31_t)0x38467255, (q31_t)0x382fde72, + (q31_t)0x38194864, (q31_t)0x3802b02c, (q31_t)0x37ec15cb, (q31_t)0x37d57943, (q31_t)0x37beda93, (q31_t)0x37a839be, + (q31_t)0x379196c3, (q31_t)0x377af1a3, + (q31_t)0x37644a60, (q31_t)0x374da0fa, (q31_t)0x3736f573, (q31_t)0x372047ca, (q31_t)0x37099802, (q31_t)0x36f2e61a, + (q31_t)0x36dc3214, (q31_t)0x36c57bf0, + (q31_t)0x36aec3b0, (q31_t)0x36980954, (q31_t)0x36814cde, (q31_t)0x366a8e4d, (q31_t)0x3653cda3, (q31_t)0x363d0ae2, + (q31_t)0x36264609, (q31_t)0x360f7f19, + (q31_t)0x35f8b614, (q31_t)0x35e1eafa, (q31_t)0x35cb1dcc, (q31_t)0x35b44e8c, (q31_t)0x359d7d39, (q31_t)0x3586a9d5, + (q31_t)0x356fd461, (q31_t)0x3558fcde, + (q31_t)0x3542234c, (q31_t)0x352b47ad, (q31_t)0x35146a00, (q31_t)0x34fd8a48, (q31_t)0x34e6a885, (q31_t)0x34cfc4b7, + (q31_t)0x34b8dee1, (q31_t)0x34a1f702, + (q31_t)0x348b0d1c, (q31_t)0x3474212f, (q31_t)0x345d333c, (q31_t)0x34464345, (q31_t)0x342f5149, (q31_t)0x34185d4b, + (q31_t)0x3401674a, (q31_t)0x33ea6f48, + (q31_t)0x33d37546, (q31_t)0x33bc7944, (q31_t)0x33a57b44, (q31_t)0x338e7b46, (q31_t)0x3377794b, (q31_t)0x33607554, + (q31_t)0x33496f62, (q31_t)0x33326776, + (q31_t)0x331b5d91, (q31_t)0x330451b3, (q31_t)0x32ed43de, (q31_t)0x32d63412, (q31_t)0x32bf2250, (q31_t)0x32a80e99, + (q31_t)0x3290f8ef, (q31_t)0x3279e151, + (q31_t)0x3262c7c1, (q31_t)0x324bac40, (q31_t)0x32348ecf, (q31_t)0x321d6f6e, (q31_t)0x32064e1e, (q31_t)0x31ef2ae1, + (q31_t)0x31d805b7, (q31_t)0x31c0dea1, + (q31_t)0x31a9b5a0, (q31_t)0x31928ab4, (q31_t)0x317b5de0, (q31_t)0x31642f23, (q31_t)0x314cfe7f, (q31_t)0x3135cbf4, + (q31_t)0x311e9783, (q31_t)0x3107612e, + (q31_t)0x30f028f4, (q31_t)0x30d8eed8, (q31_t)0x30c1b2da, (q31_t)0x30aa74fa, (q31_t)0x3093353a, (q31_t)0x307bf39b, + (q31_t)0x3064b01d, (q31_t)0x304d6ac1, + (q31_t)0x30362389, (q31_t)0x301eda75, (q31_t)0x30078f86, (q31_t)0x2ff042bd, (q31_t)0x2fd8f41b, (q31_t)0x2fc1a3a0, + (q31_t)0x2faa514f, (q31_t)0x2f92fd26, + (q31_t)0x2f7ba729, (q31_t)0x2f644f56, (q31_t)0x2f4cf5b0, (q31_t)0x2f359a37, (q31_t)0x2f1e3ced, (q31_t)0x2f06ddd1, + (q31_t)0x2eef7ce5, (q31_t)0x2ed81a29, + (q31_t)0x2ec0b5a0, (q31_t)0x2ea94f49, (q31_t)0x2e91e725, (q31_t)0x2e7a7d36, (q31_t)0x2e63117c, (q31_t)0x2e4ba3f8, + (q31_t)0x2e3434ac, (q31_t)0x2e1cc397, + (q31_t)0x2e0550bb, (q31_t)0x2deddc19, (q31_t)0x2dd665b2, (q31_t)0x2dbeed86, (q31_t)0x2da77397, (q31_t)0x2d8ff7e5, + (q31_t)0x2d787a72, (q31_t)0x2d60fb3e, + (q31_t)0x2d497a4a, (q31_t)0x2d31f797, (q31_t)0x2d1a7325, (q31_t)0x2d02ecf7, (q31_t)0x2ceb650d, (q31_t)0x2cd3db67, + (q31_t)0x2cbc5006, (q31_t)0x2ca4c2ed, + (q31_t)0x2c8d341a, (q31_t)0x2c75a390, (q31_t)0x2c5e114f, (q31_t)0x2c467d58, (q31_t)0x2c2ee7ad, (q31_t)0x2c17504d, + (q31_t)0x2bffb73a, (q31_t)0x2be81c74, + (q31_t)0x2bd07ffe, (q31_t)0x2bb8e1d7, (q31_t)0x2ba14200, (q31_t)0x2b89a07b, (q31_t)0x2b71fd48, (q31_t)0x2b5a5868, + (q31_t)0x2b42b1dd, (q31_t)0x2b2b09a6, + (q31_t)0x2b135fc6, (q31_t)0x2afbb43c, (q31_t)0x2ae4070a, (q31_t)0x2acc5831, (q31_t)0x2ab4a7b1, (q31_t)0x2a9cf58c, + (q31_t)0x2a8541c3, (q31_t)0x2a6d8c55, + (q31_t)0x2a55d545, (q31_t)0x2a3e1c93, (q31_t)0x2a266240, (q31_t)0x2a0ea64d, (q31_t)0x29f6e8bb, (q31_t)0x29df298b, + (q31_t)0x29c768be, (q31_t)0x29afa654, + (q31_t)0x2997e24f, (q31_t)0x29801caf, (q31_t)0x29685576, (q31_t)0x29508ca4, (q31_t)0x2938c23a, (q31_t)0x2920f63a, + (q31_t)0x290928a3, (q31_t)0x28f15978, + (q31_t)0x28d988b8, (q31_t)0x28c1b666, (q31_t)0x28a9e281, (q31_t)0x28920d0a, (q31_t)0x287a3604, (q31_t)0x28625d6d, + (q31_t)0x284a8349, (q31_t)0x2832a796, + (q31_t)0x281aca57, (q31_t)0x2802eb8c, (q31_t)0x27eb0b36, (q31_t)0x27d32956, (q31_t)0x27bb45ed, (q31_t)0x27a360fc, + (q31_t)0x278b7a84, (q31_t)0x27739285, + (q31_t)0x275ba901, (q31_t)0x2743bdf9, (q31_t)0x272bd16d, (q31_t)0x2713e35f, (q31_t)0x26fbf3ce, (q31_t)0x26e402bd, + (q31_t)0x26cc102d, (q31_t)0x26b41c1d, + (q31_t)0x269c268f, (q31_t)0x26842f84, (q31_t)0x266c36fe, (q31_t)0x26543cfb, (q31_t)0x263c417f, (q31_t)0x26244489, + (q31_t)0x260c461b, (q31_t)0x25f44635, + (q31_t)0x25dc44d9, (q31_t)0x25c44207, (q31_t)0x25ac3dc0, (q31_t)0x25943806, (q31_t)0x257c30d8, (q31_t)0x25642839, + (q31_t)0x254c1e28, (q31_t)0x253412a8, + (q31_t)0x251c05b8, (q31_t)0x2503f75a, (q31_t)0x24ebe78f, (q31_t)0x24d3d657, (q31_t)0x24bbc3b4, (q31_t)0x24a3afa6, + (q31_t)0x248b9a2f, (q31_t)0x2473834f, + (q31_t)0x245b6b07, (q31_t)0x24435158, (q31_t)0x242b3644, (q31_t)0x241319ca, (q31_t)0x23fafbec, (q31_t)0x23e2dcac, + (q31_t)0x23cabc09, (q31_t)0x23b29a05, + (q31_t)0x239a76a0, (q31_t)0x238251dd, (q31_t)0x236a2bba, (q31_t)0x2352043b, (q31_t)0x2339db5e, (q31_t)0x2321b126, + (q31_t)0x23098593, (q31_t)0x22f158a7, + (q31_t)0x22d92a61, (q31_t)0x22c0fac4, (q31_t)0x22a8c9cf, (q31_t)0x22909785, (q31_t)0x227863e5, (q31_t)0x22602ef1, + (q31_t)0x2247f8aa, (q31_t)0x222fc111, + (q31_t)0x22178826, (q31_t)0x21ff4dea, (q31_t)0x21e71260, (q31_t)0x21ced586, (q31_t)0x21b6975f, (q31_t)0x219e57eb, + (q31_t)0x2186172b, (q31_t)0x216dd521, + (q31_t)0x215591cc, (q31_t)0x213d4d2f, (q31_t)0x21250749, (q31_t)0x210cc01d, (q31_t)0x20f477aa, (q31_t)0x20dc2df2, + (q31_t)0x20c3e2f5, (q31_t)0x20ab96b5, + (q31_t)0x20934933, (q31_t)0x207afa6f, (q31_t)0x2062aa6b, (q31_t)0x204a5927, (q31_t)0x203206a4, (q31_t)0x2019b2e4, + (q31_t)0x20015de7, (q31_t)0x1fe907ae, + (q31_t)0x1fd0b03a, (q31_t)0x1fb8578b, (q31_t)0x1f9ffda4, (q31_t)0x1f87a285, (q31_t)0x1f6f462f, (q31_t)0x1f56e8a2, + (q31_t)0x1f3e89e0, (q31_t)0x1f2629ea, + (q31_t)0x1f0dc8c0, (q31_t)0x1ef56664, (q31_t)0x1edd02d6, (q31_t)0x1ec49e17, (q31_t)0x1eac3829, (q31_t)0x1e93d10c, + (q31_t)0x1e7b68c2, (q31_t)0x1e62ff4a, + (q31_t)0x1e4a94a7, (q31_t)0x1e3228d9, (q31_t)0x1e19bbe0, (q31_t)0x1e014dbf, (q31_t)0x1de8de75, (q31_t)0x1dd06e04, + (q31_t)0x1db7fc6d, (q31_t)0x1d9f89b1, + (q31_t)0x1d8715d0, (q31_t)0x1d6ea0cc, (q31_t)0x1d562aa6, (q31_t)0x1d3db35e, (q31_t)0x1d253af5, (q31_t)0x1d0cc16c, + (q31_t)0x1cf446c5, (q31_t)0x1cdbcb00, + (q31_t)0x1cc34e1f, (q31_t)0x1caad021, (q31_t)0x1c925109, (q31_t)0x1c79d0d6, (q31_t)0x1c614f8b, (q31_t)0x1c48cd27, + (q31_t)0x1c3049ac, (q31_t)0x1c17c51b, + (q31_t)0x1bff3f75, (q31_t)0x1be6b8ba, (q31_t)0x1bce30ec, (q31_t)0x1bb5a80c, (q31_t)0x1b9d1e1a, (q31_t)0x1b849317, + (q31_t)0x1b6c0705, (q31_t)0x1b5379e5, + (q31_t)0x1b3aebb6, (q31_t)0x1b225c7b, (q31_t)0x1b09cc34, (q31_t)0x1af13ae3, (q31_t)0x1ad8a887, (q31_t)0x1ac01522, + (q31_t)0x1aa780b6, (q31_t)0x1a8eeb42, + (q31_t)0x1a7654c8, (q31_t)0x1a5dbd49, (q31_t)0x1a4524c6, (q31_t)0x1a2c8b3f, (q31_t)0x1a13f0b6, (q31_t)0x19fb552c, + (q31_t)0x19e2b8a2, (q31_t)0x19ca1b17, + (q31_t)0x19b17c8f, (q31_t)0x1998dd09, (q31_t)0x19803c86, (q31_t)0x19679b07, (q31_t)0x194ef88e, (q31_t)0x1936551b, + (q31_t)0x191db0af, (q31_t)0x19050b4b, + (q31_t)0x18ec64f0, (q31_t)0x18d3bda0, (q31_t)0x18bb155a, (q31_t)0x18a26c20, (q31_t)0x1889c1f3, (q31_t)0x187116d4, + (q31_t)0x18586ac3, (q31_t)0x183fbdc3, + (q31_t)0x18270fd3, (q31_t)0x180e60f4, (q31_t)0x17f5b129, (q31_t)0x17dd0070, (q31_t)0x17c44ecd, (q31_t)0x17ab9c3e, + (q31_t)0x1792e8c6, (q31_t)0x177a3466, + (q31_t)0x17617f1d, (q31_t)0x1748c8ee, (q31_t)0x173011d9, (q31_t)0x171759df, (q31_t)0x16fea102, (q31_t)0x16e5e741, + (q31_t)0x16cd2c9f, (q31_t)0x16b4711b, + (q31_t)0x169bb4b7, (q31_t)0x1682f774, (q31_t)0x166a3953, (q31_t)0x16517a55, (q31_t)0x1638ba7a, (q31_t)0x161ff9c4, + (q31_t)0x16073834, (q31_t)0x15ee75cb, + (q31_t)0x15d5b288, (q31_t)0x15bcee6f, (q31_t)0x15a4297f, (q31_t)0x158b63b9, (q31_t)0x15729d1f, (q31_t)0x1559d5b1, + (q31_t)0x15410d70, (q31_t)0x1528445d, + (q31_t)0x150f7a7a, (q31_t)0x14f6afc7, (q31_t)0x14dde445, (q31_t)0x14c517f4, (q31_t)0x14ac4ad7, (q31_t)0x14937cee, + (q31_t)0x147aae3a, (q31_t)0x1461debc, + (q31_t)0x14490e74, (q31_t)0x14303d65, (q31_t)0x14176b8e, (q31_t)0x13fe98f1, (q31_t)0x13e5c58e, (q31_t)0x13ccf167, + (q31_t)0x13b41c7d, (q31_t)0x139b46d0, + (q31_t)0x13827062, (q31_t)0x13699933, (q31_t)0x1350c144, (q31_t)0x1337e897, (q31_t)0x131f0f2c, (q31_t)0x13063505, + (q31_t)0x12ed5a21, (q31_t)0x12d47e83, + (q31_t)0x12bba22b, (q31_t)0x12a2c51b, (q31_t)0x1289e752, (q31_t)0x127108d2, (q31_t)0x1258299c, (q31_t)0x123f49b2, + (q31_t)0x12266913, (q31_t)0x120d87c1, + (q31_t)0x11f4a5bd, (q31_t)0x11dbc307, (q31_t)0x11c2dfa2, (q31_t)0x11a9fb8d, (q31_t)0x119116c9, (q31_t)0x11783159, + (q31_t)0x115f4b3c, (q31_t)0x11466473, + (q31_t)0x112d7d00, (q31_t)0x111494e4, (q31_t)0x10fbac1e, (q31_t)0x10e2c2b2, (q31_t)0x10c9d89e, (q31_t)0x10b0ede5, + (q31_t)0x10980287, (q31_t)0x107f1686, + (q31_t)0x106629e1, (q31_t)0x104d3c9b, (q31_t)0x10344eb4, (q31_t)0x101b602d, (q31_t)0x10027107, (q31_t)0xfe98143, + (q31_t)0xfd090e1, (q31_t)0xfb79fe4, + (q31_t)0xf9eae4c, (q31_t)0xf85bc19, (q31_t)0xf6cc94e, (q31_t)0xf53d5ea, (q31_t)0xf3ae1ee, (q31_t)0xf21ed5d, (q31_t)0xf08f836, + (q31_t)0xef0027b, + (q31_t)0xed70c2c, (q31_t)0xebe154b, (q31_t)0xea51dd8, (q31_t)0xe8c25d5, (q31_t)0xe732d42, (q31_t)0xe5a3421, (q31_t)0xe413a72, + (q31_t)0xe284036, + (q31_t)0xe0f456f, (q31_t)0xdf64a1c, (q31_t)0xddd4e40, (q31_t)0xdc451dc, (q31_t)0xdab54ef, (q31_t)0xd92577b, (q31_t)0xd795982, + (q31_t)0xd605b03, + (q31_t)0xd475c00, (q31_t)0xd2e5c7b, (q31_t)0xd155c73, (q31_t)0xcfc5bea, (q31_t)0xce35ae1, (q31_t)0xcca5959, (q31_t)0xcb15752, + (q31_t)0xc9854cf, + (q31_t)0xc7f51cf, (q31_t)0xc664e53, (q31_t)0xc4d4a5d, (q31_t)0xc3445ee, (q31_t)0xc1b4107, (q31_t)0xc023ba7, (q31_t)0xbe935d2, + (q31_t)0xbd02f87, + (q31_t)0xbb728c7, (q31_t)0xb9e2193, (q31_t)0xb8519ed, (q31_t)0xb6c11d5, (q31_t)0xb53094d, (q31_t)0xb3a0055, (q31_t)0xb20f6ee, + (q31_t)0xb07ed19, + (q31_t)0xaeee2d7, (q31_t)0xad5d829, (q31_t)0xabccd11, (q31_t)0xaa3c18e, (q31_t)0xa8ab5a2, (q31_t)0xa71a94f, (q31_t)0xa589c94, + (q31_t)0xa3f8f73, + (q31_t)0xa2681ed, (q31_t)0xa0d7403, (q31_t)0x9f465b5, (q31_t)0x9db5706, (q31_t)0x9c247f5, (q31_t)0x9a93884, (q31_t)0x99028b3, + (q31_t)0x9771884, + (q31_t)0x95e07f8, (q31_t)0x944f70f, (q31_t)0x92be5ca, (q31_t)0x912d42c, (q31_t)0x8f9c233, (q31_t)0x8e0afe2, (q31_t)0x8c79d3a, + (q31_t)0x8ae8a3a, + (q31_t)0x89576e5, (q31_t)0x87c633c, (q31_t)0x8634f3e, (q31_t)0x84a3aee, (q31_t)0x831264c, (q31_t)0x8181159, (q31_t)0x7fefc16, + (q31_t)0x7e5e685, + (q31_t)0x7ccd0a5, (q31_t)0x7b3ba78, (q31_t)0x79aa400, (q31_t)0x7818d3c, (q31_t)0x768762e, (q31_t)0x74f5ed7, (q31_t)0x7364738, + (q31_t)0x71d2f52, + (q31_t)0x7041726, (q31_t)0x6eafeb4, (q31_t)0x6d1e5fe, (q31_t)0x6b8cd05, (q31_t)0x69fb3c9, (q31_t)0x6869a4c, (q31_t)0x66d808f, + (q31_t)0x6546692, + (q31_t)0x63b4c57, (q31_t)0x62231de, (q31_t)0x6091729, (q31_t)0x5effc38, (q31_t)0x5d6e10c, (q31_t)0x5bdc5a7, (q31_t)0x5a4aa09, + (q31_t)0x58b8e34, + (q31_t)0x5727228, (q31_t)0x55955e6, (q31_t)0x540396f, (q31_t)0x5271cc4, (q31_t)0x50dffe7, (q31_t)0x4f4e2d8, (q31_t)0x4dbc597, + (q31_t)0x4c2a827, + (q31_t)0x4a98a88, (q31_t)0x4906cbb, (q31_t)0x4774ec1, (q31_t)0x45e309a, (q31_t)0x4451249, (q31_t)0x42bf3cd, (q31_t)0x412d528, + (q31_t)0x3f9b65b, + (q31_t)0x3e09767, (q31_t)0x3c7784d, (q31_t)0x3ae590d, (q31_t)0x39539a9, (q31_t)0x37c1a22, (q31_t)0x362fa78, (q31_t)0x349daac, + (q31_t)0x330bac1, + (q31_t)0x3179ab5, (q31_t)0x2fe7a8c, (q31_t)0x2e55a44, (q31_t)0x2cc39e1, (q31_t)0x2b31961, (q31_t)0x299f8c7, (q31_t)0x280d813, + (q31_t)0x267b747, + (q31_t)0x24e9662, (q31_t)0x2357567, (q31_t)0x21c5457, (q31_t)0x2033331, (q31_t)0x1ea11f7, (q31_t)0x1d0f0ab, (q31_t)0x1b7cf4d, + (q31_t)0x19eaddd, + (q31_t)0x1858c5e, (q31_t)0x16c6ad0, (q31_t)0x1534934, (q31_t)0x13a278a, (q31_t)0x12105d5, (q31_t)0x107e414, (q31_t)0xeec249, + (q31_t)0xd5a075, + (q31_t)0xbc7e99, (q31_t)0xa35cb5, (q31_t)0x8a3acb, (q31_t)0x7118dc, (q31_t)0x57f6e9, (q31_t)0x3ed4f2, (q31_t)0x25b2f8, + (q31_t)0xc90fe +}; + +static const q31_t cos_factorsQ31_8192[8192] = { + (q31_t)0x7ffffff6, (q31_t)0x7fffffa7, (q31_t)0x7fffff09, (q31_t)0x7ffffe1c, (q31_t)0x7ffffce1, (q31_t)0x7ffffb56, + (q31_t)0x7ffff97c, (q31_t)0x7ffff753, + (q31_t)0x7ffff4dc, (q31_t)0x7ffff215, (q31_t)0x7fffef00, (q31_t)0x7fffeb9b, (q31_t)0x7fffe7e8, (q31_t)0x7fffe3e5, + (q31_t)0x7fffdf94, (q31_t)0x7fffdaf3, + (q31_t)0x7fffd604, (q31_t)0x7fffd0c6, (q31_t)0x7fffcb39, (q31_t)0x7fffc55c, (q31_t)0x7fffbf31, (q31_t)0x7fffb8b7, + (q31_t)0x7fffb1ee, (q31_t)0x7fffaad6, + (q31_t)0x7fffa36f, (q31_t)0x7fff9bb9, (q31_t)0x7fff93b4, (q31_t)0x7fff8b61, (q31_t)0x7fff82be, (q31_t)0x7fff79cc, + (q31_t)0x7fff708b, (q31_t)0x7fff66fc, + (q31_t)0x7fff5d1d, (q31_t)0x7fff52ef, (q31_t)0x7fff4873, (q31_t)0x7fff3da8, (q31_t)0x7fff328d, (q31_t)0x7fff2724, + (q31_t)0x7fff1b6b, (q31_t)0x7fff0f64, + (q31_t)0x7fff030e, (q31_t)0x7ffef669, (q31_t)0x7ffee975, (q31_t)0x7ffedc31, (q31_t)0x7ffece9f, (q31_t)0x7ffec0be, + (q31_t)0x7ffeb28e, (q31_t)0x7ffea40f, + (q31_t)0x7ffe9542, (q31_t)0x7ffe8625, (q31_t)0x7ffe76b9, (q31_t)0x7ffe66fe, (q31_t)0x7ffe56f5, (q31_t)0x7ffe469c, + (q31_t)0x7ffe35f4, (q31_t)0x7ffe24fe, + (q31_t)0x7ffe13b8, (q31_t)0x7ffe0224, (q31_t)0x7ffdf040, (q31_t)0x7ffdde0e, (q31_t)0x7ffdcb8d, (q31_t)0x7ffdb8bc, + (q31_t)0x7ffda59d, (q31_t)0x7ffd922f, + (q31_t)0x7ffd7e72, (q31_t)0x7ffd6a66, (q31_t)0x7ffd560b, (q31_t)0x7ffd4161, (q31_t)0x7ffd2c68, (q31_t)0x7ffd1720, + (q31_t)0x7ffd0189, (q31_t)0x7ffceba4, + (q31_t)0x7ffcd56f, (q31_t)0x7ffcbeeb, (q31_t)0x7ffca819, (q31_t)0x7ffc90f7, (q31_t)0x7ffc7987, (q31_t)0x7ffc61c7, + (q31_t)0x7ffc49b9, (q31_t)0x7ffc315b, + (q31_t)0x7ffc18af, (q31_t)0x7ffbffb4, (q31_t)0x7ffbe66a, (q31_t)0x7ffbccd0, (q31_t)0x7ffbb2e8, (q31_t)0x7ffb98b1, + (q31_t)0x7ffb7e2b, (q31_t)0x7ffb6356, + (q31_t)0x7ffb4833, (q31_t)0x7ffb2cc0, (q31_t)0x7ffb10fe, (q31_t)0x7ffaf4ed, (q31_t)0x7ffad88e, (q31_t)0x7ffabbdf, + (q31_t)0x7ffa9ee2, (q31_t)0x7ffa8195, + (q31_t)0x7ffa63fa, (q31_t)0x7ffa460f, (q31_t)0x7ffa27d6, (q31_t)0x7ffa094e, (q31_t)0x7ff9ea76, (q31_t)0x7ff9cb50, + (q31_t)0x7ff9abdb, (q31_t)0x7ff98c17, + (q31_t)0x7ff96c04, (q31_t)0x7ff94ba2, (q31_t)0x7ff92af1, (q31_t)0x7ff909f2, (q31_t)0x7ff8e8a3, (q31_t)0x7ff8c705, + (q31_t)0x7ff8a519, (q31_t)0x7ff882dd, + (q31_t)0x7ff86053, (q31_t)0x7ff83d79, (q31_t)0x7ff81a51, (q31_t)0x7ff7f6da, (q31_t)0x7ff7d313, (q31_t)0x7ff7aefe, + (q31_t)0x7ff78a9a, (q31_t)0x7ff765e7, + (q31_t)0x7ff740e5, (q31_t)0x7ff71b94, (q31_t)0x7ff6f5f4, (q31_t)0x7ff6d005, (q31_t)0x7ff6a9c8, (q31_t)0x7ff6833b, + (q31_t)0x7ff65c5f, (q31_t)0x7ff63535, + (q31_t)0x7ff60dbb, (q31_t)0x7ff5e5f3, (q31_t)0x7ff5bddc, (q31_t)0x7ff59576, (q31_t)0x7ff56cc0, (q31_t)0x7ff543bc, + (q31_t)0x7ff51a69, (q31_t)0x7ff4f0c7, + (q31_t)0x7ff4c6d6, (q31_t)0x7ff49c96, (q31_t)0x7ff47208, (q31_t)0x7ff4472a, (q31_t)0x7ff41bfd, (q31_t)0x7ff3f082, + (q31_t)0x7ff3c4b7, (q31_t)0x7ff3989e, + (q31_t)0x7ff36c36, (q31_t)0x7ff33f7e, (q31_t)0x7ff31278, (q31_t)0x7ff2e523, (q31_t)0x7ff2b77f, (q31_t)0x7ff2898c, + (q31_t)0x7ff25b4a, (q31_t)0x7ff22cb9, + (q31_t)0x7ff1fdd9, (q31_t)0x7ff1ceab, (q31_t)0x7ff19f2d, (q31_t)0x7ff16f61, (q31_t)0x7ff13f45, (q31_t)0x7ff10edb, + (q31_t)0x7ff0de22, (q31_t)0x7ff0ad19, + (q31_t)0x7ff07bc2, (q31_t)0x7ff04a1c, (q31_t)0x7ff01827, (q31_t)0x7fefe5e4, (q31_t)0x7fefb351, (q31_t)0x7fef806f, + (q31_t)0x7fef4d3e, (q31_t)0x7fef19bf, + (q31_t)0x7feee5f0, (q31_t)0x7feeb1d3, (q31_t)0x7fee7d67, (q31_t)0x7fee48ac, (q31_t)0x7fee13a1, (q31_t)0x7fedde48, + (q31_t)0x7feda8a0, (q31_t)0x7fed72aa, + (q31_t)0x7fed3c64, (q31_t)0x7fed05cf, (q31_t)0x7fecceec, (q31_t)0x7fec97b9, (q31_t)0x7fec6038, (q31_t)0x7fec2867, + (q31_t)0x7febf048, (q31_t)0x7febb7da, + (q31_t)0x7feb7f1d, (q31_t)0x7feb4611, (q31_t)0x7feb0cb6, (q31_t)0x7fead30c, (q31_t)0x7fea9914, (q31_t)0x7fea5ecc, + (q31_t)0x7fea2436, (q31_t)0x7fe9e950, + (q31_t)0x7fe9ae1c, (q31_t)0x7fe97299, (q31_t)0x7fe936c7, (q31_t)0x7fe8faa6, (q31_t)0x7fe8be36, (q31_t)0x7fe88177, + (q31_t)0x7fe84469, (q31_t)0x7fe8070d, + (q31_t)0x7fe7c961, (q31_t)0x7fe78b67, (q31_t)0x7fe74d1e, (q31_t)0x7fe70e85, (q31_t)0x7fe6cf9e, (q31_t)0x7fe69068, + (q31_t)0x7fe650e3, (q31_t)0x7fe61110, + (q31_t)0x7fe5d0ed, (q31_t)0x7fe5907b, (q31_t)0x7fe54fbb, (q31_t)0x7fe50eac, (q31_t)0x7fe4cd4d, (q31_t)0x7fe48ba0, + (q31_t)0x7fe449a4, (q31_t)0x7fe40759, + (q31_t)0x7fe3c4bf, (q31_t)0x7fe381d7, (q31_t)0x7fe33e9f, (q31_t)0x7fe2fb19, (q31_t)0x7fe2b743, (q31_t)0x7fe2731f, + (q31_t)0x7fe22eac, (q31_t)0x7fe1e9ea, + (q31_t)0x7fe1a4d9, (q31_t)0x7fe15f79, (q31_t)0x7fe119cb, (q31_t)0x7fe0d3cd, (q31_t)0x7fe08d81, (q31_t)0x7fe046e5, + (q31_t)0x7fdffffb, (q31_t)0x7fdfb8c2, + (q31_t)0x7fdf713a, (q31_t)0x7fdf2963, (q31_t)0x7fdee13e, (q31_t)0x7fde98c9, (q31_t)0x7fde5006, (q31_t)0x7fde06f3, + (q31_t)0x7fddbd92, (q31_t)0x7fdd73e2, + (q31_t)0x7fdd29e3, (q31_t)0x7fdcdf95, (q31_t)0x7fdc94f9, (q31_t)0x7fdc4a0d, (q31_t)0x7fdbfed3, (q31_t)0x7fdbb349, + (q31_t)0x7fdb6771, (q31_t)0x7fdb1b4a, + (q31_t)0x7fdaced4, (q31_t)0x7fda820f, (q31_t)0x7fda34fc, (q31_t)0x7fd9e799, (q31_t)0x7fd999e8, (q31_t)0x7fd94be8, + (q31_t)0x7fd8fd98, (q31_t)0x7fd8aefa, + (q31_t)0x7fd8600e, (q31_t)0x7fd810d2, (q31_t)0x7fd7c147, (q31_t)0x7fd7716e, (q31_t)0x7fd72146, (q31_t)0x7fd6d0cf, + (q31_t)0x7fd68009, (q31_t)0x7fd62ef4, + (q31_t)0x7fd5dd90, (q31_t)0x7fd58bdd, (q31_t)0x7fd539dc, (q31_t)0x7fd4e78c, (q31_t)0x7fd494ed, (q31_t)0x7fd441ff, + (q31_t)0x7fd3eec2, (q31_t)0x7fd39b36, + (q31_t)0x7fd3475c, (q31_t)0x7fd2f332, (q31_t)0x7fd29eba, (q31_t)0x7fd249f3, (q31_t)0x7fd1f4dd, (q31_t)0x7fd19f78, + (q31_t)0x7fd149c5, (q31_t)0x7fd0f3c2, + (q31_t)0x7fd09d71, (q31_t)0x7fd046d1, (q31_t)0x7fcfefe2, (q31_t)0x7fcf98a4, (q31_t)0x7fcf4117, (q31_t)0x7fcee93c, + (q31_t)0x7fce9112, (q31_t)0x7fce3898, + (q31_t)0x7fcddfd0, (q31_t)0x7fcd86b9, (q31_t)0x7fcd2d54, (q31_t)0x7fccd39f, (q31_t)0x7fcc799c, (q31_t)0x7fcc1f4a, + (q31_t)0x7fcbc4a9, (q31_t)0x7fcb69b9, + (q31_t)0x7fcb0e7a, (q31_t)0x7fcab2ed, (q31_t)0x7fca5710, (q31_t)0x7fc9fae5, (q31_t)0x7fc99e6b, (q31_t)0x7fc941a2, + (q31_t)0x7fc8e48b, (q31_t)0x7fc88724, + (q31_t)0x7fc8296f, (q31_t)0x7fc7cb6b, (q31_t)0x7fc76d18, (q31_t)0x7fc70e76, (q31_t)0x7fc6af86, (q31_t)0x7fc65046, + (q31_t)0x7fc5f0b8, (q31_t)0x7fc590db, + (q31_t)0x7fc530af, (q31_t)0x7fc4d035, (q31_t)0x7fc46f6b, (q31_t)0x7fc40e53, (q31_t)0x7fc3acec, (q31_t)0x7fc34b36, + (q31_t)0x7fc2e931, (q31_t)0x7fc286de, + (q31_t)0x7fc2243b, (q31_t)0x7fc1c14a, (q31_t)0x7fc15e0a, (q31_t)0x7fc0fa7b, (q31_t)0x7fc0969e, (q31_t)0x7fc03271, + (q31_t)0x7fbfcdf6, (q31_t)0x7fbf692c, + (q31_t)0x7fbf0414, (q31_t)0x7fbe9eac, (q31_t)0x7fbe38f6, (q31_t)0x7fbdd2f0, (q31_t)0x7fbd6c9c, (q31_t)0x7fbd05fa, + (q31_t)0x7fbc9f08, (q31_t)0x7fbc37c8, + (q31_t)0x7fbbd039, (q31_t)0x7fbb685b, (q31_t)0x7fbb002e, (q31_t)0x7fba97b2, (q31_t)0x7fba2ee8, (q31_t)0x7fb9c5cf, + (q31_t)0x7fb95c67, (q31_t)0x7fb8f2b0, + (q31_t)0x7fb888ab, (q31_t)0x7fb81e57, (q31_t)0x7fb7b3b4, (q31_t)0x7fb748c2, (q31_t)0x7fb6dd81, (q31_t)0x7fb671f2, + (q31_t)0x7fb60614, (q31_t)0x7fb599e7, + (q31_t)0x7fb52d6b, (q31_t)0x7fb4c0a1, (q31_t)0x7fb45387, (q31_t)0x7fb3e61f, (q31_t)0x7fb37869, (q31_t)0x7fb30a63, + (q31_t)0x7fb29c0f, (q31_t)0x7fb22d6c, + (q31_t)0x7fb1be7a, (q31_t)0x7fb14f39, (q31_t)0x7fb0dfaa, (q31_t)0x7fb06fcb, (q31_t)0x7fafff9e, (q31_t)0x7faf8f23, + (q31_t)0x7faf1e58, (q31_t)0x7faead3f, + (q31_t)0x7fae3bd7, (q31_t)0x7fadca20, (q31_t)0x7fad581b, (q31_t)0x7face5c6, (q31_t)0x7fac7323, (q31_t)0x7fac0031, + (q31_t)0x7fab8cf1, (q31_t)0x7fab1962, + (q31_t)0x7faaa584, (q31_t)0x7faa3157, (q31_t)0x7fa9bcdb, (q31_t)0x7fa94811, (q31_t)0x7fa8d2f8, (q31_t)0x7fa85d90, + (q31_t)0x7fa7e7d9, (q31_t)0x7fa771d4, + (q31_t)0x7fa6fb80, (q31_t)0x7fa684dd, (q31_t)0x7fa60dec, (q31_t)0x7fa596ac, (q31_t)0x7fa51f1d, (q31_t)0x7fa4a73f, + (q31_t)0x7fa42f12, (q31_t)0x7fa3b697, + (q31_t)0x7fa33dcd, (q31_t)0x7fa2c4b5, (q31_t)0x7fa24b4d, (q31_t)0x7fa1d197, (q31_t)0x7fa15792, (q31_t)0x7fa0dd3f, + (q31_t)0x7fa0629c, (q31_t)0x7f9fe7ab, + (q31_t)0x7f9f6c6b, (q31_t)0x7f9ef0dd, (q31_t)0x7f9e7500, (q31_t)0x7f9df8d4, (q31_t)0x7f9d7c59, (q31_t)0x7f9cff90, + (q31_t)0x7f9c8278, (q31_t)0x7f9c0511, + (q31_t)0x7f9b875b, (q31_t)0x7f9b0957, (q31_t)0x7f9a8b04, (q31_t)0x7f9a0c62, (q31_t)0x7f998d72, (q31_t)0x7f990e33, + (q31_t)0x7f988ea5, (q31_t)0x7f980ec8, + (q31_t)0x7f978e9d, (q31_t)0x7f970e23, (q31_t)0x7f968d5b, (q31_t)0x7f960c43, (q31_t)0x7f958add, (q31_t)0x7f950929, + (q31_t)0x7f948725, (q31_t)0x7f9404d3, + (q31_t)0x7f938232, (q31_t)0x7f92ff43, (q31_t)0x7f927c04, (q31_t)0x7f91f878, (q31_t)0x7f91749c, (q31_t)0x7f90f072, + (q31_t)0x7f906bf9, (q31_t)0x7f8fe731, + (q31_t)0x7f8f621b, (q31_t)0x7f8edcb6, (q31_t)0x7f8e5702, (q31_t)0x7f8dd0ff, (q31_t)0x7f8d4aae, (q31_t)0x7f8cc40f, + (q31_t)0x7f8c3d20, (q31_t)0x7f8bb5e3, + (q31_t)0x7f8b2e57, (q31_t)0x7f8aa67d, (q31_t)0x7f8a1e54, (q31_t)0x7f8995dc, (q31_t)0x7f890d15, (q31_t)0x7f888400, + (q31_t)0x7f87fa9c, (q31_t)0x7f8770ea, + (q31_t)0x7f86e6e9, (q31_t)0x7f865c99, (q31_t)0x7f85d1fa, (q31_t)0x7f85470d, (q31_t)0x7f84bbd1, (q31_t)0x7f843047, + (q31_t)0x7f83a46e, (q31_t)0x7f831846, + (q31_t)0x7f828bcf, (q31_t)0x7f81ff0a, (q31_t)0x7f8171f6, (q31_t)0x7f80e494, (q31_t)0x7f8056e3, (q31_t)0x7f7fc8e3, + (q31_t)0x7f7f3a95, (q31_t)0x7f7eabf8, + (q31_t)0x7f7e1d0c, (q31_t)0x7f7d8dd2, (q31_t)0x7f7cfe49, (q31_t)0x7f7c6e71, (q31_t)0x7f7bde4b, (q31_t)0x7f7b4dd6, + (q31_t)0x7f7abd13, (q31_t)0x7f7a2c01, + (q31_t)0x7f799aa0, (q31_t)0x7f7908f0, (q31_t)0x7f7876f2, (q31_t)0x7f77e4a6, (q31_t)0x7f77520a, (q31_t)0x7f76bf21, + (q31_t)0x7f762be8, (q31_t)0x7f759861, + (q31_t)0x7f75048b, (q31_t)0x7f747067, (q31_t)0x7f73dbf4, (q31_t)0x7f734732, (q31_t)0x7f72b222, (q31_t)0x7f721cc3, + (q31_t)0x7f718715, (q31_t)0x7f70f119, + (q31_t)0x7f705ace, (q31_t)0x7f6fc435, (q31_t)0x7f6f2d4d, (q31_t)0x7f6e9617, (q31_t)0x7f6dfe91, (q31_t)0x7f6d66be, + (q31_t)0x7f6cce9b, (q31_t)0x7f6c362a, + (q31_t)0x7f6b9d6b, (q31_t)0x7f6b045d, (q31_t)0x7f6a6b00, (q31_t)0x7f69d154, (q31_t)0x7f69375a, (q31_t)0x7f689d12, + (q31_t)0x7f68027b, (q31_t)0x7f676795, + (q31_t)0x7f66cc61, (q31_t)0x7f6630de, (q31_t)0x7f65950c, (q31_t)0x7f64f8ec, (q31_t)0x7f645c7d, (q31_t)0x7f63bfc0, + (q31_t)0x7f6322b4, (q31_t)0x7f62855a, + (q31_t)0x7f61e7b1, (q31_t)0x7f6149b9, (q31_t)0x7f60ab73, (q31_t)0x7f600cdf, (q31_t)0x7f5f6dfb, (q31_t)0x7f5ecec9, + (q31_t)0x7f5e2f49, (q31_t)0x7f5d8f7a, + (q31_t)0x7f5cef5c, (q31_t)0x7f5c4ef0, (q31_t)0x7f5bae36, (q31_t)0x7f5b0d2c, (q31_t)0x7f5a6bd5, (q31_t)0x7f59ca2e, + (q31_t)0x7f592839, (q31_t)0x7f5885f6, + (q31_t)0x7f57e364, (q31_t)0x7f574083, (q31_t)0x7f569d54, (q31_t)0x7f55f9d6, (q31_t)0x7f55560a, (q31_t)0x7f54b1ef, + (q31_t)0x7f540d86, (q31_t)0x7f5368ce, + (q31_t)0x7f52c3c8, (q31_t)0x7f521e73, (q31_t)0x7f5178cf, (q31_t)0x7f50d2dd, (q31_t)0x7f502c9d, (q31_t)0x7f4f860e, + (q31_t)0x7f4edf30, (q31_t)0x7f4e3804, + (q31_t)0x7f4d9089, (q31_t)0x7f4ce8c0, (q31_t)0x7f4c40a8, (q31_t)0x7f4b9842, (q31_t)0x7f4aef8d, (q31_t)0x7f4a468a, + (q31_t)0x7f499d38, (q31_t)0x7f48f398, + (q31_t)0x7f4849a9, (q31_t)0x7f479f6c, (q31_t)0x7f46f4e0, (q31_t)0x7f464a06, (q31_t)0x7f459edd, (q31_t)0x7f44f365, + (q31_t)0x7f44479f, (q31_t)0x7f439b8b, + (q31_t)0x7f42ef28, (q31_t)0x7f424277, (q31_t)0x7f419577, (q31_t)0x7f40e828, (q31_t)0x7f403a8b, (q31_t)0x7f3f8ca0, + (q31_t)0x7f3ede66, (q31_t)0x7f3e2fde, + (q31_t)0x7f3d8107, (q31_t)0x7f3cd1e2, (q31_t)0x7f3c226e, (q31_t)0x7f3b72ab, (q31_t)0x7f3ac29b, (q31_t)0x7f3a123b, + (q31_t)0x7f39618e, (q31_t)0x7f38b091, + (q31_t)0x7f37ff47, (q31_t)0x7f374dad, (q31_t)0x7f369bc6, (q31_t)0x7f35e990, (q31_t)0x7f35370b, (q31_t)0x7f348438, + (q31_t)0x7f33d116, (q31_t)0x7f331da6, + (q31_t)0x7f3269e8, (q31_t)0x7f31b5db, (q31_t)0x7f31017f, (q31_t)0x7f304cd6, (q31_t)0x7f2f97dd, (q31_t)0x7f2ee296, + (q31_t)0x7f2e2d01, (q31_t)0x7f2d771e, + (q31_t)0x7f2cc0eb, (q31_t)0x7f2c0a6b, (q31_t)0x7f2b539c, (q31_t)0x7f2a9c7e, (q31_t)0x7f29e512, (q31_t)0x7f292d58, + (q31_t)0x7f28754f, (q31_t)0x7f27bcf8, + (q31_t)0x7f270452, (q31_t)0x7f264b5e, (q31_t)0x7f25921c, (q31_t)0x7f24d88b, (q31_t)0x7f241eab, (q31_t)0x7f23647e, + (q31_t)0x7f22aa01, (q31_t)0x7f21ef37, + (q31_t)0x7f21341e, (q31_t)0x7f2078b6, (q31_t)0x7f1fbd00, (q31_t)0x7f1f00fc, (q31_t)0x7f1e44a9, (q31_t)0x7f1d8808, + (q31_t)0x7f1ccb18, (q31_t)0x7f1c0dda, + (q31_t)0x7f1b504e, (q31_t)0x7f1a9273, (q31_t)0x7f19d44a, (q31_t)0x7f1915d2, (q31_t)0x7f18570c, (q31_t)0x7f1797f8, + (q31_t)0x7f16d895, (q31_t)0x7f1618e4, + (q31_t)0x7f1558e4, (q31_t)0x7f149896, (q31_t)0x7f13d7fa, (q31_t)0x7f13170f, (q31_t)0x7f1255d6, (q31_t)0x7f11944f, + (q31_t)0x7f10d279, (q31_t)0x7f101054, + (q31_t)0x7f0f4de2, (q31_t)0x7f0e8b21, (q31_t)0x7f0dc811, (q31_t)0x7f0d04b3, (q31_t)0x7f0c4107, (q31_t)0x7f0b7d0d, + (q31_t)0x7f0ab8c4, (q31_t)0x7f09f42d, + (q31_t)0x7f092f47, (q31_t)0x7f086a13, (q31_t)0x7f07a491, (q31_t)0x7f06dec0, (q31_t)0x7f0618a1, (q31_t)0x7f055233, + (q31_t)0x7f048b78, (q31_t)0x7f03c46d, + (q31_t)0x7f02fd15, (q31_t)0x7f02356e, (q31_t)0x7f016d79, (q31_t)0x7f00a535, (q31_t)0x7effdca4, (q31_t)0x7eff13c3, + (q31_t)0x7efe4a95, (q31_t)0x7efd8118, + (q31_t)0x7efcb74d, (q31_t)0x7efbed33, (q31_t)0x7efb22cb, (q31_t)0x7efa5815, (q31_t)0x7ef98d11, (q31_t)0x7ef8c1be, + (q31_t)0x7ef7f61d, (q31_t)0x7ef72a2d, + (q31_t)0x7ef65def, (q31_t)0x7ef59163, (q31_t)0x7ef4c489, (q31_t)0x7ef3f760, (q31_t)0x7ef329e9, (q31_t)0x7ef25c24, + (q31_t)0x7ef18e10, (q31_t)0x7ef0bfae, + (q31_t)0x7eeff0fe, (q31_t)0x7eef21ff, (q31_t)0x7eee52b2, (q31_t)0x7eed8317, (q31_t)0x7eecb32d, (q31_t)0x7eebe2f6, + (q31_t)0x7eeb1270, (q31_t)0x7eea419b, + (q31_t)0x7ee97079, (q31_t)0x7ee89f08, (q31_t)0x7ee7cd49, (q31_t)0x7ee6fb3b, (q31_t)0x7ee628df, (q31_t)0x7ee55635, + (q31_t)0x7ee4833d, (q31_t)0x7ee3aff6, + (q31_t)0x7ee2dc61, (q31_t)0x7ee2087e, (q31_t)0x7ee1344d, (q31_t)0x7ee05fcd, (q31_t)0x7edf8aff, (q31_t)0x7edeb5e3, + (q31_t)0x7edde079, (q31_t)0x7edd0ac0, + (q31_t)0x7edc34b9, (q31_t)0x7edb5e64, (q31_t)0x7eda87c0, (q31_t)0x7ed9b0ce, (q31_t)0x7ed8d98e, (q31_t)0x7ed80200, + (q31_t)0x7ed72a24, (q31_t)0x7ed651f9, + (q31_t)0x7ed57980, (q31_t)0x7ed4a0b9, (q31_t)0x7ed3c7a3, (q31_t)0x7ed2ee40, (q31_t)0x7ed2148e, (q31_t)0x7ed13a8e, + (q31_t)0x7ed0603f, (q31_t)0x7ecf85a3, + (q31_t)0x7eceaab8, (q31_t)0x7ecdcf7f, (q31_t)0x7eccf3f8, (q31_t)0x7ecc1822, (q31_t)0x7ecb3bff, (q31_t)0x7eca5f8d, + (q31_t)0x7ec982cd, (q31_t)0x7ec8a5bf, + (q31_t)0x7ec7c862, (q31_t)0x7ec6eab7, (q31_t)0x7ec60cbe, (q31_t)0x7ec52e77, (q31_t)0x7ec44fe2, (q31_t)0x7ec370fe, + (q31_t)0x7ec291cd, (q31_t)0x7ec1b24d, + (q31_t)0x7ec0d27f, (q31_t)0x7ebff263, (q31_t)0x7ebf11f8, (q31_t)0x7ebe313f, (q31_t)0x7ebd5039, (q31_t)0x7ebc6ee4, + (q31_t)0x7ebb8d40, (q31_t)0x7ebaab4f, + (q31_t)0x7eb9c910, (q31_t)0x7eb8e682, (q31_t)0x7eb803a6, (q31_t)0x7eb7207c, (q31_t)0x7eb63d04, (q31_t)0x7eb5593d, + (q31_t)0x7eb47529, (q31_t)0x7eb390c6, + (q31_t)0x7eb2ac15, (q31_t)0x7eb1c716, (q31_t)0x7eb0e1c9, (q31_t)0x7eaffc2e, (q31_t)0x7eaf1645, (q31_t)0x7eae300d, + (q31_t)0x7ead4987, (q31_t)0x7eac62b3, + (q31_t)0x7eab7b91, (q31_t)0x7eaa9421, (q31_t)0x7ea9ac63, (q31_t)0x7ea8c457, (q31_t)0x7ea7dbfc, (q31_t)0x7ea6f353, + (q31_t)0x7ea60a5d, (q31_t)0x7ea52118, + (q31_t)0x7ea43785, (q31_t)0x7ea34da4, (q31_t)0x7ea26374, (q31_t)0x7ea178f7, (q31_t)0x7ea08e2b, (q31_t)0x7e9fa312, + (q31_t)0x7e9eb7aa, (q31_t)0x7e9dcbf4, + (q31_t)0x7e9cdff0, (q31_t)0x7e9bf39e, (q31_t)0x7e9b06fe, (q31_t)0x7e9a1a10, (q31_t)0x7e992cd4, (q31_t)0x7e983f49, + (q31_t)0x7e975171, (q31_t)0x7e96634a, + (q31_t)0x7e9574d6, (q31_t)0x7e948613, (q31_t)0x7e939702, (q31_t)0x7e92a7a3, (q31_t)0x7e91b7f6, (q31_t)0x7e90c7fb, + (q31_t)0x7e8fd7b2, (q31_t)0x7e8ee71b, + (q31_t)0x7e8df636, (q31_t)0x7e8d0502, (q31_t)0x7e8c1381, (q31_t)0x7e8b21b1, (q31_t)0x7e8a2f94, (q31_t)0x7e893d28, + (q31_t)0x7e884a6f, (q31_t)0x7e875767, + (q31_t)0x7e866411, (q31_t)0x7e85706d, (q31_t)0x7e847c7c, (q31_t)0x7e83883c, (q31_t)0x7e8293ae, (q31_t)0x7e819ed2, + (q31_t)0x7e80a9a8, (q31_t)0x7e7fb430, + (q31_t)0x7e7ebe6a, (q31_t)0x7e7dc856, (q31_t)0x7e7cd1f4, (q31_t)0x7e7bdb44, (q31_t)0x7e7ae446, (q31_t)0x7e79ecf9, + (q31_t)0x7e78f55f, (q31_t)0x7e77fd77, + (q31_t)0x7e770541, (q31_t)0x7e760cbd, (q31_t)0x7e7513ea, (q31_t)0x7e741aca, (q31_t)0x7e73215c, (q31_t)0x7e7227a0, + (q31_t)0x7e712d96, (q31_t)0x7e70333d, + (q31_t)0x7e6f3897, (q31_t)0x7e6e3da3, (q31_t)0x7e6d4261, (q31_t)0x7e6c46d1, (q31_t)0x7e6b4af2, (q31_t)0x7e6a4ec6, + (q31_t)0x7e69524c, (q31_t)0x7e685584, + (q31_t)0x7e67586e, (q31_t)0x7e665b0a, (q31_t)0x7e655d58, (q31_t)0x7e645f58, (q31_t)0x7e63610a, (q31_t)0x7e62626e, + (q31_t)0x7e616384, (q31_t)0x7e60644c, + (q31_t)0x7e5f64c7, (q31_t)0x7e5e64f3, (q31_t)0x7e5d64d1, (q31_t)0x7e5c6461, (q31_t)0x7e5b63a4, (q31_t)0x7e5a6298, + (q31_t)0x7e59613f, (q31_t)0x7e585f97, + (q31_t)0x7e575da2, (q31_t)0x7e565b5f, (q31_t)0x7e5558ce, (q31_t)0x7e5455ef, (q31_t)0x7e5352c1, (q31_t)0x7e524f46, + (q31_t)0x7e514b7e, (q31_t)0x7e504767, + (q31_t)0x7e4f4302, (q31_t)0x7e4e3e4f, (q31_t)0x7e4d394f, (q31_t)0x7e4c3400, (q31_t)0x7e4b2e64, (q31_t)0x7e4a287a, + (q31_t)0x7e492241, (q31_t)0x7e481bbb, + (q31_t)0x7e4714e7, (q31_t)0x7e460dc5, (q31_t)0x7e450656, (q31_t)0x7e43fe98, (q31_t)0x7e42f68c, (q31_t)0x7e41ee33, + (q31_t)0x7e40e58c, (q31_t)0x7e3fdc97, + (q31_t)0x7e3ed353, (q31_t)0x7e3dc9c3, (q31_t)0x7e3cbfe4, (q31_t)0x7e3bb5b7, (q31_t)0x7e3aab3c, (q31_t)0x7e39a074, + (q31_t)0x7e38955e, (q31_t)0x7e3789fa, + (q31_t)0x7e367e48, (q31_t)0x7e357248, (q31_t)0x7e3465fa, (q31_t)0x7e33595e, (q31_t)0x7e324c75, (q31_t)0x7e313f3e, + (q31_t)0x7e3031b9, (q31_t)0x7e2f23e6, + (q31_t)0x7e2e15c5, (q31_t)0x7e2d0756, (q31_t)0x7e2bf89a, (q31_t)0x7e2ae990, (q31_t)0x7e29da38, (q31_t)0x7e28ca92, + (q31_t)0x7e27ba9e, (q31_t)0x7e26aa5d, + (q31_t)0x7e2599cd, (q31_t)0x7e2488f0, (q31_t)0x7e2377c5, (q31_t)0x7e22664c, (q31_t)0x7e215486, (q31_t)0x7e204271, + (q31_t)0x7e1f300f, (q31_t)0x7e1e1d5f, + (q31_t)0x7e1d0a61, (q31_t)0x7e1bf716, (q31_t)0x7e1ae37c, (q31_t)0x7e19cf95, (q31_t)0x7e18bb60, (q31_t)0x7e17a6dd, + (q31_t)0x7e16920d, (q31_t)0x7e157cee, + (q31_t)0x7e146782, (q31_t)0x7e1351c9, (q31_t)0x7e123bc1, (q31_t)0x7e11256c, (q31_t)0x7e100ec8, (q31_t)0x7e0ef7d7, + (q31_t)0x7e0de099, (q31_t)0x7e0cc90c, + (q31_t)0x7e0bb132, (q31_t)0x7e0a990a, (q31_t)0x7e098095, (q31_t)0x7e0867d1, (q31_t)0x7e074ec0, (q31_t)0x7e063561, + (q31_t)0x7e051bb4, (q31_t)0x7e0401ba, + (q31_t)0x7e02e772, (q31_t)0x7e01ccdc, (q31_t)0x7e00b1f9, (q31_t)0x7dff96c7, (q31_t)0x7dfe7b48, (q31_t)0x7dfd5f7b, + (q31_t)0x7dfc4361, (q31_t)0x7dfb26f9, + (q31_t)0x7dfa0a43, (q31_t)0x7df8ed3f, (q31_t)0x7df7cfee, (q31_t)0x7df6b24f, (q31_t)0x7df59462, (q31_t)0x7df47628, + (q31_t)0x7df357a0, (q31_t)0x7df238ca, + (q31_t)0x7df119a7, (q31_t)0x7deffa35, (q31_t)0x7deeda77, (q31_t)0x7dedba6a, (q31_t)0x7dec9a10, (q31_t)0x7deb7968, + (q31_t)0x7dea5872, (q31_t)0x7de9372f, + (q31_t)0x7de8159e, (q31_t)0x7de6f3c0, (q31_t)0x7de5d193, (q31_t)0x7de4af1a, (q31_t)0x7de38c52, (q31_t)0x7de2693d, + (q31_t)0x7de145da, (q31_t)0x7de02229, + (q31_t)0x7ddefe2b, (q31_t)0x7dddd9e0, (q31_t)0x7ddcb546, (q31_t)0x7ddb905f, (q31_t)0x7dda6b2a, (q31_t)0x7dd945a8, + (q31_t)0x7dd81fd8, (q31_t)0x7dd6f9ba, + (q31_t)0x7dd5d34f, (q31_t)0x7dd4ac96, (q31_t)0x7dd38590, (q31_t)0x7dd25e3c, (q31_t)0x7dd1369a, (q31_t)0x7dd00eab, + (q31_t)0x7dcee66e, (q31_t)0x7dcdbde3, + (q31_t)0x7dcc950b, (q31_t)0x7dcb6be6, (q31_t)0x7dca4272, (q31_t)0x7dc918b1, (q31_t)0x7dc7eea3, (q31_t)0x7dc6c447, + (q31_t)0x7dc5999d, (q31_t)0x7dc46ea6, + (q31_t)0x7dc34361, (q31_t)0x7dc217cf, (q31_t)0x7dc0ebef, (q31_t)0x7dbfbfc1, (q31_t)0x7dbe9346, (q31_t)0x7dbd667d, + (q31_t)0x7dbc3967, (q31_t)0x7dbb0c03, + (q31_t)0x7db9de52, (q31_t)0x7db8b053, (q31_t)0x7db78207, (q31_t)0x7db6536d, (q31_t)0x7db52485, (q31_t)0x7db3f550, + (q31_t)0x7db2c5cd, (q31_t)0x7db195fd, + (q31_t)0x7db065df, (q31_t)0x7daf3574, (q31_t)0x7dae04bb, (q31_t)0x7dacd3b5, (q31_t)0x7daba261, (q31_t)0x7daa70c0, + (q31_t)0x7da93ed1, (q31_t)0x7da80c95, + (q31_t)0x7da6da0b, (q31_t)0x7da5a733, (q31_t)0x7da4740e, (q31_t)0x7da3409c, (q31_t)0x7da20cdc, (q31_t)0x7da0d8cf, + (q31_t)0x7d9fa474, (q31_t)0x7d9e6fcb, + (q31_t)0x7d9d3ad6, (q31_t)0x7d9c0592, (q31_t)0x7d9ad001, (q31_t)0x7d999a23, (q31_t)0x7d9863f7, (q31_t)0x7d972d7e, + (q31_t)0x7d95f6b7, (q31_t)0x7d94bfa3, + (q31_t)0x7d938841, (q31_t)0x7d925092, (q31_t)0x7d911896, (q31_t)0x7d8fe04c, (q31_t)0x7d8ea7b4, (q31_t)0x7d8d6ecf, + (q31_t)0x7d8c359d, (q31_t)0x7d8afc1d, + (q31_t)0x7d89c250, (q31_t)0x7d888835, (q31_t)0x7d874dcd, (q31_t)0x7d861317, (q31_t)0x7d84d814, (q31_t)0x7d839cc4, + (q31_t)0x7d826126, (q31_t)0x7d81253a, + (q31_t)0x7d7fe902, (q31_t)0x7d7eac7c, (q31_t)0x7d7d6fa8, (q31_t)0x7d7c3287, (q31_t)0x7d7af519, (q31_t)0x7d79b75d, + (q31_t)0x7d787954, (q31_t)0x7d773afd, + (q31_t)0x7d75fc59, (q31_t)0x7d74bd68, (q31_t)0x7d737e29, (q31_t)0x7d723e9d, (q31_t)0x7d70fec4, (q31_t)0x7d6fbe9d, + (q31_t)0x7d6e7e29, (q31_t)0x7d6d3d67, + (q31_t)0x7d6bfc58, (q31_t)0x7d6abafc, (q31_t)0x7d697952, (q31_t)0x7d68375b, (q31_t)0x7d66f517, (q31_t)0x7d65b285, + (q31_t)0x7d646fa6, (q31_t)0x7d632c79, + (q31_t)0x7d61e8ff, (q31_t)0x7d60a538, (q31_t)0x7d5f6124, (q31_t)0x7d5e1cc2, (q31_t)0x7d5cd813, (q31_t)0x7d5b9316, + (q31_t)0x7d5a4dcc, (q31_t)0x7d590835, + (q31_t)0x7d57c251, (q31_t)0x7d567c1f, (q31_t)0x7d5535a0, (q31_t)0x7d53eed3, (q31_t)0x7d52a7ba, (q31_t)0x7d516053, + (q31_t)0x7d50189e, (q31_t)0x7d4ed09d, + (q31_t)0x7d4d884e, (q31_t)0x7d4c3fb1, (q31_t)0x7d4af6c8, (q31_t)0x7d49ad91, (q31_t)0x7d48640d, (q31_t)0x7d471a3c, + (q31_t)0x7d45d01d, (q31_t)0x7d4485b1, + (q31_t)0x7d433af8, (q31_t)0x7d41eff1, (q31_t)0x7d40a49e, (q31_t)0x7d3f58fd, (q31_t)0x7d3e0d0e, (q31_t)0x7d3cc0d3, + (q31_t)0x7d3b744a, (q31_t)0x7d3a2774, + (q31_t)0x7d38da51, (q31_t)0x7d378ce0, (q31_t)0x7d363f23, (q31_t)0x7d34f118, (q31_t)0x7d33a2bf, (q31_t)0x7d32541a, + (q31_t)0x7d310527, (q31_t)0x7d2fb5e7, + (q31_t)0x7d2e665a, (q31_t)0x7d2d1680, (q31_t)0x7d2bc659, (q31_t)0x7d2a75e4, (q31_t)0x7d292522, (q31_t)0x7d27d413, + (q31_t)0x7d2682b6, (q31_t)0x7d25310d, + (q31_t)0x7d23df16, (q31_t)0x7d228cd2, (q31_t)0x7d213a41, (q31_t)0x7d1fe762, (q31_t)0x7d1e9437, (q31_t)0x7d1d40be, + (q31_t)0x7d1becf8, (q31_t)0x7d1a98e5, + (q31_t)0x7d194485, (q31_t)0x7d17efd8, (q31_t)0x7d169add, (q31_t)0x7d154595, (q31_t)0x7d13f001, (q31_t)0x7d129a1f, + (q31_t)0x7d1143ef, (q31_t)0x7d0fed73, + (q31_t)0x7d0e96aa, (q31_t)0x7d0d3f93, (q31_t)0x7d0be82f, (q31_t)0x7d0a907e, (q31_t)0x7d093880, (q31_t)0x7d07e035, + (q31_t)0x7d06879d, (q31_t)0x7d052eb8, + (q31_t)0x7d03d585, (q31_t)0x7d027c05, (q31_t)0x7d012239, (q31_t)0x7cffc81f, (q31_t)0x7cfe6db8, (q31_t)0x7cfd1304, + (q31_t)0x7cfbb803, (q31_t)0x7cfa5cb4, + (q31_t)0x7cf90119, (q31_t)0x7cf7a531, (q31_t)0x7cf648fb, (q31_t)0x7cf4ec79, (q31_t)0x7cf38fa9, (q31_t)0x7cf2328c, + (q31_t)0x7cf0d522, (q31_t)0x7cef776b, + (q31_t)0x7cee1967, (q31_t)0x7cecbb16, (q31_t)0x7ceb5c78, (q31_t)0x7ce9fd8d, (q31_t)0x7ce89e55, (q31_t)0x7ce73ed0, + (q31_t)0x7ce5defd, (q31_t)0x7ce47ede, + (q31_t)0x7ce31e72, (q31_t)0x7ce1bdb8, (q31_t)0x7ce05cb2, (q31_t)0x7cdefb5e, (q31_t)0x7cdd99be, (q31_t)0x7cdc37d0, + (q31_t)0x7cdad596, (q31_t)0x7cd9730e, + (q31_t)0x7cd8103a, (q31_t)0x7cd6ad18, (q31_t)0x7cd549aa, (q31_t)0x7cd3e5ee, (q31_t)0x7cd281e5, (q31_t)0x7cd11d90, + (q31_t)0x7ccfb8ed, (q31_t)0x7cce53fe, + (q31_t)0x7ccceec1, (q31_t)0x7ccb8937, (q31_t)0x7cca2361, (q31_t)0x7cc8bd3d, (q31_t)0x7cc756cd, (q31_t)0x7cc5f010, + (q31_t)0x7cc48905, (q31_t)0x7cc321ae, + (q31_t)0x7cc1ba09, (q31_t)0x7cc05218, (q31_t)0x7cbee9da, (q31_t)0x7cbd814f, (q31_t)0x7cbc1877, (q31_t)0x7cbaaf51, + (q31_t)0x7cb945df, (q31_t)0x7cb7dc20, + (q31_t)0x7cb67215, (q31_t)0x7cb507bc, (q31_t)0x7cb39d16, (q31_t)0x7cb23223, (q31_t)0x7cb0c6e4, (q31_t)0x7caf5b57, + (q31_t)0x7cadef7e, (q31_t)0x7cac8358, + (q31_t)0x7cab16e4, (q31_t)0x7ca9aa24, (q31_t)0x7ca83d17, (q31_t)0x7ca6cfbd, (q31_t)0x7ca56216, (q31_t)0x7ca3f423, + (q31_t)0x7ca285e2, (q31_t)0x7ca11755, + (q31_t)0x7c9fa87a, (q31_t)0x7c9e3953, (q31_t)0x7c9cc9df, (q31_t)0x7c9b5a1e, (q31_t)0x7c99ea10, (q31_t)0x7c9879b6, + (q31_t)0x7c97090e, (q31_t)0x7c95981a, + (q31_t)0x7c9426d8, (q31_t)0x7c92b54a, (q31_t)0x7c91436f, (q31_t)0x7c8fd148, (q31_t)0x7c8e5ed3, (q31_t)0x7c8cec12, + (q31_t)0x7c8b7903, (q31_t)0x7c8a05a8, + (q31_t)0x7c889200, (q31_t)0x7c871e0c, (q31_t)0x7c85a9ca, (q31_t)0x7c84353c, (q31_t)0x7c82c060, (q31_t)0x7c814b39, + (q31_t)0x7c7fd5c4, (q31_t)0x7c7e6002, + (q31_t)0x7c7ce9f4, (q31_t)0x7c7b7399, (q31_t)0x7c79fcf1, (q31_t)0x7c7885fc, (q31_t)0x7c770eba, (q31_t)0x7c75972c, + (q31_t)0x7c741f51, (q31_t)0x7c72a729, + (q31_t)0x7c712eb5, (q31_t)0x7c6fb5f3, (q31_t)0x7c6e3ce5, (q31_t)0x7c6cc38a, (q31_t)0x7c6b49e3, (q31_t)0x7c69cfee, + (q31_t)0x7c6855ad, (q31_t)0x7c66db1f, + (q31_t)0x7c656045, (q31_t)0x7c63e51e, (q31_t)0x7c6269aa, (q31_t)0x7c60ede9, (q31_t)0x7c5f71db, (q31_t)0x7c5df581, + (q31_t)0x7c5c78da, (q31_t)0x7c5afbe6, + (q31_t)0x7c597ea6, (q31_t)0x7c580119, (q31_t)0x7c56833f, (q31_t)0x7c550519, (q31_t)0x7c5386a6, (q31_t)0x7c5207e6, + (q31_t)0x7c5088d9, (q31_t)0x7c4f0980, + (q31_t)0x7c4d89da, (q31_t)0x7c4c09e8, (q31_t)0x7c4a89a8, (q31_t)0x7c49091c, (q31_t)0x7c478844, (q31_t)0x7c46071f, + (q31_t)0x7c4485ad, (q31_t)0x7c4303ee, + (q31_t)0x7c4181e3, (q31_t)0x7c3fff8b, (q31_t)0x7c3e7ce7, (q31_t)0x7c3cf9f5, (q31_t)0x7c3b76b8, (q31_t)0x7c39f32d, + (q31_t)0x7c386f56, (q31_t)0x7c36eb33, + (q31_t)0x7c3566c2, (q31_t)0x7c33e205, (q31_t)0x7c325cfc, (q31_t)0x7c30d7a6, (q31_t)0x7c2f5203, (q31_t)0x7c2dcc14, + (q31_t)0x7c2c45d8, (q31_t)0x7c2abf4f, + (q31_t)0x7c29387a, (q31_t)0x7c27b158, (q31_t)0x7c2629ea, (q31_t)0x7c24a22f, (q31_t)0x7c231a28, (q31_t)0x7c2191d4, + (q31_t)0x7c200933, (q31_t)0x7c1e8046, + (q31_t)0x7c1cf70c, (q31_t)0x7c1b6d86, (q31_t)0x7c19e3b3, (q31_t)0x7c185994, (q31_t)0x7c16cf28, (q31_t)0x7c15446f, + (q31_t)0x7c13b96a, (q31_t)0x7c122e19, + (q31_t)0x7c10a27b, (q31_t)0x7c0f1690, (q31_t)0x7c0d8a59, (q31_t)0x7c0bfdd5, (q31_t)0x7c0a7105, (q31_t)0x7c08e3e8, + (q31_t)0x7c07567f, (q31_t)0x7c05c8c9, + (q31_t)0x7c043ac7, (q31_t)0x7c02ac78, (q31_t)0x7c011ddd, (q31_t)0x7bff8ef5, (q31_t)0x7bfdffc1, (q31_t)0x7bfc7041, + (q31_t)0x7bfae073, (q31_t)0x7bf9505a, + (q31_t)0x7bf7bff4, (q31_t)0x7bf62f41, (q31_t)0x7bf49e42, (q31_t)0x7bf30cf6, (q31_t)0x7bf17b5e, (q31_t)0x7befe97a, + (q31_t)0x7bee5749, (q31_t)0x7becc4cc, + (q31_t)0x7beb3202, (q31_t)0x7be99eec, (q31_t)0x7be80b89, (q31_t)0x7be677da, (q31_t)0x7be4e3df, (q31_t)0x7be34f97, + (q31_t)0x7be1bb02, (q31_t)0x7be02621, + (q31_t)0x7bde90f4, (q31_t)0x7bdcfb7b, (q31_t)0x7bdb65b5, (q31_t)0x7bd9cfa2, (q31_t)0x7bd83944, (q31_t)0x7bd6a298, + (q31_t)0x7bd50ba1, (q31_t)0x7bd3745d, + (q31_t)0x7bd1dccc, (q31_t)0x7bd044f0, (q31_t)0x7bceacc7, (q31_t)0x7bcd1451, (q31_t)0x7bcb7b8f, (q31_t)0x7bc9e281, + (q31_t)0x7bc84927, (q31_t)0x7bc6af80, + (q31_t)0x7bc5158c, (q31_t)0x7bc37b4d, (q31_t)0x7bc1e0c1, (q31_t)0x7bc045e9, (q31_t)0x7bbeaac4, (q31_t)0x7bbd0f53, + (q31_t)0x7bbb7396, (q31_t)0x7bb9d78c, + (q31_t)0x7bb83b36, (q31_t)0x7bb69e94, (q31_t)0x7bb501a5, (q31_t)0x7bb3646a, (q31_t)0x7bb1c6e3, (q31_t)0x7bb02910, + (q31_t)0x7bae8af0, (q31_t)0x7bacec84, + (q31_t)0x7bab4dcc, (q31_t)0x7ba9aec7, (q31_t)0x7ba80f76, (q31_t)0x7ba66fd9, (q31_t)0x7ba4cfef, (q31_t)0x7ba32fba, + (q31_t)0x7ba18f38, (q31_t)0x7b9fee69, + (q31_t)0x7b9e4d4f, (q31_t)0x7b9cabe8, (q31_t)0x7b9b0a35, (q31_t)0x7b996836, (q31_t)0x7b97c5ea, (q31_t)0x7b962352, + (q31_t)0x7b94806e, (q31_t)0x7b92dd3e, + (q31_t)0x7b9139c2, (q31_t)0x7b8f95f9, (q31_t)0x7b8df1e4, (q31_t)0x7b8c4d83, (q31_t)0x7b8aa8d6, (q31_t)0x7b8903dc, + (q31_t)0x7b875e96, (q31_t)0x7b85b904, + (q31_t)0x7b841326, (q31_t)0x7b826cfc, (q31_t)0x7b80c686, (q31_t)0x7b7f1fc3, (q31_t)0x7b7d78b4, (q31_t)0x7b7bd159, + (q31_t)0x7b7a29b2, (q31_t)0x7b7881be, + (q31_t)0x7b76d97f, (q31_t)0x7b7530f3, (q31_t)0x7b73881b, (q31_t)0x7b71def7, (q31_t)0x7b703587, (q31_t)0x7b6e8bcb, + (q31_t)0x7b6ce1c2, (q31_t)0x7b6b376e, + (q31_t)0x7b698ccd, (q31_t)0x7b67e1e0, (q31_t)0x7b6636a7, (q31_t)0x7b648b22, (q31_t)0x7b62df51, (q31_t)0x7b613334, + (q31_t)0x7b5f86ca, (q31_t)0x7b5dda15, + (q31_t)0x7b5c2d13, (q31_t)0x7b5a7fc6, (q31_t)0x7b58d22c, (q31_t)0x7b572446, (q31_t)0x7b557614, (q31_t)0x7b53c796, + (q31_t)0x7b5218cc, (q31_t)0x7b5069b6, + (q31_t)0x7b4eba53, (q31_t)0x7b4d0aa5, (q31_t)0x7b4b5aab, (q31_t)0x7b49aa64, (q31_t)0x7b47f9d2, (q31_t)0x7b4648f3, + (q31_t)0x7b4497c9, (q31_t)0x7b42e652, + (q31_t)0x7b413490, (q31_t)0x7b3f8281, (q31_t)0x7b3dd026, (q31_t)0x7b3c1d80, (q31_t)0x7b3a6a8d, (q31_t)0x7b38b74e, + (q31_t)0x7b3703c3, (q31_t)0x7b354fed, + (q31_t)0x7b339bca, (q31_t)0x7b31e75b, (q31_t)0x7b3032a0, (q31_t)0x7b2e7d9a, (q31_t)0x7b2cc847, (q31_t)0x7b2b12a8, + (q31_t)0x7b295cbe, (q31_t)0x7b27a687, + (q31_t)0x7b25f004, (q31_t)0x7b243936, (q31_t)0x7b22821b, (q31_t)0x7b20cab5, (q31_t)0x7b1f1302, (q31_t)0x7b1d5b04, + (q31_t)0x7b1ba2b9, (q31_t)0x7b19ea23, + (q31_t)0x7b183141, (q31_t)0x7b167813, (q31_t)0x7b14be99, (q31_t)0x7b1304d3, (q31_t)0x7b114ac1, (q31_t)0x7b0f9063, + (q31_t)0x7b0dd5b9, (q31_t)0x7b0c1ac4, + (q31_t)0x7b0a5f82, (q31_t)0x7b08a3f5, (q31_t)0x7b06e81b, (q31_t)0x7b052bf6, (q31_t)0x7b036f85, (q31_t)0x7b01b2c8, + (q31_t)0x7afff5bf, (q31_t)0x7afe386a, + (q31_t)0x7afc7aca, (q31_t)0x7afabcdd, (q31_t)0x7af8fea5, (q31_t)0x7af74021, (q31_t)0x7af58151, (q31_t)0x7af3c235, + (q31_t)0x7af202cd, (q31_t)0x7af0431a, + (q31_t)0x7aee831a, (q31_t)0x7aecc2cf, (q31_t)0x7aeb0238, (q31_t)0x7ae94155, (q31_t)0x7ae78026, (q31_t)0x7ae5beac, + (q31_t)0x7ae3fce6, (q31_t)0x7ae23ad4, + (q31_t)0x7ae07876, (q31_t)0x7adeb5cc, (q31_t)0x7adcf2d6, (q31_t)0x7adb2f95, (q31_t)0x7ad96c08, (q31_t)0x7ad7a82f, + (q31_t)0x7ad5e40a, (q31_t)0x7ad41f9a, + (q31_t)0x7ad25ade, (q31_t)0x7ad095d6, (q31_t)0x7aced082, (q31_t)0x7acd0ae3, (q31_t)0x7acb44f8, (q31_t)0x7ac97ec1, + (q31_t)0x7ac7b83e, (q31_t)0x7ac5f170, + (q31_t)0x7ac42a55, (q31_t)0x7ac262ef, (q31_t)0x7ac09b3e, (q31_t)0x7abed341, (q31_t)0x7abd0af7, (q31_t)0x7abb4263, + (q31_t)0x7ab97982, (q31_t)0x7ab7b056, + (q31_t)0x7ab5e6de, (q31_t)0x7ab41d1b, (q31_t)0x7ab2530b, (q31_t)0x7ab088b0, (q31_t)0x7aaebe0a, (q31_t)0x7aacf318, + (q31_t)0x7aab27da, (q31_t)0x7aa95c50, + (q31_t)0x7aa7907b, (q31_t)0x7aa5c45a, (q31_t)0x7aa3f7ed, (q31_t)0x7aa22b35, (q31_t)0x7aa05e31, (q31_t)0x7a9e90e1, + (q31_t)0x7a9cc346, (q31_t)0x7a9af55f, + (q31_t)0x7a99272d, (q31_t)0x7a9758af, (q31_t)0x7a9589e5, (q31_t)0x7a93bad0, (q31_t)0x7a91eb6f, (q31_t)0x7a901bc2, + (q31_t)0x7a8e4bca, (q31_t)0x7a8c7b87, + (q31_t)0x7a8aaaf7, (q31_t)0x7a88da1c, (q31_t)0x7a8708f6, (q31_t)0x7a853784, (q31_t)0x7a8365c6, (q31_t)0x7a8193bd, + (q31_t)0x7a7fc168, (q31_t)0x7a7deec8, + (q31_t)0x7a7c1bdc, (q31_t)0x7a7a48a4, (q31_t)0x7a787521, (q31_t)0x7a76a153, (q31_t)0x7a74cd38, (q31_t)0x7a72f8d3, + (q31_t)0x7a712422, (q31_t)0x7a6f4f25, + (q31_t)0x7a6d79dd, (q31_t)0x7a6ba449, (q31_t)0x7a69ce6a, (q31_t)0x7a67f83f, (q31_t)0x7a6621c9, (q31_t)0x7a644b07, + (q31_t)0x7a6273fa, (q31_t)0x7a609ca1, + (q31_t)0x7a5ec4fc, (q31_t)0x7a5ced0d, (q31_t)0x7a5b14d1, (q31_t)0x7a593c4b, (q31_t)0x7a576379, (q31_t)0x7a558a5b, + (q31_t)0x7a53b0f2, (q31_t)0x7a51d73d, + (q31_t)0x7a4ffd3d, (q31_t)0x7a4e22f2, (q31_t)0x7a4c485b, (q31_t)0x7a4a6d78, (q31_t)0x7a48924b, (q31_t)0x7a46b6d1, + (q31_t)0x7a44db0d, (q31_t)0x7a42fefd, + (q31_t)0x7a4122a1, (q31_t)0x7a3f45fa, (q31_t)0x7a3d6908, (q31_t)0x7a3b8bca, (q31_t)0x7a39ae41, (q31_t)0x7a37d06d, + (q31_t)0x7a35f24d, (q31_t)0x7a3413e2, + (q31_t)0x7a32352b, (q31_t)0x7a305629, (q31_t)0x7a2e76dc, (q31_t)0x7a2c9743, (q31_t)0x7a2ab75f, (q31_t)0x7a28d72f, + (q31_t)0x7a26f6b4, (q31_t)0x7a2515ee, + (q31_t)0x7a2334dd, (q31_t)0x7a215380, (q31_t)0x7a1f71d7, (q31_t)0x7a1d8fe4, (q31_t)0x7a1bada5, (q31_t)0x7a19cb1b, + (q31_t)0x7a17e845, (q31_t)0x7a160524, + (q31_t)0x7a1421b8, (q31_t)0x7a123e01, (q31_t)0x7a1059fe, (q31_t)0x7a0e75b0, (q31_t)0x7a0c9117, (q31_t)0x7a0aac32, + (q31_t)0x7a08c702, (q31_t)0x7a06e187, + (q31_t)0x7a04fbc1, (q31_t)0x7a0315af, (q31_t)0x7a012f52, (q31_t)0x79ff48aa, (q31_t)0x79fd61b6, (q31_t)0x79fb7a77, + (q31_t)0x79f992ed, (q31_t)0x79f7ab18, + (q31_t)0x79f5c2f8, (q31_t)0x79f3da8c, (q31_t)0x79f1f1d5, (q31_t)0x79f008d3, (q31_t)0x79ee1f86, (q31_t)0x79ec35ed, + (q31_t)0x79ea4c09, (q31_t)0x79e861da, + (q31_t)0x79e67760, (q31_t)0x79e48c9b, (q31_t)0x79e2a18a, (q31_t)0x79e0b62e, (q31_t)0x79deca87, (q31_t)0x79dcde95, + (q31_t)0x79daf258, (q31_t)0x79d905d0, + (q31_t)0x79d718fc, (q31_t)0x79d52bdd, (q31_t)0x79d33e73, (q31_t)0x79d150be, (q31_t)0x79cf62be, (q31_t)0x79cd7473, + (q31_t)0x79cb85dc, (q31_t)0x79c996fb, + (q31_t)0x79c7a7ce, (q31_t)0x79c5b856, (q31_t)0x79c3c893, (q31_t)0x79c1d885, (q31_t)0x79bfe82c, (q31_t)0x79bdf788, + (q31_t)0x79bc0698, (q31_t)0x79ba155e, + (q31_t)0x79b823d8, (q31_t)0x79b63207, (q31_t)0x79b43fec, (q31_t)0x79b24d85, (q31_t)0x79b05ad3, (q31_t)0x79ae67d6, + (q31_t)0x79ac748e, (q31_t)0x79aa80fb, + (q31_t)0x79a88d1d, (q31_t)0x79a698f4, (q31_t)0x79a4a480, (q31_t)0x79a2afc1, (q31_t)0x79a0bab6, (q31_t)0x799ec561, + (q31_t)0x799ccfc1, (q31_t)0x799ad9d5, + (q31_t)0x7998e39f, (q31_t)0x7996ed1e, (q31_t)0x7994f651, (q31_t)0x7992ff3a, (q31_t)0x799107d8, (q31_t)0x798f102a, + (q31_t)0x798d1832, (q31_t)0x798b1fef, + (q31_t)0x79892761, (q31_t)0x79872e87, (q31_t)0x79853563, (q31_t)0x79833bf4, (q31_t)0x7981423a, (q31_t)0x797f4835, + (q31_t)0x797d4de5, (q31_t)0x797b534a, + (q31_t)0x79795864, (q31_t)0x79775d33, (q31_t)0x797561b8, (q31_t)0x797365f1, (q31_t)0x797169df, (q31_t)0x796f6d83, + (q31_t)0x796d70dc, (q31_t)0x796b73e9, + (q31_t)0x796976ac, (q31_t)0x79677924, (q31_t)0x79657b51, (q31_t)0x79637d33, (q31_t)0x79617eca, (q31_t)0x795f8017, + (q31_t)0x795d8118, (q31_t)0x795b81cf, + (q31_t)0x7959823b, (q31_t)0x7957825c, (q31_t)0x79558232, (q31_t)0x795381bd, (q31_t)0x795180fe, (q31_t)0x794f7ff3, + (q31_t)0x794d7e9e, (q31_t)0x794b7cfe, + (q31_t)0x79497b13, (q31_t)0x794778dd, (q31_t)0x7945765d, (q31_t)0x79437391, (q31_t)0x7941707b, (q31_t)0x793f6d1a, + (q31_t)0x793d696f, (q31_t)0x793b6578, + (q31_t)0x79396137, (q31_t)0x79375cab, (q31_t)0x793557d4, (q31_t)0x793352b2, (q31_t)0x79314d46, (q31_t)0x792f478f, + (q31_t)0x792d418d, (q31_t)0x792b3b40, + (q31_t)0x792934a9, (q31_t)0x79272dc7, (q31_t)0x7925269a, (q31_t)0x79231f22, (q31_t)0x79211760, (q31_t)0x791f0f53, + (q31_t)0x791d06fb, (q31_t)0x791afe59, + (q31_t)0x7918f56c, (q31_t)0x7916ec34, (q31_t)0x7914e2b2, (q31_t)0x7912d8e4, (q31_t)0x7910cecc, (q31_t)0x790ec46a, + (q31_t)0x790cb9bd, (q31_t)0x790aaec5, + (q31_t)0x7908a382, (q31_t)0x790697f5, (q31_t)0x79048c1d, (q31_t)0x79027ffa, (q31_t)0x7900738d, (q31_t)0x78fe66d5, + (q31_t)0x78fc59d3, (q31_t)0x78fa4c86, + (q31_t)0x78f83eee, (q31_t)0x78f6310c, (q31_t)0x78f422df, (q31_t)0x78f21467, (q31_t)0x78f005a5, (q31_t)0x78edf698, + (q31_t)0x78ebe741, (q31_t)0x78e9d79f, + (q31_t)0x78e7c7b2, (q31_t)0x78e5b77b, (q31_t)0x78e3a6f9, (q31_t)0x78e1962d, (q31_t)0x78df8516, (q31_t)0x78dd73b5, + (q31_t)0x78db6209, (q31_t)0x78d95012, + (q31_t)0x78d73dd1, (q31_t)0x78d52b46, (q31_t)0x78d31870, (q31_t)0x78d1054f, (q31_t)0x78cef1e4, (q31_t)0x78ccde2e, + (q31_t)0x78caca2e, (q31_t)0x78c8b5e3, + (q31_t)0x78c6a14e, (q31_t)0x78c48c6e, (q31_t)0x78c27744, (q31_t)0x78c061cf, (q31_t)0x78be4c10, (q31_t)0x78bc3606, + (q31_t)0x78ba1fb2, (q31_t)0x78b80913, + (q31_t)0x78b5f22a, (q31_t)0x78b3daf7, (q31_t)0x78b1c379, (q31_t)0x78afabb0, (q31_t)0x78ad939d, (q31_t)0x78ab7b40, + (q31_t)0x78a96298, (q31_t)0x78a749a6, + (q31_t)0x78a53069, (q31_t)0x78a316e2, (q31_t)0x78a0fd11, (q31_t)0x789ee2f5, (q31_t)0x789cc88f, (q31_t)0x789aadde, + (q31_t)0x789892e3, (q31_t)0x7896779d, + (q31_t)0x78945c0d, (q31_t)0x78924033, (q31_t)0x7890240e, (q31_t)0x788e07a0, (q31_t)0x788beae6, (q31_t)0x7889cde2, + (q31_t)0x7887b094, (q31_t)0x788592fc, + (q31_t)0x78837519, (q31_t)0x788156ec, (q31_t)0x787f3875, (q31_t)0x787d19b3, (q31_t)0x787afaa7, (q31_t)0x7878db50, + (q31_t)0x7876bbb0, (q31_t)0x78749bc5, + (q31_t)0x78727b8f, (q31_t)0x78705b10, (q31_t)0x786e3a46, (q31_t)0x786c1932, (q31_t)0x7869f7d3, (q31_t)0x7867d62a, + (q31_t)0x7865b437, (q31_t)0x786391fa, + (q31_t)0x78616f72, (q31_t)0x785f4ca1, (q31_t)0x785d2984, (q31_t)0x785b061e, (q31_t)0x7858e26e, (q31_t)0x7856be73, + (q31_t)0x78549a2e, (q31_t)0x7852759e, + (q31_t)0x785050c5, (q31_t)0x784e2ba1, (q31_t)0x784c0633, (q31_t)0x7849e07b, (q31_t)0x7847ba79, (q31_t)0x7845942c, + (q31_t)0x78436d96, (q31_t)0x784146b5, + (q31_t)0x783f1f8a, (q31_t)0x783cf815, (q31_t)0x783ad055, (q31_t)0x7838a84c, (q31_t)0x78367ff8, (q31_t)0x7834575a, + (q31_t)0x78322e72, (q31_t)0x78300540, + (q31_t)0x782ddbc4, (q31_t)0x782bb1fd, (q31_t)0x782987ed, (q31_t)0x78275d92, (q31_t)0x782532ed, (q31_t)0x782307fe, + (q31_t)0x7820dcc5, (q31_t)0x781eb142, + (q31_t)0x781c8575, (q31_t)0x781a595d, (q31_t)0x78182cfc, (q31_t)0x78160051, (q31_t)0x7813d35b, (q31_t)0x7811a61b, + (q31_t)0x780f7892, (q31_t)0x780d4abe, + (q31_t)0x780b1ca0, (q31_t)0x7808ee38, (q31_t)0x7806bf86, (q31_t)0x7804908a, (q31_t)0x78026145, (q31_t)0x780031b5, + (q31_t)0x77fe01db, (q31_t)0x77fbd1b6, + (q31_t)0x77f9a148, (q31_t)0x77f77090, (q31_t)0x77f53f8e, (q31_t)0x77f30e42, (q31_t)0x77f0dcac, (q31_t)0x77eeaacc, + (q31_t)0x77ec78a2, (q31_t)0x77ea462e, + (q31_t)0x77e81370, (q31_t)0x77e5e068, (q31_t)0x77e3ad17, (q31_t)0x77e1797b, (q31_t)0x77df4595, (q31_t)0x77dd1165, + (q31_t)0x77dadcec, (q31_t)0x77d8a828, + (q31_t)0x77d6731a, (q31_t)0x77d43dc3, (q31_t)0x77d20822, (q31_t)0x77cfd236, (q31_t)0x77cd9c01, (q31_t)0x77cb6582, + (q31_t)0x77c92eb9, (q31_t)0x77c6f7a6, + (q31_t)0x77c4c04a, (q31_t)0x77c288a3, (q31_t)0x77c050b2, (q31_t)0x77be1878, (q31_t)0x77bbdff4, (q31_t)0x77b9a726, + (q31_t)0x77b76e0e, (q31_t)0x77b534ac, + (q31_t)0x77b2fb00, (q31_t)0x77b0c10b, (q31_t)0x77ae86cc, (q31_t)0x77ac4c43, (q31_t)0x77aa1170, (q31_t)0x77a7d653, + (q31_t)0x77a59aec, (q31_t)0x77a35f3c, + (q31_t)0x77a12342, (q31_t)0x779ee6fe, (q31_t)0x779caa70, (q31_t)0x779a6d99, (q31_t)0x77983077, (q31_t)0x7795f30c, + (q31_t)0x7793b557, (q31_t)0x77917759, + (q31_t)0x778f3910, (q31_t)0x778cfa7e, (q31_t)0x778abba2, (q31_t)0x77887c7d, (q31_t)0x77863d0d, (q31_t)0x7783fd54, + (q31_t)0x7781bd52, (q31_t)0x777f7d05, + (q31_t)0x777d3c6f, (q31_t)0x777afb8f, (q31_t)0x7778ba65, (q31_t)0x777678f2, (q31_t)0x77743735, (q31_t)0x7771f52e, + (q31_t)0x776fb2de, (q31_t)0x776d7044, + (q31_t)0x776b2d60, (q31_t)0x7768ea33, (q31_t)0x7766a6bc, (q31_t)0x776462fb, (q31_t)0x77621ef1, (q31_t)0x775fda9d, + (q31_t)0x775d95ff, (q31_t)0x775b5118, + (q31_t)0x77590be7, (q31_t)0x7756c66c, (q31_t)0x775480a8, (q31_t)0x77523a9b, (q31_t)0x774ff443, (q31_t)0x774dada2, + (q31_t)0x774b66b8, (q31_t)0x77491f84, + (q31_t)0x7746d806, (q31_t)0x7744903f, (q31_t)0x7742482e, (q31_t)0x773fffd4, (q31_t)0x773db730, (q31_t)0x773b6e42, + (q31_t)0x7739250b, (q31_t)0x7736db8b, + (q31_t)0x773491c0, (q31_t)0x773247ad, (q31_t)0x772ffd50, (q31_t)0x772db2a9, (q31_t)0x772b67b9, (q31_t)0x77291c7f, + (q31_t)0x7726d0fc, (q31_t)0x7724852f, + (q31_t)0x77223919, (q31_t)0x771fecb9, (q31_t)0x771da010, (q31_t)0x771b531d, (q31_t)0x771905e1, (q31_t)0x7716b85b, + (q31_t)0x77146a8c, (q31_t)0x77121c74, + (q31_t)0x770fce12, (q31_t)0x770d7f66, (q31_t)0x770b3072, (q31_t)0x7708e133, (q31_t)0x770691ab, (q31_t)0x770441da, + (q31_t)0x7701f1c0, (q31_t)0x76ffa15c, + (q31_t)0x76fd50ae, (q31_t)0x76faffb8, (q31_t)0x76f8ae78, (q31_t)0x76f65cee, (q31_t)0x76f40b1b, (q31_t)0x76f1b8ff, + (q31_t)0x76ef6699, (q31_t)0x76ed13ea, + (q31_t)0x76eac0f2, (q31_t)0x76e86db0, (q31_t)0x76e61a25, (q31_t)0x76e3c650, (q31_t)0x76e17233, (q31_t)0x76df1dcb, + (q31_t)0x76dcc91b, (q31_t)0x76da7421, + (q31_t)0x76d81ede, (q31_t)0x76d5c952, (q31_t)0x76d3737c, (q31_t)0x76d11d5d, (q31_t)0x76cec6f5, (q31_t)0x76cc7043, + (q31_t)0x76ca1948, (q31_t)0x76c7c204, + (q31_t)0x76c56a77, (q31_t)0x76c312a0, (q31_t)0x76c0ba80, (q31_t)0x76be6217, (q31_t)0x76bc0965, (q31_t)0x76b9b069, + (q31_t)0x76b75724, (q31_t)0x76b4fd96, + (q31_t)0x76b2a3bf, (q31_t)0x76b0499e, (q31_t)0x76adef34, (q31_t)0x76ab9481, (q31_t)0x76a93985, (q31_t)0x76a6de40, + (q31_t)0x76a482b1, (q31_t)0x76a226da, + (q31_t)0x769fcab9, (q31_t)0x769d6e4f, (q31_t)0x769b119b, (q31_t)0x7698b49f, (q31_t)0x76965759, (q31_t)0x7693f9ca, + (q31_t)0x76919bf3, (q31_t)0x768f3dd2, + (q31_t)0x768cdf67, (q31_t)0x768a80b4, (q31_t)0x768821b8, (q31_t)0x7685c272, (q31_t)0x768362e4, (q31_t)0x7681030c, + (q31_t)0x767ea2eb, (q31_t)0x767c4281, + (q31_t)0x7679e1ce, (q31_t)0x767780d2, (q31_t)0x76751f8d, (q31_t)0x7672bdfe, (q31_t)0x76705c27, (q31_t)0x766dfa07, + (q31_t)0x766b979d, (q31_t)0x766934eb, + (q31_t)0x7666d1ef, (q31_t)0x76646eab, (q31_t)0x76620b1d, (q31_t)0x765fa747, (q31_t)0x765d4327, (q31_t)0x765adebe, + (q31_t)0x76587a0d, (q31_t)0x76561512, + (q31_t)0x7653afce, (q31_t)0x76514a42, (q31_t)0x764ee46c, (q31_t)0x764c7e4d, (q31_t)0x764a17e6, (q31_t)0x7647b135, + (q31_t)0x76454a3c, (q31_t)0x7642e2f9, + (q31_t)0x76407b6e, (q31_t)0x763e139a, (q31_t)0x763bab7c, (q31_t)0x76394316, (q31_t)0x7636da67, (q31_t)0x7634716f, + (q31_t)0x7632082e, (q31_t)0x762f9ea4, + (q31_t)0x762d34d1, (q31_t)0x762acab6, (q31_t)0x76286051, (q31_t)0x7625f5a3, (q31_t)0x76238aad, (q31_t)0x76211f6e, + (q31_t)0x761eb3e6, (q31_t)0x761c4815, + (q31_t)0x7619dbfb, (q31_t)0x76176f98, (q31_t)0x761502ed, (q31_t)0x761295f9, (q31_t)0x761028bb, (q31_t)0x760dbb35, + (q31_t)0x760b4d67, (q31_t)0x7608df4f, + (q31_t)0x760670ee, (q31_t)0x76040245, (q31_t)0x76019353, (q31_t)0x75ff2418, (q31_t)0x75fcb495, (q31_t)0x75fa44c8, + (q31_t)0x75f7d4b3, (q31_t)0x75f56455, + (q31_t)0x75f2f3ae, (q31_t)0x75f082bf, (q31_t)0x75ee1187, (q31_t)0x75eba006, (q31_t)0x75e92e3c, (q31_t)0x75e6bc2a, + (q31_t)0x75e449ce, (q31_t)0x75e1d72b, + (q31_t)0x75df643e, (q31_t)0x75dcf109, (q31_t)0x75da7d8b, (q31_t)0x75d809c4, (q31_t)0x75d595b4, (q31_t)0x75d3215c, + (q31_t)0x75d0acbc, (q31_t)0x75ce37d2, + (q31_t)0x75cbc2a0, (q31_t)0x75c94d25, (q31_t)0x75c6d762, (q31_t)0x75c46156, (q31_t)0x75c1eb01, (q31_t)0x75bf7464, + (q31_t)0x75bcfd7e, (q31_t)0x75ba864f, + (q31_t)0x75b80ed8, (q31_t)0x75b59718, (q31_t)0x75b31f0f, (q31_t)0x75b0a6be, (q31_t)0x75ae2e25, (q31_t)0x75abb542, + (q31_t)0x75a93c18, (q31_t)0x75a6c2a4, + (q31_t)0x75a448e8, (q31_t)0x75a1cee4, (q31_t)0x759f5496, (q31_t)0x759cda01, (q31_t)0x759a5f22, (q31_t)0x7597e3fc, + (q31_t)0x7595688c, (q31_t)0x7592ecd4, + (q31_t)0x759070d4, (q31_t)0x758df48b, (q31_t)0x758b77fa, (q31_t)0x7588fb20, (q31_t)0x75867dfd, (q31_t)0x75840093, + (q31_t)0x758182df, (q31_t)0x757f04e3, + (q31_t)0x757c869f, (q31_t)0x757a0812, (q31_t)0x7577893d, (q31_t)0x75750a1f, (q31_t)0x75728ab9, (q31_t)0x75700b0a, + (q31_t)0x756d8b13, (q31_t)0x756b0ad3, + (q31_t)0x75688a4b, (q31_t)0x7566097b, (q31_t)0x75638862, (q31_t)0x75610701, (q31_t)0x755e8557, (q31_t)0x755c0365, + (q31_t)0x7559812b, (q31_t)0x7556fea8, + (q31_t)0x75547bdd, (q31_t)0x7551f8c9, (q31_t)0x754f756e, (q31_t)0x754cf1c9, (q31_t)0x754a6ddd, (q31_t)0x7547e9a8, + (q31_t)0x7545652a, (q31_t)0x7542e065, + (q31_t)0x75405b57, (q31_t)0x753dd600, (q31_t)0x753b5061, (q31_t)0x7538ca7b, (q31_t)0x7536444b, (q31_t)0x7533bdd4, + (q31_t)0x75313714, (q31_t)0x752eb00c, + (q31_t)0x752c28bb, (q31_t)0x7529a122, (q31_t)0x75271941, (q31_t)0x75249118, (q31_t)0x752208a7, (q31_t)0x751f7fed, + (q31_t)0x751cf6eb, (q31_t)0x751a6da0, + (q31_t)0x7517e40e, (q31_t)0x75155a33, (q31_t)0x7512d010, (q31_t)0x751045a5, (q31_t)0x750dbaf2, (q31_t)0x750b2ff6, + (q31_t)0x7508a4b2, (q31_t)0x75061926, + (q31_t)0x75038d52, (q31_t)0x75010136, (q31_t)0x74fe74d1, (q31_t)0x74fbe825, (q31_t)0x74f95b30, (q31_t)0x74f6cdf3, + (q31_t)0x74f4406d, (q31_t)0x74f1b2a0, + (q31_t)0x74ef248b, (q31_t)0x74ec962d, (q31_t)0x74ea0787, (q31_t)0x74e7789a, (q31_t)0x74e4e964, (q31_t)0x74e259e6, + (q31_t)0x74dfca20, (q31_t)0x74dd3a11, + (q31_t)0x74daa9bb, (q31_t)0x74d8191d, (q31_t)0x74d58836, (q31_t)0x74d2f708, (q31_t)0x74d06591, (q31_t)0x74cdd3d2, + (q31_t)0x74cb41cc, (q31_t)0x74c8af7d, + (q31_t)0x74c61ce6, (q31_t)0x74c38a07, (q31_t)0x74c0f6e0, (q31_t)0x74be6372, (q31_t)0x74bbcfbb, (q31_t)0x74b93bbc, + (q31_t)0x74b6a775, (q31_t)0x74b412e6, + (q31_t)0x74b17e0f, (q31_t)0x74aee8f0, (q31_t)0x74ac5389, (q31_t)0x74a9bddb, (q31_t)0x74a727e4, (q31_t)0x74a491a5, + (q31_t)0x74a1fb1e, (q31_t)0x749f6450, + (q31_t)0x749ccd39, (q31_t)0x749a35db, (q31_t)0x74979e34, (q31_t)0x74950646, (q31_t)0x74926e10, (q31_t)0x748fd592, + (q31_t)0x748d3ccb, (q31_t)0x748aa3be, + (q31_t)0x74880a68, (q31_t)0x748570ca, (q31_t)0x7482d6e4, (q31_t)0x74803cb7, (q31_t)0x747da242, (q31_t)0x747b0784, + (q31_t)0x74786c7f, (q31_t)0x7475d132, + (q31_t)0x7473359e, (q31_t)0x747099c1, (q31_t)0x746dfd9d, (q31_t)0x746b6131, (q31_t)0x7468c47c, (q31_t)0x74662781, + (q31_t)0x74638a3d, (q31_t)0x7460ecb2, + (q31_t)0x745e4ede, (q31_t)0x745bb0c3, (q31_t)0x74591261, (q31_t)0x745673b6, (q31_t)0x7453d4c4, (q31_t)0x7451358a, + (q31_t)0x744e9608, (q31_t)0x744bf63e, + (q31_t)0x7449562d, (q31_t)0x7446b5d4, (q31_t)0x74441533, (q31_t)0x7441744b, (q31_t)0x743ed31b, (q31_t)0x743c31a3, + (q31_t)0x74398fe3, (q31_t)0x7436eddc, + (q31_t)0x74344b8d, (q31_t)0x7431a8f6, (q31_t)0x742f0618, (q31_t)0x742c62f2, (q31_t)0x7429bf84, (q31_t)0x74271bcf, + (q31_t)0x742477d2, (q31_t)0x7421d38e, + (q31_t)0x741f2f01, (q31_t)0x741c8a2d, (q31_t)0x7419e512, (q31_t)0x74173faf, (q31_t)0x74149a04, (q31_t)0x7411f412, + (q31_t)0x740f4dd8, (q31_t)0x740ca756, + (q31_t)0x740a008d, (q31_t)0x7407597d, (q31_t)0x7404b224, (q31_t)0x74020a85, (q31_t)0x73ff629d, (q31_t)0x73fcba6e, + (q31_t)0x73fa11f8, (q31_t)0x73f7693a, + (q31_t)0x73f4c034, (q31_t)0x73f216e7, (q31_t)0x73ef6d53, (q31_t)0x73ecc377, (q31_t)0x73ea1953, (q31_t)0x73e76ee8, + (q31_t)0x73e4c435, (q31_t)0x73e2193b, + (q31_t)0x73df6df9, (q31_t)0x73dcc270, (q31_t)0x73da16a0, (q31_t)0x73d76a88, (q31_t)0x73d4be28, (q31_t)0x73d21182, + (q31_t)0x73cf6493, (q31_t)0x73ccb75d, + (q31_t)0x73ca09e0, (q31_t)0x73c75c1c, (q31_t)0x73c4ae10, (q31_t)0x73c1ffbc, (q31_t)0x73bf5121, (q31_t)0x73bca23f, + (q31_t)0x73b9f315, (q31_t)0x73b743a4, + (q31_t)0x73b493ec, (q31_t)0x73b1e3ec, (q31_t)0x73af33a5, (q31_t)0x73ac8316, (q31_t)0x73a9d240, (q31_t)0x73a72123, + (q31_t)0x73a46fbf, (q31_t)0x73a1be13, + (q31_t)0x739f0c20, (q31_t)0x739c59e5, (q31_t)0x7399a763, (q31_t)0x7396f49a, (q31_t)0x73944189, (q31_t)0x73918e32, + (q31_t)0x738eda93, (q31_t)0x738c26ac, + (q31_t)0x7389727f, (q31_t)0x7386be0a, (q31_t)0x7384094e, (q31_t)0x7381544a, (q31_t)0x737e9f00, (q31_t)0x737be96e, + (q31_t)0x73793395, (q31_t)0x73767d74, + (q31_t)0x7373c70d, (q31_t)0x7371105e, (q31_t)0x736e5968, (q31_t)0x736ba22b, (q31_t)0x7368eaa6, (q31_t)0x736632db, + (q31_t)0x73637ac8, (q31_t)0x7360c26e, + (q31_t)0x735e09cd, (q31_t)0x735b50e4, (q31_t)0x735897b5, (q31_t)0x7355de3e, (q31_t)0x73532481, (q31_t)0x73506a7c, + (q31_t)0x734db030, (q31_t)0x734af59d, + (q31_t)0x73483ac2, (q31_t)0x73457fa1, (q31_t)0x7342c438, (q31_t)0x73400889, (q31_t)0x733d4c92, (q31_t)0x733a9054, + (q31_t)0x7337d3d0, (q31_t)0x73351704, + (q31_t)0x733259f1, (q31_t)0x732f9c97, (q31_t)0x732cdef6, (q31_t)0x732a210d, (q31_t)0x732762de, (q31_t)0x7324a468, + (q31_t)0x7321e5ab, (q31_t)0x731f26a7, + (q31_t)0x731c675b, (q31_t)0x7319a7c9, (q31_t)0x7316e7f0, (q31_t)0x731427cf, (q31_t)0x73116768, (q31_t)0x730ea6ba, + (q31_t)0x730be5c5, (q31_t)0x73092489, + (q31_t)0x73066306, (q31_t)0x7303a13b, (q31_t)0x7300df2a, (q31_t)0x72fe1cd2, (q31_t)0x72fb5a34, (q31_t)0x72f8974e, + (q31_t)0x72f5d421, (q31_t)0x72f310ad, + (q31_t)0x72f04cf3, (q31_t)0x72ed88f1, (q31_t)0x72eac4a9, (q31_t)0x72e8001a, (q31_t)0x72e53b44, (q31_t)0x72e27627, + (q31_t)0x72dfb0c3, (q31_t)0x72dceb18, + (q31_t)0x72da2526, (q31_t)0x72d75eee, (q31_t)0x72d4986f, (q31_t)0x72d1d1a9, (q31_t)0x72cf0a9c, (q31_t)0x72cc4348, + (q31_t)0x72c97bad, (q31_t)0x72c6b3cc, + (q31_t)0x72c3eba4, (q31_t)0x72c12335, (q31_t)0x72be5a7f, (q31_t)0x72bb9183, (q31_t)0x72b8c83f, (q31_t)0x72b5feb5, + (q31_t)0x72b334e4, (q31_t)0x72b06acd, + (q31_t)0x72ada06f, (q31_t)0x72aad5c9, (q31_t)0x72a80ade, (q31_t)0x72a53fab, (q31_t)0x72a27432, (q31_t)0x729fa872, + (q31_t)0x729cdc6b, (q31_t)0x729a101e, + (q31_t)0x7297438a, (q31_t)0x729476af, (q31_t)0x7291a98e, (q31_t)0x728edc26, (q31_t)0x728c0e77, (q31_t)0x72894082, + (q31_t)0x72867245, (q31_t)0x7283a3c3, + (q31_t)0x7280d4f9, (q31_t)0x727e05e9, (q31_t)0x727b3693, (q31_t)0x727866f6, (q31_t)0x72759712, (q31_t)0x7272c6e7, + (q31_t)0x726ff676, (q31_t)0x726d25bf, + (q31_t)0x726a54c1, (q31_t)0x7267837c, (q31_t)0x7264b1f0, (q31_t)0x7261e01e, (q31_t)0x725f0e06, (q31_t)0x725c3ba7, + (q31_t)0x72596901, (q31_t)0x72569615, + (q31_t)0x7253c2e3, (q31_t)0x7250ef6a, (q31_t)0x724e1baa, (q31_t)0x724b47a4, (q31_t)0x72487357, (q31_t)0x72459ec4, + (q31_t)0x7242c9ea, (q31_t)0x723ff4ca, + (q31_t)0x723d1f63, (q31_t)0x723a49b6, (q31_t)0x723773c3, (q31_t)0x72349d89, (q31_t)0x7231c708, (q31_t)0x722ef041, + (q31_t)0x722c1934, (q31_t)0x722941e0, + (q31_t)0x72266a46, (q31_t)0x72239266, (q31_t)0x7220ba3f, (q31_t)0x721de1d1, (q31_t)0x721b091d, (q31_t)0x72183023, + (q31_t)0x721556e3, (q31_t)0x72127d5c, + (q31_t)0x720fa38e, (q31_t)0x720cc97b, (q31_t)0x7209ef21, (q31_t)0x72071480, (q31_t)0x7204399a, (q31_t)0x72015e6d, + (q31_t)0x71fe82f9, (q31_t)0x71fba740, + (q31_t)0x71f8cb40, (q31_t)0x71f5eefa, (q31_t)0x71f3126d, (q31_t)0x71f0359a, (q31_t)0x71ed5881, (q31_t)0x71ea7b22, + (q31_t)0x71e79d7c, (q31_t)0x71e4bf90, + (q31_t)0x71e1e15e, (q31_t)0x71df02e5, (q31_t)0x71dc2427, (q31_t)0x71d94522, (q31_t)0x71d665d6, (q31_t)0x71d38645, + (q31_t)0x71d0a66d, (q31_t)0x71cdc650, + (q31_t)0x71cae5ec, (q31_t)0x71c80542, (q31_t)0x71c52451, (q31_t)0x71c2431b, (q31_t)0x71bf619e, (q31_t)0x71bc7fdb, + (q31_t)0x71b99dd2, (q31_t)0x71b6bb83, + (q31_t)0x71b3d8ed, (q31_t)0x71b0f612, (q31_t)0x71ae12f0, (q31_t)0x71ab2f89, (q31_t)0x71a84bdb, (q31_t)0x71a567e7, + (q31_t)0x71a283ad, (q31_t)0x719f9f2c, + (q31_t)0x719cba66, (q31_t)0x7199d55a, (q31_t)0x7196f008, (q31_t)0x71940a6f, (q31_t)0x71912490, (q31_t)0x718e3e6c, + (q31_t)0x718b5801, (q31_t)0x71887151, + (q31_t)0x71858a5a, (q31_t)0x7182a31d, (q31_t)0x717fbb9a, (q31_t)0x717cd3d2, (q31_t)0x7179ebc3, (q31_t)0x7177036e, + (q31_t)0x71741ad3, (q31_t)0x717131f3, + (q31_t)0x716e48cc, (q31_t)0x716b5f5f, (q31_t)0x716875ad, (q31_t)0x71658bb4, (q31_t)0x7162a175, (q31_t)0x715fb6f1, + (q31_t)0x715ccc26, (q31_t)0x7159e116, + (q31_t)0x7156f5c0, (q31_t)0x71540a24, (q31_t)0x71511e42, (q31_t)0x714e321a, (q31_t)0x714b45ac, (q31_t)0x714858f8, + (q31_t)0x71456bfe, (q31_t)0x71427ebf, + (q31_t)0x713f9139, (q31_t)0x713ca36e, (q31_t)0x7139b55d, (q31_t)0x7136c706, (q31_t)0x7133d869, (q31_t)0x7130e987, + (q31_t)0x712dfa5e, (q31_t)0x712b0af0, + (q31_t)0x71281b3c, (q31_t)0x71252b42, (q31_t)0x71223b02, (q31_t)0x711f4a7d, (q31_t)0x711c59b2, (q31_t)0x711968a1, + (q31_t)0x7116774a, (q31_t)0x711385ad, + (q31_t)0x711093cb, (q31_t)0x710da1a3, (q31_t)0x710aaf35, (q31_t)0x7107bc82, (q31_t)0x7104c989, (q31_t)0x7101d64a, + (q31_t)0x70fee2c5, (q31_t)0x70fbeefb, + (q31_t)0x70f8faeb, (q31_t)0x70f60695, (q31_t)0x70f311fa, (q31_t)0x70f01d19, (q31_t)0x70ed27f2, (q31_t)0x70ea3286, + (q31_t)0x70e73cd4, (q31_t)0x70e446dc, + (q31_t)0x70e1509f, (q31_t)0x70de5a1c, (q31_t)0x70db6353, (q31_t)0x70d86c45, (q31_t)0x70d574f1, (q31_t)0x70d27d58, + (q31_t)0x70cf8579, (q31_t)0x70cc8d54, + (q31_t)0x70c994ea, (q31_t)0x70c69c3a, (q31_t)0x70c3a345, (q31_t)0x70c0aa0a, (q31_t)0x70bdb08a, (q31_t)0x70bab6c4, + (q31_t)0x70b7bcb8, (q31_t)0x70b4c267, + (q31_t)0x70b1c7d1, (q31_t)0x70aeccf5, (q31_t)0x70abd1d3, (q31_t)0x70a8d66c, (q31_t)0x70a5dac0, (q31_t)0x70a2dece, + (q31_t)0x709fe296, (q31_t)0x709ce619, + (q31_t)0x7099e957, (q31_t)0x7096ec4f, (q31_t)0x7093ef01, (q31_t)0x7090f16e, (q31_t)0x708df396, (q31_t)0x708af579, + (q31_t)0x7087f715, (q31_t)0x7084f86d, + (q31_t)0x7081f97f, (q31_t)0x707efa4c, (q31_t)0x707bfad3, (q31_t)0x7078fb15, (q31_t)0x7075fb11, (q31_t)0x7072fac9, + (q31_t)0x706ffa3a, (q31_t)0x706cf967, + (q31_t)0x7069f84e, (q31_t)0x7066f6f0, (q31_t)0x7063f54c, (q31_t)0x7060f363, (q31_t)0x705df135, (q31_t)0x705aeec1, + (q31_t)0x7057ec08, (q31_t)0x7054e90a, + (q31_t)0x7051e5c7, (q31_t)0x704ee23e, (q31_t)0x704bde70, (q31_t)0x7048da5d, (q31_t)0x7045d604, (q31_t)0x7042d166, + (q31_t)0x703fcc83, (q31_t)0x703cc75b, + (q31_t)0x7039c1ed, (q31_t)0x7036bc3b, (q31_t)0x7033b643, (q31_t)0x7030b005, (q31_t)0x702da983, (q31_t)0x702aa2bb, + (q31_t)0x70279baf, (q31_t)0x7024945d, + (q31_t)0x70218cc6, (q31_t)0x701e84e9, (q31_t)0x701b7cc8, (q31_t)0x70187461, (q31_t)0x70156bb5, (q31_t)0x701262c4, + (q31_t)0x700f598e, (q31_t)0x700c5013, + (q31_t)0x70094653, (q31_t)0x70063c4e, (q31_t)0x70033203, (q31_t)0x70002774, (q31_t)0x6ffd1c9f, (q31_t)0x6ffa1185, + (q31_t)0x6ff70626, (q31_t)0x6ff3fa82, + (q31_t)0x6ff0ee99, (q31_t)0x6fede26b, (q31_t)0x6fead5f8, (q31_t)0x6fe7c940, (q31_t)0x6fe4bc43, (q31_t)0x6fe1af01, + (q31_t)0x6fdea17a, (q31_t)0x6fdb93ae, + (q31_t)0x6fd8859d, (q31_t)0x6fd57746, (q31_t)0x6fd268ab, (q31_t)0x6fcf59cb, (q31_t)0x6fcc4aa6, (q31_t)0x6fc93b3c, + (q31_t)0x6fc62b8d, (q31_t)0x6fc31b99, + (q31_t)0x6fc00b60, (q31_t)0x6fbcfae2, (q31_t)0x6fb9ea20, (q31_t)0x6fb6d918, (q31_t)0x6fb3c7cb, (q31_t)0x6fb0b63a, + (q31_t)0x6fada464, (q31_t)0x6faa9248, + (q31_t)0x6fa77fe8, (q31_t)0x6fa46d43, (q31_t)0x6fa15a59, (q31_t)0x6f9e472b, (q31_t)0x6f9b33b7, (q31_t)0x6f981fff, + (q31_t)0x6f950c01, (q31_t)0x6f91f7bf, + (q31_t)0x6f8ee338, (q31_t)0x6f8bce6c, (q31_t)0x6f88b95c, (q31_t)0x6f85a407, (q31_t)0x6f828e6c, (q31_t)0x6f7f788d, + (q31_t)0x6f7c626a, (q31_t)0x6f794c01, + (q31_t)0x6f763554, (q31_t)0x6f731e62, (q31_t)0x6f70072b, (q31_t)0x6f6cefb0, (q31_t)0x6f69d7f0, (q31_t)0x6f66bfeb, + (q31_t)0x6f63a7a1, (q31_t)0x6f608f13, + (q31_t)0x6f5d7640, (q31_t)0x6f5a5d28, (q31_t)0x6f5743cb, (q31_t)0x6f542a2a, (q31_t)0x6f511044, (q31_t)0x6f4df61a, + (q31_t)0x6f4adbab, (q31_t)0x6f47c0f7, + (q31_t)0x6f44a5ff, (q31_t)0x6f418ac2, (q31_t)0x6f3e6f40, (q31_t)0x6f3b537a, (q31_t)0x6f38376f, (q31_t)0x6f351b1f, + (q31_t)0x6f31fe8b, (q31_t)0x6f2ee1b2, + (q31_t)0x6f2bc495, (q31_t)0x6f28a733, (q31_t)0x6f25898d, (q31_t)0x6f226ba2, (q31_t)0x6f1f4d72, (q31_t)0x6f1c2efe, + (q31_t)0x6f191045, (q31_t)0x6f15f148, + (q31_t)0x6f12d206, (q31_t)0x6f0fb280, (q31_t)0x6f0c92b6, (q31_t)0x6f0972a6, (q31_t)0x6f065253, (q31_t)0x6f0331ba, + (q31_t)0x6f0010de, (q31_t)0x6efcefbd, + (q31_t)0x6ef9ce57, (q31_t)0x6ef6acad, (q31_t)0x6ef38abe, (q31_t)0x6ef0688b, (q31_t)0x6eed4614, (q31_t)0x6eea2358, + (q31_t)0x6ee70058, (q31_t)0x6ee3dd13, + (q31_t)0x6ee0b98a, (q31_t)0x6edd95bd, (q31_t)0x6eda71ab, (q31_t)0x6ed74d55, (q31_t)0x6ed428ba, (q31_t)0x6ed103db, + (q31_t)0x6ecddeb8, (q31_t)0x6ecab950, + (q31_t)0x6ec793a4, (q31_t)0x6ec46db4, (q31_t)0x6ec1477f, (q31_t)0x6ebe2106, (q31_t)0x6ebafa49, (q31_t)0x6eb7d347, + (q31_t)0x6eb4ac02, (q31_t)0x6eb18477, + (q31_t)0x6eae5ca9, (q31_t)0x6eab3496, (q31_t)0x6ea80c3f, (q31_t)0x6ea4e3a4, (q31_t)0x6ea1bac4, (q31_t)0x6e9e91a1, + (q31_t)0x6e9b6839, (q31_t)0x6e983e8d, + (q31_t)0x6e95149c, (q31_t)0x6e91ea67, (q31_t)0x6e8ebfef, (q31_t)0x6e8b9532, (q31_t)0x6e886a30, (q31_t)0x6e853eeb, + (q31_t)0x6e821361, (q31_t)0x6e7ee794, + (q31_t)0x6e7bbb82, (q31_t)0x6e788f2c, (q31_t)0x6e756291, (q31_t)0x6e7235b3, (q31_t)0x6e6f0890, (q31_t)0x6e6bdb2a, + (q31_t)0x6e68ad7f, (q31_t)0x6e657f90, + (q31_t)0x6e62515d, (q31_t)0x6e5f22e6, (q31_t)0x6e5bf42b, (q31_t)0x6e58c52c, (q31_t)0x6e5595e9, (q31_t)0x6e526662, + (q31_t)0x6e4f3696, (q31_t)0x6e4c0687, + (q31_t)0x6e48d633, (q31_t)0x6e45a59c, (q31_t)0x6e4274c1, (q31_t)0x6e3f43a1, (q31_t)0x6e3c123e, (q31_t)0x6e38e096, + (q31_t)0x6e35aeab, (q31_t)0x6e327c7b, + (q31_t)0x6e2f4a08, (q31_t)0x6e2c1750, (q31_t)0x6e28e455, (q31_t)0x6e25b115, (q31_t)0x6e227d92, (q31_t)0x6e1f49cb, + (q31_t)0x6e1c15c0, (q31_t)0x6e18e171, + (q31_t)0x6e15acde, (q31_t)0x6e127807, (q31_t)0x6e0f42ec, (q31_t)0x6e0c0d8e, (q31_t)0x6e08d7eb, (q31_t)0x6e05a205, + (q31_t)0x6e026bda, (q31_t)0x6dff356c, + (q31_t)0x6dfbfeba, (q31_t)0x6df8c7c4, (q31_t)0x6df5908b, (q31_t)0x6df2590d, (q31_t)0x6def214c, (q31_t)0x6debe947, + (q31_t)0x6de8b0fe, (q31_t)0x6de57871, + (q31_t)0x6de23fa0, (q31_t)0x6ddf068c, (q31_t)0x6ddbcd34, (q31_t)0x6dd89398, (q31_t)0x6dd559b9, (q31_t)0x6dd21f95, + (q31_t)0x6dcee52e, (q31_t)0x6dcbaa83, + (q31_t)0x6dc86f95, (q31_t)0x6dc53462, (q31_t)0x6dc1f8ec, (q31_t)0x6dbebd33, (q31_t)0x6dbb8135, (q31_t)0x6db844f4, + (q31_t)0x6db5086f, (q31_t)0x6db1cba7, + (q31_t)0x6dae8e9b, (q31_t)0x6dab514b, (q31_t)0x6da813b8, (q31_t)0x6da4d5e1, (q31_t)0x6da197c6, (q31_t)0x6d9e5968, + (q31_t)0x6d9b1ac6, (q31_t)0x6d97dbe0, + (q31_t)0x6d949cb7, (q31_t)0x6d915d4a, (q31_t)0x6d8e1d9a, (q31_t)0x6d8adda6, (q31_t)0x6d879d6e, (q31_t)0x6d845cf3, + (q31_t)0x6d811c35, (q31_t)0x6d7ddb33, + (q31_t)0x6d7a99ed, (q31_t)0x6d775864, (q31_t)0x6d741697, (q31_t)0x6d70d487, (q31_t)0x6d6d9233, (q31_t)0x6d6a4f9c, + (q31_t)0x6d670cc1, (q31_t)0x6d63c9a3, + (q31_t)0x6d608641, (q31_t)0x6d5d429c, (q31_t)0x6d59feb3, (q31_t)0x6d56ba87, (q31_t)0x6d537617, (q31_t)0x6d503164, + (q31_t)0x6d4cec6e, (q31_t)0x6d49a734, + (q31_t)0x6d4661b7, (q31_t)0x6d431bf6, (q31_t)0x6d3fd5f2, (q31_t)0x6d3c8fab, (q31_t)0x6d394920, (q31_t)0x6d360252, + (q31_t)0x6d32bb40, (q31_t)0x6d2f73eb, + (q31_t)0x6d2c2c53, (q31_t)0x6d28e477, (q31_t)0x6d259c58, (q31_t)0x6d2253f6, (q31_t)0x6d1f0b50, (q31_t)0x6d1bc267, + (q31_t)0x6d18793b, (q31_t)0x6d152fcc, + (q31_t)0x6d11e619, (q31_t)0x6d0e9c23, (q31_t)0x6d0b51e9, (q31_t)0x6d08076d, (q31_t)0x6d04bcad, (q31_t)0x6d0171aa, + (q31_t)0x6cfe2663, (q31_t)0x6cfadada, + (q31_t)0x6cf78f0d, (q31_t)0x6cf442fd, (q31_t)0x6cf0f6aa, (q31_t)0x6cedaa13, (q31_t)0x6cea5d3a, (q31_t)0x6ce7101d, + (q31_t)0x6ce3c2bd, (q31_t)0x6ce0751a, + (q31_t)0x6cdd2733, (q31_t)0x6cd9d90a, (q31_t)0x6cd68a9d, (q31_t)0x6cd33bed, (q31_t)0x6ccfecfa, (q31_t)0x6ccc9dc4, + (q31_t)0x6cc94e4b, (q31_t)0x6cc5fe8f, + (q31_t)0x6cc2ae90, (q31_t)0x6cbf5e4d, (q31_t)0x6cbc0dc8, (q31_t)0x6cb8bcff, (q31_t)0x6cb56bf4, (q31_t)0x6cb21aa5, + (q31_t)0x6caec913, (q31_t)0x6cab773e, + (q31_t)0x6ca82527, (q31_t)0x6ca4d2cc, (q31_t)0x6ca1802e, (q31_t)0x6c9e2d4d, (q31_t)0x6c9ada29, (q31_t)0x6c9786c2, + (q31_t)0x6c943318, (q31_t)0x6c90df2c, + (q31_t)0x6c8d8afc, (q31_t)0x6c8a3689, (q31_t)0x6c86e1d3, (q31_t)0x6c838cdb, (q31_t)0x6c80379f, (q31_t)0x6c7ce220, + (q31_t)0x6c798c5f, (q31_t)0x6c76365b, + (q31_t)0x6c72e013, (q31_t)0x6c6f8989, (q31_t)0x6c6c32bc, (q31_t)0x6c68dbac, (q31_t)0x6c658459, (q31_t)0x6c622cc4, + (q31_t)0x6c5ed4eb, (q31_t)0x6c5b7cd0, + (q31_t)0x6c582472, (q31_t)0x6c54cbd1, (q31_t)0x6c5172ed, (q31_t)0x6c4e19c6, (q31_t)0x6c4ac05d, (q31_t)0x6c4766b0, + (q31_t)0x6c440cc1, (q31_t)0x6c40b28f, + (q31_t)0x6c3d581b, (q31_t)0x6c39fd63, (q31_t)0x6c36a269, (q31_t)0x6c33472c, (q31_t)0x6c2febad, (q31_t)0x6c2c8fea, + (q31_t)0x6c2933e5, (q31_t)0x6c25d79d, + (q31_t)0x6c227b13, (q31_t)0x6c1f1e45, (q31_t)0x6c1bc136, (q31_t)0x6c1863e3, (q31_t)0x6c15064e, (q31_t)0x6c11a876, + (q31_t)0x6c0e4a5b, (q31_t)0x6c0aebfe, + (q31_t)0x6c078d5e, (q31_t)0x6c042e7b, (q31_t)0x6c00cf56, (q31_t)0x6bfd6fee, (q31_t)0x6bfa1044, (q31_t)0x6bf6b056, + (q31_t)0x6bf35027, (q31_t)0x6befefb5, + (q31_t)0x6bec8f00, (q31_t)0x6be92e08, (q31_t)0x6be5ccce, (q31_t)0x6be26b52, (q31_t)0x6bdf0993, (q31_t)0x6bdba791, + (q31_t)0x6bd8454d, (q31_t)0x6bd4e2c6, + (q31_t)0x6bd17ffd, (q31_t)0x6bce1cf1, (q31_t)0x6bcab9a3, (q31_t)0x6bc75613, (q31_t)0x6bc3f23f, (q31_t)0x6bc08e2a, + (q31_t)0x6bbd29d2, (q31_t)0x6bb9c537, + (q31_t)0x6bb6605a, (q31_t)0x6bb2fb3b, (q31_t)0x6baf95d9, (q31_t)0x6bac3034, (q31_t)0x6ba8ca4e, (q31_t)0x6ba56425, + (q31_t)0x6ba1fdb9, (q31_t)0x6b9e970b, + (q31_t)0x6b9b301b, (q31_t)0x6b97c8e8, (q31_t)0x6b946173, (q31_t)0x6b90f9bc, (q31_t)0x6b8d91c2, (q31_t)0x6b8a2986, + (q31_t)0x6b86c107, (q31_t)0x6b835846, + (q31_t)0x6b7fef43, (q31_t)0x6b7c85fe, (q31_t)0x6b791c76, (q31_t)0x6b75b2ac, (q31_t)0x6b7248a0, (q31_t)0x6b6ede51, + (q31_t)0x6b6b73c0, (q31_t)0x6b6808ed, + (q31_t)0x6b649dd8, (q31_t)0x6b613280, (q31_t)0x6b5dc6e6, (q31_t)0x6b5a5b0a, (q31_t)0x6b56eeec, (q31_t)0x6b53828b, + (q31_t)0x6b5015e9, (q31_t)0x6b4ca904, + (q31_t)0x6b493bdd, (q31_t)0x6b45ce73, (q31_t)0x6b4260c8, (q31_t)0x6b3ef2da, (q31_t)0x6b3b84ab, (q31_t)0x6b381639, + (q31_t)0x6b34a785, (q31_t)0x6b31388e, + (q31_t)0x6b2dc956, (q31_t)0x6b2a59dc, (q31_t)0x6b26ea1f, (q31_t)0x6b237a21, (q31_t)0x6b2009e0, (q31_t)0x6b1c995d, + (q31_t)0x6b192898, (q31_t)0x6b15b791, + (q31_t)0x6b124648, (q31_t)0x6b0ed4bd, (q31_t)0x6b0b62f0, (q31_t)0x6b07f0e1, (q31_t)0x6b047e90, (q31_t)0x6b010bfd, + (q31_t)0x6afd9928, (q31_t)0x6afa2610, + (q31_t)0x6af6b2b7, (q31_t)0x6af33f1c, (q31_t)0x6aefcb3f, (q31_t)0x6aec5720, (q31_t)0x6ae8e2bf, (q31_t)0x6ae56e1c, + (q31_t)0x6ae1f937, (q31_t)0x6ade8410, + (q31_t)0x6adb0ea8, (q31_t)0x6ad798fd, (q31_t)0x6ad42311, (q31_t)0x6ad0ace2, (q31_t)0x6acd3672, (q31_t)0x6ac9bfc0, + (q31_t)0x6ac648cb, (q31_t)0x6ac2d195, + (q31_t)0x6abf5a1e, (q31_t)0x6abbe264, (q31_t)0x6ab86a68, (q31_t)0x6ab4f22b, (q31_t)0x6ab179ac, (q31_t)0x6aae00eb, + (q31_t)0x6aaa87e8, (q31_t)0x6aa70ea4, + (q31_t)0x6aa3951d, (q31_t)0x6aa01b55, (q31_t)0x6a9ca14b, (q31_t)0x6a992700, (q31_t)0x6a95ac72, (q31_t)0x6a9231a3, + (q31_t)0x6a8eb692, (q31_t)0x6a8b3b3f, + (q31_t)0x6a87bfab, (q31_t)0x6a8443d5, (q31_t)0x6a80c7bd, (q31_t)0x6a7d4b64, (q31_t)0x6a79cec8, (q31_t)0x6a7651ec, + (q31_t)0x6a72d4cd, (q31_t)0x6a6f576d, + (q31_t)0x6a6bd9cb, (q31_t)0x6a685be8, (q31_t)0x6a64ddc2, (q31_t)0x6a615f5c, (q31_t)0x6a5de0b3, (q31_t)0x6a5a61c9, + (q31_t)0x6a56e29e, (q31_t)0x6a536331, + (q31_t)0x6a4fe382, (q31_t)0x6a4c6391, (q31_t)0x6a48e360, (q31_t)0x6a4562ec, (q31_t)0x6a41e237, (q31_t)0x6a3e6140, + (q31_t)0x6a3ae008, (q31_t)0x6a375e8f, + (q31_t)0x6a33dcd4, (q31_t)0x6a305ad7, (q31_t)0x6a2cd899, (q31_t)0x6a295619, (q31_t)0x6a25d358, (q31_t)0x6a225055, + (q31_t)0x6a1ecd11, (q31_t)0x6a1b498c, + (q31_t)0x6a17c5c5, (q31_t)0x6a1441bc, (q31_t)0x6a10bd72, (q31_t)0x6a0d38e7, (q31_t)0x6a09b41a, (q31_t)0x6a062f0c, + (q31_t)0x6a02a9bc, (q31_t)0x69ff242b, + (q31_t)0x69fb9e59, (q31_t)0x69f81845, (q31_t)0x69f491f0, (q31_t)0x69f10b5a, (q31_t)0x69ed8482, (q31_t)0x69e9fd69, + (q31_t)0x69e6760f, (q31_t)0x69e2ee73, + (q31_t)0x69df6696, (q31_t)0x69dbde77, (q31_t)0x69d85618, (q31_t)0x69d4cd77, (q31_t)0x69d14494, (q31_t)0x69cdbb71, + (q31_t)0x69ca320c, (q31_t)0x69c6a866, + (q31_t)0x69c31e7f, (q31_t)0x69bf9456, (q31_t)0x69bc09ec, (q31_t)0x69b87f41, (q31_t)0x69b4f455, (q31_t)0x69b16928, + (q31_t)0x69adddb9, (q31_t)0x69aa5209, + (q31_t)0x69a6c618, (q31_t)0x69a339e6, (q31_t)0x699fad73, (q31_t)0x699c20be, (q31_t)0x699893c9, (q31_t)0x69950692, + (q31_t)0x6991791a, (q31_t)0x698deb61, + (q31_t)0x698a5d67, (q31_t)0x6986cf2c, (q31_t)0x698340af, (q31_t)0x697fb1f2, (q31_t)0x697c22f3, (q31_t)0x697893b4, + (q31_t)0x69750433, (q31_t)0x69717472, + (q31_t)0x696de46f, (q31_t)0x696a542b, (q31_t)0x6966c3a6, (q31_t)0x696332e1, (q31_t)0x695fa1da, (q31_t)0x695c1092, + (q31_t)0x69587f09, (q31_t)0x6954ed40, + (q31_t)0x69515b35, (q31_t)0x694dc8e9, (q31_t)0x694a365c, (q31_t)0x6946a38f, (q31_t)0x69431080, (q31_t)0x693f7d31, + (q31_t)0x693be9a0, (q31_t)0x693855cf, + (q31_t)0x6934c1bd, (q31_t)0x69312d6a, (q31_t)0x692d98d6, (q31_t)0x692a0401, (q31_t)0x69266eeb, (q31_t)0x6922d995, + (q31_t)0x691f43fd, (q31_t)0x691bae25, + (q31_t)0x6918180c, (q31_t)0x691481b2, (q31_t)0x6910eb17, (q31_t)0x690d543b, (q31_t)0x6909bd1f, (q31_t)0x690625c2, + (q31_t)0x69028e24, (q31_t)0x68fef645, + (q31_t)0x68fb5e25, (q31_t)0x68f7c5c5, (q31_t)0x68f42d24, (q31_t)0x68f09442, (q31_t)0x68ecfb20, (q31_t)0x68e961bd, + (q31_t)0x68e5c819, (q31_t)0x68e22e34, + (q31_t)0x68de940f, (q31_t)0x68daf9a9, (q31_t)0x68d75f02, (q31_t)0x68d3c41b, (q31_t)0x68d028f2, (q31_t)0x68cc8d8a, + (q31_t)0x68c8f1e0, (q31_t)0x68c555f6, + (q31_t)0x68c1b9cc, (q31_t)0x68be1d61, (q31_t)0x68ba80b5, (q31_t)0x68b6e3c8, (q31_t)0x68b3469b, (q31_t)0x68afa92e, + (q31_t)0x68ac0b7f, (q31_t)0x68a86d91, + (q31_t)0x68a4cf61, (q31_t)0x68a130f1, (q31_t)0x689d9241, (q31_t)0x6899f350, (q31_t)0x6896541f, (q31_t)0x6892b4ad, + (q31_t)0x688f14fa, (q31_t)0x688b7507, + (q31_t)0x6887d4d4, (q31_t)0x68843460, (q31_t)0x688093ab, (q31_t)0x687cf2b6, (q31_t)0x68795181, (q31_t)0x6875b00b, + (q31_t)0x68720e55, (q31_t)0x686e6c5e, + (q31_t)0x686aca27, (q31_t)0x686727b0, (q31_t)0x686384f8, (q31_t)0x685fe200, (q31_t)0x685c3ec7, (q31_t)0x68589b4e, + (q31_t)0x6854f795, (q31_t)0x6851539b, + (q31_t)0x684daf61, (q31_t)0x684a0ae6, (q31_t)0x6846662c, (q31_t)0x6842c131, (q31_t)0x683f1bf5, (q31_t)0x683b7679, + (q31_t)0x6837d0bd, (q31_t)0x68342ac1, + (q31_t)0x68308485, (q31_t)0x682cde08, (q31_t)0x6829374b, (q31_t)0x6825904d, (q31_t)0x6821e910, (q31_t)0x681e4192, + (q31_t)0x681a99d4, (q31_t)0x6816f1d6, + (q31_t)0x68134997, (q31_t)0x680fa118, (q31_t)0x680bf85a, (q31_t)0x68084f5a, (q31_t)0x6804a61b, (q31_t)0x6800fc9c, + (q31_t)0x67fd52dc, (q31_t)0x67f9a8dd, + (q31_t)0x67f5fe9d, (q31_t)0x67f2541d, (q31_t)0x67eea95d, (q31_t)0x67eafe5d, (q31_t)0x67e7531c, (q31_t)0x67e3a79c, + (q31_t)0x67dffbdc, (q31_t)0x67dc4fdb, + (q31_t)0x67d8a39a, (q31_t)0x67d4f71a, (q31_t)0x67d14a59, (q31_t)0x67cd9d58, (q31_t)0x67c9f017, (q31_t)0x67c64297, + (q31_t)0x67c294d6, (q31_t)0x67bee6d5, + (q31_t)0x67bb3894, (q31_t)0x67b78a13, (q31_t)0x67b3db53, (q31_t)0x67b02c52, (q31_t)0x67ac7d11, (q31_t)0x67a8cd91, + (q31_t)0x67a51dd0, (q31_t)0x67a16dcf, + (q31_t)0x679dbd8f, (q31_t)0x679a0d0f, (q31_t)0x67965c4e, (q31_t)0x6792ab4e, (q31_t)0x678efa0e, (q31_t)0x678b488e, + (q31_t)0x678796ce, (q31_t)0x6783e4cf, + (q31_t)0x6780328f, (q31_t)0x677c8010, (q31_t)0x6778cd50, (q31_t)0x67751a51, (q31_t)0x67716713, (q31_t)0x676db394, + (q31_t)0x6769ffd5, (q31_t)0x67664bd7, + (q31_t)0x67629799, (q31_t)0x675ee31b, (q31_t)0x675b2e5e, (q31_t)0x67577960, (q31_t)0x6753c423, (q31_t)0x67500ea7, + (q31_t)0x674c58ea, (q31_t)0x6748a2ee, + (q31_t)0x6744ecb2, (q31_t)0x67413636, (q31_t)0x673d7f7b, (q31_t)0x6739c880, (q31_t)0x67361145, (q31_t)0x673259ca, + (q31_t)0x672ea210, (q31_t)0x672aea17, + (q31_t)0x672731dd, (q31_t)0x67237964, (q31_t)0x671fc0ac, (q31_t)0x671c07b4, (q31_t)0x67184e7c, (q31_t)0x67149504, + (q31_t)0x6710db4d, (q31_t)0x670d2157, + (q31_t)0x67096721, (q31_t)0x6705acab, (q31_t)0x6701f1f6, (q31_t)0x66fe3701, (q31_t)0x66fa7bcd, (q31_t)0x66f6c059, + (q31_t)0x66f304a6, (q31_t)0x66ef48b3, + (q31_t)0x66eb8c80, (q31_t)0x66e7d00f, (q31_t)0x66e4135d, (q31_t)0x66e0566c, (q31_t)0x66dc993c, (q31_t)0x66d8dbcd, + (q31_t)0x66d51e1d, (q31_t)0x66d1602f, + (q31_t)0x66cda201, (q31_t)0x66c9e393, (q31_t)0x66c624e7, (q31_t)0x66c265fa, (q31_t)0x66bea6cf, (q31_t)0x66bae764, + (q31_t)0x66b727ba, (q31_t)0x66b367d0, + (q31_t)0x66afa7a7, (q31_t)0x66abe73f, (q31_t)0x66a82697, (q31_t)0x66a465b0, (q31_t)0x66a0a489, (q31_t)0x669ce324, + (q31_t)0x6699217f, (q31_t)0x66955f9b, + (q31_t)0x66919d77, (q31_t)0x668ddb14, (q31_t)0x668a1872, (q31_t)0x66865591, (q31_t)0x66829270, (q31_t)0x667ecf11, + (q31_t)0x667b0b72, (q31_t)0x66774793, + (q31_t)0x66738376, (q31_t)0x666fbf19, (q31_t)0x666bfa7d, (q31_t)0x666835a2, (q31_t)0x66647088, (q31_t)0x6660ab2f, + (q31_t)0x665ce596, (q31_t)0x66591fbf, + (q31_t)0x665559a8, (q31_t)0x66519352, (q31_t)0x664dccbd, (q31_t)0x664a05e9, (q31_t)0x66463ed6, (q31_t)0x66427784, + (q31_t)0x663eaff2, (q31_t)0x663ae822, + (q31_t)0x66372012, (q31_t)0x663357c4, (q31_t)0x662f8f36, (q31_t)0x662bc66a, (q31_t)0x6627fd5e, (q31_t)0x66243413, + (q31_t)0x66206a8a, (q31_t)0x661ca0c1, + (q31_t)0x6618d6b9, (q31_t)0x66150c73, (q31_t)0x661141ed, (q31_t)0x660d7729, (q31_t)0x6609ac25, (q31_t)0x6605e0e3, + (q31_t)0x66021561, (q31_t)0x65fe49a1, + (q31_t)0x65fa7da2, (q31_t)0x65f6b164, (q31_t)0x65f2e4e7, (q31_t)0x65ef182b, (q31_t)0x65eb4b30, (q31_t)0x65e77df6, + (q31_t)0x65e3b07e, (q31_t)0x65dfe2c6, + (q31_t)0x65dc14d0, (q31_t)0x65d8469b, (q31_t)0x65d47827, (q31_t)0x65d0a975, (q31_t)0x65ccda83, (q31_t)0x65c90b53, + (q31_t)0x65c53be4, (q31_t)0x65c16c36, + (q31_t)0x65bd9c49, (q31_t)0x65b9cc1e, (q31_t)0x65b5fbb4, (q31_t)0x65b22b0b, (q31_t)0x65ae5a23, (q31_t)0x65aa88fd, + (q31_t)0x65a6b798, (q31_t)0x65a2e5f4, + (q31_t)0x659f1412, (q31_t)0x659b41f1, (q31_t)0x65976f91, (q31_t)0x65939cf3, (q31_t)0x658fca15, (q31_t)0x658bf6fa, + (q31_t)0x6588239f, (q31_t)0x65845006, + (q31_t)0x65807c2f, (q31_t)0x657ca818, (q31_t)0x6578d3c4, (q31_t)0x6574ff30, (q31_t)0x65712a5e, (q31_t)0x656d554d, + (q31_t)0x65697ffe, (q31_t)0x6565aa71, + (q31_t)0x6561d4a4, (q31_t)0x655dfe99, (q31_t)0x655a2850, (q31_t)0x655651c8, (q31_t)0x65527b02, (q31_t)0x654ea3fd, + (q31_t)0x654accba, (q31_t)0x6546f538, + (q31_t)0x65431d77, (q31_t)0x653f4579, (q31_t)0x653b6d3b, (q31_t)0x653794c0, (q31_t)0x6533bc06, (q31_t)0x652fe30d, + (q31_t)0x652c09d6, (q31_t)0x65283061, + (q31_t)0x652456ad, (q31_t)0x65207cbb, (q31_t)0x651ca28a, (q31_t)0x6518c81b, (q31_t)0x6514ed6e, (q31_t)0x65111283, + (q31_t)0x650d3759, (q31_t)0x65095bf0, + (q31_t)0x6505804a, (q31_t)0x6501a465, (q31_t)0x64fdc841, (q31_t)0x64f9ebe0, (q31_t)0x64f60f40, (q31_t)0x64f23262, + (q31_t)0x64ee5546, (q31_t)0x64ea77eb, + (q31_t)0x64e69a52, (q31_t)0x64e2bc7b, (q31_t)0x64dede66, (q31_t)0x64db0012, (q31_t)0x64d72180, (q31_t)0x64d342b0, + (q31_t)0x64cf63a2, (q31_t)0x64cb8456, + (q31_t)0x64c7a4cb, (q31_t)0x64c3c502, (q31_t)0x64bfe4fc, (q31_t)0x64bc04b6, (q31_t)0x64b82433, (q31_t)0x64b44372, + (q31_t)0x64b06273, (q31_t)0x64ac8135, + (q31_t)0x64a89fba, (q31_t)0x64a4be00, (q31_t)0x64a0dc08, (q31_t)0x649cf9d2, (q31_t)0x6499175e, (q31_t)0x649534ac, + (q31_t)0x649151bc, (q31_t)0x648d6e8e, + (q31_t)0x64898b22, (q31_t)0x6485a778, (q31_t)0x6481c390, (q31_t)0x647ddf6a, (q31_t)0x6479fb06, (q31_t)0x64761664, + (q31_t)0x64723184, (q31_t)0x646e4c66, + (q31_t)0x646a670a, (q31_t)0x64668170, (q31_t)0x64629b98, (q31_t)0x645eb582, (q31_t)0x645acf2e, (q31_t)0x6456e89d, + (q31_t)0x645301cd, (q31_t)0x644f1ac0, + (q31_t)0x644b3375, (q31_t)0x64474bec, (q31_t)0x64436425, (q31_t)0x643f7c20, (q31_t)0x643b93dd, (q31_t)0x6437ab5d, + (q31_t)0x6433c29f, (q31_t)0x642fd9a3, + (q31_t)0x642bf069, (q31_t)0x642806f1, (q31_t)0x64241d3c, (q31_t)0x64203348, (q31_t)0x641c4917, (q31_t)0x64185ea9, + (q31_t)0x641473fc, (q31_t)0x64108912, + (q31_t)0x640c9dea, (q31_t)0x6408b284, (q31_t)0x6404c6e1, (q31_t)0x6400db00, (q31_t)0x63fceee1, (q31_t)0x63f90285, + (q31_t)0x63f515eb, (q31_t)0x63f12913, + (q31_t)0x63ed3bfd, (q31_t)0x63e94eaa, (q31_t)0x63e5611a, (q31_t)0x63e1734b, (q31_t)0x63dd853f, (q31_t)0x63d996f6, + (q31_t)0x63d5a86f, (q31_t)0x63d1b9aa, + (q31_t)0x63cdcaa8, (q31_t)0x63c9db68, (q31_t)0x63c5ebeb, (q31_t)0x63c1fc30, (q31_t)0x63be0c37, (q31_t)0x63ba1c01, + (q31_t)0x63b62b8e, (q31_t)0x63b23add, + (q31_t)0x63ae49ee, (q31_t)0x63aa58c2, (q31_t)0x63a66759, (q31_t)0x63a275b2, (q31_t)0x639e83cd, (q31_t)0x639a91ac, + (q31_t)0x63969f4c, (q31_t)0x6392acaf, + (q31_t)0x638eb9d5, (q31_t)0x638ac6be, (q31_t)0x6386d369, (q31_t)0x6382dfd6, (q31_t)0x637eec07, (q31_t)0x637af7fa, + (q31_t)0x637703af, (q31_t)0x63730f27, + (q31_t)0x636f1a62, (q31_t)0x636b2560, (q31_t)0x63673020, (q31_t)0x63633aa3, (q31_t)0x635f44e8, (q31_t)0x635b4ef0, + (q31_t)0x635758bb, (q31_t)0x63536249, + (q31_t)0x634f6b99, (q31_t)0x634b74ad, (q31_t)0x63477d82, (q31_t)0x6343861b, (q31_t)0x633f8e76, (q31_t)0x633b9695, + (q31_t)0x63379e76, (q31_t)0x6333a619, + (q31_t)0x632fad80, (q31_t)0x632bb4a9, (q31_t)0x6327bb96, (q31_t)0x6323c245, (q31_t)0x631fc8b7, (q31_t)0x631bceeb, + (q31_t)0x6317d4e3, (q31_t)0x6313da9e, + (q31_t)0x630fe01b, (q31_t)0x630be55b, (q31_t)0x6307ea5e, (q31_t)0x6303ef25, (q31_t)0x62fff3ae, (q31_t)0x62fbf7fa, + (q31_t)0x62f7fc08, (q31_t)0x62f3ffda, + (q31_t)0x62f0036f, (q31_t)0x62ec06c7, (q31_t)0x62e809e2, (q31_t)0x62e40cbf, (q31_t)0x62e00f60, (q31_t)0x62dc11c4, + (q31_t)0x62d813eb, (q31_t)0x62d415d4, + (q31_t)0x62d01781, (q31_t)0x62cc18f1, (q31_t)0x62c81a24, (q31_t)0x62c41b1a, (q31_t)0x62c01bd3, (q31_t)0x62bc1c4f, + (q31_t)0x62b81c8f, (q31_t)0x62b41c91, + (q31_t)0x62b01c57, (q31_t)0x62ac1bdf, (q31_t)0x62a81b2b, (q31_t)0x62a41a3a, (q31_t)0x62a0190c, (q31_t)0x629c17a1, + (q31_t)0x629815fa, (q31_t)0x62941415, + (q31_t)0x629011f4, (q31_t)0x628c0f96, (q31_t)0x62880cfb, (q31_t)0x62840a23, (q31_t)0x6280070f, (q31_t)0x627c03be, + (q31_t)0x62780030, (q31_t)0x6273fc65, + (q31_t)0x626ff85e, (q31_t)0x626bf41a, (q31_t)0x6267ef99, (q31_t)0x6263eadc, (q31_t)0x625fe5e1, (q31_t)0x625be0ab, + (q31_t)0x6257db37, (q31_t)0x6253d587, + (q31_t)0x624fcf9a, (q31_t)0x624bc970, (q31_t)0x6247c30a, (q31_t)0x6243bc68, (q31_t)0x623fb588, (q31_t)0x623bae6c, + (q31_t)0x6237a714, (q31_t)0x62339f7e, + (q31_t)0x622f97ad, (q31_t)0x622b8f9e, (q31_t)0x62278754, (q31_t)0x62237ecc, (q31_t)0x621f7608, (q31_t)0x621b6d08, + (q31_t)0x621763cb, (q31_t)0x62135a51, + (q31_t)0x620f509b, (q31_t)0x620b46a9, (q31_t)0x62073c7a, (q31_t)0x6203320e, (q31_t)0x61ff2766, (q31_t)0x61fb1c82, + (q31_t)0x61f71161, (q31_t)0x61f30604, + (q31_t)0x61eefa6b, (q31_t)0x61eaee95, (q31_t)0x61e6e282, (q31_t)0x61e2d633, (q31_t)0x61dec9a8, (q31_t)0x61dabce0, + (q31_t)0x61d6afdd, (q31_t)0x61d2a29c, + (q31_t)0x61ce9520, (q31_t)0x61ca8767, (q31_t)0x61c67971, (q31_t)0x61c26b40, (q31_t)0x61be5cd2, (q31_t)0x61ba4e28, + (q31_t)0x61b63f41, (q31_t)0x61b2301e, + (q31_t)0x61ae20bf, (q31_t)0x61aa1124, (q31_t)0x61a6014d, (q31_t)0x61a1f139, (q31_t)0x619de0e9, (q31_t)0x6199d05d, + (q31_t)0x6195bf94, (q31_t)0x6191ae90, + (q31_t)0x618d9d4f, (q31_t)0x61898bd2, (q31_t)0x61857a19, (q31_t)0x61816824, (q31_t)0x617d55f2, (q31_t)0x61794385, + (q31_t)0x617530db, (q31_t)0x61711df5, + (q31_t)0x616d0ad3, (q31_t)0x6168f775, (q31_t)0x6164e3db, (q31_t)0x6160d005, (q31_t)0x615cbbf3, (q31_t)0x6158a7a4, + (q31_t)0x6154931a, (q31_t)0x61507e54, + (q31_t)0x614c6951, (q31_t)0x61485413, (q31_t)0x61443e98, (q31_t)0x614028e2, (q31_t)0x613c12f0, (q31_t)0x6137fcc1, + (q31_t)0x6133e657, (q31_t)0x612fcfb0, + (q31_t)0x612bb8ce, (q31_t)0x6127a1b0, (q31_t)0x61238a56, (q31_t)0x611f72c0, (q31_t)0x611b5aee, (q31_t)0x611742e0, + (q31_t)0x61132a96, (q31_t)0x610f1210, + (q31_t)0x610af94f, (q31_t)0x6106e051, (q31_t)0x6102c718, (q31_t)0x60feada3, (q31_t)0x60fa93f2, (q31_t)0x60f67a05, + (q31_t)0x60f25fdd, (q31_t)0x60ee4579, + (q31_t)0x60ea2ad8, (q31_t)0x60e60ffd, (q31_t)0x60e1f4e5, (q31_t)0x60ddd991, (q31_t)0x60d9be02, (q31_t)0x60d5a237, + (q31_t)0x60d18631, (q31_t)0x60cd69ee, + (q31_t)0x60c94d70, (q31_t)0x60c530b6, (q31_t)0x60c113c1, (q31_t)0x60bcf690, (q31_t)0x60b8d923, (q31_t)0x60b4bb7a, + (q31_t)0x60b09d96, (q31_t)0x60ac7f76, + (q31_t)0x60a8611b, (q31_t)0x60a44284, (q31_t)0x60a023b1, (q31_t)0x609c04a3, (q31_t)0x6097e559, (q31_t)0x6093c5d3, + (q31_t)0x608fa612, (q31_t)0x608b8616, + (q31_t)0x608765dd, (q31_t)0x6083456a, (q31_t)0x607f24ba, (q31_t)0x607b03d0, (q31_t)0x6076e2a9, (q31_t)0x6072c148, + (q31_t)0x606e9faa, (q31_t)0x606a7dd2, + (q31_t)0x60665bbd, (q31_t)0x6062396e, (q31_t)0x605e16e2, (q31_t)0x6059f41c, (q31_t)0x6055d11a, (q31_t)0x6051addc, + (q31_t)0x604d8a63, (q31_t)0x604966af, + (q31_t)0x604542bf, (q31_t)0x60411e94, (q31_t)0x603cfa2e, (q31_t)0x6038d58c, (q31_t)0x6034b0af, (q31_t)0x60308b97, + (q31_t)0x602c6643, (q31_t)0x602840b4, + (q31_t)0x60241ae9, (q31_t)0x601ff4e3, (q31_t)0x601bcea2, (q31_t)0x6017a826, (q31_t)0x6013816e, (q31_t)0x600f5a7b, + (q31_t)0x600b334d, (q31_t)0x60070be4, + (q31_t)0x6002e43f, (q31_t)0x5ffebc5f, (q31_t)0x5ffa9444, (q31_t)0x5ff66bee, (q31_t)0x5ff2435d, (q31_t)0x5fee1a90, + (q31_t)0x5fe9f188, (q31_t)0x5fe5c845, + (q31_t)0x5fe19ec7, (q31_t)0x5fdd750e, (q31_t)0x5fd94b19, (q31_t)0x5fd520ea, (q31_t)0x5fd0f67f, (q31_t)0x5fcccbd9, + (q31_t)0x5fc8a0f8, (q31_t)0x5fc475dc, + (q31_t)0x5fc04a85, (q31_t)0x5fbc1ef3, (q31_t)0x5fb7f326, (q31_t)0x5fb3c71e, (q31_t)0x5faf9adb, (q31_t)0x5fab6e5d, + (q31_t)0x5fa741a3, (q31_t)0x5fa314af, + (q31_t)0x5f9ee780, (q31_t)0x5f9aba16, (q31_t)0x5f968c70, (q31_t)0x5f925e90, (q31_t)0x5f8e3075, (q31_t)0x5f8a021f, + (q31_t)0x5f85d38e, (q31_t)0x5f81a4c2, + (q31_t)0x5f7d75bb, (q31_t)0x5f794679, (q31_t)0x5f7516fd, (q31_t)0x5f70e745, (q31_t)0x5f6cb753, (q31_t)0x5f688726, + (q31_t)0x5f6456be, (q31_t)0x5f60261b, + (q31_t)0x5f5bf53d, (q31_t)0x5f57c424, (q31_t)0x5f5392d1, (q31_t)0x5f4f6143, (q31_t)0x5f4b2f7a, (q31_t)0x5f46fd76, + (q31_t)0x5f42cb37, (q31_t)0x5f3e98be, + (q31_t)0x5f3a660a, (q31_t)0x5f36331b, (q31_t)0x5f31fff1, (q31_t)0x5f2dcc8d, (q31_t)0x5f2998ee, (q31_t)0x5f256515, + (q31_t)0x5f213100, (q31_t)0x5f1cfcb1, + (q31_t)0x5f18c827, (q31_t)0x5f149363, (q31_t)0x5f105e64, (q31_t)0x5f0c292a, (q31_t)0x5f07f3b6, (q31_t)0x5f03be07, + (q31_t)0x5eff881d, (q31_t)0x5efb51f9, + (q31_t)0x5ef71b9b, (q31_t)0x5ef2e501, (q31_t)0x5eeeae2d, (q31_t)0x5eea771f, (q31_t)0x5ee63fd6, (q31_t)0x5ee20853, + (q31_t)0x5eddd094, (q31_t)0x5ed9989c, + (q31_t)0x5ed56069, (q31_t)0x5ed127fb, (q31_t)0x5eccef53, (q31_t)0x5ec8b671, (q31_t)0x5ec47d54, (q31_t)0x5ec043fc, + (q31_t)0x5ebc0a6a, (q31_t)0x5eb7d09e, + (q31_t)0x5eb39697, (q31_t)0x5eaf5c56, (q31_t)0x5eab21da, (q31_t)0x5ea6e724, (q31_t)0x5ea2ac34, (q31_t)0x5e9e7109, + (q31_t)0x5e9a35a4, (q31_t)0x5e95fa05, + (q31_t)0x5e91be2b, (q31_t)0x5e8d8217, (q31_t)0x5e8945c8, (q31_t)0x5e85093f, (q31_t)0x5e80cc7c, (q31_t)0x5e7c8f7f, + (q31_t)0x5e785247, (q31_t)0x5e7414d5, + (q31_t)0x5e6fd729, (q31_t)0x5e6b9943, (q31_t)0x5e675b22, (q31_t)0x5e631cc7, (q31_t)0x5e5ede32, (q31_t)0x5e5a9f62, + (q31_t)0x5e566059, (q31_t)0x5e522115, + (q31_t)0x5e4de197, (q31_t)0x5e49a1df, (q31_t)0x5e4561ed, (q31_t)0x5e4121c0, (q31_t)0x5e3ce15a, (q31_t)0x5e38a0b9, + (q31_t)0x5e345fde, (q31_t)0x5e301ec9, + (q31_t)0x5e2bdd7a, (q31_t)0x5e279bf1, (q31_t)0x5e235a2e, (q31_t)0x5e1f1830, (q31_t)0x5e1ad5f9, (q31_t)0x5e169388, + (q31_t)0x5e1250dc, (q31_t)0x5e0e0df7, + (q31_t)0x5e09cad7, (q31_t)0x5e05877e, (q31_t)0x5e0143ea, (q31_t)0x5dfd001d, (q31_t)0x5df8bc15, (q31_t)0x5df477d4, + (q31_t)0x5df03359, (q31_t)0x5debeea3, + (q31_t)0x5de7a9b4, (q31_t)0x5de3648b, (q31_t)0x5ddf1f28, (q31_t)0x5ddad98b, (q31_t)0x5dd693b4, (q31_t)0x5dd24da3, + (q31_t)0x5dce0759, (q31_t)0x5dc9c0d4, + (q31_t)0x5dc57a16, (q31_t)0x5dc1331d, (q31_t)0x5dbcebeb, (q31_t)0x5db8a480, (q31_t)0x5db45cda, (q31_t)0x5db014fa, + (q31_t)0x5dabcce1, (q31_t)0x5da7848e, + (q31_t)0x5da33c01, (q31_t)0x5d9ef33b, (q31_t)0x5d9aaa3a, (q31_t)0x5d966100, (q31_t)0x5d92178d, (q31_t)0x5d8dcddf, + (q31_t)0x5d8983f8, (q31_t)0x5d8539d7, + (q31_t)0x5d80ef7c, (q31_t)0x5d7ca4e8, (q31_t)0x5d785a1a, (q31_t)0x5d740f12, (q31_t)0x5d6fc3d1, (q31_t)0x5d6b7856, + (q31_t)0x5d672ca2, (q31_t)0x5d62e0b4, + (q31_t)0x5d5e948c, (q31_t)0x5d5a482a, (q31_t)0x5d55fb90, (q31_t)0x5d51aebb, (q31_t)0x5d4d61ad, (q31_t)0x5d491465, + (q31_t)0x5d44c6e4, (q31_t)0x5d40792a, + (q31_t)0x5d3c2b35, (q31_t)0x5d37dd08, (q31_t)0x5d338ea0, (q31_t)0x5d2f4000, (q31_t)0x5d2af125, (q31_t)0x5d26a212, + (q31_t)0x5d2252c5, (q31_t)0x5d1e033e, + (q31_t)0x5d19b37e, (q31_t)0x5d156385, (q31_t)0x5d111352, (q31_t)0x5d0cc2e5, (q31_t)0x5d087240, (q31_t)0x5d042161, + (q31_t)0x5cffd048, (q31_t)0x5cfb7ef7, + (q31_t)0x5cf72d6b, (q31_t)0x5cf2dba7, (q31_t)0x5cee89a9, (q31_t)0x5cea3772, (q31_t)0x5ce5e501, (q31_t)0x5ce19258, + (q31_t)0x5cdd3f75, (q31_t)0x5cd8ec58, + (q31_t)0x5cd49903, (q31_t)0x5cd04574, (q31_t)0x5ccbf1ab, (q31_t)0x5cc79daa, (q31_t)0x5cc3496f, (q31_t)0x5cbef4fc, + (q31_t)0x5cbaa04f, (q31_t)0x5cb64b68, + (q31_t)0x5cb1f649, (q31_t)0x5cada0f0, (q31_t)0x5ca94b5e, (q31_t)0x5ca4f594, (q31_t)0x5ca09f8f, (q31_t)0x5c9c4952, + (q31_t)0x5c97f2dc, (q31_t)0x5c939c2c, + (q31_t)0x5c8f4544, (q31_t)0x5c8aee22, (q31_t)0x5c8696c7, (q31_t)0x5c823f34, (q31_t)0x5c7de767, (q31_t)0x5c798f61, + (q31_t)0x5c753722, (q31_t)0x5c70deaa, + (q31_t)0x5c6c85f9, (q31_t)0x5c682d0f, (q31_t)0x5c63d3eb, (q31_t)0x5c5f7a8f, (q31_t)0x5c5b20fa, (q31_t)0x5c56c72c, + (q31_t)0x5c526d25, (q31_t)0x5c4e12e5, + (q31_t)0x5c49b86d, (q31_t)0x5c455dbb, (q31_t)0x5c4102d0, (q31_t)0x5c3ca7ad, (q31_t)0x5c384c50, (q31_t)0x5c33f0bb, + (q31_t)0x5c2f94ec, (q31_t)0x5c2b38e5, + (q31_t)0x5c26dca5, (q31_t)0x5c22802c, (q31_t)0x5c1e237b, (q31_t)0x5c19c690, (q31_t)0x5c15696d, (q31_t)0x5c110c11, + (q31_t)0x5c0cae7c, (q31_t)0x5c0850ae, + (q31_t)0x5c03f2a8, (q31_t)0x5bff9469, (q31_t)0x5bfb35f1, (q31_t)0x5bf6d740, (q31_t)0x5bf27857, (q31_t)0x5bee1935, + (q31_t)0x5be9b9da, (q31_t)0x5be55a46, + (q31_t)0x5be0fa7a, (q31_t)0x5bdc9a75, (q31_t)0x5bd83a37, (q31_t)0x5bd3d9c1, (q31_t)0x5bcf7912, (q31_t)0x5bcb182b, + (q31_t)0x5bc6b70b, (q31_t)0x5bc255b2, + (q31_t)0x5bbdf421, (q31_t)0x5bb99257, (q31_t)0x5bb53054, (q31_t)0x5bb0ce19, (q31_t)0x5bac6ba6, (q31_t)0x5ba808f9, + (q31_t)0x5ba3a615, (q31_t)0x5b9f42f7, + (q31_t)0x5b9adfa2, (q31_t)0x5b967c13, (q31_t)0x5b92184d, (q31_t)0x5b8db44d, (q31_t)0x5b895016, (q31_t)0x5b84eba6, + (q31_t)0x5b8086fd, (q31_t)0x5b7c221c, + (q31_t)0x5b77bd02, (q31_t)0x5b7357b0, (q31_t)0x5b6ef226, (q31_t)0x5b6a8c63, (q31_t)0x5b662668, (q31_t)0x5b61c035, + (q31_t)0x5b5d59c9, (q31_t)0x5b58f324, + (q31_t)0x5b548c48, (q31_t)0x5b502533, (q31_t)0x5b4bbde6, (q31_t)0x5b475660, (q31_t)0x5b42eea2, (q31_t)0x5b3e86ac, + (q31_t)0x5b3a1e7e, (q31_t)0x5b35b617, + (q31_t)0x5b314d78, (q31_t)0x5b2ce4a1, (q31_t)0x5b287b91, (q31_t)0x5b241249, (q31_t)0x5b1fa8c9, (q31_t)0x5b1b3f11, + (q31_t)0x5b16d521, (q31_t)0x5b126af8, + (q31_t)0x5b0e0098, (q31_t)0x5b0995ff, (q31_t)0x5b052b2e, (q31_t)0x5b00c025, (q31_t)0x5afc54e3, (q31_t)0x5af7e96a, + (q31_t)0x5af37db8, (q31_t)0x5aef11cf, + (q31_t)0x5aeaa5ad, (q31_t)0x5ae63953, (q31_t)0x5ae1ccc1, (q31_t)0x5add5ff7, (q31_t)0x5ad8f2f5, (q31_t)0x5ad485bb, + (q31_t)0x5ad01849, (q31_t)0x5acbaa9f, + (q31_t)0x5ac73cbd, (q31_t)0x5ac2cea3, (q31_t)0x5abe6050, (q31_t)0x5ab9f1c6, (q31_t)0x5ab58304, (q31_t)0x5ab1140a, + (q31_t)0x5aaca4d8, (q31_t)0x5aa8356f, + (q31_t)0x5aa3c5cd, (q31_t)0x5a9f55f3, (q31_t)0x5a9ae5e2, (q31_t)0x5a967598, (q31_t)0x5a920517, (q31_t)0x5a8d945d, + (q31_t)0x5a89236c, (q31_t)0x5a84b243, + (q31_t)0x5a8040e3, (q31_t)0x5a7bcf4a, (q31_t)0x5a775d7a, (q31_t)0x5a72eb71, (q31_t)0x5a6e7931, (q31_t)0x5a6a06ba, + (q31_t)0x5a65940a, (q31_t)0x5a612123, + (q31_t)0x5a5cae04, (q31_t)0x5a583aad, (q31_t)0x5a53c71e, (q31_t)0x5a4f5358, (q31_t)0x5a4adf5a, (q31_t)0x5a466b24, + (q31_t)0x5a41f6b7, (q31_t)0x5a3d8212, + (q31_t)0x5a390d35, (q31_t)0x5a349821, (q31_t)0x5a3022d5, (q31_t)0x5a2bad51, (q31_t)0x5a273796, (q31_t)0x5a22c1a3, + (q31_t)0x5a1e4b79, (q31_t)0x5a19d517, + (q31_t)0x5a155e7d, (q31_t)0x5a10e7ac, (q31_t)0x5a0c70a3, (q31_t)0x5a07f963, (q31_t)0x5a0381eb, (q31_t)0x59ff0a3c, + (q31_t)0x59fa9255, (q31_t)0x59f61a36, + (q31_t)0x59f1a1e0, (q31_t)0x59ed2953, (q31_t)0x59e8b08e, (q31_t)0x59e43792, (q31_t)0x59dfbe5e, (q31_t)0x59db44f3, + (q31_t)0x59d6cb50, (q31_t)0x59d25176, + (q31_t)0x59cdd765, (q31_t)0x59c95d1c, (q31_t)0x59c4e29c, (q31_t)0x59c067e4, (q31_t)0x59bbecf5, (q31_t)0x59b771cf, + (q31_t)0x59b2f671, (q31_t)0x59ae7add, + (q31_t)0x59a9ff10, (q31_t)0x59a5830d, (q31_t)0x59a106d2, (q31_t)0x599c8a60, (q31_t)0x59980db6, (q31_t)0x599390d5, + (q31_t)0x598f13bd, (q31_t)0x598a966e, + (q31_t)0x598618e8, (q31_t)0x59819b2a, (q31_t)0x597d1d35, (q31_t)0x59789f09, (q31_t)0x597420a6, (q31_t)0x596fa20b, + (q31_t)0x596b233a, (q31_t)0x5966a431, + (q31_t)0x596224f1, (q31_t)0x595da57a, (q31_t)0x595925cc, (q31_t)0x5954a5e6, (q31_t)0x595025ca, (q31_t)0x594ba576, + (q31_t)0x594724ec, (q31_t)0x5942a42a, + (q31_t)0x593e2331, (q31_t)0x5939a202, (q31_t)0x5935209b, (q31_t)0x59309efd, (q31_t)0x592c1d28, (q31_t)0x59279b1c, + (q31_t)0x592318d9, (q31_t)0x591e9660, + (q31_t)0x591a13af, (q31_t)0x591590c7, (q31_t)0x59110da8, (q31_t)0x590c8a53, (q31_t)0x590806c6, (q31_t)0x59038302, + (q31_t)0x58feff08, (q31_t)0x58fa7ad7, + (q31_t)0x58f5f66e, (q31_t)0x58f171cf, (q31_t)0x58ececf9, (q31_t)0x58e867ed, (q31_t)0x58e3e2a9, (q31_t)0x58df5d2e, + (q31_t)0x58dad77d, (q31_t)0x58d65195, + (q31_t)0x58d1cb76, (q31_t)0x58cd4520, (q31_t)0x58c8be94, (q31_t)0x58c437d1, (q31_t)0x58bfb0d7, (q31_t)0x58bb29a6, + (q31_t)0x58b6a23e, (q31_t)0x58b21aa0, + (q31_t)0x58ad92cb, (q31_t)0x58a90ac0, (q31_t)0x58a4827d, (q31_t)0x589ffa04, (q31_t)0x589b7155, (q31_t)0x5896e86f, + (q31_t)0x58925f52, (q31_t)0x588dd5fe, + (q31_t)0x58894c74, (q31_t)0x5884c2b3, (q31_t)0x588038bb, (q31_t)0x587bae8d, (q31_t)0x58772429, (q31_t)0x5872998e, + (q31_t)0x586e0ebc, (q31_t)0x586983b4, + (q31_t)0x5864f875, (q31_t)0x58606d00, (q31_t)0x585be154, (q31_t)0x58575571, (q31_t)0x5852c958, (q31_t)0x584e3d09, + (q31_t)0x5849b083, (q31_t)0x584523c7, + (q31_t)0x584096d4, (q31_t)0x583c09ab, (q31_t)0x58377c4c, (q31_t)0x5832eeb6, (q31_t)0x582e60e9, (q31_t)0x5829d2e6, + (q31_t)0x582544ad, (q31_t)0x5820b63e, + (q31_t)0x581c2798, (q31_t)0x581798bb, (q31_t)0x581309a9, (q31_t)0x580e7a60, (q31_t)0x5809eae1, (q31_t)0x58055b2b, + (q31_t)0x5800cb3f, (q31_t)0x57fc3b1d, + (q31_t)0x57f7aac5, (q31_t)0x57f31a36, (q31_t)0x57ee8971, (q31_t)0x57e9f876, (q31_t)0x57e56744, (q31_t)0x57e0d5dd, + (q31_t)0x57dc443f, (q31_t)0x57d7b26b, + (q31_t)0x57d32061, (q31_t)0x57ce8e20, (q31_t)0x57c9fbaa, (q31_t)0x57c568fd, (q31_t)0x57c0d61a, (q31_t)0x57bc4301, + (q31_t)0x57b7afb2, (q31_t)0x57b31c2d, + (q31_t)0x57ae8872, (q31_t)0x57a9f480, (q31_t)0x57a56059, (q31_t)0x57a0cbfb, (q31_t)0x579c3768, (q31_t)0x5797a29e, + (q31_t)0x57930d9e, (q31_t)0x578e7869, + (q31_t)0x5789e2fd, (q31_t)0x57854d5b, (q31_t)0x5780b784, (q31_t)0x577c2176, (q31_t)0x57778b32, (q31_t)0x5772f4b9, + (q31_t)0x576e5e09, (q31_t)0x5769c724, + (q31_t)0x57653009, (q31_t)0x576098b7, (q31_t)0x575c0130, (q31_t)0x57576973, (q31_t)0x5752d180, (q31_t)0x574e3957, + (q31_t)0x5749a0f9, (q31_t)0x57450864, + (q31_t)0x57406f9a, (q31_t)0x573bd69a, (q31_t)0x57373d64, (q31_t)0x5732a3f8, (q31_t)0x572e0a56, (q31_t)0x5729707f, + (q31_t)0x5724d672, (q31_t)0x57203c2f, + (q31_t)0x571ba1b7, (q31_t)0x57170708, (q31_t)0x57126c24, (q31_t)0x570dd10a, (q31_t)0x570935bb, (q31_t)0x57049a36, + (q31_t)0x56fffe7b, (q31_t)0x56fb628b, + (q31_t)0x56f6c664, (q31_t)0x56f22a09, (q31_t)0x56ed8d77, (q31_t)0x56e8f0b0, (q31_t)0x56e453b4, (q31_t)0x56dfb681, + (q31_t)0x56db1919, (q31_t)0x56d67b7c, + (q31_t)0x56d1dda9, (q31_t)0x56cd3fa1, (q31_t)0x56c8a162, (q31_t)0x56c402ef, (q31_t)0x56bf6446, (q31_t)0x56bac567, + (q31_t)0x56b62653, (q31_t)0x56b18709, + (q31_t)0x56ace78a, (q31_t)0x56a847d6, (q31_t)0x56a3a7ec, (q31_t)0x569f07cc, (q31_t)0x569a6777, (q31_t)0x5695c6ed, + (q31_t)0x5691262d, (q31_t)0x568c8538, + (q31_t)0x5687e40e, (q31_t)0x568342ae, (q31_t)0x567ea118, (q31_t)0x5679ff4e, (q31_t)0x56755d4e, (q31_t)0x5670bb19, + (q31_t)0x566c18ae, (q31_t)0x5667760e, + (q31_t)0x5662d339, (q31_t)0x565e302e, (q31_t)0x56598cee, (q31_t)0x5654e979, (q31_t)0x565045cf, (q31_t)0x564ba1f0, + (q31_t)0x5646fddb, (q31_t)0x56425991, + (q31_t)0x563db512, (q31_t)0x5639105d, (q31_t)0x56346b74, (q31_t)0x562fc655, (q31_t)0x562b2101, (q31_t)0x56267b78, + (q31_t)0x5621d5ba, (q31_t)0x561d2fc6, + (q31_t)0x5618899e, (q31_t)0x5613e340, (q31_t)0x560f3cae, (q31_t)0x560a95e6, (q31_t)0x5605eee9, (q31_t)0x560147b7, + (q31_t)0x55fca050, (q31_t)0x55f7f8b4, + (q31_t)0x55f350e3, (q31_t)0x55eea8dd, (q31_t)0x55ea00a2, (q31_t)0x55e55832, (q31_t)0x55e0af8d, (q31_t)0x55dc06b3, + (q31_t)0x55d75da4, (q31_t)0x55d2b460, + (q31_t)0x55ce0ae7, (q31_t)0x55c96139, (q31_t)0x55c4b757, (q31_t)0x55c00d3f, (q31_t)0x55bb62f3, (q31_t)0x55b6b871, + (q31_t)0x55b20dbb, (q31_t)0x55ad62d0, + (q31_t)0x55a8b7b0, (q31_t)0x55a40c5b, (q31_t)0x559f60d1, (q31_t)0x559ab513, (q31_t)0x55960920, (q31_t)0x55915cf8, + (q31_t)0x558cb09b, (q31_t)0x55880409, + (q31_t)0x55835743, (q31_t)0x557eaa48, (q31_t)0x5579fd18, (q31_t)0x55754fb3, (q31_t)0x5570a21a, (q31_t)0x556bf44c, + (q31_t)0x55674649, (q31_t)0x55629812, + (q31_t)0x555de9a6, (q31_t)0x55593b05, (q31_t)0x55548c30, (q31_t)0x554fdd26, (q31_t)0x554b2de7, (q31_t)0x55467e74, + (q31_t)0x5541cecc, (q31_t)0x553d1ef0, + (q31_t)0x55386edf, (q31_t)0x5533be99, (q31_t)0x552f0e1f, (q31_t)0x552a5d70, (q31_t)0x5525ac8d, (q31_t)0x5520fb75, + (q31_t)0x551c4a29, (q31_t)0x551798a8, + (q31_t)0x5512e6f3, (q31_t)0x550e3509, (q31_t)0x550982eb, (q31_t)0x5504d099, (q31_t)0x55001e12, (q31_t)0x54fb6b56, + (q31_t)0x54f6b866, (q31_t)0x54f20542, + (q31_t)0x54ed51e9, (q31_t)0x54e89e5c, (q31_t)0x54e3ea9a, (q31_t)0x54df36a5, (q31_t)0x54da827a, (q31_t)0x54d5ce1c, + (q31_t)0x54d11989, (q31_t)0x54cc64c2, + (q31_t)0x54c7afc6, (q31_t)0x54c2fa96, (q31_t)0x54be4532, (q31_t)0x54b98f9a, (q31_t)0x54b4d9cd, (q31_t)0x54b023cc, + (q31_t)0x54ab6d97, (q31_t)0x54a6b72e, + (q31_t)0x54a20090, (q31_t)0x549d49bf, (q31_t)0x549892b9, (q31_t)0x5493db7f, (q31_t)0x548f2410, (q31_t)0x548a6c6e, + (q31_t)0x5485b497, (q31_t)0x5480fc8c, + (q31_t)0x547c444d, (q31_t)0x54778bda, (q31_t)0x5472d333, (q31_t)0x546e1a58, (q31_t)0x54696149, (q31_t)0x5464a805, + (q31_t)0x545fee8e, (q31_t)0x545b34e3, + (q31_t)0x54567b03, (q31_t)0x5451c0f0, (q31_t)0x544d06a8, (q31_t)0x54484c2d, (q31_t)0x5443917d, (q31_t)0x543ed699, + (q31_t)0x543a1b82, (q31_t)0x54356037, + (q31_t)0x5430a4b7, (q31_t)0x542be904, (q31_t)0x54272d1d, (q31_t)0x54227102, (q31_t)0x541db4b3, (q31_t)0x5418f830, + (q31_t)0x54143b79, (q31_t)0x540f7e8e, + (q31_t)0x540ac170, (q31_t)0x5406041d, (q31_t)0x54014697, (q31_t)0x53fc88dd, (q31_t)0x53f7caef, (q31_t)0x53f30cce, + (q31_t)0x53ee4e78, (q31_t)0x53e98fef, + (q31_t)0x53e4d132, (q31_t)0x53e01242, (q31_t)0x53db531d, (q31_t)0x53d693c5, (q31_t)0x53d1d439, (q31_t)0x53cd147a, + (q31_t)0x53c85486, (q31_t)0x53c3945f, + (q31_t)0x53bed405, (q31_t)0x53ba1377, (q31_t)0x53b552b5, (q31_t)0x53b091bf, (q31_t)0x53abd096, (q31_t)0x53a70f39, + (q31_t)0x53a24da9, (q31_t)0x539d8be5, + (q31_t)0x5398c9ed, (q31_t)0x539407c2, (q31_t)0x538f4564, (q31_t)0x538a82d1, (q31_t)0x5385c00c, (q31_t)0x5380fd12, + (q31_t)0x537c39e6, (q31_t)0x53777685, + (q31_t)0x5372b2f2, (q31_t)0x536def2a, (q31_t)0x53692b30, (q31_t)0x53646701, (q31_t)0x535fa2a0, (q31_t)0x535ade0b, + (q31_t)0x53561942, (q31_t)0x53515447, + (q31_t)0x534c8f17, (q31_t)0x5347c9b5, (q31_t)0x5343041f, (q31_t)0x533e3e55, (q31_t)0x53397859, (q31_t)0x5334b229, + (q31_t)0x532febc5, (q31_t)0x532b252f, + (q31_t)0x53265e65, (q31_t)0x53219767, (q31_t)0x531cd037, (q31_t)0x531808d3, (q31_t)0x5313413c, (q31_t)0x530e7972, + (q31_t)0x5309b174, (q31_t)0x5304e943, + (q31_t)0x530020df, (q31_t)0x52fb5848, (q31_t)0x52f68f7e, (q31_t)0x52f1c680, (q31_t)0x52ecfd4f, (q31_t)0x52e833ec, + (q31_t)0x52e36a55, (q31_t)0x52dea08a, + (q31_t)0x52d9d68d, (q31_t)0x52d50c5d, (q31_t)0x52d041f9, (q31_t)0x52cb7763, (q31_t)0x52c6ac99, (q31_t)0x52c1e19d, + (q31_t)0x52bd166d, (q31_t)0x52b84b0a, + (q31_t)0x52b37f74, (q31_t)0x52aeb3ac, (q31_t)0x52a9e7b0, (q31_t)0x52a51b81, (q31_t)0x52a04f1f, (q31_t)0x529b828a, + (q31_t)0x5296b5c3, (q31_t)0x5291e8c8, + (q31_t)0x528d1b9b, (q31_t)0x52884e3a, (q31_t)0x528380a7, (q31_t)0x527eb2e0, (q31_t)0x5279e4e7, (q31_t)0x527516bb, + (q31_t)0x5270485c, (q31_t)0x526b79ca, + (q31_t)0x5266ab06, (q31_t)0x5261dc0e, (q31_t)0x525d0ce4, (q31_t)0x52583d87, (q31_t)0x52536df7, (q31_t)0x524e9e34, + (q31_t)0x5249ce3f, (q31_t)0x5244fe17, + (q31_t)0x52402dbc, (q31_t)0x523b5d2e, (q31_t)0x52368c6e, (q31_t)0x5231bb7b, (q31_t)0x522cea55, (q31_t)0x522818fc, + (q31_t)0x52234771, (q31_t)0x521e75b3, + (q31_t)0x5219a3c3, (q31_t)0x5214d1a0, (q31_t)0x520fff4a, (q31_t)0x520b2cc2, (q31_t)0x52065a07, (q31_t)0x52018719, + (q31_t)0x51fcb3f9, (q31_t)0x51f7e0a6, + (q31_t)0x51f30d21, (q31_t)0x51ee3969, (q31_t)0x51e9657e, (q31_t)0x51e49162, (q31_t)0x51dfbd12, (q31_t)0x51dae890, + (q31_t)0x51d613dc, (q31_t)0x51d13ef5, + (q31_t)0x51cc69db, (q31_t)0x51c79490, (q31_t)0x51c2bf11, (q31_t)0x51bde960, (q31_t)0x51b9137d, (q31_t)0x51b43d68, + (q31_t)0x51af6720, (q31_t)0x51aa90a5, + (q31_t)0x51a5b9f9, (q31_t)0x51a0e31a, (q31_t)0x519c0c08, (q31_t)0x519734c4, (q31_t)0x51925d4e, (q31_t)0x518d85a6, + (q31_t)0x5188adcb, (q31_t)0x5183d5be, + (q31_t)0x517efd7f, (q31_t)0x517a250d, (q31_t)0x51754c69, (q31_t)0x51707393, (q31_t)0x516b9a8b, (q31_t)0x5166c150, + (q31_t)0x5161e7e4, (q31_t)0x515d0e45, + (q31_t)0x51583473, (q31_t)0x51535a70, (q31_t)0x514e803b, (q31_t)0x5149a5d3, (q31_t)0x5144cb39, (q31_t)0x513ff06d, + (q31_t)0x513b156f, (q31_t)0x51363a3f, + (q31_t)0x51315edd, (q31_t)0x512c8348, (q31_t)0x5127a782, (q31_t)0x5122cb8a, (q31_t)0x511def5f, (q31_t)0x51191302, + (q31_t)0x51143674, (q31_t)0x510f59b3, + (q31_t)0x510a7cc1, (q31_t)0x51059f9c, (q31_t)0x5100c246, (q31_t)0x50fbe4bd, (q31_t)0x50f70703, (q31_t)0x50f22916, + (q31_t)0x50ed4af8, (q31_t)0x50e86ca8, + (q31_t)0x50e38e25, (q31_t)0x50deaf71, (q31_t)0x50d9d08b, (q31_t)0x50d4f173, (q31_t)0x50d0122a, (q31_t)0x50cb32ae, + (q31_t)0x50c65301, (q31_t)0x50c17322, + (q31_t)0x50bc9311, (q31_t)0x50b7b2ce, (q31_t)0x50b2d259, (q31_t)0x50adf1b3, (q31_t)0x50a910db, (q31_t)0x50a42fd1, + (q31_t)0x509f4e95, (q31_t)0x509a6d28, + (q31_t)0x50958b88, (q31_t)0x5090a9b8, (q31_t)0x508bc7b5, (q31_t)0x5086e581, (q31_t)0x5082031b, (q31_t)0x507d2083, + (q31_t)0x50783dba, (q31_t)0x50735abf, + (q31_t)0x506e7793, (q31_t)0x50699435, (q31_t)0x5064b0a5, (q31_t)0x505fcce4, (q31_t)0x505ae8f1, (q31_t)0x505604cd, + (q31_t)0x50512077, (q31_t)0x504c3bef, + (q31_t)0x50475736, (q31_t)0x5042724c, (q31_t)0x503d8d30, (q31_t)0x5038a7e2, (q31_t)0x5033c263, (q31_t)0x502edcb2, + (q31_t)0x5029f6d1, (q31_t)0x502510bd, + (q31_t)0x50202a78, (q31_t)0x501b4402, (q31_t)0x50165d5a, (q31_t)0x50117681, (q31_t)0x500c8f77, (q31_t)0x5007a83b, + (q31_t)0x5002c0cd, (q31_t)0x4ffdd92f, + (q31_t)0x4ff8f15f, (q31_t)0x4ff4095e, (q31_t)0x4fef212b, (q31_t)0x4fea38c7, (q31_t)0x4fe55032, (q31_t)0x4fe0676c, + (q31_t)0x4fdb7e74, (q31_t)0x4fd6954b, + (q31_t)0x4fd1abf0, (q31_t)0x4fccc265, (q31_t)0x4fc7d8a8, (q31_t)0x4fc2eeba, (q31_t)0x4fbe049b, (q31_t)0x4fb91a4b, + (q31_t)0x4fb42fc9, (q31_t)0x4faf4517, + (q31_t)0x4faa5a33, (q31_t)0x4fa56f1e, (q31_t)0x4fa083d8, (q31_t)0x4f9b9861, (q31_t)0x4f96acb8, (q31_t)0x4f91c0df, + (q31_t)0x4f8cd4d4, (q31_t)0x4f87e899, + (q31_t)0x4f82fc2c, (q31_t)0x4f7e0f8f, (q31_t)0x4f7922c0, (q31_t)0x4f7435c0, (q31_t)0x4f6f488f, (q31_t)0x4f6a5b2e, + (q31_t)0x4f656d9b, (q31_t)0x4f607fd7, + (q31_t)0x4f5b91e3, (q31_t)0x4f56a3bd, (q31_t)0x4f51b566, (q31_t)0x4f4cc6df, (q31_t)0x4f47d827, (q31_t)0x4f42e93d, + (q31_t)0x4f3dfa23, (q31_t)0x4f390ad8, + (q31_t)0x4f341b5c, (q31_t)0x4f2f2baf, (q31_t)0x4f2a3bd2, (q31_t)0x4f254bc3, (q31_t)0x4f205b84, (q31_t)0x4f1b6b14, + (q31_t)0x4f167a73, (q31_t)0x4f1189a1, + (q31_t)0x4f0c989f, (q31_t)0x4f07a76b, (q31_t)0x4f02b608, (q31_t)0x4efdc473, (q31_t)0x4ef8d2ad, (q31_t)0x4ef3e0b7, + (q31_t)0x4eeeee90, (q31_t)0x4ee9fc39, + (q31_t)0x4ee509b1, (q31_t)0x4ee016f8, (q31_t)0x4edb240e, (q31_t)0x4ed630f4, (q31_t)0x4ed13da9, (q31_t)0x4ecc4a2e, + (q31_t)0x4ec75682, (q31_t)0x4ec262a5, + (q31_t)0x4ebd6e98, (q31_t)0x4eb87a5a, (q31_t)0x4eb385ec, (q31_t)0x4eae914d, (q31_t)0x4ea99c7d, (q31_t)0x4ea4a77d, + (q31_t)0x4e9fb24d, (q31_t)0x4e9abcec, + (q31_t)0x4e95c75b, (q31_t)0x4e90d199, (q31_t)0x4e8bdba6, (q31_t)0x4e86e583, (q31_t)0x4e81ef30, (q31_t)0x4e7cf8ac, + (q31_t)0x4e7801f8, (q31_t)0x4e730b14, + (q31_t)0x4e6e13ff, (q31_t)0x4e691cba, (q31_t)0x4e642544, (q31_t)0x4e5f2d9e, (q31_t)0x4e5a35c7, (q31_t)0x4e553dc1, + (q31_t)0x4e50458a, (q31_t)0x4e4b4d22, + (q31_t)0x4e46548b, (q31_t)0x4e415bc3, (q31_t)0x4e3c62cb, (q31_t)0x4e3769a2, (q31_t)0x4e32704a, (q31_t)0x4e2d76c1, + (q31_t)0x4e287d08, (q31_t)0x4e23831e, + (q31_t)0x4e1e8905, (q31_t)0x4e198ebb, (q31_t)0x4e149441, (q31_t)0x4e0f9997, (q31_t)0x4e0a9ebd, (q31_t)0x4e05a3b2, + (q31_t)0x4e00a878, (q31_t)0x4dfbad0d, + (q31_t)0x4df6b173, (q31_t)0x4df1b5a8, (q31_t)0x4decb9ad, (q31_t)0x4de7bd82, (q31_t)0x4de2c127, (q31_t)0x4dddc49c, + (q31_t)0x4dd8c7e1, (q31_t)0x4dd3caf6, + (q31_t)0x4dcecdda, (q31_t)0x4dc9d08f, (q31_t)0x4dc4d314, (q31_t)0x4dbfd569, (q31_t)0x4dbad78e, (q31_t)0x4db5d983, + (q31_t)0x4db0db48, (q31_t)0x4dabdcdd, + (q31_t)0x4da6de43, (q31_t)0x4da1df78, (q31_t)0x4d9ce07d, (q31_t)0x4d97e153, (q31_t)0x4d92e1f9, (q31_t)0x4d8de26f, + (q31_t)0x4d88e2b5, (q31_t)0x4d83e2cb, + (q31_t)0x4d7ee2b1, (q31_t)0x4d79e268, (q31_t)0x4d74e1ef, (q31_t)0x4d6fe146, (q31_t)0x4d6ae06d, (q31_t)0x4d65df64, + (q31_t)0x4d60de2c, (q31_t)0x4d5bdcc4, + (q31_t)0x4d56db2d, (q31_t)0x4d51d965, (q31_t)0x4d4cd76e, (q31_t)0x4d47d547, (q31_t)0x4d42d2f1, (q31_t)0x4d3dd06b, + (q31_t)0x4d38cdb5, (q31_t)0x4d33cad0, + (q31_t)0x4d2ec7bb, (q31_t)0x4d29c476, (q31_t)0x4d24c102, (q31_t)0x4d1fbd5e, (q31_t)0x4d1ab98b, (q31_t)0x4d15b588, + (q31_t)0x4d10b155, (q31_t)0x4d0bacf3, + (q31_t)0x4d06a862, (q31_t)0x4d01a3a0, (q31_t)0x4cfc9eb0, (q31_t)0x4cf79990, (q31_t)0x4cf29440, (q31_t)0x4ced8ec1, + (q31_t)0x4ce88913, (q31_t)0x4ce38335, + (q31_t)0x4cde7d28, (q31_t)0x4cd976eb, (q31_t)0x4cd4707f, (q31_t)0x4ccf69e3, (q31_t)0x4cca6318, (q31_t)0x4cc55c1e, + (q31_t)0x4cc054f4, (q31_t)0x4cbb4d9b, + (q31_t)0x4cb64613, (q31_t)0x4cb13e5b, (q31_t)0x4cac3674, (q31_t)0x4ca72e5e, (q31_t)0x4ca22619, (q31_t)0x4c9d1da4, + (q31_t)0x4c981500, (q31_t)0x4c930c2d, + (q31_t)0x4c8e032a, (q31_t)0x4c88f9f8, (q31_t)0x4c83f097, (q31_t)0x4c7ee707, (q31_t)0x4c79dd48, (q31_t)0x4c74d359, + (q31_t)0x4c6fc93b, (q31_t)0x4c6abeef, + (q31_t)0x4c65b473, (q31_t)0x4c60a9c8, (q31_t)0x4c5b9eed, (q31_t)0x4c5693e4, (q31_t)0x4c5188ac, (q31_t)0x4c4c7d44, + (q31_t)0x4c4771ae, (q31_t)0x4c4265e8, + (q31_t)0x4c3d59f3, (q31_t)0x4c384dd0, (q31_t)0x4c33417d, (q31_t)0x4c2e34fb, (q31_t)0x4c29284b, (q31_t)0x4c241b6b, + (q31_t)0x4c1f0e5c, (q31_t)0x4c1a011f, + (q31_t)0x4c14f3b2, (q31_t)0x4c0fe617, (q31_t)0x4c0ad84c, (q31_t)0x4c05ca53, (q31_t)0x4c00bc2b, (q31_t)0x4bfbadd4, + (q31_t)0x4bf69f4e, (q31_t)0x4bf19099, + (q31_t)0x4bec81b5, (q31_t)0x4be772a3, (q31_t)0x4be26362, (q31_t)0x4bdd53f2, (q31_t)0x4bd84453, (q31_t)0x4bd33485, + (q31_t)0x4bce2488, (q31_t)0x4bc9145d, + (q31_t)0x4bc40403, (q31_t)0x4bbef37b, (q31_t)0x4bb9e2c3, (q31_t)0x4bb4d1dd, (q31_t)0x4bafc0c8, (q31_t)0x4baaaf85, + (q31_t)0x4ba59e12, (q31_t)0x4ba08c72, + (q31_t)0x4b9b7aa2, (q31_t)0x4b9668a4, (q31_t)0x4b915677, (q31_t)0x4b8c441c, (q31_t)0x4b873192, (q31_t)0x4b821ed9, + (q31_t)0x4b7d0bf2, (q31_t)0x4b77f8dc, + (q31_t)0x4b72e598, (q31_t)0x4b6dd225, (q31_t)0x4b68be84, (q31_t)0x4b63aab4, (q31_t)0x4b5e96b6, (q31_t)0x4b598289, + (q31_t)0x4b546e2d, (q31_t)0x4b4f59a4, + (q31_t)0x4b4a44eb, (q31_t)0x4b453005, (q31_t)0x4b401aef, (q31_t)0x4b3b05ac, (q31_t)0x4b35f03a, (q31_t)0x4b30da9a, + (q31_t)0x4b2bc4cb, (q31_t)0x4b26aece, + (q31_t)0x4b2198a2, (q31_t)0x4b1c8248, (q31_t)0x4b176bc0, (q31_t)0x4b12550a, (q31_t)0x4b0d3e25, (q31_t)0x4b082712, + (q31_t)0x4b030fd1, (q31_t)0x4afdf861, + (q31_t)0x4af8e0c3, (q31_t)0x4af3c8f7, (q31_t)0x4aeeb0fd, (q31_t)0x4ae998d4, (q31_t)0x4ae4807d, (q31_t)0x4adf67f8, + (q31_t)0x4ada4f45, (q31_t)0x4ad53664, + (q31_t)0x4ad01d54, (q31_t)0x4acb0417, (q31_t)0x4ac5eaab, (q31_t)0x4ac0d111, (q31_t)0x4abbb749, (q31_t)0x4ab69d53, + (q31_t)0x4ab1832f, (q31_t)0x4aac68dc, + (q31_t)0x4aa74e5c, (q31_t)0x4aa233ae, (q31_t)0x4a9d18d1, (q31_t)0x4a97fdc7, (q31_t)0x4a92e28e, (q31_t)0x4a8dc728, + (q31_t)0x4a88ab93, (q31_t)0x4a838fd1, + (q31_t)0x4a7e73e0, (q31_t)0x4a7957c2, (q31_t)0x4a743b76, (q31_t)0x4a6f1efc, (q31_t)0x4a6a0253, (q31_t)0x4a64e57d, + (q31_t)0x4a5fc879, (q31_t)0x4a5aab48, + (q31_t)0x4a558de8, (q31_t)0x4a50705a, (q31_t)0x4a4b529f, (q31_t)0x4a4634b6, (q31_t)0x4a41169f, (q31_t)0x4a3bf85a, + (q31_t)0x4a36d9e7, (q31_t)0x4a31bb47, + (q31_t)0x4a2c9c79, (q31_t)0x4a277d7d, (q31_t)0x4a225e53, (q31_t)0x4a1d3efc, (q31_t)0x4a181f77, (q31_t)0x4a12ffc4, + (q31_t)0x4a0ddfe4, (q31_t)0x4a08bfd5, + (q31_t)0x4a039f9a, (q31_t)0x49fe7f30, (q31_t)0x49f95e99, (q31_t)0x49f43dd4, (q31_t)0x49ef1ce2, (q31_t)0x49e9fbc2, + (q31_t)0x49e4da74, (q31_t)0x49dfb8f9, + (q31_t)0x49da9750, (q31_t)0x49d5757a, (q31_t)0x49d05376, (q31_t)0x49cb3145, (q31_t)0x49c60ee6, (q31_t)0x49c0ec59, + (q31_t)0x49bbc9a0, (q31_t)0x49b6a6b8, + (q31_t)0x49b183a3, (q31_t)0x49ac6061, (q31_t)0x49a73cf1, (q31_t)0x49a21954, (q31_t)0x499cf589, (q31_t)0x4997d191, + (q31_t)0x4992ad6c, (q31_t)0x498d8919, + (q31_t)0x49886499, (q31_t)0x49833fec, (q31_t)0x497e1b11, (q31_t)0x4978f609, (q31_t)0x4973d0d3, (q31_t)0x496eab70, + (q31_t)0x496985e0, (q31_t)0x49646023, + (q31_t)0x495f3a38, (q31_t)0x495a1420, (q31_t)0x4954eddb, (q31_t)0x494fc768, (q31_t)0x494aa0c9, (q31_t)0x494579fc, + (q31_t)0x49405302, (q31_t)0x493b2bdb, + (q31_t)0x49360486, (q31_t)0x4930dd05, (q31_t)0x492bb556, (q31_t)0x49268d7a, (q31_t)0x49216571, (q31_t)0x491c3d3b, + (q31_t)0x491714d8, (q31_t)0x4911ec47, + (q31_t)0x490cc38a, (q31_t)0x49079aa0, (q31_t)0x49027188, (q31_t)0x48fd4844, (q31_t)0x48f81ed2, (q31_t)0x48f2f534, + (q31_t)0x48edcb68, (q31_t)0x48e8a170, + (q31_t)0x48e3774a, (q31_t)0x48de4cf8, (q31_t)0x48d92278, (q31_t)0x48d3f7cc, (q31_t)0x48ceccf3, (q31_t)0x48c9a1ed, + (q31_t)0x48c476b9, (q31_t)0x48bf4b59, + (q31_t)0x48ba1fcd, (q31_t)0x48b4f413, (q31_t)0x48afc82c, (q31_t)0x48aa9c19, (q31_t)0x48a56fd9, (q31_t)0x48a0436c, + (q31_t)0x489b16d2, (q31_t)0x4895ea0b, + (q31_t)0x4890bd18, (q31_t)0x488b8ff8, (q31_t)0x488662ab, (q31_t)0x48813531, (q31_t)0x487c078b, (q31_t)0x4876d9b8, + (q31_t)0x4871abb8, (q31_t)0x486c7d8c, + (q31_t)0x48674f33, (q31_t)0x486220ad, (q31_t)0x485cf1fa, (q31_t)0x4857c31b, (q31_t)0x48529410, (q31_t)0x484d64d7, + (q31_t)0x48483572, (q31_t)0x484305e1, + (q31_t)0x483dd623, (q31_t)0x4838a638, (q31_t)0x48337621, (q31_t)0x482e45dd, (q31_t)0x4829156d, (q31_t)0x4823e4d0, + (q31_t)0x481eb407, (q31_t)0x48198311, + (q31_t)0x481451ef, (q31_t)0x480f20a0, (q31_t)0x4809ef25, (q31_t)0x4804bd7e, (q31_t)0x47ff8baa, (q31_t)0x47fa59a9, + (q31_t)0x47f5277d, (q31_t)0x47eff523, + (q31_t)0x47eac29e, (q31_t)0x47e58fec, (q31_t)0x47e05d0e, (q31_t)0x47db2a03, (q31_t)0x47d5f6cc, (q31_t)0x47d0c369, + (q31_t)0x47cb8fd9, (q31_t)0x47c65c1d, + (q31_t)0x47c12835, (q31_t)0x47bbf421, (q31_t)0x47b6bfe0, (q31_t)0x47b18b74, (q31_t)0x47ac56da, (q31_t)0x47a72215, + (q31_t)0x47a1ed24, (q31_t)0x479cb806, + (q31_t)0x479782bc, (q31_t)0x47924d46, (q31_t)0x478d17a4, (q31_t)0x4787e1d6, (q31_t)0x4782abdb, (q31_t)0x477d75b5, + (q31_t)0x47783f62, (q31_t)0x477308e3, + (q31_t)0x476dd239, (q31_t)0x47689b62, (q31_t)0x4763645f, (q31_t)0x475e2d30, (q31_t)0x4758f5d5, (q31_t)0x4753be4e, + (q31_t)0x474e869b, (q31_t)0x47494ebc, + (q31_t)0x474416b1, (q31_t)0x473ede7a, (q31_t)0x4739a617, (q31_t)0x47346d89, (q31_t)0x472f34ce, (q31_t)0x4729fbe7, + (q31_t)0x4724c2d5, (q31_t)0x471f8996, + (q31_t)0x471a502c, (q31_t)0x47151696, (q31_t)0x470fdcd4, (q31_t)0x470aa2e6, (q31_t)0x470568cd, (q31_t)0x47002e87, + (q31_t)0x46faf416, (q31_t)0x46f5b979, + (q31_t)0x46f07eb0, (q31_t)0x46eb43bc, (q31_t)0x46e6089b, (q31_t)0x46e0cd4f, (q31_t)0x46db91d8, (q31_t)0x46d65634, + (q31_t)0x46d11a65, (q31_t)0x46cbde6a, + (q31_t)0x46c6a244, (q31_t)0x46c165f1, (q31_t)0x46bc2974, (q31_t)0x46b6ecca, (q31_t)0x46b1aff5, (q31_t)0x46ac72f4, + (q31_t)0x46a735c8, (q31_t)0x46a1f870, + (q31_t)0x469cbaed, (q31_t)0x46977d3e, (q31_t)0x46923f63, (q31_t)0x468d015d, (q31_t)0x4687c32c, (q31_t)0x468284cf, + (q31_t)0x467d4646, (q31_t)0x46780792, + (q31_t)0x4672c8b3, (q31_t)0x466d89a8, (q31_t)0x46684a71, (q31_t)0x46630b0f, (q31_t)0x465dcb82, (q31_t)0x46588bc9, + (q31_t)0x46534be5, (q31_t)0x464e0bd6, + (q31_t)0x4648cb9b, (q31_t)0x46438b35, (q31_t)0x463e4aa3, (q31_t)0x463909e7, (q31_t)0x4633c8fe, (q31_t)0x462e87eb, + (q31_t)0x462946ac, (q31_t)0x46240542, + (q31_t)0x461ec3ad, (q31_t)0x461981ec, (q31_t)0x46144001, (q31_t)0x460efde9, (q31_t)0x4609bba7, (q31_t)0x4604793a, + (q31_t)0x45ff36a1, (q31_t)0x45f9f3dd, + (q31_t)0x45f4b0ee, (q31_t)0x45ef6dd4, (q31_t)0x45ea2a8f, (q31_t)0x45e4e71f, (q31_t)0x45dfa383, (q31_t)0x45da5fbc, + (q31_t)0x45d51bcb, (q31_t)0x45cfd7ae, + (q31_t)0x45ca9366, (q31_t)0x45c54ef3, (q31_t)0x45c00a55, (q31_t)0x45bac58c, (q31_t)0x45b58098, (q31_t)0x45b03b79, + (q31_t)0x45aaf630, (q31_t)0x45a5b0bb, + (q31_t)0x45a06b1b, (q31_t)0x459b2550, (q31_t)0x4595df5a, (q31_t)0x45909939, (q31_t)0x458b52ee, (q31_t)0x45860c77, + (q31_t)0x4580c5d6, (q31_t)0x457b7f0a, + (q31_t)0x45763813, (q31_t)0x4570f0f1, (q31_t)0x456ba9a4, (q31_t)0x4566622c, (q31_t)0x45611a8a, (q31_t)0x455bd2bc, + (q31_t)0x45568ac4, (q31_t)0x455142a2, + (q31_t)0x454bfa54, (q31_t)0x4546b1dc, (q31_t)0x45416939, (q31_t)0x453c206b, (q31_t)0x4536d773, (q31_t)0x45318e4f, + (q31_t)0x452c4502, (q31_t)0x4526fb89, + (q31_t)0x4521b1e6, (q31_t)0x451c6818, (q31_t)0x45171e20, (q31_t)0x4511d3fd, (q31_t)0x450c89af, (q31_t)0x45073f37, + (q31_t)0x4501f494, (q31_t)0x44fca9c6, + (q31_t)0x44f75ecf, (q31_t)0x44f213ac, (q31_t)0x44ecc85f, (q31_t)0x44e77ce7, (q31_t)0x44e23145, (q31_t)0x44dce579, + (q31_t)0x44d79982, (q31_t)0x44d24d60, + (q31_t)0x44cd0114, (q31_t)0x44c7b49e, (q31_t)0x44c267fd, (q31_t)0x44bd1b32, (q31_t)0x44b7ce3c, (q31_t)0x44b2811c, + (q31_t)0x44ad33d2, (q31_t)0x44a7e65d, + (q31_t)0x44a298be, (q31_t)0x449d4af5, (q31_t)0x4497fd01, (q31_t)0x4492aee3, (q31_t)0x448d609b, (q31_t)0x44881228, + (q31_t)0x4482c38b, (q31_t)0x447d74c4, + (q31_t)0x447825d2, (q31_t)0x4472d6b7, (q31_t)0x446d8771, (q31_t)0x44683801, (q31_t)0x4462e866, (q31_t)0x445d98a2, + (q31_t)0x445848b3, (q31_t)0x4452f89b, + (q31_t)0x444da858, (q31_t)0x444857ea, (q31_t)0x44430753, (q31_t)0x443db692, (q31_t)0x443865a7, (q31_t)0x44331491, + (q31_t)0x442dc351, (q31_t)0x442871e8, + (q31_t)0x44232054, (q31_t)0x441dce96, (q31_t)0x44187caf, (q31_t)0x44132a9d, (q31_t)0x440dd861, (q31_t)0x440885fc, + (q31_t)0x4403336c, (q31_t)0x43fde0b2, + (q31_t)0x43f88dcf, (q31_t)0x43f33ac1, (q31_t)0x43ede78a, (q31_t)0x43e89429, (q31_t)0x43e3409d, (q31_t)0x43ddece8, + (q31_t)0x43d8990a, (q31_t)0x43d34501, + (q31_t)0x43cdf0ce, (q31_t)0x43c89c72, (q31_t)0x43c347eb, (q31_t)0x43bdf33b, (q31_t)0x43b89e62, (q31_t)0x43b3495e, + (q31_t)0x43adf431, (q31_t)0x43a89ed9, + (q31_t)0x43a34959, (q31_t)0x439df3ae, (q31_t)0x43989dda, (q31_t)0x439347dc, (q31_t)0x438df1b4, (q31_t)0x43889b63, + (q31_t)0x438344e8, (q31_t)0x437dee43, + (q31_t)0x43789775, (q31_t)0x4373407d, (q31_t)0x436de95b, (q31_t)0x43689210, (q31_t)0x43633a9c, (q31_t)0x435de2fd, + (q31_t)0x43588b36, (q31_t)0x43533344, + (q31_t)0x434ddb29, (q31_t)0x434882e5, (q31_t)0x43432a77, (q31_t)0x433dd1e0, (q31_t)0x4338791f, (q31_t)0x43332035, + (q31_t)0x432dc721, (q31_t)0x43286de4, + (q31_t)0x4323147d, (q31_t)0x431dbaed, (q31_t)0x43186133, (q31_t)0x43130751, (q31_t)0x430dad44, (q31_t)0x4308530f, + (q31_t)0x4302f8b0, (q31_t)0x42fd9e28, + (q31_t)0x42f84376, (q31_t)0x42f2e89b, (q31_t)0x42ed8d97, (q31_t)0x42e83269, (q31_t)0x42e2d713, (q31_t)0x42dd7b93, + (q31_t)0x42d81fe9, (q31_t)0x42d2c417, + (q31_t)0x42cd681b, (q31_t)0x42c80bf6, (q31_t)0x42c2afa8, (q31_t)0x42bd5331, (q31_t)0x42b7f690, (q31_t)0x42b299c7, + (q31_t)0x42ad3cd4, (q31_t)0x42a7dfb8, + (q31_t)0x42a28273, (q31_t)0x429d2505, (q31_t)0x4297c76e, (q31_t)0x429269ae, (q31_t)0x428d0bc4, (q31_t)0x4287adb2, + (q31_t)0x42824f76, (q31_t)0x427cf112, + (q31_t)0x42779285, (q31_t)0x427233ce, (q31_t)0x426cd4ef, (q31_t)0x426775e6, (q31_t)0x426216b5, (q31_t)0x425cb75a, + (q31_t)0x425757d7, (q31_t)0x4251f82b, + (q31_t)0x424c9856, (q31_t)0x42473858, (q31_t)0x4241d831, (q31_t)0x423c77e1, (q31_t)0x42371769, (q31_t)0x4231b6c7, + (q31_t)0x422c55fd, (q31_t)0x4226f50a, + (q31_t)0x422193ee, (q31_t)0x421c32a9, (q31_t)0x4216d13c, (q31_t)0x42116fa5, (q31_t)0x420c0de6, (q31_t)0x4206abfe, + (q31_t)0x420149ee, (q31_t)0x41fbe7b5, + (q31_t)0x41f68553, (q31_t)0x41f122c8, (q31_t)0x41ebc015, (q31_t)0x41e65d39, (q31_t)0x41e0fa35, (q31_t)0x41db9707, + (q31_t)0x41d633b1, (q31_t)0x41d0d033, + (q31_t)0x41cb6c8c, (q31_t)0x41c608bc, (q31_t)0x41c0a4c4, (q31_t)0x41bb40a3, (q31_t)0x41b5dc5a, (q31_t)0x41b077e8, + (q31_t)0x41ab134e, (q31_t)0x41a5ae8b, + (q31_t)0x41a049a0, (q31_t)0x419ae48c, (q31_t)0x41957f4f, (q31_t)0x419019eb, (q31_t)0x418ab45d, (q31_t)0x41854ea8, + (q31_t)0x417fe8ca, (q31_t)0x417a82c3, + (q31_t)0x41751c94, (q31_t)0x416fb63d, (q31_t)0x416a4fbd, (q31_t)0x4164e916, (q31_t)0x415f8245, (q31_t)0x415a1b4d, + (q31_t)0x4154b42c, (q31_t)0x414f4ce2, + (q31_t)0x4149e571, (q31_t)0x41447dd7, (q31_t)0x413f1615, (q31_t)0x4139ae2b, (q31_t)0x41344618, (q31_t)0x412edddd, + (q31_t)0x4129757b, (q31_t)0x41240cef, + (q31_t)0x411ea43c, (q31_t)0x41193b61, (q31_t)0x4113d25d, (q31_t)0x410e6931, (q31_t)0x4108ffdd, (q31_t)0x41039661, + (q31_t)0x40fe2cbd, (q31_t)0x40f8c2f1, + (q31_t)0x40f358fc, (q31_t)0x40edeee0, (q31_t)0x40e8849b, (q31_t)0x40e31a2f, (q31_t)0x40ddaf9b, (q31_t)0x40d844de, + (q31_t)0x40d2d9f9, (q31_t)0x40cd6eed, + (q31_t)0x40c803b8, (q31_t)0x40c2985c, (q31_t)0x40bd2cd8, (q31_t)0x40b7c12b, (q31_t)0x40b25557, (q31_t)0x40ace95b, + (q31_t)0x40a77d37, (q31_t)0x40a210eb, + (q31_t)0x409ca477, (q31_t)0x409737dc, (q31_t)0x4091cb18, (q31_t)0x408c5e2d, (q31_t)0x4086f11a, (q31_t)0x408183df, + (q31_t)0x407c167c, (q31_t)0x4076a8f1, + (q31_t)0x40713b3f, (q31_t)0x406bcd65, (q31_t)0x40665f63, (q31_t)0x4060f13a, (q31_t)0x405b82e9, (q31_t)0x40561470, + (q31_t)0x4050a5cf, (q31_t)0x404b3707, + (q31_t)0x4045c817, (q31_t)0x404058ff, (q31_t)0x403ae9c0, (q31_t)0x40357a59, (q31_t)0x40300acb, (q31_t)0x402a9b15, + (q31_t)0x40252b37, (q31_t)0x401fbb32, + (q31_t)0x401a4b05, (q31_t)0x4014dab1, (q31_t)0x400f6a35, (q31_t)0x4009f992, (q31_t)0x400488c7, (q31_t)0x3fff17d5, + (q31_t)0x3ff9a6bb, (q31_t)0x3ff4357a, + (q31_t)0x3feec411, (q31_t)0x3fe95281, (q31_t)0x3fe3e0c9, (q31_t)0x3fde6eeb, (q31_t)0x3fd8fce4, (q31_t)0x3fd38ab6, + (q31_t)0x3fce1861, (q31_t)0x3fc8a5e5, + (q31_t)0x3fc33341, (q31_t)0x3fbdc076, (q31_t)0x3fb84d83, (q31_t)0x3fb2da6a, (q31_t)0x3fad6729, (q31_t)0x3fa7f3c0, + (q31_t)0x3fa28031, (q31_t)0x3f9d0c7a, + (q31_t)0x3f97989c, (q31_t)0x3f922496, (q31_t)0x3f8cb06a, (q31_t)0x3f873c16, (q31_t)0x3f81c79b, (q31_t)0x3f7c52f9, + (q31_t)0x3f76de30, (q31_t)0x3f71693f, + (q31_t)0x3f6bf428, (q31_t)0x3f667ee9, (q31_t)0x3f610983, (q31_t)0x3f5b93f6, (q31_t)0x3f561e42, (q31_t)0x3f50a867, + (q31_t)0x3f4b3265, (q31_t)0x3f45bc3c, + (q31_t)0x3f4045ec, (q31_t)0x3f3acf75, (q31_t)0x3f3558d7, (q31_t)0x3f2fe211, (q31_t)0x3f2a6b25, (q31_t)0x3f24f412, + (q31_t)0x3f1f7cd8, (q31_t)0x3f1a0577, + (q31_t)0x3f148def, (q31_t)0x3f0f1640, (q31_t)0x3f099e6b, (q31_t)0x3f04266e, (q31_t)0x3efeae4a, (q31_t)0x3ef93600, + (q31_t)0x3ef3bd8f, (q31_t)0x3eee44f7, + (q31_t)0x3ee8cc38, (q31_t)0x3ee35352, (q31_t)0x3eddda46, (q31_t)0x3ed86113, (q31_t)0x3ed2e7b9, (q31_t)0x3ecd6e38, + (q31_t)0x3ec7f491, (q31_t)0x3ec27ac2, + (q31_t)0x3ebd00cd, (q31_t)0x3eb786b2, (q31_t)0x3eb20c6f, (q31_t)0x3eac9206, (q31_t)0x3ea71777, (q31_t)0x3ea19cc1, + (q31_t)0x3e9c21e4, (q31_t)0x3e96a6e0, + (q31_t)0x3e912bb6, (q31_t)0x3e8bb065, (q31_t)0x3e8634ee, (q31_t)0x3e80b950, (q31_t)0x3e7b3d8c, (q31_t)0x3e75c1a1, + (q31_t)0x3e70458f, (q31_t)0x3e6ac957, + (q31_t)0x3e654cf8, (q31_t)0x3e5fd073, (q31_t)0x3e5a53c8, (q31_t)0x3e54d6f6, (q31_t)0x3e4f59fe, (q31_t)0x3e49dcdf, + (q31_t)0x3e445f99, (q31_t)0x3e3ee22e, + (q31_t)0x3e39649c, (q31_t)0x3e33e6e3, (q31_t)0x3e2e6904, (q31_t)0x3e28eaff, (q31_t)0x3e236cd4, (q31_t)0x3e1dee82, + (q31_t)0x3e18700a, (q31_t)0x3e12f16b, + (q31_t)0x3e0d72a6, (q31_t)0x3e07f3bb, (q31_t)0x3e0274aa, (q31_t)0x3dfcf572, (q31_t)0x3df77615, (q31_t)0x3df1f691, + (q31_t)0x3dec76e6, (q31_t)0x3de6f716, + (q31_t)0x3de1771f, (q31_t)0x3ddbf703, (q31_t)0x3dd676c0, (q31_t)0x3dd0f656, (q31_t)0x3dcb75c7, (q31_t)0x3dc5f512, + (q31_t)0x3dc07436, (q31_t)0x3dbaf335, + (q31_t)0x3db5720d, (q31_t)0x3daff0c0, (q31_t)0x3daa6f4c, (q31_t)0x3da4edb2, (q31_t)0x3d9f6bf2, (q31_t)0x3d99ea0d, + (q31_t)0x3d946801, (q31_t)0x3d8ee5cf, + (q31_t)0x3d896377, (q31_t)0x3d83e0f9, (q31_t)0x3d7e5e56, (q31_t)0x3d78db8c, (q31_t)0x3d73589d, (q31_t)0x3d6dd587, + (q31_t)0x3d68524c, (q31_t)0x3d62ceeb, + (q31_t)0x3d5d4b64, (q31_t)0x3d57c7b7, (q31_t)0x3d5243e4, (q31_t)0x3d4cbfeb, (q31_t)0x3d473bcd, (q31_t)0x3d41b789, + (q31_t)0x3d3c331f, (q31_t)0x3d36ae8f, + (q31_t)0x3d3129da, (q31_t)0x3d2ba4fe, (q31_t)0x3d261ffd, (q31_t)0x3d209ad7, (q31_t)0x3d1b158a, (q31_t)0x3d159018, + (q31_t)0x3d100a80, (q31_t)0x3d0a84c3, + (q31_t)0x3d04fee0, (q31_t)0x3cff78d7, (q31_t)0x3cf9f2a9, (q31_t)0x3cf46c55, (q31_t)0x3ceee5db, (q31_t)0x3ce95f3c, + (q31_t)0x3ce3d877, (q31_t)0x3cde518d, + (q31_t)0x3cd8ca7d, (q31_t)0x3cd34347, (q31_t)0x3ccdbbed, (q31_t)0x3cc8346c, (q31_t)0x3cc2acc6, (q31_t)0x3cbd24fb, + (q31_t)0x3cb79d0a, (q31_t)0x3cb214f4, + (q31_t)0x3cac8cb8, (q31_t)0x3ca70457, (q31_t)0x3ca17bd0, (q31_t)0x3c9bf324, (q31_t)0x3c966a53, (q31_t)0x3c90e15c, + (q31_t)0x3c8b5840, (q31_t)0x3c85cefe, + (q31_t)0x3c804598, (q31_t)0x3c7abc0c, (q31_t)0x3c75325a, (q31_t)0x3c6fa883, (q31_t)0x3c6a1e87, (q31_t)0x3c649466, + (q31_t)0x3c5f0a20, (q31_t)0x3c597fb4, + (q31_t)0x3c53f523, (q31_t)0x3c4e6a6d, (q31_t)0x3c48df91, (q31_t)0x3c435491, (q31_t)0x3c3dc96b, (q31_t)0x3c383e20, + (q31_t)0x3c32b2b0, (q31_t)0x3c2d271b, + (q31_t)0x3c279b61, (q31_t)0x3c220f81, (q31_t)0x3c1c837d, (q31_t)0x3c16f753, (q31_t)0x3c116b04, (q31_t)0x3c0bde91, + (q31_t)0x3c0651f8, (q31_t)0x3c00c53a, + (q31_t)0x3bfb3857, (q31_t)0x3bf5ab50, (q31_t)0x3bf01e23, (q31_t)0x3bea90d1, (q31_t)0x3be5035a, (q31_t)0x3bdf75bf, + (q31_t)0x3bd9e7fe, (q31_t)0x3bd45a19, + (q31_t)0x3bcecc0e, (q31_t)0x3bc93ddf, (q31_t)0x3bc3af8b, (q31_t)0x3bbe2112, (q31_t)0x3bb89274, (q31_t)0x3bb303b1, + (q31_t)0x3bad74c9, (q31_t)0x3ba7e5bd, + (q31_t)0x3ba2568c, (q31_t)0x3b9cc736, (q31_t)0x3b9737bb, (q31_t)0x3b91a81c, (q31_t)0x3b8c1857, (q31_t)0x3b86886e, + (q31_t)0x3b80f861, (q31_t)0x3b7b682e, + (q31_t)0x3b75d7d7, (q31_t)0x3b70475c, (q31_t)0x3b6ab6bb, (q31_t)0x3b6525f6, (q31_t)0x3b5f950c, (q31_t)0x3b5a03fe, + (q31_t)0x3b5472cb, (q31_t)0x3b4ee173, + (q31_t)0x3b494ff7, (q31_t)0x3b43be57, (q31_t)0x3b3e2c91, (q31_t)0x3b389aa8, (q31_t)0x3b330899, (q31_t)0x3b2d7666, + (q31_t)0x3b27e40f, (q31_t)0x3b225193, + (q31_t)0x3b1cbef3, (q31_t)0x3b172c2e, (q31_t)0x3b119945, (q31_t)0x3b0c0637, (q31_t)0x3b067305, (q31_t)0x3b00dfaf, + (q31_t)0x3afb4c34, (q31_t)0x3af5b894, + (q31_t)0x3af024d1, (q31_t)0x3aea90e9, (q31_t)0x3ae4fcdc, (q31_t)0x3adf68ac, (q31_t)0x3ad9d457, (q31_t)0x3ad43fdd, + (q31_t)0x3aceab40, (q31_t)0x3ac9167e, + (q31_t)0x3ac38198, (q31_t)0x3abdec8d, (q31_t)0x3ab8575f, (q31_t)0x3ab2c20c, (q31_t)0x3aad2c95, (q31_t)0x3aa796fa, + (q31_t)0x3aa2013a, (q31_t)0x3a9c6b57, + (q31_t)0x3a96d54f, (q31_t)0x3a913f23, (q31_t)0x3a8ba8d3, (q31_t)0x3a86125f, (q31_t)0x3a807bc7, (q31_t)0x3a7ae50a, + (q31_t)0x3a754e2a, (q31_t)0x3a6fb726, + (q31_t)0x3a6a1ffd, (q31_t)0x3a6488b1, (q31_t)0x3a5ef140, (q31_t)0x3a5959ab, (q31_t)0x3a53c1f3, (q31_t)0x3a4e2a16, + (q31_t)0x3a489216, (q31_t)0x3a42f9f2, + (q31_t)0x3a3d61a9, (q31_t)0x3a37c93d, (q31_t)0x3a3230ad, (q31_t)0x3a2c97f9, (q31_t)0x3a26ff21, (q31_t)0x3a216625, + (q31_t)0x3a1bcd05, (q31_t)0x3a1633c1, + (q31_t)0x3a109a5a, (q31_t)0x3a0b00cf, (q31_t)0x3a056720, (q31_t)0x39ffcd4d, (q31_t)0x39fa3356, (q31_t)0x39f4993c, + (q31_t)0x39eefefe, (q31_t)0x39e9649c, + (q31_t)0x39e3ca17, (q31_t)0x39de2f6d, (q31_t)0x39d894a0, (q31_t)0x39d2f9b0, (q31_t)0x39cd5e9b, (q31_t)0x39c7c363, + (q31_t)0x39c22808, (q31_t)0x39bc8c89, + (q31_t)0x39b6f0e6, (q31_t)0x39b1551f, (q31_t)0x39abb935, (q31_t)0x39a61d28, (q31_t)0x39a080f6, (q31_t)0x399ae4a2, + (q31_t)0x39954829, (q31_t)0x398fab8e, + (q31_t)0x398a0ece, (q31_t)0x398471ec, (q31_t)0x397ed4e5, (q31_t)0x397937bc, (q31_t)0x39739a6e, (q31_t)0x396dfcfe, + (q31_t)0x39685f6a, (q31_t)0x3962c1b2, + (q31_t)0x395d23d7, (q31_t)0x395785d9, (q31_t)0x3951e7b8, (q31_t)0x394c4973, (q31_t)0x3946ab0a, (q31_t)0x39410c7f, + (q31_t)0x393b6dd0, (q31_t)0x3935cefd, + (q31_t)0x39303008, (q31_t)0x392a90ef, (q31_t)0x3924f1b3, (q31_t)0x391f5254, (q31_t)0x3919b2d1, (q31_t)0x3914132b, + (q31_t)0x390e7362, (q31_t)0x3908d376, + (q31_t)0x39033367, (q31_t)0x38fd9334, (q31_t)0x38f7f2de, (q31_t)0x38f25266, (q31_t)0x38ecb1ca, (q31_t)0x38e7110a, + (q31_t)0x38e17028, (q31_t)0x38dbcf23, + (q31_t)0x38d62dfb, (q31_t)0x38d08caf, (q31_t)0x38caeb41, (q31_t)0x38c549af, (q31_t)0x38bfa7fb, (q31_t)0x38ba0623, + (q31_t)0x38b46429, (q31_t)0x38aec20b, + (q31_t)0x38a91fcb, (q31_t)0x38a37d67, (q31_t)0x389ddae1, (q31_t)0x38983838, (q31_t)0x3892956c, (q31_t)0x388cf27d, + (q31_t)0x38874f6b, (q31_t)0x3881ac36, + (q31_t)0x387c08de, (q31_t)0x38766564, (q31_t)0x3870c1c6, (q31_t)0x386b1e06, (q31_t)0x38657a23, (q31_t)0x385fd61d, + (q31_t)0x385a31f5, (q31_t)0x38548daa, + (q31_t)0x384ee93b, (q31_t)0x384944ab, (q31_t)0x38439ff7, (q31_t)0x383dfb21, (q31_t)0x38385628, (q31_t)0x3832b10d, + (q31_t)0x382d0bce, (q31_t)0x3827666d, + (q31_t)0x3821c0ea, (q31_t)0x381c1b44, (q31_t)0x3816757b, (q31_t)0x3810cf90, (q31_t)0x380b2982, (q31_t)0x38058351, + (q31_t)0x37ffdcfe, (q31_t)0x37fa3688, + (q31_t)0x37f48ff0, (q31_t)0x37eee936, (q31_t)0x37e94259, (q31_t)0x37e39b59, (q31_t)0x37ddf437, (q31_t)0x37d84cf2, + (q31_t)0x37d2a58b, (q31_t)0x37ccfe02, + (q31_t)0x37c75656, (q31_t)0x37c1ae87, (q31_t)0x37bc0697, (q31_t)0x37b65e84, (q31_t)0x37b0b64e, (q31_t)0x37ab0df6, + (q31_t)0x37a5657c, (q31_t)0x379fbce0, + (q31_t)0x379a1421, (q31_t)0x37946b40, (q31_t)0x378ec23d, (q31_t)0x37891917, (q31_t)0x37836fcf, (q31_t)0x377dc665, + (q31_t)0x37781cd9, (q31_t)0x3772732a, + (q31_t)0x376cc959, (q31_t)0x37671f66, (q31_t)0x37617551, (q31_t)0x375bcb1a, (q31_t)0x375620c1, (q31_t)0x37507645, + (q31_t)0x374acba7, (q31_t)0x374520e7, + (q31_t)0x373f7606, (q31_t)0x3739cb02, (q31_t)0x37341fdc, (q31_t)0x372e7493, (q31_t)0x3728c929, (q31_t)0x37231d9d, + (q31_t)0x371d71ef, (q31_t)0x3717c61f, + (q31_t)0x37121a2d, (q31_t)0x370c6e19, (q31_t)0x3706c1e2, (q31_t)0x3701158a, (q31_t)0x36fb6910, (q31_t)0x36f5bc75, + (q31_t)0x36f00fb7, (q31_t)0x36ea62d7, + (q31_t)0x36e4b5d6, (q31_t)0x36df08b2, (q31_t)0x36d95b6d, (q31_t)0x36d3ae06, (q31_t)0x36ce007d, (q31_t)0x36c852d2, + (q31_t)0x36c2a506, (q31_t)0x36bcf718, + (q31_t)0x36b74908, (q31_t)0x36b19ad6, (q31_t)0x36abec82, (q31_t)0x36a63e0d, (q31_t)0x36a08f76, (q31_t)0x369ae0bd, + (q31_t)0x369531e3, (q31_t)0x368f82e7, + (q31_t)0x3689d3c9, (q31_t)0x3684248a, (q31_t)0x367e7529, (q31_t)0x3678c5a7, (q31_t)0x36731602, (q31_t)0x366d663d, + (q31_t)0x3667b655, (q31_t)0x3662064c, + (q31_t)0x365c5622, (q31_t)0x3656a5d6, (q31_t)0x3650f569, (q31_t)0x364b44da, (q31_t)0x36459429, (q31_t)0x363fe357, + (q31_t)0x363a3264, (q31_t)0x3634814f, + (q31_t)0x362ed019, (q31_t)0x36291ec1, (q31_t)0x36236d48, (q31_t)0x361dbbad, (q31_t)0x361809f1, (q31_t)0x36125814, + (q31_t)0x360ca615, (q31_t)0x3606f3f5, + (q31_t)0x360141b4, (q31_t)0x35fb8f52, (q31_t)0x35f5dcce, (q31_t)0x35f02a28, (q31_t)0x35ea7762, (q31_t)0x35e4c47a, + (q31_t)0x35df1171, (q31_t)0x35d95e47, + (q31_t)0x35d3aafc, (q31_t)0x35cdf78f, (q31_t)0x35c84401, (q31_t)0x35c29052, (q31_t)0x35bcdc82, (q31_t)0x35b72891, + (q31_t)0x35b1747e, (q31_t)0x35abc04b, + (q31_t)0x35a60bf6, (q31_t)0x35a05781, (q31_t)0x359aa2ea, (q31_t)0x3594ee32, (q31_t)0x358f3959, (q31_t)0x3589845f, + (q31_t)0x3583cf44, (q31_t)0x357e1a08, + (q31_t)0x357864ab, (q31_t)0x3572af2d, (q31_t)0x356cf98e, (q31_t)0x356743ce, (q31_t)0x35618ded, (q31_t)0x355bd7eb, + (q31_t)0x355621c9, (q31_t)0x35506b85, + (q31_t)0x354ab520, (q31_t)0x3544fe9b, (q31_t)0x353f47f5, (q31_t)0x3539912e, (q31_t)0x3533da46, (q31_t)0x352e233d, + (q31_t)0x35286c14, (q31_t)0x3522b4c9, + (q31_t)0x351cfd5e, (q31_t)0x351745d2, (q31_t)0x35118e26, (q31_t)0x350bd658, (q31_t)0x35061e6a, (q31_t)0x3500665c, + (q31_t)0x34faae2c, (q31_t)0x34f4f5dc, + (q31_t)0x34ef3d6b, (q31_t)0x34e984da, (q31_t)0x34e3cc28, (q31_t)0x34de1355, (q31_t)0x34d85a62, (q31_t)0x34d2a14e, + (q31_t)0x34cce819, (q31_t)0x34c72ec4, + (q31_t)0x34c1754e, (q31_t)0x34bbbbb8, (q31_t)0x34b60202, (q31_t)0x34b0482a, (q31_t)0x34aa8e33, (q31_t)0x34a4d41a, + (q31_t)0x349f19e2, (q31_t)0x34995f88, + (q31_t)0x3493a50f, (q31_t)0x348dea75, (q31_t)0x34882fba, (q31_t)0x348274e0, (q31_t)0x347cb9e4, (q31_t)0x3476fec9, + (q31_t)0x3471438d, (q31_t)0x346b8830, + (q31_t)0x3465ccb4, (q31_t)0x34601117, (q31_t)0x345a5559, (q31_t)0x3454997c, (q31_t)0x344edd7e, (q31_t)0x34492160, + (q31_t)0x34436521, (q31_t)0x343da8c3, + (q31_t)0x3437ec44, (q31_t)0x34322fa5, (q31_t)0x342c72e6, (q31_t)0x3426b606, (q31_t)0x3420f907, (q31_t)0x341b3be7, + (q31_t)0x34157ea7, (q31_t)0x340fc147, + (q31_t)0x340a03c7, (q31_t)0x34044626, (q31_t)0x33fe8866, (q31_t)0x33f8ca86, (q31_t)0x33f30c85, (q31_t)0x33ed4e65, + (q31_t)0x33e79024, (q31_t)0x33e1d1c4, + (q31_t)0x33dc1343, (q31_t)0x33d654a2, (q31_t)0x33d095e2, (q31_t)0x33cad701, (q31_t)0x33c51801, (q31_t)0x33bf58e1, + (q31_t)0x33b999a0, (q31_t)0x33b3da40, + (q31_t)0x33ae1ac0, (q31_t)0x33a85b20, (q31_t)0x33a29b60, (q31_t)0x339cdb81, (q31_t)0x33971b81, (q31_t)0x33915b62, + (q31_t)0x338b9b22, (q31_t)0x3385dac4, + (q31_t)0x33801a45, (q31_t)0x337a59a6, (q31_t)0x337498e8, (q31_t)0x336ed80a, (q31_t)0x3369170c, (q31_t)0x336355ef, + (q31_t)0x335d94b2, (q31_t)0x3357d355, + (q31_t)0x335211d8, (q31_t)0x334c503c, (q31_t)0x33468e80, (q31_t)0x3340cca5, (q31_t)0x333b0aaa, (q31_t)0x3335488f, + (q31_t)0x332f8655, (q31_t)0x3329c3fb, + (q31_t)0x33240182, (q31_t)0x331e3ee9, (q31_t)0x33187c31, (q31_t)0x3312b959, (q31_t)0x330cf661, (q31_t)0x3307334a, + (q31_t)0x33017014, (q31_t)0x32fbacbe, + (q31_t)0x32f5e948, (q31_t)0x32f025b4, (q31_t)0x32ea61ff, (q31_t)0x32e49e2c, (q31_t)0x32deda39, (q31_t)0x32d91626, + (q31_t)0x32d351f5, (q31_t)0x32cd8da4, + (q31_t)0x32c7c933, (q31_t)0x32c204a3, (q31_t)0x32bc3ff4, (q31_t)0x32b67b26, (q31_t)0x32b0b638, (q31_t)0x32aaf12b, + (q31_t)0x32a52bff, (q31_t)0x329f66b4, + (q31_t)0x3299a149, (q31_t)0x3293dbbf, (q31_t)0x328e1616, (q31_t)0x3288504e, (q31_t)0x32828a67, (q31_t)0x327cc460, + (q31_t)0x3276fe3a, (q31_t)0x327137f6, + (q31_t)0x326b7192, (q31_t)0x3265ab0f, (q31_t)0x325fe46c, (q31_t)0x325a1dab, (q31_t)0x325456cb, (q31_t)0x324e8fcc, + (q31_t)0x3248c8ad, (q31_t)0x32430170, + (q31_t)0x323d3a14, (q31_t)0x32377298, (q31_t)0x3231aafe, (q31_t)0x322be345, (q31_t)0x32261b6c, (q31_t)0x32205375, + (q31_t)0x321a8b5f, (q31_t)0x3214c32a, + (q31_t)0x320efad6, (q31_t)0x32093263, (q31_t)0x320369d2, (q31_t)0x31fda121, (q31_t)0x31f7d852, (q31_t)0x31f20f64, + (q31_t)0x31ec4657, (q31_t)0x31e67d2b, + (q31_t)0x31e0b3e0, (q31_t)0x31daea77, (q31_t)0x31d520ef, (q31_t)0x31cf5748, (q31_t)0x31c98d83, (q31_t)0x31c3c39e, + (q31_t)0x31bdf99b, (q31_t)0x31b82f7a, + (q31_t)0x31b2653a, (q31_t)0x31ac9adb, (q31_t)0x31a6d05d, (q31_t)0x31a105c1, (q31_t)0x319b3b06, (q31_t)0x3195702d, + (q31_t)0x318fa535, (q31_t)0x3189da1e, + (q31_t)0x31840ee9, (q31_t)0x317e4395, (q31_t)0x31787823, (q31_t)0x3172ac92, (q31_t)0x316ce0e3, (q31_t)0x31671515, + (q31_t)0x31614929, (q31_t)0x315b7d1e, + (q31_t)0x3155b0f5, (q31_t)0x314fe4ae, (q31_t)0x314a1848, (q31_t)0x31444bc3, (q31_t)0x313e7f21, (q31_t)0x3138b260, + (q31_t)0x3132e580, (q31_t)0x312d1882, + (q31_t)0x31274b66, (q31_t)0x31217e2c, (q31_t)0x311bb0d3, (q31_t)0x3115e35c, (q31_t)0x311015c6, (q31_t)0x310a4813, + (q31_t)0x31047a41, (q31_t)0x30feac51, + (q31_t)0x30f8de42, (q31_t)0x30f31016, (q31_t)0x30ed41cb, (q31_t)0x30e77362, (q31_t)0x30e1a4db, (q31_t)0x30dbd636, + (q31_t)0x30d60772, (q31_t)0x30d03891, + (q31_t)0x30ca6991, (q31_t)0x30c49a74, (q31_t)0x30becb38, (q31_t)0x30b8fbde, (q31_t)0x30b32c66, (q31_t)0x30ad5cd0, + (q31_t)0x30a78d1c, (q31_t)0x30a1bd4a, + (q31_t)0x309bed5a, (q31_t)0x30961d4c, (q31_t)0x30904d20, (q31_t)0x308a7cd6, (q31_t)0x3084ac6e, (q31_t)0x307edbe9, + (q31_t)0x30790b45, (q31_t)0x30733a83, + (q31_t)0x306d69a4, (q31_t)0x306798a7, (q31_t)0x3061c78b, (q31_t)0x305bf652, (q31_t)0x305624fb, (q31_t)0x30505387, + (q31_t)0x304a81f4, (q31_t)0x3044b044, + (q31_t)0x303ede76, (q31_t)0x30390c8a, (q31_t)0x30333a80, (q31_t)0x302d6859, (q31_t)0x30279614, (q31_t)0x3021c3b1, + (q31_t)0x301bf131, (q31_t)0x30161e93, + (q31_t)0x30104bd7, (q31_t)0x300a78fe, (q31_t)0x3004a607, (q31_t)0x2ffed2f2, (q31_t)0x2ff8ffc0, (q31_t)0x2ff32c70, + (q31_t)0x2fed5902, (q31_t)0x2fe78577, + (q31_t)0x2fe1b1cf, (q31_t)0x2fdbde09, (q31_t)0x2fd60a25, (q31_t)0x2fd03624, (q31_t)0x2fca6206, (q31_t)0x2fc48dc9, + (q31_t)0x2fbeb970, (q31_t)0x2fb8e4f9, + (q31_t)0x2fb31064, (q31_t)0x2fad3bb3, (q31_t)0x2fa766e3, (q31_t)0x2fa191f7, (q31_t)0x2f9bbced, (q31_t)0x2f95e7c5, + (q31_t)0x2f901280, (q31_t)0x2f8a3d1e, + (q31_t)0x2f84679f, (q31_t)0x2f7e9202, (q31_t)0x2f78bc48, (q31_t)0x2f72e671, (q31_t)0x2f6d107c, (q31_t)0x2f673a6a, + (q31_t)0x2f61643b, (q31_t)0x2f5b8def, + (q31_t)0x2f55b785, (q31_t)0x2f4fe0ff, (q31_t)0x2f4a0a5b, (q31_t)0x2f44339a, (q31_t)0x2f3e5cbb, (q31_t)0x2f3885c0, + (q31_t)0x2f32aea8, (q31_t)0x2f2cd772, + (q31_t)0x2f27001f, (q31_t)0x2f2128af, (q31_t)0x2f1b5122, (q31_t)0x2f157979, (q31_t)0x2f0fa1b2, (q31_t)0x2f09c9ce, + (q31_t)0x2f03f1cd, (q31_t)0x2efe19ae, + (q31_t)0x2ef84173, (q31_t)0x2ef2691b, (q31_t)0x2eec90a7, (q31_t)0x2ee6b815, (q31_t)0x2ee0df66, (q31_t)0x2edb069a, + (q31_t)0x2ed52db1, (q31_t)0x2ecf54ac, + (q31_t)0x2ec97b89, (q31_t)0x2ec3a24a, (q31_t)0x2ebdc8ee, (q31_t)0x2eb7ef75, (q31_t)0x2eb215df, (q31_t)0x2eac3c2d, + (q31_t)0x2ea6625d, (q31_t)0x2ea08871, + (q31_t)0x2e9aae68, (q31_t)0x2e94d443, (q31_t)0x2e8efa00, (q31_t)0x2e891fa1, (q31_t)0x2e834525, (q31_t)0x2e7d6a8d, + (q31_t)0x2e778fd8, (q31_t)0x2e71b506, + (q31_t)0x2e6bda17, (q31_t)0x2e65ff0c, (q31_t)0x2e6023e5, (q31_t)0x2e5a48a0, (q31_t)0x2e546d3f, (q31_t)0x2e4e91c2, + (q31_t)0x2e48b628, (q31_t)0x2e42da71, + (q31_t)0x2e3cfe9e, (q31_t)0x2e3722ae, (q31_t)0x2e3146a2, (q31_t)0x2e2b6a79, (q31_t)0x2e258e34, (q31_t)0x2e1fb1d3, + (q31_t)0x2e19d554, (q31_t)0x2e13f8ba, + (q31_t)0x2e0e1c03, (q31_t)0x2e083f30, (q31_t)0x2e026240, (q31_t)0x2dfc8534, (q31_t)0x2df6a80b, (q31_t)0x2df0cac6, + (q31_t)0x2deaed65, (q31_t)0x2de50fe8, + (q31_t)0x2ddf324e, (q31_t)0x2dd95498, (q31_t)0x2dd376c5, (q31_t)0x2dcd98d7, (q31_t)0x2dc7bacc, (q31_t)0x2dc1dca4, + (q31_t)0x2dbbfe61, (q31_t)0x2db62001, + (q31_t)0x2db04186, (q31_t)0x2daa62ee, (q31_t)0x2da4843a, (q31_t)0x2d9ea569, (q31_t)0x2d98c67d, (q31_t)0x2d92e774, + (q31_t)0x2d8d084f, (q31_t)0x2d87290f, + (q31_t)0x2d8149b2, (q31_t)0x2d7b6a39, (q31_t)0x2d758aa4, (q31_t)0x2d6faaf3, (q31_t)0x2d69cb26, (q31_t)0x2d63eb3d, + (q31_t)0x2d5e0b38, (q31_t)0x2d582b17, + (q31_t)0x2d524ada, (q31_t)0x2d4c6a81, (q31_t)0x2d468a0c, (q31_t)0x2d40a97b, (q31_t)0x2d3ac8ce, (q31_t)0x2d34e805, + (q31_t)0x2d2f0721, (q31_t)0x2d292620, + (q31_t)0x2d234504, (q31_t)0x2d1d63cc, (q31_t)0x2d178278, (q31_t)0x2d11a108, (q31_t)0x2d0bbf7d, (q31_t)0x2d05ddd5, + (q31_t)0x2cfffc12, (q31_t)0x2cfa1a33, + (q31_t)0x2cf43839, (q31_t)0x2cee5622, (q31_t)0x2ce873f0, (q31_t)0x2ce291a2, (q31_t)0x2cdcaf39, (q31_t)0x2cd6ccb4, + (q31_t)0x2cd0ea13, (q31_t)0x2ccb0756, + (q31_t)0x2cc5247e, (q31_t)0x2cbf418b, (q31_t)0x2cb95e7b, (q31_t)0x2cb37b51, (q31_t)0x2cad980a, (q31_t)0x2ca7b4a8, + (q31_t)0x2ca1d12a, (q31_t)0x2c9bed91, + (q31_t)0x2c9609dd, (q31_t)0x2c90260d, (q31_t)0x2c8a4221, (q31_t)0x2c845e1a, (q31_t)0x2c7e79f7, (q31_t)0x2c7895b9, + (q31_t)0x2c72b160, (q31_t)0x2c6ccceb, + (q31_t)0x2c66e85b, (q31_t)0x2c6103af, (q31_t)0x2c5b1ee8, (q31_t)0x2c553a06, (q31_t)0x2c4f5508, (q31_t)0x2c496fef, + (q31_t)0x2c438abb, (q31_t)0x2c3da56b, + (q31_t)0x2c37c000, (q31_t)0x2c31da7a, (q31_t)0x2c2bf4d8, (q31_t)0x2c260f1c, (q31_t)0x2c202944, (q31_t)0x2c1a4351, + (q31_t)0x2c145d42, (q31_t)0x2c0e7719, + (q31_t)0x2c0890d4, (q31_t)0x2c02aa74, (q31_t)0x2bfcc3f9, (q31_t)0x2bf6dd63, (q31_t)0x2bf0f6b1, (q31_t)0x2beb0fe5, + (q31_t)0x2be528fd, (q31_t)0x2bdf41fb, + (q31_t)0x2bd95add, (q31_t)0x2bd373a4, (q31_t)0x2bcd8c51, (q31_t)0x2bc7a4e2, (q31_t)0x2bc1bd58, (q31_t)0x2bbbd5b3, + (q31_t)0x2bb5edf4, (q31_t)0x2bb00619, + (q31_t)0x2baa1e23, (q31_t)0x2ba43613, (q31_t)0x2b9e4de7, (q31_t)0x2b9865a1, (q31_t)0x2b927d3f, (q31_t)0x2b8c94c3, + (q31_t)0x2b86ac2c, (q31_t)0x2b80c37a, + (q31_t)0x2b7adaae, (q31_t)0x2b74f1c6, (q31_t)0x2b6f08c4, (q31_t)0x2b691fa6, (q31_t)0x2b63366f, (q31_t)0x2b5d4d1c, + (q31_t)0x2b5763ae, (q31_t)0x2b517a26, + (q31_t)0x2b4b9083, (q31_t)0x2b45a6c6, (q31_t)0x2b3fbced, (q31_t)0x2b39d2fa, (q31_t)0x2b33e8ed, (q31_t)0x2b2dfec5, + (q31_t)0x2b281482, (q31_t)0x2b222a24, + (q31_t)0x2b1c3fac, (q31_t)0x2b165519, (q31_t)0x2b106a6c, (q31_t)0x2b0a7fa4, (q31_t)0x2b0494c2, (q31_t)0x2afea9c5, + (q31_t)0x2af8bead, (q31_t)0x2af2d37b, + (q31_t)0x2aece82f, (q31_t)0x2ae6fcc8, (q31_t)0x2ae11146, (q31_t)0x2adb25aa, (q31_t)0x2ad539f4, (q31_t)0x2acf4e23, + (q31_t)0x2ac96238, (q31_t)0x2ac37633, + (q31_t)0x2abd8a13, (q31_t)0x2ab79dd8, (q31_t)0x2ab1b184, (q31_t)0x2aabc515, (q31_t)0x2aa5d88b, (q31_t)0x2a9febe8, + (q31_t)0x2a99ff2a, (q31_t)0x2a941252, + (q31_t)0x2a8e255f, (q31_t)0x2a883853, (q31_t)0x2a824b2c, (q31_t)0x2a7c5deb, (q31_t)0x2a76708f, (q31_t)0x2a70831a, + (q31_t)0x2a6a958a, (q31_t)0x2a64a7e0, + (q31_t)0x2a5eba1c, (q31_t)0x2a58cc3e, (q31_t)0x2a52de46, (q31_t)0x2a4cf033, (q31_t)0x2a470207, (q31_t)0x2a4113c0, + (q31_t)0x2a3b2560, (q31_t)0x2a3536e5, + (q31_t)0x2a2f4850, (q31_t)0x2a2959a1, (q31_t)0x2a236ad9, (q31_t)0x2a1d7bf6, (q31_t)0x2a178cf9, (q31_t)0x2a119de2, + (q31_t)0x2a0baeb2, (q31_t)0x2a05bf67, + (q31_t)0x29ffd003, (q31_t)0x29f9e084, (q31_t)0x29f3f0ec, (q31_t)0x29ee013a, (q31_t)0x29e8116e, (q31_t)0x29e22188, + (q31_t)0x29dc3188, (q31_t)0x29d6416f, + (q31_t)0x29d0513b, (q31_t)0x29ca60ee, (q31_t)0x29c47087, (q31_t)0x29be8007, (q31_t)0x29b88f6c, (q31_t)0x29b29eb8, + (q31_t)0x29acadea, (q31_t)0x29a6bd02, + (q31_t)0x29a0cc01, (q31_t)0x299adae6, (q31_t)0x2994e9b1, (q31_t)0x298ef863, (q31_t)0x298906fb, (q31_t)0x2983157a, + (q31_t)0x297d23df, (q31_t)0x2977322a, + (q31_t)0x2971405b, (q31_t)0x296b4e74, (q31_t)0x29655c72, (q31_t)0x295f6a57, (q31_t)0x29597823, (q31_t)0x295385d5, + (q31_t)0x294d936d, (q31_t)0x2947a0ec, + (q31_t)0x2941ae52, (q31_t)0x293bbb9e, (q31_t)0x2935c8d1, (q31_t)0x292fd5ea, (q31_t)0x2929e2ea, (q31_t)0x2923efd0, + (q31_t)0x291dfc9d, (q31_t)0x29180951, + (q31_t)0x291215eb, (q31_t)0x290c226c, (q31_t)0x29062ed4, (q31_t)0x29003b23, (q31_t)0x28fa4758, (q31_t)0x28f45374, + (q31_t)0x28ee5f76, (q31_t)0x28e86b5f, + (q31_t)0x28e27730, (q31_t)0x28dc82e6, (q31_t)0x28d68e84, (q31_t)0x28d09a09, (q31_t)0x28caa574, (q31_t)0x28c4b0c6, + (q31_t)0x28bebbff, (q31_t)0x28b8c71f, + (q31_t)0x28b2d226, (q31_t)0x28acdd13, (q31_t)0x28a6e7e8, (q31_t)0x28a0f2a3, (q31_t)0x289afd46, (q31_t)0x289507cf, + (q31_t)0x288f123f, (q31_t)0x28891c97, + (q31_t)0x288326d5, (q31_t)0x287d30fa, (q31_t)0x28773b07, (q31_t)0x287144fa, (q31_t)0x286b4ed5, (q31_t)0x28655896, + (q31_t)0x285f623f, (q31_t)0x28596bce, + (q31_t)0x28537545, (q31_t)0x284d7ea3, (q31_t)0x284787e8, (q31_t)0x28419114, (q31_t)0x283b9a28, (q31_t)0x2835a322, + (q31_t)0x282fac04, (q31_t)0x2829b4cd, + (q31_t)0x2823bd7d, (q31_t)0x281dc615, (q31_t)0x2817ce93, (q31_t)0x2811d6f9, (q31_t)0x280bdf46, (q31_t)0x2805e77b, + (q31_t)0x27ffef97, (q31_t)0x27f9f79a, + (q31_t)0x27f3ff85, (q31_t)0x27ee0756, (q31_t)0x27e80f10, (q31_t)0x27e216b0, (q31_t)0x27dc1e38, (q31_t)0x27d625a8, + (q31_t)0x27d02cff, (q31_t)0x27ca343d, + (q31_t)0x27c43b63, (q31_t)0x27be4270, (q31_t)0x27b84965, (q31_t)0x27b25041, (q31_t)0x27ac5705, (q31_t)0x27a65db0, + (q31_t)0x27a06443, (q31_t)0x279a6abd, + (q31_t)0x2794711f, (q31_t)0x278e7768, (q31_t)0x27887d99, (q31_t)0x278283b2, (q31_t)0x277c89b3, (q31_t)0x27768f9b, + (q31_t)0x2770956a, (q31_t)0x276a9b21, + (q31_t)0x2764a0c0, (q31_t)0x275ea647, (q31_t)0x2758abb6, (q31_t)0x2752b10c, (q31_t)0x274cb64a, (q31_t)0x2746bb6f, + (q31_t)0x2740c07d, (q31_t)0x273ac572, + (q31_t)0x2734ca4f, (q31_t)0x272ecf14, (q31_t)0x2728d3c0, (q31_t)0x2722d855, (q31_t)0x271cdcd1, (q31_t)0x2716e136, + (q31_t)0x2710e582, (q31_t)0x270ae9b6, + (q31_t)0x2704edd2, (q31_t)0x26fef1d5, (q31_t)0x26f8f5c1, (q31_t)0x26f2f995, (q31_t)0x26ecfd51, (q31_t)0x26e700f5, + (q31_t)0x26e10480, (q31_t)0x26db07f4, + (q31_t)0x26d50b50, (q31_t)0x26cf0e94, (q31_t)0x26c911c0, (q31_t)0x26c314d4, (q31_t)0x26bd17d0, (q31_t)0x26b71ab4, + (q31_t)0x26b11d80, (q31_t)0x26ab2034, + (q31_t)0x26a522d1, (q31_t)0x269f2556, (q31_t)0x269927c3, (q31_t)0x26932a18, (q31_t)0x268d2c55, (q31_t)0x26872e7b, + (q31_t)0x26813088, (q31_t)0x267b327e, + (q31_t)0x2675345d, (q31_t)0x266f3623, (q31_t)0x266937d2, (q31_t)0x26633969, (q31_t)0x265d3ae9, (q31_t)0x26573c50, + (q31_t)0x26513da1, (q31_t)0x264b3ed9, + (q31_t)0x26453ffa, (q31_t)0x263f4103, (q31_t)0x263941f5, (q31_t)0x263342cf, (q31_t)0x262d4392, (q31_t)0x2627443d, + (q31_t)0x262144d0, (q31_t)0x261b454c, + (q31_t)0x261545b0, (q31_t)0x260f45fd, (q31_t)0x26094633, (q31_t)0x26034651, (q31_t)0x25fd4657, (q31_t)0x25f74646, + (q31_t)0x25f1461e, (q31_t)0x25eb45de, + (q31_t)0x25e54587, (q31_t)0x25df4519, (q31_t)0x25d94493, (q31_t)0x25d343f6, (q31_t)0x25cd4341, (q31_t)0x25c74276, + (q31_t)0x25c14192, (q31_t)0x25bb4098, + (q31_t)0x25b53f86, (q31_t)0x25af3e5d, (q31_t)0x25a93d1d, (q31_t)0x25a33bc6, (q31_t)0x259d3a57, (q31_t)0x259738d1, + (q31_t)0x25913734, (q31_t)0x258b3580, + (q31_t)0x258533b5, (q31_t)0x257f31d2, (q31_t)0x25792fd8, (q31_t)0x25732dc8, (q31_t)0x256d2ba0, (q31_t)0x25672961, + (q31_t)0x2561270b, (q31_t)0x255b249e, + (q31_t)0x2555221a, (q31_t)0x254f1f7e, (q31_t)0x25491ccc, (q31_t)0x25431a03, (q31_t)0x253d1723, (q31_t)0x2537142c, + (q31_t)0x2531111e, (q31_t)0x252b0df9, + (q31_t)0x25250abd, (q31_t)0x251f076a, (q31_t)0x25190400, (q31_t)0x25130080, (q31_t)0x250cfce8, (q31_t)0x2506f93a, + (q31_t)0x2500f574, (q31_t)0x24faf198, + (q31_t)0x24f4eda6, (q31_t)0x24eee99c, (q31_t)0x24e8e57c, (q31_t)0x24e2e144, (q31_t)0x24dcdcf6, (q31_t)0x24d6d892, + (q31_t)0x24d0d416, (q31_t)0x24cacf84, + (q31_t)0x24c4cadb, (q31_t)0x24bec61c, (q31_t)0x24b8c146, (q31_t)0x24b2bc59, (q31_t)0x24acb756, (q31_t)0x24a6b23b, + (q31_t)0x24a0ad0b, (q31_t)0x249aa7c4, + (q31_t)0x2494a266, (q31_t)0x248e9cf1, (q31_t)0x24889766, (q31_t)0x248291c5, (q31_t)0x247c8c0d, (q31_t)0x2476863e, + (q31_t)0x24708059, (q31_t)0x246a7a5e, + (q31_t)0x2464744c, (q31_t)0x245e6e23, (q31_t)0x245867e4, (q31_t)0x2452618f, (q31_t)0x244c5b24, (q31_t)0x244654a1, + (q31_t)0x24404e09, (q31_t)0x243a475a, + (q31_t)0x24344095, (q31_t)0x242e39ba, (q31_t)0x242832c8, (q31_t)0x24222bc0, (q31_t)0x241c24a1, (q31_t)0x24161d6d, + (q31_t)0x24101622, (q31_t)0x240a0ec1, + (q31_t)0x24040749, (q31_t)0x23fdffbc, (q31_t)0x23f7f818, (q31_t)0x23f1f05e, (q31_t)0x23ebe88e, (q31_t)0x23e5e0a7, + (q31_t)0x23dfd8ab, (q31_t)0x23d9d098, + (q31_t)0x23d3c86f, (q31_t)0x23cdc031, (q31_t)0x23c7b7dc, (q31_t)0x23c1af71, (q31_t)0x23bba6f0, (q31_t)0x23b59e59, + (q31_t)0x23af95ac, (q31_t)0x23a98ce8, + (q31_t)0x23a3840f, (q31_t)0x239d7b20, (q31_t)0x2397721b, (q31_t)0x23916900, (q31_t)0x238b5fcf, (q31_t)0x23855688, + (q31_t)0x237f4d2b, (q31_t)0x237943b9, + (q31_t)0x23733a30, (q31_t)0x236d3092, (q31_t)0x236726dd, (q31_t)0x23611d13, (q31_t)0x235b1333, (q31_t)0x2355093e, + (q31_t)0x234eff32, (q31_t)0x2348f511, + (q31_t)0x2342eada, (q31_t)0x233ce08d, (q31_t)0x2336d62a, (q31_t)0x2330cbb2, (q31_t)0x232ac124, (q31_t)0x2324b680, + (q31_t)0x231eabc7, (q31_t)0x2318a0f8, + (q31_t)0x23129613, (q31_t)0x230c8b19, (q31_t)0x23068009, (q31_t)0x230074e3, (q31_t)0x22fa69a8, (q31_t)0x22f45e57, + (q31_t)0x22ee52f1, (q31_t)0x22e84775, + (q31_t)0x22e23be4, (q31_t)0x22dc303d, (q31_t)0x22d62480, (q31_t)0x22d018ae, (q31_t)0x22ca0cc7, (q31_t)0x22c400ca, + (q31_t)0x22bdf4b8, (q31_t)0x22b7e890, + (q31_t)0x22b1dc53, (q31_t)0x22abd001, (q31_t)0x22a5c399, (q31_t)0x229fb71b, (q31_t)0x2299aa89, (q31_t)0x22939de1, + (q31_t)0x228d9123, (q31_t)0x22878451, + (q31_t)0x22817769, (q31_t)0x227b6a6c, (q31_t)0x22755d59, (q31_t)0x226f5032, (q31_t)0x226942f5, (q31_t)0x226335a2, + (q31_t)0x225d283b, (q31_t)0x22571abe, + (q31_t)0x22510d2d, (q31_t)0x224aff86, (q31_t)0x2244f1c9, (q31_t)0x223ee3f8, (q31_t)0x2238d612, (q31_t)0x2232c816, + (q31_t)0x222cba06, (q31_t)0x2226abe0, + (q31_t)0x22209da5, (q31_t)0x221a8f56, (q31_t)0x221480f1, (q31_t)0x220e7277, (q31_t)0x220863e8, (q31_t)0x22025544, + (q31_t)0x21fc468b, (q31_t)0x21f637be, + (q31_t)0x21f028db, (q31_t)0x21ea19e3, (q31_t)0x21e40ad7, (q31_t)0x21ddfbb5, (q31_t)0x21d7ec7f, (q31_t)0x21d1dd34, + (q31_t)0x21cbcdd3, (q31_t)0x21c5be5e, + (q31_t)0x21bfaed5, (q31_t)0x21b99f36, (q31_t)0x21b38f83, (q31_t)0x21ad7fba, (q31_t)0x21a76fdd, (q31_t)0x21a15fec, + (q31_t)0x219b4fe5, (q31_t)0x21953fca, + (q31_t)0x218f2f9a, (q31_t)0x21891f55, (q31_t)0x21830efc, (q31_t)0x217cfe8e, (q31_t)0x2176ee0b, (q31_t)0x2170dd74, + (q31_t)0x216accc8, (q31_t)0x2164bc08, + (q31_t)0x215eab33, (q31_t)0x21589a49, (q31_t)0x2152894b, (q31_t)0x214c7838, (q31_t)0x21466710, (q31_t)0x214055d4, + (q31_t)0x213a4484, (q31_t)0x2134331f, + (q31_t)0x212e21a6, (q31_t)0x21281018, (q31_t)0x2121fe76, (q31_t)0x211becbf, (q31_t)0x2115daf4, (q31_t)0x210fc914, + (q31_t)0x2109b720, (q31_t)0x2103a518, + (q31_t)0x20fd92fb, (q31_t)0x20f780ca, (q31_t)0x20f16e84, (q31_t)0x20eb5c2b, (q31_t)0x20e549bd, (q31_t)0x20df373a, + (q31_t)0x20d924a4, (q31_t)0x20d311f9, + (q31_t)0x20ccff3a, (q31_t)0x20c6ec66, (q31_t)0x20c0d97f, (q31_t)0x20bac683, (q31_t)0x20b4b373, (q31_t)0x20aea04f, + (q31_t)0x20a88d17, (q31_t)0x20a279ca, + (q31_t)0x209c666a, (q31_t)0x209652f5, (q31_t)0x20903f6c, (q31_t)0x208a2bcf, (q31_t)0x2084181e, (q31_t)0x207e0459, + (q31_t)0x2077f080, (q31_t)0x2071dc93, + (q31_t)0x206bc892, (q31_t)0x2065b47d, (q31_t)0x205fa054, (q31_t)0x20598c17, (q31_t)0x205377c6, (q31_t)0x204d6361, + (q31_t)0x20474ee8, (q31_t)0x20413a5b, + (q31_t)0x203b25bb, (q31_t)0x20351106, (q31_t)0x202efc3e, (q31_t)0x2028e761, (q31_t)0x2022d271, (q31_t)0x201cbd6d, + (q31_t)0x2016a856, (q31_t)0x2010932a, + (q31_t)0x200a7deb, (q31_t)0x20046898, (q31_t)0x1ffe5331, (q31_t)0x1ff83db6, (q31_t)0x1ff22828, (q31_t)0x1fec1286, + (q31_t)0x1fe5fcd0, (q31_t)0x1fdfe707, + (q31_t)0x1fd9d12a, (q31_t)0x1fd3bb39, (q31_t)0x1fcda535, (q31_t)0x1fc78f1d, (q31_t)0x1fc178f1, (q31_t)0x1fbb62b2, + (q31_t)0x1fb54c60, (q31_t)0x1faf35f9, + (q31_t)0x1fa91f80, (q31_t)0x1fa308f2, (q31_t)0x1f9cf252, (q31_t)0x1f96db9d, (q31_t)0x1f90c4d5, (q31_t)0x1f8aadfa, + (q31_t)0x1f84970b, (q31_t)0x1f7e8009, + (q31_t)0x1f7868f4, (q31_t)0x1f7251ca, (q31_t)0x1f6c3a8e, (q31_t)0x1f66233e, (q31_t)0x1f600bdb, (q31_t)0x1f59f465, + (q31_t)0x1f53dcdb, (q31_t)0x1f4dc53d, + (q31_t)0x1f47ad8d, (q31_t)0x1f4195c9, (q31_t)0x1f3b7df2, (q31_t)0x1f356608, (q31_t)0x1f2f4e0a, (q31_t)0x1f2935f9, + (q31_t)0x1f231dd5, (q31_t)0x1f1d059e, + (q31_t)0x1f16ed54, (q31_t)0x1f10d4f6, (q31_t)0x1f0abc85, (q31_t)0x1f04a401, (q31_t)0x1efe8b6a, (q31_t)0x1ef872c0, + (q31_t)0x1ef25a03, (q31_t)0x1eec4132, + (q31_t)0x1ee6284f, (q31_t)0x1ee00f58, (q31_t)0x1ed9f64f, (q31_t)0x1ed3dd32, (q31_t)0x1ecdc402, (q31_t)0x1ec7aac0, + (q31_t)0x1ec1916a, (q31_t)0x1ebb7802, + (q31_t)0x1eb55e86, (q31_t)0x1eaf44f8, (q31_t)0x1ea92b56, (q31_t)0x1ea311a2, (q31_t)0x1e9cf7db, (q31_t)0x1e96de01, + (q31_t)0x1e90c414, (q31_t)0x1e8aaa14, + (q31_t)0x1e849001, (q31_t)0x1e7e75dc, (q31_t)0x1e785ba3, (q31_t)0x1e724158, (q31_t)0x1e6c26fa, (q31_t)0x1e660c8a, + (q31_t)0x1e5ff206, (q31_t)0x1e59d770, + (q31_t)0x1e53bcc7, (q31_t)0x1e4da20c, (q31_t)0x1e47873d, (q31_t)0x1e416c5d, (q31_t)0x1e3b5169, (q31_t)0x1e353663, + (q31_t)0x1e2f1b4a, (q31_t)0x1e29001e, + (q31_t)0x1e22e4e0, (q31_t)0x1e1cc990, (q31_t)0x1e16ae2c, (q31_t)0x1e1092b6, (q31_t)0x1e0a772e, (q31_t)0x1e045b93, + (q31_t)0x1dfe3fe6, (q31_t)0x1df82426, + (q31_t)0x1df20853, (q31_t)0x1debec6f, (q31_t)0x1de5d077, (q31_t)0x1ddfb46e, (q31_t)0x1dd99851, (q31_t)0x1dd37c23, + (q31_t)0x1dcd5fe2, (q31_t)0x1dc7438e, + (q31_t)0x1dc12729, (q31_t)0x1dbb0ab0, (q31_t)0x1db4ee26, (q31_t)0x1daed189, (q31_t)0x1da8b4da, (q31_t)0x1da29819, + (q31_t)0x1d9c7b45, (q31_t)0x1d965e5f, + (q31_t)0x1d904167, (q31_t)0x1d8a245c, (q31_t)0x1d840740, (q31_t)0x1d7dea11, (q31_t)0x1d77ccd0, (q31_t)0x1d71af7d, + (q31_t)0x1d6b9217, (q31_t)0x1d6574a0, + (q31_t)0x1d5f5716, (q31_t)0x1d59397a, (q31_t)0x1d531bcc, (q31_t)0x1d4cfe0d, (q31_t)0x1d46e03a, (q31_t)0x1d40c256, + (q31_t)0x1d3aa460, (q31_t)0x1d348658, + (q31_t)0x1d2e683e, (q31_t)0x1d284a12, (q31_t)0x1d222bd3, (q31_t)0x1d1c0d83, (q31_t)0x1d15ef21, (q31_t)0x1d0fd0ad, + (q31_t)0x1d09b227, (q31_t)0x1d03938f, + (q31_t)0x1cfd74e5, (q31_t)0x1cf7562a, (q31_t)0x1cf1375c, (q31_t)0x1ceb187d, (q31_t)0x1ce4f98c, (q31_t)0x1cdeda89, + (q31_t)0x1cd8bb74, (q31_t)0x1cd29c4d, + (q31_t)0x1ccc7d15, (q31_t)0x1cc65dca, (q31_t)0x1cc03e6e, (q31_t)0x1cba1f01, (q31_t)0x1cb3ff81, (q31_t)0x1caddff0, + (q31_t)0x1ca7c04d, (q31_t)0x1ca1a099, + (q31_t)0x1c9b80d3, (q31_t)0x1c9560fb, (q31_t)0x1c8f4112, (q31_t)0x1c892117, (q31_t)0x1c83010a, (q31_t)0x1c7ce0ec, + (q31_t)0x1c76c0bc, (q31_t)0x1c70a07b, + (q31_t)0x1c6a8028, (q31_t)0x1c645fc3, (q31_t)0x1c5e3f4d, (q31_t)0x1c581ec6, (q31_t)0x1c51fe2d, (q31_t)0x1c4bdd83, + (q31_t)0x1c45bcc7, (q31_t)0x1c3f9bf9, + (q31_t)0x1c397b1b, (q31_t)0x1c335a2b, (q31_t)0x1c2d3929, (q31_t)0x1c271816, (q31_t)0x1c20f6f2, (q31_t)0x1c1ad5bc, + (q31_t)0x1c14b475, (q31_t)0x1c0e931d, + (q31_t)0x1c0871b4, (q31_t)0x1c025039, (q31_t)0x1bfc2ead, (q31_t)0x1bf60d0f, (q31_t)0x1befeb60, (q31_t)0x1be9c9a1, + (q31_t)0x1be3a7cf, (q31_t)0x1bdd85ed, + (q31_t)0x1bd763fa, (q31_t)0x1bd141f5, (q31_t)0x1bcb1fdf, (q31_t)0x1bc4fdb8, (q31_t)0x1bbedb80, (q31_t)0x1bb8b937, + (q31_t)0x1bb296dc, (q31_t)0x1bac7471, + (q31_t)0x1ba651f5, (q31_t)0x1ba02f67, (q31_t)0x1b9a0cc8, (q31_t)0x1b93ea19, (q31_t)0x1b8dc758, (q31_t)0x1b87a487, + (q31_t)0x1b8181a4, (q31_t)0x1b7b5eb0, + (q31_t)0x1b753bac, (q31_t)0x1b6f1897, (q31_t)0x1b68f570, (q31_t)0x1b62d239, (q31_t)0x1b5caef1, (q31_t)0x1b568b98, + (q31_t)0x1b50682e, (q31_t)0x1b4a44b3, + (q31_t)0x1b442127, (q31_t)0x1b3dfd8b, (q31_t)0x1b37d9de, (q31_t)0x1b31b620, (q31_t)0x1b2b9251, (q31_t)0x1b256e71, + (q31_t)0x1b1f4a81, (q31_t)0x1b192680, + (q31_t)0x1b13026e, (q31_t)0x1b0cde4c, (q31_t)0x1b06ba19, (q31_t)0x1b0095d5, (q31_t)0x1afa7180, (q31_t)0x1af44d1b, + (q31_t)0x1aee28a6, (q31_t)0x1ae8041f, + (q31_t)0x1ae1df88, (q31_t)0x1adbbae1, (q31_t)0x1ad59629, (q31_t)0x1acf7160, (q31_t)0x1ac94c87, (q31_t)0x1ac3279d, + (q31_t)0x1abd02a3, (q31_t)0x1ab6dd98, + (q31_t)0x1ab0b87d, (q31_t)0x1aaa9352, (q31_t)0x1aa46e16, (q31_t)0x1a9e48c9, (q31_t)0x1a98236c, (q31_t)0x1a91fdff, + (q31_t)0x1a8bd881, (q31_t)0x1a85b2f3, + (q31_t)0x1a7f8d54, (q31_t)0x1a7967a6, (q31_t)0x1a7341e6, (q31_t)0x1a6d1c17, (q31_t)0x1a66f637, (q31_t)0x1a60d047, + (q31_t)0x1a5aaa47, (q31_t)0x1a548436, + (q31_t)0x1a4e5e15, (q31_t)0x1a4837e4, (q31_t)0x1a4211a3, (q31_t)0x1a3beb52, (q31_t)0x1a35c4f0, (q31_t)0x1a2f9e7e, + (q31_t)0x1a2977fc, (q31_t)0x1a23516a, + (q31_t)0x1a1d2ac8, (q31_t)0x1a170416, (q31_t)0x1a10dd53, (q31_t)0x1a0ab681, (q31_t)0x1a048f9e, (q31_t)0x19fe68ac, + (q31_t)0x19f841a9, (q31_t)0x19f21a96, + (q31_t)0x19ebf374, (q31_t)0x19e5cc41, (q31_t)0x19dfa4fe, (q31_t)0x19d97dac, (q31_t)0x19d35649, (q31_t)0x19cd2ed7, + (q31_t)0x19c70754, (q31_t)0x19c0dfc2, + (q31_t)0x19bab820, (q31_t)0x19b4906e, (q31_t)0x19ae68ac, (q31_t)0x19a840da, (q31_t)0x19a218f9, (q31_t)0x199bf107, + (q31_t)0x1995c906, (q31_t)0x198fa0f5, + (q31_t)0x198978d4, (q31_t)0x198350a4, (q31_t)0x197d2864, (q31_t)0x19770014, (q31_t)0x1970d7b4, (q31_t)0x196aaf45, + (q31_t)0x196486c6, (q31_t)0x195e5e37, + (q31_t)0x19583599, (q31_t)0x19520ceb, (q31_t)0x194be42d, (q31_t)0x1945bb60, (q31_t)0x193f9283, (q31_t)0x19396997, + (q31_t)0x1933409b, (q31_t)0x192d178f, + (q31_t)0x1926ee74, (q31_t)0x1920c54a, (q31_t)0x191a9c10, (q31_t)0x191472c6, (q31_t)0x190e496d, (q31_t)0x19082005, + (q31_t)0x1901f68d, (q31_t)0x18fbcd06, + (q31_t)0x18f5a36f, (q31_t)0x18ef79c9, (q31_t)0x18e95014, (q31_t)0x18e3264f, (q31_t)0x18dcfc7b, (q31_t)0x18d6d297, + (q31_t)0x18d0a8a4, (q31_t)0x18ca7ea2, + (q31_t)0x18c45491, (q31_t)0x18be2a70, (q31_t)0x18b80040, (q31_t)0x18b1d601, (q31_t)0x18ababb2, (q31_t)0x18a58154, + (q31_t)0x189f56e8, (q31_t)0x18992c6b, + (q31_t)0x189301e0, (q31_t)0x188cd746, (q31_t)0x1886ac9c, (q31_t)0x188081e4, (q31_t)0x187a571c, (q31_t)0x18742c45, + (q31_t)0x186e015f, (q31_t)0x1867d66a, + (q31_t)0x1861ab66, (q31_t)0x185b8053, (q31_t)0x18555530, (q31_t)0x184f29ff, (q31_t)0x1848febf, (q31_t)0x1842d370, + (q31_t)0x183ca812, (q31_t)0x18367ca5, + (q31_t)0x18305129, (q31_t)0x182a259e, (q31_t)0x1823fa04, (q31_t)0x181dce5b, (q31_t)0x1817a2a4, (q31_t)0x181176dd, + (q31_t)0x180b4b08, (q31_t)0x18051f24, + (q31_t)0x17fef331, (q31_t)0x17f8c72f, (q31_t)0x17f29b1e, (q31_t)0x17ec6eff, (q31_t)0x17e642d1, (q31_t)0x17e01694, + (q31_t)0x17d9ea49, (q31_t)0x17d3bdee, + (q31_t)0x17cd9186, (q31_t)0x17c7650e, (q31_t)0x17c13888, (q31_t)0x17bb0bf3, (q31_t)0x17b4df4f, (q31_t)0x17aeb29d, + (q31_t)0x17a885dc, (q31_t)0x17a2590d, + (q31_t)0x179c2c2f, (q31_t)0x1795ff42, (q31_t)0x178fd247, (q31_t)0x1789a53d, (q31_t)0x17837825, (q31_t)0x177d4afe, + (q31_t)0x17771dc9, (q31_t)0x1770f086, + (q31_t)0x176ac333, (q31_t)0x176495d3, (q31_t)0x175e6864, (q31_t)0x17583ae7, (q31_t)0x17520d5b, (q31_t)0x174bdfc1, + (q31_t)0x1745b218, (q31_t)0x173f8461, + (q31_t)0x1739569c, (q31_t)0x173328c8, (q31_t)0x172cfae6, (q31_t)0x1726ccf6, (q31_t)0x17209ef8, (q31_t)0x171a70eb, + (q31_t)0x171442d0, (q31_t)0x170e14a7, + (q31_t)0x1707e670, (q31_t)0x1701b82a, (q31_t)0x16fb89d6, (q31_t)0x16f55b74, (q31_t)0x16ef2d04, (q31_t)0x16e8fe86, + (q31_t)0x16e2cff9, (q31_t)0x16dca15f, + (q31_t)0x16d672b6, (q31_t)0x16d043ff, (q31_t)0x16ca153a, (q31_t)0x16c3e667, (q31_t)0x16bdb787, (q31_t)0x16b78898, + (q31_t)0x16b1599b, (q31_t)0x16ab2a90, + (q31_t)0x16a4fb77, (q31_t)0x169ecc50, (q31_t)0x16989d1b, (q31_t)0x16926dd8, (q31_t)0x168c3e87, (q31_t)0x16860f29, + (q31_t)0x167fdfbc, (q31_t)0x1679b042, + (q31_t)0x167380ba, (q31_t)0x166d5123, (q31_t)0x1667217f, (q31_t)0x1660f1ce, (q31_t)0x165ac20e, (q31_t)0x16549241, + (q31_t)0x164e6266, (q31_t)0x1648327d, + (q31_t)0x16420286, (q31_t)0x163bd282, (q31_t)0x1635a270, (q31_t)0x162f7250, (q31_t)0x16294222, (q31_t)0x162311e7, + (q31_t)0x161ce19e, (q31_t)0x1616b148, + (q31_t)0x161080e4, (q31_t)0x160a5072, (q31_t)0x16041ff3, (q31_t)0x15fdef66, (q31_t)0x15f7becc, (q31_t)0x15f18e24, + (q31_t)0x15eb5d6e, (q31_t)0x15e52cab, + (q31_t)0x15defbdb, (q31_t)0x15d8cafd, (q31_t)0x15d29a11, (q31_t)0x15cc6918, (q31_t)0x15c63812, (q31_t)0x15c006fe, + (q31_t)0x15b9d5dd, (q31_t)0x15b3a4ae, + (q31_t)0x15ad7372, (q31_t)0x15a74228, (q31_t)0x15a110d2, (q31_t)0x159adf6e, (q31_t)0x1594adfc, (q31_t)0x158e7c7d, + (q31_t)0x15884af1, (q31_t)0x15821958, + (q31_t)0x157be7b1, (q31_t)0x1575b5fe, (q31_t)0x156f843c, (q31_t)0x1569526e, (q31_t)0x15632093, (q31_t)0x155ceeaa, + (q31_t)0x1556bcb4, (q31_t)0x15508ab1, + (q31_t)0x154a58a1, (q31_t)0x15442683, (q31_t)0x153df459, (q31_t)0x1537c221, (q31_t)0x15318fdd, (q31_t)0x152b5d8b, + (q31_t)0x15252b2c, (q31_t)0x151ef8c0, + (q31_t)0x1518c648, (q31_t)0x151293c2, (q31_t)0x150c612f, (q31_t)0x15062e8f, (q31_t)0x14fffbe2, (q31_t)0x14f9c928, + (q31_t)0x14f39662, (q31_t)0x14ed638e, + (q31_t)0x14e730ae, (q31_t)0x14e0fdc0, (q31_t)0x14dacac6, (q31_t)0x14d497bf, (q31_t)0x14ce64ab, (q31_t)0x14c8318a, + (q31_t)0x14c1fe5c, (q31_t)0x14bbcb22, + (q31_t)0x14b597da, (q31_t)0x14af6486, (q31_t)0x14a93125, (q31_t)0x14a2fdb8, (q31_t)0x149cca3e, (q31_t)0x149696b7, + (q31_t)0x14906323, (q31_t)0x148a2f82, + (q31_t)0x1483fbd5, (q31_t)0x147dc81c, (q31_t)0x14779455, (q31_t)0x14716082, (q31_t)0x146b2ca3, (q31_t)0x1464f8b7, + (q31_t)0x145ec4be, (q31_t)0x145890b9, + (q31_t)0x14525ca7, (q31_t)0x144c2888, (q31_t)0x1445f45d, (q31_t)0x143fc026, (q31_t)0x14398be2, (q31_t)0x14335792, + (q31_t)0x142d2335, (q31_t)0x1426eecb, + (q31_t)0x1420ba56, (q31_t)0x141a85d3, (q31_t)0x14145145, (q31_t)0x140e1caa, (q31_t)0x1407e803, (q31_t)0x1401b34f, + (q31_t)0x13fb7e8f, (q31_t)0x13f549c3, + (q31_t)0x13ef14ea, (q31_t)0x13e8e005, (q31_t)0x13e2ab14, (q31_t)0x13dc7616, (q31_t)0x13d6410d, (q31_t)0x13d00bf7, + (q31_t)0x13c9d6d4, (q31_t)0x13c3a1a6, + (q31_t)0x13bd6c6b, (q31_t)0x13b73725, (q31_t)0x13b101d2, (q31_t)0x13aacc73, (q31_t)0x13a49707, (q31_t)0x139e6190, + (q31_t)0x13982c0d, (q31_t)0x1391f67d, + (q31_t)0x138bc0e1, (q31_t)0x13858b3a, (q31_t)0x137f5586, (q31_t)0x13791fc6, (q31_t)0x1372e9fb, (q31_t)0x136cb423, + (q31_t)0x13667e3f, (q31_t)0x13604850, + (q31_t)0x135a1254, (q31_t)0x1353dc4c, (q31_t)0x134da639, (q31_t)0x1347701a, (q31_t)0x134139ee, (q31_t)0x133b03b7, + (q31_t)0x1334cd74, (q31_t)0x132e9725, + (q31_t)0x132860ca, (q31_t)0x13222a64, (q31_t)0x131bf3f2, (q31_t)0x1315bd73, (q31_t)0x130f86ea, (q31_t)0x13095054, + (q31_t)0x130319b3, (q31_t)0x12fce305, + (q31_t)0x12f6ac4d, (q31_t)0x12f07588, (q31_t)0x12ea3eb8, (q31_t)0x12e407dc, (q31_t)0x12ddd0f4, (q31_t)0x12d79a01, + (q31_t)0x12d16303, (q31_t)0x12cb2bf8, + (q31_t)0x12c4f4e2, (q31_t)0x12bebdc1, (q31_t)0x12b88693, (q31_t)0x12b24f5b, (q31_t)0x12ac1817, (q31_t)0x12a5e0c7, + (q31_t)0x129fa96c, (q31_t)0x12997205, + (q31_t)0x12933a93, (q31_t)0x128d0315, (q31_t)0x1286cb8c, (q31_t)0x128093f7, (q31_t)0x127a5c57, (q31_t)0x127424ac, + (q31_t)0x126decf5, (q31_t)0x1267b533, + (q31_t)0x12617d66, (q31_t)0x125b458d, (q31_t)0x12550da9, (q31_t)0x124ed5ba, (q31_t)0x12489dbf, (q31_t)0x124265b9, + (q31_t)0x123c2da8, (q31_t)0x1235f58b, + (q31_t)0x122fbd63, (q31_t)0x12298530, (q31_t)0x12234cf2, (q31_t)0x121d14a9, (q31_t)0x1216dc54, (q31_t)0x1210a3f5, + (q31_t)0x120a6b8a, (q31_t)0x12043314, + (q31_t)0x11fdfa93, (q31_t)0x11f7c207, (q31_t)0x11f18970, (q31_t)0x11eb50cd, (q31_t)0x11e51820, (q31_t)0x11dedf68, + (q31_t)0x11d8a6a4, (q31_t)0x11d26dd6, + (q31_t)0x11cc34fc, (q31_t)0x11c5fc18, (q31_t)0x11bfc329, (q31_t)0x11b98a2e, (q31_t)0x11b35129, (q31_t)0x11ad1819, + (q31_t)0x11a6defe, (q31_t)0x11a0a5d8, + (q31_t)0x119a6ca7, (q31_t)0x1194336b, (q31_t)0x118dfa25, (q31_t)0x1187c0d3, (q31_t)0x11818777, (q31_t)0x117b4e10, + (q31_t)0x1175149e, (q31_t)0x116edb22, + (q31_t)0x1168a19b, (q31_t)0x11626809, (q31_t)0x115c2e6c, (q31_t)0x1155f4c4, (q31_t)0x114fbb12, (q31_t)0x11498156, + (q31_t)0x1143478e, (q31_t)0x113d0dbc, + (q31_t)0x1136d3df, (q31_t)0x113099f8, (q31_t)0x112a6006, (q31_t)0x11242609, (q31_t)0x111dec02, (q31_t)0x1117b1f0, + (q31_t)0x111177d4, (q31_t)0x110b3dad, + (q31_t)0x1105037c, (q31_t)0x10fec940, (q31_t)0x10f88efa, (q31_t)0x10f254a9, (q31_t)0x10ec1a4e, (q31_t)0x10e5dfe8, + (q31_t)0x10dfa578, (q31_t)0x10d96afe, + (q31_t)0x10d33079, (q31_t)0x10ccf5ea, (q31_t)0x10c6bb50, (q31_t)0x10c080ac, (q31_t)0x10ba45fe, (q31_t)0x10b40b45, + (q31_t)0x10add082, (q31_t)0x10a795b5, + (q31_t)0x10a15ade, (q31_t)0x109b1ffc, (q31_t)0x1094e510, (q31_t)0x108eaa1a, (q31_t)0x10886f19, (q31_t)0x1082340f, + (q31_t)0x107bf8fa, (q31_t)0x1075bddb, + (q31_t)0x106f82b2, (q31_t)0x1069477f, (q31_t)0x10630c41, (q31_t)0x105cd0fa, (q31_t)0x105695a8, (q31_t)0x10505a4d, + (q31_t)0x104a1ee7, (q31_t)0x1043e377, + (q31_t)0x103da7fd, (q31_t)0x10376c79, (q31_t)0x103130ec, (q31_t)0x102af554, (q31_t)0x1024b9b2, (q31_t)0x101e7e06, + (q31_t)0x10184251, (q31_t)0x10120691, + (q31_t)0x100bcac7, (q31_t)0x10058ef4, (q31_t)0xfff5317, (q31_t)0xff91730, (q31_t)0xff2db3e, (q31_t)0xfec9f44, + (q31_t)0xfe6633f, (q31_t)0xfe02730, + (q31_t)0xfd9eb18, (q31_t)0xfd3aef6, (q31_t)0xfcd72ca, (q31_t)0xfc73695, (q31_t)0xfc0fa55, (q31_t)0xfbabe0c, (q31_t)0xfb481ba, + (q31_t)0xfae455d, + (q31_t)0xfa808f7, (q31_t)0xfa1cc87, (q31_t)0xf9b900e, (q31_t)0xf95538b, (q31_t)0xf8f16fe, (q31_t)0xf88da68, (q31_t)0xf829dc8, + (q31_t)0xf7c611f, + (q31_t)0xf76246c, (q31_t)0xf6fe7af, (q31_t)0xf69aae9, (q31_t)0xf636e1a, (q31_t)0xf5d3141, (q31_t)0xf56f45e, (q31_t)0xf50b773, + (q31_t)0xf4a7a7d, + (q31_t)0xf443d7e, (q31_t)0xf3e0076, (q31_t)0xf37c365, (q31_t)0xf318649, (q31_t)0xf2b4925, (q31_t)0xf250bf7, (q31_t)0xf1ecec0, + (q31_t)0xf189180, + (q31_t)0xf125436, (q31_t)0xf0c16e3, (q31_t)0xf05d987, (q31_t)0xeff9c21, (q31_t)0xef95eb2, (q31_t)0xef3213a, (q31_t)0xeece3b9, + (q31_t)0xee6a62f, + (q31_t)0xee0689b, (q31_t)0xeda2afe, (q31_t)0xed3ed58, (q31_t)0xecdafa9, (q31_t)0xec771f1, (q31_t)0xec1342f, (q31_t)0xebaf665, + (q31_t)0xeb4b891, + (q31_t)0xeae7ab4, (q31_t)0xea83ccf, (q31_t)0xea1fee0, (q31_t)0xe9bc0e8, (q31_t)0xe9582e7, (q31_t)0xe8f44dd, (q31_t)0xe8906cb, + (q31_t)0xe82c8af, + (q31_t)0xe7c8a8a, (q31_t)0xe764c5c, (q31_t)0xe700e26, (q31_t)0xe69cfe6, (q31_t)0xe63919e, (q31_t)0xe5d534d, (q31_t)0xe5714f3, + (q31_t)0xe50d690, + (q31_t)0xe4a9824, (q31_t)0xe4459af, (q31_t)0xe3e1b32, (q31_t)0xe37dcac, (q31_t)0xe319e1d, (q31_t)0xe2b5f85, (q31_t)0xe2520e5, + (q31_t)0xe1ee23c, + (q31_t)0xe18a38a, (q31_t)0xe1264cf, (q31_t)0xe0c260c, (q31_t)0xe05e740, (q31_t)0xdffa86b, (q31_t)0xdf9698e, (q31_t)0xdf32aa8, + (q31_t)0xdecebba, + (q31_t)0xde6acc3, (q31_t)0xde06dc3, (q31_t)0xdda2ebb, (q31_t)0xdd3efab, (q31_t)0xdcdb091, (q31_t)0xdc77170, (q31_t)0xdc13245, + (q31_t)0xdbaf313, + (q31_t)0xdb4b3d7, (q31_t)0xdae7494, (q31_t)0xda83548, (q31_t)0xda1f5f3, (q31_t)0xd9bb696, (q31_t)0xd957731, (q31_t)0xd8f37c3, + (q31_t)0xd88f84d, + (q31_t)0xd82b8cf, (q31_t)0xd7c7948, (q31_t)0xd7639b9, (q31_t)0xd6ffa22, (q31_t)0xd69ba82, (q31_t)0xd637ada, (q31_t)0xd5d3b2a, + (q31_t)0xd56fb71, + (q31_t)0xd50bbb1, (q31_t)0xd4a7be8, (q31_t)0xd443c17, (q31_t)0xd3dfc3e, (q31_t)0xd37bc5c, (q31_t)0xd317c73, (q31_t)0xd2b3c81, + (q31_t)0xd24fc87, + (q31_t)0xd1ebc85, (q31_t)0xd187c7b, (q31_t)0xd123c69, (q31_t)0xd0bfc4f, (q31_t)0xd05bc2d, (q31_t)0xcff7c02, (q31_t)0xcf93bd0, + (q31_t)0xcf2fb96, + (q31_t)0xcecbb53, (q31_t)0xce67b09, (q31_t)0xce03ab7, (q31_t)0xcd9fa5d, (q31_t)0xcd3b9fb, (q31_t)0xccd7991, (q31_t)0xcc7391f, + (q31_t)0xcc0f8a5, + (q31_t)0xcbab824, (q31_t)0xcb4779a, (q31_t)0xcae3709, (q31_t)0xca7f670, (q31_t)0xca1b5cf, (q31_t)0xc9b7526, (q31_t)0xc953475, + (q31_t)0xc8ef3bd, + (q31_t)0xc88b2fd, (q31_t)0xc827235, (q31_t)0xc7c3166, (q31_t)0xc75f08f, (q31_t)0xc6fafb0, (q31_t)0xc696ec9, (q31_t)0xc632ddb, + (q31_t)0xc5cece5, + (q31_t)0xc56abe8, (q31_t)0xc506ae3, (q31_t)0xc4a29d6, (q31_t)0xc43e8c2, (q31_t)0xc3da7a6, (q31_t)0xc376683, (q31_t)0xc312558, + (q31_t)0xc2ae425, + (q31_t)0xc24a2eb, (q31_t)0xc1e61aa, (q31_t)0xc182061, (q31_t)0xc11df11, (q31_t)0xc0b9db9, (q31_t)0xc055c5a, (q31_t)0xbff1af3, + (q31_t)0xbf8d985, + (q31_t)0xbf29810, (q31_t)0xbec5693, (q31_t)0xbe6150f, (q31_t)0xbdfd383, (q31_t)0xbd991f0, (q31_t)0xbd35056, (q31_t)0xbcd0eb5, + (q31_t)0xbc6cd0c, + (q31_t)0xbc08b5c, (q31_t)0xbba49a5, (q31_t)0xbb407e7, (q31_t)0xbadc621, (q31_t)0xba78454, (q31_t)0xba14280, (q31_t)0xb9b00a5, + (q31_t)0xb94bec2, + (q31_t)0xb8e7cd9, (q31_t)0xb883ae8, (q31_t)0xb81f8f0, (q31_t)0xb7bb6f2, (q31_t)0xb7574ec, (q31_t)0xb6f32df, (q31_t)0xb68f0cb, + (q31_t)0xb62aeaf, + (q31_t)0xb5c6c8d, (q31_t)0xb562a64, (q31_t)0xb4fe834, (q31_t)0xb49a5fd, (q31_t)0xb4363bf, (q31_t)0xb3d217a, (q31_t)0xb36df2e, + (q31_t)0xb309cdb, + (q31_t)0xb2a5a81, (q31_t)0xb241820, (q31_t)0xb1dd5b9, (q31_t)0xb17934b, (q31_t)0xb1150d5, (q31_t)0xb0b0e59, (q31_t)0xb04cbd6, + (q31_t)0xafe894d, + (q31_t)0xaf846bc, (q31_t)0xaf20425, (q31_t)0xaebc187, (q31_t)0xae57ee2, (q31_t)0xadf3c37, (q31_t)0xad8f985, (q31_t)0xad2b6cc, + (q31_t)0xacc740c, + (q31_t)0xac63146, (q31_t)0xabfee79, (q31_t)0xab9aba6, (q31_t)0xab368cc, (q31_t)0xaad25eb, (q31_t)0xaa6e304, (q31_t)0xaa0a016, + (q31_t)0xa9a5d22, + (q31_t)0xa941a27, (q31_t)0xa8dd725, (q31_t)0xa87941d, (q31_t)0xa81510f, (q31_t)0xa7b0dfa, (q31_t)0xa74cadf, (q31_t)0xa6e87bd, + (q31_t)0xa684495, + (q31_t)0xa620166, (q31_t)0xa5bbe31, (q31_t)0xa557af5, (q31_t)0xa4f37b3, (q31_t)0xa48f46b, (q31_t)0xa42b11d, (q31_t)0xa3c6dc8, + (q31_t)0xa362a6d, + (q31_t)0xa2fe70b, (q31_t)0xa29a3a3, (q31_t)0xa236035, (q31_t)0xa1d1cc1, (q31_t)0xa16d946, (q31_t)0xa1095c6, (q31_t)0xa0a523f, + (q31_t)0xa040eb1, + (q31_t)0x9fdcb1e, (q31_t)0x9f78784, (q31_t)0x9f143e5, (q31_t)0x9eb003f, (q31_t)0x9e4bc93, (q31_t)0x9de78e1, (q31_t)0x9d83529, + (q31_t)0x9d1f16b, + (q31_t)0x9cbada7, (q31_t)0x9c569dc, (q31_t)0x9bf260c, (q31_t)0x9b8e236, (q31_t)0x9b29e59, (q31_t)0x9ac5a77, (q31_t)0x9a6168f, + (q31_t)0x99fd2a0, + (q31_t)0x9998eac, (q31_t)0x9934ab2, (q31_t)0x98d06b2, (q31_t)0x986c2ac, (q31_t)0x9807ea1, (q31_t)0x97a3a8f, (q31_t)0x973f678, + (q31_t)0x96db25a, + (q31_t)0x9676e37, (q31_t)0x9612a0e, (q31_t)0x95ae5e0, (q31_t)0x954a1ab, (q31_t)0x94e5d71, (q31_t)0x9481931, (q31_t)0x941d4eb, + (q31_t)0x93b90a0, + (q31_t)0x9354c4f, (q31_t)0x92f07f8, (q31_t)0x928c39b, (q31_t)0x9227f39, (q31_t)0x91c3ad2, (q31_t)0x915f664, (q31_t)0x90fb1f1, + (q31_t)0x9096d79, + (q31_t)0x90328fb, (q31_t)0x8fce477, (q31_t)0x8f69fee, (q31_t)0x8f05b5f, (q31_t)0x8ea16cb, (q31_t)0x8e3d231, (q31_t)0x8dd8d92, + (q31_t)0x8d748ed, + (q31_t)0x8d10443, (q31_t)0x8cabf93, (q31_t)0x8c47ade, (q31_t)0x8be3624, (q31_t)0x8b7f164, (q31_t)0x8b1ac9f, (q31_t)0x8ab67d4, + (q31_t)0x8a52304, + (q31_t)0x89ede2f, (q31_t)0x8989955, (q31_t)0x8925475, (q31_t)0x88c0f90, (q31_t)0x885caa5, (q31_t)0x87f85b5, (q31_t)0x87940c1, + (q31_t)0x872fbc6, + (q31_t)0x86cb6c7, (q31_t)0x86671c2, (q31_t)0x8602cb9, (q31_t)0x859e7aa, (q31_t)0x853a296, (q31_t)0x84d5d7d, (q31_t)0x847185e, + (q31_t)0x840d33b, + (q31_t)0x83a8e12, (q31_t)0x83448e5, (q31_t)0x82e03b2, (q31_t)0x827be7a, (q31_t)0x821793e, (q31_t)0x81b33fc, (q31_t)0x814eeb5, + (q31_t)0x80ea969, + (q31_t)0x8086419, (q31_t)0x8021ec3, (q31_t)0x7fbd968, (q31_t)0x7f59409, (q31_t)0x7ef4ea4, (q31_t)0x7e9093b, (q31_t)0x7e2c3cd, + (q31_t)0x7dc7e5a, + (q31_t)0x7d638e2, (q31_t)0x7cff365, (q31_t)0x7c9ade4, (q31_t)0x7c3685d, (q31_t)0x7bd22d2, (q31_t)0x7b6dd42, (q31_t)0x7b097ad, + (q31_t)0x7aa5214, + (q31_t)0x7a40c76, (q31_t)0x79dc6d3, (q31_t)0x797812b, (q31_t)0x7913b7f, (q31_t)0x78af5ce, (q31_t)0x784b019, (q31_t)0x77e6a5e, + (q31_t)0x77824a0, + (q31_t)0x771dedc, (q31_t)0x76b9914, (q31_t)0x7655347, (q31_t)0x75f0d76, (q31_t)0x758c7a1, (q31_t)0x75281c6, (q31_t)0x74c3be7, + (q31_t)0x745f604, + (q31_t)0x73fb01c, (q31_t)0x7396a30, (q31_t)0x733243f, (q31_t)0x72cde4a, (q31_t)0x7269851, (q31_t)0x7205253, (q31_t)0x71a0c50, + (q31_t)0x713c64a, + (q31_t)0x70d803f, (q31_t)0x7073a2f, (q31_t)0x700f41b, (q31_t)0x6faae03, (q31_t)0x6f467e7, (q31_t)0x6ee21c6, (q31_t)0x6e7dba1, + (q31_t)0x6e19578, + (q31_t)0x6db4f4a, (q31_t)0x6d50919, (q31_t)0x6cec2e3, (q31_t)0x6c87ca9, (q31_t)0x6c2366a, (q31_t)0x6bbf028, (q31_t)0x6b5a9e1, + (q31_t)0x6af6396, + (q31_t)0x6a91d47, (q31_t)0x6a2d6f4, (q31_t)0x69c909d, (q31_t)0x6964a42, (q31_t)0x69003e3, (q31_t)0x689bd80, (q31_t)0x6837718, + (q31_t)0x67d30ad, + (q31_t)0x676ea3d, (q31_t)0x670a3ca, (q31_t)0x66a5d53, (q31_t)0x66416d8, (q31_t)0x65dd058, (q31_t)0x65789d5, (q31_t)0x651434e, + (q31_t)0x64afcc3, + (q31_t)0x644b634, (q31_t)0x63e6fa2, (q31_t)0x638290b, (q31_t)0x631e271, (q31_t)0x62b9bd3, (q31_t)0x6255531, (q31_t)0x61f0e8b, + (q31_t)0x618c7e1, + (q31_t)0x6128134, (q31_t)0x60c3a83, (q31_t)0x605f3ce, (q31_t)0x5ffad15, (q31_t)0x5f96659, (q31_t)0x5f31f99, (q31_t)0x5ecd8d6, + (q31_t)0x5e6920e, + (q31_t)0x5e04b43, (q31_t)0x5da0475, (q31_t)0x5d3bda3, (q31_t)0x5cd76cd, (q31_t)0x5c72ff4, (q31_t)0x5c0e917, (q31_t)0x5baa237, + (q31_t)0x5b45b53, + (q31_t)0x5ae146b, (q31_t)0x5a7cd80, (q31_t)0x5a18692, (q31_t)0x59b3fa0, (q31_t)0x594f8aa, (q31_t)0x58eb1b2, (q31_t)0x5886ab5, + (q31_t)0x58223b6, + (q31_t)0x57bdcb3, (q31_t)0x57595ac, (q31_t)0x56f4ea2, (q31_t)0x5690795, (q31_t)0x562c085, (q31_t)0x55c7971, (q31_t)0x556325a, + (q31_t)0x54feb3f, + (q31_t)0x549a422, (q31_t)0x5435d01, (q31_t)0x53d15dd, (q31_t)0x536ceb5, (q31_t)0x530878a, (q31_t)0x52a405d, (q31_t)0x523f92c, + (q31_t)0x51db1f7, + (q31_t)0x5176ac0, (q31_t)0x5112385, (q31_t)0x50adc48, (q31_t)0x5049507, (q31_t)0x4fe4dc3, (q31_t)0x4f8067c, (q31_t)0x4f1bf32, + (q31_t)0x4eb77e5, + (q31_t)0x4e53095, (q31_t)0x4dee942, (q31_t)0x4d8a1ec, (q31_t)0x4d25a93, (q31_t)0x4cc1337, (q31_t)0x4c5cbd8, (q31_t)0x4bf8476, + (q31_t)0x4b93d11, + (q31_t)0x4b2f5a9, (q31_t)0x4acae3e, (q31_t)0x4a666d1, (q31_t)0x4a01f60, (q31_t)0x499d7ed, (q31_t)0x4939077, (q31_t)0x48d48fe, + (q31_t)0x4870182, + (q31_t)0x480ba04, (q31_t)0x47a7282, (q31_t)0x4742afe, (q31_t)0x46de377, (q31_t)0x4679bee, (q31_t)0x4615461, (q31_t)0x45b0cd2, + (q31_t)0x454c541, + (q31_t)0x44e7dac, (q31_t)0x4483615, (q31_t)0x441ee7c, (q31_t)0x43ba6df, (q31_t)0x4355f40, (q31_t)0x42f179f, (q31_t)0x428cffb, + (q31_t)0x4228854, + (q31_t)0x41c40ab, (q31_t)0x415f8ff, (q31_t)0x40fb151, (q31_t)0x40969a0, (q31_t)0x40321ed, (q31_t)0x3fcda37, (q31_t)0x3f6927f, + (q31_t)0x3f04ac4, + (q31_t)0x3ea0307, (q31_t)0x3e3bb48, (q31_t)0x3dd7386, (q31_t)0x3d72bc2, (q31_t)0x3d0e3fb, (q31_t)0x3ca9c32, (q31_t)0x3c45467, + (q31_t)0x3be0c99, + (q31_t)0x3b7c4c9, (q31_t)0x3b17cf7, (q31_t)0x3ab3523, (q31_t)0x3a4ed4c, (q31_t)0x39ea573, (q31_t)0x3985d97, (q31_t)0x39215ba, + (q31_t)0x38bcdda, + (q31_t)0x38585f8, (q31_t)0x37f3e14, (q31_t)0x378f62e, (q31_t)0x372ae46, (q31_t)0x36c665b, (q31_t)0x3661e6f, (q31_t)0x35fd680, + (q31_t)0x3598e8f, + (q31_t)0x353469c, (q31_t)0x34cfea8, (q31_t)0x346b6b1, (q31_t)0x3406eb8, (q31_t)0x33a26bd, (q31_t)0x333dec0, (q31_t)0x32d96c1, + (q31_t)0x3274ec0, + (q31_t)0x32106bd, (q31_t)0x31abeb9, (q31_t)0x31476b2, (q31_t)0x30e2ea9, (q31_t)0x307e69f, (q31_t)0x3019e93, (q31_t)0x2fb5684, + (q31_t)0x2f50e74, + (q31_t)0x2eec663, (q31_t)0x2e87e4f, (q31_t)0x2e2363a, (q31_t)0x2dbee22, (q31_t)0x2d5a609, (q31_t)0x2cf5def, (q31_t)0x2c915d2, + (q31_t)0x2c2cdb4, + (q31_t)0x2bc8594, (q31_t)0x2b63d73, (q31_t)0x2aff54f, (q31_t)0x2a9ad2a, (q31_t)0x2a36504, (q31_t)0x29d1cdc, (q31_t)0x296d4b2, + (q31_t)0x2908c87, + (q31_t)0x28a445a, (q31_t)0x283fc2b, (q31_t)0x27db3fb, (q31_t)0x2776bc9, (q31_t)0x2712396, (q31_t)0x26adb62, (q31_t)0x264932b, + (q31_t)0x25e4af4, + (q31_t)0x25802bb, (q31_t)0x251ba80, (q31_t)0x24b7244, (q31_t)0x2452a07, (q31_t)0x23ee1c8, (q31_t)0x2389988, (q31_t)0x2325147, + (q31_t)0x22c0904, + (q31_t)0x225c0bf, (q31_t)0x21f787a, (q31_t)0x2193033, (q31_t)0x212e7eb, (q31_t)0x20c9fa1, (q31_t)0x2065757, (q31_t)0x2000f0b, + (q31_t)0x1f9c6be, + (q31_t)0x1f37e6f, (q31_t)0x1ed3620, (q31_t)0x1e6edcf, (q31_t)0x1e0a57d, (q31_t)0x1da5d2a, (q31_t)0x1d414d6, (q31_t)0x1cdcc80, + (q31_t)0x1c7842a, + (q31_t)0x1c13bd2, (q31_t)0x1baf37a, (q31_t)0x1b4ab20, (q31_t)0x1ae62c5, (q31_t)0x1a81a69, (q31_t)0x1a1d20c, (q31_t)0x19b89ae, + (q31_t)0x1954150, + (q31_t)0x18ef8f0, (q31_t)0x188b08f, (q31_t)0x182682d, (q31_t)0x17c1fcb, (q31_t)0x175d767, (q31_t)0x16f8f03, (q31_t)0x169469d, + (q31_t)0x162fe37, + (q31_t)0x15cb5d0, (q31_t)0x1566d68, (q31_t)0x15024ff, (q31_t)0x149dc96, (q31_t)0x143942b, (q31_t)0x13d4bc0, (q31_t)0x1370354, + (q31_t)0x130bae7, + (q31_t)0x12a727a, (q31_t)0x1242a0c, (q31_t)0x11de19d, (q31_t)0x117992e, (q31_t)0x11150be, (q31_t)0x10b084d, (q31_t)0x104bfdb, + (q31_t)0xfe7769, + (q31_t)0xf82ef6, (q31_t)0xf1e683, (q31_t)0xeb9e0f, (q31_t)0xe5559b, (q31_t)0xdf0d26, (q31_t)0xd8c4b0, (q31_t)0xd27c3a, + (q31_t)0xcc33c3, + (q31_t)0xc5eb4c, (q31_t)0xbfa2d5, (q31_t)0xb95a5d, (q31_t)0xb311e4, (q31_t)0xacc96b, (q31_t)0xa680f2, (q31_t)0xa03878, + (q31_t)0x99effe, + (q31_t)0x93a784, (q31_t)0x8d5f09, (q31_t)0x87168e, (q31_t)0x80ce12, (q31_t)0x7a8597, (q31_t)0x743d1a, (q31_t)0x6df49e, + (q31_t)0x67ac21, + (q31_t)0x6163a5, (q31_t)0x5b1b27, (q31_t)0x54d2aa, (q31_t)0x4e8a2c, (q31_t)0x4841af, (q31_t)0x41f931, (q31_t)0x3bb0b3, + (q31_t)0x356835, + (q31_t)0x2f1fb6, (q31_t)0x28d738, (q31_t)0x228eb9, (q31_t)0x1c463b, (q31_t)0x15fdbc, (q31_t)0xfb53d, (q31_t)0x96cbe, (q31_t)0x3243f +}; + +/** + * @} end of DCT4_IDCT4_Table group + */ + +/** + * @addtogroup DCT4_IDCT4 + * @{ + */ + +/** + * @brief Initialization function for the Q31 DCT4/IDCT4. + * @param[in,out] *S points to an instance of Q31 DCT4/IDCT4 structure. + * @param[in] *S_RFFT points to an instance of Q31 RFFT/RIFFT structure + * @param[in] *S_CFFT points to an instance of Q31 CFFT/CIFFT structure + * @param[in] N length of the DCT4. + * @param[in] Nby2 half of the length of the DCT4. + * @param[in] normalize normalizing factor. + * @return arm_status function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if N is not a supported transform length. + * \par Normalizing factor: + * The normalizing factor is sqrt(2/N), which depends on the size of transform N. + * Normalizing factors in 1.31 format are mentioned in the table below for different DCT sizes: + * \image html dct4NormalizingQ31Table.gif + */ + +arm_status arm_dct4_init_q31( + arm_dct4_instance_q31 * S, + arm_rfft_instance_q31 * S_RFFT, + arm_cfft_radix4_instance_q31 * S_CFFT, + uint16_t N, + uint16_t Nby2, + q31_t normalize) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initializing the pointer array with the weight table base addresses of different lengths */ + q31_t *twiddlePtr[4] = { (q31_t *) WeightsQ31_128, (q31_t *) WeightsQ31_512, + (q31_t *) WeightsQ31_2048, (q31_t *) WeightsQ31_8192 + }; + + /* Initializing the pointer array with the cos factor table base addresses of different lengths */ + q31_t *pCosFactor[4] = + { (q31_t *) cos_factorsQ31_128, (q31_t *) cos_factorsQ31_512, + (q31_t *) cos_factorsQ31_2048, (q31_t *) cos_factorsQ31_8192 + }; + + /* Initialize the DCT4 length */ + S->N = N; + + /* Initialize the half of DCT4 length */ + S->Nby2 = Nby2; + + /* Initialize the DCT4 Normalizing factor */ + S->normalize = normalize; + + /* Initialize Real FFT Instance */ + S->pRfft = S_RFFT; + + /* Initialize Complex FFT Instance */ + S->pCfft = S_CFFT; + + switch (N) + { + /* Initialize the table modifier values */ + case 8192U: + S->pTwiddle = twiddlePtr[3]; + S->pCosFactor = pCosFactor[3]; + break; + case 2048U: + S->pTwiddle = twiddlePtr[2]; + S->pCosFactor = pCosFactor[2]; + break; + case 512U: + S->pTwiddle = twiddlePtr[1]; + S->pCosFactor = pCosFactor[1]; + break; + case 128U: + S->pTwiddle = twiddlePtr[0]; + S->pCosFactor = pCosFactor[0]; + break; + default: + status = ARM_MATH_ARGUMENT_ERROR; + } + + /* Initialize the RFFT/RIFFT Function */ + arm_rfft_init_q31(S->pRfft, S->N, 0, 1); + + /* return the status of DCT4 Init function */ + return (status); +} + +/** + * @} end of DCT4_IDCT4 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q15.c new file mode 100644 index 0000000..4fd7f6e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q15.c @@ -0,0 +1,382 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dct4_q15.c + * Description: Processing function of DCT4 & IDCT4 Q15 + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @addtogroup DCT4_IDCT4 + * @{ + */ + +/** + * @brief Processing function for the Q15 DCT4/IDCT4. + * @param[in] *S points to an instance of the Q15 DCT4 structure. + * @param[in] *pState points to state buffer. + * @param[in,out] *pInlineBuffer points to the in-place input and output buffer. + * @return none. + * + * \par Input an output formats: + * Internally inputs are downscaled in the RFFT process function to avoid overflows. + * Number of bits downscaled, depends on the size of the transform. + * The input and output formats for different DCT sizes and number of bits to upscale are mentioned in the table below: + * + * \image html dct4FormatsQ15Table.gif + */ + +void arm_dct4_q15( + const arm_dct4_instance_q15 * S, + q15_t * pState, + q15_t * pInlineBuffer) +{ + uint32_t i; /* Loop counter */ + q15_t *weights = S->pTwiddle; /* Pointer to the Weights table */ + q15_t *cosFact = S->pCosFactor; /* Pointer to the cos factors table */ + q15_t *pS1, *pS2, *pbuff; /* Temporary pointers for input buffer and pState buffer */ + q15_t in; /* Temporary variable */ + + + /* DCT4 computation involves DCT2 (which is calculated using RFFT) + * along with some pre-processing and post-processing. + * Computational procedure is explained as follows: + * (a) Pre-processing involves multiplying input with cos factor, + * r(n) = 2 * u(n) * cos(pi*(2*n+1)/(4*n)) + * where, + * r(n) -- output of preprocessing + * u(n) -- input to preprocessing(actual Source buffer) + * (b) Calculation of DCT2 using FFT is divided into three steps: + * Step1: Re-ordering of even and odd elements of input. + * Step2: Calculating FFT of the re-ordered input. + * Step3: Taking the real part of the product of FFT output and weights. + * (c) Post-processing - DCT4 can be obtained from DCT2 output using the following equation: + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * where, + * Y4 -- DCT4 output, Y2 -- DCT2 output + * (d) Multiplying the output with the normalizing factor sqrt(2/N). + */ + + /*-------- Pre-processing ------------*/ + /* Multiplying input with cos factor i.e. r(n) = 2 * x(n) * cos(pi*(2*n+1)/(4*n)) */ + arm_mult_q15(pInlineBuffer, cosFact, pInlineBuffer, S->N); + arm_shift_q15(pInlineBuffer, 1, pInlineBuffer, S->N); + + /* ---------------------------------------------------------------- + * Step1: Re-ordering of even and odd elements as + * pState[i] = pInlineBuffer[2*i] and + * pState[N-i-1] = pInlineBuffer[2*i+1] where i = 0 to N/2 + ---------------------------------------------------------------------*/ + + /* pS1 initialized to pState */ + pS1 = pState; + + /* pS2 initialized to pState+N-1, so that it points to the end of the state buffer */ + pS2 = pState + (S->N - 1U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Initializing the loop counter to N/2 >> 2 for loop unrolling by 4 */ + i = (uint32_t) S->Nby2 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + do + { + /* Re-ordering of even and odd elements */ + /* pState[i] = pInlineBuffer[2*i] */ + *pS1++ = *pbuff++; + /* pState[N-i-1] = pInlineBuffer[2*i+1] */ + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Initializing the loop counter to N/4 instead of N for loop unrolling */ + i = (uint32_t) S->N >> 2U; + + /* Processing with loop unrolling 4 times as N is always multiple of 4. + * Compute 4 outputs at a time */ + do + { + /* Writing the re-ordered output back to inplace input buffer */ + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + + /* --------------------------------------------------------- + * Step2: Calculate RFFT for N-point input + * ---------------------------------------------------------- */ + /* pInlineBuffer is real input of length N , pState is the complex output of length 2N */ + arm_rfft_q15(S->pRfft, pInlineBuffer, pState); + + /*---------------------------------------------------------------------- + * Step3: Multiply the FFT output with the weights. + *----------------------------------------------------------------------*/ + arm_cmplx_mult_cmplx_q15(pState, weights, pState, S->N); + + /* The output of complex multiplication is in 3.13 format. + * Hence changing the format of N (i.e. 2*N elements) complex numbers to 1.15 format by shifting left by 2 bits. */ + arm_shift_q15(pState, 2, pState, S->N * 2); + + /* ----------- Post-processing ---------- */ + /* DCT-IV can be obtained from DCT-II by the equation, + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * Hence, Y4(0) = Y2(0)/2 */ + /* Getting only real part from the output and Converting to DCT-IV */ + + /* Initializing the loop counter to N >> 2 for loop unrolling by 4 */ + i = ((uint32_t) S->N - 1U) >> 2U; + + /* pbuff initialized to input buffer. */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Calculating Y4(0) from Y2(0) using Y4(0) = Y2(0)/2 */ + in = *pS1++ >> 1U; + /* input buffer acts as inplace, so output values are stored in the input itself. */ + *pbuff++ = in; + + /* pState pointer is incremented twice as the real values are located alternatively in the array */ + pS1++; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + do + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + i = ((uint32_t) S->N - 1U) % 0x4U; + + while (i > 0U) + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + /* Decrement the loop counter */ + i--; + } + + + /*------------ Normalizing the output by multiplying with the normalizing factor ----------*/ + + /* Initializing the loop counter to N/4 instead of N for loop unrolling */ + i = (uint32_t) S->N >> 2U; + + /* pbuff initialized to the pInlineBuffer(now contains the output values) */ + pbuff = pInlineBuffer; + + /* Processing with loop unrolling 4 times as N is always multiple of 4. Compute 4 outputs at a time */ + do + { + /* Multiplying pInlineBuffer with the normalizing factor sqrt(2/N) */ + in = *pbuff; + *pbuff++ = ((q15_t) (((q31_t) in * S->normalize) >> 15)); + + in = *pbuff; + *pbuff++ = ((q15_t) (((q31_t) in * S->normalize) >> 15)); + + in = *pbuff; + *pbuff++ = ((q15_t) (((q31_t) in * S->normalize) >> 15)); + + in = *pbuff; + *pbuff++ = ((q15_t) (((q31_t) in * S->normalize) >> 15)); + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initializing the loop counter to N/2 */ + i = (uint32_t) S->Nby2; + + do + { + /* Re-ordering of even and odd elements */ + /* pState[i] = pInlineBuffer[2*i] */ + *pS1++ = *pbuff++; + /* pState[N-i-1] = pInlineBuffer[2*i+1] */ + *pS2-- = *pbuff++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Initializing the loop counter */ + i = (uint32_t) S->N; + + do + { + /* Writing the re-ordered output back to inplace input buffer */ + *pbuff++ = *pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + + /* --------------------------------------------------------- + * Step2: Calculate RFFT for N-point input + * ---------------------------------------------------------- */ + /* pInlineBuffer is real input of length N , pState is the complex output of length 2N */ + arm_rfft_q15(S->pRfft, pInlineBuffer, pState); + + /*---------------------------------------------------------------------- + * Step3: Multiply the FFT output with the weights. + *----------------------------------------------------------------------*/ + arm_cmplx_mult_cmplx_q15(pState, weights, pState, S->N); + + /* The output of complex multiplication is in 3.13 format. + * Hence changing the format of N (i.e. 2*N elements) complex numbers to 1.15 format by shifting left by 2 bits. */ + arm_shift_q15(pState, 2, pState, S->N * 2); + + /* ----------- Post-processing ---------- */ + /* DCT-IV can be obtained from DCT-II by the equation, + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * Hence, Y4(0) = Y2(0)/2 */ + /* Getting only real part from the output and Converting to DCT-IV */ + + /* Initializing the loop counter */ + i = ((uint32_t) S->N - 1U); + + /* pbuff initialized to input buffer. */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Calculating Y4(0) from Y2(0) using Y4(0) = Y2(0)/2 */ + in = *pS1++ >> 1U; + /* input buffer acts as inplace, so output values are stored in the input itself. */ + *pbuff++ = in; + + /* pState pointer is incremented twice as the real values are located alternatively in the array */ + pS1++; + + do + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /*------------ Normalizing the output by multiplying with the normalizing factor ----------*/ + + /* Initializing the loop counter */ + i = (uint32_t) S->N; + + /* pbuff initialized to the pInlineBuffer(now contains the output values) */ + pbuff = pInlineBuffer; + + do + { + /* Multiplying pInlineBuffer with the normalizing factor sqrt(2/N) */ + in = *pbuff; + *pbuff++ = ((q15_t) (((q31_t) in * S->normalize) >> 15)); + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of DCT4_IDCT4 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q31.c new file mode 100644 index 0000000..7191208 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_dct4_q31.c @@ -0,0 +1,383 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_dct4_q31.c + * Description: Processing function of DCT4 & IDCT4 Q31 + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @addtogroup DCT4_IDCT4 + * @{ + */ + +/** + * @brief Processing function for the Q31 DCT4/IDCT4. + * @param[in] *S points to an instance of the Q31 DCT4 structure. + * @param[in] *pState points to state buffer. + * @param[in,out] *pInlineBuffer points to the in-place input and output buffer. + * @return none. + * \par Input an output formats: + * Input samples need to be downscaled by 1 bit to avoid saturations in the Q31 DCT process, + * as the conversion from DCT2 to DCT4 involves one subtraction. + * Internally inputs are downscaled in the RFFT process function to avoid overflows. + * Number of bits downscaled, depends on the size of the transform. + * The input and output formats for different DCT sizes and number of bits to upscale are mentioned in the table below: + * + * \image html dct4FormatsQ31Table.gif + */ + +void arm_dct4_q31( + const arm_dct4_instance_q31 * S, + q31_t * pState, + q31_t * pInlineBuffer) +{ + uint16_t i; /* Loop counter */ + q31_t *weights = S->pTwiddle; /* Pointer to the Weights table */ + q31_t *cosFact = S->pCosFactor; /* Pointer to the cos factors table */ + q31_t *pS1, *pS2, *pbuff; /* Temporary pointers for input buffer and pState buffer */ + q31_t in; /* Temporary variable */ + + + /* DCT4 computation involves DCT2 (which is calculated using RFFT) + * along with some pre-processing and post-processing. + * Computational procedure is explained as follows: + * (a) Pre-processing involves multiplying input with cos factor, + * r(n) = 2 * u(n) * cos(pi*(2*n+1)/(4*n)) + * where, + * r(n) -- output of preprocessing + * u(n) -- input to preprocessing(actual Source buffer) + * (b) Calculation of DCT2 using FFT is divided into three steps: + * Step1: Re-ordering of even and odd elements of input. + * Step2: Calculating FFT of the re-ordered input. + * Step3: Taking the real part of the product of FFT output and weights. + * (c) Post-processing - DCT4 can be obtained from DCT2 output using the following equation: + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * where, + * Y4 -- DCT4 output, Y2 -- DCT2 output + * (d) Multiplying the output with the normalizing factor sqrt(2/N). + */ + + /*-------- Pre-processing ------------*/ + /* Multiplying input with cos factor i.e. r(n) = 2 * x(n) * cos(pi*(2*n+1)/(4*n)) */ + arm_mult_q31(pInlineBuffer, cosFact, pInlineBuffer, S->N); + arm_shift_q31(pInlineBuffer, 1, pInlineBuffer, S->N); + + /* ---------------------------------------------------------------- + * Step1: Re-ordering of even and odd elements as + * pState[i] = pInlineBuffer[2*i] and + * pState[N-i-1] = pInlineBuffer[2*i+1] where i = 0 to N/2 + ---------------------------------------------------------------------*/ + + /* pS1 initialized to pState */ + pS1 = pState; + + /* pS2 initialized to pState+N-1, so that it points to the end of the state buffer */ + pS2 = pState + (S->N - 1U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /* Initializing the loop counter to N/2 >> 2 for loop unrolling by 4 */ + i = S->Nby2 >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + do + { + /* Re-ordering of even and odd elements */ + /* pState[i] = pInlineBuffer[2*i] */ + *pS1++ = *pbuff++; + /* pState[N-i-1] = pInlineBuffer[2*i+1] */ + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + *pS1++ = *pbuff++; + *pS2-- = *pbuff++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Initializing the loop counter to N/4 instead of N for loop unrolling */ + i = S->N >> 2U; + + /* Processing with loop unrolling 4 times as N is always multiple of 4. + * Compute 4 outputs at a time */ + do + { + /* Writing the re-ordered output back to inplace input buffer */ + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + *pbuff++ = *pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + + /* --------------------------------------------------------- + * Step2: Calculate RFFT for N-point input + * ---------------------------------------------------------- */ + /* pInlineBuffer is real input of length N , pState is the complex output of length 2N */ + arm_rfft_q31(S->pRfft, pInlineBuffer, pState); + + /*---------------------------------------------------------------------- + * Step3: Multiply the FFT output with the weights. + *----------------------------------------------------------------------*/ + arm_cmplx_mult_cmplx_q31(pState, weights, pState, S->N); + + /* The output of complex multiplication is in 3.29 format. + * Hence changing the format of N (i.e. 2*N elements) complex numbers to 1.31 format by shifting left by 2 bits. */ + arm_shift_q31(pState, 2, pState, S->N * 2); + + /* ----------- Post-processing ---------- */ + /* DCT-IV can be obtained from DCT-II by the equation, + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * Hence, Y4(0) = Y2(0)/2 */ + /* Getting only real part from the output and Converting to DCT-IV */ + + /* Initializing the loop counter to N >> 2 for loop unrolling by 4 */ + i = (S->N - 1U) >> 2U; + + /* pbuff initialized to input buffer. */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Calculating Y4(0) from Y2(0) using Y4(0) = Y2(0)/2 */ + in = *pS1++ >> 1U; + /* input buffer acts as inplace, so output values are stored in the input itself. */ + *pbuff++ = in; + + /* pState pointer is incremented twice as the real values are located alternatively in the array */ + pS1++; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + do + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + in = *pS1++ - in; + *pbuff++ = in; + pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + i = (S->N - 1U) % 0x4U; + + while (i > 0U) + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + /* Decrement the loop counter */ + i--; + } + + + /*------------ Normalizing the output by multiplying with the normalizing factor ----------*/ + + /* Initializing the loop counter to N/4 instead of N for loop unrolling */ + i = S->N >> 2U; + + /* pbuff initialized to the pInlineBuffer(now contains the output values) */ + pbuff = pInlineBuffer; + + /* Processing with loop unrolling 4 times as N is always multiple of 4. Compute 4 outputs at a time */ + do + { + /* Multiplying pInlineBuffer with the normalizing factor sqrt(2/N) */ + in = *pbuff; + *pbuff++ = ((q31_t) (((q63_t) in * S->normalize) >> 31)); + + in = *pbuff; + *pbuff++ = ((q31_t) (((q63_t) in * S->normalize) >> 31)); + + in = *pbuff; + *pbuff++ = ((q31_t) (((q63_t) in * S->normalize) >> 31)); + + in = *pbuff; + *pbuff++ = ((q31_t) (((q63_t) in * S->normalize) >> 31)); + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initializing the loop counter to N/2 */ + i = S->Nby2; + + do + { + /* Re-ordering of even and odd elements */ + /* pState[i] = pInlineBuffer[2*i] */ + *pS1++ = *pbuff++; + /* pState[N-i-1] = pInlineBuffer[2*i+1] */ + *pS2-- = *pbuff++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + /* pbuff initialized to input buffer */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Initializing the loop counter */ + i = S->N; + + do + { + /* Writing the re-ordered output back to inplace input buffer */ + *pbuff++ = *pS1++; + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + + + /* --------------------------------------------------------- + * Step2: Calculate RFFT for N-point input + * ---------------------------------------------------------- */ + /* pInlineBuffer is real input of length N , pState is the complex output of length 2N */ + arm_rfft_q31(S->pRfft, pInlineBuffer, pState); + + /*---------------------------------------------------------------------- + * Step3: Multiply the FFT output with the weights. + *----------------------------------------------------------------------*/ + arm_cmplx_mult_cmplx_q31(pState, weights, pState, S->N); + + /* The output of complex multiplication is in 3.29 format. + * Hence changing the format of N (i.e. 2*N elements) complex numbers to 1.31 format by shifting left by 2 bits. */ + arm_shift_q31(pState, 2, pState, S->N * 2); + + /* ----------- Post-processing ---------- */ + /* DCT-IV can be obtained from DCT-II by the equation, + * Y4(k) = Y2(k) - Y4(k-1) and Y4(-1) = Y4(0) + * Hence, Y4(0) = Y2(0)/2 */ + /* Getting only real part from the output and Converting to DCT-IV */ + + /* pbuff initialized to input buffer. */ + pbuff = pInlineBuffer; + + /* pS1 initialized to pState */ + pS1 = pState; + + /* Calculating Y4(0) from Y2(0) using Y4(0) = Y2(0)/2 */ + in = *pS1++ >> 1U; + /* input buffer acts as inplace, so output values are stored in the input itself. */ + *pbuff++ = in; + + /* pState pointer is incremented twice as the real values are located alternatively in the array */ + pS1++; + + /* Initializing the loop counter */ + i = (S->N - 1U); + + while (i > 0U) + { + /* Calculating Y4(1) to Y4(N-1) from Y2 using equation Y4(k) = Y2(k) - Y4(k-1) */ + /* pState pointer (pS1) is incremented twice as the real values are located alternatively in the array */ + in = *pS1++ - in; + *pbuff++ = in; + /* points to the next real value */ + pS1++; + + /* Decrement the loop counter */ + i--; + } + + + /*------------ Normalizing the output by multiplying with the normalizing factor ----------*/ + + /* Initializing the loop counter */ + i = S->N; + + /* pbuff initialized to the pInlineBuffer(now contains the output values) */ + pbuff = pInlineBuffer; + + do + { + /* Multiplying pInlineBuffer with the normalizing factor sqrt(2/N) */ + in = *pbuff; + *pbuff++ = ((q31_t) (((q63_t) in * S->normalize) >> 31)); + + /* Decrement the loop counter */ + i--; + } while (i > 0U); + +#endif /* #if defined (ARM_MATH_DSP) */ + +} + +/** + * @} end of DCT4_IDCT4 group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_f32.c new file mode 100644 index 0000000..16c75eb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_f32.c @@ -0,0 +1,318 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rfft_f32.c + * Description: RFFT & RIFFT Floating point process function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/* ---------------------------------------------------------------------- + * Internal functions prototypes + * -------------------------------------------------------------------- */ + +extern void arm_radix4_butterfly_f32( + float32_t * pSrc, + uint16_t fftLen, + float32_t * pCoef, + uint16_t twidCoefModifier); + +extern void arm_radix4_butterfly_inverse_f32( + float32_t * pSrc, + uint16_t fftLen, + float32_t * pCoef, + uint16_t twidCoefModifier, + float32_t onebyfftLen); + +extern void arm_bitreversal_f32( + float32_t * pSrc, + uint16_t fftSize, + uint16_t bitRevFactor, + uint16_t * pBitRevTab); + +void arm_split_rfft_f32( + float32_t * pSrc, + uint32_t fftLen, + float32_t * pATable, + float32_t * pBTable, + float32_t * pDst, + uint32_t modifier); + +void arm_split_rifft_f32( + float32_t * pSrc, + uint32_t fftLen, + float32_t * pATable, + float32_t * pBTable, + float32_t * pDst, + uint32_t modifier); + +/** +* @ingroup groupTransforms +*/ + +/** + * @addtogroup RealFFT + * @{ + */ + +/** + * @brief Processing function for the floating-point RFFT/RIFFT. + * @deprecated Do not use this function. It has been superceded by \ref arm_rfft_fast_f32 and will be removed + * in the future. + * @param[in] *S points to an instance of the floating-point RFFT/RIFFT structure. + * @param[in] *pSrc points to the input buffer. + * @param[out] *pDst points to the output buffer. + * @return none. + */ + +void arm_rfft_f32( + const arm_rfft_instance_f32 * S, + float32_t * pSrc, + float32_t * pDst) +{ + const arm_cfft_radix4_instance_f32 *S_CFFT = S->pCfft; + + + /* Calculation of Real IFFT of input */ + if (S->ifftFlagR == 1U) + { + /* Real IFFT core process */ + arm_split_rifft_f32(pSrc, S->fftLenBy2, S->pTwiddleAReal, + S->pTwiddleBReal, pDst, S->twidCoefRModifier); + + + /* Complex radix-4 IFFT process */ + arm_radix4_butterfly_inverse_f32(pDst, S_CFFT->fftLen, + S_CFFT->pTwiddle, + S_CFFT->twidCoefModifier, + S_CFFT->onebyfftLen); + + /* Bit reversal process */ + if (S->bitReverseFlagR == 1U) + { + arm_bitreversal_f32(pDst, S_CFFT->fftLen, + S_CFFT->bitRevFactor, S_CFFT->pBitRevTable); + } + } + else + { + + /* Calculation of RFFT of input */ + + /* Complex radix-4 FFT process */ + arm_radix4_butterfly_f32(pSrc, S_CFFT->fftLen, + S_CFFT->pTwiddle, S_CFFT->twidCoefModifier); + + /* Bit reversal process */ + if (S->bitReverseFlagR == 1U) + { + arm_bitreversal_f32(pSrc, S_CFFT->fftLen, + S_CFFT->bitRevFactor, S_CFFT->pBitRevTable); + } + + + /* Real FFT core process */ + arm_split_rfft_f32(pSrc, S->fftLenBy2, S->pTwiddleAReal, + S->pTwiddleBReal, pDst, S->twidCoefRModifier); + } + +} + +/** + * @} end of RealFFT group + */ + +/** + * @brief Core Real FFT process + * @param[in] *pSrc points to the input buffer. + * @param[in] fftLen length of FFT. + * @param[in] *pATable points to the twiddle Coef A buffer. + * @param[in] *pBTable points to the twiddle Coef B buffer. + * @param[out] *pDst points to the output buffer. + * @param[in] modifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. + * @return none. + */ + +void arm_split_rfft_f32( + float32_t * pSrc, + uint32_t fftLen, + float32_t * pATable, + float32_t * pBTable, + float32_t * pDst, + uint32_t modifier) +{ + uint32_t i; /* Loop Counter */ + float32_t outR, outI; /* Temporary variables for output */ + float32_t *pCoefA, *pCoefB; /* Temporary pointers for twiddle factors */ + float32_t CoefA1, CoefA2, CoefB1; /* Temporary variables for twiddle coefficients */ + float32_t *pDst1 = &pDst[2], *pDst2 = &pDst[(4U * fftLen) - 1U]; /* temp pointers for output buffer */ + float32_t *pSrc1 = &pSrc[2], *pSrc2 = &pSrc[(2U * fftLen) - 1U]; /* temp pointers for input buffer */ + + /* Init coefficient pointers */ + pCoefA = &pATable[modifier * 2U]; + pCoefB = &pBTable[modifier * 2U]; + + i = fftLen - 1U; + + while (i > 0U) + { + /* + outR = (pSrc[2 * i] * pATable[2 * i] - pSrc[2 * i + 1] * pATable[2 * i + 1] + + pSrc[2 * n - 2 * i] * pBTable[2 * i] + + pSrc[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + */ + + /* outI = (pIn[2 * i + 1] * pATable[2 * i] + pIn[2 * i] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); */ + + /* read pATable[2 * i] */ + CoefA1 = *pCoefA++; + /* pATable[2 * i + 1] */ + CoefA2 = *pCoefA; + + /* pSrc[2 * i] * pATable[2 * i] */ + outR = *pSrc1 * CoefA1; + /* pSrc[2 * i] * CoefA2 */ + outI = *pSrc1++ * CoefA2; + + /* (pSrc[2 * i + 1] + pSrc[2 * fftLen - 2 * i + 1]) * CoefA2 */ + outR -= (*pSrc1 + *pSrc2) * CoefA2; + /* pSrc[2 * i + 1] * CoefA1 */ + outI += *pSrc1++ * CoefA1; + + CoefB1 = *pCoefB; + + /* pSrc[2 * fftLen - 2 * i + 1] * CoefB1 */ + outI -= *pSrc2-- * CoefB1; + /* pSrc[2 * fftLen - 2 * i] * CoefA2 */ + outI -= *pSrc2 * CoefA2; + + /* pSrc[2 * fftLen - 2 * i] * CoefB1 */ + outR += *pSrc2-- * CoefB1; + + /* write output */ + *pDst1++ = outR; + *pDst1++ = outI; + + /* write complex conjugate output */ + *pDst2-- = -outI; + *pDst2-- = outR; + + /* update coefficient pointer */ + pCoefB = pCoefB + (modifier * 2U); + pCoefA = pCoefA + ((modifier * 2U) - 1U); + + i--; + + } + + pDst[2U * fftLen] = pSrc[0] - pSrc[1]; + pDst[(2U * fftLen) + 1U] = 0.0f; + + pDst[0] = pSrc[0] + pSrc[1]; + pDst[1] = 0.0f; + +} + + +/** + * @brief Core Real IFFT process + * @param[in] *pSrc points to the input buffer. + * @param[in] fftLen length of FFT. + * @param[in] *pATable points to the twiddle Coef A buffer. + * @param[in] *pBTable points to the twiddle Coef B buffer. + * @param[out] *pDst points to the output buffer. + * @param[in] modifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. + * @return none. + */ + +void arm_split_rifft_f32( + float32_t * pSrc, + uint32_t fftLen, + float32_t * pATable, + float32_t * pBTable, + float32_t * pDst, + uint32_t modifier) +{ + float32_t outR, outI; /* Temporary variables for output */ + float32_t *pCoefA, *pCoefB; /* Temporary pointers for twiddle factors */ + float32_t CoefA1, CoefA2, CoefB1; /* Temporary variables for twiddle coefficients */ + float32_t *pSrc1 = &pSrc[0], *pSrc2 = &pSrc[(2U * fftLen) + 1U]; + + pCoefA = &pATable[0]; + pCoefB = &pBTable[0]; + + while (fftLen > 0U) + { + /* + outR = (pIn[2 * i] * pATable[2 * i] + pIn[2 * i + 1] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + + outI = (pIn[2 * i + 1] * pATable[2 * i] - pIn[2 * i] * pATable[2 * i + 1] - + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); + + */ + + CoefA1 = *pCoefA++; + CoefA2 = *pCoefA; + + /* outR = (pSrc[2 * i] * CoefA1 */ + outR = *pSrc1 * CoefA1; + + /* - pSrc[2 * i] * CoefA2 */ + outI = -(*pSrc1++) * CoefA2; + + /* (pSrc[2 * i + 1] + pSrc[2 * fftLen - 2 * i + 1]) * CoefA2 */ + outR += (*pSrc1 + *pSrc2) * CoefA2; + + /* pSrc[2 * i + 1] * CoefA1 */ + outI += (*pSrc1++) * CoefA1; + + CoefB1 = *pCoefB; + + /* - pSrc[2 * fftLen - 2 * i + 1] * CoefB1 */ + outI -= *pSrc2-- * CoefB1; + + /* pSrc[2 * fftLen - 2 * i] * CoefB1 */ + outR += *pSrc2 * CoefB1; + + /* pSrc[2 * fftLen - 2 * i] * CoefA2 */ + outI += *pSrc2-- * CoefA2; + + /* write output */ + *pDst++ = outR; + *pDst++ = outI; + + /* update coefficient pointer */ + pCoefB = pCoefB + (modifier * 2U); + pCoefA = pCoefA + ((modifier * 2U) - 1U); + + /* Decrement loop count */ + fftLen--; + } + +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_f32.c new file mode 100644 index 0000000..08e06e0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_f32.c @@ -0,0 +1,317 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rfft_f32.c + * Description: RFFT & RIFFT Floating point process function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +void stage_rfft_f32( + arm_rfft_fast_instance_f32 * S, + float32_t * p, float32_t * pOut) +{ + uint32_t k; /* Loop Counter */ + float32_t twR, twI; /* RFFT Twiddle coefficients */ + float32_t * pCoeff = S->pTwiddleRFFT; /* Points to RFFT Twiddle factors */ + float32_t *pA = p; /* increasing pointer */ + float32_t *pB = p; /* decreasing pointer */ + float32_t xAR, xAI, xBR, xBI; /* temporary variables */ + float32_t t1a, t1b; /* temporary variables */ + float32_t p0, p1, p2, p3; /* temporary variables */ + + + k = (S->Sint).fftLen - 1; + + /* Pack first and last sample of the frequency domain together */ + + xBR = pB[0]; + xBI = pB[1]; + xAR = pA[0]; + xAI = pA[1]; + + twR = *pCoeff++ ; + twI = *pCoeff++ ; + + // U1 = XA(1) + XB(1); % It is real + t1a = xBR + xAR ; + + // U2 = XB(1) - XA(1); % It is imaginary + t1b = xBI + xAI ; + + // real(tw * (xB - xA)) = twR * (xBR - xAR) - twI * (xBI - xAI); + // imag(tw * (xB - xA)) = twI * (xBR - xAR) + twR * (xBI - xAI); + *pOut++ = 0.5f * ( t1a + t1b ); + *pOut++ = 0.5f * ( t1a - t1b ); + + // XA(1) = 1/2*( U1 - imag(U2) + i*( U1 +imag(U2) )); + pB = p + 2*k; + pA += 2; + + do + { + /* + function X = my_split_rfft(X, ifftFlag) + % X is a series of real numbers + L = length(X); + XC = X(1:2:end) +i*X(2:2:end); + XA = fft(XC); + XB = conj(XA([1 end:-1:2])); + TW = i*exp(-2*pi*i*[0:L/2-1]/L).'; + for l = 2:L/2 + XA(l) = 1/2 * (XA(l) + XB(l) + TW(l) * (XB(l) - XA(l))); + end + XA(1) = 1/2* (XA(1) + XB(1) + TW(1) * (XB(1) - XA(1))) + i*( 1/2*( XA(1) + XB(1) + i*( XA(1) - XB(1)))); + X = XA; + */ + + xBI = pB[1]; + xBR = pB[0]; + xAR = pA[0]; + xAI = pA[1]; + + twR = *pCoeff++; + twI = *pCoeff++; + + t1a = xBR - xAR ; + t1b = xBI + xAI ; + + // real(tw * (xB - xA)) = twR * (xBR - xAR) - twI * (xBI - xAI); + // imag(tw * (xB - xA)) = twI * (xBR - xAR) + twR * (xBI - xAI); + p0 = twR * t1a; + p1 = twI * t1a; + p2 = twR * t1b; + p3 = twI * t1b; + + *pOut++ = 0.5f * (xAR + xBR + p0 + p3 ); //xAR + *pOut++ = 0.5f * (xAI - xBI + p1 - p2 ); //xAI + + pA += 2; + pB -= 2; + k--; + } while (k > 0U); +} + +/* Prepares data for inverse cfft */ +void merge_rfft_f32( +arm_rfft_fast_instance_f32 * S, +float32_t * p, float32_t * pOut) +{ + uint32_t k; /* Loop Counter */ + float32_t twR, twI; /* RFFT Twiddle coefficients */ + float32_t *pCoeff = S->pTwiddleRFFT; /* Points to RFFT Twiddle factors */ + float32_t *pA = p; /* increasing pointer */ + float32_t *pB = p; /* decreasing pointer */ + float32_t xAR, xAI, xBR, xBI; /* temporary variables */ + float32_t t1a, t1b, r, s, t, u; /* temporary variables */ + + k = (S->Sint).fftLen - 1; + + xAR = pA[0]; + xAI = pA[1]; + + pCoeff += 2 ; + + *pOut++ = 0.5f * ( xAR + xAI ); + *pOut++ = 0.5f * ( xAR - xAI ); + + pB = p + 2*k ; + pA += 2 ; + + while (k > 0U) + { + /* G is half of the frequency complex spectrum */ + //for k = 2:N + // Xk(k) = 1/2 * (G(k) + conj(G(N-k+2)) + Tw(k)*( G(k) - conj(G(N-k+2)))); + xBI = pB[1] ; + xBR = pB[0] ; + xAR = pA[0]; + xAI = pA[1]; + + twR = *pCoeff++; + twI = *pCoeff++; + + t1a = xAR - xBR ; + t1b = xAI + xBI ; + + r = twR * t1a; + s = twI * t1b; + t = twI * t1a; + u = twR * t1b; + + // real(tw * (xA - xB)) = twR * (xAR - xBR) - twI * (xAI - xBI); + // imag(tw * (xA - xB)) = twI * (xAR - xBR) + twR * (xAI - xBI); + *pOut++ = 0.5f * (xAR + xBR - r - s ); //xAR + *pOut++ = 0.5f * (xAI - xBI + t - u ); //xAI + + pA += 2; + pB -= 2; + k--; + } + +} + +/** +* @ingroup groupTransforms +*/ + +/** + * @defgroup RealFFT Real FFT Functions + * + * \par + * The CMSIS DSP library includes specialized algorithms for computing the + * FFT of real data sequences. The FFT is defined over complex data but + * in many applications the input is real. Real FFT algorithms take advantage + * of the symmetry properties of the FFT and have a speed advantage over complex + * algorithms of the same length. + * \par + * The Fast RFFT algorith relays on the mixed radix CFFT that save processor usage. + * \par + * The real length N forward FFT of a sequence is computed using the steps shown below. + * \par + * \image html RFFT.gif "Real Fast Fourier Transform" + * \par + * The real sequence is initially treated as if it were complex to perform a CFFT. + * Later, a processing stage reshapes the data to obtain half of the frequency spectrum + * in complex format. Except the first complex number that contains the two real numbers + * X[0] and X[N/2] all the data is complex. In other words, the first complex sample + * contains two real values packed. + * \par + * The input for the inverse RFFT should keep the same format as the output of the + * forward RFFT. A first processing stage pre-process the data to later perform an + * inverse CFFT. + * \par + * \image html RIFFT.gif "Real Inverse Fast Fourier Transform" + * \par + * The algorithms for floating-point, Q15, and Q31 data are slightly different + * and we describe each algorithm in turn. + * \par Floating-point + * The main functions are arm_rfft_fast_f32() and arm_rfft_fast_init_f32(). + * The older functions arm_rfft_f32() and arm_rfft_init_f32() have been + * deprecated but are still documented. + * \par + * The FFT of a real N-point sequence has even symmetry in the frequency + * domain. The second half of the data equals the conjugate of the first + * half flipped in frequency. Looking at the data, we see that we can + * uniquely represent the FFT using only N/2 complex numbers. These are + * packed into the output array in alternating real and imaginary + * components: + * \par + * X = { real[0], imag[0], real[1], imag[1], real[2], imag[2] ... + * real[(N/2)-1], imag[(N/2)-1 } + * \par + * It happens that the first complex number (real[0], imag[0]) is actually + * all real. real[0] represents the DC offset, and imag[0] should be 0. + * (real[1], imag[1]) is the fundamental frequency, (real[2], imag[2]) is + * the first harmonic and so on. + * \par + * The real FFT functions pack the frequency domain data in this fashion. + * The forward transform outputs the data in this form and the inverse + * transform expects input data in this form. The function always performs + * the needed bitreversal so that the input and output data is always in + * normal order. The functions support lengths of [32, 64, 128, ..., 4096] + * samples. + * \par Q15 and Q31 + * The real algorithms are defined in a similar manner and utilize N/2 complex + * transforms behind the scenes. + * \par + * The complex transforms used internally include scaling to prevent fixed-point + * overflows. The overall scaling equals 1/(fftLen/2). + * \par + * A separate instance structure must be defined for each transform used but + * twiddle factor and bit reversal tables can be reused. + * \par + * There is also an associated initialization function for each data type. + * The initialization function performs the following operations: + * - Sets the values of the internal structure fields. + * - Initializes twiddle factor table and bit reversal table pointers. + * - Initializes the internal complex FFT data structure. + * \par + * Use of the initialization function is optional. + * However, if the initialization function is used, then the instance structure + * cannot be placed into a const data section. To place an instance structure + * into a const data section, the instance structure should be manually + * initialized as follows: + *
+ *arm_rfft_instance_q31 S = {fftLenReal, fftLenBy2, ifftFlagR, bitReverseFlagR, twidCoefRModifier, pTwiddleAReal, pTwiddleBReal, pCfft};
+ *arm_rfft_instance_q15 S = {fftLenReal, fftLenBy2, ifftFlagR, bitReverseFlagR, twidCoefRModifier, pTwiddleAReal, pTwiddleBReal, pCfft};
+ * 
+ * where fftLenReal is the length of the real transform; + * fftLenBy2 length of the internal complex transform. + * ifftFlagR Selects forward (=0) or inverse (=1) transform. + * bitReverseFlagR Selects bit reversed output (=0) or normal order + * output (=1). + * twidCoefRModifier stride modifier for the twiddle factor table. + * The value is based on the FFT length; + * pTwiddleARealpoints to the A array of twiddle coefficients; + * pTwiddleBRealpoints to the B array of twiddle coefficients; + * pCfft points to the CFFT Instance structure. The CFFT structure + * must also be initialized. Refer to arm_cfft_radix4_f32() for details regarding + * static initialization of the complex FFT instance structure. + */ + +/** +* @addtogroup RealFFT +* @{ +*/ + +/** +* @brief Processing function for the floating-point real FFT. +* @param[in] *S points to an arm_rfft_fast_instance_f32 structure. +* @param[in] *p points to the input buffer. +* @param[in] *pOut points to the output buffer. +* @param[in] ifftFlag RFFT if flag is 0, RIFFT if flag is 1 +* @return none. +*/ + +void arm_rfft_fast_f32( +arm_rfft_fast_instance_f32 * S, +float32_t * p, float32_t * pOut, +uint8_t ifftFlag) +{ + arm_cfft_instance_f32 * Sint = &(S->Sint); + Sint->fftLen = S->fftLenRFFT / 2; + + /* Calculation of Real FFT */ + if (ifftFlag) + { + /* Real FFT compression */ + merge_rfft_f32(S, p, pOut); + + /* Complex radix-4 IFFT process */ + arm_cfft_f32( Sint, pOut, ifftFlag, 1); + } + else + { + /* Calculation of RFFT of input */ + arm_cfft_f32( Sint, p, ifftFlag, 1); + + /* Real FFT extraction */ + stage_rfft_f32(S, p, pOut); + } +} + +/** +* @} end of RealFFT group +*/ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_init_f32.c new file mode 100644 index 0000000..6f6c2f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_fast_init_f32.c @@ -0,0 +1,131 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_cfft_init_f32.c + * Description: Split Radix Decimation in Frequency CFFT Floating point processing function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" + +/** + * @ingroup groupTransforms + */ + +/** + * @addtogroup RealFFT + * @{ + */ + +/** +* @brief Initialization function for the floating-point real FFT. +* @param[in,out] *S points to an arm_rfft_fast_instance_f32 structure. +* @param[in] fftLen length of the Real Sequence. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLen is not a supported value. +* +* \par Description: +* \par +* The parameter fftLen Specifies length of RFFT/CIFFT process. Supported FFT Lengths are 32, 64, 128, 256, 512, 1024, 2048, 4096. +* \par +* This Function also initializes Twiddle factor table pointer and Bit reversal table pointer. +*/ +arm_status arm_rfft_fast_init_f32( + arm_rfft_fast_instance_f32 * S, + uint16_t fftLen) +{ + arm_cfft_instance_f32 * Sint; + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + /* Initialise the FFT length */ + Sint = &(S->Sint); + Sint->fftLen = fftLen/2; + S->fftLenRFFT = fftLen; + + /* Initializations of structure parameters depending on the FFT length */ + switch (Sint->fftLen) + { + case 2048U: + /* Initializations of structure parameters for 2048 point FFT */ + /* Initialise the bit reversal table length */ + Sint->bitRevLength = ARMBITREVINDEXTABLE_2048_TABLE_LENGTH; + /* Initialise the bit reversal table pointer */ + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable2048; + /* Initialise the Twiddle coefficient pointers */ + Sint->pTwiddle = (float32_t *) twiddleCoef_2048; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_4096; + break; + case 1024U: + Sint->bitRevLength = ARMBITREVINDEXTABLE_1024_TABLE_LENGTH; + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable1024; + Sint->pTwiddle = (float32_t *) twiddleCoef_1024; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_2048; + break; + case 512U: + Sint->bitRevLength = ARMBITREVINDEXTABLE_512_TABLE_LENGTH; + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable512; + Sint->pTwiddle = (float32_t *) twiddleCoef_512; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_1024; + break; + case 256U: + Sint->bitRevLength = ARMBITREVINDEXTABLE_256_TABLE_LENGTH; + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable256; + Sint->pTwiddle = (float32_t *) twiddleCoef_256; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_512; + break; + case 128U: + Sint->bitRevLength = ARMBITREVINDEXTABLE_128_TABLE_LENGTH; + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable128; + Sint->pTwiddle = (float32_t *) twiddleCoef_128; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_256; + break; + case 64U: + Sint->bitRevLength = ARMBITREVINDEXTABLE_64_TABLE_LENGTH; + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable64; + Sint->pTwiddle = (float32_t *) twiddleCoef_64; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_128; + break; + case 32U: + Sint->bitRevLength = ARMBITREVINDEXTABLE_32_TABLE_LENGTH; + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable32; + Sint->pTwiddle = (float32_t *) twiddleCoef_32; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_64; + break; + case 16U: + Sint->bitRevLength = ARMBITREVINDEXTABLE_16_TABLE_LENGTH; + Sint->pBitRevTable = (uint16_t *)armBitRevIndexTable16; + Sint->pTwiddle = (float32_t *) twiddleCoef_16; + S->pTwiddleRFFT = (float32_t *) twiddleCoef_rfft_32; + break; + default: + /* Reporting argument error if fftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + return (status); +} + +/** + * @} end of RealFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_f32.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_f32.c new file mode 100644 index 0000000..fd02e41 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_f32.c @@ -0,0 +1,4273 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rfft_init_f32.c + * Description: RFFT & RIFFT Floating point initialisation function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/** + * @ingroup RealFFT + */ + +/** + * @addtogroup RealFFT_Table Real FFT Tables + * @{ + */ + +/** +* \par +* Generation of realCoefA array: +* \par +* n = 4096 +*
for (i = 0; i < n; i++)
+*  {
+*    pATable[2 * i] = 0.5 * (1.0 - sin (2 * PI / (double) (2 * n) * (double) i));
+*    pATable[2 * i + 1] = 0.5 * (-1.0 * cos (2 * PI / (double) (2 * n) * (double) i));
+*  } 
+*/ +static const float32_t realCoefA[8192] = { + 0.500000000000000f, -0.500000000000000f, 0.499616503715515f, -0.499999850988388f, + 0.499233007431030f, -0.499999403953552f, 0.498849511146545f, -0.499998688697815f, + 0.498466014862061f, -0.499997645616531f, 0.498082518577576f, -0.499996334314346f, + 0.497699022293091f, -0.499994695186615f, 0.497315555810928f, -0.499992787837982f, + 0.496932059526443f, -0.499990582466125f, 0.496548563241959f, -0.499988079071045f, + 0.496165096759796f, -0.499985307455063f, 0.495781600475311f, -0.499982208013535f, + 0.495398133993149f, -0.499978810548782f, 0.495014637708664f, -0.499975144863129f, + 0.494631171226501f, -0.499971181154251f, 0.494247704744339f, -0.499966919422150f, + 0.493864238262177f, -0.499962359666824f, 0.493480771780014f, -0.499957501888275f, + 0.493097305297852f, -0.499952346086502f, 0.492713838815689f, -0.499946922063828f, + 0.492330402135849f, -0.499941170215607f, 0.491946935653687f, -0.499935150146484f, + 0.491563498973846f, -0.499928832054138f, 0.491180062294006f, -0.499922215938568f, + 0.490796625614166f, -0.499915301799774f, 0.490413218736649f, -0.499908089637756f, + 0.490029782056808f, -0.499900579452515f, 0.489646375179291f, -0.499892801046371f, + 0.489262968301773f, -0.499884694814682f, 0.488879561424255f, -0.499876320362091f, + 0.488496154546738f, -0.499867647886276f, 0.488112777471542f, -0.499858677387238f, + 0.487729400396347f, -0.499849408864975f, 0.487346023321152f, -0.499839842319489f, + 0.486962646245956f, -0.499830007553101f, 0.486579269170761f, -0.499819844961166f, + 0.486195921897888f, -0.499809414148331f, 0.485812574625015f, -0.499798685312271f, + 0.485429257154465f, -0.499787658452988f, 0.485045909881592f, -0.499776333570480f, + 0.484662592411041f, -0.499764710664749f, 0.484279274940491f, -0.499752789735794f, + 0.483895987272263f, -0.499740600585938f, 0.483512699604034f, -0.499728083610535f, + 0.483129411935806f, -0.499715298414230f, 0.482746154069901f, -0.499702215194702f, + 0.482362866401672f, -0.499688833951950f, 0.481979638338089f, -0.499675154685974f, + 0.481596380472183f, -0.499661177396774f, 0.481213152408600f, -0.499646931886673f, + 0.480829954147339f, -0.499632388353348f, 0.480446726083755f, -0.499617516994476f, + 0.480063527822495f, -0.499602377414703f, 0.479680359363556f, -0.499586939811707f, + 0.479297190904617f, -0.499571204185486f, 0.478914022445679f, -0.499555170536041f, + 0.478530883789063f, -0.499538868665695f, 0.478147745132446f, -0.499522238969803f, + 0.477764606475830f, -0.499505341053009f, 0.477381497621536f, -0.499488145112991f, + 0.476998418569565f, -0.499470651149750f, 0.476615339517593f, -0.499452859163284f, + 0.476232260465622f, -0.499434769153595f, 0.475849211215973f, -0.499416410923004f, + 0.475466161966324f, -0.499397724866867f, 0.475083142518997f, -0.499378770589828f, + 0.474700123071671f, -0.499359518289566f, 0.474317133426666f, -0.499339967966080f, + 0.473934143781662f, -0.499320119619370f, 0.473551183938980f, -0.499299973249435f, + 0.473168224096298f, -0.499279528856277f, 0.472785294055939f, -0.499258816242218f, + 0.472402364015579f, -0.499237775802612f, 0.472019463777542f, -0.499216467142105f, + 0.471636593341827f, -0.499194860458374f, 0.471253722906113f, -0.499172955751419f, + 0.470870882272720f, -0.499150782823563f, 0.470488041639328f, -0.499128282070160f, + 0.470105201005936f, -0.499105513095856f, 0.469722419977188f, -0.499082416296005f, + 0.469339638948441f, -0.499059051275253f, 0.468956857919693f, -0.499035388231277f, + 0.468574106693268f, -0.499011427164078f, 0.468191385269165f, -0.498987197875977f, + 0.467808693647385f, -0.498962640762329f, 0.467426002025604f, -0.498937815427780f, + 0.467043310403824f, -0.498912662267685f, 0.466660678386688f, -0.498887240886688f, + 0.466278046369553f, -0.498861521482468f, 0.465895414352417f, -0.498835533857346f, + 0.465512841939926f, -0.498809218406677f, 0.465130269527435f, -0.498782604932785f, + 0.464747726917267f, -0.498755723237991f, 0.464365184307098f, -0.498728543519974f, + 0.463982671499252f, -0.498701065778732f, 0.463600188493729f, -0.498673290014267f, + 0.463217705488205f, -0.498645216226578f, 0.462835282087326f, -0.498616874217987f, + 0.462452858686447f, -0.498588204383850f, 0.462070435285568f, -0.498559266328812f, + 0.461688071489334f, -0.498530030250549f, 0.461305707693100f, -0.498500496149063f, + 0.460923373699188f, -0.498470664024353f, 0.460541069507599f, -0.498440563678741f, + 0.460158795118332f, -0.498410135507584f, 0.459776520729065f, -0.498379439115524f, + 0.459394276142120f, -0.498348444700241f, 0.459012061357498f, -0.498317152261734f, + 0.458629876375198f, -0.498285561800003f, 0.458247691392899f, -0.498253703117371f, + 0.457865566015244f, -0.498221516609192f, 0.457483440637589f, -0.498189061880112f, + 0.457101345062256f, -0.498156309127808f, 0.456719279289246f, -0.498123258352280f, + 0.456337243318558f, -0.498089909553528f, 0.455955207347870f, -0.498056292533875f, + 0.455573230981827f, -0.498022347688675f, 0.455191254615784f, -0.497988134622574f, + 0.454809308052063f, -0.497953623533249f, 0.454427421092987f, -0.497918814420700f, + 0.454045534133911f, -0.497883707284927f, 0.453663676977158f, -0.497848302125931f, + 0.453281819820404f, -0.497812628746033f, 0.452900022268295f, -0.497776657342911f, + 0.452518254518509f, -0.497740387916565f, 0.452136516571045f, -0.497703820466995f, + 0.451754778623581f, -0.497666954994202f, 0.451373100280762f, -0.497629791498184f, + 0.450991421937943f, -0.497592359781265f, 0.450609803199768f, -0.497554630041122f, + 0.450228184461594f, -0.497516602277756f, 0.449846625328064f, -0.497478276491165f, + 0.449465066194534f, -0.497439652681351f, 0.449083566665649f, -0.497400760650635f, + 0.448702067136765f, -0.497361570596695f, 0.448320597410202f, -0.497322082519531f, + 0.447939187288284f, -0.497282296419144f, 0.447557777166367f, -0.497242212295532f, + 0.447176426649094f, -0.497201830148697f, 0.446795076131821f, -0.497161179780960f, + 0.446413785219193f, -0.497120231389999f, 0.446032524108887f, -0.497078984975815f, + 0.445651292800903f, -0.497037440538406f, 0.445270061492920f, -0.496995598077774f, + 0.444888889789581f, -0.496953487396240f, 0.444507747888565f, -0.496911078691483f, + 0.444126635789871f, -0.496868371963501f, 0.443745553493500f, -0.496825367212296f, + 0.443364530801773f, -0.496782064437866f, 0.442983508110046f, -0.496738493442535f, + 0.442602545022964f, -0.496694594621658f, 0.442221581935883f, -0.496650427579880f, + 0.441840678453445f, -0.496605962514877f, 0.441459804773331f, -0.496561229228973f, + 0.441078960895538f, -0.496516168117523f, 0.440698176622391f, -0.496470838785172f, + 0.440317392349243f, -0.496425211429596f, 0.439936667680740f, -0.496379286050797f, + 0.439555943012238f, -0.496333062648773f, 0.439175277948380f, -0.496286571025848f, + 0.438794672489166f, -0.496239781379700f, 0.438414067029953f, -0.496192663908005f, + 0.438033521175385f, -0.496145308017731f, 0.437653005123138f, -0.496097624301910f, + 0.437272518873215f, -0.496049642562866f, 0.436892062425613f, -0.496001392602921f, + 0.436511665582657f, -0.495952844619751f, 0.436131268739700f, -0.495903998613358f, + 0.435750931501389f, -0.495854884386063f, 0.435370653867722f, -0.495805442333221f, + 0.434990376234055f, -0.495755732059479f, 0.434610158205032f, -0.495705723762512f, + 0.434229999780655f, -0.495655417442322f, 0.433849841356277f, -0.495604842901230f, + 0.433469742536545f, -0.495553970336914f, 0.433089673519135f, -0.495502769947052f, + 0.432709634304047f, -0.495451331138611f, 0.432329654693604f, -0.495399564504623f, + 0.431949704885483f, -0.495347499847412f, 0.431569814682007f, -0.495295166969299f, + 0.431189924478531f, -0.495242536067963f, 0.430810123682022f, -0.495189607143402f, + 0.430430322885513f, -0.495136409997940f, 0.430050581693649f, -0.495082914829254f, + 0.429670870304108f, -0.495029091835022f, 0.429291218519211f, -0.494975030422211f, + 0.428911596536636f, -0.494920641183853f, 0.428532034158707f, -0.494865983724594f, + 0.428152471780777f, -0.494810998439789f, 0.427772998809814f, -0.494755744934082f, + 0.427393525838852f, -0.494700223207474f, 0.427014142274857f, -0.494644373655319f, + 0.426634758710861f, -0.494588255882263f, 0.426255434751511f, -0.494531840085983f, + 0.425876170396805f, -0.494475126266479f, 0.425496935844421f, -0.494418144226074f, + 0.425117731094360f, -0.494360834360123f, 0.424738585948944f, -0.494303256273270f, + 0.424359470605850f, -0.494245409965515f, 0.423980414867401f, -0.494187235832214f, + 0.423601418733597f, -0.494128793478012f, 0.423222452402115f, -0.494070053100586f, + 0.422843515872955f, -0.494011014699936f, 0.422464638948441f, -0.493951678276062f, + 0.422085791826248f, -0.493892073631287f, 0.421707004308701f, -0.493832170963287f, + 0.421328276395798f, -0.493771970272064f, 0.420949578285217f, -0.493711471557617f, + 0.420570939779282f, -0.493650704622269f, 0.420192331075668f, -0.493589639663696f, + 0.419813781976700f, -0.493528276681900f, 0.419435262680054f, -0.493466645479202f, + 0.419056802988052f, -0.493404686450958f, 0.418678402900696f, -0.493342459201813f, + 0.418300032615662f, -0.493279963731766f, 0.417921721935272f, -0.493217140436172f, + 0.417543441057205f, -0.493154048919678f, 0.417165219783783f, -0.493090659379959f, + 0.416787058115005f, -0.493026971817017f, 0.416408926248550f, -0.492963016033173f, + 0.416030853986740f, -0.492898762226105f, 0.415652841329575f, -0.492834210395813f, + 0.415274858474731f, -0.492769360542297f, 0.414896935224533f, -0.492704242467880f, + 0.414519041776657f, -0.492638826370239f, 0.414141237735748f, -0.492573112249374f, + 0.413763463497162f, -0.492507129907608f, 0.413385748863220f, -0.492440819740295f, + 0.413008064031601f, -0.492374241352081f, 0.412630438804626f, -0.492307394742966f, + 0.412252873182297f, -0.492240220308304f, 0.411875367164612f, -0.492172777652740f, + 0.411497890949249f, -0.492105036973953f, 0.411120474338531f, -0.492037028074265f, + 0.410743117332459f, -0.491968721151352f, 0.410365819931030f, -0.491900116205215f, + 0.409988552331924f, -0.491831213235855f, 0.409611344337463f, -0.491762012243271f, + 0.409234195947647f, -0.491692543029785f, 0.408857107162476f, -0.491622805595398f, + 0.408480048179626f, -0.491552740335464f, 0.408103078603745f, -0.491482406854630f, + 0.407726138830185f, -0.491411775350571f, 0.407349258661270f, -0.491340845823288f, + 0.406972438097000f, -0.491269648075104f, 0.406595647335052f, -0.491198152303696f, + 0.406218945980072f, -0.491126358509064f, 0.405842274427414f, -0.491054296493530f, + 0.405465662479401f, -0.490981936454773f, 0.405089110136032f, -0.490909278392792f, + 0.404712617397308f, -0.490836352109909f, 0.404336184263229f, -0.490763127803802f, + 0.403959810733795f, -0.490689605474472f, 0.403583467006683f, -0.490615785121918f, + 0.403207212686539f, -0.490541696548462f, 0.402830988168716f, -0.490467309951782f, + 0.402454853057861f, -0.490392625331879f, 0.402078747749329f, -0.490317672491074f, + 0.401702702045441f, -0.490242421627045f, 0.401326715946198f, -0.490166902542114f, + 0.400950789451599f, -0.490091055631638f, 0.400574922561646f, -0.490014940500259f, + 0.400199115276337f, -0.489938557147980f, 0.399823367595673f, -0.489861875772476f, + 0.399447679519653f, -0.489784896373749f, 0.399072051048279f, -0.489707618951797f, + 0.398696482181549f, -0.489630073308945f, 0.398320972919464f, -0.489552229642868f, + 0.397945523262024f, -0.489474087953568f, 0.397570133209229f, -0.489395678043365f, + 0.397194802761078f, -0.489316970109940f, 0.396819531917572f, -0.489237964153290f, + 0.396444320678711f, -0.489158689975739f, 0.396069169044495f, -0.489079117774963f, + 0.395694077014923f, -0.488999247550964f, 0.395319044589996f, -0.488919109106064f, + 0.394944071769714f, -0.488838672637939f, 0.394569188356400f, -0.488757967948914f, + 0.394194334745407f, -0.488676935434341f, 0.393819570541382f, -0.488595664501190f, + 0.393444836139679f, -0.488514065742493f, 0.393070191144943f, -0.488432198762894f, + 0.392695605754852f, -0.488350033760071f, 0.392321079969406f, -0.488267600536346f, + 0.391946613788605f, -0.488184869289398f, 0.391572207212448f, -0.488101840019226f, + 0.391197860240936f, -0.488018542528152f, 0.390823602676392f, -0.487934947013855f, + 0.390449374914169f, -0.487851053476334f, 0.390075236558914f, -0.487766891717911f, + 0.389701157808304f, -0.487682431936264f, 0.389327138662338f, -0.487597703933716f, + 0.388953179121017f, -0.487512677907944f, 0.388579308986664f, -0.487427353858948f, + 0.388205498456955f, -0.487341761589050f, 0.387831717729568f, -0.487255871295929f, + 0.387458056211472f, -0.487169682979584f, 0.387084424495697f, -0.487083226442337f, + 0.386710882186890f, -0.486996471881866f, 0.386337369680405f, -0.486909449100494f, + 0.385963946580887f, -0.486822128295898f, 0.385590612888336f, -0.486734509468079f, + 0.385217308998108f, -0.486646622419357f, 0.384844094514847f, -0.486558437347412f, + 0.384470939636230f, -0.486469984054565f, 0.384097874164581f, -0.486381232738495f, + 0.383724838495255f, -0.486292183399200f, 0.383351892232895f, -0.486202865839005f, + 0.382979035377502f, -0.486113250255585f, 0.382606208324432f, -0.486023366451263f, + 0.382233470678329f, -0.485933154821396f, 0.381860792636871f, -0.485842704772949f, + 0.381488204002380f, -0.485751956701279f, 0.381115674972534f, -0.485660910606384f, + 0.380743205547333f, -0.485569566488266f, 0.380370795726776f, -0.485477954149246f, + 0.379998475313187f, -0.485386073589325f, 0.379626244306564f, -0.485293895006180f, + 0.379254043102264f, -0.485201418399811f, 0.378881961107254f, -0.485108673572540f, + 0.378509908914566f, -0.485015630722046f, 0.378137946128845f, -0.484922289848328f, + 0.377766042947769f, -0.484828680753708f, 0.377394229173660f, -0.484734803438187f, + 0.377022475004196f, -0.484640628099442f, 0.376650810241699f, -0.484546154737473f, + 0.376279205083847f, -0.484451413154602f, 0.375907659530640f, -0.484356373548508f, + 0.375536203384399f, -0.484261035919189f, 0.375164806842804f, -0.484165430068970f, + 0.374793499708176f, -0.484069555997849f, 0.374422252178192f, -0.483973383903503f, + 0.374051094055176f, -0.483876913785934f, 0.373679995536804f, -0.483780175447464f, + 0.373308986425400f, -0.483683139085770f, 0.372938036918640f, -0.483585834503174f, + 0.372567176818848f, -0.483488231897354f, 0.372196376323700f, -0.483390361070633f, + 0.371825665235519f, -0.483292192220688f, 0.371455013751984f, -0.483193725347519f, + 0.371084451675415f, -0.483094990253448f, 0.370713949203491f, -0.482995986938477f, + 0.370343536138535f, -0.482896685600281f, 0.369973212480545f, -0.482797086238861f, + 0.369602948427200f, -0.482697218656540f, 0.369232743978500f, -0.482597053050995f, + 0.368862658739090f, -0.482496619224548f, 0.368492603302002f, -0.482395917177200f, + 0.368122667074203f, -0.482294887304306f, 0.367752790451050f, -0.482193619012833f, + 0.367382973432541f, -0.482092022895813f, 0.367013275623322f, -0.481990188360214f, + 0.366643607616425f, -0.481888025999069f, 0.366274058818817f, -0.481785595417023f, + 0.365904569625854f, -0.481682896614075f, 0.365535169839859f, -0.481579899787903f, + 0.365165829658508f, -0.481476634740829f, 0.364796578884125f, -0.481373071670532f, + 0.364427417516708f, -0.481269240379334f, 0.364058345556259f, -0.481165111064911f, + 0.363689333200455f, -0.481060713529587f, 0.363320380449295f, -0.480956017971039f, + 0.362951546907425f, -0.480851024389267f, 0.362582772970200f, -0.480745792388916f, + 0.362214088439941f, -0.480640232563019f, 0.361845493316650f, -0.480534434318542f, + 0.361476957798004f, -0.480428308248520f, 0.361108511686325f, -0.480321943759918f, + 0.360740154981613f, -0.480215251445770f, 0.360371887683868f, -0.480108320713043f, + 0.360003679990768f, -0.480001062154770f, 0.359635561704636f, -0.479893565177917f, + 0.359267532825470f, -0.479785770177841f, 0.358899593353271f, -0.479677677154541f, + 0.358531713485718f, -0.479569315910339f, 0.358163923025131f, -0.479460656642914f, + 0.357796221971512f, -0.479351729154587f, 0.357428610324860f, -0.479242533445358f, + 0.357061088085175f, -0.479133039712906f, 0.356693625450134f, -0.479023247957230f, + 0.356326282024384f, -0.478913217782974f, 0.355958998203278f, -0.478802859783173f, + 0.355591803789139f, -0.478692263364792f, 0.355224698781967f, -0.478581339120865f, + 0.354857653379440f, -0.478470176458359f, 0.354490727186203f, -0.478358715772629f, + 0.354123860597610f, -0.478246957063675f, 0.353757113218308f, -0.478134930133820f, + 0.353390425443649f, -0.478022634983063f, 0.353023827075958f, -0.477910041809082f, + 0.352657318115234f, -0.477797180414200f, 0.352290898561478f, -0.477684020996094f, + 0.351924568414688f, -0.477570593357086f, 0.351558297872543f, -0.477456867694855f, + 0.351192146539688f, -0.477342873811722f, 0.350826084613800f, -0.477228611707687f, + 0.350460082292557f, -0.477114051580429f, 0.350094199180603f, -0.476999223232269f, + 0.349728375673294f, -0.476884096860886f, 0.349362671375275f, -0.476768702268600f, + 0.348997026681900f, -0.476653009653091f, 0.348631471395493f, -0.476537048816681f, + 0.348266035318375f, -0.476420819759369f, 0.347900658845901f, -0.476304292678833f, + 0.347535371780396f, -0.476187497377396f, 0.347170203924179f, -0.476070433855057f, + 0.346805095672607f, -0.475953072309494f, 0.346440106630325f, -0.475835442543030f, + 0.346075177192688f, -0.475717514753342f, 0.345710366964340f, -0.475599318742752f, + 0.345345616340637f, -0.475480824708939f, 0.344980984926224f, -0.475362062454224f, + 0.344616413116455f, -0.475243031978607f, 0.344251960515976f, -0.475123733282089f, + 0.343887597322464f, -0.475004136562347f, 0.343523323535919f, -0.474884241819382f, + 0.343159139156342f, -0.474764078855515f, 0.342795044183731f, -0.474643647670746f, + 0.342431038618088f, -0.474522948265076f, 0.342067122459412f, -0.474401950836182f, + 0.341703325510025f, -0.474280685186386f, 0.341339588165283f, -0.474159121513367f, + 0.340975970029831f, -0.474037289619446f, 0.340612411499023f, -0.473915189504623f, + 0.340248972177505f, -0.473792791366577f, 0.339885622262955f, -0.473670125007629f, + 0.339522391557693f, -0.473547190427780f, 0.339159220457077f, -0.473423957824707f, + 0.338796168565750f, -0.473300457000732f, 0.338433176279068f, -0.473176687955856f, + 0.338070303201675f, -0.473052620887756f, 0.337707549333572f, -0.472928285598755f, + 0.337344855070114f, -0.472803652286530f, 0.336982280015945f, -0.472678780555725f, + 0.336619764566422f, -0.472553610801697f, 0.336257368326187f, -0.472428143024445f, + 0.335895091295242f, -0.472302407026291f, 0.335532873868942f, -0.472176402807236f, + 0.335170775651932f, -0.472050130367279f, 0.334808766841888f, -0.471923559904099f, + 0.334446847438812f, -0.471796721220016f, 0.334085017442703f, -0.471669614315033f, + 0.333723306655884f, -0.471542209386826f, 0.333361685276031f, -0.471414536237717f, + 0.333000183105469f, -0.471286594867706f, 0.332638740539551f, -0.471158385276794f, + 0.332277417182922f, -0.471029877662659f, 0.331916213035584f, -0.470901101827621f, + 0.331555068492889f, -0.470772027969360f, 0.331194043159485f, -0.470642685890198f, + 0.330833107233047f, -0.470513075590134f, 0.330472290515900f, -0.470383197069168f, + 0.330111563205719f, -0.470253020524979f, 0.329750925302505f, -0.470122605562210f, + 0.329390406608582f, -0.469991862773895f, 0.329029977321625f, -0.469860881567001f, + 0.328669637441635f, -0.469729602336884f, 0.328309416770935f, -0.469598054885864f, + 0.327949285507202f, -0.469466239213943f, 0.327589273452759f, -0.469334155321121f, + 0.327229350805283f, -0.469201773405075f, 0.326869517564774f, -0.469069123268127f, + 0.326509803533554f, -0.468936175107956f, 0.326150178909302f, -0.468802988529205f, + 0.325790673494339f, -0.468669503927231f, 0.325431257486343f, -0.468535751104355f, + 0.325071930885315f, -0.468401730060577f, 0.324712723493576f, -0.468267410993576f, + 0.324353635311127f, -0.468132823705673f, 0.323994606733322f, -0.467997968196869f, + 0.323635727167130f, -0.467862844467163f, 0.323276937007904f, -0.467727422714233f, + 0.322918236255646f, -0.467591762542725f, 0.322559654712677f, -0.467455804347992f, + 0.322201162576675f, -0.467319577932358f, 0.321842789649963f, -0.467183053493500f, + 0.321484506130219f, -0.467046260833740f, 0.321126341819763f, -0.466909229755402f, + 0.320768296718597f, -0.466771900653839f, 0.320410341024399f, -0.466634273529053f, + 0.320052474737167f, -0.466496407985687f, 0.319694727659225f, -0.466358244419098f, + 0.319337099790573f, -0.466219812631607f, 0.318979561328888f, -0.466081112623215f, + 0.318622142076492f, -0.465942144393921f, 0.318264812231064f, -0.465802878141403f, + 0.317907601594925f, -0.465663343667984f, 0.317550510168076f, -0.465523540973663f, + 0.317193508148193f, -0.465383470058441f, 0.316836595535278f, -0.465243130922318f, + 0.316479831933975f, -0.465102523565292f, 0.316123157739639f, -0.464961618185043f, + 0.315766572952271f, -0.464820444583893f, 0.315410137176514f, -0.464679002761841f, + 0.315053790807724f, -0.464537292718887f, 0.314697533845901f, -0.464395314455032f, + 0.314341396093369f, -0.464253038167953f, 0.313985377550125f, -0.464110493659973f, + 0.313629478216171f, -0.463967710733414f, 0.313273668289185f, -0.463824629783630f, + 0.312917977571487f, -0.463681250810623f, 0.312562376260757f, -0.463537633419037f, + 0.312206923961639f, -0.463393747806549f, 0.311851561069489f, -0.463249564170837f, + 0.311496287584305f, -0.463105112314224f, 0.311141163110733f, -0.462960392236710f, + 0.310786128044128f, -0.462815403938293f, 0.310431212186813f, -0.462670147418976f, + 0.310076385736465f, -0.462524622678757f, 0.309721708297729f, -0.462378799915314f, + 0.309367120265961f, -0.462232738733292f, 0.309012651443481f, -0.462086379528046f, + 0.308658272027969f, -0.461939752101898f, 0.308304041624069f, -0.461792886257172f, + 0.307949900627136f, -0.461645722389221f, 0.307595878839493f, -0.461498260498047f, + 0.307241976261139f, -0.461350560188293f, 0.306888192892075f, -0.461202591657639f, + 0.306534498929977f, -0.461054325103760f, 0.306180924177170f, -0.460905820131302f, + 0.305827468633652f, -0.460757017135620f, 0.305474132299423f, -0.460607945919037f, + 0.305120915174484f, -0.460458606481552f, 0.304767817258835f, -0.460309028625488f, + 0.304414808750153f, -0.460159152746201f, 0.304061919450760f, -0.460008978843689f, + 0.303709149360657f, -0.459858566522598f, 0.303356528282166f, -0.459707885980606f, + 0.303003966808319f, -0.459556937217712f, 0.302651554346085f, -0.459405690431595f, + 0.302299261093140f, -0.459254205226898f, 0.301947087049484f, -0.459102421998978f, + 0.301595002412796f, -0.458950400352478f, 0.301243066787720f, -0.458798080682755f, + 0.300891220569611f, -0.458645492792130f, 0.300539493560791f, -0.458492636680603f, + 0.300187885761261f, -0.458339542150497f, 0.299836426973343f, -0.458186149597168f, + 0.299485057592392f, -0.458032488822937f, 0.299133807420731f, -0.457878559827805f, + 0.298782676458359f, -0.457724362611771f, 0.298431664705276f, -0.457569897174835f, + 0.298080772161484f, -0.457415163516998f, 0.297729998826981f, -0.457260161638260f, + 0.297379344701767f, -0.457104891538620f, 0.297028809785843f, -0.456949323415756f, + 0.296678394079208f, -0.456793516874313f, 0.296328097581863f, -0.456637442111969f, + 0.295977920293808f, -0.456481099128723f, 0.295627862215042f, -0.456324487924576f, + 0.295277923345566f, -0.456167578697205f, 0.294928103685379f, -0.456010431051254f, + 0.294578403234482f, -0.455853015184402f, 0.294228851795197f, -0.455695331096649f, + 0.293879389762878f, -0.455537378787994f, 0.293530046939850f, -0.455379128456116f, + 0.293180853128433f, -0.455220639705658f, 0.292831748723984f, -0.455061882734299f, + 0.292482793331146f, -0.454902857542038f, 0.292133957147598f, -0.454743564128876f, + 0.291785210371017f, -0.454584002494812f, 0.291436612606049f, -0.454424172639847f, + 0.291088134050369f, -0.454264044761658f, 0.290739774703979f, -0.454103678464890f, + 0.290391564369202f, -0.453943043947220f, 0.290043443441391f, -0.453782171010971f, + 0.289695471525192f, -0.453621000051498f, 0.289347589015961f, -0.453459560871124f, + 0.288999855518341f, -0.453297853469849f, 0.288652241230011f, -0.453135877847672f, + 0.288304775953293f, -0.452973634004593f, 0.287957400083542f, -0.452811151742935f, + 0.287610173225403f, -0.452648371458054f, 0.287263035774231f, -0.452485352754593f, + 0.286916047334671f, -0.452322036027908f, 0.286569178104401f, -0.452158480882645f, + 0.286222457885742f, -0.451994657516479f, 0.285875827074051f, -0.451830536127090f, + 0.285529345273972f, -0.451666176319122f, 0.285182982683182f, -0.451501548290253f, + 0.284836769104004f, -0.451336652040482f, 0.284490644931793f, -0.451171487569809f, + 0.284144669771194f, -0.451006084680557f, 0.283798813819885f, -0.450840383768082f, + 0.283453077077866f, -0.450674414634705f, 0.283107489347458f, -0.450508207082748f, + 0.282762020826340f, -0.450341701507568f, 0.282416671514511f, -0.450174957513809f, + 0.282071471214294f, -0.450007945299149f, 0.281726360321045f, -0.449840664863586f, + 0.281381398439407f, -0.449673116207123f, 0.281036585569382f, -0.449505299329758f, + 0.280691891908646f, -0.449337244033813f, 0.280347317457199f, -0.449168890714645f, + 0.280002862215042f, -0.449000298976898f, 0.279658555984497f, -0.448831409215927f, + 0.279314368963242f, -0.448662281036377f, 0.278970301151276f, -0.448492884635925f, + 0.278626382350922f, -0.448323249816895f, 0.278282582759857f, -0.448153316974640f, + 0.277938932180405f, -0.447983115911484f, 0.277595400810242f, -0.447812676429749f, + 0.277251988649368f, -0.447641968727112f, 0.276908725500107f, -0.447470992803574f, + 0.276565581560135f, -0.447299748659134f, 0.276222556829453f, -0.447128236293793f, + 0.275879681110382f, -0.446956485509872f, 0.275536954402924f, -0.446784436702728f, + 0.275194346904755f, -0.446612149477005f, 0.274851858615875f, -0.446439594030380f, + 0.274509519338608f, -0.446266770362854f, 0.274167299270630f, -0.446093708276749f, + 0.273825198411942f, -0.445920348167419f, 0.273483246564865f, -0.445746749639511f, + 0.273141443729401f, -0.445572882890701f, 0.272799760103226f, -0.445398747920990f, + 0.272458195686340f, -0.445224374532700f, 0.272116780281067f, -0.445049703121185f, + 0.271775513887405f, -0.444874793291092f, 0.271434366703033f, -0.444699615240097f, + 0.271093338727951f, -0.444524168968201f, 0.270752459764481f, -0.444348484277725f, + 0.270411729812622f, -0.444172531366348f, 0.270071119070053f, -0.443996280431747f, + 0.269730657339096f, -0.443819820880890f, 0.269390314817429f, -0.443643063306808f, + 0.269050091505051f, -0.443466067314148f, 0.268710047006607f, -0.443288803100586f, + 0.268370121717453f, -0.443111270666122f, 0.268030315637589f, -0.442933470010757f, + 0.267690658569336f, -0.442755430936813f, 0.267351150512695f, -0.442577123641968f, + 0.267011761665344f, -0.442398548126221f, 0.266672492027283f, -0.442219734191895f, + 0.266333401203156f, -0.442040622234344f, 0.265994429588318f, -0.441861271858215f, + 0.265655577182770f, -0.441681683063507f, 0.265316903591156f, -0.441501796245575f, + 0.264978319406509f, -0.441321671009064f, 0.264639914035797f, -0.441141277551651f, + 0.264301627874374f, -0.440960645675659f, 0.263963490724564f, -0.440779715776443f, + 0.263625472784042f, -0.440598547458649f, 0.263287603855133f, -0.440417140722275f, + 0.262949883937836f, -0.440235435962677f, 0.262612313032150f, -0.440053492784500f, + 0.262274861335754f, -0.439871311187744f, 0.261937558650970f, -0.439688831567764f, + 0.261600375175476f, -0.439506113529205f, 0.261263370513916f, -0.439323127269745f, + 0.260926485061646f, -0.439139902591705f, 0.260589718818665f, -0.438956409692764f, + 0.260253131389618f, -0.438772648572922f, 0.259916663169861f, -0.438588619232178f, + 0.259580343961716f, -0.438404351472855f, 0.259244143962860f, -0.438219845294952f, + 0.258908122777939f, -0.438035041093826f, 0.258572220802307f, -0.437849998474121f, + 0.258236467838287f, -0.437664687633514f, 0.257900834083557f, -0.437479138374329f, + 0.257565379142761f, -0.437293320894241f, 0.257230043411255f, -0.437107264995575f, + 0.256894856691360f, -0.436920911073685f, 0.256559818983078f, -0.436734348535538f, + 0.256224930286407f, -0.436547487974167f, 0.255890160799026f, -0.436360388994217f, + 0.255555540323257f, -0.436173021793365f, 0.255221068859100f, -0.435985416173935f, + 0.254886746406555f, -0.435797542333603f, 0.254552572965622f, -0.435609430074692f, + 0.254218548536301f, -0.435421019792557f, 0.253884643316269f, -0.435232400894165f, + 0.253550916910172f, -0.435043483972549f, 0.253217309713364f, -0.434854328632355f, + 0.252883851528168f, -0.434664934873581f, 0.252550542354584f, -0.434475272893906f, + 0.252217382192612f, -0.434285342693329f, 0.251884341239929f, -0.434095174074173f, + 0.251551479101181f, -0.433904737234116f, 0.251218736171722f, -0.433714061975479f, + 0.250886172056198f, -0.433523118495941f, 0.250553727149963f, -0.433331936597824f, + 0.250221431255341f, -0.433140486478806f, 0.249889299273491f, -0.432948768138886f, + 0.249557301402092f, -0.432756811380386f, 0.249225467443466f, -0.432564586400986f, + 0.248893767595291f, -0.432372123003006f, 0.248562216758728f, -0.432179391384125f, + 0.248230814933777f, -0.431986421346664f, 0.247899547219276f, -0.431793183088303f, + 0.247568443417549f, -0.431599706411362f, 0.247237488627434f, -0.431405961513519f, + 0.246906682848930f, -0.431211978197098f, 0.246576011180878f, -0.431017726659775f, + 0.246245503425598f, -0.430823236703873f, 0.245915144681931f, -0.430628478527069f, + 0.245584934949875f, -0.430433481931686f, 0.245254859328270f, -0.430238217115402f, + 0.244924947619438f, -0.430042684078217f, 0.244595184922218f, -0.429846942424774f, + 0.244265571236610f, -0.429650902748108f, 0.243936106562614f, -0.429454624652863f, + 0.243606805801392f, -0.429258108139038f, 0.243277639150620f, -0.429061323404312f, + 0.242948621511459f, -0.428864300251007f, 0.242619767785072f, -0.428667008876801f, + 0.242291063070297f, -0.428469479084015f, 0.241962507367134f, -0.428271710872650f, + 0.241634100675583f, -0.428073674440384f, 0.241305842995644f, -0.427875369787216f, + 0.240977749228477f, -0.427676826715469f, 0.240649804472923f, -0.427478045225143f, + 0.240322008728981f, -0.427278995513916f, 0.239994361996651f, -0.427079707384110f, + 0.239666879177094f, -0.426880151033401f, 0.239339530467987f, -0.426680356264114f, + 0.239012360572815f, -0.426480293273926f, 0.238685324788094f, -0.426279991865158f, + 0.238358452916145f, -0.426079452037811f, 0.238031730055809f, -0.425878643989563f, + 0.237705156207085f, -0.425677597522736f, 0.237378746271133f, -0.425476282835007f, + 0.237052485346794f, -0.425274729728699f, 0.236726388335228f, -0.425072938203812f, + 0.236400425434113f, -0.424870878458023f, 0.236074641346931f, -0.424668580293655f, + 0.235749006271362f, -0.424466013908386f, 0.235423520207405f, -0.424263238906860f, + 0.235098183155060f, -0.424060165882111f, 0.234773010015488f, -0.423856884241104f, + 0.234448000788689f, -0.423653304576874f, 0.234123140573502f, -0.423449516296387f, + 0.233798429369926f, -0.423245459794998f, 0.233473882079124f, -0.423041164875031f, + 0.233149498701096f, -0.422836631536484f, 0.232825264334679f, -0.422631829977036f, + 0.232501193881035f, -0.422426789999008f, 0.232177272439003f, -0.422221481800079f, + 0.231853514909744f, -0.422015935182571f, 0.231529906392097f, -0.421810150146484f, + 0.231206461787224f, -0.421604126691818f, 0.230883181095123f, -0.421397835016251f, + 0.230560049414635f, -0.421191304922104f, 0.230237081646919f, -0.420984506607056f, + 0.229914262890816f, -0.420777499675751f, 0.229591608047485f, -0.420570224523544f, + 0.229269117116928f, -0.420362681150436f, 0.228946775197983f, -0.420154929161072f, + 0.228624612092972f, -0.419946908950806f, 0.228302597999573f, -0.419738620519638f, + 0.227980732917786f, -0.419530123472214f, 0.227659046649933f, -0.419321358203888f, + 0.227337509393692f, -0.419112354516983f, 0.227016136050224f, -0.418903112411499f, + 0.226694911718369f, -0.418693602085114f, 0.226373866200447f, -0.418483853340149f, + 0.226052969694138f, -0.418273866176605f, 0.225732237100601f, -0.418063640594482f, + 0.225411668419838f, -0.417853146791458f, 0.225091263651848f, -0.417642414569855f, + 0.224771007895470f, -0.417431443929672f, 0.224450930953026f, -0.417220205068588f, + 0.224131003022194f, -0.417008757591248f, 0.223811239004135f, -0.416797041893005f, + 0.223491653800011f, -0.416585087776184f, 0.223172217607498f, -0.416372895240784f, + 0.222852945327759f, -0.416160434484482f, 0.222533836960793f, -0.415947735309601f, + 0.222214877605438f, -0.415734797716141f, 0.221896097064018f, -0.415521621704102f, + 0.221577480435371f, -0.415308207273483f, 0.221259027719498f, -0.415094524621964f, + 0.220940738916397f, -0.414880603551865f, 0.220622614026070f, -0.414666473865509f, + 0.220304638147354f, -0.414452046155930f, 0.219986841082573f, -0.414237409830093f, + 0.219669207930565f, -0.414022535085678f, 0.219351738691330f, -0.413807392120361f, + 0.219034433364868f, -0.413592010736465f, 0.218717306852341f, -0.413376390933990f, + 0.218400329351425f, -0.413160532712936f, 0.218083515763283f, -0.412944436073303f, + 0.217766880989075f, -0.412728071212769f, 0.217450410127640f, -0.412511497735977f, + 0.217134088277817f, -0.412294656038284f, 0.216817945241928f, -0.412077575922012f, + 0.216501981019974f, -0.411860257387161f, 0.216186165809631f, -0.411642700433731f, + 0.215870529413223f, -0.411424905061722f, 0.215555042028427f, -0.411206841468811f, + 0.215239733457565f, -0.410988569259644f, 0.214924603700638f, -0.410770028829575f, + 0.214609622955322f, -0.410551249980927f, 0.214294821023941f, -0.410332232713699f, + 0.213980183005333f, -0.410112977027893f, 0.213665723800659f, -0.409893482923508f, + 0.213351413607597f, -0.409673750400543f, 0.213037282228470f, -0.409453779459000f, + 0.212723329663277f, -0.409233570098877f, 0.212409526109695f, -0.409013092517853f, + 0.212095901370049f, -0.408792406320572f, 0.211782455444336f, -0.408571451902390f, + 0.211469158530235f, -0.408350288867950f, 0.211156040430069f, -0.408128857612610f, + 0.210843101143837f, -0.407907217741013f, 0.210530325770378f, -0.407685309648514f, + 0.210217714309692f, -0.407463163137436f, 0.209905281662941f, -0.407240778207779f, + 0.209593027830124f, -0.407018154859543f, 0.209280923008919f, -0.406795293092728f, + 0.208969011902809f, -0.406572192907333f, 0.208657249808311f, -0.406348884105682f, + 0.208345666527748f, -0.406125307083130f, 0.208034262061119f, -0.405901491641998f, + 0.207723021507263f, -0.405677437782288f, 0.207411959767342f, -0.405453115701675f, + 0.207101076841354f, -0.405228585004807f, 0.206790357828140f, -0.405003815889359f, + 0.206479802727699f, -0.404778808355331f, 0.206169426441193f, -0.404553562402725f, + 0.205859228968620f, -0.404328078031540f, 0.205549195408821f, -0.404102355241776f, + 0.205239340662956f, -0.403876423835754f, 0.204929664731026f, -0.403650224208832f, + 0.204620152711868f, -0.403423786163330f, 0.204310819506645f, -0.403197109699249f, + 0.204001650214195f, -0.402970194816589f, 0.203692659735680f, -0.402743041515350f, + 0.203383848071098f, -0.402515679597855f, 0.203075215220451f, -0.402288049459457f, + 0.202766746282578f, -0.402060180902481f, 0.202458456158638f, -0.401832103729248f, + 0.202150344848633f, -0.401603758335114f, 0.201842412352562f, -0.401375204324722f, + 0.201534643769264f, -0.401146411895752f, 0.201227053999901f, -0.400917351245880f, + 0.200919643044472f, -0.400688081979752f, 0.200612410902977f, -0.400458574295044f, + 0.200305357575417f, -0.400228828191757f, 0.199998468160629f, -0.399998843669891f, + 0.199691757559776f, -0.399768620729446f, 0.199385225772858f, -0.399538189172745f, + 0.199078872799873f, -0.399307489395142f, 0.198772698640823f, -0.399076581001282f, + 0.198466703295708f, -0.398845434188843f, 0.198160871863365f, -0.398614019155502f, + 0.197855234146118f, -0.398382395505905f, 0.197549775242805f, -0.398150533437729f, + 0.197244480252266f, -0.397918462753296f, 0.196939364075661f, -0.397686123847961f, + 0.196634441614151f, -0.397453576326370f, 0.196329683065414f, -0.397220760583878f, + 0.196025103330612f, -0.396987736225128f, 0.195720717310905f, -0.396754473447800f, + 0.195416495203972f, -0.396520972251892f, 0.195112451910973f, -0.396287262439728f, + 0.194808602333069f, -0.396053284406662f, 0.194504916667938f, -0.395819097757339f, + 0.194201424717903f, -0.395584672689438f, 0.193898096680641f, -0.395350009202957f, + 0.193594962358475f, -0.395115107297897f, 0.193292006850243f, -0.394879996776581f, + 0.192989215254784f, -0.394644618034363f, 0.192686617374420f, -0.394409030675888f, + 0.192384198307991f, -0.394173204898834f, 0.192081972956657f, -0.393937170505524f, + 0.191779911518097f, -0.393700867891312f, 0.191478043794632f, -0.393464356660843f, + 0.191176339983940f, -0.393227607011795f, 0.190874829888344f, -0.392990618944168f, + 0.190573498606682f, -0.392753422260284f, 0.190272361040115f, -0.392515957355499f, + 0.189971387386322f, -0.392278283834457f, 0.189670607447624f, -0.392040401697159f, + 0.189370006322861f, -0.391802251338959f, 0.189069598913193f, -0.391563892364502f, + 0.188769355416298f, -0.391325294971466f, 0.188469305634499f, -0.391086459159851f, + 0.188169434666634f, -0.390847414731979f, 0.187869757413864f, -0.390608131885529f, + 0.187570258975029f, -0.390368610620499f, 0.187270939350128f, -0.390128880739212f, + 0.186971798539162f, -0.389888882637024f, 0.186672851443291f, -0.389648675918579f, + 0.186374098062515f, -0.389408260583878f, 0.186075508594513f, -0.389167606830597f, + 0.185777112841606f, -0.388926714658737f, 0.185478910803795f, -0.388685584068298f, + 0.185180887579918f, -0.388444244861603f, 0.184883043169975f, -0.388202667236328f, + 0.184585392475128f, -0.387960851192474f, 0.184287920594215f, -0.387718826532364f, + 0.183990627527237f, -0.387476563453674f, 0.183693528175354f, -0.387234061956406f, + 0.183396622538567f, -0.386991351842880f, 0.183099895715714f, -0.386748403310776f, + 0.182803362607956f, -0.386505216360092f, 0.182507008314133f, -0.386261820793152f, + 0.182210832834244f, -0.386018186807632f, 0.181914865970612f, -0.385774344205856f, + 0.181619063019753f, -0.385530263185501f, 0.181323468685150f, -0.385285943746567f, + 0.181028053164482f, -0.385041415691376f, 0.180732816457748f, -0.384796649217606f, + 0.180437773466110f, -0.384551674127579f, 0.180142924189568f, -0.384306460618973f, + 0.179848253726959f, -0.384061008691788f, 0.179553776979446f, -0.383815348148346f, + 0.179259493947029f, -0.383569449186325f, 0.178965389728546f, -0.383323341608047f, + 0.178671479225159f, -0.383076995611191f, 0.178377762436867f, -0.382830440998077f, + 0.178084224462509f, -0.382583618164063f, 0.177790880203247f, -0.382336616516113f, + 0.177497729659081f, -0.382089376449585f, 0.177204772830009f, -0.381841897964478f, + 0.176911994814873f, -0.381594210863113f, 0.176619410514832f, -0.381346285343170f, + 0.176327019929886f, -0.381098151206970f, 0.176034808158875f, -0.380849778652191f, + 0.175742805004120f, -0.380601197481155f, 0.175450980663300f, -0.380352377891541f, + 0.175159350037575f, -0.380103349685669f, 0.174867913126946f, -0.379854083061218f, + 0.174576655030251f, -0.379604607820511f, 0.174285605549812f, -0.379354894161224f, + 0.173994734883308f, -0.379104942083359f, 0.173704057931900f, -0.378854811191559f, + 0.173413574695587f, -0.378604412078857f, 0.173123285174370f, -0.378353834152222f, + 0.172833189368248f, -0.378102988004684f, 0.172543287277222f, -0.377851963043213f, + 0.172253578901291f, -0.377600699663162f, 0.171964049339294f, -0.377349197864532f, + 0.171674728393555f, -0.377097487449646f, 0.171385586261749f, -0.376845568418503f, + 0.171096652746201f, -0.376593410968781f, 0.170807912945747f, -0.376341015100479f, + 0.170519351959229f, -0.376088410615921f, 0.170230999588966f, -0.375835597515106f, + 0.169942826032639f, -0.375582575798035f, 0.169654861092567f, -0.375329315662384f, + 0.169367074966431f, -0.375075817108154f, 0.169079497456551f, -0.374822109937668f, + 0.168792113661766f, -0.374568194150925f, 0.168504923582077f, -0.374314039945602f, + 0.168217927217484f, -0.374059677124023f, 0.167931124567986f, -0.373805105686188f, + 0.167644515633583f, -0.373550295829773f, 0.167358100414276f, -0.373295277357101f, + 0.167071878910065f, -0.373040050268173f, 0.166785866022110f, -0.372784584760666f, + 0.166500031948090f, -0.372528880834579f, 0.166214406490326f, -0.372272998094559f, + 0.165928974747658f, -0.372016876935959f, 0.165643751621246f, -0.371760547161102f, + 0.165358707308769f, -0.371503978967667f, 0.165073871612549f, -0.371247202157974f, + 0.164789214730263f, -0.370990216732025f, 0.164504766464233f, -0.370732992887497f, + 0.164220526814461f, -0.370475560426712f, 0.163936465978622f, -0.370217919349670f, + 0.163652613759041f, -0.369960039854050f, 0.163368955254555f, -0.369701951742172f, + 0.163085505366325f, -0.369443655014038f, 0.162802234292030f, -0.369185149669647f, + 0.162519171833992f, -0.368926405906677f, 0.162236317992210f, -0.368667453527451f, + 0.161953642964363f, -0.368408292531967f, 0.161671176552773f, -0.368148893117905f, + 0.161388918757439f, -0.367889285087585f, 0.161106839776039f, -0.367629468441010f, + 0.160824984312058f, -0.367369443178177f, 0.160543307662010f, -0.367109179496765f, + 0.160261839628220f, -0.366848707199097f, 0.159980565309525f, -0.366588026285172f, + 0.159699499607086f, -0.366327136754990f, 0.159418627619743f, -0.366066008806229f, + 0.159137964248657f, -0.365804702043533f, 0.158857494592667f, -0.365543156862259f, + 0.158577233552933f, -0.365281373262405f, 0.158297166228294f, -0.365019410848618f, + 0.158017292618752f, -0.364757210016251f, 0.157737627625465f, -0.364494800567627f, + 0.157458171248436f, -0.364232182502747f, 0.157178908586502f, -0.363969355821610f, + 0.156899839639664f, -0.363706320524216f, 0.156620979309082f, -0.363443046808243f, + 0.156342327594757f, -0.363179564476013f, 0.156063869595528f, -0.362915903329849f, + 0.155785620212555f, -0.362651973962784f, 0.155507579445839f, -0.362387865781784f, + 0.155229732394218f, -0.362123548984528f, 0.154952079057693f, -0.361858993768692f, + 0.154674649238586f, -0.361594229936600f, 0.154397398233414f, -0.361329287290573f, + 0.154120370745659f, -0.361064106225967f, 0.153843536973000f, -0.360798716545105f, + 0.153566911816597f, -0.360533088445663f, 0.153290495276451f, -0.360267281532288f, + 0.153014272451401f, -0.360001266002655f, 0.152738258242607f, -0.359735012054443f, + 0.152462437748909f, -0.359468549489975f, 0.152186840772629f, -0.359201908111572f, + 0.151911437511444f, -0.358935028314590f, 0.151636242866516f, -0.358667939901352f, + 0.151361241936684f, -0.358400642871857f, 0.151086464524269f, -0.358133137226105f, + 0.150811880826950f, -0.357865422964096f, 0.150537505745888f, -0.357597470283508f, + 0.150263324379921f, -0.357329338788986f, 0.149989366531372f, -0.357060998678207f, + 0.149715602397919f, -0.356792420148849f, 0.149442046880722f, -0.356523662805557f, + 0.149168699979782f, -0.356254696846008f, 0.148895561695099f, -0.355985492467880f, + 0.148622632026672f, -0.355716109275818f, 0.148349896073341f, -0.355446487665176f, + 0.148077383637428f, -0.355176687240601f, 0.147805064916611f, -0.354906648397446f, + 0.147532954812050f, -0.354636400938034f, 0.147261068224907f, -0.354365974664688f, + 0.146989375352860f, -0.354095309972763f, 0.146717891097069f, -0.353824466466904f, + 0.146446615457535f, -0.353553384542465f, 0.146175548434258f, -0.353282123804092f, + 0.145904675126076f, -0.353010624647141f, 0.145634025335312f, -0.352738946676254f, + 0.145363584160805f, -0.352467030286789f, 0.145093351602554f, -0.352194935083389f, + 0.144823327660561f, -0.351922631263733f, 0.144553512334824f, -0.351650089025497f, + 0.144283905625343f, -0.351377367973328f, 0.144014507532120f, -0.351104438304901f, + 0.143745318055153f, -0.350831300020218f, 0.143476337194443f, -0.350557953119278f, + 0.143207564949989f, -0.350284397602081f, 0.142939001321793f, -0.350010633468628f, + 0.142670661211014f, -0.349736660718918f, 0.142402514815331f, -0.349462509155273f, + 0.142134591937065f, -0.349188119173050f, 0.141866862773895f, -0.348913550376892f, + 0.141599357128143f, -0.348638743162155f, 0.141332060098648f, -0.348363757133484f, + 0.141064971685410f, -0.348088562488556f, 0.140798106789589f, -0.347813159227371f, + 0.140531435608864f, -0.347537547349930f, 0.140264987945557f, -0.347261756658554f, + 0.139998748898506f, -0.346985727548599f, 0.139732718467712f, -0.346709519624710f, + 0.139466896653175f, -0.346433073282242f, 0.139201298356056f, -0.346156448125839f, + 0.138935908675194f, -0.345879614353180f, 0.138670727610588f, -0.345602601766586f, + 0.138405755162239f, -0.345325350761414f, 0.138141006231308f, -0.345047920942307f, + 0.137876465916634f, -0.344770282506943f, 0.137612134218216f, -0.344492435455322f, + 0.137348011136055f, -0.344214379787445f, 0.137084111571312f, -0.343936115503311f, + 0.136820420622826f, -0.343657672405243f, 0.136556953191757f, -0.343379020690918f, + 0.136293679475784f, -0.343100160360336f, 0.136030644178391f, -0.342821091413498f, + 0.135767802596092f, -0.342541843652725f, 0.135505184531212f, -0.342262357473373f, + 0.135242775082588f, -0.341982692480087f, 0.134980589151382f, -0.341702848672867f, + 0.134718611836433f, -0.341422766447067f, 0.134456858038902f, -0.341142505407333f, + 0.134195312857628f, -0.340862035751343f, 0.133933976292610f, -0.340581357479095f, + 0.133672863245010f, -0.340300500392914f, 0.133411958813667f, -0.340019434690475f, + 0.133151277899742f, -0.339738160371780f, 0.132890805602074f, -0.339456677436829f, + 0.132630556821823f, -0.339175015687943f, 0.132370531558990f, -0.338893145322800f, + 0.132110700011253f, -0.338611096143723f, 0.131851106882095f, -0.338328808546066f, + 0.131591722369194f, -0.338046342134476f, 0.131332546472549f, -0.337763696908951f, + 0.131073594093323f, -0.337480813264847f, 0.130814850330353f, -0.337197750806808f, + 0.130556344985962f, -0.336914509534836f, 0.130298033356667f, -0.336631029844284f, + 0.130039945244789f, -0.336347371339798f, 0.129782080650330f, -0.336063534021378f, + 0.129524439573288f, -0.335779488086700f, 0.129267007112503f, -0.335495233535767f, + 0.129009798169136f, -0.335210770368576f, 0.128752797842026f, -0.334926128387451f, + 0.128496021032333f, -0.334641307592392f, 0.128239467740059f, -0.334356248378754f, + 0.127983123064041f, -0.334071010351181f, 0.127727001905441f, -0.333785593509674f, + 0.127471104264259f, -0.333499968051910f, 0.127215430140495f, -0.333214133977890f, + 0.126959964632988f, -0.332928121089935f, 0.126704722642899f, -0.332641899585724f, + 0.126449704170227f, -0.332355499267578f, 0.126194894313812f, -0.332068890333176f, + 0.125940307974815f, -0.331782072782516f, 0.125685945153236f, -0.331495076417923f, + 0.125431805849075f, -0.331207901239395f, 0.125177875161171f, -0.330920487642288f, + 0.124924175441265f, -0.330632925033569f, 0.124670691788197f, -0.330345153808594f, + 0.124417431652546f, -0.330057173967361f, 0.124164395034313f, -0.329769015312195f, + 0.123911574482918f, -0.329480648040771f, 0.123658977448940f, -0.329192101955414f, + 0.123406603932381f, -0.328903347253799f, 0.123154446482658f, -0.328614413738251f, + 0.122902512550354f, -0.328325271606445f, 0.122650802135468f, -0.328035950660706f, + 0.122399315237999f, -0.327746421098709f, 0.122148044407368f, -0.327456712722778f, + 0.121896997094154f, -0.327166795730591f, 0.121646173298359f, -0.326876699924469f, + 0.121395580470562f, -0.326586425304413f, 0.121145196259022f, -0.326295942068100f, + 0.120895043015480f, -0.326005280017853f, 0.120645113289356f, -0.325714409351349f, + 0.120395407080650f, -0.325423330068588f, 0.120145916938782f, -0.325132101774216f, + 0.119896657764912f, -0.324840664863586f, 0.119647622108459f, -0.324549019336700f, + 0.119398809969425f, -0.324257194995880f, 0.119150213897228f, -0.323965191841125f, + 0.118901848793030f, -0.323672980070114f, 0.118653707206249f, -0.323380589485168f, + 0.118405789136887f, -0.323088020086288f, 0.118158094584942f, -0.322795242071152f, + 0.117910631000996f, -0.322502255439758f, 0.117663383483887f, -0.322209119796753f, + 0.117416366934776f, -0.321915775537491f, 0.117169573903084f, -0.321622252464294f, + 0.116923004388809f, -0.321328520774841f, 0.116676658391953f, -0.321034610271454f, + 0.116430543363094f, -0.320740520954132f, 0.116184651851654f, -0.320446223020554f, + 0.115938983857632f, -0.320151746273041f, 0.115693546831608f, -0.319857090711594f, + 0.115448333323002f, -0.319562226533890f, 0.115203343331814f, -0.319267183542252f, + 0.114958584308624f, -0.318971961736679f, 0.114714048802853f, -0.318676531314850f, + 0.114469736814499f, -0.318380922079086f, 0.114225655794144f, -0.318085134029388f, + 0.113981798291206f, -0.317789167165756f, 0.113738171756268f, -0.317492991685867f, + 0.113494776189327f, -0.317196637392044f, 0.113251596689224f, -0.316900104284287f, + 0.113008655607700f, -0.316603392362595f, 0.112765938043594f, -0.316306471824646f, + 0.112523443996906f, -0.316009372472763f, 0.112281180918217f, -0.315712094306946f, + 0.112039148807526f, -0.315414607524872f, 0.111797347664833f, -0.315116971731186f, + 0.111555770039558f, -0.314819127321243f, 0.111314415931702f, -0.314521104097366f, + 0.111073300242424f, -0.314222872257233f, 0.110832408070564f, -0.313924491405487f, + 0.110591746866703f, -0.313625901937485f, 0.110351309180260f, -0.313327133655548f, + 0.110111102461815f, -0.313028186559677f, 0.109871134161949f, -0.312729060649872f, + 0.109631389379501f, -0.312429755926132f, 0.109391868114471f, -0.312130242586136f, + 0.109152585268021f, -0.311830550432205f, 0.108913525938988f, -0.311530679464340f, + 0.108674705028534f, -0.311230629682541f, 0.108436107635498f, -0.310930401086807f, + 0.108197741210461f, -0.310629993677139f, 0.107959605753422f, -0.310329377651215f, + 0.107721701264381f, -0.310028612613678f, 0.107484027743340f, -0.309727638959885f, + 0.107246585190296f, -0.309426486492157f, 0.107009373605251f, -0.309125155210495f, + 0.106772392988205f, -0.308823645114899f, 0.106535643339157f, -0.308521956205368f, + 0.106299124658108f, -0.308220088481903f, 0.106062836945057f, -0.307918041944504f, + 0.105826787650585f, -0.307615786790848f, 0.105590961873531f, -0.307313382625580f, + 0.105355374515057f, -0.307010769844055f, 0.105120018124580f, -0.306708008050919f, + 0.104884892702103f, -0.306405037641525f, 0.104649998247623f, -0.306101888418198f, + 0.104415334761143f, -0.305798590183258f, 0.104180909693241f, -0.305495083332062f, + 0.103946708142757f, -0.305191397666931f, 0.103712752461433f, -0.304887533187866f, + 0.103479020297527f, -0.304583519697189f, 0.103245526552200f, -0.304279297590256f, + 0.103012263774872f, -0.303974896669388f, 0.102779231965542f, -0.303670316934586f, + 0.102546438574791f, -0.303365558385849f, 0.102313876152039f, -0.303060621023178f, + 0.102081544697285f, -0.302755534648895f, 0.101849451661110f, -0.302450239658356f, + 0.101617597043514f, -0.302144765853882f, 0.101385973393917f, -0.301839113235474f, + 0.101154580712318f, -0.301533311605453f, 0.100923426449299f, -0.301227301359177f, + 0.100692503154278f, -0.300921112298965f, 0.100461818277836f, -0.300614774227142f, + 0.100231364369392f, -0.300308227539063f, 0.100001148879528f, -0.300001531839371f, + 0.099771171808243f, -0.299694657325745f, 0.099541425704956f, -0.299387603998184f, + 0.099311910569668f, -0.299080342054367f, 0.099082641303539f, -0.298772931098938f, + 0.098853603005409f, -0.298465341329575f, 0.098624803125858f, -0.298157602548599f, + 0.098396234214306f, -0.297849655151367f, 0.098167903721333f, -0.297541528940201f, + 0.097939811646938f, -0.297233253717422f, 0.097711957991123f, -0.296924799680710f, + 0.097484335303307f, -0.296616137027740f, 0.097256951034069f, -0.296307325363159f, + 0.097029805183411f, -0.295998334884644f, 0.096802897751331f, -0.295689195394516f, + 0.096576221287251f, -0.295379847288132f, 0.096349790692329f, -0.295070350170136f, + 0.096123591065407f, -0.294760644435883f, 0.095897629857063f, -0.294450789690018f, + 0.095671907067299f, -0.294140785932541f, 0.095446422696114f, -0.293830573558807f, + 0.095221176743507f, -0.293520182371140f, 0.094996169209480f, -0.293209642171860f, + 0.094771400094032f, -0.292898923158646f, 0.094546869397163f, -0.292588025331497f, + 0.094322577118874f, -0.292276978492737f, 0.094098523259163f, -0.291965723037720f, + 0.093874707818031f, -0.291654318571091f, 0.093651130795479f, -0.291342735290527f, + 0.093427792191505f, -0.291031002998352f, 0.093204692006111f, -0.290719062089920f, + 0.092981837689877f, -0.290406972169876f, 0.092759214341640f, -0.290094703435898f, + 0.092536836862564f, -0.289782285690308f, 0.092314697802067f, -0.289469659328461f, + 0.092092797160149f, -0.289156883955002f, 0.091871134936810f, -0.288843959569931f, + 0.091649711132050f, -0.288530826568604f, 0.091428533196449f, -0.288217544555664f, + 0.091207593679428f, -0.287904083728790f, 0.090986892580986f, -0.287590473890305f, + 0.090766437351704f, -0.287276685237885f, 0.090546220541000f, -0.286962717771530f, + 0.090326242148876f, -0.286648571491241f, 0.090106502175331f, -0.286334276199341f, + 0.089887008070946f, -0.286019802093506f, 0.089667752385139f, -0.285705178976059f, + 0.089448742568493f, -0.285390377044678f, 0.089229971170425f, -0.285075396299362f, + 0.089011445641518f, -0.284760266542435f, 0.088793158531189f, -0.284444957971573f, + 0.088575109839439f, -0.284129470586777f, 0.088357307016850f, -0.283813834190369f, + 0.088139742612839f, -0.283498018980026f, 0.087922424077988f, -0.283182054758072f, + 0.087705351412296f, -0.282865911722183f, 0.087488517165184f, -0.282549589872360f, + 0.087271921336651f, -0.282233119010925f, 0.087055571377277f, -0.281916469335556f, + 0.086839467287064f, -0.281599670648575f, 0.086623609066010f, -0.281282693147659f, + 0.086407989263535f, -0.280965566635132f, 0.086192607879639f, -0.280648261308670f, + 0.085977479815483f, -0.280330777168274f, 0.085762590169907f, -0.280013144016266f, + 0.085547938942909f, -0.279695361852646f, 0.085333541035652f, -0.279377400875092f, + 0.085119381546974f, -0.279059261083603f, 0.084905467927456f, -0.278740972280502f, + 0.084691800177097f, -0.278422504663467f, 0.084478378295898f, -0.278103888034821f, + 0.084265194833279f, -0.277785122394562f, 0.084052257239819f, -0.277466177940369f, + 0.083839565515518f, -0.277147054672241f, 0.083627119660378f, -0.276827782392502f, + 0.083414919674397f, -0.276508361101151f, 0.083202958106995f, -0.276188760995865f, + 0.082991249859333f, -0.275868982076645f, 0.082779780030251f, -0.275549083948135f, + 0.082568563520908f, -0.275228977203369f, 0.082357585430145f, -0.274908751249313f, + 0.082146860659122f, -0.274588316679001f, 0.081936374306679f, -0.274267762899399f, + 0.081726133823395f, -0.273947030305862f, 0.081516146659851f, -0.273626148700714f, + 0.081306397914886f, -0.273305088281631f, 0.081096902489662f, -0.272983878850937f, + 0.080887645483017f, -0.272662490606308f, 0.080678641796112f, -0.272340953350067f, + 0.080469883978367f, -0.272019267082214f, 0.080261372029781f, -0.271697402000427f, + 0.080053105950356f, -0.271375387907028f, 0.079845085740089f, -0.271053224802017f, + 0.079637311398983f, -0.270730882883072f, 0.079429790377617f, -0.270408391952515f, + 0.079222507774830f, -0.270085722208023f, 0.079015478491783f, -0.269762933254242f, + 0.078808702528477f, -0.269439965486526f, 0.078602164983749f, -0.269116818904877f, + 0.078395880758762f, -0.268793523311615f, 0.078189842402935f, -0.268470078706741f, + 0.077984049916267f, -0.268146485090256f, 0.077778510749340f, -0.267822742462158f, + 0.077573217451572f, -0.267498821020126f, 0.077368170022964f, -0.267174720764160f, + 0.077163375914097f, -0.266850501298904f, 0.076958827674389f, -0.266526103019714f, + 0.076754532754421f, -0.266201555728912f, 0.076550483703613f, -0.265876859426498f, + 0.076346680521965f, -0.265552014112473f, 0.076143130660057f, -0.265226989984512f, + 0.075939826667309f, -0.264901816844940f, 0.075736775994301f, -0.264576494693756f, + 0.075533971190453f, -0.264250993728638f, 0.075331419706345f, -0.263925373554230f, + 0.075129114091396f, -0.263599574565887f, 0.074927061796188f, -0.263273626565933f, + 0.074725262820721f, -0.262947499752045f, 0.074523709714413f, -0.262621253728867f, + 0.074322402477264f, -0.262294828891754f, 0.074121348559856f, -0.261968284845352f, + 0.073920547962189f, -0.261641561985016f, 0.073720000684261f, -0.261314690113068f, + 0.073519699275494f, -0.260987639427185f, 0.073319651186466f, -0.260660469532013f, + 0.073119848966599f, -0.260333120822906f, 0.072920300066471f, -0.260005623102188f, + 0.072721004486084f, -0.259678006172180f, 0.072521962225437f, -0.259350210428238f, + 0.072323165833950f, -0.259022265672684f, 0.072124622762203f, -0.258694142103195f, + 0.071926333010197f, -0.258365899324417f, 0.071728296577930f, -0.258037507534027f, + 0.071530513465405f, -0.257708936929703f, 0.071332976222038f, -0.257380217313766f, + 0.071135692298412f, -0.257051378488541f, 0.070938661694527f, -0.256722360849380f, + 0.070741884410381f, -0.256393194198608f, 0.070545360445976f, -0.256063878536224f, + 0.070349089801311f, -0.255734413862228f, 0.070153072476387f, -0.255404800176620f, + 0.069957308471203f, -0.255075037479401f, 0.069761790335178f, -0.254745125770569f, + 0.069566532969475f, -0.254415065050125f, 0.069371521472931f, -0.254084855318069f, + 0.069176770746708f, -0.253754496574402f, 0.068982265889645f, -0.253423988819122f, + 0.068788021802902f, -0.253093332052231f, 0.068594031035900f, -0.252762526273727f, + 0.068400286138058f, -0.252431541681290f, 0.068206802010536f, -0.252100437879562f, + 0.068013571202755f, -0.251769185066223f, 0.067820593714714f, -0.251437783241272f, + 0.067627869546413f, -0.251106232404709f, 0.067435398697853f, -0.250774532556534f, + 0.067243188619614f, -0.250442683696747f, 0.067051224410534f, -0.250110685825348f, + 0.066859520971775f, -0.249778553843498f, 0.066668070852757f, -0.249446272850037f, + 0.066476874053478f, -0.249113827943802f, 0.066285938024521f, -0.248781248927116f, + 0.066095255315304f, -0.248448520898819f, 0.065904818475246f, -0.248115643858910f, + 0.065714649856091f, -0.247782632708550f, 0.065524727106094f, -0.247449472546577f, + 0.065335065126419f, -0.247116148471832f, 0.065145656466484f, -0.246782705187798f, + 0.064956501126289f, -0.246449097990990f, 0.064767606556416f, -0.246115356683731f, + 0.064578965306282f, -0.245781451463699f, 0.064390584826469f, -0.245447427034378f, + 0.064202457666397f, -0.245113238692284f, 0.064014583826065f, -0.244778916239738f, + 0.063826970756054f, -0.244444444775581f, 0.063639611005783f, -0.244109839200974f, + 0.063452512025833f, -0.243775084614754f, 0.063265666365623f, -0.243440181016922f, + 0.063079081475735f, -0.243105143308640f, 0.062892749905586f, -0.242769956588745f, + 0.062706671655178f, -0.242434620857239f, 0.062520854175091f, -0.242099151015282f, + 0.062335297465324f, -0.241763532161713f, 0.062149997800589f, -0.241427779197693f, + 0.061964951455593f, -0.241091892123222f, 0.061780165880919f, -0.240755841135979f, + 0.061595637351274f, -0.240419670939446f, 0.061411365866661f, -0.240083336830139f, + 0.061227355152369f, -0.239746883511543f, 0.061043601483107f, -0.239410281181335f, + 0.060860104858875f, -0.239073529839516f, 0.060676865279675f, -0.238736644387245f, + 0.060493886470795f, -0.238399609923363f, 0.060311164706945f, -0.238062441349030f, + 0.060128703713417f, -0.237725138664246f, 0.059946499764919f, -0.237387686967850f, + 0.059764556586742f, -0.237050101161003f, 0.059582870453596f, -0.236712381243706f, + 0.059401445090771f, -0.236374512314796f, 0.059220276772976f, -0.236036509275436f, + 0.059039369225502f, -0.235698372125626f, 0.058858718723059f, -0.235360085964203f, + 0.058678328990936f, -0.235021665692329f, 0.058498200029135f, -0.234683111310005f, + 0.058318331837654f, -0.234344407916069f, 0.058138720691204f, -0.234005570411682f, + 0.057959370315075f, -0.233666598796844f, 0.057780280709267f, -0.233327493071556f, + 0.057601451873779f, -0.232988253235817f, 0.057422880083323f, -0.232648864388466f, + 0.057244572788477f, -0.232309341430664f, 0.057066522538662f, -0.231969684362412f, + 0.056888736784458f, -0.231629893183708f, 0.056711208075285f, -0.231289967894554f, + 0.056533940136433f, -0.230949893593788f, 0.056356932967901f, -0.230609700083733f, + 0.056180190294981f, -0.230269357562065f, 0.056003704667091f, -0.229928880929947f, + 0.055827483534813f, -0.229588270187378f, 0.055651523172855f, -0.229247525334358f, + 0.055475823581219f, -0.228906646370888f, 0.055300384759903f, -0.228565633296967f, + 0.055125206708908f, -0.228224486112595f, 0.054950293153524f, -0.227883204817772f, + 0.054775636643171f, -0.227541789412498f, 0.054601248353720f, -0.227200239896774f, + 0.054427117109299f, -0.226858556270599f, 0.054253250360489f, -0.226516738533974f, + 0.054079644382000f, -0.226174786686897f, 0.053906302899122f, -0.225832715630531f, + 0.053733222186565f, -0.225490495562553f, 0.053560405969620f, -0.225148141384125f, + 0.053387850522995f, -0.224805667996407f, 0.053215555846691f, -0.224463045597076f, + 0.053043525665998f, -0.224120303988457f, 0.052871759980917f, -0.223777428269386f, + 0.052700258791447f, -0.223434418439865f, 0.052529018372297f, -0.223091274499893f, + 0.052358038723469f, -0.222748011350632f, 0.052187327295542f, -0.222404599189758f, + 0.052016876637936f, -0.222061067819595f, 0.051846686750650f, -0.221717402338982f, + 0.051676765084267f, -0.221373617649078f, 0.051507104188204f, -0.221029683947563f, + 0.051337707787752f, -0.220685631036758f, 0.051168579608202f, -0.220341444015503f, + 0.050999708473682f, -0.219997137784958f, 0.050831105560064f, -0.219652697443962f, + 0.050662767142057f, -0.219308122992516f, 0.050494693219662f, -0.218963414430618f, + 0.050326880067587f, -0.218618586659431f, 0.050159335136414f, -0.218273624777794f, + 0.049992054700851f, -0.217928543686867f, 0.049825038760900f, -0.217583328485489f, + 0.049658283591270f, -0.217237979173660f, 0.049491796642542f, -0.216892510652542f, + 0.049325577914715f, -0.216546908020973f, 0.049159619957209f, -0.216201186180115f, + 0.048993926495314f, -0.215855330228806f, 0.048828501254320f, -0.215509355068207f, + 0.048663340508938f, -0.215163245797157f, 0.048498444259167f, -0.214817002415657f, + 0.048333816230297f, -0.214470639824867f, 0.048169452697039f, -0.214124158024788f, + 0.048005353659391f, -0.213777542114258f, 0.047841522842646f, -0.213430806994438f, + 0.047677956521511f, -0.213083937764168f, 0.047514654695988f, -0.212736949324608f, + 0.047351621091366f, -0.212389841675758f, 0.047188851982355f, -0.212042599916458f, + 0.047026351094246f, -0.211695238947868f, 0.046864114701748f, -0.211347743868828f, + 0.046702146530151f, -0.211000129580498f, 0.046540446579456f, -0.210652396082878f, + 0.046379011124372f, -0.210304543375969f, 0.046217843890190f, -0.209956556558609f, + 0.046056941151619f, -0.209608450531960f, 0.045896306633949f, -0.209260210394859f, + 0.045735940337181f, -0.208911851048470f, 0.045575842261314f, -0.208563387393951f, + 0.045416008681059f, -0.208214774727821f, 0.045256443321705f, -0.207866057753563f, + 0.045097146183252f, -0.207517206668854f, 0.044938117265701f, -0.207168251276016f, + 0.044779352843761f, -0.206819161772728f, 0.044620860368013f, -0.206469938158989f, + 0.044462632387877f, -0.206120610237122f, 0.044304672628641f, -0.205771163105965f, + 0.044146984815598f, -0.205421581864357f, 0.043989561498165f, -0.205071896314621f, + 0.043832406401634f, -0.204722076654434f, 0.043675523251295f, -0.204372137784958f, + 0.043518904596567f, -0.204022079706192f, 0.043362557888031f, -0.203671902418137f, + 0.043206475675106f, -0.203321605920792f, 0.043050665408373f, -0.202971190214157f, + 0.042895123362541f, -0.202620655298233f, 0.042739849537611f, -0.202270001173019f, + 0.042584843933582f, -0.201919227838516f, 0.042430106550455f, -0.201568335294724f, + 0.042275641113520f, -0.201217323541641f, 0.042121443897486f, -0.200866192579269f, + 0.041967518627644f, -0.200514942407608f, 0.041813857853413f, -0.200163587927818f, + 0.041660469025373f, -0.199812099337578f, 0.041507352143526f, -0.199460506439209f, + 0.041354499757290f, -0.199108779430389f, 0.041201923042536f, -0.198756948113441f, + 0.041049610823393f, -0.198404997587204f, 0.040897574275732f, -0.198052927851677f, + 0.040745802223682f, -0.197700738906860f, 0.040594302117825f, -0.197348430752754f, + 0.040443073958158f, -0.196996018290520f, 0.040292114019394f, -0.196643486618996f, + 0.040141426026821f, -0.196290835738182f, 0.039991009980440f, -0.195938065648079f, + 0.039840862154961f, -0.195585191249847f, 0.039690986275673f, -0.195232197642326f, + 0.039541378617287f, -0.194879084825516f, 0.039392042905092f, -0.194525867700577f, + 0.039242979139090f, -0.194172516465187f, 0.039094187319279f, -0.193819075822830f, + 0.038945667445660f, -0.193465501070023f, 0.038797415792942f, -0.193111822009087f, + 0.038649436086416f, -0.192758023738861f, 0.038501728326082f, -0.192404121160507f, + 0.038354292511940f, -0.192050099372864f, 0.038207128643990f, -0.191695958375931f, + 0.038060232996941f, -0.191341713070869f, 0.037913613021374f, -0.190987363457680f, + 0.037767261266708f, -0.190632879734039f, 0.037621185183525f, -0.190278306603432f, + 0.037475381046534f, -0.189923599362373f, 0.037329845130444f, -0.189568802714348f, + 0.037184584885836f, -0.189213871955872f, 0.037039596587420f, -0.188858851790428f, + 0.036894880235195f, -0.188503712415695f, 0.036750435829163f, -0.188148453831673f, + 0.036606263369322f, -0.187793090939522f, 0.036462362855673f, -0.187437608838081f, + 0.036318738013506f, -0.187082037329674f, 0.036175385117531f, -0.186726331710815f, + 0.036032304167747f, -0.186370536684990f, 0.035889495164156f, -0.186014622449875f, + 0.035746958106756f, -0.185658603906631f, 0.035604696720839f, -0.185302466154099f, + 0.035462711006403f, -0.184946224093437f, 0.035320993512869f, -0.184589877724648f, + 0.035179551690817f, -0.184233412146568f, 0.035038381814957f, -0.183876842260361f, + 0.034897487610579f, -0.183520168066025f, 0.034756865352392f, -0.183163389563560f, + 0.034616518765688f, -0.182806491851807f, 0.034476444125175f, -0.182449504733086f, + 0.034336645156145f, -0.182092398405075f, 0.034197118133307f, -0.181735187768936f, + 0.034057866781950f, -0.181377857923508f, 0.033918887376785f, -0.181020438671112f, + 0.033780183643103f, -0.180662900209427f, 0.033641755580902f, -0.180305257439613f, + 0.033503599464893f, -0.179947525262833f, 0.033365719020367f, -0.179589673876762f, + 0.033228114247322f, -0.179231703281403f, 0.033090781420469f, -0.178873643279076f, + 0.032953724265099f, -0.178515478968620f, 0.032816942781210f, -0.178157210350037f, + 0.032680433243513f, -0.177798837423325f, 0.032544203102589f, -0.177440345287323f, + 0.032408244907856f, -0.177081763744354f, 0.032272562384605f, -0.176723077893257f, + 0.032137155532837f, -0.176364272832870f, 0.032002024352551f, -0.176005378365517f, + 0.031867165118456f, -0.175646379590034f, 0.031732585281134f, -0.175287276506424f, + 0.031598277390003f, -0.174928069114685f, 0.031464248895645f, -0.174568757414818f, + 0.031330492347479f, -0.174209341406822f, 0.031197015196085f, -0.173849821090698f, + 0.031063811853528f, -0.173490211367607f, 0.030930884182453f, -0.173130482435226f, + 0.030798232182860f, -0.172770664095879f, 0.030665857717395f, -0.172410741448402f, + 0.030533758923411f, -0.172050714492798f, 0.030401935800910f, -0.171690583229065f, + 0.030270388349891f, -0.171330362558365f, 0.030139118432999f, -0.170970037579536f, + 0.030008124187589f, -0.170609608292580f, 0.029877405613661f, -0.170249074697495f, + 0.029746964573860f, -0.169888436794281f, 0.029616801068187f, -0.169527709484100f, + 0.029486913233995f, -0.169166877865791f, 0.029357301071286f, -0.168805956840515f, + 0.029227968305349f, -0.168444931507111f, 0.029098909348249f, -0.168083801865578f, + 0.028970129787922f, -0.167722567915916f, 0.028841627761722f, -0.167361244559288f, + 0.028713401407003f, -0.166999831795692f, 0.028585452586412f, -0.166638299822807f, + 0.028457781299949f, -0.166276678442955f, 0.028330387547612f, -0.165914967656136f, + 0.028203271329403f, -0.165553152561188f, 0.028076432645321f, -0.165191248059273f, + 0.027949871495366f, -0.164829224348068f, 0.027823587879539f, -0.164467126131058f, + 0.027697581797838f, -0.164104923605919f, 0.027571853250265f, -0.163742616772652f, + 0.027446404099464f, -0.163380220532417f, 0.027321230620146f, -0.163017734885216f, + 0.027196336537600f, -0.162655144929886f, 0.027071721851826f, -0.162292465567589f, + 0.026947384700179f, -0.161929681897163f, 0.026823325082660f, -0.161566808819771f, + 0.026699542999268f, -0.161203846335411f, 0.026576040312648f, -0.160840779542923f, + 0.026452817022800f, -0.160477623343468f, 0.026329871267080f, -0.160114362835884f, + 0.026207204908133f, -0.159751012921333f, 0.026084816083312f, -0.159387573599815f, + 0.025962706655264f, -0.159024044871330f, 0.025840876623988f, -0.158660411834717f, + 0.025719324126840f, -0.158296689391136f, 0.025598052889109f, -0.157932877540588f, + 0.025477059185505f, -0.157568961381912f, 0.025356344878674f, -0.157204970717430f, + 0.025235909968615f, -0.156840875744820f, 0.025115754455328f, -0.156476691365242f, + 0.024995878338814f, -0.156112402677536f, 0.024876279756427f, -0.155748039484024f, + 0.024756962433457f, -0.155383571982384f, 0.024637924507260f, -0.155019029974937f, + 0.024519165977836f, -0.154654383659363f, 0.024400688707829f, -0.154289647936821f, + 0.024282488971949f, -0.153924822807312f, 0.024164570495486f, -0.153559908270836f, + 0.024046931415796f, -0.153194904327393f, 0.023929571732879f, -0.152829796075821f, + 0.023812493309379f, -0.152464613318443f, 0.023695694282651f, -0.152099341154099f, + 0.023579176515341f, -0.151733979582787f, 0.023462938144803f, -0.151368513703346f, + 0.023346979171038f, -0.151002973318100f, 0.023231301456690f, -0.150637343525887f, + 0.023115905001760f, -0.150271624326706f, 0.023000787943602f, -0.149905815720558f, + 0.022885952144861f, -0.149539917707443f, 0.022771397605538f, -0.149173930287361f, + 0.022657122462988f, -0.148807853460312f, 0.022543128579855f, -0.148441687226295f, + 0.022429415956140f, -0.148075446486473f, 0.022315984591842f, -0.147709101438522f, + 0.022202832624316f, -0.147342681884766f, 0.022089963778853f, -0.146976172924042f, + 0.021977374330163f, -0.146609574556351f, 0.021865066140890f, -0.146242901682854f, + 0.021753041073680f, -0.145876124501228f, 0.021641295403242f, -0.145509272813797f, + 0.021529832854867f, -0.145142331719399f, 0.021418649703264f, -0.144775316119194f, + 0.021307749673724f, -0.144408211112022f, 0.021197130903602f, -0.144041016697884f, + 0.021086793392897f, -0.143673732876778f, 0.020976737141609f, -0.143306359648705f, + 0.020866964012384f, -0.142938911914825f, 0.020757472142577f, -0.142571389675140f, + 0.020648263394833f, -0.142203763127327f, 0.020539334043860f, -0.141836062073708f, + 0.020430689677596f, -0.141468286514282f, 0.020322324708104f, -0.141100421547890f, + 0.020214242860675f, -0.140732467174530f, 0.020106444135308f, -0.140364438295364f, + 0.019998926669359f, -0.139996320009232f, 0.019891692325473f, -0.139628127217293f, + 0.019784741103649f, -0.139259845018387f, 0.019678071141243f, -0.138891488313675f, + 0.019571684300900f, -0.138523042201996f, 0.019465578719974f, -0.138154521584511f, + 0.019359756261110f, -0.137785911560059f, 0.019254218786955f, -0.137417227029800f, + 0.019148962572217f, -0.137048453092575f, 0.019043987616897f, -0.136679604649544f, + 0.018939297646284f, -0.136310681700706f, 0.018834890797734f, -0.135941669344902f, + 0.018730765208602f, -0.135572582483292f, 0.018626924604177f, -0.135203406214714f, + 0.018523367121816f, -0.134834155440331f, 0.018420090898871f, -0.134464830160141f, + 0.018317099660635f, -0.134095430374146f, 0.018214391544461f, -0.133725941181183f, + 0.018111966550350f, -0.133356377482414f, 0.018009826540947f, -0.132986739277840f, + 0.017907967790961f, -0.132617011666298f, 0.017806394025683f, -0.132247209548950f, + 0.017705103382468f, -0.131877332925797f, 0.017604095861316f, -0.131507381796837f, + 0.017503373324871f, -0.131137356162071f, 0.017402933910489f, -0.130767241120338f, + 0.017302779480815f, -0.130397051572800f, 0.017202908173203f, -0.130026802420616f, + 0.017103319987655f, -0.129656463861465f, 0.017004016786814f, -0.129286035895348f, + 0.016904998570681f, -0.128915548324585f, 0.016806263476610f, -0.128544986248016f, + 0.016707813367248f, -0.128174334764481f, 0.016609646379948f, -0.127803623676300f, + 0.016511764377356f, -0.127432823181152f, 0.016414167359471f, -0.127061963081360f, + 0.016316853463650f, -0.126691013574600f, 0.016219824552536f, -0.126320004463196f, + 0.016123080626130f, -0.125948905944824f, 0.016026621684432f, -0.125577747821808f, + 0.015930447727442f, -0.125206500291824f, 0.015834558755159f, -0.124835193157196f, + 0.015738952904940f, -0.124463804066181f, 0.015643632039428f, -0.124092340469360f, + 0.015548598021269f, -0.123720809817314f, 0.015453847125173f, -0.123349204659462f, + 0.015359382145107f, -0.122977524995804f, 0.015265202149749f, -0.122605770826340f, + 0.015171307139099f, -0.122233949601650f, 0.015077698044479f, -0.121862053871155f, + 0.014984373003244f, -0.121490091085434f, 0.014891333878040f, -0.121118053793907f, + 0.014798580668867f, -0.120745941996574f, 0.014706112444401f, -0.120373763144016f, + 0.014613929204643f, -0.120001509785652f, 0.014522032812238f, -0.119629189372063f, + 0.014430420473218f, -0.119256794452667f, 0.014339094981551f, -0.118884332478046f, + 0.014248054474592f, -0.118511803448200f, 0.014157299883664f, -0.118139199912548f, + 0.014066831208766f, -0.117766529321671f, 0.013976648449898f, -0.117393791675568f, + 0.013886751607060f, -0.117020979523659f, 0.013797140680254f, -0.116648100316525f, + 0.013707815669477f, -0.116275154054165f, 0.013618776574731f, -0.115902140736580f, + 0.013530024327338f, -0.115529052913189f, 0.013441557064652f, -0.115155905485153f, + 0.013353376649320f, -0.114782683551311f, 0.013265483081341f, -0.114409394562244f, + 0.013177875429392f, -0.114036038517952f, 0.013090553693473f, -0.113662622869015f, + 0.013003518804908f, -0.113289132714272f, 0.012916770763695f, -0.112915575504303f, + 0.012830308638513f, -0.112541958689690f, 0.012744133360684f, -0.112168267369270f, + 0.012658244930208f, -0.111794516444206f, 0.012572642415762f, -0.111420698463917f, + 0.012487327679992f, -0.111046813428402f, 0.012402298860252f, -0.110672861337662f, + 0.012317557819188f, -0.110298842191696f, 0.012233102694154f, -0.109924763441086f, + 0.012148935347795f, -0.109550617635250f, 0.012065053917468f, -0.109176412224770f, + 0.011981460265815f, -0.108802139759064f, 0.011898153461516f, -0.108427800238132f, + 0.011815134435892f, -0.108053401112556f, 0.011732402257621f, -0.107678934931755f, + 0.011649956926703f, -0.107304409146309f, 0.011567799374461f, -0.106929816305637f, + 0.011485928669572f, -0.106555156409740f, 0.011404345743358f, -0.106180444359779f, + 0.011323049664497f, -0.105805665254593f, 0.011242041364312f, -0.105430819094181f, + 0.011161320842803f, -0.105055920779705f, 0.011080888099968f, -0.104680955410004f, + 0.011000742204487f, -0.104305922985077f, 0.010920885019004f, -0.103930838406086f, + 0.010841314680874f, -0.103555686771870f, 0.010762032121420f, -0.103180475533009f, + 0.010683037340641f, -0.102805204689503f, 0.010604331269860f, -0.102429874241352f, + 0.010525912046432f, -0.102054484188557f, 0.010447781533003f, -0.101679034531116f, + 0.010369938798249f, -0.101303517818451f, 0.010292383842170f, -0.100927948951721f, + 0.010215117596090f, -0.100552320480347f, 0.010138138197362f, -0.100176624953747f, + 0.010061448439956f, -0.099800877273083f, 0.009985045529902f, -0.099425069987774f, + 0.009908932261169f, -0.099049203097820f, 0.009833106771111f, -0.098673284053802f, + 0.009757569059730f, -0.098297297954559f, 0.009682320058346f, -0.097921259701252f, + 0.009607359766960f, -0.097545161843300f, 0.009532688185573f, -0.097169004380703f, + 0.009458304382861f, -0.096792794764042f, 0.009384209290147f, -0.096416525542736f, + 0.009310402907431f, -0.096040196716785f, 0.009236886166036f, -0.095663815736771f, + 0.009163657203317f, -0.095287375152111f, 0.009090716950595f, -0.094910882413387f, + 0.009018065407872f, -0.094534330070019f, 0.008945702575147f, -0.094157725572586f, + 0.008873629383743f, -0.093781061470509f, 0.008801844902337f, -0.093404345214367f, + 0.008730349130929f, -0.093027576804161f, 0.008659142069519f, -0.092650748789310f, + 0.008588224649429f, -0.092273868620396f, 0.008517595939338f, -0.091896936297417f, + 0.008447255939245f, -0.091519944369793f, 0.008377205580473f, -0.091142900288105f, + 0.008307444863021f, -0.090765804052353f, 0.008237972855568f, -0.090388655662537f, + 0.008168790489435f, -0.090011447668076f, 0.008099896833301f, -0.089634194970131f, + 0.008031292818487f, -0.089256882667542f, 0.007962978444993f, -0.088879525661469f, + 0.007894953712821f, -0.088502109050751f, 0.007827218621969f, -0.088124647736549f, + 0.007759772241116f, -0.087747126817703f, 0.007692615967244f, -0.087369553744793f, + 0.007625748869032f, -0.086991935968399f, 0.007559171877801f, -0.086614266037941f, + 0.007492884527892f, -0.086236543953419f, 0.007426886819303f, -0.085858769714832f, + 0.007361178752035f, -0.085480943322182f, 0.007295760791749f, -0.085103072226048f, + 0.007230632472783f, -0.084725148975849f, 0.007165793795139f, -0.084347173571587f, + 0.007101245224476f, -0.083969146013260f, 0.007036986760795f, -0.083591073751450f, + 0.006973018404096f, -0.083212949335575f, 0.006909339688718f, -0.082834780216217f, + 0.006845951545984f, -0.082456558942795f, 0.006782853044569f, -0.082078292965889f, + 0.006720044650137f, -0.081699974834919f, 0.006657526828349f, -0.081321612000465f, + 0.006595299113542f, -0.080943197011948f, 0.006533361505717f, -0.080564737319946f, + 0.006471714470536f, -0.080186225473881f, 0.006410357542336f, -0.079807676374912f, + 0.006349290721118f, -0.079429075121880f, 0.006288514938205f, -0.079050421714783f, + 0.006228029262275f, -0.078671731054783f, 0.006167833693326f, -0.078292988240719f, + 0.006107929162681f, -0.077914200723171f, 0.006048315204680f, -0.077535368502140f, + 0.005988991353661f, -0.077156484127045f, 0.005929958540946f, -0.076777562499046f, + 0.005871216300875f, -0.076398596167564f, 0.005812764633447f, -0.076019577682018f, + 0.005754603538662f, -0.075640521943569f, 0.005696733482182f, -0.075261414051056f, + 0.005639153998345f, -0.074882268905640f, 0.005581865552813f, -0.074503071606159f, + 0.005524867679924f, -0.074123837053776f, 0.005468160845339f, -0.073744557797909f, + 0.005411745049059f, -0.073365233838558f, 0.005355620291084f, -0.072985872626305f, + 0.005299786105752f, -0.072606459259987f, 0.005244242958724f, -0.072227008640766f, + 0.005188991315663f, -0.071847513318062f, 0.005134030245245f, -0.071467980742455f, + 0.005079360678792f, -0.071088403463364f, 0.005024982150644f, -0.070708781480789f, + 0.004970894660801f, -0.070329122245312f, 0.004917098674923f, -0.069949418306351f, + 0.004863593727350f, -0.069569669663906f, 0.004810380283743f, -0.069189883768559f, + 0.004757457878441f, -0.068810060620308f, 0.004704826977104f, -0.068430192768574f, + 0.004652487114072f, -0.068050287663937f, 0.004600439220667f, -0.067670337855816f, + 0.004548682365566f, -0.067290350794792f, 0.004497217014432f, -0.066910326480865f, + 0.004446043167263f, -0.066530264914036f, 0.004395160824060f, -0.066150158643723f, + 0.004344569984823f, -0.065770015120506f, 0.004294271115214f, -0.065389834344387f, + 0.004244263283908f, -0.065009608864784f, 0.004194547422230f, -0.064629353582859f, + 0.004145123064518f, -0.064249053597450f, 0.004095990676433f, -0.063868723809719f, + 0.004047149792314f, -0.063488349318504f, 0.003998600877821f, -0.063107937574387f, + 0.003950343467295f, -0.062727488577366f, 0.003902378026396f, -0.062347009778023f, + 0.003854704322293f, -0.061966486275196f, 0.003807322587818f, -0.061585929244757f, + 0.003760232590139f, -0.061205338686705f, 0.003713434794918f, -0.060824707150459f, + 0.003666928736493f, -0.060444042086601f, 0.003620714880526f, -0.060063343495131f, + 0.003574792761356f, -0.059682607650757f, 0.003529162844643f, -0.059301838278770f, + 0.003483824897557f, -0.058921031653881f, 0.003438779152930f, -0.058540191501379f, + 0.003394025377929f, -0.058159314095974f, 0.003349563805386f, -0.057778406888247f, + 0.003305394435301f, -0.057397462427616f, 0.003261517267674f, -0.057016488164663f, + 0.003217932302505f, -0.056635476648808f, 0.003174639539793f, -0.056254431605339f, + 0.003131638979539f, -0.055873356759548f, 0.003088930854574f, -0.055492244660854f, + 0.003046514932066f, -0.055111102759838f, 0.003004391444847f, -0.054729927331209f, + 0.002962560392916f, -0.054348722100258f, 0.002921021543443f, -0.053967483341694f, + 0.002879775362089f, -0.053586211055517f, 0.002838821383193f, -0.053204908967018f, + 0.002798160072416f, -0.052823577076197f, 0.002757790964097f, -0.052442211657763f, + 0.002717714523897f, -0.052060816437006f, 0.002677930751815f, -0.051679391413927f, + 0.002638439415023f, -0.051297932863235f, 0.002599240746349f, -0.050916448235512f, + 0.002560334512964f, -0.050534930080175f, 0.002521721180528f, -0.050153385847807f, + 0.002483400283381f, -0.049771808087826f, 0.002445372054353f, -0.049390204250813f, + 0.002407636726275f, -0.049008570611477f, 0.002370193833485f, -0.048626907169819f, + 0.002333043841645f, -0.048245213925838f, 0.002296186750755f, -0.047863494604826f, + 0.002259622327983f, -0.047481749206781f, 0.002223350573331f, -0.047099970281124f, + 0.002187371719629f, -0.046718169003725f, 0.002151685766876f, -0.046336337924004f, + 0.002116292715073f, -0.045954477041960f, 0.002081192564219f, -0.045572593808174f, + 0.002046385314316f, -0.045190680772066f, 0.002011870965362f, -0.044808741658926f, + 0.001977649517357f, -0.044426776468754f, 0.001943721086718f, -0.044044785201550f, + 0.001910085673444f, -0.043662767857313f, 0.001876743277535f, -0.043280724436045f, + 0.001843693898991f, -0.042898654937744f, 0.001810937537812f, -0.042516563087702f, + 0.001778474310413f, -0.042134445160627f, 0.001746304216795f, -0.041752301156521f, + 0.001714427140541f, -0.041370131075382f, 0.001682843198068f, -0.040987938642502f, + 0.001651552389376f, -0.040605723857880f, 0.001620554830879f, -0.040223482996225f, + 0.001589850406162f, -0.039841219782829f, 0.001559439115226f, -0.039458930492401f, + 0.001529321074486f, -0.039076622575521f, 0.001499496400356f, -0.038694288581610f, + 0.001469964860007f, -0.038311932235956f, 0.001440726569854f, -0.037929553538561f, + 0.001411781646311f, -0.037547148764133f, 0.001383129972965f, -0.037164725363255f, + 0.001354771666229f, -0.036782283335924f, 0.001326706726104f, -0.036399815231562f, + 0.001298935036175f, -0.036017324775457f, 0.001271456829272f, -0.035634815692902f, + 0.001244271872565f, -0.035252287983894f, 0.001217380515300f, -0.034869734197855f, + 0.001190782408230f, -0.034487165510654f, 0.001164477784187f, -0.034104570746422f, + 0.001138466643170f, -0.033721961081028f, 0.001112748985179f, -0.033339329063892f, + 0.001087324810214f, -0.032956674695015f, 0.001062194118276f, -0.032574005424976f, + 0.001037356909364f, -0.032191313803196f, 0.001012813183479f, -0.031808607280254f, + 0.000988563057035f, -0.031425878405571f, 0.000964606530033f, -0.031043132767081f, + 0.000940943544265f, -0.030660368502140f, 0.000917574157938f, -0.030277585610747f, + 0.000894498312846f, -0.029894785955548f, 0.000871716125403f, -0.029511967673898f, + 0.000849227537401f, -0.029129132628441f, 0.000827032607049f, -0.028746278956532f, + 0.000805131276138f, -0.028363410383463f, 0.000783523661084f, -0.027980525046587f, + 0.000762209703680f, -0.027597622945905f, 0.000741189462133f, -0.027214704081416f, + 0.000720462878235f, -0.026831768453121f, 0.000700030010194f, -0.026448817923665f, + 0.000679890916217f, -0.026065852493048f, 0.000660045538098f, -0.025682870298624f, + 0.000640493875835f, -0.025299875065684f, 0.000621235987637f, -0.024916863068938f, + 0.000602271873504f, -0.024533838033676f, 0.000583601591643f, -0.024150796234608f, + 0.000565225025639f, -0.023767741397023f, 0.000547142291907f, -0.023384673520923f, + 0.000529353390448f, -0.023001590743661f, 0.000511858321261f, -0.022618494927883f, + 0.000494657084346f, -0.022235386073589f, 0.000477749679703f, -0.021852264180779f, + 0.000461136136437f, -0.021469129249454f, 0.000444816454547f, -0.021085981279612f, + 0.000428790634032f, -0.020702820271254f, 0.000413058703998f, -0.020319648087025f, + 0.000397620693548f, -0.019936462864280f, 0.000382476573577f, -0.019553268328309f, + 0.000367626344087f, -0.019170060753822f, 0.000353070063284f, -0.018786842003465f, + 0.000338807702065f, -0.018403612077236f, 0.000324839289533f, -0.018020370975137f, + 0.000311164796585f, -0.017637118697166f, 0.000297784281429f, -0.017253857105970f, + 0.000284697714960f, -0.016870586201549f, 0.000271905126283f, -0.016487304121256f, + 0.000259406515397f, -0.016104012727737f, 0.000247201882303f, -0.015720712020993f, + 0.000235291256104f, -0.015337402001023f, 0.000223674607696f, -0.014954082667828f, + 0.000212351980736f, -0.014570754021406f, 0.000201323360670f, -0.014187417924404f, + 0.000190588747500f, -0.013804072514176f, 0.000180148170330f, -0.013420719653368f, + 0.000170001629158f, -0.013037359341979f, 0.000160149123985f, -0.012653990648687f, + 0.000150590654812f, -0.012270614504814f, 0.000141326236189f, -0.011887230910361f, + 0.000132355868118f, -0.011503840796649f, 0.000123679565149f, -0.011120444163680f, + 0.000115297327284f, -0.010737040080130f, 0.000107209154521f, -0.010353630408645f, + 0.000099415054137f, -0.009970214217901f, 0.000091915040684f, -0.009586792439222f, + 0.000084709099610f, -0.009203365072608f, 0.000077797252743f, -0.008819932118058f, + 0.000071179500083f, -0.008436493575573f, 0.000064855834353f, -0.008053051307797f, + 0.000058826273744f, -0.007669602986425f, 0.000053090810979f, -0.007286150939763f, + 0.000047649456974f, -0.006902694236487f, 0.000042502211727f, -0.006519233807921f, + 0.000037649078877f, -0.006135769188404f, 0.000033090062061f, -0.005752300843596f, + 0.000028825161280f, -0.005368829704821f, 0.000024854381991f, -0.004985354840755f, + 0.000021177724193f, -0.004601877182722f, 0.000017795191525f, -0.004218397196382f, + 0.000014706784896f, -0.003834914416075f, 0.000011912506125f, -0.003451429307461f, + 0.000009412358850f, -0.003067942336202f, 0.000007206342616f, -0.002684453502297f, + 0.000005294459243f, -0.002300963038579f, 0.000003676709639f, -0.001917471294291f, + 0.000002353095169f, -0.001533978385851f, 0.000001323616516f, -0.001150484546088f, + 0.000000588274133f, -0.000766990066040f, 0.000000147068562f, -0.000383495149435f, + 0.000000000000000f, -0.000000000000023f, 0.000000147068562f, 0.000383495149435f, + 0.000000588274133f, 0.000766990066040f, 0.000001323616516f, 0.001150484546088f, + 0.000002353095169f, 0.001533978385851f, 0.000003676709639f, 0.001917471294291f, + 0.000005294459243f, 0.002300963038579f, 0.000007206342616f, 0.002684453502297f, + 0.000009412358850f, 0.003067942336202f, 0.000011912506125f, 0.003451429307461f, + 0.000014706784896f, 0.003834914416075f, 0.000017795191525f, 0.004218397196382f, + 0.000021177724193f, 0.004601877182722f, 0.000024854381991f, 0.004985354840755f, + 0.000028825161280f, 0.005368829704821f, 0.000033090062061f, 0.005752300843596f, + 0.000037649078877f, 0.006135769188404f, 0.000042502211727f, 0.006519233807921f, + 0.000047649456974f, 0.006902694236487f, 0.000053090810979f, 0.007286150939763f, + 0.000058826273744f, 0.007669602986425f, 0.000064855834353f, 0.008053051307797f, + 0.000071179500083f, 0.008436493575573f, 0.000077797252743f, 0.008819932118058f, + 0.000084709099610f, 0.009203365072608f, 0.000091915040684f, 0.009586792439222f, + 0.000099415054137f, 0.009970214217901f, 0.000107209154521f, 0.010353630408645f, + 0.000115297327284f, 0.010737040080130f, 0.000123679565149f, 0.011120444163680f, + 0.000132355868118f, 0.011503840796649f, 0.000141326236189f, 0.011887230910361f, + 0.000150590654812f, 0.012270614504814f, 0.000160149123985f, 0.012653990648687f, + 0.000170001629158f, 0.013037359341979f, 0.000180148170330f, 0.013420719653368f, + 0.000190588747500f, 0.013804072514176f, 0.000201323360670f, 0.014187417924404f, + 0.000212351980736f, 0.014570754021406f, 0.000223674607696f, 0.014954082667828f, + 0.000235291256104f, 0.015337402001023f, 0.000247201882303f, 0.015720712020993f, + 0.000259406515397f, 0.016104012727737f, 0.000271905126283f, 0.016487304121256f, + 0.000284697714960f, 0.016870586201549f, 0.000297784281429f, 0.017253857105970f, + 0.000311164796585f, 0.017637118697166f, 0.000324839289533f, 0.018020370975137f, + 0.000338807702065f, 0.018403612077236f, 0.000353070063284f, 0.018786842003465f, + 0.000367626344087f, 0.019170060753822f, 0.000382476573577f, 0.019553268328309f, + 0.000397620693548f, 0.019936462864280f, 0.000413058703998f, 0.020319648087025f, + 0.000428790634032f, 0.020702820271254f, 0.000444816454547f, 0.021085981279612f, + 0.000461136136437f, 0.021469129249454f, 0.000477749679703f, 0.021852264180779f, + 0.000494657084346f, 0.022235386073589f, 0.000511858321261f, 0.022618494927883f, + 0.000529353390448f, 0.023001590743661f, 0.000547142291907f, 0.023384673520923f, + 0.000565225025639f, 0.023767741397023f, 0.000583601591643f, 0.024150796234608f, + 0.000602271873504f, 0.024533838033676f, 0.000621235987637f, 0.024916863068938f, + 0.000640493875835f, 0.025299875065684f, 0.000660045538098f, 0.025682870298624f, + 0.000679890916217f, 0.026065852493048f, 0.000700030010194f, 0.026448817923665f, + 0.000720462878235f, 0.026831768453121f, 0.000741189462133f, 0.027214704081416f, + 0.000762209703680f, 0.027597622945905f, 0.000783523661084f, 0.027980525046587f, + 0.000805131276138f, 0.028363410383463f, 0.000827032607049f, 0.028746278956532f, + 0.000849227537401f, 0.029129132628441f, 0.000871716125403f, 0.029511967673898f, + 0.000894498312846f, 0.029894785955548f, 0.000917574157938f, 0.030277585610747f, + 0.000940943544265f, 0.030660368502140f, 0.000964606530033f, 0.031043132767081f, + 0.000988563057035f, 0.031425878405571f, 0.001012813183479f, 0.031808607280254f, + 0.001037356909364f, 0.032191313803196f, 0.001062194118276f, 0.032574005424976f, + 0.001087324810214f, 0.032956674695015f, 0.001112748985179f, 0.033339329063892f, + 0.001138466643170f, 0.033721961081028f, 0.001164477784187f, 0.034104570746422f, + 0.001190782408230f, 0.034487165510654f, 0.001217380515300f, 0.034869734197855f, + 0.001244271872565f, 0.035252287983894f, 0.001271456829272f, 0.035634815692902f, + 0.001298935036175f, 0.036017324775457f, 0.001326706726104f, 0.036399815231562f, + 0.001354771666229f, 0.036782283335924f, 0.001383129972965f, 0.037164725363255f, + 0.001411781646311f, 0.037547148764133f, 0.001440726569854f, 0.037929553538561f, + 0.001469964860007f, 0.038311932235956f, 0.001499496400356f, 0.038694288581610f, + 0.001529321074486f, 0.039076622575521f, 0.001559439115226f, 0.039458930492401f, + 0.001589850406162f, 0.039841219782829f, 0.001620554830879f, 0.040223482996225f, + 0.001651552389376f, 0.040605723857880f, 0.001682843198068f, 0.040987938642502f, + 0.001714427140541f, 0.041370131075382f, 0.001746304216795f, 0.041752301156521f, + 0.001778474310413f, 0.042134445160627f, 0.001810937537812f, 0.042516563087702f, + 0.001843693898991f, 0.042898654937744f, 0.001876743277535f, 0.043280724436045f, + 0.001910085673444f, 0.043662767857313f, 0.001943721086718f, 0.044044785201550f, + 0.001977649517357f, 0.044426776468754f, 0.002011870965362f, 0.044808741658926f, + 0.002046385314316f, 0.045190680772066f, 0.002081192564219f, 0.045572593808174f, + 0.002116292715073f, 0.045954477041960f, 0.002151685766876f, 0.046336337924004f, + 0.002187371719629f, 0.046718169003725f, 0.002223350573331f, 0.047099970281124f, + 0.002259622327983f, 0.047481749206781f, 0.002296186750755f, 0.047863494604826f, + 0.002333043841645f, 0.048245213925838f, 0.002370193833485f, 0.048626907169819f, + 0.002407636726275f, 0.049008570611477f, 0.002445372054353f, 0.049390204250813f, + 0.002483400283381f, 0.049771808087826f, 0.002521721180528f, 0.050153385847807f, + 0.002560334512964f, 0.050534930080175f, 0.002599240746349f, 0.050916448235512f, + 0.002638439415023f, 0.051297932863235f, 0.002677930751815f, 0.051679391413927f, + 0.002717714523897f, 0.052060816437006f, 0.002757790964097f, 0.052442211657763f, + 0.002798160072416f, 0.052823577076197f, 0.002838821383193f, 0.053204908967018f, + 0.002879775362089f, 0.053586211055517f, 0.002921021543443f, 0.053967483341694f, + 0.002962560392916f, 0.054348722100258f, 0.003004391444847f, 0.054729927331209f, + 0.003046514932066f, 0.055111102759838f, 0.003088930854574f, 0.055492244660854f, + 0.003131638979539f, 0.055873356759548f, 0.003174639539793f, 0.056254431605339f, + 0.003217932302505f, 0.056635476648808f, 0.003261517267674f, 0.057016488164663f, + 0.003305394435301f, 0.057397462427616f, 0.003349563805386f, 0.057778406888247f, + 0.003394025377929f, 0.058159314095974f, 0.003438779152930f, 0.058540191501379f, + 0.003483824897557f, 0.058921031653881f, 0.003529162844643f, 0.059301838278770f, + 0.003574792761356f, 0.059682607650757f, 0.003620714880526f, 0.060063343495131f, + 0.003666928736493f, 0.060444042086601f, 0.003713434794918f, 0.060824707150459f, + 0.003760232590139f, 0.061205338686705f, 0.003807322587818f, 0.061585929244757f, + 0.003854704322293f, 0.061966486275196f, 0.003902378026396f, 0.062347009778023f, + 0.003950343467295f, 0.062727488577366f, 0.003998600877821f, 0.063107937574387f, + 0.004047149792314f, 0.063488349318504f, 0.004095990676433f, 0.063868723809719f, + 0.004145123064518f, 0.064249053597450f, 0.004194547422230f, 0.064629353582859f, + 0.004244263283908f, 0.065009608864784f, 0.004294271115214f, 0.065389834344387f, + 0.004344569984823f, 0.065770015120506f, 0.004395160824060f, 0.066150158643723f, + 0.004446043167263f, 0.066530264914036f, 0.004497217014432f, 0.066910326480865f, + 0.004548682365566f, 0.067290350794792f, 0.004600439220667f, 0.067670337855816f, + 0.004652487114072f, 0.068050287663937f, 0.004704826977104f, 0.068430192768574f, + 0.004757457878441f, 0.068810060620308f, 0.004810380283743f, 0.069189883768559f, + 0.004863593727350f, 0.069569669663906f, 0.004917098674923f, 0.069949418306351f, + 0.004970894660801f, 0.070329122245312f, 0.005024982150644f, 0.070708781480789f, + 0.005079360678792f, 0.071088403463364f, 0.005134030245245f, 0.071467980742455f, + 0.005188991315663f, 0.071847513318062f, 0.005244242958724f, 0.072227008640766f, + 0.005299786105752f, 0.072606459259987f, 0.005355620291084f, 0.072985872626305f, + 0.005411745049059f, 0.073365233838558f, 0.005468160845339f, 0.073744557797909f, + 0.005524867679924f, 0.074123837053776f, 0.005581865552813f, 0.074503071606159f, + 0.005639153998345f, 0.074882268905640f, 0.005696733482182f, 0.075261414051056f, + 0.005754603538662f, 0.075640521943569f, 0.005812764633447f, 0.076019577682018f, + 0.005871216300875f, 0.076398596167564f, 0.005929958540946f, 0.076777562499046f, + 0.005988991353661f, 0.077156484127045f, 0.006048315204680f, 0.077535368502140f, + 0.006107929162681f, 0.077914200723171f, 0.006167833693326f, 0.078292988240719f, + 0.006228029262275f, 0.078671731054783f, 0.006288514938205f, 0.079050421714783f, + 0.006349290721118f, 0.079429075121880f, 0.006410357542336f, 0.079807676374912f, + 0.006471714470536f, 0.080186225473881f, 0.006533361505717f, 0.080564737319946f, + 0.006595299113542f, 0.080943197011948f, 0.006657526828349f, 0.081321612000465f, + 0.006720044650137f, 0.081699974834919f, 0.006782853044569f, 0.082078292965889f, + 0.006845951545984f, 0.082456558942795f, 0.006909339688718f, 0.082834780216217f, + 0.006973018404096f, 0.083212949335575f, 0.007036986760795f, 0.083591073751450f, + 0.007101245224476f, 0.083969146013260f, 0.007165793795139f, 0.084347173571587f, + 0.007230632472783f, 0.084725148975849f, 0.007295760791749f, 0.085103072226048f, + 0.007361178752035f, 0.085480943322182f, 0.007426886819303f, 0.085858769714832f, + 0.007492884527892f, 0.086236543953419f, 0.007559171877801f, 0.086614266037941f, + 0.007625748869032f, 0.086991935968399f, 0.007692615967244f, 0.087369553744793f, + 0.007759772241116f, 0.087747126817703f, 0.007827218621969f, 0.088124647736549f, + 0.007894953712821f, 0.088502109050751f, 0.007962978444993f, 0.088879525661469f, + 0.008031292818487f, 0.089256882667542f, 0.008099896833301f, 0.089634194970131f, + 0.008168790489435f, 0.090011447668076f, 0.008237972855568f, 0.090388655662537f, + 0.008307444863021f, 0.090765804052353f, 0.008377205580473f, 0.091142900288105f, + 0.008447255939245f, 0.091519944369793f, 0.008517595939338f, 0.091896936297417f, + 0.008588224649429f, 0.092273868620396f, 0.008659142069519f, 0.092650748789310f, + 0.008730349130929f, 0.093027576804161f, 0.008801844902337f, 0.093404345214367f, + 0.008873629383743f, 0.093781061470509f, 0.008945702575147f, 0.094157725572586f, + 0.009018065407872f, 0.094534330070019f, 0.009090716950595f, 0.094910882413387f, + 0.009163657203317f, 0.095287375152111f, 0.009236886166036f, 0.095663815736771f, + 0.009310402907431f, 0.096040196716785f, 0.009384209290147f, 0.096416525542736f, + 0.009458304382861f, 0.096792794764042f, 0.009532688185573f, 0.097169004380703f, + 0.009607359766960f, 0.097545161843300f, 0.009682320058346f, 0.097921259701252f, + 0.009757569059730f, 0.098297297954559f, 0.009833106771111f, 0.098673284053802f, + 0.009908932261169f, 0.099049203097820f, 0.009985045529902f, 0.099425069987774f, + 0.010061448439956f, 0.099800877273083f, 0.010138138197362f, 0.100176624953747f, + 0.010215117596090f, 0.100552320480347f, 0.010292383842170f, 0.100927948951721f, + 0.010369938798249f, 0.101303517818451f, 0.010447781533003f, 0.101679034531116f, + 0.010525912046432f, 0.102054484188557f, 0.010604331269860f, 0.102429874241352f, + 0.010683037340641f, 0.102805204689503f, 0.010762032121420f, 0.103180475533009f, + 0.010841314680874f, 0.103555686771870f, 0.010920885019004f, 0.103930838406086f, + 0.011000742204487f, 0.104305922985077f, 0.011080888099968f, 0.104680955410004f, + 0.011161320842803f, 0.105055920779705f, 0.011242041364312f, 0.105430819094181f, + 0.011323049664497f, 0.105805665254593f, 0.011404345743358f, 0.106180444359779f, + 0.011485928669572f, 0.106555156409740f, 0.011567799374461f, 0.106929816305637f, + 0.011649956926703f, 0.107304409146309f, 0.011732402257621f, 0.107678934931755f, + 0.011815134435892f, 0.108053401112556f, 0.011898153461516f, 0.108427800238132f, + 0.011981460265815f, 0.108802139759064f, 0.012065053917468f, 0.109176412224770f, + 0.012148935347795f, 0.109550617635250f, 0.012233102694154f, 0.109924763441086f, + 0.012317557819188f, 0.110298842191696f, 0.012402298860252f, 0.110672861337662f, + 0.012487327679992f, 0.111046813428402f, 0.012572642415762f, 0.111420698463917f, + 0.012658244930208f, 0.111794516444206f, 0.012744133360684f, 0.112168267369270f, + 0.012830308638513f, 0.112541958689690f, 0.012916770763695f, 0.112915575504303f, + 0.013003518804908f, 0.113289132714272f, 0.013090553693473f, 0.113662622869015f, + 0.013177875429392f, 0.114036038517952f, 0.013265483081341f, 0.114409394562244f, + 0.013353376649320f, 0.114782683551311f, 0.013441557064652f, 0.115155905485153f, + 0.013530024327338f, 0.115529052913189f, 0.013618776574731f, 0.115902140736580f, + 0.013707815669477f, 0.116275154054165f, 0.013797140680254f, 0.116648100316525f, + 0.013886751607060f, 0.117020979523659f, 0.013976648449898f, 0.117393791675568f, + 0.014066831208766f, 0.117766529321671f, 0.014157299883664f, 0.118139199912548f, + 0.014248054474592f, 0.118511803448200f, 0.014339094981551f, 0.118884332478046f, + 0.014430420473218f, 0.119256794452667f, 0.014522032812238f, 0.119629189372063f, + 0.014613929204643f, 0.120001509785652f, 0.014706112444401f, 0.120373763144016f, + 0.014798580668867f, 0.120745941996574f, 0.014891333878040f, 0.121118053793907f, + 0.014984373003244f, 0.121490091085434f, 0.015077698044479f, 0.121862053871155f, + 0.015171307139099f, 0.122233949601650f, 0.015265202149749f, 0.122605770826340f, + 0.015359382145107f, 0.122977524995804f, 0.015453847125173f, 0.123349204659462f, + 0.015548598021269f, 0.123720809817314f, 0.015643632039428f, 0.124092340469360f, + 0.015738952904940f, 0.124463804066181f, 0.015834558755159f, 0.124835193157196f, + 0.015930447727442f, 0.125206500291824f, 0.016026621684432f, 0.125577747821808f, + 0.016123080626130f, 0.125948905944824f, 0.016219824552536f, 0.126320004463196f, + 0.016316853463650f, 0.126691013574600f, 0.016414167359471f, 0.127061963081360f, + 0.016511764377356f, 0.127432823181152f, 0.016609646379948f, 0.127803623676300f, + 0.016707813367248f, 0.128174334764481f, 0.016806263476610f, 0.128544986248016f, + 0.016904998570681f, 0.128915548324585f, 0.017004016786814f, 0.129286035895348f, + 0.017103319987655f, 0.129656463861465f, 0.017202908173203f, 0.130026802420616f, + 0.017302779480815f, 0.130397051572800f, 0.017402933910489f, 0.130767241120338f, + 0.017503373324871f, 0.131137356162071f, 0.017604095861316f, 0.131507381796837f, + 0.017705103382468f, 0.131877332925797f, 0.017806394025683f, 0.132247209548950f, + 0.017907967790961f, 0.132617011666298f, 0.018009826540947f, 0.132986739277840f, + 0.018111966550350f, 0.133356377482414f, 0.018214391544461f, 0.133725941181183f, + 0.018317099660635f, 0.134095430374146f, 0.018420090898871f, 0.134464830160141f, + 0.018523367121816f, 0.134834155440331f, 0.018626924604177f, 0.135203406214714f, + 0.018730765208602f, 0.135572582483292f, 0.018834890797734f, 0.135941669344902f, + 0.018939297646284f, 0.136310681700706f, 0.019043987616897f, 0.136679604649544f, + 0.019148962572217f, 0.137048453092575f, 0.019254218786955f, 0.137417227029800f, + 0.019359756261110f, 0.137785911560059f, 0.019465578719974f, 0.138154521584511f, + 0.019571684300900f, 0.138523042201996f, 0.019678071141243f, 0.138891488313675f, + 0.019784741103649f, 0.139259845018387f, 0.019891692325473f, 0.139628127217293f, + 0.019998926669359f, 0.139996320009232f, 0.020106444135308f, 0.140364438295364f, + 0.020214242860675f, 0.140732467174530f, 0.020322324708104f, 0.141100421547890f, + 0.020430689677596f, 0.141468286514282f, 0.020539334043860f, 0.141836062073708f, + 0.020648263394833f, 0.142203763127327f, 0.020757472142577f, 0.142571389675140f, + 0.020866964012384f, 0.142938911914825f, 0.020976737141609f, 0.143306359648705f, + 0.021086793392897f, 0.143673732876778f, 0.021197130903602f, 0.144041016697884f, + 0.021307749673724f, 0.144408211112022f, 0.021418649703264f, 0.144775316119194f, + 0.021529832854867f, 0.145142331719399f, 0.021641295403242f, 0.145509272813797f, + 0.021753041073680f, 0.145876124501228f, 0.021865066140890f, 0.146242901682854f, + 0.021977374330163f, 0.146609574556351f, 0.022089963778853f, 0.146976172924042f, + 0.022202832624316f, 0.147342681884766f, 0.022315984591842f, 0.147709101438522f, + 0.022429415956140f, 0.148075446486473f, 0.022543128579855f, 0.148441687226295f, + 0.022657122462988f, 0.148807853460312f, 0.022771397605538f, 0.149173930287361f, + 0.022885952144861f, 0.149539917707443f, 0.023000787943602f, 0.149905815720558f, + 0.023115905001760f, 0.150271624326706f, 0.023231301456690f, 0.150637343525887f, + 0.023346979171038f, 0.151002973318100f, 0.023462938144803f, 0.151368513703346f, + 0.023579176515341f, 0.151733979582787f, 0.023695694282651f, 0.152099341154099f, + 0.023812493309379f, 0.152464613318443f, 0.023929571732879f, 0.152829796075821f, + 0.024046931415796f, 0.153194904327393f, 0.024164570495486f, 0.153559908270836f, + 0.024282488971949f, 0.153924822807312f, 0.024400688707829f, 0.154289647936821f, + 0.024519165977836f, 0.154654383659363f, 0.024637924507260f, 0.155019029974937f, + 0.024756962433457f, 0.155383571982384f, 0.024876279756427f, 0.155748039484024f, + 0.024995878338814f, 0.156112402677536f, 0.025115754455328f, 0.156476691365242f, + 0.025235909968615f, 0.156840875744820f, 0.025356344878674f, 0.157204970717430f, + 0.025477059185505f, 0.157568961381912f, 0.025598052889109f, 0.157932877540588f, + 0.025719324126840f, 0.158296689391136f, 0.025840876623988f, 0.158660411834717f, + 0.025962706655264f, 0.159024044871330f, 0.026084816083312f, 0.159387573599815f, + 0.026207204908133f, 0.159751012921333f, 0.026329871267080f, 0.160114362835884f, + 0.026452817022800f, 0.160477623343468f, 0.026576040312648f, 0.160840779542923f, + 0.026699542999268f, 0.161203846335411f, 0.026823325082660f, 0.161566808819771f, + 0.026947384700179f, 0.161929681897163f, 0.027071721851826f, 0.162292465567589f, + 0.027196336537600f, 0.162655144929886f, 0.027321230620146f, 0.163017734885216f, + 0.027446404099464f, 0.163380220532417f, 0.027571853250265f, 0.163742616772652f, + 0.027697581797838f, 0.164104923605919f, 0.027823587879539f, 0.164467126131058f, + 0.027949871495366f, 0.164829224348068f, 0.028076432645321f, 0.165191248059273f, + 0.028203271329403f, 0.165553152561188f, 0.028330387547612f, 0.165914967656136f, + 0.028457781299949f, 0.166276678442955f, 0.028585452586412f, 0.166638299822807f, + 0.028713401407003f, 0.166999831795692f, 0.028841627761722f, 0.167361244559288f, + 0.028970129787922f, 0.167722567915916f, 0.029098909348249f, 0.168083801865578f, + 0.029227968305349f, 0.168444931507111f, 0.029357301071286f, 0.168805956840515f, + 0.029486913233995f, 0.169166877865791f, 0.029616801068187f, 0.169527709484100f, + 0.029746964573860f, 0.169888436794281f, 0.029877405613661f, 0.170249074697495f, + 0.030008124187589f, 0.170609608292580f, 0.030139118432999f, 0.170970037579536f, + 0.030270388349891f, 0.171330362558365f, 0.030401935800910f, 0.171690583229065f, + 0.030533758923411f, 0.172050714492798f, 0.030665857717395f, 0.172410741448402f, + 0.030798232182860f, 0.172770664095879f, 0.030930884182453f, 0.173130482435226f, + 0.031063811853528f, 0.173490211367607f, 0.031197015196085f, 0.173849821090698f, + 0.031330492347479f, 0.174209341406822f, 0.031464248895645f, 0.174568757414818f, + 0.031598277390003f, 0.174928069114685f, 0.031732585281134f, 0.175287276506424f, + 0.031867165118456f, 0.175646379590034f, 0.032002024352551f, 0.176005378365517f, + 0.032137155532837f, 0.176364272832870f, 0.032272562384605f, 0.176723077893257f, + 0.032408244907856f, 0.177081763744354f, 0.032544203102589f, 0.177440345287323f, + 0.032680433243513f, 0.177798837423325f, 0.032816942781210f, 0.178157210350037f, + 0.032953724265099f, 0.178515478968620f, 0.033090781420469f, 0.178873643279076f, + 0.033228114247322f, 0.179231703281403f, 0.033365719020367f, 0.179589673876762f, + 0.033503599464893f, 0.179947525262833f, 0.033641755580902f, 0.180305257439613f, + 0.033780183643103f, 0.180662900209427f, 0.033918887376785f, 0.181020438671112f, + 0.034057866781950f, 0.181377857923508f, 0.034197118133307f, 0.181735187768936f, + 0.034336645156145f, 0.182092398405075f, 0.034476444125175f, 0.182449504733086f, + 0.034616518765688f, 0.182806491851807f, 0.034756865352392f, 0.183163389563560f, + 0.034897487610579f, 0.183520168066025f, 0.035038381814957f, 0.183876842260361f, + 0.035179551690817f, 0.184233412146568f, 0.035320993512869f, 0.184589877724648f, + 0.035462711006403f, 0.184946224093437f, 0.035604696720839f, 0.185302466154099f, + 0.035746958106756f, 0.185658603906631f, 0.035889495164156f, 0.186014622449875f, + 0.036032304167747f, 0.186370536684990f, 0.036175385117531f, 0.186726331710815f, + 0.036318738013506f, 0.187082037329674f, 0.036462362855673f, 0.187437608838081f, + 0.036606263369322f, 0.187793090939522f, 0.036750435829163f, 0.188148453831673f, + 0.036894880235195f, 0.188503712415695f, 0.037039596587420f, 0.188858851790428f, + 0.037184584885836f, 0.189213871955872f, 0.037329845130444f, 0.189568802714348f, + 0.037475381046534f, 0.189923599362373f, 0.037621185183525f, 0.190278306603432f, + 0.037767261266708f, 0.190632879734039f, 0.037913613021374f, 0.190987363457680f, + 0.038060232996941f, 0.191341713070869f, 0.038207128643990f, 0.191695958375931f, + 0.038354292511940f, 0.192050099372864f, 0.038501728326082f, 0.192404121160507f, + 0.038649436086416f, 0.192758023738861f, 0.038797415792942f, 0.193111822009087f, + 0.038945667445660f, 0.193465501070023f, 0.039094187319279f, 0.193819075822830f, + 0.039242979139090f, 0.194172516465187f, 0.039392042905092f, 0.194525867700577f, + 0.039541378617287f, 0.194879084825516f, 0.039690986275673f, 0.195232197642326f, + 0.039840862154961f, 0.195585191249847f, 0.039991009980440f, 0.195938065648079f, + 0.040141426026821f, 0.196290835738182f, 0.040292114019394f, 0.196643486618996f, + 0.040443073958158f, 0.196996018290520f, 0.040594302117825f, 0.197348430752754f, + 0.040745802223682f, 0.197700738906860f, 0.040897574275732f, 0.198052927851677f, + 0.041049610823393f, 0.198404997587204f, 0.041201923042536f, 0.198756948113441f, + 0.041354499757290f, 0.199108779430389f, 0.041507352143526f, 0.199460506439209f, + 0.041660469025373f, 0.199812099337578f, 0.041813857853413f, 0.200163587927818f, + 0.041967518627644f, 0.200514942407608f, 0.042121443897486f, 0.200866192579269f, + 0.042275641113520f, 0.201217323541641f, 0.042430106550455f, 0.201568335294724f, + 0.042584843933582f, 0.201919227838516f, 0.042739849537611f, 0.202270001173019f, + 0.042895123362541f, 0.202620655298233f, 0.043050665408373f, 0.202971190214157f, + 0.043206475675106f, 0.203321605920792f, 0.043362557888031f, 0.203671902418137f, + 0.043518904596567f, 0.204022079706192f, 0.043675523251295f, 0.204372137784958f, + 0.043832406401634f, 0.204722076654434f, 0.043989561498165f, 0.205071896314621f, + 0.044146984815598f, 0.205421581864357f, 0.044304672628641f, 0.205771163105965f, + 0.044462632387877f, 0.206120610237122f, 0.044620860368013f, 0.206469938158989f, + 0.044779352843761f, 0.206819161772728f, 0.044938117265701f, 0.207168251276016f, + 0.045097146183252f, 0.207517206668854f, 0.045256443321705f, 0.207866057753563f, + 0.045416008681059f, 0.208214774727821f, 0.045575842261314f, 0.208563387393951f, + 0.045735940337181f, 0.208911851048470f, 0.045896306633949f, 0.209260210394859f, + 0.046056941151619f, 0.209608450531960f, 0.046217843890190f, 0.209956556558609f, + 0.046379011124372f, 0.210304543375969f, 0.046540446579456f, 0.210652396082878f, + 0.046702146530151f, 0.211000129580498f, 0.046864114701748f, 0.211347743868828f, + 0.047026351094246f, 0.211695238947868f, 0.047188851982355f, 0.212042599916458f, + 0.047351621091366f, 0.212389841675758f, 0.047514654695988f, 0.212736949324608f, + 0.047677956521511f, 0.213083937764168f, 0.047841522842646f, 0.213430806994438f, + 0.048005353659391f, 0.213777542114258f, 0.048169452697039f, 0.214124158024788f, + 0.048333816230297f, 0.214470639824867f, 0.048498444259167f, 0.214817002415657f, + 0.048663340508938f, 0.215163245797157f, 0.048828501254320f, 0.215509355068207f, + 0.048993926495314f, 0.215855330228806f, 0.049159619957209f, 0.216201186180115f, + 0.049325577914715f, 0.216546908020973f, 0.049491796642542f, 0.216892510652542f, + 0.049658283591270f, 0.217237979173660f, 0.049825038760900f, 0.217583328485489f, + 0.049992054700851f, 0.217928543686867f, 0.050159335136414f, 0.218273624777794f, + 0.050326880067587f, 0.218618586659431f, 0.050494693219662f, 0.218963414430618f, + 0.050662767142057f, 0.219308122992516f, 0.050831105560064f, 0.219652697443962f, + 0.050999708473682f, 0.219997137784958f, 0.051168579608202f, 0.220341444015503f, + 0.051337707787752f, 0.220685631036758f, 0.051507104188204f, 0.221029683947563f, + 0.051676765084267f, 0.221373617649078f, 0.051846686750650f, 0.221717402338982f, + 0.052016876637936f, 0.222061067819595f, 0.052187327295542f, 0.222404599189758f, + 0.052358038723469f, 0.222748011350632f, 0.052529018372297f, 0.223091274499893f, + 0.052700258791447f, 0.223434418439865f, 0.052871759980917f, 0.223777428269386f, + 0.053043525665998f, 0.224120303988457f, 0.053215555846691f, 0.224463045597076f, + 0.053387850522995f, 0.224805667996407f, 0.053560405969620f, 0.225148141384125f, + 0.053733222186565f, 0.225490495562553f, 0.053906302899122f, 0.225832715630531f, + 0.054079644382000f, 0.226174786686897f, 0.054253250360489f, 0.226516738533974f, + 0.054427117109299f, 0.226858556270599f, 0.054601248353720f, 0.227200239896774f, + 0.054775636643171f, 0.227541789412498f, 0.054950293153524f, 0.227883204817772f, + 0.055125206708908f, 0.228224486112595f, 0.055300384759903f, 0.228565633296967f, + 0.055475823581219f, 0.228906646370888f, 0.055651523172855f, 0.229247525334358f, + 0.055827483534813f, 0.229588270187378f, 0.056003704667091f, 0.229928880929947f, + 0.056180190294981f, 0.230269357562065f, 0.056356932967901f, 0.230609700083733f, + 0.056533940136433f, 0.230949893593788f, 0.056711208075285f, 0.231289967894554f, + 0.056888736784458f, 0.231629893183708f, 0.057066522538662f, 0.231969684362412f, + 0.057244572788477f, 0.232309341430664f, 0.057422880083323f, 0.232648864388466f, + 0.057601451873779f, 0.232988253235817f, 0.057780280709267f, 0.233327493071556f, + 0.057959370315075f, 0.233666598796844f, 0.058138720691204f, 0.234005570411682f, + 0.058318331837654f, 0.234344407916069f, 0.058498200029135f, 0.234683111310005f, + 0.058678328990936f, 0.235021665692329f, 0.058858718723059f, 0.235360085964203f, + 0.059039369225502f, 0.235698372125626f, 0.059220276772976f, 0.236036509275436f, + 0.059401445090771f, 0.236374512314796f, 0.059582870453596f, 0.236712381243706f, + 0.059764556586742f, 0.237050101161003f, 0.059946499764919f, 0.237387686967850f, + 0.060128703713417f, 0.237725138664246f, 0.060311164706945f, 0.238062441349030f, + 0.060493886470795f, 0.238399609923363f, 0.060676865279675f, 0.238736644387245f, + 0.060860104858875f, 0.239073529839516f, 0.061043601483107f, 0.239410281181335f, + 0.061227355152369f, 0.239746883511543f, 0.061411365866661f, 0.240083336830139f, + 0.061595637351274f, 0.240419670939446f, 0.061780165880919f, 0.240755841135979f, + 0.061964951455593f, 0.241091892123222f, 0.062149997800589f, 0.241427779197693f, + 0.062335297465324f, 0.241763532161713f, 0.062520854175091f, 0.242099151015282f, + 0.062706671655178f, 0.242434620857239f, 0.062892749905586f, 0.242769956588745f, + 0.063079081475735f, 0.243105143308640f, 0.063265666365623f, 0.243440181016922f, + 0.063452512025833f, 0.243775084614754f, 0.063639611005783f, 0.244109839200974f, + 0.063826970756054f, 0.244444444775581f, 0.064014583826065f, 0.244778916239738f, + 0.064202457666397f, 0.245113238692284f, 0.064390584826469f, 0.245447427034378f, + 0.064578965306282f, 0.245781451463699f, 0.064767606556416f, 0.246115356683731f, + 0.064956501126289f, 0.246449097990990f, 0.065145656466484f, 0.246782705187798f, + 0.065335065126419f, 0.247116148471832f, 0.065524727106094f, 0.247449472546577f, + 0.065714649856091f, 0.247782632708550f, 0.065904818475246f, 0.248115643858910f, + 0.066095255315304f, 0.248448520898819f, 0.066285938024521f, 0.248781248927116f, + 0.066476874053478f, 0.249113827943802f, 0.066668070852757f, 0.249446272850037f, + 0.066859520971775f, 0.249778553843498f, 0.067051224410534f, 0.250110685825348f, + 0.067243188619614f, 0.250442683696747f, 0.067435398697853f, 0.250774532556534f, + 0.067627869546413f, 0.251106232404709f, 0.067820593714714f, 0.251437783241272f, + 0.068013571202755f, 0.251769185066223f, 0.068206802010536f, 0.252100437879562f, + 0.068400286138058f, 0.252431541681290f, 0.068594031035900f, 0.252762526273727f, + 0.068788021802902f, 0.253093332052231f, 0.068982265889645f, 0.253423988819122f, + 0.069176770746708f, 0.253754496574402f, 0.069371521472931f, 0.254084855318069f, + 0.069566532969475f, 0.254415065050125f, 0.069761790335178f, 0.254745125770569f, + 0.069957308471203f, 0.255075037479401f, 0.070153072476387f, 0.255404800176620f, + 0.070349089801311f, 0.255734413862228f, 0.070545360445976f, 0.256063878536224f, + 0.070741884410381f, 0.256393194198608f, 0.070938661694527f, 0.256722360849380f, + 0.071135692298412f, 0.257051378488541f, 0.071332976222038f, 0.257380217313766f, + 0.071530513465405f, 0.257708936929703f, 0.071728296577930f, 0.258037507534027f, + 0.071926333010197f, 0.258365899324417f, 0.072124622762203f, 0.258694142103195f, + 0.072323165833950f, 0.259022265672684f, 0.072521962225437f, 0.259350210428238f, + 0.072721004486084f, 0.259678006172180f, 0.072920300066471f, 0.260005623102188f, + 0.073119848966599f, 0.260333120822906f, 0.073319651186466f, 0.260660469532013f, + 0.073519699275494f, 0.260987639427185f, 0.073720000684261f, 0.261314690113068f, + 0.073920547962189f, 0.261641561985016f, 0.074121348559856f, 0.261968284845352f, + 0.074322402477264f, 0.262294828891754f, 0.074523709714413f, 0.262621253728867f, + 0.074725262820721f, 0.262947499752045f, 0.074927061796188f, 0.263273626565933f, + 0.075129114091396f, 0.263599574565887f, 0.075331419706345f, 0.263925373554230f, + 0.075533971190453f, 0.264250993728638f, 0.075736775994301f, 0.264576494693756f, + 0.075939826667309f, 0.264901816844940f, 0.076143130660057f, 0.265226989984512f, + 0.076346680521965f, 0.265552014112473f, 0.076550483703613f, 0.265876859426498f, + 0.076754532754421f, 0.266201555728912f, 0.076958827674389f, 0.266526103019714f, + 0.077163375914097f, 0.266850501298904f, 0.077368170022964f, 0.267174720764160f, + 0.077573217451572f, 0.267498821020126f, 0.077778510749340f, 0.267822742462158f, + 0.077984049916267f, 0.268146485090256f, 0.078189842402935f, 0.268470078706741f, + 0.078395880758762f, 0.268793523311615f, 0.078602164983749f, 0.269116818904877f, + 0.078808702528477f, 0.269439965486526f, 0.079015478491783f, 0.269762933254242f, + 0.079222507774830f, 0.270085722208023f, 0.079429790377617f, 0.270408391952515f, + 0.079637311398983f, 0.270730882883072f, 0.079845085740089f, 0.271053224802017f, + 0.080053105950356f, 0.271375387907028f, 0.080261372029781f, 0.271697402000427f, + 0.080469883978367f, 0.272019267082214f, 0.080678641796112f, 0.272340953350067f, + 0.080887645483017f, 0.272662490606308f, 0.081096902489662f, 0.272983878850937f, + 0.081306397914886f, 0.273305088281631f, 0.081516146659851f, 0.273626148700714f, + 0.081726133823395f, 0.273947030305862f, 0.081936374306679f, 0.274267762899399f, + 0.082146860659122f, 0.274588316679001f, 0.082357585430145f, 0.274908751249313f, + 0.082568563520908f, 0.275228977203369f, 0.082779780030251f, 0.275549083948135f, + 0.082991249859333f, 0.275868982076645f, 0.083202958106995f, 0.276188760995865f, + 0.083414919674397f, 0.276508361101151f, 0.083627119660378f, 0.276827782392502f, + 0.083839565515518f, 0.277147054672241f, 0.084052257239819f, 0.277466177940369f, + 0.084265194833279f, 0.277785122394562f, 0.084478378295898f, 0.278103888034821f, + 0.084691800177097f, 0.278422504663467f, 0.084905467927456f, 0.278740972280502f, + 0.085119381546974f, 0.279059261083603f, 0.085333541035652f, 0.279377400875092f, + 0.085547938942909f, 0.279695361852646f, 0.085762590169907f, 0.280013144016266f, + 0.085977479815483f, 0.280330777168274f, 0.086192607879639f, 0.280648261308670f, + 0.086407989263535f, 0.280965566635132f, 0.086623609066010f, 0.281282693147659f, + 0.086839467287064f, 0.281599670648575f, 0.087055571377277f, 0.281916469335556f, + 0.087271921336651f, 0.282233119010925f, 0.087488517165184f, 0.282549589872360f, + 0.087705351412296f, 0.282865911722183f, 0.087922424077988f, 0.283182054758072f, + 0.088139742612839f, 0.283498018980026f, 0.088357307016850f, 0.283813834190369f, + 0.088575109839439f, 0.284129470586777f, 0.088793158531189f, 0.284444957971573f, + 0.089011445641518f, 0.284760266542435f, 0.089229971170425f, 0.285075396299362f, + 0.089448742568493f, 0.285390377044678f, 0.089667752385139f, 0.285705178976059f, + 0.089887008070946f, 0.286019802093506f, 0.090106502175331f, 0.286334276199341f, + 0.090326242148876f, 0.286648571491241f, 0.090546220541000f, 0.286962717771530f, + 0.090766437351704f, 0.287276685237885f, 0.090986892580986f, 0.287590473890305f, + 0.091207593679428f, 0.287904083728790f, 0.091428533196449f, 0.288217544555664f, + 0.091649711132050f, 0.288530826568604f, 0.091871134936810f, 0.288843959569931f, + 0.092092797160149f, 0.289156883955002f, 0.092314697802067f, 0.289469659328461f, + 0.092536836862564f, 0.289782285690308f, 0.092759214341640f, 0.290094703435898f, + 0.092981837689877f, 0.290406972169876f, 0.093204692006111f, 0.290719062089920f, + 0.093427792191505f, 0.291031002998352f, 0.093651130795479f, 0.291342735290527f, + 0.093874707818031f, 0.291654318571091f, 0.094098523259163f, 0.291965723037720f, + 0.094322577118874f, 0.292276978492737f, 0.094546869397163f, 0.292588025331497f, + 0.094771400094032f, 0.292898923158646f, 0.094996169209480f, 0.293209642171860f, + 0.095221176743507f, 0.293520182371140f, 0.095446422696114f, 0.293830573558807f, + 0.095671907067299f, 0.294140785932541f, 0.095897629857063f, 0.294450789690018f, + 0.096123591065407f, 0.294760644435883f, 0.096349790692329f, 0.295070350170136f, + 0.096576221287251f, 0.295379847288132f, 0.096802897751331f, 0.295689195394516f, + 0.097029805183411f, 0.295998334884644f, 0.097256951034069f, 0.296307325363159f, + 0.097484335303307f, 0.296616137027740f, 0.097711957991123f, 0.296924799680710f, + 0.097939811646938f, 0.297233253717422f, 0.098167903721333f, 0.297541528940201f, + 0.098396234214306f, 0.297849655151367f, 0.098624803125858f, 0.298157602548599f, + 0.098853603005409f, 0.298465341329575f, 0.099082641303539f, 0.298772931098938f, + 0.099311910569668f, 0.299080342054367f, 0.099541425704956f, 0.299387603998184f, + 0.099771171808243f, 0.299694657325745f, 0.100001148879528f, 0.300001531839371f, + 0.100231364369392f, 0.300308227539063f, 0.100461818277836f, 0.300614774227142f, + 0.100692503154278f, 0.300921112298965f, 0.100923426449299f, 0.301227301359177f, + 0.101154580712318f, 0.301533311605453f, 0.101385973393917f, 0.301839113235474f, + 0.101617597043514f, 0.302144765853882f, 0.101849451661110f, 0.302450239658356f, + 0.102081544697285f, 0.302755534648895f, 0.102313876152039f, 0.303060621023178f, + 0.102546438574791f, 0.303365558385849f, 0.102779231965542f, 0.303670316934586f, + 0.103012263774872f, 0.303974896669388f, 0.103245526552200f, 0.304279297590256f, + 0.103479020297527f, 0.304583519697189f, 0.103712752461433f, 0.304887533187866f, + 0.103946708142757f, 0.305191397666931f, 0.104180909693241f, 0.305495083332062f, + 0.104415334761143f, 0.305798590183258f, 0.104649998247623f, 0.306101888418198f, + 0.104884892702103f, 0.306405037641525f, 0.105120018124580f, 0.306708008050919f, + 0.105355374515057f, 0.307010769844055f, 0.105590961873531f, 0.307313382625580f, + 0.105826787650585f, 0.307615786790848f, 0.106062836945057f, 0.307918041944504f, + 0.106299124658108f, 0.308220088481903f, 0.106535643339157f, 0.308521956205368f, + 0.106772392988205f, 0.308823645114899f, 0.107009373605251f, 0.309125155210495f, + 0.107246585190296f, 0.309426486492157f, 0.107484027743340f, 0.309727638959885f, + 0.107721701264381f, 0.310028612613678f, 0.107959605753422f, 0.310329377651215f, + 0.108197741210461f, 0.310629993677139f, 0.108436107635498f, 0.310930401086807f, + 0.108674705028534f, 0.311230629682541f, 0.108913525938988f, 0.311530679464340f, + 0.109152585268021f, 0.311830550432205f, 0.109391868114471f, 0.312130242586136f, + 0.109631389379501f, 0.312429755926132f, 0.109871134161949f, 0.312729060649872f, + 0.110111102461815f, 0.313028186559677f, 0.110351309180260f, 0.313327133655548f, + 0.110591746866703f, 0.313625901937485f, 0.110832408070564f, 0.313924491405487f, + 0.111073300242424f, 0.314222872257233f, 0.111314415931702f, 0.314521104097366f, + 0.111555770039558f, 0.314819127321243f, 0.111797347664833f, 0.315116971731186f, + 0.112039148807526f, 0.315414607524872f, 0.112281180918217f, 0.315712094306946f, + 0.112523443996906f, 0.316009372472763f, 0.112765938043594f, 0.316306471824646f, + 0.113008655607700f, 0.316603392362595f, 0.113251596689224f, 0.316900104284287f, + 0.113494776189327f, 0.317196637392044f, 0.113738171756268f, 0.317492991685867f, + 0.113981798291206f, 0.317789167165756f, 0.114225655794144f, 0.318085134029388f, + 0.114469736814499f, 0.318380922079086f, 0.114714048802853f, 0.318676531314850f, + 0.114958584308624f, 0.318971961736679f, 0.115203343331814f, 0.319267183542252f, + 0.115448333323002f, 0.319562226533890f, 0.115693546831608f, 0.319857090711594f, + 0.115938983857632f, 0.320151746273041f, 0.116184651851654f, 0.320446223020554f, + 0.116430543363094f, 0.320740520954132f, 0.116676658391953f, 0.321034610271454f, + 0.116923004388809f, 0.321328520774841f, 0.117169573903084f, 0.321622252464294f, + 0.117416366934776f, 0.321915775537491f, 0.117663383483887f, 0.322209119796753f, + 0.117910631000996f, 0.322502255439758f, 0.118158094584942f, 0.322795242071152f, + 0.118405789136887f, 0.323088020086288f, 0.118653707206249f, 0.323380589485168f, + 0.118901848793030f, 0.323672980070114f, 0.119150213897228f, 0.323965191841125f, + 0.119398809969425f, 0.324257194995880f, 0.119647622108459f, 0.324549019336700f, + 0.119896657764912f, 0.324840664863586f, 0.120145916938782f, 0.325132101774216f, + 0.120395407080650f, 0.325423330068588f, 0.120645113289356f, 0.325714409351349f, + 0.120895043015480f, 0.326005280017853f, 0.121145196259022f, 0.326295942068100f, + 0.121395580470562f, 0.326586425304413f, 0.121646173298359f, 0.326876699924469f, + 0.121896997094154f, 0.327166795730591f, 0.122148044407368f, 0.327456712722778f, + 0.122399315237999f, 0.327746421098709f, 0.122650802135468f, 0.328035950660706f, + 0.122902512550354f, 0.328325271606445f, 0.123154446482658f, 0.328614413738251f, + 0.123406603932381f, 0.328903347253799f, 0.123658977448940f, 0.329192101955414f, + 0.123911574482918f, 0.329480648040771f, 0.124164395034313f, 0.329769015312195f, + 0.124417431652546f, 0.330057173967361f, 0.124670691788197f, 0.330345153808594f, + 0.124924175441265f, 0.330632925033569f, 0.125177875161171f, 0.330920487642288f, + 0.125431805849075f, 0.331207901239395f, 0.125685945153236f, 0.331495076417923f, + 0.125940307974815f, 0.331782072782516f, 0.126194894313812f, 0.332068890333176f, + 0.126449704170227f, 0.332355499267578f, 0.126704722642899f, 0.332641899585724f, + 0.126959964632988f, 0.332928121089935f, 0.127215430140495f, 0.333214133977890f, + 0.127471104264259f, 0.333499968051910f, 0.127727001905441f, 0.333785593509674f, + 0.127983123064041f, 0.334071010351181f, 0.128239467740059f, 0.334356248378754f, + 0.128496021032333f, 0.334641307592392f, 0.128752797842026f, 0.334926128387451f, + 0.129009798169136f, 0.335210770368576f, 0.129267007112503f, 0.335495233535767f, + 0.129524439573288f, 0.335779488086700f, 0.129782080650330f, 0.336063534021378f, + 0.130039945244789f, 0.336347371339798f, 0.130298033356667f, 0.336631029844284f, + 0.130556344985962f, 0.336914509534836f, 0.130814850330353f, 0.337197750806808f, + 0.131073594093323f, 0.337480813264847f, 0.131332546472549f, 0.337763696908951f, + 0.131591722369194f, 0.338046342134476f, 0.131851106882095f, 0.338328808546066f, + 0.132110700011253f, 0.338611096143723f, 0.132370531558990f, 0.338893145322800f, + 0.132630556821823f, 0.339175015687943f, 0.132890805602074f, 0.339456677436829f, + 0.133151277899742f, 0.339738160371780f, 0.133411958813667f, 0.340019434690475f, + 0.133672863245010f, 0.340300500392914f, 0.133933976292610f, 0.340581357479095f, + 0.134195312857628f, 0.340862035751343f, 0.134456858038902f, 0.341142505407333f, + 0.134718611836433f, 0.341422766447067f, 0.134980589151382f, 0.341702848672867f, + 0.135242775082588f, 0.341982692480087f, 0.135505184531212f, 0.342262357473373f, + 0.135767802596092f, 0.342541843652725f, 0.136030644178391f, 0.342821091413498f, + 0.136293679475784f, 0.343100160360336f, 0.136556953191757f, 0.343379020690918f, + 0.136820420622826f, 0.343657672405243f, 0.137084111571312f, 0.343936115503311f, + 0.137348011136055f, 0.344214379787445f, 0.137612134218216f, 0.344492435455322f, + 0.137876465916634f, 0.344770282506943f, 0.138141006231308f, 0.345047920942307f, + 0.138405755162239f, 0.345325350761414f, 0.138670727610588f, 0.345602601766586f, + 0.138935908675194f, 0.345879614353180f, 0.139201298356056f, 0.346156448125839f, + 0.139466896653175f, 0.346433073282242f, 0.139732718467712f, 0.346709519624710f, + 0.139998748898506f, 0.346985727548599f, 0.140264987945557f, 0.347261756658554f, + 0.140531435608864f, 0.347537547349930f, 0.140798106789589f, 0.347813159227371f, + 0.141064971685410f, 0.348088562488556f, 0.141332060098648f, 0.348363757133484f, + 0.141599357128143f, 0.348638743162155f, 0.141866862773895f, 0.348913550376892f, + 0.142134591937065f, 0.349188119173050f, 0.142402514815331f, 0.349462509155273f, + 0.142670661211014f, 0.349736660718918f, 0.142939001321793f, 0.350010633468628f, + 0.143207564949989f, 0.350284397602081f, 0.143476337194443f, 0.350557953119278f, + 0.143745318055153f, 0.350831300020218f, 0.144014507532120f, 0.351104438304901f, + 0.144283905625343f, 0.351377367973328f, 0.144553512334824f, 0.351650089025497f, + 0.144823327660561f, 0.351922631263733f, 0.145093351602554f, 0.352194935083389f, + 0.145363584160805f, 0.352467030286789f, 0.145634025335312f, 0.352738946676254f, + 0.145904675126076f, 0.353010624647141f, 0.146175548434258f, 0.353282123804092f, + 0.146446615457535f, 0.353553384542465f, 0.146717891097069f, 0.353824466466904f, + 0.146989375352860f, 0.354095309972763f, 0.147261068224907f, 0.354365974664688f, + 0.147532954812050f, 0.354636400938034f, 0.147805064916611f, 0.354906648397446f, + 0.148077383637428f, 0.355176687240601f, 0.148349896073341f, 0.355446487665176f, + 0.148622632026672f, 0.355716109275818f, 0.148895561695099f, 0.355985492467880f, + 0.149168699979782f, 0.356254696846008f, 0.149442046880722f, 0.356523662805557f, + 0.149715602397919f, 0.356792420148849f, 0.149989366531372f, 0.357060998678207f, + 0.150263324379921f, 0.357329338788986f, 0.150537505745888f, 0.357597470283508f, + 0.150811880826950f, 0.357865422964096f, 0.151086464524269f, 0.358133137226105f, + 0.151361241936684f, 0.358400642871857f, 0.151636242866516f, 0.358667939901352f, + 0.151911437511444f, 0.358935028314590f, 0.152186840772629f, 0.359201908111572f, + 0.152462437748909f, 0.359468549489975f, 0.152738258242607f, 0.359735012054443f, + 0.153014272451401f, 0.360001266002655f, 0.153290495276451f, 0.360267281532288f, + 0.153566911816597f, 0.360533088445663f, 0.153843536973000f, 0.360798716545105f, + 0.154120370745659f, 0.361064106225967f, 0.154397398233414f, 0.361329287290573f, + 0.154674649238586f, 0.361594229936600f, 0.154952079057693f, 0.361858993768692f, + 0.155229732394218f, 0.362123548984528f, 0.155507579445839f, 0.362387865781784f, + 0.155785620212555f, 0.362651973962784f, 0.156063869595528f, 0.362915903329849f, + 0.156342327594757f, 0.363179564476013f, 0.156620979309082f, 0.363443046808243f, + 0.156899839639664f, 0.363706320524216f, 0.157178908586502f, 0.363969355821610f, + 0.157458171248436f, 0.364232182502747f, 0.157737627625465f, 0.364494800567627f, + 0.158017292618752f, 0.364757210016251f, 0.158297166228294f, 0.365019410848618f, + 0.158577233552933f, 0.365281373262405f, 0.158857494592667f, 0.365543156862259f, + 0.159137964248657f, 0.365804702043533f, 0.159418627619743f, 0.366066008806229f, + 0.159699499607086f, 0.366327136754990f, 0.159980565309525f, 0.366588026285172f, + 0.160261839628220f, 0.366848707199097f, 0.160543307662010f, 0.367109179496765f, + 0.160824984312058f, 0.367369443178177f, 0.161106839776039f, 0.367629468441010f, + 0.161388918757439f, 0.367889285087585f, 0.161671176552773f, 0.368148893117905f, + 0.161953642964363f, 0.368408292531967f, 0.162236317992210f, 0.368667453527451f, + 0.162519171833992f, 0.368926405906677f, 0.162802234292030f, 0.369185149669647f, + 0.163085505366325f, 0.369443655014038f, 0.163368955254555f, 0.369701951742172f, + 0.163652613759041f, 0.369960039854050f, 0.163936465978622f, 0.370217919349670f, + 0.164220526814461f, 0.370475560426712f, 0.164504766464233f, 0.370732992887497f, + 0.164789214730263f, 0.370990216732025f, 0.165073871612549f, 0.371247202157974f, + 0.165358707308769f, 0.371503978967667f, 0.165643751621246f, 0.371760547161102f, + 0.165928974747658f, 0.372016876935959f, 0.166214406490326f, 0.372272998094559f, + 0.166500031948090f, 0.372528880834579f, 0.166785866022110f, 0.372784584760666f, + 0.167071878910065f, 0.373040050268173f, 0.167358100414276f, 0.373295277357101f, + 0.167644515633583f, 0.373550295829773f, 0.167931124567986f, 0.373805105686188f, + 0.168217927217484f, 0.374059677124023f, 0.168504923582077f, 0.374314039945602f, + 0.168792113661766f, 0.374568194150925f, 0.169079497456551f, 0.374822109937668f, + 0.169367074966431f, 0.375075817108154f, 0.169654861092567f, 0.375329315662384f, + 0.169942826032639f, 0.375582575798035f, 0.170230999588966f, 0.375835597515106f, + 0.170519351959229f, 0.376088410615921f, 0.170807912945747f, 0.376341015100479f, + 0.171096652746201f, 0.376593410968781f, 0.171385586261749f, 0.376845568418503f, + 0.171674728393555f, 0.377097487449646f, 0.171964049339294f, 0.377349197864532f, + 0.172253578901291f, 0.377600699663162f, 0.172543287277222f, 0.377851963043213f, + 0.172833189368248f, 0.378102988004684f, 0.173123285174370f, 0.378353834152222f, + 0.173413574695587f, 0.378604412078857f, 0.173704057931900f, 0.378854811191559f, + 0.173994734883308f, 0.379104942083359f, 0.174285605549812f, 0.379354894161224f, + 0.174576655030251f, 0.379604607820511f, 0.174867913126946f, 0.379854083061218f, + 0.175159350037575f, 0.380103349685669f, 0.175450980663300f, 0.380352377891541f, + 0.175742805004120f, 0.380601197481155f, 0.176034808158875f, 0.380849778652191f, + 0.176327019929886f, 0.381098151206970f, 0.176619410514832f, 0.381346285343170f, + 0.176911994814873f, 0.381594210863113f, 0.177204772830009f, 0.381841897964478f, + 0.177497729659081f, 0.382089376449585f, 0.177790880203247f, 0.382336616516113f, + 0.178084224462509f, 0.382583618164063f, 0.178377762436867f, 0.382830440998077f, + 0.178671479225159f, 0.383076995611191f, 0.178965389728546f, 0.383323341608047f, + 0.179259493947029f, 0.383569449186325f, 0.179553776979446f, 0.383815348148346f, + 0.179848253726959f, 0.384061008691788f, 0.180142924189568f, 0.384306460618973f, + 0.180437773466110f, 0.384551674127579f, 0.180732816457748f, 0.384796649217606f, + 0.181028053164482f, 0.385041415691376f, 0.181323468685150f, 0.385285943746567f, + 0.181619063019753f, 0.385530263185501f, 0.181914865970612f, 0.385774344205856f, + 0.182210832834244f, 0.386018186807632f, 0.182507008314133f, 0.386261820793152f, + 0.182803362607956f, 0.386505216360092f, 0.183099895715714f, 0.386748403310776f, + 0.183396622538567f, 0.386991351842880f, 0.183693528175354f, 0.387234061956406f, + 0.183990627527237f, 0.387476563453674f, 0.184287920594215f, 0.387718826532364f, + 0.184585392475128f, 0.387960851192474f, 0.184883043169975f, 0.388202667236328f, + 0.185180887579918f, 0.388444244861603f, 0.185478910803795f, 0.388685584068298f, + 0.185777112841606f, 0.388926714658737f, 0.186075508594513f, 0.389167606830597f, + 0.186374098062515f, 0.389408260583878f, 0.186672851443291f, 0.389648675918579f, + 0.186971798539162f, 0.389888882637024f, 0.187270939350128f, 0.390128880739212f, + 0.187570258975029f, 0.390368610620499f, 0.187869757413864f, 0.390608131885529f, + 0.188169434666634f, 0.390847414731979f, 0.188469305634499f, 0.391086459159851f, + 0.188769355416298f, 0.391325294971466f, 0.189069598913193f, 0.391563892364502f, + 0.189370006322861f, 0.391802251338959f, 0.189670607447624f, 0.392040401697159f, + 0.189971387386322f, 0.392278283834457f, 0.190272361040115f, 0.392515957355499f, + 0.190573498606682f, 0.392753422260284f, 0.190874829888344f, 0.392990618944168f, + 0.191176339983940f, 0.393227607011795f, 0.191478043794632f, 0.393464356660843f, + 0.191779911518097f, 0.393700867891312f, 0.192081972956657f, 0.393937170505524f, + 0.192384198307991f, 0.394173204898834f, 0.192686617374420f, 0.394409030675888f, + 0.192989215254784f, 0.394644618034363f, 0.193292006850243f, 0.394879996776581f, + 0.193594962358475f, 0.395115107297897f, 0.193898096680641f, 0.395350009202957f, + 0.194201424717903f, 0.395584672689438f, 0.194504916667938f, 0.395819097757339f, + 0.194808602333069f, 0.396053284406662f, 0.195112451910973f, 0.396287262439728f, + 0.195416495203972f, 0.396520972251892f, 0.195720717310905f, 0.396754473447800f, + 0.196025103330612f, 0.396987736225128f, 0.196329683065414f, 0.397220760583878f, + 0.196634441614151f, 0.397453576326370f, 0.196939364075661f, 0.397686123847961f, + 0.197244480252266f, 0.397918462753296f, 0.197549775242805f, 0.398150533437729f, + 0.197855234146118f, 0.398382395505905f, 0.198160871863365f, 0.398614019155502f, + 0.198466703295708f, 0.398845434188843f, 0.198772698640823f, 0.399076581001282f, + 0.199078872799873f, 0.399307489395142f, 0.199385225772858f, 0.399538189172745f, + 0.199691757559776f, 0.399768620729446f, 0.199998468160629f, 0.399998843669891f, + 0.200305357575417f, 0.400228828191757f, 0.200612410902977f, 0.400458574295044f, + 0.200919643044472f, 0.400688081979752f, 0.201227053999901f, 0.400917351245880f, + 0.201534643769264f, 0.401146411895752f, 0.201842412352562f, 0.401375204324722f, + 0.202150344848633f, 0.401603758335114f, 0.202458456158638f, 0.401832103729248f, + 0.202766746282578f, 0.402060180902481f, 0.203075215220451f, 0.402288049459457f, + 0.203383848071098f, 0.402515679597855f, 0.203692659735680f, 0.402743041515350f, + 0.204001650214195f, 0.402970194816589f, 0.204310819506645f, 0.403197109699249f, + 0.204620152711868f, 0.403423786163330f, 0.204929664731026f, 0.403650224208832f, + 0.205239340662956f, 0.403876423835754f, 0.205549195408821f, 0.404102355241776f, + 0.205859228968620f, 0.404328078031540f, 0.206169426441193f, 0.404553562402725f, + 0.206479802727699f, 0.404778808355331f, 0.206790357828140f, 0.405003815889359f, + 0.207101076841354f, 0.405228585004807f, 0.207411959767342f, 0.405453115701675f, + 0.207723021507263f, 0.405677437782288f, 0.208034262061119f, 0.405901491641998f, + 0.208345666527748f, 0.406125307083130f, 0.208657249808311f, 0.406348884105682f, + 0.208969011902809f, 0.406572192907333f, 0.209280923008919f, 0.406795293092728f, + 0.209593027830124f, 0.407018154859543f, 0.209905281662941f, 0.407240778207779f, + 0.210217714309692f, 0.407463163137436f, 0.210530325770378f, 0.407685309648514f, + 0.210843101143837f, 0.407907217741013f, 0.211156040430069f, 0.408128857612610f, + 0.211469158530235f, 0.408350288867950f, 0.211782455444336f, 0.408571451902390f, + 0.212095901370049f, 0.408792406320572f, 0.212409526109695f, 0.409013092517853f, + 0.212723329663277f, 0.409233570098877f, 0.213037282228470f, 0.409453779459000f, + 0.213351413607597f, 0.409673750400543f, 0.213665723800659f, 0.409893482923508f, + 0.213980183005333f, 0.410112977027893f, 0.214294821023941f, 0.410332232713699f, + 0.214609622955322f, 0.410551249980927f, 0.214924603700638f, 0.410770028829575f, + 0.215239733457565f, 0.410988569259644f, 0.215555042028427f, 0.411206841468811f, + 0.215870529413223f, 0.411424905061722f, 0.216186165809631f, 0.411642700433731f, + 0.216501981019974f, 0.411860257387161f, 0.216817945241928f, 0.412077575922012f, + 0.217134088277817f, 0.412294656038284f, 0.217450410127640f, 0.412511497735977f, + 0.217766880989075f, 0.412728071212769f, 0.218083515763283f, 0.412944436073303f, + 0.218400329351425f, 0.413160532712936f, 0.218717306852341f, 0.413376390933990f, + 0.219034433364868f, 0.413592010736465f, 0.219351738691330f, 0.413807392120361f, + 0.219669207930565f, 0.414022535085678f, 0.219986841082573f, 0.414237409830093f, + 0.220304638147354f, 0.414452046155930f, 0.220622614026070f, 0.414666473865509f, + 0.220940738916397f, 0.414880603551865f, 0.221259027719498f, 0.415094524621964f, + 0.221577480435371f, 0.415308207273483f, 0.221896097064018f, 0.415521621704102f, + 0.222214877605438f, 0.415734797716141f, 0.222533836960793f, 0.415947735309601f, + 0.222852945327759f, 0.416160434484482f, 0.223172217607498f, 0.416372895240784f, + 0.223491653800011f, 0.416585087776184f, 0.223811239004135f, 0.416797041893005f, + 0.224131003022194f, 0.417008757591248f, 0.224450930953026f, 0.417220205068588f, + 0.224771007895470f, 0.417431443929672f, 0.225091263651848f, 0.417642414569855f, + 0.225411668419838f, 0.417853146791458f, 0.225732237100601f, 0.418063640594482f, + 0.226052969694138f, 0.418273866176605f, 0.226373866200447f, 0.418483853340149f, + 0.226694911718369f, 0.418693602085114f, 0.227016136050224f, 0.418903112411499f, + 0.227337509393692f, 0.419112354516983f, 0.227659046649933f, 0.419321358203888f, + 0.227980732917786f, 0.419530123472214f, 0.228302597999573f, 0.419738620519638f, + 0.228624612092972f, 0.419946908950806f, 0.228946775197983f, 0.420154929161072f, + 0.229269117116928f, 0.420362681150436f, 0.229591608047485f, 0.420570224523544f, + 0.229914262890816f, 0.420777499675751f, 0.230237081646919f, 0.420984506607056f, + 0.230560049414635f, 0.421191304922104f, 0.230883181095123f, 0.421397835016251f, + 0.231206461787224f, 0.421604126691818f, 0.231529906392097f, 0.421810150146484f, + 0.231853514909744f, 0.422015935182571f, 0.232177272439003f, 0.422221481800079f, + 0.232501193881035f, 0.422426789999008f, 0.232825264334679f, 0.422631829977036f, + 0.233149498701096f, 0.422836631536484f, 0.233473882079124f, 0.423041164875031f, + 0.233798429369926f, 0.423245459794998f, 0.234123140573502f, 0.423449516296387f, + 0.234448000788689f, 0.423653304576874f, 0.234773010015488f, 0.423856884241104f, + 0.235098183155060f, 0.424060165882111f, 0.235423520207405f, 0.424263238906860f, + 0.235749006271362f, 0.424466013908386f, 0.236074641346931f, 0.424668580293655f, + 0.236400425434113f, 0.424870878458023f, 0.236726388335228f, 0.425072938203812f, + 0.237052485346794f, 0.425274729728699f, 0.237378746271133f, 0.425476282835007f, + 0.237705156207085f, 0.425677597522736f, 0.238031730055809f, 0.425878643989563f, + 0.238358452916145f, 0.426079452037811f, 0.238685324788094f, 0.426279991865158f, + 0.239012360572815f, 0.426480293273926f, 0.239339530467987f, 0.426680356264114f, + 0.239666879177094f, 0.426880151033401f, 0.239994361996651f, 0.427079707384110f, + 0.240322008728981f, 0.427278995513916f, 0.240649804472923f, 0.427478045225143f, + 0.240977749228477f, 0.427676826715469f, 0.241305842995644f, 0.427875369787216f, + 0.241634100675583f, 0.428073674440384f, 0.241962507367134f, 0.428271710872650f, + 0.242291063070297f, 0.428469479084015f, 0.242619767785072f, 0.428667008876801f, + 0.242948621511459f, 0.428864300251007f, 0.243277639150620f, 0.429061323404312f, + 0.243606805801392f, 0.429258108139038f, 0.243936106562614f, 0.429454624652863f, + 0.244265571236610f, 0.429650902748108f, 0.244595184922218f, 0.429846942424774f, + 0.244924947619438f, 0.430042684078217f, 0.245254859328270f, 0.430238217115402f, + 0.245584934949875f, 0.430433481931686f, 0.245915144681931f, 0.430628478527069f, + 0.246245503425598f, 0.430823236703873f, 0.246576011180878f, 0.431017726659775f, + 0.246906682848930f, 0.431211978197098f, 0.247237488627434f, 0.431405961513519f, + 0.247568443417549f, 0.431599706411362f, 0.247899547219276f, 0.431793183088303f, + 0.248230814933777f, 0.431986421346664f, 0.248562216758728f, 0.432179391384125f, + 0.248893767595291f, 0.432372123003006f, 0.249225467443466f, 0.432564586400986f, + 0.249557301402092f, 0.432756811380386f, 0.249889299273491f, 0.432948768138886f, + 0.250221431255341f, 0.433140486478806f, 0.250553727149963f, 0.433331936597824f, + 0.250886172056198f, 0.433523118495941f, 0.251218736171722f, 0.433714061975479f, + 0.251551479101181f, 0.433904737234116f, 0.251884341239929f, 0.434095174074173f, + 0.252217382192612f, 0.434285342693329f, 0.252550542354584f, 0.434475272893906f, + 0.252883851528168f, 0.434664934873581f, 0.253217309713364f, 0.434854328632355f, + 0.253550916910172f, 0.435043483972549f, 0.253884643316269f, 0.435232400894165f, + 0.254218548536301f, 0.435421019792557f, 0.254552572965622f, 0.435609430074692f, + 0.254886746406555f, 0.435797542333603f, 0.255221068859100f, 0.435985416173935f, + 0.255555540323257f, 0.436173021793365f, 0.255890160799026f, 0.436360388994217f, + 0.256224930286407f, 0.436547487974167f, 0.256559818983078f, 0.436734348535538f, + 0.256894856691360f, 0.436920911073685f, 0.257230043411255f, 0.437107264995575f, + 0.257565379142761f, 0.437293320894241f, 0.257900834083557f, 0.437479138374329f, + 0.258236467838287f, 0.437664687633514f, 0.258572220802307f, 0.437849998474121f, + 0.258908122777939f, 0.438035041093826f, 0.259244143962860f, 0.438219845294952f, + 0.259580343961716f, 0.438404351472855f, 0.259916663169861f, 0.438588619232178f, + 0.260253131389618f, 0.438772648572922f, 0.260589718818665f, 0.438956409692764f, + 0.260926485061646f, 0.439139902591705f, 0.261263370513916f, 0.439323127269745f, + 0.261600375175476f, 0.439506113529205f, 0.261937558650970f, 0.439688831567764f, + 0.262274861335754f, 0.439871311187744f, 0.262612313032150f, 0.440053492784500f, + 0.262949883937836f, 0.440235435962677f, 0.263287603855133f, 0.440417140722275f, + 0.263625472784042f, 0.440598547458649f, 0.263963490724564f, 0.440779715776443f, + 0.264301627874374f, 0.440960645675659f, 0.264639914035797f, 0.441141277551651f, + 0.264978319406509f, 0.441321671009064f, 0.265316903591156f, 0.441501796245575f, + 0.265655577182770f, 0.441681683063507f, 0.265994429588318f, 0.441861271858215f, + 0.266333401203156f, 0.442040622234344f, 0.266672492027283f, 0.442219734191895f, + 0.267011761665344f, 0.442398548126221f, 0.267351150512695f, 0.442577123641968f, + 0.267690658569336f, 0.442755430936813f, 0.268030315637589f, 0.442933470010757f, + 0.268370121717453f, 0.443111270666122f, 0.268710047006607f, 0.443288803100586f, + 0.269050091505051f, 0.443466067314148f, 0.269390314817429f, 0.443643063306808f, + 0.269730657339096f, 0.443819820880890f, 0.270071119070053f, 0.443996280431747f, + 0.270411729812622f, 0.444172531366348f, 0.270752459764481f, 0.444348484277725f, + 0.271093338727951f, 0.444524168968201f, 0.271434366703033f, 0.444699615240097f, + 0.271775513887405f, 0.444874793291092f, 0.272116780281067f, 0.445049703121185f, + 0.272458195686340f, 0.445224374532700f, 0.272799760103226f, 0.445398747920990f, + 0.273141443729401f, 0.445572882890701f, 0.273483246564865f, 0.445746749639511f, + 0.273825198411942f, 0.445920348167419f, 0.274167299270630f, 0.446093708276749f, + 0.274509519338608f, 0.446266770362854f, 0.274851858615875f, 0.446439594030380f, + 0.275194346904755f, 0.446612149477005f, 0.275536954402924f, 0.446784436702728f, + 0.275879681110382f, 0.446956485509872f, 0.276222556829453f, 0.447128236293793f, + 0.276565581560135f, 0.447299748659134f, 0.276908725500107f, 0.447470992803574f, + 0.277251988649368f, 0.447641968727112f, 0.277595400810242f, 0.447812676429749f, + 0.277938932180405f, 0.447983115911484f, 0.278282582759857f, 0.448153316974640f, + 0.278626382350922f, 0.448323249816895f, 0.278970301151276f, 0.448492884635925f, + 0.279314368963242f, 0.448662281036377f, 0.279658555984497f, 0.448831409215927f, + 0.280002862215042f, 0.449000298976898f, 0.280347317457199f, 0.449168890714645f, + 0.280691891908646f, 0.449337244033813f, 0.281036585569382f, 0.449505299329758f, + 0.281381398439407f, 0.449673116207123f, 0.281726360321045f, 0.449840664863586f, + 0.282071471214294f, 0.450007945299149f, 0.282416671514511f, 0.450174957513809f, + 0.282762020826340f, 0.450341701507568f, 0.283107489347458f, 0.450508207082748f, + 0.283453077077866f, 0.450674414634705f, 0.283798813819885f, 0.450840383768082f, + 0.284144669771194f, 0.451006084680557f, 0.284490644931793f, 0.451171487569809f, + 0.284836769104004f, 0.451336652040482f, 0.285182982683182f, 0.451501548290253f, + 0.285529345273972f, 0.451666176319122f, 0.285875827074051f, 0.451830536127090f, + 0.286222457885742f, 0.451994657516479f, 0.286569178104401f, 0.452158480882645f, + 0.286916047334671f, 0.452322036027908f, 0.287263035774231f, 0.452485352754593f, + 0.287610173225403f, 0.452648371458054f, 0.287957400083542f, 0.452811151742935f, + 0.288304775953293f, 0.452973634004593f, 0.288652241230011f, 0.453135877847672f, + 0.288999855518341f, 0.453297853469849f, 0.289347589015961f, 0.453459560871124f, + 0.289695471525192f, 0.453621000051498f, 0.290043443441391f, 0.453782171010971f, + 0.290391564369202f, 0.453943043947220f, 0.290739774703979f, 0.454103678464890f, + 0.291088134050369f, 0.454264044761658f, 0.291436612606049f, 0.454424172639847f, + 0.291785210371017f, 0.454584002494812f, 0.292133957147598f, 0.454743564128876f, + 0.292482793331146f, 0.454902857542038f, 0.292831748723984f, 0.455061882734299f, + 0.293180853128433f, 0.455220639705658f, 0.293530046939850f, 0.455379128456116f, + 0.293879389762878f, 0.455537378787994f, 0.294228851795197f, 0.455695331096649f, + 0.294578403234482f, 0.455853015184402f, 0.294928103685379f, 0.456010431051254f, + 0.295277923345566f, 0.456167578697205f, 0.295627862215042f, 0.456324487924576f, + 0.295977920293808f, 0.456481099128723f, 0.296328097581863f, 0.456637442111969f, + 0.296678394079208f, 0.456793516874313f, 0.297028809785843f, 0.456949323415756f, + 0.297379344701767f, 0.457104891538620f, 0.297729998826981f, 0.457260161638260f, + 0.298080772161484f, 0.457415163516998f, 0.298431664705276f, 0.457569897174835f, + 0.298782676458359f, 0.457724362611771f, 0.299133807420731f, 0.457878559827805f, + 0.299485057592392f, 0.458032488822937f, 0.299836426973343f, 0.458186149597168f, + 0.300187885761261f, 0.458339542150497f, 0.300539493560791f, 0.458492636680603f, + 0.300891220569611f, 0.458645492792130f, 0.301243066787720f, 0.458798080682755f, + 0.301595002412796f, 0.458950400352478f, 0.301947087049484f, 0.459102421998978f, + 0.302299261093140f, 0.459254205226898f, 0.302651554346085f, 0.459405690431595f, + 0.303003966808319f, 0.459556937217712f, 0.303356528282166f, 0.459707885980606f, + 0.303709149360657f, 0.459858566522598f, 0.304061919450760f, 0.460008978843689f, + 0.304414808750153f, 0.460159152746201f, 0.304767817258835f, 0.460309028625488f, + 0.305120915174484f, 0.460458606481552f, 0.305474132299423f, 0.460607945919037f, + 0.305827468633652f, 0.460757017135620f, 0.306180924177170f, 0.460905820131302f, + 0.306534498929977f, 0.461054325103760f, 0.306888192892075f, 0.461202591657639f, + 0.307241976261139f, 0.461350560188293f, 0.307595878839493f, 0.461498260498047f, + 0.307949900627136f, 0.461645722389221f, 0.308304041624069f, 0.461792886257172f, + 0.308658272027969f, 0.461939752101898f, 0.309012651443481f, 0.462086379528046f, + 0.309367120265961f, 0.462232738733292f, 0.309721708297729f, 0.462378799915314f, + 0.310076385736465f, 0.462524622678757f, 0.310431212186813f, 0.462670147418976f, + 0.310786128044128f, 0.462815403938293f, 0.311141163110733f, 0.462960392236710f, + 0.311496287584305f, 0.463105112314224f, 0.311851561069489f, 0.463249564170837f, + 0.312206923961639f, 0.463393747806549f, 0.312562376260757f, 0.463537633419037f, + 0.312917977571487f, 0.463681250810623f, 0.313273668289185f, 0.463824629783630f, + 0.313629478216171f, 0.463967710733414f, 0.313985377550125f, 0.464110493659973f, + 0.314341396093369f, 0.464253038167953f, 0.314697533845901f, 0.464395314455032f, + 0.315053790807724f, 0.464537292718887f, 0.315410137176514f, 0.464679002761841f, + 0.315766572952271f, 0.464820444583893f, 0.316123157739639f, 0.464961618185043f, + 0.316479831933975f, 0.465102523565292f, 0.316836595535278f, 0.465243130922318f, + 0.317193508148193f, 0.465383470058441f, 0.317550510168076f, 0.465523540973663f, + 0.317907601594925f, 0.465663343667984f, 0.318264812231064f, 0.465802878141403f, + 0.318622142076492f, 0.465942144393921f, 0.318979561328888f, 0.466081112623215f, + 0.319337099790573f, 0.466219812631607f, 0.319694727659225f, 0.466358244419098f, + 0.320052474737167f, 0.466496407985687f, 0.320410341024399f, 0.466634273529053f, + 0.320768296718597f, 0.466771900653839f, 0.321126341819763f, 0.466909229755402f, + 0.321484506130219f, 0.467046260833740f, 0.321842789649963f, 0.467183053493500f, + 0.322201162576675f, 0.467319577932358f, 0.322559654712677f, 0.467455804347992f, + 0.322918236255646f, 0.467591762542725f, 0.323276937007904f, 0.467727422714233f, + 0.323635727167130f, 0.467862844467163f, 0.323994606733322f, 0.467997968196869f, + 0.324353635311127f, 0.468132823705673f, 0.324712723493576f, 0.468267410993576f, + 0.325071930885315f, 0.468401730060577f, 0.325431257486343f, 0.468535751104355f, + 0.325790673494339f, 0.468669503927231f, 0.326150178909302f, 0.468802988529205f, + 0.326509803533554f, 0.468936175107956f, 0.326869517564774f, 0.469069123268127f, + 0.327229350805283f, 0.469201773405075f, 0.327589273452759f, 0.469334155321121f, + 0.327949285507202f, 0.469466239213943f, 0.328309416770935f, 0.469598054885864f, + 0.328669637441635f, 0.469729602336884f, 0.329029977321625f, 0.469860881567001f, + 0.329390406608582f, 0.469991862773895f, 0.329750925302505f, 0.470122605562210f, + 0.330111563205719f, 0.470253020524979f, 0.330472290515900f, 0.470383197069168f, + 0.330833107233047f, 0.470513075590134f, 0.331194043159485f, 0.470642685890198f, + 0.331555068492889f, 0.470772027969360f, 0.331916213035584f, 0.470901101827621f, + 0.332277417182922f, 0.471029877662659f, 0.332638740539551f, 0.471158385276794f, + 0.333000183105469f, 0.471286594867706f, 0.333361685276031f, 0.471414536237717f, + 0.333723306655884f, 0.471542209386826f, 0.334085017442703f, 0.471669614315033f, + 0.334446847438812f, 0.471796721220016f, 0.334808766841888f, 0.471923559904099f, + 0.335170775651932f, 0.472050130367279f, 0.335532873868942f, 0.472176402807236f, + 0.335895091295242f, 0.472302407026291f, 0.336257368326187f, 0.472428143024445f, + 0.336619764566422f, 0.472553610801697f, 0.336982280015945f, 0.472678780555725f, + 0.337344855070114f, 0.472803652286530f, 0.337707549333572f, 0.472928285598755f, + 0.338070303201675f, 0.473052620887756f, 0.338433176279068f, 0.473176687955856f, + 0.338796168565750f, 0.473300457000732f, 0.339159220457077f, 0.473423957824707f, + 0.339522391557693f, 0.473547190427780f, 0.339885622262955f, 0.473670125007629f, + 0.340248972177505f, 0.473792791366577f, 0.340612411499023f, 0.473915189504623f, + 0.340975970029831f, 0.474037289619446f, 0.341339588165283f, 0.474159121513367f, + 0.341703325510025f, 0.474280685186386f, 0.342067122459412f, 0.474401950836182f, + 0.342431038618088f, 0.474522948265076f, 0.342795044183731f, 0.474643647670746f, + 0.343159139156342f, 0.474764078855515f, 0.343523323535919f, 0.474884241819382f, + 0.343887597322464f, 0.475004136562347f, 0.344251960515976f, 0.475123733282089f, + 0.344616413116455f, 0.475243031978607f, 0.344980984926224f, 0.475362062454224f, + 0.345345616340637f, 0.475480824708939f, 0.345710366964340f, 0.475599318742752f, + 0.346075177192688f, 0.475717514753342f, 0.346440106630325f, 0.475835442543030f, + 0.346805095672607f, 0.475953072309494f, 0.347170203924179f, 0.476070433855057f, + 0.347535371780396f, 0.476187497377396f, 0.347900658845901f, 0.476304292678833f, + 0.348266035318375f, 0.476420819759369f, 0.348631471395493f, 0.476537048816681f, + 0.348997026681900f, 0.476653009653091f, 0.349362671375275f, 0.476768702268600f, + 0.349728375673294f, 0.476884096860886f, 0.350094199180603f, 0.476999223232269f, + 0.350460082292557f, 0.477114051580429f, 0.350826084613800f, 0.477228611707687f, + 0.351192146539688f, 0.477342873811722f, 0.351558297872543f, 0.477456867694855f, + 0.351924568414688f, 0.477570593357086f, 0.352290898561478f, 0.477684020996094f, + 0.352657318115234f, 0.477797180414200f, 0.353023827075958f, 0.477910041809082f, + 0.353390425443649f, 0.478022634983063f, 0.353757113218308f, 0.478134930133820f, + 0.354123860597610f, 0.478246957063675f, 0.354490727186203f, 0.478358715772629f, + 0.354857653379440f, 0.478470176458359f, 0.355224698781967f, 0.478581339120865f, + 0.355591803789139f, 0.478692263364792f, 0.355958998203278f, 0.478802859783173f, + 0.356326282024384f, 0.478913217782974f, 0.356693625450134f, 0.479023247957230f, + 0.357061088085175f, 0.479133039712906f, 0.357428610324860f, 0.479242533445358f, + 0.357796221971512f, 0.479351729154587f, 0.358163923025131f, 0.479460656642914f, + 0.358531713485718f, 0.479569315910339f, 0.358899593353271f, 0.479677677154541f, + 0.359267532825470f, 0.479785770177841f, 0.359635561704636f, 0.479893565177917f, + 0.360003679990768f, 0.480001062154770f, 0.360371887683868f, 0.480108320713043f, + 0.360740154981613f, 0.480215251445770f, 0.361108511686325f, 0.480321943759918f, + 0.361476957798004f, 0.480428308248520f, 0.361845493316650f, 0.480534434318542f, + 0.362214088439941f, 0.480640232563019f, 0.362582772970200f, 0.480745792388916f, + 0.362951546907425f, 0.480851024389267f, 0.363320380449295f, 0.480956017971039f, + 0.363689333200455f, 0.481060713529587f, 0.364058345556259f, 0.481165111064911f, + 0.364427417516708f, 0.481269240379334f, 0.364796578884125f, 0.481373071670532f, + 0.365165829658508f, 0.481476634740829f, 0.365535169839859f, 0.481579899787903f, + 0.365904569625854f, 0.481682896614075f, 0.366274058818817f, 0.481785595417023f, + 0.366643607616425f, 0.481888025999069f, 0.367013275623322f, 0.481990188360214f, + 0.367382973432541f, 0.482092022895813f, 0.367752790451050f, 0.482193619012833f, + 0.368122667074203f, 0.482294887304306f, 0.368492603302002f, 0.482395917177200f, + 0.368862658739090f, 0.482496619224548f, 0.369232743978500f, 0.482597053050995f, + 0.369602948427200f, 0.482697218656540f, 0.369973212480545f, 0.482797086238861f, + 0.370343536138535f, 0.482896685600281f, 0.370713949203491f, 0.482995986938477f, + 0.371084451675415f, 0.483094990253448f, 0.371455013751984f, 0.483193725347519f, + 0.371825665235519f, 0.483292192220688f, 0.372196376323700f, 0.483390361070633f, + 0.372567176818848f, 0.483488231897354f, 0.372938036918640f, 0.483585834503174f, + 0.373308986425400f, 0.483683139085770f, 0.373679995536804f, 0.483780175447464f, + 0.374051094055176f, 0.483876913785934f, 0.374422252178192f, 0.483973383903503f, + 0.374793499708176f, 0.484069555997849f, 0.375164806842804f, 0.484165430068970f, + 0.375536203384399f, 0.484261035919189f, 0.375907659530640f, 0.484356373548508f, + 0.376279205083847f, 0.484451413154602f, 0.376650810241699f, 0.484546154737473f, + 0.377022475004196f, 0.484640628099442f, 0.377394229173660f, 0.484734803438187f, + 0.377766042947769f, 0.484828680753708f, 0.378137946128845f, 0.484922289848328f, + 0.378509908914566f, 0.485015630722046f, 0.378881961107254f, 0.485108673572540f, + 0.379254043102264f, 0.485201418399811f, 0.379626244306564f, 0.485293895006180f, + 0.379998475313187f, 0.485386073589325f, 0.380370795726776f, 0.485477954149246f, + 0.380743205547333f, 0.485569566488266f, 0.381115674972534f, 0.485660910606384f, + 0.381488204002380f, 0.485751956701279f, 0.381860792636871f, 0.485842704772949f, + 0.382233470678329f, 0.485933154821396f, 0.382606208324432f, 0.486023366451263f, + 0.382979035377502f, 0.486113250255585f, 0.383351892232895f, 0.486202865839005f, + 0.383724838495255f, 0.486292183399200f, 0.384097874164581f, 0.486381232738495f, + 0.384470939636230f, 0.486469984054565f, 0.384844094514847f, 0.486558437347412f, + 0.385217308998108f, 0.486646622419357f, 0.385590612888336f, 0.486734509468079f, + 0.385963946580887f, 0.486822128295898f, 0.386337369680405f, 0.486909449100494f, + 0.386710882186890f, 0.486996471881866f, 0.387084424495697f, 0.487083226442337f, + 0.387458056211472f, 0.487169682979584f, 0.387831717729568f, 0.487255871295929f, + 0.388205498456955f, 0.487341761589050f, 0.388579308986664f, 0.487427353858948f, + 0.388953179121017f, 0.487512677907944f, 0.389327138662338f, 0.487597703933716f, + 0.389701157808304f, 0.487682431936264f, 0.390075236558914f, 0.487766891717911f, + 0.390449374914169f, 0.487851053476334f, 0.390823602676392f, 0.487934947013855f, + 0.391197860240936f, 0.488018542528152f, 0.391572207212448f, 0.488101840019226f, + 0.391946613788605f, 0.488184869289398f, 0.392321079969406f, 0.488267600536346f, + 0.392695605754852f, 0.488350033760071f, 0.393070191144943f, 0.488432198762894f, + 0.393444836139679f, 0.488514065742493f, 0.393819570541382f, 0.488595664501190f, + 0.394194334745407f, 0.488676935434341f, 0.394569188356400f, 0.488757967948914f, + 0.394944071769714f, 0.488838672637939f, 0.395319044589996f, 0.488919109106064f, + 0.395694077014923f, 0.488999247550964f, 0.396069169044495f, 0.489079117774963f, + 0.396444320678711f, 0.489158689975739f, 0.396819531917572f, 0.489237964153290f, + 0.397194802761078f, 0.489316970109940f, 0.397570133209229f, 0.489395678043365f, + 0.397945523262024f, 0.489474087953568f, 0.398320972919464f, 0.489552229642868f, + 0.398696482181549f, 0.489630073308945f, 0.399072051048279f, 0.489707618951797f, + 0.399447679519653f, 0.489784896373749f, 0.399823367595673f, 0.489861875772476f, + 0.400199115276337f, 0.489938557147980f, 0.400574922561646f, 0.490014940500259f, + 0.400950789451599f, 0.490091055631638f, 0.401326715946198f, 0.490166902542114f, + 0.401702702045441f, 0.490242421627045f, 0.402078747749329f, 0.490317672491074f, + 0.402454853057861f, 0.490392625331879f, 0.402830988168716f, 0.490467309951782f, + 0.403207212686539f, 0.490541696548462f, 0.403583467006683f, 0.490615785121918f, + 0.403959810733795f, 0.490689605474472f, 0.404336184263229f, 0.490763127803802f, + 0.404712617397308f, 0.490836352109909f, 0.405089110136032f, 0.490909278392792f, + 0.405465662479401f, 0.490981936454773f, 0.405842274427414f, 0.491054296493530f, + 0.406218945980072f, 0.491126358509064f, 0.406595647335052f, 0.491198152303696f, + 0.406972438097000f, 0.491269648075104f, 0.407349258661270f, 0.491340845823288f, + 0.407726138830185f, 0.491411775350571f, 0.408103078603745f, 0.491482406854630f, + 0.408480048179626f, 0.491552740335464f, 0.408857107162476f, 0.491622805595398f, + 0.409234195947647f, 0.491692543029785f, 0.409611344337463f, 0.491762012243271f, + 0.409988552331924f, 0.491831213235855f, 0.410365819931030f, 0.491900116205215f, + 0.410743117332459f, 0.491968721151352f, 0.411120474338531f, 0.492037028074265f, + 0.411497890949249f, 0.492105036973953f, 0.411875367164612f, 0.492172777652740f, + 0.412252873182297f, 0.492240220308304f, 0.412630438804626f, 0.492307394742966f, + 0.413008064031601f, 0.492374241352081f, 0.413385748863220f, 0.492440819740295f, + 0.413763463497162f, 0.492507129907608f, 0.414141237735748f, 0.492573112249374f, + 0.414519041776657f, 0.492638826370239f, 0.414896935224533f, 0.492704242467880f, + 0.415274858474731f, 0.492769360542297f, 0.415652841329575f, 0.492834210395813f, + 0.416030853986740f, 0.492898762226105f, 0.416408926248550f, 0.492963016033173f, + 0.416787058115005f, 0.493026971817017f, 0.417165219783783f, 0.493090659379959f, + 0.417543441057205f, 0.493154048919678f, 0.417921721935272f, 0.493217140436172f, + 0.418300032615662f, 0.493279963731766f, 0.418678402900696f, 0.493342459201813f, + 0.419056802988052f, 0.493404686450958f, 0.419435262680054f, 0.493466645479202f, + 0.419813781976700f, 0.493528276681900f, 0.420192331075668f, 0.493589639663696f, + 0.420570939779282f, 0.493650704622269f, 0.420949578285217f, 0.493711471557617f, + 0.421328276395798f, 0.493771970272064f, 0.421707004308701f, 0.493832170963287f, + 0.422085791826248f, 0.493892073631287f, 0.422464638948441f, 0.493951678276062f, + 0.422843515872955f, 0.494011014699936f, 0.423222452402115f, 0.494070053100586f, + 0.423601418733597f, 0.494128793478012f, 0.423980414867401f, 0.494187235832214f, + 0.424359470605850f, 0.494245409965515f, 0.424738585948944f, 0.494303256273270f, + 0.425117731094360f, 0.494360834360123f, 0.425496935844421f, 0.494418144226074f, + 0.425876170396805f, 0.494475126266479f, 0.426255434751511f, 0.494531840085983f, + 0.426634758710861f, 0.494588255882263f, 0.427014142274857f, 0.494644373655319f, + 0.427393525838852f, 0.494700223207474f, 0.427772998809814f, 0.494755744934082f, + 0.428152471780777f, 0.494810998439789f, 0.428532034158707f, 0.494865983724594f, + 0.428911596536636f, 0.494920641183853f, 0.429291218519211f, 0.494975030422211f, + 0.429670870304108f, 0.495029091835022f, 0.430050581693649f, 0.495082914829254f, + 0.430430322885513f, 0.495136409997940f, 0.430810123682022f, 0.495189607143402f, + 0.431189924478531f, 0.495242536067963f, 0.431569814682007f, 0.495295166969299f, + 0.431949704885483f, 0.495347499847412f, 0.432329654693604f, 0.495399564504623f, + 0.432709634304047f, 0.495451331138611f, 0.433089673519135f, 0.495502769947052f, + 0.433469742536545f, 0.495553970336914f, 0.433849841356277f, 0.495604842901230f, + 0.434229999780655f, 0.495655417442322f, 0.434610158205032f, 0.495705723762512f, + 0.434990376234055f, 0.495755732059479f, 0.435370653867722f, 0.495805442333221f, + 0.435750931501389f, 0.495854884386063f, 0.436131268739700f, 0.495903998613358f, + 0.436511665582657f, 0.495952844619751f, 0.436892062425613f, 0.496001392602921f, + 0.437272518873215f, 0.496049642562866f, 0.437653005123138f, 0.496097624301910f, + 0.438033521175385f, 0.496145308017731f, 0.438414067029953f, 0.496192663908005f, + 0.438794672489166f, 0.496239781379700f, 0.439175277948380f, 0.496286571025848f, + 0.439555943012238f, 0.496333062648773f, 0.439936667680740f, 0.496379286050797f, + 0.440317392349243f, 0.496425211429596f, 0.440698176622391f, 0.496470838785172f, + 0.441078960895538f, 0.496516168117523f, 0.441459804773331f, 0.496561229228973f, + 0.441840678453445f, 0.496605962514877f, 0.442221581935883f, 0.496650427579880f, + 0.442602545022964f, 0.496694594621658f, 0.442983508110046f, 0.496738493442535f, + 0.443364530801773f, 0.496782064437866f, 0.443745553493500f, 0.496825367212296f, + 0.444126635789871f, 0.496868371963501f, 0.444507747888565f, 0.496911078691483f, + 0.444888889789581f, 0.496953487396240f, 0.445270061492920f, 0.496995598077774f, + 0.445651292800903f, 0.497037440538406f, 0.446032524108887f, 0.497078984975815f, + 0.446413785219193f, 0.497120231389999f, 0.446795076131821f, 0.497161179780960f, + 0.447176426649094f, 0.497201830148697f, 0.447557777166367f, 0.497242212295532f, + 0.447939187288284f, 0.497282296419144f, 0.448320597410202f, 0.497322082519531f, + 0.448702067136765f, 0.497361570596695f, 0.449083566665649f, 0.497400760650635f, + 0.449465066194534f, 0.497439652681351f, 0.449846625328064f, 0.497478276491165f, + 0.450228184461594f, 0.497516602277756f, 0.450609803199768f, 0.497554630041122f, + 0.450991421937943f, 0.497592359781265f, 0.451373100280762f, 0.497629791498184f, + 0.451754778623581f, 0.497666954994202f, 0.452136516571045f, 0.497703820466995f, + 0.452518254518509f, 0.497740387916565f, 0.452900022268295f, 0.497776657342911f, + 0.453281819820404f, 0.497812628746033f, 0.453663676977158f, 0.497848302125931f, + 0.454045534133911f, 0.497883707284927f, 0.454427421092987f, 0.497918814420700f, + 0.454809308052063f, 0.497953623533249f, 0.455191254615784f, 0.497988134622574f, + 0.455573230981827f, 0.498022347688675f, 0.455955207347870f, 0.498056292533875f, + 0.456337243318558f, 0.498089909553528f, 0.456719279289246f, 0.498123258352280f, + 0.457101345062256f, 0.498156309127808f, 0.457483440637589f, 0.498189061880112f, + 0.457865566015244f, 0.498221516609192f, 0.458247691392899f, 0.498253703117371f, + 0.458629876375198f, 0.498285561800003f, 0.459012061357498f, 0.498317152261734f, + 0.459394276142120f, 0.498348444700241f, 0.459776520729065f, 0.498379439115524f, + 0.460158795118332f, 0.498410135507584f, 0.460541069507599f, 0.498440563678741f, + 0.460923373699188f, 0.498470664024353f, 0.461305707693100f, 0.498500496149063f, + 0.461688071489334f, 0.498530030250549f, 0.462070435285568f, 0.498559266328812f, + 0.462452858686447f, 0.498588204383850f, 0.462835282087326f, 0.498616874217987f, + 0.463217705488205f, 0.498645216226578f, 0.463600188493729f, 0.498673290014267f, + 0.463982671499252f, 0.498701065778732f, 0.464365184307098f, 0.498728543519974f, + 0.464747726917267f, 0.498755723237991f, 0.465130269527435f, 0.498782604932785f, + 0.465512841939926f, 0.498809218406677f, 0.465895414352417f, 0.498835533857346f, + 0.466278046369553f, 0.498861521482468f, 0.466660678386688f, 0.498887240886688f, + 0.467043310403824f, 0.498912662267685f, 0.467426002025604f, 0.498937815427780f, + 0.467808693647385f, 0.498962640762329f, 0.468191385269165f, 0.498987197875977f, + 0.468574106693268f, 0.499011427164078f, 0.468956857919693f, 0.499035388231277f, + 0.469339638948441f, 0.499059051275253f, 0.469722419977188f, 0.499082416296005f, + 0.470105201005936f, 0.499105513095856f, 0.470488041639328f, 0.499128282070160f, + 0.470870882272720f, 0.499150782823563f, 0.471253722906113f, 0.499172955751419f, + 0.471636593341827f, 0.499194860458374f, 0.472019463777542f, 0.499216467142105f, + 0.472402364015579f, 0.499237775802612f, 0.472785294055939f, 0.499258816242218f, + 0.473168224096298f, 0.499279528856277f, 0.473551183938980f, 0.499299973249435f, + 0.473934143781662f, 0.499320119619370f, 0.474317133426666f, 0.499339967966080f, + 0.474700123071671f, 0.499359518289566f, 0.475083142518997f, 0.499378770589828f, + 0.475466161966324f, 0.499397724866867f, 0.475849211215973f, 0.499416410923004f, + 0.476232260465622f, 0.499434769153595f, 0.476615339517593f, 0.499452859163284f, + 0.476998418569565f, 0.499470651149750f, 0.477381497621536f, 0.499488145112991f, + 0.477764606475830f, 0.499505341053009f, 0.478147745132446f, 0.499522238969803f, + 0.478530883789063f, 0.499538868665695f, 0.478914022445679f, 0.499555170536041f, + 0.479297190904617f, 0.499571204185486f, 0.479680359363556f, 0.499586939811707f, + 0.480063527822495f, 0.499602377414703f, 0.480446726083755f, 0.499617516994476f, + 0.480829954147339f, 0.499632388353348f, 0.481213152408600f, 0.499646931886673f, + 0.481596380472183f, 0.499661177396774f, 0.481979638338089f, 0.499675154685974f, + 0.482362866401672f, 0.499688833951950f, 0.482746154069901f, 0.499702215194702f, + 0.483129411935806f, 0.499715298414230f, 0.483512699604034f, 0.499728083610535f, + 0.483895987272263f, 0.499740600585938f, 0.484279274940491f, 0.499752789735794f, + 0.484662592411041f, 0.499764710664749f, 0.485045909881592f, 0.499776333570480f, + 0.485429257154465f, 0.499787658452988f, 0.485812574625015f, 0.499798685312271f, + 0.486195921897888f, 0.499809414148331f, 0.486579269170761f, 0.499819844961166f, + 0.486962646245956f, 0.499830007553101f, 0.487346023321152f, 0.499839842319489f, + 0.487729400396347f, 0.499849408864975f, 0.488112777471542f, 0.499858677387238f, + 0.488496154546738f, 0.499867647886276f, 0.488879561424255f, 0.499876320362091f, + 0.489262968301773f, 0.499884694814682f, 0.489646375179291f, 0.499892801046371f, + 0.490029782056808f, 0.499900579452515f, 0.490413218736649f, 0.499908089637756f, + 0.490796625614166f, 0.499915301799774f, 0.491180062294006f, 0.499922215938568f, + 0.491563498973846f, 0.499928832054138f, 0.491946935653687f, 0.499935150146484f, + 0.492330402135849f, 0.499941170215607f, 0.492713838815689f, 0.499946922063828f, + 0.493097305297852f, 0.499952346086502f, 0.493480771780014f, 0.499957501888275f, + 0.493864238262177f, 0.499962359666824f, 0.494247704744339f, 0.499966919422150f, + 0.494631171226501f, 0.499971181154251f, 0.495014637708664f, 0.499975144863129f, + 0.495398133993149f, 0.499978810548782f, 0.495781600475311f, 0.499982208013535f, + 0.496165096759796f, 0.499985307455063f, 0.496548563241959f, 0.499988079071045f, + 0.496932059526443f, 0.499990582466125f, 0.497315555810928f, 0.499992787837982f, + 0.497699022293091f, 0.499994695186615f, 0.498082518577576f, 0.499996334314346f, + 0.498466014862061f, 0.499997645616531f, 0.498849511146545f, 0.499998688697815f, + 0.499233007431030f, 0.499999403953552f, 0.499616503715515f, 0.499999850988388f, +}; + + +/** +* \par +* Generation of realCoefB array: +* \par +* n = 4096 +*
for (i = 0; i < n; i++)
+* {
+*    pBTable[2 * i] = 0.5 * (1.0 + sin (2 * PI / (double) (2 * n) * (double) i));
+*    pBTable[2 * i + 1] = 0.5 * (1.0 * cos (2 * PI / (double) (2 * n) * (double) i));
+*  } 
+* +*/ +static const float32_t realCoefB[8192] = { + 0.500000000000000f, 0.500000000000000f, 0.500383496284485f, 0.499999850988388f, + 0.500766992568970f, 0.499999403953552f, 0.501150488853455f, 0.499998688697815f, + 0.501533985137939f, 0.499997645616531f, 0.501917481422424f, 0.499996334314346f, + 0.502300977706909f, 0.499994695186615f, 0.502684473991394f, 0.499992787837982f, + 0.503067970275879f, 0.499990582466125f, 0.503451406955719f, 0.499988079071045f, + 0.503834903240204f, 0.499985307455063f, 0.504218399524689f, 0.499982208013535f, + 0.504601895809174f, 0.499978810548782f, 0.504985332489014f, 0.499975144863129f, + 0.505368828773499f, 0.499971181154251f, 0.505752325057983f, 0.499966919422150f, + 0.506135761737823f, 0.499962359666824f, 0.506519258022308f, 0.499957501888275f, + 0.506902694702148f, 0.499952346086502f, 0.507286131381989f, 0.499946922063828f, + 0.507669627666473f, 0.499941170215607f, 0.508053064346313f, 0.499935150146484f, + 0.508436501026154f, 0.499928832054138f, 0.508819937705994f, 0.499922215938568f, + 0.509203374385834f, 0.499915301799774f, 0.509586811065674f, 0.499908089637756f, + 0.509970188140869f, 0.499900579452515f, 0.510353624820709f, 0.499892801046371f, + 0.510737061500549f, 0.499884694814682f, 0.511120438575745f, 0.499876320362091f, + 0.511503815650940f, 0.499867647886276f, 0.511887252330780f, 0.499858677387238f, + 0.512270629405975f, 0.499849408864975f, 0.512654006481171f, 0.499839842319489f, + 0.513037383556366f, 0.499830007553101f, 0.513420701026917f, 0.499819844961166f, + 0.513804078102112f, 0.499809414148331f, 0.514187395572662f, 0.499798685312271f, + 0.514570772647858f, 0.499787658452988f, 0.514954090118408f, 0.499776333570480f, + 0.515337407588959f, 0.499764710664749f, 0.515720725059509f, 0.499752789735794f, + 0.516103982925415f, 0.499740600585938f, 0.516487300395966f, 0.499728083610535f, + 0.516870558261871f, 0.499715298414230f, 0.517253875732422f, 0.499702215194702f, + 0.517637133598328f, 0.499688833951950f, 0.518020391464233f, 0.499675154685974f, + 0.518403589725494f, 0.499661177396774f, 0.518786847591400f, 0.499646931886673f, + 0.519170045852661f, 0.499632388353348f, 0.519553244113922f, 0.499617516994476f, + 0.519936442375183f, 0.499602377414703f, 0.520319640636444f, 0.499586939811707f, + 0.520702838897705f, 0.499571204185486f, 0.521085977554321f, 0.499555170536041f, + 0.521469116210938f, 0.499538868665695f, 0.521852254867554f, 0.499522238969803f, + 0.522235393524170f, 0.499505341053009f, 0.522618472576141f, 0.499488145112991f, + 0.523001611232758f, 0.499470651149750f, 0.523384690284729f, 0.499452859163284f, + 0.523767769336700f, 0.499434769153595f, 0.524150788784027f, 0.499416410923004f, + 0.524533808231354f, 0.499397724866867f, 0.524916887283325f, 0.499378770589828f, + 0.525299847126007f, 0.499359518289566f, 0.525682866573334f, 0.499339967966080f, + 0.526065826416016f, 0.499320119619370f, 0.526448845863342f, 0.499299973249435f, + 0.526831746101379f, 0.499279528856277f, 0.527214705944061f, 0.499258816242218f, + 0.527597606182098f, 0.499237775802612f, 0.527980506420136f, 0.499216467142105f, + 0.528363406658173f, 0.499194860458374f, 0.528746306896210f, 0.499172955751419f, + 0.529129147529602f, 0.499150782823563f, 0.529511988162994f, 0.499128282070160f, + 0.529894769191742f, 0.499105513095856f, 0.530277609825134f, 0.499082416296005f, + 0.530660390853882f, 0.499059051275253f, 0.531043112277985f, 0.499035388231277f, + 0.531425893306732f, 0.499011427164078f, 0.531808614730835f, 0.498987197875977f, + 0.532191336154938f, 0.498962640762329f, 0.532573997974396f, 0.498937815427780f, + 0.532956659793854f, 0.498912662267685f, 0.533339321613312f, 0.498887240886688f, + 0.533721983432770f, 0.498861521482468f, 0.534104585647583f, 0.498835533857346f, + 0.534487187862396f, 0.498809218406677f, 0.534869730472565f, 0.498782604932785f, + 0.535252273082733f, 0.498755723237991f, 0.535634815692902f, 0.498728543519974f, + 0.536017298698425f, 0.498701065778732f, 0.536399841308594f, 0.498673290014267f, + 0.536782264709473f, 0.498645216226578f, 0.537164747714996f, 0.498616874217987f, + 0.537547171115875f, 0.498588204383850f, 0.537929534912109f, 0.498559266328812f, + 0.538311958312988f, 0.498530030250549f, 0.538694262504578f, 0.498500496149063f, + 0.539076626300812f, 0.498470664024353f, 0.539458930492401f, 0.498440563678741f, + 0.539841234683990f, 0.498410135507584f, 0.540223479270935f, 0.498379439115524f, + 0.540605723857880f, 0.498348444700241f, 0.540987968444824f, 0.498317152261734f, + 0.541370153427124f, 0.498285561800003f, 0.541752278804779f, 0.498253703117371f, + 0.542134463787079f, 0.498221516609192f, 0.542516589164734f, 0.498189061880112f, + 0.542898654937744f, 0.498156309127808f, 0.543280720710754f, 0.498123258352280f, + 0.543662786483765f, 0.498089909553528f, 0.544044792652130f, 0.498056292533875f, + 0.544426798820496f, 0.498022347688675f, 0.544808745384216f, 0.497988134622574f, + 0.545190691947937f, 0.497953623533249f, 0.545572578907013f, 0.497918814420700f, + 0.545954465866089f, 0.497883707284927f, 0.546336352825165f, 0.497848302125931f, + 0.546718180179596f, 0.497812628746033f, 0.547099947929382f, 0.497776657342911f, + 0.547481775283813f, 0.497740387916565f, 0.547863483428955f, 0.497703820466995f, + 0.548245191574097f, 0.497666954994202f, 0.548626899719238f, 0.497629791498184f, + 0.549008548259735f, 0.497592359781265f, 0.549390196800232f, 0.497554630041122f, + 0.549771785736084f, 0.497516602277756f, 0.550153374671936f, 0.497478276491165f, + 0.550534904003143f, 0.497439652681351f, 0.550916433334351f, 0.497400760650635f, + 0.551297962665558f, 0.497361570596695f, 0.551679372787476f, 0.497322082519531f, + 0.552060842514038f, 0.497282296419144f, 0.552442193031311f, 0.497242212295532f, + 0.552823603153229f, 0.497201830148697f, 0.553204894065857f, 0.497161179780960f, + 0.553586184978485f, 0.497120231389999f, 0.553967475891113f, 0.497078984975815f, + 0.554348707199097f, 0.497037440538406f, 0.554729938507080f, 0.496995598077774f, + 0.555111110210419f, 0.496953487396240f, 0.555492222309113f, 0.496911078691483f, + 0.555873334407806f, 0.496868371963501f, 0.556254446506500f, 0.496825367212296f, + 0.556635499000549f, 0.496782064437866f, 0.557016491889954f, 0.496738493442535f, + 0.557397484779358f, 0.496694594621658f, 0.557778418064117f, 0.496650427579880f, + 0.558159291744232f, 0.496605962514877f, 0.558540165424347f, 0.496561229228973f, + 0.558921039104462f, 0.496516168117523f, 0.559301853179932f, 0.496470838785172f, + 0.559682607650757f, 0.496425211429596f, 0.560063362121582f, 0.496379286050797f, + 0.560444056987762f, 0.496333062648773f, 0.560824692249298f, 0.496286571025848f, + 0.561205327510834f, 0.496239781379700f, 0.561585903167725f, 0.496192663908005f, + 0.561966478824615f, 0.496145308017731f, 0.562346994876862f, 0.496097624301910f, + 0.562727510929108f, 0.496049642562866f, 0.563107967376709f, 0.496001392602921f, + 0.563488364219666f, 0.495952844619751f, 0.563868701457977f, 0.495903998613358f, + 0.564249038696289f, 0.495854884386063f, 0.564629375934601f, 0.495805442333221f, + 0.565009593963623f, 0.495755732059479f, 0.565389811992645f, 0.495705723762512f, + 0.565770030021667f, 0.495655417442322f, 0.566150128841400f, 0.495604842901230f, + 0.566530287265778f, 0.495553970336914f, 0.566910326480865f, 0.495502769947052f, + 0.567290365695953f, 0.495451331138611f, 0.567670345306396f, 0.495399564504623f, + 0.568050265312195f, 0.495347499847412f, 0.568430185317993f, 0.495295166969299f, + 0.568810045719147f, 0.495242536067963f, 0.569189906120300f, 0.495189607143402f, + 0.569569647312164f, 0.495136409997940f, 0.569949388504028f, 0.495082914829254f, + 0.570329129695892f, 0.495029091835022f, 0.570708811283112f, 0.494975030422211f, + 0.571088373661041f, 0.494920641183853f, 0.571467995643616f, 0.494865983724594f, + 0.571847498416901f, 0.494810998439789f, 0.572227001190186f, 0.494755744934082f, + 0.572606444358826f, 0.494700223207474f, 0.572985887527466f, 0.494644373655319f, + 0.573365211486816f, 0.494588255882263f, 0.573744535446167f, 0.494531840085983f, + 0.574123859405518f, 0.494475126266479f, 0.574503064155579f, 0.494418144226074f, + 0.574882268905640f, 0.494360834360123f, 0.575261414051056f, 0.494303256273270f, + 0.575640499591827f, 0.494245409965515f, 0.576019585132599f, 0.494187235832214f, + 0.576398611068726f, 0.494128793478012f, 0.576777577400208f, 0.494070053100586f, + 0.577156484127045f, 0.494011014699936f, 0.577535390853882f, 0.493951678276062f, + 0.577914178371429f, 0.493892073631287f, 0.578292965888977f, 0.493832170963287f, + 0.578671753406525f, 0.493771970272064f, 0.579050421714783f, 0.493711471557617f, + 0.579429090023041f, 0.493650704622269f, 0.579807698726654f, 0.493589639663696f, + 0.580186247825623f, 0.493528276681900f, 0.580564737319946f, 0.493466645479202f, + 0.580943167209625f, 0.493404686450958f, 0.581321597099304f, 0.493342459201813f, + 0.581699967384338f, 0.493279963731766f, 0.582078278064728f, 0.493217140436172f, + 0.582456588745117f, 0.493154048919678f, 0.582834780216217f, 0.493090659379959f, + 0.583212971687317f, 0.493026971817017f, 0.583591103553772f, 0.492963016033173f, + 0.583969175815582f, 0.492898762226105f, 0.584347188472748f, 0.492834210395813f, + 0.584725141525269f, 0.492769360542297f, 0.585103094577789f, 0.492704242467880f, + 0.585480928421021f, 0.492638826370239f, 0.585858762264252f, 0.492573112249374f, + 0.586236536502838f, 0.492507129907608f, 0.586614251136780f, 0.492440819740295f, + 0.586991965770721f, 0.492374241352081f, 0.587369561195374f, 0.492307394742966f, + 0.587747097015381f, 0.492240220308304f, 0.588124632835388f, 0.492172777652740f, + 0.588502109050751f, 0.492105036973953f, 0.588879525661469f, 0.492037028074265f, + 0.589256882667542f, 0.491968721151352f, 0.589634180068970f, 0.491900116205215f, + 0.590011477470398f, 0.491831213235855f, 0.590388655662537f, 0.491762012243271f, + 0.590765833854675f, 0.491692543029785f, 0.591142892837524f, 0.491622805595398f, + 0.591519951820374f, 0.491552740335464f, 0.591896951198578f, 0.491482406854630f, + 0.592273890972137f, 0.491411775350571f, 0.592650771141052f, 0.491340845823288f, + 0.593027591705322f, 0.491269648075104f, 0.593404352664948f, 0.491198152303696f, + 0.593781054019928f, 0.491126358509064f, 0.594157755374908f, 0.491054296493530f, + 0.594534337520599f, 0.490981936454773f, 0.594910860061646f, 0.490909278392792f, + 0.595287382602692f, 0.490836352109909f, 0.595663845539093f, 0.490763127803802f, + 0.596040189266205f, 0.490689605474472f, 0.596416532993317f, 0.490615785121918f, + 0.596792817115784f, 0.490541696548462f, 0.597168982028961f, 0.490467309951782f, + 0.597545146942139f, 0.490392625331879f, 0.597921252250671f, 0.490317672491074f, + 0.598297297954559f, 0.490242421627045f, 0.598673284053802f, 0.490166902542114f, + 0.599049210548401f, 0.490091055631638f, 0.599425077438354f, 0.490014940500259f, + 0.599800884723663f, 0.489938557147980f, 0.600176632404327f, 0.489861875772476f, + 0.600552320480347f, 0.489784896373749f, 0.600927948951721f, 0.489707618951797f, + 0.601303517818451f, 0.489630073308945f, 0.601679027080536f, 0.489552229642868f, + 0.602054476737976f, 0.489474087953568f, 0.602429866790771f, 0.489395678043365f, + 0.602805197238922f, 0.489316970109940f, 0.603180468082428f, 0.489237964153290f, + 0.603555679321289f, 0.489158689975739f, 0.603930830955505f, 0.489079117774963f, + 0.604305922985077f, 0.488999247550964f, 0.604680955410004f, 0.488919109106064f, + 0.605055928230286f, 0.488838672637939f, 0.605430841445923f, 0.488757967948914f, + 0.605805635452271f, 0.488676935434341f, 0.606180429458618f, 0.488595664501190f, + 0.606555163860321f, 0.488514065742493f, 0.606929838657379f, 0.488432198762894f, + 0.607304394245148f, 0.488350033760071f, 0.607678949832916f, 0.488267600536346f, + 0.608053386211395f, 0.488184869289398f, 0.608427822589874f, 0.488101840019226f, + 0.608802139759064f, 0.488018542528152f, 0.609176397323608f, 0.487934947013855f, + 0.609550595283508f, 0.487851053476334f, 0.609924793243408f, 0.487766891717911f, + 0.610298871994019f, 0.487682431936264f, 0.610672831535339f, 0.487597703933716f, + 0.611046791076660f, 0.487512677907944f, 0.611420691013336f, 0.487427353858948f, + 0.611794531345367f, 0.487341761589050f, 0.612168252468109f, 0.487255871295929f, + 0.612541973590851f, 0.487169682979584f, 0.612915575504303f, 0.487083226442337f, + 0.613289117813110f, 0.486996471881866f, 0.613662600517273f, 0.486909449100494f, + 0.614036023616791f, 0.486822128295898f, 0.614409387111664f, 0.486734509468079f, + 0.614782691001892f, 0.486646622419357f, 0.615155875682831f, 0.486558437347412f, + 0.615529060363770f, 0.486469984054565f, 0.615902125835419f, 0.486381232738495f, + 0.616275131702423f, 0.486292183399200f, 0.616648077964783f, 0.486202865839005f, + 0.617020964622498f, 0.486113250255585f, 0.617393791675568f, 0.486023366451263f, + 0.617766559123993f, 0.485933154821396f, 0.618139207363129f, 0.485842704772949f, + 0.618511795997620f, 0.485751956701279f, 0.618884325027466f, 0.485660910606384f, + 0.619256794452667f, 0.485569566488266f, 0.619629204273224f, 0.485477954149246f, + 0.620001494884491f, 0.485386073589325f, 0.620373785495758f, 0.485293895006180f, + 0.620745956897736f, 0.485201418399811f, 0.621118068695068f, 0.485108673572540f, + 0.621490061283112f, 0.485015630722046f, 0.621862053871155f, 0.484922289848328f, + 0.622233927249908f, 0.484828680753708f, 0.622605800628662f, 0.484734803438187f, + 0.622977554798126f, 0.484640628099442f, 0.623349189758301f, 0.484546154737473f, + 0.623720824718475f, 0.484451413154602f, 0.624092340469360f, 0.484356373548508f, + 0.624463796615601f, 0.484261035919189f, 0.624835193157196f, 0.484165430068970f, + 0.625206530094147f, 0.484069555997849f, 0.625577747821808f, 0.483973383903503f, + 0.625948905944824f, 0.483876913785934f, 0.626320004463196f, 0.483780175447464f, + 0.626691043376923f, 0.483683139085770f, 0.627061963081360f, 0.483585834503174f, + 0.627432823181152f, 0.483488231897354f, 0.627803623676300f, 0.483390361070633f, + 0.628174364566803f, 0.483292192220688f, 0.628544986248016f, 0.483193725347519f, + 0.628915548324585f, 0.483094990253448f, 0.629286050796509f, 0.482995986938477f, + 0.629656434059143f, 0.482896685600281f, 0.630026817321777f, 0.482797086238861f, + 0.630397081375122f, 0.482697218656540f, 0.630767226219177f, 0.482597053050995f, + 0.631137371063232f, 0.482496619224548f, 0.631507396697998f, 0.482395917177200f, + 0.631877362728119f, 0.482294887304306f, 0.632247209548950f, 0.482193619012833f, + 0.632616996765137f, 0.482092022895813f, 0.632986724376678f, 0.481990188360214f, + 0.633356392383575f, 0.481888025999069f, 0.633725941181183f, 0.481785595417023f, + 0.634095430374146f, 0.481682896614075f, 0.634464859962463f, 0.481579899787903f, + 0.634834170341492f, 0.481476634740829f, 0.635203421115875f, 0.481373071670532f, + 0.635572552680969f, 0.481269240379334f, 0.635941684246063f, 0.481165111064911f, + 0.636310696601868f, 0.481060713529587f, 0.636679589748383f, 0.480956017971039f, + 0.637048482894897f, 0.480851024389267f, 0.637417197227478f, 0.480745792388916f, + 0.637785911560059f, 0.480640232563019f, 0.638154506683350f, 0.480534434318542f, + 0.638523042201996f, 0.480428308248520f, 0.638891458511353f, 0.480321943759918f, + 0.639259815216064f, 0.480215251445770f, 0.639628112316132f, 0.480108320713043f, + 0.639996349811554f, 0.480001062154770f, 0.640364408493042f, 0.479893565177917f, + 0.640732467174530f, 0.479785770177841f, 0.641100406646729f, 0.479677677154541f, + 0.641468286514282f, 0.479569315910339f, 0.641836047172546f, 0.479460656642914f, + 0.642203748226166f, 0.479351729154587f, 0.642571389675140f, 0.479242533445358f, + 0.642938911914825f, 0.479133039712906f, 0.643306374549866f, 0.479023247957230f, + 0.643673717975616f, 0.478913217782974f, 0.644041001796722f, 0.478802859783173f, + 0.644408226013184f, 0.478692263364792f, 0.644775331020355f, 0.478581339120865f, + 0.645142316818237f, 0.478470176458359f, 0.645509302616119f, 0.478358715772629f, + 0.645876109600067f, 0.478246957063675f, 0.646242916584015f, 0.478134930133820f, + 0.646609604358673f, 0.478022634983063f, 0.646976172924042f, 0.477910041809082f, + 0.647342681884766f, 0.477797180414200f, 0.647709131240845f, 0.477684020996094f, + 0.648075461387634f, 0.477570593357086f, 0.648441672325134f, 0.477456867694855f, + 0.648807883262634f, 0.477342873811722f, 0.649173915386200f, 0.477228611707687f, + 0.649539887905121f, 0.477114051580429f, 0.649905800819397f, 0.476999223232269f, + 0.650271594524384f, 0.476884096860886f, 0.650637328624725f, 0.476768702268600f, + 0.651003003120422f, 0.476653009653091f, 0.651368498802185f, 0.476537048816681f, + 0.651733994483948f, 0.476420819759369f, 0.652099311351776f, 0.476304292678833f, + 0.652464628219604f, 0.476187497377396f, 0.652829825878143f, 0.476070433855057f, + 0.653194904327393f, 0.475953072309494f, 0.653559923171997f, 0.475835442543030f, + 0.653924822807312f, 0.475717514753342f, 0.654289662837982f, 0.475599318742752f, + 0.654654383659363f, 0.475480824708939f, 0.655019044876099f, 0.475362062454224f, + 0.655383586883545f, 0.475243031978607f, 0.655748009681702f, 0.475123733282089f, + 0.656112432479858f, 0.475004136562347f, 0.656476676464081f, 0.474884241819382f, + 0.656840860843658f, 0.474764078855515f, 0.657204985618591f, 0.474643647670746f, + 0.657568991184235f, 0.474522948265076f, 0.657932877540588f, 0.474401950836182f, + 0.658296704292297f, 0.474280685186386f, 0.658660411834717f, 0.474159121513367f, + 0.659024059772491f, 0.474037289619446f, 0.659387588500977f, 0.473915189504623f, + 0.659750998020172f, 0.473792791366577f, 0.660114347934723f, 0.473670125007629f, + 0.660477638244629f, 0.473547190427780f, 0.660840749740601f, 0.473423957824707f, + 0.661203861236572f, 0.473300457000732f, 0.661566793918610f, 0.473176687955856f, + 0.661929666996002f, 0.473052620887756f, 0.662292480468750f, 0.472928285598755f, + 0.662655174732208f, 0.472803652286530f, 0.663017749786377f, 0.472678780555725f, + 0.663380205631256f, 0.472553610801697f, 0.663742601871490f, 0.472428143024445f, + 0.664104938507080f, 0.472302407026291f, 0.664467096328735f, 0.472176402807236f, + 0.664829254150391f, 0.472050130367279f, 0.665191233158112f, 0.471923559904099f, + 0.665553152561188f, 0.471796721220016f, 0.665914952754974f, 0.471669614315033f, + 0.666276693344116f, 0.471542209386826f, 0.666638314723969f, 0.471414536237717f, + 0.666999816894531f, 0.471286594867706f, 0.667361259460449f, 0.471158385276794f, + 0.667722582817078f, 0.471029877662659f, 0.668083786964417f, 0.470901101827621f, + 0.668444931507111f, 0.470772027969360f, 0.668805956840515f, 0.470642685890198f, + 0.669166862964630f, 0.470513075590134f, 0.669527709484100f, 0.470383197069168f, + 0.669888436794281f, 0.470253020524979f, 0.670249044895172f, 0.470122605562210f, + 0.670609593391418f, 0.469991862773895f, 0.670970022678375f, 0.469860881567001f, + 0.671330332756042f, 0.469729602336884f, 0.671690583229065f, 0.469598054885864f, + 0.672050714492798f, 0.469466239213943f, 0.672410726547241f, 0.469334155321121f, + 0.672770678997040f, 0.469201773405075f, 0.673130512237549f, 0.469069123268127f, + 0.673490226268768f, 0.468936175107956f, 0.673849821090698f, 0.468802988529205f, + 0.674209356307983f, 0.468669503927231f, 0.674568772315979f, 0.468535751104355f, + 0.674928069114685f, 0.468401730060577f, 0.675287246704102f, 0.468267410993576f, + 0.675646364688873f, 0.468132823705673f, 0.676005363464355f, 0.467997968196869f, + 0.676364302635193f, 0.467862844467163f, 0.676723062992096f, 0.467727422714233f, + 0.677081763744354f, 0.467591762542725f, 0.677440345287323f, 0.467455804347992f, + 0.677798807621002f, 0.467319577932358f, 0.678157210350037f, 0.467183053493500f, + 0.678515493869781f, 0.467046260833740f, 0.678873658180237f, 0.466909229755402f, + 0.679231703281403f, 0.466771900653839f, 0.679589688777924f, 0.466634273529053f, + 0.679947495460510f, 0.466496407985687f, 0.680305242538452f, 0.466358244419098f, + 0.680662930011749f, 0.466219812631607f, 0.681020438671112f, 0.466081112623215f, + 0.681377887725830f, 0.465942144393921f, 0.681735157966614f, 0.465802878141403f, + 0.682092368602753f, 0.465663343667984f, 0.682449519634247f, 0.465523540973663f, + 0.682806491851807f, 0.465383470058441f, 0.683163404464722f, 0.465243130922318f, + 0.683520197868347f, 0.465102523565292f, 0.683876872062683f, 0.464961618185043f, + 0.684233427047729f, 0.464820444583893f, 0.684589862823486f, 0.464679002761841f, + 0.684946238994598f, 0.464537292718887f, 0.685302436351776f, 0.464395314455032f, + 0.685658574104309f, 0.464253038167953f, 0.686014592647552f, 0.464110493659973f, + 0.686370551586151f, 0.463967710733414f, 0.686726331710815f, 0.463824629783630f, + 0.687082052230835f, 0.463681250810623f, 0.687437593936920f, 0.463537633419037f, + 0.687793076038361f, 0.463393747806549f, 0.688148438930511f, 0.463249564170837f, + 0.688503682613373f, 0.463105112314224f, 0.688858866691589f, 0.462960392236710f, + 0.689213871955872f, 0.462815403938293f, 0.689568817615509f, 0.462670147418976f, + 0.689923584461212f, 0.462524622678757f, 0.690278291702271f, 0.462378799915314f, + 0.690632879734039f, 0.462232738733292f, 0.690987348556519f, 0.462086379528046f, + 0.691341698169708f, 0.461939752101898f, 0.691695988178253f, 0.461792886257172f, + 0.692050099372864f, 0.461645722389221f, 0.692404091358185f, 0.461498260498047f, + 0.692758023738861f, 0.461350560188293f, 0.693111836910248f, 0.461202591657639f, + 0.693465530872345f, 0.461054325103760f, 0.693819046020508f, 0.460905820131302f, + 0.694172501564026f, 0.460757017135620f, 0.694525837898254f, 0.460607945919037f, + 0.694879114627838f, 0.460458606481552f, 0.695232212543488f, 0.460309028625488f, + 0.695585191249847f, 0.460159152746201f, 0.695938050746918f, 0.460008978843689f, + 0.696290850639343f, 0.459858566522598f, 0.696643471717834f, 0.459707885980606f, + 0.696996033191681f, 0.459556937217712f, 0.697348415851593f, 0.459405690431595f, + 0.697700738906860f, 0.459254205226898f, 0.698052942752838f, 0.459102421998978f, + 0.698404967784882f, 0.458950400352478f, 0.698756933212280f, 0.458798080682755f, + 0.699108779430389f, 0.458645492792130f, 0.699460506439209f, 0.458492636680603f, + 0.699812114238739f, 0.458339542150497f, 0.700163602828979f, 0.458186149597168f, + 0.700514972209930f, 0.458032488822937f, 0.700866222381592f, 0.457878559827805f, + 0.701217353343964f, 0.457724362611771f, 0.701568365097046f, 0.457569897174835f, + 0.701919257640839f, 0.457415163516998f, 0.702270030975342f, 0.457260161638260f, + 0.702620685100555f, 0.457104891538620f, 0.702971220016479f, 0.456949323415756f, + 0.703321635723114f, 0.456793516874313f, 0.703671932220459f, 0.456637442111969f, + 0.704022109508514f, 0.456481099128723f, 0.704372167587280f, 0.456324487924576f, + 0.704722046852112f, 0.456167578697205f, 0.705071866512299f, 0.456010431051254f, + 0.705421566963196f, 0.455853015184402f, 0.705771148204803f, 0.455695331096649f, + 0.706120610237122f, 0.455537378787994f, 0.706469953060150f, 0.455379128456116f, + 0.706819176673889f, 0.455220639705658f, 0.707168221473694f, 0.455061882734299f, + 0.707517206668854f, 0.454902857542038f, 0.707866072654724f, 0.454743564128876f, + 0.708214759826660f, 0.454584002494812f, 0.708563387393951f, 0.454424172639847f, + 0.708911836147308f, 0.454264044761658f, 0.709260225296021f, 0.454103678464890f, + 0.709608435630798f, 0.453943043947220f, 0.709956526756287f, 0.453782171010971f, + 0.710304558277130f, 0.453621000051498f, 0.710652410984039f, 0.453459560871124f, + 0.711000144481659f, 0.453297853469849f, 0.711347758769989f, 0.453135877847672f, + 0.711695253849030f, 0.452973634004593f, 0.712042629718781f, 0.452811151742935f, + 0.712389826774597f, 0.452648371458054f, 0.712736964225769f, 0.452485352754593f, + 0.713083922863007f, 0.452322036027908f, 0.713430821895599f, 0.452158480882645f, + 0.713777542114258f, 0.451994657516479f, 0.714124143123627f, 0.451830536127090f, + 0.714470624923706f, 0.451666176319122f, 0.714816987514496f, 0.451501548290253f, + 0.715163230895996f, 0.451336652040482f, 0.715509355068207f, 0.451171487569809f, + 0.715855300426483f, 0.451006084680557f, 0.716201186180115f, 0.450840383768082f, + 0.716546893119812f, 0.450674414634705f, 0.716892480850220f, 0.450508207082748f, + 0.717238008975983f, 0.450341701507568f, 0.717583298683167f, 0.450174957513809f, + 0.717928528785706f, 0.450007945299149f, 0.718273639678955f, 0.449840664863586f, + 0.718618571758270f, 0.449673116207123f, 0.718963444232941f, 0.449505299329758f, + 0.719308137893677f, 0.449337244033813f, 0.719652712345123f, 0.449168890714645f, + 0.719997107982636f, 0.449000298976898f, 0.720341444015503f, 0.448831409215927f, + 0.720685660839081f, 0.448662281036377f, 0.721029698848724f, 0.448492884635925f, + 0.721373617649078f, 0.448323249816895f, 0.721717417240143f, 0.448153316974640f, + 0.722061097621918f, 0.447983115911484f, 0.722404599189758f, 0.447812676429749f, + 0.722747981548309f, 0.447641968727112f, 0.723091304302216f, 0.447470992803574f, + 0.723434448242188f, 0.447299748659134f, 0.723777413368225f, 0.447128236293793f, + 0.724120318889618f, 0.446956485509872f, 0.724463045597076f, 0.446784436702728f, + 0.724805653095245f, 0.446612149477005f, 0.725148141384125f, 0.446439594030380f, + 0.725490510463715f, 0.446266770362854f, 0.725832700729370f, 0.446093708276749f, + 0.726174771785736f, 0.445920348167419f, 0.726516723632813f, 0.445746749639511f, + 0.726858556270599f, 0.445572882890701f, 0.727200269699097f, 0.445398747920990f, + 0.727541804313660f, 0.445224374532700f, 0.727883219718933f, 0.445049703121185f, + 0.728224515914917f, 0.444874793291092f, 0.728565633296967f, 0.444699615240097f, + 0.728906631469727f, 0.444524168968201f, 0.729247510433197f, 0.444348484277725f, + 0.729588270187378f, 0.444172531366348f, 0.729928910732269f, 0.443996280431747f, + 0.730269372463226f, 0.443819820880890f, 0.730609714984894f, 0.443643063306808f, + 0.730949878692627f, 0.443466067314148f, 0.731289982795715f, 0.443288803100586f, + 0.731629908084869f, 0.443111270666122f, 0.731969714164734f, 0.442933470010757f, + 0.732309341430664f, 0.442755430936813f, 0.732648849487305f, 0.442577123641968f, + 0.732988238334656f, 0.442398548126221f, 0.733327507972717f, 0.442219734191895f, + 0.733666598796844f, 0.442040622234344f, 0.734005570411682f, 0.441861271858215f, + 0.734344422817230f, 0.441681683063507f, 0.734683096408844f, 0.441501796245575f, + 0.735021650791168f, 0.441321671009064f, 0.735360085964203f, 0.441141277551651f, + 0.735698342323303f, 0.440960645675659f, 0.736036539077759f, 0.440779715776443f, + 0.736374497413635f, 0.440598547458649f, 0.736712396144867f, 0.440417140722275f, + 0.737050116062164f, 0.440235435962677f, 0.737387716770172f, 0.440053492784500f, + 0.737725138664246f, 0.439871311187744f, 0.738062441349030f, 0.439688831567764f, + 0.738399624824524f, 0.439506113529205f, 0.738736629486084f, 0.439323127269745f, + 0.739073514938354f, 0.439139902591705f, 0.739410281181335f, 0.438956409692764f, + 0.739746868610382f, 0.438772648572922f, 0.740083336830139f, 0.438588619232178f, + 0.740419685840607f, 0.438404351472855f, 0.740755856037140f, 0.438219845294952f, + 0.741091907024384f, 0.438035041093826f, 0.741427779197693f, 0.437849998474121f, + 0.741763532161713f, 0.437664687633514f, 0.742099165916443f, 0.437479138374329f, + 0.742434620857239f, 0.437293320894241f, 0.742769956588745f, 0.437107264995575f, + 0.743105113506317f, 0.436920911073685f, 0.743440151214600f, 0.436734348535538f, + 0.743775069713593f, 0.436547487974167f, 0.744109809398651f, 0.436360388994217f, + 0.744444429874420f, 0.436173021793365f, 0.744778931140900f, 0.435985416173935f, + 0.745113253593445f, 0.435797542333603f, 0.745447397232056f, 0.435609430074692f, + 0.745781481266022f, 0.435421019792557f, 0.746115326881409f, 0.435232400894165f, + 0.746449112892151f, 0.435043483972549f, 0.746782720088959f, 0.434854328632355f, + 0.747116148471832f, 0.434664934873581f, 0.747449457645416f, 0.434475272893906f, + 0.747782647609711f, 0.434285342693329f, 0.748115658760071f, 0.434095174074173f, + 0.748448550701141f, 0.433904737234116f, 0.748781263828278f, 0.433714061975479f, + 0.749113857746124f, 0.433523118495941f, 0.749446272850037f, 0.433331936597824f, + 0.749778568744659f, 0.433140486478806f, 0.750110685825348f, 0.432948768138886f, + 0.750442683696747f, 0.432756811380386f, 0.750774562358856f, 0.432564586400986f, + 0.751106262207031f, 0.432372123003006f, 0.751437783241272f, 0.432179391384125f, + 0.751769185066223f, 0.431986421346664f, 0.752100467681885f, 0.431793183088303f, + 0.752431571483612f, 0.431599706411362f, 0.752762496471405f, 0.431405961513519f, + 0.753093302249908f, 0.431211978197098f, 0.753423988819122f, 0.431017726659775f, + 0.753754496574402f, 0.430823236703873f, 0.754084885120392f, 0.430628478527069f, + 0.754415094852448f, 0.430433481931686f, 0.754745125770569f, 0.430238217115402f, + 0.755075037479401f, 0.430042684078217f, 0.755404829978943f, 0.429846942424774f, + 0.755734443664551f, 0.429650902748108f, 0.756063878536224f, 0.429454624652863f, + 0.756393194198608f, 0.429258108139038f, 0.756722390651703f, 0.429061323404312f, + 0.757051348686218f, 0.428864300251007f, 0.757380247116089f, 0.428667008876801f, + 0.757708966732025f, 0.428469479084015f, 0.758037507534027f, 0.428271710872650f, + 0.758365929126740f, 0.428073674440384f, 0.758694171905518f, 0.427875369787216f, + 0.759022235870361f, 0.427676826715469f, 0.759350180625916f, 0.427478045225143f, + 0.759678006172180f, 0.427278995513916f, 0.760005652904511f, 0.427079707384110f, + 0.760333120822906f, 0.426880151033401f, 0.760660469532013f, 0.426680356264114f, + 0.760987639427185f, 0.426480293273926f, 0.761314690113068f, 0.426279991865158f, + 0.761641561985016f, 0.426079452037811f, 0.761968255043030f, 0.425878643989563f, + 0.762294828891754f, 0.425677597522736f, 0.762621283531189f, 0.425476282835007f, + 0.762947499752045f, 0.425274729728699f, 0.763273596763611f, 0.425072938203812f, + 0.763599574565887f, 0.424870878458023f, 0.763925373554230f, 0.424668580293655f, + 0.764250993728638f, 0.424466013908386f, 0.764576494693756f, 0.424263238906860f, + 0.764901816844940f, 0.424060165882111f, 0.765226960182190f, 0.423856884241104f, + 0.765551984310150f, 0.423653304576874f, 0.765876889228821f, 0.423449516296387f, + 0.766201555728912f, 0.423245459794998f, 0.766526103019714f, 0.423041164875031f, + 0.766850471496582f, 0.422836631536484f, 0.767174720764160f, 0.422631829977036f, + 0.767498791217804f, 0.422426789999008f, 0.767822742462158f, 0.422221481800079f, + 0.768146514892578f, 0.422015935182571f, 0.768470108509064f, 0.421810150146484f, + 0.768793523311615f, 0.421604126691818f, 0.769116818904877f, 0.421397835016251f, + 0.769439935684204f, 0.421191304922104f, 0.769762933254242f, 0.420984506607056f, + 0.770085752010345f, 0.420777499675751f, 0.770408391952515f, 0.420570224523544f, + 0.770730912685394f, 0.420362681150436f, 0.771053194999695f, 0.420154929161072f, + 0.771375417709351f, 0.419946908950806f, 0.771697402000427f, 0.419738620519638f, + 0.772019267082214f, 0.419530123472214f, 0.772340953350067f, 0.419321358203888f, + 0.772662520408630f, 0.419112354516983f, 0.772983849048615f, 0.418903112411499f, + 0.773305058479309f, 0.418693602085114f, 0.773626148700714f, 0.418483853340149f, + 0.773947000503540f, 0.418273866176605f, 0.774267733097076f, 0.418063640594482f, + 0.774588346481323f, 0.417853146791458f, 0.774908721446991f, 0.417642414569855f, + 0.775228977203369f, 0.417431443929672f, 0.775549054145813f, 0.417220205068588f, + 0.775869011878967f, 0.417008757591248f, 0.776188731193542f, 0.416797041893005f, + 0.776508331298828f, 0.416585087776184f, 0.776827812194824f, 0.416372895240784f, + 0.777147054672241f, 0.416160434484482f, 0.777466177940369f, 0.415947735309601f, + 0.777785122394562f, 0.415734797716141f, 0.778103888034821f, 0.415521621704102f, + 0.778422534465790f, 0.415308207273483f, 0.778741002082825f, 0.415094524621964f, + 0.779059290885925f, 0.414880603551865f, 0.779377400875092f, 0.414666473865509f, + 0.779695332050323f, 0.414452046155930f, 0.780013144016266f, 0.414237409830093f, + 0.780330777168274f, 0.414022535085678f, 0.780648231506348f, 0.413807392120361f, + 0.780965566635132f, 0.413592010736465f, 0.781282722949982f, 0.413376390933990f, + 0.781599700450897f, 0.413160532712936f, 0.781916499137878f, 0.412944436073303f, + 0.782233119010925f, 0.412728071212769f, 0.782549619674683f, 0.412511497735977f, + 0.782865881919861f, 0.412294656038284f, 0.783182024955750f, 0.412077575922012f, + 0.783498048782349f, 0.411860257387161f, 0.783813834190369f, 0.411642700433731f, + 0.784129500389099f, 0.411424905061722f, 0.784444928169250f, 0.411206841468811f, + 0.784760236740112f, 0.410988569259644f, 0.785075426101685f, 0.410770028829575f, + 0.785390377044678f, 0.410551249980927f, 0.785705149173737f, 0.410332232713699f, + 0.786019802093506f, 0.410112977027893f, 0.786334276199341f, 0.409893482923508f, + 0.786648571491241f, 0.409673750400543f, 0.786962687969208f, 0.409453779459000f, + 0.787276685237885f, 0.409233570098877f, 0.787590444087982f, 0.409013092517853f, + 0.787904083728790f, 0.408792406320572f, 0.788217544555664f, 0.408571451902390f, + 0.788530826568604f, 0.408350288867950f, 0.788843929767609f, 0.408128857612610f, + 0.789156913757324f, 0.407907217741013f, 0.789469659328461f, 0.407685309648514f, + 0.789782285690308f, 0.407463163137436f, 0.790094733238220f, 0.407240778207779f, + 0.790407001972198f, 0.407018154859543f, 0.790719091892242f, 0.406795293092728f, + 0.791031002998352f, 0.406572192907333f, 0.791342735290527f, 0.406348884105682f, + 0.791654348373413f, 0.406125307083130f, 0.791965723037720f, 0.405901491641998f, + 0.792276978492737f, 0.405677437782288f, 0.792588055133820f, 0.405453115701675f, + 0.792898952960968f, 0.405228585004807f, 0.793209671974182f, 0.405003815889359f, + 0.793520212173462f, 0.404778808355331f, 0.793830573558807f, 0.404553562402725f, + 0.794140756130219f, 0.404328078031540f, 0.794450819492340f, 0.404102355241776f, + 0.794760644435883f, 0.403876423835754f, 0.795070350170136f, 0.403650224208832f, + 0.795379877090454f, 0.403423786163330f, 0.795689165592194f, 0.403197109699249f, + 0.795998334884644f, 0.402970194816589f, 0.796307325363159f, 0.402743041515350f, + 0.796616137027740f, 0.402515679597855f, 0.796924769878387f, 0.402288049459457f, + 0.797233223915100f, 0.402060180902481f, 0.797541558742523f, 0.401832103729248f, + 0.797849655151367f, 0.401603758335114f, 0.798157572746277f, 0.401375204324722f, + 0.798465371131897f, 0.401146411895752f, 0.798772931098938f, 0.400917351245880f, + 0.799080371856689f, 0.400688081979752f, 0.799387574195862f, 0.400458574295044f, + 0.799694657325745f, 0.400228828191757f, 0.800001561641693f, 0.399998843669891f, + 0.800308227539063f, 0.399768620729446f, 0.800614774227142f, 0.399538189172745f, + 0.800921142101288f, 0.399307489395142f, 0.801227271556854f, 0.399076581001282f, + 0.801533281803131f, 0.398845434188843f, 0.801839113235474f, 0.398614019155502f, + 0.802144765853882f, 0.398382395505905f, 0.802450239658356f, 0.398150533437729f, + 0.802755534648895f, 0.397918462753296f, 0.803060650825500f, 0.397686123847961f, + 0.803365588188171f, 0.397453576326370f, 0.803670346736908f, 0.397220760583878f, + 0.803974866867065f, 0.396987736225128f, 0.804279267787933f, 0.396754473447800f, + 0.804583489894867f, 0.396520972251892f, 0.804887533187866f, 0.396287262439728f, + 0.805191397666931f, 0.396053284406662f, 0.805495083332062f, 0.395819097757339f, + 0.805798590183258f, 0.395584672689438f, 0.806101918220520f, 0.395350009202957f, + 0.806405067443848f, 0.395115107297897f, 0.806707978248596f, 0.394879996776581f, + 0.807010769844055f, 0.394644618034363f, 0.807313382625580f, 0.394409030675888f, + 0.807615816593170f, 0.394173204898834f, 0.807918012142181f, 0.393937170505524f, + 0.808220088481903f, 0.393700867891312f, 0.808521986007690f, 0.393464356660843f, + 0.808823645114899f, 0.393227607011795f, 0.809125185012817f, 0.392990618944168f, + 0.809426486492157f, 0.392753422260284f, 0.809727668762207f, 0.392515957355499f, + 0.810028612613678f, 0.392278283834457f, 0.810329377651215f, 0.392040401697159f, + 0.810629963874817f, 0.391802251338959f, 0.810930430889130f, 0.391563892364502f, + 0.811230659484863f, 0.391325294971466f, 0.811530709266663f, 0.391086459159851f, + 0.811830580234528f, 0.390847414731979f, 0.812130272388458f, 0.390608131885529f, + 0.812429726123810f, 0.390368610620499f, 0.812729060649872f, 0.390128880739212f, + 0.813028216362000f, 0.389888882637024f, 0.813327133655548f, 0.389648675918579f, + 0.813625931739807f, 0.389408260583878f, 0.813924491405487f, 0.389167606830597f, + 0.814222872257233f, 0.388926714658737f, 0.814521074295044f, 0.388685584068298f, + 0.814819097518921f, 0.388444244861603f, 0.815116941928864f, 0.388202667236328f, + 0.815414607524872f, 0.387960851192474f, 0.815712094306946f, 0.387718826532364f, + 0.816009342670441f, 0.387476563453674f, 0.816306471824646f, 0.387234061956406f, + 0.816603362560272f, 0.386991351842880f, 0.816900074481964f, 0.386748403310776f, + 0.817196667194366f, 0.386505216360092f, 0.817493021488190f, 0.386261820793152f, + 0.817789137363434f, 0.386018186807632f, 0.818085134029388f, 0.385774344205856f, + 0.818380951881409f, 0.385530263185501f, 0.818676531314850f, 0.385285943746567f, + 0.818971931934357f, 0.385041415691376f, 0.819267153739929f, 0.384796649217606f, + 0.819562196731567f, 0.384551674127579f, 0.819857060909271f, 0.384306460618973f, + 0.820151746273041f, 0.384061008691788f, 0.820446193218231f, 0.383815348148346f, + 0.820740520954132f, 0.383569449186325f, 0.821034610271454f, 0.383323341608047f, + 0.821328520774841f, 0.383076995611191f, 0.821622252464294f, 0.382830440998077f, + 0.821915745735168f, 0.382583618164063f, 0.822209119796753f, 0.382336616516113f, + 0.822502255439758f, 0.382089376449585f, 0.822795212268829f, 0.381841897964478f, + 0.823087990283966f, 0.381594210863113f, 0.823380589485168f, 0.381346285343170f, + 0.823673009872437f, 0.381098151206970f, 0.823965191841125f, 0.380849778652191f, + 0.824257194995880f, 0.380601197481155f, 0.824549019336700f, 0.380352377891541f, + 0.824840664863586f, 0.380103349685669f, 0.825132071971893f, 0.379854083061218f, + 0.825423359870911f, 0.379604607820511f, 0.825714409351349f, 0.379354894161224f, + 0.826005280017853f, 0.379104942083359f, 0.826295912265778f, 0.378854811191559f, + 0.826586425304413f, 0.378604412078857f, 0.826876699924469f, 0.378353834152222f, + 0.827166795730591f, 0.378102988004684f, 0.827456712722778f, 0.377851963043213f, + 0.827746450901031f, 0.377600699663162f, 0.828035950660706f, 0.377349197864532f, + 0.828325271606445f, 0.377097487449646f, 0.828614413738251f, 0.376845568418503f, + 0.828903317451477f, 0.376593410968781f, 0.829192101955414f, 0.376341015100479f, + 0.829480648040771f, 0.376088410615921f, 0.829769015312195f, 0.375835597515106f, + 0.830057144165039f, 0.375582575798035f, 0.830345153808594f, 0.375329315662384f, + 0.830632925033569f, 0.375075817108154f, 0.830920517444611f, 0.374822109937668f, + 0.831207871437073f, 0.374568194150925f, 0.831495106220245f, 0.374314039945602f, + 0.831782102584839f, 0.374059677124023f, 0.832068860530853f, 0.373805105686188f, + 0.832355499267578f, 0.373550295829773f, 0.832641899585724f, 0.373295277357101f, + 0.832928121089935f, 0.373040050268173f, 0.833214163780212f, 0.372784584760666f, + 0.833499968051910f, 0.372528880834579f, 0.833785593509674f, 0.372272998094559f, + 0.834071040153503f, 0.372016876935959f, 0.834356248378754f, 0.371760547161102f, + 0.834641277790070f, 0.371503978967667f, 0.834926128387451f, 0.371247202157974f, + 0.835210800170898f, 0.370990216732025f, 0.835495233535767f, 0.370732992887497f, + 0.835779488086700f, 0.370475560426712f, 0.836063504219055f, 0.370217919349670f, + 0.836347401142120f, 0.369960039854050f, 0.836631059646606f, 0.369701951742172f, + 0.836914479732513f, 0.369443655014038f, 0.837197780609131f, 0.369185149669647f, + 0.837480843067169f, 0.368926405906677f, 0.837763667106628f, 0.368667453527451f, + 0.838046371936798f, 0.368408292531967f, 0.838328838348389f, 0.368148893117905f, + 0.838611066341400f, 0.367889285087585f, 0.838893175125122f, 0.367629468441010f, + 0.839175045490265f, 0.367369443178177f, 0.839456677436829f, 0.367109179496765f, + 0.839738130569458f, 0.366848707199097f, 0.840019404888153f, 0.366588026285172f, + 0.840300500392914f, 0.366327136754990f, 0.840581357479095f, 0.366066008806229f, + 0.840862035751343f, 0.365804702043533f, 0.841142535209656f, 0.365543156862259f, + 0.841422796249390f, 0.365281373262405f, 0.841702818870544f, 0.365019410848618f, + 0.841982722282410f, 0.364757210016251f, 0.842262387275696f, 0.364494800567627f, + 0.842541813850403f, 0.364232182502747f, 0.842821121215820f, 0.363969355821610f, + 0.843100130558014f, 0.363706320524216f, 0.843379020690918f, 0.363443046808243f, + 0.843657672405243f, 0.363179564476013f, 0.843936145305634f, 0.362915903329849f, + 0.844214379787445f, 0.362651973962784f, 0.844492435455322f, 0.362387865781784f, + 0.844770252704620f, 0.362123548984528f, 0.845047891139984f, 0.361858993768692f, + 0.845325350761414f, 0.361594229936600f, 0.845602571964264f, 0.361329287290573f, + 0.845879614353180f, 0.361064106225967f, 0.846156477928162f, 0.360798716545105f, + 0.846433103084564f, 0.360533088445663f, 0.846709489822388f, 0.360267281532288f, + 0.846985757350922f, 0.360001266002655f, 0.847261726856232f, 0.359735012054443f, + 0.847537577152252f, 0.359468549489975f, 0.847813189029694f, 0.359201908111572f, + 0.848088562488556f, 0.358935028314590f, 0.848363757133484f, 0.358667939901352f, + 0.848638772964478f, 0.358400642871857f, 0.848913550376892f, 0.358133137226105f, + 0.849188148975372f, 0.357865422964096f, 0.849462509155273f, 0.357597470283508f, + 0.849736690521240f, 0.357329338788986f, 0.850010633468628f, 0.357060998678207f, + 0.850284397602081f, 0.356792420148849f, 0.850557923316956f, 0.356523662805557f, + 0.850831270217896f, 0.356254696846008f, 0.851104438304901f, 0.355985492467880f, + 0.851377367973328f, 0.355716109275818f, 0.851650118827820f, 0.355446487665176f, + 0.851922631263733f, 0.355176687240601f, 0.852194905281067f, 0.354906648397446f, + 0.852467060089111f, 0.354636400938034f, 0.852738916873932f, 0.354365974664688f, + 0.853010654449463f, 0.354095309972763f, 0.853282094001770f, 0.353824466466904f, + 0.853553414344788f, 0.353553384542465f, 0.853824436664581f, 0.353282123804092f, + 0.854095339775085f, 0.353010624647141f, 0.854365944862366f, 0.352738946676254f, + 0.854636430740356f, 0.352467030286789f, 0.854906618595123f, 0.352194935083389f, + 0.855176687240601f, 0.351922631263733f, 0.855446517467499f, 0.351650089025497f, + 0.855716109275818f, 0.351377367973328f, 0.855985522270203f, 0.351104438304901f, + 0.856254696846008f, 0.350831300020218f, 0.856523692607880f, 0.350557953119278f, + 0.856792449951172f, 0.350284397602081f, 0.857060968875885f, 0.350010633468628f, + 0.857329368591309f, 0.349736660718918f, 0.857597470283508f, 0.349462509155273f, + 0.857865393161774f, 0.349188119173050f, 0.858133137226105f, 0.348913550376892f, + 0.858400642871857f, 0.348638743162155f, 0.858667910099030f, 0.348363757133484f, + 0.858934998512268f, 0.348088562488556f, 0.859201908111572f, 0.347813159227371f, + 0.859468579292297f, 0.347537547349930f, 0.859735012054443f, 0.347261756658554f, + 0.860001266002655f, 0.346985727548599f, 0.860267281532288f, 0.346709519624710f, + 0.860533118247986f, 0.346433073282242f, 0.860798716545105f, 0.346156448125839f, + 0.861064076423645f, 0.345879614353180f, 0.861329257488251f, 0.345602601766586f, + 0.861594259738922f, 0.345325350761414f, 0.861859023571014f, 0.345047920942307f, + 0.862123548984528f, 0.344770282506943f, 0.862387895584106f, 0.344492435455322f, + 0.862652003765106f, 0.344214379787445f, 0.862915873527527f, 0.343936115503311f, + 0.863179564476013f, 0.343657672405243f, 0.863443076610565f, 0.343379020690918f, + 0.863706290721893f, 0.343100160360336f, 0.863969385623932f, 0.342821091413498f, + 0.864232182502747f, 0.342541843652725f, 0.864494800567627f, 0.342262357473373f, + 0.864757239818573f, 0.341982692480087f, 0.865019381046295f, 0.341702848672867f, + 0.865281403064728f, 0.341422766447067f, 0.865543127059937f, 0.341142505407333f, + 0.865804672241211f, 0.340862035751343f, 0.866066038608551f, 0.340581357479095f, + 0.866327106952667f, 0.340300500392914f, 0.866588056087494f, 0.340019434690475f, + 0.866848707199097f, 0.339738160371780f, 0.867109179496765f, 0.339456677436829f, + 0.867369413375854f, 0.339175015687943f, 0.867629468441010f, 0.338893145322800f, + 0.867889285087585f, 0.338611096143723f, 0.868148922920227f, 0.338328808546066f, + 0.868408262729645f, 0.338046342134476f, 0.868667483329773f, 0.337763696908951f, + 0.868926405906677f, 0.337480813264847f, 0.869185149669647f, 0.337197750806808f, + 0.869443655014038f, 0.336914509534836f, 0.869701981544495f, 0.336631029844284f, + 0.869960069656372f, 0.336347371339798f, 0.870217919349670f, 0.336063534021378f, + 0.870475590229034f, 0.335779488086700f, 0.870733022689819f, 0.335495233535767f, + 0.870990216732025f, 0.335210770368576f, 0.871247172355652f, 0.334926128387451f, + 0.871503949165344f, 0.334641307592392f, 0.871760547161102f, 0.334356248378754f, + 0.872016847133636f, 0.334071010351181f, 0.872272968292236f, 0.333785593509674f, + 0.872528910636902f, 0.333499968051910f, 0.872784554958344f, 0.333214133977890f, + 0.873040020465851f, 0.332928121089935f, 0.873295307159424f, 0.332641899585724f, + 0.873550295829773f, 0.332355499267578f, 0.873805105686188f, 0.332068890333176f, + 0.874059677124023f, 0.331782072782516f, 0.874314069747925f, 0.331495076417923f, + 0.874568223953247f, 0.331207901239395f, 0.874822139739990f, 0.330920487642288f, + 0.875075817108154f, 0.330632925033569f, 0.875329315662384f, 0.330345153808594f, + 0.875582575798035f, 0.330057173967361f, 0.875835597515106f, 0.329769015312195f, + 0.876088440418243f, 0.329480648040771f, 0.876341044902802f, 0.329192101955414f, + 0.876593410968781f, 0.328903347253799f, 0.876845538616180f, 0.328614413738251f, + 0.877097487449646f, 0.328325271606445f, 0.877349197864532f, 0.328035950660706f, + 0.877600669860840f, 0.327746421098709f, 0.877851963043213f, 0.327456712722778f, + 0.878103017807007f, 0.327166795730591f, 0.878353834152222f, 0.326876699924469f, + 0.878604412078857f, 0.326586425304413f, 0.878854811191559f, 0.326295942068100f, + 0.879104971885681f, 0.326005280017853f, 0.879354894161224f, 0.325714409351349f, + 0.879604578018188f, 0.325423330068588f, 0.879854083061218f, 0.325132101774216f, + 0.880103349685669f, 0.324840664863586f, 0.880352377891541f, 0.324549019336700f, + 0.880601167678833f, 0.324257194995880f, 0.880849778652191f, 0.323965191841125f, + 0.881098151206970f, 0.323672980070114f, 0.881346285343170f, 0.323380589485168f, + 0.881594181060791f, 0.323088020086288f, 0.881841897964478f, 0.322795242071152f, + 0.882089376449585f, 0.322502255439758f, 0.882336616516113f, 0.322209119796753f, + 0.882583618164063f, 0.321915775537491f, 0.882830440998077f, 0.321622252464294f, + 0.883076965808868f, 0.321328520774841f, 0.883323311805725f, 0.321034610271454f, + 0.883569478988647f, 0.320740520954132f, 0.883815348148346f, 0.320446223020554f, + 0.884061038494110f, 0.320151746273041f, 0.884306430816650f, 0.319857090711594f, + 0.884551644325256f, 0.319562226533890f, 0.884796679019928f, 0.319267183542252f, + 0.885041415691376f, 0.318971961736679f, 0.885285973548889f, 0.318676531314850f, + 0.885530233383179f, 0.318380922079086f, 0.885774314403534f, 0.318085134029388f, + 0.886018216609955f, 0.317789167165756f, 0.886261820793152f, 0.317492991685867f, + 0.886505246162415f, 0.317196637392044f, 0.886748373508453f, 0.316900104284287f, + 0.886991322040558f, 0.316603392362595f, 0.887234091758728f, 0.316306471824646f, + 0.887476563453674f, 0.316009372472763f, 0.887718796730042f, 0.315712094306946f, + 0.887960851192474f, 0.315414607524872f, 0.888202667236328f, 0.315116971731186f, + 0.888444244861603f, 0.314819127321243f, 0.888685584068298f, 0.314521104097366f, + 0.888926684856415f, 0.314222872257233f, 0.889167606830597f, 0.313924491405487f, + 0.889408230781555f, 0.313625901937485f, 0.889648675918579f, 0.313327133655548f, + 0.889888882637024f, 0.313028186559677f, 0.890128850936890f, 0.312729060649872f, + 0.890368640422821f, 0.312429755926132f, 0.890608131885529f, 0.312130242586136f, + 0.890847444534302f, 0.311830550432205f, 0.891086459159851f, 0.311530679464340f, + 0.891325294971466f, 0.311230629682541f, 0.891563892364502f, 0.310930401086807f, + 0.891802251338959f, 0.310629993677139f, 0.892040371894836f, 0.310329377651215f, + 0.892278313636780f, 0.310028612613678f, 0.892515957355499f, 0.309727638959885f, + 0.892753422260284f, 0.309426486492157f, 0.892990648746490f, 0.309125155210495f, + 0.893227577209473f, 0.308823645114899f, 0.893464326858521f, 0.308521956205368f, + 0.893700897693634f, 0.308220088481903f, 0.893937170505524f, 0.307918041944504f, + 0.894173204898834f, 0.307615786790848f, 0.894409060478210f, 0.307313382625580f, + 0.894644618034363f, 0.307010769844055f, 0.894879996776581f, 0.306708008050919f, + 0.895115137100220f, 0.306405037641525f, 0.895349979400635f, 0.306101888418198f, + 0.895584642887115f, 0.305798590183258f, 0.895819067955017f, 0.305495083332062f, + 0.896053314208984f, 0.305191397666931f, 0.896287262439728f, 0.304887533187866f, + 0.896520972251892f, 0.304583519697189f, 0.896754503250122f, 0.304279297590256f, + 0.896987736225128f, 0.303974896669388f, 0.897220790386200f, 0.303670316934586f, + 0.897453546524048f, 0.303365558385849f, 0.897686123847961f, 0.303060621023178f, + 0.897918462753296f, 0.302755534648895f, 0.898150563240051f, 0.302450239658356f, + 0.898382425308228f, 0.302144765853882f, 0.898614048957825f, 0.301839113235474f, + 0.898845434188843f, 0.301533311605453f, 0.899076581001282f, 0.301227301359177f, + 0.899307489395142f, 0.300921112298965f, 0.899538159370422f, 0.300614774227142f, + 0.899768650531769f, 0.300308227539063f, 0.899998843669891f, 0.300001531839371f, + 0.900228857994080f, 0.299694657325745f, 0.900458574295044f, 0.299387603998184f, + 0.900688111782074f, 0.299080342054367f, 0.900917351245880f, 0.298772931098938f, + 0.901146411895752f, 0.298465341329575f, 0.901375174522400f, 0.298157602548599f, + 0.901603758335114f, 0.297849655151367f, 0.901832103729248f, 0.297541528940201f, + 0.902060210704803f, 0.297233253717422f, 0.902288019657135f, 0.296924799680710f, + 0.902515649795532f, 0.296616137027740f, 0.902743041515350f, 0.296307325363159f, + 0.902970194816589f, 0.295998334884644f, 0.903197109699249f, 0.295689195394516f, + 0.903423786163330f, 0.295379847288132f, 0.903650224208832f, 0.295070350170136f, + 0.903876423835754f, 0.294760644435883f, 0.904102385044098f, 0.294450789690018f, + 0.904328107833862f, 0.294140785932541f, 0.904553592205048f, 0.293830573558807f, + 0.904778838157654f, 0.293520182371140f, 0.905003845691681f, 0.293209642171860f, + 0.905228614807129f, 0.292898923158646f, 0.905453145503998f, 0.292588025331497f, + 0.905677437782288f, 0.292276978492737f, 0.905901491641998f, 0.291965723037720f, + 0.906125307083130f, 0.291654318571091f, 0.906348884105682f, 0.291342735290527f, + 0.906572222709656f, 0.291031002998352f, 0.906795322895050f, 0.290719062089920f, + 0.907018184661865f, 0.290406972169876f, 0.907240808010101f, 0.290094703435898f, + 0.907463192939758f, 0.289782285690308f, 0.907685279846191f, 0.289469659328461f, + 0.907907187938690f, 0.289156883955002f, 0.908128857612610f, 0.288843959569931f, + 0.908350288867950f, 0.288530826568604f, 0.908571481704712f, 0.288217544555664f, + 0.908792436122894f, 0.287904083728790f, 0.909013092517853f, 0.287590473890305f, + 0.909233570098877f, 0.287276685237885f, 0.909453809261322f, 0.286962717771530f, + 0.909673750400543f, 0.286648571491241f, 0.909893512725830f, 0.286334276199341f, + 0.910112977027893f, 0.286019802093506f, 0.910332262516022f, 0.285705178976059f, + 0.910551249980927f, 0.285390377044678f, 0.910769999027252f, 0.285075396299362f, + 0.910988569259644f, 0.284760266542435f, 0.911206841468811f, 0.284444957971573f, + 0.911424875259399f, 0.284129470586777f, 0.911642670631409f, 0.283813834190369f, + 0.911860227584839f, 0.283498018980026f, 0.912077546119690f, 0.283182054758072f, + 0.912294626235962f, 0.282865911722183f, 0.912511467933655f, 0.282549589872360f, + 0.912728071212769f, 0.282233119010925f, 0.912944436073303f, 0.281916469335556f, + 0.913160502910614f, 0.281599670648575f, 0.913376390933990f, 0.281282693147659f, + 0.913592040538788f, 0.280965566635132f, 0.913807392120361f, 0.280648261308670f, + 0.914022505283356f, 0.280330777168274f, 0.914237439632416f, 0.280013144016266f, + 0.914452075958252f, 0.279695361852646f, 0.914666473865509f, 0.279377400875092f, + 0.914880633354187f, 0.279059261083603f, 0.915094554424286f, 0.278740972280502f, + 0.915308177471161f, 0.278422504663467f, 0.915521621704102f, 0.278103888034821f, + 0.915734827518463f, 0.277785122394562f, 0.915947735309601f, 0.277466177940369f, + 0.916160404682159f, 0.277147054672241f, 0.916372895240784f, 0.276827782392502f, + 0.916585087776184f, 0.276508361101151f, 0.916797041893005f, 0.276188760995865f, + 0.917008757591248f, 0.275868982076645f, 0.917220234870911f, 0.275549083948135f, + 0.917431414127350f, 0.275228977203369f, 0.917642414569855f, 0.274908751249313f, + 0.917853116989136f, 0.274588316679001f, 0.918063640594482f, 0.274267762899399f, + 0.918273866176605f, 0.273947030305862f, 0.918483853340149f, 0.273626148700714f, + 0.918693602085114f, 0.273305088281631f, 0.918903112411499f, 0.272983878850937f, + 0.919112324714661f, 0.272662490606308f, 0.919321358203888f, 0.272340953350067f, + 0.919530093669891f, 0.272019267082214f, 0.919738650321960f, 0.271697402000427f, + 0.919946908950806f, 0.271375387907028f, 0.920154929161072f, 0.271053224802017f, + 0.920362710952759f, 0.270730882883072f, 0.920570194721222f, 0.270408391952515f, + 0.920777499675751f, 0.270085722208023f, 0.920984506607056f, 0.269762933254242f, + 0.921191275119781f, 0.269439965486526f, 0.921397805213928f, 0.269116818904877f, + 0.921604096889496f, 0.268793523311615f, 0.921810150146484f, 0.268470078706741f, + 0.922015964984894f, 0.268146485090256f, 0.922221481800079f, 0.267822742462158f, + 0.922426760196686f, 0.267498821020126f, 0.922631800174713f, 0.267174720764160f, + 0.922836601734161f, 0.266850501298904f, 0.923041164875031f, 0.266526103019714f, + 0.923245489597321f, 0.266201555728912f, 0.923449516296387f, 0.265876859426498f, + 0.923653304576874f, 0.265552014112473f, 0.923856854438782f, 0.265226989984512f, + 0.924060165882111f, 0.264901816844940f, 0.924263238906860f, 0.264576494693756f, + 0.924466013908386f, 0.264250993728638f, 0.924668610095978f, 0.263925373554230f, + 0.924870908260345f, 0.263599574565887f, 0.925072908401489f, 0.263273626565933f, + 0.925274729728699f, 0.262947499752045f, 0.925476312637329f, 0.262621253728867f, + 0.925677597522736f, 0.262294828891754f, 0.925878643989563f, 0.261968284845352f, + 0.926079452037811f, 0.261641561985016f, 0.926280021667480f, 0.261314690113068f, + 0.926480293273926f, 0.260987639427185f, 0.926680326461792f, 0.260660469532013f, + 0.926880121231079f, 0.260333120822906f, 0.927079677581787f, 0.260005623102188f, + 0.927278995513916f, 0.259678006172180f, 0.927478015422821f, 0.259350210428238f, + 0.927676856517792f, 0.259022265672684f, 0.927875399589539f, 0.258694142103195f, + 0.928073644638062f, 0.258365899324417f, 0.928271710872650f, 0.258037507534027f, + 0.928469479084015f, 0.257708936929703f, 0.928667008876801f, 0.257380217313766f, + 0.928864300251007f, 0.257051378488541f, 0.929061353206635f, 0.256722360849380f, + 0.929258108139038f, 0.256393194198608f, 0.929454624652863f, 0.256063878536224f, + 0.929650902748108f, 0.255734413862228f, 0.929846942424774f, 0.255404800176620f, + 0.930042684078217f, 0.255075037479401f, 0.930238187313080f, 0.254745125770569f, + 0.930433452129364f, 0.254415065050125f, 0.930628478527069f, 0.254084855318069f, + 0.930823206901550f, 0.253754496574402f, 0.931017756462097f, 0.253423988819122f, + 0.931211948394775f, 0.253093332052231f, 0.931405961513519f, 0.252762526273727f, + 0.931599736213684f, 0.252431541681290f, 0.931793212890625f, 0.252100437879562f, + 0.931986451148987f, 0.251769185066223f, 0.932179391384125f, 0.251437783241272f, + 0.932372152805328f, 0.251106232404709f, 0.932564616203308f, 0.250774532556534f, + 0.932756841182709f, 0.250442683696747f, 0.932948768138886f, 0.250110685825348f, + 0.933140456676483f, 0.249778553843498f, 0.933331906795502f, 0.249446272850037f, + 0.933523118495941f, 0.249113827943802f, 0.933714091777802f, 0.248781248927116f, + 0.933904767036438f, 0.248448520898819f, 0.934095203876495f, 0.248115643858910f, + 0.934285342693329f, 0.247782632708550f, 0.934475243091583f, 0.247449472546577f, + 0.934664964675903f, 0.247116148471832f, 0.934854328632355f, 0.246782705187798f, + 0.935043513774872f, 0.246449097990990f, 0.935232400894165f, 0.246115356683731f, + 0.935421049594879f, 0.245781451463699f, 0.935609400272369f, 0.245447427034378f, + 0.935797572135925f, 0.245113238692284f, 0.935985386371613f, 0.244778916239738f, + 0.936173021793365f, 0.244444444775581f, 0.936360359191895f, 0.244109839200974f, + 0.936547517776489f, 0.243775084614754f, 0.936734318733215f, 0.243440181016922f, + 0.936920940876007f, 0.243105143308640f, 0.937107264995575f, 0.242769956588745f, + 0.937293350696564f, 0.242434620857239f, 0.937479138374329f, 0.242099151015282f, + 0.937664687633514f, 0.241763532161713f, 0.937849998474121f, 0.241427779197693f, + 0.938035070896149f, 0.241091892123222f, 0.938219845294952f, 0.240755841135979f, + 0.938404381275177f, 0.240419670939446f, 0.938588619232178f, 0.240083336830139f, + 0.938772618770599f, 0.239746883511543f, 0.938956379890442f, 0.239410281181335f, + 0.939139902591705f, 0.239073529839516f, 0.939323127269745f, 0.238736644387245f, + 0.939506113529205f, 0.238399609923363f, 0.939688861370087f, 0.238062441349030f, + 0.939871311187744f, 0.237725138664246f, 0.940053522586823f, 0.237387686967850f, + 0.940235435962677f, 0.237050101161003f, 0.940417110919952f, 0.236712381243706f, + 0.940598547458649f, 0.236374512314796f, 0.940779745578766f, 0.236036509275436f, + 0.940960645675659f, 0.235698372125626f, 0.941141307353973f, 0.235360085964203f, + 0.941321671009064f, 0.235021665692329f, 0.941501796245575f, 0.234683111310005f, + 0.941681683063507f, 0.234344407916069f, 0.941861271858215f, 0.234005570411682f, + 0.942040622234344f, 0.233666598796844f, 0.942219734191895f, 0.233327493071556f, + 0.942398548126221f, 0.232988253235817f, 0.942577123641968f, 0.232648864388466f, + 0.942755401134491f, 0.232309341430664f, 0.942933499813080f, 0.231969684362412f, + 0.943111240863800f, 0.231629893183708f, 0.943288803100586f, 0.231289967894554f, + 0.943466067314148f, 0.230949893593788f, 0.943643093109131f, 0.230609700083733f, + 0.943819820880890f, 0.230269357562065f, 0.943996310234070f, 0.229928880929947f, + 0.944172501564026f, 0.229588270187378f, 0.944348454475403f, 0.229247525334358f, + 0.944524168968201f, 0.228906646370888f, 0.944699645042419f, 0.228565633296967f, + 0.944874763488770f, 0.228224486112595f, 0.945049703121185f, 0.227883204817772f, + 0.945224344730377f, 0.227541789412498f, 0.945398747920990f, 0.227200239896774f, + 0.945572853088379f, 0.226858556270599f, 0.945746779441834f, 0.226516738533974f, + 0.945920348167419f, 0.226174786686897f, 0.946093678474426f, 0.225832715630531f, + 0.946266770362854f, 0.225490495562553f, 0.946439623832703f, 0.225148141384125f, + 0.946612179279327f, 0.224805667996407f, 0.946784436702728f, 0.224463045597076f, + 0.946956455707550f, 0.224120303988457f, 0.947128236293793f, 0.223777428269386f, + 0.947299718856812f, 0.223434418439865f, 0.947470963001251f, 0.223091274499893f, + 0.947641968727112f, 0.222748011350632f, 0.947812676429749f, 0.222404599189758f, + 0.947983145713806f, 0.222061067819595f, 0.948153316974640f, 0.221717402338982f, + 0.948323249816895f, 0.221373617649078f, 0.948492884635925f, 0.221029683947563f, + 0.948662281036377f, 0.220685631036758f, 0.948831439018250f, 0.220341444015503f, + 0.949000298976898f, 0.219997137784958f, 0.949168920516968f, 0.219652697443962f, + 0.949337244033813f, 0.219308122992516f, 0.949505329132080f, 0.218963414430618f, + 0.949673116207123f, 0.218618586659431f, 0.949840664863586f, 0.218273624777794f, + 0.950007975101471f, 0.217928543686867f, 0.950174987316132f, 0.217583328485489f, + 0.950341701507568f, 0.217237979173660f, 0.950508177280426f, 0.216892510652542f, + 0.950674414634705f, 0.216546908020973f, 0.950840353965759f, 0.216201186180115f, + 0.951006054878235f, 0.215855330228806f, 0.951171517372131f, 0.215509355068207f, + 0.951336681842804f, 0.215163245797157f, 0.951501548290253f, 0.214817002415657f, + 0.951666176319122f, 0.214470639824867f, 0.951830565929413f, 0.214124158024788f, + 0.951994657516479f, 0.213777542114258f, 0.952158451080322f, 0.213430806994438f, + 0.952322065830231f, 0.213083937764168f, 0.952485322952271f, 0.212736949324608f, + 0.952648401260376f, 0.212389841675758f, 0.952811121940613f, 0.212042599916458f, + 0.952973663806915f, 0.211695238947868f, 0.953135907649994f, 0.211347743868828f, + 0.953297853469849f, 0.211000129580498f, 0.953459560871124f, 0.210652396082878f, + 0.953620970249176f, 0.210304543375969f, 0.953782141208649f, 0.209956556558609f, + 0.953943073749542f, 0.209608450531960f, 0.954103708267212f, 0.209260210394859f, + 0.954264044761658f, 0.208911851048470f, 0.954424142837524f, 0.208563387393951f, + 0.954584002494812f, 0.208214774727821f, 0.954743564128876f, 0.207866057753563f, + 0.954902827739716f, 0.207517206668854f, 0.955061912536621f, 0.207168251276016f, + 0.955220639705658f, 0.206819161772728f, 0.955379128456116f, 0.206469938158989f, + 0.955537378787994f, 0.206120610237122f, 0.955695331096649f, 0.205771163105965f, + 0.955853044986725f, 0.205421581864357f, 0.956010460853577f, 0.205071896314621f, + 0.956167578697205f, 0.204722076654434f, 0.956324458122253f, 0.204372137784958f, + 0.956481099128723f, 0.204022079706192f, 0.956637442111969f, 0.203671902418137f, + 0.956793546676636f, 0.203321605920792f, 0.956949353218079f, 0.202971190214157f, + 0.957104861736298f, 0.202620655298233f, 0.957260131835938f, 0.202270001173019f, + 0.957415163516998f, 0.201919227838516f, 0.957569897174835f, 0.201568335294724f, + 0.957724332809448f, 0.201217323541641f, 0.957878530025482f, 0.200866192579269f, + 0.958032488822937f, 0.200514942407608f, 0.958186149597168f, 0.200163587927818f, + 0.958339512348175f, 0.199812099337578f, 0.958492636680603f, 0.199460506439209f, + 0.958645522594452f, 0.199108779430389f, 0.958798050880432f, 0.198756948113441f, + 0.958950400352478f, 0.198404997587204f, 0.959102451801300f, 0.198052927851677f, + 0.959254205226898f, 0.197700738906860f, 0.959405720233917f, 0.197348430752754f, + 0.959556937217712f, 0.196996018290520f, 0.959707856178284f, 0.196643486618996f, + 0.959858596324921f, 0.196290835738182f, 0.960008978843689f, 0.195938065648079f, + 0.960159122943878f, 0.195585191249847f, 0.960309028625488f, 0.195232197642326f, + 0.960458636283875f, 0.194879084825516f, 0.960607945919037f, 0.194525867700577f, + 0.960757017135620f, 0.194172516465187f, 0.960905790328979f, 0.193819075822830f, + 0.961054325103760f, 0.193465501070023f, 0.961202561855316f, 0.193111822009087f, + 0.961350560188293f, 0.192758023738861f, 0.961498260498047f, 0.192404121160507f, + 0.961645722389221f, 0.192050099372864f, 0.961792886257172f, 0.191695958375931f, + 0.961939752101898f, 0.191341713070869f, 0.962086379528046f, 0.190987363457680f, + 0.962232708930969f, 0.190632879734039f, 0.962378799915314f, 0.190278306603432f, + 0.962524592876434f, 0.189923599362373f, 0.962670147418976f, 0.189568802714348f, + 0.962815403938293f, 0.189213871955872f, 0.962960422039032f, 0.188858851790428f, + 0.963105142116547f, 0.188503712415695f, 0.963249564170837f, 0.188148453831673f, + 0.963393747806549f, 0.187793090939522f, 0.963537633419037f, 0.187437608838081f, + 0.963681280612946f, 0.187082037329674f, 0.963824629783630f, 0.186726331710815f, + 0.963967680931091f, 0.186370536684990f, 0.964110493659973f, 0.186014622449875f, + 0.964253067970276f, 0.185658603906631f, 0.964395284652710f, 0.185302466154099f, + 0.964537262916565f, 0.184946224093437f, 0.964679002761841f, 0.184589877724648f, + 0.964820444583893f, 0.184233412146568f, 0.964961588382721f, 0.183876842260361f, + 0.965102493762970f, 0.183520168066025f, 0.965243160724640f, 0.183163389563560f, + 0.965383470058441f, 0.182806491851807f, 0.965523540973663f, 0.182449504733086f, + 0.965663373470306f, 0.182092398405075f, 0.965802907943726f, 0.181735187768936f, + 0.965942144393921f, 0.181377857923508f, 0.966081082820892f, 0.181020438671112f, + 0.966219842433929f, 0.180662900209427f, 0.966358244419098f, 0.180305257439613f, + 0.966496407985687f, 0.179947525262833f, 0.966634273529053f, 0.179589673876762f, + 0.966771900653839f, 0.179231703281403f, 0.966909229755402f, 0.178873643279076f, + 0.967046260833740f, 0.178515478968620f, 0.967183053493500f, 0.178157210350037f, + 0.967319548130035f, 0.177798837423325f, 0.967455804347992f, 0.177440345287323f, + 0.967591762542725f, 0.177081763744354f, 0.967727422714233f, 0.176723077893257f, + 0.967862844467163f, 0.176364272832870f, 0.967997968196869f, 0.176005378365517f, + 0.968132853507996f, 0.175646379590034f, 0.968267440795898f, 0.175287276506424f, + 0.968401730060577f, 0.174928069114685f, 0.968535780906677f, 0.174568757414818f, + 0.968669533729553f, 0.174209341406822f, 0.968802988529205f, 0.173849821090698f, + 0.968936204910278f, 0.173490211367607f, 0.969069123268127f, 0.173130482435226f, + 0.969201743602753f, 0.172770664095879f, 0.969334125518799f, 0.172410741448402f, + 0.969466269016266f, 0.172050714492798f, 0.969598054885864f, 0.171690583229065f, + 0.969729602336884f, 0.171330362558365f, 0.969860911369324f, 0.170970037579536f, + 0.969991862773895f, 0.170609608292580f, 0.970122575759888f, 0.170249074697495f, + 0.970253050327301f, 0.169888436794281f, 0.970383226871490f, 0.169527709484100f, + 0.970513105392456f, 0.169166877865791f, 0.970642685890198f, 0.168805956840515f, + 0.970772027969360f, 0.168444931507111f, 0.970901072025299f, 0.168083801865578f, + 0.971029877662659f, 0.167722567915916f, 0.971158385276794f, 0.167361244559288f, + 0.971286594867706f, 0.166999831795692f, 0.971414566040039f, 0.166638299822807f, + 0.971542239189148f, 0.166276678442955f, 0.971669614315033f, 0.165914967656136f, + 0.971796751022339f, 0.165553152561188f, 0.971923589706421f, 0.165191248059273f, + 0.972050130367279f, 0.164829224348068f, 0.972176432609558f, 0.164467126131058f, + 0.972302436828613f, 0.164104923605919f, 0.972428143024445f, 0.163742616772652f, + 0.972553610801697f, 0.163380220532417f, 0.972678780555725f, 0.163017734885216f, + 0.972803652286530f, 0.162655144929886f, 0.972928285598755f, 0.162292465567589f, + 0.973052620887756f, 0.161929681897163f, 0.973176658153534f, 0.161566808819771f, + 0.973300457000732f, 0.161203846335411f, 0.973423957824707f, 0.160840779542923f, + 0.973547160625458f, 0.160477623343468f, 0.973670125007629f, 0.160114362835884f, + 0.973792791366577f, 0.159751012921333f, 0.973915159702301f, 0.159387573599815f, + 0.974037289619446f, 0.159024044871330f, 0.974159121513367f, 0.158660411834717f, + 0.974280655384064f, 0.158296689391136f, 0.974401950836182f, 0.157932877540588f, + 0.974522948265076f, 0.157568961381912f, 0.974643647670746f, 0.157204970717430f, + 0.974764108657837f, 0.156840875744820f, 0.974884271621704f, 0.156476691365242f, + 0.975004136562347f, 0.156112402677536f, 0.975123703479767f, 0.155748039484024f, + 0.975243031978607f, 0.155383571982384f, 0.975362062454224f, 0.155019029974937f, + 0.975480854511261f, 0.154654383659363f, 0.975599288940430f, 0.154289647936821f, + 0.975717484951019f, 0.153924822807312f, 0.975835442543030f, 0.153559908270836f, + 0.975953042507172f, 0.153194904327393f, 0.976070404052734f, 0.152829796075821f, + 0.976187527179718f, 0.152464613318443f, 0.976304292678833f, 0.152099341154099f, + 0.976420819759369f, 0.151733979582787f, 0.976537048816681f, 0.151368513703346f, + 0.976653039455414f, 0.151002973318100f, 0.976768672466278f, 0.150637343525887f, + 0.976884067058563f, 0.150271624326706f, 0.976999223232269f, 0.149905815720558f, + 0.977114021778107f, 0.149539917707443f, 0.977228581905365f, 0.149173930287361f, + 0.977342903614044f, 0.148807853460312f, 0.977456867694855f, 0.148441687226295f, + 0.977570593357086f, 0.148075446486473f, 0.977684020996094f, 0.147709101438522f, + 0.977797150611877f, 0.147342681884766f, 0.977910041809082f, 0.146976172924042f, + 0.978022634983063f, 0.146609574556351f, 0.978134930133820f, 0.146242901682854f, + 0.978246986865997f, 0.145876124501228f, 0.978358685970306f, 0.145509272813797f, + 0.978470146656036f, 0.145142331719399f, 0.978581368923187f, 0.144775316119194f, + 0.978692233562469f, 0.144408211112022f, 0.978802859783173f, 0.144041016697884f, + 0.978913187980652f, 0.143673732876778f, 0.979023277759552f, 0.143306359648705f, + 0.979133009910584f, 0.142938911914825f, 0.979242503643036f, 0.142571389675140f, + 0.979351758956909f, 0.142203763127327f, 0.979460656642914f, 0.141836062073708f, + 0.979569315910339f, 0.141468286514282f, 0.979677677154541f, 0.141100421547890f, + 0.979785740375519f, 0.140732467174530f, 0.979893565177917f, 0.140364438295364f, + 0.980001091957092f, 0.139996320009232f, 0.980108320713043f, 0.139628127217293f, + 0.980215251445770f, 0.139259845018387f, 0.980321943759918f, 0.138891488313675f, + 0.980428338050842f, 0.138523042201996f, 0.980534434318542f, 0.138154521584511f, + 0.980640232563019f, 0.137785911560059f, 0.980745792388916f, 0.137417227029800f, + 0.980851054191589f, 0.137048453092575f, 0.980956017971039f, 0.136679604649544f, + 0.981060683727264f, 0.136310681700706f, 0.981165111064911f, 0.135941669344902f, + 0.981269240379334f, 0.135572582483292f, 0.981373071670532f, 0.135203406214714f, + 0.981476604938507f, 0.134834155440331f, 0.981579899787903f, 0.134464830160141f, + 0.981682896614075f, 0.134095430374146f, 0.981785595417023f, 0.133725941181183f, + 0.981888055801392f, 0.133356377482414f, 0.981990158557892f, 0.132986739277840f, + 0.982092022895813f, 0.132617011666298f, 0.982193589210510f, 0.132247209548950f, + 0.982294917106628f, 0.131877332925797f, 0.982395887374878f, 0.131507381796837f, + 0.982496619224548f, 0.131137356162071f, 0.982597053050995f, 0.130767241120338f, + 0.982697248458862f, 0.130397051572800f, 0.982797086238861f, 0.130026802420616f, + 0.982896685600281f, 0.129656463861465f, 0.982995986938477f, 0.129286035895348f, + 0.983094990253448f, 0.128915548324585f, 0.983193755149841f, 0.128544986248016f, + 0.983292162418365f, 0.128174334764481f, 0.983390331268311f, 0.127803623676300f, + 0.983488261699677f, 0.127432823181152f, 0.983585834503174f, 0.127061963081360f, + 0.983683168888092f, 0.126691013574600f, 0.983780145645142f, 0.126320004463196f, + 0.983876943588257f, 0.125948905944824f, 0.983973383903503f, 0.125577747821808f, + 0.984069526195526f, 0.125206500291824f, 0.984165430068970f, 0.124835193157196f, + 0.984261035919189f, 0.124463804066181f, 0.984356343746185f, 0.124092340469360f, + 0.984451413154602f, 0.123720809817314f, 0.984546124935150f, 0.123349204659462f, + 0.984640598297119f, 0.122977524995804f, 0.984734773635864f, 0.122605770826340f, + 0.984828710556030f, 0.122233949601650f, 0.984922289848328f, 0.121862053871155f, + 0.985015630722046f, 0.121490091085434f, 0.985108673572540f, 0.121118053793907f, + 0.985201418399811f, 0.120745941996574f, 0.985293865203857f, 0.120373763144016f, + 0.985386073589325f, 0.120001509785652f, 0.985477983951569f, 0.119629189372063f, + 0.985569596290588f, 0.119256794452667f, 0.985660910606384f, 0.118884332478046f, + 0.985751926898956f, 0.118511803448200f, 0.985842704772949f, 0.118139199912548f, + 0.985933184623718f, 0.117766529321671f, 0.986023366451263f, 0.117393791675568f, + 0.986113250255585f, 0.117020979523659f, 0.986202836036682f, 0.116648100316525f, + 0.986292183399200f, 0.116275154054165f, 0.986381232738495f, 0.115902140736580f, + 0.986469984054565f, 0.115529052913189f, 0.986558437347412f, 0.115155905485153f, + 0.986646652221680f, 0.114782683551311f, 0.986734509468079f, 0.114409394562244f, + 0.986822128295898f, 0.114036038517952f, 0.986909449100494f, 0.113662622869015f, + 0.986996471881866f, 0.113289132714272f, 0.987083256244659f, 0.112915575504303f, + 0.987169682979584f, 0.112541958689690f, 0.987255871295929f, 0.112168267369270f, + 0.987341761589050f, 0.111794516444206f, 0.987427353858948f, 0.111420698463917f, + 0.987512648105621f, 0.111046813428402f, 0.987597703933716f, 0.110672861337662f, + 0.987682461738586f, 0.110298842191696f, 0.987766921520233f, 0.109924763441086f, + 0.987851083278656f, 0.109550617635250f, 0.987934947013855f, 0.109176412224770f, + 0.988018512725830f, 0.108802139759064f, 0.988101840019226f, 0.108427800238132f, + 0.988184869289398f, 0.108053401112556f, 0.988267600536346f, 0.107678934931755f, + 0.988350033760071f, 0.107304409146309f, 0.988432228565216f, 0.106929816305637f, + 0.988514065742493f, 0.106555156409740f, 0.988595664501190f, 0.106180444359779f, + 0.988676965236664f, 0.105805665254593f, 0.988757967948914f, 0.105430819094181f, + 0.988838672637939f, 0.105055920779705f, 0.988919138908386f, 0.104680955410004f, + 0.988999247550964f, 0.104305922985077f, 0.989079117774963f, 0.103930838406086f, + 0.989158689975739f, 0.103555686771870f, 0.989237964153290f, 0.103180475533009f, + 0.989316940307617f, 0.102805204689503f, 0.989395678043365f, 0.102429874241352f, + 0.989474058151245f, 0.102054484188557f, 0.989552199840546f, 0.101679034531116f, + 0.989630043506622f, 0.101303517818451f, 0.989707589149475f, 0.100927948951721f, + 0.989784896373749f, 0.100552320480347f, 0.989861845970154f, 0.100176624953747f, + 0.989938557147980f, 0.099800877273083f, 0.990014970302582f, 0.099425069987774f, + 0.990091085433960f, 0.099049203097820f, 0.990166902542114f, 0.098673284053802f, + 0.990242421627045f, 0.098297297954559f, 0.990317702293396f, 0.097921259701252f, + 0.990392625331879f, 0.097545161843300f, 0.990467309951782f, 0.097169004380703f, + 0.990541696548462f, 0.096792794764042f, 0.990615785121918f, 0.096416525542736f, + 0.990689575672150f, 0.096040196716785f, 0.990763127803802f, 0.095663815736771f, + 0.990836322307587f, 0.095287375152111f, 0.990909278392792f, 0.094910882413387f, + 0.990981936454773f, 0.094534330070019f, 0.991054296493530f, 0.094157725572586f, + 0.991126358509064f, 0.093781061470509f, 0.991198182106018f, 0.093404345214367f, + 0.991269648075104f, 0.093027576804161f, 0.991340875625610f, 0.092650748789310f, + 0.991411805152893f, 0.092273868620396f, 0.991482377052307f, 0.091896936297417f, + 0.991552770137787f, 0.091519944369793f, 0.991622805595398f, 0.091142900288105f, + 0.991692543029785f, 0.090765804052353f, 0.991762042045593f, 0.090388655662537f, + 0.991831183433533f, 0.090011447668076f, 0.991900086402893f, 0.089634194970131f, + 0.991968691349030f, 0.089256882667542f, 0.992036998271942f, 0.088879525661469f, + 0.992105066776276f, 0.088502109050751f, 0.992172777652740f, 0.088124647736549f, + 0.992240250110626f, 0.087747126817703f, 0.992307364940643f, 0.087369553744793f, + 0.992374241352081f, 0.086991935968399f, 0.992440819740295f, 0.086614266037941f, + 0.992507100105286f, 0.086236543953419f, 0.992573142051697f, 0.085858769714832f, + 0.992638826370239f, 0.085480943322182f, 0.992704212665558f, 0.085103072226048f, + 0.992769360542297f, 0.084725148975849f, 0.992834210395813f, 0.084347173571587f, + 0.992898762226105f, 0.083969146013260f, 0.992963016033173f, 0.083591073751450f, + 0.993026971817017f, 0.083212949335575f, 0.993090689182281f, 0.082834780216217f, + 0.993154048919678f, 0.082456558942795f, 0.993217170238495f, 0.082078292965889f, + 0.993279933929443f, 0.081699974834919f, 0.993342459201813f, 0.081321612000465f, + 0.993404686450958f, 0.080943197011948f, 0.993466615676880f, 0.080564737319946f, + 0.993528306484222f, 0.080186225473881f, 0.993589639663696f, 0.079807676374912f, + 0.993650734424591f, 0.079429075121880f, 0.993711471557617f, 0.079050421714783f, + 0.993771970272064f, 0.078671731054783f, 0.993832170963287f, 0.078292988240719f, + 0.993892073631287f, 0.077914200723171f, 0.993951678276062f, 0.077535368502140f, + 0.994010984897614f, 0.077156484127045f, 0.994070053100586f, 0.076777562499046f, + 0.994128763675690f, 0.076398596167564f, 0.994187235832214f, 0.076019577682018f, + 0.994245409965515f, 0.075640521943569f, 0.994303286075592f, 0.075261414051056f, + 0.994360864162445f, 0.074882268905640f, 0.994418144226074f, 0.074503071606159f, + 0.994475126266479f, 0.074123837053776f, 0.994531810283661f, 0.073744557797909f, + 0.994588255882263f, 0.073365233838558f, 0.994644403457642f, 0.072985872626305f, + 0.994700193405151f, 0.072606459259987f, 0.994755744934082f, 0.072227008640766f, + 0.994810998439789f, 0.071847513318062f, 0.994865953922272f, 0.071467980742455f, + 0.994920611381531f, 0.071088403463364f, 0.994975030422211f, 0.070708781480789f, + 0.995029091835022f, 0.070329122245312f, 0.995082914829254f, 0.069949418306351f, + 0.995136380195618f, 0.069569669663906f, 0.995189607143402f, 0.069189883768559f, + 0.995242536067963f, 0.068810060620308f, 0.995295166969299f, 0.068430192768574f, + 0.995347499847412f, 0.068050287663937f, 0.995399534702301f, 0.067670337855816f, + 0.995451331138611f, 0.067290350794792f, 0.995502769947052f, 0.066910326480865f, + 0.995553970336914f, 0.066530264914036f, 0.995604813098907f, 0.066150158643723f, + 0.995655417442322f, 0.065770015120506f, 0.995705723762512f, 0.065389834344387f, + 0.995755732059479f, 0.065009608864784f, 0.995805442333221f, 0.064629353582859f, + 0.995854854583740f, 0.064249053597450f, 0.995904028415680f, 0.063868723809719f, + 0.995952844619751f, 0.063488349318504f, 0.996001422405243f, 0.063107937574387f, + 0.996049642562866f, 0.062727488577366f, 0.996097624301910f, 0.062347009778023f, + 0.996145308017731f, 0.061966486275196f, 0.996192693710327f, 0.061585929244757f, + 0.996239781379700f, 0.061205338686705f, 0.996286571025848f, 0.060824707150459f, + 0.996333062648773f, 0.060444042086601f, 0.996379256248474f, 0.060063343495131f, + 0.996425211429596f, 0.059682607650757f, 0.996470808982849f, 0.059301838278770f, + 0.996516168117523f, 0.058921031653881f, 0.996561229228973f, 0.058540191501379f, + 0.996605992317200f, 0.058159314095974f, 0.996650457382202f, 0.057778406888247f, + 0.996694624423981f, 0.057397462427616f, 0.996738493442535f, 0.057016488164663f, + 0.996782064437866f, 0.056635476648808f, 0.996825337409973f, 0.056254431605339f, + 0.996868371963501f, 0.055873356759548f, 0.996911048889160f, 0.055492244660854f, + 0.996953487396240f, 0.055111102759838f, 0.996995627880096f, 0.054729927331209f, + 0.997037410736084f, 0.054348722100258f, 0.997078955173492f, 0.053967483341694f, + 0.997120201587677f, 0.053586211055517f, 0.997161149978638f, 0.053204908967018f, + 0.997201859951019f, 0.052823577076197f, 0.997242212295532f, 0.052442211657763f, + 0.997282266616821f, 0.052060816437006f, 0.997322082519531f, 0.051679391413927f, + 0.997361540794373f, 0.051297932863235f, 0.997400760650635f, 0.050916448235512f, + 0.997439682483673f, 0.050534930080175f, 0.997478306293488f, 0.050153385847807f, + 0.997516572475433f, 0.049771808087826f, 0.997554600238800f, 0.049390204250813f, + 0.997592389583588f, 0.049008570611477f, 0.997629821300507f, 0.048626907169819f, + 0.997666954994202f, 0.048245213925838f, 0.997703790664673f, 0.047863494604826f, + 0.997740387916565f, 0.047481749206781f, 0.997776627540588f, 0.047099970281124f, + 0.997812628746033f, 0.046718169003725f, 0.997848331928253f, 0.046336337924004f, + 0.997883677482605f, 0.045954477041960f, 0.997918784618378f, 0.045572593808174f, + 0.997953593730927f, 0.045190680772066f, 0.997988104820251f, 0.044808741658926f, + 0.998022377490997f, 0.044426776468754f, 0.998056292533875f, 0.044044785201550f, + 0.998089909553528f, 0.043662767857313f, 0.998123228549957f, 0.043280724436045f, + 0.998156309127808f, 0.042898654937744f, 0.998189091682434f, 0.042516563087702f, + 0.998221516609192f, 0.042134445160627f, 0.998253703117371f, 0.041752301156521f, + 0.998285591602325f, 0.041370131075382f, 0.998317182064056f, 0.040987938642502f, + 0.998348474502563f, 0.040605723857880f, 0.998379468917847f, 0.040223482996225f, + 0.998410165309906f, 0.039841219782829f, 0.998440563678741f, 0.039458930492401f, + 0.998470664024353f, 0.039076622575521f, 0.998500525951386f, 0.038694288581610f, + 0.998530030250549f, 0.038311932235956f, 0.998559296131134f, 0.037929553538561f, + 0.998588204383850f, 0.037547148764133f, 0.998616874217987f, 0.037164725363255f, + 0.998645246028900f, 0.036782283335924f, 0.998673319816589f, 0.036399815231562f, + 0.998701035976410f, 0.036017324775457f, 0.998728513717651f, 0.035634815692902f, + 0.998755753040314f, 0.035252287983894f, 0.998782634735107f, 0.034869734197855f, + 0.998809218406677f, 0.034487165510654f, 0.998835504055023f, 0.034104570746422f, + 0.998861551284790f, 0.033721961081028f, 0.998887240886688f, 0.033339329063892f, + 0.998912692070007f, 0.032956674695015f, 0.998937785625458f, 0.032574005424976f, + 0.998962640762329f, 0.032191313803196f, 0.998987197875977f, 0.031808607280254f, + 0.999011456966400f, 0.031425878405571f, 0.999035418033600f, 0.031043132767081f, + 0.999059081077576f, 0.030660368502140f, 0.999082446098328f, 0.030277585610747f, + 0.999105513095856f, 0.029894785955548f, 0.999128282070160f, 0.029511967673898f, + 0.999150753021240f, 0.029129132628441f, 0.999172985553741f, 0.028746278956532f, + 0.999194860458374f, 0.028363410383463f, 0.999216496944427f, 0.027980525046587f, + 0.999237775802612f, 0.027597622945905f, 0.999258816242218f, 0.027214704081416f, + 0.999279558658600f, 0.026831768453121f, 0.999299943447113f, 0.026448817923665f, + 0.999320089817047f, 0.026065852493048f, 0.999339938163757f, 0.025682870298624f, + 0.999359488487244f, 0.025299875065684f, 0.999378740787506f, 0.024916863068938f, + 0.999397754669189f, 0.024533838033676f, 0.999416410923004f, 0.024150796234608f, + 0.999434769153595f, 0.023767741397023f, 0.999452829360962f, 0.023384673520923f, + 0.999470651149750f, 0.023001590743661f, 0.999488115310669f, 0.022618494927883f, + 0.999505341053009f, 0.022235386073589f, 0.999522268772125f, 0.021852264180779f, + 0.999538838863373f, 0.021469129249454f, 0.999555170536041f, 0.021085981279612f, + 0.999571204185486f, 0.020702820271254f, 0.999586939811707f, 0.020319648087025f, + 0.999602377414703f, 0.019936462864280f, 0.999617516994476f, 0.019553268328309f, + 0.999632358551025f, 0.019170060753822f, 0.999646902084351f, 0.018786842003465f, + 0.999661207199097f, 0.018403612077236f, 0.999675154685974f, 0.018020370975137f, + 0.999688863754272f, 0.017637118697166f, 0.999702215194702f, 0.017253857105970f, + 0.999715328216553f, 0.016870586201549f, 0.999728083610535f, 0.016487304121256f, + 0.999740600585938f, 0.016104012727737f, 0.999752819538116f, 0.015720712020993f, + 0.999764680862427f, 0.015337402001023f, 0.999776303768158f, 0.014954082667828f, + 0.999787628650665f, 0.014570754021406f, 0.999798655509949f, 0.014187417924404f, + 0.999809384346008f, 0.013804072514176f, 0.999819874763489f, 0.013420719653368f, + 0.999830007553101f, 0.013037359341979f, 0.999839842319489f, 0.012653990648687f, + 0.999849438667297f, 0.012270614504814f, 0.999858677387238f, 0.011887230910361f, + 0.999867618083954f, 0.011503840796649f, 0.999876320362091f, 0.011120444163680f, + 0.999884724617004f, 0.010737040080130f, 0.999892771244049f, 0.010353630408645f, + 0.999900579452515f, 0.009970214217901f, 0.999908089637756f, 0.009586792439222f, + 0.999915301799774f, 0.009203365072608f, 0.999922215938568f, 0.008819932118058f, + 0.999928832054138f, 0.008436493575573f, 0.999935150146484f, 0.008053051307797f, + 0.999941170215607f, 0.007669602986425f, 0.999946892261505f, 0.007286150939763f, + 0.999952375888824f, 0.006902694236487f, 0.999957501888275f, 0.006519233807921f, + 0.999962329864502f, 0.006135769188404f, 0.999966919422150f, 0.005752300843596f, + 0.999971151351929f, 0.005368829704821f, 0.999975144863129f, 0.004985354840755f, + 0.999978840351105f, 0.004601877182722f, 0.999982178211212f, 0.004218397196382f, + 0.999985277652740f, 0.003834914416075f, 0.999988079071045f, 0.003451429307461f, + 0.999990582466125f, 0.003067942336202f, 0.999992787837982f, 0.002684453502297f, + 0.999994695186615f, 0.002300963038579f, 0.999996304512024f, 0.001917471294291f, + 0.999997675418854f, 0.001533978385851f, 0.999998688697815f, 0.001150484546088f, + 0.999999403953552f, 0.000766990066040f, 0.999999880790710f, 0.000383495149435f, + 1.000000000000000f, 0.000000000000023f, 0.999999880790710f, -0.000383495149435f, + 0.999999403953552f, -0.000766990066040f, 0.999998688697815f, -0.001150484546088f, + 0.999997675418854f, -0.001533978385851f, 0.999996304512024f, -0.001917471294291f, + 0.999994695186615f, -0.002300963038579f, 0.999992787837982f, -0.002684453502297f, + 0.999990582466125f, -0.003067942336202f, 0.999988079071045f, -0.003451429307461f, + 0.999985277652740f, -0.003834914416075f, 0.999982178211212f, -0.004218397196382f, + 0.999978840351105f, -0.004601877182722f, 0.999975144863129f, -0.004985354840755f, + 0.999971151351929f, -0.005368829704821f, 0.999966919422150f, -0.005752300843596f, + 0.999962329864502f, -0.006135769188404f, 0.999957501888275f, -0.006519233807921f, + 0.999952375888824f, -0.006902694236487f, 0.999946892261505f, -0.007286150939763f, + 0.999941170215607f, -0.007669602986425f, 0.999935150146484f, -0.008053051307797f, + 0.999928832054138f, -0.008436493575573f, 0.999922215938568f, -0.008819932118058f, + 0.999915301799774f, -0.009203365072608f, 0.999908089637756f, -0.009586792439222f, + 0.999900579452515f, -0.009970214217901f, 0.999892771244049f, -0.010353630408645f, + 0.999884724617004f, -0.010737040080130f, 0.999876320362091f, -0.011120444163680f, + 0.999867618083954f, -0.011503840796649f, 0.999858677387238f, -0.011887230910361f, + 0.999849438667297f, -0.012270614504814f, 0.999839842319489f, -0.012653990648687f, + 0.999830007553101f, -0.013037359341979f, 0.999819874763489f, -0.013420719653368f, + 0.999809384346008f, -0.013804072514176f, 0.999798655509949f, -0.014187417924404f, + 0.999787628650665f, -0.014570754021406f, 0.999776303768158f, -0.014954082667828f, + 0.999764680862427f, -0.015337402001023f, 0.999752819538116f, -0.015720712020993f, + 0.999740600585938f, -0.016104012727737f, 0.999728083610535f, -0.016487304121256f, + 0.999715328216553f, -0.016870586201549f, 0.999702215194702f, -0.017253857105970f, + 0.999688863754272f, -0.017637118697166f, 0.999675154685974f, -0.018020370975137f, + 0.999661207199097f, -0.018403612077236f, 0.999646902084351f, -0.018786842003465f, + 0.999632358551025f, -0.019170060753822f, 0.999617516994476f, -0.019553268328309f, + 0.999602377414703f, -0.019936462864280f, 0.999586939811707f, -0.020319648087025f, + 0.999571204185486f, -0.020702820271254f, 0.999555170536041f, -0.021085981279612f, + 0.999538838863373f, -0.021469129249454f, 0.999522268772125f, -0.021852264180779f, + 0.999505341053009f, -0.022235386073589f, 0.999488115310669f, -0.022618494927883f, + 0.999470651149750f, -0.023001590743661f, 0.999452829360962f, -0.023384673520923f, + 0.999434769153595f, -0.023767741397023f, 0.999416410923004f, -0.024150796234608f, + 0.999397754669189f, -0.024533838033676f, 0.999378740787506f, -0.024916863068938f, + 0.999359488487244f, -0.025299875065684f, 0.999339938163757f, -0.025682870298624f, + 0.999320089817047f, -0.026065852493048f, 0.999299943447113f, -0.026448817923665f, + 0.999279558658600f, -0.026831768453121f, 0.999258816242218f, -0.027214704081416f, + 0.999237775802612f, -0.027597622945905f, 0.999216496944427f, -0.027980525046587f, + 0.999194860458374f, -0.028363410383463f, 0.999172985553741f, -0.028746278956532f, + 0.999150753021240f, -0.029129132628441f, 0.999128282070160f, -0.029511967673898f, + 0.999105513095856f, -0.029894785955548f, 0.999082446098328f, -0.030277585610747f, + 0.999059081077576f, -0.030660368502140f, 0.999035418033600f, -0.031043132767081f, + 0.999011456966400f, -0.031425878405571f, 0.998987197875977f, -0.031808607280254f, + 0.998962640762329f, -0.032191313803196f, 0.998937785625458f, -0.032574005424976f, + 0.998912692070007f, -0.032956674695015f, 0.998887240886688f, -0.033339329063892f, + 0.998861551284790f, -0.033721961081028f, 0.998835504055023f, -0.034104570746422f, + 0.998809218406677f, -0.034487165510654f, 0.998782634735107f, -0.034869734197855f, + 0.998755753040314f, -0.035252287983894f, 0.998728513717651f, -0.035634815692902f, + 0.998701035976410f, -0.036017324775457f, 0.998673319816589f, -0.036399815231562f, + 0.998645246028900f, -0.036782283335924f, 0.998616874217987f, -0.037164725363255f, + 0.998588204383850f, -0.037547148764133f, 0.998559296131134f, -0.037929553538561f, + 0.998530030250549f, -0.038311932235956f, 0.998500525951386f, -0.038694288581610f, + 0.998470664024353f, -0.039076622575521f, 0.998440563678741f, -0.039458930492401f, + 0.998410165309906f, -0.039841219782829f, 0.998379468917847f, -0.040223482996225f, + 0.998348474502563f, -0.040605723857880f, 0.998317182064056f, -0.040987938642502f, + 0.998285591602325f, -0.041370131075382f, 0.998253703117371f, -0.041752301156521f, + 0.998221516609192f, -0.042134445160627f, 0.998189091682434f, -0.042516563087702f, + 0.998156309127808f, -0.042898654937744f, 0.998123228549957f, -0.043280724436045f, + 0.998089909553528f, -0.043662767857313f, 0.998056292533875f, -0.044044785201550f, + 0.998022377490997f, -0.044426776468754f, 0.997988104820251f, -0.044808741658926f, + 0.997953593730927f, -0.045190680772066f, 0.997918784618378f, -0.045572593808174f, + 0.997883677482605f, -0.045954477041960f, 0.997848331928253f, -0.046336337924004f, + 0.997812628746033f, -0.046718169003725f, 0.997776627540588f, -0.047099970281124f, + 0.997740387916565f, -0.047481749206781f, 0.997703790664673f, -0.047863494604826f, + 0.997666954994202f, -0.048245213925838f, 0.997629821300507f, -0.048626907169819f, + 0.997592389583588f, -0.049008570611477f, 0.997554600238800f, -0.049390204250813f, + 0.997516572475433f, -0.049771808087826f, 0.997478306293488f, -0.050153385847807f, + 0.997439682483673f, -0.050534930080175f, 0.997400760650635f, -0.050916448235512f, + 0.997361540794373f, -0.051297932863235f, 0.997322082519531f, -0.051679391413927f, + 0.997282266616821f, -0.052060816437006f, 0.997242212295532f, -0.052442211657763f, + 0.997201859951019f, -0.052823577076197f, 0.997161149978638f, -0.053204908967018f, + 0.997120201587677f, -0.053586211055517f, 0.997078955173492f, -0.053967483341694f, + 0.997037410736084f, -0.054348722100258f, 0.996995627880096f, -0.054729927331209f, + 0.996953487396240f, -0.055111102759838f, 0.996911048889160f, -0.055492244660854f, + 0.996868371963501f, -0.055873356759548f, 0.996825337409973f, -0.056254431605339f, + 0.996782064437866f, -0.056635476648808f, 0.996738493442535f, -0.057016488164663f, + 0.996694624423981f, -0.057397462427616f, 0.996650457382202f, -0.057778406888247f, + 0.996605992317200f, -0.058159314095974f, 0.996561229228973f, -0.058540191501379f, + 0.996516168117523f, -0.058921031653881f, 0.996470808982849f, -0.059301838278770f, + 0.996425211429596f, -0.059682607650757f, 0.996379256248474f, -0.060063343495131f, + 0.996333062648773f, -0.060444042086601f, 0.996286571025848f, -0.060824707150459f, + 0.996239781379700f, -0.061205338686705f, 0.996192693710327f, -0.061585929244757f, + 0.996145308017731f, -0.061966486275196f, 0.996097624301910f, -0.062347009778023f, + 0.996049642562866f, -0.062727488577366f, 0.996001422405243f, -0.063107937574387f, + 0.995952844619751f, -0.063488349318504f, 0.995904028415680f, -0.063868723809719f, + 0.995854854583740f, -0.064249053597450f, 0.995805442333221f, -0.064629353582859f, + 0.995755732059479f, -0.065009608864784f, 0.995705723762512f, -0.065389834344387f, + 0.995655417442322f, -0.065770015120506f, 0.995604813098907f, -0.066150158643723f, + 0.995553970336914f, -0.066530264914036f, 0.995502769947052f, -0.066910326480865f, + 0.995451331138611f, -0.067290350794792f, 0.995399534702301f, -0.067670337855816f, + 0.995347499847412f, -0.068050287663937f, 0.995295166969299f, -0.068430192768574f, + 0.995242536067963f, -0.068810060620308f, 0.995189607143402f, -0.069189883768559f, + 0.995136380195618f, -0.069569669663906f, 0.995082914829254f, -0.069949418306351f, + 0.995029091835022f, -0.070329122245312f, 0.994975030422211f, -0.070708781480789f, + 0.994920611381531f, -0.071088403463364f, 0.994865953922272f, -0.071467980742455f, + 0.994810998439789f, -0.071847513318062f, 0.994755744934082f, -0.072227008640766f, + 0.994700193405151f, -0.072606459259987f, 0.994644403457642f, -0.072985872626305f, + 0.994588255882263f, -0.073365233838558f, 0.994531810283661f, -0.073744557797909f, + 0.994475126266479f, -0.074123837053776f, 0.994418144226074f, -0.074503071606159f, + 0.994360864162445f, -0.074882268905640f, 0.994303286075592f, -0.075261414051056f, + 0.994245409965515f, -0.075640521943569f, 0.994187235832214f, -0.076019577682018f, + 0.994128763675690f, -0.076398596167564f, 0.994070053100586f, -0.076777562499046f, + 0.994010984897614f, -0.077156484127045f, 0.993951678276062f, -0.077535368502140f, + 0.993892073631287f, -0.077914200723171f, 0.993832170963287f, -0.078292988240719f, + 0.993771970272064f, -0.078671731054783f, 0.993711471557617f, -0.079050421714783f, + 0.993650734424591f, -0.079429075121880f, 0.993589639663696f, -0.079807676374912f, + 0.993528306484222f, -0.080186225473881f, 0.993466615676880f, -0.080564737319946f, + 0.993404686450958f, -0.080943197011948f, 0.993342459201813f, -0.081321612000465f, + 0.993279933929443f, -0.081699974834919f, 0.993217170238495f, -0.082078292965889f, + 0.993154048919678f, -0.082456558942795f, 0.993090689182281f, -0.082834780216217f, + 0.993026971817017f, -0.083212949335575f, 0.992963016033173f, -0.083591073751450f, + 0.992898762226105f, -0.083969146013260f, 0.992834210395813f, -0.084347173571587f, + 0.992769360542297f, -0.084725148975849f, 0.992704212665558f, -0.085103072226048f, + 0.992638826370239f, -0.085480943322182f, 0.992573142051697f, -0.085858769714832f, + 0.992507100105286f, -0.086236543953419f, 0.992440819740295f, -0.086614266037941f, + 0.992374241352081f, -0.086991935968399f, 0.992307364940643f, -0.087369553744793f, + 0.992240250110626f, -0.087747126817703f, 0.992172777652740f, -0.088124647736549f, + 0.992105066776276f, -0.088502109050751f, 0.992036998271942f, -0.088879525661469f, + 0.991968691349030f, -0.089256882667542f, 0.991900086402893f, -0.089634194970131f, + 0.991831183433533f, -0.090011447668076f, 0.991762042045593f, -0.090388655662537f, + 0.991692543029785f, -0.090765804052353f, 0.991622805595398f, -0.091142900288105f, + 0.991552770137787f, -0.091519944369793f, 0.991482377052307f, -0.091896936297417f, + 0.991411805152893f, -0.092273868620396f, 0.991340875625610f, -0.092650748789310f, + 0.991269648075104f, -0.093027576804161f, 0.991198182106018f, -0.093404345214367f, + 0.991126358509064f, -0.093781061470509f, 0.991054296493530f, -0.094157725572586f, + 0.990981936454773f, -0.094534330070019f, 0.990909278392792f, -0.094910882413387f, + 0.990836322307587f, -0.095287375152111f, 0.990763127803802f, -0.095663815736771f, + 0.990689575672150f, -0.096040196716785f, 0.990615785121918f, -0.096416525542736f, + 0.990541696548462f, -0.096792794764042f, 0.990467309951782f, -0.097169004380703f, + 0.990392625331879f, -0.097545161843300f, 0.990317702293396f, -0.097921259701252f, + 0.990242421627045f, -0.098297297954559f, 0.990166902542114f, -0.098673284053802f, + 0.990091085433960f, -0.099049203097820f, 0.990014970302582f, -0.099425069987774f, + 0.989938557147980f, -0.099800877273083f, 0.989861845970154f, -0.100176624953747f, + 0.989784896373749f, -0.100552320480347f, 0.989707589149475f, -0.100927948951721f, + 0.989630043506622f, -0.101303517818451f, 0.989552199840546f, -0.101679034531116f, + 0.989474058151245f, -0.102054484188557f, 0.989395678043365f, -0.102429874241352f, + 0.989316940307617f, -0.102805204689503f, 0.989237964153290f, -0.103180475533009f, + 0.989158689975739f, -0.103555686771870f, 0.989079117774963f, -0.103930838406086f, + 0.988999247550964f, -0.104305922985077f, 0.988919138908386f, -0.104680955410004f, + 0.988838672637939f, -0.105055920779705f, 0.988757967948914f, -0.105430819094181f, + 0.988676965236664f, -0.105805665254593f, 0.988595664501190f, -0.106180444359779f, + 0.988514065742493f, -0.106555156409740f, 0.988432228565216f, -0.106929816305637f, + 0.988350033760071f, -0.107304409146309f, 0.988267600536346f, -0.107678934931755f, + 0.988184869289398f, -0.108053401112556f, 0.988101840019226f, -0.108427800238132f, + 0.988018512725830f, -0.108802139759064f, 0.987934947013855f, -0.109176412224770f, + 0.987851083278656f, -0.109550617635250f, 0.987766921520233f, -0.109924763441086f, + 0.987682461738586f, -0.110298842191696f, 0.987597703933716f, -0.110672861337662f, + 0.987512648105621f, -0.111046813428402f, 0.987427353858948f, -0.111420698463917f, + 0.987341761589050f, -0.111794516444206f, 0.987255871295929f, -0.112168267369270f, + 0.987169682979584f, -0.112541958689690f, 0.987083256244659f, -0.112915575504303f, + 0.986996471881866f, -0.113289132714272f, 0.986909449100494f, -0.113662622869015f, + 0.986822128295898f, -0.114036038517952f, 0.986734509468079f, -0.114409394562244f, + 0.986646652221680f, -0.114782683551311f, 0.986558437347412f, -0.115155905485153f, + 0.986469984054565f, -0.115529052913189f, 0.986381232738495f, -0.115902140736580f, + 0.986292183399200f, -0.116275154054165f, 0.986202836036682f, -0.116648100316525f, + 0.986113250255585f, -0.117020979523659f, 0.986023366451263f, -0.117393791675568f, + 0.985933184623718f, -0.117766529321671f, 0.985842704772949f, -0.118139199912548f, + 0.985751926898956f, -0.118511803448200f, 0.985660910606384f, -0.118884332478046f, + 0.985569596290588f, -0.119256794452667f, 0.985477983951569f, -0.119629189372063f, + 0.985386073589325f, -0.120001509785652f, 0.985293865203857f, -0.120373763144016f, + 0.985201418399811f, -0.120745941996574f, 0.985108673572540f, -0.121118053793907f, + 0.985015630722046f, -0.121490091085434f, 0.984922289848328f, -0.121862053871155f, + 0.984828710556030f, -0.122233949601650f, 0.984734773635864f, -0.122605770826340f, + 0.984640598297119f, -0.122977524995804f, 0.984546124935150f, -0.123349204659462f, + 0.984451413154602f, -0.123720809817314f, 0.984356343746185f, -0.124092340469360f, + 0.984261035919189f, -0.124463804066181f, 0.984165430068970f, -0.124835193157196f, + 0.984069526195526f, -0.125206500291824f, 0.983973383903503f, -0.125577747821808f, + 0.983876943588257f, -0.125948905944824f, 0.983780145645142f, -0.126320004463196f, + 0.983683168888092f, -0.126691013574600f, 0.983585834503174f, -0.127061963081360f, + 0.983488261699677f, -0.127432823181152f, 0.983390331268311f, -0.127803623676300f, + 0.983292162418365f, -0.128174334764481f, 0.983193755149841f, -0.128544986248016f, + 0.983094990253448f, -0.128915548324585f, 0.982995986938477f, -0.129286035895348f, + 0.982896685600281f, -0.129656463861465f, 0.982797086238861f, -0.130026802420616f, + 0.982697248458862f, -0.130397051572800f, 0.982597053050995f, -0.130767241120338f, + 0.982496619224548f, -0.131137356162071f, 0.982395887374878f, -0.131507381796837f, + 0.982294917106628f, -0.131877332925797f, 0.982193589210510f, -0.132247209548950f, + 0.982092022895813f, -0.132617011666298f, 0.981990158557892f, -0.132986739277840f, + 0.981888055801392f, -0.133356377482414f, 0.981785595417023f, -0.133725941181183f, + 0.981682896614075f, -0.134095430374146f, 0.981579899787903f, -0.134464830160141f, + 0.981476604938507f, -0.134834155440331f, 0.981373071670532f, -0.135203406214714f, + 0.981269240379334f, -0.135572582483292f, 0.981165111064911f, -0.135941669344902f, + 0.981060683727264f, -0.136310681700706f, 0.980956017971039f, -0.136679604649544f, + 0.980851054191589f, -0.137048453092575f, 0.980745792388916f, -0.137417227029800f, + 0.980640232563019f, -0.137785911560059f, 0.980534434318542f, -0.138154521584511f, + 0.980428338050842f, -0.138523042201996f, 0.980321943759918f, -0.138891488313675f, + 0.980215251445770f, -0.139259845018387f, 0.980108320713043f, -0.139628127217293f, + 0.980001091957092f, -0.139996320009232f, 0.979893565177917f, -0.140364438295364f, + 0.979785740375519f, -0.140732467174530f, 0.979677677154541f, -0.141100421547890f, + 0.979569315910339f, -0.141468286514282f, 0.979460656642914f, -0.141836062073708f, + 0.979351758956909f, -0.142203763127327f, 0.979242503643036f, -0.142571389675140f, + 0.979133009910584f, -0.142938911914825f, 0.979023277759552f, -0.143306359648705f, + 0.978913187980652f, -0.143673732876778f, 0.978802859783173f, -0.144041016697884f, + 0.978692233562469f, -0.144408211112022f, 0.978581368923187f, -0.144775316119194f, + 0.978470146656036f, -0.145142331719399f, 0.978358685970306f, -0.145509272813797f, + 0.978246986865997f, -0.145876124501228f, 0.978134930133820f, -0.146242901682854f, + 0.978022634983063f, -0.146609574556351f, 0.977910041809082f, -0.146976172924042f, + 0.977797150611877f, -0.147342681884766f, 0.977684020996094f, -0.147709101438522f, + 0.977570593357086f, -0.148075446486473f, 0.977456867694855f, -0.148441687226295f, + 0.977342903614044f, -0.148807853460312f, 0.977228581905365f, -0.149173930287361f, + 0.977114021778107f, -0.149539917707443f, 0.976999223232269f, -0.149905815720558f, + 0.976884067058563f, -0.150271624326706f, 0.976768672466278f, -0.150637343525887f, + 0.976653039455414f, -0.151002973318100f, 0.976537048816681f, -0.151368513703346f, + 0.976420819759369f, -0.151733979582787f, 0.976304292678833f, -0.152099341154099f, + 0.976187527179718f, -0.152464613318443f, 0.976070404052734f, -0.152829796075821f, + 0.975953042507172f, -0.153194904327393f, 0.975835442543030f, -0.153559908270836f, + 0.975717484951019f, -0.153924822807312f, 0.975599288940430f, -0.154289647936821f, + 0.975480854511261f, -0.154654383659363f, 0.975362062454224f, -0.155019029974937f, + 0.975243031978607f, -0.155383571982384f, 0.975123703479767f, -0.155748039484024f, + 0.975004136562347f, -0.156112402677536f, 0.974884271621704f, -0.156476691365242f, + 0.974764108657837f, -0.156840875744820f, 0.974643647670746f, -0.157204970717430f, + 0.974522948265076f, -0.157568961381912f, 0.974401950836182f, -0.157932877540588f, + 0.974280655384064f, -0.158296689391136f, 0.974159121513367f, -0.158660411834717f, + 0.974037289619446f, -0.159024044871330f, 0.973915159702301f, -0.159387573599815f, + 0.973792791366577f, -0.159751012921333f, 0.973670125007629f, -0.160114362835884f, + 0.973547160625458f, -0.160477623343468f, 0.973423957824707f, -0.160840779542923f, + 0.973300457000732f, -0.161203846335411f, 0.973176658153534f, -0.161566808819771f, + 0.973052620887756f, -0.161929681897163f, 0.972928285598755f, -0.162292465567589f, + 0.972803652286530f, -0.162655144929886f, 0.972678780555725f, -0.163017734885216f, + 0.972553610801697f, -0.163380220532417f, 0.972428143024445f, -0.163742616772652f, + 0.972302436828613f, -0.164104923605919f, 0.972176432609558f, -0.164467126131058f, + 0.972050130367279f, -0.164829224348068f, 0.971923589706421f, -0.165191248059273f, + 0.971796751022339f, -0.165553152561188f, 0.971669614315033f, -0.165914967656136f, + 0.971542239189148f, -0.166276678442955f, 0.971414566040039f, -0.166638299822807f, + 0.971286594867706f, -0.166999831795692f, 0.971158385276794f, -0.167361244559288f, + 0.971029877662659f, -0.167722567915916f, 0.970901072025299f, -0.168083801865578f, + 0.970772027969360f, -0.168444931507111f, 0.970642685890198f, -0.168805956840515f, + 0.970513105392456f, -0.169166877865791f, 0.970383226871490f, -0.169527709484100f, + 0.970253050327301f, -0.169888436794281f, 0.970122575759888f, -0.170249074697495f, + 0.969991862773895f, -0.170609608292580f, 0.969860911369324f, -0.170970037579536f, + 0.969729602336884f, -0.171330362558365f, 0.969598054885864f, -0.171690583229065f, + 0.969466269016266f, -0.172050714492798f, 0.969334125518799f, -0.172410741448402f, + 0.969201743602753f, -0.172770664095879f, 0.969069123268127f, -0.173130482435226f, + 0.968936204910278f, -0.173490211367607f, 0.968802988529205f, -0.173849821090698f, + 0.968669533729553f, -0.174209341406822f, 0.968535780906677f, -0.174568757414818f, + 0.968401730060577f, -0.174928069114685f, 0.968267440795898f, -0.175287276506424f, + 0.968132853507996f, -0.175646379590034f, 0.967997968196869f, -0.176005378365517f, + 0.967862844467163f, -0.176364272832870f, 0.967727422714233f, -0.176723077893257f, + 0.967591762542725f, -0.177081763744354f, 0.967455804347992f, -0.177440345287323f, + 0.967319548130035f, -0.177798837423325f, 0.967183053493500f, -0.178157210350037f, + 0.967046260833740f, -0.178515478968620f, 0.966909229755402f, -0.178873643279076f, + 0.966771900653839f, -0.179231703281403f, 0.966634273529053f, -0.179589673876762f, + 0.966496407985687f, -0.179947525262833f, 0.966358244419098f, -0.180305257439613f, + 0.966219842433929f, -0.180662900209427f, 0.966081082820892f, -0.181020438671112f, + 0.965942144393921f, -0.181377857923508f, 0.965802907943726f, -0.181735187768936f, + 0.965663373470306f, -0.182092398405075f, 0.965523540973663f, -0.182449504733086f, + 0.965383470058441f, -0.182806491851807f, 0.965243160724640f, -0.183163389563560f, + 0.965102493762970f, -0.183520168066025f, 0.964961588382721f, -0.183876842260361f, + 0.964820444583893f, -0.184233412146568f, 0.964679002761841f, -0.184589877724648f, + 0.964537262916565f, -0.184946224093437f, 0.964395284652710f, -0.185302466154099f, + 0.964253067970276f, -0.185658603906631f, 0.964110493659973f, -0.186014622449875f, + 0.963967680931091f, -0.186370536684990f, 0.963824629783630f, -0.186726331710815f, + 0.963681280612946f, -0.187082037329674f, 0.963537633419037f, -0.187437608838081f, + 0.963393747806549f, -0.187793090939522f, 0.963249564170837f, -0.188148453831673f, + 0.963105142116547f, -0.188503712415695f, 0.962960422039032f, -0.188858851790428f, + 0.962815403938293f, -0.189213871955872f, 0.962670147418976f, -0.189568802714348f, + 0.962524592876434f, -0.189923599362373f, 0.962378799915314f, -0.190278306603432f, + 0.962232708930969f, -0.190632879734039f, 0.962086379528046f, -0.190987363457680f, + 0.961939752101898f, -0.191341713070869f, 0.961792886257172f, -0.191695958375931f, + 0.961645722389221f, -0.192050099372864f, 0.961498260498047f, -0.192404121160507f, + 0.961350560188293f, -0.192758023738861f, 0.961202561855316f, -0.193111822009087f, + 0.961054325103760f, -0.193465501070023f, 0.960905790328979f, -0.193819075822830f, + 0.960757017135620f, -0.194172516465187f, 0.960607945919037f, -0.194525867700577f, + 0.960458636283875f, -0.194879084825516f, 0.960309028625488f, -0.195232197642326f, + 0.960159122943878f, -0.195585191249847f, 0.960008978843689f, -0.195938065648079f, + 0.959858596324921f, -0.196290835738182f, 0.959707856178284f, -0.196643486618996f, + 0.959556937217712f, -0.196996018290520f, 0.959405720233917f, -0.197348430752754f, + 0.959254205226898f, -0.197700738906860f, 0.959102451801300f, -0.198052927851677f, + 0.958950400352478f, -0.198404997587204f, 0.958798050880432f, -0.198756948113441f, + 0.958645522594452f, -0.199108779430389f, 0.958492636680603f, -0.199460506439209f, + 0.958339512348175f, -0.199812099337578f, 0.958186149597168f, -0.200163587927818f, + 0.958032488822937f, -0.200514942407608f, 0.957878530025482f, -0.200866192579269f, + 0.957724332809448f, -0.201217323541641f, 0.957569897174835f, -0.201568335294724f, + 0.957415163516998f, -0.201919227838516f, 0.957260131835938f, -0.202270001173019f, + 0.957104861736298f, -0.202620655298233f, 0.956949353218079f, -0.202971190214157f, + 0.956793546676636f, -0.203321605920792f, 0.956637442111969f, -0.203671902418137f, + 0.956481099128723f, -0.204022079706192f, 0.956324458122253f, -0.204372137784958f, + 0.956167578697205f, -0.204722076654434f, 0.956010460853577f, -0.205071896314621f, + 0.955853044986725f, -0.205421581864357f, 0.955695331096649f, -0.205771163105965f, + 0.955537378787994f, -0.206120610237122f, 0.955379128456116f, -0.206469938158989f, + 0.955220639705658f, -0.206819161772728f, 0.955061912536621f, -0.207168251276016f, + 0.954902827739716f, -0.207517206668854f, 0.954743564128876f, -0.207866057753563f, + 0.954584002494812f, -0.208214774727821f, 0.954424142837524f, -0.208563387393951f, + 0.954264044761658f, -0.208911851048470f, 0.954103708267212f, -0.209260210394859f, + 0.953943073749542f, -0.209608450531960f, 0.953782141208649f, -0.209956556558609f, + 0.953620970249176f, -0.210304543375969f, 0.953459560871124f, -0.210652396082878f, + 0.953297853469849f, -0.211000129580498f, 0.953135907649994f, -0.211347743868828f, + 0.952973663806915f, -0.211695238947868f, 0.952811121940613f, -0.212042599916458f, + 0.952648401260376f, -0.212389841675758f, 0.952485322952271f, -0.212736949324608f, + 0.952322065830231f, -0.213083937764168f, 0.952158451080322f, -0.213430806994438f, + 0.951994657516479f, -0.213777542114258f, 0.951830565929413f, -0.214124158024788f, + 0.951666176319122f, -0.214470639824867f, 0.951501548290253f, -0.214817002415657f, + 0.951336681842804f, -0.215163245797157f, 0.951171517372131f, -0.215509355068207f, + 0.951006054878235f, -0.215855330228806f, 0.950840353965759f, -0.216201186180115f, + 0.950674414634705f, -0.216546908020973f, 0.950508177280426f, -0.216892510652542f, + 0.950341701507568f, -0.217237979173660f, 0.950174987316132f, -0.217583328485489f, + 0.950007975101471f, -0.217928543686867f, 0.949840664863586f, -0.218273624777794f, + 0.949673116207123f, -0.218618586659431f, 0.949505329132080f, -0.218963414430618f, + 0.949337244033813f, -0.219308122992516f, 0.949168920516968f, -0.219652697443962f, + 0.949000298976898f, -0.219997137784958f, 0.948831439018250f, -0.220341444015503f, + 0.948662281036377f, -0.220685631036758f, 0.948492884635925f, -0.221029683947563f, + 0.948323249816895f, -0.221373617649078f, 0.948153316974640f, -0.221717402338982f, + 0.947983145713806f, -0.222061067819595f, 0.947812676429749f, -0.222404599189758f, + 0.947641968727112f, -0.222748011350632f, 0.947470963001251f, -0.223091274499893f, + 0.947299718856812f, -0.223434418439865f, 0.947128236293793f, -0.223777428269386f, + 0.946956455707550f, -0.224120303988457f, 0.946784436702728f, -0.224463045597076f, + 0.946612179279327f, -0.224805667996407f, 0.946439623832703f, -0.225148141384125f, + 0.946266770362854f, -0.225490495562553f, 0.946093678474426f, -0.225832715630531f, + 0.945920348167419f, -0.226174786686897f, 0.945746779441834f, -0.226516738533974f, + 0.945572853088379f, -0.226858556270599f, 0.945398747920990f, -0.227200239896774f, + 0.945224344730377f, -0.227541789412498f, 0.945049703121185f, -0.227883204817772f, + 0.944874763488770f, -0.228224486112595f, 0.944699645042419f, -0.228565633296967f, + 0.944524168968201f, -0.228906646370888f, 0.944348454475403f, -0.229247525334358f, + 0.944172501564026f, -0.229588270187378f, 0.943996310234070f, -0.229928880929947f, + 0.943819820880890f, -0.230269357562065f, 0.943643093109131f, -0.230609700083733f, + 0.943466067314148f, -0.230949893593788f, 0.943288803100586f, -0.231289967894554f, + 0.943111240863800f, -0.231629893183708f, 0.942933499813080f, -0.231969684362412f, + 0.942755401134491f, -0.232309341430664f, 0.942577123641968f, -0.232648864388466f, + 0.942398548126221f, -0.232988253235817f, 0.942219734191895f, -0.233327493071556f, + 0.942040622234344f, -0.233666598796844f, 0.941861271858215f, -0.234005570411682f, + 0.941681683063507f, -0.234344407916069f, 0.941501796245575f, -0.234683111310005f, + 0.941321671009064f, -0.235021665692329f, 0.941141307353973f, -0.235360085964203f, + 0.940960645675659f, -0.235698372125626f, 0.940779745578766f, -0.236036509275436f, + 0.940598547458649f, -0.236374512314796f, 0.940417110919952f, -0.236712381243706f, + 0.940235435962677f, -0.237050101161003f, 0.940053522586823f, -0.237387686967850f, + 0.939871311187744f, -0.237725138664246f, 0.939688861370087f, -0.238062441349030f, + 0.939506113529205f, -0.238399609923363f, 0.939323127269745f, -0.238736644387245f, + 0.939139902591705f, -0.239073529839516f, 0.938956379890442f, -0.239410281181335f, + 0.938772618770599f, -0.239746883511543f, 0.938588619232178f, -0.240083336830139f, + 0.938404381275177f, -0.240419670939446f, 0.938219845294952f, -0.240755841135979f, + 0.938035070896149f, -0.241091892123222f, 0.937849998474121f, -0.241427779197693f, + 0.937664687633514f, -0.241763532161713f, 0.937479138374329f, -0.242099151015282f, + 0.937293350696564f, -0.242434620857239f, 0.937107264995575f, -0.242769956588745f, + 0.936920940876007f, -0.243105143308640f, 0.936734318733215f, -0.243440181016922f, + 0.936547517776489f, -0.243775084614754f, 0.936360359191895f, -0.244109839200974f, + 0.936173021793365f, -0.244444444775581f, 0.935985386371613f, -0.244778916239738f, + 0.935797572135925f, -0.245113238692284f, 0.935609400272369f, -0.245447427034378f, + 0.935421049594879f, -0.245781451463699f, 0.935232400894165f, -0.246115356683731f, + 0.935043513774872f, -0.246449097990990f, 0.934854328632355f, -0.246782705187798f, + 0.934664964675903f, -0.247116148471832f, 0.934475243091583f, -0.247449472546577f, + 0.934285342693329f, -0.247782632708550f, 0.934095203876495f, -0.248115643858910f, + 0.933904767036438f, -0.248448520898819f, 0.933714091777802f, -0.248781248927116f, + 0.933523118495941f, -0.249113827943802f, 0.933331906795502f, -0.249446272850037f, + 0.933140456676483f, -0.249778553843498f, 0.932948768138886f, -0.250110685825348f, + 0.932756841182709f, -0.250442683696747f, 0.932564616203308f, -0.250774532556534f, + 0.932372152805328f, -0.251106232404709f, 0.932179391384125f, -0.251437783241272f, + 0.931986451148987f, -0.251769185066223f, 0.931793212890625f, -0.252100437879562f, + 0.931599736213684f, -0.252431541681290f, 0.931405961513519f, -0.252762526273727f, + 0.931211948394775f, -0.253093332052231f, 0.931017756462097f, -0.253423988819122f, + 0.930823206901550f, -0.253754496574402f, 0.930628478527069f, -0.254084855318069f, + 0.930433452129364f, -0.254415065050125f, 0.930238187313080f, -0.254745125770569f, + 0.930042684078217f, -0.255075037479401f, 0.929846942424774f, -0.255404800176620f, + 0.929650902748108f, -0.255734413862228f, 0.929454624652863f, -0.256063878536224f, + 0.929258108139038f, -0.256393194198608f, 0.929061353206635f, -0.256722360849380f, + 0.928864300251007f, -0.257051378488541f, 0.928667008876801f, -0.257380217313766f, + 0.928469479084015f, -0.257708936929703f, 0.928271710872650f, -0.258037507534027f, + 0.928073644638062f, -0.258365899324417f, 0.927875399589539f, -0.258694142103195f, + 0.927676856517792f, -0.259022265672684f, 0.927478015422821f, -0.259350210428238f, + 0.927278995513916f, -0.259678006172180f, 0.927079677581787f, -0.260005623102188f, + 0.926880121231079f, -0.260333120822906f, 0.926680326461792f, -0.260660469532013f, + 0.926480293273926f, -0.260987639427185f, 0.926280021667480f, -0.261314690113068f, + 0.926079452037811f, -0.261641561985016f, 0.925878643989563f, -0.261968284845352f, + 0.925677597522736f, -0.262294828891754f, 0.925476312637329f, -0.262621253728867f, + 0.925274729728699f, -0.262947499752045f, 0.925072908401489f, -0.263273626565933f, + 0.924870908260345f, -0.263599574565887f, 0.924668610095978f, -0.263925373554230f, + 0.924466013908386f, -0.264250993728638f, 0.924263238906860f, -0.264576494693756f, + 0.924060165882111f, -0.264901816844940f, 0.923856854438782f, -0.265226989984512f, + 0.923653304576874f, -0.265552014112473f, 0.923449516296387f, -0.265876859426498f, + 0.923245489597321f, -0.266201555728912f, 0.923041164875031f, -0.266526103019714f, + 0.922836601734161f, -0.266850501298904f, 0.922631800174713f, -0.267174720764160f, + 0.922426760196686f, -0.267498821020126f, 0.922221481800079f, -0.267822742462158f, + 0.922015964984894f, -0.268146485090256f, 0.921810150146484f, -0.268470078706741f, + 0.921604096889496f, -0.268793523311615f, 0.921397805213928f, -0.269116818904877f, + 0.921191275119781f, -0.269439965486526f, 0.920984506607056f, -0.269762933254242f, + 0.920777499675751f, -0.270085722208023f, 0.920570194721222f, -0.270408391952515f, + 0.920362710952759f, -0.270730882883072f, 0.920154929161072f, -0.271053224802017f, + 0.919946908950806f, -0.271375387907028f, 0.919738650321960f, -0.271697402000427f, + 0.919530093669891f, -0.272019267082214f, 0.919321358203888f, -0.272340953350067f, + 0.919112324714661f, -0.272662490606308f, 0.918903112411499f, -0.272983878850937f, + 0.918693602085114f, -0.273305088281631f, 0.918483853340149f, -0.273626148700714f, + 0.918273866176605f, -0.273947030305862f, 0.918063640594482f, -0.274267762899399f, + 0.917853116989136f, -0.274588316679001f, 0.917642414569855f, -0.274908751249313f, + 0.917431414127350f, -0.275228977203369f, 0.917220234870911f, -0.275549083948135f, + 0.917008757591248f, -0.275868982076645f, 0.916797041893005f, -0.276188760995865f, + 0.916585087776184f, -0.276508361101151f, 0.916372895240784f, -0.276827782392502f, + 0.916160404682159f, -0.277147054672241f, 0.915947735309601f, -0.277466177940369f, + 0.915734827518463f, -0.277785122394562f, 0.915521621704102f, -0.278103888034821f, + 0.915308177471161f, -0.278422504663467f, 0.915094554424286f, -0.278740972280502f, + 0.914880633354187f, -0.279059261083603f, 0.914666473865509f, -0.279377400875092f, + 0.914452075958252f, -0.279695361852646f, 0.914237439632416f, -0.280013144016266f, + 0.914022505283356f, -0.280330777168274f, 0.913807392120361f, -0.280648261308670f, + 0.913592040538788f, -0.280965566635132f, 0.913376390933990f, -0.281282693147659f, + 0.913160502910614f, -0.281599670648575f, 0.912944436073303f, -0.281916469335556f, + 0.912728071212769f, -0.282233119010925f, 0.912511467933655f, -0.282549589872360f, + 0.912294626235962f, -0.282865911722183f, 0.912077546119690f, -0.283182054758072f, + 0.911860227584839f, -0.283498018980026f, 0.911642670631409f, -0.283813834190369f, + 0.911424875259399f, -0.284129470586777f, 0.911206841468811f, -0.284444957971573f, + 0.910988569259644f, -0.284760266542435f, 0.910769999027252f, -0.285075396299362f, + 0.910551249980927f, -0.285390377044678f, 0.910332262516022f, -0.285705178976059f, + 0.910112977027893f, -0.286019802093506f, 0.909893512725830f, -0.286334276199341f, + 0.909673750400543f, -0.286648571491241f, 0.909453809261322f, -0.286962717771530f, + 0.909233570098877f, -0.287276685237885f, 0.909013092517853f, -0.287590473890305f, + 0.908792436122894f, -0.287904083728790f, 0.908571481704712f, -0.288217544555664f, + 0.908350288867950f, -0.288530826568604f, 0.908128857612610f, -0.288843959569931f, + 0.907907187938690f, -0.289156883955002f, 0.907685279846191f, -0.289469659328461f, + 0.907463192939758f, -0.289782285690308f, 0.907240808010101f, -0.290094703435898f, + 0.907018184661865f, -0.290406972169876f, 0.906795322895050f, -0.290719062089920f, + 0.906572222709656f, -0.291031002998352f, 0.906348884105682f, -0.291342735290527f, + 0.906125307083130f, -0.291654318571091f, 0.905901491641998f, -0.291965723037720f, + 0.905677437782288f, -0.292276978492737f, 0.905453145503998f, -0.292588025331497f, + 0.905228614807129f, -0.292898923158646f, 0.905003845691681f, -0.293209642171860f, + 0.904778838157654f, -0.293520182371140f, 0.904553592205048f, -0.293830573558807f, + 0.904328107833862f, -0.294140785932541f, 0.904102385044098f, -0.294450789690018f, + 0.903876423835754f, -0.294760644435883f, 0.903650224208832f, -0.295070350170136f, + 0.903423786163330f, -0.295379847288132f, 0.903197109699249f, -0.295689195394516f, + 0.902970194816589f, -0.295998334884644f, 0.902743041515350f, -0.296307325363159f, + 0.902515649795532f, -0.296616137027740f, 0.902288019657135f, -0.296924799680710f, + 0.902060210704803f, -0.297233253717422f, 0.901832103729248f, -0.297541528940201f, + 0.901603758335114f, -0.297849655151367f, 0.901375174522400f, -0.298157602548599f, + 0.901146411895752f, -0.298465341329575f, 0.900917351245880f, -0.298772931098938f, + 0.900688111782074f, -0.299080342054367f, 0.900458574295044f, -0.299387603998184f, + 0.900228857994080f, -0.299694657325745f, 0.899998843669891f, -0.300001531839371f, + 0.899768650531769f, -0.300308227539063f, 0.899538159370422f, -0.300614774227142f, + 0.899307489395142f, -0.300921112298965f, 0.899076581001282f, -0.301227301359177f, + 0.898845434188843f, -0.301533311605453f, 0.898614048957825f, -0.301839113235474f, + 0.898382425308228f, -0.302144765853882f, 0.898150563240051f, -0.302450239658356f, + 0.897918462753296f, -0.302755534648895f, 0.897686123847961f, -0.303060621023178f, + 0.897453546524048f, -0.303365558385849f, 0.897220790386200f, -0.303670316934586f, + 0.896987736225128f, -0.303974896669388f, 0.896754503250122f, -0.304279297590256f, + 0.896520972251892f, -0.304583519697189f, 0.896287262439728f, -0.304887533187866f, + 0.896053314208984f, -0.305191397666931f, 0.895819067955017f, -0.305495083332062f, + 0.895584642887115f, -0.305798590183258f, 0.895349979400635f, -0.306101888418198f, + 0.895115137100220f, -0.306405037641525f, 0.894879996776581f, -0.306708008050919f, + 0.894644618034363f, -0.307010769844055f, 0.894409060478210f, -0.307313382625580f, + 0.894173204898834f, -0.307615786790848f, 0.893937170505524f, -0.307918041944504f, + 0.893700897693634f, -0.308220088481903f, 0.893464326858521f, -0.308521956205368f, + 0.893227577209473f, -0.308823645114899f, 0.892990648746490f, -0.309125155210495f, + 0.892753422260284f, -0.309426486492157f, 0.892515957355499f, -0.309727638959885f, + 0.892278313636780f, -0.310028612613678f, 0.892040371894836f, -0.310329377651215f, + 0.891802251338959f, -0.310629993677139f, 0.891563892364502f, -0.310930401086807f, + 0.891325294971466f, -0.311230629682541f, 0.891086459159851f, -0.311530679464340f, + 0.890847444534302f, -0.311830550432205f, 0.890608131885529f, -0.312130242586136f, + 0.890368640422821f, -0.312429755926132f, 0.890128850936890f, -0.312729060649872f, + 0.889888882637024f, -0.313028186559677f, 0.889648675918579f, -0.313327133655548f, + 0.889408230781555f, -0.313625901937485f, 0.889167606830597f, -0.313924491405487f, + 0.888926684856415f, -0.314222872257233f, 0.888685584068298f, -0.314521104097366f, + 0.888444244861603f, -0.314819127321243f, 0.888202667236328f, -0.315116971731186f, + 0.887960851192474f, -0.315414607524872f, 0.887718796730042f, -0.315712094306946f, + 0.887476563453674f, -0.316009372472763f, 0.887234091758728f, -0.316306471824646f, + 0.886991322040558f, -0.316603392362595f, 0.886748373508453f, -0.316900104284287f, + 0.886505246162415f, -0.317196637392044f, 0.886261820793152f, -0.317492991685867f, + 0.886018216609955f, -0.317789167165756f, 0.885774314403534f, -0.318085134029388f, + 0.885530233383179f, -0.318380922079086f, 0.885285973548889f, -0.318676531314850f, + 0.885041415691376f, -0.318971961736679f, 0.884796679019928f, -0.319267183542252f, + 0.884551644325256f, -0.319562226533890f, 0.884306430816650f, -0.319857090711594f, + 0.884061038494110f, -0.320151746273041f, 0.883815348148346f, -0.320446223020554f, + 0.883569478988647f, -0.320740520954132f, 0.883323311805725f, -0.321034610271454f, + 0.883076965808868f, -0.321328520774841f, 0.882830440998077f, -0.321622252464294f, + 0.882583618164063f, -0.321915775537491f, 0.882336616516113f, -0.322209119796753f, + 0.882089376449585f, -0.322502255439758f, 0.881841897964478f, -0.322795242071152f, + 0.881594181060791f, -0.323088020086288f, 0.881346285343170f, -0.323380589485168f, + 0.881098151206970f, -0.323672980070114f, 0.880849778652191f, -0.323965191841125f, + 0.880601167678833f, -0.324257194995880f, 0.880352377891541f, -0.324549019336700f, + 0.880103349685669f, -0.324840664863586f, 0.879854083061218f, -0.325132101774216f, + 0.879604578018188f, -0.325423330068588f, 0.879354894161224f, -0.325714409351349f, + 0.879104971885681f, -0.326005280017853f, 0.878854811191559f, -0.326295942068100f, + 0.878604412078857f, -0.326586425304413f, 0.878353834152222f, -0.326876699924469f, + 0.878103017807007f, -0.327166795730591f, 0.877851963043213f, -0.327456712722778f, + 0.877600669860840f, -0.327746421098709f, 0.877349197864532f, -0.328035950660706f, + 0.877097487449646f, -0.328325271606445f, 0.876845538616180f, -0.328614413738251f, + 0.876593410968781f, -0.328903347253799f, 0.876341044902802f, -0.329192101955414f, + 0.876088440418243f, -0.329480648040771f, 0.875835597515106f, -0.329769015312195f, + 0.875582575798035f, -0.330057173967361f, 0.875329315662384f, -0.330345153808594f, + 0.875075817108154f, -0.330632925033569f, 0.874822139739990f, -0.330920487642288f, + 0.874568223953247f, -0.331207901239395f, 0.874314069747925f, -0.331495076417923f, + 0.874059677124023f, -0.331782072782516f, 0.873805105686188f, -0.332068890333176f, + 0.873550295829773f, -0.332355499267578f, 0.873295307159424f, -0.332641899585724f, + 0.873040020465851f, -0.332928121089935f, 0.872784554958344f, -0.333214133977890f, + 0.872528910636902f, -0.333499968051910f, 0.872272968292236f, -0.333785593509674f, + 0.872016847133636f, -0.334071010351181f, 0.871760547161102f, -0.334356248378754f, + 0.871503949165344f, -0.334641307592392f, 0.871247172355652f, -0.334926128387451f, + 0.870990216732025f, -0.335210770368576f, 0.870733022689819f, -0.335495233535767f, + 0.870475590229034f, -0.335779488086700f, 0.870217919349670f, -0.336063534021378f, + 0.869960069656372f, -0.336347371339798f, 0.869701981544495f, -0.336631029844284f, + 0.869443655014038f, -0.336914509534836f, 0.869185149669647f, -0.337197750806808f, + 0.868926405906677f, -0.337480813264847f, 0.868667483329773f, -0.337763696908951f, + 0.868408262729645f, -0.338046342134476f, 0.868148922920227f, -0.338328808546066f, + 0.867889285087585f, -0.338611096143723f, 0.867629468441010f, -0.338893145322800f, + 0.867369413375854f, -0.339175015687943f, 0.867109179496765f, -0.339456677436829f, + 0.866848707199097f, -0.339738160371780f, 0.866588056087494f, -0.340019434690475f, + 0.866327106952667f, -0.340300500392914f, 0.866066038608551f, -0.340581357479095f, + 0.865804672241211f, -0.340862035751343f, 0.865543127059937f, -0.341142505407333f, + 0.865281403064728f, -0.341422766447067f, 0.865019381046295f, -0.341702848672867f, + 0.864757239818573f, -0.341982692480087f, 0.864494800567627f, -0.342262357473373f, + 0.864232182502747f, -0.342541843652725f, 0.863969385623932f, -0.342821091413498f, + 0.863706290721893f, -0.343100160360336f, 0.863443076610565f, -0.343379020690918f, + 0.863179564476013f, -0.343657672405243f, 0.862915873527527f, -0.343936115503311f, + 0.862652003765106f, -0.344214379787445f, 0.862387895584106f, -0.344492435455322f, + 0.862123548984528f, -0.344770282506943f, 0.861859023571014f, -0.345047920942307f, + 0.861594259738922f, -0.345325350761414f, 0.861329257488251f, -0.345602601766586f, + 0.861064076423645f, -0.345879614353180f, 0.860798716545105f, -0.346156448125839f, + 0.860533118247986f, -0.346433073282242f, 0.860267281532288f, -0.346709519624710f, + 0.860001266002655f, -0.346985727548599f, 0.859735012054443f, -0.347261756658554f, + 0.859468579292297f, -0.347537547349930f, 0.859201908111572f, -0.347813159227371f, + 0.858934998512268f, -0.348088562488556f, 0.858667910099030f, -0.348363757133484f, + 0.858400642871857f, -0.348638743162155f, 0.858133137226105f, -0.348913550376892f, + 0.857865393161774f, -0.349188119173050f, 0.857597470283508f, -0.349462509155273f, + 0.857329368591309f, -0.349736660718918f, 0.857060968875885f, -0.350010633468628f, + 0.856792449951172f, -0.350284397602081f, 0.856523692607880f, -0.350557953119278f, + 0.856254696846008f, -0.350831300020218f, 0.855985522270203f, -0.351104438304901f, + 0.855716109275818f, -0.351377367973328f, 0.855446517467499f, -0.351650089025497f, + 0.855176687240601f, -0.351922631263733f, 0.854906618595123f, -0.352194935083389f, + 0.854636430740356f, -0.352467030286789f, 0.854365944862366f, -0.352738946676254f, + 0.854095339775085f, -0.353010624647141f, 0.853824436664581f, -0.353282123804092f, + 0.853553414344788f, -0.353553384542465f, 0.853282094001770f, -0.353824466466904f, + 0.853010654449463f, -0.354095309972763f, 0.852738916873932f, -0.354365974664688f, + 0.852467060089111f, -0.354636400938034f, 0.852194905281067f, -0.354906648397446f, + 0.851922631263733f, -0.355176687240601f, 0.851650118827820f, -0.355446487665176f, + 0.851377367973328f, -0.355716109275818f, 0.851104438304901f, -0.355985492467880f, + 0.850831270217896f, -0.356254696846008f, 0.850557923316956f, -0.356523662805557f, + 0.850284397602081f, -0.356792420148849f, 0.850010633468628f, -0.357060998678207f, + 0.849736690521240f, -0.357329338788986f, 0.849462509155273f, -0.357597470283508f, + 0.849188148975372f, -0.357865422964096f, 0.848913550376892f, -0.358133137226105f, + 0.848638772964478f, -0.358400642871857f, 0.848363757133484f, -0.358667939901352f, + 0.848088562488556f, -0.358935028314590f, 0.847813189029694f, -0.359201908111572f, + 0.847537577152252f, -0.359468549489975f, 0.847261726856232f, -0.359735012054443f, + 0.846985757350922f, -0.360001266002655f, 0.846709489822388f, -0.360267281532288f, + 0.846433103084564f, -0.360533088445663f, 0.846156477928162f, -0.360798716545105f, + 0.845879614353180f, -0.361064106225967f, 0.845602571964264f, -0.361329287290573f, + 0.845325350761414f, -0.361594229936600f, 0.845047891139984f, -0.361858993768692f, + 0.844770252704620f, -0.362123548984528f, 0.844492435455322f, -0.362387865781784f, + 0.844214379787445f, -0.362651973962784f, 0.843936145305634f, -0.362915903329849f, + 0.843657672405243f, -0.363179564476013f, 0.843379020690918f, -0.363443046808243f, + 0.843100130558014f, -0.363706320524216f, 0.842821121215820f, -0.363969355821610f, + 0.842541813850403f, -0.364232182502747f, 0.842262387275696f, -0.364494800567627f, + 0.841982722282410f, -0.364757210016251f, 0.841702818870544f, -0.365019410848618f, + 0.841422796249390f, -0.365281373262405f, 0.841142535209656f, -0.365543156862259f, + 0.840862035751343f, -0.365804702043533f, 0.840581357479095f, -0.366066008806229f, + 0.840300500392914f, -0.366327136754990f, 0.840019404888153f, -0.366588026285172f, + 0.839738130569458f, -0.366848707199097f, 0.839456677436829f, -0.367109179496765f, + 0.839175045490265f, -0.367369443178177f, 0.838893175125122f, -0.367629468441010f, + 0.838611066341400f, -0.367889285087585f, 0.838328838348389f, -0.368148893117905f, + 0.838046371936798f, -0.368408292531967f, 0.837763667106628f, -0.368667453527451f, + 0.837480843067169f, -0.368926405906677f, 0.837197780609131f, -0.369185149669647f, + 0.836914479732513f, -0.369443655014038f, 0.836631059646606f, -0.369701951742172f, + 0.836347401142120f, -0.369960039854050f, 0.836063504219055f, -0.370217919349670f, + 0.835779488086700f, -0.370475560426712f, 0.835495233535767f, -0.370732992887497f, + 0.835210800170898f, -0.370990216732025f, 0.834926128387451f, -0.371247202157974f, + 0.834641277790070f, -0.371503978967667f, 0.834356248378754f, -0.371760547161102f, + 0.834071040153503f, -0.372016876935959f, 0.833785593509674f, -0.372272998094559f, + 0.833499968051910f, -0.372528880834579f, 0.833214163780212f, -0.372784584760666f, + 0.832928121089935f, -0.373040050268173f, 0.832641899585724f, -0.373295277357101f, + 0.832355499267578f, -0.373550295829773f, 0.832068860530853f, -0.373805105686188f, + 0.831782102584839f, -0.374059677124023f, 0.831495106220245f, -0.374314039945602f, + 0.831207871437073f, -0.374568194150925f, 0.830920517444611f, -0.374822109937668f, + 0.830632925033569f, -0.375075817108154f, 0.830345153808594f, -0.375329315662384f, + 0.830057144165039f, -0.375582575798035f, 0.829769015312195f, -0.375835597515106f, + 0.829480648040771f, -0.376088410615921f, 0.829192101955414f, -0.376341015100479f, + 0.828903317451477f, -0.376593410968781f, 0.828614413738251f, -0.376845568418503f, + 0.828325271606445f, -0.377097487449646f, 0.828035950660706f, -0.377349197864532f, + 0.827746450901031f, -0.377600699663162f, 0.827456712722778f, -0.377851963043213f, + 0.827166795730591f, -0.378102988004684f, 0.826876699924469f, -0.378353834152222f, + 0.826586425304413f, -0.378604412078857f, 0.826295912265778f, -0.378854811191559f, + 0.826005280017853f, -0.379104942083359f, 0.825714409351349f, -0.379354894161224f, + 0.825423359870911f, -0.379604607820511f, 0.825132071971893f, -0.379854083061218f, + 0.824840664863586f, -0.380103349685669f, 0.824549019336700f, -0.380352377891541f, + 0.824257194995880f, -0.380601197481155f, 0.823965191841125f, -0.380849778652191f, + 0.823673009872437f, -0.381098151206970f, 0.823380589485168f, -0.381346285343170f, + 0.823087990283966f, -0.381594210863113f, 0.822795212268829f, -0.381841897964478f, + 0.822502255439758f, -0.382089376449585f, 0.822209119796753f, -0.382336616516113f, + 0.821915745735168f, -0.382583618164063f, 0.821622252464294f, -0.382830440998077f, + 0.821328520774841f, -0.383076995611191f, 0.821034610271454f, -0.383323341608047f, + 0.820740520954132f, -0.383569449186325f, 0.820446193218231f, -0.383815348148346f, + 0.820151746273041f, -0.384061008691788f, 0.819857060909271f, -0.384306460618973f, + 0.819562196731567f, -0.384551674127579f, 0.819267153739929f, -0.384796649217606f, + 0.818971931934357f, -0.385041415691376f, 0.818676531314850f, -0.385285943746567f, + 0.818380951881409f, -0.385530263185501f, 0.818085134029388f, -0.385774344205856f, + 0.817789137363434f, -0.386018186807632f, 0.817493021488190f, -0.386261820793152f, + 0.817196667194366f, -0.386505216360092f, 0.816900074481964f, -0.386748403310776f, + 0.816603362560272f, -0.386991351842880f, 0.816306471824646f, -0.387234061956406f, + 0.816009342670441f, -0.387476563453674f, 0.815712094306946f, -0.387718826532364f, + 0.815414607524872f, -0.387960851192474f, 0.815116941928864f, -0.388202667236328f, + 0.814819097518921f, -0.388444244861603f, 0.814521074295044f, -0.388685584068298f, + 0.814222872257233f, -0.388926714658737f, 0.813924491405487f, -0.389167606830597f, + 0.813625931739807f, -0.389408260583878f, 0.813327133655548f, -0.389648675918579f, + 0.813028216362000f, -0.389888882637024f, 0.812729060649872f, -0.390128880739212f, + 0.812429726123810f, -0.390368610620499f, 0.812130272388458f, -0.390608131885529f, + 0.811830580234528f, -0.390847414731979f, 0.811530709266663f, -0.391086459159851f, + 0.811230659484863f, -0.391325294971466f, 0.810930430889130f, -0.391563892364502f, + 0.810629963874817f, -0.391802251338959f, 0.810329377651215f, -0.392040401697159f, + 0.810028612613678f, -0.392278283834457f, 0.809727668762207f, -0.392515957355499f, + 0.809426486492157f, -0.392753422260284f, 0.809125185012817f, -0.392990618944168f, + 0.808823645114899f, -0.393227607011795f, 0.808521986007690f, -0.393464356660843f, + 0.808220088481903f, -0.393700867891312f, 0.807918012142181f, -0.393937170505524f, + 0.807615816593170f, -0.394173204898834f, 0.807313382625580f, -0.394409030675888f, + 0.807010769844055f, -0.394644618034363f, 0.806707978248596f, -0.394879996776581f, + 0.806405067443848f, -0.395115107297897f, 0.806101918220520f, -0.395350009202957f, + 0.805798590183258f, -0.395584672689438f, 0.805495083332062f, -0.395819097757339f, + 0.805191397666931f, -0.396053284406662f, 0.804887533187866f, -0.396287262439728f, + 0.804583489894867f, -0.396520972251892f, 0.804279267787933f, -0.396754473447800f, + 0.803974866867065f, -0.396987736225128f, 0.803670346736908f, -0.397220760583878f, + 0.803365588188171f, -0.397453576326370f, 0.803060650825500f, -0.397686123847961f, + 0.802755534648895f, -0.397918462753296f, 0.802450239658356f, -0.398150533437729f, + 0.802144765853882f, -0.398382395505905f, 0.801839113235474f, -0.398614019155502f, + 0.801533281803131f, -0.398845434188843f, 0.801227271556854f, -0.399076581001282f, + 0.800921142101288f, -0.399307489395142f, 0.800614774227142f, -0.399538189172745f, + 0.800308227539063f, -0.399768620729446f, 0.800001561641693f, -0.399998843669891f, + 0.799694657325745f, -0.400228828191757f, 0.799387574195862f, -0.400458574295044f, + 0.799080371856689f, -0.400688081979752f, 0.798772931098938f, -0.400917351245880f, + 0.798465371131897f, -0.401146411895752f, 0.798157572746277f, -0.401375204324722f, + 0.797849655151367f, -0.401603758335114f, 0.797541558742523f, -0.401832103729248f, + 0.797233223915100f, -0.402060180902481f, 0.796924769878387f, -0.402288049459457f, + 0.796616137027740f, -0.402515679597855f, 0.796307325363159f, -0.402743041515350f, + 0.795998334884644f, -0.402970194816589f, 0.795689165592194f, -0.403197109699249f, + 0.795379877090454f, -0.403423786163330f, 0.795070350170136f, -0.403650224208832f, + 0.794760644435883f, -0.403876423835754f, 0.794450819492340f, -0.404102355241776f, + 0.794140756130219f, -0.404328078031540f, 0.793830573558807f, -0.404553562402725f, + 0.793520212173462f, -0.404778808355331f, 0.793209671974182f, -0.405003815889359f, + 0.792898952960968f, -0.405228585004807f, 0.792588055133820f, -0.405453115701675f, + 0.792276978492737f, -0.405677437782288f, 0.791965723037720f, -0.405901491641998f, + 0.791654348373413f, -0.406125307083130f, 0.791342735290527f, -0.406348884105682f, + 0.791031002998352f, -0.406572192907333f, 0.790719091892242f, -0.406795293092728f, + 0.790407001972198f, -0.407018154859543f, 0.790094733238220f, -0.407240778207779f, + 0.789782285690308f, -0.407463163137436f, 0.789469659328461f, -0.407685309648514f, + 0.789156913757324f, -0.407907217741013f, 0.788843929767609f, -0.408128857612610f, + 0.788530826568604f, -0.408350288867950f, 0.788217544555664f, -0.408571451902390f, + 0.787904083728790f, -0.408792406320572f, 0.787590444087982f, -0.409013092517853f, + 0.787276685237885f, -0.409233570098877f, 0.786962687969208f, -0.409453779459000f, + 0.786648571491241f, -0.409673750400543f, 0.786334276199341f, -0.409893482923508f, + 0.786019802093506f, -0.410112977027893f, 0.785705149173737f, -0.410332232713699f, + 0.785390377044678f, -0.410551249980927f, 0.785075426101685f, -0.410770028829575f, + 0.784760236740112f, -0.410988569259644f, 0.784444928169250f, -0.411206841468811f, + 0.784129500389099f, -0.411424905061722f, 0.783813834190369f, -0.411642700433731f, + 0.783498048782349f, -0.411860257387161f, 0.783182024955750f, -0.412077575922012f, + 0.782865881919861f, -0.412294656038284f, 0.782549619674683f, -0.412511497735977f, + 0.782233119010925f, -0.412728071212769f, 0.781916499137878f, -0.412944436073303f, + 0.781599700450897f, -0.413160532712936f, 0.781282722949982f, -0.413376390933990f, + 0.780965566635132f, -0.413592010736465f, 0.780648231506348f, -0.413807392120361f, + 0.780330777168274f, -0.414022535085678f, 0.780013144016266f, -0.414237409830093f, + 0.779695332050323f, -0.414452046155930f, 0.779377400875092f, -0.414666473865509f, + 0.779059290885925f, -0.414880603551865f, 0.778741002082825f, -0.415094524621964f, + 0.778422534465790f, -0.415308207273483f, 0.778103888034821f, -0.415521621704102f, + 0.777785122394562f, -0.415734797716141f, 0.777466177940369f, -0.415947735309601f, + 0.777147054672241f, -0.416160434484482f, 0.776827812194824f, -0.416372895240784f, + 0.776508331298828f, -0.416585087776184f, 0.776188731193542f, -0.416797041893005f, + 0.775869011878967f, -0.417008757591248f, 0.775549054145813f, -0.417220205068588f, + 0.775228977203369f, -0.417431443929672f, 0.774908721446991f, -0.417642414569855f, + 0.774588346481323f, -0.417853146791458f, 0.774267733097076f, -0.418063640594482f, + 0.773947000503540f, -0.418273866176605f, 0.773626148700714f, -0.418483853340149f, + 0.773305058479309f, -0.418693602085114f, 0.772983849048615f, -0.418903112411499f, + 0.772662520408630f, -0.419112354516983f, 0.772340953350067f, -0.419321358203888f, + 0.772019267082214f, -0.419530123472214f, 0.771697402000427f, -0.419738620519638f, + 0.771375417709351f, -0.419946908950806f, 0.771053194999695f, -0.420154929161072f, + 0.770730912685394f, -0.420362681150436f, 0.770408391952515f, -0.420570224523544f, + 0.770085752010345f, -0.420777499675751f, 0.769762933254242f, -0.420984506607056f, + 0.769439935684204f, -0.421191304922104f, 0.769116818904877f, -0.421397835016251f, + 0.768793523311615f, -0.421604126691818f, 0.768470108509064f, -0.421810150146484f, + 0.768146514892578f, -0.422015935182571f, 0.767822742462158f, -0.422221481800079f, + 0.767498791217804f, -0.422426789999008f, 0.767174720764160f, -0.422631829977036f, + 0.766850471496582f, -0.422836631536484f, 0.766526103019714f, -0.423041164875031f, + 0.766201555728912f, -0.423245459794998f, 0.765876889228821f, -0.423449516296387f, + 0.765551984310150f, -0.423653304576874f, 0.765226960182190f, -0.423856884241104f, + 0.764901816844940f, -0.424060165882111f, 0.764576494693756f, -0.424263238906860f, + 0.764250993728638f, -0.424466013908386f, 0.763925373554230f, -0.424668580293655f, + 0.763599574565887f, -0.424870878458023f, 0.763273596763611f, -0.425072938203812f, + 0.762947499752045f, -0.425274729728699f, 0.762621283531189f, -0.425476282835007f, + 0.762294828891754f, -0.425677597522736f, 0.761968255043030f, -0.425878643989563f, + 0.761641561985016f, -0.426079452037811f, 0.761314690113068f, -0.426279991865158f, + 0.760987639427185f, -0.426480293273926f, 0.760660469532013f, -0.426680356264114f, + 0.760333120822906f, -0.426880151033401f, 0.760005652904511f, -0.427079707384110f, + 0.759678006172180f, -0.427278995513916f, 0.759350180625916f, -0.427478045225143f, + 0.759022235870361f, -0.427676826715469f, 0.758694171905518f, -0.427875369787216f, + 0.758365929126740f, -0.428073674440384f, 0.758037507534027f, -0.428271710872650f, + 0.757708966732025f, -0.428469479084015f, 0.757380247116089f, -0.428667008876801f, + 0.757051348686218f, -0.428864300251007f, 0.756722390651703f, -0.429061323404312f, + 0.756393194198608f, -0.429258108139038f, 0.756063878536224f, -0.429454624652863f, + 0.755734443664551f, -0.429650902748108f, 0.755404829978943f, -0.429846942424774f, + 0.755075037479401f, -0.430042684078217f, 0.754745125770569f, -0.430238217115402f, + 0.754415094852448f, -0.430433481931686f, 0.754084885120392f, -0.430628478527069f, + 0.753754496574402f, -0.430823236703873f, 0.753423988819122f, -0.431017726659775f, + 0.753093302249908f, -0.431211978197098f, 0.752762496471405f, -0.431405961513519f, + 0.752431571483612f, -0.431599706411362f, 0.752100467681885f, -0.431793183088303f, + 0.751769185066223f, -0.431986421346664f, 0.751437783241272f, -0.432179391384125f, + 0.751106262207031f, -0.432372123003006f, 0.750774562358856f, -0.432564586400986f, + 0.750442683696747f, -0.432756811380386f, 0.750110685825348f, -0.432948768138886f, + 0.749778568744659f, -0.433140486478806f, 0.749446272850037f, -0.433331936597824f, + 0.749113857746124f, -0.433523118495941f, 0.748781263828278f, -0.433714061975479f, + 0.748448550701141f, -0.433904737234116f, 0.748115658760071f, -0.434095174074173f, + 0.747782647609711f, -0.434285342693329f, 0.747449457645416f, -0.434475272893906f, + 0.747116148471832f, -0.434664934873581f, 0.746782720088959f, -0.434854328632355f, + 0.746449112892151f, -0.435043483972549f, 0.746115326881409f, -0.435232400894165f, + 0.745781481266022f, -0.435421019792557f, 0.745447397232056f, -0.435609430074692f, + 0.745113253593445f, -0.435797542333603f, 0.744778931140900f, -0.435985416173935f, + 0.744444429874420f, -0.436173021793365f, 0.744109809398651f, -0.436360388994217f, + 0.743775069713593f, -0.436547487974167f, 0.743440151214600f, -0.436734348535538f, + 0.743105113506317f, -0.436920911073685f, 0.742769956588745f, -0.437107264995575f, + 0.742434620857239f, -0.437293320894241f, 0.742099165916443f, -0.437479138374329f, + 0.741763532161713f, -0.437664687633514f, 0.741427779197693f, -0.437849998474121f, + 0.741091907024384f, -0.438035041093826f, 0.740755856037140f, -0.438219845294952f, + 0.740419685840607f, -0.438404351472855f, 0.740083336830139f, -0.438588619232178f, + 0.739746868610382f, -0.438772648572922f, 0.739410281181335f, -0.438956409692764f, + 0.739073514938354f, -0.439139902591705f, 0.738736629486084f, -0.439323127269745f, + 0.738399624824524f, -0.439506113529205f, 0.738062441349030f, -0.439688831567764f, + 0.737725138664246f, -0.439871311187744f, 0.737387716770172f, -0.440053492784500f, + 0.737050116062164f, -0.440235435962677f, 0.736712396144867f, -0.440417140722275f, + 0.736374497413635f, -0.440598547458649f, 0.736036539077759f, -0.440779715776443f, + 0.735698342323303f, -0.440960645675659f, 0.735360085964203f, -0.441141277551651f, + 0.735021650791168f, -0.441321671009064f, 0.734683096408844f, -0.441501796245575f, + 0.734344422817230f, -0.441681683063507f, 0.734005570411682f, -0.441861271858215f, + 0.733666598796844f, -0.442040622234344f, 0.733327507972717f, -0.442219734191895f, + 0.732988238334656f, -0.442398548126221f, 0.732648849487305f, -0.442577123641968f, + 0.732309341430664f, -0.442755430936813f, 0.731969714164734f, -0.442933470010757f, + 0.731629908084869f, -0.443111270666122f, 0.731289982795715f, -0.443288803100586f, + 0.730949878692627f, -0.443466067314148f, 0.730609714984894f, -0.443643063306808f, + 0.730269372463226f, -0.443819820880890f, 0.729928910732269f, -0.443996280431747f, + 0.729588270187378f, -0.444172531366348f, 0.729247510433197f, -0.444348484277725f, + 0.728906631469727f, -0.444524168968201f, 0.728565633296967f, -0.444699615240097f, + 0.728224515914917f, -0.444874793291092f, 0.727883219718933f, -0.445049703121185f, + 0.727541804313660f, -0.445224374532700f, 0.727200269699097f, -0.445398747920990f, + 0.726858556270599f, -0.445572882890701f, 0.726516723632813f, -0.445746749639511f, + 0.726174771785736f, -0.445920348167419f, 0.725832700729370f, -0.446093708276749f, + 0.725490510463715f, -0.446266770362854f, 0.725148141384125f, -0.446439594030380f, + 0.724805653095245f, -0.446612149477005f, 0.724463045597076f, -0.446784436702728f, + 0.724120318889618f, -0.446956485509872f, 0.723777413368225f, -0.447128236293793f, + 0.723434448242188f, -0.447299748659134f, 0.723091304302216f, -0.447470992803574f, + 0.722747981548309f, -0.447641968727112f, 0.722404599189758f, -0.447812676429749f, + 0.722061097621918f, -0.447983115911484f, 0.721717417240143f, -0.448153316974640f, + 0.721373617649078f, -0.448323249816895f, 0.721029698848724f, -0.448492884635925f, + 0.720685660839081f, -0.448662281036377f, 0.720341444015503f, -0.448831409215927f, + 0.719997107982636f, -0.449000298976898f, 0.719652712345123f, -0.449168890714645f, + 0.719308137893677f, -0.449337244033813f, 0.718963444232941f, -0.449505299329758f, + 0.718618571758270f, -0.449673116207123f, 0.718273639678955f, -0.449840664863586f, + 0.717928528785706f, -0.450007945299149f, 0.717583298683167f, -0.450174957513809f, + 0.717238008975983f, -0.450341701507568f, 0.716892480850220f, -0.450508207082748f, + 0.716546893119812f, -0.450674414634705f, 0.716201186180115f, -0.450840383768082f, + 0.715855300426483f, -0.451006084680557f, 0.715509355068207f, -0.451171487569809f, + 0.715163230895996f, -0.451336652040482f, 0.714816987514496f, -0.451501548290253f, + 0.714470624923706f, -0.451666176319122f, 0.714124143123627f, -0.451830536127090f, + 0.713777542114258f, -0.451994657516479f, 0.713430821895599f, -0.452158480882645f, + 0.713083922863007f, -0.452322036027908f, 0.712736964225769f, -0.452485352754593f, + 0.712389826774597f, -0.452648371458054f, 0.712042629718781f, -0.452811151742935f, + 0.711695253849030f, -0.452973634004593f, 0.711347758769989f, -0.453135877847672f, + 0.711000144481659f, -0.453297853469849f, 0.710652410984039f, -0.453459560871124f, + 0.710304558277130f, -0.453621000051498f, 0.709956526756287f, -0.453782171010971f, + 0.709608435630798f, -0.453943043947220f, 0.709260225296021f, -0.454103678464890f, + 0.708911836147308f, -0.454264044761658f, 0.708563387393951f, -0.454424172639847f, + 0.708214759826660f, -0.454584002494812f, 0.707866072654724f, -0.454743564128876f, + 0.707517206668854f, -0.454902857542038f, 0.707168221473694f, -0.455061882734299f, + 0.706819176673889f, -0.455220639705658f, 0.706469953060150f, -0.455379128456116f, + 0.706120610237122f, -0.455537378787994f, 0.705771148204803f, -0.455695331096649f, + 0.705421566963196f, -0.455853015184402f, 0.705071866512299f, -0.456010431051254f, + 0.704722046852112f, -0.456167578697205f, 0.704372167587280f, -0.456324487924576f, + 0.704022109508514f, -0.456481099128723f, 0.703671932220459f, -0.456637442111969f, + 0.703321635723114f, -0.456793516874313f, 0.702971220016479f, -0.456949323415756f, + 0.702620685100555f, -0.457104891538620f, 0.702270030975342f, -0.457260161638260f, + 0.701919257640839f, -0.457415163516998f, 0.701568365097046f, -0.457569897174835f, + 0.701217353343964f, -0.457724362611771f, 0.700866222381592f, -0.457878559827805f, + 0.700514972209930f, -0.458032488822937f, 0.700163602828979f, -0.458186149597168f, + 0.699812114238739f, -0.458339542150497f, 0.699460506439209f, -0.458492636680603f, + 0.699108779430389f, -0.458645492792130f, 0.698756933212280f, -0.458798080682755f, + 0.698404967784882f, -0.458950400352478f, 0.698052942752838f, -0.459102421998978f, + 0.697700738906860f, -0.459254205226898f, 0.697348415851593f, -0.459405690431595f, + 0.696996033191681f, -0.459556937217712f, 0.696643471717834f, -0.459707885980606f, + 0.696290850639343f, -0.459858566522598f, 0.695938050746918f, -0.460008978843689f, + 0.695585191249847f, -0.460159152746201f, 0.695232212543488f, -0.460309028625488f, + 0.694879114627838f, -0.460458606481552f, 0.694525837898254f, -0.460607945919037f, + 0.694172501564026f, -0.460757017135620f, 0.693819046020508f, -0.460905820131302f, + 0.693465530872345f, -0.461054325103760f, 0.693111836910248f, -0.461202591657639f, + 0.692758023738861f, -0.461350560188293f, 0.692404091358185f, -0.461498260498047f, + 0.692050099372864f, -0.461645722389221f, 0.691695988178253f, -0.461792886257172f, + 0.691341698169708f, -0.461939752101898f, 0.690987348556519f, -0.462086379528046f, + 0.690632879734039f, -0.462232738733292f, 0.690278291702271f, -0.462378799915314f, + 0.689923584461212f, -0.462524622678757f, 0.689568817615509f, -0.462670147418976f, + 0.689213871955872f, -0.462815403938293f, 0.688858866691589f, -0.462960392236710f, + 0.688503682613373f, -0.463105112314224f, 0.688148438930511f, -0.463249564170837f, + 0.687793076038361f, -0.463393747806549f, 0.687437593936920f, -0.463537633419037f, + 0.687082052230835f, -0.463681250810623f, 0.686726331710815f, -0.463824629783630f, + 0.686370551586151f, -0.463967710733414f, 0.686014592647552f, -0.464110493659973f, + 0.685658574104309f, -0.464253038167953f, 0.685302436351776f, -0.464395314455032f, + 0.684946238994598f, -0.464537292718887f, 0.684589862823486f, -0.464679002761841f, + 0.684233427047729f, -0.464820444583893f, 0.683876872062683f, -0.464961618185043f, + 0.683520197868347f, -0.465102523565292f, 0.683163404464722f, -0.465243130922318f, + 0.682806491851807f, -0.465383470058441f, 0.682449519634247f, -0.465523540973663f, + 0.682092368602753f, -0.465663343667984f, 0.681735157966614f, -0.465802878141403f, + 0.681377887725830f, -0.465942144393921f, 0.681020438671112f, -0.466081112623215f, + 0.680662930011749f, -0.466219812631607f, 0.680305242538452f, -0.466358244419098f, + 0.679947495460510f, -0.466496407985687f, 0.679589688777924f, -0.466634273529053f, + 0.679231703281403f, -0.466771900653839f, 0.678873658180237f, -0.466909229755402f, + 0.678515493869781f, -0.467046260833740f, 0.678157210350037f, -0.467183053493500f, + 0.677798807621002f, -0.467319577932358f, 0.677440345287323f, -0.467455804347992f, + 0.677081763744354f, -0.467591762542725f, 0.676723062992096f, -0.467727422714233f, + 0.676364302635193f, -0.467862844467163f, 0.676005363464355f, -0.467997968196869f, + 0.675646364688873f, -0.468132823705673f, 0.675287246704102f, -0.468267410993576f, + 0.674928069114685f, -0.468401730060577f, 0.674568772315979f, -0.468535751104355f, + 0.674209356307983f, -0.468669503927231f, 0.673849821090698f, -0.468802988529205f, + 0.673490226268768f, -0.468936175107956f, 0.673130512237549f, -0.469069123268127f, + 0.672770678997040f, -0.469201773405075f, 0.672410726547241f, -0.469334155321121f, + 0.672050714492798f, -0.469466239213943f, 0.671690583229065f, -0.469598054885864f, + 0.671330332756042f, -0.469729602336884f, 0.670970022678375f, -0.469860881567001f, + 0.670609593391418f, -0.469991862773895f, 0.670249044895172f, -0.470122605562210f, + 0.669888436794281f, -0.470253020524979f, 0.669527709484100f, -0.470383197069168f, + 0.669166862964630f, -0.470513075590134f, 0.668805956840515f, -0.470642685890198f, + 0.668444931507111f, -0.470772027969360f, 0.668083786964417f, -0.470901101827621f, + 0.667722582817078f, -0.471029877662659f, 0.667361259460449f, -0.471158385276794f, + 0.666999816894531f, -0.471286594867706f, 0.666638314723969f, -0.471414536237717f, + 0.666276693344116f, -0.471542209386826f, 0.665914952754974f, -0.471669614315033f, + 0.665553152561188f, -0.471796721220016f, 0.665191233158112f, -0.471923559904099f, + 0.664829254150391f, -0.472050130367279f, 0.664467096328735f, -0.472176402807236f, + 0.664104938507080f, -0.472302407026291f, 0.663742601871490f, -0.472428143024445f, + 0.663380205631256f, -0.472553610801697f, 0.663017749786377f, -0.472678780555725f, + 0.662655174732208f, -0.472803652286530f, 0.662292480468750f, -0.472928285598755f, + 0.661929666996002f, -0.473052620887756f, 0.661566793918610f, -0.473176687955856f, + 0.661203861236572f, -0.473300457000732f, 0.660840749740601f, -0.473423957824707f, + 0.660477638244629f, -0.473547190427780f, 0.660114347934723f, -0.473670125007629f, + 0.659750998020172f, -0.473792791366577f, 0.659387588500977f, -0.473915189504623f, + 0.659024059772491f, -0.474037289619446f, 0.658660411834717f, -0.474159121513367f, + 0.658296704292297f, -0.474280685186386f, 0.657932877540588f, -0.474401950836182f, + 0.657568991184235f, -0.474522948265076f, 0.657204985618591f, -0.474643647670746f, + 0.656840860843658f, -0.474764078855515f, 0.656476676464081f, -0.474884241819382f, + 0.656112432479858f, -0.475004136562347f, 0.655748009681702f, -0.475123733282089f, + 0.655383586883545f, -0.475243031978607f, 0.655019044876099f, -0.475362062454224f, + 0.654654383659363f, -0.475480824708939f, 0.654289662837982f, -0.475599318742752f, + 0.653924822807312f, -0.475717514753342f, 0.653559923171997f, -0.475835442543030f, + 0.653194904327393f, -0.475953072309494f, 0.652829825878143f, -0.476070433855057f, + 0.652464628219604f, -0.476187497377396f, 0.652099311351776f, -0.476304292678833f, + 0.651733994483948f, -0.476420819759369f, 0.651368498802185f, -0.476537048816681f, + 0.651003003120422f, -0.476653009653091f, 0.650637328624725f, -0.476768702268600f, + 0.650271594524384f, -0.476884096860886f, 0.649905800819397f, -0.476999223232269f, + 0.649539887905121f, -0.477114051580429f, 0.649173915386200f, -0.477228611707687f, + 0.648807883262634f, -0.477342873811722f, 0.648441672325134f, -0.477456867694855f, + 0.648075461387634f, -0.477570593357086f, 0.647709131240845f, -0.477684020996094f, + 0.647342681884766f, -0.477797180414200f, 0.646976172924042f, -0.477910041809082f, + 0.646609604358673f, -0.478022634983063f, 0.646242916584015f, -0.478134930133820f, + 0.645876109600067f, -0.478246957063675f, 0.645509302616119f, -0.478358715772629f, + 0.645142316818237f, -0.478470176458359f, 0.644775331020355f, -0.478581339120865f, + 0.644408226013184f, -0.478692263364792f, 0.644041001796722f, -0.478802859783173f, + 0.643673717975616f, -0.478913217782974f, 0.643306374549866f, -0.479023247957230f, + 0.642938911914825f, -0.479133039712906f, 0.642571389675140f, -0.479242533445358f, + 0.642203748226166f, -0.479351729154587f, 0.641836047172546f, -0.479460656642914f, + 0.641468286514282f, -0.479569315910339f, 0.641100406646729f, -0.479677677154541f, + 0.640732467174530f, -0.479785770177841f, 0.640364408493042f, -0.479893565177917f, + 0.639996349811554f, -0.480001062154770f, 0.639628112316132f, -0.480108320713043f, + 0.639259815216064f, -0.480215251445770f, 0.638891458511353f, -0.480321943759918f, + 0.638523042201996f, -0.480428308248520f, 0.638154506683350f, -0.480534434318542f, + 0.637785911560059f, -0.480640232563019f, 0.637417197227478f, -0.480745792388916f, + 0.637048482894897f, -0.480851024389267f, 0.636679589748383f, -0.480956017971039f, + 0.636310696601868f, -0.481060713529587f, 0.635941684246063f, -0.481165111064911f, + 0.635572552680969f, -0.481269240379334f, 0.635203421115875f, -0.481373071670532f, + 0.634834170341492f, -0.481476634740829f, 0.634464859962463f, -0.481579899787903f, + 0.634095430374146f, -0.481682896614075f, 0.633725941181183f, -0.481785595417023f, + 0.633356392383575f, -0.481888025999069f, 0.632986724376678f, -0.481990188360214f, + 0.632616996765137f, -0.482092022895813f, 0.632247209548950f, -0.482193619012833f, + 0.631877362728119f, -0.482294887304306f, 0.631507396697998f, -0.482395917177200f, + 0.631137371063232f, -0.482496619224548f, 0.630767226219177f, -0.482597053050995f, + 0.630397081375122f, -0.482697218656540f, 0.630026817321777f, -0.482797086238861f, + 0.629656434059143f, -0.482896685600281f, 0.629286050796509f, -0.482995986938477f, + 0.628915548324585f, -0.483094990253448f, 0.628544986248016f, -0.483193725347519f, + 0.628174364566803f, -0.483292192220688f, 0.627803623676300f, -0.483390361070633f, + 0.627432823181152f, -0.483488231897354f, 0.627061963081360f, -0.483585834503174f, + 0.626691043376923f, -0.483683139085770f, 0.626320004463196f, -0.483780175447464f, + 0.625948905944824f, -0.483876913785934f, 0.625577747821808f, -0.483973383903503f, + 0.625206530094147f, -0.484069555997849f, 0.624835193157196f, -0.484165430068970f, + 0.624463796615601f, -0.484261035919189f, 0.624092340469360f, -0.484356373548508f, + 0.623720824718475f, -0.484451413154602f, 0.623349189758301f, -0.484546154737473f, + 0.622977554798126f, -0.484640628099442f, 0.622605800628662f, -0.484734803438187f, + 0.622233927249908f, -0.484828680753708f, 0.621862053871155f, -0.484922289848328f, + 0.621490061283112f, -0.485015630722046f, 0.621118068695068f, -0.485108673572540f, + 0.620745956897736f, -0.485201418399811f, 0.620373785495758f, -0.485293895006180f, + 0.620001494884491f, -0.485386073589325f, 0.619629204273224f, -0.485477954149246f, + 0.619256794452667f, -0.485569566488266f, 0.618884325027466f, -0.485660910606384f, + 0.618511795997620f, -0.485751956701279f, 0.618139207363129f, -0.485842704772949f, + 0.617766559123993f, -0.485933154821396f, 0.617393791675568f, -0.486023366451263f, + 0.617020964622498f, -0.486113250255585f, 0.616648077964783f, -0.486202865839005f, + 0.616275131702423f, -0.486292183399200f, 0.615902125835419f, -0.486381232738495f, + 0.615529060363770f, -0.486469984054565f, 0.615155875682831f, -0.486558437347412f, + 0.614782691001892f, -0.486646622419357f, 0.614409387111664f, -0.486734509468079f, + 0.614036023616791f, -0.486822128295898f, 0.613662600517273f, -0.486909449100494f, + 0.613289117813110f, -0.486996471881866f, 0.612915575504303f, -0.487083226442337f, + 0.612541973590851f, -0.487169682979584f, 0.612168252468109f, -0.487255871295929f, + 0.611794531345367f, -0.487341761589050f, 0.611420691013336f, -0.487427353858948f, + 0.611046791076660f, -0.487512677907944f, 0.610672831535339f, -0.487597703933716f, + 0.610298871994019f, -0.487682431936264f, 0.609924793243408f, -0.487766891717911f, + 0.609550595283508f, -0.487851053476334f, 0.609176397323608f, -0.487934947013855f, + 0.608802139759064f, -0.488018542528152f, 0.608427822589874f, -0.488101840019226f, + 0.608053386211395f, -0.488184869289398f, 0.607678949832916f, -0.488267600536346f, + 0.607304394245148f, -0.488350033760071f, 0.606929838657379f, -0.488432198762894f, + 0.606555163860321f, -0.488514065742493f, 0.606180429458618f, -0.488595664501190f, + 0.605805635452271f, -0.488676935434341f, 0.605430841445923f, -0.488757967948914f, + 0.605055928230286f, -0.488838672637939f, 0.604680955410004f, -0.488919109106064f, + 0.604305922985077f, -0.488999247550964f, 0.603930830955505f, -0.489079117774963f, + 0.603555679321289f, -0.489158689975739f, 0.603180468082428f, -0.489237964153290f, + 0.602805197238922f, -0.489316970109940f, 0.602429866790771f, -0.489395678043365f, + 0.602054476737976f, -0.489474087953568f, 0.601679027080536f, -0.489552229642868f, + 0.601303517818451f, -0.489630073308945f, 0.600927948951721f, -0.489707618951797f, + 0.600552320480347f, -0.489784896373749f, 0.600176632404327f, -0.489861875772476f, + 0.599800884723663f, -0.489938557147980f, 0.599425077438354f, -0.490014940500259f, + 0.599049210548401f, -0.490091055631638f, 0.598673284053802f, -0.490166902542114f, + 0.598297297954559f, -0.490242421627045f, 0.597921252250671f, -0.490317672491074f, + 0.597545146942139f, -0.490392625331879f, 0.597168982028961f, -0.490467309951782f, + 0.596792817115784f, -0.490541696548462f, 0.596416532993317f, -0.490615785121918f, + 0.596040189266205f, -0.490689605474472f, 0.595663845539093f, -0.490763127803802f, + 0.595287382602692f, -0.490836352109909f, 0.594910860061646f, -0.490909278392792f, + 0.594534337520599f, -0.490981936454773f, 0.594157755374908f, -0.491054296493530f, + 0.593781054019928f, -0.491126358509064f, 0.593404352664948f, -0.491198152303696f, + 0.593027591705322f, -0.491269648075104f, 0.592650771141052f, -0.491340845823288f, + 0.592273890972137f, -0.491411775350571f, 0.591896951198578f, -0.491482406854630f, + 0.591519951820374f, -0.491552740335464f, 0.591142892837524f, -0.491622805595398f, + 0.590765833854675f, -0.491692543029785f, 0.590388655662537f, -0.491762012243271f, + 0.590011477470398f, -0.491831213235855f, 0.589634180068970f, -0.491900116205215f, + 0.589256882667542f, -0.491968721151352f, 0.588879525661469f, -0.492037028074265f, + 0.588502109050751f, -0.492105036973953f, 0.588124632835388f, -0.492172777652740f, + 0.587747097015381f, -0.492240220308304f, 0.587369561195374f, -0.492307394742966f, + 0.586991965770721f, -0.492374241352081f, 0.586614251136780f, -0.492440819740295f, + 0.586236536502838f, -0.492507129907608f, 0.585858762264252f, -0.492573112249374f, + 0.585480928421021f, -0.492638826370239f, 0.585103094577789f, -0.492704242467880f, + 0.584725141525269f, -0.492769360542297f, 0.584347188472748f, -0.492834210395813f, + 0.583969175815582f, -0.492898762226105f, 0.583591103553772f, -0.492963016033173f, + 0.583212971687317f, -0.493026971817017f, 0.582834780216217f, -0.493090659379959f, + 0.582456588745117f, -0.493154048919678f, 0.582078278064728f, -0.493217140436172f, + 0.581699967384338f, -0.493279963731766f, 0.581321597099304f, -0.493342459201813f, + 0.580943167209625f, -0.493404686450958f, 0.580564737319946f, -0.493466645479202f, + 0.580186247825623f, -0.493528276681900f, 0.579807698726654f, -0.493589639663696f, + 0.579429090023041f, -0.493650704622269f, 0.579050421714783f, -0.493711471557617f, + 0.578671753406525f, -0.493771970272064f, 0.578292965888977f, -0.493832170963287f, + 0.577914178371429f, -0.493892073631287f, 0.577535390853882f, -0.493951678276062f, + 0.577156484127045f, -0.494011014699936f, 0.576777577400208f, -0.494070053100586f, + 0.576398611068726f, -0.494128793478012f, 0.576019585132599f, -0.494187235832214f, + 0.575640499591827f, -0.494245409965515f, 0.575261414051056f, -0.494303256273270f, + 0.574882268905640f, -0.494360834360123f, 0.574503064155579f, -0.494418144226074f, + 0.574123859405518f, -0.494475126266479f, 0.573744535446167f, -0.494531840085983f, + 0.573365211486816f, -0.494588255882263f, 0.572985887527466f, -0.494644373655319f, + 0.572606444358826f, -0.494700223207474f, 0.572227001190186f, -0.494755744934082f, + 0.571847498416901f, -0.494810998439789f, 0.571467995643616f, -0.494865983724594f, + 0.571088373661041f, -0.494920641183853f, 0.570708811283112f, -0.494975030422211f, + 0.570329129695892f, -0.495029091835022f, 0.569949388504028f, -0.495082914829254f, + 0.569569647312164f, -0.495136409997940f, 0.569189906120300f, -0.495189607143402f, + 0.568810045719147f, -0.495242536067963f, 0.568430185317993f, -0.495295166969299f, + 0.568050265312195f, -0.495347499847412f, 0.567670345306396f, -0.495399564504623f, + 0.567290365695953f, -0.495451331138611f, 0.566910326480865f, -0.495502769947052f, + 0.566530287265778f, -0.495553970336914f, 0.566150128841400f, -0.495604842901230f, + 0.565770030021667f, -0.495655417442322f, 0.565389811992645f, -0.495705723762512f, + 0.565009593963623f, -0.495755732059479f, 0.564629375934601f, -0.495805442333221f, + 0.564249038696289f, -0.495854884386063f, 0.563868701457977f, -0.495903998613358f, + 0.563488364219666f, -0.495952844619751f, 0.563107967376709f, -0.496001392602921f, + 0.562727510929108f, -0.496049642562866f, 0.562346994876862f, -0.496097624301910f, + 0.561966478824615f, -0.496145308017731f, 0.561585903167725f, -0.496192663908005f, + 0.561205327510834f, -0.496239781379700f, 0.560824692249298f, -0.496286571025848f, + 0.560444056987762f, -0.496333062648773f, 0.560063362121582f, -0.496379286050797f, + 0.559682607650757f, -0.496425211429596f, 0.559301853179932f, -0.496470838785172f, + 0.558921039104462f, -0.496516168117523f, 0.558540165424347f, -0.496561229228973f, + 0.558159291744232f, -0.496605962514877f, 0.557778418064117f, -0.496650427579880f, + 0.557397484779358f, -0.496694594621658f, 0.557016491889954f, -0.496738493442535f, + 0.556635499000549f, -0.496782064437866f, 0.556254446506500f, -0.496825367212296f, + 0.555873334407806f, -0.496868371963501f, 0.555492222309113f, -0.496911078691483f, + 0.555111110210419f, -0.496953487396240f, 0.554729938507080f, -0.496995598077774f, + 0.554348707199097f, -0.497037440538406f, 0.553967475891113f, -0.497078984975815f, + 0.553586184978485f, -0.497120231389999f, 0.553204894065857f, -0.497161179780960f, + 0.552823603153229f, -0.497201830148697f, 0.552442193031311f, -0.497242212295532f, + 0.552060842514038f, -0.497282296419144f, 0.551679372787476f, -0.497322082519531f, + 0.551297962665558f, -0.497361570596695f, 0.550916433334351f, -0.497400760650635f, + 0.550534904003143f, -0.497439652681351f, 0.550153374671936f, -0.497478276491165f, + 0.549771785736084f, -0.497516602277756f, 0.549390196800232f, -0.497554630041122f, + 0.549008548259735f, -0.497592359781265f, 0.548626899719238f, -0.497629791498184f, + 0.548245191574097f, -0.497666954994202f, 0.547863483428955f, -0.497703820466995f, + 0.547481775283813f, -0.497740387916565f, 0.547099947929382f, -0.497776657342911f, + 0.546718180179596f, -0.497812628746033f, 0.546336352825165f, -0.497848302125931f, + 0.545954465866089f, -0.497883707284927f, 0.545572578907013f, -0.497918814420700f, + 0.545190691947937f, -0.497953623533249f, 0.544808745384216f, -0.497988134622574f, + 0.544426798820496f, -0.498022347688675f, 0.544044792652130f, -0.498056292533875f, + 0.543662786483765f, -0.498089909553528f, 0.543280720710754f, -0.498123258352280f, + 0.542898654937744f, -0.498156309127808f, 0.542516589164734f, -0.498189061880112f, + 0.542134463787079f, -0.498221516609192f, 0.541752278804779f, -0.498253703117371f, + 0.541370153427124f, -0.498285561800003f, 0.540987968444824f, -0.498317152261734f, + 0.540605723857880f, -0.498348444700241f, 0.540223479270935f, -0.498379439115524f, + 0.539841234683990f, -0.498410135507584f, 0.539458930492401f, -0.498440563678741f, + 0.539076626300812f, -0.498470664024353f, 0.538694262504578f, -0.498500496149063f, + 0.538311958312988f, -0.498530030250549f, 0.537929534912109f, -0.498559266328812f, + 0.537547171115875f, -0.498588204383850f, 0.537164747714996f, -0.498616874217987f, + 0.536782264709473f, -0.498645216226578f, 0.536399841308594f, -0.498673290014267f, + 0.536017298698425f, -0.498701065778732f, 0.535634815692902f, -0.498728543519974f, + 0.535252273082733f, -0.498755723237991f, 0.534869730472565f, -0.498782604932785f, + 0.534487187862396f, -0.498809218406677f, 0.534104585647583f, -0.498835533857346f, + 0.533721983432770f, -0.498861521482468f, 0.533339321613312f, -0.498887240886688f, + 0.532956659793854f, -0.498912662267685f, 0.532573997974396f, -0.498937815427780f, + 0.532191336154938f, -0.498962640762329f, 0.531808614730835f, -0.498987197875977f, + 0.531425893306732f, -0.499011427164078f, 0.531043112277985f, -0.499035388231277f, + 0.530660390853882f, -0.499059051275253f, 0.530277609825134f, -0.499082416296005f, + 0.529894769191742f, -0.499105513095856f, 0.529511988162994f, -0.499128282070160f, + 0.529129147529602f, -0.499150782823563f, 0.528746306896210f, -0.499172955751419f, + 0.528363406658173f, -0.499194860458374f, 0.527980506420136f, -0.499216467142105f, + 0.527597606182098f, -0.499237775802612f, 0.527214705944061f, -0.499258816242218f, + 0.526831746101379f, -0.499279528856277f, 0.526448845863342f, -0.499299973249435f, + 0.526065826416016f, -0.499320119619370f, 0.525682866573334f, -0.499339967966080f, + 0.525299847126007f, -0.499359518289566f, 0.524916887283325f, -0.499378770589828f, + 0.524533808231354f, -0.499397724866867f, 0.524150788784027f, -0.499416410923004f, + 0.523767769336700f, -0.499434769153595f, 0.523384690284729f, -0.499452859163284f, + 0.523001611232758f, -0.499470651149750f, 0.522618472576141f, -0.499488145112991f, + 0.522235393524170f, -0.499505341053009f, 0.521852254867554f, -0.499522238969803f, + 0.521469116210938f, -0.499538868665695f, 0.521085977554321f, -0.499555170536041f, + 0.520702838897705f, -0.499571204185486f, 0.520319640636444f, -0.499586939811707f, + 0.519936442375183f, -0.499602377414703f, 0.519553244113922f, -0.499617516994476f, + 0.519170045852661f, -0.499632388353348f, 0.518786847591400f, -0.499646931886673f, + 0.518403589725494f, -0.499661177396774f, 0.518020391464233f, -0.499675154685974f, + 0.517637133598328f, -0.499688833951950f, 0.517253875732422f, -0.499702215194702f, + 0.516870558261871f, -0.499715298414230f, 0.516487300395966f, -0.499728083610535f, + 0.516103982925415f, -0.499740600585938f, 0.515720725059509f, -0.499752789735794f, + 0.515337407588959f, -0.499764710664749f, 0.514954090118408f, -0.499776333570480f, + 0.514570772647858f, -0.499787658452988f, 0.514187395572662f, -0.499798685312271f, + 0.513804078102112f, -0.499809414148331f, 0.513420701026917f, -0.499819844961166f, + 0.513037383556366f, -0.499830007553101f, 0.512654006481171f, -0.499839842319489f, + 0.512270629405975f, -0.499849408864975f, 0.511887252330780f, -0.499858677387238f, + 0.511503815650940f, -0.499867647886276f, 0.511120438575745f, -0.499876320362091f, + 0.510737061500549f, -0.499884694814682f, 0.510353624820709f, -0.499892801046371f, + 0.509970188140869f, -0.499900579452515f, 0.509586811065674f, -0.499908089637756f, + 0.509203374385834f, -0.499915301799774f, 0.508819937705994f, -0.499922215938568f, + 0.508436501026154f, -0.499928832054138f, 0.508053064346313f, -0.499935150146484f, + 0.507669627666473f, -0.499941170215607f, 0.507286131381989f, -0.499946922063828f, + 0.506902694702148f, -0.499952346086502f, 0.506519258022308f, -0.499957501888275f, + 0.506135761737823f, -0.499962359666824f, 0.505752325057983f, -0.499966919422150f, + 0.505368828773499f, -0.499971181154251f, 0.504985332489014f, -0.499975144863129f, + 0.504601895809174f, -0.499978810548782f, 0.504218399524689f, -0.499982208013535f, + 0.503834903240204f, -0.499985307455063f, 0.503451406955719f, -0.499988079071045f, + 0.503067970275879f, -0.499990582466125f, 0.502684473991394f, -0.499992787837982f, + 0.502300977706909f, -0.499994695186615f, 0.501917481422424f, -0.499996334314346f, + 0.501533985137939f, -0.499997645616531f, 0.501150488853455f, -0.499998688697815f, + 0.500766992568970f, -0.499999403953552f, 0.500383496284485f, -0.499999850988388f, +}; + + + +/** +* @brief Initialization function for the floating-point RFFT/RIFFT. +* @deprecated Do not use this function. It has been superceded by \ref arm_rfft_fast_init_f32 and will be removed +* in the future. +* @param[in,out] *S points to an instance of the floating-point RFFT/RIFFT structure. +* @param[in,out] *S_CFFT points to an instance of the floating-point CFFT/CIFFT structure. +* @param[in] fftLenReal length of the FFT. +* @param[in] ifftFlagR flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLenReal is not a supported value. +* +* \par Description: +* \par +* The parameter fftLenReal Specifies length of RFFT/RIFFT Process. Supported FFT Lengths are 128, 512, 2048. +* \par +* The parameter ifftFlagR controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlagR to calculate RIFFT, otherwise RFFT is calculated. +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* This function also initializes Twiddle factor table. +*/ + +/** +* @} end of RealFFT_Table group +*/ + +/** +* @addtogroup RealFFT +* @{ +*/ + +arm_status arm_rfft_init_f32( + arm_rfft_instance_f32 * S, + arm_cfft_radix4_instance_f32 * S_CFFT, + uint32_t fftLenReal, + uint32_t ifftFlagR, + uint32_t bitReverseFlag) +{ + + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initialize the Real FFT length */ + S->fftLenReal = (uint16_t) fftLenReal; + + /* Initialize the Complex FFT length */ + S->fftLenBy2 = (uint16_t) fftLenReal / 2U; + + /* Initialize the Twiddle coefficientA pointer */ + S->pTwiddleAReal = (float32_t *) realCoefA; + + /* Initialize the Twiddle coefficientB pointer */ + S->pTwiddleBReal = (float32_t *) realCoefB; + + /* Initialize the Flag for selection of RFFT or RIFFT */ + S->ifftFlagR = (uint8_t) ifftFlagR; + + /* Initialize the Flag for calculation Bit reversal or not */ + S->bitReverseFlagR = (uint8_t) bitReverseFlag; + + /* Initializations of structure parameters depending on the FFT length */ + switch (S->fftLenReal) + { + /* Init table modifier value */ + case 8192U: + S->twidCoefRModifier = 1U; + break; + case 2048U: + S->twidCoefRModifier = 4U; + break; + case 512U: + S->twidCoefRModifier = 16U; + break; + case 128U: + S->twidCoefRModifier = 64U; + break; + default: + /* Reporting argument error if rfftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + /* Init Complex FFT Instance */ + S->pCfft = S_CFFT; + + if (S->ifftFlagR) + { + /* Initializes the CIFFT Module for fftLenreal/2 length */ + arm_cfft_radix4_init_f32(S->pCfft, S->fftLenBy2, 1U, 0U); + } + else + { + /* Initializes the CFFT Module for fftLenreal/2 length */ + arm_cfft_radix4_init_f32(S->pCfft, S->fftLenBy2, 0U, 0U); + } + + /* return the status of RFFT Init function */ + return (status); + +} + + /** + * @} end of RealFFT group + */ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q15.c new file mode 100644 index 0000000..3d1f229 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q15.c @@ -0,0 +1,2229 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rfft_init_q15.c + * Description: RFFT & RIFFT Q15 initialisation function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" +#include "arm_const_structs.h" + +/** +* @ingroup RealFFT +*/ + +/** + * @addtogroup RealFFT_Table Real FFT Tables +* @{ +*/ + +/** +* \par +* Generation fixed-point realCoefAQ15 array in Q15 format: +* \par +* n = 4096 +*
for (i = 0; i < n; i++)
+*  {
+*    pATable[2 * i] = 0.5 * (1.0 - sin (2 * PI / (double) (2 * n) * (double) i));
+*    pATable[2 * i + 1] = 0.5 * (-1.0 * cos (2 * PI / (double) (2 * n) * (double) i));
+*  } 
+* \par +* Convert to fixed point Q15 format +* round(pATable[i] * pow(2, 15)) +*/ +const q15_t ALIGN4 realCoefAQ15[8192] = { + (q15_t)0x4000, (q15_t)0xc000, (q15_t)0x3ff3, (q15_t)0xc000, (q15_t)0x3fe7, (q15_t)0xc000, (q15_t)0x3fda, (q15_t)0xc000, + (q15_t)0x3fce, (q15_t)0xc000, (q15_t)0x3fc1, (q15_t)0xc000, (q15_t)0x3fb5, (q15_t)0xc000, (q15_t)0x3fa8, (q15_t)0xc000, + (q15_t)0x3f9b, (q15_t)0xc000, (q15_t)0x3f8f, (q15_t)0xc000, (q15_t)0x3f82, (q15_t)0xc000, (q15_t)0x3f76, (q15_t)0xc001, + (q15_t)0x3f69, (q15_t)0xc001, (q15_t)0x3f5d, (q15_t)0xc001, (q15_t)0x3f50, (q15_t)0xc001, (q15_t)0x3f44, (q15_t)0xc001, + (q15_t)0x3f37, (q15_t)0xc001, (q15_t)0x3f2a, (q15_t)0xc001, (q15_t)0x3f1e, (q15_t)0xc002, (q15_t)0x3f11, (q15_t)0xc002, + (q15_t)0x3f05, (q15_t)0xc002, (q15_t)0x3ef8, (q15_t)0xc002, (q15_t)0x3eec, (q15_t)0xc002, (q15_t)0x3edf, (q15_t)0xc003, + (q15_t)0x3ed2, (q15_t)0xc003, (q15_t)0x3ec6, (q15_t)0xc003, (q15_t)0x3eb9, (q15_t)0xc003, (q15_t)0x3ead, (q15_t)0xc004, + (q15_t)0x3ea0, (q15_t)0xc004, (q15_t)0x3e94, (q15_t)0xc004, (q15_t)0x3e87, (q15_t)0xc004, (q15_t)0x3e7a, (q15_t)0xc005, + (q15_t)0x3e6e, (q15_t)0xc005, (q15_t)0x3e61, (q15_t)0xc005, (q15_t)0x3e55, (q15_t)0xc006, (q15_t)0x3e48, (q15_t)0xc006, + (q15_t)0x3e3c, (q15_t)0xc006, (q15_t)0x3e2f, (q15_t)0xc007, (q15_t)0x3e23, (q15_t)0xc007, (q15_t)0x3e16, (q15_t)0xc007, + (q15_t)0x3e09, (q15_t)0xc008, (q15_t)0x3dfd, (q15_t)0xc008, (q15_t)0x3df0, (q15_t)0xc009, (q15_t)0x3de4, (q15_t)0xc009, + (q15_t)0x3dd7, (q15_t)0xc009, (q15_t)0x3dcb, (q15_t)0xc00a, (q15_t)0x3dbe, (q15_t)0xc00a, (q15_t)0x3db2, (q15_t)0xc00b, + (q15_t)0x3da5, (q15_t)0xc00b, (q15_t)0x3d98, (q15_t)0xc00c, (q15_t)0x3d8c, (q15_t)0xc00c, (q15_t)0x3d7f, (q15_t)0xc00d, + (q15_t)0x3d73, (q15_t)0xc00d, (q15_t)0x3d66, (q15_t)0xc00e, (q15_t)0x3d5a, (q15_t)0xc00e, (q15_t)0x3d4d, (q15_t)0xc00f, + (q15_t)0x3d40, (q15_t)0xc00f, (q15_t)0x3d34, (q15_t)0xc010, (q15_t)0x3d27, (q15_t)0xc010, (q15_t)0x3d1b, (q15_t)0xc011, + (q15_t)0x3d0e, (q15_t)0xc011, (q15_t)0x3d02, (q15_t)0xc012, (q15_t)0x3cf5, (q15_t)0xc013, (q15_t)0x3ce9, (q15_t)0xc013, + (q15_t)0x3cdc, (q15_t)0xc014, (q15_t)0x3cd0, (q15_t)0xc014, (q15_t)0x3cc3, (q15_t)0xc015, (q15_t)0x3cb6, (q15_t)0xc016, + (q15_t)0x3caa, (q15_t)0xc016, (q15_t)0x3c9d, (q15_t)0xc017, (q15_t)0x3c91, (q15_t)0xc018, (q15_t)0x3c84, (q15_t)0xc018, + (q15_t)0x3c78, (q15_t)0xc019, (q15_t)0x3c6b, (q15_t)0xc01a, (q15_t)0x3c5f, (q15_t)0xc01a, (q15_t)0x3c52, (q15_t)0xc01b, + (q15_t)0x3c45, (q15_t)0xc01c, (q15_t)0x3c39, (q15_t)0xc01d, (q15_t)0x3c2c, (q15_t)0xc01d, (q15_t)0x3c20, (q15_t)0xc01e, + (q15_t)0x3c13, (q15_t)0xc01f, (q15_t)0x3c07, (q15_t)0xc020, (q15_t)0x3bfa, (q15_t)0xc020, (q15_t)0x3bee, (q15_t)0xc021, + (q15_t)0x3be1, (q15_t)0xc022, (q15_t)0x3bd5, (q15_t)0xc023, (q15_t)0x3bc8, (q15_t)0xc024, (q15_t)0x3bbc, (q15_t)0xc024, + (q15_t)0x3baf, (q15_t)0xc025, (q15_t)0x3ba2, (q15_t)0xc026, (q15_t)0x3b96, (q15_t)0xc027, (q15_t)0x3b89, (q15_t)0xc028, + (q15_t)0x3b7d, (q15_t)0xc029, (q15_t)0x3b70, (q15_t)0xc02a, (q15_t)0x3b64, (q15_t)0xc02b, (q15_t)0x3b57, (q15_t)0xc02b, + (q15_t)0x3b4b, (q15_t)0xc02c, (q15_t)0x3b3e, (q15_t)0xc02d, (q15_t)0x3b32, (q15_t)0xc02e, (q15_t)0x3b25, (q15_t)0xc02f, + (q15_t)0x3b19, (q15_t)0xc030, (q15_t)0x3b0c, (q15_t)0xc031, (q15_t)0x3b00, (q15_t)0xc032, (q15_t)0x3af3, (q15_t)0xc033, + (q15_t)0x3ae6, (q15_t)0xc034, (q15_t)0x3ada, (q15_t)0xc035, (q15_t)0x3acd, (q15_t)0xc036, (q15_t)0x3ac1, (q15_t)0xc037, + (q15_t)0x3ab4, (q15_t)0xc038, (q15_t)0x3aa8, (q15_t)0xc039, (q15_t)0x3a9b, (q15_t)0xc03a, (q15_t)0x3a8f, (q15_t)0xc03b, + (q15_t)0x3a82, (q15_t)0xc03c, (q15_t)0x3a76, (q15_t)0xc03d, (q15_t)0x3a69, (q15_t)0xc03f, (q15_t)0x3a5d, (q15_t)0xc040, + (q15_t)0x3a50, (q15_t)0xc041, (q15_t)0x3a44, (q15_t)0xc042, (q15_t)0x3a37, (q15_t)0xc043, (q15_t)0x3a2b, (q15_t)0xc044, + (q15_t)0x3a1e, (q15_t)0xc045, (q15_t)0x3a12, (q15_t)0xc047, (q15_t)0x3a05, (q15_t)0xc048, (q15_t)0x39f9, (q15_t)0xc049, + (q15_t)0x39ec, (q15_t)0xc04a, (q15_t)0x39e0, (q15_t)0xc04b, (q15_t)0x39d3, (q15_t)0xc04c, (q15_t)0x39c7, (q15_t)0xc04e, + (q15_t)0x39ba, (q15_t)0xc04f, (q15_t)0x39ae, (q15_t)0xc050, (q15_t)0x39a1, (q15_t)0xc051, (q15_t)0x3995, (q15_t)0xc053, + (q15_t)0x3988, (q15_t)0xc054, (q15_t)0x397c, (q15_t)0xc055, (q15_t)0x396f, (q15_t)0xc056, (q15_t)0x3963, (q15_t)0xc058, + (q15_t)0x3956, (q15_t)0xc059, (q15_t)0x394a, (q15_t)0xc05a, (q15_t)0x393d, (q15_t)0xc05c, (q15_t)0x3931, (q15_t)0xc05d, + (q15_t)0x3924, (q15_t)0xc05e, (q15_t)0x3918, (q15_t)0xc060, (q15_t)0x390b, (q15_t)0xc061, (q15_t)0x38ff, (q15_t)0xc062, + (q15_t)0x38f2, (q15_t)0xc064, (q15_t)0x38e6, (q15_t)0xc065, (q15_t)0x38d9, (q15_t)0xc067, (q15_t)0x38cd, (q15_t)0xc068, + (q15_t)0x38c0, (q15_t)0xc069, (q15_t)0x38b4, (q15_t)0xc06b, (q15_t)0x38a7, (q15_t)0xc06c, (q15_t)0x389b, (q15_t)0xc06e, + (q15_t)0x388e, (q15_t)0xc06f, (q15_t)0x3882, (q15_t)0xc071, (q15_t)0x3875, (q15_t)0xc072, (q15_t)0x3869, (q15_t)0xc074, + (q15_t)0x385c, (q15_t)0xc075, (q15_t)0x3850, (q15_t)0xc077, (q15_t)0x3843, (q15_t)0xc078, (q15_t)0x3837, (q15_t)0xc07a, + (q15_t)0x382a, (q15_t)0xc07b, (q15_t)0x381e, (q15_t)0xc07d, (q15_t)0x3811, (q15_t)0xc07e, (q15_t)0x3805, (q15_t)0xc080, + (q15_t)0x37f9, (q15_t)0xc081, (q15_t)0x37ec, (q15_t)0xc083, (q15_t)0x37e0, (q15_t)0xc085, (q15_t)0x37d3, (q15_t)0xc086, + (q15_t)0x37c7, (q15_t)0xc088, (q15_t)0x37ba, (q15_t)0xc089, (q15_t)0x37ae, (q15_t)0xc08b, (q15_t)0x37a1, (q15_t)0xc08d, + (q15_t)0x3795, (q15_t)0xc08e, (q15_t)0x3788, (q15_t)0xc090, (q15_t)0x377c, (q15_t)0xc092, (q15_t)0x376f, (q15_t)0xc093, + (q15_t)0x3763, (q15_t)0xc095, (q15_t)0x3757, (q15_t)0xc097, (q15_t)0x374a, (q15_t)0xc098, (q15_t)0x373e, (q15_t)0xc09a, + (q15_t)0x3731, (q15_t)0xc09c, (q15_t)0x3725, (q15_t)0xc09e, (q15_t)0x3718, (q15_t)0xc09f, (q15_t)0x370c, (q15_t)0xc0a1, + (q15_t)0x36ff, (q15_t)0xc0a3, (q15_t)0x36f3, (q15_t)0xc0a5, (q15_t)0x36e7, (q15_t)0xc0a6, (q15_t)0x36da, (q15_t)0xc0a8, + (q15_t)0x36ce, (q15_t)0xc0aa, (q15_t)0x36c1, (q15_t)0xc0ac, (q15_t)0x36b5, (q15_t)0xc0ae, (q15_t)0x36a8, (q15_t)0xc0af, + (q15_t)0x369c, (q15_t)0xc0b1, (q15_t)0x3690, (q15_t)0xc0b3, (q15_t)0x3683, (q15_t)0xc0b5, (q15_t)0x3677, (q15_t)0xc0b7, + (q15_t)0x366a, (q15_t)0xc0b9, (q15_t)0x365e, (q15_t)0xc0bb, (q15_t)0x3651, (q15_t)0xc0bd, (q15_t)0x3645, (q15_t)0xc0be, + (q15_t)0x3639, (q15_t)0xc0c0, (q15_t)0x362c, (q15_t)0xc0c2, (q15_t)0x3620, (q15_t)0xc0c4, (q15_t)0x3613, (q15_t)0xc0c6, + (q15_t)0x3607, (q15_t)0xc0c8, (q15_t)0x35fa, (q15_t)0xc0ca, (q15_t)0x35ee, (q15_t)0xc0cc, (q15_t)0x35e2, (q15_t)0xc0ce, + (q15_t)0x35d5, (q15_t)0xc0d0, (q15_t)0x35c9, (q15_t)0xc0d2, (q15_t)0x35bc, (q15_t)0xc0d4, (q15_t)0x35b0, (q15_t)0xc0d6, + (q15_t)0x35a4, (q15_t)0xc0d8, (q15_t)0x3597, (q15_t)0xc0da, (q15_t)0x358b, (q15_t)0xc0dc, (q15_t)0x357e, (q15_t)0xc0de, + (q15_t)0x3572, (q15_t)0xc0e0, (q15_t)0x3566, (q15_t)0xc0e2, (q15_t)0x3559, (q15_t)0xc0e4, (q15_t)0x354d, (q15_t)0xc0e7, + (q15_t)0x3540, (q15_t)0xc0e9, (q15_t)0x3534, (q15_t)0xc0eb, (q15_t)0x3528, (q15_t)0xc0ed, (q15_t)0x351b, (q15_t)0xc0ef, + (q15_t)0x350f, (q15_t)0xc0f1, (q15_t)0x3503, (q15_t)0xc0f3, (q15_t)0x34f6, (q15_t)0xc0f6, (q15_t)0x34ea, (q15_t)0xc0f8, + (q15_t)0x34dd, (q15_t)0xc0fa, (q15_t)0x34d1, (q15_t)0xc0fc, (q15_t)0x34c5, (q15_t)0xc0fe, (q15_t)0x34b8, (q15_t)0xc100, + (q15_t)0x34ac, (q15_t)0xc103, (q15_t)0x34a0, (q15_t)0xc105, (q15_t)0x3493, (q15_t)0xc107, (q15_t)0x3487, (q15_t)0xc109, + (q15_t)0x347b, (q15_t)0xc10c, (q15_t)0x346e, (q15_t)0xc10e, (q15_t)0x3462, (q15_t)0xc110, (q15_t)0x3455, (q15_t)0xc113, + (q15_t)0x3449, (q15_t)0xc115, (q15_t)0x343d, (q15_t)0xc117, (q15_t)0x3430, (q15_t)0xc119, (q15_t)0x3424, (q15_t)0xc11c, + (q15_t)0x3418, (q15_t)0xc11e, (q15_t)0x340b, (q15_t)0xc120, (q15_t)0x33ff, (q15_t)0xc123, (q15_t)0x33f3, (q15_t)0xc125, + (q15_t)0x33e6, (q15_t)0xc128, (q15_t)0x33da, (q15_t)0xc12a, (q15_t)0x33ce, (q15_t)0xc12c, (q15_t)0x33c1, (q15_t)0xc12f, + (q15_t)0x33b5, (q15_t)0xc131, (q15_t)0x33a9, (q15_t)0xc134, (q15_t)0x339c, (q15_t)0xc136, (q15_t)0x3390, (q15_t)0xc138, + (q15_t)0x3384, (q15_t)0xc13b, (q15_t)0x3377, (q15_t)0xc13d, (q15_t)0x336b, (q15_t)0xc140, (q15_t)0x335f, (q15_t)0xc142, + (q15_t)0x3352, (q15_t)0xc145, (q15_t)0x3346, (q15_t)0xc147, (q15_t)0x333a, (q15_t)0xc14a, (q15_t)0x332d, (q15_t)0xc14c, + (q15_t)0x3321, (q15_t)0xc14f, (q15_t)0x3315, (q15_t)0xc151, (q15_t)0x3308, (q15_t)0xc154, (q15_t)0x32fc, (q15_t)0xc156, + (q15_t)0x32f0, (q15_t)0xc159, (q15_t)0x32e4, (q15_t)0xc15b, (q15_t)0x32d7, (q15_t)0xc15e, (q15_t)0x32cb, (q15_t)0xc161, + (q15_t)0x32bf, (q15_t)0xc163, (q15_t)0x32b2, (q15_t)0xc166, (q15_t)0x32a6, (q15_t)0xc168, (q15_t)0x329a, (q15_t)0xc16b, + (q15_t)0x328e, (q15_t)0xc16e, (q15_t)0x3281, (q15_t)0xc170, (q15_t)0x3275, (q15_t)0xc173, (q15_t)0x3269, (q15_t)0xc176, + (q15_t)0x325c, (q15_t)0xc178, (q15_t)0x3250, (q15_t)0xc17b, (q15_t)0x3244, (q15_t)0xc17e, (q15_t)0x3238, (q15_t)0xc180, + (q15_t)0x322b, (q15_t)0xc183, (q15_t)0x321f, (q15_t)0xc186, (q15_t)0x3213, (q15_t)0xc189, (q15_t)0x3207, (q15_t)0xc18b, + (q15_t)0x31fa, (q15_t)0xc18e, (q15_t)0x31ee, (q15_t)0xc191, (q15_t)0x31e2, (q15_t)0xc194, (q15_t)0x31d5, (q15_t)0xc196, + (q15_t)0x31c9, (q15_t)0xc199, (q15_t)0x31bd, (q15_t)0xc19c, (q15_t)0x31b1, (q15_t)0xc19f, (q15_t)0x31a4, (q15_t)0xc1a2, + (q15_t)0x3198, (q15_t)0xc1a4, (q15_t)0x318c, (q15_t)0xc1a7, (q15_t)0x3180, (q15_t)0xc1aa, (q15_t)0x3174, (q15_t)0xc1ad, + (q15_t)0x3167, (q15_t)0xc1b0, (q15_t)0x315b, (q15_t)0xc1b3, (q15_t)0x314f, (q15_t)0xc1b6, (q15_t)0x3143, (q15_t)0xc1b8, + (q15_t)0x3136, (q15_t)0xc1bb, (q15_t)0x312a, (q15_t)0xc1be, (q15_t)0x311e, (q15_t)0xc1c1, (q15_t)0x3112, (q15_t)0xc1c4, + (q15_t)0x3105, (q15_t)0xc1c7, (q15_t)0x30f9, (q15_t)0xc1ca, (q15_t)0x30ed, (q15_t)0xc1cd, (q15_t)0x30e1, (q15_t)0xc1d0, + (q15_t)0x30d5, (q15_t)0xc1d3, (q15_t)0x30c8, (q15_t)0xc1d6, (q15_t)0x30bc, (q15_t)0xc1d9, (q15_t)0x30b0, (q15_t)0xc1dc, + (q15_t)0x30a4, (q15_t)0xc1df, (q15_t)0x3098, (q15_t)0xc1e2, (q15_t)0x308b, (q15_t)0xc1e5, (q15_t)0x307f, (q15_t)0xc1e8, + (q15_t)0x3073, (q15_t)0xc1eb, (q15_t)0x3067, (q15_t)0xc1ee, (q15_t)0x305b, (q15_t)0xc1f1, (q15_t)0x304e, (q15_t)0xc1f4, + (q15_t)0x3042, (q15_t)0xc1f7, (q15_t)0x3036, (q15_t)0xc1fa, (q15_t)0x302a, (q15_t)0xc1fd, (q15_t)0x301e, (q15_t)0xc201, + (q15_t)0x3012, (q15_t)0xc204, (q15_t)0x3005, (q15_t)0xc207, (q15_t)0x2ff9, (q15_t)0xc20a, (q15_t)0x2fed, (q15_t)0xc20d, + (q15_t)0x2fe1, (q15_t)0xc210, (q15_t)0x2fd5, (q15_t)0xc213, (q15_t)0x2fc9, (q15_t)0xc217, (q15_t)0x2fbc, (q15_t)0xc21a, + (q15_t)0x2fb0, (q15_t)0xc21d, (q15_t)0x2fa4, (q15_t)0xc220, (q15_t)0x2f98, (q15_t)0xc223, (q15_t)0x2f8c, (q15_t)0xc227, + (q15_t)0x2f80, (q15_t)0xc22a, (q15_t)0x2f74, (q15_t)0xc22d, (q15_t)0x2f67, (q15_t)0xc230, (q15_t)0x2f5b, (q15_t)0xc234, + (q15_t)0x2f4f, (q15_t)0xc237, (q15_t)0x2f43, (q15_t)0xc23a, (q15_t)0x2f37, (q15_t)0xc23e, (q15_t)0x2f2b, (q15_t)0xc241, + (q15_t)0x2f1f, (q15_t)0xc244, (q15_t)0x2f13, (q15_t)0xc247, (q15_t)0x2f06, (q15_t)0xc24b, (q15_t)0x2efa, (q15_t)0xc24e, + (q15_t)0x2eee, (q15_t)0xc251, (q15_t)0x2ee2, (q15_t)0xc255, (q15_t)0x2ed6, (q15_t)0xc258, (q15_t)0x2eca, (q15_t)0xc25c, + (q15_t)0x2ebe, (q15_t)0xc25f, (q15_t)0x2eb2, (q15_t)0xc262, (q15_t)0x2ea6, (q15_t)0xc266, (q15_t)0x2e99, (q15_t)0xc269, + (q15_t)0x2e8d, (q15_t)0xc26d, (q15_t)0x2e81, (q15_t)0xc270, (q15_t)0x2e75, (q15_t)0xc273, (q15_t)0x2e69, (q15_t)0xc277, + (q15_t)0x2e5d, (q15_t)0xc27a, (q15_t)0x2e51, (q15_t)0xc27e, (q15_t)0x2e45, (q15_t)0xc281, (q15_t)0x2e39, (q15_t)0xc285, + (q15_t)0x2e2d, (q15_t)0xc288, (q15_t)0x2e21, (q15_t)0xc28c, (q15_t)0x2e15, (q15_t)0xc28f, (q15_t)0x2e09, (q15_t)0xc293, + (q15_t)0x2dfc, (q15_t)0xc296, (q15_t)0x2df0, (q15_t)0xc29a, (q15_t)0x2de4, (q15_t)0xc29d, (q15_t)0x2dd8, (q15_t)0xc2a1, + (q15_t)0x2dcc, (q15_t)0xc2a5, (q15_t)0x2dc0, (q15_t)0xc2a8, (q15_t)0x2db4, (q15_t)0xc2ac, (q15_t)0x2da8, (q15_t)0xc2af, + (q15_t)0x2d9c, (q15_t)0xc2b3, (q15_t)0x2d90, (q15_t)0xc2b7, (q15_t)0x2d84, (q15_t)0xc2ba, (q15_t)0x2d78, (q15_t)0xc2be, + (q15_t)0x2d6c, (q15_t)0xc2c1, (q15_t)0x2d60, (q15_t)0xc2c5, (q15_t)0x2d54, (q15_t)0xc2c9, (q15_t)0x2d48, (q15_t)0xc2cc, + (q15_t)0x2d3c, (q15_t)0xc2d0, (q15_t)0x2d30, (q15_t)0xc2d4, (q15_t)0x2d24, (q15_t)0xc2d8, (q15_t)0x2d18, (q15_t)0xc2db, + (q15_t)0x2d0c, (q15_t)0xc2df, (q15_t)0x2d00, (q15_t)0xc2e3, (q15_t)0x2cf4, (q15_t)0xc2e6, (q15_t)0x2ce8, (q15_t)0xc2ea, + (q15_t)0x2cdc, (q15_t)0xc2ee, (q15_t)0x2cd0, (q15_t)0xc2f2, (q15_t)0x2cc4, (q15_t)0xc2f5, (q15_t)0x2cb8, (q15_t)0xc2f9, + (q15_t)0x2cac, (q15_t)0xc2fd, (q15_t)0x2ca0, (q15_t)0xc301, (q15_t)0x2c94, (q15_t)0xc305, (q15_t)0x2c88, (q15_t)0xc308, + (q15_t)0x2c7c, (q15_t)0xc30c, (q15_t)0x2c70, (q15_t)0xc310, (q15_t)0x2c64, (q15_t)0xc314, (q15_t)0x2c58, (q15_t)0xc318, + (q15_t)0x2c4c, (q15_t)0xc31c, (q15_t)0x2c40, (q15_t)0xc320, (q15_t)0x2c34, (q15_t)0xc323, (q15_t)0x2c28, (q15_t)0xc327, + (q15_t)0x2c1c, (q15_t)0xc32b, (q15_t)0x2c10, (q15_t)0xc32f, (q15_t)0x2c05, (q15_t)0xc333, (q15_t)0x2bf9, (q15_t)0xc337, + (q15_t)0x2bed, (q15_t)0xc33b, (q15_t)0x2be1, (q15_t)0xc33f, (q15_t)0x2bd5, (q15_t)0xc343, (q15_t)0x2bc9, (q15_t)0xc347, + (q15_t)0x2bbd, (q15_t)0xc34b, (q15_t)0x2bb1, (q15_t)0xc34f, (q15_t)0x2ba5, (q15_t)0xc353, (q15_t)0x2b99, (q15_t)0xc357, + (q15_t)0x2b8d, (q15_t)0xc35b, (q15_t)0x2b81, (q15_t)0xc35f, (q15_t)0x2b75, (q15_t)0xc363, (q15_t)0x2b6a, (q15_t)0xc367, + (q15_t)0x2b5e, (q15_t)0xc36b, (q15_t)0x2b52, (q15_t)0xc36f, (q15_t)0x2b46, (q15_t)0xc373, (q15_t)0x2b3a, (q15_t)0xc377, + (q15_t)0x2b2e, (q15_t)0xc37b, (q15_t)0x2b22, (q15_t)0xc37f, (q15_t)0x2b16, (q15_t)0xc383, (q15_t)0x2b0a, (q15_t)0xc387, + (q15_t)0x2aff, (q15_t)0xc38c, (q15_t)0x2af3, (q15_t)0xc390, (q15_t)0x2ae7, (q15_t)0xc394, (q15_t)0x2adb, (q15_t)0xc398, + (q15_t)0x2acf, (q15_t)0xc39c, (q15_t)0x2ac3, (q15_t)0xc3a0, (q15_t)0x2ab7, (q15_t)0xc3a5, (q15_t)0x2aac, (q15_t)0xc3a9, + (q15_t)0x2aa0, (q15_t)0xc3ad, (q15_t)0x2a94, (q15_t)0xc3b1, (q15_t)0x2a88, (q15_t)0xc3b5, (q15_t)0x2a7c, (q15_t)0xc3ba, + (q15_t)0x2a70, (q15_t)0xc3be, (q15_t)0x2a65, (q15_t)0xc3c2, (q15_t)0x2a59, (q15_t)0xc3c6, (q15_t)0x2a4d, (q15_t)0xc3ca, + (q15_t)0x2a41, (q15_t)0xc3cf, (q15_t)0x2a35, (q15_t)0xc3d3, (q15_t)0x2a29, (q15_t)0xc3d7, (q15_t)0x2a1e, (q15_t)0xc3dc, + (q15_t)0x2a12, (q15_t)0xc3e0, (q15_t)0x2a06, (q15_t)0xc3e4, (q15_t)0x29fa, (q15_t)0xc3e9, (q15_t)0x29ee, (q15_t)0xc3ed, + (q15_t)0x29e3, (q15_t)0xc3f1, (q15_t)0x29d7, (q15_t)0xc3f6, (q15_t)0x29cb, (q15_t)0xc3fa, (q15_t)0x29bf, (q15_t)0xc3fe, + (q15_t)0x29b4, (q15_t)0xc403, (q15_t)0x29a8, (q15_t)0xc407, (q15_t)0x299c, (q15_t)0xc40b, (q15_t)0x2990, (q15_t)0xc410, + (q15_t)0x2984, (q15_t)0xc414, (q15_t)0x2979, (q15_t)0xc419, (q15_t)0x296d, (q15_t)0xc41d, (q15_t)0x2961, (q15_t)0xc422, + (q15_t)0x2955, (q15_t)0xc426, (q15_t)0x294a, (q15_t)0xc42a, (q15_t)0x293e, (q15_t)0xc42f, (q15_t)0x2932, (q15_t)0xc433, + (q15_t)0x2926, (q15_t)0xc438, (q15_t)0x291b, (q15_t)0xc43c, (q15_t)0x290f, (q15_t)0xc441, (q15_t)0x2903, (q15_t)0xc445, + (q15_t)0x28f7, (q15_t)0xc44a, (q15_t)0x28ec, (q15_t)0xc44e, (q15_t)0x28e0, (q15_t)0xc453, (q15_t)0x28d4, (q15_t)0xc457, + (q15_t)0x28c9, (q15_t)0xc45c, (q15_t)0x28bd, (q15_t)0xc461, (q15_t)0x28b1, (q15_t)0xc465, (q15_t)0x28a5, (q15_t)0xc46a, + (q15_t)0x289a, (q15_t)0xc46e, (q15_t)0x288e, (q15_t)0xc473, (q15_t)0x2882, (q15_t)0xc478, (q15_t)0x2877, (q15_t)0xc47c, + (q15_t)0x286b, (q15_t)0xc481, (q15_t)0x285f, (q15_t)0xc485, (q15_t)0x2854, (q15_t)0xc48a, (q15_t)0x2848, (q15_t)0xc48f, + (q15_t)0x283c, (q15_t)0xc493, (q15_t)0x2831, (q15_t)0xc498, (q15_t)0x2825, (q15_t)0xc49d, (q15_t)0x2819, (q15_t)0xc4a1, + (q15_t)0x280e, (q15_t)0xc4a6, (q15_t)0x2802, (q15_t)0xc4ab, (q15_t)0x27f6, (q15_t)0xc4b0, (q15_t)0x27eb, (q15_t)0xc4b4, + (q15_t)0x27df, (q15_t)0xc4b9, (q15_t)0x27d3, (q15_t)0xc4be, (q15_t)0x27c8, (q15_t)0xc4c2, (q15_t)0x27bc, (q15_t)0xc4c7, + (q15_t)0x27b1, (q15_t)0xc4cc, (q15_t)0x27a5, (q15_t)0xc4d1, (q15_t)0x2799, (q15_t)0xc4d6, (q15_t)0x278e, (q15_t)0xc4da, + (q15_t)0x2782, (q15_t)0xc4df, (q15_t)0x2777, (q15_t)0xc4e4, (q15_t)0x276b, (q15_t)0xc4e9, (q15_t)0x275f, (q15_t)0xc4ee, + (q15_t)0x2754, (q15_t)0xc4f2, (q15_t)0x2748, (q15_t)0xc4f7, (q15_t)0x273d, (q15_t)0xc4fc, (q15_t)0x2731, (q15_t)0xc501, + (q15_t)0x2725, (q15_t)0xc506, (q15_t)0x271a, (q15_t)0xc50b, (q15_t)0x270e, (q15_t)0xc510, (q15_t)0x2703, (q15_t)0xc515, + (q15_t)0x26f7, (q15_t)0xc51a, (q15_t)0x26ec, (q15_t)0xc51e, (q15_t)0x26e0, (q15_t)0xc523, (q15_t)0x26d4, (q15_t)0xc528, + (q15_t)0x26c9, (q15_t)0xc52d, (q15_t)0x26bd, (q15_t)0xc532, (q15_t)0x26b2, (q15_t)0xc537, (q15_t)0x26a6, (q15_t)0xc53c, + (q15_t)0x269b, (q15_t)0xc541, (q15_t)0x268f, (q15_t)0xc546, (q15_t)0x2684, (q15_t)0xc54b, (q15_t)0x2678, (q15_t)0xc550, + (q15_t)0x266d, (q15_t)0xc555, (q15_t)0x2661, (q15_t)0xc55a, (q15_t)0x2656, (q15_t)0xc55f, (q15_t)0x264a, (q15_t)0xc564, + (q15_t)0x263f, (q15_t)0xc569, (q15_t)0x2633, (q15_t)0xc56e, (q15_t)0x2628, (q15_t)0xc573, (q15_t)0x261c, (q15_t)0xc578, + (q15_t)0x2611, (q15_t)0xc57e, (q15_t)0x2605, (q15_t)0xc583, (q15_t)0x25fa, (q15_t)0xc588, (q15_t)0x25ee, (q15_t)0xc58d, + (q15_t)0x25e3, (q15_t)0xc592, (q15_t)0x25d7, (q15_t)0xc597, (q15_t)0x25cc, (q15_t)0xc59c, (q15_t)0x25c0, (q15_t)0xc5a1, + (q15_t)0x25b5, (q15_t)0xc5a7, (q15_t)0x25a9, (q15_t)0xc5ac, (q15_t)0x259e, (q15_t)0xc5b1, (q15_t)0x2592, (q15_t)0xc5b6, + (q15_t)0x2587, (q15_t)0xc5bb, (q15_t)0x257c, (q15_t)0xc5c1, (q15_t)0x2570, (q15_t)0xc5c6, (q15_t)0x2565, (q15_t)0xc5cb, + (q15_t)0x2559, (q15_t)0xc5d0, (q15_t)0x254e, (q15_t)0xc5d5, (q15_t)0x2542, (q15_t)0xc5db, (q15_t)0x2537, (q15_t)0xc5e0, + (q15_t)0x252c, (q15_t)0xc5e5, (q15_t)0x2520, (q15_t)0xc5ea, (q15_t)0x2515, (q15_t)0xc5f0, (q15_t)0x2509, (q15_t)0xc5f5, + (q15_t)0x24fe, (q15_t)0xc5fa, (q15_t)0x24f3, (q15_t)0xc600, (q15_t)0x24e7, (q15_t)0xc605, (q15_t)0x24dc, (q15_t)0xc60a, + (q15_t)0x24d0, (q15_t)0xc610, (q15_t)0x24c5, (q15_t)0xc615, (q15_t)0x24ba, (q15_t)0xc61a, (q15_t)0x24ae, (q15_t)0xc620, + (q15_t)0x24a3, (q15_t)0xc625, (q15_t)0x2498, (q15_t)0xc62a, (q15_t)0x248c, (q15_t)0xc630, (q15_t)0x2481, (q15_t)0xc635, + (q15_t)0x2476, (q15_t)0xc63b, (q15_t)0x246a, (q15_t)0xc640, (q15_t)0x245f, (q15_t)0xc645, (q15_t)0x2454, (q15_t)0xc64b, + (q15_t)0x2448, (q15_t)0xc650, (q15_t)0x243d, (q15_t)0xc656, (q15_t)0x2432, (q15_t)0xc65b, (q15_t)0x2426, (q15_t)0xc661, + (q15_t)0x241b, (q15_t)0xc666, (q15_t)0x2410, (q15_t)0xc66c, (q15_t)0x2404, (q15_t)0xc671, (q15_t)0x23f9, (q15_t)0xc677, + (q15_t)0x23ee, (q15_t)0xc67c, (q15_t)0x23e2, (q15_t)0xc682, (q15_t)0x23d7, (q15_t)0xc687, (q15_t)0x23cc, (q15_t)0xc68d, + (q15_t)0x23c1, (q15_t)0xc692, (q15_t)0x23b5, (q15_t)0xc698, (q15_t)0x23aa, (q15_t)0xc69d, (q15_t)0x239f, (q15_t)0xc6a3, + (q15_t)0x2394, (q15_t)0xc6a8, (q15_t)0x2388, (q15_t)0xc6ae, (q15_t)0x237d, (q15_t)0xc6b4, (q15_t)0x2372, (q15_t)0xc6b9, + (q15_t)0x2367, (q15_t)0xc6bf, (q15_t)0x235b, (q15_t)0xc6c5, (q15_t)0x2350, (q15_t)0xc6ca, (q15_t)0x2345, (q15_t)0xc6d0, + (q15_t)0x233a, (q15_t)0xc6d5, (q15_t)0x232e, (q15_t)0xc6db, (q15_t)0x2323, (q15_t)0xc6e1, (q15_t)0x2318, (q15_t)0xc6e6, + (q15_t)0x230d, (q15_t)0xc6ec, (q15_t)0x2301, (q15_t)0xc6f2, (q15_t)0x22f6, (q15_t)0xc6f7, (q15_t)0x22eb, (q15_t)0xc6fd, + (q15_t)0x22e0, (q15_t)0xc703, (q15_t)0x22d5, (q15_t)0xc709, (q15_t)0x22ca, (q15_t)0xc70e, (q15_t)0x22be, (q15_t)0xc714, + (q15_t)0x22b3, (q15_t)0xc71a, (q15_t)0x22a8, (q15_t)0xc720, (q15_t)0x229d, (q15_t)0xc725, (q15_t)0x2292, (q15_t)0xc72b, + (q15_t)0x2287, (q15_t)0xc731, (q15_t)0x227b, (q15_t)0xc737, (q15_t)0x2270, (q15_t)0xc73d, (q15_t)0x2265, (q15_t)0xc742, + (q15_t)0x225a, (q15_t)0xc748, (q15_t)0x224f, (q15_t)0xc74e, (q15_t)0x2244, (q15_t)0xc754, (q15_t)0x2239, (q15_t)0xc75a, + (q15_t)0x222d, (q15_t)0xc75f, (q15_t)0x2222, (q15_t)0xc765, (q15_t)0x2217, (q15_t)0xc76b, (q15_t)0x220c, (q15_t)0xc771, + (q15_t)0x2201, (q15_t)0xc777, (q15_t)0x21f6, (q15_t)0xc77d, (q15_t)0x21eb, (q15_t)0xc783, (q15_t)0x21e0, (q15_t)0xc789, + (q15_t)0x21d5, (q15_t)0xc78f, (q15_t)0x21ca, (q15_t)0xc795, (q15_t)0x21be, (q15_t)0xc79a, (q15_t)0x21b3, (q15_t)0xc7a0, + (q15_t)0x21a8, (q15_t)0xc7a6, (q15_t)0x219d, (q15_t)0xc7ac, (q15_t)0x2192, (q15_t)0xc7b2, (q15_t)0x2187, (q15_t)0xc7b8, + (q15_t)0x217c, (q15_t)0xc7be, (q15_t)0x2171, (q15_t)0xc7c4, (q15_t)0x2166, (q15_t)0xc7ca, (q15_t)0x215b, (q15_t)0xc7d0, + (q15_t)0x2150, (q15_t)0xc7d6, (q15_t)0x2145, (q15_t)0xc7dc, (q15_t)0x213a, (q15_t)0xc7e2, (q15_t)0x212f, (q15_t)0xc7e8, + (q15_t)0x2124, (q15_t)0xc7ee, (q15_t)0x2119, (q15_t)0xc7f5, (q15_t)0x210e, (q15_t)0xc7fb, (q15_t)0x2103, (q15_t)0xc801, + (q15_t)0x20f8, (q15_t)0xc807, (q15_t)0x20ed, (q15_t)0xc80d, (q15_t)0x20e2, (q15_t)0xc813, (q15_t)0x20d7, (q15_t)0xc819, + (q15_t)0x20cc, (q15_t)0xc81f, (q15_t)0x20c1, (q15_t)0xc825, (q15_t)0x20b6, (q15_t)0xc82b, (q15_t)0x20ab, (q15_t)0xc832, + (q15_t)0x20a0, (q15_t)0xc838, (q15_t)0x2095, (q15_t)0xc83e, (q15_t)0x208a, (q15_t)0xc844, (q15_t)0x207f, (q15_t)0xc84a, + (q15_t)0x2074, (q15_t)0xc850, (q15_t)0x2069, (q15_t)0xc857, (q15_t)0x205e, (q15_t)0xc85d, (q15_t)0x2054, (q15_t)0xc863, + (q15_t)0x2049, (q15_t)0xc869, (q15_t)0x203e, (q15_t)0xc870, (q15_t)0x2033, (q15_t)0xc876, (q15_t)0x2028, (q15_t)0xc87c, + (q15_t)0x201d, (q15_t)0xc882, (q15_t)0x2012, (q15_t)0xc889, (q15_t)0x2007, (q15_t)0xc88f, (q15_t)0x1ffc, (q15_t)0xc895, + (q15_t)0x1ff1, (q15_t)0xc89b, (q15_t)0x1fe7, (q15_t)0xc8a2, (q15_t)0x1fdc, (q15_t)0xc8a8, (q15_t)0x1fd1, (q15_t)0xc8ae, + (q15_t)0x1fc6, (q15_t)0xc8b5, (q15_t)0x1fbb, (q15_t)0xc8bb, (q15_t)0x1fb0, (q15_t)0xc8c1, (q15_t)0x1fa5, (q15_t)0xc8c8, + (q15_t)0x1f9b, (q15_t)0xc8ce, (q15_t)0x1f90, (q15_t)0xc8d4, (q15_t)0x1f85, (q15_t)0xc8db, (q15_t)0x1f7a, (q15_t)0xc8e1, + (q15_t)0x1f6f, (q15_t)0xc8e8, (q15_t)0x1f65, (q15_t)0xc8ee, (q15_t)0x1f5a, (q15_t)0xc8f4, (q15_t)0x1f4f, (q15_t)0xc8fb, + (q15_t)0x1f44, (q15_t)0xc901, (q15_t)0x1f39, (q15_t)0xc908, (q15_t)0x1f2f, (q15_t)0xc90e, (q15_t)0x1f24, (q15_t)0xc915, + (q15_t)0x1f19, (q15_t)0xc91b, (q15_t)0x1f0e, (q15_t)0xc921, (q15_t)0x1f03, (q15_t)0xc928, (q15_t)0x1ef9, (q15_t)0xc92e, + (q15_t)0x1eee, (q15_t)0xc935, (q15_t)0x1ee3, (q15_t)0xc93b, (q15_t)0x1ed8, (q15_t)0xc942, (q15_t)0x1ece, (q15_t)0xc948, + (q15_t)0x1ec3, (q15_t)0xc94f, (q15_t)0x1eb8, (q15_t)0xc955, (q15_t)0x1ead, (q15_t)0xc95c, (q15_t)0x1ea3, (q15_t)0xc963, + (q15_t)0x1e98, (q15_t)0xc969, (q15_t)0x1e8d, (q15_t)0xc970, (q15_t)0x1e83, (q15_t)0xc976, (q15_t)0x1e78, (q15_t)0xc97d, + (q15_t)0x1e6d, (q15_t)0xc983, (q15_t)0x1e62, (q15_t)0xc98a, (q15_t)0x1e58, (q15_t)0xc991, (q15_t)0x1e4d, (q15_t)0xc997, + (q15_t)0x1e42, (q15_t)0xc99e, (q15_t)0x1e38, (q15_t)0xc9a4, (q15_t)0x1e2d, (q15_t)0xc9ab, (q15_t)0x1e22, (q15_t)0xc9b2, + (q15_t)0x1e18, (q15_t)0xc9b8, (q15_t)0x1e0d, (q15_t)0xc9bf, (q15_t)0x1e02, (q15_t)0xc9c6, (q15_t)0x1df8, (q15_t)0xc9cc, + (q15_t)0x1ded, (q15_t)0xc9d3, (q15_t)0x1de2, (q15_t)0xc9da, (q15_t)0x1dd8, (q15_t)0xc9e0, (q15_t)0x1dcd, (q15_t)0xc9e7, + (q15_t)0x1dc3, (q15_t)0xc9ee, (q15_t)0x1db8, (q15_t)0xc9f5, (q15_t)0x1dad, (q15_t)0xc9fb, (q15_t)0x1da3, (q15_t)0xca02, + (q15_t)0x1d98, (q15_t)0xca09, (q15_t)0x1d8e, (q15_t)0xca10, (q15_t)0x1d83, (q15_t)0xca16, (q15_t)0x1d78, (q15_t)0xca1d, + (q15_t)0x1d6e, (q15_t)0xca24, (q15_t)0x1d63, (q15_t)0xca2b, (q15_t)0x1d59, (q15_t)0xca32, (q15_t)0x1d4e, (q15_t)0xca38, + (q15_t)0x1d44, (q15_t)0xca3f, (q15_t)0x1d39, (q15_t)0xca46, (q15_t)0x1d2e, (q15_t)0xca4d, (q15_t)0x1d24, (q15_t)0xca54, + (q15_t)0x1d19, (q15_t)0xca5b, (q15_t)0x1d0f, (q15_t)0xca61, (q15_t)0x1d04, (q15_t)0xca68, (q15_t)0x1cfa, (q15_t)0xca6f, + (q15_t)0x1cef, (q15_t)0xca76, (q15_t)0x1ce5, (q15_t)0xca7d, (q15_t)0x1cda, (q15_t)0xca84, (q15_t)0x1cd0, (q15_t)0xca8b, + (q15_t)0x1cc5, (q15_t)0xca92, (q15_t)0x1cbb, (q15_t)0xca99, (q15_t)0x1cb0, (q15_t)0xca9f, (q15_t)0x1ca6, (q15_t)0xcaa6, + (q15_t)0x1c9b, (q15_t)0xcaad, (q15_t)0x1c91, (q15_t)0xcab4, (q15_t)0x1c86, (q15_t)0xcabb, (q15_t)0x1c7c, (q15_t)0xcac2, + (q15_t)0x1c72, (q15_t)0xcac9, (q15_t)0x1c67, (q15_t)0xcad0, (q15_t)0x1c5d, (q15_t)0xcad7, (q15_t)0x1c52, (q15_t)0xcade, + (q15_t)0x1c48, (q15_t)0xcae5, (q15_t)0x1c3d, (q15_t)0xcaec, (q15_t)0x1c33, (q15_t)0xcaf3, (q15_t)0x1c29, (q15_t)0xcafa, + (q15_t)0x1c1e, (q15_t)0xcb01, (q15_t)0x1c14, (q15_t)0xcb08, (q15_t)0x1c09, (q15_t)0xcb0f, (q15_t)0x1bff, (q15_t)0xcb16, + (q15_t)0x1bf5, (q15_t)0xcb1e, (q15_t)0x1bea, (q15_t)0xcb25, (q15_t)0x1be0, (q15_t)0xcb2c, (q15_t)0x1bd5, (q15_t)0xcb33, + (q15_t)0x1bcb, (q15_t)0xcb3a, (q15_t)0x1bc1, (q15_t)0xcb41, (q15_t)0x1bb6, (q15_t)0xcb48, (q15_t)0x1bac, (q15_t)0xcb4f, + (q15_t)0x1ba2, (q15_t)0xcb56, (q15_t)0x1b97, (q15_t)0xcb5e, (q15_t)0x1b8d, (q15_t)0xcb65, (q15_t)0x1b83, (q15_t)0xcb6c, + (q15_t)0x1b78, (q15_t)0xcb73, (q15_t)0x1b6e, (q15_t)0xcb7a, (q15_t)0x1b64, (q15_t)0xcb81, (q15_t)0x1b59, (q15_t)0xcb89, + (q15_t)0x1b4f, (q15_t)0xcb90, (q15_t)0x1b45, (q15_t)0xcb97, (q15_t)0x1b3b, (q15_t)0xcb9e, (q15_t)0x1b30, (q15_t)0xcba5, + (q15_t)0x1b26, (q15_t)0xcbad, (q15_t)0x1b1c, (q15_t)0xcbb4, (q15_t)0x1b11, (q15_t)0xcbbb, (q15_t)0x1b07, (q15_t)0xcbc2, + (q15_t)0x1afd, (q15_t)0xcbca, (q15_t)0x1af3, (q15_t)0xcbd1, (q15_t)0x1ae8, (q15_t)0xcbd8, (q15_t)0x1ade, (q15_t)0xcbe0, + (q15_t)0x1ad4, (q15_t)0xcbe7, (q15_t)0x1aca, (q15_t)0xcbee, (q15_t)0x1abf, (q15_t)0xcbf5, (q15_t)0x1ab5, (q15_t)0xcbfd, + (q15_t)0x1aab, (q15_t)0xcc04, (q15_t)0x1aa1, (q15_t)0xcc0b, (q15_t)0x1a97, (q15_t)0xcc13, (q15_t)0x1a8c, (q15_t)0xcc1a, + (q15_t)0x1a82, (q15_t)0xcc21, (q15_t)0x1a78, (q15_t)0xcc29, (q15_t)0x1a6e, (q15_t)0xcc30, (q15_t)0x1a64, (q15_t)0xcc38, + (q15_t)0x1a5a, (q15_t)0xcc3f, (q15_t)0x1a4f, (q15_t)0xcc46, (q15_t)0x1a45, (q15_t)0xcc4e, (q15_t)0x1a3b, (q15_t)0xcc55, + (q15_t)0x1a31, (q15_t)0xcc5d, (q15_t)0x1a27, (q15_t)0xcc64, (q15_t)0x1a1d, (q15_t)0xcc6b, (q15_t)0x1a13, (q15_t)0xcc73, + (q15_t)0x1a08, (q15_t)0xcc7a, (q15_t)0x19fe, (q15_t)0xcc82, (q15_t)0x19f4, (q15_t)0xcc89, (q15_t)0x19ea, (q15_t)0xcc91, + (q15_t)0x19e0, (q15_t)0xcc98, (q15_t)0x19d6, (q15_t)0xcca0, (q15_t)0x19cc, (q15_t)0xcca7, (q15_t)0x19c2, (q15_t)0xccaf, + (q15_t)0x19b8, (q15_t)0xccb6, (q15_t)0x19ae, (q15_t)0xccbe, (q15_t)0x19a4, (q15_t)0xccc5, (q15_t)0x199a, (q15_t)0xcccd, + (q15_t)0x198f, (q15_t)0xccd4, (q15_t)0x1985, (q15_t)0xccdc, (q15_t)0x197b, (q15_t)0xcce3, (q15_t)0x1971, (q15_t)0xcceb, + (q15_t)0x1967, (q15_t)0xccf3, (q15_t)0x195d, (q15_t)0xccfa, (q15_t)0x1953, (q15_t)0xcd02, (q15_t)0x1949, (q15_t)0xcd09, + (q15_t)0x193f, (q15_t)0xcd11, (q15_t)0x1935, (q15_t)0xcd19, (q15_t)0x192b, (q15_t)0xcd20, (q15_t)0x1921, (q15_t)0xcd28, + (q15_t)0x1917, (q15_t)0xcd30, (q15_t)0x190d, (q15_t)0xcd37, (q15_t)0x1903, (q15_t)0xcd3f, (q15_t)0x18f9, (q15_t)0xcd46, + (q15_t)0x18ef, (q15_t)0xcd4e, (q15_t)0x18e6, (q15_t)0xcd56, (q15_t)0x18dc, (q15_t)0xcd5d, (q15_t)0x18d2, (q15_t)0xcd65, + (q15_t)0x18c8, (q15_t)0xcd6d, (q15_t)0x18be, (q15_t)0xcd75, (q15_t)0x18b4, (q15_t)0xcd7c, (q15_t)0x18aa, (q15_t)0xcd84, + (q15_t)0x18a0, (q15_t)0xcd8c, (q15_t)0x1896, (q15_t)0xcd93, (q15_t)0x188c, (q15_t)0xcd9b, (q15_t)0x1882, (q15_t)0xcda3, + (q15_t)0x1878, (q15_t)0xcdab, (q15_t)0x186f, (q15_t)0xcdb2, (q15_t)0x1865, (q15_t)0xcdba, (q15_t)0x185b, (q15_t)0xcdc2, + (q15_t)0x1851, (q15_t)0xcdca, (q15_t)0x1847, (q15_t)0xcdd2, (q15_t)0x183d, (q15_t)0xcdd9, (q15_t)0x1833, (q15_t)0xcde1, + (q15_t)0x182a, (q15_t)0xcde9, (q15_t)0x1820, (q15_t)0xcdf1, (q15_t)0x1816, (q15_t)0xcdf9, (q15_t)0x180c, (q15_t)0xce01, + (q15_t)0x1802, (q15_t)0xce08, (q15_t)0x17f8, (q15_t)0xce10, (q15_t)0x17ef, (q15_t)0xce18, (q15_t)0x17e5, (q15_t)0xce20, + (q15_t)0x17db, (q15_t)0xce28, (q15_t)0x17d1, (q15_t)0xce30, (q15_t)0x17c8, (q15_t)0xce38, (q15_t)0x17be, (q15_t)0xce40, + (q15_t)0x17b4, (q15_t)0xce47, (q15_t)0x17aa, (q15_t)0xce4f, (q15_t)0x17a0, (q15_t)0xce57, (q15_t)0x1797, (q15_t)0xce5f, + (q15_t)0x178d, (q15_t)0xce67, (q15_t)0x1783, (q15_t)0xce6f, (q15_t)0x177a, (q15_t)0xce77, (q15_t)0x1770, (q15_t)0xce7f, + (q15_t)0x1766, (q15_t)0xce87, (q15_t)0x175c, (q15_t)0xce8f, (q15_t)0x1753, (q15_t)0xce97, (q15_t)0x1749, (q15_t)0xce9f, + (q15_t)0x173f, (q15_t)0xcea7, (q15_t)0x1736, (q15_t)0xceaf, (q15_t)0x172c, (q15_t)0xceb7, (q15_t)0x1722, (q15_t)0xcebf, + (q15_t)0x1719, (q15_t)0xcec7, (q15_t)0x170f, (q15_t)0xcecf, (q15_t)0x1705, (q15_t)0xced7, (q15_t)0x16fc, (q15_t)0xcedf, + (q15_t)0x16f2, (q15_t)0xcee7, (q15_t)0x16e8, (q15_t)0xceef, (q15_t)0x16df, (q15_t)0xcef7, (q15_t)0x16d5, (q15_t)0xceff, + (q15_t)0x16cb, (q15_t)0xcf07, (q15_t)0x16c2, (q15_t)0xcf10, (q15_t)0x16b8, (q15_t)0xcf18, (q15_t)0x16af, (q15_t)0xcf20, + (q15_t)0x16a5, (q15_t)0xcf28, (q15_t)0x169b, (q15_t)0xcf30, (q15_t)0x1692, (q15_t)0xcf38, (q15_t)0x1688, (q15_t)0xcf40, + (q15_t)0x167f, (q15_t)0xcf48, (q15_t)0x1675, (q15_t)0xcf51, (q15_t)0x166c, (q15_t)0xcf59, (q15_t)0x1662, (q15_t)0xcf61, + (q15_t)0x1659, (q15_t)0xcf69, (q15_t)0x164f, (q15_t)0xcf71, (q15_t)0x1645, (q15_t)0xcf79, (q15_t)0x163c, (q15_t)0xcf82, + (q15_t)0x1632, (q15_t)0xcf8a, (q15_t)0x1629, (q15_t)0xcf92, (q15_t)0x161f, (q15_t)0xcf9a, (q15_t)0x1616, (q15_t)0xcfa3, + (q15_t)0x160c, (q15_t)0xcfab, (q15_t)0x1603, (q15_t)0xcfb3, (q15_t)0x15f9, (q15_t)0xcfbb, (q15_t)0x15f0, (q15_t)0xcfc4, + (q15_t)0x15e6, (q15_t)0xcfcc, (q15_t)0x15dd, (q15_t)0xcfd4, (q15_t)0x15d4, (q15_t)0xcfdc, (q15_t)0x15ca, (q15_t)0xcfe5, + (q15_t)0x15c1, (q15_t)0xcfed, (q15_t)0x15b7, (q15_t)0xcff5, (q15_t)0x15ae, (q15_t)0xcffe, (q15_t)0x15a4, (q15_t)0xd006, + (q15_t)0x159b, (q15_t)0xd00e, (q15_t)0x1592, (q15_t)0xd016, (q15_t)0x1588, (q15_t)0xd01f, (q15_t)0x157f, (q15_t)0xd027, + (q15_t)0x1575, (q15_t)0xd030, (q15_t)0x156c, (q15_t)0xd038, (q15_t)0x1563, (q15_t)0xd040, (q15_t)0x1559, (q15_t)0xd049, + (q15_t)0x1550, (q15_t)0xd051, (q15_t)0x1547, (q15_t)0xd059, (q15_t)0x153d, (q15_t)0xd062, (q15_t)0x1534, (q15_t)0xd06a, + (q15_t)0x152a, (q15_t)0xd073, (q15_t)0x1521, (q15_t)0xd07b, (q15_t)0x1518, (q15_t)0xd083, (q15_t)0x150e, (q15_t)0xd08c, + (q15_t)0x1505, (q15_t)0xd094, (q15_t)0x14fc, (q15_t)0xd09d, (q15_t)0x14f3, (q15_t)0xd0a5, (q15_t)0x14e9, (q15_t)0xd0ae, + (q15_t)0x14e0, (q15_t)0xd0b6, (q15_t)0x14d7, (q15_t)0xd0bf, (q15_t)0x14cd, (q15_t)0xd0c7, (q15_t)0x14c4, (q15_t)0xd0d0, + (q15_t)0x14bb, (q15_t)0xd0d8, (q15_t)0x14b2, (q15_t)0xd0e0, (q15_t)0x14a8, (q15_t)0xd0e9, (q15_t)0x149f, (q15_t)0xd0f2, + (q15_t)0x1496, (q15_t)0xd0fa, (q15_t)0x148d, (q15_t)0xd103, (q15_t)0x1483, (q15_t)0xd10b, (q15_t)0x147a, (q15_t)0xd114, + (q15_t)0x1471, (q15_t)0xd11c, (q15_t)0x1468, (q15_t)0xd125, (q15_t)0x145f, (q15_t)0xd12d, (q15_t)0x1455, (q15_t)0xd136, + (q15_t)0x144c, (q15_t)0xd13e, (q15_t)0x1443, (q15_t)0xd147, (q15_t)0x143a, (q15_t)0xd150, (q15_t)0x1431, (q15_t)0xd158, + (q15_t)0x1428, (q15_t)0xd161, (q15_t)0x141e, (q15_t)0xd169, (q15_t)0x1415, (q15_t)0xd172, (q15_t)0x140c, (q15_t)0xd17b, + (q15_t)0x1403, (q15_t)0xd183, (q15_t)0x13fa, (q15_t)0xd18c, (q15_t)0x13f1, (q15_t)0xd195, (q15_t)0x13e8, (q15_t)0xd19d, + (q15_t)0x13df, (q15_t)0xd1a6, (q15_t)0x13d5, (q15_t)0xd1af, (q15_t)0x13cc, (q15_t)0xd1b7, (q15_t)0x13c3, (q15_t)0xd1c0, + (q15_t)0x13ba, (q15_t)0xd1c9, (q15_t)0x13b1, (q15_t)0xd1d1, (q15_t)0x13a8, (q15_t)0xd1da, (q15_t)0x139f, (q15_t)0xd1e3, + (q15_t)0x1396, (q15_t)0xd1eb, (q15_t)0x138d, (q15_t)0xd1f4, (q15_t)0x1384, (q15_t)0xd1fd, (q15_t)0x137b, (q15_t)0xd206, + (q15_t)0x1372, (q15_t)0xd20e, (q15_t)0x1369, (q15_t)0xd217, (q15_t)0x1360, (q15_t)0xd220, (q15_t)0x1357, (q15_t)0xd229, + (q15_t)0x134e, (q15_t)0xd231, (q15_t)0x1345, (q15_t)0xd23a, (q15_t)0x133c, (q15_t)0xd243, (q15_t)0x1333, (q15_t)0xd24c, + (q15_t)0x132a, (q15_t)0xd255, (q15_t)0x1321, (q15_t)0xd25d, (q15_t)0x1318, (q15_t)0xd266, (q15_t)0x130f, (q15_t)0xd26f, + (q15_t)0x1306, (q15_t)0xd278, (q15_t)0x12fd, (q15_t)0xd281, (q15_t)0x12f4, (q15_t)0xd28a, (q15_t)0x12eb, (q15_t)0xd292, + (q15_t)0x12e2, (q15_t)0xd29b, (q15_t)0x12d9, (q15_t)0xd2a4, (q15_t)0x12d1, (q15_t)0xd2ad, (q15_t)0x12c8, (q15_t)0xd2b6, + (q15_t)0x12bf, (q15_t)0xd2bf, (q15_t)0x12b6, (q15_t)0xd2c8, (q15_t)0x12ad, (q15_t)0xd2d1, (q15_t)0x12a4, (q15_t)0xd2d9, + (q15_t)0x129b, (q15_t)0xd2e2, (q15_t)0x1292, (q15_t)0xd2eb, (q15_t)0x128a, (q15_t)0xd2f4, (q15_t)0x1281, (q15_t)0xd2fd, + (q15_t)0x1278, (q15_t)0xd306, (q15_t)0x126f, (q15_t)0xd30f, (q15_t)0x1266, (q15_t)0xd318, (q15_t)0x125d, (q15_t)0xd321, + (q15_t)0x1255, (q15_t)0xd32a, (q15_t)0x124c, (q15_t)0xd333, (q15_t)0x1243, (q15_t)0xd33c, (q15_t)0x123a, (q15_t)0xd345, + (q15_t)0x1231, (q15_t)0xd34e, (q15_t)0x1229, (q15_t)0xd357, (q15_t)0x1220, (q15_t)0xd360, (q15_t)0x1217, (q15_t)0xd369, + (q15_t)0x120e, (q15_t)0xd372, (q15_t)0x1206, (q15_t)0xd37b, (q15_t)0x11fd, (q15_t)0xd384, (q15_t)0x11f4, (q15_t)0xd38d, + (q15_t)0x11eb, (q15_t)0xd396, (q15_t)0x11e3, (q15_t)0xd39f, (q15_t)0x11da, (q15_t)0xd3a8, (q15_t)0x11d1, (q15_t)0xd3b1, + (q15_t)0x11c9, (q15_t)0xd3ba, (q15_t)0x11c0, (q15_t)0xd3c3, (q15_t)0x11b7, (q15_t)0xd3cc, (q15_t)0x11af, (q15_t)0xd3d5, + (q15_t)0x11a6, (q15_t)0xd3df, (q15_t)0x119d, (q15_t)0xd3e8, (q15_t)0x1195, (q15_t)0xd3f1, (q15_t)0x118c, (q15_t)0xd3fa, + (q15_t)0x1183, (q15_t)0xd403, (q15_t)0x117b, (q15_t)0xd40c, (q15_t)0x1172, (q15_t)0xd415, (q15_t)0x1169, (q15_t)0xd41e, + (q15_t)0x1161, (q15_t)0xd428, (q15_t)0x1158, (q15_t)0xd431, (q15_t)0x1150, (q15_t)0xd43a, (q15_t)0x1147, (q15_t)0xd443, + (q15_t)0x113e, (q15_t)0xd44c, (q15_t)0x1136, (q15_t)0xd455, (q15_t)0x112d, (q15_t)0xd45f, (q15_t)0x1125, (q15_t)0xd468, + (q15_t)0x111c, (q15_t)0xd471, (q15_t)0x1114, (q15_t)0xd47a, (q15_t)0x110b, (q15_t)0xd483, (q15_t)0x1103, (q15_t)0xd48d, + (q15_t)0x10fa, (q15_t)0xd496, (q15_t)0x10f2, (q15_t)0xd49f, (q15_t)0x10e9, (q15_t)0xd4a8, (q15_t)0x10e0, (q15_t)0xd4b2, + (q15_t)0x10d8, (q15_t)0xd4bb, (q15_t)0x10d0, (q15_t)0xd4c4, (q15_t)0x10c7, (q15_t)0xd4cd, (q15_t)0x10bf, (q15_t)0xd4d7, + (q15_t)0x10b6, (q15_t)0xd4e0, (q15_t)0x10ae, (q15_t)0xd4e9, (q15_t)0x10a5, (q15_t)0xd4f3, (q15_t)0x109d, (q15_t)0xd4fc, + (q15_t)0x1094, (q15_t)0xd505, (q15_t)0x108c, (q15_t)0xd50e, (q15_t)0x1083, (q15_t)0xd518, (q15_t)0x107b, (q15_t)0xd521, + (q15_t)0x1073, (q15_t)0xd52a, (q15_t)0x106a, (q15_t)0xd534, (q15_t)0x1062, (q15_t)0xd53d, (q15_t)0x1059, (q15_t)0xd547, + (q15_t)0x1051, (q15_t)0xd550, (q15_t)0x1049, (q15_t)0xd559, (q15_t)0x1040, (q15_t)0xd563, (q15_t)0x1038, (q15_t)0xd56c, + (q15_t)0x1030, (q15_t)0xd575, (q15_t)0x1027, (q15_t)0xd57f, (q15_t)0x101f, (q15_t)0xd588, (q15_t)0x1016, (q15_t)0xd592, + (q15_t)0x100e, (q15_t)0xd59b, (q15_t)0x1006, (q15_t)0xd5a4, (q15_t)0xffe, (q15_t)0xd5ae, (q15_t)0xff5, (q15_t)0xd5b7, + (q15_t)0xfed, (q15_t)0xd5c1, (q15_t)0xfe5, (q15_t)0xd5ca, (q15_t)0xfdc, (q15_t)0xd5d4, (q15_t)0xfd4, (q15_t)0xd5dd, + (q15_t)0xfcc, (q15_t)0xd5e6, (q15_t)0xfc4, (q15_t)0xd5f0, (q15_t)0xfbb, (q15_t)0xd5f9, (q15_t)0xfb3, (q15_t)0xd603, + (q15_t)0xfab, (q15_t)0xd60c, (q15_t)0xfa3, (q15_t)0xd616, (q15_t)0xf9a, (q15_t)0xd61f, (q15_t)0xf92, (q15_t)0xd629, + (q15_t)0xf8a, (q15_t)0xd632, (q15_t)0xf82, (q15_t)0xd63c, (q15_t)0xf79, (q15_t)0xd645, (q15_t)0xf71, (q15_t)0xd64f, + (q15_t)0xf69, (q15_t)0xd659, (q15_t)0xf61, (q15_t)0xd662, (q15_t)0xf59, (q15_t)0xd66c, (q15_t)0xf51, (q15_t)0xd675, + (q15_t)0xf48, (q15_t)0xd67f, (q15_t)0xf40, (q15_t)0xd688, (q15_t)0xf38, (q15_t)0xd692, (q15_t)0xf30, (q15_t)0xd69b, + (q15_t)0xf28, (q15_t)0xd6a5, (q15_t)0xf20, (q15_t)0xd6af, (q15_t)0xf18, (q15_t)0xd6b8, (q15_t)0xf10, (q15_t)0xd6c2, + (q15_t)0xf07, (q15_t)0xd6cb, (q15_t)0xeff, (q15_t)0xd6d5, (q15_t)0xef7, (q15_t)0xd6df, (q15_t)0xeef, (q15_t)0xd6e8, + (q15_t)0xee7, (q15_t)0xd6f2, (q15_t)0xedf, (q15_t)0xd6fc, (q15_t)0xed7, (q15_t)0xd705, (q15_t)0xecf, (q15_t)0xd70f, + (q15_t)0xec7, (q15_t)0xd719, (q15_t)0xebf, (q15_t)0xd722, (q15_t)0xeb7, (q15_t)0xd72c, (q15_t)0xeaf, (q15_t)0xd736, + (q15_t)0xea7, (q15_t)0xd73f, (q15_t)0xe9f, (q15_t)0xd749, (q15_t)0xe97, (q15_t)0xd753, (q15_t)0xe8f, (q15_t)0xd75c, + (q15_t)0xe87, (q15_t)0xd766, (q15_t)0xe7f, (q15_t)0xd770, (q15_t)0xe77, (q15_t)0xd77a, (q15_t)0xe6f, (q15_t)0xd783, + (q15_t)0xe67, (q15_t)0xd78d, (q15_t)0xe5f, (q15_t)0xd797, (q15_t)0xe57, (q15_t)0xd7a0, (q15_t)0xe4f, (q15_t)0xd7aa, + (q15_t)0xe47, (q15_t)0xd7b4, (q15_t)0xe40, (q15_t)0xd7be, (q15_t)0xe38, (q15_t)0xd7c8, (q15_t)0xe30, (q15_t)0xd7d1, + (q15_t)0xe28, (q15_t)0xd7db, (q15_t)0xe20, (q15_t)0xd7e5, (q15_t)0xe18, (q15_t)0xd7ef, (q15_t)0xe10, (q15_t)0xd7f8, + (q15_t)0xe08, (q15_t)0xd802, (q15_t)0xe01, (q15_t)0xd80c, (q15_t)0xdf9, (q15_t)0xd816, (q15_t)0xdf1, (q15_t)0xd820, + (q15_t)0xde9, (q15_t)0xd82a, (q15_t)0xde1, (q15_t)0xd833, (q15_t)0xdd9, (q15_t)0xd83d, (q15_t)0xdd2, (q15_t)0xd847, + (q15_t)0xdca, (q15_t)0xd851, (q15_t)0xdc2, (q15_t)0xd85b, (q15_t)0xdba, (q15_t)0xd865, (q15_t)0xdb2, (q15_t)0xd86f, + (q15_t)0xdab, (q15_t)0xd878, (q15_t)0xda3, (q15_t)0xd882, (q15_t)0xd9b, (q15_t)0xd88c, (q15_t)0xd93, (q15_t)0xd896, + (q15_t)0xd8c, (q15_t)0xd8a0, (q15_t)0xd84, (q15_t)0xd8aa, (q15_t)0xd7c, (q15_t)0xd8b4, (q15_t)0xd75, (q15_t)0xd8be, + (q15_t)0xd6d, (q15_t)0xd8c8, (q15_t)0xd65, (q15_t)0xd8d2, (q15_t)0xd5d, (q15_t)0xd8dc, (q15_t)0xd56, (q15_t)0xd8e6, + (q15_t)0xd4e, (q15_t)0xd8ef, (q15_t)0xd46, (q15_t)0xd8f9, (q15_t)0xd3f, (q15_t)0xd903, (q15_t)0xd37, (q15_t)0xd90d, + (q15_t)0xd30, (q15_t)0xd917, (q15_t)0xd28, (q15_t)0xd921, (q15_t)0xd20, (q15_t)0xd92b, (q15_t)0xd19, (q15_t)0xd935, + (q15_t)0xd11, (q15_t)0xd93f, (q15_t)0xd09, (q15_t)0xd949, (q15_t)0xd02, (q15_t)0xd953, (q15_t)0xcfa, (q15_t)0xd95d, + (q15_t)0xcf3, (q15_t)0xd967, (q15_t)0xceb, (q15_t)0xd971, (q15_t)0xce3, (q15_t)0xd97b, (q15_t)0xcdc, (q15_t)0xd985, + (q15_t)0xcd4, (q15_t)0xd98f, (q15_t)0xccd, (q15_t)0xd99a, (q15_t)0xcc5, (q15_t)0xd9a4, (q15_t)0xcbe, (q15_t)0xd9ae, + (q15_t)0xcb6, (q15_t)0xd9b8, (q15_t)0xcaf, (q15_t)0xd9c2, (q15_t)0xca7, (q15_t)0xd9cc, (q15_t)0xca0, (q15_t)0xd9d6, + (q15_t)0xc98, (q15_t)0xd9e0, (q15_t)0xc91, (q15_t)0xd9ea, (q15_t)0xc89, (q15_t)0xd9f4, (q15_t)0xc82, (q15_t)0xd9fe, + (q15_t)0xc7a, (q15_t)0xda08, (q15_t)0xc73, (q15_t)0xda13, (q15_t)0xc6b, (q15_t)0xda1d, (q15_t)0xc64, (q15_t)0xda27, + (q15_t)0xc5d, (q15_t)0xda31, (q15_t)0xc55, (q15_t)0xda3b, (q15_t)0xc4e, (q15_t)0xda45, (q15_t)0xc46, (q15_t)0xda4f, + (q15_t)0xc3f, (q15_t)0xda5a, (q15_t)0xc38, (q15_t)0xda64, (q15_t)0xc30, (q15_t)0xda6e, (q15_t)0xc29, (q15_t)0xda78, + (q15_t)0xc21, (q15_t)0xda82, (q15_t)0xc1a, (q15_t)0xda8c, (q15_t)0xc13, (q15_t)0xda97, (q15_t)0xc0b, (q15_t)0xdaa1, + (q15_t)0xc04, (q15_t)0xdaab, (q15_t)0xbfd, (q15_t)0xdab5, (q15_t)0xbf5, (q15_t)0xdabf, (q15_t)0xbee, (q15_t)0xdaca, + (q15_t)0xbe7, (q15_t)0xdad4, (q15_t)0xbe0, (q15_t)0xdade, (q15_t)0xbd8, (q15_t)0xdae8, (q15_t)0xbd1, (q15_t)0xdaf3, + (q15_t)0xbca, (q15_t)0xdafd, (q15_t)0xbc2, (q15_t)0xdb07, (q15_t)0xbbb, (q15_t)0xdb11, (q15_t)0xbb4, (q15_t)0xdb1c, + (q15_t)0xbad, (q15_t)0xdb26, (q15_t)0xba5, (q15_t)0xdb30, (q15_t)0xb9e, (q15_t)0xdb3b, (q15_t)0xb97, (q15_t)0xdb45, + (q15_t)0xb90, (q15_t)0xdb4f, (q15_t)0xb89, (q15_t)0xdb59, (q15_t)0xb81, (q15_t)0xdb64, (q15_t)0xb7a, (q15_t)0xdb6e, + (q15_t)0xb73, (q15_t)0xdb78, (q15_t)0xb6c, (q15_t)0xdb83, (q15_t)0xb65, (q15_t)0xdb8d, (q15_t)0xb5e, (q15_t)0xdb97, + (q15_t)0xb56, (q15_t)0xdba2, (q15_t)0xb4f, (q15_t)0xdbac, (q15_t)0xb48, (q15_t)0xdbb6, (q15_t)0xb41, (q15_t)0xdbc1, + (q15_t)0xb3a, (q15_t)0xdbcb, (q15_t)0xb33, (q15_t)0xdbd5, (q15_t)0xb2c, (q15_t)0xdbe0, (q15_t)0xb25, (q15_t)0xdbea, + (q15_t)0xb1e, (q15_t)0xdbf5, (q15_t)0xb16, (q15_t)0xdbff, (q15_t)0xb0f, (q15_t)0xdc09, (q15_t)0xb08, (q15_t)0xdc14, + (q15_t)0xb01, (q15_t)0xdc1e, (q15_t)0xafa, (q15_t)0xdc29, (q15_t)0xaf3, (q15_t)0xdc33, (q15_t)0xaec, (q15_t)0xdc3d, + (q15_t)0xae5, (q15_t)0xdc48, (q15_t)0xade, (q15_t)0xdc52, (q15_t)0xad7, (q15_t)0xdc5d, (q15_t)0xad0, (q15_t)0xdc67, + (q15_t)0xac9, (q15_t)0xdc72, (q15_t)0xac2, (q15_t)0xdc7c, (q15_t)0xabb, (q15_t)0xdc86, (q15_t)0xab4, (q15_t)0xdc91, + (q15_t)0xaad, (q15_t)0xdc9b, (q15_t)0xaa6, (q15_t)0xdca6, (q15_t)0xa9f, (q15_t)0xdcb0, (q15_t)0xa99, (q15_t)0xdcbb, + (q15_t)0xa92, (q15_t)0xdcc5, (q15_t)0xa8b, (q15_t)0xdcd0, (q15_t)0xa84, (q15_t)0xdcda, (q15_t)0xa7d, (q15_t)0xdce5, + (q15_t)0xa76, (q15_t)0xdcef, (q15_t)0xa6f, (q15_t)0xdcfa, (q15_t)0xa68, (q15_t)0xdd04, (q15_t)0xa61, (q15_t)0xdd0f, + (q15_t)0xa5b, (q15_t)0xdd19, (q15_t)0xa54, (q15_t)0xdd24, (q15_t)0xa4d, (q15_t)0xdd2e, (q15_t)0xa46, (q15_t)0xdd39, + (q15_t)0xa3f, (q15_t)0xdd44, (q15_t)0xa38, (q15_t)0xdd4e, (q15_t)0xa32, (q15_t)0xdd59, (q15_t)0xa2b, (q15_t)0xdd63, + (q15_t)0xa24, (q15_t)0xdd6e, (q15_t)0xa1d, (q15_t)0xdd78, (q15_t)0xa16, (q15_t)0xdd83, (q15_t)0xa10, (q15_t)0xdd8e, + (q15_t)0xa09, (q15_t)0xdd98, (q15_t)0xa02, (q15_t)0xdda3, (q15_t)0x9fb, (q15_t)0xddad, (q15_t)0x9f5, (q15_t)0xddb8, + (q15_t)0x9ee, (q15_t)0xddc3, (q15_t)0x9e7, (q15_t)0xddcd, (q15_t)0x9e0, (q15_t)0xddd8, (q15_t)0x9da, (q15_t)0xdde2, + (q15_t)0x9d3, (q15_t)0xdded, (q15_t)0x9cc, (q15_t)0xddf8, (q15_t)0x9c6, (q15_t)0xde02, (q15_t)0x9bf, (q15_t)0xde0d, + (q15_t)0x9b8, (q15_t)0xde18, (q15_t)0x9b2, (q15_t)0xde22, (q15_t)0x9ab, (q15_t)0xde2d, (q15_t)0x9a4, (q15_t)0xde38, + (q15_t)0x99e, (q15_t)0xde42, (q15_t)0x997, (q15_t)0xde4d, (q15_t)0x991, (q15_t)0xde58, (q15_t)0x98a, (q15_t)0xde62, + (q15_t)0x983, (q15_t)0xde6d, (q15_t)0x97d, (q15_t)0xde78, (q15_t)0x976, (q15_t)0xde83, (q15_t)0x970, (q15_t)0xde8d, + (q15_t)0x969, (q15_t)0xde98, (q15_t)0x963, (q15_t)0xdea3, (q15_t)0x95c, (q15_t)0xdead, (q15_t)0x955, (q15_t)0xdeb8, + (q15_t)0x94f, (q15_t)0xdec3, (q15_t)0x948, (q15_t)0xdece, (q15_t)0x942, (q15_t)0xded8, (q15_t)0x93b, (q15_t)0xdee3, + (q15_t)0x935, (q15_t)0xdeee, (q15_t)0x92e, (q15_t)0xdef9, (q15_t)0x928, (q15_t)0xdf03, (q15_t)0x921, (q15_t)0xdf0e, + (q15_t)0x91b, (q15_t)0xdf19, (q15_t)0x915, (q15_t)0xdf24, (q15_t)0x90e, (q15_t)0xdf2f, (q15_t)0x908, (q15_t)0xdf39, + (q15_t)0x901, (q15_t)0xdf44, (q15_t)0x8fb, (q15_t)0xdf4f, (q15_t)0x8f4, (q15_t)0xdf5a, (q15_t)0x8ee, (q15_t)0xdf65, + (q15_t)0x8e8, (q15_t)0xdf6f, (q15_t)0x8e1, (q15_t)0xdf7a, (q15_t)0x8db, (q15_t)0xdf85, (q15_t)0x8d4, (q15_t)0xdf90, + (q15_t)0x8ce, (q15_t)0xdf9b, (q15_t)0x8c8, (q15_t)0xdfa5, (q15_t)0x8c1, (q15_t)0xdfb0, (q15_t)0x8bb, (q15_t)0xdfbb, + (q15_t)0x8b5, (q15_t)0xdfc6, (q15_t)0x8ae, (q15_t)0xdfd1, (q15_t)0x8a8, (q15_t)0xdfdc, (q15_t)0x8a2, (q15_t)0xdfe7, + (q15_t)0x89b, (q15_t)0xdff1, (q15_t)0x895, (q15_t)0xdffc, (q15_t)0x88f, (q15_t)0xe007, (q15_t)0x889, (q15_t)0xe012, + (q15_t)0x882, (q15_t)0xe01d, (q15_t)0x87c, (q15_t)0xe028, (q15_t)0x876, (q15_t)0xe033, (q15_t)0x870, (q15_t)0xe03e, + (q15_t)0x869, (q15_t)0xe049, (q15_t)0x863, (q15_t)0xe054, (q15_t)0x85d, (q15_t)0xe05e, (q15_t)0x857, (q15_t)0xe069, + (q15_t)0x850, (q15_t)0xe074, (q15_t)0x84a, (q15_t)0xe07f, (q15_t)0x844, (q15_t)0xe08a, (q15_t)0x83e, (q15_t)0xe095, + (q15_t)0x838, (q15_t)0xe0a0, (q15_t)0x832, (q15_t)0xe0ab, (q15_t)0x82b, (q15_t)0xe0b6, (q15_t)0x825, (q15_t)0xe0c1, + (q15_t)0x81f, (q15_t)0xe0cc, (q15_t)0x819, (q15_t)0xe0d7, (q15_t)0x813, (q15_t)0xe0e2, (q15_t)0x80d, (q15_t)0xe0ed, + (q15_t)0x807, (q15_t)0xe0f8, (q15_t)0x801, (q15_t)0xe103, (q15_t)0x7fb, (q15_t)0xe10e, (q15_t)0x7f5, (q15_t)0xe119, + (q15_t)0x7ee, (q15_t)0xe124, (q15_t)0x7e8, (q15_t)0xe12f, (q15_t)0x7e2, (q15_t)0xe13a, (q15_t)0x7dc, (q15_t)0xe145, + (q15_t)0x7d6, (q15_t)0xe150, (q15_t)0x7d0, (q15_t)0xe15b, (q15_t)0x7ca, (q15_t)0xe166, (q15_t)0x7c4, (q15_t)0xe171, + (q15_t)0x7be, (q15_t)0xe17c, (q15_t)0x7b8, (q15_t)0xe187, (q15_t)0x7b2, (q15_t)0xe192, (q15_t)0x7ac, (q15_t)0xe19d, + (q15_t)0x7a6, (q15_t)0xe1a8, (q15_t)0x7a0, (q15_t)0xe1b3, (q15_t)0x79a, (q15_t)0xe1be, (q15_t)0x795, (q15_t)0xe1ca, + (q15_t)0x78f, (q15_t)0xe1d5, (q15_t)0x789, (q15_t)0xe1e0, (q15_t)0x783, (q15_t)0xe1eb, (q15_t)0x77d, (q15_t)0xe1f6, + (q15_t)0x777, (q15_t)0xe201, (q15_t)0x771, (q15_t)0xe20c, (q15_t)0x76b, (q15_t)0xe217, (q15_t)0x765, (q15_t)0xe222, + (q15_t)0x75f, (q15_t)0xe22d, (q15_t)0x75a, (q15_t)0xe239, (q15_t)0x754, (q15_t)0xe244, (q15_t)0x74e, (q15_t)0xe24f, + (q15_t)0x748, (q15_t)0xe25a, (q15_t)0x742, (q15_t)0xe265, (q15_t)0x73d, (q15_t)0xe270, (q15_t)0x737, (q15_t)0xe27b, + (q15_t)0x731, (q15_t)0xe287, (q15_t)0x72b, (q15_t)0xe292, (q15_t)0x725, (q15_t)0xe29d, (q15_t)0x720, (q15_t)0xe2a8, + (q15_t)0x71a, (q15_t)0xe2b3, (q15_t)0x714, (q15_t)0xe2be, (q15_t)0x70e, (q15_t)0xe2ca, (q15_t)0x709, (q15_t)0xe2d5, + (q15_t)0x703, (q15_t)0xe2e0, (q15_t)0x6fd, (q15_t)0xe2eb, (q15_t)0x6f7, (q15_t)0xe2f6, (q15_t)0x6f2, (q15_t)0xe301, + (q15_t)0x6ec, (q15_t)0xe30d, (q15_t)0x6e6, (q15_t)0xe318, (q15_t)0x6e1, (q15_t)0xe323, (q15_t)0x6db, (q15_t)0xe32e, + (q15_t)0x6d5, (q15_t)0xe33a, (q15_t)0x6d0, (q15_t)0xe345, (q15_t)0x6ca, (q15_t)0xe350, (q15_t)0x6c5, (q15_t)0xe35b, + (q15_t)0x6bf, (q15_t)0xe367, (q15_t)0x6b9, (q15_t)0xe372, (q15_t)0x6b4, (q15_t)0xe37d, (q15_t)0x6ae, (q15_t)0xe388, + (q15_t)0x6a8, (q15_t)0xe394, (q15_t)0x6a3, (q15_t)0xe39f, (q15_t)0x69d, (q15_t)0xe3aa, (q15_t)0x698, (q15_t)0xe3b5, + (q15_t)0x692, (q15_t)0xe3c1, (q15_t)0x68d, (q15_t)0xe3cc, (q15_t)0x687, (q15_t)0xe3d7, (q15_t)0x682, (q15_t)0xe3e2, + (q15_t)0x67c, (q15_t)0xe3ee, (q15_t)0x677, (q15_t)0xe3f9, (q15_t)0x671, (q15_t)0xe404, (q15_t)0x66c, (q15_t)0xe410, + (q15_t)0x666, (q15_t)0xe41b, (q15_t)0x661, (q15_t)0xe426, (q15_t)0x65b, (q15_t)0xe432, (q15_t)0x656, (q15_t)0xe43d, + (q15_t)0x650, (q15_t)0xe448, (q15_t)0x64b, (q15_t)0xe454, (q15_t)0x645, (q15_t)0xe45f, (q15_t)0x640, (q15_t)0xe46a, + (q15_t)0x63b, (q15_t)0xe476, (q15_t)0x635, (q15_t)0xe481, (q15_t)0x630, (q15_t)0xe48c, (q15_t)0x62a, (q15_t)0xe498, + (q15_t)0x625, (q15_t)0xe4a3, (q15_t)0x620, (q15_t)0xe4ae, (q15_t)0x61a, (q15_t)0xe4ba, (q15_t)0x615, (q15_t)0xe4c5, + (q15_t)0x610, (q15_t)0xe4d0, (q15_t)0x60a, (q15_t)0xe4dc, (q15_t)0x605, (q15_t)0xe4e7, (q15_t)0x600, (q15_t)0xe4f3, + (q15_t)0x5fa, (q15_t)0xe4fe, (q15_t)0x5f5, (q15_t)0xe509, (q15_t)0x5f0, (q15_t)0xe515, (q15_t)0x5ea, (q15_t)0xe520, + (q15_t)0x5e5, (q15_t)0xe52c, (q15_t)0x5e0, (q15_t)0xe537, (q15_t)0x5db, (q15_t)0xe542, (q15_t)0x5d5, (q15_t)0xe54e, + (q15_t)0x5d0, (q15_t)0xe559, (q15_t)0x5cb, (q15_t)0xe565, (q15_t)0x5c6, (q15_t)0xe570, (q15_t)0x5c1, (q15_t)0xe57c, + (q15_t)0x5bb, (q15_t)0xe587, (q15_t)0x5b6, (q15_t)0xe592, (q15_t)0x5b1, (q15_t)0xe59e, (q15_t)0x5ac, (q15_t)0xe5a9, + (q15_t)0x5a7, (q15_t)0xe5b5, (q15_t)0x5a1, (q15_t)0xe5c0, (q15_t)0x59c, (q15_t)0xe5cc, (q15_t)0x597, (q15_t)0xe5d7, + (q15_t)0x592, (q15_t)0xe5e3, (q15_t)0x58d, (q15_t)0xe5ee, (q15_t)0x588, (q15_t)0xe5fa, (q15_t)0x583, (q15_t)0xe605, + (q15_t)0x57e, (q15_t)0xe611, (q15_t)0x578, (q15_t)0xe61c, (q15_t)0x573, (q15_t)0xe628, (q15_t)0x56e, (q15_t)0xe633, + (q15_t)0x569, (q15_t)0xe63f, (q15_t)0x564, (q15_t)0xe64a, (q15_t)0x55f, (q15_t)0xe656, (q15_t)0x55a, (q15_t)0xe661, + (q15_t)0x555, (q15_t)0xe66d, (q15_t)0x550, (q15_t)0xe678, (q15_t)0x54b, (q15_t)0xe684, (q15_t)0x546, (q15_t)0xe68f, + (q15_t)0x541, (q15_t)0xe69b, (q15_t)0x53c, (q15_t)0xe6a6, (q15_t)0x537, (q15_t)0xe6b2, (q15_t)0x532, (q15_t)0xe6bd, + (q15_t)0x52d, (q15_t)0xe6c9, (q15_t)0x528, (q15_t)0xe6d4, (q15_t)0x523, (q15_t)0xe6e0, (q15_t)0x51e, (q15_t)0xe6ec, + (q15_t)0x51a, (q15_t)0xe6f7, (q15_t)0x515, (q15_t)0xe703, (q15_t)0x510, (q15_t)0xe70e, (q15_t)0x50b, (q15_t)0xe71a, + (q15_t)0x506, (q15_t)0xe725, (q15_t)0x501, (q15_t)0xe731, (q15_t)0x4fc, (q15_t)0xe73d, (q15_t)0x4f7, (q15_t)0xe748, + (q15_t)0x4f2, (q15_t)0xe754, (q15_t)0x4ee, (q15_t)0xe75f, (q15_t)0x4e9, (q15_t)0xe76b, (q15_t)0x4e4, (q15_t)0xe777, + (q15_t)0x4df, (q15_t)0xe782, (q15_t)0x4da, (q15_t)0xe78e, (q15_t)0x4d6, (q15_t)0xe799, (q15_t)0x4d1, (q15_t)0xe7a5, + (q15_t)0x4cc, (q15_t)0xe7b1, (q15_t)0x4c7, (q15_t)0xe7bc, (q15_t)0x4c2, (q15_t)0xe7c8, (q15_t)0x4be, (q15_t)0xe7d3, + (q15_t)0x4b9, (q15_t)0xe7df, (q15_t)0x4b4, (q15_t)0xe7eb, (q15_t)0x4b0, (q15_t)0xe7f6, (q15_t)0x4ab, (q15_t)0xe802, + (q15_t)0x4a6, (q15_t)0xe80e, (q15_t)0x4a1, (q15_t)0xe819, (q15_t)0x49d, (q15_t)0xe825, (q15_t)0x498, (q15_t)0xe831, + (q15_t)0x493, (q15_t)0xe83c, (q15_t)0x48f, (q15_t)0xe848, (q15_t)0x48a, (q15_t)0xe854, (q15_t)0x485, (q15_t)0xe85f, + (q15_t)0x481, (q15_t)0xe86b, (q15_t)0x47c, (q15_t)0xe877, (q15_t)0x478, (q15_t)0xe882, (q15_t)0x473, (q15_t)0xe88e, + (q15_t)0x46e, (q15_t)0xe89a, (q15_t)0x46a, (q15_t)0xe8a5, (q15_t)0x465, (q15_t)0xe8b1, (q15_t)0x461, (q15_t)0xe8bd, + (q15_t)0x45c, (q15_t)0xe8c9, (q15_t)0x457, (q15_t)0xe8d4, (q15_t)0x453, (q15_t)0xe8e0, (q15_t)0x44e, (q15_t)0xe8ec, + (q15_t)0x44a, (q15_t)0xe8f7, (q15_t)0x445, (q15_t)0xe903, (q15_t)0x441, (q15_t)0xe90f, (q15_t)0x43c, (q15_t)0xe91b, + (q15_t)0x438, (q15_t)0xe926, (q15_t)0x433, (q15_t)0xe932, (q15_t)0x42f, (q15_t)0xe93e, (q15_t)0x42a, (q15_t)0xe94a, + (q15_t)0x426, (q15_t)0xe955, (q15_t)0x422, (q15_t)0xe961, (q15_t)0x41d, (q15_t)0xe96d, (q15_t)0x419, (q15_t)0xe979, + (q15_t)0x414, (q15_t)0xe984, (q15_t)0x410, (q15_t)0xe990, (q15_t)0x40b, (q15_t)0xe99c, (q15_t)0x407, (q15_t)0xe9a8, + (q15_t)0x403, (q15_t)0xe9b4, (q15_t)0x3fe, (q15_t)0xe9bf, (q15_t)0x3fa, (q15_t)0xe9cb, (q15_t)0x3f6, (q15_t)0xe9d7, + (q15_t)0x3f1, (q15_t)0xe9e3, (q15_t)0x3ed, (q15_t)0xe9ee, (q15_t)0x3e9, (q15_t)0xe9fa, (q15_t)0x3e4, (q15_t)0xea06, + (q15_t)0x3e0, (q15_t)0xea12, (q15_t)0x3dc, (q15_t)0xea1e, (q15_t)0x3d7, (q15_t)0xea29, (q15_t)0x3d3, (q15_t)0xea35, + (q15_t)0x3cf, (q15_t)0xea41, (q15_t)0x3ca, (q15_t)0xea4d, (q15_t)0x3c6, (q15_t)0xea59, (q15_t)0x3c2, (q15_t)0xea65, + (q15_t)0x3be, (q15_t)0xea70, (q15_t)0x3ba, (q15_t)0xea7c, (q15_t)0x3b5, (q15_t)0xea88, (q15_t)0x3b1, (q15_t)0xea94, + (q15_t)0x3ad, (q15_t)0xeaa0, (q15_t)0x3a9, (q15_t)0xeaac, (q15_t)0x3a5, (q15_t)0xeab7, (q15_t)0x3a0, (q15_t)0xeac3, + (q15_t)0x39c, (q15_t)0xeacf, (q15_t)0x398, (q15_t)0xeadb, (q15_t)0x394, (q15_t)0xeae7, (q15_t)0x390, (q15_t)0xeaf3, + (q15_t)0x38c, (q15_t)0xeaff, (q15_t)0x387, (q15_t)0xeb0a, (q15_t)0x383, (q15_t)0xeb16, (q15_t)0x37f, (q15_t)0xeb22, + (q15_t)0x37b, (q15_t)0xeb2e, (q15_t)0x377, (q15_t)0xeb3a, (q15_t)0x373, (q15_t)0xeb46, (q15_t)0x36f, (q15_t)0xeb52, + (q15_t)0x36b, (q15_t)0xeb5e, (q15_t)0x367, (q15_t)0xeb6a, (q15_t)0x363, (q15_t)0xeb75, (q15_t)0x35f, (q15_t)0xeb81, + (q15_t)0x35b, (q15_t)0xeb8d, (q15_t)0x357, (q15_t)0xeb99, (q15_t)0x353, (q15_t)0xeba5, (q15_t)0x34f, (q15_t)0xebb1, + (q15_t)0x34b, (q15_t)0xebbd, (q15_t)0x347, (q15_t)0xebc9, (q15_t)0x343, (q15_t)0xebd5, (q15_t)0x33f, (q15_t)0xebe1, + (q15_t)0x33b, (q15_t)0xebed, (q15_t)0x337, (q15_t)0xebf9, (q15_t)0x333, (q15_t)0xec05, (q15_t)0x32f, (q15_t)0xec10, + (q15_t)0x32b, (q15_t)0xec1c, (q15_t)0x327, (q15_t)0xec28, (q15_t)0x323, (q15_t)0xec34, (q15_t)0x320, (q15_t)0xec40, + (q15_t)0x31c, (q15_t)0xec4c, (q15_t)0x318, (q15_t)0xec58, (q15_t)0x314, (q15_t)0xec64, (q15_t)0x310, (q15_t)0xec70, + (q15_t)0x30c, (q15_t)0xec7c, (q15_t)0x308, (q15_t)0xec88, (q15_t)0x305, (q15_t)0xec94, (q15_t)0x301, (q15_t)0xeca0, + (q15_t)0x2fd, (q15_t)0xecac, (q15_t)0x2f9, (q15_t)0xecb8, (q15_t)0x2f5, (q15_t)0xecc4, (q15_t)0x2f2, (q15_t)0xecd0, + (q15_t)0x2ee, (q15_t)0xecdc, (q15_t)0x2ea, (q15_t)0xece8, (q15_t)0x2e6, (q15_t)0xecf4, (q15_t)0x2e3, (q15_t)0xed00, + (q15_t)0x2df, (q15_t)0xed0c, (q15_t)0x2db, (q15_t)0xed18, (q15_t)0x2d8, (q15_t)0xed24, (q15_t)0x2d4, (q15_t)0xed30, + (q15_t)0x2d0, (q15_t)0xed3c, (q15_t)0x2cc, (q15_t)0xed48, (q15_t)0x2c9, (q15_t)0xed54, (q15_t)0x2c5, (q15_t)0xed60, + (q15_t)0x2c1, (q15_t)0xed6c, (q15_t)0x2be, (q15_t)0xed78, (q15_t)0x2ba, (q15_t)0xed84, (q15_t)0x2b7, (q15_t)0xed90, + (q15_t)0x2b3, (q15_t)0xed9c, (q15_t)0x2af, (q15_t)0xeda8, (q15_t)0x2ac, (q15_t)0xedb4, (q15_t)0x2a8, (q15_t)0xedc0, + (q15_t)0x2a5, (q15_t)0xedcc, (q15_t)0x2a1, (q15_t)0xedd8, (q15_t)0x29d, (q15_t)0xede4, (q15_t)0x29a, (q15_t)0xedf0, + (q15_t)0x296, (q15_t)0xedfc, (q15_t)0x293, (q15_t)0xee09, (q15_t)0x28f, (q15_t)0xee15, (q15_t)0x28c, (q15_t)0xee21, + (q15_t)0x288, (q15_t)0xee2d, (q15_t)0x285, (q15_t)0xee39, (q15_t)0x281, (q15_t)0xee45, (q15_t)0x27e, (q15_t)0xee51, + (q15_t)0x27a, (q15_t)0xee5d, (q15_t)0x277, (q15_t)0xee69, (q15_t)0x273, (q15_t)0xee75, (q15_t)0x270, (q15_t)0xee81, + (q15_t)0x26d, (q15_t)0xee8d, (q15_t)0x269, (q15_t)0xee99, (q15_t)0x266, (q15_t)0xeea6, (q15_t)0x262, (q15_t)0xeeb2, + (q15_t)0x25f, (q15_t)0xeebe, (q15_t)0x25c, (q15_t)0xeeca, (q15_t)0x258, (q15_t)0xeed6, (q15_t)0x255, (q15_t)0xeee2, + (q15_t)0x251, (q15_t)0xeeee, (q15_t)0x24e, (q15_t)0xeefa, (q15_t)0x24b, (q15_t)0xef06, (q15_t)0x247, (q15_t)0xef13, + (q15_t)0x244, (q15_t)0xef1f, (q15_t)0x241, (q15_t)0xef2b, (q15_t)0x23e, (q15_t)0xef37, (q15_t)0x23a, (q15_t)0xef43, + (q15_t)0x237, (q15_t)0xef4f, (q15_t)0x234, (q15_t)0xef5b, (q15_t)0x230, (q15_t)0xef67, (q15_t)0x22d, (q15_t)0xef74, + (q15_t)0x22a, (q15_t)0xef80, (q15_t)0x227, (q15_t)0xef8c, (q15_t)0x223, (q15_t)0xef98, (q15_t)0x220, (q15_t)0xefa4, + (q15_t)0x21d, (q15_t)0xefb0, (q15_t)0x21a, (q15_t)0xefbc, (q15_t)0x217, (q15_t)0xefc9, (q15_t)0x213, (q15_t)0xefd5, + (q15_t)0x210, (q15_t)0xefe1, (q15_t)0x20d, (q15_t)0xefed, (q15_t)0x20a, (q15_t)0xeff9, (q15_t)0x207, (q15_t)0xf005, + (q15_t)0x204, (q15_t)0xf012, (q15_t)0x201, (q15_t)0xf01e, (q15_t)0x1fd, (q15_t)0xf02a, (q15_t)0x1fa, (q15_t)0xf036, + (q15_t)0x1f7, (q15_t)0xf042, (q15_t)0x1f4, (q15_t)0xf04e, (q15_t)0x1f1, (q15_t)0xf05b, (q15_t)0x1ee, (q15_t)0xf067, + (q15_t)0x1eb, (q15_t)0xf073, (q15_t)0x1e8, (q15_t)0xf07f, (q15_t)0x1e5, (q15_t)0xf08b, (q15_t)0x1e2, (q15_t)0xf098, + (q15_t)0x1df, (q15_t)0xf0a4, (q15_t)0x1dc, (q15_t)0xf0b0, (q15_t)0x1d9, (q15_t)0xf0bc, (q15_t)0x1d6, (q15_t)0xf0c8, + (q15_t)0x1d3, (q15_t)0xf0d5, (q15_t)0x1d0, (q15_t)0xf0e1, (q15_t)0x1cd, (q15_t)0xf0ed, (q15_t)0x1ca, (q15_t)0xf0f9, + (q15_t)0x1c7, (q15_t)0xf105, (q15_t)0x1c4, (q15_t)0xf112, (q15_t)0x1c1, (q15_t)0xf11e, (q15_t)0x1be, (q15_t)0xf12a, + (q15_t)0x1bb, (q15_t)0xf136, (q15_t)0x1b8, (q15_t)0xf143, (q15_t)0x1b6, (q15_t)0xf14f, (q15_t)0x1b3, (q15_t)0xf15b, + (q15_t)0x1b0, (q15_t)0xf167, (q15_t)0x1ad, (q15_t)0xf174, (q15_t)0x1aa, (q15_t)0xf180, (q15_t)0x1a7, (q15_t)0xf18c, + (q15_t)0x1a4, (q15_t)0xf198, (q15_t)0x1a2, (q15_t)0xf1a4, (q15_t)0x19f, (q15_t)0xf1b1, (q15_t)0x19c, (q15_t)0xf1bd, + (q15_t)0x199, (q15_t)0xf1c9, (q15_t)0x196, (q15_t)0xf1d5, (q15_t)0x194, (q15_t)0xf1e2, (q15_t)0x191, (q15_t)0xf1ee, + (q15_t)0x18e, (q15_t)0xf1fa, (q15_t)0x18b, (q15_t)0xf207, (q15_t)0x189, (q15_t)0xf213, (q15_t)0x186, (q15_t)0xf21f, + (q15_t)0x183, (q15_t)0xf22b, (q15_t)0x180, (q15_t)0xf238, (q15_t)0x17e, (q15_t)0xf244, (q15_t)0x17b, (q15_t)0xf250, + (q15_t)0x178, (q15_t)0xf25c, (q15_t)0x176, (q15_t)0xf269, (q15_t)0x173, (q15_t)0xf275, (q15_t)0x170, (q15_t)0xf281, + (q15_t)0x16e, (q15_t)0xf28e, (q15_t)0x16b, (q15_t)0xf29a, (q15_t)0x168, (q15_t)0xf2a6, (q15_t)0x166, (q15_t)0xf2b2, + (q15_t)0x163, (q15_t)0xf2bf, (q15_t)0x161, (q15_t)0xf2cb, (q15_t)0x15e, (q15_t)0xf2d7, (q15_t)0x15b, (q15_t)0xf2e4, + (q15_t)0x159, (q15_t)0xf2f0, (q15_t)0x156, (q15_t)0xf2fc, (q15_t)0x154, (q15_t)0xf308, (q15_t)0x151, (q15_t)0xf315, + (q15_t)0x14f, (q15_t)0xf321, (q15_t)0x14c, (q15_t)0xf32d, (q15_t)0x14a, (q15_t)0xf33a, (q15_t)0x147, (q15_t)0xf346, + (q15_t)0x145, (q15_t)0xf352, (q15_t)0x142, (q15_t)0xf35f, (q15_t)0x140, (q15_t)0xf36b, (q15_t)0x13d, (q15_t)0xf377, + (q15_t)0x13b, (q15_t)0xf384, (q15_t)0x138, (q15_t)0xf390, (q15_t)0x136, (q15_t)0xf39c, (q15_t)0x134, (q15_t)0xf3a9, + (q15_t)0x131, (q15_t)0xf3b5, (q15_t)0x12f, (q15_t)0xf3c1, (q15_t)0x12c, (q15_t)0xf3ce, (q15_t)0x12a, (q15_t)0xf3da, + (q15_t)0x128, (q15_t)0xf3e6, (q15_t)0x125, (q15_t)0xf3f3, (q15_t)0x123, (q15_t)0xf3ff, (q15_t)0x120, (q15_t)0xf40b, + (q15_t)0x11e, (q15_t)0xf418, (q15_t)0x11c, (q15_t)0xf424, (q15_t)0x119, (q15_t)0xf430, (q15_t)0x117, (q15_t)0xf43d, + (q15_t)0x115, (q15_t)0xf449, (q15_t)0x113, (q15_t)0xf455, (q15_t)0x110, (q15_t)0xf462, (q15_t)0x10e, (q15_t)0xf46e, + (q15_t)0x10c, (q15_t)0xf47b, (q15_t)0x109, (q15_t)0xf487, (q15_t)0x107, (q15_t)0xf493, (q15_t)0x105, (q15_t)0xf4a0, + (q15_t)0x103, (q15_t)0xf4ac, (q15_t)0x100, (q15_t)0xf4b8, (q15_t)0xfe, (q15_t)0xf4c5, (q15_t)0xfc, (q15_t)0xf4d1, + (q15_t)0xfa, (q15_t)0xf4dd, (q15_t)0xf8, (q15_t)0xf4ea, (q15_t)0xf6, (q15_t)0xf4f6, (q15_t)0xf3, (q15_t)0xf503, + (q15_t)0xf1, (q15_t)0xf50f, (q15_t)0xef, (q15_t)0xf51b, (q15_t)0xed, (q15_t)0xf528, (q15_t)0xeb, (q15_t)0xf534, + (q15_t)0xe9, (q15_t)0xf540, (q15_t)0xe7, (q15_t)0xf54d, (q15_t)0xe4, (q15_t)0xf559, (q15_t)0xe2, (q15_t)0xf566, + (q15_t)0xe0, (q15_t)0xf572, (q15_t)0xde, (q15_t)0xf57e, (q15_t)0xdc, (q15_t)0xf58b, (q15_t)0xda, (q15_t)0xf597, + (q15_t)0xd8, (q15_t)0xf5a4, (q15_t)0xd6, (q15_t)0xf5b0, (q15_t)0xd4, (q15_t)0xf5bc, (q15_t)0xd2, (q15_t)0xf5c9, + (q15_t)0xd0, (q15_t)0xf5d5, (q15_t)0xce, (q15_t)0xf5e2, (q15_t)0xcc, (q15_t)0xf5ee, (q15_t)0xca, (q15_t)0xf5fa, + (q15_t)0xc8, (q15_t)0xf607, (q15_t)0xc6, (q15_t)0xf613, (q15_t)0xc4, (q15_t)0xf620, (q15_t)0xc2, (q15_t)0xf62c, + (q15_t)0xc0, (q15_t)0xf639, (q15_t)0xbe, (q15_t)0xf645, (q15_t)0xbd, (q15_t)0xf651, (q15_t)0xbb, (q15_t)0xf65e, + (q15_t)0xb9, (q15_t)0xf66a, (q15_t)0xb7, (q15_t)0xf677, (q15_t)0xb5, (q15_t)0xf683, (q15_t)0xb3, (q15_t)0xf690, + (q15_t)0xb1, (q15_t)0xf69c, (q15_t)0xaf, (q15_t)0xf6a8, (q15_t)0xae, (q15_t)0xf6b5, (q15_t)0xac, (q15_t)0xf6c1, + (q15_t)0xaa, (q15_t)0xf6ce, (q15_t)0xa8, (q15_t)0xf6da, (q15_t)0xa6, (q15_t)0xf6e7, (q15_t)0xa5, (q15_t)0xf6f3, + (q15_t)0xa3, (q15_t)0xf6ff, (q15_t)0xa1, (q15_t)0xf70c, (q15_t)0x9f, (q15_t)0xf718, (q15_t)0x9e, (q15_t)0xf725, + (q15_t)0x9c, (q15_t)0xf731, (q15_t)0x9a, (q15_t)0xf73e, (q15_t)0x98, (q15_t)0xf74a, (q15_t)0x97, (q15_t)0xf757, + (q15_t)0x95, (q15_t)0xf763, (q15_t)0x93, (q15_t)0xf76f, (q15_t)0x92, (q15_t)0xf77c, (q15_t)0x90, (q15_t)0xf788, + (q15_t)0x8e, (q15_t)0xf795, (q15_t)0x8d, (q15_t)0xf7a1, (q15_t)0x8b, (q15_t)0xf7ae, (q15_t)0x89, (q15_t)0xf7ba, + (q15_t)0x88, (q15_t)0xf7c7, (q15_t)0x86, (q15_t)0xf7d3, (q15_t)0x85, (q15_t)0xf7e0, (q15_t)0x83, (q15_t)0xf7ec, + (q15_t)0x81, (q15_t)0xf7f9, (q15_t)0x80, (q15_t)0xf805, (q15_t)0x7e, (q15_t)0xf811, (q15_t)0x7d, (q15_t)0xf81e, + (q15_t)0x7b, (q15_t)0xf82a, (q15_t)0x7a, (q15_t)0xf837, (q15_t)0x78, (q15_t)0xf843, (q15_t)0x77, (q15_t)0xf850, + (q15_t)0x75, (q15_t)0xf85c, (q15_t)0x74, (q15_t)0xf869, (q15_t)0x72, (q15_t)0xf875, (q15_t)0x71, (q15_t)0xf882, + (q15_t)0x6f, (q15_t)0xf88e, (q15_t)0x6e, (q15_t)0xf89b, (q15_t)0x6c, (q15_t)0xf8a7, (q15_t)0x6b, (q15_t)0xf8b4, + (q15_t)0x69, (q15_t)0xf8c0, (q15_t)0x68, (q15_t)0xf8cd, (q15_t)0x67, (q15_t)0xf8d9, (q15_t)0x65, (q15_t)0xf8e6, + (q15_t)0x64, (q15_t)0xf8f2, (q15_t)0x62, (q15_t)0xf8ff, (q15_t)0x61, (q15_t)0xf90b, (q15_t)0x60, (q15_t)0xf918, + (q15_t)0x5e, (q15_t)0xf924, (q15_t)0x5d, (q15_t)0xf931, (q15_t)0x5c, (q15_t)0xf93d, (q15_t)0x5a, (q15_t)0xf94a, + (q15_t)0x59, (q15_t)0xf956, (q15_t)0x58, (q15_t)0xf963, (q15_t)0x56, (q15_t)0xf96f, (q15_t)0x55, (q15_t)0xf97c, + (q15_t)0x54, (q15_t)0xf988, (q15_t)0x53, (q15_t)0xf995, (q15_t)0x51, (q15_t)0xf9a1, (q15_t)0x50, (q15_t)0xf9ae, + (q15_t)0x4f, (q15_t)0xf9ba, (q15_t)0x4e, (q15_t)0xf9c7, (q15_t)0x4c, (q15_t)0xf9d3, (q15_t)0x4b, (q15_t)0xf9e0, + (q15_t)0x4a, (q15_t)0xf9ec, (q15_t)0x49, (q15_t)0xf9f9, (q15_t)0x48, (q15_t)0xfa05, (q15_t)0x47, (q15_t)0xfa12, + (q15_t)0x45, (q15_t)0xfa1e, (q15_t)0x44, (q15_t)0xfa2b, (q15_t)0x43, (q15_t)0xfa37, (q15_t)0x42, (q15_t)0xfa44, + (q15_t)0x41, (q15_t)0xfa50, (q15_t)0x40, (q15_t)0xfa5d, (q15_t)0x3f, (q15_t)0xfa69, (q15_t)0x3d, (q15_t)0xfa76, + (q15_t)0x3c, (q15_t)0xfa82, (q15_t)0x3b, (q15_t)0xfa8f, (q15_t)0x3a, (q15_t)0xfa9b, (q15_t)0x39, (q15_t)0xfaa8, + (q15_t)0x38, (q15_t)0xfab4, (q15_t)0x37, (q15_t)0xfac1, (q15_t)0x36, (q15_t)0xfacd, (q15_t)0x35, (q15_t)0xfada, + (q15_t)0x34, (q15_t)0xfae6, (q15_t)0x33, (q15_t)0xfaf3, (q15_t)0x32, (q15_t)0xfb00, (q15_t)0x31, (q15_t)0xfb0c, + (q15_t)0x30, (q15_t)0xfb19, (q15_t)0x2f, (q15_t)0xfb25, (q15_t)0x2e, (q15_t)0xfb32, (q15_t)0x2d, (q15_t)0xfb3e, + (q15_t)0x2c, (q15_t)0xfb4b, (q15_t)0x2b, (q15_t)0xfb57, (q15_t)0x2b, (q15_t)0xfb64, (q15_t)0x2a, (q15_t)0xfb70, + (q15_t)0x29, (q15_t)0xfb7d, (q15_t)0x28, (q15_t)0xfb89, (q15_t)0x27, (q15_t)0xfb96, (q15_t)0x26, (q15_t)0xfba2, + (q15_t)0x25, (q15_t)0xfbaf, (q15_t)0x24, (q15_t)0xfbbc, (q15_t)0x24, (q15_t)0xfbc8, (q15_t)0x23, (q15_t)0xfbd5, + (q15_t)0x22, (q15_t)0xfbe1, (q15_t)0x21, (q15_t)0xfbee, (q15_t)0x20, (q15_t)0xfbfa, (q15_t)0x20, (q15_t)0xfc07, + (q15_t)0x1f, (q15_t)0xfc13, (q15_t)0x1e, (q15_t)0xfc20, (q15_t)0x1d, (q15_t)0xfc2c, (q15_t)0x1d, (q15_t)0xfc39, + (q15_t)0x1c, (q15_t)0xfc45, (q15_t)0x1b, (q15_t)0xfc52, (q15_t)0x1a, (q15_t)0xfc5f, (q15_t)0x1a, (q15_t)0xfc6b, + (q15_t)0x19, (q15_t)0xfc78, (q15_t)0x18, (q15_t)0xfc84, (q15_t)0x18, (q15_t)0xfc91, (q15_t)0x17, (q15_t)0xfc9d, + (q15_t)0x16, (q15_t)0xfcaa, (q15_t)0x16, (q15_t)0xfcb6, (q15_t)0x15, (q15_t)0xfcc3, (q15_t)0x14, (q15_t)0xfcd0, + (q15_t)0x14, (q15_t)0xfcdc, (q15_t)0x13, (q15_t)0xfce9, (q15_t)0x13, (q15_t)0xfcf5, (q15_t)0x12, (q15_t)0xfd02, + (q15_t)0x11, (q15_t)0xfd0e, (q15_t)0x11, (q15_t)0xfd1b, (q15_t)0x10, (q15_t)0xfd27, (q15_t)0x10, (q15_t)0xfd34, + (q15_t)0xf, (q15_t)0xfd40, (q15_t)0xf, (q15_t)0xfd4d, (q15_t)0xe, (q15_t)0xfd5a, (q15_t)0xe, (q15_t)0xfd66, + (q15_t)0xd, (q15_t)0xfd73, (q15_t)0xd, (q15_t)0xfd7f, (q15_t)0xc, (q15_t)0xfd8c, (q15_t)0xc, (q15_t)0xfd98, + (q15_t)0xb, (q15_t)0xfda5, (q15_t)0xb, (q15_t)0xfdb2, (q15_t)0xa, (q15_t)0xfdbe, (q15_t)0xa, (q15_t)0xfdcb, + (q15_t)0x9, (q15_t)0xfdd7, (q15_t)0x9, (q15_t)0xfde4, (q15_t)0x9, (q15_t)0xfdf0, (q15_t)0x8, (q15_t)0xfdfd, + (q15_t)0x8, (q15_t)0xfe09, (q15_t)0x7, (q15_t)0xfe16, (q15_t)0x7, (q15_t)0xfe23, (q15_t)0x7, (q15_t)0xfe2f, + (q15_t)0x6, (q15_t)0xfe3c, (q15_t)0x6, (q15_t)0xfe48, (q15_t)0x6, (q15_t)0xfe55, (q15_t)0x5, (q15_t)0xfe61, + (q15_t)0x5, (q15_t)0xfe6e, (q15_t)0x5, (q15_t)0xfe7a, (q15_t)0x4, (q15_t)0xfe87, (q15_t)0x4, (q15_t)0xfe94, + (q15_t)0x4, (q15_t)0xfea0, (q15_t)0x4, (q15_t)0xfead, (q15_t)0x3, (q15_t)0xfeb9, (q15_t)0x3, (q15_t)0xfec6, + (q15_t)0x3, (q15_t)0xfed2, (q15_t)0x3, (q15_t)0xfedf, (q15_t)0x2, (q15_t)0xfeec, (q15_t)0x2, (q15_t)0xfef8, + (q15_t)0x2, (q15_t)0xff05, (q15_t)0x2, (q15_t)0xff11, (q15_t)0x2, (q15_t)0xff1e, (q15_t)0x1, (q15_t)0xff2a, + (q15_t)0x1, (q15_t)0xff37, (q15_t)0x1, (q15_t)0xff44, (q15_t)0x1, (q15_t)0xff50, (q15_t)0x1, (q15_t)0xff5d, + (q15_t)0x1, (q15_t)0xff69, (q15_t)0x1, (q15_t)0xff76, (q15_t)0x0, (q15_t)0xff82, (q15_t)0x0, (q15_t)0xff8f, + (q15_t)0x0, (q15_t)0xff9b, (q15_t)0x0, (q15_t)0xffa8, (q15_t)0x0, (q15_t)0xffb5, (q15_t)0x0, (q15_t)0xffc1, + (q15_t)0x0, (q15_t)0xffce, (q15_t)0x0, (q15_t)0xffda, (q15_t)0x0, (q15_t)0xffe7, (q15_t)0x0, (q15_t)0xfff3, + (q15_t)0x0, (q15_t)0x0, (q15_t)0x0, (q15_t)0xd, (q15_t)0x0, (q15_t)0x19, (q15_t)0x0, (q15_t)0x26, + (q15_t)0x0, (q15_t)0x32, (q15_t)0x0, (q15_t)0x3f, (q15_t)0x0, (q15_t)0x4b, (q15_t)0x0, (q15_t)0x58, + (q15_t)0x0, (q15_t)0x65, (q15_t)0x0, (q15_t)0x71, (q15_t)0x0, (q15_t)0x7e, (q15_t)0x1, (q15_t)0x8a, + (q15_t)0x1, (q15_t)0x97, (q15_t)0x1, (q15_t)0xa3, (q15_t)0x1, (q15_t)0xb0, (q15_t)0x1, (q15_t)0xbc, + (q15_t)0x1, (q15_t)0xc9, (q15_t)0x1, (q15_t)0xd6, (q15_t)0x2, (q15_t)0xe2, (q15_t)0x2, (q15_t)0xef, + (q15_t)0x2, (q15_t)0xfb, (q15_t)0x2, (q15_t)0x108, (q15_t)0x2, (q15_t)0x114, (q15_t)0x3, (q15_t)0x121, + (q15_t)0x3, (q15_t)0x12e, (q15_t)0x3, (q15_t)0x13a, (q15_t)0x3, (q15_t)0x147, (q15_t)0x4, (q15_t)0x153, + (q15_t)0x4, (q15_t)0x160, (q15_t)0x4, (q15_t)0x16c, (q15_t)0x4, (q15_t)0x179, (q15_t)0x5, (q15_t)0x186, + (q15_t)0x5, (q15_t)0x192, (q15_t)0x5, (q15_t)0x19f, (q15_t)0x6, (q15_t)0x1ab, (q15_t)0x6, (q15_t)0x1b8, + (q15_t)0x6, (q15_t)0x1c4, (q15_t)0x7, (q15_t)0x1d1, (q15_t)0x7, (q15_t)0x1dd, (q15_t)0x7, (q15_t)0x1ea, + (q15_t)0x8, (q15_t)0x1f7, (q15_t)0x8, (q15_t)0x203, (q15_t)0x9, (q15_t)0x210, (q15_t)0x9, (q15_t)0x21c, + (q15_t)0x9, (q15_t)0x229, (q15_t)0xa, (q15_t)0x235, (q15_t)0xa, (q15_t)0x242, (q15_t)0xb, (q15_t)0x24e, + (q15_t)0xb, (q15_t)0x25b, (q15_t)0xc, (q15_t)0x268, (q15_t)0xc, (q15_t)0x274, (q15_t)0xd, (q15_t)0x281, + (q15_t)0xd, (q15_t)0x28d, (q15_t)0xe, (q15_t)0x29a, (q15_t)0xe, (q15_t)0x2a6, (q15_t)0xf, (q15_t)0x2b3, + (q15_t)0xf, (q15_t)0x2c0, (q15_t)0x10, (q15_t)0x2cc, (q15_t)0x10, (q15_t)0x2d9, (q15_t)0x11, (q15_t)0x2e5, + (q15_t)0x11, (q15_t)0x2f2, (q15_t)0x12, (q15_t)0x2fe, (q15_t)0x13, (q15_t)0x30b, (q15_t)0x13, (q15_t)0x317, + (q15_t)0x14, (q15_t)0x324, (q15_t)0x14, (q15_t)0x330, (q15_t)0x15, (q15_t)0x33d, (q15_t)0x16, (q15_t)0x34a, + (q15_t)0x16, (q15_t)0x356, (q15_t)0x17, (q15_t)0x363, (q15_t)0x18, (q15_t)0x36f, (q15_t)0x18, (q15_t)0x37c, + (q15_t)0x19, (q15_t)0x388, (q15_t)0x1a, (q15_t)0x395, (q15_t)0x1a, (q15_t)0x3a1, (q15_t)0x1b, (q15_t)0x3ae, + (q15_t)0x1c, (q15_t)0x3bb, (q15_t)0x1d, (q15_t)0x3c7, (q15_t)0x1d, (q15_t)0x3d4, (q15_t)0x1e, (q15_t)0x3e0, + (q15_t)0x1f, (q15_t)0x3ed, (q15_t)0x20, (q15_t)0x3f9, (q15_t)0x20, (q15_t)0x406, (q15_t)0x21, (q15_t)0x412, + (q15_t)0x22, (q15_t)0x41f, (q15_t)0x23, (q15_t)0x42b, (q15_t)0x24, (q15_t)0x438, (q15_t)0x24, (q15_t)0x444, + (q15_t)0x25, (q15_t)0x451, (q15_t)0x26, (q15_t)0x45e, (q15_t)0x27, (q15_t)0x46a, (q15_t)0x28, (q15_t)0x477, + (q15_t)0x29, (q15_t)0x483, (q15_t)0x2a, (q15_t)0x490, (q15_t)0x2b, (q15_t)0x49c, (q15_t)0x2b, (q15_t)0x4a9, + (q15_t)0x2c, (q15_t)0x4b5, (q15_t)0x2d, (q15_t)0x4c2, (q15_t)0x2e, (q15_t)0x4ce, (q15_t)0x2f, (q15_t)0x4db, + (q15_t)0x30, (q15_t)0x4e7, (q15_t)0x31, (q15_t)0x4f4, (q15_t)0x32, (q15_t)0x500, (q15_t)0x33, (q15_t)0x50d, + (q15_t)0x34, (q15_t)0x51a, (q15_t)0x35, (q15_t)0x526, (q15_t)0x36, (q15_t)0x533, (q15_t)0x37, (q15_t)0x53f, + (q15_t)0x38, (q15_t)0x54c, (q15_t)0x39, (q15_t)0x558, (q15_t)0x3a, (q15_t)0x565, (q15_t)0x3b, (q15_t)0x571, + (q15_t)0x3c, (q15_t)0x57e, (q15_t)0x3d, (q15_t)0x58a, (q15_t)0x3f, (q15_t)0x597, (q15_t)0x40, (q15_t)0x5a3, + (q15_t)0x41, (q15_t)0x5b0, (q15_t)0x42, (q15_t)0x5bc, (q15_t)0x43, (q15_t)0x5c9, (q15_t)0x44, (q15_t)0x5d5, + (q15_t)0x45, (q15_t)0x5e2, (q15_t)0x47, (q15_t)0x5ee, (q15_t)0x48, (q15_t)0x5fb, (q15_t)0x49, (q15_t)0x607, + (q15_t)0x4a, (q15_t)0x614, (q15_t)0x4b, (q15_t)0x620, (q15_t)0x4c, (q15_t)0x62d, (q15_t)0x4e, (q15_t)0x639, + (q15_t)0x4f, (q15_t)0x646, (q15_t)0x50, (q15_t)0x652, (q15_t)0x51, (q15_t)0x65f, (q15_t)0x53, (q15_t)0x66b, + (q15_t)0x54, (q15_t)0x678, (q15_t)0x55, (q15_t)0x684, (q15_t)0x56, (q15_t)0x691, (q15_t)0x58, (q15_t)0x69d, + (q15_t)0x59, (q15_t)0x6aa, (q15_t)0x5a, (q15_t)0x6b6, (q15_t)0x5c, (q15_t)0x6c3, (q15_t)0x5d, (q15_t)0x6cf, + (q15_t)0x5e, (q15_t)0x6dc, (q15_t)0x60, (q15_t)0x6e8, (q15_t)0x61, (q15_t)0x6f5, (q15_t)0x62, (q15_t)0x701, + (q15_t)0x64, (q15_t)0x70e, (q15_t)0x65, (q15_t)0x71a, (q15_t)0x67, (q15_t)0x727, (q15_t)0x68, (q15_t)0x733, + (q15_t)0x69, (q15_t)0x740, (q15_t)0x6b, (q15_t)0x74c, (q15_t)0x6c, (q15_t)0x759, (q15_t)0x6e, (q15_t)0x765, + (q15_t)0x6f, (q15_t)0x772, (q15_t)0x71, (q15_t)0x77e, (q15_t)0x72, (q15_t)0x78b, (q15_t)0x74, (q15_t)0x797, + (q15_t)0x75, (q15_t)0x7a4, (q15_t)0x77, (q15_t)0x7b0, (q15_t)0x78, (q15_t)0x7bd, (q15_t)0x7a, (q15_t)0x7c9, + (q15_t)0x7b, (q15_t)0x7d6, (q15_t)0x7d, (q15_t)0x7e2, (q15_t)0x7e, (q15_t)0x7ef, (q15_t)0x80, (q15_t)0x7fb, + (q15_t)0x81, (q15_t)0x807, (q15_t)0x83, (q15_t)0x814, (q15_t)0x85, (q15_t)0x820, (q15_t)0x86, (q15_t)0x82d, + (q15_t)0x88, (q15_t)0x839, (q15_t)0x89, (q15_t)0x846, (q15_t)0x8b, (q15_t)0x852, (q15_t)0x8d, (q15_t)0x85f, + (q15_t)0x8e, (q15_t)0x86b, (q15_t)0x90, (q15_t)0x878, (q15_t)0x92, (q15_t)0x884, (q15_t)0x93, (q15_t)0x891, + (q15_t)0x95, (q15_t)0x89d, (q15_t)0x97, (q15_t)0x8a9, (q15_t)0x98, (q15_t)0x8b6, (q15_t)0x9a, (q15_t)0x8c2, + (q15_t)0x9c, (q15_t)0x8cf, (q15_t)0x9e, (q15_t)0x8db, (q15_t)0x9f, (q15_t)0x8e8, (q15_t)0xa1, (q15_t)0x8f4, + (q15_t)0xa3, (q15_t)0x901, (q15_t)0xa5, (q15_t)0x90d, (q15_t)0xa6, (q15_t)0x919, (q15_t)0xa8, (q15_t)0x926, + (q15_t)0xaa, (q15_t)0x932, (q15_t)0xac, (q15_t)0x93f, (q15_t)0xae, (q15_t)0x94b, (q15_t)0xaf, (q15_t)0x958, + (q15_t)0xb1, (q15_t)0x964, (q15_t)0xb3, (q15_t)0x970, (q15_t)0xb5, (q15_t)0x97d, (q15_t)0xb7, (q15_t)0x989, + (q15_t)0xb9, (q15_t)0x996, (q15_t)0xbb, (q15_t)0x9a2, (q15_t)0xbd, (q15_t)0x9af, (q15_t)0xbe, (q15_t)0x9bb, + (q15_t)0xc0, (q15_t)0x9c7, (q15_t)0xc2, (q15_t)0x9d4, (q15_t)0xc4, (q15_t)0x9e0, (q15_t)0xc6, (q15_t)0x9ed, + (q15_t)0xc8, (q15_t)0x9f9, (q15_t)0xca, (q15_t)0xa06, (q15_t)0xcc, (q15_t)0xa12, (q15_t)0xce, (q15_t)0xa1e, + (q15_t)0xd0, (q15_t)0xa2b, (q15_t)0xd2, (q15_t)0xa37, (q15_t)0xd4, (q15_t)0xa44, (q15_t)0xd6, (q15_t)0xa50, + (q15_t)0xd8, (q15_t)0xa5c, (q15_t)0xda, (q15_t)0xa69, (q15_t)0xdc, (q15_t)0xa75, (q15_t)0xde, (q15_t)0xa82, + (q15_t)0xe0, (q15_t)0xa8e, (q15_t)0xe2, (q15_t)0xa9a, (q15_t)0xe4, (q15_t)0xaa7, (q15_t)0xe7, (q15_t)0xab3, + (q15_t)0xe9, (q15_t)0xac0, (q15_t)0xeb, (q15_t)0xacc, (q15_t)0xed, (q15_t)0xad8, (q15_t)0xef, (q15_t)0xae5, + (q15_t)0xf1, (q15_t)0xaf1, (q15_t)0xf3, (q15_t)0xafd, (q15_t)0xf6, (q15_t)0xb0a, (q15_t)0xf8, (q15_t)0xb16, + (q15_t)0xfa, (q15_t)0xb23, (q15_t)0xfc, (q15_t)0xb2f, (q15_t)0xfe, (q15_t)0xb3b, (q15_t)0x100, (q15_t)0xb48, + (q15_t)0x103, (q15_t)0xb54, (q15_t)0x105, (q15_t)0xb60, (q15_t)0x107, (q15_t)0xb6d, (q15_t)0x109, (q15_t)0xb79, + (q15_t)0x10c, (q15_t)0xb85, (q15_t)0x10e, (q15_t)0xb92, (q15_t)0x110, (q15_t)0xb9e, (q15_t)0x113, (q15_t)0xbab, + (q15_t)0x115, (q15_t)0xbb7, (q15_t)0x117, (q15_t)0xbc3, (q15_t)0x119, (q15_t)0xbd0, (q15_t)0x11c, (q15_t)0xbdc, + (q15_t)0x11e, (q15_t)0xbe8, (q15_t)0x120, (q15_t)0xbf5, (q15_t)0x123, (q15_t)0xc01, (q15_t)0x125, (q15_t)0xc0d, + (q15_t)0x128, (q15_t)0xc1a, (q15_t)0x12a, (q15_t)0xc26, (q15_t)0x12c, (q15_t)0xc32, (q15_t)0x12f, (q15_t)0xc3f, + (q15_t)0x131, (q15_t)0xc4b, (q15_t)0x134, (q15_t)0xc57, (q15_t)0x136, (q15_t)0xc64, (q15_t)0x138, (q15_t)0xc70, + (q15_t)0x13b, (q15_t)0xc7c, (q15_t)0x13d, (q15_t)0xc89, (q15_t)0x140, (q15_t)0xc95, (q15_t)0x142, (q15_t)0xca1, + (q15_t)0x145, (q15_t)0xcae, (q15_t)0x147, (q15_t)0xcba, (q15_t)0x14a, (q15_t)0xcc6, (q15_t)0x14c, (q15_t)0xcd3, + (q15_t)0x14f, (q15_t)0xcdf, (q15_t)0x151, (q15_t)0xceb, (q15_t)0x154, (q15_t)0xcf8, (q15_t)0x156, (q15_t)0xd04, + (q15_t)0x159, (q15_t)0xd10, (q15_t)0x15b, (q15_t)0xd1c, (q15_t)0x15e, (q15_t)0xd29, (q15_t)0x161, (q15_t)0xd35, + (q15_t)0x163, (q15_t)0xd41, (q15_t)0x166, (q15_t)0xd4e, (q15_t)0x168, (q15_t)0xd5a, (q15_t)0x16b, (q15_t)0xd66, + (q15_t)0x16e, (q15_t)0xd72, (q15_t)0x170, (q15_t)0xd7f, (q15_t)0x173, (q15_t)0xd8b, (q15_t)0x176, (q15_t)0xd97, + (q15_t)0x178, (q15_t)0xda4, (q15_t)0x17b, (q15_t)0xdb0, (q15_t)0x17e, (q15_t)0xdbc, (q15_t)0x180, (q15_t)0xdc8, + (q15_t)0x183, (q15_t)0xdd5, (q15_t)0x186, (q15_t)0xde1, (q15_t)0x189, (q15_t)0xded, (q15_t)0x18b, (q15_t)0xdf9, + (q15_t)0x18e, (q15_t)0xe06, (q15_t)0x191, (q15_t)0xe12, (q15_t)0x194, (q15_t)0xe1e, (q15_t)0x196, (q15_t)0xe2b, + (q15_t)0x199, (q15_t)0xe37, (q15_t)0x19c, (q15_t)0xe43, (q15_t)0x19f, (q15_t)0xe4f, (q15_t)0x1a2, (q15_t)0xe5c, + (q15_t)0x1a4, (q15_t)0xe68, (q15_t)0x1a7, (q15_t)0xe74, (q15_t)0x1aa, (q15_t)0xe80, (q15_t)0x1ad, (q15_t)0xe8c, + (q15_t)0x1b0, (q15_t)0xe99, (q15_t)0x1b3, (q15_t)0xea5, (q15_t)0x1b6, (q15_t)0xeb1, (q15_t)0x1b8, (q15_t)0xebd, + (q15_t)0x1bb, (q15_t)0xeca, (q15_t)0x1be, (q15_t)0xed6, (q15_t)0x1c1, (q15_t)0xee2, (q15_t)0x1c4, (q15_t)0xeee, + (q15_t)0x1c7, (q15_t)0xefb, (q15_t)0x1ca, (q15_t)0xf07, (q15_t)0x1cd, (q15_t)0xf13, (q15_t)0x1d0, (q15_t)0xf1f, + (q15_t)0x1d3, (q15_t)0xf2b, (q15_t)0x1d6, (q15_t)0xf38, (q15_t)0x1d9, (q15_t)0xf44, (q15_t)0x1dc, (q15_t)0xf50, + (q15_t)0x1df, (q15_t)0xf5c, (q15_t)0x1e2, (q15_t)0xf68, (q15_t)0x1e5, (q15_t)0xf75, (q15_t)0x1e8, (q15_t)0xf81, + (q15_t)0x1eb, (q15_t)0xf8d, (q15_t)0x1ee, (q15_t)0xf99, (q15_t)0x1f1, (q15_t)0xfa5, (q15_t)0x1f4, (q15_t)0xfb2, + (q15_t)0x1f7, (q15_t)0xfbe, (q15_t)0x1fa, (q15_t)0xfca, (q15_t)0x1fd, (q15_t)0xfd6, (q15_t)0x201, (q15_t)0xfe2, + (q15_t)0x204, (q15_t)0xfee, (q15_t)0x207, (q15_t)0xffb, (q15_t)0x20a, (q15_t)0x1007, (q15_t)0x20d, (q15_t)0x1013, + (q15_t)0x210, (q15_t)0x101f, (q15_t)0x213, (q15_t)0x102b, (q15_t)0x217, (q15_t)0x1037, (q15_t)0x21a, (q15_t)0x1044, + (q15_t)0x21d, (q15_t)0x1050, (q15_t)0x220, (q15_t)0x105c, (q15_t)0x223, (q15_t)0x1068, (q15_t)0x227, (q15_t)0x1074, + (q15_t)0x22a, (q15_t)0x1080, (q15_t)0x22d, (q15_t)0x108c, (q15_t)0x230, (q15_t)0x1099, (q15_t)0x234, (q15_t)0x10a5, + (q15_t)0x237, (q15_t)0x10b1, (q15_t)0x23a, (q15_t)0x10bd, (q15_t)0x23e, (q15_t)0x10c9, (q15_t)0x241, (q15_t)0x10d5, + (q15_t)0x244, (q15_t)0x10e1, (q15_t)0x247, (q15_t)0x10ed, (q15_t)0x24b, (q15_t)0x10fa, (q15_t)0x24e, (q15_t)0x1106, + (q15_t)0x251, (q15_t)0x1112, (q15_t)0x255, (q15_t)0x111e, (q15_t)0x258, (q15_t)0x112a, (q15_t)0x25c, (q15_t)0x1136, + (q15_t)0x25f, (q15_t)0x1142, (q15_t)0x262, (q15_t)0x114e, (q15_t)0x266, (q15_t)0x115a, (q15_t)0x269, (q15_t)0x1167, + (q15_t)0x26d, (q15_t)0x1173, (q15_t)0x270, (q15_t)0x117f, (q15_t)0x273, (q15_t)0x118b, (q15_t)0x277, (q15_t)0x1197, + (q15_t)0x27a, (q15_t)0x11a3, (q15_t)0x27e, (q15_t)0x11af, (q15_t)0x281, (q15_t)0x11bb, (q15_t)0x285, (q15_t)0x11c7, + (q15_t)0x288, (q15_t)0x11d3, (q15_t)0x28c, (q15_t)0x11df, (q15_t)0x28f, (q15_t)0x11eb, (q15_t)0x293, (q15_t)0x11f7, + (q15_t)0x296, (q15_t)0x1204, (q15_t)0x29a, (q15_t)0x1210, (q15_t)0x29d, (q15_t)0x121c, (q15_t)0x2a1, (q15_t)0x1228, + (q15_t)0x2a5, (q15_t)0x1234, (q15_t)0x2a8, (q15_t)0x1240, (q15_t)0x2ac, (q15_t)0x124c, (q15_t)0x2af, (q15_t)0x1258, + (q15_t)0x2b3, (q15_t)0x1264, (q15_t)0x2b7, (q15_t)0x1270, (q15_t)0x2ba, (q15_t)0x127c, (q15_t)0x2be, (q15_t)0x1288, + (q15_t)0x2c1, (q15_t)0x1294, (q15_t)0x2c5, (q15_t)0x12a0, (q15_t)0x2c9, (q15_t)0x12ac, (q15_t)0x2cc, (q15_t)0x12b8, + (q15_t)0x2d0, (q15_t)0x12c4, (q15_t)0x2d4, (q15_t)0x12d0, (q15_t)0x2d8, (q15_t)0x12dc, (q15_t)0x2db, (q15_t)0x12e8, + (q15_t)0x2df, (q15_t)0x12f4, (q15_t)0x2e3, (q15_t)0x1300, (q15_t)0x2e6, (q15_t)0x130c, (q15_t)0x2ea, (q15_t)0x1318, + (q15_t)0x2ee, (q15_t)0x1324, (q15_t)0x2f2, (q15_t)0x1330, (q15_t)0x2f5, (q15_t)0x133c, (q15_t)0x2f9, (q15_t)0x1348, + (q15_t)0x2fd, (q15_t)0x1354, (q15_t)0x301, (q15_t)0x1360, (q15_t)0x305, (q15_t)0x136c, (q15_t)0x308, (q15_t)0x1378, + (q15_t)0x30c, (q15_t)0x1384, (q15_t)0x310, (q15_t)0x1390, (q15_t)0x314, (q15_t)0x139c, (q15_t)0x318, (q15_t)0x13a8, + (q15_t)0x31c, (q15_t)0x13b4, (q15_t)0x320, (q15_t)0x13c0, (q15_t)0x323, (q15_t)0x13cc, (q15_t)0x327, (q15_t)0x13d8, + (q15_t)0x32b, (q15_t)0x13e4, (q15_t)0x32f, (q15_t)0x13f0, (q15_t)0x333, (q15_t)0x13fb, (q15_t)0x337, (q15_t)0x1407, + (q15_t)0x33b, (q15_t)0x1413, (q15_t)0x33f, (q15_t)0x141f, (q15_t)0x343, (q15_t)0x142b, (q15_t)0x347, (q15_t)0x1437, + (q15_t)0x34b, (q15_t)0x1443, (q15_t)0x34f, (q15_t)0x144f, (q15_t)0x353, (q15_t)0x145b, (q15_t)0x357, (q15_t)0x1467, + (q15_t)0x35b, (q15_t)0x1473, (q15_t)0x35f, (q15_t)0x147f, (q15_t)0x363, (q15_t)0x148b, (q15_t)0x367, (q15_t)0x1496, + (q15_t)0x36b, (q15_t)0x14a2, (q15_t)0x36f, (q15_t)0x14ae, (q15_t)0x373, (q15_t)0x14ba, (q15_t)0x377, (q15_t)0x14c6, + (q15_t)0x37b, (q15_t)0x14d2, (q15_t)0x37f, (q15_t)0x14de, (q15_t)0x383, (q15_t)0x14ea, (q15_t)0x387, (q15_t)0x14f6, + (q15_t)0x38c, (q15_t)0x1501, (q15_t)0x390, (q15_t)0x150d, (q15_t)0x394, (q15_t)0x1519, (q15_t)0x398, (q15_t)0x1525, + (q15_t)0x39c, (q15_t)0x1531, (q15_t)0x3a0, (q15_t)0x153d, (q15_t)0x3a5, (q15_t)0x1549, (q15_t)0x3a9, (q15_t)0x1554, + (q15_t)0x3ad, (q15_t)0x1560, (q15_t)0x3b1, (q15_t)0x156c, (q15_t)0x3b5, (q15_t)0x1578, (q15_t)0x3ba, (q15_t)0x1584, + (q15_t)0x3be, (q15_t)0x1590, (q15_t)0x3c2, (q15_t)0x159b, (q15_t)0x3c6, (q15_t)0x15a7, (q15_t)0x3ca, (q15_t)0x15b3, + (q15_t)0x3cf, (q15_t)0x15bf, (q15_t)0x3d3, (q15_t)0x15cb, (q15_t)0x3d7, (q15_t)0x15d7, (q15_t)0x3dc, (q15_t)0x15e2, + (q15_t)0x3e0, (q15_t)0x15ee, (q15_t)0x3e4, (q15_t)0x15fa, (q15_t)0x3e9, (q15_t)0x1606, (q15_t)0x3ed, (q15_t)0x1612, + (q15_t)0x3f1, (q15_t)0x161d, (q15_t)0x3f6, (q15_t)0x1629, (q15_t)0x3fa, (q15_t)0x1635, (q15_t)0x3fe, (q15_t)0x1641, + (q15_t)0x403, (q15_t)0x164c, (q15_t)0x407, (q15_t)0x1658, (q15_t)0x40b, (q15_t)0x1664, (q15_t)0x410, (q15_t)0x1670, + (q15_t)0x414, (q15_t)0x167c, (q15_t)0x419, (q15_t)0x1687, (q15_t)0x41d, (q15_t)0x1693, (q15_t)0x422, (q15_t)0x169f, + (q15_t)0x426, (q15_t)0x16ab, (q15_t)0x42a, (q15_t)0x16b6, (q15_t)0x42f, (q15_t)0x16c2, (q15_t)0x433, (q15_t)0x16ce, + (q15_t)0x438, (q15_t)0x16da, (q15_t)0x43c, (q15_t)0x16e5, (q15_t)0x441, (q15_t)0x16f1, (q15_t)0x445, (q15_t)0x16fd, + (q15_t)0x44a, (q15_t)0x1709, (q15_t)0x44e, (q15_t)0x1714, (q15_t)0x453, (q15_t)0x1720, (q15_t)0x457, (q15_t)0x172c, + (q15_t)0x45c, (q15_t)0x1737, (q15_t)0x461, (q15_t)0x1743, (q15_t)0x465, (q15_t)0x174f, (q15_t)0x46a, (q15_t)0x175b, + (q15_t)0x46e, (q15_t)0x1766, (q15_t)0x473, (q15_t)0x1772, (q15_t)0x478, (q15_t)0x177e, (q15_t)0x47c, (q15_t)0x1789, + (q15_t)0x481, (q15_t)0x1795, (q15_t)0x485, (q15_t)0x17a1, (q15_t)0x48a, (q15_t)0x17ac, (q15_t)0x48f, (q15_t)0x17b8, + (q15_t)0x493, (q15_t)0x17c4, (q15_t)0x498, (q15_t)0x17cf, (q15_t)0x49d, (q15_t)0x17db, (q15_t)0x4a1, (q15_t)0x17e7, + (q15_t)0x4a6, (q15_t)0x17f2, (q15_t)0x4ab, (q15_t)0x17fe, (q15_t)0x4b0, (q15_t)0x180a, (q15_t)0x4b4, (q15_t)0x1815, + (q15_t)0x4b9, (q15_t)0x1821, (q15_t)0x4be, (q15_t)0x182d, (q15_t)0x4c2, (q15_t)0x1838, (q15_t)0x4c7, (q15_t)0x1844, + (q15_t)0x4cc, (q15_t)0x184f, (q15_t)0x4d1, (q15_t)0x185b, (q15_t)0x4d6, (q15_t)0x1867, (q15_t)0x4da, (q15_t)0x1872, + (q15_t)0x4df, (q15_t)0x187e, (q15_t)0x4e4, (q15_t)0x1889, (q15_t)0x4e9, (q15_t)0x1895, (q15_t)0x4ee, (q15_t)0x18a1, + (q15_t)0x4f2, (q15_t)0x18ac, (q15_t)0x4f7, (q15_t)0x18b8, (q15_t)0x4fc, (q15_t)0x18c3, (q15_t)0x501, (q15_t)0x18cf, + (q15_t)0x506, (q15_t)0x18db, (q15_t)0x50b, (q15_t)0x18e6, (q15_t)0x510, (q15_t)0x18f2, (q15_t)0x515, (q15_t)0x18fd, + (q15_t)0x51a, (q15_t)0x1909, (q15_t)0x51e, (q15_t)0x1914, (q15_t)0x523, (q15_t)0x1920, (q15_t)0x528, (q15_t)0x192c, + (q15_t)0x52d, (q15_t)0x1937, (q15_t)0x532, (q15_t)0x1943, (q15_t)0x537, (q15_t)0x194e, (q15_t)0x53c, (q15_t)0x195a, + (q15_t)0x541, (q15_t)0x1965, (q15_t)0x546, (q15_t)0x1971, (q15_t)0x54b, (q15_t)0x197c, (q15_t)0x550, (q15_t)0x1988, + (q15_t)0x555, (q15_t)0x1993, (q15_t)0x55a, (q15_t)0x199f, (q15_t)0x55f, (q15_t)0x19aa, (q15_t)0x564, (q15_t)0x19b6, + (q15_t)0x569, (q15_t)0x19c1, (q15_t)0x56e, (q15_t)0x19cd, (q15_t)0x573, (q15_t)0x19d8, (q15_t)0x578, (q15_t)0x19e4, + (q15_t)0x57e, (q15_t)0x19ef, (q15_t)0x583, (q15_t)0x19fb, (q15_t)0x588, (q15_t)0x1a06, (q15_t)0x58d, (q15_t)0x1a12, + (q15_t)0x592, (q15_t)0x1a1d, (q15_t)0x597, (q15_t)0x1a29, (q15_t)0x59c, (q15_t)0x1a34, (q15_t)0x5a1, (q15_t)0x1a40, + (q15_t)0x5a7, (q15_t)0x1a4b, (q15_t)0x5ac, (q15_t)0x1a57, (q15_t)0x5b1, (q15_t)0x1a62, (q15_t)0x5b6, (q15_t)0x1a6e, + (q15_t)0x5bb, (q15_t)0x1a79, (q15_t)0x5c1, (q15_t)0x1a84, (q15_t)0x5c6, (q15_t)0x1a90, (q15_t)0x5cb, (q15_t)0x1a9b, + (q15_t)0x5d0, (q15_t)0x1aa7, (q15_t)0x5d5, (q15_t)0x1ab2, (q15_t)0x5db, (q15_t)0x1abe, (q15_t)0x5e0, (q15_t)0x1ac9, + (q15_t)0x5e5, (q15_t)0x1ad4, (q15_t)0x5ea, (q15_t)0x1ae0, (q15_t)0x5f0, (q15_t)0x1aeb, (q15_t)0x5f5, (q15_t)0x1af7, + (q15_t)0x5fa, (q15_t)0x1b02, (q15_t)0x600, (q15_t)0x1b0d, (q15_t)0x605, (q15_t)0x1b19, (q15_t)0x60a, (q15_t)0x1b24, + (q15_t)0x610, (q15_t)0x1b30, (q15_t)0x615, (q15_t)0x1b3b, (q15_t)0x61a, (q15_t)0x1b46, (q15_t)0x620, (q15_t)0x1b52, + (q15_t)0x625, (q15_t)0x1b5d, (q15_t)0x62a, (q15_t)0x1b68, (q15_t)0x630, (q15_t)0x1b74, (q15_t)0x635, (q15_t)0x1b7f, + (q15_t)0x63b, (q15_t)0x1b8a, (q15_t)0x640, (q15_t)0x1b96, (q15_t)0x645, (q15_t)0x1ba1, (q15_t)0x64b, (q15_t)0x1bac, + (q15_t)0x650, (q15_t)0x1bb8, (q15_t)0x656, (q15_t)0x1bc3, (q15_t)0x65b, (q15_t)0x1bce, (q15_t)0x661, (q15_t)0x1bda, + (q15_t)0x666, (q15_t)0x1be5, (q15_t)0x66c, (q15_t)0x1bf0, (q15_t)0x671, (q15_t)0x1bfc, (q15_t)0x677, (q15_t)0x1c07, + (q15_t)0x67c, (q15_t)0x1c12, (q15_t)0x682, (q15_t)0x1c1e, (q15_t)0x687, (q15_t)0x1c29, (q15_t)0x68d, (q15_t)0x1c34, + (q15_t)0x692, (q15_t)0x1c3f, (q15_t)0x698, (q15_t)0x1c4b, (q15_t)0x69d, (q15_t)0x1c56, (q15_t)0x6a3, (q15_t)0x1c61, + (q15_t)0x6a8, (q15_t)0x1c6c, (q15_t)0x6ae, (q15_t)0x1c78, (q15_t)0x6b4, (q15_t)0x1c83, (q15_t)0x6b9, (q15_t)0x1c8e, + (q15_t)0x6bf, (q15_t)0x1c99, (q15_t)0x6c5, (q15_t)0x1ca5, (q15_t)0x6ca, (q15_t)0x1cb0, (q15_t)0x6d0, (q15_t)0x1cbb, + (q15_t)0x6d5, (q15_t)0x1cc6, (q15_t)0x6db, (q15_t)0x1cd2, (q15_t)0x6e1, (q15_t)0x1cdd, (q15_t)0x6e6, (q15_t)0x1ce8, + (q15_t)0x6ec, (q15_t)0x1cf3, (q15_t)0x6f2, (q15_t)0x1cff, (q15_t)0x6f7, (q15_t)0x1d0a, (q15_t)0x6fd, (q15_t)0x1d15, + (q15_t)0x703, (q15_t)0x1d20, (q15_t)0x709, (q15_t)0x1d2b, (q15_t)0x70e, (q15_t)0x1d36, (q15_t)0x714, (q15_t)0x1d42, + (q15_t)0x71a, (q15_t)0x1d4d, (q15_t)0x720, (q15_t)0x1d58, (q15_t)0x725, (q15_t)0x1d63, (q15_t)0x72b, (q15_t)0x1d6e, + (q15_t)0x731, (q15_t)0x1d79, (q15_t)0x737, (q15_t)0x1d85, (q15_t)0x73d, (q15_t)0x1d90, (q15_t)0x742, (q15_t)0x1d9b, + (q15_t)0x748, (q15_t)0x1da6, (q15_t)0x74e, (q15_t)0x1db1, (q15_t)0x754, (q15_t)0x1dbc, (q15_t)0x75a, (q15_t)0x1dc7, + (q15_t)0x75f, (q15_t)0x1dd3, (q15_t)0x765, (q15_t)0x1dde, (q15_t)0x76b, (q15_t)0x1de9, (q15_t)0x771, (q15_t)0x1df4, + (q15_t)0x777, (q15_t)0x1dff, (q15_t)0x77d, (q15_t)0x1e0a, (q15_t)0x783, (q15_t)0x1e15, (q15_t)0x789, (q15_t)0x1e20, + (q15_t)0x78f, (q15_t)0x1e2b, (q15_t)0x795, (q15_t)0x1e36, (q15_t)0x79a, (q15_t)0x1e42, (q15_t)0x7a0, (q15_t)0x1e4d, + (q15_t)0x7a6, (q15_t)0x1e58, (q15_t)0x7ac, (q15_t)0x1e63, (q15_t)0x7b2, (q15_t)0x1e6e, (q15_t)0x7b8, (q15_t)0x1e79, + (q15_t)0x7be, (q15_t)0x1e84, (q15_t)0x7c4, (q15_t)0x1e8f, (q15_t)0x7ca, (q15_t)0x1e9a, (q15_t)0x7d0, (q15_t)0x1ea5, + (q15_t)0x7d6, (q15_t)0x1eb0, (q15_t)0x7dc, (q15_t)0x1ebb, (q15_t)0x7e2, (q15_t)0x1ec6, (q15_t)0x7e8, (q15_t)0x1ed1, + (q15_t)0x7ee, (q15_t)0x1edc, (q15_t)0x7f5, (q15_t)0x1ee7, (q15_t)0x7fb, (q15_t)0x1ef2, (q15_t)0x801, (q15_t)0x1efd, + (q15_t)0x807, (q15_t)0x1f08, (q15_t)0x80d, (q15_t)0x1f13, (q15_t)0x813, (q15_t)0x1f1e, (q15_t)0x819, (q15_t)0x1f29, + (q15_t)0x81f, (q15_t)0x1f34, (q15_t)0x825, (q15_t)0x1f3f, (q15_t)0x82b, (q15_t)0x1f4a, (q15_t)0x832, (q15_t)0x1f55, + (q15_t)0x838, (q15_t)0x1f60, (q15_t)0x83e, (q15_t)0x1f6b, (q15_t)0x844, (q15_t)0x1f76, (q15_t)0x84a, (q15_t)0x1f81, + (q15_t)0x850, (q15_t)0x1f8c, (q15_t)0x857, (q15_t)0x1f97, (q15_t)0x85d, (q15_t)0x1fa2, (q15_t)0x863, (q15_t)0x1fac, + (q15_t)0x869, (q15_t)0x1fb7, (q15_t)0x870, (q15_t)0x1fc2, (q15_t)0x876, (q15_t)0x1fcd, (q15_t)0x87c, (q15_t)0x1fd8, + (q15_t)0x882, (q15_t)0x1fe3, (q15_t)0x889, (q15_t)0x1fee, (q15_t)0x88f, (q15_t)0x1ff9, (q15_t)0x895, (q15_t)0x2004, + (q15_t)0x89b, (q15_t)0x200f, (q15_t)0x8a2, (q15_t)0x2019, (q15_t)0x8a8, (q15_t)0x2024, (q15_t)0x8ae, (q15_t)0x202f, + (q15_t)0x8b5, (q15_t)0x203a, (q15_t)0x8bb, (q15_t)0x2045, (q15_t)0x8c1, (q15_t)0x2050, (q15_t)0x8c8, (q15_t)0x205b, + (q15_t)0x8ce, (q15_t)0x2065, (q15_t)0x8d4, (q15_t)0x2070, (q15_t)0x8db, (q15_t)0x207b, (q15_t)0x8e1, (q15_t)0x2086, + (q15_t)0x8e8, (q15_t)0x2091, (q15_t)0x8ee, (q15_t)0x209b, (q15_t)0x8f4, (q15_t)0x20a6, (q15_t)0x8fb, (q15_t)0x20b1, + (q15_t)0x901, (q15_t)0x20bc, (q15_t)0x908, (q15_t)0x20c7, (q15_t)0x90e, (q15_t)0x20d1, (q15_t)0x915, (q15_t)0x20dc, + (q15_t)0x91b, (q15_t)0x20e7, (q15_t)0x921, (q15_t)0x20f2, (q15_t)0x928, (q15_t)0x20fd, (q15_t)0x92e, (q15_t)0x2107, + (q15_t)0x935, (q15_t)0x2112, (q15_t)0x93b, (q15_t)0x211d, (q15_t)0x942, (q15_t)0x2128, (q15_t)0x948, (q15_t)0x2132, + (q15_t)0x94f, (q15_t)0x213d, (q15_t)0x955, (q15_t)0x2148, (q15_t)0x95c, (q15_t)0x2153, (q15_t)0x963, (q15_t)0x215d, + (q15_t)0x969, (q15_t)0x2168, (q15_t)0x970, (q15_t)0x2173, (q15_t)0x976, (q15_t)0x217d, (q15_t)0x97d, (q15_t)0x2188, + (q15_t)0x983, (q15_t)0x2193, (q15_t)0x98a, (q15_t)0x219e, (q15_t)0x991, (q15_t)0x21a8, (q15_t)0x997, (q15_t)0x21b3, + (q15_t)0x99e, (q15_t)0x21be, (q15_t)0x9a4, (q15_t)0x21c8, (q15_t)0x9ab, (q15_t)0x21d3, (q15_t)0x9b2, (q15_t)0x21de, + (q15_t)0x9b8, (q15_t)0x21e8, (q15_t)0x9bf, (q15_t)0x21f3, (q15_t)0x9c6, (q15_t)0x21fe, (q15_t)0x9cc, (q15_t)0x2208, + (q15_t)0x9d3, (q15_t)0x2213, (q15_t)0x9da, (q15_t)0x221e, (q15_t)0x9e0, (q15_t)0x2228, (q15_t)0x9e7, (q15_t)0x2233, + (q15_t)0x9ee, (q15_t)0x223d, (q15_t)0x9f5, (q15_t)0x2248, (q15_t)0x9fb, (q15_t)0x2253, (q15_t)0xa02, (q15_t)0x225d, + (q15_t)0xa09, (q15_t)0x2268, (q15_t)0xa10, (q15_t)0x2272, (q15_t)0xa16, (q15_t)0x227d, (q15_t)0xa1d, (q15_t)0x2288, + (q15_t)0xa24, (q15_t)0x2292, (q15_t)0xa2b, (q15_t)0x229d, (q15_t)0xa32, (q15_t)0x22a7, (q15_t)0xa38, (q15_t)0x22b2, + (q15_t)0xa3f, (q15_t)0x22bc, (q15_t)0xa46, (q15_t)0x22c7, (q15_t)0xa4d, (q15_t)0x22d2, (q15_t)0xa54, (q15_t)0x22dc, + (q15_t)0xa5b, (q15_t)0x22e7, (q15_t)0xa61, (q15_t)0x22f1, (q15_t)0xa68, (q15_t)0x22fc, (q15_t)0xa6f, (q15_t)0x2306, + (q15_t)0xa76, (q15_t)0x2311, (q15_t)0xa7d, (q15_t)0x231b, (q15_t)0xa84, (q15_t)0x2326, (q15_t)0xa8b, (q15_t)0x2330, + (q15_t)0xa92, (q15_t)0x233b, (q15_t)0xa99, (q15_t)0x2345, (q15_t)0xa9f, (q15_t)0x2350, (q15_t)0xaa6, (q15_t)0x235a, + (q15_t)0xaad, (q15_t)0x2365, (q15_t)0xab4, (q15_t)0x236f, (q15_t)0xabb, (q15_t)0x237a, (q15_t)0xac2, (q15_t)0x2384, + (q15_t)0xac9, (q15_t)0x238e, (q15_t)0xad0, (q15_t)0x2399, (q15_t)0xad7, (q15_t)0x23a3, (q15_t)0xade, (q15_t)0x23ae, + (q15_t)0xae5, (q15_t)0x23b8, (q15_t)0xaec, (q15_t)0x23c3, (q15_t)0xaf3, (q15_t)0x23cd, (q15_t)0xafa, (q15_t)0x23d7, + (q15_t)0xb01, (q15_t)0x23e2, (q15_t)0xb08, (q15_t)0x23ec, (q15_t)0xb0f, (q15_t)0x23f7, (q15_t)0xb16, (q15_t)0x2401, + (q15_t)0xb1e, (q15_t)0x240b, (q15_t)0xb25, (q15_t)0x2416, (q15_t)0xb2c, (q15_t)0x2420, (q15_t)0xb33, (q15_t)0x242b, + (q15_t)0xb3a, (q15_t)0x2435, (q15_t)0xb41, (q15_t)0x243f, (q15_t)0xb48, (q15_t)0x244a, (q15_t)0xb4f, (q15_t)0x2454, + (q15_t)0xb56, (q15_t)0x245e, (q15_t)0xb5e, (q15_t)0x2469, (q15_t)0xb65, (q15_t)0x2473, (q15_t)0xb6c, (q15_t)0x247d, + (q15_t)0xb73, (q15_t)0x2488, (q15_t)0xb7a, (q15_t)0x2492, (q15_t)0xb81, (q15_t)0x249c, (q15_t)0xb89, (q15_t)0x24a7, + (q15_t)0xb90, (q15_t)0x24b1, (q15_t)0xb97, (q15_t)0x24bb, (q15_t)0xb9e, (q15_t)0x24c5, (q15_t)0xba5, (q15_t)0x24d0, + (q15_t)0xbad, (q15_t)0x24da, (q15_t)0xbb4, (q15_t)0x24e4, (q15_t)0xbbb, (q15_t)0x24ef, (q15_t)0xbc2, (q15_t)0x24f9, + (q15_t)0xbca, (q15_t)0x2503, (q15_t)0xbd1, (q15_t)0x250d, (q15_t)0xbd8, (q15_t)0x2518, (q15_t)0xbe0, (q15_t)0x2522, + (q15_t)0xbe7, (q15_t)0x252c, (q15_t)0xbee, (q15_t)0x2536, (q15_t)0xbf5, (q15_t)0x2541, (q15_t)0xbfd, (q15_t)0x254b, + (q15_t)0xc04, (q15_t)0x2555, (q15_t)0xc0b, (q15_t)0x255f, (q15_t)0xc13, (q15_t)0x2569, (q15_t)0xc1a, (q15_t)0x2574, + (q15_t)0xc21, (q15_t)0x257e, (q15_t)0xc29, (q15_t)0x2588, (q15_t)0xc30, (q15_t)0x2592, (q15_t)0xc38, (q15_t)0x259c, + (q15_t)0xc3f, (q15_t)0x25a6, (q15_t)0xc46, (q15_t)0x25b1, (q15_t)0xc4e, (q15_t)0x25bb, (q15_t)0xc55, (q15_t)0x25c5, + (q15_t)0xc5d, (q15_t)0x25cf, (q15_t)0xc64, (q15_t)0x25d9, (q15_t)0xc6b, (q15_t)0x25e3, (q15_t)0xc73, (q15_t)0x25ed, + (q15_t)0xc7a, (q15_t)0x25f8, (q15_t)0xc82, (q15_t)0x2602, (q15_t)0xc89, (q15_t)0x260c, (q15_t)0xc91, (q15_t)0x2616, + (q15_t)0xc98, (q15_t)0x2620, (q15_t)0xca0, (q15_t)0x262a, (q15_t)0xca7, (q15_t)0x2634, (q15_t)0xcaf, (q15_t)0x263e, + (q15_t)0xcb6, (q15_t)0x2648, (q15_t)0xcbe, (q15_t)0x2652, (q15_t)0xcc5, (q15_t)0x265c, (q15_t)0xccd, (q15_t)0x2666, + (q15_t)0xcd4, (q15_t)0x2671, (q15_t)0xcdc, (q15_t)0x267b, (q15_t)0xce3, (q15_t)0x2685, (q15_t)0xceb, (q15_t)0x268f, + (q15_t)0xcf3, (q15_t)0x2699, (q15_t)0xcfa, (q15_t)0x26a3, (q15_t)0xd02, (q15_t)0x26ad, (q15_t)0xd09, (q15_t)0x26b7, + (q15_t)0xd11, (q15_t)0x26c1, (q15_t)0xd19, (q15_t)0x26cb, (q15_t)0xd20, (q15_t)0x26d5, (q15_t)0xd28, (q15_t)0x26df, + (q15_t)0xd30, (q15_t)0x26e9, (q15_t)0xd37, (q15_t)0x26f3, (q15_t)0xd3f, (q15_t)0x26fd, (q15_t)0xd46, (q15_t)0x2707, + (q15_t)0xd4e, (q15_t)0x2711, (q15_t)0xd56, (q15_t)0x271a, (q15_t)0xd5d, (q15_t)0x2724, (q15_t)0xd65, (q15_t)0x272e, + (q15_t)0xd6d, (q15_t)0x2738, (q15_t)0xd75, (q15_t)0x2742, (q15_t)0xd7c, (q15_t)0x274c, (q15_t)0xd84, (q15_t)0x2756, + (q15_t)0xd8c, (q15_t)0x2760, (q15_t)0xd93, (q15_t)0x276a, (q15_t)0xd9b, (q15_t)0x2774, (q15_t)0xda3, (q15_t)0x277e, + (q15_t)0xdab, (q15_t)0x2788, (q15_t)0xdb2, (q15_t)0x2791, (q15_t)0xdba, (q15_t)0x279b, (q15_t)0xdc2, (q15_t)0x27a5, + (q15_t)0xdca, (q15_t)0x27af, (q15_t)0xdd2, (q15_t)0x27b9, (q15_t)0xdd9, (q15_t)0x27c3, (q15_t)0xde1, (q15_t)0x27cd, + (q15_t)0xde9, (q15_t)0x27d6, (q15_t)0xdf1, (q15_t)0x27e0, (q15_t)0xdf9, (q15_t)0x27ea, (q15_t)0xe01, (q15_t)0x27f4, + (q15_t)0xe08, (q15_t)0x27fe, (q15_t)0xe10, (q15_t)0x2808, (q15_t)0xe18, (q15_t)0x2811, (q15_t)0xe20, (q15_t)0x281b, + (q15_t)0xe28, (q15_t)0x2825, (q15_t)0xe30, (q15_t)0x282f, (q15_t)0xe38, (q15_t)0x2838, (q15_t)0xe40, (q15_t)0x2842, + (q15_t)0xe47, (q15_t)0x284c, (q15_t)0xe4f, (q15_t)0x2856, (q15_t)0xe57, (q15_t)0x2860, (q15_t)0xe5f, (q15_t)0x2869, + (q15_t)0xe67, (q15_t)0x2873, (q15_t)0xe6f, (q15_t)0x287d, (q15_t)0xe77, (q15_t)0x2886, (q15_t)0xe7f, (q15_t)0x2890, + (q15_t)0xe87, (q15_t)0x289a, (q15_t)0xe8f, (q15_t)0x28a4, (q15_t)0xe97, (q15_t)0x28ad, (q15_t)0xe9f, (q15_t)0x28b7, + (q15_t)0xea7, (q15_t)0x28c1, (q15_t)0xeaf, (q15_t)0x28ca, (q15_t)0xeb7, (q15_t)0x28d4, (q15_t)0xebf, (q15_t)0x28de, + (q15_t)0xec7, (q15_t)0x28e7, (q15_t)0xecf, (q15_t)0x28f1, (q15_t)0xed7, (q15_t)0x28fb, (q15_t)0xedf, (q15_t)0x2904, + (q15_t)0xee7, (q15_t)0x290e, (q15_t)0xeef, (q15_t)0x2918, (q15_t)0xef7, (q15_t)0x2921, (q15_t)0xeff, (q15_t)0x292b, + (q15_t)0xf07, (q15_t)0x2935, (q15_t)0xf10, (q15_t)0x293e, (q15_t)0xf18, (q15_t)0x2948, (q15_t)0xf20, (q15_t)0x2951, + (q15_t)0xf28, (q15_t)0x295b, (q15_t)0xf30, (q15_t)0x2965, (q15_t)0xf38, (q15_t)0x296e, (q15_t)0xf40, (q15_t)0x2978, + (q15_t)0xf48, (q15_t)0x2981, (q15_t)0xf51, (q15_t)0x298b, (q15_t)0xf59, (q15_t)0x2994, (q15_t)0xf61, (q15_t)0x299e, + (q15_t)0xf69, (q15_t)0x29a7, (q15_t)0xf71, (q15_t)0x29b1, (q15_t)0xf79, (q15_t)0x29bb, (q15_t)0xf82, (q15_t)0x29c4, + (q15_t)0xf8a, (q15_t)0x29ce, (q15_t)0xf92, (q15_t)0x29d7, (q15_t)0xf9a, (q15_t)0x29e1, (q15_t)0xfa3, (q15_t)0x29ea, + (q15_t)0xfab, (q15_t)0x29f4, (q15_t)0xfb3, (q15_t)0x29fd, (q15_t)0xfbb, (q15_t)0x2a07, (q15_t)0xfc4, (q15_t)0x2a10, + (q15_t)0xfcc, (q15_t)0x2a1a, (q15_t)0xfd4, (q15_t)0x2a23, (q15_t)0xfdc, (q15_t)0x2a2c, (q15_t)0xfe5, (q15_t)0x2a36, + (q15_t)0xfed, (q15_t)0x2a3f, (q15_t)0xff5, (q15_t)0x2a49, (q15_t)0xffe, (q15_t)0x2a52, (q15_t)0x1006, (q15_t)0x2a5c, + (q15_t)0x100e, (q15_t)0x2a65, (q15_t)0x1016, (q15_t)0x2a6e, (q15_t)0x101f, (q15_t)0x2a78, (q15_t)0x1027, (q15_t)0x2a81, + (q15_t)0x1030, (q15_t)0x2a8b, (q15_t)0x1038, (q15_t)0x2a94, (q15_t)0x1040, (q15_t)0x2a9d, (q15_t)0x1049, (q15_t)0x2aa7, + (q15_t)0x1051, (q15_t)0x2ab0, (q15_t)0x1059, (q15_t)0x2ab9, (q15_t)0x1062, (q15_t)0x2ac3, (q15_t)0x106a, (q15_t)0x2acc, + (q15_t)0x1073, (q15_t)0x2ad6, (q15_t)0x107b, (q15_t)0x2adf, (q15_t)0x1083, (q15_t)0x2ae8, (q15_t)0x108c, (q15_t)0x2af2, + (q15_t)0x1094, (q15_t)0x2afb, (q15_t)0x109d, (q15_t)0x2b04, (q15_t)0x10a5, (q15_t)0x2b0d, (q15_t)0x10ae, (q15_t)0x2b17, + (q15_t)0x10b6, (q15_t)0x2b20, (q15_t)0x10bf, (q15_t)0x2b29, (q15_t)0x10c7, (q15_t)0x2b33, (q15_t)0x10d0, (q15_t)0x2b3c, + (q15_t)0x10d8, (q15_t)0x2b45, (q15_t)0x10e0, (q15_t)0x2b4e, (q15_t)0x10e9, (q15_t)0x2b58, (q15_t)0x10f2, (q15_t)0x2b61, + (q15_t)0x10fa, (q15_t)0x2b6a, (q15_t)0x1103, (q15_t)0x2b73, (q15_t)0x110b, (q15_t)0x2b7d, (q15_t)0x1114, (q15_t)0x2b86, + (q15_t)0x111c, (q15_t)0x2b8f, (q15_t)0x1125, (q15_t)0x2b98, (q15_t)0x112d, (q15_t)0x2ba1, (q15_t)0x1136, (q15_t)0x2bab, + (q15_t)0x113e, (q15_t)0x2bb4, (q15_t)0x1147, (q15_t)0x2bbd, (q15_t)0x1150, (q15_t)0x2bc6, (q15_t)0x1158, (q15_t)0x2bcf, + (q15_t)0x1161, (q15_t)0x2bd8, (q15_t)0x1169, (q15_t)0x2be2, (q15_t)0x1172, (q15_t)0x2beb, (q15_t)0x117b, (q15_t)0x2bf4, + (q15_t)0x1183, (q15_t)0x2bfd, (q15_t)0x118c, (q15_t)0x2c06, (q15_t)0x1195, (q15_t)0x2c0f, (q15_t)0x119d, (q15_t)0x2c18, + (q15_t)0x11a6, (q15_t)0x2c21, (q15_t)0x11af, (q15_t)0x2c2b, (q15_t)0x11b7, (q15_t)0x2c34, (q15_t)0x11c0, (q15_t)0x2c3d, + (q15_t)0x11c9, (q15_t)0x2c46, (q15_t)0x11d1, (q15_t)0x2c4f, (q15_t)0x11da, (q15_t)0x2c58, (q15_t)0x11e3, (q15_t)0x2c61, + (q15_t)0x11eb, (q15_t)0x2c6a, (q15_t)0x11f4, (q15_t)0x2c73, (q15_t)0x11fd, (q15_t)0x2c7c, (q15_t)0x1206, (q15_t)0x2c85, + (q15_t)0x120e, (q15_t)0x2c8e, (q15_t)0x1217, (q15_t)0x2c97, (q15_t)0x1220, (q15_t)0x2ca0, (q15_t)0x1229, (q15_t)0x2ca9, + (q15_t)0x1231, (q15_t)0x2cb2, (q15_t)0x123a, (q15_t)0x2cbb, (q15_t)0x1243, (q15_t)0x2cc4, (q15_t)0x124c, (q15_t)0x2ccd, + (q15_t)0x1255, (q15_t)0x2cd6, (q15_t)0x125d, (q15_t)0x2cdf, (q15_t)0x1266, (q15_t)0x2ce8, (q15_t)0x126f, (q15_t)0x2cf1, + (q15_t)0x1278, (q15_t)0x2cfa, (q15_t)0x1281, (q15_t)0x2d03, (q15_t)0x128a, (q15_t)0x2d0c, (q15_t)0x1292, (q15_t)0x2d15, + (q15_t)0x129b, (q15_t)0x2d1e, (q15_t)0x12a4, (q15_t)0x2d27, (q15_t)0x12ad, (q15_t)0x2d2f, (q15_t)0x12b6, (q15_t)0x2d38, + (q15_t)0x12bf, (q15_t)0x2d41, (q15_t)0x12c8, (q15_t)0x2d4a, (q15_t)0x12d1, (q15_t)0x2d53, (q15_t)0x12d9, (q15_t)0x2d5c, + (q15_t)0x12e2, (q15_t)0x2d65, (q15_t)0x12eb, (q15_t)0x2d6e, (q15_t)0x12f4, (q15_t)0x2d76, (q15_t)0x12fd, (q15_t)0x2d7f, + (q15_t)0x1306, (q15_t)0x2d88, (q15_t)0x130f, (q15_t)0x2d91, (q15_t)0x1318, (q15_t)0x2d9a, (q15_t)0x1321, (q15_t)0x2da3, + (q15_t)0x132a, (q15_t)0x2dab, (q15_t)0x1333, (q15_t)0x2db4, (q15_t)0x133c, (q15_t)0x2dbd, (q15_t)0x1345, (q15_t)0x2dc6, + (q15_t)0x134e, (q15_t)0x2dcf, (q15_t)0x1357, (q15_t)0x2dd7, (q15_t)0x1360, (q15_t)0x2de0, (q15_t)0x1369, (q15_t)0x2de9, + (q15_t)0x1372, (q15_t)0x2df2, (q15_t)0x137b, (q15_t)0x2dfa, (q15_t)0x1384, (q15_t)0x2e03, (q15_t)0x138d, (q15_t)0x2e0c, + (q15_t)0x1396, (q15_t)0x2e15, (q15_t)0x139f, (q15_t)0x2e1d, (q15_t)0x13a8, (q15_t)0x2e26, (q15_t)0x13b1, (q15_t)0x2e2f, + (q15_t)0x13ba, (q15_t)0x2e37, (q15_t)0x13c3, (q15_t)0x2e40, (q15_t)0x13cc, (q15_t)0x2e49, (q15_t)0x13d5, (q15_t)0x2e51, + (q15_t)0x13df, (q15_t)0x2e5a, (q15_t)0x13e8, (q15_t)0x2e63, (q15_t)0x13f1, (q15_t)0x2e6b, (q15_t)0x13fa, (q15_t)0x2e74, + (q15_t)0x1403, (q15_t)0x2e7d, (q15_t)0x140c, (q15_t)0x2e85, (q15_t)0x1415, (q15_t)0x2e8e, (q15_t)0x141e, (q15_t)0x2e97, + (q15_t)0x1428, (q15_t)0x2e9f, (q15_t)0x1431, (q15_t)0x2ea8, (q15_t)0x143a, (q15_t)0x2eb0, (q15_t)0x1443, (q15_t)0x2eb9, + (q15_t)0x144c, (q15_t)0x2ec2, (q15_t)0x1455, (q15_t)0x2eca, (q15_t)0x145f, (q15_t)0x2ed3, (q15_t)0x1468, (q15_t)0x2edb, + (q15_t)0x1471, (q15_t)0x2ee4, (q15_t)0x147a, (q15_t)0x2eec, (q15_t)0x1483, (q15_t)0x2ef5, (q15_t)0x148d, (q15_t)0x2efd, + (q15_t)0x1496, (q15_t)0x2f06, (q15_t)0x149f, (q15_t)0x2f0e, (q15_t)0x14a8, (q15_t)0x2f17, (q15_t)0x14b2, (q15_t)0x2f20, + (q15_t)0x14bb, (q15_t)0x2f28, (q15_t)0x14c4, (q15_t)0x2f30, (q15_t)0x14cd, (q15_t)0x2f39, (q15_t)0x14d7, (q15_t)0x2f41, + (q15_t)0x14e0, (q15_t)0x2f4a, (q15_t)0x14e9, (q15_t)0x2f52, (q15_t)0x14f3, (q15_t)0x2f5b, (q15_t)0x14fc, (q15_t)0x2f63, + (q15_t)0x1505, (q15_t)0x2f6c, (q15_t)0x150e, (q15_t)0x2f74, (q15_t)0x1518, (q15_t)0x2f7d, (q15_t)0x1521, (q15_t)0x2f85, + (q15_t)0x152a, (q15_t)0x2f8d, (q15_t)0x1534, (q15_t)0x2f96, (q15_t)0x153d, (q15_t)0x2f9e, (q15_t)0x1547, (q15_t)0x2fa7, + (q15_t)0x1550, (q15_t)0x2faf, (q15_t)0x1559, (q15_t)0x2fb7, (q15_t)0x1563, (q15_t)0x2fc0, (q15_t)0x156c, (q15_t)0x2fc8, + (q15_t)0x1575, (q15_t)0x2fd0, (q15_t)0x157f, (q15_t)0x2fd9, (q15_t)0x1588, (q15_t)0x2fe1, (q15_t)0x1592, (q15_t)0x2fea, + (q15_t)0x159b, (q15_t)0x2ff2, (q15_t)0x15a4, (q15_t)0x2ffa, (q15_t)0x15ae, (q15_t)0x3002, (q15_t)0x15b7, (q15_t)0x300b, + (q15_t)0x15c1, (q15_t)0x3013, (q15_t)0x15ca, (q15_t)0x301b, (q15_t)0x15d4, (q15_t)0x3024, (q15_t)0x15dd, (q15_t)0x302c, + (q15_t)0x15e6, (q15_t)0x3034, (q15_t)0x15f0, (q15_t)0x303c, (q15_t)0x15f9, (q15_t)0x3045, (q15_t)0x1603, (q15_t)0x304d, + (q15_t)0x160c, (q15_t)0x3055, (q15_t)0x1616, (q15_t)0x305d, (q15_t)0x161f, (q15_t)0x3066, (q15_t)0x1629, (q15_t)0x306e, + (q15_t)0x1632, (q15_t)0x3076, (q15_t)0x163c, (q15_t)0x307e, (q15_t)0x1645, (q15_t)0x3087, (q15_t)0x164f, (q15_t)0x308f, + (q15_t)0x1659, (q15_t)0x3097, (q15_t)0x1662, (q15_t)0x309f, (q15_t)0x166c, (q15_t)0x30a7, (q15_t)0x1675, (q15_t)0x30af, + (q15_t)0x167f, (q15_t)0x30b8, (q15_t)0x1688, (q15_t)0x30c0, (q15_t)0x1692, (q15_t)0x30c8, (q15_t)0x169b, (q15_t)0x30d0, + (q15_t)0x16a5, (q15_t)0x30d8, (q15_t)0x16af, (q15_t)0x30e0, (q15_t)0x16b8, (q15_t)0x30e8, (q15_t)0x16c2, (q15_t)0x30f0, + (q15_t)0x16cb, (q15_t)0x30f9, (q15_t)0x16d5, (q15_t)0x3101, (q15_t)0x16df, (q15_t)0x3109, (q15_t)0x16e8, (q15_t)0x3111, + (q15_t)0x16f2, (q15_t)0x3119, (q15_t)0x16fc, (q15_t)0x3121, (q15_t)0x1705, (q15_t)0x3129, (q15_t)0x170f, (q15_t)0x3131, + (q15_t)0x1719, (q15_t)0x3139, (q15_t)0x1722, (q15_t)0x3141, (q15_t)0x172c, (q15_t)0x3149, (q15_t)0x1736, (q15_t)0x3151, + (q15_t)0x173f, (q15_t)0x3159, (q15_t)0x1749, (q15_t)0x3161, (q15_t)0x1753, (q15_t)0x3169, (q15_t)0x175c, (q15_t)0x3171, + (q15_t)0x1766, (q15_t)0x3179, (q15_t)0x1770, (q15_t)0x3181, (q15_t)0x177a, (q15_t)0x3189, (q15_t)0x1783, (q15_t)0x3191, + (q15_t)0x178d, (q15_t)0x3199, (q15_t)0x1797, (q15_t)0x31a1, (q15_t)0x17a0, (q15_t)0x31a9, (q15_t)0x17aa, (q15_t)0x31b1, + (q15_t)0x17b4, (q15_t)0x31b9, (q15_t)0x17be, (q15_t)0x31c0, (q15_t)0x17c8, (q15_t)0x31c8, (q15_t)0x17d1, (q15_t)0x31d0, + (q15_t)0x17db, (q15_t)0x31d8, (q15_t)0x17e5, (q15_t)0x31e0, (q15_t)0x17ef, (q15_t)0x31e8, (q15_t)0x17f8, (q15_t)0x31f0, + (q15_t)0x1802, (q15_t)0x31f8, (q15_t)0x180c, (q15_t)0x31ff, (q15_t)0x1816, (q15_t)0x3207, (q15_t)0x1820, (q15_t)0x320f, + (q15_t)0x182a, (q15_t)0x3217, (q15_t)0x1833, (q15_t)0x321f, (q15_t)0x183d, (q15_t)0x3227, (q15_t)0x1847, (q15_t)0x322e, + (q15_t)0x1851, (q15_t)0x3236, (q15_t)0x185b, (q15_t)0x323e, (q15_t)0x1865, (q15_t)0x3246, (q15_t)0x186f, (q15_t)0x324e, + (q15_t)0x1878, (q15_t)0x3255, (q15_t)0x1882, (q15_t)0x325d, (q15_t)0x188c, (q15_t)0x3265, (q15_t)0x1896, (q15_t)0x326d, + (q15_t)0x18a0, (q15_t)0x3274, (q15_t)0x18aa, (q15_t)0x327c, (q15_t)0x18b4, (q15_t)0x3284, (q15_t)0x18be, (q15_t)0x328b, + (q15_t)0x18c8, (q15_t)0x3293, (q15_t)0x18d2, (q15_t)0x329b, (q15_t)0x18dc, (q15_t)0x32a3, (q15_t)0x18e6, (q15_t)0x32aa, + (q15_t)0x18ef, (q15_t)0x32b2, (q15_t)0x18f9, (q15_t)0x32ba, (q15_t)0x1903, (q15_t)0x32c1, (q15_t)0x190d, (q15_t)0x32c9, + (q15_t)0x1917, (q15_t)0x32d0, (q15_t)0x1921, (q15_t)0x32d8, (q15_t)0x192b, (q15_t)0x32e0, (q15_t)0x1935, (q15_t)0x32e7, + (q15_t)0x193f, (q15_t)0x32ef, (q15_t)0x1949, (q15_t)0x32f7, (q15_t)0x1953, (q15_t)0x32fe, (q15_t)0x195d, (q15_t)0x3306, + (q15_t)0x1967, (q15_t)0x330d, (q15_t)0x1971, (q15_t)0x3315, (q15_t)0x197b, (q15_t)0x331d, (q15_t)0x1985, (q15_t)0x3324, + (q15_t)0x198f, (q15_t)0x332c, (q15_t)0x199a, (q15_t)0x3333, (q15_t)0x19a4, (q15_t)0x333b, (q15_t)0x19ae, (q15_t)0x3342, + (q15_t)0x19b8, (q15_t)0x334a, (q15_t)0x19c2, (q15_t)0x3351, (q15_t)0x19cc, (q15_t)0x3359, (q15_t)0x19d6, (q15_t)0x3360, + (q15_t)0x19e0, (q15_t)0x3368, (q15_t)0x19ea, (q15_t)0x336f, (q15_t)0x19f4, (q15_t)0x3377, (q15_t)0x19fe, (q15_t)0x337e, + (q15_t)0x1a08, (q15_t)0x3386, (q15_t)0x1a13, (q15_t)0x338d, (q15_t)0x1a1d, (q15_t)0x3395, (q15_t)0x1a27, (q15_t)0x339c, + (q15_t)0x1a31, (q15_t)0x33a3, (q15_t)0x1a3b, (q15_t)0x33ab, (q15_t)0x1a45, (q15_t)0x33b2, (q15_t)0x1a4f, (q15_t)0x33ba, + (q15_t)0x1a5a, (q15_t)0x33c1, (q15_t)0x1a64, (q15_t)0x33c8, (q15_t)0x1a6e, (q15_t)0x33d0, (q15_t)0x1a78, (q15_t)0x33d7, + (q15_t)0x1a82, (q15_t)0x33df, (q15_t)0x1a8c, (q15_t)0x33e6, (q15_t)0x1a97, (q15_t)0x33ed, (q15_t)0x1aa1, (q15_t)0x33f5, + (q15_t)0x1aab, (q15_t)0x33fc, (q15_t)0x1ab5, (q15_t)0x3403, (q15_t)0x1abf, (q15_t)0x340b, (q15_t)0x1aca, (q15_t)0x3412, + (q15_t)0x1ad4, (q15_t)0x3419, (q15_t)0x1ade, (q15_t)0x3420, (q15_t)0x1ae8, (q15_t)0x3428, (q15_t)0x1af3, (q15_t)0x342f, + (q15_t)0x1afd, (q15_t)0x3436, (q15_t)0x1b07, (q15_t)0x343e, (q15_t)0x1b11, (q15_t)0x3445, (q15_t)0x1b1c, (q15_t)0x344c, + (q15_t)0x1b26, (q15_t)0x3453, (q15_t)0x1b30, (q15_t)0x345b, (q15_t)0x1b3b, (q15_t)0x3462, (q15_t)0x1b45, (q15_t)0x3469, + (q15_t)0x1b4f, (q15_t)0x3470, (q15_t)0x1b59, (q15_t)0x3477, (q15_t)0x1b64, (q15_t)0x347f, (q15_t)0x1b6e, (q15_t)0x3486, + (q15_t)0x1b78, (q15_t)0x348d, (q15_t)0x1b83, (q15_t)0x3494, (q15_t)0x1b8d, (q15_t)0x349b, (q15_t)0x1b97, (q15_t)0x34a2, + (q15_t)0x1ba2, (q15_t)0x34aa, (q15_t)0x1bac, (q15_t)0x34b1, (q15_t)0x1bb6, (q15_t)0x34b8, (q15_t)0x1bc1, (q15_t)0x34bf, + (q15_t)0x1bcb, (q15_t)0x34c6, (q15_t)0x1bd5, (q15_t)0x34cd, (q15_t)0x1be0, (q15_t)0x34d4, (q15_t)0x1bea, (q15_t)0x34db, + (q15_t)0x1bf5, (q15_t)0x34e2, (q15_t)0x1bff, (q15_t)0x34ea, (q15_t)0x1c09, (q15_t)0x34f1, (q15_t)0x1c14, (q15_t)0x34f8, + (q15_t)0x1c1e, (q15_t)0x34ff, (q15_t)0x1c29, (q15_t)0x3506, (q15_t)0x1c33, (q15_t)0x350d, (q15_t)0x1c3d, (q15_t)0x3514, + (q15_t)0x1c48, (q15_t)0x351b, (q15_t)0x1c52, (q15_t)0x3522, (q15_t)0x1c5d, (q15_t)0x3529, (q15_t)0x1c67, (q15_t)0x3530, + (q15_t)0x1c72, (q15_t)0x3537, (q15_t)0x1c7c, (q15_t)0x353e, (q15_t)0x1c86, (q15_t)0x3545, (q15_t)0x1c91, (q15_t)0x354c, + (q15_t)0x1c9b, (q15_t)0x3553, (q15_t)0x1ca6, (q15_t)0x355a, (q15_t)0x1cb0, (q15_t)0x3561, (q15_t)0x1cbb, (q15_t)0x3567, + (q15_t)0x1cc5, (q15_t)0x356e, (q15_t)0x1cd0, (q15_t)0x3575, (q15_t)0x1cda, (q15_t)0x357c, (q15_t)0x1ce5, (q15_t)0x3583, + (q15_t)0x1cef, (q15_t)0x358a, (q15_t)0x1cfa, (q15_t)0x3591, (q15_t)0x1d04, (q15_t)0x3598, (q15_t)0x1d0f, (q15_t)0x359f, + (q15_t)0x1d19, (q15_t)0x35a5, (q15_t)0x1d24, (q15_t)0x35ac, (q15_t)0x1d2e, (q15_t)0x35b3, (q15_t)0x1d39, (q15_t)0x35ba, + (q15_t)0x1d44, (q15_t)0x35c1, (q15_t)0x1d4e, (q15_t)0x35c8, (q15_t)0x1d59, (q15_t)0x35ce, (q15_t)0x1d63, (q15_t)0x35d5, + (q15_t)0x1d6e, (q15_t)0x35dc, (q15_t)0x1d78, (q15_t)0x35e3, (q15_t)0x1d83, (q15_t)0x35ea, (q15_t)0x1d8e, (q15_t)0x35f0, + (q15_t)0x1d98, (q15_t)0x35f7, (q15_t)0x1da3, (q15_t)0x35fe, (q15_t)0x1dad, (q15_t)0x3605, (q15_t)0x1db8, (q15_t)0x360b, + (q15_t)0x1dc3, (q15_t)0x3612, (q15_t)0x1dcd, (q15_t)0x3619, (q15_t)0x1dd8, (q15_t)0x3620, (q15_t)0x1de2, (q15_t)0x3626, + (q15_t)0x1ded, (q15_t)0x362d, (q15_t)0x1df8, (q15_t)0x3634, (q15_t)0x1e02, (q15_t)0x363a, (q15_t)0x1e0d, (q15_t)0x3641, + (q15_t)0x1e18, (q15_t)0x3648, (q15_t)0x1e22, (q15_t)0x364e, (q15_t)0x1e2d, (q15_t)0x3655, (q15_t)0x1e38, (q15_t)0x365c, + (q15_t)0x1e42, (q15_t)0x3662, (q15_t)0x1e4d, (q15_t)0x3669, (q15_t)0x1e58, (q15_t)0x366f, (q15_t)0x1e62, (q15_t)0x3676, + (q15_t)0x1e6d, (q15_t)0x367d, (q15_t)0x1e78, (q15_t)0x3683, (q15_t)0x1e83, (q15_t)0x368a, (q15_t)0x1e8d, (q15_t)0x3690, + (q15_t)0x1e98, (q15_t)0x3697, (q15_t)0x1ea3, (q15_t)0x369d, (q15_t)0x1ead, (q15_t)0x36a4, (q15_t)0x1eb8, (q15_t)0x36ab, + (q15_t)0x1ec3, (q15_t)0x36b1, (q15_t)0x1ece, (q15_t)0x36b8, (q15_t)0x1ed8, (q15_t)0x36be, (q15_t)0x1ee3, (q15_t)0x36c5, + (q15_t)0x1eee, (q15_t)0x36cb, (q15_t)0x1ef9, (q15_t)0x36d2, (q15_t)0x1f03, (q15_t)0x36d8, (q15_t)0x1f0e, (q15_t)0x36df, + (q15_t)0x1f19, (q15_t)0x36e5, (q15_t)0x1f24, (q15_t)0x36eb, (q15_t)0x1f2f, (q15_t)0x36f2, (q15_t)0x1f39, (q15_t)0x36f8, + (q15_t)0x1f44, (q15_t)0x36ff, (q15_t)0x1f4f, (q15_t)0x3705, (q15_t)0x1f5a, (q15_t)0x370c, (q15_t)0x1f65, (q15_t)0x3712, + (q15_t)0x1f6f, (q15_t)0x3718, (q15_t)0x1f7a, (q15_t)0x371f, (q15_t)0x1f85, (q15_t)0x3725, (q15_t)0x1f90, (q15_t)0x372c, + (q15_t)0x1f9b, (q15_t)0x3732, (q15_t)0x1fa5, (q15_t)0x3738, (q15_t)0x1fb0, (q15_t)0x373f, (q15_t)0x1fbb, (q15_t)0x3745, + (q15_t)0x1fc6, (q15_t)0x374b, (q15_t)0x1fd1, (q15_t)0x3752, (q15_t)0x1fdc, (q15_t)0x3758, (q15_t)0x1fe7, (q15_t)0x375e, + (q15_t)0x1ff1, (q15_t)0x3765, (q15_t)0x1ffc, (q15_t)0x376b, (q15_t)0x2007, (q15_t)0x3771, (q15_t)0x2012, (q15_t)0x3777, + (q15_t)0x201d, (q15_t)0x377e, (q15_t)0x2028, (q15_t)0x3784, (q15_t)0x2033, (q15_t)0x378a, (q15_t)0x203e, (q15_t)0x3790, + (q15_t)0x2049, (q15_t)0x3797, (q15_t)0x2054, (q15_t)0x379d, (q15_t)0x205e, (q15_t)0x37a3, (q15_t)0x2069, (q15_t)0x37a9, + (q15_t)0x2074, (q15_t)0x37b0, (q15_t)0x207f, (q15_t)0x37b6, (q15_t)0x208a, (q15_t)0x37bc, (q15_t)0x2095, (q15_t)0x37c2, + (q15_t)0x20a0, (q15_t)0x37c8, (q15_t)0x20ab, (q15_t)0x37ce, (q15_t)0x20b6, (q15_t)0x37d5, (q15_t)0x20c1, (q15_t)0x37db, + (q15_t)0x20cc, (q15_t)0x37e1, (q15_t)0x20d7, (q15_t)0x37e7, (q15_t)0x20e2, (q15_t)0x37ed, (q15_t)0x20ed, (q15_t)0x37f3, + (q15_t)0x20f8, (q15_t)0x37f9, (q15_t)0x2103, (q15_t)0x37ff, (q15_t)0x210e, (q15_t)0x3805, (q15_t)0x2119, (q15_t)0x380b, + (q15_t)0x2124, (q15_t)0x3812, (q15_t)0x212f, (q15_t)0x3818, (q15_t)0x213a, (q15_t)0x381e, (q15_t)0x2145, (q15_t)0x3824, + (q15_t)0x2150, (q15_t)0x382a, (q15_t)0x215b, (q15_t)0x3830, (q15_t)0x2166, (q15_t)0x3836, (q15_t)0x2171, (q15_t)0x383c, + (q15_t)0x217c, (q15_t)0x3842, (q15_t)0x2187, (q15_t)0x3848, (q15_t)0x2192, (q15_t)0x384e, (q15_t)0x219d, (q15_t)0x3854, + (q15_t)0x21a8, (q15_t)0x385a, (q15_t)0x21b3, (q15_t)0x3860, (q15_t)0x21be, (q15_t)0x3866, (q15_t)0x21ca, (q15_t)0x386b, + (q15_t)0x21d5, (q15_t)0x3871, (q15_t)0x21e0, (q15_t)0x3877, (q15_t)0x21eb, (q15_t)0x387d, (q15_t)0x21f6, (q15_t)0x3883, + (q15_t)0x2201, (q15_t)0x3889, (q15_t)0x220c, (q15_t)0x388f, (q15_t)0x2217, (q15_t)0x3895, (q15_t)0x2222, (q15_t)0x389b, + (q15_t)0x222d, (q15_t)0x38a1, (q15_t)0x2239, (q15_t)0x38a6, (q15_t)0x2244, (q15_t)0x38ac, (q15_t)0x224f, (q15_t)0x38b2, + (q15_t)0x225a, (q15_t)0x38b8, (q15_t)0x2265, (q15_t)0x38be, (q15_t)0x2270, (q15_t)0x38c3, (q15_t)0x227b, (q15_t)0x38c9, + (q15_t)0x2287, (q15_t)0x38cf, (q15_t)0x2292, (q15_t)0x38d5, (q15_t)0x229d, (q15_t)0x38db, (q15_t)0x22a8, (q15_t)0x38e0, + (q15_t)0x22b3, (q15_t)0x38e6, (q15_t)0x22be, (q15_t)0x38ec, (q15_t)0x22ca, (q15_t)0x38f2, (q15_t)0x22d5, (q15_t)0x38f7, + (q15_t)0x22e0, (q15_t)0x38fd, (q15_t)0x22eb, (q15_t)0x3903, (q15_t)0x22f6, (q15_t)0x3909, (q15_t)0x2301, (q15_t)0x390e, + (q15_t)0x230d, (q15_t)0x3914, (q15_t)0x2318, (q15_t)0x391a, (q15_t)0x2323, (q15_t)0x391f, (q15_t)0x232e, (q15_t)0x3925, + (q15_t)0x233a, (q15_t)0x392b, (q15_t)0x2345, (q15_t)0x3930, (q15_t)0x2350, (q15_t)0x3936, (q15_t)0x235b, (q15_t)0x393b, + (q15_t)0x2367, (q15_t)0x3941, (q15_t)0x2372, (q15_t)0x3947, (q15_t)0x237d, (q15_t)0x394c, (q15_t)0x2388, (q15_t)0x3952, + (q15_t)0x2394, (q15_t)0x3958, (q15_t)0x239f, (q15_t)0x395d, (q15_t)0x23aa, (q15_t)0x3963, (q15_t)0x23b5, (q15_t)0x3968, + (q15_t)0x23c1, (q15_t)0x396e, (q15_t)0x23cc, (q15_t)0x3973, (q15_t)0x23d7, (q15_t)0x3979, (q15_t)0x23e2, (q15_t)0x397e, + (q15_t)0x23ee, (q15_t)0x3984, (q15_t)0x23f9, (q15_t)0x3989, (q15_t)0x2404, (q15_t)0x398f, (q15_t)0x2410, (q15_t)0x3994, + (q15_t)0x241b, (q15_t)0x399a, (q15_t)0x2426, (q15_t)0x399f, (q15_t)0x2432, (q15_t)0x39a5, (q15_t)0x243d, (q15_t)0x39aa, + (q15_t)0x2448, (q15_t)0x39b0, (q15_t)0x2454, (q15_t)0x39b5, (q15_t)0x245f, (q15_t)0x39bb, (q15_t)0x246a, (q15_t)0x39c0, + (q15_t)0x2476, (q15_t)0x39c5, (q15_t)0x2481, (q15_t)0x39cb, (q15_t)0x248c, (q15_t)0x39d0, (q15_t)0x2498, (q15_t)0x39d6, + (q15_t)0x24a3, (q15_t)0x39db, (q15_t)0x24ae, (q15_t)0x39e0, (q15_t)0x24ba, (q15_t)0x39e6, (q15_t)0x24c5, (q15_t)0x39eb, + (q15_t)0x24d0, (q15_t)0x39f0, (q15_t)0x24dc, (q15_t)0x39f6, (q15_t)0x24e7, (q15_t)0x39fb, (q15_t)0x24f3, (q15_t)0x3a00, + (q15_t)0x24fe, (q15_t)0x3a06, (q15_t)0x2509, (q15_t)0x3a0b, (q15_t)0x2515, (q15_t)0x3a10, (q15_t)0x2520, (q15_t)0x3a16, + (q15_t)0x252c, (q15_t)0x3a1b, (q15_t)0x2537, (q15_t)0x3a20, (q15_t)0x2542, (q15_t)0x3a25, (q15_t)0x254e, (q15_t)0x3a2b, + (q15_t)0x2559, (q15_t)0x3a30, (q15_t)0x2565, (q15_t)0x3a35, (q15_t)0x2570, (q15_t)0x3a3a, (q15_t)0x257c, (q15_t)0x3a3f, + (q15_t)0x2587, (q15_t)0x3a45, (q15_t)0x2592, (q15_t)0x3a4a, (q15_t)0x259e, (q15_t)0x3a4f, (q15_t)0x25a9, (q15_t)0x3a54, + (q15_t)0x25b5, (q15_t)0x3a59, (q15_t)0x25c0, (q15_t)0x3a5f, (q15_t)0x25cc, (q15_t)0x3a64, (q15_t)0x25d7, (q15_t)0x3a69, + (q15_t)0x25e3, (q15_t)0x3a6e, (q15_t)0x25ee, (q15_t)0x3a73, (q15_t)0x25fa, (q15_t)0x3a78, (q15_t)0x2605, (q15_t)0x3a7d, + (q15_t)0x2611, (q15_t)0x3a82, (q15_t)0x261c, (q15_t)0x3a88, (q15_t)0x2628, (q15_t)0x3a8d, (q15_t)0x2633, (q15_t)0x3a92, + (q15_t)0x263f, (q15_t)0x3a97, (q15_t)0x264a, (q15_t)0x3a9c, (q15_t)0x2656, (q15_t)0x3aa1, (q15_t)0x2661, (q15_t)0x3aa6, + (q15_t)0x266d, (q15_t)0x3aab, (q15_t)0x2678, (q15_t)0x3ab0, (q15_t)0x2684, (q15_t)0x3ab5, (q15_t)0x268f, (q15_t)0x3aba, + (q15_t)0x269b, (q15_t)0x3abf, (q15_t)0x26a6, (q15_t)0x3ac4, (q15_t)0x26b2, (q15_t)0x3ac9, (q15_t)0x26bd, (q15_t)0x3ace, + (q15_t)0x26c9, (q15_t)0x3ad3, (q15_t)0x26d4, (q15_t)0x3ad8, (q15_t)0x26e0, (q15_t)0x3add, (q15_t)0x26ec, (q15_t)0x3ae2, + (q15_t)0x26f7, (q15_t)0x3ae6, (q15_t)0x2703, (q15_t)0x3aeb, (q15_t)0x270e, (q15_t)0x3af0, (q15_t)0x271a, (q15_t)0x3af5, + (q15_t)0x2725, (q15_t)0x3afa, (q15_t)0x2731, (q15_t)0x3aff, (q15_t)0x273d, (q15_t)0x3b04, (q15_t)0x2748, (q15_t)0x3b09, + (q15_t)0x2754, (q15_t)0x3b0e, (q15_t)0x275f, (q15_t)0x3b12, (q15_t)0x276b, (q15_t)0x3b17, (q15_t)0x2777, (q15_t)0x3b1c, + (q15_t)0x2782, (q15_t)0x3b21, (q15_t)0x278e, (q15_t)0x3b26, (q15_t)0x2799, (q15_t)0x3b2a, (q15_t)0x27a5, (q15_t)0x3b2f, + (q15_t)0x27b1, (q15_t)0x3b34, (q15_t)0x27bc, (q15_t)0x3b39, (q15_t)0x27c8, (q15_t)0x3b3e, (q15_t)0x27d3, (q15_t)0x3b42, + (q15_t)0x27df, (q15_t)0x3b47, (q15_t)0x27eb, (q15_t)0x3b4c, (q15_t)0x27f6, (q15_t)0x3b50, (q15_t)0x2802, (q15_t)0x3b55, + (q15_t)0x280e, (q15_t)0x3b5a, (q15_t)0x2819, (q15_t)0x3b5f, (q15_t)0x2825, (q15_t)0x3b63, (q15_t)0x2831, (q15_t)0x3b68, + (q15_t)0x283c, (q15_t)0x3b6d, (q15_t)0x2848, (q15_t)0x3b71, (q15_t)0x2854, (q15_t)0x3b76, (q15_t)0x285f, (q15_t)0x3b7b, + (q15_t)0x286b, (q15_t)0x3b7f, (q15_t)0x2877, (q15_t)0x3b84, (q15_t)0x2882, (q15_t)0x3b88, (q15_t)0x288e, (q15_t)0x3b8d, + (q15_t)0x289a, (q15_t)0x3b92, (q15_t)0x28a5, (q15_t)0x3b96, (q15_t)0x28b1, (q15_t)0x3b9b, (q15_t)0x28bd, (q15_t)0x3b9f, + (q15_t)0x28c9, (q15_t)0x3ba4, (q15_t)0x28d4, (q15_t)0x3ba9, (q15_t)0x28e0, (q15_t)0x3bad, (q15_t)0x28ec, (q15_t)0x3bb2, + (q15_t)0x28f7, (q15_t)0x3bb6, (q15_t)0x2903, (q15_t)0x3bbb, (q15_t)0x290f, (q15_t)0x3bbf, (q15_t)0x291b, (q15_t)0x3bc4, + (q15_t)0x2926, (q15_t)0x3bc8, (q15_t)0x2932, (q15_t)0x3bcd, (q15_t)0x293e, (q15_t)0x3bd1, (q15_t)0x294a, (q15_t)0x3bd6, + (q15_t)0x2955, (q15_t)0x3bda, (q15_t)0x2961, (q15_t)0x3bde, (q15_t)0x296d, (q15_t)0x3be3, (q15_t)0x2979, (q15_t)0x3be7, + (q15_t)0x2984, (q15_t)0x3bec, (q15_t)0x2990, (q15_t)0x3bf0, (q15_t)0x299c, (q15_t)0x3bf5, (q15_t)0x29a8, (q15_t)0x3bf9, + (q15_t)0x29b4, (q15_t)0x3bfd, (q15_t)0x29bf, (q15_t)0x3c02, (q15_t)0x29cb, (q15_t)0x3c06, (q15_t)0x29d7, (q15_t)0x3c0a, + (q15_t)0x29e3, (q15_t)0x3c0f, (q15_t)0x29ee, (q15_t)0x3c13, (q15_t)0x29fa, (q15_t)0x3c17, (q15_t)0x2a06, (q15_t)0x3c1c, + (q15_t)0x2a12, (q15_t)0x3c20, (q15_t)0x2a1e, (q15_t)0x3c24, (q15_t)0x2a29, (q15_t)0x3c29, (q15_t)0x2a35, (q15_t)0x3c2d, + (q15_t)0x2a41, (q15_t)0x3c31, (q15_t)0x2a4d, (q15_t)0x3c36, (q15_t)0x2a59, (q15_t)0x3c3a, (q15_t)0x2a65, (q15_t)0x3c3e, + (q15_t)0x2a70, (q15_t)0x3c42, (q15_t)0x2a7c, (q15_t)0x3c46, (q15_t)0x2a88, (q15_t)0x3c4b, (q15_t)0x2a94, (q15_t)0x3c4f, + (q15_t)0x2aa0, (q15_t)0x3c53, (q15_t)0x2aac, (q15_t)0x3c57, (q15_t)0x2ab7, (q15_t)0x3c5b, (q15_t)0x2ac3, (q15_t)0x3c60, + (q15_t)0x2acf, (q15_t)0x3c64, (q15_t)0x2adb, (q15_t)0x3c68, (q15_t)0x2ae7, (q15_t)0x3c6c, (q15_t)0x2af3, (q15_t)0x3c70, + (q15_t)0x2aff, (q15_t)0x3c74, (q15_t)0x2b0a, (q15_t)0x3c79, (q15_t)0x2b16, (q15_t)0x3c7d, (q15_t)0x2b22, (q15_t)0x3c81, + (q15_t)0x2b2e, (q15_t)0x3c85, (q15_t)0x2b3a, (q15_t)0x3c89, (q15_t)0x2b46, (q15_t)0x3c8d, (q15_t)0x2b52, (q15_t)0x3c91, + (q15_t)0x2b5e, (q15_t)0x3c95, (q15_t)0x2b6a, (q15_t)0x3c99, (q15_t)0x2b75, (q15_t)0x3c9d, (q15_t)0x2b81, (q15_t)0x3ca1, + (q15_t)0x2b8d, (q15_t)0x3ca5, (q15_t)0x2b99, (q15_t)0x3ca9, (q15_t)0x2ba5, (q15_t)0x3cad, (q15_t)0x2bb1, (q15_t)0x3cb1, + (q15_t)0x2bbd, (q15_t)0x3cb5, (q15_t)0x2bc9, (q15_t)0x3cb9, (q15_t)0x2bd5, (q15_t)0x3cbd, (q15_t)0x2be1, (q15_t)0x3cc1, + (q15_t)0x2bed, (q15_t)0x3cc5, (q15_t)0x2bf9, (q15_t)0x3cc9, (q15_t)0x2c05, (q15_t)0x3ccd, (q15_t)0x2c10, (q15_t)0x3cd1, + (q15_t)0x2c1c, (q15_t)0x3cd5, (q15_t)0x2c28, (q15_t)0x3cd9, (q15_t)0x2c34, (q15_t)0x3cdd, (q15_t)0x2c40, (q15_t)0x3ce0, + (q15_t)0x2c4c, (q15_t)0x3ce4, (q15_t)0x2c58, (q15_t)0x3ce8, (q15_t)0x2c64, (q15_t)0x3cec, (q15_t)0x2c70, (q15_t)0x3cf0, + (q15_t)0x2c7c, (q15_t)0x3cf4, (q15_t)0x2c88, (q15_t)0x3cf8, (q15_t)0x2c94, (q15_t)0x3cfb, (q15_t)0x2ca0, (q15_t)0x3cff, + (q15_t)0x2cac, (q15_t)0x3d03, (q15_t)0x2cb8, (q15_t)0x3d07, (q15_t)0x2cc4, (q15_t)0x3d0b, (q15_t)0x2cd0, (q15_t)0x3d0e, + (q15_t)0x2cdc, (q15_t)0x3d12, (q15_t)0x2ce8, (q15_t)0x3d16, (q15_t)0x2cf4, (q15_t)0x3d1a, (q15_t)0x2d00, (q15_t)0x3d1d, + (q15_t)0x2d0c, (q15_t)0x3d21, (q15_t)0x2d18, (q15_t)0x3d25, (q15_t)0x2d24, (q15_t)0x3d28, (q15_t)0x2d30, (q15_t)0x3d2c, + (q15_t)0x2d3c, (q15_t)0x3d30, (q15_t)0x2d48, (q15_t)0x3d34, (q15_t)0x2d54, (q15_t)0x3d37, (q15_t)0x2d60, (q15_t)0x3d3b, + (q15_t)0x2d6c, (q15_t)0x3d3f, (q15_t)0x2d78, (q15_t)0x3d42, (q15_t)0x2d84, (q15_t)0x3d46, (q15_t)0x2d90, (q15_t)0x3d49, + (q15_t)0x2d9c, (q15_t)0x3d4d, (q15_t)0x2da8, (q15_t)0x3d51, (q15_t)0x2db4, (q15_t)0x3d54, (q15_t)0x2dc0, (q15_t)0x3d58, + (q15_t)0x2dcc, (q15_t)0x3d5b, (q15_t)0x2dd8, (q15_t)0x3d5f, (q15_t)0x2de4, (q15_t)0x3d63, (q15_t)0x2df0, (q15_t)0x3d66, + (q15_t)0x2dfc, (q15_t)0x3d6a, (q15_t)0x2e09, (q15_t)0x3d6d, (q15_t)0x2e15, (q15_t)0x3d71, (q15_t)0x2e21, (q15_t)0x3d74, + (q15_t)0x2e2d, (q15_t)0x3d78, (q15_t)0x2e39, (q15_t)0x3d7b, (q15_t)0x2e45, (q15_t)0x3d7f, (q15_t)0x2e51, (q15_t)0x3d82, + (q15_t)0x2e5d, (q15_t)0x3d86, (q15_t)0x2e69, (q15_t)0x3d89, (q15_t)0x2e75, (q15_t)0x3d8d, (q15_t)0x2e81, (q15_t)0x3d90, + (q15_t)0x2e8d, (q15_t)0x3d93, (q15_t)0x2e99, (q15_t)0x3d97, (q15_t)0x2ea6, (q15_t)0x3d9a, (q15_t)0x2eb2, (q15_t)0x3d9e, + (q15_t)0x2ebe, (q15_t)0x3da1, (q15_t)0x2eca, (q15_t)0x3da4, (q15_t)0x2ed6, (q15_t)0x3da8, (q15_t)0x2ee2, (q15_t)0x3dab, + (q15_t)0x2eee, (q15_t)0x3daf, (q15_t)0x2efa, (q15_t)0x3db2, (q15_t)0x2f06, (q15_t)0x3db5, (q15_t)0x2f13, (q15_t)0x3db9, + (q15_t)0x2f1f, (q15_t)0x3dbc, (q15_t)0x2f2b, (q15_t)0x3dbf, (q15_t)0x2f37, (q15_t)0x3dc2, (q15_t)0x2f43, (q15_t)0x3dc6, + (q15_t)0x2f4f, (q15_t)0x3dc9, (q15_t)0x2f5b, (q15_t)0x3dcc, (q15_t)0x2f67, (q15_t)0x3dd0, (q15_t)0x2f74, (q15_t)0x3dd3, + (q15_t)0x2f80, (q15_t)0x3dd6, (q15_t)0x2f8c, (q15_t)0x3dd9, (q15_t)0x2f98, (q15_t)0x3ddd, (q15_t)0x2fa4, (q15_t)0x3de0, + (q15_t)0x2fb0, (q15_t)0x3de3, (q15_t)0x2fbc, (q15_t)0x3de6, (q15_t)0x2fc9, (q15_t)0x3de9, (q15_t)0x2fd5, (q15_t)0x3ded, + (q15_t)0x2fe1, (q15_t)0x3df0, (q15_t)0x2fed, (q15_t)0x3df3, (q15_t)0x2ff9, (q15_t)0x3df6, (q15_t)0x3005, (q15_t)0x3df9, + (q15_t)0x3012, (q15_t)0x3dfc, (q15_t)0x301e, (q15_t)0x3dff, (q15_t)0x302a, (q15_t)0x3e03, (q15_t)0x3036, (q15_t)0x3e06, + (q15_t)0x3042, (q15_t)0x3e09, (q15_t)0x304e, (q15_t)0x3e0c, (q15_t)0x305b, (q15_t)0x3e0f, (q15_t)0x3067, (q15_t)0x3e12, + (q15_t)0x3073, (q15_t)0x3e15, (q15_t)0x307f, (q15_t)0x3e18, (q15_t)0x308b, (q15_t)0x3e1b, (q15_t)0x3098, (q15_t)0x3e1e, + (q15_t)0x30a4, (q15_t)0x3e21, (q15_t)0x30b0, (q15_t)0x3e24, (q15_t)0x30bc, (q15_t)0x3e27, (q15_t)0x30c8, (q15_t)0x3e2a, + (q15_t)0x30d5, (q15_t)0x3e2d, (q15_t)0x30e1, (q15_t)0x3e30, (q15_t)0x30ed, (q15_t)0x3e33, (q15_t)0x30f9, (q15_t)0x3e36, + (q15_t)0x3105, (q15_t)0x3e39, (q15_t)0x3112, (q15_t)0x3e3c, (q15_t)0x311e, (q15_t)0x3e3f, (q15_t)0x312a, (q15_t)0x3e42, + (q15_t)0x3136, (q15_t)0x3e45, (q15_t)0x3143, (q15_t)0x3e48, (q15_t)0x314f, (q15_t)0x3e4a, (q15_t)0x315b, (q15_t)0x3e4d, + (q15_t)0x3167, (q15_t)0x3e50, (q15_t)0x3174, (q15_t)0x3e53, (q15_t)0x3180, (q15_t)0x3e56, (q15_t)0x318c, (q15_t)0x3e59, + (q15_t)0x3198, (q15_t)0x3e5c, (q15_t)0x31a4, (q15_t)0x3e5e, (q15_t)0x31b1, (q15_t)0x3e61, (q15_t)0x31bd, (q15_t)0x3e64, + (q15_t)0x31c9, (q15_t)0x3e67, (q15_t)0x31d5, (q15_t)0x3e6a, (q15_t)0x31e2, (q15_t)0x3e6c, (q15_t)0x31ee, (q15_t)0x3e6f, + (q15_t)0x31fa, (q15_t)0x3e72, (q15_t)0x3207, (q15_t)0x3e75, (q15_t)0x3213, (q15_t)0x3e77, (q15_t)0x321f, (q15_t)0x3e7a, + (q15_t)0x322b, (q15_t)0x3e7d, (q15_t)0x3238, (q15_t)0x3e80, (q15_t)0x3244, (q15_t)0x3e82, (q15_t)0x3250, (q15_t)0x3e85, + (q15_t)0x325c, (q15_t)0x3e88, (q15_t)0x3269, (q15_t)0x3e8a, (q15_t)0x3275, (q15_t)0x3e8d, (q15_t)0x3281, (q15_t)0x3e90, + (q15_t)0x328e, (q15_t)0x3e92, (q15_t)0x329a, (q15_t)0x3e95, (q15_t)0x32a6, (q15_t)0x3e98, (q15_t)0x32b2, (q15_t)0x3e9a, + (q15_t)0x32bf, (q15_t)0x3e9d, (q15_t)0x32cb, (q15_t)0x3e9f, (q15_t)0x32d7, (q15_t)0x3ea2, (q15_t)0x32e4, (q15_t)0x3ea5, + (q15_t)0x32f0, (q15_t)0x3ea7, (q15_t)0x32fc, (q15_t)0x3eaa, (q15_t)0x3308, (q15_t)0x3eac, (q15_t)0x3315, (q15_t)0x3eaf, + (q15_t)0x3321, (q15_t)0x3eb1, (q15_t)0x332d, (q15_t)0x3eb4, (q15_t)0x333a, (q15_t)0x3eb6, (q15_t)0x3346, (q15_t)0x3eb9, + (q15_t)0x3352, (q15_t)0x3ebb, (q15_t)0x335f, (q15_t)0x3ebe, (q15_t)0x336b, (q15_t)0x3ec0, (q15_t)0x3377, (q15_t)0x3ec3, + (q15_t)0x3384, (q15_t)0x3ec5, (q15_t)0x3390, (q15_t)0x3ec8, (q15_t)0x339c, (q15_t)0x3eca, (q15_t)0x33a9, (q15_t)0x3ecc, + (q15_t)0x33b5, (q15_t)0x3ecf, (q15_t)0x33c1, (q15_t)0x3ed1, (q15_t)0x33ce, (q15_t)0x3ed4, (q15_t)0x33da, (q15_t)0x3ed6, + (q15_t)0x33e6, (q15_t)0x3ed8, (q15_t)0x33f3, (q15_t)0x3edb, (q15_t)0x33ff, (q15_t)0x3edd, (q15_t)0x340b, (q15_t)0x3ee0, + (q15_t)0x3418, (q15_t)0x3ee2, (q15_t)0x3424, (q15_t)0x3ee4, (q15_t)0x3430, (q15_t)0x3ee7, (q15_t)0x343d, (q15_t)0x3ee9, + (q15_t)0x3449, (q15_t)0x3eeb, (q15_t)0x3455, (q15_t)0x3eed, (q15_t)0x3462, (q15_t)0x3ef0, (q15_t)0x346e, (q15_t)0x3ef2, + (q15_t)0x347b, (q15_t)0x3ef4, (q15_t)0x3487, (q15_t)0x3ef7, (q15_t)0x3493, (q15_t)0x3ef9, (q15_t)0x34a0, (q15_t)0x3efb, + (q15_t)0x34ac, (q15_t)0x3efd, (q15_t)0x34b8, (q15_t)0x3f00, (q15_t)0x34c5, (q15_t)0x3f02, (q15_t)0x34d1, (q15_t)0x3f04, + (q15_t)0x34dd, (q15_t)0x3f06, (q15_t)0x34ea, (q15_t)0x3f08, (q15_t)0x34f6, (q15_t)0x3f0a, (q15_t)0x3503, (q15_t)0x3f0d, + (q15_t)0x350f, (q15_t)0x3f0f, (q15_t)0x351b, (q15_t)0x3f11, (q15_t)0x3528, (q15_t)0x3f13, (q15_t)0x3534, (q15_t)0x3f15, + (q15_t)0x3540, (q15_t)0x3f17, (q15_t)0x354d, (q15_t)0x3f19, (q15_t)0x3559, (q15_t)0x3f1c, (q15_t)0x3566, (q15_t)0x3f1e, + (q15_t)0x3572, (q15_t)0x3f20, (q15_t)0x357e, (q15_t)0x3f22, (q15_t)0x358b, (q15_t)0x3f24, (q15_t)0x3597, (q15_t)0x3f26, + (q15_t)0x35a4, (q15_t)0x3f28, (q15_t)0x35b0, (q15_t)0x3f2a, (q15_t)0x35bc, (q15_t)0x3f2c, (q15_t)0x35c9, (q15_t)0x3f2e, + (q15_t)0x35d5, (q15_t)0x3f30, (q15_t)0x35e2, (q15_t)0x3f32, (q15_t)0x35ee, (q15_t)0x3f34, (q15_t)0x35fa, (q15_t)0x3f36, + (q15_t)0x3607, (q15_t)0x3f38, (q15_t)0x3613, (q15_t)0x3f3a, (q15_t)0x3620, (q15_t)0x3f3c, (q15_t)0x362c, (q15_t)0x3f3e, + (q15_t)0x3639, (q15_t)0x3f40, (q15_t)0x3645, (q15_t)0x3f42, (q15_t)0x3651, (q15_t)0x3f43, (q15_t)0x365e, (q15_t)0x3f45, + (q15_t)0x366a, (q15_t)0x3f47, (q15_t)0x3677, (q15_t)0x3f49, (q15_t)0x3683, (q15_t)0x3f4b, (q15_t)0x3690, (q15_t)0x3f4d, + (q15_t)0x369c, (q15_t)0x3f4f, (q15_t)0x36a8, (q15_t)0x3f51, (q15_t)0x36b5, (q15_t)0x3f52, (q15_t)0x36c1, (q15_t)0x3f54, + (q15_t)0x36ce, (q15_t)0x3f56, (q15_t)0x36da, (q15_t)0x3f58, (q15_t)0x36e7, (q15_t)0x3f5a, (q15_t)0x36f3, (q15_t)0x3f5b, + (q15_t)0x36ff, (q15_t)0x3f5d, (q15_t)0x370c, (q15_t)0x3f5f, (q15_t)0x3718, (q15_t)0x3f61, (q15_t)0x3725, (q15_t)0x3f62, + (q15_t)0x3731, (q15_t)0x3f64, (q15_t)0x373e, (q15_t)0x3f66, (q15_t)0x374a, (q15_t)0x3f68, (q15_t)0x3757, (q15_t)0x3f69, + (q15_t)0x3763, (q15_t)0x3f6b, (q15_t)0x376f, (q15_t)0x3f6d, (q15_t)0x377c, (q15_t)0x3f6e, (q15_t)0x3788, (q15_t)0x3f70, + (q15_t)0x3795, (q15_t)0x3f72, (q15_t)0x37a1, (q15_t)0x3f73, (q15_t)0x37ae, (q15_t)0x3f75, (q15_t)0x37ba, (q15_t)0x3f77, + (q15_t)0x37c7, (q15_t)0x3f78, (q15_t)0x37d3, (q15_t)0x3f7a, (q15_t)0x37e0, (q15_t)0x3f7b, (q15_t)0x37ec, (q15_t)0x3f7d, + (q15_t)0x37f9, (q15_t)0x3f7f, (q15_t)0x3805, (q15_t)0x3f80, (q15_t)0x3811, (q15_t)0x3f82, (q15_t)0x381e, (q15_t)0x3f83, + (q15_t)0x382a, (q15_t)0x3f85, (q15_t)0x3837, (q15_t)0x3f86, (q15_t)0x3843, (q15_t)0x3f88, (q15_t)0x3850, (q15_t)0x3f89, + (q15_t)0x385c, (q15_t)0x3f8b, (q15_t)0x3869, (q15_t)0x3f8c, (q15_t)0x3875, (q15_t)0x3f8e, (q15_t)0x3882, (q15_t)0x3f8f, + (q15_t)0x388e, (q15_t)0x3f91, (q15_t)0x389b, (q15_t)0x3f92, (q15_t)0x38a7, (q15_t)0x3f94, (q15_t)0x38b4, (q15_t)0x3f95, + (q15_t)0x38c0, (q15_t)0x3f97, (q15_t)0x38cd, (q15_t)0x3f98, (q15_t)0x38d9, (q15_t)0x3f99, (q15_t)0x38e6, (q15_t)0x3f9b, + (q15_t)0x38f2, (q15_t)0x3f9c, (q15_t)0x38ff, (q15_t)0x3f9e, (q15_t)0x390b, (q15_t)0x3f9f, (q15_t)0x3918, (q15_t)0x3fa0, + (q15_t)0x3924, (q15_t)0x3fa2, (q15_t)0x3931, (q15_t)0x3fa3, (q15_t)0x393d, (q15_t)0x3fa4, (q15_t)0x394a, (q15_t)0x3fa6, + (q15_t)0x3956, (q15_t)0x3fa7, (q15_t)0x3963, (q15_t)0x3fa8, (q15_t)0x396f, (q15_t)0x3faa, (q15_t)0x397c, (q15_t)0x3fab, + (q15_t)0x3988, (q15_t)0x3fac, (q15_t)0x3995, (q15_t)0x3fad, (q15_t)0x39a1, (q15_t)0x3faf, (q15_t)0x39ae, (q15_t)0x3fb0, + (q15_t)0x39ba, (q15_t)0x3fb1, (q15_t)0x39c7, (q15_t)0x3fb2, (q15_t)0x39d3, (q15_t)0x3fb4, (q15_t)0x39e0, (q15_t)0x3fb5, + (q15_t)0x39ec, (q15_t)0x3fb6, (q15_t)0x39f9, (q15_t)0x3fb7, (q15_t)0x3a05, (q15_t)0x3fb8, (q15_t)0x3a12, (q15_t)0x3fb9, + (q15_t)0x3a1e, (q15_t)0x3fbb, (q15_t)0x3a2b, (q15_t)0x3fbc, (q15_t)0x3a37, (q15_t)0x3fbd, (q15_t)0x3a44, (q15_t)0x3fbe, + (q15_t)0x3a50, (q15_t)0x3fbf, (q15_t)0x3a5d, (q15_t)0x3fc0, (q15_t)0x3a69, (q15_t)0x3fc1, (q15_t)0x3a76, (q15_t)0x3fc3, + (q15_t)0x3a82, (q15_t)0x3fc4, (q15_t)0x3a8f, (q15_t)0x3fc5, (q15_t)0x3a9b, (q15_t)0x3fc6, (q15_t)0x3aa8, (q15_t)0x3fc7, + (q15_t)0x3ab4, (q15_t)0x3fc8, (q15_t)0x3ac1, (q15_t)0x3fc9, (q15_t)0x3acd, (q15_t)0x3fca, (q15_t)0x3ada, (q15_t)0x3fcb, + (q15_t)0x3ae6, (q15_t)0x3fcc, (q15_t)0x3af3, (q15_t)0x3fcd, (q15_t)0x3b00, (q15_t)0x3fce, (q15_t)0x3b0c, (q15_t)0x3fcf, + (q15_t)0x3b19, (q15_t)0x3fd0, (q15_t)0x3b25, (q15_t)0x3fd1, (q15_t)0x3b32, (q15_t)0x3fd2, (q15_t)0x3b3e, (q15_t)0x3fd3, + (q15_t)0x3b4b, (q15_t)0x3fd4, (q15_t)0x3b57, (q15_t)0x3fd5, (q15_t)0x3b64, (q15_t)0x3fd5, (q15_t)0x3b70, (q15_t)0x3fd6, + (q15_t)0x3b7d, (q15_t)0x3fd7, (q15_t)0x3b89, (q15_t)0x3fd8, (q15_t)0x3b96, (q15_t)0x3fd9, (q15_t)0x3ba2, (q15_t)0x3fda, + (q15_t)0x3baf, (q15_t)0x3fdb, (q15_t)0x3bbc, (q15_t)0x3fdc, (q15_t)0x3bc8, (q15_t)0x3fdc, (q15_t)0x3bd5, (q15_t)0x3fdd, + (q15_t)0x3be1, (q15_t)0x3fde, (q15_t)0x3bee, (q15_t)0x3fdf, (q15_t)0x3bfa, (q15_t)0x3fe0, (q15_t)0x3c07, (q15_t)0x3fe0, + (q15_t)0x3c13, (q15_t)0x3fe1, (q15_t)0x3c20, (q15_t)0x3fe2, (q15_t)0x3c2c, (q15_t)0x3fe3, (q15_t)0x3c39, (q15_t)0x3fe3, + (q15_t)0x3c45, (q15_t)0x3fe4, (q15_t)0x3c52, (q15_t)0x3fe5, (q15_t)0x3c5f, (q15_t)0x3fe6, (q15_t)0x3c6b, (q15_t)0x3fe6, + (q15_t)0x3c78, (q15_t)0x3fe7, (q15_t)0x3c84, (q15_t)0x3fe8, (q15_t)0x3c91, (q15_t)0x3fe8, (q15_t)0x3c9d, (q15_t)0x3fe9, + (q15_t)0x3caa, (q15_t)0x3fea, (q15_t)0x3cb6, (q15_t)0x3fea, (q15_t)0x3cc3, (q15_t)0x3feb, (q15_t)0x3cd0, (q15_t)0x3fec, + (q15_t)0x3cdc, (q15_t)0x3fec, (q15_t)0x3ce9, (q15_t)0x3fed, (q15_t)0x3cf5, (q15_t)0x3fed, (q15_t)0x3d02, (q15_t)0x3fee, + (q15_t)0x3d0e, (q15_t)0x3fef, (q15_t)0x3d1b, (q15_t)0x3fef, (q15_t)0x3d27, (q15_t)0x3ff0, (q15_t)0x3d34, (q15_t)0x3ff0, + (q15_t)0x3d40, (q15_t)0x3ff1, (q15_t)0x3d4d, (q15_t)0x3ff1, (q15_t)0x3d5a, (q15_t)0x3ff2, (q15_t)0x3d66, (q15_t)0x3ff2, + (q15_t)0x3d73, (q15_t)0x3ff3, (q15_t)0x3d7f, (q15_t)0x3ff3, (q15_t)0x3d8c, (q15_t)0x3ff4, (q15_t)0x3d98, (q15_t)0x3ff4, + (q15_t)0x3da5, (q15_t)0x3ff5, (q15_t)0x3db2, (q15_t)0x3ff5, (q15_t)0x3dbe, (q15_t)0x3ff6, (q15_t)0x3dcb, (q15_t)0x3ff6, + (q15_t)0x3dd7, (q15_t)0x3ff7, (q15_t)0x3de4, (q15_t)0x3ff7, (q15_t)0x3df0, (q15_t)0x3ff7, (q15_t)0x3dfd, (q15_t)0x3ff8, + (q15_t)0x3e09, (q15_t)0x3ff8, (q15_t)0x3e16, (q15_t)0x3ff9, (q15_t)0x3e23, (q15_t)0x3ff9, (q15_t)0x3e2f, (q15_t)0x3ff9, + (q15_t)0x3e3c, (q15_t)0x3ffa, (q15_t)0x3e48, (q15_t)0x3ffa, (q15_t)0x3e55, (q15_t)0x3ffa, (q15_t)0x3e61, (q15_t)0x3ffb, + (q15_t)0x3e6e, (q15_t)0x3ffb, (q15_t)0x3e7a, (q15_t)0x3ffb, (q15_t)0x3e87, (q15_t)0x3ffc, (q15_t)0x3e94, (q15_t)0x3ffc, + (q15_t)0x3ea0, (q15_t)0x3ffc, (q15_t)0x3ead, (q15_t)0x3ffc, (q15_t)0x3eb9, (q15_t)0x3ffd, (q15_t)0x3ec6, (q15_t)0x3ffd, + (q15_t)0x3ed2, (q15_t)0x3ffd, (q15_t)0x3edf, (q15_t)0x3ffd, (q15_t)0x3eec, (q15_t)0x3ffe, (q15_t)0x3ef8, (q15_t)0x3ffe, + (q15_t)0x3f05, (q15_t)0x3ffe, (q15_t)0x3f11, (q15_t)0x3ffe, (q15_t)0x3f1e, (q15_t)0x3ffe, (q15_t)0x3f2a, (q15_t)0x3fff, + (q15_t)0x3f37, (q15_t)0x3fff, (q15_t)0x3f44, (q15_t)0x3fff, (q15_t)0x3f50, (q15_t)0x3fff, (q15_t)0x3f5d, (q15_t)0x3fff, + (q15_t)0x3f69, (q15_t)0x3fff, (q15_t)0x3f76, (q15_t)0x3fff, (q15_t)0x3f82, (q15_t)0x4000, (q15_t)0x3f8f, (q15_t)0x4000, + (q15_t)0x3f9b, (q15_t)0x4000, (q15_t)0x3fa8, (q15_t)0x4000, (q15_t)0x3fb5, (q15_t)0x4000, (q15_t)0x3fc1, (q15_t)0x4000, + (q15_t)0x3fce, (q15_t)0x4000, (q15_t)0x3fda, (q15_t)0x4000, (q15_t)0x3fe7, (q15_t)0x4000, (q15_t)0x3ff3, (q15_t)0x4000, +}; + +/** +* \par +* Generation of real_CoefB array: +* \par +* n = 4096 +*
for (i = 0; i < n; i++)
+*  {
+*    pBTable[2 * i] = 0.5 * (1.0 + sin (2 * PI / (double) (2 * n) * (double) i));
+*    pBTable[2 * i + 1] = 0.5 * (1.0 * cos (2 * PI / (double) (2 * n) * (double) i));
+*  } 
+* \par +* Convert to fixed point Q15 format +* round(pBTable[i] * pow(2, 15)) +* +*/ +const q15_t ALIGN4 realCoefBQ15[8192] = { + (q15_t)0x4000, (q15_t)0x4000, (q15_t)0x400d, (q15_t)0x4000, (q15_t)0x4019, (q15_t)0x4000, (q15_t)0x4026, (q15_t)0x4000, + (q15_t)0x4032, (q15_t)0x4000, (q15_t)0x403f, (q15_t)0x4000, (q15_t)0x404b, (q15_t)0x4000, (q15_t)0x4058, (q15_t)0x4000, + (q15_t)0x4065, (q15_t)0x4000, (q15_t)0x4071, (q15_t)0x4000, (q15_t)0x407e, (q15_t)0x4000, (q15_t)0x408a, (q15_t)0x3fff, + (q15_t)0x4097, (q15_t)0x3fff, (q15_t)0x40a3, (q15_t)0x3fff, (q15_t)0x40b0, (q15_t)0x3fff, (q15_t)0x40bc, (q15_t)0x3fff, + (q15_t)0x40c9, (q15_t)0x3fff, (q15_t)0x40d6, (q15_t)0x3fff, (q15_t)0x40e2, (q15_t)0x3ffe, (q15_t)0x40ef, (q15_t)0x3ffe, + (q15_t)0x40fb, (q15_t)0x3ffe, (q15_t)0x4108, (q15_t)0x3ffe, (q15_t)0x4114, (q15_t)0x3ffe, (q15_t)0x4121, (q15_t)0x3ffd, + (q15_t)0x412e, (q15_t)0x3ffd, (q15_t)0x413a, (q15_t)0x3ffd, (q15_t)0x4147, (q15_t)0x3ffd, (q15_t)0x4153, (q15_t)0x3ffc, + (q15_t)0x4160, (q15_t)0x3ffc, (q15_t)0x416c, (q15_t)0x3ffc, (q15_t)0x4179, (q15_t)0x3ffc, (q15_t)0x4186, (q15_t)0x3ffb, + (q15_t)0x4192, (q15_t)0x3ffb, (q15_t)0x419f, (q15_t)0x3ffb, (q15_t)0x41ab, (q15_t)0x3ffa, (q15_t)0x41b8, (q15_t)0x3ffa, + (q15_t)0x41c4, (q15_t)0x3ffa, (q15_t)0x41d1, (q15_t)0x3ff9, (q15_t)0x41dd, (q15_t)0x3ff9, (q15_t)0x41ea, (q15_t)0x3ff9, + (q15_t)0x41f7, (q15_t)0x3ff8, (q15_t)0x4203, (q15_t)0x3ff8, (q15_t)0x4210, (q15_t)0x3ff7, (q15_t)0x421c, (q15_t)0x3ff7, + (q15_t)0x4229, (q15_t)0x3ff7, (q15_t)0x4235, (q15_t)0x3ff6, (q15_t)0x4242, (q15_t)0x3ff6, (q15_t)0x424e, (q15_t)0x3ff5, + (q15_t)0x425b, (q15_t)0x3ff5, (q15_t)0x4268, (q15_t)0x3ff4, (q15_t)0x4274, (q15_t)0x3ff4, (q15_t)0x4281, (q15_t)0x3ff3, + (q15_t)0x428d, (q15_t)0x3ff3, (q15_t)0x429a, (q15_t)0x3ff2, (q15_t)0x42a6, (q15_t)0x3ff2, (q15_t)0x42b3, (q15_t)0x3ff1, + (q15_t)0x42c0, (q15_t)0x3ff1, (q15_t)0x42cc, (q15_t)0x3ff0, (q15_t)0x42d9, (q15_t)0x3ff0, (q15_t)0x42e5, (q15_t)0x3fef, + (q15_t)0x42f2, (q15_t)0x3fef, (q15_t)0x42fe, (q15_t)0x3fee, (q15_t)0x430b, (q15_t)0x3fed, (q15_t)0x4317, (q15_t)0x3fed, + (q15_t)0x4324, (q15_t)0x3fec, (q15_t)0x4330, (q15_t)0x3fec, (q15_t)0x433d, (q15_t)0x3feb, (q15_t)0x434a, (q15_t)0x3fea, + (q15_t)0x4356, (q15_t)0x3fea, (q15_t)0x4363, (q15_t)0x3fe9, (q15_t)0x436f, (q15_t)0x3fe8, (q15_t)0x437c, (q15_t)0x3fe8, + (q15_t)0x4388, (q15_t)0x3fe7, (q15_t)0x4395, (q15_t)0x3fe6, (q15_t)0x43a1, (q15_t)0x3fe6, (q15_t)0x43ae, (q15_t)0x3fe5, + (q15_t)0x43bb, (q15_t)0x3fe4, (q15_t)0x43c7, (q15_t)0x3fe3, (q15_t)0x43d4, (q15_t)0x3fe3, (q15_t)0x43e0, (q15_t)0x3fe2, + (q15_t)0x43ed, (q15_t)0x3fe1, (q15_t)0x43f9, (q15_t)0x3fe0, (q15_t)0x4406, (q15_t)0x3fe0, (q15_t)0x4412, (q15_t)0x3fdf, + (q15_t)0x441f, (q15_t)0x3fde, (q15_t)0x442b, (q15_t)0x3fdd, (q15_t)0x4438, (q15_t)0x3fdc, (q15_t)0x4444, (q15_t)0x3fdc, + (q15_t)0x4451, (q15_t)0x3fdb, (q15_t)0x445e, (q15_t)0x3fda, (q15_t)0x446a, (q15_t)0x3fd9, (q15_t)0x4477, (q15_t)0x3fd8, + (q15_t)0x4483, (q15_t)0x3fd7, (q15_t)0x4490, (q15_t)0x3fd6, (q15_t)0x449c, (q15_t)0x3fd5, (q15_t)0x44a9, (q15_t)0x3fd5, + (q15_t)0x44b5, (q15_t)0x3fd4, (q15_t)0x44c2, (q15_t)0x3fd3, (q15_t)0x44ce, (q15_t)0x3fd2, (q15_t)0x44db, (q15_t)0x3fd1, + (q15_t)0x44e7, (q15_t)0x3fd0, (q15_t)0x44f4, (q15_t)0x3fcf, (q15_t)0x4500, (q15_t)0x3fce, (q15_t)0x450d, (q15_t)0x3fcd, + (q15_t)0x451a, (q15_t)0x3fcc, (q15_t)0x4526, (q15_t)0x3fcb, (q15_t)0x4533, (q15_t)0x3fca, (q15_t)0x453f, (q15_t)0x3fc9, + (q15_t)0x454c, (q15_t)0x3fc8, (q15_t)0x4558, (q15_t)0x3fc7, (q15_t)0x4565, (q15_t)0x3fc6, (q15_t)0x4571, (q15_t)0x3fc5, + (q15_t)0x457e, (q15_t)0x3fc4, (q15_t)0x458a, (q15_t)0x3fc3, (q15_t)0x4597, (q15_t)0x3fc1, (q15_t)0x45a3, (q15_t)0x3fc0, + (q15_t)0x45b0, (q15_t)0x3fbf, (q15_t)0x45bc, (q15_t)0x3fbe, (q15_t)0x45c9, (q15_t)0x3fbd, (q15_t)0x45d5, (q15_t)0x3fbc, + (q15_t)0x45e2, (q15_t)0x3fbb, (q15_t)0x45ee, (q15_t)0x3fb9, (q15_t)0x45fb, (q15_t)0x3fb8, (q15_t)0x4607, (q15_t)0x3fb7, + (q15_t)0x4614, (q15_t)0x3fb6, (q15_t)0x4620, (q15_t)0x3fb5, (q15_t)0x462d, (q15_t)0x3fb4, (q15_t)0x4639, (q15_t)0x3fb2, + (q15_t)0x4646, (q15_t)0x3fb1, (q15_t)0x4652, (q15_t)0x3fb0, (q15_t)0x465f, (q15_t)0x3faf, (q15_t)0x466b, (q15_t)0x3fad, + (q15_t)0x4678, (q15_t)0x3fac, (q15_t)0x4684, (q15_t)0x3fab, (q15_t)0x4691, (q15_t)0x3faa, (q15_t)0x469d, (q15_t)0x3fa8, + (q15_t)0x46aa, (q15_t)0x3fa7, (q15_t)0x46b6, (q15_t)0x3fa6, (q15_t)0x46c3, (q15_t)0x3fa4, (q15_t)0x46cf, (q15_t)0x3fa3, + (q15_t)0x46dc, (q15_t)0x3fa2, (q15_t)0x46e8, (q15_t)0x3fa0, (q15_t)0x46f5, (q15_t)0x3f9f, (q15_t)0x4701, (q15_t)0x3f9e, + (q15_t)0x470e, (q15_t)0x3f9c, (q15_t)0x471a, (q15_t)0x3f9b, (q15_t)0x4727, (q15_t)0x3f99, (q15_t)0x4733, (q15_t)0x3f98, + (q15_t)0x4740, (q15_t)0x3f97, (q15_t)0x474c, (q15_t)0x3f95, (q15_t)0x4759, (q15_t)0x3f94, (q15_t)0x4765, (q15_t)0x3f92, + (q15_t)0x4772, (q15_t)0x3f91, (q15_t)0x477e, (q15_t)0x3f8f, (q15_t)0x478b, (q15_t)0x3f8e, (q15_t)0x4797, (q15_t)0x3f8c, + (q15_t)0x47a4, (q15_t)0x3f8b, (q15_t)0x47b0, (q15_t)0x3f89, (q15_t)0x47bd, (q15_t)0x3f88, (q15_t)0x47c9, (q15_t)0x3f86, + (q15_t)0x47d6, (q15_t)0x3f85, (q15_t)0x47e2, (q15_t)0x3f83, (q15_t)0x47ef, (q15_t)0x3f82, (q15_t)0x47fb, (q15_t)0x3f80, + (q15_t)0x4807, (q15_t)0x3f7f, (q15_t)0x4814, (q15_t)0x3f7d, (q15_t)0x4820, (q15_t)0x3f7b, (q15_t)0x482d, (q15_t)0x3f7a, + (q15_t)0x4839, (q15_t)0x3f78, (q15_t)0x4846, (q15_t)0x3f77, (q15_t)0x4852, (q15_t)0x3f75, (q15_t)0x485f, (q15_t)0x3f73, + (q15_t)0x486b, (q15_t)0x3f72, (q15_t)0x4878, (q15_t)0x3f70, (q15_t)0x4884, (q15_t)0x3f6e, (q15_t)0x4891, (q15_t)0x3f6d, + (q15_t)0x489d, (q15_t)0x3f6b, (q15_t)0x48a9, (q15_t)0x3f69, (q15_t)0x48b6, (q15_t)0x3f68, (q15_t)0x48c2, (q15_t)0x3f66, + (q15_t)0x48cf, (q15_t)0x3f64, (q15_t)0x48db, (q15_t)0x3f62, (q15_t)0x48e8, (q15_t)0x3f61, (q15_t)0x48f4, (q15_t)0x3f5f, + (q15_t)0x4901, (q15_t)0x3f5d, (q15_t)0x490d, (q15_t)0x3f5b, (q15_t)0x4919, (q15_t)0x3f5a, (q15_t)0x4926, (q15_t)0x3f58, + (q15_t)0x4932, (q15_t)0x3f56, (q15_t)0x493f, (q15_t)0x3f54, (q15_t)0x494b, (q15_t)0x3f52, (q15_t)0x4958, (q15_t)0x3f51, + (q15_t)0x4964, (q15_t)0x3f4f, (q15_t)0x4970, (q15_t)0x3f4d, (q15_t)0x497d, (q15_t)0x3f4b, (q15_t)0x4989, (q15_t)0x3f49, + (q15_t)0x4996, (q15_t)0x3f47, (q15_t)0x49a2, (q15_t)0x3f45, (q15_t)0x49af, (q15_t)0x3f43, (q15_t)0x49bb, (q15_t)0x3f42, + (q15_t)0x49c7, (q15_t)0x3f40, (q15_t)0x49d4, (q15_t)0x3f3e, (q15_t)0x49e0, (q15_t)0x3f3c, (q15_t)0x49ed, (q15_t)0x3f3a, + (q15_t)0x49f9, (q15_t)0x3f38, (q15_t)0x4a06, (q15_t)0x3f36, (q15_t)0x4a12, (q15_t)0x3f34, (q15_t)0x4a1e, (q15_t)0x3f32, + (q15_t)0x4a2b, (q15_t)0x3f30, (q15_t)0x4a37, (q15_t)0x3f2e, (q15_t)0x4a44, (q15_t)0x3f2c, (q15_t)0x4a50, (q15_t)0x3f2a, + (q15_t)0x4a5c, (q15_t)0x3f28, (q15_t)0x4a69, (q15_t)0x3f26, (q15_t)0x4a75, (q15_t)0x3f24, (q15_t)0x4a82, (q15_t)0x3f22, + (q15_t)0x4a8e, (q15_t)0x3f20, (q15_t)0x4a9a, (q15_t)0x3f1e, (q15_t)0x4aa7, (q15_t)0x3f1c, (q15_t)0x4ab3, (q15_t)0x3f19, + (q15_t)0x4ac0, (q15_t)0x3f17, (q15_t)0x4acc, (q15_t)0x3f15, (q15_t)0x4ad8, (q15_t)0x3f13, (q15_t)0x4ae5, (q15_t)0x3f11, + (q15_t)0x4af1, (q15_t)0x3f0f, (q15_t)0x4afd, (q15_t)0x3f0d, (q15_t)0x4b0a, (q15_t)0x3f0a, (q15_t)0x4b16, (q15_t)0x3f08, + (q15_t)0x4b23, (q15_t)0x3f06, (q15_t)0x4b2f, (q15_t)0x3f04, (q15_t)0x4b3b, (q15_t)0x3f02, (q15_t)0x4b48, (q15_t)0x3f00, + (q15_t)0x4b54, (q15_t)0x3efd, (q15_t)0x4b60, (q15_t)0x3efb, (q15_t)0x4b6d, (q15_t)0x3ef9, (q15_t)0x4b79, (q15_t)0x3ef7, + (q15_t)0x4b85, (q15_t)0x3ef4, (q15_t)0x4b92, (q15_t)0x3ef2, (q15_t)0x4b9e, (q15_t)0x3ef0, (q15_t)0x4bab, (q15_t)0x3eed, + (q15_t)0x4bb7, (q15_t)0x3eeb, (q15_t)0x4bc3, (q15_t)0x3ee9, (q15_t)0x4bd0, (q15_t)0x3ee7, (q15_t)0x4bdc, (q15_t)0x3ee4, + (q15_t)0x4be8, (q15_t)0x3ee2, (q15_t)0x4bf5, (q15_t)0x3ee0, (q15_t)0x4c01, (q15_t)0x3edd, (q15_t)0x4c0d, (q15_t)0x3edb, + (q15_t)0x4c1a, (q15_t)0x3ed8, (q15_t)0x4c26, (q15_t)0x3ed6, (q15_t)0x4c32, (q15_t)0x3ed4, (q15_t)0x4c3f, (q15_t)0x3ed1, + (q15_t)0x4c4b, (q15_t)0x3ecf, (q15_t)0x4c57, (q15_t)0x3ecc, (q15_t)0x4c64, (q15_t)0x3eca, (q15_t)0x4c70, (q15_t)0x3ec8, + (q15_t)0x4c7c, (q15_t)0x3ec5, (q15_t)0x4c89, (q15_t)0x3ec3, (q15_t)0x4c95, (q15_t)0x3ec0, (q15_t)0x4ca1, (q15_t)0x3ebe, + (q15_t)0x4cae, (q15_t)0x3ebb, (q15_t)0x4cba, (q15_t)0x3eb9, (q15_t)0x4cc6, (q15_t)0x3eb6, (q15_t)0x4cd3, (q15_t)0x3eb4, + (q15_t)0x4cdf, (q15_t)0x3eb1, (q15_t)0x4ceb, (q15_t)0x3eaf, (q15_t)0x4cf8, (q15_t)0x3eac, (q15_t)0x4d04, (q15_t)0x3eaa, + (q15_t)0x4d10, (q15_t)0x3ea7, (q15_t)0x4d1c, (q15_t)0x3ea5, (q15_t)0x4d29, (q15_t)0x3ea2, (q15_t)0x4d35, (q15_t)0x3e9f, + (q15_t)0x4d41, (q15_t)0x3e9d, (q15_t)0x4d4e, (q15_t)0x3e9a, (q15_t)0x4d5a, (q15_t)0x3e98, (q15_t)0x4d66, (q15_t)0x3e95, + (q15_t)0x4d72, (q15_t)0x3e92, (q15_t)0x4d7f, (q15_t)0x3e90, (q15_t)0x4d8b, (q15_t)0x3e8d, (q15_t)0x4d97, (q15_t)0x3e8a, + (q15_t)0x4da4, (q15_t)0x3e88, (q15_t)0x4db0, (q15_t)0x3e85, (q15_t)0x4dbc, (q15_t)0x3e82, (q15_t)0x4dc8, (q15_t)0x3e80, + (q15_t)0x4dd5, (q15_t)0x3e7d, (q15_t)0x4de1, (q15_t)0x3e7a, (q15_t)0x4ded, (q15_t)0x3e77, (q15_t)0x4df9, (q15_t)0x3e75, + (q15_t)0x4e06, (q15_t)0x3e72, (q15_t)0x4e12, (q15_t)0x3e6f, (q15_t)0x4e1e, (q15_t)0x3e6c, (q15_t)0x4e2b, (q15_t)0x3e6a, + (q15_t)0x4e37, (q15_t)0x3e67, (q15_t)0x4e43, (q15_t)0x3e64, (q15_t)0x4e4f, (q15_t)0x3e61, (q15_t)0x4e5c, (q15_t)0x3e5e, + (q15_t)0x4e68, (q15_t)0x3e5c, (q15_t)0x4e74, (q15_t)0x3e59, (q15_t)0x4e80, (q15_t)0x3e56, (q15_t)0x4e8c, (q15_t)0x3e53, + (q15_t)0x4e99, (q15_t)0x3e50, (q15_t)0x4ea5, (q15_t)0x3e4d, (q15_t)0x4eb1, (q15_t)0x3e4a, (q15_t)0x4ebd, (q15_t)0x3e48, + (q15_t)0x4eca, (q15_t)0x3e45, (q15_t)0x4ed6, (q15_t)0x3e42, (q15_t)0x4ee2, (q15_t)0x3e3f, (q15_t)0x4eee, (q15_t)0x3e3c, + (q15_t)0x4efb, (q15_t)0x3e39, (q15_t)0x4f07, (q15_t)0x3e36, (q15_t)0x4f13, (q15_t)0x3e33, (q15_t)0x4f1f, (q15_t)0x3e30, + (q15_t)0x4f2b, (q15_t)0x3e2d, (q15_t)0x4f38, (q15_t)0x3e2a, (q15_t)0x4f44, (q15_t)0x3e27, (q15_t)0x4f50, (q15_t)0x3e24, + (q15_t)0x4f5c, (q15_t)0x3e21, (q15_t)0x4f68, (q15_t)0x3e1e, (q15_t)0x4f75, (q15_t)0x3e1b, (q15_t)0x4f81, (q15_t)0x3e18, + (q15_t)0x4f8d, (q15_t)0x3e15, (q15_t)0x4f99, (q15_t)0x3e12, (q15_t)0x4fa5, (q15_t)0x3e0f, (q15_t)0x4fb2, (q15_t)0x3e0c, + (q15_t)0x4fbe, (q15_t)0x3e09, (q15_t)0x4fca, (q15_t)0x3e06, (q15_t)0x4fd6, (q15_t)0x3e03, (q15_t)0x4fe2, (q15_t)0x3dff, + (q15_t)0x4fee, (q15_t)0x3dfc, (q15_t)0x4ffb, (q15_t)0x3df9, (q15_t)0x5007, (q15_t)0x3df6, (q15_t)0x5013, (q15_t)0x3df3, + (q15_t)0x501f, (q15_t)0x3df0, (q15_t)0x502b, (q15_t)0x3ded, (q15_t)0x5037, (q15_t)0x3de9, (q15_t)0x5044, (q15_t)0x3de6, + (q15_t)0x5050, (q15_t)0x3de3, (q15_t)0x505c, (q15_t)0x3de0, (q15_t)0x5068, (q15_t)0x3ddd, (q15_t)0x5074, (q15_t)0x3dd9, + (q15_t)0x5080, (q15_t)0x3dd6, (q15_t)0x508c, (q15_t)0x3dd3, (q15_t)0x5099, (q15_t)0x3dd0, (q15_t)0x50a5, (q15_t)0x3dcc, + (q15_t)0x50b1, (q15_t)0x3dc9, (q15_t)0x50bd, (q15_t)0x3dc6, (q15_t)0x50c9, (q15_t)0x3dc2, (q15_t)0x50d5, (q15_t)0x3dbf, + (q15_t)0x50e1, (q15_t)0x3dbc, (q15_t)0x50ed, (q15_t)0x3db9, (q15_t)0x50fa, (q15_t)0x3db5, (q15_t)0x5106, (q15_t)0x3db2, + (q15_t)0x5112, (q15_t)0x3daf, (q15_t)0x511e, (q15_t)0x3dab, (q15_t)0x512a, (q15_t)0x3da8, (q15_t)0x5136, (q15_t)0x3da4, + (q15_t)0x5142, (q15_t)0x3da1, (q15_t)0x514e, (q15_t)0x3d9e, (q15_t)0x515a, (q15_t)0x3d9a, (q15_t)0x5167, (q15_t)0x3d97, + (q15_t)0x5173, (q15_t)0x3d93, (q15_t)0x517f, (q15_t)0x3d90, (q15_t)0x518b, (q15_t)0x3d8d, (q15_t)0x5197, (q15_t)0x3d89, + (q15_t)0x51a3, (q15_t)0x3d86, (q15_t)0x51af, (q15_t)0x3d82, (q15_t)0x51bb, (q15_t)0x3d7f, (q15_t)0x51c7, (q15_t)0x3d7b, + (q15_t)0x51d3, (q15_t)0x3d78, (q15_t)0x51df, (q15_t)0x3d74, (q15_t)0x51eb, (q15_t)0x3d71, (q15_t)0x51f7, (q15_t)0x3d6d, + (q15_t)0x5204, (q15_t)0x3d6a, (q15_t)0x5210, (q15_t)0x3d66, (q15_t)0x521c, (q15_t)0x3d63, (q15_t)0x5228, (q15_t)0x3d5f, + (q15_t)0x5234, (q15_t)0x3d5b, (q15_t)0x5240, (q15_t)0x3d58, (q15_t)0x524c, (q15_t)0x3d54, (q15_t)0x5258, (q15_t)0x3d51, + (q15_t)0x5264, (q15_t)0x3d4d, (q15_t)0x5270, (q15_t)0x3d49, (q15_t)0x527c, (q15_t)0x3d46, (q15_t)0x5288, (q15_t)0x3d42, + (q15_t)0x5294, (q15_t)0x3d3f, (q15_t)0x52a0, (q15_t)0x3d3b, (q15_t)0x52ac, (q15_t)0x3d37, (q15_t)0x52b8, (q15_t)0x3d34, + (q15_t)0x52c4, (q15_t)0x3d30, (q15_t)0x52d0, (q15_t)0x3d2c, (q15_t)0x52dc, (q15_t)0x3d28, (q15_t)0x52e8, (q15_t)0x3d25, + (q15_t)0x52f4, (q15_t)0x3d21, (q15_t)0x5300, (q15_t)0x3d1d, (q15_t)0x530c, (q15_t)0x3d1a, (q15_t)0x5318, (q15_t)0x3d16, + (q15_t)0x5324, (q15_t)0x3d12, (q15_t)0x5330, (q15_t)0x3d0e, (q15_t)0x533c, (q15_t)0x3d0b, (q15_t)0x5348, (q15_t)0x3d07, + (q15_t)0x5354, (q15_t)0x3d03, (q15_t)0x5360, (q15_t)0x3cff, (q15_t)0x536c, (q15_t)0x3cfb, (q15_t)0x5378, (q15_t)0x3cf8, + (q15_t)0x5384, (q15_t)0x3cf4, (q15_t)0x5390, (q15_t)0x3cf0, (q15_t)0x539c, (q15_t)0x3cec, (q15_t)0x53a8, (q15_t)0x3ce8, + (q15_t)0x53b4, (q15_t)0x3ce4, (q15_t)0x53c0, (q15_t)0x3ce0, (q15_t)0x53cc, (q15_t)0x3cdd, (q15_t)0x53d8, (q15_t)0x3cd9, + (q15_t)0x53e4, (q15_t)0x3cd5, (q15_t)0x53f0, (q15_t)0x3cd1, (q15_t)0x53fb, (q15_t)0x3ccd, (q15_t)0x5407, (q15_t)0x3cc9, + (q15_t)0x5413, (q15_t)0x3cc5, (q15_t)0x541f, (q15_t)0x3cc1, (q15_t)0x542b, (q15_t)0x3cbd, (q15_t)0x5437, (q15_t)0x3cb9, + (q15_t)0x5443, (q15_t)0x3cb5, (q15_t)0x544f, (q15_t)0x3cb1, (q15_t)0x545b, (q15_t)0x3cad, (q15_t)0x5467, (q15_t)0x3ca9, + (q15_t)0x5473, (q15_t)0x3ca5, (q15_t)0x547f, (q15_t)0x3ca1, (q15_t)0x548b, (q15_t)0x3c9d, (q15_t)0x5496, (q15_t)0x3c99, + (q15_t)0x54a2, (q15_t)0x3c95, (q15_t)0x54ae, (q15_t)0x3c91, (q15_t)0x54ba, (q15_t)0x3c8d, (q15_t)0x54c6, (q15_t)0x3c89, + (q15_t)0x54d2, (q15_t)0x3c85, (q15_t)0x54de, (q15_t)0x3c81, (q15_t)0x54ea, (q15_t)0x3c7d, (q15_t)0x54f6, (q15_t)0x3c79, + (q15_t)0x5501, (q15_t)0x3c74, (q15_t)0x550d, (q15_t)0x3c70, (q15_t)0x5519, (q15_t)0x3c6c, (q15_t)0x5525, (q15_t)0x3c68, + (q15_t)0x5531, (q15_t)0x3c64, (q15_t)0x553d, (q15_t)0x3c60, (q15_t)0x5549, (q15_t)0x3c5b, (q15_t)0x5554, (q15_t)0x3c57, + (q15_t)0x5560, (q15_t)0x3c53, (q15_t)0x556c, (q15_t)0x3c4f, (q15_t)0x5578, (q15_t)0x3c4b, (q15_t)0x5584, (q15_t)0x3c46, + (q15_t)0x5590, (q15_t)0x3c42, (q15_t)0x559b, (q15_t)0x3c3e, (q15_t)0x55a7, (q15_t)0x3c3a, (q15_t)0x55b3, (q15_t)0x3c36, + (q15_t)0x55bf, (q15_t)0x3c31, (q15_t)0x55cb, (q15_t)0x3c2d, (q15_t)0x55d7, (q15_t)0x3c29, (q15_t)0x55e2, (q15_t)0x3c24, + (q15_t)0x55ee, (q15_t)0x3c20, (q15_t)0x55fa, (q15_t)0x3c1c, (q15_t)0x5606, (q15_t)0x3c17, (q15_t)0x5612, (q15_t)0x3c13, + (q15_t)0x561d, (q15_t)0x3c0f, (q15_t)0x5629, (q15_t)0x3c0a, (q15_t)0x5635, (q15_t)0x3c06, (q15_t)0x5641, (q15_t)0x3c02, + (q15_t)0x564c, (q15_t)0x3bfd, (q15_t)0x5658, (q15_t)0x3bf9, (q15_t)0x5664, (q15_t)0x3bf5, (q15_t)0x5670, (q15_t)0x3bf0, + (q15_t)0x567c, (q15_t)0x3bec, (q15_t)0x5687, (q15_t)0x3be7, (q15_t)0x5693, (q15_t)0x3be3, (q15_t)0x569f, (q15_t)0x3bde, + (q15_t)0x56ab, (q15_t)0x3bda, (q15_t)0x56b6, (q15_t)0x3bd6, (q15_t)0x56c2, (q15_t)0x3bd1, (q15_t)0x56ce, (q15_t)0x3bcd, + (q15_t)0x56da, (q15_t)0x3bc8, (q15_t)0x56e5, (q15_t)0x3bc4, (q15_t)0x56f1, (q15_t)0x3bbf, (q15_t)0x56fd, (q15_t)0x3bbb, + (q15_t)0x5709, (q15_t)0x3bb6, (q15_t)0x5714, (q15_t)0x3bb2, (q15_t)0x5720, (q15_t)0x3bad, (q15_t)0x572c, (q15_t)0x3ba9, + (q15_t)0x5737, (q15_t)0x3ba4, (q15_t)0x5743, (q15_t)0x3b9f, (q15_t)0x574f, (q15_t)0x3b9b, (q15_t)0x575b, (q15_t)0x3b96, + (q15_t)0x5766, (q15_t)0x3b92, (q15_t)0x5772, (q15_t)0x3b8d, (q15_t)0x577e, (q15_t)0x3b88, (q15_t)0x5789, (q15_t)0x3b84, + (q15_t)0x5795, (q15_t)0x3b7f, (q15_t)0x57a1, (q15_t)0x3b7b, (q15_t)0x57ac, (q15_t)0x3b76, (q15_t)0x57b8, (q15_t)0x3b71, + (q15_t)0x57c4, (q15_t)0x3b6d, (q15_t)0x57cf, (q15_t)0x3b68, (q15_t)0x57db, (q15_t)0x3b63, (q15_t)0x57e7, (q15_t)0x3b5f, + (q15_t)0x57f2, (q15_t)0x3b5a, (q15_t)0x57fe, (q15_t)0x3b55, (q15_t)0x580a, (q15_t)0x3b50, (q15_t)0x5815, (q15_t)0x3b4c, + (q15_t)0x5821, (q15_t)0x3b47, (q15_t)0x582d, (q15_t)0x3b42, (q15_t)0x5838, (q15_t)0x3b3e, (q15_t)0x5844, (q15_t)0x3b39, + (q15_t)0x584f, (q15_t)0x3b34, (q15_t)0x585b, (q15_t)0x3b2f, (q15_t)0x5867, (q15_t)0x3b2a, (q15_t)0x5872, (q15_t)0x3b26, + (q15_t)0x587e, (q15_t)0x3b21, (q15_t)0x5889, (q15_t)0x3b1c, (q15_t)0x5895, (q15_t)0x3b17, (q15_t)0x58a1, (q15_t)0x3b12, + (q15_t)0x58ac, (q15_t)0x3b0e, (q15_t)0x58b8, (q15_t)0x3b09, (q15_t)0x58c3, (q15_t)0x3b04, (q15_t)0x58cf, (q15_t)0x3aff, + (q15_t)0x58db, (q15_t)0x3afa, (q15_t)0x58e6, (q15_t)0x3af5, (q15_t)0x58f2, (q15_t)0x3af0, (q15_t)0x58fd, (q15_t)0x3aeb, + (q15_t)0x5909, (q15_t)0x3ae6, (q15_t)0x5914, (q15_t)0x3ae2, (q15_t)0x5920, (q15_t)0x3add, (q15_t)0x592c, (q15_t)0x3ad8, + (q15_t)0x5937, (q15_t)0x3ad3, (q15_t)0x5943, (q15_t)0x3ace, (q15_t)0x594e, (q15_t)0x3ac9, (q15_t)0x595a, (q15_t)0x3ac4, + (q15_t)0x5965, (q15_t)0x3abf, (q15_t)0x5971, (q15_t)0x3aba, (q15_t)0x597c, (q15_t)0x3ab5, (q15_t)0x5988, (q15_t)0x3ab0, + (q15_t)0x5993, (q15_t)0x3aab, (q15_t)0x599f, (q15_t)0x3aa6, (q15_t)0x59aa, (q15_t)0x3aa1, (q15_t)0x59b6, (q15_t)0x3a9c, + (q15_t)0x59c1, (q15_t)0x3a97, (q15_t)0x59cd, (q15_t)0x3a92, (q15_t)0x59d8, (q15_t)0x3a8d, (q15_t)0x59e4, (q15_t)0x3a88, + (q15_t)0x59ef, (q15_t)0x3a82, (q15_t)0x59fb, (q15_t)0x3a7d, (q15_t)0x5a06, (q15_t)0x3a78, (q15_t)0x5a12, (q15_t)0x3a73, + (q15_t)0x5a1d, (q15_t)0x3a6e, (q15_t)0x5a29, (q15_t)0x3a69, (q15_t)0x5a34, (q15_t)0x3a64, (q15_t)0x5a40, (q15_t)0x3a5f, + (q15_t)0x5a4b, (q15_t)0x3a59, (q15_t)0x5a57, (q15_t)0x3a54, (q15_t)0x5a62, (q15_t)0x3a4f, (q15_t)0x5a6e, (q15_t)0x3a4a, + (q15_t)0x5a79, (q15_t)0x3a45, (q15_t)0x5a84, (q15_t)0x3a3f, (q15_t)0x5a90, (q15_t)0x3a3a, (q15_t)0x5a9b, (q15_t)0x3a35, + (q15_t)0x5aa7, (q15_t)0x3a30, (q15_t)0x5ab2, (q15_t)0x3a2b, (q15_t)0x5abe, (q15_t)0x3a25, (q15_t)0x5ac9, (q15_t)0x3a20, + (q15_t)0x5ad4, (q15_t)0x3a1b, (q15_t)0x5ae0, (q15_t)0x3a16, (q15_t)0x5aeb, (q15_t)0x3a10, (q15_t)0x5af7, (q15_t)0x3a0b, + (q15_t)0x5b02, (q15_t)0x3a06, (q15_t)0x5b0d, (q15_t)0x3a00, (q15_t)0x5b19, (q15_t)0x39fb, (q15_t)0x5b24, (q15_t)0x39f6, + (q15_t)0x5b30, (q15_t)0x39f0, (q15_t)0x5b3b, (q15_t)0x39eb, (q15_t)0x5b46, (q15_t)0x39e6, (q15_t)0x5b52, (q15_t)0x39e0, + (q15_t)0x5b5d, (q15_t)0x39db, (q15_t)0x5b68, (q15_t)0x39d6, (q15_t)0x5b74, (q15_t)0x39d0, (q15_t)0x5b7f, (q15_t)0x39cb, + (q15_t)0x5b8a, (q15_t)0x39c5, (q15_t)0x5b96, (q15_t)0x39c0, (q15_t)0x5ba1, (q15_t)0x39bb, (q15_t)0x5bac, (q15_t)0x39b5, + (q15_t)0x5bb8, (q15_t)0x39b0, (q15_t)0x5bc3, (q15_t)0x39aa, (q15_t)0x5bce, (q15_t)0x39a5, (q15_t)0x5bda, (q15_t)0x399f, + (q15_t)0x5be5, (q15_t)0x399a, (q15_t)0x5bf0, (q15_t)0x3994, (q15_t)0x5bfc, (q15_t)0x398f, (q15_t)0x5c07, (q15_t)0x3989, + (q15_t)0x5c12, (q15_t)0x3984, (q15_t)0x5c1e, (q15_t)0x397e, (q15_t)0x5c29, (q15_t)0x3979, (q15_t)0x5c34, (q15_t)0x3973, + (q15_t)0x5c3f, (q15_t)0x396e, (q15_t)0x5c4b, (q15_t)0x3968, (q15_t)0x5c56, (q15_t)0x3963, (q15_t)0x5c61, (q15_t)0x395d, + (q15_t)0x5c6c, (q15_t)0x3958, (q15_t)0x5c78, (q15_t)0x3952, (q15_t)0x5c83, (q15_t)0x394c, (q15_t)0x5c8e, (q15_t)0x3947, + (q15_t)0x5c99, (q15_t)0x3941, (q15_t)0x5ca5, (q15_t)0x393b, (q15_t)0x5cb0, (q15_t)0x3936, (q15_t)0x5cbb, (q15_t)0x3930, + (q15_t)0x5cc6, (q15_t)0x392b, (q15_t)0x5cd2, (q15_t)0x3925, (q15_t)0x5cdd, (q15_t)0x391f, (q15_t)0x5ce8, (q15_t)0x391a, + (q15_t)0x5cf3, (q15_t)0x3914, (q15_t)0x5cff, (q15_t)0x390e, (q15_t)0x5d0a, (q15_t)0x3909, (q15_t)0x5d15, (q15_t)0x3903, + (q15_t)0x5d20, (q15_t)0x38fd, (q15_t)0x5d2b, (q15_t)0x38f7, (q15_t)0x5d36, (q15_t)0x38f2, (q15_t)0x5d42, (q15_t)0x38ec, + (q15_t)0x5d4d, (q15_t)0x38e6, (q15_t)0x5d58, (q15_t)0x38e0, (q15_t)0x5d63, (q15_t)0x38db, (q15_t)0x5d6e, (q15_t)0x38d5, + (q15_t)0x5d79, (q15_t)0x38cf, (q15_t)0x5d85, (q15_t)0x38c9, (q15_t)0x5d90, (q15_t)0x38c3, (q15_t)0x5d9b, (q15_t)0x38be, + (q15_t)0x5da6, (q15_t)0x38b8, (q15_t)0x5db1, (q15_t)0x38b2, (q15_t)0x5dbc, (q15_t)0x38ac, (q15_t)0x5dc7, (q15_t)0x38a6, + (q15_t)0x5dd3, (q15_t)0x38a1, (q15_t)0x5dde, (q15_t)0x389b, (q15_t)0x5de9, (q15_t)0x3895, (q15_t)0x5df4, (q15_t)0x388f, + (q15_t)0x5dff, (q15_t)0x3889, (q15_t)0x5e0a, (q15_t)0x3883, (q15_t)0x5e15, (q15_t)0x387d, (q15_t)0x5e20, (q15_t)0x3877, + (q15_t)0x5e2b, (q15_t)0x3871, (q15_t)0x5e36, (q15_t)0x386b, (q15_t)0x5e42, (q15_t)0x3866, (q15_t)0x5e4d, (q15_t)0x3860, + (q15_t)0x5e58, (q15_t)0x385a, (q15_t)0x5e63, (q15_t)0x3854, (q15_t)0x5e6e, (q15_t)0x384e, (q15_t)0x5e79, (q15_t)0x3848, + (q15_t)0x5e84, (q15_t)0x3842, (q15_t)0x5e8f, (q15_t)0x383c, (q15_t)0x5e9a, (q15_t)0x3836, (q15_t)0x5ea5, (q15_t)0x3830, + (q15_t)0x5eb0, (q15_t)0x382a, (q15_t)0x5ebb, (q15_t)0x3824, (q15_t)0x5ec6, (q15_t)0x381e, (q15_t)0x5ed1, (q15_t)0x3818, + (q15_t)0x5edc, (q15_t)0x3812, (q15_t)0x5ee7, (q15_t)0x380b, (q15_t)0x5ef2, (q15_t)0x3805, (q15_t)0x5efd, (q15_t)0x37ff, + (q15_t)0x5f08, (q15_t)0x37f9, (q15_t)0x5f13, (q15_t)0x37f3, (q15_t)0x5f1e, (q15_t)0x37ed, (q15_t)0x5f29, (q15_t)0x37e7, + (q15_t)0x5f34, (q15_t)0x37e1, (q15_t)0x5f3f, (q15_t)0x37db, (q15_t)0x5f4a, (q15_t)0x37d5, (q15_t)0x5f55, (q15_t)0x37ce, + (q15_t)0x5f60, (q15_t)0x37c8, (q15_t)0x5f6b, (q15_t)0x37c2, (q15_t)0x5f76, (q15_t)0x37bc, (q15_t)0x5f81, (q15_t)0x37b6, + (q15_t)0x5f8c, (q15_t)0x37b0, (q15_t)0x5f97, (q15_t)0x37a9, (q15_t)0x5fa2, (q15_t)0x37a3, (q15_t)0x5fac, (q15_t)0x379d, + (q15_t)0x5fb7, (q15_t)0x3797, (q15_t)0x5fc2, (q15_t)0x3790, (q15_t)0x5fcd, (q15_t)0x378a, (q15_t)0x5fd8, (q15_t)0x3784, + (q15_t)0x5fe3, (q15_t)0x377e, (q15_t)0x5fee, (q15_t)0x3777, (q15_t)0x5ff9, (q15_t)0x3771, (q15_t)0x6004, (q15_t)0x376b, + (q15_t)0x600f, (q15_t)0x3765, (q15_t)0x6019, (q15_t)0x375e, (q15_t)0x6024, (q15_t)0x3758, (q15_t)0x602f, (q15_t)0x3752, + (q15_t)0x603a, (q15_t)0x374b, (q15_t)0x6045, (q15_t)0x3745, (q15_t)0x6050, (q15_t)0x373f, (q15_t)0x605b, (q15_t)0x3738, + (q15_t)0x6065, (q15_t)0x3732, (q15_t)0x6070, (q15_t)0x372c, (q15_t)0x607b, (q15_t)0x3725, (q15_t)0x6086, (q15_t)0x371f, + (q15_t)0x6091, (q15_t)0x3718, (q15_t)0x609b, (q15_t)0x3712, (q15_t)0x60a6, (q15_t)0x370c, (q15_t)0x60b1, (q15_t)0x3705, + (q15_t)0x60bc, (q15_t)0x36ff, (q15_t)0x60c7, (q15_t)0x36f8, (q15_t)0x60d1, (q15_t)0x36f2, (q15_t)0x60dc, (q15_t)0x36eb, + (q15_t)0x60e7, (q15_t)0x36e5, (q15_t)0x60f2, (q15_t)0x36df, (q15_t)0x60fd, (q15_t)0x36d8, (q15_t)0x6107, (q15_t)0x36d2, + (q15_t)0x6112, (q15_t)0x36cb, (q15_t)0x611d, (q15_t)0x36c5, (q15_t)0x6128, (q15_t)0x36be, (q15_t)0x6132, (q15_t)0x36b8, + (q15_t)0x613d, (q15_t)0x36b1, (q15_t)0x6148, (q15_t)0x36ab, (q15_t)0x6153, (q15_t)0x36a4, (q15_t)0x615d, (q15_t)0x369d, + (q15_t)0x6168, (q15_t)0x3697, (q15_t)0x6173, (q15_t)0x3690, (q15_t)0x617d, (q15_t)0x368a, (q15_t)0x6188, (q15_t)0x3683, + (q15_t)0x6193, (q15_t)0x367d, (q15_t)0x619e, (q15_t)0x3676, (q15_t)0x61a8, (q15_t)0x366f, (q15_t)0x61b3, (q15_t)0x3669, + (q15_t)0x61be, (q15_t)0x3662, (q15_t)0x61c8, (q15_t)0x365c, (q15_t)0x61d3, (q15_t)0x3655, (q15_t)0x61de, (q15_t)0x364e, + (q15_t)0x61e8, (q15_t)0x3648, (q15_t)0x61f3, (q15_t)0x3641, (q15_t)0x61fe, (q15_t)0x363a, (q15_t)0x6208, (q15_t)0x3634, + (q15_t)0x6213, (q15_t)0x362d, (q15_t)0x621e, (q15_t)0x3626, (q15_t)0x6228, (q15_t)0x3620, (q15_t)0x6233, (q15_t)0x3619, + (q15_t)0x623d, (q15_t)0x3612, (q15_t)0x6248, (q15_t)0x360b, (q15_t)0x6253, (q15_t)0x3605, (q15_t)0x625d, (q15_t)0x35fe, + (q15_t)0x6268, (q15_t)0x35f7, (q15_t)0x6272, (q15_t)0x35f0, (q15_t)0x627d, (q15_t)0x35ea, (q15_t)0x6288, (q15_t)0x35e3, + (q15_t)0x6292, (q15_t)0x35dc, (q15_t)0x629d, (q15_t)0x35d5, (q15_t)0x62a7, (q15_t)0x35ce, (q15_t)0x62b2, (q15_t)0x35c8, + (q15_t)0x62bc, (q15_t)0x35c1, (q15_t)0x62c7, (q15_t)0x35ba, (q15_t)0x62d2, (q15_t)0x35b3, (q15_t)0x62dc, (q15_t)0x35ac, + (q15_t)0x62e7, (q15_t)0x35a5, (q15_t)0x62f1, (q15_t)0x359f, (q15_t)0x62fc, (q15_t)0x3598, (q15_t)0x6306, (q15_t)0x3591, + (q15_t)0x6311, (q15_t)0x358a, (q15_t)0x631b, (q15_t)0x3583, (q15_t)0x6326, (q15_t)0x357c, (q15_t)0x6330, (q15_t)0x3575, + (q15_t)0x633b, (q15_t)0x356e, (q15_t)0x6345, (q15_t)0x3567, (q15_t)0x6350, (q15_t)0x3561, (q15_t)0x635a, (q15_t)0x355a, + (q15_t)0x6365, (q15_t)0x3553, (q15_t)0x636f, (q15_t)0x354c, (q15_t)0x637a, (q15_t)0x3545, (q15_t)0x6384, (q15_t)0x353e, + (q15_t)0x638e, (q15_t)0x3537, (q15_t)0x6399, (q15_t)0x3530, (q15_t)0x63a3, (q15_t)0x3529, (q15_t)0x63ae, (q15_t)0x3522, + (q15_t)0x63b8, (q15_t)0x351b, (q15_t)0x63c3, (q15_t)0x3514, (q15_t)0x63cd, (q15_t)0x350d, (q15_t)0x63d7, (q15_t)0x3506, + (q15_t)0x63e2, (q15_t)0x34ff, (q15_t)0x63ec, (q15_t)0x34f8, (q15_t)0x63f7, (q15_t)0x34f1, (q15_t)0x6401, (q15_t)0x34ea, + (q15_t)0x640b, (q15_t)0x34e2, (q15_t)0x6416, (q15_t)0x34db, (q15_t)0x6420, (q15_t)0x34d4, (q15_t)0x642b, (q15_t)0x34cd, + (q15_t)0x6435, (q15_t)0x34c6, (q15_t)0x643f, (q15_t)0x34bf, (q15_t)0x644a, (q15_t)0x34b8, (q15_t)0x6454, (q15_t)0x34b1, + (q15_t)0x645e, (q15_t)0x34aa, (q15_t)0x6469, (q15_t)0x34a2, (q15_t)0x6473, (q15_t)0x349b, (q15_t)0x647d, (q15_t)0x3494, + (q15_t)0x6488, (q15_t)0x348d, (q15_t)0x6492, (q15_t)0x3486, (q15_t)0x649c, (q15_t)0x347f, (q15_t)0x64a7, (q15_t)0x3477, + (q15_t)0x64b1, (q15_t)0x3470, (q15_t)0x64bb, (q15_t)0x3469, (q15_t)0x64c5, (q15_t)0x3462, (q15_t)0x64d0, (q15_t)0x345b, + (q15_t)0x64da, (q15_t)0x3453, (q15_t)0x64e4, (q15_t)0x344c, (q15_t)0x64ef, (q15_t)0x3445, (q15_t)0x64f9, (q15_t)0x343e, + (q15_t)0x6503, (q15_t)0x3436, (q15_t)0x650d, (q15_t)0x342f, (q15_t)0x6518, (q15_t)0x3428, (q15_t)0x6522, (q15_t)0x3420, + (q15_t)0x652c, (q15_t)0x3419, (q15_t)0x6536, (q15_t)0x3412, (q15_t)0x6541, (q15_t)0x340b, (q15_t)0x654b, (q15_t)0x3403, + (q15_t)0x6555, (q15_t)0x33fc, (q15_t)0x655f, (q15_t)0x33f5, (q15_t)0x6569, (q15_t)0x33ed, (q15_t)0x6574, (q15_t)0x33e6, + (q15_t)0x657e, (q15_t)0x33df, (q15_t)0x6588, (q15_t)0x33d7, (q15_t)0x6592, (q15_t)0x33d0, (q15_t)0x659c, (q15_t)0x33c8, + (q15_t)0x65a6, (q15_t)0x33c1, (q15_t)0x65b1, (q15_t)0x33ba, (q15_t)0x65bb, (q15_t)0x33b2, (q15_t)0x65c5, (q15_t)0x33ab, + (q15_t)0x65cf, (q15_t)0x33a3, (q15_t)0x65d9, (q15_t)0x339c, (q15_t)0x65e3, (q15_t)0x3395, (q15_t)0x65ed, (q15_t)0x338d, + (q15_t)0x65f8, (q15_t)0x3386, (q15_t)0x6602, (q15_t)0x337e, (q15_t)0x660c, (q15_t)0x3377, (q15_t)0x6616, (q15_t)0x336f, + (q15_t)0x6620, (q15_t)0x3368, (q15_t)0x662a, (q15_t)0x3360, (q15_t)0x6634, (q15_t)0x3359, (q15_t)0x663e, (q15_t)0x3351, + (q15_t)0x6648, (q15_t)0x334a, (q15_t)0x6652, (q15_t)0x3342, (q15_t)0x665c, (q15_t)0x333b, (q15_t)0x6666, (q15_t)0x3333, + (q15_t)0x6671, (q15_t)0x332c, (q15_t)0x667b, (q15_t)0x3324, (q15_t)0x6685, (q15_t)0x331d, (q15_t)0x668f, (q15_t)0x3315, + (q15_t)0x6699, (q15_t)0x330d, (q15_t)0x66a3, (q15_t)0x3306, (q15_t)0x66ad, (q15_t)0x32fe, (q15_t)0x66b7, (q15_t)0x32f7, + (q15_t)0x66c1, (q15_t)0x32ef, (q15_t)0x66cb, (q15_t)0x32e7, (q15_t)0x66d5, (q15_t)0x32e0, (q15_t)0x66df, (q15_t)0x32d8, + (q15_t)0x66e9, (q15_t)0x32d0, (q15_t)0x66f3, (q15_t)0x32c9, (q15_t)0x66fd, (q15_t)0x32c1, (q15_t)0x6707, (q15_t)0x32ba, + (q15_t)0x6711, (q15_t)0x32b2, (q15_t)0x671a, (q15_t)0x32aa, (q15_t)0x6724, (q15_t)0x32a3, (q15_t)0x672e, (q15_t)0x329b, + (q15_t)0x6738, (q15_t)0x3293, (q15_t)0x6742, (q15_t)0x328b, (q15_t)0x674c, (q15_t)0x3284, (q15_t)0x6756, (q15_t)0x327c, + (q15_t)0x6760, (q15_t)0x3274, (q15_t)0x676a, (q15_t)0x326d, (q15_t)0x6774, (q15_t)0x3265, (q15_t)0x677e, (q15_t)0x325d, + (q15_t)0x6788, (q15_t)0x3255, (q15_t)0x6791, (q15_t)0x324e, (q15_t)0x679b, (q15_t)0x3246, (q15_t)0x67a5, (q15_t)0x323e, + (q15_t)0x67af, (q15_t)0x3236, (q15_t)0x67b9, (q15_t)0x322e, (q15_t)0x67c3, (q15_t)0x3227, (q15_t)0x67cd, (q15_t)0x321f, + (q15_t)0x67d6, (q15_t)0x3217, (q15_t)0x67e0, (q15_t)0x320f, (q15_t)0x67ea, (q15_t)0x3207, (q15_t)0x67f4, (q15_t)0x31ff, + (q15_t)0x67fe, (q15_t)0x31f8, (q15_t)0x6808, (q15_t)0x31f0, (q15_t)0x6811, (q15_t)0x31e8, (q15_t)0x681b, (q15_t)0x31e0, + (q15_t)0x6825, (q15_t)0x31d8, (q15_t)0x682f, (q15_t)0x31d0, (q15_t)0x6838, (q15_t)0x31c8, (q15_t)0x6842, (q15_t)0x31c0, + (q15_t)0x684c, (q15_t)0x31b9, (q15_t)0x6856, (q15_t)0x31b1, (q15_t)0x6860, (q15_t)0x31a9, (q15_t)0x6869, (q15_t)0x31a1, + (q15_t)0x6873, (q15_t)0x3199, (q15_t)0x687d, (q15_t)0x3191, (q15_t)0x6886, (q15_t)0x3189, (q15_t)0x6890, (q15_t)0x3181, + (q15_t)0x689a, (q15_t)0x3179, (q15_t)0x68a4, (q15_t)0x3171, (q15_t)0x68ad, (q15_t)0x3169, (q15_t)0x68b7, (q15_t)0x3161, + (q15_t)0x68c1, (q15_t)0x3159, (q15_t)0x68ca, (q15_t)0x3151, (q15_t)0x68d4, (q15_t)0x3149, (q15_t)0x68de, (q15_t)0x3141, + (q15_t)0x68e7, (q15_t)0x3139, (q15_t)0x68f1, (q15_t)0x3131, (q15_t)0x68fb, (q15_t)0x3129, (q15_t)0x6904, (q15_t)0x3121, + (q15_t)0x690e, (q15_t)0x3119, (q15_t)0x6918, (q15_t)0x3111, (q15_t)0x6921, (q15_t)0x3109, (q15_t)0x692b, (q15_t)0x3101, + (q15_t)0x6935, (q15_t)0x30f9, (q15_t)0x693e, (q15_t)0x30f0, (q15_t)0x6948, (q15_t)0x30e8, (q15_t)0x6951, (q15_t)0x30e0, + (q15_t)0x695b, (q15_t)0x30d8, (q15_t)0x6965, (q15_t)0x30d0, (q15_t)0x696e, (q15_t)0x30c8, (q15_t)0x6978, (q15_t)0x30c0, + (q15_t)0x6981, (q15_t)0x30b8, (q15_t)0x698b, (q15_t)0x30af, (q15_t)0x6994, (q15_t)0x30a7, (q15_t)0x699e, (q15_t)0x309f, + (q15_t)0x69a7, (q15_t)0x3097, (q15_t)0x69b1, (q15_t)0x308f, (q15_t)0x69bb, (q15_t)0x3087, (q15_t)0x69c4, (q15_t)0x307e, + (q15_t)0x69ce, (q15_t)0x3076, (q15_t)0x69d7, (q15_t)0x306e, (q15_t)0x69e1, (q15_t)0x3066, (q15_t)0x69ea, (q15_t)0x305d, + (q15_t)0x69f4, (q15_t)0x3055, (q15_t)0x69fd, (q15_t)0x304d, (q15_t)0x6a07, (q15_t)0x3045, (q15_t)0x6a10, (q15_t)0x303c, + (q15_t)0x6a1a, (q15_t)0x3034, (q15_t)0x6a23, (q15_t)0x302c, (q15_t)0x6a2c, (q15_t)0x3024, (q15_t)0x6a36, (q15_t)0x301b, + (q15_t)0x6a3f, (q15_t)0x3013, (q15_t)0x6a49, (q15_t)0x300b, (q15_t)0x6a52, (q15_t)0x3002, (q15_t)0x6a5c, (q15_t)0x2ffa, + (q15_t)0x6a65, (q15_t)0x2ff2, (q15_t)0x6a6e, (q15_t)0x2fea, (q15_t)0x6a78, (q15_t)0x2fe1, (q15_t)0x6a81, (q15_t)0x2fd9, + (q15_t)0x6a8b, (q15_t)0x2fd0, (q15_t)0x6a94, (q15_t)0x2fc8, (q15_t)0x6a9d, (q15_t)0x2fc0, (q15_t)0x6aa7, (q15_t)0x2fb7, + (q15_t)0x6ab0, (q15_t)0x2faf, (q15_t)0x6ab9, (q15_t)0x2fa7, (q15_t)0x6ac3, (q15_t)0x2f9e, (q15_t)0x6acc, (q15_t)0x2f96, + (q15_t)0x6ad6, (q15_t)0x2f8d, (q15_t)0x6adf, (q15_t)0x2f85, (q15_t)0x6ae8, (q15_t)0x2f7d, (q15_t)0x6af2, (q15_t)0x2f74, + (q15_t)0x6afb, (q15_t)0x2f6c, (q15_t)0x6b04, (q15_t)0x2f63, (q15_t)0x6b0d, (q15_t)0x2f5b, (q15_t)0x6b17, (q15_t)0x2f52, + (q15_t)0x6b20, (q15_t)0x2f4a, (q15_t)0x6b29, (q15_t)0x2f41, (q15_t)0x6b33, (q15_t)0x2f39, (q15_t)0x6b3c, (q15_t)0x2f30, + (q15_t)0x6b45, (q15_t)0x2f28, (q15_t)0x6b4e, (q15_t)0x2f20, (q15_t)0x6b58, (q15_t)0x2f17, (q15_t)0x6b61, (q15_t)0x2f0e, + (q15_t)0x6b6a, (q15_t)0x2f06, (q15_t)0x6b73, (q15_t)0x2efd, (q15_t)0x6b7d, (q15_t)0x2ef5, (q15_t)0x6b86, (q15_t)0x2eec, + (q15_t)0x6b8f, (q15_t)0x2ee4, (q15_t)0x6b98, (q15_t)0x2edb, (q15_t)0x6ba1, (q15_t)0x2ed3, (q15_t)0x6bab, (q15_t)0x2eca, + (q15_t)0x6bb4, (q15_t)0x2ec2, (q15_t)0x6bbd, (q15_t)0x2eb9, (q15_t)0x6bc6, (q15_t)0x2eb0, (q15_t)0x6bcf, (q15_t)0x2ea8, + (q15_t)0x6bd8, (q15_t)0x2e9f, (q15_t)0x6be2, (q15_t)0x2e97, (q15_t)0x6beb, (q15_t)0x2e8e, (q15_t)0x6bf4, (q15_t)0x2e85, + (q15_t)0x6bfd, (q15_t)0x2e7d, (q15_t)0x6c06, (q15_t)0x2e74, (q15_t)0x6c0f, (q15_t)0x2e6b, (q15_t)0x6c18, (q15_t)0x2e63, + (q15_t)0x6c21, (q15_t)0x2e5a, (q15_t)0x6c2b, (q15_t)0x2e51, (q15_t)0x6c34, (q15_t)0x2e49, (q15_t)0x6c3d, (q15_t)0x2e40, + (q15_t)0x6c46, (q15_t)0x2e37, (q15_t)0x6c4f, (q15_t)0x2e2f, (q15_t)0x6c58, (q15_t)0x2e26, (q15_t)0x6c61, (q15_t)0x2e1d, + (q15_t)0x6c6a, (q15_t)0x2e15, (q15_t)0x6c73, (q15_t)0x2e0c, (q15_t)0x6c7c, (q15_t)0x2e03, (q15_t)0x6c85, (q15_t)0x2dfa, + (q15_t)0x6c8e, (q15_t)0x2df2, (q15_t)0x6c97, (q15_t)0x2de9, (q15_t)0x6ca0, (q15_t)0x2de0, (q15_t)0x6ca9, (q15_t)0x2dd7, + (q15_t)0x6cb2, (q15_t)0x2dcf, (q15_t)0x6cbb, (q15_t)0x2dc6, (q15_t)0x6cc4, (q15_t)0x2dbd, (q15_t)0x6ccd, (q15_t)0x2db4, + (q15_t)0x6cd6, (q15_t)0x2dab, (q15_t)0x6cdf, (q15_t)0x2da3, (q15_t)0x6ce8, (q15_t)0x2d9a, (q15_t)0x6cf1, (q15_t)0x2d91, + (q15_t)0x6cfa, (q15_t)0x2d88, (q15_t)0x6d03, (q15_t)0x2d7f, (q15_t)0x6d0c, (q15_t)0x2d76, (q15_t)0x6d15, (q15_t)0x2d6e, + (q15_t)0x6d1e, (q15_t)0x2d65, (q15_t)0x6d27, (q15_t)0x2d5c, (q15_t)0x6d2f, (q15_t)0x2d53, (q15_t)0x6d38, (q15_t)0x2d4a, + (q15_t)0x6d41, (q15_t)0x2d41, (q15_t)0x6d4a, (q15_t)0x2d38, (q15_t)0x6d53, (q15_t)0x2d2f, (q15_t)0x6d5c, (q15_t)0x2d27, + (q15_t)0x6d65, (q15_t)0x2d1e, (q15_t)0x6d6e, (q15_t)0x2d15, (q15_t)0x6d76, (q15_t)0x2d0c, (q15_t)0x6d7f, (q15_t)0x2d03, + (q15_t)0x6d88, (q15_t)0x2cfa, (q15_t)0x6d91, (q15_t)0x2cf1, (q15_t)0x6d9a, (q15_t)0x2ce8, (q15_t)0x6da3, (q15_t)0x2cdf, + (q15_t)0x6dab, (q15_t)0x2cd6, (q15_t)0x6db4, (q15_t)0x2ccd, (q15_t)0x6dbd, (q15_t)0x2cc4, (q15_t)0x6dc6, (q15_t)0x2cbb, + (q15_t)0x6dcf, (q15_t)0x2cb2, (q15_t)0x6dd7, (q15_t)0x2ca9, (q15_t)0x6de0, (q15_t)0x2ca0, (q15_t)0x6de9, (q15_t)0x2c97, + (q15_t)0x6df2, (q15_t)0x2c8e, (q15_t)0x6dfa, (q15_t)0x2c85, (q15_t)0x6e03, (q15_t)0x2c7c, (q15_t)0x6e0c, (q15_t)0x2c73, + (q15_t)0x6e15, (q15_t)0x2c6a, (q15_t)0x6e1d, (q15_t)0x2c61, (q15_t)0x6e26, (q15_t)0x2c58, (q15_t)0x6e2f, (q15_t)0x2c4f, + (q15_t)0x6e37, (q15_t)0x2c46, (q15_t)0x6e40, (q15_t)0x2c3d, (q15_t)0x6e49, (q15_t)0x2c34, (q15_t)0x6e51, (q15_t)0x2c2b, + (q15_t)0x6e5a, (q15_t)0x2c21, (q15_t)0x6e63, (q15_t)0x2c18, (q15_t)0x6e6b, (q15_t)0x2c0f, (q15_t)0x6e74, (q15_t)0x2c06, + (q15_t)0x6e7d, (q15_t)0x2bfd, (q15_t)0x6e85, (q15_t)0x2bf4, (q15_t)0x6e8e, (q15_t)0x2beb, (q15_t)0x6e97, (q15_t)0x2be2, + (q15_t)0x6e9f, (q15_t)0x2bd8, (q15_t)0x6ea8, (q15_t)0x2bcf, (q15_t)0x6eb0, (q15_t)0x2bc6, (q15_t)0x6eb9, (q15_t)0x2bbd, + (q15_t)0x6ec2, (q15_t)0x2bb4, (q15_t)0x6eca, (q15_t)0x2bab, (q15_t)0x6ed3, (q15_t)0x2ba1, (q15_t)0x6edb, (q15_t)0x2b98, + (q15_t)0x6ee4, (q15_t)0x2b8f, (q15_t)0x6eec, (q15_t)0x2b86, (q15_t)0x6ef5, (q15_t)0x2b7d, (q15_t)0x6efd, (q15_t)0x2b73, + (q15_t)0x6f06, (q15_t)0x2b6a, (q15_t)0x6f0e, (q15_t)0x2b61, (q15_t)0x6f17, (q15_t)0x2b58, (q15_t)0x6f20, (q15_t)0x2b4e, + (q15_t)0x6f28, (q15_t)0x2b45, (q15_t)0x6f30, (q15_t)0x2b3c, (q15_t)0x6f39, (q15_t)0x2b33, (q15_t)0x6f41, (q15_t)0x2b29, + (q15_t)0x6f4a, (q15_t)0x2b20, (q15_t)0x6f52, (q15_t)0x2b17, (q15_t)0x6f5b, (q15_t)0x2b0d, (q15_t)0x6f63, (q15_t)0x2b04, + (q15_t)0x6f6c, (q15_t)0x2afb, (q15_t)0x6f74, (q15_t)0x2af2, (q15_t)0x6f7d, (q15_t)0x2ae8, (q15_t)0x6f85, (q15_t)0x2adf, + (q15_t)0x6f8d, (q15_t)0x2ad6, (q15_t)0x6f96, (q15_t)0x2acc, (q15_t)0x6f9e, (q15_t)0x2ac3, (q15_t)0x6fa7, (q15_t)0x2ab9, + (q15_t)0x6faf, (q15_t)0x2ab0, (q15_t)0x6fb7, (q15_t)0x2aa7, (q15_t)0x6fc0, (q15_t)0x2a9d, (q15_t)0x6fc8, (q15_t)0x2a94, + (q15_t)0x6fd0, (q15_t)0x2a8b, (q15_t)0x6fd9, (q15_t)0x2a81, (q15_t)0x6fe1, (q15_t)0x2a78, (q15_t)0x6fea, (q15_t)0x2a6e, + (q15_t)0x6ff2, (q15_t)0x2a65, (q15_t)0x6ffa, (q15_t)0x2a5c, (q15_t)0x7002, (q15_t)0x2a52, (q15_t)0x700b, (q15_t)0x2a49, + (q15_t)0x7013, (q15_t)0x2a3f, (q15_t)0x701b, (q15_t)0x2a36, (q15_t)0x7024, (q15_t)0x2a2c, (q15_t)0x702c, (q15_t)0x2a23, + (q15_t)0x7034, (q15_t)0x2a1a, (q15_t)0x703c, (q15_t)0x2a10, (q15_t)0x7045, (q15_t)0x2a07, (q15_t)0x704d, (q15_t)0x29fd, + (q15_t)0x7055, (q15_t)0x29f4, (q15_t)0x705d, (q15_t)0x29ea, (q15_t)0x7066, (q15_t)0x29e1, (q15_t)0x706e, (q15_t)0x29d7, + (q15_t)0x7076, (q15_t)0x29ce, (q15_t)0x707e, (q15_t)0x29c4, (q15_t)0x7087, (q15_t)0x29bb, (q15_t)0x708f, (q15_t)0x29b1, + (q15_t)0x7097, (q15_t)0x29a7, (q15_t)0x709f, (q15_t)0x299e, (q15_t)0x70a7, (q15_t)0x2994, (q15_t)0x70af, (q15_t)0x298b, + (q15_t)0x70b8, (q15_t)0x2981, (q15_t)0x70c0, (q15_t)0x2978, (q15_t)0x70c8, (q15_t)0x296e, (q15_t)0x70d0, (q15_t)0x2965, + (q15_t)0x70d8, (q15_t)0x295b, (q15_t)0x70e0, (q15_t)0x2951, (q15_t)0x70e8, (q15_t)0x2948, (q15_t)0x70f0, (q15_t)0x293e, + (q15_t)0x70f9, (q15_t)0x2935, (q15_t)0x7101, (q15_t)0x292b, (q15_t)0x7109, (q15_t)0x2921, (q15_t)0x7111, (q15_t)0x2918, + (q15_t)0x7119, (q15_t)0x290e, (q15_t)0x7121, (q15_t)0x2904, (q15_t)0x7129, (q15_t)0x28fb, (q15_t)0x7131, (q15_t)0x28f1, + (q15_t)0x7139, (q15_t)0x28e7, (q15_t)0x7141, (q15_t)0x28de, (q15_t)0x7149, (q15_t)0x28d4, (q15_t)0x7151, (q15_t)0x28ca, + (q15_t)0x7159, (q15_t)0x28c1, (q15_t)0x7161, (q15_t)0x28b7, (q15_t)0x7169, (q15_t)0x28ad, (q15_t)0x7171, (q15_t)0x28a4, + (q15_t)0x7179, (q15_t)0x289a, (q15_t)0x7181, (q15_t)0x2890, (q15_t)0x7189, (q15_t)0x2886, (q15_t)0x7191, (q15_t)0x287d, + (q15_t)0x7199, (q15_t)0x2873, (q15_t)0x71a1, (q15_t)0x2869, (q15_t)0x71a9, (q15_t)0x2860, (q15_t)0x71b1, (q15_t)0x2856, + (q15_t)0x71b9, (q15_t)0x284c, (q15_t)0x71c0, (q15_t)0x2842, (q15_t)0x71c8, (q15_t)0x2838, (q15_t)0x71d0, (q15_t)0x282f, + (q15_t)0x71d8, (q15_t)0x2825, (q15_t)0x71e0, (q15_t)0x281b, (q15_t)0x71e8, (q15_t)0x2811, (q15_t)0x71f0, (q15_t)0x2808, + (q15_t)0x71f8, (q15_t)0x27fe, (q15_t)0x71ff, (q15_t)0x27f4, (q15_t)0x7207, (q15_t)0x27ea, (q15_t)0x720f, (q15_t)0x27e0, + (q15_t)0x7217, (q15_t)0x27d6, (q15_t)0x721f, (q15_t)0x27cd, (q15_t)0x7227, (q15_t)0x27c3, (q15_t)0x722e, (q15_t)0x27b9, + (q15_t)0x7236, (q15_t)0x27af, (q15_t)0x723e, (q15_t)0x27a5, (q15_t)0x7246, (q15_t)0x279b, (q15_t)0x724e, (q15_t)0x2791, + (q15_t)0x7255, (q15_t)0x2788, (q15_t)0x725d, (q15_t)0x277e, (q15_t)0x7265, (q15_t)0x2774, (q15_t)0x726d, (q15_t)0x276a, + (q15_t)0x7274, (q15_t)0x2760, (q15_t)0x727c, (q15_t)0x2756, (q15_t)0x7284, (q15_t)0x274c, (q15_t)0x728b, (q15_t)0x2742, + (q15_t)0x7293, (q15_t)0x2738, (q15_t)0x729b, (q15_t)0x272e, (q15_t)0x72a3, (q15_t)0x2724, (q15_t)0x72aa, (q15_t)0x271a, + (q15_t)0x72b2, (q15_t)0x2711, (q15_t)0x72ba, (q15_t)0x2707, (q15_t)0x72c1, (q15_t)0x26fd, (q15_t)0x72c9, (q15_t)0x26f3, + (q15_t)0x72d0, (q15_t)0x26e9, (q15_t)0x72d8, (q15_t)0x26df, (q15_t)0x72e0, (q15_t)0x26d5, (q15_t)0x72e7, (q15_t)0x26cb, + (q15_t)0x72ef, (q15_t)0x26c1, (q15_t)0x72f7, (q15_t)0x26b7, (q15_t)0x72fe, (q15_t)0x26ad, (q15_t)0x7306, (q15_t)0x26a3, + (q15_t)0x730d, (q15_t)0x2699, (q15_t)0x7315, (q15_t)0x268f, (q15_t)0x731d, (q15_t)0x2685, (q15_t)0x7324, (q15_t)0x267b, + (q15_t)0x732c, (q15_t)0x2671, (q15_t)0x7333, (q15_t)0x2666, (q15_t)0x733b, (q15_t)0x265c, (q15_t)0x7342, (q15_t)0x2652, + (q15_t)0x734a, (q15_t)0x2648, (q15_t)0x7351, (q15_t)0x263e, (q15_t)0x7359, (q15_t)0x2634, (q15_t)0x7360, (q15_t)0x262a, + (q15_t)0x7368, (q15_t)0x2620, (q15_t)0x736f, (q15_t)0x2616, (q15_t)0x7377, (q15_t)0x260c, (q15_t)0x737e, (q15_t)0x2602, + (q15_t)0x7386, (q15_t)0x25f8, (q15_t)0x738d, (q15_t)0x25ed, (q15_t)0x7395, (q15_t)0x25e3, (q15_t)0x739c, (q15_t)0x25d9, + (q15_t)0x73a3, (q15_t)0x25cf, (q15_t)0x73ab, (q15_t)0x25c5, (q15_t)0x73b2, (q15_t)0x25bb, (q15_t)0x73ba, (q15_t)0x25b1, + (q15_t)0x73c1, (q15_t)0x25a6, (q15_t)0x73c8, (q15_t)0x259c, (q15_t)0x73d0, (q15_t)0x2592, (q15_t)0x73d7, (q15_t)0x2588, + (q15_t)0x73df, (q15_t)0x257e, (q15_t)0x73e6, (q15_t)0x2574, (q15_t)0x73ed, (q15_t)0x2569, (q15_t)0x73f5, (q15_t)0x255f, + (q15_t)0x73fc, (q15_t)0x2555, (q15_t)0x7403, (q15_t)0x254b, (q15_t)0x740b, (q15_t)0x2541, (q15_t)0x7412, (q15_t)0x2536, + (q15_t)0x7419, (q15_t)0x252c, (q15_t)0x7420, (q15_t)0x2522, (q15_t)0x7428, (q15_t)0x2518, (q15_t)0x742f, (q15_t)0x250d, + (q15_t)0x7436, (q15_t)0x2503, (q15_t)0x743e, (q15_t)0x24f9, (q15_t)0x7445, (q15_t)0x24ef, (q15_t)0x744c, (q15_t)0x24e4, + (q15_t)0x7453, (q15_t)0x24da, (q15_t)0x745b, (q15_t)0x24d0, (q15_t)0x7462, (q15_t)0x24c5, (q15_t)0x7469, (q15_t)0x24bb, + (q15_t)0x7470, (q15_t)0x24b1, (q15_t)0x7477, (q15_t)0x24a7, (q15_t)0x747f, (q15_t)0x249c, (q15_t)0x7486, (q15_t)0x2492, + (q15_t)0x748d, (q15_t)0x2488, (q15_t)0x7494, (q15_t)0x247d, (q15_t)0x749b, (q15_t)0x2473, (q15_t)0x74a2, (q15_t)0x2469, + (q15_t)0x74aa, (q15_t)0x245e, (q15_t)0x74b1, (q15_t)0x2454, (q15_t)0x74b8, (q15_t)0x244a, (q15_t)0x74bf, (q15_t)0x243f, + (q15_t)0x74c6, (q15_t)0x2435, (q15_t)0x74cd, (q15_t)0x242b, (q15_t)0x74d4, (q15_t)0x2420, (q15_t)0x74db, (q15_t)0x2416, + (q15_t)0x74e2, (q15_t)0x240b, (q15_t)0x74ea, (q15_t)0x2401, (q15_t)0x74f1, (q15_t)0x23f7, (q15_t)0x74f8, (q15_t)0x23ec, + (q15_t)0x74ff, (q15_t)0x23e2, (q15_t)0x7506, (q15_t)0x23d7, (q15_t)0x750d, (q15_t)0x23cd, (q15_t)0x7514, (q15_t)0x23c3, + (q15_t)0x751b, (q15_t)0x23b8, (q15_t)0x7522, (q15_t)0x23ae, (q15_t)0x7529, (q15_t)0x23a3, (q15_t)0x7530, (q15_t)0x2399, + (q15_t)0x7537, (q15_t)0x238e, (q15_t)0x753e, (q15_t)0x2384, (q15_t)0x7545, (q15_t)0x237a, (q15_t)0x754c, (q15_t)0x236f, + (q15_t)0x7553, (q15_t)0x2365, (q15_t)0x755a, (q15_t)0x235a, (q15_t)0x7561, (q15_t)0x2350, (q15_t)0x7567, (q15_t)0x2345, + (q15_t)0x756e, (q15_t)0x233b, (q15_t)0x7575, (q15_t)0x2330, (q15_t)0x757c, (q15_t)0x2326, (q15_t)0x7583, (q15_t)0x231b, + (q15_t)0x758a, (q15_t)0x2311, (q15_t)0x7591, (q15_t)0x2306, (q15_t)0x7598, (q15_t)0x22fc, (q15_t)0x759f, (q15_t)0x22f1, + (q15_t)0x75a5, (q15_t)0x22e7, (q15_t)0x75ac, (q15_t)0x22dc, (q15_t)0x75b3, (q15_t)0x22d2, (q15_t)0x75ba, (q15_t)0x22c7, + (q15_t)0x75c1, (q15_t)0x22bc, (q15_t)0x75c8, (q15_t)0x22b2, (q15_t)0x75ce, (q15_t)0x22a7, (q15_t)0x75d5, (q15_t)0x229d, + (q15_t)0x75dc, (q15_t)0x2292, (q15_t)0x75e3, (q15_t)0x2288, (q15_t)0x75ea, (q15_t)0x227d, (q15_t)0x75f0, (q15_t)0x2272, + (q15_t)0x75f7, (q15_t)0x2268, (q15_t)0x75fe, (q15_t)0x225d, (q15_t)0x7605, (q15_t)0x2253, (q15_t)0x760b, (q15_t)0x2248, + (q15_t)0x7612, (q15_t)0x223d, (q15_t)0x7619, (q15_t)0x2233, (q15_t)0x7620, (q15_t)0x2228, (q15_t)0x7626, (q15_t)0x221e, + (q15_t)0x762d, (q15_t)0x2213, (q15_t)0x7634, (q15_t)0x2208, (q15_t)0x763a, (q15_t)0x21fe, (q15_t)0x7641, (q15_t)0x21f3, + (q15_t)0x7648, (q15_t)0x21e8, (q15_t)0x764e, (q15_t)0x21de, (q15_t)0x7655, (q15_t)0x21d3, (q15_t)0x765c, (q15_t)0x21c8, + (q15_t)0x7662, (q15_t)0x21be, (q15_t)0x7669, (q15_t)0x21b3, (q15_t)0x766f, (q15_t)0x21a8, (q15_t)0x7676, (q15_t)0x219e, + (q15_t)0x767d, (q15_t)0x2193, (q15_t)0x7683, (q15_t)0x2188, (q15_t)0x768a, (q15_t)0x217d, (q15_t)0x7690, (q15_t)0x2173, + (q15_t)0x7697, (q15_t)0x2168, (q15_t)0x769d, (q15_t)0x215d, (q15_t)0x76a4, (q15_t)0x2153, (q15_t)0x76ab, (q15_t)0x2148, + (q15_t)0x76b1, (q15_t)0x213d, (q15_t)0x76b8, (q15_t)0x2132, (q15_t)0x76be, (q15_t)0x2128, (q15_t)0x76c5, (q15_t)0x211d, + (q15_t)0x76cb, (q15_t)0x2112, (q15_t)0x76d2, (q15_t)0x2107, (q15_t)0x76d8, (q15_t)0x20fd, (q15_t)0x76df, (q15_t)0x20f2, + (q15_t)0x76e5, (q15_t)0x20e7, (q15_t)0x76eb, (q15_t)0x20dc, (q15_t)0x76f2, (q15_t)0x20d1, (q15_t)0x76f8, (q15_t)0x20c7, + (q15_t)0x76ff, (q15_t)0x20bc, (q15_t)0x7705, (q15_t)0x20b1, (q15_t)0x770c, (q15_t)0x20a6, (q15_t)0x7712, (q15_t)0x209b, + (q15_t)0x7718, (q15_t)0x2091, (q15_t)0x771f, (q15_t)0x2086, (q15_t)0x7725, (q15_t)0x207b, (q15_t)0x772c, (q15_t)0x2070, + (q15_t)0x7732, (q15_t)0x2065, (q15_t)0x7738, (q15_t)0x205b, (q15_t)0x773f, (q15_t)0x2050, (q15_t)0x7745, (q15_t)0x2045, + (q15_t)0x774b, (q15_t)0x203a, (q15_t)0x7752, (q15_t)0x202f, (q15_t)0x7758, (q15_t)0x2024, (q15_t)0x775e, (q15_t)0x2019, + (q15_t)0x7765, (q15_t)0x200f, (q15_t)0x776b, (q15_t)0x2004, (q15_t)0x7771, (q15_t)0x1ff9, (q15_t)0x7777, (q15_t)0x1fee, + (q15_t)0x777e, (q15_t)0x1fe3, (q15_t)0x7784, (q15_t)0x1fd8, (q15_t)0x778a, (q15_t)0x1fcd, (q15_t)0x7790, (q15_t)0x1fc2, + (q15_t)0x7797, (q15_t)0x1fb7, (q15_t)0x779d, (q15_t)0x1fac, (q15_t)0x77a3, (q15_t)0x1fa2, (q15_t)0x77a9, (q15_t)0x1f97, + (q15_t)0x77b0, (q15_t)0x1f8c, (q15_t)0x77b6, (q15_t)0x1f81, (q15_t)0x77bc, (q15_t)0x1f76, (q15_t)0x77c2, (q15_t)0x1f6b, + (q15_t)0x77c8, (q15_t)0x1f60, (q15_t)0x77ce, (q15_t)0x1f55, (q15_t)0x77d5, (q15_t)0x1f4a, (q15_t)0x77db, (q15_t)0x1f3f, + (q15_t)0x77e1, (q15_t)0x1f34, (q15_t)0x77e7, (q15_t)0x1f29, (q15_t)0x77ed, (q15_t)0x1f1e, (q15_t)0x77f3, (q15_t)0x1f13, + (q15_t)0x77f9, (q15_t)0x1f08, (q15_t)0x77ff, (q15_t)0x1efd, (q15_t)0x7805, (q15_t)0x1ef2, (q15_t)0x780b, (q15_t)0x1ee7, + (q15_t)0x7812, (q15_t)0x1edc, (q15_t)0x7818, (q15_t)0x1ed1, (q15_t)0x781e, (q15_t)0x1ec6, (q15_t)0x7824, (q15_t)0x1ebb, + (q15_t)0x782a, (q15_t)0x1eb0, (q15_t)0x7830, (q15_t)0x1ea5, (q15_t)0x7836, (q15_t)0x1e9a, (q15_t)0x783c, (q15_t)0x1e8f, + (q15_t)0x7842, (q15_t)0x1e84, (q15_t)0x7848, (q15_t)0x1e79, (q15_t)0x784e, (q15_t)0x1e6e, (q15_t)0x7854, (q15_t)0x1e63, + (q15_t)0x785a, (q15_t)0x1e58, (q15_t)0x7860, (q15_t)0x1e4d, (q15_t)0x7866, (q15_t)0x1e42, (q15_t)0x786b, (q15_t)0x1e36, + (q15_t)0x7871, (q15_t)0x1e2b, (q15_t)0x7877, (q15_t)0x1e20, (q15_t)0x787d, (q15_t)0x1e15, (q15_t)0x7883, (q15_t)0x1e0a, + (q15_t)0x7889, (q15_t)0x1dff, (q15_t)0x788f, (q15_t)0x1df4, (q15_t)0x7895, (q15_t)0x1de9, (q15_t)0x789b, (q15_t)0x1dde, + (q15_t)0x78a1, (q15_t)0x1dd3, (q15_t)0x78a6, (q15_t)0x1dc7, (q15_t)0x78ac, (q15_t)0x1dbc, (q15_t)0x78b2, (q15_t)0x1db1, + (q15_t)0x78b8, (q15_t)0x1da6, (q15_t)0x78be, (q15_t)0x1d9b, (q15_t)0x78c3, (q15_t)0x1d90, (q15_t)0x78c9, (q15_t)0x1d85, + (q15_t)0x78cf, (q15_t)0x1d79, (q15_t)0x78d5, (q15_t)0x1d6e, (q15_t)0x78db, (q15_t)0x1d63, (q15_t)0x78e0, (q15_t)0x1d58, + (q15_t)0x78e6, (q15_t)0x1d4d, (q15_t)0x78ec, (q15_t)0x1d42, (q15_t)0x78f2, (q15_t)0x1d36, (q15_t)0x78f7, (q15_t)0x1d2b, + (q15_t)0x78fd, (q15_t)0x1d20, (q15_t)0x7903, (q15_t)0x1d15, (q15_t)0x7909, (q15_t)0x1d0a, (q15_t)0x790e, (q15_t)0x1cff, + (q15_t)0x7914, (q15_t)0x1cf3, (q15_t)0x791a, (q15_t)0x1ce8, (q15_t)0x791f, (q15_t)0x1cdd, (q15_t)0x7925, (q15_t)0x1cd2, + (q15_t)0x792b, (q15_t)0x1cc6, (q15_t)0x7930, (q15_t)0x1cbb, (q15_t)0x7936, (q15_t)0x1cb0, (q15_t)0x793b, (q15_t)0x1ca5, + (q15_t)0x7941, (q15_t)0x1c99, (q15_t)0x7947, (q15_t)0x1c8e, (q15_t)0x794c, (q15_t)0x1c83, (q15_t)0x7952, (q15_t)0x1c78, + (q15_t)0x7958, (q15_t)0x1c6c, (q15_t)0x795d, (q15_t)0x1c61, (q15_t)0x7963, (q15_t)0x1c56, (q15_t)0x7968, (q15_t)0x1c4b, + (q15_t)0x796e, (q15_t)0x1c3f, (q15_t)0x7973, (q15_t)0x1c34, (q15_t)0x7979, (q15_t)0x1c29, (q15_t)0x797e, (q15_t)0x1c1e, + (q15_t)0x7984, (q15_t)0x1c12, (q15_t)0x7989, (q15_t)0x1c07, (q15_t)0x798f, (q15_t)0x1bfc, (q15_t)0x7994, (q15_t)0x1bf0, + (q15_t)0x799a, (q15_t)0x1be5, (q15_t)0x799f, (q15_t)0x1bda, (q15_t)0x79a5, (q15_t)0x1bce, (q15_t)0x79aa, (q15_t)0x1bc3, + (q15_t)0x79b0, (q15_t)0x1bb8, (q15_t)0x79b5, (q15_t)0x1bac, (q15_t)0x79bb, (q15_t)0x1ba1, (q15_t)0x79c0, (q15_t)0x1b96, + (q15_t)0x79c5, (q15_t)0x1b8a, (q15_t)0x79cb, (q15_t)0x1b7f, (q15_t)0x79d0, (q15_t)0x1b74, (q15_t)0x79d6, (q15_t)0x1b68, + (q15_t)0x79db, (q15_t)0x1b5d, (q15_t)0x79e0, (q15_t)0x1b52, (q15_t)0x79e6, (q15_t)0x1b46, (q15_t)0x79eb, (q15_t)0x1b3b, + (q15_t)0x79f0, (q15_t)0x1b30, (q15_t)0x79f6, (q15_t)0x1b24, (q15_t)0x79fb, (q15_t)0x1b19, (q15_t)0x7a00, (q15_t)0x1b0d, + (q15_t)0x7a06, (q15_t)0x1b02, (q15_t)0x7a0b, (q15_t)0x1af7, (q15_t)0x7a10, (q15_t)0x1aeb, (q15_t)0x7a16, (q15_t)0x1ae0, + (q15_t)0x7a1b, (q15_t)0x1ad4, (q15_t)0x7a20, (q15_t)0x1ac9, (q15_t)0x7a25, (q15_t)0x1abe, (q15_t)0x7a2b, (q15_t)0x1ab2, + (q15_t)0x7a30, (q15_t)0x1aa7, (q15_t)0x7a35, (q15_t)0x1a9b, (q15_t)0x7a3a, (q15_t)0x1a90, (q15_t)0x7a3f, (q15_t)0x1a84, + (q15_t)0x7a45, (q15_t)0x1a79, (q15_t)0x7a4a, (q15_t)0x1a6e, (q15_t)0x7a4f, (q15_t)0x1a62, (q15_t)0x7a54, (q15_t)0x1a57, + (q15_t)0x7a59, (q15_t)0x1a4b, (q15_t)0x7a5f, (q15_t)0x1a40, (q15_t)0x7a64, (q15_t)0x1a34, (q15_t)0x7a69, (q15_t)0x1a29, + (q15_t)0x7a6e, (q15_t)0x1a1d, (q15_t)0x7a73, (q15_t)0x1a12, (q15_t)0x7a78, (q15_t)0x1a06, (q15_t)0x7a7d, (q15_t)0x19fb, + (q15_t)0x7a82, (q15_t)0x19ef, (q15_t)0x7a88, (q15_t)0x19e4, (q15_t)0x7a8d, (q15_t)0x19d8, (q15_t)0x7a92, (q15_t)0x19cd, + (q15_t)0x7a97, (q15_t)0x19c1, (q15_t)0x7a9c, (q15_t)0x19b6, (q15_t)0x7aa1, (q15_t)0x19aa, (q15_t)0x7aa6, (q15_t)0x199f, + (q15_t)0x7aab, (q15_t)0x1993, (q15_t)0x7ab0, (q15_t)0x1988, (q15_t)0x7ab5, (q15_t)0x197c, (q15_t)0x7aba, (q15_t)0x1971, + (q15_t)0x7abf, (q15_t)0x1965, (q15_t)0x7ac4, (q15_t)0x195a, (q15_t)0x7ac9, (q15_t)0x194e, (q15_t)0x7ace, (q15_t)0x1943, + (q15_t)0x7ad3, (q15_t)0x1937, (q15_t)0x7ad8, (q15_t)0x192c, (q15_t)0x7add, (q15_t)0x1920, (q15_t)0x7ae2, (q15_t)0x1914, + (q15_t)0x7ae6, (q15_t)0x1909, (q15_t)0x7aeb, (q15_t)0x18fd, (q15_t)0x7af0, (q15_t)0x18f2, (q15_t)0x7af5, (q15_t)0x18e6, + (q15_t)0x7afa, (q15_t)0x18db, (q15_t)0x7aff, (q15_t)0x18cf, (q15_t)0x7b04, (q15_t)0x18c3, (q15_t)0x7b09, (q15_t)0x18b8, + (q15_t)0x7b0e, (q15_t)0x18ac, (q15_t)0x7b12, (q15_t)0x18a1, (q15_t)0x7b17, (q15_t)0x1895, (q15_t)0x7b1c, (q15_t)0x1889, + (q15_t)0x7b21, (q15_t)0x187e, (q15_t)0x7b26, (q15_t)0x1872, (q15_t)0x7b2a, (q15_t)0x1867, (q15_t)0x7b2f, (q15_t)0x185b, + (q15_t)0x7b34, (q15_t)0x184f, (q15_t)0x7b39, (q15_t)0x1844, (q15_t)0x7b3e, (q15_t)0x1838, (q15_t)0x7b42, (q15_t)0x182d, + (q15_t)0x7b47, (q15_t)0x1821, (q15_t)0x7b4c, (q15_t)0x1815, (q15_t)0x7b50, (q15_t)0x180a, (q15_t)0x7b55, (q15_t)0x17fe, + (q15_t)0x7b5a, (q15_t)0x17f2, (q15_t)0x7b5f, (q15_t)0x17e7, (q15_t)0x7b63, (q15_t)0x17db, (q15_t)0x7b68, (q15_t)0x17cf, + (q15_t)0x7b6d, (q15_t)0x17c4, (q15_t)0x7b71, (q15_t)0x17b8, (q15_t)0x7b76, (q15_t)0x17ac, (q15_t)0x7b7b, (q15_t)0x17a1, + (q15_t)0x7b7f, (q15_t)0x1795, (q15_t)0x7b84, (q15_t)0x1789, (q15_t)0x7b88, (q15_t)0x177e, (q15_t)0x7b8d, (q15_t)0x1772, + (q15_t)0x7b92, (q15_t)0x1766, (q15_t)0x7b96, (q15_t)0x175b, (q15_t)0x7b9b, (q15_t)0x174f, (q15_t)0x7b9f, (q15_t)0x1743, + (q15_t)0x7ba4, (q15_t)0x1737, (q15_t)0x7ba9, (q15_t)0x172c, (q15_t)0x7bad, (q15_t)0x1720, (q15_t)0x7bb2, (q15_t)0x1714, + (q15_t)0x7bb6, (q15_t)0x1709, (q15_t)0x7bbb, (q15_t)0x16fd, (q15_t)0x7bbf, (q15_t)0x16f1, (q15_t)0x7bc4, (q15_t)0x16e5, + (q15_t)0x7bc8, (q15_t)0x16da, (q15_t)0x7bcd, (q15_t)0x16ce, (q15_t)0x7bd1, (q15_t)0x16c2, (q15_t)0x7bd6, (q15_t)0x16b6, + (q15_t)0x7bda, (q15_t)0x16ab, (q15_t)0x7bde, (q15_t)0x169f, (q15_t)0x7be3, (q15_t)0x1693, (q15_t)0x7be7, (q15_t)0x1687, + (q15_t)0x7bec, (q15_t)0x167c, (q15_t)0x7bf0, (q15_t)0x1670, (q15_t)0x7bf5, (q15_t)0x1664, (q15_t)0x7bf9, (q15_t)0x1658, + (q15_t)0x7bfd, (q15_t)0x164c, (q15_t)0x7c02, (q15_t)0x1641, (q15_t)0x7c06, (q15_t)0x1635, (q15_t)0x7c0a, (q15_t)0x1629, + (q15_t)0x7c0f, (q15_t)0x161d, (q15_t)0x7c13, (q15_t)0x1612, (q15_t)0x7c17, (q15_t)0x1606, (q15_t)0x7c1c, (q15_t)0x15fa, + (q15_t)0x7c20, (q15_t)0x15ee, (q15_t)0x7c24, (q15_t)0x15e2, (q15_t)0x7c29, (q15_t)0x15d7, (q15_t)0x7c2d, (q15_t)0x15cb, + (q15_t)0x7c31, (q15_t)0x15bf, (q15_t)0x7c36, (q15_t)0x15b3, (q15_t)0x7c3a, (q15_t)0x15a7, (q15_t)0x7c3e, (q15_t)0x159b, + (q15_t)0x7c42, (q15_t)0x1590, (q15_t)0x7c46, (q15_t)0x1584, (q15_t)0x7c4b, (q15_t)0x1578, (q15_t)0x7c4f, (q15_t)0x156c, + (q15_t)0x7c53, (q15_t)0x1560, (q15_t)0x7c57, (q15_t)0x1554, (q15_t)0x7c5b, (q15_t)0x1549, (q15_t)0x7c60, (q15_t)0x153d, + (q15_t)0x7c64, (q15_t)0x1531, (q15_t)0x7c68, (q15_t)0x1525, (q15_t)0x7c6c, (q15_t)0x1519, (q15_t)0x7c70, (q15_t)0x150d, + (q15_t)0x7c74, (q15_t)0x1501, (q15_t)0x7c79, (q15_t)0x14f6, (q15_t)0x7c7d, (q15_t)0x14ea, (q15_t)0x7c81, (q15_t)0x14de, + (q15_t)0x7c85, (q15_t)0x14d2, (q15_t)0x7c89, (q15_t)0x14c6, (q15_t)0x7c8d, (q15_t)0x14ba, (q15_t)0x7c91, (q15_t)0x14ae, + (q15_t)0x7c95, (q15_t)0x14a2, (q15_t)0x7c99, (q15_t)0x1496, (q15_t)0x7c9d, (q15_t)0x148b, (q15_t)0x7ca1, (q15_t)0x147f, + (q15_t)0x7ca5, (q15_t)0x1473, (q15_t)0x7ca9, (q15_t)0x1467, (q15_t)0x7cad, (q15_t)0x145b, (q15_t)0x7cb1, (q15_t)0x144f, + (q15_t)0x7cb5, (q15_t)0x1443, (q15_t)0x7cb9, (q15_t)0x1437, (q15_t)0x7cbd, (q15_t)0x142b, (q15_t)0x7cc1, (q15_t)0x141f, + (q15_t)0x7cc5, (q15_t)0x1413, (q15_t)0x7cc9, (q15_t)0x1407, (q15_t)0x7ccd, (q15_t)0x13fb, (q15_t)0x7cd1, (q15_t)0x13f0, + (q15_t)0x7cd5, (q15_t)0x13e4, (q15_t)0x7cd9, (q15_t)0x13d8, (q15_t)0x7cdd, (q15_t)0x13cc, (q15_t)0x7ce0, (q15_t)0x13c0, + (q15_t)0x7ce4, (q15_t)0x13b4, (q15_t)0x7ce8, (q15_t)0x13a8, (q15_t)0x7cec, (q15_t)0x139c, (q15_t)0x7cf0, (q15_t)0x1390, + (q15_t)0x7cf4, (q15_t)0x1384, (q15_t)0x7cf8, (q15_t)0x1378, (q15_t)0x7cfb, (q15_t)0x136c, (q15_t)0x7cff, (q15_t)0x1360, + (q15_t)0x7d03, (q15_t)0x1354, (q15_t)0x7d07, (q15_t)0x1348, (q15_t)0x7d0b, (q15_t)0x133c, (q15_t)0x7d0e, (q15_t)0x1330, + (q15_t)0x7d12, (q15_t)0x1324, (q15_t)0x7d16, (q15_t)0x1318, (q15_t)0x7d1a, (q15_t)0x130c, (q15_t)0x7d1d, (q15_t)0x1300, + (q15_t)0x7d21, (q15_t)0x12f4, (q15_t)0x7d25, (q15_t)0x12e8, (q15_t)0x7d28, (q15_t)0x12dc, (q15_t)0x7d2c, (q15_t)0x12d0, + (q15_t)0x7d30, (q15_t)0x12c4, (q15_t)0x7d34, (q15_t)0x12b8, (q15_t)0x7d37, (q15_t)0x12ac, (q15_t)0x7d3b, (q15_t)0x12a0, + (q15_t)0x7d3f, (q15_t)0x1294, (q15_t)0x7d42, (q15_t)0x1288, (q15_t)0x7d46, (q15_t)0x127c, (q15_t)0x7d49, (q15_t)0x1270, + (q15_t)0x7d4d, (q15_t)0x1264, (q15_t)0x7d51, (q15_t)0x1258, (q15_t)0x7d54, (q15_t)0x124c, (q15_t)0x7d58, (q15_t)0x1240, + (q15_t)0x7d5b, (q15_t)0x1234, (q15_t)0x7d5f, (q15_t)0x1228, (q15_t)0x7d63, (q15_t)0x121c, (q15_t)0x7d66, (q15_t)0x1210, + (q15_t)0x7d6a, (q15_t)0x1204, (q15_t)0x7d6d, (q15_t)0x11f7, (q15_t)0x7d71, (q15_t)0x11eb, (q15_t)0x7d74, (q15_t)0x11df, + (q15_t)0x7d78, (q15_t)0x11d3, (q15_t)0x7d7b, (q15_t)0x11c7, (q15_t)0x7d7f, (q15_t)0x11bb, (q15_t)0x7d82, (q15_t)0x11af, + (q15_t)0x7d86, (q15_t)0x11a3, (q15_t)0x7d89, (q15_t)0x1197, (q15_t)0x7d8d, (q15_t)0x118b, (q15_t)0x7d90, (q15_t)0x117f, + (q15_t)0x7d93, (q15_t)0x1173, (q15_t)0x7d97, (q15_t)0x1167, (q15_t)0x7d9a, (q15_t)0x115a, (q15_t)0x7d9e, (q15_t)0x114e, + (q15_t)0x7da1, (q15_t)0x1142, (q15_t)0x7da4, (q15_t)0x1136, (q15_t)0x7da8, (q15_t)0x112a, (q15_t)0x7dab, (q15_t)0x111e, + (q15_t)0x7daf, (q15_t)0x1112, (q15_t)0x7db2, (q15_t)0x1106, (q15_t)0x7db5, (q15_t)0x10fa, (q15_t)0x7db9, (q15_t)0x10ed, + (q15_t)0x7dbc, (q15_t)0x10e1, (q15_t)0x7dbf, (q15_t)0x10d5, (q15_t)0x7dc2, (q15_t)0x10c9, (q15_t)0x7dc6, (q15_t)0x10bd, + (q15_t)0x7dc9, (q15_t)0x10b1, (q15_t)0x7dcc, (q15_t)0x10a5, (q15_t)0x7dd0, (q15_t)0x1099, (q15_t)0x7dd3, (q15_t)0x108c, + (q15_t)0x7dd6, (q15_t)0x1080, (q15_t)0x7dd9, (q15_t)0x1074, (q15_t)0x7ddd, (q15_t)0x1068, (q15_t)0x7de0, (q15_t)0x105c, + (q15_t)0x7de3, (q15_t)0x1050, (q15_t)0x7de6, (q15_t)0x1044, (q15_t)0x7de9, (q15_t)0x1037, (q15_t)0x7ded, (q15_t)0x102b, + (q15_t)0x7df0, (q15_t)0x101f, (q15_t)0x7df3, (q15_t)0x1013, (q15_t)0x7df6, (q15_t)0x1007, (q15_t)0x7df9, (q15_t)0xffb, + (q15_t)0x7dfc, (q15_t)0xfee, (q15_t)0x7dff, (q15_t)0xfe2, (q15_t)0x7e03, (q15_t)0xfd6, (q15_t)0x7e06, (q15_t)0xfca, + (q15_t)0x7e09, (q15_t)0xfbe, (q15_t)0x7e0c, (q15_t)0xfb2, (q15_t)0x7e0f, (q15_t)0xfa5, (q15_t)0x7e12, (q15_t)0xf99, + (q15_t)0x7e15, (q15_t)0xf8d, (q15_t)0x7e18, (q15_t)0xf81, (q15_t)0x7e1b, (q15_t)0xf75, (q15_t)0x7e1e, (q15_t)0xf68, + (q15_t)0x7e21, (q15_t)0xf5c, (q15_t)0x7e24, (q15_t)0xf50, (q15_t)0x7e27, (q15_t)0xf44, (q15_t)0x7e2a, (q15_t)0xf38, + (q15_t)0x7e2d, (q15_t)0xf2b, (q15_t)0x7e30, (q15_t)0xf1f, (q15_t)0x7e33, (q15_t)0xf13, (q15_t)0x7e36, (q15_t)0xf07, + (q15_t)0x7e39, (q15_t)0xefb, (q15_t)0x7e3c, (q15_t)0xeee, (q15_t)0x7e3f, (q15_t)0xee2, (q15_t)0x7e42, (q15_t)0xed6, + (q15_t)0x7e45, (q15_t)0xeca, (q15_t)0x7e48, (q15_t)0xebd, (q15_t)0x7e4a, (q15_t)0xeb1, (q15_t)0x7e4d, (q15_t)0xea5, + (q15_t)0x7e50, (q15_t)0xe99, (q15_t)0x7e53, (q15_t)0xe8c, (q15_t)0x7e56, (q15_t)0xe80, (q15_t)0x7e59, (q15_t)0xe74, + (q15_t)0x7e5c, (q15_t)0xe68, (q15_t)0x7e5e, (q15_t)0xe5c, (q15_t)0x7e61, (q15_t)0xe4f, (q15_t)0x7e64, (q15_t)0xe43, + (q15_t)0x7e67, (q15_t)0xe37, (q15_t)0x7e6a, (q15_t)0xe2b, (q15_t)0x7e6c, (q15_t)0xe1e, (q15_t)0x7e6f, (q15_t)0xe12, + (q15_t)0x7e72, (q15_t)0xe06, (q15_t)0x7e75, (q15_t)0xdf9, (q15_t)0x7e77, (q15_t)0xded, (q15_t)0x7e7a, (q15_t)0xde1, + (q15_t)0x7e7d, (q15_t)0xdd5, (q15_t)0x7e80, (q15_t)0xdc8, (q15_t)0x7e82, (q15_t)0xdbc, (q15_t)0x7e85, (q15_t)0xdb0, + (q15_t)0x7e88, (q15_t)0xda4, (q15_t)0x7e8a, (q15_t)0xd97, (q15_t)0x7e8d, (q15_t)0xd8b, (q15_t)0x7e90, (q15_t)0xd7f, + (q15_t)0x7e92, (q15_t)0xd72, (q15_t)0x7e95, (q15_t)0xd66, (q15_t)0x7e98, (q15_t)0xd5a, (q15_t)0x7e9a, (q15_t)0xd4e, + (q15_t)0x7e9d, (q15_t)0xd41, (q15_t)0x7e9f, (q15_t)0xd35, (q15_t)0x7ea2, (q15_t)0xd29, (q15_t)0x7ea5, (q15_t)0xd1c, + (q15_t)0x7ea7, (q15_t)0xd10, (q15_t)0x7eaa, (q15_t)0xd04, (q15_t)0x7eac, (q15_t)0xcf8, (q15_t)0x7eaf, (q15_t)0xceb, + (q15_t)0x7eb1, (q15_t)0xcdf, (q15_t)0x7eb4, (q15_t)0xcd3, (q15_t)0x7eb6, (q15_t)0xcc6, (q15_t)0x7eb9, (q15_t)0xcba, + (q15_t)0x7ebb, (q15_t)0xcae, (q15_t)0x7ebe, (q15_t)0xca1, (q15_t)0x7ec0, (q15_t)0xc95, (q15_t)0x7ec3, (q15_t)0xc89, + (q15_t)0x7ec5, (q15_t)0xc7c, (q15_t)0x7ec8, (q15_t)0xc70, (q15_t)0x7eca, (q15_t)0xc64, (q15_t)0x7ecc, (q15_t)0xc57, + (q15_t)0x7ecf, (q15_t)0xc4b, (q15_t)0x7ed1, (q15_t)0xc3f, (q15_t)0x7ed4, (q15_t)0xc32, (q15_t)0x7ed6, (q15_t)0xc26, + (q15_t)0x7ed8, (q15_t)0xc1a, (q15_t)0x7edb, (q15_t)0xc0d, (q15_t)0x7edd, (q15_t)0xc01, (q15_t)0x7ee0, (q15_t)0xbf5, + (q15_t)0x7ee2, (q15_t)0xbe8, (q15_t)0x7ee4, (q15_t)0xbdc, (q15_t)0x7ee7, (q15_t)0xbd0, (q15_t)0x7ee9, (q15_t)0xbc3, + (q15_t)0x7eeb, (q15_t)0xbb7, (q15_t)0x7eed, (q15_t)0xbab, (q15_t)0x7ef0, (q15_t)0xb9e, (q15_t)0x7ef2, (q15_t)0xb92, + (q15_t)0x7ef4, (q15_t)0xb85, (q15_t)0x7ef7, (q15_t)0xb79, (q15_t)0x7ef9, (q15_t)0xb6d, (q15_t)0x7efb, (q15_t)0xb60, + (q15_t)0x7efd, (q15_t)0xb54, (q15_t)0x7f00, (q15_t)0xb48, (q15_t)0x7f02, (q15_t)0xb3b, (q15_t)0x7f04, (q15_t)0xb2f, + (q15_t)0x7f06, (q15_t)0xb23, (q15_t)0x7f08, (q15_t)0xb16, (q15_t)0x7f0a, (q15_t)0xb0a, (q15_t)0x7f0d, (q15_t)0xafd, + (q15_t)0x7f0f, (q15_t)0xaf1, (q15_t)0x7f11, (q15_t)0xae5, (q15_t)0x7f13, (q15_t)0xad8, (q15_t)0x7f15, (q15_t)0xacc, + (q15_t)0x7f17, (q15_t)0xac0, (q15_t)0x7f19, (q15_t)0xab3, (q15_t)0x7f1c, (q15_t)0xaa7, (q15_t)0x7f1e, (q15_t)0xa9a, + (q15_t)0x7f20, (q15_t)0xa8e, (q15_t)0x7f22, (q15_t)0xa82, (q15_t)0x7f24, (q15_t)0xa75, (q15_t)0x7f26, (q15_t)0xa69, + (q15_t)0x7f28, (q15_t)0xa5c, (q15_t)0x7f2a, (q15_t)0xa50, (q15_t)0x7f2c, (q15_t)0xa44, (q15_t)0x7f2e, (q15_t)0xa37, + (q15_t)0x7f30, (q15_t)0xa2b, (q15_t)0x7f32, (q15_t)0xa1e, (q15_t)0x7f34, (q15_t)0xa12, (q15_t)0x7f36, (q15_t)0xa06, + (q15_t)0x7f38, (q15_t)0x9f9, (q15_t)0x7f3a, (q15_t)0x9ed, (q15_t)0x7f3c, (q15_t)0x9e0, (q15_t)0x7f3e, (q15_t)0x9d4, + (q15_t)0x7f40, (q15_t)0x9c7, (q15_t)0x7f42, (q15_t)0x9bb, (q15_t)0x7f43, (q15_t)0x9af, (q15_t)0x7f45, (q15_t)0x9a2, + (q15_t)0x7f47, (q15_t)0x996, (q15_t)0x7f49, (q15_t)0x989, (q15_t)0x7f4b, (q15_t)0x97d, (q15_t)0x7f4d, (q15_t)0x970, + (q15_t)0x7f4f, (q15_t)0x964, (q15_t)0x7f51, (q15_t)0x958, (q15_t)0x7f52, (q15_t)0x94b, (q15_t)0x7f54, (q15_t)0x93f, + (q15_t)0x7f56, (q15_t)0x932, (q15_t)0x7f58, (q15_t)0x926, (q15_t)0x7f5a, (q15_t)0x919, (q15_t)0x7f5b, (q15_t)0x90d, + (q15_t)0x7f5d, (q15_t)0x901, (q15_t)0x7f5f, (q15_t)0x8f4, (q15_t)0x7f61, (q15_t)0x8e8, (q15_t)0x7f62, (q15_t)0x8db, + (q15_t)0x7f64, (q15_t)0x8cf, (q15_t)0x7f66, (q15_t)0x8c2, (q15_t)0x7f68, (q15_t)0x8b6, (q15_t)0x7f69, (q15_t)0x8a9, + (q15_t)0x7f6b, (q15_t)0x89d, (q15_t)0x7f6d, (q15_t)0x891, (q15_t)0x7f6e, (q15_t)0x884, (q15_t)0x7f70, (q15_t)0x878, + (q15_t)0x7f72, (q15_t)0x86b, (q15_t)0x7f73, (q15_t)0x85f, (q15_t)0x7f75, (q15_t)0x852, (q15_t)0x7f77, (q15_t)0x846, + (q15_t)0x7f78, (q15_t)0x839, (q15_t)0x7f7a, (q15_t)0x82d, (q15_t)0x7f7b, (q15_t)0x820, (q15_t)0x7f7d, (q15_t)0x814, + (q15_t)0x7f7f, (q15_t)0x807, (q15_t)0x7f80, (q15_t)0x7fb, (q15_t)0x7f82, (q15_t)0x7ef, (q15_t)0x7f83, (q15_t)0x7e2, + (q15_t)0x7f85, (q15_t)0x7d6, (q15_t)0x7f86, (q15_t)0x7c9, (q15_t)0x7f88, (q15_t)0x7bd, (q15_t)0x7f89, (q15_t)0x7b0, + (q15_t)0x7f8b, (q15_t)0x7a4, (q15_t)0x7f8c, (q15_t)0x797, (q15_t)0x7f8e, (q15_t)0x78b, (q15_t)0x7f8f, (q15_t)0x77e, + (q15_t)0x7f91, (q15_t)0x772, (q15_t)0x7f92, (q15_t)0x765, (q15_t)0x7f94, (q15_t)0x759, (q15_t)0x7f95, (q15_t)0x74c, + (q15_t)0x7f97, (q15_t)0x740, (q15_t)0x7f98, (q15_t)0x733, (q15_t)0x7f99, (q15_t)0x727, (q15_t)0x7f9b, (q15_t)0x71a, + (q15_t)0x7f9c, (q15_t)0x70e, (q15_t)0x7f9e, (q15_t)0x701, (q15_t)0x7f9f, (q15_t)0x6f5, (q15_t)0x7fa0, (q15_t)0x6e8, + (q15_t)0x7fa2, (q15_t)0x6dc, (q15_t)0x7fa3, (q15_t)0x6cf, (q15_t)0x7fa4, (q15_t)0x6c3, (q15_t)0x7fa6, (q15_t)0x6b6, + (q15_t)0x7fa7, (q15_t)0x6aa, (q15_t)0x7fa8, (q15_t)0x69d, (q15_t)0x7faa, (q15_t)0x691, (q15_t)0x7fab, (q15_t)0x684, + (q15_t)0x7fac, (q15_t)0x678, (q15_t)0x7fad, (q15_t)0x66b, (q15_t)0x7faf, (q15_t)0x65f, (q15_t)0x7fb0, (q15_t)0x652, + (q15_t)0x7fb1, (q15_t)0x646, (q15_t)0x7fb2, (q15_t)0x639, (q15_t)0x7fb4, (q15_t)0x62d, (q15_t)0x7fb5, (q15_t)0x620, + (q15_t)0x7fb6, (q15_t)0x614, (q15_t)0x7fb7, (q15_t)0x607, (q15_t)0x7fb8, (q15_t)0x5fb, (q15_t)0x7fb9, (q15_t)0x5ee, + (q15_t)0x7fbb, (q15_t)0x5e2, (q15_t)0x7fbc, (q15_t)0x5d5, (q15_t)0x7fbd, (q15_t)0x5c9, (q15_t)0x7fbe, (q15_t)0x5bc, + (q15_t)0x7fbf, (q15_t)0x5b0, (q15_t)0x7fc0, (q15_t)0x5a3, (q15_t)0x7fc1, (q15_t)0x597, (q15_t)0x7fc3, (q15_t)0x58a, + (q15_t)0x7fc4, (q15_t)0x57e, (q15_t)0x7fc5, (q15_t)0x571, (q15_t)0x7fc6, (q15_t)0x565, (q15_t)0x7fc7, (q15_t)0x558, + (q15_t)0x7fc8, (q15_t)0x54c, (q15_t)0x7fc9, (q15_t)0x53f, (q15_t)0x7fca, (q15_t)0x533, (q15_t)0x7fcb, (q15_t)0x526, + (q15_t)0x7fcc, (q15_t)0x51a, (q15_t)0x7fcd, (q15_t)0x50d, (q15_t)0x7fce, (q15_t)0x500, (q15_t)0x7fcf, (q15_t)0x4f4, + (q15_t)0x7fd0, (q15_t)0x4e7, (q15_t)0x7fd1, (q15_t)0x4db, (q15_t)0x7fd2, (q15_t)0x4ce, (q15_t)0x7fd3, (q15_t)0x4c2, + (q15_t)0x7fd4, (q15_t)0x4b5, (q15_t)0x7fd5, (q15_t)0x4a9, (q15_t)0x7fd5, (q15_t)0x49c, (q15_t)0x7fd6, (q15_t)0x490, + (q15_t)0x7fd7, (q15_t)0x483, (q15_t)0x7fd8, (q15_t)0x477, (q15_t)0x7fd9, (q15_t)0x46a, (q15_t)0x7fda, (q15_t)0x45e, + (q15_t)0x7fdb, (q15_t)0x451, (q15_t)0x7fdc, (q15_t)0x444, (q15_t)0x7fdc, (q15_t)0x438, (q15_t)0x7fdd, (q15_t)0x42b, + (q15_t)0x7fde, (q15_t)0x41f, (q15_t)0x7fdf, (q15_t)0x412, (q15_t)0x7fe0, (q15_t)0x406, (q15_t)0x7fe0, (q15_t)0x3f9, + (q15_t)0x7fe1, (q15_t)0x3ed, (q15_t)0x7fe2, (q15_t)0x3e0, (q15_t)0x7fe3, (q15_t)0x3d4, (q15_t)0x7fe3, (q15_t)0x3c7, + (q15_t)0x7fe4, (q15_t)0x3bb, (q15_t)0x7fe5, (q15_t)0x3ae, (q15_t)0x7fe6, (q15_t)0x3a1, (q15_t)0x7fe6, (q15_t)0x395, + (q15_t)0x7fe7, (q15_t)0x388, (q15_t)0x7fe8, (q15_t)0x37c, (q15_t)0x7fe8, (q15_t)0x36f, (q15_t)0x7fe9, (q15_t)0x363, + (q15_t)0x7fea, (q15_t)0x356, (q15_t)0x7fea, (q15_t)0x34a, (q15_t)0x7feb, (q15_t)0x33d, (q15_t)0x7fec, (q15_t)0x330, + (q15_t)0x7fec, (q15_t)0x324, (q15_t)0x7fed, (q15_t)0x317, (q15_t)0x7fed, (q15_t)0x30b, (q15_t)0x7fee, (q15_t)0x2fe, + (q15_t)0x7fef, (q15_t)0x2f2, (q15_t)0x7fef, (q15_t)0x2e5, (q15_t)0x7ff0, (q15_t)0x2d9, (q15_t)0x7ff0, (q15_t)0x2cc, + (q15_t)0x7ff1, (q15_t)0x2c0, (q15_t)0x7ff1, (q15_t)0x2b3, (q15_t)0x7ff2, (q15_t)0x2a6, (q15_t)0x7ff2, (q15_t)0x29a, + (q15_t)0x7ff3, (q15_t)0x28d, (q15_t)0x7ff3, (q15_t)0x281, (q15_t)0x7ff4, (q15_t)0x274, (q15_t)0x7ff4, (q15_t)0x268, + (q15_t)0x7ff5, (q15_t)0x25b, (q15_t)0x7ff5, (q15_t)0x24e, (q15_t)0x7ff6, (q15_t)0x242, (q15_t)0x7ff6, (q15_t)0x235, + (q15_t)0x7ff7, (q15_t)0x229, (q15_t)0x7ff7, (q15_t)0x21c, (q15_t)0x7ff7, (q15_t)0x210, (q15_t)0x7ff8, (q15_t)0x203, + (q15_t)0x7ff8, (q15_t)0x1f7, (q15_t)0x7ff9, (q15_t)0x1ea, (q15_t)0x7ff9, (q15_t)0x1dd, (q15_t)0x7ff9, (q15_t)0x1d1, + (q15_t)0x7ffa, (q15_t)0x1c4, (q15_t)0x7ffa, (q15_t)0x1b8, (q15_t)0x7ffa, (q15_t)0x1ab, (q15_t)0x7ffb, (q15_t)0x19f, + (q15_t)0x7ffb, (q15_t)0x192, (q15_t)0x7ffb, (q15_t)0x186, (q15_t)0x7ffc, (q15_t)0x179, (q15_t)0x7ffc, (q15_t)0x16c, + (q15_t)0x7ffc, (q15_t)0x160, (q15_t)0x7ffc, (q15_t)0x153, (q15_t)0x7ffd, (q15_t)0x147, (q15_t)0x7ffd, (q15_t)0x13a, + (q15_t)0x7ffd, (q15_t)0x12e, (q15_t)0x7ffd, (q15_t)0x121, (q15_t)0x7ffe, (q15_t)0x114, (q15_t)0x7ffe, (q15_t)0x108, + (q15_t)0x7ffe, (q15_t)0xfb, (q15_t)0x7ffe, (q15_t)0xef, (q15_t)0x7ffe, (q15_t)0xe2, (q15_t)0x7fff, (q15_t)0xd6, + (q15_t)0x7fff, (q15_t)0xc9, (q15_t)0x7fff, (q15_t)0xbc, (q15_t)0x7fff, (q15_t)0xb0, (q15_t)0x7fff, (q15_t)0xa3, + (q15_t)0x7fff, (q15_t)0x97, (q15_t)0x7fff, (q15_t)0x8a, (q15_t)0x7fff, (q15_t)0x7e, (q15_t)0x7fff, (q15_t)0x71, + (q15_t)0x7fff, (q15_t)0x65, (q15_t)0x7fff, (q15_t)0x58, (q15_t)0x7fff, (q15_t)0x4b, (q15_t)0x7fff, (q15_t)0x3f, + (q15_t)0x7fff, (q15_t)0x32, (q15_t)0x7fff, (q15_t)0x26, (q15_t)0x7fff, (q15_t)0x19, (q15_t)0x7fff, (q15_t)0xd, + (q15_t)0x7fff, (q15_t)0x0, (q15_t)0x7fff, (q15_t)0xfff3, (q15_t)0x7fff, (q15_t)0xffe7, (q15_t)0x7fff, (q15_t)0xffda, + (q15_t)0x7fff, (q15_t)0xffce, (q15_t)0x7fff, (q15_t)0xffc1, (q15_t)0x7fff, (q15_t)0xffb5, (q15_t)0x7fff, (q15_t)0xffa8, + (q15_t)0x7fff, (q15_t)0xff9b, (q15_t)0x7fff, (q15_t)0xff8f, (q15_t)0x7fff, (q15_t)0xff82, (q15_t)0x7fff, (q15_t)0xff76, + (q15_t)0x7fff, (q15_t)0xff69, (q15_t)0x7fff, (q15_t)0xff5d, (q15_t)0x7fff, (q15_t)0xff50, (q15_t)0x7fff, (q15_t)0xff44, + (q15_t)0x7fff, (q15_t)0xff37, (q15_t)0x7fff, (q15_t)0xff2a, (q15_t)0x7ffe, (q15_t)0xff1e, (q15_t)0x7ffe, (q15_t)0xff11, + (q15_t)0x7ffe, (q15_t)0xff05, (q15_t)0x7ffe, (q15_t)0xfef8, (q15_t)0x7ffe, (q15_t)0xfeec, (q15_t)0x7ffd, (q15_t)0xfedf, + (q15_t)0x7ffd, (q15_t)0xfed2, (q15_t)0x7ffd, (q15_t)0xfec6, (q15_t)0x7ffd, (q15_t)0xfeb9, (q15_t)0x7ffc, (q15_t)0xfead, + (q15_t)0x7ffc, (q15_t)0xfea0, (q15_t)0x7ffc, (q15_t)0xfe94, (q15_t)0x7ffc, (q15_t)0xfe87, (q15_t)0x7ffb, (q15_t)0xfe7a, + (q15_t)0x7ffb, (q15_t)0xfe6e, (q15_t)0x7ffb, (q15_t)0xfe61, (q15_t)0x7ffa, (q15_t)0xfe55, (q15_t)0x7ffa, (q15_t)0xfe48, + (q15_t)0x7ffa, (q15_t)0xfe3c, (q15_t)0x7ff9, (q15_t)0xfe2f, (q15_t)0x7ff9, (q15_t)0xfe23, (q15_t)0x7ff9, (q15_t)0xfe16, + (q15_t)0x7ff8, (q15_t)0xfe09, (q15_t)0x7ff8, (q15_t)0xfdfd, (q15_t)0x7ff7, (q15_t)0xfdf0, (q15_t)0x7ff7, (q15_t)0xfde4, + (q15_t)0x7ff7, (q15_t)0xfdd7, (q15_t)0x7ff6, (q15_t)0xfdcb, (q15_t)0x7ff6, (q15_t)0xfdbe, (q15_t)0x7ff5, (q15_t)0xfdb2, + (q15_t)0x7ff5, (q15_t)0xfda5, (q15_t)0x7ff4, (q15_t)0xfd98, (q15_t)0x7ff4, (q15_t)0xfd8c, (q15_t)0x7ff3, (q15_t)0xfd7f, + (q15_t)0x7ff3, (q15_t)0xfd73, (q15_t)0x7ff2, (q15_t)0xfd66, (q15_t)0x7ff2, (q15_t)0xfd5a, (q15_t)0x7ff1, (q15_t)0xfd4d, + (q15_t)0x7ff1, (q15_t)0xfd40, (q15_t)0x7ff0, (q15_t)0xfd34, (q15_t)0x7ff0, (q15_t)0xfd27, (q15_t)0x7fef, (q15_t)0xfd1b, + (q15_t)0x7fef, (q15_t)0xfd0e, (q15_t)0x7fee, (q15_t)0xfd02, (q15_t)0x7fed, (q15_t)0xfcf5, (q15_t)0x7fed, (q15_t)0xfce9, + (q15_t)0x7fec, (q15_t)0xfcdc, (q15_t)0x7fec, (q15_t)0xfcd0, (q15_t)0x7feb, (q15_t)0xfcc3, (q15_t)0x7fea, (q15_t)0xfcb6, + (q15_t)0x7fea, (q15_t)0xfcaa, (q15_t)0x7fe9, (q15_t)0xfc9d, (q15_t)0x7fe8, (q15_t)0xfc91, (q15_t)0x7fe8, (q15_t)0xfc84, + (q15_t)0x7fe7, (q15_t)0xfc78, (q15_t)0x7fe6, (q15_t)0xfc6b, (q15_t)0x7fe6, (q15_t)0xfc5f, (q15_t)0x7fe5, (q15_t)0xfc52, + (q15_t)0x7fe4, (q15_t)0xfc45, (q15_t)0x7fe3, (q15_t)0xfc39, (q15_t)0x7fe3, (q15_t)0xfc2c, (q15_t)0x7fe2, (q15_t)0xfc20, + (q15_t)0x7fe1, (q15_t)0xfc13, (q15_t)0x7fe0, (q15_t)0xfc07, (q15_t)0x7fe0, (q15_t)0xfbfa, (q15_t)0x7fdf, (q15_t)0xfbee, + (q15_t)0x7fde, (q15_t)0xfbe1, (q15_t)0x7fdd, (q15_t)0xfbd5, (q15_t)0x7fdc, (q15_t)0xfbc8, (q15_t)0x7fdc, (q15_t)0xfbbc, + (q15_t)0x7fdb, (q15_t)0xfbaf, (q15_t)0x7fda, (q15_t)0xfba2, (q15_t)0x7fd9, (q15_t)0xfb96, (q15_t)0x7fd8, (q15_t)0xfb89, + (q15_t)0x7fd7, (q15_t)0xfb7d, (q15_t)0x7fd6, (q15_t)0xfb70, (q15_t)0x7fd5, (q15_t)0xfb64, (q15_t)0x7fd5, (q15_t)0xfb57, + (q15_t)0x7fd4, (q15_t)0xfb4b, (q15_t)0x7fd3, (q15_t)0xfb3e, (q15_t)0x7fd2, (q15_t)0xfb32, (q15_t)0x7fd1, (q15_t)0xfb25, + (q15_t)0x7fd0, (q15_t)0xfb19, (q15_t)0x7fcf, (q15_t)0xfb0c, (q15_t)0x7fce, (q15_t)0xfb00, (q15_t)0x7fcd, (q15_t)0xfaf3, + (q15_t)0x7fcc, (q15_t)0xfae6, (q15_t)0x7fcb, (q15_t)0xfada, (q15_t)0x7fca, (q15_t)0xfacd, (q15_t)0x7fc9, (q15_t)0xfac1, + (q15_t)0x7fc8, (q15_t)0xfab4, (q15_t)0x7fc7, (q15_t)0xfaa8, (q15_t)0x7fc6, (q15_t)0xfa9b, (q15_t)0x7fc5, (q15_t)0xfa8f, + (q15_t)0x7fc4, (q15_t)0xfa82, (q15_t)0x7fc3, (q15_t)0xfa76, (q15_t)0x7fc1, (q15_t)0xfa69, (q15_t)0x7fc0, (q15_t)0xfa5d, + (q15_t)0x7fbf, (q15_t)0xfa50, (q15_t)0x7fbe, (q15_t)0xfa44, (q15_t)0x7fbd, (q15_t)0xfa37, (q15_t)0x7fbc, (q15_t)0xfa2b, + (q15_t)0x7fbb, (q15_t)0xfa1e, (q15_t)0x7fb9, (q15_t)0xfa12, (q15_t)0x7fb8, (q15_t)0xfa05, (q15_t)0x7fb7, (q15_t)0xf9f9, + (q15_t)0x7fb6, (q15_t)0xf9ec, (q15_t)0x7fb5, (q15_t)0xf9e0, (q15_t)0x7fb4, (q15_t)0xf9d3, (q15_t)0x7fb2, (q15_t)0xf9c7, + (q15_t)0x7fb1, (q15_t)0xf9ba, (q15_t)0x7fb0, (q15_t)0xf9ae, (q15_t)0x7faf, (q15_t)0xf9a1, (q15_t)0x7fad, (q15_t)0xf995, + (q15_t)0x7fac, (q15_t)0xf988, (q15_t)0x7fab, (q15_t)0xf97c, (q15_t)0x7faa, (q15_t)0xf96f, (q15_t)0x7fa8, (q15_t)0xf963, + (q15_t)0x7fa7, (q15_t)0xf956, (q15_t)0x7fa6, (q15_t)0xf94a, (q15_t)0x7fa4, (q15_t)0xf93d, (q15_t)0x7fa3, (q15_t)0xf931, + (q15_t)0x7fa2, (q15_t)0xf924, (q15_t)0x7fa0, (q15_t)0xf918, (q15_t)0x7f9f, (q15_t)0xf90b, (q15_t)0x7f9e, (q15_t)0xf8ff, + (q15_t)0x7f9c, (q15_t)0xf8f2, (q15_t)0x7f9b, (q15_t)0xf8e6, (q15_t)0x7f99, (q15_t)0xf8d9, (q15_t)0x7f98, (q15_t)0xf8cd, + (q15_t)0x7f97, (q15_t)0xf8c0, (q15_t)0x7f95, (q15_t)0xf8b4, (q15_t)0x7f94, (q15_t)0xf8a7, (q15_t)0x7f92, (q15_t)0xf89b, + (q15_t)0x7f91, (q15_t)0xf88e, (q15_t)0x7f8f, (q15_t)0xf882, (q15_t)0x7f8e, (q15_t)0xf875, (q15_t)0x7f8c, (q15_t)0xf869, + (q15_t)0x7f8b, (q15_t)0xf85c, (q15_t)0x7f89, (q15_t)0xf850, (q15_t)0x7f88, (q15_t)0xf843, (q15_t)0x7f86, (q15_t)0xf837, + (q15_t)0x7f85, (q15_t)0xf82a, (q15_t)0x7f83, (q15_t)0xf81e, (q15_t)0x7f82, (q15_t)0xf811, (q15_t)0x7f80, (q15_t)0xf805, + (q15_t)0x7f7f, (q15_t)0xf7f9, (q15_t)0x7f7d, (q15_t)0xf7ec, (q15_t)0x7f7b, (q15_t)0xf7e0, (q15_t)0x7f7a, (q15_t)0xf7d3, + (q15_t)0x7f78, (q15_t)0xf7c7, (q15_t)0x7f77, (q15_t)0xf7ba, (q15_t)0x7f75, (q15_t)0xf7ae, (q15_t)0x7f73, (q15_t)0xf7a1, + (q15_t)0x7f72, (q15_t)0xf795, (q15_t)0x7f70, (q15_t)0xf788, (q15_t)0x7f6e, (q15_t)0xf77c, (q15_t)0x7f6d, (q15_t)0xf76f, + (q15_t)0x7f6b, (q15_t)0xf763, (q15_t)0x7f69, (q15_t)0xf757, (q15_t)0x7f68, (q15_t)0xf74a, (q15_t)0x7f66, (q15_t)0xf73e, + (q15_t)0x7f64, (q15_t)0xf731, (q15_t)0x7f62, (q15_t)0xf725, (q15_t)0x7f61, (q15_t)0xf718, (q15_t)0x7f5f, (q15_t)0xf70c, + (q15_t)0x7f5d, (q15_t)0xf6ff, (q15_t)0x7f5b, (q15_t)0xf6f3, (q15_t)0x7f5a, (q15_t)0xf6e7, (q15_t)0x7f58, (q15_t)0xf6da, + (q15_t)0x7f56, (q15_t)0xf6ce, (q15_t)0x7f54, (q15_t)0xf6c1, (q15_t)0x7f52, (q15_t)0xf6b5, (q15_t)0x7f51, (q15_t)0xf6a8, + (q15_t)0x7f4f, (q15_t)0xf69c, (q15_t)0x7f4d, (q15_t)0xf690, (q15_t)0x7f4b, (q15_t)0xf683, (q15_t)0x7f49, (q15_t)0xf677, + (q15_t)0x7f47, (q15_t)0xf66a, (q15_t)0x7f45, (q15_t)0xf65e, (q15_t)0x7f43, (q15_t)0xf651, (q15_t)0x7f42, (q15_t)0xf645, + (q15_t)0x7f40, (q15_t)0xf639, (q15_t)0x7f3e, (q15_t)0xf62c, (q15_t)0x7f3c, (q15_t)0xf620, (q15_t)0x7f3a, (q15_t)0xf613, + (q15_t)0x7f38, (q15_t)0xf607, (q15_t)0x7f36, (q15_t)0xf5fa, (q15_t)0x7f34, (q15_t)0xf5ee, (q15_t)0x7f32, (q15_t)0xf5e2, + (q15_t)0x7f30, (q15_t)0xf5d5, (q15_t)0x7f2e, (q15_t)0xf5c9, (q15_t)0x7f2c, (q15_t)0xf5bc, (q15_t)0x7f2a, (q15_t)0xf5b0, + (q15_t)0x7f28, (q15_t)0xf5a4, (q15_t)0x7f26, (q15_t)0xf597, (q15_t)0x7f24, (q15_t)0xf58b, (q15_t)0x7f22, (q15_t)0xf57e, + (q15_t)0x7f20, (q15_t)0xf572, (q15_t)0x7f1e, (q15_t)0xf566, (q15_t)0x7f1c, (q15_t)0xf559, (q15_t)0x7f19, (q15_t)0xf54d, + (q15_t)0x7f17, (q15_t)0xf540, (q15_t)0x7f15, (q15_t)0xf534, (q15_t)0x7f13, (q15_t)0xf528, (q15_t)0x7f11, (q15_t)0xf51b, + (q15_t)0x7f0f, (q15_t)0xf50f, (q15_t)0x7f0d, (q15_t)0xf503, (q15_t)0x7f0a, (q15_t)0xf4f6, (q15_t)0x7f08, (q15_t)0xf4ea, + (q15_t)0x7f06, (q15_t)0xf4dd, (q15_t)0x7f04, (q15_t)0xf4d1, (q15_t)0x7f02, (q15_t)0xf4c5, (q15_t)0x7f00, (q15_t)0xf4b8, + (q15_t)0x7efd, (q15_t)0xf4ac, (q15_t)0x7efb, (q15_t)0xf4a0, (q15_t)0x7ef9, (q15_t)0xf493, (q15_t)0x7ef7, (q15_t)0xf487, + (q15_t)0x7ef4, (q15_t)0xf47b, (q15_t)0x7ef2, (q15_t)0xf46e, (q15_t)0x7ef0, (q15_t)0xf462, (q15_t)0x7eed, (q15_t)0xf455, + (q15_t)0x7eeb, (q15_t)0xf449, (q15_t)0x7ee9, (q15_t)0xf43d, (q15_t)0x7ee7, (q15_t)0xf430, (q15_t)0x7ee4, (q15_t)0xf424, + (q15_t)0x7ee2, (q15_t)0xf418, (q15_t)0x7ee0, (q15_t)0xf40b, (q15_t)0x7edd, (q15_t)0xf3ff, (q15_t)0x7edb, (q15_t)0xf3f3, + (q15_t)0x7ed8, (q15_t)0xf3e6, (q15_t)0x7ed6, (q15_t)0xf3da, (q15_t)0x7ed4, (q15_t)0xf3ce, (q15_t)0x7ed1, (q15_t)0xf3c1, + (q15_t)0x7ecf, (q15_t)0xf3b5, (q15_t)0x7ecc, (q15_t)0xf3a9, (q15_t)0x7eca, (q15_t)0xf39c, (q15_t)0x7ec8, (q15_t)0xf390, + (q15_t)0x7ec5, (q15_t)0xf384, (q15_t)0x7ec3, (q15_t)0xf377, (q15_t)0x7ec0, (q15_t)0xf36b, (q15_t)0x7ebe, (q15_t)0xf35f, + (q15_t)0x7ebb, (q15_t)0xf352, (q15_t)0x7eb9, (q15_t)0xf346, (q15_t)0x7eb6, (q15_t)0xf33a, (q15_t)0x7eb4, (q15_t)0xf32d, + (q15_t)0x7eb1, (q15_t)0xf321, (q15_t)0x7eaf, (q15_t)0xf315, (q15_t)0x7eac, (q15_t)0xf308, (q15_t)0x7eaa, (q15_t)0xf2fc, + (q15_t)0x7ea7, (q15_t)0xf2f0, (q15_t)0x7ea5, (q15_t)0xf2e4, (q15_t)0x7ea2, (q15_t)0xf2d7, (q15_t)0x7e9f, (q15_t)0xf2cb, + (q15_t)0x7e9d, (q15_t)0xf2bf, (q15_t)0x7e9a, (q15_t)0xf2b2, (q15_t)0x7e98, (q15_t)0xf2a6, (q15_t)0x7e95, (q15_t)0xf29a, + (q15_t)0x7e92, (q15_t)0xf28e, (q15_t)0x7e90, (q15_t)0xf281, (q15_t)0x7e8d, (q15_t)0xf275, (q15_t)0x7e8a, (q15_t)0xf269, + (q15_t)0x7e88, (q15_t)0xf25c, (q15_t)0x7e85, (q15_t)0xf250, (q15_t)0x7e82, (q15_t)0xf244, (q15_t)0x7e80, (q15_t)0xf238, + (q15_t)0x7e7d, (q15_t)0xf22b, (q15_t)0x7e7a, (q15_t)0xf21f, (q15_t)0x7e77, (q15_t)0xf213, (q15_t)0x7e75, (q15_t)0xf207, + (q15_t)0x7e72, (q15_t)0xf1fa, (q15_t)0x7e6f, (q15_t)0xf1ee, (q15_t)0x7e6c, (q15_t)0xf1e2, (q15_t)0x7e6a, (q15_t)0xf1d5, + (q15_t)0x7e67, (q15_t)0xf1c9, (q15_t)0x7e64, (q15_t)0xf1bd, (q15_t)0x7e61, (q15_t)0xf1b1, (q15_t)0x7e5e, (q15_t)0xf1a4, + (q15_t)0x7e5c, (q15_t)0xf198, (q15_t)0x7e59, (q15_t)0xf18c, (q15_t)0x7e56, (q15_t)0xf180, (q15_t)0x7e53, (q15_t)0xf174, + (q15_t)0x7e50, (q15_t)0xf167, (q15_t)0x7e4d, (q15_t)0xf15b, (q15_t)0x7e4a, (q15_t)0xf14f, (q15_t)0x7e48, (q15_t)0xf143, + (q15_t)0x7e45, (q15_t)0xf136, (q15_t)0x7e42, (q15_t)0xf12a, (q15_t)0x7e3f, (q15_t)0xf11e, (q15_t)0x7e3c, (q15_t)0xf112, + (q15_t)0x7e39, (q15_t)0xf105, (q15_t)0x7e36, (q15_t)0xf0f9, (q15_t)0x7e33, (q15_t)0xf0ed, (q15_t)0x7e30, (q15_t)0xf0e1, + (q15_t)0x7e2d, (q15_t)0xf0d5, (q15_t)0x7e2a, (q15_t)0xf0c8, (q15_t)0x7e27, (q15_t)0xf0bc, (q15_t)0x7e24, (q15_t)0xf0b0, + (q15_t)0x7e21, (q15_t)0xf0a4, (q15_t)0x7e1e, (q15_t)0xf098, (q15_t)0x7e1b, (q15_t)0xf08b, (q15_t)0x7e18, (q15_t)0xf07f, + (q15_t)0x7e15, (q15_t)0xf073, (q15_t)0x7e12, (q15_t)0xf067, (q15_t)0x7e0f, (q15_t)0xf05b, (q15_t)0x7e0c, (q15_t)0xf04e, + (q15_t)0x7e09, (q15_t)0xf042, (q15_t)0x7e06, (q15_t)0xf036, (q15_t)0x7e03, (q15_t)0xf02a, (q15_t)0x7dff, (q15_t)0xf01e, + (q15_t)0x7dfc, (q15_t)0xf012, (q15_t)0x7df9, (q15_t)0xf005, (q15_t)0x7df6, (q15_t)0xeff9, (q15_t)0x7df3, (q15_t)0xefed, + (q15_t)0x7df0, (q15_t)0xefe1, (q15_t)0x7ded, (q15_t)0xefd5, (q15_t)0x7de9, (q15_t)0xefc9, (q15_t)0x7de6, (q15_t)0xefbc, + (q15_t)0x7de3, (q15_t)0xefb0, (q15_t)0x7de0, (q15_t)0xefa4, (q15_t)0x7ddd, (q15_t)0xef98, (q15_t)0x7dd9, (q15_t)0xef8c, + (q15_t)0x7dd6, (q15_t)0xef80, (q15_t)0x7dd3, (q15_t)0xef74, (q15_t)0x7dd0, (q15_t)0xef67, (q15_t)0x7dcc, (q15_t)0xef5b, + (q15_t)0x7dc9, (q15_t)0xef4f, (q15_t)0x7dc6, (q15_t)0xef43, (q15_t)0x7dc2, (q15_t)0xef37, (q15_t)0x7dbf, (q15_t)0xef2b, + (q15_t)0x7dbc, (q15_t)0xef1f, (q15_t)0x7db9, (q15_t)0xef13, (q15_t)0x7db5, (q15_t)0xef06, (q15_t)0x7db2, (q15_t)0xeefa, + (q15_t)0x7daf, (q15_t)0xeeee, (q15_t)0x7dab, (q15_t)0xeee2, (q15_t)0x7da8, (q15_t)0xeed6, (q15_t)0x7da4, (q15_t)0xeeca, + (q15_t)0x7da1, (q15_t)0xeebe, (q15_t)0x7d9e, (q15_t)0xeeb2, (q15_t)0x7d9a, (q15_t)0xeea6, (q15_t)0x7d97, (q15_t)0xee99, + (q15_t)0x7d93, (q15_t)0xee8d, (q15_t)0x7d90, (q15_t)0xee81, (q15_t)0x7d8d, (q15_t)0xee75, (q15_t)0x7d89, (q15_t)0xee69, + (q15_t)0x7d86, (q15_t)0xee5d, (q15_t)0x7d82, (q15_t)0xee51, (q15_t)0x7d7f, (q15_t)0xee45, (q15_t)0x7d7b, (q15_t)0xee39, + (q15_t)0x7d78, (q15_t)0xee2d, (q15_t)0x7d74, (q15_t)0xee21, (q15_t)0x7d71, (q15_t)0xee15, (q15_t)0x7d6d, (q15_t)0xee09, + (q15_t)0x7d6a, (q15_t)0xedfc, (q15_t)0x7d66, (q15_t)0xedf0, (q15_t)0x7d63, (q15_t)0xede4, (q15_t)0x7d5f, (q15_t)0xedd8, + (q15_t)0x7d5b, (q15_t)0xedcc, (q15_t)0x7d58, (q15_t)0xedc0, (q15_t)0x7d54, (q15_t)0xedb4, (q15_t)0x7d51, (q15_t)0xeda8, + (q15_t)0x7d4d, (q15_t)0xed9c, (q15_t)0x7d49, (q15_t)0xed90, (q15_t)0x7d46, (q15_t)0xed84, (q15_t)0x7d42, (q15_t)0xed78, + (q15_t)0x7d3f, (q15_t)0xed6c, (q15_t)0x7d3b, (q15_t)0xed60, (q15_t)0x7d37, (q15_t)0xed54, (q15_t)0x7d34, (q15_t)0xed48, + (q15_t)0x7d30, (q15_t)0xed3c, (q15_t)0x7d2c, (q15_t)0xed30, (q15_t)0x7d28, (q15_t)0xed24, (q15_t)0x7d25, (q15_t)0xed18, + (q15_t)0x7d21, (q15_t)0xed0c, (q15_t)0x7d1d, (q15_t)0xed00, (q15_t)0x7d1a, (q15_t)0xecf4, (q15_t)0x7d16, (q15_t)0xece8, + (q15_t)0x7d12, (q15_t)0xecdc, (q15_t)0x7d0e, (q15_t)0xecd0, (q15_t)0x7d0b, (q15_t)0xecc4, (q15_t)0x7d07, (q15_t)0xecb8, + (q15_t)0x7d03, (q15_t)0xecac, (q15_t)0x7cff, (q15_t)0xeca0, (q15_t)0x7cfb, (q15_t)0xec94, (q15_t)0x7cf8, (q15_t)0xec88, + (q15_t)0x7cf4, (q15_t)0xec7c, (q15_t)0x7cf0, (q15_t)0xec70, (q15_t)0x7cec, (q15_t)0xec64, (q15_t)0x7ce8, (q15_t)0xec58, + (q15_t)0x7ce4, (q15_t)0xec4c, (q15_t)0x7ce0, (q15_t)0xec40, (q15_t)0x7cdd, (q15_t)0xec34, (q15_t)0x7cd9, (q15_t)0xec28, + (q15_t)0x7cd5, (q15_t)0xec1c, (q15_t)0x7cd1, (q15_t)0xec10, (q15_t)0x7ccd, (q15_t)0xec05, (q15_t)0x7cc9, (q15_t)0xebf9, + (q15_t)0x7cc5, (q15_t)0xebed, (q15_t)0x7cc1, (q15_t)0xebe1, (q15_t)0x7cbd, (q15_t)0xebd5, (q15_t)0x7cb9, (q15_t)0xebc9, + (q15_t)0x7cb5, (q15_t)0xebbd, (q15_t)0x7cb1, (q15_t)0xebb1, (q15_t)0x7cad, (q15_t)0xeba5, (q15_t)0x7ca9, (q15_t)0xeb99, + (q15_t)0x7ca5, (q15_t)0xeb8d, (q15_t)0x7ca1, (q15_t)0xeb81, (q15_t)0x7c9d, (q15_t)0xeb75, (q15_t)0x7c99, (q15_t)0xeb6a, + (q15_t)0x7c95, (q15_t)0xeb5e, (q15_t)0x7c91, (q15_t)0xeb52, (q15_t)0x7c8d, (q15_t)0xeb46, (q15_t)0x7c89, (q15_t)0xeb3a, + (q15_t)0x7c85, (q15_t)0xeb2e, (q15_t)0x7c81, (q15_t)0xeb22, (q15_t)0x7c7d, (q15_t)0xeb16, (q15_t)0x7c79, (q15_t)0xeb0a, + (q15_t)0x7c74, (q15_t)0xeaff, (q15_t)0x7c70, (q15_t)0xeaf3, (q15_t)0x7c6c, (q15_t)0xeae7, (q15_t)0x7c68, (q15_t)0xeadb, + (q15_t)0x7c64, (q15_t)0xeacf, (q15_t)0x7c60, (q15_t)0xeac3, (q15_t)0x7c5b, (q15_t)0xeab7, (q15_t)0x7c57, (q15_t)0xeaac, + (q15_t)0x7c53, (q15_t)0xeaa0, (q15_t)0x7c4f, (q15_t)0xea94, (q15_t)0x7c4b, (q15_t)0xea88, (q15_t)0x7c46, (q15_t)0xea7c, + (q15_t)0x7c42, (q15_t)0xea70, (q15_t)0x7c3e, (q15_t)0xea65, (q15_t)0x7c3a, (q15_t)0xea59, (q15_t)0x7c36, (q15_t)0xea4d, + (q15_t)0x7c31, (q15_t)0xea41, (q15_t)0x7c2d, (q15_t)0xea35, (q15_t)0x7c29, (q15_t)0xea29, (q15_t)0x7c24, (q15_t)0xea1e, + (q15_t)0x7c20, (q15_t)0xea12, (q15_t)0x7c1c, (q15_t)0xea06, (q15_t)0x7c17, (q15_t)0xe9fa, (q15_t)0x7c13, (q15_t)0xe9ee, + (q15_t)0x7c0f, (q15_t)0xe9e3, (q15_t)0x7c0a, (q15_t)0xe9d7, (q15_t)0x7c06, (q15_t)0xe9cb, (q15_t)0x7c02, (q15_t)0xe9bf, + (q15_t)0x7bfd, (q15_t)0xe9b4, (q15_t)0x7bf9, (q15_t)0xe9a8, (q15_t)0x7bf5, (q15_t)0xe99c, (q15_t)0x7bf0, (q15_t)0xe990, + (q15_t)0x7bec, (q15_t)0xe984, (q15_t)0x7be7, (q15_t)0xe979, (q15_t)0x7be3, (q15_t)0xe96d, (q15_t)0x7bde, (q15_t)0xe961, + (q15_t)0x7bda, (q15_t)0xe955, (q15_t)0x7bd6, (q15_t)0xe94a, (q15_t)0x7bd1, (q15_t)0xe93e, (q15_t)0x7bcd, (q15_t)0xe932, + (q15_t)0x7bc8, (q15_t)0xe926, (q15_t)0x7bc4, (q15_t)0xe91b, (q15_t)0x7bbf, (q15_t)0xe90f, (q15_t)0x7bbb, (q15_t)0xe903, + (q15_t)0x7bb6, (q15_t)0xe8f7, (q15_t)0x7bb2, (q15_t)0xe8ec, (q15_t)0x7bad, (q15_t)0xe8e0, (q15_t)0x7ba9, (q15_t)0xe8d4, + (q15_t)0x7ba4, (q15_t)0xe8c9, (q15_t)0x7b9f, (q15_t)0xe8bd, (q15_t)0x7b9b, (q15_t)0xe8b1, (q15_t)0x7b96, (q15_t)0xe8a5, + (q15_t)0x7b92, (q15_t)0xe89a, (q15_t)0x7b8d, (q15_t)0xe88e, (q15_t)0x7b88, (q15_t)0xe882, (q15_t)0x7b84, (q15_t)0xe877, + (q15_t)0x7b7f, (q15_t)0xe86b, (q15_t)0x7b7b, (q15_t)0xe85f, (q15_t)0x7b76, (q15_t)0xe854, (q15_t)0x7b71, (q15_t)0xe848, + (q15_t)0x7b6d, (q15_t)0xe83c, (q15_t)0x7b68, (q15_t)0xe831, (q15_t)0x7b63, (q15_t)0xe825, (q15_t)0x7b5f, (q15_t)0xe819, + (q15_t)0x7b5a, (q15_t)0xe80e, (q15_t)0x7b55, (q15_t)0xe802, (q15_t)0x7b50, (q15_t)0xe7f6, (q15_t)0x7b4c, (q15_t)0xe7eb, + (q15_t)0x7b47, (q15_t)0xe7df, (q15_t)0x7b42, (q15_t)0xe7d3, (q15_t)0x7b3e, (q15_t)0xe7c8, (q15_t)0x7b39, (q15_t)0xe7bc, + (q15_t)0x7b34, (q15_t)0xe7b1, (q15_t)0x7b2f, (q15_t)0xe7a5, (q15_t)0x7b2a, (q15_t)0xe799, (q15_t)0x7b26, (q15_t)0xe78e, + (q15_t)0x7b21, (q15_t)0xe782, (q15_t)0x7b1c, (q15_t)0xe777, (q15_t)0x7b17, (q15_t)0xe76b, (q15_t)0x7b12, (q15_t)0xe75f, + (q15_t)0x7b0e, (q15_t)0xe754, (q15_t)0x7b09, (q15_t)0xe748, (q15_t)0x7b04, (q15_t)0xe73d, (q15_t)0x7aff, (q15_t)0xe731, + (q15_t)0x7afa, (q15_t)0xe725, (q15_t)0x7af5, (q15_t)0xe71a, (q15_t)0x7af0, (q15_t)0xe70e, (q15_t)0x7aeb, (q15_t)0xe703, + (q15_t)0x7ae6, (q15_t)0xe6f7, (q15_t)0x7ae2, (q15_t)0xe6ec, (q15_t)0x7add, (q15_t)0xe6e0, (q15_t)0x7ad8, (q15_t)0xe6d4, + (q15_t)0x7ad3, (q15_t)0xe6c9, (q15_t)0x7ace, (q15_t)0xe6bd, (q15_t)0x7ac9, (q15_t)0xe6b2, (q15_t)0x7ac4, (q15_t)0xe6a6, + (q15_t)0x7abf, (q15_t)0xe69b, (q15_t)0x7aba, (q15_t)0xe68f, (q15_t)0x7ab5, (q15_t)0xe684, (q15_t)0x7ab0, (q15_t)0xe678, + (q15_t)0x7aab, (q15_t)0xe66d, (q15_t)0x7aa6, (q15_t)0xe661, (q15_t)0x7aa1, (q15_t)0xe656, (q15_t)0x7a9c, (q15_t)0xe64a, + (q15_t)0x7a97, (q15_t)0xe63f, (q15_t)0x7a92, (q15_t)0xe633, (q15_t)0x7a8d, (q15_t)0xe628, (q15_t)0x7a88, (q15_t)0xe61c, + (q15_t)0x7a82, (q15_t)0xe611, (q15_t)0x7a7d, (q15_t)0xe605, (q15_t)0x7a78, (q15_t)0xe5fa, (q15_t)0x7a73, (q15_t)0xe5ee, + (q15_t)0x7a6e, (q15_t)0xe5e3, (q15_t)0x7a69, (q15_t)0xe5d7, (q15_t)0x7a64, (q15_t)0xe5cc, (q15_t)0x7a5f, (q15_t)0xe5c0, + (q15_t)0x7a59, (q15_t)0xe5b5, (q15_t)0x7a54, (q15_t)0xe5a9, (q15_t)0x7a4f, (q15_t)0xe59e, (q15_t)0x7a4a, (q15_t)0xe592, + (q15_t)0x7a45, (q15_t)0xe587, (q15_t)0x7a3f, (q15_t)0xe57c, (q15_t)0x7a3a, (q15_t)0xe570, (q15_t)0x7a35, (q15_t)0xe565, + (q15_t)0x7a30, (q15_t)0xe559, (q15_t)0x7a2b, (q15_t)0xe54e, (q15_t)0x7a25, (q15_t)0xe542, (q15_t)0x7a20, (q15_t)0xe537, + (q15_t)0x7a1b, (q15_t)0xe52c, (q15_t)0x7a16, (q15_t)0xe520, (q15_t)0x7a10, (q15_t)0xe515, (q15_t)0x7a0b, (q15_t)0xe509, + (q15_t)0x7a06, (q15_t)0xe4fe, (q15_t)0x7a00, (q15_t)0xe4f3, (q15_t)0x79fb, (q15_t)0xe4e7, (q15_t)0x79f6, (q15_t)0xe4dc, + (q15_t)0x79f0, (q15_t)0xe4d0, (q15_t)0x79eb, (q15_t)0xe4c5, (q15_t)0x79e6, (q15_t)0xe4ba, (q15_t)0x79e0, (q15_t)0xe4ae, + (q15_t)0x79db, (q15_t)0xe4a3, (q15_t)0x79d6, (q15_t)0xe498, (q15_t)0x79d0, (q15_t)0xe48c, (q15_t)0x79cb, (q15_t)0xe481, + (q15_t)0x79c5, (q15_t)0xe476, (q15_t)0x79c0, (q15_t)0xe46a, (q15_t)0x79bb, (q15_t)0xe45f, (q15_t)0x79b5, (q15_t)0xe454, + (q15_t)0x79b0, (q15_t)0xe448, (q15_t)0x79aa, (q15_t)0xe43d, (q15_t)0x79a5, (q15_t)0xe432, (q15_t)0x799f, (q15_t)0xe426, + (q15_t)0x799a, (q15_t)0xe41b, (q15_t)0x7994, (q15_t)0xe410, (q15_t)0x798f, (q15_t)0xe404, (q15_t)0x7989, (q15_t)0xe3f9, + (q15_t)0x7984, (q15_t)0xe3ee, (q15_t)0x797e, (q15_t)0xe3e2, (q15_t)0x7979, (q15_t)0xe3d7, (q15_t)0x7973, (q15_t)0xe3cc, + (q15_t)0x796e, (q15_t)0xe3c1, (q15_t)0x7968, (q15_t)0xe3b5, (q15_t)0x7963, (q15_t)0xe3aa, (q15_t)0x795d, (q15_t)0xe39f, + (q15_t)0x7958, (q15_t)0xe394, (q15_t)0x7952, (q15_t)0xe388, (q15_t)0x794c, (q15_t)0xe37d, (q15_t)0x7947, (q15_t)0xe372, + (q15_t)0x7941, (q15_t)0xe367, (q15_t)0x793b, (q15_t)0xe35b, (q15_t)0x7936, (q15_t)0xe350, (q15_t)0x7930, (q15_t)0xe345, + (q15_t)0x792b, (q15_t)0xe33a, (q15_t)0x7925, (q15_t)0xe32e, (q15_t)0x791f, (q15_t)0xe323, (q15_t)0x791a, (q15_t)0xe318, + (q15_t)0x7914, (q15_t)0xe30d, (q15_t)0x790e, (q15_t)0xe301, (q15_t)0x7909, (q15_t)0xe2f6, (q15_t)0x7903, (q15_t)0xe2eb, + (q15_t)0x78fd, (q15_t)0xe2e0, (q15_t)0x78f7, (q15_t)0xe2d5, (q15_t)0x78f2, (q15_t)0xe2ca, (q15_t)0x78ec, (q15_t)0xe2be, + (q15_t)0x78e6, (q15_t)0xe2b3, (q15_t)0x78e0, (q15_t)0xe2a8, (q15_t)0x78db, (q15_t)0xe29d, (q15_t)0x78d5, (q15_t)0xe292, + (q15_t)0x78cf, (q15_t)0xe287, (q15_t)0x78c9, (q15_t)0xe27b, (q15_t)0x78c3, (q15_t)0xe270, (q15_t)0x78be, (q15_t)0xe265, + (q15_t)0x78b8, (q15_t)0xe25a, (q15_t)0x78b2, (q15_t)0xe24f, (q15_t)0x78ac, (q15_t)0xe244, (q15_t)0x78a6, (q15_t)0xe239, + (q15_t)0x78a1, (q15_t)0xe22d, (q15_t)0x789b, (q15_t)0xe222, (q15_t)0x7895, (q15_t)0xe217, (q15_t)0x788f, (q15_t)0xe20c, + (q15_t)0x7889, (q15_t)0xe201, (q15_t)0x7883, (q15_t)0xe1f6, (q15_t)0x787d, (q15_t)0xe1eb, (q15_t)0x7877, (q15_t)0xe1e0, + (q15_t)0x7871, (q15_t)0xe1d5, (q15_t)0x786b, (q15_t)0xe1ca, (q15_t)0x7866, (q15_t)0xe1be, (q15_t)0x7860, (q15_t)0xe1b3, + (q15_t)0x785a, (q15_t)0xe1a8, (q15_t)0x7854, (q15_t)0xe19d, (q15_t)0x784e, (q15_t)0xe192, (q15_t)0x7848, (q15_t)0xe187, + (q15_t)0x7842, (q15_t)0xe17c, (q15_t)0x783c, (q15_t)0xe171, (q15_t)0x7836, (q15_t)0xe166, (q15_t)0x7830, (q15_t)0xe15b, + (q15_t)0x782a, (q15_t)0xe150, (q15_t)0x7824, (q15_t)0xe145, (q15_t)0x781e, (q15_t)0xe13a, (q15_t)0x7818, (q15_t)0xe12f, + (q15_t)0x7812, (q15_t)0xe124, (q15_t)0x780b, (q15_t)0xe119, (q15_t)0x7805, (q15_t)0xe10e, (q15_t)0x77ff, (q15_t)0xe103, + (q15_t)0x77f9, (q15_t)0xe0f8, (q15_t)0x77f3, (q15_t)0xe0ed, (q15_t)0x77ed, (q15_t)0xe0e2, (q15_t)0x77e7, (q15_t)0xe0d7, + (q15_t)0x77e1, (q15_t)0xe0cc, (q15_t)0x77db, (q15_t)0xe0c1, (q15_t)0x77d5, (q15_t)0xe0b6, (q15_t)0x77ce, (q15_t)0xe0ab, + (q15_t)0x77c8, (q15_t)0xe0a0, (q15_t)0x77c2, (q15_t)0xe095, (q15_t)0x77bc, (q15_t)0xe08a, (q15_t)0x77b6, (q15_t)0xe07f, + (q15_t)0x77b0, (q15_t)0xe074, (q15_t)0x77a9, (q15_t)0xe069, (q15_t)0x77a3, (q15_t)0xe05e, (q15_t)0x779d, (q15_t)0xe054, + (q15_t)0x7797, (q15_t)0xe049, (q15_t)0x7790, (q15_t)0xe03e, (q15_t)0x778a, (q15_t)0xe033, (q15_t)0x7784, (q15_t)0xe028, + (q15_t)0x777e, (q15_t)0xe01d, (q15_t)0x7777, (q15_t)0xe012, (q15_t)0x7771, (q15_t)0xe007, (q15_t)0x776b, (q15_t)0xdffc, + (q15_t)0x7765, (q15_t)0xdff1, (q15_t)0x775e, (q15_t)0xdfe7, (q15_t)0x7758, (q15_t)0xdfdc, (q15_t)0x7752, (q15_t)0xdfd1, + (q15_t)0x774b, (q15_t)0xdfc6, (q15_t)0x7745, (q15_t)0xdfbb, (q15_t)0x773f, (q15_t)0xdfb0, (q15_t)0x7738, (q15_t)0xdfa5, + (q15_t)0x7732, (q15_t)0xdf9b, (q15_t)0x772c, (q15_t)0xdf90, (q15_t)0x7725, (q15_t)0xdf85, (q15_t)0x771f, (q15_t)0xdf7a, + (q15_t)0x7718, (q15_t)0xdf6f, (q15_t)0x7712, (q15_t)0xdf65, (q15_t)0x770c, (q15_t)0xdf5a, (q15_t)0x7705, (q15_t)0xdf4f, + (q15_t)0x76ff, (q15_t)0xdf44, (q15_t)0x76f8, (q15_t)0xdf39, (q15_t)0x76f2, (q15_t)0xdf2f, (q15_t)0x76eb, (q15_t)0xdf24, + (q15_t)0x76e5, (q15_t)0xdf19, (q15_t)0x76df, (q15_t)0xdf0e, (q15_t)0x76d8, (q15_t)0xdf03, (q15_t)0x76d2, (q15_t)0xdef9, + (q15_t)0x76cb, (q15_t)0xdeee, (q15_t)0x76c5, (q15_t)0xdee3, (q15_t)0x76be, (q15_t)0xded8, (q15_t)0x76b8, (q15_t)0xdece, + (q15_t)0x76b1, (q15_t)0xdec3, (q15_t)0x76ab, (q15_t)0xdeb8, (q15_t)0x76a4, (q15_t)0xdead, (q15_t)0x769d, (q15_t)0xdea3, + (q15_t)0x7697, (q15_t)0xde98, (q15_t)0x7690, (q15_t)0xde8d, (q15_t)0x768a, (q15_t)0xde83, (q15_t)0x7683, (q15_t)0xde78, + (q15_t)0x767d, (q15_t)0xde6d, (q15_t)0x7676, (q15_t)0xde62, (q15_t)0x766f, (q15_t)0xde58, (q15_t)0x7669, (q15_t)0xde4d, + (q15_t)0x7662, (q15_t)0xde42, (q15_t)0x765c, (q15_t)0xde38, (q15_t)0x7655, (q15_t)0xde2d, (q15_t)0x764e, (q15_t)0xde22, + (q15_t)0x7648, (q15_t)0xde18, (q15_t)0x7641, (q15_t)0xde0d, (q15_t)0x763a, (q15_t)0xde02, (q15_t)0x7634, (q15_t)0xddf8, + (q15_t)0x762d, (q15_t)0xdded, (q15_t)0x7626, (q15_t)0xdde2, (q15_t)0x7620, (q15_t)0xddd8, (q15_t)0x7619, (q15_t)0xddcd, + (q15_t)0x7612, (q15_t)0xddc3, (q15_t)0x760b, (q15_t)0xddb8, (q15_t)0x7605, (q15_t)0xddad, (q15_t)0x75fe, (q15_t)0xdda3, + (q15_t)0x75f7, (q15_t)0xdd98, (q15_t)0x75f0, (q15_t)0xdd8e, (q15_t)0x75ea, (q15_t)0xdd83, (q15_t)0x75e3, (q15_t)0xdd78, + (q15_t)0x75dc, (q15_t)0xdd6e, (q15_t)0x75d5, (q15_t)0xdd63, (q15_t)0x75ce, (q15_t)0xdd59, (q15_t)0x75c8, (q15_t)0xdd4e, + (q15_t)0x75c1, (q15_t)0xdd44, (q15_t)0x75ba, (q15_t)0xdd39, (q15_t)0x75b3, (q15_t)0xdd2e, (q15_t)0x75ac, (q15_t)0xdd24, + (q15_t)0x75a5, (q15_t)0xdd19, (q15_t)0x759f, (q15_t)0xdd0f, (q15_t)0x7598, (q15_t)0xdd04, (q15_t)0x7591, (q15_t)0xdcfa, + (q15_t)0x758a, (q15_t)0xdcef, (q15_t)0x7583, (q15_t)0xdce5, (q15_t)0x757c, (q15_t)0xdcda, (q15_t)0x7575, (q15_t)0xdcd0, + (q15_t)0x756e, (q15_t)0xdcc5, (q15_t)0x7567, (q15_t)0xdcbb, (q15_t)0x7561, (q15_t)0xdcb0, (q15_t)0x755a, (q15_t)0xdca6, + (q15_t)0x7553, (q15_t)0xdc9b, (q15_t)0x754c, (q15_t)0xdc91, (q15_t)0x7545, (q15_t)0xdc86, (q15_t)0x753e, (q15_t)0xdc7c, + (q15_t)0x7537, (q15_t)0xdc72, (q15_t)0x7530, (q15_t)0xdc67, (q15_t)0x7529, (q15_t)0xdc5d, (q15_t)0x7522, (q15_t)0xdc52, + (q15_t)0x751b, (q15_t)0xdc48, (q15_t)0x7514, (q15_t)0xdc3d, (q15_t)0x750d, (q15_t)0xdc33, (q15_t)0x7506, (q15_t)0xdc29, + (q15_t)0x74ff, (q15_t)0xdc1e, (q15_t)0x74f8, (q15_t)0xdc14, (q15_t)0x74f1, (q15_t)0xdc09, (q15_t)0x74ea, (q15_t)0xdbff, + (q15_t)0x74e2, (q15_t)0xdbf5, (q15_t)0x74db, (q15_t)0xdbea, (q15_t)0x74d4, (q15_t)0xdbe0, (q15_t)0x74cd, (q15_t)0xdbd5, + (q15_t)0x74c6, (q15_t)0xdbcb, (q15_t)0x74bf, (q15_t)0xdbc1, (q15_t)0x74b8, (q15_t)0xdbb6, (q15_t)0x74b1, (q15_t)0xdbac, + (q15_t)0x74aa, (q15_t)0xdba2, (q15_t)0x74a2, (q15_t)0xdb97, (q15_t)0x749b, (q15_t)0xdb8d, (q15_t)0x7494, (q15_t)0xdb83, + (q15_t)0x748d, (q15_t)0xdb78, (q15_t)0x7486, (q15_t)0xdb6e, (q15_t)0x747f, (q15_t)0xdb64, (q15_t)0x7477, (q15_t)0xdb59, + (q15_t)0x7470, (q15_t)0xdb4f, (q15_t)0x7469, (q15_t)0xdb45, (q15_t)0x7462, (q15_t)0xdb3b, (q15_t)0x745b, (q15_t)0xdb30, + (q15_t)0x7453, (q15_t)0xdb26, (q15_t)0x744c, (q15_t)0xdb1c, (q15_t)0x7445, (q15_t)0xdb11, (q15_t)0x743e, (q15_t)0xdb07, + (q15_t)0x7436, (q15_t)0xdafd, (q15_t)0x742f, (q15_t)0xdaf3, (q15_t)0x7428, (q15_t)0xdae8, (q15_t)0x7420, (q15_t)0xdade, + (q15_t)0x7419, (q15_t)0xdad4, (q15_t)0x7412, (q15_t)0xdaca, (q15_t)0x740b, (q15_t)0xdabf, (q15_t)0x7403, (q15_t)0xdab5, + (q15_t)0x73fc, (q15_t)0xdaab, (q15_t)0x73f5, (q15_t)0xdaa1, (q15_t)0x73ed, (q15_t)0xda97, (q15_t)0x73e6, (q15_t)0xda8c, + (q15_t)0x73df, (q15_t)0xda82, (q15_t)0x73d7, (q15_t)0xda78, (q15_t)0x73d0, (q15_t)0xda6e, (q15_t)0x73c8, (q15_t)0xda64, + (q15_t)0x73c1, (q15_t)0xda5a, (q15_t)0x73ba, (q15_t)0xda4f, (q15_t)0x73b2, (q15_t)0xda45, (q15_t)0x73ab, (q15_t)0xda3b, + (q15_t)0x73a3, (q15_t)0xda31, (q15_t)0x739c, (q15_t)0xda27, (q15_t)0x7395, (q15_t)0xda1d, (q15_t)0x738d, (q15_t)0xda13, + (q15_t)0x7386, (q15_t)0xda08, (q15_t)0x737e, (q15_t)0xd9fe, (q15_t)0x7377, (q15_t)0xd9f4, (q15_t)0x736f, (q15_t)0xd9ea, + (q15_t)0x7368, (q15_t)0xd9e0, (q15_t)0x7360, (q15_t)0xd9d6, (q15_t)0x7359, (q15_t)0xd9cc, (q15_t)0x7351, (q15_t)0xd9c2, + (q15_t)0x734a, (q15_t)0xd9b8, (q15_t)0x7342, (q15_t)0xd9ae, (q15_t)0x733b, (q15_t)0xd9a4, (q15_t)0x7333, (q15_t)0xd99a, + (q15_t)0x732c, (q15_t)0xd98f, (q15_t)0x7324, (q15_t)0xd985, (q15_t)0x731d, (q15_t)0xd97b, (q15_t)0x7315, (q15_t)0xd971, + (q15_t)0x730d, (q15_t)0xd967, (q15_t)0x7306, (q15_t)0xd95d, (q15_t)0x72fe, (q15_t)0xd953, (q15_t)0x72f7, (q15_t)0xd949, + (q15_t)0x72ef, (q15_t)0xd93f, (q15_t)0x72e7, (q15_t)0xd935, (q15_t)0x72e0, (q15_t)0xd92b, (q15_t)0x72d8, (q15_t)0xd921, + (q15_t)0x72d0, (q15_t)0xd917, (q15_t)0x72c9, (q15_t)0xd90d, (q15_t)0x72c1, (q15_t)0xd903, (q15_t)0x72ba, (q15_t)0xd8f9, + (q15_t)0x72b2, (q15_t)0xd8ef, (q15_t)0x72aa, (q15_t)0xd8e6, (q15_t)0x72a3, (q15_t)0xd8dc, (q15_t)0x729b, (q15_t)0xd8d2, + (q15_t)0x7293, (q15_t)0xd8c8, (q15_t)0x728b, (q15_t)0xd8be, (q15_t)0x7284, (q15_t)0xd8b4, (q15_t)0x727c, (q15_t)0xd8aa, + (q15_t)0x7274, (q15_t)0xd8a0, (q15_t)0x726d, (q15_t)0xd896, (q15_t)0x7265, (q15_t)0xd88c, (q15_t)0x725d, (q15_t)0xd882, + (q15_t)0x7255, (q15_t)0xd878, (q15_t)0x724e, (q15_t)0xd86f, (q15_t)0x7246, (q15_t)0xd865, (q15_t)0x723e, (q15_t)0xd85b, + (q15_t)0x7236, (q15_t)0xd851, (q15_t)0x722e, (q15_t)0xd847, (q15_t)0x7227, (q15_t)0xd83d, (q15_t)0x721f, (q15_t)0xd833, + (q15_t)0x7217, (q15_t)0xd82a, (q15_t)0x720f, (q15_t)0xd820, (q15_t)0x7207, (q15_t)0xd816, (q15_t)0x71ff, (q15_t)0xd80c, + (q15_t)0x71f8, (q15_t)0xd802, (q15_t)0x71f0, (q15_t)0xd7f8, (q15_t)0x71e8, (q15_t)0xd7ef, (q15_t)0x71e0, (q15_t)0xd7e5, + (q15_t)0x71d8, (q15_t)0xd7db, (q15_t)0x71d0, (q15_t)0xd7d1, (q15_t)0x71c8, (q15_t)0xd7c8, (q15_t)0x71c0, (q15_t)0xd7be, + (q15_t)0x71b9, (q15_t)0xd7b4, (q15_t)0x71b1, (q15_t)0xd7aa, (q15_t)0x71a9, (q15_t)0xd7a0, (q15_t)0x71a1, (q15_t)0xd797, + (q15_t)0x7199, (q15_t)0xd78d, (q15_t)0x7191, (q15_t)0xd783, (q15_t)0x7189, (q15_t)0xd77a, (q15_t)0x7181, (q15_t)0xd770, + (q15_t)0x7179, (q15_t)0xd766, (q15_t)0x7171, (q15_t)0xd75c, (q15_t)0x7169, (q15_t)0xd753, (q15_t)0x7161, (q15_t)0xd749, + (q15_t)0x7159, (q15_t)0xd73f, (q15_t)0x7151, (q15_t)0xd736, (q15_t)0x7149, (q15_t)0xd72c, (q15_t)0x7141, (q15_t)0xd722, + (q15_t)0x7139, (q15_t)0xd719, (q15_t)0x7131, (q15_t)0xd70f, (q15_t)0x7129, (q15_t)0xd705, (q15_t)0x7121, (q15_t)0xd6fc, + (q15_t)0x7119, (q15_t)0xd6f2, (q15_t)0x7111, (q15_t)0xd6e8, (q15_t)0x7109, (q15_t)0xd6df, (q15_t)0x7101, (q15_t)0xd6d5, + (q15_t)0x70f9, (q15_t)0xd6cb, (q15_t)0x70f0, (q15_t)0xd6c2, (q15_t)0x70e8, (q15_t)0xd6b8, (q15_t)0x70e0, (q15_t)0xd6af, + (q15_t)0x70d8, (q15_t)0xd6a5, (q15_t)0x70d0, (q15_t)0xd69b, (q15_t)0x70c8, (q15_t)0xd692, (q15_t)0x70c0, (q15_t)0xd688, + (q15_t)0x70b8, (q15_t)0xd67f, (q15_t)0x70af, (q15_t)0xd675, (q15_t)0x70a7, (q15_t)0xd66c, (q15_t)0x709f, (q15_t)0xd662, + (q15_t)0x7097, (q15_t)0xd659, (q15_t)0x708f, (q15_t)0xd64f, (q15_t)0x7087, (q15_t)0xd645, (q15_t)0x707e, (q15_t)0xd63c, + (q15_t)0x7076, (q15_t)0xd632, (q15_t)0x706e, (q15_t)0xd629, (q15_t)0x7066, (q15_t)0xd61f, (q15_t)0x705d, (q15_t)0xd616, + (q15_t)0x7055, (q15_t)0xd60c, (q15_t)0x704d, (q15_t)0xd603, (q15_t)0x7045, (q15_t)0xd5f9, (q15_t)0x703c, (q15_t)0xd5f0, + (q15_t)0x7034, (q15_t)0xd5e6, (q15_t)0x702c, (q15_t)0xd5dd, (q15_t)0x7024, (q15_t)0xd5d4, (q15_t)0x701b, (q15_t)0xd5ca, + (q15_t)0x7013, (q15_t)0xd5c1, (q15_t)0x700b, (q15_t)0xd5b7, (q15_t)0x7002, (q15_t)0xd5ae, (q15_t)0x6ffa, (q15_t)0xd5a4, + (q15_t)0x6ff2, (q15_t)0xd59b, (q15_t)0x6fea, (q15_t)0xd592, (q15_t)0x6fe1, (q15_t)0xd588, (q15_t)0x6fd9, (q15_t)0xd57f, + (q15_t)0x6fd0, (q15_t)0xd575, (q15_t)0x6fc8, (q15_t)0xd56c, (q15_t)0x6fc0, (q15_t)0xd563, (q15_t)0x6fb7, (q15_t)0xd559, + (q15_t)0x6faf, (q15_t)0xd550, (q15_t)0x6fa7, (q15_t)0xd547, (q15_t)0x6f9e, (q15_t)0xd53d, (q15_t)0x6f96, (q15_t)0xd534, + (q15_t)0x6f8d, (q15_t)0xd52a, (q15_t)0x6f85, (q15_t)0xd521, (q15_t)0x6f7d, (q15_t)0xd518, (q15_t)0x6f74, (q15_t)0xd50e, + (q15_t)0x6f6c, (q15_t)0xd505, (q15_t)0x6f63, (q15_t)0xd4fc, (q15_t)0x6f5b, (q15_t)0xd4f3, (q15_t)0x6f52, (q15_t)0xd4e9, + (q15_t)0x6f4a, (q15_t)0xd4e0, (q15_t)0x6f41, (q15_t)0xd4d7, (q15_t)0x6f39, (q15_t)0xd4cd, (q15_t)0x6f30, (q15_t)0xd4c4, + (q15_t)0x6f28, (q15_t)0xd4bb, (q15_t)0x6f20, (q15_t)0xd4b2, (q15_t)0x6f17, (q15_t)0xd4a8, (q15_t)0x6f0e, (q15_t)0xd49f, + (q15_t)0x6f06, (q15_t)0xd496, (q15_t)0x6efd, (q15_t)0xd48d, (q15_t)0x6ef5, (q15_t)0xd483, (q15_t)0x6eec, (q15_t)0xd47a, + (q15_t)0x6ee4, (q15_t)0xd471, (q15_t)0x6edb, (q15_t)0xd468, (q15_t)0x6ed3, (q15_t)0xd45f, (q15_t)0x6eca, (q15_t)0xd455, + (q15_t)0x6ec2, (q15_t)0xd44c, (q15_t)0x6eb9, (q15_t)0xd443, (q15_t)0x6eb0, (q15_t)0xd43a, (q15_t)0x6ea8, (q15_t)0xd431, + (q15_t)0x6e9f, (q15_t)0xd428, (q15_t)0x6e97, (q15_t)0xd41e, (q15_t)0x6e8e, (q15_t)0xd415, (q15_t)0x6e85, (q15_t)0xd40c, + (q15_t)0x6e7d, (q15_t)0xd403, (q15_t)0x6e74, (q15_t)0xd3fa, (q15_t)0x6e6b, (q15_t)0xd3f1, (q15_t)0x6e63, (q15_t)0xd3e8, + (q15_t)0x6e5a, (q15_t)0xd3df, (q15_t)0x6e51, (q15_t)0xd3d5, (q15_t)0x6e49, (q15_t)0xd3cc, (q15_t)0x6e40, (q15_t)0xd3c3, + (q15_t)0x6e37, (q15_t)0xd3ba, (q15_t)0x6e2f, (q15_t)0xd3b1, (q15_t)0x6e26, (q15_t)0xd3a8, (q15_t)0x6e1d, (q15_t)0xd39f, + (q15_t)0x6e15, (q15_t)0xd396, (q15_t)0x6e0c, (q15_t)0xd38d, (q15_t)0x6e03, (q15_t)0xd384, (q15_t)0x6dfa, (q15_t)0xd37b, + (q15_t)0x6df2, (q15_t)0xd372, (q15_t)0x6de9, (q15_t)0xd369, (q15_t)0x6de0, (q15_t)0xd360, (q15_t)0x6dd7, (q15_t)0xd357, + (q15_t)0x6dcf, (q15_t)0xd34e, (q15_t)0x6dc6, (q15_t)0xd345, (q15_t)0x6dbd, (q15_t)0xd33c, (q15_t)0x6db4, (q15_t)0xd333, + (q15_t)0x6dab, (q15_t)0xd32a, (q15_t)0x6da3, (q15_t)0xd321, (q15_t)0x6d9a, (q15_t)0xd318, (q15_t)0x6d91, (q15_t)0xd30f, + (q15_t)0x6d88, (q15_t)0xd306, (q15_t)0x6d7f, (q15_t)0xd2fd, (q15_t)0x6d76, (q15_t)0xd2f4, (q15_t)0x6d6e, (q15_t)0xd2eb, + (q15_t)0x6d65, (q15_t)0xd2e2, (q15_t)0x6d5c, (q15_t)0xd2d9, (q15_t)0x6d53, (q15_t)0xd2d1, (q15_t)0x6d4a, (q15_t)0xd2c8, + (q15_t)0x6d41, (q15_t)0xd2bf, (q15_t)0x6d38, (q15_t)0xd2b6, (q15_t)0x6d2f, (q15_t)0xd2ad, (q15_t)0x6d27, (q15_t)0xd2a4, + (q15_t)0x6d1e, (q15_t)0xd29b, (q15_t)0x6d15, (q15_t)0xd292, (q15_t)0x6d0c, (q15_t)0xd28a, (q15_t)0x6d03, (q15_t)0xd281, + (q15_t)0x6cfa, (q15_t)0xd278, (q15_t)0x6cf1, (q15_t)0xd26f, (q15_t)0x6ce8, (q15_t)0xd266, (q15_t)0x6cdf, (q15_t)0xd25d, + (q15_t)0x6cd6, (q15_t)0xd255, (q15_t)0x6ccd, (q15_t)0xd24c, (q15_t)0x6cc4, (q15_t)0xd243, (q15_t)0x6cbb, (q15_t)0xd23a, + (q15_t)0x6cb2, (q15_t)0xd231, (q15_t)0x6ca9, (q15_t)0xd229, (q15_t)0x6ca0, (q15_t)0xd220, (q15_t)0x6c97, (q15_t)0xd217, + (q15_t)0x6c8e, (q15_t)0xd20e, (q15_t)0x6c85, (q15_t)0xd206, (q15_t)0x6c7c, (q15_t)0xd1fd, (q15_t)0x6c73, (q15_t)0xd1f4, + (q15_t)0x6c6a, (q15_t)0xd1eb, (q15_t)0x6c61, (q15_t)0xd1e3, (q15_t)0x6c58, (q15_t)0xd1da, (q15_t)0x6c4f, (q15_t)0xd1d1, + (q15_t)0x6c46, (q15_t)0xd1c9, (q15_t)0x6c3d, (q15_t)0xd1c0, (q15_t)0x6c34, (q15_t)0xd1b7, (q15_t)0x6c2b, (q15_t)0xd1af, + (q15_t)0x6c21, (q15_t)0xd1a6, (q15_t)0x6c18, (q15_t)0xd19d, (q15_t)0x6c0f, (q15_t)0xd195, (q15_t)0x6c06, (q15_t)0xd18c, + (q15_t)0x6bfd, (q15_t)0xd183, (q15_t)0x6bf4, (q15_t)0xd17b, (q15_t)0x6beb, (q15_t)0xd172, (q15_t)0x6be2, (q15_t)0xd169, + (q15_t)0x6bd8, (q15_t)0xd161, (q15_t)0x6bcf, (q15_t)0xd158, (q15_t)0x6bc6, (q15_t)0xd150, (q15_t)0x6bbd, (q15_t)0xd147, + (q15_t)0x6bb4, (q15_t)0xd13e, (q15_t)0x6bab, (q15_t)0xd136, (q15_t)0x6ba1, (q15_t)0xd12d, (q15_t)0x6b98, (q15_t)0xd125, + (q15_t)0x6b8f, (q15_t)0xd11c, (q15_t)0x6b86, (q15_t)0xd114, (q15_t)0x6b7d, (q15_t)0xd10b, (q15_t)0x6b73, (q15_t)0xd103, + (q15_t)0x6b6a, (q15_t)0xd0fa, (q15_t)0x6b61, (q15_t)0xd0f2, (q15_t)0x6b58, (q15_t)0xd0e9, (q15_t)0x6b4e, (q15_t)0xd0e0, + (q15_t)0x6b45, (q15_t)0xd0d8, (q15_t)0x6b3c, (q15_t)0xd0d0, (q15_t)0x6b33, (q15_t)0xd0c7, (q15_t)0x6b29, (q15_t)0xd0bf, + (q15_t)0x6b20, (q15_t)0xd0b6, (q15_t)0x6b17, (q15_t)0xd0ae, (q15_t)0x6b0d, (q15_t)0xd0a5, (q15_t)0x6b04, (q15_t)0xd09d, + (q15_t)0x6afb, (q15_t)0xd094, (q15_t)0x6af2, (q15_t)0xd08c, (q15_t)0x6ae8, (q15_t)0xd083, (q15_t)0x6adf, (q15_t)0xd07b, + (q15_t)0x6ad6, (q15_t)0xd073, (q15_t)0x6acc, (q15_t)0xd06a, (q15_t)0x6ac3, (q15_t)0xd062, (q15_t)0x6ab9, (q15_t)0xd059, + (q15_t)0x6ab0, (q15_t)0xd051, (q15_t)0x6aa7, (q15_t)0xd049, (q15_t)0x6a9d, (q15_t)0xd040, (q15_t)0x6a94, (q15_t)0xd038, + (q15_t)0x6a8b, (q15_t)0xd030, (q15_t)0x6a81, (q15_t)0xd027, (q15_t)0x6a78, (q15_t)0xd01f, (q15_t)0x6a6e, (q15_t)0xd016, + (q15_t)0x6a65, (q15_t)0xd00e, (q15_t)0x6a5c, (q15_t)0xd006, (q15_t)0x6a52, (q15_t)0xcffe, (q15_t)0x6a49, (q15_t)0xcff5, + (q15_t)0x6a3f, (q15_t)0xcfed, (q15_t)0x6a36, (q15_t)0xcfe5, (q15_t)0x6a2c, (q15_t)0xcfdc, (q15_t)0x6a23, (q15_t)0xcfd4, + (q15_t)0x6a1a, (q15_t)0xcfcc, (q15_t)0x6a10, (q15_t)0xcfc4, (q15_t)0x6a07, (q15_t)0xcfbb, (q15_t)0x69fd, (q15_t)0xcfb3, + (q15_t)0x69f4, (q15_t)0xcfab, (q15_t)0x69ea, (q15_t)0xcfa3, (q15_t)0x69e1, (q15_t)0xcf9a, (q15_t)0x69d7, (q15_t)0xcf92, + (q15_t)0x69ce, (q15_t)0xcf8a, (q15_t)0x69c4, (q15_t)0xcf82, (q15_t)0x69bb, (q15_t)0xcf79, (q15_t)0x69b1, (q15_t)0xcf71, + (q15_t)0x69a7, (q15_t)0xcf69, (q15_t)0x699e, (q15_t)0xcf61, (q15_t)0x6994, (q15_t)0xcf59, (q15_t)0x698b, (q15_t)0xcf51, + (q15_t)0x6981, (q15_t)0xcf48, (q15_t)0x6978, (q15_t)0xcf40, (q15_t)0x696e, (q15_t)0xcf38, (q15_t)0x6965, (q15_t)0xcf30, + (q15_t)0x695b, (q15_t)0xcf28, (q15_t)0x6951, (q15_t)0xcf20, (q15_t)0x6948, (q15_t)0xcf18, (q15_t)0x693e, (q15_t)0xcf10, + (q15_t)0x6935, (q15_t)0xcf07, (q15_t)0x692b, (q15_t)0xceff, (q15_t)0x6921, (q15_t)0xcef7, (q15_t)0x6918, (q15_t)0xceef, + (q15_t)0x690e, (q15_t)0xcee7, (q15_t)0x6904, (q15_t)0xcedf, (q15_t)0x68fb, (q15_t)0xced7, (q15_t)0x68f1, (q15_t)0xcecf, + (q15_t)0x68e7, (q15_t)0xcec7, (q15_t)0x68de, (q15_t)0xcebf, (q15_t)0x68d4, (q15_t)0xceb7, (q15_t)0x68ca, (q15_t)0xceaf, + (q15_t)0x68c1, (q15_t)0xcea7, (q15_t)0x68b7, (q15_t)0xce9f, (q15_t)0x68ad, (q15_t)0xce97, (q15_t)0x68a4, (q15_t)0xce8f, + (q15_t)0x689a, (q15_t)0xce87, (q15_t)0x6890, (q15_t)0xce7f, (q15_t)0x6886, (q15_t)0xce77, (q15_t)0x687d, (q15_t)0xce6f, + (q15_t)0x6873, (q15_t)0xce67, (q15_t)0x6869, (q15_t)0xce5f, (q15_t)0x6860, (q15_t)0xce57, (q15_t)0x6856, (q15_t)0xce4f, + (q15_t)0x684c, (q15_t)0xce47, (q15_t)0x6842, (q15_t)0xce40, (q15_t)0x6838, (q15_t)0xce38, (q15_t)0x682f, (q15_t)0xce30, + (q15_t)0x6825, (q15_t)0xce28, (q15_t)0x681b, (q15_t)0xce20, (q15_t)0x6811, (q15_t)0xce18, (q15_t)0x6808, (q15_t)0xce10, + (q15_t)0x67fe, (q15_t)0xce08, (q15_t)0x67f4, (q15_t)0xce01, (q15_t)0x67ea, (q15_t)0xcdf9, (q15_t)0x67e0, (q15_t)0xcdf1, + (q15_t)0x67d6, (q15_t)0xcde9, (q15_t)0x67cd, (q15_t)0xcde1, (q15_t)0x67c3, (q15_t)0xcdd9, (q15_t)0x67b9, (q15_t)0xcdd2, + (q15_t)0x67af, (q15_t)0xcdca, (q15_t)0x67a5, (q15_t)0xcdc2, (q15_t)0x679b, (q15_t)0xcdba, (q15_t)0x6791, (q15_t)0xcdb2, + (q15_t)0x6788, (q15_t)0xcdab, (q15_t)0x677e, (q15_t)0xcda3, (q15_t)0x6774, (q15_t)0xcd9b, (q15_t)0x676a, (q15_t)0xcd93, + (q15_t)0x6760, (q15_t)0xcd8c, (q15_t)0x6756, (q15_t)0xcd84, (q15_t)0x674c, (q15_t)0xcd7c, (q15_t)0x6742, (q15_t)0xcd75, + (q15_t)0x6738, (q15_t)0xcd6d, (q15_t)0x672e, (q15_t)0xcd65, (q15_t)0x6724, (q15_t)0xcd5d, (q15_t)0x671a, (q15_t)0xcd56, + (q15_t)0x6711, (q15_t)0xcd4e, (q15_t)0x6707, (q15_t)0xcd46, (q15_t)0x66fd, (q15_t)0xcd3f, (q15_t)0x66f3, (q15_t)0xcd37, + (q15_t)0x66e9, (q15_t)0xcd30, (q15_t)0x66df, (q15_t)0xcd28, (q15_t)0x66d5, (q15_t)0xcd20, (q15_t)0x66cb, (q15_t)0xcd19, + (q15_t)0x66c1, (q15_t)0xcd11, (q15_t)0x66b7, (q15_t)0xcd09, (q15_t)0x66ad, (q15_t)0xcd02, (q15_t)0x66a3, (q15_t)0xccfa, + (q15_t)0x6699, (q15_t)0xccf3, (q15_t)0x668f, (q15_t)0xcceb, (q15_t)0x6685, (q15_t)0xcce3, (q15_t)0x667b, (q15_t)0xccdc, + (q15_t)0x6671, (q15_t)0xccd4, (q15_t)0x6666, (q15_t)0xcccd, (q15_t)0x665c, (q15_t)0xccc5, (q15_t)0x6652, (q15_t)0xccbe, + (q15_t)0x6648, (q15_t)0xccb6, (q15_t)0x663e, (q15_t)0xccaf, (q15_t)0x6634, (q15_t)0xcca7, (q15_t)0x662a, (q15_t)0xcca0, + (q15_t)0x6620, (q15_t)0xcc98, (q15_t)0x6616, (q15_t)0xcc91, (q15_t)0x660c, (q15_t)0xcc89, (q15_t)0x6602, (q15_t)0xcc82, + (q15_t)0x65f8, (q15_t)0xcc7a, (q15_t)0x65ed, (q15_t)0xcc73, (q15_t)0x65e3, (q15_t)0xcc6b, (q15_t)0x65d9, (q15_t)0xcc64, + (q15_t)0x65cf, (q15_t)0xcc5d, (q15_t)0x65c5, (q15_t)0xcc55, (q15_t)0x65bb, (q15_t)0xcc4e, (q15_t)0x65b1, (q15_t)0xcc46, + (q15_t)0x65a6, (q15_t)0xcc3f, (q15_t)0x659c, (q15_t)0xcc38, (q15_t)0x6592, (q15_t)0xcc30, (q15_t)0x6588, (q15_t)0xcc29, + (q15_t)0x657e, (q15_t)0xcc21, (q15_t)0x6574, (q15_t)0xcc1a, (q15_t)0x6569, (q15_t)0xcc13, (q15_t)0x655f, (q15_t)0xcc0b, + (q15_t)0x6555, (q15_t)0xcc04, (q15_t)0x654b, (q15_t)0xcbfd, (q15_t)0x6541, (q15_t)0xcbf5, (q15_t)0x6536, (q15_t)0xcbee, + (q15_t)0x652c, (q15_t)0xcbe7, (q15_t)0x6522, (q15_t)0xcbe0, (q15_t)0x6518, (q15_t)0xcbd8, (q15_t)0x650d, (q15_t)0xcbd1, + (q15_t)0x6503, (q15_t)0xcbca, (q15_t)0x64f9, (q15_t)0xcbc2, (q15_t)0x64ef, (q15_t)0xcbbb, (q15_t)0x64e4, (q15_t)0xcbb4, + (q15_t)0x64da, (q15_t)0xcbad, (q15_t)0x64d0, (q15_t)0xcba5, (q15_t)0x64c5, (q15_t)0xcb9e, (q15_t)0x64bb, (q15_t)0xcb97, + (q15_t)0x64b1, (q15_t)0xcb90, (q15_t)0x64a7, (q15_t)0xcb89, (q15_t)0x649c, (q15_t)0xcb81, (q15_t)0x6492, (q15_t)0xcb7a, + (q15_t)0x6488, (q15_t)0xcb73, (q15_t)0x647d, (q15_t)0xcb6c, (q15_t)0x6473, (q15_t)0xcb65, (q15_t)0x6469, (q15_t)0xcb5e, + (q15_t)0x645e, (q15_t)0xcb56, (q15_t)0x6454, (q15_t)0xcb4f, (q15_t)0x644a, (q15_t)0xcb48, (q15_t)0x643f, (q15_t)0xcb41, + (q15_t)0x6435, (q15_t)0xcb3a, (q15_t)0x642b, (q15_t)0xcb33, (q15_t)0x6420, (q15_t)0xcb2c, (q15_t)0x6416, (q15_t)0xcb25, + (q15_t)0x640b, (q15_t)0xcb1e, (q15_t)0x6401, (q15_t)0xcb16, (q15_t)0x63f7, (q15_t)0xcb0f, (q15_t)0x63ec, (q15_t)0xcb08, + (q15_t)0x63e2, (q15_t)0xcb01, (q15_t)0x63d7, (q15_t)0xcafa, (q15_t)0x63cd, (q15_t)0xcaf3, (q15_t)0x63c3, (q15_t)0xcaec, + (q15_t)0x63b8, (q15_t)0xcae5, (q15_t)0x63ae, (q15_t)0xcade, (q15_t)0x63a3, (q15_t)0xcad7, (q15_t)0x6399, (q15_t)0xcad0, + (q15_t)0x638e, (q15_t)0xcac9, (q15_t)0x6384, (q15_t)0xcac2, (q15_t)0x637a, (q15_t)0xcabb, (q15_t)0x636f, (q15_t)0xcab4, + (q15_t)0x6365, (q15_t)0xcaad, (q15_t)0x635a, (q15_t)0xcaa6, (q15_t)0x6350, (q15_t)0xca9f, (q15_t)0x6345, (q15_t)0xca99, + (q15_t)0x633b, (q15_t)0xca92, (q15_t)0x6330, (q15_t)0xca8b, (q15_t)0x6326, (q15_t)0xca84, (q15_t)0x631b, (q15_t)0xca7d, + (q15_t)0x6311, (q15_t)0xca76, (q15_t)0x6306, (q15_t)0xca6f, (q15_t)0x62fc, (q15_t)0xca68, (q15_t)0x62f1, (q15_t)0xca61, + (q15_t)0x62e7, (q15_t)0xca5b, (q15_t)0x62dc, (q15_t)0xca54, (q15_t)0x62d2, (q15_t)0xca4d, (q15_t)0x62c7, (q15_t)0xca46, + (q15_t)0x62bc, (q15_t)0xca3f, (q15_t)0x62b2, (q15_t)0xca38, (q15_t)0x62a7, (q15_t)0xca32, (q15_t)0x629d, (q15_t)0xca2b, + (q15_t)0x6292, (q15_t)0xca24, (q15_t)0x6288, (q15_t)0xca1d, (q15_t)0x627d, (q15_t)0xca16, (q15_t)0x6272, (q15_t)0xca10, + (q15_t)0x6268, (q15_t)0xca09, (q15_t)0x625d, (q15_t)0xca02, (q15_t)0x6253, (q15_t)0xc9fb, (q15_t)0x6248, (q15_t)0xc9f5, + (q15_t)0x623d, (q15_t)0xc9ee, (q15_t)0x6233, (q15_t)0xc9e7, (q15_t)0x6228, (q15_t)0xc9e0, (q15_t)0x621e, (q15_t)0xc9da, + (q15_t)0x6213, (q15_t)0xc9d3, (q15_t)0x6208, (q15_t)0xc9cc, (q15_t)0x61fe, (q15_t)0xc9c6, (q15_t)0x61f3, (q15_t)0xc9bf, + (q15_t)0x61e8, (q15_t)0xc9b8, (q15_t)0x61de, (q15_t)0xc9b2, (q15_t)0x61d3, (q15_t)0xc9ab, (q15_t)0x61c8, (q15_t)0xc9a4, + (q15_t)0x61be, (q15_t)0xc99e, (q15_t)0x61b3, (q15_t)0xc997, (q15_t)0x61a8, (q15_t)0xc991, (q15_t)0x619e, (q15_t)0xc98a, + (q15_t)0x6193, (q15_t)0xc983, (q15_t)0x6188, (q15_t)0xc97d, (q15_t)0x617d, (q15_t)0xc976, (q15_t)0x6173, (q15_t)0xc970, + (q15_t)0x6168, (q15_t)0xc969, (q15_t)0x615d, (q15_t)0xc963, (q15_t)0x6153, (q15_t)0xc95c, (q15_t)0x6148, (q15_t)0xc955, + (q15_t)0x613d, (q15_t)0xc94f, (q15_t)0x6132, (q15_t)0xc948, (q15_t)0x6128, (q15_t)0xc942, (q15_t)0x611d, (q15_t)0xc93b, + (q15_t)0x6112, (q15_t)0xc935, (q15_t)0x6107, (q15_t)0xc92e, (q15_t)0x60fd, (q15_t)0xc928, (q15_t)0x60f2, (q15_t)0xc921, + (q15_t)0x60e7, (q15_t)0xc91b, (q15_t)0x60dc, (q15_t)0xc915, (q15_t)0x60d1, (q15_t)0xc90e, (q15_t)0x60c7, (q15_t)0xc908, + (q15_t)0x60bc, (q15_t)0xc901, (q15_t)0x60b1, (q15_t)0xc8fb, (q15_t)0x60a6, (q15_t)0xc8f4, (q15_t)0x609b, (q15_t)0xc8ee, + (q15_t)0x6091, (q15_t)0xc8e8, (q15_t)0x6086, (q15_t)0xc8e1, (q15_t)0x607b, (q15_t)0xc8db, (q15_t)0x6070, (q15_t)0xc8d4, + (q15_t)0x6065, (q15_t)0xc8ce, (q15_t)0x605b, (q15_t)0xc8c8, (q15_t)0x6050, (q15_t)0xc8c1, (q15_t)0x6045, (q15_t)0xc8bb, + (q15_t)0x603a, (q15_t)0xc8b5, (q15_t)0x602f, (q15_t)0xc8ae, (q15_t)0x6024, (q15_t)0xc8a8, (q15_t)0x6019, (q15_t)0xc8a2, + (q15_t)0x600f, (q15_t)0xc89b, (q15_t)0x6004, (q15_t)0xc895, (q15_t)0x5ff9, (q15_t)0xc88f, (q15_t)0x5fee, (q15_t)0xc889, + (q15_t)0x5fe3, (q15_t)0xc882, (q15_t)0x5fd8, (q15_t)0xc87c, (q15_t)0x5fcd, (q15_t)0xc876, (q15_t)0x5fc2, (q15_t)0xc870, + (q15_t)0x5fb7, (q15_t)0xc869, (q15_t)0x5fac, (q15_t)0xc863, (q15_t)0x5fa2, (q15_t)0xc85d, (q15_t)0x5f97, (q15_t)0xc857, + (q15_t)0x5f8c, (q15_t)0xc850, (q15_t)0x5f81, (q15_t)0xc84a, (q15_t)0x5f76, (q15_t)0xc844, (q15_t)0x5f6b, (q15_t)0xc83e, + (q15_t)0x5f60, (q15_t)0xc838, (q15_t)0x5f55, (q15_t)0xc832, (q15_t)0x5f4a, (q15_t)0xc82b, (q15_t)0x5f3f, (q15_t)0xc825, + (q15_t)0x5f34, (q15_t)0xc81f, (q15_t)0x5f29, (q15_t)0xc819, (q15_t)0x5f1e, (q15_t)0xc813, (q15_t)0x5f13, (q15_t)0xc80d, + (q15_t)0x5f08, (q15_t)0xc807, (q15_t)0x5efd, (q15_t)0xc801, (q15_t)0x5ef2, (q15_t)0xc7fb, (q15_t)0x5ee7, (q15_t)0xc7f5, + (q15_t)0x5edc, (q15_t)0xc7ee, (q15_t)0x5ed1, (q15_t)0xc7e8, (q15_t)0x5ec6, (q15_t)0xc7e2, (q15_t)0x5ebb, (q15_t)0xc7dc, + (q15_t)0x5eb0, (q15_t)0xc7d6, (q15_t)0x5ea5, (q15_t)0xc7d0, (q15_t)0x5e9a, (q15_t)0xc7ca, (q15_t)0x5e8f, (q15_t)0xc7c4, + (q15_t)0x5e84, (q15_t)0xc7be, (q15_t)0x5e79, (q15_t)0xc7b8, (q15_t)0x5e6e, (q15_t)0xc7b2, (q15_t)0x5e63, (q15_t)0xc7ac, + (q15_t)0x5e58, (q15_t)0xc7a6, (q15_t)0x5e4d, (q15_t)0xc7a0, (q15_t)0x5e42, (q15_t)0xc79a, (q15_t)0x5e36, (q15_t)0xc795, + (q15_t)0x5e2b, (q15_t)0xc78f, (q15_t)0x5e20, (q15_t)0xc789, (q15_t)0x5e15, (q15_t)0xc783, (q15_t)0x5e0a, (q15_t)0xc77d, + (q15_t)0x5dff, (q15_t)0xc777, (q15_t)0x5df4, (q15_t)0xc771, (q15_t)0x5de9, (q15_t)0xc76b, (q15_t)0x5dde, (q15_t)0xc765, + (q15_t)0x5dd3, (q15_t)0xc75f, (q15_t)0x5dc7, (q15_t)0xc75a, (q15_t)0x5dbc, (q15_t)0xc754, (q15_t)0x5db1, (q15_t)0xc74e, + (q15_t)0x5da6, (q15_t)0xc748, (q15_t)0x5d9b, (q15_t)0xc742, (q15_t)0x5d90, (q15_t)0xc73d, (q15_t)0x5d85, (q15_t)0xc737, + (q15_t)0x5d79, (q15_t)0xc731, (q15_t)0x5d6e, (q15_t)0xc72b, (q15_t)0x5d63, (q15_t)0xc725, (q15_t)0x5d58, (q15_t)0xc720, + (q15_t)0x5d4d, (q15_t)0xc71a, (q15_t)0x5d42, (q15_t)0xc714, (q15_t)0x5d36, (q15_t)0xc70e, (q15_t)0x5d2b, (q15_t)0xc709, + (q15_t)0x5d20, (q15_t)0xc703, (q15_t)0x5d15, (q15_t)0xc6fd, (q15_t)0x5d0a, (q15_t)0xc6f7, (q15_t)0x5cff, (q15_t)0xc6f2, + (q15_t)0x5cf3, (q15_t)0xc6ec, (q15_t)0x5ce8, (q15_t)0xc6e6, (q15_t)0x5cdd, (q15_t)0xc6e1, (q15_t)0x5cd2, (q15_t)0xc6db, + (q15_t)0x5cc6, (q15_t)0xc6d5, (q15_t)0x5cbb, (q15_t)0xc6d0, (q15_t)0x5cb0, (q15_t)0xc6ca, (q15_t)0x5ca5, (q15_t)0xc6c5, + (q15_t)0x5c99, (q15_t)0xc6bf, (q15_t)0x5c8e, (q15_t)0xc6b9, (q15_t)0x5c83, (q15_t)0xc6b4, (q15_t)0x5c78, (q15_t)0xc6ae, + (q15_t)0x5c6c, (q15_t)0xc6a8, (q15_t)0x5c61, (q15_t)0xc6a3, (q15_t)0x5c56, (q15_t)0xc69d, (q15_t)0x5c4b, (q15_t)0xc698, + (q15_t)0x5c3f, (q15_t)0xc692, (q15_t)0x5c34, (q15_t)0xc68d, (q15_t)0x5c29, (q15_t)0xc687, (q15_t)0x5c1e, (q15_t)0xc682, + (q15_t)0x5c12, (q15_t)0xc67c, (q15_t)0x5c07, (q15_t)0xc677, (q15_t)0x5bfc, (q15_t)0xc671, (q15_t)0x5bf0, (q15_t)0xc66c, + (q15_t)0x5be5, (q15_t)0xc666, (q15_t)0x5bda, (q15_t)0xc661, (q15_t)0x5bce, (q15_t)0xc65b, (q15_t)0x5bc3, (q15_t)0xc656, + (q15_t)0x5bb8, (q15_t)0xc650, (q15_t)0x5bac, (q15_t)0xc64b, (q15_t)0x5ba1, (q15_t)0xc645, (q15_t)0x5b96, (q15_t)0xc640, + (q15_t)0x5b8a, (q15_t)0xc63b, (q15_t)0x5b7f, (q15_t)0xc635, (q15_t)0x5b74, (q15_t)0xc630, (q15_t)0x5b68, (q15_t)0xc62a, + (q15_t)0x5b5d, (q15_t)0xc625, (q15_t)0x5b52, (q15_t)0xc620, (q15_t)0x5b46, (q15_t)0xc61a, (q15_t)0x5b3b, (q15_t)0xc615, + (q15_t)0x5b30, (q15_t)0xc610, (q15_t)0x5b24, (q15_t)0xc60a, (q15_t)0x5b19, (q15_t)0xc605, (q15_t)0x5b0d, (q15_t)0xc600, + (q15_t)0x5b02, (q15_t)0xc5fa, (q15_t)0x5af7, (q15_t)0xc5f5, (q15_t)0x5aeb, (q15_t)0xc5f0, (q15_t)0x5ae0, (q15_t)0xc5ea, + (q15_t)0x5ad4, (q15_t)0xc5e5, (q15_t)0x5ac9, (q15_t)0xc5e0, (q15_t)0x5abe, (q15_t)0xc5db, (q15_t)0x5ab2, (q15_t)0xc5d5, + (q15_t)0x5aa7, (q15_t)0xc5d0, (q15_t)0x5a9b, (q15_t)0xc5cb, (q15_t)0x5a90, (q15_t)0xc5c6, (q15_t)0x5a84, (q15_t)0xc5c1, + (q15_t)0x5a79, (q15_t)0xc5bb, (q15_t)0x5a6e, (q15_t)0xc5b6, (q15_t)0x5a62, (q15_t)0xc5b1, (q15_t)0x5a57, (q15_t)0xc5ac, + (q15_t)0x5a4b, (q15_t)0xc5a7, (q15_t)0x5a40, (q15_t)0xc5a1, (q15_t)0x5a34, (q15_t)0xc59c, (q15_t)0x5a29, (q15_t)0xc597, + (q15_t)0x5a1d, (q15_t)0xc592, (q15_t)0x5a12, (q15_t)0xc58d, (q15_t)0x5a06, (q15_t)0xc588, (q15_t)0x59fb, (q15_t)0xc583, + (q15_t)0x59ef, (q15_t)0xc57e, (q15_t)0x59e4, (q15_t)0xc578, (q15_t)0x59d8, (q15_t)0xc573, (q15_t)0x59cd, (q15_t)0xc56e, + (q15_t)0x59c1, (q15_t)0xc569, (q15_t)0x59b6, (q15_t)0xc564, (q15_t)0x59aa, (q15_t)0xc55f, (q15_t)0x599f, (q15_t)0xc55a, + (q15_t)0x5993, (q15_t)0xc555, (q15_t)0x5988, (q15_t)0xc550, (q15_t)0x597c, (q15_t)0xc54b, (q15_t)0x5971, (q15_t)0xc546, + (q15_t)0x5965, (q15_t)0xc541, (q15_t)0x595a, (q15_t)0xc53c, (q15_t)0x594e, (q15_t)0xc537, (q15_t)0x5943, (q15_t)0xc532, + (q15_t)0x5937, (q15_t)0xc52d, (q15_t)0x592c, (q15_t)0xc528, (q15_t)0x5920, (q15_t)0xc523, (q15_t)0x5914, (q15_t)0xc51e, + (q15_t)0x5909, (q15_t)0xc51a, (q15_t)0x58fd, (q15_t)0xc515, (q15_t)0x58f2, (q15_t)0xc510, (q15_t)0x58e6, (q15_t)0xc50b, + (q15_t)0x58db, (q15_t)0xc506, (q15_t)0x58cf, (q15_t)0xc501, (q15_t)0x58c3, (q15_t)0xc4fc, (q15_t)0x58b8, (q15_t)0xc4f7, + (q15_t)0x58ac, (q15_t)0xc4f2, (q15_t)0x58a1, (q15_t)0xc4ee, (q15_t)0x5895, (q15_t)0xc4e9, (q15_t)0x5889, (q15_t)0xc4e4, + (q15_t)0x587e, (q15_t)0xc4df, (q15_t)0x5872, (q15_t)0xc4da, (q15_t)0x5867, (q15_t)0xc4d6, (q15_t)0x585b, (q15_t)0xc4d1, + (q15_t)0x584f, (q15_t)0xc4cc, (q15_t)0x5844, (q15_t)0xc4c7, (q15_t)0x5838, (q15_t)0xc4c2, (q15_t)0x582d, (q15_t)0xc4be, + (q15_t)0x5821, (q15_t)0xc4b9, (q15_t)0x5815, (q15_t)0xc4b4, (q15_t)0x580a, (q15_t)0xc4b0, (q15_t)0x57fe, (q15_t)0xc4ab, + (q15_t)0x57f2, (q15_t)0xc4a6, (q15_t)0x57e7, (q15_t)0xc4a1, (q15_t)0x57db, (q15_t)0xc49d, (q15_t)0x57cf, (q15_t)0xc498, + (q15_t)0x57c4, (q15_t)0xc493, (q15_t)0x57b8, (q15_t)0xc48f, (q15_t)0x57ac, (q15_t)0xc48a, (q15_t)0x57a1, (q15_t)0xc485, + (q15_t)0x5795, (q15_t)0xc481, (q15_t)0x5789, (q15_t)0xc47c, (q15_t)0x577e, (q15_t)0xc478, (q15_t)0x5772, (q15_t)0xc473, + (q15_t)0x5766, (q15_t)0xc46e, (q15_t)0x575b, (q15_t)0xc46a, (q15_t)0x574f, (q15_t)0xc465, (q15_t)0x5743, (q15_t)0xc461, + (q15_t)0x5737, (q15_t)0xc45c, (q15_t)0x572c, (q15_t)0xc457, (q15_t)0x5720, (q15_t)0xc453, (q15_t)0x5714, (q15_t)0xc44e, + (q15_t)0x5709, (q15_t)0xc44a, (q15_t)0x56fd, (q15_t)0xc445, (q15_t)0x56f1, (q15_t)0xc441, (q15_t)0x56e5, (q15_t)0xc43c, + (q15_t)0x56da, (q15_t)0xc438, (q15_t)0x56ce, (q15_t)0xc433, (q15_t)0x56c2, (q15_t)0xc42f, (q15_t)0x56b6, (q15_t)0xc42a, + (q15_t)0x56ab, (q15_t)0xc426, (q15_t)0x569f, (q15_t)0xc422, (q15_t)0x5693, (q15_t)0xc41d, (q15_t)0x5687, (q15_t)0xc419, + (q15_t)0x567c, (q15_t)0xc414, (q15_t)0x5670, (q15_t)0xc410, (q15_t)0x5664, (q15_t)0xc40b, (q15_t)0x5658, (q15_t)0xc407, + (q15_t)0x564c, (q15_t)0xc403, (q15_t)0x5641, (q15_t)0xc3fe, (q15_t)0x5635, (q15_t)0xc3fa, (q15_t)0x5629, (q15_t)0xc3f6, + (q15_t)0x561d, (q15_t)0xc3f1, (q15_t)0x5612, (q15_t)0xc3ed, (q15_t)0x5606, (q15_t)0xc3e9, (q15_t)0x55fa, (q15_t)0xc3e4, + (q15_t)0x55ee, (q15_t)0xc3e0, (q15_t)0x55e2, (q15_t)0xc3dc, (q15_t)0x55d7, (q15_t)0xc3d7, (q15_t)0x55cb, (q15_t)0xc3d3, + (q15_t)0x55bf, (q15_t)0xc3cf, (q15_t)0x55b3, (q15_t)0xc3ca, (q15_t)0x55a7, (q15_t)0xc3c6, (q15_t)0x559b, (q15_t)0xc3c2, + (q15_t)0x5590, (q15_t)0xc3be, (q15_t)0x5584, (q15_t)0xc3ba, (q15_t)0x5578, (q15_t)0xc3b5, (q15_t)0x556c, (q15_t)0xc3b1, + (q15_t)0x5560, (q15_t)0xc3ad, (q15_t)0x5554, (q15_t)0xc3a9, (q15_t)0x5549, (q15_t)0xc3a5, (q15_t)0x553d, (q15_t)0xc3a0, + (q15_t)0x5531, (q15_t)0xc39c, (q15_t)0x5525, (q15_t)0xc398, (q15_t)0x5519, (q15_t)0xc394, (q15_t)0x550d, (q15_t)0xc390, + (q15_t)0x5501, (q15_t)0xc38c, (q15_t)0x54f6, (q15_t)0xc387, (q15_t)0x54ea, (q15_t)0xc383, (q15_t)0x54de, (q15_t)0xc37f, + (q15_t)0x54d2, (q15_t)0xc37b, (q15_t)0x54c6, (q15_t)0xc377, (q15_t)0x54ba, (q15_t)0xc373, (q15_t)0x54ae, (q15_t)0xc36f, + (q15_t)0x54a2, (q15_t)0xc36b, (q15_t)0x5496, (q15_t)0xc367, (q15_t)0x548b, (q15_t)0xc363, (q15_t)0x547f, (q15_t)0xc35f, + (q15_t)0x5473, (q15_t)0xc35b, (q15_t)0x5467, (q15_t)0xc357, (q15_t)0x545b, (q15_t)0xc353, (q15_t)0x544f, (q15_t)0xc34f, + (q15_t)0x5443, (q15_t)0xc34b, (q15_t)0x5437, (q15_t)0xc347, (q15_t)0x542b, (q15_t)0xc343, (q15_t)0x541f, (q15_t)0xc33f, + (q15_t)0x5413, (q15_t)0xc33b, (q15_t)0x5407, (q15_t)0xc337, (q15_t)0x53fb, (q15_t)0xc333, (q15_t)0x53f0, (q15_t)0xc32f, + (q15_t)0x53e4, (q15_t)0xc32b, (q15_t)0x53d8, (q15_t)0xc327, (q15_t)0x53cc, (q15_t)0xc323, (q15_t)0x53c0, (q15_t)0xc320, + (q15_t)0x53b4, (q15_t)0xc31c, (q15_t)0x53a8, (q15_t)0xc318, (q15_t)0x539c, (q15_t)0xc314, (q15_t)0x5390, (q15_t)0xc310, + (q15_t)0x5384, (q15_t)0xc30c, (q15_t)0x5378, (q15_t)0xc308, (q15_t)0x536c, (q15_t)0xc305, (q15_t)0x5360, (q15_t)0xc301, + (q15_t)0x5354, (q15_t)0xc2fd, (q15_t)0x5348, (q15_t)0xc2f9, (q15_t)0x533c, (q15_t)0xc2f5, (q15_t)0x5330, (q15_t)0xc2f2, + (q15_t)0x5324, (q15_t)0xc2ee, (q15_t)0x5318, (q15_t)0xc2ea, (q15_t)0x530c, (q15_t)0xc2e6, (q15_t)0x5300, (q15_t)0xc2e3, + (q15_t)0x52f4, (q15_t)0xc2df, (q15_t)0x52e8, (q15_t)0xc2db, (q15_t)0x52dc, (q15_t)0xc2d8, (q15_t)0x52d0, (q15_t)0xc2d4, + (q15_t)0x52c4, (q15_t)0xc2d0, (q15_t)0x52b8, (q15_t)0xc2cc, (q15_t)0x52ac, (q15_t)0xc2c9, (q15_t)0x52a0, (q15_t)0xc2c5, + (q15_t)0x5294, (q15_t)0xc2c1, (q15_t)0x5288, (q15_t)0xc2be, (q15_t)0x527c, (q15_t)0xc2ba, (q15_t)0x5270, (q15_t)0xc2b7, + (q15_t)0x5264, (q15_t)0xc2b3, (q15_t)0x5258, (q15_t)0xc2af, (q15_t)0x524c, (q15_t)0xc2ac, (q15_t)0x5240, (q15_t)0xc2a8, + (q15_t)0x5234, (q15_t)0xc2a5, (q15_t)0x5228, (q15_t)0xc2a1, (q15_t)0x521c, (q15_t)0xc29d, (q15_t)0x5210, (q15_t)0xc29a, + (q15_t)0x5204, (q15_t)0xc296, (q15_t)0x51f7, (q15_t)0xc293, (q15_t)0x51eb, (q15_t)0xc28f, (q15_t)0x51df, (q15_t)0xc28c, + (q15_t)0x51d3, (q15_t)0xc288, (q15_t)0x51c7, (q15_t)0xc285, (q15_t)0x51bb, (q15_t)0xc281, (q15_t)0x51af, (q15_t)0xc27e, + (q15_t)0x51a3, (q15_t)0xc27a, (q15_t)0x5197, (q15_t)0xc277, (q15_t)0x518b, (q15_t)0xc273, (q15_t)0x517f, (q15_t)0xc270, + (q15_t)0x5173, (q15_t)0xc26d, (q15_t)0x5167, (q15_t)0xc269, (q15_t)0x515a, (q15_t)0xc266, (q15_t)0x514e, (q15_t)0xc262, + (q15_t)0x5142, (q15_t)0xc25f, (q15_t)0x5136, (q15_t)0xc25c, (q15_t)0x512a, (q15_t)0xc258, (q15_t)0x511e, (q15_t)0xc255, + (q15_t)0x5112, (q15_t)0xc251, (q15_t)0x5106, (q15_t)0xc24e, (q15_t)0x50fa, (q15_t)0xc24b, (q15_t)0x50ed, (q15_t)0xc247, + (q15_t)0x50e1, (q15_t)0xc244, (q15_t)0x50d5, (q15_t)0xc241, (q15_t)0x50c9, (q15_t)0xc23e, (q15_t)0x50bd, (q15_t)0xc23a, + (q15_t)0x50b1, (q15_t)0xc237, (q15_t)0x50a5, (q15_t)0xc234, (q15_t)0x5099, (q15_t)0xc230, (q15_t)0x508c, (q15_t)0xc22d, + (q15_t)0x5080, (q15_t)0xc22a, (q15_t)0x5074, (q15_t)0xc227, (q15_t)0x5068, (q15_t)0xc223, (q15_t)0x505c, (q15_t)0xc220, + (q15_t)0x5050, (q15_t)0xc21d, (q15_t)0x5044, (q15_t)0xc21a, (q15_t)0x5037, (q15_t)0xc217, (q15_t)0x502b, (q15_t)0xc213, + (q15_t)0x501f, (q15_t)0xc210, (q15_t)0x5013, (q15_t)0xc20d, (q15_t)0x5007, (q15_t)0xc20a, (q15_t)0x4ffb, (q15_t)0xc207, + (q15_t)0x4fee, (q15_t)0xc204, (q15_t)0x4fe2, (q15_t)0xc201, (q15_t)0x4fd6, (q15_t)0xc1fd, (q15_t)0x4fca, (q15_t)0xc1fa, + (q15_t)0x4fbe, (q15_t)0xc1f7, (q15_t)0x4fb2, (q15_t)0xc1f4, (q15_t)0x4fa5, (q15_t)0xc1f1, (q15_t)0x4f99, (q15_t)0xc1ee, + (q15_t)0x4f8d, (q15_t)0xc1eb, (q15_t)0x4f81, (q15_t)0xc1e8, (q15_t)0x4f75, (q15_t)0xc1e5, (q15_t)0x4f68, (q15_t)0xc1e2, + (q15_t)0x4f5c, (q15_t)0xc1df, (q15_t)0x4f50, (q15_t)0xc1dc, (q15_t)0x4f44, (q15_t)0xc1d9, (q15_t)0x4f38, (q15_t)0xc1d6, + (q15_t)0x4f2b, (q15_t)0xc1d3, (q15_t)0x4f1f, (q15_t)0xc1d0, (q15_t)0x4f13, (q15_t)0xc1cd, (q15_t)0x4f07, (q15_t)0xc1ca, + (q15_t)0x4efb, (q15_t)0xc1c7, (q15_t)0x4eee, (q15_t)0xc1c4, (q15_t)0x4ee2, (q15_t)0xc1c1, (q15_t)0x4ed6, (q15_t)0xc1be, + (q15_t)0x4eca, (q15_t)0xc1bb, (q15_t)0x4ebd, (q15_t)0xc1b8, (q15_t)0x4eb1, (q15_t)0xc1b6, (q15_t)0x4ea5, (q15_t)0xc1b3, + (q15_t)0x4e99, (q15_t)0xc1b0, (q15_t)0x4e8c, (q15_t)0xc1ad, (q15_t)0x4e80, (q15_t)0xc1aa, (q15_t)0x4e74, (q15_t)0xc1a7, + (q15_t)0x4e68, (q15_t)0xc1a4, (q15_t)0x4e5c, (q15_t)0xc1a2, (q15_t)0x4e4f, (q15_t)0xc19f, (q15_t)0x4e43, (q15_t)0xc19c, + (q15_t)0x4e37, (q15_t)0xc199, (q15_t)0x4e2b, (q15_t)0xc196, (q15_t)0x4e1e, (q15_t)0xc194, (q15_t)0x4e12, (q15_t)0xc191, + (q15_t)0x4e06, (q15_t)0xc18e, (q15_t)0x4df9, (q15_t)0xc18b, (q15_t)0x4ded, (q15_t)0xc189, (q15_t)0x4de1, (q15_t)0xc186, + (q15_t)0x4dd5, (q15_t)0xc183, (q15_t)0x4dc8, (q15_t)0xc180, (q15_t)0x4dbc, (q15_t)0xc17e, (q15_t)0x4db0, (q15_t)0xc17b, + (q15_t)0x4da4, (q15_t)0xc178, (q15_t)0x4d97, (q15_t)0xc176, (q15_t)0x4d8b, (q15_t)0xc173, (q15_t)0x4d7f, (q15_t)0xc170, + (q15_t)0x4d72, (q15_t)0xc16e, (q15_t)0x4d66, (q15_t)0xc16b, (q15_t)0x4d5a, (q15_t)0xc168, (q15_t)0x4d4e, (q15_t)0xc166, + (q15_t)0x4d41, (q15_t)0xc163, (q15_t)0x4d35, (q15_t)0xc161, (q15_t)0x4d29, (q15_t)0xc15e, (q15_t)0x4d1c, (q15_t)0xc15b, + (q15_t)0x4d10, (q15_t)0xc159, (q15_t)0x4d04, (q15_t)0xc156, (q15_t)0x4cf8, (q15_t)0xc154, (q15_t)0x4ceb, (q15_t)0xc151, + (q15_t)0x4cdf, (q15_t)0xc14f, (q15_t)0x4cd3, (q15_t)0xc14c, (q15_t)0x4cc6, (q15_t)0xc14a, (q15_t)0x4cba, (q15_t)0xc147, + (q15_t)0x4cae, (q15_t)0xc145, (q15_t)0x4ca1, (q15_t)0xc142, (q15_t)0x4c95, (q15_t)0xc140, (q15_t)0x4c89, (q15_t)0xc13d, + (q15_t)0x4c7c, (q15_t)0xc13b, (q15_t)0x4c70, (q15_t)0xc138, (q15_t)0x4c64, (q15_t)0xc136, (q15_t)0x4c57, (q15_t)0xc134, + (q15_t)0x4c4b, (q15_t)0xc131, (q15_t)0x4c3f, (q15_t)0xc12f, (q15_t)0x4c32, (q15_t)0xc12c, (q15_t)0x4c26, (q15_t)0xc12a, + (q15_t)0x4c1a, (q15_t)0xc128, (q15_t)0x4c0d, (q15_t)0xc125, (q15_t)0x4c01, (q15_t)0xc123, (q15_t)0x4bf5, (q15_t)0xc120, + (q15_t)0x4be8, (q15_t)0xc11e, (q15_t)0x4bdc, (q15_t)0xc11c, (q15_t)0x4bd0, (q15_t)0xc119, (q15_t)0x4bc3, (q15_t)0xc117, + (q15_t)0x4bb7, (q15_t)0xc115, (q15_t)0x4bab, (q15_t)0xc113, (q15_t)0x4b9e, (q15_t)0xc110, (q15_t)0x4b92, (q15_t)0xc10e, + (q15_t)0x4b85, (q15_t)0xc10c, (q15_t)0x4b79, (q15_t)0xc109, (q15_t)0x4b6d, (q15_t)0xc107, (q15_t)0x4b60, (q15_t)0xc105, + (q15_t)0x4b54, (q15_t)0xc103, (q15_t)0x4b48, (q15_t)0xc100, (q15_t)0x4b3b, (q15_t)0xc0fe, (q15_t)0x4b2f, (q15_t)0xc0fc, + (q15_t)0x4b23, (q15_t)0xc0fa, (q15_t)0x4b16, (q15_t)0xc0f8, (q15_t)0x4b0a, (q15_t)0xc0f6, (q15_t)0x4afd, (q15_t)0xc0f3, + (q15_t)0x4af1, (q15_t)0xc0f1, (q15_t)0x4ae5, (q15_t)0xc0ef, (q15_t)0x4ad8, (q15_t)0xc0ed, (q15_t)0x4acc, (q15_t)0xc0eb, + (q15_t)0x4ac0, (q15_t)0xc0e9, (q15_t)0x4ab3, (q15_t)0xc0e7, (q15_t)0x4aa7, (q15_t)0xc0e4, (q15_t)0x4a9a, (q15_t)0xc0e2, + (q15_t)0x4a8e, (q15_t)0xc0e0, (q15_t)0x4a82, (q15_t)0xc0de, (q15_t)0x4a75, (q15_t)0xc0dc, (q15_t)0x4a69, (q15_t)0xc0da, + (q15_t)0x4a5c, (q15_t)0xc0d8, (q15_t)0x4a50, (q15_t)0xc0d6, (q15_t)0x4a44, (q15_t)0xc0d4, (q15_t)0x4a37, (q15_t)0xc0d2, + (q15_t)0x4a2b, (q15_t)0xc0d0, (q15_t)0x4a1e, (q15_t)0xc0ce, (q15_t)0x4a12, (q15_t)0xc0cc, (q15_t)0x4a06, (q15_t)0xc0ca, + (q15_t)0x49f9, (q15_t)0xc0c8, (q15_t)0x49ed, (q15_t)0xc0c6, (q15_t)0x49e0, (q15_t)0xc0c4, (q15_t)0x49d4, (q15_t)0xc0c2, + (q15_t)0x49c7, (q15_t)0xc0c0, (q15_t)0x49bb, (q15_t)0xc0be, (q15_t)0x49af, (q15_t)0xc0bd, (q15_t)0x49a2, (q15_t)0xc0bb, + (q15_t)0x4996, (q15_t)0xc0b9, (q15_t)0x4989, (q15_t)0xc0b7, (q15_t)0x497d, (q15_t)0xc0b5, (q15_t)0x4970, (q15_t)0xc0b3, + (q15_t)0x4964, (q15_t)0xc0b1, (q15_t)0x4958, (q15_t)0xc0af, (q15_t)0x494b, (q15_t)0xc0ae, (q15_t)0x493f, (q15_t)0xc0ac, + (q15_t)0x4932, (q15_t)0xc0aa, (q15_t)0x4926, (q15_t)0xc0a8, (q15_t)0x4919, (q15_t)0xc0a6, (q15_t)0x490d, (q15_t)0xc0a5, + (q15_t)0x4901, (q15_t)0xc0a3, (q15_t)0x48f4, (q15_t)0xc0a1, (q15_t)0x48e8, (q15_t)0xc09f, (q15_t)0x48db, (q15_t)0xc09e, + (q15_t)0x48cf, (q15_t)0xc09c, (q15_t)0x48c2, (q15_t)0xc09a, (q15_t)0x48b6, (q15_t)0xc098, (q15_t)0x48a9, (q15_t)0xc097, + (q15_t)0x489d, (q15_t)0xc095, (q15_t)0x4891, (q15_t)0xc093, (q15_t)0x4884, (q15_t)0xc092, (q15_t)0x4878, (q15_t)0xc090, + (q15_t)0x486b, (q15_t)0xc08e, (q15_t)0x485f, (q15_t)0xc08d, (q15_t)0x4852, (q15_t)0xc08b, (q15_t)0x4846, (q15_t)0xc089, + (q15_t)0x4839, (q15_t)0xc088, (q15_t)0x482d, (q15_t)0xc086, (q15_t)0x4820, (q15_t)0xc085, (q15_t)0x4814, (q15_t)0xc083, + (q15_t)0x4807, (q15_t)0xc081, (q15_t)0x47fb, (q15_t)0xc080, (q15_t)0x47ef, (q15_t)0xc07e, (q15_t)0x47e2, (q15_t)0xc07d, + (q15_t)0x47d6, (q15_t)0xc07b, (q15_t)0x47c9, (q15_t)0xc07a, (q15_t)0x47bd, (q15_t)0xc078, (q15_t)0x47b0, (q15_t)0xc077, + (q15_t)0x47a4, (q15_t)0xc075, (q15_t)0x4797, (q15_t)0xc074, (q15_t)0x478b, (q15_t)0xc072, (q15_t)0x477e, (q15_t)0xc071, + (q15_t)0x4772, (q15_t)0xc06f, (q15_t)0x4765, (q15_t)0xc06e, (q15_t)0x4759, (q15_t)0xc06c, (q15_t)0x474c, (q15_t)0xc06b, + (q15_t)0x4740, (q15_t)0xc069, (q15_t)0x4733, (q15_t)0xc068, (q15_t)0x4727, (q15_t)0xc067, (q15_t)0x471a, (q15_t)0xc065, + (q15_t)0x470e, (q15_t)0xc064, (q15_t)0x4701, (q15_t)0xc062, (q15_t)0x46f5, (q15_t)0xc061, (q15_t)0x46e8, (q15_t)0xc060, + (q15_t)0x46dc, (q15_t)0xc05e, (q15_t)0x46cf, (q15_t)0xc05d, (q15_t)0x46c3, (q15_t)0xc05c, (q15_t)0x46b6, (q15_t)0xc05a, + (q15_t)0x46aa, (q15_t)0xc059, (q15_t)0x469d, (q15_t)0xc058, (q15_t)0x4691, (q15_t)0xc056, (q15_t)0x4684, (q15_t)0xc055, + (q15_t)0x4678, (q15_t)0xc054, (q15_t)0x466b, (q15_t)0xc053, (q15_t)0x465f, (q15_t)0xc051, (q15_t)0x4652, (q15_t)0xc050, + (q15_t)0x4646, (q15_t)0xc04f, (q15_t)0x4639, (q15_t)0xc04e, (q15_t)0x462d, (q15_t)0xc04c, (q15_t)0x4620, (q15_t)0xc04b, + (q15_t)0x4614, (q15_t)0xc04a, (q15_t)0x4607, (q15_t)0xc049, (q15_t)0x45fb, (q15_t)0xc048, (q15_t)0x45ee, (q15_t)0xc047, + (q15_t)0x45e2, (q15_t)0xc045, (q15_t)0x45d5, (q15_t)0xc044, (q15_t)0x45c9, (q15_t)0xc043, (q15_t)0x45bc, (q15_t)0xc042, + (q15_t)0x45b0, (q15_t)0xc041, (q15_t)0x45a3, (q15_t)0xc040, (q15_t)0x4597, (q15_t)0xc03f, (q15_t)0x458a, (q15_t)0xc03d, + (q15_t)0x457e, (q15_t)0xc03c, (q15_t)0x4571, (q15_t)0xc03b, (q15_t)0x4565, (q15_t)0xc03a, (q15_t)0x4558, (q15_t)0xc039, + (q15_t)0x454c, (q15_t)0xc038, (q15_t)0x453f, (q15_t)0xc037, (q15_t)0x4533, (q15_t)0xc036, (q15_t)0x4526, (q15_t)0xc035, + (q15_t)0x451a, (q15_t)0xc034, (q15_t)0x450d, (q15_t)0xc033, (q15_t)0x4500, (q15_t)0xc032, (q15_t)0x44f4, (q15_t)0xc031, + (q15_t)0x44e7, (q15_t)0xc030, (q15_t)0x44db, (q15_t)0xc02f, (q15_t)0x44ce, (q15_t)0xc02e, (q15_t)0x44c2, (q15_t)0xc02d, + (q15_t)0x44b5, (q15_t)0xc02c, (q15_t)0x44a9, (q15_t)0xc02b, (q15_t)0x449c, (q15_t)0xc02b, (q15_t)0x4490, (q15_t)0xc02a, + (q15_t)0x4483, (q15_t)0xc029, (q15_t)0x4477, (q15_t)0xc028, (q15_t)0x446a, (q15_t)0xc027, (q15_t)0x445e, (q15_t)0xc026, + (q15_t)0x4451, (q15_t)0xc025, (q15_t)0x4444, (q15_t)0xc024, (q15_t)0x4438, (q15_t)0xc024, (q15_t)0x442b, (q15_t)0xc023, + (q15_t)0x441f, (q15_t)0xc022, (q15_t)0x4412, (q15_t)0xc021, (q15_t)0x4406, (q15_t)0xc020, (q15_t)0x43f9, (q15_t)0xc020, + (q15_t)0x43ed, (q15_t)0xc01f, (q15_t)0x43e0, (q15_t)0xc01e, (q15_t)0x43d4, (q15_t)0xc01d, (q15_t)0x43c7, (q15_t)0xc01d, + (q15_t)0x43bb, (q15_t)0xc01c, (q15_t)0x43ae, (q15_t)0xc01b, (q15_t)0x43a1, (q15_t)0xc01a, (q15_t)0x4395, (q15_t)0xc01a, + (q15_t)0x4388, (q15_t)0xc019, (q15_t)0x437c, (q15_t)0xc018, (q15_t)0x436f, (q15_t)0xc018, (q15_t)0x4363, (q15_t)0xc017, + (q15_t)0x4356, (q15_t)0xc016, (q15_t)0x434a, (q15_t)0xc016, (q15_t)0x433d, (q15_t)0xc015, (q15_t)0x4330, (q15_t)0xc014, + (q15_t)0x4324, (q15_t)0xc014, (q15_t)0x4317, (q15_t)0xc013, (q15_t)0x430b, (q15_t)0xc013, (q15_t)0x42fe, (q15_t)0xc012, + (q15_t)0x42f2, (q15_t)0xc011, (q15_t)0x42e5, (q15_t)0xc011, (q15_t)0x42d9, (q15_t)0xc010, (q15_t)0x42cc, (q15_t)0xc010, + (q15_t)0x42c0, (q15_t)0xc00f, (q15_t)0x42b3, (q15_t)0xc00f, (q15_t)0x42a6, (q15_t)0xc00e, (q15_t)0x429a, (q15_t)0xc00e, + (q15_t)0x428d, (q15_t)0xc00d, (q15_t)0x4281, (q15_t)0xc00d, (q15_t)0x4274, (q15_t)0xc00c, (q15_t)0x4268, (q15_t)0xc00c, + (q15_t)0x425b, (q15_t)0xc00b, (q15_t)0x424e, (q15_t)0xc00b, (q15_t)0x4242, (q15_t)0xc00a, (q15_t)0x4235, (q15_t)0xc00a, + (q15_t)0x4229, (q15_t)0xc009, (q15_t)0x421c, (q15_t)0xc009, (q15_t)0x4210, (q15_t)0xc009, (q15_t)0x4203, (q15_t)0xc008, + (q15_t)0x41f7, (q15_t)0xc008, (q15_t)0x41ea, (q15_t)0xc007, (q15_t)0x41dd, (q15_t)0xc007, (q15_t)0x41d1, (q15_t)0xc007, + (q15_t)0x41c4, (q15_t)0xc006, (q15_t)0x41b8, (q15_t)0xc006, (q15_t)0x41ab, (q15_t)0xc006, (q15_t)0x419f, (q15_t)0xc005, + (q15_t)0x4192, (q15_t)0xc005, (q15_t)0x4186, (q15_t)0xc005, (q15_t)0x4179, (q15_t)0xc004, (q15_t)0x416c, (q15_t)0xc004, + (q15_t)0x4160, (q15_t)0xc004, (q15_t)0x4153, (q15_t)0xc004, (q15_t)0x4147, (q15_t)0xc003, (q15_t)0x413a, (q15_t)0xc003, + (q15_t)0x412e, (q15_t)0xc003, (q15_t)0x4121, (q15_t)0xc003, (q15_t)0x4114, (q15_t)0xc002, (q15_t)0x4108, (q15_t)0xc002, + (q15_t)0x40fb, (q15_t)0xc002, (q15_t)0x40ef, (q15_t)0xc002, (q15_t)0x40e2, (q15_t)0xc002, (q15_t)0x40d6, (q15_t)0xc001, + (q15_t)0x40c9, (q15_t)0xc001, (q15_t)0x40bc, (q15_t)0xc001, (q15_t)0x40b0, (q15_t)0xc001, (q15_t)0x40a3, (q15_t)0xc001, + (q15_t)0x4097, (q15_t)0xc001, (q15_t)0x408a, (q15_t)0xc001, (q15_t)0x407e, (q15_t)0xc000, (q15_t)0x4071, (q15_t)0xc000, + (q15_t)0x4065, (q15_t)0xc000, (q15_t)0x4058, (q15_t)0xc000, (q15_t)0x404b, (q15_t)0xc000, (q15_t)0x403f, (q15_t)0xc000, + (q15_t)0x4032, (q15_t)0xc000, (q15_t)0x4026, (q15_t)0xc000, (q15_t)0x4019, (q15_t)0xc000, (q15_t)0x400d, (q15_t)0xc000, +}; + +/** +* @} end of RealFFT_Table group +*/ + +/** +* @addtogroup RealFFT +* @{ +*/ + +/** +* @brief Initialization function for the Q15 RFFT/RIFFT. +* @param[in, out] *S points to an instance of the Q15 RFFT/RIFFT structure. +* @param[in] fftLenReal length of the FFT. +* @param[in] ifftFlagR flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLenReal is not a supported value. +* +* \par Description: +* \par +* The parameter fftLenReal Specifies length of RFFT/RIFFT Process. Supported FFT Lengths are 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192. +* \par +* The parameter ifftFlagR controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlagR to calculate RIFFT, otherwise RFFT is calculated. +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par +* This function also initializes Twiddle factor table. +*/ +arm_status arm_rfft_init_q15( + arm_rfft_instance_q15 * S, + uint32_t fftLenReal, + uint32_t ifftFlagR, + uint32_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initialize the Real FFT length */ + S->fftLenReal = (uint16_t) fftLenReal; + + /* Initialize the Twiddle coefficientA pointer */ + S->pTwiddleAReal = (q15_t *) realCoefAQ15; + + /* Initialize the Twiddle coefficientB pointer */ + S->pTwiddleBReal = (q15_t *) realCoefBQ15; + + /* Initialize the Flag for selection of RFFT or RIFFT */ + S->ifftFlagR = (uint8_t) ifftFlagR; + + /* Initialize the Flag for calculation Bit reversal or not */ + S->bitReverseFlagR = (uint8_t) bitReverseFlag; + + /* Initialization of coef modifier depending on the FFT length */ + switch (S->fftLenReal) + { + case 8192U: + S->twidCoefRModifier = 1U; + S->pCfft = &arm_cfft_sR_q15_len4096; + break; + case 4096U: + S->twidCoefRModifier = 2U; + S->pCfft = &arm_cfft_sR_q15_len2048; + break; + case 2048U: + S->twidCoefRModifier = 4U; + S->pCfft = &arm_cfft_sR_q15_len1024; + break; + case 1024U: + S->twidCoefRModifier = 8U; + S->pCfft = &arm_cfft_sR_q15_len512; + break; + case 512U: + S->twidCoefRModifier = 16U; + S->pCfft = &arm_cfft_sR_q15_len256; + break; + case 256U: + S->twidCoefRModifier = 32U; + S->pCfft = &arm_cfft_sR_q15_len128; + break; + case 128U: + S->twidCoefRModifier = 64U; + S->pCfft = &arm_cfft_sR_q15_len64; + break; + case 64U: + S->twidCoefRModifier = 128U; + S->pCfft = &arm_cfft_sR_q15_len32; + break; + case 32U: + S->twidCoefRModifier = 256U; + S->pCfft = &arm_cfft_sR_q15_len16; + break; + default: + /* Reporting argument error if rfftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + /* return the status of RFFT Init function */ + return (status); +} + +/** +* @} end of RealFFT group +*/ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q31.c new file mode 100644 index 0000000..04369ed --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_init_q31.c @@ -0,0 +1,4280 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rfft_init_q31.c + * Description: RFFT & RIFFT Q31 initialisation function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_common_tables.h" +#include "arm_const_structs.h" + +/** +* @ingroup RealFFT +*/ + +/** + * @addtogroup RealFFT_Table Real FFT Tables +* @{ +*/ + +/** +* \par +* Generation fixed-point realCoefAQ31 array in Q31 format: +* \par +* n = 4096 +*
for (i = 0; i < n; i++)
+* {
+*    pATable[2 * i] = 0.5 * (1.0 - sin (2 * PI / (double) (2 * n) * (double) i));
+*    pATable[2 * i + 1] = 0.5 * (-1.0 * cos (2 * PI / (double) (2 * n) * (double) i));
+* }
+* \par +* Convert to fixed point Q31 format +* round(pATable[i] * pow(2, 31)) +*/ +const q31_t realCoefAQ31[8192] = { + (q31_t)0x40000000, (q31_t)0xc0000000, (q31_t)0x3ff36f02, (q31_t)0xc000013c, + (q31_t)0x3fe6de05, (q31_t)0xc00004ef, (q31_t)0x3fda4d09, (q31_t)0xc0000b1a, + (q31_t)0x3fcdbc0f, (q31_t)0xc00013bd, (q31_t)0x3fc12b16, (q31_t)0xc0001ed8, + (q31_t)0x3fb49a1f, (q31_t)0xc0002c6a, (q31_t)0x3fa8092c, (q31_t)0xc0003c74, + (q31_t)0x3f9b783c, (q31_t)0xc0004ef5, (q31_t)0x3f8ee750, (q31_t)0xc00063ee, + (q31_t)0x3f825668, (q31_t)0xc0007b5f, (q31_t)0x3f75c585, (q31_t)0xc0009547, + (q31_t)0x3f6934a8, (q31_t)0xc000b1a7, (q31_t)0x3f5ca3d0, (q31_t)0xc000d07e, + (q31_t)0x3f5012fe, (q31_t)0xc000f1ce, (q31_t)0x3f438234, (q31_t)0xc0011594, + (q31_t)0x3f36f170, (q31_t)0xc0013bd3, (q31_t)0x3f2a60b4, (q31_t)0xc0016489, + (q31_t)0x3f1dd001, (q31_t)0xc0018fb6, (q31_t)0x3f113f56, (q31_t)0xc001bd5c, + (q31_t)0x3f04aeb5, (q31_t)0xc001ed78, (q31_t)0x3ef81e1d, (q31_t)0xc002200d, + (q31_t)0x3eeb8d8f, (q31_t)0xc0025519, (q31_t)0x3edefd0c, (q31_t)0xc0028c9c, + (q31_t)0x3ed26c94, (q31_t)0xc002c697, (q31_t)0x3ec5dc28, (q31_t)0xc003030a, + (q31_t)0x3eb94bc8, (q31_t)0xc00341f4, (q31_t)0x3eacbb74, (q31_t)0xc0038356, + (q31_t)0x3ea02b2e, (q31_t)0xc003c72f, (q31_t)0x3e939af5, (q31_t)0xc0040d80, + (q31_t)0x3e870aca, (q31_t)0xc0045648, (q31_t)0x3e7a7aae, (q31_t)0xc004a188, + (q31_t)0x3e6deaa1, (q31_t)0xc004ef3f, (q31_t)0x3e615aa3, (q31_t)0xc0053f6e, + (q31_t)0x3e54cab5, (q31_t)0xc0059214, (q31_t)0x3e483ad8, (q31_t)0xc005e731, + (q31_t)0x3e3bab0b, (q31_t)0xc0063ec6, (q31_t)0x3e2f1b50, (q31_t)0xc00698d3, + (q31_t)0x3e228ba7, (q31_t)0xc006f556, (q31_t)0x3e15fc11, (q31_t)0xc0075452, + (q31_t)0x3e096c8d, (q31_t)0xc007b5c4, (q31_t)0x3dfcdd1d, (q31_t)0xc00819ae, + (q31_t)0x3df04dc0, (q31_t)0xc008800f, (q31_t)0x3de3be78, (q31_t)0xc008e8e8, + (q31_t)0x3dd72f45, (q31_t)0xc0095438, (q31_t)0x3dcaa027, (q31_t)0xc009c1ff, + (q31_t)0x3dbe111e, (q31_t)0xc00a323d, (q31_t)0x3db1822c, (q31_t)0xc00aa4f3, + (q31_t)0x3da4f351, (q31_t)0xc00b1a20, (q31_t)0x3d98648d, (q31_t)0xc00b91c4, + (q31_t)0x3d8bd5e1, (q31_t)0xc00c0be0, (q31_t)0x3d7f474d, (q31_t)0xc00c8872, + (q31_t)0x3d72b8d2, (q31_t)0xc00d077c, (q31_t)0x3d662a70, (q31_t)0xc00d88fd, + (q31_t)0x3d599c28, (q31_t)0xc00e0cf5, (q31_t)0x3d4d0df9, (q31_t)0xc00e9364, + (q31_t)0x3d407fe6, (q31_t)0xc00f1c4a, (q31_t)0x3d33f1ed, (q31_t)0xc00fa7a8, + (q31_t)0x3d276410, (q31_t)0xc010357c, (q31_t)0x3d1ad650, (q31_t)0xc010c5c7, + (q31_t)0x3d0e48ab, (q31_t)0xc011588a, (q31_t)0x3d01bb24, (q31_t)0xc011edc3, + (q31_t)0x3cf52dbb, (q31_t)0xc0128574, (q31_t)0x3ce8a06f, (q31_t)0xc0131f9b, + (q31_t)0x3cdc1342, (q31_t)0xc013bc39, (q31_t)0x3ccf8634, (q31_t)0xc0145b4e, + (q31_t)0x3cc2f945, (q31_t)0xc014fcda, (q31_t)0x3cb66c77, (q31_t)0xc015a0dd, + (q31_t)0x3ca9dfc8, (q31_t)0xc0164757, (q31_t)0x3c9d533b, (q31_t)0xc016f047, + (q31_t)0x3c90c6cf, (q31_t)0xc0179bae, (q31_t)0x3c843a85, (q31_t)0xc018498c, + (q31_t)0x3c77ae5e, (q31_t)0xc018f9e1, (q31_t)0x3c6b2259, (q31_t)0xc019acac, + (q31_t)0x3c5e9678, (q31_t)0xc01a61ee, (q31_t)0x3c520aba, (q31_t)0xc01b19a7, + (q31_t)0x3c457f21, (q31_t)0xc01bd3d6, (q31_t)0x3c38f3ac, (q31_t)0xc01c907c, + (q31_t)0x3c2c685d, (q31_t)0xc01d4f99, (q31_t)0x3c1fdd34, (q31_t)0xc01e112b, + (q31_t)0x3c135231, (q31_t)0xc01ed535, (q31_t)0x3c06c754, (q31_t)0xc01f9bb5, + (q31_t)0x3bfa3c9f, (q31_t)0xc02064ab, (q31_t)0x3bedb212, (q31_t)0xc0213018, + (q31_t)0x3be127ac, (q31_t)0xc021fdfb, (q31_t)0x3bd49d70, (q31_t)0xc022ce54, + (q31_t)0x3bc8135c, (q31_t)0xc023a124, (q31_t)0x3bbb8973, (q31_t)0xc024766a, + (q31_t)0x3baeffb3, (q31_t)0xc0254e27, (q31_t)0x3ba2761e, (q31_t)0xc0262859, + (q31_t)0x3b95ecb4, (q31_t)0xc0270502, (q31_t)0x3b896375, (q31_t)0xc027e421, + (q31_t)0x3b7cda63, (q31_t)0xc028c5b6, (q31_t)0x3b70517d, (q31_t)0xc029a9c1, + (q31_t)0x3b63c8c4, (q31_t)0xc02a9042, (q31_t)0x3b574039, (q31_t)0xc02b7939, + (q31_t)0x3b4ab7db, (q31_t)0xc02c64a6, (q31_t)0x3b3e2fac, (q31_t)0xc02d5289, + (q31_t)0x3b31a7ac, (q31_t)0xc02e42e2, (q31_t)0x3b251fdc, (q31_t)0xc02f35b1, + (q31_t)0x3b18983b, (q31_t)0xc0302af5, (q31_t)0x3b0c10cb, (q31_t)0xc03122b0, + (q31_t)0x3aff898c, (q31_t)0xc0321ce0, (q31_t)0x3af3027e, (q31_t)0xc0331986, + (q31_t)0x3ae67ba2, (q31_t)0xc03418a2, (q31_t)0x3ad9f4f8, (q31_t)0xc0351a33, + (q31_t)0x3acd6e81, (q31_t)0xc0361e3a, (q31_t)0x3ac0e83d, (q31_t)0xc03724b6, + (q31_t)0x3ab4622d, (q31_t)0xc0382da8, (q31_t)0x3aa7dc52, (q31_t)0xc0393910, + (q31_t)0x3a9b56ab, (q31_t)0xc03a46ed, (q31_t)0x3a8ed139, (q31_t)0xc03b573f, + (q31_t)0x3a824bfd, (q31_t)0xc03c6a07, (q31_t)0x3a75c6f8, (q31_t)0xc03d7f44, + (q31_t)0x3a694229, (q31_t)0xc03e96f6, (q31_t)0x3a5cbd91, (q31_t)0xc03fb11d, + (q31_t)0x3a503930, (q31_t)0xc040cdba, (q31_t)0x3a43b508, (q31_t)0xc041eccc, + (q31_t)0x3a373119, (q31_t)0xc0430e53, (q31_t)0x3a2aad62, (q31_t)0xc044324f, + (q31_t)0x3a1e29e5, (q31_t)0xc04558c0, (q31_t)0x3a11a6a3, (q31_t)0xc04681a6, + (q31_t)0x3a05239a, (q31_t)0xc047ad01, (q31_t)0x39f8a0cd, (q31_t)0xc048dad1, + (q31_t)0x39ec1e3b, (q31_t)0xc04a0b16, (q31_t)0x39df9be6, (q31_t)0xc04b3dcf, + (q31_t)0x39d319cc, (q31_t)0xc04c72fe, (q31_t)0x39c697f0, (q31_t)0xc04daaa1, + (q31_t)0x39ba1651, (q31_t)0xc04ee4b8, (q31_t)0x39ad94f0, (q31_t)0xc0502145, + (q31_t)0x39a113cd, (q31_t)0xc0516045, (q31_t)0x399492ea, (q31_t)0xc052a1bb, + (q31_t)0x39881245, (q31_t)0xc053e5a5, (q31_t)0x397b91e1, (q31_t)0xc0552c03, + (q31_t)0x396f11bc, (q31_t)0xc05674d6, (q31_t)0x396291d9, (q31_t)0xc057c01d, + (q31_t)0x39561237, (q31_t)0xc0590dd8, (q31_t)0x394992d7, (q31_t)0xc05a5e07, + (q31_t)0x393d13b8, (q31_t)0xc05bb0ab, (q31_t)0x393094dd, (q31_t)0xc05d05c3, + (q31_t)0x39241645, (q31_t)0xc05e5d4e, (q31_t)0x391797f0, (q31_t)0xc05fb74e, + (q31_t)0x390b19e0, (q31_t)0xc06113c2, (q31_t)0x38fe9c15, (q31_t)0xc06272aa, + (q31_t)0x38f21e8e, (q31_t)0xc063d405, (q31_t)0x38e5a14d, (q31_t)0xc06537d4, + (q31_t)0x38d92452, (q31_t)0xc0669e18, (q31_t)0x38cca79e, (q31_t)0xc06806ce, + (q31_t)0x38c02b31, (q31_t)0xc06971f9, (q31_t)0x38b3af0c, (q31_t)0xc06adf97, + (q31_t)0x38a7332e, (q31_t)0xc06c4fa8, (q31_t)0x389ab799, (q31_t)0xc06dc22e, + (q31_t)0x388e3c4d, (q31_t)0xc06f3726, (q31_t)0x3881c14b, (q31_t)0xc070ae92, + (q31_t)0x38754692, (q31_t)0xc0722871, (q31_t)0x3868cc24, (q31_t)0xc073a4c3, + (q31_t)0x385c5201, (q31_t)0xc0752389, (q31_t)0x384fd829, (q31_t)0xc076a4c2, + (q31_t)0x38435e9d, (q31_t)0xc078286e, (q31_t)0x3836e55d, (q31_t)0xc079ae8c, + (q31_t)0x382a6c6a, (q31_t)0xc07b371e, (q31_t)0x381df3c5, (q31_t)0xc07cc223, + (q31_t)0x38117b6d, (q31_t)0xc07e4f9b, (q31_t)0x38050364, (q31_t)0xc07fdf85, + (q31_t)0x37f88ba9, (q31_t)0xc08171e2, (q31_t)0x37ec143e, (q31_t)0xc08306b2, + (q31_t)0x37df9d22, (q31_t)0xc0849df4, (q31_t)0x37d32657, (q31_t)0xc08637a9, + (q31_t)0x37c6afdc, (q31_t)0xc087d3d0, (q31_t)0x37ba39b3, (q31_t)0xc089726a, + (q31_t)0x37adc3db, (q31_t)0xc08b1376, (q31_t)0x37a14e55, (q31_t)0xc08cb6f5, + (q31_t)0x3794d922, (q31_t)0xc08e5ce5, (q31_t)0x37886442, (q31_t)0xc0900548, + (q31_t)0x377befb5, (q31_t)0xc091b01d, (q31_t)0x376f7b7d, (q31_t)0xc0935d64, + (q31_t)0x37630799, (q31_t)0xc0950d1d, (q31_t)0x3756940a, (q31_t)0xc096bf48, + (q31_t)0x374a20d0, (q31_t)0xc09873e4, (q31_t)0x373daded, (q31_t)0xc09a2af3, + (q31_t)0x37313b60, (q31_t)0xc09be473, (q31_t)0x3724c92a, (q31_t)0xc09da065, + (q31_t)0x3718574b, (q31_t)0xc09f5ec8, (q31_t)0x370be5c4, (q31_t)0xc0a11f9d, + (q31_t)0x36ff7496, (q31_t)0xc0a2e2e3, (q31_t)0x36f303c0, (q31_t)0xc0a4a89b, + (q31_t)0x36e69344, (q31_t)0xc0a670c4, (q31_t)0x36da2321, (q31_t)0xc0a83b5e, + (q31_t)0x36cdb359, (q31_t)0xc0aa086a, (q31_t)0x36c143ec, (q31_t)0xc0abd7e6, + (q31_t)0x36b4d4d9, (q31_t)0xc0ada9d4, (q31_t)0x36a86623, (q31_t)0xc0af7e33, + (q31_t)0x369bf7c9, (q31_t)0xc0b15502, (q31_t)0x368f89cb, (q31_t)0xc0b32e42, + (q31_t)0x36831c2b, (q31_t)0xc0b509f3, (q31_t)0x3676aee8, (q31_t)0xc0b6e815, + (q31_t)0x366a4203, (q31_t)0xc0b8c8a7, (q31_t)0x365dd57d, (q31_t)0xc0baabaa, + (q31_t)0x36516956, (q31_t)0xc0bc911d, (q31_t)0x3644fd8f, (q31_t)0xc0be7901, + (q31_t)0x36389228, (q31_t)0xc0c06355, (q31_t)0x362c2721, (q31_t)0xc0c25019, + (q31_t)0x361fbc7b, (q31_t)0xc0c43f4d, (q31_t)0x36135237, (q31_t)0xc0c630f2, + (q31_t)0x3606e854, (q31_t)0xc0c82506, (q31_t)0x35fa7ed4, (q31_t)0xc0ca1b8a, + (q31_t)0x35ee15b7, (q31_t)0xc0cc147f, (q31_t)0x35e1acfd, (q31_t)0xc0ce0fe3, + (q31_t)0x35d544a7, (q31_t)0xc0d00db6, (q31_t)0x35c8dcb6, (q31_t)0xc0d20dfa, + (q31_t)0x35bc7529, (q31_t)0xc0d410ad, (q31_t)0x35b00e02, (q31_t)0xc0d615cf, + (q31_t)0x35a3a740, (q31_t)0xc0d81d61, (q31_t)0x359740e5, (q31_t)0xc0da2762, + (q31_t)0x358adaf0, (q31_t)0xc0dc33d2, (q31_t)0x357e7563, (q31_t)0xc0de42b2, + (q31_t)0x3572103d, (q31_t)0xc0e05401, (q31_t)0x3565ab80, (q31_t)0xc0e267be, + (q31_t)0x3559472b, (q31_t)0xc0e47deb, (q31_t)0x354ce33f, (q31_t)0xc0e69686, + (q31_t)0x35407fbd, (q31_t)0xc0e8b190, (q31_t)0x35341ca5, (q31_t)0xc0eacf09, + (q31_t)0x3527b9f7, (q31_t)0xc0eceef1, (q31_t)0x351b57b5, (q31_t)0xc0ef1147, + (q31_t)0x350ef5de, (q31_t)0xc0f1360b, (q31_t)0x35029473, (q31_t)0xc0f35d3e, + (q31_t)0x34f63374, (q31_t)0xc0f586df, (q31_t)0x34e9d2e3, (q31_t)0xc0f7b2ee, + (q31_t)0x34dd72be, (q31_t)0xc0f9e16b, (q31_t)0x34d11308, (q31_t)0xc0fc1257, + (q31_t)0x34c4b3c0, (q31_t)0xc0fe45b0, (q31_t)0x34b854e7, (q31_t)0xc1007b77, + (q31_t)0x34abf67e, (q31_t)0xc102b3ac, (q31_t)0x349f9884, (q31_t)0xc104ee4f, + (q31_t)0x34933afa, (q31_t)0xc1072b5f, (q31_t)0x3486dde1, (q31_t)0xc1096add, + (q31_t)0x347a8139, (q31_t)0xc10bacc8, (q31_t)0x346e2504, (q31_t)0xc10df120, + (q31_t)0x3461c940, (q31_t)0xc11037e6, (q31_t)0x34556def, (q31_t)0xc1128119, + (q31_t)0x34491311, (q31_t)0xc114ccb9, (q31_t)0x343cb8a7, (q31_t)0xc1171ac6, + (q31_t)0x34305eb0, (q31_t)0xc1196b3f, (q31_t)0x3424052f, (q31_t)0xc11bbe26, + (q31_t)0x3417ac22, (q31_t)0xc11e1379, (q31_t)0x340b538b, (q31_t)0xc1206b39, + (q31_t)0x33fefb6a, (q31_t)0xc122c566, (q31_t)0x33f2a3bf, (q31_t)0xc12521ff, + (q31_t)0x33e64c8c, (q31_t)0xc1278104, (q31_t)0x33d9f5cf, (q31_t)0xc129e276, + (q31_t)0x33cd9f8b, (q31_t)0xc12c4653, (q31_t)0x33c149bf, (q31_t)0xc12eac9d, + (q31_t)0x33b4f46c, (q31_t)0xc1311553, (q31_t)0x33a89f92, (q31_t)0xc1338075, + (q31_t)0x339c4b32, (q31_t)0xc135ee02, (q31_t)0x338ff74d, (q31_t)0xc1385dfb, + (q31_t)0x3383a3e2, (q31_t)0xc13ad060, (q31_t)0x337750f2, (q31_t)0xc13d4530, + (q31_t)0x336afe7e, (q31_t)0xc13fbc6c, (q31_t)0x335eac86, (q31_t)0xc1423613, + (q31_t)0x33525b0b, (q31_t)0xc144b225, (q31_t)0x33460a0d, (q31_t)0xc14730a3, + (q31_t)0x3339b98d, (q31_t)0xc149b18b, (q31_t)0x332d698a, (q31_t)0xc14c34df, + (q31_t)0x33211a07, (q31_t)0xc14eba9d, (q31_t)0x3314cb02, (q31_t)0xc15142c6, + (q31_t)0x33087c7d, (q31_t)0xc153cd5a, (q31_t)0x32fc2e77, (q31_t)0xc1565a58, + (q31_t)0x32efe0f2, (q31_t)0xc158e9c1, (q31_t)0x32e393ef, (q31_t)0xc15b7b94, + (q31_t)0x32d7476c, (q31_t)0xc15e0fd1, (q31_t)0x32cafb6b, (q31_t)0xc160a678, + (q31_t)0x32beafed, (q31_t)0xc1633f8a, (q31_t)0x32b264f2, (q31_t)0xc165db05, + (q31_t)0x32a61a7a, (q31_t)0xc16878eb, (q31_t)0x3299d085, (q31_t)0xc16b193a, + (q31_t)0x328d8715, (q31_t)0xc16dbbf3, (q31_t)0x32813e2a, (q31_t)0xc1706115, + (q31_t)0x3274f5c3, (q31_t)0xc17308a1, (q31_t)0x3268ade3, (q31_t)0xc175b296, + (q31_t)0x325c6688, (q31_t)0xc1785ef4, (q31_t)0x32501fb5, (q31_t)0xc17b0dbb, + (q31_t)0x3243d968, (q31_t)0xc17dbeec, (q31_t)0x323793a3, (q31_t)0xc1807285, + (q31_t)0x322b4e66, (q31_t)0xc1832888, (q31_t)0x321f09b1, (q31_t)0xc185e0f3, + (q31_t)0x3212c585, (q31_t)0xc1889bc6, (q31_t)0x320681e3, (q31_t)0xc18b5903, + (q31_t)0x31fa3ecb, (q31_t)0xc18e18a7, (q31_t)0x31edfc3d, (q31_t)0xc190dab4, + (q31_t)0x31e1ba3a, (q31_t)0xc1939f29, (q31_t)0x31d578c2, (q31_t)0xc1966606, + (q31_t)0x31c937d6, (q31_t)0xc1992f4c, (q31_t)0x31bcf777, (q31_t)0xc19bfaf9, + (q31_t)0x31b0b7a4, (q31_t)0xc19ec90d, (q31_t)0x31a4785e, (q31_t)0xc1a1998a, + (q31_t)0x319839a6, (q31_t)0xc1a46c6e, (q31_t)0x318bfb7d, (q31_t)0xc1a741b9, + (q31_t)0x317fbde2, (q31_t)0xc1aa196c, (q31_t)0x317380d6, (q31_t)0xc1acf386, + (q31_t)0x31674459, (q31_t)0xc1afd007, (q31_t)0x315b086d, (q31_t)0xc1b2aef0, + (q31_t)0x314ecd11, (q31_t)0xc1b5903f, (q31_t)0x31429247, (q31_t)0xc1b873f5, + (q31_t)0x3136580d, (q31_t)0xc1bb5a11, (q31_t)0x312a1e66, (q31_t)0xc1be4294, + (q31_t)0x311de551, (q31_t)0xc1c12d7e, (q31_t)0x3111accf, (q31_t)0xc1c41ace, + (q31_t)0x310574e0, (q31_t)0xc1c70a84, (q31_t)0x30f93d86, (q31_t)0xc1c9fca0, + (q31_t)0x30ed06bf, (q31_t)0xc1ccf122, (q31_t)0x30e0d08d, (q31_t)0xc1cfe80a, + (q31_t)0x30d49af1, (q31_t)0xc1d2e158, (q31_t)0x30c865ea, (q31_t)0xc1d5dd0c, + (q31_t)0x30bc317a, (q31_t)0xc1d8db25, (q31_t)0x30affda0, (q31_t)0xc1dbdba3, + (q31_t)0x30a3ca5d, (q31_t)0xc1dede87, (q31_t)0x309797b2, (q31_t)0xc1e1e3d0, + (q31_t)0x308b659f, (q31_t)0xc1e4eb7e, (q31_t)0x307f3424, (q31_t)0xc1e7f591, + (q31_t)0x30730342, (q31_t)0xc1eb0209, (q31_t)0x3066d2fa, (q31_t)0xc1ee10e5, + (q31_t)0x305aa34c, (q31_t)0xc1f12227, (q31_t)0x304e7438, (q31_t)0xc1f435cc, + (q31_t)0x304245c0, (q31_t)0xc1f74bd6, (q31_t)0x303617e2, (q31_t)0xc1fa6445, + (q31_t)0x3029eaa1, (q31_t)0xc1fd7f17, (q31_t)0x301dbdfb, (q31_t)0xc2009c4e, + (q31_t)0x301191f3, (q31_t)0xc203bbe8, (q31_t)0x30056687, (q31_t)0xc206dde6, + (q31_t)0x2ff93bba, (q31_t)0xc20a0248, (q31_t)0x2fed118a, (q31_t)0xc20d290d, + (q31_t)0x2fe0e7f9, (q31_t)0xc2105236, (q31_t)0x2fd4bf08, (q31_t)0xc2137dc2, + (q31_t)0x2fc896b5, (q31_t)0xc216abb1, (q31_t)0x2fbc6f03, (q31_t)0xc219dc03, + (q31_t)0x2fb047f2, (q31_t)0xc21d0eb8, (q31_t)0x2fa42181, (q31_t)0xc22043d0, + (q31_t)0x2f97fbb2, (q31_t)0xc2237b4b, (q31_t)0x2f8bd685, (q31_t)0xc226b528, + (q31_t)0x2f7fb1fa, (q31_t)0xc229f167, (q31_t)0x2f738e12, (q31_t)0xc22d3009, + (q31_t)0x2f676ace, (q31_t)0xc230710d, (q31_t)0x2f5b482d, (q31_t)0xc233b473, + (q31_t)0x2f4f2630, (q31_t)0xc236fa3b, (q31_t)0x2f4304d8, (q31_t)0xc23a4265, + (q31_t)0x2f36e426, (q31_t)0xc23d8cf1, (q31_t)0x2f2ac419, (q31_t)0xc240d9de, + (q31_t)0x2f1ea4b2, (q31_t)0xc244292c, (q31_t)0x2f1285f2, (q31_t)0xc2477adc, + (q31_t)0x2f0667d9, (q31_t)0xc24aceed, (q31_t)0x2efa4a67, (q31_t)0xc24e255e, + (q31_t)0x2eee2d9d, (q31_t)0xc2517e31, (q31_t)0x2ee2117c, (q31_t)0xc254d965, + (q31_t)0x2ed5f604, (q31_t)0xc25836f9, (q31_t)0x2ec9db35, (q31_t)0xc25b96ee, + (q31_t)0x2ebdc110, (q31_t)0xc25ef943, (q31_t)0x2eb1a796, (q31_t)0xc2625df8, + (q31_t)0x2ea58ec6, (q31_t)0xc265c50e, (q31_t)0x2e9976a1, (q31_t)0xc2692e83, + (q31_t)0x2e8d5f29, (q31_t)0xc26c9a58, (q31_t)0x2e81485c, (q31_t)0xc270088e, + (q31_t)0x2e75323c, (q31_t)0xc2737922, (q31_t)0x2e691cc9, (q31_t)0xc276ec16, + (q31_t)0x2e5d0804, (q31_t)0xc27a616a, (q31_t)0x2e50f3ed, (q31_t)0xc27dd91c, + (q31_t)0x2e44e084, (q31_t)0xc281532e, (q31_t)0x2e38cdcb, (q31_t)0xc284cf9f, + (q31_t)0x2e2cbbc1, (q31_t)0xc2884e6e, (q31_t)0x2e20aa67, (q31_t)0xc28bcf9c, + (q31_t)0x2e1499bd, (q31_t)0xc28f5329, (q31_t)0x2e0889c4, (q31_t)0xc292d914, + (q31_t)0x2dfc7a7c, (q31_t)0xc296615d, (q31_t)0x2df06be6, (q31_t)0xc299ec05, + (q31_t)0x2de45e03, (q31_t)0xc29d790a, (q31_t)0x2dd850d2, (q31_t)0xc2a1086d, + (q31_t)0x2dcc4454, (q31_t)0xc2a49a2e, (q31_t)0x2dc0388a, (q31_t)0xc2a82e4d, + (q31_t)0x2db42d74, (q31_t)0xc2abc4c9, (q31_t)0x2da82313, (q31_t)0xc2af5da2, + (q31_t)0x2d9c1967, (q31_t)0xc2b2f8d8, (q31_t)0x2d901070, (q31_t)0xc2b6966c, + (q31_t)0x2d84082f, (q31_t)0xc2ba365c, (q31_t)0x2d7800a5, (q31_t)0xc2bdd8a9, + (q31_t)0x2d6bf9d1, (q31_t)0xc2c17d52, (q31_t)0x2d5ff3b5, (q31_t)0xc2c52459, + (q31_t)0x2d53ee51, (q31_t)0xc2c8cdbb, (q31_t)0x2d47e9a5, (q31_t)0xc2cc7979, + (q31_t)0x2d3be5b1, (q31_t)0xc2d02794, (q31_t)0x2d2fe277, (q31_t)0xc2d3d80a, + (q31_t)0x2d23dff7, (q31_t)0xc2d78add, (q31_t)0x2d17de31, (q31_t)0xc2db400a, + (q31_t)0x2d0bdd25, (q31_t)0xc2def794, (q31_t)0x2cffdcd4, (q31_t)0xc2e2b178, + (q31_t)0x2cf3dd3f, (q31_t)0xc2e66db8, (q31_t)0x2ce7de66, (q31_t)0xc2ea2c53, + (q31_t)0x2cdbe04a, (q31_t)0xc2eded49, (q31_t)0x2ccfe2ea, (q31_t)0xc2f1b099, + (q31_t)0x2cc3e648, (q31_t)0xc2f57644, (q31_t)0x2cb7ea63, (q31_t)0xc2f93e4a, + (q31_t)0x2cabef3d, (q31_t)0xc2fd08a9, (q31_t)0x2c9ff4d6, (q31_t)0xc300d563, + (q31_t)0x2c93fb2e, (q31_t)0xc304a477, (q31_t)0x2c880245, (q31_t)0xc30875e5, + (q31_t)0x2c7c0a1d, (q31_t)0xc30c49ad, (q31_t)0x2c7012b5, (q31_t)0xc3101fce, + (q31_t)0x2c641c0e, (q31_t)0xc313f848, (q31_t)0x2c582629, (q31_t)0xc317d31c, + (q31_t)0x2c4c3106, (q31_t)0xc31bb049, (q31_t)0x2c403ca5, (q31_t)0xc31f8fcf, + (q31_t)0x2c344908, (q31_t)0xc32371ae, (q31_t)0x2c28562d, (q31_t)0xc32755e5, + (q31_t)0x2c1c6417, (q31_t)0xc32b3c75, (q31_t)0x2c1072c4, (q31_t)0xc32f255e, + (q31_t)0x2c048237, (q31_t)0xc333109e, (q31_t)0x2bf8926f, (q31_t)0xc336fe37, + (q31_t)0x2beca36c, (q31_t)0xc33aee27, (q31_t)0x2be0b52f, (q31_t)0xc33ee070, + (q31_t)0x2bd4c7ba, (q31_t)0xc342d510, (q31_t)0x2bc8db0b, (q31_t)0xc346cc07, + (q31_t)0x2bbcef23, (q31_t)0xc34ac556, (q31_t)0x2bb10404, (q31_t)0xc34ec0fc, + (q31_t)0x2ba519ad, (q31_t)0xc352bef9, (q31_t)0x2b99301f, (q31_t)0xc356bf4d, + (q31_t)0x2b8d475b, (q31_t)0xc35ac1f7, (q31_t)0x2b815f60, (q31_t)0xc35ec6f8, + (q31_t)0x2b75782f, (q31_t)0xc362ce50, (q31_t)0x2b6991ca, (q31_t)0xc366d7fd, + (q31_t)0x2b5dac2f, (q31_t)0xc36ae401, (q31_t)0x2b51c760, (q31_t)0xc36ef25b, + (q31_t)0x2b45e35d, (q31_t)0xc373030a, (q31_t)0x2b3a0027, (q31_t)0xc377160f, + (q31_t)0x2b2e1dbe, (q31_t)0xc37b2b6a, (q31_t)0x2b223c22, (q31_t)0xc37f4319, + (q31_t)0x2b165b54, (q31_t)0xc3835d1e, (q31_t)0x2b0a7b54, (q31_t)0xc3877978, + (q31_t)0x2afe9c24, (q31_t)0xc38b9827, (q31_t)0x2af2bdc3, (q31_t)0xc38fb92a, + (q31_t)0x2ae6e031, (q31_t)0xc393dc82, (q31_t)0x2adb0370, (q31_t)0xc398022f, + (q31_t)0x2acf277f, (q31_t)0xc39c2a2f, (q31_t)0x2ac34c60, (q31_t)0xc3a05484, + (q31_t)0x2ab77212, (q31_t)0xc3a4812c, (q31_t)0x2aab9896, (q31_t)0xc3a8b028, + (q31_t)0x2a9fbfed, (q31_t)0xc3ace178, (q31_t)0x2a93e817, (q31_t)0xc3b1151b, + (q31_t)0x2a881114, (q31_t)0xc3b54b11, (q31_t)0x2a7c3ae5, (q31_t)0xc3b9835a, + (q31_t)0x2a70658a, (q31_t)0xc3bdbdf6, (q31_t)0x2a649105, (q31_t)0xc3c1fae5, + (q31_t)0x2a58bd54, (q31_t)0xc3c63a26, (q31_t)0x2a4cea79, (q31_t)0xc3ca7bba, + (q31_t)0x2a411874, (q31_t)0xc3cebfa0, (q31_t)0x2a354746, (q31_t)0xc3d305d8, + (q31_t)0x2a2976ef, (q31_t)0xc3d74e62, (q31_t)0x2a1da770, (q31_t)0xc3db993e, + (q31_t)0x2a11d8c8, (q31_t)0xc3dfe66c, (q31_t)0x2a060af9, (q31_t)0xc3e435ea, + (q31_t)0x29fa3e03, (q31_t)0xc3e887bb, (q31_t)0x29ee71e6, (q31_t)0xc3ecdbdc, + (q31_t)0x29e2a6a3, (q31_t)0xc3f1324e, (q31_t)0x29d6dc3b, (q31_t)0xc3f58b10, + (q31_t)0x29cb12ad, (q31_t)0xc3f9e624, (q31_t)0x29bf49fa, (q31_t)0xc3fe4388, + (q31_t)0x29b38223, (q31_t)0xc402a33c, (q31_t)0x29a7bb28, (q31_t)0xc4070540, + (q31_t)0x299bf509, (q31_t)0xc40b6994, (q31_t)0x29902fc7, (q31_t)0xc40fd037, + (q31_t)0x29846b63, (q31_t)0xc414392b, (q31_t)0x2978a7dd, (q31_t)0xc418a46d, + (q31_t)0x296ce535, (q31_t)0xc41d11ff, (q31_t)0x2961236c, (q31_t)0xc42181e0, + (q31_t)0x29556282, (q31_t)0xc425f410, (q31_t)0x2949a278, (q31_t)0xc42a688f, + (q31_t)0x293de34e, (q31_t)0xc42edf5c, (q31_t)0x29322505, (q31_t)0xc4335877, + (q31_t)0x2926679c, (q31_t)0xc437d3e1, (q31_t)0x291aab16, (q31_t)0xc43c5199, + (q31_t)0x290eef71, (q31_t)0xc440d19e, (q31_t)0x290334af, (q31_t)0xc44553f2, + (q31_t)0x28f77acf, (q31_t)0xc449d892, (q31_t)0x28ebc1d3, (q31_t)0xc44e5f80, + (q31_t)0x28e009ba, (q31_t)0xc452e8bc, (q31_t)0x28d45286, (q31_t)0xc4577444, + (q31_t)0x28c89c37, (q31_t)0xc45c0219, (q31_t)0x28bce6cd, (q31_t)0xc460923b, + (q31_t)0x28b13248, (q31_t)0xc46524a9, (q31_t)0x28a57ea9, (q31_t)0xc469b963, + (q31_t)0x2899cbf1, (q31_t)0xc46e5069, (q31_t)0x288e1a20, (q31_t)0xc472e9bc, + (q31_t)0x28826936, (q31_t)0xc477855a, (q31_t)0x2876b934, (q31_t)0xc47c2344, + (q31_t)0x286b0a1a, (q31_t)0xc480c379, (q31_t)0x285f5be9, (q31_t)0xc48565f9, + (q31_t)0x2853aea1, (q31_t)0xc48a0ac4, (q31_t)0x28480243, (q31_t)0xc48eb1db, + (q31_t)0x283c56cf, (q31_t)0xc4935b3c, (q31_t)0x2830ac45, (q31_t)0xc49806e7, + (q31_t)0x282502a7, (q31_t)0xc49cb4dd, (q31_t)0x281959f4, (q31_t)0xc4a1651c, + (q31_t)0x280db22d, (q31_t)0xc4a617a6, (q31_t)0x28020b52, (q31_t)0xc4aacc7a, + (q31_t)0x27f66564, (q31_t)0xc4af8397, (q31_t)0x27eac063, (q31_t)0xc4b43cfd, + (q31_t)0x27df1c50, (q31_t)0xc4b8f8ad, (q31_t)0x27d3792b, (q31_t)0xc4bdb6a6, + (q31_t)0x27c7d6f4, (q31_t)0xc4c276e8, (q31_t)0x27bc35ad, (q31_t)0xc4c73972, + (q31_t)0x27b09555, (q31_t)0xc4cbfe45, (q31_t)0x27a4f5ed, (q31_t)0xc4d0c560, + (q31_t)0x27995776, (q31_t)0xc4d58ec3, (q31_t)0x278db9ef, (q31_t)0xc4da5a6f, + (q31_t)0x27821d59, (q31_t)0xc4df2862, (q31_t)0x277681b6, (q31_t)0xc4e3f89c, + (q31_t)0x276ae704, (q31_t)0xc4e8cb1e, (q31_t)0x275f4d45, (q31_t)0xc4ed9fe7, + (q31_t)0x2753b479, (q31_t)0xc4f276f7, (q31_t)0x27481ca1, (q31_t)0xc4f7504e, + (q31_t)0x273c85bc, (q31_t)0xc4fc2bec, (q31_t)0x2730efcc, (q31_t)0xc50109d0, + (q31_t)0x27255ad1, (q31_t)0xc505e9fb, (q31_t)0x2719c6cb, (q31_t)0xc50acc6b, + (q31_t)0x270e33bb, (q31_t)0xc50fb121, (q31_t)0x2702a1a1, (q31_t)0xc514981d, + (q31_t)0x26f7107e, (q31_t)0xc519815f, (q31_t)0x26eb8052, (q31_t)0xc51e6ce6, + (q31_t)0x26dff11d, (q31_t)0xc5235ab2, (q31_t)0x26d462e1, (q31_t)0xc5284ac3, + (q31_t)0x26c8d59c, (q31_t)0xc52d3d18, (q31_t)0x26bd4951, (q31_t)0xc53231b3, + (q31_t)0x26b1bdff, (q31_t)0xc5372891, (q31_t)0x26a633a6, (q31_t)0xc53c21b4, + (q31_t)0x269aaa48, (q31_t)0xc5411d1b, (q31_t)0x268f21e5, (q31_t)0xc5461ac6, + (q31_t)0x26839a7c, (q31_t)0xc54b1ab4, (q31_t)0x26781410, (q31_t)0xc5501ce5, + (q31_t)0x266c8e9f, (q31_t)0xc555215a, (q31_t)0x26610a2a, (q31_t)0xc55a2812, + (q31_t)0x265586b3, (q31_t)0xc55f310d, (q31_t)0x264a0438, (q31_t)0xc5643c4a, + (q31_t)0x263e82bc, (q31_t)0xc56949ca, (q31_t)0x2633023e, (q31_t)0xc56e598c, + (q31_t)0x262782be, (q31_t)0xc5736b90, (q31_t)0x261c043d, (q31_t)0xc5787fd6, + (q31_t)0x261086bc, (q31_t)0xc57d965d, (q31_t)0x26050a3b, (q31_t)0xc582af26, + (q31_t)0x25f98ebb, (q31_t)0xc587ca31, (q31_t)0x25ee143b, (q31_t)0xc58ce77c, + (q31_t)0x25e29abc, (q31_t)0xc5920708, (q31_t)0x25d72240, (q31_t)0xc59728d5, + (q31_t)0x25cbaac5, (q31_t)0xc59c4ce3, (q31_t)0x25c0344d, (q31_t)0xc5a17330, + (q31_t)0x25b4bed8, (q31_t)0xc5a69bbe, (q31_t)0x25a94a67, (q31_t)0xc5abc68c, + (q31_t)0x259dd6f9, (q31_t)0xc5b0f399, (q31_t)0x25926490, (q31_t)0xc5b622e6, + (q31_t)0x2586f32c, (q31_t)0xc5bb5472, (q31_t)0x257b82cd, (q31_t)0xc5c0883d, + (q31_t)0x25701374, (q31_t)0xc5c5be47, (q31_t)0x2564a521, (q31_t)0xc5caf690, + (q31_t)0x255937d5, (q31_t)0xc5d03118, (q31_t)0x254dcb8f, (q31_t)0xc5d56ddd, + (q31_t)0x25426051, (q31_t)0xc5daace1, (q31_t)0x2536f61b, (q31_t)0xc5dfee22, + (q31_t)0x252b8cee, (q31_t)0xc5e531a1, (q31_t)0x252024c9, (q31_t)0xc5ea775e, + (q31_t)0x2514bdad, (q31_t)0xc5efbf58, (q31_t)0x2509579b, (q31_t)0xc5f5098f, + (q31_t)0x24fdf294, (q31_t)0xc5fa5603, (q31_t)0x24f28e96, (q31_t)0xc5ffa4b3, + (q31_t)0x24e72ba4, (q31_t)0xc604f5a0, (q31_t)0x24dbc9bd, (q31_t)0xc60a48c9, + (q31_t)0x24d068e2, (q31_t)0xc60f9e2e, (q31_t)0x24c50914, (q31_t)0xc614f5cf, + (q31_t)0x24b9aa52, (q31_t)0xc61a4fac, (q31_t)0x24ae4c9d, (q31_t)0xc61fabc4, + (q31_t)0x24a2eff6, (q31_t)0xc6250a18, (q31_t)0x2497945d, (q31_t)0xc62a6aa6, + (q31_t)0x248c39d3, (q31_t)0xc62fcd6f, (q31_t)0x2480e057, (q31_t)0xc6353273, + (q31_t)0x247587eb, (q31_t)0xc63a99b1, (q31_t)0x246a308f, (q31_t)0xc6400329, + (q31_t)0x245eda43, (q31_t)0xc6456edb, (q31_t)0x24538507, (q31_t)0xc64adcc7, + (q31_t)0x244830dd, (q31_t)0xc6504ced, (q31_t)0x243cddc4, (q31_t)0xc655bf4c, + (q31_t)0x24318bbe, (q31_t)0xc65b33e4, (q31_t)0x24263ac9, (q31_t)0xc660aab5, + (q31_t)0x241aeae8, (q31_t)0xc66623be, (q31_t)0x240f9c1a, (q31_t)0xc66b9f01, + (q31_t)0x24044e60, (q31_t)0xc6711c7b, (q31_t)0x23f901ba, (q31_t)0xc6769c2e, + (q31_t)0x23edb628, (q31_t)0xc67c1e18, (q31_t)0x23e26bac, (q31_t)0xc681a23a, + (q31_t)0x23d72245, (q31_t)0xc6872894, (q31_t)0x23cbd9f4, (q31_t)0xc68cb124, + (q31_t)0x23c092b9, (q31_t)0xc6923bec, (q31_t)0x23b54c95, (q31_t)0xc697c8eb, + (q31_t)0x23aa0788, (q31_t)0xc69d5820, (q31_t)0x239ec393, (q31_t)0xc6a2e98b, + (q31_t)0x239380b6, (q31_t)0xc6a87d2d, (q31_t)0x23883ef2, (q31_t)0xc6ae1304, + (q31_t)0x237cfe47, (q31_t)0xc6b3ab12, (q31_t)0x2371beb5, (q31_t)0xc6b94554, + (q31_t)0x2366803c, (q31_t)0xc6bee1cd, (q31_t)0x235b42df, (q31_t)0xc6c4807a, + (q31_t)0x2350069b, (q31_t)0xc6ca215c, (q31_t)0x2344cb73, (q31_t)0xc6cfc472, + (q31_t)0x23399167, (q31_t)0xc6d569be, (q31_t)0x232e5876, (q31_t)0xc6db113d, + (q31_t)0x232320a2, (q31_t)0xc6e0baf0, (q31_t)0x2317e9eb, (q31_t)0xc6e666d7, + (q31_t)0x230cb451, (q31_t)0xc6ec14f2, (q31_t)0x23017fd5, (q31_t)0xc6f1c540, + (q31_t)0x22f64c77, (q31_t)0xc6f777c1, (q31_t)0x22eb1a37, (q31_t)0xc6fd2c75, + (q31_t)0x22dfe917, (q31_t)0xc702e35c, (q31_t)0x22d4b916, (q31_t)0xc7089c75, + (q31_t)0x22c98a35, (q31_t)0xc70e57c0, (q31_t)0x22be5c74, (q31_t)0xc714153e, + (q31_t)0x22b32fd4, (q31_t)0xc719d4ed, (q31_t)0x22a80456, (q31_t)0xc71f96ce, + (q31_t)0x229cd9f8, (q31_t)0xc7255ae0, (q31_t)0x2291b0bd, (q31_t)0xc72b2123, + (q31_t)0x228688a4, (q31_t)0xc730e997, (q31_t)0x227b61af, (q31_t)0xc736b43c, + (q31_t)0x22703bdc, (q31_t)0xc73c8111, (q31_t)0x2265172e, (q31_t)0xc7425016, + (q31_t)0x2259f3a3, (q31_t)0xc748214c, (q31_t)0x224ed13d, (q31_t)0xc74df4b1, + (q31_t)0x2243affc, (q31_t)0xc753ca46, (q31_t)0x22388fe1, (q31_t)0xc759a20a, + (q31_t)0x222d70eb, (q31_t)0xc75f7bfe, (q31_t)0x2222531c, (q31_t)0xc7655820, + (q31_t)0x22173674, (q31_t)0xc76b3671, (q31_t)0x220c1af3, (q31_t)0xc77116f0, + (q31_t)0x22010099, (q31_t)0xc776f99d, (q31_t)0x21f5e768, (q31_t)0xc77cde79, + (q31_t)0x21eacf5f, (q31_t)0xc782c582, (q31_t)0x21dfb87f, (q31_t)0xc788aeb9, + (q31_t)0x21d4a2c8, (q31_t)0xc78e9a1d, (q31_t)0x21c98e3b, (q31_t)0xc79487ae, + (q31_t)0x21be7ad8, (q31_t)0xc79a776c, (q31_t)0x21b368a0, (q31_t)0xc7a06957, + (q31_t)0x21a85793, (q31_t)0xc7a65d6e, (q31_t)0x219d47b1, (q31_t)0xc7ac53b1, + (q31_t)0x219238fb, (q31_t)0xc7b24c20, (q31_t)0x21872b72, (q31_t)0xc7b846ba, + (q31_t)0x217c1f15, (q31_t)0xc7be4381, (q31_t)0x217113e5, (q31_t)0xc7c44272, + (q31_t)0x216609e3, (q31_t)0xc7ca438f, (q31_t)0x215b0110, (q31_t)0xc7d046d6, + (q31_t)0x214ff96a, (q31_t)0xc7d64c47, (q31_t)0x2144f2f3, (q31_t)0xc7dc53e3, + (q31_t)0x2139edac, (q31_t)0xc7e25daa, (q31_t)0x212ee995, (q31_t)0xc7e8699a, + (q31_t)0x2123e6ad, (q31_t)0xc7ee77b3, (q31_t)0x2118e4f6, (q31_t)0xc7f487f6, + (q31_t)0x210de470, (q31_t)0xc7fa9a62, (q31_t)0x2102e51c, (q31_t)0xc800aef7, + (q31_t)0x20f7e6f9, (q31_t)0xc806c5b5, (q31_t)0x20ecea09, (q31_t)0xc80cde9b, + (q31_t)0x20e1ee4b, (q31_t)0xc812f9a9, (q31_t)0x20d6f3c1, (q31_t)0xc81916df, + (q31_t)0x20cbfa6a, (q31_t)0xc81f363d, (q31_t)0x20c10247, (q31_t)0xc82557c3, + (q31_t)0x20b60b58, (q31_t)0xc82b7b70, (q31_t)0x20ab159e, (q31_t)0xc831a143, + (q31_t)0x20a0211a, (q31_t)0xc837c93e, (q31_t)0x20952dcb, (q31_t)0xc83df35f, + (q31_t)0x208a3bb2, (q31_t)0xc8441fa6, (q31_t)0x207f4acf, (q31_t)0xc84a4e14, + (q31_t)0x20745b24, (q31_t)0xc8507ea7, (q31_t)0x20696cb0, (q31_t)0xc856b160, + (q31_t)0x205e7f74, (q31_t)0xc85ce63e, (q31_t)0x2053936f, (q31_t)0xc8631d42, + (q31_t)0x2048a8a4, (q31_t)0xc869566a, (q31_t)0x203dbf11, (q31_t)0xc86f91b7, + (q31_t)0x2032d6b8, (q31_t)0xc875cf28, (q31_t)0x2027ef99, (q31_t)0xc87c0ebd, + (q31_t)0x201d09b4, (q31_t)0xc8825077, (q31_t)0x2012250a, (q31_t)0xc8889454, + (q31_t)0x2007419b, (q31_t)0xc88eda54, (q31_t)0x1ffc5f67, (q31_t)0xc8952278, + (q31_t)0x1ff17e70, (q31_t)0xc89b6cbf, (q31_t)0x1fe69eb4, (q31_t)0xc8a1b928, + (q31_t)0x1fdbc036, (q31_t)0xc8a807b4, (q31_t)0x1fd0e2f5, (q31_t)0xc8ae5862, + (q31_t)0x1fc606f1, (q31_t)0xc8b4ab32, (q31_t)0x1fbb2c2c, (q31_t)0xc8bb0023, + (q31_t)0x1fb052a5, (q31_t)0xc8c15736, (q31_t)0x1fa57a5d, (q31_t)0xc8c7b06b, + (q31_t)0x1f9aa354, (q31_t)0xc8ce0bc0, (q31_t)0x1f8fcd8b, (q31_t)0xc8d46936, + (q31_t)0x1f84f902, (q31_t)0xc8dac8cd, (q31_t)0x1f7a25ba, (q31_t)0xc8e12a84, + (q31_t)0x1f6f53b3, (q31_t)0xc8e78e5b, (q31_t)0x1f6482ed, (q31_t)0xc8edf452, + (q31_t)0x1f59b369, (q31_t)0xc8f45c68, (q31_t)0x1f4ee527, (q31_t)0xc8fac69e, + (q31_t)0x1f441828, (q31_t)0xc90132f2, (q31_t)0x1f394c6b, (q31_t)0xc907a166, + (q31_t)0x1f2e81f3, (q31_t)0xc90e11f7, (q31_t)0x1f23b8be, (q31_t)0xc91484a8, + (q31_t)0x1f18f0ce, (q31_t)0xc91af976, (q31_t)0x1f0e2a22, (q31_t)0xc9217062, + (q31_t)0x1f0364bc, (q31_t)0xc927e96b, (q31_t)0x1ef8a09b, (q31_t)0xc92e6492, + (q31_t)0x1eedddc0, (q31_t)0xc934e1d6, (q31_t)0x1ee31c2b, (q31_t)0xc93b6137, + (q31_t)0x1ed85bdd, (q31_t)0xc941e2b4, (q31_t)0x1ecd9cd7, (q31_t)0xc948664d, + (q31_t)0x1ec2df18, (q31_t)0xc94eec03, (q31_t)0x1eb822a1, (q31_t)0xc95573d4, + (q31_t)0x1ead6773, (q31_t)0xc95bfdc1, (q31_t)0x1ea2ad8d, (q31_t)0xc96289c9, + (q31_t)0x1e97f4f1, (q31_t)0xc96917ec, (q31_t)0x1e8d3d9e, (q31_t)0xc96fa82a, + (q31_t)0x1e828796, (q31_t)0xc9763a83, (q31_t)0x1e77d2d8, (q31_t)0xc97ccef5, + (q31_t)0x1e6d1f65, (q31_t)0xc9836582, (q31_t)0x1e626d3e, (q31_t)0xc989fe29, + (q31_t)0x1e57bc62, (q31_t)0xc99098e9, (q31_t)0x1e4d0cd2, (q31_t)0xc99735c2, + (q31_t)0x1e425e8f, (q31_t)0xc99dd4b4, (q31_t)0x1e37b199, (q31_t)0xc9a475bf, + (q31_t)0x1e2d05f1, (q31_t)0xc9ab18e3, (q31_t)0x1e225b96, (q31_t)0xc9b1be1e, + (q31_t)0x1e17b28a, (q31_t)0xc9b86572, (q31_t)0x1e0d0acc, (q31_t)0xc9bf0edd, + (q31_t)0x1e02645d, (q31_t)0xc9c5ba60, (q31_t)0x1df7bf3e, (q31_t)0xc9cc67fa, + (q31_t)0x1ded1b6e, (q31_t)0xc9d317ab, (q31_t)0x1de278ef, (q31_t)0xc9d9c973, + (q31_t)0x1dd7d7c1, (q31_t)0xc9e07d51, (q31_t)0x1dcd37e4, (q31_t)0xc9e73346, + (q31_t)0x1dc29958, (q31_t)0xc9edeb50, (q31_t)0x1db7fc1e, (q31_t)0xc9f4a570, + (q31_t)0x1dad6036, (q31_t)0xc9fb61a5, (q31_t)0x1da2c5a2, (q31_t)0xca021fef, + (q31_t)0x1d982c60, (q31_t)0xca08e04f, (q31_t)0x1d8d9472, (q31_t)0xca0fa2c3, + (q31_t)0x1d82fdd8, (q31_t)0xca16674b, (q31_t)0x1d786892, (q31_t)0xca1d2de7, + (q31_t)0x1d6dd4a2, (q31_t)0xca23f698, (q31_t)0x1d634206, (q31_t)0xca2ac15b, + (q31_t)0x1d58b0c0, (q31_t)0xca318e32, (q31_t)0x1d4e20d0, (q31_t)0xca385d1d, + (q31_t)0x1d439236, (q31_t)0xca3f2e19, (q31_t)0x1d3904f4, (q31_t)0xca460129, + (q31_t)0x1d2e7908, (q31_t)0xca4cd64b, (q31_t)0x1d23ee74, (q31_t)0xca53ad7e, + (q31_t)0x1d196538, (q31_t)0xca5a86c4, (q31_t)0x1d0edd55, (q31_t)0xca61621b, + (q31_t)0x1d0456ca, (q31_t)0xca683f83, (q31_t)0x1cf9d199, (q31_t)0xca6f1efc, + (q31_t)0x1cef4dc2, (q31_t)0xca760086, (q31_t)0x1ce4cb44, (q31_t)0xca7ce420, + (q31_t)0x1cda4a21, (q31_t)0xca83c9ca, (q31_t)0x1ccfca59, (q31_t)0xca8ab184, + (q31_t)0x1cc54bec, (q31_t)0xca919b4e, (q31_t)0x1cbacedb, (q31_t)0xca988727, + (q31_t)0x1cb05326, (q31_t)0xca9f750f, (q31_t)0x1ca5d8cd, (q31_t)0xcaa66506, + (q31_t)0x1c9b5fd2, (q31_t)0xcaad570c, (q31_t)0x1c90e834, (q31_t)0xcab44b1f, + (q31_t)0x1c8671f3, (q31_t)0xcabb4141, (q31_t)0x1c7bfd11, (q31_t)0xcac23971, + (q31_t)0x1c71898d, (q31_t)0xcac933ae, (q31_t)0x1c671768, (q31_t)0xcad02ff8, + (q31_t)0x1c5ca6a2, (q31_t)0xcad72e4f, (q31_t)0x1c52373c, (q31_t)0xcade2eb3, + (q31_t)0x1c47c936, (q31_t)0xcae53123, (q31_t)0x1c3d5c91, (q31_t)0xcaec35a0, + (q31_t)0x1c32f14d, (q31_t)0xcaf33c28, (q31_t)0x1c28876a, (q31_t)0xcafa44bc, + (q31_t)0x1c1e1ee9, (q31_t)0xcb014f5b, (q31_t)0x1c13b7c9, (q31_t)0xcb085c05, + (q31_t)0x1c09520d, (q31_t)0xcb0f6aba, (q31_t)0x1bfeedb3, (q31_t)0xcb167b79, + (q31_t)0x1bf48abd, (q31_t)0xcb1d8e43, (q31_t)0x1bea292b, (q31_t)0xcb24a316, + (q31_t)0x1bdfc8fc, (q31_t)0xcb2bb9f4, (q31_t)0x1bd56a32, (q31_t)0xcb32d2da, + (q31_t)0x1bcb0cce, (q31_t)0xcb39edca, (q31_t)0x1bc0b0ce, (q31_t)0xcb410ac3, + (q31_t)0x1bb65634, (q31_t)0xcb4829c4, (q31_t)0x1babfd01, (q31_t)0xcb4f4acd, + (q31_t)0x1ba1a534, (q31_t)0xcb566ddf, (q31_t)0x1b974ece, (q31_t)0xcb5d92f8, + (q31_t)0x1b8cf9cf, (q31_t)0xcb64ba19, (q31_t)0x1b82a638, (q31_t)0xcb6be341, + (q31_t)0x1b785409, (q31_t)0xcb730e70, (q31_t)0x1b6e0342, (q31_t)0xcb7a3ba5, + (q31_t)0x1b63b3e5, (q31_t)0xcb816ae1, (q31_t)0x1b5965f1, (q31_t)0xcb889c23, + (q31_t)0x1b4f1967, (q31_t)0xcb8fcf6b, (q31_t)0x1b44ce46, (q31_t)0xcb9704b9, + (q31_t)0x1b3a8491, (q31_t)0xcb9e3c0b, (q31_t)0x1b303c46, (q31_t)0xcba57563, + (q31_t)0x1b25f566, (q31_t)0xcbacb0bf, (q31_t)0x1b1baff2, (q31_t)0xcbb3ee20, + (q31_t)0x1b116beb, (q31_t)0xcbbb2d85, (q31_t)0x1b072950, (q31_t)0xcbc26eee, + (q31_t)0x1afce821, (q31_t)0xcbc9b25a, (q31_t)0x1af2a860, (q31_t)0xcbd0f7ca, + (q31_t)0x1ae86a0d, (q31_t)0xcbd83f3d, (q31_t)0x1ade2d28, (q31_t)0xcbdf88b3, + (q31_t)0x1ad3f1b1, (q31_t)0xcbe6d42b, (q31_t)0x1ac9b7a9, (q31_t)0xcbee21a5, + (q31_t)0x1abf7f11, (q31_t)0xcbf57121, (q31_t)0x1ab547e8, (q31_t)0xcbfcc29f, + (q31_t)0x1aab122f, (q31_t)0xcc04161e, (q31_t)0x1aa0dde7, (q31_t)0xcc0b6b9e, + (q31_t)0x1a96ab0f, (q31_t)0xcc12c31f, (q31_t)0x1a8c79a9, (q31_t)0xcc1a1ca0, + (q31_t)0x1a8249b4, (q31_t)0xcc217822, (q31_t)0x1a781b31, (q31_t)0xcc28d5a3, + (q31_t)0x1a6dee21, (q31_t)0xcc303524, (q31_t)0x1a63c284, (q31_t)0xcc3796a5, + (q31_t)0x1a599859, (q31_t)0xcc3efa25, (q31_t)0x1a4f6fa3, (q31_t)0xcc465fa3, + (q31_t)0x1a454860, (q31_t)0xcc4dc720, (q31_t)0x1a3b2292, (q31_t)0xcc55309b, + (q31_t)0x1a30fe38, (q31_t)0xcc5c9c14, (q31_t)0x1a26db54, (q31_t)0xcc64098b, + (q31_t)0x1a1cb9e5, (q31_t)0xcc6b78ff, (q31_t)0x1a1299ec, (q31_t)0xcc72ea70, + (q31_t)0x1a087b69, (q31_t)0xcc7a5dde, (q31_t)0x19fe5e5e, (q31_t)0xcc81d349, + (q31_t)0x19f442c9, (q31_t)0xcc894aaf, (q31_t)0x19ea28ac, (q31_t)0xcc90c412, + (q31_t)0x19e01006, (q31_t)0xcc983f70, (q31_t)0x19d5f8d9, (q31_t)0xcc9fbcca, + (q31_t)0x19cbe325, (q31_t)0xcca73c1e, (q31_t)0x19c1cee9, (q31_t)0xccaebd6e, + (q31_t)0x19b7bc27, (q31_t)0xccb640b8, (q31_t)0x19adaadf, (q31_t)0xccbdc5fc, + (q31_t)0x19a39b11, (q31_t)0xccc54d3a, (q31_t)0x19998cbe, (q31_t)0xccccd671, + (q31_t)0x198f7fe6, (q31_t)0xccd461a2, (q31_t)0x19857489, (q31_t)0xccdbeecc, + (q31_t)0x197b6aa8, (q31_t)0xcce37def, (q31_t)0x19716243, (q31_t)0xcceb0f0a, + (q31_t)0x19675b5a, (q31_t)0xccf2a21d, (q31_t)0x195d55ef, (q31_t)0xccfa3729, + (q31_t)0x19535201, (q31_t)0xcd01ce2b, (q31_t)0x19494f90, (q31_t)0xcd096725, + (q31_t)0x193f4e9e, (q31_t)0xcd110216, (q31_t)0x19354f2a, (q31_t)0xcd189efe, + (q31_t)0x192b5135, (q31_t)0xcd203ddc, (q31_t)0x192154bf, (q31_t)0xcd27deb0, + (q31_t)0x191759c9, (q31_t)0xcd2f817b, (q31_t)0x190d6053, (q31_t)0xcd37263a, + (q31_t)0x1903685d, (q31_t)0xcd3eccef, (q31_t)0x18f971e8, (q31_t)0xcd467599, + (q31_t)0x18ef7cf4, (q31_t)0xcd4e2037, (q31_t)0x18e58982, (q31_t)0xcd55ccca, + (q31_t)0x18db9792, (q31_t)0xcd5d7b50, (q31_t)0x18d1a724, (q31_t)0xcd652bcb, + (q31_t)0x18c7b838, (q31_t)0xcd6cde39, (q31_t)0x18bdcad0, (q31_t)0xcd74929a, + (q31_t)0x18b3deeb, (q31_t)0xcd7c48ee, (q31_t)0x18a9f48a, (q31_t)0xcd840134, + (q31_t)0x18a00bae, (q31_t)0xcd8bbb6d, (q31_t)0x18962456, (q31_t)0xcd937798, + (q31_t)0x188c3e83, (q31_t)0xcd9b35b4, (q31_t)0x18825a35, (q31_t)0xcda2f5c2, + (q31_t)0x1878776d, (q31_t)0xcdaab7c0, (q31_t)0x186e962b, (q31_t)0xcdb27bb0, + (q31_t)0x1864b670, (q31_t)0xcdba4190, (q31_t)0x185ad83c, (q31_t)0xcdc20960, + (q31_t)0x1850fb8e, (q31_t)0xcdc9d320, (q31_t)0x18472069, (q31_t)0xcdd19ed0, + (q31_t)0x183d46cc, (q31_t)0xcdd96c6f, (q31_t)0x18336eb7, (q31_t)0xcde13bfd, + (q31_t)0x1829982b, (q31_t)0xcde90d79, (q31_t)0x181fc328, (q31_t)0xcdf0e0e4, + (q31_t)0x1815efae, (q31_t)0xcdf8b63d, (q31_t)0x180c1dbf, (q31_t)0xce008d84, + (q31_t)0x18024d59, (q31_t)0xce0866b8, (q31_t)0x17f87e7f, (q31_t)0xce1041d9, + (q31_t)0x17eeb130, (q31_t)0xce181ee8, (q31_t)0x17e4e56c, (q31_t)0xce1ffde2, + (q31_t)0x17db1b34, (q31_t)0xce27dec9, (q31_t)0x17d15288, (q31_t)0xce2fc19c, + (q31_t)0x17c78b68, (q31_t)0xce37a65b, (q31_t)0x17bdc5d6, (q31_t)0xce3f8d05, + (q31_t)0x17b401d1, (q31_t)0xce47759a, (q31_t)0x17aa3f5a, (q31_t)0xce4f6019, + (q31_t)0x17a07e70, (q31_t)0xce574c84, (q31_t)0x1796bf16, (q31_t)0xce5f3ad8, + (q31_t)0x178d014a, (q31_t)0xce672b16, (q31_t)0x1783450d, (q31_t)0xce6f1d3d, + (q31_t)0x17798a60, (q31_t)0xce77114e, (q31_t)0x176fd143, (q31_t)0xce7f0748, + (q31_t)0x176619b6, (q31_t)0xce86ff2a, (q31_t)0x175c63ba, (q31_t)0xce8ef8f4, + (q31_t)0x1752af4f, (q31_t)0xce96f4a7, (q31_t)0x1748fc75, (q31_t)0xce9ef241, + (q31_t)0x173f4b2e, (q31_t)0xcea6f1c2, (q31_t)0x17359b78, (q31_t)0xceaef32b, + (q31_t)0x172bed55, (q31_t)0xceb6f67a, (q31_t)0x172240c5, (q31_t)0xcebefbb0, + (q31_t)0x171895c9, (q31_t)0xcec702cb, (q31_t)0x170eec60, (q31_t)0xcecf0bcd, + (q31_t)0x1705448b, (q31_t)0xced716b4, (q31_t)0x16fb9e4b, (q31_t)0xcedf2380, + (q31_t)0x16f1f99f, (q31_t)0xcee73231, (q31_t)0x16e85689, (q31_t)0xceef42c7, + (q31_t)0x16deb508, (q31_t)0xcef75541, (q31_t)0x16d5151d, (q31_t)0xceff699f, + (q31_t)0x16cb76c9, (q31_t)0xcf077fe1, (q31_t)0x16c1da0b, (q31_t)0xcf0f9805, + (q31_t)0x16b83ee4, (q31_t)0xcf17b20d, (q31_t)0x16aea555, (q31_t)0xcf1fcdf8, + (q31_t)0x16a50d5d, (q31_t)0xcf27ebc5, (q31_t)0x169b76fe, (q31_t)0xcf300b74, + (q31_t)0x1691e237, (q31_t)0xcf382d05, (q31_t)0x16884f09, (q31_t)0xcf405077, + (q31_t)0x167ebd74, (q31_t)0xcf4875ca, (q31_t)0x16752d79, (q31_t)0xcf509cfe, + (q31_t)0x166b9f18, (q31_t)0xcf58c613, (q31_t)0x16621251, (q31_t)0xcf60f108, + (q31_t)0x16588725, (q31_t)0xcf691ddd, (q31_t)0x164efd94, (q31_t)0xcf714c91, + (q31_t)0x1645759f, (q31_t)0xcf797d24, (q31_t)0x163bef46, (q31_t)0xcf81af97, + (q31_t)0x16326a88, (q31_t)0xcf89e3e8, (q31_t)0x1628e767, (q31_t)0xcf921a17, + (q31_t)0x161f65e4, (q31_t)0xcf9a5225, (q31_t)0x1615e5fd, (q31_t)0xcfa28c10, + (q31_t)0x160c67b4, (q31_t)0xcfaac7d8, (q31_t)0x1602eb0a, (q31_t)0xcfb3057d, + (q31_t)0x15f96ffd, (q31_t)0xcfbb4500, (q31_t)0x15eff690, (q31_t)0xcfc3865e, + (q31_t)0x15e67ec1, (q31_t)0xcfcbc999, (q31_t)0x15dd0892, (q31_t)0xcfd40eaf, + (q31_t)0x15d39403, (q31_t)0xcfdc55a1, (q31_t)0x15ca2115, (q31_t)0xcfe49e6d, + (q31_t)0x15c0afc6, (q31_t)0xcfece915, (q31_t)0x15b74019, (q31_t)0xcff53597, + (q31_t)0x15add20d, (q31_t)0xcffd83f4, (q31_t)0x15a465a3, (q31_t)0xd005d42a, + (q31_t)0x159afadb, (q31_t)0xd00e2639, (q31_t)0x159191b5, (q31_t)0xd0167a22, + (q31_t)0x15882a32, (q31_t)0xd01ecfe4, (q31_t)0x157ec452, (q31_t)0xd027277e, + (q31_t)0x15756016, (q31_t)0xd02f80f1, (q31_t)0x156bfd7d, (q31_t)0xd037dc3b, + (q31_t)0x15629c89, (q31_t)0xd040395d, (q31_t)0x15593d3a, (q31_t)0xd0489856, + (q31_t)0x154fdf8f, (q31_t)0xd050f926, (q31_t)0x15468389, (q31_t)0xd0595bcd, + (q31_t)0x153d292a, (q31_t)0xd061c04a, (q31_t)0x1533d070, (q31_t)0xd06a269d, + (q31_t)0x152a795d, (q31_t)0xd0728ec6, (q31_t)0x152123f0, (q31_t)0xd07af8c4, + (q31_t)0x1517d02b, (q31_t)0xd0836497, (q31_t)0x150e7e0d, (q31_t)0xd08bd23f, + (q31_t)0x15052d97, (q31_t)0xd09441bb, (q31_t)0x14fbdec9, (q31_t)0xd09cb30b, + (q31_t)0x14f291a4, (q31_t)0xd0a5262f, (q31_t)0x14e94627, (q31_t)0xd0ad9b26, + (q31_t)0x14dffc54, (q31_t)0xd0b611f1, (q31_t)0x14d6b42b, (q31_t)0xd0be8a8d, + (q31_t)0x14cd6dab, (q31_t)0xd0c704fd, (q31_t)0x14c428d6, (q31_t)0xd0cf813e, + (q31_t)0x14bae5ab, (q31_t)0xd0d7ff51, (q31_t)0x14b1a42c, (q31_t)0xd0e07f36, + (q31_t)0x14a86458, (q31_t)0xd0e900ec, (q31_t)0x149f2630, (q31_t)0xd0f18472, + (q31_t)0x1495e9b3, (q31_t)0xd0fa09c9, (q31_t)0x148caee4, (q31_t)0xd10290f0, + (q31_t)0x148375c1, (q31_t)0xd10b19e7, (q31_t)0x147a3e4b, (q31_t)0xd113a4ad, + (q31_t)0x14710883, (q31_t)0xd11c3142, (q31_t)0x1467d469, (q31_t)0xd124bfa6, + (q31_t)0x145ea1fd, (q31_t)0xd12d4fd9, (q31_t)0x14557140, (q31_t)0xd135e1d9, + (q31_t)0x144c4232, (q31_t)0xd13e75a8, (q31_t)0x144314d3, (q31_t)0xd1470b44, + (q31_t)0x1439e923, (q31_t)0xd14fa2ad, (q31_t)0x1430bf24, (q31_t)0xd1583be2, + (q31_t)0x142796d5, (q31_t)0xd160d6e5, (q31_t)0x141e7037, (q31_t)0xd16973b3, + (q31_t)0x14154b4a, (q31_t)0xd172124d, (q31_t)0x140c280e, (q31_t)0xd17ab2b3, + (q31_t)0x14030684, (q31_t)0xd18354e4, (q31_t)0x13f9e6ad, (q31_t)0xd18bf8e0, + (q31_t)0x13f0c887, (q31_t)0xd1949ea6, (q31_t)0x13e7ac15, (q31_t)0xd19d4636, + (q31_t)0x13de9156, (q31_t)0xd1a5ef90, (q31_t)0x13d5784a, (q31_t)0xd1ae9ab4, + (q31_t)0x13cc60f2, (q31_t)0xd1b747a0, (q31_t)0x13c34b4f, (q31_t)0xd1bff656, + (q31_t)0x13ba3760, (q31_t)0xd1c8a6d4, (q31_t)0x13b12526, (q31_t)0xd1d1591a, + (q31_t)0x13a814a2, (q31_t)0xd1da0d28, (q31_t)0x139f05d3, (q31_t)0xd1e2c2fd, + (q31_t)0x1395f8ba, (q31_t)0xd1eb7a9a, (q31_t)0x138ced57, (q31_t)0xd1f433fd, + (q31_t)0x1383e3ab, (q31_t)0xd1fcef27, (q31_t)0x137adbb6, (q31_t)0xd205ac17, + (q31_t)0x1371d579, (q31_t)0xd20e6acc, (q31_t)0x1368d0f3, (q31_t)0xd2172b48, + (q31_t)0x135fce26, (q31_t)0xd21fed88, (q31_t)0x1356cd11, (q31_t)0xd228b18d, + (q31_t)0x134dcdb4, (q31_t)0xd2317756, (q31_t)0x1344d011, (q31_t)0xd23a3ee4, + (q31_t)0x133bd427, (q31_t)0xd2430835, (q31_t)0x1332d9f7, (q31_t)0xd24bd34a, + (q31_t)0x1329e181, (q31_t)0xd254a021, (q31_t)0x1320eac6, (q31_t)0xd25d6ebc, + (q31_t)0x1317f5c6, (q31_t)0xd2663f19, (q31_t)0x130f0280, (q31_t)0xd26f1138, + (q31_t)0x130610f7, (q31_t)0xd277e518, (q31_t)0x12fd2129, (q31_t)0xd280babb, + (q31_t)0x12f43318, (q31_t)0xd289921e, (q31_t)0x12eb46c3, (q31_t)0xd2926b41, + (q31_t)0x12e25c2b, (q31_t)0xd29b4626, (q31_t)0x12d97350, (q31_t)0xd2a422ca, + (q31_t)0x12d08c33, (q31_t)0xd2ad012e, (q31_t)0x12c7a6d4, (q31_t)0xd2b5e151, + (q31_t)0x12bec333, (q31_t)0xd2bec333, (q31_t)0x12b5e151, (q31_t)0xd2c7a6d4, + (q31_t)0x12ad012e, (q31_t)0xd2d08c33, (q31_t)0x12a422ca, (q31_t)0xd2d97350, + (q31_t)0x129b4626, (q31_t)0xd2e25c2b, (q31_t)0x12926b41, (q31_t)0xd2eb46c3, + (q31_t)0x1289921e, (q31_t)0xd2f43318, (q31_t)0x1280babb, (q31_t)0xd2fd2129, + (q31_t)0x1277e518, (q31_t)0xd30610f7, (q31_t)0x126f1138, (q31_t)0xd30f0280, + (q31_t)0x12663f19, (q31_t)0xd317f5c6, (q31_t)0x125d6ebc, (q31_t)0xd320eac6, + (q31_t)0x1254a021, (q31_t)0xd329e181, (q31_t)0x124bd34a, (q31_t)0xd332d9f7, + (q31_t)0x12430835, (q31_t)0xd33bd427, (q31_t)0x123a3ee4, (q31_t)0xd344d011, + (q31_t)0x12317756, (q31_t)0xd34dcdb4, (q31_t)0x1228b18d, (q31_t)0xd356cd11, + (q31_t)0x121fed88, (q31_t)0xd35fce26, (q31_t)0x12172b48, (q31_t)0xd368d0f3, + (q31_t)0x120e6acc, (q31_t)0xd371d579, (q31_t)0x1205ac17, (q31_t)0xd37adbb6, + (q31_t)0x11fcef27, (q31_t)0xd383e3ab, (q31_t)0x11f433fd, (q31_t)0xd38ced57, + (q31_t)0x11eb7a9a, (q31_t)0xd395f8ba, (q31_t)0x11e2c2fd, (q31_t)0xd39f05d3, + (q31_t)0x11da0d28, (q31_t)0xd3a814a2, (q31_t)0x11d1591a, (q31_t)0xd3b12526, + (q31_t)0x11c8a6d4, (q31_t)0xd3ba3760, (q31_t)0x11bff656, (q31_t)0xd3c34b4f, + (q31_t)0x11b747a0, (q31_t)0xd3cc60f2, (q31_t)0x11ae9ab4, (q31_t)0xd3d5784a, + (q31_t)0x11a5ef90, (q31_t)0xd3de9156, (q31_t)0x119d4636, (q31_t)0xd3e7ac15, + (q31_t)0x11949ea6, (q31_t)0xd3f0c887, (q31_t)0x118bf8e0, (q31_t)0xd3f9e6ad, + (q31_t)0x118354e4, (q31_t)0xd4030684, (q31_t)0x117ab2b3, (q31_t)0xd40c280e, + (q31_t)0x1172124d, (q31_t)0xd4154b4a, (q31_t)0x116973b3, (q31_t)0xd41e7037, + (q31_t)0x1160d6e5, (q31_t)0xd42796d5, (q31_t)0x11583be2, (q31_t)0xd430bf24, + (q31_t)0x114fa2ad, (q31_t)0xd439e923, (q31_t)0x11470b44, (q31_t)0xd44314d3, + (q31_t)0x113e75a8, (q31_t)0xd44c4232, (q31_t)0x1135e1d9, (q31_t)0xd4557140, + (q31_t)0x112d4fd9, (q31_t)0xd45ea1fd, (q31_t)0x1124bfa6, (q31_t)0xd467d469, + (q31_t)0x111c3142, (q31_t)0xd4710883, (q31_t)0x1113a4ad, (q31_t)0xd47a3e4b, + (q31_t)0x110b19e7, (q31_t)0xd48375c1, (q31_t)0x110290f0, (q31_t)0xd48caee4, + (q31_t)0x10fa09c9, (q31_t)0xd495e9b3, (q31_t)0x10f18472, (q31_t)0xd49f2630, + (q31_t)0x10e900ec, (q31_t)0xd4a86458, (q31_t)0x10e07f36, (q31_t)0xd4b1a42c, + (q31_t)0x10d7ff51, (q31_t)0xd4bae5ab, (q31_t)0x10cf813e, (q31_t)0xd4c428d6, + (q31_t)0x10c704fd, (q31_t)0xd4cd6dab, (q31_t)0x10be8a8d, (q31_t)0xd4d6b42b, + (q31_t)0x10b611f1, (q31_t)0xd4dffc54, (q31_t)0x10ad9b26, (q31_t)0xd4e94627, + (q31_t)0x10a5262f, (q31_t)0xd4f291a4, (q31_t)0x109cb30b, (q31_t)0xd4fbdec9, + (q31_t)0x109441bb, (q31_t)0xd5052d97, (q31_t)0x108bd23f, (q31_t)0xd50e7e0d, + (q31_t)0x10836497, (q31_t)0xd517d02b, (q31_t)0x107af8c4, (q31_t)0xd52123f0, + (q31_t)0x10728ec6, (q31_t)0xd52a795d, (q31_t)0x106a269d, (q31_t)0xd533d070, + (q31_t)0x1061c04a, (q31_t)0xd53d292a, (q31_t)0x10595bcd, (q31_t)0xd5468389, + (q31_t)0x1050f926, (q31_t)0xd54fdf8f, (q31_t)0x10489856, (q31_t)0xd5593d3a, + (q31_t)0x1040395d, (q31_t)0xd5629c89, (q31_t)0x1037dc3b, (q31_t)0xd56bfd7d, + (q31_t)0x102f80f1, (q31_t)0xd5756016, (q31_t)0x1027277e, (q31_t)0xd57ec452, + (q31_t)0x101ecfe4, (q31_t)0xd5882a32, (q31_t)0x10167a22, (q31_t)0xd59191b5, + (q31_t)0x100e2639, (q31_t)0xd59afadb, (q31_t)0x1005d42a, (q31_t)0xd5a465a3, + (q31_t)0xffd83f4, (q31_t)0xd5add20d, (q31_t)0xff53597, (q31_t)0xd5b74019, + (q31_t)0xfece915, (q31_t)0xd5c0afc6, (q31_t)0xfe49e6d, (q31_t)0xd5ca2115, + (q31_t)0xfdc55a1, (q31_t)0xd5d39403, (q31_t)0xfd40eaf, (q31_t)0xd5dd0892, + (q31_t)0xfcbc999, (q31_t)0xd5e67ec1, (q31_t)0xfc3865e, (q31_t)0xd5eff690, + (q31_t)0xfbb4500, (q31_t)0xd5f96ffd, (q31_t)0xfb3057d, (q31_t)0xd602eb0a, + (q31_t)0xfaac7d8, (q31_t)0xd60c67b4, (q31_t)0xfa28c10, (q31_t)0xd615e5fd, + (q31_t)0xf9a5225, (q31_t)0xd61f65e4, (q31_t)0xf921a17, (q31_t)0xd628e767, + (q31_t)0xf89e3e8, (q31_t)0xd6326a88, (q31_t)0xf81af97, (q31_t)0xd63bef46, + (q31_t)0xf797d24, (q31_t)0xd645759f, (q31_t)0xf714c91, (q31_t)0xd64efd94, + (q31_t)0xf691ddd, (q31_t)0xd6588725, (q31_t)0xf60f108, (q31_t)0xd6621251, + (q31_t)0xf58c613, (q31_t)0xd66b9f18, (q31_t)0xf509cfe, (q31_t)0xd6752d79, + (q31_t)0xf4875ca, (q31_t)0xd67ebd74, (q31_t)0xf405077, (q31_t)0xd6884f09, + (q31_t)0xf382d05, (q31_t)0xd691e237, (q31_t)0xf300b74, (q31_t)0xd69b76fe, + (q31_t)0xf27ebc5, (q31_t)0xd6a50d5d, (q31_t)0xf1fcdf8, (q31_t)0xd6aea555, + (q31_t)0xf17b20d, (q31_t)0xd6b83ee4, (q31_t)0xf0f9805, (q31_t)0xd6c1da0b, + (q31_t)0xf077fe1, (q31_t)0xd6cb76c9, (q31_t)0xeff699f, (q31_t)0xd6d5151d, + (q31_t)0xef75541, (q31_t)0xd6deb508, (q31_t)0xeef42c7, (q31_t)0xd6e85689, + (q31_t)0xee73231, (q31_t)0xd6f1f99f, (q31_t)0xedf2380, (q31_t)0xd6fb9e4b, + (q31_t)0xed716b4, (q31_t)0xd705448b, (q31_t)0xecf0bcd, (q31_t)0xd70eec60, + (q31_t)0xec702cb, (q31_t)0xd71895c9, (q31_t)0xebefbb0, (q31_t)0xd72240c5, + (q31_t)0xeb6f67a, (q31_t)0xd72bed55, (q31_t)0xeaef32b, (q31_t)0xd7359b78, + (q31_t)0xea6f1c2, (q31_t)0xd73f4b2e, (q31_t)0xe9ef241, (q31_t)0xd748fc75, + (q31_t)0xe96f4a7, (q31_t)0xd752af4f, (q31_t)0xe8ef8f4, (q31_t)0xd75c63ba, + (q31_t)0xe86ff2a, (q31_t)0xd76619b6, (q31_t)0xe7f0748, (q31_t)0xd76fd143, + (q31_t)0xe77114e, (q31_t)0xd7798a60, (q31_t)0xe6f1d3d, (q31_t)0xd783450d, + (q31_t)0xe672b16, (q31_t)0xd78d014a, (q31_t)0xe5f3ad8, (q31_t)0xd796bf16, + (q31_t)0xe574c84, (q31_t)0xd7a07e70, (q31_t)0xe4f6019, (q31_t)0xd7aa3f5a, + (q31_t)0xe47759a, (q31_t)0xd7b401d1, (q31_t)0xe3f8d05, (q31_t)0xd7bdc5d6, + (q31_t)0xe37a65b, (q31_t)0xd7c78b68, (q31_t)0xe2fc19c, (q31_t)0xd7d15288, + (q31_t)0xe27dec9, (q31_t)0xd7db1b34, (q31_t)0xe1ffde2, (q31_t)0xd7e4e56c, + (q31_t)0xe181ee8, (q31_t)0xd7eeb130, (q31_t)0xe1041d9, (q31_t)0xd7f87e7f, + (q31_t)0xe0866b8, (q31_t)0xd8024d59, (q31_t)0xe008d84, (q31_t)0xd80c1dbf, + (q31_t)0xdf8b63d, (q31_t)0xd815efae, (q31_t)0xdf0e0e4, (q31_t)0xd81fc328, + (q31_t)0xde90d79, (q31_t)0xd829982b, (q31_t)0xde13bfd, (q31_t)0xd8336eb7, + (q31_t)0xdd96c6f, (q31_t)0xd83d46cc, (q31_t)0xdd19ed0, (q31_t)0xd8472069, + (q31_t)0xdc9d320, (q31_t)0xd850fb8e, (q31_t)0xdc20960, (q31_t)0xd85ad83c, + (q31_t)0xdba4190, (q31_t)0xd864b670, (q31_t)0xdb27bb0, (q31_t)0xd86e962b, + (q31_t)0xdaab7c0, (q31_t)0xd878776d, (q31_t)0xda2f5c2, (q31_t)0xd8825a35, + (q31_t)0xd9b35b4, (q31_t)0xd88c3e83, (q31_t)0xd937798, (q31_t)0xd8962456, + (q31_t)0xd8bbb6d, (q31_t)0xd8a00bae, (q31_t)0xd840134, (q31_t)0xd8a9f48a, + (q31_t)0xd7c48ee, (q31_t)0xd8b3deeb, (q31_t)0xd74929a, (q31_t)0xd8bdcad0, + (q31_t)0xd6cde39, (q31_t)0xd8c7b838, (q31_t)0xd652bcb, (q31_t)0xd8d1a724, + (q31_t)0xd5d7b50, (q31_t)0xd8db9792, (q31_t)0xd55ccca, (q31_t)0xd8e58982, + (q31_t)0xd4e2037, (q31_t)0xd8ef7cf4, (q31_t)0xd467599, (q31_t)0xd8f971e8, + (q31_t)0xd3eccef, (q31_t)0xd903685d, (q31_t)0xd37263a, (q31_t)0xd90d6053, + (q31_t)0xd2f817b, (q31_t)0xd91759c9, (q31_t)0xd27deb0, (q31_t)0xd92154bf, + (q31_t)0xd203ddc, (q31_t)0xd92b5135, (q31_t)0xd189efe, (q31_t)0xd9354f2a, + (q31_t)0xd110216, (q31_t)0xd93f4e9e, (q31_t)0xd096725, (q31_t)0xd9494f90, + (q31_t)0xd01ce2b, (q31_t)0xd9535201, (q31_t)0xcfa3729, (q31_t)0xd95d55ef, + (q31_t)0xcf2a21d, (q31_t)0xd9675b5a, (q31_t)0xceb0f0a, (q31_t)0xd9716243, + (q31_t)0xce37def, (q31_t)0xd97b6aa8, (q31_t)0xcdbeecc, (q31_t)0xd9857489, + (q31_t)0xcd461a2, (q31_t)0xd98f7fe6, (q31_t)0xcccd671, (q31_t)0xd9998cbe, + (q31_t)0xcc54d3a, (q31_t)0xd9a39b11, (q31_t)0xcbdc5fc, (q31_t)0xd9adaadf, + (q31_t)0xcb640b8, (q31_t)0xd9b7bc27, (q31_t)0xcaebd6e, (q31_t)0xd9c1cee9, + (q31_t)0xca73c1e, (q31_t)0xd9cbe325, (q31_t)0xc9fbcca, (q31_t)0xd9d5f8d9, + (q31_t)0xc983f70, (q31_t)0xd9e01006, (q31_t)0xc90c412, (q31_t)0xd9ea28ac, + (q31_t)0xc894aaf, (q31_t)0xd9f442c9, (q31_t)0xc81d349, (q31_t)0xd9fe5e5e, + (q31_t)0xc7a5dde, (q31_t)0xda087b69, (q31_t)0xc72ea70, (q31_t)0xda1299ec, + (q31_t)0xc6b78ff, (q31_t)0xda1cb9e5, (q31_t)0xc64098b, (q31_t)0xda26db54, + (q31_t)0xc5c9c14, (q31_t)0xda30fe38, (q31_t)0xc55309b, (q31_t)0xda3b2292, + (q31_t)0xc4dc720, (q31_t)0xda454860, (q31_t)0xc465fa3, (q31_t)0xda4f6fa3, + (q31_t)0xc3efa25, (q31_t)0xda599859, (q31_t)0xc3796a5, (q31_t)0xda63c284, + (q31_t)0xc303524, (q31_t)0xda6dee21, (q31_t)0xc28d5a3, (q31_t)0xda781b31, + (q31_t)0xc217822, (q31_t)0xda8249b4, (q31_t)0xc1a1ca0, (q31_t)0xda8c79a9, + (q31_t)0xc12c31f, (q31_t)0xda96ab0f, (q31_t)0xc0b6b9e, (q31_t)0xdaa0dde7, + (q31_t)0xc04161e, (q31_t)0xdaab122f, (q31_t)0xbfcc29f, (q31_t)0xdab547e8, + (q31_t)0xbf57121, (q31_t)0xdabf7f11, (q31_t)0xbee21a5, (q31_t)0xdac9b7a9, + (q31_t)0xbe6d42b, (q31_t)0xdad3f1b1, (q31_t)0xbdf88b3, (q31_t)0xdade2d28, + (q31_t)0xbd83f3d, (q31_t)0xdae86a0d, (q31_t)0xbd0f7ca, (q31_t)0xdaf2a860, + (q31_t)0xbc9b25a, (q31_t)0xdafce821, (q31_t)0xbc26eee, (q31_t)0xdb072950, + (q31_t)0xbbb2d85, (q31_t)0xdb116beb, (q31_t)0xbb3ee20, (q31_t)0xdb1baff2, + (q31_t)0xbacb0bf, (q31_t)0xdb25f566, (q31_t)0xba57563, (q31_t)0xdb303c46, + (q31_t)0xb9e3c0b, (q31_t)0xdb3a8491, (q31_t)0xb9704b9, (q31_t)0xdb44ce46, + (q31_t)0xb8fcf6b, (q31_t)0xdb4f1967, (q31_t)0xb889c23, (q31_t)0xdb5965f1, + (q31_t)0xb816ae1, (q31_t)0xdb63b3e5, (q31_t)0xb7a3ba5, (q31_t)0xdb6e0342, + (q31_t)0xb730e70, (q31_t)0xdb785409, (q31_t)0xb6be341, (q31_t)0xdb82a638, + (q31_t)0xb64ba19, (q31_t)0xdb8cf9cf, (q31_t)0xb5d92f8, (q31_t)0xdb974ece, + (q31_t)0xb566ddf, (q31_t)0xdba1a534, (q31_t)0xb4f4acd, (q31_t)0xdbabfd01, + (q31_t)0xb4829c4, (q31_t)0xdbb65634, (q31_t)0xb410ac3, (q31_t)0xdbc0b0ce, + (q31_t)0xb39edca, (q31_t)0xdbcb0cce, (q31_t)0xb32d2da, (q31_t)0xdbd56a32, + (q31_t)0xb2bb9f4, (q31_t)0xdbdfc8fc, (q31_t)0xb24a316, (q31_t)0xdbea292b, + (q31_t)0xb1d8e43, (q31_t)0xdbf48abd, (q31_t)0xb167b79, (q31_t)0xdbfeedb3, + (q31_t)0xb0f6aba, (q31_t)0xdc09520d, (q31_t)0xb085c05, (q31_t)0xdc13b7c9, + (q31_t)0xb014f5b, (q31_t)0xdc1e1ee9, (q31_t)0xafa44bc, (q31_t)0xdc28876a, + (q31_t)0xaf33c28, (q31_t)0xdc32f14d, (q31_t)0xaec35a0, (q31_t)0xdc3d5c91, + (q31_t)0xae53123, (q31_t)0xdc47c936, (q31_t)0xade2eb3, (q31_t)0xdc52373c, + (q31_t)0xad72e4f, (q31_t)0xdc5ca6a2, (q31_t)0xad02ff8, (q31_t)0xdc671768, + (q31_t)0xac933ae, (q31_t)0xdc71898d, (q31_t)0xac23971, (q31_t)0xdc7bfd11, + (q31_t)0xabb4141, (q31_t)0xdc8671f3, (q31_t)0xab44b1f, (q31_t)0xdc90e834, + (q31_t)0xaad570c, (q31_t)0xdc9b5fd2, (q31_t)0xaa66506, (q31_t)0xdca5d8cd, + (q31_t)0xa9f750f, (q31_t)0xdcb05326, (q31_t)0xa988727, (q31_t)0xdcbacedb, + (q31_t)0xa919b4e, (q31_t)0xdcc54bec, (q31_t)0xa8ab184, (q31_t)0xdccfca59, + (q31_t)0xa83c9ca, (q31_t)0xdcda4a21, (q31_t)0xa7ce420, (q31_t)0xdce4cb44, + (q31_t)0xa760086, (q31_t)0xdcef4dc2, (q31_t)0xa6f1efc, (q31_t)0xdcf9d199, + (q31_t)0xa683f83, (q31_t)0xdd0456ca, (q31_t)0xa61621b, (q31_t)0xdd0edd55, + (q31_t)0xa5a86c4, (q31_t)0xdd196538, (q31_t)0xa53ad7e, (q31_t)0xdd23ee74, + (q31_t)0xa4cd64b, (q31_t)0xdd2e7908, (q31_t)0xa460129, (q31_t)0xdd3904f4, + (q31_t)0xa3f2e19, (q31_t)0xdd439236, (q31_t)0xa385d1d, (q31_t)0xdd4e20d0, + (q31_t)0xa318e32, (q31_t)0xdd58b0c0, (q31_t)0xa2ac15b, (q31_t)0xdd634206, + (q31_t)0xa23f698, (q31_t)0xdd6dd4a2, (q31_t)0xa1d2de7, (q31_t)0xdd786892, + (q31_t)0xa16674b, (q31_t)0xdd82fdd8, (q31_t)0xa0fa2c3, (q31_t)0xdd8d9472, + (q31_t)0xa08e04f, (q31_t)0xdd982c60, (q31_t)0xa021fef, (q31_t)0xdda2c5a2, + (q31_t)0x9fb61a5, (q31_t)0xddad6036, (q31_t)0x9f4a570, (q31_t)0xddb7fc1e, + (q31_t)0x9edeb50, (q31_t)0xddc29958, (q31_t)0x9e73346, (q31_t)0xddcd37e4, + (q31_t)0x9e07d51, (q31_t)0xddd7d7c1, (q31_t)0x9d9c973, (q31_t)0xdde278ef, + (q31_t)0x9d317ab, (q31_t)0xdded1b6e, (q31_t)0x9cc67fa, (q31_t)0xddf7bf3e, + (q31_t)0x9c5ba60, (q31_t)0xde02645d, (q31_t)0x9bf0edd, (q31_t)0xde0d0acc, + (q31_t)0x9b86572, (q31_t)0xde17b28a, (q31_t)0x9b1be1e, (q31_t)0xde225b96, + (q31_t)0x9ab18e3, (q31_t)0xde2d05f1, (q31_t)0x9a475bf, (q31_t)0xde37b199, + (q31_t)0x99dd4b4, (q31_t)0xde425e8f, (q31_t)0x99735c2, (q31_t)0xde4d0cd2, + (q31_t)0x99098e9, (q31_t)0xde57bc62, (q31_t)0x989fe29, (q31_t)0xde626d3e, + (q31_t)0x9836582, (q31_t)0xde6d1f65, (q31_t)0x97ccef5, (q31_t)0xde77d2d8, + (q31_t)0x9763a83, (q31_t)0xde828796, (q31_t)0x96fa82a, (q31_t)0xde8d3d9e, + (q31_t)0x96917ec, (q31_t)0xde97f4f1, (q31_t)0x96289c9, (q31_t)0xdea2ad8d, + (q31_t)0x95bfdc1, (q31_t)0xdead6773, (q31_t)0x95573d4, (q31_t)0xdeb822a1, + (q31_t)0x94eec03, (q31_t)0xdec2df18, (q31_t)0x948664d, (q31_t)0xdecd9cd7, + (q31_t)0x941e2b4, (q31_t)0xded85bdd, (q31_t)0x93b6137, (q31_t)0xdee31c2b, + (q31_t)0x934e1d6, (q31_t)0xdeedddc0, (q31_t)0x92e6492, (q31_t)0xdef8a09b, + (q31_t)0x927e96b, (q31_t)0xdf0364bc, (q31_t)0x9217062, (q31_t)0xdf0e2a22, + (q31_t)0x91af976, (q31_t)0xdf18f0ce, (q31_t)0x91484a8, (q31_t)0xdf23b8be, + (q31_t)0x90e11f7, (q31_t)0xdf2e81f3, (q31_t)0x907a166, (q31_t)0xdf394c6b, + (q31_t)0x90132f2, (q31_t)0xdf441828, (q31_t)0x8fac69e, (q31_t)0xdf4ee527, + (q31_t)0x8f45c68, (q31_t)0xdf59b369, (q31_t)0x8edf452, (q31_t)0xdf6482ed, + (q31_t)0x8e78e5b, (q31_t)0xdf6f53b3, (q31_t)0x8e12a84, (q31_t)0xdf7a25ba, + (q31_t)0x8dac8cd, (q31_t)0xdf84f902, (q31_t)0x8d46936, (q31_t)0xdf8fcd8b, + (q31_t)0x8ce0bc0, (q31_t)0xdf9aa354, (q31_t)0x8c7b06b, (q31_t)0xdfa57a5d, + (q31_t)0x8c15736, (q31_t)0xdfb052a5, (q31_t)0x8bb0023, (q31_t)0xdfbb2c2c, + (q31_t)0x8b4ab32, (q31_t)0xdfc606f1, (q31_t)0x8ae5862, (q31_t)0xdfd0e2f5, + (q31_t)0x8a807b4, (q31_t)0xdfdbc036, (q31_t)0x8a1b928, (q31_t)0xdfe69eb4, + (q31_t)0x89b6cbf, (q31_t)0xdff17e70, (q31_t)0x8952278, (q31_t)0xdffc5f67, + (q31_t)0x88eda54, (q31_t)0xe007419b, (q31_t)0x8889454, (q31_t)0xe012250a, + (q31_t)0x8825077, (q31_t)0xe01d09b4, (q31_t)0x87c0ebd, (q31_t)0xe027ef99, + (q31_t)0x875cf28, (q31_t)0xe032d6b8, (q31_t)0x86f91b7, (q31_t)0xe03dbf11, + (q31_t)0x869566a, (q31_t)0xe048a8a4, (q31_t)0x8631d42, (q31_t)0xe053936f, + (q31_t)0x85ce63e, (q31_t)0xe05e7f74, (q31_t)0x856b160, (q31_t)0xe0696cb0, + (q31_t)0x8507ea7, (q31_t)0xe0745b24, (q31_t)0x84a4e14, (q31_t)0xe07f4acf, + (q31_t)0x8441fa6, (q31_t)0xe08a3bb2, (q31_t)0x83df35f, (q31_t)0xe0952dcb, + (q31_t)0x837c93e, (q31_t)0xe0a0211a, (q31_t)0x831a143, (q31_t)0xe0ab159e, + (q31_t)0x82b7b70, (q31_t)0xe0b60b58, (q31_t)0x82557c3, (q31_t)0xe0c10247, + (q31_t)0x81f363d, (q31_t)0xe0cbfa6a, (q31_t)0x81916df, (q31_t)0xe0d6f3c1, + (q31_t)0x812f9a9, (q31_t)0xe0e1ee4b, (q31_t)0x80cde9b, (q31_t)0xe0ecea09, + (q31_t)0x806c5b5, (q31_t)0xe0f7e6f9, (q31_t)0x800aef7, (q31_t)0xe102e51c, + (q31_t)0x7fa9a62, (q31_t)0xe10de470, (q31_t)0x7f487f6, (q31_t)0xe118e4f6, + (q31_t)0x7ee77b3, (q31_t)0xe123e6ad, (q31_t)0x7e8699a, (q31_t)0xe12ee995, + (q31_t)0x7e25daa, (q31_t)0xe139edac, (q31_t)0x7dc53e3, (q31_t)0xe144f2f3, + (q31_t)0x7d64c47, (q31_t)0xe14ff96a, (q31_t)0x7d046d6, (q31_t)0xe15b0110, + (q31_t)0x7ca438f, (q31_t)0xe16609e3, (q31_t)0x7c44272, (q31_t)0xe17113e5, + (q31_t)0x7be4381, (q31_t)0xe17c1f15, (q31_t)0x7b846ba, (q31_t)0xe1872b72, + (q31_t)0x7b24c20, (q31_t)0xe19238fb, (q31_t)0x7ac53b1, (q31_t)0xe19d47b1, + (q31_t)0x7a65d6e, (q31_t)0xe1a85793, (q31_t)0x7a06957, (q31_t)0xe1b368a0, + (q31_t)0x79a776c, (q31_t)0xe1be7ad8, (q31_t)0x79487ae, (q31_t)0xe1c98e3b, + (q31_t)0x78e9a1d, (q31_t)0xe1d4a2c8, (q31_t)0x788aeb9, (q31_t)0xe1dfb87f, + (q31_t)0x782c582, (q31_t)0xe1eacf5f, (q31_t)0x77cde79, (q31_t)0xe1f5e768, + (q31_t)0x776f99d, (q31_t)0xe2010099, (q31_t)0x77116f0, (q31_t)0xe20c1af3, + (q31_t)0x76b3671, (q31_t)0xe2173674, (q31_t)0x7655820, (q31_t)0xe222531c, + (q31_t)0x75f7bfe, (q31_t)0xe22d70eb, (q31_t)0x759a20a, (q31_t)0xe2388fe1, + (q31_t)0x753ca46, (q31_t)0xe243affc, (q31_t)0x74df4b1, (q31_t)0xe24ed13d, + (q31_t)0x748214c, (q31_t)0xe259f3a3, (q31_t)0x7425016, (q31_t)0xe265172e, + (q31_t)0x73c8111, (q31_t)0xe2703bdc, (q31_t)0x736b43c, (q31_t)0xe27b61af, + (q31_t)0x730e997, (q31_t)0xe28688a4, (q31_t)0x72b2123, (q31_t)0xe291b0bd, + (q31_t)0x7255ae0, (q31_t)0xe29cd9f8, (q31_t)0x71f96ce, (q31_t)0xe2a80456, + (q31_t)0x719d4ed, (q31_t)0xe2b32fd4, (q31_t)0x714153e, (q31_t)0xe2be5c74, + (q31_t)0x70e57c0, (q31_t)0xe2c98a35, (q31_t)0x7089c75, (q31_t)0xe2d4b916, + (q31_t)0x702e35c, (q31_t)0xe2dfe917, (q31_t)0x6fd2c75, (q31_t)0xe2eb1a37, + (q31_t)0x6f777c1, (q31_t)0xe2f64c77, (q31_t)0x6f1c540, (q31_t)0xe3017fd5, + (q31_t)0x6ec14f2, (q31_t)0xe30cb451, (q31_t)0x6e666d7, (q31_t)0xe317e9eb, + (q31_t)0x6e0baf0, (q31_t)0xe32320a2, (q31_t)0x6db113d, (q31_t)0xe32e5876, + (q31_t)0x6d569be, (q31_t)0xe3399167, (q31_t)0x6cfc472, (q31_t)0xe344cb73, + (q31_t)0x6ca215c, (q31_t)0xe350069b, (q31_t)0x6c4807a, (q31_t)0xe35b42df, + (q31_t)0x6bee1cd, (q31_t)0xe366803c, (q31_t)0x6b94554, (q31_t)0xe371beb5, + (q31_t)0x6b3ab12, (q31_t)0xe37cfe47, (q31_t)0x6ae1304, (q31_t)0xe3883ef2, + (q31_t)0x6a87d2d, (q31_t)0xe39380b6, (q31_t)0x6a2e98b, (q31_t)0xe39ec393, + (q31_t)0x69d5820, (q31_t)0xe3aa0788, (q31_t)0x697c8eb, (q31_t)0xe3b54c95, + (q31_t)0x6923bec, (q31_t)0xe3c092b9, (q31_t)0x68cb124, (q31_t)0xe3cbd9f4, + (q31_t)0x6872894, (q31_t)0xe3d72245, (q31_t)0x681a23a, (q31_t)0xe3e26bac, + (q31_t)0x67c1e18, (q31_t)0xe3edb628, (q31_t)0x6769c2e, (q31_t)0xe3f901ba, + (q31_t)0x6711c7b, (q31_t)0xe4044e60, (q31_t)0x66b9f01, (q31_t)0xe40f9c1a, + (q31_t)0x66623be, (q31_t)0xe41aeae8, (q31_t)0x660aab5, (q31_t)0xe4263ac9, + (q31_t)0x65b33e4, (q31_t)0xe4318bbe, (q31_t)0x655bf4c, (q31_t)0xe43cddc4, + (q31_t)0x6504ced, (q31_t)0xe44830dd, (q31_t)0x64adcc7, (q31_t)0xe4538507, + (q31_t)0x6456edb, (q31_t)0xe45eda43, (q31_t)0x6400329, (q31_t)0xe46a308f, + (q31_t)0x63a99b1, (q31_t)0xe47587eb, (q31_t)0x6353273, (q31_t)0xe480e057, + (q31_t)0x62fcd6f, (q31_t)0xe48c39d3, (q31_t)0x62a6aa6, (q31_t)0xe497945d, + (q31_t)0x6250a18, (q31_t)0xe4a2eff6, (q31_t)0x61fabc4, (q31_t)0xe4ae4c9d, + (q31_t)0x61a4fac, (q31_t)0xe4b9aa52, (q31_t)0x614f5cf, (q31_t)0xe4c50914, + (q31_t)0x60f9e2e, (q31_t)0xe4d068e2, (q31_t)0x60a48c9, (q31_t)0xe4dbc9bd, + (q31_t)0x604f5a0, (q31_t)0xe4e72ba4, (q31_t)0x5ffa4b3, (q31_t)0xe4f28e96, + (q31_t)0x5fa5603, (q31_t)0xe4fdf294, (q31_t)0x5f5098f, (q31_t)0xe509579b, + (q31_t)0x5efbf58, (q31_t)0xe514bdad, (q31_t)0x5ea775e, (q31_t)0xe52024c9, + (q31_t)0x5e531a1, (q31_t)0xe52b8cee, (q31_t)0x5dfee22, (q31_t)0xe536f61b, + (q31_t)0x5daace1, (q31_t)0xe5426051, (q31_t)0x5d56ddd, (q31_t)0xe54dcb8f, + (q31_t)0x5d03118, (q31_t)0xe55937d5, (q31_t)0x5caf690, (q31_t)0xe564a521, + (q31_t)0x5c5be47, (q31_t)0xe5701374, (q31_t)0x5c0883d, (q31_t)0xe57b82cd, + (q31_t)0x5bb5472, (q31_t)0xe586f32c, (q31_t)0x5b622e6, (q31_t)0xe5926490, + (q31_t)0x5b0f399, (q31_t)0xe59dd6f9, (q31_t)0x5abc68c, (q31_t)0xe5a94a67, + (q31_t)0x5a69bbe, (q31_t)0xe5b4bed8, (q31_t)0x5a17330, (q31_t)0xe5c0344d, + (q31_t)0x59c4ce3, (q31_t)0xe5cbaac5, (q31_t)0x59728d5, (q31_t)0xe5d72240, + (q31_t)0x5920708, (q31_t)0xe5e29abc, (q31_t)0x58ce77c, (q31_t)0xe5ee143b, + (q31_t)0x587ca31, (q31_t)0xe5f98ebb, (q31_t)0x582af26, (q31_t)0xe6050a3b, + (q31_t)0x57d965d, (q31_t)0xe61086bc, (q31_t)0x5787fd6, (q31_t)0xe61c043d, + (q31_t)0x5736b90, (q31_t)0xe62782be, (q31_t)0x56e598c, (q31_t)0xe633023e, + (q31_t)0x56949ca, (q31_t)0xe63e82bc, (q31_t)0x5643c4a, (q31_t)0xe64a0438, + (q31_t)0x55f310d, (q31_t)0xe65586b3, (q31_t)0x55a2812, (q31_t)0xe6610a2a, + (q31_t)0x555215a, (q31_t)0xe66c8e9f, (q31_t)0x5501ce5, (q31_t)0xe6781410, + (q31_t)0x54b1ab4, (q31_t)0xe6839a7c, (q31_t)0x5461ac6, (q31_t)0xe68f21e5, + (q31_t)0x5411d1b, (q31_t)0xe69aaa48, (q31_t)0x53c21b4, (q31_t)0xe6a633a6, + (q31_t)0x5372891, (q31_t)0xe6b1bdff, (q31_t)0x53231b3, (q31_t)0xe6bd4951, + (q31_t)0x52d3d18, (q31_t)0xe6c8d59c, (q31_t)0x5284ac3, (q31_t)0xe6d462e1, + (q31_t)0x5235ab2, (q31_t)0xe6dff11d, (q31_t)0x51e6ce6, (q31_t)0xe6eb8052, + (q31_t)0x519815f, (q31_t)0xe6f7107e, (q31_t)0x514981d, (q31_t)0xe702a1a1, + (q31_t)0x50fb121, (q31_t)0xe70e33bb, (q31_t)0x50acc6b, (q31_t)0xe719c6cb, + (q31_t)0x505e9fb, (q31_t)0xe7255ad1, (q31_t)0x50109d0, (q31_t)0xe730efcc, + (q31_t)0x4fc2bec, (q31_t)0xe73c85bc, (q31_t)0x4f7504e, (q31_t)0xe7481ca1, + (q31_t)0x4f276f7, (q31_t)0xe753b479, (q31_t)0x4ed9fe7, (q31_t)0xe75f4d45, + (q31_t)0x4e8cb1e, (q31_t)0xe76ae704, (q31_t)0x4e3f89c, (q31_t)0xe77681b6, + (q31_t)0x4df2862, (q31_t)0xe7821d59, (q31_t)0x4da5a6f, (q31_t)0xe78db9ef, + (q31_t)0x4d58ec3, (q31_t)0xe7995776, (q31_t)0x4d0c560, (q31_t)0xe7a4f5ed, + (q31_t)0x4cbfe45, (q31_t)0xe7b09555, (q31_t)0x4c73972, (q31_t)0xe7bc35ad, + (q31_t)0x4c276e8, (q31_t)0xe7c7d6f4, (q31_t)0x4bdb6a6, (q31_t)0xe7d3792b, + (q31_t)0x4b8f8ad, (q31_t)0xe7df1c50, (q31_t)0x4b43cfd, (q31_t)0xe7eac063, + (q31_t)0x4af8397, (q31_t)0xe7f66564, (q31_t)0x4aacc7a, (q31_t)0xe8020b52, + (q31_t)0x4a617a6, (q31_t)0xe80db22d, (q31_t)0x4a1651c, (q31_t)0xe81959f4, + (q31_t)0x49cb4dd, (q31_t)0xe82502a7, (q31_t)0x49806e7, (q31_t)0xe830ac45, + (q31_t)0x4935b3c, (q31_t)0xe83c56cf, (q31_t)0x48eb1db, (q31_t)0xe8480243, + (q31_t)0x48a0ac4, (q31_t)0xe853aea1, (q31_t)0x48565f9, (q31_t)0xe85f5be9, + (q31_t)0x480c379, (q31_t)0xe86b0a1a, (q31_t)0x47c2344, (q31_t)0xe876b934, + (q31_t)0x477855a, (q31_t)0xe8826936, (q31_t)0x472e9bc, (q31_t)0xe88e1a20, + (q31_t)0x46e5069, (q31_t)0xe899cbf1, (q31_t)0x469b963, (q31_t)0xe8a57ea9, + (q31_t)0x46524a9, (q31_t)0xe8b13248, (q31_t)0x460923b, (q31_t)0xe8bce6cd, + (q31_t)0x45c0219, (q31_t)0xe8c89c37, (q31_t)0x4577444, (q31_t)0xe8d45286, + (q31_t)0x452e8bc, (q31_t)0xe8e009ba, (q31_t)0x44e5f80, (q31_t)0xe8ebc1d3, + (q31_t)0x449d892, (q31_t)0xe8f77acf, (q31_t)0x44553f2, (q31_t)0xe90334af, + (q31_t)0x440d19e, (q31_t)0xe90eef71, (q31_t)0x43c5199, (q31_t)0xe91aab16, + (q31_t)0x437d3e1, (q31_t)0xe926679c, (q31_t)0x4335877, (q31_t)0xe9322505, + (q31_t)0x42edf5c, (q31_t)0xe93de34e, (q31_t)0x42a688f, (q31_t)0xe949a278, + (q31_t)0x425f410, (q31_t)0xe9556282, (q31_t)0x42181e0, (q31_t)0xe961236c, + (q31_t)0x41d11ff, (q31_t)0xe96ce535, (q31_t)0x418a46d, (q31_t)0xe978a7dd, + (q31_t)0x414392b, (q31_t)0xe9846b63, (q31_t)0x40fd037, (q31_t)0xe9902fc7, + (q31_t)0x40b6994, (q31_t)0xe99bf509, (q31_t)0x4070540, (q31_t)0xe9a7bb28, + (q31_t)0x402a33c, (q31_t)0xe9b38223, (q31_t)0x3fe4388, (q31_t)0xe9bf49fa, + (q31_t)0x3f9e624, (q31_t)0xe9cb12ad, (q31_t)0x3f58b10, (q31_t)0xe9d6dc3b, + (q31_t)0x3f1324e, (q31_t)0xe9e2a6a3, (q31_t)0x3ecdbdc, (q31_t)0xe9ee71e6, + (q31_t)0x3e887bb, (q31_t)0xe9fa3e03, (q31_t)0x3e435ea, (q31_t)0xea060af9, + (q31_t)0x3dfe66c, (q31_t)0xea11d8c8, (q31_t)0x3db993e, (q31_t)0xea1da770, + (q31_t)0x3d74e62, (q31_t)0xea2976ef, (q31_t)0x3d305d8, (q31_t)0xea354746, + (q31_t)0x3cebfa0, (q31_t)0xea411874, (q31_t)0x3ca7bba, (q31_t)0xea4cea79, + (q31_t)0x3c63a26, (q31_t)0xea58bd54, (q31_t)0x3c1fae5, (q31_t)0xea649105, + (q31_t)0x3bdbdf6, (q31_t)0xea70658a, (q31_t)0x3b9835a, (q31_t)0xea7c3ae5, + (q31_t)0x3b54b11, (q31_t)0xea881114, (q31_t)0x3b1151b, (q31_t)0xea93e817, + (q31_t)0x3ace178, (q31_t)0xea9fbfed, (q31_t)0x3a8b028, (q31_t)0xeaab9896, + (q31_t)0x3a4812c, (q31_t)0xeab77212, (q31_t)0x3a05484, (q31_t)0xeac34c60, + (q31_t)0x39c2a2f, (q31_t)0xeacf277f, (q31_t)0x398022f, (q31_t)0xeadb0370, + (q31_t)0x393dc82, (q31_t)0xeae6e031, (q31_t)0x38fb92a, (q31_t)0xeaf2bdc3, + (q31_t)0x38b9827, (q31_t)0xeafe9c24, (q31_t)0x3877978, (q31_t)0xeb0a7b54, + (q31_t)0x3835d1e, (q31_t)0xeb165b54, (q31_t)0x37f4319, (q31_t)0xeb223c22, + (q31_t)0x37b2b6a, (q31_t)0xeb2e1dbe, (q31_t)0x377160f, (q31_t)0xeb3a0027, + (q31_t)0x373030a, (q31_t)0xeb45e35d, (q31_t)0x36ef25b, (q31_t)0xeb51c760, + (q31_t)0x36ae401, (q31_t)0xeb5dac2f, (q31_t)0x366d7fd, (q31_t)0xeb6991ca, + (q31_t)0x362ce50, (q31_t)0xeb75782f, (q31_t)0x35ec6f8, (q31_t)0xeb815f60, + (q31_t)0x35ac1f7, (q31_t)0xeb8d475b, (q31_t)0x356bf4d, (q31_t)0xeb99301f, + (q31_t)0x352bef9, (q31_t)0xeba519ad, (q31_t)0x34ec0fc, (q31_t)0xebb10404, + (q31_t)0x34ac556, (q31_t)0xebbcef23, (q31_t)0x346cc07, (q31_t)0xebc8db0b, + (q31_t)0x342d510, (q31_t)0xebd4c7ba, (q31_t)0x33ee070, (q31_t)0xebe0b52f, + (q31_t)0x33aee27, (q31_t)0xebeca36c, (q31_t)0x336fe37, (q31_t)0xebf8926f, + (q31_t)0x333109e, (q31_t)0xec048237, (q31_t)0x32f255e, (q31_t)0xec1072c4, + (q31_t)0x32b3c75, (q31_t)0xec1c6417, (q31_t)0x32755e5, (q31_t)0xec28562d, + (q31_t)0x32371ae, (q31_t)0xec344908, (q31_t)0x31f8fcf, (q31_t)0xec403ca5, + (q31_t)0x31bb049, (q31_t)0xec4c3106, (q31_t)0x317d31c, (q31_t)0xec582629, + (q31_t)0x313f848, (q31_t)0xec641c0e, (q31_t)0x3101fce, (q31_t)0xec7012b5, + (q31_t)0x30c49ad, (q31_t)0xec7c0a1d, (q31_t)0x30875e5, (q31_t)0xec880245, + (q31_t)0x304a477, (q31_t)0xec93fb2e, (q31_t)0x300d563, (q31_t)0xec9ff4d6, + (q31_t)0x2fd08a9, (q31_t)0xecabef3d, (q31_t)0x2f93e4a, (q31_t)0xecb7ea63, + (q31_t)0x2f57644, (q31_t)0xecc3e648, (q31_t)0x2f1b099, (q31_t)0xeccfe2ea, + (q31_t)0x2eded49, (q31_t)0xecdbe04a, (q31_t)0x2ea2c53, (q31_t)0xece7de66, + (q31_t)0x2e66db8, (q31_t)0xecf3dd3f, (q31_t)0x2e2b178, (q31_t)0xecffdcd4, + (q31_t)0x2def794, (q31_t)0xed0bdd25, (q31_t)0x2db400a, (q31_t)0xed17de31, + (q31_t)0x2d78add, (q31_t)0xed23dff7, (q31_t)0x2d3d80a, (q31_t)0xed2fe277, + (q31_t)0x2d02794, (q31_t)0xed3be5b1, (q31_t)0x2cc7979, (q31_t)0xed47e9a5, + (q31_t)0x2c8cdbb, (q31_t)0xed53ee51, (q31_t)0x2c52459, (q31_t)0xed5ff3b5, + (q31_t)0x2c17d52, (q31_t)0xed6bf9d1, (q31_t)0x2bdd8a9, (q31_t)0xed7800a5, + (q31_t)0x2ba365c, (q31_t)0xed84082f, (q31_t)0x2b6966c, (q31_t)0xed901070, + (q31_t)0x2b2f8d8, (q31_t)0xed9c1967, (q31_t)0x2af5da2, (q31_t)0xeda82313, + (q31_t)0x2abc4c9, (q31_t)0xedb42d74, (q31_t)0x2a82e4d, (q31_t)0xedc0388a, + (q31_t)0x2a49a2e, (q31_t)0xedcc4454, (q31_t)0x2a1086d, (q31_t)0xedd850d2, + (q31_t)0x29d790a, (q31_t)0xede45e03, (q31_t)0x299ec05, (q31_t)0xedf06be6, + (q31_t)0x296615d, (q31_t)0xedfc7a7c, (q31_t)0x292d914, (q31_t)0xee0889c4, + (q31_t)0x28f5329, (q31_t)0xee1499bd, (q31_t)0x28bcf9c, (q31_t)0xee20aa67, + (q31_t)0x2884e6e, (q31_t)0xee2cbbc1, (q31_t)0x284cf9f, (q31_t)0xee38cdcb, + (q31_t)0x281532e, (q31_t)0xee44e084, (q31_t)0x27dd91c, (q31_t)0xee50f3ed, + (q31_t)0x27a616a, (q31_t)0xee5d0804, (q31_t)0x276ec16, (q31_t)0xee691cc9, + (q31_t)0x2737922, (q31_t)0xee75323c, (q31_t)0x270088e, (q31_t)0xee81485c, + (q31_t)0x26c9a58, (q31_t)0xee8d5f29, (q31_t)0x2692e83, (q31_t)0xee9976a1, + (q31_t)0x265c50e, (q31_t)0xeea58ec6, (q31_t)0x2625df8, (q31_t)0xeeb1a796, + (q31_t)0x25ef943, (q31_t)0xeebdc110, (q31_t)0x25b96ee, (q31_t)0xeec9db35, + (q31_t)0x25836f9, (q31_t)0xeed5f604, (q31_t)0x254d965, (q31_t)0xeee2117c, + (q31_t)0x2517e31, (q31_t)0xeeee2d9d, (q31_t)0x24e255e, (q31_t)0xeefa4a67, + (q31_t)0x24aceed, (q31_t)0xef0667d9, (q31_t)0x2477adc, (q31_t)0xef1285f2, + (q31_t)0x244292c, (q31_t)0xef1ea4b2, (q31_t)0x240d9de, (q31_t)0xef2ac419, + (q31_t)0x23d8cf1, (q31_t)0xef36e426, (q31_t)0x23a4265, (q31_t)0xef4304d8, + (q31_t)0x236fa3b, (q31_t)0xef4f2630, (q31_t)0x233b473, (q31_t)0xef5b482d, + (q31_t)0x230710d, (q31_t)0xef676ace, (q31_t)0x22d3009, (q31_t)0xef738e12, + (q31_t)0x229f167, (q31_t)0xef7fb1fa, (q31_t)0x226b528, (q31_t)0xef8bd685, + (q31_t)0x2237b4b, (q31_t)0xef97fbb2, (q31_t)0x22043d0, (q31_t)0xefa42181, + (q31_t)0x21d0eb8, (q31_t)0xefb047f2, (q31_t)0x219dc03, (q31_t)0xefbc6f03, + (q31_t)0x216abb1, (q31_t)0xefc896b5, (q31_t)0x2137dc2, (q31_t)0xefd4bf08, + (q31_t)0x2105236, (q31_t)0xefe0e7f9, (q31_t)0x20d290d, (q31_t)0xefed118a, + (q31_t)0x20a0248, (q31_t)0xeff93bba, (q31_t)0x206dde6, (q31_t)0xf0056687, + (q31_t)0x203bbe8, (q31_t)0xf01191f3, (q31_t)0x2009c4e, (q31_t)0xf01dbdfb, + (q31_t)0x1fd7f17, (q31_t)0xf029eaa1, (q31_t)0x1fa6445, (q31_t)0xf03617e2, + (q31_t)0x1f74bd6, (q31_t)0xf04245c0, (q31_t)0x1f435cc, (q31_t)0xf04e7438, + (q31_t)0x1f12227, (q31_t)0xf05aa34c, (q31_t)0x1ee10e5, (q31_t)0xf066d2fa, + (q31_t)0x1eb0209, (q31_t)0xf0730342, (q31_t)0x1e7f591, (q31_t)0xf07f3424, + (q31_t)0x1e4eb7e, (q31_t)0xf08b659f, (q31_t)0x1e1e3d0, (q31_t)0xf09797b2, + (q31_t)0x1dede87, (q31_t)0xf0a3ca5d, (q31_t)0x1dbdba3, (q31_t)0xf0affda0, + (q31_t)0x1d8db25, (q31_t)0xf0bc317a, (q31_t)0x1d5dd0c, (q31_t)0xf0c865ea, + (q31_t)0x1d2e158, (q31_t)0xf0d49af1, (q31_t)0x1cfe80a, (q31_t)0xf0e0d08d, + (q31_t)0x1ccf122, (q31_t)0xf0ed06bf, (q31_t)0x1c9fca0, (q31_t)0xf0f93d86, + (q31_t)0x1c70a84, (q31_t)0xf10574e0, (q31_t)0x1c41ace, (q31_t)0xf111accf, + (q31_t)0x1c12d7e, (q31_t)0xf11de551, (q31_t)0x1be4294, (q31_t)0xf12a1e66, + (q31_t)0x1bb5a11, (q31_t)0xf136580d, (q31_t)0x1b873f5, (q31_t)0xf1429247, + (q31_t)0x1b5903f, (q31_t)0xf14ecd11, (q31_t)0x1b2aef0, (q31_t)0xf15b086d, + (q31_t)0x1afd007, (q31_t)0xf1674459, (q31_t)0x1acf386, (q31_t)0xf17380d6, + (q31_t)0x1aa196c, (q31_t)0xf17fbde2, (q31_t)0x1a741b9, (q31_t)0xf18bfb7d, + (q31_t)0x1a46c6e, (q31_t)0xf19839a6, (q31_t)0x1a1998a, (q31_t)0xf1a4785e, + (q31_t)0x19ec90d, (q31_t)0xf1b0b7a4, (q31_t)0x19bfaf9, (q31_t)0xf1bcf777, + (q31_t)0x1992f4c, (q31_t)0xf1c937d6, (q31_t)0x1966606, (q31_t)0xf1d578c2, + (q31_t)0x1939f29, (q31_t)0xf1e1ba3a, (q31_t)0x190dab4, (q31_t)0xf1edfc3d, + (q31_t)0x18e18a7, (q31_t)0xf1fa3ecb, (q31_t)0x18b5903, (q31_t)0xf20681e3, + (q31_t)0x1889bc6, (q31_t)0xf212c585, (q31_t)0x185e0f3, (q31_t)0xf21f09b1, + (q31_t)0x1832888, (q31_t)0xf22b4e66, (q31_t)0x1807285, (q31_t)0xf23793a3, + (q31_t)0x17dbeec, (q31_t)0xf243d968, (q31_t)0x17b0dbb, (q31_t)0xf2501fb5, + (q31_t)0x1785ef4, (q31_t)0xf25c6688, (q31_t)0x175b296, (q31_t)0xf268ade3, + (q31_t)0x17308a1, (q31_t)0xf274f5c3, (q31_t)0x1706115, (q31_t)0xf2813e2a, + (q31_t)0x16dbbf3, (q31_t)0xf28d8715, (q31_t)0x16b193a, (q31_t)0xf299d085, + (q31_t)0x16878eb, (q31_t)0xf2a61a7a, (q31_t)0x165db05, (q31_t)0xf2b264f2, + (q31_t)0x1633f8a, (q31_t)0xf2beafed, (q31_t)0x160a678, (q31_t)0xf2cafb6b, + (q31_t)0x15e0fd1, (q31_t)0xf2d7476c, (q31_t)0x15b7b94, (q31_t)0xf2e393ef, + (q31_t)0x158e9c1, (q31_t)0xf2efe0f2, (q31_t)0x1565a58, (q31_t)0xf2fc2e77, + (q31_t)0x153cd5a, (q31_t)0xf3087c7d, (q31_t)0x15142c6, (q31_t)0xf314cb02, + (q31_t)0x14eba9d, (q31_t)0xf3211a07, (q31_t)0x14c34df, (q31_t)0xf32d698a, + (q31_t)0x149b18b, (q31_t)0xf339b98d, (q31_t)0x14730a3, (q31_t)0xf3460a0d, + (q31_t)0x144b225, (q31_t)0xf3525b0b, (q31_t)0x1423613, (q31_t)0xf35eac86, + (q31_t)0x13fbc6c, (q31_t)0xf36afe7e, (q31_t)0x13d4530, (q31_t)0xf37750f2, + (q31_t)0x13ad060, (q31_t)0xf383a3e2, (q31_t)0x1385dfb, (q31_t)0xf38ff74d, + (q31_t)0x135ee02, (q31_t)0xf39c4b32, (q31_t)0x1338075, (q31_t)0xf3a89f92, + (q31_t)0x1311553, (q31_t)0xf3b4f46c, (q31_t)0x12eac9d, (q31_t)0xf3c149bf, + (q31_t)0x12c4653, (q31_t)0xf3cd9f8b, (q31_t)0x129e276, (q31_t)0xf3d9f5cf, + (q31_t)0x1278104, (q31_t)0xf3e64c8c, (q31_t)0x12521ff, (q31_t)0xf3f2a3bf, + (q31_t)0x122c566, (q31_t)0xf3fefb6a, (q31_t)0x1206b39, (q31_t)0xf40b538b, + (q31_t)0x11e1379, (q31_t)0xf417ac22, (q31_t)0x11bbe26, (q31_t)0xf424052f, + (q31_t)0x1196b3f, (q31_t)0xf4305eb0, (q31_t)0x1171ac6, (q31_t)0xf43cb8a7, + (q31_t)0x114ccb9, (q31_t)0xf4491311, (q31_t)0x1128119, (q31_t)0xf4556def, + (q31_t)0x11037e6, (q31_t)0xf461c940, (q31_t)0x10df120, (q31_t)0xf46e2504, + (q31_t)0x10bacc8, (q31_t)0xf47a8139, (q31_t)0x1096add, (q31_t)0xf486dde1, + (q31_t)0x1072b5f, (q31_t)0xf4933afa, (q31_t)0x104ee4f, (q31_t)0xf49f9884, + (q31_t)0x102b3ac, (q31_t)0xf4abf67e, (q31_t)0x1007b77, (q31_t)0xf4b854e7, + (q31_t)0xfe45b0, (q31_t)0xf4c4b3c0, (q31_t)0xfc1257, (q31_t)0xf4d11308, + (q31_t)0xf9e16b, (q31_t)0xf4dd72be, (q31_t)0xf7b2ee, (q31_t)0xf4e9d2e3, + (q31_t)0xf586df, (q31_t)0xf4f63374, (q31_t)0xf35d3e, (q31_t)0xf5029473, + (q31_t)0xf1360b, (q31_t)0xf50ef5de, (q31_t)0xef1147, (q31_t)0xf51b57b5, + (q31_t)0xeceef1, (q31_t)0xf527b9f7, (q31_t)0xeacf09, (q31_t)0xf5341ca5, + (q31_t)0xe8b190, (q31_t)0xf5407fbd, (q31_t)0xe69686, (q31_t)0xf54ce33f, + (q31_t)0xe47deb, (q31_t)0xf559472b, (q31_t)0xe267be, (q31_t)0xf565ab80, + (q31_t)0xe05401, (q31_t)0xf572103d, (q31_t)0xde42b2, (q31_t)0xf57e7563, + (q31_t)0xdc33d2, (q31_t)0xf58adaf0, (q31_t)0xda2762, (q31_t)0xf59740e5, + (q31_t)0xd81d61, (q31_t)0xf5a3a740, (q31_t)0xd615cf, (q31_t)0xf5b00e02, + (q31_t)0xd410ad, (q31_t)0xf5bc7529, (q31_t)0xd20dfa, (q31_t)0xf5c8dcb6, + (q31_t)0xd00db6, (q31_t)0xf5d544a7, (q31_t)0xce0fe3, (q31_t)0xf5e1acfd, + (q31_t)0xcc147f, (q31_t)0xf5ee15b7, (q31_t)0xca1b8a, (q31_t)0xf5fa7ed4, + (q31_t)0xc82506, (q31_t)0xf606e854, (q31_t)0xc630f2, (q31_t)0xf6135237, + (q31_t)0xc43f4d, (q31_t)0xf61fbc7b, (q31_t)0xc25019, (q31_t)0xf62c2721, + (q31_t)0xc06355, (q31_t)0xf6389228, (q31_t)0xbe7901, (q31_t)0xf644fd8f, + (q31_t)0xbc911d, (q31_t)0xf6516956, (q31_t)0xbaabaa, (q31_t)0xf65dd57d, + (q31_t)0xb8c8a7, (q31_t)0xf66a4203, (q31_t)0xb6e815, (q31_t)0xf676aee8, + (q31_t)0xb509f3, (q31_t)0xf6831c2b, (q31_t)0xb32e42, (q31_t)0xf68f89cb, + (q31_t)0xb15502, (q31_t)0xf69bf7c9, (q31_t)0xaf7e33, (q31_t)0xf6a86623, + (q31_t)0xada9d4, (q31_t)0xf6b4d4d9, (q31_t)0xabd7e6, (q31_t)0xf6c143ec, + (q31_t)0xaa086a, (q31_t)0xf6cdb359, (q31_t)0xa83b5e, (q31_t)0xf6da2321, + (q31_t)0xa670c4, (q31_t)0xf6e69344, (q31_t)0xa4a89b, (q31_t)0xf6f303c0, + (q31_t)0xa2e2e3, (q31_t)0xf6ff7496, (q31_t)0xa11f9d, (q31_t)0xf70be5c4, + (q31_t)0x9f5ec8, (q31_t)0xf718574b, (q31_t)0x9da065, (q31_t)0xf724c92a, + (q31_t)0x9be473, (q31_t)0xf7313b60, (q31_t)0x9a2af3, (q31_t)0xf73daded, + (q31_t)0x9873e4, (q31_t)0xf74a20d0, (q31_t)0x96bf48, (q31_t)0xf756940a, + (q31_t)0x950d1d, (q31_t)0xf7630799, (q31_t)0x935d64, (q31_t)0xf76f7b7d, + (q31_t)0x91b01d, (q31_t)0xf77befb5, (q31_t)0x900548, (q31_t)0xf7886442, + (q31_t)0x8e5ce5, (q31_t)0xf794d922, (q31_t)0x8cb6f5, (q31_t)0xf7a14e55, + (q31_t)0x8b1376, (q31_t)0xf7adc3db, (q31_t)0x89726a, (q31_t)0xf7ba39b3, + (q31_t)0x87d3d0, (q31_t)0xf7c6afdc, (q31_t)0x8637a9, (q31_t)0xf7d32657, + (q31_t)0x849df4, (q31_t)0xf7df9d22, (q31_t)0x8306b2, (q31_t)0xf7ec143e, + (q31_t)0x8171e2, (q31_t)0xf7f88ba9, (q31_t)0x7fdf85, (q31_t)0xf8050364, + (q31_t)0x7e4f9b, (q31_t)0xf8117b6d, (q31_t)0x7cc223, (q31_t)0xf81df3c5, + (q31_t)0x7b371e, (q31_t)0xf82a6c6a, (q31_t)0x79ae8c, (q31_t)0xf836e55d, + (q31_t)0x78286e, (q31_t)0xf8435e9d, (q31_t)0x76a4c2, (q31_t)0xf84fd829, + (q31_t)0x752389, (q31_t)0xf85c5201, (q31_t)0x73a4c3, (q31_t)0xf868cc24, + (q31_t)0x722871, (q31_t)0xf8754692, (q31_t)0x70ae92, (q31_t)0xf881c14b, + (q31_t)0x6f3726, (q31_t)0xf88e3c4d, (q31_t)0x6dc22e, (q31_t)0xf89ab799, + (q31_t)0x6c4fa8, (q31_t)0xf8a7332e, (q31_t)0x6adf97, (q31_t)0xf8b3af0c, + (q31_t)0x6971f9, (q31_t)0xf8c02b31, (q31_t)0x6806ce, (q31_t)0xf8cca79e, + (q31_t)0x669e18, (q31_t)0xf8d92452, (q31_t)0x6537d4, (q31_t)0xf8e5a14d, + (q31_t)0x63d405, (q31_t)0xf8f21e8e, (q31_t)0x6272aa, (q31_t)0xf8fe9c15, + (q31_t)0x6113c2, (q31_t)0xf90b19e0, (q31_t)0x5fb74e, (q31_t)0xf91797f0, + (q31_t)0x5e5d4e, (q31_t)0xf9241645, (q31_t)0x5d05c3, (q31_t)0xf93094dd, + (q31_t)0x5bb0ab, (q31_t)0xf93d13b8, (q31_t)0x5a5e07, (q31_t)0xf94992d7, + (q31_t)0x590dd8, (q31_t)0xf9561237, (q31_t)0x57c01d, (q31_t)0xf96291d9, + (q31_t)0x5674d6, (q31_t)0xf96f11bc, (q31_t)0x552c03, (q31_t)0xf97b91e1, + (q31_t)0x53e5a5, (q31_t)0xf9881245, (q31_t)0x52a1bb, (q31_t)0xf99492ea, + (q31_t)0x516045, (q31_t)0xf9a113cd, (q31_t)0x502145, (q31_t)0xf9ad94f0, + (q31_t)0x4ee4b8, (q31_t)0xf9ba1651, (q31_t)0x4daaa1, (q31_t)0xf9c697f0, + (q31_t)0x4c72fe, (q31_t)0xf9d319cc, (q31_t)0x4b3dcf, (q31_t)0xf9df9be6, + (q31_t)0x4a0b16, (q31_t)0xf9ec1e3b, (q31_t)0x48dad1, (q31_t)0xf9f8a0cd, + (q31_t)0x47ad01, (q31_t)0xfa05239a, (q31_t)0x4681a6, (q31_t)0xfa11a6a3, + (q31_t)0x4558c0, (q31_t)0xfa1e29e5, (q31_t)0x44324f, (q31_t)0xfa2aad62, + (q31_t)0x430e53, (q31_t)0xfa373119, (q31_t)0x41eccc, (q31_t)0xfa43b508, + (q31_t)0x40cdba, (q31_t)0xfa503930, (q31_t)0x3fb11d, (q31_t)0xfa5cbd91, + (q31_t)0x3e96f6, (q31_t)0xfa694229, (q31_t)0x3d7f44, (q31_t)0xfa75c6f8, + (q31_t)0x3c6a07, (q31_t)0xfa824bfd, (q31_t)0x3b573f, (q31_t)0xfa8ed139, + (q31_t)0x3a46ed, (q31_t)0xfa9b56ab, (q31_t)0x393910, (q31_t)0xfaa7dc52, + (q31_t)0x382da8, (q31_t)0xfab4622d, (q31_t)0x3724b6, (q31_t)0xfac0e83d, + (q31_t)0x361e3a, (q31_t)0xfacd6e81, (q31_t)0x351a33, (q31_t)0xfad9f4f8, + (q31_t)0x3418a2, (q31_t)0xfae67ba2, (q31_t)0x331986, (q31_t)0xfaf3027e, + (q31_t)0x321ce0, (q31_t)0xfaff898c, (q31_t)0x3122b0, (q31_t)0xfb0c10cb, + (q31_t)0x302af5, (q31_t)0xfb18983b, (q31_t)0x2f35b1, (q31_t)0xfb251fdc, + (q31_t)0x2e42e2, (q31_t)0xfb31a7ac, (q31_t)0x2d5289, (q31_t)0xfb3e2fac, + (q31_t)0x2c64a6, (q31_t)0xfb4ab7db, (q31_t)0x2b7939, (q31_t)0xfb574039, + (q31_t)0x2a9042, (q31_t)0xfb63c8c4, (q31_t)0x29a9c1, (q31_t)0xfb70517d, + (q31_t)0x28c5b6, (q31_t)0xfb7cda63, (q31_t)0x27e421, (q31_t)0xfb896375, + (q31_t)0x270502, (q31_t)0xfb95ecb4, (q31_t)0x262859, (q31_t)0xfba2761e, + (q31_t)0x254e27, (q31_t)0xfbaeffb3, (q31_t)0x24766a, (q31_t)0xfbbb8973, + (q31_t)0x23a124, (q31_t)0xfbc8135c, (q31_t)0x22ce54, (q31_t)0xfbd49d70, + (q31_t)0x21fdfb, (q31_t)0xfbe127ac, (q31_t)0x213018, (q31_t)0xfbedb212, + (q31_t)0x2064ab, (q31_t)0xfbfa3c9f, (q31_t)0x1f9bb5, (q31_t)0xfc06c754, + (q31_t)0x1ed535, (q31_t)0xfc135231, (q31_t)0x1e112b, (q31_t)0xfc1fdd34, + (q31_t)0x1d4f99, (q31_t)0xfc2c685d, (q31_t)0x1c907c, (q31_t)0xfc38f3ac, + (q31_t)0x1bd3d6, (q31_t)0xfc457f21, (q31_t)0x1b19a7, (q31_t)0xfc520aba, + (q31_t)0x1a61ee, (q31_t)0xfc5e9678, (q31_t)0x19acac, (q31_t)0xfc6b2259, + (q31_t)0x18f9e1, (q31_t)0xfc77ae5e, (q31_t)0x18498c, (q31_t)0xfc843a85, + (q31_t)0x179bae, (q31_t)0xfc90c6cf, (q31_t)0x16f047, (q31_t)0xfc9d533b, + (q31_t)0x164757, (q31_t)0xfca9dfc8, (q31_t)0x15a0dd, (q31_t)0xfcb66c77, + (q31_t)0x14fcda, (q31_t)0xfcc2f945, (q31_t)0x145b4e, (q31_t)0xfccf8634, + (q31_t)0x13bc39, (q31_t)0xfcdc1342, (q31_t)0x131f9b, (q31_t)0xfce8a06f, + (q31_t)0x128574, (q31_t)0xfcf52dbb, (q31_t)0x11edc3, (q31_t)0xfd01bb24, + (q31_t)0x11588a, (q31_t)0xfd0e48ab, (q31_t)0x10c5c7, (q31_t)0xfd1ad650, + (q31_t)0x10357c, (q31_t)0xfd276410, (q31_t)0xfa7a8, (q31_t)0xfd33f1ed, + (q31_t)0xf1c4a, (q31_t)0xfd407fe6, (q31_t)0xe9364, (q31_t)0xfd4d0df9, + (q31_t)0xe0cf5, (q31_t)0xfd599c28, (q31_t)0xd88fd, (q31_t)0xfd662a70, + (q31_t)0xd077c, (q31_t)0xfd72b8d2, (q31_t)0xc8872, (q31_t)0xfd7f474d, + (q31_t)0xc0be0, (q31_t)0xfd8bd5e1, (q31_t)0xb91c4, (q31_t)0xfd98648d, + (q31_t)0xb1a20, (q31_t)0xfda4f351, (q31_t)0xaa4f3, (q31_t)0xfdb1822c, + (q31_t)0xa323d, (q31_t)0xfdbe111e, (q31_t)0x9c1ff, (q31_t)0xfdcaa027, + (q31_t)0x95438, (q31_t)0xfdd72f45, (q31_t)0x8e8e8, (q31_t)0xfde3be78, + (q31_t)0x8800f, (q31_t)0xfdf04dc0, (q31_t)0x819ae, (q31_t)0xfdfcdd1d, + (q31_t)0x7b5c4, (q31_t)0xfe096c8d, (q31_t)0x75452, (q31_t)0xfe15fc11, + (q31_t)0x6f556, (q31_t)0xfe228ba7, (q31_t)0x698d3, (q31_t)0xfe2f1b50, + (q31_t)0x63ec6, (q31_t)0xfe3bab0b, (q31_t)0x5e731, (q31_t)0xfe483ad8, + (q31_t)0x59214, (q31_t)0xfe54cab5, (q31_t)0x53f6e, (q31_t)0xfe615aa3, + (q31_t)0x4ef3f, (q31_t)0xfe6deaa1, (q31_t)0x4a188, (q31_t)0xfe7a7aae, + (q31_t)0x45648, (q31_t)0xfe870aca, (q31_t)0x40d80, (q31_t)0xfe939af5, + (q31_t)0x3c72f, (q31_t)0xfea02b2e, (q31_t)0x38356, (q31_t)0xfeacbb74, + (q31_t)0x341f4, (q31_t)0xfeb94bc8, (q31_t)0x3030a, (q31_t)0xfec5dc28, + (q31_t)0x2c697, (q31_t)0xfed26c94, (q31_t)0x28c9c, (q31_t)0xfedefd0c, + (q31_t)0x25519, (q31_t)0xfeeb8d8f, (q31_t)0x2200d, (q31_t)0xfef81e1d, + (q31_t)0x1ed78, (q31_t)0xff04aeb5, (q31_t)0x1bd5c, (q31_t)0xff113f56, + (q31_t)0x18fb6, (q31_t)0xff1dd001, (q31_t)0x16489, (q31_t)0xff2a60b4, + (q31_t)0x13bd3, (q31_t)0xff36f170, (q31_t)0x11594, (q31_t)0xff438234, + (q31_t)0xf1ce, (q31_t)0xff5012fe, (q31_t)0xd07e, (q31_t)0xff5ca3d0, + (q31_t)0xb1a7, (q31_t)0xff6934a8, (q31_t)0x9547, (q31_t)0xff75c585, + (q31_t)0x7b5f, (q31_t)0xff825668, (q31_t)0x63ee, (q31_t)0xff8ee750, + (q31_t)0x4ef5, (q31_t)0xff9b783c, (q31_t)0x3c74, (q31_t)0xffa8092c, + (q31_t)0x2c6a, (q31_t)0xffb49a1f, (q31_t)0x1ed8, (q31_t)0xffc12b16, + (q31_t)0x13bd, (q31_t)0xffcdbc0f, (q31_t)0xb1a, (q31_t)0xffda4d09, + (q31_t)0x4ef, (q31_t)0xffe6de05, (q31_t)0x13c, (q31_t)0xfff36f02, + (q31_t)0x0, (q31_t)0x0, (q31_t)0x13c, (q31_t)0xc90fe, + (q31_t)0x4ef, (q31_t)0x1921fb, (q31_t)0xb1a, (q31_t)0x25b2f7, + (q31_t)0x13bd, (q31_t)0x3243f1, (q31_t)0x1ed8, (q31_t)0x3ed4ea, + (q31_t)0x2c6a, (q31_t)0x4b65e1, (q31_t)0x3c74, (q31_t)0x57f6d4, + (q31_t)0x4ef5, (q31_t)0x6487c4, (q31_t)0x63ee, (q31_t)0x7118b0, + (q31_t)0x7b5f, (q31_t)0x7da998, (q31_t)0x9547, (q31_t)0x8a3a7b, + (q31_t)0xb1a7, (q31_t)0x96cb58, (q31_t)0xd07e, (q31_t)0xa35c30, + (q31_t)0xf1ce, (q31_t)0xafed02, (q31_t)0x11594, (q31_t)0xbc7dcc, + (q31_t)0x13bd3, (q31_t)0xc90e90, (q31_t)0x16489, (q31_t)0xd59f4c, + (q31_t)0x18fb6, (q31_t)0xe22fff, (q31_t)0x1bd5c, (q31_t)0xeec0aa, + (q31_t)0x1ed78, (q31_t)0xfb514b, (q31_t)0x2200d, (q31_t)0x107e1e3, + (q31_t)0x25519, (q31_t)0x1147271, (q31_t)0x28c9c, (q31_t)0x12102f4, + (q31_t)0x2c697, (q31_t)0x12d936c, (q31_t)0x3030a, (q31_t)0x13a23d8, + (q31_t)0x341f4, (q31_t)0x146b438, (q31_t)0x38356, (q31_t)0x153448c, + (q31_t)0x3c72f, (q31_t)0x15fd4d2, (q31_t)0x40d80, (q31_t)0x16c650b, + (q31_t)0x45648, (q31_t)0x178f536, (q31_t)0x4a188, (q31_t)0x1858552, + (q31_t)0x4ef3f, (q31_t)0x192155f, (q31_t)0x53f6e, (q31_t)0x19ea55d, + (q31_t)0x59214, (q31_t)0x1ab354b, (q31_t)0x5e731, (q31_t)0x1b7c528, + (q31_t)0x63ec6, (q31_t)0x1c454f5, (q31_t)0x698d3, (q31_t)0x1d0e4b0, + (q31_t)0x6f556, (q31_t)0x1dd7459, (q31_t)0x75452, (q31_t)0x1ea03ef, + (q31_t)0x7b5c4, (q31_t)0x1f69373, (q31_t)0x819ae, (q31_t)0x20322e3, + (q31_t)0x8800f, (q31_t)0x20fb240, (q31_t)0x8e8e8, (q31_t)0x21c4188, + (q31_t)0x95438, (q31_t)0x228d0bb, (q31_t)0x9c1ff, (q31_t)0x2355fd9, + (q31_t)0xa323d, (q31_t)0x241eee2, (q31_t)0xaa4f3, (q31_t)0x24e7dd4, + (q31_t)0xb1a20, (q31_t)0x25b0caf, (q31_t)0xb91c4, (q31_t)0x2679b73, + (q31_t)0xc0be0, (q31_t)0x2742a1f, (q31_t)0xc8872, (q31_t)0x280b8b3, + (q31_t)0xd077c, (q31_t)0x28d472e, (q31_t)0xd88fd, (q31_t)0x299d590, + (q31_t)0xe0cf5, (q31_t)0x2a663d8, (q31_t)0xe9364, (q31_t)0x2b2f207, + (q31_t)0xf1c4a, (q31_t)0x2bf801a, (q31_t)0xfa7a8, (q31_t)0x2cc0e13, + (q31_t)0x10357c, (q31_t)0x2d89bf0, (q31_t)0x10c5c7, (q31_t)0x2e529b0, + (q31_t)0x11588a, (q31_t)0x2f1b755, (q31_t)0x11edc3, (q31_t)0x2fe44dc, + (q31_t)0x128574, (q31_t)0x30ad245, (q31_t)0x131f9b, (q31_t)0x3175f91, + (q31_t)0x13bc39, (q31_t)0x323ecbe, (q31_t)0x145b4e, (q31_t)0x33079cc, + (q31_t)0x14fcda, (q31_t)0x33d06bb, (q31_t)0x15a0dd, (q31_t)0x3499389, + (q31_t)0x164757, (q31_t)0x3562038, (q31_t)0x16f047, (q31_t)0x362acc5, + (q31_t)0x179bae, (q31_t)0x36f3931, (q31_t)0x18498c, (q31_t)0x37bc57b, + (q31_t)0x18f9e1, (q31_t)0x38851a2, (q31_t)0x19acac, (q31_t)0x394dda7, + (q31_t)0x1a61ee, (q31_t)0x3a16988, (q31_t)0x1b19a7, (q31_t)0x3adf546, + (q31_t)0x1bd3d6, (q31_t)0x3ba80df, (q31_t)0x1c907c, (q31_t)0x3c70c54, + (q31_t)0x1d4f99, (q31_t)0x3d397a3, (q31_t)0x1e112b, (q31_t)0x3e022cc, + (q31_t)0x1ed535, (q31_t)0x3ecadcf, (q31_t)0x1f9bb5, (q31_t)0x3f938ac, + (q31_t)0x2064ab, (q31_t)0x405c361, (q31_t)0x213018, (q31_t)0x4124dee, + (q31_t)0x21fdfb, (q31_t)0x41ed854, (q31_t)0x22ce54, (q31_t)0x42b6290, + (q31_t)0x23a124, (q31_t)0x437eca4, (q31_t)0x24766a, (q31_t)0x444768d, + (q31_t)0x254e27, (q31_t)0x451004d, (q31_t)0x262859, (q31_t)0x45d89e2, + (q31_t)0x270502, (q31_t)0x46a134c, (q31_t)0x27e421, (q31_t)0x4769c8b, + (q31_t)0x28c5b6, (q31_t)0x483259d, (q31_t)0x29a9c1, (q31_t)0x48fae83, + (q31_t)0x2a9042, (q31_t)0x49c373c, (q31_t)0x2b7939, (q31_t)0x4a8bfc7, + (q31_t)0x2c64a6, (q31_t)0x4b54825, (q31_t)0x2d5289, (q31_t)0x4c1d054, + (q31_t)0x2e42e2, (q31_t)0x4ce5854, (q31_t)0x2f35b1, (q31_t)0x4dae024, + (q31_t)0x302af5, (q31_t)0x4e767c5, (q31_t)0x3122b0, (q31_t)0x4f3ef35, + (q31_t)0x321ce0, (q31_t)0x5007674, (q31_t)0x331986, (q31_t)0x50cfd82, + (q31_t)0x3418a2, (q31_t)0x519845e, (q31_t)0x351a33, (q31_t)0x5260b08, + (q31_t)0x361e3a, (q31_t)0x532917f, (q31_t)0x3724b6, (q31_t)0x53f17c3, + (q31_t)0x382da8, (q31_t)0x54b9dd3, (q31_t)0x393910, (q31_t)0x55823ae, + (q31_t)0x3a46ed, (q31_t)0x564a955, (q31_t)0x3b573f, (q31_t)0x5712ec7, + (q31_t)0x3c6a07, (q31_t)0x57db403, (q31_t)0x3d7f44, (q31_t)0x58a3908, + (q31_t)0x3e96f6, (q31_t)0x596bdd7, (q31_t)0x3fb11d, (q31_t)0x5a3426f, + (q31_t)0x40cdba, (q31_t)0x5afc6d0, (q31_t)0x41eccc, (q31_t)0x5bc4af8, + (q31_t)0x430e53, (q31_t)0x5c8cee7, (q31_t)0x44324f, (q31_t)0x5d5529e, + (q31_t)0x4558c0, (q31_t)0x5e1d61b, (q31_t)0x4681a6, (q31_t)0x5ee595d, + (q31_t)0x47ad01, (q31_t)0x5fadc66, (q31_t)0x48dad1, (q31_t)0x6075f33, + (q31_t)0x4a0b16, (q31_t)0x613e1c5, (q31_t)0x4b3dcf, (q31_t)0x620641a, + (q31_t)0x4c72fe, (q31_t)0x62ce634, (q31_t)0x4daaa1, (q31_t)0x6396810, + (q31_t)0x4ee4b8, (q31_t)0x645e9af, (q31_t)0x502145, (q31_t)0x6526b10, + (q31_t)0x516045, (q31_t)0x65eec33, (q31_t)0x52a1bb, (q31_t)0x66b6d16, + (q31_t)0x53e5a5, (q31_t)0x677edbb, (q31_t)0x552c03, (q31_t)0x6846e1f, + (q31_t)0x5674d6, (q31_t)0x690ee44, (q31_t)0x57c01d, (q31_t)0x69d6e27, + (q31_t)0x590dd8, (q31_t)0x6a9edc9, (q31_t)0x5a5e07, (q31_t)0x6b66d29, + (q31_t)0x5bb0ab, (q31_t)0x6c2ec48, (q31_t)0x5d05c3, (q31_t)0x6cf6b23, + (q31_t)0x5e5d4e, (q31_t)0x6dbe9bb, (q31_t)0x5fb74e, (q31_t)0x6e86810, + (q31_t)0x6113c2, (q31_t)0x6f4e620, (q31_t)0x6272aa, (q31_t)0x70163eb, + (q31_t)0x63d405, (q31_t)0x70de172, (q31_t)0x6537d4, (q31_t)0x71a5eb3, + (q31_t)0x669e18, (q31_t)0x726dbae, (q31_t)0x6806ce, (q31_t)0x7335862, + (q31_t)0x6971f9, (q31_t)0x73fd4cf, (q31_t)0x6adf97, (q31_t)0x74c50f4, + (q31_t)0x6c4fa8, (q31_t)0x758ccd2, (q31_t)0x6dc22e, (q31_t)0x7654867, + (q31_t)0x6f3726, (q31_t)0x771c3b3, (q31_t)0x70ae92, (q31_t)0x77e3eb5, + (q31_t)0x722871, (q31_t)0x78ab96e, (q31_t)0x73a4c3, (q31_t)0x79733dc, + (q31_t)0x752389, (q31_t)0x7a3adff, (q31_t)0x76a4c2, (q31_t)0x7b027d7, + (q31_t)0x78286e, (q31_t)0x7bca163, (q31_t)0x79ae8c, (q31_t)0x7c91aa3, + (q31_t)0x7b371e, (q31_t)0x7d59396, (q31_t)0x7cc223, (q31_t)0x7e20c3b, + (q31_t)0x7e4f9b, (q31_t)0x7ee8493, (q31_t)0x7fdf85, (q31_t)0x7fafc9c, + (q31_t)0x8171e2, (q31_t)0x8077457, (q31_t)0x8306b2, (q31_t)0x813ebc2, + (q31_t)0x849df4, (q31_t)0x82062de, (q31_t)0x8637a9, (q31_t)0x82cd9a9, + (q31_t)0x87d3d0, (q31_t)0x8395024, (q31_t)0x89726a, (q31_t)0x845c64d, + (q31_t)0x8b1376, (q31_t)0x8523c25, (q31_t)0x8cb6f5, (q31_t)0x85eb1ab, + (q31_t)0x8e5ce5, (q31_t)0x86b26de, (q31_t)0x900548, (q31_t)0x8779bbe, + (q31_t)0x91b01d, (q31_t)0x884104b, (q31_t)0x935d64, (q31_t)0x8908483, + (q31_t)0x950d1d, (q31_t)0x89cf867, (q31_t)0x96bf48, (q31_t)0x8a96bf6, + (q31_t)0x9873e4, (q31_t)0x8b5df30, (q31_t)0x9a2af3, (q31_t)0x8c25213, + (q31_t)0x9be473, (q31_t)0x8cec4a0, (q31_t)0x9da065, (q31_t)0x8db36d6, + (q31_t)0x9f5ec8, (q31_t)0x8e7a8b5, (q31_t)0xa11f9d, (q31_t)0x8f41a3c, + (q31_t)0xa2e2e3, (q31_t)0x9008b6a, (q31_t)0xa4a89b, (q31_t)0x90cfc40, + (q31_t)0xa670c4, (q31_t)0x9196cbc, (q31_t)0xa83b5e, (q31_t)0x925dcdf, + (q31_t)0xaa086a, (q31_t)0x9324ca7, (q31_t)0xabd7e6, (q31_t)0x93ebc14, + (q31_t)0xada9d4, (q31_t)0x94b2b27, (q31_t)0xaf7e33, (q31_t)0x95799dd, + (q31_t)0xb15502, (q31_t)0x9640837, (q31_t)0xb32e42, (q31_t)0x9707635, + (q31_t)0xb509f3, (q31_t)0x97ce3d5, (q31_t)0xb6e815, (q31_t)0x9895118, + (q31_t)0xb8c8a7, (q31_t)0x995bdfd, (q31_t)0xbaabaa, (q31_t)0x9a22a83, + (q31_t)0xbc911d, (q31_t)0x9ae96aa, (q31_t)0xbe7901, (q31_t)0x9bb0271, + (q31_t)0xc06355, (q31_t)0x9c76dd8, (q31_t)0xc25019, (q31_t)0x9d3d8df, + (q31_t)0xc43f4d, (q31_t)0x9e04385, (q31_t)0xc630f2, (q31_t)0x9ecadc9, + (q31_t)0xc82506, (q31_t)0x9f917ac, (q31_t)0xca1b8a, (q31_t)0xa05812c, + (q31_t)0xcc147f, (q31_t)0xa11ea49, (q31_t)0xce0fe3, (q31_t)0xa1e5303, + (q31_t)0xd00db6, (q31_t)0xa2abb59, (q31_t)0xd20dfa, (q31_t)0xa37234a, + (q31_t)0xd410ad, (q31_t)0xa438ad7, (q31_t)0xd615cf, (q31_t)0xa4ff1fe, + (q31_t)0xd81d61, (q31_t)0xa5c58c0, (q31_t)0xda2762, (q31_t)0xa68bf1b, + (q31_t)0xdc33d2, (q31_t)0xa752510, (q31_t)0xde42b2, (q31_t)0xa818a9d, + (q31_t)0xe05401, (q31_t)0xa8defc3, (q31_t)0xe267be, (q31_t)0xa9a5480, + (q31_t)0xe47deb, (q31_t)0xaa6b8d5, (q31_t)0xe69686, (q31_t)0xab31cc1, + (q31_t)0xe8b190, (q31_t)0xabf8043, (q31_t)0xeacf09, (q31_t)0xacbe35b, + (q31_t)0xeceef1, (q31_t)0xad84609, (q31_t)0xef1147, (q31_t)0xae4a84b, + (q31_t)0xf1360b, (q31_t)0xaf10a22, (q31_t)0xf35d3e, (q31_t)0xafd6b8d, + (q31_t)0xf586df, (q31_t)0xb09cc8c, (q31_t)0xf7b2ee, (q31_t)0xb162d1d, + (q31_t)0xf9e16b, (q31_t)0xb228d42, (q31_t)0xfc1257, (q31_t)0xb2eecf8, + (q31_t)0xfe45b0, (q31_t)0xb3b4c40, (q31_t)0x1007b77, (q31_t)0xb47ab19, + (q31_t)0x102b3ac, (q31_t)0xb540982, (q31_t)0x104ee4f, (q31_t)0xb60677c, + (q31_t)0x1072b5f, (q31_t)0xb6cc506, (q31_t)0x1096add, (q31_t)0xb79221f, + (q31_t)0x10bacc8, (q31_t)0xb857ec7, (q31_t)0x10df120, (q31_t)0xb91dafc, + (q31_t)0x11037e6, (q31_t)0xb9e36c0, (q31_t)0x1128119, (q31_t)0xbaa9211, + (q31_t)0x114ccb9, (q31_t)0xbb6ecef, (q31_t)0x1171ac6, (q31_t)0xbc34759, + (q31_t)0x1196b3f, (q31_t)0xbcfa150, (q31_t)0x11bbe26, (q31_t)0xbdbfad1, + (q31_t)0x11e1379, (q31_t)0xbe853de, (q31_t)0x1206b39, (q31_t)0xbf4ac75, + (q31_t)0x122c566, (q31_t)0xc010496, (q31_t)0x12521ff, (q31_t)0xc0d5c41, + (q31_t)0x1278104, (q31_t)0xc19b374, (q31_t)0x129e276, (q31_t)0xc260a31, + (q31_t)0x12c4653, (q31_t)0xc326075, (q31_t)0x12eac9d, (q31_t)0xc3eb641, + (q31_t)0x1311553, (q31_t)0xc4b0b94, (q31_t)0x1338075, (q31_t)0xc57606e, + (q31_t)0x135ee02, (q31_t)0xc63b4ce, (q31_t)0x1385dfb, (q31_t)0xc7008b3, + (q31_t)0x13ad060, (q31_t)0xc7c5c1e, (q31_t)0x13d4530, (q31_t)0xc88af0e, + (q31_t)0x13fbc6c, (q31_t)0xc950182, (q31_t)0x1423613, (q31_t)0xca1537a, + (q31_t)0x144b225, (q31_t)0xcada4f5, (q31_t)0x14730a3, (q31_t)0xcb9f5f3, + (q31_t)0x149b18b, (q31_t)0xcc64673, (q31_t)0x14c34df, (q31_t)0xcd29676, + (q31_t)0x14eba9d, (q31_t)0xcdee5f9, (q31_t)0x15142c6, (q31_t)0xceb34fe, + (q31_t)0x153cd5a, (q31_t)0xcf78383, (q31_t)0x1565a58, (q31_t)0xd03d189, + (q31_t)0x158e9c1, (q31_t)0xd101f0e, (q31_t)0x15b7b94, (q31_t)0xd1c6c11, + (q31_t)0x15e0fd1, (q31_t)0xd28b894, (q31_t)0x160a678, (q31_t)0xd350495, + (q31_t)0x1633f8a, (q31_t)0xd415013, (q31_t)0x165db05, (q31_t)0xd4d9b0e, + (q31_t)0x16878eb, (q31_t)0xd59e586, (q31_t)0x16b193a, (q31_t)0xd662f7b, + (q31_t)0x16dbbf3, (q31_t)0xd7278eb, (q31_t)0x1706115, (q31_t)0xd7ec1d6, + (q31_t)0x17308a1, (q31_t)0xd8b0a3d, (q31_t)0x175b296, (q31_t)0xd97521d, + (q31_t)0x1785ef4, (q31_t)0xda39978, (q31_t)0x17b0dbb, (q31_t)0xdafe04b, + (q31_t)0x17dbeec, (q31_t)0xdbc2698, (q31_t)0x1807285, (q31_t)0xdc86c5d, + (q31_t)0x1832888, (q31_t)0xdd4b19a, (q31_t)0x185e0f3, (q31_t)0xde0f64f, + (q31_t)0x1889bc6, (q31_t)0xded3a7b, (q31_t)0x18b5903, (q31_t)0xdf97e1d, + (q31_t)0x18e18a7, (q31_t)0xe05c135, (q31_t)0x190dab4, (q31_t)0xe1203c3, + (q31_t)0x1939f29, (q31_t)0xe1e45c6, (q31_t)0x1966606, (q31_t)0xe2a873e, + (q31_t)0x1992f4c, (q31_t)0xe36c82a, (q31_t)0x19bfaf9, (q31_t)0xe430889, + (q31_t)0x19ec90d, (q31_t)0xe4f485c, (q31_t)0x1a1998a, (q31_t)0xe5b87a2, + (q31_t)0x1a46c6e, (q31_t)0xe67c65a, (q31_t)0x1a741b9, (q31_t)0xe740483, + (q31_t)0x1aa196c, (q31_t)0xe80421e, (q31_t)0x1acf386, (q31_t)0xe8c7f2a, + (q31_t)0x1afd007, (q31_t)0xe98bba7, (q31_t)0x1b2aef0, (q31_t)0xea4f793, + (q31_t)0x1b5903f, (q31_t)0xeb132ef, (q31_t)0x1b873f5, (q31_t)0xebd6db9, + (q31_t)0x1bb5a11, (q31_t)0xec9a7f3, (q31_t)0x1be4294, (q31_t)0xed5e19a, + (q31_t)0x1c12d7e, (q31_t)0xee21aaf, (q31_t)0x1c41ace, (q31_t)0xeee5331, + (q31_t)0x1c70a84, (q31_t)0xefa8b20, (q31_t)0x1c9fca0, (q31_t)0xf06c27a, + (q31_t)0x1ccf122, (q31_t)0xf12f941, (q31_t)0x1cfe80a, (q31_t)0xf1f2f73, + (q31_t)0x1d2e158, (q31_t)0xf2b650f, (q31_t)0x1d5dd0c, (q31_t)0xf379a16, + (q31_t)0x1d8db25, (q31_t)0xf43ce86, (q31_t)0x1dbdba3, (q31_t)0xf500260, + (q31_t)0x1dede87, (q31_t)0xf5c35a3, (q31_t)0x1e1e3d0, (q31_t)0xf68684e, + (q31_t)0x1e4eb7e, (q31_t)0xf749a61, (q31_t)0x1e7f591, (q31_t)0xf80cbdc, + (q31_t)0x1eb0209, (q31_t)0xf8cfcbe, (q31_t)0x1ee10e5, (q31_t)0xf992d06, + (q31_t)0x1f12227, (q31_t)0xfa55cb4, (q31_t)0x1f435cc, (q31_t)0xfb18bc8, + (q31_t)0x1f74bd6, (q31_t)0xfbdba40, (q31_t)0x1fa6445, (q31_t)0xfc9e81e, + (q31_t)0x1fd7f17, (q31_t)0xfd6155f, (q31_t)0x2009c4e, (q31_t)0xfe24205, + (q31_t)0x203bbe8, (q31_t)0xfee6e0d, (q31_t)0x206dde6, (q31_t)0xffa9979, + (q31_t)0x20a0248, (q31_t)0x1006c446, (q31_t)0x20d290d, (q31_t)0x1012ee76, + (q31_t)0x2105236, (q31_t)0x101f1807, (q31_t)0x2137dc2, (q31_t)0x102b40f8, + (q31_t)0x216abb1, (q31_t)0x1037694b, (q31_t)0x219dc03, (q31_t)0x104390fd, + (q31_t)0x21d0eb8, (q31_t)0x104fb80e, (q31_t)0x22043d0, (q31_t)0x105bde7f, + (q31_t)0x2237b4b, (q31_t)0x1068044e, (q31_t)0x226b528, (q31_t)0x1074297b, + (q31_t)0x229f167, (q31_t)0x10804e06, (q31_t)0x22d3009, (q31_t)0x108c71ee, + (q31_t)0x230710d, (q31_t)0x10989532, (q31_t)0x233b473, (q31_t)0x10a4b7d3, + (q31_t)0x236fa3b, (q31_t)0x10b0d9d0, (q31_t)0x23a4265, (q31_t)0x10bcfb28, + (q31_t)0x23d8cf1, (q31_t)0x10c91bda, (q31_t)0x240d9de, (q31_t)0x10d53be7, + (q31_t)0x244292c, (q31_t)0x10e15b4e, (q31_t)0x2477adc, (q31_t)0x10ed7a0e, + (q31_t)0x24aceed, (q31_t)0x10f99827, (q31_t)0x24e255e, (q31_t)0x1105b599, + (q31_t)0x2517e31, (q31_t)0x1111d263, (q31_t)0x254d965, (q31_t)0x111dee84, + (q31_t)0x25836f9, (q31_t)0x112a09fc, (q31_t)0x25b96ee, (q31_t)0x113624cb, + (q31_t)0x25ef943, (q31_t)0x11423ef0, (q31_t)0x2625df8, (q31_t)0x114e586a, + (q31_t)0x265c50e, (q31_t)0x115a713a, (q31_t)0x2692e83, (q31_t)0x1166895f, + (q31_t)0x26c9a58, (q31_t)0x1172a0d7, (q31_t)0x270088e, (q31_t)0x117eb7a4, + (q31_t)0x2737922, (q31_t)0x118acdc4, (q31_t)0x276ec16, (q31_t)0x1196e337, + (q31_t)0x27a616a, (q31_t)0x11a2f7fc, (q31_t)0x27dd91c, (q31_t)0x11af0c13, + (q31_t)0x281532e, (q31_t)0x11bb1f7c, (q31_t)0x284cf9f, (q31_t)0x11c73235, + (q31_t)0x2884e6e, (q31_t)0x11d3443f, (q31_t)0x28bcf9c, (q31_t)0x11df5599, + (q31_t)0x28f5329, (q31_t)0x11eb6643, (q31_t)0x292d914, (q31_t)0x11f7763c, + (q31_t)0x296615d, (q31_t)0x12038584, (q31_t)0x299ec05, (q31_t)0x120f941a, + (q31_t)0x29d790a, (q31_t)0x121ba1fd, (q31_t)0x2a1086d, (q31_t)0x1227af2e, + (q31_t)0x2a49a2e, (q31_t)0x1233bbac, (q31_t)0x2a82e4d, (q31_t)0x123fc776, + (q31_t)0x2abc4c9, (q31_t)0x124bd28c, (q31_t)0x2af5da2, (q31_t)0x1257dced, + (q31_t)0x2b2f8d8, (q31_t)0x1263e699, (q31_t)0x2b6966c, (q31_t)0x126fef90, + (q31_t)0x2ba365c, (q31_t)0x127bf7d1, (q31_t)0x2bdd8a9, (q31_t)0x1287ff5b, + (q31_t)0x2c17d52, (q31_t)0x1294062f, (q31_t)0x2c52459, (q31_t)0x12a00c4b, + (q31_t)0x2c8cdbb, (q31_t)0x12ac11af, (q31_t)0x2cc7979, (q31_t)0x12b8165b, + (q31_t)0x2d02794, (q31_t)0x12c41a4f, (q31_t)0x2d3d80a, (q31_t)0x12d01d89, + (q31_t)0x2d78add, (q31_t)0x12dc2009, (q31_t)0x2db400a, (q31_t)0x12e821cf, + (q31_t)0x2def794, (q31_t)0x12f422db, (q31_t)0x2e2b178, (q31_t)0x1300232c, + (q31_t)0x2e66db8, (q31_t)0x130c22c1, (q31_t)0x2ea2c53, (q31_t)0x1318219a, + (q31_t)0x2eded49, (q31_t)0x13241fb6, (q31_t)0x2f1b099, (q31_t)0x13301d16, + (q31_t)0x2f57644, (q31_t)0x133c19b8, (q31_t)0x2f93e4a, (q31_t)0x1348159d, + (q31_t)0x2fd08a9, (q31_t)0x135410c3, (q31_t)0x300d563, (q31_t)0x13600b2a, + (q31_t)0x304a477, (q31_t)0x136c04d2, (q31_t)0x30875e5, (q31_t)0x1377fdbb, + (q31_t)0x30c49ad, (q31_t)0x1383f5e3, (q31_t)0x3101fce, (q31_t)0x138fed4b, + (q31_t)0x313f848, (q31_t)0x139be3f2, (q31_t)0x317d31c, (q31_t)0x13a7d9d7, + (q31_t)0x31bb049, (q31_t)0x13b3cefa, (q31_t)0x31f8fcf, (q31_t)0x13bfc35b, + (q31_t)0x32371ae, (q31_t)0x13cbb6f8, (q31_t)0x32755e5, (q31_t)0x13d7a9d3, + (q31_t)0x32b3c75, (q31_t)0x13e39be9, (q31_t)0x32f255e, (q31_t)0x13ef8d3c, + (q31_t)0x333109e, (q31_t)0x13fb7dc9, (q31_t)0x336fe37, (q31_t)0x14076d91, + (q31_t)0x33aee27, (q31_t)0x14135c94, (q31_t)0x33ee070, (q31_t)0x141f4ad1, + (q31_t)0x342d510, (q31_t)0x142b3846, (q31_t)0x346cc07, (q31_t)0x143724f5, + (q31_t)0x34ac556, (q31_t)0x144310dd, (q31_t)0x34ec0fc, (q31_t)0x144efbfc, + (q31_t)0x352bef9, (q31_t)0x145ae653, (q31_t)0x356bf4d, (q31_t)0x1466cfe1, + (q31_t)0x35ac1f7, (q31_t)0x1472b8a5, (q31_t)0x35ec6f8, (q31_t)0x147ea0a0, + (q31_t)0x362ce50, (q31_t)0x148a87d1, (q31_t)0x366d7fd, (q31_t)0x14966e36, + (q31_t)0x36ae401, (q31_t)0x14a253d1, (q31_t)0x36ef25b, (q31_t)0x14ae38a0, + (q31_t)0x373030a, (q31_t)0x14ba1ca3, (q31_t)0x377160f, (q31_t)0x14c5ffd9, + (q31_t)0x37b2b6a, (q31_t)0x14d1e242, (q31_t)0x37f4319, (q31_t)0x14ddc3de, + (q31_t)0x3835d1e, (q31_t)0x14e9a4ac, (q31_t)0x3877978, (q31_t)0x14f584ac, + (q31_t)0x38b9827, (q31_t)0x150163dc, (q31_t)0x38fb92a, (q31_t)0x150d423d, + (q31_t)0x393dc82, (q31_t)0x15191fcf, (q31_t)0x398022f, (q31_t)0x1524fc90, + (q31_t)0x39c2a2f, (q31_t)0x1530d881, (q31_t)0x3a05484, (q31_t)0x153cb3a0, + (q31_t)0x3a4812c, (q31_t)0x15488dee, (q31_t)0x3a8b028, (q31_t)0x1554676a, + (q31_t)0x3ace178, (q31_t)0x15604013, (q31_t)0x3b1151b, (q31_t)0x156c17e9, + (q31_t)0x3b54b11, (q31_t)0x1577eeec, (q31_t)0x3b9835a, (q31_t)0x1583c51b, + (q31_t)0x3bdbdf6, (q31_t)0x158f9a76, (q31_t)0x3c1fae5, (q31_t)0x159b6efb, + (q31_t)0x3c63a26, (q31_t)0x15a742ac, (q31_t)0x3ca7bba, (q31_t)0x15b31587, + (q31_t)0x3cebfa0, (q31_t)0x15bee78c, (q31_t)0x3d305d8, (q31_t)0x15cab8ba, + (q31_t)0x3d74e62, (q31_t)0x15d68911, (q31_t)0x3db993e, (q31_t)0x15e25890, + (q31_t)0x3dfe66c, (q31_t)0x15ee2738, (q31_t)0x3e435ea, (q31_t)0x15f9f507, + (q31_t)0x3e887bb, (q31_t)0x1605c1fd, (q31_t)0x3ecdbdc, (q31_t)0x16118e1a, + (q31_t)0x3f1324e, (q31_t)0x161d595d, (q31_t)0x3f58b10, (q31_t)0x162923c5, + (q31_t)0x3f9e624, (q31_t)0x1634ed53, (q31_t)0x3fe4388, (q31_t)0x1640b606, + (q31_t)0x402a33c, (q31_t)0x164c7ddd, (q31_t)0x4070540, (q31_t)0x165844d8, + (q31_t)0x40b6994, (q31_t)0x16640af7, (q31_t)0x40fd037, (q31_t)0x166fd039, + (q31_t)0x414392b, (q31_t)0x167b949d, (q31_t)0x418a46d, (q31_t)0x16875823, + (q31_t)0x41d11ff, (q31_t)0x16931acb, (q31_t)0x42181e0, (q31_t)0x169edc94, + (q31_t)0x425f410, (q31_t)0x16aa9d7e, (q31_t)0x42a688f, (q31_t)0x16b65d88, + (q31_t)0x42edf5c, (q31_t)0x16c21cb2, (q31_t)0x4335877, (q31_t)0x16cddafb, + (q31_t)0x437d3e1, (q31_t)0x16d99864, (q31_t)0x43c5199, (q31_t)0x16e554ea, + (q31_t)0x440d19e, (q31_t)0x16f1108f, (q31_t)0x44553f2, (q31_t)0x16fccb51, + (q31_t)0x449d892, (q31_t)0x17088531, (q31_t)0x44e5f80, (q31_t)0x17143e2d, + (q31_t)0x452e8bc, (q31_t)0x171ff646, (q31_t)0x4577444, (q31_t)0x172bad7a, + (q31_t)0x45c0219, (q31_t)0x173763c9, (q31_t)0x460923b, (q31_t)0x17431933, + (q31_t)0x46524a9, (q31_t)0x174ecdb8, (q31_t)0x469b963, (q31_t)0x175a8157, + (q31_t)0x46e5069, (q31_t)0x1766340f, (q31_t)0x472e9bc, (q31_t)0x1771e5e0, + (q31_t)0x477855a, (q31_t)0x177d96ca, (q31_t)0x47c2344, (q31_t)0x178946cc, + (q31_t)0x480c379, (q31_t)0x1794f5e6, (q31_t)0x48565f9, (q31_t)0x17a0a417, + (q31_t)0x48a0ac4, (q31_t)0x17ac515f, (q31_t)0x48eb1db, (q31_t)0x17b7fdbd, + (q31_t)0x4935b3c, (q31_t)0x17c3a931, (q31_t)0x49806e7, (q31_t)0x17cf53bb, + (q31_t)0x49cb4dd, (q31_t)0x17dafd59, (q31_t)0x4a1651c, (q31_t)0x17e6a60c, + (q31_t)0x4a617a6, (q31_t)0x17f24dd3, (q31_t)0x4aacc7a, (q31_t)0x17fdf4ae, + (q31_t)0x4af8397, (q31_t)0x18099a9c, (q31_t)0x4b43cfd, (q31_t)0x18153f9d, + (q31_t)0x4b8f8ad, (q31_t)0x1820e3b0, (q31_t)0x4bdb6a6, (q31_t)0x182c86d5, + (q31_t)0x4c276e8, (q31_t)0x1838290c, (q31_t)0x4c73972, (q31_t)0x1843ca53, + (q31_t)0x4cbfe45, (q31_t)0x184f6aab, (q31_t)0x4d0c560, (q31_t)0x185b0a13, + (q31_t)0x4d58ec3, (q31_t)0x1866a88a, (q31_t)0x4da5a6f, (q31_t)0x18724611, + (q31_t)0x4df2862, (q31_t)0x187de2a7, (q31_t)0x4e3f89c, (q31_t)0x18897e4a, + (q31_t)0x4e8cb1e, (q31_t)0x189518fc, (q31_t)0x4ed9fe7, (q31_t)0x18a0b2bb, + (q31_t)0x4f276f7, (q31_t)0x18ac4b87, (q31_t)0x4f7504e, (q31_t)0x18b7e35f, + (q31_t)0x4fc2bec, (q31_t)0x18c37a44, (q31_t)0x50109d0, (q31_t)0x18cf1034, + (q31_t)0x505e9fb, (q31_t)0x18daa52f, (q31_t)0x50acc6b, (q31_t)0x18e63935, + (q31_t)0x50fb121, (q31_t)0x18f1cc45, (q31_t)0x514981d, (q31_t)0x18fd5e5f, + (q31_t)0x519815f, (q31_t)0x1908ef82, (q31_t)0x51e6ce6, (q31_t)0x19147fae, + (q31_t)0x5235ab2, (q31_t)0x19200ee3, (q31_t)0x5284ac3, (q31_t)0x192b9d1f, + (q31_t)0x52d3d18, (q31_t)0x19372a64, (q31_t)0x53231b3, (q31_t)0x1942b6af, + (q31_t)0x5372891, (q31_t)0x194e4201, (q31_t)0x53c21b4, (q31_t)0x1959cc5a, + (q31_t)0x5411d1b, (q31_t)0x196555b8, (q31_t)0x5461ac6, (q31_t)0x1970de1b, + (q31_t)0x54b1ab4, (q31_t)0x197c6584, (q31_t)0x5501ce5, (q31_t)0x1987ebf0, + (q31_t)0x555215a, (q31_t)0x19937161, (q31_t)0x55a2812, (q31_t)0x199ef5d6, + (q31_t)0x55f310d, (q31_t)0x19aa794d, (q31_t)0x5643c4a, (q31_t)0x19b5fbc8, + (q31_t)0x56949ca, (q31_t)0x19c17d44, (q31_t)0x56e598c, (q31_t)0x19ccfdc2, + (q31_t)0x5736b90, (q31_t)0x19d87d42, (q31_t)0x5787fd6, (q31_t)0x19e3fbc3, + (q31_t)0x57d965d, (q31_t)0x19ef7944, (q31_t)0x582af26, (q31_t)0x19faf5c5, + (q31_t)0x587ca31, (q31_t)0x1a067145, (q31_t)0x58ce77c, (q31_t)0x1a11ebc5, + (q31_t)0x5920708, (q31_t)0x1a1d6544, (q31_t)0x59728d5, (q31_t)0x1a28ddc0, + (q31_t)0x59c4ce3, (q31_t)0x1a34553b, (q31_t)0x5a17330, (q31_t)0x1a3fcbb3, + (q31_t)0x5a69bbe, (q31_t)0x1a4b4128, (q31_t)0x5abc68c, (q31_t)0x1a56b599, + (q31_t)0x5b0f399, (q31_t)0x1a622907, (q31_t)0x5b622e6, (q31_t)0x1a6d9b70, + (q31_t)0x5bb5472, (q31_t)0x1a790cd4, (q31_t)0x5c0883d, (q31_t)0x1a847d33, + (q31_t)0x5c5be47, (q31_t)0x1a8fec8c, (q31_t)0x5caf690, (q31_t)0x1a9b5adf, + (q31_t)0x5d03118, (q31_t)0x1aa6c82b, (q31_t)0x5d56ddd, (q31_t)0x1ab23471, + (q31_t)0x5daace1, (q31_t)0x1abd9faf, (q31_t)0x5dfee22, (q31_t)0x1ac909e5, + (q31_t)0x5e531a1, (q31_t)0x1ad47312, (q31_t)0x5ea775e, (q31_t)0x1adfdb37, + (q31_t)0x5efbf58, (q31_t)0x1aeb4253, (q31_t)0x5f5098f, (q31_t)0x1af6a865, + (q31_t)0x5fa5603, (q31_t)0x1b020d6c, (q31_t)0x5ffa4b3, (q31_t)0x1b0d716a, + (q31_t)0x604f5a0, (q31_t)0x1b18d45c, (q31_t)0x60a48c9, (q31_t)0x1b243643, + (q31_t)0x60f9e2e, (q31_t)0x1b2f971e, (q31_t)0x614f5cf, (q31_t)0x1b3af6ec, + (q31_t)0x61a4fac, (q31_t)0x1b4655ae, (q31_t)0x61fabc4, (q31_t)0x1b51b363, + (q31_t)0x6250a18, (q31_t)0x1b5d100a, (q31_t)0x62a6aa6, (q31_t)0x1b686ba3, + (q31_t)0x62fcd6f, (q31_t)0x1b73c62d, (q31_t)0x6353273, (q31_t)0x1b7f1fa9, + (q31_t)0x63a99b1, (q31_t)0x1b8a7815, (q31_t)0x6400329, (q31_t)0x1b95cf71, + (q31_t)0x6456edb, (q31_t)0x1ba125bd, (q31_t)0x64adcc7, (q31_t)0x1bac7af9, + (q31_t)0x6504ced, (q31_t)0x1bb7cf23, (q31_t)0x655bf4c, (q31_t)0x1bc3223c, + (q31_t)0x65b33e4, (q31_t)0x1bce7442, (q31_t)0x660aab5, (q31_t)0x1bd9c537, + (q31_t)0x66623be, (q31_t)0x1be51518, (q31_t)0x66b9f01, (q31_t)0x1bf063e6, + (q31_t)0x6711c7b, (q31_t)0x1bfbb1a0, (q31_t)0x6769c2e, (q31_t)0x1c06fe46, + (q31_t)0x67c1e18, (q31_t)0x1c1249d8, (q31_t)0x681a23a, (q31_t)0x1c1d9454, + (q31_t)0x6872894, (q31_t)0x1c28ddbb, (q31_t)0x68cb124, (q31_t)0x1c34260c, + (q31_t)0x6923bec, (q31_t)0x1c3f6d47, (q31_t)0x697c8eb, (q31_t)0x1c4ab36b, + (q31_t)0x69d5820, (q31_t)0x1c55f878, (q31_t)0x6a2e98b, (q31_t)0x1c613c6d, + (q31_t)0x6a87d2d, (q31_t)0x1c6c7f4a, (q31_t)0x6ae1304, (q31_t)0x1c77c10e, + (q31_t)0x6b3ab12, (q31_t)0x1c8301b9, (q31_t)0x6b94554, (q31_t)0x1c8e414b, + (q31_t)0x6bee1cd, (q31_t)0x1c997fc4, (q31_t)0x6c4807a, (q31_t)0x1ca4bd21, + (q31_t)0x6ca215c, (q31_t)0x1caff965, (q31_t)0x6cfc472, (q31_t)0x1cbb348d, + (q31_t)0x6d569be, (q31_t)0x1cc66e99, (q31_t)0x6db113d, (q31_t)0x1cd1a78a, + (q31_t)0x6e0baf0, (q31_t)0x1cdcdf5e, (q31_t)0x6e666d7, (q31_t)0x1ce81615, + (q31_t)0x6ec14f2, (q31_t)0x1cf34baf, (q31_t)0x6f1c540, (q31_t)0x1cfe802b, + (q31_t)0x6f777c1, (q31_t)0x1d09b389, (q31_t)0x6fd2c75, (q31_t)0x1d14e5c9, + (q31_t)0x702e35c, (q31_t)0x1d2016e9, (q31_t)0x7089c75, (q31_t)0x1d2b46ea, + (q31_t)0x70e57c0, (q31_t)0x1d3675cb, (q31_t)0x714153e, (q31_t)0x1d41a38c, + (q31_t)0x719d4ed, (q31_t)0x1d4cd02c, (q31_t)0x71f96ce, (q31_t)0x1d57fbaa, + (q31_t)0x7255ae0, (q31_t)0x1d632608, (q31_t)0x72b2123, (q31_t)0x1d6e4f43, + (q31_t)0x730e997, (q31_t)0x1d79775c, (q31_t)0x736b43c, (q31_t)0x1d849e51, + (q31_t)0x73c8111, (q31_t)0x1d8fc424, (q31_t)0x7425016, (q31_t)0x1d9ae8d2, + (q31_t)0x748214c, (q31_t)0x1da60c5d, (q31_t)0x74df4b1, (q31_t)0x1db12ec3, + (q31_t)0x753ca46, (q31_t)0x1dbc5004, (q31_t)0x759a20a, (q31_t)0x1dc7701f, + (q31_t)0x75f7bfe, (q31_t)0x1dd28f15, (q31_t)0x7655820, (q31_t)0x1dddace4, + (q31_t)0x76b3671, (q31_t)0x1de8c98c, (q31_t)0x77116f0, (q31_t)0x1df3e50d, + (q31_t)0x776f99d, (q31_t)0x1dfeff67, (q31_t)0x77cde79, (q31_t)0x1e0a1898, + (q31_t)0x782c582, (q31_t)0x1e1530a1, (q31_t)0x788aeb9, (q31_t)0x1e204781, + (q31_t)0x78e9a1d, (q31_t)0x1e2b5d38, (q31_t)0x79487ae, (q31_t)0x1e3671c5, + (q31_t)0x79a776c, (q31_t)0x1e418528, (q31_t)0x7a06957, (q31_t)0x1e4c9760, + (q31_t)0x7a65d6e, (q31_t)0x1e57a86d, (q31_t)0x7ac53b1, (q31_t)0x1e62b84f, + (q31_t)0x7b24c20, (q31_t)0x1e6dc705, (q31_t)0x7b846ba, (q31_t)0x1e78d48e, + (q31_t)0x7be4381, (q31_t)0x1e83e0eb, (q31_t)0x7c44272, (q31_t)0x1e8eec1b, + (q31_t)0x7ca438f, (q31_t)0x1e99f61d, (q31_t)0x7d046d6, (q31_t)0x1ea4fef0, + (q31_t)0x7d64c47, (q31_t)0x1eb00696, (q31_t)0x7dc53e3, (q31_t)0x1ebb0d0d, + (q31_t)0x7e25daa, (q31_t)0x1ec61254, (q31_t)0x7e8699a, (q31_t)0x1ed1166b, + (q31_t)0x7ee77b3, (q31_t)0x1edc1953, (q31_t)0x7f487f6, (q31_t)0x1ee71b0a, + (q31_t)0x7fa9a62, (q31_t)0x1ef21b90, (q31_t)0x800aef7, (q31_t)0x1efd1ae4, + (q31_t)0x806c5b5, (q31_t)0x1f081907, (q31_t)0x80cde9b, (q31_t)0x1f1315f7, + (q31_t)0x812f9a9, (q31_t)0x1f1e11b5, (q31_t)0x81916df, (q31_t)0x1f290c3f, + (q31_t)0x81f363d, (q31_t)0x1f340596, (q31_t)0x82557c3, (q31_t)0x1f3efdb9, + (q31_t)0x82b7b70, (q31_t)0x1f49f4a8, (q31_t)0x831a143, (q31_t)0x1f54ea62, + (q31_t)0x837c93e, (q31_t)0x1f5fdee6, (q31_t)0x83df35f, (q31_t)0x1f6ad235, + (q31_t)0x8441fa6, (q31_t)0x1f75c44e, (q31_t)0x84a4e14, (q31_t)0x1f80b531, + (q31_t)0x8507ea7, (q31_t)0x1f8ba4dc, (q31_t)0x856b160, (q31_t)0x1f969350, + (q31_t)0x85ce63e, (q31_t)0x1fa1808c, (q31_t)0x8631d42, (q31_t)0x1fac6c91, + (q31_t)0x869566a, (q31_t)0x1fb7575c, (q31_t)0x86f91b7, (q31_t)0x1fc240ef, + (q31_t)0x875cf28, (q31_t)0x1fcd2948, (q31_t)0x87c0ebd, (q31_t)0x1fd81067, + (q31_t)0x8825077, (q31_t)0x1fe2f64c, (q31_t)0x8889454, (q31_t)0x1feddaf6, + (q31_t)0x88eda54, (q31_t)0x1ff8be65, (q31_t)0x8952278, (q31_t)0x2003a099, + (q31_t)0x89b6cbf, (q31_t)0x200e8190, (q31_t)0x8a1b928, (q31_t)0x2019614c, + (q31_t)0x8a807b4, (q31_t)0x20243fca, (q31_t)0x8ae5862, (q31_t)0x202f1d0b, + (q31_t)0x8b4ab32, (q31_t)0x2039f90f, (q31_t)0x8bb0023, (q31_t)0x2044d3d4, + (q31_t)0x8c15736, (q31_t)0x204fad5b, (q31_t)0x8c7b06b, (q31_t)0x205a85a3, + (q31_t)0x8ce0bc0, (q31_t)0x20655cac, (q31_t)0x8d46936, (q31_t)0x20703275, + (q31_t)0x8dac8cd, (q31_t)0x207b06fe, (q31_t)0x8e12a84, (q31_t)0x2085da46, + (q31_t)0x8e78e5b, (q31_t)0x2090ac4d, (q31_t)0x8edf452, (q31_t)0x209b7d13, + (q31_t)0x8f45c68, (q31_t)0x20a64c97, (q31_t)0x8fac69e, (q31_t)0x20b11ad9, + (q31_t)0x90132f2, (q31_t)0x20bbe7d8, (q31_t)0x907a166, (q31_t)0x20c6b395, + (q31_t)0x90e11f7, (q31_t)0x20d17e0d, (q31_t)0x91484a8, (q31_t)0x20dc4742, + (q31_t)0x91af976, (q31_t)0x20e70f32, (q31_t)0x9217062, (q31_t)0x20f1d5de, + (q31_t)0x927e96b, (q31_t)0x20fc9b44, (q31_t)0x92e6492, (q31_t)0x21075f65, + (q31_t)0x934e1d6, (q31_t)0x21122240, (q31_t)0x93b6137, (q31_t)0x211ce3d5, + (q31_t)0x941e2b4, (q31_t)0x2127a423, (q31_t)0x948664d, (q31_t)0x21326329, + (q31_t)0x94eec03, (q31_t)0x213d20e8, (q31_t)0x95573d4, (q31_t)0x2147dd5f, + (q31_t)0x95bfdc1, (q31_t)0x2152988d, (q31_t)0x96289c9, (q31_t)0x215d5273, + (q31_t)0x96917ec, (q31_t)0x21680b0f, (q31_t)0x96fa82a, (q31_t)0x2172c262, + (q31_t)0x9763a83, (q31_t)0x217d786a, (q31_t)0x97ccef5, (q31_t)0x21882d28, + (q31_t)0x9836582, (q31_t)0x2192e09b, (q31_t)0x989fe29, (q31_t)0x219d92c2, + (q31_t)0x99098e9, (q31_t)0x21a8439e, (q31_t)0x99735c2, (q31_t)0x21b2f32e, + (q31_t)0x99dd4b4, (q31_t)0x21bda171, (q31_t)0x9a475bf, (q31_t)0x21c84e67, + (q31_t)0x9ab18e3, (q31_t)0x21d2fa0f, (q31_t)0x9b1be1e, (q31_t)0x21dda46a, + (q31_t)0x9b86572, (q31_t)0x21e84d76, (q31_t)0x9bf0edd, (q31_t)0x21f2f534, + (q31_t)0x9c5ba60, (q31_t)0x21fd9ba3, (q31_t)0x9cc67fa, (q31_t)0x220840c2, + (q31_t)0x9d317ab, (q31_t)0x2212e492, (q31_t)0x9d9c973, (q31_t)0x221d8711, + (q31_t)0x9e07d51, (q31_t)0x2228283f, (q31_t)0x9e73346, (q31_t)0x2232c81c, + (q31_t)0x9edeb50, (q31_t)0x223d66a8, (q31_t)0x9f4a570, (q31_t)0x224803e2, + (q31_t)0x9fb61a5, (q31_t)0x22529fca, (q31_t)0xa021fef, (q31_t)0x225d3a5e, + (q31_t)0xa08e04f, (q31_t)0x2267d3a0, (q31_t)0xa0fa2c3, (q31_t)0x22726b8e, + (q31_t)0xa16674b, (q31_t)0x227d0228, (q31_t)0xa1d2de7, (q31_t)0x2287976e, + (q31_t)0xa23f698, (q31_t)0x22922b5e, (q31_t)0xa2ac15b, (q31_t)0x229cbdfa, + (q31_t)0xa318e32, (q31_t)0x22a74f40, (q31_t)0xa385d1d, (q31_t)0x22b1df30, + (q31_t)0xa3f2e19, (q31_t)0x22bc6dca, (q31_t)0xa460129, (q31_t)0x22c6fb0c, + (q31_t)0xa4cd64b, (q31_t)0x22d186f8, (q31_t)0xa53ad7e, (q31_t)0x22dc118c, + (q31_t)0xa5a86c4, (q31_t)0x22e69ac8, (q31_t)0xa61621b, (q31_t)0x22f122ab, + (q31_t)0xa683f83, (q31_t)0x22fba936, (q31_t)0xa6f1efc, (q31_t)0x23062e67, + (q31_t)0xa760086, (q31_t)0x2310b23e, (q31_t)0xa7ce420, (q31_t)0x231b34bc, + (q31_t)0xa83c9ca, (q31_t)0x2325b5df, (q31_t)0xa8ab184, (q31_t)0x233035a7, + (q31_t)0xa919b4e, (q31_t)0x233ab414, (q31_t)0xa988727, (q31_t)0x23453125, + (q31_t)0xa9f750f, (q31_t)0x234facda, (q31_t)0xaa66506, (q31_t)0x235a2733, + (q31_t)0xaad570c, (q31_t)0x2364a02e, (q31_t)0xab44b1f, (q31_t)0x236f17cc, + (q31_t)0xabb4141, (q31_t)0x23798e0d, (q31_t)0xac23971, (q31_t)0x238402ef, + (q31_t)0xac933ae, (q31_t)0x238e7673, (q31_t)0xad02ff8, (q31_t)0x2398e898, + (q31_t)0xad72e4f, (q31_t)0x23a3595e, (q31_t)0xade2eb3, (q31_t)0x23adc8c4, + (q31_t)0xae53123, (q31_t)0x23b836ca, (q31_t)0xaec35a0, (q31_t)0x23c2a36f, + (q31_t)0xaf33c28, (q31_t)0x23cd0eb3, (q31_t)0xafa44bc, (q31_t)0x23d77896, + (q31_t)0xb014f5b, (q31_t)0x23e1e117, (q31_t)0xb085c05, (q31_t)0x23ec4837, + (q31_t)0xb0f6aba, (q31_t)0x23f6adf3, (q31_t)0xb167b79, (q31_t)0x2401124d, + (q31_t)0xb1d8e43, (q31_t)0x240b7543, (q31_t)0xb24a316, (q31_t)0x2415d6d5, + (q31_t)0xb2bb9f4, (q31_t)0x24203704, (q31_t)0xb32d2da, (q31_t)0x242a95ce, + (q31_t)0xb39edca, (q31_t)0x2434f332, (q31_t)0xb410ac3, (q31_t)0x243f4f32, + (q31_t)0xb4829c4, (q31_t)0x2449a9cc, (q31_t)0xb4f4acd, (q31_t)0x245402ff, + (q31_t)0xb566ddf, (q31_t)0x245e5acc, (q31_t)0xb5d92f8, (q31_t)0x2468b132, + (q31_t)0xb64ba19, (q31_t)0x24730631, (q31_t)0xb6be341, (q31_t)0x247d59c8, + (q31_t)0xb730e70, (q31_t)0x2487abf7, (q31_t)0xb7a3ba5, (q31_t)0x2491fcbe, + (q31_t)0xb816ae1, (q31_t)0x249c4c1b, (q31_t)0xb889c23, (q31_t)0x24a69a0f, + (q31_t)0xb8fcf6b, (q31_t)0x24b0e699, (q31_t)0xb9704b9, (q31_t)0x24bb31ba, + (q31_t)0xb9e3c0b, (q31_t)0x24c57b6f, (q31_t)0xba57563, (q31_t)0x24cfc3ba, + (q31_t)0xbacb0bf, (q31_t)0x24da0a9a, (q31_t)0xbb3ee20, (q31_t)0x24e4500e, + (q31_t)0xbbb2d85, (q31_t)0x24ee9415, (q31_t)0xbc26eee, (q31_t)0x24f8d6b0, + (q31_t)0xbc9b25a, (q31_t)0x250317df, (q31_t)0xbd0f7ca, (q31_t)0x250d57a0, + (q31_t)0xbd83f3d, (q31_t)0x251795f3, (q31_t)0xbdf88b3, (q31_t)0x2521d2d8, + (q31_t)0xbe6d42b, (q31_t)0x252c0e4f, (q31_t)0xbee21a5, (q31_t)0x25364857, + (q31_t)0xbf57121, (q31_t)0x254080ef, (q31_t)0xbfcc29f, (q31_t)0x254ab818, + (q31_t)0xc04161e, (q31_t)0x2554edd1, (q31_t)0xc0b6b9e, (q31_t)0x255f2219, + (q31_t)0xc12c31f, (q31_t)0x256954f1, (q31_t)0xc1a1ca0, (q31_t)0x25738657, + (q31_t)0xc217822, (q31_t)0x257db64c, (q31_t)0xc28d5a3, (q31_t)0x2587e4cf, + (q31_t)0xc303524, (q31_t)0x259211df, (q31_t)0xc3796a5, (q31_t)0x259c3d7c, + (q31_t)0xc3efa25, (q31_t)0x25a667a7, (q31_t)0xc465fa3, (q31_t)0x25b0905d, + (q31_t)0xc4dc720, (q31_t)0x25bab7a0, (q31_t)0xc55309b, (q31_t)0x25c4dd6e, + (q31_t)0xc5c9c14, (q31_t)0x25cf01c8, (q31_t)0xc64098b, (q31_t)0x25d924ac, + (q31_t)0xc6b78ff, (q31_t)0x25e3461b, (q31_t)0xc72ea70, (q31_t)0x25ed6614, + (q31_t)0xc7a5dde, (q31_t)0x25f78497, (q31_t)0xc81d349, (q31_t)0x2601a1a2, + (q31_t)0xc894aaf, (q31_t)0x260bbd37, (q31_t)0xc90c412, (q31_t)0x2615d754, + (q31_t)0xc983f70, (q31_t)0x261feffa, (q31_t)0xc9fbcca, (q31_t)0x262a0727, + (q31_t)0xca73c1e, (q31_t)0x26341cdb, (q31_t)0xcaebd6e, (q31_t)0x263e3117, + (q31_t)0xcb640b8, (q31_t)0x264843d9, (q31_t)0xcbdc5fc, (q31_t)0x26525521, + (q31_t)0xcc54d3a, (q31_t)0x265c64ef, (q31_t)0xcccd671, (q31_t)0x26667342, + (q31_t)0xcd461a2, (q31_t)0x2670801a, (q31_t)0xcdbeecc, (q31_t)0x267a8b77, + (q31_t)0xce37def, (q31_t)0x26849558, (q31_t)0xceb0f0a, (q31_t)0x268e9dbd, + (q31_t)0xcf2a21d, (q31_t)0x2698a4a6, (q31_t)0xcfa3729, (q31_t)0x26a2aa11, + (q31_t)0xd01ce2b, (q31_t)0x26acadff, (q31_t)0xd096725, (q31_t)0x26b6b070, + (q31_t)0xd110216, (q31_t)0x26c0b162, (q31_t)0xd189efe, (q31_t)0x26cab0d6, + (q31_t)0xd203ddc, (q31_t)0x26d4aecb, (q31_t)0xd27deb0, (q31_t)0x26deab41, + (q31_t)0xd2f817b, (q31_t)0x26e8a637, (q31_t)0xd37263a, (q31_t)0x26f29fad, + (q31_t)0xd3eccef, (q31_t)0x26fc97a3, (q31_t)0xd467599, (q31_t)0x27068e18, + (q31_t)0xd4e2037, (q31_t)0x2710830c, (q31_t)0xd55ccca, (q31_t)0x271a767e, + (q31_t)0xd5d7b50, (q31_t)0x2724686e, (q31_t)0xd652bcb, (q31_t)0x272e58dc, + (q31_t)0xd6cde39, (q31_t)0x273847c8, (q31_t)0xd74929a, (q31_t)0x27423530, + (q31_t)0xd7c48ee, (q31_t)0x274c2115, (q31_t)0xd840134, (q31_t)0x27560b76, + (q31_t)0xd8bbb6d, (q31_t)0x275ff452, (q31_t)0xd937798, (q31_t)0x2769dbaa, + (q31_t)0xd9b35b4, (q31_t)0x2773c17d, (q31_t)0xda2f5c2, (q31_t)0x277da5cb, + (q31_t)0xdaab7c0, (q31_t)0x27878893, (q31_t)0xdb27bb0, (q31_t)0x279169d5, + (q31_t)0xdba4190, (q31_t)0x279b4990, (q31_t)0xdc20960, (q31_t)0x27a527c4, + (q31_t)0xdc9d320, (q31_t)0x27af0472, (q31_t)0xdd19ed0, (q31_t)0x27b8df97, + (q31_t)0xdd96c6f, (q31_t)0x27c2b934, (q31_t)0xde13bfd, (q31_t)0x27cc9149, + (q31_t)0xde90d79, (q31_t)0x27d667d5, (q31_t)0xdf0e0e4, (q31_t)0x27e03cd8, + (q31_t)0xdf8b63d, (q31_t)0x27ea1052, (q31_t)0xe008d84, (q31_t)0x27f3e241, + (q31_t)0xe0866b8, (q31_t)0x27fdb2a7, (q31_t)0xe1041d9, (q31_t)0x28078181, + (q31_t)0xe181ee8, (q31_t)0x28114ed0, (q31_t)0xe1ffde2, (q31_t)0x281b1a94, + (q31_t)0xe27dec9, (q31_t)0x2824e4cc, (q31_t)0xe2fc19c, (q31_t)0x282ead78, + (q31_t)0xe37a65b, (q31_t)0x28387498, (q31_t)0xe3f8d05, (q31_t)0x28423a2a, + (q31_t)0xe47759a, (q31_t)0x284bfe2f, (q31_t)0xe4f6019, (q31_t)0x2855c0a6, + (q31_t)0xe574c84, (q31_t)0x285f8190, (q31_t)0xe5f3ad8, (q31_t)0x286940ea, + (q31_t)0xe672b16, (q31_t)0x2872feb6, (q31_t)0xe6f1d3d, (q31_t)0x287cbaf3, + (q31_t)0xe77114e, (q31_t)0x288675a0, (q31_t)0xe7f0748, (q31_t)0x28902ebd, + (q31_t)0xe86ff2a, (q31_t)0x2899e64a, (q31_t)0xe8ef8f4, (q31_t)0x28a39c46, + (q31_t)0xe96f4a7, (q31_t)0x28ad50b1, (q31_t)0xe9ef241, (q31_t)0x28b7038b, + (q31_t)0xea6f1c2, (q31_t)0x28c0b4d2, (q31_t)0xeaef32b, (q31_t)0x28ca6488, + (q31_t)0xeb6f67a, (q31_t)0x28d412ab, (q31_t)0xebefbb0, (q31_t)0x28ddbf3b, + (q31_t)0xec702cb, (q31_t)0x28e76a37, (q31_t)0xecf0bcd, (q31_t)0x28f113a0, + (q31_t)0xed716b4, (q31_t)0x28fabb75, (q31_t)0xedf2380, (q31_t)0x290461b5, + (q31_t)0xee73231, (q31_t)0x290e0661, (q31_t)0xeef42c7, (q31_t)0x2917a977, + (q31_t)0xef75541, (q31_t)0x29214af8, (q31_t)0xeff699f, (q31_t)0x292aeae3, + (q31_t)0xf077fe1, (q31_t)0x29348937, (q31_t)0xf0f9805, (q31_t)0x293e25f5, + (q31_t)0xf17b20d, (q31_t)0x2947c11c, (q31_t)0xf1fcdf8, (q31_t)0x29515aab, + (q31_t)0xf27ebc5, (q31_t)0x295af2a3, (q31_t)0xf300b74, (q31_t)0x29648902, + (q31_t)0xf382d05, (q31_t)0x296e1dc9, (q31_t)0xf405077, (q31_t)0x2977b0f7, + (q31_t)0xf4875ca, (q31_t)0x2981428c, (q31_t)0xf509cfe, (q31_t)0x298ad287, + (q31_t)0xf58c613, (q31_t)0x299460e8, (q31_t)0xf60f108, (q31_t)0x299dedaf, + (q31_t)0xf691ddd, (q31_t)0x29a778db, (q31_t)0xf714c91, (q31_t)0x29b1026c, + (q31_t)0xf797d24, (q31_t)0x29ba8a61, (q31_t)0xf81af97, (q31_t)0x29c410ba, + (q31_t)0xf89e3e8, (q31_t)0x29cd9578, (q31_t)0xf921a17, (q31_t)0x29d71899, + (q31_t)0xf9a5225, (q31_t)0x29e09a1c, (q31_t)0xfa28c10, (q31_t)0x29ea1a03, + (q31_t)0xfaac7d8, (q31_t)0x29f3984c, (q31_t)0xfb3057d, (q31_t)0x29fd14f6, + (q31_t)0xfbb4500, (q31_t)0x2a069003, (q31_t)0xfc3865e, (q31_t)0x2a100970, + (q31_t)0xfcbc999, (q31_t)0x2a19813f, (q31_t)0xfd40eaf, (q31_t)0x2a22f76e, + (q31_t)0xfdc55a1, (q31_t)0x2a2c6bfd, (q31_t)0xfe49e6d, (q31_t)0x2a35deeb, + (q31_t)0xfece915, (q31_t)0x2a3f503a, (q31_t)0xff53597, (q31_t)0x2a48bfe7, + (q31_t)0xffd83f4, (q31_t)0x2a522df3, (q31_t)0x1005d42a, (q31_t)0x2a5b9a5d, + (q31_t)0x100e2639, (q31_t)0x2a650525, (q31_t)0x10167a22, (q31_t)0x2a6e6e4b, + (q31_t)0x101ecfe4, (q31_t)0x2a77d5ce, (q31_t)0x1027277e, (q31_t)0x2a813bae, + (q31_t)0x102f80f1, (q31_t)0x2a8a9fea, (q31_t)0x1037dc3b, (q31_t)0x2a940283, + (q31_t)0x1040395d, (q31_t)0x2a9d6377, (q31_t)0x10489856, (q31_t)0x2aa6c2c6, + (q31_t)0x1050f926, (q31_t)0x2ab02071, (q31_t)0x10595bcd, (q31_t)0x2ab97c77, + (q31_t)0x1061c04a, (q31_t)0x2ac2d6d6, (q31_t)0x106a269d, (q31_t)0x2acc2f90, + (q31_t)0x10728ec6, (q31_t)0x2ad586a3, (q31_t)0x107af8c4, (q31_t)0x2adedc10, + (q31_t)0x10836497, (q31_t)0x2ae82fd5, (q31_t)0x108bd23f, (q31_t)0x2af181f3, + (q31_t)0x109441bb, (q31_t)0x2afad269, (q31_t)0x109cb30b, (q31_t)0x2b042137, + (q31_t)0x10a5262f, (q31_t)0x2b0d6e5c, (q31_t)0x10ad9b26, (q31_t)0x2b16b9d9, + (q31_t)0x10b611f1, (q31_t)0x2b2003ac, (q31_t)0x10be8a8d, (q31_t)0x2b294bd5, + (q31_t)0x10c704fd, (q31_t)0x2b329255, (q31_t)0x10cf813e, (q31_t)0x2b3bd72a, + (q31_t)0x10d7ff51, (q31_t)0x2b451a55, (q31_t)0x10e07f36, (q31_t)0x2b4e5bd4, + (q31_t)0x10e900ec, (q31_t)0x2b579ba8, (q31_t)0x10f18472, (q31_t)0x2b60d9d0, + (q31_t)0x10fa09c9, (q31_t)0x2b6a164d, (q31_t)0x110290f0, (q31_t)0x2b73511c, + (q31_t)0x110b19e7, (q31_t)0x2b7c8a3f, (q31_t)0x1113a4ad, (q31_t)0x2b85c1b5, + (q31_t)0x111c3142, (q31_t)0x2b8ef77d, (q31_t)0x1124bfa6, (q31_t)0x2b982b97, + (q31_t)0x112d4fd9, (q31_t)0x2ba15e03, (q31_t)0x1135e1d9, (q31_t)0x2baa8ec0, + (q31_t)0x113e75a8, (q31_t)0x2bb3bdce, (q31_t)0x11470b44, (q31_t)0x2bbceb2d, + (q31_t)0x114fa2ad, (q31_t)0x2bc616dd, (q31_t)0x11583be2, (q31_t)0x2bcf40dc, + (q31_t)0x1160d6e5, (q31_t)0x2bd8692b, (q31_t)0x116973b3, (q31_t)0x2be18fc9, + (q31_t)0x1172124d, (q31_t)0x2beab4b6, (q31_t)0x117ab2b3, (q31_t)0x2bf3d7f2, + (q31_t)0x118354e4, (q31_t)0x2bfcf97c, (q31_t)0x118bf8e0, (q31_t)0x2c061953, + (q31_t)0x11949ea6, (q31_t)0x2c0f3779, (q31_t)0x119d4636, (q31_t)0x2c1853eb, + (q31_t)0x11a5ef90, (q31_t)0x2c216eaa, (q31_t)0x11ae9ab4, (q31_t)0x2c2a87b6, + (q31_t)0x11b747a0, (q31_t)0x2c339f0e, (q31_t)0x11bff656, (q31_t)0x2c3cb4b1, + (q31_t)0x11c8a6d4, (q31_t)0x2c45c8a0, (q31_t)0x11d1591a, (q31_t)0x2c4edada, + (q31_t)0x11da0d28, (q31_t)0x2c57eb5e, (q31_t)0x11e2c2fd, (q31_t)0x2c60fa2d, + (q31_t)0x11eb7a9a, (q31_t)0x2c6a0746, (q31_t)0x11f433fd, (q31_t)0x2c7312a9, + (q31_t)0x11fcef27, (q31_t)0x2c7c1c55, (q31_t)0x1205ac17, (q31_t)0x2c85244a, + (q31_t)0x120e6acc, (q31_t)0x2c8e2a87, (q31_t)0x12172b48, (q31_t)0x2c972f0d, + (q31_t)0x121fed88, (q31_t)0x2ca031da, (q31_t)0x1228b18d, (q31_t)0x2ca932ef, + (q31_t)0x12317756, (q31_t)0x2cb2324c, (q31_t)0x123a3ee4, (q31_t)0x2cbb2fef, + (q31_t)0x12430835, (q31_t)0x2cc42bd9, (q31_t)0x124bd34a, (q31_t)0x2ccd2609, + (q31_t)0x1254a021, (q31_t)0x2cd61e7f, (q31_t)0x125d6ebc, (q31_t)0x2cdf153a, + (q31_t)0x12663f19, (q31_t)0x2ce80a3a, (q31_t)0x126f1138, (q31_t)0x2cf0fd80, + (q31_t)0x1277e518, (q31_t)0x2cf9ef09, (q31_t)0x1280babb, (q31_t)0x2d02ded7, + (q31_t)0x1289921e, (q31_t)0x2d0bcce8, (q31_t)0x12926b41, (q31_t)0x2d14b93d, + (q31_t)0x129b4626, (q31_t)0x2d1da3d5, (q31_t)0x12a422ca, (q31_t)0x2d268cb0, + (q31_t)0x12ad012e, (q31_t)0x2d2f73cd, (q31_t)0x12b5e151, (q31_t)0x2d38592c, + (q31_t)0x12bec333, (q31_t)0x2d413ccd, (q31_t)0x12c7a6d4, (q31_t)0x2d4a1eaf, + (q31_t)0x12d08c33, (q31_t)0x2d52fed2, (q31_t)0x12d97350, (q31_t)0x2d5bdd36, + (q31_t)0x12e25c2b, (q31_t)0x2d64b9da, (q31_t)0x12eb46c3, (q31_t)0x2d6d94bf, + (q31_t)0x12f43318, (q31_t)0x2d766de2, (q31_t)0x12fd2129, (q31_t)0x2d7f4545, + (q31_t)0x130610f7, (q31_t)0x2d881ae8, (q31_t)0x130f0280, (q31_t)0x2d90eec8, + (q31_t)0x1317f5c6, (q31_t)0x2d99c0e7, (q31_t)0x1320eac6, (q31_t)0x2da29144, + (q31_t)0x1329e181, (q31_t)0x2dab5fdf, (q31_t)0x1332d9f7, (q31_t)0x2db42cb6, + (q31_t)0x133bd427, (q31_t)0x2dbcf7cb, (q31_t)0x1344d011, (q31_t)0x2dc5c11c, + (q31_t)0x134dcdb4, (q31_t)0x2dce88aa, (q31_t)0x1356cd11, (q31_t)0x2dd74e73, + (q31_t)0x135fce26, (q31_t)0x2de01278, (q31_t)0x1368d0f3, (q31_t)0x2de8d4b8, + (q31_t)0x1371d579, (q31_t)0x2df19534, (q31_t)0x137adbb6, (q31_t)0x2dfa53e9, + (q31_t)0x1383e3ab, (q31_t)0x2e0310d9, (q31_t)0x138ced57, (q31_t)0x2e0bcc03, + (q31_t)0x1395f8ba, (q31_t)0x2e148566, (q31_t)0x139f05d3, (q31_t)0x2e1d3d03, + (q31_t)0x13a814a2, (q31_t)0x2e25f2d8, (q31_t)0x13b12526, (q31_t)0x2e2ea6e6, + (q31_t)0x13ba3760, (q31_t)0x2e37592c, (q31_t)0x13c34b4f, (q31_t)0x2e4009aa, + (q31_t)0x13cc60f2, (q31_t)0x2e48b860, (q31_t)0x13d5784a, (q31_t)0x2e51654c, + (q31_t)0x13de9156, (q31_t)0x2e5a1070, (q31_t)0x13e7ac15, (q31_t)0x2e62b9ca, + (q31_t)0x13f0c887, (q31_t)0x2e6b615a, (q31_t)0x13f9e6ad, (q31_t)0x2e740720, + (q31_t)0x14030684, (q31_t)0x2e7cab1c, (q31_t)0x140c280e, (q31_t)0x2e854d4d, + (q31_t)0x14154b4a, (q31_t)0x2e8dedb3, (q31_t)0x141e7037, (q31_t)0x2e968c4d, + (q31_t)0x142796d5, (q31_t)0x2e9f291b, (q31_t)0x1430bf24, (q31_t)0x2ea7c41e, + (q31_t)0x1439e923, (q31_t)0x2eb05d53, (q31_t)0x144314d3, (q31_t)0x2eb8f4bc, + (q31_t)0x144c4232, (q31_t)0x2ec18a58, (q31_t)0x14557140, (q31_t)0x2eca1e27, + (q31_t)0x145ea1fd, (q31_t)0x2ed2b027, (q31_t)0x1467d469, (q31_t)0x2edb405a, + (q31_t)0x14710883, (q31_t)0x2ee3cebe, (q31_t)0x147a3e4b, (q31_t)0x2eec5b53, + (q31_t)0x148375c1, (q31_t)0x2ef4e619, (q31_t)0x148caee4, (q31_t)0x2efd6f10, + (q31_t)0x1495e9b3, (q31_t)0x2f05f637, (q31_t)0x149f2630, (q31_t)0x2f0e7b8e, + (q31_t)0x14a86458, (q31_t)0x2f16ff14, (q31_t)0x14b1a42c, (q31_t)0x2f1f80ca, + (q31_t)0x14bae5ab, (q31_t)0x2f2800af, (q31_t)0x14c428d6, (q31_t)0x2f307ec2, + (q31_t)0x14cd6dab, (q31_t)0x2f38fb03, (q31_t)0x14d6b42b, (q31_t)0x2f417573, + (q31_t)0x14dffc54, (q31_t)0x2f49ee0f, (q31_t)0x14e94627, (q31_t)0x2f5264da, + (q31_t)0x14f291a4, (q31_t)0x2f5ad9d1, (q31_t)0x14fbdec9, (q31_t)0x2f634cf5, + (q31_t)0x15052d97, (q31_t)0x2f6bbe45, (q31_t)0x150e7e0d, (q31_t)0x2f742dc1, + (q31_t)0x1517d02b, (q31_t)0x2f7c9b69, (q31_t)0x152123f0, (q31_t)0x2f85073c, + (q31_t)0x152a795d, (q31_t)0x2f8d713a, (q31_t)0x1533d070, (q31_t)0x2f95d963, + (q31_t)0x153d292a, (q31_t)0x2f9e3fb6, (q31_t)0x15468389, (q31_t)0x2fa6a433, + (q31_t)0x154fdf8f, (q31_t)0x2faf06da, (q31_t)0x15593d3a, (q31_t)0x2fb767aa, + (q31_t)0x15629c89, (q31_t)0x2fbfc6a3, (q31_t)0x156bfd7d, (q31_t)0x2fc823c5, + (q31_t)0x15756016, (q31_t)0x2fd07f0f, (q31_t)0x157ec452, (q31_t)0x2fd8d882, + (q31_t)0x15882a32, (q31_t)0x2fe1301c, (q31_t)0x159191b5, (q31_t)0x2fe985de, + (q31_t)0x159afadb, (q31_t)0x2ff1d9c7, (q31_t)0x15a465a3, (q31_t)0x2ffa2bd6, + (q31_t)0x15add20d, (q31_t)0x30027c0c, (q31_t)0x15b74019, (q31_t)0x300aca69, + (q31_t)0x15c0afc6, (q31_t)0x301316eb, (q31_t)0x15ca2115, (q31_t)0x301b6193, + (q31_t)0x15d39403, (q31_t)0x3023aa5f, (q31_t)0x15dd0892, (q31_t)0x302bf151, + (q31_t)0x15e67ec1, (q31_t)0x30343667, (q31_t)0x15eff690, (q31_t)0x303c79a2, + (q31_t)0x15f96ffd, (q31_t)0x3044bb00, (q31_t)0x1602eb0a, (q31_t)0x304cfa83, + (q31_t)0x160c67b4, (q31_t)0x30553828, (q31_t)0x1615e5fd, (q31_t)0x305d73f0, + (q31_t)0x161f65e4, (q31_t)0x3065addb, (q31_t)0x1628e767, (q31_t)0x306de5e9, + (q31_t)0x16326a88, (q31_t)0x30761c18, (q31_t)0x163bef46, (q31_t)0x307e5069, + (q31_t)0x1645759f, (q31_t)0x308682dc, (q31_t)0x164efd94, (q31_t)0x308eb36f, + (q31_t)0x16588725, (q31_t)0x3096e223, (q31_t)0x16621251, (q31_t)0x309f0ef8, + (q31_t)0x166b9f18, (q31_t)0x30a739ed, (q31_t)0x16752d79, (q31_t)0x30af6302, + (q31_t)0x167ebd74, (q31_t)0x30b78a36, (q31_t)0x16884f09, (q31_t)0x30bfaf89, + (q31_t)0x1691e237, (q31_t)0x30c7d2fb, (q31_t)0x169b76fe, (q31_t)0x30cff48c, + (q31_t)0x16a50d5d, (q31_t)0x30d8143b, (q31_t)0x16aea555, (q31_t)0x30e03208, + (q31_t)0x16b83ee4, (q31_t)0x30e84df3, (q31_t)0x16c1da0b, (q31_t)0x30f067fb, + (q31_t)0x16cb76c9, (q31_t)0x30f8801f, (q31_t)0x16d5151d, (q31_t)0x31009661, + (q31_t)0x16deb508, (q31_t)0x3108aabf, (q31_t)0x16e85689, (q31_t)0x3110bd39, + (q31_t)0x16f1f99f, (q31_t)0x3118cdcf, (q31_t)0x16fb9e4b, (q31_t)0x3120dc80, + (q31_t)0x1705448b, (q31_t)0x3128e94c, (q31_t)0x170eec60, (q31_t)0x3130f433, + (q31_t)0x171895c9, (q31_t)0x3138fd35, (q31_t)0x172240c5, (q31_t)0x31410450, + (q31_t)0x172bed55, (q31_t)0x31490986, (q31_t)0x17359b78, (q31_t)0x31510cd5, + (q31_t)0x173f4b2e, (q31_t)0x31590e3e, (q31_t)0x1748fc75, (q31_t)0x31610dbf, + (q31_t)0x1752af4f, (q31_t)0x31690b59, (q31_t)0x175c63ba, (q31_t)0x3171070c, + (q31_t)0x176619b6, (q31_t)0x317900d6, (q31_t)0x176fd143, (q31_t)0x3180f8b8, + (q31_t)0x17798a60, (q31_t)0x3188eeb2, (q31_t)0x1783450d, (q31_t)0x3190e2c3, + (q31_t)0x178d014a, (q31_t)0x3198d4ea, (q31_t)0x1796bf16, (q31_t)0x31a0c528, + (q31_t)0x17a07e70, (q31_t)0x31a8b37c, (q31_t)0x17aa3f5a, (q31_t)0x31b09fe7, + (q31_t)0x17b401d1, (q31_t)0x31b88a66, (q31_t)0x17bdc5d6, (q31_t)0x31c072fb, + (q31_t)0x17c78b68, (q31_t)0x31c859a5, (q31_t)0x17d15288, (q31_t)0x31d03e64, + (q31_t)0x17db1b34, (q31_t)0x31d82137, (q31_t)0x17e4e56c, (q31_t)0x31e0021e, + (q31_t)0x17eeb130, (q31_t)0x31e7e118, (q31_t)0x17f87e7f, (q31_t)0x31efbe27, + (q31_t)0x18024d59, (q31_t)0x31f79948, (q31_t)0x180c1dbf, (q31_t)0x31ff727c, + (q31_t)0x1815efae, (q31_t)0x320749c3, (q31_t)0x181fc328, (q31_t)0x320f1f1c, + (q31_t)0x1829982b, (q31_t)0x3216f287, (q31_t)0x18336eb7, (q31_t)0x321ec403, + (q31_t)0x183d46cc, (q31_t)0x32269391, (q31_t)0x18472069, (q31_t)0x322e6130, + (q31_t)0x1850fb8e, (q31_t)0x32362ce0, (q31_t)0x185ad83c, (q31_t)0x323df6a0, + (q31_t)0x1864b670, (q31_t)0x3245be70, (q31_t)0x186e962b, (q31_t)0x324d8450, + (q31_t)0x1878776d, (q31_t)0x32554840, (q31_t)0x18825a35, (q31_t)0x325d0a3e, + (q31_t)0x188c3e83, (q31_t)0x3264ca4c, (q31_t)0x18962456, (q31_t)0x326c8868, + (q31_t)0x18a00bae, (q31_t)0x32744493, (q31_t)0x18a9f48a, (q31_t)0x327bfecc, + (q31_t)0x18b3deeb, (q31_t)0x3283b712, (q31_t)0x18bdcad0, (q31_t)0x328b6d66, + (q31_t)0x18c7b838, (q31_t)0x329321c7, (q31_t)0x18d1a724, (q31_t)0x329ad435, + (q31_t)0x18db9792, (q31_t)0x32a284b0, (q31_t)0x18e58982, (q31_t)0x32aa3336, + (q31_t)0x18ef7cf4, (q31_t)0x32b1dfc9, (q31_t)0x18f971e8, (q31_t)0x32b98a67, + (q31_t)0x1903685d, (q31_t)0x32c13311, (q31_t)0x190d6053, (q31_t)0x32c8d9c6, + (q31_t)0x191759c9, (q31_t)0x32d07e85, (q31_t)0x192154bf, (q31_t)0x32d82150, + (q31_t)0x192b5135, (q31_t)0x32dfc224, (q31_t)0x19354f2a, (q31_t)0x32e76102, + (q31_t)0x193f4e9e, (q31_t)0x32eefdea, (q31_t)0x19494f90, (q31_t)0x32f698db, + (q31_t)0x19535201, (q31_t)0x32fe31d5, (q31_t)0x195d55ef, (q31_t)0x3305c8d7, + (q31_t)0x19675b5a, (q31_t)0x330d5de3, (q31_t)0x19716243, (q31_t)0x3314f0f6, + (q31_t)0x197b6aa8, (q31_t)0x331c8211, (q31_t)0x19857489, (q31_t)0x33241134, + (q31_t)0x198f7fe6, (q31_t)0x332b9e5e, (q31_t)0x19998cbe, (q31_t)0x3333298f, + (q31_t)0x19a39b11, (q31_t)0x333ab2c6, (q31_t)0x19adaadf, (q31_t)0x33423a04, + (q31_t)0x19b7bc27, (q31_t)0x3349bf48, (q31_t)0x19c1cee9, (q31_t)0x33514292, + (q31_t)0x19cbe325, (q31_t)0x3358c3e2, (q31_t)0x19d5f8d9, (q31_t)0x33604336, + (q31_t)0x19e01006, (q31_t)0x3367c090, (q31_t)0x19ea28ac, (q31_t)0x336f3bee, + (q31_t)0x19f442c9, (q31_t)0x3376b551, (q31_t)0x19fe5e5e, (q31_t)0x337e2cb7, + (q31_t)0x1a087b69, (q31_t)0x3385a222, (q31_t)0x1a1299ec, (q31_t)0x338d1590, + (q31_t)0x1a1cb9e5, (q31_t)0x33948701, (q31_t)0x1a26db54, (q31_t)0x339bf675, + (q31_t)0x1a30fe38, (q31_t)0x33a363ec, (q31_t)0x1a3b2292, (q31_t)0x33aacf65, + (q31_t)0x1a454860, (q31_t)0x33b238e0, (q31_t)0x1a4f6fa3, (q31_t)0x33b9a05d, + (q31_t)0x1a599859, (q31_t)0x33c105db, (q31_t)0x1a63c284, (q31_t)0x33c8695b, + (q31_t)0x1a6dee21, (q31_t)0x33cfcadc, (q31_t)0x1a781b31, (q31_t)0x33d72a5d, + (q31_t)0x1a8249b4, (q31_t)0x33de87de, (q31_t)0x1a8c79a9, (q31_t)0x33e5e360, + (q31_t)0x1a96ab0f, (q31_t)0x33ed3ce1, (q31_t)0x1aa0dde7, (q31_t)0x33f49462, + (q31_t)0x1aab122f, (q31_t)0x33fbe9e2, (q31_t)0x1ab547e8, (q31_t)0x34033d61, + (q31_t)0x1abf7f11, (q31_t)0x340a8edf, (q31_t)0x1ac9b7a9, (q31_t)0x3411de5b, + (q31_t)0x1ad3f1b1, (q31_t)0x34192bd5, (q31_t)0x1ade2d28, (q31_t)0x3420774d, + (q31_t)0x1ae86a0d, (q31_t)0x3427c0c3, (q31_t)0x1af2a860, (q31_t)0x342f0836, + (q31_t)0x1afce821, (q31_t)0x34364da6, (q31_t)0x1b072950, (q31_t)0x343d9112, + (q31_t)0x1b116beb, (q31_t)0x3444d27b, (q31_t)0x1b1baff2, (q31_t)0x344c11e0, + (q31_t)0x1b25f566, (q31_t)0x34534f41, (q31_t)0x1b303c46, (q31_t)0x345a8a9d, + (q31_t)0x1b3a8491, (q31_t)0x3461c3f5, (q31_t)0x1b44ce46, (q31_t)0x3468fb47, + (q31_t)0x1b4f1967, (q31_t)0x34703095, (q31_t)0x1b5965f1, (q31_t)0x347763dd, + (q31_t)0x1b63b3e5, (q31_t)0x347e951f, (q31_t)0x1b6e0342, (q31_t)0x3485c45b, + (q31_t)0x1b785409, (q31_t)0x348cf190, (q31_t)0x1b82a638, (q31_t)0x34941cbf, + (q31_t)0x1b8cf9cf, (q31_t)0x349b45e7, (q31_t)0x1b974ece, (q31_t)0x34a26d08, + (q31_t)0x1ba1a534, (q31_t)0x34a99221, (q31_t)0x1babfd01, (q31_t)0x34b0b533, + (q31_t)0x1bb65634, (q31_t)0x34b7d63c, (q31_t)0x1bc0b0ce, (q31_t)0x34bef53d, + (q31_t)0x1bcb0cce, (q31_t)0x34c61236, (q31_t)0x1bd56a32, (q31_t)0x34cd2d26, + (q31_t)0x1bdfc8fc, (q31_t)0x34d4460c, (q31_t)0x1bea292b, (q31_t)0x34db5cea, + (q31_t)0x1bf48abd, (q31_t)0x34e271bd, (q31_t)0x1bfeedb3, (q31_t)0x34e98487, + (q31_t)0x1c09520d, (q31_t)0x34f09546, (q31_t)0x1c13b7c9, (q31_t)0x34f7a3fb, + (q31_t)0x1c1e1ee9, (q31_t)0x34feb0a5, (q31_t)0x1c28876a, (q31_t)0x3505bb44, + (q31_t)0x1c32f14d, (q31_t)0x350cc3d8, (q31_t)0x1c3d5c91, (q31_t)0x3513ca60, + (q31_t)0x1c47c936, (q31_t)0x351acedd, (q31_t)0x1c52373c, (q31_t)0x3521d14d, + (q31_t)0x1c5ca6a2, (q31_t)0x3528d1b1, (q31_t)0x1c671768, (q31_t)0x352fd008, + (q31_t)0x1c71898d, (q31_t)0x3536cc52, (q31_t)0x1c7bfd11, (q31_t)0x353dc68f, + (q31_t)0x1c8671f3, (q31_t)0x3544bebf, (q31_t)0x1c90e834, (q31_t)0x354bb4e1, + (q31_t)0x1c9b5fd2, (q31_t)0x3552a8f4, (q31_t)0x1ca5d8cd, (q31_t)0x35599afa, + (q31_t)0x1cb05326, (q31_t)0x35608af1, (q31_t)0x1cbacedb, (q31_t)0x356778d9, + (q31_t)0x1cc54bec, (q31_t)0x356e64b2, (q31_t)0x1ccfca59, (q31_t)0x35754e7c, + (q31_t)0x1cda4a21, (q31_t)0x357c3636, (q31_t)0x1ce4cb44, (q31_t)0x35831be0, + (q31_t)0x1cef4dc2, (q31_t)0x3589ff7a, (q31_t)0x1cf9d199, (q31_t)0x3590e104, + (q31_t)0x1d0456ca, (q31_t)0x3597c07d, (q31_t)0x1d0edd55, (q31_t)0x359e9de5, + (q31_t)0x1d196538, (q31_t)0x35a5793c, (q31_t)0x1d23ee74, (q31_t)0x35ac5282, + (q31_t)0x1d2e7908, (q31_t)0x35b329b5, (q31_t)0x1d3904f4, (q31_t)0x35b9fed7, + (q31_t)0x1d439236, (q31_t)0x35c0d1e7, (q31_t)0x1d4e20d0, (q31_t)0x35c7a2e3, + (q31_t)0x1d58b0c0, (q31_t)0x35ce71ce, (q31_t)0x1d634206, (q31_t)0x35d53ea5, + (q31_t)0x1d6dd4a2, (q31_t)0x35dc0968, (q31_t)0x1d786892, (q31_t)0x35e2d219, + (q31_t)0x1d82fdd8, (q31_t)0x35e998b5, (q31_t)0x1d8d9472, (q31_t)0x35f05d3d, + (q31_t)0x1d982c60, (q31_t)0x35f71fb1, (q31_t)0x1da2c5a2, (q31_t)0x35fde011, + (q31_t)0x1dad6036, (q31_t)0x36049e5b, (q31_t)0x1db7fc1e, (q31_t)0x360b5a90, + (q31_t)0x1dc29958, (q31_t)0x361214b0, (q31_t)0x1dcd37e4, (q31_t)0x3618ccba, + (q31_t)0x1dd7d7c1, (q31_t)0x361f82af, (q31_t)0x1de278ef, (q31_t)0x3626368d, + (q31_t)0x1ded1b6e, (q31_t)0x362ce855, (q31_t)0x1df7bf3e, (q31_t)0x36339806, + (q31_t)0x1e02645d, (q31_t)0x363a45a0, (q31_t)0x1e0d0acc, (q31_t)0x3640f123, + (q31_t)0x1e17b28a, (q31_t)0x36479a8e, (q31_t)0x1e225b96, (q31_t)0x364e41e2, + (q31_t)0x1e2d05f1, (q31_t)0x3654e71d, (q31_t)0x1e37b199, (q31_t)0x365b8a41, + (q31_t)0x1e425e8f, (q31_t)0x36622b4c, (q31_t)0x1e4d0cd2, (q31_t)0x3668ca3e, + (q31_t)0x1e57bc62, (q31_t)0x366f6717, (q31_t)0x1e626d3e, (q31_t)0x367601d7, + (q31_t)0x1e6d1f65, (q31_t)0x367c9a7e, (q31_t)0x1e77d2d8, (q31_t)0x3683310b, + (q31_t)0x1e828796, (q31_t)0x3689c57d, (q31_t)0x1e8d3d9e, (q31_t)0x369057d6, + (q31_t)0x1e97f4f1, (q31_t)0x3696e814, (q31_t)0x1ea2ad8d, (q31_t)0x369d7637, + (q31_t)0x1ead6773, (q31_t)0x36a4023f, (q31_t)0x1eb822a1, (q31_t)0x36aa8c2c, + (q31_t)0x1ec2df18, (q31_t)0x36b113fd, (q31_t)0x1ecd9cd7, (q31_t)0x36b799b3, + (q31_t)0x1ed85bdd, (q31_t)0x36be1d4c, (q31_t)0x1ee31c2b, (q31_t)0x36c49ec9, + (q31_t)0x1eedddc0, (q31_t)0x36cb1e2a, (q31_t)0x1ef8a09b, (q31_t)0x36d19b6e, + (q31_t)0x1f0364bc, (q31_t)0x36d81695, (q31_t)0x1f0e2a22, (q31_t)0x36de8f9e, + (q31_t)0x1f18f0ce, (q31_t)0x36e5068a, (q31_t)0x1f23b8be, (q31_t)0x36eb7b58, + (q31_t)0x1f2e81f3, (q31_t)0x36f1ee09, (q31_t)0x1f394c6b, (q31_t)0x36f85e9a, + (q31_t)0x1f441828, (q31_t)0x36fecd0e, (q31_t)0x1f4ee527, (q31_t)0x37053962, + (q31_t)0x1f59b369, (q31_t)0x370ba398, (q31_t)0x1f6482ed, (q31_t)0x37120bae, + (q31_t)0x1f6f53b3, (q31_t)0x371871a5, (q31_t)0x1f7a25ba, (q31_t)0x371ed57c, + (q31_t)0x1f84f902, (q31_t)0x37253733, (q31_t)0x1f8fcd8b, (q31_t)0x372b96ca, + (q31_t)0x1f9aa354, (q31_t)0x3731f440, (q31_t)0x1fa57a5d, (q31_t)0x37384f95, + (q31_t)0x1fb052a5, (q31_t)0x373ea8ca, (q31_t)0x1fbb2c2c, (q31_t)0x3744ffdd, + (q31_t)0x1fc606f1, (q31_t)0x374b54ce, (q31_t)0x1fd0e2f5, (q31_t)0x3751a79e, + (q31_t)0x1fdbc036, (q31_t)0x3757f84c, (q31_t)0x1fe69eb4, (q31_t)0x375e46d8, + (q31_t)0x1ff17e70, (q31_t)0x37649341, (q31_t)0x1ffc5f67, (q31_t)0x376add88, + (q31_t)0x2007419b, (q31_t)0x377125ac, (q31_t)0x2012250a, (q31_t)0x37776bac, + (q31_t)0x201d09b4, (q31_t)0x377daf89, (q31_t)0x2027ef99, (q31_t)0x3783f143, + (q31_t)0x2032d6b8, (q31_t)0x378a30d8, (q31_t)0x203dbf11, (q31_t)0x37906e49, + (q31_t)0x2048a8a4, (q31_t)0x3796a996, (q31_t)0x2053936f, (q31_t)0x379ce2be, + (q31_t)0x205e7f74, (q31_t)0x37a319c2, (q31_t)0x20696cb0, (q31_t)0x37a94ea0, + (q31_t)0x20745b24, (q31_t)0x37af8159, (q31_t)0x207f4acf, (q31_t)0x37b5b1ec, + (q31_t)0x208a3bb2, (q31_t)0x37bbe05a, (q31_t)0x20952dcb, (q31_t)0x37c20ca1, + (q31_t)0x20a0211a, (q31_t)0x37c836c2, (q31_t)0x20ab159e, (q31_t)0x37ce5ebd, + (q31_t)0x20b60b58, (q31_t)0x37d48490, (q31_t)0x20c10247, (q31_t)0x37daa83d, + (q31_t)0x20cbfa6a, (q31_t)0x37e0c9c3, (q31_t)0x20d6f3c1, (q31_t)0x37e6e921, + (q31_t)0x20e1ee4b, (q31_t)0x37ed0657, (q31_t)0x20ecea09, (q31_t)0x37f32165, + (q31_t)0x20f7e6f9, (q31_t)0x37f93a4b, (q31_t)0x2102e51c, (q31_t)0x37ff5109, + (q31_t)0x210de470, (q31_t)0x3805659e, (q31_t)0x2118e4f6, (q31_t)0x380b780a, + (q31_t)0x2123e6ad, (q31_t)0x3811884d, (q31_t)0x212ee995, (q31_t)0x38179666, + (q31_t)0x2139edac, (q31_t)0x381da256, (q31_t)0x2144f2f3, (q31_t)0x3823ac1d, + (q31_t)0x214ff96a, (q31_t)0x3829b3b9, (q31_t)0x215b0110, (q31_t)0x382fb92a, + (q31_t)0x216609e3, (q31_t)0x3835bc71, (q31_t)0x217113e5, (q31_t)0x383bbd8e, + (q31_t)0x217c1f15, (q31_t)0x3841bc7f, (q31_t)0x21872b72, (q31_t)0x3847b946, + (q31_t)0x219238fb, (q31_t)0x384db3e0, (q31_t)0x219d47b1, (q31_t)0x3853ac4f, + (q31_t)0x21a85793, (q31_t)0x3859a292, (q31_t)0x21b368a0, (q31_t)0x385f96a9, + (q31_t)0x21be7ad8, (q31_t)0x38658894, (q31_t)0x21c98e3b, (q31_t)0x386b7852, + (q31_t)0x21d4a2c8, (q31_t)0x387165e3, (q31_t)0x21dfb87f, (q31_t)0x38775147, + (q31_t)0x21eacf5f, (q31_t)0x387d3a7e, (q31_t)0x21f5e768, (q31_t)0x38832187, + (q31_t)0x22010099, (q31_t)0x38890663, (q31_t)0x220c1af3, (q31_t)0x388ee910, + (q31_t)0x22173674, (q31_t)0x3894c98f, (q31_t)0x2222531c, (q31_t)0x389aa7e0, + (q31_t)0x222d70eb, (q31_t)0x38a08402, (q31_t)0x22388fe1, (q31_t)0x38a65df6, + (q31_t)0x2243affc, (q31_t)0x38ac35ba, (q31_t)0x224ed13d, (q31_t)0x38b20b4f, + (q31_t)0x2259f3a3, (q31_t)0x38b7deb4, (q31_t)0x2265172e, (q31_t)0x38bdafea, + (q31_t)0x22703bdc, (q31_t)0x38c37eef, (q31_t)0x227b61af, (q31_t)0x38c94bc4, + (q31_t)0x228688a4, (q31_t)0x38cf1669, (q31_t)0x2291b0bd, (q31_t)0x38d4dedd, + (q31_t)0x229cd9f8, (q31_t)0x38daa520, (q31_t)0x22a80456, (q31_t)0x38e06932, + (q31_t)0x22b32fd4, (q31_t)0x38e62b13, (q31_t)0x22be5c74, (q31_t)0x38ebeac2, + (q31_t)0x22c98a35, (q31_t)0x38f1a840, (q31_t)0x22d4b916, (q31_t)0x38f7638b, + (q31_t)0x22dfe917, (q31_t)0x38fd1ca4, (q31_t)0x22eb1a37, (q31_t)0x3902d38b, + (q31_t)0x22f64c77, (q31_t)0x3908883f, (q31_t)0x23017fd5, (q31_t)0x390e3ac0, + (q31_t)0x230cb451, (q31_t)0x3913eb0e, (q31_t)0x2317e9eb, (q31_t)0x39199929, + (q31_t)0x232320a2, (q31_t)0x391f4510, (q31_t)0x232e5876, (q31_t)0x3924eec3, + (q31_t)0x23399167, (q31_t)0x392a9642, (q31_t)0x2344cb73, (q31_t)0x39303b8e, + (q31_t)0x2350069b, (q31_t)0x3935dea4, (q31_t)0x235b42df, (q31_t)0x393b7f86, + (q31_t)0x2366803c, (q31_t)0x39411e33, (q31_t)0x2371beb5, (q31_t)0x3946baac, + (q31_t)0x237cfe47, (q31_t)0x394c54ee, (q31_t)0x23883ef2, (q31_t)0x3951ecfc, + (q31_t)0x239380b6, (q31_t)0x395782d3, (q31_t)0x239ec393, (q31_t)0x395d1675, + (q31_t)0x23aa0788, (q31_t)0x3962a7e0, (q31_t)0x23b54c95, (q31_t)0x39683715, + (q31_t)0x23c092b9, (q31_t)0x396dc414, (q31_t)0x23cbd9f4, (q31_t)0x39734edc, + (q31_t)0x23d72245, (q31_t)0x3978d76c, (q31_t)0x23e26bac, (q31_t)0x397e5dc6, + (q31_t)0x23edb628, (q31_t)0x3983e1e8, (q31_t)0x23f901ba, (q31_t)0x398963d2, + (q31_t)0x24044e60, (q31_t)0x398ee385, (q31_t)0x240f9c1a, (q31_t)0x399460ff, + (q31_t)0x241aeae8, (q31_t)0x3999dc42, (q31_t)0x24263ac9, (q31_t)0x399f554b, + (q31_t)0x24318bbe, (q31_t)0x39a4cc1c, (q31_t)0x243cddc4, (q31_t)0x39aa40b4, + (q31_t)0x244830dd, (q31_t)0x39afb313, (q31_t)0x24538507, (q31_t)0x39b52339, + (q31_t)0x245eda43, (q31_t)0x39ba9125, (q31_t)0x246a308f, (q31_t)0x39bffcd7, + (q31_t)0x247587eb, (q31_t)0x39c5664f, (q31_t)0x2480e057, (q31_t)0x39cacd8d, + (q31_t)0x248c39d3, (q31_t)0x39d03291, (q31_t)0x2497945d, (q31_t)0x39d5955a, + (q31_t)0x24a2eff6, (q31_t)0x39daf5e8, (q31_t)0x24ae4c9d, (q31_t)0x39e0543c, + (q31_t)0x24b9aa52, (q31_t)0x39e5b054, (q31_t)0x24c50914, (q31_t)0x39eb0a31, + (q31_t)0x24d068e2, (q31_t)0x39f061d2, (q31_t)0x24dbc9bd, (q31_t)0x39f5b737, + (q31_t)0x24e72ba4, (q31_t)0x39fb0a60, (q31_t)0x24f28e96, (q31_t)0x3a005b4d, + (q31_t)0x24fdf294, (q31_t)0x3a05a9fd, (q31_t)0x2509579b, (q31_t)0x3a0af671, + (q31_t)0x2514bdad, (q31_t)0x3a1040a8, (q31_t)0x252024c9, (q31_t)0x3a1588a2, + (q31_t)0x252b8cee, (q31_t)0x3a1ace5f, (q31_t)0x2536f61b, (q31_t)0x3a2011de, + (q31_t)0x25426051, (q31_t)0x3a25531f, (q31_t)0x254dcb8f, (q31_t)0x3a2a9223, + (q31_t)0x255937d5, (q31_t)0x3a2fcee8, (q31_t)0x2564a521, (q31_t)0x3a350970, + (q31_t)0x25701374, (q31_t)0x3a3a41b9, (q31_t)0x257b82cd, (q31_t)0x3a3f77c3, + (q31_t)0x2586f32c, (q31_t)0x3a44ab8e, (q31_t)0x25926490, (q31_t)0x3a49dd1a, + (q31_t)0x259dd6f9, (q31_t)0x3a4f0c67, (q31_t)0x25a94a67, (q31_t)0x3a543974, + (q31_t)0x25b4bed8, (q31_t)0x3a596442, (q31_t)0x25c0344d, (q31_t)0x3a5e8cd0, + (q31_t)0x25cbaac5, (q31_t)0x3a63b31d, (q31_t)0x25d72240, (q31_t)0x3a68d72b, + (q31_t)0x25e29abc, (q31_t)0x3a6df8f8, (q31_t)0x25ee143b, (q31_t)0x3a731884, + (q31_t)0x25f98ebb, (q31_t)0x3a7835cf, (q31_t)0x26050a3b, (q31_t)0x3a7d50da, + (q31_t)0x261086bc, (q31_t)0x3a8269a3, (q31_t)0x261c043d, (q31_t)0x3a87802a, + (q31_t)0x262782be, (q31_t)0x3a8c9470, (q31_t)0x2633023e, (q31_t)0x3a91a674, + (q31_t)0x263e82bc, (q31_t)0x3a96b636, (q31_t)0x264a0438, (q31_t)0x3a9bc3b6, + (q31_t)0x265586b3, (q31_t)0x3aa0cef3, (q31_t)0x26610a2a, (q31_t)0x3aa5d7ee, + (q31_t)0x266c8e9f, (q31_t)0x3aaadea6, (q31_t)0x26781410, (q31_t)0x3aafe31b, + (q31_t)0x26839a7c, (q31_t)0x3ab4e54c, (q31_t)0x268f21e5, (q31_t)0x3ab9e53a, + (q31_t)0x269aaa48, (q31_t)0x3abee2e5, (q31_t)0x26a633a6, (q31_t)0x3ac3de4c, + (q31_t)0x26b1bdff, (q31_t)0x3ac8d76f, (q31_t)0x26bd4951, (q31_t)0x3acdce4d, + (q31_t)0x26c8d59c, (q31_t)0x3ad2c2e8, (q31_t)0x26d462e1, (q31_t)0x3ad7b53d, + (q31_t)0x26dff11d, (q31_t)0x3adca54e, (q31_t)0x26eb8052, (q31_t)0x3ae1931a, + (q31_t)0x26f7107e, (q31_t)0x3ae67ea1, (q31_t)0x2702a1a1, (q31_t)0x3aeb67e3, + (q31_t)0x270e33bb, (q31_t)0x3af04edf, (q31_t)0x2719c6cb, (q31_t)0x3af53395, + (q31_t)0x27255ad1, (q31_t)0x3afa1605, (q31_t)0x2730efcc, (q31_t)0x3afef630, + (q31_t)0x273c85bc, (q31_t)0x3b03d414, (q31_t)0x27481ca1, (q31_t)0x3b08afb2, + (q31_t)0x2753b479, (q31_t)0x3b0d8909, (q31_t)0x275f4d45, (q31_t)0x3b126019, + (q31_t)0x276ae704, (q31_t)0x3b1734e2, (q31_t)0x277681b6, (q31_t)0x3b1c0764, + (q31_t)0x27821d59, (q31_t)0x3b20d79e, (q31_t)0x278db9ef, (q31_t)0x3b25a591, + (q31_t)0x27995776, (q31_t)0x3b2a713d, (q31_t)0x27a4f5ed, (q31_t)0x3b2f3aa0, + (q31_t)0x27b09555, (q31_t)0x3b3401bb, (q31_t)0x27bc35ad, (q31_t)0x3b38c68e, + (q31_t)0x27c7d6f4, (q31_t)0x3b3d8918, (q31_t)0x27d3792b, (q31_t)0x3b42495a, + (q31_t)0x27df1c50, (q31_t)0x3b470753, (q31_t)0x27eac063, (q31_t)0x3b4bc303, + (q31_t)0x27f66564, (q31_t)0x3b507c69, (q31_t)0x28020b52, (q31_t)0x3b553386, + (q31_t)0x280db22d, (q31_t)0x3b59e85a, (q31_t)0x281959f4, (q31_t)0x3b5e9ae4, + (q31_t)0x282502a7, (q31_t)0x3b634b23, (q31_t)0x2830ac45, (q31_t)0x3b67f919, + (q31_t)0x283c56cf, (q31_t)0x3b6ca4c4, (q31_t)0x28480243, (q31_t)0x3b714e25, + (q31_t)0x2853aea1, (q31_t)0x3b75f53c, (q31_t)0x285f5be9, (q31_t)0x3b7a9a07, + (q31_t)0x286b0a1a, (q31_t)0x3b7f3c87, (q31_t)0x2876b934, (q31_t)0x3b83dcbc, + (q31_t)0x28826936, (q31_t)0x3b887aa6, (q31_t)0x288e1a20, (q31_t)0x3b8d1644, + (q31_t)0x2899cbf1, (q31_t)0x3b91af97, (q31_t)0x28a57ea9, (q31_t)0x3b96469d, + (q31_t)0x28b13248, (q31_t)0x3b9adb57, (q31_t)0x28bce6cd, (q31_t)0x3b9f6dc5, + (q31_t)0x28c89c37, (q31_t)0x3ba3fde7, (q31_t)0x28d45286, (q31_t)0x3ba88bbc, + (q31_t)0x28e009ba, (q31_t)0x3bad1744, (q31_t)0x28ebc1d3, (q31_t)0x3bb1a080, + (q31_t)0x28f77acf, (q31_t)0x3bb6276e, (q31_t)0x290334af, (q31_t)0x3bbaac0e, + (q31_t)0x290eef71, (q31_t)0x3bbf2e62, (q31_t)0x291aab16, (q31_t)0x3bc3ae67, + (q31_t)0x2926679c, (q31_t)0x3bc82c1f, (q31_t)0x29322505, (q31_t)0x3bcca789, + (q31_t)0x293de34e, (q31_t)0x3bd120a4, (q31_t)0x2949a278, (q31_t)0x3bd59771, + (q31_t)0x29556282, (q31_t)0x3bda0bf0, (q31_t)0x2961236c, (q31_t)0x3bde7e20, + (q31_t)0x296ce535, (q31_t)0x3be2ee01, (q31_t)0x2978a7dd, (q31_t)0x3be75b93, + (q31_t)0x29846b63, (q31_t)0x3bebc6d5, (q31_t)0x29902fc7, (q31_t)0x3bf02fc9, + (q31_t)0x299bf509, (q31_t)0x3bf4966c, (q31_t)0x29a7bb28, (q31_t)0x3bf8fac0, + (q31_t)0x29b38223, (q31_t)0x3bfd5cc4, (q31_t)0x29bf49fa, (q31_t)0x3c01bc78, + (q31_t)0x29cb12ad, (q31_t)0x3c0619dc, (q31_t)0x29d6dc3b, (q31_t)0x3c0a74f0, + (q31_t)0x29e2a6a3, (q31_t)0x3c0ecdb2, (q31_t)0x29ee71e6, (q31_t)0x3c132424, + (q31_t)0x29fa3e03, (q31_t)0x3c177845, (q31_t)0x2a060af9, (q31_t)0x3c1bca16, + (q31_t)0x2a11d8c8, (q31_t)0x3c201994, (q31_t)0x2a1da770, (q31_t)0x3c2466c2, + (q31_t)0x2a2976ef, (q31_t)0x3c28b19e, (q31_t)0x2a354746, (q31_t)0x3c2cfa28, + (q31_t)0x2a411874, (q31_t)0x3c314060, (q31_t)0x2a4cea79, (q31_t)0x3c358446, + (q31_t)0x2a58bd54, (q31_t)0x3c39c5da, (q31_t)0x2a649105, (q31_t)0x3c3e051b, + (q31_t)0x2a70658a, (q31_t)0x3c42420a, (q31_t)0x2a7c3ae5, (q31_t)0x3c467ca6, + (q31_t)0x2a881114, (q31_t)0x3c4ab4ef, (q31_t)0x2a93e817, (q31_t)0x3c4eeae5, + (q31_t)0x2a9fbfed, (q31_t)0x3c531e88, (q31_t)0x2aab9896, (q31_t)0x3c574fd8, + (q31_t)0x2ab77212, (q31_t)0x3c5b7ed4, (q31_t)0x2ac34c60, (q31_t)0x3c5fab7c, + (q31_t)0x2acf277f, (q31_t)0x3c63d5d1, (q31_t)0x2adb0370, (q31_t)0x3c67fdd1, + (q31_t)0x2ae6e031, (q31_t)0x3c6c237e, (q31_t)0x2af2bdc3, (q31_t)0x3c7046d6, + (q31_t)0x2afe9c24, (q31_t)0x3c7467d9, (q31_t)0x2b0a7b54, (q31_t)0x3c788688, + (q31_t)0x2b165b54, (q31_t)0x3c7ca2e2, (q31_t)0x2b223c22, (q31_t)0x3c80bce7, + (q31_t)0x2b2e1dbe, (q31_t)0x3c84d496, (q31_t)0x2b3a0027, (q31_t)0x3c88e9f1, + (q31_t)0x2b45e35d, (q31_t)0x3c8cfcf6, (q31_t)0x2b51c760, (q31_t)0x3c910da5, + (q31_t)0x2b5dac2f, (q31_t)0x3c951bff, (q31_t)0x2b6991ca, (q31_t)0x3c992803, + (q31_t)0x2b75782f, (q31_t)0x3c9d31b0, (q31_t)0x2b815f60, (q31_t)0x3ca13908, + (q31_t)0x2b8d475b, (q31_t)0x3ca53e09, (q31_t)0x2b99301f, (q31_t)0x3ca940b3, + (q31_t)0x2ba519ad, (q31_t)0x3cad4107, (q31_t)0x2bb10404, (q31_t)0x3cb13f04, + (q31_t)0x2bbcef23, (q31_t)0x3cb53aaa, (q31_t)0x2bc8db0b, (q31_t)0x3cb933f9, + (q31_t)0x2bd4c7ba, (q31_t)0x3cbd2af0, (q31_t)0x2be0b52f, (q31_t)0x3cc11f90, + (q31_t)0x2beca36c, (q31_t)0x3cc511d9, (q31_t)0x2bf8926f, (q31_t)0x3cc901c9, + (q31_t)0x2c048237, (q31_t)0x3cccef62, (q31_t)0x2c1072c4, (q31_t)0x3cd0daa2, + (q31_t)0x2c1c6417, (q31_t)0x3cd4c38b, (q31_t)0x2c28562d, (q31_t)0x3cd8aa1b, + (q31_t)0x2c344908, (q31_t)0x3cdc8e52, (q31_t)0x2c403ca5, (q31_t)0x3ce07031, + (q31_t)0x2c4c3106, (q31_t)0x3ce44fb7, (q31_t)0x2c582629, (q31_t)0x3ce82ce4, + (q31_t)0x2c641c0e, (q31_t)0x3cec07b8, (q31_t)0x2c7012b5, (q31_t)0x3cefe032, + (q31_t)0x2c7c0a1d, (q31_t)0x3cf3b653, (q31_t)0x2c880245, (q31_t)0x3cf78a1b, + (q31_t)0x2c93fb2e, (q31_t)0x3cfb5b89, (q31_t)0x2c9ff4d6, (q31_t)0x3cff2a9d, + (q31_t)0x2cabef3d, (q31_t)0x3d02f757, (q31_t)0x2cb7ea63, (q31_t)0x3d06c1b6, + (q31_t)0x2cc3e648, (q31_t)0x3d0a89bc, (q31_t)0x2ccfe2ea, (q31_t)0x3d0e4f67, + (q31_t)0x2cdbe04a, (q31_t)0x3d1212b7, (q31_t)0x2ce7de66, (q31_t)0x3d15d3ad, + (q31_t)0x2cf3dd3f, (q31_t)0x3d199248, (q31_t)0x2cffdcd4, (q31_t)0x3d1d4e88, + (q31_t)0x2d0bdd25, (q31_t)0x3d21086c, (q31_t)0x2d17de31, (q31_t)0x3d24bff6, + (q31_t)0x2d23dff7, (q31_t)0x3d287523, (q31_t)0x2d2fe277, (q31_t)0x3d2c27f6, + (q31_t)0x2d3be5b1, (q31_t)0x3d2fd86c, (q31_t)0x2d47e9a5, (q31_t)0x3d338687, + (q31_t)0x2d53ee51, (q31_t)0x3d373245, (q31_t)0x2d5ff3b5, (q31_t)0x3d3adba7, + (q31_t)0x2d6bf9d1, (q31_t)0x3d3e82ae, (q31_t)0x2d7800a5, (q31_t)0x3d422757, + (q31_t)0x2d84082f, (q31_t)0x3d45c9a4, (q31_t)0x2d901070, (q31_t)0x3d496994, + (q31_t)0x2d9c1967, (q31_t)0x3d4d0728, (q31_t)0x2da82313, (q31_t)0x3d50a25e, + (q31_t)0x2db42d74, (q31_t)0x3d543b37, (q31_t)0x2dc0388a, (q31_t)0x3d57d1b3, + (q31_t)0x2dcc4454, (q31_t)0x3d5b65d2, (q31_t)0x2dd850d2, (q31_t)0x3d5ef793, + (q31_t)0x2de45e03, (q31_t)0x3d6286f6, (q31_t)0x2df06be6, (q31_t)0x3d6613fb, + (q31_t)0x2dfc7a7c, (q31_t)0x3d699ea3, (q31_t)0x2e0889c4, (q31_t)0x3d6d26ec, + (q31_t)0x2e1499bd, (q31_t)0x3d70acd7, (q31_t)0x2e20aa67, (q31_t)0x3d743064, + (q31_t)0x2e2cbbc1, (q31_t)0x3d77b192, (q31_t)0x2e38cdcb, (q31_t)0x3d7b3061, + (q31_t)0x2e44e084, (q31_t)0x3d7eacd2, (q31_t)0x2e50f3ed, (q31_t)0x3d8226e4, + (q31_t)0x2e5d0804, (q31_t)0x3d859e96, (q31_t)0x2e691cc9, (q31_t)0x3d8913ea, + (q31_t)0x2e75323c, (q31_t)0x3d8c86de, (q31_t)0x2e81485c, (q31_t)0x3d8ff772, + (q31_t)0x2e8d5f29, (q31_t)0x3d9365a8, (q31_t)0x2e9976a1, (q31_t)0x3d96d17d, + (q31_t)0x2ea58ec6, (q31_t)0x3d9a3af2, (q31_t)0x2eb1a796, (q31_t)0x3d9da208, + (q31_t)0x2ebdc110, (q31_t)0x3da106bd, (q31_t)0x2ec9db35, (q31_t)0x3da46912, + (q31_t)0x2ed5f604, (q31_t)0x3da7c907, (q31_t)0x2ee2117c, (q31_t)0x3dab269b, + (q31_t)0x2eee2d9d, (q31_t)0x3dae81cf, (q31_t)0x2efa4a67, (q31_t)0x3db1daa2, + (q31_t)0x2f0667d9, (q31_t)0x3db53113, (q31_t)0x2f1285f2, (q31_t)0x3db88524, + (q31_t)0x2f1ea4b2, (q31_t)0x3dbbd6d4, (q31_t)0x2f2ac419, (q31_t)0x3dbf2622, + (q31_t)0x2f36e426, (q31_t)0x3dc2730f, (q31_t)0x2f4304d8, (q31_t)0x3dc5bd9b, + (q31_t)0x2f4f2630, (q31_t)0x3dc905c5, (q31_t)0x2f5b482d, (q31_t)0x3dcc4b8d, + (q31_t)0x2f676ace, (q31_t)0x3dcf8ef3, (q31_t)0x2f738e12, (q31_t)0x3dd2cff7, + (q31_t)0x2f7fb1fa, (q31_t)0x3dd60e99, (q31_t)0x2f8bd685, (q31_t)0x3dd94ad8, + (q31_t)0x2f97fbb2, (q31_t)0x3ddc84b5, (q31_t)0x2fa42181, (q31_t)0x3ddfbc30, + (q31_t)0x2fb047f2, (q31_t)0x3de2f148, (q31_t)0x2fbc6f03, (q31_t)0x3de623fd, + (q31_t)0x2fc896b5, (q31_t)0x3de9544f, (q31_t)0x2fd4bf08, (q31_t)0x3dec823e, + (q31_t)0x2fe0e7f9, (q31_t)0x3defadca, (q31_t)0x2fed118a, (q31_t)0x3df2d6f3, + (q31_t)0x2ff93bba, (q31_t)0x3df5fdb8, (q31_t)0x30056687, (q31_t)0x3df9221a, + (q31_t)0x301191f3, (q31_t)0x3dfc4418, (q31_t)0x301dbdfb, (q31_t)0x3dff63b2, + (q31_t)0x3029eaa1, (q31_t)0x3e0280e9, (q31_t)0x303617e2, (q31_t)0x3e059bbb, + (q31_t)0x304245c0, (q31_t)0x3e08b42a, (q31_t)0x304e7438, (q31_t)0x3e0bca34, + (q31_t)0x305aa34c, (q31_t)0x3e0eddd9, (q31_t)0x3066d2fa, (q31_t)0x3e11ef1b, + (q31_t)0x30730342, (q31_t)0x3e14fdf7, (q31_t)0x307f3424, (q31_t)0x3e180a6f, + (q31_t)0x308b659f, (q31_t)0x3e1b1482, (q31_t)0x309797b2, (q31_t)0x3e1e1c30, + (q31_t)0x30a3ca5d, (q31_t)0x3e212179, (q31_t)0x30affda0, (q31_t)0x3e24245d, + (q31_t)0x30bc317a, (q31_t)0x3e2724db, (q31_t)0x30c865ea, (q31_t)0x3e2a22f4, + (q31_t)0x30d49af1, (q31_t)0x3e2d1ea8, (q31_t)0x30e0d08d, (q31_t)0x3e3017f6, + (q31_t)0x30ed06bf, (q31_t)0x3e330ede, (q31_t)0x30f93d86, (q31_t)0x3e360360, + (q31_t)0x310574e0, (q31_t)0x3e38f57c, (q31_t)0x3111accf, (q31_t)0x3e3be532, + (q31_t)0x311de551, (q31_t)0x3e3ed282, (q31_t)0x312a1e66, (q31_t)0x3e41bd6c, + (q31_t)0x3136580d, (q31_t)0x3e44a5ef, (q31_t)0x31429247, (q31_t)0x3e478c0b, + (q31_t)0x314ecd11, (q31_t)0x3e4a6fc1, (q31_t)0x315b086d, (q31_t)0x3e4d5110, + (q31_t)0x31674459, (q31_t)0x3e502ff9, (q31_t)0x317380d6, (q31_t)0x3e530c7a, + (q31_t)0x317fbde2, (q31_t)0x3e55e694, (q31_t)0x318bfb7d, (q31_t)0x3e58be47, + (q31_t)0x319839a6, (q31_t)0x3e5b9392, (q31_t)0x31a4785e, (q31_t)0x3e5e6676, + (q31_t)0x31b0b7a4, (q31_t)0x3e6136f3, (q31_t)0x31bcf777, (q31_t)0x3e640507, + (q31_t)0x31c937d6, (q31_t)0x3e66d0b4, (q31_t)0x31d578c2, (q31_t)0x3e6999fa, + (q31_t)0x31e1ba3a, (q31_t)0x3e6c60d7, (q31_t)0x31edfc3d, (q31_t)0x3e6f254c, + (q31_t)0x31fa3ecb, (q31_t)0x3e71e759, (q31_t)0x320681e3, (q31_t)0x3e74a6fd, + (q31_t)0x3212c585, (q31_t)0x3e77643a, (q31_t)0x321f09b1, (q31_t)0x3e7a1f0d, + (q31_t)0x322b4e66, (q31_t)0x3e7cd778, (q31_t)0x323793a3, (q31_t)0x3e7f8d7b, + (q31_t)0x3243d968, (q31_t)0x3e824114, (q31_t)0x32501fb5, (q31_t)0x3e84f245, + (q31_t)0x325c6688, (q31_t)0x3e87a10c, (q31_t)0x3268ade3, (q31_t)0x3e8a4d6a, + (q31_t)0x3274f5c3, (q31_t)0x3e8cf75f, (q31_t)0x32813e2a, (q31_t)0x3e8f9eeb, + (q31_t)0x328d8715, (q31_t)0x3e92440d, (q31_t)0x3299d085, (q31_t)0x3e94e6c6, + (q31_t)0x32a61a7a, (q31_t)0x3e978715, (q31_t)0x32b264f2, (q31_t)0x3e9a24fb, + (q31_t)0x32beafed, (q31_t)0x3e9cc076, (q31_t)0x32cafb6b, (q31_t)0x3e9f5988, + (q31_t)0x32d7476c, (q31_t)0x3ea1f02f, (q31_t)0x32e393ef, (q31_t)0x3ea4846c, + (q31_t)0x32efe0f2, (q31_t)0x3ea7163f, (q31_t)0x32fc2e77, (q31_t)0x3ea9a5a8, + (q31_t)0x33087c7d, (q31_t)0x3eac32a6, (q31_t)0x3314cb02, (q31_t)0x3eaebd3a, + (q31_t)0x33211a07, (q31_t)0x3eb14563, (q31_t)0x332d698a, (q31_t)0x3eb3cb21, + (q31_t)0x3339b98d, (q31_t)0x3eb64e75, (q31_t)0x33460a0d, (q31_t)0x3eb8cf5d, + (q31_t)0x33525b0b, (q31_t)0x3ebb4ddb, (q31_t)0x335eac86, (q31_t)0x3ebdc9ed, + (q31_t)0x336afe7e, (q31_t)0x3ec04394, (q31_t)0x337750f2, (q31_t)0x3ec2bad0, + (q31_t)0x3383a3e2, (q31_t)0x3ec52fa0, (q31_t)0x338ff74d, (q31_t)0x3ec7a205, + (q31_t)0x339c4b32, (q31_t)0x3eca11fe, (q31_t)0x33a89f92, (q31_t)0x3ecc7f8b, + (q31_t)0x33b4f46c, (q31_t)0x3eceeaad, (q31_t)0x33c149bf, (q31_t)0x3ed15363, + (q31_t)0x33cd9f8b, (q31_t)0x3ed3b9ad, (q31_t)0x33d9f5cf, (q31_t)0x3ed61d8a, + (q31_t)0x33e64c8c, (q31_t)0x3ed87efc, (q31_t)0x33f2a3bf, (q31_t)0x3edade01, + (q31_t)0x33fefb6a, (q31_t)0x3edd3a9a, (q31_t)0x340b538b, (q31_t)0x3edf94c7, + (q31_t)0x3417ac22, (q31_t)0x3ee1ec87, (q31_t)0x3424052f, (q31_t)0x3ee441da, + (q31_t)0x34305eb0, (q31_t)0x3ee694c1, (q31_t)0x343cb8a7, (q31_t)0x3ee8e53a, + (q31_t)0x34491311, (q31_t)0x3eeb3347, (q31_t)0x34556def, (q31_t)0x3eed7ee7, + (q31_t)0x3461c940, (q31_t)0x3eefc81a, (q31_t)0x346e2504, (q31_t)0x3ef20ee0, + (q31_t)0x347a8139, (q31_t)0x3ef45338, (q31_t)0x3486dde1, (q31_t)0x3ef69523, + (q31_t)0x34933afa, (q31_t)0x3ef8d4a1, (q31_t)0x349f9884, (q31_t)0x3efb11b1, + (q31_t)0x34abf67e, (q31_t)0x3efd4c54, (q31_t)0x34b854e7, (q31_t)0x3eff8489, + (q31_t)0x34c4b3c0, (q31_t)0x3f01ba50, (q31_t)0x34d11308, (q31_t)0x3f03eda9, + (q31_t)0x34dd72be, (q31_t)0x3f061e95, (q31_t)0x34e9d2e3, (q31_t)0x3f084d12, + (q31_t)0x34f63374, (q31_t)0x3f0a7921, (q31_t)0x35029473, (q31_t)0x3f0ca2c2, + (q31_t)0x350ef5de, (q31_t)0x3f0ec9f5, (q31_t)0x351b57b5, (q31_t)0x3f10eeb9, + (q31_t)0x3527b9f7, (q31_t)0x3f13110f, (q31_t)0x35341ca5, (q31_t)0x3f1530f7, + (q31_t)0x35407fbd, (q31_t)0x3f174e70, (q31_t)0x354ce33f, (q31_t)0x3f19697a, + (q31_t)0x3559472b, (q31_t)0x3f1b8215, (q31_t)0x3565ab80, (q31_t)0x3f1d9842, + (q31_t)0x3572103d, (q31_t)0x3f1fabff, (q31_t)0x357e7563, (q31_t)0x3f21bd4e, + (q31_t)0x358adaf0, (q31_t)0x3f23cc2e, (q31_t)0x359740e5, (q31_t)0x3f25d89e, + (q31_t)0x35a3a740, (q31_t)0x3f27e29f, (q31_t)0x35b00e02, (q31_t)0x3f29ea31, + (q31_t)0x35bc7529, (q31_t)0x3f2bef53, (q31_t)0x35c8dcb6, (q31_t)0x3f2df206, + (q31_t)0x35d544a7, (q31_t)0x3f2ff24a, (q31_t)0x35e1acfd, (q31_t)0x3f31f01d, + (q31_t)0x35ee15b7, (q31_t)0x3f33eb81, (q31_t)0x35fa7ed4, (q31_t)0x3f35e476, + (q31_t)0x3606e854, (q31_t)0x3f37dafa, (q31_t)0x36135237, (q31_t)0x3f39cf0e, + (q31_t)0x361fbc7b, (q31_t)0x3f3bc0b3, (q31_t)0x362c2721, (q31_t)0x3f3dafe7, + (q31_t)0x36389228, (q31_t)0x3f3f9cab, (q31_t)0x3644fd8f, (q31_t)0x3f4186ff, + (q31_t)0x36516956, (q31_t)0x3f436ee3, (q31_t)0x365dd57d, (q31_t)0x3f455456, + (q31_t)0x366a4203, (q31_t)0x3f473759, (q31_t)0x3676aee8, (q31_t)0x3f4917eb, + (q31_t)0x36831c2b, (q31_t)0x3f4af60d, (q31_t)0x368f89cb, (q31_t)0x3f4cd1be, + (q31_t)0x369bf7c9, (q31_t)0x3f4eaafe, (q31_t)0x36a86623, (q31_t)0x3f5081cd, + (q31_t)0x36b4d4d9, (q31_t)0x3f52562c, (q31_t)0x36c143ec, (q31_t)0x3f54281a, + (q31_t)0x36cdb359, (q31_t)0x3f55f796, (q31_t)0x36da2321, (q31_t)0x3f57c4a2, + (q31_t)0x36e69344, (q31_t)0x3f598f3c, (q31_t)0x36f303c0, (q31_t)0x3f5b5765, + (q31_t)0x36ff7496, (q31_t)0x3f5d1d1d, (q31_t)0x370be5c4, (q31_t)0x3f5ee063, + (q31_t)0x3718574b, (q31_t)0x3f60a138, (q31_t)0x3724c92a, (q31_t)0x3f625f9b, + (q31_t)0x37313b60, (q31_t)0x3f641b8d, (q31_t)0x373daded, (q31_t)0x3f65d50d, + (q31_t)0x374a20d0, (q31_t)0x3f678c1c, (q31_t)0x3756940a, (q31_t)0x3f6940b8, + (q31_t)0x37630799, (q31_t)0x3f6af2e3, (q31_t)0x376f7b7d, (q31_t)0x3f6ca29c, + (q31_t)0x377befb5, (q31_t)0x3f6e4fe3, (q31_t)0x37886442, (q31_t)0x3f6ffab8, + (q31_t)0x3794d922, (q31_t)0x3f71a31b, (q31_t)0x37a14e55, (q31_t)0x3f73490b, + (q31_t)0x37adc3db, (q31_t)0x3f74ec8a, (q31_t)0x37ba39b3, (q31_t)0x3f768d96, + (q31_t)0x37c6afdc, (q31_t)0x3f782c30, (q31_t)0x37d32657, (q31_t)0x3f79c857, + (q31_t)0x37df9d22, (q31_t)0x3f7b620c, (q31_t)0x37ec143e, (q31_t)0x3f7cf94e, + (q31_t)0x37f88ba9, (q31_t)0x3f7e8e1e, (q31_t)0x38050364, (q31_t)0x3f80207b, + (q31_t)0x38117b6d, (q31_t)0x3f81b065, (q31_t)0x381df3c5, (q31_t)0x3f833ddd, + (q31_t)0x382a6c6a, (q31_t)0x3f84c8e2, (q31_t)0x3836e55d, (q31_t)0x3f865174, + (q31_t)0x38435e9d, (q31_t)0x3f87d792, (q31_t)0x384fd829, (q31_t)0x3f895b3e, + (q31_t)0x385c5201, (q31_t)0x3f8adc77, (q31_t)0x3868cc24, (q31_t)0x3f8c5b3d, + (q31_t)0x38754692, (q31_t)0x3f8dd78f, (q31_t)0x3881c14b, (q31_t)0x3f8f516e, + (q31_t)0x388e3c4d, (q31_t)0x3f90c8da, (q31_t)0x389ab799, (q31_t)0x3f923dd2, + (q31_t)0x38a7332e, (q31_t)0x3f93b058, (q31_t)0x38b3af0c, (q31_t)0x3f952069, + (q31_t)0x38c02b31, (q31_t)0x3f968e07, (q31_t)0x38cca79e, (q31_t)0x3f97f932, + (q31_t)0x38d92452, (q31_t)0x3f9961e8, (q31_t)0x38e5a14d, (q31_t)0x3f9ac82c, + (q31_t)0x38f21e8e, (q31_t)0x3f9c2bfb, (q31_t)0x38fe9c15, (q31_t)0x3f9d8d56, + (q31_t)0x390b19e0, (q31_t)0x3f9eec3e, (q31_t)0x391797f0, (q31_t)0x3fa048b2, + (q31_t)0x39241645, (q31_t)0x3fa1a2b2, (q31_t)0x393094dd, (q31_t)0x3fa2fa3d, + (q31_t)0x393d13b8, (q31_t)0x3fa44f55, (q31_t)0x394992d7, (q31_t)0x3fa5a1f9, + (q31_t)0x39561237, (q31_t)0x3fa6f228, (q31_t)0x396291d9, (q31_t)0x3fa83fe3, + (q31_t)0x396f11bc, (q31_t)0x3fa98b2a, (q31_t)0x397b91e1, (q31_t)0x3faad3fd, + (q31_t)0x39881245, (q31_t)0x3fac1a5b, (q31_t)0x399492ea, (q31_t)0x3fad5e45, + (q31_t)0x39a113cd, (q31_t)0x3fae9fbb, (q31_t)0x39ad94f0, (q31_t)0x3fafdebb, + (q31_t)0x39ba1651, (q31_t)0x3fb11b48, (q31_t)0x39c697f0, (q31_t)0x3fb2555f, + (q31_t)0x39d319cc, (q31_t)0x3fb38d02, (q31_t)0x39df9be6, (q31_t)0x3fb4c231, + (q31_t)0x39ec1e3b, (q31_t)0x3fb5f4ea, (q31_t)0x39f8a0cd, (q31_t)0x3fb7252f, + (q31_t)0x3a05239a, (q31_t)0x3fb852ff, (q31_t)0x3a11a6a3, (q31_t)0x3fb97e5a, + (q31_t)0x3a1e29e5, (q31_t)0x3fbaa740, (q31_t)0x3a2aad62, (q31_t)0x3fbbcdb1, + (q31_t)0x3a373119, (q31_t)0x3fbcf1ad, (q31_t)0x3a43b508, (q31_t)0x3fbe1334, + (q31_t)0x3a503930, (q31_t)0x3fbf3246, (q31_t)0x3a5cbd91, (q31_t)0x3fc04ee3, + (q31_t)0x3a694229, (q31_t)0x3fc1690a, (q31_t)0x3a75c6f8, (q31_t)0x3fc280bc, + (q31_t)0x3a824bfd, (q31_t)0x3fc395f9, (q31_t)0x3a8ed139, (q31_t)0x3fc4a8c1, + (q31_t)0x3a9b56ab, (q31_t)0x3fc5b913, (q31_t)0x3aa7dc52, (q31_t)0x3fc6c6f0, + (q31_t)0x3ab4622d, (q31_t)0x3fc7d258, (q31_t)0x3ac0e83d, (q31_t)0x3fc8db4a, + (q31_t)0x3acd6e81, (q31_t)0x3fc9e1c6, (q31_t)0x3ad9f4f8, (q31_t)0x3fcae5cd, + (q31_t)0x3ae67ba2, (q31_t)0x3fcbe75e, (q31_t)0x3af3027e, (q31_t)0x3fcce67a, + (q31_t)0x3aff898c, (q31_t)0x3fcde320, (q31_t)0x3b0c10cb, (q31_t)0x3fcedd50, + (q31_t)0x3b18983b, (q31_t)0x3fcfd50b, (q31_t)0x3b251fdc, (q31_t)0x3fd0ca4f, + (q31_t)0x3b31a7ac, (q31_t)0x3fd1bd1e, (q31_t)0x3b3e2fac, (q31_t)0x3fd2ad77, + (q31_t)0x3b4ab7db, (q31_t)0x3fd39b5a, (q31_t)0x3b574039, (q31_t)0x3fd486c7, + (q31_t)0x3b63c8c4, (q31_t)0x3fd56fbe, (q31_t)0x3b70517d, (q31_t)0x3fd6563f, + (q31_t)0x3b7cda63, (q31_t)0x3fd73a4a, (q31_t)0x3b896375, (q31_t)0x3fd81bdf, + (q31_t)0x3b95ecb4, (q31_t)0x3fd8fafe, (q31_t)0x3ba2761e, (q31_t)0x3fd9d7a7, + (q31_t)0x3baeffb3, (q31_t)0x3fdab1d9, (q31_t)0x3bbb8973, (q31_t)0x3fdb8996, + (q31_t)0x3bc8135c, (q31_t)0x3fdc5edc, (q31_t)0x3bd49d70, (q31_t)0x3fdd31ac, + (q31_t)0x3be127ac, (q31_t)0x3fde0205, (q31_t)0x3bedb212, (q31_t)0x3fdecfe8, + (q31_t)0x3bfa3c9f, (q31_t)0x3fdf9b55, (q31_t)0x3c06c754, (q31_t)0x3fe0644b, + (q31_t)0x3c135231, (q31_t)0x3fe12acb, (q31_t)0x3c1fdd34, (q31_t)0x3fe1eed5, + (q31_t)0x3c2c685d, (q31_t)0x3fe2b067, (q31_t)0x3c38f3ac, (q31_t)0x3fe36f84, + (q31_t)0x3c457f21, (q31_t)0x3fe42c2a, (q31_t)0x3c520aba, (q31_t)0x3fe4e659, + (q31_t)0x3c5e9678, (q31_t)0x3fe59e12, (q31_t)0x3c6b2259, (q31_t)0x3fe65354, + (q31_t)0x3c77ae5e, (q31_t)0x3fe7061f, (q31_t)0x3c843a85, (q31_t)0x3fe7b674, + (q31_t)0x3c90c6cf, (q31_t)0x3fe86452, (q31_t)0x3c9d533b, (q31_t)0x3fe90fb9, + (q31_t)0x3ca9dfc8, (q31_t)0x3fe9b8a9, (q31_t)0x3cb66c77, (q31_t)0x3fea5f23, + (q31_t)0x3cc2f945, (q31_t)0x3feb0326, (q31_t)0x3ccf8634, (q31_t)0x3feba4b2, + (q31_t)0x3cdc1342, (q31_t)0x3fec43c7, (q31_t)0x3ce8a06f, (q31_t)0x3fece065, + (q31_t)0x3cf52dbb, (q31_t)0x3fed7a8c, (q31_t)0x3d01bb24, (q31_t)0x3fee123d, + (q31_t)0x3d0e48ab, (q31_t)0x3feea776, (q31_t)0x3d1ad650, (q31_t)0x3fef3a39, + (q31_t)0x3d276410, (q31_t)0x3fefca84, (q31_t)0x3d33f1ed, (q31_t)0x3ff05858, + (q31_t)0x3d407fe6, (q31_t)0x3ff0e3b6, (q31_t)0x3d4d0df9, (q31_t)0x3ff16c9c, + (q31_t)0x3d599c28, (q31_t)0x3ff1f30b, (q31_t)0x3d662a70, (q31_t)0x3ff27703, + (q31_t)0x3d72b8d2, (q31_t)0x3ff2f884, (q31_t)0x3d7f474d, (q31_t)0x3ff3778e, + (q31_t)0x3d8bd5e1, (q31_t)0x3ff3f420, (q31_t)0x3d98648d, (q31_t)0x3ff46e3c, + (q31_t)0x3da4f351, (q31_t)0x3ff4e5e0, (q31_t)0x3db1822c, (q31_t)0x3ff55b0d, + (q31_t)0x3dbe111e, (q31_t)0x3ff5cdc3, (q31_t)0x3dcaa027, (q31_t)0x3ff63e01, + (q31_t)0x3dd72f45, (q31_t)0x3ff6abc8, (q31_t)0x3de3be78, (q31_t)0x3ff71718, + (q31_t)0x3df04dc0, (q31_t)0x3ff77ff1, (q31_t)0x3dfcdd1d, (q31_t)0x3ff7e652, + (q31_t)0x3e096c8d, (q31_t)0x3ff84a3c, (q31_t)0x3e15fc11, (q31_t)0x3ff8abae, + (q31_t)0x3e228ba7, (q31_t)0x3ff90aaa, (q31_t)0x3e2f1b50, (q31_t)0x3ff9672d, + (q31_t)0x3e3bab0b, (q31_t)0x3ff9c13a, (q31_t)0x3e483ad8, (q31_t)0x3ffa18cf, + (q31_t)0x3e54cab5, (q31_t)0x3ffa6dec, (q31_t)0x3e615aa3, (q31_t)0x3ffac092, + (q31_t)0x3e6deaa1, (q31_t)0x3ffb10c1, (q31_t)0x3e7a7aae, (q31_t)0x3ffb5e78, + (q31_t)0x3e870aca, (q31_t)0x3ffba9b8, (q31_t)0x3e939af5, (q31_t)0x3ffbf280, + (q31_t)0x3ea02b2e, (q31_t)0x3ffc38d1, (q31_t)0x3eacbb74, (q31_t)0x3ffc7caa, + (q31_t)0x3eb94bc8, (q31_t)0x3ffcbe0c, (q31_t)0x3ec5dc28, (q31_t)0x3ffcfcf6, + (q31_t)0x3ed26c94, (q31_t)0x3ffd3969, (q31_t)0x3edefd0c, (q31_t)0x3ffd7364, + (q31_t)0x3eeb8d8f, (q31_t)0x3ffdaae7, (q31_t)0x3ef81e1d, (q31_t)0x3ffddff3, + (q31_t)0x3f04aeb5, (q31_t)0x3ffe1288, (q31_t)0x3f113f56, (q31_t)0x3ffe42a4, + (q31_t)0x3f1dd001, (q31_t)0x3ffe704a, (q31_t)0x3f2a60b4, (q31_t)0x3ffe9b77, + (q31_t)0x3f36f170, (q31_t)0x3ffec42d, (q31_t)0x3f438234, (q31_t)0x3ffeea6c, + (q31_t)0x3f5012fe, (q31_t)0x3fff0e32, (q31_t)0x3f5ca3d0, (q31_t)0x3fff2f82, + (q31_t)0x3f6934a8, (q31_t)0x3fff4e59, (q31_t)0x3f75c585, (q31_t)0x3fff6ab9, + (q31_t)0x3f825668, (q31_t)0x3fff84a1, (q31_t)0x3f8ee750, (q31_t)0x3fff9c12, + (q31_t)0x3f9b783c, (q31_t)0x3fffb10b, (q31_t)0x3fa8092c, (q31_t)0x3fffc38c, + (q31_t)0x3fb49a1f, (q31_t)0x3fffd396, (q31_t)0x3fc12b16, (q31_t)0x3fffe128, + (q31_t)0x3fcdbc0f, (q31_t)0x3fffec43, (q31_t)0x3fda4d09, (q31_t)0x3ffff4e6, + (q31_t)0x3fe6de05, (q31_t)0x3ffffb11, (q31_t)0x3ff36f02, (q31_t)0x3ffffec4, +}; + + +/** +* \par +* Generation of realCoefBQ31 array: +* \par +* n = 4096 +*
for (i = 0; i < n; i++)
+* {
+*    pBTable[2 * i] = 0.5 * (1.0 + sin (2 * PI / (double) (2 * n) * (double) i));
+*    pBTable[2 * i + 1] = 0.5 * (1.0 * cos (2 * PI / (double) (2 * n) * (double) i));
+* } 
+* \par +* Convert to fixed point Q31 format +* round(pBTable[i] * pow(2, 31)) +* +*/ + +const q31_t realCoefBQ31[8192] = { + (q31_t)0x40000000, (q31_t)0x40000000, (q31_t)0x400c90fe, (q31_t)0x3ffffec4, + (q31_t)0x401921fb, (q31_t)0x3ffffb11, (q31_t)0x4025b2f7, (q31_t)0x3ffff4e6, + (q31_t)0x403243f1, (q31_t)0x3fffec43, (q31_t)0x403ed4ea, (q31_t)0x3fffe128, + (q31_t)0x404b65e1, (q31_t)0x3fffd396, (q31_t)0x4057f6d4, (q31_t)0x3fffc38c, + (q31_t)0x406487c4, (q31_t)0x3fffb10b, (q31_t)0x407118b0, (q31_t)0x3fff9c12, + (q31_t)0x407da998, (q31_t)0x3fff84a1, (q31_t)0x408a3a7b, (q31_t)0x3fff6ab9, + (q31_t)0x4096cb58, (q31_t)0x3fff4e59, (q31_t)0x40a35c30, (q31_t)0x3fff2f82, + (q31_t)0x40afed02, (q31_t)0x3fff0e32, (q31_t)0x40bc7dcc, (q31_t)0x3ffeea6c, + (q31_t)0x40c90e90, (q31_t)0x3ffec42d, (q31_t)0x40d59f4c, (q31_t)0x3ffe9b77, + (q31_t)0x40e22fff, (q31_t)0x3ffe704a, (q31_t)0x40eec0aa, (q31_t)0x3ffe42a4, + (q31_t)0x40fb514b, (q31_t)0x3ffe1288, (q31_t)0x4107e1e3, (q31_t)0x3ffddff3, + (q31_t)0x41147271, (q31_t)0x3ffdaae7, (q31_t)0x412102f4, (q31_t)0x3ffd7364, + (q31_t)0x412d936c, (q31_t)0x3ffd3969, (q31_t)0x413a23d8, (q31_t)0x3ffcfcf6, + (q31_t)0x4146b438, (q31_t)0x3ffcbe0c, (q31_t)0x4153448c, (q31_t)0x3ffc7caa, + (q31_t)0x415fd4d2, (q31_t)0x3ffc38d1, (q31_t)0x416c650b, (q31_t)0x3ffbf280, + (q31_t)0x4178f536, (q31_t)0x3ffba9b8, (q31_t)0x41858552, (q31_t)0x3ffb5e78, + (q31_t)0x4192155f, (q31_t)0x3ffb10c1, (q31_t)0x419ea55d, (q31_t)0x3ffac092, + (q31_t)0x41ab354b, (q31_t)0x3ffa6dec, (q31_t)0x41b7c528, (q31_t)0x3ffa18cf, + (q31_t)0x41c454f5, (q31_t)0x3ff9c13a, (q31_t)0x41d0e4b0, (q31_t)0x3ff9672d, + (q31_t)0x41dd7459, (q31_t)0x3ff90aaa, (q31_t)0x41ea03ef, (q31_t)0x3ff8abae, + (q31_t)0x41f69373, (q31_t)0x3ff84a3c, (q31_t)0x420322e3, (q31_t)0x3ff7e652, + (q31_t)0x420fb240, (q31_t)0x3ff77ff1, (q31_t)0x421c4188, (q31_t)0x3ff71718, + (q31_t)0x4228d0bb, (q31_t)0x3ff6abc8, (q31_t)0x42355fd9, (q31_t)0x3ff63e01, + (q31_t)0x4241eee2, (q31_t)0x3ff5cdc3, (q31_t)0x424e7dd4, (q31_t)0x3ff55b0d, + (q31_t)0x425b0caf, (q31_t)0x3ff4e5e0, (q31_t)0x42679b73, (q31_t)0x3ff46e3c, + (q31_t)0x42742a1f, (q31_t)0x3ff3f420, (q31_t)0x4280b8b3, (q31_t)0x3ff3778e, + (q31_t)0x428d472e, (q31_t)0x3ff2f884, (q31_t)0x4299d590, (q31_t)0x3ff27703, + (q31_t)0x42a663d8, (q31_t)0x3ff1f30b, (q31_t)0x42b2f207, (q31_t)0x3ff16c9c, + (q31_t)0x42bf801a, (q31_t)0x3ff0e3b6, (q31_t)0x42cc0e13, (q31_t)0x3ff05858, + (q31_t)0x42d89bf0, (q31_t)0x3fefca84, (q31_t)0x42e529b0, (q31_t)0x3fef3a39, + (q31_t)0x42f1b755, (q31_t)0x3feea776, (q31_t)0x42fe44dc, (q31_t)0x3fee123d, + (q31_t)0x430ad245, (q31_t)0x3fed7a8c, (q31_t)0x43175f91, (q31_t)0x3fece065, + (q31_t)0x4323ecbe, (q31_t)0x3fec43c7, (q31_t)0x433079cc, (q31_t)0x3feba4b2, + (q31_t)0x433d06bb, (q31_t)0x3feb0326, (q31_t)0x43499389, (q31_t)0x3fea5f23, + (q31_t)0x43562038, (q31_t)0x3fe9b8a9, (q31_t)0x4362acc5, (q31_t)0x3fe90fb9, + (q31_t)0x436f3931, (q31_t)0x3fe86452, (q31_t)0x437bc57b, (q31_t)0x3fe7b674, + (q31_t)0x438851a2, (q31_t)0x3fe7061f, (q31_t)0x4394dda7, (q31_t)0x3fe65354, + (q31_t)0x43a16988, (q31_t)0x3fe59e12, (q31_t)0x43adf546, (q31_t)0x3fe4e659, + (q31_t)0x43ba80df, (q31_t)0x3fe42c2a, (q31_t)0x43c70c54, (q31_t)0x3fe36f84, + (q31_t)0x43d397a3, (q31_t)0x3fe2b067, (q31_t)0x43e022cc, (q31_t)0x3fe1eed5, + (q31_t)0x43ecadcf, (q31_t)0x3fe12acb, (q31_t)0x43f938ac, (q31_t)0x3fe0644b, + (q31_t)0x4405c361, (q31_t)0x3fdf9b55, (q31_t)0x44124dee, (q31_t)0x3fdecfe8, + (q31_t)0x441ed854, (q31_t)0x3fde0205, (q31_t)0x442b6290, (q31_t)0x3fdd31ac, + (q31_t)0x4437eca4, (q31_t)0x3fdc5edc, (q31_t)0x4444768d, (q31_t)0x3fdb8996, + (q31_t)0x4451004d, (q31_t)0x3fdab1d9, (q31_t)0x445d89e2, (q31_t)0x3fd9d7a7, + (q31_t)0x446a134c, (q31_t)0x3fd8fafe, (q31_t)0x44769c8b, (q31_t)0x3fd81bdf, + (q31_t)0x4483259d, (q31_t)0x3fd73a4a, (q31_t)0x448fae83, (q31_t)0x3fd6563f, + (q31_t)0x449c373c, (q31_t)0x3fd56fbe, (q31_t)0x44a8bfc7, (q31_t)0x3fd486c7, + (q31_t)0x44b54825, (q31_t)0x3fd39b5a, (q31_t)0x44c1d054, (q31_t)0x3fd2ad77, + (q31_t)0x44ce5854, (q31_t)0x3fd1bd1e, (q31_t)0x44dae024, (q31_t)0x3fd0ca4f, + (q31_t)0x44e767c5, (q31_t)0x3fcfd50b, (q31_t)0x44f3ef35, (q31_t)0x3fcedd50, + (q31_t)0x45007674, (q31_t)0x3fcde320, (q31_t)0x450cfd82, (q31_t)0x3fcce67a, + (q31_t)0x4519845e, (q31_t)0x3fcbe75e, (q31_t)0x45260b08, (q31_t)0x3fcae5cd, + (q31_t)0x4532917f, (q31_t)0x3fc9e1c6, (q31_t)0x453f17c3, (q31_t)0x3fc8db4a, + (q31_t)0x454b9dd3, (q31_t)0x3fc7d258, (q31_t)0x455823ae, (q31_t)0x3fc6c6f0, + (q31_t)0x4564a955, (q31_t)0x3fc5b913, (q31_t)0x45712ec7, (q31_t)0x3fc4a8c1, + (q31_t)0x457db403, (q31_t)0x3fc395f9, (q31_t)0x458a3908, (q31_t)0x3fc280bc, + (q31_t)0x4596bdd7, (q31_t)0x3fc1690a, (q31_t)0x45a3426f, (q31_t)0x3fc04ee3, + (q31_t)0x45afc6d0, (q31_t)0x3fbf3246, (q31_t)0x45bc4af8, (q31_t)0x3fbe1334, + (q31_t)0x45c8cee7, (q31_t)0x3fbcf1ad, (q31_t)0x45d5529e, (q31_t)0x3fbbcdb1, + (q31_t)0x45e1d61b, (q31_t)0x3fbaa740, (q31_t)0x45ee595d, (q31_t)0x3fb97e5a, + (q31_t)0x45fadc66, (q31_t)0x3fb852ff, (q31_t)0x46075f33, (q31_t)0x3fb7252f, + (q31_t)0x4613e1c5, (q31_t)0x3fb5f4ea, (q31_t)0x4620641a, (q31_t)0x3fb4c231, + (q31_t)0x462ce634, (q31_t)0x3fb38d02, (q31_t)0x46396810, (q31_t)0x3fb2555f, + (q31_t)0x4645e9af, (q31_t)0x3fb11b48, (q31_t)0x46526b10, (q31_t)0x3fafdebb, + (q31_t)0x465eec33, (q31_t)0x3fae9fbb, (q31_t)0x466b6d16, (q31_t)0x3fad5e45, + (q31_t)0x4677edbb, (q31_t)0x3fac1a5b, (q31_t)0x46846e1f, (q31_t)0x3faad3fd, + (q31_t)0x4690ee44, (q31_t)0x3fa98b2a, (q31_t)0x469d6e27, (q31_t)0x3fa83fe3, + (q31_t)0x46a9edc9, (q31_t)0x3fa6f228, (q31_t)0x46b66d29, (q31_t)0x3fa5a1f9, + (q31_t)0x46c2ec48, (q31_t)0x3fa44f55, (q31_t)0x46cf6b23, (q31_t)0x3fa2fa3d, + (q31_t)0x46dbe9bb, (q31_t)0x3fa1a2b2, (q31_t)0x46e86810, (q31_t)0x3fa048b2, + (q31_t)0x46f4e620, (q31_t)0x3f9eec3e, (q31_t)0x470163eb, (q31_t)0x3f9d8d56, + (q31_t)0x470de172, (q31_t)0x3f9c2bfb, (q31_t)0x471a5eb3, (q31_t)0x3f9ac82c, + (q31_t)0x4726dbae, (q31_t)0x3f9961e8, (q31_t)0x47335862, (q31_t)0x3f97f932, + (q31_t)0x473fd4cf, (q31_t)0x3f968e07, (q31_t)0x474c50f4, (q31_t)0x3f952069, + (q31_t)0x4758ccd2, (q31_t)0x3f93b058, (q31_t)0x47654867, (q31_t)0x3f923dd2, + (q31_t)0x4771c3b3, (q31_t)0x3f90c8da, (q31_t)0x477e3eb5, (q31_t)0x3f8f516e, + (q31_t)0x478ab96e, (q31_t)0x3f8dd78f, (q31_t)0x479733dc, (q31_t)0x3f8c5b3d, + (q31_t)0x47a3adff, (q31_t)0x3f8adc77, (q31_t)0x47b027d7, (q31_t)0x3f895b3e, + (q31_t)0x47bca163, (q31_t)0x3f87d792, (q31_t)0x47c91aa3, (q31_t)0x3f865174, + (q31_t)0x47d59396, (q31_t)0x3f84c8e2, (q31_t)0x47e20c3b, (q31_t)0x3f833ddd, + (q31_t)0x47ee8493, (q31_t)0x3f81b065, (q31_t)0x47fafc9c, (q31_t)0x3f80207b, + (q31_t)0x48077457, (q31_t)0x3f7e8e1e, (q31_t)0x4813ebc2, (q31_t)0x3f7cf94e, + (q31_t)0x482062de, (q31_t)0x3f7b620c, (q31_t)0x482cd9a9, (q31_t)0x3f79c857, + (q31_t)0x48395024, (q31_t)0x3f782c30, (q31_t)0x4845c64d, (q31_t)0x3f768d96, + (q31_t)0x48523c25, (q31_t)0x3f74ec8a, (q31_t)0x485eb1ab, (q31_t)0x3f73490b, + (q31_t)0x486b26de, (q31_t)0x3f71a31b, (q31_t)0x48779bbe, (q31_t)0x3f6ffab8, + (q31_t)0x4884104b, (q31_t)0x3f6e4fe3, (q31_t)0x48908483, (q31_t)0x3f6ca29c, + (q31_t)0x489cf867, (q31_t)0x3f6af2e3, (q31_t)0x48a96bf6, (q31_t)0x3f6940b8, + (q31_t)0x48b5df30, (q31_t)0x3f678c1c, (q31_t)0x48c25213, (q31_t)0x3f65d50d, + (q31_t)0x48cec4a0, (q31_t)0x3f641b8d, (q31_t)0x48db36d6, (q31_t)0x3f625f9b, + (q31_t)0x48e7a8b5, (q31_t)0x3f60a138, (q31_t)0x48f41a3c, (q31_t)0x3f5ee063, + (q31_t)0x49008b6a, (q31_t)0x3f5d1d1d, (q31_t)0x490cfc40, (q31_t)0x3f5b5765, + (q31_t)0x49196cbc, (q31_t)0x3f598f3c, (q31_t)0x4925dcdf, (q31_t)0x3f57c4a2, + (q31_t)0x49324ca7, (q31_t)0x3f55f796, (q31_t)0x493ebc14, (q31_t)0x3f54281a, + (q31_t)0x494b2b27, (q31_t)0x3f52562c, (q31_t)0x495799dd, (q31_t)0x3f5081cd, + (q31_t)0x49640837, (q31_t)0x3f4eaafe, (q31_t)0x49707635, (q31_t)0x3f4cd1be, + (q31_t)0x497ce3d5, (q31_t)0x3f4af60d, (q31_t)0x49895118, (q31_t)0x3f4917eb, + (q31_t)0x4995bdfd, (q31_t)0x3f473759, (q31_t)0x49a22a83, (q31_t)0x3f455456, + (q31_t)0x49ae96aa, (q31_t)0x3f436ee3, (q31_t)0x49bb0271, (q31_t)0x3f4186ff, + (q31_t)0x49c76dd8, (q31_t)0x3f3f9cab, (q31_t)0x49d3d8df, (q31_t)0x3f3dafe7, + (q31_t)0x49e04385, (q31_t)0x3f3bc0b3, (q31_t)0x49ecadc9, (q31_t)0x3f39cf0e, + (q31_t)0x49f917ac, (q31_t)0x3f37dafa, (q31_t)0x4a05812c, (q31_t)0x3f35e476, + (q31_t)0x4a11ea49, (q31_t)0x3f33eb81, (q31_t)0x4a1e5303, (q31_t)0x3f31f01d, + (q31_t)0x4a2abb59, (q31_t)0x3f2ff24a, (q31_t)0x4a37234a, (q31_t)0x3f2df206, + (q31_t)0x4a438ad7, (q31_t)0x3f2bef53, (q31_t)0x4a4ff1fe, (q31_t)0x3f29ea31, + (q31_t)0x4a5c58c0, (q31_t)0x3f27e29f, (q31_t)0x4a68bf1b, (q31_t)0x3f25d89e, + (q31_t)0x4a752510, (q31_t)0x3f23cc2e, (q31_t)0x4a818a9d, (q31_t)0x3f21bd4e, + (q31_t)0x4a8defc3, (q31_t)0x3f1fabff, (q31_t)0x4a9a5480, (q31_t)0x3f1d9842, + (q31_t)0x4aa6b8d5, (q31_t)0x3f1b8215, (q31_t)0x4ab31cc1, (q31_t)0x3f19697a, + (q31_t)0x4abf8043, (q31_t)0x3f174e70, (q31_t)0x4acbe35b, (q31_t)0x3f1530f7, + (q31_t)0x4ad84609, (q31_t)0x3f13110f, (q31_t)0x4ae4a84b, (q31_t)0x3f10eeb9, + (q31_t)0x4af10a22, (q31_t)0x3f0ec9f5, (q31_t)0x4afd6b8d, (q31_t)0x3f0ca2c2, + (q31_t)0x4b09cc8c, (q31_t)0x3f0a7921, (q31_t)0x4b162d1d, (q31_t)0x3f084d12, + (q31_t)0x4b228d42, (q31_t)0x3f061e95, (q31_t)0x4b2eecf8, (q31_t)0x3f03eda9, + (q31_t)0x4b3b4c40, (q31_t)0x3f01ba50, (q31_t)0x4b47ab19, (q31_t)0x3eff8489, + (q31_t)0x4b540982, (q31_t)0x3efd4c54, (q31_t)0x4b60677c, (q31_t)0x3efb11b1, + (q31_t)0x4b6cc506, (q31_t)0x3ef8d4a1, (q31_t)0x4b79221f, (q31_t)0x3ef69523, + (q31_t)0x4b857ec7, (q31_t)0x3ef45338, (q31_t)0x4b91dafc, (q31_t)0x3ef20ee0, + (q31_t)0x4b9e36c0, (q31_t)0x3eefc81a, (q31_t)0x4baa9211, (q31_t)0x3eed7ee7, + (q31_t)0x4bb6ecef, (q31_t)0x3eeb3347, (q31_t)0x4bc34759, (q31_t)0x3ee8e53a, + (q31_t)0x4bcfa150, (q31_t)0x3ee694c1, (q31_t)0x4bdbfad1, (q31_t)0x3ee441da, + (q31_t)0x4be853de, (q31_t)0x3ee1ec87, (q31_t)0x4bf4ac75, (q31_t)0x3edf94c7, + (q31_t)0x4c010496, (q31_t)0x3edd3a9a, (q31_t)0x4c0d5c41, (q31_t)0x3edade01, + (q31_t)0x4c19b374, (q31_t)0x3ed87efc, (q31_t)0x4c260a31, (q31_t)0x3ed61d8a, + (q31_t)0x4c326075, (q31_t)0x3ed3b9ad, (q31_t)0x4c3eb641, (q31_t)0x3ed15363, + (q31_t)0x4c4b0b94, (q31_t)0x3eceeaad, (q31_t)0x4c57606e, (q31_t)0x3ecc7f8b, + (q31_t)0x4c63b4ce, (q31_t)0x3eca11fe, (q31_t)0x4c7008b3, (q31_t)0x3ec7a205, + (q31_t)0x4c7c5c1e, (q31_t)0x3ec52fa0, (q31_t)0x4c88af0e, (q31_t)0x3ec2bad0, + (q31_t)0x4c950182, (q31_t)0x3ec04394, (q31_t)0x4ca1537a, (q31_t)0x3ebdc9ed, + (q31_t)0x4cada4f5, (q31_t)0x3ebb4ddb, (q31_t)0x4cb9f5f3, (q31_t)0x3eb8cf5d, + (q31_t)0x4cc64673, (q31_t)0x3eb64e75, (q31_t)0x4cd29676, (q31_t)0x3eb3cb21, + (q31_t)0x4cdee5f9, (q31_t)0x3eb14563, (q31_t)0x4ceb34fe, (q31_t)0x3eaebd3a, + (q31_t)0x4cf78383, (q31_t)0x3eac32a6, (q31_t)0x4d03d189, (q31_t)0x3ea9a5a8, + (q31_t)0x4d101f0e, (q31_t)0x3ea7163f, (q31_t)0x4d1c6c11, (q31_t)0x3ea4846c, + (q31_t)0x4d28b894, (q31_t)0x3ea1f02f, (q31_t)0x4d350495, (q31_t)0x3e9f5988, + (q31_t)0x4d415013, (q31_t)0x3e9cc076, (q31_t)0x4d4d9b0e, (q31_t)0x3e9a24fb, + (q31_t)0x4d59e586, (q31_t)0x3e978715, (q31_t)0x4d662f7b, (q31_t)0x3e94e6c6, + (q31_t)0x4d7278eb, (q31_t)0x3e92440d, (q31_t)0x4d7ec1d6, (q31_t)0x3e8f9eeb, + (q31_t)0x4d8b0a3d, (q31_t)0x3e8cf75f, (q31_t)0x4d97521d, (q31_t)0x3e8a4d6a, + (q31_t)0x4da39978, (q31_t)0x3e87a10c, (q31_t)0x4dafe04b, (q31_t)0x3e84f245, + (q31_t)0x4dbc2698, (q31_t)0x3e824114, (q31_t)0x4dc86c5d, (q31_t)0x3e7f8d7b, + (q31_t)0x4dd4b19a, (q31_t)0x3e7cd778, (q31_t)0x4de0f64f, (q31_t)0x3e7a1f0d, + (q31_t)0x4ded3a7b, (q31_t)0x3e77643a, (q31_t)0x4df97e1d, (q31_t)0x3e74a6fd, + (q31_t)0x4e05c135, (q31_t)0x3e71e759, (q31_t)0x4e1203c3, (q31_t)0x3e6f254c, + (q31_t)0x4e1e45c6, (q31_t)0x3e6c60d7, (q31_t)0x4e2a873e, (q31_t)0x3e6999fa, + (q31_t)0x4e36c82a, (q31_t)0x3e66d0b4, (q31_t)0x4e430889, (q31_t)0x3e640507, + (q31_t)0x4e4f485c, (q31_t)0x3e6136f3, (q31_t)0x4e5b87a2, (q31_t)0x3e5e6676, + (q31_t)0x4e67c65a, (q31_t)0x3e5b9392, (q31_t)0x4e740483, (q31_t)0x3e58be47, + (q31_t)0x4e80421e, (q31_t)0x3e55e694, (q31_t)0x4e8c7f2a, (q31_t)0x3e530c7a, + (q31_t)0x4e98bba7, (q31_t)0x3e502ff9, (q31_t)0x4ea4f793, (q31_t)0x3e4d5110, + (q31_t)0x4eb132ef, (q31_t)0x3e4a6fc1, (q31_t)0x4ebd6db9, (q31_t)0x3e478c0b, + (q31_t)0x4ec9a7f3, (q31_t)0x3e44a5ef, (q31_t)0x4ed5e19a, (q31_t)0x3e41bd6c, + (q31_t)0x4ee21aaf, (q31_t)0x3e3ed282, (q31_t)0x4eee5331, (q31_t)0x3e3be532, + (q31_t)0x4efa8b20, (q31_t)0x3e38f57c, (q31_t)0x4f06c27a, (q31_t)0x3e360360, + (q31_t)0x4f12f941, (q31_t)0x3e330ede, (q31_t)0x4f1f2f73, (q31_t)0x3e3017f6, + (q31_t)0x4f2b650f, (q31_t)0x3e2d1ea8, (q31_t)0x4f379a16, (q31_t)0x3e2a22f4, + (q31_t)0x4f43ce86, (q31_t)0x3e2724db, (q31_t)0x4f500260, (q31_t)0x3e24245d, + (q31_t)0x4f5c35a3, (q31_t)0x3e212179, (q31_t)0x4f68684e, (q31_t)0x3e1e1c30, + (q31_t)0x4f749a61, (q31_t)0x3e1b1482, (q31_t)0x4f80cbdc, (q31_t)0x3e180a6f, + (q31_t)0x4f8cfcbe, (q31_t)0x3e14fdf7, (q31_t)0x4f992d06, (q31_t)0x3e11ef1b, + (q31_t)0x4fa55cb4, (q31_t)0x3e0eddd9, (q31_t)0x4fb18bc8, (q31_t)0x3e0bca34, + (q31_t)0x4fbdba40, (q31_t)0x3e08b42a, (q31_t)0x4fc9e81e, (q31_t)0x3e059bbb, + (q31_t)0x4fd6155f, (q31_t)0x3e0280e9, (q31_t)0x4fe24205, (q31_t)0x3dff63b2, + (q31_t)0x4fee6e0d, (q31_t)0x3dfc4418, (q31_t)0x4ffa9979, (q31_t)0x3df9221a, + (q31_t)0x5006c446, (q31_t)0x3df5fdb8, (q31_t)0x5012ee76, (q31_t)0x3df2d6f3, + (q31_t)0x501f1807, (q31_t)0x3defadca, (q31_t)0x502b40f8, (q31_t)0x3dec823e, + (q31_t)0x5037694b, (q31_t)0x3de9544f, (q31_t)0x504390fd, (q31_t)0x3de623fd, + (q31_t)0x504fb80e, (q31_t)0x3de2f148, (q31_t)0x505bde7f, (q31_t)0x3ddfbc30, + (q31_t)0x5068044e, (q31_t)0x3ddc84b5, (q31_t)0x5074297b, (q31_t)0x3dd94ad8, + (q31_t)0x50804e06, (q31_t)0x3dd60e99, (q31_t)0x508c71ee, (q31_t)0x3dd2cff7, + (q31_t)0x50989532, (q31_t)0x3dcf8ef3, (q31_t)0x50a4b7d3, (q31_t)0x3dcc4b8d, + (q31_t)0x50b0d9d0, (q31_t)0x3dc905c5, (q31_t)0x50bcfb28, (q31_t)0x3dc5bd9b, + (q31_t)0x50c91bda, (q31_t)0x3dc2730f, (q31_t)0x50d53be7, (q31_t)0x3dbf2622, + (q31_t)0x50e15b4e, (q31_t)0x3dbbd6d4, (q31_t)0x50ed7a0e, (q31_t)0x3db88524, + (q31_t)0x50f99827, (q31_t)0x3db53113, (q31_t)0x5105b599, (q31_t)0x3db1daa2, + (q31_t)0x5111d263, (q31_t)0x3dae81cf, (q31_t)0x511dee84, (q31_t)0x3dab269b, + (q31_t)0x512a09fc, (q31_t)0x3da7c907, (q31_t)0x513624cb, (q31_t)0x3da46912, + (q31_t)0x51423ef0, (q31_t)0x3da106bd, (q31_t)0x514e586a, (q31_t)0x3d9da208, + (q31_t)0x515a713a, (q31_t)0x3d9a3af2, (q31_t)0x5166895f, (q31_t)0x3d96d17d, + (q31_t)0x5172a0d7, (q31_t)0x3d9365a8, (q31_t)0x517eb7a4, (q31_t)0x3d8ff772, + (q31_t)0x518acdc4, (q31_t)0x3d8c86de, (q31_t)0x5196e337, (q31_t)0x3d8913ea, + (q31_t)0x51a2f7fc, (q31_t)0x3d859e96, (q31_t)0x51af0c13, (q31_t)0x3d8226e4, + (q31_t)0x51bb1f7c, (q31_t)0x3d7eacd2, (q31_t)0x51c73235, (q31_t)0x3d7b3061, + (q31_t)0x51d3443f, (q31_t)0x3d77b192, (q31_t)0x51df5599, (q31_t)0x3d743064, + (q31_t)0x51eb6643, (q31_t)0x3d70acd7, (q31_t)0x51f7763c, (q31_t)0x3d6d26ec, + (q31_t)0x52038584, (q31_t)0x3d699ea3, (q31_t)0x520f941a, (q31_t)0x3d6613fb, + (q31_t)0x521ba1fd, (q31_t)0x3d6286f6, (q31_t)0x5227af2e, (q31_t)0x3d5ef793, + (q31_t)0x5233bbac, (q31_t)0x3d5b65d2, (q31_t)0x523fc776, (q31_t)0x3d57d1b3, + (q31_t)0x524bd28c, (q31_t)0x3d543b37, (q31_t)0x5257dced, (q31_t)0x3d50a25e, + (q31_t)0x5263e699, (q31_t)0x3d4d0728, (q31_t)0x526fef90, (q31_t)0x3d496994, + (q31_t)0x527bf7d1, (q31_t)0x3d45c9a4, (q31_t)0x5287ff5b, (q31_t)0x3d422757, + (q31_t)0x5294062f, (q31_t)0x3d3e82ae, (q31_t)0x52a00c4b, (q31_t)0x3d3adba7, + (q31_t)0x52ac11af, (q31_t)0x3d373245, (q31_t)0x52b8165b, (q31_t)0x3d338687, + (q31_t)0x52c41a4f, (q31_t)0x3d2fd86c, (q31_t)0x52d01d89, (q31_t)0x3d2c27f6, + (q31_t)0x52dc2009, (q31_t)0x3d287523, (q31_t)0x52e821cf, (q31_t)0x3d24bff6, + (q31_t)0x52f422db, (q31_t)0x3d21086c, (q31_t)0x5300232c, (q31_t)0x3d1d4e88, + (q31_t)0x530c22c1, (q31_t)0x3d199248, (q31_t)0x5318219a, (q31_t)0x3d15d3ad, + (q31_t)0x53241fb6, (q31_t)0x3d1212b7, (q31_t)0x53301d16, (q31_t)0x3d0e4f67, + (q31_t)0x533c19b8, (q31_t)0x3d0a89bc, (q31_t)0x5348159d, (q31_t)0x3d06c1b6, + (q31_t)0x535410c3, (q31_t)0x3d02f757, (q31_t)0x53600b2a, (q31_t)0x3cff2a9d, + (q31_t)0x536c04d2, (q31_t)0x3cfb5b89, (q31_t)0x5377fdbb, (q31_t)0x3cf78a1b, + (q31_t)0x5383f5e3, (q31_t)0x3cf3b653, (q31_t)0x538fed4b, (q31_t)0x3cefe032, + (q31_t)0x539be3f2, (q31_t)0x3cec07b8, (q31_t)0x53a7d9d7, (q31_t)0x3ce82ce4, + (q31_t)0x53b3cefa, (q31_t)0x3ce44fb7, (q31_t)0x53bfc35b, (q31_t)0x3ce07031, + (q31_t)0x53cbb6f8, (q31_t)0x3cdc8e52, (q31_t)0x53d7a9d3, (q31_t)0x3cd8aa1b, + (q31_t)0x53e39be9, (q31_t)0x3cd4c38b, (q31_t)0x53ef8d3c, (q31_t)0x3cd0daa2, + (q31_t)0x53fb7dc9, (q31_t)0x3cccef62, (q31_t)0x54076d91, (q31_t)0x3cc901c9, + (q31_t)0x54135c94, (q31_t)0x3cc511d9, (q31_t)0x541f4ad1, (q31_t)0x3cc11f90, + (q31_t)0x542b3846, (q31_t)0x3cbd2af0, (q31_t)0x543724f5, (q31_t)0x3cb933f9, + (q31_t)0x544310dd, (q31_t)0x3cb53aaa, (q31_t)0x544efbfc, (q31_t)0x3cb13f04, + (q31_t)0x545ae653, (q31_t)0x3cad4107, (q31_t)0x5466cfe1, (q31_t)0x3ca940b3, + (q31_t)0x5472b8a5, (q31_t)0x3ca53e09, (q31_t)0x547ea0a0, (q31_t)0x3ca13908, + (q31_t)0x548a87d1, (q31_t)0x3c9d31b0, (q31_t)0x54966e36, (q31_t)0x3c992803, + (q31_t)0x54a253d1, (q31_t)0x3c951bff, (q31_t)0x54ae38a0, (q31_t)0x3c910da5, + (q31_t)0x54ba1ca3, (q31_t)0x3c8cfcf6, (q31_t)0x54c5ffd9, (q31_t)0x3c88e9f1, + (q31_t)0x54d1e242, (q31_t)0x3c84d496, (q31_t)0x54ddc3de, (q31_t)0x3c80bce7, + (q31_t)0x54e9a4ac, (q31_t)0x3c7ca2e2, (q31_t)0x54f584ac, (q31_t)0x3c788688, + (q31_t)0x550163dc, (q31_t)0x3c7467d9, (q31_t)0x550d423d, (q31_t)0x3c7046d6, + (q31_t)0x55191fcf, (q31_t)0x3c6c237e, (q31_t)0x5524fc90, (q31_t)0x3c67fdd1, + (q31_t)0x5530d881, (q31_t)0x3c63d5d1, (q31_t)0x553cb3a0, (q31_t)0x3c5fab7c, + (q31_t)0x55488dee, (q31_t)0x3c5b7ed4, (q31_t)0x5554676a, (q31_t)0x3c574fd8, + (q31_t)0x55604013, (q31_t)0x3c531e88, (q31_t)0x556c17e9, (q31_t)0x3c4eeae5, + (q31_t)0x5577eeec, (q31_t)0x3c4ab4ef, (q31_t)0x5583c51b, (q31_t)0x3c467ca6, + (q31_t)0x558f9a76, (q31_t)0x3c42420a, (q31_t)0x559b6efb, (q31_t)0x3c3e051b, + (q31_t)0x55a742ac, (q31_t)0x3c39c5da, (q31_t)0x55b31587, (q31_t)0x3c358446, + (q31_t)0x55bee78c, (q31_t)0x3c314060, (q31_t)0x55cab8ba, (q31_t)0x3c2cfa28, + (q31_t)0x55d68911, (q31_t)0x3c28b19e, (q31_t)0x55e25890, (q31_t)0x3c2466c2, + (q31_t)0x55ee2738, (q31_t)0x3c201994, (q31_t)0x55f9f507, (q31_t)0x3c1bca16, + (q31_t)0x5605c1fd, (q31_t)0x3c177845, (q31_t)0x56118e1a, (q31_t)0x3c132424, + (q31_t)0x561d595d, (q31_t)0x3c0ecdb2, (q31_t)0x562923c5, (q31_t)0x3c0a74f0, + (q31_t)0x5634ed53, (q31_t)0x3c0619dc, (q31_t)0x5640b606, (q31_t)0x3c01bc78, + (q31_t)0x564c7ddd, (q31_t)0x3bfd5cc4, (q31_t)0x565844d8, (q31_t)0x3bf8fac0, + (q31_t)0x56640af7, (q31_t)0x3bf4966c, (q31_t)0x566fd039, (q31_t)0x3bf02fc9, + (q31_t)0x567b949d, (q31_t)0x3bebc6d5, (q31_t)0x56875823, (q31_t)0x3be75b93, + (q31_t)0x56931acb, (q31_t)0x3be2ee01, (q31_t)0x569edc94, (q31_t)0x3bde7e20, + (q31_t)0x56aa9d7e, (q31_t)0x3bda0bf0, (q31_t)0x56b65d88, (q31_t)0x3bd59771, + (q31_t)0x56c21cb2, (q31_t)0x3bd120a4, (q31_t)0x56cddafb, (q31_t)0x3bcca789, + (q31_t)0x56d99864, (q31_t)0x3bc82c1f, (q31_t)0x56e554ea, (q31_t)0x3bc3ae67, + (q31_t)0x56f1108f, (q31_t)0x3bbf2e62, (q31_t)0x56fccb51, (q31_t)0x3bbaac0e, + (q31_t)0x57088531, (q31_t)0x3bb6276e, (q31_t)0x57143e2d, (q31_t)0x3bb1a080, + (q31_t)0x571ff646, (q31_t)0x3bad1744, (q31_t)0x572bad7a, (q31_t)0x3ba88bbc, + (q31_t)0x573763c9, (q31_t)0x3ba3fde7, (q31_t)0x57431933, (q31_t)0x3b9f6dc5, + (q31_t)0x574ecdb8, (q31_t)0x3b9adb57, (q31_t)0x575a8157, (q31_t)0x3b96469d, + (q31_t)0x5766340f, (q31_t)0x3b91af97, (q31_t)0x5771e5e0, (q31_t)0x3b8d1644, + (q31_t)0x577d96ca, (q31_t)0x3b887aa6, (q31_t)0x578946cc, (q31_t)0x3b83dcbc, + (q31_t)0x5794f5e6, (q31_t)0x3b7f3c87, (q31_t)0x57a0a417, (q31_t)0x3b7a9a07, + (q31_t)0x57ac515f, (q31_t)0x3b75f53c, (q31_t)0x57b7fdbd, (q31_t)0x3b714e25, + (q31_t)0x57c3a931, (q31_t)0x3b6ca4c4, (q31_t)0x57cf53bb, (q31_t)0x3b67f919, + (q31_t)0x57dafd59, (q31_t)0x3b634b23, (q31_t)0x57e6a60c, (q31_t)0x3b5e9ae4, + (q31_t)0x57f24dd3, (q31_t)0x3b59e85a, (q31_t)0x57fdf4ae, (q31_t)0x3b553386, + (q31_t)0x58099a9c, (q31_t)0x3b507c69, (q31_t)0x58153f9d, (q31_t)0x3b4bc303, + (q31_t)0x5820e3b0, (q31_t)0x3b470753, (q31_t)0x582c86d5, (q31_t)0x3b42495a, + (q31_t)0x5838290c, (q31_t)0x3b3d8918, (q31_t)0x5843ca53, (q31_t)0x3b38c68e, + (q31_t)0x584f6aab, (q31_t)0x3b3401bb, (q31_t)0x585b0a13, (q31_t)0x3b2f3aa0, + (q31_t)0x5866a88a, (q31_t)0x3b2a713d, (q31_t)0x58724611, (q31_t)0x3b25a591, + (q31_t)0x587de2a7, (q31_t)0x3b20d79e, (q31_t)0x58897e4a, (q31_t)0x3b1c0764, + (q31_t)0x589518fc, (q31_t)0x3b1734e2, (q31_t)0x58a0b2bb, (q31_t)0x3b126019, + (q31_t)0x58ac4b87, (q31_t)0x3b0d8909, (q31_t)0x58b7e35f, (q31_t)0x3b08afb2, + (q31_t)0x58c37a44, (q31_t)0x3b03d414, (q31_t)0x58cf1034, (q31_t)0x3afef630, + (q31_t)0x58daa52f, (q31_t)0x3afa1605, (q31_t)0x58e63935, (q31_t)0x3af53395, + (q31_t)0x58f1cc45, (q31_t)0x3af04edf, (q31_t)0x58fd5e5f, (q31_t)0x3aeb67e3, + (q31_t)0x5908ef82, (q31_t)0x3ae67ea1, (q31_t)0x59147fae, (q31_t)0x3ae1931a, + (q31_t)0x59200ee3, (q31_t)0x3adca54e, (q31_t)0x592b9d1f, (q31_t)0x3ad7b53d, + (q31_t)0x59372a64, (q31_t)0x3ad2c2e8, (q31_t)0x5942b6af, (q31_t)0x3acdce4d, + (q31_t)0x594e4201, (q31_t)0x3ac8d76f, (q31_t)0x5959cc5a, (q31_t)0x3ac3de4c, + (q31_t)0x596555b8, (q31_t)0x3abee2e5, (q31_t)0x5970de1b, (q31_t)0x3ab9e53a, + (q31_t)0x597c6584, (q31_t)0x3ab4e54c, (q31_t)0x5987ebf0, (q31_t)0x3aafe31b, + (q31_t)0x59937161, (q31_t)0x3aaadea6, (q31_t)0x599ef5d6, (q31_t)0x3aa5d7ee, + (q31_t)0x59aa794d, (q31_t)0x3aa0cef3, (q31_t)0x59b5fbc8, (q31_t)0x3a9bc3b6, + (q31_t)0x59c17d44, (q31_t)0x3a96b636, (q31_t)0x59ccfdc2, (q31_t)0x3a91a674, + (q31_t)0x59d87d42, (q31_t)0x3a8c9470, (q31_t)0x59e3fbc3, (q31_t)0x3a87802a, + (q31_t)0x59ef7944, (q31_t)0x3a8269a3, (q31_t)0x59faf5c5, (q31_t)0x3a7d50da, + (q31_t)0x5a067145, (q31_t)0x3a7835cf, (q31_t)0x5a11ebc5, (q31_t)0x3a731884, + (q31_t)0x5a1d6544, (q31_t)0x3a6df8f8, (q31_t)0x5a28ddc0, (q31_t)0x3a68d72b, + (q31_t)0x5a34553b, (q31_t)0x3a63b31d, (q31_t)0x5a3fcbb3, (q31_t)0x3a5e8cd0, + (q31_t)0x5a4b4128, (q31_t)0x3a596442, (q31_t)0x5a56b599, (q31_t)0x3a543974, + (q31_t)0x5a622907, (q31_t)0x3a4f0c67, (q31_t)0x5a6d9b70, (q31_t)0x3a49dd1a, + (q31_t)0x5a790cd4, (q31_t)0x3a44ab8e, (q31_t)0x5a847d33, (q31_t)0x3a3f77c3, + (q31_t)0x5a8fec8c, (q31_t)0x3a3a41b9, (q31_t)0x5a9b5adf, (q31_t)0x3a350970, + (q31_t)0x5aa6c82b, (q31_t)0x3a2fcee8, (q31_t)0x5ab23471, (q31_t)0x3a2a9223, + (q31_t)0x5abd9faf, (q31_t)0x3a25531f, (q31_t)0x5ac909e5, (q31_t)0x3a2011de, + (q31_t)0x5ad47312, (q31_t)0x3a1ace5f, (q31_t)0x5adfdb37, (q31_t)0x3a1588a2, + (q31_t)0x5aeb4253, (q31_t)0x3a1040a8, (q31_t)0x5af6a865, (q31_t)0x3a0af671, + (q31_t)0x5b020d6c, (q31_t)0x3a05a9fd, (q31_t)0x5b0d716a, (q31_t)0x3a005b4d, + (q31_t)0x5b18d45c, (q31_t)0x39fb0a60, (q31_t)0x5b243643, (q31_t)0x39f5b737, + (q31_t)0x5b2f971e, (q31_t)0x39f061d2, (q31_t)0x5b3af6ec, (q31_t)0x39eb0a31, + (q31_t)0x5b4655ae, (q31_t)0x39e5b054, (q31_t)0x5b51b363, (q31_t)0x39e0543c, + (q31_t)0x5b5d100a, (q31_t)0x39daf5e8, (q31_t)0x5b686ba3, (q31_t)0x39d5955a, + (q31_t)0x5b73c62d, (q31_t)0x39d03291, (q31_t)0x5b7f1fa9, (q31_t)0x39cacd8d, + (q31_t)0x5b8a7815, (q31_t)0x39c5664f, (q31_t)0x5b95cf71, (q31_t)0x39bffcd7, + (q31_t)0x5ba125bd, (q31_t)0x39ba9125, (q31_t)0x5bac7af9, (q31_t)0x39b52339, + (q31_t)0x5bb7cf23, (q31_t)0x39afb313, (q31_t)0x5bc3223c, (q31_t)0x39aa40b4, + (q31_t)0x5bce7442, (q31_t)0x39a4cc1c, (q31_t)0x5bd9c537, (q31_t)0x399f554b, + (q31_t)0x5be51518, (q31_t)0x3999dc42, (q31_t)0x5bf063e6, (q31_t)0x399460ff, + (q31_t)0x5bfbb1a0, (q31_t)0x398ee385, (q31_t)0x5c06fe46, (q31_t)0x398963d2, + (q31_t)0x5c1249d8, (q31_t)0x3983e1e8, (q31_t)0x5c1d9454, (q31_t)0x397e5dc6, + (q31_t)0x5c28ddbb, (q31_t)0x3978d76c, (q31_t)0x5c34260c, (q31_t)0x39734edc, + (q31_t)0x5c3f6d47, (q31_t)0x396dc414, (q31_t)0x5c4ab36b, (q31_t)0x39683715, + (q31_t)0x5c55f878, (q31_t)0x3962a7e0, (q31_t)0x5c613c6d, (q31_t)0x395d1675, + (q31_t)0x5c6c7f4a, (q31_t)0x395782d3, (q31_t)0x5c77c10e, (q31_t)0x3951ecfc, + (q31_t)0x5c8301b9, (q31_t)0x394c54ee, (q31_t)0x5c8e414b, (q31_t)0x3946baac, + (q31_t)0x5c997fc4, (q31_t)0x39411e33, (q31_t)0x5ca4bd21, (q31_t)0x393b7f86, + (q31_t)0x5caff965, (q31_t)0x3935dea4, (q31_t)0x5cbb348d, (q31_t)0x39303b8e, + (q31_t)0x5cc66e99, (q31_t)0x392a9642, (q31_t)0x5cd1a78a, (q31_t)0x3924eec3, + (q31_t)0x5cdcdf5e, (q31_t)0x391f4510, (q31_t)0x5ce81615, (q31_t)0x39199929, + (q31_t)0x5cf34baf, (q31_t)0x3913eb0e, (q31_t)0x5cfe802b, (q31_t)0x390e3ac0, + (q31_t)0x5d09b389, (q31_t)0x3908883f, (q31_t)0x5d14e5c9, (q31_t)0x3902d38b, + (q31_t)0x5d2016e9, (q31_t)0x38fd1ca4, (q31_t)0x5d2b46ea, (q31_t)0x38f7638b, + (q31_t)0x5d3675cb, (q31_t)0x38f1a840, (q31_t)0x5d41a38c, (q31_t)0x38ebeac2, + (q31_t)0x5d4cd02c, (q31_t)0x38e62b13, (q31_t)0x5d57fbaa, (q31_t)0x38e06932, + (q31_t)0x5d632608, (q31_t)0x38daa520, (q31_t)0x5d6e4f43, (q31_t)0x38d4dedd, + (q31_t)0x5d79775c, (q31_t)0x38cf1669, (q31_t)0x5d849e51, (q31_t)0x38c94bc4, + (q31_t)0x5d8fc424, (q31_t)0x38c37eef, (q31_t)0x5d9ae8d2, (q31_t)0x38bdafea, + (q31_t)0x5da60c5d, (q31_t)0x38b7deb4, (q31_t)0x5db12ec3, (q31_t)0x38b20b4f, + (q31_t)0x5dbc5004, (q31_t)0x38ac35ba, (q31_t)0x5dc7701f, (q31_t)0x38a65df6, + (q31_t)0x5dd28f15, (q31_t)0x38a08402, (q31_t)0x5dddace4, (q31_t)0x389aa7e0, + (q31_t)0x5de8c98c, (q31_t)0x3894c98f, (q31_t)0x5df3e50d, (q31_t)0x388ee910, + (q31_t)0x5dfeff67, (q31_t)0x38890663, (q31_t)0x5e0a1898, (q31_t)0x38832187, + (q31_t)0x5e1530a1, (q31_t)0x387d3a7e, (q31_t)0x5e204781, (q31_t)0x38775147, + (q31_t)0x5e2b5d38, (q31_t)0x387165e3, (q31_t)0x5e3671c5, (q31_t)0x386b7852, + (q31_t)0x5e418528, (q31_t)0x38658894, (q31_t)0x5e4c9760, (q31_t)0x385f96a9, + (q31_t)0x5e57a86d, (q31_t)0x3859a292, (q31_t)0x5e62b84f, (q31_t)0x3853ac4f, + (q31_t)0x5e6dc705, (q31_t)0x384db3e0, (q31_t)0x5e78d48e, (q31_t)0x3847b946, + (q31_t)0x5e83e0eb, (q31_t)0x3841bc7f, (q31_t)0x5e8eec1b, (q31_t)0x383bbd8e, + (q31_t)0x5e99f61d, (q31_t)0x3835bc71, (q31_t)0x5ea4fef0, (q31_t)0x382fb92a, + (q31_t)0x5eb00696, (q31_t)0x3829b3b9, (q31_t)0x5ebb0d0d, (q31_t)0x3823ac1d, + (q31_t)0x5ec61254, (q31_t)0x381da256, (q31_t)0x5ed1166b, (q31_t)0x38179666, + (q31_t)0x5edc1953, (q31_t)0x3811884d, (q31_t)0x5ee71b0a, (q31_t)0x380b780a, + (q31_t)0x5ef21b90, (q31_t)0x3805659e, (q31_t)0x5efd1ae4, (q31_t)0x37ff5109, + (q31_t)0x5f081907, (q31_t)0x37f93a4b, (q31_t)0x5f1315f7, (q31_t)0x37f32165, + (q31_t)0x5f1e11b5, (q31_t)0x37ed0657, (q31_t)0x5f290c3f, (q31_t)0x37e6e921, + (q31_t)0x5f340596, (q31_t)0x37e0c9c3, (q31_t)0x5f3efdb9, (q31_t)0x37daa83d, + (q31_t)0x5f49f4a8, (q31_t)0x37d48490, (q31_t)0x5f54ea62, (q31_t)0x37ce5ebd, + (q31_t)0x5f5fdee6, (q31_t)0x37c836c2, (q31_t)0x5f6ad235, (q31_t)0x37c20ca1, + (q31_t)0x5f75c44e, (q31_t)0x37bbe05a, (q31_t)0x5f80b531, (q31_t)0x37b5b1ec, + (q31_t)0x5f8ba4dc, (q31_t)0x37af8159, (q31_t)0x5f969350, (q31_t)0x37a94ea0, + (q31_t)0x5fa1808c, (q31_t)0x37a319c2, (q31_t)0x5fac6c91, (q31_t)0x379ce2be, + (q31_t)0x5fb7575c, (q31_t)0x3796a996, (q31_t)0x5fc240ef, (q31_t)0x37906e49, + (q31_t)0x5fcd2948, (q31_t)0x378a30d8, (q31_t)0x5fd81067, (q31_t)0x3783f143, + (q31_t)0x5fe2f64c, (q31_t)0x377daf89, (q31_t)0x5feddaf6, (q31_t)0x37776bac, + (q31_t)0x5ff8be65, (q31_t)0x377125ac, (q31_t)0x6003a099, (q31_t)0x376add88, + (q31_t)0x600e8190, (q31_t)0x37649341, (q31_t)0x6019614c, (q31_t)0x375e46d8, + (q31_t)0x60243fca, (q31_t)0x3757f84c, (q31_t)0x602f1d0b, (q31_t)0x3751a79e, + (q31_t)0x6039f90f, (q31_t)0x374b54ce, (q31_t)0x6044d3d4, (q31_t)0x3744ffdd, + (q31_t)0x604fad5b, (q31_t)0x373ea8ca, (q31_t)0x605a85a3, (q31_t)0x37384f95, + (q31_t)0x60655cac, (q31_t)0x3731f440, (q31_t)0x60703275, (q31_t)0x372b96ca, + (q31_t)0x607b06fe, (q31_t)0x37253733, (q31_t)0x6085da46, (q31_t)0x371ed57c, + (q31_t)0x6090ac4d, (q31_t)0x371871a5, (q31_t)0x609b7d13, (q31_t)0x37120bae, + (q31_t)0x60a64c97, (q31_t)0x370ba398, (q31_t)0x60b11ad9, (q31_t)0x37053962, + (q31_t)0x60bbe7d8, (q31_t)0x36fecd0e, (q31_t)0x60c6b395, (q31_t)0x36f85e9a, + (q31_t)0x60d17e0d, (q31_t)0x36f1ee09, (q31_t)0x60dc4742, (q31_t)0x36eb7b58, + (q31_t)0x60e70f32, (q31_t)0x36e5068a, (q31_t)0x60f1d5de, (q31_t)0x36de8f9e, + (q31_t)0x60fc9b44, (q31_t)0x36d81695, (q31_t)0x61075f65, (q31_t)0x36d19b6e, + (q31_t)0x61122240, (q31_t)0x36cb1e2a, (q31_t)0x611ce3d5, (q31_t)0x36c49ec9, + (q31_t)0x6127a423, (q31_t)0x36be1d4c, (q31_t)0x61326329, (q31_t)0x36b799b3, + (q31_t)0x613d20e8, (q31_t)0x36b113fd, (q31_t)0x6147dd5f, (q31_t)0x36aa8c2c, + (q31_t)0x6152988d, (q31_t)0x36a4023f, (q31_t)0x615d5273, (q31_t)0x369d7637, + (q31_t)0x61680b0f, (q31_t)0x3696e814, (q31_t)0x6172c262, (q31_t)0x369057d6, + (q31_t)0x617d786a, (q31_t)0x3689c57d, (q31_t)0x61882d28, (q31_t)0x3683310b, + (q31_t)0x6192e09b, (q31_t)0x367c9a7e, (q31_t)0x619d92c2, (q31_t)0x367601d7, + (q31_t)0x61a8439e, (q31_t)0x366f6717, (q31_t)0x61b2f32e, (q31_t)0x3668ca3e, + (q31_t)0x61bda171, (q31_t)0x36622b4c, (q31_t)0x61c84e67, (q31_t)0x365b8a41, + (q31_t)0x61d2fa0f, (q31_t)0x3654e71d, (q31_t)0x61dda46a, (q31_t)0x364e41e2, + (q31_t)0x61e84d76, (q31_t)0x36479a8e, (q31_t)0x61f2f534, (q31_t)0x3640f123, + (q31_t)0x61fd9ba3, (q31_t)0x363a45a0, (q31_t)0x620840c2, (q31_t)0x36339806, + (q31_t)0x6212e492, (q31_t)0x362ce855, (q31_t)0x621d8711, (q31_t)0x3626368d, + (q31_t)0x6228283f, (q31_t)0x361f82af, (q31_t)0x6232c81c, (q31_t)0x3618ccba, + (q31_t)0x623d66a8, (q31_t)0x361214b0, (q31_t)0x624803e2, (q31_t)0x360b5a90, + (q31_t)0x62529fca, (q31_t)0x36049e5b, (q31_t)0x625d3a5e, (q31_t)0x35fde011, + (q31_t)0x6267d3a0, (q31_t)0x35f71fb1, (q31_t)0x62726b8e, (q31_t)0x35f05d3d, + (q31_t)0x627d0228, (q31_t)0x35e998b5, (q31_t)0x6287976e, (q31_t)0x35e2d219, + (q31_t)0x62922b5e, (q31_t)0x35dc0968, (q31_t)0x629cbdfa, (q31_t)0x35d53ea5, + (q31_t)0x62a74f40, (q31_t)0x35ce71ce, (q31_t)0x62b1df30, (q31_t)0x35c7a2e3, + (q31_t)0x62bc6dca, (q31_t)0x35c0d1e7, (q31_t)0x62c6fb0c, (q31_t)0x35b9fed7, + (q31_t)0x62d186f8, (q31_t)0x35b329b5, (q31_t)0x62dc118c, (q31_t)0x35ac5282, + (q31_t)0x62e69ac8, (q31_t)0x35a5793c, (q31_t)0x62f122ab, (q31_t)0x359e9de5, + (q31_t)0x62fba936, (q31_t)0x3597c07d, (q31_t)0x63062e67, (q31_t)0x3590e104, + (q31_t)0x6310b23e, (q31_t)0x3589ff7a, (q31_t)0x631b34bc, (q31_t)0x35831be0, + (q31_t)0x6325b5df, (q31_t)0x357c3636, (q31_t)0x633035a7, (q31_t)0x35754e7c, + (q31_t)0x633ab414, (q31_t)0x356e64b2, (q31_t)0x63453125, (q31_t)0x356778d9, + (q31_t)0x634facda, (q31_t)0x35608af1, (q31_t)0x635a2733, (q31_t)0x35599afa, + (q31_t)0x6364a02e, (q31_t)0x3552a8f4, (q31_t)0x636f17cc, (q31_t)0x354bb4e1, + (q31_t)0x63798e0d, (q31_t)0x3544bebf, (q31_t)0x638402ef, (q31_t)0x353dc68f, + (q31_t)0x638e7673, (q31_t)0x3536cc52, (q31_t)0x6398e898, (q31_t)0x352fd008, + (q31_t)0x63a3595e, (q31_t)0x3528d1b1, (q31_t)0x63adc8c4, (q31_t)0x3521d14d, + (q31_t)0x63b836ca, (q31_t)0x351acedd, (q31_t)0x63c2a36f, (q31_t)0x3513ca60, + (q31_t)0x63cd0eb3, (q31_t)0x350cc3d8, (q31_t)0x63d77896, (q31_t)0x3505bb44, + (q31_t)0x63e1e117, (q31_t)0x34feb0a5, (q31_t)0x63ec4837, (q31_t)0x34f7a3fb, + (q31_t)0x63f6adf3, (q31_t)0x34f09546, (q31_t)0x6401124d, (q31_t)0x34e98487, + (q31_t)0x640b7543, (q31_t)0x34e271bd, (q31_t)0x6415d6d5, (q31_t)0x34db5cea, + (q31_t)0x64203704, (q31_t)0x34d4460c, (q31_t)0x642a95ce, (q31_t)0x34cd2d26, + (q31_t)0x6434f332, (q31_t)0x34c61236, (q31_t)0x643f4f32, (q31_t)0x34bef53d, + (q31_t)0x6449a9cc, (q31_t)0x34b7d63c, (q31_t)0x645402ff, (q31_t)0x34b0b533, + (q31_t)0x645e5acc, (q31_t)0x34a99221, (q31_t)0x6468b132, (q31_t)0x34a26d08, + (q31_t)0x64730631, (q31_t)0x349b45e7, (q31_t)0x647d59c8, (q31_t)0x34941cbf, + (q31_t)0x6487abf7, (q31_t)0x348cf190, (q31_t)0x6491fcbe, (q31_t)0x3485c45b, + (q31_t)0x649c4c1b, (q31_t)0x347e951f, (q31_t)0x64a69a0f, (q31_t)0x347763dd, + (q31_t)0x64b0e699, (q31_t)0x34703095, (q31_t)0x64bb31ba, (q31_t)0x3468fb47, + (q31_t)0x64c57b6f, (q31_t)0x3461c3f5, (q31_t)0x64cfc3ba, (q31_t)0x345a8a9d, + (q31_t)0x64da0a9a, (q31_t)0x34534f41, (q31_t)0x64e4500e, (q31_t)0x344c11e0, + (q31_t)0x64ee9415, (q31_t)0x3444d27b, (q31_t)0x64f8d6b0, (q31_t)0x343d9112, + (q31_t)0x650317df, (q31_t)0x34364da6, (q31_t)0x650d57a0, (q31_t)0x342f0836, + (q31_t)0x651795f3, (q31_t)0x3427c0c3, (q31_t)0x6521d2d8, (q31_t)0x3420774d, + (q31_t)0x652c0e4f, (q31_t)0x34192bd5, (q31_t)0x65364857, (q31_t)0x3411de5b, + (q31_t)0x654080ef, (q31_t)0x340a8edf, (q31_t)0x654ab818, (q31_t)0x34033d61, + (q31_t)0x6554edd1, (q31_t)0x33fbe9e2, (q31_t)0x655f2219, (q31_t)0x33f49462, + (q31_t)0x656954f1, (q31_t)0x33ed3ce1, (q31_t)0x65738657, (q31_t)0x33e5e360, + (q31_t)0x657db64c, (q31_t)0x33de87de, (q31_t)0x6587e4cf, (q31_t)0x33d72a5d, + (q31_t)0x659211df, (q31_t)0x33cfcadc, (q31_t)0x659c3d7c, (q31_t)0x33c8695b, + (q31_t)0x65a667a7, (q31_t)0x33c105db, (q31_t)0x65b0905d, (q31_t)0x33b9a05d, + (q31_t)0x65bab7a0, (q31_t)0x33b238e0, (q31_t)0x65c4dd6e, (q31_t)0x33aacf65, + (q31_t)0x65cf01c8, (q31_t)0x33a363ec, (q31_t)0x65d924ac, (q31_t)0x339bf675, + (q31_t)0x65e3461b, (q31_t)0x33948701, (q31_t)0x65ed6614, (q31_t)0x338d1590, + (q31_t)0x65f78497, (q31_t)0x3385a222, (q31_t)0x6601a1a2, (q31_t)0x337e2cb7, + (q31_t)0x660bbd37, (q31_t)0x3376b551, (q31_t)0x6615d754, (q31_t)0x336f3bee, + (q31_t)0x661feffa, (q31_t)0x3367c090, (q31_t)0x662a0727, (q31_t)0x33604336, + (q31_t)0x66341cdb, (q31_t)0x3358c3e2, (q31_t)0x663e3117, (q31_t)0x33514292, + (q31_t)0x664843d9, (q31_t)0x3349bf48, (q31_t)0x66525521, (q31_t)0x33423a04, + (q31_t)0x665c64ef, (q31_t)0x333ab2c6, (q31_t)0x66667342, (q31_t)0x3333298f, + (q31_t)0x6670801a, (q31_t)0x332b9e5e, (q31_t)0x667a8b77, (q31_t)0x33241134, + (q31_t)0x66849558, (q31_t)0x331c8211, (q31_t)0x668e9dbd, (q31_t)0x3314f0f6, + (q31_t)0x6698a4a6, (q31_t)0x330d5de3, (q31_t)0x66a2aa11, (q31_t)0x3305c8d7, + (q31_t)0x66acadff, (q31_t)0x32fe31d5, (q31_t)0x66b6b070, (q31_t)0x32f698db, + (q31_t)0x66c0b162, (q31_t)0x32eefdea, (q31_t)0x66cab0d6, (q31_t)0x32e76102, + (q31_t)0x66d4aecb, (q31_t)0x32dfc224, (q31_t)0x66deab41, (q31_t)0x32d82150, + (q31_t)0x66e8a637, (q31_t)0x32d07e85, (q31_t)0x66f29fad, (q31_t)0x32c8d9c6, + (q31_t)0x66fc97a3, (q31_t)0x32c13311, (q31_t)0x67068e18, (q31_t)0x32b98a67, + (q31_t)0x6710830c, (q31_t)0x32b1dfc9, (q31_t)0x671a767e, (q31_t)0x32aa3336, + (q31_t)0x6724686e, (q31_t)0x32a284b0, (q31_t)0x672e58dc, (q31_t)0x329ad435, + (q31_t)0x673847c8, (q31_t)0x329321c7, (q31_t)0x67423530, (q31_t)0x328b6d66, + (q31_t)0x674c2115, (q31_t)0x3283b712, (q31_t)0x67560b76, (q31_t)0x327bfecc, + (q31_t)0x675ff452, (q31_t)0x32744493, (q31_t)0x6769dbaa, (q31_t)0x326c8868, + (q31_t)0x6773c17d, (q31_t)0x3264ca4c, (q31_t)0x677da5cb, (q31_t)0x325d0a3e, + (q31_t)0x67878893, (q31_t)0x32554840, (q31_t)0x679169d5, (q31_t)0x324d8450, + (q31_t)0x679b4990, (q31_t)0x3245be70, (q31_t)0x67a527c4, (q31_t)0x323df6a0, + (q31_t)0x67af0472, (q31_t)0x32362ce0, (q31_t)0x67b8df97, (q31_t)0x322e6130, + (q31_t)0x67c2b934, (q31_t)0x32269391, (q31_t)0x67cc9149, (q31_t)0x321ec403, + (q31_t)0x67d667d5, (q31_t)0x3216f287, (q31_t)0x67e03cd8, (q31_t)0x320f1f1c, + (q31_t)0x67ea1052, (q31_t)0x320749c3, (q31_t)0x67f3e241, (q31_t)0x31ff727c, + (q31_t)0x67fdb2a7, (q31_t)0x31f79948, (q31_t)0x68078181, (q31_t)0x31efbe27, + (q31_t)0x68114ed0, (q31_t)0x31e7e118, (q31_t)0x681b1a94, (q31_t)0x31e0021e, + (q31_t)0x6824e4cc, (q31_t)0x31d82137, (q31_t)0x682ead78, (q31_t)0x31d03e64, + (q31_t)0x68387498, (q31_t)0x31c859a5, (q31_t)0x68423a2a, (q31_t)0x31c072fb, + (q31_t)0x684bfe2f, (q31_t)0x31b88a66, (q31_t)0x6855c0a6, (q31_t)0x31b09fe7, + (q31_t)0x685f8190, (q31_t)0x31a8b37c, (q31_t)0x686940ea, (q31_t)0x31a0c528, + (q31_t)0x6872feb6, (q31_t)0x3198d4ea, (q31_t)0x687cbaf3, (q31_t)0x3190e2c3, + (q31_t)0x688675a0, (q31_t)0x3188eeb2, (q31_t)0x68902ebd, (q31_t)0x3180f8b8, + (q31_t)0x6899e64a, (q31_t)0x317900d6, (q31_t)0x68a39c46, (q31_t)0x3171070c, + (q31_t)0x68ad50b1, (q31_t)0x31690b59, (q31_t)0x68b7038b, (q31_t)0x31610dbf, + (q31_t)0x68c0b4d2, (q31_t)0x31590e3e, (q31_t)0x68ca6488, (q31_t)0x31510cd5, + (q31_t)0x68d412ab, (q31_t)0x31490986, (q31_t)0x68ddbf3b, (q31_t)0x31410450, + (q31_t)0x68e76a37, (q31_t)0x3138fd35, (q31_t)0x68f113a0, (q31_t)0x3130f433, + (q31_t)0x68fabb75, (q31_t)0x3128e94c, (q31_t)0x690461b5, (q31_t)0x3120dc80, + (q31_t)0x690e0661, (q31_t)0x3118cdcf, (q31_t)0x6917a977, (q31_t)0x3110bd39, + (q31_t)0x69214af8, (q31_t)0x3108aabf, (q31_t)0x692aeae3, (q31_t)0x31009661, + (q31_t)0x69348937, (q31_t)0x30f8801f, (q31_t)0x693e25f5, (q31_t)0x30f067fb, + (q31_t)0x6947c11c, (q31_t)0x30e84df3, (q31_t)0x69515aab, (q31_t)0x30e03208, + (q31_t)0x695af2a3, (q31_t)0x30d8143b, (q31_t)0x69648902, (q31_t)0x30cff48c, + (q31_t)0x696e1dc9, (q31_t)0x30c7d2fb, (q31_t)0x6977b0f7, (q31_t)0x30bfaf89, + (q31_t)0x6981428c, (q31_t)0x30b78a36, (q31_t)0x698ad287, (q31_t)0x30af6302, + (q31_t)0x699460e8, (q31_t)0x30a739ed, (q31_t)0x699dedaf, (q31_t)0x309f0ef8, + (q31_t)0x69a778db, (q31_t)0x3096e223, (q31_t)0x69b1026c, (q31_t)0x308eb36f, + (q31_t)0x69ba8a61, (q31_t)0x308682dc, (q31_t)0x69c410ba, (q31_t)0x307e5069, + (q31_t)0x69cd9578, (q31_t)0x30761c18, (q31_t)0x69d71899, (q31_t)0x306de5e9, + (q31_t)0x69e09a1c, (q31_t)0x3065addb, (q31_t)0x69ea1a03, (q31_t)0x305d73f0, + (q31_t)0x69f3984c, (q31_t)0x30553828, (q31_t)0x69fd14f6, (q31_t)0x304cfa83, + (q31_t)0x6a069003, (q31_t)0x3044bb00, (q31_t)0x6a100970, (q31_t)0x303c79a2, + (q31_t)0x6a19813f, (q31_t)0x30343667, (q31_t)0x6a22f76e, (q31_t)0x302bf151, + (q31_t)0x6a2c6bfd, (q31_t)0x3023aa5f, (q31_t)0x6a35deeb, (q31_t)0x301b6193, + (q31_t)0x6a3f503a, (q31_t)0x301316eb, (q31_t)0x6a48bfe7, (q31_t)0x300aca69, + (q31_t)0x6a522df3, (q31_t)0x30027c0c, (q31_t)0x6a5b9a5d, (q31_t)0x2ffa2bd6, + (q31_t)0x6a650525, (q31_t)0x2ff1d9c7, (q31_t)0x6a6e6e4b, (q31_t)0x2fe985de, + (q31_t)0x6a77d5ce, (q31_t)0x2fe1301c, (q31_t)0x6a813bae, (q31_t)0x2fd8d882, + (q31_t)0x6a8a9fea, (q31_t)0x2fd07f0f, (q31_t)0x6a940283, (q31_t)0x2fc823c5, + (q31_t)0x6a9d6377, (q31_t)0x2fbfc6a3, (q31_t)0x6aa6c2c6, (q31_t)0x2fb767aa, + (q31_t)0x6ab02071, (q31_t)0x2faf06da, (q31_t)0x6ab97c77, (q31_t)0x2fa6a433, + (q31_t)0x6ac2d6d6, (q31_t)0x2f9e3fb6, (q31_t)0x6acc2f90, (q31_t)0x2f95d963, + (q31_t)0x6ad586a3, (q31_t)0x2f8d713a, (q31_t)0x6adedc10, (q31_t)0x2f85073c, + (q31_t)0x6ae82fd5, (q31_t)0x2f7c9b69, (q31_t)0x6af181f3, (q31_t)0x2f742dc1, + (q31_t)0x6afad269, (q31_t)0x2f6bbe45, (q31_t)0x6b042137, (q31_t)0x2f634cf5, + (q31_t)0x6b0d6e5c, (q31_t)0x2f5ad9d1, (q31_t)0x6b16b9d9, (q31_t)0x2f5264da, + (q31_t)0x6b2003ac, (q31_t)0x2f49ee0f, (q31_t)0x6b294bd5, (q31_t)0x2f417573, + (q31_t)0x6b329255, (q31_t)0x2f38fb03, (q31_t)0x6b3bd72a, (q31_t)0x2f307ec2, + (q31_t)0x6b451a55, (q31_t)0x2f2800af, (q31_t)0x6b4e5bd4, (q31_t)0x2f1f80ca, + (q31_t)0x6b579ba8, (q31_t)0x2f16ff14, (q31_t)0x6b60d9d0, (q31_t)0x2f0e7b8e, + (q31_t)0x6b6a164d, (q31_t)0x2f05f637, (q31_t)0x6b73511c, (q31_t)0x2efd6f10, + (q31_t)0x6b7c8a3f, (q31_t)0x2ef4e619, (q31_t)0x6b85c1b5, (q31_t)0x2eec5b53, + (q31_t)0x6b8ef77d, (q31_t)0x2ee3cebe, (q31_t)0x6b982b97, (q31_t)0x2edb405a, + (q31_t)0x6ba15e03, (q31_t)0x2ed2b027, (q31_t)0x6baa8ec0, (q31_t)0x2eca1e27, + (q31_t)0x6bb3bdce, (q31_t)0x2ec18a58, (q31_t)0x6bbceb2d, (q31_t)0x2eb8f4bc, + (q31_t)0x6bc616dd, (q31_t)0x2eb05d53, (q31_t)0x6bcf40dc, (q31_t)0x2ea7c41e, + (q31_t)0x6bd8692b, (q31_t)0x2e9f291b, (q31_t)0x6be18fc9, (q31_t)0x2e968c4d, + (q31_t)0x6beab4b6, (q31_t)0x2e8dedb3, (q31_t)0x6bf3d7f2, (q31_t)0x2e854d4d, + (q31_t)0x6bfcf97c, (q31_t)0x2e7cab1c, (q31_t)0x6c061953, (q31_t)0x2e740720, + (q31_t)0x6c0f3779, (q31_t)0x2e6b615a, (q31_t)0x6c1853eb, (q31_t)0x2e62b9ca, + (q31_t)0x6c216eaa, (q31_t)0x2e5a1070, (q31_t)0x6c2a87b6, (q31_t)0x2e51654c, + (q31_t)0x6c339f0e, (q31_t)0x2e48b860, (q31_t)0x6c3cb4b1, (q31_t)0x2e4009aa, + (q31_t)0x6c45c8a0, (q31_t)0x2e37592c, (q31_t)0x6c4edada, (q31_t)0x2e2ea6e6, + (q31_t)0x6c57eb5e, (q31_t)0x2e25f2d8, (q31_t)0x6c60fa2d, (q31_t)0x2e1d3d03, + (q31_t)0x6c6a0746, (q31_t)0x2e148566, (q31_t)0x6c7312a9, (q31_t)0x2e0bcc03, + (q31_t)0x6c7c1c55, (q31_t)0x2e0310d9, (q31_t)0x6c85244a, (q31_t)0x2dfa53e9, + (q31_t)0x6c8e2a87, (q31_t)0x2df19534, (q31_t)0x6c972f0d, (q31_t)0x2de8d4b8, + (q31_t)0x6ca031da, (q31_t)0x2de01278, (q31_t)0x6ca932ef, (q31_t)0x2dd74e73, + (q31_t)0x6cb2324c, (q31_t)0x2dce88aa, (q31_t)0x6cbb2fef, (q31_t)0x2dc5c11c, + (q31_t)0x6cc42bd9, (q31_t)0x2dbcf7cb, (q31_t)0x6ccd2609, (q31_t)0x2db42cb6, + (q31_t)0x6cd61e7f, (q31_t)0x2dab5fdf, (q31_t)0x6cdf153a, (q31_t)0x2da29144, + (q31_t)0x6ce80a3a, (q31_t)0x2d99c0e7, (q31_t)0x6cf0fd80, (q31_t)0x2d90eec8, + (q31_t)0x6cf9ef09, (q31_t)0x2d881ae8, (q31_t)0x6d02ded7, (q31_t)0x2d7f4545, + (q31_t)0x6d0bcce8, (q31_t)0x2d766de2, (q31_t)0x6d14b93d, (q31_t)0x2d6d94bf, + (q31_t)0x6d1da3d5, (q31_t)0x2d64b9da, (q31_t)0x6d268cb0, (q31_t)0x2d5bdd36, + (q31_t)0x6d2f73cd, (q31_t)0x2d52fed2, (q31_t)0x6d38592c, (q31_t)0x2d4a1eaf, + (q31_t)0x6d413ccd, (q31_t)0x2d413ccd, (q31_t)0x6d4a1eaf, (q31_t)0x2d38592c, + (q31_t)0x6d52fed2, (q31_t)0x2d2f73cd, (q31_t)0x6d5bdd36, (q31_t)0x2d268cb0, + (q31_t)0x6d64b9da, (q31_t)0x2d1da3d5, (q31_t)0x6d6d94bf, (q31_t)0x2d14b93d, + (q31_t)0x6d766de2, (q31_t)0x2d0bcce8, (q31_t)0x6d7f4545, (q31_t)0x2d02ded7, + (q31_t)0x6d881ae8, (q31_t)0x2cf9ef09, (q31_t)0x6d90eec8, (q31_t)0x2cf0fd80, + (q31_t)0x6d99c0e7, (q31_t)0x2ce80a3a, (q31_t)0x6da29144, (q31_t)0x2cdf153a, + (q31_t)0x6dab5fdf, (q31_t)0x2cd61e7f, (q31_t)0x6db42cb6, (q31_t)0x2ccd2609, + (q31_t)0x6dbcf7cb, (q31_t)0x2cc42bd9, (q31_t)0x6dc5c11c, (q31_t)0x2cbb2fef, + (q31_t)0x6dce88aa, (q31_t)0x2cb2324c, (q31_t)0x6dd74e73, (q31_t)0x2ca932ef, + (q31_t)0x6de01278, (q31_t)0x2ca031da, (q31_t)0x6de8d4b8, (q31_t)0x2c972f0d, + (q31_t)0x6df19534, (q31_t)0x2c8e2a87, (q31_t)0x6dfa53e9, (q31_t)0x2c85244a, + (q31_t)0x6e0310d9, (q31_t)0x2c7c1c55, (q31_t)0x6e0bcc03, (q31_t)0x2c7312a9, + (q31_t)0x6e148566, (q31_t)0x2c6a0746, (q31_t)0x6e1d3d03, (q31_t)0x2c60fa2d, + (q31_t)0x6e25f2d8, (q31_t)0x2c57eb5e, (q31_t)0x6e2ea6e6, (q31_t)0x2c4edada, + (q31_t)0x6e37592c, (q31_t)0x2c45c8a0, (q31_t)0x6e4009aa, (q31_t)0x2c3cb4b1, + (q31_t)0x6e48b860, (q31_t)0x2c339f0e, (q31_t)0x6e51654c, (q31_t)0x2c2a87b6, + (q31_t)0x6e5a1070, (q31_t)0x2c216eaa, (q31_t)0x6e62b9ca, (q31_t)0x2c1853eb, + (q31_t)0x6e6b615a, (q31_t)0x2c0f3779, (q31_t)0x6e740720, (q31_t)0x2c061953, + (q31_t)0x6e7cab1c, (q31_t)0x2bfcf97c, (q31_t)0x6e854d4d, (q31_t)0x2bf3d7f2, + (q31_t)0x6e8dedb3, (q31_t)0x2beab4b6, (q31_t)0x6e968c4d, (q31_t)0x2be18fc9, + (q31_t)0x6e9f291b, (q31_t)0x2bd8692b, (q31_t)0x6ea7c41e, (q31_t)0x2bcf40dc, + (q31_t)0x6eb05d53, (q31_t)0x2bc616dd, (q31_t)0x6eb8f4bc, (q31_t)0x2bbceb2d, + (q31_t)0x6ec18a58, (q31_t)0x2bb3bdce, (q31_t)0x6eca1e27, (q31_t)0x2baa8ec0, + (q31_t)0x6ed2b027, (q31_t)0x2ba15e03, (q31_t)0x6edb405a, (q31_t)0x2b982b97, + (q31_t)0x6ee3cebe, (q31_t)0x2b8ef77d, (q31_t)0x6eec5b53, (q31_t)0x2b85c1b5, + (q31_t)0x6ef4e619, (q31_t)0x2b7c8a3f, (q31_t)0x6efd6f10, (q31_t)0x2b73511c, + (q31_t)0x6f05f637, (q31_t)0x2b6a164d, (q31_t)0x6f0e7b8e, (q31_t)0x2b60d9d0, + (q31_t)0x6f16ff14, (q31_t)0x2b579ba8, (q31_t)0x6f1f80ca, (q31_t)0x2b4e5bd4, + (q31_t)0x6f2800af, (q31_t)0x2b451a55, (q31_t)0x6f307ec2, (q31_t)0x2b3bd72a, + (q31_t)0x6f38fb03, (q31_t)0x2b329255, (q31_t)0x6f417573, (q31_t)0x2b294bd5, + (q31_t)0x6f49ee0f, (q31_t)0x2b2003ac, (q31_t)0x6f5264da, (q31_t)0x2b16b9d9, + (q31_t)0x6f5ad9d1, (q31_t)0x2b0d6e5c, (q31_t)0x6f634cf5, (q31_t)0x2b042137, + (q31_t)0x6f6bbe45, (q31_t)0x2afad269, (q31_t)0x6f742dc1, (q31_t)0x2af181f3, + (q31_t)0x6f7c9b69, (q31_t)0x2ae82fd5, (q31_t)0x6f85073c, (q31_t)0x2adedc10, + (q31_t)0x6f8d713a, (q31_t)0x2ad586a3, (q31_t)0x6f95d963, (q31_t)0x2acc2f90, + (q31_t)0x6f9e3fb6, (q31_t)0x2ac2d6d6, (q31_t)0x6fa6a433, (q31_t)0x2ab97c77, + (q31_t)0x6faf06da, (q31_t)0x2ab02071, (q31_t)0x6fb767aa, (q31_t)0x2aa6c2c6, + (q31_t)0x6fbfc6a3, (q31_t)0x2a9d6377, (q31_t)0x6fc823c5, (q31_t)0x2a940283, + (q31_t)0x6fd07f0f, (q31_t)0x2a8a9fea, (q31_t)0x6fd8d882, (q31_t)0x2a813bae, + (q31_t)0x6fe1301c, (q31_t)0x2a77d5ce, (q31_t)0x6fe985de, (q31_t)0x2a6e6e4b, + (q31_t)0x6ff1d9c7, (q31_t)0x2a650525, (q31_t)0x6ffa2bd6, (q31_t)0x2a5b9a5d, + (q31_t)0x70027c0c, (q31_t)0x2a522df3, (q31_t)0x700aca69, (q31_t)0x2a48bfe7, + (q31_t)0x701316eb, (q31_t)0x2a3f503a, (q31_t)0x701b6193, (q31_t)0x2a35deeb, + (q31_t)0x7023aa5f, (q31_t)0x2a2c6bfd, (q31_t)0x702bf151, (q31_t)0x2a22f76e, + (q31_t)0x70343667, (q31_t)0x2a19813f, (q31_t)0x703c79a2, (q31_t)0x2a100970, + (q31_t)0x7044bb00, (q31_t)0x2a069003, (q31_t)0x704cfa83, (q31_t)0x29fd14f6, + (q31_t)0x70553828, (q31_t)0x29f3984c, (q31_t)0x705d73f0, (q31_t)0x29ea1a03, + (q31_t)0x7065addb, (q31_t)0x29e09a1c, (q31_t)0x706de5e9, (q31_t)0x29d71899, + (q31_t)0x70761c18, (q31_t)0x29cd9578, (q31_t)0x707e5069, (q31_t)0x29c410ba, + (q31_t)0x708682dc, (q31_t)0x29ba8a61, (q31_t)0x708eb36f, (q31_t)0x29b1026c, + (q31_t)0x7096e223, (q31_t)0x29a778db, (q31_t)0x709f0ef8, (q31_t)0x299dedaf, + (q31_t)0x70a739ed, (q31_t)0x299460e8, (q31_t)0x70af6302, (q31_t)0x298ad287, + (q31_t)0x70b78a36, (q31_t)0x2981428c, (q31_t)0x70bfaf89, (q31_t)0x2977b0f7, + (q31_t)0x70c7d2fb, (q31_t)0x296e1dc9, (q31_t)0x70cff48c, (q31_t)0x29648902, + (q31_t)0x70d8143b, (q31_t)0x295af2a3, (q31_t)0x70e03208, (q31_t)0x29515aab, + (q31_t)0x70e84df3, (q31_t)0x2947c11c, (q31_t)0x70f067fb, (q31_t)0x293e25f5, + (q31_t)0x70f8801f, (q31_t)0x29348937, (q31_t)0x71009661, (q31_t)0x292aeae3, + (q31_t)0x7108aabf, (q31_t)0x29214af8, (q31_t)0x7110bd39, (q31_t)0x2917a977, + (q31_t)0x7118cdcf, (q31_t)0x290e0661, (q31_t)0x7120dc80, (q31_t)0x290461b5, + (q31_t)0x7128e94c, (q31_t)0x28fabb75, (q31_t)0x7130f433, (q31_t)0x28f113a0, + (q31_t)0x7138fd35, (q31_t)0x28e76a37, (q31_t)0x71410450, (q31_t)0x28ddbf3b, + (q31_t)0x71490986, (q31_t)0x28d412ab, (q31_t)0x71510cd5, (q31_t)0x28ca6488, + (q31_t)0x71590e3e, (q31_t)0x28c0b4d2, (q31_t)0x71610dbf, (q31_t)0x28b7038b, + (q31_t)0x71690b59, (q31_t)0x28ad50b1, (q31_t)0x7171070c, (q31_t)0x28a39c46, + (q31_t)0x717900d6, (q31_t)0x2899e64a, (q31_t)0x7180f8b8, (q31_t)0x28902ebd, + (q31_t)0x7188eeb2, (q31_t)0x288675a0, (q31_t)0x7190e2c3, (q31_t)0x287cbaf3, + (q31_t)0x7198d4ea, (q31_t)0x2872feb6, (q31_t)0x71a0c528, (q31_t)0x286940ea, + (q31_t)0x71a8b37c, (q31_t)0x285f8190, (q31_t)0x71b09fe7, (q31_t)0x2855c0a6, + (q31_t)0x71b88a66, (q31_t)0x284bfe2f, (q31_t)0x71c072fb, (q31_t)0x28423a2a, + (q31_t)0x71c859a5, (q31_t)0x28387498, (q31_t)0x71d03e64, (q31_t)0x282ead78, + (q31_t)0x71d82137, (q31_t)0x2824e4cc, (q31_t)0x71e0021e, (q31_t)0x281b1a94, + (q31_t)0x71e7e118, (q31_t)0x28114ed0, (q31_t)0x71efbe27, (q31_t)0x28078181, + (q31_t)0x71f79948, (q31_t)0x27fdb2a7, (q31_t)0x71ff727c, (q31_t)0x27f3e241, + (q31_t)0x720749c3, (q31_t)0x27ea1052, (q31_t)0x720f1f1c, (q31_t)0x27e03cd8, + (q31_t)0x7216f287, (q31_t)0x27d667d5, (q31_t)0x721ec403, (q31_t)0x27cc9149, + (q31_t)0x72269391, (q31_t)0x27c2b934, (q31_t)0x722e6130, (q31_t)0x27b8df97, + (q31_t)0x72362ce0, (q31_t)0x27af0472, (q31_t)0x723df6a0, (q31_t)0x27a527c4, + (q31_t)0x7245be70, (q31_t)0x279b4990, (q31_t)0x724d8450, (q31_t)0x279169d5, + (q31_t)0x72554840, (q31_t)0x27878893, (q31_t)0x725d0a3e, (q31_t)0x277da5cb, + (q31_t)0x7264ca4c, (q31_t)0x2773c17d, (q31_t)0x726c8868, (q31_t)0x2769dbaa, + (q31_t)0x72744493, (q31_t)0x275ff452, (q31_t)0x727bfecc, (q31_t)0x27560b76, + (q31_t)0x7283b712, (q31_t)0x274c2115, (q31_t)0x728b6d66, (q31_t)0x27423530, + (q31_t)0x729321c7, (q31_t)0x273847c8, (q31_t)0x729ad435, (q31_t)0x272e58dc, + (q31_t)0x72a284b0, (q31_t)0x2724686e, (q31_t)0x72aa3336, (q31_t)0x271a767e, + (q31_t)0x72b1dfc9, (q31_t)0x2710830c, (q31_t)0x72b98a67, (q31_t)0x27068e18, + (q31_t)0x72c13311, (q31_t)0x26fc97a3, (q31_t)0x72c8d9c6, (q31_t)0x26f29fad, + (q31_t)0x72d07e85, (q31_t)0x26e8a637, (q31_t)0x72d82150, (q31_t)0x26deab41, + (q31_t)0x72dfc224, (q31_t)0x26d4aecb, (q31_t)0x72e76102, (q31_t)0x26cab0d6, + (q31_t)0x72eefdea, (q31_t)0x26c0b162, (q31_t)0x72f698db, (q31_t)0x26b6b070, + (q31_t)0x72fe31d5, (q31_t)0x26acadff, (q31_t)0x7305c8d7, (q31_t)0x26a2aa11, + (q31_t)0x730d5de3, (q31_t)0x2698a4a6, (q31_t)0x7314f0f6, (q31_t)0x268e9dbd, + (q31_t)0x731c8211, (q31_t)0x26849558, (q31_t)0x73241134, (q31_t)0x267a8b77, + (q31_t)0x732b9e5e, (q31_t)0x2670801a, (q31_t)0x7333298f, (q31_t)0x26667342, + (q31_t)0x733ab2c6, (q31_t)0x265c64ef, (q31_t)0x73423a04, (q31_t)0x26525521, + (q31_t)0x7349bf48, (q31_t)0x264843d9, (q31_t)0x73514292, (q31_t)0x263e3117, + (q31_t)0x7358c3e2, (q31_t)0x26341cdb, (q31_t)0x73604336, (q31_t)0x262a0727, + (q31_t)0x7367c090, (q31_t)0x261feffa, (q31_t)0x736f3bee, (q31_t)0x2615d754, + (q31_t)0x7376b551, (q31_t)0x260bbd37, (q31_t)0x737e2cb7, (q31_t)0x2601a1a2, + (q31_t)0x7385a222, (q31_t)0x25f78497, (q31_t)0x738d1590, (q31_t)0x25ed6614, + (q31_t)0x73948701, (q31_t)0x25e3461b, (q31_t)0x739bf675, (q31_t)0x25d924ac, + (q31_t)0x73a363ec, (q31_t)0x25cf01c8, (q31_t)0x73aacf65, (q31_t)0x25c4dd6e, + (q31_t)0x73b238e0, (q31_t)0x25bab7a0, (q31_t)0x73b9a05d, (q31_t)0x25b0905d, + (q31_t)0x73c105db, (q31_t)0x25a667a7, (q31_t)0x73c8695b, (q31_t)0x259c3d7c, + (q31_t)0x73cfcadc, (q31_t)0x259211df, (q31_t)0x73d72a5d, (q31_t)0x2587e4cf, + (q31_t)0x73de87de, (q31_t)0x257db64c, (q31_t)0x73e5e360, (q31_t)0x25738657, + (q31_t)0x73ed3ce1, (q31_t)0x256954f1, (q31_t)0x73f49462, (q31_t)0x255f2219, + (q31_t)0x73fbe9e2, (q31_t)0x2554edd1, (q31_t)0x74033d61, (q31_t)0x254ab818, + (q31_t)0x740a8edf, (q31_t)0x254080ef, (q31_t)0x7411de5b, (q31_t)0x25364857, + (q31_t)0x74192bd5, (q31_t)0x252c0e4f, (q31_t)0x7420774d, (q31_t)0x2521d2d8, + (q31_t)0x7427c0c3, (q31_t)0x251795f3, (q31_t)0x742f0836, (q31_t)0x250d57a0, + (q31_t)0x74364da6, (q31_t)0x250317df, (q31_t)0x743d9112, (q31_t)0x24f8d6b0, + (q31_t)0x7444d27b, (q31_t)0x24ee9415, (q31_t)0x744c11e0, (q31_t)0x24e4500e, + (q31_t)0x74534f41, (q31_t)0x24da0a9a, (q31_t)0x745a8a9d, (q31_t)0x24cfc3ba, + (q31_t)0x7461c3f5, (q31_t)0x24c57b6f, (q31_t)0x7468fb47, (q31_t)0x24bb31ba, + (q31_t)0x74703095, (q31_t)0x24b0e699, (q31_t)0x747763dd, (q31_t)0x24a69a0f, + (q31_t)0x747e951f, (q31_t)0x249c4c1b, (q31_t)0x7485c45b, (q31_t)0x2491fcbe, + (q31_t)0x748cf190, (q31_t)0x2487abf7, (q31_t)0x74941cbf, (q31_t)0x247d59c8, + (q31_t)0x749b45e7, (q31_t)0x24730631, (q31_t)0x74a26d08, (q31_t)0x2468b132, + (q31_t)0x74a99221, (q31_t)0x245e5acc, (q31_t)0x74b0b533, (q31_t)0x245402ff, + (q31_t)0x74b7d63c, (q31_t)0x2449a9cc, (q31_t)0x74bef53d, (q31_t)0x243f4f32, + (q31_t)0x74c61236, (q31_t)0x2434f332, (q31_t)0x74cd2d26, (q31_t)0x242a95ce, + (q31_t)0x74d4460c, (q31_t)0x24203704, (q31_t)0x74db5cea, (q31_t)0x2415d6d5, + (q31_t)0x74e271bd, (q31_t)0x240b7543, (q31_t)0x74e98487, (q31_t)0x2401124d, + (q31_t)0x74f09546, (q31_t)0x23f6adf3, (q31_t)0x74f7a3fb, (q31_t)0x23ec4837, + (q31_t)0x74feb0a5, (q31_t)0x23e1e117, (q31_t)0x7505bb44, (q31_t)0x23d77896, + (q31_t)0x750cc3d8, (q31_t)0x23cd0eb3, (q31_t)0x7513ca60, (q31_t)0x23c2a36f, + (q31_t)0x751acedd, (q31_t)0x23b836ca, (q31_t)0x7521d14d, (q31_t)0x23adc8c4, + (q31_t)0x7528d1b1, (q31_t)0x23a3595e, (q31_t)0x752fd008, (q31_t)0x2398e898, + (q31_t)0x7536cc52, (q31_t)0x238e7673, (q31_t)0x753dc68f, (q31_t)0x238402ef, + (q31_t)0x7544bebf, (q31_t)0x23798e0d, (q31_t)0x754bb4e1, (q31_t)0x236f17cc, + (q31_t)0x7552a8f4, (q31_t)0x2364a02e, (q31_t)0x75599afa, (q31_t)0x235a2733, + (q31_t)0x75608af1, (q31_t)0x234facda, (q31_t)0x756778d9, (q31_t)0x23453125, + (q31_t)0x756e64b2, (q31_t)0x233ab414, (q31_t)0x75754e7c, (q31_t)0x233035a7, + (q31_t)0x757c3636, (q31_t)0x2325b5df, (q31_t)0x75831be0, (q31_t)0x231b34bc, + (q31_t)0x7589ff7a, (q31_t)0x2310b23e, (q31_t)0x7590e104, (q31_t)0x23062e67, + (q31_t)0x7597c07d, (q31_t)0x22fba936, (q31_t)0x759e9de5, (q31_t)0x22f122ab, + (q31_t)0x75a5793c, (q31_t)0x22e69ac8, (q31_t)0x75ac5282, (q31_t)0x22dc118c, + (q31_t)0x75b329b5, (q31_t)0x22d186f8, (q31_t)0x75b9fed7, (q31_t)0x22c6fb0c, + (q31_t)0x75c0d1e7, (q31_t)0x22bc6dca, (q31_t)0x75c7a2e3, (q31_t)0x22b1df30, + (q31_t)0x75ce71ce, (q31_t)0x22a74f40, (q31_t)0x75d53ea5, (q31_t)0x229cbdfa, + (q31_t)0x75dc0968, (q31_t)0x22922b5e, (q31_t)0x75e2d219, (q31_t)0x2287976e, + (q31_t)0x75e998b5, (q31_t)0x227d0228, (q31_t)0x75f05d3d, (q31_t)0x22726b8e, + (q31_t)0x75f71fb1, (q31_t)0x2267d3a0, (q31_t)0x75fde011, (q31_t)0x225d3a5e, + (q31_t)0x76049e5b, (q31_t)0x22529fca, (q31_t)0x760b5a90, (q31_t)0x224803e2, + (q31_t)0x761214b0, (q31_t)0x223d66a8, (q31_t)0x7618ccba, (q31_t)0x2232c81c, + (q31_t)0x761f82af, (q31_t)0x2228283f, (q31_t)0x7626368d, (q31_t)0x221d8711, + (q31_t)0x762ce855, (q31_t)0x2212e492, (q31_t)0x76339806, (q31_t)0x220840c2, + (q31_t)0x763a45a0, (q31_t)0x21fd9ba3, (q31_t)0x7640f123, (q31_t)0x21f2f534, + (q31_t)0x76479a8e, (q31_t)0x21e84d76, (q31_t)0x764e41e2, (q31_t)0x21dda46a, + (q31_t)0x7654e71d, (q31_t)0x21d2fa0f, (q31_t)0x765b8a41, (q31_t)0x21c84e67, + (q31_t)0x76622b4c, (q31_t)0x21bda171, (q31_t)0x7668ca3e, (q31_t)0x21b2f32e, + (q31_t)0x766f6717, (q31_t)0x21a8439e, (q31_t)0x767601d7, (q31_t)0x219d92c2, + (q31_t)0x767c9a7e, (q31_t)0x2192e09b, (q31_t)0x7683310b, (q31_t)0x21882d28, + (q31_t)0x7689c57d, (q31_t)0x217d786a, (q31_t)0x769057d6, (q31_t)0x2172c262, + (q31_t)0x7696e814, (q31_t)0x21680b0f, (q31_t)0x769d7637, (q31_t)0x215d5273, + (q31_t)0x76a4023f, (q31_t)0x2152988d, (q31_t)0x76aa8c2c, (q31_t)0x2147dd5f, + (q31_t)0x76b113fd, (q31_t)0x213d20e8, (q31_t)0x76b799b3, (q31_t)0x21326329, + (q31_t)0x76be1d4c, (q31_t)0x2127a423, (q31_t)0x76c49ec9, (q31_t)0x211ce3d5, + (q31_t)0x76cb1e2a, (q31_t)0x21122240, (q31_t)0x76d19b6e, (q31_t)0x21075f65, + (q31_t)0x76d81695, (q31_t)0x20fc9b44, (q31_t)0x76de8f9e, (q31_t)0x20f1d5de, + (q31_t)0x76e5068a, (q31_t)0x20e70f32, (q31_t)0x76eb7b58, (q31_t)0x20dc4742, + (q31_t)0x76f1ee09, (q31_t)0x20d17e0d, (q31_t)0x76f85e9a, (q31_t)0x20c6b395, + (q31_t)0x76fecd0e, (q31_t)0x20bbe7d8, (q31_t)0x77053962, (q31_t)0x20b11ad9, + (q31_t)0x770ba398, (q31_t)0x20a64c97, (q31_t)0x77120bae, (q31_t)0x209b7d13, + (q31_t)0x771871a5, (q31_t)0x2090ac4d, (q31_t)0x771ed57c, (q31_t)0x2085da46, + (q31_t)0x77253733, (q31_t)0x207b06fe, (q31_t)0x772b96ca, (q31_t)0x20703275, + (q31_t)0x7731f440, (q31_t)0x20655cac, (q31_t)0x77384f95, (q31_t)0x205a85a3, + (q31_t)0x773ea8ca, (q31_t)0x204fad5b, (q31_t)0x7744ffdd, (q31_t)0x2044d3d4, + (q31_t)0x774b54ce, (q31_t)0x2039f90f, (q31_t)0x7751a79e, (q31_t)0x202f1d0b, + (q31_t)0x7757f84c, (q31_t)0x20243fca, (q31_t)0x775e46d8, (q31_t)0x2019614c, + (q31_t)0x77649341, (q31_t)0x200e8190, (q31_t)0x776add88, (q31_t)0x2003a099, + (q31_t)0x777125ac, (q31_t)0x1ff8be65, (q31_t)0x77776bac, (q31_t)0x1feddaf6, + (q31_t)0x777daf89, (q31_t)0x1fe2f64c, (q31_t)0x7783f143, (q31_t)0x1fd81067, + (q31_t)0x778a30d8, (q31_t)0x1fcd2948, (q31_t)0x77906e49, (q31_t)0x1fc240ef, + (q31_t)0x7796a996, (q31_t)0x1fb7575c, (q31_t)0x779ce2be, (q31_t)0x1fac6c91, + (q31_t)0x77a319c2, (q31_t)0x1fa1808c, (q31_t)0x77a94ea0, (q31_t)0x1f969350, + (q31_t)0x77af8159, (q31_t)0x1f8ba4dc, (q31_t)0x77b5b1ec, (q31_t)0x1f80b531, + (q31_t)0x77bbe05a, (q31_t)0x1f75c44e, (q31_t)0x77c20ca1, (q31_t)0x1f6ad235, + (q31_t)0x77c836c2, (q31_t)0x1f5fdee6, (q31_t)0x77ce5ebd, (q31_t)0x1f54ea62, + (q31_t)0x77d48490, (q31_t)0x1f49f4a8, (q31_t)0x77daa83d, (q31_t)0x1f3efdb9, + (q31_t)0x77e0c9c3, (q31_t)0x1f340596, (q31_t)0x77e6e921, (q31_t)0x1f290c3f, + (q31_t)0x77ed0657, (q31_t)0x1f1e11b5, (q31_t)0x77f32165, (q31_t)0x1f1315f7, + (q31_t)0x77f93a4b, (q31_t)0x1f081907, (q31_t)0x77ff5109, (q31_t)0x1efd1ae4, + (q31_t)0x7805659e, (q31_t)0x1ef21b90, (q31_t)0x780b780a, (q31_t)0x1ee71b0a, + (q31_t)0x7811884d, (q31_t)0x1edc1953, (q31_t)0x78179666, (q31_t)0x1ed1166b, + (q31_t)0x781da256, (q31_t)0x1ec61254, (q31_t)0x7823ac1d, (q31_t)0x1ebb0d0d, + (q31_t)0x7829b3b9, (q31_t)0x1eb00696, (q31_t)0x782fb92a, (q31_t)0x1ea4fef0, + (q31_t)0x7835bc71, (q31_t)0x1e99f61d, (q31_t)0x783bbd8e, (q31_t)0x1e8eec1b, + (q31_t)0x7841bc7f, (q31_t)0x1e83e0eb, (q31_t)0x7847b946, (q31_t)0x1e78d48e, + (q31_t)0x784db3e0, (q31_t)0x1e6dc705, (q31_t)0x7853ac4f, (q31_t)0x1e62b84f, + (q31_t)0x7859a292, (q31_t)0x1e57a86d, (q31_t)0x785f96a9, (q31_t)0x1e4c9760, + (q31_t)0x78658894, (q31_t)0x1e418528, (q31_t)0x786b7852, (q31_t)0x1e3671c5, + (q31_t)0x787165e3, (q31_t)0x1e2b5d38, (q31_t)0x78775147, (q31_t)0x1e204781, + (q31_t)0x787d3a7e, (q31_t)0x1e1530a1, (q31_t)0x78832187, (q31_t)0x1e0a1898, + (q31_t)0x78890663, (q31_t)0x1dfeff67, (q31_t)0x788ee910, (q31_t)0x1df3e50d, + (q31_t)0x7894c98f, (q31_t)0x1de8c98c, (q31_t)0x789aa7e0, (q31_t)0x1dddace4, + (q31_t)0x78a08402, (q31_t)0x1dd28f15, (q31_t)0x78a65df6, (q31_t)0x1dc7701f, + (q31_t)0x78ac35ba, (q31_t)0x1dbc5004, (q31_t)0x78b20b4f, (q31_t)0x1db12ec3, + (q31_t)0x78b7deb4, (q31_t)0x1da60c5d, (q31_t)0x78bdafea, (q31_t)0x1d9ae8d2, + (q31_t)0x78c37eef, (q31_t)0x1d8fc424, (q31_t)0x78c94bc4, (q31_t)0x1d849e51, + (q31_t)0x78cf1669, (q31_t)0x1d79775c, (q31_t)0x78d4dedd, (q31_t)0x1d6e4f43, + (q31_t)0x78daa520, (q31_t)0x1d632608, (q31_t)0x78e06932, (q31_t)0x1d57fbaa, + (q31_t)0x78e62b13, (q31_t)0x1d4cd02c, (q31_t)0x78ebeac2, (q31_t)0x1d41a38c, + (q31_t)0x78f1a840, (q31_t)0x1d3675cb, (q31_t)0x78f7638b, (q31_t)0x1d2b46ea, + (q31_t)0x78fd1ca4, (q31_t)0x1d2016e9, (q31_t)0x7902d38b, (q31_t)0x1d14e5c9, + (q31_t)0x7908883f, (q31_t)0x1d09b389, (q31_t)0x790e3ac0, (q31_t)0x1cfe802b, + (q31_t)0x7913eb0e, (q31_t)0x1cf34baf, (q31_t)0x79199929, (q31_t)0x1ce81615, + (q31_t)0x791f4510, (q31_t)0x1cdcdf5e, (q31_t)0x7924eec3, (q31_t)0x1cd1a78a, + (q31_t)0x792a9642, (q31_t)0x1cc66e99, (q31_t)0x79303b8e, (q31_t)0x1cbb348d, + (q31_t)0x7935dea4, (q31_t)0x1caff965, (q31_t)0x793b7f86, (q31_t)0x1ca4bd21, + (q31_t)0x79411e33, (q31_t)0x1c997fc4, (q31_t)0x7946baac, (q31_t)0x1c8e414b, + (q31_t)0x794c54ee, (q31_t)0x1c8301b9, (q31_t)0x7951ecfc, (q31_t)0x1c77c10e, + (q31_t)0x795782d3, (q31_t)0x1c6c7f4a, (q31_t)0x795d1675, (q31_t)0x1c613c6d, + (q31_t)0x7962a7e0, (q31_t)0x1c55f878, (q31_t)0x79683715, (q31_t)0x1c4ab36b, + (q31_t)0x796dc414, (q31_t)0x1c3f6d47, (q31_t)0x79734edc, (q31_t)0x1c34260c, + (q31_t)0x7978d76c, (q31_t)0x1c28ddbb, (q31_t)0x797e5dc6, (q31_t)0x1c1d9454, + (q31_t)0x7983e1e8, (q31_t)0x1c1249d8, (q31_t)0x798963d2, (q31_t)0x1c06fe46, + (q31_t)0x798ee385, (q31_t)0x1bfbb1a0, (q31_t)0x799460ff, (q31_t)0x1bf063e6, + (q31_t)0x7999dc42, (q31_t)0x1be51518, (q31_t)0x799f554b, (q31_t)0x1bd9c537, + (q31_t)0x79a4cc1c, (q31_t)0x1bce7442, (q31_t)0x79aa40b4, (q31_t)0x1bc3223c, + (q31_t)0x79afb313, (q31_t)0x1bb7cf23, (q31_t)0x79b52339, (q31_t)0x1bac7af9, + (q31_t)0x79ba9125, (q31_t)0x1ba125bd, (q31_t)0x79bffcd7, (q31_t)0x1b95cf71, + (q31_t)0x79c5664f, (q31_t)0x1b8a7815, (q31_t)0x79cacd8d, (q31_t)0x1b7f1fa9, + (q31_t)0x79d03291, (q31_t)0x1b73c62d, (q31_t)0x79d5955a, (q31_t)0x1b686ba3, + (q31_t)0x79daf5e8, (q31_t)0x1b5d100a, (q31_t)0x79e0543c, (q31_t)0x1b51b363, + (q31_t)0x79e5b054, (q31_t)0x1b4655ae, (q31_t)0x79eb0a31, (q31_t)0x1b3af6ec, + (q31_t)0x79f061d2, (q31_t)0x1b2f971e, (q31_t)0x79f5b737, (q31_t)0x1b243643, + (q31_t)0x79fb0a60, (q31_t)0x1b18d45c, (q31_t)0x7a005b4d, (q31_t)0x1b0d716a, + (q31_t)0x7a05a9fd, (q31_t)0x1b020d6c, (q31_t)0x7a0af671, (q31_t)0x1af6a865, + (q31_t)0x7a1040a8, (q31_t)0x1aeb4253, (q31_t)0x7a1588a2, (q31_t)0x1adfdb37, + (q31_t)0x7a1ace5f, (q31_t)0x1ad47312, (q31_t)0x7a2011de, (q31_t)0x1ac909e5, + (q31_t)0x7a25531f, (q31_t)0x1abd9faf, (q31_t)0x7a2a9223, (q31_t)0x1ab23471, + (q31_t)0x7a2fcee8, (q31_t)0x1aa6c82b, (q31_t)0x7a350970, (q31_t)0x1a9b5adf, + (q31_t)0x7a3a41b9, (q31_t)0x1a8fec8c, (q31_t)0x7a3f77c3, (q31_t)0x1a847d33, + (q31_t)0x7a44ab8e, (q31_t)0x1a790cd4, (q31_t)0x7a49dd1a, (q31_t)0x1a6d9b70, + (q31_t)0x7a4f0c67, (q31_t)0x1a622907, (q31_t)0x7a543974, (q31_t)0x1a56b599, + (q31_t)0x7a596442, (q31_t)0x1a4b4128, (q31_t)0x7a5e8cd0, (q31_t)0x1a3fcbb3, + (q31_t)0x7a63b31d, (q31_t)0x1a34553b, (q31_t)0x7a68d72b, (q31_t)0x1a28ddc0, + (q31_t)0x7a6df8f8, (q31_t)0x1a1d6544, (q31_t)0x7a731884, (q31_t)0x1a11ebc5, + (q31_t)0x7a7835cf, (q31_t)0x1a067145, (q31_t)0x7a7d50da, (q31_t)0x19faf5c5, + (q31_t)0x7a8269a3, (q31_t)0x19ef7944, (q31_t)0x7a87802a, (q31_t)0x19e3fbc3, + (q31_t)0x7a8c9470, (q31_t)0x19d87d42, (q31_t)0x7a91a674, (q31_t)0x19ccfdc2, + (q31_t)0x7a96b636, (q31_t)0x19c17d44, (q31_t)0x7a9bc3b6, (q31_t)0x19b5fbc8, + (q31_t)0x7aa0cef3, (q31_t)0x19aa794d, (q31_t)0x7aa5d7ee, (q31_t)0x199ef5d6, + (q31_t)0x7aaadea6, (q31_t)0x19937161, (q31_t)0x7aafe31b, (q31_t)0x1987ebf0, + (q31_t)0x7ab4e54c, (q31_t)0x197c6584, (q31_t)0x7ab9e53a, (q31_t)0x1970de1b, + (q31_t)0x7abee2e5, (q31_t)0x196555b8, (q31_t)0x7ac3de4c, (q31_t)0x1959cc5a, + (q31_t)0x7ac8d76f, (q31_t)0x194e4201, (q31_t)0x7acdce4d, (q31_t)0x1942b6af, + (q31_t)0x7ad2c2e8, (q31_t)0x19372a64, (q31_t)0x7ad7b53d, (q31_t)0x192b9d1f, + (q31_t)0x7adca54e, (q31_t)0x19200ee3, (q31_t)0x7ae1931a, (q31_t)0x19147fae, + (q31_t)0x7ae67ea1, (q31_t)0x1908ef82, (q31_t)0x7aeb67e3, (q31_t)0x18fd5e5f, + (q31_t)0x7af04edf, (q31_t)0x18f1cc45, (q31_t)0x7af53395, (q31_t)0x18e63935, + (q31_t)0x7afa1605, (q31_t)0x18daa52f, (q31_t)0x7afef630, (q31_t)0x18cf1034, + (q31_t)0x7b03d414, (q31_t)0x18c37a44, (q31_t)0x7b08afb2, (q31_t)0x18b7e35f, + (q31_t)0x7b0d8909, (q31_t)0x18ac4b87, (q31_t)0x7b126019, (q31_t)0x18a0b2bb, + (q31_t)0x7b1734e2, (q31_t)0x189518fc, (q31_t)0x7b1c0764, (q31_t)0x18897e4a, + (q31_t)0x7b20d79e, (q31_t)0x187de2a7, (q31_t)0x7b25a591, (q31_t)0x18724611, + (q31_t)0x7b2a713d, (q31_t)0x1866a88a, (q31_t)0x7b2f3aa0, (q31_t)0x185b0a13, + (q31_t)0x7b3401bb, (q31_t)0x184f6aab, (q31_t)0x7b38c68e, (q31_t)0x1843ca53, + (q31_t)0x7b3d8918, (q31_t)0x1838290c, (q31_t)0x7b42495a, (q31_t)0x182c86d5, + (q31_t)0x7b470753, (q31_t)0x1820e3b0, (q31_t)0x7b4bc303, (q31_t)0x18153f9d, + (q31_t)0x7b507c69, (q31_t)0x18099a9c, (q31_t)0x7b553386, (q31_t)0x17fdf4ae, + (q31_t)0x7b59e85a, (q31_t)0x17f24dd3, (q31_t)0x7b5e9ae4, (q31_t)0x17e6a60c, + (q31_t)0x7b634b23, (q31_t)0x17dafd59, (q31_t)0x7b67f919, (q31_t)0x17cf53bb, + (q31_t)0x7b6ca4c4, (q31_t)0x17c3a931, (q31_t)0x7b714e25, (q31_t)0x17b7fdbd, + (q31_t)0x7b75f53c, (q31_t)0x17ac515f, (q31_t)0x7b7a9a07, (q31_t)0x17a0a417, + (q31_t)0x7b7f3c87, (q31_t)0x1794f5e6, (q31_t)0x7b83dcbc, (q31_t)0x178946cc, + (q31_t)0x7b887aa6, (q31_t)0x177d96ca, (q31_t)0x7b8d1644, (q31_t)0x1771e5e0, + (q31_t)0x7b91af97, (q31_t)0x1766340f, (q31_t)0x7b96469d, (q31_t)0x175a8157, + (q31_t)0x7b9adb57, (q31_t)0x174ecdb8, (q31_t)0x7b9f6dc5, (q31_t)0x17431933, + (q31_t)0x7ba3fde7, (q31_t)0x173763c9, (q31_t)0x7ba88bbc, (q31_t)0x172bad7a, + (q31_t)0x7bad1744, (q31_t)0x171ff646, (q31_t)0x7bb1a080, (q31_t)0x17143e2d, + (q31_t)0x7bb6276e, (q31_t)0x17088531, (q31_t)0x7bbaac0e, (q31_t)0x16fccb51, + (q31_t)0x7bbf2e62, (q31_t)0x16f1108f, (q31_t)0x7bc3ae67, (q31_t)0x16e554ea, + (q31_t)0x7bc82c1f, (q31_t)0x16d99864, (q31_t)0x7bcca789, (q31_t)0x16cddafb, + (q31_t)0x7bd120a4, (q31_t)0x16c21cb2, (q31_t)0x7bd59771, (q31_t)0x16b65d88, + (q31_t)0x7bda0bf0, (q31_t)0x16aa9d7e, (q31_t)0x7bde7e20, (q31_t)0x169edc94, + (q31_t)0x7be2ee01, (q31_t)0x16931acb, (q31_t)0x7be75b93, (q31_t)0x16875823, + (q31_t)0x7bebc6d5, (q31_t)0x167b949d, (q31_t)0x7bf02fc9, (q31_t)0x166fd039, + (q31_t)0x7bf4966c, (q31_t)0x16640af7, (q31_t)0x7bf8fac0, (q31_t)0x165844d8, + (q31_t)0x7bfd5cc4, (q31_t)0x164c7ddd, (q31_t)0x7c01bc78, (q31_t)0x1640b606, + (q31_t)0x7c0619dc, (q31_t)0x1634ed53, (q31_t)0x7c0a74f0, (q31_t)0x162923c5, + (q31_t)0x7c0ecdb2, (q31_t)0x161d595d, (q31_t)0x7c132424, (q31_t)0x16118e1a, + (q31_t)0x7c177845, (q31_t)0x1605c1fd, (q31_t)0x7c1bca16, (q31_t)0x15f9f507, + (q31_t)0x7c201994, (q31_t)0x15ee2738, (q31_t)0x7c2466c2, (q31_t)0x15e25890, + (q31_t)0x7c28b19e, (q31_t)0x15d68911, (q31_t)0x7c2cfa28, (q31_t)0x15cab8ba, + (q31_t)0x7c314060, (q31_t)0x15bee78c, (q31_t)0x7c358446, (q31_t)0x15b31587, + (q31_t)0x7c39c5da, (q31_t)0x15a742ac, (q31_t)0x7c3e051b, (q31_t)0x159b6efb, + (q31_t)0x7c42420a, (q31_t)0x158f9a76, (q31_t)0x7c467ca6, (q31_t)0x1583c51b, + (q31_t)0x7c4ab4ef, (q31_t)0x1577eeec, (q31_t)0x7c4eeae5, (q31_t)0x156c17e9, + (q31_t)0x7c531e88, (q31_t)0x15604013, (q31_t)0x7c574fd8, (q31_t)0x1554676a, + (q31_t)0x7c5b7ed4, (q31_t)0x15488dee, (q31_t)0x7c5fab7c, (q31_t)0x153cb3a0, + (q31_t)0x7c63d5d1, (q31_t)0x1530d881, (q31_t)0x7c67fdd1, (q31_t)0x1524fc90, + (q31_t)0x7c6c237e, (q31_t)0x15191fcf, (q31_t)0x7c7046d6, (q31_t)0x150d423d, + (q31_t)0x7c7467d9, (q31_t)0x150163dc, (q31_t)0x7c788688, (q31_t)0x14f584ac, + (q31_t)0x7c7ca2e2, (q31_t)0x14e9a4ac, (q31_t)0x7c80bce7, (q31_t)0x14ddc3de, + (q31_t)0x7c84d496, (q31_t)0x14d1e242, (q31_t)0x7c88e9f1, (q31_t)0x14c5ffd9, + (q31_t)0x7c8cfcf6, (q31_t)0x14ba1ca3, (q31_t)0x7c910da5, (q31_t)0x14ae38a0, + (q31_t)0x7c951bff, (q31_t)0x14a253d1, (q31_t)0x7c992803, (q31_t)0x14966e36, + (q31_t)0x7c9d31b0, (q31_t)0x148a87d1, (q31_t)0x7ca13908, (q31_t)0x147ea0a0, + (q31_t)0x7ca53e09, (q31_t)0x1472b8a5, (q31_t)0x7ca940b3, (q31_t)0x1466cfe1, + (q31_t)0x7cad4107, (q31_t)0x145ae653, (q31_t)0x7cb13f04, (q31_t)0x144efbfc, + (q31_t)0x7cb53aaa, (q31_t)0x144310dd, (q31_t)0x7cb933f9, (q31_t)0x143724f5, + (q31_t)0x7cbd2af0, (q31_t)0x142b3846, (q31_t)0x7cc11f90, (q31_t)0x141f4ad1, + (q31_t)0x7cc511d9, (q31_t)0x14135c94, (q31_t)0x7cc901c9, (q31_t)0x14076d91, + (q31_t)0x7cccef62, (q31_t)0x13fb7dc9, (q31_t)0x7cd0daa2, (q31_t)0x13ef8d3c, + (q31_t)0x7cd4c38b, (q31_t)0x13e39be9, (q31_t)0x7cd8aa1b, (q31_t)0x13d7a9d3, + (q31_t)0x7cdc8e52, (q31_t)0x13cbb6f8, (q31_t)0x7ce07031, (q31_t)0x13bfc35b, + (q31_t)0x7ce44fb7, (q31_t)0x13b3cefa, (q31_t)0x7ce82ce4, (q31_t)0x13a7d9d7, + (q31_t)0x7cec07b8, (q31_t)0x139be3f2, (q31_t)0x7cefe032, (q31_t)0x138fed4b, + (q31_t)0x7cf3b653, (q31_t)0x1383f5e3, (q31_t)0x7cf78a1b, (q31_t)0x1377fdbb, + (q31_t)0x7cfb5b89, (q31_t)0x136c04d2, (q31_t)0x7cff2a9d, (q31_t)0x13600b2a, + (q31_t)0x7d02f757, (q31_t)0x135410c3, (q31_t)0x7d06c1b6, (q31_t)0x1348159d, + (q31_t)0x7d0a89bc, (q31_t)0x133c19b8, (q31_t)0x7d0e4f67, (q31_t)0x13301d16, + (q31_t)0x7d1212b7, (q31_t)0x13241fb6, (q31_t)0x7d15d3ad, (q31_t)0x1318219a, + (q31_t)0x7d199248, (q31_t)0x130c22c1, (q31_t)0x7d1d4e88, (q31_t)0x1300232c, + (q31_t)0x7d21086c, (q31_t)0x12f422db, (q31_t)0x7d24bff6, (q31_t)0x12e821cf, + (q31_t)0x7d287523, (q31_t)0x12dc2009, (q31_t)0x7d2c27f6, (q31_t)0x12d01d89, + (q31_t)0x7d2fd86c, (q31_t)0x12c41a4f, (q31_t)0x7d338687, (q31_t)0x12b8165b, + (q31_t)0x7d373245, (q31_t)0x12ac11af, (q31_t)0x7d3adba7, (q31_t)0x12a00c4b, + (q31_t)0x7d3e82ae, (q31_t)0x1294062f, (q31_t)0x7d422757, (q31_t)0x1287ff5b, + (q31_t)0x7d45c9a4, (q31_t)0x127bf7d1, (q31_t)0x7d496994, (q31_t)0x126fef90, + (q31_t)0x7d4d0728, (q31_t)0x1263e699, (q31_t)0x7d50a25e, (q31_t)0x1257dced, + (q31_t)0x7d543b37, (q31_t)0x124bd28c, (q31_t)0x7d57d1b3, (q31_t)0x123fc776, + (q31_t)0x7d5b65d2, (q31_t)0x1233bbac, (q31_t)0x7d5ef793, (q31_t)0x1227af2e, + (q31_t)0x7d6286f6, (q31_t)0x121ba1fd, (q31_t)0x7d6613fb, (q31_t)0x120f941a, + (q31_t)0x7d699ea3, (q31_t)0x12038584, (q31_t)0x7d6d26ec, (q31_t)0x11f7763c, + (q31_t)0x7d70acd7, (q31_t)0x11eb6643, (q31_t)0x7d743064, (q31_t)0x11df5599, + (q31_t)0x7d77b192, (q31_t)0x11d3443f, (q31_t)0x7d7b3061, (q31_t)0x11c73235, + (q31_t)0x7d7eacd2, (q31_t)0x11bb1f7c, (q31_t)0x7d8226e4, (q31_t)0x11af0c13, + (q31_t)0x7d859e96, (q31_t)0x11a2f7fc, (q31_t)0x7d8913ea, (q31_t)0x1196e337, + (q31_t)0x7d8c86de, (q31_t)0x118acdc4, (q31_t)0x7d8ff772, (q31_t)0x117eb7a4, + (q31_t)0x7d9365a8, (q31_t)0x1172a0d7, (q31_t)0x7d96d17d, (q31_t)0x1166895f, + (q31_t)0x7d9a3af2, (q31_t)0x115a713a, (q31_t)0x7d9da208, (q31_t)0x114e586a, + (q31_t)0x7da106bd, (q31_t)0x11423ef0, (q31_t)0x7da46912, (q31_t)0x113624cb, + (q31_t)0x7da7c907, (q31_t)0x112a09fc, (q31_t)0x7dab269b, (q31_t)0x111dee84, + (q31_t)0x7dae81cf, (q31_t)0x1111d263, (q31_t)0x7db1daa2, (q31_t)0x1105b599, + (q31_t)0x7db53113, (q31_t)0x10f99827, (q31_t)0x7db88524, (q31_t)0x10ed7a0e, + (q31_t)0x7dbbd6d4, (q31_t)0x10e15b4e, (q31_t)0x7dbf2622, (q31_t)0x10d53be7, + (q31_t)0x7dc2730f, (q31_t)0x10c91bda, (q31_t)0x7dc5bd9b, (q31_t)0x10bcfb28, + (q31_t)0x7dc905c5, (q31_t)0x10b0d9d0, (q31_t)0x7dcc4b8d, (q31_t)0x10a4b7d3, + (q31_t)0x7dcf8ef3, (q31_t)0x10989532, (q31_t)0x7dd2cff7, (q31_t)0x108c71ee, + (q31_t)0x7dd60e99, (q31_t)0x10804e06, (q31_t)0x7dd94ad8, (q31_t)0x1074297b, + (q31_t)0x7ddc84b5, (q31_t)0x1068044e, (q31_t)0x7ddfbc30, (q31_t)0x105bde7f, + (q31_t)0x7de2f148, (q31_t)0x104fb80e, (q31_t)0x7de623fd, (q31_t)0x104390fd, + (q31_t)0x7de9544f, (q31_t)0x1037694b, (q31_t)0x7dec823e, (q31_t)0x102b40f8, + (q31_t)0x7defadca, (q31_t)0x101f1807, (q31_t)0x7df2d6f3, (q31_t)0x1012ee76, + (q31_t)0x7df5fdb8, (q31_t)0x1006c446, (q31_t)0x7df9221a, (q31_t)0xffa9979, + (q31_t)0x7dfc4418, (q31_t)0xfee6e0d, (q31_t)0x7dff63b2, (q31_t)0xfe24205, + (q31_t)0x7e0280e9, (q31_t)0xfd6155f, (q31_t)0x7e059bbb, (q31_t)0xfc9e81e, + (q31_t)0x7e08b42a, (q31_t)0xfbdba40, (q31_t)0x7e0bca34, (q31_t)0xfb18bc8, + (q31_t)0x7e0eddd9, (q31_t)0xfa55cb4, (q31_t)0x7e11ef1b, (q31_t)0xf992d06, + (q31_t)0x7e14fdf7, (q31_t)0xf8cfcbe, (q31_t)0x7e180a6f, (q31_t)0xf80cbdc, + (q31_t)0x7e1b1482, (q31_t)0xf749a61, (q31_t)0x7e1e1c30, (q31_t)0xf68684e, + (q31_t)0x7e212179, (q31_t)0xf5c35a3, (q31_t)0x7e24245d, (q31_t)0xf500260, + (q31_t)0x7e2724db, (q31_t)0xf43ce86, (q31_t)0x7e2a22f4, (q31_t)0xf379a16, + (q31_t)0x7e2d1ea8, (q31_t)0xf2b650f, (q31_t)0x7e3017f6, (q31_t)0xf1f2f73, + (q31_t)0x7e330ede, (q31_t)0xf12f941, (q31_t)0x7e360360, (q31_t)0xf06c27a, + (q31_t)0x7e38f57c, (q31_t)0xefa8b20, (q31_t)0x7e3be532, (q31_t)0xeee5331, + (q31_t)0x7e3ed282, (q31_t)0xee21aaf, (q31_t)0x7e41bd6c, (q31_t)0xed5e19a, + (q31_t)0x7e44a5ef, (q31_t)0xec9a7f3, (q31_t)0x7e478c0b, (q31_t)0xebd6db9, + (q31_t)0x7e4a6fc1, (q31_t)0xeb132ef, (q31_t)0x7e4d5110, (q31_t)0xea4f793, + (q31_t)0x7e502ff9, (q31_t)0xe98bba7, (q31_t)0x7e530c7a, (q31_t)0xe8c7f2a, + (q31_t)0x7e55e694, (q31_t)0xe80421e, (q31_t)0x7e58be47, (q31_t)0xe740483, + (q31_t)0x7e5b9392, (q31_t)0xe67c65a, (q31_t)0x7e5e6676, (q31_t)0xe5b87a2, + (q31_t)0x7e6136f3, (q31_t)0xe4f485c, (q31_t)0x7e640507, (q31_t)0xe430889, + (q31_t)0x7e66d0b4, (q31_t)0xe36c82a, (q31_t)0x7e6999fa, (q31_t)0xe2a873e, + (q31_t)0x7e6c60d7, (q31_t)0xe1e45c6, (q31_t)0x7e6f254c, (q31_t)0xe1203c3, + (q31_t)0x7e71e759, (q31_t)0xe05c135, (q31_t)0x7e74a6fd, (q31_t)0xdf97e1d, + (q31_t)0x7e77643a, (q31_t)0xded3a7b, (q31_t)0x7e7a1f0d, (q31_t)0xde0f64f, + (q31_t)0x7e7cd778, (q31_t)0xdd4b19a, (q31_t)0x7e7f8d7b, (q31_t)0xdc86c5d, + (q31_t)0x7e824114, (q31_t)0xdbc2698, (q31_t)0x7e84f245, (q31_t)0xdafe04b, + (q31_t)0x7e87a10c, (q31_t)0xda39978, (q31_t)0x7e8a4d6a, (q31_t)0xd97521d, + (q31_t)0x7e8cf75f, (q31_t)0xd8b0a3d, (q31_t)0x7e8f9eeb, (q31_t)0xd7ec1d6, + (q31_t)0x7e92440d, (q31_t)0xd7278eb, (q31_t)0x7e94e6c6, (q31_t)0xd662f7b, + (q31_t)0x7e978715, (q31_t)0xd59e586, (q31_t)0x7e9a24fb, (q31_t)0xd4d9b0e, + (q31_t)0x7e9cc076, (q31_t)0xd415013, (q31_t)0x7e9f5988, (q31_t)0xd350495, + (q31_t)0x7ea1f02f, (q31_t)0xd28b894, (q31_t)0x7ea4846c, (q31_t)0xd1c6c11, + (q31_t)0x7ea7163f, (q31_t)0xd101f0e, (q31_t)0x7ea9a5a8, (q31_t)0xd03d189, + (q31_t)0x7eac32a6, (q31_t)0xcf78383, (q31_t)0x7eaebd3a, (q31_t)0xceb34fe, + (q31_t)0x7eb14563, (q31_t)0xcdee5f9, (q31_t)0x7eb3cb21, (q31_t)0xcd29676, + (q31_t)0x7eb64e75, (q31_t)0xcc64673, (q31_t)0x7eb8cf5d, (q31_t)0xcb9f5f3, + (q31_t)0x7ebb4ddb, (q31_t)0xcada4f5, (q31_t)0x7ebdc9ed, (q31_t)0xca1537a, + (q31_t)0x7ec04394, (q31_t)0xc950182, (q31_t)0x7ec2bad0, (q31_t)0xc88af0e, + (q31_t)0x7ec52fa0, (q31_t)0xc7c5c1e, (q31_t)0x7ec7a205, (q31_t)0xc7008b3, + (q31_t)0x7eca11fe, (q31_t)0xc63b4ce, (q31_t)0x7ecc7f8b, (q31_t)0xc57606e, + (q31_t)0x7eceeaad, (q31_t)0xc4b0b94, (q31_t)0x7ed15363, (q31_t)0xc3eb641, + (q31_t)0x7ed3b9ad, (q31_t)0xc326075, (q31_t)0x7ed61d8a, (q31_t)0xc260a31, + (q31_t)0x7ed87efc, (q31_t)0xc19b374, (q31_t)0x7edade01, (q31_t)0xc0d5c41, + (q31_t)0x7edd3a9a, (q31_t)0xc010496, (q31_t)0x7edf94c7, (q31_t)0xbf4ac75, + (q31_t)0x7ee1ec87, (q31_t)0xbe853de, (q31_t)0x7ee441da, (q31_t)0xbdbfad1, + (q31_t)0x7ee694c1, (q31_t)0xbcfa150, (q31_t)0x7ee8e53a, (q31_t)0xbc34759, + (q31_t)0x7eeb3347, (q31_t)0xbb6ecef, (q31_t)0x7eed7ee7, (q31_t)0xbaa9211, + (q31_t)0x7eefc81a, (q31_t)0xb9e36c0, (q31_t)0x7ef20ee0, (q31_t)0xb91dafc, + (q31_t)0x7ef45338, (q31_t)0xb857ec7, (q31_t)0x7ef69523, (q31_t)0xb79221f, + (q31_t)0x7ef8d4a1, (q31_t)0xb6cc506, (q31_t)0x7efb11b1, (q31_t)0xb60677c, + (q31_t)0x7efd4c54, (q31_t)0xb540982, (q31_t)0x7eff8489, (q31_t)0xb47ab19, + (q31_t)0x7f01ba50, (q31_t)0xb3b4c40, (q31_t)0x7f03eda9, (q31_t)0xb2eecf8, + (q31_t)0x7f061e95, (q31_t)0xb228d42, (q31_t)0x7f084d12, (q31_t)0xb162d1d, + (q31_t)0x7f0a7921, (q31_t)0xb09cc8c, (q31_t)0x7f0ca2c2, (q31_t)0xafd6b8d, + (q31_t)0x7f0ec9f5, (q31_t)0xaf10a22, (q31_t)0x7f10eeb9, (q31_t)0xae4a84b, + (q31_t)0x7f13110f, (q31_t)0xad84609, (q31_t)0x7f1530f7, (q31_t)0xacbe35b, + (q31_t)0x7f174e70, (q31_t)0xabf8043, (q31_t)0x7f19697a, (q31_t)0xab31cc1, + (q31_t)0x7f1b8215, (q31_t)0xaa6b8d5, (q31_t)0x7f1d9842, (q31_t)0xa9a5480, + (q31_t)0x7f1fabff, (q31_t)0xa8defc3, (q31_t)0x7f21bd4e, (q31_t)0xa818a9d, + (q31_t)0x7f23cc2e, (q31_t)0xa752510, (q31_t)0x7f25d89e, (q31_t)0xa68bf1b, + (q31_t)0x7f27e29f, (q31_t)0xa5c58c0, (q31_t)0x7f29ea31, (q31_t)0xa4ff1fe, + (q31_t)0x7f2bef53, (q31_t)0xa438ad7, (q31_t)0x7f2df206, (q31_t)0xa37234a, + (q31_t)0x7f2ff24a, (q31_t)0xa2abb59, (q31_t)0x7f31f01d, (q31_t)0xa1e5303, + (q31_t)0x7f33eb81, (q31_t)0xa11ea49, (q31_t)0x7f35e476, (q31_t)0xa05812c, + (q31_t)0x7f37dafa, (q31_t)0x9f917ac, (q31_t)0x7f39cf0e, (q31_t)0x9ecadc9, + (q31_t)0x7f3bc0b3, (q31_t)0x9e04385, (q31_t)0x7f3dafe7, (q31_t)0x9d3d8df, + (q31_t)0x7f3f9cab, (q31_t)0x9c76dd8, (q31_t)0x7f4186ff, (q31_t)0x9bb0271, + (q31_t)0x7f436ee3, (q31_t)0x9ae96aa, (q31_t)0x7f455456, (q31_t)0x9a22a83, + (q31_t)0x7f473759, (q31_t)0x995bdfd, (q31_t)0x7f4917eb, (q31_t)0x9895118, + (q31_t)0x7f4af60d, (q31_t)0x97ce3d5, (q31_t)0x7f4cd1be, (q31_t)0x9707635, + (q31_t)0x7f4eaafe, (q31_t)0x9640837, (q31_t)0x7f5081cd, (q31_t)0x95799dd, + (q31_t)0x7f52562c, (q31_t)0x94b2b27, (q31_t)0x7f54281a, (q31_t)0x93ebc14, + (q31_t)0x7f55f796, (q31_t)0x9324ca7, (q31_t)0x7f57c4a2, (q31_t)0x925dcdf, + (q31_t)0x7f598f3c, (q31_t)0x9196cbc, (q31_t)0x7f5b5765, (q31_t)0x90cfc40, + (q31_t)0x7f5d1d1d, (q31_t)0x9008b6a, (q31_t)0x7f5ee063, (q31_t)0x8f41a3c, + (q31_t)0x7f60a138, (q31_t)0x8e7a8b5, (q31_t)0x7f625f9b, (q31_t)0x8db36d6, + (q31_t)0x7f641b8d, (q31_t)0x8cec4a0, (q31_t)0x7f65d50d, (q31_t)0x8c25213, + (q31_t)0x7f678c1c, (q31_t)0x8b5df30, (q31_t)0x7f6940b8, (q31_t)0x8a96bf6, + (q31_t)0x7f6af2e3, (q31_t)0x89cf867, (q31_t)0x7f6ca29c, (q31_t)0x8908483, + (q31_t)0x7f6e4fe3, (q31_t)0x884104b, (q31_t)0x7f6ffab8, (q31_t)0x8779bbe, + (q31_t)0x7f71a31b, (q31_t)0x86b26de, (q31_t)0x7f73490b, (q31_t)0x85eb1ab, + (q31_t)0x7f74ec8a, (q31_t)0x8523c25, (q31_t)0x7f768d96, (q31_t)0x845c64d, + (q31_t)0x7f782c30, (q31_t)0x8395024, (q31_t)0x7f79c857, (q31_t)0x82cd9a9, + (q31_t)0x7f7b620c, (q31_t)0x82062de, (q31_t)0x7f7cf94e, (q31_t)0x813ebc2, + (q31_t)0x7f7e8e1e, (q31_t)0x8077457, (q31_t)0x7f80207b, (q31_t)0x7fafc9c, + (q31_t)0x7f81b065, (q31_t)0x7ee8493, (q31_t)0x7f833ddd, (q31_t)0x7e20c3b, + (q31_t)0x7f84c8e2, (q31_t)0x7d59396, (q31_t)0x7f865174, (q31_t)0x7c91aa3, + (q31_t)0x7f87d792, (q31_t)0x7bca163, (q31_t)0x7f895b3e, (q31_t)0x7b027d7, + (q31_t)0x7f8adc77, (q31_t)0x7a3adff, (q31_t)0x7f8c5b3d, (q31_t)0x79733dc, + (q31_t)0x7f8dd78f, (q31_t)0x78ab96e, (q31_t)0x7f8f516e, (q31_t)0x77e3eb5, + (q31_t)0x7f90c8da, (q31_t)0x771c3b3, (q31_t)0x7f923dd2, (q31_t)0x7654867, + (q31_t)0x7f93b058, (q31_t)0x758ccd2, (q31_t)0x7f952069, (q31_t)0x74c50f4, + (q31_t)0x7f968e07, (q31_t)0x73fd4cf, (q31_t)0x7f97f932, (q31_t)0x7335862, + (q31_t)0x7f9961e8, (q31_t)0x726dbae, (q31_t)0x7f9ac82c, (q31_t)0x71a5eb3, + (q31_t)0x7f9c2bfb, (q31_t)0x70de172, (q31_t)0x7f9d8d56, (q31_t)0x70163eb, + (q31_t)0x7f9eec3e, (q31_t)0x6f4e620, (q31_t)0x7fa048b2, (q31_t)0x6e86810, + (q31_t)0x7fa1a2b2, (q31_t)0x6dbe9bb, (q31_t)0x7fa2fa3d, (q31_t)0x6cf6b23, + (q31_t)0x7fa44f55, (q31_t)0x6c2ec48, (q31_t)0x7fa5a1f9, (q31_t)0x6b66d29, + (q31_t)0x7fa6f228, (q31_t)0x6a9edc9, (q31_t)0x7fa83fe3, (q31_t)0x69d6e27, + (q31_t)0x7fa98b2a, (q31_t)0x690ee44, (q31_t)0x7faad3fd, (q31_t)0x6846e1f, + (q31_t)0x7fac1a5b, (q31_t)0x677edbb, (q31_t)0x7fad5e45, (q31_t)0x66b6d16, + (q31_t)0x7fae9fbb, (q31_t)0x65eec33, (q31_t)0x7fafdebb, (q31_t)0x6526b10, + (q31_t)0x7fb11b48, (q31_t)0x645e9af, (q31_t)0x7fb2555f, (q31_t)0x6396810, + (q31_t)0x7fb38d02, (q31_t)0x62ce634, (q31_t)0x7fb4c231, (q31_t)0x620641a, + (q31_t)0x7fb5f4ea, (q31_t)0x613e1c5, (q31_t)0x7fb7252f, (q31_t)0x6075f33, + (q31_t)0x7fb852ff, (q31_t)0x5fadc66, (q31_t)0x7fb97e5a, (q31_t)0x5ee595d, + (q31_t)0x7fbaa740, (q31_t)0x5e1d61b, (q31_t)0x7fbbcdb1, (q31_t)0x5d5529e, + (q31_t)0x7fbcf1ad, (q31_t)0x5c8cee7, (q31_t)0x7fbe1334, (q31_t)0x5bc4af8, + (q31_t)0x7fbf3246, (q31_t)0x5afc6d0, (q31_t)0x7fc04ee3, (q31_t)0x5a3426f, + (q31_t)0x7fc1690a, (q31_t)0x596bdd7, (q31_t)0x7fc280bc, (q31_t)0x58a3908, + (q31_t)0x7fc395f9, (q31_t)0x57db403, (q31_t)0x7fc4a8c1, (q31_t)0x5712ec7, + (q31_t)0x7fc5b913, (q31_t)0x564a955, (q31_t)0x7fc6c6f0, (q31_t)0x55823ae, + (q31_t)0x7fc7d258, (q31_t)0x54b9dd3, (q31_t)0x7fc8db4a, (q31_t)0x53f17c3, + (q31_t)0x7fc9e1c6, (q31_t)0x532917f, (q31_t)0x7fcae5cd, (q31_t)0x5260b08, + (q31_t)0x7fcbe75e, (q31_t)0x519845e, (q31_t)0x7fcce67a, (q31_t)0x50cfd82, + (q31_t)0x7fcde320, (q31_t)0x5007674, (q31_t)0x7fcedd50, (q31_t)0x4f3ef35, + (q31_t)0x7fcfd50b, (q31_t)0x4e767c5, (q31_t)0x7fd0ca4f, (q31_t)0x4dae024, + (q31_t)0x7fd1bd1e, (q31_t)0x4ce5854, (q31_t)0x7fd2ad77, (q31_t)0x4c1d054, + (q31_t)0x7fd39b5a, (q31_t)0x4b54825, (q31_t)0x7fd486c7, (q31_t)0x4a8bfc7, + (q31_t)0x7fd56fbe, (q31_t)0x49c373c, (q31_t)0x7fd6563f, (q31_t)0x48fae83, + (q31_t)0x7fd73a4a, (q31_t)0x483259d, (q31_t)0x7fd81bdf, (q31_t)0x4769c8b, + (q31_t)0x7fd8fafe, (q31_t)0x46a134c, (q31_t)0x7fd9d7a7, (q31_t)0x45d89e2, + (q31_t)0x7fdab1d9, (q31_t)0x451004d, (q31_t)0x7fdb8996, (q31_t)0x444768d, + (q31_t)0x7fdc5edc, (q31_t)0x437eca4, (q31_t)0x7fdd31ac, (q31_t)0x42b6290, + (q31_t)0x7fde0205, (q31_t)0x41ed854, (q31_t)0x7fdecfe8, (q31_t)0x4124dee, + (q31_t)0x7fdf9b55, (q31_t)0x405c361, (q31_t)0x7fe0644b, (q31_t)0x3f938ac, + (q31_t)0x7fe12acb, (q31_t)0x3ecadcf, (q31_t)0x7fe1eed5, (q31_t)0x3e022cc, + (q31_t)0x7fe2b067, (q31_t)0x3d397a3, (q31_t)0x7fe36f84, (q31_t)0x3c70c54, + (q31_t)0x7fe42c2a, (q31_t)0x3ba80df, (q31_t)0x7fe4e659, (q31_t)0x3adf546, + (q31_t)0x7fe59e12, (q31_t)0x3a16988, (q31_t)0x7fe65354, (q31_t)0x394dda7, + (q31_t)0x7fe7061f, (q31_t)0x38851a2, (q31_t)0x7fe7b674, (q31_t)0x37bc57b, + (q31_t)0x7fe86452, (q31_t)0x36f3931, (q31_t)0x7fe90fb9, (q31_t)0x362acc5, + (q31_t)0x7fe9b8a9, (q31_t)0x3562038, (q31_t)0x7fea5f23, (q31_t)0x3499389, + (q31_t)0x7feb0326, (q31_t)0x33d06bb, (q31_t)0x7feba4b2, (q31_t)0x33079cc, + (q31_t)0x7fec43c7, (q31_t)0x323ecbe, (q31_t)0x7fece065, (q31_t)0x3175f91, + (q31_t)0x7fed7a8c, (q31_t)0x30ad245, (q31_t)0x7fee123d, (q31_t)0x2fe44dc, + (q31_t)0x7feea776, (q31_t)0x2f1b755, (q31_t)0x7fef3a39, (q31_t)0x2e529b0, + (q31_t)0x7fefca84, (q31_t)0x2d89bf0, (q31_t)0x7ff05858, (q31_t)0x2cc0e13, + (q31_t)0x7ff0e3b6, (q31_t)0x2bf801a, (q31_t)0x7ff16c9c, (q31_t)0x2b2f207, + (q31_t)0x7ff1f30b, (q31_t)0x2a663d8, (q31_t)0x7ff27703, (q31_t)0x299d590, + (q31_t)0x7ff2f884, (q31_t)0x28d472e, (q31_t)0x7ff3778e, (q31_t)0x280b8b3, + (q31_t)0x7ff3f420, (q31_t)0x2742a1f, (q31_t)0x7ff46e3c, (q31_t)0x2679b73, + (q31_t)0x7ff4e5e0, (q31_t)0x25b0caf, (q31_t)0x7ff55b0d, (q31_t)0x24e7dd4, + (q31_t)0x7ff5cdc3, (q31_t)0x241eee2, (q31_t)0x7ff63e01, (q31_t)0x2355fd9, + (q31_t)0x7ff6abc8, (q31_t)0x228d0bb, (q31_t)0x7ff71718, (q31_t)0x21c4188, + (q31_t)0x7ff77ff1, (q31_t)0x20fb240, (q31_t)0x7ff7e652, (q31_t)0x20322e3, + (q31_t)0x7ff84a3c, (q31_t)0x1f69373, (q31_t)0x7ff8abae, (q31_t)0x1ea03ef, + (q31_t)0x7ff90aaa, (q31_t)0x1dd7459, (q31_t)0x7ff9672d, (q31_t)0x1d0e4b0, + (q31_t)0x7ff9c13a, (q31_t)0x1c454f5, (q31_t)0x7ffa18cf, (q31_t)0x1b7c528, + (q31_t)0x7ffa6dec, (q31_t)0x1ab354b, (q31_t)0x7ffac092, (q31_t)0x19ea55d, + (q31_t)0x7ffb10c1, (q31_t)0x192155f, (q31_t)0x7ffb5e78, (q31_t)0x1858552, + (q31_t)0x7ffba9b8, (q31_t)0x178f536, (q31_t)0x7ffbf280, (q31_t)0x16c650b, + (q31_t)0x7ffc38d1, (q31_t)0x15fd4d2, (q31_t)0x7ffc7caa, (q31_t)0x153448c, + (q31_t)0x7ffcbe0c, (q31_t)0x146b438, (q31_t)0x7ffcfcf6, (q31_t)0x13a23d8, + (q31_t)0x7ffd3969, (q31_t)0x12d936c, (q31_t)0x7ffd7364, (q31_t)0x12102f4, + (q31_t)0x7ffdaae7, (q31_t)0x1147271, (q31_t)0x7ffddff3, (q31_t)0x107e1e3, + (q31_t)0x7ffe1288, (q31_t)0xfb514b, (q31_t)0x7ffe42a4, (q31_t)0xeec0aa, + (q31_t)0x7ffe704a, (q31_t)0xe22fff, (q31_t)0x7ffe9b77, (q31_t)0xd59f4c, + (q31_t)0x7ffec42d, (q31_t)0xc90e90, (q31_t)0x7ffeea6c, (q31_t)0xbc7dcc, + (q31_t)0x7fff0e32, (q31_t)0xafed02, (q31_t)0x7fff2f82, (q31_t)0xa35c30, + (q31_t)0x7fff4e59, (q31_t)0x96cb58, (q31_t)0x7fff6ab9, (q31_t)0x8a3a7b, + (q31_t)0x7fff84a1, (q31_t)0x7da998, (q31_t)0x7fff9c12, (q31_t)0x7118b0, + (q31_t)0x7fffb10b, (q31_t)0x6487c4, (q31_t)0x7fffc38c, (q31_t)0x57f6d4, + (q31_t)0x7fffd396, (q31_t)0x4b65e1, (q31_t)0x7fffe128, (q31_t)0x3ed4ea, + (q31_t)0x7fffec43, (q31_t)0x3243f1, (q31_t)0x7ffff4e6, (q31_t)0x25b2f7, + (q31_t)0x7ffffb11, (q31_t)0x1921fb, (q31_t)0x7ffffec4, (q31_t)0xc90fe, + (q31_t)0x7fffffff, (q31_t)0x0, (q31_t)0x7ffffec4, (q31_t)0xfff36f02, + (q31_t)0x7ffffb11, (q31_t)0xffe6de05, (q31_t)0x7ffff4e6, (q31_t)0xffda4d09, + (q31_t)0x7fffec43, (q31_t)0xffcdbc0f, (q31_t)0x7fffe128, (q31_t)0xffc12b16, + (q31_t)0x7fffd396, (q31_t)0xffb49a1f, (q31_t)0x7fffc38c, (q31_t)0xffa8092c, + (q31_t)0x7fffb10b, (q31_t)0xff9b783c, (q31_t)0x7fff9c12, (q31_t)0xff8ee750, + (q31_t)0x7fff84a1, (q31_t)0xff825668, (q31_t)0x7fff6ab9, (q31_t)0xff75c585, + (q31_t)0x7fff4e59, (q31_t)0xff6934a8, (q31_t)0x7fff2f82, (q31_t)0xff5ca3d0, + (q31_t)0x7fff0e32, (q31_t)0xff5012fe, (q31_t)0x7ffeea6c, (q31_t)0xff438234, + (q31_t)0x7ffec42d, (q31_t)0xff36f170, (q31_t)0x7ffe9b77, (q31_t)0xff2a60b4, + (q31_t)0x7ffe704a, (q31_t)0xff1dd001, (q31_t)0x7ffe42a4, (q31_t)0xff113f56, + (q31_t)0x7ffe1288, (q31_t)0xff04aeb5, (q31_t)0x7ffddff3, (q31_t)0xfef81e1d, + (q31_t)0x7ffdaae7, (q31_t)0xfeeb8d8f, (q31_t)0x7ffd7364, (q31_t)0xfedefd0c, + (q31_t)0x7ffd3969, (q31_t)0xfed26c94, (q31_t)0x7ffcfcf6, (q31_t)0xfec5dc28, + (q31_t)0x7ffcbe0c, (q31_t)0xfeb94bc8, (q31_t)0x7ffc7caa, (q31_t)0xfeacbb74, + (q31_t)0x7ffc38d1, (q31_t)0xfea02b2e, (q31_t)0x7ffbf280, (q31_t)0xfe939af5, + (q31_t)0x7ffba9b8, (q31_t)0xfe870aca, (q31_t)0x7ffb5e78, (q31_t)0xfe7a7aae, + (q31_t)0x7ffb10c1, (q31_t)0xfe6deaa1, (q31_t)0x7ffac092, (q31_t)0xfe615aa3, + (q31_t)0x7ffa6dec, (q31_t)0xfe54cab5, (q31_t)0x7ffa18cf, (q31_t)0xfe483ad8, + (q31_t)0x7ff9c13a, (q31_t)0xfe3bab0b, (q31_t)0x7ff9672d, (q31_t)0xfe2f1b50, + (q31_t)0x7ff90aaa, (q31_t)0xfe228ba7, (q31_t)0x7ff8abae, (q31_t)0xfe15fc11, + (q31_t)0x7ff84a3c, (q31_t)0xfe096c8d, (q31_t)0x7ff7e652, (q31_t)0xfdfcdd1d, + (q31_t)0x7ff77ff1, (q31_t)0xfdf04dc0, (q31_t)0x7ff71718, (q31_t)0xfde3be78, + (q31_t)0x7ff6abc8, (q31_t)0xfdd72f45, (q31_t)0x7ff63e01, (q31_t)0xfdcaa027, + (q31_t)0x7ff5cdc3, (q31_t)0xfdbe111e, (q31_t)0x7ff55b0d, (q31_t)0xfdb1822c, + (q31_t)0x7ff4e5e0, (q31_t)0xfda4f351, (q31_t)0x7ff46e3c, (q31_t)0xfd98648d, + (q31_t)0x7ff3f420, (q31_t)0xfd8bd5e1, (q31_t)0x7ff3778e, (q31_t)0xfd7f474d, + (q31_t)0x7ff2f884, (q31_t)0xfd72b8d2, (q31_t)0x7ff27703, (q31_t)0xfd662a70, + (q31_t)0x7ff1f30b, (q31_t)0xfd599c28, (q31_t)0x7ff16c9c, (q31_t)0xfd4d0df9, + (q31_t)0x7ff0e3b6, (q31_t)0xfd407fe6, (q31_t)0x7ff05858, (q31_t)0xfd33f1ed, + (q31_t)0x7fefca84, (q31_t)0xfd276410, (q31_t)0x7fef3a39, (q31_t)0xfd1ad650, + (q31_t)0x7feea776, (q31_t)0xfd0e48ab, (q31_t)0x7fee123d, (q31_t)0xfd01bb24, + (q31_t)0x7fed7a8c, (q31_t)0xfcf52dbb, (q31_t)0x7fece065, (q31_t)0xfce8a06f, + (q31_t)0x7fec43c7, (q31_t)0xfcdc1342, (q31_t)0x7feba4b2, (q31_t)0xfccf8634, + (q31_t)0x7feb0326, (q31_t)0xfcc2f945, (q31_t)0x7fea5f23, (q31_t)0xfcb66c77, + (q31_t)0x7fe9b8a9, (q31_t)0xfca9dfc8, (q31_t)0x7fe90fb9, (q31_t)0xfc9d533b, + (q31_t)0x7fe86452, (q31_t)0xfc90c6cf, (q31_t)0x7fe7b674, (q31_t)0xfc843a85, + (q31_t)0x7fe7061f, (q31_t)0xfc77ae5e, (q31_t)0x7fe65354, (q31_t)0xfc6b2259, + (q31_t)0x7fe59e12, (q31_t)0xfc5e9678, (q31_t)0x7fe4e659, (q31_t)0xfc520aba, + (q31_t)0x7fe42c2a, (q31_t)0xfc457f21, (q31_t)0x7fe36f84, (q31_t)0xfc38f3ac, + (q31_t)0x7fe2b067, (q31_t)0xfc2c685d, (q31_t)0x7fe1eed5, (q31_t)0xfc1fdd34, + (q31_t)0x7fe12acb, (q31_t)0xfc135231, (q31_t)0x7fe0644b, (q31_t)0xfc06c754, + (q31_t)0x7fdf9b55, (q31_t)0xfbfa3c9f, (q31_t)0x7fdecfe8, (q31_t)0xfbedb212, + (q31_t)0x7fde0205, (q31_t)0xfbe127ac, (q31_t)0x7fdd31ac, (q31_t)0xfbd49d70, + (q31_t)0x7fdc5edc, (q31_t)0xfbc8135c, (q31_t)0x7fdb8996, (q31_t)0xfbbb8973, + (q31_t)0x7fdab1d9, (q31_t)0xfbaeffb3, (q31_t)0x7fd9d7a7, (q31_t)0xfba2761e, + (q31_t)0x7fd8fafe, (q31_t)0xfb95ecb4, (q31_t)0x7fd81bdf, (q31_t)0xfb896375, + (q31_t)0x7fd73a4a, (q31_t)0xfb7cda63, (q31_t)0x7fd6563f, (q31_t)0xfb70517d, + (q31_t)0x7fd56fbe, (q31_t)0xfb63c8c4, (q31_t)0x7fd486c7, (q31_t)0xfb574039, + (q31_t)0x7fd39b5a, (q31_t)0xfb4ab7db, (q31_t)0x7fd2ad77, (q31_t)0xfb3e2fac, + (q31_t)0x7fd1bd1e, (q31_t)0xfb31a7ac, (q31_t)0x7fd0ca4f, (q31_t)0xfb251fdc, + (q31_t)0x7fcfd50b, (q31_t)0xfb18983b, (q31_t)0x7fcedd50, (q31_t)0xfb0c10cb, + (q31_t)0x7fcde320, (q31_t)0xfaff898c, (q31_t)0x7fcce67a, (q31_t)0xfaf3027e, + (q31_t)0x7fcbe75e, (q31_t)0xfae67ba2, (q31_t)0x7fcae5cd, (q31_t)0xfad9f4f8, + (q31_t)0x7fc9e1c6, (q31_t)0xfacd6e81, (q31_t)0x7fc8db4a, (q31_t)0xfac0e83d, + (q31_t)0x7fc7d258, (q31_t)0xfab4622d, (q31_t)0x7fc6c6f0, (q31_t)0xfaa7dc52, + (q31_t)0x7fc5b913, (q31_t)0xfa9b56ab, (q31_t)0x7fc4a8c1, (q31_t)0xfa8ed139, + (q31_t)0x7fc395f9, (q31_t)0xfa824bfd, (q31_t)0x7fc280bc, (q31_t)0xfa75c6f8, + (q31_t)0x7fc1690a, (q31_t)0xfa694229, (q31_t)0x7fc04ee3, (q31_t)0xfa5cbd91, + (q31_t)0x7fbf3246, (q31_t)0xfa503930, (q31_t)0x7fbe1334, (q31_t)0xfa43b508, + (q31_t)0x7fbcf1ad, (q31_t)0xfa373119, (q31_t)0x7fbbcdb1, (q31_t)0xfa2aad62, + (q31_t)0x7fbaa740, (q31_t)0xfa1e29e5, (q31_t)0x7fb97e5a, (q31_t)0xfa11a6a3, + (q31_t)0x7fb852ff, (q31_t)0xfa05239a, (q31_t)0x7fb7252f, (q31_t)0xf9f8a0cd, + (q31_t)0x7fb5f4ea, (q31_t)0xf9ec1e3b, (q31_t)0x7fb4c231, (q31_t)0xf9df9be6, + (q31_t)0x7fb38d02, (q31_t)0xf9d319cc, (q31_t)0x7fb2555f, (q31_t)0xf9c697f0, + (q31_t)0x7fb11b48, (q31_t)0xf9ba1651, (q31_t)0x7fafdebb, (q31_t)0xf9ad94f0, + (q31_t)0x7fae9fbb, (q31_t)0xf9a113cd, (q31_t)0x7fad5e45, (q31_t)0xf99492ea, + (q31_t)0x7fac1a5b, (q31_t)0xf9881245, (q31_t)0x7faad3fd, (q31_t)0xf97b91e1, + (q31_t)0x7fa98b2a, (q31_t)0xf96f11bc, (q31_t)0x7fa83fe3, (q31_t)0xf96291d9, + (q31_t)0x7fa6f228, (q31_t)0xf9561237, (q31_t)0x7fa5a1f9, (q31_t)0xf94992d7, + (q31_t)0x7fa44f55, (q31_t)0xf93d13b8, (q31_t)0x7fa2fa3d, (q31_t)0xf93094dd, + (q31_t)0x7fa1a2b2, (q31_t)0xf9241645, (q31_t)0x7fa048b2, (q31_t)0xf91797f0, + (q31_t)0x7f9eec3e, (q31_t)0xf90b19e0, (q31_t)0x7f9d8d56, (q31_t)0xf8fe9c15, + (q31_t)0x7f9c2bfb, (q31_t)0xf8f21e8e, (q31_t)0x7f9ac82c, (q31_t)0xf8e5a14d, + (q31_t)0x7f9961e8, (q31_t)0xf8d92452, (q31_t)0x7f97f932, (q31_t)0xf8cca79e, + (q31_t)0x7f968e07, (q31_t)0xf8c02b31, (q31_t)0x7f952069, (q31_t)0xf8b3af0c, + (q31_t)0x7f93b058, (q31_t)0xf8a7332e, (q31_t)0x7f923dd2, (q31_t)0xf89ab799, + (q31_t)0x7f90c8da, (q31_t)0xf88e3c4d, (q31_t)0x7f8f516e, (q31_t)0xf881c14b, + (q31_t)0x7f8dd78f, (q31_t)0xf8754692, (q31_t)0x7f8c5b3d, (q31_t)0xf868cc24, + (q31_t)0x7f8adc77, (q31_t)0xf85c5201, (q31_t)0x7f895b3e, (q31_t)0xf84fd829, + (q31_t)0x7f87d792, (q31_t)0xf8435e9d, (q31_t)0x7f865174, (q31_t)0xf836e55d, + (q31_t)0x7f84c8e2, (q31_t)0xf82a6c6a, (q31_t)0x7f833ddd, (q31_t)0xf81df3c5, + (q31_t)0x7f81b065, (q31_t)0xf8117b6d, (q31_t)0x7f80207b, (q31_t)0xf8050364, + (q31_t)0x7f7e8e1e, (q31_t)0xf7f88ba9, (q31_t)0x7f7cf94e, (q31_t)0xf7ec143e, + (q31_t)0x7f7b620c, (q31_t)0xf7df9d22, (q31_t)0x7f79c857, (q31_t)0xf7d32657, + (q31_t)0x7f782c30, (q31_t)0xf7c6afdc, (q31_t)0x7f768d96, (q31_t)0xf7ba39b3, + (q31_t)0x7f74ec8a, (q31_t)0xf7adc3db, (q31_t)0x7f73490b, (q31_t)0xf7a14e55, + (q31_t)0x7f71a31b, (q31_t)0xf794d922, (q31_t)0x7f6ffab8, (q31_t)0xf7886442, + (q31_t)0x7f6e4fe3, (q31_t)0xf77befb5, (q31_t)0x7f6ca29c, (q31_t)0xf76f7b7d, + (q31_t)0x7f6af2e3, (q31_t)0xf7630799, (q31_t)0x7f6940b8, (q31_t)0xf756940a, + (q31_t)0x7f678c1c, (q31_t)0xf74a20d0, (q31_t)0x7f65d50d, (q31_t)0xf73daded, + (q31_t)0x7f641b8d, (q31_t)0xf7313b60, (q31_t)0x7f625f9b, (q31_t)0xf724c92a, + (q31_t)0x7f60a138, (q31_t)0xf718574b, (q31_t)0x7f5ee063, (q31_t)0xf70be5c4, + (q31_t)0x7f5d1d1d, (q31_t)0xf6ff7496, (q31_t)0x7f5b5765, (q31_t)0xf6f303c0, + (q31_t)0x7f598f3c, (q31_t)0xf6e69344, (q31_t)0x7f57c4a2, (q31_t)0xf6da2321, + (q31_t)0x7f55f796, (q31_t)0xf6cdb359, (q31_t)0x7f54281a, (q31_t)0xf6c143ec, + (q31_t)0x7f52562c, (q31_t)0xf6b4d4d9, (q31_t)0x7f5081cd, (q31_t)0xf6a86623, + (q31_t)0x7f4eaafe, (q31_t)0xf69bf7c9, (q31_t)0x7f4cd1be, (q31_t)0xf68f89cb, + (q31_t)0x7f4af60d, (q31_t)0xf6831c2b, (q31_t)0x7f4917eb, (q31_t)0xf676aee8, + (q31_t)0x7f473759, (q31_t)0xf66a4203, (q31_t)0x7f455456, (q31_t)0xf65dd57d, + (q31_t)0x7f436ee3, (q31_t)0xf6516956, (q31_t)0x7f4186ff, (q31_t)0xf644fd8f, + (q31_t)0x7f3f9cab, (q31_t)0xf6389228, (q31_t)0x7f3dafe7, (q31_t)0xf62c2721, + (q31_t)0x7f3bc0b3, (q31_t)0xf61fbc7b, (q31_t)0x7f39cf0e, (q31_t)0xf6135237, + (q31_t)0x7f37dafa, (q31_t)0xf606e854, (q31_t)0x7f35e476, (q31_t)0xf5fa7ed4, + (q31_t)0x7f33eb81, (q31_t)0xf5ee15b7, (q31_t)0x7f31f01d, (q31_t)0xf5e1acfd, + (q31_t)0x7f2ff24a, (q31_t)0xf5d544a7, (q31_t)0x7f2df206, (q31_t)0xf5c8dcb6, + (q31_t)0x7f2bef53, (q31_t)0xf5bc7529, (q31_t)0x7f29ea31, (q31_t)0xf5b00e02, + (q31_t)0x7f27e29f, (q31_t)0xf5a3a740, (q31_t)0x7f25d89e, (q31_t)0xf59740e5, + (q31_t)0x7f23cc2e, (q31_t)0xf58adaf0, (q31_t)0x7f21bd4e, (q31_t)0xf57e7563, + (q31_t)0x7f1fabff, (q31_t)0xf572103d, (q31_t)0x7f1d9842, (q31_t)0xf565ab80, + (q31_t)0x7f1b8215, (q31_t)0xf559472b, (q31_t)0x7f19697a, (q31_t)0xf54ce33f, + (q31_t)0x7f174e70, (q31_t)0xf5407fbd, (q31_t)0x7f1530f7, (q31_t)0xf5341ca5, + (q31_t)0x7f13110f, (q31_t)0xf527b9f7, (q31_t)0x7f10eeb9, (q31_t)0xf51b57b5, + (q31_t)0x7f0ec9f5, (q31_t)0xf50ef5de, (q31_t)0x7f0ca2c2, (q31_t)0xf5029473, + (q31_t)0x7f0a7921, (q31_t)0xf4f63374, (q31_t)0x7f084d12, (q31_t)0xf4e9d2e3, + (q31_t)0x7f061e95, (q31_t)0xf4dd72be, (q31_t)0x7f03eda9, (q31_t)0xf4d11308, + (q31_t)0x7f01ba50, (q31_t)0xf4c4b3c0, (q31_t)0x7eff8489, (q31_t)0xf4b854e7, + (q31_t)0x7efd4c54, (q31_t)0xf4abf67e, (q31_t)0x7efb11b1, (q31_t)0xf49f9884, + (q31_t)0x7ef8d4a1, (q31_t)0xf4933afa, (q31_t)0x7ef69523, (q31_t)0xf486dde1, + (q31_t)0x7ef45338, (q31_t)0xf47a8139, (q31_t)0x7ef20ee0, (q31_t)0xf46e2504, + (q31_t)0x7eefc81a, (q31_t)0xf461c940, (q31_t)0x7eed7ee7, (q31_t)0xf4556def, + (q31_t)0x7eeb3347, (q31_t)0xf4491311, (q31_t)0x7ee8e53a, (q31_t)0xf43cb8a7, + (q31_t)0x7ee694c1, (q31_t)0xf4305eb0, (q31_t)0x7ee441da, (q31_t)0xf424052f, + (q31_t)0x7ee1ec87, (q31_t)0xf417ac22, (q31_t)0x7edf94c7, (q31_t)0xf40b538b, + (q31_t)0x7edd3a9a, (q31_t)0xf3fefb6a, (q31_t)0x7edade01, (q31_t)0xf3f2a3bf, + (q31_t)0x7ed87efc, (q31_t)0xf3e64c8c, (q31_t)0x7ed61d8a, (q31_t)0xf3d9f5cf, + (q31_t)0x7ed3b9ad, (q31_t)0xf3cd9f8b, (q31_t)0x7ed15363, (q31_t)0xf3c149bf, + (q31_t)0x7eceeaad, (q31_t)0xf3b4f46c, (q31_t)0x7ecc7f8b, (q31_t)0xf3a89f92, + (q31_t)0x7eca11fe, (q31_t)0xf39c4b32, (q31_t)0x7ec7a205, (q31_t)0xf38ff74d, + (q31_t)0x7ec52fa0, (q31_t)0xf383a3e2, (q31_t)0x7ec2bad0, (q31_t)0xf37750f2, + (q31_t)0x7ec04394, (q31_t)0xf36afe7e, (q31_t)0x7ebdc9ed, (q31_t)0xf35eac86, + (q31_t)0x7ebb4ddb, (q31_t)0xf3525b0b, (q31_t)0x7eb8cf5d, (q31_t)0xf3460a0d, + (q31_t)0x7eb64e75, (q31_t)0xf339b98d, (q31_t)0x7eb3cb21, (q31_t)0xf32d698a, + (q31_t)0x7eb14563, (q31_t)0xf3211a07, (q31_t)0x7eaebd3a, (q31_t)0xf314cb02, + (q31_t)0x7eac32a6, (q31_t)0xf3087c7d, (q31_t)0x7ea9a5a8, (q31_t)0xf2fc2e77, + (q31_t)0x7ea7163f, (q31_t)0xf2efe0f2, (q31_t)0x7ea4846c, (q31_t)0xf2e393ef, + (q31_t)0x7ea1f02f, (q31_t)0xf2d7476c, (q31_t)0x7e9f5988, (q31_t)0xf2cafb6b, + (q31_t)0x7e9cc076, (q31_t)0xf2beafed, (q31_t)0x7e9a24fb, (q31_t)0xf2b264f2, + (q31_t)0x7e978715, (q31_t)0xf2a61a7a, (q31_t)0x7e94e6c6, (q31_t)0xf299d085, + (q31_t)0x7e92440d, (q31_t)0xf28d8715, (q31_t)0x7e8f9eeb, (q31_t)0xf2813e2a, + (q31_t)0x7e8cf75f, (q31_t)0xf274f5c3, (q31_t)0x7e8a4d6a, (q31_t)0xf268ade3, + (q31_t)0x7e87a10c, (q31_t)0xf25c6688, (q31_t)0x7e84f245, (q31_t)0xf2501fb5, + (q31_t)0x7e824114, (q31_t)0xf243d968, (q31_t)0x7e7f8d7b, (q31_t)0xf23793a3, + (q31_t)0x7e7cd778, (q31_t)0xf22b4e66, (q31_t)0x7e7a1f0d, (q31_t)0xf21f09b1, + (q31_t)0x7e77643a, (q31_t)0xf212c585, (q31_t)0x7e74a6fd, (q31_t)0xf20681e3, + (q31_t)0x7e71e759, (q31_t)0xf1fa3ecb, (q31_t)0x7e6f254c, (q31_t)0xf1edfc3d, + (q31_t)0x7e6c60d7, (q31_t)0xf1e1ba3a, (q31_t)0x7e6999fa, (q31_t)0xf1d578c2, + (q31_t)0x7e66d0b4, (q31_t)0xf1c937d6, (q31_t)0x7e640507, (q31_t)0xf1bcf777, + (q31_t)0x7e6136f3, (q31_t)0xf1b0b7a4, (q31_t)0x7e5e6676, (q31_t)0xf1a4785e, + (q31_t)0x7e5b9392, (q31_t)0xf19839a6, (q31_t)0x7e58be47, (q31_t)0xf18bfb7d, + (q31_t)0x7e55e694, (q31_t)0xf17fbde2, (q31_t)0x7e530c7a, (q31_t)0xf17380d6, + (q31_t)0x7e502ff9, (q31_t)0xf1674459, (q31_t)0x7e4d5110, (q31_t)0xf15b086d, + (q31_t)0x7e4a6fc1, (q31_t)0xf14ecd11, (q31_t)0x7e478c0b, (q31_t)0xf1429247, + (q31_t)0x7e44a5ef, (q31_t)0xf136580d, (q31_t)0x7e41bd6c, (q31_t)0xf12a1e66, + (q31_t)0x7e3ed282, (q31_t)0xf11de551, (q31_t)0x7e3be532, (q31_t)0xf111accf, + (q31_t)0x7e38f57c, (q31_t)0xf10574e0, (q31_t)0x7e360360, (q31_t)0xf0f93d86, + (q31_t)0x7e330ede, (q31_t)0xf0ed06bf, (q31_t)0x7e3017f6, (q31_t)0xf0e0d08d, + (q31_t)0x7e2d1ea8, (q31_t)0xf0d49af1, (q31_t)0x7e2a22f4, (q31_t)0xf0c865ea, + (q31_t)0x7e2724db, (q31_t)0xf0bc317a, (q31_t)0x7e24245d, (q31_t)0xf0affda0, + (q31_t)0x7e212179, (q31_t)0xf0a3ca5d, (q31_t)0x7e1e1c30, (q31_t)0xf09797b2, + (q31_t)0x7e1b1482, (q31_t)0xf08b659f, (q31_t)0x7e180a6f, (q31_t)0xf07f3424, + (q31_t)0x7e14fdf7, (q31_t)0xf0730342, (q31_t)0x7e11ef1b, (q31_t)0xf066d2fa, + (q31_t)0x7e0eddd9, (q31_t)0xf05aa34c, (q31_t)0x7e0bca34, (q31_t)0xf04e7438, + (q31_t)0x7e08b42a, (q31_t)0xf04245c0, (q31_t)0x7e059bbb, (q31_t)0xf03617e2, + (q31_t)0x7e0280e9, (q31_t)0xf029eaa1, (q31_t)0x7dff63b2, (q31_t)0xf01dbdfb, + (q31_t)0x7dfc4418, (q31_t)0xf01191f3, (q31_t)0x7df9221a, (q31_t)0xf0056687, + (q31_t)0x7df5fdb8, (q31_t)0xeff93bba, (q31_t)0x7df2d6f3, (q31_t)0xefed118a, + (q31_t)0x7defadca, (q31_t)0xefe0e7f9, (q31_t)0x7dec823e, (q31_t)0xefd4bf08, + (q31_t)0x7de9544f, (q31_t)0xefc896b5, (q31_t)0x7de623fd, (q31_t)0xefbc6f03, + (q31_t)0x7de2f148, (q31_t)0xefb047f2, (q31_t)0x7ddfbc30, (q31_t)0xefa42181, + (q31_t)0x7ddc84b5, (q31_t)0xef97fbb2, (q31_t)0x7dd94ad8, (q31_t)0xef8bd685, + (q31_t)0x7dd60e99, (q31_t)0xef7fb1fa, (q31_t)0x7dd2cff7, (q31_t)0xef738e12, + (q31_t)0x7dcf8ef3, (q31_t)0xef676ace, (q31_t)0x7dcc4b8d, (q31_t)0xef5b482d, + (q31_t)0x7dc905c5, (q31_t)0xef4f2630, (q31_t)0x7dc5bd9b, (q31_t)0xef4304d8, + (q31_t)0x7dc2730f, (q31_t)0xef36e426, (q31_t)0x7dbf2622, (q31_t)0xef2ac419, + (q31_t)0x7dbbd6d4, (q31_t)0xef1ea4b2, (q31_t)0x7db88524, (q31_t)0xef1285f2, + (q31_t)0x7db53113, (q31_t)0xef0667d9, (q31_t)0x7db1daa2, (q31_t)0xeefa4a67, + (q31_t)0x7dae81cf, (q31_t)0xeeee2d9d, (q31_t)0x7dab269b, (q31_t)0xeee2117c, + (q31_t)0x7da7c907, (q31_t)0xeed5f604, (q31_t)0x7da46912, (q31_t)0xeec9db35, + (q31_t)0x7da106bd, (q31_t)0xeebdc110, (q31_t)0x7d9da208, (q31_t)0xeeb1a796, + (q31_t)0x7d9a3af2, (q31_t)0xeea58ec6, (q31_t)0x7d96d17d, (q31_t)0xee9976a1, + (q31_t)0x7d9365a8, (q31_t)0xee8d5f29, (q31_t)0x7d8ff772, (q31_t)0xee81485c, + (q31_t)0x7d8c86de, (q31_t)0xee75323c, (q31_t)0x7d8913ea, (q31_t)0xee691cc9, + (q31_t)0x7d859e96, (q31_t)0xee5d0804, (q31_t)0x7d8226e4, (q31_t)0xee50f3ed, + (q31_t)0x7d7eacd2, (q31_t)0xee44e084, (q31_t)0x7d7b3061, (q31_t)0xee38cdcb, + (q31_t)0x7d77b192, (q31_t)0xee2cbbc1, (q31_t)0x7d743064, (q31_t)0xee20aa67, + (q31_t)0x7d70acd7, (q31_t)0xee1499bd, (q31_t)0x7d6d26ec, (q31_t)0xee0889c4, + (q31_t)0x7d699ea3, (q31_t)0xedfc7a7c, (q31_t)0x7d6613fb, (q31_t)0xedf06be6, + (q31_t)0x7d6286f6, (q31_t)0xede45e03, (q31_t)0x7d5ef793, (q31_t)0xedd850d2, + (q31_t)0x7d5b65d2, (q31_t)0xedcc4454, (q31_t)0x7d57d1b3, (q31_t)0xedc0388a, + (q31_t)0x7d543b37, (q31_t)0xedb42d74, (q31_t)0x7d50a25e, (q31_t)0xeda82313, + (q31_t)0x7d4d0728, (q31_t)0xed9c1967, (q31_t)0x7d496994, (q31_t)0xed901070, + (q31_t)0x7d45c9a4, (q31_t)0xed84082f, (q31_t)0x7d422757, (q31_t)0xed7800a5, + (q31_t)0x7d3e82ae, (q31_t)0xed6bf9d1, (q31_t)0x7d3adba7, (q31_t)0xed5ff3b5, + (q31_t)0x7d373245, (q31_t)0xed53ee51, (q31_t)0x7d338687, (q31_t)0xed47e9a5, + (q31_t)0x7d2fd86c, (q31_t)0xed3be5b1, (q31_t)0x7d2c27f6, (q31_t)0xed2fe277, + (q31_t)0x7d287523, (q31_t)0xed23dff7, (q31_t)0x7d24bff6, (q31_t)0xed17de31, + (q31_t)0x7d21086c, (q31_t)0xed0bdd25, (q31_t)0x7d1d4e88, (q31_t)0xecffdcd4, + (q31_t)0x7d199248, (q31_t)0xecf3dd3f, (q31_t)0x7d15d3ad, (q31_t)0xece7de66, + (q31_t)0x7d1212b7, (q31_t)0xecdbe04a, (q31_t)0x7d0e4f67, (q31_t)0xeccfe2ea, + (q31_t)0x7d0a89bc, (q31_t)0xecc3e648, (q31_t)0x7d06c1b6, (q31_t)0xecb7ea63, + (q31_t)0x7d02f757, (q31_t)0xecabef3d, (q31_t)0x7cff2a9d, (q31_t)0xec9ff4d6, + (q31_t)0x7cfb5b89, (q31_t)0xec93fb2e, (q31_t)0x7cf78a1b, (q31_t)0xec880245, + (q31_t)0x7cf3b653, (q31_t)0xec7c0a1d, (q31_t)0x7cefe032, (q31_t)0xec7012b5, + (q31_t)0x7cec07b8, (q31_t)0xec641c0e, (q31_t)0x7ce82ce4, (q31_t)0xec582629, + (q31_t)0x7ce44fb7, (q31_t)0xec4c3106, (q31_t)0x7ce07031, (q31_t)0xec403ca5, + (q31_t)0x7cdc8e52, (q31_t)0xec344908, (q31_t)0x7cd8aa1b, (q31_t)0xec28562d, + (q31_t)0x7cd4c38b, (q31_t)0xec1c6417, (q31_t)0x7cd0daa2, (q31_t)0xec1072c4, + (q31_t)0x7cccef62, (q31_t)0xec048237, (q31_t)0x7cc901c9, (q31_t)0xebf8926f, + (q31_t)0x7cc511d9, (q31_t)0xebeca36c, (q31_t)0x7cc11f90, (q31_t)0xebe0b52f, + (q31_t)0x7cbd2af0, (q31_t)0xebd4c7ba, (q31_t)0x7cb933f9, (q31_t)0xebc8db0b, + (q31_t)0x7cb53aaa, (q31_t)0xebbcef23, (q31_t)0x7cb13f04, (q31_t)0xebb10404, + (q31_t)0x7cad4107, (q31_t)0xeba519ad, (q31_t)0x7ca940b3, (q31_t)0xeb99301f, + (q31_t)0x7ca53e09, (q31_t)0xeb8d475b, (q31_t)0x7ca13908, (q31_t)0xeb815f60, + (q31_t)0x7c9d31b0, (q31_t)0xeb75782f, (q31_t)0x7c992803, (q31_t)0xeb6991ca, + (q31_t)0x7c951bff, (q31_t)0xeb5dac2f, (q31_t)0x7c910da5, (q31_t)0xeb51c760, + (q31_t)0x7c8cfcf6, (q31_t)0xeb45e35d, (q31_t)0x7c88e9f1, (q31_t)0xeb3a0027, + (q31_t)0x7c84d496, (q31_t)0xeb2e1dbe, (q31_t)0x7c80bce7, (q31_t)0xeb223c22, + (q31_t)0x7c7ca2e2, (q31_t)0xeb165b54, (q31_t)0x7c788688, (q31_t)0xeb0a7b54, + (q31_t)0x7c7467d9, (q31_t)0xeafe9c24, (q31_t)0x7c7046d6, (q31_t)0xeaf2bdc3, + (q31_t)0x7c6c237e, (q31_t)0xeae6e031, (q31_t)0x7c67fdd1, (q31_t)0xeadb0370, + (q31_t)0x7c63d5d1, (q31_t)0xeacf277f, (q31_t)0x7c5fab7c, (q31_t)0xeac34c60, + (q31_t)0x7c5b7ed4, (q31_t)0xeab77212, (q31_t)0x7c574fd8, (q31_t)0xeaab9896, + (q31_t)0x7c531e88, (q31_t)0xea9fbfed, (q31_t)0x7c4eeae5, (q31_t)0xea93e817, + (q31_t)0x7c4ab4ef, (q31_t)0xea881114, (q31_t)0x7c467ca6, (q31_t)0xea7c3ae5, + (q31_t)0x7c42420a, (q31_t)0xea70658a, (q31_t)0x7c3e051b, (q31_t)0xea649105, + (q31_t)0x7c39c5da, (q31_t)0xea58bd54, (q31_t)0x7c358446, (q31_t)0xea4cea79, + (q31_t)0x7c314060, (q31_t)0xea411874, (q31_t)0x7c2cfa28, (q31_t)0xea354746, + (q31_t)0x7c28b19e, (q31_t)0xea2976ef, (q31_t)0x7c2466c2, (q31_t)0xea1da770, + (q31_t)0x7c201994, (q31_t)0xea11d8c8, (q31_t)0x7c1bca16, (q31_t)0xea060af9, + (q31_t)0x7c177845, (q31_t)0xe9fa3e03, (q31_t)0x7c132424, (q31_t)0xe9ee71e6, + (q31_t)0x7c0ecdb2, (q31_t)0xe9e2a6a3, (q31_t)0x7c0a74f0, (q31_t)0xe9d6dc3b, + (q31_t)0x7c0619dc, (q31_t)0xe9cb12ad, (q31_t)0x7c01bc78, (q31_t)0xe9bf49fa, + (q31_t)0x7bfd5cc4, (q31_t)0xe9b38223, (q31_t)0x7bf8fac0, (q31_t)0xe9a7bb28, + (q31_t)0x7bf4966c, (q31_t)0xe99bf509, (q31_t)0x7bf02fc9, (q31_t)0xe9902fc7, + (q31_t)0x7bebc6d5, (q31_t)0xe9846b63, (q31_t)0x7be75b93, (q31_t)0xe978a7dd, + (q31_t)0x7be2ee01, (q31_t)0xe96ce535, (q31_t)0x7bde7e20, (q31_t)0xe961236c, + (q31_t)0x7bda0bf0, (q31_t)0xe9556282, (q31_t)0x7bd59771, (q31_t)0xe949a278, + (q31_t)0x7bd120a4, (q31_t)0xe93de34e, (q31_t)0x7bcca789, (q31_t)0xe9322505, + (q31_t)0x7bc82c1f, (q31_t)0xe926679c, (q31_t)0x7bc3ae67, (q31_t)0xe91aab16, + (q31_t)0x7bbf2e62, (q31_t)0xe90eef71, (q31_t)0x7bbaac0e, (q31_t)0xe90334af, + (q31_t)0x7bb6276e, (q31_t)0xe8f77acf, (q31_t)0x7bb1a080, (q31_t)0xe8ebc1d3, + (q31_t)0x7bad1744, (q31_t)0xe8e009ba, (q31_t)0x7ba88bbc, (q31_t)0xe8d45286, + (q31_t)0x7ba3fde7, (q31_t)0xe8c89c37, (q31_t)0x7b9f6dc5, (q31_t)0xe8bce6cd, + (q31_t)0x7b9adb57, (q31_t)0xe8b13248, (q31_t)0x7b96469d, (q31_t)0xe8a57ea9, + (q31_t)0x7b91af97, (q31_t)0xe899cbf1, (q31_t)0x7b8d1644, (q31_t)0xe88e1a20, + (q31_t)0x7b887aa6, (q31_t)0xe8826936, (q31_t)0x7b83dcbc, (q31_t)0xe876b934, + (q31_t)0x7b7f3c87, (q31_t)0xe86b0a1a, (q31_t)0x7b7a9a07, (q31_t)0xe85f5be9, + (q31_t)0x7b75f53c, (q31_t)0xe853aea1, (q31_t)0x7b714e25, (q31_t)0xe8480243, + (q31_t)0x7b6ca4c4, (q31_t)0xe83c56cf, (q31_t)0x7b67f919, (q31_t)0xe830ac45, + (q31_t)0x7b634b23, (q31_t)0xe82502a7, (q31_t)0x7b5e9ae4, (q31_t)0xe81959f4, + (q31_t)0x7b59e85a, (q31_t)0xe80db22d, (q31_t)0x7b553386, (q31_t)0xe8020b52, + (q31_t)0x7b507c69, (q31_t)0xe7f66564, (q31_t)0x7b4bc303, (q31_t)0xe7eac063, + (q31_t)0x7b470753, (q31_t)0xe7df1c50, (q31_t)0x7b42495a, (q31_t)0xe7d3792b, + (q31_t)0x7b3d8918, (q31_t)0xe7c7d6f4, (q31_t)0x7b38c68e, (q31_t)0xe7bc35ad, + (q31_t)0x7b3401bb, (q31_t)0xe7b09555, (q31_t)0x7b2f3aa0, (q31_t)0xe7a4f5ed, + (q31_t)0x7b2a713d, (q31_t)0xe7995776, (q31_t)0x7b25a591, (q31_t)0xe78db9ef, + (q31_t)0x7b20d79e, (q31_t)0xe7821d59, (q31_t)0x7b1c0764, (q31_t)0xe77681b6, + (q31_t)0x7b1734e2, (q31_t)0xe76ae704, (q31_t)0x7b126019, (q31_t)0xe75f4d45, + (q31_t)0x7b0d8909, (q31_t)0xe753b479, (q31_t)0x7b08afb2, (q31_t)0xe7481ca1, + (q31_t)0x7b03d414, (q31_t)0xe73c85bc, (q31_t)0x7afef630, (q31_t)0xe730efcc, + (q31_t)0x7afa1605, (q31_t)0xe7255ad1, (q31_t)0x7af53395, (q31_t)0xe719c6cb, + (q31_t)0x7af04edf, (q31_t)0xe70e33bb, (q31_t)0x7aeb67e3, (q31_t)0xe702a1a1, + (q31_t)0x7ae67ea1, (q31_t)0xe6f7107e, (q31_t)0x7ae1931a, (q31_t)0xe6eb8052, + (q31_t)0x7adca54e, (q31_t)0xe6dff11d, (q31_t)0x7ad7b53d, (q31_t)0xe6d462e1, + (q31_t)0x7ad2c2e8, (q31_t)0xe6c8d59c, (q31_t)0x7acdce4d, (q31_t)0xe6bd4951, + (q31_t)0x7ac8d76f, (q31_t)0xe6b1bdff, (q31_t)0x7ac3de4c, (q31_t)0xe6a633a6, + (q31_t)0x7abee2e5, (q31_t)0xe69aaa48, (q31_t)0x7ab9e53a, (q31_t)0xe68f21e5, + (q31_t)0x7ab4e54c, (q31_t)0xe6839a7c, (q31_t)0x7aafe31b, (q31_t)0xe6781410, + (q31_t)0x7aaadea6, (q31_t)0xe66c8e9f, (q31_t)0x7aa5d7ee, (q31_t)0xe6610a2a, + (q31_t)0x7aa0cef3, (q31_t)0xe65586b3, (q31_t)0x7a9bc3b6, (q31_t)0xe64a0438, + (q31_t)0x7a96b636, (q31_t)0xe63e82bc, (q31_t)0x7a91a674, (q31_t)0xe633023e, + (q31_t)0x7a8c9470, (q31_t)0xe62782be, (q31_t)0x7a87802a, (q31_t)0xe61c043d, + (q31_t)0x7a8269a3, (q31_t)0xe61086bc, (q31_t)0x7a7d50da, (q31_t)0xe6050a3b, + (q31_t)0x7a7835cf, (q31_t)0xe5f98ebb, (q31_t)0x7a731884, (q31_t)0xe5ee143b, + (q31_t)0x7a6df8f8, (q31_t)0xe5e29abc, (q31_t)0x7a68d72b, (q31_t)0xe5d72240, + (q31_t)0x7a63b31d, (q31_t)0xe5cbaac5, (q31_t)0x7a5e8cd0, (q31_t)0xe5c0344d, + (q31_t)0x7a596442, (q31_t)0xe5b4bed8, (q31_t)0x7a543974, (q31_t)0xe5a94a67, + (q31_t)0x7a4f0c67, (q31_t)0xe59dd6f9, (q31_t)0x7a49dd1a, (q31_t)0xe5926490, + (q31_t)0x7a44ab8e, (q31_t)0xe586f32c, (q31_t)0x7a3f77c3, (q31_t)0xe57b82cd, + (q31_t)0x7a3a41b9, (q31_t)0xe5701374, (q31_t)0x7a350970, (q31_t)0xe564a521, + (q31_t)0x7a2fcee8, (q31_t)0xe55937d5, (q31_t)0x7a2a9223, (q31_t)0xe54dcb8f, + (q31_t)0x7a25531f, (q31_t)0xe5426051, (q31_t)0x7a2011de, (q31_t)0xe536f61b, + (q31_t)0x7a1ace5f, (q31_t)0xe52b8cee, (q31_t)0x7a1588a2, (q31_t)0xe52024c9, + (q31_t)0x7a1040a8, (q31_t)0xe514bdad, (q31_t)0x7a0af671, (q31_t)0xe509579b, + (q31_t)0x7a05a9fd, (q31_t)0xe4fdf294, (q31_t)0x7a005b4d, (q31_t)0xe4f28e96, + (q31_t)0x79fb0a60, (q31_t)0xe4e72ba4, (q31_t)0x79f5b737, (q31_t)0xe4dbc9bd, + (q31_t)0x79f061d2, (q31_t)0xe4d068e2, (q31_t)0x79eb0a31, (q31_t)0xe4c50914, + (q31_t)0x79e5b054, (q31_t)0xe4b9aa52, (q31_t)0x79e0543c, (q31_t)0xe4ae4c9d, + (q31_t)0x79daf5e8, (q31_t)0xe4a2eff6, (q31_t)0x79d5955a, (q31_t)0xe497945d, + (q31_t)0x79d03291, (q31_t)0xe48c39d3, (q31_t)0x79cacd8d, (q31_t)0xe480e057, + (q31_t)0x79c5664f, (q31_t)0xe47587eb, (q31_t)0x79bffcd7, (q31_t)0xe46a308f, + (q31_t)0x79ba9125, (q31_t)0xe45eda43, (q31_t)0x79b52339, (q31_t)0xe4538507, + (q31_t)0x79afb313, (q31_t)0xe44830dd, (q31_t)0x79aa40b4, (q31_t)0xe43cddc4, + (q31_t)0x79a4cc1c, (q31_t)0xe4318bbe, (q31_t)0x799f554b, (q31_t)0xe4263ac9, + (q31_t)0x7999dc42, (q31_t)0xe41aeae8, (q31_t)0x799460ff, (q31_t)0xe40f9c1a, + (q31_t)0x798ee385, (q31_t)0xe4044e60, (q31_t)0x798963d2, (q31_t)0xe3f901ba, + (q31_t)0x7983e1e8, (q31_t)0xe3edb628, (q31_t)0x797e5dc6, (q31_t)0xe3e26bac, + (q31_t)0x7978d76c, (q31_t)0xe3d72245, (q31_t)0x79734edc, (q31_t)0xe3cbd9f4, + (q31_t)0x796dc414, (q31_t)0xe3c092b9, (q31_t)0x79683715, (q31_t)0xe3b54c95, + (q31_t)0x7962a7e0, (q31_t)0xe3aa0788, (q31_t)0x795d1675, (q31_t)0xe39ec393, + (q31_t)0x795782d3, (q31_t)0xe39380b6, (q31_t)0x7951ecfc, (q31_t)0xe3883ef2, + (q31_t)0x794c54ee, (q31_t)0xe37cfe47, (q31_t)0x7946baac, (q31_t)0xe371beb5, + (q31_t)0x79411e33, (q31_t)0xe366803c, (q31_t)0x793b7f86, (q31_t)0xe35b42df, + (q31_t)0x7935dea4, (q31_t)0xe350069b, (q31_t)0x79303b8e, (q31_t)0xe344cb73, + (q31_t)0x792a9642, (q31_t)0xe3399167, (q31_t)0x7924eec3, (q31_t)0xe32e5876, + (q31_t)0x791f4510, (q31_t)0xe32320a2, (q31_t)0x79199929, (q31_t)0xe317e9eb, + (q31_t)0x7913eb0e, (q31_t)0xe30cb451, (q31_t)0x790e3ac0, (q31_t)0xe3017fd5, + (q31_t)0x7908883f, (q31_t)0xe2f64c77, (q31_t)0x7902d38b, (q31_t)0xe2eb1a37, + (q31_t)0x78fd1ca4, (q31_t)0xe2dfe917, (q31_t)0x78f7638b, (q31_t)0xe2d4b916, + (q31_t)0x78f1a840, (q31_t)0xe2c98a35, (q31_t)0x78ebeac2, (q31_t)0xe2be5c74, + (q31_t)0x78e62b13, (q31_t)0xe2b32fd4, (q31_t)0x78e06932, (q31_t)0xe2a80456, + (q31_t)0x78daa520, (q31_t)0xe29cd9f8, (q31_t)0x78d4dedd, (q31_t)0xe291b0bd, + (q31_t)0x78cf1669, (q31_t)0xe28688a4, (q31_t)0x78c94bc4, (q31_t)0xe27b61af, + (q31_t)0x78c37eef, (q31_t)0xe2703bdc, (q31_t)0x78bdafea, (q31_t)0xe265172e, + (q31_t)0x78b7deb4, (q31_t)0xe259f3a3, (q31_t)0x78b20b4f, (q31_t)0xe24ed13d, + (q31_t)0x78ac35ba, (q31_t)0xe243affc, (q31_t)0x78a65df6, (q31_t)0xe2388fe1, + (q31_t)0x78a08402, (q31_t)0xe22d70eb, (q31_t)0x789aa7e0, (q31_t)0xe222531c, + (q31_t)0x7894c98f, (q31_t)0xe2173674, (q31_t)0x788ee910, (q31_t)0xe20c1af3, + (q31_t)0x78890663, (q31_t)0xe2010099, (q31_t)0x78832187, (q31_t)0xe1f5e768, + (q31_t)0x787d3a7e, (q31_t)0xe1eacf5f, (q31_t)0x78775147, (q31_t)0xe1dfb87f, + (q31_t)0x787165e3, (q31_t)0xe1d4a2c8, (q31_t)0x786b7852, (q31_t)0xe1c98e3b, + (q31_t)0x78658894, (q31_t)0xe1be7ad8, (q31_t)0x785f96a9, (q31_t)0xe1b368a0, + (q31_t)0x7859a292, (q31_t)0xe1a85793, (q31_t)0x7853ac4f, (q31_t)0xe19d47b1, + (q31_t)0x784db3e0, (q31_t)0xe19238fb, (q31_t)0x7847b946, (q31_t)0xe1872b72, + (q31_t)0x7841bc7f, (q31_t)0xe17c1f15, (q31_t)0x783bbd8e, (q31_t)0xe17113e5, + (q31_t)0x7835bc71, (q31_t)0xe16609e3, (q31_t)0x782fb92a, (q31_t)0xe15b0110, + (q31_t)0x7829b3b9, (q31_t)0xe14ff96a, (q31_t)0x7823ac1d, (q31_t)0xe144f2f3, + (q31_t)0x781da256, (q31_t)0xe139edac, (q31_t)0x78179666, (q31_t)0xe12ee995, + (q31_t)0x7811884d, (q31_t)0xe123e6ad, (q31_t)0x780b780a, (q31_t)0xe118e4f6, + (q31_t)0x7805659e, (q31_t)0xe10de470, (q31_t)0x77ff5109, (q31_t)0xe102e51c, + (q31_t)0x77f93a4b, (q31_t)0xe0f7e6f9, (q31_t)0x77f32165, (q31_t)0xe0ecea09, + (q31_t)0x77ed0657, (q31_t)0xe0e1ee4b, (q31_t)0x77e6e921, (q31_t)0xe0d6f3c1, + (q31_t)0x77e0c9c3, (q31_t)0xe0cbfa6a, (q31_t)0x77daa83d, (q31_t)0xe0c10247, + (q31_t)0x77d48490, (q31_t)0xe0b60b58, (q31_t)0x77ce5ebd, (q31_t)0xe0ab159e, + (q31_t)0x77c836c2, (q31_t)0xe0a0211a, (q31_t)0x77c20ca1, (q31_t)0xe0952dcb, + (q31_t)0x77bbe05a, (q31_t)0xe08a3bb2, (q31_t)0x77b5b1ec, (q31_t)0xe07f4acf, + (q31_t)0x77af8159, (q31_t)0xe0745b24, (q31_t)0x77a94ea0, (q31_t)0xe0696cb0, + (q31_t)0x77a319c2, (q31_t)0xe05e7f74, (q31_t)0x779ce2be, (q31_t)0xe053936f, + (q31_t)0x7796a996, (q31_t)0xe048a8a4, (q31_t)0x77906e49, (q31_t)0xe03dbf11, + (q31_t)0x778a30d8, (q31_t)0xe032d6b8, (q31_t)0x7783f143, (q31_t)0xe027ef99, + (q31_t)0x777daf89, (q31_t)0xe01d09b4, (q31_t)0x77776bac, (q31_t)0xe012250a, + (q31_t)0x777125ac, (q31_t)0xe007419b, (q31_t)0x776add88, (q31_t)0xdffc5f67, + (q31_t)0x77649341, (q31_t)0xdff17e70, (q31_t)0x775e46d8, (q31_t)0xdfe69eb4, + (q31_t)0x7757f84c, (q31_t)0xdfdbc036, (q31_t)0x7751a79e, (q31_t)0xdfd0e2f5, + (q31_t)0x774b54ce, (q31_t)0xdfc606f1, (q31_t)0x7744ffdd, (q31_t)0xdfbb2c2c, + (q31_t)0x773ea8ca, (q31_t)0xdfb052a5, (q31_t)0x77384f95, (q31_t)0xdfa57a5d, + (q31_t)0x7731f440, (q31_t)0xdf9aa354, (q31_t)0x772b96ca, (q31_t)0xdf8fcd8b, + (q31_t)0x77253733, (q31_t)0xdf84f902, (q31_t)0x771ed57c, (q31_t)0xdf7a25ba, + (q31_t)0x771871a5, (q31_t)0xdf6f53b3, (q31_t)0x77120bae, (q31_t)0xdf6482ed, + (q31_t)0x770ba398, (q31_t)0xdf59b369, (q31_t)0x77053962, (q31_t)0xdf4ee527, + (q31_t)0x76fecd0e, (q31_t)0xdf441828, (q31_t)0x76f85e9a, (q31_t)0xdf394c6b, + (q31_t)0x76f1ee09, (q31_t)0xdf2e81f3, (q31_t)0x76eb7b58, (q31_t)0xdf23b8be, + (q31_t)0x76e5068a, (q31_t)0xdf18f0ce, (q31_t)0x76de8f9e, (q31_t)0xdf0e2a22, + (q31_t)0x76d81695, (q31_t)0xdf0364bc, (q31_t)0x76d19b6e, (q31_t)0xdef8a09b, + (q31_t)0x76cb1e2a, (q31_t)0xdeedddc0, (q31_t)0x76c49ec9, (q31_t)0xdee31c2b, + (q31_t)0x76be1d4c, (q31_t)0xded85bdd, (q31_t)0x76b799b3, (q31_t)0xdecd9cd7, + (q31_t)0x76b113fd, (q31_t)0xdec2df18, (q31_t)0x76aa8c2c, (q31_t)0xdeb822a1, + (q31_t)0x76a4023f, (q31_t)0xdead6773, (q31_t)0x769d7637, (q31_t)0xdea2ad8d, + (q31_t)0x7696e814, (q31_t)0xde97f4f1, (q31_t)0x769057d6, (q31_t)0xde8d3d9e, + (q31_t)0x7689c57d, (q31_t)0xde828796, (q31_t)0x7683310b, (q31_t)0xde77d2d8, + (q31_t)0x767c9a7e, (q31_t)0xde6d1f65, (q31_t)0x767601d7, (q31_t)0xde626d3e, + (q31_t)0x766f6717, (q31_t)0xde57bc62, (q31_t)0x7668ca3e, (q31_t)0xde4d0cd2, + (q31_t)0x76622b4c, (q31_t)0xde425e8f, (q31_t)0x765b8a41, (q31_t)0xde37b199, + (q31_t)0x7654e71d, (q31_t)0xde2d05f1, (q31_t)0x764e41e2, (q31_t)0xde225b96, + (q31_t)0x76479a8e, (q31_t)0xde17b28a, (q31_t)0x7640f123, (q31_t)0xde0d0acc, + (q31_t)0x763a45a0, (q31_t)0xde02645d, (q31_t)0x76339806, (q31_t)0xddf7bf3e, + (q31_t)0x762ce855, (q31_t)0xdded1b6e, (q31_t)0x7626368d, (q31_t)0xdde278ef, + (q31_t)0x761f82af, (q31_t)0xddd7d7c1, (q31_t)0x7618ccba, (q31_t)0xddcd37e4, + (q31_t)0x761214b0, (q31_t)0xddc29958, (q31_t)0x760b5a90, (q31_t)0xddb7fc1e, + (q31_t)0x76049e5b, (q31_t)0xddad6036, (q31_t)0x75fde011, (q31_t)0xdda2c5a2, + (q31_t)0x75f71fb1, (q31_t)0xdd982c60, (q31_t)0x75f05d3d, (q31_t)0xdd8d9472, + (q31_t)0x75e998b5, (q31_t)0xdd82fdd8, (q31_t)0x75e2d219, (q31_t)0xdd786892, + (q31_t)0x75dc0968, (q31_t)0xdd6dd4a2, (q31_t)0x75d53ea5, (q31_t)0xdd634206, + (q31_t)0x75ce71ce, (q31_t)0xdd58b0c0, (q31_t)0x75c7a2e3, (q31_t)0xdd4e20d0, + (q31_t)0x75c0d1e7, (q31_t)0xdd439236, (q31_t)0x75b9fed7, (q31_t)0xdd3904f4, + (q31_t)0x75b329b5, (q31_t)0xdd2e7908, (q31_t)0x75ac5282, (q31_t)0xdd23ee74, + (q31_t)0x75a5793c, (q31_t)0xdd196538, (q31_t)0x759e9de5, (q31_t)0xdd0edd55, + (q31_t)0x7597c07d, (q31_t)0xdd0456ca, (q31_t)0x7590e104, (q31_t)0xdcf9d199, + (q31_t)0x7589ff7a, (q31_t)0xdcef4dc2, (q31_t)0x75831be0, (q31_t)0xdce4cb44, + (q31_t)0x757c3636, (q31_t)0xdcda4a21, (q31_t)0x75754e7c, (q31_t)0xdccfca59, + (q31_t)0x756e64b2, (q31_t)0xdcc54bec, (q31_t)0x756778d9, (q31_t)0xdcbacedb, + (q31_t)0x75608af1, (q31_t)0xdcb05326, (q31_t)0x75599afa, (q31_t)0xdca5d8cd, + (q31_t)0x7552a8f4, (q31_t)0xdc9b5fd2, (q31_t)0x754bb4e1, (q31_t)0xdc90e834, + (q31_t)0x7544bebf, (q31_t)0xdc8671f3, (q31_t)0x753dc68f, (q31_t)0xdc7bfd11, + (q31_t)0x7536cc52, (q31_t)0xdc71898d, (q31_t)0x752fd008, (q31_t)0xdc671768, + (q31_t)0x7528d1b1, (q31_t)0xdc5ca6a2, (q31_t)0x7521d14d, (q31_t)0xdc52373c, + (q31_t)0x751acedd, (q31_t)0xdc47c936, (q31_t)0x7513ca60, (q31_t)0xdc3d5c91, + (q31_t)0x750cc3d8, (q31_t)0xdc32f14d, (q31_t)0x7505bb44, (q31_t)0xdc28876a, + (q31_t)0x74feb0a5, (q31_t)0xdc1e1ee9, (q31_t)0x74f7a3fb, (q31_t)0xdc13b7c9, + (q31_t)0x74f09546, (q31_t)0xdc09520d, (q31_t)0x74e98487, (q31_t)0xdbfeedb3, + (q31_t)0x74e271bd, (q31_t)0xdbf48abd, (q31_t)0x74db5cea, (q31_t)0xdbea292b, + (q31_t)0x74d4460c, (q31_t)0xdbdfc8fc, (q31_t)0x74cd2d26, (q31_t)0xdbd56a32, + (q31_t)0x74c61236, (q31_t)0xdbcb0cce, (q31_t)0x74bef53d, (q31_t)0xdbc0b0ce, + (q31_t)0x74b7d63c, (q31_t)0xdbb65634, (q31_t)0x74b0b533, (q31_t)0xdbabfd01, + (q31_t)0x74a99221, (q31_t)0xdba1a534, (q31_t)0x74a26d08, (q31_t)0xdb974ece, + (q31_t)0x749b45e7, (q31_t)0xdb8cf9cf, (q31_t)0x74941cbf, (q31_t)0xdb82a638, + (q31_t)0x748cf190, (q31_t)0xdb785409, (q31_t)0x7485c45b, (q31_t)0xdb6e0342, + (q31_t)0x747e951f, (q31_t)0xdb63b3e5, (q31_t)0x747763dd, (q31_t)0xdb5965f1, + (q31_t)0x74703095, (q31_t)0xdb4f1967, (q31_t)0x7468fb47, (q31_t)0xdb44ce46, + (q31_t)0x7461c3f5, (q31_t)0xdb3a8491, (q31_t)0x745a8a9d, (q31_t)0xdb303c46, + (q31_t)0x74534f41, (q31_t)0xdb25f566, (q31_t)0x744c11e0, (q31_t)0xdb1baff2, + (q31_t)0x7444d27b, (q31_t)0xdb116beb, (q31_t)0x743d9112, (q31_t)0xdb072950, + (q31_t)0x74364da6, (q31_t)0xdafce821, (q31_t)0x742f0836, (q31_t)0xdaf2a860, + (q31_t)0x7427c0c3, (q31_t)0xdae86a0d, (q31_t)0x7420774d, (q31_t)0xdade2d28, + (q31_t)0x74192bd5, (q31_t)0xdad3f1b1, (q31_t)0x7411de5b, (q31_t)0xdac9b7a9, + (q31_t)0x740a8edf, (q31_t)0xdabf7f11, (q31_t)0x74033d61, (q31_t)0xdab547e8, + (q31_t)0x73fbe9e2, (q31_t)0xdaab122f, (q31_t)0x73f49462, (q31_t)0xdaa0dde7, + (q31_t)0x73ed3ce1, (q31_t)0xda96ab0f, (q31_t)0x73e5e360, (q31_t)0xda8c79a9, + (q31_t)0x73de87de, (q31_t)0xda8249b4, (q31_t)0x73d72a5d, (q31_t)0xda781b31, + (q31_t)0x73cfcadc, (q31_t)0xda6dee21, (q31_t)0x73c8695b, (q31_t)0xda63c284, + (q31_t)0x73c105db, (q31_t)0xda599859, (q31_t)0x73b9a05d, (q31_t)0xda4f6fa3, + (q31_t)0x73b238e0, (q31_t)0xda454860, (q31_t)0x73aacf65, (q31_t)0xda3b2292, + (q31_t)0x73a363ec, (q31_t)0xda30fe38, (q31_t)0x739bf675, (q31_t)0xda26db54, + (q31_t)0x73948701, (q31_t)0xda1cb9e5, (q31_t)0x738d1590, (q31_t)0xda1299ec, + (q31_t)0x7385a222, (q31_t)0xda087b69, (q31_t)0x737e2cb7, (q31_t)0xd9fe5e5e, + (q31_t)0x7376b551, (q31_t)0xd9f442c9, (q31_t)0x736f3bee, (q31_t)0xd9ea28ac, + (q31_t)0x7367c090, (q31_t)0xd9e01006, (q31_t)0x73604336, (q31_t)0xd9d5f8d9, + (q31_t)0x7358c3e2, (q31_t)0xd9cbe325, (q31_t)0x73514292, (q31_t)0xd9c1cee9, + (q31_t)0x7349bf48, (q31_t)0xd9b7bc27, (q31_t)0x73423a04, (q31_t)0xd9adaadf, + (q31_t)0x733ab2c6, (q31_t)0xd9a39b11, (q31_t)0x7333298f, (q31_t)0xd9998cbe, + (q31_t)0x732b9e5e, (q31_t)0xd98f7fe6, (q31_t)0x73241134, (q31_t)0xd9857489, + (q31_t)0x731c8211, (q31_t)0xd97b6aa8, (q31_t)0x7314f0f6, (q31_t)0xd9716243, + (q31_t)0x730d5de3, (q31_t)0xd9675b5a, (q31_t)0x7305c8d7, (q31_t)0xd95d55ef, + (q31_t)0x72fe31d5, (q31_t)0xd9535201, (q31_t)0x72f698db, (q31_t)0xd9494f90, + (q31_t)0x72eefdea, (q31_t)0xd93f4e9e, (q31_t)0x72e76102, (q31_t)0xd9354f2a, + (q31_t)0x72dfc224, (q31_t)0xd92b5135, (q31_t)0x72d82150, (q31_t)0xd92154bf, + (q31_t)0x72d07e85, (q31_t)0xd91759c9, (q31_t)0x72c8d9c6, (q31_t)0xd90d6053, + (q31_t)0x72c13311, (q31_t)0xd903685d, (q31_t)0x72b98a67, (q31_t)0xd8f971e8, + (q31_t)0x72b1dfc9, (q31_t)0xd8ef7cf4, (q31_t)0x72aa3336, (q31_t)0xd8e58982, + (q31_t)0x72a284b0, (q31_t)0xd8db9792, (q31_t)0x729ad435, (q31_t)0xd8d1a724, + (q31_t)0x729321c7, (q31_t)0xd8c7b838, (q31_t)0x728b6d66, (q31_t)0xd8bdcad0, + (q31_t)0x7283b712, (q31_t)0xd8b3deeb, (q31_t)0x727bfecc, (q31_t)0xd8a9f48a, + (q31_t)0x72744493, (q31_t)0xd8a00bae, (q31_t)0x726c8868, (q31_t)0xd8962456, + (q31_t)0x7264ca4c, (q31_t)0xd88c3e83, (q31_t)0x725d0a3e, (q31_t)0xd8825a35, + (q31_t)0x72554840, (q31_t)0xd878776d, (q31_t)0x724d8450, (q31_t)0xd86e962b, + (q31_t)0x7245be70, (q31_t)0xd864b670, (q31_t)0x723df6a0, (q31_t)0xd85ad83c, + (q31_t)0x72362ce0, (q31_t)0xd850fb8e, (q31_t)0x722e6130, (q31_t)0xd8472069, + (q31_t)0x72269391, (q31_t)0xd83d46cc, (q31_t)0x721ec403, (q31_t)0xd8336eb7, + (q31_t)0x7216f287, (q31_t)0xd829982b, (q31_t)0x720f1f1c, (q31_t)0xd81fc328, + (q31_t)0x720749c3, (q31_t)0xd815efae, (q31_t)0x71ff727c, (q31_t)0xd80c1dbf, + (q31_t)0x71f79948, (q31_t)0xd8024d59, (q31_t)0x71efbe27, (q31_t)0xd7f87e7f, + (q31_t)0x71e7e118, (q31_t)0xd7eeb130, (q31_t)0x71e0021e, (q31_t)0xd7e4e56c, + (q31_t)0x71d82137, (q31_t)0xd7db1b34, (q31_t)0x71d03e64, (q31_t)0xd7d15288, + (q31_t)0x71c859a5, (q31_t)0xd7c78b68, (q31_t)0x71c072fb, (q31_t)0xd7bdc5d6, + (q31_t)0x71b88a66, (q31_t)0xd7b401d1, (q31_t)0x71b09fe7, (q31_t)0xd7aa3f5a, + (q31_t)0x71a8b37c, (q31_t)0xd7a07e70, (q31_t)0x71a0c528, (q31_t)0xd796bf16, + (q31_t)0x7198d4ea, (q31_t)0xd78d014a, (q31_t)0x7190e2c3, (q31_t)0xd783450d, + (q31_t)0x7188eeb2, (q31_t)0xd7798a60, (q31_t)0x7180f8b8, (q31_t)0xd76fd143, + (q31_t)0x717900d6, (q31_t)0xd76619b6, (q31_t)0x7171070c, (q31_t)0xd75c63ba, + (q31_t)0x71690b59, (q31_t)0xd752af4f, (q31_t)0x71610dbf, (q31_t)0xd748fc75, + (q31_t)0x71590e3e, (q31_t)0xd73f4b2e, (q31_t)0x71510cd5, (q31_t)0xd7359b78, + (q31_t)0x71490986, (q31_t)0xd72bed55, (q31_t)0x71410450, (q31_t)0xd72240c5, + (q31_t)0x7138fd35, (q31_t)0xd71895c9, (q31_t)0x7130f433, (q31_t)0xd70eec60, + (q31_t)0x7128e94c, (q31_t)0xd705448b, (q31_t)0x7120dc80, (q31_t)0xd6fb9e4b, + (q31_t)0x7118cdcf, (q31_t)0xd6f1f99f, (q31_t)0x7110bd39, (q31_t)0xd6e85689, + (q31_t)0x7108aabf, (q31_t)0xd6deb508, (q31_t)0x71009661, (q31_t)0xd6d5151d, + (q31_t)0x70f8801f, (q31_t)0xd6cb76c9, (q31_t)0x70f067fb, (q31_t)0xd6c1da0b, + (q31_t)0x70e84df3, (q31_t)0xd6b83ee4, (q31_t)0x70e03208, (q31_t)0xd6aea555, + (q31_t)0x70d8143b, (q31_t)0xd6a50d5d, (q31_t)0x70cff48c, (q31_t)0xd69b76fe, + (q31_t)0x70c7d2fb, (q31_t)0xd691e237, (q31_t)0x70bfaf89, (q31_t)0xd6884f09, + (q31_t)0x70b78a36, (q31_t)0xd67ebd74, (q31_t)0x70af6302, (q31_t)0xd6752d79, + (q31_t)0x70a739ed, (q31_t)0xd66b9f18, (q31_t)0x709f0ef8, (q31_t)0xd6621251, + (q31_t)0x7096e223, (q31_t)0xd6588725, (q31_t)0x708eb36f, (q31_t)0xd64efd94, + (q31_t)0x708682dc, (q31_t)0xd645759f, (q31_t)0x707e5069, (q31_t)0xd63bef46, + (q31_t)0x70761c18, (q31_t)0xd6326a88, (q31_t)0x706de5e9, (q31_t)0xd628e767, + (q31_t)0x7065addb, (q31_t)0xd61f65e4, (q31_t)0x705d73f0, (q31_t)0xd615e5fd, + (q31_t)0x70553828, (q31_t)0xd60c67b4, (q31_t)0x704cfa83, (q31_t)0xd602eb0a, + (q31_t)0x7044bb00, (q31_t)0xd5f96ffd, (q31_t)0x703c79a2, (q31_t)0xd5eff690, + (q31_t)0x70343667, (q31_t)0xd5e67ec1, (q31_t)0x702bf151, (q31_t)0xd5dd0892, + (q31_t)0x7023aa5f, (q31_t)0xd5d39403, (q31_t)0x701b6193, (q31_t)0xd5ca2115, + (q31_t)0x701316eb, (q31_t)0xd5c0afc6, (q31_t)0x700aca69, (q31_t)0xd5b74019, + (q31_t)0x70027c0c, (q31_t)0xd5add20d, (q31_t)0x6ffa2bd6, (q31_t)0xd5a465a3, + (q31_t)0x6ff1d9c7, (q31_t)0xd59afadb, (q31_t)0x6fe985de, (q31_t)0xd59191b5, + (q31_t)0x6fe1301c, (q31_t)0xd5882a32, (q31_t)0x6fd8d882, (q31_t)0xd57ec452, + (q31_t)0x6fd07f0f, (q31_t)0xd5756016, (q31_t)0x6fc823c5, (q31_t)0xd56bfd7d, + (q31_t)0x6fbfc6a3, (q31_t)0xd5629c89, (q31_t)0x6fb767aa, (q31_t)0xd5593d3a, + (q31_t)0x6faf06da, (q31_t)0xd54fdf8f, (q31_t)0x6fa6a433, (q31_t)0xd5468389, + (q31_t)0x6f9e3fb6, (q31_t)0xd53d292a, (q31_t)0x6f95d963, (q31_t)0xd533d070, + (q31_t)0x6f8d713a, (q31_t)0xd52a795d, (q31_t)0x6f85073c, (q31_t)0xd52123f0, + (q31_t)0x6f7c9b69, (q31_t)0xd517d02b, (q31_t)0x6f742dc1, (q31_t)0xd50e7e0d, + (q31_t)0x6f6bbe45, (q31_t)0xd5052d97, (q31_t)0x6f634cf5, (q31_t)0xd4fbdec9, + (q31_t)0x6f5ad9d1, (q31_t)0xd4f291a4, (q31_t)0x6f5264da, (q31_t)0xd4e94627, + (q31_t)0x6f49ee0f, (q31_t)0xd4dffc54, (q31_t)0x6f417573, (q31_t)0xd4d6b42b, + (q31_t)0x6f38fb03, (q31_t)0xd4cd6dab, (q31_t)0x6f307ec2, (q31_t)0xd4c428d6, + (q31_t)0x6f2800af, (q31_t)0xd4bae5ab, (q31_t)0x6f1f80ca, (q31_t)0xd4b1a42c, + (q31_t)0x6f16ff14, (q31_t)0xd4a86458, (q31_t)0x6f0e7b8e, (q31_t)0xd49f2630, + (q31_t)0x6f05f637, (q31_t)0xd495e9b3, (q31_t)0x6efd6f10, (q31_t)0xd48caee4, + (q31_t)0x6ef4e619, (q31_t)0xd48375c1, (q31_t)0x6eec5b53, (q31_t)0xd47a3e4b, + (q31_t)0x6ee3cebe, (q31_t)0xd4710883, (q31_t)0x6edb405a, (q31_t)0xd467d469, + (q31_t)0x6ed2b027, (q31_t)0xd45ea1fd, (q31_t)0x6eca1e27, (q31_t)0xd4557140, + (q31_t)0x6ec18a58, (q31_t)0xd44c4232, (q31_t)0x6eb8f4bc, (q31_t)0xd44314d3, + (q31_t)0x6eb05d53, (q31_t)0xd439e923, (q31_t)0x6ea7c41e, (q31_t)0xd430bf24, + (q31_t)0x6e9f291b, (q31_t)0xd42796d5, (q31_t)0x6e968c4d, (q31_t)0xd41e7037, + (q31_t)0x6e8dedb3, (q31_t)0xd4154b4a, (q31_t)0x6e854d4d, (q31_t)0xd40c280e, + (q31_t)0x6e7cab1c, (q31_t)0xd4030684, (q31_t)0x6e740720, (q31_t)0xd3f9e6ad, + (q31_t)0x6e6b615a, (q31_t)0xd3f0c887, (q31_t)0x6e62b9ca, (q31_t)0xd3e7ac15, + (q31_t)0x6e5a1070, (q31_t)0xd3de9156, (q31_t)0x6e51654c, (q31_t)0xd3d5784a, + (q31_t)0x6e48b860, (q31_t)0xd3cc60f2, (q31_t)0x6e4009aa, (q31_t)0xd3c34b4f, + (q31_t)0x6e37592c, (q31_t)0xd3ba3760, (q31_t)0x6e2ea6e6, (q31_t)0xd3b12526, + (q31_t)0x6e25f2d8, (q31_t)0xd3a814a2, (q31_t)0x6e1d3d03, (q31_t)0xd39f05d3, + (q31_t)0x6e148566, (q31_t)0xd395f8ba, (q31_t)0x6e0bcc03, (q31_t)0xd38ced57, + (q31_t)0x6e0310d9, (q31_t)0xd383e3ab, (q31_t)0x6dfa53e9, (q31_t)0xd37adbb6, + (q31_t)0x6df19534, (q31_t)0xd371d579, (q31_t)0x6de8d4b8, (q31_t)0xd368d0f3, + (q31_t)0x6de01278, (q31_t)0xd35fce26, (q31_t)0x6dd74e73, (q31_t)0xd356cd11, + (q31_t)0x6dce88aa, (q31_t)0xd34dcdb4, (q31_t)0x6dc5c11c, (q31_t)0xd344d011, + (q31_t)0x6dbcf7cb, (q31_t)0xd33bd427, (q31_t)0x6db42cb6, (q31_t)0xd332d9f7, + (q31_t)0x6dab5fdf, (q31_t)0xd329e181, (q31_t)0x6da29144, (q31_t)0xd320eac6, + (q31_t)0x6d99c0e7, (q31_t)0xd317f5c6, (q31_t)0x6d90eec8, (q31_t)0xd30f0280, + (q31_t)0x6d881ae8, (q31_t)0xd30610f7, (q31_t)0x6d7f4545, (q31_t)0xd2fd2129, + (q31_t)0x6d766de2, (q31_t)0xd2f43318, (q31_t)0x6d6d94bf, (q31_t)0xd2eb46c3, + (q31_t)0x6d64b9da, (q31_t)0xd2e25c2b, (q31_t)0x6d5bdd36, (q31_t)0xd2d97350, + (q31_t)0x6d52fed2, (q31_t)0xd2d08c33, (q31_t)0x6d4a1eaf, (q31_t)0xd2c7a6d4, + (q31_t)0x6d413ccd, (q31_t)0xd2bec333, (q31_t)0x6d38592c, (q31_t)0xd2b5e151, + (q31_t)0x6d2f73cd, (q31_t)0xd2ad012e, (q31_t)0x6d268cb0, (q31_t)0xd2a422ca, + (q31_t)0x6d1da3d5, (q31_t)0xd29b4626, (q31_t)0x6d14b93d, (q31_t)0xd2926b41, + (q31_t)0x6d0bcce8, (q31_t)0xd289921e, (q31_t)0x6d02ded7, (q31_t)0xd280babb, + (q31_t)0x6cf9ef09, (q31_t)0xd277e518, (q31_t)0x6cf0fd80, (q31_t)0xd26f1138, + (q31_t)0x6ce80a3a, (q31_t)0xd2663f19, (q31_t)0x6cdf153a, (q31_t)0xd25d6ebc, + (q31_t)0x6cd61e7f, (q31_t)0xd254a021, (q31_t)0x6ccd2609, (q31_t)0xd24bd34a, + (q31_t)0x6cc42bd9, (q31_t)0xd2430835, (q31_t)0x6cbb2fef, (q31_t)0xd23a3ee4, + (q31_t)0x6cb2324c, (q31_t)0xd2317756, (q31_t)0x6ca932ef, (q31_t)0xd228b18d, + (q31_t)0x6ca031da, (q31_t)0xd21fed88, (q31_t)0x6c972f0d, (q31_t)0xd2172b48, + (q31_t)0x6c8e2a87, (q31_t)0xd20e6acc, (q31_t)0x6c85244a, (q31_t)0xd205ac17, + (q31_t)0x6c7c1c55, (q31_t)0xd1fcef27, (q31_t)0x6c7312a9, (q31_t)0xd1f433fd, + (q31_t)0x6c6a0746, (q31_t)0xd1eb7a9a, (q31_t)0x6c60fa2d, (q31_t)0xd1e2c2fd, + (q31_t)0x6c57eb5e, (q31_t)0xd1da0d28, (q31_t)0x6c4edada, (q31_t)0xd1d1591a, + (q31_t)0x6c45c8a0, (q31_t)0xd1c8a6d4, (q31_t)0x6c3cb4b1, (q31_t)0xd1bff656, + (q31_t)0x6c339f0e, (q31_t)0xd1b747a0, (q31_t)0x6c2a87b6, (q31_t)0xd1ae9ab4, + (q31_t)0x6c216eaa, (q31_t)0xd1a5ef90, (q31_t)0x6c1853eb, (q31_t)0xd19d4636, + (q31_t)0x6c0f3779, (q31_t)0xd1949ea6, (q31_t)0x6c061953, (q31_t)0xd18bf8e0, + (q31_t)0x6bfcf97c, (q31_t)0xd18354e4, (q31_t)0x6bf3d7f2, (q31_t)0xd17ab2b3, + (q31_t)0x6beab4b6, (q31_t)0xd172124d, (q31_t)0x6be18fc9, (q31_t)0xd16973b3, + (q31_t)0x6bd8692b, (q31_t)0xd160d6e5, (q31_t)0x6bcf40dc, (q31_t)0xd1583be2, + (q31_t)0x6bc616dd, (q31_t)0xd14fa2ad, (q31_t)0x6bbceb2d, (q31_t)0xd1470b44, + (q31_t)0x6bb3bdce, (q31_t)0xd13e75a8, (q31_t)0x6baa8ec0, (q31_t)0xd135e1d9, + (q31_t)0x6ba15e03, (q31_t)0xd12d4fd9, (q31_t)0x6b982b97, (q31_t)0xd124bfa6, + (q31_t)0x6b8ef77d, (q31_t)0xd11c3142, (q31_t)0x6b85c1b5, (q31_t)0xd113a4ad, + (q31_t)0x6b7c8a3f, (q31_t)0xd10b19e7, (q31_t)0x6b73511c, (q31_t)0xd10290f0, + (q31_t)0x6b6a164d, (q31_t)0xd0fa09c9, (q31_t)0x6b60d9d0, (q31_t)0xd0f18472, + (q31_t)0x6b579ba8, (q31_t)0xd0e900ec, (q31_t)0x6b4e5bd4, (q31_t)0xd0e07f36, + (q31_t)0x6b451a55, (q31_t)0xd0d7ff51, (q31_t)0x6b3bd72a, (q31_t)0xd0cf813e, + (q31_t)0x6b329255, (q31_t)0xd0c704fd, (q31_t)0x6b294bd5, (q31_t)0xd0be8a8d, + (q31_t)0x6b2003ac, (q31_t)0xd0b611f1, (q31_t)0x6b16b9d9, (q31_t)0xd0ad9b26, + (q31_t)0x6b0d6e5c, (q31_t)0xd0a5262f, (q31_t)0x6b042137, (q31_t)0xd09cb30b, + (q31_t)0x6afad269, (q31_t)0xd09441bb, (q31_t)0x6af181f3, (q31_t)0xd08bd23f, + (q31_t)0x6ae82fd5, (q31_t)0xd0836497, (q31_t)0x6adedc10, (q31_t)0xd07af8c4, + (q31_t)0x6ad586a3, (q31_t)0xd0728ec6, (q31_t)0x6acc2f90, (q31_t)0xd06a269d, + (q31_t)0x6ac2d6d6, (q31_t)0xd061c04a, (q31_t)0x6ab97c77, (q31_t)0xd0595bcd, + (q31_t)0x6ab02071, (q31_t)0xd050f926, (q31_t)0x6aa6c2c6, (q31_t)0xd0489856, + (q31_t)0x6a9d6377, (q31_t)0xd040395d, (q31_t)0x6a940283, (q31_t)0xd037dc3b, + (q31_t)0x6a8a9fea, (q31_t)0xd02f80f1, (q31_t)0x6a813bae, (q31_t)0xd027277e, + (q31_t)0x6a77d5ce, (q31_t)0xd01ecfe4, (q31_t)0x6a6e6e4b, (q31_t)0xd0167a22, + (q31_t)0x6a650525, (q31_t)0xd00e2639, (q31_t)0x6a5b9a5d, (q31_t)0xd005d42a, + (q31_t)0x6a522df3, (q31_t)0xcffd83f4, (q31_t)0x6a48bfe7, (q31_t)0xcff53597, + (q31_t)0x6a3f503a, (q31_t)0xcfece915, (q31_t)0x6a35deeb, (q31_t)0xcfe49e6d, + (q31_t)0x6a2c6bfd, (q31_t)0xcfdc55a1, (q31_t)0x6a22f76e, (q31_t)0xcfd40eaf, + (q31_t)0x6a19813f, (q31_t)0xcfcbc999, (q31_t)0x6a100970, (q31_t)0xcfc3865e, + (q31_t)0x6a069003, (q31_t)0xcfbb4500, (q31_t)0x69fd14f6, (q31_t)0xcfb3057d, + (q31_t)0x69f3984c, (q31_t)0xcfaac7d8, (q31_t)0x69ea1a03, (q31_t)0xcfa28c10, + (q31_t)0x69e09a1c, (q31_t)0xcf9a5225, (q31_t)0x69d71899, (q31_t)0xcf921a17, + (q31_t)0x69cd9578, (q31_t)0xcf89e3e8, (q31_t)0x69c410ba, (q31_t)0xcf81af97, + (q31_t)0x69ba8a61, (q31_t)0xcf797d24, (q31_t)0x69b1026c, (q31_t)0xcf714c91, + (q31_t)0x69a778db, (q31_t)0xcf691ddd, (q31_t)0x699dedaf, (q31_t)0xcf60f108, + (q31_t)0x699460e8, (q31_t)0xcf58c613, (q31_t)0x698ad287, (q31_t)0xcf509cfe, + (q31_t)0x6981428c, (q31_t)0xcf4875ca, (q31_t)0x6977b0f7, (q31_t)0xcf405077, + (q31_t)0x696e1dc9, (q31_t)0xcf382d05, (q31_t)0x69648902, (q31_t)0xcf300b74, + (q31_t)0x695af2a3, (q31_t)0xcf27ebc5, (q31_t)0x69515aab, (q31_t)0xcf1fcdf8, + (q31_t)0x6947c11c, (q31_t)0xcf17b20d, (q31_t)0x693e25f5, (q31_t)0xcf0f9805, + (q31_t)0x69348937, (q31_t)0xcf077fe1, (q31_t)0x692aeae3, (q31_t)0xceff699f, + (q31_t)0x69214af8, (q31_t)0xcef75541, (q31_t)0x6917a977, (q31_t)0xceef42c7, + (q31_t)0x690e0661, (q31_t)0xcee73231, (q31_t)0x690461b5, (q31_t)0xcedf2380, + (q31_t)0x68fabb75, (q31_t)0xced716b4, (q31_t)0x68f113a0, (q31_t)0xcecf0bcd, + (q31_t)0x68e76a37, (q31_t)0xcec702cb, (q31_t)0x68ddbf3b, (q31_t)0xcebefbb0, + (q31_t)0x68d412ab, (q31_t)0xceb6f67a, (q31_t)0x68ca6488, (q31_t)0xceaef32b, + (q31_t)0x68c0b4d2, (q31_t)0xcea6f1c2, (q31_t)0x68b7038b, (q31_t)0xce9ef241, + (q31_t)0x68ad50b1, (q31_t)0xce96f4a7, (q31_t)0x68a39c46, (q31_t)0xce8ef8f4, + (q31_t)0x6899e64a, (q31_t)0xce86ff2a, (q31_t)0x68902ebd, (q31_t)0xce7f0748, + (q31_t)0x688675a0, (q31_t)0xce77114e, (q31_t)0x687cbaf3, (q31_t)0xce6f1d3d, + (q31_t)0x6872feb6, (q31_t)0xce672b16, (q31_t)0x686940ea, (q31_t)0xce5f3ad8, + (q31_t)0x685f8190, (q31_t)0xce574c84, (q31_t)0x6855c0a6, (q31_t)0xce4f6019, + (q31_t)0x684bfe2f, (q31_t)0xce47759a, (q31_t)0x68423a2a, (q31_t)0xce3f8d05, + (q31_t)0x68387498, (q31_t)0xce37a65b, (q31_t)0x682ead78, (q31_t)0xce2fc19c, + (q31_t)0x6824e4cc, (q31_t)0xce27dec9, (q31_t)0x681b1a94, (q31_t)0xce1ffde2, + (q31_t)0x68114ed0, (q31_t)0xce181ee8, (q31_t)0x68078181, (q31_t)0xce1041d9, + (q31_t)0x67fdb2a7, (q31_t)0xce0866b8, (q31_t)0x67f3e241, (q31_t)0xce008d84, + (q31_t)0x67ea1052, (q31_t)0xcdf8b63d, (q31_t)0x67e03cd8, (q31_t)0xcdf0e0e4, + (q31_t)0x67d667d5, (q31_t)0xcde90d79, (q31_t)0x67cc9149, (q31_t)0xcde13bfd, + (q31_t)0x67c2b934, (q31_t)0xcdd96c6f, (q31_t)0x67b8df97, (q31_t)0xcdd19ed0, + (q31_t)0x67af0472, (q31_t)0xcdc9d320, (q31_t)0x67a527c4, (q31_t)0xcdc20960, + (q31_t)0x679b4990, (q31_t)0xcdba4190, (q31_t)0x679169d5, (q31_t)0xcdb27bb0, + (q31_t)0x67878893, (q31_t)0xcdaab7c0, (q31_t)0x677da5cb, (q31_t)0xcda2f5c2, + (q31_t)0x6773c17d, (q31_t)0xcd9b35b4, (q31_t)0x6769dbaa, (q31_t)0xcd937798, + (q31_t)0x675ff452, (q31_t)0xcd8bbb6d, (q31_t)0x67560b76, (q31_t)0xcd840134, + (q31_t)0x674c2115, (q31_t)0xcd7c48ee, (q31_t)0x67423530, (q31_t)0xcd74929a, + (q31_t)0x673847c8, (q31_t)0xcd6cde39, (q31_t)0x672e58dc, (q31_t)0xcd652bcb, + (q31_t)0x6724686e, (q31_t)0xcd5d7b50, (q31_t)0x671a767e, (q31_t)0xcd55ccca, + (q31_t)0x6710830c, (q31_t)0xcd4e2037, (q31_t)0x67068e18, (q31_t)0xcd467599, + (q31_t)0x66fc97a3, (q31_t)0xcd3eccef, (q31_t)0x66f29fad, (q31_t)0xcd37263a, + (q31_t)0x66e8a637, (q31_t)0xcd2f817b, (q31_t)0x66deab41, (q31_t)0xcd27deb0, + (q31_t)0x66d4aecb, (q31_t)0xcd203ddc, (q31_t)0x66cab0d6, (q31_t)0xcd189efe, + (q31_t)0x66c0b162, (q31_t)0xcd110216, (q31_t)0x66b6b070, (q31_t)0xcd096725, + (q31_t)0x66acadff, (q31_t)0xcd01ce2b, (q31_t)0x66a2aa11, (q31_t)0xccfa3729, + (q31_t)0x6698a4a6, (q31_t)0xccf2a21d, (q31_t)0x668e9dbd, (q31_t)0xcceb0f0a, + (q31_t)0x66849558, (q31_t)0xcce37def, (q31_t)0x667a8b77, (q31_t)0xccdbeecc, + (q31_t)0x6670801a, (q31_t)0xccd461a2, (q31_t)0x66667342, (q31_t)0xccccd671, + (q31_t)0x665c64ef, (q31_t)0xccc54d3a, (q31_t)0x66525521, (q31_t)0xccbdc5fc, + (q31_t)0x664843d9, (q31_t)0xccb640b8, (q31_t)0x663e3117, (q31_t)0xccaebd6e, + (q31_t)0x66341cdb, (q31_t)0xcca73c1e, (q31_t)0x662a0727, (q31_t)0xcc9fbcca, + (q31_t)0x661feffa, (q31_t)0xcc983f70, (q31_t)0x6615d754, (q31_t)0xcc90c412, + (q31_t)0x660bbd37, (q31_t)0xcc894aaf, (q31_t)0x6601a1a2, (q31_t)0xcc81d349, + (q31_t)0x65f78497, (q31_t)0xcc7a5dde, (q31_t)0x65ed6614, (q31_t)0xcc72ea70, + (q31_t)0x65e3461b, (q31_t)0xcc6b78ff, (q31_t)0x65d924ac, (q31_t)0xcc64098b, + (q31_t)0x65cf01c8, (q31_t)0xcc5c9c14, (q31_t)0x65c4dd6e, (q31_t)0xcc55309b, + (q31_t)0x65bab7a0, (q31_t)0xcc4dc720, (q31_t)0x65b0905d, (q31_t)0xcc465fa3, + (q31_t)0x65a667a7, (q31_t)0xcc3efa25, (q31_t)0x659c3d7c, (q31_t)0xcc3796a5, + (q31_t)0x659211df, (q31_t)0xcc303524, (q31_t)0x6587e4cf, (q31_t)0xcc28d5a3, + (q31_t)0x657db64c, (q31_t)0xcc217822, (q31_t)0x65738657, (q31_t)0xcc1a1ca0, + (q31_t)0x656954f1, (q31_t)0xcc12c31f, (q31_t)0x655f2219, (q31_t)0xcc0b6b9e, + (q31_t)0x6554edd1, (q31_t)0xcc04161e, (q31_t)0x654ab818, (q31_t)0xcbfcc29f, + (q31_t)0x654080ef, (q31_t)0xcbf57121, (q31_t)0x65364857, (q31_t)0xcbee21a5, + (q31_t)0x652c0e4f, (q31_t)0xcbe6d42b, (q31_t)0x6521d2d8, (q31_t)0xcbdf88b3, + (q31_t)0x651795f3, (q31_t)0xcbd83f3d, (q31_t)0x650d57a0, (q31_t)0xcbd0f7ca, + (q31_t)0x650317df, (q31_t)0xcbc9b25a, (q31_t)0x64f8d6b0, (q31_t)0xcbc26eee, + (q31_t)0x64ee9415, (q31_t)0xcbbb2d85, (q31_t)0x64e4500e, (q31_t)0xcbb3ee20, + (q31_t)0x64da0a9a, (q31_t)0xcbacb0bf, (q31_t)0x64cfc3ba, (q31_t)0xcba57563, + (q31_t)0x64c57b6f, (q31_t)0xcb9e3c0b, (q31_t)0x64bb31ba, (q31_t)0xcb9704b9, + (q31_t)0x64b0e699, (q31_t)0xcb8fcf6b, (q31_t)0x64a69a0f, (q31_t)0xcb889c23, + (q31_t)0x649c4c1b, (q31_t)0xcb816ae1, (q31_t)0x6491fcbe, (q31_t)0xcb7a3ba5, + (q31_t)0x6487abf7, (q31_t)0xcb730e70, (q31_t)0x647d59c8, (q31_t)0xcb6be341, + (q31_t)0x64730631, (q31_t)0xcb64ba19, (q31_t)0x6468b132, (q31_t)0xcb5d92f8, + (q31_t)0x645e5acc, (q31_t)0xcb566ddf, (q31_t)0x645402ff, (q31_t)0xcb4f4acd, + (q31_t)0x6449a9cc, (q31_t)0xcb4829c4, (q31_t)0x643f4f32, (q31_t)0xcb410ac3, + (q31_t)0x6434f332, (q31_t)0xcb39edca, (q31_t)0x642a95ce, (q31_t)0xcb32d2da, + (q31_t)0x64203704, (q31_t)0xcb2bb9f4, (q31_t)0x6415d6d5, (q31_t)0xcb24a316, + (q31_t)0x640b7543, (q31_t)0xcb1d8e43, (q31_t)0x6401124d, (q31_t)0xcb167b79, + (q31_t)0x63f6adf3, (q31_t)0xcb0f6aba, (q31_t)0x63ec4837, (q31_t)0xcb085c05, + (q31_t)0x63e1e117, (q31_t)0xcb014f5b, (q31_t)0x63d77896, (q31_t)0xcafa44bc, + (q31_t)0x63cd0eb3, (q31_t)0xcaf33c28, (q31_t)0x63c2a36f, (q31_t)0xcaec35a0, + (q31_t)0x63b836ca, (q31_t)0xcae53123, (q31_t)0x63adc8c4, (q31_t)0xcade2eb3, + (q31_t)0x63a3595e, (q31_t)0xcad72e4f, (q31_t)0x6398e898, (q31_t)0xcad02ff8, + (q31_t)0x638e7673, (q31_t)0xcac933ae, (q31_t)0x638402ef, (q31_t)0xcac23971, + (q31_t)0x63798e0d, (q31_t)0xcabb4141, (q31_t)0x636f17cc, (q31_t)0xcab44b1f, + (q31_t)0x6364a02e, (q31_t)0xcaad570c, (q31_t)0x635a2733, (q31_t)0xcaa66506, + (q31_t)0x634facda, (q31_t)0xca9f750f, (q31_t)0x63453125, (q31_t)0xca988727, + (q31_t)0x633ab414, (q31_t)0xca919b4e, (q31_t)0x633035a7, (q31_t)0xca8ab184, + (q31_t)0x6325b5df, (q31_t)0xca83c9ca, (q31_t)0x631b34bc, (q31_t)0xca7ce420, + (q31_t)0x6310b23e, (q31_t)0xca760086, (q31_t)0x63062e67, (q31_t)0xca6f1efc, + (q31_t)0x62fba936, (q31_t)0xca683f83, (q31_t)0x62f122ab, (q31_t)0xca61621b, + (q31_t)0x62e69ac8, (q31_t)0xca5a86c4, (q31_t)0x62dc118c, (q31_t)0xca53ad7e, + (q31_t)0x62d186f8, (q31_t)0xca4cd64b, (q31_t)0x62c6fb0c, (q31_t)0xca460129, + (q31_t)0x62bc6dca, (q31_t)0xca3f2e19, (q31_t)0x62b1df30, (q31_t)0xca385d1d, + (q31_t)0x62a74f40, (q31_t)0xca318e32, (q31_t)0x629cbdfa, (q31_t)0xca2ac15b, + (q31_t)0x62922b5e, (q31_t)0xca23f698, (q31_t)0x6287976e, (q31_t)0xca1d2de7, + (q31_t)0x627d0228, (q31_t)0xca16674b, (q31_t)0x62726b8e, (q31_t)0xca0fa2c3, + (q31_t)0x6267d3a0, (q31_t)0xca08e04f, (q31_t)0x625d3a5e, (q31_t)0xca021fef, + (q31_t)0x62529fca, (q31_t)0xc9fb61a5, (q31_t)0x624803e2, (q31_t)0xc9f4a570, + (q31_t)0x623d66a8, (q31_t)0xc9edeb50, (q31_t)0x6232c81c, (q31_t)0xc9e73346, + (q31_t)0x6228283f, (q31_t)0xc9e07d51, (q31_t)0x621d8711, (q31_t)0xc9d9c973, + (q31_t)0x6212e492, (q31_t)0xc9d317ab, (q31_t)0x620840c2, (q31_t)0xc9cc67fa, + (q31_t)0x61fd9ba3, (q31_t)0xc9c5ba60, (q31_t)0x61f2f534, (q31_t)0xc9bf0edd, + (q31_t)0x61e84d76, (q31_t)0xc9b86572, (q31_t)0x61dda46a, (q31_t)0xc9b1be1e, + (q31_t)0x61d2fa0f, (q31_t)0xc9ab18e3, (q31_t)0x61c84e67, (q31_t)0xc9a475bf, + (q31_t)0x61bda171, (q31_t)0xc99dd4b4, (q31_t)0x61b2f32e, (q31_t)0xc99735c2, + (q31_t)0x61a8439e, (q31_t)0xc99098e9, (q31_t)0x619d92c2, (q31_t)0xc989fe29, + (q31_t)0x6192e09b, (q31_t)0xc9836582, (q31_t)0x61882d28, (q31_t)0xc97ccef5, + (q31_t)0x617d786a, (q31_t)0xc9763a83, (q31_t)0x6172c262, (q31_t)0xc96fa82a, + (q31_t)0x61680b0f, (q31_t)0xc96917ec, (q31_t)0x615d5273, (q31_t)0xc96289c9, + (q31_t)0x6152988d, (q31_t)0xc95bfdc1, (q31_t)0x6147dd5f, (q31_t)0xc95573d4, + (q31_t)0x613d20e8, (q31_t)0xc94eec03, (q31_t)0x61326329, (q31_t)0xc948664d, + (q31_t)0x6127a423, (q31_t)0xc941e2b4, (q31_t)0x611ce3d5, (q31_t)0xc93b6137, + (q31_t)0x61122240, (q31_t)0xc934e1d6, (q31_t)0x61075f65, (q31_t)0xc92e6492, + (q31_t)0x60fc9b44, (q31_t)0xc927e96b, (q31_t)0x60f1d5de, (q31_t)0xc9217062, + (q31_t)0x60e70f32, (q31_t)0xc91af976, (q31_t)0x60dc4742, (q31_t)0xc91484a8, + (q31_t)0x60d17e0d, (q31_t)0xc90e11f7, (q31_t)0x60c6b395, (q31_t)0xc907a166, + (q31_t)0x60bbe7d8, (q31_t)0xc90132f2, (q31_t)0x60b11ad9, (q31_t)0xc8fac69e, + (q31_t)0x60a64c97, (q31_t)0xc8f45c68, (q31_t)0x609b7d13, (q31_t)0xc8edf452, + (q31_t)0x6090ac4d, (q31_t)0xc8e78e5b, (q31_t)0x6085da46, (q31_t)0xc8e12a84, + (q31_t)0x607b06fe, (q31_t)0xc8dac8cd, (q31_t)0x60703275, (q31_t)0xc8d46936, + (q31_t)0x60655cac, (q31_t)0xc8ce0bc0, (q31_t)0x605a85a3, (q31_t)0xc8c7b06b, + (q31_t)0x604fad5b, (q31_t)0xc8c15736, (q31_t)0x6044d3d4, (q31_t)0xc8bb0023, + (q31_t)0x6039f90f, (q31_t)0xc8b4ab32, (q31_t)0x602f1d0b, (q31_t)0xc8ae5862, + (q31_t)0x60243fca, (q31_t)0xc8a807b4, (q31_t)0x6019614c, (q31_t)0xc8a1b928, + (q31_t)0x600e8190, (q31_t)0xc89b6cbf, (q31_t)0x6003a099, (q31_t)0xc8952278, + (q31_t)0x5ff8be65, (q31_t)0xc88eda54, (q31_t)0x5feddaf6, (q31_t)0xc8889454, + (q31_t)0x5fe2f64c, (q31_t)0xc8825077, (q31_t)0x5fd81067, (q31_t)0xc87c0ebd, + (q31_t)0x5fcd2948, (q31_t)0xc875cf28, (q31_t)0x5fc240ef, (q31_t)0xc86f91b7, + (q31_t)0x5fb7575c, (q31_t)0xc869566a, (q31_t)0x5fac6c91, (q31_t)0xc8631d42, + (q31_t)0x5fa1808c, (q31_t)0xc85ce63e, (q31_t)0x5f969350, (q31_t)0xc856b160, + (q31_t)0x5f8ba4dc, (q31_t)0xc8507ea7, (q31_t)0x5f80b531, (q31_t)0xc84a4e14, + (q31_t)0x5f75c44e, (q31_t)0xc8441fa6, (q31_t)0x5f6ad235, (q31_t)0xc83df35f, + (q31_t)0x5f5fdee6, (q31_t)0xc837c93e, (q31_t)0x5f54ea62, (q31_t)0xc831a143, + (q31_t)0x5f49f4a8, (q31_t)0xc82b7b70, (q31_t)0x5f3efdb9, (q31_t)0xc82557c3, + (q31_t)0x5f340596, (q31_t)0xc81f363d, (q31_t)0x5f290c3f, (q31_t)0xc81916df, + (q31_t)0x5f1e11b5, (q31_t)0xc812f9a9, (q31_t)0x5f1315f7, (q31_t)0xc80cde9b, + (q31_t)0x5f081907, (q31_t)0xc806c5b5, (q31_t)0x5efd1ae4, (q31_t)0xc800aef7, + (q31_t)0x5ef21b90, (q31_t)0xc7fa9a62, (q31_t)0x5ee71b0a, (q31_t)0xc7f487f6, + (q31_t)0x5edc1953, (q31_t)0xc7ee77b3, (q31_t)0x5ed1166b, (q31_t)0xc7e8699a, + (q31_t)0x5ec61254, (q31_t)0xc7e25daa, (q31_t)0x5ebb0d0d, (q31_t)0xc7dc53e3, + (q31_t)0x5eb00696, (q31_t)0xc7d64c47, (q31_t)0x5ea4fef0, (q31_t)0xc7d046d6, + (q31_t)0x5e99f61d, (q31_t)0xc7ca438f, (q31_t)0x5e8eec1b, (q31_t)0xc7c44272, + (q31_t)0x5e83e0eb, (q31_t)0xc7be4381, (q31_t)0x5e78d48e, (q31_t)0xc7b846ba, + (q31_t)0x5e6dc705, (q31_t)0xc7b24c20, (q31_t)0x5e62b84f, (q31_t)0xc7ac53b1, + (q31_t)0x5e57a86d, (q31_t)0xc7a65d6e, (q31_t)0x5e4c9760, (q31_t)0xc7a06957, + (q31_t)0x5e418528, (q31_t)0xc79a776c, (q31_t)0x5e3671c5, (q31_t)0xc79487ae, + (q31_t)0x5e2b5d38, (q31_t)0xc78e9a1d, (q31_t)0x5e204781, (q31_t)0xc788aeb9, + (q31_t)0x5e1530a1, (q31_t)0xc782c582, (q31_t)0x5e0a1898, (q31_t)0xc77cde79, + (q31_t)0x5dfeff67, (q31_t)0xc776f99d, (q31_t)0x5df3e50d, (q31_t)0xc77116f0, + (q31_t)0x5de8c98c, (q31_t)0xc76b3671, (q31_t)0x5dddace4, (q31_t)0xc7655820, + (q31_t)0x5dd28f15, (q31_t)0xc75f7bfe, (q31_t)0x5dc7701f, (q31_t)0xc759a20a, + (q31_t)0x5dbc5004, (q31_t)0xc753ca46, (q31_t)0x5db12ec3, (q31_t)0xc74df4b1, + (q31_t)0x5da60c5d, (q31_t)0xc748214c, (q31_t)0x5d9ae8d2, (q31_t)0xc7425016, + (q31_t)0x5d8fc424, (q31_t)0xc73c8111, (q31_t)0x5d849e51, (q31_t)0xc736b43c, + (q31_t)0x5d79775c, (q31_t)0xc730e997, (q31_t)0x5d6e4f43, (q31_t)0xc72b2123, + (q31_t)0x5d632608, (q31_t)0xc7255ae0, (q31_t)0x5d57fbaa, (q31_t)0xc71f96ce, + (q31_t)0x5d4cd02c, (q31_t)0xc719d4ed, (q31_t)0x5d41a38c, (q31_t)0xc714153e, + (q31_t)0x5d3675cb, (q31_t)0xc70e57c0, (q31_t)0x5d2b46ea, (q31_t)0xc7089c75, + (q31_t)0x5d2016e9, (q31_t)0xc702e35c, (q31_t)0x5d14e5c9, (q31_t)0xc6fd2c75, + (q31_t)0x5d09b389, (q31_t)0xc6f777c1, (q31_t)0x5cfe802b, (q31_t)0xc6f1c540, + (q31_t)0x5cf34baf, (q31_t)0xc6ec14f2, (q31_t)0x5ce81615, (q31_t)0xc6e666d7, + (q31_t)0x5cdcdf5e, (q31_t)0xc6e0baf0, (q31_t)0x5cd1a78a, (q31_t)0xc6db113d, + (q31_t)0x5cc66e99, (q31_t)0xc6d569be, (q31_t)0x5cbb348d, (q31_t)0xc6cfc472, + (q31_t)0x5caff965, (q31_t)0xc6ca215c, (q31_t)0x5ca4bd21, (q31_t)0xc6c4807a, + (q31_t)0x5c997fc4, (q31_t)0xc6bee1cd, (q31_t)0x5c8e414b, (q31_t)0xc6b94554, + (q31_t)0x5c8301b9, (q31_t)0xc6b3ab12, (q31_t)0x5c77c10e, (q31_t)0xc6ae1304, + (q31_t)0x5c6c7f4a, (q31_t)0xc6a87d2d, (q31_t)0x5c613c6d, (q31_t)0xc6a2e98b, + (q31_t)0x5c55f878, (q31_t)0xc69d5820, (q31_t)0x5c4ab36b, (q31_t)0xc697c8eb, + (q31_t)0x5c3f6d47, (q31_t)0xc6923bec, (q31_t)0x5c34260c, (q31_t)0xc68cb124, + (q31_t)0x5c28ddbb, (q31_t)0xc6872894, (q31_t)0x5c1d9454, (q31_t)0xc681a23a, + (q31_t)0x5c1249d8, (q31_t)0xc67c1e18, (q31_t)0x5c06fe46, (q31_t)0xc6769c2e, + (q31_t)0x5bfbb1a0, (q31_t)0xc6711c7b, (q31_t)0x5bf063e6, (q31_t)0xc66b9f01, + (q31_t)0x5be51518, (q31_t)0xc66623be, (q31_t)0x5bd9c537, (q31_t)0xc660aab5, + (q31_t)0x5bce7442, (q31_t)0xc65b33e4, (q31_t)0x5bc3223c, (q31_t)0xc655bf4c, + (q31_t)0x5bb7cf23, (q31_t)0xc6504ced, (q31_t)0x5bac7af9, (q31_t)0xc64adcc7, + (q31_t)0x5ba125bd, (q31_t)0xc6456edb, (q31_t)0x5b95cf71, (q31_t)0xc6400329, + (q31_t)0x5b8a7815, (q31_t)0xc63a99b1, (q31_t)0x5b7f1fa9, (q31_t)0xc6353273, + (q31_t)0x5b73c62d, (q31_t)0xc62fcd6f, (q31_t)0x5b686ba3, (q31_t)0xc62a6aa6, + (q31_t)0x5b5d100a, (q31_t)0xc6250a18, (q31_t)0x5b51b363, (q31_t)0xc61fabc4, + (q31_t)0x5b4655ae, (q31_t)0xc61a4fac, (q31_t)0x5b3af6ec, (q31_t)0xc614f5cf, + (q31_t)0x5b2f971e, (q31_t)0xc60f9e2e, (q31_t)0x5b243643, (q31_t)0xc60a48c9, + (q31_t)0x5b18d45c, (q31_t)0xc604f5a0, (q31_t)0x5b0d716a, (q31_t)0xc5ffa4b3, + (q31_t)0x5b020d6c, (q31_t)0xc5fa5603, (q31_t)0x5af6a865, (q31_t)0xc5f5098f, + (q31_t)0x5aeb4253, (q31_t)0xc5efbf58, (q31_t)0x5adfdb37, (q31_t)0xc5ea775e, + (q31_t)0x5ad47312, (q31_t)0xc5e531a1, (q31_t)0x5ac909e5, (q31_t)0xc5dfee22, + (q31_t)0x5abd9faf, (q31_t)0xc5daace1, (q31_t)0x5ab23471, (q31_t)0xc5d56ddd, + (q31_t)0x5aa6c82b, (q31_t)0xc5d03118, (q31_t)0x5a9b5adf, (q31_t)0xc5caf690, + (q31_t)0x5a8fec8c, (q31_t)0xc5c5be47, (q31_t)0x5a847d33, (q31_t)0xc5c0883d, + (q31_t)0x5a790cd4, (q31_t)0xc5bb5472, (q31_t)0x5a6d9b70, (q31_t)0xc5b622e6, + (q31_t)0x5a622907, (q31_t)0xc5b0f399, (q31_t)0x5a56b599, (q31_t)0xc5abc68c, + (q31_t)0x5a4b4128, (q31_t)0xc5a69bbe, (q31_t)0x5a3fcbb3, (q31_t)0xc5a17330, + (q31_t)0x5a34553b, (q31_t)0xc59c4ce3, (q31_t)0x5a28ddc0, (q31_t)0xc59728d5, + (q31_t)0x5a1d6544, (q31_t)0xc5920708, (q31_t)0x5a11ebc5, (q31_t)0xc58ce77c, + (q31_t)0x5a067145, (q31_t)0xc587ca31, (q31_t)0x59faf5c5, (q31_t)0xc582af26, + (q31_t)0x59ef7944, (q31_t)0xc57d965d, (q31_t)0x59e3fbc3, (q31_t)0xc5787fd6, + (q31_t)0x59d87d42, (q31_t)0xc5736b90, (q31_t)0x59ccfdc2, (q31_t)0xc56e598c, + (q31_t)0x59c17d44, (q31_t)0xc56949ca, (q31_t)0x59b5fbc8, (q31_t)0xc5643c4a, + (q31_t)0x59aa794d, (q31_t)0xc55f310d, (q31_t)0x599ef5d6, (q31_t)0xc55a2812, + (q31_t)0x59937161, (q31_t)0xc555215a, (q31_t)0x5987ebf0, (q31_t)0xc5501ce5, + (q31_t)0x597c6584, (q31_t)0xc54b1ab4, (q31_t)0x5970de1b, (q31_t)0xc5461ac6, + (q31_t)0x596555b8, (q31_t)0xc5411d1b, (q31_t)0x5959cc5a, (q31_t)0xc53c21b4, + (q31_t)0x594e4201, (q31_t)0xc5372891, (q31_t)0x5942b6af, (q31_t)0xc53231b3, + (q31_t)0x59372a64, (q31_t)0xc52d3d18, (q31_t)0x592b9d1f, (q31_t)0xc5284ac3, + (q31_t)0x59200ee3, (q31_t)0xc5235ab2, (q31_t)0x59147fae, (q31_t)0xc51e6ce6, + (q31_t)0x5908ef82, (q31_t)0xc519815f, (q31_t)0x58fd5e5f, (q31_t)0xc514981d, + (q31_t)0x58f1cc45, (q31_t)0xc50fb121, (q31_t)0x58e63935, (q31_t)0xc50acc6b, + (q31_t)0x58daa52f, (q31_t)0xc505e9fb, (q31_t)0x58cf1034, (q31_t)0xc50109d0, + (q31_t)0x58c37a44, (q31_t)0xc4fc2bec, (q31_t)0x58b7e35f, (q31_t)0xc4f7504e, + (q31_t)0x58ac4b87, (q31_t)0xc4f276f7, (q31_t)0x58a0b2bb, (q31_t)0xc4ed9fe7, + (q31_t)0x589518fc, (q31_t)0xc4e8cb1e, (q31_t)0x58897e4a, (q31_t)0xc4e3f89c, + (q31_t)0x587de2a7, (q31_t)0xc4df2862, (q31_t)0x58724611, (q31_t)0xc4da5a6f, + (q31_t)0x5866a88a, (q31_t)0xc4d58ec3, (q31_t)0x585b0a13, (q31_t)0xc4d0c560, + (q31_t)0x584f6aab, (q31_t)0xc4cbfe45, (q31_t)0x5843ca53, (q31_t)0xc4c73972, + (q31_t)0x5838290c, (q31_t)0xc4c276e8, (q31_t)0x582c86d5, (q31_t)0xc4bdb6a6, + (q31_t)0x5820e3b0, (q31_t)0xc4b8f8ad, (q31_t)0x58153f9d, (q31_t)0xc4b43cfd, + (q31_t)0x58099a9c, (q31_t)0xc4af8397, (q31_t)0x57fdf4ae, (q31_t)0xc4aacc7a, + (q31_t)0x57f24dd3, (q31_t)0xc4a617a6, (q31_t)0x57e6a60c, (q31_t)0xc4a1651c, + (q31_t)0x57dafd59, (q31_t)0xc49cb4dd, (q31_t)0x57cf53bb, (q31_t)0xc49806e7, + (q31_t)0x57c3a931, (q31_t)0xc4935b3c, (q31_t)0x57b7fdbd, (q31_t)0xc48eb1db, + (q31_t)0x57ac515f, (q31_t)0xc48a0ac4, (q31_t)0x57a0a417, (q31_t)0xc48565f9, + (q31_t)0x5794f5e6, (q31_t)0xc480c379, (q31_t)0x578946cc, (q31_t)0xc47c2344, + (q31_t)0x577d96ca, (q31_t)0xc477855a, (q31_t)0x5771e5e0, (q31_t)0xc472e9bc, + (q31_t)0x5766340f, (q31_t)0xc46e5069, (q31_t)0x575a8157, (q31_t)0xc469b963, + (q31_t)0x574ecdb8, (q31_t)0xc46524a9, (q31_t)0x57431933, (q31_t)0xc460923b, + (q31_t)0x573763c9, (q31_t)0xc45c0219, (q31_t)0x572bad7a, (q31_t)0xc4577444, + (q31_t)0x571ff646, (q31_t)0xc452e8bc, (q31_t)0x57143e2d, (q31_t)0xc44e5f80, + (q31_t)0x57088531, (q31_t)0xc449d892, (q31_t)0x56fccb51, (q31_t)0xc44553f2, + (q31_t)0x56f1108f, (q31_t)0xc440d19e, (q31_t)0x56e554ea, (q31_t)0xc43c5199, + (q31_t)0x56d99864, (q31_t)0xc437d3e1, (q31_t)0x56cddafb, (q31_t)0xc4335877, + (q31_t)0x56c21cb2, (q31_t)0xc42edf5c, (q31_t)0x56b65d88, (q31_t)0xc42a688f, + (q31_t)0x56aa9d7e, (q31_t)0xc425f410, (q31_t)0x569edc94, (q31_t)0xc42181e0, + (q31_t)0x56931acb, (q31_t)0xc41d11ff, (q31_t)0x56875823, (q31_t)0xc418a46d, + (q31_t)0x567b949d, (q31_t)0xc414392b, (q31_t)0x566fd039, (q31_t)0xc40fd037, + (q31_t)0x56640af7, (q31_t)0xc40b6994, (q31_t)0x565844d8, (q31_t)0xc4070540, + (q31_t)0x564c7ddd, (q31_t)0xc402a33c, (q31_t)0x5640b606, (q31_t)0xc3fe4388, + (q31_t)0x5634ed53, (q31_t)0xc3f9e624, (q31_t)0x562923c5, (q31_t)0xc3f58b10, + (q31_t)0x561d595d, (q31_t)0xc3f1324e, (q31_t)0x56118e1a, (q31_t)0xc3ecdbdc, + (q31_t)0x5605c1fd, (q31_t)0xc3e887bb, (q31_t)0x55f9f507, (q31_t)0xc3e435ea, + (q31_t)0x55ee2738, (q31_t)0xc3dfe66c, (q31_t)0x55e25890, (q31_t)0xc3db993e, + (q31_t)0x55d68911, (q31_t)0xc3d74e62, (q31_t)0x55cab8ba, (q31_t)0xc3d305d8, + (q31_t)0x55bee78c, (q31_t)0xc3cebfa0, (q31_t)0x55b31587, (q31_t)0xc3ca7bba, + (q31_t)0x55a742ac, (q31_t)0xc3c63a26, (q31_t)0x559b6efb, (q31_t)0xc3c1fae5, + (q31_t)0x558f9a76, (q31_t)0xc3bdbdf6, (q31_t)0x5583c51b, (q31_t)0xc3b9835a, + (q31_t)0x5577eeec, (q31_t)0xc3b54b11, (q31_t)0x556c17e9, (q31_t)0xc3b1151b, + (q31_t)0x55604013, (q31_t)0xc3ace178, (q31_t)0x5554676a, (q31_t)0xc3a8b028, + (q31_t)0x55488dee, (q31_t)0xc3a4812c, (q31_t)0x553cb3a0, (q31_t)0xc3a05484, + (q31_t)0x5530d881, (q31_t)0xc39c2a2f, (q31_t)0x5524fc90, (q31_t)0xc398022f, + (q31_t)0x55191fcf, (q31_t)0xc393dc82, (q31_t)0x550d423d, (q31_t)0xc38fb92a, + (q31_t)0x550163dc, (q31_t)0xc38b9827, (q31_t)0x54f584ac, (q31_t)0xc3877978, + (q31_t)0x54e9a4ac, (q31_t)0xc3835d1e, (q31_t)0x54ddc3de, (q31_t)0xc37f4319, + (q31_t)0x54d1e242, (q31_t)0xc37b2b6a, (q31_t)0x54c5ffd9, (q31_t)0xc377160f, + (q31_t)0x54ba1ca3, (q31_t)0xc373030a, (q31_t)0x54ae38a0, (q31_t)0xc36ef25b, + (q31_t)0x54a253d1, (q31_t)0xc36ae401, (q31_t)0x54966e36, (q31_t)0xc366d7fd, + (q31_t)0x548a87d1, (q31_t)0xc362ce50, (q31_t)0x547ea0a0, (q31_t)0xc35ec6f8, + (q31_t)0x5472b8a5, (q31_t)0xc35ac1f7, (q31_t)0x5466cfe1, (q31_t)0xc356bf4d, + (q31_t)0x545ae653, (q31_t)0xc352bef9, (q31_t)0x544efbfc, (q31_t)0xc34ec0fc, + (q31_t)0x544310dd, (q31_t)0xc34ac556, (q31_t)0x543724f5, (q31_t)0xc346cc07, + (q31_t)0x542b3846, (q31_t)0xc342d510, (q31_t)0x541f4ad1, (q31_t)0xc33ee070, + (q31_t)0x54135c94, (q31_t)0xc33aee27, (q31_t)0x54076d91, (q31_t)0xc336fe37, + (q31_t)0x53fb7dc9, (q31_t)0xc333109e, (q31_t)0x53ef8d3c, (q31_t)0xc32f255e, + (q31_t)0x53e39be9, (q31_t)0xc32b3c75, (q31_t)0x53d7a9d3, (q31_t)0xc32755e5, + (q31_t)0x53cbb6f8, (q31_t)0xc32371ae, (q31_t)0x53bfc35b, (q31_t)0xc31f8fcf, + (q31_t)0x53b3cefa, (q31_t)0xc31bb049, (q31_t)0x53a7d9d7, (q31_t)0xc317d31c, + (q31_t)0x539be3f2, (q31_t)0xc313f848, (q31_t)0x538fed4b, (q31_t)0xc3101fce, + (q31_t)0x5383f5e3, (q31_t)0xc30c49ad, (q31_t)0x5377fdbb, (q31_t)0xc30875e5, + (q31_t)0x536c04d2, (q31_t)0xc304a477, (q31_t)0x53600b2a, (q31_t)0xc300d563, + (q31_t)0x535410c3, (q31_t)0xc2fd08a9, (q31_t)0x5348159d, (q31_t)0xc2f93e4a, + (q31_t)0x533c19b8, (q31_t)0xc2f57644, (q31_t)0x53301d16, (q31_t)0xc2f1b099, + (q31_t)0x53241fb6, (q31_t)0xc2eded49, (q31_t)0x5318219a, (q31_t)0xc2ea2c53, + (q31_t)0x530c22c1, (q31_t)0xc2e66db8, (q31_t)0x5300232c, (q31_t)0xc2e2b178, + (q31_t)0x52f422db, (q31_t)0xc2def794, (q31_t)0x52e821cf, (q31_t)0xc2db400a, + (q31_t)0x52dc2009, (q31_t)0xc2d78add, (q31_t)0x52d01d89, (q31_t)0xc2d3d80a, + (q31_t)0x52c41a4f, (q31_t)0xc2d02794, (q31_t)0x52b8165b, (q31_t)0xc2cc7979, + (q31_t)0x52ac11af, (q31_t)0xc2c8cdbb, (q31_t)0x52a00c4b, (q31_t)0xc2c52459, + (q31_t)0x5294062f, (q31_t)0xc2c17d52, (q31_t)0x5287ff5b, (q31_t)0xc2bdd8a9, + (q31_t)0x527bf7d1, (q31_t)0xc2ba365c, (q31_t)0x526fef90, (q31_t)0xc2b6966c, + (q31_t)0x5263e699, (q31_t)0xc2b2f8d8, (q31_t)0x5257dced, (q31_t)0xc2af5da2, + (q31_t)0x524bd28c, (q31_t)0xc2abc4c9, (q31_t)0x523fc776, (q31_t)0xc2a82e4d, + (q31_t)0x5233bbac, (q31_t)0xc2a49a2e, (q31_t)0x5227af2e, (q31_t)0xc2a1086d, + (q31_t)0x521ba1fd, (q31_t)0xc29d790a, (q31_t)0x520f941a, (q31_t)0xc299ec05, + (q31_t)0x52038584, (q31_t)0xc296615d, (q31_t)0x51f7763c, (q31_t)0xc292d914, + (q31_t)0x51eb6643, (q31_t)0xc28f5329, (q31_t)0x51df5599, (q31_t)0xc28bcf9c, + (q31_t)0x51d3443f, (q31_t)0xc2884e6e, (q31_t)0x51c73235, (q31_t)0xc284cf9f, + (q31_t)0x51bb1f7c, (q31_t)0xc281532e, (q31_t)0x51af0c13, (q31_t)0xc27dd91c, + (q31_t)0x51a2f7fc, (q31_t)0xc27a616a, (q31_t)0x5196e337, (q31_t)0xc276ec16, + (q31_t)0x518acdc4, (q31_t)0xc2737922, (q31_t)0x517eb7a4, (q31_t)0xc270088e, + (q31_t)0x5172a0d7, (q31_t)0xc26c9a58, (q31_t)0x5166895f, (q31_t)0xc2692e83, + (q31_t)0x515a713a, (q31_t)0xc265c50e, (q31_t)0x514e586a, (q31_t)0xc2625df8, + (q31_t)0x51423ef0, (q31_t)0xc25ef943, (q31_t)0x513624cb, (q31_t)0xc25b96ee, + (q31_t)0x512a09fc, (q31_t)0xc25836f9, (q31_t)0x511dee84, (q31_t)0xc254d965, + (q31_t)0x5111d263, (q31_t)0xc2517e31, (q31_t)0x5105b599, (q31_t)0xc24e255e, + (q31_t)0x50f99827, (q31_t)0xc24aceed, (q31_t)0x50ed7a0e, (q31_t)0xc2477adc, + (q31_t)0x50e15b4e, (q31_t)0xc244292c, (q31_t)0x50d53be7, (q31_t)0xc240d9de, + (q31_t)0x50c91bda, (q31_t)0xc23d8cf1, (q31_t)0x50bcfb28, (q31_t)0xc23a4265, + (q31_t)0x50b0d9d0, (q31_t)0xc236fa3b, (q31_t)0x50a4b7d3, (q31_t)0xc233b473, + (q31_t)0x50989532, (q31_t)0xc230710d, (q31_t)0x508c71ee, (q31_t)0xc22d3009, + (q31_t)0x50804e06, (q31_t)0xc229f167, (q31_t)0x5074297b, (q31_t)0xc226b528, + (q31_t)0x5068044e, (q31_t)0xc2237b4b, (q31_t)0x505bde7f, (q31_t)0xc22043d0, + (q31_t)0x504fb80e, (q31_t)0xc21d0eb8, (q31_t)0x504390fd, (q31_t)0xc219dc03, + (q31_t)0x5037694b, (q31_t)0xc216abb1, (q31_t)0x502b40f8, (q31_t)0xc2137dc2, + (q31_t)0x501f1807, (q31_t)0xc2105236, (q31_t)0x5012ee76, (q31_t)0xc20d290d, + (q31_t)0x5006c446, (q31_t)0xc20a0248, (q31_t)0x4ffa9979, (q31_t)0xc206dde6, + (q31_t)0x4fee6e0d, (q31_t)0xc203bbe8, (q31_t)0x4fe24205, (q31_t)0xc2009c4e, + (q31_t)0x4fd6155f, (q31_t)0xc1fd7f17, (q31_t)0x4fc9e81e, (q31_t)0xc1fa6445, + (q31_t)0x4fbdba40, (q31_t)0xc1f74bd6, (q31_t)0x4fb18bc8, (q31_t)0xc1f435cc, + (q31_t)0x4fa55cb4, (q31_t)0xc1f12227, (q31_t)0x4f992d06, (q31_t)0xc1ee10e5, + (q31_t)0x4f8cfcbe, (q31_t)0xc1eb0209, (q31_t)0x4f80cbdc, (q31_t)0xc1e7f591, + (q31_t)0x4f749a61, (q31_t)0xc1e4eb7e, (q31_t)0x4f68684e, (q31_t)0xc1e1e3d0, + (q31_t)0x4f5c35a3, (q31_t)0xc1dede87, (q31_t)0x4f500260, (q31_t)0xc1dbdba3, + (q31_t)0x4f43ce86, (q31_t)0xc1d8db25, (q31_t)0x4f379a16, (q31_t)0xc1d5dd0c, + (q31_t)0x4f2b650f, (q31_t)0xc1d2e158, (q31_t)0x4f1f2f73, (q31_t)0xc1cfe80a, + (q31_t)0x4f12f941, (q31_t)0xc1ccf122, (q31_t)0x4f06c27a, (q31_t)0xc1c9fca0, + (q31_t)0x4efa8b20, (q31_t)0xc1c70a84, (q31_t)0x4eee5331, (q31_t)0xc1c41ace, + (q31_t)0x4ee21aaf, (q31_t)0xc1c12d7e, (q31_t)0x4ed5e19a, (q31_t)0xc1be4294, + (q31_t)0x4ec9a7f3, (q31_t)0xc1bb5a11, (q31_t)0x4ebd6db9, (q31_t)0xc1b873f5, + (q31_t)0x4eb132ef, (q31_t)0xc1b5903f, (q31_t)0x4ea4f793, (q31_t)0xc1b2aef0, + (q31_t)0x4e98bba7, (q31_t)0xc1afd007, (q31_t)0x4e8c7f2a, (q31_t)0xc1acf386, + (q31_t)0x4e80421e, (q31_t)0xc1aa196c, (q31_t)0x4e740483, (q31_t)0xc1a741b9, + (q31_t)0x4e67c65a, (q31_t)0xc1a46c6e, (q31_t)0x4e5b87a2, (q31_t)0xc1a1998a, + (q31_t)0x4e4f485c, (q31_t)0xc19ec90d, (q31_t)0x4e430889, (q31_t)0xc19bfaf9, + (q31_t)0x4e36c82a, (q31_t)0xc1992f4c, (q31_t)0x4e2a873e, (q31_t)0xc1966606, + (q31_t)0x4e1e45c6, (q31_t)0xc1939f29, (q31_t)0x4e1203c3, (q31_t)0xc190dab4, + (q31_t)0x4e05c135, (q31_t)0xc18e18a7, (q31_t)0x4df97e1d, (q31_t)0xc18b5903, + (q31_t)0x4ded3a7b, (q31_t)0xc1889bc6, (q31_t)0x4de0f64f, (q31_t)0xc185e0f3, + (q31_t)0x4dd4b19a, (q31_t)0xc1832888, (q31_t)0x4dc86c5d, (q31_t)0xc1807285, + (q31_t)0x4dbc2698, (q31_t)0xc17dbeec, (q31_t)0x4dafe04b, (q31_t)0xc17b0dbb, + (q31_t)0x4da39978, (q31_t)0xc1785ef4, (q31_t)0x4d97521d, (q31_t)0xc175b296, + (q31_t)0x4d8b0a3d, (q31_t)0xc17308a1, (q31_t)0x4d7ec1d6, (q31_t)0xc1706115, + (q31_t)0x4d7278eb, (q31_t)0xc16dbbf3, (q31_t)0x4d662f7b, (q31_t)0xc16b193a, + (q31_t)0x4d59e586, (q31_t)0xc16878eb, (q31_t)0x4d4d9b0e, (q31_t)0xc165db05, + (q31_t)0x4d415013, (q31_t)0xc1633f8a, (q31_t)0x4d350495, (q31_t)0xc160a678, + (q31_t)0x4d28b894, (q31_t)0xc15e0fd1, (q31_t)0x4d1c6c11, (q31_t)0xc15b7b94, + (q31_t)0x4d101f0e, (q31_t)0xc158e9c1, (q31_t)0x4d03d189, (q31_t)0xc1565a58, + (q31_t)0x4cf78383, (q31_t)0xc153cd5a, (q31_t)0x4ceb34fe, (q31_t)0xc15142c6, + (q31_t)0x4cdee5f9, (q31_t)0xc14eba9d, (q31_t)0x4cd29676, (q31_t)0xc14c34df, + (q31_t)0x4cc64673, (q31_t)0xc149b18b, (q31_t)0x4cb9f5f3, (q31_t)0xc14730a3, + (q31_t)0x4cada4f5, (q31_t)0xc144b225, (q31_t)0x4ca1537a, (q31_t)0xc1423613, + (q31_t)0x4c950182, (q31_t)0xc13fbc6c, (q31_t)0x4c88af0e, (q31_t)0xc13d4530, + (q31_t)0x4c7c5c1e, (q31_t)0xc13ad060, (q31_t)0x4c7008b3, (q31_t)0xc1385dfb, + (q31_t)0x4c63b4ce, (q31_t)0xc135ee02, (q31_t)0x4c57606e, (q31_t)0xc1338075, + (q31_t)0x4c4b0b94, (q31_t)0xc1311553, (q31_t)0x4c3eb641, (q31_t)0xc12eac9d, + (q31_t)0x4c326075, (q31_t)0xc12c4653, (q31_t)0x4c260a31, (q31_t)0xc129e276, + (q31_t)0x4c19b374, (q31_t)0xc1278104, (q31_t)0x4c0d5c41, (q31_t)0xc12521ff, + (q31_t)0x4c010496, (q31_t)0xc122c566, (q31_t)0x4bf4ac75, (q31_t)0xc1206b39, + (q31_t)0x4be853de, (q31_t)0xc11e1379, (q31_t)0x4bdbfad1, (q31_t)0xc11bbe26, + (q31_t)0x4bcfa150, (q31_t)0xc1196b3f, (q31_t)0x4bc34759, (q31_t)0xc1171ac6, + (q31_t)0x4bb6ecef, (q31_t)0xc114ccb9, (q31_t)0x4baa9211, (q31_t)0xc1128119, + (q31_t)0x4b9e36c0, (q31_t)0xc11037e6, (q31_t)0x4b91dafc, (q31_t)0xc10df120, + (q31_t)0x4b857ec7, (q31_t)0xc10bacc8, (q31_t)0x4b79221f, (q31_t)0xc1096add, + (q31_t)0x4b6cc506, (q31_t)0xc1072b5f, (q31_t)0x4b60677c, (q31_t)0xc104ee4f, + (q31_t)0x4b540982, (q31_t)0xc102b3ac, (q31_t)0x4b47ab19, (q31_t)0xc1007b77, + (q31_t)0x4b3b4c40, (q31_t)0xc0fe45b0, (q31_t)0x4b2eecf8, (q31_t)0xc0fc1257, + (q31_t)0x4b228d42, (q31_t)0xc0f9e16b, (q31_t)0x4b162d1d, (q31_t)0xc0f7b2ee, + (q31_t)0x4b09cc8c, (q31_t)0xc0f586df, (q31_t)0x4afd6b8d, (q31_t)0xc0f35d3e, + (q31_t)0x4af10a22, (q31_t)0xc0f1360b, (q31_t)0x4ae4a84b, (q31_t)0xc0ef1147, + (q31_t)0x4ad84609, (q31_t)0xc0eceef1, (q31_t)0x4acbe35b, (q31_t)0xc0eacf09, + (q31_t)0x4abf8043, (q31_t)0xc0e8b190, (q31_t)0x4ab31cc1, (q31_t)0xc0e69686, + (q31_t)0x4aa6b8d5, (q31_t)0xc0e47deb, (q31_t)0x4a9a5480, (q31_t)0xc0e267be, + (q31_t)0x4a8defc3, (q31_t)0xc0e05401, (q31_t)0x4a818a9d, (q31_t)0xc0de42b2, + (q31_t)0x4a752510, (q31_t)0xc0dc33d2, (q31_t)0x4a68bf1b, (q31_t)0xc0da2762, + (q31_t)0x4a5c58c0, (q31_t)0xc0d81d61, (q31_t)0x4a4ff1fe, (q31_t)0xc0d615cf, + (q31_t)0x4a438ad7, (q31_t)0xc0d410ad, (q31_t)0x4a37234a, (q31_t)0xc0d20dfa, + (q31_t)0x4a2abb59, (q31_t)0xc0d00db6, (q31_t)0x4a1e5303, (q31_t)0xc0ce0fe3, + (q31_t)0x4a11ea49, (q31_t)0xc0cc147f, (q31_t)0x4a05812c, (q31_t)0xc0ca1b8a, + (q31_t)0x49f917ac, (q31_t)0xc0c82506, (q31_t)0x49ecadc9, (q31_t)0xc0c630f2, + (q31_t)0x49e04385, (q31_t)0xc0c43f4d, (q31_t)0x49d3d8df, (q31_t)0xc0c25019, + (q31_t)0x49c76dd8, (q31_t)0xc0c06355, (q31_t)0x49bb0271, (q31_t)0xc0be7901, + (q31_t)0x49ae96aa, (q31_t)0xc0bc911d, (q31_t)0x49a22a83, (q31_t)0xc0baabaa, + (q31_t)0x4995bdfd, (q31_t)0xc0b8c8a7, (q31_t)0x49895118, (q31_t)0xc0b6e815, + (q31_t)0x497ce3d5, (q31_t)0xc0b509f3, (q31_t)0x49707635, (q31_t)0xc0b32e42, + (q31_t)0x49640837, (q31_t)0xc0b15502, (q31_t)0x495799dd, (q31_t)0xc0af7e33, + (q31_t)0x494b2b27, (q31_t)0xc0ada9d4, (q31_t)0x493ebc14, (q31_t)0xc0abd7e6, + (q31_t)0x49324ca7, (q31_t)0xc0aa086a, (q31_t)0x4925dcdf, (q31_t)0xc0a83b5e, + (q31_t)0x49196cbc, (q31_t)0xc0a670c4, (q31_t)0x490cfc40, (q31_t)0xc0a4a89b, + (q31_t)0x49008b6a, (q31_t)0xc0a2e2e3, (q31_t)0x48f41a3c, (q31_t)0xc0a11f9d, + (q31_t)0x48e7a8b5, (q31_t)0xc09f5ec8, (q31_t)0x48db36d6, (q31_t)0xc09da065, + (q31_t)0x48cec4a0, (q31_t)0xc09be473, (q31_t)0x48c25213, (q31_t)0xc09a2af3, + (q31_t)0x48b5df30, (q31_t)0xc09873e4, (q31_t)0x48a96bf6, (q31_t)0xc096bf48, + (q31_t)0x489cf867, (q31_t)0xc0950d1d, (q31_t)0x48908483, (q31_t)0xc0935d64, + (q31_t)0x4884104b, (q31_t)0xc091b01d, (q31_t)0x48779bbe, (q31_t)0xc0900548, + (q31_t)0x486b26de, (q31_t)0xc08e5ce5, (q31_t)0x485eb1ab, (q31_t)0xc08cb6f5, + (q31_t)0x48523c25, (q31_t)0xc08b1376, (q31_t)0x4845c64d, (q31_t)0xc089726a, + (q31_t)0x48395024, (q31_t)0xc087d3d0, (q31_t)0x482cd9a9, (q31_t)0xc08637a9, + (q31_t)0x482062de, (q31_t)0xc0849df4, (q31_t)0x4813ebc2, (q31_t)0xc08306b2, + (q31_t)0x48077457, (q31_t)0xc08171e2, (q31_t)0x47fafc9c, (q31_t)0xc07fdf85, + (q31_t)0x47ee8493, (q31_t)0xc07e4f9b, (q31_t)0x47e20c3b, (q31_t)0xc07cc223, + (q31_t)0x47d59396, (q31_t)0xc07b371e, (q31_t)0x47c91aa3, (q31_t)0xc079ae8c, + (q31_t)0x47bca163, (q31_t)0xc078286e, (q31_t)0x47b027d7, (q31_t)0xc076a4c2, + (q31_t)0x47a3adff, (q31_t)0xc0752389, (q31_t)0x479733dc, (q31_t)0xc073a4c3, + (q31_t)0x478ab96e, (q31_t)0xc0722871, (q31_t)0x477e3eb5, (q31_t)0xc070ae92, + (q31_t)0x4771c3b3, (q31_t)0xc06f3726, (q31_t)0x47654867, (q31_t)0xc06dc22e, + (q31_t)0x4758ccd2, (q31_t)0xc06c4fa8, (q31_t)0x474c50f4, (q31_t)0xc06adf97, + (q31_t)0x473fd4cf, (q31_t)0xc06971f9, (q31_t)0x47335862, (q31_t)0xc06806ce, + (q31_t)0x4726dbae, (q31_t)0xc0669e18, (q31_t)0x471a5eb3, (q31_t)0xc06537d4, + (q31_t)0x470de172, (q31_t)0xc063d405, (q31_t)0x470163eb, (q31_t)0xc06272aa, + (q31_t)0x46f4e620, (q31_t)0xc06113c2, (q31_t)0x46e86810, (q31_t)0xc05fb74e, + (q31_t)0x46dbe9bb, (q31_t)0xc05e5d4e, (q31_t)0x46cf6b23, (q31_t)0xc05d05c3, + (q31_t)0x46c2ec48, (q31_t)0xc05bb0ab, (q31_t)0x46b66d29, (q31_t)0xc05a5e07, + (q31_t)0x46a9edc9, (q31_t)0xc0590dd8, (q31_t)0x469d6e27, (q31_t)0xc057c01d, + (q31_t)0x4690ee44, (q31_t)0xc05674d6, (q31_t)0x46846e1f, (q31_t)0xc0552c03, + (q31_t)0x4677edbb, (q31_t)0xc053e5a5, (q31_t)0x466b6d16, (q31_t)0xc052a1bb, + (q31_t)0x465eec33, (q31_t)0xc0516045, (q31_t)0x46526b10, (q31_t)0xc0502145, + (q31_t)0x4645e9af, (q31_t)0xc04ee4b8, (q31_t)0x46396810, (q31_t)0xc04daaa1, + (q31_t)0x462ce634, (q31_t)0xc04c72fe, (q31_t)0x4620641a, (q31_t)0xc04b3dcf, + (q31_t)0x4613e1c5, (q31_t)0xc04a0b16, (q31_t)0x46075f33, (q31_t)0xc048dad1, + (q31_t)0x45fadc66, (q31_t)0xc047ad01, (q31_t)0x45ee595d, (q31_t)0xc04681a6, + (q31_t)0x45e1d61b, (q31_t)0xc04558c0, (q31_t)0x45d5529e, (q31_t)0xc044324f, + (q31_t)0x45c8cee7, (q31_t)0xc0430e53, (q31_t)0x45bc4af8, (q31_t)0xc041eccc, + (q31_t)0x45afc6d0, (q31_t)0xc040cdba, (q31_t)0x45a3426f, (q31_t)0xc03fb11d, + (q31_t)0x4596bdd7, (q31_t)0xc03e96f6, (q31_t)0x458a3908, (q31_t)0xc03d7f44, + (q31_t)0x457db403, (q31_t)0xc03c6a07, (q31_t)0x45712ec7, (q31_t)0xc03b573f, + (q31_t)0x4564a955, (q31_t)0xc03a46ed, (q31_t)0x455823ae, (q31_t)0xc0393910, + (q31_t)0x454b9dd3, (q31_t)0xc0382da8, (q31_t)0x453f17c3, (q31_t)0xc03724b6, + (q31_t)0x4532917f, (q31_t)0xc0361e3a, (q31_t)0x45260b08, (q31_t)0xc0351a33, + (q31_t)0x4519845e, (q31_t)0xc03418a2, (q31_t)0x450cfd82, (q31_t)0xc0331986, + (q31_t)0x45007674, (q31_t)0xc0321ce0, (q31_t)0x44f3ef35, (q31_t)0xc03122b0, + (q31_t)0x44e767c5, (q31_t)0xc0302af5, (q31_t)0x44dae024, (q31_t)0xc02f35b1, + (q31_t)0x44ce5854, (q31_t)0xc02e42e2, (q31_t)0x44c1d054, (q31_t)0xc02d5289, + (q31_t)0x44b54825, (q31_t)0xc02c64a6, (q31_t)0x44a8bfc7, (q31_t)0xc02b7939, + (q31_t)0x449c373c, (q31_t)0xc02a9042, (q31_t)0x448fae83, (q31_t)0xc029a9c1, + (q31_t)0x4483259d, (q31_t)0xc028c5b6, (q31_t)0x44769c8b, (q31_t)0xc027e421, + (q31_t)0x446a134c, (q31_t)0xc0270502, (q31_t)0x445d89e2, (q31_t)0xc0262859, + (q31_t)0x4451004d, (q31_t)0xc0254e27, (q31_t)0x4444768d, (q31_t)0xc024766a, + (q31_t)0x4437eca4, (q31_t)0xc023a124, (q31_t)0x442b6290, (q31_t)0xc022ce54, + (q31_t)0x441ed854, (q31_t)0xc021fdfb, (q31_t)0x44124dee, (q31_t)0xc0213018, + (q31_t)0x4405c361, (q31_t)0xc02064ab, (q31_t)0x43f938ac, (q31_t)0xc01f9bb5, + (q31_t)0x43ecadcf, (q31_t)0xc01ed535, (q31_t)0x43e022cc, (q31_t)0xc01e112b, + (q31_t)0x43d397a3, (q31_t)0xc01d4f99, (q31_t)0x43c70c54, (q31_t)0xc01c907c, + (q31_t)0x43ba80df, (q31_t)0xc01bd3d6, (q31_t)0x43adf546, (q31_t)0xc01b19a7, + (q31_t)0x43a16988, (q31_t)0xc01a61ee, (q31_t)0x4394dda7, (q31_t)0xc019acac, + (q31_t)0x438851a2, (q31_t)0xc018f9e1, (q31_t)0x437bc57b, (q31_t)0xc018498c, + (q31_t)0x436f3931, (q31_t)0xc0179bae, (q31_t)0x4362acc5, (q31_t)0xc016f047, + (q31_t)0x43562038, (q31_t)0xc0164757, (q31_t)0x43499389, (q31_t)0xc015a0dd, + (q31_t)0x433d06bb, (q31_t)0xc014fcda, (q31_t)0x433079cc, (q31_t)0xc0145b4e, + (q31_t)0x4323ecbe, (q31_t)0xc013bc39, (q31_t)0x43175f91, (q31_t)0xc0131f9b, + (q31_t)0x430ad245, (q31_t)0xc0128574, (q31_t)0x42fe44dc, (q31_t)0xc011edc3, + (q31_t)0x42f1b755, (q31_t)0xc011588a, (q31_t)0x42e529b0, (q31_t)0xc010c5c7, + (q31_t)0x42d89bf0, (q31_t)0xc010357c, (q31_t)0x42cc0e13, (q31_t)0xc00fa7a8, + (q31_t)0x42bf801a, (q31_t)0xc00f1c4a, (q31_t)0x42b2f207, (q31_t)0xc00e9364, + (q31_t)0x42a663d8, (q31_t)0xc00e0cf5, (q31_t)0x4299d590, (q31_t)0xc00d88fd, + (q31_t)0x428d472e, (q31_t)0xc00d077c, (q31_t)0x4280b8b3, (q31_t)0xc00c8872, + (q31_t)0x42742a1f, (q31_t)0xc00c0be0, (q31_t)0x42679b73, (q31_t)0xc00b91c4, + (q31_t)0x425b0caf, (q31_t)0xc00b1a20, (q31_t)0x424e7dd4, (q31_t)0xc00aa4f3, + (q31_t)0x4241eee2, (q31_t)0xc00a323d, (q31_t)0x42355fd9, (q31_t)0xc009c1ff, + (q31_t)0x4228d0bb, (q31_t)0xc0095438, (q31_t)0x421c4188, (q31_t)0xc008e8e8, + (q31_t)0x420fb240, (q31_t)0xc008800f, (q31_t)0x420322e3, (q31_t)0xc00819ae, + (q31_t)0x41f69373, (q31_t)0xc007b5c4, (q31_t)0x41ea03ef, (q31_t)0xc0075452, + (q31_t)0x41dd7459, (q31_t)0xc006f556, (q31_t)0x41d0e4b0, (q31_t)0xc00698d3, + (q31_t)0x41c454f5, (q31_t)0xc0063ec6, (q31_t)0x41b7c528, (q31_t)0xc005e731, + (q31_t)0x41ab354b, (q31_t)0xc0059214, (q31_t)0x419ea55d, (q31_t)0xc0053f6e, + (q31_t)0x4192155f, (q31_t)0xc004ef3f, (q31_t)0x41858552, (q31_t)0xc004a188, + (q31_t)0x4178f536, (q31_t)0xc0045648, (q31_t)0x416c650b, (q31_t)0xc0040d80, + (q31_t)0x415fd4d2, (q31_t)0xc003c72f, (q31_t)0x4153448c, (q31_t)0xc0038356, + (q31_t)0x4146b438, (q31_t)0xc00341f4, (q31_t)0x413a23d8, (q31_t)0xc003030a, + (q31_t)0x412d936c, (q31_t)0xc002c697, (q31_t)0x412102f4, (q31_t)0xc0028c9c, + (q31_t)0x41147271, (q31_t)0xc0025519, (q31_t)0x4107e1e3, (q31_t)0xc002200d, + (q31_t)0x40fb514b, (q31_t)0xc001ed78, (q31_t)0x40eec0aa, (q31_t)0xc001bd5c, + (q31_t)0x40e22fff, (q31_t)0xc0018fb6, (q31_t)0x40d59f4c, (q31_t)0xc0016489, + (q31_t)0x40c90e90, (q31_t)0xc0013bd3, (q31_t)0x40bc7dcc, (q31_t)0xc0011594, + (q31_t)0x40afed02, (q31_t)0xc000f1ce, (q31_t)0x40a35c30, (q31_t)0xc000d07e, + (q31_t)0x4096cb58, (q31_t)0xc000b1a7, (q31_t)0x408a3a7b, (q31_t)0xc0009547, + (q31_t)0x407da998, (q31_t)0xc0007b5f, (q31_t)0x407118b0, (q31_t)0xc00063ee, + (q31_t)0x406487c4, (q31_t)0xc0004ef5, (q31_t)0x4057f6d4, (q31_t)0xc0003c74, + (q31_t)0x404b65e1, (q31_t)0xc0002c6a, (q31_t)0x403ed4ea, (q31_t)0xc0001ed8, + (q31_t)0x403243f1, (q31_t)0xc00013bd, (q31_t)0x4025b2f7, (q31_t)0xc0000b1a, + (q31_t)0x401921fb, (q31_t)0xc00004ef, (q31_t)0x400c90fe, (q31_t)0xc000013c, +}; + +/** +* @} end of RealFFT_Table group +*/ + +/** +* @addtogroup RealFFT +* @{ +*/ + +/** +* @brief Initialization function for the Q31 RFFT/RIFFT. +* @param[in, out] *S points to an instance of the Q31 RFFT/RIFFT structure. +* @param[in] fftLenReal length of the FFT. +* @param[in] ifftFlagR flag that selects forward (ifftFlagR=0) or inverse (ifftFlagR=1) transform. +* @param[in] bitReverseFlag flag that enables (bitReverseFlag=1) or disables (bitReverseFlag=0) bit reversal of output. +* @return The function returns ARM_MATH_SUCCESS if initialization is successful or ARM_MATH_ARGUMENT_ERROR if fftLenReal is not a supported value. +* +* \par Description: +* \par +* The parameter fftLenReal Specifies length of RFFT/RIFFT Process. Supported FFT Lengths are 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192. +* \par +* The parameter ifftFlagR controls whether a forward or inverse transform is computed. +* Set(=1) ifftFlagR to calculate RIFFT, otherwise RFFT is calculated. +* \par +* The parameter bitReverseFlag controls whether output is in normal order or bit reversed order. +* Set(=1) bitReverseFlag for output to be in normal order otherwise output is in bit reversed order. +* \par 7 +* This function also initializes Twiddle factor table. +*/ + +arm_status arm_rfft_init_q31( + arm_rfft_instance_q31 * S, + uint32_t fftLenReal, + uint32_t ifftFlagR, + uint32_t bitReverseFlag) +{ + /* Initialise the default arm status */ + arm_status status = ARM_MATH_SUCCESS; + + /* Initialize the Real FFT length */ + S->fftLenReal = (uint16_t) fftLenReal; + + /* Initialize the Twiddle coefficientA pointer */ + S->pTwiddleAReal = (q31_t *) realCoefAQ31; + + /* Initialize the Twiddle coefficientB pointer */ + S->pTwiddleBReal = (q31_t *) realCoefBQ31; + + /* Initialize the Flag for selection of RFFT or RIFFT */ + S->ifftFlagR = (uint8_t) ifftFlagR; + + /* Initialize the Flag for calculation Bit reversal or not */ + S->bitReverseFlagR = (uint8_t) bitReverseFlag; + + /* Initialization of coef modifier depending on the FFT length */ + switch (S->fftLenReal) + { + case 8192U: + S->twidCoefRModifier = 1U; + S->pCfft = &arm_cfft_sR_q31_len4096; + break; + case 4096U: + S->twidCoefRModifier = 2U; + S->pCfft = &arm_cfft_sR_q31_len2048; + break; + case 2048U: + S->twidCoefRModifier = 4U; + S->pCfft = &arm_cfft_sR_q31_len1024; + break; + case 1024U: + S->twidCoefRModifier = 8U; + S->pCfft = &arm_cfft_sR_q31_len512; + break; + case 512U: + S->twidCoefRModifier = 16U; + S->pCfft = &arm_cfft_sR_q31_len256; + break; + case 256U: + S->twidCoefRModifier = 32U; + S->pCfft = &arm_cfft_sR_q31_len128; + break; + case 128U: + S->twidCoefRModifier = 64U; + S->pCfft = &arm_cfft_sR_q31_len64; + break; + case 64U: + S->twidCoefRModifier = 128U; + S->pCfft = &arm_cfft_sR_q31_len32; + break; + case 32U: + S->twidCoefRModifier = 256U; + S->pCfft = &arm_cfft_sR_q31_len16; + break; + default: + /* Reporting argument error if rfftSize is not valid value */ + status = ARM_MATH_ARGUMENT_ERROR; + break; + } + + /* return the status of RFFT Init function */ + return (status); +} + +/** +* @} end of RealFFT group +*/ diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q15.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q15.c new file mode 100644 index 0000000..8a888f4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q15.c @@ -0,0 +1,426 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rfft_q15.c + * Description: RFFT & RIFFT Q15 process function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/* ---------------------------------------------------------------------- + * Internal functions prototypes + * -------------------------------------------------------------------- */ + +void arm_split_rfft_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pATable, + q15_t * pBTable, + q15_t * pDst, + uint32_t modifier); + +void arm_split_rifft_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pATable, + q15_t * pBTable, + q15_t * pDst, + uint32_t modifier); + +/** +* @addtogroup RealFFT +* @{ +*/ + +/** +* @brief Processing function for the Q15 RFFT/RIFFT. +* @param[in] *S points to an instance of the Q15 RFFT/RIFFT structure. +* @param[in] *pSrc points to the input buffer. +* @param[out] *pDst points to the output buffer. +* @return none. +* +* \par Input an output formats: +* \par +* Internally input is downscaled by 2 for every stage to avoid saturations inside CFFT/CIFFT process. +* Hence the output format is different for different RFFT sizes. +* The input and output formats for different RFFT sizes and number of bits to upscale are mentioned in the tables below for RFFT and RIFFT: +* \par +* \image html RFFTQ15.gif "Input and Output Formats for Q15 RFFT" +* \par +* \image html RIFFTQ15.gif "Input and Output Formats for Q15 RIFFT" +*/ + +void arm_rfft_q15( + const arm_rfft_instance_q15 * S, + q15_t * pSrc, + q15_t * pDst) +{ + const arm_cfft_instance_q15 *S_CFFT = S->pCfft; + uint32_t i; + uint32_t L2 = S->fftLenReal >> 1; + + /* Calculation of RIFFT of input */ + if (S->ifftFlagR == 1U) + { + /* Real IFFT core process */ + arm_split_rifft_q15(pSrc, L2, S->pTwiddleAReal, + S->pTwiddleBReal, pDst, S->twidCoefRModifier); + + /* Complex IFFT process */ + arm_cfft_q15(S_CFFT, pDst, S->ifftFlagR, S->bitReverseFlagR); + + for(i=0;ifftLenReal;i++) + { + pDst[i] = pDst[i] << 1; + } + } + else + { + /* Calculation of RFFT of input */ + + /* Complex FFT process */ + arm_cfft_q15(S_CFFT, pSrc, S->ifftFlagR, S->bitReverseFlagR); + + /* Real FFT core process */ + arm_split_rfft_q15(pSrc, L2, S->pTwiddleAReal, + S->pTwiddleBReal, pDst, S->twidCoefRModifier); + } +} + +/** +* @} end of RealFFT group +*/ + +/** +* @brief Core Real FFT process +* @param *pSrc points to the input buffer. +* @param fftLen length of FFT. +* @param *pATable points to the A twiddle Coef buffer. +* @param *pBTable points to the B twiddle Coef buffer. +* @param *pDst points to the output buffer. +* @param modifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @return none. +* The function implements a Real FFT +*/ + +void arm_split_rfft_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pATable, + q15_t * pBTable, + q15_t * pDst, + uint32_t modifier) +{ + uint32_t i; /* Loop Counter */ + q31_t outR, outI; /* Temporary variables for output */ + q15_t *pCoefA, *pCoefB; /* Temporary pointers for twiddle factors */ + q15_t *pSrc1, *pSrc2; +#if defined (ARM_MATH_DSP) + q15_t *pD1, *pD2; +#endif + + // pSrc[2U * fftLen] = pSrc[0]; + // pSrc[(2U * fftLen) + 1U] = pSrc[1]; + + pCoefA = &pATable[modifier * 2U]; + pCoefB = &pBTable[modifier * 2U]; + + pSrc1 = &pSrc[2]; + pSrc2 = &pSrc[(2U * fftLen) - 2U]; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + i = 1U; + pD1 = pDst + 2; + pD2 = pDst + (4U * fftLen) - 2; + + for(i = fftLen - 1; i > 0; i--) + { + /* + outR = (pSrc[2 * i] * pATable[2 * i] - pSrc[2 * i + 1] * pATable[2 * i + 1] + + pSrc[2 * n - 2 * i] * pBTable[2 * i] + + pSrc[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + */ + + /* outI = (pIn[2 * i + 1] * pATable[2 * i] + pIn[2 * i] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); */ + + +#ifndef ARM_MATH_BIG_ENDIAN + + /* pSrc[2 * i] * pATable[2 * i] - pSrc[2 * i + 1] * pATable[2 * i + 1] */ + outR = __SMUSD(*__SIMD32(pSrc1), *__SIMD32(pCoefA)); + +#else + + /* -(pSrc[2 * i + 1] * pATable[2 * i + 1] - pSrc[2 * i] * pATable[2 * i]) */ + outR = -(__SMUSD(*__SIMD32(pSrc1), *__SIMD32(pCoefA))); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* pSrc[2 * n - 2 * i] * pBTable[2 * i] + + pSrc[2 * n - 2 * i + 1] * pBTable[2 * i + 1]) */ + outR = __SMLAD(*__SIMD32(pSrc2), *__SIMD32(pCoefB), outR) >> 16U; + + /* pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i] */ + +#ifndef ARM_MATH_BIG_ENDIAN + + outI = __SMUSDX(*__SIMD32(pSrc2)--, *__SIMD32(pCoefB)); + +#else + + outI = __SMUSDX(*__SIMD32(pCoefB), *__SIMD32(pSrc2)--); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* (pIn[2 * i + 1] * pATable[2 * i] + pIn[2 * i] * pATable[2 * i + 1] */ + outI = __SMLADX(*__SIMD32(pSrc1)++, *__SIMD32(pCoefA), outI); + + /* write output */ + *pD1++ = (q15_t) outR; + *pD1++ = outI >> 16U; + + /* write complex conjugate output */ + pD2[0] = (q15_t) outR; + pD2[1] = -(outI >> 16U); + pD2 -= 2; + + /* update coefficient pointer */ + pCoefB = pCoefB + (2U * modifier); + pCoefA = pCoefA + (2U * modifier); + } + + pDst[2U * fftLen] = (pSrc[0] - pSrc[1]) >> 1; + pDst[(2U * fftLen) + 1U] = 0; + + pDst[0] = (pSrc[0] + pSrc[1]) >> 1; + pDst[1] = 0; + +#else + + /* Run the below code for Cortex-M0 */ + i = 1U; + + while (i < fftLen) + { + /* + outR = (pSrc[2 * i] * pATable[2 * i] - pSrc[2 * i + 1] * pATable[2 * i + 1] + + pSrc[2 * n - 2 * i] * pBTable[2 * i] + + pSrc[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + */ + + outR = *pSrc1 * *pCoefA; + outR = outR - (*(pSrc1 + 1) * *(pCoefA + 1)); + outR = outR + (*pSrc2 * *pCoefB); + outR = (outR + (*(pSrc2 + 1) * *(pCoefB + 1))) >> 16; + + + /* outI = (pIn[2 * i + 1] * pATable[2 * i] + pIn[2 * i] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); + */ + + outI = *pSrc2 * *(pCoefB + 1); + outI = outI - (*(pSrc2 + 1) * *pCoefB); + outI = outI + (*(pSrc1 + 1) * *pCoefA); + outI = outI + (*pSrc1 * *(pCoefA + 1)); + + /* update input pointers */ + pSrc1 += 2U; + pSrc2 -= 2U; + + /* write output */ + pDst[2U * i] = (q15_t) outR; + pDst[(2U * i) + 1U] = outI >> 16U; + + /* write complex conjugate output */ + pDst[(4U * fftLen) - (2U * i)] = (q15_t) outR; + pDst[((4U * fftLen) - (2U * i)) + 1U] = -(outI >> 16U); + + /* update coefficient pointer */ + pCoefB = pCoefB + (2U * modifier); + pCoefA = pCoefA + (2U * modifier); + + i++; + } + + pDst[2U * fftLen] = (pSrc[0] - pSrc[1]) >> 1; + pDst[(2U * fftLen) + 1U] = 0; + + pDst[0] = (pSrc[0] + pSrc[1]) >> 1; + pDst[1] = 0; + +#endif /* #if defined (ARM_MATH_DSP) */ +} + + +/** +* @brief Core Real IFFT process +* @param[in] *pSrc points to the input buffer. +* @param[in] fftLen length of FFT. +* @param[in] *pATable points to the twiddle Coef A buffer. +* @param[in] *pBTable points to the twiddle Coef B buffer. +* @param[out] *pDst points to the output buffer. +* @param[in] modifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @return none. +* The function implements a Real IFFT +*/ +void arm_split_rifft_q15( + q15_t * pSrc, + uint32_t fftLen, + q15_t * pATable, + q15_t * pBTable, + q15_t * pDst, + uint32_t modifier) +{ + uint32_t i; /* Loop Counter */ + q31_t outR, outI; /* Temporary variables for output */ + q15_t *pCoefA, *pCoefB; /* Temporary pointers for twiddle factors */ + q15_t *pSrc1, *pSrc2; + q15_t *pDst1 = &pDst[0]; + + pCoefA = &pATable[0]; + pCoefB = &pBTable[0]; + + pSrc1 = &pSrc[0]; + pSrc2 = &pSrc[2U * fftLen]; + +#if defined (ARM_MATH_DSP) + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + i = fftLen; + + while (i > 0U) + { + /* + outR = (pIn[2 * i] * pATable[2 * i] + pIn[2 * i + 1] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + + outI = (pIn[2 * i + 1] * pATable[2 * i] - pIn[2 * i] * pATable[2 * i + 1] - + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); + */ + + +#ifndef ARM_MATH_BIG_ENDIAN + + /* pIn[2 * n - 2 * i] * pBTable[2 * i] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i + 1]) */ + outR = __SMUSD(*__SIMD32(pSrc2), *__SIMD32(pCoefB)); + +#else + + /* -(-pIn[2 * n - 2 * i] * pBTable[2 * i] + + pIn[2 * n - 2 * i + 1] * pBTable[2 * i + 1])) */ + outR = -(__SMUSD(*__SIMD32(pSrc2), *__SIMD32(pCoefB))); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* pIn[2 * i] * pATable[2 * i] + pIn[2 * i + 1] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i] */ + outR = __SMLAD(*__SIMD32(pSrc1), *__SIMD32(pCoefA), outR) >> 16U; + + /* + -pIn[2 * n - 2 * i] * pBTable[2 * i + 1] + + pIn[2 * n - 2 * i + 1] * pBTable[2 * i] */ + outI = __SMUADX(*__SIMD32(pSrc2)--, *__SIMD32(pCoefB)); + + /* pIn[2 * i + 1] * pATable[2 * i] - pIn[2 * i] * pATable[2 * i + 1] */ + +#ifndef ARM_MATH_BIG_ENDIAN + + outI = __SMLSDX(*__SIMD32(pCoefA), *__SIMD32(pSrc1)++, -outI); + +#else + + outI = __SMLSDX(*__SIMD32(pSrc1)++, *__SIMD32(pCoefA), -outI); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + /* write output */ + +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst1)++ = __PKHBT(outR, (outI >> 16U), 16); + +#else + + *__SIMD32(pDst1)++ = __PKHBT((outI >> 16U), outR, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* update coefficient pointer */ + pCoefB = pCoefB + (2U * modifier); + pCoefA = pCoefA + (2U * modifier); + + i--; + } +#else + /* Run the below code for Cortex-M0 */ + i = fftLen; + + while (i > 0U) + { + /* + outR = (pIn[2 * i] * pATable[2 * i] + pIn[2 * i + 1] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + */ + + outR = *pSrc2 * *pCoefB; + outR = outR - (*(pSrc2 + 1) * *(pCoefB + 1)); + outR = outR + (*pSrc1 * *pCoefA); + outR = (outR + (*(pSrc1 + 1) * *(pCoefA + 1))) >> 16; + + /* + outI = (pIn[2 * i + 1] * pATable[2 * i] - pIn[2 * i] * pATable[2 * i + 1] - + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); + */ + + outI = *(pSrc1 + 1) * *pCoefA; + outI = outI - (*pSrc1 * *(pCoefA + 1)); + outI = outI - (*pSrc2 * *(pCoefB + 1)); + outI = outI - (*(pSrc2 + 1) * *(pCoefB)); + + /* update input pointers */ + pSrc1 += 2U; + pSrc2 -= 2U; + + /* write output */ + *pDst1++ = (q15_t) outR; + *pDst1++ = (q15_t) (outI >> 16); + + /* update coefficient pointer */ + pCoefB = pCoefB + (2U * modifier); + pCoefA = pCoefA + (2U * modifier); + + i--; + } +#endif /* #if defined (ARM_MATH_DSP) */ +} diff --git a/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q31.c b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q31.c new file mode 100644 index 0000000..d21b964 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/DSP/Source/TransformFunctions/arm_rfft_q31.c @@ -0,0 +1,283 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS DSP Library + * Title: arm_rfft_q31.c + * Description: FFT & RIFFT Q31 process function + * + * $Date: 27. January 2017 + * $Revision: V.1.5.1 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2017 ARM Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" + +/* ---------------------------------------------------------------------- + * Internal functions prototypes + * -------------------------------------------------------------------- */ + +void arm_split_rfft_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pATable, + q31_t * pBTable, + q31_t * pDst, + uint32_t modifier); + +void arm_split_rifft_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pATable, + q31_t * pBTable, + q31_t * pDst, + uint32_t modifier); + +/** +* @addtogroup RealFFT +* @{ +*/ + +/** +* @brief Processing function for the Q31 RFFT/RIFFT. +* @param[in] *S points to an instance of the Q31 RFFT/RIFFT structure. +* @param[in] *pSrc points to the input buffer. +* @param[out] *pDst points to the output buffer. +* @return none. +* +* \par Input an output formats: +* \par +* Internally input is downscaled by 2 for every stage to avoid saturations inside CFFT/CIFFT process. +* Hence the output format is different for different RFFT sizes. +* The input and output formats for different RFFT sizes and number of bits to upscale are mentioned in the tables below for RFFT and RIFFT: +* \par +* \image html RFFTQ31.gif "Input and Output Formats for Q31 RFFT" +* +* \par +* \image html RIFFTQ31.gif "Input and Output Formats for Q31 RIFFT" +*/ +void arm_rfft_q31( + const arm_rfft_instance_q31 * S, + q31_t * pSrc, + q31_t * pDst) +{ + const arm_cfft_instance_q31 *S_CFFT = S->pCfft; + uint32_t i; + uint32_t L2 = S->fftLenReal >> 1; + + /* Calculation of RIFFT of input */ + if (S->ifftFlagR == 1U) + { + /* Real IFFT core process */ + arm_split_rifft_q31(pSrc, L2, S->pTwiddleAReal, + S->pTwiddleBReal, pDst, S->twidCoefRModifier); + + /* Complex IFFT process */ + arm_cfft_q31(S_CFFT, pDst, S->ifftFlagR, S->bitReverseFlagR); + + for(i=0;ifftLenReal;i++) + { + pDst[i] = pDst[i] << 1; + } + } + else + { + /* Calculation of RFFT of input */ + + /* Complex FFT process */ + arm_cfft_q31(S_CFFT, pSrc, S->ifftFlagR, S->bitReverseFlagR); + + /* Real FFT core process */ + arm_split_rfft_q31(pSrc, L2, S->pTwiddleAReal, + S->pTwiddleBReal, pDst, S->twidCoefRModifier); + } +} + +/** +* @} end of RealFFT group +*/ + +/** +* @brief Core Real FFT process +* @param[in] *pSrc points to the input buffer. +* @param[in] fftLen length of FFT. +* @param[in] *pATable points to the twiddle Coef A buffer. +* @param[in] *pBTable points to the twiddle Coef B buffer. +* @param[out] *pDst points to the output buffer. +* @param[in] modifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @return none. +*/ +void arm_split_rfft_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pATable, + q31_t * pBTable, + q31_t * pDst, + uint32_t modifier) +{ + uint32_t i; /* Loop Counter */ + q31_t outR, outI; /* Temporary variables for output */ + q31_t *pCoefA, *pCoefB; /* Temporary pointers for twiddle factors */ + q31_t CoefA1, CoefA2, CoefB1; /* Temporary variables for twiddle coefficients */ + q31_t *pOut1 = &pDst[2], *pOut2 = &pDst[(4U * fftLen) - 1U]; + q31_t *pIn1 = &pSrc[2], *pIn2 = &pSrc[(2U * fftLen) - 1U]; + + /* Init coefficient pointers */ + pCoefA = &pATable[modifier * 2U]; + pCoefB = &pBTable[modifier * 2U]; + + i = fftLen - 1U; + + while (i > 0U) + { + /* + outR = (pSrc[2 * i] * pATable[2 * i] - pSrc[2 * i + 1] * pATable[2 * i + 1] + + pSrc[2 * n - 2 * i] * pBTable[2 * i] + + pSrc[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + */ + + /* outI = (pIn[2 * i + 1] * pATable[2 * i] + pIn[2 * i] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); */ + + CoefA1 = *pCoefA++; + CoefA2 = *pCoefA; + + /* outR = (pSrc[2 * i] * pATable[2 * i] */ + mult_32x32_keep32_R(outR, *pIn1, CoefA1); + + /* outI = pIn[2 * i] * pATable[2 * i + 1] */ + mult_32x32_keep32_R(outI, *pIn1++, CoefA2); + + /* - pSrc[2 * i + 1] * pATable[2 * i + 1] */ + multSub_32x32_keep32_R(outR, *pIn1, CoefA2); + + /* (pIn[2 * i + 1] * pATable[2 * i] */ + multAcc_32x32_keep32_R(outI, *pIn1++, CoefA1); + + /* pSrc[2 * n - 2 * i] * pBTable[2 * i] */ + multSub_32x32_keep32_R(outR, *pIn2, CoefA2); + CoefB1 = *pCoefB; + + /* pIn[2 * n - 2 * i] * pBTable[2 * i + 1] */ + multSub_32x32_keep32_R(outI, *pIn2--, CoefB1); + + /* pSrc[2 * n - 2 * i + 1] * pBTable[2 * i + 1] */ + multAcc_32x32_keep32_R(outR, *pIn2, CoefB1); + + /* pIn[2 * n - 2 * i + 1] * pBTable[2 * i] */ + multSub_32x32_keep32_R(outI, *pIn2--, CoefA2); + + /* write output */ + *pOut1++ = outR; + *pOut1++ = outI; + + /* write complex conjugate output */ + *pOut2-- = -outI; + *pOut2-- = outR; + + /* update coefficient pointer */ + pCoefB = pCoefB + (modifier * 2U); + pCoefA = pCoefA + ((modifier * 2U) - 1U); + + i--; + } + pDst[2U * fftLen] = (pSrc[0] - pSrc[1]) >> 1; + pDst[(2U * fftLen) + 1U] = 0; + + pDst[0] = (pSrc[0] + pSrc[1]) >> 1; + pDst[1] = 0; +} + +/** +* @brief Core Real IFFT process +* @param[in] *pSrc points to the input buffer. +* @param[in] fftLen length of FFT. +* @param[in] *pATable points to the twiddle Coef A buffer. +* @param[in] *pBTable points to the twiddle Coef B buffer. +* @param[out] *pDst points to the output buffer. +* @param[in] modifier twiddle coefficient modifier that supports different size FFTs with the same twiddle factor table. +* @return none. +*/ +void arm_split_rifft_q31( + q31_t * pSrc, + uint32_t fftLen, + q31_t * pATable, + q31_t * pBTable, + q31_t * pDst, + uint32_t modifier) +{ + q31_t outR, outI; /* Temporary variables for output */ + q31_t *pCoefA, *pCoefB; /* Temporary pointers for twiddle factors */ + q31_t CoefA1, CoefA2, CoefB1; /* Temporary variables for twiddle coefficients */ + q31_t *pIn1 = &pSrc[0], *pIn2 = &pSrc[(2U * fftLen) + 1U]; + + pCoefA = &pATable[0]; + pCoefB = &pBTable[0]; + + while (fftLen > 0U) + { + /* + outR = (pIn[2 * i] * pATable[2 * i] + pIn[2 * i + 1] * pATable[2 * i + 1] + + pIn[2 * n - 2 * i] * pBTable[2 * i] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i + 1]); + + outI = (pIn[2 * i + 1] * pATable[2 * i] - pIn[2 * i] * pATable[2 * i + 1] - + pIn[2 * n - 2 * i] * pBTable[2 * i + 1] - + pIn[2 * n - 2 * i + 1] * pBTable[2 * i]); + */ + CoefA1 = *pCoefA++; + CoefA2 = *pCoefA; + + /* outR = (pIn[2 * i] * pATable[2 * i] */ + mult_32x32_keep32_R(outR, *pIn1, CoefA1); + + /* - pIn[2 * i] * pATable[2 * i + 1] */ + mult_32x32_keep32_R(outI, *pIn1++, -CoefA2); + + /* pIn[2 * i + 1] * pATable[2 * i + 1] */ + multAcc_32x32_keep32_R(outR, *pIn1, CoefA2); + + /* pIn[2 * i + 1] * pATable[2 * i] */ + multAcc_32x32_keep32_R(outI, *pIn1++, CoefA1); + + /* pIn[2 * n - 2 * i] * pBTable[2 * i] */ + multAcc_32x32_keep32_R(outR, *pIn2, CoefA2); + CoefB1 = *pCoefB; + + /* pIn[2 * n - 2 * i] * pBTable[2 * i + 1] */ + multSub_32x32_keep32_R(outI, *pIn2--, CoefB1); + + /* pIn[2 * n - 2 * i + 1] * pBTable[2 * i + 1] */ + multAcc_32x32_keep32_R(outR, *pIn2, CoefB1); + + /* pIn[2 * n - 2 * i + 1] * pBTable[2 * i] */ + multAcc_32x32_keep32_R(outI, *pIn2--, CoefA2); + + /* write output */ + *pDst++ = outR; + *pDst++ = outI; + + /* update coefficient pointer */ + pCoefB = pCoefB + (modifier * 2U); + pCoefA = pCoefA + ((modifier * 2U) - 1U); + + /* Decrement loop count */ + fftLen--; + } +} diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f030x6.h b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f030x6.h new file mode 100644 index 0000000..3dcaee7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/stm32f030x6.h @@ -0,0 +1,5368 @@ +/** + ****************************************************************************** + * @file stm32f030x6.h + * @author MCD Application Team + * @brief CMSIS Cortex-M0 Device Peripheral Access Layer Header File. + * This file contains all the peripheral register's definitions, bits + * definitions and memory mapping for STM32F0xx devices. + * + * This file contains: + * - Data structures and the address mapping for all peripherals + * - Peripheral's registers declarations and bits definition + * - Macros to access peripheral’s registers hardware + * + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f030x6 + * @{ + */ + +#ifndef __STM32F030x6_H +#define __STM32F030x6_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + USART1_IRQn = 27 /*!< USART1 global Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f030x8 + * @{ + */ + +#ifndef __STM32F030x8_H +#define __STM32F030x8_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_IRQn = 17, /*!< TIM6 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt */ + USART2_IRQn = 28 /*!< USART2 global Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f030xc + * @{ + */ + +#ifndef __STM32F030xC_H +#define __STM32F030xC_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_IRQn = 17, /*!< TIM6 global Interrupt */ + TIM7_IRQn = 18, /*!< TIM7 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt & EXTI Line26 Interrupt (USART2 wakeup) */ + USART3_6_IRQn = 29, /*!< USART3 to USART6 global Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ + uint32_t RESERVED0[40];/*!< Reserved as declared by channel typedef 0x08 - 0xA4 */ + __IO uint32_t CSELR; /*!< Channel selection register, Address offset: 0xA8 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f031x6 + * @{ + */ + +#ifndef __STM32F031x6_H +#define __STM32F031x6_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + PVD_IRQn = 1, /*!< PVD Interrupt through EXTI Lines 16 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + USART1_IRQn = 27 /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f038xx + * @{ + */ + +#ifndef __STM32F038xx_H +#define __STM32F038xx_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + USART1_IRQn = 27 /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f042x6 + * @{ + */ + +#ifndef __STM32F042x6_H +#define __STM32F042x6_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + PVD_VDDIO2_IRQn = 1, /*!< PVD & VDDIO2 Interrupt through EXTI Lines 16 and 31 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_CRS_IRQn = 4, /*!< RCC & CRS global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt */ + CEC_CAN_IRQn = 30, /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ + USB_IRQn = 31 /*!< USB global Interrupt & EXTI Line18 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief Controller Area Network TxMailBox + */ +typedef struct +{ + __IO uint32_t TIR; /*!< CAN TX mailbox identifier register */ + __IO uint32_t TDTR; /*!< CAN mailbox data length control and time stamp register */ + __IO uint32_t TDLR; /*!< CAN mailbox data low register */ + __IO uint32_t TDHR; /*!< CAN mailbox data high register */ +}CAN_TxMailBox_TypeDef; + +/** + * @brief Controller Area Network FIFOMailBox + */ +typedef struct +{ + __IO uint32_t RIR; /*!< CAN receive FIFO mailbox identifier register */ + __IO uint32_t RDTR; /*!< CAN receive FIFO mailbox data length control and time stamp register */ + __IO uint32_t RDLR; /*!< CAN receive FIFO mailbox data low register */ + __IO uint32_t RDHR; /*!< CAN receive FIFO mailbox data high register */ +}CAN_FIFOMailBox_TypeDef; + +/** + * @brief Controller Area Network FilterRegister + */ +typedef struct +{ + __IO uint32_t FR1; /*!< CAN Filter bank register 1 */ + __IO uint32_t FR2; /*!< CAN Filter bank register 1 */ +}CAN_FilterRegister_TypeDef; + +/** + * @brief Controller Area Network + */ +typedef struct +{ + __IO uint32_t MCR; /*!< CAN master control register, Address offset: 0x00 */ + __IO uint32_t MSR; /*!< CAN master status register, Address offset: 0x04 */ + __IO uint32_t TSR; /*!< CAN transmit status register, Address offset: 0x08 */ + __IO uint32_t RF0R; /*!< CAN receive FIFO 0 register, Address offset: 0x0C */ + __IO uint32_t RF1R; /*!< CAN receive FIFO 1 register, Address offset: 0x10 */ + __IO uint32_t IER; /*!< CAN interrupt enable register, Address offset: 0x14 */ + __IO uint32_t ESR; /*!< CAN error status register, Address offset: 0x18 */ + __IO uint32_t BTR; /*!< CAN bit timing register, Address offset: 0x1C */ + uint32_t RESERVED0[88]; /*!< Reserved, 0x020 - 0x17F */ + CAN_TxMailBox_TypeDef sTxMailBox[3]; /*!< CAN Tx MailBox, Address offset: 0x180 - 0x1AC */ + CAN_FIFOMailBox_TypeDef sFIFOMailBox[2]; /*!< CAN FIFO MailBox, Address offset: 0x1B0 - 0x1CC */ + uint32_t RESERVED1[12]; /*!< Reserved, 0x1D0 - 0x1FF */ + __IO uint32_t FMR; /*!< CAN filter master register, Address offset: 0x200 */ + __IO uint32_t FM1R; /*!< CAN filter mode register, Address offset: 0x204 */ + uint32_t RESERVED2; /*!< Reserved, 0x208 */ + __IO uint32_t FS1R; /*!< CAN filter scale register, Address offset: 0x20C */ + uint32_t RESERVED3; /*!< Reserved, 0x210 */ + __IO uint32_t FFA1R; /*!< CAN filter FIFO assignment register, Address offset: 0x214 */ + uint32_t RESERVED4; /*!< Reserved, 0x218 */ + __IO uint32_t FA1R; /*!< CAN filter activation register, Address offset: 0x21C */ + uint32_t RESERVED5[8]; /*!< Reserved, 0x220-0x23F */ + CAN_FilterRegister_TypeDef sFilterRegister[14]; /*!< CAN Filter Register, Address offset: 0x240-0x2AC */ +}CAN_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Clock Recovery System + */ +typedef struct +{ +__IO uint32_t CR; /*!< CRS ccontrol register, Address offset: 0x00 */ +__IO uint32_t CFGR; /*!< CRS configuration register, Address offset: 0x04 */ +__IO uint32_t ISR; /*!< CRS interrupt and status register, Address offset: 0x08 */ +__IO uint32_t ICR; /*!< CRS interrupt flag clear register, Address offset: 0x0C */ +}CRS_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f048xx + * @{ + */ + +#ifndef __STM32F048xx_H +#define __STM32F048xx_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + VDDIO2_IRQn = 1, /*!< VDDIO2 Interrupt through EXTI Line 31 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_CRS_IRQn = 4, /*!< RCC & CRS global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt */ + CEC_CAN_IRQn = 30, /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ + USB_IRQn = 31 /*!< USB global Interrupt & EXTI Line18 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief Controller Area Network TxMailBox + */ +typedef struct +{ + __IO uint32_t TIR; /*!< CAN TX mailbox identifier register */ + __IO uint32_t TDTR; /*!< CAN mailbox data length control and time stamp register */ + __IO uint32_t TDLR; /*!< CAN mailbox data low register */ + __IO uint32_t TDHR; /*!< CAN mailbox data high register */ +}CAN_TxMailBox_TypeDef; + +/** + * @brief Controller Area Network FIFOMailBox + */ +typedef struct +{ + __IO uint32_t RIR; /*!< CAN receive FIFO mailbox identifier register */ + __IO uint32_t RDTR; /*!< CAN receive FIFO mailbox data length control and time stamp register */ + __IO uint32_t RDLR; /*!< CAN receive FIFO mailbox data low register */ + __IO uint32_t RDHR; /*!< CAN receive FIFO mailbox data high register */ +}CAN_FIFOMailBox_TypeDef; + +/** + * @brief Controller Area Network FilterRegister + */ +typedef struct +{ + __IO uint32_t FR1; /*!< CAN Filter bank register 1 */ + __IO uint32_t FR2; /*!< CAN Filter bank register 1 */ +}CAN_FilterRegister_TypeDef; + +/** + * @brief Controller Area Network + */ +typedef struct +{ + __IO uint32_t MCR; /*!< CAN master control register, Address offset: 0x00 */ + __IO uint32_t MSR; /*!< CAN master status register, Address offset: 0x04 */ + __IO uint32_t TSR; /*!< CAN transmit status register, Address offset: 0x08 */ + __IO uint32_t RF0R; /*!< CAN receive FIFO 0 register, Address offset: 0x0C */ + __IO uint32_t RF1R; /*!< CAN receive FIFO 1 register, Address offset: 0x10 */ + __IO uint32_t IER; /*!< CAN interrupt enable register, Address offset: 0x14 */ + __IO uint32_t ESR; /*!< CAN error status register, Address offset: 0x18 */ + __IO uint32_t BTR; /*!< CAN bit timing register, Address offset: 0x1C */ + uint32_t RESERVED0[88]; /*!< Reserved, 0x020 - 0x17F */ + CAN_TxMailBox_TypeDef sTxMailBox[3]; /*!< CAN Tx MailBox, Address offset: 0x180 - 0x1AC */ + CAN_FIFOMailBox_TypeDef sFIFOMailBox[2]; /*!< CAN FIFO MailBox, Address offset: 0x1B0 - 0x1CC */ + uint32_t RESERVED1[12]; /*!< Reserved, 0x1D0 - 0x1FF */ + __IO uint32_t FMR; /*!< CAN filter master register, Address offset: 0x200 */ + __IO uint32_t FM1R; /*!< CAN filter mode register, Address offset: 0x204 */ + uint32_t RESERVED2; /*!< Reserved, 0x208 */ + __IO uint32_t FS1R; /*!< CAN filter scale register, Address offset: 0x20C */ + uint32_t RESERVED3; /*!< Reserved, 0x210 */ + __IO uint32_t FFA1R; /*!< CAN filter FIFO assignment register, Address offset: 0x214 */ + uint32_t RESERVED4; /*!< Reserved, 0x218 */ + __IO uint32_t FA1R; /*!< CAN filter activation register, Address offset: 0x21C */ + uint32_t RESERVED5[8]; /*!< Reserved, 0x220-0x23F */ + CAN_FilterRegister_TypeDef sFilterRegister[14]; /*!< CAN Filter Register, Address offset: 0x240-0x2AC */ +}CAN_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Clock Recovery System + */ +typedef struct +{ +__IO uint32_t CR; /*!< CRS ccontrol register, Address offset: 0x00 */ +__IO uint32_t CFGR; /*!< CRS configuration register, Address offset: 0x04 */ +__IO uint32_t ISR; /*!< CRS interrupt and status register, Address offset: 0x08 */ +__IO uint32_t ICR; /*!< CRS interrupt flag clear register, Address offset: 0x0C */ +}CRS_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f051x8 + * @{ + */ + +#ifndef __STM32F051x8_H +#define __STM32F051x8_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + PVD_IRQn = 1, /*!< PVD Interrupt through EXTI Lines 16 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_COMP_IRQn = 12, /*!< ADC1 and COMP interrupts (ADC interrupt combined with EXTI Lines 21 and 22 */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_DAC_IRQn = 17, /*!< TIM6 global and DAC channel underrun error Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt */ + CEC_CAN_IRQn = 30 /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief Comparator + */ + +typedef struct +{ + __IO uint16_t CSR; /*!< COMP control and status register, Address offset: 0x00 */ +} COMP_TypeDef; + +typedef struct +{ + __IO uint32_t CSR; /*!< COMP control and status register, used for bits common to several COMP instances, Address offset: 0x00 */ +} COMP_Common_TypeDef; + +/* Legacy defines */ +typedef struct +{ + __IO uint32_t CSR; /*!< Kept for legacy purpose. Use structure 'COMP_Common_TypeDef'. */ +}COMP1_2_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Digital to Analog Converter + */ + +typedef struct +{ + __IO uint32_t CR; /*!< DAC control register, Address offset: 0x00 */ + __IO uint32_t SWTRIGR; /*!< DAC software trigger register, Address offset: 0x04 */ + __IO uint32_t DHR12R1; /*!< DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08 */ + __IO uint32_t DHR12L1; /*!< DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C */ + __IO uint32_t DHR8R1; /*!< DAC channel1 8-bit right aligned data holding register, Address offset: 0x10 */ + uint32_t RESERVED1[6]; /*!< Reserved, Address offset: 0x14 to 0x28 */ + __IO uint32_t DOR1; /*!< DAC channel1 data output register, Address offset: 0x2C */ + uint32_t RESERVED2; /*!< Reserved, Address offset: 0x30 */ + __IO uint32_t SR; /*!< DAC status register, Address offset: 0x34 */ +} DAC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f058xx + * @{ + */ + +#ifndef __STM32F058xx_H +#define __STM32F058xx_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_COMP_IRQn = 12, /*!< ADC1 and COMP interrupts (ADC interrupt combined with EXTI Lines 21 and 22 */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_DAC_IRQn = 17, /*!< TIM6 global and DAC channel underrun error Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt */ + CEC_CAN_IRQn = 30 /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief Comparator + */ + +typedef struct +{ + __IO uint16_t CSR; /*!< COMP control and status register, Address offset: 0x00 */ +} COMP_TypeDef; + +typedef struct +{ + __IO uint32_t CSR; /*!< COMP control and status register, used for bits common to several COMP instances, Address offset: 0x00 */ +} COMP_Common_TypeDef; + +/* Legacy defines */ +typedef struct +{ + __IO uint32_t CSR; /*!< Kept for legacy purpose. Use structure 'COMP_Common_TypeDef'. */ +}COMP1_2_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Digital to Analog Converter + */ + +typedef struct +{ + __IO uint32_t CR; /*!< DAC control register, Address offset: 0x00 */ + __IO uint32_t SWTRIGR; /*!< DAC software trigger register, Address offset: 0x04 */ + __IO uint32_t DHR12R1; /*!< DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08 */ + __IO uint32_t DHR12L1; /*!< DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C */ + __IO uint32_t DHR8R1; /*!< DAC channel1 8-bit right aligned data holding register, Address offset: 0x10 */ + uint32_t RESERVED1[6]; /*!< Reserved, Address offset: 0x14 to 0x28 */ + __IO uint32_t DOR1; /*!< DAC channel1 data output register, Address offset: 0x2C */ + uint32_t RESERVED2; /*!< Reserved, Address offset: 0x30 */ + __IO uint32_t SR; /*!< DAC status register, Address offset: 0x34 */ +} DAC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f070x6 + * @{ + */ + +#ifndef __STM32F070x6_H +#define __STM32F070x6_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt */ + USB_IRQn = 31 /*!< USB global Interrupt & EXTI Line18 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f070xb + * @{ + */ + +#ifndef __STM32F070xB_H +#define __STM32F070xB_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_IRQn = 4, /*!< RCC global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_IRQn = 11, /*!< DMA1 Channel 4 and Channel 5 Interrupt */ + ADC1_IRQn = 12, /*!< ADC1 Interrupt */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_IRQn = 17, /*!< TIM6 global Interrupt */ + TIM7_IRQn = 18, /*!< TIM7 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt */ + USART2_IRQn = 28, /*!< USART2 global Interrupt */ + USART3_4_IRQn = 29, /*!< USART3 and USART4 global Interrupt */ + USB_IRQn = 31 /*!< USB global Interrupt & EXTI Line18 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t RESERVED3; /*!< Reserved, 0x14 */ +} CRC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f071xb + * @{ + */ + +#ifndef __STM32F071xB_H +#define __STM32F071xB_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + PVD_VDDIO2_IRQn = 1, /*!< PVD & VDDIO2 Interrupt through EXTI Lines 16 and 31 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_CRS_IRQn = 4, /*!< RCC & CRS global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_6_7_IRQn = 11, /*!< DMA1 Channel 4 to Channel 7 Interrupt */ + ADC1_COMP_IRQn = 12, /*!< ADC1 and COMP interrupts (ADC interrupt combined with EXTI Lines 21 and 22 */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_DAC_IRQn = 17, /*!< TIM6 global and DAC channel underrun error Interrupt */ + TIM7_IRQn = 18, /*!< TIM7 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt & EXTI Line26 Interrupt (USART2 wakeup) */ + USART3_4_IRQn = 29, /*!< USART3 and USART4 global Interrupt */ + CEC_CAN_IRQn = 30 /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief Comparator + */ + +typedef struct +{ + __IO uint16_t CSR; /*!< COMP control and status register, Address offset: 0x00 */ +} COMP_TypeDef; + +typedef struct +{ + __IO uint32_t CSR; /*!< COMP control and status register, used for bits common to several COMP instances, Address offset: 0x00 */ +} COMP_Common_TypeDef; + +/* Legacy defines */ +typedef struct +{ + __IO uint32_t CSR; /*!< Kept for legacy purpose. Use structure 'COMP_Common_TypeDef'. */ +}COMP1_2_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t POL; /*!< CRC polynomial register, Address offset: 0x14 */ +} CRC_TypeDef; + +/** + * @brief Clock Recovery System + */ +typedef struct +{ +__IO uint32_t CR; /*!< CRS ccontrol register, Address offset: 0x00 */ +__IO uint32_t CFGR; /*!< CRS configuration register, Address offset: 0x04 */ +__IO uint32_t ISR; /*!< CRS interrupt and status register, Address offset: 0x08 */ +__IO uint32_t ICR; /*!< CRS interrupt flag clear register, Address offset: 0x0C */ +}CRS_TypeDef; + +/** + * @brief Digital to Analog Converter + */ + +typedef struct +{ + __IO uint32_t CR; /*!< DAC control register, Address offset: 0x00 */ + __IO uint32_t SWTRIGR; /*!< DAC software trigger register, Address offset: 0x04 */ + __IO uint32_t DHR12R1; /*!< DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08 */ + __IO uint32_t DHR12L1; /*!< DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C */ + __IO uint32_t DHR8R1; /*!< DAC channel1 8-bit right aligned data holding register, Address offset: 0x10 */ + __IO uint32_t DHR12R2; /*!< DAC channel2 12-bit right aligned data holding register, Address offset: 0x14 */ + __IO uint32_t DHR12L2; /*!< DAC channel2 12-bit left aligned data holding register, Address offset: 0x18 */ + __IO uint32_t DHR8R2; /*!< DAC channel2 8-bit right-aligned data holding register, Address offset: 0x1C */ + __IO uint32_t DHR12RD; /*!< Dual DAC 12-bit right-aligned data holding register, Address offset: 0x20 */ + __IO uint32_t DHR12LD; /*!< DUAL DAC 12-bit left aligned data holding register, Address offset: 0x24 */ + __IO uint32_t DHR8RD; /*!< DUAL DAC 8-bit right aligned data holding register, Address offset: 0x28 */ + __IO uint32_t DOR1; /*!< DAC channel1 data output register, Address offset: 0x2C */ + __IO uint32_t DOR2; /*!< DAC channel2 data output register, Address offset: 0x30 */ + __IO uint32_t SR; /*!< DAC status register, Address offset: 0x34 */ +} DAC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f072xb + * @{ + */ + +#ifndef __STM32F072xB_H +#define __STM32F072xB_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + PVD_VDDIO2_IRQn = 1, /*!< PVD & VDDIO2 Interrupt through EXTI Lines 16 and 31 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_CRS_IRQn = 4, /*!< RCC & CRS global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_6_7_IRQn = 11, /*!< DMA1 Channel 4 to Channel 7 Interrupt */ + ADC1_COMP_IRQn = 12, /*!< ADC1 and COMP interrupts (ADC interrupt combined with EXTI Lines 21 and 22 */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_DAC_IRQn = 17, /*!< TIM6 global and DAC channel underrun error Interrupt */ + TIM7_IRQn = 18, /*!< TIM7 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt & EXTI Line26 Interrupt (USART2 wakeup) */ + USART3_4_IRQn = 29, /*!< USART3 and USART4 global Interrupt */ + CEC_CAN_IRQn = 30, /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ + USB_IRQn = 31 /*!< USB global Interrupt & EXTI Line18 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief Controller Area Network TxMailBox + */ +typedef struct +{ + __IO uint32_t TIR; /*!< CAN TX mailbox identifier register */ + __IO uint32_t TDTR; /*!< CAN mailbox data length control and time stamp register */ + __IO uint32_t TDLR; /*!< CAN mailbox data low register */ + __IO uint32_t TDHR; /*!< CAN mailbox data high register */ +}CAN_TxMailBox_TypeDef; + +/** + * @brief Controller Area Network FIFOMailBox + */ +typedef struct +{ + __IO uint32_t RIR; /*!< CAN receive FIFO mailbox identifier register */ + __IO uint32_t RDTR; /*!< CAN receive FIFO mailbox data length control and time stamp register */ + __IO uint32_t RDLR; /*!< CAN receive FIFO mailbox data low register */ + __IO uint32_t RDHR; /*!< CAN receive FIFO mailbox data high register */ +}CAN_FIFOMailBox_TypeDef; + +/** + * @brief Controller Area Network FilterRegister + */ +typedef struct +{ + __IO uint32_t FR1; /*!< CAN Filter bank register 1 */ + __IO uint32_t FR2; /*!< CAN Filter bank register 1 */ +}CAN_FilterRegister_TypeDef; + +/** + * @brief Controller Area Network + */ +typedef struct +{ + __IO uint32_t MCR; /*!< CAN master control register, Address offset: 0x00 */ + __IO uint32_t MSR; /*!< CAN master status register, Address offset: 0x04 */ + __IO uint32_t TSR; /*!< CAN transmit status register, Address offset: 0x08 */ + __IO uint32_t RF0R; /*!< CAN receive FIFO 0 register, Address offset: 0x0C */ + __IO uint32_t RF1R; /*!< CAN receive FIFO 1 register, Address offset: 0x10 */ + __IO uint32_t IER; /*!< CAN interrupt enable register, Address offset: 0x14 */ + __IO uint32_t ESR; /*!< CAN error status register, Address offset: 0x18 */ + __IO uint32_t BTR; /*!< CAN bit timing register, Address offset: 0x1C */ + uint32_t RESERVED0[88]; /*!< Reserved, 0x020 - 0x17F */ + CAN_TxMailBox_TypeDef sTxMailBox[3]; /*!< CAN Tx MailBox, Address offset: 0x180 - 0x1AC */ + CAN_FIFOMailBox_TypeDef sFIFOMailBox[2]; /*!< CAN FIFO MailBox, Address offset: 0x1B0 - 0x1CC */ + uint32_t RESERVED1[12]; /*!< Reserved, 0x1D0 - 0x1FF */ + __IO uint32_t FMR; /*!< CAN filter master register, Address offset: 0x200 */ + __IO uint32_t FM1R; /*!< CAN filter mode register, Address offset: 0x204 */ + uint32_t RESERVED2; /*!< Reserved, 0x208 */ + __IO uint32_t FS1R; /*!< CAN filter scale register, Address offset: 0x20C */ + uint32_t RESERVED3; /*!< Reserved, 0x210 */ + __IO uint32_t FFA1R; /*!< CAN filter FIFO assignment register, Address offset: 0x214 */ + uint32_t RESERVED4; /*!< Reserved, 0x218 */ + __IO uint32_t FA1R; /*!< CAN filter activation register, Address offset: 0x21C */ + uint32_t RESERVED5[8]; /*!< Reserved, 0x220-0x23F */ + CAN_FilterRegister_TypeDef sFilterRegister[14]; /*!< CAN Filter Register, Address offset: 0x240-0x2AC */ +}CAN_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief Comparator + */ + +typedef struct +{ + __IO uint16_t CSR; /*!< COMP control and status register, Address offset: 0x00 */ +} COMP_TypeDef; + +typedef struct +{ + __IO uint32_t CSR; /*!< COMP control and status register, used for bits common to several COMP instances, Address offset: 0x00 */ +} COMP_Common_TypeDef; + +/* Legacy defines */ +typedef struct +{ + __IO uint32_t CSR; /*!< Kept for legacy purpose. Use structure 'COMP_Common_TypeDef'. */ +}COMP1_2_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t POL; /*!< CRC polynomial register, Address offset: 0x14 */ +} CRC_TypeDef; + +/** + * @brief Clock Recovery System + */ +typedef struct +{ +__IO uint32_t CR; /*!< CRS ccontrol register, Address offset: 0x00 */ +__IO uint32_t CFGR; /*!< CRS configuration register, Address offset: 0x04 */ +__IO uint32_t ISR; /*!< CRS interrupt and status register, Address offset: 0x08 */ +__IO uint32_t ICR; /*!< CRS interrupt flag clear register, Address offset: 0x0C */ +}CRS_TypeDef; + +/** + * @brief Digital to Analog Converter + */ + +typedef struct +{ + __IO uint32_t CR; /*!< DAC control register, Address offset: 0x00 */ + __IO uint32_t SWTRIGR; /*!< DAC software trigger register, Address offset: 0x04 */ + __IO uint32_t DHR12R1; /*!< DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08 */ + __IO uint32_t DHR12L1; /*!< DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C */ + __IO uint32_t DHR8R1; /*!< DAC channel1 8-bit right aligned data holding register, Address offset: 0x10 */ + __IO uint32_t DHR12R2; /*!< DAC channel2 12-bit right aligned data holding register, Address offset: 0x14 */ + __IO uint32_t DHR12L2; /*!< DAC channel2 12-bit left aligned data holding register, Address offset: 0x18 */ + __IO uint32_t DHR8R2; /*!< DAC channel2 8-bit right-aligned data holding register, Address offset: 0x1C */ + __IO uint32_t DHR12RD; /*!< Dual DAC 12-bit right-aligned data holding register, Address offset: 0x20 */ + __IO uint32_t DHR12LD; /*!< DUAL DAC 12-bit left aligned data holding register, Address offset: 0x24 */ + __IO uint32_t DHR8RD; /*!< DUAL DAC 8-bit right aligned data holding register, Address offset: 0x28 */ + __IO uint32_t DOR1; /*!< DAC channel1 data output register, Address offset: 0x2C */ + __IO uint32_t DOR2; /*!< DAC channel2 data output register, Address offset: 0x30 */ + __IO uint32_t SR; /*!< DAC status register, Address offset: 0x34 */ +} DAC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f078xx + * @{ + */ + +#ifndef __STM32F078xx_H +#define __STM32F078xx_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + VDDIO2_IRQn = 1, /*!< VDDIO2 Interrupt through EXTI Line 31 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_CRS_IRQn = 4, /*!< RCC & CRS global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Channel1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Channel2_3_IRQn = 10, /*!< DMA1 Channel 2 and Channel 3 Interrupt */ + DMA1_Channel4_5_6_7_IRQn = 11, /*!< DMA1 Channel 4 to Channel 7 Interrupt */ + ADC1_COMP_IRQn = 12, /*!< ADC1 and COMP interrupts (ADC interrupt combined with EXTI Lines 21 and 22 */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_DAC_IRQn = 17, /*!< TIM6 global and DAC channel underrun error Interrupt */ + TIM7_IRQn = 18, /*!< TIM7 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt & EXTI Line26 Interrupt (USART2 wakeup) */ + USART3_4_IRQn = 29, /*!< USART3 and USART4 global Interrupt */ + CEC_CAN_IRQn = 30, /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ + USB_IRQn = 31 /*!< USB global Interrupt & EXTI Line18 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief Controller Area Network TxMailBox + */ +typedef struct +{ + __IO uint32_t TIR; /*!< CAN TX mailbox identifier register */ + __IO uint32_t TDTR; /*!< CAN mailbox data length control and time stamp register */ + __IO uint32_t TDLR; /*!< CAN mailbox data low register */ + __IO uint32_t TDHR; /*!< CAN mailbox data high register */ +}CAN_TxMailBox_TypeDef; + +/** + * @brief Controller Area Network FIFOMailBox + */ +typedef struct +{ + __IO uint32_t RIR; /*!< CAN receive FIFO mailbox identifier register */ + __IO uint32_t RDTR; /*!< CAN receive FIFO mailbox data length control and time stamp register */ + __IO uint32_t RDLR; /*!< CAN receive FIFO mailbox data low register */ + __IO uint32_t RDHR; /*!< CAN receive FIFO mailbox data high register */ +}CAN_FIFOMailBox_TypeDef; + +/** + * @brief Controller Area Network FilterRegister + */ +typedef struct +{ + __IO uint32_t FR1; /*!< CAN Filter bank register 1 */ + __IO uint32_t FR2; /*!< CAN Filter bank register 1 */ +}CAN_FilterRegister_TypeDef; + +/** + * @brief Controller Area Network + */ +typedef struct +{ + __IO uint32_t MCR; /*!< CAN master control register, Address offset: 0x00 */ + __IO uint32_t MSR; /*!< CAN master status register, Address offset: 0x04 */ + __IO uint32_t TSR; /*!< CAN transmit status register, Address offset: 0x08 */ + __IO uint32_t RF0R; /*!< CAN receive FIFO 0 register, Address offset: 0x0C */ + __IO uint32_t RF1R; /*!< CAN receive FIFO 1 register, Address offset: 0x10 */ + __IO uint32_t IER; /*!< CAN interrupt enable register, Address offset: 0x14 */ + __IO uint32_t ESR; /*!< CAN error status register, Address offset: 0x18 */ + __IO uint32_t BTR; /*!< CAN bit timing register, Address offset: 0x1C */ + uint32_t RESERVED0[88]; /*!< Reserved, 0x020 - 0x17F */ + CAN_TxMailBox_TypeDef sTxMailBox[3]; /*!< CAN Tx MailBox, Address offset: 0x180 - 0x1AC */ + CAN_FIFOMailBox_TypeDef sFIFOMailBox[2]; /*!< CAN FIFO MailBox, Address offset: 0x1B0 - 0x1CC */ + uint32_t RESERVED1[12]; /*!< Reserved, 0x1D0 - 0x1FF */ + __IO uint32_t FMR; /*!< CAN filter master register, Address offset: 0x200 */ + __IO uint32_t FM1R; /*!< CAN filter mode register, Address offset: 0x204 */ + uint32_t RESERVED2; /*!< Reserved, 0x208 */ + __IO uint32_t FS1R; /*!< CAN filter scale register, Address offset: 0x20C */ + uint32_t RESERVED3; /*!< Reserved, 0x210 */ + __IO uint32_t FFA1R; /*!< CAN filter FIFO assignment register, Address offset: 0x214 */ + uint32_t RESERVED4; /*!< Reserved, 0x218 */ + __IO uint32_t FA1R; /*!< CAN filter activation register, Address offset: 0x21C */ + uint32_t RESERVED5[8]; /*!< Reserved, 0x220-0x23F */ + CAN_FilterRegister_TypeDef sFilterRegister[14]; /*!< CAN Filter Register, Address offset: 0x240-0x2AC */ +}CAN_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief Comparator + */ + +typedef struct +{ + __IO uint16_t CSR; /*!< COMP control and status register, Address offset: 0x00 */ +} COMP_TypeDef; + +typedef struct +{ + __IO uint32_t CSR; /*!< COMP control and status register, used for bits common to several COMP instances, Address offset: 0x00 */ +} COMP_Common_TypeDef; + +/* Legacy defines */ +typedef struct +{ + __IO uint32_t CSR; /*!< Kept for legacy purpose. Use structure 'COMP_Common_TypeDef'. */ +}COMP1_2_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t POL; /*!< CRC polynomial register, Address offset: 0x14 */ +} CRC_TypeDef; + +/** + * @brief Clock Recovery System + */ +typedef struct +{ +__IO uint32_t CR; /*!< CRS ccontrol register, Address offset: 0x00 */ +__IO uint32_t CFGR; /*!< CRS configuration register, Address offset: 0x04 */ +__IO uint32_t ISR; /*!< CRS interrupt and status register, Address offset: 0x08 */ +__IO uint32_t ICR; /*!< CRS interrupt flag clear register, Address offset: 0x0C */ +}CRS_TypeDef; + +/** + * @brief Digital to Analog Converter + */ + +typedef struct +{ + __IO uint32_t CR; /*!< DAC control register, Address offset: 0x00 */ + __IO uint32_t SWTRIGR; /*!< DAC software trigger register, Address offset: 0x04 */ + __IO uint32_t DHR12R1; /*!< DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08 */ + __IO uint32_t DHR12L1; /*!< DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C */ + __IO uint32_t DHR8R1; /*!< DAC channel1 8-bit right aligned data holding register, Address offset: 0x10 */ + __IO uint32_t DHR12R2; /*!< DAC channel2 12-bit right aligned data holding register, Address offset: 0x14 */ + __IO uint32_t DHR12L2; /*!< DAC channel2 12-bit left aligned data holding register, Address offset: 0x18 */ + __IO uint32_t DHR8R2; /*!< DAC channel2 8-bit right-aligned data holding register, Address offset: 0x1C */ + __IO uint32_t DHR12RD; /*!< Dual DAC 12-bit right-aligned data holding register, Address offset: 0x20 */ + __IO uint32_t DHR12LD; /*!< DUAL DAC 12-bit left aligned data holding register, Address offset: 0x24 */ + __IO uint32_t DHR8RD; /*!< DUAL DAC 8-bit right aligned data holding register, Address offset: 0x28 */ + __IO uint32_t DOR1; /*!< DAC channel1 data output register, Address offset: 0x2C */ + __IO uint32_t DOR2; /*!< DAC channel2 data output register, Address offset: 0x30 */ + __IO uint32_t SR; /*!< DAC status register, Address offset: 0x34 */ +} DAC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f091xc + * @{ + */ + +#ifndef __STM32F091xC_H +#define __STM32F091xC_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + PVD_VDDIO2_IRQn = 1, /*!< PVD & VDDIO2 Interrupt through EXTI Lines 16 and 31 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_CRS_IRQn = 4, /*!< RCC & CRS global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Ch1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Ch2_3_DMA2_Ch1_2_IRQn = 10, /*!< DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 Interrupts */ + DMA1_Ch4_7_DMA2_Ch3_5_IRQn = 11, /*!< DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 Interrupt */ + ADC1_COMP_IRQn = 12, /*!< ADC1 and COMP interrupts (ADC interrupt combined with EXTI Lines 21 and 22 */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_DAC_IRQn = 17, /*!< TIM6 global and DAC channel underrun error Interrupt */ + TIM7_IRQn = 18, /*!< TIM7 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt & EXTI Line26 Interrupt (USART2 wakeup) */ + USART3_8_IRQn = 29, /*!< USART3 to USART8 global Interrupt */ + CEC_CAN_IRQn = 30 /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief Controller Area Network TxMailBox + */ +typedef struct +{ + __IO uint32_t TIR; /*!< CAN TX mailbox identifier register */ + __IO uint32_t TDTR; /*!< CAN mailbox data length control and time stamp register */ + __IO uint32_t TDLR; /*!< CAN mailbox data low register */ + __IO uint32_t TDHR; /*!< CAN mailbox data high register */ +}CAN_TxMailBox_TypeDef; + +/** + * @brief Controller Area Network FIFOMailBox + */ +typedef struct +{ + __IO uint32_t RIR; /*!< CAN receive FIFO mailbox identifier register */ + __IO uint32_t RDTR; /*!< CAN receive FIFO mailbox data length control and time stamp register */ + __IO uint32_t RDLR; /*!< CAN receive FIFO mailbox data low register */ + __IO uint32_t RDHR; /*!< CAN receive FIFO mailbox data high register */ +}CAN_FIFOMailBox_TypeDef; + +/** + * @brief Controller Area Network FilterRegister + */ +typedef struct +{ + __IO uint32_t FR1; /*!< CAN Filter bank register 1 */ + __IO uint32_t FR2; /*!< CAN Filter bank register 1 */ +}CAN_FilterRegister_TypeDef; + +/** + * @brief Controller Area Network + */ +typedef struct +{ + __IO uint32_t MCR; /*!< CAN master control register, Address offset: 0x00 */ + __IO uint32_t MSR; /*!< CAN master status register, Address offset: 0x04 */ + __IO uint32_t TSR; /*!< CAN transmit status register, Address offset: 0x08 */ + __IO uint32_t RF0R; /*!< CAN receive FIFO 0 register, Address offset: 0x0C */ + __IO uint32_t RF1R; /*!< CAN receive FIFO 1 register, Address offset: 0x10 */ + __IO uint32_t IER; /*!< CAN interrupt enable register, Address offset: 0x14 */ + __IO uint32_t ESR; /*!< CAN error status register, Address offset: 0x18 */ + __IO uint32_t BTR; /*!< CAN bit timing register, Address offset: 0x1C */ + uint32_t RESERVED0[88]; /*!< Reserved, 0x020 - 0x17F */ + CAN_TxMailBox_TypeDef sTxMailBox[3]; /*!< CAN Tx MailBox, Address offset: 0x180 - 0x1AC */ + CAN_FIFOMailBox_TypeDef sFIFOMailBox[2]; /*!< CAN FIFO MailBox, Address offset: 0x1B0 - 0x1CC */ + uint32_t RESERVED1[12]; /*!< Reserved, 0x1D0 - 0x1FF */ + __IO uint32_t FMR; /*!< CAN filter master register, Address offset: 0x200 */ + __IO uint32_t FM1R; /*!< CAN filter mode register, Address offset: 0x204 */ + uint32_t RESERVED2; /*!< Reserved, 0x208 */ + __IO uint32_t FS1R; /*!< CAN filter scale register, Address offset: 0x20C */ + uint32_t RESERVED3; /*!< Reserved, 0x210 */ + __IO uint32_t FFA1R; /*!< CAN filter FIFO assignment register, Address offset: 0x214 */ + uint32_t RESERVED4; /*!< Reserved, 0x218 */ + __IO uint32_t FA1R; /*!< CAN filter activation register, Address offset: 0x21C */ + uint32_t RESERVED5[8]; /*!< Reserved, 0x220-0x23F */ + CAN_FilterRegister_TypeDef sFilterRegister[14]; /*!< CAN Filter Register, Address offset: 0x240-0x2AC */ +}CAN_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief Comparator + */ + +typedef struct +{ + __IO uint16_t CSR; /*!< COMP control and status register, Address offset: 0x00 */ +} COMP_TypeDef; + +typedef struct +{ + __IO uint32_t CSR; /*!< COMP control and status register, used for bits common to several COMP instances, Address offset: 0x00 */ +} COMP_Common_TypeDef; + +/* Legacy defines */ +typedef struct +{ + __IO uint32_t CSR; /*!< Kept for legacy purpose. Use structure 'COMP_Common_TypeDef'. */ +}COMP1_2_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t POL; /*!< CRC polynomial register, Address offset: 0x14 */ +} CRC_TypeDef; + +/** + * @brief Clock Recovery System + */ +typedef struct +{ +__IO uint32_t CR; /*!< CRS ccontrol register, Address offset: 0x00 */ +__IO uint32_t CFGR; /*!< CRS configuration register, Address offset: 0x04 */ +__IO uint32_t ISR; /*!< CRS interrupt and status register, Address offset: 0x08 */ +__IO uint32_t ICR; /*!< CRS interrupt flag clear register, Address offset: 0x0C */ +}CRS_TypeDef; + +/** + * @brief Digital to Analog Converter + */ + +typedef struct +{ + __IO uint32_t CR; /*!< DAC control register, Address offset: 0x00 */ + __IO uint32_t SWTRIGR; /*!< DAC software trigger register, Address offset: 0x04 */ + __IO uint32_t DHR12R1; /*!< DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08 */ + __IO uint32_t DHR12L1; /*!< DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C */ + __IO uint32_t DHR8R1; /*!< DAC channel1 8-bit right aligned data holding register, Address offset: 0x10 */ + __IO uint32_t DHR12R2; /*!< DAC channel2 12-bit right aligned data holding register, Address offset: 0x14 */ + __IO uint32_t DHR12L2; /*!< DAC channel2 12-bit left aligned data holding register, Address offset: 0x18 */ + __IO uint32_t DHR8R2; /*!< DAC channel2 8-bit right-aligned data holding register, Address offset: 0x1C */ + __IO uint32_t DHR12RD; /*!< Dual DAC 12-bit right-aligned data holding register, Address offset: 0x20 */ + __IO uint32_t DHR12LD; /*!< DUAL DAC 12-bit left aligned data holding register, Address offset: 0x24 */ + __IO uint32_t DHR8RD; /*!< DUAL DAC 8-bit right aligned data holding register, Address offset: 0x28 */ + __IO uint32_t DOR1; /*!< DAC channel1 data output register, Address offset: 0x2C */ + __IO uint32_t DOR2; /*!< DAC channel2 data output register, Address offset: 0x30 */ + __IO uint32_t SR; /*!< DAC status register, Address offset: 0x34 */ +} DAC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ + uint32_t RESERVED0[40];/*!< Reserved as declared by channel typedef 0x08 - 0xA4 */ + __IO uint32_t CSELR; /*!< Channel selection register, Address offset: 0xA8 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*! exti[31] Interrupt */ +#define SYSCFG_ITLINE1_SR_VDDIO2_Pos (1U) +#define SYSCFG_ITLINE1_SR_VDDIO2_Msk (0x1UL << SYSCFG_ITLINE1_SR_VDDIO2_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE1_SR_VDDIO2 SYSCFG_ITLINE1_SR_VDDIO2_Msk /*!< VDDIO2 -> exti[16] Interrupt */ +#define SYSCFG_ITLINE2_SR_RTC_ALRA_Pos (0U) +#define SYSCFG_ITLINE2_SR_RTC_ALRA_Msk (0x1UL << SYSCFG_ITLINE2_SR_RTC_ALRA_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE2_SR_RTC_ALRA SYSCFG_ITLINE2_SR_RTC_ALRA_Msk /*!< RTC Alarm -> exti[17] interrupt .... */ +#define SYSCFG_ITLINE2_SR_RTC_TSTAMP_Pos (1U) +#define SYSCFG_ITLINE2_SR_RTC_TSTAMP_Msk (0x1UL << SYSCFG_ITLINE2_SR_RTC_TSTAMP_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE2_SR_RTC_TSTAMP SYSCFG_ITLINE2_SR_RTC_TSTAMP_Msk /*!< RTC Time Stamp -> exti[19] interrupt */ +#define SYSCFG_ITLINE2_SR_RTC_WAKEUP_Pos (2U) +#define SYSCFG_ITLINE2_SR_RTC_WAKEUP_Msk (0x1UL << SYSCFG_ITLINE2_SR_RTC_WAKEUP_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE2_SR_RTC_WAKEUP SYSCFG_ITLINE2_SR_RTC_WAKEUP_Msk /*!< RTC WAKEUP -> exti[20] Interrupt */ +#define SYSCFG_ITLINE3_SR_FLASH_ITF_Pos (0U) +#define SYSCFG_ITLINE3_SR_FLASH_ITF_Msk (0x1UL << SYSCFG_ITLINE3_SR_FLASH_ITF_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE3_SR_FLASH_ITF SYSCFG_ITLINE3_SR_FLASH_ITF_Msk /*!< Flash ITF Interrupt */ +#define SYSCFG_ITLINE4_SR_CRS_Pos (0U) +#define SYSCFG_ITLINE4_SR_CRS_Msk (0x1UL << SYSCFG_ITLINE4_SR_CRS_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE4_SR_CRS SYSCFG_ITLINE4_SR_CRS_Msk /*!< CRS interrupt */ +#define SYSCFG_ITLINE4_SR_CLK_CTRL_Pos (1U) +#define SYSCFG_ITLINE4_SR_CLK_CTRL_Msk (0x1UL << SYSCFG_ITLINE4_SR_CLK_CTRL_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE4_SR_CLK_CTRL SYSCFG_ITLINE4_SR_CLK_CTRL_Msk /*!< CLK CTRL interrupt */ +#define SYSCFG_ITLINE5_SR_EXTI0_Pos (0U) +#define SYSCFG_ITLINE5_SR_EXTI0_Msk (0x1UL << SYSCFG_ITLINE5_SR_EXTI0_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE5_SR_EXTI0 SYSCFG_ITLINE5_SR_EXTI0_Msk /*!< External Interrupt 0 */ +#define SYSCFG_ITLINE5_SR_EXTI1_Pos (1U) +#define SYSCFG_ITLINE5_SR_EXTI1_Msk (0x1UL << SYSCFG_ITLINE5_SR_EXTI1_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE5_SR_EXTI1 SYSCFG_ITLINE5_SR_EXTI1_Msk /*!< External Interrupt 1 */ +#define SYSCFG_ITLINE6_SR_EXTI2_Pos (0U) +#define SYSCFG_ITLINE6_SR_EXTI2_Msk (0x1UL << SYSCFG_ITLINE6_SR_EXTI2_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE6_SR_EXTI2 SYSCFG_ITLINE6_SR_EXTI2_Msk /*!< External Interrupt 2 */ +#define SYSCFG_ITLINE6_SR_EXTI3_Pos (1U) +#define SYSCFG_ITLINE6_SR_EXTI3_Msk (0x1UL << SYSCFG_ITLINE6_SR_EXTI3_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE6_SR_EXTI3 SYSCFG_ITLINE6_SR_EXTI3_Msk /*!< External Interrupt 3 */ +#define SYSCFG_ITLINE7_SR_EXTI4_Pos (0U) +#define SYSCFG_ITLINE7_SR_EXTI4_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI4_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE7_SR_EXTI4 SYSCFG_ITLINE7_SR_EXTI4_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI5_Pos (1U) +#define SYSCFG_ITLINE7_SR_EXTI5_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI5_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE7_SR_EXTI5 SYSCFG_ITLINE7_SR_EXTI5_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI6_Pos (2U) +#define SYSCFG_ITLINE7_SR_EXTI6_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI6_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE7_SR_EXTI6 SYSCFG_ITLINE7_SR_EXTI6_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI7_Pos (3U) +#define SYSCFG_ITLINE7_SR_EXTI7_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI7_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE7_SR_EXTI7 SYSCFG_ITLINE7_SR_EXTI7_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI8_Pos (4U) +#define SYSCFG_ITLINE7_SR_EXTI8_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI8_Pos) /*!< 0x00000010 */ +#define SYSCFG_ITLINE7_SR_EXTI8 SYSCFG_ITLINE7_SR_EXTI8_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI9_Pos (5U) +#define SYSCFG_ITLINE7_SR_EXTI9_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI9_Pos) /*!< 0x00000020 */ +#define SYSCFG_ITLINE7_SR_EXTI9 SYSCFG_ITLINE7_SR_EXTI9_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI10_Pos (6U) +#define SYSCFG_ITLINE7_SR_EXTI10_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI10_Pos) /*!< 0x00000040 */ +#define SYSCFG_ITLINE7_SR_EXTI10 SYSCFG_ITLINE7_SR_EXTI10_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI11_Pos (7U) +#define SYSCFG_ITLINE7_SR_EXTI11_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI11_Pos) /*!< 0x00000080 */ +#define SYSCFG_ITLINE7_SR_EXTI11 SYSCFG_ITLINE7_SR_EXTI11_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI12_Pos (8U) +#define SYSCFG_ITLINE7_SR_EXTI12_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI12_Pos) /*!< 0x00000100 */ +#define SYSCFG_ITLINE7_SR_EXTI12 SYSCFG_ITLINE7_SR_EXTI12_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI13_Pos (9U) +#define SYSCFG_ITLINE7_SR_EXTI13_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI13_Pos) /*!< 0x00000200 */ +#define SYSCFG_ITLINE7_SR_EXTI13 SYSCFG_ITLINE7_SR_EXTI13_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI14_Pos (10U) +#define SYSCFG_ITLINE7_SR_EXTI14_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI14_Pos) /*!< 0x00000400 */ +#define SYSCFG_ITLINE7_SR_EXTI14 SYSCFG_ITLINE7_SR_EXTI14_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI15_Pos (11U) +#define SYSCFG_ITLINE7_SR_EXTI15_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI15_Pos) /*!< 0x00000800 */ +#define SYSCFG_ITLINE7_SR_EXTI15 SYSCFG_ITLINE7_SR_EXTI15_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE8_SR_TSC_EOA_Pos (0U) +#define SYSCFG_ITLINE8_SR_TSC_EOA_Msk (0x1UL << SYSCFG_ITLINE8_SR_TSC_EOA_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE8_SR_TSC_EOA SYSCFG_ITLINE8_SR_TSC_EOA_Msk /*!< Touch control EOA Interrupt */ +#define SYSCFG_ITLINE8_SR_TSC_MCE_Pos (1U) +#define SYSCFG_ITLINE8_SR_TSC_MCE_Msk (0x1UL << SYSCFG_ITLINE8_SR_TSC_MCE_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE8_SR_TSC_MCE SYSCFG_ITLINE8_SR_TSC_MCE_Msk /*!< Touch control MCE Interrupt */ +#define SYSCFG_ITLINE9_SR_DMA1_CH1_Pos (0U) +#define SYSCFG_ITLINE9_SR_DMA1_CH1_Msk (0x1UL << SYSCFG_ITLINE9_SR_DMA1_CH1_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE9_SR_DMA1_CH1 SYSCFG_ITLINE9_SR_DMA1_CH1_Msk /*!< DMA1 Channel 1 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA1_CH2_Pos (0U) +#define SYSCFG_ITLINE10_SR_DMA1_CH2_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA1_CH2_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE10_SR_DMA1_CH2 SYSCFG_ITLINE10_SR_DMA1_CH2_Msk /*!< DMA1 Channel 2 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA1_CH3_Pos (1U) +#define SYSCFG_ITLINE10_SR_DMA1_CH3_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA1_CH3_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE10_SR_DMA1_CH3 SYSCFG_ITLINE10_SR_DMA1_CH3_Msk /*!< DMA2 Channel 3 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA2_CH1_Pos (2U) +#define SYSCFG_ITLINE10_SR_DMA2_CH1_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA2_CH1_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE10_SR_DMA2_CH1 SYSCFG_ITLINE10_SR_DMA2_CH1_Msk /*!< DMA2 Channel 1 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA2_CH2_Pos (3U) +#define SYSCFG_ITLINE10_SR_DMA2_CH2_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA2_CH2_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE10_SR_DMA2_CH2 SYSCFG_ITLINE10_SR_DMA2_CH2_Msk /*!< DMA2 Channel 2 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH4_Pos (0U) +#define SYSCFG_ITLINE11_SR_DMA1_CH4_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH4_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH4 SYSCFG_ITLINE11_SR_DMA1_CH4_Msk /*!< DMA1 Channel 4 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH5_Pos (1U) +#define SYSCFG_ITLINE11_SR_DMA1_CH5_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH5_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH5 SYSCFG_ITLINE11_SR_DMA1_CH5_Msk /*!< DMA1 Channel 5 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH6_Pos (2U) +#define SYSCFG_ITLINE11_SR_DMA1_CH6_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH6_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH6 SYSCFG_ITLINE11_SR_DMA1_CH6_Msk /*!< DMA1 Channel 6 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH7_Pos (3U) +#define SYSCFG_ITLINE11_SR_DMA1_CH7_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH7_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH7 SYSCFG_ITLINE11_SR_DMA1_CH7_Msk /*!< DMA1 Channel 7 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA2_CH3_Pos (4U) +#define SYSCFG_ITLINE11_SR_DMA2_CH3_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA2_CH3_Pos) /*!< 0x00000010 */ +#define SYSCFG_ITLINE11_SR_DMA2_CH3 SYSCFG_ITLINE11_SR_DMA2_CH3_Msk /*!< DMA2 Channel 3 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA2_CH4_Pos (5U) +#define SYSCFG_ITLINE11_SR_DMA2_CH4_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA2_CH4_Pos) /*!< 0x00000020 */ +#define SYSCFG_ITLINE11_SR_DMA2_CH4 SYSCFG_ITLINE11_SR_DMA2_CH4_Msk /*!< DMA2 Channel 4 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA2_CH5_Pos (6U) +#define SYSCFG_ITLINE11_SR_DMA2_CH5_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA2_CH5_Pos) /*!< 0x00000040 */ +#define SYSCFG_ITLINE11_SR_DMA2_CH5 SYSCFG_ITLINE11_SR_DMA2_CH5_Msk /*!< DMA2 Channel 5 Interrupt */ +#define SYSCFG_ITLINE12_SR_ADC_Pos (0U) +#define SYSCFG_ITLINE12_SR_ADC_Msk (0x1UL << SYSCFG_ITLINE12_SR_ADC_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE12_SR_ADC SYSCFG_ITLINE12_SR_ADC_Msk /*!< ADC Interrupt */ +#define SYSCFG_ITLINE12_SR_COMP1_Pos (1U) +#define SYSCFG_ITLINE12_SR_COMP1_Msk (0x1UL << SYSCFG_ITLINE12_SR_COMP1_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE12_SR_COMP1 SYSCFG_ITLINE12_SR_COMP1_Msk /*!< COMP1 Interrupt -> exti[21] */ +#define SYSCFG_ITLINE12_SR_COMP2_Pos (2U) +#define SYSCFG_ITLINE12_SR_COMP2_Msk (0x1UL << SYSCFG_ITLINE12_SR_COMP2_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE12_SR_COMP2 SYSCFG_ITLINE12_SR_COMP2_Msk /*!< COMP2 Interrupt -> exti[22] */ +#define SYSCFG_ITLINE13_SR_TIM1_BRK_Pos (0U) +#define SYSCFG_ITLINE13_SR_TIM1_BRK_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_BRK_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE13_SR_TIM1_BRK SYSCFG_ITLINE13_SR_TIM1_BRK_Msk /*!< TIM1 BRK Interrupt */ +#define SYSCFG_ITLINE13_SR_TIM1_UPD_Pos (1U) +#define SYSCFG_ITLINE13_SR_TIM1_UPD_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_UPD_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE13_SR_TIM1_UPD SYSCFG_ITLINE13_SR_TIM1_UPD_Msk /*!< TIM1 UPD Interrupt */ +#define SYSCFG_ITLINE13_SR_TIM1_TRG_Pos (2U) +#define SYSCFG_ITLINE13_SR_TIM1_TRG_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_TRG_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE13_SR_TIM1_TRG SYSCFG_ITLINE13_SR_TIM1_TRG_Msk /*!< TIM1 TRG Interrupt */ +#define SYSCFG_ITLINE13_SR_TIM1_CCU_Pos (3U) +#define SYSCFG_ITLINE13_SR_TIM1_CCU_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_CCU_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE13_SR_TIM1_CCU SYSCFG_ITLINE13_SR_TIM1_CCU_Msk /*!< TIM1 CCU Interrupt */ +#define SYSCFG_ITLINE14_SR_TIM1_CC_Pos (0U) +#define SYSCFG_ITLINE14_SR_TIM1_CC_Msk (0x1UL << SYSCFG_ITLINE14_SR_TIM1_CC_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE14_SR_TIM1_CC SYSCFG_ITLINE14_SR_TIM1_CC_Msk /*!< TIM1 CC Interrupt */ +#define SYSCFG_ITLINE15_SR_TIM2_GLB_Pos (0U) +#define SYSCFG_ITLINE15_SR_TIM2_GLB_Msk (0x1UL << SYSCFG_ITLINE15_SR_TIM2_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE15_SR_TIM2_GLB SYSCFG_ITLINE15_SR_TIM2_GLB_Msk /*!< TIM2 GLB Interrupt */ +#define SYSCFG_ITLINE16_SR_TIM3_GLB_Pos (0U) +#define SYSCFG_ITLINE16_SR_TIM3_GLB_Msk (0x1UL << SYSCFG_ITLINE16_SR_TIM3_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE16_SR_TIM3_GLB SYSCFG_ITLINE16_SR_TIM3_GLB_Msk /*!< TIM3 GLB Interrupt */ +#define SYSCFG_ITLINE17_SR_DAC_Pos (0U) +#define SYSCFG_ITLINE17_SR_DAC_Msk (0x1UL << SYSCFG_ITLINE17_SR_DAC_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE17_SR_DAC SYSCFG_ITLINE17_SR_DAC_Msk /*!< DAC Interrupt */ +#define SYSCFG_ITLINE17_SR_TIM6_GLB_Pos (1U) +#define SYSCFG_ITLINE17_SR_TIM6_GLB_Msk (0x1UL << SYSCFG_ITLINE17_SR_TIM6_GLB_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE17_SR_TIM6_GLB SYSCFG_ITLINE17_SR_TIM6_GLB_Msk /*!< TIM6 GLB Interrupt */ +#define SYSCFG_ITLINE18_SR_TIM7_GLB_Pos (0U) +#define SYSCFG_ITLINE18_SR_TIM7_GLB_Msk (0x1UL << SYSCFG_ITLINE18_SR_TIM7_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE18_SR_TIM7_GLB SYSCFG_ITLINE18_SR_TIM7_GLB_Msk /*!< TIM7 GLB Interrupt */ +#define SYSCFG_ITLINE19_SR_TIM14_GLB_Pos (0U) +#define SYSCFG_ITLINE19_SR_TIM14_GLB_Msk (0x1UL << SYSCFG_ITLINE19_SR_TIM14_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE19_SR_TIM14_GLB SYSCFG_ITLINE19_SR_TIM14_GLB_Msk /*!< TIM14 GLB Interrupt */ +#define SYSCFG_ITLINE20_SR_TIM15_GLB_Pos (0U) +#define SYSCFG_ITLINE20_SR_TIM15_GLB_Msk (0x1UL << SYSCFG_ITLINE20_SR_TIM15_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE20_SR_TIM15_GLB SYSCFG_ITLINE20_SR_TIM15_GLB_Msk /*!< TIM15 GLB Interrupt */ +#define SYSCFG_ITLINE21_SR_TIM16_GLB_Pos (0U) +#define SYSCFG_ITLINE21_SR_TIM16_GLB_Msk (0x1UL << SYSCFG_ITLINE21_SR_TIM16_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE21_SR_TIM16_GLB SYSCFG_ITLINE21_SR_TIM16_GLB_Msk /*!< TIM16 GLB Interrupt */ +#define SYSCFG_ITLINE22_SR_TIM17_GLB_Pos (0U) +#define SYSCFG_ITLINE22_SR_TIM17_GLB_Msk (0x1UL << SYSCFG_ITLINE22_SR_TIM17_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE22_SR_TIM17_GLB SYSCFG_ITLINE22_SR_TIM17_GLB_Msk /*!< TIM17 GLB Interrupt */ +#define SYSCFG_ITLINE23_SR_I2C1_GLB_Pos (0U) +#define SYSCFG_ITLINE23_SR_I2C1_GLB_Msk (0x1UL << SYSCFG_ITLINE23_SR_I2C1_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE23_SR_I2C1_GLB SYSCFG_ITLINE23_SR_I2C1_GLB_Msk /*!< I2C1 GLB Interrupt -> exti[23] */ +#define SYSCFG_ITLINE24_SR_I2C2_GLB_Pos (0U) +#define SYSCFG_ITLINE24_SR_I2C2_GLB_Msk (0x1UL << SYSCFG_ITLINE24_SR_I2C2_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE24_SR_I2C2_GLB SYSCFG_ITLINE24_SR_I2C2_GLB_Msk /*!< I2C2 GLB Interrupt */ +#define SYSCFG_ITLINE25_SR_SPI1_Pos (0U) +#define SYSCFG_ITLINE25_SR_SPI1_Msk (0x1UL << SYSCFG_ITLINE25_SR_SPI1_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE25_SR_SPI1 SYSCFG_ITLINE25_SR_SPI1_Msk /*!< SPI1 Interrupt */ +#define SYSCFG_ITLINE26_SR_SPI2_Pos (0U) +#define SYSCFG_ITLINE26_SR_SPI2_Msk (0x1UL << SYSCFG_ITLINE26_SR_SPI2_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE26_SR_SPI2 SYSCFG_ITLINE26_SR_SPI2_Msk /*!< SPI2 Interrupt */ +#define SYSCFG_ITLINE27_SR_USART1_GLB_Pos (0U) +#define SYSCFG_ITLINE27_SR_USART1_GLB_Msk (0x1UL << SYSCFG_ITLINE27_SR_USART1_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE27_SR_USART1_GLB SYSCFG_ITLINE27_SR_USART1_GLB_Msk /*!< USART1 GLB Interrupt -> exti[25] */ +#define SYSCFG_ITLINE28_SR_USART2_GLB_Pos (0U) +#define SYSCFG_ITLINE28_SR_USART2_GLB_Msk (0x1UL << SYSCFG_ITLINE28_SR_USART2_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE28_SR_USART2_GLB SYSCFG_ITLINE28_SR_USART2_GLB_Msk /*!< USART2 GLB Interrupt -> exti[26] */ +#define SYSCFG_ITLINE29_SR_USART3_GLB_Pos (0U) +#define SYSCFG_ITLINE29_SR_USART3_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART3_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE29_SR_USART3_GLB SYSCFG_ITLINE29_SR_USART3_GLB_Msk /*!< USART3 GLB Interrupt -> exti[28] */ +#define SYSCFG_ITLINE29_SR_USART4_GLB_Pos (1U) +#define SYSCFG_ITLINE29_SR_USART4_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART4_GLB_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE29_SR_USART4_GLB SYSCFG_ITLINE29_SR_USART4_GLB_Msk /*!< USART4 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART5_GLB_Pos (2U) +#define SYSCFG_ITLINE29_SR_USART5_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART5_GLB_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE29_SR_USART5_GLB SYSCFG_ITLINE29_SR_USART5_GLB_Msk /*!< USART5 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART6_GLB_Pos (3U) +#define SYSCFG_ITLINE29_SR_USART6_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART6_GLB_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE29_SR_USART6_GLB SYSCFG_ITLINE29_SR_USART6_GLB_Msk /*!< USART6 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART7_GLB_Pos (4U) +#define SYSCFG_ITLINE29_SR_USART7_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART7_GLB_Pos) /*!< 0x00000010 */ +#define SYSCFG_ITLINE29_SR_USART7_GLB SYSCFG_ITLINE29_SR_USART7_GLB_Msk /*!< USART7 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART8_GLB_Pos (5U) +#define SYSCFG_ITLINE29_SR_USART8_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART8_GLB_Pos) /*!< 0x00000020 */ +#define SYSCFG_ITLINE29_SR_USART8_GLB SYSCFG_ITLINE29_SR_USART8_GLB_Msk /*!< USART8 GLB Interrupt */ +#define SYSCFG_ITLINE30_SR_CAN_Pos (0U) +#define SYSCFG_ITLINE30_SR_CAN_Msk (0x1UL << SYSCFG_ITLINE30_SR_CAN_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE30_SR_CAN SYSCFG_ITLINE30_SR_CAN_Msk /*!< CAN Interrupt */ +#define SYSCFG_ITLINE30_SR_CEC_Pos (1U) +#define SYSCFG_ITLINE30_SR_CEC_Msk (0x1UL << SYSCFG_ITLINE30_SR_CEC_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE30_SR_CEC SYSCFG_ITLINE30_SR_CEC_Msk /*!< CEC Interrupt */ + +/*****************************************************************************/ +/* */ +/* Timers (TIM) */ +/* */ +/*****************************************************************************/ +/******************* Bit definition for TIM_CR1 register *******************/ +#define TIM_CR1_CEN_Pos (0U) +#define TIM_CR1_CEN_Msk (0x1UL << TIM_CR1_CEN_Pos) /*!< 0x00000001 */ +#define TIM_CR1_CEN TIM_CR1_CEN_Msk /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f098xx + * @{ + */ + +#ifndef __STM32F098xx_H +#define __STM32F098xx_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Configuration_section_for_CMSIS + * @{ + */ +/** + * @brief Configuration of the Cortex-M0 Processor and Core Peripherals + */ +#define __CM0_REV 0 /*!< Core Revision r0p0 */ +#define __MPU_PRESENT 0 /*!< STM32F0xx do not provide MPU */ +#define __NVIC_PRIO_BITS 2 /*!< STM32F0xx uses 2 Bits for the Priority Levels */ +#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */ + +/** + * @} + */ + +/** @addtogroup Peripheral_interrupt_number_definition + * @{ + */ + +/** + * @brief STM32F0xx Interrupt Number Definition, according to the selected device + * in @ref Library_configuration_section + */ + +/*!< Interrupt Number Definition */ +typedef enum +{ +/****** Cortex-M0 Processor Exceptions Numbers **************************************************************/ + NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */ + HardFault_IRQn = -13, /*!< 3 Cortex-M0 Hard Fault Interrupt */ + SVC_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */ + PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */ + SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */ + +/****** STM32F0 specific Interrupt Numbers ******************************************************************/ + WWDG_IRQn = 0, /*!< Window WatchDog Interrupt */ + VDDIO2_IRQn = 1, /*!< VDDIO2 Interrupt through EXTI Line 31 */ + RTC_IRQn = 2, /*!< RTC Interrupt through EXTI Lines 17, 19 and 20 */ + FLASH_IRQn = 3, /*!< FLASH global Interrupt */ + RCC_CRS_IRQn = 4, /*!< RCC & CRS global Interrupt */ + EXTI0_1_IRQn = 5, /*!< EXTI Line 0 and 1 Interrupt */ + EXTI2_3_IRQn = 6, /*!< EXTI Line 2 and 3 Interrupt */ + EXTI4_15_IRQn = 7, /*!< EXTI Line 4 to 15 Interrupt */ + TSC_IRQn = 8, /*!< Touch Sensing Controller Interrupts */ + DMA1_Ch1_IRQn = 9, /*!< DMA1 Channel 1 Interrupt */ + DMA1_Ch2_3_DMA2_Ch1_2_IRQn = 10, /*!< DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 Interrupts */ + DMA1_Ch4_7_DMA2_Ch3_5_IRQn = 11, /*!< DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 Interrupt */ + ADC1_COMP_IRQn = 12, /*!< ADC1 and COMP interrupts (ADC interrupt combined with EXTI Lines 21 and 22 */ + TIM1_BRK_UP_TRG_COM_IRQn = 13, /*!< TIM1 Break, Update, Trigger and Commutation Interrupt */ + TIM1_CC_IRQn = 14, /*!< TIM1 Capture Compare Interrupt */ + TIM2_IRQn = 15, /*!< TIM2 global Interrupt */ + TIM3_IRQn = 16, /*!< TIM3 global Interrupt */ + TIM6_DAC_IRQn = 17, /*!< TIM6 global and DAC channel underrun error Interrupt */ + TIM7_IRQn = 18, /*!< TIM7 global Interrupt */ + TIM14_IRQn = 19, /*!< TIM14 global Interrupt */ + TIM15_IRQn = 20, /*!< TIM15 global Interrupt */ + TIM16_IRQn = 21, /*!< TIM16 global Interrupt */ + TIM17_IRQn = 22, /*!< TIM17 global Interrupt */ + I2C1_IRQn = 23, /*!< I2C1 Event Interrupt & EXTI Line23 Interrupt (I2C1 wakeup) */ + I2C2_IRQn = 24, /*!< I2C2 Event Interrupt */ + SPI1_IRQn = 25, /*!< SPI1 global Interrupt */ + SPI2_IRQn = 26, /*!< SPI2 global Interrupt */ + USART1_IRQn = 27, /*!< USART1 global Interrupt & EXTI Line25 Interrupt (USART1 wakeup) */ + USART2_IRQn = 28, /*!< USART2 global Interrupt & EXTI Line26 Interrupt (USART2 wakeup) */ + USART3_8_IRQn = 29, /*!< USART3 to USART8 global Interrupt */ + CEC_CAN_IRQn = 30 /*!< CEC and CAN global Interrupts & EXTI Line27 Interrupt */ +} IRQn_Type; + +/** + * @} + */ + +#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */ +#include "system_stm32f0xx.h" /* STM32F0xx System Header */ +#include + +/** @addtogroup Peripheral_registers_structures + * @{ + */ + +/** + * @brief Analog to Digital Converter + */ + +typedef struct +{ + __IO uint32_t ISR; /*!< ADC interrupt and status register, Address offset: 0x00 */ + __IO uint32_t IER; /*!< ADC interrupt enable register, Address offset: 0x04 */ + __IO uint32_t CR; /*!< ADC control register, Address offset: 0x08 */ + __IO uint32_t CFGR1; /*!< ADC configuration register 1, Address offset: 0x0C */ + __IO uint32_t CFGR2; /*!< ADC configuration register 2, Address offset: 0x10 */ + __IO uint32_t SMPR; /*!< ADC sampling time register, Address offset: 0x14 */ + uint32_t RESERVED1; /*!< Reserved, 0x18 */ + uint32_t RESERVED2; /*!< Reserved, 0x1C */ + __IO uint32_t TR; /*!< ADC analog watchdog 1 threshold register, Address offset: 0x20 */ + uint32_t RESERVED3; /*!< Reserved, 0x24 */ + __IO uint32_t CHSELR; /*!< ADC group regular sequencer register, Address offset: 0x28 */ + uint32_t RESERVED4[5]; /*!< Reserved, 0x2C */ + __IO uint32_t DR; /*!< ADC group regular data register, Address offset: 0x40 */ +} ADC_TypeDef; + +typedef struct +{ + __IO uint32_t CCR; /*!< ADC common configuration register, Address offset: ADC1 base address + 0x308 */ +} ADC_Common_TypeDef; + +/** + * @brief Controller Area Network TxMailBox + */ +typedef struct +{ + __IO uint32_t TIR; /*!< CAN TX mailbox identifier register */ + __IO uint32_t TDTR; /*!< CAN mailbox data length control and time stamp register */ + __IO uint32_t TDLR; /*!< CAN mailbox data low register */ + __IO uint32_t TDHR; /*!< CAN mailbox data high register */ +}CAN_TxMailBox_TypeDef; + +/** + * @brief Controller Area Network FIFOMailBox + */ +typedef struct +{ + __IO uint32_t RIR; /*!< CAN receive FIFO mailbox identifier register */ + __IO uint32_t RDTR; /*!< CAN receive FIFO mailbox data length control and time stamp register */ + __IO uint32_t RDLR; /*!< CAN receive FIFO mailbox data low register */ + __IO uint32_t RDHR; /*!< CAN receive FIFO mailbox data high register */ +}CAN_FIFOMailBox_TypeDef; + +/** + * @brief Controller Area Network FilterRegister + */ +typedef struct +{ + __IO uint32_t FR1; /*!< CAN Filter bank register 1 */ + __IO uint32_t FR2; /*!< CAN Filter bank register 1 */ +}CAN_FilterRegister_TypeDef; + +/** + * @brief Controller Area Network + */ +typedef struct +{ + __IO uint32_t MCR; /*!< CAN master control register, Address offset: 0x00 */ + __IO uint32_t MSR; /*!< CAN master status register, Address offset: 0x04 */ + __IO uint32_t TSR; /*!< CAN transmit status register, Address offset: 0x08 */ + __IO uint32_t RF0R; /*!< CAN receive FIFO 0 register, Address offset: 0x0C */ + __IO uint32_t RF1R; /*!< CAN receive FIFO 1 register, Address offset: 0x10 */ + __IO uint32_t IER; /*!< CAN interrupt enable register, Address offset: 0x14 */ + __IO uint32_t ESR; /*!< CAN error status register, Address offset: 0x18 */ + __IO uint32_t BTR; /*!< CAN bit timing register, Address offset: 0x1C */ + uint32_t RESERVED0[88]; /*!< Reserved, 0x020 - 0x17F */ + CAN_TxMailBox_TypeDef sTxMailBox[3]; /*!< CAN Tx MailBox, Address offset: 0x180 - 0x1AC */ + CAN_FIFOMailBox_TypeDef sFIFOMailBox[2]; /*!< CAN FIFO MailBox, Address offset: 0x1B0 - 0x1CC */ + uint32_t RESERVED1[12]; /*!< Reserved, 0x1D0 - 0x1FF */ + __IO uint32_t FMR; /*!< CAN filter master register, Address offset: 0x200 */ + __IO uint32_t FM1R; /*!< CAN filter mode register, Address offset: 0x204 */ + uint32_t RESERVED2; /*!< Reserved, 0x208 */ + __IO uint32_t FS1R; /*!< CAN filter scale register, Address offset: 0x20C */ + uint32_t RESERVED3; /*!< Reserved, 0x210 */ + __IO uint32_t FFA1R; /*!< CAN filter FIFO assignment register, Address offset: 0x214 */ + uint32_t RESERVED4; /*!< Reserved, 0x218 */ + __IO uint32_t FA1R; /*!< CAN filter activation register, Address offset: 0x21C */ + uint32_t RESERVED5[8]; /*!< Reserved, 0x220-0x23F */ + CAN_FilterRegister_TypeDef sFilterRegister[14]; /*!< CAN Filter Register, Address offset: 0x240-0x2AC */ +}CAN_TypeDef; + +/** + * @brief HDMI-CEC + */ + +typedef struct +{ + __IO uint32_t CR; /*!< CEC control register, Address offset:0x00 */ + __IO uint32_t CFGR; /*!< CEC configuration register, Address offset:0x04 */ + __IO uint32_t TXDR; /*!< CEC Tx data register , Address offset:0x08 */ + __IO uint32_t RXDR; /*!< CEC Rx Data Register, Address offset:0x0C */ + __IO uint32_t ISR; /*!< CEC Interrupt and Status Register, Address offset:0x10 */ + __IO uint32_t IER; /*!< CEC interrupt enable register, Address offset:0x14 */ +}CEC_TypeDef; + +/** + * @brief Comparator + */ + +typedef struct +{ + __IO uint16_t CSR; /*!< COMP control and status register, Address offset: 0x00 */ +} COMP_TypeDef; + +typedef struct +{ + __IO uint32_t CSR; /*!< COMP control and status register, used for bits common to several COMP instances, Address offset: 0x00 */ +} COMP_Common_TypeDef; + +/* Legacy defines */ +typedef struct +{ + __IO uint32_t CSR; /*!< Kept for legacy purpose. Use structure 'COMP_Common_TypeDef'. */ +}COMP1_2_TypeDef; + +/** + * @brief CRC calculation unit + */ + +typedef struct +{ + __IO uint32_t DR; /*!< CRC Data register, Address offset: 0x00 */ + __IO uint8_t IDR; /*!< CRC Independent data register, Address offset: 0x04 */ + uint8_t RESERVED0; /*!< Reserved, 0x05 */ + uint16_t RESERVED1; /*!< Reserved, 0x06 */ + __IO uint32_t CR; /*!< CRC Control register, Address offset: 0x08 */ + uint32_t RESERVED2; /*!< Reserved, 0x0C */ + __IO uint32_t INIT; /*!< Initial CRC value register, Address offset: 0x10 */ + __IO uint32_t POL; /*!< CRC polynomial register, Address offset: 0x14 */ +} CRC_TypeDef; + +/** + * @brief Clock Recovery System + */ +typedef struct +{ +__IO uint32_t CR; /*!< CRS ccontrol register, Address offset: 0x00 */ +__IO uint32_t CFGR; /*!< CRS configuration register, Address offset: 0x04 */ +__IO uint32_t ISR; /*!< CRS interrupt and status register, Address offset: 0x08 */ +__IO uint32_t ICR; /*!< CRS interrupt flag clear register, Address offset: 0x0C */ +}CRS_TypeDef; + +/** + * @brief Digital to Analog Converter + */ + +typedef struct +{ + __IO uint32_t CR; /*!< DAC control register, Address offset: 0x00 */ + __IO uint32_t SWTRIGR; /*!< DAC software trigger register, Address offset: 0x04 */ + __IO uint32_t DHR12R1; /*!< DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08 */ + __IO uint32_t DHR12L1; /*!< DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C */ + __IO uint32_t DHR8R1; /*!< DAC channel1 8-bit right aligned data holding register, Address offset: 0x10 */ + __IO uint32_t DHR12R2; /*!< DAC channel2 12-bit right aligned data holding register, Address offset: 0x14 */ + __IO uint32_t DHR12L2; /*!< DAC channel2 12-bit left aligned data holding register, Address offset: 0x18 */ + __IO uint32_t DHR8R2; /*!< DAC channel2 8-bit right-aligned data holding register, Address offset: 0x1C */ + __IO uint32_t DHR12RD; /*!< Dual DAC 12-bit right-aligned data holding register, Address offset: 0x20 */ + __IO uint32_t DHR12LD; /*!< DUAL DAC 12-bit left aligned data holding register, Address offset: 0x24 */ + __IO uint32_t DHR8RD; /*!< DUAL DAC 8-bit right aligned data holding register, Address offset: 0x28 */ + __IO uint32_t DOR1; /*!< DAC channel1 data output register, Address offset: 0x2C */ + __IO uint32_t DOR2; /*!< DAC channel2 data output register, Address offset: 0x30 */ + __IO uint32_t SR; /*!< DAC status register, Address offset: 0x34 */ +} DAC_TypeDef; + +/** + * @brief Debug MCU + */ + +typedef struct +{ + __IO uint32_t IDCODE; /*!< MCU device ID code, Address offset: 0x00 */ + __IO uint32_t CR; /*!< Debug MCU configuration register, Address offset: 0x04 */ + __IO uint32_t APB1FZ; /*!< Debug MCU APB1 freeze register, Address offset: 0x08 */ + __IO uint32_t APB2FZ; /*!< Debug MCU APB2 freeze register, Address offset: 0x0C */ +}DBGMCU_TypeDef; + +/** + * @brief DMA Controller + */ + +typedef struct +{ + __IO uint32_t CCR; /*!< DMA channel x configuration register */ + __IO uint32_t CNDTR; /*!< DMA channel x number of data register */ + __IO uint32_t CPAR; /*!< DMA channel x peripheral address register */ + __IO uint32_t CMAR; /*!< DMA channel x memory address register */ +} DMA_Channel_TypeDef; + +typedef struct +{ + __IO uint32_t ISR; /*!< DMA interrupt status register, Address offset: 0x00 */ + __IO uint32_t IFCR; /*!< DMA interrupt flag clear register, Address offset: 0x04 */ + uint32_t RESERVED0[40];/*!< Reserved as declared by channel typedef 0x08 - 0xA4 */ + __IO uint32_t CSELR; /*!< Channel selection register, Address offset: 0xA8 */ +} DMA_TypeDef; + +/** + * @brief External Interrupt/Event Controller + */ + +typedef struct +{ + __IO uint32_t IMR; /*! exti[16] Interrupt */ +#define SYSCFG_ITLINE2_SR_RTC_ALRA_Pos (0U) +#define SYSCFG_ITLINE2_SR_RTC_ALRA_Msk (0x1UL << SYSCFG_ITLINE2_SR_RTC_ALRA_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE2_SR_RTC_ALRA SYSCFG_ITLINE2_SR_RTC_ALRA_Msk /*!< RTC Alarm -> exti[17] interrupt .... */ +#define SYSCFG_ITLINE2_SR_RTC_TSTAMP_Pos (1U) +#define SYSCFG_ITLINE2_SR_RTC_TSTAMP_Msk (0x1UL << SYSCFG_ITLINE2_SR_RTC_TSTAMP_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE2_SR_RTC_TSTAMP SYSCFG_ITLINE2_SR_RTC_TSTAMP_Msk /*!< RTC Time Stamp -> exti[19] interrupt */ +#define SYSCFG_ITLINE2_SR_RTC_WAKEUP_Pos (2U) +#define SYSCFG_ITLINE2_SR_RTC_WAKEUP_Msk (0x1UL << SYSCFG_ITLINE2_SR_RTC_WAKEUP_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE2_SR_RTC_WAKEUP SYSCFG_ITLINE2_SR_RTC_WAKEUP_Msk /*!< RTC WAKEUP -> exti[20] Interrupt */ +#define SYSCFG_ITLINE3_SR_FLASH_ITF_Pos (0U) +#define SYSCFG_ITLINE3_SR_FLASH_ITF_Msk (0x1UL << SYSCFG_ITLINE3_SR_FLASH_ITF_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE3_SR_FLASH_ITF SYSCFG_ITLINE3_SR_FLASH_ITF_Msk /*!< Flash ITF Interrupt */ +#define SYSCFG_ITLINE4_SR_CRS_Pos (0U) +#define SYSCFG_ITLINE4_SR_CRS_Msk (0x1UL << SYSCFG_ITLINE4_SR_CRS_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE4_SR_CRS SYSCFG_ITLINE4_SR_CRS_Msk /*!< CRS interrupt */ +#define SYSCFG_ITLINE4_SR_CLK_CTRL_Pos (1U) +#define SYSCFG_ITLINE4_SR_CLK_CTRL_Msk (0x1UL << SYSCFG_ITLINE4_SR_CLK_CTRL_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE4_SR_CLK_CTRL SYSCFG_ITLINE4_SR_CLK_CTRL_Msk /*!< CLK CTRL interrupt */ +#define SYSCFG_ITLINE5_SR_EXTI0_Pos (0U) +#define SYSCFG_ITLINE5_SR_EXTI0_Msk (0x1UL << SYSCFG_ITLINE5_SR_EXTI0_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE5_SR_EXTI0 SYSCFG_ITLINE5_SR_EXTI0_Msk /*!< External Interrupt 0 */ +#define SYSCFG_ITLINE5_SR_EXTI1_Pos (1U) +#define SYSCFG_ITLINE5_SR_EXTI1_Msk (0x1UL << SYSCFG_ITLINE5_SR_EXTI1_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE5_SR_EXTI1 SYSCFG_ITLINE5_SR_EXTI1_Msk /*!< External Interrupt 1 */ +#define SYSCFG_ITLINE6_SR_EXTI2_Pos (0U) +#define SYSCFG_ITLINE6_SR_EXTI2_Msk (0x1UL << SYSCFG_ITLINE6_SR_EXTI2_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE6_SR_EXTI2 SYSCFG_ITLINE6_SR_EXTI2_Msk /*!< External Interrupt 2 */ +#define SYSCFG_ITLINE6_SR_EXTI3_Pos (1U) +#define SYSCFG_ITLINE6_SR_EXTI3_Msk (0x1UL << SYSCFG_ITLINE6_SR_EXTI3_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE6_SR_EXTI3 SYSCFG_ITLINE6_SR_EXTI3_Msk /*!< External Interrupt 3 */ +#define SYSCFG_ITLINE7_SR_EXTI4_Pos (0U) +#define SYSCFG_ITLINE7_SR_EXTI4_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI4_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE7_SR_EXTI4 SYSCFG_ITLINE7_SR_EXTI4_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI5_Pos (1U) +#define SYSCFG_ITLINE7_SR_EXTI5_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI5_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE7_SR_EXTI5 SYSCFG_ITLINE7_SR_EXTI5_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI6_Pos (2U) +#define SYSCFG_ITLINE7_SR_EXTI6_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI6_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE7_SR_EXTI6 SYSCFG_ITLINE7_SR_EXTI6_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI7_Pos (3U) +#define SYSCFG_ITLINE7_SR_EXTI7_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI7_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE7_SR_EXTI7 SYSCFG_ITLINE7_SR_EXTI7_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI8_Pos (4U) +#define SYSCFG_ITLINE7_SR_EXTI8_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI8_Pos) /*!< 0x00000010 */ +#define SYSCFG_ITLINE7_SR_EXTI8 SYSCFG_ITLINE7_SR_EXTI8_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI9_Pos (5U) +#define SYSCFG_ITLINE7_SR_EXTI9_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI9_Pos) /*!< 0x00000020 */ +#define SYSCFG_ITLINE7_SR_EXTI9 SYSCFG_ITLINE7_SR_EXTI9_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI10_Pos (6U) +#define SYSCFG_ITLINE7_SR_EXTI10_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI10_Pos) /*!< 0x00000040 */ +#define SYSCFG_ITLINE7_SR_EXTI10 SYSCFG_ITLINE7_SR_EXTI10_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI11_Pos (7U) +#define SYSCFG_ITLINE7_SR_EXTI11_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI11_Pos) /*!< 0x00000080 */ +#define SYSCFG_ITLINE7_SR_EXTI11 SYSCFG_ITLINE7_SR_EXTI11_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI12_Pos (8U) +#define SYSCFG_ITLINE7_SR_EXTI12_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI12_Pos) /*!< 0x00000100 */ +#define SYSCFG_ITLINE7_SR_EXTI12 SYSCFG_ITLINE7_SR_EXTI12_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI13_Pos (9U) +#define SYSCFG_ITLINE7_SR_EXTI13_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI13_Pos) /*!< 0x00000200 */ +#define SYSCFG_ITLINE7_SR_EXTI13 SYSCFG_ITLINE7_SR_EXTI13_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI14_Pos (10U) +#define SYSCFG_ITLINE7_SR_EXTI14_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI14_Pos) /*!< 0x00000400 */ +#define SYSCFG_ITLINE7_SR_EXTI14 SYSCFG_ITLINE7_SR_EXTI14_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE7_SR_EXTI15_Pos (11U) +#define SYSCFG_ITLINE7_SR_EXTI15_Msk (0x1UL << SYSCFG_ITLINE7_SR_EXTI15_Pos) /*!< 0x00000800 */ +#define SYSCFG_ITLINE7_SR_EXTI15 SYSCFG_ITLINE7_SR_EXTI15_Msk /*!< External Interrupt 15 to 4 */ +#define SYSCFG_ITLINE8_SR_TSC_EOA_Pos (0U) +#define SYSCFG_ITLINE8_SR_TSC_EOA_Msk (0x1UL << SYSCFG_ITLINE8_SR_TSC_EOA_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE8_SR_TSC_EOA SYSCFG_ITLINE8_SR_TSC_EOA_Msk /*!< Touch control EOA Interrupt */ +#define SYSCFG_ITLINE8_SR_TSC_MCE_Pos (1U) +#define SYSCFG_ITLINE8_SR_TSC_MCE_Msk (0x1UL << SYSCFG_ITLINE8_SR_TSC_MCE_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE8_SR_TSC_MCE SYSCFG_ITLINE8_SR_TSC_MCE_Msk /*!< Touch control MCE Interrupt */ +#define SYSCFG_ITLINE9_SR_DMA1_CH1_Pos (0U) +#define SYSCFG_ITLINE9_SR_DMA1_CH1_Msk (0x1UL << SYSCFG_ITLINE9_SR_DMA1_CH1_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE9_SR_DMA1_CH1 SYSCFG_ITLINE9_SR_DMA1_CH1_Msk /*!< DMA1 Channel 1 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA1_CH2_Pos (0U) +#define SYSCFG_ITLINE10_SR_DMA1_CH2_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA1_CH2_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE10_SR_DMA1_CH2 SYSCFG_ITLINE10_SR_DMA1_CH2_Msk /*!< DMA1 Channel 2 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA1_CH3_Pos (1U) +#define SYSCFG_ITLINE10_SR_DMA1_CH3_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA1_CH3_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE10_SR_DMA1_CH3 SYSCFG_ITLINE10_SR_DMA1_CH3_Msk /*!< DMA2 Channel 3 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA2_CH1_Pos (2U) +#define SYSCFG_ITLINE10_SR_DMA2_CH1_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA2_CH1_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE10_SR_DMA2_CH1 SYSCFG_ITLINE10_SR_DMA2_CH1_Msk /*!< DMA2 Channel 1 Interrupt */ +#define SYSCFG_ITLINE10_SR_DMA2_CH2_Pos (3U) +#define SYSCFG_ITLINE10_SR_DMA2_CH2_Msk (0x1UL << SYSCFG_ITLINE10_SR_DMA2_CH2_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE10_SR_DMA2_CH2 SYSCFG_ITLINE10_SR_DMA2_CH2_Msk /*!< DMA2 Channel 2 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH4_Pos (0U) +#define SYSCFG_ITLINE11_SR_DMA1_CH4_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH4_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH4 SYSCFG_ITLINE11_SR_DMA1_CH4_Msk /*!< DMA1 Channel 4 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH5_Pos (1U) +#define SYSCFG_ITLINE11_SR_DMA1_CH5_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH5_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH5 SYSCFG_ITLINE11_SR_DMA1_CH5_Msk /*!< DMA1 Channel 5 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH6_Pos (2U) +#define SYSCFG_ITLINE11_SR_DMA1_CH6_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH6_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH6 SYSCFG_ITLINE11_SR_DMA1_CH6_Msk /*!< DMA1 Channel 6 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA1_CH7_Pos (3U) +#define SYSCFG_ITLINE11_SR_DMA1_CH7_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA1_CH7_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE11_SR_DMA1_CH7 SYSCFG_ITLINE11_SR_DMA1_CH7_Msk /*!< DMA1 Channel 7 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA2_CH3_Pos (4U) +#define SYSCFG_ITLINE11_SR_DMA2_CH3_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA2_CH3_Pos) /*!< 0x00000010 */ +#define SYSCFG_ITLINE11_SR_DMA2_CH3 SYSCFG_ITLINE11_SR_DMA2_CH3_Msk /*!< DMA2 Channel 3 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA2_CH4_Pos (5U) +#define SYSCFG_ITLINE11_SR_DMA2_CH4_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA2_CH4_Pos) /*!< 0x00000020 */ +#define SYSCFG_ITLINE11_SR_DMA2_CH4 SYSCFG_ITLINE11_SR_DMA2_CH4_Msk /*!< DMA2 Channel 4 Interrupt */ +#define SYSCFG_ITLINE11_SR_DMA2_CH5_Pos (6U) +#define SYSCFG_ITLINE11_SR_DMA2_CH5_Msk (0x1UL << SYSCFG_ITLINE11_SR_DMA2_CH5_Pos) /*!< 0x00000040 */ +#define SYSCFG_ITLINE11_SR_DMA2_CH5 SYSCFG_ITLINE11_SR_DMA2_CH5_Msk /*!< DMA2 Channel 5 Interrupt */ +#define SYSCFG_ITLINE12_SR_ADC_Pos (0U) +#define SYSCFG_ITLINE12_SR_ADC_Msk (0x1UL << SYSCFG_ITLINE12_SR_ADC_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE12_SR_ADC SYSCFG_ITLINE12_SR_ADC_Msk /*!< ADC Interrupt */ +#define SYSCFG_ITLINE12_SR_COMP1_Pos (1U) +#define SYSCFG_ITLINE12_SR_COMP1_Msk (0x1UL << SYSCFG_ITLINE12_SR_COMP1_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE12_SR_COMP1 SYSCFG_ITLINE12_SR_COMP1_Msk /*!< COMP1 Interrupt -> exti[21] */ +#define SYSCFG_ITLINE12_SR_COMP2_Pos (2U) +#define SYSCFG_ITLINE12_SR_COMP2_Msk (0x1UL << SYSCFG_ITLINE12_SR_COMP2_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE12_SR_COMP2 SYSCFG_ITLINE12_SR_COMP2_Msk /*!< COMP2 Interrupt -> exti[22] */ +#define SYSCFG_ITLINE13_SR_TIM1_BRK_Pos (0U) +#define SYSCFG_ITLINE13_SR_TIM1_BRK_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_BRK_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE13_SR_TIM1_BRK SYSCFG_ITLINE13_SR_TIM1_BRK_Msk /*!< TIM1 BRK Interrupt */ +#define SYSCFG_ITLINE13_SR_TIM1_UPD_Pos (1U) +#define SYSCFG_ITLINE13_SR_TIM1_UPD_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_UPD_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE13_SR_TIM1_UPD SYSCFG_ITLINE13_SR_TIM1_UPD_Msk /*!< TIM1 UPD Interrupt */ +#define SYSCFG_ITLINE13_SR_TIM1_TRG_Pos (2U) +#define SYSCFG_ITLINE13_SR_TIM1_TRG_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_TRG_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE13_SR_TIM1_TRG SYSCFG_ITLINE13_SR_TIM1_TRG_Msk /*!< TIM1 TRG Interrupt */ +#define SYSCFG_ITLINE13_SR_TIM1_CCU_Pos (3U) +#define SYSCFG_ITLINE13_SR_TIM1_CCU_Msk (0x1UL << SYSCFG_ITLINE13_SR_TIM1_CCU_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE13_SR_TIM1_CCU SYSCFG_ITLINE13_SR_TIM1_CCU_Msk /*!< TIM1 CCU Interrupt */ +#define SYSCFG_ITLINE14_SR_TIM1_CC_Pos (0U) +#define SYSCFG_ITLINE14_SR_TIM1_CC_Msk (0x1UL << SYSCFG_ITLINE14_SR_TIM1_CC_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE14_SR_TIM1_CC SYSCFG_ITLINE14_SR_TIM1_CC_Msk /*!< TIM1 CC Interrupt */ +#define SYSCFG_ITLINE15_SR_TIM2_GLB_Pos (0U) +#define SYSCFG_ITLINE15_SR_TIM2_GLB_Msk (0x1UL << SYSCFG_ITLINE15_SR_TIM2_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE15_SR_TIM2_GLB SYSCFG_ITLINE15_SR_TIM2_GLB_Msk /*!< TIM2 GLB Interrupt */ +#define SYSCFG_ITLINE16_SR_TIM3_GLB_Pos (0U) +#define SYSCFG_ITLINE16_SR_TIM3_GLB_Msk (0x1UL << SYSCFG_ITLINE16_SR_TIM3_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE16_SR_TIM3_GLB SYSCFG_ITLINE16_SR_TIM3_GLB_Msk /*!< TIM3 GLB Interrupt */ +#define SYSCFG_ITLINE17_SR_DAC_Pos (0U) +#define SYSCFG_ITLINE17_SR_DAC_Msk (0x1UL << SYSCFG_ITLINE17_SR_DAC_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE17_SR_DAC SYSCFG_ITLINE17_SR_DAC_Msk /*!< DAC Interrupt */ +#define SYSCFG_ITLINE17_SR_TIM6_GLB_Pos (1U) +#define SYSCFG_ITLINE17_SR_TIM6_GLB_Msk (0x1UL << SYSCFG_ITLINE17_SR_TIM6_GLB_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE17_SR_TIM6_GLB SYSCFG_ITLINE17_SR_TIM6_GLB_Msk /*!< TIM6 GLB Interrupt */ +#define SYSCFG_ITLINE18_SR_TIM7_GLB_Pos (0U) +#define SYSCFG_ITLINE18_SR_TIM7_GLB_Msk (0x1UL << SYSCFG_ITLINE18_SR_TIM7_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE18_SR_TIM7_GLB SYSCFG_ITLINE18_SR_TIM7_GLB_Msk /*!< TIM7 GLB Interrupt */ +#define SYSCFG_ITLINE19_SR_TIM14_GLB_Pos (0U) +#define SYSCFG_ITLINE19_SR_TIM14_GLB_Msk (0x1UL << SYSCFG_ITLINE19_SR_TIM14_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE19_SR_TIM14_GLB SYSCFG_ITLINE19_SR_TIM14_GLB_Msk /*!< TIM14 GLB Interrupt */ +#define SYSCFG_ITLINE20_SR_TIM15_GLB_Pos (0U) +#define SYSCFG_ITLINE20_SR_TIM15_GLB_Msk (0x1UL << SYSCFG_ITLINE20_SR_TIM15_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE20_SR_TIM15_GLB SYSCFG_ITLINE20_SR_TIM15_GLB_Msk /*!< TIM15 GLB Interrupt */ +#define SYSCFG_ITLINE21_SR_TIM16_GLB_Pos (0U) +#define SYSCFG_ITLINE21_SR_TIM16_GLB_Msk (0x1UL << SYSCFG_ITLINE21_SR_TIM16_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE21_SR_TIM16_GLB SYSCFG_ITLINE21_SR_TIM16_GLB_Msk /*!< TIM16 GLB Interrupt */ +#define SYSCFG_ITLINE22_SR_TIM17_GLB_Pos (0U) +#define SYSCFG_ITLINE22_SR_TIM17_GLB_Msk (0x1UL << SYSCFG_ITLINE22_SR_TIM17_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE22_SR_TIM17_GLB SYSCFG_ITLINE22_SR_TIM17_GLB_Msk /*!< TIM17 GLB Interrupt */ +#define SYSCFG_ITLINE23_SR_I2C1_GLB_Pos (0U) +#define SYSCFG_ITLINE23_SR_I2C1_GLB_Msk (0x1UL << SYSCFG_ITLINE23_SR_I2C1_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE23_SR_I2C1_GLB SYSCFG_ITLINE23_SR_I2C1_GLB_Msk /*!< I2C1 GLB Interrupt -> exti[23] */ +#define SYSCFG_ITLINE24_SR_I2C2_GLB_Pos (0U) +#define SYSCFG_ITLINE24_SR_I2C2_GLB_Msk (0x1UL << SYSCFG_ITLINE24_SR_I2C2_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE24_SR_I2C2_GLB SYSCFG_ITLINE24_SR_I2C2_GLB_Msk /*!< I2C2 GLB Interrupt */ +#define SYSCFG_ITLINE25_SR_SPI1_Pos (0U) +#define SYSCFG_ITLINE25_SR_SPI1_Msk (0x1UL << SYSCFG_ITLINE25_SR_SPI1_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE25_SR_SPI1 SYSCFG_ITLINE25_SR_SPI1_Msk /*!< SPI1 Interrupt */ +#define SYSCFG_ITLINE26_SR_SPI2_Pos (0U) +#define SYSCFG_ITLINE26_SR_SPI2_Msk (0x1UL << SYSCFG_ITLINE26_SR_SPI2_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE26_SR_SPI2 SYSCFG_ITLINE26_SR_SPI2_Msk /*!< SPI2 Interrupt */ +#define SYSCFG_ITLINE27_SR_USART1_GLB_Pos (0U) +#define SYSCFG_ITLINE27_SR_USART1_GLB_Msk (0x1UL << SYSCFG_ITLINE27_SR_USART1_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE27_SR_USART1_GLB SYSCFG_ITLINE27_SR_USART1_GLB_Msk /*!< USART1 GLB Interrupt -> exti[25] */ +#define SYSCFG_ITLINE28_SR_USART2_GLB_Pos (0U) +#define SYSCFG_ITLINE28_SR_USART2_GLB_Msk (0x1UL << SYSCFG_ITLINE28_SR_USART2_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE28_SR_USART2_GLB SYSCFG_ITLINE28_SR_USART2_GLB_Msk /*!< USART2 GLB Interrupt -> exti[26] */ +#define SYSCFG_ITLINE29_SR_USART3_GLB_Pos (0U) +#define SYSCFG_ITLINE29_SR_USART3_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART3_GLB_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE29_SR_USART3_GLB SYSCFG_ITLINE29_SR_USART3_GLB_Msk /*!< USART3 GLB Interrupt -> exti[28] */ +#define SYSCFG_ITLINE29_SR_USART4_GLB_Pos (1U) +#define SYSCFG_ITLINE29_SR_USART4_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART4_GLB_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE29_SR_USART4_GLB SYSCFG_ITLINE29_SR_USART4_GLB_Msk /*!< USART4 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART5_GLB_Pos (2U) +#define SYSCFG_ITLINE29_SR_USART5_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART5_GLB_Pos) /*!< 0x00000004 */ +#define SYSCFG_ITLINE29_SR_USART5_GLB SYSCFG_ITLINE29_SR_USART5_GLB_Msk /*!< USART5 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART6_GLB_Pos (3U) +#define SYSCFG_ITLINE29_SR_USART6_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART6_GLB_Pos) /*!< 0x00000008 */ +#define SYSCFG_ITLINE29_SR_USART6_GLB SYSCFG_ITLINE29_SR_USART6_GLB_Msk /*!< USART6 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART7_GLB_Pos (4U) +#define SYSCFG_ITLINE29_SR_USART7_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART7_GLB_Pos) /*!< 0x00000010 */ +#define SYSCFG_ITLINE29_SR_USART7_GLB SYSCFG_ITLINE29_SR_USART7_GLB_Msk /*!< USART7 GLB Interrupt */ +#define SYSCFG_ITLINE29_SR_USART8_GLB_Pos (5U) +#define SYSCFG_ITLINE29_SR_USART8_GLB_Msk (0x1UL << SYSCFG_ITLINE29_SR_USART8_GLB_Pos) /*!< 0x00000020 */ +#define SYSCFG_ITLINE29_SR_USART8_GLB SYSCFG_ITLINE29_SR_USART8_GLB_Msk /*!< USART8 GLB Interrupt */ +#define SYSCFG_ITLINE30_SR_CAN_Pos (0U) +#define SYSCFG_ITLINE30_SR_CAN_Msk (0x1UL << SYSCFG_ITLINE30_SR_CAN_Pos) /*!< 0x00000001 */ +#define SYSCFG_ITLINE30_SR_CAN SYSCFG_ITLINE30_SR_CAN_Msk /*!< CAN Interrupt */ +#define SYSCFG_ITLINE30_SR_CEC_Pos (1U) +#define SYSCFG_ITLINE30_SR_CEC_Msk (0x1UL << SYSCFG_ITLINE30_SR_CEC_Pos) /*!< 0x00000002 */ +#define SYSCFG_ITLINE30_SR_CEC SYSCFG_ITLINE30_SR_CEC_Msk /*!< CEC Interrupt */ + +/*****************************************************************************/ +/* */ +/* Timers (TIM) */ +/* */ +/*****************************************************************************/ +/******************* Bit definition for TIM_CR1 register *******************/ +#define TIM_CR1_CEN_Pos (0U) +#define TIM_CR1_CEN_Msk (0x1UL << TIM_CR1_CEN_Pos) /*!< 0x00000001 */ +#define TIM_CR1_CEN TIM_CR1_CEN_Msk /*!
© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.
+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f0xx + * @{ + */ + +#ifndef __STM32F0xx_H +#define __STM32F0xx_H + +#ifdef __cplusplus + extern "C" { +#endif /* __cplusplus */ + +/** @addtogroup Library_configuration_section + * @{ + */ + +/** + * @brief STM32 Family + */ +#if !defined (STM32F0) +#define STM32F0 +#endif /* STM32F0 */ + +/** Uncomment the line below according to the target STM32 device used in your application. + * stm32f0xxxx.h file contains: + * - All the peripheral register's definitions, bits definitions and memory mapping for STM32F0xxxx devices + * - IRQ channel definition + * - Peripheral memory mapping and physical registers address definition + * - Peripheral pointer declaration and driver header file inclusion + * - Product miscellaneous configuration: assert macros… + * Note: These CMSIS drivers (stm32f0xxxx.h) are always supporting features of the sub-family’s superset. + */ + +#if !defined (STM32F030x6) && !defined (STM32F030x8) && \ + !defined (STM32F031x6) && !defined (STM32F038xx) && \ + !defined (STM32F042x6) && !defined (STM32F048xx) && !defined (STM32F070x6) && \ + !defined (STM32F051x8) && !defined (STM32F058xx) && \ + !defined (STM32F071xB) && !defined (STM32F072xB) && !defined (STM32F078xx) && !defined (STM32F070xB) && \ + !defined (STM32F091xC) && !defined (STM32F098xx) && !defined (STM32F030xC) + /* #define STM32F030x6 */ /*!< STM32F030x4, STM32F030x6 Devices (STM32F030xx microcontrollers where the Flash memory ranges between 16 and 32 Kbytes) */ + /* #define STM32F030x8 */ /*!< STM32F030x8 Devices (STM32F030xx microcontrollers where the Flash memory is 64 Kbytes) */ + /* #define STM32F031x6 */ /*!< STM32F031x4, STM32F031x6 Devices (STM32F031xx microcontrollers where the Flash memory ranges between 16 and 32 Kbytes) */ + /* #define STM32F038xx */ /*!< STM32F038xx Devices (STM32F038xx microcontrollers where the Flash memory is 32 Kbytes) */ + /* #define STM32F042x6 */ /*!< STM32F042x4, STM32F042x6 Devices (STM32F042xx microcontrollers where the Flash memory ranges between 16 and 32 Kbytes) */ + /* #define STM32F048xx */ /*!< STM32F048xx Devices (STM32F048xx microcontrollers where the Flash memory is 32 Kbytes) */ + /* #define STM32F051x8 */ /*!< STM32F051x4, STM32F051x6, STM32F051x8 Devices (STM32F051xx microcontrollers where the Flash memory ranges between 16 and 64 Kbytes) */ + /* #define STM32F058xx */ /*!< STM32F058xx Devices (STM32F058xx microcontrollers where the Flash memory is 64 Kbytes) */ + /* #define STM32F070x6 */ /*!< STM32F070x6 Devices (STM32F070x6 microcontrollers where the Flash memory ranges between 16 and 32 Kbytes) */ + /* #define STM32F070xB */ /*!< STM32F070xB Devices (STM32F070xB microcontrollers where the Flash memory ranges between 64 and 128 Kbytes) */ + /* #define STM32F071xB */ /*!< STM32F071x8, STM32F071xB Devices (STM32F071xx microcontrollers where the Flash memory ranges between 64 and 128 Kbytes) */ + /* #define STM32F072xB */ /*!< STM32F072x8, STM32F072xB Devices (STM32F072xx microcontrollers where the Flash memory ranges between 64 and 128 Kbytes) */ + /* #define STM32F078xx */ /*!< STM32F078xx Devices (STM32F078xx microcontrollers where the Flash memory is 128 Kbytes) */ + /* #define STM32F030xC */ /*!< STM32F030xC Devices (STM32F030xC microcontrollers where the Flash memory is 256 Kbytes) */ + /* #define STM32F091xC */ /*!< STM32F091xB, STM32F091xC Devices (STM32F091xx microcontrollers where the Flash memory ranges between 128 and 256 Kbytes) */ + /* #define STM32F098xx */ /*!< STM32F098xx Devices (STM32F098xx microcontrollers where the Flash memory is 256 Kbytes) */ +#endif +/* Legacy aliases */ +#if defined (STM32F048x6) + #define STM32F048xx +#endif /* STM32F048x6 */ + +/* Tip: To avoid modifying this file each time you need to switch between these + devices, you can define the device in your toolchain compiler preprocessor. + */ +#if !defined (USE_HAL_DRIVER) +/** + * @brief Comment the line below if you will not use the peripherals drivers. + In this case, these drivers will not be included and the application code will + be based on direct access to peripherals registers + */ + /*#define USE_HAL_DRIVER */ +#endif /* USE_HAL_DRIVER */ + +/** + * @brief CMSIS Device version number V2.3.6 + */ +#define __STM32F0_DEVICE_VERSION_MAIN (0x02) /*!< [31:24] main version */ +#define __STM32F0_DEVICE_VERSION_SUB1 (0x03) /*!< [23:16] sub1 version */ +#define __STM32F0_DEVICE_VERSION_SUB2 (0x06) /*!< [15:8] sub2 version */ +#define __STM32F0_DEVICE_VERSION_RC (0x00) /*!< [7:0] release candidate */ +#define __STM32F0_DEVICE_VERSION ((__STM32F0_DEVICE_VERSION_MAIN << 24)\ + |(__STM32F0_DEVICE_VERSION_SUB1 << 16)\ + |(__STM32F0_DEVICE_VERSION_SUB2 << 8 )\ + |(__STM32F0_DEVICE_VERSION_RC)) + +/** + * @} + */ + +/** @addtogroup Device_Included + * @{ + */ + +#if defined(STM32F030x6) + #include "stm32f030x6.h" +#elif defined(STM32F030x8) + #include "stm32f030x8.h" +#elif defined(STM32F031x6) + #include "stm32f031x6.h" +#elif defined(STM32F038xx) + #include "stm32f038xx.h" +#elif defined(STM32F042x6) + #include "stm32f042x6.h" +#elif defined(STM32F048xx) + #include "stm32f048xx.h" +#elif defined(STM32F051x8) + #include "stm32f051x8.h" +#elif defined(STM32F058xx) + #include "stm32f058xx.h" +#elif defined(STM32F070x6) + #include "stm32f070x6.h" +#elif defined(STM32F070xB) + #include "stm32f070xb.h" +#elif defined(STM32F071xB) + #include "stm32f071xb.h" +#elif defined(STM32F072xB) + #include "stm32f072xb.h" +#elif defined(STM32F078xx) + #include "stm32f078xx.h" +#elif defined(STM32F091xC) + #include "stm32f091xc.h" +#elif defined(STM32F098xx) + #include "stm32f098xx.h" +#elif defined(STM32F030xC) + #include "stm32f030xc.h" +#else + #error "Please select first the target STM32F0xx device used in your application (in stm32f0xx.h file)" +#endif + +/** + * @} + */ + +/** @addtogroup Exported_types + * @{ + */ +typedef enum +{ + RESET = 0U, + SET = !RESET +} FlagStatus, ITStatus; + +typedef enum +{ + DISABLE = 0U, + ENABLE = !DISABLE +} FunctionalState; +#define IS_FUNCTIONAL_STATE(STATE) (((STATE) == DISABLE) || ((STATE) == ENABLE)) + +typedef enum +{ + SUCCESS = 0U, + ERROR = !SUCCESS +} ErrorStatus; + +/** + * @} + */ + + +/** @addtogroup Exported_macros + * @{ + */ +#define SET_BIT(REG, BIT) ((REG) |= (BIT)) + +#define CLEAR_BIT(REG, BIT) ((REG) &= ~(BIT)) + +#define READ_BIT(REG, BIT) ((REG) & (BIT)) + +#define CLEAR_REG(REG) ((REG) = (0x0)) + +#define WRITE_REG(REG, VAL) ((REG) = (VAL)) + +#define READ_REG(REG) ((REG)) + +#define MODIFY_REG(REG, CLEARMASK, SETMASK) WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK))) + +/* Use of interrupt control for register exclusive access */ +/* Atomic 32-bit register access macro to set one or several bits */ +#define ATOMIC_SET_BIT(REG, BIT) \ + do { \ + uint32_t primask; \ + primask = __get_PRIMASK(); \ + __set_PRIMASK(1); \ + SET_BIT((REG), (BIT)); \ + __set_PRIMASK(primask); \ + } while(0) + +/* Atomic 32-bit register access macro to clear one or several bits */ +#define ATOMIC_CLEAR_BIT(REG, BIT) \ + do { \ + uint32_t primask; \ + primask = __get_PRIMASK(); \ + __set_PRIMASK(1); \ + CLEAR_BIT((REG), (BIT)); \ + __set_PRIMASK(primask); \ + } while(0) + +/* Atomic 32-bit register access macro to clear and set one or several bits */ +#define ATOMIC_MODIFY_REG(REG, CLEARMSK, SETMASK) \ + do { \ + uint32_t primask; \ + primask = __get_PRIMASK(); \ + __set_PRIMASK(1); \ + MODIFY_REG((REG), (CLEARMSK), (SETMASK)); \ + __set_PRIMASK(primask); \ + } while(0) + +/* Atomic 16-bit register access macro to set one or several bits */ +#define ATOMIC_SETH_BIT(REG, BIT) ATOMIC_SET_BIT(REG, BIT) \ + +/* Atomic 16-bit register access macro to clear one or several bits */ +#define ATOMIC_CLEARH_BIT(REG, BIT) ATOMIC_CLEAR_BIT(REG, BIT) \ + +/* Atomic 16-bit register access macro to clear and set one or several bits */ +#define ATOMIC_MODIFYH_REG(REG, CLEARMSK, SETMASK) ATOMIC_MODIFY_REG(REG, CLEARMSK, SETMASK) \ + +/** + * @} + */ + +#if defined (USE_HAL_DRIVER) + #include "stm32f0xx_hal.h" +#endif /* USE_HAL_DRIVER */ + + +#ifdef __cplusplus +} +#endif /* __cplusplus */ + +#endif /* __STM32F0xx_H */ +/** + * @} + */ + +/** + * @} + */ + + + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/system_stm32f0xx.h b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/system_stm32f0xx.h new file mode 100644 index 0000000..fafabf4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Include/system_stm32f0xx.h @@ -0,0 +1,105 @@ +/** + ****************************************************************************** + * @file system_stm32f0xx.h + * @author MCD Application Team + * @brief CMSIS Cortex-M0 Device System Source File for STM32F0xx devices. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f0xx_system + * @{ + */ + +/** + * @brief Define to prevent recursive inclusion + */ +#ifndef __SYSTEM_STM32F0XX_H +#define __SYSTEM_STM32F0XX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/** @addtogroup STM32F0xx_System_Includes + * @{ + */ + +/** + * @} + */ + + +/** @addtogroup STM32F0xx_System_Exported_types + * @{ + */ + /* This variable is updated in three ways: + 1) by calling CMSIS function SystemCoreClockUpdate() + 3) by calling HAL API function HAL_RCC_GetHCLKFreq() + 3) by calling HAL API function HAL_RCC_ClockConfig() + Note: If you use this function to configure the system clock; then there + is no need to call the 2 first functions listed above, since SystemCoreClock + variable is updated automatically. + */ +extern uint32_t SystemCoreClock; /*!< System Clock Frequency (Core Clock) */ +extern const uint8_t AHBPrescTable[16]; /*!< AHB prescalers table values */ +extern const uint8_t APBPrescTable[8]; /*!< APB prescalers table values */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Exported_Constants + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Exported_Macros + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Exported_Functions + * @{ + */ + +extern void SystemInit(void); +extern void SystemCoreClockUpdate(void); +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /*__SYSTEM_STM32F0XX_H */ + +/** + * @} + */ + +/** + * @} + */ +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/License.md b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/License.md new file mode 100644 index 0000000..2d1eee1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/License.md @@ -0,0 +1,83 @@ +Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + +TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + +1. Definitions. + +"License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. + +"Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. + +"Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. + +"You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. + +"Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. + +"Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. + +"Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). + +"Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. + +"Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." + +"Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. + +2. Grant of Copyright License. + +Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. + +3. Grant of Patent License. + +Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. + +4. Redistribution. + +You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: +1.You must give any other recipients of the Work or Derivative Works a copy of this License; and +2.You must cause any modified files to carry prominent notices stating that You changed the files; and +3.You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and +4.If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. + +You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. + +5. Submission of Contributions. + +Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. + +6. Trademarks. + +This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. + +7. Disclaimer of Warranty. + +Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. + +8. Limitation of Liability. + +In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. + +9. Accepting Warranty or Additional Liability. + +While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. + +END OF TERMS AND CONDITIONS + +APPENDIX: + + Copyright [2019] [STMicroelectronics] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x6.s new file mode 100644 index 0000000..c89426e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x6.s @@ -0,0 +1,230 @@ +;******************************************************************************* +;* File Name : startup_stm32f030x6.s +;* Author : MCD Application Team +;* Description : STM32F030x4/STM32F030x6 devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + + +WWDG_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM3_IRQHandler +TIM14_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +SPI1_IRQHandler +USART1_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x8.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x8.s new file mode 100644 index 0000000..02aff1e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030x8.s @@ -0,0 +1,240 @@ +;******************************************************************************* +;* File Name : startup_stm32f030x8.s +;* Author : MCD Application Team +;* Description : STM32F030x8 devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_IRQHandler ; TIM6 + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + + +WWDG_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM3_IRQHandler +TIM6_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030xc.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030xc.s new file mode 100644 index 0000000..bc3c745 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f030xc.s @@ -0,0 +1,245 @@ +;******************************************************************************* +;* File Name : startup_stm32f030xc.s +;* Author : MCD Application Team +;* Description : STM32F030xc/STM32F030xb devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_IRQHandler ; TIM6 + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_6_IRQHandler ; USART3, USART4, USART5, USART6 + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_IRQHandler [WEAK] + EXPORT TIM7_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USART3_6_IRQHandler [WEAK] + + +WWDG_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM3_IRQHandler +TIM6_IRQHandler +TIM7_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USART3_6_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f031x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f031x6.s new file mode 100644 index 0000000..0f01cdd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f031x6.s @@ -0,0 +1,234 @@ +;******************************************************************************* +;* File Name : startup_stm32f031x6.s +;* Author : MCD Application Team +;* Description : STM32F031x4/STM32F031x6 devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT PVD_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + + +WWDG_IRQHandler +PVD_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM14_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +SPI1_IRQHandler +USART1_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f038xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f038xx.s new file mode 100644 index 0000000..ac7a40d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f038xx.s @@ -0,0 +1,232 @@ +;******************************************************************************* +;* File Name : startup_stm32f038xx.s +;* Author : MCD Application Team +;* Description : STM32F038xx devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + + +WWDG_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM14_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +SPI1_IRQHandler +USART1_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f042x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f042x6.s new file mode 100644 index 0000000..8ff3823 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f042x6.s @@ -0,0 +1,275 @@ +;******************************************************************************* +;* File Name : startup_stm32f042x6.s +;* Author : MCD Application Team +;* Description : STM32F042x4/STM32F042x6 devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + + + + LDR R0, =__initial_sp ; set stack pointer + MSR MSP, R0 + +;;Check if boot space corresponds to test memory + + LDR R0,=0x00000004 + LDR R1, [R0] + LSRS R1, R1, #24 + LDR R2,=0x1F + CMP R1, R2 + + BNE ApplicationStart + +;; SYSCFG clock enable + + LDR R0,=0x40021018 + LDR R1,=0x00000001 + STR R1, [R0] + +;; Set CFGR1 register with flash memory remap at address 0 + + LDR R0,=0x40010000 + LDR R1,=0x00000000 + STR R1, [R0] +ApplicationStart + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT PVD_VDDIO2_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_CRS_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT CEC_CAN_IRQHandler [WEAK] + EXPORT USB_IRQHandler [WEAK] + + +WWDG_IRQHandler +PVD_VDDIO2_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_CRS_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM14_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +CEC_CAN_IRQHandler +USB_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f048xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f048xx.s new file mode 100644 index 0000000..45816f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f048xx.s @@ -0,0 +1,247 @@ +;******************************************************************************* +;* File Name : startup_stm32f048xx.s +;* Author : MCD Application Team +;* Description : STM32F048xx devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD VDDIO2_IRQHandler ; VDDIO2 Monitor through EXTI Line 31 + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT VDDIO2_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_CRS_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT CEC_CAN_IRQHandler [WEAK] + EXPORT USB_IRQHandler [WEAK] + + +WWDG_IRQHandler +VDDIO2_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_CRS_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM14_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +CEC_CAN_IRQHandler +USB_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f051x8.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f051x8.s new file mode 100644 index 0000000..783b327 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f051x8.s @@ -0,0 +1,250 @@ +;******************************************************************************* +;* File Name : startup_stm32f051x8.s +;* Author : MCD Application Team +;* Description : STM32F051x4/STM32F051x6/STM32F051x8 devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_IRQHandler ; CEC + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT PVD_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_COMP_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_DAC_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT CEC_IRQHandler [WEAK] + + +WWDG_IRQHandler +PVD_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_COMP_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM6_DAC_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +CEC_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f058xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f058xx.s new file mode 100644 index 0000000..5a41a8e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f058xx.s @@ -0,0 +1,248 @@ +;******************************************************************************* +;* File Name : startup_stm32f058xx.s +;* Author : MCD Application Team +;* Description : STM32F058xx devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_IRQHandler ; CEC + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_COMP_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_DAC_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT CEC_IRQHandler [WEAK] + + +WWDG_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_COMP_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM6_DAC_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +CEC_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070x6.s new file mode 100644 index 0000000..d78bb2f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070x6.s @@ -0,0 +1,265 @@ +;******************************************************************************* +;* File Name : startup_stm32f070x6.s +;* Author : MCD Application Team +;* Description : STM32F070x4/STM32F070x6 devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD USB_IRQHandler ; USB + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + + + + LDR R0, =__initial_sp ; set stack pointer + MSR MSP, R0 + +;;Check if boot space corresponds to test memory + + LDR R0,=0x00000004 + LDR R1, [R0] + LSRS R1, R1, #24 + LDR R2,=0x1F + CMP R1, R2 + + BNE ApplicationStart + +;; SYSCFG clock enable + + LDR R0,=0x40021018 + LDR R1,=0x00000001 + STR R1, [R0] + +;; Set CFGR1 register with flash memory remap at address 0 + + LDR R0,=0x40010000 + LDR R1,=0x00000000 + STR R1, [R0] +ApplicationStart + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USB_IRQHandler [WEAK] + + +WWDG_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM3_IRQHandler +TIM14_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +SPI1_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USB_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070xb.s new file mode 100644 index 0000000..3967557 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f070xb.s @@ -0,0 +1,249 @@ +;******************************************************************************* +;* File Name : startup_stm32f070xb.s +;* Author : MCD Application Team +;* Description : STM32F070x8/STM32F070xB devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_IRQHandler ; TIM6 + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 & USART4 + DCD 0 ; Reserved + DCD USB_IRQHandler ; USB + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_IRQHandler [WEAK] + EXPORT ADC1_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_IRQHandler [WEAK] + EXPORT TIM7_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USART3_4_IRQHandler [WEAK] + EXPORT USB_IRQHandler [WEAK] + + +WWDG_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_IRQHandler +ADC1_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM3_IRQHandler +TIM6_IRQHandler +TIM7_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USART3_4_IRQHandler +USB_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f071xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f071xb.s new file mode 100644 index 0000000..b546be5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f071xb.s @@ -0,0 +1,254 @@ +;******************************************************************************* +;* File Name : startup_stm32f071xb.s +;* Author : MCD Application Team +;* Description : STM32F071x8/STM32F071xB devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_6_7_IRQHandler ; DMA1 Channel 4, Channel 5, Channel 6 and Channel 7 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 & USART4 + DCD CEC_IRQHandler ; CEC + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT PVD_VDDIO2_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_CRS_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_6_7_IRQHandler [WEAK] + EXPORT ADC1_COMP_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_DAC_IRQHandler [WEAK] + EXPORT TIM7_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USART3_4_IRQHandler [WEAK] + EXPORT CEC_IRQHandler [WEAK] + + +WWDG_IRQHandler +PVD_VDDIO2_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_CRS_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_6_7_IRQHandler +ADC1_COMP_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM6_DAC_IRQHandler +TIM7_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USART3_4_IRQHandler +CEC_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f072xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f072xb.s new file mode 100644 index 0000000..57a8bca --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f072xb.s @@ -0,0 +1,257 @@ +;******************************************************************************* +;* File Name : startup_stm32f072xb.s +;* Author : MCD Application Team +;* Description : STM32F072x8/STM32F072xB devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_6_7_IRQHandler ; DMA1 Channel 4, Channel 5, Channel 6 and Channel 7 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 & USART4 + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT PVD_VDDIO2_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_CRS_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_6_7_IRQHandler [WEAK] + EXPORT ADC1_COMP_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_DAC_IRQHandler [WEAK] + EXPORT TIM7_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USART3_4_IRQHandler [WEAK] + EXPORT CEC_CAN_IRQHandler [WEAK] + EXPORT USB_IRQHandler [WEAK] + + +WWDG_IRQHandler +PVD_VDDIO2_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_CRS_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_6_7_IRQHandler +ADC1_COMP_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM6_DAC_IRQHandler +TIM7_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USART3_4_IRQHandler +CEC_CAN_IRQHandler +USB_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f078xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f078xx.s new file mode 100644 index 0000000..122a399 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f078xx.s @@ -0,0 +1,257 @@ +;******************************************************************************* +;* File Name : startup_stm32f078xx.s +;* Author : MCD Application Team +;* Description : STM32F078xx devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD VDDIO2_IRQHandler ; VDDIO2 Monitor through EXTI Line 31 + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_6_7_IRQHandler ; DMA1 Channel 4, Channel 5, Channel 6 and Channel 7 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 & USART4 + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT VDDIO2_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_CRS_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Channel1_IRQHandler [WEAK] + EXPORT DMA1_Channel2_3_IRQHandler [WEAK] + EXPORT DMA1_Channel4_5_6_7_IRQHandler [WEAK] + EXPORT ADC1_COMP_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_DAC_IRQHandler [WEAK] + EXPORT TIM7_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USART3_4_IRQHandler [WEAK] + EXPORT CEC_CAN_IRQHandler [WEAK] + EXPORT USB_IRQHandler [WEAK] + + +WWDG_IRQHandler +VDDIO2_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_CRS_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Channel1_IRQHandler +DMA1_Channel2_3_IRQHandler +DMA1_Channel4_5_6_7_IRQHandler +ADC1_COMP_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM6_DAC_IRQHandler +TIM7_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USART3_4_IRQHandler +CEC_CAN_IRQHandler +USB_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f091xc.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f091xc.s new file mode 100644 index 0000000..a51cc74 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f091xc.s @@ -0,0 +1,254 @@ +;******************************************************************************* +;* File Name : startup_stm32f091xc.s +;* Author : MCD Application Team +;* Description : STM32F091xc/STM32F098xc devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Ch1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler ; DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 + DCD DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler ; DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_8_IRQHandler ; USART3, USART4, USART5, USART6, USART7, USART8 + DCD CEC_CAN_IRQHandler ; CEC and CAN + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT PVD_VDDIO2_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_CRS_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Ch1_IRQHandler [WEAK] + EXPORT DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler [WEAK] + EXPORT DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler [WEAK] + EXPORT ADC1_COMP_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_DAC_IRQHandler [WEAK] + EXPORT TIM7_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USART3_8_IRQHandler [WEAK] + EXPORT CEC_CAN_IRQHandler [WEAK] + + +WWDG_IRQHandler +PVD_VDDIO2_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_CRS_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Ch1_IRQHandler +DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler +DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler +ADC1_COMP_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM6_DAC_IRQHandler +TIM7_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USART3_8_IRQHandler +CEC_CAN_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f098xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f098xx.s new file mode 100644 index 0000000..44a03dd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/arm/startup_stm32f098xx.s @@ -0,0 +1,254 @@ +;******************************************************************************* +;* File Name : startup_stm32f098xx.s +;* Author : MCD Application Team +;* Description : STM32F098xx devices vector table for MDK-ARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == Reset_Handler +;* - Set the vector table entries with the exceptions ISR address +;* - Branches to __main in the C library (which eventually +;* calls main()). +;* After Reset the CortexM0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************** +;* @attention +;* +;* Copyright (c) 2016 STMicroelectronics. +;* All rights reserved. +;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +;* <<< Use Configuration Wizard in Context Menu >>> +; + +; Amount of memory (in bytes) allocated for Stack +; Tailor this value to your application needs +; Stack Configuration +; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Stack_Size EQU 0x00000400 + + AREA STACK, NOINIT, READWRITE, ALIGN=3 +Stack_Mem SPACE Stack_Size +__initial_sp + + +; Heap Configuration +; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8> +; + +Heap_Size EQU 0x00000200 + + AREA HEAP, NOINIT, READWRITE, ALIGN=3 +__heap_base +Heap_Mem SPACE Heap_Size +__heap_limit + + PRESERVE8 + THUMB + + +; Vector Table Mapped to Address 0 at Reset + AREA RESET, DATA, READONLY + EXPORT __Vectors + EXPORT __Vectors_End + EXPORT __Vectors_Size + +__Vectors DCD __initial_sp ; Top of Stack + DCD Reset_Handler ; Reset Handler + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD VDDIO2_IRQHandler ; VDDIO2 Monitor through EXTI Line 31 + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Ch1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler ; DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 + DCD DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler ; DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_8_IRQHandler ; USART3, USART4, USART5, USART6, USART7, USART8 + DCD CEC_CAN_IRQHandler ; CEC and CAN + +__Vectors_End + +__Vectors_Size EQU __Vectors_End - __Vectors + + AREA |.text|, CODE, READONLY + +; Reset handler routine +Reset_Handler PROC + EXPORT Reset_Handler [WEAK] + IMPORT __main + IMPORT SystemInit + LDR R0, =SystemInit + BLX R0 + LDR R0, =__main + BX R0 + ENDP + +; Dummy Exception Handlers (infinite loops which can be modified) + +NMI_Handler PROC + EXPORT NMI_Handler [WEAK] + B . + ENDP +HardFault_Handler\ + PROC + EXPORT HardFault_Handler [WEAK] + B . + ENDP +SVC_Handler PROC + EXPORT SVC_Handler [WEAK] + B . + ENDP +PendSV_Handler PROC + EXPORT PendSV_Handler [WEAK] + B . + ENDP +SysTick_Handler PROC + EXPORT SysTick_Handler [WEAK] + B . + ENDP + +Default_Handler PROC + + EXPORT WWDG_IRQHandler [WEAK] + EXPORT VDDIO2_IRQHandler [WEAK] + EXPORT RTC_IRQHandler [WEAK] + EXPORT FLASH_IRQHandler [WEAK] + EXPORT RCC_CRS_IRQHandler [WEAK] + EXPORT EXTI0_1_IRQHandler [WEAK] + EXPORT EXTI2_3_IRQHandler [WEAK] + EXPORT EXTI4_15_IRQHandler [WEAK] + EXPORT TSC_IRQHandler [WEAK] + EXPORT DMA1_Ch1_IRQHandler [WEAK] + EXPORT DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler [WEAK] + EXPORT DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler [WEAK] + EXPORT ADC1_COMP_IRQHandler [WEAK] + EXPORT TIM1_BRK_UP_TRG_COM_IRQHandler [WEAK] + EXPORT TIM1_CC_IRQHandler [WEAK] + EXPORT TIM2_IRQHandler [WEAK] + EXPORT TIM3_IRQHandler [WEAK] + EXPORT TIM6_DAC_IRQHandler [WEAK] + EXPORT TIM7_IRQHandler [WEAK] + EXPORT TIM14_IRQHandler [WEAK] + EXPORT TIM15_IRQHandler [WEAK] + EXPORT TIM16_IRQHandler [WEAK] + EXPORT TIM17_IRQHandler [WEAK] + EXPORT I2C1_IRQHandler [WEAK] + EXPORT I2C2_IRQHandler [WEAK] + EXPORT SPI1_IRQHandler [WEAK] + EXPORT SPI2_IRQHandler [WEAK] + EXPORT USART1_IRQHandler [WEAK] + EXPORT USART2_IRQHandler [WEAK] + EXPORT USART3_8_IRQHandler [WEAK] + EXPORT CEC_CAN_IRQHandler [WEAK] + + +WWDG_IRQHandler +VDDIO2_IRQHandler +RTC_IRQHandler +FLASH_IRQHandler +RCC_CRS_IRQHandler +EXTI0_1_IRQHandler +EXTI2_3_IRQHandler +EXTI4_15_IRQHandler +TSC_IRQHandler +DMA1_Ch1_IRQHandler +DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler +DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler +ADC1_COMP_IRQHandler +TIM1_BRK_UP_TRG_COM_IRQHandler +TIM1_CC_IRQHandler +TIM2_IRQHandler +TIM3_IRQHandler +TIM6_DAC_IRQHandler +TIM7_IRQHandler +TIM14_IRQHandler +TIM15_IRQHandler +TIM16_IRQHandler +TIM17_IRQHandler +I2C1_IRQHandler +I2C2_IRQHandler +SPI1_IRQHandler +SPI2_IRQHandler +USART1_IRQHandler +USART2_IRQHandler +USART3_8_IRQHandler +CEC_CAN_IRQHandler + + B . + + ENDP + + ALIGN + +;******************************************************************************* +; User Stack and Heap initialization +;******************************************************************************* + IF :DEF:__MICROLIB + + EXPORT __initial_sp + EXPORT __heap_base + EXPORT __heap_limit + + ELSE + + IMPORT __use_two_region_memory + EXPORT __user_initial_stackheap + +__user_initial_stackheap + + LDR R0, = Heap_Mem + LDR R1, =(Stack_Mem + Stack_Size) + LDR R2, = (Heap_Mem + Heap_Size) + LDR R3, = Stack_Mem + BX LR + + ALIGN + + ENDIF + + END + +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x6.s new file mode 100644 index 0000000..727c24d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x6.s @@ -0,0 +1,258 @@ +/** + ****************************************************************************** + * @file startup_stm32f030x6.s + * @author MCD Application Team + * @brief STM32F030x4/STM32F030x6 devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word 0 /* Reserved */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_IRQHandler /* RCC */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word 0 /* Reserved */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word 0 /* Reserved */ + .word TIM3_IRQHandler /* TIM3 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word 0 /* Reserved */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word 0 /* Reserved */ + .word SPI1_IRQHandler /* SPI1 */ + .word 0 /* Reserved */ + .word USART1_IRQHandler /* USART1 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_IRQHandler + .thumb_set RCC_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x8.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x8.s new file mode 100644 index 0000000..ff3496e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030x8.s @@ -0,0 +1,273 @@ +/** + ****************************************************************************** + * @file startup_stm32f030x8.s + * @author MCD Application Team + * @brief STM32F030x8 devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word 0 /* Reserved */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_IRQHandler /* RCC */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word 0 /* Reserved */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word 0 /* Reserved */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_IRQHandler /* TIM6 */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_IRQHandler + .thumb_set RCC_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_IRQHandler + .thumb_set TIM6_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030xc.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030xc.s new file mode 100644 index 0000000..43b492d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f030xc.s @@ -0,0 +1,278 @@ +/** + ****************************************************************************** + * @file startup_stm32f030xc.s + * @author MCD Application Team + * @brief STM32F030xc/STM32F030xb devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word 0 /* Reserved */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_IRQHandler /* RCC */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word 0 /* Reserved */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word 0 /* Reserved */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_IRQHandler /* TIM6 */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_6_IRQHandler /* USART3, USART4, USART5, USART6 */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_IRQHandler + .thumb_set RCC_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_IRQHandler + .thumb_set TIM6_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_6_IRQHandler + .thumb_set USART3_6_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f031x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f031x6.s new file mode 100644 index 0000000..3d990f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f031x6.s @@ -0,0 +1,264 @@ +/** + ****************************************************************************** + * @file startup_stm32f031x6.s + * @author MCD Application Team + * @brief STM32F031x4/STM32F031x6 devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word PVD_IRQHandler /* PVD through EXTI Line detect */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_IRQHandler /* RCC */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word 0 /* Reserved */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word 0 /* Reserved */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word 0 /* Reserved */ + .word SPI1_IRQHandler /* SPI1 */ + .word 0 /* Reserved */ + .word USART1_IRQHandler /* USART1 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak PVD_IRQHandler + .thumb_set PVD_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_IRQHandler + .thumb_set RCC_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f038xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f038xx.s new file mode 100644 index 0000000..5059094 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f038xx.s @@ -0,0 +1,261 @@ +/** + ****************************************************************************** + * @file startup_stm32f038xx.s + * @author MCD Application Team + * @brief STM32F038xx devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word 0 /* Reserved */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_IRQHandler /* RCC */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word 0 /* Reserved */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word 0 /* Reserved */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word 0 /* Reserved */ + .word SPI1_IRQHandler /* SPI1 */ + .word 0 /* Reserved */ + .word USART1_IRQHandler /* USART1 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_IRQHandler + .thumb_set RCC_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f042x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f042x6.s new file mode 100644 index 0000000..2f80631 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f042x6.s @@ -0,0 +1,309 @@ +/** + ****************************************************************************** + * @file startup_stm32f042x6.s + * @author MCD Application Team + * @brief STM32F042x4/STM32F042x6 devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + +/** + * @brief This is the code that gets called when the processor first + * starts execution following a reset event. Only the absolutely + * necessary set is performed, after which the application + * supplied main() routine is called. + * @param None + * @retval : None +*/ + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/*Check if boot space corresponds to test memory*/ + + LDR R0,=0x00000004 + LDR R1, [R0] + LSRS R1, R1, #24 + LDR R2,=0x1F + CMP R1, R2 + BNE ApplicationStart + + /*SYSCFG clock enable*/ + + LDR R0,=0x40021018 + LDR R1,=0x00000001 + STR R1, [R0] + +/*Set CFGR1 register with flash memory remap at address 0*/ + LDR R0,=0x40010000 + LDR R1,=0x00000000 + STR R1, [R0] + +ApplicationStart: +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word PVD_VDDIO2_IRQHandler /* PVD and VDDIO2 through EXTI Line detect */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word 0 /* Reserved */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word 0 /* Reserved */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word 0 /* Reserved */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word USB_IRQHandler /* USB */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak PVD_VDDIO2_IRQHandler + .thumb_set PVD_VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + + .weak USB_IRQHandler + .thumb_set USB_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f048xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f048xx.s new file mode 100644 index 0000000..b0c04f1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f048xx.s @@ -0,0 +1,279 @@ +/** + ****************************************************************************** + * @file startup_stm32f048xx.s + * @author MCD Application Team + * @brief STM32F048xx devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word VDDIO2_IRQHandler /* VDDIO2 Monitor through EXTI Line 31 */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word 0 /* Reserved */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word 0 /* Reserved */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word 0 /* Reserved */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word USB_IRQHandler /* USB */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak VDDIO2_IRQHandler + .thumb_set VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + + .weak USB_IRQHandler + .thumb_set USB_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f051x8.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f051x8.s new file mode 100644 index 0000000..2df2759 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f051x8.s @@ -0,0 +1,285 @@ +/** + ****************************************************************************** + * @file startup_stm32f051x8.s + * @author MCD Application Team + * @brief STM32F051x4/STM32F051x6/STM32F051x8 devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word PVD_IRQHandler /* PVD through EXTI Line detect */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word 0 /* Reserved */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak PVD_IRQHandler + .thumb_set PVD_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f058xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f058xx.s new file mode 100644 index 0000000..f934e6b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f058xx.s @@ -0,0 +1,282 @@ +/** + ****************************************************************************** + * @file startup_stm32f058xx.s + * @author MCD Application Team + * @brief STM32F058xx devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word 0 /* Reserved */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word 0 /* Reserved */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070x6.s new file mode 100644 index 0000000..c9e85bc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070x6.s @@ -0,0 +1,294 @@ +/** + ****************************************************************************** + * @file startup_stm32f070x6.s + * @author MCD Application Team + * @brief STM32F070x4/STM32F070x6 devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + +/** + * @brief This is the code that gets called when the processor first + * starts execution following a reset event. Only the absolutely + * necessary set is performed, after which the application + * supplied main() routine is called. + * @param None + * @retval : None +*/ + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/*Check if boot space corresponds to test memory*/ + + LDR R0,=0x00000004 + LDR R1, [R0] + LSRS R1, R1, #24 + LDR R2,=0x1F + CMP R1, R2 + BNE ApplicationStart + + /*SYSCFG clock enable*/ + + LDR R0,=0x40021018 + LDR R1,=0x00000001 + STR R1, [R0] + +/*Set CFGR1 register with flash memory remap at address 0*/ + LDR R0,=0x40010000 + LDR R1,=0x00000000 + STR R1, [R0] + +ApplicationStart: +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word 0 /* Reserved */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_IRQHandler /* RCC */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word 0 /* Reserved */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word 0 /* Reserved */ + .word TIM3_IRQHandler /* TIM3 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word TIM14_IRQHandler /* TIM14 */ + .word 0 /* Reserved */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word 0 /* Reserved */ + .word SPI1_IRQHandler /* SPI1 */ + .word 0 /* Reserved */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word 0 /* Reserved */ + .word 0 /* Reserved */ + .word USB_IRQHandler /* USB */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_IRQHandler + .thumb_set RCC_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USB_IRQHandler + .thumb_set USB_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070xb.s new file mode 100644 index 0000000..c3026e0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f070xb.s @@ -0,0 +1,282 @@ +/** + ****************************************************************************** + * @file startup_stm32f070xb.s + * @author MCD Application Team + * @brief STM32F070xb/STM32F070x8 devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word 0 /* Reserved */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_IRQHandler /* RCC */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word 0 /* Reserved */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_IRQHandler /* DMA1 Channel 4 and Channel 5 */ + .word ADC1_IRQHandler /* ADC1 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word 0 /* Reserved */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_IRQHandler /* TIM6 */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_4_IRQHandler /* USART3 and USART4 */ + .word 0 /* Reserved */ + .word USB_IRQHandler /* USB */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_IRQHandler + .thumb_set RCC_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_IRQHandler + .thumb_set DMA1_Channel4_5_IRQHandler,Default_Handler + + .weak ADC1_IRQHandler + .thumb_set ADC1_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_IRQHandler + .thumb_set TIM6_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_4_IRQHandler + .thumb_set USART3_4_IRQHandler,Default_Handler + + .weak USB_IRQHandler + .thumb_set USB_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f071xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f071xb.s new file mode 100644 index 0000000..7dcb62d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f071xb.s @@ -0,0 +1,291 @@ +/** + ****************************************************************************** + * @file startup_stm32f071xb.s + * @author MCD Application Team + * @brief STM32F071x8/STM32F071xB devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word PVD_VDDIO2_IRQHandler /* PVD and VDDIO2 through EXTI Line detect */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_6_7_IRQHandler /* DMA1 Channel 4, Channel 5, Channel 6 and Channel 7*/ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_4_IRQHandler /* USART3 and USART4 */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word 0 /* Reserved */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak PVD_VDDIO2_IRQHandler + .thumb_set PVD_VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_6_7_IRQHandler + .thumb_set DMA1_Channel4_5_6_7_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_4_IRQHandler + .thumb_set USART3_4_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f072xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f072xb.s new file mode 100644 index 0000000..9d431a9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f072xb.s @@ -0,0 +1,294 @@ +/** + ****************************************************************************** + * @file startup_stm32f072xb.s + * @author MCD Application Team + * @brief STM32F072x8/STM32F072xB devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word PVD_VDDIO2_IRQHandler /* PVD and VDDIO2 through EXTI Line detect */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_6_7_IRQHandler /* DMA1 Channel 4, Channel 5, Channel 6 and Channel 7*/ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_4_IRQHandler /* USART3 and USART4 */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word USB_IRQHandler /* USB */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak PVD_VDDIO2_IRQHandler + .thumb_set PVD_VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_6_7_IRQHandler + .thumb_set DMA1_Channel4_5_6_7_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_4_IRQHandler + .thumb_set USART3_4_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + + .weak USB_IRQHandler + .thumb_set USB_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f078xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f078xx.s new file mode 100644 index 0000000..c7b54ba --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f078xx.s @@ -0,0 +1,294 @@ +/** + ****************************************************************************** + * @file startup_stm32f078xx.s + * @author MCD Application Team + * @brief STM32F078xx devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word VDDIO2_IRQHandler /* VDDIO2 Monitor through EXTI Line 31 */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_6_7_IRQHandler /* DMA1 Channel 4, Channel 5, Channel 6 and Channel 7*/ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_4_IRQHandler /* USART3 and USART4 */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word USB_IRQHandler /* USB */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak VDDIO2_IRQHandler + .thumb_set VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_6_7_IRQHandler + .thumb_set DMA1_Channel4_5_6_7_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_4_IRQHandler + .thumb_set USART3_4_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + + .weak USB_IRQHandler + .thumb_set USB_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f091xc.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f091xc.s new file mode 100644 index 0000000..1e7d642 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f091xc.s @@ -0,0 +1,290 @@ +/** + ****************************************************************************** + * @file startup_stm32f091xc.s + * @author MCD Application Team + * @brief STM32F091xC devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word PVD_VDDIO2_IRQHandler /* PVD and VDDIO2 through EXTI Line detect */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Ch1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler /* DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 */ + .word DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler /* DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 */ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_8_IRQHandler /* USART3, USART4, USART5, USART6, USART7, USART8 */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak PVD_VDDIO2_IRQHandler + .thumb_set PVD_VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Ch1_IRQHandler + .thumb_set DMA1_Ch1_IRQHandler,Default_Handler + + .weak DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + .thumb_set DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler,Default_Handler + + .weak DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + .thumb_set DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_8_IRQHandler + .thumb_set USART3_8_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f098xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f098xx.s new file mode 100644 index 0000000..5826c2f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/gcc/startup_stm32f098xx.s @@ -0,0 +1,290 @@ +/** + ****************************************************************************** + * @file startup_stm32f098xx.s + * @author MCD Application Team + * @brief STM32F098xx devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word VDDIO2_IRQHandler /* VDDIO2 Monitor through EXTI Line 31 */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Ch1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler /* DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 */ + .word DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler /* DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 */ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_8_IRQHandler /* USART3, USART4, USART5, USART6, USART7, USART8 */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak VDDIO2_IRQHandler + .thumb_set VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Ch1_IRQHandler + .thumb_set DMA1_Ch1_IRQHandler,Default_Handler + + .weak DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + .thumb_set DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler,Default_Handler + + .weak DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + .thumb_set DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_8_IRQHandler + .thumb_set USART3_8_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x6_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x6_flash.icf new file mode 100644 index 0000000..4df4564 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x6_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x08007FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20000FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x8_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x8_flash.icf new file mode 100644 index 0000000..d8897f2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030x8_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0800FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20001FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030xc_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030xc_flash.icf new file mode 100644 index 0000000..e513274 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f030xc_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0803FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f031x6_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f031x6_flash.icf new file mode 100644 index 0000000..4df4564 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f031x6_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x08007FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20000FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f038xx_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f038xx_flash.icf new file mode 100644 index 0000000..4df4564 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f038xx_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x08007FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20000FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f042x6_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f042x6_flash.icf new file mode 100644 index 0000000..25f0bac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f042x6_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x08007FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x200017FF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f048xx_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f048xx_flash.icf new file mode 100644 index 0000000..25f0bac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f048xx_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x08007FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x200017FF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f051x8_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f051x8_flash.icf new file mode 100644 index 0000000..d8897f2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f051x8_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0800FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20001FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f058xx_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f058xx_flash.icf new file mode 100644 index 0000000..d8897f2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f058xx_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0800FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20001FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070x6_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070x6_flash.icf new file mode 100644 index 0000000..25f0bac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070x6_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x08007FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x200017FF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070xb_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070xb_flash.icf new file mode 100644 index 0000000..7ee89ac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f070xb_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0801FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20003FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f071xb_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f071xb_flash.icf new file mode 100644 index 0000000..7ee89ac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f071xb_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0801FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20003FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f072xb_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f072xb_flash.icf new file mode 100644 index 0000000..7ee89ac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f072xb_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0801FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20003FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f078xx_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f078xx_flash.icf new file mode 100644 index 0000000..7ee89ac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f078xx_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0801FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20003FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_flash.icf new file mode 100644 index 0000000..e513274 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0803FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_sram.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_sram.icf new file mode 100644 index 0000000..d0ba727 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f091xc_sram.icf @@ -0,0 +1,31 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x20000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; +define symbol __ICFEDIT_region_ROM_end__ = 0x20003FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20004000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; \ No newline at end of file diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_flash.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_flash.icf new file mode 100644 index 0000000..e513274 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_flash.icf @@ -0,0 +1,33 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x08000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x08000000; +define symbol __ICFEDIT_region_ROM_end__ = 0x0803FFFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20000000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; + +export symbol __ICFEDIT_region_RAM_start__; +export symbol __ICFEDIT_region_RAM_end__; diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_sram.icf b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_sram.icf new file mode 100644 index 0000000..d0ba727 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/linker/stm32f098xx_sram.icf @@ -0,0 +1,31 @@ +/*###ICF### Section handled by ICF editor, don't touch! ****/ +/*-Editor annotation file-*/ +/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */ +/*-Specials-*/ +define symbol __ICFEDIT_intvec_start__ = 0x20000000; +/*-Memory Regions-*/ +define symbol __ICFEDIT_region_ROM_start__ = 0x20000000 ; +define symbol __ICFEDIT_region_ROM_end__ = 0x20003FFF; +define symbol __ICFEDIT_region_RAM_start__ = 0x20004000; +define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF; +/*-Sizes-*/ +define symbol __ICFEDIT_size_cstack__ = 0x400; +define symbol __ICFEDIT_size_heap__ = 0x200; +/**** End of ICF editor section. ###ICF###*/ + + +define memory mem with size = 4G; +define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__]; +define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__]; + +define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { }; +define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { }; + +initialize by copy { readwrite }; +do not initialize { section .noinit }; + +place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec }; + +place in ROM_region { readonly }; +place in RAM_region { readwrite, + block CSTACK, block HEAP }; \ No newline at end of file diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x6.s new file mode 100644 index 0000000..3263b01 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x6.s @@ -0,0 +1,245 @@ +;******************************************************************************* +;* File Name : startup_stm32f030x6.s +;* Author : MCD Application Team +;* Description : STM32F030x4/STM32F030x6 devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_IRQHandler + B RCC_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x8.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x8.s new file mode 100644 index 0000000..adcaacb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030x8.s @@ -0,0 +1,274 @@ +;******************************************************************************* +;* File Name : startup_stm32f030x8.s +;* Author : MCD Application Team +;* Description : STM32F030x8 devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_IRQHandler ; TIM6 + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + + + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_IRQHandler + B RCC_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_IRQHandler + B TIM6_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030xc.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030xc.s new file mode 100644 index 0000000..58647e2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f030xc.s @@ -0,0 +1,283 @@ +;******************************************************************************* +;* File Name : startup_stm32f030xc.s +;* Author : MCD Application Team +;* Description : STM32F030xc devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_IRQHandler ; TIM6 + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_6_IRQHandler ; USART3, USART4, USART5, USART6 + DCD 0 ; Reserved + DCD 0 ; Reserved + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_IRQHandler + B RCC_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_IRQHandler + B TIM6_IRQHandler + + PUBWEAK TIM7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM7_IRQHandler + B TIM7_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USART3_6_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART3_6_IRQHandler + B USART3_6_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f031x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f031x6.s new file mode 100644 index 0000000..e8eee70 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f031x6.s @@ -0,0 +1,255 @@ +;******************************************************************************* +;* File Name : startup_stm32f031x6.s +;* Author : MCD Application Team +;* Description : STM32F031x4/STM32F031x6 devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK PVD_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +PVD_IRQHandler + B PVD_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_IRQHandler + B RCC_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f038xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f038xx.s new file mode 100644 index 0000000..c51bde8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f038xx.s @@ -0,0 +1,250 @@ +;******************************************************************************* +;* File Name : startup_stm32f038xx.s +;* Author : MCD Application Team +;* Description : STM32F038xx devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_IRQHandler + B RCC_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f042x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f042x6.s new file mode 100644 index 0000000..1a0097d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f042x6.s @@ -0,0 +1,306 @@ +;******************************************************************************* +;* File Name : startup_stm32f042x6.s +;* Author : MCD Application Team +;* Description : STM32F042x4/STM32F042x6 devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD and VDDIO2 through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TSC + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + + LDR R0, =sfe(CSTACK) ; set stack pointer + MSR MSP, R0 + +;;Check if boot space corresponds to test memory + LDR R0,=0x00000004 + LDR R1, [R0] + LSRS R1, R1, #24 + LDR R2,=0x1F + CMP R1, R2 + + BNE ApplicationStart +;; SYSCFG clock enable + LDR R0,=0x40021018 + LDR R1,=0x00000001 + STR R1, [R0] + +;; Set CFGR1 register with flash memory remap at address 0 + + LDR R0,=0x40010000 + LDR R1,=0x00000000 + STR R1, [R0] +ApplicationStart + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK PVD_VDDIO2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +PVD_VDDIO2_IRQHandler + B PVD_VDDIO2_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + PUBWEAK USB_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USB_IRQHandler + B USB_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f048xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f048xx.s new file mode 100644 index 0000000..24d7c60 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f048xx.s @@ -0,0 +1,283 @@ +;******************************************************************************* +;* File Name : startup_stm32f048xx.s +;* Author : MCD Application Team +;* Description : STM32F048xx devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD VDDIO2_IRQHandler ; VDDIO2 Monitor through EXTI Line 31 + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TSC + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK VDDIO2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +VDDIO2_IRQHandler + B VDDIO2_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + PUBWEAK USB_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USB_IRQHandler + B USB_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f051x8.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f051x8.s new file mode 100644 index 0000000..14bd025 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f051x8.s @@ -0,0 +1,293 @@ +;******************************************************************************* +;* File Name : startup_stm32f051x8.s +;* Author : MCD Application Team +;* Description : STM32F051x4/STM32F051x6/STM32F051x8 devices vector table +;* for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_IRQHandler ; PVD through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TSC + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_CAN_IRQHandler ; CEC and CAN + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK PVD_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +PVD_IRQHandler + B PVD_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_COMP_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_COMP_IRQHandler + B ADC1_COMP_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_DAC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_DAC_IRQHandler + B TIM6_DAC_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f058xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f058xx.s new file mode 100644 index 0000000..d39c089 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f058xx.s @@ -0,0 +1,287 @@ +;******************************************************************************* +;* File Name : startup_stm32f058xx.s +;* Author : MCD Application Team +;* Description : STM32F058xx devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TSC + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD CEC_CAN_IRQHandler ; CEC and CAN + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_COMP_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_COMP_IRQHandler + B ADC1_COMP_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_DAC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_DAC_IRQHandler + B TIM6_DAC_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070x6.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070x6.s new file mode 100644 index 0000000..d387ddf --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070x6.s @@ -0,0 +1,281 @@ +;******************************************************************************* +;* File Name : startup_stm32f070x6.s +;* Author : MCD Application Team +;* Description : STM32F070x6 devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD TIM14_IRQHandler ; TIM14 + DCD 0 ; Reserved + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD 0 ; Reserved + DCD SPI1_IRQHandler ; SPI1 + DCD 0 ; Reserved + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD USB_IRQHandler ; USB + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + + LDR R0, =sfe(CSTACK) ; set stack pointer + MSR MSP, R0 + +;;Check if boot space corresponds to test memory + LDR R0,=0x00000004 + LDR R1, [R0] + LSRS R1, R1, #24 + LDR R2,=0x1F + CMP R1, R2 + + BNE ApplicationStart +;; SYSCFG clock enable + LDR R0,=0x40021018 + LDR R1,=0x00000001 + STR R1, [R0] + +;; Set CFGR1 register with flash memory remap at address 0 + + LDR R0,=0x40010000 + LDR R1,=0x00000000 + STR R1, [R0] +ApplicationStart + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_IRQHandler + B RCC_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USB_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USB_IRQHandler + B USB_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070xb.s new file mode 100644 index 0000000..e66127f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f070xb.s @@ -0,0 +1,288 @@ +;******************************************************************************* +;* File Name : startup_stm32f070xb.s +;* Author : MCD Application Team +;* Description : STM32F070xB devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD 0 ; Reserved + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_IRQHandler ; RCC + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD 0 ; Reserved + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_IRQHandler ; DMA1 Channel 4 and Channel 5 + DCD ADC1_IRQHandler ; ADC1 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD 0 ; Reserved + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_IRQHandler ; TIM6 + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 and USART4 + DCD 0 ; Reserved + DCD USB_IRQHandler ; USB + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_IRQHandler + B RCC_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_IRQHandler + B DMA1_Channel4_5_IRQHandler + + PUBWEAK ADC1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_IRQHandler + B ADC1_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_IRQHandler + B TIM6_IRQHandler + + PUBWEAK TIM7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM7_IRQHandler + B TIM7_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USART3_4_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART3_4_IRQHandler + B USART3_4_IRQHandler + + PUBWEAK USB_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USB_IRQHandler + B USB_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f071xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f071xb.s new file mode 100644 index 0000000..d716fab --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f071xb.s @@ -0,0 +1,302 @@ +;******************************************************************************* +;* File Name : startup_stm32f071xb.s +;* Author : MCD Application Team +;* Description : STM32F071x8/STM32F071xB devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD and VDDIO2 through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TSC + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_6_7_IRQHandler ; DMA1 Channel 4 to Channel 7 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 and USART4 + DCD CEC_CAN_IRQHandler ; CEC and CAN + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK PVD_VDDIO2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +PVD_VDDIO2_IRQHandler + B PVD_VDDIO2_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_6_7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_6_7_IRQHandler + B DMA1_Channel4_5_6_7_IRQHandler + + PUBWEAK ADC1_COMP_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_COMP_IRQHandler + B ADC1_COMP_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_DAC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_DAC_IRQHandler + B TIM6_DAC_IRQHandler + + PUBWEAK TIM7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM7_IRQHandler + B TIM7_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USART3_4_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART3_4_IRQHandler + B USART3_4_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f072xb.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f072xb.s new file mode 100644 index 0000000..b92a665 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f072xb.s @@ -0,0 +1,308 @@ +;******************************************************************************* +;* File Name : startup_stm32f072xb.s +;* Author : MCD Application Team +;* Description : STM32F072x8/STM32F072xB devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD and VDDIO2 through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TSC + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_6_7_IRQHandler ; DMA1 Channel 4 to Channel 7 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 and USART4 + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK PVD_VDDIO2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +PVD_VDDIO2_IRQHandler + B PVD_VDDIO2_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_6_7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_6_7_IRQHandler + B DMA1_Channel4_5_6_7_IRQHandler + + PUBWEAK ADC1_COMP_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_COMP_IRQHandler + B ADC1_COMP_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_DAC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_DAC_IRQHandler + B TIM6_DAC_IRQHandler + + PUBWEAK TIM7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM7_IRQHandler + B TIM7_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USART3_4_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART3_4_IRQHandler + B USART3_4_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + PUBWEAK USB_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USB_IRQHandler + B USB_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f078xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f078xx.s new file mode 100644 index 0000000..d9b9ed2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f078xx.s @@ -0,0 +1,308 @@ +;******************************************************************************* +;* File Name : startup_stm32f078xx.s +;* Author : MCD Application Team +;* Description : STM32F078xx devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD VDDIO2_IRQHandler ; VDDIO2 Monitor through EXTI Line 31 + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TSC + DCD DMA1_Channel1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Channel2_3_IRQHandler ; DMA1 Channel 2 and Channel 3 + DCD DMA1_Channel4_5_6_7_IRQHandler ; DMA1 Channel 4 to Channel 7 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_4_IRQHandler ; USART3 and USART4 + DCD CEC_CAN_IRQHandler ; CEC and CAN + DCD USB_IRQHandler ; USB + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK VDDIO2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +VDDIO2_IRQHandler + B VDDIO2_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Channel1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel1_IRQHandler + B DMA1_Channel1_IRQHandler + + PUBWEAK DMA1_Channel2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel2_3_IRQHandler + B DMA1_Channel2_3_IRQHandler + + PUBWEAK DMA1_Channel4_5_6_7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Channel4_5_6_7_IRQHandler + B DMA1_Channel4_5_6_7_IRQHandler + + PUBWEAK ADC1_COMP_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_COMP_IRQHandler + B ADC1_COMP_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_DAC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_DAC_IRQHandler + B TIM6_DAC_IRQHandler + + PUBWEAK TIM7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM7_IRQHandler + B TIM7_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USART3_4_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART3_4_IRQHandler + B USART3_4_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + PUBWEAK USB_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USB_IRQHandler + B USB_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f091xc.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f091xc.s new file mode 100644 index 0000000..f7dc0b3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f091xc.s @@ -0,0 +1,302 @@ +;******************************************************************************* +;* File Name : startup_stm32f091xc.s +;* Author : MCD Application Team +;* Description : STM32F091xc/STM32F098xc devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD PVD_VDDIO2_IRQHandler ; PVD and VDDIO2 through EXTI Line detect + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Ch1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler ; DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 + DCD DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler ; DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_8_IRQHandler ; USART3, USART4, USART5, USART6, USART7, USART8 + DCD CEC_CAN_IRQHandler ; CEC and CAN + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK PVD_VDDIO2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +PVD_VDDIO2_IRQHandler + B PVD_VDDIO2_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Ch1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Ch1_IRQHandler + B DMA1_Ch1_IRQHandler + + PUBWEAK DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + B DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + + PUBWEAK DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + B DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + + PUBWEAK ADC1_COMP_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_COMP_IRQHandler + B ADC1_COMP_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_DAC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_DAC_IRQHandler + B TIM6_DAC_IRQHandler + + PUBWEAK TIM7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM7_IRQHandler + B TIM7_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USART3_8_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART3_8_IRQHandler + B USART3_8_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f098xx.s b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f098xx.s new file mode 100644 index 0000000..4d29787 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/iar/startup_stm32f098xx.s @@ -0,0 +1,302 @@ +;******************************************************************************* +;* File Name : startup_stm32f098xx.s +;* Author : MCD Application Team +;* Description : STM32F098xx devices vector table for EWARM toolchain. +;* This module performs: +;* - Set the initial SP +;* - Set the initial PC == __iar_program_start, +;* - Set the vector table entries with the exceptions ISR +;* address, +;* - Branches to main in the C library (which eventually +;* calls main()). +;* After Reset the Cortex-M0 processor is in Thread mode, +;* priority is Privileged, and the Stack is set to Main. +;******************************************************************************* +;* @attention +;* +;*

© Copyright (c) 2016 STMicroelectronics. +;* All rights reserved.

+;* +;* This software component is licensed by ST under BSD 3-Clause license, +;* the "License"; You may not use this file except in compliance with the +;* License. You may obtain a copy of the License at: +;* opensource.org/licenses/BSD-3-Clause +;* +;******************************************************************************* +; +; +; The modules in this file are included in the libraries, and may be replaced +; by any user-defined modules that define the PUBLIC symbol _program_start or +; a user defined start symbol. +; To override the cstartup defined in the library, simply add your modified +; version to the workbench project. +; +; The vector table is normally located at address 0. +; When debugging in RAM, it can be located in RAM, aligned to at least 2^6. +; The name "__vector_table" has special meaning for C-SPY: +; it is where the SP start value is found, and the NVIC vector +; table register (VTOR) is initialized to this address if != 0. +; +; Cortex-M version +; + + MODULE ?cstartup + + ;; Forward declaration of sections. + SECTION CSTACK:DATA:NOROOT(3) + + SECTION .intvec:CODE:NOROOT(2) + + EXTERN __iar_program_start + EXTERN SystemInit + PUBLIC __vector_table + + DATA +__vector_table + DCD sfe(CSTACK) + DCD Reset_Handler ; Reset Handler + + DCD NMI_Handler ; NMI Handler + DCD HardFault_Handler ; Hard Fault Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD SVC_Handler ; SVCall Handler + DCD 0 ; Reserved + DCD 0 ; Reserved + DCD PendSV_Handler ; PendSV Handler + DCD SysTick_Handler ; SysTick Handler + + ; External Interrupts + DCD WWDG_IRQHandler ; Window Watchdog + DCD VDDIO2_IRQHandler ; VDDIO2 Monitor through EXTI Line 31 + DCD RTC_IRQHandler ; RTC through EXTI Line + DCD FLASH_IRQHandler ; FLASH + DCD RCC_CRS_IRQHandler ; RCC and CRS + DCD EXTI0_1_IRQHandler ; EXTI Line 0 and 1 + DCD EXTI2_3_IRQHandler ; EXTI Line 2 and 3 + DCD EXTI4_15_IRQHandler ; EXTI Line 4 to 15 + DCD TSC_IRQHandler ; TS + DCD DMA1_Ch1_IRQHandler ; DMA1 Channel 1 + DCD DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler ; DMA1 Channel 2 and 3 & DMA2 Channel 1 and 2 + DCD DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler ; DMA1 Channel 4 to 7 & DMA2 Channel 3 to 5 + DCD ADC1_COMP_IRQHandler ; ADC1, COMP1 and COMP2 + DCD TIM1_BRK_UP_TRG_COM_IRQHandler ; TIM1 Break, Update, Trigger and Commutation + DCD TIM1_CC_IRQHandler ; TIM1 Capture Compare + DCD TIM2_IRQHandler ; TIM2 + DCD TIM3_IRQHandler ; TIM3 + DCD TIM6_DAC_IRQHandler ; TIM6 and DAC + DCD TIM7_IRQHandler ; TIM7 + DCD TIM14_IRQHandler ; TIM14 + DCD TIM15_IRQHandler ; TIM15 + DCD TIM16_IRQHandler ; TIM16 + DCD TIM17_IRQHandler ; TIM17 + DCD I2C1_IRQHandler ; I2C1 + DCD I2C2_IRQHandler ; I2C2 + DCD SPI1_IRQHandler ; SPI1 + DCD SPI2_IRQHandler ; SPI2 + DCD USART1_IRQHandler ; USART1 + DCD USART2_IRQHandler ; USART2 + DCD USART3_8_IRQHandler ; USART3, USART4, USART5, USART6, USART7, USART8 + DCD CEC_CAN_IRQHandler ; CEC and CAN + +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; +;; +;; Default interrupt handlers. +;; + THUMB + + PUBWEAK Reset_Handler + SECTION .text:CODE:NOROOT:REORDER(2) +Reset_Handler + LDR R0, =SystemInit + BLX R0 + LDR R0, =__iar_program_start + BX R0 + + PUBWEAK NMI_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +NMI_Handler + B NMI_Handler + + PUBWEAK HardFault_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +HardFault_Handler + B HardFault_Handler + + PUBWEAK SVC_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SVC_Handler + B SVC_Handler + + PUBWEAK PendSV_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +PendSV_Handler + B PendSV_Handler + + PUBWEAK SysTick_Handler + SECTION .text:CODE:NOROOT:REORDER(1) +SysTick_Handler + B SysTick_Handler + + PUBWEAK WWDG_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +WWDG_IRQHandler + B WWDG_IRQHandler + + PUBWEAK VDDIO2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +VDDIO2_IRQHandler + B VDDIO2_IRQHandler + + PUBWEAK RTC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RTC_IRQHandler + B RTC_IRQHandler + + PUBWEAK FLASH_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +FLASH_IRQHandler + B FLASH_IRQHandler + + PUBWEAK RCC_CRS_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +RCC_CRS_IRQHandler + B RCC_CRS_IRQHandler + + PUBWEAK EXTI0_1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI0_1_IRQHandler + B EXTI0_1_IRQHandler + + PUBWEAK EXTI2_3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI2_3_IRQHandler + B EXTI2_3_IRQHandler + + PUBWEAK EXTI4_15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +EXTI4_15_IRQHandler + B EXTI4_15_IRQHandler + + PUBWEAK TSC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TSC_IRQHandler + B TSC_IRQHandler + + PUBWEAK DMA1_Ch1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Ch1_IRQHandler + B DMA1_Ch1_IRQHandler + + PUBWEAK DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + B DMA1_Ch2_3_DMA2_Ch1_2_IRQHandler + + PUBWEAK DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + B DMA1_Ch4_7_DMA2_Ch3_5_IRQHandler + + PUBWEAK ADC1_COMP_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +ADC1_COMP_IRQHandler + B ADC1_COMP_IRQHandler + + PUBWEAK TIM1_BRK_UP_TRG_COM_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_BRK_UP_TRG_COM_IRQHandler + B TIM1_BRK_UP_TRG_COM_IRQHandler + + PUBWEAK TIM1_CC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM1_CC_IRQHandler + B TIM1_CC_IRQHandler + + PUBWEAK TIM2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM2_IRQHandler + B TIM2_IRQHandler + + PUBWEAK TIM3_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM3_IRQHandler + B TIM3_IRQHandler + + PUBWEAK TIM6_DAC_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM6_DAC_IRQHandler + B TIM6_DAC_IRQHandler + + PUBWEAK TIM7_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM7_IRQHandler + B TIM7_IRQHandler + + PUBWEAK TIM14_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM14_IRQHandler + B TIM14_IRQHandler + + PUBWEAK TIM15_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM15_IRQHandler + B TIM15_IRQHandler + + PUBWEAK TIM16_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM16_IRQHandler + B TIM16_IRQHandler + + PUBWEAK TIM17_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +TIM17_IRQHandler + B TIM17_IRQHandler + + PUBWEAK I2C1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C1_IRQHandler + B I2C1_IRQHandler + + PUBWEAK I2C2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +I2C2_IRQHandler + B I2C2_IRQHandler + + PUBWEAK SPI1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI1_IRQHandler + B SPI1_IRQHandler + + PUBWEAK SPI2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +SPI2_IRQHandler + B SPI2_IRQHandler + + PUBWEAK USART1_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART1_IRQHandler + B USART1_IRQHandler + + PUBWEAK USART2_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART2_IRQHandler + B USART2_IRQHandler + + PUBWEAK USART3_8_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +USART3_8_IRQHandler + B USART3_8_IRQHandler + + PUBWEAK CEC_CAN_IRQHandler + SECTION .text:CODE:NOROOT:REORDER(1) +CEC_CAN_IRQHandler + B CEC_CAN_IRQHandler + + END +;************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE***** diff --git a/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/system_stm32f0xx.c b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/system_stm32f0xx.c new file mode 100644 index 0000000..1b0fbe5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Device/ST/STM32F0xx/Source/Templates/system_stm32f0xx.c @@ -0,0 +1,247 @@ +/** + ****************************************************************************** + * @file system_stm32f0xx.c + * @author MCD Application Team + * @brief CMSIS Cortex-M0 Device Peripheral Access Layer System Source File. + * + * 1. This file provides two functions and one global variable to be called from + * user application: + * - SystemInit(): This function is called at startup just after reset and + * before branch to main program. This call is made inside + * the "startup_stm32f0xx.s" file. + * + * - SystemCoreClock variable: Contains the core clock (HCLK), it can be used + * by the user application to setup the SysTick + * timer or configure other parameters. + * + * - SystemCoreClockUpdate(): Updates the variable SystemCoreClock and must + * be called whenever the core clock is changed + * during program execution. + * + * + ****************************************************************************** + * @attention + * + *

© Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

+ * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f0xx_system + * @{ + */ + +/** @addtogroup STM32F0xx_System_Private_Includes + * @{ + */ + +#include "stm32f0xx.h" + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_TypesDefinitions + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Defines + * @{ + */ +#if !defined (HSE_VALUE) + #define HSE_VALUE ((uint32_t)8000000) /*!< Default value of the External oscillator in Hz. + This value can be provided and adapted by the user application. */ +#endif /* HSE_VALUE */ + +#if !defined (HSI_VALUE) + #define HSI_VALUE ((uint32_t)8000000) /*!< Default value of the Internal oscillator in Hz. + This value can be provided and adapted by the user application. */ +#endif /* HSI_VALUE */ + +#if !defined (HSI48_VALUE) +#define HSI48_VALUE ((uint32_t)48000000) /*!< Default value of the HSI48 Internal oscillator in Hz. + This value can be provided and adapted by the user application. */ +#endif /* HSI48_VALUE */ +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Macros + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Variables + * @{ + */ + /* This variable is updated in three ways: + 1) by calling CMSIS function SystemCoreClockUpdate() + 2) by calling HAL API function HAL_RCC_GetHCLKFreq() + 3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency + Note: If you use this function to configure the system clock; then there + is no need to call the 2 first functions listed above, since SystemCoreClock + variable is updated automatically. + */ +uint32_t SystemCoreClock = 8000000; + +const uint8_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}; +const uint8_t APBPrescTable[8] = {0, 0, 0, 0, 1, 2, 3, 4}; + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_FunctionPrototypes + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Functions + * @{ + */ + +/** + * @brief Setup the microcontroller system + * @param None + * @retval None + */ +void SystemInit(void) +{ + /* NOTE :SystemInit(): This function is called at startup just after reset and + before branch to main program. This call is made inside + the "startup_stm32f0xx.s" file. + User can setups the default system clock (System clock source, PLL Multiplier + and Divider factors, AHB/APBx prescalers and Flash settings). + */ +} + +/** + * @brief Update SystemCoreClock variable according to Clock Register Values. + * The SystemCoreClock variable contains the core clock (HCLK), it can + * be used by the user application to setup the SysTick timer or configure + * other parameters. + * + * @note Each time the core clock (HCLK) changes, this function must be called + * to update SystemCoreClock variable value. Otherwise, any configuration + * based on this variable will be incorrect. + * + * @note - The system frequency computed by this function is not the real + * frequency in the chip. It is calculated based on the predefined + * constant and the selected clock source: + * + * - If SYSCLK source is HSI, SystemCoreClock will contain the HSI_VALUE(*) + * + * - If SYSCLK source is HSE, SystemCoreClock will contain the HSE_VALUE(**) + * + * - If SYSCLK source is PLL, SystemCoreClock will contain the HSE_VALUE(**) + * or HSI_VALUE(*) multiplied/divided by the PLL factors. + * + * (*) HSI_VALUE is a constant defined in stm32f0xx_hal_conf.h file (default value + * 8 MHz) but the real value may vary depending on the variations + * in voltage and temperature. + * + * (**) HSE_VALUE is a constant defined in stm32f0xx_hal_conf.h file (its value + * depends on the application requirements), user has to ensure that HSE_VALUE + * is same as the real frequency of the crystal used. Otherwise, this function + * may have wrong result. + * + * - The result of this function could be not correct when using fractional + * value for HSE crystal. + * + * @param None + * @retval None + */ +void SystemCoreClockUpdate (void) +{ + uint32_t tmp = 0, pllmull = 0, pllsource = 0, predivfactor = 0; + + /* Get SYSCLK source -------------------------------------------------------*/ + tmp = RCC->CFGR & RCC_CFGR_SWS; + + switch (tmp) + { + case RCC_CFGR_SWS_HSI: /* HSI used as system clock */ + SystemCoreClock = HSI_VALUE; + break; + case RCC_CFGR_SWS_HSE: /* HSE used as system clock */ + SystemCoreClock = HSE_VALUE; + break; + case RCC_CFGR_SWS_PLL: /* PLL used as system clock */ + /* Get PLL clock source and multiplication factor ----------------------*/ + pllmull = RCC->CFGR & RCC_CFGR_PLLMUL; + pllsource = RCC->CFGR & RCC_CFGR_PLLSRC; + pllmull = ( pllmull >> 18) + 2; + predivfactor = (RCC->CFGR2 & RCC_CFGR2_PREDIV) + 1; + + if (pllsource == RCC_CFGR_PLLSRC_HSE_PREDIV) + { + /* HSE used as PLL clock source : SystemCoreClock = HSE/PREDIV * PLLMUL */ + SystemCoreClock = (HSE_VALUE/predivfactor) * pllmull; + } +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) + else if (pllsource == RCC_CFGR_PLLSRC_HSI48_PREDIV) + { + /* HSI48 used as PLL clock source : SystemCoreClock = HSI48/PREDIV * PLLMUL */ + SystemCoreClock = (HSI48_VALUE/predivfactor) * pllmull; + } +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || STM32F078xx || STM32F091xC || STM32F098xx */ + else + { +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6) \ + || defined(STM32F078xx) || defined(STM32F071xB) || defined(STM32F072xB) \ + || defined(STM32F070xB) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + /* HSI used as PLL clock source : SystemCoreClock = HSI/PREDIV * PLLMUL */ + SystemCoreClock = (HSI_VALUE/predivfactor) * pllmull; +#else + /* HSI used as PLL clock source : SystemCoreClock = HSI/2 * PLLMUL */ + SystemCoreClock = (HSI_VALUE >> 1) * pllmull; +#endif /* STM32F042x6 || STM32F048xx || STM32F070x6 || + STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || + STM32F091xC || STM32F098xx || STM32F030xC */ + } + break; + default: /* HSI used as system clock */ + SystemCoreClock = HSI_VALUE; + break; + } + /* Compute HCLK clock frequency ----------------*/ + /* Get HCLK prescaler */ + tmp = AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> 4)]; + /* HCLK clock frequency */ + SystemCoreClock >>= tmp; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/CMSIS/Include/cmsis_armcc.h b/Chapter04/bare/platform/CMSIS/Include/cmsis_armcc.h new file mode 100644 index 0000000..7d751fb --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/cmsis_armcc.h @@ -0,0 +1,865 @@ +/**************************************************************************//** + * @file cmsis_armcc.h + * @brief CMSIS compiler ARMCC (Arm Compiler 5) header file + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_ARMCC_H +#define __CMSIS_ARMCC_H + + +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 400677) + #error "Please use Arm Compiler Toolchain V4.0.677 or later!" +#endif + +/* CMSIS compiler control architecture macros */ +#if ((defined (__TARGET_ARCH_6_M ) && (__TARGET_ARCH_6_M == 1)) || \ + (defined (__TARGET_ARCH_6S_M ) && (__TARGET_ARCH_6S_M == 1)) ) + #define __ARM_ARCH_6M__ 1 +#endif + +#if (defined (__TARGET_ARCH_7_M ) && (__TARGET_ARCH_7_M == 1)) + #define __ARM_ARCH_7M__ 1 +#endif + +#if (defined (__TARGET_ARCH_7E_M) && (__TARGET_ARCH_7E_M == 1)) + #define __ARM_ARCH_7EM__ 1 +#endif + + /* __ARM_ARCH_8M_BASE__ not applicable */ + /* __ARM_ARCH_8M_MAIN__ not applicable */ + + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE __inline +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static __inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE static __forceinline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __declspec(noreturn) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed)) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT __packed struct +#endif +#ifndef __PACKED_UNION + #define __PACKED_UNION __packed union +#endif +#ifndef __UNALIGNED_UINT32 /* deprecated */ + #define __UNALIGNED_UINT32(x) (*((__packed uint32_t *)(x))) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #define __UNALIGNED_UINT16_WRITE(addr, val) ((*((__packed uint16_t *)(addr))) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #define __UNALIGNED_UINT16_READ(addr) (*((const __packed uint16_t *)(addr))) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #define __UNALIGNED_UINT32_WRITE(addr, val) ((*((__packed uint32_t *)(addr))) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #define __UNALIGNED_UINT32_READ(addr) (*((const __packed uint32_t *)(addr))) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + +/* ########################### Core Function Access ########################### */ +/** \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions + @{ + */ + +/** + \brief Enable IRQ Interrupts + \details Enables IRQ interrupts by clearing the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __enable_irq(); */ + + +/** + \brief Disable IRQ Interrupts + \details Disables IRQ interrupts by setting the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __disable_irq(); */ + +/** + \brief Get Control Register + \details Returns the content of the Control Register. + \return Control Register value + */ +__STATIC_INLINE uint32_t __get_CONTROL(void) +{ + register uint32_t __regControl __ASM("control"); + return(__regControl); +} + + +/** + \brief Set Control Register + \details Writes the given value to the Control Register. + \param [in] control Control Register value to set + */ +__STATIC_INLINE void __set_CONTROL(uint32_t control) +{ + register uint32_t __regControl __ASM("control"); + __regControl = control; +} + + +/** + \brief Get IPSR Register + \details Returns the content of the IPSR Register. + \return IPSR Register value + */ +__STATIC_INLINE uint32_t __get_IPSR(void) +{ + register uint32_t __regIPSR __ASM("ipsr"); + return(__regIPSR); +} + + +/** + \brief Get APSR Register + \details Returns the content of the APSR Register. + \return APSR Register value + */ +__STATIC_INLINE uint32_t __get_APSR(void) +{ + register uint32_t __regAPSR __ASM("apsr"); + return(__regAPSR); +} + + +/** + \brief Get xPSR Register + \details Returns the content of the xPSR Register. + \return xPSR Register value + */ +__STATIC_INLINE uint32_t __get_xPSR(void) +{ + register uint32_t __regXPSR __ASM("xpsr"); + return(__regXPSR); +} + + +/** + \brief Get Process Stack Pointer + \details Returns the current value of the Process Stack Pointer (PSP). + \return PSP Register value + */ +__STATIC_INLINE uint32_t __get_PSP(void) +{ + register uint32_t __regProcessStackPointer __ASM("psp"); + return(__regProcessStackPointer); +} + + +/** + \brief Set Process Stack Pointer + \details Assigns the given value to the Process Stack Pointer (PSP). + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_INLINE void __set_PSP(uint32_t topOfProcStack) +{ + register uint32_t __regProcessStackPointer __ASM("psp"); + __regProcessStackPointer = topOfProcStack; +} + + +/** + \brief Get Main Stack Pointer + \details Returns the current value of the Main Stack Pointer (MSP). + \return MSP Register value + */ +__STATIC_INLINE uint32_t __get_MSP(void) +{ + register uint32_t __regMainStackPointer __ASM("msp"); + return(__regMainStackPointer); +} + + +/** + \brief Set Main Stack Pointer + \details Assigns the given value to the Main Stack Pointer (MSP). + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_INLINE void __set_MSP(uint32_t topOfMainStack) +{ + register uint32_t __regMainStackPointer __ASM("msp"); + __regMainStackPointer = topOfMainStack; +} + + +/** + \brief Get Priority Mask + \details Returns the current state of the priority mask bit from the Priority Mask Register. + \return Priority Mask value + */ +__STATIC_INLINE uint32_t __get_PRIMASK(void) +{ + register uint32_t __regPriMask __ASM("primask"); + return(__regPriMask); +} + + +/** + \brief Set Priority Mask + \details Assigns the given value to the Priority Mask Register. + \param [in] priMask Priority Mask + */ +__STATIC_INLINE void __set_PRIMASK(uint32_t priMask) +{ + register uint32_t __regPriMask __ASM("primask"); + __regPriMask = (priMask); +} + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + +/** + \brief Enable FIQ + \details Enables FIQ interrupts by clearing the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __enable_fault_irq __enable_fiq + + +/** + \brief Disable FIQ + \details Disables FIQ interrupts by setting the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __disable_fault_irq __disable_fiq + + +/** + \brief Get Base Priority + \details Returns the current value of the Base Priority register. + \return Base Priority register value + */ +__STATIC_INLINE uint32_t __get_BASEPRI(void) +{ + register uint32_t __regBasePri __ASM("basepri"); + return(__regBasePri); +} + + +/** + \brief Set Base Priority + \details Assigns the given value to the Base Priority register. + \param [in] basePri Base Priority value to set + */ +__STATIC_INLINE void __set_BASEPRI(uint32_t basePri) +{ + register uint32_t __regBasePri __ASM("basepri"); + __regBasePri = (basePri & 0xFFU); +} + + +/** + \brief Set Base Priority with condition + \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, + or the new value increases the BASEPRI priority level. + \param [in] basePri Base Priority value to set + */ +__STATIC_INLINE void __set_BASEPRI_MAX(uint32_t basePri) +{ + register uint32_t __regBasePriMax __ASM("basepri_max"); + __regBasePriMax = (basePri & 0xFFU); +} + + +/** + \brief Get Fault Mask + \details Returns the current value of the Fault Mask register. + \return Fault Mask register value + */ +__STATIC_INLINE uint32_t __get_FAULTMASK(void) +{ + register uint32_t __regFaultMask __ASM("faultmask"); + return(__regFaultMask); +} + + +/** + \brief Set Fault Mask + \details Assigns the given value to the Fault Mask register. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_INLINE void __set_FAULTMASK(uint32_t faultMask) +{ + register uint32_t __regFaultMask __ASM("faultmask"); + __regFaultMask = (faultMask & (uint32_t)1U); +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ + + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value + */ +__STATIC_INLINE uint32_t __get_FPSCR(void) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + register uint32_t __regfpscr __ASM("fpscr"); + return(__regfpscr); +#else + return(0U); +#endif +} + + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set + */ +__STATIC_INLINE void __set_FPSCR(uint32_t fpscr) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + register uint32_t __regfpscr __ASM("fpscr"); + __regfpscr = (fpscr); +#else + (void)fpscr; +#endif +} + + +/*@} end of CMSIS_Core_RegAccFunctions */ + + +/* ########################## Core Instruction Access ######################### */ +/** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface + Access to dedicated instructions + @{ +*/ + +/** + \brief No Operation + \details No Operation does nothing. This instruction can be used for code alignment purposes. + */ +#define __NOP __nop + + +/** + \brief Wait For Interrupt + \details Wait For Interrupt is a hint instruction that suspends execution until one of a number of events occurs. + */ +#define __WFI __wfi + + +/** + \brief Wait For Event + \details Wait For Event is a hint instruction that permits the processor to enter + a low-power state until one of a number of events occurs. + */ +#define __WFE __wfe + + +/** + \brief Send Event + \details Send Event is a hint instruction. It causes an event to be signaled to the CPU. + */ +#define __SEV __sev + + +/** + \brief Instruction Synchronization Barrier + \details Instruction Synchronization Barrier flushes the pipeline in the processor, + so that all instructions following the ISB are fetched from cache or memory, + after the instruction has been completed. + */ +#define __ISB() do {\ + __schedule_barrier();\ + __isb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Synchronization Barrier + \details Acts as a special kind of Data Memory Barrier. + It completes when all explicit memory accesses before this instruction complete. + */ +#define __DSB() do {\ + __schedule_barrier();\ + __dsb(0xF);\ + __schedule_barrier();\ + } while (0U) + +/** + \brief Data Memory Barrier + \details Ensures the apparent order of the explicit memory operations before + and after the instruction, without ensuring their completion. + */ +#define __DMB() do {\ + __schedule_barrier();\ + __dmb(0xF);\ + __schedule_barrier();\ + } while (0U) + + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV __rev + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".rev16_text"))) __STATIC_INLINE __ASM uint32_t __REV16(uint32_t value) +{ + rev16 r0, r0 + bx lr +} +#endif + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".revsh_text"))) __STATIC_INLINE __ASM int16_t __REVSH(int16_t value) +{ + revsh r0, r0 + bx lr +} +#endif + + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +#define __ROR __ror + + +/** + \brief Breakpoint + \details Causes the processor to enter Debug state. + Debug tools can use this to investigate system state when the instruction at a particular address is reached. + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __breakpoint(value) + + +/** + \brief Reverse bit order of value + \details Reverses the bit order of the given value. + \param [in] value Value to reverse + \return Reversed value + */ +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + #define __RBIT __rbit +#else +__attribute__((always_inline)) __STATIC_INLINE uint32_t __RBIT(uint32_t value) +{ + uint32_t result; + uint32_t s = (4U /*sizeof(v)*/ * 8U) - 1U; /* extra shift needed at end */ + + result = value; /* r will be reversed bits of v; first get LSB of v */ + for (value >>= 1U; value != 0U; value >>= 1U) + { + result <<= 1U; + result |= value & 1U; + s--; + } + result <<= s; /* shift when v's highest bits are zero */ + return result; +} +#endif + + +/** + \brief Count leading zeros + \details Counts the number of leading zeros of a data value. + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ __clz + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXB(ptr) ((uint8_t ) __ldrex(ptr)) +#else + #define __LDREXB(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint8_t ) __ldrex(ptr)) _Pragma("pop") +#endif + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXH(ptr) ((uint16_t) __ldrex(ptr)) +#else + #define __LDREXH(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint16_t) __ldrex(ptr)) _Pragma("pop") +#endif + + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __LDREXW(ptr) ((uint32_t ) __ldrex(ptr)) +#else + #define __LDREXW(ptr) _Pragma("push") _Pragma("diag_suppress 3731") ((uint32_t ) __ldrex(ptr)) _Pragma("pop") +#endif + + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXB(value, ptr) __strex(value, ptr) +#else + #define __STREXB(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXH(value, ptr) __strex(value, ptr) +#else + #define __STREXH(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#if defined(__ARMCC_VERSION) && (__ARMCC_VERSION < 5060020) + #define __STREXW(value, ptr) __strex(value, ptr) +#else + #define __STREXW(value, ptr) _Pragma("push") _Pragma("diag_suppress 3731") __strex(value, ptr) _Pragma("pop") +#endif + + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +#define __CLREX __clrex + + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT __ssat + + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT __usat + + +/** + \brief Rotate Right with Extend (32 bit) + \details Moves each bit of a bitstring right by one bit. + The carry input is shifted in at the left end of the bitstring. + \param [in] value Value to rotate + \return Rotated value + */ +#ifndef __NO_EMBEDDED_ASM +__attribute__((section(".rrx_text"))) __STATIC_INLINE __ASM uint32_t __RRX(uint32_t value) +{ + rrx r0, r0 + bx lr +} +#endif + + +/** + \brief LDRT Unprivileged (8 bit) + \details Executes a Unprivileged LDRT instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#define __LDRBT(ptr) ((uint8_t ) __ldrt(ptr)) + + +/** + \brief LDRT Unprivileged (16 bit) + \details Executes a Unprivileged LDRT instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#define __LDRHT(ptr) ((uint16_t) __ldrt(ptr)) + + +/** + \brief LDRT Unprivileged (32 bit) + \details Executes a Unprivileged LDRT instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#define __LDRT(ptr) ((uint32_t ) __ldrt(ptr)) + + +/** + \brief STRT Unprivileged (8 bit) + \details Executes a Unprivileged STRT instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +#define __STRBT(value, ptr) __strt(value, ptr) + + +/** + \brief STRT Unprivileged (16 bit) + \details Executes a Unprivileged STRT instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +#define __STRHT(value, ptr) __strt(value, ptr) + + +/** + \brief STRT Unprivileged (32 bit) + \details Executes a Unprivileged STRT instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +#define __STRT(value, ptr) __strt(value, ptr) + +#else /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +__attribute__((always_inline)) __STATIC_INLINE int32_t __SSAT(int32_t val, uint32_t sat) +{ + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; +} + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +__attribute__((always_inline)) __STATIC_INLINE uint32_t __USAT(int32_t val, uint32_t sat) +{ + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ + +/*@}*/ /* end of group CMSIS_Core_InstructionInterface */ + + +/* ################### Compiler specific Intrinsics ########################### */ +/** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics + Access to dedicated SIMD instructions + @{ +*/ + +#if ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) + +#define __SADD8 __sadd8 +#define __QADD8 __qadd8 +#define __SHADD8 __shadd8 +#define __UADD8 __uadd8 +#define __UQADD8 __uqadd8 +#define __UHADD8 __uhadd8 +#define __SSUB8 __ssub8 +#define __QSUB8 __qsub8 +#define __SHSUB8 __shsub8 +#define __USUB8 __usub8 +#define __UQSUB8 __uqsub8 +#define __UHSUB8 __uhsub8 +#define __SADD16 __sadd16 +#define __QADD16 __qadd16 +#define __SHADD16 __shadd16 +#define __UADD16 __uadd16 +#define __UQADD16 __uqadd16 +#define __UHADD16 __uhadd16 +#define __SSUB16 __ssub16 +#define __QSUB16 __qsub16 +#define __SHSUB16 __shsub16 +#define __USUB16 __usub16 +#define __UQSUB16 __uqsub16 +#define __UHSUB16 __uhsub16 +#define __SASX __sasx +#define __QASX __qasx +#define __SHASX __shasx +#define __UASX __uasx +#define __UQASX __uqasx +#define __UHASX __uhasx +#define __SSAX __ssax +#define __QSAX __qsax +#define __SHSAX __shsax +#define __USAX __usax +#define __UQSAX __uqsax +#define __UHSAX __uhsax +#define __USAD8 __usad8 +#define __USADA8 __usada8 +#define __SSAT16 __ssat16 +#define __USAT16 __usat16 +#define __UXTB16 __uxtb16 +#define __UXTAB16 __uxtab16 +#define __SXTB16 __sxtb16 +#define __SXTAB16 __sxtab16 +#define __SMUAD __smuad +#define __SMUADX __smuadx +#define __SMLAD __smlad +#define __SMLADX __smladx +#define __SMLALD __smlald +#define __SMLALDX __smlaldx +#define __SMUSD __smusd +#define __SMUSDX __smusdx +#define __SMLSD __smlsd +#define __SMLSDX __smlsdx +#define __SMLSLD __smlsld +#define __SMLSLDX __smlsldx +#define __SEL __sel +#define __QADD __qadd +#define __QSUB __qsub + +#define __PKHBT(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0x0000FFFFUL) | \ + ((((uint32_t)(ARG2)) << (ARG3)) & 0xFFFF0000UL) ) + +#define __PKHTB(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0xFFFF0000UL) | \ + ((((uint32_t)(ARG2)) >> (ARG3)) & 0x0000FFFFUL) ) + +#define __SMMLA(ARG1,ARG2,ARG3) ( (int32_t)((((int64_t)(ARG1) * (ARG2)) + \ + ((int64_t)(ARG3) << 32U) ) >> 32U)) + +#endif /* ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1)) ) */ +/*@} end of group CMSIS_SIMD_intrinsics */ + + +#endif /* __CMSIS_ARMCC_H */ diff --git a/Chapter04/bare/platform/CMSIS/Include/cmsis_armclang.h b/Chapter04/bare/platform/CMSIS/Include/cmsis_armclang.h new file mode 100644 index 0000000..d8031b0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/cmsis_armclang.h @@ -0,0 +1,1869 @@ +/**************************************************************************//** + * @file cmsis_armclang.h + * @brief CMSIS compiler armclang (Arm Compiler 6) header file + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/*lint -esym(9058, IRQn)*/ /* disable MISRA 2012 Rule 2.4 for IRQn */ + +#ifndef __CMSIS_ARMCLANG_H +#define __CMSIS_ARMCLANG_H + +#pragma clang system_header /* treat file as system include file */ + +#ifndef __ARM_COMPAT_H +#include /* Compatibility header for Arm Compiler 5 intrinsics */ +#endif + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE __inline +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static __inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __attribute__((always_inline)) static __inline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __attribute__((__noreturn__)) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_UNION + #define __PACKED_UNION union __attribute__((packed, aligned(1))) +#endif +#ifndef __UNALIGNED_UINT32 /* deprecated */ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32 */ + struct __attribute__((packed)) T_UINT32 { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_WRITE */ + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT16_READ)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT16_READ */ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32_WRITE)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32_WRITE */ + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #pragma clang diagnostic push + #pragma clang diagnostic ignored "-Wpacked" +/*lint -esym(9058, T_UINT32_READ)*/ /* disable MISRA 2012 Rule 2.4 for T_UINT32_READ */ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #pragma clang diagnostic pop + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + + +/* ########################### Core Function Access ########################### */ +/** \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions + @{ + */ + +/** + \brief Enable IRQ Interrupts + \details Enables IRQ interrupts by clearing the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __enable_irq(); see arm_compat.h */ + + +/** + \brief Disable IRQ Interrupts + \details Disables IRQ interrupts by setting the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +/* intrinsic void __disable_irq(); see arm_compat.h */ + + +/** + \brief Get Control Register + \details Returns the content of the Control Register. + \return Control Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CONTROL(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Control Register (non-secure) + \details Returns the content of the non-secure Control Register when in secure mode. + \return non-secure Control Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_CONTROL_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Control Register + \details Writes the given value to the Control Register. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __set_CONTROL(uint32_t control) +{ + __ASM volatile ("MSR control, %0" : : "r" (control) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Control Register (non-secure) + \details Writes the given value to the non-secure Control Register when in secure state. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) +{ + __ASM volatile ("MSR control_ns, %0" : : "r" (control) : "memory"); +} +#endif + + +/** + \brief Get IPSR Register + \details Returns the content of the IPSR Register. + \return IPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_IPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, ipsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get APSR Register + \details Returns the content of the APSR Register. + \return APSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_APSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, apsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get xPSR Register + \details Returns the content of the xPSR Register. + \return xPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_xPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, xpsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get Process Stack Pointer + \details Returns the current value of the Process Stack Pointer (PSP). + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer (non-secure) + \details Returns the current value of the non-secure Process Stack Pointer (PSP) when in secure state. + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Process Stack Pointer + \details Assigns the given value to the Process Stack Pointer (PSP). + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_PSP(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp, %0" : : "r" (topOfProcStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Process Stack Pointer (PSP) when in secure state. + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSP_NS(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp_ns, %0" : : "r" (topOfProcStack) : ); +} +#endif + + +/** + \brief Get Main Stack Pointer + \details Returns the current value of the Main Stack Pointer (MSP). + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer (non-secure) + \details Returns the current value of the non-secure Main Stack Pointer (MSP) when in secure state. + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Main Stack Pointer + \details Assigns the given value to the Main Stack Pointer (MSP). + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_MSP(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp, %0" : : "r" (topOfMainStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Main Stack Pointer (MSP) when in secure state. + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSP_NS(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp_ns, %0" : : "r" (topOfMainStack) : ); +} +#endif + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Stack Pointer (non-secure) + \details Returns the current value of the non-secure Stack Pointer (SP) when in secure state. + \return SP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_SP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, sp_ns" : "=r" (result) ); + return(result); +} + + +/** + \brief Set Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Stack Pointer (SP) when in secure state. + \param [in] topOfStack Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_SP_NS(uint32_t topOfStack) +{ + __ASM volatile ("MSR sp_ns, %0" : : "r" (topOfStack) : ); +} +#endif + + +/** + \brief Get Priority Mask + \details Returns the current state of the priority mask bit from the Priority Mask Register. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __get_PRIMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Priority Mask (non-secure) + \details Returns the current state of the non-secure priority mask bit from the Priority Mask Register when in secure state. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PRIMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Priority Mask + \details Assigns the given value to the Priority Mask Register. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __set_PRIMASK(uint32_t priMask) +{ + __ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Priority Mask (non-secure) + \details Assigns the given value to the non-secure Priority Mask Register when in secure state. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __TZ_set_PRIMASK_NS(uint32_t priMask) +{ + __ASM volatile ("MSR primask_ns, %0" : : "r" (priMask) : "memory"); +} +#endif + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) +/** + \brief Enable FIQ + \details Enables FIQ interrupts by clearing the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __enable_fault_irq __enable_fiq /* see arm_compat.h */ + + +/** + \brief Disable FIQ + \details Disables FIQ interrupts by setting the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +#define __disable_fault_irq __disable_fiq /* see arm_compat.h */ + + +/** + \brief Get Base Priority + \details Returns the current value of the Base Priority register. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __get_BASEPRI(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Base Priority (non-secure) + \details Returns the current value of the non-secure Base Priority register when in secure state. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_BASEPRI_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Base Priority + \details Assigns the given value to the Base Priority register. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI(uint32_t basePri) +{ + __ASM volatile ("MSR basepri, %0" : : "r" (basePri) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Base Priority (non-secure) + \details Assigns the given value to the non-secure Base Priority register when in secure state. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __TZ_set_BASEPRI_NS(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_ns, %0" : : "r" (basePri) : "memory"); +} +#endif + + +/** + \brief Set Base Priority with condition + \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, + or the new value increases the BASEPRI priority level. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI_MAX(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_max, %0" : : "r" (basePri) : "memory"); +} + + +/** + \brief Get Fault Mask + \details Returns the current value of the Fault Mask register. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __get_FAULTMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Fault Mask (non-secure) + \details Returns the current value of the non-secure Fault Mask register when in secure state. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_FAULTMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Fault Mask + \details Assigns the given value to the Fault Mask register. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __set_FAULTMASK(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask, %0" : : "r" (faultMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Fault Mask (non-secure) + \details Assigns the given value to the non-secure Fault Mask register when in secure state. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __TZ_set_FAULTMASK_NS(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask_ns, %0" : : "r" (faultMask) : "memory"); +} +#endif + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + +/** + \brief Get Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the Process Stack Pointer Limit (PSPLIM). + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim" : "=r" (result) ); + return result; +#endif +} + +#if (defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the Process Stack Pointer Limit (PSPLIM). + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_PSPLIM(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim, %0" : : "r" (ProcStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSPLIM_NS(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim_ns, %0\n" : : "r" (ProcStackPtrLimit)); +#endif +} +#endif + + +/** + \brief Get Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the Main Stack Pointer Limit (MSPLIM). + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim" : "=r" (result) ); + return result; +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the non-secure Main Stack Pointer Limit(MSPLIM) when in secure state. + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the Main Stack Pointer Limit (MSPLIM). + \param [in] MainStackPtrLimit Main Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_MSPLIM(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim, %0" : : "r" (MainStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the non-secure Main Stack Pointer Limit (MSPLIM) when in secure state. + \param [in] MainStackPtrLimit Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSPLIM_NS(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim_ns, %0" : : "r" (MainStackPtrLimit)); +#endif +} +#endif + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value + */ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#define __get_FPSCR (uint32_t)__builtin_arm_get_fpscr +#else +#define __get_FPSCR() ((uint32_t)0U) +#endif + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set + */ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#define __set_FPSCR __builtin_arm_set_fpscr +#else +#define __set_FPSCR(x) ((void)(x)) +#endif + + +/*@} end of CMSIS_Core_RegAccFunctions */ + + +/* ########################## Core Instruction Access ######################### */ +/** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface + Access to dedicated instructions + @{ +*/ + +/* Define macros for porting to both thumb1 and thumb2. + * For thumb1, use low register (r0-r7), specified by constraint "l" + * Otherwise, use general registers, specified by constraint "r" */ +#if defined (__thumb__) && !defined (__thumb2__) +#define __CMSIS_GCC_OUT_REG(r) "=l" (r) +#define __CMSIS_GCC_USE_REG(r) "l" (r) +#else +#define __CMSIS_GCC_OUT_REG(r) "=r" (r) +#define __CMSIS_GCC_USE_REG(r) "r" (r) +#endif + +/** + \brief No Operation + \details No Operation does nothing. This instruction can be used for code alignment purposes. + */ +#define __NOP __builtin_arm_nop + +/** + \brief Wait For Interrupt + \details Wait For Interrupt is a hint instruction that suspends execution until one of a number of events occurs. + */ +#define __WFI __builtin_arm_wfi + + +/** + \brief Wait For Event + \details Wait For Event is a hint instruction that permits the processor to enter + a low-power state until one of a number of events occurs. + */ +#define __WFE __builtin_arm_wfe + + +/** + \brief Send Event + \details Send Event is a hint instruction. It causes an event to be signaled to the CPU. + */ +#define __SEV __builtin_arm_sev + + +/** + \brief Instruction Synchronization Barrier + \details Instruction Synchronization Barrier flushes the pipeline in the processor, + so that all instructions following the ISB are fetched from cache or memory, + after the instruction has been completed. + */ +#define __ISB() __builtin_arm_isb(0xF); + +/** + \brief Data Synchronization Barrier + \details Acts as a special kind of Data Memory Barrier. + It completes when all explicit memory accesses before this instruction complete. + */ +#define __DSB() __builtin_arm_dsb(0xF); + + +/** + \brief Data Memory Barrier + \details Ensures the apparent order of the explicit memory operations before + and after the instruction, without ensuring their completion. + */ +#define __DMB() __builtin_arm_dmb(0xF); + + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV(value) __builtin_bswap32(value) + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REV16(value) __ROR(__REV(value), 16) + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +#define __REVSH(value) (int16_t)__builtin_bswap16(value) + + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __ROR(uint32_t op1, uint32_t op2) +{ + op2 %= 32U; + if (op2 == 0U) + { + return op1; + } + return (op1 >> op2) | (op1 << (32U - op2)); +} + + +/** + \brief Breakpoint + \details Causes the processor to enter Debug state. + Debug tools can use this to investigate system state when the instruction at a particular address is reached. + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __ASM volatile ("bkpt "#value) + + +/** + \brief Reverse bit order of value + \details Reverses the bit order of the given value. + \param [in] value Value to reverse + \return Reversed value + */ +#define __RBIT __builtin_arm_rbit + +/** + \brief Count leading zeros + \details Counts the number of leading zeros of a data value. + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ (uint8_t)__builtin_clz + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#define __LDREXB (uint8_t)__builtin_arm_ldrex + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#define __LDREXH (uint16_t)__builtin_arm_ldrex + + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#define __LDREXW (uint32_t)__builtin_arm_ldrex + + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXB (uint32_t)__builtin_arm_strex + + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXH (uint32_t)__builtin_arm_strex + + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STREXW (uint32_t)__builtin_arm_strex + + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +#define __CLREX __builtin_arm_clrex + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT __builtin_arm_ssat + + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT __builtin_arm_usat + + +/** + \brief Rotate Right with Extend (32 bit) + \details Moves each bit of a bitstring right by one bit. + The carry input is shifted in at the left end of the bitstring. + \param [in] value Value to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __RRX(uint32_t value) +{ + uint32_t result; + + __ASM volatile ("rrx %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return(result); +} + + +/** + \brief LDRT Unprivileged (8 bit) + \details Executes a Unprivileged LDRT instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDRBT(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrbt %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (16 bit) + \details Executes a Unprivileged LDRT instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDRHT(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrht %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (32 bit) + \details Executes a Unprivileged LDRT instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDRT(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrt %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief STRT Unprivileged (8 bit) + \details Executes a Unprivileged STRT instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRBT(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("strbt %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (16 bit) + \details Executes a Unprivileged STRT instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRHT(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("strht %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (32 bit) + \details Executes a Unprivileged STRT instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRT(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("strt %1, %0" : "=Q" (*ptr) : "r" (value) ); +} + +#else /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +__STATIC_FORCEINLINE int32_t __SSAT(int32_t val, uint32_t sat) +{ + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; +} + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +__STATIC_FORCEINLINE uint32_t __USAT(int32_t val, uint32_t sat) +{ + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief Load-Acquire (8 bit) + \details Executes a LDAB instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDAB(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldab %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); +} + + +/** + \brief Load-Acquire (16 bit) + \details Executes a LDAH instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDAH(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldah %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); +} + + +/** + \brief Load-Acquire (32 bit) + \details Executes a LDA instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDA(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("lda %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief Store-Release (8 bit) + \details Executes a STLB instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLB(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("stlb %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (16 bit) + \details Executes a STLH instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLH(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("stlh %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (32 bit) + \details Executes a STL instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STL(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("stl %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Load-Acquire Exclusive (8 bit) + \details Executes a LDAB exclusive instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +#define __LDAEXB (uint8_t)__builtin_arm_ldaex + + +/** + \brief Load-Acquire Exclusive (16 bit) + \details Executes a LDAH exclusive instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +#define __LDAEXH (uint16_t)__builtin_arm_ldaex + + +/** + \brief Load-Acquire Exclusive (32 bit) + \details Executes a LDA exclusive instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +#define __LDAEX (uint32_t)__builtin_arm_ldaex + + +/** + \brief Store-Release Exclusive (8 bit) + \details Executes a STLB exclusive instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STLEXB (uint32_t)__builtin_arm_stlex + + +/** + \brief Store-Release Exclusive (16 bit) + \details Executes a STLH exclusive instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STLEXH (uint32_t)__builtin_arm_stlex + + +/** + \brief Store-Release Exclusive (32 bit) + \details Executes a STL exclusive instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +#define __STLEX (uint32_t)__builtin_arm_stlex + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + +/*@}*/ /* end of group CMSIS_Core_InstructionInterface */ + + +/* ################### Compiler specific Intrinsics ########################### */ +/** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics + Access to dedicated SIMD instructions + @{ +*/ + +#if (defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1)) + +__STATIC_FORCEINLINE uint32_t __SADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usad8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USADA8(uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("usada8 %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#define __SSAT16(ARG1,ARG2) \ +({ \ + int32_t __RES, __ARG1 = (ARG1); \ + __ASM ("ssat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +#define __USAT16(ARG1,ARG2) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1); \ + __ASM ("usat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +__STATIC_FORCEINLINE uint32_t __UXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("uxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("sxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUAD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuad %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUADX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuadx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLAD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlad %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLADX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smladx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLALD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLALDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SMUSD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUSDX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusdx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsd %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSDX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsdx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SEL (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sel %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QADD( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qadd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QSUB( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qsub %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +#if 0 +#define __PKHBT(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + __ASM ("pkhbt %0, %1, %2, lsl %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) + +#define __PKHTB(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + if (ARG3 == 0) \ + __ASM ("pkhtb %0, %1, %2" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2) ); \ + else \ + __ASM ("pkhtb %0, %1, %2, asr %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) +#endif + +#define __PKHBT(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0x0000FFFFUL) | \ + ((((uint32_t)(ARG2)) << (ARG3)) & 0xFFFF0000UL) ) + +#define __PKHTB(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0xFFFF0000UL) | \ + ((((uint32_t)(ARG2)) >> (ARG3)) & 0x0000FFFFUL) ) + +__STATIC_FORCEINLINE int32_t __SMMLA (int32_t op1, int32_t op2, int32_t op3) +{ + int32_t result; + + __ASM volatile ("smmla %0, %1, %2, %3" : "=r" (result): "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#endif /* (__ARM_FEATURE_DSP == 1) */ +/*@} end of group CMSIS_SIMD_intrinsics */ + + +#endif /* __CMSIS_ARMCLANG_H */ diff --git a/Chapter04/bare/platform/CMSIS/Include/cmsis_compiler.h b/Chapter04/bare/platform/CMSIS/Include/cmsis_compiler.h new file mode 100644 index 0000000..79a2cac --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/cmsis_compiler.h @@ -0,0 +1,266 @@ +/**************************************************************************//** + * @file cmsis_compiler.h + * @brief CMSIS compiler generic header file + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_COMPILER_H +#define __CMSIS_COMPILER_H + +#include + +/* + * Arm Compiler 4/5 + */ +#if defined ( __CC_ARM ) + #include "cmsis_armcc.h" + + +/* + * Arm Compiler 6 (armclang) + */ +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #include "cmsis_armclang.h" + + +/* + * GNU Compiler + */ +#elif defined ( __GNUC__ ) + #include "cmsis_gcc.h" + + +/* + * IAR Compiler + */ +#elif defined ( __ICCARM__ ) + #include + + +/* + * TI Arm Compiler + */ +#elif defined ( __TI_ARM__ ) + #include + + #ifndef __ASM + #define __ASM __asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + #define __NO_RETURN __attribute__((noreturn)) + #endif + #ifndef __USED + #define __USED __attribute__((used)) + #endif + #ifndef __WEAK + #define __WEAK __attribute__((weak)) + #endif + #ifndef __PACKED + #define __PACKED __attribute__((packed)) + #endif + #ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed)) + #endif + #ifndef __PACKED_UNION + #define __PACKED_UNION union __attribute__((packed)) + #endif + #ifndef __UNALIGNED_UINT32 /* deprecated */ + struct __attribute__((packed)) T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __UNALIGNED_UINT16_WRITE + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void*)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT16_READ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) + #endif + #ifndef __UNALIGNED_UINT32_WRITE + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT32_READ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) + #endif + #ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) + #endif + #ifndef __RESTRICT + #warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. + #define __RESTRICT + #endif + + +/* + * TASKING Compiler + */ +#elif defined ( __TASKING__ ) + /* + * The CMSIS functions have been implemented as intrinsics in the compiler. + * Please use "carm -?i" to get an up to date list of all intrinsics, + * Including the CMSIS ones. + */ + + #ifndef __ASM + #define __ASM __asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + #define __NO_RETURN __attribute__((noreturn)) + #endif + #ifndef __USED + #define __USED __attribute__((used)) + #endif + #ifndef __WEAK + #define __WEAK __attribute__((weak)) + #endif + #ifndef __PACKED + #define __PACKED __packed__ + #endif + #ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __packed__ + #endif + #ifndef __PACKED_UNION + #define __PACKED_UNION union __packed__ + #endif + #ifndef __UNALIGNED_UINT32 /* deprecated */ + struct __packed__ T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __UNALIGNED_UINT16_WRITE + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT16_READ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) + #endif + #ifndef __UNALIGNED_UINT32_WRITE + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT32_READ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) + #endif + #ifndef __ALIGNED + #define __ALIGNED(x) __align(x) + #endif + #ifndef __RESTRICT + #warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. + #define __RESTRICT + #endif + + +/* + * COSMIC Compiler + */ +#elif defined ( __CSMC__ ) + #include + + #ifndef __ASM + #define __ASM _asm + #endif + #ifndef __INLINE + #define __INLINE inline + #endif + #ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline + #endif + #ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __STATIC_INLINE + #endif + #ifndef __NO_RETURN + // NO RETURN is automatically detected hence no warning here + #define __NO_RETURN + #endif + #ifndef __USED + #warning No compiler specific solution for __USED. __USED is ignored. + #define __USED + #endif + #ifndef __WEAK + #define __WEAK __weak + #endif + #ifndef __PACKED + #define __PACKED @packed + #endif + #ifndef __PACKED_STRUCT + #define __PACKED_STRUCT @packed struct + #endif + #ifndef __PACKED_UNION + #define __PACKED_UNION @packed union + #endif + #ifndef __UNALIGNED_UINT32 /* deprecated */ + @packed struct T_UINT32 { uint32_t v; }; + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) + #endif + #ifndef __UNALIGNED_UINT16_WRITE + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT16_READ + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) + #endif + #ifndef __UNALIGNED_UINT32_WRITE + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) + #endif + #ifndef __UNALIGNED_UINT32_READ + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) + #endif + #ifndef __ALIGNED + #warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored. + #define __ALIGNED(x) + #endif + #ifndef __RESTRICT + #warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. + #define __RESTRICT + #endif + + +#else + #error Unknown compiler. +#endif + + +#endif /* __CMSIS_COMPILER_H */ + diff --git a/Chapter04/bare/platform/CMSIS/Include/cmsis_gcc.h b/Chapter04/bare/platform/CMSIS/Include/cmsis_gcc.h new file mode 100644 index 0000000..1bd41a4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/cmsis_gcc.h @@ -0,0 +1,2085 @@ +/**************************************************************************//** + * @file cmsis_gcc.h + * @brief CMSIS compiler GCC header file + * @version V5.0.4 + * @date 09. April 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __CMSIS_GCC_H +#define __CMSIS_GCC_H + +/* ignore some GCC warnings */ +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wsign-conversion" +#pragma GCC diagnostic ignored "-Wconversion" +#pragma GCC diagnostic ignored "-Wunused-parameter" + +/* Fallback for __has_builtin */ +#ifndef __has_builtin + #define __has_builtin(x) (0) +#endif + +/* CMSIS compiler specific defines */ +#ifndef __ASM + #define __ASM __asm +#endif +#ifndef __INLINE + #define __INLINE inline +#endif +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline +#endif +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __attribute__((always_inline)) static inline +#endif +#ifndef __NO_RETURN + #define __NO_RETURN __attribute__((__noreturn__)) +#endif +#ifndef __USED + #define __USED __attribute__((used)) +#endif +#ifndef __WEAK + #define __WEAK __attribute__((weak)) +#endif +#ifndef __PACKED + #define __PACKED __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_STRUCT + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) +#endif +#ifndef __PACKED_UNION + #define __PACKED_UNION union __attribute__((packed, aligned(1))) +#endif +#ifndef __UNALIGNED_UINT32 /* deprecated */ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + struct __attribute__((packed)) T_UINT32 { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) +#endif +#ifndef __UNALIGNED_UINT16_WRITE + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT16_READ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT16_READ { uint16_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) +#endif +#ifndef __UNALIGNED_UINT32_WRITE + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) +#endif +#ifndef __UNALIGNED_UINT32_READ + #pragma GCC diagnostic push + #pragma GCC diagnostic ignored "-Wpacked" + #pragma GCC diagnostic ignored "-Wattributes" + __PACKED_STRUCT T_UINT32_READ { uint32_t v; }; + #pragma GCC diagnostic pop + #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) +#endif +#ifndef __ALIGNED + #define __ALIGNED(x) __attribute__((aligned(x))) +#endif +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + + +/* ########################### Core Function Access ########################### */ +/** \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions + @{ + */ + +/** + \brief Enable IRQ Interrupts + \details Enables IRQ interrupts by clearing the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __enable_irq(void) +{ + __ASM volatile ("cpsie i" : : : "memory"); +} + + +/** + \brief Disable IRQ Interrupts + \details Disables IRQ interrupts by setting the I-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __disable_irq(void) +{ + __ASM volatile ("cpsid i" : : : "memory"); +} + + +/** + \brief Get Control Register + \details Returns the content of the Control Register. + \return Control Register value + */ +__STATIC_FORCEINLINE uint32_t __get_CONTROL(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Control Register (non-secure) + \details Returns the content of the non-secure Control Register when in secure mode. + \return non-secure Control Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_CONTROL_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, control_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Control Register + \details Writes the given value to the Control Register. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __set_CONTROL(uint32_t control) +{ + __ASM volatile ("MSR control, %0" : : "r" (control) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Control Register (non-secure) + \details Writes the given value to the non-secure Control Register when in secure state. + \param [in] control Control Register value to set + */ +__STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) +{ + __ASM volatile ("MSR control_ns, %0" : : "r" (control) : "memory"); +} +#endif + + +/** + \brief Get IPSR Register + \details Returns the content of the IPSR Register. + \return IPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_IPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, ipsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get APSR Register + \details Returns the content of the APSR Register. + \return APSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_APSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, apsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get xPSR Register + \details Returns the content of the xPSR Register. + \return xPSR Register value + */ +__STATIC_FORCEINLINE uint32_t __get_xPSR(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, xpsr" : "=r" (result) ); + return(result); +} + + +/** + \brief Get Process Stack Pointer + \details Returns the current value of the Process Stack Pointer (PSP). + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer (non-secure) + \details Returns the current value of the non-secure Process Stack Pointer (PSP) when in secure state. + \return PSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, psp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Process Stack Pointer + \details Assigns the given value to the Process Stack Pointer (PSP). + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_PSP(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp, %0" : : "r" (topOfProcStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Process Stack Pointer (PSP) when in secure state. + \param [in] topOfProcStack Process Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSP_NS(uint32_t topOfProcStack) +{ + __ASM volatile ("MSR psp_ns, %0" : : "r" (topOfProcStack) : ); +} +#endif + + +/** + \brief Get Main Stack Pointer + \details Returns the current value of the Main Stack Pointer (MSP). + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSP(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer (non-secure) + \details Returns the current value of the non-secure Main Stack Pointer (MSP) when in secure state. + \return MSP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, msp_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Main Stack Pointer + \details Assigns the given value to the Main Stack Pointer (MSP). + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __set_MSP(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp, %0" : : "r" (topOfMainStack) : ); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Main Stack Pointer (MSP) when in secure state. + \param [in] topOfMainStack Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSP_NS(uint32_t topOfMainStack) +{ + __ASM volatile ("MSR msp_ns, %0" : : "r" (topOfMainStack) : ); +} +#endif + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Stack Pointer (non-secure) + \details Returns the current value of the non-secure Stack Pointer (SP) when in secure state. + \return SP Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_SP_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, sp_ns" : "=r" (result) ); + return(result); +} + + +/** + \brief Set Stack Pointer (non-secure) + \details Assigns the given value to the non-secure Stack Pointer (SP) when in secure state. + \param [in] topOfStack Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_SP_NS(uint32_t topOfStack) +{ + __ASM volatile ("MSR sp_ns, %0" : : "r" (topOfStack) : ); +} +#endif + + +/** + \brief Get Priority Mask + \details Returns the current state of the priority mask bit from the Priority Mask Register. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __get_PRIMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory"); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Priority Mask (non-secure) + \details Returns the current state of the non-secure priority mask bit from the Priority Mask Register when in secure state. + \return Priority Mask value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PRIMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, primask_ns" : "=r" (result) :: "memory"); + return(result); +} +#endif + + +/** + \brief Set Priority Mask + \details Assigns the given value to the Priority Mask Register. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __set_PRIMASK(uint32_t priMask) +{ + __ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Priority Mask (non-secure) + \details Assigns the given value to the non-secure Priority Mask Register when in secure state. + \param [in] priMask Priority Mask + */ +__STATIC_FORCEINLINE void __TZ_set_PRIMASK_NS(uint32_t priMask) +{ + __ASM volatile ("MSR primask_ns, %0" : : "r" (priMask) : "memory"); +} +#endif + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) +/** + \brief Enable FIQ + \details Enables FIQ interrupts by clearing the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __enable_fault_irq(void) +{ + __ASM volatile ("cpsie f" : : : "memory"); +} + + +/** + \brief Disable FIQ + \details Disables FIQ interrupts by setting the F-bit in the CPSR. + Can only be executed in Privileged modes. + */ +__STATIC_FORCEINLINE void __disable_fault_irq(void) +{ + __ASM volatile ("cpsid f" : : : "memory"); +} + + +/** + \brief Get Base Priority + \details Returns the current value of the Base Priority register. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __get_BASEPRI(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Base Priority (non-secure) + \details Returns the current value of the non-secure Base Priority register when in secure state. + \return Base Priority register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_BASEPRI_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, basepri_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Base Priority + \details Assigns the given value to the Base Priority register. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI(uint32_t basePri) +{ + __ASM volatile ("MSR basepri, %0" : : "r" (basePri) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Base Priority (non-secure) + \details Assigns the given value to the non-secure Base Priority register when in secure state. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __TZ_set_BASEPRI_NS(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_ns, %0" : : "r" (basePri) : "memory"); +} +#endif + + +/** + \brief Set Base Priority with condition + \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, + or the new value increases the BASEPRI priority level. + \param [in] basePri Base Priority value to set + */ +__STATIC_FORCEINLINE void __set_BASEPRI_MAX(uint32_t basePri) +{ + __ASM volatile ("MSR basepri_max, %0" : : "r" (basePri) : "memory"); +} + + +/** + \brief Get Fault Mask + \details Returns the current value of the Fault Mask register. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __get_FAULTMASK(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask" : "=r" (result) ); + return(result); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Fault Mask (non-secure) + \details Returns the current value of the non-secure Fault Mask register when in secure state. + \return Fault Mask register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_FAULTMASK_NS(void) +{ + uint32_t result; + + __ASM volatile ("MRS %0, faultmask_ns" : "=r" (result) ); + return(result); +} +#endif + + +/** + \brief Set Fault Mask + \details Assigns the given value to the Fault Mask register. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __set_FAULTMASK(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask, %0" : : "r" (faultMask) : "memory"); +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Fault Mask (non-secure) + \details Assigns the given value to the non-secure Fault Mask register when in secure state. + \param [in] faultMask Fault Mask value to set + */ +__STATIC_FORCEINLINE void __TZ_set_FAULTMASK_NS(uint32_t faultMask) +{ + __ASM volatile ("MSR faultmask_ns, %0" : : "r" (faultMask) : "memory"); +} +#endif + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + +/** + \brief Get Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the Process Stack Pointer Limit (PSPLIM). + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_PSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim" : "=r" (result) ); + return result; +#endif +} + +#if (defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Process Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \return PSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_PSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, psplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Process Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the Process Stack Pointer Limit (PSPLIM). + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_PSPLIM(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim, %0" : : "r" (ProcStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Process Stack Pointer (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the non-secure Process Stack Pointer Limit (PSPLIM) when in secure state. + \param [in] ProcStackPtrLimit Process Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __TZ_set_PSPLIM_NS(uint32_t ProcStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)ProcStackPtrLimit; +#else + __ASM volatile ("MSR psplim_ns, %0\n" : : "r" (ProcStackPtrLimit)); +#endif +} +#endif + + +/** + \brief Get Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always in non-secure + mode. + + \details Returns the current value of the Main Stack Pointer Limit (MSPLIM). + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __get_MSPLIM(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim" : "=r" (result) ); + return result; +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Get Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence zero is returned always. + + \details Returns the current value of the non-secure Main Stack Pointer Limit(MSPLIM) when in secure state. + \return MSPLIM Register value + */ +__STATIC_FORCEINLINE uint32_t __TZ_get_MSPLIM_NS(void) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + return 0U; +#else + uint32_t result; + __ASM volatile ("MRS %0, msplim_ns" : "=r" (result) ); + return result; +#endif +} +#endif + + +/** + \brief Set Main Stack Pointer Limit + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored in non-secure + mode. + + \details Assigns the given value to the Main Stack Pointer Limit (MSPLIM). + \param [in] MainStackPtrLimit Main Stack Pointer Limit value to set + */ +__STATIC_FORCEINLINE void __set_MSPLIM(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim, %0" : : "r" (MainStackPtrLimit)); +#endif +} + + +#if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) +/** + \brief Set Main Stack Pointer Limit (non-secure) + Devices without ARMv8-M Main Extensions (i.e. Cortex-M23) lack the non-secure + Stack Pointer Limit register hence the write is silently ignored. + + \details Assigns the given value to the non-secure Main Stack Pointer Limit (MSPLIM) when in secure state. + \param [in] MainStackPtrLimit Main Stack Pointer value to set + */ +__STATIC_FORCEINLINE void __TZ_set_MSPLIM_NS(uint32_t MainStackPtrLimit) +{ +#if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)MainStackPtrLimit; +#else + __ASM volatile ("MSR msplim_ns, %0" : : "r" (MainStackPtrLimit)); +#endif +} +#endif + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + + +/** + \brief Get FPSCR + \details Returns the current value of the Floating Point Status/Control register. + \return Floating Point Status/Control register value + */ +__STATIC_FORCEINLINE uint32_t __get_FPSCR(void) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#if __has_builtin(__builtin_arm_get_fpscr) +// Re-enable using built-in when GCC has been fixed +// || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2) + /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */ + return __builtin_arm_get_fpscr(); +#else + uint32_t result; + + __ASM volatile ("VMRS %0, fpscr" : "=r" (result) ); + return(result); +#endif +#else + return(0U); +#endif +} + + +/** + \brief Set FPSCR + \details Assigns the given value to the Floating Point Status/Control register. + \param [in] fpscr Floating Point Status/Control value to set + */ +__STATIC_FORCEINLINE void __set_FPSCR(uint32_t fpscr) +{ +#if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) +#if __has_builtin(__builtin_arm_set_fpscr) +// Re-enable using built-in when GCC has been fixed +// || (__GNUC__ > 7) || (__GNUC__ == 7 && __GNUC_MINOR__ >= 2) + /* see https://gcc.gnu.org/ml/gcc-patches/2017-04/msg00443.html */ + __builtin_arm_set_fpscr(fpscr); +#else + __ASM volatile ("VMSR fpscr, %0" : : "r" (fpscr) : "vfpcc", "memory"); +#endif +#else + (void)fpscr; +#endif +} + + +/*@} end of CMSIS_Core_RegAccFunctions */ + + +/* ########################## Core Instruction Access ######################### */ +/** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface + Access to dedicated instructions + @{ +*/ + +/* Define macros for porting to both thumb1 and thumb2. + * For thumb1, use low register (r0-r7), specified by constraint "l" + * Otherwise, use general registers, specified by constraint "r" */ +#if defined (__thumb__) && !defined (__thumb2__) +#define __CMSIS_GCC_OUT_REG(r) "=l" (r) +#define __CMSIS_GCC_RW_REG(r) "+l" (r) +#define __CMSIS_GCC_USE_REG(r) "l" (r) +#else +#define __CMSIS_GCC_OUT_REG(r) "=r" (r) +#define __CMSIS_GCC_RW_REG(r) "+r" (r) +#define __CMSIS_GCC_USE_REG(r) "r" (r) +#endif + +/** + \brief No Operation + \details No Operation does nothing. This instruction can be used for code alignment purposes. + */ +#define __NOP() __ASM volatile ("nop") + +/** + \brief Wait For Interrupt + \details Wait For Interrupt is a hint instruction that suspends execution until one of a number of events occurs. + */ +#define __WFI() __ASM volatile ("wfi") + + +/** + \brief Wait For Event + \details Wait For Event is a hint instruction that permits the processor to enter + a low-power state until one of a number of events occurs. + */ +#define __WFE() __ASM volatile ("wfe") + + +/** + \brief Send Event + \details Send Event is a hint instruction. It causes an event to be signaled to the CPU. + */ +#define __SEV() __ASM volatile ("sev") + + +/** + \brief Instruction Synchronization Barrier + \details Instruction Synchronization Barrier flushes the pipeline in the processor, + so that all instructions following the ISB are fetched from cache or memory, + after the instruction has been completed. + */ +__STATIC_FORCEINLINE void __ISB(void) +{ + __ASM volatile ("isb 0xF":::"memory"); +} + + +/** + \brief Data Synchronization Barrier + \details Acts as a special kind of Data Memory Barrier. + It completes when all explicit memory accesses before this instruction complete. + */ +__STATIC_FORCEINLINE void __DSB(void) +{ + __ASM volatile ("dsb 0xF":::"memory"); +} + + +/** + \brief Data Memory Barrier + \details Ensures the apparent order of the explicit memory operations before + and after the instruction, without ensuring their completion. + */ +__STATIC_FORCEINLINE void __DMB(void) +{ + __ASM volatile ("dmb 0xF":::"memory"); +} + + +/** + \brief Reverse byte order (32 bit) + \details Reverses the byte order in unsigned integer value. For example, 0x12345678 becomes 0x78563412. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __REV(uint32_t value) +{ +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5) + return __builtin_bswap32(value); +#else + uint32_t result; + + __ASM volatile ("rev %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +#endif +} + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order within each halfword of a word. For example, 0x12345678 becomes 0x34127856. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __REV16(uint32_t value) +{ + uint32_t result; + + __ASM volatile ("rev16 %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +} + + +/** + \brief Reverse byte order (16 bit) + \details Reverses the byte order in a 16-bit value and returns the signed 16-bit result. For example, 0x0080 becomes 0x8000. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE int16_t __REVSH(int16_t value) +{ +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + return (int16_t)__builtin_bswap16(value); +#else + int16_t result; + + __ASM volatile ("revsh %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return result; +#endif +} + + +/** + \brief Rotate Right in unsigned value (32 bit) + \details Rotate Right (immediate) provides the value of the contents of a register rotated by a variable number of bits. + \param [in] op1 Value to rotate + \param [in] op2 Number of Bits to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __ROR(uint32_t op1, uint32_t op2) +{ + op2 %= 32U; + if (op2 == 0U) + { + return op1; + } + return (op1 >> op2) | (op1 << (32U - op2)); +} + + +/** + \brief Breakpoint + \details Causes the processor to enter Debug state. + Debug tools can use this to investigate system state when the instruction at a particular address is reached. + \param [in] value is ignored by the processor. + If required, a debugger can use it to store additional information about the breakpoint. + */ +#define __BKPT(value) __ASM volatile ("bkpt "#value) + + +/** + \brief Reverse bit order of value + \details Reverses the bit order of the given value. + \param [in] value Value to reverse + \return Reversed value + */ +__STATIC_FORCEINLINE uint32_t __RBIT(uint32_t value) +{ + uint32_t result; + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) + __ASM volatile ("rbit %0, %1" : "=r" (result) : "r" (value) ); +#else + uint32_t s = (4U /*sizeof(v)*/ * 8U) - 1U; /* extra shift needed at end */ + + result = value; /* r will be reversed bits of v; first get LSB of v */ + for (value >>= 1U; value != 0U; value >>= 1U) + { + result <<= 1U; + result |= value & 1U; + s--; + } + result <<= s; /* shift when v's highest bits are zero */ +#endif + return result; +} + + +/** + \brief Count leading zeros + \details Counts the number of leading zeros of a data value. + \param [in] value Value to count the leading zeros + \return number of leading zeros in value + */ +#define __CLZ (uint8_t)__builtin_clz + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief LDR Exclusive (8 bit) + \details Executes a exclusive LDR instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDREXB(volatile uint8_t *addr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrexb %0, %1" : "=r" (result) : "Q" (*addr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrexb %0, [%1]" : "=r" (result) : "r" (addr) : "memory" ); +#endif + return ((uint8_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDR Exclusive (16 bit) + \details Executes a exclusive LDR instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDREXH(volatile uint16_t *addr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrexh %0, %1" : "=r" (result) : "Q" (*addr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrexh %0, [%1]" : "=r" (result) : "r" (addr) : "memory" ); +#endif + return ((uint16_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDR Exclusive (32 bit) + \details Executes a exclusive LDR instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDREXW(volatile uint32_t *addr) +{ + uint32_t result; + + __ASM volatile ("ldrex %0, %1" : "=r" (result) : "Q" (*addr) ); + return(result); +} + + +/** + \brief STR Exclusive (8 bit) + \details Executes a exclusive STR instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXB(uint8_t value, volatile uint8_t *addr) +{ + uint32_t result; + + __ASM volatile ("strexb %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief STR Exclusive (16 bit) + \details Executes a exclusive STR instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXH(uint16_t value, volatile uint16_t *addr) +{ + uint32_t result; + + __ASM volatile ("strexh %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief STR Exclusive (32 bit) + \details Executes a exclusive STR instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STREXW(uint32_t value, volatile uint32_t *addr) +{ + uint32_t result; + + __ASM volatile ("strex %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" (value) ); + return(result); +} + + +/** + \brief Remove the exclusive lock + \details Removes the exclusive lock which is created by LDREX. + */ +__STATIC_FORCEINLINE void __CLREX(void) +{ + __ASM volatile ("clrex" ::: "memory"); +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] ARG1 Value to be saturated + \param [in] ARG2 Bit position to saturate to (1..32) + \return Saturated value + */ +#define __SSAT(ARG1,ARG2) \ +__extension__ \ +({ \ + int32_t __RES, __ARG1 = (ARG1); \ + __ASM ("ssat %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] ARG1 Value to be saturated + \param [in] ARG2 Bit position to saturate to (0..31) + \return Saturated value + */ +#define __USAT(ARG1,ARG2) \ + __extension__ \ +({ \ + uint32_t __RES, __ARG1 = (ARG1); \ + __ASM ("usat %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + + +/** + \brief Rotate Right with Extend (32 bit) + \details Moves each bit of a bitstring right by one bit. + The carry input is shifted in at the left end of the bitstring. + \param [in] value Value to rotate + \return Rotated value + */ +__STATIC_FORCEINLINE uint32_t __RRX(uint32_t value) +{ + uint32_t result; + + __ASM volatile ("rrx %0, %1" : __CMSIS_GCC_OUT_REG (result) : __CMSIS_GCC_USE_REG (value) ); + return(result); +} + + +/** + \brief LDRT Unprivileged (8 bit) + \details Executes a Unprivileged LDRT instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDRBT(volatile uint8_t *ptr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrbt %0, %1" : "=r" (result) : "Q" (*ptr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrbt %0, [%1]" : "=r" (result) : "r" (ptr) : "memory" ); +#endif + return ((uint8_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (16 bit) + \details Executes a Unprivileged LDRT instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDRHT(volatile uint16_t *ptr) +{ + uint32_t result; + +#if (__GNUC__ > 4) || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8) + __ASM volatile ("ldrht %0, %1" : "=r" (result) : "Q" (*ptr) ); +#else + /* Prior to GCC 4.8, "Q" will be expanded to [rx, #0] which is not + accepted by assembler. So has to use following less efficient pattern. + */ + __ASM volatile ("ldrht %0, [%1]" : "=r" (result) : "r" (ptr) : "memory" ); +#endif + return ((uint16_t) result); /* Add explicit type cast here */ +} + + +/** + \brief LDRT Unprivileged (32 bit) + \details Executes a Unprivileged LDRT instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDRT(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldrt %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief STRT Unprivileged (8 bit) + \details Executes a Unprivileged STRT instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRBT(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("strbt %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (16 bit) + \details Executes a Unprivileged STRT instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRHT(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("strht %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief STRT Unprivileged (32 bit) + \details Executes a Unprivileged STRT instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STRT(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("strt %1, %0" : "=Q" (*ptr) : "r" (value) ); +} + +#else /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + +/** + \brief Signed Saturate + \details Saturates a signed value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (1..32) + \return Saturated value + */ +__STATIC_FORCEINLINE int32_t __SSAT(int32_t val, uint32_t sat) +{ + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; +} + +/** + \brief Unsigned Saturate + \details Saturates an unsigned value. + \param [in] value Value to be saturated + \param [in] sat Bit position to saturate to (0..31) + \return Saturated value + */ +__STATIC_FORCEINLINE uint32_t __USAT(int32_t val, uint32_t sat) +{ + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; +} + +#endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__ == 1)) || \ + (defined (__ARM_ARCH_7EM__ ) && (__ARM_ARCH_7EM__ == 1)) || \ + (defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) ) */ + + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) +/** + \brief Load-Acquire (8 bit) + \details Executes a LDAB instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDAB(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldab %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); +} + + +/** + \brief Load-Acquire (16 bit) + \details Executes a LDAH instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDAH(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldah %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); +} + + +/** + \brief Load-Acquire (32 bit) + \details Executes a LDA instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDA(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("lda %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief Store-Release (8 bit) + \details Executes a STLB instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLB(uint8_t value, volatile uint8_t *ptr) +{ + __ASM volatile ("stlb %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (16 bit) + \details Executes a STLH instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STLH(uint16_t value, volatile uint16_t *ptr) +{ + __ASM volatile ("stlh %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Store-Release (32 bit) + \details Executes a STL instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + */ +__STATIC_FORCEINLINE void __STL(uint32_t value, volatile uint32_t *ptr) +{ + __ASM volatile ("stl %1, %0" : "=Q" (*ptr) : "r" ((uint32_t)value) ); +} + + +/** + \brief Load-Acquire Exclusive (8 bit) + \details Executes a LDAB exclusive instruction for 8 bit value. + \param [in] ptr Pointer to data + \return value of type uint8_t at (*ptr) + */ +__STATIC_FORCEINLINE uint8_t __LDAEXB(volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldaexb %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint8_t) result); +} + + +/** + \brief Load-Acquire Exclusive (16 bit) + \details Executes a LDAH exclusive instruction for 16 bit values. + \param [in] ptr Pointer to data + \return value of type uint16_t at (*ptr) + */ +__STATIC_FORCEINLINE uint16_t __LDAEXH(volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldaexh %0, %1" : "=r" (result) : "Q" (*ptr) ); + return ((uint16_t) result); +} + + +/** + \brief Load-Acquire Exclusive (32 bit) + \details Executes a LDA exclusive instruction for 32 bit values. + \param [in] ptr Pointer to data + \return value of type uint32_t at (*ptr) + */ +__STATIC_FORCEINLINE uint32_t __LDAEX(volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("ldaex %0, %1" : "=r" (result) : "Q" (*ptr) ); + return(result); +} + + +/** + \brief Store-Release Exclusive (8 bit) + \details Executes a STLB exclusive instruction for 8 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STLEXB(uint8_t value, volatile uint8_t *ptr) +{ + uint32_t result; + + __ASM volatile ("stlexb %0, %2, %1" : "=&r" (result), "=Q" (*ptr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief Store-Release Exclusive (16 bit) + \details Executes a STLH exclusive instruction for 16 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STLEXH(uint16_t value, volatile uint16_t *ptr) +{ + uint32_t result; + + __ASM volatile ("stlexh %0, %2, %1" : "=&r" (result), "=Q" (*ptr) : "r" ((uint32_t)value) ); + return(result); +} + + +/** + \brief Store-Release Exclusive (32 bit) + \details Executes a STL exclusive instruction for 32 bit values. + \param [in] value Value to store + \param [in] ptr Pointer to location + \return 0 Function succeeded + \return 1 Function failed + */ +__STATIC_FORCEINLINE uint32_t __STLEX(uint32_t value, volatile uint32_t *ptr) +{ + uint32_t result; + + __ASM volatile ("stlex %0, %2, %1" : "=&r" (result), "=Q" (*ptr) : "r" ((uint32_t)value) ); + return(result); +} + +#endif /* ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) */ + +/*@}*/ /* end of group CMSIS_Core_InstructionInterface */ + + +/* ################### Compiler specific Intrinsics ########################### */ +/** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics + Access to dedicated SIMD instructions + @{ +*/ + +#if (defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1)) + +__STATIC_FORCEINLINE uint32_t __SADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + + +__STATIC_FORCEINLINE uint32_t __SADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHADD16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhadd16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSUB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsub16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHASX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhasx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("ssax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __QSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("qsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("shsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UQSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uqsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UHSAX(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uhsax %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USAD8(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("usad8 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __USADA8(uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("usada8 %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#define __SSAT16(ARG1,ARG2) \ +({ \ + int32_t __RES, __ARG1 = (ARG1); \ + __ASM ("ssat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +#define __USAT16(ARG1,ARG2) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1); \ + __ASM ("usat16 %0, %1, %2" : "=r" (__RES) : "I" (ARG2), "r" (__ARG1) ); \ + __RES; \ + }) + +__STATIC_FORCEINLINE uint32_t __UXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("uxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __UXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("uxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTB16(uint32_t op1) +{ + uint32_t result; + + __ASM volatile ("sxtb16 %0, %1" : "=r" (result) : "r" (op1)); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SXTAB16(uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sxtab16 %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUAD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuad %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUADX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smuadx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLAD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlad %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLADX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smladx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLALD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlald %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLALDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlaldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SMUSD (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMUSDX (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("smusdx %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSD (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsd %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint32_t __SMLSDX (uint32_t op1, uint32_t op2, uint32_t op3) +{ + uint32_t result; + + __ASM volatile ("smlsdx %0, %1, %2, %3" : "=r" (result) : "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLD (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsld %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint64_t __SMLSLDX (uint32_t op1, uint32_t op2, uint64_t acc) +{ + union llreg_u{ + uint32_t w32[2]; + uint64_t w64; + } llr; + llr.w64 = acc; + +#ifndef __ARMEB__ /* Little endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[0]), "=r" (llr.w32[1]): "r" (op1), "r" (op2) , "0" (llr.w32[0]), "1" (llr.w32[1]) ); +#else /* Big endian */ + __ASM volatile ("smlsldx %0, %1, %2, %3" : "=r" (llr.w32[1]), "=r" (llr.w32[0]): "r" (op1), "r" (op2) , "0" (llr.w32[1]), "1" (llr.w32[0]) ); +#endif + + return(llr.w64); +} + +__STATIC_FORCEINLINE uint32_t __SEL (uint32_t op1, uint32_t op2) +{ + uint32_t result; + + __ASM volatile ("sel %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QADD( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qadd %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +__STATIC_FORCEINLINE int32_t __QSUB( int32_t op1, int32_t op2) +{ + int32_t result; + + __ASM volatile ("qsub %0, %1, %2" : "=r" (result) : "r" (op1), "r" (op2) ); + return(result); +} + +#if 0 +#define __PKHBT(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + __ASM ("pkhbt %0, %1, %2, lsl %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) + +#define __PKHTB(ARG1,ARG2,ARG3) \ +({ \ + uint32_t __RES, __ARG1 = (ARG1), __ARG2 = (ARG2); \ + if (ARG3 == 0) \ + __ASM ("pkhtb %0, %1, %2" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2) ); \ + else \ + __ASM ("pkhtb %0, %1, %2, asr %3" : "=r" (__RES) : "r" (__ARG1), "r" (__ARG2), "I" (ARG3) ); \ + __RES; \ + }) +#endif + +#define __PKHBT(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0x0000FFFFUL) | \ + ((((uint32_t)(ARG2)) << (ARG3)) & 0xFFFF0000UL) ) + +#define __PKHTB(ARG1,ARG2,ARG3) ( ((((uint32_t)(ARG1)) ) & 0xFFFF0000UL) | \ + ((((uint32_t)(ARG2)) >> (ARG3)) & 0x0000FFFFUL) ) + +__STATIC_FORCEINLINE int32_t __SMMLA (int32_t op1, int32_t op2, int32_t op3) +{ + int32_t result; + + __ASM volatile ("smmla %0, %1, %2, %3" : "=r" (result): "r" (op1), "r" (op2), "r" (op3) ); + return(result); +} + +#endif /* (__ARM_FEATURE_DSP == 1) */ +/*@} end of group CMSIS_SIMD_intrinsics */ + + +#pragma GCC diagnostic pop + +#endif /* __CMSIS_GCC_H */ diff --git a/Chapter04/bare/platform/CMSIS/Include/cmsis_iccarm.h b/Chapter04/bare/platform/CMSIS/Include/cmsis_iccarm.h new file mode 100644 index 0000000..3c90a2c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/cmsis_iccarm.h @@ -0,0 +1,935 @@ +/**************************************************************************//** + * @file cmsis_iccarm.h + * @brief CMSIS compiler ICCARM (IAR Compiler for Arm) header file + * @version V5.0.7 + * @date 19. June 2018 + ******************************************************************************/ + +//------------------------------------------------------------------------------ +// +// Copyright (c) 2017-2018 IAR Systems +// +// Licensed under the Apache License, Version 2.0 (the "License") +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +//------------------------------------------------------------------------------ + + +#ifndef __CMSIS_ICCARM_H__ +#define __CMSIS_ICCARM_H__ + +#ifndef __ICCARM__ + #error This file should only be compiled by ICCARM +#endif + +#pragma system_include + +#define __IAR_FT _Pragma("inline=forced") __intrinsic + +#if (__VER__ >= 8000000) + #define __ICCARM_V8 1 +#else + #define __ICCARM_V8 0 +#endif + +#ifndef __ALIGNED + #if __ICCARM_V8 + #define __ALIGNED(x) __attribute__((aligned(x))) + #elif (__VER__ >= 7080000) + /* Needs IAR language extensions */ + #define __ALIGNED(x) __attribute__((aligned(x))) + #else + #warning No compiler specific solution for __ALIGNED.__ALIGNED is ignored. + #define __ALIGNED(x) + #endif +#endif + + +/* Define compiler macros for CPU architecture, used in CMSIS 5. + */ +#if __ARM_ARCH_6M__ || __ARM_ARCH_7M__ || __ARM_ARCH_7EM__ || __ARM_ARCH_8M_BASE__ || __ARM_ARCH_8M_MAIN__ +/* Macros already defined */ +#else + #if defined(__ARM8M_MAINLINE__) || defined(__ARM8EM_MAINLINE__) + #define __ARM_ARCH_8M_MAIN__ 1 + #elif defined(__ARM8M_BASELINE__) + #define __ARM_ARCH_8M_BASE__ 1 + #elif defined(__ARM_ARCH_PROFILE) && __ARM_ARCH_PROFILE == 'M' + #if __ARM_ARCH == 6 + #define __ARM_ARCH_6M__ 1 + #elif __ARM_ARCH == 7 + #if __ARM_FEATURE_DSP + #define __ARM_ARCH_7EM__ 1 + #else + #define __ARM_ARCH_7M__ 1 + #endif + #endif /* __ARM_ARCH */ + #endif /* __ARM_ARCH_PROFILE == 'M' */ +#endif + +/* Alternativ core deduction for older ICCARM's */ +#if !defined(__ARM_ARCH_6M__) && !defined(__ARM_ARCH_7M__) && !defined(__ARM_ARCH_7EM__) && \ + !defined(__ARM_ARCH_8M_BASE__) && !defined(__ARM_ARCH_8M_MAIN__) + #if defined(__ARM6M__) && (__CORE__ == __ARM6M__) + #define __ARM_ARCH_6M__ 1 + #elif defined(__ARM7M__) && (__CORE__ == __ARM7M__) + #define __ARM_ARCH_7M__ 1 + #elif defined(__ARM7EM__) && (__CORE__ == __ARM7EM__) + #define __ARM_ARCH_7EM__ 1 + #elif defined(__ARM8M_BASELINE__) && (__CORE == __ARM8M_BASELINE__) + #define __ARM_ARCH_8M_BASE__ 1 + #elif defined(__ARM8M_MAINLINE__) && (__CORE == __ARM8M_MAINLINE__) + #define __ARM_ARCH_8M_MAIN__ 1 + #elif defined(__ARM8EM_MAINLINE__) && (__CORE == __ARM8EM_MAINLINE__) + #define __ARM_ARCH_8M_MAIN__ 1 + #else + #error "Unknown target." + #endif +#endif + + + +#if defined(__ARM_ARCH_6M__) && __ARM_ARCH_6M__==1 + #define __IAR_M0_FAMILY 1 +#elif defined(__ARM_ARCH_8M_BASE__) && __ARM_ARCH_8M_BASE__==1 + #define __IAR_M0_FAMILY 1 +#else + #define __IAR_M0_FAMILY 0 +#endif + + +#ifndef __ASM + #define __ASM __asm +#endif + +#ifndef __INLINE + #define __INLINE inline +#endif + +#ifndef __NO_RETURN + #if __ICCARM_V8 + #define __NO_RETURN __attribute__((__noreturn__)) + #else + #define __NO_RETURN _Pragma("object_attribute=__noreturn") + #endif +#endif + +#ifndef __PACKED + #if __ICCARM_V8 + #define __PACKED __attribute__((packed, aligned(1))) + #else + /* Needs IAR language extensions */ + #define __PACKED __packed + #endif +#endif + +#ifndef __PACKED_STRUCT + #if __ICCARM_V8 + #define __PACKED_STRUCT struct __attribute__((packed, aligned(1))) + #else + /* Needs IAR language extensions */ + #define __PACKED_STRUCT __packed struct + #endif +#endif + +#ifndef __PACKED_UNION + #if __ICCARM_V8 + #define __PACKED_UNION union __attribute__((packed, aligned(1))) + #else + /* Needs IAR language extensions */ + #define __PACKED_UNION __packed union + #endif +#endif + +#ifndef __RESTRICT + #define __RESTRICT __restrict +#endif + +#ifndef __STATIC_INLINE + #define __STATIC_INLINE static inline +#endif + +#ifndef __FORCEINLINE + #define __FORCEINLINE _Pragma("inline=forced") +#endif + +#ifndef __STATIC_FORCEINLINE + #define __STATIC_FORCEINLINE __FORCEINLINE __STATIC_INLINE +#endif + +#ifndef __UNALIGNED_UINT16_READ +#pragma language=save +#pragma language=extended +__IAR_FT uint16_t __iar_uint16_read(void const *ptr) +{ + return *(__packed uint16_t*)(ptr); +} +#pragma language=restore +#define __UNALIGNED_UINT16_READ(PTR) __iar_uint16_read(PTR) +#endif + + +#ifndef __UNALIGNED_UINT16_WRITE +#pragma language=save +#pragma language=extended +__IAR_FT void __iar_uint16_write(void const *ptr, uint16_t val) +{ + *(__packed uint16_t*)(ptr) = val;; +} +#pragma language=restore +#define __UNALIGNED_UINT16_WRITE(PTR,VAL) __iar_uint16_write(PTR,VAL) +#endif + +#ifndef __UNALIGNED_UINT32_READ +#pragma language=save +#pragma language=extended +__IAR_FT uint32_t __iar_uint32_read(void const *ptr) +{ + return *(__packed uint32_t*)(ptr); +} +#pragma language=restore +#define __UNALIGNED_UINT32_READ(PTR) __iar_uint32_read(PTR) +#endif + +#ifndef __UNALIGNED_UINT32_WRITE +#pragma language=save +#pragma language=extended +__IAR_FT void __iar_uint32_write(void const *ptr, uint32_t val) +{ + *(__packed uint32_t*)(ptr) = val;; +} +#pragma language=restore +#define __UNALIGNED_UINT32_WRITE(PTR,VAL) __iar_uint32_write(PTR,VAL) +#endif + +#ifndef __UNALIGNED_UINT32 /* deprecated */ +#pragma language=save +#pragma language=extended +__packed struct __iar_u32 { uint32_t v; }; +#pragma language=restore +#define __UNALIGNED_UINT32(PTR) (((struct __iar_u32 *)(PTR))->v) +#endif + +#ifndef __USED + #if __ICCARM_V8 + #define __USED __attribute__((used)) + #else + #define __USED _Pragma("__root") + #endif +#endif + +#ifndef __WEAK + #if __ICCARM_V8 + #define __WEAK __attribute__((weak)) + #else + #define __WEAK _Pragma("__weak") + #endif +#endif + + +#ifndef __ICCARM_INTRINSICS_VERSION__ + #define __ICCARM_INTRINSICS_VERSION__ 0 +#endif + +#if __ICCARM_INTRINSICS_VERSION__ == 2 + + #if defined(__CLZ) + #undef __CLZ + #endif + #if defined(__REVSH) + #undef __REVSH + #endif + #if defined(__RBIT) + #undef __RBIT + #endif + #if defined(__SSAT) + #undef __SSAT + #endif + #if defined(__USAT) + #undef __USAT + #endif + + #include "iccarm_builtin.h" + + #define __disable_fault_irq __iar_builtin_disable_fiq + #define __disable_irq __iar_builtin_disable_interrupt + #define __enable_fault_irq __iar_builtin_enable_fiq + #define __enable_irq __iar_builtin_enable_interrupt + #define __arm_rsr __iar_builtin_rsr + #define __arm_wsr __iar_builtin_wsr + + + #define __get_APSR() (__arm_rsr("APSR")) + #define __get_BASEPRI() (__arm_rsr("BASEPRI")) + #define __get_CONTROL() (__arm_rsr("CONTROL")) + #define __get_FAULTMASK() (__arm_rsr("FAULTMASK")) + + #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) ) + #define __get_FPSCR() (__arm_rsr("FPSCR")) + #define __set_FPSCR(VALUE) (__arm_wsr("FPSCR", (VALUE))) + #else + #define __get_FPSCR() ( 0 ) + #define __set_FPSCR(VALUE) ((void)VALUE) + #endif + + #define __get_IPSR() (__arm_rsr("IPSR")) + #define __get_MSP() (__arm_rsr("MSP")) + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + #define __get_MSPLIM() (0U) + #else + #define __get_MSPLIM() (__arm_rsr("MSPLIM")) + #endif + #define __get_PRIMASK() (__arm_rsr("PRIMASK")) + #define __get_PSP() (__arm_rsr("PSP")) + + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + #define __get_PSPLIM() (0U) + #else + #define __get_PSPLIM() (__arm_rsr("PSPLIM")) + #endif + + #define __get_xPSR() (__arm_rsr("xPSR")) + + #define __set_BASEPRI(VALUE) (__arm_wsr("BASEPRI", (VALUE))) + #define __set_BASEPRI_MAX(VALUE) (__arm_wsr("BASEPRI_MAX", (VALUE))) + #define __set_CONTROL(VALUE) (__arm_wsr("CONTROL", (VALUE))) + #define __set_FAULTMASK(VALUE) (__arm_wsr("FAULTMASK", (VALUE))) + #define __set_MSP(VALUE) (__arm_wsr("MSP", (VALUE))) + + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + #define __set_MSPLIM(VALUE) ((void)(VALUE)) + #else + #define __set_MSPLIM(VALUE) (__arm_wsr("MSPLIM", (VALUE))) + #endif + #define __set_PRIMASK(VALUE) (__arm_wsr("PRIMASK", (VALUE))) + #define __set_PSP(VALUE) (__arm_wsr("PSP", (VALUE))) + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + #define __set_PSPLIM(VALUE) ((void)(VALUE)) + #else + #define __set_PSPLIM(VALUE) (__arm_wsr("PSPLIM", (VALUE))) + #endif + + #define __TZ_get_CONTROL_NS() (__arm_rsr("CONTROL_NS")) + #define __TZ_set_CONTROL_NS(VALUE) (__arm_wsr("CONTROL_NS", (VALUE))) + #define __TZ_get_PSP_NS() (__arm_rsr("PSP_NS")) + #define __TZ_set_PSP_NS(VALUE) (__arm_wsr("PSP_NS", (VALUE))) + #define __TZ_get_MSP_NS() (__arm_rsr("MSP_NS")) + #define __TZ_set_MSP_NS(VALUE) (__arm_wsr("MSP_NS", (VALUE))) + #define __TZ_get_SP_NS() (__arm_rsr("SP_NS")) + #define __TZ_set_SP_NS(VALUE) (__arm_wsr("SP_NS", (VALUE))) + #define __TZ_get_PRIMASK_NS() (__arm_rsr("PRIMASK_NS")) + #define __TZ_set_PRIMASK_NS(VALUE) (__arm_wsr("PRIMASK_NS", (VALUE))) + #define __TZ_get_BASEPRI_NS() (__arm_rsr("BASEPRI_NS")) + #define __TZ_set_BASEPRI_NS(VALUE) (__arm_wsr("BASEPRI_NS", (VALUE))) + #define __TZ_get_FAULTMASK_NS() (__arm_rsr("FAULTMASK_NS")) + #define __TZ_set_FAULTMASK_NS(VALUE)(__arm_wsr("FAULTMASK_NS", (VALUE))) + + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + #define __TZ_get_PSPLIM_NS() (0U) + #define __TZ_set_PSPLIM_NS(VALUE) ((void)(VALUE)) + #else + #define __TZ_get_PSPLIM_NS() (__arm_rsr("PSPLIM_NS")) + #define __TZ_set_PSPLIM_NS(VALUE) (__arm_wsr("PSPLIM_NS", (VALUE))) + #endif + + #define __TZ_get_MSPLIM_NS() (__arm_rsr("MSPLIM_NS")) + #define __TZ_set_MSPLIM_NS(VALUE) (__arm_wsr("MSPLIM_NS", (VALUE))) + + #define __NOP __iar_builtin_no_operation + + #define __CLZ __iar_builtin_CLZ + #define __CLREX __iar_builtin_CLREX + + #define __DMB __iar_builtin_DMB + #define __DSB __iar_builtin_DSB + #define __ISB __iar_builtin_ISB + + #define __LDREXB __iar_builtin_LDREXB + #define __LDREXH __iar_builtin_LDREXH + #define __LDREXW __iar_builtin_LDREX + + #define __RBIT __iar_builtin_RBIT + #define __REV __iar_builtin_REV + #define __REV16 __iar_builtin_REV16 + + __IAR_FT int16_t __REVSH(int16_t val) + { + return (int16_t) __iar_builtin_REVSH(val); + } + + #define __ROR __iar_builtin_ROR + #define __RRX __iar_builtin_RRX + + #define __SEV __iar_builtin_SEV + + #if !__IAR_M0_FAMILY + #define __SSAT __iar_builtin_SSAT + #endif + + #define __STREXB __iar_builtin_STREXB + #define __STREXH __iar_builtin_STREXH + #define __STREXW __iar_builtin_STREX + + #if !__IAR_M0_FAMILY + #define __USAT __iar_builtin_USAT + #endif + + #define __WFE __iar_builtin_WFE + #define __WFI __iar_builtin_WFI + + #if __ARM_MEDIA__ + #define __SADD8 __iar_builtin_SADD8 + #define __QADD8 __iar_builtin_QADD8 + #define __SHADD8 __iar_builtin_SHADD8 + #define __UADD8 __iar_builtin_UADD8 + #define __UQADD8 __iar_builtin_UQADD8 + #define __UHADD8 __iar_builtin_UHADD8 + #define __SSUB8 __iar_builtin_SSUB8 + #define __QSUB8 __iar_builtin_QSUB8 + #define __SHSUB8 __iar_builtin_SHSUB8 + #define __USUB8 __iar_builtin_USUB8 + #define __UQSUB8 __iar_builtin_UQSUB8 + #define __UHSUB8 __iar_builtin_UHSUB8 + #define __SADD16 __iar_builtin_SADD16 + #define __QADD16 __iar_builtin_QADD16 + #define __SHADD16 __iar_builtin_SHADD16 + #define __UADD16 __iar_builtin_UADD16 + #define __UQADD16 __iar_builtin_UQADD16 + #define __UHADD16 __iar_builtin_UHADD16 + #define __SSUB16 __iar_builtin_SSUB16 + #define __QSUB16 __iar_builtin_QSUB16 + #define __SHSUB16 __iar_builtin_SHSUB16 + #define __USUB16 __iar_builtin_USUB16 + #define __UQSUB16 __iar_builtin_UQSUB16 + #define __UHSUB16 __iar_builtin_UHSUB16 + #define __SASX __iar_builtin_SASX + #define __QASX __iar_builtin_QASX + #define __SHASX __iar_builtin_SHASX + #define __UASX __iar_builtin_UASX + #define __UQASX __iar_builtin_UQASX + #define __UHASX __iar_builtin_UHASX + #define __SSAX __iar_builtin_SSAX + #define __QSAX __iar_builtin_QSAX + #define __SHSAX __iar_builtin_SHSAX + #define __USAX __iar_builtin_USAX + #define __UQSAX __iar_builtin_UQSAX + #define __UHSAX __iar_builtin_UHSAX + #define __USAD8 __iar_builtin_USAD8 + #define __USADA8 __iar_builtin_USADA8 + #define __SSAT16 __iar_builtin_SSAT16 + #define __USAT16 __iar_builtin_USAT16 + #define __UXTB16 __iar_builtin_UXTB16 + #define __UXTAB16 __iar_builtin_UXTAB16 + #define __SXTB16 __iar_builtin_SXTB16 + #define __SXTAB16 __iar_builtin_SXTAB16 + #define __SMUAD __iar_builtin_SMUAD + #define __SMUADX __iar_builtin_SMUADX + #define __SMMLA __iar_builtin_SMMLA + #define __SMLAD __iar_builtin_SMLAD + #define __SMLADX __iar_builtin_SMLADX + #define __SMLALD __iar_builtin_SMLALD + #define __SMLALDX __iar_builtin_SMLALDX + #define __SMUSD __iar_builtin_SMUSD + #define __SMUSDX __iar_builtin_SMUSDX + #define __SMLSD __iar_builtin_SMLSD + #define __SMLSDX __iar_builtin_SMLSDX + #define __SMLSLD __iar_builtin_SMLSLD + #define __SMLSLDX __iar_builtin_SMLSLDX + #define __SEL __iar_builtin_SEL + #define __QADD __iar_builtin_QADD + #define __QSUB __iar_builtin_QSUB + #define __PKHBT __iar_builtin_PKHBT + #define __PKHTB __iar_builtin_PKHTB + #endif + +#else /* __ICCARM_INTRINSICS_VERSION__ == 2 */ + + #if __IAR_M0_FAMILY + /* Avoid clash between intrinsics.h and arm_math.h when compiling for Cortex-M0. */ + #define __CLZ __cmsis_iar_clz_not_active + #define __SSAT __cmsis_iar_ssat_not_active + #define __USAT __cmsis_iar_usat_not_active + #define __RBIT __cmsis_iar_rbit_not_active + #define __get_APSR __cmsis_iar_get_APSR_not_active + #endif + + + #if (!((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) )) + #define __get_FPSCR __cmsis_iar_get_FPSR_not_active + #define __set_FPSCR __cmsis_iar_set_FPSR_not_active + #endif + + #ifdef __INTRINSICS_INCLUDED + #error intrinsics.h is already included previously! + #endif + + #include + + #if __IAR_M0_FAMILY + /* Avoid clash between intrinsics.h and arm_math.h when compiling for Cortex-M0. */ + #undef __CLZ + #undef __SSAT + #undef __USAT + #undef __RBIT + #undef __get_APSR + + __STATIC_INLINE uint8_t __CLZ(uint32_t data) + { + if (data == 0U) { return 32U; } + + uint32_t count = 0U; + uint32_t mask = 0x80000000U; + + while ((data & mask) == 0U) + { + count += 1U; + mask = mask >> 1U; + } + return count; + } + + __STATIC_INLINE uint32_t __RBIT(uint32_t v) + { + uint8_t sc = 31U; + uint32_t r = v; + for (v >>= 1U; v; v >>= 1U) + { + r <<= 1U; + r |= v & 1U; + sc--; + } + return (r << sc); + } + + __STATIC_INLINE uint32_t __get_APSR(void) + { + uint32_t res; + __asm("MRS %0,APSR" : "=r" (res)); + return res; + } + + #endif + + #if (!((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ + (defined (__FPU_USED ) && (__FPU_USED == 1U)) )) + #undef __get_FPSCR + #undef __set_FPSCR + #define __get_FPSCR() (0) + #define __set_FPSCR(VALUE) ((void)VALUE) + #endif + + #pragma diag_suppress=Pe940 + #pragma diag_suppress=Pe177 + + #define __enable_irq __enable_interrupt + #define __disable_irq __disable_interrupt + #define __NOP __no_operation + + #define __get_xPSR __get_PSR + + #if (!defined(__ARM_ARCH_6M__) || __ARM_ARCH_6M__==0) + + __IAR_FT uint32_t __LDREXW(uint32_t volatile *ptr) + { + return __LDREX((unsigned long *)ptr); + } + + __IAR_FT uint32_t __STREXW(uint32_t value, uint32_t volatile *ptr) + { + return __STREX(value, (unsigned long *)ptr); + } + #endif + + + /* __CORTEX_M is defined in core_cm0.h, core_cm3.h and core_cm4.h. */ + #if (__CORTEX_M >= 0x03) + + __IAR_FT uint32_t __RRX(uint32_t value) + { + uint32_t result; + __ASM("RRX %0, %1" : "=r"(result) : "r" (value) : "cc"); + return(result); + } + + __IAR_FT void __set_BASEPRI_MAX(uint32_t value) + { + __asm volatile("MSR BASEPRI_MAX,%0"::"r" (value)); + } + + + #define __enable_fault_irq __enable_fiq + #define __disable_fault_irq __disable_fiq + + + #endif /* (__CORTEX_M >= 0x03) */ + + __IAR_FT uint32_t __ROR(uint32_t op1, uint32_t op2) + { + return (op1 >> op2) | (op1 << ((sizeof(op1)*8)-op2)); + } + + #if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + + __IAR_FT uint32_t __get_MSPLIM(void) + { + uint32_t res; + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + res = 0U; + #else + __asm volatile("MRS %0,MSPLIM" : "=r" (res)); + #endif + return res; + } + + __IAR_FT void __set_MSPLIM(uint32_t value) + { + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure MSPLIM is RAZ/WI + (void)value; + #else + __asm volatile("MSR MSPLIM,%0" :: "r" (value)); + #endif + } + + __IAR_FT uint32_t __get_PSPLIM(void) + { + uint32_t res; + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + res = 0U; + #else + __asm volatile("MRS %0,PSPLIM" : "=r" (res)); + #endif + return res; + } + + __IAR_FT void __set_PSPLIM(uint32_t value) + { + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)value; + #else + __asm volatile("MSR PSPLIM,%0" :: "r" (value)); + #endif + } + + __IAR_FT uint32_t __TZ_get_CONTROL_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,CONTROL_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_CONTROL_NS(uint32_t value) + { + __asm volatile("MSR CONTROL_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_PSP_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,PSP_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_PSP_NS(uint32_t value) + { + __asm volatile("MSR PSP_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_MSP_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,MSP_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_MSP_NS(uint32_t value) + { + __asm volatile("MSR MSP_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_SP_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,SP_NS" : "=r" (res)); + return res; + } + __IAR_FT void __TZ_set_SP_NS(uint32_t value) + { + __asm volatile("MSR SP_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_PRIMASK_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,PRIMASK_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_PRIMASK_NS(uint32_t value) + { + __asm volatile("MSR PRIMASK_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_BASEPRI_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,BASEPRI_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_BASEPRI_NS(uint32_t value) + { + __asm volatile("MSR BASEPRI_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_FAULTMASK_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,FAULTMASK_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_FAULTMASK_NS(uint32_t value) + { + __asm volatile("MSR FAULTMASK_NS,%0" :: "r" (value)); + } + + __IAR_FT uint32_t __TZ_get_PSPLIM_NS(void) + { + uint32_t res; + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + res = 0U; + #else + __asm volatile("MRS %0,PSPLIM_NS" : "=r" (res)); + #endif + return res; + } + + __IAR_FT void __TZ_set_PSPLIM_NS(uint32_t value) + { + #if (!(defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) && \ + (!defined (__ARM_FEATURE_CMSE ) || (__ARM_FEATURE_CMSE < 3))) + // without main extensions, the non-secure PSPLIM is RAZ/WI + (void)value; + #else + __asm volatile("MSR PSPLIM_NS,%0" :: "r" (value)); + #endif + } + + __IAR_FT uint32_t __TZ_get_MSPLIM_NS(void) + { + uint32_t res; + __asm volatile("MRS %0,MSPLIM_NS" : "=r" (res)); + return res; + } + + __IAR_FT void __TZ_set_MSPLIM_NS(uint32_t value) + { + __asm volatile("MSR MSPLIM_NS,%0" :: "r" (value)); + } + + #endif /* __ARM_ARCH_8M_MAIN__ or __ARM_ARCH_8M_BASE__ */ + +#endif /* __ICCARM_INTRINSICS_VERSION__ == 2 */ + +#define __BKPT(value) __asm volatile ("BKPT %0" : : "i"(value)) + +#if __IAR_M0_FAMILY + __STATIC_INLINE int32_t __SSAT(int32_t val, uint32_t sat) + { + if ((sat >= 1U) && (sat <= 32U)) + { + const int32_t max = (int32_t)((1U << (sat - 1U)) - 1U); + const int32_t min = -1 - max ; + if (val > max) + { + return max; + } + else if (val < min) + { + return min; + } + } + return val; + } + + __STATIC_INLINE uint32_t __USAT(int32_t val, uint32_t sat) + { + if (sat <= 31U) + { + const uint32_t max = ((1U << sat) - 1U); + if (val > (int32_t)max) + { + return max; + } + else if (val < 0) + { + return 0U; + } + } + return (uint32_t)val; + } +#endif + +#if (__CORTEX_M >= 0x03) /* __CORTEX_M is defined in core_cm0.h, core_cm3.h and core_cm4.h. */ + + __IAR_FT uint8_t __LDRBT(volatile uint8_t *addr) + { + uint32_t res; + __ASM("LDRBT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); + return ((uint8_t)res); + } + + __IAR_FT uint16_t __LDRHT(volatile uint16_t *addr) + { + uint32_t res; + __ASM("LDRHT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); + return ((uint16_t)res); + } + + __IAR_FT uint32_t __LDRT(volatile uint32_t *addr) + { + uint32_t res; + __ASM("LDRT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); + return res; + } + + __IAR_FT void __STRBT(uint8_t value, volatile uint8_t *addr) + { + __ASM("STRBT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); + } + + __IAR_FT void __STRHT(uint16_t value, volatile uint16_t *addr) + { + __ASM("STRHT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); + } + + __IAR_FT void __STRT(uint32_t value, volatile uint32_t *addr) + { + __ASM("STRT %1, [%0]" : : "r" (addr), "r" (value) : "memory"); + } + +#endif /* (__CORTEX_M >= 0x03) */ + +#if ((defined (__ARM_ARCH_8M_MAIN__ ) && (__ARM_ARCH_8M_MAIN__ == 1)) || \ + (defined (__ARM_ARCH_8M_BASE__ ) && (__ARM_ARCH_8M_BASE__ == 1)) ) + + + __IAR_FT uint8_t __LDAB(volatile uint8_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAB %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint8_t)res); + } + + __IAR_FT uint16_t __LDAH(volatile uint16_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAH %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint16_t)res); + } + + __IAR_FT uint32_t __LDA(volatile uint32_t *ptr) + { + uint32_t res; + __ASM volatile ("LDA %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return res; + } + + __IAR_FT void __STLB(uint8_t value, volatile uint8_t *ptr) + { + __ASM volatile ("STLB %1, [%0]" :: "r" (ptr), "r" (value) : "memory"); + } + + __IAR_FT void __STLH(uint16_t value, volatile uint16_t *ptr) + { + __ASM volatile ("STLH %1, [%0]" :: "r" (ptr), "r" (value) : "memory"); + } + + __IAR_FT void __STL(uint32_t value, volatile uint32_t *ptr) + { + __ASM volatile ("STL %1, [%0]" :: "r" (ptr), "r" (value) : "memory"); + } + + __IAR_FT uint8_t __LDAEXB(volatile uint8_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAEXB %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint8_t)res); + } + + __IAR_FT uint16_t __LDAEXH(volatile uint16_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAEXH %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return ((uint16_t)res); + } + + __IAR_FT uint32_t __LDAEX(volatile uint32_t *ptr) + { + uint32_t res; + __ASM volatile ("LDAEX %0, [%1]" : "=r" (res) : "r" (ptr) : "memory"); + return res; + } + + __IAR_FT uint32_t __STLEXB(uint8_t value, volatile uint8_t *ptr) + { + uint32_t res; + __ASM volatile ("STLEXB %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory"); + return res; + } + + __IAR_FT uint32_t __STLEXH(uint16_t value, volatile uint16_t *ptr) + { + uint32_t res; + __ASM volatile ("STLEXH %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory"); + return res; + } + + __IAR_FT uint32_t __STLEX(uint32_t value, volatile uint32_t *ptr) + { + uint32_t res; + __ASM volatile ("STLEX %0, %2, [%1]" : "=r" (res) : "r" (ptr), "r" (value) : "memory"); + return res; + } + +#endif /* __ARM_ARCH_8M_MAIN__ or __ARM_ARCH_8M_BASE__ */ + +#undef __IAR_FT +#undef __IAR_M0_FAMILY +#undef __ICCARM_V8 + +#pragma diag_default=Pe940 +#pragma diag_default=Pe177 + +#endif /* __CMSIS_ICCARM_H__ */ diff --git a/Chapter04/bare/platform/CMSIS/Include/cmsis_version.h b/Chapter04/bare/platform/CMSIS/Include/cmsis_version.h new file mode 100644 index 0000000..ae3f2e3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/cmsis_version.h @@ -0,0 +1,39 @@ +/**************************************************************************//** + * @file cmsis_version.h + * @brief CMSIS Core(M) Version definitions + * @version V5.0.2 + * @date 19. April 2017 + ******************************************************************************/ +/* + * Copyright (c) 2009-2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CMSIS_VERSION_H +#define __CMSIS_VERSION_H + +/* CMSIS Version definitions */ +#define __CM_CMSIS_VERSION_MAIN ( 5U) /*!< [31:16] CMSIS Core(M) main version */ +#define __CM_CMSIS_VERSION_SUB ( 1U) /*!< [15:0] CMSIS Core(M) sub version */ +#define __CM_CMSIS_VERSION ((__CM_CMSIS_VERSION_MAIN << 16U) | \ + __CM_CMSIS_VERSION_SUB ) /*!< CMSIS Core(M) version number */ +#endif diff --git a/Chapter04/bare/platform/CMSIS/Include/core_armv8mbl.h b/Chapter04/bare/platform/CMSIS/Include/core_armv8mbl.h new file mode 100644 index 0000000..ec76ab2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_armv8mbl.h @@ -0,0 +1,1918 @@ +/**************************************************************************//** + * @file core_armv8mbl.h + * @brief CMSIS Armv8-M Baseline Core Peripheral Access Layer Header File + * @version V5.0.7 + * @date 22. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_ARMV8MBL_H_GENERIC +#define __CORE_ARMV8MBL_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_ARMv8MBL + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS definitions */ +#define __ARMv8MBL_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __ARMv8MBL_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __ARMv8MBL_CMSIS_VERSION ((__ARMv8MBL_CMSIS_VERSION_MAIN << 16U) | \ + __ARMv8MBL_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M ( 2U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MBL_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_ARMV8MBL_H_DEPENDANT +#define __CORE_ARMV8MBL_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __ARMv8MBL_REV + #define __ARMv8MBL_REV 0x0000U + #warning "__ARMv8MBL_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __VTOR_PRESENT + #define __VTOR_PRESENT 0U + #warning "__VTOR_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif + + #ifndef __ETM_PRESENT + #define __ETM_PRESENT 0U + #warning "__ETM_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MTB_PRESENT + #define __MTB_PRESENT 0U + #warning "__MTB_PRESENT not defined in device header file; using default!" + #endif + +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group ARMv8MBL */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint32_t IPR[124U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ +#else + uint32_t RESERVED0; +#endif + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHPR[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + uint32_t RESERVED0[6U]; + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x3UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Sizes Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Sizes Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[809U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) Software Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) Software Lock Status Register */ + uint32_t RESERVED4[4U]; + __IM uint32_t TYPE; /*!< Offset: 0xFC8 (R/ ) Device Identifier Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_SWOSCALER_Pos 0U /*!< TPI ACPR: SWOSCALER Position */ +#define TPI_ACPR_SWOSCALER_Msk (0xFFFFUL /*<< TPI_ACPR_SWOSCALER_Pos*/) /*!< TPI ACPR: SWOSCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI Periodic Synchronization Control Register Definitions */ +#define TPI_PSCR_PSCount_Pos 0U /*!< TPI PSCR: PSCount Position */ +#define TPI_PSCR_PSCount_Msk (0x1FUL /*<< TPI_PSCR_PSCount_Pos*/) /*!< TPI PSCR: TPSCount Mask */ + +/* TPI Software Lock Status Register Definitions */ +#define TPI_LSR_nTT_Pos 1U /*!< TPI LSR: Not thirty-two bit. Position */ +#define TPI_LSR_nTT_Msk (0x1UL << TPI_LSR_nTT_Pos) /*!< TPI LSR: Not thirty-two bit. Mask */ + +#define TPI_LSR_SLK_Pos 1U /*!< TPI LSR: Software Lock status Position */ +#define TPI_LSR_SLK_Msk (0x1UL << TPI_LSR_SLK_Pos) /*!< TPI LSR: Software Lock status Mask */ + +#define TPI_LSR_SLI_Pos 0U /*!< TPI LSR: Software Lock implemented Position */ +#define TPI_LSR_SLI_Msk (0x1UL /*<< TPI_LSR_SLI_Pos*/) /*!< TPI LSR: Software Lock implemented Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFO depth Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFO depth Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + uint32_t RESERVED0[7U]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 1U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: EN Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: EN Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#endif +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register */ +#define CoreDebug_DEMCR_DWTENA_Pos 24U /*!< CoreDebug DEMCR: DWTENA Position */ +#define CoreDebug_DEMCR_DWTENA_Msk (1UL << CoreDebug_DEMCR_DWTENA_Pos) /*!< CoreDebug DEMCR: DWTENA Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + If VTOR is not present address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC_NS->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB_NS->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB_NS->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB_NS->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MBL_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_armv8mml.h b/Chapter04/bare/platform/CMSIS/Include/core_armv8mml.h new file mode 100644 index 0000000..2d0f106 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_armv8mml.h @@ -0,0 +1,2927 @@ +/**************************************************************************//** + * @file core_armv8mml.h + * @brief CMSIS Armv8-M Mainline Core Peripheral Access Layer Header File + * @version V5.0.7 + * @date 06. July 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_ARMV8MML_H_GENERIC +#define __CORE_ARMV8MML_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_ARMv8MML + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS Armv8MML definitions */ +#define __ARMv8MML_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __ARMv8MML_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __ARMv8MML_CMSIS_VERSION ((__ARMv8MML_CMSIS_VERSION_MAIN << 16U) | \ + __ARMv8MML_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (81U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined(__ARM_FEATURE_DSP) + #if defined(__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MML_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_ARMV8MML_H_DEPENDANT +#define __CORE_ARMV8MML_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __ARMv8MML_REV + #define __ARMv8MML_REV 0x0000U + #warning "__ARMv8MML_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DSP_PRESENT + #define __DSP_PRESENT 0U + #warning "__DSP_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group ARMv8MML */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:7; /*!< bit: 9..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t IT:2; /*!< bit: 25..26 saved IT state (read 0) */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_IT_Pos 25U /*!< xPSR: IT Position */ +#define xPSR_IT_Msk (3UL << xPSR_IT_Pos) /*!< xPSR: IT Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t FPCA:1; /*!< bit: 2 Floating-point context active */ + uint32_t SFPA:1; /*!< bit: 3 Secure floating-point active */ + uint32_t _reserved1:28; /*!< bit: 4..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SFPA_Pos 3U /*!< CONTROL: SFPA Position */ +#define CONTROL_SFPA_Msk (1UL << CONTROL_SFPA_Pos) /*!< CONTROL: SFPA Mask */ + +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint8_t IPR[496U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED6[580U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHPR[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t ID_PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t ID_DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ID_ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t ID_MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ID_ISAR[6U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + __IM uint32_t CLIDR; /*!< Offset: 0x078 (R/ ) Cache Level ID register */ + __IM uint32_t CTR; /*!< Offset: 0x07C (R/ ) Cache Type register */ + __IM uint32_t CCSIDR; /*!< Offset: 0x080 (R/ ) Cache Size ID Register */ + __IOM uint32_t CSSELR; /*!< Offset: 0x084 (R/W) Cache Size Selection Register */ + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + __IOM uint32_t NSACR; /*!< Offset: 0x08C (R/W) Non-Secure Access Control Register */ + uint32_t RESERVED3[92U]; + __OM uint32_t STIR; /*!< Offset: 0x200 ( /W) Software Triggered Interrupt Register */ + uint32_t RESERVED4[15U]; + __IM uint32_t MVFR0; /*!< Offset: 0x240 (R/ ) Media and VFP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x244 (R/ ) Media and VFP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x248 (R/ ) Media and VFP Feature Register 2 */ + uint32_t RESERVED5[1U]; + __OM uint32_t ICIALLU; /*!< Offset: 0x250 ( /W) I-Cache Invalidate All to PoU */ + uint32_t RESERVED6[1U]; + __OM uint32_t ICIMVAU; /*!< Offset: 0x258 ( /W) I-Cache Invalidate by MVA to PoU */ + __OM uint32_t DCIMVAC; /*!< Offset: 0x25C ( /W) D-Cache Invalidate by MVA to PoC */ + __OM uint32_t DCISW; /*!< Offset: 0x260 ( /W) D-Cache Invalidate by Set-way */ + __OM uint32_t DCCMVAU; /*!< Offset: 0x264 ( /W) D-Cache Clean by MVA to PoU */ + __OM uint32_t DCCMVAC; /*!< Offset: 0x268 ( /W) D-Cache Clean by MVA to PoC */ + __OM uint32_t DCCSW; /*!< Offset: 0x26C ( /W) D-Cache Clean by Set-way */ + __OM uint32_t DCCIMVAC; /*!< Offset: 0x270 ( /W) D-Cache Clean and Invalidate by MVA to PoC */ + __OM uint32_t DCCISW; /*!< Offset: 0x274 ( /W) D-Cache Clean and Invalidate by Set-way */ + uint32_t RESERVED7[6U]; + __IOM uint32_t ITCMCR; /*!< Offset: 0x290 (R/W) Instruction Tightly-Coupled Memory Control Register */ + __IOM uint32_t DTCMCR; /*!< Offset: 0x294 (R/W) Data Tightly-Coupled Memory Control Registers */ + __IOM uint32_t AHBPCR; /*!< Offset: 0x298 (R/W) AHBP Control Register */ + __IOM uint32_t CACR; /*!< Offset: 0x29C (R/W) L1 Cache Control Register */ + __IOM uint32_t AHBSCR; /*!< Offset: 0x2A0 (R/W) AHB Slave Control Register */ + uint32_t RESERVED8[1U]; + __IOM uint32_t ABFSR; /*!< Offset: 0x2A8 (R/W) Auxiliary Bus Fault Status Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTPENDED_Pos 20U /*!< SCB SHCSR: SECUREFAULTPENDED Position */ +#define SCB_SHCSR_SECUREFAULTPENDED_Msk (1UL << SCB_SHCSR_SECUREFAULTPENDED_Pos) /*!< SCB SHCSR: SECUREFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTENA_Pos 19U /*!< SCB SHCSR: SECUREFAULTENA Position */ +#define SCB_SHCSR_SECUREFAULTENA_Msk (1UL << SCB_SHCSR_SECUREFAULTENA_Pos) /*!< SCB SHCSR: SECUREFAULTENA Mask */ + +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_SECUREFAULTACT_Pos 4U /*!< SCB SHCSR: SECUREFAULTACT Position */ +#define SCB_SHCSR_SECUREFAULTACT_Msk (1UL << SCB_SHCSR_SECUREFAULTACT_Pos) /*!< SCB SHCSR: SECUREFAULTACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_STKOF_Pos (SCB_CFSR_USGFAULTSR_Pos + 4U) /*!< SCB CFSR (UFSR): STKOF Position */ +#define SCB_CFSR_STKOF_Msk (1UL << SCB_CFSR_STKOF_Pos) /*!< SCB CFSR (UFSR): STKOF Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/* SCB Non-Secure Access Control Register Definitions */ +#define SCB_NSACR_CP11_Pos 11U /*!< SCB NSACR: CP11 Position */ +#define SCB_NSACR_CP11_Msk (1UL << SCB_NSACR_CP11_Pos) /*!< SCB NSACR: CP11 Mask */ + +#define SCB_NSACR_CP10_Pos 10U /*!< SCB NSACR: CP10 Position */ +#define SCB_NSACR_CP10_Msk (1UL << SCB_NSACR_CP10_Pos) /*!< SCB NSACR: CP10 Mask */ + +#define SCB_NSACR_CPn_Pos 0U /*!< SCB NSACR: CPn Position */ +#define SCB_NSACR_CPn_Msk (1UL /*<< SCB_NSACR_CPn_Pos*/) /*!< SCB NSACR: CPn Mask */ + +/* SCB Cache Level ID Register Definitions */ +#define SCB_CLIDR_LOUU_Pos 27U /*!< SCB CLIDR: LoUU Position */ +#define SCB_CLIDR_LOUU_Msk (7UL << SCB_CLIDR_LOUU_Pos) /*!< SCB CLIDR: LoUU Mask */ + +#define SCB_CLIDR_LOC_Pos 24U /*!< SCB CLIDR: LoC Position */ +#define SCB_CLIDR_LOC_Msk (7UL << SCB_CLIDR_LOC_Pos) /*!< SCB CLIDR: LoC Mask */ + +/* SCB Cache Type Register Definitions */ +#define SCB_CTR_FORMAT_Pos 29U /*!< SCB CTR: Format Position */ +#define SCB_CTR_FORMAT_Msk (7UL << SCB_CTR_FORMAT_Pos) /*!< SCB CTR: Format Mask */ + +#define SCB_CTR_CWG_Pos 24U /*!< SCB CTR: CWG Position */ +#define SCB_CTR_CWG_Msk (0xFUL << SCB_CTR_CWG_Pos) /*!< SCB CTR: CWG Mask */ + +#define SCB_CTR_ERG_Pos 20U /*!< SCB CTR: ERG Position */ +#define SCB_CTR_ERG_Msk (0xFUL << SCB_CTR_ERG_Pos) /*!< SCB CTR: ERG Mask */ + +#define SCB_CTR_DMINLINE_Pos 16U /*!< SCB CTR: DminLine Position */ +#define SCB_CTR_DMINLINE_Msk (0xFUL << SCB_CTR_DMINLINE_Pos) /*!< SCB CTR: DminLine Mask */ + +#define SCB_CTR_IMINLINE_Pos 0U /*!< SCB CTR: ImInLine Position */ +#define SCB_CTR_IMINLINE_Msk (0xFUL /*<< SCB_CTR_IMINLINE_Pos*/) /*!< SCB CTR: ImInLine Mask */ + +/* SCB Cache Size ID Register Definitions */ +#define SCB_CCSIDR_WT_Pos 31U /*!< SCB CCSIDR: WT Position */ +#define SCB_CCSIDR_WT_Msk (1UL << SCB_CCSIDR_WT_Pos) /*!< SCB CCSIDR: WT Mask */ + +#define SCB_CCSIDR_WB_Pos 30U /*!< SCB CCSIDR: WB Position */ +#define SCB_CCSIDR_WB_Msk (1UL << SCB_CCSIDR_WB_Pos) /*!< SCB CCSIDR: WB Mask */ + +#define SCB_CCSIDR_RA_Pos 29U /*!< SCB CCSIDR: RA Position */ +#define SCB_CCSIDR_RA_Msk (1UL << SCB_CCSIDR_RA_Pos) /*!< SCB CCSIDR: RA Mask */ + +#define SCB_CCSIDR_WA_Pos 28U /*!< SCB CCSIDR: WA Position */ +#define SCB_CCSIDR_WA_Msk (1UL << SCB_CCSIDR_WA_Pos) /*!< SCB CCSIDR: WA Mask */ + +#define SCB_CCSIDR_NUMSETS_Pos 13U /*!< SCB CCSIDR: NumSets Position */ +#define SCB_CCSIDR_NUMSETS_Msk (0x7FFFUL << SCB_CCSIDR_NUMSETS_Pos) /*!< SCB CCSIDR: NumSets Mask */ + +#define SCB_CCSIDR_ASSOCIATIVITY_Pos 3U /*!< SCB CCSIDR: Associativity Position */ +#define SCB_CCSIDR_ASSOCIATIVITY_Msk (0x3FFUL << SCB_CCSIDR_ASSOCIATIVITY_Pos) /*!< SCB CCSIDR: Associativity Mask */ + +#define SCB_CCSIDR_LINESIZE_Pos 0U /*!< SCB CCSIDR: LineSize Position */ +#define SCB_CCSIDR_LINESIZE_Msk (7UL /*<< SCB_CCSIDR_LINESIZE_Pos*/) /*!< SCB CCSIDR: LineSize Mask */ + +/* SCB Cache Size Selection Register Definitions */ +#define SCB_CSSELR_LEVEL_Pos 1U /*!< SCB CSSELR: Level Position */ +#define SCB_CSSELR_LEVEL_Msk (7UL << SCB_CSSELR_LEVEL_Pos) /*!< SCB CSSELR: Level Mask */ + +#define SCB_CSSELR_IND_Pos 0U /*!< SCB CSSELR: InD Position */ +#define SCB_CSSELR_IND_Msk (1UL /*<< SCB_CSSELR_IND_Pos*/) /*!< SCB CSSELR: InD Mask */ + +/* SCB Software Triggered Interrupt Register Definitions */ +#define SCB_STIR_INTID_Pos 0U /*!< SCB STIR: INTID Position */ +#define SCB_STIR_INTID_Msk (0x1FFUL /*<< SCB_STIR_INTID_Pos*/) /*!< SCB STIR: INTID Mask */ + +/* SCB D-Cache Invalidate by Set-way Register Definitions */ +#define SCB_DCISW_WAY_Pos 30U /*!< SCB DCISW: Way Position */ +#define SCB_DCISW_WAY_Msk (3UL << SCB_DCISW_WAY_Pos) /*!< SCB DCISW: Way Mask */ + +#define SCB_DCISW_SET_Pos 5U /*!< SCB DCISW: Set Position */ +#define SCB_DCISW_SET_Msk (0x1FFUL << SCB_DCISW_SET_Pos) /*!< SCB DCISW: Set Mask */ + +/* SCB D-Cache Clean by Set-way Register Definitions */ +#define SCB_DCCSW_WAY_Pos 30U /*!< SCB DCCSW: Way Position */ +#define SCB_DCCSW_WAY_Msk (3UL << SCB_DCCSW_WAY_Pos) /*!< SCB DCCSW: Way Mask */ + +#define SCB_DCCSW_SET_Pos 5U /*!< SCB DCCSW: Set Position */ +#define SCB_DCCSW_SET_Msk (0x1FFUL << SCB_DCCSW_SET_Pos) /*!< SCB DCCSW: Set Mask */ + +/* SCB D-Cache Clean and Invalidate by Set-way Register Definitions */ +#define SCB_DCCISW_WAY_Pos 30U /*!< SCB DCCISW: Way Position */ +#define SCB_DCCISW_WAY_Msk (3UL << SCB_DCCISW_WAY_Pos) /*!< SCB DCCISW: Way Mask */ + +#define SCB_DCCISW_SET_Pos 5U /*!< SCB DCCISW: Set Position */ +#define SCB_DCCISW_SET_Msk (0x1FFUL << SCB_DCCISW_SET_Pos) /*!< SCB DCCISW: Set Mask */ + +/* Instruction Tightly-Coupled Memory Control Register Definitions */ +#define SCB_ITCMCR_SZ_Pos 3U /*!< SCB ITCMCR: SZ Position */ +#define SCB_ITCMCR_SZ_Msk (0xFUL << SCB_ITCMCR_SZ_Pos) /*!< SCB ITCMCR: SZ Mask */ + +#define SCB_ITCMCR_RETEN_Pos 2U /*!< SCB ITCMCR: RETEN Position */ +#define SCB_ITCMCR_RETEN_Msk (1UL << SCB_ITCMCR_RETEN_Pos) /*!< SCB ITCMCR: RETEN Mask */ + +#define SCB_ITCMCR_RMW_Pos 1U /*!< SCB ITCMCR: RMW Position */ +#define SCB_ITCMCR_RMW_Msk (1UL << SCB_ITCMCR_RMW_Pos) /*!< SCB ITCMCR: RMW Mask */ + +#define SCB_ITCMCR_EN_Pos 0U /*!< SCB ITCMCR: EN Position */ +#define SCB_ITCMCR_EN_Msk (1UL /*<< SCB_ITCMCR_EN_Pos*/) /*!< SCB ITCMCR: EN Mask */ + +/* Data Tightly-Coupled Memory Control Register Definitions */ +#define SCB_DTCMCR_SZ_Pos 3U /*!< SCB DTCMCR: SZ Position */ +#define SCB_DTCMCR_SZ_Msk (0xFUL << SCB_DTCMCR_SZ_Pos) /*!< SCB DTCMCR: SZ Mask */ + +#define SCB_DTCMCR_RETEN_Pos 2U /*!< SCB DTCMCR: RETEN Position */ +#define SCB_DTCMCR_RETEN_Msk (1UL << SCB_DTCMCR_RETEN_Pos) /*!< SCB DTCMCR: RETEN Mask */ + +#define SCB_DTCMCR_RMW_Pos 1U /*!< SCB DTCMCR: RMW Position */ +#define SCB_DTCMCR_RMW_Msk (1UL << SCB_DTCMCR_RMW_Pos) /*!< SCB DTCMCR: RMW Mask */ + +#define SCB_DTCMCR_EN_Pos 0U /*!< SCB DTCMCR: EN Position */ +#define SCB_DTCMCR_EN_Msk (1UL /*<< SCB_DTCMCR_EN_Pos*/) /*!< SCB DTCMCR: EN Mask */ + +/* AHBP Control Register Definitions */ +#define SCB_AHBPCR_SZ_Pos 1U /*!< SCB AHBPCR: SZ Position */ +#define SCB_AHBPCR_SZ_Msk (7UL << SCB_AHBPCR_SZ_Pos) /*!< SCB AHBPCR: SZ Mask */ + +#define SCB_AHBPCR_EN_Pos 0U /*!< SCB AHBPCR: EN Position */ +#define SCB_AHBPCR_EN_Msk (1UL /*<< SCB_AHBPCR_EN_Pos*/) /*!< SCB AHBPCR: EN Mask */ + +/* L1 Cache Control Register Definitions */ +#define SCB_CACR_FORCEWT_Pos 2U /*!< SCB CACR: FORCEWT Position */ +#define SCB_CACR_FORCEWT_Msk (1UL << SCB_CACR_FORCEWT_Pos) /*!< SCB CACR: FORCEWT Mask */ + +#define SCB_CACR_ECCEN_Pos 1U /*!< SCB CACR: ECCEN Position */ +#define SCB_CACR_ECCEN_Msk (1UL << SCB_CACR_ECCEN_Pos) /*!< SCB CACR: ECCEN Mask */ + +#define SCB_CACR_SIWT_Pos 0U /*!< SCB CACR: SIWT Position */ +#define SCB_CACR_SIWT_Msk (1UL /*<< SCB_CACR_SIWT_Pos*/) /*!< SCB CACR: SIWT Mask */ + +/* AHBS Control Register Definitions */ +#define SCB_AHBSCR_INITCOUNT_Pos 11U /*!< SCB AHBSCR: INITCOUNT Position */ +#define SCB_AHBSCR_INITCOUNT_Msk (0x1FUL << SCB_AHBPCR_INITCOUNT_Pos) /*!< SCB AHBSCR: INITCOUNT Mask */ + +#define SCB_AHBSCR_TPRI_Pos 2U /*!< SCB AHBSCR: TPRI Position */ +#define SCB_AHBSCR_TPRI_Msk (0x1FFUL << SCB_AHBPCR_TPRI_Pos) /*!< SCB AHBSCR: TPRI Mask */ + +#define SCB_AHBSCR_CTL_Pos 0U /*!< SCB AHBSCR: CTL Position*/ +#define SCB_AHBSCR_CTL_Msk (3UL /*<< SCB_AHBPCR_CTL_Pos*/) /*!< SCB AHBSCR: CTL Mask */ + +/* Auxiliary Bus Fault Status Register Definitions */ +#define SCB_ABFSR_AXIMTYPE_Pos 8U /*!< SCB ABFSR: AXIMTYPE Position*/ +#define SCB_ABFSR_AXIMTYPE_Msk (3UL << SCB_ABFSR_AXIMTYPE_Pos) /*!< SCB ABFSR: AXIMTYPE Mask */ + +#define SCB_ABFSR_EPPB_Pos 4U /*!< SCB ABFSR: EPPB Position*/ +#define SCB_ABFSR_EPPB_Msk (1UL << SCB_ABFSR_EPPB_Pos) /*!< SCB ABFSR: EPPB Mask */ + +#define SCB_ABFSR_AXIM_Pos 3U /*!< SCB ABFSR: AXIM Position*/ +#define SCB_ABFSR_AXIM_Msk (1UL << SCB_ABFSR_AXIM_Pos) /*!< SCB ABFSR: AXIM Mask */ + +#define SCB_ABFSR_AHBP_Pos 2U /*!< SCB ABFSR: AHBP Position*/ +#define SCB_ABFSR_AHBP_Msk (1UL << SCB_ABFSR_AHBP_Pos) /*!< SCB ABFSR: AHBP Mask */ + +#define SCB_ABFSR_DTCM_Pos 1U /*!< SCB ABFSR: DTCM Position*/ +#define SCB_ABFSR_DTCM_Msk (1UL << SCB_ABFSR_DTCM_Pos) /*!< SCB ABFSR: DTCM Mask */ + +#define SCB_ABFSR_ITCM_Pos 0U /*!< SCB ABFSR: ITCM Position*/ +#define SCB_ABFSR_ITCM_Msk (1UL /*<< SCB_ABFSR_ITCM_Pos*/) /*!< SCB ABFSR: ITCM Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ + __IOM uint32_t CPPWR; /*!< Offset: 0x00C (R/W) Coprocessor Power Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) ITM Device Architecture Register */ + uint32_t RESERVED6[4U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Stimulus Port Register Definitions */ +#define ITM_STIM_DISABLED_Pos 1U /*!< ITM STIM: DISABLED Position */ +#define ITM_STIM_DISABLED_Msk (0x1UL << ITM_STIM_DISABLED_Pos) /*!< ITM STIM: DISABLED Mask */ + +#define ITM_STIM_FIFOREADY_Pos 0U /*!< ITM STIM: FIFOREADY Position */ +#define ITM_STIM_FIFOREADY_Msk (0x1UL /*<< ITM_STIM_FIFOREADY_Pos*/) /*!< ITM STIM: FIFOREADY Mask */ + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TRACEBUSID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TRACEBUSID_Msk (0x7FUL << ITM_TCR_TRACEBUSID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPRESCALE_Pos 8U /*!< ITM TCR: TSPRESCALE Position */ +#define ITM_TCR_TSPRESCALE_Msk (3UL << ITM_TCR_TSPRESCALE_Pos) /*!< ITM TCR: TSPRESCALE Mask */ + +#define ITM_TCR_STALLENA_Pos 5U /*!< ITM TCR: STALLENA Position */ +#define ITM_TCR_STALLENA_Msk (1UL << ITM_TCR_STALLENA_Pos) /*!< ITM TCR: STALLENA Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ + uint32_t RESERVED32[934U]; + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R ) Lock Status Register */ + uint32_t RESERVED33[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) Device Architecture Register */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCDISS_Pos 23U /*!< DWT CTRL: CYCDISS Position */ +#define DWT_CTRL_CYCDISS_Msk (0x1UL << DWT_CTRL_CYCDISS_Pos) /*!< DWT CTRL: CYCDISS Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x1UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Sizes Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Sizes Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[809U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) Software Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) Software Lock Status Register */ + uint32_t RESERVED4[4U]; + __IM uint32_t TYPE; /*!< Offset: 0xFC8 (R/ ) Device Identifier Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_SWOSCALER_Pos 0U /*!< TPI ACPR: SWOSCALER Position */ +#define TPI_ACPR_SWOSCALER_Msk (0xFFFFUL /*<< TPI_ACPR_SWOSCALER_Pos*/) /*!< TPI ACPR: SWOSCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI Periodic Synchronization Control Register Definitions */ +#define TPI_PSCR_PSCount_Pos 0U /*!< TPI PSCR: PSCount Position */ +#define TPI_PSCR_PSCount_Msk (0x1FUL /*<< TPI_PSCR_PSCount_Pos*/) /*!< TPI PSCR: TPSCount Mask */ + +/* TPI Software Lock Status Register Definitions */ +#define TPI_LSR_nTT_Pos 1U /*!< TPI LSR: Not thirty-two bit. Position */ +#define TPI_LSR_nTT_Msk (0x1UL << TPI_LSR_nTT_Pos) /*!< TPI LSR: Not thirty-two bit. Mask */ + +#define TPI_LSR_SLK_Pos 1U /*!< TPI LSR: Software Lock status Position */ +#define TPI_LSR_SLK_Msk (0x1UL << TPI_LSR_SLK_Pos) /*!< TPI LSR: Software Lock status Mask */ + +#define TPI_LSR_SLI_Pos 0U /*!< TPI LSR: Software Lock implemented Position */ +#define TPI_LSR_SLI_Msk (0x1UL /*<< TPI_LSR_SLI_Pos*/) /*!< TPI LSR: Software Lock implemented Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFO depth Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFO depth Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Region Base Address Register Alias 1 */ + __IOM uint32_t RLAR_A1; /*!< Offset: 0x018 (R/W) MPU Region Limit Address Register Alias 1 */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Region Base Address Register Alias 2 */ + __IOM uint32_t RLAR_A2; /*!< Offset: 0x020 (R/W) MPU Region Limit Address Register Alias 2 */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Region Base Address Register Alias 3 */ + __IOM uint32_t RLAR_A3; /*!< Offset: 0x028 (R/W) MPU Region Limit Address Register Alias 3 */ + uint32_t RESERVED0[1]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: Region enable bit Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: Region enable bit Disable Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#else + uint32_t RESERVED0[3]; +#endif + __IOM uint32_t SFSR; /*!< Offset: 0x014 (R/W) Secure Fault Status Register */ + __IOM uint32_t SFAR; /*!< Offset: 0x018 (R/W) Secure Fault Address Register */ +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/* Secure Fault Status Register Definitions */ +#define SAU_SFSR_LSERR_Pos 7U /*!< SAU SFSR: LSERR Position */ +#define SAU_SFSR_LSERR_Msk (1UL << SAU_SFSR_LSERR_Pos) /*!< SAU SFSR: LSERR Mask */ + +#define SAU_SFSR_SFARVALID_Pos 6U /*!< SAU SFSR: SFARVALID Position */ +#define SAU_SFSR_SFARVALID_Msk (1UL << SAU_SFSR_SFARVALID_Pos) /*!< SAU SFSR: SFARVALID Mask */ + +#define SAU_SFSR_LSPERR_Pos 5U /*!< SAU SFSR: LSPERR Position */ +#define SAU_SFSR_LSPERR_Msk (1UL << SAU_SFSR_LSPERR_Pos) /*!< SAU SFSR: LSPERR Mask */ + +#define SAU_SFSR_INVTRAN_Pos 4U /*!< SAU SFSR: INVTRAN Position */ +#define SAU_SFSR_INVTRAN_Msk (1UL << SAU_SFSR_INVTRAN_Pos) /*!< SAU SFSR: INVTRAN Mask */ + +#define SAU_SFSR_AUVIOL_Pos 3U /*!< SAU SFSR: AUVIOL Position */ +#define SAU_SFSR_AUVIOL_Msk (1UL << SAU_SFSR_AUVIOL_Pos) /*!< SAU SFSR: AUVIOL Mask */ + +#define SAU_SFSR_INVER_Pos 2U /*!< SAU SFSR: INVER Position */ +#define SAU_SFSR_INVER_Msk (1UL << SAU_SFSR_INVER_Pos) /*!< SAU SFSR: INVER Mask */ + +#define SAU_SFSR_INVIS_Pos 1U /*!< SAU SFSR: INVIS Position */ +#define SAU_SFSR_INVIS_Msk (1UL << SAU_SFSR_INVIS_Pos) /*!< SAU SFSR: INVIS Mask */ + +#define SAU_SFSR_INVEP_Pos 0U /*!< SAU SFSR: INVEP Position */ +#define SAU_SFSR_INVEP_Msk (1UL /*<< SAU_SFSR_INVEP_Pos*/) /*!< SAU SFSR: INVEP Mask */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_LSPENS_Pos 29U /*!< FPCCR: LSPENS Position */ +#define FPU_FPCCR_LSPENS_Msk (1UL << FPU_FPCCR_LSPENS_Pos) /*!< FPCCR: LSPENS bit Mask */ + +#define FPU_FPCCR_CLRONRET_Pos 28U /*!< FPCCR: CLRONRET Position */ +#define FPU_FPCCR_CLRONRET_Msk (1UL << FPU_FPCCR_CLRONRET_Pos) /*!< FPCCR: CLRONRET bit Mask */ + +#define FPU_FPCCR_CLRONRETS_Pos 27U /*!< FPCCR: CLRONRETS Position */ +#define FPU_FPCCR_CLRONRETS_Msk (1UL << FPU_FPCCR_CLRONRETS_Pos) /*!< FPCCR: CLRONRETS bit Mask */ + +#define FPU_FPCCR_TS_Pos 26U /*!< FPCCR: TS Position */ +#define FPU_FPCCR_TS_Msk (1UL << FPU_FPCCR_TS_Pos) /*!< FPCCR: TS bit Mask */ + +#define FPU_FPCCR_UFRDY_Pos 10U /*!< FPCCR: UFRDY Position */ +#define FPU_FPCCR_UFRDY_Msk (1UL << FPU_FPCCR_UFRDY_Pos) /*!< FPCCR: UFRDY bit Mask */ + +#define FPU_FPCCR_SPLIMVIOL_Pos 9U /*!< FPCCR: SPLIMVIOL Position */ +#define FPU_FPCCR_SPLIMVIOL_Msk (1UL << FPU_FPCCR_SPLIMVIOL_Pos) /*!< FPCCR: SPLIMVIOL bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_SFRDY_Pos 7U /*!< FPCCR: SFRDY Position */ +#define FPU_FPCCR_SFRDY_Msk (1UL << FPU_FPCCR_SFRDY_Pos) /*!< FPCCR: SFRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_S_Pos 2U /*!< FPCCR: Security status of the FP context bit Position */ +#define FPU_FPCCR_S_Msk (1UL << FPU_FPCCR_S_Pos) /*!< FPCCR: Security status of the FP context bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + #define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + + #define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ + #define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCnSCB_NS ((SCnSCB_Type *) SCS_BASE_NS ) /*!< System control Register not in SCB(non-secure address space) */ + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + + #define FPU_BASE_NS (SCS_BASE_NS + 0x0F30UL) /*!< Floating Point Unit (non-secure address space) */ + #define FPU_NS ((FPU_Type *) FPU_BASE_NS ) /*!< Floating Point Unit (non-secure address space) */ + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priorty group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Set Priority Grouping (non-secure) + \details Sets the non-secure priority grouping field when in secure state using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void TZ_NVIC_SetPriorityGrouping_NS(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB_NS->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priorty group */ + SCB_NS->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping (non-secure) + \details Reads the priority grouping field from the non-secure NVIC when in secure state. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriorityGrouping_NS(void) +{ + return ((uint32_t)((SCB_NS->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC_NS->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = FPU->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x220U) + { + return 2U; /* Double + Single precision FPU */ + } + else if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_ARMV8MML_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm0.h b/Chapter04/bare/platform/CMSIS/Include/core_cm0.h new file mode 100644 index 0000000..6f82227 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm0.h @@ -0,0 +1,949 @@ +/**************************************************************************//** + * @file core_cm0.h + * @brief CMSIS Cortex-M0 Core Peripheral Access Layer Header File + * @version V5.0.5 + * @date 28. May 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM0_H_GENERIC +#define __CORE_CM0_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M0 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM0 definitions */ +#define __CM0_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM0_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM0_CMSIS_VERSION ((__CM0_CMSIS_VERSION_MAIN << 16U) | \ + __CM0_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (0U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM0_H_DEPENDANT +#define __CORE_CM0_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM0_REV + #define __CM0_REV 0x0000U + #warning "__CM0_REV not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M0 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t _reserved0:1; /*!< bit: 0 Reserved */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + uint32_t RESERVED0; + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Cortex-M0 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the Cortex-M0 header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M0 */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + Address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)0x0U; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)0x0U; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm0plus.h b/Chapter04/bare/platform/CMSIS/Include/core_cm0plus.h new file mode 100644 index 0000000..b9377e8 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm0plus.h @@ -0,0 +1,1083 @@ +/**************************************************************************//** + * @file core_cm0plus.h + * @brief CMSIS Cortex-M0+ Core Peripheral Access Layer Header File + * @version V5.0.6 + * @date 28. May 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM0PLUS_H_GENERIC +#define __CORE_CM0PLUS_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex-M0+ + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM0+ definitions */ +#define __CM0PLUS_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM0PLUS_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM0PLUS_CMSIS_VERSION ((__CM0PLUS_CMSIS_VERSION_MAIN << 16U) | \ + __CM0PLUS_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (0U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0PLUS_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM0PLUS_H_DEPENDANT +#define __CORE_CM0PLUS_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM0PLUS_REV + #define __CM0PLUS_REV 0x0000U + #warning "__CM0PLUS_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __VTOR_PRESENT + #define __VTOR_PRESENT 0U + #warning "__VTOR_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex-M0+ */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ +#else + uint32_t RESERVED0; +#endif + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) +/* SCB Interrupt Control State Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 8U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0xFFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 1U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 8U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0xFFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Cortex-M0+ Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the Cortex-M0+ header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M0+ */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + If VTOR is not present address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; + +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM0PLUS_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm1.h b/Chapter04/bare/platform/CMSIS/Include/core_cm1.h new file mode 100644 index 0000000..fd1c407 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm1.h @@ -0,0 +1,976 @@ +/**************************************************************************//** + * @file core_cm1.h + * @brief CMSIS Cortex-M1 Core Peripheral Access Layer Header File + * @version V1.0.0 + * @date 23. July 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM1_H_GENERIC +#define __CORE_CM1_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M1 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM1 definitions */ +#define __CM1_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM1_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM1_CMSIS_VERSION ((__CM1_CMSIS_VERSION_MAIN << 16U) | \ + __CM1_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (1U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM1_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM1_H_DEPENDANT +#define __CORE_CM1_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM1_REV + #define __CM1_REV 0x0100U + #warning "__CM1_REV not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M1 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t _reserved0:1; /*!< bit: 0 Reserved */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + uint32_t RESERVED0; + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_ITCMUAEN_Pos 4U /*!< ACTLR: Instruction TCM Upper Alias Enable Position */ +#define SCnSCB_ACTLR_ITCMUAEN_Msk (1UL << SCnSCB_ACTLR_ITCMUAEN_Pos) /*!< ACTLR: Instruction TCM Upper Alias Enable Mask */ + +#define SCnSCB_ACTLR_ITCMLAEN_Pos 3U /*!< ACTLR: Instruction TCM Lower Alias Enable Position */ +#define SCnSCB_ACTLR_ITCMLAEN_Msk (1UL << SCnSCB_ACTLR_ITCMLAEN_Pos) /*!< ACTLR: Instruction TCM Lower Alias Enable Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Cortex-M1 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the Cortex-M1 header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for Cortex-M1 */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + Address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)0x0U; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)0x0U; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM1_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm23.h b/Chapter04/bare/platform/CMSIS/Include/core_cm23.h new file mode 100644 index 0000000..8202a8d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm23.h @@ -0,0 +1,1993 @@ +/**************************************************************************//** + * @file core_cm23.h + * @brief CMSIS Cortex-M23 Core Peripheral Access Layer Header File + * @version V5.0.7 + * @date 22. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM23_H_GENERIC +#define __CORE_CM23_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M23 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS definitions */ +#define __CM23_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM23_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM23_CMSIS_VERSION ((__CM23_CMSIS_VERSION_MAIN << 16U) | \ + __CM23_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (23U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM23_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM23_H_DEPENDANT +#define __CORE_CM23_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM23_REV + #define __CM23_REV 0x0000U + #warning "__CM23_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __VTOR_PRESENT + #define __VTOR_PRESENT 0U + #warning "__VTOR_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif + + #ifndef __ETM_PRESENT + #define __ETM_PRESENT 0U + #warning "__ETM_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MTB_PRESENT + #define __MTB_PRESENT 0U + #warning "__MTB_PRESENT not defined in device header file; using default!" + #endif + +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M23 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint32_t IPR[124U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ +#else + uint32_t RESERVED0; +#endif + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED1; + __IOM uint32_t SHPR[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + uint32_t RESERVED0[6U]; + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x3UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t ITFTTD0; /*!< Offset: 0xEEC (R/ ) Integration Test FIFO Test Data 0 Register */ + __IOM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/W) Integration Test ATB Control Register 2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) Integration Test ATB Control Register 0 */ + __IM uint32_t ITFTTD1; /*!< Offset: 0xEFC (R/ ) Integration Test FIFO Test Data 1 Register */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) Device Configuration Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Identifier Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration Test FIFO Test Data 0 Register Definitions */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD0: ATB Interface 2 ATVALIDPosition */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD0: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD0_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD0: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD0_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data2_Pos 16U /*!< TPI ITFTTD0: ATB Interface 1 data2 Position */ +#define TPI_ITFTTD0_ATB_IF1_data2_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data2 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data1_Pos 8U /*!< TPI ITFTTD0: ATB Interface 1 data1 Position */ +#define TPI_ITFTTD0_ATB_IF1_data1_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data1 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data0_Pos 0U /*!< TPI ITFTTD0: ATB Interface 1 data0 Position */ +#define TPI_ITFTTD0_ATB_IF1_data0_Msk (0xFFUL /*<< TPI_ITFTTD0_ATB_IF1_data0_Pos*/) /*!< TPI ITFTTD0: ATB Interface 1 data0 Mask */ + +/* TPI Integration Test ATB Control Register 2 Register Definitions */ +#define TPI_ITATBCTR2_AFVALID2S_Pos 1U /*!< TPI ITATBCTR2: AFVALID2S Position */ +#define TPI_ITATBCTR2_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID2S_Pos) /*!< TPI ITATBCTR2: AFVALID2SS Mask */ + +#define TPI_ITATBCTR2_AFVALID1S_Pos 1U /*!< TPI ITATBCTR2: AFVALID1S Position */ +#define TPI_ITATBCTR2_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID1S_Pos) /*!< TPI ITATBCTR2: AFVALID1SS Mask */ + +#define TPI_ITATBCTR2_ATREADY2S_Pos 0U /*!< TPI ITATBCTR2: ATREADY2S Position */ +#define TPI_ITATBCTR2_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2S_Pos*/) /*!< TPI ITATBCTR2: ATREADY2S Mask */ + +#define TPI_ITATBCTR2_ATREADY1S_Pos 0U /*!< TPI ITATBCTR2: ATREADY1S Position */ +#define TPI_ITATBCTR2_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1S_Pos*/) /*!< TPI ITATBCTR2: ATREADY1S Mask */ + +/* TPI Integration Test FIFO Test Data 1 Register Definitions */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD1: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD1_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD1: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD1_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data2_Pos 16U /*!< TPI ITFTTD1: ATB Interface 2 data2 Position */ +#define TPI_ITFTTD1_ATB_IF2_data2_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data2 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data1_Pos 8U /*!< TPI ITFTTD1: ATB Interface 2 data1 Position */ +#define TPI_ITFTTD1_ATB_IF2_data1_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data1 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data0_Pos 0U /*!< TPI ITFTTD1: ATB Interface 2 data0 Position */ +#define TPI_ITFTTD1_ATB_IF2_data0_Msk (0xFFUL /*<< TPI_ITFTTD1_ATB_IF2_data0_Pos*/) /*!< TPI ITFTTD1: ATB Interface 2 data0 Mask */ + +/* TPI Integration Test ATB Control Register 0 Definitions */ +#define TPI_ITATBCTR0_AFVALID2S_Pos 1U /*!< TPI ITATBCTR0: AFVALID2S Position */ +#define TPI_ITATBCTR0_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID2S_Pos) /*!< TPI ITATBCTR0: AFVALID2SS Mask */ + +#define TPI_ITATBCTR0_AFVALID1S_Pos 1U /*!< TPI ITATBCTR0: AFVALID1S Position */ +#define TPI_ITATBCTR0_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID1S_Pos) /*!< TPI ITATBCTR0: AFVALID1SS Mask */ + +#define TPI_ITATBCTR0_ATREADY2S_Pos 0U /*!< TPI ITATBCTR0: ATREADY2S Position */ +#define TPI_ITATBCTR0_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2S_Pos*/) /*!< TPI ITATBCTR0: ATREADY2S Mask */ + +#define TPI_ITATBCTR0_ATREADY1S_Pos 0U /*!< TPI ITATBCTR0: ATREADY1S Position */ +#define TPI_ITATBCTR0_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1S_Pos*/) /*!< TPI ITATBCTR0: ATREADY1S Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFOSZ Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFOSZ Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x3FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + uint32_t RESERVED0[7U]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 1U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: EN Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: EN Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#endif +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register */ +#define CoreDebug_DEMCR_DWTENA_Pos 24U /*!< CoreDebug DEMCR: DWTENA Position */ +#define CoreDebug_DEMCR_DWTENA_Msk (1UL << CoreDebug_DEMCR_DWTENA_Pos) /*!< CoreDebug DEMCR: DWTENA Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else +/*#define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping not available for Cortex-M23 */ +/*#define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping not available for Cortex-M23 */ + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + +#define __NVIC_SetPriorityGrouping(X) (void)(X) +#define __NVIC_GetPriorityGrouping() (0U) + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + If VTOR is not present address 0 must be mapped to SRAM. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ +#if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) + uint32_t *vectors = (uint32_t *)SCB->VTOR; +#else + uint32_t *vectors = (uint32_t *)0x0U; +#endif + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[_IP_IDX(IRQn)] = ((uint32_t)(NVIC_NS->IPR[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB_NS->SHPR[_SHP_IDX(IRQn)] = ((uint32_t)(SCB_NS->SHPR[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IPR[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB_NS->SHPR[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM23_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm3.h b/Chapter04/bare/platform/CMSIS/Include/core_cm3.h new file mode 100644 index 0000000..b0dfbd3 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm3.h @@ -0,0 +1,1941 @@ +/**************************************************************************//** + * @file core_cm3.h + * @brief CMSIS Cortex-M3 Core Peripheral Access Layer Header File + * @version V5.0.8 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM3_H_GENERIC +#define __CORE_CM3_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M3 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM3 definitions */ +#define __CM3_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM3_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM3_CMSIS_VERSION ((__CM3_CMSIS_VERSION_MAIN << 16U) | \ + __CM3_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (3U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM3_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM3_H_DEPENDANT +#define __CORE_CM3_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM3_REV + #define __CM3_REV 0x0200U + #warning "__CM3_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M3 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:27; /*!< bit: 0..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t _reserved1:8; /*!< bit: 16..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHP[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[5U]; + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#if defined (__CM3_REV) && (__CM3_REV < 0x0201U) /* core r2p1 */ +#define SCB_VTOR_TBLBASE_Pos 29U /*!< SCB VTOR: TBLBASE Position */ +#define SCB_VTOR_TBLBASE_Msk (1UL << SCB_VTOR_TBLBASE_Pos) /*!< SCB VTOR: TBLBASE Mask */ + +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x3FFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#else +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ +#endif + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ +#if defined (__CM3_REV) && (__CM3_REV >= 0x200U) + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +#else + uint32_t RESERVED1[1U]; +#endif +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/* Auxiliary Control Register Definitions */ + +#define SCnSCB_ACTLR_DISFOLD_Pos 2U /*!< ACTLR: DISFOLD Position */ +#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos) /*!< ACTLR: DISFOLD Mask */ + +#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1U /*!< ACTLR: DISDEFWBUF Position */ +#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos) /*!< ACTLR: DISDEFWBUF Mask */ + +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM3_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm33.h b/Chapter04/bare/platform/CMSIS/Include/core_cm33.h new file mode 100644 index 0000000..02f82e2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm33.h @@ -0,0 +1,3002 @@ +/**************************************************************************//** + * @file core_cm33.h + * @brief CMSIS Cortex-M33 Core Peripheral Access Layer Header File + * @version V5.0.9 + * @date 06. July 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM33_H_GENERIC +#define __CORE_CM33_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M33 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM33 definitions */ +#define __CM33_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM33_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM33_CMSIS_VERSION ((__CM33_CMSIS_VERSION_MAIN << 16U) | \ + __CM33_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (33U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined (__TARGET_FPU_VFP) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined (__ARM_PCS_VFP) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined (__ARMVFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + + #if defined (__ARM_FEATURE_DSP) && (__ARM_FEATURE_DSP == 1U) + #if defined (__DSP_PRESENT) && (__DSP_PRESENT == 1U) + #define __DSP_USED 1U + #else + #error "Compiler generates DSP (SIMD) instructions for a devices without DSP extensions (check __DSP_PRESENT)" + #define __DSP_USED 0U + #endif + #else + #define __DSP_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined (__TI_VFP_SUPPORT__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined (__FPU_VFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM33_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM33_H_DEPENDANT +#define __CORE_CM33_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM33_REV + #define __CM33_REV 0x0000U + #warning "__CM33_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __SAUREGION_PRESENT + #define __SAUREGION_PRESENT 0U + #warning "__SAUREGION_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DSP_PRESENT + #define __DSP_PRESENT 0U + #warning "__DSP_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M33 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core SAU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:7; /*!< bit: 9..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t IT:2; /*!< bit: 25..26 saved IT state (read 0) */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_IT_Pos 25U /*!< xPSR: IT Position */ +#define xPSR_IT_Msk (3UL << xPSR_IT_Pos) /*!< xPSR: IT Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack-pointer select */ + uint32_t FPCA:1; /*!< bit: 2 Floating-point context active */ + uint32_t SFPA:1; /*!< bit: 3 Secure floating-point active */ + uint32_t _reserved1:28; /*!< bit: 4..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SFPA_Pos 3U /*!< CONTROL: SFPA Position */ +#define CONTROL_SFPA_Msk (1UL << CONTROL_SFPA_Pos) /*!< CONTROL: SFPA Mask */ + +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[16U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[16U]; + __IOM uint32_t ICER[16U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[16U]; + __IOM uint32_t ISPR[16U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[16U]; + __IOM uint32_t ICPR[16U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[16U]; + __IOM uint32_t IABR[16U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[16U]; + __IOM uint32_t ITNS[16U]; /*!< Offset: 0x280 (R/W) Interrupt Non-Secure State Register */ + uint32_t RESERVED5[16U]; + __IOM uint8_t IPR[496U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED6[580U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHPR[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t ID_PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t ID_DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ID_ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t ID_MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ID_ISAR[6U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + __IM uint32_t CLIDR; /*!< Offset: 0x078 (R/ ) Cache Level ID register */ + __IM uint32_t CTR; /*!< Offset: 0x07C (R/ ) Cache Type register */ + __IM uint32_t CCSIDR; /*!< Offset: 0x080 (R/ ) Cache Size ID Register */ + __IOM uint32_t CSSELR; /*!< Offset: 0x084 (R/W) Cache Size Selection Register */ + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + __IOM uint32_t NSACR; /*!< Offset: 0x08C (R/W) Non-Secure Access Control Register */ + uint32_t RESERVED3[92U]; + __OM uint32_t STIR; /*!< Offset: 0x200 ( /W) Software Triggered Interrupt Register */ + uint32_t RESERVED4[15U]; + __IM uint32_t MVFR0; /*!< Offset: 0x240 (R/ ) Media and VFP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x244 (R/ ) Media and VFP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x248 (R/ ) Media and VFP Feature Register 2 */ + uint32_t RESERVED5[1U]; + __OM uint32_t ICIALLU; /*!< Offset: 0x250 ( /W) I-Cache Invalidate All to PoU */ + uint32_t RESERVED6[1U]; + __OM uint32_t ICIMVAU; /*!< Offset: 0x258 ( /W) I-Cache Invalidate by MVA to PoU */ + __OM uint32_t DCIMVAC; /*!< Offset: 0x25C ( /W) D-Cache Invalidate by MVA to PoC */ + __OM uint32_t DCISW; /*!< Offset: 0x260 ( /W) D-Cache Invalidate by Set-way */ + __OM uint32_t DCCMVAU; /*!< Offset: 0x264 ( /W) D-Cache Clean by MVA to PoU */ + __OM uint32_t DCCMVAC; /*!< Offset: 0x268 ( /W) D-Cache Clean by MVA to PoC */ + __OM uint32_t DCCSW; /*!< Offset: 0x26C ( /W) D-Cache Clean by Set-way */ + __OM uint32_t DCCIMVAC; /*!< Offset: 0x270 ( /W) D-Cache Clean and Invalidate by MVA to PoC */ + __OM uint32_t DCCISW; /*!< Offset: 0x274 ( /W) D-Cache Clean and Invalidate by Set-way */ + uint32_t RESERVED7[6U]; + __IOM uint32_t ITCMCR; /*!< Offset: 0x290 (R/W) Instruction Tightly-Coupled Memory Control Register */ + __IOM uint32_t DTCMCR; /*!< Offset: 0x294 (R/W) Data Tightly-Coupled Memory Control Registers */ + __IOM uint32_t AHBPCR; /*!< Offset: 0x298 (R/W) AHBP Control Register */ + __IOM uint32_t CACR; /*!< Offset: 0x29C (R/W) L1 Cache Control Register */ + __IOM uint32_t AHBSCR; /*!< Offset: 0x2A0 (R/W) AHB Slave Control Register */ + uint32_t RESERVED8[1U]; + __IOM uint32_t ABFSR; /*!< Offset: 0x2A8 (R/W) Auxiliary Bus Fault Status Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_PENDNMISET_Pos 31U /*!< SCB ICSR: PENDNMISET Position */ +#define SCB_ICSR_PENDNMISET_Msk (1UL << SCB_ICSR_PENDNMISET_Pos) /*!< SCB ICSR: PENDNMISET Mask */ + +#define SCB_ICSR_NMIPENDSET_Pos SCB_ICSR_PENDNMISET_Pos /*!< SCB ICSR: NMIPENDSET Position, backward compatibility */ +#define SCB_ICSR_NMIPENDSET_Msk SCB_ICSR_PENDNMISET_Msk /*!< SCB ICSR: NMIPENDSET Mask, backward compatibility */ + +#define SCB_ICSR_PENDNMICLR_Pos 30U /*!< SCB ICSR: PENDNMICLR Position */ +#define SCB_ICSR_PENDNMICLR_Msk (1UL << SCB_ICSR_PENDNMICLR_Pos) /*!< SCB ICSR: PENDNMICLR Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_STTNS_Pos 24U /*!< SCB ICSR: STTNS Position (Security Extension) */ +#define SCB_ICSR_STTNS_Msk (1UL << SCB_ICSR_STTNS_Pos) /*!< SCB ICSR: STTNS Mask (Security Extension) */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIS_Pos 14U /*!< SCB AIRCR: PRIS Position */ +#define SCB_AIRCR_PRIS_Msk (1UL << SCB_AIRCR_PRIS_Pos) /*!< SCB AIRCR: PRIS Mask */ + +#define SCB_AIRCR_BFHFNMINS_Pos 13U /*!< SCB AIRCR: BFHFNMINS Position */ +#define SCB_AIRCR_BFHFNMINS_Msk (1UL << SCB_AIRCR_BFHFNMINS_Pos) /*!< SCB AIRCR: BFHFNMINS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQS_Pos 3U /*!< SCB AIRCR: SYSRESETREQS Position */ +#define SCB_AIRCR_SYSRESETREQS_Msk (1UL << SCB_AIRCR_SYSRESETREQS_Pos) /*!< SCB AIRCR: SYSRESETREQS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEPS_Pos 3U /*!< SCB SCR: SLEEPDEEPS Position */ +#define SCB_SCR_SLEEPDEEPS_Msk (1UL << SCB_SCR_SLEEPDEEPS_Pos) /*!< SCB SCR: SLEEPDEEPS Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: BP Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: BP Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: IC Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: IC Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: DC Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: DC Mask */ + +#define SCB_CCR_STKOFHFNMIGN_Pos 10U /*!< SCB CCR: STKOFHFNMIGN Position */ +#define SCB_CCR_STKOFHFNMIGN_Msk (1UL << SCB_CCR_STKOFHFNMIGN_Pos) /*!< SCB CCR: STKOFHFNMIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_HARDFAULTPENDED_Pos 21U /*!< SCB SHCSR: HARDFAULTPENDED Position */ +#define SCB_SHCSR_HARDFAULTPENDED_Msk (1UL << SCB_SHCSR_HARDFAULTPENDED_Pos) /*!< SCB SHCSR: HARDFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTPENDED_Pos 20U /*!< SCB SHCSR: SECUREFAULTPENDED Position */ +#define SCB_SHCSR_SECUREFAULTPENDED_Msk (1UL << SCB_SHCSR_SECUREFAULTPENDED_Pos) /*!< SCB SHCSR: SECUREFAULTPENDED Mask */ + +#define SCB_SHCSR_SECUREFAULTENA_Pos 19U /*!< SCB SHCSR: SECUREFAULTENA Position */ +#define SCB_SHCSR_SECUREFAULTENA_Msk (1UL << SCB_SHCSR_SECUREFAULTENA_Pos) /*!< SCB SHCSR: SECUREFAULTENA Mask */ + +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_NMIACT_Pos 5U /*!< SCB SHCSR: NMIACT Position */ +#define SCB_SHCSR_NMIACT_Msk (1UL << SCB_SHCSR_NMIACT_Pos) /*!< SCB SHCSR: NMIACT Mask */ + +#define SCB_SHCSR_SECUREFAULTACT_Pos 4U /*!< SCB SHCSR: SECUREFAULTACT Position */ +#define SCB_SHCSR_SECUREFAULTACT_Msk (1UL << SCB_SHCSR_SECUREFAULTACT_Pos) /*!< SCB SHCSR: SECUREFAULTACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_HARDFAULTACT_Pos 2U /*!< SCB SHCSR: HARDFAULTACT Position */ +#define SCB_SHCSR_HARDFAULTACT_Msk (1UL << SCB_SHCSR_HARDFAULTACT_Pos) /*!< SCB SHCSR: HARDFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_STKOF_Pos (SCB_CFSR_USGFAULTSR_Pos + 4U) /*!< SCB CFSR (UFSR): STKOF Position */ +#define SCB_CFSR_STKOF_Msk (1UL << SCB_CFSR_STKOF_Pos) /*!< SCB CFSR (UFSR): STKOF Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/* SCB Non-Secure Access Control Register Definitions */ +#define SCB_NSACR_CP11_Pos 11U /*!< SCB NSACR: CP11 Position */ +#define SCB_NSACR_CP11_Msk (1UL << SCB_NSACR_CP11_Pos) /*!< SCB NSACR: CP11 Mask */ + +#define SCB_NSACR_CP10_Pos 10U /*!< SCB NSACR: CP10 Position */ +#define SCB_NSACR_CP10_Msk (1UL << SCB_NSACR_CP10_Pos) /*!< SCB NSACR: CP10 Mask */ + +#define SCB_NSACR_CPn_Pos 0U /*!< SCB NSACR: CPn Position */ +#define SCB_NSACR_CPn_Msk (1UL /*<< SCB_NSACR_CPn_Pos*/) /*!< SCB NSACR: CPn Mask */ + +/* SCB Cache Level ID Register Definitions */ +#define SCB_CLIDR_LOUU_Pos 27U /*!< SCB CLIDR: LoUU Position */ +#define SCB_CLIDR_LOUU_Msk (7UL << SCB_CLIDR_LOUU_Pos) /*!< SCB CLIDR: LoUU Mask */ + +#define SCB_CLIDR_LOC_Pos 24U /*!< SCB CLIDR: LoC Position */ +#define SCB_CLIDR_LOC_Msk (7UL << SCB_CLIDR_LOC_Pos) /*!< SCB CLIDR: LoC Mask */ + +/* SCB Cache Type Register Definitions */ +#define SCB_CTR_FORMAT_Pos 29U /*!< SCB CTR: Format Position */ +#define SCB_CTR_FORMAT_Msk (7UL << SCB_CTR_FORMAT_Pos) /*!< SCB CTR: Format Mask */ + +#define SCB_CTR_CWG_Pos 24U /*!< SCB CTR: CWG Position */ +#define SCB_CTR_CWG_Msk (0xFUL << SCB_CTR_CWG_Pos) /*!< SCB CTR: CWG Mask */ + +#define SCB_CTR_ERG_Pos 20U /*!< SCB CTR: ERG Position */ +#define SCB_CTR_ERG_Msk (0xFUL << SCB_CTR_ERG_Pos) /*!< SCB CTR: ERG Mask */ + +#define SCB_CTR_DMINLINE_Pos 16U /*!< SCB CTR: DminLine Position */ +#define SCB_CTR_DMINLINE_Msk (0xFUL << SCB_CTR_DMINLINE_Pos) /*!< SCB CTR: DminLine Mask */ + +#define SCB_CTR_IMINLINE_Pos 0U /*!< SCB CTR: ImInLine Position */ +#define SCB_CTR_IMINLINE_Msk (0xFUL /*<< SCB_CTR_IMINLINE_Pos*/) /*!< SCB CTR: ImInLine Mask */ + +/* SCB Cache Size ID Register Definitions */ +#define SCB_CCSIDR_WT_Pos 31U /*!< SCB CCSIDR: WT Position */ +#define SCB_CCSIDR_WT_Msk (1UL << SCB_CCSIDR_WT_Pos) /*!< SCB CCSIDR: WT Mask */ + +#define SCB_CCSIDR_WB_Pos 30U /*!< SCB CCSIDR: WB Position */ +#define SCB_CCSIDR_WB_Msk (1UL << SCB_CCSIDR_WB_Pos) /*!< SCB CCSIDR: WB Mask */ + +#define SCB_CCSIDR_RA_Pos 29U /*!< SCB CCSIDR: RA Position */ +#define SCB_CCSIDR_RA_Msk (1UL << SCB_CCSIDR_RA_Pos) /*!< SCB CCSIDR: RA Mask */ + +#define SCB_CCSIDR_WA_Pos 28U /*!< SCB CCSIDR: WA Position */ +#define SCB_CCSIDR_WA_Msk (1UL << SCB_CCSIDR_WA_Pos) /*!< SCB CCSIDR: WA Mask */ + +#define SCB_CCSIDR_NUMSETS_Pos 13U /*!< SCB CCSIDR: NumSets Position */ +#define SCB_CCSIDR_NUMSETS_Msk (0x7FFFUL << SCB_CCSIDR_NUMSETS_Pos) /*!< SCB CCSIDR: NumSets Mask */ + +#define SCB_CCSIDR_ASSOCIATIVITY_Pos 3U /*!< SCB CCSIDR: Associativity Position */ +#define SCB_CCSIDR_ASSOCIATIVITY_Msk (0x3FFUL << SCB_CCSIDR_ASSOCIATIVITY_Pos) /*!< SCB CCSIDR: Associativity Mask */ + +#define SCB_CCSIDR_LINESIZE_Pos 0U /*!< SCB CCSIDR: LineSize Position */ +#define SCB_CCSIDR_LINESIZE_Msk (7UL /*<< SCB_CCSIDR_LINESIZE_Pos*/) /*!< SCB CCSIDR: LineSize Mask */ + +/* SCB Cache Size Selection Register Definitions */ +#define SCB_CSSELR_LEVEL_Pos 1U /*!< SCB CSSELR: Level Position */ +#define SCB_CSSELR_LEVEL_Msk (7UL << SCB_CSSELR_LEVEL_Pos) /*!< SCB CSSELR: Level Mask */ + +#define SCB_CSSELR_IND_Pos 0U /*!< SCB CSSELR: InD Position */ +#define SCB_CSSELR_IND_Msk (1UL /*<< SCB_CSSELR_IND_Pos*/) /*!< SCB CSSELR: InD Mask */ + +/* SCB Software Triggered Interrupt Register Definitions */ +#define SCB_STIR_INTID_Pos 0U /*!< SCB STIR: INTID Position */ +#define SCB_STIR_INTID_Msk (0x1FFUL /*<< SCB_STIR_INTID_Pos*/) /*!< SCB STIR: INTID Mask */ + +/* SCB D-Cache Invalidate by Set-way Register Definitions */ +#define SCB_DCISW_WAY_Pos 30U /*!< SCB DCISW: Way Position */ +#define SCB_DCISW_WAY_Msk (3UL << SCB_DCISW_WAY_Pos) /*!< SCB DCISW: Way Mask */ + +#define SCB_DCISW_SET_Pos 5U /*!< SCB DCISW: Set Position */ +#define SCB_DCISW_SET_Msk (0x1FFUL << SCB_DCISW_SET_Pos) /*!< SCB DCISW: Set Mask */ + +/* SCB D-Cache Clean by Set-way Register Definitions */ +#define SCB_DCCSW_WAY_Pos 30U /*!< SCB DCCSW: Way Position */ +#define SCB_DCCSW_WAY_Msk (3UL << SCB_DCCSW_WAY_Pos) /*!< SCB DCCSW: Way Mask */ + +#define SCB_DCCSW_SET_Pos 5U /*!< SCB DCCSW: Set Position */ +#define SCB_DCCSW_SET_Msk (0x1FFUL << SCB_DCCSW_SET_Pos) /*!< SCB DCCSW: Set Mask */ + +/* SCB D-Cache Clean and Invalidate by Set-way Register Definitions */ +#define SCB_DCCISW_WAY_Pos 30U /*!< SCB DCCISW: Way Position */ +#define SCB_DCCISW_WAY_Msk (3UL << SCB_DCCISW_WAY_Pos) /*!< SCB DCCISW: Way Mask */ + +#define SCB_DCCISW_SET_Pos 5U /*!< SCB DCCISW: Set Position */ +#define SCB_DCCISW_SET_Msk (0x1FFUL << SCB_DCCISW_SET_Pos) /*!< SCB DCCISW: Set Mask */ + +/* Instruction Tightly-Coupled Memory Control Register Definitions */ +#define SCB_ITCMCR_SZ_Pos 3U /*!< SCB ITCMCR: SZ Position */ +#define SCB_ITCMCR_SZ_Msk (0xFUL << SCB_ITCMCR_SZ_Pos) /*!< SCB ITCMCR: SZ Mask */ + +#define SCB_ITCMCR_RETEN_Pos 2U /*!< SCB ITCMCR: RETEN Position */ +#define SCB_ITCMCR_RETEN_Msk (1UL << SCB_ITCMCR_RETEN_Pos) /*!< SCB ITCMCR: RETEN Mask */ + +#define SCB_ITCMCR_RMW_Pos 1U /*!< SCB ITCMCR: RMW Position */ +#define SCB_ITCMCR_RMW_Msk (1UL << SCB_ITCMCR_RMW_Pos) /*!< SCB ITCMCR: RMW Mask */ + +#define SCB_ITCMCR_EN_Pos 0U /*!< SCB ITCMCR: EN Position */ +#define SCB_ITCMCR_EN_Msk (1UL /*<< SCB_ITCMCR_EN_Pos*/) /*!< SCB ITCMCR: EN Mask */ + +/* Data Tightly-Coupled Memory Control Register Definitions */ +#define SCB_DTCMCR_SZ_Pos 3U /*!< SCB DTCMCR: SZ Position */ +#define SCB_DTCMCR_SZ_Msk (0xFUL << SCB_DTCMCR_SZ_Pos) /*!< SCB DTCMCR: SZ Mask */ + +#define SCB_DTCMCR_RETEN_Pos 2U /*!< SCB DTCMCR: RETEN Position */ +#define SCB_DTCMCR_RETEN_Msk (1UL << SCB_DTCMCR_RETEN_Pos) /*!< SCB DTCMCR: RETEN Mask */ + +#define SCB_DTCMCR_RMW_Pos 1U /*!< SCB DTCMCR: RMW Position */ +#define SCB_DTCMCR_RMW_Msk (1UL << SCB_DTCMCR_RMW_Pos) /*!< SCB DTCMCR: RMW Mask */ + +#define SCB_DTCMCR_EN_Pos 0U /*!< SCB DTCMCR: EN Position */ +#define SCB_DTCMCR_EN_Msk (1UL /*<< SCB_DTCMCR_EN_Pos*/) /*!< SCB DTCMCR: EN Mask */ + +/* AHBP Control Register Definitions */ +#define SCB_AHBPCR_SZ_Pos 1U /*!< SCB AHBPCR: SZ Position */ +#define SCB_AHBPCR_SZ_Msk (7UL << SCB_AHBPCR_SZ_Pos) /*!< SCB AHBPCR: SZ Mask */ + +#define SCB_AHBPCR_EN_Pos 0U /*!< SCB AHBPCR: EN Position */ +#define SCB_AHBPCR_EN_Msk (1UL /*<< SCB_AHBPCR_EN_Pos*/) /*!< SCB AHBPCR: EN Mask */ + +/* L1 Cache Control Register Definitions */ +#define SCB_CACR_FORCEWT_Pos 2U /*!< SCB CACR: FORCEWT Position */ +#define SCB_CACR_FORCEWT_Msk (1UL << SCB_CACR_FORCEWT_Pos) /*!< SCB CACR: FORCEWT Mask */ + +#define SCB_CACR_ECCEN_Pos 1U /*!< SCB CACR: ECCEN Position */ +#define SCB_CACR_ECCEN_Msk (1UL << SCB_CACR_ECCEN_Pos) /*!< SCB CACR: ECCEN Mask */ + +#define SCB_CACR_SIWT_Pos 0U /*!< SCB CACR: SIWT Position */ +#define SCB_CACR_SIWT_Msk (1UL /*<< SCB_CACR_SIWT_Pos*/) /*!< SCB CACR: SIWT Mask */ + +/* AHBS Control Register Definitions */ +#define SCB_AHBSCR_INITCOUNT_Pos 11U /*!< SCB AHBSCR: INITCOUNT Position */ +#define SCB_AHBSCR_INITCOUNT_Msk (0x1FUL << SCB_AHBPCR_INITCOUNT_Pos) /*!< SCB AHBSCR: INITCOUNT Mask */ + +#define SCB_AHBSCR_TPRI_Pos 2U /*!< SCB AHBSCR: TPRI Position */ +#define SCB_AHBSCR_TPRI_Msk (0x1FFUL << SCB_AHBPCR_TPRI_Pos) /*!< SCB AHBSCR: TPRI Mask */ + +#define SCB_AHBSCR_CTL_Pos 0U /*!< SCB AHBSCR: CTL Position*/ +#define SCB_AHBSCR_CTL_Msk (3UL /*<< SCB_AHBPCR_CTL_Pos*/) /*!< SCB AHBSCR: CTL Mask */ + +/* Auxiliary Bus Fault Status Register Definitions */ +#define SCB_ABFSR_AXIMTYPE_Pos 8U /*!< SCB ABFSR: AXIMTYPE Position*/ +#define SCB_ABFSR_AXIMTYPE_Msk (3UL << SCB_ABFSR_AXIMTYPE_Pos) /*!< SCB ABFSR: AXIMTYPE Mask */ + +#define SCB_ABFSR_EPPB_Pos 4U /*!< SCB ABFSR: EPPB Position*/ +#define SCB_ABFSR_EPPB_Msk (1UL << SCB_ABFSR_EPPB_Pos) /*!< SCB ABFSR: EPPB Mask */ + +#define SCB_ABFSR_AXIM_Pos 3U /*!< SCB ABFSR: AXIM Position*/ +#define SCB_ABFSR_AXIM_Msk (1UL << SCB_ABFSR_AXIM_Pos) /*!< SCB ABFSR: AXIM Mask */ + +#define SCB_ABFSR_AHBP_Pos 2U /*!< SCB ABFSR: AHBP Position*/ +#define SCB_ABFSR_AHBP_Msk (1UL << SCB_ABFSR_AHBP_Pos) /*!< SCB ABFSR: AHBP Mask */ + +#define SCB_ABFSR_DTCM_Pos 1U /*!< SCB ABFSR: DTCM Position*/ +#define SCB_ABFSR_DTCM_Msk (1UL << SCB_ABFSR_DTCM_Pos) /*!< SCB ABFSR: DTCM Mask */ + +#define SCB_ABFSR_ITCM_Pos 0U /*!< SCB ABFSR: ITCM Position*/ +#define SCB_ABFSR_ITCM_Msk (1UL /*<< SCB_ABFSR_ITCM_Pos*/) /*!< SCB ABFSR: ITCM Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ + __IOM uint32_t CPPWR; /*!< Offset: 0x00C (R/W) Coprocessor Power Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) ITM Device Architecture Register */ + uint32_t RESERVED6[4U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Stimulus Port Register Definitions */ +#define ITM_STIM_DISABLED_Pos 1U /*!< ITM STIM: DISABLED Position */ +#define ITM_STIM_DISABLED_Msk (0x1UL << ITM_STIM_DISABLED_Pos) /*!< ITM STIM: DISABLED Mask */ + +#define ITM_STIM_FIFOREADY_Pos 0U /*!< ITM STIM: FIFOREADY Position */ +#define ITM_STIM_FIFOREADY_Msk (0x1UL /*<< ITM_STIM_FIFOREADY_Pos*/) /*!< ITM STIM: FIFOREADY Mask */ + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TRACEBUSID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TRACEBUSID_Msk (0x7FUL << ITM_TCR_TRACEBUSID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPRESCALE_Pos 8U /*!< ITM TCR: TSPRESCALE Position */ +#define ITM_TCR_TSPRESCALE_Msk (3UL << ITM_TCR_TSPRESCALE_Pos) /*!< ITM TCR: TSPRESCALE Mask */ + +#define ITM_TCR_STALLENA_Pos 5U /*!< ITM TCR: STALLENA Position */ +#define ITM_TCR_STALLENA_Msk (1UL << ITM_TCR_STALLENA_Pos) /*!< ITM TCR: STALLENA Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + uint32_t RESERVED3[1U]; + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED4[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + uint32_t RESERVED5[1U]; + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED6[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + uint32_t RESERVED7[1U]; + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED8[1U]; + __IOM uint32_t COMP4; /*!< Offset: 0x060 (R/W) Comparator Register 4 */ + uint32_t RESERVED9[1U]; + __IOM uint32_t FUNCTION4; /*!< Offset: 0x068 (R/W) Function Register 4 */ + uint32_t RESERVED10[1U]; + __IOM uint32_t COMP5; /*!< Offset: 0x070 (R/W) Comparator Register 5 */ + uint32_t RESERVED11[1U]; + __IOM uint32_t FUNCTION5; /*!< Offset: 0x078 (R/W) Function Register 5 */ + uint32_t RESERVED12[1U]; + __IOM uint32_t COMP6; /*!< Offset: 0x080 (R/W) Comparator Register 6 */ + uint32_t RESERVED13[1U]; + __IOM uint32_t FUNCTION6; /*!< Offset: 0x088 (R/W) Function Register 6 */ + uint32_t RESERVED14[1U]; + __IOM uint32_t COMP7; /*!< Offset: 0x090 (R/W) Comparator Register 7 */ + uint32_t RESERVED15[1U]; + __IOM uint32_t FUNCTION7; /*!< Offset: 0x098 (R/W) Function Register 7 */ + uint32_t RESERVED16[1U]; + __IOM uint32_t COMP8; /*!< Offset: 0x0A0 (R/W) Comparator Register 8 */ + uint32_t RESERVED17[1U]; + __IOM uint32_t FUNCTION8; /*!< Offset: 0x0A8 (R/W) Function Register 8 */ + uint32_t RESERVED18[1U]; + __IOM uint32_t COMP9; /*!< Offset: 0x0B0 (R/W) Comparator Register 9 */ + uint32_t RESERVED19[1U]; + __IOM uint32_t FUNCTION9; /*!< Offset: 0x0B8 (R/W) Function Register 9 */ + uint32_t RESERVED20[1U]; + __IOM uint32_t COMP10; /*!< Offset: 0x0C0 (R/W) Comparator Register 10 */ + uint32_t RESERVED21[1U]; + __IOM uint32_t FUNCTION10; /*!< Offset: 0x0C8 (R/W) Function Register 10 */ + uint32_t RESERVED22[1U]; + __IOM uint32_t COMP11; /*!< Offset: 0x0D0 (R/W) Comparator Register 11 */ + uint32_t RESERVED23[1U]; + __IOM uint32_t FUNCTION11; /*!< Offset: 0x0D8 (R/W) Function Register 11 */ + uint32_t RESERVED24[1U]; + __IOM uint32_t COMP12; /*!< Offset: 0x0E0 (R/W) Comparator Register 12 */ + uint32_t RESERVED25[1U]; + __IOM uint32_t FUNCTION12; /*!< Offset: 0x0E8 (R/W) Function Register 12 */ + uint32_t RESERVED26[1U]; + __IOM uint32_t COMP13; /*!< Offset: 0x0F0 (R/W) Comparator Register 13 */ + uint32_t RESERVED27[1U]; + __IOM uint32_t FUNCTION13; /*!< Offset: 0x0F8 (R/W) Function Register 13 */ + uint32_t RESERVED28[1U]; + __IOM uint32_t COMP14; /*!< Offset: 0x100 (R/W) Comparator Register 14 */ + uint32_t RESERVED29[1U]; + __IOM uint32_t FUNCTION14; /*!< Offset: 0x108 (R/W) Function Register 14 */ + uint32_t RESERVED30[1U]; + __IOM uint32_t COMP15; /*!< Offset: 0x110 (R/W) Comparator Register 15 */ + uint32_t RESERVED31[1U]; + __IOM uint32_t FUNCTION15; /*!< Offset: 0x118 (R/W) Function Register 15 */ + uint32_t RESERVED32[934U]; + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R ) Lock Status Register */ + uint32_t RESERVED33[1U]; + __IM uint32_t DEVARCH; /*!< Offset: 0xFBC (R/ ) Device Architecture Register */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCDISS_Pos 23U /*!< DWT CTRL: CYCDISS Position */ +#define DWT_CTRL_CYCDISS_Msk (0x1UL << DWT_CTRL_CYCDISS_Pos) /*!< DWT CTRL: CYCDISS Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_ID_Pos 27U /*!< DWT FUNCTION: ID Position */ +#define DWT_FUNCTION_ID_Msk (0x1FUL << DWT_FUNCTION_ID_Pos) /*!< DWT FUNCTION: ID Mask */ + +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_ACTION_Pos 4U /*!< DWT FUNCTION: ACTION Position */ +#define DWT_FUNCTION_ACTION_Msk (0x1UL << DWT_FUNCTION_ACTION_Pos) /*!< DWT FUNCTION: ACTION Mask */ + +#define DWT_FUNCTION_MATCH_Pos 0U /*!< DWT FUNCTION: MATCH Position */ +#define DWT_FUNCTION_MATCH_Msk (0xFUL /*<< DWT_FUNCTION_MATCH_Pos*/) /*!< DWT FUNCTION: MATCH Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IOM uint32_t PSCR; /*!< Offset: 0x308 (R/W) Periodic Synchronization Control Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t ITFTTD0; /*!< Offset: 0xEEC (R/ ) Integration Test FIFO Test Data 0 Register */ + __IOM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/W) Integration Test ATB Control Register 2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) Integration Test ATB Control Register 0 */ + __IM uint32_t ITFTTD1; /*!< Offset: 0xEFC (R/ ) Integration Test FIFO Test Data 1 Register */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) Device Configuration Register */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) Device Type Identifier Register */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_FOnMan_Pos 6U /*!< TPI FFCR: FOnMan Position */ +#define TPI_FFCR_FOnMan_Msk (0x1UL << TPI_FFCR_FOnMan_Pos) /*!< TPI FFCR: FOnMan Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration Test FIFO Test Data 0 Register Definitions */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD0: ATB Interface 2 ATVALIDPosition */ +#define TPI_ITFTTD0_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD0: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD0_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD0_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD0: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD0_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD0: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD0_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD0_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD0: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data2_Pos 16U /*!< TPI ITFTTD0: ATB Interface 1 data2 Position */ +#define TPI_ITFTTD0_ATB_IF1_data2_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data2 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data1_Pos 8U /*!< TPI ITFTTD0: ATB Interface 1 data1 Position */ +#define TPI_ITFTTD0_ATB_IF1_data1_Msk (0xFFUL << TPI_ITFTTD0_ATB_IF1_data1_Pos) /*!< TPI ITFTTD0: ATB Interface 1 data1 Mask */ + +#define TPI_ITFTTD0_ATB_IF1_data0_Pos 0U /*!< TPI ITFTTD0: ATB Interface 1 data0 Position */ +#define TPI_ITFTTD0_ATB_IF1_data0_Msk (0xFFUL /*<< TPI_ITFTTD0_ATB_IF1_data0_Pos*/) /*!< TPI ITFTTD0: ATB Interface 1 data0 Mask */ + +/* TPI Integration Test ATB Control Register 2 Register Definitions */ +#define TPI_ITATBCTR2_AFVALID2S_Pos 1U /*!< TPI ITATBCTR2: AFVALID2S Position */ +#define TPI_ITATBCTR2_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID2S_Pos) /*!< TPI ITATBCTR2: AFVALID2SS Mask */ + +#define TPI_ITATBCTR2_AFVALID1S_Pos 1U /*!< TPI ITATBCTR2: AFVALID1S Position */ +#define TPI_ITATBCTR2_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR2_AFVALID1S_Pos) /*!< TPI ITATBCTR2: AFVALID1SS Mask */ + +#define TPI_ITATBCTR2_ATREADY2S_Pos 0U /*!< TPI ITATBCTR2: ATREADY2S Position */ +#define TPI_ITATBCTR2_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2S_Pos*/) /*!< TPI ITATBCTR2: ATREADY2S Mask */ + +#define TPI_ITATBCTR2_ATREADY1S_Pos 0U /*!< TPI ITATBCTR2: ATREADY1S Position */ +#define TPI_ITATBCTR2_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1S_Pos*/) /*!< TPI ITATBCTR2: ATREADY1S Mask */ + +/* TPI Integration Test FIFO Test Data 1 Register Definitions */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Pos 29U /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF2_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 2 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF2_bytecount_Pos 27U /*!< TPI ITFTTD1: ATB Interface 2 byte count Position */ +#define TPI_ITFTTD1_ATB_IF2_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF2_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 2 byte count Mask */ + +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Pos 26U /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Position */ +#define TPI_ITFTTD1_ATB_IF1_ATVALID_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_ATVALID_Pos) /*!< TPI ITFTTD1: ATB Interface 1 ATVALID Mask */ + +#define TPI_ITFTTD1_ATB_IF1_bytecount_Pos 24U /*!< TPI ITFTTD1: ATB Interface 1 byte count Position */ +#define TPI_ITFTTD1_ATB_IF1_bytecount_Msk (0x3UL << TPI_ITFTTD1_ATB_IF1_bytecount_Pos) /*!< TPI ITFTTD1: ATB Interface 1 byte countt Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data2_Pos 16U /*!< TPI ITFTTD1: ATB Interface 2 data2 Position */ +#define TPI_ITFTTD1_ATB_IF2_data2_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data2 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data1_Pos 8U /*!< TPI ITFTTD1: ATB Interface 2 data1 Position */ +#define TPI_ITFTTD1_ATB_IF2_data1_Msk (0xFFUL << TPI_ITFTTD1_ATB_IF2_data1_Pos) /*!< TPI ITFTTD1: ATB Interface 2 data1 Mask */ + +#define TPI_ITFTTD1_ATB_IF2_data0_Pos 0U /*!< TPI ITFTTD1: ATB Interface 2 data0 Position */ +#define TPI_ITFTTD1_ATB_IF2_data0_Msk (0xFFUL /*<< TPI_ITFTTD1_ATB_IF2_data0_Pos*/) /*!< TPI ITFTTD1: ATB Interface 2 data0 Mask */ + +/* TPI Integration Test ATB Control Register 0 Definitions */ +#define TPI_ITATBCTR0_AFVALID2S_Pos 1U /*!< TPI ITATBCTR0: AFVALID2S Position */ +#define TPI_ITATBCTR0_AFVALID2S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID2S_Pos) /*!< TPI ITATBCTR0: AFVALID2SS Mask */ + +#define TPI_ITATBCTR0_AFVALID1S_Pos 1U /*!< TPI ITATBCTR0: AFVALID1S Position */ +#define TPI_ITATBCTR0_AFVALID1S_Msk (0x1UL << TPI_ITATBCTR0_AFVALID1S_Pos) /*!< TPI ITATBCTR0: AFVALID1SS Mask */ + +#define TPI_ITATBCTR0_ATREADY2S_Pos 0U /*!< TPI ITATBCTR0: ATREADY2S Position */ +#define TPI_ITATBCTR0_ATREADY2S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2S_Pos*/) /*!< TPI ITATBCTR0: ATREADY2S Mask */ + +#define TPI_ITATBCTR0_ATREADY1S_Pos 0U /*!< TPI ITATBCTR0: ATREADY1S Position */ +#define TPI_ITATBCTR0_ATREADY1S_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1S_Pos*/) /*!< TPI ITATBCTR0: ATREADY1S Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_FIFOSZ_Pos 6U /*!< TPI DEVID: FIFOSZ Position */ +#define TPI_DEVID_FIFOSZ_Msk (0x7UL << TPI_DEVID_FIFOSZ_Pos) /*!< TPI DEVID: FIFOSZ Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x3FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) MPU Region Limit Address Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Region Base Address Register Alias 1 */ + __IOM uint32_t RLAR_A1; /*!< Offset: 0x018 (R/W) MPU Region Limit Address Register Alias 1 */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Region Base Address Register Alias 2 */ + __IOM uint32_t RLAR_A2; /*!< Offset: 0x020 (R/W) MPU Region Limit Address Register Alias 2 */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Region Base Address Register Alias 3 */ + __IOM uint32_t RLAR_A3; /*!< Offset: 0x028 (R/W) MPU Region Limit Address Register Alias 3 */ + uint32_t RESERVED0[1]; + union { + __IOM uint32_t MAIR[2]; + struct { + __IOM uint32_t MAIR0; /*!< Offset: 0x030 (R/W) MPU Memory Attribute Indirection Register 0 */ + __IOM uint32_t MAIR1; /*!< Offset: 0x034 (R/W) MPU Memory Attribute Indirection Register 1 */ + }; + }; +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_BASE_Pos 5U /*!< MPU RBAR: BASE Position */ +#define MPU_RBAR_BASE_Msk (0x7FFFFFFUL << MPU_RBAR_BASE_Pos) /*!< MPU RBAR: BASE Mask */ + +#define MPU_RBAR_SH_Pos 3U /*!< MPU RBAR: SH Position */ +#define MPU_RBAR_SH_Msk (0x3UL << MPU_RBAR_SH_Pos) /*!< MPU RBAR: SH Mask */ + +#define MPU_RBAR_AP_Pos 1U /*!< MPU RBAR: AP Position */ +#define MPU_RBAR_AP_Msk (0x3UL << MPU_RBAR_AP_Pos) /*!< MPU RBAR: AP Mask */ + +#define MPU_RBAR_XN_Pos 0U /*!< MPU RBAR: XN Position */ +#define MPU_RBAR_XN_Msk (01UL /*<< MPU_RBAR_XN_Pos*/) /*!< MPU RBAR: XN Mask */ + +/* MPU Region Limit Address Register Definitions */ +#define MPU_RLAR_LIMIT_Pos 5U /*!< MPU RLAR: LIMIT Position */ +#define MPU_RLAR_LIMIT_Msk (0x7FFFFFFUL << MPU_RLAR_LIMIT_Pos) /*!< MPU RLAR: LIMIT Mask */ + +#define MPU_RLAR_AttrIndx_Pos 1U /*!< MPU RLAR: AttrIndx Position */ +#define MPU_RLAR_AttrIndx_Msk (0x7UL << MPU_RLAR_AttrIndx_Pos) /*!< MPU RLAR: AttrIndx Mask */ + +#define MPU_RLAR_EN_Pos 0U /*!< MPU RLAR: Region enable bit Position */ +#define MPU_RLAR_EN_Msk (1UL /*<< MPU_RLAR_EN_Pos*/) /*!< MPU RLAR: Region enable bit Disable Mask */ + +/* MPU Memory Attribute Indirection Register 0 Definitions */ +#define MPU_MAIR0_Attr3_Pos 24U /*!< MPU MAIR0: Attr3 Position */ +#define MPU_MAIR0_Attr3_Msk (0xFFUL << MPU_MAIR0_Attr3_Pos) /*!< MPU MAIR0: Attr3 Mask */ + +#define MPU_MAIR0_Attr2_Pos 16U /*!< MPU MAIR0: Attr2 Position */ +#define MPU_MAIR0_Attr2_Msk (0xFFUL << MPU_MAIR0_Attr2_Pos) /*!< MPU MAIR0: Attr2 Mask */ + +#define MPU_MAIR0_Attr1_Pos 8U /*!< MPU MAIR0: Attr1 Position */ +#define MPU_MAIR0_Attr1_Msk (0xFFUL << MPU_MAIR0_Attr1_Pos) /*!< MPU MAIR0: Attr1 Mask */ + +#define MPU_MAIR0_Attr0_Pos 0U /*!< MPU MAIR0: Attr0 Position */ +#define MPU_MAIR0_Attr0_Msk (0xFFUL /*<< MPU_MAIR0_Attr0_Pos*/) /*!< MPU MAIR0: Attr0 Mask */ + +/* MPU Memory Attribute Indirection Register 1 Definitions */ +#define MPU_MAIR1_Attr7_Pos 24U /*!< MPU MAIR1: Attr7 Position */ +#define MPU_MAIR1_Attr7_Msk (0xFFUL << MPU_MAIR1_Attr7_Pos) /*!< MPU MAIR1: Attr7 Mask */ + +#define MPU_MAIR1_Attr6_Pos 16U /*!< MPU MAIR1: Attr6 Position */ +#define MPU_MAIR1_Attr6_Msk (0xFFUL << MPU_MAIR1_Attr6_Pos) /*!< MPU MAIR1: Attr6 Mask */ + +#define MPU_MAIR1_Attr5_Pos 8U /*!< MPU MAIR1: Attr5 Position */ +#define MPU_MAIR1_Attr5_Msk (0xFFUL << MPU_MAIR1_Attr5_Pos) /*!< MPU MAIR1: Attr5 Mask */ + +#define MPU_MAIR1_Attr4_Pos 0U /*!< MPU MAIR1: Attr4 Position */ +#define MPU_MAIR1_Attr4_Msk (0xFFUL /*<< MPU_MAIR1_Attr4_Pos*/) /*!< MPU MAIR1: Attr4 Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SAU Security Attribution Unit (SAU) + \brief Type definitions for the Security Attribution Unit (SAU) + @{ + */ + +/** + \brief Structure type to access the Security Attribution Unit (SAU). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SAU Control Register */ + __IM uint32_t TYPE; /*!< Offset: 0x004 (R/ ) SAU Type Register */ +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) SAU Region Number Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) SAU Region Base Address Register */ + __IOM uint32_t RLAR; /*!< Offset: 0x010 (R/W) SAU Region Limit Address Register */ +#else + uint32_t RESERVED0[3]; +#endif + __IOM uint32_t SFSR; /*!< Offset: 0x014 (R/W) Secure Fault Status Register */ + __IOM uint32_t SFAR; /*!< Offset: 0x018 (R/W) Secure Fault Address Register */ +} SAU_Type; + +/* SAU Control Register Definitions */ +#define SAU_CTRL_ALLNS_Pos 1U /*!< SAU CTRL: ALLNS Position */ +#define SAU_CTRL_ALLNS_Msk (1UL << SAU_CTRL_ALLNS_Pos) /*!< SAU CTRL: ALLNS Mask */ + +#define SAU_CTRL_ENABLE_Pos 0U /*!< SAU CTRL: ENABLE Position */ +#define SAU_CTRL_ENABLE_Msk (1UL /*<< SAU_CTRL_ENABLE_Pos*/) /*!< SAU CTRL: ENABLE Mask */ + +/* SAU Type Register Definitions */ +#define SAU_TYPE_SREGION_Pos 0U /*!< SAU TYPE: SREGION Position */ +#define SAU_TYPE_SREGION_Msk (0xFFUL /*<< SAU_TYPE_SREGION_Pos*/) /*!< SAU TYPE: SREGION Mask */ + +#if defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) +/* SAU Region Number Register Definitions */ +#define SAU_RNR_REGION_Pos 0U /*!< SAU RNR: REGION Position */ +#define SAU_RNR_REGION_Msk (0xFFUL /*<< SAU_RNR_REGION_Pos*/) /*!< SAU RNR: REGION Mask */ + +/* SAU Region Base Address Register Definitions */ +#define SAU_RBAR_BADDR_Pos 5U /*!< SAU RBAR: BADDR Position */ +#define SAU_RBAR_BADDR_Msk (0x7FFFFFFUL << SAU_RBAR_BADDR_Pos) /*!< SAU RBAR: BADDR Mask */ + +/* SAU Region Limit Address Register Definitions */ +#define SAU_RLAR_LADDR_Pos 5U /*!< SAU RLAR: LADDR Position */ +#define SAU_RLAR_LADDR_Msk (0x7FFFFFFUL << SAU_RLAR_LADDR_Pos) /*!< SAU RLAR: LADDR Mask */ + +#define SAU_RLAR_NSC_Pos 1U /*!< SAU RLAR: NSC Position */ +#define SAU_RLAR_NSC_Msk (1UL << SAU_RLAR_NSC_Pos) /*!< SAU RLAR: NSC Mask */ + +#define SAU_RLAR_ENABLE_Pos 0U /*!< SAU RLAR: ENABLE Position */ +#define SAU_RLAR_ENABLE_Msk (1UL /*<< SAU_RLAR_ENABLE_Pos*/) /*!< SAU RLAR: ENABLE Mask */ + +#endif /* defined (__SAUREGION_PRESENT) && (__SAUREGION_PRESENT == 1U) */ + +/* Secure Fault Status Register Definitions */ +#define SAU_SFSR_LSERR_Pos 7U /*!< SAU SFSR: LSERR Position */ +#define SAU_SFSR_LSERR_Msk (1UL << SAU_SFSR_LSERR_Pos) /*!< SAU SFSR: LSERR Mask */ + +#define SAU_SFSR_SFARVALID_Pos 6U /*!< SAU SFSR: SFARVALID Position */ +#define SAU_SFSR_SFARVALID_Msk (1UL << SAU_SFSR_SFARVALID_Pos) /*!< SAU SFSR: SFARVALID Mask */ + +#define SAU_SFSR_LSPERR_Pos 5U /*!< SAU SFSR: LSPERR Position */ +#define SAU_SFSR_LSPERR_Msk (1UL << SAU_SFSR_LSPERR_Pos) /*!< SAU SFSR: LSPERR Mask */ + +#define SAU_SFSR_INVTRAN_Pos 4U /*!< SAU SFSR: INVTRAN Position */ +#define SAU_SFSR_INVTRAN_Msk (1UL << SAU_SFSR_INVTRAN_Pos) /*!< SAU SFSR: INVTRAN Mask */ + +#define SAU_SFSR_AUVIOL_Pos 3U /*!< SAU SFSR: AUVIOL Position */ +#define SAU_SFSR_AUVIOL_Msk (1UL << SAU_SFSR_AUVIOL_Pos) /*!< SAU SFSR: AUVIOL Mask */ + +#define SAU_SFSR_INVER_Pos 2U /*!< SAU SFSR: INVER Position */ +#define SAU_SFSR_INVER_Msk (1UL << SAU_SFSR_INVER_Pos) /*!< SAU SFSR: INVER Mask */ + +#define SAU_SFSR_INVIS_Pos 1U /*!< SAU SFSR: INVIS Position */ +#define SAU_SFSR_INVIS_Msk (1UL << SAU_SFSR_INVIS_Pos) /*!< SAU SFSR: INVIS Mask */ + +#define SAU_SFSR_INVEP_Pos 0U /*!< SAU SFSR: INVEP Position */ +#define SAU_SFSR_INVEP_Msk (1UL /*<< SAU_SFSR_INVEP_Pos*/) /*!< SAU SFSR: INVEP Mask */ + +/*@} end of group CMSIS_SAU */ +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_LSPENS_Pos 29U /*!< FPCCR: LSPENS Position */ +#define FPU_FPCCR_LSPENS_Msk (1UL << FPU_FPCCR_LSPENS_Pos) /*!< FPCCR: LSPENS bit Mask */ + +#define FPU_FPCCR_CLRONRET_Pos 28U /*!< FPCCR: CLRONRET Position */ +#define FPU_FPCCR_CLRONRET_Msk (1UL << FPU_FPCCR_CLRONRET_Pos) /*!< FPCCR: CLRONRET bit Mask */ + +#define FPU_FPCCR_CLRONRETS_Pos 27U /*!< FPCCR: CLRONRETS Position */ +#define FPU_FPCCR_CLRONRETS_Msk (1UL << FPU_FPCCR_CLRONRETS_Pos) /*!< FPCCR: CLRONRETS bit Mask */ + +#define FPU_FPCCR_TS_Pos 26U /*!< FPCCR: TS Position */ +#define FPU_FPCCR_TS_Msk (1UL << FPU_FPCCR_TS_Pos) /*!< FPCCR: TS bit Mask */ + +#define FPU_FPCCR_UFRDY_Pos 10U /*!< FPCCR: UFRDY Position */ +#define FPU_FPCCR_UFRDY_Msk (1UL << FPU_FPCCR_UFRDY_Pos) /*!< FPCCR: UFRDY bit Mask */ + +#define FPU_FPCCR_SPLIMVIOL_Pos 9U /*!< FPCCR: SPLIMVIOL Position */ +#define FPU_FPCCR_SPLIMVIOL_Msk (1UL << FPU_FPCCR_SPLIMVIOL_Pos) /*!< FPCCR: SPLIMVIOL bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_SFRDY_Pos 7U /*!< FPCCR: SFRDY Position */ +#define FPU_FPCCR_SFRDY_Msk (1UL << FPU_FPCCR_SFRDY_Pos) /*!< FPCCR: SFRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_S_Pos 2U /*!< FPCCR: Security status of the FP context bit Position */ +#define FPU_FPCCR_S_Msk (1UL << FPU_FPCCR_S_Pos) /*!< FPCCR: Security status of the FP context bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ + uint32_t RESERVED4[1U]; + __IOM uint32_t DAUTHCTRL; /*!< Offset: 0x014 (R/W) Debug Authentication Control Register */ + __IOM uint32_t DSCSR; /*!< Offset: 0x018 (R/W) Debug Security Control and Status Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESTART_ST_Pos 26U /*!< CoreDebug DHCSR: S_RESTART_ST Position */ +#define CoreDebug_DHCSR_S_RESTART_ST_Msk (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos) /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/* Debug Authentication Control Register Definitions */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos 3U /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ +#define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ + +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos 2U /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos) /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ + +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos 1U /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ +#define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos) /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ + +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos 0U /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ +#define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ + +/* Debug Security Control and Status Register Definitions */ +#define CoreDebug_DSCSR_CDS_Pos 16U /*!< CoreDebug DSCSR: CDS Position */ +#define CoreDebug_DSCSR_CDS_Msk (1UL << CoreDebug_DSCSR_CDS_Pos) /*!< CoreDebug DSCSR: CDS Mask */ + +#define CoreDebug_DSCSR_SBRSEL_Pos 1U /*!< CoreDebug DSCSR: SBRSEL Position */ +#define CoreDebug_DSCSR_SBRSEL_Msk (1UL << CoreDebug_DSCSR_SBRSEL_Pos) /*!< CoreDebug DSCSR: SBRSEL Mask */ + +#define CoreDebug_DSCSR_SBRSELEN_Pos 0U /*!< CoreDebug DSCSR: SBRSELEN Position */ +#define CoreDebug_DSCSR_SBRSELEN_Msk (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/) /*!< CoreDebug DSCSR: SBRSELEN Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ + #define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ + #define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ + #define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ + #define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ + #define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ + #define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ + #define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ + #define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + + #define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ + #define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ + #define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ + #define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + #define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ + #define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ + #define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ + #define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE ) /*!< Core Debug configuration struct */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ + #endif + + #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SAU_BASE (SCS_BASE + 0x0DD0UL) /*!< Security Attribution Unit */ + #define SAU ((SAU_Type *) SAU_BASE ) /*!< Security Attribution Unit */ + #endif + + #define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ + #define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + #define SCS_BASE_NS (0xE002E000UL) /*!< System Control Space Base Address (non-secure address space) */ + #define CoreDebug_BASE_NS (0xE002EDF0UL) /*!< Core Debug Base Address (non-secure address space) */ + #define SysTick_BASE_NS (SCS_BASE_NS + 0x0010UL) /*!< SysTick Base Address (non-secure address space) */ + #define NVIC_BASE_NS (SCS_BASE_NS + 0x0100UL) /*!< NVIC Base Address (non-secure address space) */ + #define SCB_BASE_NS (SCS_BASE_NS + 0x0D00UL) /*!< System Control Block Base Address (non-secure address space) */ + + #define SCnSCB_NS ((SCnSCB_Type *) SCS_BASE_NS ) /*!< System control Register not in SCB(non-secure address space) */ + #define SCB_NS ((SCB_Type *) SCB_BASE_NS ) /*!< SCB configuration struct (non-secure address space) */ + #define SysTick_NS ((SysTick_Type *) SysTick_BASE_NS ) /*!< SysTick configuration struct (non-secure address space) */ + #define NVIC_NS ((NVIC_Type *) NVIC_BASE_NS ) /*!< NVIC configuration struct (non-secure address space) */ + #define CoreDebug_NS ((CoreDebug_Type *) CoreDebug_BASE_NS) /*!< Core Debug configuration struct (non-secure address space) */ + + #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE_NS (SCS_BASE_NS + 0x0D90UL) /*!< Memory Protection Unit (non-secure address space) */ + #define MPU_NS ((MPU_Type *) MPU_BASE_NS ) /*!< Memory Protection Unit (non-secure address space) */ + #endif + + #define FPU_BASE_NS (SCS_BASE_NS + 0x0F30UL) /*!< Floating Point Unit (non-secure address space) */ + #define FPU_NS ((FPU_Type *) FPU_BASE_NS ) /*!< Floating Point Unit (non-secure address space) */ + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* Special LR values for Secure/Non-Secure call handling and exception handling */ + +/* Function Return Payload (from ARMv8-M Architecture Reference Manual) LR value on entry from Secure BLXNS */ +#define FNC_RETURN (0xFEFFFFFFUL) /* bit [0] ignored when processing a branch */ + +/* The following EXC_RETURN mask values are used to evaluate the LR on exception entry */ +#define EXC_RETURN_PREFIX (0xFF000000UL) /* bits [31:24] set to indicate an EXC_RETURN value */ +#define EXC_RETURN_S (0x00000040UL) /* bit [6] stack used to push registers: 0=Non-secure 1=Secure */ +#define EXC_RETURN_DCRS (0x00000020UL) /* bit [5] stacking rules for called registers: 0=skipped 1=saved */ +#define EXC_RETURN_FTYPE (0x00000010UL) /* bit [4] allocate stack for floating-point context: 0=done 1=skipped */ +#define EXC_RETURN_MODE (0x00000008UL) /* bit [3] processor mode for return: 0=Handler mode 1=Thread mode */ +#define EXC_RETURN_SPSEL (0x00000002UL) /* bit [1] stack pointer used to restore context: 0=MSP 1=PSP */ +#define EXC_RETURN_ES (0x00000001UL) /* bit [0] security state exception was taken to: 0=Non-secure 1=Secure */ + +/* Integrity Signature (from ARMv8-M Architecture Reference Manual) for exception context stacking */ +#if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) /* Value for processors with floating-point extension: */ +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125AUL) /* bit [0] SFTC must match LR bit[4] EXC_RETURN_FTYPE */ +#else +#define EXC_INTEGRITY_SIGNATURE (0xFEFA125BUL) /* Value for processors without floating-point extension */ +#endif + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Get Interrupt Target State + \details Reads the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + \return 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_GetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Target State + \details Sets the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_SetTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] |= ((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Clear Interrupt Target State + \details Clears the interrupt target field in the NVIC and returns the interrupt target bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 if interrupt is assigned to Secure + 1 if interrupt is assigned to Non Secure + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t NVIC_ClearTargetState(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] &= ~((uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL))); + return((uint32_t)(((NVIC->ITNS[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief Set Priority Grouping (non-secure) + \details Sets the non-secure priority grouping field when in secure state using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void TZ_NVIC_SetPriorityGrouping_NS(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB_NS->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB_NS->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping (non-secure) + \details Reads the priority grouping field from the non-secure NVIC when in secure state. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriorityGrouping_NS(void) +{ + return ((uint32_t)((SCB_NS->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt (non-secure) + \details Enables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_EnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status (non-secure) + \details Returns a device specific interrupt enable status from the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetEnableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt (non-secure) + \details Disables a device specific interrupt in the non-secure NVIC interrupt controller when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_DisableIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Pending Interrupt (non-secure) + \details Reads the NVIC pending register in the non-secure NVIC when in secure state and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt (non-secure) + \details Sets the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_SetPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt (non-secure) + \details Clears the pending bit of a device specific interrupt in the non-secure NVIC pending register when in secure state. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void TZ_NVIC_ClearPendingIRQ_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt (non-secure) + \details Reads the active register in non-secure NVIC when in secure state and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetActive_NS(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC_NS->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority (non-secure) + \details Sets the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every non-secure processor exception. + */ +__STATIC_INLINE void TZ_NVIC_SetPriority_NS(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC_NS->IPR[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority (non-secure) + \details Reads the priority of a non-secure device specific interrupt or a non-secure processor exception when in secure state. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t TZ_NVIC_GetPriority_NS(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC_NS->IPR[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB_NS->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} +#endif /* defined (__ARM_FEATURE_CMSE) &&(__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv8.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = FPU->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x220U) + { + return 2U; /* Double + Single precision FPU */ + } + else if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## SAU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SAUFunctions SAU Functions + \brief Functions that configure the SAU. + @{ + */ + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) + +/** + \brief Enable SAU + \details Enables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Enable(void) +{ + SAU->CTRL |= (SAU_CTRL_ENABLE_Msk); +} + + + +/** + \brief Disable SAU + \details Disables the Security Attribution Unit (SAU). + */ +__STATIC_INLINE void TZ_SAU_Disable(void) +{ + SAU->CTRL &= ~(SAU_CTRL_ENABLE_Msk); +} + +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +/*@} end of CMSIS_Core_SAUFunctions */ + + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) +/** + \brief System Tick Configuration (non-secure) + \details Initializes the non-secure System Timer and its interrupt when in secure state, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function TZ_SysTick_Config_NS is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + + */ +__STATIC_INLINE uint32_t TZ_SysTick_Config_NS(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick_NS->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + TZ_NVIC_SetPriority_NS (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick_NS->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick_NS->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} +#endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM33_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm4.h b/Chapter04/bare/platform/CMSIS/Include/core_cm4.h new file mode 100644 index 0000000..308b868 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm4.h @@ -0,0 +1,2129 @@ +/**************************************************************************//** + * @file core_cm4.h + * @brief CMSIS Cortex-M4 Core Peripheral Access Layer Header File + * @version V5.0.8 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM4_H_GENERIC +#define __CORE_CM4_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M4 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM4 definitions */ +#define __CM4_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM4_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM4_CMSIS_VERSION ((__CM4_CMSIS_VERSION_MAIN << 16U) | \ + __CM4_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (4U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM4_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM4_H_DEPENDANT +#define __CORE_CM4_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM4_REV + #define __CM4_REV 0x0000U + #warning "__CM4_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M4 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t FPCA:1; /*!< bit: 2 FP extension active flag */ + uint32_t _reserved0:29; /*!< bit: 3..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHP[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[5U]; + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_DISOOFP_Pos 9U /*!< ACTLR: DISOOFP Position */ +#define SCnSCB_ACTLR_DISOOFP_Msk (1UL << SCnSCB_ACTLR_DISOOFP_Pos) /*!< ACTLR: DISOOFP Mask */ + +#define SCnSCB_ACTLR_DISFPCA_Pos 8U /*!< ACTLR: DISFPCA Position */ +#define SCnSCB_ACTLR_DISFPCA_Msk (1UL << SCnSCB_ACTLR_DISFPCA_Pos) /*!< ACTLR: DISFPCA Mask */ + +#define SCnSCB_ACTLR_DISFOLD_Pos 2U /*!< ACTLR: DISFOLD Position */ +#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos) /*!< ACTLR: DISFOLD Mask */ + +#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1U /*!< ACTLR: DISDEFWBUF Position */ +#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos) /*!< ACTLR: DISDEFWBUF Mask */ + +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif /* defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +#define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ +#define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ +#define EXC_RETURN_HANDLER_FPU (0xFFFFFFE1UL) /* return to Handler mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_MSP_FPU (0xFFFFFFE9UL) /* return to Thread mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_PSP_FPU (0xFFFFFFEDUL) /* return to Thread mode, uses PSP after return, restore floating-point state */ + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = FPU->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM4_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_cm7.h b/Chapter04/bare/platform/CMSIS/Include/core_cm7.h new file mode 100644 index 0000000..ada6c2a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_cm7.h @@ -0,0 +1,2671 @@ +/**************************************************************************//** + * @file core_cm7.h + * @brief CMSIS Cortex-M7 Core Peripheral Access Layer Header File + * @version V5.0.8 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_CM7_H_GENERIC +#define __CORE_CM7_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup Cortex_M7 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS CM7 definitions */ +#define __CM7_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __CM7_CMSIS_VERSION_SUB ( __CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __CM7_CMSIS_VERSION ((__CM7_CMSIS_VERSION_MAIN << 16U) | \ + __CM7_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_M (7U) /*!< Cortex-M Core */ + +/** __FPU_USED indicates whether an FPU is used or not. + For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. +*/ +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #warning "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #if defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U) + #define __FPU_USED 1U + #else + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #define __FPU_USED 0U + #endif + #else + #define __FPU_USED 0U + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM7_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_CM7_H_DEPENDANT +#define __CORE_CM7_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __CM7_REV + #define __CM7_REV 0x0000U + #warning "__CM7_REV not defined in device header file; using default!" + #endif + + #ifndef __FPU_PRESENT + #define __FPU_PRESENT 0U + #warning "__FPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __ICACHE_PRESENT + #define __ICACHE_PRESENT 0U + #warning "__ICACHE_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DCACHE_PRESENT + #define __DCACHE_PRESENT 0U + #warning "__DCACHE_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __DTCM_PRESENT + #define __DTCM_PRESENT 0U + #warning "__DTCM_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group Cortex_M7 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + - Core FPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:16; /*!< bit: 0..15 Reserved */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:7; /*!< bit: 20..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + +#define APSR_GE_Pos 16U /*!< APSR: GE Position */ +#define APSR_GE_Msk (0xFUL << APSR_GE_Pos) /*!< APSR: GE Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t GE:4; /*!< bit: 16..19 Greater than or Equal flags */ + uint32_t _reserved1:4; /*!< bit: 20..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_GE_Pos 16U /*!< xPSR: GE Position */ +#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos) /*!< xPSR: GE Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t FPCA:1; /*!< bit: 2 FP extension active flag */ + uint32_t _reserved0:29; /*!< bit: 3..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_FPCA_Pos 2U /*!< CONTROL: FPCA Position */ +#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos) /*!< CONTROL: FPCA Mask */ + +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHPR[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t ID_PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t ID_DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ID_AFR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t ID_MFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ID_ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[1U]; + __IM uint32_t CLIDR; /*!< Offset: 0x078 (R/ ) Cache Level ID register */ + __IM uint32_t CTR; /*!< Offset: 0x07C (R/ ) Cache Type register */ + __IM uint32_t CCSIDR; /*!< Offset: 0x080 (R/ ) Cache Size ID Register */ + __IOM uint32_t CSSELR; /*!< Offset: 0x084 (R/W) Cache Size Selection Register */ + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + uint32_t RESERVED3[93U]; + __OM uint32_t STIR; /*!< Offset: 0x200 ( /W) Software Triggered Interrupt Register */ + uint32_t RESERVED4[15U]; + __IM uint32_t MVFR0; /*!< Offset: 0x240 (R/ ) Media and VFP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x244 (R/ ) Media and VFP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x248 (R/ ) Media and VFP Feature Register 2 */ + uint32_t RESERVED5[1U]; + __OM uint32_t ICIALLU; /*!< Offset: 0x250 ( /W) I-Cache Invalidate All to PoU */ + uint32_t RESERVED6[1U]; + __OM uint32_t ICIMVAU; /*!< Offset: 0x258 ( /W) I-Cache Invalidate by MVA to PoU */ + __OM uint32_t DCIMVAC; /*!< Offset: 0x25C ( /W) D-Cache Invalidate by MVA to PoC */ + __OM uint32_t DCISW; /*!< Offset: 0x260 ( /W) D-Cache Invalidate by Set-way */ + __OM uint32_t DCCMVAU; /*!< Offset: 0x264 ( /W) D-Cache Clean by MVA to PoU */ + __OM uint32_t DCCMVAC; /*!< Offset: 0x268 ( /W) D-Cache Clean by MVA to PoC */ + __OM uint32_t DCCSW; /*!< Offset: 0x26C ( /W) D-Cache Clean by Set-way */ + __OM uint32_t DCCIMVAC; /*!< Offset: 0x270 ( /W) D-Cache Clean and Invalidate by MVA to PoC */ + __OM uint32_t DCCISW; /*!< Offset: 0x274 ( /W) D-Cache Clean and Invalidate by Set-way */ + uint32_t RESERVED7[6U]; + __IOM uint32_t ITCMCR; /*!< Offset: 0x290 (R/W) Instruction Tightly-Coupled Memory Control Register */ + __IOM uint32_t DTCMCR; /*!< Offset: 0x294 (R/W) Data Tightly-Coupled Memory Control Registers */ + __IOM uint32_t AHBPCR; /*!< Offset: 0x298 (R/W) AHBP Control Register */ + __IOM uint32_t CACR; /*!< Offset: 0x29C (R/W) L1 Cache Control Register */ + __IOM uint32_t AHBSCR; /*!< Offset: 0x2A0 (R/W) AHB Slave Control Register */ + uint32_t RESERVED8[1U]; + __IOM uint32_t ABFSR; /*!< Offset: 0x2A8 (R/W) Auxiliary Bus Fault Status Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_BP_Pos 18U /*!< SCB CCR: Branch prediction enable bit Position */ +#define SCB_CCR_BP_Msk (1UL << SCB_CCR_BP_Pos) /*!< SCB CCR: Branch prediction enable bit Mask */ + +#define SCB_CCR_IC_Pos 17U /*!< SCB CCR: Instruction cache enable bit Position */ +#define SCB_CCR_IC_Msk (1UL << SCB_CCR_IC_Pos) /*!< SCB CCR: Instruction cache enable bit Mask */ + +#define SCB_CCR_DC_Pos 16U /*!< SCB CCR: Cache enable bit Position */ +#define SCB_CCR_DC_Msk (1UL << SCB_CCR_DC_Pos) /*!< SCB CCR: Cache enable bit Mask */ + +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MLSPERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 5U) /*!< SCB CFSR (MMFSR): MLSPERR Position */ +#define SCB_CFSR_MLSPERR_Msk (1UL << SCB_CFSR_MLSPERR_Pos) /*!< SCB CFSR (MMFSR): MLSPERR Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_LSPERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 5U) /*!< SCB CFSR (BFSR): LSPERR Position */ +#define SCB_CFSR_LSPERR_Msk (1UL << SCB_CFSR_LSPERR_Pos) /*!< SCB CFSR (BFSR): LSPERR Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/* SCB Cache Level ID Register Definitions */ +#define SCB_CLIDR_LOUU_Pos 27U /*!< SCB CLIDR: LoUU Position */ +#define SCB_CLIDR_LOUU_Msk (7UL << SCB_CLIDR_LOUU_Pos) /*!< SCB CLIDR: LoUU Mask */ + +#define SCB_CLIDR_LOC_Pos 24U /*!< SCB CLIDR: LoC Position */ +#define SCB_CLIDR_LOC_Msk (7UL << SCB_CLIDR_LOC_Pos) /*!< SCB CLIDR: LoC Mask */ + +/* SCB Cache Type Register Definitions */ +#define SCB_CTR_FORMAT_Pos 29U /*!< SCB CTR: Format Position */ +#define SCB_CTR_FORMAT_Msk (7UL << SCB_CTR_FORMAT_Pos) /*!< SCB CTR: Format Mask */ + +#define SCB_CTR_CWG_Pos 24U /*!< SCB CTR: CWG Position */ +#define SCB_CTR_CWG_Msk (0xFUL << SCB_CTR_CWG_Pos) /*!< SCB CTR: CWG Mask */ + +#define SCB_CTR_ERG_Pos 20U /*!< SCB CTR: ERG Position */ +#define SCB_CTR_ERG_Msk (0xFUL << SCB_CTR_ERG_Pos) /*!< SCB CTR: ERG Mask */ + +#define SCB_CTR_DMINLINE_Pos 16U /*!< SCB CTR: DminLine Position */ +#define SCB_CTR_DMINLINE_Msk (0xFUL << SCB_CTR_DMINLINE_Pos) /*!< SCB CTR: DminLine Mask */ + +#define SCB_CTR_IMINLINE_Pos 0U /*!< SCB CTR: ImInLine Position */ +#define SCB_CTR_IMINLINE_Msk (0xFUL /*<< SCB_CTR_IMINLINE_Pos*/) /*!< SCB CTR: ImInLine Mask */ + +/* SCB Cache Size ID Register Definitions */ +#define SCB_CCSIDR_WT_Pos 31U /*!< SCB CCSIDR: WT Position */ +#define SCB_CCSIDR_WT_Msk (1UL << SCB_CCSIDR_WT_Pos) /*!< SCB CCSIDR: WT Mask */ + +#define SCB_CCSIDR_WB_Pos 30U /*!< SCB CCSIDR: WB Position */ +#define SCB_CCSIDR_WB_Msk (1UL << SCB_CCSIDR_WB_Pos) /*!< SCB CCSIDR: WB Mask */ + +#define SCB_CCSIDR_RA_Pos 29U /*!< SCB CCSIDR: RA Position */ +#define SCB_CCSIDR_RA_Msk (1UL << SCB_CCSIDR_RA_Pos) /*!< SCB CCSIDR: RA Mask */ + +#define SCB_CCSIDR_WA_Pos 28U /*!< SCB CCSIDR: WA Position */ +#define SCB_CCSIDR_WA_Msk (1UL << SCB_CCSIDR_WA_Pos) /*!< SCB CCSIDR: WA Mask */ + +#define SCB_CCSIDR_NUMSETS_Pos 13U /*!< SCB CCSIDR: NumSets Position */ +#define SCB_CCSIDR_NUMSETS_Msk (0x7FFFUL << SCB_CCSIDR_NUMSETS_Pos) /*!< SCB CCSIDR: NumSets Mask */ + +#define SCB_CCSIDR_ASSOCIATIVITY_Pos 3U /*!< SCB CCSIDR: Associativity Position */ +#define SCB_CCSIDR_ASSOCIATIVITY_Msk (0x3FFUL << SCB_CCSIDR_ASSOCIATIVITY_Pos) /*!< SCB CCSIDR: Associativity Mask */ + +#define SCB_CCSIDR_LINESIZE_Pos 0U /*!< SCB CCSIDR: LineSize Position */ +#define SCB_CCSIDR_LINESIZE_Msk (7UL /*<< SCB_CCSIDR_LINESIZE_Pos*/) /*!< SCB CCSIDR: LineSize Mask */ + +/* SCB Cache Size Selection Register Definitions */ +#define SCB_CSSELR_LEVEL_Pos 1U /*!< SCB CSSELR: Level Position */ +#define SCB_CSSELR_LEVEL_Msk (7UL << SCB_CSSELR_LEVEL_Pos) /*!< SCB CSSELR: Level Mask */ + +#define SCB_CSSELR_IND_Pos 0U /*!< SCB CSSELR: InD Position */ +#define SCB_CSSELR_IND_Msk (1UL /*<< SCB_CSSELR_IND_Pos*/) /*!< SCB CSSELR: InD Mask */ + +/* SCB Software Triggered Interrupt Register Definitions */ +#define SCB_STIR_INTID_Pos 0U /*!< SCB STIR: INTID Position */ +#define SCB_STIR_INTID_Msk (0x1FFUL /*<< SCB_STIR_INTID_Pos*/) /*!< SCB STIR: INTID Mask */ + +/* SCB D-Cache Invalidate by Set-way Register Definitions */ +#define SCB_DCISW_WAY_Pos 30U /*!< SCB DCISW: Way Position */ +#define SCB_DCISW_WAY_Msk (3UL << SCB_DCISW_WAY_Pos) /*!< SCB DCISW: Way Mask */ + +#define SCB_DCISW_SET_Pos 5U /*!< SCB DCISW: Set Position */ +#define SCB_DCISW_SET_Msk (0x1FFUL << SCB_DCISW_SET_Pos) /*!< SCB DCISW: Set Mask */ + +/* SCB D-Cache Clean by Set-way Register Definitions */ +#define SCB_DCCSW_WAY_Pos 30U /*!< SCB DCCSW: Way Position */ +#define SCB_DCCSW_WAY_Msk (3UL << SCB_DCCSW_WAY_Pos) /*!< SCB DCCSW: Way Mask */ + +#define SCB_DCCSW_SET_Pos 5U /*!< SCB DCCSW: Set Position */ +#define SCB_DCCSW_SET_Msk (0x1FFUL << SCB_DCCSW_SET_Pos) /*!< SCB DCCSW: Set Mask */ + +/* SCB D-Cache Clean and Invalidate by Set-way Register Definitions */ +#define SCB_DCCISW_WAY_Pos 30U /*!< SCB DCCISW: Way Position */ +#define SCB_DCCISW_WAY_Msk (3UL << SCB_DCCISW_WAY_Pos) /*!< SCB DCCISW: Way Mask */ + +#define SCB_DCCISW_SET_Pos 5U /*!< SCB DCCISW: Set Position */ +#define SCB_DCCISW_SET_Msk (0x1FFUL << SCB_DCCISW_SET_Pos) /*!< SCB DCCISW: Set Mask */ + +/* Instruction Tightly-Coupled Memory Control Register Definitions */ +#define SCB_ITCMCR_SZ_Pos 3U /*!< SCB ITCMCR: SZ Position */ +#define SCB_ITCMCR_SZ_Msk (0xFUL << SCB_ITCMCR_SZ_Pos) /*!< SCB ITCMCR: SZ Mask */ + +#define SCB_ITCMCR_RETEN_Pos 2U /*!< SCB ITCMCR: RETEN Position */ +#define SCB_ITCMCR_RETEN_Msk (1UL << SCB_ITCMCR_RETEN_Pos) /*!< SCB ITCMCR: RETEN Mask */ + +#define SCB_ITCMCR_RMW_Pos 1U /*!< SCB ITCMCR: RMW Position */ +#define SCB_ITCMCR_RMW_Msk (1UL << SCB_ITCMCR_RMW_Pos) /*!< SCB ITCMCR: RMW Mask */ + +#define SCB_ITCMCR_EN_Pos 0U /*!< SCB ITCMCR: EN Position */ +#define SCB_ITCMCR_EN_Msk (1UL /*<< SCB_ITCMCR_EN_Pos*/) /*!< SCB ITCMCR: EN Mask */ + +/* Data Tightly-Coupled Memory Control Register Definitions */ +#define SCB_DTCMCR_SZ_Pos 3U /*!< SCB DTCMCR: SZ Position */ +#define SCB_DTCMCR_SZ_Msk (0xFUL << SCB_DTCMCR_SZ_Pos) /*!< SCB DTCMCR: SZ Mask */ + +#define SCB_DTCMCR_RETEN_Pos 2U /*!< SCB DTCMCR: RETEN Position */ +#define SCB_DTCMCR_RETEN_Msk (1UL << SCB_DTCMCR_RETEN_Pos) /*!< SCB DTCMCR: RETEN Mask */ + +#define SCB_DTCMCR_RMW_Pos 1U /*!< SCB DTCMCR: RMW Position */ +#define SCB_DTCMCR_RMW_Msk (1UL << SCB_DTCMCR_RMW_Pos) /*!< SCB DTCMCR: RMW Mask */ + +#define SCB_DTCMCR_EN_Pos 0U /*!< SCB DTCMCR: EN Position */ +#define SCB_DTCMCR_EN_Msk (1UL /*<< SCB_DTCMCR_EN_Pos*/) /*!< SCB DTCMCR: EN Mask */ + +/* AHBP Control Register Definitions */ +#define SCB_AHBPCR_SZ_Pos 1U /*!< SCB AHBPCR: SZ Position */ +#define SCB_AHBPCR_SZ_Msk (7UL << SCB_AHBPCR_SZ_Pos) /*!< SCB AHBPCR: SZ Mask */ + +#define SCB_AHBPCR_EN_Pos 0U /*!< SCB AHBPCR: EN Position */ +#define SCB_AHBPCR_EN_Msk (1UL /*<< SCB_AHBPCR_EN_Pos*/) /*!< SCB AHBPCR: EN Mask */ + +/* L1 Cache Control Register Definitions */ +#define SCB_CACR_FORCEWT_Pos 2U /*!< SCB CACR: FORCEWT Position */ +#define SCB_CACR_FORCEWT_Msk (1UL << SCB_CACR_FORCEWT_Pos) /*!< SCB CACR: FORCEWT Mask */ + +#define SCB_CACR_ECCEN_Pos 1U /*!< SCB CACR: ECCEN Position */ +#define SCB_CACR_ECCEN_Msk (1UL << SCB_CACR_ECCEN_Pos) /*!< SCB CACR: ECCEN Mask */ + +#define SCB_CACR_SIWT_Pos 0U /*!< SCB CACR: SIWT Position */ +#define SCB_CACR_SIWT_Msk (1UL /*<< SCB_CACR_SIWT_Pos*/) /*!< SCB CACR: SIWT Mask */ + +/* AHBS Control Register Definitions */ +#define SCB_AHBSCR_INITCOUNT_Pos 11U /*!< SCB AHBSCR: INITCOUNT Position */ +#define SCB_AHBSCR_INITCOUNT_Msk (0x1FUL << SCB_AHBPCR_INITCOUNT_Pos) /*!< SCB AHBSCR: INITCOUNT Mask */ + +#define SCB_AHBSCR_TPRI_Pos 2U /*!< SCB AHBSCR: TPRI Position */ +#define SCB_AHBSCR_TPRI_Msk (0x1FFUL << SCB_AHBPCR_TPRI_Pos) /*!< SCB AHBSCR: TPRI Mask */ + +#define SCB_AHBSCR_CTL_Pos 0U /*!< SCB AHBSCR: CTL Position*/ +#define SCB_AHBSCR_CTL_Msk (3UL /*<< SCB_AHBPCR_CTL_Pos*/) /*!< SCB AHBSCR: CTL Mask */ + +/* Auxiliary Bus Fault Status Register Definitions */ +#define SCB_ABFSR_AXIMTYPE_Pos 8U /*!< SCB ABFSR: AXIMTYPE Position*/ +#define SCB_ABFSR_AXIMTYPE_Msk (3UL << SCB_ABFSR_AXIMTYPE_Pos) /*!< SCB ABFSR: AXIMTYPE Mask */ + +#define SCB_ABFSR_EPPB_Pos 4U /*!< SCB ABFSR: EPPB Position*/ +#define SCB_ABFSR_EPPB_Msk (1UL << SCB_ABFSR_EPPB_Pos) /*!< SCB ABFSR: EPPB Mask */ + +#define SCB_ABFSR_AXIM_Pos 3U /*!< SCB ABFSR: AXIM Position*/ +#define SCB_ABFSR_AXIM_Msk (1UL << SCB_ABFSR_AXIM_Pos) /*!< SCB ABFSR: AXIM Mask */ + +#define SCB_ABFSR_AHBP_Pos 2U /*!< SCB ABFSR: AHBP Position*/ +#define SCB_ABFSR_AHBP_Msk (1UL << SCB_ABFSR_AHBP_Pos) /*!< SCB ABFSR: AHBP Mask */ + +#define SCB_ABFSR_DTCM_Pos 1U /*!< SCB ABFSR: DTCM Position*/ +#define SCB_ABFSR_DTCM_Msk (1UL << SCB_ABFSR_DTCM_Pos) /*!< SCB ABFSR: DTCM Mask */ + +#define SCB_ABFSR_ITCM_Pos 0U /*!< SCB ABFSR: ITCM Position*/ +#define SCB_ABFSR_ITCM_Msk (1UL /*<< SCB_ABFSR_ITCM_Pos*/) /*!< SCB ABFSR: ITCM Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_DISITMATBFLUSH_Pos 12U /*!< ACTLR: DISITMATBFLUSH Position */ +#define SCnSCB_ACTLR_DISITMATBFLUSH_Msk (1UL << SCnSCB_ACTLR_DISITMATBFLUSH_Pos) /*!< ACTLR: DISITMATBFLUSH Mask */ + +#define SCnSCB_ACTLR_DISRAMODE_Pos 11U /*!< ACTLR: DISRAMODE Position */ +#define SCnSCB_ACTLR_DISRAMODE_Msk (1UL << SCnSCB_ACTLR_DISRAMODE_Pos) /*!< ACTLR: DISRAMODE Mask */ + +#define SCnSCB_ACTLR_FPEXCODIS_Pos 10U /*!< ACTLR: FPEXCODIS Position */ +#define SCnSCB_ACTLR_FPEXCODIS_Msk (1UL << SCnSCB_ACTLR_FPEXCODIS_Pos) /*!< ACTLR: FPEXCODIS Mask */ + +#define SCnSCB_ACTLR_DISFOLD_Pos 2U /*!< ACTLR: DISFOLD Position */ +#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos) /*!< ACTLR: DISFOLD Mask */ + +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFFFFFFFFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ + uint32_t RESERVED3[981U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( W) Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R ) Lock Status Register */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +#define MPU_TYPE_RALIASES 4U + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif /* defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_FPU Floating Point Unit (FPU) + \brief Type definitions for the Floating Point Unit (FPU) + @{ + */ + +/** + \brief Structure type to access the Floating Point Unit (FPU). + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IOM uint32_t FPCCR; /*!< Offset: 0x004 (R/W) Floating-Point Context Control Register */ + __IOM uint32_t FPCAR; /*!< Offset: 0x008 (R/W) Floating-Point Context Address Register */ + __IOM uint32_t FPDSCR; /*!< Offset: 0x00C (R/W) Floating-Point Default Status Control Register */ + __IM uint32_t MVFR0; /*!< Offset: 0x010 (R/ ) Media and FP Feature Register 0 */ + __IM uint32_t MVFR1; /*!< Offset: 0x014 (R/ ) Media and FP Feature Register 1 */ + __IM uint32_t MVFR2; /*!< Offset: 0x018 (R/ ) Media and FP Feature Register 2 */ +} FPU_Type; + +/* Floating-Point Context Control Register Definitions */ +#define FPU_FPCCR_ASPEN_Pos 31U /*!< FPCCR: ASPEN bit Position */ +#define FPU_FPCCR_ASPEN_Msk (1UL << FPU_FPCCR_ASPEN_Pos) /*!< FPCCR: ASPEN bit Mask */ + +#define FPU_FPCCR_LSPEN_Pos 30U /*!< FPCCR: LSPEN Position */ +#define FPU_FPCCR_LSPEN_Msk (1UL << FPU_FPCCR_LSPEN_Pos) /*!< FPCCR: LSPEN bit Mask */ + +#define FPU_FPCCR_MONRDY_Pos 8U /*!< FPCCR: MONRDY Position */ +#define FPU_FPCCR_MONRDY_Msk (1UL << FPU_FPCCR_MONRDY_Pos) /*!< FPCCR: MONRDY bit Mask */ + +#define FPU_FPCCR_BFRDY_Pos 6U /*!< FPCCR: BFRDY Position */ +#define FPU_FPCCR_BFRDY_Msk (1UL << FPU_FPCCR_BFRDY_Pos) /*!< FPCCR: BFRDY bit Mask */ + +#define FPU_FPCCR_MMRDY_Pos 5U /*!< FPCCR: MMRDY Position */ +#define FPU_FPCCR_MMRDY_Msk (1UL << FPU_FPCCR_MMRDY_Pos) /*!< FPCCR: MMRDY bit Mask */ + +#define FPU_FPCCR_HFRDY_Pos 4U /*!< FPCCR: HFRDY Position */ +#define FPU_FPCCR_HFRDY_Msk (1UL << FPU_FPCCR_HFRDY_Pos) /*!< FPCCR: HFRDY bit Mask */ + +#define FPU_FPCCR_THREAD_Pos 3U /*!< FPCCR: processor mode bit Position */ +#define FPU_FPCCR_THREAD_Msk (1UL << FPU_FPCCR_THREAD_Pos) /*!< FPCCR: processor mode active bit Mask */ + +#define FPU_FPCCR_USER_Pos 1U /*!< FPCCR: privilege level bit Position */ +#define FPU_FPCCR_USER_Msk (1UL << FPU_FPCCR_USER_Pos) /*!< FPCCR: privilege level bit Mask */ + +#define FPU_FPCCR_LSPACT_Pos 0U /*!< FPCCR: Lazy state preservation active bit Position */ +#define FPU_FPCCR_LSPACT_Msk (1UL /*<< FPU_FPCCR_LSPACT_Pos*/) /*!< FPCCR: Lazy state preservation active bit Mask */ + +/* Floating-Point Context Address Register Definitions */ +#define FPU_FPCAR_ADDRESS_Pos 3U /*!< FPCAR: ADDRESS bit Position */ +#define FPU_FPCAR_ADDRESS_Msk (0x1FFFFFFFUL << FPU_FPCAR_ADDRESS_Pos) /*!< FPCAR: ADDRESS bit Mask */ + +/* Floating-Point Default Status Control Register Definitions */ +#define FPU_FPDSCR_AHP_Pos 26U /*!< FPDSCR: AHP bit Position */ +#define FPU_FPDSCR_AHP_Msk (1UL << FPU_FPDSCR_AHP_Pos) /*!< FPDSCR: AHP bit Mask */ + +#define FPU_FPDSCR_DN_Pos 25U /*!< FPDSCR: DN bit Position */ +#define FPU_FPDSCR_DN_Msk (1UL << FPU_FPDSCR_DN_Pos) /*!< FPDSCR: DN bit Mask */ + +#define FPU_FPDSCR_FZ_Pos 24U /*!< FPDSCR: FZ bit Position */ +#define FPU_FPDSCR_FZ_Msk (1UL << FPU_FPDSCR_FZ_Pos) /*!< FPDSCR: FZ bit Mask */ + +#define FPU_FPDSCR_RMode_Pos 22U /*!< FPDSCR: RMode bit Position */ +#define FPU_FPDSCR_RMode_Msk (3UL << FPU_FPDSCR_RMode_Pos) /*!< FPDSCR: RMode bit Mask */ + +/* Media and FP Feature Register 0 Definitions */ +#define FPU_MVFR0_FP_rounding_modes_Pos 28U /*!< MVFR0: FP rounding modes bits Position */ +#define FPU_MVFR0_FP_rounding_modes_Msk (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos) /*!< MVFR0: FP rounding modes bits Mask */ + +#define FPU_MVFR0_Short_vectors_Pos 24U /*!< MVFR0: Short vectors bits Position */ +#define FPU_MVFR0_Short_vectors_Msk (0xFUL << FPU_MVFR0_Short_vectors_Pos) /*!< MVFR0: Short vectors bits Mask */ + +#define FPU_MVFR0_Square_root_Pos 20U /*!< MVFR0: Square root bits Position */ +#define FPU_MVFR0_Square_root_Msk (0xFUL << FPU_MVFR0_Square_root_Pos) /*!< MVFR0: Square root bits Mask */ + +#define FPU_MVFR0_Divide_Pos 16U /*!< MVFR0: Divide bits Position */ +#define FPU_MVFR0_Divide_Msk (0xFUL << FPU_MVFR0_Divide_Pos) /*!< MVFR0: Divide bits Mask */ + +#define FPU_MVFR0_FP_excep_trapping_Pos 12U /*!< MVFR0: FP exception trapping bits Position */ +#define FPU_MVFR0_FP_excep_trapping_Msk (0xFUL << FPU_MVFR0_FP_excep_trapping_Pos) /*!< MVFR0: FP exception trapping bits Mask */ + +#define FPU_MVFR0_Double_precision_Pos 8U /*!< MVFR0: Double-precision bits Position */ +#define FPU_MVFR0_Double_precision_Msk (0xFUL << FPU_MVFR0_Double_precision_Pos) /*!< MVFR0: Double-precision bits Mask */ + +#define FPU_MVFR0_Single_precision_Pos 4U /*!< MVFR0: Single-precision bits Position */ +#define FPU_MVFR0_Single_precision_Msk (0xFUL << FPU_MVFR0_Single_precision_Pos) /*!< MVFR0: Single-precision bits Mask */ + +#define FPU_MVFR0_A_SIMD_registers_Pos 0U /*!< MVFR0: A_SIMD registers bits Position */ +#define FPU_MVFR0_A_SIMD_registers_Msk (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/) /*!< MVFR0: A_SIMD registers bits Mask */ + +/* Media and FP Feature Register 1 Definitions */ +#define FPU_MVFR1_FP_fused_MAC_Pos 28U /*!< MVFR1: FP fused MAC bits Position */ +#define FPU_MVFR1_FP_fused_MAC_Msk (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos) /*!< MVFR1: FP fused MAC bits Mask */ + +#define FPU_MVFR1_FP_HPFP_Pos 24U /*!< MVFR1: FP HPFP bits Position */ +#define FPU_MVFR1_FP_HPFP_Msk (0xFUL << FPU_MVFR1_FP_HPFP_Pos) /*!< MVFR1: FP HPFP bits Mask */ + +#define FPU_MVFR1_D_NaN_mode_Pos 4U /*!< MVFR1: D_NaN mode bits Position */ +#define FPU_MVFR1_D_NaN_mode_Msk (0xFUL << FPU_MVFR1_D_NaN_mode_Pos) /*!< MVFR1: D_NaN mode bits Mask */ + +#define FPU_MVFR1_FtZ_mode_Pos 0U /*!< MVFR1: FtZ mode bits Position */ +#define FPU_MVFR1_FtZ_mode_Msk (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/) /*!< MVFR1: FtZ mode bits Mask */ + +/* Media and FP Feature Register 2 Definitions */ + +/*@} end of group CMSIS_FPU */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +#define FPU_BASE (SCS_BASE + 0x0F30UL) /*!< Floating Point Unit */ +#define FPU ((FPU_Type *) FPU_BASE ) /*!< Floating Point Unit */ + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ +#define EXC_RETURN_HANDLER_FPU (0xFFFFFFE1UL) /* return to Handler mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_MSP_FPU (0xFFFFFFE9UL) /* return to Thread mode, uses MSP after return, restore floating-point state */ +#define EXC_RETURN_THREAD_PSP_FPU (0xFFFFFFEDUL) /* return to Thread mode, uses PSP after return, restore floating-point state */ + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos) ); /* Insert write key and priority group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + +/* ########################## MPU functions #################################### */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + +#include "mpu_armv7.h" + +#endif + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + uint32_t mvfr0; + + mvfr0 = SCB->MVFR0; + if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x220U) + { + return 2U; /* Double + Single precision FPU */ + } + else if ((mvfr0 & (FPU_MVFR0_Single_precision_Msk | FPU_MVFR0_Double_precision_Msk)) == 0x020U) + { + return 1U; /* Single precision FPU */ + } + else + { + return 0U; /* No FPU */ + } +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ########################## Cache functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_CacheFunctions Cache Functions + \brief Functions that configure Instruction and Data cache. + @{ + */ + +/* Cache Size ID Register Macros */ +#define CCSIDR_WAYS(x) (((x) & SCB_CCSIDR_ASSOCIATIVITY_Msk) >> SCB_CCSIDR_ASSOCIATIVITY_Pos) +#define CCSIDR_SETS(x) (((x) & SCB_CCSIDR_NUMSETS_Msk ) >> SCB_CCSIDR_NUMSETS_Pos ) + + +/** + \brief Enable I-Cache + \details Turns on I-Cache + */ +__STATIC_INLINE void SCB_EnableICache (void) +{ + #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) + __DSB(); + __ISB(); + SCB->ICIALLU = 0UL; /* invalidate I-Cache */ + __DSB(); + __ISB(); + SCB->CCR |= (uint32_t)SCB_CCR_IC_Msk; /* enable I-Cache */ + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Disable I-Cache + \details Turns off I-Cache + */ +__STATIC_INLINE void SCB_DisableICache (void) +{ + #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) + __DSB(); + __ISB(); + SCB->CCR &= ~(uint32_t)SCB_CCR_IC_Msk; /* disable I-Cache */ + SCB->ICIALLU = 0UL; /* invalidate I-Cache */ + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Invalidate I-Cache + \details Invalidates I-Cache + */ +__STATIC_INLINE void SCB_InvalidateICache (void) +{ + #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) + __DSB(); + __ISB(); + SCB->ICIALLU = 0UL; + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Enable D-Cache + \details Turns on D-Cache + */ +__STATIC_INLINE void SCB_EnableDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | + ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + __DSB(); + + SCB->CCR |= (uint32_t)SCB_CCR_DC_Msk; /* enable D-Cache */ + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Disable D-Cache + \details Turns off D-Cache + */ +__STATIC_INLINE void SCB_DisableDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + SCB->CCR &= ~(uint32_t)SCB_CCR_DC_Msk; /* disable D-Cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* clean & invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | + ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Invalidate D-Cache + \details Invalidates D-Cache + */ +__STATIC_INLINE void SCB_InvalidateDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | + ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Clean D-Cache + \details Cleans D-Cache + */ +__STATIC_INLINE void SCB_CleanDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* clean D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCCSW = (((sets << SCB_DCCSW_SET_Pos) & SCB_DCCSW_SET_Msk) | + ((ways << SCB_DCCSW_WAY_Pos) & SCB_DCCSW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief Clean & Invalidate D-Cache + \details Cleans and Invalidates D-Cache + */ +__STATIC_INLINE void SCB_CleanInvalidateDCache (void) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + uint32_t ccsidr; + uint32_t sets; + uint32_t ways; + + SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/ /* Level 1 data cache */ + __DSB(); + + ccsidr = SCB->CCSIDR; + + /* clean & invalidate D-Cache */ + sets = (uint32_t)(CCSIDR_SETS(ccsidr)); + do { + ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); + do { + SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | + ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk) ); + #if defined ( __CC_ARM ) + __schedule_barrier(); + #endif + } while (ways-- != 0U); + } while(sets-- != 0U); + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief D-Cache Invalidate by address + \details Invalidates D-Cache for the given address + \param[in] addr address (aligned to 32-byte boundary) + \param[in] dsize size of memory block (in number of bytes) +*/ +__STATIC_INLINE void SCB_InvalidateDCache_by_Addr (uint32_t *addr, int32_t dsize) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + int32_t op_size = dsize; + uint32_t op_addr = (uint32_t)addr; + int32_t linesize = 32; /* in Cortex-M7 size of cache line is fixed to 8 words (32 bytes) */ + + __DSB(); + + while (op_size > 0) { + SCB->DCIMVAC = op_addr; + op_addr += (uint32_t)linesize; + op_size -= linesize; + } + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief D-Cache Clean by address + \details Cleans D-Cache for the given address + \param[in] addr address (aligned to 32-byte boundary) + \param[in] dsize size of memory block (in number of bytes) +*/ +__STATIC_INLINE void SCB_CleanDCache_by_Addr (uint32_t *addr, int32_t dsize) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + int32_t op_size = dsize; + uint32_t op_addr = (uint32_t) addr; + int32_t linesize = 32; /* in Cortex-M7 size of cache line is fixed to 8 words (32 bytes) */ + + __DSB(); + + while (op_size > 0) { + SCB->DCCMVAC = op_addr; + op_addr += (uint32_t)linesize; + op_size -= linesize; + } + + __DSB(); + __ISB(); + #endif +} + + +/** + \brief D-Cache Clean and Invalidate by address + \details Cleans and invalidates D_Cache for the given address + \param[in] addr address (aligned to 32-byte boundary) + \param[in] dsize size of memory block (in number of bytes) +*/ +__STATIC_INLINE void SCB_CleanInvalidateDCache_by_Addr (uint32_t *addr, int32_t dsize) +{ + #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) + int32_t op_size = dsize; + uint32_t op_addr = (uint32_t) addr; + int32_t linesize = 32; /* in Cortex-M7 size of cache line is fixed to 8 words (32 bytes) */ + + __DSB(); + + while (op_size > 0) { + SCB->DCCIMVAC = op_addr; + op_addr += (uint32_t)linesize; + op_size -= linesize; + } + + __DSB(); + __ISB(); + #endif +} + + +/*@} end of CMSIS_Core_CacheFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_CM7_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_sc000.h b/Chapter04/bare/platform/CMSIS/Include/core_sc000.h new file mode 100644 index 0000000..9086c64 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_sc000.h @@ -0,0 +1,1022 @@ +/**************************************************************************//** + * @file core_sc000.h + * @brief CMSIS SC000 Core Peripheral Access Layer Header File + * @version V5.0.5 + * @date 28. May 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_SC000_H_GENERIC +#define __CORE_SC000_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup SC000 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS SC000 definitions */ +#define __SC000_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __SC000_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __SC000_CMSIS_VERSION ((__SC000_CMSIS_VERSION_MAIN << 16U) | \ + __SC000_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_SC (000U) /*!< Cortex secure core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC000_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_SC000_H_DEPENDANT +#define __CORE_SC000_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __SC000_REV + #define __SC000_REV 0x0000U + #warning "__SC000_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 2U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group SC000 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:28; /*!< bit: 0..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:15; /*!< bit: 9..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit (read 0) */ + uint32_t _reserved1:3; /*!< bit: 25..27 Reserved */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t _reserved0:1; /*!< bit: 0 Reserved */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[1U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[31U]; + __IOM uint32_t ICER[1U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[31U]; + __IOM uint32_t ISPR[1U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[31U]; + __IOM uint32_t ICPR[1U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[31U]; + uint32_t RESERVED4[64U]; + __IOM uint32_t IP[8U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register */ +} NVIC_Type; + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + uint32_t RESERVED0[1U]; + __IOM uint32_t SHP[2U]; /*!< Offset: 0x01C (R/W) System Handlers Priority Registers. [0] is RESERVED */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + uint32_t RESERVED1[154U]; + __IOM uint32_t SFCR; /*!< Offset: 0x290 (R/W) Security Features Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACTLR; /*!< Offset: 0x008 (R/W) Auxiliary Control Register */ +} SCnSCB_Type; + +/* Auxiliary Control Register Definitions */ +#define SCnSCB_ACTLR_DISMCYCINT_Pos 0U /*!< ACTLR: DISMCYCINT Position */ +#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/) /*!< ACTLR: DISMCYCINT Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ +} MPU_Type; + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 8U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0xFFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief SC000 Core Debug Registers (DCB registers, SHCSR, and DFSR) are only accessible over DAP and not via processor. + Therefore they are not covered by the SC000 header file. + @{ + */ +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else +/*#define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping not available for SC000 */ +/*#define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping not available for SC000 */ + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ +/*#define NVIC_GetActive __NVIC_GetActive not available for SC000 */ + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + +/* Interrupt Priorities are WORD accessible only under Armv6-M */ +/* The following MACROS handle generation of the register offset and byte masks */ +#define _BIT_SHIFT(IRQn) ( ((((uint32_t)(int32_t)(IRQn)) ) & 0x03UL) * 8UL) +#define _SHP_IDX(IRQn) ( (((((uint32_t)(int32_t)(IRQn)) & 0x0FUL)-8UL) >> 2UL) ) +#define _IP_IDX(IRQn) ( (((uint32_t)(int32_t)(IRQn)) >> 2UL) ) + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[0U] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } + else + { + SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) | + (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn))); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IP[ _IP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return((uint32_t)(((SCB->SHP[_SHP_IDX(IRQn)] >> _BIT_SHIFT(IRQn) ) & (uint32_t)0xFFUL) >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = ((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + SCB_AIRCR_SYSRESETREQ_Msk); + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC000_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/core_sc300.h b/Chapter04/bare/platform/CMSIS/Include/core_sc300.h new file mode 100644 index 0000000..665822d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/core_sc300.h @@ -0,0 +1,1915 @@ +/**************************************************************************//** + * @file core_sc300.h + * @brief CMSIS SC300 Core Peripheral Access Layer Header File + * @version V5.0.6 + * @date 04. June 2018 + ******************************************************************************/ +/* + * Copyright (c) 2009-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef __CORE_SC300_H_GENERIC +#define __CORE_SC300_H_GENERIC + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + \page CMSIS_MISRA_Exceptions MISRA-C:2004 Compliance Exceptions + CMSIS violates the following MISRA-C:2004 rules: + + \li Required Rule 8.5, object/function definition in header file.
+ Function definitions in header files are used to allow 'inlining'. + + \li Required Rule 18.4, declaration of union type or object of union type: '{...}'.
+ Unions are used for effective representation of core registers. + + \li Advisory Rule 19.7, Function-like macro defined.
+ Function-like macros are used to allow more efficient code. + */ + + +/******************************************************************************* + * CMSIS definitions + ******************************************************************************/ +/** + \ingroup SC3000 + @{ + */ + +#include "cmsis_version.h" + +/* CMSIS SC300 definitions */ +#define __SC300_CMSIS_VERSION_MAIN (__CM_CMSIS_VERSION_MAIN) /*!< \deprecated [31:16] CMSIS HAL main version */ +#define __SC300_CMSIS_VERSION_SUB (__CM_CMSIS_VERSION_SUB) /*!< \deprecated [15:0] CMSIS HAL sub version */ +#define __SC300_CMSIS_VERSION ((__SC300_CMSIS_VERSION_MAIN << 16U) | \ + __SC300_CMSIS_VERSION_SUB ) /*!< \deprecated CMSIS HAL version number */ + +#define __CORTEX_SC (300U) /*!< Cortex secure core */ + +/** __FPU_USED indicates whether an FPU is used or not. + This core does not support an FPU at all +*/ +#define __FPU_USED 0U + +#if defined ( __CC_ARM ) + #if defined __TARGET_FPU_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) + #if defined __ARM_PCS_VFP + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __GNUC__ ) + #if defined (__VFP_FP__) && !defined(__SOFTFP__) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __ICCARM__ ) + #if defined __ARMVFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TI_ARM__ ) + #if defined __TI_VFP_SUPPORT__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __TASKING__ ) + #if defined __FPU_VFP__ + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#elif defined ( __CSMC__ ) + #if ( __CSMC__ & 0x400U) + #error "Compiler generates FPU instructions for a device without an FPU (check __FPU_PRESENT)" + #endif + +#endif + +#include "cmsis_compiler.h" /* CMSIS compiler specific defines */ + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC300_H_GENERIC */ + +#ifndef __CMSIS_GENERIC + +#ifndef __CORE_SC300_H_DEPENDANT +#define __CORE_SC300_H_DEPENDANT + +#ifdef __cplusplus + extern "C" { +#endif + +/* check device defines and use defaults */ +#if defined __CHECK_DEVICE_DEFINES + #ifndef __SC300_REV + #define __SC300_REV 0x0000U + #warning "__SC300_REV not defined in device header file; using default!" + #endif + + #ifndef __MPU_PRESENT + #define __MPU_PRESENT 0U + #warning "__MPU_PRESENT not defined in device header file; using default!" + #endif + + #ifndef __NVIC_PRIO_BITS + #define __NVIC_PRIO_BITS 3U + #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" + #endif + + #ifndef __Vendor_SysTickConfig + #define __Vendor_SysTickConfig 0U + #warning "__Vendor_SysTickConfig not defined in device header file; using default!" + #endif +#endif + +/* IO definitions (access restrictions to peripheral registers) */ +/** + \defgroup CMSIS_glob_defs CMSIS Global Defines + + IO Type Qualifiers are used + \li to specify the access to peripheral variables. + \li for automatic generation of peripheral register debug information. +*/ +#ifdef __cplusplus + #define __I volatile /*!< Defines 'read only' permissions */ +#else + #define __I volatile const /*!< Defines 'read only' permissions */ +#endif +#define __O volatile /*!< Defines 'write only' permissions */ +#define __IO volatile /*!< Defines 'read / write' permissions */ + +/* following defines should be used for structure members */ +#define __IM volatile const /*! Defines 'read only' structure member permissions */ +#define __OM volatile /*! Defines 'write only' structure member permissions */ +#define __IOM volatile /*! Defines 'read / write' structure member permissions */ + +/*@} end of group SC300 */ + + + +/******************************************************************************* + * Register Abstraction + Core Register contain: + - Core Register + - Core NVIC Register + - Core SCB Register + - Core SysTick Register + - Core Debug Register + - Core MPU Register + ******************************************************************************/ +/** + \defgroup CMSIS_core_register Defines and Type Definitions + \brief Type definitions and defines for Cortex-M processor based devices. +*/ + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CORE Status and Control Registers + \brief Core Register type definitions. + @{ + */ + +/** + \brief Union type to access the Application Program Status Register (APSR). + */ +typedef union +{ + struct + { + uint32_t _reserved0:27; /*!< bit: 0..26 Reserved */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} APSR_Type; + +/* APSR Register Definitions */ +#define APSR_N_Pos 31U /*!< APSR: N Position */ +#define APSR_N_Msk (1UL << APSR_N_Pos) /*!< APSR: N Mask */ + +#define APSR_Z_Pos 30U /*!< APSR: Z Position */ +#define APSR_Z_Msk (1UL << APSR_Z_Pos) /*!< APSR: Z Mask */ + +#define APSR_C_Pos 29U /*!< APSR: C Position */ +#define APSR_C_Msk (1UL << APSR_C_Pos) /*!< APSR: C Mask */ + +#define APSR_V_Pos 28U /*!< APSR: V Position */ +#define APSR_V_Msk (1UL << APSR_V_Pos) /*!< APSR: V Mask */ + +#define APSR_Q_Pos 27U /*!< APSR: Q Position */ +#define APSR_Q_Msk (1UL << APSR_Q_Pos) /*!< APSR: Q Mask */ + + +/** + \brief Union type to access the Interrupt Program Status Register (IPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:23; /*!< bit: 9..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} IPSR_Type; + +/* IPSR Register Definitions */ +#define IPSR_ISR_Pos 0U /*!< IPSR: ISR Position */ +#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/) /*!< IPSR: ISR Mask */ + + +/** + \brief Union type to access the Special-Purpose Program Status Registers (xPSR). + */ +typedef union +{ + struct + { + uint32_t ISR:9; /*!< bit: 0.. 8 Exception number */ + uint32_t _reserved0:1; /*!< bit: 9 Reserved */ + uint32_t ICI_IT_1:6; /*!< bit: 10..15 ICI/IT part 1 */ + uint32_t _reserved1:8; /*!< bit: 16..23 Reserved */ + uint32_t T:1; /*!< bit: 24 Thumb bit */ + uint32_t ICI_IT_2:2; /*!< bit: 25..26 ICI/IT part 2 */ + uint32_t Q:1; /*!< bit: 27 Saturation condition flag */ + uint32_t V:1; /*!< bit: 28 Overflow condition code flag */ + uint32_t C:1; /*!< bit: 29 Carry condition code flag */ + uint32_t Z:1; /*!< bit: 30 Zero condition code flag */ + uint32_t N:1; /*!< bit: 31 Negative condition code flag */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} xPSR_Type; + +/* xPSR Register Definitions */ +#define xPSR_N_Pos 31U /*!< xPSR: N Position */ +#define xPSR_N_Msk (1UL << xPSR_N_Pos) /*!< xPSR: N Mask */ + +#define xPSR_Z_Pos 30U /*!< xPSR: Z Position */ +#define xPSR_Z_Msk (1UL << xPSR_Z_Pos) /*!< xPSR: Z Mask */ + +#define xPSR_C_Pos 29U /*!< xPSR: C Position */ +#define xPSR_C_Msk (1UL << xPSR_C_Pos) /*!< xPSR: C Mask */ + +#define xPSR_V_Pos 28U /*!< xPSR: V Position */ +#define xPSR_V_Msk (1UL << xPSR_V_Pos) /*!< xPSR: V Mask */ + +#define xPSR_Q_Pos 27U /*!< xPSR: Q Position */ +#define xPSR_Q_Msk (1UL << xPSR_Q_Pos) /*!< xPSR: Q Mask */ + +#define xPSR_ICI_IT_2_Pos 25U /*!< xPSR: ICI/IT part 2 Position */ +#define xPSR_ICI_IT_2_Msk (3UL << xPSR_ICI_IT_2_Pos) /*!< xPSR: ICI/IT part 2 Mask */ + +#define xPSR_T_Pos 24U /*!< xPSR: T Position */ +#define xPSR_T_Msk (1UL << xPSR_T_Pos) /*!< xPSR: T Mask */ + +#define xPSR_ICI_IT_1_Pos 10U /*!< xPSR: ICI/IT part 1 Position */ +#define xPSR_ICI_IT_1_Msk (0x3FUL << xPSR_ICI_IT_1_Pos) /*!< xPSR: ICI/IT part 1 Mask */ + +#define xPSR_ISR_Pos 0U /*!< xPSR: ISR Position */ +#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/) /*!< xPSR: ISR Mask */ + + +/** + \brief Union type to access the Control Registers (CONTROL). + */ +typedef union +{ + struct + { + uint32_t nPRIV:1; /*!< bit: 0 Execution privilege in Thread mode */ + uint32_t SPSEL:1; /*!< bit: 1 Stack to be used */ + uint32_t _reserved1:30; /*!< bit: 2..31 Reserved */ + } b; /*!< Structure used for bit access */ + uint32_t w; /*!< Type used for word access */ +} CONTROL_Type; + +/* CONTROL Register Definitions */ +#define CONTROL_SPSEL_Pos 1U /*!< CONTROL: SPSEL Position */ +#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos) /*!< CONTROL: SPSEL Mask */ + +#define CONTROL_nPRIV_Pos 0U /*!< CONTROL: nPRIV Position */ +#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/) /*!< CONTROL: nPRIV Mask */ + +/*@} end of group CMSIS_CORE */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_NVIC Nested Vectored Interrupt Controller (NVIC) + \brief Type definitions for the NVIC Registers + @{ + */ + +/** + \brief Structure type to access the Nested Vectored Interrupt Controller (NVIC). + */ +typedef struct +{ + __IOM uint32_t ISER[8U]; /*!< Offset: 0x000 (R/W) Interrupt Set Enable Register */ + uint32_t RESERVED0[24U]; + __IOM uint32_t ICER[8U]; /*!< Offset: 0x080 (R/W) Interrupt Clear Enable Register */ + uint32_t RSERVED1[24U]; + __IOM uint32_t ISPR[8U]; /*!< Offset: 0x100 (R/W) Interrupt Set Pending Register */ + uint32_t RESERVED2[24U]; + __IOM uint32_t ICPR[8U]; /*!< Offset: 0x180 (R/W) Interrupt Clear Pending Register */ + uint32_t RESERVED3[24U]; + __IOM uint32_t IABR[8U]; /*!< Offset: 0x200 (R/W) Interrupt Active bit Register */ + uint32_t RESERVED4[56U]; + __IOM uint8_t IP[240U]; /*!< Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide) */ + uint32_t RESERVED5[644U]; + __OM uint32_t STIR; /*!< Offset: 0xE00 ( /W) Software Trigger Interrupt Register */ +} NVIC_Type; + +/* Software Triggered Interrupt Register Definitions */ +#define NVIC_STIR_INTID_Pos 0U /*!< STIR: INTLINESNUM Position */ +#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/) /*!< STIR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_NVIC */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCB System Control Block (SCB) + \brief Type definitions for the System Control Block Registers + @{ + */ + +/** + \brief Structure type to access the System Control Block (SCB). + */ +typedef struct +{ + __IM uint32_t CPUID; /*!< Offset: 0x000 (R/ ) CPUID Base Register */ + __IOM uint32_t ICSR; /*!< Offset: 0x004 (R/W) Interrupt Control and State Register */ + __IOM uint32_t VTOR; /*!< Offset: 0x008 (R/W) Vector Table Offset Register */ + __IOM uint32_t AIRCR; /*!< Offset: 0x00C (R/W) Application Interrupt and Reset Control Register */ + __IOM uint32_t SCR; /*!< Offset: 0x010 (R/W) System Control Register */ + __IOM uint32_t CCR; /*!< Offset: 0x014 (R/W) Configuration Control Register */ + __IOM uint8_t SHP[12U]; /*!< Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15) */ + __IOM uint32_t SHCSR; /*!< Offset: 0x024 (R/W) System Handler Control and State Register */ + __IOM uint32_t CFSR; /*!< Offset: 0x028 (R/W) Configurable Fault Status Register */ + __IOM uint32_t HFSR; /*!< Offset: 0x02C (R/W) HardFault Status Register */ + __IOM uint32_t DFSR; /*!< Offset: 0x030 (R/W) Debug Fault Status Register */ + __IOM uint32_t MMFAR; /*!< Offset: 0x034 (R/W) MemManage Fault Address Register */ + __IOM uint32_t BFAR; /*!< Offset: 0x038 (R/W) BusFault Address Register */ + __IOM uint32_t AFSR; /*!< Offset: 0x03C (R/W) Auxiliary Fault Status Register */ + __IM uint32_t PFR[2U]; /*!< Offset: 0x040 (R/ ) Processor Feature Register */ + __IM uint32_t DFR; /*!< Offset: 0x048 (R/ ) Debug Feature Register */ + __IM uint32_t ADR; /*!< Offset: 0x04C (R/ ) Auxiliary Feature Register */ + __IM uint32_t MMFR[4U]; /*!< Offset: 0x050 (R/ ) Memory Model Feature Register */ + __IM uint32_t ISAR[5U]; /*!< Offset: 0x060 (R/ ) Instruction Set Attributes Register */ + uint32_t RESERVED0[5U]; + __IOM uint32_t CPACR; /*!< Offset: 0x088 (R/W) Coprocessor Access Control Register */ + uint32_t RESERVED1[129U]; + __IOM uint32_t SFCR; /*!< Offset: 0x290 (R/W) Security Features Control Register */ +} SCB_Type; + +/* SCB CPUID Register Definitions */ +#define SCB_CPUID_IMPLEMENTER_Pos 24U /*!< SCB CPUID: IMPLEMENTER Position */ +#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos) /*!< SCB CPUID: IMPLEMENTER Mask */ + +#define SCB_CPUID_VARIANT_Pos 20U /*!< SCB CPUID: VARIANT Position */ +#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos) /*!< SCB CPUID: VARIANT Mask */ + +#define SCB_CPUID_ARCHITECTURE_Pos 16U /*!< SCB CPUID: ARCHITECTURE Position */ +#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos) /*!< SCB CPUID: ARCHITECTURE Mask */ + +#define SCB_CPUID_PARTNO_Pos 4U /*!< SCB CPUID: PARTNO Position */ +#define SCB_CPUID_PARTNO_Msk (0xFFFUL << SCB_CPUID_PARTNO_Pos) /*!< SCB CPUID: PARTNO Mask */ + +#define SCB_CPUID_REVISION_Pos 0U /*!< SCB CPUID: REVISION Position */ +#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/) /*!< SCB CPUID: REVISION Mask */ + +/* SCB Interrupt Control State Register Definitions */ +#define SCB_ICSR_NMIPENDSET_Pos 31U /*!< SCB ICSR: NMIPENDSET Position */ +#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos) /*!< SCB ICSR: NMIPENDSET Mask */ + +#define SCB_ICSR_PENDSVSET_Pos 28U /*!< SCB ICSR: PENDSVSET Position */ +#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos) /*!< SCB ICSR: PENDSVSET Mask */ + +#define SCB_ICSR_PENDSVCLR_Pos 27U /*!< SCB ICSR: PENDSVCLR Position */ +#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos) /*!< SCB ICSR: PENDSVCLR Mask */ + +#define SCB_ICSR_PENDSTSET_Pos 26U /*!< SCB ICSR: PENDSTSET Position */ +#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos) /*!< SCB ICSR: PENDSTSET Mask */ + +#define SCB_ICSR_PENDSTCLR_Pos 25U /*!< SCB ICSR: PENDSTCLR Position */ +#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos) /*!< SCB ICSR: PENDSTCLR Mask */ + +#define SCB_ICSR_ISRPREEMPT_Pos 23U /*!< SCB ICSR: ISRPREEMPT Position */ +#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos) /*!< SCB ICSR: ISRPREEMPT Mask */ + +#define SCB_ICSR_ISRPENDING_Pos 22U /*!< SCB ICSR: ISRPENDING Position */ +#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos) /*!< SCB ICSR: ISRPENDING Mask */ + +#define SCB_ICSR_VECTPENDING_Pos 12U /*!< SCB ICSR: VECTPENDING Position */ +#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos) /*!< SCB ICSR: VECTPENDING Mask */ + +#define SCB_ICSR_RETTOBASE_Pos 11U /*!< SCB ICSR: RETTOBASE Position */ +#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos) /*!< SCB ICSR: RETTOBASE Mask */ + +#define SCB_ICSR_VECTACTIVE_Pos 0U /*!< SCB ICSR: VECTACTIVE Position */ +#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/) /*!< SCB ICSR: VECTACTIVE Mask */ + +/* SCB Vector Table Offset Register Definitions */ +#define SCB_VTOR_TBLBASE_Pos 29U /*!< SCB VTOR: TBLBASE Position */ +#define SCB_VTOR_TBLBASE_Msk (1UL << SCB_VTOR_TBLBASE_Pos) /*!< SCB VTOR: TBLBASE Mask */ + +#define SCB_VTOR_TBLOFF_Pos 7U /*!< SCB VTOR: TBLOFF Position */ +#define SCB_VTOR_TBLOFF_Msk (0x3FFFFFUL << SCB_VTOR_TBLOFF_Pos) /*!< SCB VTOR: TBLOFF Mask */ + +/* SCB Application Interrupt and Reset Control Register Definitions */ +#define SCB_AIRCR_VECTKEY_Pos 16U /*!< SCB AIRCR: VECTKEY Position */ +#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos) /*!< SCB AIRCR: VECTKEY Mask */ + +#define SCB_AIRCR_VECTKEYSTAT_Pos 16U /*!< SCB AIRCR: VECTKEYSTAT Position */ +#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos) /*!< SCB AIRCR: VECTKEYSTAT Mask */ + +#define SCB_AIRCR_ENDIANESS_Pos 15U /*!< SCB AIRCR: ENDIANESS Position */ +#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos) /*!< SCB AIRCR: ENDIANESS Mask */ + +#define SCB_AIRCR_PRIGROUP_Pos 8U /*!< SCB AIRCR: PRIGROUP Position */ +#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos) /*!< SCB AIRCR: PRIGROUP Mask */ + +#define SCB_AIRCR_SYSRESETREQ_Pos 2U /*!< SCB AIRCR: SYSRESETREQ Position */ +#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos) /*!< SCB AIRCR: SYSRESETREQ Mask */ + +#define SCB_AIRCR_VECTCLRACTIVE_Pos 1U /*!< SCB AIRCR: VECTCLRACTIVE Position */ +#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos) /*!< SCB AIRCR: VECTCLRACTIVE Mask */ + +#define SCB_AIRCR_VECTRESET_Pos 0U /*!< SCB AIRCR: VECTRESET Position */ +#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/) /*!< SCB AIRCR: VECTRESET Mask */ + +/* SCB System Control Register Definitions */ +#define SCB_SCR_SEVONPEND_Pos 4U /*!< SCB SCR: SEVONPEND Position */ +#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos) /*!< SCB SCR: SEVONPEND Mask */ + +#define SCB_SCR_SLEEPDEEP_Pos 2U /*!< SCB SCR: SLEEPDEEP Position */ +#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos) /*!< SCB SCR: SLEEPDEEP Mask */ + +#define SCB_SCR_SLEEPONEXIT_Pos 1U /*!< SCB SCR: SLEEPONEXIT Position */ +#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos) /*!< SCB SCR: SLEEPONEXIT Mask */ + +/* SCB Configuration Control Register Definitions */ +#define SCB_CCR_STKALIGN_Pos 9U /*!< SCB CCR: STKALIGN Position */ +#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos) /*!< SCB CCR: STKALIGN Mask */ + +#define SCB_CCR_BFHFNMIGN_Pos 8U /*!< SCB CCR: BFHFNMIGN Position */ +#define SCB_CCR_BFHFNMIGN_Msk (1UL << SCB_CCR_BFHFNMIGN_Pos) /*!< SCB CCR: BFHFNMIGN Mask */ + +#define SCB_CCR_DIV_0_TRP_Pos 4U /*!< SCB CCR: DIV_0_TRP Position */ +#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos) /*!< SCB CCR: DIV_0_TRP Mask */ + +#define SCB_CCR_UNALIGN_TRP_Pos 3U /*!< SCB CCR: UNALIGN_TRP Position */ +#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos) /*!< SCB CCR: UNALIGN_TRP Mask */ + +#define SCB_CCR_USERSETMPEND_Pos 1U /*!< SCB CCR: USERSETMPEND Position */ +#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos) /*!< SCB CCR: USERSETMPEND Mask */ + +#define SCB_CCR_NONBASETHRDENA_Pos 0U /*!< SCB CCR: NONBASETHRDENA Position */ +#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/) /*!< SCB CCR: NONBASETHRDENA Mask */ + +/* SCB System Handler Control and State Register Definitions */ +#define SCB_SHCSR_USGFAULTENA_Pos 18U /*!< SCB SHCSR: USGFAULTENA Position */ +#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos) /*!< SCB SHCSR: USGFAULTENA Mask */ + +#define SCB_SHCSR_BUSFAULTENA_Pos 17U /*!< SCB SHCSR: BUSFAULTENA Position */ +#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos) /*!< SCB SHCSR: BUSFAULTENA Mask */ + +#define SCB_SHCSR_MEMFAULTENA_Pos 16U /*!< SCB SHCSR: MEMFAULTENA Position */ +#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos) /*!< SCB SHCSR: MEMFAULTENA Mask */ + +#define SCB_SHCSR_SVCALLPENDED_Pos 15U /*!< SCB SHCSR: SVCALLPENDED Position */ +#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos) /*!< SCB SHCSR: SVCALLPENDED Mask */ + +#define SCB_SHCSR_BUSFAULTPENDED_Pos 14U /*!< SCB SHCSR: BUSFAULTPENDED Position */ +#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos) /*!< SCB SHCSR: BUSFAULTPENDED Mask */ + +#define SCB_SHCSR_MEMFAULTPENDED_Pos 13U /*!< SCB SHCSR: MEMFAULTPENDED Position */ +#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos) /*!< SCB SHCSR: MEMFAULTPENDED Mask */ + +#define SCB_SHCSR_USGFAULTPENDED_Pos 12U /*!< SCB SHCSR: USGFAULTPENDED Position */ +#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos) /*!< SCB SHCSR: USGFAULTPENDED Mask */ + +#define SCB_SHCSR_SYSTICKACT_Pos 11U /*!< SCB SHCSR: SYSTICKACT Position */ +#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos) /*!< SCB SHCSR: SYSTICKACT Mask */ + +#define SCB_SHCSR_PENDSVACT_Pos 10U /*!< SCB SHCSR: PENDSVACT Position */ +#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos) /*!< SCB SHCSR: PENDSVACT Mask */ + +#define SCB_SHCSR_MONITORACT_Pos 8U /*!< SCB SHCSR: MONITORACT Position */ +#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos) /*!< SCB SHCSR: MONITORACT Mask */ + +#define SCB_SHCSR_SVCALLACT_Pos 7U /*!< SCB SHCSR: SVCALLACT Position */ +#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos) /*!< SCB SHCSR: SVCALLACT Mask */ + +#define SCB_SHCSR_USGFAULTACT_Pos 3U /*!< SCB SHCSR: USGFAULTACT Position */ +#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos) /*!< SCB SHCSR: USGFAULTACT Mask */ + +#define SCB_SHCSR_BUSFAULTACT_Pos 1U /*!< SCB SHCSR: BUSFAULTACT Position */ +#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos) /*!< SCB SHCSR: BUSFAULTACT Mask */ + +#define SCB_SHCSR_MEMFAULTACT_Pos 0U /*!< SCB SHCSR: MEMFAULTACT Position */ +#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/) /*!< SCB SHCSR: MEMFAULTACT Mask */ + +/* SCB Configurable Fault Status Register Definitions */ +#define SCB_CFSR_USGFAULTSR_Pos 16U /*!< SCB CFSR: Usage Fault Status Register Position */ +#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos) /*!< SCB CFSR: Usage Fault Status Register Mask */ + +#define SCB_CFSR_BUSFAULTSR_Pos 8U /*!< SCB CFSR: Bus Fault Status Register Position */ +#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos) /*!< SCB CFSR: Bus Fault Status Register Mask */ + +#define SCB_CFSR_MEMFAULTSR_Pos 0U /*!< SCB CFSR: Memory Manage Fault Status Register Position */ +#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/) /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ + +/* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_MMARVALID_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 7U) /*!< SCB CFSR (MMFSR): MMARVALID Position */ +#define SCB_CFSR_MMARVALID_Msk (1UL << SCB_CFSR_MMARVALID_Pos) /*!< SCB CFSR (MMFSR): MMARVALID Mask */ + +#define SCB_CFSR_MSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 4U) /*!< SCB CFSR (MMFSR): MSTKERR Position */ +#define SCB_CFSR_MSTKERR_Msk (1UL << SCB_CFSR_MSTKERR_Pos) /*!< SCB CFSR (MMFSR): MSTKERR Mask */ + +#define SCB_CFSR_MUNSTKERR_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 3U) /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ +#define SCB_CFSR_MUNSTKERR_Msk (1UL << SCB_CFSR_MUNSTKERR_Pos) /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ + +#define SCB_CFSR_DACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 1U) /*!< SCB CFSR (MMFSR): DACCVIOL Position */ +#define SCB_CFSR_DACCVIOL_Msk (1UL << SCB_CFSR_DACCVIOL_Pos) /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ + +#define SCB_CFSR_IACCVIOL_Pos (SCB_SHCSR_MEMFAULTACT_Pos + 0U) /*!< SCB CFSR (MMFSR): IACCVIOL Position */ +#define SCB_CFSR_IACCVIOL_Msk (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/) /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ + +/* BusFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_BFARVALID_Pos (SCB_CFSR_BUSFAULTSR_Pos + 7U) /*!< SCB CFSR (BFSR): BFARVALID Position */ +#define SCB_CFSR_BFARVALID_Msk (1UL << SCB_CFSR_BFARVALID_Pos) /*!< SCB CFSR (BFSR): BFARVALID Mask */ + +#define SCB_CFSR_STKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 4U) /*!< SCB CFSR (BFSR): STKERR Position */ +#define SCB_CFSR_STKERR_Msk (1UL << SCB_CFSR_STKERR_Pos) /*!< SCB CFSR (BFSR): STKERR Mask */ + +#define SCB_CFSR_UNSTKERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 3U) /*!< SCB CFSR (BFSR): UNSTKERR Position */ +#define SCB_CFSR_UNSTKERR_Msk (1UL << SCB_CFSR_UNSTKERR_Pos) /*!< SCB CFSR (BFSR): UNSTKERR Mask */ + +#define SCB_CFSR_IMPRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 2U) /*!< SCB CFSR (BFSR): IMPRECISERR Position */ +#define SCB_CFSR_IMPRECISERR_Msk (1UL << SCB_CFSR_IMPRECISERR_Pos) /*!< SCB CFSR (BFSR): IMPRECISERR Mask */ + +#define SCB_CFSR_PRECISERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 1U) /*!< SCB CFSR (BFSR): PRECISERR Position */ +#define SCB_CFSR_PRECISERR_Msk (1UL << SCB_CFSR_PRECISERR_Pos) /*!< SCB CFSR (BFSR): PRECISERR Mask */ + +#define SCB_CFSR_IBUSERR_Pos (SCB_CFSR_BUSFAULTSR_Pos + 0U) /*!< SCB CFSR (BFSR): IBUSERR Position */ +#define SCB_CFSR_IBUSERR_Msk (1UL << SCB_CFSR_IBUSERR_Pos) /*!< SCB CFSR (BFSR): IBUSERR Mask */ + +/* UsageFault Status Register (part of SCB Configurable Fault Status Register) */ +#define SCB_CFSR_DIVBYZERO_Pos (SCB_CFSR_USGFAULTSR_Pos + 9U) /*!< SCB CFSR (UFSR): DIVBYZERO Position */ +#define SCB_CFSR_DIVBYZERO_Msk (1UL << SCB_CFSR_DIVBYZERO_Pos) /*!< SCB CFSR (UFSR): DIVBYZERO Mask */ + +#define SCB_CFSR_UNALIGNED_Pos (SCB_CFSR_USGFAULTSR_Pos + 8U) /*!< SCB CFSR (UFSR): UNALIGNED Position */ +#define SCB_CFSR_UNALIGNED_Msk (1UL << SCB_CFSR_UNALIGNED_Pos) /*!< SCB CFSR (UFSR): UNALIGNED Mask */ + +#define SCB_CFSR_NOCP_Pos (SCB_CFSR_USGFAULTSR_Pos + 3U) /*!< SCB CFSR (UFSR): NOCP Position */ +#define SCB_CFSR_NOCP_Msk (1UL << SCB_CFSR_NOCP_Pos) /*!< SCB CFSR (UFSR): NOCP Mask */ + +#define SCB_CFSR_INVPC_Pos (SCB_CFSR_USGFAULTSR_Pos + 2U) /*!< SCB CFSR (UFSR): INVPC Position */ +#define SCB_CFSR_INVPC_Msk (1UL << SCB_CFSR_INVPC_Pos) /*!< SCB CFSR (UFSR): INVPC Mask */ + +#define SCB_CFSR_INVSTATE_Pos (SCB_CFSR_USGFAULTSR_Pos + 1U) /*!< SCB CFSR (UFSR): INVSTATE Position */ +#define SCB_CFSR_INVSTATE_Msk (1UL << SCB_CFSR_INVSTATE_Pos) /*!< SCB CFSR (UFSR): INVSTATE Mask */ + +#define SCB_CFSR_UNDEFINSTR_Pos (SCB_CFSR_USGFAULTSR_Pos + 0U) /*!< SCB CFSR (UFSR): UNDEFINSTR Position */ +#define SCB_CFSR_UNDEFINSTR_Msk (1UL << SCB_CFSR_UNDEFINSTR_Pos) /*!< SCB CFSR (UFSR): UNDEFINSTR Mask */ + +/* SCB Hard Fault Status Register Definitions */ +#define SCB_HFSR_DEBUGEVT_Pos 31U /*!< SCB HFSR: DEBUGEVT Position */ +#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos) /*!< SCB HFSR: DEBUGEVT Mask */ + +#define SCB_HFSR_FORCED_Pos 30U /*!< SCB HFSR: FORCED Position */ +#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos) /*!< SCB HFSR: FORCED Mask */ + +#define SCB_HFSR_VECTTBL_Pos 1U /*!< SCB HFSR: VECTTBL Position */ +#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos) /*!< SCB HFSR: VECTTBL Mask */ + +/* SCB Debug Fault Status Register Definitions */ +#define SCB_DFSR_EXTERNAL_Pos 4U /*!< SCB DFSR: EXTERNAL Position */ +#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos) /*!< SCB DFSR: EXTERNAL Mask */ + +#define SCB_DFSR_VCATCH_Pos 3U /*!< SCB DFSR: VCATCH Position */ +#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos) /*!< SCB DFSR: VCATCH Mask */ + +#define SCB_DFSR_DWTTRAP_Pos 2U /*!< SCB DFSR: DWTTRAP Position */ +#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos) /*!< SCB DFSR: DWTTRAP Mask */ + +#define SCB_DFSR_BKPT_Pos 1U /*!< SCB DFSR: BKPT Position */ +#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos) /*!< SCB DFSR: BKPT Mask */ + +#define SCB_DFSR_HALTED_Pos 0U /*!< SCB DFSR: HALTED Position */ +#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/) /*!< SCB DFSR: HALTED Mask */ + +/*@} end of group CMSIS_SCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SCnSCB System Controls not in SCB (SCnSCB) + \brief Type definitions for the System Control and ID Register not in the SCB + @{ + */ + +/** + \brief Structure type to access the System Control and ID Register not in the SCB. + */ +typedef struct +{ + uint32_t RESERVED0[1U]; + __IM uint32_t ICTR; /*!< Offset: 0x004 (R/ ) Interrupt Controller Type Register */ + uint32_t RESERVED1[1U]; +} SCnSCB_Type; + +/* Interrupt Controller Type Register Definitions */ +#define SCnSCB_ICTR_INTLINESNUM_Pos 0U /*!< ICTR: INTLINESNUM Position */ +#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/) /*!< ICTR: INTLINESNUM Mask */ + +/*@} end of group CMSIS_SCnotSCB */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_SysTick System Tick Timer (SysTick) + \brief Type definitions for the System Timer Registers. + @{ + */ + +/** + \brief Structure type to access the System Timer (SysTick). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) SysTick Control and Status Register */ + __IOM uint32_t LOAD; /*!< Offset: 0x004 (R/W) SysTick Reload Value Register */ + __IOM uint32_t VAL; /*!< Offset: 0x008 (R/W) SysTick Current Value Register */ + __IM uint32_t CALIB; /*!< Offset: 0x00C (R/ ) SysTick Calibration Register */ +} SysTick_Type; + +/* SysTick Control / Status Register Definitions */ +#define SysTick_CTRL_COUNTFLAG_Pos 16U /*!< SysTick CTRL: COUNTFLAG Position */ +#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos) /*!< SysTick CTRL: COUNTFLAG Mask */ + +#define SysTick_CTRL_CLKSOURCE_Pos 2U /*!< SysTick CTRL: CLKSOURCE Position */ +#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos) /*!< SysTick CTRL: CLKSOURCE Mask */ + +#define SysTick_CTRL_TICKINT_Pos 1U /*!< SysTick CTRL: TICKINT Position */ +#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos) /*!< SysTick CTRL: TICKINT Mask */ + +#define SysTick_CTRL_ENABLE_Pos 0U /*!< SysTick CTRL: ENABLE Position */ +#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/) /*!< SysTick CTRL: ENABLE Mask */ + +/* SysTick Reload Register Definitions */ +#define SysTick_LOAD_RELOAD_Pos 0U /*!< SysTick LOAD: RELOAD Position */ +#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/) /*!< SysTick LOAD: RELOAD Mask */ + +/* SysTick Current Register Definitions */ +#define SysTick_VAL_CURRENT_Pos 0U /*!< SysTick VAL: CURRENT Position */ +#define SysTick_VAL_CURRENT_Msk (0xFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/) /*!< SysTick VAL: CURRENT Mask */ + +/* SysTick Calibration Register Definitions */ +#define SysTick_CALIB_NOREF_Pos 31U /*!< SysTick CALIB: NOREF Position */ +#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos) /*!< SysTick CALIB: NOREF Mask */ + +#define SysTick_CALIB_SKEW_Pos 30U /*!< SysTick CALIB: SKEW Position */ +#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos) /*!< SysTick CALIB: SKEW Mask */ + +#define SysTick_CALIB_TENMS_Pos 0U /*!< SysTick CALIB: TENMS Position */ +#define SysTick_CALIB_TENMS_Msk (0xFFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/) /*!< SysTick CALIB: TENMS Mask */ + +/*@} end of group CMSIS_SysTick */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_ITM Instrumentation Trace Macrocell (ITM) + \brief Type definitions for the Instrumentation Trace Macrocell (ITM) + @{ + */ + +/** + \brief Structure type to access the Instrumentation Trace Macrocell Register (ITM). + */ +typedef struct +{ + __OM union + { + __OM uint8_t u8; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 8-bit */ + __OM uint16_t u16; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 16-bit */ + __OM uint32_t u32; /*!< Offset: 0x000 ( /W) ITM Stimulus Port 32-bit */ + } PORT [32U]; /*!< Offset: 0x000 ( /W) ITM Stimulus Port Registers */ + uint32_t RESERVED0[864U]; + __IOM uint32_t TER; /*!< Offset: 0xE00 (R/W) ITM Trace Enable Register */ + uint32_t RESERVED1[15U]; + __IOM uint32_t TPR; /*!< Offset: 0xE40 (R/W) ITM Trace Privilege Register */ + uint32_t RESERVED2[15U]; + __IOM uint32_t TCR; /*!< Offset: 0xE80 (R/W) ITM Trace Control Register */ + uint32_t RESERVED3[29U]; + __OM uint32_t IWR; /*!< Offset: 0xEF8 ( /W) ITM Integration Write Register */ + __IM uint32_t IRR; /*!< Offset: 0xEFC (R/ ) ITM Integration Read Register */ + __IOM uint32_t IMCR; /*!< Offset: 0xF00 (R/W) ITM Integration Mode Control Register */ + uint32_t RESERVED4[43U]; + __OM uint32_t LAR; /*!< Offset: 0xFB0 ( /W) ITM Lock Access Register */ + __IM uint32_t LSR; /*!< Offset: 0xFB4 (R/ ) ITM Lock Status Register */ + uint32_t RESERVED5[6U]; + __IM uint32_t PID4; /*!< Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4 */ + __IM uint32_t PID5; /*!< Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5 */ + __IM uint32_t PID6; /*!< Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6 */ + __IM uint32_t PID7; /*!< Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7 */ + __IM uint32_t PID0; /*!< Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0 */ + __IM uint32_t PID1; /*!< Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1 */ + __IM uint32_t PID2; /*!< Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2 */ + __IM uint32_t PID3; /*!< Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3 */ + __IM uint32_t CID0; /*!< Offset: 0xFF0 (R/ ) ITM Component Identification Register #0 */ + __IM uint32_t CID1; /*!< Offset: 0xFF4 (R/ ) ITM Component Identification Register #1 */ + __IM uint32_t CID2; /*!< Offset: 0xFF8 (R/ ) ITM Component Identification Register #2 */ + __IM uint32_t CID3; /*!< Offset: 0xFFC (R/ ) ITM Component Identification Register #3 */ +} ITM_Type; + +/* ITM Trace Privilege Register Definitions */ +#define ITM_TPR_PRIVMASK_Pos 0U /*!< ITM TPR: PRIVMASK Position */ +#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/) /*!< ITM TPR: PRIVMASK Mask */ + +/* ITM Trace Control Register Definitions */ +#define ITM_TCR_BUSY_Pos 23U /*!< ITM TCR: BUSY Position */ +#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos) /*!< ITM TCR: BUSY Mask */ + +#define ITM_TCR_TraceBusID_Pos 16U /*!< ITM TCR: ATBID Position */ +#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos) /*!< ITM TCR: ATBID Mask */ + +#define ITM_TCR_GTSFREQ_Pos 10U /*!< ITM TCR: Global timestamp frequency Position */ +#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos) /*!< ITM TCR: Global timestamp frequency Mask */ + +#define ITM_TCR_TSPrescale_Pos 8U /*!< ITM TCR: TSPrescale Position */ +#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos) /*!< ITM TCR: TSPrescale Mask */ + +#define ITM_TCR_SWOENA_Pos 4U /*!< ITM TCR: SWOENA Position */ +#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos) /*!< ITM TCR: SWOENA Mask */ + +#define ITM_TCR_DWTENA_Pos 3U /*!< ITM TCR: DWTENA Position */ +#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos) /*!< ITM TCR: DWTENA Mask */ + +#define ITM_TCR_SYNCENA_Pos 2U /*!< ITM TCR: SYNCENA Position */ +#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos) /*!< ITM TCR: SYNCENA Mask */ + +#define ITM_TCR_TSENA_Pos 1U /*!< ITM TCR: TSENA Position */ +#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos) /*!< ITM TCR: TSENA Mask */ + +#define ITM_TCR_ITMENA_Pos 0U /*!< ITM TCR: ITM Enable bit Position */ +#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/) /*!< ITM TCR: ITM Enable bit Mask */ + +/* ITM Integration Write Register Definitions */ +#define ITM_IWR_ATVALIDM_Pos 0U /*!< ITM IWR: ATVALIDM Position */ +#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/) /*!< ITM IWR: ATVALIDM Mask */ + +/* ITM Integration Read Register Definitions */ +#define ITM_IRR_ATREADYM_Pos 0U /*!< ITM IRR: ATREADYM Position */ +#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/) /*!< ITM IRR: ATREADYM Mask */ + +/* ITM Integration Mode Control Register Definitions */ +#define ITM_IMCR_INTEGRATION_Pos 0U /*!< ITM IMCR: INTEGRATION Position */ +#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/) /*!< ITM IMCR: INTEGRATION Mask */ + +/* ITM Lock Status Register Definitions */ +#define ITM_LSR_ByteAcc_Pos 2U /*!< ITM LSR: ByteAcc Position */ +#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos) /*!< ITM LSR: ByteAcc Mask */ + +#define ITM_LSR_Access_Pos 1U /*!< ITM LSR: Access Position */ +#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos) /*!< ITM LSR: Access Mask */ + +#define ITM_LSR_Present_Pos 0U /*!< ITM LSR: Present Position */ +#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/) /*!< ITM LSR: Present Mask */ + +/*@}*/ /* end of group CMSIS_ITM */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_DWT Data Watchpoint and Trace (DWT) + \brief Type definitions for the Data Watchpoint and Trace (DWT) + @{ + */ + +/** + \brief Structure type to access the Data Watchpoint and Trace Register (DWT). + */ +typedef struct +{ + __IOM uint32_t CTRL; /*!< Offset: 0x000 (R/W) Control Register */ + __IOM uint32_t CYCCNT; /*!< Offset: 0x004 (R/W) Cycle Count Register */ + __IOM uint32_t CPICNT; /*!< Offset: 0x008 (R/W) CPI Count Register */ + __IOM uint32_t EXCCNT; /*!< Offset: 0x00C (R/W) Exception Overhead Count Register */ + __IOM uint32_t SLEEPCNT; /*!< Offset: 0x010 (R/W) Sleep Count Register */ + __IOM uint32_t LSUCNT; /*!< Offset: 0x014 (R/W) LSU Count Register */ + __IOM uint32_t FOLDCNT; /*!< Offset: 0x018 (R/W) Folded-instruction Count Register */ + __IM uint32_t PCSR; /*!< Offset: 0x01C (R/ ) Program Counter Sample Register */ + __IOM uint32_t COMP0; /*!< Offset: 0x020 (R/W) Comparator Register 0 */ + __IOM uint32_t MASK0; /*!< Offset: 0x024 (R/W) Mask Register 0 */ + __IOM uint32_t FUNCTION0; /*!< Offset: 0x028 (R/W) Function Register 0 */ + uint32_t RESERVED0[1U]; + __IOM uint32_t COMP1; /*!< Offset: 0x030 (R/W) Comparator Register 1 */ + __IOM uint32_t MASK1; /*!< Offset: 0x034 (R/W) Mask Register 1 */ + __IOM uint32_t FUNCTION1; /*!< Offset: 0x038 (R/W) Function Register 1 */ + uint32_t RESERVED1[1U]; + __IOM uint32_t COMP2; /*!< Offset: 0x040 (R/W) Comparator Register 2 */ + __IOM uint32_t MASK2; /*!< Offset: 0x044 (R/W) Mask Register 2 */ + __IOM uint32_t FUNCTION2; /*!< Offset: 0x048 (R/W) Function Register 2 */ + uint32_t RESERVED2[1U]; + __IOM uint32_t COMP3; /*!< Offset: 0x050 (R/W) Comparator Register 3 */ + __IOM uint32_t MASK3; /*!< Offset: 0x054 (R/W) Mask Register 3 */ + __IOM uint32_t FUNCTION3; /*!< Offset: 0x058 (R/W) Function Register 3 */ +} DWT_Type; + +/* DWT Control Register Definitions */ +#define DWT_CTRL_NUMCOMP_Pos 28U /*!< DWT CTRL: NUMCOMP Position */ +#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos) /*!< DWT CTRL: NUMCOMP Mask */ + +#define DWT_CTRL_NOTRCPKT_Pos 27U /*!< DWT CTRL: NOTRCPKT Position */ +#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos) /*!< DWT CTRL: NOTRCPKT Mask */ + +#define DWT_CTRL_NOEXTTRIG_Pos 26U /*!< DWT CTRL: NOEXTTRIG Position */ +#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos) /*!< DWT CTRL: NOEXTTRIG Mask */ + +#define DWT_CTRL_NOCYCCNT_Pos 25U /*!< DWT CTRL: NOCYCCNT Position */ +#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos) /*!< DWT CTRL: NOCYCCNT Mask */ + +#define DWT_CTRL_NOPRFCNT_Pos 24U /*!< DWT CTRL: NOPRFCNT Position */ +#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos) /*!< DWT CTRL: NOPRFCNT Mask */ + +#define DWT_CTRL_CYCEVTENA_Pos 22U /*!< DWT CTRL: CYCEVTENA Position */ +#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos) /*!< DWT CTRL: CYCEVTENA Mask */ + +#define DWT_CTRL_FOLDEVTENA_Pos 21U /*!< DWT CTRL: FOLDEVTENA Position */ +#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos) /*!< DWT CTRL: FOLDEVTENA Mask */ + +#define DWT_CTRL_LSUEVTENA_Pos 20U /*!< DWT CTRL: LSUEVTENA Position */ +#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos) /*!< DWT CTRL: LSUEVTENA Mask */ + +#define DWT_CTRL_SLEEPEVTENA_Pos 19U /*!< DWT CTRL: SLEEPEVTENA Position */ +#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos) /*!< DWT CTRL: SLEEPEVTENA Mask */ + +#define DWT_CTRL_EXCEVTENA_Pos 18U /*!< DWT CTRL: EXCEVTENA Position */ +#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos) /*!< DWT CTRL: EXCEVTENA Mask */ + +#define DWT_CTRL_CPIEVTENA_Pos 17U /*!< DWT CTRL: CPIEVTENA Position */ +#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos) /*!< DWT CTRL: CPIEVTENA Mask */ + +#define DWT_CTRL_EXCTRCENA_Pos 16U /*!< DWT CTRL: EXCTRCENA Position */ +#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos) /*!< DWT CTRL: EXCTRCENA Mask */ + +#define DWT_CTRL_PCSAMPLENA_Pos 12U /*!< DWT CTRL: PCSAMPLENA Position */ +#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos) /*!< DWT CTRL: PCSAMPLENA Mask */ + +#define DWT_CTRL_SYNCTAP_Pos 10U /*!< DWT CTRL: SYNCTAP Position */ +#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos) /*!< DWT CTRL: SYNCTAP Mask */ + +#define DWT_CTRL_CYCTAP_Pos 9U /*!< DWT CTRL: CYCTAP Position */ +#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos) /*!< DWT CTRL: CYCTAP Mask */ + +#define DWT_CTRL_POSTINIT_Pos 5U /*!< DWT CTRL: POSTINIT Position */ +#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos) /*!< DWT CTRL: POSTINIT Mask */ + +#define DWT_CTRL_POSTPRESET_Pos 1U /*!< DWT CTRL: POSTPRESET Position */ +#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos) /*!< DWT CTRL: POSTPRESET Mask */ + +#define DWT_CTRL_CYCCNTENA_Pos 0U /*!< DWT CTRL: CYCCNTENA Position */ +#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/) /*!< DWT CTRL: CYCCNTENA Mask */ + +/* DWT CPI Count Register Definitions */ +#define DWT_CPICNT_CPICNT_Pos 0U /*!< DWT CPICNT: CPICNT Position */ +#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/) /*!< DWT CPICNT: CPICNT Mask */ + +/* DWT Exception Overhead Count Register Definitions */ +#define DWT_EXCCNT_EXCCNT_Pos 0U /*!< DWT EXCCNT: EXCCNT Position */ +#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/) /*!< DWT EXCCNT: EXCCNT Mask */ + +/* DWT Sleep Count Register Definitions */ +#define DWT_SLEEPCNT_SLEEPCNT_Pos 0U /*!< DWT SLEEPCNT: SLEEPCNT Position */ +#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/) /*!< DWT SLEEPCNT: SLEEPCNT Mask */ + +/* DWT LSU Count Register Definitions */ +#define DWT_LSUCNT_LSUCNT_Pos 0U /*!< DWT LSUCNT: LSUCNT Position */ +#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/) /*!< DWT LSUCNT: LSUCNT Mask */ + +/* DWT Folded-instruction Count Register Definitions */ +#define DWT_FOLDCNT_FOLDCNT_Pos 0U /*!< DWT FOLDCNT: FOLDCNT Position */ +#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/) /*!< DWT FOLDCNT: FOLDCNT Mask */ + +/* DWT Comparator Mask Register Definitions */ +#define DWT_MASK_MASK_Pos 0U /*!< DWT MASK: MASK Position */ +#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/) /*!< DWT MASK: MASK Mask */ + +/* DWT Comparator Function Register Definitions */ +#define DWT_FUNCTION_MATCHED_Pos 24U /*!< DWT FUNCTION: MATCHED Position */ +#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos) /*!< DWT FUNCTION: MATCHED Mask */ + +#define DWT_FUNCTION_DATAVADDR1_Pos 16U /*!< DWT FUNCTION: DATAVADDR1 Position */ +#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos) /*!< DWT FUNCTION: DATAVADDR1 Mask */ + +#define DWT_FUNCTION_DATAVADDR0_Pos 12U /*!< DWT FUNCTION: DATAVADDR0 Position */ +#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos) /*!< DWT FUNCTION: DATAVADDR0 Mask */ + +#define DWT_FUNCTION_DATAVSIZE_Pos 10U /*!< DWT FUNCTION: DATAVSIZE Position */ +#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos) /*!< DWT FUNCTION: DATAVSIZE Mask */ + +#define DWT_FUNCTION_LNK1ENA_Pos 9U /*!< DWT FUNCTION: LNK1ENA Position */ +#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos) /*!< DWT FUNCTION: LNK1ENA Mask */ + +#define DWT_FUNCTION_DATAVMATCH_Pos 8U /*!< DWT FUNCTION: DATAVMATCH Position */ +#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos) /*!< DWT FUNCTION: DATAVMATCH Mask */ + +#define DWT_FUNCTION_CYCMATCH_Pos 7U /*!< DWT FUNCTION: CYCMATCH Position */ +#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos) /*!< DWT FUNCTION: CYCMATCH Mask */ + +#define DWT_FUNCTION_EMITRANGE_Pos 5U /*!< DWT FUNCTION: EMITRANGE Position */ +#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos) /*!< DWT FUNCTION: EMITRANGE Mask */ + +#define DWT_FUNCTION_FUNCTION_Pos 0U /*!< DWT FUNCTION: FUNCTION Position */ +#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/) /*!< DWT FUNCTION: FUNCTION Mask */ + +/*@}*/ /* end of group CMSIS_DWT */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_TPI Trace Port Interface (TPI) + \brief Type definitions for the Trace Port Interface (TPI) + @{ + */ + +/** + \brief Structure type to access the Trace Port Interface Register (TPI). + */ +typedef struct +{ + __IM uint32_t SSPSR; /*!< Offset: 0x000 (R/ ) Supported Parallel Port Size Register */ + __IOM uint32_t CSPSR; /*!< Offset: 0x004 (R/W) Current Parallel Port Size Register */ + uint32_t RESERVED0[2U]; + __IOM uint32_t ACPR; /*!< Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register */ + uint32_t RESERVED1[55U]; + __IOM uint32_t SPPR; /*!< Offset: 0x0F0 (R/W) Selected Pin Protocol Register */ + uint32_t RESERVED2[131U]; + __IM uint32_t FFSR; /*!< Offset: 0x300 (R/ ) Formatter and Flush Status Register */ + __IOM uint32_t FFCR; /*!< Offset: 0x304 (R/W) Formatter and Flush Control Register */ + __IM uint32_t FSCR; /*!< Offset: 0x308 (R/ ) Formatter Synchronization Counter Register */ + uint32_t RESERVED3[759U]; + __IM uint32_t TRIGGER; /*!< Offset: 0xEE8 (R/ ) TRIGGER Register */ + __IM uint32_t FIFO0; /*!< Offset: 0xEEC (R/ ) Integration ETM Data */ + __IM uint32_t ITATBCTR2; /*!< Offset: 0xEF0 (R/ ) ITATBCTR2 */ + uint32_t RESERVED4[1U]; + __IM uint32_t ITATBCTR0; /*!< Offset: 0xEF8 (R/ ) ITATBCTR0 */ + __IM uint32_t FIFO1; /*!< Offset: 0xEFC (R/ ) Integration ITM Data */ + __IOM uint32_t ITCTRL; /*!< Offset: 0xF00 (R/W) Integration Mode Control */ + uint32_t RESERVED5[39U]; + __IOM uint32_t CLAIMSET; /*!< Offset: 0xFA0 (R/W) Claim tag set */ + __IOM uint32_t CLAIMCLR; /*!< Offset: 0xFA4 (R/W) Claim tag clear */ + uint32_t RESERVED7[8U]; + __IM uint32_t DEVID; /*!< Offset: 0xFC8 (R/ ) TPIU_DEVID */ + __IM uint32_t DEVTYPE; /*!< Offset: 0xFCC (R/ ) TPIU_DEVTYPE */ +} TPI_Type; + +/* TPI Asynchronous Clock Prescaler Register Definitions */ +#define TPI_ACPR_PRESCALER_Pos 0U /*!< TPI ACPR: PRESCALER Position */ +#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/) /*!< TPI ACPR: PRESCALER Mask */ + +/* TPI Selected Pin Protocol Register Definitions */ +#define TPI_SPPR_TXMODE_Pos 0U /*!< TPI SPPR: TXMODE Position */ +#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/) /*!< TPI SPPR: TXMODE Mask */ + +/* TPI Formatter and Flush Status Register Definitions */ +#define TPI_FFSR_FtNonStop_Pos 3U /*!< TPI FFSR: FtNonStop Position */ +#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos) /*!< TPI FFSR: FtNonStop Mask */ + +#define TPI_FFSR_TCPresent_Pos 2U /*!< TPI FFSR: TCPresent Position */ +#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos) /*!< TPI FFSR: TCPresent Mask */ + +#define TPI_FFSR_FtStopped_Pos 1U /*!< TPI FFSR: FtStopped Position */ +#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos) /*!< TPI FFSR: FtStopped Mask */ + +#define TPI_FFSR_FlInProg_Pos 0U /*!< TPI FFSR: FlInProg Position */ +#define TPI_FFSR_FlInProg_Msk (0x1UL /*<< TPI_FFSR_FlInProg_Pos*/) /*!< TPI FFSR: FlInProg Mask */ + +/* TPI Formatter and Flush Control Register Definitions */ +#define TPI_FFCR_TrigIn_Pos 8U /*!< TPI FFCR: TrigIn Position */ +#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos) /*!< TPI FFCR: TrigIn Mask */ + +#define TPI_FFCR_EnFCont_Pos 1U /*!< TPI FFCR: EnFCont Position */ +#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos) /*!< TPI FFCR: EnFCont Mask */ + +/* TPI TRIGGER Register Definitions */ +#define TPI_TRIGGER_TRIGGER_Pos 0U /*!< TPI TRIGGER: TRIGGER Position */ +#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/) /*!< TPI TRIGGER: TRIGGER Mask */ + +/* TPI Integration ETM Data Register Definitions (FIFO0) */ +#define TPI_FIFO0_ITM_ATVALID_Pos 29U /*!< TPI FIFO0: ITM_ATVALID Position */ +#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos) /*!< TPI FIFO0: ITM_ATVALID Mask */ + +#define TPI_FIFO0_ITM_bytecount_Pos 27U /*!< TPI FIFO0: ITM_bytecount Position */ +#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos) /*!< TPI FIFO0: ITM_bytecount Mask */ + +#define TPI_FIFO0_ETM_ATVALID_Pos 26U /*!< TPI FIFO0: ETM_ATVALID Position */ +#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos) /*!< TPI FIFO0: ETM_ATVALID Mask */ + +#define TPI_FIFO0_ETM_bytecount_Pos 24U /*!< TPI FIFO0: ETM_bytecount Position */ +#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos) /*!< TPI FIFO0: ETM_bytecount Mask */ + +#define TPI_FIFO0_ETM2_Pos 16U /*!< TPI FIFO0: ETM2 Position */ +#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos) /*!< TPI FIFO0: ETM2 Mask */ + +#define TPI_FIFO0_ETM1_Pos 8U /*!< TPI FIFO0: ETM1 Position */ +#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos) /*!< TPI FIFO0: ETM1 Mask */ + +#define TPI_FIFO0_ETM0_Pos 0U /*!< TPI FIFO0: ETM0 Position */ +#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/) /*!< TPI FIFO0: ETM0 Mask */ + +/* TPI ITATBCTR2 Register Definitions */ +#define TPI_ITATBCTR2_ATREADY2_Pos 0U /*!< TPI ITATBCTR2: ATREADY2 Position */ +#define TPI_ITATBCTR2_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY2_Pos*/) /*!< TPI ITATBCTR2: ATREADY2 Mask */ + +#define TPI_ITATBCTR2_ATREADY1_Pos 0U /*!< TPI ITATBCTR2: ATREADY1 Position */ +#define TPI_ITATBCTR2_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY1_Pos*/) /*!< TPI ITATBCTR2: ATREADY1 Mask */ + +/* TPI Integration ITM Data Register Definitions (FIFO1) */ +#define TPI_FIFO1_ITM_ATVALID_Pos 29U /*!< TPI FIFO1: ITM_ATVALID Position */ +#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos) /*!< TPI FIFO1: ITM_ATVALID Mask */ + +#define TPI_FIFO1_ITM_bytecount_Pos 27U /*!< TPI FIFO1: ITM_bytecount Position */ +#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos) /*!< TPI FIFO1: ITM_bytecount Mask */ + +#define TPI_FIFO1_ETM_ATVALID_Pos 26U /*!< TPI FIFO1: ETM_ATVALID Position */ +#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos) /*!< TPI FIFO1: ETM_ATVALID Mask */ + +#define TPI_FIFO1_ETM_bytecount_Pos 24U /*!< TPI FIFO1: ETM_bytecount Position */ +#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos) /*!< TPI FIFO1: ETM_bytecount Mask */ + +#define TPI_FIFO1_ITM2_Pos 16U /*!< TPI FIFO1: ITM2 Position */ +#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos) /*!< TPI FIFO1: ITM2 Mask */ + +#define TPI_FIFO1_ITM1_Pos 8U /*!< TPI FIFO1: ITM1 Position */ +#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos) /*!< TPI FIFO1: ITM1 Mask */ + +#define TPI_FIFO1_ITM0_Pos 0U /*!< TPI FIFO1: ITM0 Position */ +#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/) /*!< TPI FIFO1: ITM0 Mask */ + +/* TPI ITATBCTR0 Register Definitions */ +#define TPI_ITATBCTR0_ATREADY2_Pos 0U /*!< TPI ITATBCTR0: ATREADY2 Position */ +#define TPI_ITATBCTR0_ATREADY2_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY2_Pos*/) /*!< TPI ITATBCTR0: ATREADY2 Mask */ + +#define TPI_ITATBCTR0_ATREADY1_Pos 0U /*!< TPI ITATBCTR0: ATREADY1 Position */ +#define TPI_ITATBCTR0_ATREADY1_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY1_Pos*/) /*!< TPI ITATBCTR0: ATREADY1 Mask */ + +/* TPI Integration Mode Control Register Definitions */ +#define TPI_ITCTRL_Mode_Pos 0U /*!< TPI ITCTRL: Mode Position */ +#define TPI_ITCTRL_Mode_Msk (0x3UL /*<< TPI_ITCTRL_Mode_Pos*/) /*!< TPI ITCTRL: Mode Mask */ + +/* TPI DEVID Register Definitions */ +#define TPI_DEVID_NRZVALID_Pos 11U /*!< TPI DEVID: NRZVALID Position */ +#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos) /*!< TPI DEVID: NRZVALID Mask */ + +#define TPI_DEVID_MANCVALID_Pos 10U /*!< TPI DEVID: MANCVALID Position */ +#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos) /*!< TPI DEVID: MANCVALID Mask */ + +#define TPI_DEVID_PTINVALID_Pos 9U /*!< TPI DEVID: PTINVALID Position */ +#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos) /*!< TPI DEVID: PTINVALID Mask */ + +#define TPI_DEVID_MinBufSz_Pos 6U /*!< TPI DEVID: MinBufSz Position */ +#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos) /*!< TPI DEVID: MinBufSz Mask */ + +#define TPI_DEVID_AsynClkIn_Pos 5U /*!< TPI DEVID: AsynClkIn Position */ +#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos) /*!< TPI DEVID: AsynClkIn Mask */ + +#define TPI_DEVID_NrTraceInput_Pos 0U /*!< TPI DEVID: NrTraceInput Position */ +#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/) /*!< TPI DEVID: NrTraceInput Mask */ + +/* TPI DEVTYPE Register Definitions */ +#define TPI_DEVTYPE_SubType_Pos 4U /*!< TPI DEVTYPE: SubType Position */ +#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/) /*!< TPI DEVTYPE: SubType Mask */ + +#define TPI_DEVTYPE_MajorType_Pos 0U /*!< TPI DEVTYPE: MajorType Position */ +#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos) /*!< TPI DEVTYPE: MajorType Mask */ + +/*@}*/ /* end of group CMSIS_TPI */ + + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_MPU Memory Protection Unit (MPU) + \brief Type definitions for the Memory Protection Unit (MPU) + @{ + */ + +/** + \brief Structure type to access the Memory Protection Unit (MPU). + */ +typedef struct +{ + __IM uint32_t TYPE; /*!< Offset: 0x000 (R/ ) MPU Type Register */ + __IOM uint32_t CTRL; /*!< Offset: 0x004 (R/W) MPU Control Register */ + __IOM uint32_t RNR; /*!< Offset: 0x008 (R/W) MPU Region RNRber Register */ + __IOM uint32_t RBAR; /*!< Offset: 0x00C (R/W) MPU Region Base Address Register */ + __IOM uint32_t RASR; /*!< Offset: 0x010 (R/W) MPU Region Attribute and Size Register */ + __IOM uint32_t RBAR_A1; /*!< Offset: 0x014 (R/W) MPU Alias 1 Region Base Address Register */ + __IOM uint32_t RASR_A1; /*!< Offset: 0x018 (R/W) MPU Alias 1 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A2; /*!< Offset: 0x01C (R/W) MPU Alias 2 Region Base Address Register */ + __IOM uint32_t RASR_A2; /*!< Offset: 0x020 (R/W) MPU Alias 2 Region Attribute and Size Register */ + __IOM uint32_t RBAR_A3; /*!< Offset: 0x024 (R/W) MPU Alias 3 Region Base Address Register */ + __IOM uint32_t RASR_A3; /*!< Offset: 0x028 (R/W) MPU Alias 3 Region Attribute and Size Register */ +} MPU_Type; + +/* MPU Type Register Definitions */ +#define MPU_TYPE_IREGION_Pos 16U /*!< MPU TYPE: IREGION Position */ +#define MPU_TYPE_IREGION_Msk (0xFFUL << MPU_TYPE_IREGION_Pos) /*!< MPU TYPE: IREGION Mask */ + +#define MPU_TYPE_DREGION_Pos 8U /*!< MPU TYPE: DREGION Position */ +#define MPU_TYPE_DREGION_Msk (0xFFUL << MPU_TYPE_DREGION_Pos) /*!< MPU TYPE: DREGION Mask */ + +#define MPU_TYPE_SEPARATE_Pos 0U /*!< MPU TYPE: SEPARATE Position */ +#define MPU_TYPE_SEPARATE_Msk (1UL /*<< MPU_TYPE_SEPARATE_Pos*/) /*!< MPU TYPE: SEPARATE Mask */ + +/* MPU Control Register Definitions */ +#define MPU_CTRL_PRIVDEFENA_Pos 2U /*!< MPU CTRL: PRIVDEFENA Position */ +#define MPU_CTRL_PRIVDEFENA_Msk (1UL << MPU_CTRL_PRIVDEFENA_Pos) /*!< MPU CTRL: PRIVDEFENA Mask */ + +#define MPU_CTRL_HFNMIENA_Pos 1U /*!< MPU CTRL: HFNMIENA Position */ +#define MPU_CTRL_HFNMIENA_Msk (1UL << MPU_CTRL_HFNMIENA_Pos) /*!< MPU CTRL: HFNMIENA Mask */ + +#define MPU_CTRL_ENABLE_Pos 0U /*!< MPU CTRL: ENABLE Position */ +#define MPU_CTRL_ENABLE_Msk (1UL /*<< MPU_CTRL_ENABLE_Pos*/) /*!< MPU CTRL: ENABLE Mask */ + +/* MPU Region Number Register Definitions */ +#define MPU_RNR_REGION_Pos 0U /*!< MPU RNR: REGION Position */ +#define MPU_RNR_REGION_Msk (0xFFUL /*<< MPU_RNR_REGION_Pos*/) /*!< MPU RNR: REGION Mask */ + +/* MPU Region Base Address Register Definitions */ +#define MPU_RBAR_ADDR_Pos 5U /*!< MPU RBAR: ADDR Position */ +#define MPU_RBAR_ADDR_Msk (0x7FFFFFFUL << MPU_RBAR_ADDR_Pos) /*!< MPU RBAR: ADDR Mask */ + +#define MPU_RBAR_VALID_Pos 4U /*!< MPU RBAR: VALID Position */ +#define MPU_RBAR_VALID_Msk (1UL << MPU_RBAR_VALID_Pos) /*!< MPU RBAR: VALID Mask */ + +#define MPU_RBAR_REGION_Pos 0U /*!< MPU RBAR: REGION Position */ +#define MPU_RBAR_REGION_Msk (0xFUL /*<< MPU_RBAR_REGION_Pos*/) /*!< MPU RBAR: REGION Mask */ + +/* MPU Region Attribute and Size Register Definitions */ +#define MPU_RASR_ATTRS_Pos 16U /*!< MPU RASR: MPU Region Attribute field Position */ +#define MPU_RASR_ATTRS_Msk (0xFFFFUL << MPU_RASR_ATTRS_Pos) /*!< MPU RASR: MPU Region Attribute field Mask */ + +#define MPU_RASR_XN_Pos 28U /*!< MPU RASR: ATTRS.XN Position */ +#define MPU_RASR_XN_Msk (1UL << MPU_RASR_XN_Pos) /*!< MPU RASR: ATTRS.XN Mask */ + +#define MPU_RASR_AP_Pos 24U /*!< MPU RASR: ATTRS.AP Position */ +#define MPU_RASR_AP_Msk (0x7UL << MPU_RASR_AP_Pos) /*!< MPU RASR: ATTRS.AP Mask */ + +#define MPU_RASR_TEX_Pos 19U /*!< MPU RASR: ATTRS.TEX Position */ +#define MPU_RASR_TEX_Msk (0x7UL << MPU_RASR_TEX_Pos) /*!< MPU RASR: ATTRS.TEX Mask */ + +#define MPU_RASR_S_Pos 18U /*!< MPU RASR: ATTRS.S Position */ +#define MPU_RASR_S_Msk (1UL << MPU_RASR_S_Pos) /*!< MPU RASR: ATTRS.S Mask */ + +#define MPU_RASR_C_Pos 17U /*!< MPU RASR: ATTRS.C Position */ +#define MPU_RASR_C_Msk (1UL << MPU_RASR_C_Pos) /*!< MPU RASR: ATTRS.C Mask */ + +#define MPU_RASR_B_Pos 16U /*!< MPU RASR: ATTRS.B Position */ +#define MPU_RASR_B_Msk (1UL << MPU_RASR_B_Pos) /*!< MPU RASR: ATTRS.B Mask */ + +#define MPU_RASR_SRD_Pos 8U /*!< MPU RASR: Sub-Region Disable Position */ +#define MPU_RASR_SRD_Msk (0xFFUL << MPU_RASR_SRD_Pos) /*!< MPU RASR: Sub-Region Disable Mask */ + +#define MPU_RASR_SIZE_Pos 1U /*!< MPU RASR: Region Size Field Position */ +#define MPU_RASR_SIZE_Msk (0x1FUL << MPU_RASR_SIZE_Pos) /*!< MPU RASR: Region Size Field Mask */ + +#define MPU_RASR_ENABLE_Pos 0U /*!< MPU RASR: Region enable bit Position */ +#define MPU_RASR_ENABLE_Msk (1UL /*<< MPU_RASR_ENABLE_Pos*/) /*!< MPU RASR: Region enable bit Disable Mask */ + +/*@} end of group CMSIS_MPU */ +#endif + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_CoreDebug Core Debug Registers (CoreDebug) + \brief Type definitions for the Core Debug Registers + @{ + */ + +/** + \brief Structure type to access the Core Debug Register (CoreDebug). + */ +typedef struct +{ + __IOM uint32_t DHCSR; /*!< Offset: 0x000 (R/W) Debug Halting Control and Status Register */ + __OM uint32_t DCRSR; /*!< Offset: 0x004 ( /W) Debug Core Register Selector Register */ + __IOM uint32_t DCRDR; /*!< Offset: 0x008 (R/W) Debug Core Register Data Register */ + __IOM uint32_t DEMCR; /*!< Offset: 0x00C (R/W) Debug Exception and Monitor Control Register */ +} CoreDebug_Type; + +/* Debug Halting Control and Status Register Definitions */ +#define CoreDebug_DHCSR_DBGKEY_Pos 16U /*!< CoreDebug DHCSR: DBGKEY Position */ +#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos) /*!< CoreDebug DHCSR: DBGKEY Mask */ + +#define CoreDebug_DHCSR_S_RESET_ST_Pos 25U /*!< CoreDebug DHCSR: S_RESET_ST Position */ +#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos) /*!< CoreDebug DHCSR: S_RESET_ST Mask */ + +#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24U /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ +#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos) /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ + +#define CoreDebug_DHCSR_S_LOCKUP_Pos 19U /*!< CoreDebug DHCSR: S_LOCKUP Position */ +#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos) /*!< CoreDebug DHCSR: S_LOCKUP Mask */ + +#define CoreDebug_DHCSR_S_SLEEP_Pos 18U /*!< CoreDebug DHCSR: S_SLEEP Position */ +#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos) /*!< CoreDebug DHCSR: S_SLEEP Mask */ + +#define CoreDebug_DHCSR_S_HALT_Pos 17U /*!< CoreDebug DHCSR: S_HALT Position */ +#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos) /*!< CoreDebug DHCSR: S_HALT Mask */ + +#define CoreDebug_DHCSR_S_REGRDY_Pos 16U /*!< CoreDebug DHCSR: S_REGRDY Position */ +#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos) /*!< CoreDebug DHCSR: S_REGRDY Mask */ + +#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5U /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ +#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos) /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ + +#define CoreDebug_DHCSR_C_MASKINTS_Pos 3U /*!< CoreDebug DHCSR: C_MASKINTS Position */ +#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos) /*!< CoreDebug DHCSR: C_MASKINTS Mask */ + +#define CoreDebug_DHCSR_C_STEP_Pos 2U /*!< CoreDebug DHCSR: C_STEP Position */ +#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos) /*!< CoreDebug DHCSR: C_STEP Mask */ + +#define CoreDebug_DHCSR_C_HALT_Pos 1U /*!< CoreDebug DHCSR: C_HALT Position */ +#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos) /*!< CoreDebug DHCSR: C_HALT Mask */ + +#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0U /*!< CoreDebug DHCSR: C_DEBUGEN Position */ +#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/) /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ + +/* Debug Core Register Selector Register Definitions */ +#define CoreDebug_DCRSR_REGWnR_Pos 16U /*!< CoreDebug DCRSR: REGWnR Position */ +#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos) /*!< CoreDebug DCRSR: REGWnR Mask */ + +#define CoreDebug_DCRSR_REGSEL_Pos 0U /*!< CoreDebug DCRSR: REGSEL Position */ +#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/) /*!< CoreDebug DCRSR: REGSEL Mask */ + +/* Debug Exception and Monitor Control Register Definitions */ +#define CoreDebug_DEMCR_TRCENA_Pos 24U /*!< CoreDebug DEMCR: TRCENA Position */ +#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos) /*!< CoreDebug DEMCR: TRCENA Mask */ + +#define CoreDebug_DEMCR_MON_REQ_Pos 19U /*!< CoreDebug DEMCR: MON_REQ Position */ +#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos) /*!< CoreDebug DEMCR: MON_REQ Mask */ + +#define CoreDebug_DEMCR_MON_STEP_Pos 18U /*!< CoreDebug DEMCR: MON_STEP Position */ +#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos) /*!< CoreDebug DEMCR: MON_STEP Mask */ + +#define CoreDebug_DEMCR_MON_PEND_Pos 17U /*!< CoreDebug DEMCR: MON_PEND Position */ +#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos) /*!< CoreDebug DEMCR: MON_PEND Mask */ + +#define CoreDebug_DEMCR_MON_EN_Pos 16U /*!< CoreDebug DEMCR: MON_EN Position */ +#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos) /*!< CoreDebug DEMCR: MON_EN Mask */ + +#define CoreDebug_DEMCR_VC_HARDERR_Pos 10U /*!< CoreDebug DEMCR: VC_HARDERR Position */ +#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos) /*!< CoreDebug DEMCR: VC_HARDERR Mask */ + +#define CoreDebug_DEMCR_VC_INTERR_Pos 9U /*!< CoreDebug DEMCR: VC_INTERR Position */ +#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos) /*!< CoreDebug DEMCR: VC_INTERR Mask */ + +#define CoreDebug_DEMCR_VC_BUSERR_Pos 8U /*!< CoreDebug DEMCR: VC_BUSERR Position */ +#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos) /*!< CoreDebug DEMCR: VC_BUSERR Mask */ + +#define CoreDebug_DEMCR_VC_STATERR_Pos 7U /*!< CoreDebug DEMCR: VC_STATERR Position */ +#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos) /*!< CoreDebug DEMCR: VC_STATERR Mask */ + +#define CoreDebug_DEMCR_VC_CHKERR_Pos 6U /*!< CoreDebug DEMCR: VC_CHKERR Position */ +#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos) /*!< CoreDebug DEMCR: VC_CHKERR Mask */ + +#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5U /*!< CoreDebug DEMCR: VC_NOCPERR Position */ +#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos) /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ + +#define CoreDebug_DEMCR_VC_MMERR_Pos 4U /*!< CoreDebug DEMCR: VC_MMERR Position */ +#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos) /*!< CoreDebug DEMCR: VC_MMERR Mask */ + +#define CoreDebug_DEMCR_VC_CORERESET_Pos 0U /*!< CoreDebug DEMCR: VC_CORERESET Position */ +#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/) /*!< CoreDebug DEMCR: VC_CORERESET Mask */ + +/*@} end of group CMSIS_CoreDebug */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_bitfield Core register bit field macros + \brief Macros for use with bit field definitions (xxx_Pos, xxx_Msk). + @{ + */ + +/** + \brief Mask and shift a bit field value for use in a register bit range. + \param[in] field Name of the register bit field. + \param[in] value Value of the bit field. This parameter is interpreted as an uint32_t type. + \return Masked and shifted value. +*/ +#define _VAL2FLD(field, value) (((uint32_t)(value) << field ## _Pos) & field ## _Msk) + +/** + \brief Mask and shift a register value to extract a bit filed value. + \param[in] field Name of the register bit field. + \param[in] value Value of register. This parameter is interpreted as an uint32_t type. + \return Masked and shifted bit field value. +*/ +#define _FLD2VAL(field, value) (((uint32_t)(value) & field ## _Msk) >> field ## _Pos) + +/*@} end of group CMSIS_core_bitfield */ + + +/** + \ingroup CMSIS_core_register + \defgroup CMSIS_core_base Core Definitions + \brief Definitions for base addresses, unions, and structures. + @{ + */ + +/* Memory mapping of Core Hardware */ +#define SCS_BASE (0xE000E000UL) /*!< System Control Space Base Address */ +#define ITM_BASE (0xE0000000UL) /*!< ITM Base Address */ +#define DWT_BASE (0xE0001000UL) /*!< DWT Base Address */ +#define TPI_BASE (0xE0040000UL) /*!< TPI Base Address */ +#define CoreDebug_BASE (0xE000EDF0UL) /*!< Core Debug Base Address */ +#define SysTick_BASE (SCS_BASE + 0x0010UL) /*!< SysTick Base Address */ +#define NVIC_BASE (SCS_BASE + 0x0100UL) /*!< NVIC Base Address */ +#define SCB_BASE (SCS_BASE + 0x0D00UL) /*!< System Control Block Base Address */ + +#define SCnSCB ((SCnSCB_Type *) SCS_BASE ) /*!< System control Register not in SCB */ +#define SCB ((SCB_Type *) SCB_BASE ) /*!< SCB configuration struct */ +#define SysTick ((SysTick_Type *) SysTick_BASE ) /*!< SysTick configuration struct */ +#define NVIC ((NVIC_Type *) NVIC_BASE ) /*!< NVIC configuration struct */ +#define ITM ((ITM_Type *) ITM_BASE ) /*!< ITM configuration struct */ +#define DWT ((DWT_Type *) DWT_BASE ) /*!< DWT configuration struct */ +#define TPI ((TPI_Type *) TPI_BASE ) /*!< TPI configuration struct */ +#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE) /*!< Core Debug configuration struct */ + +#if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) + #define MPU_BASE (SCS_BASE + 0x0D90UL) /*!< Memory Protection Unit */ + #define MPU ((MPU_Type *) MPU_BASE ) /*!< Memory Protection Unit */ +#endif + +/*@} */ + + + +/******************************************************************************* + * Hardware Abstraction Layer + Core Function Interface contains: + - Core NVIC Functions + - Core SysTick Functions + - Core Debug Functions + - Core Register Access Functions + ******************************************************************************/ +/** + \defgroup CMSIS_Core_FunctionInterface Functions and Instructions Reference +*/ + + + +/* ########################## NVIC functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_NVICFunctions NVIC Functions + \brief Functions that manage interrupts and exceptions via the NVIC. + @{ + */ + +#ifdef CMSIS_NVIC_VIRTUAL + #ifndef CMSIS_NVIC_VIRTUAL_HEADER_FILE + #define CMSIS_NVIC_VIRTUAL_HEADER_FILE "cmsis_nvic_virtual.h" + #endif + #include CMSIS_NVIC_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetPriorityGrouping __NVIC_SetPriorityGrouping + #define NVIC_GetPriorityGrouping __NVIC_GetPriorityGrouping + #define NVIC_EnableIRQ __NVIC_EnableIRQ + #define NVIC_GetEnableIRQ __NVIC_GetEnableIRQ + #define NVIC_DisableIRQ __NVIC_DisableIRQ + #define NVIC_GetPendingIRQ __NVIC_GetPendingIRQ + #define NVIC_SetPendingIRQ __NVIC_SetPendingIRQ + #define NVIC_ClearPendingIRQ __NVIC_ClearPendingIRQ + #define NVIC_GetActive __NVIC_GetActive + #define NVIC_SetPriority __NVIC_SetPriority + #define NVIC_GetPriority __NVIC_GetPriority + #define NVIC_SystemReset __NVIC_SystemReset +#endif /* CMSIS_NVIC_VIRTUAL */ + +#ifdef CMSIS_VECTAB_VIRTUAL + #ifndef CMSIS_VECTAB_VIRTUAL_HEADER_FILE + #define CMSIS_VECTAB_VIRTUAL_HEADER_FILE "cmsis_vectab_virtual.h" + #endif + #include CMSIS_VECTAB_VIRTUAL_HEADER_FILE +#else + #define NVIC_SetVector __NVIC_SetVector + #define NVIC_GetVector __NVIC_GetVector +#endif /* (CMSIS_VECTAB_VIRTUAL) */ + +#define NVIC_USER_IRQ_OFFSET 16 + + +/* The following EXC_RETURN values are saved the LR on exception entry */ +#define EXC_RETURN_HANDLER (0xFFFFFFF1UL) /* return to Handler mode, uses MSP after return */ +#define EXC_RETURN_THREAD_MSP (0xFFFFFFF9UL) /* return to Thread mode, uses MSP after return */ +#define EXC_RETURN_THREAD_PSP (0xFFFFFFFDUL) /* return to Thread mode, uses PSP after return */ + + + +/** + \brief Set Priority Grouping + \details Sets the priority grouping field using the required unlock sequence. + The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. + Only values from 0..7 are used. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Priority grouping field. + */ +__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup) +{ + uint32_t reg_value; + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + + reg_value = SCB->AIRCR; /* read old register configuration */ + reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change */ + reg_value = (reg_value | + ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (PriorityGroupTmp << 8U) ); /* Insert write key and priorty group */ + SCB->AIRCR = reg_value; +} + + +/** + \brief Get Priority Grouping + \details Reads the priority grouping field from the NVIC Interrupt Controller. + \return Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field). + */ +__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void) +{ + return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos)); +} + + +/** + \brief Enable Interrupt + \details Enables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Interrupt Enable status + \details Returns a device specific interrupt enable status from the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt is not enabled. + \return 1 Interrupt is enabled. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetEnableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Disable Interrupt + \details Disables a device specific interrupt in the NVIC interrupt controller. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_DisableIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + __DSB(); + __ISB(); + } +} + + +/** + \brief Get Pending Interrupt + \details Reads the NVIC pending register and returns the pending bit for the specified device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not pending. + \return 1 Interrupt status is pending. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Pending Interrupt + \details Sets the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ISPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Clear Pending Interrupt + \details Clears the pending bit of a device specific interrupt in the NVIC pending register. + \param [in] IRQn Device specific interrupt number. + \note IRQn must not be negative. + */ +__STATIC_INLINE void __NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->ICPR[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL)); + } +} + + +/** + \brief Get Active Interrupt + \details Reads the active register in the NVIC and returns the active bit for the device specific interrupt. + \param [in] IRQn Device specific interrupt number. + \return 0 Interrupt status is not active. + \return 1 Interrupt status is active. + \note IRQn must not be negative. + */ +__STATIC_INLINE uint32_t __NVIC_GetActive(IRQn_Type IRQn) +{ + if ((int32_t)(IRQn) >= 0) + { + return((uint32_t)(((NVIC->IABR[(((uint32_t)IRQn) >> 5UL)] & (1UL << (((uint32_t)IRQn) & 0x1FUL))) != 0UL) ? 1UL : 0UL)); + } + else + { + return(0U); + } +} + + +/** + \brief Set Interrupt Priority + \details Sets the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \param [in] priority Priority to set. + \note The priority cannot be set for every processor exception. + */ +__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority) +{ + if ((int32_t)(IRQn) >= 0) + { + NVIC->IP[((uint32_t)IRQn)] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } + else + { + SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL); + } +} + + +/** + \brief Get Interrupt Priority + \details Reads the priority of a device specific interrupt or a processor exception. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Interrupt Priority. + Value is aligned automatically to the implemented priority bits of the microcontroller. + */ +__STATIC_INLINE uint32_t __NVIC_GetPriority(IRQn_Type IRQn) +{ + + if ((int32_t)(IRQn) >= 0) + { + return(((uint32_t)NVIC->IP[((uint32_t)IRQn)] >> (8U - __NVIC_PRIO_BITS))); + } + else + { + return(((uint32_t)SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] >> (8U - __NVIC_PRIO_BITS))); + } +} + + +/** + \brief Encode Priority + \details Encodes the priority for an interrupt with the given priority group, + preemptive priority value, and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set. + \param [in] PriorityGroup Used priority group. + \param [in] PreemptPriority Preemptive priority value (starting from 0). + \param [in] SubPriority Subpriority value (starting from 0). + \return Encoded priority. Value can be used in the function \ref NVIC_SetPriority(). + */ +__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + return ( + ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) | + ((SubPriority & (uint32_t)((1UL << (SubPriorityBits )) - 1UL))) + ); +} + + +/** + \brief Decode Priority + \details Decodes an interrupt priority value with a given priority group to + preemptive priority value and subpriority value. + In case of a conflict between priority grouping and available + priority bits (__NVIC_PRIO_BITS) the smallest possible priority group is set. + \param [in] Priority Priority value, which can be retrieved with the function \ref NVIC_GetPriority(). + \param [in] PriorityGroup Used priority group. + \param [out] pPreemptPriority Preemptive priority value (starting from 0). + \param [out] pSubPriority Subpriority value (starting from 0). + */ +__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t* const pPreemptPriority, uint32_t* const pSubPriority) +{ + uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL); /* only values 0..7 are used */ + uint32_t PreemptPriorityBits; + uint32_t SubPriorityBits; + + PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp); + SubPriorityBits = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS)); + + *pPreemptPriority = (Priority >> SubPriorityBits) & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL); + *pSubPriority = (Priority ) & (uint32_t)((1UL << (SubPriorityBits )) - 1UL); +} + + +/** + \brief Set Interrupt Vector + \details Sets an interrupt vector in SRAM based interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + VTOR must been relocated to SRAM before. + \param [in] IRQn Interrupt number + \param [in] vector Address of interrupt handler function + */ +__STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; +} + + +/** + \brief Get Interrupt Vector + \details Reads an interrupt vector from interrupt vector table. + The interrupt number can be positive to specify a device specific interrupt, + or negative to specify a processor exception. + \param [in] IRQn Interrupt number. + \return Address of interrupt handler function + */ +__STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) +{ + uint32_t *vectors = (uint32_t *)SCB->VTOR; + return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; +} + + +/** + \brief System Reset + \details Initiates a system reset request to reset the MCU. + */ +__NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) +{ + __DSB(); /* Ensure all outstanding memory accesses included + buffered write are completed before reset */ + SCB->AIRCR = (uint32_t)((0x5FAUL << SCB_AIRCR_VECTKEY_Pos) | + (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | + SCB_AIRCR_SYSRESETREQ_Msk ); /* Keep priority group unchanged */ + __DSB(); /* Ensure completion of memory access */ + + for(;;) /* wait until reset */ + { + __NOP(); + } +} + +/*@} end of CMSIS_Core_NVICFunctions */ + + +/* ########################## FPU functions #################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_FpuFunctions FPU Functions + \brief Function that provides FPU type. + @{ + */ + +/** + \brief get FPU type + \details returns the FPU type + \returns + - \b 0: No FPU + - \b 1: Single precision FPU + - \b 2: Double + Single precision FPU + */ +__STATIC_INLINE uint32_t SCB_GetFPUType(void) +{ + return 0U; /* No FPU */ +} + + +/*@} end of CMSIS_Core_FpuFunctions */ + + + +/* ################################## SysTick function ############################################ */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_Core_SysTickFunctions SysTick Functions + \brief Functions that configure the System. + @{ + */ + +#if defined (__Vendor_SysTickConfig) && (__Vendor_SysTickConfig == 0U) + +/** + \brief System Tick Configuration + \details Initializes the System Timer and its interrupt, and starts the System Tick Timer. + Counter is in free running mode to generate periodic interrupts. + \param [in] ticks Number of ticks between two interrupts. + \return 0 Function succeeded. + \return 1 Function failed. + \note When the variable __Vendor_SysTickConfig is set to 1, then the + function SysTick_Config is not included. In this case, the file device.h + must contain a vendor-specific implementation of this function. + */ +__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks) +{ + if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk) + { + return (1UL); /* Reload value impossible */ + } + + SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */ + NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_TICKINT_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */ + return (0UL); /* Function successful */ +} + +#endif + +/*@} end of CMSIS_Core_SysTickFunctions */ + + + +/* ##################################### Debug In/Output function ########################################### */ +/** + \ingroup CMSIS_Core_FunctionInterface + \defgroup CMSIS_core_DebugFunctions ITM Functions + \brief Functions that access the ITM debug interface. + @{ + */ + +extern volatile int32_t ITM_RxBuffer; /*!< External variable to receive characters. */ +#define ITM_RXBUFFER_EMPTY ((int32_t)0x5AA55AA5U) /*!< Value identifying \ref ITM_RxBuffer is ready for next character. */ + + +/** + \brief ITM Send Character + \details Transmits a character via the ITM channel 0, and + \li Just returns when no debugger is connected that has booked the output. + \li Is blocking when a debugger is connected, but the previous character sent has not been transmitted. + \param [in] ch Character to transmit. + \returns Character to transmit. + */ +__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch) +{ + if (((ITM->TCR & ITM_TCR_ITMENA_Msk) != 0UL) && /* ITM enabled */ + ((ITM->TER & 1UL ) != 0UL) ) /* ITM Port #0 enabled */ + { + while (ITM->PORT[0U].u32 == 0UL) + { + __NOP(); + } + ITM->PORT[0U].u8 = (uint8_t)ch; + } + return (ch); +} + + +/** + \brief ITM Receive Character + \details Inputs a character via the external variable \ref ITM_RxBuffer. + \return Received character. + \return -1 No character pending. + */ +__STATIC_INLINE int32_t ITM_ReceiveChar (void) +{ + int32_t ch = -1; /* no character available */ + + if (ITM_RxBuffer != ITM_RXBUFFER_EMPTY) + { + ch = ITM_RxBuffer; + ITM_RxBuffer = ITM_RXBUFFER_EMPTY; /* ready for next character */ + } + + return (ch); +} + + +/** + \brief ITM Check Character + \details Checks whether a character is pending for reading in the variable \ref ITM_RxBuffer. + \return 0 No character available. + \return 1 Character available. + */ +__STATIC_INLINE int32_t ITM_CheckChar (void) +{ + + if (ITM_RxBuffer == ITM_RXBUFFER_EMPTY) + { + return (0); /* no character available */ + } + else + { + return (1); /* character available */ + } +} + +/*@} end of CMSIS_core_DebugFunctions */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* __CORE_SC300_H_DEPENDANT */ + +#endif /* __CMSIS_GENERIC */ diff --git a/Chapter04/bare/platform/CMSIS/Include/mpu_armv7.h b/Chapter04/bare/platform/CMSIS/Include/mpu_armv7.h new file mode 100644 index 0000000..7d4b600 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/mpu_armv7.h @@ -0,0 +1,270 @@ +/****************************************************************************** + * @file mpu_armv7.h + * @brief CMSIS MPU API for Armv7-M MPU + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef ARM_MPU_ARMV7_H +#define ARM_MPU_ARMV7_H + +#define ARM_MPU_REGION_SIZE_32B ((uint8_t)0x04U) ///!< MPU Region Size 32 Bytes +#define ARM_MPU_REGION_SIZE_64B ((uint8_t)0x05U) ///!< MPU Region Size 64 Bytes +#define ARM_MPU_REGION_SIZE_128B ((uint8_t)0x06U) ///!< MPU Region Size 128 Bytes +#define ARM_MPU_REGION_SIZE_256B ((uint8_t)0x07U) ///!< MPU Region Size 256 Bytes +#define ARM_MPU_REGION_SIZE_512B ((uint8_t)0x08U) ///!< MPU Region Size 512 Bytes +#define ARM_MPU_REGION_SIZE_1KB ((uint8_t)0x09U) ///!< MPU Region Size 1 KByte +#define ARM_MPU_REGION_SIZE_2KB ((uint8_t)0x0AU) ///!< MPU Region Size 2 KBytes +#define ARM_MPU_REGION_SIZE_4KB ((uint8_t)0x0BU) ///!< MPU Region Size 4 KBytes +#define ARM_MPU_REGION_SIZE_8KB ((uint8_t)0x0CU) ///!< MPU Region Size 8 KBytes +#define ARM_MPU_REGION_SIZE_16KB ((uint8_t)0x0DU) ///!< MPU Region Size 16 KBytes +#define ARM_MPU_REGION_SIZE_32KB ((uint8_t)0x0EU) ///!< MPU Region Size 32 KBytes +#define ARM_MPU_REGION_SIZE_64KB ((uint8_t)0x0FU) ///!< MPU Region Size 64 KBytes +#define ARM_MPU_REGION_SIZE_128KB ((uint8_t)0x10U) ///!< MPU Region Size 128 KBytes +#define ARM_MPU_REGION_SIZE_256KB ((uint8_t)0x11U) ///!< MPU Region Size 256 KBytes +#define ARM_MPU_REGION_SIZE_512KB ((uint8_t)0x12U) ///!< MPU Region Size 512 KBytes +#define ARM_MPU_REGION_SIZE_1MB ((uint8_t)0x13U) ///!< MPU Region Size 1 MByte +#define ARM_MPU_REGION_SIZE_2MB ((uint8_t)0x14U) ///!< MPU Region Size 2 MBytes +#define ARM_MPU_REGION_SIZE_4MB ((uint8_t)0x15U) ///!< MPU Region Size 4 MBytes +#define ARM_MPU_REGION_SIZE_8MB ((uint8_t)0x16U) ///!< MPU Region Size 8 MBytes +#define ARM_MPU_REGION_SIZE_16MB ((uint8_t)0x17U) ///!< MPU Region Size 16 MBytes +#define ARM_MPU_REGION_SIZE_32MB ((uint8_t)0x18U) ///!< MPU Region Size 32 MBytes +#define ARM_MPU_REGION_SIZE_64MB ((uint8_t)0x19U) ///!< MPU Region Size 64 MBytes +#define ARM_MPU_REGION_SIZE_128MB ((uint8_t)0x1AU) ///!< MPU Region Size 128 MBytes +#define ARM_MPU_REGION_SIZE_256MB ((uint8_t)0x1BU) ///!< MPU Region Size 256 MBytes +#define ARM_MPU_REGION_SIZE_512MB ((uint8_t)0x1CU) ///!< MPU Region Size 512 MBytes +#define ARM_MPU_REGION_SIZE_1GB ((uint8_t)0x1DU) ///!< MPU Region Size 1 GByte +#define ARM_MPU_REGION_SIZE_2GB ((uint8_t)0x1EU) ///!< MPU Region Size 2 GBytes +#define ARM_MPU_REGION_SIZE_4GB ((uint8_t)0x1FU) ///!< MPU Region Size 4 GBytes + +#define ARM_MPU_AP_NONE 0U ///!< MPU Access Permission no access +#define ARM_MPU_AP_PRIV 1U ///!< MPU Access Permission privileged access only +#define ARM_MPU_AP_URO 2U ///!< MPU Access Permission unprivileged access read-only +#define ARM_MPU_AP_FULL 3U ///!< MPU Access Permission full access +#define ARM_MPU_AP_PRO 5U ///!< MPU Access Permission privileged access read-only +#define ARM_MPU_AP_RO 6U ///!< MPU Access Permission read-only access + +/** MPU Region Base Address Register Value +* +* \param Region The region to be configured, number 0 to 15. +* \param BaseAddress The base address for the region. +*/ +#define ARM_MPU_RBAR(Region, BaseAddress) \ + (((BaseAddress) & MPU_RBAR_ADDR_Msk) | \ + ((Region) & MPU_RBAR_REGION_Msk) | \ + (MPU_RBAR_VALID_Msk)) + +/** +* MPU Memory Access Attributes +* +* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral. +* \param IsShareable Region is shareable between multiple bus masters. +* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache. +* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy. +*/ +#define ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable) \ + ((((TypeExtField ) << MPU_RASR_TEX_Pos) & MPU_RASR_TEX_Msk) | \ + (((IsShareable ) << MPU_RASR_S_Pos) & MPU_RASR_S_Msk) | \ + (((IsCacheable ) << MPU_RASR_C_Pos) & MPU_RASR_C_Msk) | \ + (((IsBufferable ) << MPU_RASR_B_Pos) & MPU_RASR_B_Msk)) + +/** +* MPU Region Attribute and Size Register Value +* +* \param DisableExec Instruction access disable bit, 1= disable instruction fetches. +* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode. +* \param AccessAttributes Memory access attribution, see \ref ARM_MPU_ACCESS_. +* \param SubRegionDisable Sub-region disable field. +* \param Size Region size of the region to be configured, for example 4K, 8K. +*/ +#define ARM_MPU_RASR_EX(DisableExec, AccessPermission, AccessAttributes, SubRegionDisable, Size) \ + ((((DisableExec ) << MPU_RASR_XN_Pos) & MPU_RASR_XN_Msk) | \ + (((AccessPermission) << MPU_RASR_AP_Pos) & MPU_RASR_AP_Msk) | \ + (((AccessAttributes) ) & (MPU_RASR_TEX_Msk | MPU_RASR_S_Msk | MPU_RASR_C_Msk | MPU_RASR_B_Msk))) + +/** +* MPU Region Attribute and Size Register Value +* +* \param DisableExec Instruction access disable bit, 1= disable instruction fetches. +* \param AccessPermission Data access permissions, allows you to configure read/write access for User and Privileged mode. +* \param TypeExtField Type extension field, allows you to configure memory access type, for example strongly ordered, peripheral. +* \param IsShareable Region is shareable between multiple bus masters. +* \param IsCacheable Region is cacheable, i.e. its value may be kept in cache. +* \param IsBufferable Region is bufferable, i.e. using write-back caching. Cacheable but non-bufferable regions use write-through policy. +* \param SubRegionDisable Sub-region disable field. +* \param Size Region size of the region to be configured, for example 4K, 8K. +*/ +#define ARM_MPU_RASR(DisableExec, AccessPermission, TypeExtField, IsShareable, IsCacheable, IsBufferable, SubRegionDisable, Size) \ + ARM_MPU_RASR_EX(DisableExec, AccessPermission, ARM_MPU_ACCESS_(TypeExtField, IsShareable, IsCacheable, IsBufferable), SubRegionDisable, Size) + +/** +* MPU Memory Access Attribute for strongly ordered memory. +* - TEX: 000b +* - Shareable +* - Non-cacheable +* - Non-bufferable +*/ +#define ARM_MPU_ACCESS_ORDERED ARM_MPU_ACCESS_(0U, 1U, 0U, 0U) + +/** +* MPU Memory Access Attribute for device memory. +* - TEX: 000b (if non-shareable) or 010b (if shareable) +* - Shareable or non-shareable +* - Non-cacheable +* - Bufferable (if shareable) or non-bufferable (if non-shareable) +* +* \param IsShareable Configures the device memory as shareable or non-shareable. +*/ +#define ARM_MPU_ACCESS_DEVICE(IsShareable) ((IsShareable) ? ARM_MPU_ACCESS_(0U, 1U, 0U, 1U) : ARM_MPU_ACCESS_(2U, 0U, 0U, 0U)) + +/** +* MPU Memory Access Attribute for normal memory. +* - TEX: 1BBb (reflecting outer cacheability rules) +* - Shareable or non-shareable +* - Cacheable or non-cacheable (reflecting inner cacheability rules) +* - Bufferable or non-bufferable (reflecting inner cacheability rules) +* +* \param OuterCp Configures the outer cache policy. +* \param InnerCp Configures the inner cache policy. +* \param IsShareable Configures the memory as shareable or non-shareable. +*/ +#define ARM_MPU_ACCESS_NORMAL(OuterCp, InnerCp, IsShareable) ARM_MPU_ACCESS_((4U | (OuterCp)), IsShareable, ((InnerCp) & 2U), ((InnerCp) & 1U)) + +/** +* MPU Memory Access Attribute non-cacheable policy. +*/ +#define ARM_MPU_CACHEP_NOCACHE 0U + +/** +* MPU Memory Access Attribute write-back, write and read allocate policy. +*/ +#define ARM_MPU_CACHEP_WB_WRA 1U + +/** +* MPU Memory Access Attribute write-through, no write allocate policy. +*/ +#define ARM_MPU_CACHEP_WT_NWA 2U + +/** +* MPU Memory Access Attribute write-back, no write allocate policy. +*/ +#define ARM_MPU_CACHEP_WB_NWA 3U + + +/** +* Struct for a single MPU Region +*/ +typedef struct { + uint32_t RBAR; //!< The region base address register value (RBAR) + uint32_t RASR; //!< The region attribute and size register value (RASR) \ref MPU_RASR +} ARM_MPU_Region_t; + +/** Enable the MPU. +* \param MPU_Control Default access permissions for unconfigured regions. +*/ +__STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control) +{ + __DSB(); + __ISB(); + MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; +#endif +} + +/** Disable the MPU. +*/ +__STATIC_INLINE void ARM_MPU_Disable(void) +{ + __DSB(); + __ISB(); +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; +#endif + MPU->CTRL &= ~MPU_CTRL_ENABLE_Msk; +} + +/** Clear and disable the given MPU region. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr) +{ + MPU->RNR = rnr; + MPU->RASR = 0U; +} + +/** Configure an MPU region. +* \param rbar Value for RBAR register. +* \param rsar Value for RSAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rbar, uint32_t rasr) +{ + MPU->RBAR = rbar; + MPU->RASR = rasr; +} + +/** Configure the given MPU region. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rsar Value for RSAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegionEx(uint32_t rnr, uint32_t rbar, uint32_t rasr) +{ + MPU->RNR = rnr; + MPU->RBAR = rbar; + MPU->RASR = rasr; +} + +/** Memcopy with strictly ordered memory access, e.g. for register targets. +* \param dst Destination data is copied to. +* \param src Source data is copied from. +* \param len Amount of data words to be copied. +*/ +__STATIC_INLINE void orderedCpy(volatile uint32_t* dst, const uint32_t* __RESTRICT src, uint32_t len) +{ + uint32_t i; + for (i = 0U; i < len; ++i) + { + dst[i] = src[i]; + } +} + +/** Load the given number of MPU regions from a table. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_Load(ARM_MPU_Region_t const* table, uint32_t cnt) +{ + const uint32_t rowWordSize = sizeof(ARM_MPU_Region_t)/4U; + while (cnt > MPU_TYPE_RALIASES) { + orderedCpy(&(MPU->RBAR), &(table->RBAR), MPU_TYPE_RALIASES*rowWordSize); + table += MPU_TYPE_RALIASES; + cnt -= MPU_TYPE_RALIASES; + } + orderedCpy(&(MPU->RBAR), &(table->RBAR), cnt*rowWordSize); +} + +#endif diff --git a/Chapter04/bare/platform/CMSIS/Include/mpu_armv8.h b/Chapter04/bare/platform/CMSIS/Include/mpu_armv8.h new file mode 100644 index 0000000..99ee9f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/mpu_armv8.h @@ -0,0 +1,333 @@ +/****************************************************************************** + * @file mpu_armv8.h + * @brief CMSIS MPU API for Armv8-M MPU + * @version V5.0.4 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef ARM_MPU_ARMV8_H +#define ARM_MPU_ARMV8_H + +/** \brief Attribute for device memory (outer only) */ +#define ARM_MPU_ATTR_DEVICE ( 0U ) + +/** \brief Attribute for non-cacheable, normal memory */ +#define ARM_MPU_ATTR_NON_CACHEABLE ( 4U ) + +/** \brief Attribute for normal memory (outer and inner) +* \param NT Non-Transient: Set to 1 for non-transient data. +* \param WB Write-Back: Set to 1 to use write-back update policy. +* \param RA Read Allocation: Set to 1 to use cache allocation on read miss. +* \param WA Write Allocation: Set to 1 to use cache allocation on write miss. +*/ +#define ARM_MPU_ATTR_MEMORY_(NT, WB, RA, WA) \ + (((NT & 1U) << 3U) | ((WB & 1U) << 2U) | ((RA & 1U) << 1U) | (WA & 1U)) + +/** \brief Device memory type non Gathering, non Re-ordering, non Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_nGnRnE (0U) + +/** \brief Device memory type non Gathering, non Re-ordering, Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_nGnRE (1U) + +/** \brief Device memory type non Gathering, Re-ordering, Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_nGRE (2U) + +/** \brief Device memory type Gathering, Re-ordering, Early Write Acknowledgement */ +#define ARM_MPU_ATTR_DEVICE_GRE (3U) + +/** \brief Memory Attribute +* \param O Outer memory attributes +* \param I O == ARM_MPU_ATTR_DEVICE: Device memory attributes, else: Inner memory attributes +*/ +#define ARM_MPU_ATTR(O, I) (((O & 0xFU) << 4U) | (((O & 0xFU) != 0U) ? (I & 0xFU) : ((I & 0x3U) << 2U))) + +/** \brief Normal memory non-shareable */ +#define ARM_MPU_SH_NON (0U) + +/** \brief Normal memory outer shareable */ +#define ARM_MPU_SH_OUTER (2U) + +/** \brief Normal memory inner shareable */ +#define ARM_MPU_SH_INNER (3U) + +/** \brief Memory access permissions +* \param RO Read-Only: Set to 1 for read-only memory. +* \param NP Non-Privileged: Set to 1 for non-privileged memory. +*/ +#define ARM_MPU_AP_(RO, NP) (((RO & 1U) << 1U) | (NP & 1U)) + +/** \brief Region Base Address Register value +* \param BASE The base address bits [31:5] of a memory region. The value is zero extended. Effective address gets 32 byte aligned. +* \param SH Defines the Shareability domain for this memory region. +* \param RO Read-Only: Set to 1 for a read-only memory region. +* \param NP Non-Privileged: Set to 1 for a non-privileged memory region. +* \oaram XN eXecute Never: Set to 1 for a non-executable memory region. +*/ +#define ARM_MPU_RBAR(BASE, SH, RO, NP, XN) \ + ((BASE & MPU_RBAR_BASE_Msk) | \ + ((SH << MPU_RBAR_SH_Pos) & MPU_RBAR_SH_Msk) | \ + ((ARM_MPU_AP_(RO, NP) << MPU_RBAR_AP_Pos) & MPU_RBAR_AP_Msk) | \ + ((XN << MPU_RBAR_XN_Pos) & MPU_RBAR_XN_Msk)) + +/** \brief Region Limit Address Register value +* \param LIMIT The limit address bits [31:5] for this memory region. The value is one extended. +* \param IDX The attribute index to be associated with this memory region. +*/ +#define ARM_MPU_RLAR(LIMIT, IDX) \ + ((LIMIT & MPU_RLAR_LIMIT_Msk) | \ + ((IDX << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \ + (MPU_RLAR_EN_Msk)) + +/** +* Struct for a single MPU Region +*/ +typedef struct { + uint32_t RBAR; /*!< Region Base Address Register value */ + uint32_t RLAR; /*!< Region Limit Address Register value */ +} ARM_MPU_Region_t; + +/** Enable the MPU. +* \param MPU_Control Default access permissions for unconfigured regions. +*/ +__STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control) +{ + __DSB(); + __ISB(); + MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; +#endif +} + +/** Disable the MPU. +*/ +__STATIC_INLINE void ARM_MPU_Disable(void) +{ + __DSB(); + __ISB(); +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; +#endif + MPU->CTRL &= ~MPU_CTRL_ENABLE_Msk; +} + +#ifdef MPU_NS +/** Enable the Non-secure MPU. +* \param MPU_Control Default access permissions for unconfigured regions. +*/ +__STATIC_INLINE void ARM_MPU_Enable_NS(uint32_t MPU_Control) +{ + __DSB(); + __ISB(); + MPU_NS->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB_NS->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; +#endif +} + +/** Disable the Non-secure MPU. +*/ +__STATIC_INLINE void ARM_MPU_Disable_NS(void) +{ + __DSB(); + __ISB(); +#ifdef SCB_SHCSR_MEMFAULTENA_Msk + SCB_NS->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; +#endif + MPU_NS->CTRL &= ~MPU_CTRL_ENABLE_Msk; +} +#endif + +/** Set the memory attribute encoding to the given MPU. +* \param mpu Pointer to the MPU to be configured. +* \param idx The attribute index to be set [0-7] +* \param attr The attribute value to be set. +*/ +__STATIC_INLINE void ARM_MPU_SetMemAttrEx(MPU_Type* mpu, uint8_t idx, uint8_t attr) +{ + const uint8_t reg = idx / 4U; + const uint32_t pos = ((idx % 4U) * 8U); + const uint32_t mask = 0xFFU << pos; + + if (reg >= (sizeof(mpu->MAIR) / sizeof(mpu->MAIR[0]))) { + return; // invalid index + } + + mpu->MAIR[reg] = ((mpu->MAIR[reg] & ~mask) | ((attr << pos) & mask)); +} + +/** Set the memory attribute encoding. +* \param idx The attribute index to be set [0-7] +* \param attr The attribute value to be set. +*/ +__STATIC_INLINE void ARM_MPU_SetMemAttr(uint8_t idx, uint8_t attr) +{ + ARM_MPU_SetMemAttrEx(MPU, idx, attr); +} + +#ifdef MPU_NS +/** Set the memory attribute encoding to the Non-secure MPU. +* \param idx The attribute index to be set [0-7] +* \param attr The attribute value to be set. +*/ +__STATIC_INLINE void ARM_MPU_SetMemAttr_NS(uint8_t idx, uint8_t attr) +{ + ARM_MPU_SetMemAttrEx(MPU_NS, idx, attr); +} +#endif + +/** Clear and disable the given MPU region of the given MPU. +* \param mpu Pointer to MPU to be used. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegionEx(MPU_Type* mpu, uint32_t rnr) +{ + mpu->RNR = rnr; + mpu->RLAR = 0U; +} + +/** Clear and disable the given MPU region. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr) +{ + ARM_MPU_ClrRegionEx(MPU, rnr); +} + +#ifdef MPU_NS +/** Clear and disable the given Non-secure MPU region. +* \param rnr Region number to be cleared. +*/ +__STATIC_INLINE void ARM_MPU_ClrRegion_NS(uint32_t rnr) +{ + ARM_MPU_ClrRegionEx(MPU_NS, rnr); +} +#endif + +/** Configure the given MPU region of the given MPU. +* \param mpu Pointer to MPU to be used. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rlar Value for RLAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegionEx(MPU_Type* mpu, uint32_t rnr, uint32_t rbar, uint32_t rlar) +{ + mpu->RNR = rnr; + mpu->RBAR = rbar; + mpu->RLAR = rlar; +} + +/** Configure the given MPU region. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rlar Value for RLAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rnr, uint32_t rbar, uint32_t rlar) +{ + ARM_MPU_SetRegionEx(MPU, rnr, rbar, rlar); +} + +#ifdef MPU_NS +/** Configure the given Non-secure MPU region. +* \param rnr Region number to be configured. +* \param rbar Value for RBAR register. +* \param rlar Value for RLAR register. +*/ +__STATIC_INLINE void ARM_MPU_SetRegion_NS(uint32_t rnr, uint32_t rbar, uint32_t rlar) +{ + ARM_MPU_SetRegionEx(MPU_NS, rnr, rbar, rlar); +} +#endif + +/** Memcopy with strictly ordered memory access, e.g. for register targets. +* \param dst Destination data is copied to. +* \param src Source data is copied from. +* \param len Amount of data words to be copied. +*/ +__STATIC_INLINE void orderedCpy(volatile uint32_t* dst, const uint32_t* __RESTRICT src, uint32_t len) +{ + uint32_t i; + for (i = 0U; i < len; ++i) + { + dst[i] = src[i]; + } +} + +/** Load the given number of MPU regions from a table to the given MPU. +* \param mpu Pointer to the MPU registers to be used. +* \param rnr First region number to be configured. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_LoadEx(MPU_Type* mpu, uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt) +{ + const uint32_t rowWordSize = sizeof(ARM_MPU_Region_t)/4U; + if (cnt == 1U) { + mpu->RNR = rnr; + orderedCpy(&(mpu->RBAR), &(table->RBAR), rowWordSize); + } else { + uint32_t rnrBase = rnr & ~(MPU_TYPE_RALIASES-1U); + uint32_t rnrOffset = rnr % MPU_TYPE_RALIASES; + + mpu->RNR = rnrBase; + while ((rnrOffset + cnt) > MPU_TYPE_RALIASES) { + uint32_t c = MPU_TYPE_RALIASES - rnrOffset; + orderedCpy(&(mpu->RBAR)+(rnrOffset*2U), &(table->RBAR), c*rowWordSize); + table += c; + cnt -= c; + rnrOffset = 0U; + rnrBase += MPU_TYPE_RALIASES; + mpu->RNR = rnrBase; + } + + orderedCpy(&(mpu->RBAR)+(rnrOffset*2U), &(table->RBAR), cnt*rowWordSize); + } +} + +/** Load the given number of MPU regions from a table. +* \param rnr First region number to be configured. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_Load(uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt) +{ + ARM_MPU_LoadEx(MPU, rnr, table, cnt); +} + +#ifdef MPU_NS +/** Load the given number of MPU regions from a table to the Non-secure MPU. +* \param rnr First region number to be configured. +* \param table Pointer to the MPU configuration table. +* \param cnt Amount of regions to be configured. +*/ +__STATIC_INLINE void ARM_MPU_Load_NS(uint32_t rnr, ARM_MPU_Region_t const* table, uint32_t cnt) +{ + ARM_MPU_LoadEx(MPU_NS, rnr, table, cnt); +} +#endif + +#endif + diff --git a/Chapter04/bare/platform/CMSIS/Include/tz_context.h b/Chapter04/bare/platform/CMSIS/Include/tz_context.h new file mode 100644 index 0000000..d4c1474 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/Include/tz_context.h @@ -0,0 +1,70 @@ +/****************************************************************************** + * @file tz_context.h + * @brief Context Management for Armv8-M TrustZone + * @version V1.0.1 + * @date 10. January 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#if defined ( __ICCARM__ ) + #pragma system_include /* treat file as system include file for MISRA check */ +#elif defined (__clang__) + #pragma clang system_header /* treat file as system include file */ +#endif + +#ifndef TZ_CONTEXT_H +#define TZ_CONTEXT_H + +#include + +#ifndef TZ_MODULEID_T +#define TZ_MODULEID_T +/// \details Data type that identifies secure software modules called by a process. +typedef uint32_t TZ_ModuleId_t; +#endif + +/// \details TZ Memory ID identifies an allocated memory slot. +typedef uint32_t TZ_MemoryId_t; + +/// Initialize secure context memory system +/// \return execution status (1: success, 0: error) +uint32_t TZ_InitContextSystem_S (void); + +/// Allocate context memory for calling secure software modules in TrustZone +/// \param[in] module identifies software modules called from non-secure mode +/// \return value != 0 id TrustZone memory slot identifier +/// \return value 0 no memory available or internal error +TZ_MemoryId_t TZ_AllocModuleContext_S (TZ_ModuleId_t module); + +/// Free context memory that was previously allocated with \ref TZ_AllocModuleContext_S +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +uint32_t TZ_FreeModuleContext_S (TZ_MemoryId_t id); + +/// Load secure context (called on RTOS thread context switch) +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +uint32_t TZ_LoadContext_S (TZ_MemoryId_t id); + +/// Store secure context (called on RTOS thread context switch) +/// \param[in] id TrustZone memory slot identifier +/// \return execution status (1: success, 0: error) +uint32_t TZ_StoreContext_S (TZ_MemoryId_t id); + +#endif // TZ_CONTEXT_H diff --git a/Chapter04/bare/platform/CMSIS/LICENSE.txt b/Chapter04/bare/platform/CMSIS/LICENSE.txt new file mode 100644 index 0000000..c0ee812 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/LICENSE.txt @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "{}" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright {yyyy} {name of copyright owner} + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/Chapter04/bare/platform/CMSIS/Lib/ARM/arm_cortexM0b_math.lib b/Chapter04/bare/platform/CMSIS/Lib/ARM/arm_cortexM0b_math.lib new file mode 100644 index 0000000000000000000000000000000000000000..beec2520ecb0dcdcde432dbf89415a0e2ae3b605 GIT binary patch literal 13085890 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�T$)M-A8=L=y>11tj-@!96{_ecfK6J>4C{ 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%0A2b}u#WWT?>sOP$e$RC_E3)>yV>jr2DZfq?~iuv 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�RU}`DPXNdbPDQFE%-IJ#DJudOt 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

e7c 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

8rw@LSY={_Od zUr6^=;X064D4e5Ix*_RKNcUaRy-B)Xmaf#-f%b&LJ5d(6i#*KT9ny_S_d@AjD_z)) z)1iLjF6_YF2ZXEJ5AwE=J-&u4LaxdmpT`)N;4fkvZpL4tX*&ppJ?hN(BNzk|e3_=z zNc={#KkA`+f4J<|QIbblh;1^LoNeM8|EY?H1`=LPSP@T1aI;a(E(LK(k>Z4$mj zy4Oor=8J{T3wV*V|DvrDZkO(WbZ?dJmxP;#dWiJOTO(bxEgT+^?xoUwLb!{i9Tpc# zxJ$aIe<|GJZ%Frlg}Y?CbftZlBqfaeMf6MlCfucqrMpqOLFppj65Ud1pQS&Q@Lz?y z4D}cJFMGFie<0mo33qwFbPq~b+Lc-f3YUMmbkUx0_&MoHy;gJxc*UEf`&sEeB;1wK z4l4r^Mtw(oR^B9C$!ArmfLD!4_etTdmg%%w(yx~BS|jbX=Hr5{K-O;sMG`(f$+LAcab z65rFL9Zq|Tgx@3Gdxd*CDhQ%GeT#Hkq}wgsbEPZu$>}nEPDee)!#yfpna-!n@_qUX z0`JX}?k4HhNcT+X_DEOC@%Bkr*5lq=C49Sdr9Hj(OZZRHeMP#j33uHx=~hd(LAo-1 z)=9bRW+eWt(!D~u|1RBor2Bw$WqjBDSi=7!++wG6QQ*lg#f8$9^;xm3UyEh_EtdJW zSmvK%DYy6<8SaD9m2!(8k?<4J{e^JX%lcxyl)HX~#QUVXO}dTJJzKixN%x?14@vi8 z>B@Yv{x%8AdTsq(68@%ieu{Z``tC|#LfHY^nIhIP_?gLGwi*sw#wd!+kD z=_aH*EnS&z8?KkI)N6yxKO1B^ZjkwB!*?a!uZ3GG^(d9)uJqp|{@cPmL#FQ;GXI`& zsl?0jUX~-^vLfk9`<88&@J{JU{$*E6SlY4d8xnp>x-vb>UJ~$ThjeAR+T1MRUg^s8 z+59#MUnkuUN%#BG{he^jC7*I>_wsUym-a62l(6Jq{%#3>OuF|iAE+Fj}_>RQ?O1Kp= ze^khFRdIvB>;1t8u}}ir(s-f5p_OCGs9Zl~c0w!1@r9G|KDa~b4fDF?e9khKn(7;k zkKib&as!8D@{xoYLHoGOFb-`V6EG%YC&Bpe2p7;V=32FKnwi9GY-|WSk+5w_oS(dZ zJXJ2G#`|yw=XCl0@v*5?c||NZLZ_$3hWk=OJHwL)626KUA^d(*NXukrKZ1=-5lw75 zHtgHoIyf}Fvpyzn9#^F7O zE61lJq3Qvf03#F02~0(fq%iwE&V%ir=D~*QclNXo9~uc%)MW|=i}m;OFrjw3#UVE3 zJ3D@1vis2Z)L<+`T+*X5fC*MkUf0UWCnu{L_l)#~ru{g8RgkA8pR@yJz|+v>0Zqaq zbPyTk6p_`ilt7tgdSWOhvJKwpqGQTJS|jdo8VIWEd?$Rqp0*C$X&aob?C?c>k&rLA zwY{Rkw|8rMAmEGQEgTAk0>1DbAC6y+?ym8@HQKYYX=k$lYXP>k`?~0i=a4Vd7_9Sk zht8?~bT@`y|vusMey4sbDH*)od?x!F;%$V^$Deh1F%i z2WI2BvFkJ7ZTRyMg)dO~59;RiggY|!^2&Mt@*m#4OzTjy2fRehSVh#!8M;YpN*s*W*aHwXDcNs62QSXhkl(o`S(8XOf%GsTbn!5(bYf zAIBXaBznv>@TUrYiLrX*yW>BAFwZGC+)f(ZHo!ypsYmg~8~~?N_>Tb0Q-H~@ z-SkecpTQprs~#0s3qJ>VWy8-|07iEFFt=#d&xtXS)~tk@{H%1C^UsRz@1Uc&sV74` zTx}qDLJ`5uKu2ra+%}3-(OK-5gE=%>AJm@=bh(9~K$_@}q;p_yMb`nZx%UCwrc>#D z4$Nhl={$(9^QPH!8s_HAbb0RsykRySUkk@Pje7F#!H zc@$qSy~#(#V>4hgzoURLf5rJ>o>1o}vmy;7sdBy=cLxZ_hU!st7X7?WfZ!X72(GfnR>eKR@0x z=(qk^_+5#gdNSze8v;QV`OkL`=suyC!BzTUjm50r2I998KPqpS*UhBghPPnv#tLQB8IMa*070otum|HgMcW?l((ytWnq(6SDK2`BOI0<|n ze(F(jE&3fi0s^8{kD{~ackm?;&`&*z4s-ry{l-vl$GWm_;T^R+h7qx-ze7r>PQ|$uTa|pi$_{ryO zx8uc&ALVB!ek7OTwHH4#-6Meg_z@k^D7rSho9U=NrSL@O#!t~%_+0`oogekN6rF|N zB_vbv%Qex};@u?ok~+W?KaxxIil3E^_$xXJpNWq2RdfqYbk=wb!LI;6lDlXQx+Czr z1wW#r{Ho-VKBjnF>IF>t6WtR06y18fo9RjbD>^FIiq4|nrDQ*)-I?_FZewW>1qNBPj6Wy0gbgJE__*?99*%QDKp5jr4UnYJ(f;sP# zbY!Cpbl1EOek#6ICc0DbPUS^D*L()W?+XfotI8~;jfw8s1hUDSZ0HyaYofd9LD0ml zbf%&G!P@e%ErF`K>iVicpsL>M^?T_Nf3Z$dQ&Z#hR#jHiRB`1{&Xw3iAj?fS!0qMf64eq~2%>MQrPrtV6ep*^vD!^KT6__RH)!W{(zW!g`j8!s-q z_$QucS>q>uoSRx%*j;qqlYhJ?)tYLl`t2(%WxstH%snDbE;i2*BVyNo(msbc8F!OW z_Rw&dshl^dHqWx)KC=E;OCo`Z174_e1OLLFHZyUbTZY9 z<13W^SChtJFNE6%lH1Si8$Qs4s~Z&Js&i*Bn~XyX9*6ItbLC-?0^E15JT6jz4f}9% z8IGKc#ptjFqUTS9r$Y;>r}X-6KA*$$JVx9^J*WMM^Xx|rn9frqwft%c)#iMY9ummB zVvgQi&AOR$YYuZeo&FVgjpVFwIo!Fxle1?s_!Vnx7n}HY;wGW58bBdiQIzgnTyE)v_!tdnx^LIW7^V&*6mj^s!x&Qp{WJuklw^AQ>s@I3^?16Kjg>!Zq9Y zKoIw&`(<3DR|~wNT`fKIA*HL5Td)kHX^B_|`8Ck@mG;nvedyUmA8+ z6cImgml~oh8gF{yNWFvIO>ME7XiO2C(Zm9GsT+pj#64}hIvTx|v+zN5j%QN`DGY9e zCw+ATN4mRO!njJ_BD5tG?7?v%v9@4)%bu?8=JY_ySIAG}r@We>n5{=>Z%?R`e|Om( zY7IwmtuYdKS7(n@I2dV)#=>;lF~shaEGCDhM*7U}y6Na{bCt)%g~`znFE)}II2=A1 zY;TVRqtQ@zkAV(%ghARK+8t__7NpG765;G{9*XF8dDYwlyAs9qsr05w7GbnBcw2#G z9j9l5$2g_KQH~GG#n}UrlIT|9NAtUza0GP4OXLeZumRS7t|lQTmoV7Ue+d7BXO6nsc4@tJ~>22+{B7sha3b!RL6 zyu9w9KN?%lt2Qu>HHVtoqezDhu^5@AGpeyN^$Md+fTk|i5$^PE#@;-QO#;SZF-KHZ z)Ybqs1r+iLp-SHBpQ#-b50syV53WEVA3b(v5=l7-(!)YdaIZH|f!gyzDF!e}0p`t8 z3NRIcs@kf$%9<*m-y%f-ZHTC^sHm*0t?*aY)Kyp2)>hZ~Ya!xdG9=%nh#R@yEqXeb^B>abCf!@6 zhsFOtbbtF)xmowmGEqLH2as9Ol$meU{iI>c3GiXv(FwnLBYlCTuC~V$JNg z8@^JLw6buA;cb^rA2+;pZH|{rpQ8w%FT^Vgyb5b;?8`bHI!ZiF`DXWV89V?yh`Z24 zV-HaX6jE93=vA$$YEt#i@Gx?~w{&_iGF8nsnVQo-#wBwB=>hC&f+-&4DW-aPR27;Vu8J7pHqRR2TF&L54s=s*V{(+HBa);2!&3tZ zj8WCjN!~3|=eyyE9X<=}T9yqHoyCcs922xo!%(#7aj_gZ#_1o5k82q9P7GmljwWX$ zFxO>tLR`$FkBB67u8vT_3=EBoTpj~97)9V!7o#(SuVQsxf{-Byd_Sw_Ao2l$x3aAq zMDi1O2W#*~ru49Pvoi%K13%2p60i*YG}|Fy8T>gG@+fU5hpoQr9JH zLh2fwEku}k-pxA9NL{;5GgjBJ%Z$}EjR;wEO{P%vR<_GPNtU;=-3CrqbB}@3wcIO( z82p}Q=b3PlAx?)hA$1ksXhP~5zKM&$SXQP~LJ%p$(`=9v;9??~b{DMUX{Qj+u>5|R|gpc8?(f`T8WRum4= z@7~qa0}fIYwteI5dyTz>imtOO0*}$Ll*V2KxThry@X%mVW0yJ!BugF|gc+{_7!B

kih&1+70=v2q;c?tv&wdNA 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⪼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 z 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

LK-QfI zr$td7!^nqv2^dC$h21u9`@F5Na)U%^a3e9(=^8D76g$HPLc}Hs8b%X6_(SW`OOZLJ zA;+361c956Lp&9w7J9(i=wdFRGD{8PObJp}w=H2#R4&@-ksdlE&M>wt;nH+g21?V` z3@+>2N|}>yRz3)~YrrthR*z8n9QjBDo$}Ez-lZu?=DRhJKaaqe0#gWhj|5~)mjnop zm!i@6Qfd!BLQpR~keE0<7)D=^gB=u5Mc)}zx*A5mdPJ&o<)dNj($U0!Km$_ppr)s| zA!11NahM;#V?;>vjrVsAL<$OqhGRJX6I=bUV`YrK zJ($1;F*sx!_hWM84*FV&zJML<8X2Lxlg9Q9cH_`2#P;@g0h|~a!BuKw>nkfuqWSz^ zd3h;LfGy}5nOKjj6UXC|1qFB zAsp-Qoj98hDF=(X9i8?t67A`W4-WUn*Y^#hlb>xg4uM4kJ{pV80uDA!yG_0pvh1RcO)AtUK?y{bc9NE&_ zzo)-99^o;H9<&S}yH(YrgSEA6RC!V9y9^1MHuXdbhG&)yz3~z31e!tKQGs%Mg-ZeZ z!E{5UpauSG8SfvAd%8MO(C9c3(u9FUaf^4V(V!h~Lv^-w)OTW(N2RN|s2fzSGx+I5 z*G{~G>g1DuJIe}-3ZuyRJ!PGB@jdu(mg5kQlbLOzTufwIQ!Fm4-EvlAJDsVi?xkB_ zR*X7QC;7++^T202h_~-;jks!iV}0!=JHD-D%jP<~cDLhda2I+#u(+ECRco*hSD@m! zyZ8*UsAse<|8;=R(Qv?c z>ra4N6dV9C@vpVP;IDsz;^o^wiRuK5=2ibV9?iG;qxe)4LLUwo!yxlVFxq|d7Xgf+ zRXREs`IGvkeO|*@r-FVC82Y8%sN<0y|I&&y40?i1en^ade)d0fJTU|OdmD^SX7&$l zFb1--@3g^l0bg%}(GShOzy_n=ncZiD7XWV7FaX#$I~y=W8-Xy}GwTf-40~pM*QECu zRe<-{U@Vr+qB$M^7WfR<8lvOW*A_deHiYY%uN*_rWIlgM8eXD$Mc;csbx(ZSkuCpKF6L92M}H z{DGeCYkW?Dcdiss?|M)Lk!bGcn)P7JI+(X1HlXGm)VKf>dUC zDDW6W!2wVd6$eCA9?BpB0xBTr!wK*?0D_{T^r=t&-?jJJ=bU?TZhBMDkN?l_v^VRl zwbx#I?X}k)&pCSopU=1qhhE1J4j)}i5b1;n-h=rj!EYJHau;3lfiB@gn5k0uvz+t) zVft?v!Y@}+_@6lZb%hJ0LzcoLQw7&zib*)imG}jGQij9NB#t^R@lzPKvfOrC?`4#Z z*8e<=SqQ%flRPK=PRz>)zsoQx2tK9KHJ~@8Z$Lk(2Yf_A*hj)`3{Pjcmm%cK@M{>} z!tg$Zk28Fp;olVW&1P80FwStC;rkih!0_t~Szq593ireJDSbbDRKhI`O@?PNyprJu z8Geo->>%Uaub^c=q_>6afqGm?P}}v(n5z>0RVF1&AA{_RpancWA3QPC}n13_< zZO-t|Vm?hc+P^Y_&#@k_DoE8x+IJyCl)uD3!Vq=t})bUE@F5&!yhvIrGkrk z8J@|I?TTJO#?QTwA^HoFm-`|^)@yN#!WX}j;g=XbsNfQ|!;&cD7c;zpAX*=H2ra&F(2A7Y&KTv4a+73|+DzR37X3a&hkA^Xe9?Nr5b~x^A#;;&_kAkbwKoH;RO$-|t zb}&4hA^XW{E}zwC$7H-m7;-tU=K8(*6-5utWw?Q11;djVb~5C2LOqOgJ07};ag5I? zy%5_obRXk?VE8)2Hxyj6kYPDP^nVn84VTXvPIt`#roV^bMGQa4@NS0pGvxfP`3d9y zr(nLHAu2qjlfQ}~w`cj>zUH(4=Cl9iv;X9Cy7?dAcpqcP>E=Jo_~Q(pS8y%27i&4) zwTqb^X1JMQEyGh7zMbKj4EHlUmm&Mf+FKasc5Uq)jDMTqPZ|D#;Y$qvs2~=`r9Hyz z_u;jSAJ4FqVFN?9OSq5mL5A$-VXn_%womwz9DWz-u3Uny9~dK7ZKEBsHU zKdRvIT)xM%{~mun)49GEWhuNUk0IN)=tRc1F=Y8gmoUzDEP8>EdDv; zFDtldJwwj_rXI$*UD?F-ZWG&i)5kgd^9tgNA?de~lNg?&V000~l?<6L%Jz$Xm+8M$ zu!Q}igzHtwwTf&`M=NjpA-x%V+gwwf1sBk z>lyeW<3D2f4+Vp07l=RD$Z(k9H4IUYWH{_fFl(-YvkDoqU1sf3IN5g%_$)iaUrr+Y zTX;6+Gm5cs&6MK{45|ap#h$AM6)N9VYh%+)t4Ca|T2g^^{H`LTTQE95< zpIvcCC&#<=h&dji6Nb$*Vr`M(+P&i~iHO}Im20HeSP4=5{l9HO0KCF{V_NuLtePW`#cE?ap zd|w3TXDRlSQfE8h`9%u3IBGCHMCVA5gDDTiQy}uSedBvf@!jM~Y8!M@l8 zPDJUMoJfv`!<~&SW>X@zue2qc2)D<>u@jn0O2Ru&XpTn13EVZs^A=X+2;{3&4eZbXL%j?TSIEXHqj<$}5kzD+-Cpq^5X^;fg~tGO0N(84jl@?j;$S zG;kg=Y`4m!+42zZ=Ddo!ilcQYj(b%8B;(q7pFx$9F^}4lRBTs!J3}{e$T&J5k^i> z3K;2R(m+rg%K(`aDMfGZ7n_AM2mW$;${hvNePZ^=l=zWoNQws>87q|7B z+a9lOr@RJ+J(v0*s(Y}H&TGU9UwFcZVM@NWJK5bcAfFEB1?%*?XPDy85{twV-!g3J zvO>_@eX-xDD=Cgt;{)22BF{&pxd>QpR0s)y`zURP65wLb3 zuQL24$@=1ZAJ(!`_^N<=@EKUUOyS!MoMh@t$H5wxOw1q+cd{So@;q>(-SfAO6?C@tDPB>*UIB z;9dk_oy)qkJeU2lmV=|+;aU&vzqeSclZtoVmEm!4GSd^e%_=Mfi^oYp^7b>Iq$Qmf%l_ z?)YMze0{*3^2&fO#E;}*ebbW1`LN`nY;&$dxV~7P!S>U9i+>7+PR#_U`MBIP-xBzh zpYozFtsnWDL%(I4fouIX;vRXWpU=0VT>7oN4EjAb zl~3TAv{S!4@;$8|*0s~=mq&gT#!p{5U6+1&NY}VRGXZKomwu~PA?$&veBxoy9QIrN z9B{24o^zzrZ}qDPBVK*!bY1#|9tQ*Is4vau(r*pn_i83U<`W;ny+c2Gc4p~Uf_s#$ zSNY}_fqn^o`qJsT^vk~k3>o;}+8pqGP74Fn`VHdVp&va1GnU{-^&^5`8vWM7?z5jm zxW3ZpSNv%(v}-0n&F8XTF?=~dG<|74ZZ~v2Dn(w!R?P&c^Fi&iBOhfq0AGk7<>Pq# z(&VEIHpvblTwgj}mz`@K1H;EP6QJgEU*g;l_F@FPD6;ivU;^&b~*L4H4h zaDC}?&j&%@1ScQz5g;Gbmkt{PK|3>UFTVhMCTyk4}Nc4$9!`g zd@lQ4a~Z<4{pLIP*5clg-)pXR@R48Ye7N+xhI~cqw`>}|JK$yo2&a4;o1X7lXMR^t z!$5}eg^!p&$Li15uk&Z9y;M46c*~w*>4{ioc+plOEdG#>oy$GlLk{_l?_eRjg zyO^)c!RJc%rapw}bn)CcoxGa{5vKE7?ciI1dp~}B-E;w}^UE3o)b*Uo+QIk9QOxH) z>cJ-v;NZKRe5u>bXRUISMvF%_g+kG?s`BcxXtX>M3gJI4^%oD|Dk>^Mp|a}ADn)tM z>~rJI4Z^3@f@EQk|2PO=ewi8op1l6H-uh)V3;Tv%)7dTL&f@Cwu4%n~mf6Qfz-W9>vN}Y0UEC`b7J1azB5S1Ei~cY~+k& z@5DHrOV=q%1D0f)2_q$A7P1tn~S^49NR`)4o^{b8>QK<;>2RlRYOGnW){X#a_*Td$aO&an)Wb@D zl_UL%*y6J;2woVt$bYf#1KeE9c*lV^RUc!i9|#)at*DSXhoYU^mmn$;{vUbwgnz%h z-~}f1j8FPRB-_zN7-AvFx*3){1M(awNo#tiiEnGiarl-ThaDE}Wdf&N(Z>IZaQeV- zUy{#_f}D!eyA>VxYj^f=q|K;4o7TZwQg_A3cpD69V=0Q-DC2;V zht}&&%TrBYQ23)+BIx&LFJ79pcvaS7{9A&%ta|)52C*b7vQ+yhmGBwCbBt@R#fxon z&|YEq&Y?kpz9{oyLnJf~NVRsZAx?FW=r#xYIBAl=%6)yTGj5up{Dx!?y7N#;BwCq| zCfPJ;F`WXUkrPVFPbiNlYNE5g4%Db*kqCdaNyO@E>~+#CgW~mDEjGHhxymAy7KhwO zxpP-LB{VrqC!OKjYP`l{F|>Df)HgLWn9QSt#&LYWNI%XFoCuXkUM38V4DU{*j82R( z!SM;G(jI+dU7c1eR35>%za=G7S|_%Ij(3`M?c2?|HhdJj)5KTWDiQ}ZASlt+&`BR` zA0fc?b!!M;w;~ZroQ2}n{=SujS%j1?TvI};xvq8?rhxNQX49rLXTCHd2q)lPH9Q1vD!P@8k(Bp?nE2nu}*A_Z8pZ5 z8+NpH)Tc($p(_1U<8#D%DCQXu-`N>&mERh7#J4sjI^!KE;O(uQtZ=NoE@3vcf{bLh zv51L1lS4hud&_hDUiye!N2fqE_Lo$@orRIm`AS-E~@;Rod-i9#ugbXoPK3J@4ZmLbGUXf_E zAr_ltVfcti)fXE*i6u-i>&(RV25eakD+~@AVyS7i$52Kk1qX@_ZU`L+tz8>Bh;Q+j ztf&s2&_V2wyxbC2a9{({h$re|)V$!#D=7@IK$RLe(%XQTEASyY)6+#I4JOmYUuBxj zZLM4B7n1D|{V~K^9JbYo&(S;0`gmP)B4qg1nI@U0HDQP%eG8+FgQv=DX~Gxkw7Zp< z0FKuSC84yWvI3+@kl=GfDtJ%iKxMzWp!`0BV5>I@v2y2RVa|TA9#rYXc7~!QXo=6_ zWPnpDpuC$?0i`5bR#{e6T2Th_*_;H(b`p5RU0PaM5-F{yDle<7EU$`GB8hX!kjM*3 zC@(j}AwdMn3@8=l<)xs#SJEgqpp}(WmsM9(mQb_DEFjx#j>A=)=DWluyR7&=JH*?Vm)Z;&+VuT)43%wZ+7H-N&O2N9 zayx(x;576VcBo|pW&64UZ+l-QEoRw3oBe7BIo0^rI6}ON;95txrNfa5;(DofgH;Yr z|3f+5U4I3%AcayJ_@PO}F{1D`5nmwFa@;@e1mI_`>o{sSg$PUB!ej|3&HO8cc z4c`kIA!GhdBhU^*s^4oA0=QlLlh^^Zy)=1^LtHxijjUQ_)={U0pCSHE1UQpT`9Gqd z)NIN>hys_96uUX6=!bli6-%J(^FV&DB->&&{X9vxg=_lxl5Qtqxh17>kq=2w!E*YR z>&Q-CmgL1Uep((`+`ikfo+UG4_`Zx=-T%tD4-Hh*%({NcEYP(j4F`P+#O26NUAugtUJR8He+G;g$VJ1Q>5q0wGE^2S=%LRD&>fa+2z8E(41(Fc@<7?5DW zqNUL(Dha2|J4K6=Xld8#q*^+*IjNSW?JBK)OVOLecALZ^ZxW~3G)v7LHqFv0$6J8X1*C-d1 zOScBC)Y1Dec{C4Li2-d(qA5YsPE0-uU8~yeh^fz0-m)&`Em_R2`G*k0sQ$Z?6IfGe?d)i4me1G4F8jPutWt_y zVi%czciqVF#Mp>j=>@Ib*!)$WI15vLoF;0=56c+6%<3Jn=8ryc5j8xNa#MSvW7=dT zgVLkjsJYEA{!>Sd9Vx10u%f=;7a!G84;(4#PGYd4ekmY6qocMb+NaeQPx5-Pg=As^ z?M*v*BEDkPf;Rs(Anv4P60(^Tr0g{@GTPQp5oIhxnQb~jHTMR^{aT}zBWTppJuvL8 z&P7?`ds-bS#i5QBi`B7kccy9{$`U`;y0mvRwZszJj$omImhSPrwpHGnEq<-lummVo zM#mJdHc4vCnuoH*YyN693OF~9(^TKd0C*w3wK&=|sR4Sv|T z!qGS4IKOr*dv?f^{8nK%?|i+R_hqsjIfSUGPZ`p*Bbkgq^;1}UOT!=G(s0%qm*Rm& zYO8`kYpjd+2-R43wzmQ*rbF_-SCfRC;GztL@mq)AdMXFB-B{I+W1tc-8_lip)_6x# zUC8j~<4naZG=7Qj7)C#{Xo=B+Td15mI}9nNG9=No95pvi(;2koD!axA!=F zKsgZX3@z?Hg8$f3{~bL?`3}9KvH`zB@||PQ*y0;+?Db3Q+-Q1foa?#Hy_|yZp*G6Z z8k*9OZDJ309z~fRO9R{vY*T8j3m=D4=5=9=nbj?piz{2VH{+RF6#=Xn$VUTjc3w+4 zP{;Y%b^X&^RvFG~S;SjbZm_Vt0s(vCiSEv5r$>8oCUU7LTFFf0TSfTMd+GG<_a-VE zSd=~*lO==2__QU16446<&V~BO5elq~!{u{7JofV}S5Q-?8W_D}>u9qezngaQ&6hI- zOnw?;r^Tfb^=;d0o8$Cgs8Wk>$D^;zgkxMZK0$Mi8XdQxJ-)Lp-i}#=<$NjXSTP!P zj42bZrqmF4X9Kj+)3P=@_bGzC^0^0XRC6a!nXKi8!VT+b`h&eLsTepk8ah5y;AR2O zUYM#Wt%NZXZ79y?)elyFCUmti#4oLT)YBJ%?CBmiX?0~{V3-7A@$E07ar@S|c^aNF zqJ{1s9O<6eKr_*Xrq-rTj1Z9i>lRBhSmZiL-^e5m!*nwq#(J8Hmrm6G;>26@B93Lx zNWWRxP$xI0Abb2B=jf`#hFjanA^y+8xlHlc_r_ed|o<}q6NFFT$KPwyB^Z8b^iFj!WOO)wLBKJN;^UZC2B>3_Mc?! z|7FEV`x4Q$A+!cgN$tUOn!C86@E2I&x40guTBJ&nMfW?ZlWw(A80>K9^>yeq+$}qR z=_|Ev7bUyPsgwXnyN{%ej15s0!?PFN3QXJ3>KJaBS`5T~2Vy577aLY3`~DRUOS>h} z#g*4ar!RJ!PqthZiY$CGNY5sE1|~8$3`a<@i!B5)9|=+$is49eeYBt-%X2)$arDZe zetP;e=ixE)MU!{!BRmNREx|=^pOGgM{69`1AuIYCi50 zmy5UQ=0gn{`VAcVeSJ9BxWqIMIM#MR6h_SxK5>;hhK_KhSA;`;@nJgxbw!%pQ~u{^ z`Owk`?3&wC_@DjalQuVXWV-p&(PSbjGY4In=`ziJdM0Po{1+`eT8TQuXelyrNC8YQ z<)whQ!L{t=RWhk%Ps#i! zM|>%`w!gb)+{xdc;%VUHOVsH%7v-0HjJv$LF5w!?}-)P~oQzl`)pQh44@~g!kYy~MhI^yzg zRa{IW%6?VUxce9vCT<_rwkM9iX@n#MHYpS1R$gS$D1P*Pb}6lKT;r3v%9$cPT>TiH z{;3D9_B!Tgd|1f*tdH^}`Dj_OA=c8=yenk*{>vS~@Zat82mIgg1p?w>Uwyo}GiIJz z8pQl_pP81JYX}yhd7dasJ&BQ9ef4f6vHmeZwEb`gD9k1}Jc!*P5 z5vi@f)cjXI`G~iS3IGoc6HP7kcnD1IsME{q@_Dd+Y-@;*`&9vLZ}of@J*=Nb-^hH{ zicHD^OZVXZ?t|mJ4ntG%Z(9i$;E=L0j6VwtQdKD|q#33PMT7^f2=sg{(W#@kV{Ncv zJml9|Yinpo#H|=p5<=oq2c+^ar&3X-s9v9_}SuiHn9@TY|S zltLN?(-ey=xj}|*poMY_P>~-^SDx2^i&oEF5%B&DA}DDoafn}yb)oDNN`ubYqt(Ec z=B2?&CwXZ=sZ+cSG_w2!X@GYC&a5oh7b)5oE!tO7v~P+9h>|A%B+H%ueJb}=p5~%q zeyXzjqEdRaVhX=Dm5Uz|piN1ci(he*d}QqQ${~E%6YK3YOG^%*9QP)ZqW~QR-9_?k z?(Wcup@K6};U{S3gzLl^Oy!hmo8W#=6WB5~W+3CisX4O+q>b+= zhbJnV+jf}hQ;5^?@(#{)i__N>XeXcX2-?}yiIAUFHsMvtw$|odSPxDU`?=|Oq!{(Z z#0~Np#uZcMNb2#W_5OwT(@Z0?nG}77Vb7-Q?fPiQqc@NwHJFDU#_4wlOShyx57P=c zM80J+theN)jzD0_^sHTehJu%|CdZB3l8@p2qhR})m6(R%nYi(WIONZ5#}U#B7xTo0 z{>AOGnyaVdcp(WmRdtCUFD?fzXLi)qWBC4MakYPuqVOAQcZ(1Ca|?g(o0~U0In>!b zs-Ckq`PLeFqj(Qt0z-E(;#(WY8?75j_V+_8LUWA#T;mz3Z2!O*`pxl)?&02~d1fWT zH;cP+f`#|{rxSU9sz{(xbLL9S%ULUjd875T z?_REt(oyz7LohaQz;;0;^B(bmIl;n*a%Lbiu$5$@a0{ivQ{>`fs@%Y0@gd0l*sK}I z6;#^Zy2@e<>=idd=AULFQx<9(nN(VVd&F&!`O@s%yjTSF{sr=g7y{_dmluPp(p|v+ z&DprYCWCpXz*N_R<-WC9dD})+_}sj01L|&m-nKqusBKJ{NY;q>H4?dG{tO(=Q7L)` zrWO8_coo8bH6!8Fx~gJGD;zzMk((VAe}(Y-7tBC&M-@pgoSMAs4~PpEp#CkKiE!$^ zj-)yIt?b{54?y;h7cI=|@1JN+4(nFO$QuBmVX%9*q@cC*~^2C3InjeMmWu$MQA8!Tgbmp?uhVI@8yfI5}!J!eH zZ{*86*(miw5p%4&Z{R?Q?J%Mp&V_9i!<^$l_9LR8SD|K@r-?M-^mo)n*e-alBjQjqpev$YTls~lkU#UE`s8f_DqNV(T3t0IN<>xLqj&J@O*GXu&Pw$H>cP z*DTLVVEBg2&8LB<%0ov(L#NIJWU?zrs+_khQDYHVzVzXlUC2`Q!ZGnGWPd$>d0wj) zW8}5=*p~6-spoZgb5oBtbt-CR1P81e8RubyOcNRIkdC&f+9RV2J7q@udMDiN(!%eF zi*tj84`PIzi897vSzE0!5V?s<8Rbo^%!3YP7CoY@zTlGl+&MWO3dzysqPL5$K%pOn zGgOEsIaV2{L0PIoG)%Lsle@#AQ1086Lh~QZ&z*IhmqOHZE_zw~4;1>Zb#wDtWO1R< zFx+b?n73N1Cu&%T3A9{V0hXiuf!0y*D)Rv5ok`mzA^ zrcHyYXYTXjqLsnI^WTiwE2*(y*MteL>j+E8qKz?M)B@wGPUo@)Lv@p zG%`5VWQ%VVA3Zi$_``x3BsHzsyptl!EmmX}~4tiaU_h?S<|Y zAL(?uFpepaMWa2AE1`3FNv-%`sYBH>dx=S|FkzJ+i-YKTOj+fYyd-W}6)e2^c=yUr zN}@avv=X%)!j|5PQv#7fNvG}KGF!)(;=4%UFKnYw-vq|M>`#mCIU^?Eu9u*Tenvc_I5TACwo zbe|LFC6fWKq+}bp?8D-YykOy@k!h1+^H@o7-LR4(eA=YQUdw~x9wc>Vbo!)}z3imO zV2)hLafoV`J#!@uxO`MRf~2l1kx6+k&wJIpyrD@oG|)>;L-cSPYkagwuO$CO+_^ef zcwy-hcW32T`1f#ADVf#|(P^eMDH!EI;?2pqW#zmtGU6l-Fg9a6u zCPu}x;wJIoP_XcqWy{m&Y>2r|3rP3vJyHWr@-acT3aiMgyp0^TpSo+o!8M91#vXk!-TI zsYI)Rk%42#;k2c!Uf4yUJ~`NZP!F8pH>fm6t&+nzYPiNnyRnGpD$8TP zDK1(YEWEpVraF0+?~!#%tBowZRUP6gX!FPkGt|brMBj`yR9>r|6CZ~*|6MavZ9JYL z=4DV`>1~5G+vA4CZEJ%ypWQ58@vrY492hm_)6Wq(a-pUpj4@8?`+tY=zTHnYbTZM}WmMyCvSuPvT!X zQCu5XPj7U{p%)~J9Hj`!PkCKX{3|;xqvqL| z_=S{)Z@AvPw3}+hYg#wjK3v&)2Fe*VzpfP*W+8itM&$1(W!zdPt|1wxB2z~x;*~n_ zNu|co%lLe~_=;2`me_ezws^H(e4A}?loGxa7f&loVC%7?DULtI#jn^7M=9Ym4dTyI zLd*68s6Y%~f@l6(x z-mudN_+FEEOl#20Ss3ul0=`CaXJG(#yW$k_6I%f1VMY=jJVm^uB%qWtbWo$_@27~r zaI8e;u|B&^oR>o$wX<_-tKjZ+jGEtW6PM-Co3Sk|&9O9IA&s?as&UAvZfO?3T~|mQ zAiah_^BEeUhjZ7jPoU2e%h9sii2~=2PAtc&ZdOOlE6w8l>(}e(G{#b$$NC|PE_+Z% zbm}|0dwZ!<*8L^K1b<$0M~k@IA;#+B*WV$BF8^m@=W~VuW4{Ic#ixf19|hKpr9fy&0*%9#K;tkAOs~5RDRo*Li$-Met2)GQl@ereSI#I&!6&GcO8U#h~-_*S8aGKx2ns2--hb^Z8aaes)5ZRWjtoDe(tXA=-Cah_Jv+pW8;_^=c6?xUhjA&KezY~o4;&| zCsOrNCY?^LBUy9=mXw+LXIix8jdzJF%4N6Ue(lfh7$WDZj$tRMvwWAc-Ea)-y09&T z>-`H#;XkH*#*xoju~oa@oGjNVyl3a#lwrl>^bvgCjfXRTlTVRldLG`lNWNLe|A8R@U8H$@S?qMvvwi(x=f% z=HnTa53A#o`FLg;Ba0E2#yP7O-`g*au|672Y_F?}CvcvSO~Ti7+gtEGj~Va4uBpbk zc1Ux)b*tLC2=w>ZbhSBp6V5>CtZOvRu>-K14|W7H&bBEDe3`kuIo4sk+opBK@zrQU ztf?70Vi|O-sl4c$Sab~r9VZ1#8ddaNY@Ylq78@(J;F}})xo1M|t{B3nu*LK`E8cje z2L~a?y@|t$Dh#m=dB%Q^*cVoQ)~dc0#lFhwMr93OhtW>IwA=EA68b6?nof;`Pgv4L zDyu@I7OzNnkex14c?BZ1dPTwkA!%ckL@2E`uV^LZ>9d7%H4v@cD;hr3O`BSo%-N}4 z(V~%(^m&V7e;cIN;T5qYQkFh@rByP239pD$py@S@$ZrMT6 z)5o6HJEGN9WbQrbqi5hF0kkUm?0~ID`j*g;>mnmVLnFiH1ieH*t~ORAGJgU{Ef(4+ zoF98Z`tSdGT_XOyJ_J;6==vYSo)veCH?oa0k-e1He2x2s@V_iDGntnwPL|>JW1Umc zN#`2RgX04};<$1u2R#=TesFw|IOb=G)yA35wi+w>xndo{ALnqS;S8s5+e94UuX6ag zsp0hMi%25;O23l-hDc?gGnaD3h2Z$I=J2O-pu<Q{Z@7bHETzC1^*3TpV*E{I6?{ z1*sh5`e6AjSUwzJMO-;0|HfOA^TF~B&Em?e?6`7$QLsEqEHLOYS2`8y)hJ&lc+L+h zo=vGdXtQX*m+LzKo=-84naYF4N%7nOp2wKyo~fo|u6x1tN9KCNmnw?d8zt-4;JPkL z>GVc0m5Uk{$>pC5u5W6tIjLN-1yO7zVEdJ3b6G()6^d;a*e=WFG+l;}O@d-O1h(5H zTdtQ$$&dZy0Y79Omn1T&$jTA%cPRa1lN_bRElqSnpCn;CHR_V^E9bs`yAMw)od<9D3eMy?7!r{a5fU1TB+q5 z##D0ye+AQLn91erl8LHsa5b2|&rIj0I)r4BRXA7=uD>vsyOK*bS&xHffbAo5lv;1N zYPw{Tl{t7N*dEYquIjE5l{Gr}HSoQx`4)I6r>b@EIq+RQmy=!X!KdnWRu1^SK9^eC z#g4{S&IRSmHq;(wMZolP$prITEwar-rp?+8rt{~Kq)JaFGHupbV7gT@eIJ$ELzJ{_ z*2lp1xMce(Oy*w2bT5FPT4lQ4}8}wpmb3OJlM?sfdk1t344jv0hBM4I|TjEN#-sZ z}s^zSk&Te*tM;K=~d)On4 zvz&d6N0@F>seWhQm!3fyAp4c{4AKrcE7CJ4bL4DI&!Mc6Gnt-487JrF^c-xXoF~(> zu&HK=^ek+#StTj0K4#6QS_IWl%^I}{vVy>jXcX}~0lymjHe*fDe;iI$$+OSJI3(xZ z`@!aQE{5KU2j>YC(%WLE<|e`~>^0u7VHy%Pi2Z@&xrW6!@~YI2Huk(8YO z+Y@~Xc2DJHw<9|r*ZEEvCi3sK6hL{Vi*j|6SYvEjfX-kI5X|1iF-=Rci(%N9Gv}l^ z{v7nQ>TK%8LHl&-tW*+efK6DKg#+qs6lHHCb%>ZNh-0>sNQ60>pgHC`2^cPDl$hsh z#4r}XG^$X3BZ8L$D9OUf2Xu#j%)=6FTJ`5KE+ z!W$Pu71W8vP=6DJl+9KA5rt5UsHS6|%Ef~8D_v|5pJ9~I4VLSR5%YuvH4Ca2_;XI4 z+q6{KrXrQBh?O>REAv&^Bo#e`RI5{oL^{DHZCy%)8k?XZqGd=W8ODh=VJmEPl8xG` zZh^^8P7NSsiM+)oD|Lw&vxyENvkjv*H9!ghxy~lD5D@E+gVCb!$6S;{Tp@a=BHJG}=hQbi5`TA;nH{ph#kyLJgytZu~i$=a!*xPDY8f*aSjbk3l%OQXAc1 zZFH&hP*tRcajHV8s5_QPN#qv^x}}>=MKg@;%cM7*wjAEHW4ZM8on=yzZ&nc)cWJ~h zPUl-F{dRRr3|;EhFy5g#Db06kq-X)5CZkz|yh|Y}q+20G$3xNRLX~Q-yhTENbVJD` z>BcbngA(i}KoxyYkaabT0lr17Gt{kN?A5^}e^4VTaVZ$Vl>f?yKfs9d|12XoR z3ORZ1W*}ngS zMS4;??GZ%U*Pk33=}Vs2KY~tvw$U^U5p*W+5Dw@a#~@-fiX*10HkP7l9_6{cuoKQU zRd(y`mv$o@IZpOW?k1Qf=h2EtNl_GM+=C~B?9;JACvK8?-#;?8*Spo_a$YM`l(IeaTV03N(YlBad=hMY@5sgJp)$#x~fmZDL?3 z>1pcF#-@}lAuSwK=TV(bI*$;E)YZ`$@4_&T+^Z$h1Cnd&NZQi13(ugsj z9=~@q;jHb(c-=N9y`yb=YdxO3J888z3_T7i4(CDL8tTUxsMzl=IfEkV9qSLxbPTPV zDF>YUiUUCpn1W-g%@iD)Y|ecN{1qIBaA$lpiF1GMkasfh+cX|9-uMIX8yOEEGNpHo z14nxL5)_Um+q$}dXIq#d!!h)+E(%9mZ(a4k(f3*x;WRqbR|q(|*tvT&LFqT=uNueN z74%ENq2HX>bU5OZ$n!J~e!?wzlsVw-Ivh9#uXAVtN?yR{0}nAuiJ|YAW911r`kL9V zI>HwLf7*fP0{@x=$MA9X$2AURP#!7z0iS)b4u>%0e>RTErKF8OuFUUjTB6c8@;mEw zi{EFQ1pE;Pj?Q}4`3@ZKiOh;Sa5U_*)Kgv%7x|3Mn09>25uOM9TnC;HJm$dH1GmZ? z@o@%S_M?vQmB24|;Dx}qJ8zD!y3m0`pDcV(rY`V9pRBhz zaOe{}?7*Q<@H-A1`UEZiKz!7jV7((8i;O`Ole!R&Id$NE2afZ;1MhL*Yk+TY;Ol@} zbp-J@!X=&MvjX@B9Q+%AJJT-*?o1zL@4Lsrk1pExZU>H2SADdoDleoLf~)+AQ7T{9 zTHNWti-7NU;24k!%m2Y&fH15508U|FaPV)!{muB1KUTm$q3i6M7%u@1e>SegPhP<3 zdY}A@KafY)g#3#?`3fgld{KKud1#pph_Y%X2pw996Lt*|ydOSD@Ii*K?;OI>PDuJc z7`8BU#GA$OBt*P<98cniCn4fVh;-*uIMoq?z!xws!y}mZ5)S(>A&7L=5=42eBKR%L zeqD6Q2fBn0VPZ_-&tjrV@PC;88-~BdT$$)7PZ^GSPq;ujgyS)-f@?8lB^>oYhNFyR zIO>+f;lmO?MM0z8)^|C{M?S&?k&irrIv?j@hDG>Am>fFk@TWS$@502B;8QAn(x3D& zpr_OaZJC6SFX1+Zr!(Bk5b|aCH4JZIcpt;Z89vYOZwmV08x+r1$Pn$E#K#%FpWzJ* zzs`{L^}V5RKk78a^P_G^xP_s~@GOQ`GW;OJ&oP7@WW4(owCsoU>d7A8z;(<*|`u^z7~NY#t@Hk9}R2N_<5R zONja`;Sj^~89uJyJhsEURgAYWM7vAz<~_g=?Hl3qPh`mUoj<@h{7Z)aRlx=G7_Mg+ zV+g+`z6ETb1wUi_FA6SP#PD*4KVwl<|uh-oTLM98;+9V@4Q0q2N+3r=`rll=HQW?X~PPif=i$Z_5uc z&U&t>Q}_z@?-gHU{3Qif9>=voHq)#ZqQ#$#p7;<}-&+ThI`)@w`Z$A4^ zKBt?H@u7_WF@~IO{=i1z*51MRw;BGF;V&4z#PE*_Vo_e^C(M2yUd#CL3`-d{Fl4)g`xqZ&$bKH?`W$Ba zgg?pQw=w(*L$+6#?G*kE(|^y9{bk*3g|Az~@NEpaKCIiq_zs5eV3=gMk0F=ax~myy zz1Fe+tmATA$NsbKN#^^Nf`zO{A=kUY|77~33Lekpdp!H^@#iz0>w8g_!i(}4vVDtA zWPBS#mS1!U<7~&G2N-{vA(v;-YYN}!W61StV?E7B%j?8(aNmf+v06F-!3T$A0=;Uv-6+OVxrqgN za}T~o#iz6C487fBqs5$RcTdk)a$oW8v60Eq;u149L?>vOgFT~rwlz)cO@>QMB19sN zm?Tm!clRRB$RshCt+ivP^d{>|D_Xiub@a3=4(a50j~_9|BXqj4c}A=)GF-cNyd@Da z`+G>3E2eq_01@`@DW?d{QGD&wWL8GXE6ttqtT{&ni+OmA)G*H+t?uj{X-uAeupBYy zaxm*Ng&@0XKZTi*v4PXJ)<)xdTg#_r1FO#bkuq!5s%n$M&_y%lkYc z42=(r(>n{JcxW;vqwU@&qwT5Q*4aF`e~4a!nqsbA84ZT+?Uixj&2#{;IT=2s`>cVE z{bQ5;W}Kv?W~C2H^pd@5t7M;;D6icy)Dzzq!P#AkJ*Cvy4tR8uLN1OPj1SQn7UW>c zL-7R47${aQ#DzIHXkz24ap|=C#`l=Y3*k}pH5YlLQ9C&>*cY3?DJ?yd6Up&#xU;dv zY)ZuTm9~Tv;r4hqc0zMWNqFZ8&CzH$fxD)7JRS`0e}dcxrjoadb!p9qIx#le9d!+xs; z@8g+fce1-@z#N3~&c`-SlSy^*6vMTPWMopkTr#LYtwxY! zWYP+H$gtfileW!6z?<_b>Q9c=r8w?U`IC%m=Y0lMO2#~DPg1d6jq(iL$RXqCd`Jp- zGY(`4uq`+P@3CSZrR(Sx2u`0#12jI7LBC`-I4Vn!orzD_et-y>G$`&C1ko~SK#rzA zPAOodlSuAJaNMJ60AyU-eKRR+Zv13SyWpwvW>WGg zvEN(+pfqp}(Pr3*NC7GSF~c6j5@1^}6K`?az{7J$i40uFWHEAb680Vr+Vz>4XE4ve zc+@n_XsPM2klAZiC;Pf1{XNwPGqImQqLD^%8L{Fec%_fWNH^Vh*2;j+tu+wD&LUF+ z^$4eIY7hp^VSHCIC5mi?tJ2VEgo?SNiHVv{Ulw_F8oGykRXWkqf6@TFv#BNR_`6t+ z{Qv0#|CBNRj9!Yt4BKkofTPVZDyh^=bVs0A7NhzQ`hUb>ZjC`JF&HEg7!ENVdMG+q>|G z;_6F>x#anlW+u;%^*B#?Soe3P>)!{wUMK1ZbMujYnebu#%AmaID@{HESU)r#(@cPA z_=1$*P7gkp{j$ygPkRP@l#jEg^7+04n$`ig*%kQXQ64^u@8rXJss9Gh^rgeFZtmop zgY{e^Uo+WZz8i7x@IU!JRt{(}{6hGV@8IXd`Z3AVZZ-$&mNFbbUI>#Hmz%{${_J5F zUmxhsbRPzeHBOl>)<&&#Ilq>?|Hk_t*CAYAI$bUg&9`I}3|{5N{%r9*0Q=3=!T?#G zFM@lAe#;&QuJw!JUfac`-?Hamqr(W-R~r3RA|D3UR;^3(x%4|W1pPexRN%S0Q@^~I zfouJ!T}Y!}-ro@x#!p{5U6=hI z`h_k)*mL;lOQ-A7Z%rQgIv*}OzX!e-d`dF`YCb$?a@zRNvMdyM|@rTM7;aM<}m;>p1;h990aS^By9nG2EE;3p8SFD>tU5cEB6|KkAu zP#*QA@6Q6k$%lLdKCYP@VPm-0&WzhDRv}%o-`nvE;Yaca--F*Q{P?=22sg{|i{aP*L-w}2Nex%=g2cOG+*ItG&Z9ht1 z=YxFAk>6{tcJM8B@VV@A?F|Ui`M_AvlIP0DwPa_VkCoH#!G59u;gpZO^n4$D8DUyp zetN#^D1Vx7{WN^=XNwQdXw&86x-ti!ZvV)hF8f{A44SsHZpR6C+2y)UnEhVRDZjek z_u#u}3GDJN=A$x5Q*Jj;AWWxQ<=}Irdo$G!ZI{gsz7@Eqddk<$R|BQA^d{^L@A@i4NY zq9PP3tFEd9!1b=#=f;~Ggij|YQ!a3%kJ~$54pM?;^at;Z?=nuiYs=QryYAgO`jx{C z^9qcgb*~LI_~weo#oC1pvu7`QTr|wC$(beL>SJ@RBs}l>oKqhcdDlN@th~Nv(e10U zpMShQuY1cSw;Kx^8nR!1)WsHm=k{53XD)tZ zjo&|O<)wACiyt=*A;gEfCvVTK8(aKj8tVHH_hI6#+q(F$vE_CHDI0lx3!YywYhhC? z=TJe&_{QNaAOFo=A>&X^-j;71HY;~M3-bq5>0n>Y43{Fb`Fr28kLmEC)YgHC#>pP~ zj%wpLJ_y|3ji=u7gDJDTxIWQ7oZQdfUIFQ99~(I%**h^#?6R!zN4lQRTAwRZOL?p- zt>u-LmsgfoR`6P$+@(Us)jqpZ+F^?jQ}+{)D>P&ttgIxv^cP-TU51geO0QfwC_6v@ zy?(LMheZa+`+wEOSTE)4pJe0jJ8W!3-oWKY1JT=iydln>pF7XUHnK&wFWa9J$O-0T zV~n1z4^Fd#`%mA~J=kw?C%SrYu9^wa zibb8qX3F#=1)GeM{N9n_ec0S`4HU%HF3YbTo|(GeN=6&3*yTy0va(dWh;M9YWI&&j zylI(+YIlReU!Enh76<+QdH5^*Vf-FT zU0)@}fFVwmfIg)a+i`mWeov}f+*#KWNBRO!eClJJanlUtHza#Pp=hWi60OWf_hy>( z5QYMxkrPVFPbiNlYNE5g4%Db*kqCd%OvLJH>;%*-gW~mDEjGHhxymAy7KhwsymMDO zB{Vrq?u?xW@S>T;(B9cm-_+1xGLH@#$Ke_y{Ww{3B2*@MnJ_pqygQXLIx)rs$M?}n zdkiV+>a=2^@<>IbtfWLr>%@lX@lLa@eY;uLhA+ll@n~kyNh8=Ak z^{J6`s7gQ8_#Ckwig^aacXq~G<%jqk@vTjX&Ugn3czbInD;#UDOPEcqAS2mrEMj60 zT4U$EWjY+GY2CNAqrNmH;H)uG9EY{p?#uABmN2g6ztj+P$;>~P9a;AoMDGobe zsZrEwy}BaqMfIh<4o!LNjoOV))o2<%EXI>Rf6lrbd#5H}F*X-b`_Cvgl#={5+o1XQ zGTL{4j%liwXUshzL(G+rgzK7{YEvpiBwB5V#U|MVrD{@z!^UM|2~*5EGqJq^Td+g# z!9hbTHO=-ItXfiVpy=R+(1Fm}wV{Lf&XdWC>fi|-#E##~Enx)*HXx07qAo@a0?u%g z!Vn8osevQC4T!k{`zkO!T~yLwGF|*trrF%qx|Mz**>cbyL#)N&ah=#*q0_97*EJ_X zhHsr|l4)8KhA7gvFxohHs?3%qY`8$XwTTJfcr{fLN=qs$K$-*zUP7dT_e2g<_NxoZ z??VW-E~F4EcTN`O><8;Xl}>DDC|ZKH^DIsVIHdy0yEzq5N}^?zWmTmWWgwr;Nq}r8 zQC(6}T3T5WDXpj~FRQF9uZmP6iF3)2$O}m*FE_*?K?KSSC>7=9rJ%i6(kM5em6cSN zRaaD&RF_X0;yf8bxsgd(g@UbE$|@>xK0#$^Wu&^iJX#SgM`9NX$Tpkfa22QdF0sij zE56ST@iykAHbaIseZL(;Wm}r|12&cO&KADh4qyW~4Sj_jY8gS{v~$qiNFZ&fp+C z;5!yS1UZ^!52u#=kI9r}0;v(aT7pR#qn7`8qw8J3i_Zo!&ZWsR~c0g?} zOoh`$p7&SX>mk0>ZLoAM8$z-1)GZq6zCAs=PM5-9sTkl!oG zwpdL+PttASntr~d+euh%Noic0q*9=yM01Oh>t*I?z!9)tu$jx`@*?re*oquCS{ z-^Oi0?FgzeCvb?zrJ^cC7#xDo4~c4t!Vd_&Nt_^26hEQ2ikeV69h{`%-YHH}C`W!s zoUCw;{fyY6aE|_>h)HQUZ4leA>h!ldXqFa@4x*(?lY?k!bc#yCDf3Rz;v`zywK}Pm zj%`k=rD?lLtKU-eCb8WnvB;amX*SJLbB9f{wA{&w*z%qcZ+FmGAWjK$5G@to;UHQX zzEdWHnJkx7QZZ@5GooKI40RvivO8mqEIUnjQS9ZF9jr^i8|irtJ#Raf<^d})plwMs zC1|3E>0%?swfx$xni96CDNZ>i2#FT-0eH>T5LHx(o10qWAPfxC+op!7p<#2Z6KygF zjZbt>4D>oUPBP8bHoRVo$sG-P`;xtbw1X)>fPerJ8ry#ugS}GBMiSyBDhq}) zMD5*^?3)}+;w;Lsv4P}R!G;=82gZ8}A_p4ey%)zhq5XUCkzlAGvK=}8D1_D@S!myk zgx*R*TaKt{-_T4n{R)KQeQe|qZ`B&&XN0zO5IQnuh~EIM-PYb&fCbLUB$XY$H|^d# zI)XB0njtO=(3I_T1ojS|W%V=lvQMZ%bx2*0R7=+QD<1&y7JlB3f9QFS-?eV9~-jdb&ntuo}jOxETIe}G>*3OPLEJo7O^)CDTT#1TZWd7ZCBf}G8BZGzSLs z>Jw*S%8%1=?f79C1MA6>)jML%AARB?YIrE+ruIa~w8=^arANC_bDLlMr;ZvsQdG%c zMSa09KB}W0I8xM|#9&4JQb2r0M{Q5EPpdB;S@vQ})WihZn|AUlt z3E4~vQudk{8ExyQh%%O;%r>2%ntOxdeyvf<5j1M)9vJpk=b|j}J*|$E;!wwm#p+nN zJ5x0eWr-haUD`XET4IT9N3hU9OZWI*%em;E$G?CKhq8rVGSpO^q0wYT$G_T_~qlbmdXKbH`d|f7^phS5(MT4J=| z7AmLC4nvBm42kWv2$!8cK|JYLh9X&_+ z&N}30J$`Q^-#G@2E%pb%-qp0uji#5zxt{CX%P9yS`J-H|p(zd7CiY+>U6kpuG{Eh^ zuDjN{@Np<*UKhrgS>0l}xUzM7GoFG~5x|;(T+Dy7^IFP*I-b(5>!0Sjp5eTfMZ9I@ z1`Eq85U?kn=jHoej`NPs`fu z+@}ck%I6-mQO%t^WwMqV3OB5$>5n1Kpkmf69dB}5Q}er5sllo#?904To5g^e2ZZN%|siTTAMmC zLO}YjTP)3Bk?SCRBa=AX)y;Sq>uD-pI#K_N6P(eDIF>yl{bprDo!sn%?D2P;3#|^% zZfzrn_&*EhGR1@5^L<)nB;&2gqyGNU-ofti@qzw>(sBjrX*S)Tcw&eVmD>%WlTo&C z71NH>PmCu_A%hAXpYY?U;_2~@HgrQkpClB0RBIcWI#`H~-2DO3G=ZMaJVgYyPCQgl z3ewY(hs;4wi(Zoq&23w2BcXzgDUY@OYz0Z(_^LIG$2YF)`Vg`hRKV-l5U50whxuDmb`dLufrR z)UPu{Q6mRREc65`THg$!!Jh96SQ)^^GTnp!id?8YdvKKZ%yN+~8gg+Ja)A$tXHv9a zca^IW0BP4l8jgY(|5w<;Ric*1qE=}~$e={6Xwd$Xto^^NIBBmdx;BK?z$vLcm`-yS zHx&K?EBqGMBUOu3NwVmEM|IMzRtke14!yn(y@tDG2QYo5*6pHXcR7_30BQG;v=JQe zfhvY)FS-?&wxQKA+%mNoi2V-4PC_m=K}+`iD;$<~;G&BwuZ>P$>^7flxhxb}_+*ft zP2g?8%nid4QtV<2fy_sO)P`a>(p(=c=*RLL4{;p5a;Tr4J`FlMYMMTM*AcV5pueay zvjSuJnp<$S*!@N1(1qvwO<_JS`tu8i8GNdkX)vUwqQ$rjATE ze>$2>L}linD>GfD*-y{pjGF(Vg-0t7~3B5O>&8&>C90d*<}Up!iw} zdrD&6);rB)cc^-Rb^U1&Zys2>s%Cb&geYoKW%JrB@ojh1BP7Z(vG({~9aA?*I;Lml zUe6LwxFTqN&w~6|w)ms(Soz`|@m;BGo$7v9!u=l37O(qONLyRsUKYB~`piCbjG-nIGkdF9p~3clV4t`TJ8m4SalwI{mJp z{Brq6Q)(sne&?=@nAP*FLyyP7B~I0BvPOY$$Uz{6&uiS_&ixedXO95TeR#4+V{z59 z69E%Zi$M5|7A`ww66X79D((Lx?@i$AD$4%xGk42PlcwoyY10zY+cYg{Xwuy5At{ix z4NaPmq_lOoqWf2e+L|)$47ZEpvQm`PP76lbt0AH7~DK1EV z=+FMY&oeXUoO|!NX;RRSzt8_dI`cg9%(KmU=FFJ^$}JavaIzi`bVTJ|FR2uYFneTC zBX+AQOhg~oz9)*mX@EF*)=C#6%0KcbeFI3}_Z89_$8|2&m7f&pQD1)K zqRmfIna&!lcZ6xzOpxxA70=kxAU52wp{cPGPl>qDDi|X1&)Nw>rJ5jArU`!RQm>n6 zMLm{9B{=-VrG(;TE3LPYb%j%W7AsZ(ej1y~W>z5O1=!iP8JlipKIEw_E37TUqxo-K z{ED}P3IHz+JDOVR@e-JJmD6@}ejlt~+Zy6Fw=AH|n;hRo59_zlpH+0`icHi3OZVWO z?!Dt`9flsozher{#ie^=n1ANwMyrySM^BhC6&Vhh8R-35N2ksfn`^b1<1x23t+lbS zqruD(CkVn>2S|BbNhvGQ{PS|*6WVYp|&#@8{|W4@J|u_Qw(mHOj9oM z@UanTgYac3klil9BWdkydA?hdXC=I%m+ zpP(lv{C1TUQ@opb7sCRq2x{b1Fb|u%fw9(quok{L2nT}_S30qc9{DriaVXw0i$TKtwsLs7yt#EtSbn^4 z9yagbioyo^{sH~ua}G&cn>vy5i}EIHm2BPAybbHY339(U9SyUQ-#FaN&q&wAJtN82 zm*)Np=eL>0%$}s^!wKtY$~xVVrabz*QBp(E(91aeKDGEP^^Qfo57P?SSiWmdSTN=t ze;bWwvAD;xHvVt~o3SRxjX=?@*ni}0+f|OoFuW5tj){HlKpVa&k+7I6E^{wv<7O`3 zj$=a-U~1|NpC&#In4j#ZugCQLE8<%Be2Gyz)*cWyxC42AaHVG9L&nbTQTd*|$+g1B z8pS?@2~6F^h--x>YqV}8(%%oQ2=p7-0pmGVwtrv@vjoU2k2tWz-SYuFUp@++*L$Yn=~@)UlR)Nq)PW~X{tk%$72gNXSEl88VKh&G z#8YI%^XxA!!r^`8;-}#GBX2sn6aL$dWBj@3q8#dAeb(s6_(aE!fqqrgt`(^U3+Wla zDsx}Bw|l%V+}9ssUx(?dqJZlo;_YN_-T_~XFtN=p%*id$!o=yv5k}r}9Tk_&@#fu_ z#3f)^79-5bUy03NpSdIAe{}L>;a$)(BVDXg!^<7;ups=^u0i zV*^uG6_h+55+6(P<~`=01y9d<;)%k|V};}R;$y0SXMwl@d~Z#j1z$m>?W`*oqi3i1 z9C-eDHaxjd6Y!+c@;oH&0nbji^Ba#avl6sHzn6xF4K@2u_pCLIb9@ z?k#n#@MUcrmFcNj8wX@8Eo)<+jHOGlqXT`G&)E*|0&#hoH}97zIa20PQzl{_DHAcj z``(m*anvsJF4R9M6X_XJCSsXVCSpM+nPjK;3UMuD{xDU_6d773#iUG%`Q3Mn3PE|Cz)Kgynhq7L*_km(d^Epy^OMYa-*AqPL$b`HPwNQrMyH&us>^b zn^kjF%ciZk-PC#FUD&AQOcvrB5x<3yE7N9C(QJ*PXJA_9&xkj`{5P{=PQ9xvhJ?&9 z5*dM{ka!!+56+u~=C&r1m^pQMNgorJ&O`f4pAB;wzK*9k#;v4R#mB(=`T6Nt{rwZo z5k4tEa5ppnMB`xhcJ7DJTe`Ba_}(7b9T^*s*zxYH(at>seSL#8YRXQ&mI*t%@mAXi z_@Ae$FaZ)8Oj}0!2KuopSodzJifdzc?*w+t(k?hiPcyPP#+_0x6bX-Y_YF)HSrvv` zpMSl07TSM$!M~gKF?yH8=$-5pZ$R(E3*Q~R)oAxFcs)jMyT7TLCx2U9m5v6w=-*s# zyT3{AIg{e^(ECS=7rraCoco-t(Rc3etdZeJ&tBE=xDQnWjboMPJ~Aa=JOop2S@Qp$ zDYjCPrW_T|!<0`fjjv5sk1|(IaHD)ZH%L874|g)?vbIm`(EUcLfmb$1vIBDi^SS>( zY^hbJtr4?i-Rv?Rzja41x09o%_r&z{W`fu3#@nO%aj?N) zuSS6y=FUSws)?+%km-1;LX|fHX^**9EJT6L&4Kcdu<~Qn)khao+8S{ul;5}PU#UFx zsBy{@(o}xlrAql5vIFz>IVn%Yo%XUg0Obz{ot2j@zjkktuD_nFxWe!yDvYFA6bAKJ z@%8{|+LPW!_GAZAZ*j1NYtg(r#PhJ_?&TR-9hknsxHOu0N*mf68#}cT;HjztWBIvd zp`43w`O=4HRv|O*^fB=Ucz+{1BWsgpV`OdWu{`6-lJD!Vb5qYYwG{begbG+UGOnf( zEE5K|b48n9>0oGjCmY(=I}zJ2rGH;s5%A_6!VGyP${0tvwVHDvswOeY$l9coIb>62 z{u9#c^RCPer1%{a;@Rc=^Tk)8&`)w^s1QBmm}MX*Wzh=JG|lu*V2e$m!1+?4v?sFz z$)9#oh`P@CuZjPKLf=}Mn$^O^g-*kWT}#1ptGRk2r-gWc=A{)tepw%A9R*vN2k_h( zv8n{m?E)VVe_MiC@2VNfP?I1fg9~9=8Pq%jFNw>Sdh;$hb*3`VV&GXV1JJZ~aMfPW zAofGXtB}!b`DzqAdGCiXFJ{B5@x?-J2J?;=`3r7sg3NTr|4IsYYmDUXm+5Sn81N%vxgN6(+3m zV{s5ePnetB!dJu{nclo>Pm5joi4v+Nf~HWbLRj2;aq}c36m?qlo6R~YEWQT`e|?uE zjN^GaGU6!cVeu0PdST79rtm_L)nW-$b$fbKXn|-^o_Glo9?p-Iz|WDogw(U4b{2uQ z)`RMdZ*gNgfkjt~1E+ZNZYr3Tv#P_Ib4=Th=S&rN(Qm~Q;QZ!sILj()a<&SXdagLm zT(FDJ63>A1i)&-+tCKf&YS!$ItkKB01@ zDXgHZAAB)o;8LU!Khk2BJzc%Zse8> z){SDBvL?mr#$EW*%f-dZy?Hm6Pva7&J}F^gL$|aj-6(gur5ozULa7^KixTQa6R4B3 z#n++R7b_epA}Z`eq-nS>GNot2m>Jln9ClxF^TH_#^^w8uy_y{L28~9d0-3o~MR_$X zlc#gkagC35V-YW=EKhz=T)x7a_dw-rb#g4<!&}6x8I)II-(b!5lwont3UAfj)#7#cs@}nY(J;UL9O0P@bsagF z<3#WOJBs~wKdZ*)Ez$Hajoxp>(;or-RqMouJS!!C+EfAlIKv%pK(V3kXf*rhK>p2j z;v*i#UXh#ZW9fjD?gQs5LEc{Xt;vcnLQ20Ur`!mD?p4IfGn7apQEG_bE zBYGThn-g#?>KmWnaJ1d(LagneOf9-bCh_oU$dhLAE`yuRHk{F;TO8sFN4xH@@}%B% z7*&5dQ~V)H2eMG>aD;Ub2c-_;;0$y)!e`sgPKQU%5})&~!nUlA8hlU=J7jUlkIJLm zhWAZf7_M5nWk-_PH5}RABF_RAnc7C9YJUwjqvPYVb871AE3`Rm)RYm=Rrzp?J%|_M ztq9y^iZ_;Z8! zjq<|@a`;lCc#}D_Z0@L^sS-xjOO0Y*64is2%{8;gcKv#BbrSY7QtOZgXL6&+RE;Ck z-sGraW}>fpa=rKzXF^%eIMYWqh})%t%{5BYHrf8Hb|~TT$syY=Y1tx;s;4%HFPr%j z`DHo=A8is3Dh7!iI~{}XH;JdT2F=QZ0Y?+?HBzhz1Mu55XN#X%43rJC;&A9}@rvYt zQl4Q2HLCu8w)m^c)iLv2cW)FI`>954?TqggVn-dL>eY?nYCr9aZE0z)Nl+`;S()+9 zp-Oc}vv_r79u0uB4S}9#Xoj8>ShcDHW1h%B&u$3?tOhz9*Pb2lwO75~EIztwmCjCc zEID|r8lvnxg4(jv*wNkFOM|i=FTuw9%c}cY!~-@q<`BQ?K4wFMpq^7)L-Xu@5h(7ve$f$PH2rtU$km8p171p8o&>Zdk|Ls6O88Zv@2 zBjC)7Y?%?~%w3~nBYimY3Xe<}xfDPfLyj8NA8i#^=dw-%!@C{yQi_mnq=!;Zs|LM} zw2C|97}#`E3`jr4fK(&~q@JPGankJ@ZQ^ao8dLY3vh>+a+C9-);WAcs-Y$e910TK8 z9D}00BjXe`svkT@+_0LBWroMok{LovVrU#S85&0w!^FDllw!Nbv1mjd|75#(RVqOq zkFktI!YY#JSPv3ec5{cgD$gv&80&~B{Lf6u`MPpZ0mw3W*Q~3$u~WR9#|<`mUy9Xq z^Onk{8#SAzmdlUfUGf>cOYX1f+RIPmU3*bIa4CX)tBsn=Wp-KnZK%!PQ}wCM;`Y8%^0$EGxng}`nv*yp4=*Z6%KX(*t_7|8R z&rC3S5b}m!3O*tQAL&XU_{uHfx;0$*F&67b7cnwJxj6sOX7F=T?sJZEw;5FrZ4sZ% zKaKh`J^)=7v2lp%C_fgU2Djp|!|u^T!l*vHRs15K)$JV^>zzbbxMd8759s!tnM>%} z$^L$9n2}>cGb*tE`8`C{ik+zuJn!(VqlbyG`xohJ&K(~^$ausU$+LtWT*tk$gI=NO z>3`QA#f6CterukY9az&=ecgHDs)8uh@CsLrJ2_ZZaMUa_cML=c70b+(4@Vs0e8BOD z(h_K#n#phSrP@GDtM-^(?Jmk58SdlxXr@tp$NA#nXw{`xX;}{L5eFT0Kb}|TE;>=K zR=?CGUXNCYeL1~8$ML20ph?#M(|q~I_lPg7jj9I9muOIM<;V%Svf#}VbtSfUJeM6P z_+#}~!s6*@y`)R0Q|ovh9f2p=sDGwMtBzeDt|{eVA$HrJH82!jA_s=8q)x^*d%t0u z*mdDp2p$aj3+15DA5w5g!sf=|t|@ClF|%v09kBJ=T~pYbhi_#uyzDh&J(5)qCP~2e zU>K(W12`s@^8-o#>_Fi~RrmLZAC~e!6Kj(-)P&09M3ZbXjz-x;vrWA!!?R8dFjH0! zzt@V=SV)OHWz&NYb_o!2tVwnNUA;PDj)#l7hRrS2+b}jJMXFxz6*reTt85NZp_db@ z95=ItR;1h!shl}bv2s9KHrUKbtg<*5tMb9Bn{=DNCujt*S&VWRLY+vXO0&l7HF$Em5t zMOI34!>0A}=px`hXyN7I=uNn_q_b{=@c}CVr}^MSAmjZOrUPGQZf>q=H~z!IbvEFu z(Z-slW}Jv+ybqt3@Q=QU#p4v;Wm$r-l)j72;?H7nuwo0oIpWVfJNR_PAU=gHpzW;K z@k%dlg0^@V*9+lxqm3{S=RM+FSpKY4ek+P|m1RVlhOfiuq+dF1d36zel?qMcGvO1K zM43t|kg3Hf6JBH|%2Zm0Oq-lC;ewEaxrz!&R;yFCqSC}>;a&}7Yjetm4|NktD`Csd zamp4dEJ|!!2g!q)gZ(w_a)9eU1ccZ$`DDMdD<#bK_%OtIPqq34* zy*+X6X=_KQvVz>bBXRZ_)DaK&GxChZ^~d{`(BO5Ek)ffH;qU})q92zBD-v3L0!Td; z`Y7DPduihD|9WFs{Cj-}D0k?(pTe0H4~Sz)#x9r_wawQ!D1`epfhUu>0dXd$Td#G_ z!5|$lUIN9(Ttu-yo`T+s3pXgfOcZH8vCP2 zlR6#qMpIG8!c^{5P(7%rQlhE22a#k&Ap4Cbi}3g1s0Y6qWF`USyO!FjY-c~dYE@hfOfaX>|sT2^7E+r~_&nMj9QB;mDWvWV0 zy{f64T*_2oQ0-5a5|25$l*ya3qf~?>0UU+kxu$HsTy>@ zXS#>rSqJT;ZMZTb@sI4 zOAb%^HE3^0Cmlwn522PPc8Dwz|KlM4P=L56C=$h8mW=-`kl!1Stz)0Z*oAi& zT-)W2z~og(ewvaom_;RX=bg;MKPLxblBpv~MzQn6&M>@(_4!oER{}+MVcI7%K)nW3 z^!x=gxU^^_y_GXWp?v~C`wj3AWk;cA05xhyp#lK4-;Sbk2JS0%9F-<;&)RWRX288= z$8jsc8C6T|NcKOF>+DGOGLT_A5>GwkKA_5`v==eXLQKsM=wd+iBi7s?%ser!jpAsXnn?P#)#sXfc= zXtqn@8|-+tOX7Fh@obmGN0%=>3o8L%w`Y)c$s8}(6Qo_7;Pu)Qc+}xq<;{!3bJg;; z#^GiC^6rjHkd@5)nYaX5)4Y$yC8+A=eJw6U)j8k7xD-|Ke3fQPv-%fqGrspaq_B~` zOB_uGfO&Odt?2x8RPP)z^O?Ro(zLOqK zOu!CEdOa}#`@z2?F@bc4e|=&K=@tKEVhZUT|K}1@C?ENMn3zPlDp@2ZQ65V!it6?8 z)O?PKkR4U>sDH9K0i3tr1^vVN-sFN_$l?V6>q(!|W1rErNMDMoP*VDQ-VTTX~=K028lRL1BNkAM=jpz z7K(`HuQJG@fCr|z{V6H9BAcQVS(uBPu``i)5=Z75#-bD?$-A-_rx-GlK{#BLhYZG2 zogTt8=444h(M-ZqjV+_b178J7pis9^*(t|ZkkmTMp-Wo}9;SZB{;HCL2# zkmE%_-d{-(++ae13*1iS2+Yb&=Y-XGz$CL!f_W6B$Y~OXdo>oIg!30b6|{>5P=76@ zl%z`fLJ3fgkj7(eet{tUiWe9}XBZ_E!7_aTa-Ke~YF_0$xBtx4rbW^>WzlGfEVq#B z6w{6}QSh-%JG`NA7 z>3mHVK#HAh10iCg1P!B^B5r?mY6%MGOq5uQg&=U#Nl2%v)JhSh{IViRwiMMJduLafY#ZG1sPZGf0^JSC>x@6Qa z-lHi==6f};W*&iI1^NiMKmszQTLOf~i_uWJl-kQt2y`tNg#6(={2qa z!X z4$eYq-#|CO$va&d|hW{xmE5RwS`Msl)>u`PIL}V(zr4VpG;Es|0iF0uW zPkw&S0RF-2=+ViEb#!+xzN{RIfa3&&V=cZ5=kp=wP+?E>z&(OoyZa+UBYlx|{UaFZ z=NL`H;1PtAh9bigh`VREErayx|yOb?Y6 z7Oe^4qI=NHz<#=0Xx&;ie$U9*PAi7&D44#1-2;7*AWu}xsmsWTn^iM5R9DAVl@*q} z$B>|DRBteUWR@k-7a7HlpxKlk)v8#>a8+Pen4Spcx59<369YpLM{fu7o1%_}G+|)v zS9aR*YNkl2uJ+D`F3k3*inSE>02OnDBpvPAg?CY1d<1Y;X+dE@2!+49w5vX{8(+|J z8q#q@bC<<8hKbB;CgaxH&F40C(BYcug1U93MQAAXl8=m-CqLUkyoPUY!kyb28tOLM z@$IdfH`U|)yB$}HOVJyE#U(vxUqk)43l-W%Pxz58-waAr7hrU= z`p4<$#?2q4Cz%k&a=@4lnLmQj|C_%cU`(-6=^2K9Qooe%Y8Y!)&@T#xekqUWbmYhX zDd%Vy^aPvykQw8B$}*i!%<#XdBN-2pKiJYSp`G&+8=MCCAsdYGXwK(tFvg!bSJ>eB zfQK~<0QSwnM;2s<;R&!kb1LbssLYSgRyXyyu}6=0>)HC{^q-kO1M~; zy#e@Sz}MK)VY|QG2Co226A}J_{xlSsUH)Rgx2a^}cPik18w`DtN^LOoG2Kb@(8u?b zEgky!?Djw(U!N@<`uNQ9lKS|}Is+K`c%QS;Lm%%aY%sJ4j3pikd@oemQ+6Lo3 zJIay9W_c;t)K|e1irmPS^rpTz4)>2p+kh!I+MUscD1}`ryudJ;2u7cA3gvtRb%(;o zRQM#?3c-JuFtO$I78Tm^`Bgp+kuO!{Bbf3r9{D hgh$)rt?`GzD`y>hMVfqi!#t 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%0DEP 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

BH(##ymgXBRedV%SKX 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 #F7-opv&sG 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 z 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

H0&j)fP2QBoaWUwcMzw7WL7eSz&%kVOP`sx1V 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 z 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 z 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%0DEP z@293dG@GVpiLXKVeGC7c%2SIvLU|&Z%Ex`4mA@u6A#PtJ=aHEkX>T4qE~ATy}N8krst&Gf`KPFI z4T+mh15cHP#_H;3oe1#cq9Cbq-ZE2-MP&Zchi6tMOWyJQ;vMk*QEF1k2F=Du+0bTL z#*w1->u_>Yk2bXwH8Vm1tmqryVT6>41UJfpHe+RkgvK|^gm$zKhPO-cPl)pq+?j_k zLLQGY#!*>Y%`p%alQ3meX<}s#*_4^_sIq$81*r)!o(Kxb(dCR&#rL7mb7|vLh$cB^ z9;iWCs6sSMGp&=b*``p!sY;>gkEJF|xjK?U)O61HqxdZp`tg$3lscJRXf%xQwG_-- zX~5TsH60!nVggOmEy6siJkUA{jxu*)-WjlpgdE!?oFzV*i&1a-IA!o4h-Ju37*hsS z&xBXS{(0`qb59tr4AdA{R?7f3W;$fiPOK6KAmc5_sI_br#M#k6Xx}wnd#R~YU-w9p zCEhM>nD5T~WyScOQG5jB?eB8rj*oO!mm3!=W88NT8p3!To4 zS$Q&Rbcy3iXkT7ZD?V82Q1#4OVv;LNSmnp!Ai5sEta3Bo6t^Y2GcR8jzVZ_ylm~*Q zP^&;#+}rU2EF|PLTjg6OYnEU90uuguoFoijJ{{$VG%9oXDL@dpTdZ!BSvO0E)yLB)85QTEKe zMO^E3XTDyLGkDSZ7Hi4Zc(TVbhqx+183M2l}3>gk~64?%GI=FIh>=0YarN)MZB=QoPVF#zu295 z@5+hl6fu8~t<$L5$lObA6qiApM^{Zyo5(r(NwlH-N`6J$1Z{p*GEr?J>>{R&Bfmzs z4c2TI^olzdyG!mU6>mG!+q=7he!2VECr2(+t`vUyO6rA3~t6uzt1NK0_c?!X=31cQxM6Ji|) zm7zsT-w-CR#?h9+Ku-{R8M4}J#T`Am#=*@rI(3JYC*JEYO5Qt3{5eDiN}<-_h}1zG zR62-*X zm4mvCWfO>Y=z`rYJz2bHG2k>zh{K_i#hZ!)a(SEu)F}DK$>OgZt7-hP?pQC*@lc7{(mb+N z2=8@_lDF22i#&A9wXUwVY?M+Vjg>soILR>1ZMEX9C7IL#(lG>@&(H`xEg?O<34NYO zLib|{1h&eh-xf(yH;GBp01tnO0M5Y}rH^kAhe9ID)KDU1WB?g?wkzpn##USZ0Fo{JGW7;@Ao zy|`Xnlp%HM>fIedFII$fBRyC>ts3+?QZK$Xf`LspWB;li18t0I+y>Eb=M(KU0h-;S0#7c(8(o!;nmc-CF zYBDsAGQ-hz*FN-uh-q;w8j-~>YZPxOCCK7oDI<|c6-kU(4n|Aa^-bc!Ofwt9Qb$Z- zf60`LuL~DtfXb8Omb#K_o5dTMvciU*OR=hM<~&t(Lq^k7bLBL=Ma{um)cKm0y>dq0 zvKPfeB(>O&+VFTaxy3qfLv{YnlB+g~Tb9W>AF6>>`%&`L867f<9#ZKOKK6=?_5eyD z2T2VAs+8h^d0Zez1Z(`9jD~!ZcqyV_v%SFhczlA&^ zAC_W0brF5zl#BZhZ3%u}$$dVe+^t5*{hP(j*~_Rs8`#x9$gQ(+h{~v%nw$}=$F#$4 z(L=&0J-kJ{oGsOD@9J+KLQ}Z8AD0j4`kkCX2ng@ql zhOGs~{KhO&cpJs+#cNltseVbQ|mNJ&zw(6xBBxXInnCRU6jg9wtTqtVLIsqu1co zlIDta##xpJZu7y7K*pICr3qhVZmcb9G(Ka|nyc{DXmwdlEpEgz=#eb>qi(~tH2&xD_?qp<>i&qLz%_dLcwLcizvKltV&zBvxNXd(P! zar3>$=j4E60N>Tn`+@RD#wZetjOB6oMtTttC*B5}RfA_?Txmv3%!x5h4_@ZZ4u(5@D8MN^l`*PESk>p2#65Ic8?yWt?Pq&XNv1cRo7?Uh1u!IWdNEBoPf4Wg~(y zPy72Yh?}oMkTaR+fnsDkg%6QTZc z@+pW_;d2#2F?^bix|t|Qzx+gl!l90m!!QbS5OY;rN!-dfr{|>Dn%T-WMWJLxEVhVi zIot}1q@sHvb!8}#NUJQ;+Sx=Xu?Q+6=F_1h!&q$**1}dNTBxP!8kp>)P!Cd;$ZIUJ zQkRHj7SYCJs$rCedPpW9S6F0b0%GL?7|nziq2+I~pO&KY!~A@w_tb)p{KAgB z(+o|>&c=exU{`CmH#@tx&yQ;eu-(_)hYK&U|2Tv#I$X4aJMyLHb~>>@r{H>8gF(7K zbzpB#8$O(aZ%0=v(4k-u7r_jyUb!;gmnHuxDk{J&5ZUd)q1CuPeK0VbjVJE1vpaz| z^>q%?V|m%xZC&^W!_nZ-;A(oi11GC`0^m3Z;kXf`1>ff)W>0Qg3-#f&pN_X;`w(Y$ zXP~FABe1%&ufIJo)u`zO2QN(26X+crScUBH`8wMRvN6i|1a`yo2Fh&hoziTCBf){T zq3r}mNw}{lH!sVFXRZ)t9I2<9MOQDEN#E1gzteIdI%L5?CJ?bw6iz6CghWF69?6P zRll9iA8Qk-1+O@^_*K!W%WVTG>=G`z(xC-o=@xnQM@wN&ZjKMxzPqrcGO!yb=cFI} zaWzYe#W#$Jifek~wTg|KYUFc+d@=QEJpSm-u2g)K!@Tjuj$-)Th*$M0)>T!kx6{pM zA0-bJ)%NHk>QzrC-ax?ju7UCAPSl+L3TtYy&$&V5T z{9^4-#sofO!_mP^In9P+5Id#HhEE5cZNt$AO-Zof=yN4i!81A_Eo)yZ|OWY{PSbUt+_N*U{^3_(I@FgZd%th=Z z`7V3up2M)8UANb);Z09d*INlp@+U=7He51`Db<0U__Q)UNV^HIG z*@mYBzt)E50pDuFkroGrf9i+$;3b~0;dt{vTx`P^0dKJ3OM%<P z`wRF(`4K^sACzxnQ2VE<+Dc`Me^kE>)X4?pa}Z^L;30;OqB;=%H^%?Tu#TZEo`>T} zhv860`p7qFJ(T!r!y}7QD$Zlj4Z!xEw{&LbRUXc0k_MTw_lI!HM3TH=L_uVlOi^FZ>4{?Z@iRpNfew=)hq zOZqU=&tpEw4;k+&#;;@itBil0@$WGHea4YqsTa~E<3G#zYm6iBh>rgi#3VuDs1p(v zGi+nHi{UE zsO|ba%&iIk0p|a9`Z<_16ApWy~gk_3PzvAuz?}xU-X@f|4l&;=f9_!@lJ-HWq2<`w40rg`fU+1>>eMOlMfe5apJ_ z#j$G&TO7w&)8NR`g^-8Q$c;crR zeuv>91!uAyX8IUEpW*ckna`|Dh0p3^_@sifIiF^8_}QGUIc%>v-%#O_xP437$2jXb zw?g4_xqQ$4Hsfz9IBx+%E-&*iPN4M8&t-T9!^atNeNK*3crxpqd^+QU48OwgPYP0B zPka}!9TuF)_@xZ*S8yR32nx4wIm2p(jSROjFkylhYJgN(n+@I!_lE4V10VIjj3hMYf(SneY9 z0R_9e90n)Cotstuw)J6n;D+=|H%6i__(U-|959gy0=M} zw4~`Yot7j`)0ylcEp(DhlA&3K%#E6dMXnU8B_`C0q4r2D0C3#1+evfdTEN8-OF-1Rbl*UR#|{z{3L^}Wy~ z;KCf~O8XXWmhe{TO8$k1BrNS%_^5=xCtaDJg|7;DgH5`!UTvt8aJzJ6{%m-Mgm0AY z-O_zly1x}}k>pb(?Os$Q@zUN!EfSXei*Atcho$?lbY(kP^b-mHPPiM_Nmr(SW2b~= zyRuQ%yN%M$8}E|gpAs&1B=B3q_DzHdwXFN9kx%SW-SSH-so zywM*-I;vn>8t?eX{WI_X7hwjg$T;nGR4c+Uienv}aC?;x^U6hh+EgDN?;PwHz>!u( zCJxK>15qo2_LEs*93DLccKZi7+b%K7s}<3dDCU9nUhIRyrY&)L^X`%1A}On*6E}cP z6zv`v8Xqny*8Kx?cB|gsIo!K7IJPJ1Db@+$^;%+DW?8!sWoSE{Gpz3&ecRTCvhkL# zR-f+SClAL(5sS-+u&=j_A~gA${cS;Ng;R^-=0iP$h-Gk$w!xxr&E)Pex)^4p6Ub~WMwKvCDtY$ zRdOhLDn(~Xbdg&;deZEgQs-ojygAj)QcTiQDaLWii#svRQcY}9Db@+u$Wl%`QYq$f zJg7x6^D&k7Aprxq@YO{+q|zoy7SxWOZaI)~Ppc5{xMrefPBJ|6e9Y9Ehj<{s6YRI*RDHX`<$t9=$8r&s$p z12dB;3900=H3`-npJ9VLgB~Y3HM*|*igi<*-lg~SlvZ_@dCL(*SKWsj(K|?q5}(S7 zcX5KwlJSz(WipKp2KF#d2~=>_f5s~OsYzPPr#oK5Inw; ze^Ku(5^PS|c@y2qe|fJlro%X+_4i~wT`*~6Z%KNzh%an88*2;?m*VfiTQ(7*7&9 zmj||a!Jsnv#o2Ebk%Us90}aDGit$Lfws!)fbbxoxCaj+&q8pE;TaX93+YN3e56rb$ z`DHu`c=c2|8`%Z(F6zm63BGjvs_?_SA}@;$*Z^}z#E97;lL%9fk{hRAt{Vi6iU_Wvi_()#FBI)=GXtA1xc1X$^}0sbWV zolR+d5kK`PxpDgCeF6m6D6GvN`xJsO2?>dSnQWi=}`K4;ZLGpK{~QOap#u^k6Tt)X6_$}$!GzoYiew2;^{F2yt6KtI3M!0$u zzc@SBegp(}DI&OvE-oE)jo2$umw*m)zE=JAQJGTuVZAJwe*11m*j)V7qvXcvw~zE2 zRzz?WU7UWCS!NKYR&<8}S?sqTbVj@DhF{q)uHD^_Fy{vmt{%m2KM=|f@8yr;5Ajfs z@{`V1x+g$(Oc7badf``v0NyJv23-iAR{Yd^f$X^hKmPKAi|3mA@W+cEl>?GVzjXW> z@w3vsDDgz+#81)1^Lq(liXZin6kQy@Ls(pkE%sN$y$6>8>MQiXZg}lE}TzYoR0ElhHL==%|fK zMt8A=PQA}5{c(1=ZW1_UmqPfH@jD1}9!EH(mvl`+ck>p6x$z^qQv4L%a`^4|$>-*a zQLV6^YCNhgQr=kTj?F_cq4%kJ6dfCmq5A;#RA?QF2rj2H#^}DXqM?m$x39Fatg6)K zD=Txmy>5EMU#x1BmzTTUrDZ;ECC6Vp`#_+np4pT*&XMxlg80DoRAG54@m-g8f!6Y+ zEe*q8I^Hn+xi{{+`Ph{Y&p8%$iibw53yr&4zgoQ-)GN0cx36ZIk(M&J7=}#)-Jl>qO99ltv{!G z*%R6C$-eETMTOdloh`d+9(Zoz&V?Jb9|v=8s=qhq_WBRrz5pTf>c_G_xK^vbSC7{B zWIyP^mpSzh)JB*6F00Rfas9Z*rWf9nRv#sIt#*^MzVK$(!pm-6d}2-g_{t6IwEErk zpVB|I^1QX0ep&rPH_y7$`Tn%p%a;8Su_x>It+nZw-JDjxo4d~U&$`o9JGkt%<$v+_ zzkl&9uAG6J7eDo*_q&z{{TJW9D5v{bm)5Ok=x5dLTJ}uV1^yk5nisVfSI&8&cHwGU zZkl#Dr|qe~=V?E-=LBmGy>RY}wi>uUI_K792h)!&L+Y0uBU{*y&Cl6#Wc~^E>;4y4 z9b3{{a}2gSkriA~bLhEsh@E+>J?C)Fd(ysk!hUG$!EpBB?Ds6(aw47lhpsz#W6qY9 zvsPy0X;1y-zU5zjWu1m}-J-vhw9eY=?|}4pBNCY(@ihl)tVs_C?E?xMPm0rG`ssru{2wnJ>8M+On0TH zrKhLQN}ruRCvC3$GQip&Bqh%Tk36d$wuE{Z@~Qom4|~?1x$m9Ms~lI`ud%(G`7=9h zPtMMKyMNBE%(rurCuBXHje>~(DSQ?4rs}9a_5&@Aory{+(`tKFrp5VxH!Td~EOZ9q zKYF)0M|&|ji2x_|7-%SX{X>Jh-Sh`XP-ril_ZKJouES+{kE<83VAvPtol`W-wtw^u zhjFCOLbM-`0DP=(xDH2^DDZ|p^I#vs?F7lCyX2X{ifGF&bsdAkENT}dwc{gDk7L`1 z#i7HGv=4U*%q}`Ig2K>`Vi)eR-j@k6>}Ty`9mBOU`p#XQ{d)`mp%3m7p*p^u&7he$ zR=#U^Qr9sdOW#YdtX;#MSZ|;cr2uMwlgxCT4h#F`P9mj~Otcs5NAEqblhaZNz&j3* zVhG0JyxQ*&S5nhSATMZwlw^YRQwMet9{|4u-P7twRDiqaoL{kx@c!L}SI(*5lc#f=F(>d&UL!JLNP}(o;R*3_Ux!yh>^mm) zgCuyJCRXa~2-`x=vjcCPSe~M4$p9OtZMQe-U{ zX1a3mBN98T<6G*=%;xeD;;`8_NIjhPZA5T61%V^+W#EVuLf%E3&G{4oavp&VCI6i~ zfb=8&jQ-k~Dic&bFvfRYrrmN2w$Ab4zC*KJ=7ArtIfmybr}j zC%@#LwTp=9fXtDc-|&LFET^nHJ)A`YCGB_ zgR?d6j|snBXbQuT7^uU=pqqyTGfZQUM8Z5*j%EZO)I0{aPgKNXW8P08Pa zAX2^t^2txJ9uoc-UG6~QuSen~u>=IQ0H%;XWF_Z-A}7FjgeLZ*H(AL!fDq)R3{i0@ zB<3mBSU3hjQ=q(921 zQ8pOXfb0B`fUdi9>!Y0*Si6h8zKUG5e7a7{vJ~L+o>N?QPFb12h9h;g!1_1|2ju6} zgsiG6^;R|Upg>)NK}LR)s?=LyQ1By;B0EDQXnc^)AjgRZ)Po=eC|W4eRu`>hCQrMix@iaadCzqSuDD z>9wu+T78F(vlB!l8B~v;aBF>pj!`&8K-_2NZhUqQA@Z|xiVLs#;du-q=F{_-5aZ+X z80?fJB7NX4HN>0E^ck5W6Xb8JZPd%dx+1osiG|l{7)~5%+}2#_EVga z;#gya+FI*_O@Vl!^#OkbhgRv0{-*lvt!;I&kyNOVPw6)@Oa;|Jv4jDE9g#o_KLnsH z&=3qq0&U3PZ7mV0us>8A)`KlTL+n<`Vyt(3pwsF%Oo!wA4S#D0^(7b%@MbdI_{yT4NiKmTVr$irjpvGU`v8B2m^24gdd6R|v^WBr~HEZ1a@qMjC3#^64 zy+0p4V}n`VWIkjB!nJ;C5O97pXNFk7at$o<@)2`6&UBFYWKl_j@nrF{b-k&zrGb8Y zs3OKIYz?}^kvcHe>jJe+VYg;mtLtQ%maxVOl@~@E1x=;i9BgrKz%FgjW7;Wd?1(>%> zDZmu_N-Ih$OUg@uzEp|;+7wY$TwGF8QS2=#uPiIAs3@!SRzSo7G9=PM9LmZxc90Q* z5(7+mSy>5i@8CE}4REE!Ri#zs6~$F$;~Kkyhfr#`C?ivRm8GTS6{TqLODeooWo5o{ zUm1j5!@yf_3ZST1&3DK|$64{P8IstT*O~+=+Vov!43TVZ+IO2+nRaR68_WP{0IQ*o zn4yLdgzand65IPmZZX3K%Ir5;(6Pq9*%Fc{3vRK58#ppGY6d6Dr;nMzhBl|lru!)Y=n3)00$yQljeXI;Lr00nO%v=mm%$?-fVc}y zH1-(9KqZyUj?vUwnkLom^!K9#e8ZpzBTLhqpip!AC%I%UAT~mxmSCJm`5se!JZcIp zsr$Ye5SzRovT(3L_eWZrgSClT)*r=$Bd)ci{1kz^(BlBwVi?=6+4kB-Kew=Edr1Lg z%s(gq+MyHlM+Jg`Y#0B`wnObin!GAQ;&gbOtXiqp(n||Jjs2YvC`=~iAA~`!nV5eP z21SNr%;ub;AGA?Y42Jxj2lP8Q+GMNnS8%+^T;Z?ecvFN?EJ?=IHi)2%mGX_E!(Z|| zC$Hi0lhW|)w%w1#3Z4+n_E~t<`R{={c&MwlV?=Y<(hP)} zYc(-6E^?%susQo0LQthn=hk1#D%}L3KoEE@(CB<2!pieO)@(%@ z+O=4*hK{XPtf6U0$fB#7g`)ScZ6->xyoX(A;tVynn>a(u9a4zN?|JqX3r;e`3B?wq zq2gODNJGPmxEPFNWllu}kwQGrdN=_tTa$Tr$!eZ=3h^7ZXSFDTm;``lIewU)(axfA zzzTF|o5R5{4HPk4Y(&4-BX*dJAz`x^;*HC9dC zW`6{2vJ9fz{rb8r6zA%CODp!(V{k{EUfhPha?gx9tJ{*7)Fk(T+V7j46k0E&irpLrb8J4-HB%556pNiz;NI~fTPg~jok<^7_Q07 zcXtoD-%i-B-e~uDe-!87kBsz1NAmKkf$baZ%=1pxbAKX=%iQ~V@r9{7&$|sNz5`6_ zPR+D?Mod3SOq)-sY4^ZPH2oZy;zJCi5MPvP?8gMQwh=fqqOo5Ctl1ih<-n7PTk6WLN zj~E;6jJ;CM$f{)ZKN%ZD_1_&G!z@Tkq^%WGz_k9g)4aQbgA9vABhlTpLxW=@L-G^&-~ z|5Q;qff4m3JG(=C6=^C>iH?&up#tj^Ug_8p}T=VDRE zh$YoA;P^yUKki~bRJw%Pg3bQ$)>BxhueoD%k7<>6q_JNqH4FwqmEjRVt4tCbv-ubMRXg^KPtdZ4P0g zvW;Gk_H3KOo@;UVEB8wz zZjUUS|FfDTkrkAn)%fM&w}$coZ8zrO1L&xD^+vrR&=P11)*>fzZ4S1D`Y&GDhf%8x z&3>A2bC=P}4qb|=1h}mb;rwM-lOWtp9fql~INME|+`jT{`R+?et0|I+F@$3NQmq`w zcP@Gvv}nM4H{NZUeXlA(v`?S%>@p-frFT(^Wym;+B5~=llmW80OYGUw9y&$&F}eOH zmK@Q)U5oUr!|!Y=J4?{mj?ssAe4ZOkFZFX1&U0r`5YCK1z8YOq>avaX;t*ft=~>jl zZNp6)#=P)KMxR-DF{NxqO6x!B3zlqRowbeU`K5rgi(W0_+r#CVl=84QwCna*btP?dT67DWvyoF zV;Cn&XD`~QridIe8Pg2~`Ri!-gB=Z&4Kmc{UhmF}CjreKm@1f*!-$TVH{5lj7FK@D zRJGCAFAP71puYjo+cBzl;=Gu#zCmJ$$+y3-#%&D&{X(n@qJ{41ALF&&K*Hxix`)O)`=jxMCo!KU;w5ACzYG`cxbY$|=DNH+dPRLLKPiXo@pr}( zgNu7wTB$(%!+>R;Vxjj+n^GBK5^M4;d(SYg1|1#k>)FpOmnT-U$-jBCTLL1r`R?k`UzERw2fD8RnPp66z zlS+jYX?z20cVpm(p0-$G%*&hBgzMJ1RXA2DrW#L$5DFufY!f0+_y1t9Fr-#}z8U0NlPx+=fO5 zsET1;P_+WnHnb{6JWs_2Y`+1vxeO3V_>hx! zUv>74rEVA*A;vBy6Y%_|liE;pN1Ez9U%rMOa{d>5M3y`m*PDQKDOVv%p_>G-&>%NX8VH)7HhV9XPdoL(dTdC{qveB z%BwwDh8q9Y@{9fRFiNZ5_Vr)La3me6S3kMgt$+^7jU=NsF&>9-LCrs(xPWFWu z@)%(qG#Sii(WI)AQr8!p*m+>+Dw^5p1R<4^QIX7BTCv?w^dBlAgP!M z6Zcmadnzu1qEDEScc!sF+0Np3T@&3=Ve8o9hi^iwpGaeWwXNWEJkf^|mD58Yd_9eQ z+V1HZ8s1O(#_&v(kHq`a>Fo3NH7ZIhdm$z^?@7!L(%EO6YkE35N3HZdF(nOj@?o`V zuOUB0;RjP{CFuSTUmG#1m!l5V9|sk?K#}np1;jxMf(SmPU`uiCp@7#C1ORWt$|Ci} z#haZF7>F7Og6}q9{!%7pwijY?K-tCQk8Ttbpc({~L=n+Gk=5|sDKit^CzS1p;&la( z9LGjsVtDyO7Nv79=xi7-&2ijpUP$uHXe1}fEX53{s zeT+S834>TY+!(BnV3dfHRax#atzIXY2!=0rIZ0!Gz#zt+ zyUJ<1IbRP}%eET3%Pul#TT8;V=s~p_eYd1DW@KU}SUURmb?hIN^Ds0N|GFVK510Lo z@O9}}RSF7dgegK1;V~lut*?b6Dq3D#tb8NJ<93y_*82Kzz=%;WC5kEK2`Qz#RPis! zgH34nfjds2?}9Y6wXr6WhYj++Li{PFKP5;CI@1)3ESb+k^WB&zM+X(@QFu}E>haL* zd0d2I9zk%6i9__FuM3krB{YcCoUR5Yw?rD8d#*cy1|*&0nP;AxjWpO-FbUa;m2s?glBJg3HduX?-HZ{GlB{^ z=`O(LZeYy$AIyd4yJ28Z;&VwZEIf{br%zMZhSY_9i3>|jl1voWKe_r}NoXt6QtM+( zW#ws_;E{wTFnMf9fyZN0Q)V(q8sCx+PgOLvZr8=f3%js+r?o}L9p!;Gw3E*#2-*>h zAmqmtL2Q+5ZE4zx`QRk6U!0DHvk~7o;G;aeDUVDUBVpkZ|Bd|@0*qhH)KVKs#eULh z9x%;DcK^|Smb)DQpm#cjE%66n1;Tw#_>+N-*Uq!E@|D@f#c-G zyQr+FE*u(+?vr<70%*tnfJ>rXW1~b4mBr(5Oc|bqNLkv9H9o3k6yJ&cN6ygR3Jk-r zCa%4~4%#z9d-0kUtK#$6RrbsfujYJ}JR2L508>@x@OpLwU_P>=wjSO0&$65Biv&jQ zSbK=wYR@S6qit@E^&9G-ZH<;AztqlPL$)=J9QBzt2h-_G@#nd+bl`6vR!TYsyP~*p zR?A?U*q73s1&`RLWBEudOMsl^O9@!gx6~M4J_??Wo|fk&u{;41PnI>6XHN;f%C=Ro=fLwB=Rz_k_HpdS^$k4hVhoxf^*O^sqhsOT zz8;y?wl#A#E~K*$v&`LkSI20#-reKlw$@PwAnZE!w^`1DYNR80nidi=g27FnjkLXTjs?GvMiHAfCwF0ZYo z&44eX+)k`3&ql`{_5twx^Gta1OijX*a?9~B`y_b2JUb)DPsbR%L?yychYi4I%kk3z z0`NKPUzrULzRt~|HV4CWXPIq{D`)Gl2%np?mChmn<@}tj-NLs}h#l_hHf_$+;ml-L z&vzF5WR6G3JZZ>;&mm;Omu|m*PKI{UD)XZ#e?lh0vxH3evV~0e+=*mTI-S?Bn;`S) zxk4t(QZmUWWRfr4e(zjVT8m8AN+pxRg-r4ZndD0(lb0>$>+BxL{Ny}Ty9;SAqbQ!d z(oI4qitNal3}a&{pCThTJ!g2QS#o8~rmeUg)OcboY}hm=7vdUXzk-lM^Jh@dER~|O zZ(8QhvRA~CQH$buPYZmA;4nNyRO_HOph1*m@uXTqFb zU#HR>@2#}ovUh{`4;L-W>FF73iVmt)N6YC0qQ1XlH^-p0wB=y(y)8Ns9T|;U@%EhI z$iBYr?tauHo~E4P8crDLz^b;Ek^Vy}3S%It9g6le4|VtTU{|n`Ggor0@8}xCj#=6T zhemL|mdky-QR;#s`bbB2-(;~_V0i6IZ(!ep_Qx{+)3lG%yEIPkSx)u}^gglp%;+uO zc4xrqae7kup6KAlloto9TUt|9R@kh^^R{YKMUW;weP9gpz zgdR;KluF{f8g|7ZXTjCk(+QnFd!|BJR&K_8R|28j(DOdeZiLXUt;~|ezYXX3bCdD+ zw`%Ccc5<}zj<}ZI2yhzBcw0<64mNn%%eR1^bLX#uxdyVvL@var3PoPanE$wK&0=KO zJP(xr8drXVn)=vmnqSC14CN25`gbZ%E$S5I327+5;GI(WTXQoO989Do4b-_M%oNAgIcVq=>gJ6&%zL;CpTm69SPFHOVNUR*$befj2<%snU zuxm1$1&^VJoQg8qNnTrxJ`fd?IAug>lFB@0QD)IMh1C}v%FURQom?M$4Y>FKdjO*D zFNmM<;e}3R#*$*5HLAqPN@$&45;H!S>JatJoMPfLOqk`zIFV_CSua;9K5lMM?7*qGa7LL=il#D6&_UlRXSk5BjDTCG2I2 zB7<2{#rq*5YZ9i48!&5_eG{UN6?0LMj$vae)SRAARP%BM#zogaO*IYB;x^{^Xp&xV z{ta7?!V;BS zAq<_0RE1IYEWd}n&+RPuMQK*@lud85oakV5WcPky!G$@Km_emUJlS!hO?^FI$wPsk-qd ze8tu5iq+17+bgCq$&4}^y3LQ#jbbk}bwl}BEOdi!X;R&&19es|`vP?PNM(Y8hyptn z4Gwlk#qqyrHPAD#bUCcHnrT)HO_*Es%ENF!u&n8PD!=lxtHC>ZiF`9JZFa5B+k({qYdR(_KWN;X!Bh4 zOtnd{ikOo^ekHdJ=4@9EvQMsYR)2gG`@MZ#SAXBI&R0K&c+Z8Zl?Q#C*!_PevES}T zoA7x{EIpD&>l;()UjqHLo7p=YYXyJWR000Dvjr=l*wA+}mi_Y}|I%i5okOyhOY;w z{urYJrBLbc64!w}B6MJnq@cq~r=i2wwy+O4*I|Pd4#lSIKyH(H#Yg2aX2W`uI$)c0 z%x;$lYYRZ8QL8@c$7XbVe0G7quC7ughbJl#S02FHN4Nzsv?Dw6zq~=$s{h;1e#W`s z8?HCc?VcL;s?v?_hTzggQd3h-tNv9DyUK;+g&UE+)8z5dT6Qz>xB!VdO%}heWgil1 zoIa0F)v?cUHT>Znr)7&*>e$z%El!ieX9Dbd!V)-o>~yl@&jI#JX@}F~@UeRK8t2fw zEnJtX5?b|7>)F9HDhJKm{46*EO}A0LxtwAF)vEt~KKqM|6;3_Y z$G5U8(y2u4h)iu2;@>)2^>4Sb>(gnQYjbmxKS`$>*oNO59-X`|jwFUG7q-_W^ zo}nJPCu7~ZFy47A3$GtjC}8=bV_BHhb+uLhzKOkS-8vPW`dH%Sv2K8(^Eap^I=wsS zwh6qH)%y}`oIk04pqV{nVPm}F*FC`5&`Z$D=B0QxFA}~ONN6T{g^A0{>~`&!DySFY+;YZMCPfXMDWOPc;uy)$nf*X?ZYEO z-8l0KLngerBtRQOPHLOp)yl5V<2v;XP9)GvDnh!E9#TD}8uWUpm3?>$1B-5w0qG|h zkcz~B)YFtYiFEs7i2Y5lM%R6h$bD`mWu92Aa6L0O-d?yY3m?5wKZm?sL!;!?Hhtv+ zc56OQEN6HsEjdGINes1<21D(nWSCrc6+)MV7#7E*5n24kHuhVg1X(;TWh4@*B8dsh zL9&$H9%k1T7}*$?I${d@bEaf`Rk$bvM4p_n)K$MP!hTc0D{Sn(6tn6UtPoWJ$bCMc+?`tW!`s>28`e{MHoA9Y zOt#M2V^l`P(BzWgRt!6=7JZCqn@;RtKib-r>EDPELf~zX&h9a1<95$#=;}7f145f_XKOF~r#?xo{>L zUp3Fp%_t0Qx_KA7wkSq5EaA%cjtA2U2{p^k8v#*L#j^9n;E208A8<4(wFDZcX7ZJM zp*9fHsy$*=yPcv(2fKNHG+Wzr?_1bcV^tScrD-{shdq)|_fuJQ-qO>x>ZYHzv){)m z#BDjfKBusyInbok|I2LoKW}9p+89#|q%BdQV9KG>GG)bl<5&p( zGU)M&mqHI+--VY$58c!S*Vs7RK50%UX1DLR0+x2WeG+@~@U1Lj?l*j$f>kFvNx*mF zHBJs*;OJN`%1BGk&F~(mez220UB+KD@o6$&HNJAu(WEqKCu7n?y-hVM!+V{0pG=x9 z{C?9*??MXXT{iU+!Y%K6bg|pZ6RT{zqcqs4XU zlW4`$@w`Zf@#5p@czzlqv!OVR(^q94?_o=fk4D4WYHI^wTtH-^@GaZ6W_-`15lFk##Dwu>=C&q(oA!1S7YX32 z(RzQd2`6G{bnO&>=$lv!r?e9MO7TsseI-6!P+y2_b)!jJ06eW`x?5xk3W}rfCzXMZ^q76tk^JLd;PJMKRZk(6o69 zB;xrB(6j~0Yw})bqKJ6WI*n44;Xu;t>2q*TIj+ECOUSc04>#mwBX9}#;Ckw%a}Xr% z%vm-^6P_%>;lOM}&{n8$A3Aeq2@3LN6P`RP=V;{Q%me4((#lylL{xY+&8={yb2V+X z0_Mz_H)k$b=PuxCuBqUT#|ek5zm_~W$&efyxSh>CNLJoL9+002!AKTzuz9xk2H5Ic z6Es!b0+XE=8$ikudW(q`>Jrj#A}vg2Yg$cg0A~Vpt%;UQfUH{yqxn!CGmsAf0ccvi ziQTba=Ys7>WrIK|u#uRlctH~&#m={Y5V2K&n$|=fd-|rirO2G~kYmjzg20v~2&bad zN*>&?u#}fjk)@h;fdDD1+m>-oR4&5gB~L`)aGU2cUYahy)}`TA%bH)+NHLX?s*K@$XlFkUXI1DQu7!Qhgla9`G1e zDIjC-6~K9OHvt$CK=xA7Yg7T6Hde-K@OU*;(zJ=qS{4-Ew}`Dx&va_qRxWn7A41>*#lH*f2Px<2V8=`}Ggu;7hDSj$^3~ z2kzjkd>*))b}rCvxPgx0VLC^3bpJpnKA=NrcV7p<@!??{2s665s;b0S$p4g=m*O;t z4PC?In{kZ#Safm&?$6t>p$BjnpS9AZc^fu#_Tdk@rNiT6o9PY@?64Y$g5wy3<7AL_ ze5Z?;1K!Sd8u!z>ItFw_Lx?od6CD`pj&AN58tID8)`Ejz;f9R{qJv|j=O90PzG!#p z26Q*xgyC?{fv{Uw54Rh^NO81td^fpCQtm7F78m+(-xX+5NIo4gx_Ki{`@W%(J*E%Q zkuTkS6MfxLH@}nCFu>`j${%|(i2#i>b-6bT%`6|fqr;dMm_g=IiHf%hF9zHWh8f%& zT4BG|vA%(5LQ}gp1YxGv;WnY#aie3qE{a#Pw-czi&&cU`2l}X5ersJ; z!K6bMaRPsj$>NX7wS`)@Xxl*VBB1>?ZP0xdQcuxy%`rlx;NAbKEh+1 z{$d5u6>q~0d$o;$+O1Z+aRnsjA);C?fJEII=)rvm`1UnAgDmPA>2V9=rh3)7YNTS^ zIn>uz58i+=Fh0AFf$_op950s8`Q74(M6gFihKteH>^~{kp}p}xfPW=n2Z+Ic_75#E z_^XGdBV3I&2-yx8O{{u&IGS+dq3|>V!h0MrnrP!87;V4txB;VkHTx3^BlSC1!8l}q z^s~ayZ+4{$M|@)Wn1Vr1u)&Wa1HMUxlQ98bYJu^hnbmE9(V3mqWP#@cF15gT7tNwO zVE6-mc=x3L-2yKH{Bs2ZK>E_Z02rj2BZH?W{aqFq=}8Y8^fs*=aE1kj>@=0P+9I2V zyiU8(5`GroRtvleFvN-n^lNY)!w)R*dce0?;AMby3w$a8o3k>;A!`=vo zeCG|8aL9LFWPu^y>9fG#?KH|5;zPdU8A~|iJKke~O8`eK@J7Iy7I+1Uz;`V$?jNup zwZOT6w_D%>z|dJdkdMxd?Y}MXI>1)@VC-$%WeLamR5rvB58|UNFspprfxzBv311EP z0t=iE*qXoSQfk)p)A{Q+Tj&enKa3yB4|^8n2jyEEQ{lP7l2o?jL-kujom@#FUqe|S z_i^cd3)O+(*CqUhba4U(r?bRMm+`oZcynbu4kI3S5s$m5kMk&eljH+FZg(nWsqcqq5rMV^zZ4Vv~{MzFH;6&S-2d^KJN zR{Vn)ClU<3OUQjz=&Ai&x_^~=!`?g{uq$`BN*DEl!+WF){v3v#xO=a3zbf4m(*3D) zQ4WdDhBlhJsGHmkNOx4aXfHYbcIkdmx>8>o$|Hr_QTMouI>X&9($%Gl{N(tf(tWRV zk$)U7^UwZ>fDQXW-X^lomr;btRd)R>#?SC7w>yPwtLO z_uJC_iEtgLPZaJz+sEDg(!Ex?lHMWdU6%>G>u1vavvAW;?VR=gnOiWxpW_r?$gqJLAbNfjuQV_9_en9uFU6IM8g0I3V60m-|R*SUm@L_ zq$|tC?3V>RN7{eRITCJ?F4_;$W6nL&{ep1kI;Fczx*MfCAl)madqTMLq#fpEOSo0K zX#a`-yho+`PvOqrEL~~e`F#>b`6BxHe-rM4dD2}cUB7fuZi#Mzw9kScOZYFsU5NIU z!WZ5k-S12H7s6fCCEdN!m3GBjipR^iO1ig5_czj&dSx~XIP)Uuenz^F33suy!(yL= zuaWNU(v^Ic6bN|9kaV9C?oydgOC|kMnXYBhUduiv=(1${mUU3VQqSdhUr_p&%ksVa zJ_)}p+!ZUOE6dA@?+ExTuXHbw?vv7$^*MWifU~9E*%wQAOu8SCF5VL)pWfx%m3CNp zsf3S6_hI3#LIXi`t2RovUb=14-6dUFPFBhMS%r3t$NQ#qWj?Qx^?TLt1>QYZy7|&A zm+raJjYwC@ad%2sw&U)5B#iea$#YA4y1y#n|B>!rrTd0(S1*)qnRKhAEAwZyl)HLT z;xCu()zW>hbRUxLBhr=WUHu~o|3kRBcIl$Rlb*TR(v|I5u54d(W%WlPU2Y>28v4jdahK?pvh0SGxP8dqBFfoUFN5 z!m?dk^MHiEF5MTT`!ngjEZsi|7nAGU9v)flJ!>SqUb-dHt(UH}i>F({{nC}?+#~C= zN7~2pAsPNj>3&YS(q0~EC(o}X{*Tg?%-bD65cM|w@NoE-3jT+ zd|P{ygr#0#KWm?sbiWjCfz+cw*1LlDNc^{iyI$t+dRczgUn%jjz8AU# zT$m$WY2U)l65c9Z$-nTBgryw|AC>U;q$~5Y@KphCut`_es||G$ZkMjipAGMj@Qu>F zTe{Cm_qW0=l6;D!-HVDOUfR2;MZ%JQ(G3#*uyh}mu52fZej?%D33uZ<>B{tP?3A!< zS2oIew^7=8<6ScRQ^Lg#1YT~v=Suf{;rbRycZGB%oln}&_ic&)g>Z{y`6!n4s`wUx zH~NFeu{HzS(s;&4?(2MfP=r~kBI9)1QLPBaCXRJcyNSnOwsoaS4Fyp8l$`Rmmvl{ z7Vhc{O7O1SM`5~mr0>Fp8ed>fOPMZiT(OXw2UsG)PCt)O)4zRx$;d<~P}ZFw!oXY)L>ETr=dh`PqgGW7{NMkcD(e+Q1G<(9HP{89qr>VHuv*Vm5 zpU)G9FBk{}e4gNT56*iIUs&$BJRI3tyR}Y$6#yHXJgs!7bifm+@mG4<0vA+zLT!O? zr6+(3<0gu=roK*(rwzBgL`TOw9@wnEuhTkhZ^=HH4pmD$qNsR~DXEl|SfhAU(V^(6 zl$|NjMRxJ%N%Lz;t&>^u=2SO}F-cFQ9LFgyZoxE*HL*#hTqk5Bi#hQ~rJTp{pf<(K z$5a}K1Ps&)PZueXN~a>E$s`JO4%OxHfHunQ!57dO6P- zoOZSwv1gp;s=}j)q*CA2t+7O&Lj9i6Ys<_)a8ITF##dNGOQpWX+;)pNsnkz1XAmKk z`bZIs%%C_a^a^DCqqo!P);}5dwCW#^ds_96$27B#>P{;8XH9Q>Ue2)o2@QB1KE3+K z8JM}uo6HpYW!5CbWI1P$dY;dq--(`$uIs)M-6BuNA^V*b73JQpN`%o3_u)o#5mFOn@aF>s zkFVrk)QO7(o0In8M6dE+-g%7aH_mLSJz0+zT z{t|EXNWTr^*BCmi3nZk&{80?uCVush12p)_bSQqAuu1wcgsVr{LfTo;o%IP2L=+KRMb|F;iVkMc>~p8m zvEKn_(Qg&eDE%? zzsip|`>m@)me61T_Ct#5y4e-ar)&KBJB87I<^fsi+=f(4yB(L{v`V4{~ck6 z@KcYH8>e3Zr9Xx8SMVI@KB1VwmHZgxr$xW@#E;4h)i=!9Cev>{>c;FB5w4yj`jtdLt?Ag*4_Mi`0RAL)-gGI}qTL8r zkKz|+=i1vraF-&2tLWm=QMU>ECh8K|)q2%|cfJzeVmL4`9-p^)i%Z9$2*R@PBe`>?q3cKXY>{**I|jeF^d9~M!bpGOH{U|H27XI= z4^w_9Ix24}9dY^{eh6Vozh%?VJq!Kv5KeN>N=|p}-w~$xtx8UJ-C_$J>7GQt>k2J& z)J7$vqx?{E)%%>%A7_{A+JRGcA>PUOb;F#;5l-o)a+rkfW)H&L_z_(xeu{26{C520 zb8{W471qRzN7Y5j8w=fg|Ab;vZcv$ZmJP?yeSq?!Bc9F}sh9YQhBmt0zS7FFs#2e? ztjz89y6F*rvA|JYUha06mKB$la{R@!4+NU(nN6t$&P*d27Q_ddsKWA8;#)55LM{BI zEe*q8I^Hn+xi{{+`Ph=)El1d`OL`9ebLFy} zEoom(dphfI&X%JKjx0R3w3i*5doeq<^iH-?JF@iH+&kvMoqNo6#L-*X>-*~)Z~U{~ zv9kOY?U-Zbxj9?v=V@t2GEPK-7t|bj?y_SGk2v$RA8%RZJ(78+c5K0_^YXM4vyNqg zLuT*(UTx)h6n}ZMzwTJ(Y7M&0>YY52e$08)v2e@Lv?Gg8xQ}Ie(?P2pnce%vqt1%- zThoutGUMFpG~&!A>}_f9b7XzPA3EYVw)kjT&XyyKpZdu$N7exNXXI>oc9wSVecBG+ zj*R;B`bCP1*0JEF+VmH-7w6u(?Beue%b?q`W0Y2QY(6;5KcW5lQrNBLm@8+?i50=K zkgl_lrX{zsRkK!Qq;_W-Q!tVs`J=i^ILwpcw5MLZ zZ~2#BxmD}+_L{nDE6X86%Q^7WpML%2TVeIyS&!ImWh-YLMHPPPFBC)54!rTk8!~?> zTbDlY%Kg_ZcHDnO{kp~TYA>o^w78;nr=xuNVYlX=tY2C?xVVBK_}A4AE1yZXkvS|{kWa2u-RPT^#7}kF|8<{f0d2D zYq7EBMP+!yj^?wgYrV!Uou7fGMoVL9wlsUXBi)(qN>58qPoI@OJAF>t+;n>H#`YFT z$uq$t&#H$lp&o{OYMtf7?)PWzd#Cd%$JO?0Z0~0N%ud^vXJ@|MKW9hg+d0V-;vM5i z{p;~JRY(1?A8cvtOjJ^tR@*0JTAZj<_@Bb(KL2rPVfRyFrhEw({v>4&%3PmXOft=s)L1gjdcvy z3N|EPJGQH{e~$&hHt*`wbvn4?NrXPLb9hqMakj1YitT7**KntxVUa%ki#DSeeMCY6k_>lvo7cF7{{yAcOoDg($6{9{sZP(4v*cH1C$3oW`F64C_{rqBV$V{ihBv>wD2A_D$W*xI*nZmSF~F3xca;A{}s z?dh)dOI?}SuC)|_N0}q#?W5q!DZuG;E#X14TtT>y#A!*~Iw*D)MR1V_aDq%1!8Rt| z-^#)3cs@e~hPDL4>MalMs-09KD*C+xvP6gj!Y8Vg%t_=`k#D22O$QVNsb`pg!e zrzz5l5vEAVZ+#ph&lD;0-5@1De;8IP>->>`uDf&Vqn#N3xr@ENid?)dbe$FuDZuAF zr?~8#vNC}UN9t;U^>Gpo$d7ypSyff)t!m;yfw~5RjQl25skg$Q;D_);c7{mM_#mB< zjc@U>tQ9+})y=kZi=gyD0OF6AX^bZa0j>Qa*jYx#$i(#QXeUDtL z6myq(%e|$=$R0{MjuQ$*^xDuiy|xwKQ18(3RlkTNgX$3!Zmo~d2mYrBi2E4YjgO%r zM1BlSap5&ThmJwSd=MQIVtf)EgPoE@qz~MshUgENJ|lBvg8Xf@je2=lSHxB{vG7_A z!-*q}+nQ_KB~$SJ^3nv#vF2RbmJ$-Gud2*4h2#0Nm^H?O^OhyTA8Hb!=f99p{bX;Y> z+I9`wo~b?h^~WCPp(Hm8Kbo^z0e#sV9rv!&-X6Wzt+Ba$GevDvuqLK@d3{wH%hbuj zC?h&mU)=h`7E6p?tB1GM*W&~L-QC}hwq4gle&kVc-elqaeD|b#%^LT9jV+UCfwj=M z_vhm+U@*&@%!iCXxYke23(iaC%n%D$u7O2fK4LD%xdjrREGlU*o-BU0t~a%|G|#N+KzHK)PSZ@$Yc^iqR6kO^N|bQh<58 zlmbk#ue74HvZTBe=u4#tpiL1~#l|a)%L~Vy4_}M36<%Qkd^C!lYrW8SnukFhTBo&0@TFq0OnX>3&K8`c=HKfLB;sV_!7z&{5)XvjRKLW$*|HAnrmF zjXg#&P)TL8V>Gpvrb)Fs{rxBb-!SOG$kH??DAb((NiLZSh>eh_B^c*XzQb`FV#3t{DEF5gm{gKw@U~Qt7^+z$`h-)n=KSkg!^k0Cs7{>N%w!OB|&n>LkUQz%V z^A8GucIZ<5QGs9}+r>Y#?NB?BCa=nnI2~Rmt5)i@^wPplV}B4Wh_k6A?6Qh(YdK}Cp$4gzk9V6Pb2V*)|x-q(v)M*An zou_GHXq4qhH(|3k6GBj>PUo~=%PQRjp+FFLE34ul$^n7*uyZ(w>?iP}tlAwKH{w3X z&K01H{5U&Lz%uspY>R+p^xrT)=Z2HLapSL&-(bNRS~OaahAu%1($MI9A;QY@LDpdP3CqN1RSI&d=G>B zMl|*+8oHL&5CR5=hBfv&!0q)xfctv-Gf3fZ@P}07s(}8oLo-FkF+D z@9rLQzn!pMz0vOR{wU6U9~tS3j^yQ61KT&+ndhCX=l(<#m$~=#;sZ-}o_8BkdE%tIx3RZj$d8*S%=jK2qf3$|j#&LC8@rks9+Dgkg)z0wVM_K4D``4k#8ck~S=R_AIL`;JnF zbFrvn#FFY5aD1YwA9t}IDqTWt!DfGW>nSYM*W59>$F#~j(%7$*8U_QQ%J7JwRVImz zS^an#d(~crMxiE%1qNu(j{p}Qt5%J#>V`5n7Xq@zZ9!Vv8@UM zja5VJn-+atxeFk1dt~AKpVcHGC3q-7v}U#zzjc%kXuC11A3#UNt2gQmftEm9uogLy zYjdzI)PM2HK8#wkX!g^Do4br&cIZ+}CBW@`2M%@=#o2D!Awec#C=ymmW(Q z5CsT!h87Q}cnuIJ@;(815Se1w3(Pow`r zEdOAopssaWO;dmthAI^M5SG4DV~&2&=opPTs#VSGuuN@p+HsHTVvy`&%NHA7f%A3Jup=; zDTfgqGjF)tMJ=rSn5k-`v0oT|3_*VbptoaG@5FH_V||0f5R-3zVU61w0{VqmWkd_z z(?8TPhD$hc_e-!P7(ovK^8ad(G=YTAgLDs#clJl)2~T1^O~gya>VFw7mT}`nV9a%S zd-RI>T7FOr+2ikwCk7YQw6s!z_=f?@JjJr{l{Td^#3a__TlSt|T!lG0+Sjw6TP{zm zjgx=#X14@HYV+OaA#YJsbTdv55uP&z4J>qg%8oV4U4gb%yoLZiO(5P;Ev;zkV4+gr zo*|q<(E7}?gpk$=xbsSY`W~ktbI@whtDK;zwV}rA&f5^Pto51^#Es|nPF8Yzc}eitqIqybE|NyQcf{3*_ht{+{#@8 z!=-r;Q|QjypP%nuhXmp3El~t0s&}&30M9X^b~h#)Bml?sboBo_QX$SeLbl8- z70IF@6*nRk_@sU&Sqt*Gd=(79?KW`3RSTp44qL?Ks8M23t5iWqAxDj9(EdYG`+r+@ zb{VB`H3}uQ2h(XDM-7EPEfqe)^+?nrk&}{jkEJ@PRx5_U42ND{gkFOk`~@(5rB>}C zCyy&sf&sXFmADO!3{Vxryr60Yrfq0djCh`k4cLAIY{$VD$G}Cq{~ZOEPA{WJR$ddF zKHE(?-f|frlJFrXtxa_HjiqiF86n0lCKK@drjy!GbVr)%e0e>Xo|9c1%UjvqL#t2y z))zGmpT2F08OrM^jHDd7&>bNLCrk##GZ0-Ux|iZT4L-Ktxy&SJw%=QzkY@XX2^MR% zduN-yRMF>e;{EfQDdW1-CIQ6hIeaiIc9%ND7bse4>sT`Szo578;9U`{H#vlzu*qF) zYIm3mP?+}8LY$5d1P);tbx}x=bHq_Bq-Nko&)fF$0YG$Qq_<+Rx08J#hCD`C2Tca^Sv0BYq}25VCw3kfx{79YIzdR~WK<;c z78m<^eAH72l`%2*_-z$aHApIE!o>a6#h!|bpy(53R{y3=E1&WNs*Vtp14w zS92coV>V1=e%wZB;&e2vSnqERHtlq4w*QKcpxGa?*&X&Tn6!Gg9l=v{f zo5UL(FTZanq^}I)6YSjkCN^)>(Vl3`%mX9(4kh&(d(svPx=V_DrM|MNVtoBrR#{b1 zh4S)@jW$0CWg>pecj&Zh#$AR}x7f3mFo@N|jluc|Mv1sE%IzcZ-?I|<$`paGToHWV zCYPINMm?TI6*&CBCWT_LmFC+hb>2ySjxA;Zo{JCV$*e@keyq;vr5=xwobq zL-SwS_!4g^WdIfp!@=e{ECSOWb=thn*Mrrvt;X)MiwxS2kf&v<0icmy&%!okiYvG8BmKPT*--z+JT_vrx zzCIi?j#KEnAPsG8tcm1dyS=Xve~Rf(36g@&G{quI z=JU{eHzvx_K}C8LUX;9gJT!YA7onI(5Zq$o5WVQ@!X!@#4I(wCtAWWakp}0U>rS8n zNvC-E)U*5&j{i6QUSAh>?(U^h*xvIN}i1kNr0)U zb9g-RU*uy>mo`0SRPoAkscv5aT9%i2e z&zEOs#sXOClPr zO=iq&EtBGvObRKP6pAKO`j-1saT8?TF$v9XBdujr?kOAHPUu9LT^T!@u&`84krD36 z2yL-Ems>V1#cid|6Ys)8mNBJ}m_G4m2sv-^1RTxQDB6N!GJjee1oJ;lh&lDHsv1UR zjysW&66+J6fcgHU321I>BBL{>E-&^Xadr~gU-Cql)9veUn&Z9|`-su^omdsDrK>elu_teB-$aOeal8<{dBJEe9g;_q+m2<|Mj z97eW2&l>Rzw7)9#zfJoHy^A9Bj&qBH(EGsDqoX(9?T&)gBlNc0o7_C^Ct`0h8tC-@ za=q>LCcWc_#5bY$uV+j>Dqb%8oTK688GXHhwq4xtWFN{mny4->`^bbm@lzD#`kDXt ziejr3Rg{m#3nUpeDjzMs1K@M@ZzE4~HgchC7x zDo;J?2<3@rDxY*VD}QxnO49CV%2Rbuenaeo@&~-pl~*mld{?3NUzd5;HEkXwz!!xUrCGX^ZaS*)k%}mQ!uh|$G>)R~LI5O1xI;`B(qfISEJsH6P zEBXd_7$Ie%z>U(;rYw(A(Bx)W(2n-O$bKpLNpWt9JLh4HkjJBp@v&^J<`{_FBtjYG zO{~nrHf5$frmUWHUS>*yCyGLHbUEcD@k1!|o2+pvL=QP;9jHNBxI#2cGp&=d$)-@s zNlKx~k7uUDT@_6s>N=O zWwi`oW0pg@c50Ql1Tx-&j9SZ9A*>w@gx|ZyYcKWa)Ym=IWU04_>yL5gJexfMQDd4d zx+t>T)T!b&hs-QJLj@RkuyJGLU|x)3bh=<;@*z4HzA?0+465$ ztZ9DnOGxV{&F6HmiX;;ITN915f|6cnq9BI1FdyvL=ZLX!*-mfOoGuw$v$$%HRA3Jch2JlV~S$) zn4-9Cn4$3e-M{9W*Jws|}pr@L8=;b!%_-K+|asI8iXO27PoF!8uZ&ns(zE|1n!6P}-+#zn7 zVO=7lOYU)N=(xh$_N>`pVQa9O!&)Or-n(NNFZs`~%nNVdzx5;6;QSM|*H~7a? zr5i%iN7ao6P{(A7A49iWmql?zIP74crne&?x3{I)FpLarLk_zwW%I%=3YCHG)?Iqw z44b0SC{jv#Ho2&rO-q-S+E9uRxxxpVGcK2e>b*6-nU8dV!vd+Ckh zQfTwoiV12Hy+;2PZK%G|UlKP!o99X=s!f!)h#BLkuhDITIosL2;*NRl(%V;xx19^x zyMrOWeEZoaM=sQ?vM|O8U;pi$WopsVH-v{*_^p@VhwmK+D3a9Hb8l{(%VKF*BK0C3j zvT~U&jx5wpV9_`4E@~`aBjnY4qiB}{ye8csxbGxZrysvem6AzTFC!m~B z`sZ?SP7I3Iv=-$%LLRqOh|7t`i73<&vUs~f+^p0%avtBU6hD+|lr?QWB3m4+6hCKM z93hAASBYnoC9w6_kyOXus>Gkz4oAr0+tuO&$)RpTQ{{M-FiKyp7Q17~59&6QO(5G9 zYs3YySe!_$Llrn(Hi~p^9O?EZM~<0}zUuKc;!2qbbv^D(|Fc%yq!g?zV^LdF`?K1i z!Uu+WY^$VIi!@4~SS#){^N(hiu^3!fBOYJ|qZ@WC22a+AC$t8&T!diMBH(MJ$RY$` zw~J2@zqJ@}879Qx;ShW_ODJ%@ z(P0zw%#@hM(zk2Hg$oww>@>zwH;)B9lwICIZQ1GGfl~|UrmXLmVB`LM>D_hWej6L} z7Qf(b$%bx%b~dj^vU#1@d|~AWb>jA8=aV-0u(*G_dOnlIsKJ@K(7vV(!10ApO=~yi z$~fE>z&aRX3`j*{K83o98OPD{xUS`tI!W0Rrr zF*6)pcO65gUzirhq!C&C(nj%?Qi3cVQ8E&VQjx@{elS|eu4@u|bIfXtC>=3{{UuW} zzIHCE097YPt#qZ=G>bQKWP=S~mtr;DoLQ>rhK;7F<;utK7WE9?qSn{6?2=F9ExX_z zBCW-~)P~1$=`GfJ8*1}+lwP?(+_Xrx`EU)a)(_89Yjnsg`aYvq_}CjV`U5D18YDFc zC@;l{BrE4j}{mAl0#{plugW8Na_&jwEEALQQIc$j=tJ{G`(>+#rOx9G#d zSb1Qxcrj0^+aBz1A3|5SsUMpU==PnSP2}>S&Q2_tQTK*gII!o19h9mb?^XhM-jSn@ zHkk;ke-WR%aR3MK@V%tJT@vLe!8&?J5C2QP`{ArQY5I{`b>+(~;_YySq%FtR=P@qA`V{<|xG;1^GY>!nOOmRg6iXdf&o3-#}`Xz8Jo z#l^+)wh+1O&$=-bd|BNXHj_GOTkQRYZD7}eZ6V~%ptC^T6gufpDcl@7>Fg;$bK!8y zPHRFjy=9jjvGv<6JFzwo-^wEAE;H1oShZo01bQ28;{Snp7s^jQNR8%$Ls3MDmZ`n4~;d>rGwkWD^G|sSMYOB_-!9Gli{w0g9Hb<|) z87R#aYmL*b2<+yA9f6F~EJ_o;%-m30)@XduqBU3HtI_JRnp*6LWt@u7OXNl0#NyUq zV1~(9if>|_v+?Pwj4_OE`F&06;lBTw_(5tkSl|zONPbL=+TZTu@b7v4FP;-}sp3IT~*`W+8M?TAS>!T+B5VCxJW{h!dxnPOHIDT&^r5A>p_LCr?? zBptMPCtD;+JY|7FB}#FjXiiT8&f`v{AO)soY+iaSf+iW|35OFQhIHClYCeMOrhR2&EQ5WyG^|ILR%ZoVwpv>F~Onl<>3*M3CI-|nVEoCIU7dv!5>pl4^;{=jB1OzIcZDMCX{lG zB58CjG1K{KEQAz0!G=P_I)xfWEd`vOm5D{Doa0erbrylp_0tefu2fF}oU1ThdZ?;W z!#Gi)RMm|$Bq#EVCJIuZSp5()gZ=SkD$2uFbfZA04#j#6-6 zNkL(*4@X=f%{WR=yNa$_EQ`LQuYbE0LUvS3M{qdU5%5y2S>-?SQk8|D(yUOkOzqyh zzKK;sM<9fmfC~c z(}^Px@VRSX0#(%B-|1Dx9q(vZ_fg?6VW$np9WV^Xr}kkuKC(|3!u!0tI1l0W{OA%B zf;N6=;t6;PQ# zn4$chKLLYkhATyu*K?l@M|nNFfy--(!&nX+&#ESlo3#fzm^kV>_GufAo;~(b8=e8Y z-iBuahZ^bv{{^V>-`H^MIURGY4W9+vZ^LtdYkxA3AM)Lw*y17I{jd#(eD_yuIOMxc zdn);EpDiBp-LQeW5D)pTU)ylVcYW1{mjI_DljViN!$g0qV_=bL;h6=9R6nv;wP_6Wm$^ji~0v+BSzZPZm(eY z7{iwo6!2e)7kikFKEg|!egqZ4@J|^(#ITN`EnghxlMwkPaXyJ7pM=OK z;W9khQv6Eh13Zaw8DD@0RKkn!=t>ZB<`LY72T+0!;VCtOF4KW7;Ujo}MZ7>?N4Q8} zn1p9p!e`)llOX&;;tTNLNjQ8_;_v~9qpeE32G5!l5B(($|B&(Udx>{59%B3~#{Y-m zWel%pcoV0)llk7w`2CDO%J7#=e}VDeGyax>4%mg{J77l%p@)QLFuYPh1OBM(n1=KQ z?3+ap_RS!u?Ryr+TZHey^QfJE51uIrzYo(`1fN#=7=L8=5$lJ(P}&LnC0xf4_LBH^ zhTt!8_`QU;Fno~V0fsL#g#S@G2YgmS)RTl&3cS=R_YOA=;*d zs~P$kp33kNhOnbd_Z^0?gT(hMXxb0*R+D{xVi?N^YPCSM-=y82(Mc*y9;CFy#7+ zy@T<;E9l|+_cSx!$?!`Ix&3&4#rW?Oj6?rR`o*DdmT)CQuIIRm8GnqS&iB5;&YV0+E@wn~@A{ae~@##zsq6$+op{ypnJ4%g2d^kXvLV+^^T=WzR;^R}XU6B#aKSi#cJ>$$j|0|4ti{Vch zazB~>d&d8w;Nk@gx%`XU80UUvF}J(LZ0E%{aQt@_#A*lWw*|*BJV8O<6o#`HaylQ| z&-Y8Fzp7v%`$r+StHLW3-5d|@!@C^VmY!pZ3BD(v3-U2NmT&H)J7DBvi^jp$Hoz_& z!n}39oR;;6hT3{td$3(rzD2`QfS!PzKx@_PI5wv4Q#dA@2f=t(j}*|Zrjw0)nta8C zv%d?gt*|sq?Ge4LKa|f>TibBX=y3kF{=T75exbjthjxhdcejPQ*3}Gd4`dbkiBM2r z%W0p_ZAYH%n`k>@fBo_khj%ob(!aB{-Jc~lIF87pUST7{j;><=ha0MjJECOh83+zw&Q;C7=XW97wqcpAYx%n7+U^}azQSdr zWrMle+hv}rS~{k}Ka_Ps>#4!U9sNU{{wm@UUX%{ZB+KN>*2v_8gT>{WdfKXn3$Vki zN*-2sTrkY=hmrGr2ID=n(;B&n@-w_AF@pKZ5y(yYdi~wqetcdvAYE^Gpv$j(34TE* zJd6}lAY+S;so+T6M-tE#+gSyp4!iOaGY8mpR?WmVzey5T~j zHrSSx)reDP0t16tS+HVvu+9E1!B(MMGTnl*l=Ebvn#SWj;bzLx&P3VA<4q&7s|u9a zN3FpT?T{mXP&a#|j=*`3$O~j%tJD+lUYYZV>tE%L=;bC@`8FO$R`Zg<5m&pJd%|_D z8$4WOJndbdUQ5Zx(Y_~iBeN?BO5HTjizu&jSZ&S|S?k@-wwzuP)5XAW#t2Q>R z#duV{;GC-Oa4tG!RDH}Q3rzgatQiwAAyDqJ}0(_08eaDht1&9LO))N&{B;PU;}h^ zarIDd`(O|!=(dEd4#KB69pKg4jio*K+7F+g4H{*5nq1o&Xl)D17ls+`3cV!Bh)IkS zQ^Zuq46O8@iQSv=PRQvtDhl%pmSd;8St7$hv_!f#93b)cH9MmJssXVL`#P?)8Xk>0>vDJfHLZBWMmVdQTYJur6g3cBALwWV3 z<0AMuF+VUKey;1mC>lS^bK2#)J^@~-h1%jG(z!9uF|KrHA>HOE{36QXegSEoIDER8 zTVTUGqoj+lU))BdX&y(qZ=?8kk4)#l{E^)*37?1DjwtDNho_sgA9Z)#$aDtg3GMu* zfS-{$GM!@^Xg2?wvKu)0%S!yb_-X&!f-rnSyV(@X&&hZId1-&)dNb4Air5BDLx9sc zauBx5{TMjr+@xI0xtel!BW#nK0^K}Ufu=7lm+M2zopl2eM5_<>12Y}kn=?@}17v>U zLxgSmWl$2WALd?1(=P*Q98?y4jiTRNvhiA-2vDbs&~Gkm=ZxZ~0`rS@{pP0w*ZLJ8 ztm|zz!r-mTJ3kkA7JmBDawF_FA99V0bs|8WE<(TgFCp%sk?G_*6Px`Od=qK3em;ap z(Qg5@jhFD#mzEo$-?5h=!38=IpiUQ|U$z%<`|#5jrxShNp2%z`Xun#K1{P~{B0x?j2-@sidNOcrXUwUOR*upT z){1!%uP-e(q8#NHBf$+i5ui>NQI3iNd_PecB^~C&?fMN50@wQGAv}tmhtEb_B7XYP zawGH`CjCM>5ui>Np&wpv8OCQ((&0UYUB4ZahWd_`_~BiZsb56@yc2r6zlnH#X}NeW zW9oq5>9^t!l~G?hd@2Y!4}zzE2gz>GiEMHG2x})m@GO*HrX%0?;z#_*o?ZCG;m6mW zzaUV6AC<$2AEl#mZN|@*?%Z_XIvtIDbh@<>>B#PspZLY%r_)99BfT^~O0UyJ@;e)G znjh(-(=A2VuHOZ~seB|i9>3AjU1v*|Fh;uX*wQ81(nXfze#E8WM{*~Pk?v_!V>YLo zY)cnW-t#^~oGvewN0)HJ#+9+R{bX<$Tgz+hw{fT|_y~Pe+_C$E-2Z71_!` zH)E|w1i!s4Hh!67q#LxQTQEjCs$Z=ijaf#M`%POq-LH{7BkZ^Le$cd?^*Dm?$Z|Xc zv+o0)?5xK_QPN#@HsZaUj_N?`HxprMSA1Ot{Tz>J3{Y^G`es|YD|@ky@{3W@iBMR& zo8Ca0w#amg3kwPhyw>F_T2{Qg$mc6A_Iedv{l)8_l9Cdyw`lqDk|LS>80mNl$%P-MZWJOUG4HE{{8}{Hj^Al4q4YBd&6##a-jMe%5sf#+_;B zThim!rmM@Zf~Na2&Uorwuc`ol=hQhwOsA~>)}7OSa&V-#{P{KG zqAj=VUma2JtDpMYYmTmLWwVFG>^#)pN3UfV=WhAy{@oFluR+?ft^&62LX!D&F}nm7 zd;hh-YlnXO;1zolMpHO8kglkn9! zpu9{Ik*P2t6=>0)61CvY683gMb)o8m0p~uanB~Ca4DtE@?JZ}Wl|khV3BjXm@Bg*g z+bDpWA9Bif1B(oC+T@f;7y`zMSVyeWS4;KdmCTQw6fG4XS>gF?Qx##xJZwij zcoB-xZ)~iJ(gQNZE!ZRn&mUnh_QPPP30qlVEbTZG=uN>;CAR2cH2!wPw&N?{_O2Sa zt1YF8zba_$a)pEf&xUc|*~%Meb575}7JW8}q_l+O7P*cyTS9UdZO55gLv312?7J;; z?=DVhZmkX6_{Y``+IhQ)PNe}(!eSR}4Lej8v+B3B(5_gvO?S2qwuUNT7tZ3mwWY0l zyGg)D#yB=bMlRl}BJidQ8$Z+cNUof%p`CtzA#Hi{H=r}Nl5!x>{(3}kZ85Wyfb%q@)IwZ*ST7vw0D%>zl>>#ayKot8JFLWR}RKsz_G7=I~5Xo(DrY? zHn!>wxJZKGct&gf^Qj3aM~^ zF{-b`!-kI@?sFmGEOEYY_JME-s`5Mv+CjduKf z8#58_QQ!kaCL>UYJFoi>6i7ti2@1?W;9dyDlV;&u2!&wBb>bQ+wD5RDo&)ZM>k&8+ z+zU6-p8%1DK$=Z~(^2nlKxpA!gCeh`;H@OT@W+V3o^VFtJ_H`8z>^4ENrB%Xa1sTu z%GI^XsJ;SE@FZX0?SSK-;tHpOSVO*ehUJSJN5~gFEMF|AxV9HE^b2P zq?qaW>!chU|61-$L_3{VH>vcmngSaM7{a->PI z#5`6N07?LpIj(FbtzwoEFXwxUNMF$1&P$p}6l9+s;{$Y0N6-_~3Su^Xt6A5W89;~? zS?r=k$m;w%GJ@5Q79l&(N1Nv`HlO6D$7BG+#mprnLK(O7XG$3e1Vg9uVXaQA^CwCj zH`J-1tkWUS6LTf2Q|6AP(z!_;x5F711DQy$cM;;H8X$hyJd=r3K*E*Qd!eYTB&}LB zJ2{*OZFYicSF>u)H!n$vJ-}TVjMbcPte{ zR>Bp{sWB^<)zgc{$T0(!-rqbkrj`;rZ(THJbmmA3{r}oLC#Kdd;292~_qw9i=`dWU z8&_N*L+FSM$LU!JV^r$E&ReIyPV{d4dJ!>ILc@uzVPpgX28IkW0_o)CSdB#GhS;D` z`s-M&NX-cIL?;ZI)u>))zAKE@G zMn1|5&QM8nrXc5`Am_2^tn)Nj2@%wnjzxE+IZ}{0Qjj?!s4tlZiZxn!C`fr;S5(de zs=l&@C;0%D!miG`&5HGIM*Cax7|0b3{-lq#$!dP+#;Nv?!64r}I#i67#!Nm2w_?m9iYvn9f7>$O=)A z^Vq9&IufIuU9uK18^6^YRwh?;loVB{!jB>RtO_${NoUqFtjl0vJc4IDVeOU%zxmCJc-m20pZsymiLHOdN6 zkn`9oSLbQA@*t@5P>}Ob0)3Suu-*`MHkFEGFZD8zR)?puNa)cG$7v&D(S)g5D0Vo! zS~xG6nDa&ogGyvfjEOOx+sL0MUjXuibQl#B%+HV5nU9C{25F>V>x{9R6@-{QZjabj?smbF}jcv z*~f*H$g4o!(X8JG@}Vw|EIaL|9d%3hxF^-a~ZlJrvg7gRtp66xMw(g;lv_ zUK-BGKA7mL)RJy`8|YjzMc3X&bX6`z-v@j@>jO39rFADn>rUa__>t}u*1A(z>yDtQ zJB79G6xO;^SnEz z{SjwgDdAlc(I>0kSX-h4By9-_@5YZTL1AqP3TsOsY+8cC+7cAjmY}e<1ckLFD6B1k zuxSYjt1e5*H7!AOZ3zl%OHgzltAOg2LJo2!~y(!-hUG3WMVY1hgeu5Z0EU z@NWFb5){^!ps=rEdbTliXVW2twHY zawNt~YVI%>MjcT^ln+^0Lrl$BA+vJ0KxK^;YyBlnex2A(CKh-?AfHf%k%^nvZm28w zE*U{D!|VK!smmzOlEQFfH8j>&*VI-;3azdxYsSXZ{!yP|@VCSr0PAu45L1T|+%>_ONL>9NA}v z>l@HsYMQEKv*FaB;h3Yc+FE~EQ&UxAvqe@(YpXU^)v^W2nW`HkJM6selI?RoW(DNs zP6zlj$_oP(O@A@BXQX1mywfw^W9mrEjL7}pKOEL^;5&ciN|6pQ~VYFrVZ8A*b33_?d~?jbico$4Aw2o z-kG~=p?9Zu-aPLv>|@1bMYW~z?pla3p~)~Jbicp0e*GHyd997P#XKBR)m#b2{>rL~+9t2znD6(KY1TIxB3B1t zv;m}9=C7++@6E%f(uNoWj*p8aVM*cA5|D;Kg0~PU`%48omv*WP$`2z3M{ZM$Svq?X zPT7g1yOf-=&0b$2`p{EZ3~-VH$`@G*D22YFrA5n@loWw{8jAqg60y9naLJOTg#}AW zmK7H*U0S@XU@1hLL54(Gh(mF)A$AKQP+>qRDK1_D+L@9@r2(y|aCy=4lBI>qi-!zx zmW-j&NKs~`_?8tFl`Jhn&%b18!Sdo_Ux}|6!p;@o?XRtZtJuwVo<)wZ;`vrgbYt$d z5{%QP7g{+~v88D*vZ!2kw(wW12sVJ-&=*^=rV*6wE3%{8`%-B!(+1k?m)XeS#=qPa z6Rirau*I7?9Ihg+m3mj3^gn57w5iSEs_8B&07gWz zvp`T;+YtAfbm+)*oGK~yNf|N&B8a=v#1Ict4m48kcFeBU)-~yVr@I>-@Ti#{jBH(V z6sMNypOBKJfba~_dV(RD9Et3|;gs?`)nD1x=+F^L}SB-)J_ltiMo1k_yP2T622pv8p zt1k0b&`k?JJm3)l&SX*kK@`-QMfoRD;4+e8b?20Qw}XmeGL-i`kk6E4i>;=gCFvG( zP5-i_TOv%iBpG`g5J45o@=e!~H+fl;=gRz}rjga{xC^VdWI+ta4-nM%Uqg+2=(_|b zMktjd-hW2y2aTa=MMX<_u$LB)1bf@NhdKgyywRVr%VALrzh}WdfyC2rC69-R$)e&2 zH!3fSTsuRu>2iq}e$r|0YV9}ha%`XrpFLvDf?Oqn)k@YN#3elDa}lSGH3>SKMWN>- zm&d{_Mh%Es=BG32_KIa*!r%~uUM-eO6n;SHO=5*aQT>G8CQ7{xLuTH4#BmDc%)b!F zE1YvbFIFp@v%ewABsZLDh6N8={u&$2)MBlTXzEg9BbpkWphVbt-XrSlL{q!^(M&ZrSu|72%`C*?_q;gCMq`FJjmSncRs5WdXlnR* zDF#opTvGv+NE4nHoiYIqR_D6=!dzK*n(&6$K3BP*dS0OQ;k4fV73}1OD_$vj2dxm&H5@3g1z*awjoMs*j(0(KAEEi z23rS%?Y0!h`Tgtb@m)F|@@UZ85oqro2nE`+d$HDXaHzi*-AoyV^i5TjBuDSdgC~LP zp@BdLjrg%;`=+Y0b&=6K0FCPJ<4+cC>P zPEF?a<}5@UWj-l=V&b;gI4+i?P7nXt=9B9if*jX*Z(Ndi5-O+_(7QER78&Klw!L;)5 zOgkpT^fqEzcUVn3dM2Xj55W{08K8vt8r={t5?bF#XkWh}UISXbuAw=5xV3vIKy`uMh1dke46 zjLaCG?Wo;Sj>>Y((tirki{`&AFo@ZZ_05g-weq_ivBf&4GZ{U`7O{oQzpbLLcd);& zTP@qe1n9~iImD@WQBqEHu`+?uqroV> z!zsS1vz8q$t4v^KecdUp*I9QSF6(AWU}pWkOMF{rZD?v3Q{RUEzIGhF(lm(vrhz;W zJJe}LD?f3GduW=3Y$h2gdkyx5>N_c;%w;IEjm4;RpIhwL8r2;}qq^2$Z*+C`#E2)g zI+BY`9WxiJW8#s8D*Z)_ctPvZ&{$Jf)`T4$Ws#%TXhVOnu61C$WtB5y#hEsjgE|Bei_jvn}@r*$Aw+7aZWi*^M$EBDX4DVG) zZ9UdC_Kl}MvT^?J>XJ|rTvVXB_+{cZkLm$^H|FE3XrkP|*1x7|eN|&k1!^MG;S#H9 z{8GSU82z@Pu8bz!yv200!;oTRf~F1Sh?h6R@+k3M8ZeB^CE2cA>GhRtSm-^Cv>G9q z7(*!LFZCM)zUN|;K`#&F=%!$U;XFlq5Pefl&nKs&*wNNzM&444arzJjRsQy#g8Z)N z-edCtvbSE7cK>1g$Kv|m=sC)F=A%3d@H>`#XBs-&LE4^1&U2&drEzZ5dG0id!ZwYl zS954eL$<*#oY;dpJ%$FjjW|`)oEM&rTIP9SjG0vs)5S~IZ>YuFuw?`=XCNPK|JCPO zDuJp>tF7P4bv4fCT4r(7>J1i_SLA7z4fIk@K8frVx%8Yt7x~yi{BrPHgkLVz4J=A) zhGorQGJe#WL5=8%0{cXL!C@+_h~woOJG`)qTCbpnJ!)X|jw9Fn*_o|$0#>GcLcqh% z+OmyRQi;m?4dt~}^h#%`X5WC9R^wxianZmaJ#&=mywwd=n=7gs@YG;BUzj>(jW%X9+!x%>^XBYaY+Gc)aGN&7I7A~O2A47bBs)1vD-bLQ*$RtR! z9j2-ol|#QDGjDj~sb8$TD0H(i#H(i5Ylt_1bhQrn=@_`dU@tMmF673>kdRF{223TD&J_V{w{E+t`|1~ zbFQnP)4#O3LT*<}_V`T5!r+kJ_4VWs|1fc`Q@rr~vO}v3G0`=7+}Rmw?`|C!2zKt0 zmdjRewJE%6m6s7!+J)ZZQMYgvzm=zx60R6Q1{FF!<;2^?tyPWnxD5gQ6`{CCt*=K{ z2MZN}_G_YP0==Jknh0#2DsT1@ke-og$Q<;x=zW=>wth`{fj2uZ?6uYhW|TCZw_xWo zX|Dp3{*f~{fKv>EgMsmvQ|AaPr6#H}9s=8Kc<{qWTfJh;&K}c*3l?~FJl;}{FfrMf z?*G!t?LDEQY>3JAX75_K(7ONy!m;DZ1t@F5&O#GiVP@-?KsMOre3w}OYz^Gn{hug> z+I1P#GO<#OmJOx26s5opd=sf!B#)?9#Q@x{1veZyIq;vbMMRC79*b6`9bp_bYG#A> zH?#KtvFdC$y>Kp^lKO+OG>=FPg}=uNALVwWT9K+rX5DFPPP*3$OJK!AuX~|aZ>zik zjNPbpzbKPOIF(`mZVwW-KAa?qCWd)I-3yG_(drzLJT)7zeH3hmz!#g*2Ri-}4oiEe z)5VR~LdULlE1m4QOcX`9*-h^z+Jb}QHw|rpKpW+Hy8zcjh*aJ9DnLnHU_f7!*!Gbgmj+s{1tfIQ|l26~S=4ZNnO{ za?nBx4aY6<)+kkt`D^9)ynMuS-S{5hY+uuRMxD~2l1suRc#)biCB?Y*6!`!U=$A&+p%9o7(|V7^P1+#HEorbcRc!W!UY+SEi;2x)tfw z9`Swmyw29P0ekw+Fi%4|zC?vybLgT~!oL~ODnWcFvNhtVo}W7OcpRz3i8`5VQ6TKL z5h%fTHEwffT0Sj4h!O$118){-EUxbCM8JcnNg(`26PGt-V&?c=I1MDHn*8ybZUWL8 zm5ND}Xosq5guc#|iQpsJ_LSmNjgTDIVr60keuo1 zPrY!p<}ttRz(nTl4l0vON7IVcWpy>RTfBzj|3zjnocBANF6U1iE|+-3QCU^nT;@M< zi4PBWJ8?(H&F@i7^cCaz1S|I*!{UufTFs1^c~I2YVM(P z1iliT;8_R1ZlW3WNEXY%;WrKzikGc4-$tb?*eOrb!7RXYk+HIv%MkMil(S(27T>CT z$WvZYP+o#Z^FKM{E8Zfi0K7D8s;R5QOJG`EPRq{a`(XXr)(|&1RRwKWAN5^yuYMbS zBd0TGWWpv`TDy0&?i%2E7Z_}ps>~cYBeGah9$_gZMVfz3Hf%zx54;fy{V$R>tXo^&oQ?J1zFhn% zq(4hg6bz;*7g=(lj9uu(L^%eiD37Kq&#T5ov*!^R3S|bxEi4bES7Tk69aQOZxeBFjIlO1~_s zxoDUluI#W+a`%;tNUu#5kschNO<_?)dX<{^qhNO}#c@f4W$o?$C51atkJ|%*5I|#g zYpz_)-RfQC%{~PUevqD=aGg@Jgu<0E-Jn?WKbQ+&=!Joi(h&DZ zVNF9g{pkpW<&9t1eNx!?Bypjn{-dk^KvY{D#9BdK*5=K2eT9^tF7@V!Z_^Gs;SqtD49HTaQhO1T`lPM>@Bs+BNqiFL&iPGDgfOwiE-ac^!i9+yhY?2Bawds$ z;@vslkCoQ4N){n3n!QFZhP0XUH1QR1-s|y@%^Lf5s1+bJR0t3%`npYmBO_Ev=ar;5 zNRF}(`iK7DPRj)q&u7I&3GSTVPlTuI^TZPlQzjK2!580HrMPm$)!=(i+yrzLRNK*Y zmDT7vOMC-7_r_0vr>xXbcv5Y-o)ve1=a~s98D+G8m~_7~+I$QlM@AWKZibM{`Aj?l zIGZJd`W!sHyK5cuVlvi+RD5E_I@&W0DJN&FqkYs6N>*Y+!4AvjvK;Olv1hV7=YxbS zDN`g-1(Hk(xui@Ad7O_XfMl1s5B?`*Qhb_}NuhKplS1BTGO3*I>&0b|`9>nkTx`lj zh-D(=asDJRMJ%?-j43i@BA#U;#4-_zCR6%WOp3S(G9Q|RX19@+I4bv)jcz9u7nxld zJDafHRL-0c?#T#ku{@VsHm%TYrOp$t$U>Gem5@E+&k*wU$rEu3t5LKC$7KGNI0)vS zO^7-5uBsYFWsW^Rj2zFwzu;dCkiOjXSwS5o^X=!mBsFRIM8Iqk+ zI~4Kvw{`?~7FrG?Tc79i;u&cFz106U?IZLqiqJbQT^xkouT4EVdh^}xC|Es0Z@az8 z&EuXHdy~;Xr~jAhZMQe+9e;uNCiH%D#?+(Y+G`u{cuQ$-PiyNNoL-|G%)#YU$ znNTTyilY2*=KsB-*lI-J<23Czzy^5NlU3mQN0nmtZjo`y5C4N z@FwR_X3C_6Q)K^vkk9gIYs607YT^sxU5LN+m@&nFhwf|P9opF9MG}PG8cis9;-oF& ztSRoCucePAbn@H@3tgO%E2A(vTynpMCUac}mPw$H8 z>CFhY*^M`b_2XcJn?2tJ$|QGrD@Zhn(gTJRq9oN!~`~$xKQ7VU)5+FG~7}cmZYEKQ}F-i5}ilCeNpV zrz%5Zb#=2Y1bDJ5NUD5pnX1MjvVQ4%G^>&&@8t8vLGV71nU=9$voSK(w^^2PWT@A8 zw81lvHnkM>WCRDS=o{c+gp`Q_H%dpF(h#Mf$=hW?JK6^$`=#VRiE~rjIWJ;_JT7ID zWNS6YK;$M7$|!GQWnQ!?Gv#Gv^`x(7rXXU070y9CcLpq%kYl@)%fzQMG3s3~P8mE1Vi~d$#*{(LGv#Bk zXO=tXnq$W+11$!311$sCnB|bJo!TNUfsC`V6EkWpTZOQsG!TC8!gKz(?4=%^`npG& zEOno_{up=8+Y=ErrrDy4BFjx(ByNMK=N3+&R6J~oZoR0YqyeX1A?}8#M{^=)e5BLq z%9w_y2HSicH$waLlA7_sREKJ3))bSRVZ!7;CI@lr@yjMRO^934-8r`}ik$fg6Ursh z)kY{ggvGtRwIcuth0T_K%VJF%7Qcjq3v-W-gaJHH2l}E4dQSWXf<7EukempzJdn_F z6@?~p~a$fC&SNL@qR320+Q^a5~ae4-oK2~7Wn*f-mqb65VDoY{vp=ZLmH zk~2B*^nZxQ!1;p3V{=vw-sEgmF!fv`ILnHiu}M4)&L1s~^w((C*sfVib7X{u?Kn@F z1fz+PedLVqi@P)2IjWwisH6miXwbWQDm>Qbn#P&`lWAdQOaJHC^DF>RB{}m zy5*>)k_JpWS3Cw$-z$`&?6(wadOljq%jg+WLjyh4)I;yQ2h=3J;{2YtXO27Px+PP` znE1!t$<~pmdLhnqTg6Q?tV_Ybm!H_W?ZRZ`%&Zl!LD>04V+iA_(Uq=hMiv8uit!4g z>X~`3xW?|nq;qXfMMMh3Q< zrrnmZd0}&fN;>>R51ipQXf%qHl72k7sGLnpm%};gxcFp-@Wye>Gh)v?ch0YuPgJL< z^?P`oM%6~vUV2bm3T<9qF+pvj*XX~Z4b@lrN8$!(^ViaeY7^xxV#YY?YjoRS&UW@W z;*NRl()}yN+s*~;-NBGwzWwZzBNw#Vq%4ea!j=W%&4W?;-b#G+5}qDKqke5fdb}Mm zN^e{x&UDRJ{AsNP_%Eg82a!A}jJR1aIl09?B0aG`^Eh#ZYXL3vkV7wU z7ITy$#6N5mp_qg8=NvEYcP*qh#j<-)g{4WJEtEdkYhO3$a#-%G9Ez zZwL>sBB^CC&=bPD4B2e9VC$ZafINIiAj~vcjE9*ge%E1?p1)fBHB1L8A?siqk~)az zl@8+h!|PxiIszSDSS`NcUVwF1O=bAb9OY2ep}sW_H(Qcu!R@N9RTV3}r8lsx4oZ^3 z>AH+Y>8)j0qmFOVPAsde#Qxi=IP&jKV} zDSjx`C~Mk$M7B7$O8lH{afBQmsS?j9OJGN`BdLzP)#6WVha=?hV72%_a;V$TR5@NH zjM9&*#qL=0gSri66UcVQ8gW4^)+|!%Pz6qxjUt^JN4mYqk$a}2uX<&TxKd_9U5`7{ zO>4zXO2OJP7PUpSKdT)od|;@@ws=~#NTc+RYsH;r{?Y6*7K3lrhzFR#=!PAO!Jlfx z6Iz2>Eesru+Oko+LK-W5q;bfpeo`ymnx8{AKw5@C&ok(8 z7iXm`Sk;7ko>+{Y-4Y61-{=-&RyQVCdUl<-aKQqdoyJ(yVI%w5GCSQt?b&hfXl-vt zk~#W*2{!HzN*}Ki_uJT*xA+B*6B~IGw6VcJBAktJh}fLD@`Cl^_G9OhHu&DSe|tcc zhl)|tDoaz-MmO>^Lp814m@DIOTL9}|jFo>}FCGrdEK5W8L6td4WzMr@Mp$NU3HA4N zU@I& zzycK+wi#NTXu2I}5T7X4A(+c=*qS6p^@Gt$_Jby| zH^;2Th|)=>Ns4JS{{YjYRl3seH;XrNWP=S~mtr;D9G_~sVWVkkx$-f*MLmPJsP#21 zyW|sj%Pw+{#Vz)wHawO~Z?V?fP@8|K^t&6xO^alk57)qI{qR7wMu!Tn?=yOZkF6o& z2|_BBq|^XVUfS7@bsMr~t?_d@I`WO;cTokK{RPIy;}T3g2w7u}6pRrw2?iKN@Ygqq z%X4MrN0iunblEdbxd-h9HV!Je2cyc}Vw66+N!*yXi25`7Jd1m0<3;jO`B(rC#_6E; z9@cnK81f}`dS=R^XYtzlS-_W8{(ZA}Fkcp+J=otqgwAnOKXxgQiyx^$JWu5Eq0UY$ zp;32>T97^O?x0llc-s=d6ObH-w8=zRCXDz=c>_4TmG3V7?UE?R4d#KOhJGMu*}+^S z6JzDwTgBVq3gK05$6@qIKfWJ{MpegpNW#MswhtT#ux^B^6HhI|n9AzYPo=W*z*IW> zlvRJ|ByscNXtsniz?6HA$dq}H9H}W$#|JZ0@*Y~b=X2tzaJ`gC$5QKX7Tv>-odo}F z7A^hN=f%avvP+9xvSxK^i#MuHZ8O<;@fN$!+Xf{q*y%uaWSs@7L+hjiZPBrH`V?+1 zdTrThO@^hn?6M=aKBr|T)|KJ&PjJ{}hT0UXHoCztZfT=i5CGkL7GvE(?3~P$#f_!s zpDcb=EIY}_GFjbZL7W;S$ucE{mkB+io>5RErlgjgR`0aS3d(*Qk#e}9J5apgru$-l zjdI$Sb{#PL^1PN_b2;!9^y{&wmEPYft}BVIvf05F+&`+yBSvLVfRsbGO3GQCEGb7s zs|>c{jIOeHK2qi9OW$b|ZrH5y;EXw6ml3bnedrWQMF8K>gA6nW7%ws;ORmf%-}Z)}~j@hPl~F^oa^JyF-; zz9%|b=N#+rgm7{TeKur%C-i^#OnVd}Vj~CZn~K zvfxB}3#mZH6hSHC?L;CZXo60WXeSuPB#lzy$r>??BptMPCtD;+JY|7FB}#FjXiiT; z0*>IJAO)soz zAXivqW&&d6Y#7Z4e@sC=R4K$Tsx9i~q%BFCP|7umq|vp+Oy{ey5K`;}8wwHY6lxf? z6mWW0CKjP`jz^8vSp-7YW4(@S+VvE`*$vaBhpH+yj1v_~Roys4aw5NIq96sD70oa< z%#hx+F%90dDNXwN<|4_-5toaETQp)ATR8}&Pf|fj(4vBd@j0E6WPV;Fxk-fL9!Jf` z5ktty3Q;kw3L!d1slH?-wOs}wsDlC|CO`q4^yijf8v$zQU2fLZFoGOJt}m#dVQkmY z#J^i3N^*}*PjS7(klJIP41h;Smw=3Yib9T0TnVIKA?edeuK|tV?pG{Z@K7mKGK}F> zMj8~}F-1_vX&5_KasY;w*O7j@iYIP7=x_I)RMfGgxTElMh9>0YVdiHr*xK#Q%j@m) zW19oKH|*}ihMIVhIfQq8*vJQa@XN?;wDf_N)Ah85LbN~Yz^1L z%?zwszI=%l~y*`SSAGg7|}HgV506 zDmohkOSF0d;5Z23*m0x<-~S?KPeEG?O&r)>%wy1&--o=zoq?Xdj=-wUzW(+=yiwB& zPF|R*C(t`MumaWM^R;&@%fsm7U$7sJQBdY<@08{v90d=w4Q(ShiUE8j1%@4@hjJ> zD`*2LViPdhQlbT8?-sfBNK0{kLB0>}FkIYH85qVAJsF31Yz@<5@r_`j@|w{&En~yR z8hPv?Z;ZVPhfsR+Dit3UFn64>qZqC?;#9wiwN(}C>~!<^Ny$THwH-c*cGuI1GZ^q; zZD8Ux)!yIfRW_dB=vjAXHkfdM4Z)o<4992xVK_$a3Fl*^N;e?72tQo~>~c{v%CM`o*I>d^t$JFdX{De_2N(KmNy0(Kt3m03K)Zqs+knpyR2qz<*)GaYKsx zo(;#KH||OsJ{dTjcr7pF$2}{q!-nG?6}QHQLzg((LrGphP(IIRK#U9eD|9??y3F>%_@Iu@RPp3{d{O&19zxS3pL&|%OA3l^hS0YH@!~wjFJk-}#&1x# z1HM3f9Pn96@2Fv1jAn`x)WLworZnH$3UMln>2q6zDw{)hDaX| zT*N6{z^`R|9Yb3_59gB*`4TxF;gnC(kxxSOhm$D%O6CK6GUGBH<(x)1+CnNp$ng^V z1)g~cK5iIk5p#|**+d`3d}$}GZB=W_|dHzW=@RC5A)NF4qu@imOY zt`cuy9QAfAr4KQV{$IwQ$@o_ozl!0F48P6ryPOW~M&^5z^?9E8zR2-!G5%M^4=LP{ z$S_&a9Vi#+<3M?cp96NKayZs8WW61`7>A$9`0E&=f0Fpi3?WzIe^<~6A0eFXc@i#S z$a0)4$Jxttw11fnek|e5N-yVasvewoFhsi}eVyokWV)X+{xilOVI2M|INfRqcexplV|+5>DU74fBe^d0b>v5`Oop(7q%Y=l z>_;y4BiAa9FJ}mUlIhuAt_H@NIsX>M{S0y6lj*;}knQUlV0;JXJB{((jGx2!`HZ6; zB%iM`j($br*K;{;Vt6~#zsKqBX8gyD|Ag`V4ACAXpT{}=0OLdTG(MB-BvZVV~?sh^mEc(cDa3v(`n?=g&}b~^m7 zlyLan5`xf|+K&PKB!r*H_Kp5S!UBe;l&JZ zWXS1VoId6~C?LFFrxh>u%0GadCn{NmC75=;;b+5QP9GTzP* z<20F${W9Ty6`q*RFrQ&HL)1T|PrQcVYYI+cJ4{-_cqhXf82(nl$!_P4cGCYML z`^g-xpE-{){bhz+&vUqadtHj|oyTxB!#ai=7;b0Ca=g13-^=h`hCgM<_Vhld@VOp_ zlNnBDcr3$OhK&rle&({=xnE)W@_ z^B7*l@Ct_PC-Z*7IQMJw9%uY_4FAUP?+RuKhH(s8zby9qtQAZzXLtfb_PZ>$OV$^e z{$+;j=ULpIv)Dda_jCM144+`g_R3;AW&Kmp=f^N)f0;j*@nsB;W614c{wBtI84fZ$ zjp2n1x!&gA&N%BepZ#Y(*W-NlpZRZay3Z8MVLfuV-R0cI^j8#I#Pz#~{ddtdOy_ox zJ44~Qiy5wA*vzn#A?u&Z^_%+u)49LNeP7{uT#tAIDg7&t^~+=ad2LKTmEl(zex2d> z8FIVLWBvAumaG5tP7nVF?Ri@g2h~Wwx&6>zZr3cl7uQmyMPUR%>sUd8%sZ zL>d23)(Ner1{-(u4|V#hh)Z};I`Ga#CSSHjCLbIuF5lGCRyACJ&7f8Cuqxz&;RRV3 zIp1e6-b1?|lD8;#!|O(JoZ*2kzj7Uf>Ckm@BcmMW$#s(n%;j`aJ*pWOD9#&wJkO?8`kTH@qCU7he& zz}wK6+d}8fhjK$T!OGmW&}o&qt!<%5Wo`&}N$x1t8vDC)bK7tcRBUuCHy73#=InwG6RomC_jZv%wtYF8;IDpT5pPZz(iwu8GsX*cIxY~rwz zQ~K5Y(}bQxX`fR2W~3viCsUg3#TU_%DZQ3^vk@nm(rP3SA|z8fDS|ys5OoTrky^9q zmPQ$OTBVW4omOe&F^yEDl9Ws`%GyW7{$QoiL}PlTkrOZyn^Z_9waqFxrTi2t;wki6 z(IJXrZ@NDk&o>D_?#pz zP__7_@j>XT<>F4ExG21Gt4sh7#KU>wRV9Es(C5RC+(5~P)E{gQHzn*27V(bghu#mh zbU~-Jt0qw&8pJy2CpYPI)Z>Qc7~L&iKR(z!){h&mJDhgb;X}9{kn9}jp=0%P@k!{I z7Q}#ZE$;~Py&c)!TD7ZBOG%%>=Cg&a#VnH@jnmXI)#}!2i;MhKICydi%XSec9RZnI zHpbT4(HN0(BB>c1dnW$R!DPV{9@l+9rYM+;;ZG_46K(a#ch?;NnDH=2bt~2qDI8;*TS$Yco`S4SZq89+bOz%wiF(1b1VO~wAC-u z5Uw6cPm}gjcm*U|yF!Ai@MOB_c<{SPXZ1)t_74C|@~!HFU&*%;?^G^HUz>cZCICBx zF!d~X+M@|9i)zml&I?+N59r9733pL!Hun|!6< zt6im#;3_jlgtUnS|GRVG|3dr-UW8u)`KsQ=y6dY5S5E@@>Rtpwt3raS@ND)A<$@K#)T8iZy`joccsEF_ zRY-7^9%*2d0l@GCoGeI}6}r~Vl0+&+Y>NAb1U`LshoxLqN^Rd_Z%+HSxejcXn7 zegK$BzCDHTEBUA%Okn3ds}YutpL!Hun|ymHUri_^xC+lE-=2L4B3r3P;avlONxqB8 zeuPK)z=xlb?@YWSj!KVmjSPrkKrHDP>*`YT80G=I#8RgKZ+jK z&UB`D{nRPI8^%j3eyUxVhxb1GX5c5E>%WYb+wmhk-1re+(rXibCcIA*9Y21AM>q&%@a*(1L71YKV#2f2`v$@ky;Kuk1>Vhk_rX68KjKUHimx5-ITIem zPlWfX32&we&#uQG5tfM`@tu_z?*_=^QF>5*ReT%pZqnlx(m~;2Jy6G6X2T<%3Xk%o zqGyxu79YZte2XW+t3)=-LpbSiOk%vxoQW_+@3=|uCQNuFdjk1BbCn5?>as+5UohdR zcAxaO+2u3)08@6MIwTRjCt-HNC4K#g@jibE!tx|usR{3Byi<9R&*#64;`dGEgR9CV zrHu*io_=JLD;@A?^Qj5%Ylnc-X~#RE*pH8(j3-c9SyojV2$Yrie0~lV|FO1GUS96= zm6imm;NUrP=DDH9dgfAMfimNInE*HcjtVU8(#4afwP`I6ow9cLp?zzIzcyTdY`y1J z&&??}cy}-DTyf^!^KM_N?e5Inr=3@y_wM`e|MSe)x1j*b5;}O;GzN z$K&Rck1I8H_MD8__>d=+rMgnxX`VE1T1r}KT3XtSw3%tMQq$9@UbpsINXR2WBhM^{ z%TW%UKh@&uSrJ@t_Jy8{+shUJ0i^HA5F1+O^$ zTKV+DtpU(p(fX|CDQkVknN~nxo29kkbZ~pOB2QWCyQv<*p|nB1qDP&)fgQ+{o~`I@ zA5r@9lPWKBe^*OkDGR*rlw(pBxM!psm$D!w3%^D9<$2jrXirrgj^4NH91@PY{wwfK zw&D-N+;m;AJrs@la_VDUK3~9B>rTz*XgCE2~_uT_`e2|V<#&_7*iJ>F3wzt)V>+7Qu zM+J@I>Yt%r96&$jE9JNnFfcT@#R?f78<7Ch7okFW`rfow3Fa&Fm!k_)%&E2GNSRQ3 zw6=9UuDHiHvYVp#qFY3gLG=iVwA8oL$K8hsuzl?6!^f^*B0qMexOg=_ceMa4AG}&Z z^iN(b&^Q&LAE-+SQ4WnaJ#nN$!M56lXn7>6kj-Es;WrzGBeyrKZ>sT?#KD8*r4HCZ zic?Z-HCAg|OMSR8WM^6*3bx~DooGX_v3_GqTb(tM3KjfGf8U@E8%f;k3+HnoSE z`KQNip|#-%t`tWCuWxRb0tZ`bBhfJ3G!C}wB#E)U@oin^cinV2tz3T>mz76Cyx2%= zz;MEAu(2^3j6_0h?FKm96b5QzXhWz`T97hReJdx2vx7v}pg@hAsSB?CI8i;S7iO$R zV0D5Hq%lsgaTVd~J8>?D3GXPpFT!szc(GYgT)0h3v(Y}E#?tw+S8Zds#!@u=fhvtH zh>~@XzELWAxbB55l#pm`G_t3tDDI4J zUQ0h8uS4jc#+LCa4uqq1q1wiXPjfAgM#(hI5sek9R~T&+IF-?+aI#eNqH&2XG<0U8!W1di%Uu>iv1OH0cuN>TThRQRjP z$^zwqGBCTCfi}tkvWnS!ml$B16+dBwI2-d)10hM9UT(w?YIDP8T@ug!C|_ch#Nx($@suQh?K#=p)K;*Xq|+^W zuuKnI_-FKR=Tx~>4^J{t?$9I1tZ2&2d-X7B7;^%ARu6PYozLlkx?v_yoX-neO1s!I z`xlH*DT$>l+-(FqrPDn|urAHvlIea@0DU4}S>RPzTVvnU;gC_ngPU;SB)M_hAGc@2T5qwfK*$uO?pvW>M3L2hBqbx?W8 zn7>yZNQdswACwmaWWD$owh>}GN%FP~vB~frS+z1+ON|zO8v8o|keLj~KL~3lb-o5NZ z?nUyG_ik40YaQ3)KFCfIUK#lbcCzrx*az4t!Y`x0&Vrm8j&jCTuZsU#6HJ$)!35N0 z37derM5hWCW||MOCNof%uGtLLWo$7+bxB(VFS?Uf2)dW8H$al)Ubex2>0)j)V7io> zBol+)0d|H7CJ7#39VVbI;zvwCUBdt3Y%r#kDHRh)3UGk+asI zjB|WD`|v%DFVDXo8s7?{b%!U~GbN&T6Vax_O4_q+Dw2K;M6qQQ8sf_tjs1+gEp6l- z8qwHq;jLNM+Mc(gb6`A1X@~EuI=2oFA&n(WW0!eo$aXpcy9Yk1w=;FTO{k7*XT(G- z{_|xId3>4kq6f{ixu2A6i=3IZN3^b$9I+E%wbfsDv5#WNj|&Hk`22=}&D|2!Ib!vnU2G3kJj6NN z8o_slld$CoLXK9g`aU=Nl!_WWTvU#rM?L6fx2mWUhl{$25cH^D@vwVT)YeGrr1G|o z40YqENX%GwZ*8TVh%W*aq1Au$um@?HglxtM344tV4Y%}CL>@~MW}A#q^*%4#uOw`7tIDsea!lQ?=TDUR;9D^>kO3VTJ#(%Keo3P#o)#zOr~ougX~tDKk0 zextNJ*0waYV#>0Onn!n*%j3>*d&F$rWxV|FPPQINrU$B4SdA~jNHV=& ziurtNt%5*f1!7+^^^uA4zgLwcl7bXkieCgPJnb7xWz zzLQ0|>RnUnvW@lO5K*M*G1S3r!_5HtyzsF|WjQa5KC^hmba6%V`bMmWRg!}_171;l z&~YtkAd=E3>tB#*mE^cqk~m`N1`G4YenfvOEz9wd$fc~1#u@Zb9?Qp%_IA>KsX|H{ zSd>2T;wgj4_=G8g6j2ie=81a$VG^uVhVwN$EZI4xE1;I4272!}B08Fv(@BT&=I{{$ z20snK4OqItNsv#cYD29UHRzeoB90!T zLB)t0c!jMY$es0&Mh(ka4DBt1o%HNO9o5(_hfMl(LqYxu8vbbPEJ_9$8t|?3<=Ihy zvlXTaC!{bE#mpP-=1>bOKVz!cXzW+|JBFaI!_(I}8tuY2@?-sjL=cm2e`O8p*M_1S zutJC$x_4lxb1a`mqV?hCa65Vk;Qy|U(g+kj57IL<-Zc=jBObzhnuwQ()c-MD4B|sW zpwD&rd!rTgwftNFvd7;UR|Xf2G`CQO_=oP7X^JJ^3tUQMuyK~;X?O21?m!$J?eE>i zEted&%%i0>hFK?A)S?e7=h#Sx6pQz;a z@)P%W-Tk9DbshJVC9kK7VbM|ng^uro>=q3C(9;%6jCpyJnsCJmp9;q+Wt@r0#?=0E zD|c@jF3kg*LSNpl{CwXED1>{fL>8c^{)uAUd!in#XA03^mrrZGpON+{Lz1fEo>>O=U9{~l@XFiQ9T-@zf(&8 zFH6pDJr^!Trlk5{GRbY&5co?{;3Hg)L@5#}DM|O5ij%6fEC@z88 z!#jDh8+g3t(!EgOPA{!ZboGxVZx|WDVi$u5Xg=koIuzZJ#=1aWFQ(^Y7su2p`+8~h zX~5i2)9~pBrkJgHy@l;bM=tcW6M^Rp0>x8cT`0PjqMZgE*Y8pc6*SjdCSR-O`n};T z)?9bZG-V=QVNTy5t6M;_w6BaTa4UkJzoPd6Mey%jh3MZ{NeaB3Q5T2s`Nu zShlOWS~(sc2wZ|?)cLIfodd4MLTU!C!@PMr9{|KgM*2Djd$5qO1&dEFFjjrLi(Sc% zSJj8;H1ui=F>uH9CDEwm!d&fU+>ZUci(O-np(0%E6k)fU-DE_drbwYX(*Gh&ALY^-TdY+g=dU-2&M z?d%#gn1g_T9>i;I?>02qks0P^3V`+1{G#9TkM!T@rM$)Bj6O#oUeuq23( zc8a9N+ify2@%p5)Jz>13JjBOyf-o^&`9l_^?{Mi`bwAB)SC(#AQCd0I`3`j1VYO2!V2i@FSO8 zZlW1=JBcb#c-bYHVqul$+ekbA1V6SAvj9J~hjKM55%LS@*}5LvZ$&)BsVVo@lw)ZA zYZqVQEu{p&qG2T5REI@i+Fwo^&-r?=TDH~L?QW4k>zf_dq6gJ#^c@mUpOLXluyhXW z?A$df=V53l{ym*>9uC(V;p@^?Q3?uZgegK1;c-0zt*=GeRkS=?tb9Gj6K95F~;AM9Z%K4xxReqq(S?Zxwb&fKv~Y$Kfke z+3-OD(iE54@C7!}hhq0v;QYt2V0U-4q<8}9xHT3VhSQeUS;%*Dcly@&^0uSEkI~2p z&-U^Xdhg`4OP~Q}1Ql??SAfmkfEe>XmowlXZW(qbwzO~VBH9Zg`+Sd|2g$Ky3K2qcVeN{8nw8e29-#b*qsWAjc+ za};+fhuTn29&iZS6mCbz&nm*$D%sN9xEb@o31YuG84f2S)=zKYW2CF%#z(PDxD!bM_UqIxJwTIb_?u>#zxYDyNU-h|`Y1#5az6>_xTIR`CU-@xw z8g91N4sc=V$ijZClynYu$D-RSv<$YIJ(T7x*zcZ<~4kQD(Z5-pv?}Fy_ zo=IrB7FlSLm(x7tK(hqbu(SVV&w}O~lhQoPN)uk9$ui?<($(!5t_t>J(0su=kIadE z99wXFHBUN=K^?Tu9v&JUi}dyP%A|HJOV>D)u71oi_e8rpM|+|@y#a3PDDnW9eUklc zhPPl}ij5iDY-Z+U7ArG$;$fJPwOohTMKiqxH>L6vFf_9b;%Zj~aAgnI(J62lF5)BXgNk6Jf5OOug65;_ido)*C(@=s)3cUn zB5@12z;Sf(F;#|V0lN`&Z<{d%x{OlWSyrBmo~`V&p!t`n(Bz4lfF`Au=TUYaXudHs zBRl9vxj#t83?hKuT-iZnReJNdADM|49C?>bbqaBn{z$93)r4H-h!Xc$`w2h={)h~5j^ph=DvSchIYuz^KRrn!4u(`f+yax z1W&yAoOqI+-iz6_;Q7OJ!INbwp7bVo(p#GQu5=Vy6VH@m6;BEmJn2pFq&Fv?Ja2j5 zV|&5#zS$^t8)z@1$ez5=O+Y4!?8%;pU}GttA|roV_V8vS=gN{zTX8$7^2A!$uwhKj zBxQ*G223uQGlh(1DimG)lM;WC{Sm}}Jtg8)yNYB;NE|JZmXR7@e*^LTbEhD=sfZ*d zPE}s&73{*fD1Y;&LY$hf!%2>IEA>rw1!%uAe_nQP?^t7OP}MqGc0U011D#tq1hu6r z8x+27MMfRe;@${w!ai0z$N)z&i7UZJco1{C^azG&MBUD*i#`;vfk*;CM=3q|7?2P%m{=nN3BTpMWcB)p>zr+3n_E#S> zDf{cFU9(nbhhcvROs{rgN;z?M4Lg6nw_s1!WK8GGoGMe6nUgUm#epd|^z5&*Yryn7 z$7agx--eTgxyg9@ttxu4og6j2$5zwp0bactZ?n|nAcMwUwgN#;oi_#PIIT>?z zI|)z8J?C|{55hm^a~58d{F+_GD*t-)R#&%qN}|L_okC(zjTNsCfVw{OT1lUrjPzR_ zbm6&Z?p^E^=yLDU%TN16Vq}C2SUWT-yAhlx6mH`gZGM%5qVw9h zqCMSX_IhdFv+UvwZ^7f}Atxh@c8Hf&y$?j$#3qc$O;VW0O~TB7N?3jFB{>DI~EXc8#n3?a~*r*kr9+~6b-Rh{#H$Nm=r zeQSAob`wu7R2qETigS<5<5qb_lIj*>08PU!;+`h*1I?pgD|0`_oiQUz@V;HfIqbco z(d%82BoEmMl00}KOv;0bXU1!6&k}FJ1;;1L10@EQRXpIER1coD7lhc=;PEDSG#a)V z#@^AGwe7+<8fR*CWJX6yxdGkRzkV z*vnw_i^54&;S)hd4kWM4+mow86GV#&*lXbM*eW{*KAojfNRADav23*fvNOKLwO0a* zE@S(S^%mS*G%017hZSX8*^j488F7oWmj1m#yx zu;*7NYiw1dxjC|jcbNTh%B0_k6|W-~-^3os_7*(tpOlp}kIqV#4V@MFCuK$U%Ji~F z!Ro=l{Wo}Z8>3OG;m%VLVbPd#0(>7Y% z#vC6_(hJHzVGkbXEx4#;;Up9PPV>}6ndT1BXj-ZibbRHAZNSWoC(hAj?6+X{=gFAK zq)~}3Qid}_ry^Nqlsrf8WjFb}1-~lIOsv`DHp`9;#zwa65*D17J%Jfin#7YGH&Tx} zU^as;naiF9+uh~9N!TKLnO0IJ*Adn0yzCM52!`eC5uq>CWuv}UCYO!gvP4dbmyK89 zOZKqymwF3sshGqhPIVH`Mox(h+2&YequBEd*^oaL3fb_sD4}fBfjTCKeFL(6q0%8E zBEycw!h=1r3Dpxu&%o5>Fx!$BFYDowJm2W&PiAE0Q5NO1X<58GXS!|6S~!k*gzZ`8 zEqJ(UsxmpIZ|6i^Y@ll8jc)#CtBNrw-+!k7M2ccL@9K zezF>$w^;F^8r5s@_y>W1=^A#PXStwHn<_vbXTxI!6dU>uS;-#&`a^5jCq0t9MAymN z@rnE!YuNRk6||#+cfCNFr3pcZzGb^0O9TGzPht;y@@b`*R}Vs2n&jC``2B-gZiZ`7 z&*&I;hue%Q#MlnXv02B^I0moUp^mZGwqdMg@GQC+XY{BNhj$61U3Zvyl4~7W^`B2> zf3V0v8Y&qMav9iuAp_f=gbW9#A;Wi0VW0J`zy_;G5FeC750M<=qjHPcu-?>x=BlYv zR3up)gRw155RwGWQaWnYR|l~f9Uq^a7ObnQRO)c0CbW2}(uO14f>^F6JM#b3LLSnp ze-UKAM1VF?^PHl5`7ONjki+F_a$?x|<* za0*T9BX!9Np;fZ+&L zvQP6!Nb95{eX@b=6#_N}C9BP%{2Ap?_(#XLnRZEw5~)=`)4;y0$4_LJ$p~B?W{*e$ zi48j$foH?)86`oZRH5Hd1$>QUSD_zvyXsW-6N7-%VM-JpKb5^9C?J)S%%EEJ-%n+K zm9Zkp$GUeNJ3ozb)TZ|MTEX7xXw`47W0$4THrJ-6#$bY6!Hty_Zyd^0cQvv%mlse2 zNZSx-JVQP7+>8|~B53niCTezrDg3gbW0{!MO=+ustC3y4VugxMeJrZ55q%p)=Pjry zI<+00-QCnEtM(FPyg#pgpou+fBBM9)D<0rvs1Y=iIcO(ykjR|1`kf|r@A1n?8hlth zvQ>=FxEf*HcL?djU2t4y4Tn1iFjpquyJFY}qpg0XnLTca%(WpUcw{&{@*-1Yyz|H% z!y`jIIP(faCbV4ALmNX5X{#@9VVC7`nfeEJILIXhA=yX{DV`Dyavf}8pN}J8l1&mI z`6K}nkqD4@ni9uJwr{qwzX{UAFqcSuZYE_Ot5mo!k{fS3T$YKCUa6l$uiZnV^s23X zy2(q|MGhzv?h@)dZ zNTk^<5q4>To{To_h$!sOiIVYE=Ar};X>!E0tG=n7yMMdOh2_l9zd_1V-sc&J%ld z$SkUzQ9FFh1sU}LghH7iF~||Q6nDeo0678}{pT!HNVPLrL<*`G+Qj4+y>o9Qkh6svq6R?pU>w>a)@9Bm7n# zs$L(bJj#a!$iXcbc9<>tIMY@?w~7616&JU=f24aHRpG`F96q4RcUB&OYsPzfv0+BE z4UNdaX|L=gtd`zhoYE!XT^tF!e-U1|VRQs8?~UM%19>mOxOPHy|2uX{DjZqktL9lb z8HKH@uREPxT4WIoOSrP#$;GsSqhwimBS1EtXsho!gFR*yU09W-O=e_%9F*!zL0ZbF;bLFm>!Ya4ZCG40`>dQRu~u z;?y|w283VVINUK|Oekh`>@s^y^>)Vu_U7SRSy0%ezjX;xUFakM-i2nI95mqQSkBK# zP0PvfpIiN47yDruZ)of~8BI-~Ty!)^C+(0$C+cmgSsC8zM0+w})bP8ES859>kayWs zBZOT71RM#=sf}*+qPK^OItKME)tk{arpBsY?`F4@JBzG0Qi0bKiyYUpg;XTmK_Q&p zP;ub^G;}bjlUQW7-!Ah0>YHQijdETVD%71!f{&_i$dxE=>4 zF)|ynNt|}vf_=U0DE*_+$oksaP$Z&h1_t#88jJW(7`)Y7J%YlJk0n%CkSCISDr z0T+j(hjD*Ndu@YujuC*HgW*P;h^5h0q5Pq5 zVlkZ3O7JViH?i(x@#!iLp*v9NbDM34`~K&HUC=}w2l;Ui$)e7>d)4}F&wu>wTYMcN zt4ORyNc)n$)vG~!o&h4{`71Qi zD8mEQ+-b9L@96@1rI&?yxCti{;m`oimq1#0EZ;{o{#z!+*F1q8$oA?As5tLIkDb*G)29$qADQ*H$dV1)r(EAc7~ zkcjRB*D5QJKqnfYwTlQ)Z2&|>jGwI_OBky|~j>rY*266QdVR>-BPH3prHK`@B+C zP3xDhh;^2D)wHcDnCK5EkKnvb;ZxWk5v1}s#9u&TSZP4U-Yz^Rr>}-*M0m0mkzAw7 zqiJJhyabO|bBpd+qh&(io%7l9v<0}^c4D=BfuZ>`-A_r;zF|DR)ptf|Pf1x%@kcZT zShWfhG-Lgp1HM(O28W_Jb^yzJ14B6A66=lQSdzoRIye)b2X3Jq3bgBOTj%gFotHYg zYg-pSltXAwelqXUic$J zy<>Du-l|ny{rHFO=kWO08oH|kJE^wCKyeJraRNvOzQ;w(ZT_wfYNjpg=kfyHArRQn z8{0P26I;_eG}0ZLsf7nY&IfyKiw%yAo`|#w1bTb?tI);x07k^!2EvBjz1)W6hxW0q z@h#*gutK2RUtAc#9aq3f!W49@=$aF_9d-_lY&G5x9ck3lzoWk==A$HZHpcWd3|g-; z6<%GxZr`e*>8DRmY#37n(@bE>fp*LBY{PA(o65JU1vYLO>)#f0Ob*|wu;sIH-4Cew zIDa!-e$Y*z4&3?J5f$07$=?N#?Vv6?_Mrp)?GAoCNJm+bzbJs*v7@Y`F17=^>v$N# zaeRxqFFBrwh^w>3jTY-Sg!$!!^6=_4xGK`Os!q@mFZ!u4W-q$vZMb=_wjorz&J5Qt ziR3gyRMQoaD2v;AaZduiiH%J&xw=PseZtVw=`yRz&f?DcZ<7}-sl|`a^eujj7-rpW z!pG=rR+sX7wDE#2R`|AdK4Kf52v{hP@T{@(AH{NV5Xl*teN-k8Y`{$A)P z9?%1SubyY%2Y=5)rf@V`p0iE<6X35l`IjIIyle8~eggM5P5vDC&o%jxSKPHGKRQKj zGyfGB3Vz)bjR#^WyH&64rRPw_Y$@wi)wi_-~zwWI_8Z0YCW$V&^! zk37aT0iWZ@{|pA2-_=6a@kstZCm|V!k>HM#BAs^?D zwB|1K=I%P_o-W<3(gl4Uew}phlI~;Dh5kJJHR(cc^1G16+(jPeZb-VL(!E@|s6Tl) z$_aO+ye`;{{BGo7?jrAT_Y~t#iN%vCeN_>yR zPdP`xQ+_GkzX&(=Wa+j_SEgU;ebWDb!cCLupCgxNH0Th+=Y%_3+F^E<^tVVC^(Mue{axw)Q@C^1NLSi-PQUace-Zwi zzX^BlZ0W9$Zcw_&w}dxW+Gp<1r2ntNoi|^)S4#Is(*2ci=XXnYyL6>psg5JM85c?S zdg;C{T`AXsCgET3U()@GbRQS)LTQJE0qMV3y0=JI(mAR?_>UTr?(@Q3B-3e;#9t)! zS}g6g_#T0mDeJe)-O?}RJi1o+kCyrS=r2qE8^T?3taN35S@Nv#ALEzqS<-z*y0ScH z%@zJEDR7FZHnNOD8CH=BqTlRqTe^0tUmF_R4`-XJ?EL==( zbGdV6zRz7I{VSzgBHeoFO1tFtNdJIzWj@c9cm@Qpt-@-N0zfQW6e&Hq3FYQ?P zUFm;Gx-vZr-xmH=F6qj0wW?0~JESYqXVrPqe~onSknW4peN(tal1`Dddr^^uOM4eJ zOTVOFbfxrvUb>G;SJsn7KbQXB3HO8*(v|w3&?Wt{UO7RQyA!0HPqF4>@ zf0A@h6>ea@beBk1;svDr0zZ)OUkSHZ=8s}ou8OZ0aJ@eW`72>t>i_%6{gLReYoc5g zVfLp;KTUR2E5b2_W1U@a`_voeaf|rOWOR7EYp`=0j*KcYU|0^{7Bd5Azn0mL!njQE~5yi8kg5<^5`iusO&h)C_FgRWh=pHB{E)5MkSB|0t#xw+&<3 zd!(oj(YEa1(fX>^wKopz+!iRVOcV{K>+a@pLXC87Lv%d%)XtCgx9uDm?~R6tirLWW zu0T>{Ek_?4E34VKtt+&{j}un~x+NW@Vwmu@fQtf}^lzh+$0*B)Jcl&|$~`+q`=TQM z;GJ$Zro5!p;L@g^pt`?zG&i@sp$V7R26vP+Kw`q)dVYZ+d`*R=C-zlB9*xzT-dgw zSZnO>%FS)VZ7Z?SvD{o(YoNaiI(5c6yZWQsV%xe0utbv}|Cth1YNtw6uE;>Suwybg z$ZD!wm7yqlGC3+PdJks4i~4xMco+s^IBn3K@4=IfBPEEHH(f%wtYFFNoN- zT5pOO!9-(vxquUxb{5cMf1vbN6#=qKGW9@GwYO33r_{(9i3wqnDcAObjA+S}W6KS- zh?7jYHBt!?k}0PY!7*VFe+uQ2+O_GHOBr`s<&wvpR=MOcjijV9l}uX7dPv0nVCB+8 zV|wM16EISoR7fVt%_<~J{wdbWQ|QT}e-w>Ii_4-3ct^XVRaM<3o#oxVz@wY%BMsCI znQ}CI1}jRqLyt@^`cY{Oy}N?_$#H?IKTsMUgic&8ZuE$Y!fUiF(+e*g-$J{N7QIOHyNWy>I>aVE0%* zE}88}xS0lDuJnLz=RgmgdYwC_1u^UC?i#YO%qEKV(9*)9U5BOp`D_Tcqs3|l#o)C`V26aVKh1SI{q?guKxz`O>3O7Wja zt4F@O?gGG!hjj`kJPq?m7QEH)V~#+7NCSE>-@x&>2miX@^}$t-(xMRn^-izn;~&LU zj|#KVW0ErK6&RQjXnVLnO2oRE5Ek&V;vtHLh}Kgy^0xiDWy^k5GD%p(1L z;+_9j^vdBg(;I*vb7hwZy!iDg+DDlF50zD?ne@eb3--Ue7#M5I>17?yh`zrXA z{Z`^VfqdDwBPI?n=gULb ztN5u$@wKJzQp$UmDI~ZG&nDl}YZ10D9*=DW%p_k9>7nGqoOmMna(WPU34ZEPd~NdO z{0<02Q#}gLCf~ACfbic639iIrn2$Bfw~Xj5#E;6`D*O`IFBd^GU&TN5D84rNie3dm zt3raS@NDv(;0G&$sYl_-dPC*YlFLA1twMsU^q7rzlbuUngkRYiYh{V_DE$@cHXp*( zqxjnNSWR}gT_M3$cs4y&e-8T->KyPek8PH3=pg(`KFW(kA3qoLBic&eAu8kP_^C(n zwaGV3@y}LBa21|SzTw>n`;`M8))&n3ZSR4f@;>E*t=a-wgcZvzzRs z^l;;y@W{UjKQmrC{C@mMU&2v%4R|->T?oIT=QZKk>0O2}MK8sKXQ%hDiC(G+uLAF8 zzTbtP^dtF*zmm_6XU_K&KM~%q5T@wOG~wCxcpG7v_z~Y(iSf=$N7%5$qj$yErtf)Y zBTU(EjtOrW-c92XYAyz`$yn4+ihJ;`h1 zd;YIXcqDrQ`OZf^)#*`PmH_VpJ0aNy)_eAtcVa|OBCw(a&CcwLl z(pT99adf<+@lNGMK9{46xgJqIxT;)I+L-XJd9{0ZQ6+VM^(_Lo=r zj3-c9SyojV2$Yrie0~lV|FQH^US96=m6qTe0S-TN=DDH9dgfAMfimNInE*FGNd=a6 z4C2Yt+O(F3PFXwr(7v_9UmLDJw%&7V%FW&zJiC{kxwq4I-e;F;yE~7*u|DtJ_uv2L znXzv}e0({~HSnIHhX?NXJWHJnZV;yP-e@BO=S!OdumZAX;a>_n8TjFx1 zfYSfByV>rT_L9$sWB30t*^T{;u|+?XrMgnxX`VE1T1r}KT3XtS zw3%tMQq$9@Hn;XwNW>#SBhM^{%TW%UKh@pp$qgdyhlV5kSH7QQh!8p!SRxV}3V?P%>$4tjs`VL%&QOfa%GjcwYk>sTdTv@D((^pU zDf9aBLY|H-r~!{CZBeCqnftq13QJkwb*CJYvcNqf<+zjuDOva}!Y{|mj&ds4u5J*5&gBe8v7iMGg`r8l@>>3JCa5EG|2-tV}>7 z?RB+);<{*{aF6^Xi-1*CrT(f$9u%s>wc!$t-VLl$KP7rJN>F~30^KkT-0?v=>l9yF zVnts^Xl-w+3)k24Td0Aff<|!%$51a$f*$jga$E@*7#iGSg$$34NPy}4E+IXAJyxp( z^OgC_{iVgYyPH(Up%9_=Xl?6yTq=z(-f%0pU+N-*>Jb!asc)yxHwCqX0k%)qeE4(? zOys9)6c?|?$7>dV26=JT_;J5^^I@q zGQaDlqno@{9v9aGM?$>VNNm7x)MBu)F&d0SLT&8^INTHlYGY_as8L#wGE;pkCx_EN zM28?>jgr{_itEb>Do|OL;ZRk&0E-dswB>2WDHX0Fd{`~My_cwjhdtUF&D$;pH#RGZ zyKiZIHrnUYSUO+qs%;F{SPF+fP=!x}qGTVWaFhxkZeCyuB_vuKjjXS)$Jdro-@pJq zwxKJ)Vd3IDelzxjZ`m^6E_@p#!2)W+!ByDkmFvXvCi1}}6sZkT<$yCQIWfcnluKaZ zM;FH*jc-IHJW*7VU_4R$tSIhjZeB}2AFoB|pT?H)N)Cjhb)nkEh);7Zk4DKf%@K_i zs#h3o6gZX9rf{=w6}G5pYz%&E_Tqq&;)-&B#sNZ(AyD4O{Sy_v;(_ox5Q3{eC`8xJ zj3P06fx1iZ32yQQicyb#RI-7exB&7o$pw(&Kxsv3Wl4D{z-LPq02?f-ii=B1DvJFj z<&|Zn6%}Qb{tB=-mkbGAh(cMJ#&$CTkTQUjmz9+Ob{>b3Hh`5DSCv+kR}@#3jbpKg zhmba$m7XYp%F@#Eic-}6B^Cavva&#VpbX3|W}uCdfUIIR-z5gvX2nk!AxLhQlSq&0Ow!Jsr&X59xG^9xT(t7XBGM+&NWl)x(oalsohYGAo)g^Iknn8pfOe zpVb2$Qs;Aepl+DS6X)~7meMZv%>D%d=N5K%?_EG z<3GbWa|YH3PBpe2aRtAC z!wnXCwj>^VTwp;7EBWhLhd1&(B`@aj6XNjXcHNKJDz1p;`YK*k`^)DosjJe;$53@~ z<1^cl6V#Qi?WpM=qycmPVE4dyPYe@MYKtK67NyAZ%<#>onD?8P3=y5gbk9qPn=2r- z=<%==Ioj#&>m1QMF7Id`wv=cdkC(2&#6pS*XoYG3QP9``|ZlJLsNPq34PU&cPbP7!_? z{dE@P)Nr~gZe3LT*P39u6b&YzE=$-1)FnDqurSknkTscsx^&HEs4ioR8LCU#DtOWL zkV4SCY`p=JB=@on222-oqXE;U+$5P8^bW8yOfX3hry`nwx`-b!0d)!gi?hL~R;E-; zASu8B*2@tv10vJztff5d6ySBXb*adLV!S|W155BbhQ&y{!fXr$ z*V%)2#yYoBFs2{YHwPQTYnwxLd}vUDkqGM8f;*;0;G=^74H>L%xp@w7W0XGd>W* z*}EenxY0Z>zZ%f~(XKrIL_L3Z!Z^pbvk#xw`11Vgq4BLCT6cJ&JyRljHxX?*tfW2L zrXuOrKoq-0p&>q`(b&((+tNl}+}h553vbQ3*7m#|ode@BN;`ae)wy+e2x%-~8oSIx zL$=cq*gf!3y`8D!Z9;WiJ0qrG@t-et$m58dmpW+9&;6uqTjZRyJ)(7m{bv{3LlqBk4!1_yCS}VJgdD9}^?h#kDHSz%xTqXKk9yF}ZdFky z4i|M3A?Q)R;$iowsI8IKN#$)F8S2JyaG0&`-r7nz5nl-^LaYDgVGq(Y3E7Mj680J! z8gA*Oh&+}i%r+UJ>V00eUrE$-7>SxX`v;xH*^|PaRpM|eCUNvwQXJiHSE~An6!wae zrL`^G6pXApjD`A}I!Ct}Ryi+~{YHtQ6A+>dj|g045^K!rCsNtl?kZFYHQ{#2Q^eyn zg6RNjkpdk!s1H|v3ChtDb#=Q%RY=+acBzCgqyF78as3;;t_B| z62f_7SmO}xqYguSEKYXyYG0syeZKE(k}8ff5e8GtU#e9E+2*2`K??}HcjI5Lxwoqv zMEe9O&CY?^)^(!3yMY`%;Q|hvf_2E!Jr0Fr#!EM9o-uk@ou}Eb(FN{93 zc*S&aMf3VbtcX>TgE<2}vHwBGwWL8&A1@kuS^t7et0c#@lEe{9H&~cI9*;5bM02OL z(!v}ciCoGGX`De1<*|JHXiqflk1C|Jfko*%FP<`(j8B*{ND(zrV4kS=A11*{WjJ58 z!=jyIx&mq$YM}RyV_>6sIh}OKW)2@AVDQrr+tgmSd(Xvj3BHxOItK^8I zUo<*KV~%PSx4t#BsW#M#QG=fOEaK=f8dQw9fmhfXg4|gTY1FW+#n9eD*h$Ym)KQJ? za>%4lHx%Trpy7|k&Z1mEGuMI^vV2uzpbnn1W=NK+R!} zmuZSc-wRwyWUz6TsT9qsSk#Vwa7R<`MV%^IKd2yOFyCnIfEog?|{ULeLMm4vfs)L0}0egX93P9^KFA_jnC*;d30q7-;L*}5> zqPIChW6Rnazb|iKi{_k3gP+_kp(Dq{1e5x z_e4Ef&lIA;E}!t|3gD=Q&Vhf07UHxEB+JyaNE8iPTmvoe$>UU#7U;Hg6$C)-W>CX1 z*rWdnTi8-m&#@>~DkCJ3qIxt)f2WlGUzVKRdM;dwOiA^@WRlykA@G-^z(=?oiBcp| zQj+d96(?0|SrCkH$n{OgHQ31;fXNHBsuwxBEmH{sp!OJ1!+r8p#4s7})auKuy)4I?91>|ziB z&8NInhoU>uSQp6a#q^x);+R@xUoWjb4VW8h8b1BN6tgw2x3E3w$c4UkBJi9+pm++b z3q|)*w9}yD`dx~lg64Y5W7W62*p=*fRegv~L$AgV1J`(65{+8!uGDVEMYYen*fsVT zD#F!H5q7)TO-2N2iWIsd{V&q=p)L{76}BVsciikw1DhH$RsE@GoQY7ze3>&eWF65c z?nBe|YSrJOiASBOiHxGcnS%=4#8lq!um=n(s10@59W}kf%f4Yjw=nCZ$zVQ$CqMDtI5wx6$2{o@zVc)YyJq%MB6LXJ0P%%}7q+&WM_ihS%-WEaOJ0|39 zsqD|LWBC1=gm<;DwKe-)jqLYiDtp(pgyV6gFLBDJmjLm-RQ4rzZuijeE|S+m(Wmq`s2W2rztdEq5#-!0uaI%mEV+|dnw=@hXBA`SXrdLxM1faD7OM(b#r$}nN-6j(guTLu56UKYWLwr0Z2ovL#KV(t* zE}gy&_R}24buKO|A1Tt}>TOv46AP}!Jmx(vOl02cBAqxMO)J(1o5GEoeVXfA_6VB$ zVVB$E{x&X)V^6y3LXGXg=xHSZ4Dcq|Zh?1j-abpj;vR$R(GXXhz*mq6!pVc1fmKSf%+k(#}7@Pcg(Sz>n>r zT+K>^`~rHmuEz#k5f5={%KbIv7@Ggu#g}+XDFLu(7zsDkVG)>iq0|0yz8X2-SYLA4rvhs4uoWGoXbodY{Nca6$<7#fOyPiLHm3x`Jdy0lf4f&v<0icmy& zT#rEOYms&pEzcG!Uyt#GTdCGkUmpqSF$&_M7+ju|T*^xo{enE$gmxeJYy$lcP+QkE z)U@YevwWZs|BC5f2~mTurwCz?v9oePaqw) z#$v;8+VVOJ`EKq`-x^=ub`J+kTZ*n{lnl;bg@34!7_z(p7O|B(e6T@4xs!OJVd8g)y2k&WEEek2-^p#E>|&7^l`)N=}h$ zEOI?n31lL9#70<0WK)O76E{3-C1GhZ*7&HFQG6TrA9-8xO)y^t*WPEl-5IU85?uJ% zY<7`*K`Srje3d*48DiVq z`drJjZ21u%Zt!+3^JJ?p{J1v_7bI&3xUh71VLw(%ItROBQG73$!B(?}(!2%x-II~r zZzTyYCwb6;B(7S{!1(gJpn1J#5}K|>7MkScG!Hq@ETJ2#|Cc=rnr}=>^DHY(c!?&< zjHgLAb7#0J*pET;1@AmEC-!k{!I9S3&Y-<-F{p#~*~3GlW0Ai8UYXRcW$7Ac($$Yy z=ALMG=V(u~r#HZD9i?mGGhCl!f1BYg*q35s#x|RoIhn=EjGcHGW@IhbA$HMBZ^2Ee zJOvERY|NbOl~@gKGk1(#3Ce#-O(UDN;Z8T6dBdax0Q#le0JyUC>&lTX!ak@7M*1g= zEGTF`%C4B@EqEer3N$@yi6#=afD0T)7avn)cowi5LHD*9Q=rQzwVh?<$>`b2J`0+E znF>vws0nCNYIz=I_krdcGc&S-xbIy%NX88EyT{3jLAnhcFpv9@nRvkociB|uV3_VL zb1h5BUNw3i7Ji&IjzsImS*TcJj?U~~(`1!0{!Sj&L6K@{D6K`qm z`)A=Qb~Derk^clwgl7t#c*_zz@#b^lNqTxOX4it}57PxtmZ^Bso8U=rY3{qyQD{v( zQ;tWXYzjxSdpaVl8agFeYb`GQ@rZCYQ{aLPm2@;S-j!U;eIF(1Q4j?2jP+>nRbZ z+VwER(GqDHsR8yk5Z^y{3X+?ONJ7bZ9!tG~T{suzZ{AdhQ}cB=$==-`U^OGk}uBb;=&D;fU>> zSk=}t(q5sgFb0&`p;&LzP)~m^b_FXw>5^)FXZIL(%+fA6)OmCGjp!`QE2VA-5*_L6 z>7OVzG7Ps&+FJG!q`zUoznkybDR1OuqSIW zrgLUal_|^2$(WPkz?2($_Se}pVEUb7GiCN~!zsetWW4=W6}{L_j+)+MtLgOsuU?I} zS?Y0+L1Qmlfgq>On}T#5SYrU^VN``IuVu`6!nJH65^Q!Zg#Qi~euS!eYckC#WS@ud zyN~-<3Qsj^obUwHg`az&6#mAXjJdm=gs0@5^E%rH;h*z43olB3&8}jVe?8f8iII{h zF;b_H7*u1$>jR*!&%9RBCnqEQRtH^pE}DB6dj-1OyEHR9g6p+j4JeY;Wu zG-X!c&b5r#;6&H-t zzyTSsc4$;~BRB*KxABZNzsf<;dF@=$p6)Swy)^Gxc5#Nc;BoYjlMzNc#7nE*2cm3Z z6Gr4FDa_+0Vdg(2tUmXWoQzp%4g&Gs<@__)*C5c#xk(B{gB(2#M5oLu5OvdZ>tt*+ z36yb$5NOWRITi3Y z;P_;DAfLgqiU;Mo$$0Rry&%M{29GzvqtUR{F!qkdtZi4a_7X#Upn)dI-Q_!ie*2`svd?K{?6aC6b5lw}@Plx<}{o-$?NMZaNB zf$}?tp)9hjPT5Fcs=4AQ^MqY|3VRWhUp>K|U!AP6RgvcA$R6Hd_RA@gekWGEj$C{b zdm!6e@U(wYR?<8=D_J&lR^*?Q71=A(%N_-*2LqF{6817!k-9GoPj=i$J?enj47y}4dlqbWm-{ARi|l1uNts+nRIl^0 zN6;e}ma|8MzEGEq`dXP>HhRkvIVoN?UWG5&!_HsoEx4s(5|cR9Njw`lB{pQ6W08$w z&og90{#Ynv!`q^SvQY=>m>l*E$o7Rwhm42}I~EHM_QWPsPZ&J|Q1mRS-d-Exp&K4IF5OQ?OEn6c(`h+GC8Ji=R{p>pmUc}0eRUjQ$lHY z>SeXDYaq>2Cr(is=M?=Q(olM3y~=KfG(WDMsx%I(h}lV`S7O^>&i2?rcHc5@^}Vav zTkaLz1O3BMzWO=DdoHM_4&|bcW8MFE2>b1RvKpVaSn;76)obzi2Z4X-8g`y%xu8#* zDnK7+!D9s!8~P4e$sYjvLu=S4J(9dc*U8)QiToRD*!7+jw4;M}y+E0z2|lhlx;8i=+F&5i4 zjI|7&MK|M&9#!J-E@8Cm4l_@3twXE+^U3TF78yuGCBs231KTfTVEdDh;ovl6_|7Tp zv)&chU=<1CgL3F0l0$q{ZZR9yn>x^3HFb)LB&%aEwxtO|^149js8wGb#AbASe0Ex} zuC7w4!2MUszo?>csV8s(@>?eVpOz17jG-(1Ho zOQUVBO-+r#1i6A6D=XeOl&S7&WN$7npazh(A<%e+dg!?sD^^6%=CMrF>;_Z#WkZKc zC2}%S+N$4bWS6g4p`ueCiz;kH-$v1S3u=l^ZAWK!H#N$ty#yKW&#ND3Vh@|h=uP~J z2RIpO1kGd)+Q}RwGH0!Rr-|Kr{Bn{89~O^n72`9mMi_S+Li%tQ9M@UH;m!ffmC5(6 z7;Zk)RzK6s9=Am1+K>`FG8`Uxkts6XdE}1ak)a-(d4(YpS}y6KjUk7$)t9%h%ksEP z{ewFkOH(S}?1nFUzOQb$G zlQNH0svarTcDO7PAH7mPhhDpfM(I^s{m5zT#(b_UCwMq1IYCHC1hqptLG6$vm{@id zQew6^CXLAA*R-)Wg%D(Mn`XokS`kObe2_@9TO#bz0zDaR+7VIMpA#kHtIS0SAkyTB zX;*zyJA1u=7g+127o+GFED=T5(wnA|%ZK3|Vhr9P_Sbam;v@2oUC16Rv%|dAM)u{h zI*k1`ROaui{`7jbcO@_LRtb#KkDRx;j^8H=v#54P?eH-dWYh-`3T1}GAV=g<+z5*U zS5?NWl1#jqJKYp7=J6)zF0vCCL}( zADR?CAow0|$bTm9T7_On%7 z-0uF7?r~Iw8%J>XfGXcvc?7N*@9o8g8PPU0A_J$rvXih{u(lGzc!&2ox;PSc|029_ z!{`WH4#yh@@?L^*<%H_~ckGl@II_l9&9ibc3R_oScRIVY$RZk+aAmubi)jT%$+GfB zfRs?MtUNI|;x5hy9F0jS0miABd?jCq4Zx&gkC?^opy;u|9x<}fR^N37d(0}juqsW< z!8~lgqwI&X>g+|+wd(5EI@nuQfw(Ovm*+6HGzOZa{fB1DKYfJVd4eSyNL!*n!IVSO zGG);_(={cwcO1ycDEiatuSVJPR=I>pCll*%79D~mxl$jdMXTRGlU-HDn+5x}Kcivr zUmzNWO(ag{W^=t^>ezMQSP0%2^!i1k(2IM-sd4BH2*18@xMRYYP|WJsW%iir?T!iT z&BM2{ps-7S>k_28&`AQk3(Yt=Xu#32oS%`JmXqN>xB9^@_QNvX(Aae{nwmhl=xCBo z+98Wh)Z0|EGQ8J`_GH4S;ddFY)D}`8@3N^z2)hIbI1-jq8{O(fZx0uB4C-5|H=}J# zja9$i&2A}o7Flnk0 z=pcN{w!R79^F(n(QA?Y4t`X80YF>+Tm<0Ue23#DD9>xtO?X?ZsIYt0Z^TCNg+Svvq zf-f`IHwN3Zj~TG`5WX6%4~83YB9=y1gYt*IiN$bAE5WZ6-^99)#iy%0MAIht_ca5D z`~K$xUC%`Q2Kj9diK4#k(O&(3?0pM(TvfII+4D%!CVi!)EhSB-$+VQmdOfI4ob7i?2*<#CskTVEh1(L;#g=W5+Pj^G)IP=U>J)uO3aHjVi-&GttES@MIz>98x6`)rVCkf zrlsSY)8%waH!JdR5>6HZPmwn`W_V>fg4EeKtI`d1vzlmzaVjDhYjn6Dowm~y2i;~7 zoo?2q8w9c!L2_tiFJBoGax!=iBvPULISTFfULiPZm?q^ z0SBa=E^m;nyrnW=({dz?Y@r16>6UIbD;oCETMm~lTn<(6-T88;zlB0dGZep1Ar!-} z>8Oj#1?g9^+#o*GNxCtNvLeLXx}jgnHiy#$~NV(WJRp7h&!3D(juwo9;8|o zOC-`(i?nkk5vnbMiiq)ZEXgpoTZEmk)fpCQsk#FuJ2N(blqK>Gi>%ZoV!$HWgy1mU zn%Dp-1ms$a%tAn{TMMK4;g6XphoC|Xqu!$KU9xY<9^`VTB5AaNgz0!83n9hMvY|*~ zmqHDrk#3x6+cHW~IA@~7nk)jL&8HxoT&aa_aF)VK>7lAf4dZNuQc<_9l9I?T+Ub^V zIuy+?cCV7&bk1sc)1KAR*Y}o6Nsa{tVBDt>!#J03q4as`mKZwKtzo=Pb5fdb*GRz< zLc@%v5OTgkR7jUXh>nhsf2m3}B5#pU58Y5QQMxgVUbh7M2~b7vbF;37(a*Ptb%DAy zi~~BDr97zlDQt)YQhgkjH;^%+b3n#EsE{)=wgDMcNY+ZyYfK}CFC=*6{r3nc~=A+#c`w1p70*){) zF7V@sEAY(1611!6_ASy3hlWQFSa*nyBI@a%?C*(ss00(*V*VKn#GYZQP&0cGPvP*q zOQ$C~g86~@l`eT-yxFA7NJE)+@)Wkfz%AqbgVBU#;VBHod@^q0pxU?cx6}D!ZX$K! z#K+FCa>XWJH%M`tbkUX%o#RxR_uy&W7ZXOXSWvHmO10qom z2YYcw0=|ch&abp0qrDzw=Xvy&bu(v!=|^n{o}e+fBM!%h`RO;>_%SL=HxG7o8E^g` zcoT=az)bQ2HXQQwC9)8%#~?)P1TK#kR~#}NO}=?ic&drvxepv&C-Wj4&kFPM07rK$ z-Q-dFE&Qm-;UN8DaOk)21|5$0_*+&&{ISicSo`y8l1>6S{f5(QO2K-7Jz7BY!4bKIhX~Q>TZ1)2jz6!W$Z^%C# z_<6Q)q@R*+!;!xGPc|IsyYI8%NZ)<64M+O!E*p;Y-89aX7t%xeZj_mcBYoFbY&f1) zuEREb3-C%Cz6LJvstw1v1kSr{IDEr-kqt*)oI7mzO5moCL!XTp0)E*R4qYANHXQp_ zIbZ{Ifgk4tiI;6S&PEWX{~&xl@B_B+O~4CmIJ%(5uWdN(%lVbi}nnfJ&pA>@MV+em(09?RbiB8>O84f>`&=xP1 z<4K5k=^T%6iYMuaCn3rygZQ_x9N>!>m*KGE3c}%IGABr99pR5*fJyMXIEIy=jV}2> zmk{-6HHE*%`2RBeD@LiH3$#@pf-5j^BnV$zPteb>hQr%9Jffh{Y3Z{P{AT)>U{FQ) z<%Usir^Da25`GVcjRc=&IseV@b(RnNNIj5m33o9(mm&N_(ji~M4>G)i;r$GsVE9vp zZz$+M8B;t5d|bjH!!d>*V0bgbuQ6nO9d9b!2_L5TPWYaLI~ax;UdZq|h96@1Zwz4v z8SeoFP5U9eYO>GQF|H=4%k_(J5yDaLOYQVaFjgfT_NcJak6^4z_+=Q6Gkt?S{4*F+ z6OMZ1C-?&E@jC^ndXRo%DZ{fE{wqV&847o3``yGi{8Hu%&ld^d&k{~B{5Hd%DCkaeG5n)~sb?~5Wys~1dKcsHdy<>R<)7BUcrU|uF}#-{ z>b>NDUcm*K4807uG30Wl=O6Jec$A@z_o~7da{d-JFn$Tc8yK=*EPO@b>1_Y>t&BG^ z>|uD6;a3&RKs~1PGgdL&!f=q`r3{}?a1q;KQ5NGZ4AE|qoJ9{Z{F{P{w=-n>F79U> z{zd$Y|E%DWMGQAG3^0V>65kTG&ypWA{wD>OqFtr%rPnY-yD9M(6+}Q*j}qXt@u`R`?mTB3^^T7H{;xndyX=Weg>uIVS9S+XZ-gJ zUuXEHg6o$uEMr*BkjrO1r@MZN>F;8AIl~VzyqDnv3^~8+f5iA-70humM1?0kbFvt6 zdzQoPYYzKw4*PEo`%ez1n{zeCyOklQoAU_cPcZzcg1OvYha!=EvHh2b9*#H6;ghnM}{o6GoSh9wN^8M0lx zJ&X@9WIy+EefF|_yr1CkyBL0%A=}H#cJls$>Az*j{<2}A!Z)mEcsfI_4;ywczK7x4 z7)BXRGURgGa0BD4*9P{V4P1^J*nc*BkNJMCU_R@S&-E_RKxjYMARd}I;A=j(II>tL0a`_Zq%=q;T zZ)f;4!(S>`#Bz$*?nOmRXL}blGtTmhu3`L>4DVye?PSqU82^=mTQ)M}{BP-IoZFQx zT<^B9owwY^;h$9yEBw-LeP=K{OF{oKhHDrypP%jL|2ETKRIr%+qnPVe@r{aZ_6Hv` zj7r#+`u{$Hus`+N4b{FBVdkgE+(mZGD8lxH<6Yf=efkdbw?%SFGCVTTJ=8Ubt)hx7 z8kWHaqjmzlr)9^nDf6(xG3h!E!G{NB0ueQrY827LBW7E}eR$IduSKc-k@t^|6mhCu z-8f@&vS|P4@We<_aX2tYyQ78&x<~qUg~ks=y~SZ7_LYj5z6f14ziOJVaq(-)R3iJ8S&G1I=Y&b=-+fHl_%p;mDw`s1FhL1!RPpfjx&y zMkiZ?WjzTZ4371WVP< ztgZ|D+YXIR^oD~Z#cpSPL?C5lr(_==FRR%z*d3hoVWU;W9#f2*F-&yFkc<2VHJ^GuHQg_Zl@o(?o7S2AjFR#Q(vAKN?T^>#Eg;q2PLWJ!~^-P;=U2DUa9 z7kl?^ZS?!S?YIjCgF(MHw8x8WmfO!M_r9yWV^{62I)zpMZD{ni&|c0#Z?Gm%>1_+1 zUFmIY3$|B!gE*&cve;&hZYxsG zo32h?XvI$>a+3fIOWx` zl$NWLnA!MxLNV<6Bx5$dA18yF9IG5>(`Y0RkYFt;Li)_6(PDAb{La@WIPSb0LdLZW zFb7ALG3V_HDt26xH%C9P$(WxLNCETq05kSmDSq7yz*}b13e2kIwrc&H9&lD!LYdjr z>iBAmXtSxsF^AG3&TML}RY-_1n_5Z{5|s<0&!JY*BW=F5lH<;+R?4{Zs+BUPRgzSr zW>b{h3aQv{tybD(%&%5T0ak%i7G_i8_ADeT{W&(ubLhgNXA};Hi%Y|alMYA1k&23v z(z2>bu+d5N?G4obm}@M2^{Q%jf}WUJ?Za#ev!jC7k*5Xfogxl0DPEd&e}UPde}A@njuq2<)UEuef*C z<4Dvf9p+mXz-U)$i>XDH#jI zGO@z33a`MQifxUtzUwqUqK)`Av+lAXxF;zW9G)p6Z zIunhyd%C>{|0u4$G+&%N@yzVxIbMaJMDj3qY3hJmXDj~I;ioU1Zam)&V3-Xb^fMZ? zFhDIYE*~xr!iZO2$@q>#1le9+nlH|NDLr6Fl;3#1W8lMlm3gr|$45cYvT>VAdGO$; zFU|LU5bS(?u;I;`$rgsWKRaK#3wYslKF26%m+>?C#9C7-s8V3!&U|u@iIQ`ZjA2a!%)^E+1px@)BG&3LK zQP6DqWgh{q_1ld5B>H7vi!d*K`bwf-HqteSS6`Yh&VK9a!0@1E0%Sh%5!~DK^N_D- z{R(iOL_g1JguQ^DzI3{A_VbX9uhL9_nlDbj^_L;+*mOQ|0cbY;aws2KKg@$C(=Ug7 z>I(eyrPGbmFXwqM5U;*8Uz~oqJ}~^7W&&hBfjL~eez_!X1%6cDsD37~U+(YlO4JJo z*OyK=PQRijz|g9h05xBnep@_9ifH=MeB5qmKP|ZkB6eyfK%I{a+}rG2`XKP7_)$Kv zK9(#WrB9=6^B`PbI^DQ@RKE&_+cXoP=8Mb6wj1zH0+q48G#}=!?fMNr16=Euhx;UU z9)1a7lsA28d2#v;lYX#`d1<~l{YFN>@uJCP!RoZG>AafhidT=^}Y_U5KBKgWE%(yI#PJzH}Hp7j&YyeaDO7Bfp|w z7Jej;?AeFk0{r+oQi>a$4=3)4kMOb1^CoPHORowa_eX5hODZkC5|%ExKR z`7Zeq!n8c?_oQ!Jx|fjsG#}}nM88X3wDD0}mW=N&Ha`7arF7%$a_I`twEYT_%eyoS z<~)XQ$}jn0l60@4^3`@Jweg*bd#W#deE{(tU)LC*u9s9cHoj}_hnvtCLSLFsz&UJu zH}!&{OEUpVzAeSRsxpst`AaLys!IL-G7x=|to~!YrM$e{<0&oiR{`KUf8o1>jrBry zr&y|x`O@iwc+;<_!qQuUxbloPqvf6*J4fz0wsYjmBlTHph4*7lhC;_L5a`|sLpZ}{HC<&<-gn=v+DoVf@u=%Y zmpiVOF8MUqV?Jqcj^9_jr8*pl{WQoBC!-Q`J~1<(+9x+E8vg#z=W8Qn?95*}#P*bg zlfu~EKsWG`wXa=vlAbpDVopOe`t<(&OVN-#090*4t1)vwR}hTnjK0`yO^rTlvl)u9 zkF5>RDec_~9b((N`F%n!{fdN}U(H{p#ek<|IbBj~(Jk@PDdf$$Bl5*5EZ^S*>N?rof({+K4U^wi_sgHJhJbq8H&tH*) zq6vp-#+U;9zOBV&Tg%E6wY{UR7E~M-4Hk*;M_ELysw(wWHOio19S#j=HoCXCN_`b3 zhulbk&X)%7#1QRtitjA3v~M!BcC^)n>g(kh)Zo!UV>p3hxEK3Ck9$fbFB1lahxW%( zM#e{(VEe*LX;0se)oR5&WxjG>X)#XjrmSO2h+s#!wskj-l*Tu2I1}8*dEuaX1hu!+ zchJY1N?Ou@xR2L7_;?M8@W*Qu7q`~uYcYhF57=Tt%um>2sME5D{6RWvhKwbX}jY~w#EoI1RCr2w6xX5M$(}w{TO*Vs1AxH3<&P+2sX=43EP4@L+v=i7X`e#xq}rB zwAQwVLv*q)lHJ83#``7)yY2U;>F6A9?c?fj;P#-bHp~qgHd+icHiiT3?ZLJViyUeS zfweJsPOyD#c;%57jlu*W+gDf*a2yYe&t>jI{`?O*qpwq**&uIEwI5wfgSf z#&-(tSK_w{X^HeO&b_6T+Hjx85E*jitF|#z6H_&O{whN(50iCJzG13*ICVj+U`n_) z+`hZM9$#CAJp%)VSV_l!!@k9N@>J|8Pj0T~upw44Sy62~I0oAgt4(2fQ=5=Ru)Q`w zO#}9;l)?}TRH=b2Jvuc0RD2`K^kh*4FO&kP=>w>k7 z?HW8kR_H-(x#g?LZR5aYn{#+M|N6jzjkGyxL)g-Cht@=aCr zstd|bA_T{NP>7j3I}3C6g7vUUC$QJ!FGeeRAtwWzQUT>1oC+w#{?dxl%98R@kT2pS zK(>;oDlRT5sVMf9lvkFOR#cQ#`YMpbyUCEq3rQ%$L;8py0%Zo2^0KlL&@PrV$_;3x z#Z{$MCZ!`LwP0{EC2n4ok%ZU&l$nYnO2scgx1iFfu-S)r^+OkKFs3Qkl`pSFTc zZBA57U!V-2Pb3=)+$w7u;%g=yIx-zQTZ>~d4H*FeBwcA@h=(W!Dk(QRW>afxnsmD} zFaQtumdOu6wx&6OQ%nBGWy&&v*a(SQf(aSr`$G5js42AN?gv&tZ1$cL?V+9FKu1ec zs5Vi{`lFa|#I<|MPZ4-7`W_(L4CDBP*i+jOkQO!^FKL8~`5TQuJ9LMBt5FExcJYs5 z57bVi$*UX^r^6d$)yi-!J+$yM#9xR2XR;`NB??N-qWq00a2ZLlnsbVN#6ejx1#kOUPhr*FEBe8|g^e6Nh3lt&h~;|rL&k{K}^ zU&O6`{>u4I>Z-KL5meo@5n9}q6V#Ee?X2k^qG5CYP-I}DCyJ>l{jMOoo7Sid+c>FF z_R`r1F-6RGvy^EQ29zzjTq1?XI+4DvQN!hMkM-dV6T{_l(+CIiGFB(VCDP215p$=S z1Rc$ysQ4Cc32H@9WtjHKy;4+q2!lfq`VmnjQTPF&N5xi&qWB5DQ&f9eC(O8ai!&6; zkslUkDx70KD|RTHqrWTyQW|zv#fghL{hc2X2&><#sO>4 zp>1jpwbPIh1IGsRYrX0W|ns&IpH_Tks+vhI!QK#p#O!V9!__Pj!%pZp_vJwOWz)>qjdDg z5*P{OO^ii*sK<|8VfF+AyW)cnMY|4AFeV>%HwPL+JDY=ba%fP3kqFw@{5%XMa6bG2 z%rlTvles^ z@-}&ThCS~fYNRjPGcgdwzPqENIL$n7Q#GjlW8Hbasd{;zh~u4}Lw)$h#*^pUjU3+s zp>-z~+A}AicaqSi6KdKsI2TR7454^)6gkA#G=}&wp)GBM;>33G3!pW-T08P4y9Oqr zRCf6Os_VeWFv^%|hPcW_L$-4f7#XS! zY~h*d_=vGnmgKB8s(a`*k|n(F6U3hJ~IFQ+To$` z(P2KcNVFQ;zTyxUV#tr3z^(Xl5AA&sW=$Ni`VS6qIW;_#a;UYvZN_9JgVLkbsJ_c7 z{zXR(oG7YfFr&WY6u0Q8QzweLml({bpLdB*>!_{mtuyM|IyxM|R&bcHjvQzuPsEpk zTF|yXyTsizO+q%4f|R|+heuj^DWZ&JD6`EZsQQ>&JfJmdI)O$_UHwCe)ww)Hd`GJz zrP$OlW3f6W9-pb|hf~CJT9?+gP*b3N*9k1t-_$jBz_QB4sp5aM8m0iH%E+kV)h3CJ zS^aRTc-2{jMxiFu!D*^^vPH0MUad-?6Pxtm*e{iGr#f6KOFtUrvvDmjd^c>Yi+MKI zwluY3%Ce0fkIpQI%bDZkU3#yQ_5a9h+mYGyK=lf%^|2UfX7)=lpC8+*AkbQYI5wO1 z$R_!pt4UHtK^a<)Uk-k`R1RpnF(V&DN5vOz2=5Fw2iromD2W`0OYETji;w#-dcC13 zKof4BGJ4pdOEH}Rrz0U;J`8ITgnOvNFg=zOyKS4tU%q>j=OWT-TFN9CiDLdzuOaX= z7rhKxK9Ic|-)_TsP3yjJDjQgozW9{tW zbuGJV8iTZ`Q=!GTV%chT!qG1p8>cZxwT@fg8r)kOY{jU-biNpM%oq(i#5h#^abzQ}L3C`d@*K{XKXPm~&me-f%^I zt=ubs?C}>NGlPQynp?;r{%Yb}rdaa5)S*>IGKn>L%-K7FqsYd_`g;#c%jKzcZMxsS z-NT5=?IzEeC|kHn*oxCjj9aIXL4}S_I zRmK5Av(KlF5tBnulZx zJb8yVZSrhHhH&(WasetG-&C=QZZ)Iz%pn@=@;;ZD0qob%HSmwfh1&80#WJ^CB#VYz zT#sDf`^UKyE!gAARSAH!n;;EaV2}MHY!O$YrpKaIX-AkviJH-%{U=!ae^_xwOfOsy zr=<2^Ce7oxq44Ke;gejCR4q~^$)bC0)k(KnF$`8X^!gg~8tRe{fSD_`ZWkqcoKq|zOl%tzhShN3&tSm)2{#q=C^acoazPcN-L4cH&lG<^ED zEoN(8Z$ZbbBNuo&NWc@8fZ{nMU7)&`>NyQLj$fr%Suh;GwqdP?<2M#sY&h;%X!TN6 zpTAM|&ugZQ>t;8AQ+pw(9zXiZSU*y4Ya6av_4hgY-=Vkfl3fw3SGkm(%mu9Yae(BL z1A!~BjJm8ALw)orYdR zAO?=`x*{BoIk(cd35V1^=@8e)$Iub3OBCUVQ+(8lK#wBLo>2a0Y5LIA2<)0Wq43w7 z;u97(J;-$Pr=!V4RA%f4IU|RnGaSZQXvR^a`afvm(M;4PMoW>2LkeJWDX+N1mn=Ja;A_-YJ$Ok!O$87ybfSk)=k^?5hmJTP@t&FoAGA(vB8mCYMd#5d!ko*+?< ziMhvb>zKMh(lHZe?)4P$WLyNzpRgcrO%;D|oF>oKB);pEtz+HqI=J5>sp56V8p$U! zeMKTay#kDHq>9fuy^-OO!=!JF%tYl#vOkw5zT(W)QDVibWMa#nlKEkp_`Ex}x2t>1 z&fjaB5=A|tQMtTCt$yoJe%1NIX|)nuzlpDn7}fKrL-)tQCC=7tvPOY$#6}>7&uZM} z&h&Yacr8Hy=nkwbQeRv>*@=LGs7WCFb`zHmWfJCiK9&ZOQ%(MaO*a8)r{ZD~F&$Dx zjk{a9Fmd~cwmosYp%F^QwMCg2xAG#3(s%0gt+0>gI6ml*y2_CvEw0{*)jzf1YRzMQ z+JTA8&p0Sgl8>ep>jO=p#(f^c@gMOK4ClQLr_1?u926%WanuDHI|AXeOZ*t%P2q`- zhu^m}(O-t~3Etd$6fbYo(fiDpnFmGn9ZKpA@wlTkW(C+4hYtch`HTrhuGiPLCCRn-# z4s{(K<9Qewiht8gI1h&njmmZDSXJ`#X@sdl5#b>-0MDHd6B zlMLPD!9+PasK}3|E6=OPMYHE|5sGC5B`qcn@vFWrO!B1CprdBK8d%a2X>i6Fo&*|D z>J)Di^(=oz8sHs(gB5v`zJf`A!DMm4^RqiVjnv1&mvC2;RrF4J! zG=6QWIDSZgHpQiJ{ED08BV%8v7{t<8AQB0e6i=ZX4@9FQ0Bw0)1@dj~F3)yP-a%CO zaT+<{I#^yp_gzwU337lLK~0?U)%Cs+R)32kLrYIBUK>@qDAJdn@?mW;w#$arXa&MW~*ZJGf{(WXeXad5VSYcfsh|pgz&0lOLOBs%m*il{lZK>mYlTPK%bX16EAoD5r zQZgsrvDoW&)U$X>~_A#LW2 zifbVGkEv;7vo@URCY?7#nE=5&kQ)R?ws}-J%0<}+4Z&#tl;wg-=6&Moba(#4X>*Y2 z+DS4|xcO4yX>#!~Ri;TSsH(nxR2IRTpWW@lTgbtd^`Hh9R!G?F))aGEA?k;oWreyCLQQ;ZcyZY7L z;_O{L>Tan@cBH?@vboHMd%3uLu{-}K>0XuQaWhTaxm23COLKl99mlZS)4UV@r_x0D zYLzDLvQ(P5^CU`>^67rBxB+Q?FGHm%R_iqBPNhkAY0f(`P-$&xrmWRzQn*T!?o^s| zmnco?Tkbc+QKWg-B2>F`=v_wTud>q7k?0iJl|9vt7fa<78R2Q!<{9&-AzZWRRopIW zJh2uwVi{8=k}@p*2Z>y4n*)#9=xsDDf6BAgyyC(<0xt<+zNt0DWjWlOVrd&e82Lsm1? z4?_Jw*M3PsYw5_w?lVqN&Z5r*;h|{vVXk8O z9|*GX$oNn3dnA9|X)`AOL3*ymHfSeE{x}l7E>WW7iHmB)CCl9TmuJnC=;DQQO;oJT z$y}V0AW>=PMPCuuBhmj{yPDm<4Vwx}lga0|Zs^tP<1KDL+^7l=Zn#wP^jFtaLPUey$iIk_}Ui`8+2IZgdBvxM4{F=kX+J9Zy(+VRcSz)Bkp)jb$ znw}pJ&HOBFrTpY%X55k>FVc&a+##MrUOuyab#^UgR=wAI&l=uAK+yMm-< zQsOIAUqqHKeRyUSvXs4aRQwLIzm~H)yIG4dvYWdt%Q&*tdL7=})V)oe3dU(j0S;I@ zJjUG!NkN9&q@yjXN|4c|9WtXmk@5I;Y3X;wdo$hn521%V8)b~+vbLIiAaav9Wt2Cu zG7s65S@x*1`jRVhGSkx%C?tEA%gz&DhC)B|&Qc*7wi__AM#|As>Uu^}V7Nfs9x4LNSbzDMRj7UNdx@bzL&hr5LsK+|xG zur%clG>?K;nfo#Bj9M-so9E1TiZ@P0uXp1t)8I}Jry&br#x$sUX8u%MzQ&z@>FKjg z1AYd}>NLpfW=cc4_VS>(4r%-nX*6248o|4x(b#9#Z0)6nPQwG!O}6|_am#7${2%1a zA*mV7mN+T0+=>I?btGd|MkbYYxQEQ>~a99Kg7 z^pcwK!BmH;XVw&xoMFN&KPCt9=n2azx8fCXN0vMPhRyLaKQW1NN6<{vatKR$1Shc} zh2jp&zh$;g35#zdg+HC76vi-~jt(bG=zj4-B=lbeGiF6j1X(qfQ1KjkMWYK{m5fXbor>8eM#XdLQSniaJO9Pf z)yZ=H>(IXh)*&||KVd_SGt<_RDy310YG+j5@gs-_=T(aJse{;nQCP~yLNjFMV*wAfp zjBXTrsihnIV};TUcPo?XMjfcra>Q4m+oviMI3gT&JQ^D6iB9RBFnR{IE{ENgvUhepF$vO5=Z0GGXToc0ZId9FME-m1Ckl(2lers|>tU59lR;LGtk zCDlfjURIm99@;#*b&lF3F44E54V72c3*t6t^Gx+zwMnpwm_3W~N^Tp>*{&TDcjdaP zKeJ8z+PN_@&_5EEtDnQN=Yn?XxEFn#*!TaA<9)jyZNuj+vHZvywQJM)UjqM?+r`DM z4N5+}Q~~+e8y+j5c%kojtoUcae$RICeiw^pc2j&jKZ$>3ySUM{k>2Q#T`x!$X-W~2 zAM?7PNCW?G&Jg#yHqlD4Y#vl*$*uPhfB%r-&2+5n85@^yq|ItVtk*#$x9A+6z~I$5 z-Z>r}9Kl+KbkTj-qes^`+%t{dy2H#9uXPyJe>hY8Hbw`^q1NFgse^bx=^!4Mg$^&x zLx=y|AwK5bh!?Ed1NfjE`B257J}Qqf8`hgT@wjU0QVmH~=TLNi6O@!~fzG2*eO&-A zqvPYVvjcT?l{z~zQ&YxtscgehX+aF_$d2+qJt2=9)&CU`KaSvGCo@;zAV)UwC|ml zEq+%gzR9+jr-aW3#rKsZu=Ut{isO$#@pHDrJSBX(Uc4qHH0^G$o2?Q?^-t@?kyP@7 zrrm)#M7wdPxGEJdCsOTD8P1ZGB8w|Wmc7c6V`ibPdTgiokc@<~o^_=6H;AK3!Nve5 zwNKSQs~#$RY+}&%mb9voM)l(j;@{2q$?P(dfDeSkH&{S&!_Fk&J0bD7)}WEI(4R01 z_!=ob3;nR$wP%SRSpql@bCU4TS>hEX0i`@k2Q{kya+dfL$7-K_tk3Kcm!y$L?ZxTm z@r_gbQ^%{g<{`9UXEV^%k%t@_uE;sYBu>gd$Rq6Qn$2PwLIg4&|fv!g2#p@*`5UP6rf zC)HnS68GA~n2-34Uy@?zA!rx#QoNX#NX!M>UTYGcIei0ZgAa>G52*2(%tok7fo=fD z1tX!Z0nC;0eRp)c%P_V*-Yg!9i7azNnUIkIWaO2$$heo0J4Z%`d$8vfhD>;JF+wkf z95=RophaAjCw1x{noOVATesKWvk8Fm|5okY5Q ztyTP4i5`KuROwTpo92nts)w~Y2q;$LqgU$Z&~0RRjBbr>-#A-*WRuLS6nG*nr9fy) z0*&LQK;t+IOs=~QDY07|lSX9m>)XUHl@es}xSUav$Q7lS&<~R3?B;fHWxiRAak(R* zu)h?V$UjbE?y5i9Azsdx6*l&z7pv;#uTfPurZ-JBR}RBF)fl`}yQ4KsHr$uX>a^asp*nw8^@nzgqnl-&kJZ4c{qVqjb@F&om_ z8U&P=;&@nWAV&nN|D1(}{2cLo!i3HC0{!FJC5#q?tdXV?en}<#QfHEcuh=6#SRe~O zF2{Q4B8F#~F7`jPW%yZ@?z0Kg-Dgzaw@2JwxS86sv4f-I+&UW%k&nt@0X(<`!w$Pe z9}>p4C-#aT7fN*_{iBfyG=+OcvH5_m-&uJ?u9@iV#S1g)+0Y0FPJ8YUakXG=C5rKm z>~(ZYCcOQN@Pc#3Mgb)qcakW33D&U_y8GXGh^0toL#~=<w~J)v$!i z&mAwO6%uNel{X5eq>5$bslkzi*dK5#%36YqT{GoMzET^68Py)OtKCV_qeDGvWMgc* z<2-SHtm?|DG%W}7hzAntej=+bS~*{o}cs3`q==a;c7#2^)>ZMFNlUgUT=rAlPGxhhhX!V=t zi)+i|Vw+d{~PL9b6e6nb%}I6WMC{R%f<9PXU5 zCKR(e58Dx2yWKg3ck}SAEF>H@@4A(!Zgi4B@5W=C03P7zST4&RB1t>%{Y9%4*>cTetKqq(Iqa(+?rMB|yZ{5KnDH z^o{vET-iBfzEZsp&&Jef^~(`)b9rKw&4-l#<>V?)>)AppQtlDR@RTV;+v9dj3-)Lmp+MBG9S;Xe3%bDnU7~@FtQkq(>QJ2 z@?*W?6!W9e_T9C$!S;5;ut@lpZFdvC=LutrqLwz}-Bw6ruz4r;VN&#WS#-5IdI;y2 zbksH&@3aE2n-6vbGA^l;lHb=1p6L6Zw{}1ibsYHP9@0hcb@xK-w>|&oPv4U35Npp;s}a(= z%J$`Ay|HBpzKLEBq7$e5of5(^FfOl=o_*DX}D+x@!@Zrr=CV z3&qKm7E+6dnSwYL+KEI+*96UxVJ8^IB8?LBVvQKa5`AmQUTTqudD%vTa+K*p)|_eS zIQMip-O|m9Je-7+g}_tf%_5wDla3&DHqNSaL*1+<8aBp81Y?a3_oLHxn&P0_ETYrR z+H`|J_993Qt*l&t%|g|!VR$sHG{Z2~Ya~5=QF;bM=PZ$G=2l4Hbpw#~H_#1sEF|E7 zwA1AcvX!?~25ef6gpn$@t|UUWMNknjevTy>#&(Oa6Sg|TLM>Hyz+`8}29UBu-eHlIxGi_T&DGKLIlvtBRAhh`ugp(_^&<)N~SSdYJ6{%sItxziJwpCIR`9(Y3(oKh= z8OH8a(woj%4R6}BTKf9lQYp!?pa6{fG-4R%@-37;Pu&tjr@A$aw`opF^X(cbSVCx+ z(G)_?SBMJfQV7w}5%MopsYc{266&EFN+wD-hSBSmU_Sw>=zVV1)iC<`7O^f+w}x>* z2b25(ji{6dH9v(7kwB`C!}10)MsyCy*asDIX2v!kqYBAdNqUWG#4yIoWDTCEmKL4d zZmfpFhn9&AY0Gi8?bJ5DfuZF!-%m;Le8YJBfako@o|3Yj;F-*V!d$!OLEv)2Ycen!2R@w0=@M%*flaj`=yQ@9_$_-7(-}Je;3e+ zkr8bCGPb>{s>EL)|CN`QV%LYl$jHQYY?nSBohrnMd4+|&z}ts=$LW~7!ou!;{6qJ1 zWMX_foz;OisRpBvIF7`z14t*n$3@IRUw0=xreoI6`^V|4#G+vcnCy)X4);X2_YRLn zq6>}C5X5<4ufgch_}EsIO}DQ%QivYLTd*OHHc%#v^hy&Fj?729C-xIeVg!G=ueiXE zBd)+R3roLf3m+P>Y)-$Y>WBlFc5o^sY1>CMLdPW^DmyB z=m=&A=2^bvfbo`-UL$Q~n#xny0vorC_YX!B7Kf)W6!X=%iGyn2&EHPv@41Q8i6b97 z!^#_*eBB_$?bAiOK6IkH-6?km=`1Vq75U*ElVzQC(Mh~qC&Lhq-COi=$#FA$c|-?_IqeCq;S+>y#XIV{Qs#N6|xX!@+yC4Z+%7cDi{+q?Dne+D?c>RUGWa zF$wr2HagGZij4Mpl%eO-W7ch5EKL854abu-2FGXmF*rWZPrud1kI`9rm&RSjo4*IX zn{gMINnXf?L!Q2b2jO}wLc~ts^4M|3A;Z!1n-_(rni!t{z|n;=FT(N6FfWpiZW%pb z)ur@Xc)P~22?6wr!J*&6n{+th<8R?6jf0QOqrjwXKXm~lXi>A?=Z@N zpKZf&!h0HZUFEgRVfbL;@7eIvfM0FH*8y*};km%^;8z#oZ^jVsIUBwTxIO*Tfxq1r zj`ULsZ8*|*|E~>4`tAp8IMR1tXTy=cyT^tjeK)2;)dhW!zT5O6;7H%~HCs5ITCR84 z@GZdcNK+U1v4^(vPc|Iq6F9$W!*hVY%ZBFzud(5E0<23Le% zZW!fuI{alT;rC$pNDz8add7boCJB88W|%`BUDh=qW#A_(ug(&t%xjkjpRiF2?^?!89)aH1_ATUZ$h{ zqx946Wr*j8#GhAiK_){l!)*+?oEKcn_@fMUyjK;zkn^{&f$>Wi-oTLkV&N+aPe+kZ z`srI4HZsI>Leh^i{HlT(ZicHE;u%1E8G{TjW%z`Gi`Wi}vKVh+h<20WEqajQ-xOTD zogv$IaX;hmFXCVPX9brmVz`lEfFb;r_?EDJmi(CUKPk9$8N+KB{(#|&3NDK3F&s=XTt4l<`k7WP5tF;8AIl~VzyqDnv3^~8+f5iA-70humM1?22Kg>P8T@N|Y;A2#e@d=JC7 zF^n>tWXR>V;ReQ8uMO-!8@L=du>WlM9`pTN!F<*upX*)zzcBqV1vhi~Zf5`8d@0kp zz89n@ydaw)+qYmlh~*Tq-HVEt&h{>9W}M|0UBmb%8Q#Z`+sUGzF#anAw`^p{`QOsbIJYZX zxZZ7HJ8!v-!#}GaR{Evi`p#f@mV*9e4A(GZK0n*f|81tfs9-VsM={r{;u{s+><>c! zO4yeA|2~30Q2lj7)vF>*{}h?K$&MLC*rss2s~fOS-(eoNNKQ?LM<%+5x(2ajRFOr) za`<4>PN4U->^L@O9#%LeU&kT%@Ssc}qNY@hBAS52q-(ejZye$ED78=W{?U;lPPMBW zXKhXv?H?VU7%3_a2L@@E)bK#}NZ+o|_<^XmI7|ee&lWS;oMr^^5A31seZ!IN15+J) zTPGrwU148Yg7|6~7ZDEiQE<4?-xO#Ig)4kz72&;dhhSTRCiBoJom&z<+B~9LTZ)?yS*xFcJ z?A^Py(eL-R<1Q2o2L0a99xwJ=Za=5o`>ytmUA4RF6j}kaq0!qyn>q)*!J0s&w=H;f zrMI;$*k0)k;=s1aVxzIY+v{z^X)DpOajzHF8tCsvp1Pu4-TmRg=wM`EG})B8txP#{ zx**H+FrM%joDEe$1YFhLj%zPL1$>>Q7aay(Ha(Zj3TfR-H&&Ijqlvf8- zTE0$VX5;J$#jx*_jM+GUoD6Dota6-9tC2uJqE)E~DKwjAi{()ZJYT2axbyM|8P~GF z96VXZoVPEi*l~^C938a z<0~?v&88m598ilmv#GaMDIvma>M2D?STKk`hk8kmwfWXdjytbW%K9-=)EaD?O0gHP9nJOBy!<7<}%O{bafRmhG<9Z}J!^84JWR zvBI$mFU6lKXq39#Y19@M`KquswMJw+h?IeV)kd}px2Iy%DutwGO74aDzgQq(_Lt)e z;H4;-*N|5!{*!Ed@x9{?5bS(dr%1$SU>+%kZyRvT5ttWcfiBE9NIr?+UpG(>puTiA z8bQ$abbAT@QCxlLusC@F^Ay6PnE*9koIJAy#qtbF$CmDj6~H?* zlM0gz$q7Qb-n9e7wx=p`T80MS$kxwMiZ`EbU`|;`W;`LjDe9Yv3TE8_9LchnS z%M*`*X45bGTHxA#n{l5+zwFx(=EYB6N$i)6bPbZJFU=Qczjb6|;?)=PiI0L{)6cUS zxYn-#_eu2gr{DS;5O!=jpEv-TO}`w~s;>q;O z=|R{P_~}ch8>e5+ufRYu^`-gZ^vm4=hJVvcfXpW_A8Xeym*lO$kLp_?eo5@-MbN?* z@K0Yl-8lVb{2a(1 z$=3NDraGR1pT2auar%u={EIXbpyrFyZ{!HVUQED;^#!|r2YY~%?~@;_!;j?S7vJt4 z9KbtRA4izJbh=niF?GQ0A<8Ss(3if)^CE^1zULy_=u69^=b1JNZr|}2@U`NGep&dD zJW8VvzXka5b%gAs^Wnrj@e#fkKRaIsa36k@U*gex4Y;@ST?SmsbKCgh%={^XY@<;kn`dYtuKD*yj{A7GDB23F$Xyc2|$EyfijUT0(o}BOE z41|p^AKmM8E|k?8)uhG3qaHMqx)p? zN@31p2&ep#A12|uipp2p1#wKiQ*lrAg|82wjyb-eF+g1}scdX~*E|O|!J40WX+G+- z+W2m|0vuf?7t7mH?8i&m*5xm)EUPN@`^(Ba9-kzu|5$n{FE96aN=y7z0JzRy`0ik1 zy>RH{AX&(K*$6lNiYhF!y?syN|5z+Iara zi*H+R9O+tp%(%Ed@AWs|{M-4_uOkB@OXa~O<~>v_@fSr-+P4%Z<76{(3p~G=U`~_AazL@bgNF%-XVmMvdF*(k!*d_Tx2$kgQK1LMgGoC!-$#G zRE|Z%9QeyIr&!}~q(IXDw|%VbG5^Ka-^=#jwb|bAy@|^yrzAHU;-bZwi}133sz`OD zI@4Tf?zEJ&)U>p;1!)V@(o-|is9lfkwUCl0Lq?um4@W{h%=D=h*Vo3t@{2BWy~laE z<7(-WPjfxy(+B7Hy~SIq!-3eZg$!{rDlz9%3~;{OsA%~6Kc6o-qjcsk9b#Kb!l_|w z2c{c%$=cU0J2g)meK98_8hv_C|D|Z_RsvNU(`wAz;}rzsIioLjt5c)T+JFWOVxRUZ zno*)>S}SyjZSUsyS-tct60T3l#9PWzK3c<*D&J7;t6Mn#(?}61%iYeD(^8f@7o@C9 zS)P)G-%9-Q+~O2GPjwrP-nZkOq#QNP8*xvzl9#{~bzPt%7!G@K>Z9ErkKa@5^H=1c zXu@HdHKqW+Z)Zg;4E>=Fp{~WVRuuFr(_yEP+ppVJ3w)8B0A}78o0Hsr9OnC)Z-GZ z4+c80T}HSe&{)5xrL8VDk`7hr$H>z`bx@F5D-ZwGWZNE27M`wF$A6Ewkw+CglVQ$c{`C_24F&t=b54Lq!EuCK@EmtoJq06xBHLiqguG@=}m5 z;v_(}lBg;!E-9%f_LY=ZmX%gilvVmFki@&mkjM*3C@V9>5kUmX3@GJgWhJ0pENPS* z&`OJ|N~_8%imS>du=pcGC^s@Gvrzn%rKRN+rD*$0DtuLCW&U!184`Q1fNazQxQg9; zS6JjYE56SPNo>q3Erwaz^aEB5m2GL-t1T+$oh^Kg6~G3t8~R!+)HH&!eQjQ1dtWat zX4*iT{RSI3*7zT^g(ND18*SmH4ks#zo21_LW;xjX59M^T8O-Go7yhqic;ZsI#SEWi zq1tv^@PKcb{19YoniDv+BUW&P+8GXX zv^0fk6Sb^AiU~(tyQlmVf#;&{0kX|7j$ep9wG9DjVZ-r~M#z}I(Fn9dcj&hog#d0B z|0woA?L?Zq${}$&yg^p24A;^_3qM2rg$Qsai}F{ZpwukN--rU2krb;rr|3r45GVfjmq#1 zr<}=jEuD=JQ^b5XP?*rY<2H(bVWHm4sd9-J;1( zG_`BCQ%xOP>{L_JR+SbV7pW9IDt22W7I{>hW6?}C_gFMj%e|b4CGS~ro{h!=u}h+j zXsY-&8`0G8?J^mRX}P4Lib)fm6}^%Hvmjh{7p#|MrwK2M1M8IwVm1Ufv{tYNztdXNYR* zHU~P;CUX#-Fw`HhahwqjH@DzzKn(M!(~A=s2gXLCkvyFE6dj)!9YQk`K$pHfSV!sT z?+r;b%26n{~0P;hITdw>*Ua&1S1i&vH5uzOyJD; z1DIzZrzUfI@;4!jVx5JosW`+OmvYyDoStA-7=w1dkqRn#hQRPm(UASN-L)N%z)9hS zXY2uQh*#0jHMg`PU}$*65N`n8Qy&6)sJGt`mpTb0OCIWl8LtG|9y|x=Sai}5*8>f; z*W_*T^bC96LDWcJv}a-ei=gX`Y3XU4{HqZV?tZn2*oMx;uk<`cC~ioO?C}T zM5*lXEmqfokztfE(+qKyi-v6HA}}&=q4}Jtlh1_eY0nuo5sUwF*@O2dO1$VnGi}aC z_}RiU)A12w*Gf*>Bju#bL0A7xh#^$}{n2sEhctJzwKU2#X0gxOKU~hAihX4M{k6kG z(lg6-ijV;worN}h=ZZK0+>`>qpMsK2Re?0{vJi&Mq_Xf;d$N|ljO#j8yc z8?*Z1RPm~_3XMWdsDsl~@nnl&+t6B-Kqoft!%<)=;IA2wj;CYf$9}j>$5R>YMcF1%;(3pDx|i#0M z?U7CLKUb54oZzAit;a71zg#K@wB4AI52B;u3pa#!2AhLzp<0wgj>9E(Q2)ipeHgvo z&=jBvH%}Qo?9io{&VUn>5H25vH3`B!)M1z&ON!mL&EqfMy~%SCX*Dfn5{yJKf2r3H z_?e4d1}z`R-i>d!;XJ54h~68d@yR=p?bubLB+sH*`jGiuZes7T`2g8l?*)DD3H-;B z`p@V&%6B#(KeW7fI{D5iXl%#nqX0S2ji#6Sxe4dFS5pu^qeZ!zT~q3^jrU=fK$Pie z)WL1TZr|p-@LH5I&kLi^tZp$~T+zI{5$j=<1TbeHr}f|JxR!EI)F-QkS=T?sWi`uj zEsHp50vcz~MLxC(KYB-+-j^z%vVleE!!KDfn2b+a zGAI!}QDC2__nn}?N;zDv*$vr;!M(M?R*V`<=ZjItjM1QDOdEKGVng7a z_0UES%UZ15#|Tc8&pxzKjU7B>GN&8zH*KWhk0CCgV&G7}XR{|So&`JyV5(4338P`m zykWn6y|D6Qp{tD{UNrA91brC@&aMx4;}iPv{vi^G$+tg=hTS`Z;d8J;h!(ncV7O}> z2cuy>{!nwM13d(!|GLT22o^aH(lb2KJrIp&JdXJ^6)%~n{}tHm--8E%IoIXu4Oi6H z%54M49)A%sGdMh;xrH3!uO`lAiY4Dm9a?21lUS3-oV_DBo@{KazxS}TT%KCjru*&N zJ&dT_Zt|RovW2UJtvJ2JxOEyCROtAm6YGoT2HRTj7y|k|Lh+1hZb4HA3zdTQ6wx$+ z)@Pn30$V5O$twZr`;v#uL90ctN`}Ukoi#pBUSZ6#)@x>vG@i#dRVnS|qtst__K#tw zWgIFr`+VvcF}c)4mB%+Bc0UGw=xM7Z#=N{4O}KHRM~5FyU}CZ{J^!VZBZDKQc}S+f zlXrO2CeKD>2*;r)7ogJdO%kV)3DU4F_Siqd7I7tNdMs*{c7$1!s2L5~e}c9DhZSeU^uqOU zN@@>g(makE3V)6jKFRe+)go1rEV|cLoph@e!(fF&udhL`p)UCVn7LBxc2Tm&Ih7Is zY4?*foG(vR4D*7z6_~N1)iL5_YB3P|Er^|fTx<{&?fFMIEbV1O7gt^jow?X8KG|}a zD6;SgH?2){_m9usFdQMqE|w6;eAG>CD7qt!b^g3wOwVx_$M#hA^wR3nfc-&D!>4cC zVz%b>7Ie%ya)GCV1Uz90D4s*o1*&_gp3{)y_*IIP1;g=c8`f$#eq*7+fZa!3}q1Ob?pJ~TA~yXH?XfhF%8T;YR$f4*AhjBidanz{(51M#16SaxaQe@(g0+?LND=zUROA1;; zQ}={9z1=Oo8p9rwSQkwO%ULv5b&7R;-ic4cSogaQ?)ONlc-^r^^2tnJ zk;qT40OK2};&V=KWO(E-=^G<6Q8|+A&!vg4ICFKBSn(>E*s`Z&ewZdc@6PS*>K?Q6 z_u8gJQIBX;E-z85-#V0Eb^dT#tpwL^;%g&D^*rj({c&)Kvo)KnQ6L<#5s2Zl8n?M~ zF9p1oAOLg+Ru-u*uAb~fz(CX_5PrLf%ZD-vb37kQ1Iei-f5N7lfV5L_F^QNCsiMZ+ ztz4M6eMH-yINs0*rQ_P7OpIH3kwxh{b^2D=M{^t>bVyz0NRbv-Z^i1LT5z@IF+c6V zMCNB4lqbnY(~9+hrcmQPkKy=__y~scUWe1={5lSg6OTCRf{h)4@YyAP4DhD#M90JL zTbk%E!}tVm?mdc^H|pqpX3WfkqWTUc^@e!d(HioU6!}a2WmU!Hc+0P{s-g=1@|1&K zep1SG1TfzbrnhE1W!NS~JZ%d@vf=iIP<;nRi8!spd39iDF@u=G!QDzA3q@A!Y%di4T?8tVGCvA)l?g@%pWbhd4FmzM66j&42EY zOT49209Z6^4>i?c5t!aVr?<=Hdaz!$HNDB1lna`Y&iJ4&O8aUK- zc#P*^Xejdsk7EnU*8@y zW8_bZVx{s3r&3<3<>%+YCiM1!Cr+X7g0*#5Lrq5>UX}M3;9oKQD?wJ!nWk7|$xSkJ zlLr&!=%6A$nyx&r9v97?$3-ZX5tOu;IK;2|x-iL;N`sD?`D$QEOQgXWXLu55K&ex_ zP1Lje8EJrb01j56g;|<YrTwZzQypWvR_Ern1YlOz=QL6Ie0|XCdRE={d6mB#mz?hbJo2z?SW0&A8VkSQp%t=;JZU4Wlk!rB%QbCy z)=J9K%UBa*MrQG?c>l=Vdawe+Fsz9iZ;B(%%vPK(r*N@IyvMn`RaSGkN}h!ml7LfH zm-uFJ4RATKqqZL1_b-YYoXZr2-&ng>e8icV|64~!cFb3Oj$9*~Kjg!S-i};Xw*Jab zqG>oV*?3keOS>8NW2K~PC=v}HtiU1A+r&L-?)(RwGl_g4RwPg<@}&eKarAN~#+MI5 z=8diyWI9&H$Rt$CJf1)%zHQ7D|1G`)nXk+!^MY8JKuM-pJzXZ9)Sc<55YIs7Q|_f? zPQ1slA6s0@qKh$Tg4}1143CYs_x1O3Q9E)o44FuGKW3SG!jZ1Ao^VgEU)nlM$HZqk z-Y@>Vz@2|AB`z_s&z@K!v&1GQww@p{vXq|JeHy_^OKQ|2yyHWg#Ji z1VX^a;}HUekc1>80Zc%$LL{3>Sbg@HA zjK|UJcA2-s|CCI`rzx2Txs^b`xE1r3xE#D+n4aY6 z>>R8O^jh6e7YNnet=l98y`{s0#rLMbu0a1lz)p91f-SqdIy$=1l4O}Y!E%|fr4>)L zjpW!D$Q1^Wq@pj-S=ZOm)rq%)wVVXzTHV?{h&N{GEjaXfiSmSWQ6oF0b|~WSZ|&$B zF0dR%S|)a_coy0pNcnHmK1}bzFumhk;$7(d)Qn@JH;;D5!0KUo+wDzm9`^%rX%ZS} z>VLW3c6*cFQ-;JX(EI6GGmeRu%Rc8=c)6#qH_*0+8=mY#d7z2t^0FI?&k;XFQNB3) z|6WmSwW5mhp?CpBxpK}(Z?bxnscM27;@eZb)T5~02wm2;!R@-=NHFlo=16+-)a2>1 zCqZbA<B))F5rj%ZPrYAU1))Eho5t?ngl&bT$>jL0J9_mxIePl2u%6zGaGBkBQ%FA! zHW=)A6eyG23t53Q!eZ1EK+zjxk$ zQhDl8M<`E3Q~7D`SFc_;OYcftF+>1m#N&BpN5w^^2Pc+~Scyt%1on_3F)(;xv3 zSkX7Y(+EjHft#eGO7gY|2c3Oj&)}#p%iMu@MxKv&-qHh;KuoUuTR{A-c&i>p)G)LKUKEnrWTnO*Vy+ zPf-dbKAxT&cOa5NbQ3=PZSi|3^!(tjh(qt*Oi!UDM%KBC2 z1VoK#w#cH$ax-R#+ac0d+%Z~GsNmnFMvX7i~ow(QI z%6dF+Oi^qeQxvxiQxxH2iXwZZxx^14>c0H3MJan(qR3#jQptIU>M|piN*XXNC?12T z0|io)eMqsE=OeW|PtTB=8tA2_9(uTqH9lITSDarI_sw%} z4CzuZ@#Qk#(mv4nBe=t@^LBZXm7F5#4K&rynzd zAg>-#@)@RXG}lU#x>3ljJZYqEvJ0Pcp*VNGE9-{kW0)jTpCsKVQe{K8#1P#mcao(W z{9}gF4WZOgb)yN?ap~ea(Cw=$A~+%(b}&%W+YuPnGhxgOY*P-qEoJix-CR=ojk*71 zvOAMpG@b5--Euk?auAojaUA!cxNw0h>w%RM)hS~AwhmVYx?A_?BEXl!bsAM0S$pm# zaTTk8W`YGmYN5!^#ss>o7|Ge4_YMhz?Xjt-}$igLqi!ARZov4o4=T!;jX8 zFS{1u1*_&Vd{B;ZsOnH3m4}!O&zpQ0uIgG>2E{-hJurZP=+pu3+5Vv+@NBNgV$PbN@|0xr%NN)Is>yvZ4xm>)jb)((Em8~bB zoKf${ZX9lVlOxA;qpx~=t@ymmgt{Jgrq8YuH!B5e%UIMF)&8t@ zsPKWI9@|^eszn+lPplL7nE6Mu%UBFPS0f%|2BRBxECx^3h$plLwOoX*h(*BHNa023 zg5CC=Bwn-_a2Y1V;gOTXn~DQ!d7KVvl>Fl)@d4**9)GSo*Nbyw$)h&6jO-P{M;)W& zt@YxvSbEL1uCBIh6t9rRa*s3)In`~o;;n^QGyu|T2y{O~GxUt)MT?p-=7}`)?3PgA zJkW_Wtm;NLmAq3cKDTI*&Q5bI>adZ$hqB8N)Rvvbj@I^e8kF^T2{x|ZmfTw>9hzB7m_yku(*GRx<8Y}sA*N84Z!i~U`=Z`*2*~C z78qp>J*^t_I?^D%GJ=6kH)cTkQ9)?J0u>py8Cso4x_!4%e56w@2QQ`}V*+M4He3stwQO+&=4l z8*1}kEBX8eaq|+{=0i2GT0cB+OQk$u6lT%mjDEw%-jLBBKq<5tQiFiwSAO5(A%NzY>d*|P7x1D#!`6bL+qcJ#*!peXFy76> zx3b`{#|*V8R&AIhf!>B;oB#%JOf07-$Hb;5=bc@0Uz_-4ksN5k%VZ5T`Ne9YNo6uV z3@H=MHub8EoONP68Mb=(Jywv$LW-1AHa!U8Ede6-*YMItyAGJ+VXCj!e5HB|#>SXH z$s6tBhT_O7n}byT8>6c{VrC1iNVy|QIdhQis%Arm%)BI?(c|%1-Rdcgp zSR{PQwxJH+^Z2nvQA3k)wiQ!bRlgSdFe&<37F}(QUW4;XS}N8VXIc^1%?CRI8E06O zW_+2sp|-5a_>4tsslr#I)nzrc*b&R1qeA6H-^Ai}%2Cic7kC{)hH!S)QDkB(?N@Ol0~A#(-#?3qU0zP%^4eyb5Bz!NP!udI0?s%$eA*L zV~11Y5v9(?nH6uSKpN4oF*Y(7b98(@CT+*56clt5odR>?4FaC2;9QfsA`Y8{s-R(b zHLWngFy?C{K7ML^0$8U{lWHzlE9;J!pmb=H6flgUT;x1q zTFJDP)10v+&mT+8WJSR|F*3#ltZi9|ZVBCSm&LWxCC8FBv{N-~U9 z7GW)Hwc0{0RoB2|Cx%9lvP52Ek(IhcEVGC)7K1Bs7flmbu<5ZoJWPVB`+0zL1Ga60EX$ny>tqLJJCPMj1N@}|d zLQn?gBy=-XYat6_9;5V=0Bf`+j}M-%^UjVQ@IIz7ep5<_Z_eKG(Z zL0tke_D+SIm{1C&Um@;P(rZ8?hA~(qTkuecwCJu?Mj8~}JzXq}O~Ki=!=)U6q2)E% zPf0Pp;eLFF_mskpWknqYry81&lY<4C!LHVBZ%$5cpC8)};PGB}A2zte^Tr`OlEcP2 z*b`qyZlgC8=&iS&)?kqKOC8wL)7IBLfY^?%R-i+{AU1v(ShaHHvixlMr?|KfyFTQ! z2ZvT+yY#`pa1Kt)%gN~k-rUzYNXO*mIs13AcSKF5FftB zMb4hQHXjYsAJ0Ssbp%#*_Vu?1rWiH7VCRLsdIG(J11C`3bmX1-`lnL8Ar3nc~;R9_$+X#+gg#6;Xg6w=8afLMFumtTYx@xI3!|uNR9aae0 zQAHhHySh38UaG;!wwQbg%R)~wRj66Mc5hDKBhR{&gnTt_;-K1h^S9Iadu}56aO9)Uue`A?uMMQIeY$AZ2Op-}KDj%H zuP8S!Hy_@ytH@Uw*oBwtWE|qLdy76Uc_b5+*A$BbEjDbdk!KU~-qovcQlvMhQt?p% zb5j^QiWzzn4&JL+S5>jzPB+hplsr^c+X<0qianh;CIO$s1}0fu?fsozW$4Mwm~~$l z3ghpx;TTCnaD1j8g5v}I_#18Mad#Hqrtv7_!9Q^bpyolHLB1H57 zm&cB)6fz!Nzj;x7jEQ0V2aYL}c@d5=!@P(;re*Qy_tmBJn{uQ;U+)I43Qt|cq%OLmu)x(sJKUMI3~ey_td$crV&;#6{cX9}nDbi--JZ+OtVs&Xje6u5w|5-w0Dl3vHqmM@0$Nr-&$oR4tIC+Wy1;R+m_PU%aT z5Adms%Xs+G48q}KvLui*kMJjOqe<{79LGw~MwjV8m+%?GNTc|_G5&XkALDKnbb)&H z5=0#@A_&{gCkUUC5YO9Xd<)0JPbr;os-;gV;adK=xVa+yLM$8D>G$Erjd1vF0YT^` z`TU+C^po;Y*Ak-K60T>smEjJC;4kB^VR#$EhZv&#GX8fAQEtK=sACD?;}TXe9ANl4 zhUhr7`&#|3MKa1f541dY+HwwljGt6LE%8=_h zZXe^1G1U3qSNIez-;{NXpUd!ShU^zp-c)!zs)Xzje*(i=h8+xVX80Wi6I={uF~k@^ z`4f5=p2zSh1*ftdrn(t#V2FN`@=g6Q!+$B5xQZd$H?fOx_!p&5{7AuRQyDH|SjG^3 zOX;SueWty{_y-CmO=oxo!(TCcRl(`)40keQyHX!Ve3LI=crC*>7_wd|bqY`U6vJ;Y zd_=(+Y=;^7j9nTLK%=6j4G*YiAX-}By4bZ-K~#SDuX zu4dT6kmY#W80UW6do$x-WytpQKE(KY4FAUPV+H3YF)U(;c@*h8pX+Bn%bh>W^s^XV z$nf(FA7J<}LoV<97a9Mjg6U3%Xz(N_-OZ5uvvlrX)7gL1*?-g7f6`fQ`sJMOOAJ|V zI_B+??^6tar{DtaFBY)e1u0C=U|7nqoZ(3fPhq%|;ckX!Gh{zma2w;?uPwNj@t-jK z4Z~L$zRB><3Sx0v>Yc%UpRs`PB@CA_tY*k|$>?Cbn<4vo2Dj%7wok^b9RD?j-)6}6 z%3wQXyw3DLF=T&PI7Q(L=QBK>A-9KxYZ%|e@KlBYhPxPYy)C?&an@@g`_DqI$A#=a z3xCP!UQ;lO^~mCOmvtr6A6IY**Y6Vc-zDcUo!fhMw8FDJ4B5Wfs~BI;kojj{%sAUI z`^Stw%aH3c`+bGyI2dxf%Bf`B$B^qM=N!hbVt5n7XBfVvU@r5?WxMC*GM(+6ThBQ2 z&%J{2uQ2=}L+&SYf6MsW3NBs5kjuZcjdAW*mU6pW%649QBgfyZAfEI~zs+0C@FWHE zr!$^j+-l&CjG&ow%*nrY#Ehn(eOCDCtxSg`&xD!n=|(*9E-1mV7#YC z3TRhLszxp?Kw{C=za4KJ;q@rBPx7|@U@l8-ZNpicyK=Yn_YDPe3;bn0v`ebLyDhkV zea+yGKt_R|2zhz7oTII2wj=+JO|-qQ|D??wl^gdI4+gtC{dq+Z@~g+V$gq1mMf+>> z>&lvH{LAx-misr$9fEBF&BVR^bZ&`%XK-apd*8ai);&eY5yoBb1PR_Nc2k@`ufJ>K z+VcFW9rZ#5{`Q`{-0jG)rA%fh@7}a$S^uuas-lhv8F~h~2C%-^6U4H2 zzs$C6m&~?(<@%P|?%h541uI6&2Gg~-%RE)JbZmovDC4Bo)4Q5>_YZaYtB8x;(E6-E zD#}`!d~mR+d{a+b)vi43xT=ze)FT%RE8ZdG+>AkaSN?-A zoor0LWR&C3rj9awe(yj=M$5W79AaCxYgt`Jb4FuTM%f9q1qB(KPpHk$&uB)drmCtc zKci+-2KHNS-dLP*R&&exiuIKWT@G|zZAJra>RgpkRbI9tqp9lT6&a09Rn03hs&HW2 zt^%XBt1Tm=38$?D1_m=SV6E=1Hk7F~(Aw7J?+Ns@cjFPwDE?=wR4$!vQ5njCGGNE? zcu=URGPFZc_VIYsi0mC$`p(@hvyWPfBibcb)F)Hja&D479`6oQUY$^BIXkf#kGDr; z!_H4U#^e2AJgC;KdK^!;5rILZ$5QR2(0KYS=0{!dWSxTZPRb)>UdsX#@MM{D(!QW_ zhxK|BbOalZ$$5cfFliSsbAO`x*Bt@eWjy`BxO#7^-A`zcvnmtHjHg|PH)LcRPdg4d zp%!_@({8O=LWc3QQ_2vrVvv6V?UKf|$+k<*JE?Xl^G>Q=%A8hJQkxo2U2;F9a(}XR zY2z`ub}1QHHBLnsPnFw?FlzNruwS0QOcwJazu#X_a&!rAZ{tZLyAW@Kj5_p>$3=?dOY9ucYM1BD}_Fp0~+i5?@e$X;*7DD?c1bXk`x zN1;dHFK~WA-_u+G|F)IxmHe;qsH#N`YgIz`UpgbYZPwfR76cup z;JNridG)2^!uScSQwXn41gO)6@pJqOagq389n;K%pcCt+MkRjw()_~HeGv)9lkOFy zTc?=;YJOqmh{{6Tb4O3-f?Y*0Lb|Z>M)xDlY2!%uOQgZtm3gs#j_X0ux*`}ucJbn; zFP-i(5bWtrhYfGgiEMFL2ehY)PX&%OD)Z9(u%2XKO-NtyWaC);R^sQzkNgxr2i6OT zAIu@Icq+eFh2>w(uNat}UpH{9l}UaiU-RQ~nEcLw*aL{y7xObnj!o{28Ngd~A{8ew zu3yb>#&*~xVPrbl(rx<9!fn2(ANj;6`pr5YW&dy_zi|ELpd4fQpVn{AkD=caBl(HP zL9^-S*#}(PZwbPq=;yf+aT)mOYZUu=AlD$C`qJsb>^F~WOlkGS>BMy)*!1(J0oVFv zBRq3jGw-=+_3tcPri4VP6Vjah3Pl{YQ!BHnNI8g&8A;El|$=?HSy8(OYcD3 z#rWw<%MH^n{cR*5p8C@1!t`6P1_|!ci2ymBzwn0P(I?V z%iBk7JOMv_X}Mwg1u6d-IuW2w7p7luFXCQ}kPgom?E3BO08YM7elQO|;*Vc=zq_*= z?_k}6IDKikc%EYFfZ%Q_EAh~m4r9CsNeADHBHQRo^P}-h8wJ77`~&G45ul$NKjKF+ zw&NFvA76XPPP!aUgee{2oAI-!YXP2zAC;HV=ydB4wx>HExaQ}wr3>eG8R9g*Xj{5) zeh=9A#n{p+ww3ps^KI#`#Px^+*J@-{xI?{a<{mzA-n*69Q8ztR&@Ov|z9#=_jm|f1x22IgW%<-Vc0Cl^hy0N9Z;svp0?Rrqe#mQGr+f=oG>cM39ntk!^OR6tB;J!Gnx**edYHIxt z%kO#atW4vj*x}TcPIryFsr=xJ#+;vd)*Swz`n0{`z?4TF`=%U7zPS8=drs1vvS-Bs zkrsDd+?BBh+&3hqrB>g2ZOrweI@-v4DyiYF@&}(gE7y1_-gjCs$=y`dcG$Qs)?LFK zcOCxAb?$?42c~8jPr29MRDRuaU0KFUv*sC|nwY1baxD-WAFtSPTE$$$U6a)GRJ_I) zI5s}+z63Gn<;8lM4*%sq`~qX+kEkSJx~+Lu929A54o>r2vOo5zQyMNgn0Q@W^<`I1 zKj^+ed?9AB@l1{3-}1$ngYN2kzmRx?fcA-3;%g&Vb|Wl1 zAT7H%IGru)GIh3F_QcxtBG=zR9zx*kwJK1=e6?0l;h6AZC zkmZ2Z?n_|nKOJ<#3aRO5SN!t8)a$2iH|8EU{m@lY;VsSuXJ?-M8{f;KeBX)vb^<#w8 z&7WV-%P?SX7wLH@3ASy5ZU6duUjK4+ z((5;!{qe^iqtPX)RvslLv6ixPd2ahL`_AZCocc$drh#LE)jDJT%JAh$oc7o5&ui`I zENl%d`pgha(!C{=dEDLNHkc*T2i&zp&Zc$b*}I?38QsOAK*FV)9fY#)uIyju>ZbRIDpD zIyNRYHa0GHN^E>gLM+X2Lg(+K^|RhLDYrLiyW7W zvXp>RoHQlnGi5ZldxG08pUFAyuaG`byDba-dd?8XqT$N2x-RDOxX{4x|Nm}zoRw6d zsHm8sUfSCgUzXwx1|v#DGuFPnwI9(gqT;a6SMYo9#7pAE>gcfNDcA~^J0Hcet6AOz zV3IoZp{`&vwqL?Mfw%_fm%D5-#U$IwnuUDjSr zlywWeX}y)Vfo5LuxBB!687$~+n#wKw_)TuHnnGA*jeFf++ zbks>(bk2M%_Z#mSTWkIPVi_`=w{7jfwn%>F;p~?v?ULm8Q-1Juo*?&)Qrk}X{gMSZ z_ODXWulFEWY>OvRLCVJpxJQ&J}wu2{5#+{0j+TGAF z4w#$@XfHl+f|2obO=@Udu$8w8R_L~^yjie9Ykb(Z5*rR914(_a`V!n?=AQ>4s7uG) z;*i7H2f|HwEb=x5?m^&53Va8FdpZ$#l(6T3T}0T+z4-Hv(T>0W1Z_P61-Pe(?xH{n z0xKxsMqmyFaK9HFV^m*)`|E;y2t5}<9~Dnap#}9=IC&b}@m0Cu`VzPo1nAEokskt-1qTg^yn}-Gll+38!jtZ$z%P)5z5*zC36z&8@D>6$Q2_ULQRf-e7o%?{ z`Sh&BnJMmaI*2voi>oLA`NBU!zF5NYjXzP`!I9#{3oPEToW(nwEMEMS#T$oFYSjWeV3k;_G@1B-2tO1klP4J#Tw3kWz%MGj>n zuk%N+M0Be2O#A`MH?xVM^IB;hU{uP5qzUni&Opf0j5OAoxt#l&sY+6!mq_kT=XbSo zG0w-&q!?&*lT&N#j3*q{i*dd$ zolF}4^0Sn3&esJS>o`{&O5u!ShjBSCl}Vy=T_TP1zX?Nyd6@D!7zY1FaROyLDfLz5 zgSpJ_Liir?g;o(b=?a^LYP~`gcM;OT;xO_HXcA)yLnfHz2VvP7|t`_Ci(&Vu0zBO2@On>R0QJW<+uV-juP<{a?j<@*J-aXCl-}GZ^s#NoT~&3pO2(WJP7Jb=RsZQgtlrCyCC|)&}w0lJyi!%of}fcq7_U z8p(kbR>vP?tmBUezB@7@IKyU|GlDt~1v!u1s3Z@0ptDYBSHD2UI`(fiS;{acRbj~`h6 zWDv@GvogqSicPp&s6v&;LhO}CY!FL^;aIYqzBralz_E4{R3e$raO__Ph~5g@Nvg1_ zaurtgRN)7Z=C>-1NJhKya<~BDY7Rql)PqbfR6|o?)y`B{4M{T0{jUnALd|lO*MYo_ zZVsP;@WmWf#Zc*01*`BOqz5oLHrl;s&A z(^LN`6%8$yV?UKo+m*tqREns%tb&LyJjTq3&8C8DgPG+;9^qHMs3G6Exqq!k#^-ay>U z(NrSJ5Gom4LLp(rckHhPMY{%twQEpVm0hLLt^vB~8Wh&9L19&HncnQ0h^}1&VY7NE ztgDy8hw!87rLeAE3hU~nFqJA%rGa+piUy!AHVROegTlHT6ut|;yE%<62k2%wD6Gpt zVO6xQXYFqNC! z8ey(X6(+YX<#M5j=H&^w6_Vr`p+havqSbIo2E;sYqfBP~L2RQ;q|EC>Seuu^+PoCj z=B4lh_|XW4uxVZjYx7cAo0r1cycE`Mg0N{W3Ttyw_z-?%E(&XNQCORc!elOT6NJ?z z@LqpqSxc4Q?@g}`w0XVx-h#aR<>^>w^84vkdy2@%@tggWf_rp}VhlTPP(s*v|ypMtMqm+J>(}D~9(tit`E!3M97{Y_46^;;(4j z;IC-F)`6S-*!xmt;;3pwH8)hZ&^DMyi3r;R(2G3)A%yn;q`U}Py8wm|LiPa+i7|Hq z455xFBFYEutRdDBt&mwcT%fY1igo_tX1`8sCliZ2yJ2MFmUSEI%Du}*(94PoBcv{) zJj)6~jn&xHP+e176)v>8s;mW@jQiJ>)mCq6XsQg&q+^wQDnEQxRhW*dgkljRsy4S& z)yo|jo2u5-;H zj+9gv7PO5Ne9YmDT^MWa^6kjQ#2}GU^m?=9grKT%bw~Z1NT(=WJ}U$@I~( zk_JPg<#+r2wGH)a>F1Tb2mLX`0z9;7sRUzxWmQFOv)6De^!v#)_05LJ)uTz~Irzli5QD(+vAiTKD_C9((hx}S6e4Awl{dV+Q(aJg7h-U9I>nf!vnSz{ok+Sz z$tm0H&BxO{aXO0uPEtVm3`+q8Z?G*dT(PXU5acsh1jv?%l?4UMmMt&HTUNZHsBro6 zq7`||A>wQ@B+5b@ii!-eR}g^;14?mG(K67^ku)j|XoUqU3s)8|FIZVLgw-V(L#2_T z%u2~$QCL{Kyb!(qvgLUzi;D7#^NS$tA_3n1+A6q;-Fz2YZO(kN8OMgPSHPFe z$OyG_iy3JeX6(xOin1l!CEVG+YQ?f9A#LGyD>_m=-C;$W+8nK#zDWhZY)Ez%2r6qE z;=3jtIx@X%vmp*i88QPRh`Z9n5RXs}G*a$%%&ykfHR*n*yBi+xGc!FH*}CQkPA$_v zAtg%zp&26e1Vb{*vqI1Fs4KLU?pIbsXz^YU%{6QNWi1VLH5HM1))zzKk=O1izeD6! z%sN1}8OHIt*i^BuOj_7*9MK3F^N$*Vc9;nLNuyxE{o-H5Ca4`rllM6$OozXdRaf{c zXwbsX5dRdq;=gE9n+vSfiW3#ixt|wn6wcY- z5M`1ZPN!=fFy*hc(M&DY*@&htH8!HD(Md{#o#%a`&Q3J7tG8249UJUaQ`1HztJ75U zX0gE{G0U69MvG>uxyhoLT5e_`7Qg4kDK;82#Hms?qN(DkHlnHFr=%F%&2mizR3c4y zUUbR?J*~rBcb}dw>rNBi5Ig287o=MWe9n#E9Q=->`+zx^(AG8AG}Fx@ZW-5MUYntI z4p6s+b?P>!2(;!pi~)ET*$^wJ5!cq#SAo#gOZy5KqJ*Z+Wi9BFIci|Ab+D`5mSVNv zU*CYu6L5n^lirR%d-p&v(4N_gcaH~$`g_sMlwnHWTvbVO^gdI#6UZDI2z1blAKU70 zsw!I_9=$uzx`U#z?69G}thQ!teO0BrHCTo_5%jTHnYft<@!8bMbT-9bJ7xBO-eH zf`<4z&`s4fKzDa`8R9%Ap=8P3oiO92K%1*J0v!nK!YfihYnsb57kfMUyq_Uz`}RP` zP|ff8aPGDEyXXhRdBef@@b9ccOb#+J-ot=&Tbsypmm*SaIvhdO4O zAufxeTehu;Z0|nZ9B1%e1zJD}nnR@bwlJv37vin=w<5d_FUOWgd2Hc#mcuiKW;

z$}xFIx#V9$^rHE13k+fxr*5RXN-AoD0tlx+dcj&B*&5dK~+t}aNj^lKi2hra&k|zfGO-7|3MTz@pnS^X6 z87X@W_5~X{DWl9~D6@^lsN|4KJghaUJBmhitzEs5)wwWQJgL=@Tx{x?xmX<&4=+^7 zPou>PT9?MAn!2*)^+&N#S6%DC4$CU%#E3s=HB1Idm0-V0t4$J`v*f2S;(g~zbPDA) zc*ZR2OXZV2g6#lMRh4)Tdtj)W-@En=$P8}u1L~r&aV~y%qr;dNGB#E;)HPzUvWbRA zr`r+bOn350hnLCrzjwU-$arR;`r8|8mpvM_&3P%-1w(rkQd`e;jYH$5eF|hUPDMJcrRw8tTeu!OdGl zgB_+6BNH@lC`Y^;49g?LduhTjGM8jqTI$U&-mutv25B`yGBJiwtY7M<2R!CtmO&2= zhq3L zVTBwopVr}FUBr3?HRM(Uvv(Y$=g&-UrBlk%TwF>|cbIY!)g)r7{tJFB6MzAbC8N*}^F zQaQJykE(6qTPAb;A#3p>y8SW4r>Pn^Hs8C%n;D)2X?DO=HKTIq_haP^=M(D(D=!J% zYz*T6ms zLxB9hnMrDqM6QE$^bNIj2f`D6i1jp;Z!}i_D{wfn7XyL0)|J=kUtV1yw^=58{6omX z;IQTT26BjhnmE@f9`>H+&?-YrWKAA-b_UzKTL%WZI`>G+WvWNq6kfH;%ZMuNV(*El zTeynf%F{^+PZ&W46*?Yv;>qIHs-^}ELqLB?D8{Jz26T0>P$6hf6HOE7`OGs!VCz(Q zGnaw%tV~1Zpr=Le%LKIzYs>SznK>bkwf<^GN#l9*hF3^?<&pHiIlBgMGG*6bVEpCO zIYLUQiK>hrgY7ol_+h549x-NSj%mV0i@Z7>Pbo*3m~2erzqE3DPp~i(VzRxNdloPD zE<%BDe7tf2%9=M^V4^3O**YeW4R*OC$}9l3x^C_MPn1IK7LIC}SSd!!hEiOGQeex- ziBv6;ht;cM0B+ZV8;%hj_)pj(tVT_bMXS<|Fpe5EvqAe?S^NK3b+(&cI3G?){lQq8 zhoy$XUuT7naXV72NYx~>?zA;0-D`y;u;QWDccE8rs~iBvZq&M8l*z-KN-+SphlpEW ze-AY=tPAR1V9btI=LqMi*?{fOz;+0HaiBt=<3HiBwD&(<+;}Z?>}t2t$)3wZQG{Dv z^euN=*WmaK!x=*CVle^F$6VBhVmeY=nV;E-*hXbF`}A{L&c@8n z?3Qt7&i1wtgQqM81rrdRt)`c1oCY7q+tF4L497b*tP$_mS!jXbxNV9xOI36JS~)*2 zA8}tdz8g5(XP@dhR+QSuW1P>iIQze0wjU*@B6!{urR-!rzzW+Rpi!oiHv$*qG3xY2 zm0S|`<3Vcj^kn1uo$>}C(BHqkwYLKg61L&t)6+tf+~^Qjh~stlp(YKT^!nuW8Og@Q ze*ds-Z3jeQlpJ=5tHN{W4ErNx*y|M6Ss7?3(#a$8znhj1O^uLTr;f<{uTF8Rm6`@J z-TmooQiv+dp0L8;v++)PCTEmK?JAH@U=j zLXw9FYo*0txr#=1hpNM@>u+3m^T5#^c~=K`H2l)VxYTK6R8*RkRot_7W~Z3Fi7ogtov zbbN^l{l1~x1@qStmQ@?#2}fg%cUf+JVSdrdf?~Yow_@e;mGGCR9rW^( zQl_O0>mBlKZEq3wy%5jX;vm-FysoCY1$T)!-Q1f`;-9rA$S=|f@{4tXUpe@36RoI+ zvseiZzjm-tJZz=)HY#1-usj6{s{qf1$I4=^K+ON3oQ)gs;;qVuJmtlC<;A!)f6XBu z@fK1A;Gto2OZj2+aXNEFCS-x7wR?B# zo&jEmpu;I%A@JZ^Qv*t>Umg(0+~T^3&}(2)m#@QIjl5jDW9wc7Pm+mtX}PnpaDsz ze2Zyj`3h-(cK~)S&)k)ly(>R^S3&l!5f&iIDCH+!;pN|@O1~naxoDans_d?O$vwY# zM0#ziu=L;nZ3+s*(yP?O9|im7@*X@ID{F7}FDn>EJ?;nuf&fjKt=aNz?pE(AZ{|)k z_(8gJ!nLz_8HHOV?`0?fRs=P1*qeoyyFszmf3Oz5*b4(Ar6KNhE0C; z0mD|jywgzcucB`t&`&-eA!>6?3u0bcUV~R98|rJfU_E%0+%J!nMzT?F{M{h$k@k(a zM^gLcnD1XGH2m!fV|;f~p_}Mf=j+gvN1x$DYVa)+Jpj|sSeD($&sg|*m{!Qf@|fLW zp)hN^2G`7ja48R+XA+}(<^2-R3rlv~-{*c;gGlc*1f5AO$jI?z5iK*^!9x}u^Y z+@4u42BIq-@gAbux2=(iM6YZO4H(G<|H4~Ju14%HDW8=aAB(-t zN~7!y)H8Ivwgj9y1c@&ZR{)pye>5UslK(AnwR5_n@Oy0!h=b1LtZSSJo{;U*919E& zZ`hWM$Y0mK-3s&I!Z%$5-NFmBJiYb#vF0tN$}j~8jI(?P@X^~&($M&b}qwi zWR6qCbKv>Et|T%i-uBprgG2GsgYj{QK_isjgB{EUo40p$a#cGPBp6aiTNl=%JN)gf z10DX3&U|TWKYRefz9Bw}b7lP@I!u_@Viy+4ETO{02}cn|)^d8p1yfvEhhn6)tdfNZ zi)63Siy>|1{H(YFoDasvlFgd>cB>acYN!w(RP=S51cxVBN$2V$J4lYQ54wx~u3^gs z70=hi18*ffwrNlI+6tHZLnEQf2QxG>R`b$&vIlIbyJA{3=$A{6U< zE@t4=|5Gv%pQdCY;+UO$x!X@tjmf?F)l z<(5q^?6y+pi6>@3%a}^YHR2Bta(CiHoWg1pZCztB|46(G=AWH55$4pps%jXOIYuHQ zIcAgi2+WU6gt@JWjLw|8yqJ5%`P0z;k|vgqHhZ93iJ;I>~yCm*s{B;qoW%wNtVeIESCveTJh}LNRBhe z6$X){0(*uW0;@x4%6><`oYjtb;Al|E`cjZ7$G}2{Ac1rC~#NXfA(KTFPIgD(5 zu|48hX#Zf!f1CDUdKZT29k)ch3%x&>acuPF(e4;nJxp)Ay~)kvelIRfLIX|xFW1{{ zZ_<0p_2L%j{lBwj91|~>1M#u&a!+4xpluH~JlTixKoimBWgi*eEPjZh{CM{Ny`tD^ zMHVH&BVIsJzB6Z}H(5Q(R5ig3@$ISA)T5~02wm2;!R@-=NHC^jyiQM^x?;NQKM-1D z`Ls1-r*1Xj4e=ht-+$bg;=fPhT4;xM6!9Jiy+4vr^2Djz#ktd6S$Da|5}KGdVWF$j zlM}Ne2$hDO`jWT`Lf@F1#_r#Qvl^wziz zD3jdfP>^5}%PnFO?yBJOMsngijs-JNVN*|n@^47x`>CrBt)|2#@f9e4+r0mz^3;ejK4J(u<}&AznaP4$n{XG}FC&a$+G(JXIN*s;gUcA;6PeK~m*? z%M3Lak@ZWTr&*OOc_$qZ?}GRLq^Ei6H5#ljCzEC?sc>)6Ws#hC=_$7^gyXlVjF_nv{hqMAJ0WI>~3+6iPlvDU|qL zdUD)@krbk?GdWrO9t!<#VS=YlRu?)AdEeU78noZH(uA)QYdSnF#0@mvZV?u%{DIa{ z@WOK!?mGjPOUSuh@|VTmXJgj8Xq+;562vlOC5$P9nrBLkxNwdu>-OWvD+4VCmen$V zjad%q+9^B4e#qFLnc%6lY!$>Crh(A03-|fsvX{Db>gyh9vXozlFCOR0`o}~>jcK;X zqR4VHP7t?4)a#2UP%54_MYdiwQpMZpc115(aQT9q5ZF=ymaH2)ZC=OhIxX$nro!*|*0o3M~+&Hj3Xt!s{a> z$ooiLL)-~yV}&kj4H(d7+&g{dQb6DFS$(bB@R)Tm8oUdOx zHfPn~P0m&YQ_nSmv#i)zo#GjAzA!J`Uqf_eYwXahr8zvoU3Q$8Ou8b8l6~Z?L*ibK zE9XsvxN*XZjTJab} zJy;+`*@qNsc|KCh^YjdY+#A18R|8a-J>3ee+ydcP^VT#=?K3b!y2O!zu>N zkS+xiU%q4OwhNP$Gy4?rI)oi4977majjnW6Gg25P72_2~)ie81ah=zdb!k!B=p`H5 zW}ZNApnuyQWx*uRFs-0s5sxQsR6Lr1g&A~Ck$4hfZ!7kWAr|gsdy+DC8PUBadHOLU zz*#qP^@x(suyli2(v)rpxs@l4)J=BbbM6x7&Ua-!ynGCkMCy~28%3yW=$06w8|6;2 zbVHUIN;ia3N7aocP{*wk-+^vVu880paM;0sbzl#A4a^K|gQnezg-SXJNKc&M zH)u49lT7PaxDnd?t7M|uM0kqm8ApAMZX2xG&b?ZEZGo%gaH)95xv0In zE9jR`Kl|j&1+CVTfjLgdTY`A}{$1_@^LYQgvZXQ;i_*sWha$t@4Q-}^!Lajrh)Il6kI*23V&>?XWI=rz) zeA%@KuVLYECo&q-a?Nqe(bO6jVo<5SKkxvWB5 z5RKwBuS5AJ$>SFl;u_*{G72?G7FSh@Ta_A<=kZLX__kD|tQjX#Ou`n|R*9dmEhfp~ z*Hz+KWeIFhHW?KTR*Toz4wK~YRJHi4Ixqi>ao2` zty-i}^5=Ep9y9-Fb{UJow`#X{p8u5hIpq7i!6|o5TW+}V~U9j7ICy5s= z23&>-ad`VA@uuQ{S{|o^8YMTc7awr0=JDq`yk49eOCGhkWn`}qKI#}H`)kEzvGg)* zU0rS2C|)6rUnR5C2x`xcv7@!U9Z7Qacu8!cN?xcF57^k4L;Ru_BpVt8 z?Q9am+2F};vTI-I_4VS;;}?=P`24tkM?jT_ic!-lOHz7VPxBO#e(X=of&nLR3VsVy_YGP5t(-`9biv2e?Tk&6*}F~nn(eyc%TmML}W>fIGV zFIEI9N>;3%RtepQL1@AP6&bb}TAfI`{ZFI#NU_G$eTUsznrVnu z9jw((K(QL1#?m~8g6(|+6f{a-Jy{%FEDI|c9!*Qh5ZX$H9*d!e8IG>Ij=>3*mc_AX zL>B*UlXy!hK^6}y8Ht3gNn%7l7_DRvH;YTN%xVlPon-1!Oe6URm>#Rrl^kjjZ)C{^ z8~R>~)pWDgsHPh-o2Hg4Z^M1+9^9wiukr1XcjUf3tfNgP!aKr<&pu-S#~Jfj(%&wLa+YA8 zm1~%{IJ=pPWMast=I-?5>|Leb-zqN64N(n`aCzLxz_LO_&D{0mz=p+VWIjI^b6oqV$PV#6zK~E34A79Ca#3BI;jfVKuzBU?!0BHDGjW-Wsa?_KSwwGLYn)qdr>?Xs@WObBzbJR3R zmdO)ZCiIPZO+n3>JicM8pV(ssWlxSsIpNSet>gzRM2;PF8 zJ?66|KW`N`6h~Is>|*nNKDx>y=4H@|OqHmVGrL)-9EesKY{eN}WpN~2zkdC4il>;3$8QJQ#sT{z@(D<4#jbp1;expO&x-_H<(>=lX12c zQ(INP7TY{2`dJoT?Y&-ugHc*4)){A75!fsU8x9#~Sd?ab__?9BtjYL{MQf?TN2%3i zHMQ7q3+D#vi@v$VjhL|vze0R->zs>EV>vP?zu(z*wC{_K)%o1CC#=x>jq^7{&3!}t z?EzmkcCrf49&FV^z3qct*a^%>Qx)5z0C~3ff7|Cof$J~FZ=NxQ* zs+(dl-&i^g-(=4R;uP4EuLj4^L}eK9@vGyVv2=jEJijKzWu0IX9ZE8c7>ke;Z5ViG znvT4oEQS$hAr;7&EGWekJCO+SnxIo8*a?O)Ril(RQ6q*iO$ROBNfwC`PhVtEiISsG zG-qr)&b!CS++rpLW@KXjc{d_w%D_~dz!Q%sbvDnectZu!h=z^1k-?awDs=cLdk`$ldG)L%+5g$XKso`%n@WTdi=Z;%&ODT47^^J8TG(o}g<7hvfyqt`jUZ)-yv8Ccb%|JJ5p7JS z7)E($gk%D8g+*p2AXd(W(emMs$*6}ah2ZQui@JH*mT8+%%C(B5(RIX3=c}<0QtTuf z3K8oSY8bT?aK@G<6ryrYM2*#11VZa)BA#5SfdV+oAys;)s#3!^S)o+bO|v8?@{48) zQlLfA3}eGA=}jBc;7yy-q_1x-l$;!K*+{rWBZje+gHZYu6{G|{6*P=fbxM-?DUD=L zBNT%iH6KSbA*U%s#k4Af=$NGDCn>4zG6+E(6d*AH3K&MGOM-0#sG)Cnv95;E#X;oy zvJ0Ssbp%#*_F)vCV$}44 zkr$Tg3G@yQoPb)%&+k~CmxIa2ComsQRZ!Mz@08Xf9OVwQ4Q(ShO8N7P^9r)_ak>`L zjKc`Dq3Non(gM5t`gd3%WJm3EbnWWu2zW=HHJ95r`LdPu_f%BKqTz_eQw@chC2RNQ z^i8HtIs!o~HB7iV$N)!zjC{}yf%=+K4YitCFrAW{?@xFH!n9IzObvvR~gua_w!^N;;~JP&*B@#M13c2 zM&sm+4I69Z@rS%g_9`4k>CLHBd{n^Pea4PruHJ+b{wmg0Rjjwu&0{Df50%w+2qoHF zPbbb}z*n__30G8mf2UWOcw&=h-I0aB_%0iYQ8EO_762hQKK_sI#4Ht0pyWmPR$G4D z$i=5?Jj(d^J>cl{H?kaTPWk<5S!s8$KO4c&G~q$`|_^U=VFYCCl=}-f6>8 zp4go#HRk0GqZoLW4KIXA-?rg-z$w4Hkp4K}+idte;EQee0_+X(CmX&5__u8MEa1Cs z`0>D3*>K2@hKn0lx`L3W1hkTc5FXV@O*9==cU9eK^>nC@41&?e_n%+KHp1b@!(Fq#8!5u;XM{(IK%FUtC4}!uxQt;L!xo0!3_rsV?Np|}kKs=k zqP&v+X9c6+pM*!vQhG;09@QVUV+k{v4qun)@)<8;9FtZmchqXe*$z?bm|n~DlNsO0 zknKYKhvXYzdKcrpjQ2CXn{h5*)LzEV=lIJQ-^Y5RolE`E-$?y#;&it$eh1@UXZ&7< z-(~m%j(?c(M;L#cakM+h7xg9KZy3JJ>0V>}4aWb-xVAg|Oy>K$igy_bcVSE?d$JyBf||0PhsfibRCRi z{FnOmFus%VU5ua3_}Pq~r*P^QNq_2JW-*lg%(+L)cg1u$zSY8GfGOT?}Cd8UL_?WPsL1MWRJfSi(Q1Hy%Ycn$RT}1 zD#Jw#ix~zP{zyT`EQVYk4z|1FJwlyw#}EczKrAA1YKR~UY%U>xEoJ`UrY zgeNgE*BCym;7sN-vypM`cV_-g;i+6tshoZmmunW=Yt~aL zU0Mml+Z3G5dd|i;N&3%b|DOFTh0jT1Siz9}WzPEwKW-z#eGD-k5g#|VXLk|fthf6@ z#;;@eGX>|)V955I%XXN1Gt=*5h;fkk&pV#s28P`XhZ*i=$bK@9>u28cOn;Xl*Rz+~ zw>L%6y#)*#82T7?Fg%?h%kf^!_(6u;KDD<4jv;U^E|E9D5 zq_f=gdpX}v7_!{-KQjJ-f(v38a(}Ua6yWXSef$aY#dRnZsDWXS%qFpu%I4C@$jdsx`X_?ZmPWB6HyH!$RSTlhW3 zS+9k!FwXV3ko{-jhl;)^UcoHZBa7Qz)_0iB0CxsVqdoSRAzJTY41-m%@dWPJN3%L9R><0zUbNuTHn)AU&@chzY$ou(xf+z>g z`$d#Ymy4C#Tyw|i0V5Y%nGUwL0dChJJZs67&k+2ksC#tkyQ1!n-SXTYukBFt@;8 z)#C~#@w3kza@(X+Qrfhn>1}&k)3gbhho(TLnlRWUX2nqsPKtWM?JXAnX_?XZ+}ATQaVu?z+R(PauCN8uH_wS~l;d-5?PdDQ-h+WaQ}r5r-nwjC z?wUX-&=3rit*Fh(32azVo1Gm90jdcGgV}+a^#Sa}9$HrrI49J!x?**uLJNUb*9Pio zyZ2xqSYB2XXbhfQ6liD+hKd3~e9CcKj#1m)8VEGvJ4_veLxBKd*3;cO@)nn)64@Kw zV*;wd1W+~OX)%$Z3Frny#mCcvMif_-CX0_+Ya@CfSIj?Wy4{#b`*>P&l=12-wRYns zG2?07F~x9WCmG{u?NKsle6j0sJi|l`0Z{`KnKGUciY3wDdbG`f%N|u*kY#P(C(wpv z$)j!ss&v%&Ho+#~ka2YNF9jTR}rJc@$}{B z&WmE>>AMkMrbe0Z^i{ilP+&ZLlL|yt2}(|&FVb1-X!|0UJ*vJa%N|u zTI8`umHy}YqC>{f^+hSbu4{5(JeBQqAx6bda1@@v+!XVkFrMo!4v)|pZVP9%w0GvU zbmW2~+!$OJs>TFjA_edQyE<#fm|azU+fuCM2>4k zqtLTQ(q+vRk3x?jUtU-QvUC4M)4iseHKWe<)co^bKFy4nVIIwcDx=MiA*-2w{MbvZ zhsI+(riS;-+99!}r=9kw58(aEA)^czjH_BYT3Wm1{p?gvg?>T~4=H2eT4^rYx|Z19>u=GgUAcu zrw^^S76iarZz1#=S867eC$T8|ip~f1v5|ZNYtc^oipf`PUk2b&>?@|eaTq^+jAGx4 zA~0O0nUHF}DEn5BZ3jm3iBmvx#IJ<>(Dr2k9>uG+M}M;&~P^CMp$T3(bNYxBUcUo#=q zd{KU^eICzV+!}-L$DldvyJS0XZ6EGWjb`5^)CLmp(}&g@W#1*&fMG~8A=P|Q_U-Z^ zE0(-VP{v{3r89wpSH{neRL3uB+`Tjf=c8Eu?m!uB1HdZ}unZ*fAbE83;HX zUzEIkq(jT2xs>LMmRE{AEicZ&R|wdtm&%b$(o6hWUNj%sq4}u%Xnb7`zR3>0Xg{_i zFBw158$Sl$l~7g6eAI5VUb5Ta$4v);ll>%bDt?-85nw0Zi@-G>wKvTdW#3JQk*Dp$ zedJO3K1B0LLq6#}c67e|e&lI+cur+BdHahTd}RA5_U&(Q@X;7G8ef-#PoK}p|ERd^ z-wB$I%W}Y@$-5ZgJb--iH*0jhJF1bF#(a4WzBzzh`0;T^Kf2ZZ8bhl48`X`2@9qGa zNly$u0Raxa2d@NAOElkcIoX9-e*4JIE6Oj<%g)X(@cR{A{l#sOf&$R;vkEB-$7z$# z4c1l(Q=0|JLi*((eD4P8u=F%8jx^(Bqwb;7Rs9bgSk?dCPw%~C&!ojhSLIdiYs{{l z`zBp&bSGXFw{Ox-iI-fxFDdzYP{hTFS9!z1eUnmlUg=4>>N;1|HG7gS#zQX$r`A1N ze(#Itq#3VHx_GLwKIM{>#?YJP`(8HYK9^d0=&x0$?KJnqJ!M`Qw`bDD<$IFmPM=%$ zg4iRHC+$hXE!WEATdQup*}Ps9xA{8#j}?iuO=APn~HW$Pq`}CddS%4 zOQ|W}3zQ!;i9E@9RhSzpgR(yU=`)QT)jFhXU*Bnd=nBkdS!HVWN%TKF3 zEDnF;@OKxx!F9gmIzP*oS~D+ksd4BJ^6O`_^yox8+K zIaQmxF02U8dH=KvvwZUsQ@6qwBenE-uW_DHda8fJS1L9nr!`!BebO@H;M_f~E+gsD zJ$SJ3N|)bU5NGT}ME?%^U8$wz=e^Q$*epl-^5^%s(X!mAL3ipYhkkSKlpnl%ctxxh z_~s9c+EZ5UoH?Q;l^%NU&6f^ms&-JZKZAHMmXqh_hy*|qxKTS)-}HRYk2Ixs!8 zCgm#B%3t5g9X+mZHTsQH{asVYzehxBW6G`RRAN_^`PR+ne){RB=%~}x$lw-7v#OGv zpV{`Az0vnseA<&nWCPyS)$)mNjDr7qP0ZhG>tR47m=t#9Y(#Lel>qZ(a!gm&W_Q z9q~4@(9Az|$<_E}hWO&t#3^`PEKbCkaW0?R=ka-caXz1Kl5esvJ}$vWv!ckkJT-~W zLPna?4l|}5mVTOB@Zs8CmUQO%o(tR;x-K#=7iCGkF3~zU>8!FOjq$dwnqG@|7j0c;7U&$>@2%V3agB;@L?^gm6L03uvf`iL*l!8hBzKA9 zoXHP1>o3AcN^`&3pZfJp{jFN*r0+HNtBv1ZZ?<=R2fOi)P3^QPe26}nM8%=o_u8h2 z?;V4(wwX3;bL^Y0)gWq?#a!qJzFdS-dM*MePpH&ezXn9FISlu>EntwDMsv3 zgl)VGJoxDT+NS>PK(S@H@n@hH$PyGZga-5?&=G3)z(!p%8+QSWKN_2A!{Gu68Lppi zYRAq)VV2>#MWVFZSvXAPA=h=f-2Y8&9~TZw5s=u|wuOAhZ8T-hCcR}GX)s*1QV?w# zr|{%W_~;m#G-A5|`aZy@)wjTG}-lKFX<6YyJPJx{ct1FUQdkRJk~c|_`4dTROFm# z!kb3P@tY*d`H~y^bO7waOe#{YIxX<4`W8l76IZU>2}TZqGpOkaj5qOq;jb6#JRl6BQGf=6Ap#Q8gC&9cfDeg(V%-= z-#D8bJ=>d&QXX;wn6F-%n}WZk(qxazOJS47qs;Tml3ZC--gRCR1#=EWezFVzc`qXo zWeP=T5}V?2eHC_Lwz%uRAh1N|z{Wa8;BTscv;=29Xov<)0D234w;JN)C=$3D9V86KX074c{ljx5 zV3>749tNTh6NZ5pQOFNcy3}T7s$8eyL`ib(evm|N!*3Tv5~2@*S%7$7iWE4BVf=JT z7l&o8vV!v!;wp#h+CJAhAh;TiFqWp7xFt$XYsmm*xsxQ7OF5$=%fOl@y9_|qMO0k| zpgwdN+|AH>0O~RXD(eJ5eaJFzN4iSpDv~aXy3u7F)ui>|WTN!})MW@{eE{{L%b;pB zqobC@07RV^X$_N{T&IESoQOswFo6-}D#UdF8zOVFKq?rG_R&C0c8BqJn~ zlPsA$<1z$t8K;w^4`mu`Mu7UDyOYQ@cWdpc*J!LiI8ozhp_( zmN=`3%D@t85?qGb0hNKr1hVzcCXoteKkREjs%<4$2~hM?fuF}bPXK;S!Ilr;XVH?M z-gZWPOIZ73JO}7k5y6(EpUc1*n4M8B1X;%q0sS(fbr_hd8W>Ng7u<#4JqiRQk1O$a zPfQZTnrP?dJ5q!BKEMwnl~GwprfOx$0CgDxxs0RURn3RuiR!!P{Xp6>ZRHeN4;xHLbmk)wNV7J^~9hL_81dz?J+=IhCnVu4Em@A zuqiTdL~2ykiWW|}&LCj4G%)HR{?=iW=rm%!GBUSGdM|U)I-GuTS!j^C&r4+{+75|{ z)(cap;#i5Z;z$f~DKMPt3=HR@k?CB=sB4tUvgYneq(k^^M>8i_S2w|T;dc+y9|rs@ z1&c&<9Y4dmtAXF@Y6R=9MzHQ`1RuuleJ=Y6Ov8WDYeFVYjSAid_)3QN1AdTU<)q?y z9rSmYuA3j^&{YHm3CUx1Wuh;~kLB|KuXtc5rT`K~QFW9ep>9uArlP2Z039c420Bgz z>o^gt;{@1>6JV|aDaYzMMAxvsr zQSO_&F=w>8AHm9bMc2)W=(Zo+`A?nkf+i7ab%KccV0Z-bKKf}OJafo>h8fHonY zQr+bU*0CX2$A(}X8^Bg<2-dM7xDLMtCDV!x(RFM9TmBKO{UccW2iWqDVC^5lRO2*c z0JaV{Ao7D!?FYfy4}!HH1ZzJ4TYeC%{UBKTL9ni4g0&w6AI6XBm|$JUfUP^Gt;Z*B93lhn# z&aaRyW7>>V$CO|lQ-XC&34RzqI&A^AVoI=%DZx6X1nZa*tYZq;iV?v&Mg;2^0k&d9 zu#OSIx@`bfhrs&-m1RxAaM-`Fs-xBK&-UkJWfv~Q(o{H1kMvVUcGilV{1y56iW+LF ztN=AzvPgutt|Ve{ab8w&t;`BmuCmw&wz=}M3M~$~_k7dF22wQKOJ9}5&a-rTf()Qy z4NZ-eHC0t%=FwS$SitV<#CKYU{CSd>2|azinAe zBknIP{Lb$QdxlZ zCZ7?6h;2S2a;%L$Bd8->gny9E7GmkqhOEkAhsqi&s>21Lux56WNko=2Fp{~cdhMEW zf9?o+SwUV5?lLNqn-dwVhQ|7;n%ZEr(yCxt6TT)8t}d&sT3_E-8Cgi@D*fa?+N!EB zomC0LVrB$4GzIJAhO3RiRW+feU?VDcZCw)^T-Hz#3fI(u47ICS#8B7p)>bEMg$^HR zwcz>&^p~1YP<9*U1`QvzE32&ymxV&X#wMGrSZjmpg0&n$YD`rPQXE$GX>`FR@H8u> z!*ehGd>rE@oy?Vg=yqKa-XNh3`0XA0%}i`Et@a^jR^mGbzghUrh9(go4y%_O!(Dzn z1}a}ns;I3gkLVa#xB(@S!W0|SZkReAzHcvPG9_FQ4y~=K!j80Ie@~AgW`)BIWr%K0 z+Vp}Kz6t`h^FEU-^DgLDvFobIkAJe%Vrp7 zOuu56P;Sf6UT#y_caHECb_NH)8R#qRTq_7F_7!Qd<9)S^m=yyZ_G=vE$lzb=$ca@2 z*E#Yn8;(>F*Gs#rta@;^Kh)C=RyNm1RQ`=te(YMg$;uyRrF_*Yz)jK7m~XN2I55r% z_?nd&qjqk!GOfUjT{+)SvE;Z!H}>1@T(%^lFMQL^j#W>0*x8mfN2;d#$N|iV17)XaX{*j1&~3~l_i)_QVDcY9(Jsu)-g2cai^yTE#M~>KLk03<`|7y z@;@UrO9hbyVvPjDvd9ZU&-G}Kba?l3J0sG)Uy4x8s&H9T{hFGJSR?Dp5&0lH za}#DBAUgtMz9rUIRF}yJ8|LpcLcx4TBd`vWq5sh+1n{`{XR#h;$Fk%voD*fk#}w6~ za0Q*T@H52UiGaprQ~p5|)S6BCgeYh-l41|%RD7pNu2=%)IS=G7NwO_g)6bK1Tezlw zS<-D4R7n)E(70ddqrXx@CvL-K*m#?%#%)0j$SMjC z;UagJDDo4A20`dvQ7lok143^RD2$Zs&Fp; zdr>B(;Tx7MgO>hP4w_{}wS#EcQsW?67M-M2IAuN{);Nilb#+dvWn;aQYFXN#bah&W z-Xhl8Bo=v#SZC8LGuPWR%gPO`#FqDxIK@F@fiH<>2hlR|^A4hA;i*y$u4uWYIuw&8 zyd*j$!`7DVTz980kaedCzZY8;s3wR-1pxHk$6Wl5rR#vXn9!~X)r9DR5tohCnAZl> zE(Pk+aE-du$pcq7*bwLoidua~?LzK|8xvU9eGG`4AwG4H)IXF%T zhwJL`WG*i9>OgMqXzLm5?`TWw#WT)B!vnn-X38+74+SepkKUOIR|09ngB|TO z>Lj?P$`Esu=9V70IKiw427M4j8mQ!9RY=p|e&gDTCP-ja*mDM7);7dnFwoW2Hz1?8 zuip?K16^NL1N6+!ZbN+8MJPq`%ua-H7tl~}9nis!ZHBlSXica*ZK=P#&wmzC+qyd1 zhkH8k@xg(C?v8=9r6r(t54NUdZLgAWERM7NXLey*Gk;pvT6laDgjOC|X#0eOev^c* zIijWQTPI@acOevedcZ?$V`hj~39WA=v~R!=Zvib|-O!Y_t)*wUgX#{u-L-7#??W9k z%@CKl>5^>|GTVB-V4Y_w^5dJ!c6oZ_S8Qx!*4PD0-ZRC8H1Lq-nuZW=bIDS%)k+3sM}tvvw@X~5 zi~+C(nYr)sptk`u!?@$E$+}o8$u0Z+S@SD*M?7Hg@!QRG*CP`o-MktIu> zj1zxx6=P5+uW4ePs+=4V93NU%Rf&hY2Zww3VeaNZX+aA0UwP2Ek@l5H#czJZxv`>t zO#>Dz8|n1uN-^E8g)aW8>1DG2?;P(qGM*Wze#gh&t&h&y*1QyJgOQ^OnXTu##)0vS zM-IvVUPBT*!9fl!z;7Xbi>Mwjc4Iw0h>1#8xH`NlSQl)psX$FEG~J?<<}X=1htYQ% z)|AnLn?IjUc9>F(WC*P-N4`86mdD8V(}ZDUDJgd4N`H32+NJ(4l2s!#lVB*t`lY^u zz~@}dGU(=koZV!tHC$)t7DRhH&^hF6xE<@+Q}CFW9X%MZp?M=WXi%urKneHYD!bK zp)Pzl4Rv}fO>i6WDP(J1cphq**M%`>Rv?y(3+vX_;%-^oD20?N2sto&X;%WaKkQUy@DEXse#!$K8YDlTi8M$B3vl15ODERUA8VL zji{_&TV5NaTRMeWd;@M;jZZk{MT0|h%~7JuRy71SR0JDv)nGNg2y?6w)w;xp3$L2U z9JJ0VSfek?>TT~M1jq8T3u9Dm6JIh}>ksKmm(b;pAx@`i;M{EgGJje$3wX95R5hbY z7zktK4Id-dH&$L1y4x7yHx}$S#P5N0wG4(^u}SezcP|OV;@kV8dhM!UcpdH!VubGO z>1!EUN>`#)HFY&jm?1#_2Np{$SmZiLd*5(tPe(N4hgeTj4-4ly#SPyto7!ZkiEYV$xjOsXdRhhtyE}Kt$fc>f z+5{heyq^)}?Na}Vs9Q9ZuwAB;7*~uSg9;lDxo~%JQ?Rifry-!v5sGtET|I_6L?{om zpAk(H=>E*}MBwNI{b{)%y&!og9CWwnFOs3QepPvvKP@BTw$@**EEzn1*7hP9uPoC3 zfvbBEUzzP5>KMPDxo6ExJx-A#1vyX|H~-1 zZSBuXgPP_3v>i*A`j^0=PVEpC&Dx%0p)0In?Gq@5xLo449Khz-Ej|AiUZ`EhQ7sem zVzgrL;%az-?I|ZxwP25`S0w<_u7@;y5_s_cA{J3KYPDGOD%}vqQKMEdSpRjl{{O5x z+pJc&0F9EygRv}+;)cQBVuL^9ex!Pls!0~z>F7>+)QVuR^I_NbU{`O8JOPZ|sr9%h z*`pej5&&tBkhH#mt<=S^E~rO=F$Y>*B3h;v1F=7W*kQ=UCm1@~|1TOWeKUX#?z}cS zcD37la^$j5xbSrk-J59b9vXjOxIjc)Y$1^Ow1>t}Oh;-fv(q}UJjYWU$649mNq3)m zoF{6!e0tVVvLUT=dDFNHFZVZ*fP=PxoC&C2uBMmjJPkSKAHB81RTe>^H>~;&XcV zP?LsEdW7=&K%#MRIK17lwgaLtN)DOg>gW=>!0uQDcDlqqy8xYvG_t5g8Wf9ml zcTC}bb&0Rr+;k$-!=ElDl_+O+L^*>O&O7OzoKf<9T6naSI>cxxQaPj`9bL-XZgIaY z1*4&5drVKi>Jbk{utz9sp~YaiibipVsoUAsS3G#~z_L{hvtucuq8-Z3>%8Le=%PnZ z$|bS(_^d9e2P9oGrgI;7#i6JInm=Ym-W(_1Gmi}qo`F3y(EN6*SVuO$-DrMK#fcBh zxsp#heQ~UIdNCM3juYQ<1={-hcaXgiGGo;v$^Mp4{HJS?E)pqTsfnz6Qu7O+__k+J zXG`m#lfN^frGbwRQK6qXlsj+!VnnY5-#gL05m)tm)uHF(;1VZmHrb;<*y$h;!#x^z zH0Msr_-l*|&`sP~q`9~{vl9Uqq85ShuUfb~DU&esl}H*$F17d*wweh@s}vWLi0MpK z)qrm1$^`h7jy-XFtP#@VK2C)gpgbs|c(&U(4!2`~!%*tSGQ(5@r+-zLnZO0iM zC%>O)Vs<{RPw?d4(|CBJlAdP9$~-7)?vPt$h-b`(8h>tPc3yUVaZUlA@+&GXEJl0z znMn^nDPx+-u-*}-r)K>5*gHc!@5qDNaHzVbstH$#IsOcPHmQHX$$*Wpm?67BGyL4- z+fB5h9xb965`JN_Qrv8%^)~V@YrFh<6jlLVjLwyA79r=?@Uvkp9==uOP^P>ftGoc0 z=D#)NE#5q;0NgYT)vT$+O<;PuoE|%u_k;CqTSM%3sR~+K7xP|puf7}oRpzr+WFi(= zT6)fG*)hoLFmx&YxTQF)rM-PX-j|LvB|V+4FjX!JJYf}}`)i>lT`VoC)KaU&lP>LA zeN|N`Xq8AGQN-5r6l*ES)AG~P5EFX(z#nDMe}lDQb#-}D8lJn(UXDLG^d}dtU@}dm zD3VKM?ovM%$}vHOKbo#uUKI{nJ&!7oBMT^L5oL&9&2uNV*J$RJThsWZPV$>6VH^^(G zD@R--spl}P=Pwj`l()hn_ujF;+(T0y{aq+BgD;urqD|jV&E3QISa{DnZIDCcXLg14 znLO0tcE`9pvmXq^P(0$n!v=DO9@ZKjG!k<@#Pdm>hBFFrnTC7j#;0PZE3x4WoW|8% z^C{v2S5ku<2GreiJg@|uh60H%6ITG2SAKLZ!1Vq*;u_ZsMd2sf9u|9DiRo9k5>g{} zUo#gOsk{|jqPW6bc*Xvmfp6G@EO=XOf-v!e4g~z#}xT` zq)4D7Qutzs#6Eb5;#=Y|$b7&(hM8tTgiJ!E%;Xp{Y5OwMC4LH-yF6pb+!ZMksFYbW zQf6l^_A)cqix(mD&z|WNPCVzaxkEnKV0;=8&=}sQ_V*1Ag}S;sxvI@Y35HbC+KpA{ z_HbLvV0*Z|Gh4y=wzS`%bm^JpDsU8KXAtykn=*WeaR=$Bt0rV7$^q1 zx7$rn$^5mrJl>Q3)!jq)IBjn;`t3-FM*bBKonlu4h1=V(JTV*x6FBM;d z%&R9)K&GtJQDjnWxqmJ0hRj{@iK%7S6 zXRW!&o4UGRRuhIW=`PHX|fxx>DQU-EPNR`r*kH7f$u0e-a;1I+HD(fZR$a zAfM~G_(XhQ$)WQnXn#s4@{^TLKq*QmAb%{KFH1QbiBY+K%A#VyeJ>=bmnb@Z&GYM!#wZKn{Uusd~o2oIjhB{af) zsr?)6mdibx9@TB3!4vn&`t4vUC0B?yq2%_d6KNE7r)cdSQ}|!RyAXcCw226((N$H$ zsKRk3G7{rX79Tk|>~=pv&Fry(!y9&!FO^uOs7uw0(Lj$}E`TfTU4Ib?q{V|r?5 z=TL2j+B;PaL){=$^|Wl3XH|@rW-1ov8#}gj3=DQS>8{lNrZcIq{ZT0*!}Lz&&F;(+kFO6kFwhtZ))a~UKP8h zql3=+H@DjvZ?b#xwc=LT{pZ;;Ka*B2PsE=^D^Km~?P%S>9Z!y-e4>fj zaZ1h%Ieq|IVYg{}#!ka(!W-g$q5j*)j;a2;bY6=b(2k%!8A`t$ODVO)DXrqX8J_gp zQpQp`HGRTLixwtMT@pj74D^&=h^wLWjd{u3{2TFgNEtGD{?-G%dfXf%y*p~8w=z7| zFy0t3jzbJi_Iws7lhWm>Ai*M*+r;U(szQ@D5~sdpE}Dr7n^Fnm-;l-+&`=*)O;c;d zH(>n!`Tv*3(}+64cp_THPrH?k|K7sHY5QXtPt`qbk~je4-}T2fUiJL)9XY!Fx>H9~ zhIh2eh?_uV(1Vq@NP7&GH-74>PiFHDS2i(!zQUCua5d>00N5E!RHbdh7#ftr*>8bs4H zD>{j1It)rYOBpov4+|3~Js8U%8afjb#2YZ^<;4l9Yh-m{(2&=yO)dS->sFfZbz)72 zr-itHrpqnDe5yUrItm_j?#6XzhutLP+%EA(@$nqYdY6n-2Ty`nhpdD#bx`+A65_(S zp7gJMZoE3sV-Q)b1K5~;$fljtA$CK@rD+MNwRWuf@oZ^F)vuX;bXz#Z)B&IP+$4KU6)J9=+lt8=bC< zV;W`E=m>HrbS^Kc6(1~hsD5TIG07Ds+y%hmAWl7D+2xLzEN)Bjq~E_RdgUiVDSKoo zwHt&jy{)Ca0~&Ig?Dj3)I_6yQEHqrV{Ik(8i0kQ&zL<($6Tg6>Psdgy7lP~-NGP}M zv0b4BqFE=2*P!9GjA&Qnb)>E#9t3o-qDBEUXS}N$JqXOYOB|TzN&kN4n3A~-Yspc4 zf23q;z_Y#LX-K~IxUnUx4sS`eE0{*E5t3!a&OS{%56L^TqT6e%Xl&7fcM zGU<+`N{*4U9}@ScdeZ+ewki&frHcE8rHb$|RZ+Z>7mFW3)z7oX^ol!#t%?HX@Jh}@ z)UX`WD;dD#E5*}L^%k!~%Uh39iH8s#nOa_n=y&SCT8t(Ze?52R z7z_Wg)~TgroK|ttj2KdAVxipWaVnFQGiR-M3(Bs_8$%gajjnW6Gg28Q72{P#)idW& zvCr>GKR-WtbkD|)S!zdb$H3+tDuUBfx6=wL7V&uEM()uBEGnRLj}t$I+WiIoG1Q`Y zIqsy4?IVWQ>8S&l5#ZA~a`lMVXWF(QEXm3?Kq+?UBW;sI_}tsXc?&%04;PLRl2~Js zYDO_C8@5f2u#HMjw{1g_naVamvqrUzCQ!$giw9xbQ$;b_1{&;8hyDE@j2f63I8K_* zSjz5&T^1_o!$NxEjCO-gqezJ<)zn1gYFdh%&e6a%*x!Ohyr{Z7_E+MPYcFL$Tn%g9UNJ#yV%O+DV-3~UJUo*FYd$QQs5LR}BBqX`zDAD?)@Ym)<*<3v0kh&vB>>~AGre~ILWYvA{d4cbdguc33u&*?zkxkDLcH-eu>bOSajBcdGrKK5k{>r;jFMd^i0j--=!p+G z^&&&klp!QP;&DQe2L8)W6c4+X(w$;CJSb;rk!K_EclR2BM6&>2rjluYqdkP!kBdrf z(cFj6fT2k9P{-DO+{=*NW+V3SY41>9^8(B?dMXbqPkgV#D7mUs{7-}pw7{NtGF*c|b;xF6|IU`IpYU$wtYiW#V-y4exmU^U@wI7k|;V z(bp>{Y@AVYVTHKB3-?0R@b4&P{G>u$OEOM|Q%5P{E0yBw%8a9z@zYB2U1>&H2s`v2 zMJ%oiipMz?M=9Y@P`scbfvw4o#)PY@#BVtcM=9ayD)Cn-Va?i5<#>%SO1`v8?2My! zux4%91d2VdN?aC)hZm`LD2G#IS4-i}k>c!fR3#}GtNyS`{D&-rx*m6-JFCSl%D~z( zR<%*}YP%mQd~kTH<0)#@BaM8+J$b!?cS5b%eDaaVL}q#JW0H*B%qeZ*+7kw8&-?=xm0NUrT%NRIL}8dYD3e= zQ6c)QW0YK4D=zcVW3X%1)Rv9XDrB%yMh1r()f2Vi4~x_31W1n|(De*P+@e6@lBy8S zd7=oXA6qGKeWEMEs;+mS1Al$g^wZwRPgo&n+fv@Z#~nmJa0)xlz+1y{T!X z6Zx+GnwB1{l`-7ff#+b1m4B=gPec@!-q3ka6;4)#3mk<3%fik51AXn-6APD2ICC*V z4~8TgEAOrsm!(OYx_h_9u!{|WiBc4sr%i)h7dMD+j1b_kO$&g1)}%3JI~dKgheKjlx>b!)-bta! zN@%S10imCjcO?%siQlKo4jcJgirsb7SE#NVF`K5ID=)*F)irptdcLN4hrA+h-a*Zy zsM-0b4bN9on(gOpsLwxJ@}FzPEz4w|kF>z<{b+&e869$5pJ((FKF*Ge@qmmv4?USNJaKE)V8NO77{>{E(;&7&y3eZ9DLxvcyskF86W zE5@f6*E9}?jlW5~NMh;TXq5bVz4&UzG8)h5JuM!cjW?-{%F6<@VEX#7BcjHe!dUt4 z2Jvc!G`FpLplujK;ran=PN4gDN;Q$ohdVp*z>GRK)S^51K01@Q>Tz$S1J^rp*3l}N z@N_Wpmv0-yhm!eRGSDW8a+Y9ygV(Swan58ZQivh%nx`yGT;9L(yPL$W%m~wP3zyG3 z0W2%Tv@E5108FDAmQt-Qj%14c0|z_UN|3Ruro5A{%m!ghv-PKgrP=ap!}Q@`b|TUE z`NG7E{FTq1BEEiHgbOOVbRCPDxgw?uM+$Dnp`#8iuAO1mvn#Loyf_qTmkjNgW*s52 z;tIa(r1W1F*^-w}6<6lVAualmHG5DyF02N%4HV;|jm|djn3ObQ%L6%(b!Mpnt&_eA zje)H*TjAD2ug%--#jup-9ZtkC<}`1|b7goB6cTn=P^%KvN+D|pD;4&6$Le8N^ah6j}kj

$osl+z78 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⋘0>71rNu;4RP0(v& z;eNLv(&Y;{bxpzAsEXmms8eKy$u`K{FjYL<0wtC+C0rK{?QCek$q!-o;GiK^gu`uq zShqNDy5R6e_q2Q6I`?5itYosH+IZZDHyR?#6qYx=5pe`Ub$)6XaDKKFhESkN4Q%mk zM95V*uY&1`f|3T4iNa@x!%eL%+v(?)EeQQF#5&9>I_e=fTpy@w3b_r(`f!*`(-Ja7 zfp)@ZboD7Mykc2W!V~+?TP+~wSFDokn?Fvbw)PPo6Tvb|CUQt|CHfe|} zr4OY>MrCG-ud=kXyrL8>e@TV6s;tac?khuNZxfImZVI5N*v)sXMUJuJ+by5?#=OpA zn4?W^utKP0OVhs7qH@~V!Z%tTYyi8VZ?b$%BPiR~<;A!6Ez)A94Yb*BwUMKZf1AxG zUKZSL^EY)kQAXS;^=>fp!CwB5Pj{K#oF6g%?=$`5=gRv{|2byLhs*$66m5n1sOiUs zv1h=CP0u*F^AXe2G|cRo^D$*hwo7bb|G4GLnncxwdo1sG`Sc0P+tlVn+4Olz07gWz zv4B%q+Ynzd>ClnsxM@Q?DC3X;;6c)rCWd&JLZFgzvtu^3wx&t9JA;EL0sm?8Ly)a$ zj#H>5|06PH89{V_crC%C4Dy7~V?AmLZK?aQ2M!&SM;W(xdGUo3z0_`vu`n^UWfZN4CiQP~;o+hudPmB(K zC#zP5>!{Ph&k+A00t%Bw`6p43YZm2SL_v{}6stL>;71&k6jPw=^FY2rk}a{Cex;;a z!ZrOWNw=afizUTzjRR3o#&Y~-(UG0J%*nUO@CkWjb~`?g4Ir5i!|??;b^j~(Qfa8t zCfA+nXRK+(9DhZ_=(^6@fni#79vJQ!oa~KYdZRyGki#Oqrr}JLGL59Aa}i>SnD6mz z{@CSqN)|myBAFMId-}V^46F#L6=l8Roa(X$AxR?DoEI^-wH~d5SrnQdC8b)pC8!Nv zm0>!!|2k3WCJY6F&^ttxL{Sb1Ju0?H6xmPcJ)+v(Hfe^vPn@Mt4*YF#w!%5|lVY2~ zIrt00FQwt6ciaH24_s zT~)0VJt}ruBo=v8?6PR4n!7EUspTGy#FF=Xd;NYDOP`-CILcQYCH*wgf;J7^Zji4N*UIbG zJ7T>LMY;}Kr6Z zg(2pcn7an$9uTv_7VPZG*?~$fzOy z4s>@z5a^-40YhBnB$O<9s1Ihm4rnN_3+Q-c$`H2z4Tfs-HoAL9+!qtIr$5p=IT*n` z0AphVk+Hmu)u0ZHcjtMh8>BlP$EEH={rK|No#)+&6u%!r>rX7S_oRg0LqeNRsA=!e z$!K~ngknP)Da1FvhIoe1)^pHcf6_$yx^u=Y9Pygoqh9XP+keGBjD#s-WIcFMYxQ?i3w z{VySgQT_KvCa@aP($U_EW$dMBBKBH$mq=7#OKU8$ziwoBVr+yjQN)5{&6gbFB24-J zAA4^CUuALik3Vylkv zYB+Od&YW}R%)UG`c$vhCFW>ao*1@FFBbNQuAugeYha}fFHe;o99I=u>>CtGE-R%^g z(oy{{uYMy zjg<}cjaaa3qVCa|=5RSPoG!IiccrZV`zP9tOk@PA&nj8puajoxxD;Em;jIb+&3#*( ztCuGXUE{V#HqQT9O_ItAO3)(wW#Dfy9KaEY}v ze#z%CjNWai_tS!#x0pIR3@Jtv;I&4C%g(SOO1PH>45MR7w&mqsU&*Fr-g8N-QId%< zgkt?t?;voWi%|w`9>~#6{wBk@TbCgEc7gKjJS01OAAgL#Xo6+Pydore>9LgovUiL+ z|7P5Gg7RZ={ZA}8YJ9r{=~;@uQ>pCCL1Q~apC!t5ZZy3#&W*axok~Ht(F6Hv4ozvu zHnbBL6eCYhp#g3aUK%mig%==~d0iM|X63|kap}fQb=VDCNdRjGvZ45(^IA$l-cH#> z>3Oa31g!S4~?wrJ8*sHmxSc9OI(FA)0fP>9{qG)mtm88!>Az3tyNzW{mYZ#;A!` zZFmSuXAQK`)3OFD^dQISb4)+KYC;3MWL&WA%17NF$H}E$j-LGKs#>p8S3sMhFE<2yI8+zU3FkH_6N~I zclGqQ4dGE%yaiOdv9<*x1jv8KB&h?5TnFjwA8zjnMiL&!dYXzi7OVdecxcFrj=)^& z%I^x4)>O(HjL07U5Hc}%xM*Vo6^Q>ean4h0_+I4DDnm?kO&)i4h43`$;9z&xK54lu zwarcLHEX<#sMId=o{qdlQ3+Uax`=S~C~x>e$ETdwUEE&X)PQaX=uZhnAGNUoO&u&$ z1iz=rPkYe*%roS{)~WVp6~gOhl7`GdyG3tFg1Uxv75Uz*+^}t}x6L4FJa7KUN@=fr zlKzgfdk`-@;6cNQr&GrWOQrTyX?!1ScVOa&k+#}m%*q-l%2LS4j# zY?)jt#)^hiT!U2L8ivVaEyyGCRWSg!o4^gvat!`EY!Q*8W{E|u(gk4xIci3O_P4Y4 z|F-PxFiYVg6iR9j#?w548VY}z6+X%JNYx^hlgzryR-JUK6-Ho%L$7Z`uf8_f0gPX% zb-O6ZBMOyb0B#QvxBh`%s$y6d)UCj{4Xut5$y2id+aH1LF!Qdi~6>ca9I4{>b0vbT$N zpL*;aHBFy>Y>U~L)s@pS;mA4O7GiMJVo)#%(K%{(srqT~ar`O9N`m2d-G((9jz3#y zf#JAgx;08wWBxihKCc)xubbEe&UQFj&COiuy!Qn6u{ip_V6^X&LlNvZxs;votwhvM zCK@H3oCsWoZPZzfid=de#71foUUtz+VFxy!o))6)GY)aJI8`?v zYS7SS2*kjXqL&2%Vee=gHwmNcDTlZwGKP+DFj|EDPI03Zfx0419+m%>X!+382;`bN zD)YCU;&zLgIx^k->1a}jO3XgnLKRXdS_1*R&1xJr%DzhrkET!?8_h)u2N%GxxxDHU z_gGxe8k)LCP3diJ@vSiOFkx-97%W%OSk)2M^_Om(JTP@t&FpxBkjjyuO6K)3;)jt@ zPau?IV(szAI;L)rbj+xU!>2n>MMTi_Q8V(^Sn*fKDe|pvqC2Q;9bWtnqWC=;E8cO; zmvl1Gmqjb5mx1uTSn*|NW=DT$AL$#$Gg>|p?=O4AH=T=hlyLS+OnBatm}foWtM0{J zZS8}0`mV5&20H$UN`2-~-YoI#s9FiSKS$O^%<6g8p~vH(5@%{MS)<^w-{wICU(&d( zILoUN-i{K02oCHl(pX&e?Bs!osOdrYZ6+=|Wn$*|Ww;-_oNDn0hlpiIM^w&rii*9+ zXRpd?xNhalg!55td!l$xBgDbALYWv&`6G+w;g9Ys$)`1r>l{*7Ia8#~)myRqr#4)z zb<8h1u#kC|gVH4FXj!qwUte3d&1*Qm8yUfH-sf<-oZrL4wc=4nRdrp9KX7KD4->o* z^yujPexyBp#h9PqcMVVV` zFHbw@@RL%e#gFxl0G*og7UL@?@r*4DVgt?VYin9COTJ-rS&#SUH*u?U>U0bzlaQ#$y|w$Un8B3n{fD6#Y3EmlKhGi zOwE7qkXyV(lmXZ@Y_6@Z!X_}CE~l^iZ(}-hMJ8;4 zrLAXg+rB|whoPzX4^6>YcmQ!g?n{TOlATR6Ocja<51SEaf33MiN6U(cwakq1h*Kx6 zp{Ay}+KiDsDvBlLQI=9tr1@uO!6tP2z#E~^Pe9tZVSPnQ7S3J!a_~<9{ZojfU@%Rw z$db!s=rS)B$}vDidbGbPc{TXa>Ul(j0vSPZ3yVYaYOD*BJf$>fshFw;7Pn{`oOYTw ziUuT|;w__*oB`NfnzbiCXOAyuPeIO}Q5GPdG15=GBGbP|rG8~pbI~wAT-iN7 z$=z2nie8&4f*u^8O+irvy`m=mNZ8j(d$Bd<@8}2=7K|VtcLjqXfTpar9C@0%&AY~% zwHpQUJNaCcpslqn2zjxz7Dpu;Hr8#!dhi&rUmA}_vQhh|H_JKF zfl+fLwfAM7zxY5~Vd0;eTG!UnkVoH*Olt6yi8kZ(9!ud`-eckYRIQMWfz zF4w5(StBV+hp~nSjiiEGasJ5NxVse7FzksN?~DD;q(-`VL+y&s5Ena>8)Y?@yX0v& zkOZ8ny2O`@tAWdz9kulszJFa@>zt*0_{7?M;s$3@_Fo+F>G&kPr7fiP*=rq(jdcDV zJW2FB7Q50zmHol4E@(xlhd!-;PAc2gJ%D}_D))5+1H19vwkQ|h@wl^(ILBjoB%CEs z$?{kfmiSUX3G>SzfamqDad2Mi{FYT!SmH|d7cx_6DaW%siS#z z72-Q^N2&M)cs}h;By-{%#|}KVA+s*bpixqv9_k+)YTnu1#aZoG9B)V=?cG>q?hJIa z4R!`PyL{5t0lK~*$#I2vcbYro|8zKT=WaT+Ihdxq ziyez&(l>-uczpT>y3PTVGt)P8Dp#Ts8|v<~Y%bH`P8OHUbZ7r6E>p=oZpwtqrDVe8 zaegf>$vAG8c_+%Bl8NwCB@?bRB@-@hG?|o6_od=m$oy%%k||QPOmZoiSMPUde)S1@zcXoH-RIrv4&s=NTI)-p!mQKN;5u9mcNSADsI-p2kpslleq`)dL zvi5n_iJw9HL&^VX+DGVJ6ruMtw|E13ADw-2^yc2~Bv?H{Z@ayzm{0qjxI7URH03{B zZ@axo@9D$hbI|+gxwB77DVJ@|$tdON{e8jqeO&Qm8_FF`)FLn2$hchb0FrXcy#ISi zvE_Nq)CdRIhCZw9!{X1pn^9S0k9 z_S_5jC3o2s#G9TKmS-YnRVeaC(#%I3i)SOlW@JM7?@Q$esHqRnrkOe7^H6^O!hfgo z)S`}3o;*$E6F$z$-;j}%us@pel-)C55f4K7qu%JstD0Z2uRxbym)Yx@Hjf!AGh!!^ z8PsBpP7gfI^dvS?dNPvYZ;6r?S&9B_~?d%weY?l(B6qhEsvmeF?c_PXf$7O9b$3Rp}B9u|3 ziIsWSrp&Czl+_b1%SejzL{UhNE@z!3z5#`v&77b@G|4gZKn=>m6{2C9X`Q4kHieST zQVPv{JR@n^p=b(G(>d!;;t%MK(J&&{QZR2dS5MU39}{SrZjp44Di5@d zf}_mcn0E%PA|c0iN#}|8=3&&kbb>N?5X3TMCX6eCs%O&6;*$C9?2AsFs0`E?SXRpb zHf}m((N3-w2O;A%$f&by6~fukV0hm(QG2PWQ-9BBlO^9NZaKxB{qw9zh#J>y(M6Hv zX3rLPLexXcCL?M*>qQkM4LJJ(aSud&Ejx0>M;1Dr8FLC`*60$)mC(Mtq*i>e)S>E` zwZtS>n6S!^#X)pE0a@i{zbfuXb7x<>JaXkHOehZoO`%qSu()^Ng;+=^XtBz-OxB!$ z_%S5>{Uk{k#C$r~A63vp;#mm#bMrXRp8A=8XDkdt7vS;35aiiCr{kx*nu~Rm_&C-K?!GRt7 zlm!#hN3eoQi+DV6qvX*5EW)7k6U37cyT8Ocj#v~g+fK^(X+-mym_C3JL5Nq6hPD_KRgy;QCY$j2mxv1&xwCIB9mgb8>ukEIN+|6gC9|R1%rM=EJkin(QD!UM z;7S=&H>$X&WQcD;w=b-WQV>yKhk~_zoxu@362{2DHsrABOF8OE$1Ms~!Jf8#njGZ@ zl}33brDahOm8)rKayUl~*I=j(i+B-vdCL9blEv=q`&La>r>OaRVx7j+M&@2xleh-j zJhpn0+CxV@w#(qM^ASs zAa_6e<;aDaj!cYk!q5L5$9cOK%JF$iI6aa^`x~R_kAeR3HR5BgC5k^CssMkyPlFv$ z9Oye9&i*-&e`k%j!o}>F++-g~PwZb^Bd&KXr4t=;=mpNgqZA?jVaEl92lRhFP2A^N zMmxo_c~FU^MV@U$-`!_qCOJ|%ac4QfP?Ob!SjRynwP>aLyb+~!DA*gqUWTkT+i*vZ zu5oa)ADz0x$`kK(7-fGwUHm0X2TGyV;h5Ax98o%mBNNc!*c5d5{#x-__fj0N!oA{@ z9ms7mullGw%xu_i(sz`Tj%lrYH@QMMjYio)KMtega%7^Sag_n0bwFAW z8{=e0`LFD>jIv+*#cw1xe8cs@xgD+$Z)x4=oee2nC3RxT8D)Q{5EsWFdClvQzA5s! zvr=3~JkCU-rpV&;N^!eVW9mGfptm+I&= z#!{Wf(q4)#dr(_+>O0yxI;d0D{UzAAe^qu*y|~ZD#_Zyk-XqyiCunDLERxMJVslRU z+x6nEQs|LM} zHHgoTVqnva8IXRI5IInh8e_l$m9;w2bo+LrcvrE;(0!NPT2Zy?WUY1sid1~`O5+@I zcJvRD(@S%{D<3B@b!9iUh*z>@g$+NKVpZMj`Ks!M zji#yQ%4vA3nuE8h^EIveipehpWY-6FPC*bTm!52 zqvWYGI+Sodq|zsR>=ha90hB@xk{Se5Da9-GxIm6PtnqUi8uHEJmr(_q?FGii6BCRU zgskCFf{!V|$6Ch_eAyOpU5?EBh!pFoi|C)AT-<+XOYn0_?sHM)ZZpar*dlJrT~6)U z;O>DTZk>&Xsf?bEUc+-2)xNXbQIs;PL@oztghFyJEPj z3kPOY-%y7F?0J4KQ8nOXY7p}sIqGPaL^%D6@SM$qc*=?Ul7SBCDMty`BTnWNXD@S+ zOboeeo|ci6(^!7pc5!)Lm}=O<<$fm<%L-97OUoJn(U^**WvR)Lgt#AYFvwcM8@Fc4 zoqVM>JjPXfz^-;HMGy9M%JFELQGUl+;-PTWl~rk34(1U@qUwGktIkN7s#VKhZWXVG zDzCI_gr8Uu{)c?zD`R0ej?JL5H0oxK43a0Fzk}31vo~kKvyyLlyq`WuFza9`z zh3lnEI-Xi5vS>dnDHHXtv}oD;XNv>HvRjBe_Gfhr`4_2lQ0hsw~kl~ifOI;?1-)1ZXLndJbWvQnEOmuyJFRjK@$Ai(Tx*8 z2abW|tfW{^MpFI-W%ss=pBBrGCNfP{SK}*D15HYkaXc(dG}_dwGIG?3{$#{z;rCfi z>I*4Q4%u`kgi`|KIZ&$_fYuJ}F#E%l);{w{^)~d4vB9!eI>gN-(N#7(Dc>t&t2}CC z3#~}GV@f%*qms(O(@KLaIb*9Vjzp?_r0k}kc(p{<#Zgw)-CMy;V{42aEn-MNhE_5i zRn9iL3cbK@9U^hapyS(yA_mzZOIG}^qWva-4v?>t#v_?B%`J-+7&;EJM#CgTDt zq^^47I^4sg{Li=i)#d25c)g^ha=me$6@c4(a3hd$uI1B=FEcmQ`J0T7T7E6n_-eGq zUt5P8v5b%4^Ah=^Z(=c>G79lmgl}S<3-IZx3^9x$`F#y$r%~^|)1TX%ym#jGJ$L^I z|E}l%^1GGz2s!!%4CW2v_^{@WH1?SL5?pUd%Tu0|h(*SV1bi#K2#6E!=+3Fd^DwSV zBQEZ=IHw1%)vI@9lHJzJGBM#^h7oIdB*x&qZ41S#+7?oYh)IGdrrSNqBTjp0ig>$+ zVa(7d5zo|!VI*j$#XHgRBH~#~4N6gx3rTZ&;^OdB4mrs&I}0!5q#*MNyD5jr_^6AkH9=J_DRm?(HbCaP8>P|A$UqK;7@rpiQAr!->{ZU7g1?g9qY!DslDme_JI1e#bCzK_uN^p8k zkFQNpwkZksR-UDn=Q^faX?dyWUPxUP?nz#&Ew6PcvxMB~QQQX=5_oFe<_WBola7THeeAo>dEAG#|<%y}?wi5W}dk ze77cSOW1-`u2WtbT~Ew(yjlw(#m=yy5V1j_hEYcjr>8u=2$^#_a;)C+Aavs#gi}#! zAP3%9NRcH}WvOADsZh%5rn!<6m5XL_lA}fW8OEl$vNUZ@MQPfSD$DxTBFV`yEeC|# zG-4Rr*$Ji3QcfahRZheBkftP=AJ#}t0-*s$V+c80Au6OzA>@w%k}pw7?T}6g>Ldq= z36jGwy4(`%AV3v;r<-*(jBa)!);Y>)7`t>Z@$b=ylH9B5DXfneQhn@~4)6%+6p*oZ zE9CU}av%c=NlPKU1~r0SuUOXL;WBB_J!_0qD7<%;SmH@`8^%aEJ78$}o9ZW~m@s3W zzRP=7QD!9~WO@A95I5b+~W`cje2# z9dvSmPQ&%Kg+g?X>fpZKc6>mG(9Z5Qpu?dME`%9evuahLFGv1UQc{H5AaXlG!)tJj z`cQBr7w_oh=5_&Z?(Z6+$MbS?+q>}(hNYq5p*8e|2ToY^2ElO%!f`W5E56f3%-;O= zR+{(Q&$D1+m)DQTd%A+X{hh%zUHttX*Y#-i1a10ChO7aVGe0cW?G!rlbT{XI9g|xxm{()VV3(=83o!xu7 zJA+>NX6`6MOg(k}@Rv#yYNoBjo7+FNeCZ5^uv{>OOr;VRX)Reyqs-Z};bsCV92u<;T{5Dt`6(?eL1Yu#2vLXvMg@RbCU)TAY`k z=R=9uQ`}k=+=EkgG7RCk#--Kb8^J`yHG}c8#iq@*@`*ye#Ci=LjP&MKDL%?!-VS3& zF;s8D3w)L9t1CCy{mrK$B@Y$V_E041UT+uPOTf3W!6{@_$3T}?8F{ipXWgiU!MKmw zQ1qB#I6l)4!|{QB+z7VZJ2?*FJ+}Cmt;NxNL;hUG`)>kYs!gAO`R0$pV@(YGK5z`3%pc+CE6kr4IEG`>f2Vzve$)489NIv?FdX_# z59x5kCzk)zIOqvC`B7xxPv~$;Ebx15I69_jH`{Owey4rhhR+0U+7t27cTJ;bY2^<% z`l@L~HhdQFQ#1|)>GK=|4pPIFB-7*hh7Cu0JZ65+au_AR&HMrm-mz+yf=IygfqxxN z`2!AFvHdoDA#k4!UyRA*J2red@bB92xxncKVEF^TQ-N37aLA8Ivf+^L{*?`feD~*V zIOMy{`~yG8ch}m&A>Xab8>I*GU9Z`~A>Vb_hNHuBb=vS1z`;}f5Ffmpzqa9cufTbm z4bK3+!-i)AhYsq8_!ta1{$j&XHyod};m8X|yA8*ERt|a-LH-aQ?+1xzZ8+Xc5ZBxA zMZmY&@MXa5>BkV%c)=D<_qG3*4bOr56Zk{<5uGSMPPm73cm_%jepI&jNA=r4om@a6 zkE1LQ{0YOSQ5}GbIE9M@_OEAXi|65Z5+Yta$0MBLNq@wXa3$uYL|@K)fX`%HhNH~P zAsl5XnIPnN2|kLsBSF;9)Chk`2Y(5VV%CXpk*simGDH3XWp6$~l!rwGQFbJbJR{2p z)Fp}g8Lwu16XuT;j(m~fK@RU`e3EoW$3M*e|IPmQv;PtHhux(d*iXuN zk?CG$9OYi>`4`5IGyV^SJKPGV@ioPFpsW!;2g;blQI;vb19q2iE&HFr_*TYy8J^4V z5W}xC{2@cu%kfWzJJEcR94GQk!gUM-3vqsI)-;Je25{+j|@lpBz#Xn2l@uW z9k8Q>)eHw2ev;wM48P5g^>w_ja3}JE;yY1SC0xr8c9Qr<7^3`0{L>6kZX^ynNO(j+ z(|(XwPWJg8st!S2Z;)?m2>&M5BkcYc8pc|}VULw||NU4DARPT#3HvX#hu?(-2g1LM zWehG=sLcWC?F#Q5V1((;K+AKC>8QNJYoF~eUe=vu@O z^_Rk3`xsu%km+4aA9J4akNFM5zbP1dI>SbWoPV)*GyXpcdN}_*EsS?DJfGox41db- zmkLfxVwlOWoFV7)v;&Mk#!$z5OX1Twebd)7ej&qa8FIOp{;I;`*#2>=8LwlAev#}H zcbMU~6pTl^LH_Y*Cna3Lu$SRQ438=}gY7UQjqwJC=yxdoj2|#WyFmENH4NFlGtq8J zf0Qo?-&HVS2E(Nc{R~lVi7tWdlkg(re^)RO?GA+}Ud{0541cHKtPX~|8M0l`JIZ)T z7c;z`;VTSTujG1#Cx4jXR~bI6;B2e*r@-FY}*N_$m1e&tdokL$1$h2?|eR zz0=NSe2C#^8U9&88beS%EMPkS;+ab5bc$@eJ3mla&h?Zsl2yEvKsGZ~gMtYCNs!?PIfX1JH( z1q`{IEWU$rZr2vy!}t#w{*vKu7{1EzuL@!lKV%aZ8|U$ThdsSLS3ELqF=7KR^U7-YDI zA?MqYYZ+&~mT>u5!uhy_%g>UZGTrYL%w|2Zx!z@eiv1r~a5?AiaxTBiFJgbL?>R9F z&q-&<_RU$t_y&f|Kj$*W*^W6sVEktcIX`pWQh2U|A=j(iD#lwGa{lCgjPYw2-p245 zhOa4@$9(eG?s<9a&-TvS$T;)QyPEOOGkky{x089lV*F1Eu2{;D)4!sfac);uaJ^f> zc3$xr4*!yZI4L2^ZT@Kt&rr}ei{X5ROy^_!`F_m)zf-V)%SQp%tAgv5zd0U6Ib8+Y z(mcvX@b7Z`pNG}5Jo6UbK_d^>I}WwA1Mbu=taInd)!RU5xV^8f7gufNS$;T1&>OUS z&^b3dj!Uik!ERr#WZR(@n~gkLqQ-J`U?3Mm{|}YkNkXF%xJ6L9f(`Kg)Tx4bXN^*s;J-G)Y#J&$dp$j zN5oaPSt7#Toy8QP&R6emstuIp7ncUMMn*7+`v&NRm%#4Os+Nxa^}+4?iV=f;Htzb) zOz>X0m%;-11Kpd~RrsoRZ7dF`7h-JWSV;{AI(qZ-b|S(yzl>1Pvt?i5z@EnH;?5`$ zdI!4)u>ji}!bZS=jJ9KsjJ9*thL*aXy}iDIm19MN**ZF8oa#Dy;36=bc}Ckux|{Y6 z40i>piA#7=IQn6JL{z}=n#qprI>GqVY=(*y^HGBaVbp6>Q&+Y7dAnYsv3^of+AQPEYl$>?L|+o)Q|S@XeEw~8}KpGbL*P+q;>X%%l`Gm-Kgl?@kn z;xUo(9>Ig!7%Lwq(ojTU5V<4OA(fdxE5*F1iJfYJ;J8yN4Kl8k`bm^x8FR|zK*f$| z<0e@MY&@n`0wjYeXTKSH%6YFFfC<)r{rWADPoTa}synkX65JRyI;ynn*r!`=eriu=;4@ zF}3+mjGA>nGV3Phy;k5l|oyDDVZM$PIJ^N>>#WmUI^2lMKAhUA?(^ zJ%$pKi-J#qRSzCztYvoX0k(iSEWsJ=QGvSOFB%<$;aMhLH5nB}ws0%Q@b``Om-)A9 z4F4$nt(E@x=s{}@9*GUo^Tsv9 zeH}yHcx1OV>Y*WgwbKcnZ9ScI<2TkyGKUO5CXegdf^F^Ha!)bcU8zqj88PwG#4It} zF&7^N%o8-rOm-TT1$p_aa3|h;k?tU`cm$*x=`J|uVfHDR#3o7V>G*f1K)}R*jxU0i zqF`M@{)+G~@zy_fJ8pr8oeuj9QRxmv(3K15P}(>d+~ zPI2{5(?#%eg4aa&x$?m%8b7Q<+Vyi?3A{=RwS`5}9i14Rdp79K#-IL;kq$SeYqWP~ z{>Gq-S&zN3b4@Bs_Xzt<`vGX8r8k0Zx)&^tkLKt2B>c1vaK^*V&SO#N&JU-CpTr+dPNxkN#;}u>CY$8qu_9B0xxPXqv^!=;AhkC zR5Fa#F9+^1^gA^ZVf3eeT5g1Xr;=_5G!dYti_q`XUm)xUqv^zz@U!WcMdeECmkak8 z`epq$!d}9k{%N@p`Yj{=^rwHCE<(TTR1iFq6aKrn&wx14PE-6b(ND37UrU=4UI{c=8z^Di$UT>r+ogIdrh6Z5TRPTk1rA!74r*t{u=ARoIA`NU zxc+H=5q7Sky!ebJ0@QR7>8Q@aIgF|(bl-=cO}~*I;95WI#f_!k$hioM$DjUbxe@w} zkbWbY2vE~S=(o=nB&jvsCxF@X`v?Vk@JHpqi$86@h<5iQpmBc=;rgffMF_g!zd=Ae z^iR7(@X&GKyx=P!JF1CnVLRd0g#gZv?+0BY91Zx>{X!z#l<(8<$G^*nS3dqI9VC~iHB@FRapM-KkR;&&Y8e30q#$ELgfTL|+qU6GA$9^6j+@$Y)*=eSp6 zfVwVH-q`4FxC+ID#vuBq=|m`u?sh68ZJG#B(yb^cEGqI^KVQ+x;#EaHUvY`on=if9 zzt|`#DS=;6aly)!(*Nw~7gX2P2!|FYIZ}SxJU%-@6_!p!;+JJ?Hk!Y)c3tQ@53UP+ z4#!K<2)1tikL&rovYq?|NVa&YZHD{DQ@)4eSGfG`7QoK zb03=fn~DQR9qWtN`fK8U;;8XzsvDh^V(z1JpH98pzZFzZR~!P>a!^gLN&J-a2IEF! z=d=Y$pE8L4CdZ8;^+*238=VIo2gDCu*Lu?TJoUg0MvZspG<&#Fk?`o*IXA>rCZ6p% z6bHTH4!Q9!QkA~;fa|Gi4o$lue&<@_6F0`D`m>FrDH{?hZu|v~*St7up|NmU?9)e` zJ2#wNxxiR3EwSlnEV*}HarQ;|9-k+@>8W?VGUI!1{0OcGJx{$yZnVhnzfXND*_+Iq za?cxIyJEKMYZulmojs%S!!@&JmsW0bmCXBu*YJZp(3jV7(mu608L#0{b%S85{@$Y%{dw4Wuc`=c*)=*Jbc*>7M+{yE{{L-mE)V{TZT=IR z&5e9imiL`2Z17o)}N8$K#pineK^;jrUML89utBf^jl< zWZCs_MAgHTPpv8cM1?bOeyllvTprYC>YA6K3HQAu)?>oLDtIf+kn zK2RO@hksCJh?7x?In9pGaGKnxZ215Ga+*X1B?<+tr@wE9m;S*g{ISD*bRjA}yTpkE z{YgK**MIZ$+uUMx%&1j%TrtO;t76yPEC;CnM2oknJJgITiW1>W!C!WFs0vrFFe={f zwk|4yAAJ%ap4rybF+4CJIUIK!+`7H1kB%lF7#E4*l+E@XRxrpN+n}fpcO0zRMmJv& zFOTaQ{I|WmXICW>p}Ak%I@A_2J+_B%0|tUfH!%cEzRx1D&D%q}%%GI*p*<#2v_0(c zOR4ldt$cB_WVT%)mBRx{GBGr+*gg^n(7hqg0Qof`bWs{1cWzfYA(*b*dKq3L%mQBW z9u#;5?Ofrn?y|#&(%W=wtOXlyf>QoeKT(H#iJ5`co!WQ$31ezymg4G{Xhn-G|J~?8 z!g(v!AK<18S>+*#N|@Syvv*c*;XExy#3Z}pV^ZCT&U48z*X@j%8kBFIv zP~m*&{CRG-^ZOu;NpYT+?2L_B=-fvLhydunQ}8#}c|Ib#VSnZ6W#eS zOF-`?{h*kKxFBpqN=S2y)R<(4&~_yoW5((@PeB^dJI>1lf;L{@i|z9sg&Pj~w8nAX zYzYmqRtKzwM}-O?2K1wKZjoV#MupnF&a`=9Rw~jBfrEwmC&(*NMx^g}#Og2}#Fu4Cldb;dma0GomRt{w6bAkW>G(L^6?L?>IfS1C}# zj{6~Rk=;Y~Xkk8~p#dhbeSNI7r*E50^}WUUCHX}K1(I6}t}d!>2~;+23RE`Wd+eh4)YzAM5GVg zSwpn2mdnf>PLRK;a($qrIiQK{-ozr`ZWu}2vVK#2g|~2&zrUm?3bmi&6c&UVtFft} zrnas+QfN)JzXew~1=joPYPK{qRfR{=p-MibA7xc#m=3CfVo?LCx3*Mol%KgbRj;dU z##8gi;7uD_SYdx-WpkjGUZ98A4a{O_=WuVk-EEoUt=u44;QVXA4A>~KdFHL$pQN3Uf%J_qa{(Z*ns4vjV79PAc5 zJxe^+ZAp$iT=1dpfML4HjQG7Ahd_Zp`P`4YE_PnxxKwOOHh%EKhaZulBp3Y+eUod< zhu$I%b#sW$-voAg4G}L7HdNNtR_OXKt69Ep6+SHukfl*p0#uFh(vX_$G_FE+ECoIVzM|5im4zim@IIGC zz}phBs-U2-u(Tk*uw-R%QE6%M%KTD@xPT0av=E2lVngf~Y{_VMhU?9N;Vd7Dr+0!+onHsWPiNoARd%5WCR2dccqCT9;O(mq}=S7O|7kI z((O)94@$s~OnNY~HO)~9wWNPSN|pk`BSdQnhGmqW2|aS8rqGtUpIZUp$$MTj*RBir zTN>(XE2FinFNB37uDztZjKJ*}$H3cW7{?#Qmdf>hX<@^0Oe18>KWhZqVQBRije-HU zi+>YapmsD(-r|r59o{3Wt_)OCr-eU5{DVADm@J?FB_HIPckbM1eT^tVKq#gb%P;(!RsSe9=V9ofmtoV--VACpFAx8rMA zW|s*u9AAf1_rG#~j0P%=a`mEW)XGT2tw=N|uWYU8?xQ8X?!Jzm;m#l?OZxb?9A@d6 zJHD}(J72EEi7+u)O!Y1>f8^pOC5wJ85yK029Xs0w4D;4aeJf|!GN166vn-~z*8K)| z;^^V%l|YY0VXYT7V#u~KKzGAmE>?O8LxCXl2C+(_C?ib2QRZzNHsjta zPE#mHengzEaE|?)SgUZ3{)+HRZn#YxuMBJX>ui3e7VB-ErY^NMPgA2aln6V|dqut7 z)6{OG-PhEy!R~8n+NfmFbI3~3!(x-=#Vikt&6c03<`&D()N(5evG_eF&a(M2L)-#v z^E6fbkj>N7@WWCJ=Es~>n?cWd?yf@gki-NI`v1y~fu6EtV>MA)kD8x(zZESWHCKI8y zj$K$Zr$SBU_GT|b7{xjRNmFr%I6`t;k6deKQW%3Sb(0DzeptKFen@`Prpgv@U{UyX z1#g@f;w?0E8ygxC(AOU_#Ct%u)YJmq+tqD|i=2d#CHHp0jF$s#uHFoEFu2DM*8r_; zuE<*E?ds!-@gkuOO@#Ij7~+pWD>gK?WbJ9| z84gn3;p^G9U7>#DG5ZbjX<;Uw6R($zx#I_D5jUKV=uMTkuH9RD_wy_y&s!~pLv64XP z(P)(2?G&HVQT->1DhbS}$DHC89d+bHQMVF-8TG3!@kJfAvAJQ z)kq}~-+60BPRj&b<9|-j)_Mms_c;%@x0chv8lG+-@M@j7V55V8i}l_F#j`fmU2Vi>EGCezd9wC8;-5Kh$T# zi@!zq!-XTZzOk~Qz7flxP1HR)(;O~mhLdlmzf#u!{fHWEw=J?cFeWkr)h9x%FMnw` zYmQ5?u@~N|Akf_XGaj5sdt~GMpVcHGCHPT-GV!+re@iJJ&~{^WzZwIT{J{Fay6TP9 zO|_NCi42EJtflcwK96Da-bKBi7TmnW)Y)N3F`57`0wP>?h80o5y)OInSROpGBE>z8^zg8N*IGH5G8j&AZd8P46h1kt&0nxCA9WS`73WZtF_z4X}1 zfGR++Gqkwx1m(x#`kz>GRN2WwI+o!to661{G`2(Z&6ix~M$=2<+^Fl^sT72350J0s z(3FO3LpyQ#E%Njf8sIkJH4AfHcmZ;m*M%`=R!%Gzmu}othrP9x1h8fxw+KGyyp~ds zw^LRPJ+C#szvGStO)y5FNGu@biz5--t+hCv_SDp-Y_Yp%ZzWrUS-?Xke zuo=6JXra4$`rC%^@F(7zsohxHf)N7bzhjcrfkdu@boLLo_XHyek7GSe#T$#&{|G#0 z<3&ecu65;i1xjlwean`4mm)!U?n@N`ikd%CV4|zdXq}UY2D^O1WhMYu?X>m$ zJ5r(UEJC(SE)`=%Ln^L8D)4#xWU?0I5&5bZfZI*rhUXmy{~fl7$WgPzqE_jGFo7I3 zqe1)IS^Ixmc6OMha1jb6wFl#A9zhL-zsw4sG zo9qC_uhhC-l;jbGN-+SphlpGMKrdA>tPAQ^VBCgQ$B5*q*?{ejz;+mXaiv?Z^WRZm z=>{_Tapkqp@w45clP#BtA_=#X#vduZZ@;Rs=Nv6z78V{U3gF&wF@@?~{ld5(uT zwqDuWMY~Tu_KupSPd~QBY|QG)X_;{39B&ITIBGE{n1tvYHM~^)H266F6k{d9aJ+8A z8V$#vEwsRJ+%er6rK&N1ogAN6jGEU?Y!SeA#8!O);!>xEjfw4JarA$|Xx}A=A~=@r zQg+g3&_~S!B%PcHT!wAbS&fQZdK|)y&}9h3z_XQ?1p;AjH5)hKVfLpS;+n`9I>Nzd5%xR9jaCHeiZppt{$HZy zLsKJ=YwD=X-*$@IEo$n>bn~a9Ng*mR`)mtUNTFyA1n~Z+ao8yPE-gHoLTzj`7bzTE z0LSL?s!QBsaY1Wn>K-+v_>SOPVdP=L+GsIYuA;H3BdqH$-8gw*>Z+RA@dP22BSDqS z>tn! z>k(gdFYanB>?^o>@3n)T=neafr+T;LHKPZE<0sn=J;i}AH1Au@drneWk*L; z&UK24y~t;;%4)c7<;;ZhQEhvocuyn5!L>q}7*6>ki~8_afWJao7OTMFSqBTnW-G0?QR?zX8v_^MJ4xx^|q}cKI2pwv}t41z34u@8+{wo znJY433oLCtd)xL6@;VGn#eZlD&cZ`_19D$FT$Su>nqjI?M0nVYK>KUWEjn6OM66|I zj7OY0X$>_s&DCa%>`_rHDUY(0k|NDNI}0|U(+A!Ng?<9k#trK$TC#A8+n0lX3h19g zBn5+Miba-OCPSBbu~3cyD$=99R1x&x0Bs72BIp%0@kheGR@#fLF@Hx#ps-*B`M4_>3;{G{wdKgu z+-=@9-mKlI@Iy3n!f$s;A-UTm??R*iD}vf{#G8%7-SDy2f3Oz5%nJj9(h&DbVa>z1 zJ9&!2awjhAJ5t!hBypmo{$s0ue^gspmRcTWDmzch1V^Hpz~YfR0Ui&JPMO7E%=or^ zc&fCnVM{=L60seJcN#VZ@D6x&6WYn=q6BTNZ9&M3rL{OJ*|4#08`guzi2c%dG?I<_ za^hw=M>;TSj-<|EnCCAPI>qhO@DCQP`#)*Oqwkj`HF(NIn{j%NrEo3pvGDm0t&ol7 zNta_9yA;zf?1>xii~Y`|M!b}&a4|z%>`ZQy z)m-k9r{O>naH{GOUoNf&E@yVs)?@hob#bk8mh#~fYxjv8oJrY#am1(NTilkmklJUj zbu2d0`9s_!(eGI7N)J``2fMnU6`>vjA2B~CmF?;tK)(r<`#OSw-K7XG7vJ%?vyV8( zV|gT;B~Z!oSQM7NV(`3L`~W)1$KrTH3Tf}g zDsyL`qiwJ=(Anjawho{SK-d-H-D&RZ2V)|HiEVaa(aaJqOsqbEFtV28xVU(_JNw31 znFChJB7{Y=*VxIBHgg8W)!_WMSP$8(32&Fm!Yhj)JSy=lvG#DJhpOn7&m;%QQT9PY zFwi|>6+y-G0dZBFJNpsOBzU^k5l>`pwp4f&UwllJw?(*5+wJ6ta3{nO#Vm8R*` z=3tucE_N)AN#77s;qmDkx|M5Y`i4&BN>pM)-JO=rWjfr+;*y!}>|e!YDw)SknQ*z3 zOt?JGuf-)9$L%ujMEO%P5uU1K!j-0E!sU%7lhWzFR9p+0KaE#1MXHubE+vy(9_JnL zsI)ejF$=Uz3Rg18rDT#TnoL=?-0z9Qka_nERJ+Y|mQfW?S?O>I0_2eBk!Bn$l}luV zd(uPOtdh$$n~vhPQR9idu#ja;DI}&}`~gBPn>mSsW~&tK-QzNUM!W&$zn>IyYF$+} zjL955k&zVZ6Yqlgk%UQTZmS|=Gp8mm_A2r51k}I8$uOtx>qMHP-->-rTm|0G&q_@1 z>KdvG_UTr~NbiP6O;6hn>4VnNk&eaprr@67z+lks?@SN1?CtLC>_JVEX-W@ONWzvj z>}nfHp697341t6?)B66-?k=1P)^g&RYfW3n5Khd}DL6EOGmQ-Cl8sUa6bTHpb#{*w zSOrGbKF>PwGiZM(`9Dqj2)&CU^q%GxZ$R&(vrmrR+}oW5t4HWK5@Y2OoRlMeOP=BdOtmP_DLz_vduXer98dAFWA11E1qmaxuc0%t&sYOw(5t^(WLpyc55pQ72=2%A3jHFqz z{eWw}Ri>>GJ2k8E-xqH}{J~Sk6@MM|YvB#r3B(_V(1X#0Qc0XqAugQd&b}mVJfSnE zPgbZ%%}AOV6Gf;r^o(zcYasOd3sSlGH{s@ZX)@V=>xNz(Cr3-~ifHN00JqtUH-)w1 zV1v${djY@XF1vzw)3d_zOvJ1TMczo7`G{ljY-HGsOep_-sr&#n_2JnxGe>+L%I{zJ z?^K>z)KSWlr>T6x$65IsGLjPZM^m1%d*&?AUSTCCCOfv1_C#70U_MpFDOQPLtyQNkVKd8Fm8MXBk{7``EKGil(d($G{>)1ngr zo?H~9ubj8cR$~#Fzx3gmmC2HK;(&MqyuY21n!Zu9G151-Tb6O8tNl8h+|;8@Ek(_Y zPyj3Y2YDDFWg@{%vY^dc6(ymGEi$2<9Yc}rQsR^1(j<5G!x$k?L>c3_tgYr4h>A&s zGO9GOG7sC7ne~{mdctKHNpYSi3dzysth2;7pwP3K6I6&MIc6THL0Py$G)yzCleERA zP|{gSp_z|oBuzUMO(AMJXZ=b177BfLNql;}%q}zrhPJzrCUE;VB+LxEqiVv1L zR6VnnnB)o*R{60wh^{9ftK95Y#T{wx>}!`tuKa`v<$<6n)G81b_YS3VKL93qilm88<0%A;_w+gmT#)KPj|8l#(r8hJ=T5BPE2d zsH#Rl8!Ms}Kyk*mxRH%O%9Y~51@7#d^2X)NWmt2LsQaTiQvpu-gLn*_-#!6nRb)-h zRt8hcHHx#$*tu)PGvNHvipcUB%^JHjYiW-3&>lO^OD6VL(89+?b8i&)q`R{p&mUJ5 zo5vKzb;A@z__(6TUa4;J07TvE8();NmnDh}W=oYEhp1*bYO16GQ$yl0h&ogtMMYnp zk5=>2dxzD~Krc1*(&jeS_-K({aehJEyU?9|apCO9&dRp%AElT|&a`%jPBW}Y!N8Yi zY&~{ivICn}EdB^#e;rR4XN}Hul{1tK8dOYF7-i4A!{SD-JNtJ6KA$EU>cO0=OUbdZ-@zaRrH8FhvBZ3gG9ufI$ zQ#Ue8s??2KX{scR)=f6y^Dhw>E^=qzTsn?PsMgtZQfnqD=96Dil|&oOOwMnYPbeNZCJ#M$jeji7ndw{XWzGKvN}c0-xKRJrZzJ7(wf9I z(B`q#lhh`9j(!krD8JHP5}$!KzbKomHc@sFCz4-d+Xid43;M*}i``{+m5bM%OFMeH zLjk$_*)K;f)O2KGj1zwT?>Nrey-<$NTf*s)G}_-7O@9pZm#+~Yb1hN)=}-muKbvqYbl-RkV7wU79OPt@eeyLC_JG5^J(Hf z*D~5Emd%4oEG_bEBl_+>BQwd7(uv!l35J@iCd4`pDycPN|@s}_iD1};wV^RlkMCl-oOhAWYQ_$i2YsF{XOL4%e z*^dv(kq(s|>Z9^7vthrf72Q>Rn`%hXTKj@K>Y*eloTk%glpXZrFgiXyJJVlPwNfWX zCTheO&6RC9AT5ZEak8WQS9V%P*{}WLHy_emrN-2Ge5p!&L#p9#-Z~{)yip~7$hMdwhp$$P zpD9b=>anS0$KR^O@7WGh-;Qgo2q|SJyiJMaIfu@ zw5pLt*%RxcneHvZ({4V+b^#p%Hp!($b~P=<`G>T6Rk)aPH`EiF-y; zOjFtGb>fptm+I&=#!{Wf(q4)#dr(_+>O1Hu1a!)}zXTiiugdPJ7x&rNm|gtRdn6m` z1nq2&MY1_YY|bfvyI$ON>Jrih9~KYnQu8yJj9R>B3+-#$0UYOqYTJ6SR>to3AkM)U zGthL@vdTxq5CeC`_fF>JmFg5 zL11aT-GCw$AHC8zhnyY#gXA>I?>|%AuuLXaGCYx%k|DGthQ@J|p>doUj;*^6q30@0 zi(}CU&vBGr(h-v{*oyfUl%UQ0F@^v zEp=r#wuo1^}4{Q;)cW8;)i>0k0DGR_OH>UwnHt1=M~*t$B@s^lB0OjF zARf)(zGR?7ddg9P^<0h~{l5!f$uiGvz&kIuxTe#fsWMWw%s%B|f z10Whxv9v5TIg$|f0}cjROL*hfOu3V<)P~2nY7f}eZl&nKzD_l>G0N{aOFR^=y0R)Q z%fUS2NL1ZVWYrldQ?+XO%dO(|aD}8T$JgfswzMXil=^>}E#Lf*xP3)fF<@JwLcx^% zQ!-`V+fy|qj(0qlk(Bpl`PT#Dsc^lNNyk&`L>BFbC1s-il@={~|7>xfSau7M$NsF2 zA^#%PF>EDuQn%UL4cox371u(@&Y&w_bqZbd0u(xjE_(I}&^$QYI$|v-rnT;~Ber(C zbp&Vg@U1Lj?lWEOid8!XN$_t+H%N%K>0mc7y;ZZ3(gve`-bUKv~EQ6pPuMamsh%9$ONR1Th28f?iKTV-)1QspCMHwDG3 zC9*D#va;^p3T_%(WAtbdL;5kalIeI(rNiv_WICQ3$H<~TLSxUu5v6g4y%7g!;6)f?C09wy~~zU8kjN3X?OC@q!ijq|Jk+~$KD zfsAu4pJsfSxv9?IWPH@}YpKRpqc#58I^2k5$Tz3)iHW?l3|)hP6(*w;-^4l>;L}wK zz;8%?UxV3c)VuHW=Qg-AEN?20`9S~;8u-H=2*HOv@}4_5=`$b0_5X>N4=4CS;OjL0 zNZo+XY>rdfWxlKui;NWs_+EMuJe+umZcc3q%#vxu#hn)C^x%g;XM9k|2udc2Dw%(;k{4-tJ)-Gc-!XGc{ru3EFA#PPDv;c-B&b zQk3LE(wv?+yp4?);KUqq%+A8AJ81}k3}c~k8irT<72!?gMH-2Vn-Lce))@&>&Bdh>WV!*! z`b)@xTQCVY!0lA&K(ewDWx%pz2u8AygW2RH$8zO|`}UGi%yW~W3hGZX)L%g%Me&M0 zUm+C3r~UEWda@w>3X=_@!z;|>FpT0n#9W%${)0R|O*0Xs_(}-bgXD5_COF4<4RXGjg zLz}~sFNHdCP)s$=yFT2g8)_Zoo?3E zFuK`^Sm!9GVeHbu#J@))N^-BJr?5U^NcFK_I=~~OQ$WVvt&r2>%Yh6iBrS#X8q^4S zzG7K}hs&fz_pC8eq43^WVu>di4|9){vjc{fzo~v^ivACC^DKj1E;KdgWxy>;kX^772oP2W^aCbD|O@cGc6eS=Jg};o~~eT ze`jz_SN}jqaJo_32UcF#syEm-G`Jf1;=_AaMY)BjqW!%gd=St#v>M;|*Aq<$G6uZG zdHE&Y;ZP@pdW*bSbmL?vp0~pH>@EHMJ*&Ntj5iOI{W`j&{Rl_OgYCmR2##R^UrByJ zjt_5Nfo1|`pzB80tdKU?+dr_&av?hMr?Y!ccW2Nm$1|f0G4<5>!(S^=sF}77Z*Kq8 z@})Bv!ji!hGL=ePq_t!*k@hjoe)ak7@QS#!i>`oZMLBAfSB12q5asz$BK8!wRt5Lqq@4^yIIeQhZ@rIZqT-rj z@w&yP&9(B;L%zs*4W6L%=2j^_%3d?lRtg6ZkI1U5HHb0yZ4-^iQNB98J9WYXu%_VtBz2IEG5*kHXP6n7=CE z=&Q{i;WV1mKQC}}$#KiHhthBQcQuZS3ZP#Y4*jNoLx&?iiKx^#=m|IZAu>9m>9ce= z@EK6?e{A?n;4j;7^i|V-WW&)nO*8F@_~13|dRurB@O?HM!_8@J8iz8-k1+j!Pg}3U z!3^o2hCfQD;YyO}_58+$BfXw4nDh=~6>#;2Jv?VQ40P@ux^qeXfMdoU`<4wy2N3&p z8=ell--c%Z_u25J$ntk=IPR>DG4libaj$g@J!&j}z_Wpy_E+*_U=uSO^4-6(;gIkC zybXtZ_Z}M#`R-a94*71#R6ix(^_mTbeAi(cUIM(+hQl_l#Wo!8|2Thb!xsU+&4w=l zzQcy+0$*;!@s6nDFE$)y&GA_qUJSh5hQqcFq*?u-KVDrB&)RS=aI-uiJQMgfTX+s| zd-`br`hqPy3-152;Va<&1pZK-L>lxbOP2+eHBHj#+M>xfk{)i{x zN=$u;zMT00Phebz=VJm(coC+y1R-ZJLFk)C@CnRfBm5;D{3Se!2`<9LT!o8M7%s$I zm;6t~e3T%{fy7b9mJ*J(RpQl*qufdy`L~?HKg4)9hr^yS-ns058RJ(neu(kg8Ge)b zp#Dj|NRQI62=_I`zD60~p3`_qC zh7Anc84ff2q=LpC%kHV*V<0~=2_iqz3F`c~5W_XXFTwoQ?td@lsDyt9%VY$fQTiFb zWr+4jrW@^~gy1jX28P=i?qUf3GWzs&GG1sy2!EeONjC$;g1=jzaZSTh#}f=iSJ{0IYXv* zF@4N=%0K2e4F9HJ?CA^}8FK!`-p%;`DCpt*_p~tH#qfNF_c28MBYix-RB#&V5#iI& zc1u{!kn?%k0mdI=sN=n*@ades>FXK4km0oqxm-+tRpD`L|G3qR*D>s5c$ne06pVK> zoXcdYCd^>C zl%by?$}Q0)uzeChBq^0K6A1aKBu4IQwpYVKBX{y3a4u>+iUI@6jqkXFcatDtsQ7?|ENg{8a_#FJQ>!W&V>2KP8{xISij*$n`lbLE&kvciP#E4>9~K z!#^vyfbF?}?Xcin_CLVz0RqIg5$X@>VPJi?IEyXXbR|5rgg#U=ScvS;58JUMyz0i<8+ulVLf-3WjGeJd5FOhI<)a!0`XE z_a^XhR#pG_b7x7WZMr3;gwlp-IxR_>hMDYXTIeL1G@)6BWV#yPAc{u<|39Bh z?mg$8d(OG%F3;Vbd%2vfx|d;Y*H(Ro;jgj#BX)nz?knv6Nx4`gkoNF#x%aJNcrCjn z?AEi(cJcKvJisoOb061dAKSiTz*!6hv|N)+yd64fa_hs`xyUC<*w!Y zUCZTn?WK(8`d*l(;KCes*}jDv8Q#J!^DjKeFx#>4s|l?aCQk@6KR5pK&LLe_XlPO(Dyz|4eqzR&HQ1yUW;Rx&YfR@GZvwLb=6U zK8m?s72l-rW`7XnbR%p_0r!`B!Jg#y0D?LM4u-M+2d_s;gn zmf9_K3akLw(Bx~SL$pJ_P))GX*A_ab(id(EwO9H=xFBz$*l6nS^7-0uyG?9#%;$p@ z2l~5`Elt=mmQ$!}lus2RAF?ZzQWS44pDt7sJ(W^5CA!K;8GYKEoKi12v)-EORskpJ zsg&>p<<;$)UgQJcar` zs~4P=k>H+6eNL>vh?YwIjl1<1aZ;(TRt_OTD)o~hOvx0)oke}5_u28*M~-`3^-;z> zuKFlrTG>c-DV2QW_D98jYxU8_I#4++7{Z@-hh6`?4sbiW2Ik`uG(}R zGBZIs^=97&8^xyt>dr&y)FAZwe7IU=N)*{lR!)NtOvTGWP&Exc34fJafs%hx4>Ho& zJZ%TENOoQS={?uDPV4dQRlvwEX}25PXiIWO`_MSH9(8ooI7_N{WDa5BZeh zKXKL%`yCGhVW-17Mlw1B^GtDc8vr(FW>y@>hv3H?fPTbf@MYi!dSf$wBo{x&-Ebk- z!TJfzr^)-4;K+vzLJ#IQq+AKW`#65t43MLZ(q!|)>v$3WD6W1qT>?KR=37(Y=fZqT zQht~>HFbd3^-=t*!%sh2ZX(_9L68ESyBKskG&8uGUqU+ES0M~@NaiyQT^i;OWgcll zO_yLlxfY$weu;G8Cz9yr!2GbOE4*_bg4_dIs1@eGJe!?vKJvqP`&2pu^Nx19Mc)Bj zFqO_R1e~q>E&4lP4}Kf)^Wvw=Unl%XyDnyn2~XkrL703v-%L6muwf1(hv^)YPd2%W zF{GzYZKPbx;hJ(ey(YiQpx(_0*N>LVcGh&umV+RoiQsCw4&^uLhGD;qsdVBWz}fVp z^$t@%%;ip}--@eYqoY͋D%kq*P&9!#U3_i5;dpZPGIcoGY4j^S0)nt6f~)Bg>{nI^ zQH0ZvraK)7_;tCex&h#3O{BsI5_9m+X6N-k0<7&^1phSYSpQq>P4gmLKU!{roog~c zaHl4MtLYNbQ3D&7)Fq+A{JLGg@mB$B{no)hjeZlvie&3Y%T3U4f@mf+5nN4|px?x0 z2qIbf(R5h%u~gjL zf&@A$2hRYfAI)zB2rU%eOQ4(UPIw~tdGRBDWY0eQs4Vbv#eML2@!No(6F;J(bnU>; zPWKdGKYm0v2CfsHO9y$7F1m`*Rr z*K(y&E+HKUk0LA^Khkg6^mOkAFOkP|In&c!Rf#ao zFLwsIu#Ilb40L@qI_f`ZyX=79W|ylD*ywb-M)pjw-&HpQM|euF?ne-u$nQ?DKMXw4 z>Hbg>x*N_#xEDX7qdd_1odQ4AD}HV`fNDy8K>Y~zP}^*ydw&~>=T|flTump2*@GT&AspdBH8NKI2@^%?s{utT3)yaI@=lV}S}GJd@3G~a3K(qDaMPG4tV-wNM~b+5nq=0EDIW~S1KL)?viwOmU^TX z;wAA?`b(>!g}8Z6&Zg_;JY)QN5>|8c1#{Y-IeAM?&8^R$QDFQy^Ja0HaoU{p=bmx) z)vhqk-LhiNqPAz!`)beK(s${(@9}#Ao}9L4U;pIdFTL8gvM-NhD65c->eC_X&%eGL zTIEZvR?`2kiWTdCf9=CUUldFCLyMNA1-HK$UK-V z!TgKwp1GcR=@}k+E64XGNy!tzBhRjfBdH#yd}?d? z5nm2w?Yqom8EhDXym}og?tp>u50kb3H?xh)T+7 zb-cuBaidb%bzD$X6xzfi6>2z6qzlseTfc2%QE;qqA0pUky z{nRb)7iqSn==Zzg(cdonY=1)Yb*O*19Vb4a+vPY9zg_(}d$!jESM|%Yr#MvnwtqM@ zGNMDp(|y*dP$0oKExY)%X&vDMyYxjK8go&HBB>o8fwB_YF)UA+b)45R+@&zPaE>-H zLYT$jJfPo=R0K^yY^|m#((Wn zT(I(jqgS3rOwX?2$!HWa&&F?I=fCV4?utg~R2&KZe5WR-lUjahn6c?RI>a^}QS=l_ z(eIbcu<)V4o6P8Rn4K+pB}c!MO$U)gK`dg7lBNQlBoV&N#YUc>tIccXk_Ys`s98WvNIS+wr zCG}Sg87rgFI;!a7nkUv^L0GmX+2_ z!OmbS_{T&zi0O0*0CJg6A&%+OoAtn*9M7oA}LRykaJZiy!sLK5-l)lFrUA{_jf~VH4${~!J63?qiMsyq^mxeumM~g;&{itx~p-*BTB@-|Z zPvJPU$s|zz#Bl0bXbEOF12`?=KkX6-5OvaK&O_{>FI;3 zq$t0RMtJ*!Xl;OXv>y0%H1g|c&@(lokzYq6 zzkCFiZtH@PP&Dezt&eqK(C97p2P$&WJVm3lno0oy|N7#x^=0J>+a9T_1vVf_B*34J z6SAtR)L+#kgFBcgJIf$3_@o`wm@cPhYv$YQ?-|{&GJ~VUXM+ILIm#iPna$?XC3@I#%Ks0STYjd+~`qgphD%N_!XZL48AX3L@?^dlF-knjhN7 zVW%V!=|dFO5M2+;XJ!s3DA-op5G`+yYGON@SorORk;IXPt<5#wk}3FLd1(^rAjK&u zjyG1gt+l?fDU>L*J`{}LK(A;+u&I7~Yg=7>Bps^c#~Ys`)Ve9pe?ky zu{{!MLk4eciLk=KaBX|Eu?1*|-NG!!`o{Nm+5M*JaMgk7Zw;fqG`5FiwP9-Da6ELd zsVN$4Zx6LaEVLqR3T+EDu?49x)rTcJoLELR7$0%!*Rg^BN*U?ggoBYOIN?5dJ`wA+n-m z6Xa@?DjaTz5=$5pt&O&Ct*^&P5K-^IfFYJfqv0T|TAVjoxIf=J>0PzTyC2{8GFoA6 zG~WIB=un!>@+R{kBh+3Sqy_;WjGrzlX)r!r{N>STQ)|m+ z`gvu`LH`V~3Ws_}>cBW!7piS)_Zp7X(I}awrQHyP+6$wNf~GRs+}Pq>hb`ZR7z2z= z(h^ZpTu~0xI8Z1hgvxuTf3l)iJy3oEA-JN9Ld?|JNtm)1r2Cbe;0|w~7;WbTECw)1 z0p=Yn1(@PMX+>#eNqH&I7qSSTEfG~XpQfau*k4j!Syoz6QC8`%fQXC9kVp%0C@V9> z0YL~#3^3(oWhKD9OX4Usz?BwPl~$Ek6jzmv8{!ffLaC9W%uESXmX?-Rl%mBisqj~o zl?BQJWe|3y0Pkp12t~zizJnGz!HVy;LXsQvDvKaRo4(hIp^`04dyR$Vw6le;wF1}x zc0*rhg_=fCwy(`gZtv@*#Y`J$v)^Dt#~c4fTS&4jxXBi7>Ts-#xJ~L^Z{~x&{2`xi zH-kAp62d=Vh9}RJJIwGDGvzKb0vAPFVZPf8W5d`p;2twDN$z~e3^WZhbLMk6BGlLl$#y1skJpty4@KVKneJ|Ne@Q0ra4KWmh?|c$x=Xkgk&wjxQy~Wq5F8$ z6xveveJdb7c`u6g#?8@Sq_w%RHd)L1!?hF8CT<(P%KD$~uEBpio@E@^FTM@|1AO&slah~5cWtx$aMUP9Q@f=}yU+0M7a=1tPusTG{!mrnF~>tpZA~%iXcmUXMJ|s8TfLbuf-0kQrvFu<(n}Bu1cA4RDhZ+-5O}v( zFF|BKf%l7QZ+P5{`;a(OfgJfsah8HP_6uT@f;sxjA}G1x6nNYYt>tgF;Y=+WY)Dg= zMjO)9=ximz&hsJBY)6{fwb-$yj;(gAscBfrqHC;`qIZj}7K&NkEw))WQ_bxb&eU=T z3$ggUAl_!fF+-f*Y(ttVzTJj2HT(}L1|wO{shA?th!;e!B*4XioOkD~lzFESFN-}Z zRS{I<1zMk`_5M?79Iy->+UEAgb{Z&RxY&SxE$^pSL&9b?#3{o7p}iUJ0IaMTqLM0c zQ)5dAi2gy^HjXJ^>NW=>Xp=dJZa(bqwo#lJjkdI6zdQza)ak`d(F3EyvF<$FL>U{y z+%uY)AiDJJp*oVIzc0i{Aa8s$)K+r zhvc_yt&M;Ki^4ZUxSPfhuc4u9X$>P_aA?>NZvfn0-w1GDZ@(cfbrMLH+}8^;UInl{ zv<={B4AXDd18i)s$;@~eUEAMMKXPu5F+GK!15 z`}%PDq&LsM6)C<0OzV!#v}aaK?>jwle9zR$cS1FW#qo3KYAFi; z-I!c6Kvq@`%-ca)>La;UUS5;r6x} z#YzIDN7$%-z$xCRqXv%^RT7v{k2u90I_l)HqV6C9GwP>Y;-flhxIH|hzTuIfZX8XE zD_*!x<65KUV`$Xe z**}2K~F-D8?} z!@JVOue2H_1EtC^(`u8%$Ei1xUh7WZzfZEX%?qOy%%kIv-|mowMNHws)W+mQpQwj-(ZKy_ndeQ`~i znf+2M`^C2^2sGCQjlw;*Zdk2O($8cdQ?g?saX^fzU0Qs+*BuyZZ^B_G#<6Q%>M8cz(PgC)x zWA#4*mk@dJA~5H={JqhN`dWGH4%y@HLM8^68nv`if%sn&<~+qh@1+i{GQ=d;R_Q#;GQF#M$r1qcL~AP33>BMfcl=KA#>1b(QA^RsdaOW-YKbu~Z$=ZYS>x5= zSf!j|VzM#4|D~0?_YRllK}?}HZ-0KicMTGRYuZ#1ps4=IViR0%M(deHG}z_cE;9i* z;;3`rUy%xRdK9u{cBz;y8d7mRQh^fzW|OrbPsmrr0Nic^H(bdv`meA>LXMgx7PU$j zgcNerj0WvL%-a9Uva{PPg)31gsXdrU^8{)r{0Ub01lJ=~i&RcB>t0)R(ydk;ffWwD zz5u-jJLL;t=1Q&GMM<7es1yTmdyKdZ;er)ZG0Y3w%>so8+-*THrid~vv5 ztmj`*VCgJ4dbsjh;LO=>(aDy}1d)UfyJ>BrtA8wY!*GN+yI4%X^BZnzL(v^+ste@x zVtS6dIJUR4x0hC*2JA0t8a{o?7BigJTNp_>a-lau44$zV6wg9*q3T|$_cZu8ew$_` z!EpS}289jB?=7&{aNIlB>ZPhaf0OK=*Gw7Lr8a<5Ckx4rv)Xg&Qs1T+sjXvi^nXHc zU+-=AxRjmD1+0W!@L}0ykpqE)SVmnOR^$?K2n(s1xc&9E^W^{_HZs!JIoN}Rgxy$t zdQOPyJ00R$ak_3kRHvcW5Qu^6Mh`}#ad&JRw+W;AS%ZH#AhrnXbnx>lcw}8xA=S-r-%b{?3zs%Ca3 zK}h9fOeOQCH1V~>sK*e>F){b}Ege%gNIGWH#J!#-o=u3L>62#U2h+u$9H+{Az=`gV zvUPm%JA~r*RJwTGu}sp*L?296P7i|cjdbw|r>}cxct7bI$1_1u6_`!e`>+in#cU80~47ab5NQj9Zf6N2b&w4c6trR7ZW2G&PNXrc7c*w&fl+;jl6pft?Fct|ONs)e zfwHRNa_sV}tg5I&d3nx3o1c_2ks#(fqO@zqi%*6zI<$pBY_z?hu|9%PA}$W|21xw( z>;!=_O%N#81mAb?audy{C$gvlhaWgtC>C33zKv4npOmKpV;11~#88>cN`(9r=?rhh zrdt&cacau_HRTwZ|I#6scuOe*uxQxc*j$H2VA@qqA8g6>V7+W>h&!DsgSNILU5g&n ztI>BcojD^DH^I_5u&;CfD9^*tQ2cAA;5=M@I3m}j<5ejrpb@4DMT95J2(-S|9?{YA z5@O|>F`jhlq_x)9w};Fa1yiC}Ql4Td<)xZ`K^|;EyAQkx3jG&I!&@3^B6-*#A1K7X zV)|Etq@XiRvB;A7GBn?diE?yMksgg#C9fV2&7LPj!2O4apt!}wA$rxEKYbAEXV`8y@=5~Kh#f*LvLEx_h(V66Ec%!TKBVPH@i;vp%l zeH^D)AE&T&sSA5p3QJ8ACrau+z4~8HYAef9YvW91=V_VX@uViOc&tl-#}iXiW-*vH zzAYb~t!Qf99#tPN?84@q)|M#lZx6MhoqQol(2m9kLVjG)h^>;XEloQyA3RO$mu8}o zY}7Xnx63iobyLPjSa`ypx&K0eiK|gYY9lH7aKai*S?8`&mq(xLOKLC;Er990gC(1I zjfK}!wL&(QCv1d;#BA;#YZ&jMyFAy8;?mlEomj(D@1nAzy7us3Y#-nM37`Y}1I~+e zkBt&JR927m>9ILH3zM?68Ebsh$SnRK_8+;!=T~4DhBa~HO>w}P89pDcX|*aoUtI3Y z3d?FPSIL)SLlR)B>JnZnt_3VdcGT9R`~GQhgLARM@Q$@d#4XOufg`ktOJ%&!k_F%J%k;;Jpcz2fJg@^YKNk*dQMExC)8`nd~tcx>flGNu64~>qs_x1O3Ry$T@7*a@AKW3SGqTQXN zJ<*=tfV6cKWdOq7BmOqWU2r%pL73QS7naN{@xsLVV+bQ_IgX0U=ei4SO_w=fr7S^M zGJ8#*3~4iGOk4}je@^$1&DwC^tSr2;2m(=ytE4r;kuzLJ2cu>>NRF}(8iJAjNvjAd zo{x%a=D7==^vr^%Ycugg<`zhWr|`wcRGF?UaSQlqii}`S&hSpF z9d*NDp&qW&$K4Rd;Z9ZPe(x6*$jt^w~C7ca``?Hy~1 z4eD0M$ms{7exP%=#GtiwEjAGw8I9TT&Ya=MzW$z`0n{X!rkvp#Nf_zGsFnvBEVc@a ztbLx%;(O5k=B$4=?GyAaP0)LeTf7RrpILHZ^yatS39x#C-gbLaF`x4#an&MJ(53(8 zdfV+yde0pfAA;V`oxJ3PlyceToQP7MGc*|M+RqhFwxRr@Nm}G(8#!;Ccoa#wN?$ifWC}WbGd7)9prvfhC(Gxta4b7t8ho zzGYUKwtDQ;tY&;g{1M_0ojRlV8|l3k-=G~s{80!!luRg<#Q8PilEvp;z0<(bBsTT6#0UZ8qa=aqT$R z;APKmfuQ6rUj-Q^vc^I#!l(*G-pE|=q+`_*WY~Nkl>drUeuSF(_-tBGC_Vz^51jU| zRGwPYDasSlRDR)Qto$vxnF|jjQ=YPW!OP+>lz+yXTzOUVYxWoG^6N6+x~9$3rpt`< zS!4#aSX0vjq?w*YVMJ6$&&Y?5%DT`e<3$Jr$w_da$349%Q$k>dL4Fd>fWZ7qDDq2 zfVD%T+>MYjk>EC2&=yxEN$8@8OlVK{SYo@h=-cATOn1Q(=pm<~jB!-fRpz4|VGjYW-cfqBnrz!(A z2A0(_0L_>VS+ui4;t*u~1~Qr~TMc9HXe|ESm8!ke&}nF3s>!nM7k8ZMF8F@lEJV#{ zw&bG7a!Zzo`yuMF{Mm?_$$CjeNdqpqSbPSe9xOMx{+_WDoImylTG-tE5s!$-37N-%wUpPWj1tM5T_f( zUS#Qp^07qe2H(f^vKZj(`g{qYgeVq9He@C(3?uQ%jc}qM!l1A$rQ|XU@{;G}QU9Q!N zKW(Z2f7~H~6;N#GI~vda1&}|yQM|{+?3vtTpGZ&aU)d;ba;>2q9kS~M&cdSxF$V%a>X#L^_sPNMH0G<=zkr9Go#(#3hyW)os<2bI*KV`v zuWS7=i+uaN$N#W%>jYjpMAU31p zYr5)6-;N@pLB_cn?zGlS_3I}?L%H;SjV22GrV{-jC3*GP#; z=!e~|J6rtFV!&yb6^AFz7OyA{$mJ9Zs8Rj*v&COIR(tBPKDI?%;-M0?BQmvBn3_Mo z*&?p?&^FiR=BD5@r9v8O`BdXjp}Mz8{AP6ly#Q$&0(HNshwjT5sef=HiC(M-=|+06dRjH;b);2%WC{bDZp?u6V+N!mF(CB}txhuCz7Q6FQ>@W- z-($B{Qmt@@vNYcLa78vgdZm62dAo;3$!l!*@;Ty`e3@9u@K{<(hR~828b?ir#!+TC zz3w`ME~qdqj!7f3`1Nh#H%bYzctXlZBy3F*la_<&Qg(a0xT?U+#)Q-nQ`lcJCFASD zMH!&-)h$@2s%~6wnrf~bhIgnjc!%0w)3INU$UF96^bQ|;MMir7rI3T9205yf z;=*(sAV&zR|GXRx`8M&Rq=L=%0{!FE1fvBZYj~94BTDd*j%frR+%9e`l$oE9Vm)*b zLn+F|`G>Xyzo6v4kW}tYqx#Y9;;waTsXZG#e`JhXXX6PfqjFe)65NVmhuxx22xG%D zJH(IINp-vXN4m$+6mB2E;RCvUFV7=%&3JDwHq5AZLlX+H=f!uIMuL(%kLc@ zrWKNEwmfeHMAIs^JWmadq>J+bM`Nrd&^R?yuH-AVftXS45xd$Q6g@Vm?(11@Y`FJr z;<0$ul~rk44(1V$C)NE}R-M1}c&)nOXC2~q@d`;>&aBTdY-tTNDfRy}TmJFw;=^ae z6$7>^g8PgnSwF`qfLJmu{ZI%b_=*U~}Ve$D}o( zxV&S(9k8|A9h2Cbhi_%UVZZ6?QmnerNdmqLuW@ql0!PPkab~(FH`9M{^+R3aJ7w}k zlb9y!RTC&z9ZgD;aWpPX)Z5gvGP2i+_sOKy!tb}d^e&`8*=5r&A?y+$Pd!q;?LoAEtQ6h{=bwiy>&Ax)u{%{Yfi;ooWD)#2!kxV0ow z+hAN|1>iIvoCsuGXkps%W#-nVV4Lv{3l|CDtI_&kV-rrqGA_{Hq|i697*5H%bW8C~ ztaAlEUFE<5`F&02vA+MA{dH;7S>O+PNWMPb?zQ;udHyfnIXLyiHS41v^S;67sjqPg z_N~e5=`e8u8-^x)QVb&pJz+qy|6Egppn zzAeO}G~B0bfw(o<0%{R4QxL^mJCYFdG(uBk*b%r=TZ2TrKm&%cP4xVC%gJOrsba!#ISC{H%wU^hfCmg(>SEP1M; zAn$U*lV`;|gPffC;M};hat;m+RbIpJYFufCVXV}^ym|BIWq@_=LaFAe3hDUVaLD?r z$%B&%$#H<&>C%H_r{`B@N*WFZF&$V;BJ3WxLbvXH~;vY-mSKhJ{tXHZCKhNAZ? zfMNtR9(6KHkbWgu2GQYmXYv?ESrKBcUs%1cYN69}Rz~AeWt;MNv_e)`$jwYwX`xhf zFQit*BMG(MLTz43h-wR=B4QjJk1~vn7Gg7Ob*2Scs&0bG&WaBpWeL5>LMwF%8MKf# zCUXs=CO$wi0lL;gGZP@|R={Whl*dfuLr4LJQEy>)EZn(pJ5sq>p)}Y)%yhg)3n0bL zwt*0_MS-}}jXX}zhKy2V&RNK@W(z@J%Si~QqSQ(r+^MismQapMy%C&!#Z5bo4~VeDcrlzyA?5))_@aPZ)7AdLS(hEU7jsCSIDP=jd;>!`=o0IW<5-%*0XsMwUk2``oeH%3ZExrBFrAw^x_@sMKA1yj zPk$%C@!??{05iI=s;VSVDF2n0m*Vt?b=||`8*yyc>BHLx;!5HqxCP*ip4N299G8j*~z-@Leuq?)7(d(5qWteL93l6TPv$Lp`yLy+b42 zvAIU$AXs=|qrI`gvC;L&k3ey8g@0WMs^)Rt*#U{T*Ff2=yI0zcV5B(KHNKnNX;L02 z_ZJriaK9C3Qb;}>DZ23tnf84{BYP|#q9b2=`X~B(VqVHN%K*ops$l%(%?dQr)a_k2 zG`oE0i49{KU>2E2B`VP>vKUA^m}c;Q5T!Qt~nWoa2(5`zeu0TM1H1i z1>>fQt=k&qRfBve^+sI$=v`N*_$ZHg+KU}T*Sifj>eV)cYPZ<&=9Q0N-hgp1KC_R5@qzuk?dX!qyR#9G;4QZJ z7;Vj?J4)o^GT!_nV073N2x8)op9zD%euM|%dTc?+4!~$)^&`X4gqshAr<)Mo zG9QA`_M49vFuGTBpVJtn-`tpnai{=vi-V!x+^7ymd}8@K4TGLwlOII}{6!s3i3NO* z4aSRR&UH&cCd439rZ0yRE>G6EV z1|vNlb8xrVVUz=|QnAqocNnEG=^HlK5BOmld@A4x8+;nzN*fH_(*9wC*8+ar2A>T0 z3LAVnVB8_09wk3*r45FBw`p&LL%#bVTR7yqFSo&v@5bt=dO#2P?tB{z`L4g&V90lU z!3LKAeuoV{1MqqqybML)uQnL>4LCnl>rD0G1YQT@!=nLWhBz`DA;>##M zPWbQ9;ehG6DFJ?W0z9VSTtyFF`l0r~=tWhfGCP3RBe@qae1PF=7`}nw2hl4hI@n3Z zdxhOsRXDLHJg)ba{BY8ng0mUEkl{-hhW?WNb_E-Vw}LeN3d%CMPqO<>RA+)wA0+-w zcAMF?#q)4H=^|bR$CEJPNf+^?TZwTpg>PU!fEO?A{ccsi(JU@l6x3qS#rN> z7}*JUNe8@ipTZ~@;dB!%!2)ffbkX)KBX|kMwdBG+5=Nb&oD!%D5=I%6a5=+4hC>X8 z8ICaAgYhoKA7T6i<1b_QAj7vZjPfM;|0laBzY<10l=5MJ$q#mv@be7+lHHdX|7VVe z{Gs>`q*uCVQ>BaMkmBP59OVYs-NbGuyTj~W%F+1AHukp;D<3zC-=Kbf8)Q|eVx;TIw{kOe3$MPc6YJ6hh6ZO;Wx5-FT0Pi`wY83 zV;6QIdI#!;bPL!;K1z6$-S@JK`XKSh2kElD4wPSlooH*Mi#9^Ko7j!Ai+U{ahuD2T zyU1sWhaIH*xN=SVLEZ+k&zDf-$xY+(4*PE;_;Z-ou;VW=j7tlBVyPVH+u4DKc?CN;0DR?fYZ*Bv_m#}*SyId~j zzM|lHZ2x)d8E#^?huyo`{k(EB-0b3=PU*#P%{YCNS zf0f;TD0jg|cGn~nvwJ?fY*%^<6W`3s*}aKfw2KnYdSx{$IO{*y{S>=TD0d0lVM&1DE7`rBUFLIA zfr3vOV)t3)F6De$%JfS)T_>}>PX4H(%jWhi`vAkN=P9)cK84HoDW7Ec73D5l!7i7V zW#3ltseX3PWA|xxxjrvnsNm(S_wsWY9%J_&c7Ly2diRsvR^`d8)6hT= z-DzjAThDGAySv!sa&j8y&uM7KWV~;%%lUj7*YDGQr|{kkcJtXSXZK8YBkZyqZx_Sd zj(hKB_&#>op5Dh8{v*4uv-_rUS1w|=jNNK>Ie%8N+?A7ze?A7S@#b~(K( zf5`CvDmT~3E-F0PC3iWy+@9rf`UWU0{TlE=+zsBy5*!?-Xudw?k zbVMDy^`J2+2#7MdK1Ij*?l{^F?J`|<$POx1H-J>YA!#kIUiSZ`C0uPru(IG z3s{c=u6G6RWBfOjyO#5JEtlW5molE~dtsV_3v<|I`xb6wcniDCzwjW#Y{$Z{GWcQJfDyLYksU3Pz?+#=>v#C9(#Vm#ZssD)wXUvw?Q zA7S@VcDbD_`U%6oRqh#U*yZ$}(Zw*gD`#-MJA>_f#+@Agaphu%g)F!JGub^`xq-#( zE@PMJ0&Ks)w;2Bm>pUtT0Sp zi>kY2Y~f9!y|M^2*JUd~B?&X8Yc* z(1ahS+A8w6yyJvnVIdA(6fhXxOQ*Y0F;V3V>oZhhCPw?Bs?5Mow?|X?F=}uzR!>mh zkv!`2MH-rMQE+ggq}kW*3x|Bc^-aaaz8&kE0s&t;e2t+{DBx?{?!%eZ?c2(I?`)53 zsoheizzTp3O}Wp=E^+$V0$87+7_3T5_JfHPx+hPSR5;=n2ZJ3qh@NPi#^t_(|DtJs=*bRD=W`)aY3Gm`V$h zgn?fD>y`;gq1j>{)ao8@LEyN@RSINWE7h|oy)x!;=f8@b(CE!F^KCqiFXttLB zET3hYJByAfx<1ipG*A+?$%}SJE4#aU0_DA>2#dCbwzW4<-ytPZd@Zcr$Voa?=Bql& zDK)zp*v362P`}4Zrv{-P=EKD&Q=-V0t8yBAU@BhbQ`I#1B>d%=!WSs{C-wCrjm^_` z^@?OC^Pk?wjO$*`ZWqFI9b<5zivv1%H$z7~?vIVp&ByiQgWY5OxPP}JZhsLzKzA+<+ap7j!t(8mQIqq7$smVyom?IX8C61HvoxmwL`x&b_PNTNC$X|tH z@|KAl2ca?$kZt6+;5`KcOUWcXQ&P{x{{;d8DLxL&2g&%DZ;($Z{u5*Uu-|bj5X4v0 zVf`Q(9j%wf(QN>Tv9S4Q-k1lFbR0m*qBTJC(P?O+023>>w;2>yKRPUdpR*@5elF5C z89&S~+U2@1|76r@p|-FDI(J5jbYal#NWw269q#);^YpRl(lBIm{2~cmg8k-@%t#7! z|B2*ZHkHnSc^kW3=J_F)Y@;8}561x@bl$)_|0vexZr4P%FwD={=@#DrICmfV^ ztI^Nm&%;OMr3ydHMar`1f-XDZhg>R8^ejG%e_s6bqxCBQ!p`p{z?j35{4iH&@;d;( zo!_evdoytQVSWbNS<78^5CqBW%=v55{Rno+(9Ga6Ke>Oxrr(Mq2-EsuE^s>iR=~~< z{LE(>{k%wr(O^=Ua%EkxrFUf|^m}?LoxpsZ-F~ZKdsDwc_z9-`H~`niZ}k$uKK%4E zjee^k*SJm-!PRsL_FMfF!oE6{PFw?=&3bU<~_FUP8EjrqQpAbPH=DxSB4(eq|qmD8lJS z({a0@>(P3Ii_Myd0Oc3t+R{T|qx*J|Xm=`~yE5%RKodQ4A z7k+Mp>v&K@aCM!fys^=}A2jpco`jAHhmG!@g`nw7q&uUyq`bmwJ%Q57vZ~TRpsd{M z^-Hw+k7bhba^Omft4d2H{@l42hnnhzL#qYO!l3-NA#Qz@Dy&Q;zJ)W|jMj%YZ61F3 z@aEyq4%fSGcHiMTurk|YysLgiefDW{&b|BfH{blnxxYF$_9dt;GL-f%F`I#5|6sp7 zWTL41gndzRA})8MJT`C}EYFQpn$sv+U(BThiUXzPC7l7DOQGY`)FUHP`$@UENeClt zzJX6b+0LeU$V?dS#ya$;3>|nA#Z5b^tZ~am-Fet4mN^`0;Pn678uM2FR9pX-&DMth zO*~FHVYt>17cR)0Z=@UPBHfYh^te23Pnsv)%nyuqvsFLPb)yuxvfEP_vSJ>`2AkNq)DM4pF;Sg16de&B(-fW~LO<%k0z2E<-q} z7(Q$x@3T(NA;eA+izg!O*oZO`-(IDBAb?gD<%Ax64!~uKFIuq^!`Dy^qFXr6N)u^W zZs$p9S!r3$H2M$ZBrr}7!D|UlTY@*9ZhO%`c3ecdQIqP0AL&<*z+`bE%pa0a$)#rl;&?KAmCqLT(-WfTw&WIb+y3a%4?8FfImMYWK~tEzp6Gza1Zh)fTd0XGNQJ3BEZN}%6V;horAM}c-u%x_X&$X=jAa5W8#q0yJ=Vz@ zjv~yKtMdZP>W+_g;9rX0$&e!EMR9L0Er>?@yy(ix6{y;##+tZF;SW?9A}dOELC!|0 z(&5$!v4k8MyS0uNR0x{+my@@3s|XvO&(o(e+s^XW&CteNrUm};xCWlj_H=o^z+KrgZ>#} zm2BL=I9eB~ZE8oWxjGsp)3mf3qELHbv{BGhMw=U3yz8*_%MfFLv586|N{TDWff@%2 zC52FV@AOYr^r{ESPap)>mQaY9Iy(td_JVZ3k`vtF4HTpOynw|3CMm$YgQWn2E_y|2 zWl4D{&=;}@pe+$q#l(oGgAVUrKRN+rD*j_D*RPtWr6ZQ8H8Oaz#BCH zMa6EugBCi$itn~Uk{k0Xiy%dtzSoMOk}XYpjfLg3vxTp<0@wg{LtkfwnnqBzugyzt z@9U+-OdDvk-(W+>8~;XINU|)r$rf(vaIB2DP3m25=7YWbA)jtHgE>DE!arb!C(o5T z%xC^}wplyb6{90_UZ3s#W8;&CyAY=Ys1JDi~p+9I4 z47gqVv)B%`lWFoAha~9m23fT-T1zi2{0#ATLZC2NnExdVa?Qg0gD@yE5@R*z6#amM zl43HH?>wO2CD9gJjlV?VE#?}3sl;0%%wkD0u5dsEWh~1#i;jHB%bdJY#-El(X1C)( z%rVJ?7>-ZFtKYwJj*+@5VL5iHn=&R#I97wY(6t>k{ev_B?jP(P81IQ;GD+{lLr0T_ zV`}aQ$4|*wM%SWLn3yb%_q>-WBY#R3JuZ>Pqnz%(&Jn}qaF6z3^M~P52diOb#p;B( zgvT5cF?G6$(9tXmjg4F$3$_@A5mXtabAGQ9m0p5SAPBrgR7nu!fWW)OdI=)?3A|ra zd&A>q+=s-O3gpO7inA2Vv0o6I6wJ|I7D34kC&S{#NG*S}4QFc6U_+X^G}@4+MrSJ# zcAgK3W;@cq@$ELGso{S}F&NEqPQ?_FM!X<;B>^s{;k-LW$4g0w>P%aU=c&c2J~xvYCD=57B;J4P8o3R&3Ff3g4ht1REe7!TS7qe z57K5eLsV0@IT%5k%t3S;Qh&FN;>>8Yr4_sIFu#i)FV?w-f-&u|wI$fpxVa@%Cx-?l7>S^b zEy%-Q0{7eR!3+ZxYBIOCARl2A>ue-V#UbJZ$(;joVuDFw3_8$9DyaAw0s}XNL-O0U z)<(dAMPU;$&Z{@XYiQ_NTEhq!92z#n8vwW0Hv-((+i!?Vodl94_w~YzR{?AfZ38$O zn=r)n02|wD^76esL*91~w!1IZGd>W*xxphNxQ#t8zZ%&7(XKrIWWDq!qqxYsuMeNC zc=P;Qk>WeRwC>nUduGM-eq!2uOig?C&PLPEf+@CbB8B)s#SlLxu(gdq+&C|O4X|cQ zIFdKfIWQihyu)`)oqL9dkjIQO#MLeuvh6}(_rL|_dq&NnR!@1)s3}$amkSkq(o^zf z3YuecKE>}Ao?A|g7{9u4!d@vSWHPz>A3_YG`tOd7VJ4&{($~1sL+Z<|r9Bv5*U zjp_%S;(a=5@K{kLff@CPQ{17WP97`j4k9q4e##|2s-uS6!!zm|9vSM!5q6k~?%oro zl87(vG@}iFbBTv&nuKg787X^>4Gp*UQbZZcP-dHnQT1WBcwB4Ld<>16JNpNdt8+z~ z__kI@a z+1JH>Gu79fu|2YJ{`YEoOpAzZ!;Ym$U}slzZemSnqOgEvsVHQ#$7X*ESM zF@{jgU+UEZe&?c>K??`6cjMn`IM3H5i1zeRo?V1w$FCPn^DauU453pM?cVDz>PudF zY-ND#t=Fy|IY#-hxc)nq9M!*Fjr6R+?{q3VC!w(&qfPp9o*PXs^>dTXb7xZ!K1W5q znq5=svW@lO;6vo;sno%3!^!04yzmO-GS3U6&#b(dF0N?V+Ju#`N^&q~ASd+S>bRCt zpt91c>-TY9r8ur-7AGvVT-Lx7uR9}53vzNKa+N5gaRxn9#`5u_eV4SCsgUvp z7NrlXWX@nRe%hQtj_8R3`$WC}7#UW|;c~SOi*-r!71+3;272!}x;C1Z+ertB=E@NQ z20snKZCJFyNSZ!x;Yfx zhP6So(7gjgonyGf4R;4Lwlqf2LxB9(O_C;%$a#>Sq4BPPSR&z3%%`b%)3N#=fr|;e zcoCR$UH;x^MSZRO{GRObcOesliw;^^sX+X%33HxevG-DkRvBWFYw}HJ?=Y@X8y)TM z-7hVdr&hGdzj33N0hQW(?^(!O6qTqIrx8^{B|v>o(vUf5wdgfT(A2uQ#_!Er7q_hS7c)p2&+DJ8 zl=kwI^w*vJqc{y37a*mcP8}mIl^Uti_$Juy#=s9fZMDRhmp7vc*R1jC@cl_lOg5(X zzqE4q-r>?bh$-~u?a$Bmu0euub&Dzjlso>(ViR0%M(deHG}z_cE;9i*0-LXMgx7PU$jgcNerj0WvL z%-a9Uva{PPg)31gsXdrU^8{)r{0Ub01lJ=~i&RcB>t0)R(ydk;ffWwDz5u-jJLL;t z=1Q&GMM<7es1yTmdyKdZ;Xrm&G0Y3w%>so8+-*THrid~vu=tmj`*VChU4 zdbsjh;LO=>(aDy}1d)UfyJ>BrtA8wY!*GN+yI4%X^BZnzL(v^+ste@xVtS6dIJUR4 zx0hC*2JA0t8a{o?7BigJTNp_>a-lau44$zV6wg9*q3T|$_cZu8ew$_`!EpS}289jB z?=7&{aNIlB>ZPhaf0OK=*Gw7Lr8a<5M-Ir2vs%Y;sr}VPYU@}W{h!d=cgd~@)|*_) zPUZqu;y6Ik$$`K@ETb+CD{_fAgoV^h+z5Bu`Emdd8yV^A9PGhD!fq@+Jtsuv!$!U3na)rvr`B2Au@|HoE=&IlR{Kt>=#iZg`y)G#a(X3-A45nY2wioYGb3hNa5fD zcX}?bxWs2HE@%x+-IJ#DF1Pr69C@6uPMQpsvuLd9BiDF54ilvm7YW@XzunFxx@FpnqUmy){X{d?hVUv8I5dVtlUkQ?e z&NRg$OXkbad@m--(LqIeG+vdwdOS3Ho)Do}Mo`@1;t;*+>%t_@Dh(nv$E$(GEtv*q zp6N}Z0ZFHL`P8%gIcb1B0OwcaP528Z0)-RBg%eXOK$vOLPrMS-KcP}znbcg=&5u`h zA|Sa3%BRq4Qzg)Y1GFhFO`uoQ#2*QJumUG5js?5Bqb0?Y$j3dg*f5;7yv{J_qPI?Qlxf>X3{s(j6`Cb?pl!kan3Tq$7X_m(+ zY+dTY9+tvVlf;RV`cJR^my_Dcveeo*Q`vc1CU`ul2`nD#QsD8#)Rb8arj2jQhi5CA zTDM2l2MoKgd8f4{iaT9HZD=Q7ND{Q8F@lgES2SX)WNS;)PRs{S6Z@r^Xe1l;ox|;N zjC9?UF_K#QGWTD+rKK?Xc)}V@SqHLFmq#D;M`|z)Eyn4+gC(1IjfK}!wL&(QCv1du zLN;|+*R`6%voI-3o3X}6jm+W?V*imle0~LnVOSG4-V_I%nPFUKu3#}=T<**Y%W5uH z$(Lh85@4$85?(8=1uRE))YhZ>{%LW8bFsqkjKR7aS;=b0yJtsN*fgWxj zcdT;d=&$!A=)vXA#tTx}-u@B1H=*)icPx5-1um@KARhL(3m$jQ#PacYmH;KoBS~1| zn&?c7FTV<&H@Rlu=~x=alR(MyXcC?!bldiSi*JMHD>L#uFP>~}mboX|-8tG5?dc6j zTSw_i`%K4s#NXz)3l66x2opQ)!jhRKUYJ;a3}Iv~$5ChrSsU)HlZCgD5&?vHp*RqZ9P_Gm{hGf-)5GSgOQnG~*Ml26Gb zUox4pY`NbMcSGg_^HJ@#(OyPXUS*}DE8QuwD`&DD8%yOB8Nr^M;hlAKuwbSGHH2$6 zZN=@R#uIB{!m$PC{t*gq0X_@0q zWMrlX#NWXD@rAR{+*U=VXHHFC`ZeORg{XgvX2YCbU&qoM@2<h-<+6#l?$qdV9y3 zVuMyQ)DJ}cK<93WL2K#A!Q^{eY$7%?8nfe_Im3~C{XIPcs7W$SIm0!QFw%)tZ6nk3 zA{B)(kkk&vdYgxO`g^e}Sj)*^uJxVWW7siEyWr5~EiiJWPc};3P$W9i+0#E+Y!w(; z`#hV)_n`gFS^sX@C+J<8p!XcNcolj-v*g6+&2PICVD$vO?e?Z(KIco~szs=vOaIOF zw%eQZo;xl+1iha-dC3VW<+9B=5v4q5XfW2bpDUhhL-|FMw8+b5Y~DKYD3Wr=DgXD9 zV#^hkl%wKBB;|d}rj{nFMVYTUxN&8BzL#1Q)f%D6+CA2%+l>qZOEyPxGv{Y6mhA_8 z%d9eOz7S;Nk?|GrM~FXk>Wt!Vr1x5UgLVw@MRT`CFJQ*^IZvwc}ue zmp#7)f|9#@6=aym8Vk7yqbd}6BXhx%j#W#LVe@@Z{wq@X5o+q=vuQ!0_z09gaN568 zd1_IoC{IXJ`GuFU^0(w>Eso>`eJc`q6fuY&g%a*VdtjqZE7j1e~AKE zJ2cAO2-V}v8E%sWZE;nSgf5E6g!XigCALe8zAdiIbQe5<9&#$m7)NDoHTytROcIn) zrHPe!!lumPZz!uTJeZp~&yz$U*}Gi)Ht|^~^aEdt3eh0P%mdXai&u!cX(--Gq0H?z zg)-l!6k71j+{`&QCsT-eq>Fzm{u>H?adk#cv&=3u8gkqk=^Qo(vKY5ghp!iNI@~S9 z0Gftd1bI|>pm`K*W$wqgGiDVD**s@nB;Gg$z1}q`%HU2A%aEBcqYSE^nLiU(EOQrJ zdU~odXs}^U5mEh_F&(mKXNANe$oLIpG+DM9#@^9b{JSevd#Rz*(7;raW!*3CIMrS7 z{k&O-n$c{@MUmx}ED`rZ)MNRx5jB(bl8TZBTynAa3`9LxkT~Nb3!R>?JE>S^jV^Iq z3GLHMYQ_gs9jcyLQ%rJ(3A6l|9K@?9Dy!U*SH!)`-32$SO`Q3O6UrSyQ>axSEbiU7 z(F_ubBUbsA$vP=2z6A+?JwXyiF`kYMB^C6T_yGj{v~b3x$cZ4U#uCV7d*-Cj1kut0 z@iRzxY+a%RIi00*h#LWItp7*emw?Ar9QnVV(Phi0WNg{U@>m`lS(fA(-LhoxNE%s# zb)k`bfRaJS$P(6NUA75_F@X@41Xzw7uq1I3!m;EelnNSOVy-~W9Y)vN02>gww1^S##{)e69!@hxt2Be3#1@$lN@{M(9V zmCQb@B}di$nUcwYSN>8w0m-kPLb7sMQ?gaS)N;*`EDLtk4)H7`Kfg8FUt?M0fEF#y zkux@J$9c(QFji8sja>CXaeq#7{*#_rlVbCjNpamUlOlZ9q{v=b$>Jd-^?-Nwq?Em^ zq{v{lT*+~WYL;W>N*XY0Ogw?4-d`+}vUe%g@_ekCmxJx}SA8VbOB-7d1SXXZ3OML05AA&r7r7=WKSH<%CDV&3ogq!j1^Q`#N&Y*Wse46Rvx86 z*DMv^MzTlCU9%($_p&`nnLUqaUYF&JV?;22V};TUcPr!SMgyobbHx{-+g+7098oSx z2S)nBhxJGpBLh9GiP0YAU>Ak@@KE;=%}x`S?lDEm$j&1dm8)slayUl~*Th&i7V)CW z^31P_t2ZR)KUg(aonn^nsdb90jV!(Fc5xH5d1BifwTWG#Z$=v`uk7c=hoQ|6s^_Xr zjHif+lvjM)V9j>zh`4VZ$$tX;*KQYAByCjk>7@$D$G+`&0*V*D^bx_GIx<;okc{NUUO@@cZ@GL`Cn|;`$N7p#qGmYN5!^#ss>oBVSc#im8 zgbtKLt-}eagLp*gARb9ThZFPA;ooqfhID_hS&IivcQwc@H2WG~o={LNFw-F4y?l5rj~HBS*Q z*NKlSHRdnlll9{BQVm~l@4RgB`+D&x+hU#)KI0ePRhGckWAiDFKl#Nk*beiQa8HAH zRZ3{?4Av*Agi-xMgE*Q>e$d?Mn?tl)cZ%y$@p2;74wd0-St+u)a%9`9964q-+Nvja ziucJ#DC>kH{Zpejt`uzYaZ>wK{j=(!!Y8JNZEs1d8fjEN)hIq~#*b&0*#x{NAil~1 z;v0500pAXYr?du5oQ1)dS-{sw(ODRT-EKHn{Kyi(d6<)g$IcZmDG4a$1Rd0<{_DBo z&m1e5c&vMOiDPNxQF}XPwhGa`j#2&VUE;bldd;=DxycvDE2OcqXBvl`>dq$d>y7!; z0n%#-H2kI!x;tajrXcz}k%gAsN)$MEbl6=yHzTFJ`sF6^o=ux{bQ)t(gN^9J6kYb9 zw&>J%bocgBr>y%+h)Mow_5ID_L7Nz}i{Es=6hob$UCfDSF(*jOMK!NBi+j)7NZR1T z;_(A&ekQXKz(Iu2KF|Z;xM(cUJ%qI~zV8X+Z33g_sTT2AL}Zy8%7lyzAS17|MaI31 z+%+~n+J`-_Fl9o|#R$C^a?+@IPph~tPwF%{G95!NR)lmTJy<=h8uU8RDn2nofK4|R zK>D!&Qjr9ZdWKdfmTq5a6Ms>nF?2tmN?)2unqM&5MlDYg$T}aXfmQqA zdFmY8U&P=;+R%!AV&mi{G5%3e7E><%!JMM0^{Sv5=IL` z)<{zcpHK;(=!%o@HG9M@1+ws?a;&E=Vl=^YvHzhh!_TR7pNpC9KBM}fJ>nyUTc|yo zI5;kk&!Oh^G4fG4Er18NV%lN1=wrgDd3vw-NugA?cW}IS3Qggjacn-I>vwh@k!z>= z`|-kz>KmHiz-d1`L|mvPiE%(l$DJg~QG#{KgdYBP9bzex z*^p1ovvV^F+G=h&UtC)hp&B0Ha=+uovO-MFvh&8l6j!nAJT*Cz5c>m8gjq|Fv1_J$ zlCRVTVOF)r?P_;X^zcZZn%NjNcU~aA7OA?jDlN;wJmQgckiI*c4 zlD3>(pHtYpVcvVu2dbvUQ#D(pS|6%4eYwGErje0 z`aP;s=*QvS)H(Ef6>h#b+;!MmP|WT+Vn=N4cGqFNn}=^@A>oL5*P}%BV2}iQ54v#z z=)f_sT%M7dmYdT0~@YM@DZGEPS1iAI}xRYs0F(VrZ)TKFT@ zE%k*ID2Hsi6T({pL>v$B(nhboG5f=nT_ffz)%(ylriQCu>=n0{$5z?wq`WW2S9!+B z7Fv;VCzNt#M^=$Bb^wK;kKCzo{8H5!*%0oct4I|3P(Sd<{X%6B4|Un#zcb*{yyt1^VnC#BDA`cL)!&peN0q7egs)k8|8;Cozv zXCuGq`M-O9mVEHAI*Uyyw~8ni>y52ANYSw#R42~hJ0pN2Uy|HLdivSvPMi{%tj>zb zOtwyoNr@!k^jnLtECpvvS}0DCw2(SP%n-z}&`u;mx+Z9jMRo$t1lK4rFVTo$EY-J` z>}3{-n3r!dC`TDd$eJ@PJsrp2&@J7p$it~O*$6yC-YmvxH|Ypc=isbLH`GlQ(Xa_N zA{c9QxEBMoGZhEjW)q!m)}|W-au!2!U}fb3Yz(Sy4a22rr8wJky++d07pE_R=-j1J z%?%Y2xRU|M`Wxv6yAu*{K-yXI2HDD6CIdESB4K0;C74gQbhAa#uxDN-ytgnDs^A;* zOsKz=LP{4Yevd*ZhF8;3?=l7HSCVNEAL<|77)DtUVs2Yny|iknGwqy3ftAWO<&k7X ztgwhXnXl3!spu}GS`|qo(l(2%NMe^l4Wo%}oM|MoHpv0Oj0--HuAe>yOm2Plu!b<6(sz?pv zJcUwGx37|t$S;C)OE(>gW*D8Tq&MxRHe^qh^!2@^Qj%jq0T}mb#4yh1TPS^jx+R7# zb!!-J)0~v%+ci?Kl+X~PDTG|85Eas`5Tawy<6Wjw?UlDksE=+anK0d;pGcNqKLM)f z1IetbVGQyuVqK(e4dZ|gCiz1eQ7I2=ehM2Qfm9zyc$7CZip?zXY;g*Y->``e_P>{b`{`{2dc$qFdu)vM zMx8h^+%q~ffzZCeZlF_RW7y z9vtnTq{HwE3ws9f4@1qdsmbkhE(hM48V*C^BofDNA6@wN7BPoCJzdl@tCu?XINVXh zobC?~kM@PP_m7VEh8G%v5y)}DP{ZMo$%$w(_ z?wQ(8Fi!Tp<(}dKFAlN-PXacey+gNel?FI8I)1>qLv$2Q-{ACMU)V)u7iER{XU!LR z;;2H+jP<$-N9R!@ec>_8{O4MhM``+{8h( zZ_jV1^9R~Q>cZ)bT_NRi&7K~RqBh>5Z5+BVSniVBeRP!-d5XMngz2)b`tUT~mXl!! z$963G#NwGkR9rJzoKVrZJ0Oo4X?>?nrZ?KnxVuF+q&%T70s zdz3O%RNG;XsBgplIQIbGxQ6FiPQBy(E@k04je&I&W`pU&HUzz61dh+_BXErP)4Of_ zm|dmkYdpz#;}5`T4|ckez)bQo6e@AZ)0bF=a6OkGVi$0Eq_^Ub;b_jyi^5Y)41GFq z42#T*aP$M_~4M%>`E>YYVe>;qF;P|NvIL?SqJ!!)|z`tO_&jdbU!`A`FQlYvKe*VtAJl=!_NYKt_?@}DRicdydV$hC;!5RBmLx0+Hj$lQ}^; z>j-}olShKz#Br(wZFI>8x`f{{j4TR&k@1%qBG0Rdj&gMY3ba9+2*TIa6NHT=gfB_B zLxmf=Ej?CJe4XwwOq2+}+AzxP^an5rBmB#l3KD#l<@`6p*En62u}mNNm2els^BEps z2>CMn7KV2+{2D{pTZX^D5cQgH2g+7L__l<8hG-Wg{vL+6GyD=m*4Ocd!kzG4;&;O5 zB;3I;#PDKo`!^;>x$nZN1f2`nw42EuoH4M3&7u>-36AX2{R}{XG^S7{(@nZ~c zX2^cA@Fj((v;EVzG2X*bK#+acZDrWN zu$|%g4B1cCarvx6J0{~j!H~;&9oO%5FDtrh5yQ<4%Nd@{u!A9|4$*?)7{e{wn9-1l<44>9C)b025?X@)N-xPjY?4V>W7#?JJh~ec7*-tjy$vC%b8}4WPQHDQe_%nttG5n)~Sg4lvaI@dLH!!}1 zVF|+qhHMviALBy|+0WfvpWSR9_s2Q>K8BxX$o6uxo!q}-`tKOBzieEn@Qv#kp2d*s z!^Rzq?_u~hhGB-&47uDk-pn}bwUPa2BbVbw_MeU4VZL7|n9q9TbG^&|XQn@?;1(|5 zE$qKru4Fpb_kt9K7vwNx`xb0xd>2EOUvLfMY{!DHGyYwMT%HB5D7?_Ykn2@pJ>y*r zxqJ$*VEiVAA7S_`!(S^{#Bz$*?nOmRXL}d5FwXLeu4nuc3?E|1?PSqU8UKxfTQ@P} z{BP}HoZFSHT<^BBowt6N!#}AYp3qCb^_hPb3FK{VN}AlH178h{0})kFT(0hk-7Wpgi(ZT1t+_E00;CP)?$m~B4cQ5s%NBo z7+X9QSu{Mp9uC_H^nR5c$7af-3daKKBm^HBmI?H#)ls8}mJ+dk8XCYGLU^4??Q6V$ ze5{C5?e4+ZnA1i3$495eii$(NVcOL+G}JRTuq!ZmAnYy<5y9iJ#hkG^*^7vsyJ;WZ z(7v9rsdEnnFFrh88gk2>d7~n#$F7KQXrPQDGr8hH#&mJJTguPjD!x3 zRdw`^HipkXQid3G*`(_&8zH;$5QT+2(ab>({uvu@fjN@;j z^A$oz6jjGrq3Xn5~Me7K1 zk=I~+n6?NbUs2A62LR+Y(-Q+Br9n_n%kkZfo}kE8TvatTtV2G!6E+-R(FQB|I_dcEegjgFVPoceuM}Ff<$1+5!Z>dkz0EbMNh<)W<*z|C!@zLz8N)_!w0yTY3{h3vY zke*0Qj;^|hmPpNwI5ie=5~-bd6 zL#joI6e71gD)yVJi8dMYtBF#8Rn(M)M9SKpg_-3($0m3V<5LWNLZOhiG8CO?s5j&- z_Li2HbbG--2ge5+X>gG^KR!QI{dJ51mf4YqIOFCZ1n&jU2-LlN>C7OE$=ofskupSe(T^XK zcQxQt(lDK;+b}iKJ2{9`UAtz!(SmP8`XI1-sE>B(bx#^T%olgck*<7HmXlnkU!*Zo z7A+9V#R|tNynnu0(8My+Y19=Ld8+UjX^qHn5NQztvW%Q0+^)uiQwmAVklYLLe~Caq zf|ui7FcLr3A>>tx|0GyneDA<|Lj)h5E5zb6u)`4m@QIxI?_z&cVQ@*F>apjh&-?r2ZfNp`8%iQ2-V`LHgT5Z{B~Ym6Z; zDj)Lw=%*9l!#a(KB`?Z;DcO*dFdpJ{Ey^eP0N(W`Oxyxvyklj5w0(mXR!S=U*@O5(4mogOf=8MvAy$4|r&*T$*pxNxVp7NpfBj1dpUoMG? zQ7@zYFPC@{@W0$2gYRESC|}xs6~Jx!Z6J9o@T2-sh+iE2Hr$Tan4U+tzO-GU>{oON z7}_)wpyrFRU(r)YifH=MeB5qmKP}0Fh@F}VQ0IgCHCsMP$AD`)r1B_m5=HVgMohf(tJ_*sM&${3FQL^8T!)q7lWYV;CA|Uusx`mY+>WL*G_=jckBgU8*b>AjUUM)dk)~Y06)GizY8}y zA5Pp8AK{1}!S`w49{ec3#H0Bdac`IRJa8>9*~S+w?*ziMJo3#r@{VTN8(&mDjO;oPQuOd5Kify8K3W%3t?KG_IuJJ zD&1q1Ha^llj(*4N_M^5e9^ZgXp6*vE-6*>pI|>@nDIW#+#glgp%=s|$dE)b3*N89| z^Of58R^#4@A79rEp!$75V}QEOQrXz}u7}Oi$71ja5N&)PydFH=(R^ErODZc|*5xg& zEUPN@ddtdPE{`Ou|9EmzUJhDmaaCohq+hu3a(`2UaA>t4Sr~cpznREwSyW-^%|2Xt zM!V7aZOF=b_l3t_d*hA2Ul_jP6WyD> zLjJQzI9YO4k3(`#Rfh-WaFFWAv0mh8}8C?(|4gaiddCYZj>w=cIU%RvBu$0-)#Q>ZfmS# zy`{GP51XwG&l|X$aw&0(Aud^xvDip8QbnpG)tQ!*mYkN7mYSB9wjga`T6*fDG-|aY z$0Xzqr$a`bT@Oc0J-C$XTc|w|P5ND@EEa$@XW~U-~27+=R^DSc_;#5InK<|UU z3{CPQK-FfhjA6H5+~M{00c&>_3fc$8$i0S@Vd;N|^pyZSC$b%z+ehficSv3ee|LV3 zl8e^u^vE?-Lzyg`j~Xc=B{SK1MoMN%rZXjFH4x!E42m<2@GYRPOcrN2gw}=hau|+F z6{NYj<5C*u$V*^Nx!%{|4~1O04dEV_%j+ukcq?*IAfXT~^HPAoPk^PaBvB_~J*uJGw+S8X>by_i3nWx-S zT8wkADeKr!!QT<8YwN^;%=o$tCu(~*FC5f>pkQl52Yn8yq{R)0`b^A)&%}@jeuf47@R2~dzW;>Zg;M8r)Fp{~W zv9r0>RWgI_D=&?~?V~t2JDl`24cyk=+7Q5@<57t=_15?92_IuNG zbPBfiadotA&@ZbEbAyI$3VlsYAzv`)Z||_kf#v{MoBX@|O>9AOriL~t4m)S4fz}2+ z^A#9B8PCjUHn|qVqIise#|qB0jcL|y4~`;ypsc=OXGY?~`_c3bj#Z_ffhBzieC^s@G zvrxR1rKRN+rD*j_Dm+zXW!`dc84`P!fNazNxQg9;*I48zE56$biEYelErtYb`W`EW z%C56d)U1O$+DrHLUPqZp{9-0YZ5t*vR&?at5;Jm8xqKLpvD<`_;b`Ja+0 z%LF1L#A*qqWR&j;JXt`P^`LkGigLL+3%-)aQfVIcH7jY0soi+>V(pmr=xUg3}^9bPA^R)*@R z)56aXeH8dp1z1Qjf&Z@P}`0 z7PYMd4WaA0Y6nMXVmvs~J2cf7#z0BG!Y7ACDLfCt_mXlIGHF>NLQE0!-F{@oiU4Jc zt|XDdvz*?6?r|f@kvuVgmqU!Cq-2`gVAaJMgd~YHb56wEsU|^3vnVRQgvL?h;tOqv7Zw=6wc9K z6h0{pJCfq0LY@9j8_m?B(MB|N3D}6HM(3&|>@pt^&32-xU5lM+>eyS)Zf|&@~*!(<9CUCC$0jw~PQEv;<`7#STi z#Opx!Gz5Si>K`=3l}jiQX1W{B&O zXv%gz0(*xpHv5@+*(X%b=x5YYEB?!e7`)|A>_-^%?8Esu_bt5U933(8$;WByQclYv zbM@ba7(w;lAD+ZYNJ~e1D_$^=>!#Ko+Y%M~$o%{3Mn@*cNBOWH(Pq?q!67cjlpi~2 zTk+-I)BAdvHFm`6KRU$K)bLQsfwmyNf1D**$)NOTGpg@%ihtHoeW!{l8O*3BoZ=20 z_3){p?j;5@>SvO~JvwSzux(a-+r~$Gv8@_bsCy5zktgCyJuRr_FG=D7S|%ZzNkPh9 zlcQs;{S;BgGL+e76IA_hvUo&m)O-q!n!5)_Vykm?iukrxM@q4&W5!~2OguVM)!#@F zKh(OkwFjDg!Cj}Y&|q`-!~x4HSEPzxYBfv&N|mv3#j8yc8MFEusp1u96&i)wKnJI( z;>i}lw&}Affi7%#hvTwT%3bPED(k5d^^I%s%fWA5MBiA~+T4c4%694=o!O2gXRecX zx4ll*|D%bvBZ-Va_488eyDjRq&2cFnEkw2|q_!UG8V@JZ9@!-SV>L<02`Ap zgv-vbHb%IM1`IP}NwGCGE^m3~X4fU8)r^!$FcQW3rG9$AeJ(~B^x!~_Zakfa^Pu)1 zdgqVkCzm4Ik7{XQ%ysT83c?qxC|7f6N<+5E0c^a7GCh+9xb4^x+gul3i&ExwVT_s8 zEtZQbS~{EXB&?DE)(qr={+pfGQVxm+WYsY1`dwUB3C?R-#Az!xSXf?3N!G*@-JQ`! z59H)bE!CP6bppuqb_wB})d2@o`HAC88G!>+?$T4f{?Tazc9{bM-7Yhq%s|A@3)o_eB9_uIF-7*V<1>^cW!3s(tQar%jI z+YB@H7zghpo=+VkBA1$|^7sbC z?#ILrBW?AFF)wdc6K>k%(&0y9n3!x#{lBzw@9gn;ETd4$)wjcPE({z^)11L;oAOP#aI6Smu_Cc+rrHn~)29t~i&X1$$JvDglso z8>C@7>52ahTSS$p>9MF)+7S{cQ8OB}|2S*^zgC>RrWdYZDt(2nH)0dVL9cjdaTnVD?I_+eOJ9TDS&yV!`pb3rlIr>{L+E0>05j?L-Qg$*QU`5XZB%hoJT!Y7`%i9#YB;1GxsTnwl z?6!k)0uUY_ALt(G!-ItVc=+_6LR5d)A+8r^>E=TX8u|@^7&!Xsnoua>yhr0U9Pavz zL);V{Lr1tVR)nKY@j)vBbw!#zruW%Je)@o03^QzXhUvG({a9aA?*I%dqwy_O=L ziHe~4V;1CxQpFz~XUa1viSI^b>qz&z5$^YRs(8(@M)Ju_UlYquuL0xhsp3;kckk%f z5z;q8W~_1~*`G=iUvO^FQ6j~wWFpI+lKFm`_)PMK{_dU$JAc1zNfh;nX65n{b^3in z`9%=`lQ74RBWWNx)#6XcbQ6$vDlR4w(;-#Vxcd+nCT<_swkM9)HA3km zZB-`5t-Q#h^o==v=j)+0j$0g3S2|Bs__yc?hVwy(Gs*cC9Iz%HchvivI((t?O1zlh9Y&9i&hML==qn9p31iCAFi9y-*0WP;aWXe$1wnQ$Hs z?irWQr6X0z&!-ut3Pps+%n0;+E!d%>Vx{spr&3<3 z<>%+YCiM1!D@vjN0BhT>#@dcNyd>`}z`tVpSAwiyFio+@lAC4dW)~L9F+fFrG+lXK z11?%UkBU$%BPeMRafn}ybzzcclm;EO^VPtT7E6P(&vwPofKsP;n`vbEGtvO>0358y zoAwk;dkdzE3#MmSfGBbDPqL!(Kdo|K8Pi-e%#T!d+AF1d%V+RwQ$_JZ0<ryzT<|Hg~scyDRS?D*PnPoNyg1FQNNxDZ2zY zz>1(I9(Lv9!%LI?aG=U|fFaa5l&CHo4AZ~nHIXqL*)Ve36K43T>FYmOrgm9Lqza8!5 zb1{PU209S(lZpUdm27Qk+K2VvII*9fjYo=6-#Oea=SVlqm?NoYU*`K4Z|YGPeLP{! zrmSt;Xvm}Y2qZO_haSf1XDlT<_!$eo-=P((a5kn-tJIuiR^6QX!Ytk$-9V;Vb z5-Me$j3KjxPI>-s@omU_X;zsRMal$9GDX%*nRJ?UhND9K05bnGc^R1#?{VzMw$ifb zA`BWM_c;+?KN@d1HY_q^B0YmxW$p|0c2D$$`ue@n)*<>BGsE#u;x7x5^B+!$N=)pt zCl<>rk%@_Ir$~&fT9};w!BklSR?eali)F9)*^oAKhQ;-e{HN43vROOMO_RZ9%K!IBgZ`A8|9+xgN9&y@UZ2AO6Ei2z3IvM-$CTR?3MM<H0dtQdFLWjT3ebaYjv6wuF|ACl_uTAN>ln)^6TO_(!6gm zs@-mSmr?nvtaNmgI7Lp%IUK}`rE-ak@U$HBYbGAe$F zM6Ovf2S;;I4k@y?~Ff6L|~oVu@5X^ws?_1EIPkp08u%X0erC!4|}Rx>mRLc>t^en~-V>Bzz2 zdwX~~JU$V&)15hE9ft<{`i4-GWS(-yY9(VwH=b%68EHQxSC|A#-DtSKd9-h^A8!Tg zbQZDHhVI@;yfI5}!J*AtA`cZ80of?^LXpsTci-UQV#{HqWzu$v??U_cXa1vUAEkF` zl->)H#qXi_(<@Go-rU=r2CGNuZMQeM`GT*AYnP#duKWkr+iq{td*PJ$81(+nRVz-5 zm&-Qiba;8r=t#Kd2vU1Cqb- z%vqDah5EI~2JIBdpG2ZJ#!8etadE9Uwmdoi>g?GPU9xbliHfY;j3p^C5|xHt`~`6n z68-nJS?vDp*bi8mO!nWpp;xbyqoq%ZYU#~@WV0D>k7&ms2Aw_k0zN5Sb_I(}Vy#77 zhFKL{-pE+;4abHRD6qwDDF5$L`EhFMBa3NCf%pWJKf3OJQ+aApXDClZQ~9OuWaU4Q zo3Zq0Eaj=Vm%Jz*hVoClVk@s|e(jNB?Y~JmGYTUmUSXupp)jb$nwcLE&HOBDqx|G% zEV?5`UZfW-y;J-UdAWCeR!$JZH)L)J4LnsI+8Y`=bS5B^T|rVaDDf3)EF#O7K0LDu zS;}5EE`AT$U&_tOY0+YgoR%KTGL9Veybf<}>d~f71@knd00*oao#0`Fq#(oX($SVz z#mMNg4w=!u-pS~8Y1y~MyE2mVAHxVa5oL^%vbLIIAaau^Wt2CuGLPAmS^k8w`qFE1 zGt$#yC?rRh%P$b0heF?XC#Voja?CPNgR)44XqaYNCu5IIp^OWZLQ9^^%~4LNV^=pHjCvY5BhfUh5GIy@}I1e&H>grzBepmh|y$~=g9 zXV`KH**s@lDqdfWQSYV%)8Ii6ry&br)-j+F8cmk1#_;ZFII{0b)Lv@pG&(fXWSMu1JI+kb|6bl4lA6_Qv6CXptym%M zMp9qfJeQ`i<8ihLUD)X-!fZggv7Uy z!kZ=^DP=D!DKeNXS8^Ppn#`EFk_OBg6Hg$i_ZQ2g>|Khr zJRhs(FsO~dqX8*6;DNUtRSNIbAEIsdAX6|*e-$6BW*$+UKePBWrO!N8Yi zZ0finPD~cg>N4>wB=*PI662!Lg|13QCWb*pqKQ%QtUfM2=t|E2d1+SsoXu{tobX6^ zeE$(;!DTszv4TpAcsy{U?9l)$%AjkOif<#?qvftyl7)NOo}|p4M>Ma?a>g+t7~|C= zVqanEMq{lksT4v+Nado2s)S0>Bi_q<^${3CaADRpYM*6~s^+*^a1KW_pZcACcu!}-{c&Ph`W{2OP z(kN0!b{@HCF3pCs<#3J~u8Fa3EaF9#<(XdjvCQ|lC08(DhU?cyeA z^Tf6}Y7@Ie-;6d?UfIu!4?~+DRL@nL7*7#%5-6|uw!xb1+7WTzhUDsdYsAaWO}#^d zV zc)=>@!w2Qahbj*BQF(;f@Vu!D-Bok9YDluXM#B4>p`>gJbRLcB8+~{g9Uq^a=c}*B z2J$L9^8aCDrc@aqy2hmiF|{K*%Ky|uo;0fe%O`#&rQsW{H!tmYt$0Q2Mmv4aSvjNn zm$l-m6l5>hi2Th{#@%(|7LsuuGBr;TFV~5WD>ddX-&K~t)?@Q2jz9UuFW3(AlyFajcvVVh?hMu^s)SMfLW4M(N`BDX>6=5eTX%}< zQt@&k)ee>6Y*{I?xpHLNs~ov!HrlEucZ&DPNGR)sBmGmOIIa|I@^Mo8RQs{iy zG)h{=R_iWmvqth6R8f-)#rs%QA~u0)u7jjR`H1$0&Kdm0Md^IkcuRL)HAd?v2^=VoA`?ojiLJiRr=CQ z+B}h3^|4k50Yw%*dZlp=-S&=7(5+GP)$_y$Hp|RPfv3_^3WSy<&^T!dG)}U>_`2(m z61&B*Xhasjsa^b9DM1#G${8hzTv3WK{UBb>ZV!rU^UY$6${h)X{iRSczIHAu097WZ zEqB!)><};J%L*I$(u-Af^Vg`V8!?)unk%Q_U1|>ArQWaUIwEJ}T}R*^BCE^(stu3j zvb(JJZK%%QSN*ugGW*pcLv1sX;(_DNb|6 z269BO#?RSk$ajk$$4uC4FEBn%EMc@DWQ{bH@ClXhiLN*aU$aNtQXmUID#v>2B1RKT z7yBRDGW?uM_qmwq?lY<%+9N(vxP{uYiG$;l+&UYNk&nu00X(=B(+;~u9}`B+(|g5F z3Z=TegX6tZXbSg?WAg!Bzq9j*Tszg@j~8ZC-_QgHPW#~@;%ddSl`!Tza@5fyneg^6 z!V7j!i~~wK?j%u;60FlF^zgsy5KEEFhJ0$Cotsh6R&&ew;@YAJ)$j^8)d;NY#~9 zX;}{D5s$>w{Zv+6ymG!)t$CqKyd0^JwB_vjoWhpYM3Zv=mf7+TZxbKi8sP?POH?SB za&%s%EP8dmro`(V&*f$m{h{V_A@NM4Udp7isdXxgj>3{MQ*Wh3tKYa#+)yUFh3MD* ztd7BRrRo^=k~&%Y?CpkaVAq9hA!KLJ?@^sXKh6NB&Y|C{aP!6CuEW-XVs_UNJ7R0M zyAI>sJbWt)2}jJk9wn*=gCx*<(2Wy72abW|@{H89+zij<)erQD@07`oCOS`6SK}>L z15L`4aWW!LG}_dwGIG?3{^YRL!XL42sV}5JIb_qF5Z)3X;&?zc0A0QM#_SJQc8!>? zRPRIIm>RBru~*z)9$RIzlk&b8U*#DiTWCefolwe|9hFoLL@N)r?8H}DJQA()Bh|Ns z#Y^R~F3zyB?%s-Ti?1TcSJ3g6@=Vmdo7>&|6ZC&QW{o)MsqtRez zU7bG|#4#Tx3E#4HHsgDq5Vk04Z8t8rLYn+7JFyRwqF-jw)#m5{oLtgT*Jxa71z*(*0~m+uF4R@ z7?a=E^q=bcpLrh3L?Z_Ns)v+Fk^3kZ&qjXJ^MChTE&1SK^;K+2xm85DSZ{1yitnG- zgX+Zjd}jo3|kOuD6;6?r)I zCL4ig$eYDD?Is;T>KvR^>4v(=A{sWqMg(Jx4)+iarK&DwN>K+a-F4y>$P zfQ>=btzoz{trTaUuGdI<`r`CO5S_bJs=1*;0(UY1S$`wlV0S_S4oEvo-XL3f%Vfaj zOeBnKp#<~kmTtBv8urY~gcBELLKS>to(c80Qb_3{#qUuF#qer6>RqNF{Yo+o;zRwT z8^b6oLdcfe%lLh@Jq68S}tZt12&(F~(=mGq|FS@5Pk zS<=_{mP$#E1qEQ-rxC+ApKqb`1?rX68o^22WwHiORZELbZ#S}_@S){mV_GK8 zpgml}H!!rk=KI+wx-`ta54bKU?JFtkD}I}y35A7NjF}wl9&!~Hj*Nz|#Q+}V4UJ+m zOFUbg!s9n=qJ#bKW#E2#8-d<%8}1$(qrFiljtuvV4ox7mZ?GHa)Yup{d70Q=RaN3G zkpIfdOR>X4Vei<~c5ID489rQybMXob`+)~X`zPrzyu!ksLHxr|b8KpIJDtmcx2A@} zkT{9NvD-%%zP&}vVNXvN^~~y}j=@R#^ss0YF{k^(!=ruS?fs+Uz2SvMU<7hpFw}5( zWO8B~3dLJo;;k&iIO0uM4+j`16O5C6Z@H(qz>9;dz>|OtXz$SN zTcrUGjgB9%?hqY?(>FLh*cWzD*+p4l{#o-yoHL8JIT(hSKq^OOz zXd8zv43@j(b{}13MV=xr9AUbwt3Eu9x8-CQ!m%BTKFxTh5Ea)<7AI76?heRf26;2; z?Kt$&Ramd&s2g*a7dwg}cRNnft84Vv?XuI&;~u3971egwBkJ35Kh8bCH?HBimQ(L| zze`zoPGex*gxO&FkPSia7=hz6`v@E#*r#7;%p@FE?K_$2bA#=%dxDUTupe@ur{W`TdwhNIJ2aH|c+z;?l9HXNrjFX*@7 z=$97kvf=257SNtV@`8NWash@6>H>oNrTqdJf{dgLnV+=J+i>J3?H!66ksU@k@G={Y z)74X7v*8}#57_WCfsfm8oEM*}PGkoW@-|>*_7_|D7T{mC;j4fjv*Bj}57=Z2;T(!Q?~e+TRTQqb>@hp)SNHU-^{{--!FWZ8+ui{rHjp;As;1xAAWLOHx%xK4^w<6d{4q13_}brW_TmR_c8oehOmQ-_lSa~ z{g7TY+2bpiGZWNy{Ty6`@Grm>?DS)phY}8ZRM_c9F^?tuotSGgeWN`b?MD^isK;J{ z&$AxCSCFa)=_i&kJeT3WFoge5xI^3THpZV+kf!=FfAD7srx?N?C64}wVA6VqXhS4^ zgyFRenLmm7Q!Z8Xl%FyDlY*(|Fl=MU<(GONo`!^;>x$nZN1f2`nw z42EuoH4M3&7u>-36AX2{R}{XG^S7{(@nZ~cX2^cA@Fj((v;EVzG2Xbq2xV)F)L56HsYU4<5##Ib&Wr+4p(pj&} zW`$?Io#AH~KBnLbw!;c9Q6KNl7eg2GGu>Q^KFHn>0x*g!>1T>ea>F0@NCvQ`$EPi8Ge-E zZxvk2_FT($SbGW6Z(#V4g6q&gkbT!}W!S*5o#FWm*-zGS`K&`bCgVN9kjr@;*Y9;N zE4phD!_5rK8J^9sgCVEm>S3JQao2Ii?_$XIbbXESKQMfa;TsCBU&gSEVKqZ8pY@#X z`om1WjN#P`-^cJlhL14h{I35I<9|~y*U1nSp6rsF&5+x(Ty9@;*?)7{e{obHB9rn?!|Fsx;GF2f5L9%Oik;pGh3Pd41iIJavX z?q~c_hCgQbGlnlQ{G)>V0;h5w=oPeoMy=7w((}hS+9-k zKO4CmH?se1{0{T|Lcx62BcJPC{y#JQNd>oX`EFtV-Et+qD7+wtA=|fLJL9_; zviyQ;7-u^ce4X*{GUW0sctzobupQa2kn2@pJ>y*rxqJ$*VEiVAA7S_`!(S^{#Bz$* z?nOmRXL}d5FwXLeu4nuc3?E|1?PSqU8UKxfTQ@P}{BP}HoZFSHT<^BBowt6N!#}AY zp47|ydd_Beu7cj>4A(GZJ}=wP`z@ybT)|@Yk7BM@#kVTDIUan}Fe+hJ8vlC;{)Zf= z7h#pB$lL{X!YIP_f|K1nfCKstYqCXhu`x6@)icsPjIExEEE*nT4~Ojpde6#^V^if( zg<~Og5`vEm%LIDWDydOKONv-W4GrK;A-vY4_BY-?K32r3cK6_n%;}>2_x=R-LxNX=*ZAO|Do`BRYSNUgXM944;3b3^C}kN!MF9LU!dL z3JZD02Y2tR_4*IAl!eqmB{p^}1cpPs!=9o6MA+w(5o(9_94Q%}Zu6J*#fUIGF*t$s z!{ITkU60FX`=@2JfvQ~{O+$x@6AnpQw zzu)T)>~Uj*c$DzOq}vT^4Gs1nPu=0}p25&?c(`|He8%dytuQ%Px(d0KiFi(= ziQL+eD0(8EG$XnyJQ+Q1>CLE!TtIJ5b<3$K^+dcnN_lmZq~+u!CJ`@>DTbY%WF+GC zQ8K8RvC1)#<|2lGh-XT@q)8$T6$_%qcD~-gap&aQlId3OWv7?%~IeLIi z#{7z33Yd4$Hr&49UF^|Ca~^BzigS1t&$oI)uDR@t-8?i|-v+ zZ;0T-bA?!Z2G)Hd_-cT=@zWP&fG(^LNIr?+--ST2wqRa56HTD#d%7LNKZ>g_9Tp`| zV0|GGd5#}LP%L>^ceJPLr2N+FL~UWwe3vB1_b~V?7#^XaiM67&7 z*)N6iu{VaiXucc3bKOin$IYN=9dMhPjejou^u=M0t3a^x)!C z>9=YJ@_rKG`qJrg`Ra7nARk7fW&+fFQTnYp3jLm%$tS)JnoU1!zGvyT1^03E%OUy5 zvw7)sqx8!;3XU60uDJTGBb$&e`eJzk>zH=^);$Yc+phrkar9gFbA&yQpT6Sg=b|*P z(@cPxFUo%F+Yt8fOg_;En$3Q+gOI5o`DPsba$N|!20wl2bffH-dlwiI@W0%@g706o zFhFg;3f$ZD+d%SG;79eN5WhJ3ZFmr`Gd+)ReZ|qQ=youWZS! zH?%*Oz?a2N%>=0PLH(L7AEh?{CtFiK@N6qyK1x4~w#|ibed%|FgY7(T3-05xA! zK58z+`vmnd_^|G5*KhP=z_osPxQ}D!(fbj$2tR%4bffeeeHaXrnh8+zMd^pvoekp$ zG5DhD(LqWx4L`EqI{dVLQSI(Q_)0S6MPE8yJpV9t!0q%G@sDKaOW$7%f{ugR=?B4v zpLyx9aZt1q;PxGd!AE{Yzij+S9@%pMzXka5b@}7C(fM%Vp7;pgi=UnEY2Y6GD8Iy` z`5JL=<2wq}l$VTq%@-x_D5at0k#B0gXnB=3d8sx&s+ab3cL1mSk$xmw%Zuh~v++^< zczhSy`0#AYIHh}Le7<9(ua>9%p3;a)_t=FtKGHpoe#Z{m_^2(5 z$9IE`Pxq^oZj@b)-31!aDIW#+#gq4GnDb%g^Tg-7j>^o%eAG5*d8=_x^@XqNpr7Ll z8UxhzlFG)$cRkwX^wAi6G@!TfeeePBbVu`TEiUy`xU9=tT3J?A>h+eDyIdYgR{!zj zq`Vxo(&DPhQc1sX;pP6O2I0_ZL9#IN!D*%z49I`mOpd^hOcOlFE&eWy9`#*eTXH9O~Q6|KDwmg{-&K*8gF%wc&XKms74K zZZX6qOEMPY)%jGB>PU5_C8Z^&rKF{%rKK%MTbP!fx+slW?Z`0+xx?v@k!RP#5mOH{ zed_b|<@RM>{LbX7lCE~X%kf@z!l$^d@_BxVe)sUE>ZvdC%N#?Tj*6->DfF4}$*5HL z`@fqXH)ZIY?>ofVDUs{B*h)*c-jZh^C>G6o_}7c>U+e)!AKfUN|oHg#nTyZ+)1 zyCMx(yR?8H_JJ{S&tYX)`rjdaC4kf;+p#%*j4pkL~Q&Ls~5zfP)IMXtn3sSZao^qx`=<_W}EsUQXmnukebH}AL&XJeE zqH?{j!ygK{avQ=uE|=F;?D1CQqCi3+TIZzzuV-6v*|xHBMGbb;*MUl9hP~Jb;m@Fm zSXEW(scMoz{(2m}&1`gUaiOa>IplT(bV@ULr$%VMP<+9NHziDlwvP7tKtqE($r(I4 zXaeV0jP_#(-bq)fpkQl52YnW)q{R)0`drL~&&7}ke=bIGacg}r7D0&kWGo`Y z{AetKIwOn7AEdK}sCL$!Svah>uf47@R2~dzW;>Zg;Ph?FFp{~Wv9r0>RWgI_D=&?~ z?V~t2L!9(A4cyk=+7Q6u<57t=_15?92_IuNGbQ-qyadpIQ&@ZbE zbAyKM3VlsYAzv`)Z||_kf#v{MoBX@|O>9AOriL~t4m)V5fz}2+^OY;V&&+5xt!j+t z2zajGOxu`d?fT#-!iUQ0TXwU$W9tOmuf%T^on4MWz%%&=3Xs7Dk%@Pi3e%(Bdk@+hT^8 z1djKvB%!3Zq8y|tkl-mq%Dc>SxT0TOP<|RAI5vYq%-q>on6n?OM^rk#y)JJt+RuwQ z8Q_!(DDU7@Kq>Z?VgO%KUJCLhoCL^L5>>^;B_$Qbo|5v)veJr*vPw?{lDM1leHfjJ|#csZ9EOL|;-))7&Hs-Y!LxMJaj}=2@TblO07M1hP7QWsJ zU<23ZJ^D5vyB{S{99}xv5MeUTezvisS4sYsds}}4tD=T zIo)msb9qFC|BD$OyHxHl!xJo&kC+kI6>ZLZ+zeyG*bCsJW?+oc`Is4K8fNyw`Gm41 z+a=oB@3KN!lZd)-w-p?#obIuLO>It9OrNC;U^FBf3*0Je8{$hQ9Xc`{J41_yWg0R9 z0!X^j#1M~B3{+BXcFd;M)->sMXJ`l>@J*8+f^1E545ya-Psx;J0+A77wFFZ#%6Ekx z=TTE=%iZ^^fXM9qPy_=zL%xpI=0IJnmi0#w;fQPZlot?qK1LlN+YICQmDp3)h=cE; zgW))#5i;g)H3IE05c-`)A%NS(KZ!k1JC-J|a7dI6uai|PLv_??;b(}y5&_O+QT|30 zl$u5PJ5k^=l43RI6#b}!vSJF9eICeHNU|kX(~n8IC0x_5lyoZz(=92Ds~t#!3YOD1 zT}O8EvLxRn$fRY72r)&>cN>x!D*}`)x{^c+&vJSPy2p(q zNAkn~-VQO6l9Fj|gH;!65RxR)%sCNrr`aOi3w8QC zZ8TGhMjO%8C14|(8l9_>u*-ZvG~0=$b}e?Qsbj01YHHf1(xRgkm7>Q*r$u6s$Hi`o zW~#ZzqM2Im*1#LuA#kbjrriO2q$zV3iB^6don(&dY;ir|LU`SGocaVE_J)?h%}91H|$vWO{TBgVCE_1c=67B;JC4&Ju& z1)I?aVDZ=xl~jqF0xf;6vf=0~Cy9 zht3vXQ($L{zg|uaN-z^a8=Iep$pp?DAu{inuX9!H(6b;#L@2u;91WpPsAY;FDL%f29uBEjN0VAVhhIk$5o`wL>L;Zt> zxY9`|S@KXn%y=!(pno^eiSV=`ZUPzz*5++?^^LmTLDb%XaNpEW82i?akK;7(yv^01 z4o>vsc@8(o`&b;8x(*HCOBYw3rxQ88148RhEwpb=LhmM_&8O6~Z+I@6ejY;Gr8V$P ziy?kOXlpw%JdP93#jk+Y?rQ7Eo9-T(3RBtP`={;$W1}czrWxY8B$~3FkHFrci_Lzf zUiJyqGx`~|)QbP|AqH>#6Z;VcJ^OGz&V387IY&o~eDZPHx|Gwh$Xxw*Ax2RB_lGC3 z64KJq-ij9t@_($*4j@IWh_IP zZ8kyG4=0O9v_{RR(5Sh4a3r=mSEquDJR>#DnGgbYK6!Al?OIv%O*%#b( z3JVQ3cTXI!ta3%F_@!3E6rfZY8&|yAB#|+zzmY0laaN&Gs10;*nkt@b5p0`3s}ktK z#&2LA32kKA~xsD{UgT^l&9>eG-4b47UaC4PWXNMuhOa`1TgmBpz*2V~T z(STuQEGf38#^o*V-0Zr9w3?AJ2}Yt=ztm3;xX;BXgB~2n(T%6ma30hiMDP4jnO%x( zM?N!((-$S^L*^&3vAxIU17vUg{OZ9|_>U#^AJKD^?`%YVHsN;``OX<=Y$xeGe!0$# zrkBRKG1s}XCvwTkB{;8T5vQ%(U}1SBC0P?sbazG@J&=<#k!wW( z%`@mCAKQ!{z28jlIu%gaz@qd$mMj@8#>Xugl!#s^urJhmPElZ`94?>M;bC3Oas@SF zs)5lvwp9(~<#yACmbr3NeEYL#?A+-O?Z&e~w9x%SqurA@L=1b^2U-Fh7$G42*G!fsu*h|gzR{_k zp>QCkRMAi;zt|^x{8h-zV59w(R&t2HnK+jz9`;`8 z&?+OD*qS`)>>tBXUK108{YRwb^3)S;y5GLt#fZx7X4g6YkGwAdkF%=!fA35tOOrNf zQrfhn=`@{|G)>Y>_BJUrYa5z0AxT%F!z7tBp;@Ncnkq{LK}3{R7TIL|KoN08R7934 zi-3GZK>fMkbd%g^8cNC&wbx_CX+M?)kmNIKzi;u_ug~PJ$GN;dy%&&Dn2Vt z7X@59jtnYve8!2L#ho?Hjp&Ae{)ABUQJWjl)WJf9p#79+nn3$A&k}*HQ{&Do0O>gy zhRi{`MQ_Uh^^F@U^W2#^A=_H-m|oI&?!2*5X|Ftz{;soU2sahu0iLO+Q^yENr6#I0 zz7Mv$F!94kTWv9BW=?9t6)W7@e_sR>lZ~nWmsalR3l?TVOtw37-^!Kl6-W@C4pBvb zawl&r-$d7%(K@FQ4R-ltl$ikBn&9vKSENE+Jb`SPUMePvhE!aERN#BX>0~W}hvlnc z0B+ZV8?Kce`d8Q@EJw`}i&~`%!W44Uj0Wv*XYK!G+1X*1!lfvb)E-Qxd01#D{8d)? z1lJ=~i&RcB>n>Y$(ydlV0LveGeHVK5`(+0(d8O9vq6{8Zs1yTmdziT4Eq1D6SQpf- zz@!bWjuFmNvjN*5f$a$R;!>VK=f9%B(ls*lasp5dt* zh9iX7#bN@UPq?TJ#c-s)+MC&hvve10PamOrcl&Z%3^>Tb(Ic{DzwF#WM zsX&eRF;>R@kvX!H5-mY8v?QT9Drcr=CD*k~?NIJf{#%;jj5xX0px*3i^FVoGmuiSL924-w|4 z#bCLL#;T67t}nT8^1#$pHM5fmLMq1sDw$VDi$}tv9!Dt0#M6j4{_inU! zCM<#uA2B0uiV=TtoGjm_q;Ln7twW37K@`8oW5m0TMKYXB^d*tX=_LsGUX1vv)6+2! z+(-I`@Qjp?#QUqU;@i$;I!Y*eB_=fQNzBh<#n)ZSy8P`!_V8V{B~jEPnw86+sM6;R zQCXd5wm)pb?EUpLWwhUFj=EO*l#0HfUjuWR-C)Yswo<>Mc z)M{m7IOUHlO5d2%cfNVF#&MNH>MCc7w7Gf{cK_6dtF?~#B?lHV?{ZL@WH?$@tgUFM ztKZ=^9N!C%U^wr0IHR23$3tu4aYuDceQSm9i~=tvcw^|%(fR#I6TL;4pWx))6F9t4 zO(&VLG7pLxI~3F!;weW{ox32{Tj(uXlV6Neex++l)}Xxn)Io=zlrpUqSnu%BsTp?> zt~3$P+Wa8a*Rrv$wiUBPJcQx)lKAKB0lY;zfVWr&_?d&Zn`lKnoW&Y&__>3HVq=xo z+bDH;WAZ{ltO7hA?kkg73ZGvgolRSC@K(h`oXX<7%3@5-f9H@}yoHnj*feaZYpBL1 zFr7Z9bLDbBSZ~`J;%2AHpe>st?nU?O-RN65oVg+svcTf+-Rs{s#Op9L6@SDOoQVf~ z2IanVs47`mG{aQBi14Txf%ey0T6MI{uvjb27>_x1(i&@PTWZW0S>vKuQXXe1#f6%G zRwishrw`m=3jH^NHf`Ei*_w$%^4@IxlTZH?ASoD3Q!KLNO6j}OjfHXyP>~)@S0%3& zKUzHxi;yoPC~hHfD7+f$!X(cq4O%N_s)5BVk_M-q>W-iRNvC)#X=M3p(g0@w_LO9f z=4Fq1vq$r@N5@%!C=;Zgc!j5bRHeQ&qPb|8AFAxAS913jj|;C&6&4;GpiO>ZSa=nh z_#dKyJU}U4Rr| zMNkvR+*vr>4T`n?gSGILZWtIL4RNm&)-r+%FlQ(%XX?W4lftGZi4!IDpIH3|BHGHb z)T$6u*?C$fI26$Y7LS}M@OX55$}9#G#<%6eGbQzn+kEN+hMhRP)417(H$`ij(N4Y) z!E1Y6D|}uqsl!pp#?AFRupT@?>{liWBiX3$9Bz9(_q5slj1rGfwZZ6s+ex7T!0~In)sqHEw#=M9R`(tdSujIsYb{ zKXNtgDZw-hd*a6XV!t!F36HcXT+9|1Ia8WsHJ7{OX*iGsoT|FSSBcAk%b6Xu^%%Z? zQ(Wnst0;V8?S65sGdb(ej)e4(ulO9xjCB5R53gT4mPMuOulgh!i^qkH7o@UXJ%i{s zp>lsmz_+Ia45s7ZJ_=7;bkRPsC) zfhWFYOcuWpPlM;tNqL?f$`dH@6shBR(yP|VjuP=ac>dItMCQafj$OD`T4r5{K_jF- zJ>=_0<9)}n1VajG@4+f_r?105)amQ&@=9C#=t=ct$EU>K<6Kz}MTZF!JM6+DnI%-1 zSbH2{WG%-ranUSS)^#y52dtEZ35#T}iIX91<_w6-!TGN-v1GGmyq_iuZyhB91oJ^_ z5FF{|Q{TuJWgj#IgFRzb5mY=M6rYKAWjz)<4W3aOh$k{PODa5$FFvM9j!F^Ng6~an z)8H#8wtS+6}98A+)MUG|B>6?PeKOucnk8;gP-_)sGNlI+6r_-{zOouB)Ts+5> z^~-pVl6lOO30IVo30JK18}WF?+%EG@ls_dC{;5hPTxm)sT<%CRDV?rQh$|uUCkaZX zNYygQrDT#T)_F$)Dy>as^kOZO{FO{{DVgMoBvY0x*L&ht$h>!-#OdtpJ#m{LgefcQOxTry`G1nW_WE~83R+7?Iu_rX1EYb#p@5z4Ob@p1 z?dk07MNN`vN)J}bfUSP)Y8%P1FH%t$Mv$t3Kv%;+XHOSS1#3A8%(d3vF^m(lbP5h_ z-W>V3xTuqjQU?_A4f;EK#`3KKBP|oVK|BZTuSxlL(>_e^!Z5w#T;fgWeR$r9(VKg_ z6JYf)z3ujacL4N==^_kz3uiUy=RSx|AO8>T`=#2lyceToQP7MKF}X%-^UeC zwxQh7L@e^M8H>*m4WMSGFW@EwakA*&)crBjE?)Er>sO@}%OgqJAy3K|7B4V-R{U zl29s%vn#~~b6r^%r%fhw&aCMQ6{#7?bD|>%m4=@EZE*#J{$Oz`7yo8l2rNw|`)}RQ ztK;No>7&A0deg&YHsj49?Ks$=v*%u*LUNZ~L4rxFw1`QVRiVfm$#WiaESrZ6o9%(} zKak1~Qd1wAO>?rv7ohz9CI3q0sYM;9JP}Rh6F<(%Uz?GfxIdEel-+Y)6AwZ8!|uq+ ztD0ZAFJG76sPu7}5j|06#7rYIsKpwe9uUp+BsEcbGLjQ+jF1*tiW2V-FCr~>Elo{t z!SD@`Y3)xZ!BBP0b0Zk7dY?wSY*O=^`1?d%v1ZG;Dj>+0;j)AC{gejv+6D#wmO_{k*D61!4l93!A8$lsCx}1Ba_!boUxo3(B z(Im&r12rfMRfvXZrgf6H*%V4XQzxL-XOCJjfR}J zw)%tSL>BW_8t`>tO^1htm_XBXi?CQ#9%vl}N11yt?+jQ)LN?FI=Zg0hV${20iZXZ* z#4=4=)ldJ#oQ1I{~N+yhbH z$O>Qak%dlY#!2}yYjla@N*Hpv7Q!dcQirN%))JFkVZtgu76;Mw_+*uvcU0Vw=E}Nq zRrtzJh)^B~nnJAtVR7%kOK6ag-)fa_nXHq1;>VEiw-Y2`2=nQ{Ktw?gi=RW#ud*ji zid+b?YAm5#wkJ;tEfCGm60btS!#Uv+i(D!}u9FP;GBcaFnZ6iq>Y98h%HE||%kzCk zTSCJlY1FQb4}S#VFI^`-7PVaQr$ZIsk9*y*1BwHE$3oe^fZ+G76Q7D=_8i<~A0D3A zA6+M|j#@z{I^@s`oJFisg!qRX7ZkAw|EE*M{ZT7vr&u-*DzQ|ocTo7Ae#4XOnBO@x zEMc(OYC^2zpfa>*8yLal)i~BR9Ow&TFGE(F9k`=M*EqPDMyKwu^2B=`M%iCZ6MqiT zfl{b-I3jfrhm;QD&=hnyG6NlcuwLBeT7d&rEfx5n9O+Qmp*|`PF&p-q+R$A!_*Fxa z*47``)c_@BTcFculpUqIY*@*PbkjI@>;ws{C1`;(x7H?FE z+m#wK=kb+l@hz!FMa%XX+2YM=@d(>uh8(_LBc4;1z|~_j$&SC)h~KdtX2{`7wc;Jg zpnTV2)JAcuQn0>)MeR`a&#H$C9~$Yiosw2H(kOdsqxhN`e8*dycRCm;i*OzBe z2S~>dXg)(DbWie%6)ouVL@HW#ODJ&e=tL^kJffS+-l!L!Ua>+)r!f{a*ofXo(Pa;6 zi%xxqzoUaXW!+zbjq8_X_cVz6ZEVage#JeK4RwNcHb=tQ93eJmm%q~>?mA^TX@d`o z2Y0LanM_8VUx9W2$JxO;e=pX`*xeo&_8Ug|Q=7%3A(3TjC=oI;fQ&rf78!0Cxh*(2 z(1|;*Fl9o|#Rwe?IcAi9x=~z~DRt`UAB~_FD@S%{Djz2>b!FGJir2Dag$+IQVpZL&MXKtCjHapP%4v9;nuE8g z^EGYz;jvs=n|0oX>ipehpW7mCT_x*$s0LQ;M+w|fEuRL3S#&?6 zPx#m?GTH+ug*roO5KyHQ&$;3PIU-o&=QK3rTg6Ke1)J>!#>Z0=j248f5vv3rQG$=O zO(6J^ZQ`nInfYNU)>9WTFh#kz|In7;7nIx=BFf!ils&jj+>*13+OwfOgTvf98;?>M zmD2*0;6_Y4>=u1g80CkziM*)s~ zaW92x#NJ8(^Bp{U|AueW@(v&2sEK$X_;zrBq8nx915_OAmi3dxs$Kd24PaQ2kmON zQS?B6r<&Oq<#(JZ9u8GqS(TRMU>g@S5wQBjRZQ_kkg`_Pf*XKC4v?iLA z`hS`&-};caeRW7NU|XU>!IT3tGG*>NGc_fScf631ocmV!H+|xnP`#8%CsXTq79D^k zWupF>7A<@KEODSnb_?Oh{;ZB6??TlvY$tV6ci7tv+rX|3*Fwn7pes*x3SD>voH~at zufolP!);^Mf?`_RK09J-x7)^WHV@y*g2O)3)vj2zV~_-TJGyZK=)f_soSPgIn~|J% ze%Zb4;wMG2qX|!w)zx^5)j*TdWE=}g6OA_Ys*D_UqCXk4TKIjIllnsPltVV%3E`9g z5eMsdX`@3s%>HnGTfcdvdI$Q(m_XTU9pZ-K$SRwil=roXRUS98g;u285v82jQAy=M zw9;Tp&crH&hu)8*&uzMn_x;ZdpJk#E1Ao;+N<_zv=nUeOF6v zJS_YRn^ImCQ7o1ks}u44^HNZqc%Sd2Iz0Ij<4+1jCrEQ3^aqBZiTvofhvTi$sCvt}rM? z$x%p}Gd3RYlctc99P={q>P;FvPm+$=c0}bRb!oNz!9w3Iror$iXafl4F&k;m*7i6ylr|sDf|IQ=tB8@+nME;qw$i zF}#|NdY2+dzk(El!lC|=!!U|+5p!)~S>l>RXY6SSb@P>NibKhYSYi=3aJW*7q@uea zbxkOdNNX+9hWSJ&vj{38=E|WY!&qk#Ho#V=TBxP!dYJ6AP!Cd;$m=b#QkRGo7SYB8 zkKk5@dPpW9S6O6c0%G-I7|o0Fn2da=QHWvGTGZ`{I}*1cl^YaEqZ^5tj#prOL9ty-;#;#APGk4viSbPIf}+GnJD9v?-@yd`O2RnIG0j zb|RrZMxzNiOCid~uMnbR(Bn-~Qahv*f;!1TVglqqKjD&K7Xhm1-7ePEFnZXDSZ6Dz zVeHo4#J^V~N^+kLPk#Nxkm}=rbbtpQ&88afh$Ca~QOIctAWBNYnoohz2drr-_Qv2u36(DFCa&qmRuVeY-#eP&^2K~ZP^hYU@~$-!dG zaF4&&os-i);KLOI*vji2z-5-$TO7gm8!pko{rA#y7oA3+6K;L}V36)c9opB|KF~V^ z-_9OC(2-yem%I$ETeGIXn=St-E-u6k4>=vdk#)EleK;_dgLmz1E;3?0^m3d;kfOi4d31(W?x==8}-cUP)E-&Z8qi(Am(USpl_fv zu&!%hup=xxQtcM2-l<_*cr11zxvIFfSy9iE@ zd~b1Hezq46Ss~06Y(RI1u3Ie)uylsr^a z+hdQYZ+%^O_W<9x2Bw=&9fMtNW#MU!fprsRgYkVf1ifPjj?e5vaE$ol{kHI!UBzc< zJj!_gE#PzqJN=>%nD`|tRN~;LeV=+l9txi)`< zqaQGTZr~Vd&H9z5DE(&b(Ks#+&wc(H-WlpjX z9`d8UZ1YEd6xDCTVe63;Pu+3;+* zuf-pgAM7Sk`8Ga@KluYrzhU_={>e}{h2cm-(|@9I^I{f6J?mfJ5lx| zT+h(Q@FNTlGW;Av)LR)Ic98Ipf~Nf-uZ-;Teax8&YP)_DMTGEgqbS(v7hoPrIP6hk zr|-u+mhg{buFdr2c7N3WHH3c^vvq>6upVzJNY#V%6G;qDXZU%BC_m)y(Du8Y@h26e zDTquT%Cm$c3{f5>{!0a;mNG;eLiDJ83@>HK;iEWw^tp;2{cDDQRWRl>hD{7P|6=ZD z9Oaz&$8!G1wldzu@H~e1GyDm|mlTXkX6Rv9&XDst?f~OYFx2thR`@JV->i*{U%>E6 zhFmUY9aVTd+dqCSn4QLWBg0QJ z{2{}CC^%;wL$>dn9>!6=i0_=gE0{Q&;R=Qo3{h?=Tq4^i@ny#UreM-shLQkKF` z8esU0g7Z0_=5zS@oUR3IuLWOH;ZnJMOWn^n>$$K>;S0HZFZ>$gM-^POm?4*!MNcdI zxtuKF{8@r_OvZbHA?NcFuHQ@EP;_?!!<7t+8J^0pl_ASS|xcgSdzsQj7 z>3*2;w-~<5@O=fBCNV5xSjLd^XDQ2FI>z+#7+%cqa}4iic!(jVcj+$}|33vYoD5On z$u1db47oka;Py3x%Wnpk-wZB487w#BGaTsGy83Y=QtR0y~?R(yp18} zPtL~}zk=Z{44-BAx`MgPCztJ>o6B^zckX7!nSbu(jDLaQgABQy%>5YLgBD+*$#UY6UuQyHGFpm#3AMGQHdm+j~MG1GsmU_O_Re6Cmd zS1YZ#hoS#VSv(c?;~2k&EjEhyCq<-P(mU*<88U=nIat_xt;B z)l;rT!!~wbz)qlZR(2ehDi0_e3#r3kysu9R=uoSqMlLNWVjb1jjgvw+)}-z?-ZdD^ zWvTvlypcJYyK8V@B$%7;tLUTKO?|!X!R}3U!@C2Xd>;|=@@z53tx|R%;+Cy+AFt0d zT#`5Rk>)LV9qm4kyrDNNqS}5%guUHG6rtYRP|;lHE6FP=@of)}U#G~VyL2!4`SJ#Pwr;5O*6iL~p>Z9*Qkuvy=GHueed2rZ+_`S(O|QV4jHGW zp59sTjd)J?f25~*@8C$6uZFmUCZ!XrqB3~t1{r*KxTtblUwh4H9 z5OS{9V7!m63Zt^33L7>8sMw4Sb^BDoft#Kprb1*?;+3V&3jN^jkjK-yu>r5nR*V)j zcv?J7HJ*yK_4)ap?Q843UQY{Lbu~3LUQgXN4=zY<*;?#5ucdWU)uw8NmH^#Y?`fo4 zm}@*Wl@+C)=9)7~Jx$FuEv23sys$Q!Z`Aj+dpyl}9wjg|?D4=_y*=$nlRw~Z@A35o z`Z{{C&k|nnY`MwF(sjtAN{$CvJC&jnY9o&>Nfdo5MQL1gm3uP!gxNQ)CUOpaFx9P6 zP12`QtizO7Z%JCEoY+jIm`7y8rJi_9rPzn@pzOBtaVqUa1O_3SN*$!hR9Y%#M6K;i zO9RK9QBja_t)x$*2+No=E(9ueSUWe(5@6#ov+S1)W}NqC?3rb}uKFk^Q>pp-6;=v9 zg_=IC{>;inaGy#|4zIe1HkFzi@_H=dOr@q;*@FmEshJcZG)E9|8a0vnu9?f!Mjs_L&J46w|O+{Xzw2O&5gJkC@1@`dBQ zFedZhMU8P$WRq4p0o^;EF0*aT1oQ~}7|IQKcnBvcI7XngvtV76OA^s)C`p0eu)*C{?VP7FqI0NfGA>qn_d+?`!q(A+z zJ|M$M1pk}`6l)9SPp6?C6zwKw5dTnI{nLJ7`~=n)rozwh5*S6|hjmB0TqmWsS_`%L zg@-$5is2qYI7*xTO^}YL1Ozy&0|8DH4(Sk)(h+9AXiCTS2>ims9YC1N#)orU37Xac z&X_d(15<8+w(V87UF;IDtoPv)gfZVKgD zs}2OH!?h{5<~I*@!z|g(`K#qFLOP6% zIuM`^7pC8${m}2J@!`Y|L9^+H%l9n(R>3`ie(A&?X*PdaZkT@Q`w`-R8EQiPmXJ+I z7yV;?0_&J|{gylnT-z@j?g{i;@>}@5f}^eyj>4PKwz=W2e_C#soy#6VfSYw7KpieD9pz`?JVAAYa9DS?>o@RU zz_osva8F?8fqUSWfIt1ya>Mi+cnAT8bs#_;E=)fhcQ%aYBZLd9M|((SEdI!TOYo=l z3u|}xpsctkE&8YBV*kU`0nX9y;2+|lf7<;K5Of?kNAE{4{Fy)PHwcO@1aN+I4B@C; z(O(+=h#%Rr8-H>5@N@*> zmx@1uk;ZjLS7GPrH&{TNU)9Mx;hFHG*oh?mxH z!6f0_C}x@PC%Gq29PR?rSM$^5o@9i{z2GccIMRIr{Vo`@g`>7?qHqUn;dH-Ba>ML$ z!52XzI;A5Ue-rWh8qE0+hs&Ed++~z!ZVpFngXXsoZmKW*yA1j{zO6ApT`wtbY~e0P z+Z<0k^-qVR0lh8Ub;QfB0|Cl#tMd!u98|CbxrEh*=OP3=ug5o^%|v{tJZyOjO4sh>GpZY4RN(G z&@OA^dT1AbcFS42`0k$CQl(qB{}tnvTl*irRf=ZK=|)`xZ&L zxiD60=(yI=ZNOHJYiFg`fy*feXB{^Fu=BdaYlVOAwTb?XuzJNc&h+(%Q%_$~dEoiH zOylL0>l{nsmL$jg;IOm1<*ZGM;}$0;tv?(~?(Qqj`c(RQZ)|>Srt!?*zLxU+H@la1 zXOcvfZnCDd&0qfzgpM+m-Al>;hhlLKGy8;i&5zi<3X=(0mNz{P*8~ zA4M`jmDngTo#g;|y(d0F&+Ry2AFrH<2ji$-8+c)M+}fDd7i($l{=$;tVt)y*rO_2_ z>L(*p8%Q;HJ>Dpfo^9ZhQ?6{LdB{vy;s~_quPE9u`UqKtR@K}kJ96hkPO-@0P~YnQ z|88rnTmDmR{ogiQ8+j<+?>ptv@hU@{Gbeer5o5%N7)OjVHY(N?8yy=H8yg!JJ1aIm zCLxx3>CiDK6^9eSBh#*jBcdLrd}_=2=a^HGviIYzi=r-ee!}q?QIXQ^cx6_~M=Rnx zQa&n!JjL~v-*PP;)9rD%FE{ztqh-kguuk%NbIuxUx7C9n*3+>t`dx9;vt0xK0 zv+>v5gIhzpO!VX)d20~+ir@AGYX;>TSrl0Ou-m%N2SLORV<+DetRq~tQ$N9=DI;wv zNY%(7G?vu1pu8W{adum_<~aSD=|JF-R|)WO4L7g2FH9p ztTP+1obme3U_16!=r$@spWmT_(B zp6SH!HB=|(63#D(Xc3*_nlmpt1^?k+*X-!|_%|VX5&m^LWo|N+?x_T-znLo;onjOkB#;^KbkT>`lRSpGRBXL=p}H(IPW`O z@^CrNjjkfXd@zcMz9>2+&3P`kz|)Pt6$_l_M5ip4QsbkyfZ@nOXM74XTgAM#lj130 zaBg&+jn{nO5KU=uMz2K>qzy7CFlcGf%i%!Mkd9eIMEo&I?|J0mazSPCij7_eNcyHk zHzWSZDbWowETu4o6p#W$bb53OM)!KmfwchVxdsmF$wh%E!*Q+$ZgfmouymgL3f#1E zDISFfRww`s2S#(!0}cZXi1a`>`4e{_(ANxch9&@I5)NeQpTJ>6@nu6aX#&u-_$xQW zmhq%k8;L4qsUfz8kq~j4MKZ2|`#M9|B5IP2y+JD>SBLPD6YuK`$3YAt1lm|AB;6+K zpk(Yk_~rA>016ow;(mJwLd>7y;W$`rvXJgDf9Jt3+Brz%0AhUEP(ES79S1=$RW?1@ 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 z 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%0A^9>C^ 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

r5LKQXB!BZ*B62{`S;)Uf+Re{~e%5ABb@+ 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

GgFg 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

4soG4Q8yoI(9mZH#K2Q@ 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 f>ZIM^Yz1RAGi@|}F4HV{*)Jz!V6nWA^}w)635 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%0ATzstPGzef9op=eq8{vS#_* znU(LWnKQSfa=WW|!H2zue_u^XW&hj~!r)$B*}vexgRibfB^Gm4eRqjz&48@V&+T~6 zzKePcRIst)@@Km9Yrdr^sX zn&0L$xl!5h|1`b}`?pJz;{{4o^b;36?%sj^U0(WwlTeHo&i)^_SeFoKH3Vk_irJ9$ zn6i=*+%wob)ZwRB3hE6UKahBZiC^6_ScOw`$Q$L@F^o13-`nCVSosn{l3v59w6*>D zgga8mDQ~}Vr0jrG%5|i`r(}mbFiSE));q0(@;Gcq%67glQ>jpE?BMG%l?t`s{kkS; z7DIe`JI++Z0YSYoTH$fsh<`+@?Q7d*r?s}_Nkvb#wrfX+c64e-n+$;yXK*$S6ojKg zJ3861qhmlFEDVK=|J*r2R>rdn3#i)hv5xfKPRD@bK3tOj zm_g#;6$q5#gqfd!G$?Ht2w*!4JqQ2-mb7 z2pz@uN=(y@uErZx4@7S%)CbieOJioD=b*lW9$`$cK2TVFL$OfpMICyl_e{2-`Z~98 ze%FW*G0E<@n3TBy2{H5LIxmk&o*P5h9H$3=ozB=~0O9Oe2KW4Aw>zd-;$KHVIA%Cs zzAPr$`5S|fSZ7wu0(ZP~>~e)Q#Vi0*27dGLn;Z>?#zc9*j~>Sm zeis{}Q3Atpi6PEYKGGL64fy(seD#A7j)4z`9EY&^l|CGTx8o3n?#AyjcH?E+@d@Rg z5N-?nbhs8HQOdE8 zibWx2G(H*LdFXz-p!@8CB%%dLL<=Ise3TM)lbK3>-Y)wdyKISQ*%HyR2{9j1G7omG zGSjEr+V(`(HiX-JR5<6MuiE33h>lYtI!;1Do;*V!yF(tADkw^_<4~tfBXVnv$gMSk zJLE~RWu?F>c$L4UIuP(?)CAkT-h6LCUVcdin!-SU7N*G~Kkux9qO*$16t%gfsuEOm zmSB+xe+W;+va-UwvO4KiUA5k1Be%s>m{($Q$OEogwl`8lqy2OOJ{n{VyhVA%d4&Z9Qd$d+ z>Z)!DR5or7R5sw8fo%btlA!{zR}H+H8){nUz>HIPgdG^*#eo5cgbxg$uy9&O280ko z4h;zLF^>%hp-xC5(g*3RAx1rx%gh{3kiV&NL!h`hpqcGt5`n@o2#2zEV5#)tKL#w#}=f*RMRNM;Y>D{tg{Qm(R)kcwy!J2dh96Qq`VRb=CF-W5z zq5Kgk^Rm2sC0*))@_XQe>)pu5Or4#DIlI8RU&Z6!=EZ3|hParc0Zy@i@_vp5l!E-i zlETu}#f2bW!cl;1MNw8zuzGb#LEh@((xSqWlA_YQ5=3!184_tB2}MPQI3S2Xi2%qqLZ518w%3Y~)bm-)!@Vlm)lg{7oHBl@Yf|y=%;Tu$MpN)9t1==SP_T z$4&ppx$+6qe~Ov%DKh{UMO$IM)AVD**fZeMre}oQ`Hbml8fNm$`K+=f+aY`UKkfH9VAEZ|huHpI6~I&@?@ZZHu?WE?U8JV?6I#1M~B z2vkyTcFd;M)->sMr?(d+;0Go@1lgMA2!&emKP6+95rhVa)Dn!!AU_p)^hiyiEp!FB+IvwpR4?)6{5Be@E|V zXAnye`V$8XH?7$ooGl@TX0F*&5n_s%?tym`CWR?k^teO}zdLnww+&%B)IHpd?XiZ- z<)$|#%)?u=pf2Gt-?W%J)+Fd)7Da`(a7$1lyh;OfAHp@F)Jqr&1fhpTnM6?z2)$FB zB~fHQp`R1w-o{Zg?AOKF3gy7x7w0IPLq8+dDV&49DEv|yPSD5A+B*LAHkzr$1{=}T zrPf9?H9A*CVVC)JQEw-j+HJB^O&uHTR8!MN6&GCrt`xmfY_>=&@=meEqM2%LwP>c6 z+c*+S-ZSES8;u3xnlO{YPx+DWG@#DO^aEZ)2O?Xl4 zUZRR1O`od0LyG~^={;Z}2DJ6fwaxSjiWkuh7}xsL?tS&LS+8E6ia=|wM<0N-MMIQQ zC9bR8R1HE;Kke-|L^%zc{Viyd*^8!&dpc|!X9ohC8u0xBUK?r9i(9sPhX;clnYhI> zI5Ilak7mY?A$@ao6~&`J>cpEs=IC&+lSceF*>7vLe`C1!-eB8q^2TJw=1u;(+Vz{N ztK_S}YP^Y{jm^r$%fw(?$8OA9P@yJsd$U%+k3yY`q^U5(92Rq1ubl2+Rv3d0ER+f= zd6=isG$g-ib7c!8a8&p{3-|gM;&n81n;IJ7(LXR~h<^axT2l*jZ&!~YKHwyjEV;J} zX1oSybM+RW!@)g7=)KtNXR2hMP(Gob zQHu-sE0?$VNXf{H+q5F#e4P6hUU>`;7`i6@o^>hj$vR{CKZWQ=_1_g7!TidmmZpX} zxi3#_x9)_&T94Q+wv+jHRSxuz4DlM$c1+@~`G!MWj8}f#_+o{Zccoy#N3li@SpHXs zxSARsin+G28S|$yp2*Qk2Bk-%QT|1z_^1x*KUGl4UR`S)YQFSRa>O||v@=8dPY zP)~i^@NUa0SHy}Jv>K)WrOM!t;?*Vz4O#yESn;~E42?oXEfz+knN>L1BG@h|Q900R zE&Ph@t?KfPG~G4IzR?SeI!he1W9u6$8|oV|1=>X2qchFna%MRBHiqkD{Xa0(c4R6e zP`#7J`o^6!GsmS^va!}JciNh7xjLcaPt;XXNMuhLlz!4d+F=1kpDS^nP+Fk{$Za z6QwVjVi_`z4vAcPY-K+ah^Msyl}<`^3@!g(vWSW8+#&%Rc z*GdUs&Oj~`yxaF$NP!NT%!xvUpYbazH0E%V7Yk!wUY z&M%S=l`Y!iP2bnhH)yLUZ(vdSP+jH>CgY>#401$I6xb)~^G=arh3qfa0I>uZF<(Iq zdDXz^9mn_wGBeufp!5v+hJcr!4gM|FQi-aD%@uXkv`AE<#W!LZY-++WE*c)8caCx$ zwx+RqTV-`4-Wtrp7ov_CVuKDb;l-;q)CZ-r2HNP?vIZ;lA%Y{Nvm0$xT?@Z5nbQqf zE0)vik0CCkY+&Df?@DiGI16}o!&J3VB@6{H^M*T=^uo%og|0S+c;0lQp1ugAyKOko zj`Mv+diqHqCg1)hHf&yB9oT{uN3_sgy#s9{xa<~pEY)tRZNUfu@xN)Z)PY6LgLDpz zw)Y0Z8Bbz9O@)gl>hA&%QxTkBsv|OfICnxvXwO&S4YFBvALEfUM1gtP!#CX;OGN{n; zm=o)jJF1%+&c+MBr=q@PM2G6$^|y)GH* z8rE0jc{6iDmbKn6y`=HHdHYJGz49pbH=RAhxETW%MNU1PIz&h+HBqJU9f;k97e9=& z)e>W7=A|yz;1VGwtkcMka zhW|Hg5tgH7iAAl_1z`#~Y6gS$cd_>WYuVXhmck_{l++$frg<1Q6#frZ_&u&isuro7 zWYJx=>ZDt(5C+R1dVLFe^|#3mVDd_>+eOJ9R;ZK!NPC#14Gi^B6~nxsZUrW7XmyBi znOY3Q{s3Y}As0s&20Q;Z3M?JBM-NwC3!OaMEk4TET6yShU+-e1&u1K>-l>a4~J~TA~yXKB4{0*nL%i^YvOgDczn2bavX1{Hs3Mmw= zfdKBjHSRRZ|C1&j%}8xxv=kXRqyR>j@{&t@)slkN(9}I*NCV5dJ9> zmz^>Rb37YL1Iei-e*$JP0cpMBViGa!Rap(!Cpk0Wd|ca}IR2p#ipRA|nHWy_kVW(H zE5L6x&2il9kh;n@MOs|_Bv${_f~z%;`FRH>GVgUznj{}hE7thyYwNaq4aa|m2QZuu zI-D-&w{an`c-&D{UDx6doVPk3FL?XVqoectfhOh`;r#?V_nyG!jVjt7jhT5+)YxHl zjUk?LG}d}o=jIpUv-E;u?D8uuD=9;H`LTmGKPhEe{Fv_u(5@M85l(g!Ke72C+CcM$ z+L{);CE|iLZ$3r;Q#(U`k!Hv*)(k&$@NyH)sE3OvgM^Z;{T%&DhSX!XZpWab86+Ud?~+kW0LUlmS>YY_6@Z!Xhy3SEr5aay?it z+Zy5yr^=wsn4TZT~RO!_cev_sobhabe_;T$c`2B`b^G zFqJO?JZ1)<^|j^}9V{~})Cx1i_nkUv4K+2*)nAS*Ht$+*=0&LRBlPBk=c3}(v)ZY_jhQ8Y$D&YH>~$$Q-{kn;q|PMl%>sB_;xp`;FH*Ye#qh?|^q z6oq%JJtz)4ld}HoNJz(r&@F9)YMs5-vD8Q(#6E-(4Bf?mW2q~BuyP>S)dj5x_0Xr^ z&q!svdWO(%LgoIBVBjKrH7wSM2R!bqN1T(1d?ZvPP$}|61d;hgkoghuC}iH^nnb1} zB}68nQs&7BGVy78lK5}&BglMdQkfTq$^=R>Me0PEU8@UlIBJRb1!Vr%J)6u4`|ZNj z8#3!c3>qQz>4O8qBhB4CU7Xd9r3r?Nq`e2T%$mBxBar-BtcPsY zgnM~q;gv;@KhD<#NBUqDonD*dpm>yh&=3su?6ZoXlKGIhA>N(!ea~sgbgd_u$lNTc z@C3Q|m@3JYEDl5NCuf|7TtT@VSy!2juHE9(konr_$ds8HMJDBz>ml()$b2a-Dcw(> z^`D>;;is?o;c}$=QB=w0a(*Wc4jfLHjtWe5-Cg8Z8k4?pQ28gMZ|qU7S?L=)m20+& zcCe?@vbju$J6T*k%boR`c%O>%q!}k%E)^$S9_Rh>NybTgoS#GaQ*pvSRmBNcnu-%H zZ=^UWo$e2bn-J&I2`WyJs^cV=ij!O(=iLdYw6-{77V9|4U&To-6(_kO#VN~{`yb*? z#QDXUsCHXuFQY22veNB?P88UczONY@OXU<9;hyxt?N-Uw&10imY1ZI`5=wREIo z^1UgzCpa`5w9}pGgDrb|Iy-x**Hn#sg=B1L!>YECPyTn)K1}bzFuiBE z#jDW!=-l^4Z|?2h1FMJWZMQcS^BLb3*UUx*P5C$1+iq{tJ8o2b273Q^{@nMZl*=|J zeem7eJAI%(*uI}Do@_(8qlsALWg8ivBOXFhKC$5czNFZ4MJ45=_$89^(S;LBlhvZk zR0G@)ThH`Ti_$I|88lhDM!I#okzioS=0rx)%%nN8{eWwsRi>>GJ2k5b-xYsB^oJHr z8vV`GuZ3pyDWX4#NDoDdluF{v3UTEech=QulSMi!?sOv+sToPLVj@H;4L$Q4;zmUJ z-NmU~{OMFDX)@V=>xN!!Cr3-~3Tx?254YKjH-)t05QEO1djY?cF1vyRlUQL9XXC93 zMczo7^?k?ExyZ1YJ}CcPsr(Q%^`Y4`D_eXP${#r6e^YsCQ70%*L{s_153=%yGm;Vy zL{grzd)ABM2$VnSjjX(?`4#&Mboq6ey{>8Vm}r?1dm5QRE!M>JfM}*?b|a-HBPrn% z5z-<{QR3a=mq^RKOH$LDF?>VfX3@Y?rJ<>&rbQyyGEOA8Nfxv@Wf2lO zyG16nvtuN@U7GzP@u4Jl)?*kUPemEyq^zyx7>J5Vm@=v~u`-X@l$rB{vU=jdjHGx^ z1cl`2a?bhUYf$Ltz9}k1FF9r&s6kn%LNrV>t&_CXrcl!PN}*X#W+crRkE9Saopb&u z{u>JY=dy(KdYN5lG>q`M6uh^ZvnOg;h!o<>xYnk{lvWVyL>#pe*!!z)fFs>!Su zF)C@mxtEKtBC7kd!e@MBq0^Z$uRvyvE^%B5?bAzY#s^a!s-9U>Omc<^v;3GGMAs9L zRc`J};_fte)=ewJXMRE=<$<6XsZ}5>=^eN?7BLjGSmj$LYhFP75HbAiJ&Iu%@6*A7 zh!H(3evXKKn>}e#nZxvrncV|7BH)&LC9y2Pg8)j65PZ|~3 zE7dI?LR4SRpFApMFDoiCm@QRu9HN@#h^dkWOdS+YAgb{K8CB%z`A9V{y>CQEub<)0x@z^@@XpFM@gJd>O35^Lh)y%4Nx{IE-`INXk;%+iP$d3< z$o@K6WSliR(^bw;GH6gS)yOD&7ThUr^}4g3FHDV|vdL|h9_$Ye?b@#_I6HkGW>9Go zj|Xm)JQ{$78FXQy_z|K#Q0$!~S`;taO3LJEMDsd3eF!6hL7qJ#_PM5RWR_H^8@bX{ zNt&peY{C~_Ev{VR&bqy15|i+JmA1dCgwp;IG8?+h3ek<&XIr`<$XulxTq#j?qXE>S z4Dn6qc28-9f`|e;60Gg-49dfMX*LWa1KW_pZcACcaEd}zu(xf$9yp`ipwcK(Qd%Yz zQ8}BICWmv>a19T(VG=JaFBg4BT)ott^J%}5Ppwl_ZDj7HHHjOc%@b#xrZ$mt z^xbGf`IUBD+yQNVQGUAGL|8>kpF(~`w+-fO7x#-VE_IjRyGFd?T;9>!GZ>Jop96B_ zLQRJcW1P_aeu7E3S31cxE@nhx3#8m)43~T+3-kha7rAvhXNHNPft6LE!=apUxH!x>nFiv1}ex zVri0RJMs7Q8@?n*N+*udCOFt+H6hk^P{}P?2S)MoiUX)ef_;Nn%aGM(JI?6QH4bj3 z(XKnpJn>qGQU2F+#GgZSpcHByPDmZZBT5JH$P{!qF%2EQyH0%Cy&M~?n*I2o9O+Qm zp*|`PF&oyKTG3tAx2c9Ct+hY6s~$>{!f85HlyR?v-A8_Ri!#PGEw`CiBj2y zL(+m+7$-Z*zp~RZ%75z@zmwAN4cEJuc4vinUF$|yKqykf>>jc%@R@rPP?dj4xG*uSqrh&D*ABi&v|}_t+NGl7f#}tz}}X5Z>z;`cB}U@nT%T8(+urv+W{OG4%W8yVy=wc?Lq8=G1fe_Njw%3 zSf+*&Ap--*z$v!CaLd50gF^$IIP(gxOz627p^YIYjWyRdi0d+?PCfm5BIw16kZz<0 ztEW|iUMCvFXD0}->Ba&`KNdhLk^oZA(CS3e?OToFEhQR5_uVS@rJ1yOLbd8-tu6u- zsrcxX#yRBd7#Jp}vF1DHiNh;oVx_=SX(tieijd4x**(_GWQSmYI!VsUxAVzZ6Qw*M*BRK;_AMmb&s=Tf~c5 zvciV$OR=hM);hP zEdSVMapy`|=R-BHYClSz+M`2e(fy3x;bX7JXb+$ia*)&@ph_ujwZ{Q+M6kxsX=uo| zh-V{4Y_=B|A5Se}v>;>+kBaz&iugopl!y;*6*p(g%nwVkesvK8Q;ZkqAKDW9jEeV} zi1BVW${*S)K9#eQ+Oy${hDNw`HXfrgDqjmwf*bJKVYldG!dP>3oA`B(RJWsNsACjO z;npD>KA`J&S|*VzM!UMOVMg^0btu4|U+yKY2JB1?;(bSsI@%=@cK^aZd&}?;prpek ziE@g7m6oDVo0WGz9)shM&mU#Shkq-qb@)o!KW!TwJ5W@D_m`+V_msOrk9G%W}7 zh({voek!ZZOqs4#*F4uMUI|r5+H!JzPGL*yMUzthFSF%eE)aLE3MmF`OH?SBa$s7f z%zb0Jro{G+XEKs<|FY&Q0dXu;FJ;on)H;<#2VhB=sDGtJ%iq~4#)@RO5Welt>KO7q zpgM+aq)zH~d%Iy9*tOzV2-z8Q<*81gi>|Xm=g^g}aC75u>pp8jF|BpK9kI3Bt^2Sy z58ui{!hX|*`?`qGjzJOubmIijfn#7fCn?sGk(76N`PbXU(?znQ2~U&N)#MkefhMKN zI2n>A8g1%X89C}if3nYN;rClk>I=zJ4%u`kgk1te9IEB1jSlTF`@@vh{>p(~J&%)- z6dNpmu|wQm99d_J1VIhh*lbG$%(GAcqClqN6K#tikFII zU7TQL-Mtmu7F}cXXkkP8C|b#MJfqTKc6>4&&rD)uF%YJ)=ZxedU1Fa3(P;DL%F62I zW?U~~lJG6t=6Zb36TlHg4Nb=7mQP*vru8_7NzpH}=<0CvTHJ@yQn|sn)bhY-J~$D` zxWu9~Wf8xf-Dc`L4I~swwUc-kr zZ_%2C>ou7RWS26r#8{Px@1~akapJbUd9}Fn(B(7Y(UISs?BX@v=fu|y;B@iXHSAUY#as=2g80-qaztiOyL zI1Q741Jcfv4kRmcw)9w$jEIpe*2zgdwd16_j({oNjZHlr@aVS|4ODy7g<}0;GD!3Q1 zmW2|Dbe2V0pF)Iki=YDH9Xpg{7;7!Udf4i03$;{T2a}x>>Osm9d7VX8>Jrg!5p6gFh9e26EuOg%nvrRhAmYc?zYhZkjJ8QMqU) zCplUa%`i64m!)Y-DoWGVR9V)y6-r5t8QEamt`Wo7!A>ZBzH$;nt8yB~1)7uMe4j?L z6A2A48bioVg(#mkg%BNsrTp0{)(+`JM4jZIXoBQ0j4rnXy9iK4?{>4UhS9@Lgt|~U z4P&?VCi%S@Q8D*ve)8)lfm9y{qysVrbqdJX7b)bNgf&2h6q1%gdJSvDFh+`G4IV9* z7TvSfNQJ_C=ZIyVWL#{%Zw)(OX!%U{b5rz#cxT`3J-@JXbx~)*1=KN0LQW1QaYlOD zdc8S0{R06UO@JjpyvYvJn&c>!?Qr-G&dryeyJ!~!?TqVd8yuuFRfqTYwPWN5-_D*k zpreC>IAVEtZCTms{A~HBxVR7}L*#S}j;_U#>LbB@Ik=@SC#MT|^FY@KUCo!1)82zW z7@`i2j;y8oJh0oUF9?Yvh#aSc;2K&A*_YSe%H4SY2kiCk3()!|Emh_YApD-LVBbJz zaBbJXP)9J%sO^U|FU-{!>>n9E3t59Jo{IBwR-={<^bO+Mfc}xQ@VS3I@eCrGA#YJ` zUa@y{uoLlm3%!|i_+%$;y27XJEdv9+XL%7hu0K#F?C6pvBpitkwvX;27{v(r#d!tU z`M3rPJX5d)ojkgBl{CZNfuY@&3&D{^ojrScI)h$4w3%Rw=_k-1dZD#K&E$1>a|WiJ zJDtHn%ppuKcd7J+n@tuOX(-c9-kb&)xM8HHFBmZ|yg9WYpOu?9sP^Oj?Q|Z25~&q; zOtuD8QLN8v2Py0zFFF>Y6$PqQ9v{+*(v+KzqOqr_wJNv=yYHkQ{BgWXt0gx~hze_Z z>)(N~yH6>#+3 z=0iA*F7@LDjxIX>Y)w%5#U0f+4lsazAvpAldqVpoJVk+(K7Je$H{~HPI;Obg+8a0q zzj3o{INUS-X2a2U&G?NCM_)C=v?s#P0e-K|KMD8^HXOsx8GAGi<&YmC`T?JDf%blD}-sG(;0gm1v_8}X8I`H?~ z@C@K49g;t%ju03XH=<;n2^$`kT(#y*7`1;E{K>-uhFpmedHbl|uQ zDtlLBq#g%2&hUPQk1{;L@GS*#YMkU3$V&<*Y8awkN*wV^cn!lZF+9TX7YtdhgXKA3 z3kv5bWq7WF)FydJ^CwZ(3H}$uAEPY+E@mm5^pgJd3~k|Na5xDOZYGB#oWe;u!bynu zXA%DzmIFMIap|9j7iz)_@v2P_@hm0yI9`|uK83gHFuLReT|%^X3*k@syqqA)B+&)R zqJ$`8iwH;AT1F6UfW)gAuVuW2@okLnVtKn6-^=)w46kQ+i2ZM8{0_!H$M`q#u1)bG zJrY818UL>s|1INxQv43^QaT)HJ0(P&kuZbdN`|nPq@(?j5amX~28P>}e8&Y!KGiFV z-_gVPMU0O!j&?-)e}M5Z#y`&T?qfR28R>68zO+B`E0yp(tVs}rUg-pNK3<6dC*fD) zJ>5?KI^MMjf50$G2>wLHXZ$zAHx;DUP-!>FmvAG)9So5_k`DP2-pufBh7U75%J4ac z|4`6@Izr(bSqxDwBtFa#`7CkduY})X$oe|oQMeQ3kNllzb0l2HFu?F)hA1!6|6>fl zzz}wj^hXpl?T7f*k$t{x7^MWYUB80)2g1LBITAblN=zvb4tuPz(+^-;g76Pw0)^>W zcK>@ZDMI*vU@Dg2an|Ei1<@o*{lsjBXirFAf$||C+CG8~ZNJ+Xe^No3CX(qx{g)8s zPQo8DM7vD53-wpR0*3n;Uc-?2UCbYIsiMdHj^S$x#-78lks;?_>=zmTyMi9he@_eJ zT?{W{_#nfl89uAv4778k=M1#760Tv$`8;Ec@h2GSaIY&oj?)*nf$=LD-o%j0MchjY zk7xVGpT&3`!%l{GGUWCq!L9Iw`3%vwk)8>C3{lS|epJDkY=@a?jH4YP|Ct|V_$b4F zDmZH`L$>cMv@66v3*}3~w-ijA$#6MCKSPvT;!9-vB>tN5zbQC-4#STy{29aN6`a$- zklV32Y*+NsQf|^!3~yohB16_IxnAMP?_>C7hL0&Ym+de&pYabdyqzJ-nU|&Tc>@fO zDVW0fl*0TeoUZw7ulb)>e5u^Nr5<3M^;}S?@C97H7u?7AOA0Pr%#h2=!XGJoQ69q! z89v33>vLM7!qZsqw4IEPF#I$_^hcCGi`kxw*$#^@Vfq-uhZH;m4FvI@v5H|0!zPA1 z7;-r|gY)MMv|}>d6AU?@&*1uf#w&{MO<=f!VKKwA8MZLwc)ab5b35+6lks~PvOT>I zGyWHbZ!&yG!6ma97BMVm$oaE`<6W|k>6bCQn&HP7KFIJ9hMe9dJPug$KZ=g4#iTtl zP~pig8EFi;J+{^HChFngT-px3-YfHb%`1cq-%kXy$Ut;)I1+my6?cw8c?_0|F zN`|W$)-Ytd_&OQyWys~+$MxCA_VL}t{$FJHHHK_2AKS_I2d4j-A(xkBaSC6ygyESC zxjrmg$M{x;7cdMm+{2LbZP`tXvtG-%{4C>qT*l>R+0)GTdj+#tk1VctSs!KklM1fn z{9VcAcjX6|&h3jkmY9|WSs4o{V3xIX=L*JeWcVqDKVkT?g1Iawm+hXL%XGGP?k2`re(pyY|186Y7;-zA`y0mpsNkyQ z3_1O)+8O6|Wfj-ERcz-~cd-AL6vXZjS#I;rW_YfG`EwX9WXOE^Y`^>;GW~f43%Gm~ zaJ?$HMbXXiAj;`l*p}XxiU_`~#_a<6iT8qB%n0V1ClC)Cxj5Q#q^%vWTe~o?pDU-T z1B0XO{cU|XW-QmDVGBiH&`zK|es&xOdJiZZlkp=EyuVLI(4pqoja-_X$1HrH8@tr7 zrB0o#y=!PNmt$>f$Nj8(a(4|4j1J}&1pIw;vTmTaeXx6D?a1z+uOL8#ygXY-5{c#e z@Hy@d1V3*pod}J)b1O#Mhc;F2#hI3QMUjK!=uZUL+fCkqy8L>7Q*EFmuc#!jO&%(3 zi%)G80CWEkU3C+Up=&^vAU=;LV&*Eo?*;5tK|t9Y}Xzcth;PuOI`2YzWjpH zXu)8)jt&{7x{hx82#os9ZM(RqY46ZzSD>1t*zK&Zm!zbum+T`WMHO57+N<~E;gDX% z9+HimFf4$CkaP15#{1~7Iw~=$$YDvz=*d-Of=bLlf1tOQR&a)8Dcm#M9Z5DJ*(?|&A!HJpZ~17f&$;Rv+DBmea&#yR##W&`)arP zaCCR`mSW#!%`F=%H&!XM1n7o3Ujv;FUhS){@R$0Us?RI+H8xc@m-?!4_urlZqpqjj z=WD{nJ;C7-pAS~-?P-s))MCq9PNc3^K2?rd$0_Nf%|Fy+L>4fi z@gi|kX}wq+wZqdb6C8G01ww|MRza2_r(G0O=&-i$G|Pca#`Fq-6fo@)U=Ka*?AOfz zO3PGQfhjfNR;@p+p3cfkC^MB>9bSzQY$~-lR;>D5Xpz{>E`Y?tk!C*=MV8|46- zLynel>n}##G(rm*&RCUNFh@Js7(c;N4<`yIdSNK&!&Nd9g2-00GzvX`B3;7|=A-3deuDN(=*O7}R|0N^dyd`=C;UcpbMQyp|2;OysTOSu0xY=eRbMZ}u$ccl$&> z`zG=R>}H{qo?}`4(osGd~DFAAb7L@rLPlCgL^5G!vla3)3&N6n>9RVrG@E`aDIHqBLb#*ox03Sg zAb$GM@rLQQ@+cUlQ2w$hFTS9K0kS-Sd1$+S*(7f+erxbU+Yn8^?B}tU?l}DQ6Ggw0 zN5RmjnE*9knEgr-r@RePvuZwWUvxcMGYApXU+G7uBLM`Po!5R7_-ymX2!V+3KnYe3*Z?>$mSI;95UwFQe$U?^*a!+VrF2 z4byKQ=|^QyKbkL0zx_L*dL(&R7qRPiaW8NWeq=wajhXs&!VTFvKQ11@p1{w5rXL+I z)`3hL!FeDRe<+Rm(e8^u&|%;_kOsEnn#txz{fCYe&JVr~zB}NcvhT%@R9_(Vuqxho9`waZZ zpW>x>G+znh0Q6k*1^m(FB@XUrd=J|A;wRyI%Ep&q;|ov6v+$$5BmHJh!uL9|ag6ye zRxtGov)^?egr80?rAMcO%9zd0*Ij4hOSbWa+2y*M;HT}9V&e--$9129pH9cZN%&wt zkqLiFZ+djT>z{|8mX|RJ-`h66<D-OquiJ)CdV>cZ01UhBy(EG;T4%*U56UN8RRQGcuQ7?cCl0;)1~zU@!osf0=O24=+!&kVHO3s{b25#id&dpWy0N5jj8Mkh zhmCPZhN#?N963C5EIzgRaKg=rsWrEFx_i1aKN^=|9Eu%_sY!nGop=6utbW{act+Z~ ziYuPkFz!fOH|DH3_;lrA$GAbE7gQaN8#gkP`$IL!-EG}o3Uzb^aa0^UI%nZJ(3aL* z*L`94ikO#-h0_1S~xC4JZhn?e&iYtz}#^V>b#@!35j~7r5X)Am(`4e-IM{~y)jLqtP zfA?A1hW7Z!XBB$V*Ohq2W+5m3DAP5&CboOHyTIfQv0AYw{qkdf9`_ucff#i@{pa}1 zJkQw7@j2=1#^%UUq{^i6!UN;8mm8V5ApLm8a+D)mJ}w+z^zj+p>ru|Ck0$!?I{C~@ z<9KRWwld#b$4f@VUB|?7SLNSo@+j|heM0^D`wQgN1xQLV5VgomK^TcevIh|`$8FRU- z%SuYSf<;9{opJaL}**aQ!a*h1eks7$;UGBWLYI3ns{#;Ky=k&Ny z;qad)!Ncdk^_tDUZ+e_ZC_ye)>}Wq7zl;yNu~h`Po50zRyG3n6ghWtVVHl55Pz(i+ z(BGcHW}JdX|<-^*iKgZD4j` z+Q2=BJX-RJlf2-T7dDZfxU7{}El)x$-<>-K8+-N)jNpP-EgA~^6VxWU4@5}><+Bza zYe~Y52Na{$T+(jZVZShTJ5*{WitTtK!+G=eZ5`d};>Il3jrg}+#U&J`4}aT%Z)huF zRisNmkmLA{E`8r4q5o{XP9T*t2Gv@8stpkZeJNN``2)TO)9bS)HoXO0T8M}8} z7{D0`N&knvZ-I}xxc2|ez7j|XAqfyL#3ckwV!++JLqORi8;InwW)}fXyXLVWk&uKu zAXpKq)mm#6d==EHrPivw_F=7Ut*vNVwZ5*;TCHuhw^g(+YqfIgz4iY+^Y}eBzl0>x zetJKj{|`1ZXXeZ~XU?3N-@JY^+B2Z{1)fH_h>(tBIGEn>ioXJj|2sPVr>8lbs&&InPV? zWWbZ`neR!@aPARMy7OrV0_SJAolZ|We9U=h_W}UFa-_T6o>EV`)8|=$@PsAKJ%o_q zIgw*M3G(pFaDMv&5$_c4j1$}mo^^=J0ylyBkU~9dgIeu&XU+rqT;kz;S>tJvogaJx zaFX*z7coh29@s-noHOy;;YmM*SbLBPIV0I-cvb>l%0rO~tkXTq@SE>E-;=(?J&Us8 zInh0P9QyS-OTvTA6zrj6YkvrY_)CClLH%s^2>Q10+GUtn$klT3|h;Y*9 zdp7XY(7h>zGhwx77^IMI{_jN30{1NE{d>5QlBkd=`+n!W7x2Wt2aj~;**q|5$wE&q z5+PHWJYbfG)K&|`Bu@Z7P=Xy;-G<-oh{)is#_kje;A+l85(ys7d8>kksmT7WIrgtZid_6YF8%x9hk!i%S@@rqenFLokD*a( zqCtK|gZzpH`4tWL)x&Ou9CvCg#PdNaAg_8@3u2LJ2+lCo$dGAs9%L*uqd$KKR*L4_ ze+za{>yHZDi$I3y8Ri292LuHP2o4gs9B6kcG@&dJBef*~kyQyii#$Fr)5y$x5TDFN3ED`TZ^tUW4B`3J}OLMya3Bn92(-P!H;y$0VO>Ll=KAX(sMvb&jBSp2bA<2P|_2iOV0r% zJqMKZ98l5|V0j9x^?>5gfQI0R>^Sy!!oLQ;bI=-+Ut~u3MP9gHW<~f#PJ~}%MEFHM zgkNNX`(-YKUt~h~MIMA-WP$so{<$9#;bGVYRU3!|qfu{8U98>f^?Qqa{_-3iK|7Nu z!tYyIRJyXXQiO&hwKWL!a}*B9BW5VDva-Zi*}$WMwQF@W@*7wszH%Ld9~~Ll93n=R z!39Z1$wHBq+WNY>sKlWG2Sp9xz~ufebk~QyCFX$M{=O~Nkb&Vr8DKiEMo3Sm;nXO> zyrsS}AC7I})FLKLnsI{9rYO#z5{YC~9iqa`brCv>>KGAmNAY-Z6c3mX zb4iqT1LEMFb+IkIj;W3{(|Cf@|x;kzfl7ctcY}3LFU4groIM2nO5rlEiTL$hLN~ zUsoNjNz(nzA=H=pa4<^MMq(ojS4#vM8lr)4IM@;~f(2?r@XTO?)F2sCU5JyzX{Rn; zJ(pRqzLyGvv9Wv~b};dpoDW7nBZEN?U)Jc8kx05uG_pMw)aDui+g zO#JeZaske}lHubeB?(5xOP>{uHZ(V_rJt9#AoNFLOK>qrq!xsuwZWQ(uvc>|jYdf| zO<|1{Dle2a1e}U!V||l%IlisZ*f3yxjl=_raef?vMi2yRp`g4Ae52)E;(_ox5QA$@ zDMrto8AW1t0d<$)6WHX%sdRWtOE!Rs3qn32xgey-Us8_6wXzZfpD$S;*kDmvR8(AC zUgRq-t0*lgFE6d|m4n3|QY7+16iQ1qwwF-=Wdye+#sx^sIsK8th}hQ zbVOqp@)*huXQda4zoMk1th@v*e{s35vb5A+<}U@aPczVtHUwcRX7yca1jlLdGe(TP zGA}a_CaKfU87V}zxoWR4LS^2ihOaatqyo%}-e<(>N)WoQ$+Oq@)m&q`4wTxjF$G(d zf2}FTt_ZF(#p^O0s~~RRa@XnQV75P$(~WwxERVSOFX-|1rE-%VKgmM*qMksSqRE&K z>2Xpq<^uSV9%)lLx9X9)VkRz}uLxaAy~G>)?MAGW#8MaTFrw|s=}seBm*!Z-bT?%H zJtE#%z$>(^vG3{OkWq#QFbF=(dGG{?AnHOAjXg{$P)TL8qc^ptrb)Fsy}hu2pX&G^ zWNMmijGE&=!8vmV)&zDf!3a8x(0zp8wi+^PsA-0_)@5-1s z89pGbRzz#)rG=ly{)Yl!Oh(B6QV2@T2>Azvz+`xc(VSEAy$;HXPLRLz5d29VY>-vq z7xHj}xC+0BhZ`((vm_puIKYAmR`S1>eA1$!-^mX)(bjDh7R4(t)tmx+5B9EMF##uu| zQ*)(GhKNq0W|{}T2I5zih&Meh=8?-N9o=n%n#c*!GYC#37dPXP2#S-;#k;FDu zVN^0BgvLj%L<2Smg%DK{rF(%cV-;S4U=RczWR)C*9T0ekt>hqzpTIjr8>VEcK>9U82(k3p34oS)(~n zm#)bis>|4H4%HJomOv%!c~mQ+k2seqSQ7e~NlwzBNbUChf)1-!|&E*2&z#tXFPYaxCo&^TZr zI<$@9`Y;U`F>G9iey#jcO$-ei#ZU*k4g%puyaTXFL1PtEi5u#hf(Yp8qffCkRz=bnsnKXtGd@GZAdfn|ow1JIp@CRO9&WRa4UY`=p_vJwOCJu_5+C&; zKSlz1BSW!H>ha@*+l|4%`uOObv9_%gjj4wXO@W5`wN1fVJ~SxCNCa(cK^_JZ18p5! zv4lxRP3ra*!0!foQyP(F)0EUBS0vw9%(Ad=g>%-M~ z`QFZc?$u+zW4Cu_H;%3L=J_@t$2Wm! z?Xih=PKoFpM6~gkl6G#JilpBLQGB*{o3Y561dX{kO!1F&okpX=!fYdvV!j<8HK6v>2P&W>Wu_n*P4w z!G5{Kj7iT`-*K?>FyzP0XGVH{XV~TriE5v)>KzBWgc=^=TptQ!{*&{uXUh?U93idh zE+@N6B@G-aDM!$g9&xgpRMOF7CEY{_deU#Y*qthAC>)wl-q2uw2adJJHSrx=Lu83K z-9`~w^>-J$m!?TbXPl7G*Kq$pa~CD#sWhRsi3n94cC&|+M2*LgsIjf5&t9BMJnShY z4yR%gM^7ci(c$<^RXyTiFDqF>E%l9o@cLtDsHd@QNbXx8L;7R_dtHg46A+>d3<_MO z5^Kt;M-te(&Pp^2)%951<7yV^c#B}VtV@(YtFh69ZEh8pP-UrCBkwdW0+fy4iI#U` zO><)i6P7LXdUR$vT+SS)yp`y3-j3{@Y&$ZU9;j+;jB`y$GQD4lxj}2If=Fzu5c?{$ z!?LeCVS8kv{O{EyiK3tkEygbgza>--XuB~VAEb%$=(_0IU{kQAz6K?c<8ZMx)PM2G zK8#vzXbjMVo41r+cIZ-!MZj&)i03cEYMXd3br{B`;$&B?^7_j*%7V9tO~>VMR6E#)9?T&vwK%W9J2 zT1n!#l^Zn7pZE=eAzG#5BazEkA&oQWAsfrbkG_pL8NWg*8)%dcC*dW7$@p`mg2#Z#eBaVL2&@hcTs#My#P;gUCFoaQqZhRJT^c3q-V1Q&5K6?&Q_?Zeq0KJQOvwy#ZxV; z{F13^qp{!We$>-90d%(wMd@0d;hsJsh{?CVv2`2P2BT+UeGn~lS8spYFfM(^U4!*a z^%3+C!2f+6r2!~>9;CB>q`fy5k9ZXGX(HWtr2d=XB111;1o~W;uPa(!SHsV@BYpf2 zYwh0bIR4G}P0zi)$`VEOV28^=hvKL~irF zr=e_NDp4a%7a^`36O2&E_>2>)i)RH}n(-O}_$+~VM>RF0se^_}5cV8}sQ_A^d7c8K zc7oo#Vg$XwaY!AsTJ$bQXlPzr?epd>w=8SDr$=$+d3~c5Twgxo{=Tzk2scFG!sN;4 zQ>C!vQU!`Ueh9K#Fz`c9TP!i=(HC*R4^smrGT#4!yi&~`&VG<>(Cxi4~meT*rinBwv!o@I3Y7Zuo zJPsQIe_aZEoa>ROMWQ4n=`K@sQmvK+!H9=k--BFzZTtl=aiv!6B1exiDnS6$9wci0 zxS0)A4D*7j6_~K0RVm_WDl#DZQ;;12T^wW^>-<+3EFHQ^kF2}~IB~HXc)aD(L1f{} zZd#jY?-`!FVq^k~UJN3j`Iwv9P;^HcYW;a#n4Xhe9MfCb+eNESz2+A+4WFJgr3~eD z6-FkVxX>FR0#6$Ril)H2P;@WFdm3~cfAAPt&>Vj>K_SiYCj%_P%|$bfUaIKxH}L*> z^_X$psT`RKcTnp;$0D}H@SqK^aZTA4~0S;j}HVc#WL!g zkU-}F`>~Lkh8yH>*vf3@T_1b=hrm`b9VU zt_9t~tWE!1i}VgrN2RQg6EUKsF_F#dJnSd&Nsqx)ro`OilPaZZkW@>bAm(V^{FsfGFN7rM5Z-+q|iqY3PN$3l+BGkvL@o#HEx zst*#_*PXc?{R6v*y@jS-ITG!!C$jH2m#8FG@`8=E?1{~biR_#1C0%XpLuULgi>1*= zC*ol>YR@4*#plH_wGwE5im#0r)yq+b>W>49ouSZpjY7a)Qve}+O~EE}?xKkIY$6cu zz{(=^#l@SQ0x%HO0|@@24)d2X5p%p^4MUJqO#WaKF@Mn!mUFGZQigz#oua7WyIB?{ zypJl~Q<@JHKonf32o=N2AJQm39N~Az`Dl*gS_hYvj}&Qf^=7R8i3L|<9`jBICNjV3 zpgeIrnpUg}G}bq4_G*sr$0yL7_dA>}=MNk%7kkuE8*GRKqGuHQF~A$e8yzpdpQ=EA zDaI$*x%U`0Z`9ImX3WeZMD!hs>ooR+BUJA#Ug0nCmsS>)VV7S;WqBp+C7F$?hX_*kCJ3dH;x`3!Bq=39{tX{yV7)nyo(|IWdecuS}N zuxJ>rZ>+^4FzqgYV;Q+o<1XEnP6$_-PyKlNY2C1 zQ2Zx4<2+oPJjmCjt)dhZ&(PU`!H& z%cGJ@S&5=wkO!U6?gMX}K>rEU(E4@Nkvwda_ZQ+%5&bDfR?wNIRHVs#9-HsQL^(RB z$d3vamRE;|X3ygi;NoN?5Y#Mb2w(Jdp^|5W1d;0LN?=g4li<`-?Ia-XlrEoomcJnh zum@m!dEO3R;SPV{j-tXHV>Cb^sR!B?t^!v_UO zQ&bX%FR+O|GIn=4-H;vVz(Es5qbSF%vDg5dmb|t?zMH$vyV{$#9Tk3Knmop2G;JS!uGFv`*X7_Pslj9^a#pNGg z{2$ut%Fxuw7FC&P8Y+0mRs{x)<&&WC@YtLg1jbEoDu-vv8=5yp#YYThVe?LNQ#455 zL7<&{$tG%3eFQPTEU(8_$>yep&6p1!C-tin;cznITZbF@7-`>_F_KvO()V9{q@^(V z0R`@6pwU!^v4n-CRCR7Xi6Mtfv>2z>Q;XNgH5R#^ssu8TJZ>Ybxf0Smm_`^yD!mQ@Q`yNk`Gx)0^}r**pT$& zkOPb_e+-(}xhA0Lm}j9$Ag6iMhGwxJH2;e|1)6V7Nb_7PO@Ks`WsarURa}H~tjpQY zLGw9xDyb9t+k&f@u$@8s(4tVA+-DE;4-JRAd%9#%JC-DCoJo5RW|=#q9c@FM(atVE z*L4&&0A`Ki5LL%u5M}C-0(0oD%Y|@cEP)mo6r#Xm^&<`4d!JbjW1O?3p*cD0cf=3dk zK-0CBXrgcnxWHrR;$x~bS2{Zgx;M|50$oO>Z7(Y?M%PyMCD8oqRA}--9fu~Bmg@m_ z7ihjUGc7ydL%lyj77;)M`5f5+m@4^P&L7T%2M4QXqXJW1cb7Vrc(T_Ii1_5}^*zFu zlD)oD_)-Pifu2r7=R6m7y^O+Md8HeLOqAG_JsQTwQa(jSaANkrX2Wu2&8DrmZPa*TEo{J0 zCTHU5XRm|Fr72S|G*hK$@0pPJ^XzR9|J{^`Q|l^?tq_CRE3PiJQ@y){K6U(FFCZCKUT(h^@LQy2ycy-XYXJA1mYE118l z!6#W#t!wKT#*SIq1&7cSErcS)Sw zGu-TL$o+K2@sV4;?T&-i_Ol zoa}**uJ7#rzF7M%S@C!qDql3VCePc*q~+`ZWaXv>|M#+DDix8HqwHm5<*J2at;uLn zW{D22Mc1>u)S|TWMg~pRmf>#IZX|11vN@8IHY;roZ$IE$XxOyTW2a^{`A6(8V88!_ z3E5vu?=@>tAA|i-Fx_v*lq_*pHM?+*yWoPb&T*7s0%;)Q&RYYIcc-^ z+6hm^o$@9-4B?;l+6ymge)X;*WxuZMF@@n7uP_p(P#Dx=jm-}N_57rUC_g!A$v4^L zg; z-UjXO;tI_C$0GF@WY%D}WM(J zl00N5Nb=x?Fd+}Bo@uYKOBT8dE;?zlJWykxS;Yg;g!$m6ogQTS!Q=Pf(O~Fm0DDJc z)_2!r^(BT*{k>yVmVO7j=>&Jd&+?|gYC^Tyvm(u9WUxEH>cRY}u$oAFwyd}UGxo51 z!0PUT_!%E=bgD4s7V)A{7AGsAd3s6A_+Y9-)H7p>iO(=$mLHRYc=beimCJaG-InDp zxaQ>enI8*N*%8#48U|rd@4)Th;7}AX?3-t6Zj?O<4u3mN9ELESj`iCzdXT*cM!znc zFe`i_$f&UdO52_|D>OkguYkP<4i7Gm=fKC2s)Xd&P$`Q*Q|*B{<6GSLMqu9M?C>IY z!3`@Wq%3V%QI4zoV=0pX&wHIc2FmXpgR(GLow8BD)N+lX%nNq@8umOWzj{i%z1nGG zt0K+Skv*`(49h8#9y?aNjhufyyC>US@Hj4Wu*|%Q0lZSYRFBR|)(xE%!4t9~ePz1Y z17LNpe_~cbUj{2um?>AhA0nD%+gx!4W)85&!0JE|XJtPLHQT#-V@yg7Z+#5zpP9X|KeR`E{8-;ndT1h(zG-w==jPJTd$cJFPsIX>F) z8*joFUcxS1>@K*md;*o&wMpX^He^e&$VRDC4cTBH8A3Mr=8Y>Gb)ZhjVc&&pw^!I0 zA`EsoR^Qhd8&y4F^bAa04zn(K^};C%wXxo|T?!p`gGwWU(z5c%MEPu57Vpkc!!lQ>=sD# z^Qx&zW3!5wJ&E!fUpJVuUDU_!TH>zy>MHg}=dzC8o`EP|{p{yG7iv0k(Z{jw|2vBP zcE4DK&s(hc$QrG0jKx0!{L5CePr8;0`n0J6^l>i}RzR_#@2HjhOF+MGHT$efl9%W@ z`FMOH|JG`DoogBG=-^#1P-clj5Tb9{F31vr|EE*g{jPjkDdx?C$Sh6rY$kl1S)ZHc znAeG8`^g<>F`5u#J1ECyt^FeyylO{Vhhy6Yu$IBA&1Rg@qiP)dGK_ZJVdhD$b!b)Z zoW}lak%4lkWH`cQU=Ily*h7<$;m9;(_|Y2nCHFFHunGt8K{@gvibH%LoG%4I! z$KK-<8aIS%Co6Z5H*CR`tX>_6Qk1NCjam@AY1_89iTXse!RVh>vq^W0D-cw#s_@jO#v z_<7>ifx-SxoOy*I6W&}Bpp79%wN;;MW|!x2nQ$wNja*U?mMKU{@swzg>qs;E$`}GB z*(3pyk21nLDqLc8SRk?z$4<8Ih1lN(X>{GUiqfY-*VSW{s#8j}9WKknN3Yb+A#X?j z5P7v#KRkmS%;%Zq1dk;pCkQEtpmtOzs2!CA$Cq8j&}BZl#xZF`8o#=Q{ay$`8js5v zu|%$jqpcl`m$Mtg?6LyA7~^tBM4^99)XqMRWA3W1kFYljc!jm@OEIc$!9r1WExl=~ zxqKMjD#qZgVt-BRE`Lnre(ZL8uByQE4GaF_5%Im$uUL?LfS|a zjE@M$M_R{WeCbAZZ6PoGxE!mY3+taGUz~qv%J55q?@P9PH)~Z7Y-C?teloRZ^c|LL zowbL_M)|M+7L41zEKTFXOk4HzCictaT-=VH!Hy9$g&PNP_<*Y4S$Py(J<`>M4Kw21 z&;SEYe0e8fHDhOL4C5W%>uBdl*!_$6!ZU|(o0)u<40iB9-b-lj?eEwcrX@7h{cqhV zsc<41Up3FlNh=Jky7nw~*$RtjSi+U>om@;S*h-d_HwdJ01 zHIuL83$YO}q1c0Fv0Ev5tgn;zN3*n5x1G%%w2CgYO4D*s4|~W~_G4*v*1YLzb=7OF z?2lG~xGpD_=NP&)2AY)nf0{1;@-g=1Q!Hj6b%_cERrXIyl`Gzxt}3y;h zlY5eK@bR&vfZwPFg~&>dg*zW0}3k`b*0H=J+Cy z>DfXm67Gl)PJdBx;Sgx#!IYixMP?7hi~La44Kems8Lx|Dw5(olMK_EuG2Uo#UHWmP z;`w+<Pcq6S1`O@Qnh0@X-x!{}T7pm*AUN=OTQ%Dx$Oj{(VgsQ0&gWQ=i-5o7xpqzDgAw zsK+3`>LDRK_#PL|yVh@d{?Fdeim#93j$Dv;vr<39wH}|-{FYWGTsV!BKa}?}wpcr5 zHolKu48V!|Jm=QqN*GtJmXvgAk~5L6Smk%gq`QsVWIWa&O-nEWQazf6n`Y?x8A_sQ zGYp^x3DX#1%rpm5K#~ej7|G@UO`D}aLQYYDrp;DfgLbMBM96cNX_TWh7qaF|Ou`kz z>EtC(Mjmd($wK5@?wN(#aFP%u?#Y>-qzO+Zg=yLXB+wSBct7-bg1{he7KM{%QIbYZ z_AF4YpI0#h2Zsu;rg>FZNwTIbRzOnHtfXX+&Y8`{TvE=RTsIuj{!;Sb^g?nRpmq}X zAX|BCCLKcCjd&}SK+9a>5Swn zPS*%e(@MyrX{9TWa^>u**_E@MiKivk&l9>Svj&U6awBl9#H%oZL~<{=u5oe{ce_U73ek;}CrNP+8!m`Yb~03_JyCJ-#v3sBP< z$m2|0m0W_tISnP&Xao@0G#Bw?O3mcKy$bWVg^D88v@--qMcp!=QzE+vlb1XZ5vFMy z=5uR0GZWUdF_YW+rV>ucF{2QOn-!pGXGt%FK3jMRp;dS_?PCg)cz#>~g|i97y~I>~ z93BGB5rBwk699#yQ{+z-TsycIj5^6fY+~fmv@SPywva;=z1uBi#U0eri&WyPM3CxZKlgyffXV?Wd%FNmOI`(FPyku;NUk9TXxeZoufZc#5J}T^ ztkyCi@Xk4m8ct0cT_rtGG=HZ1St(w57@KePo?X&eT-sUmF?t8`faS|ESu@zcIwcsZSDQNLx}C{X#+Si zFo2_!hgMfs7W)hNpR%$NoB*-BV_;-8j!qwrjV{MEcgvS|0S@D~_Ps@fI<#bGeVX&|lmHWw+k`Py6Mn;VPh{EL`qS6Ru5ek9(}72DR|8C%`e zKiCnQsnz#^loz_%7V8@xT8VOL>-1MFFGdZW=Jg$5j4KX=`Z~I}`UpnGW9=hb$Q?%k z{xV-tp&wUW0cR3gpwmTHpTbqJvwv`_;X`s1PiN1Lp3az8^!!ulG0?FfoHql->_Xhm1Mm7fgKTDrow!VinsQQBG?+kuUBJPz?Vxuw;h z8%IQ>)uVBl#fCHM`K^TV-0Ic1BhtIPR?rb1{XiHqh~9Y%F5RnH7pz%t4%cso%@{5|MAhzIh5zx&rF82sIO`5_+s-JdkYgTEVhT8Ibn;O_>G z4uikzWfNQs_(l_qyttJ8YDkYWv|XSf9>BPt!16c;n z_X`t@vAN@V6O8k#9A}zf+!y44O^65SaYq7s$^*umif}ZkY@}Rl?90rE_#icvQNQj^lL<1Q72;U8MBR3<3BHOakm0v zZNgtA=>SfVFpo!Fm`gC~NIJRT<0bbe7!Q;CQ%%c^3+H$U=kAjjNh6+awxyCF`6-;_ z;BG1g*#x7GEhZOri^ByHhAnbDUl{5OozN$$T3*n#{J>_GlV9tY|zrFX#Qxr@5S<4==r zjl^q`FzO9Ycb0^^rQ0jRhb0XA;&^){jQnv}=FcJX=Qt$8kuQqZV5huXP>%BnR^@pi z#>)g>qG{#k@Ov>PC-^?h5s(W#ko?+zN%wu>(h!rv8SI6->!mC6!L~{m^m#nw~<#l{0U?_~6?6E7n1~=4`lv96 z@5O`$!6?r%8NSRM4?A5+@YgYQL+-0mj<FI*R@!>(w<$rBz&24CB94Idv=R(&u^srSK%hedXNy3uq?lX zyCnSI!cCOrpBRyFmvk?X?)}nzR=TeUcSf3YbEUgVy0V;S?33_g(pBl+74S@%znSYK ze4%u&k*>6hnQsX=N$NjorGy)#+bP{c(*3S*likuqJ3)F)#=D=p+oXGube|UPEUAZC zSrTrRF5Z8XZq|>b`w!u!td_3SZ%U7ZVPAxw@^|6Ro+aI7(hW!#c1w7(rG94rQo^#` zOPwR&)GMX?GwJ?TxN|zByIs0cuk@BCx@i|n_d4mmDP1X7dZU2TKQ7&GO7~&mW=K6` z_$B;l>E0+^NoQ_>fams0_Zi{NljSr|;?I-$nlJS=|4xCIDciTqy%LskE7FayC!{OubJlDDXGyuU&XMr2biX9sKM9xm3`BR4 z)Wf3lCA?3%4+!@}G!TS$;wjRtlWvQ2&yudRlM`k6oQQUer+ZAgvYbzp_4~v>ig0hT zbn~TKCf!q|8E18hhomd>yZ9Fp{$JtdIHijUPxNxKq$}IA9NE6+Nc+u^_M0Q^ zCr9$lxk9G9S-O&M&Z823TDq?ZcZqB-mPo!!(q(wAbXQ5YTDqr8_iX8Im+nsK?vbvv zlO?xFShj0R?ve0Mr2C3=e*_kt^*!cZq~gmTs|h>!d67lG`caUg=6Z z&z1E#SL!GC%QF5h>3&CH=xnB`oz=_+tsbAYECWh3^V@xkI|LUM;VcaI17>`7HmW zgs+zF7p42Wbbl}06_U;hsrMBtWVqD#iY5t5`YW!K@K>b!fOKU$x#Cw6{)2E&StebX z|5Mr}EZdb+WW75@>iLvgWc=5Jiya=^Zhfap_jKX<=SX*d*hA4F9cgi==%N z$$C|Eoe0TiX9itv!O0>@Jhx3$CVRzA$xui#VB z(SecnzP4>RDr|)jhHVhrV&(war)P$7D0jbrG0{E@!n?L{1|4DwU0XpD@0etdc4Ma* zw#A9_v9}BktdLyW+HuF~jul%5`$q;=6h#Bu=ycp@Z~H*^`ugFmvD~641^9fXltdD% z@Rm934y5hhNJlzH+e7CD&TZ`9FtQ^S^_AME#o3)mu(O+@qYeJXKudkJ+*ev2-Na9Y zHZc>+{Xp&;q`PXO+XpHm9sTQKXYDFQia6@(^iQBy?4-D;Z?NagwblOM)~3>^xa-D5 z8xzE_Xva1m7iM#SC#de-xT|<@M<`g@X_H{vP|pzNmA4IGd1H_#+p>cv>#kfMY3SX# z&0kb8UNWeyql2djHqcca(UIKK+s^B0**Q4U6%7&Qkd&3R9DR7Ww0h&V_TUa5 zPT3XcmNJwX!|H}5c!gh+@HRSaj?6{a8`g@*a&`=LM}_UcPq$f<9ck6LsH-!e?ra{) z&5f*U#Kpyd9mS2g;oML#H?Xpys3>>S$_BqbHw<5WFc|db)^E(k8QbAA%W^LWN7mP@ zuN7c9z;z9|&2*4=FgI8osK{*zo>7q-Y6*rba)Y>}Z%2{V(9@oq+kzW*Vnf5ZxzJW` zPdoC|7HezoiFOVSjhG;O2xmlLZAAw<=whGPcDr>JsUMT=s~VRpj4XGOR%TUat};4G zJ{hYUle`nlA}hLi@^MRgOudzb`O!o-DgbexObv(=Uff)2R0tw7nHphBMph7_F_{_? zM?R&k0(V4^WS z3*ZE%UHsT`SrMzYD&U(1cfNHdxGYLpNX zOs0Oy1lB@9+9}jWdf!dAKFYMys*gPFwCW>IX%r*XrOA||Y=1=Rk5(T|G^SS{IRT@z zr`Q~uQ(KFEif!=}dba2@MWfLof7Hh0qPRezvb>@zR*Gw5aWi@F%*r{pn*O)qB5WY!o_lxwz3~OcLJ0Rg4qv9~;g~pmLmW8~S{ZlIt)2 zCv_Sl^^N298CUS$>OZ}+YU!s=W6#8R-E5GeZP2Z9%W`WYKd8KJq_1PR2UiQX+HRY| zw@RHL*w))g=bU4vC3jd0VCcD)_mugneYU$s?b*^i$urm-mf@I>PaziIcxx;eIklRi z6~0QG1h|l8J18g_5t&-H3*H47vvMK{X&ied{-!WQO!jeL49*E)PJ=%s_)C=4BmIs; z2q3}=4{H>5cpB!AEO@K1-h=re{ZX_r*TC^)1no&@89J5`*I>nSX9A|Q>QR}Eqvyu3 zXfpIXn47VshdE5Me4gI|u2oD;adCJFd6UE=J$2g9i_1sC)4-vhddA6b;w@NLdO{(= zRd{jwOCr9TCV}^3(8Iil{z!Tb%+>0&;Z3;*Cb3V)(&HSYS0w|ybD=xujbrgN%mJG5 zGG7H;Fc#0zk1)&!sb@hle2Mr~;)nT8Zi_C++y+1RQazz(0ojz7eDaYpIf?+A>6HLZ z#gFJ=K2oPA^P$s2J`xWgUOkeYCiSfF7QX_7h(dy^@MQTayc{3&LU~b-#AE+JfJwfk zs{kwcFyAC{B6V$ zu6h*T1_Z#b^0DG+z$Bx36keQsrx1KtA;Fb+YzzD*{rM;#N944>ACtwz)H{5&WxkyYUm`vi+J@YzHxf4 ze*y@%C?vQFFD@Ua_hJu6tqmULu+8%A{sv$rAJ*~4lW+H7#3kdW9>q6KzTG6>utI{X z@Z#jVU=8Bz+6}BNnC0730hnxt?7)kk(q9|=psmVd&l>EzyA@&TQGBtMqRRm9r+$k+ zL_Y11emuNh6W&Y{UVJ{zM_eX;#5ZXIylYU5w@WVSd z-~Fo)r}CR(!dn8rDZl&8dZBu)=*7vmpY)>Sn?C_wC*;dRJmuqr@$s&@9C3=?i4)-6 zYQiJg$C2-<`%QS%mW_w^ya`Xe_eoE2db#Qk2vhnioPgfDQ0HO9Q+~+~$KiY9J&03! zDKX(KfS>A%d~SRN)$cw9!BzE=%Ep9uGv3EZ->|`B0~Wlm)&Zw29`BUmQeTE<5 zrIjUqeD&e=;y)ho7fUZ?Wk4(`uPiU(;pfcU6Ktqs4kZ>SGoCL~z}K#!3QM~z@#JYO zTJwEt)(+fvcW;_nLjl+M}Bm?4OZ&82-eA*#~B4 zuGu&H3!re&k+~w%m$_Cuyf0&ucb`)`vTr_I?V$7h4?q0JK3wK@K;u5wfs6&(zPU*6 zJTM==H26Fc3)lxd9LuSFsQqp8YnyK&sE+OP9ALtCV18)vK?&_+3o7=_?+z^R?OV{j zMq;`JpE`CR?VP|t3GLGk0Pg^>Ue#W`lymSX>igUWlcj8F2WJUB2h#}Wj9U;R_<9h- z<*)NgITnDr=YWgTV!F=-jv~jJ?sFbYk!d{#lO#PwB?Gxh(Rn1r@t6x9iGp68=im&% zO-OLYtBB#;c?{>N%QpX+gT##2>tEvXP8D*GuQaMrKPJnYAy4+sK>)vkuOJT~xzTe!A)Gs}tcK z&irY2{r(x77GxgYKa*R?)3A^vZXv0#kXc_yfsM?vSjarG3|L4yT-QNi7wn)Wwdp=E z4|Xvhv=R=aA54%oA~dZXOpsXk1j1q=2~vyfKst0PA#NcH<1EA@wJa<|La-3vSu7+$ zw-AqRA?XKa3O)zZ$5_bBxY8pFNjTt^7NUG^-BvW+=R(;E>++yfg~cfgnTOoW&@BW* zHg10^7A1W!RkwpA!A-Z2R0)&a30qO=7Q#Yin=B;d;2c;;3b&AC-9j=@{$vZ<>qnI} z9Lzc}d#ScCabKdPL}yY-qC`{RY6n%Va0zMmxev@lDJJm}P2nXv1O7>t=)qi`V|E}V zu3S@jxu)nfUzVhfKZDm$VO`n*U>}gU`^+VqD|Cyxo-1_=PDaV0c1>7vbv~WnOvq=@ zNCJ&qp?}oXT&aI{AXREUvHJGsv^QFL&8w($)y*2+d+FlOe5t!Vk3F4Smq&RXeKn6g z0 zaooOfJRUcX(o0;!Rppj>?l_S#HD1>4!z&Ya0f?z_I_^_EJUw|galNczZ0v~;eD0If zh1tqjtNPHcwH24T@+Azp{2)32Zr&w#9(J;Y4u?4T;s5JgE=T;6b^f0wool`i@i=+W zoUF0)Q_^N>30eY6a3nYrU5V~QPhvu1V&aU%nTbgW$%)kOwvH;vFpdX}JhL1QTRC+8 zxm*hV$B`RI-}x!`#jZ=7pLSfq0_m+zHaqK*0JXu*Qx@BOr35xp2M)d0lQ)R{a0J zoG16sC?}^q?_zx(Dgk~|Vo9`pWEdZ>clGY#hsnvJBsR^`8cPbKFB;C+o1;Z1dbbRP4p|= z%=wPyVV-oi%lY39&jR<1x$e2?0GadR-RbTG=RX{t^bAkBhkoHD^4KK zbl$!PpvUV(=sf2Io^eh=zYLlFssE&LvC)XYjxl`1A1lxFEiA4Nf%c;t-AQb`9c@(2wmK^Cq0Am zpFz438sqRnlEbWr6QCf^T=%ShLq)ipZ$S~rfIE!}$2|jTfKH&bMMkO3M|NyWtpO3L z)au};QllT0kn)pDII7gBq-C7@BtKwnUeN!8V1fx-JPF<|s>-Bq! zeE#wrw8qgWZHS==zi(wx>B`bd5gLxv)*#f+Q8*w^A)&y^$`W5?1CI*UuGP`VZ(x=9 z%5@BWaA0I}h!~CZ(ajz>O9=avb%ao)rMAAVE-GMJkB9TZ&)gda} zTo<7OijENxcUp@Vr?r5IJgtS&!fTw@VhOOE*kXy%&up=Tj>#hO2kKHn^g|7wUN|yC zftH$e(Xwz3BYy1zMu`cfYb@@gZo5r&He0u2q(KsX$1i5S5GwIO(B zut92&jHxcf$>FR^G--Ic)%u`|)X!o@kCK?Z?DGYMWdkr%BLuAv~X9xchtLNiFcRA=F4Ca zYQpjE%Exd=Czdyw4<5mAO@Nvf-0#4NAr(To1SWp@NVx!qD#`Hil9B`? zCN2p1gye#dB7aGFNkws434+g;ED&t4s4OZfE-o+f6_-_%mXw#5R`|-nVh<@2c_9j= zr5fAID1b79kh0R!VuXE?hf!`2R#H@1Qdw4BR9QNru?u+&<%YA;3&meiQc_l4f_F!8 zxv#Rc)L-T=1+z~x(2h0)VJc?zU1|i!Y4I~gjJ+~1GY}@J)6W?xM7FtVuP{Po-lc}G zG$Nz|%!=M;#Og{Ay06Kz*Z0+2W4aEM+OIJMTa|yUDaNh{t~15!G90TQZs2m)>E&Ry zKa|srdbBK$xcD#V@%E*1lO8|GLiwVeK$@b-m=Ec3QZeQN_>vxJQ#!Zmk-B0gE}X9j zT}r*g8~g1>tdzu37w#~k?aJv+BU+c{SjBWVWdMCD-dMmZw5_r4>EV!3hT|qEc9`?v z2@pZlg(Mn#m{OpU%4SDzYE4a(YIk~jVF5qY@j=McG}{<8$A5xz<_xR}>{@~mp5z6l zdW+N)nsWCuBf^@!msz-eZ8Q*RZmh4dYgvC`iAP$qrM!m7v(R@zut_nFH`vCSbpftn z&2dBlq|84l0Mem5^=AcwfNU54$~Ho5J4xP^F>x|{Kw7Pc*3e4}KaKql1;Ch$kpHC+ zl$sIp4+??F@DQUpr{sGblog#If9E0ilRVfUtHLkj;RbOPei08hSmo_8POcyf>*tN`M`&|Dj`0LQ;Y73brvV?ctz@n*R)pm z^wE@aPhUsxNM{U7L+bM>-YwE+h7#orb?Rh@=p?3lsAwR5vYoO;kBfQaSgE7CZBTPL z+(X^iiI0Q5-84eN`iRj9aj`^wWF@f^^Z=F22odQG*dP=_R7I5TmAQ;ncnN|*5O|PP zau9Yv;32k>gD8Fi?_gEl(1@P)UUsSgW#UKJX#$q1Ut((nER(;<0-PFdB551a`L8vF z=~ApS1?sZYn*w!-P8Tf9H1B1N=0IJ#CUdARW3xF_moy}Jb?Jg0VjGMgN%9ao(+JbW z+-QX9Qf`t=40DVkG>(&SQT}f0}-^zGKy~B?ddRKoEnWbHDgs0!$j)zcE&n- zhX!IDdAJQZHas%ehh`>#E`2yyOMKM#*J$$#@e=0G$t=L zGzA*!*ER)f`Ou&kBN4Q*1$h`u477D@#XJQWHL2TMkdHV@bvm*p(hzbS=eAxxy&+Md z3_2Z_3n=JeUPgr>`z;%4BA_5y;oDE#kA`yv(a<$DhY-=%KcKM>0B)?S2e`AVM`IT` z2_#MK?1CCE0~ijT32-R3Lt|G1tPfY`<$F8(y`P}aj_z3JNN)`H)C>;x#0K;7s}R~V z)Sl-Xt>b<>jNRUy-8h!Oo9Ekr9Nz?@wZ|sfIVGZZ5YfhCO4_+?Dw2L1MDbM}a)<*6 zH1~a?k+0H^_NAG$1d#0AZ z6RO6%XT%~V{_<@H^88-=O$Rh{if@f9E4uLst$P)Y+biX`tlw7sgRwqT|1Gg$%%?O( zTACa9o?W)txUCFRz-%+yOzPiK)898d*e@^n#dPGV?>N|b81m!hEF*m`PthS!?GskL z<6xIi!$X|wLt)H|@>KS0If9TQq*dMJWLK%Afnz1*2zt^ZPIi+@I(n?6n+QQq`b`(R zQzZ?BLlepy8tm`Dap|~bykl#KED{w)OPci*t#GJ*C9qR7~RNsiZhM9G|JGM?CChB}=HKzA+G9e+&)v zG`0=NWl1umPh!DWiJ=n^q6`cQT%{6g%Bn{a*t^b3Gz!)AnE&T$7U_74V7lx{lt3#E zvd1;q0+F(<#rM?Cwk>hZ&HPnCc$v%u)uV@U=gqydNUUukGj77k0!ieWD!)lv&FLfBk zrs8B*t@8TIHspKHC#lA8CcX;^Wzg~i@7?$|XwL1*g6R7ydWY;rwyk5H zao$Cfv?2ZcB75sG*#PO=BkxPP{}}dTQ2lqb9MQjBiu_=WQag!kXD%As;X%6Bg66r= z^in_9cAh(vqHx?0%2n^0QkQMG8>i@_Oi!Q=ZVPV0(&vR2p_JvkF#62Gi|OL>rVR~P zPpcpYa|V1_;G>RfDF-XMc@w3^wc72ntR^|Gl_ZW^xk1DHiNBaCM9X@7Byt%mq;Up4 zWMldG(Km4PT}dI84KzyUVDOT`Wc;`#gA!2_1?Gu*-!TfTM8@+qKP>s#mMcOnLk;xa zaZO4zFQ<)erO4qU1Pp%G1UUu8XBfCN0mxj7Yc5w z35GCg(2dU`j-FzjN-<{ORd0=fb=E-|H7sj3a&IAQm(OmrQ4J9}WYVV_3i6lH@JD0k zQZdL_zxQNsUOWnLwnA0)<5C!mV&)BZ(W!-%Uour~H1=EFk9zthfbO;-Y`yF09q#EP zf|z{!8(X(wZ7_N!Rv6JjclGwS4dc>q+*McKR3AYP0sPYwh0bJcZG}P0zi)$`Vtc#O>^=hvKL~irFr=e_NDp4a%7a^`36O2&E_>2?llV=56 zn(-O}_$+~VM>RF0se^_}5cV8}sQ_A^d7c8Kc7oo#Vg$XwaY!AsTJ$bQXlPzr?epd> zw=8SDr$=$+d3~c5Twgxo{=Tzk2saPm!rjT|Q>C!vQU!`Ueh9K#Fz`c9TP!i=SrCYua; z`HV}?0FJn8>-|^cLYxwaVwqYl#!H4=T#a1dc$ldaEzsl2RS*ER8$b=$L=F8bbP-pg zy2YYaDMOe@{0Zd$}RlCU11Dv?n4Lsg*=^(Q3WjC!&wD$~8UNJI(MK1;s(0t5IZ78}U z4YmHfE=%z^X^z`w8ogA}=WpQs^Xf6;Rf;>w(|i%Y;dr< zt*;Xc30tuE^c-VVw>a39>?GBEh)zS7#*hM6USArGj+*9n5XiKuXB_P6_!KI^e!B#F zo$Pue0lkV8x-I>$(e$A%5zrO3E%Eo9?8^o=y~tGar;>3dA~U<_m(xX-s7EIuH9ve9~hul_@dz_@qjy8YGp{HgoTL*fVhn6uxai-kiYRahwnx z+K!c4nBRV(YpeO~hxt94z}|N(7Fn?Pyq39og!2WFMmj*bY2mi>E)w2 zj%yuURz6as#nqd!`X?4#jd{#F9hk`cs)O>x@n~AHF3?!tu-U6Qz8{}JbKdW8x|~12 z#p>))M{Ten5{RBr?8g9a6mN9A{C=te{iPV6VCUXr*t}6o`=K#2j}Xy!D6Z4k6OK^5 zw|IrW#9vxjREAxC6_w?cu$Si?wE0O06A56xBTBnwyrnonl09#V1KVhLU42~yqeR?h z>Gc!)7t9F$Qib3zQwTqE$mJ%QQI9842?{SdBvUN5(tI1`&Ns?Wf5$Aq&*NixHY*VG zYvePu0o!*)I;5#C^HrB&X#P6~U*avH0>GkSxW2I#i@>x$oi?uX^cT-iMZuUP2A4-Am$DK?zaS4fq1^}GID!5XsG;@isv~*W zYVR+^pCbBGjI5wDO{qwe`8+n?i-~e{P>~-ME-bGO56zy(B`D$v1T{+p zv3ohQ@Ca@zm?pF3lV^4xXEr%bGE-ds@x}k4t*#7BoorE+nWmwFhip|~&{#eR8V`@n znL%LO^rmunro5qfV^n+waTYf3G&e9t;NJ}fa8T*giq3z`uhG9)y`;hH*riHfSH7!=f zXR(W&=^v^JI7TY1;Lnca?7oq0 zk+uP`&R*|WqGbvuy&UnY z*nNraf`^)9?UX#MmySuI-{Lkey-~%YyiwY%l`S2e*QwCtg*pyRDlOLo>@LuJYi3$@z=wK&ge)R}2=Y0y129$cxtu?o2@ehi z&qf8Ny6!G@Eb(No9}w}$+3S0RFC}|@r|_i;wgWw#hR%6D-0AF+6nDX|l5z#lqdHIc zT!JTjiO#!|(zK&yo_E0h1W&|g3ZC#~37+tI?RZi?-JfRHfakNxf+x#VJjo|`k}uJD zTQVxGiKl0g;z{v>C;0?V^4am^w&nhS9Rkn0W}(`hNqZTEdGbm(3YjReD|4Eaoecz#9G*Zp-j%i)6ZT9lS@;kU}&aF(cUv5@#opwApW~45vSHw z6vMd0@g~yJ68!A%ApX$oDM)UrBI6UMCNJR%_Nm#Zf2mU;POq}6!-s)b{%$!Jk# zi4Lws*R#CTqKI|_hgoeI?pEzavW6v_BROfa(&q5?1HOfZO&dLSYF3kf#Qp;I`%jpV z{k8O7vljI+*dGPc{dP>r5@%Jj3+K2CF3FmRY0Av0GG&=LX(=8Xrd-jpzQe8t(;qF$ zl;+=p`&YQi`1@Nm^kO?XT6$MpORq<`^=7=KvA?sY3tx9AGI-g`w?KeX=dXffJ+Rsc zOvR`QuNEyW4U`TnPUoF8m-O;@ZlTLiQC1zxTv{rSR0EjuD;$b>U}!N(z54 zCvEm#JK?FgQ{H5UA^g)`d*Q_^w|ZBRvR{|}*41_H8Lu!BrcfBvVvWrY0`>f)hA2Nd zX~{R)Hz_h&c2m2d8ArBQufxtw)!S5D#K;H+SkpfwyAhlxGTg!qZBC_4 zMpGj^qn#bY@$FLTQ|!}e?t+KWL!OK<+EHFx^*#`pNt`gknxrrfn}nJ3n9%y{OLNka z5^V(Hy~{agvu{J77jq{m5DjwlG7z0It3cFE)3uYf(IimX*+QU{$8*wV9Iz9Jn$9_Y zVE+YyzP~g%yO9?c8VxOeE(PP(n*LZ9pFI)XLJXk!)C!3 zwB7831?crInGcY9PS4EyHUnj2+Lg2UgA6Ne#;r(^xL zj2>h!g3+%FC(H_;2r_Ccfzq}o&I(Ns%`0H9fy0B#<2hJoR7E48ltpcjsrJB}@hxtA zBQWoBc6gDy;D!|wQkFKXD96?Pv6RVx=e^Dz1LgOQL0OorPT446YPrTx<^?-{4SODx zUp*z>UhTB8RgvcE$R5~XhUJt=j~y%CM$W&U-IMJuc-%K3E2$oxm8=^&D}pCvMf%Eg zvj@QHUjM|bguV<`q%c#ict1om%eJ}V3d|f}kAc;JBF@Twdfu+)Wp5i1T>~}Mw2c)f^n&s)*u5vZ3ob6sh<{m`CjM>AlvAd;L%cLCO$z$Ya>UkaX2uI=K`DC!%-)%Z znJgMr=%QpO8`PFzb?6FPx%K8|!V`rO;tFs5BxdEh~>ql+UJR@$MWo zTtfqGn8b@K%M*UcE?MF(xW96$GTD~zv1J-p8eV!?E$nJY^VrHMN@HK5A4M7}udG+u zEs*BtRa2G5W)(4e66H0%ZZK!NsE^&X#9j5(RqT(>WgWde15v*E+0T0})O6&ck7M2c zcNF{Wez6Llw^;F!HCo>oi+=?8m#t=>bS)M1X;TI0;|?vXfMP@6Q7ieEfPUX<_F0!C zFVS`K@%Tjkt<~&0*D~7C!Mk3d%o2qlMBlPqkR<~DPp7i`UHP<9%$o<1S(@b8O!z&0 zT5g(SUgyv-cL!RGCdAkd%CT8%{|E-J+R@hG*tP+zW$+LqZ1j&?ICyG7TAiw1$1jy$l)!G-^(g-0*;4GC#t!jS&o6+&{*%^V_+6t8&o~co7ELEw)L9Rh8jFTSu zU;fh4s(u|{zv0yI4cAAfcBq=Yt7N0wIfSmKAe>h9dNsS)gY1RZA%D}PaYqfimS~)T zOih!-A8Xi`g&5PP@wHm^Z7xP2ylGmxc)OPUMCxLi6uuc`F9=QG=&|V($6tf&cTx}2 zq;O{)dyi9S+z_svtPon&YjtdI0@*?1hQJh(UALB9o`B7XR69h5vv{S*l9eONT;<3x zv(Q#OzLtHSCqh|II?-p>u|q<@hJa+XS=2wH9twD9WSeQ1w5X9<)f4}Zy*Gi6v#R>X zpF5LDrcJsfUDA@K({x(WG)ZT&r%9n%CdtsG2}!y^aL6)gL$ftYn<7hDMP5`Yn+O6T zg1C#Q$jd8G5m8VJ;)0@rFKXEo6{X_B|9kE|_j#U~%%o`mKfeFZ@A+hM?m73|bI(0@ zeeS)_y$#}vX83q^nM%M1g5n!2AiiOz67c{g_}xuX;5nAJ^e zt$4Ljd|=HQ9h}Bks`FSgK*41XY70(%M`w38b;`QGgc#Q^EADL)57@+*UHqDRr5Nf2 z?P88bi#bYS&Z+!MllaWZt4SMtSUj>vy`RZs1aT`ov=4RxIL;XkcJ^bgjNM&f?1M2X zpV%TEjR-7LLy3@q0c7CCw!m=9z#YRQLp?b23a?D)xfr31A;*l$4>XIbvZYQq;5dd} ztO)5wda!z0HRyG;S==>AfK4|RK>D!&Qjr9ZdWKdfmTq5f5pOEd7`pFKxi8J6%@e6r z4{Nm-P^9CdR~qM#vwLWioJQq0P8T<>m5G%CkEf*+2rWsVam*BG9Akm;b=N+Hc8g=u zh%A0ht9V%{K^Bin8AXXyQH(LmLA;dR+$OHfF|#o$btDw_mqN+-x^Phjs62VcQdjZO zcJX44tgw;$Qmm?*vrJXph|x6FT=^Q_q29qe)c%@|1M-c$;{b|>Nbj(3wc)W`Mu)ZE zhU)z1DsI>+ZeJ(se53|e?MKN|dvwSwx}VWIeC!n&?E#cRogp;{s8ZTHf_)p3V2z(M z(2#Ev&&G_{Y%efAo?gUgLC6|z74cCO@zIVr5nr)gT$d{|KPtug)kO?VGhUp3XiM-j zD&A*e#=Fy~cyPP;c-}f{&*(cWZk>%ssf^0k0+irpymr_v`lv7}kL(b?$dl@J_l=7`dh~&lC?ws;;a` z({eD6I2=>=<5_ji;+a~t^7#(&YNSHamQ(9<99vp1nw0u?&6a;WOMG&DL@{7nqC&xx zLo+gE{$FNlN^I|VCMz}nkCk5zi6amA2$qzIdN(av@z&Ym>SEa~L~r}E zItJe*s$ZI?qw;Q&BT?dYZkexxVPjw2te#ZR@H#ZJ=Gd2NRX#Cy0ydX4;Oa~np>)OqHjzJ zSG?FQZZ3(fve`-bUyQHvq>(MOBIS-M<;;#sDhHyK23vCCt1J#jt9-cPrm%RaMApSg zR@U8H!ArPOOvf`S9cITT)A7s{MixU+8oO7dJ=7}}nIDa|ZLO&ZwBgDl zi-d34wl?8=o)C^GYHl?yw0s%^Tk3HRlcHZ>(beJTLEL}RUejQlZ+YM}ADjqeoM%zm z@MY%K#;R81y%w!KfUidDs)CI;5z9CipO?sozKO-_lu?LZ5x$9aF2|><(#J5y_4Du@^hzL3 zfphSJxcVi*Ya}P1lI(Qj$}DwfOq$EOH6}5VWEe>nVSb`v;6@p`W`=?o#w-h|LBLc& z9JB32A|z{q=18#<3}cQ)iFvL@3}c>lTC(R`Bw}8$#-J3XCLn1}cXBeW!67F(7G~r2 zn+$j^l8!mJ^(Gl!>OPz$$%b;I6U{J|B7m_>`};9aJ4tbnGlS^lSe|SU$eaVo!Np~> za6qVX8iq&Hic$1gE{0R$2vvB*?DQm;k-1cf^W^!p#FODDN0fNK7~*Szow)9r3uonFwG!7)I)L@ zMsYquZkSgwuY8`RtQ61?ag@9aRky!|cwaZ~N zKguKBuM|*-VbodF9rJe1+m2M$E0RVVNSF>6v=CD4G#iR2HY?OH8p+{wSEdvpb52E$ zHCY5gw=9A`6{Ti!;QoZgvV^KEHH_00N?F~yL`tG^(MC>kv@4onY+WKt)3$V!rtRsn ztnVn2k{q*g!MIZ+hH(Zvq4b%`NemszX&7f|PKxtA8p)kUXo%57Le5r*^669v(J}b( z&sVW_OD7`gAqPbhCWm44x+K^|fGYZK7wc*mee6W2bClCC_GoXC->(rB^MK|jzd;g6 z^>Ii#AY)jkfQ-FYA*ZHP0vS+9_IcjWmh|vuI!bGd<5-5n zVLCVmUwZDMT?w?)ZJ={_n9fKYJuuLPkK^Fm)7J@fe0Ug#y^L-wFE8}x%6}y#ML6jp zuX}iWBaTQP3s2E>US3{TAO2y;IXphLk?!Zf?x}$=B#t3+ochs$ zZ*UQEz}MA5-LthFUtM-TguwfH!vjM-;f=jRBi-TIMsN_KJh0V3cyMfV1M>nE0W4RC< z`P0+4udgTUq3oM%h?%FZD)JT*g_>#W_T&xCEMI!U!RWLB65GV1PTsfEZLA%*7qTOyieHnj3tUl$anaEZ9T-!0$Rj{H zit~N>ew2uP#T~Wbeb_-K{os!yS~@JbQ9@K$(;K%|Y~2==7Z~yZ)f;i0q$jUd$x#mT zDONjU?*cKrik>z<00V8Dv%WNUuj3`9z1sx>1XO z$*&DWsT#20q7TjL%-R-(f$aJ zzuBW22S4GaJPM4zD(z2+1-{mXqa&KVz=mV6JL_*Yd@k_kZ8-X>S&!Oq^i8www&9R9 z>uQYyLHcH$1sqWu38^wYvvO=W(&K*3J?4_&ytsu!(Ip9PuZbHvm8$;&++(2OROc zzG34>{4QPI3>ClYY@0vgcR?rhz`qb?d&Y*Z2mTQoj`Oh-u+c<4;K$tq2^i3rcovGt zvo;*Iciv{h!Rzd?;cI}?AWlAzhxcyBPi#2OrgB_k!&=F z?-~9>(FN)l$-#`Bg2=M~;YhoL$O8%|DjBb12)oO0XRtr=QR0IPCzyUQ^IygA!%V-8 z@lP}SB8NkHmGM5t5cwzLhutOp*9?y;e#b4!-|;ENIo%F~BYhkwe-z&FTZX7_M0X}C z+&P~i%C4lNj!B4NnuN6~KIayODDRT~9>#YwM7k*+C-O)7BYz}*HN%fG{SM~;Ji~jL zewgtm7$V?`?x&+@svxFCc0Tnib(ZWO;On<3gz>Ay*Zcb&$N?dD>;x%!zOddl#ZGQ0=x zxg_rqynzxtg4bI>1NoKV0DK%yftC;&2ioTr!6voWe;u z!bw8 zx`aq~I{ClO_%Vjahozv4B+SGCrh7LX=ktpJn)4hOaUFr-Jl;N_-Bqy%J_A`HpoAVNZ(Jv5{dN z!)Au(D?2zYVtAQKkK=0gzn1ZjvwY}H_HlfP{lCIE>@4Glou&V;+5Zm=p)cv-gncDM zUn3#vR$39C&_an|0V2YIK*&*A@r91S29F@CUJ}lCA^Cv>@4GXfZ?|oexD)w zMd|;Xf@lV0xuN!e%1?q@r7K~+VR#5%$T-Fb6fOZ{14_5CQ}I(dTueBiET(CbN;*A8SiCy0YlUq z(#y^5lKWYO&q`(JWmw6O^O@csDBP^?GSuN-SNLpB-|Pm)FJ^cxLoOGyUs8B7+dp{& zpCxh{3hG@Sj9djOG_%8+LZe+;zo!iGa z$`|p^eN(}Ca~Q5+Sj7(GbHY6W_bf+5ChByTy}b2-~#`FTvgn&E>Au0R7p{43TotYg^9@C=4rPF8UKtUx;^ z!+n<_=kp4#-z#2KbWaMywG2xbp2D!5A;;tCVw~G?&+UwViXq$6^DyIoWcUWdw-j7C zpJ6e>3Wl6ND>>ek+%K=Zfc-CLcmu-+7#?QG>0SAA#{a2cmXjeWJlQ2HgCVzPS=_#6 zarw>S@|(rwCyV3F`XGn9l_AHQ^%&zv7(TDyDsC@UalEV2nC@j*$*`K?X$;R~xR>F6 zh8HsAaUo(7(;hz-5qM@{hm&?6(731p|7BZ}3$aeAeFy7CQ z%ej~9vzP7T{UrN;j^S4rvc0@)C-3i={s)F!URKXm`0AAmPiDyVVf7})w=+D8VVL1Q zhMaG!uVtL|TFvEWHRt1ME z=k>R-|K}CNt|?h=eWx%yO+o(xhRYZ-pP%jL{~ps{P_Tf@M*-KXg6kFC91o(Lmch34 zKIkL(lpLSuV|G2?Jdu0U$j4EyW1U@qyR{4JV)=5lCp0|XHP|_TWB2kc8nzS-gzW^{ z^J>R&!2OWIv6wXm!3PFp1l?+x%E+fR9V}#pc4OBjwwS83=68(@=X0!`UAV7!U;eI< zq4DATf>6}}oirWl?;75{IXJc_>@5fp!RNDujI~VEjj%=A>3H-|b@A@v!HHd^JNI{o zyz;>GsIY1)3y(V3@-xgtdaq$`?nt`9NE_rDDH_7U|_Uw z6iYV)!&pKb$={7&yY|UoyURDXH}>xz@E4TD3kI`wcgrw=M!NPUH10jE^W47H{UhVO zp#VvVOiB+Hq$GP;y<{I7E3V!?&=uI{!->_3Jt7Y|VOT(nAm{rH#s}!+Mk+3*Axb&{4O5cAz>h-oaG~p8Ps(pn`-ZpPbz+1JUv7o@aV?(3g z?`?xC7zhOX-r#mG&Z}?RR^q*&t$lON=30f80&QsYHq)W_0dJtXs?6IOIK9l<(i&(h z^9FF?<-P)=v9HVPZN+U>;n6X#7uM?U>yk^7I0g)=;ZVZPez|QLw?b@7FaddU{suJo& zS(r`{jm!(LF0mARIz@I;a8*iV@VLcflI~m*-k$1K?V;GGQ+=Y8S62vIwTZ+`r#i(H z!?lZKOs9H9$)Iev@^L!tQVapndkDHondvl&EQ{LqnHC5RJEPJd!&<37fl@3(&bSm!GqQGJwQXH*|$NGltuE=?yNx&2Y0 z-(G#R$(UJvlme{WrX)-!yX{Gcne`{w7N5Yd7z3_QC{*AN#fUf59V+SaVYe1e9>dcb z*w)rSqm&a0g7XMe4<2J^XLju&wtzV-!G|J~JaxZcG}#NIK`*XWniNE~aAk4m{>gNi zf8}xLG33iP9IwCdT^ez=2bLD_gx?9MhtRiwx=oHFdfo5=*N4cI@(7%2S>48 zaiDH|uzRczH+^@++}(&z2YVp1v%iO~9q^7BRd{8smjh|J%O=xRqxV%Bi7B(h074&YK<}_*w@_pr4p;{&~9YjijN4k-j0OwM?^GYE}sgip({?8TgnC|1iySo&C zxe)mj;Xg^%54#<=gFu2cAJ#Tv@fnzVir}lndi0M$(+?$p9?VflK8ZkVD$sOB2^G0(#Y%59ALd}3m6PQ;Fvn}^3TNs)K))D+ z4|8R9zJ*!<2UiqK%brY(LGnl5E$GpME%AX?vS~E3bxK zQZy4F^9izpO+PQ$PU}Z?AdY_C&m!%|;IAJYZ6d#RI36*%%ybCM8QS&B z+XP(emkW0s`{lL3?>YSRqvMUzFW(1-t27g!=8MuV{{i?tG?`EA0?lT>^^^{+ALh~H z>9?NZq%x@=9dDF=zJ*|zM)~vY2H$73FhG_kHo$Gu&rkB`NA)cazc}{uXJdcrbMV(s z9Q`WYU?5xTNApG5uW|>XBAR|QAGaI2oNl@os@H2KK%I_RaNE*R^$+0M&RAcImyYTb z^fey%>qo~MW#?cn7;e){fSNBV9l101fgf}^Z6DC(&{m#DwJkQ49!0`LUsO5{5l%8G-sCCxhGFM}%tz%_ z#~YR2YhHsN=}+?J+W1z%ZACkm5mVTdtIUiy^ zA7Gq#Z`}<)5Azk-_?E&=^@X2XuR#9ZuQ5PfXDM%Ne79Glm{1<;NAn37!p8S`8kcoy zCP2xzzOcBU++#idqO#)hB0paBJs$kwQU9@YQ&Ljm@f4MpmlsI-*|RSUG}Z}+j!sI< z)^b%mUpbp9EbU6gla1Yd+wR{~KYaf~^~3l24vMC%vjf8yXT3H2%>v;ymi<@tp(9z( zCaj%*#J6_Slk=bRu5>zPE!%lyewNem;p#(ACan|~U3AgI!Nq4^v~tw-o##&S8Z|G} zc^>f953fv+KJ(!-4xhOz=SzGJ@cqCOS8kH{Y~Tl6-{};;``?Q$zUXi;3HW;@{&T6J z`bTX?CVm&dL>Mb#5396df|$u`YTsa=JY*-o`yKnb?wz>YlFFum+pu{Cr)1KkkJcMA zKfa>w?k+#pUe(MG9V@9GDTL}N*=Lgwlg}NHZ}nt0yoZN7^jBUT=)of&Ai1X&A&cP>LNg~OSdJDU-PhHIwc~Kxd`q9+k zV{IJyEJuJ8M};_p&O67&zdF_}pwiPJZGSqNtH^toPxzn}oiLO!di41!Pbm3l9p72` zhH7wK!ug1iC|u6;#fuZuoQe3IpO(1TwaB?QG0o+4&clC~GbwTOq(zGo(-N0C*QF6X zafwSTlwR8s)7UG0*+P&Kmo1UdIkD6^CvoXQMN3S>NP*gP`8W*M`Ns9v(^LYr`i+L; ze7A%+h5>HkA@g3%bi(PuwkOc7ujGJID^qKTb^vM|;Y&{Yv(ON2b{y_hL$pSb(hYHX z6sf@$lfY6yZB=_96!K)%g}Xc+zo)?GFU>;N6$;VpJbCzi8w!dy6qhS%TYGH{sD8;J z5&mSEh~?!)zVb%t6{xK@*~o2i75Pd{4tbnV`_2}MXnc^)`^L!w*ji&Uw6wR@2J7lV z%%i*MYSLd56Y z5kBSz-VxMENksY}oi#+0W4X-C;RIE+)-;4l+CrMyP9_mPyI~}Ad&AbIYER)LdR0kL z4DKolQ&}U^ckssQ(2I_-txX2zEymd=ED_qr5(-sQS{q~4cLo8vkqS|;o2i9Um#}t-5u@-Rz+G?t(alpCFQW!#kDmAdhw-zCn;tU0*#|ugt zjK>R~5ehXnZ>guBN46sL&k(C{V03#e1czz^HH~c^e3%>xk!iNH86sCZVYE^3l!cmt zTReH#W@v~p;MlMy355lvB_NH1gc3uf>Eb^84U}MQHLdQ)g#k&R(z{Q1Mjl z@c0YRj-JcW0H;_$c`wHTN`b$qw5Y7GqzL5mI0}%hD9Q^83JXgMe1#=t#YLs1#bv%y zL~$V*5@{g`#l?m=D2PCb0i~q4xDd39B#lx7T2VoHQF%#eL3#1GAug6alo}b8nJNCV zqN0-0BDDU6rM~jwVtaJ-E6lf>ery7}ZNd6bReN(&uqIZ^`tt~XgteEH=izwa_4P z#6O6D!emkYNfhLoMfn#|P-G;D`zZAku56ntQ{ywrZ|q{&a+xB5Lqe0WJ$49NXZb z!7!opk%0%tKb3gKhp|&9>?!hOchSatbcY3NJ?%q7{a}us9ie2=lOPiLZKr#8=ZKNu zaE{rDp3gy7x7N;tlLq8)nDV&49D5|71oG^}?hjsk* zHkzqLgN5J#131JH?>2 zHK7l{M7tr%s1i2@w*)}w8>B6XhNz%nb5%RqWcH$2roL_)$0?!EmS*g^#ETvcdT|SJ z|LAbII~%tghR4Q72GPt^VMyN=sHJ%Hw=Q@S$Q~aJ_t1zRr>1QWRBev--XHGVL*AHv z*t(^vF<8GPP%B>z3h^d_HZ~_4FB8L^-Fq<8K!uvj?a5gSKMHjklBU8Cb5zWo{c?hW zSz!!13{EPjd-m@}>*dMzZAFT2fzaCH3+*`}p?8zersHbbGjJlBeg#6YNf#-^ z7e|Kp1)-Imby@i}hd39n{J0Ur3h$L6x|ub0 zz=}UP#O2iRP|U%WHq2nkP_d(x3`&m{qvCT;@nIdb>UcpVgBkRwQ{1A1P8=`j4q`Ba zeknnGS_f@uYnf8tmXV=u9FL0YL%a91P)WpBo?1}ln+f8pG)+P_lY*4J#)gKQdnup{ zWhk>vC8**dmpH67YC4WaO`Uy%vDLXeQG8#kBc<5XF+;IBCLW!rif<>1pJ`oMT7ykh zZJUo{p}wZh(LI(`E=m%=)oPdmlq$m`idUN?GGxWKlf>)Jax@CnLCls*Gplg2MX+7s zpmLzYS_=_7JJcnU)=C@ojmz<)HS-k_ePc~?Qwt_7Td8|=W;ha@Sx!0;2+vir{vVuf zJ2IUSs9saHKE$J5+Z>l-nIW=OA+_~b*LY|;?U7CLe^!$uO)AGIE8)z-Zx!VO+HTCr z2QX0ag&IQjfh~d7U=4C2%aI^9(fGy3V;H^S&{RbeZk}T5>@cL5%z#@0;V(PG>KOhW z8Zb-_CB;@&di*6@*Luz)ttQ1xf)Od^FZC({_qiBl&;o)S-T1Z|&b_(>(Oyk@KRF-y z7`ZMMr!Sgj8N#3{)IH$K-yOU3*vfz^Kx$3vf#Z}POX`1O$x-9m)v)Fo{7$B_vj~mt z*a)3tP4nDndTE>+bDle$yzuEW^3@!g(vWRzHxA83o}NSl+*aIhVa^LLM=tZcFviTv ziRt3fEn6G0B34EKa|W`Zc)RbllmeBNR$c!T=hZadYgxoQmT$1Id=e6@7f*C|Mhh*> z$v2TJMJ~N(&_iWxEq=5wo%X2ZQr^I#^jV$E8BE5<%^Bo~o+z+S)ccN;VMXjOSM9K9 z7c*Z$jd<0-=pDzRhqALe=@9BH`G$a(pN6V!0jWf7^VaId04?j3YVj>txSF1DjEhFc z=$)fNhplS~?5GK};H|+dd=cuHAsTduNiSZ(NFS8WI%uO`%bKm!M+lCU&fRFE8r%7m z$((M;S-XZ_e++RBWdr;AJ?lK#(JbKE15*X#N*D=Y<_&ku=!KPE2wiOq@q+0_J$(_# z?#@vh3eeX-);CB3G5Pja(Xh2X5ZZ<{LbTAm{X?B&xC|6`&;+*x+c82w{BM{njbM@U zAU#9lUH#!`#$%XIQ{m!?`kTN7Hy(5Z=3JMrH&j|zBaeC@d;CMl#Nfi5EzMLQ{%PWz zr&#p8#GzG2G_f^#+}S&fD>+9;`+5&Z%Vn#TZE|ni=wU>qcCF`B8DeNh)AU-sx-a@vAgi% zhmp2gV$9B-(u8Z)c(gxODJPkjY)t*Xv~u^ra8Wj*$@OF(Si9D<1_{CyV5$gEP~Sv> ziEc21^_)O3*ya5RW&&{BMrZ%OBNghz5@gGXr6OK1q~aQ+0$-b+NY;WqDqocVNV^Hr za4p2>zrz+$Ick(FbkQ+5DTS8ClZO7^Hir366Q!z2x#<5CsFyr6Ccrfg_+ zh-jHw48(p1V#gsD2Rem&{v8FD&L5(OE3bu4o$VH%Y`IJnN%*9T)+VrvaQcSf01L@Nn~<5e5hVmN+pp#_HH&e_%|RgL)@<@mgM(tF+XUf|S$6LR3J z*0B=Q{&XW@TH}2V{w|F66XZ|?>s1NLPUZqu^m~BhlP>~SU>S8mi(;3ALs&>n#m%BO z?UgS8;gONuor67CNZ5tNrymMYahpSYNSv&j4>f4$rE3Ik!c~@6ghCPbHybzMvi2t( z;+p6XI>4b=0S-FFN38(V6>0XE@;^`0ho(kg*W59M|HUajX>n6Wrkg(^v}aRn6>F5h0ZmVU^756UDcpgB~YR4vD$P@9B`bLDC^(ChmZKl@1aqUPTj`_Y}=f+~P~FRlS{Eqjvt@h>`|AengGlcPPK4{mGq^|N!krr2P#p<70aJA+!KkdLo=4Tv~Cdo(Bigi^@!N#2)!|~tI z0SxB@4rhY%e{f-{c+627Xl$^mtR?VX*tTv4;{4mNh#A_h53#U?V9lv<3Jkmw9OCE zhT0l}b?tad#N|~UKSlo|JA=PiGx$q1!;c-j+(a|#(IUzr;U^A`6pO7i-$tqPO~{id zF$?h1XkVGkGWh%o>1^4G4Y(>C!c>>|s!Q-{{u_r};w_>Kz@lMWu&EY{z_i1hww}xN zV7+W>h})bhgSKvoxfVUBSEE19eCCWy!~{!c|NhPcqdX5ouj1b_BhJQgh$C`cI#QLK z9D2i4z6kKB8GzQ;+S+xn?5I#{%@E&q>ZCQ-)wKo85IK{ASg}0Dv6K{P`8nCJ3GF`c zL@D$Gu(oV&sBX{3-fMp@{uR)_LL>!)X$nP_Tq}LodN5Ir0V>j?>8j+_;i1{{r~ueM zg8)ieL>S^%V_lf!Nu@!1^-MLeq{Y(Ulv849K(SM}wKTH)HEDo70DDWb_xW=7`E&Ob zHdPcqBtV;jq9}gFP4bbjdrEO) z=U7#Dcc`#n0{OTn93BQ}&F;*VySY0(8$H>3QQ^nv%?Z!ml0tHKO4)@-0cHd>al(^> z&E23_^FNpiU+aN^!D)!E%E;QradPSmBg>n9WcSO+rWX?@O6nh9{cpsym1U`Q5vH=s zv`la~rU@(=dDD>b=;V}H0^)|Z<-?Pujm_Ib>O+Pzuz9C>O9*#^2U^iiJ`=-hN3b0} zzbFl2t7P+*#+{fCjuZO1sd%IqwSIcDd`G%^(mRq``!e@mysf1$`iR1Mo3f7Mqalwz z?vd1B9$Jjk>#2pCc#VbkcW8xdBHyt$taoHnM?%7+*RvKNap$ z`7=`4-o6p^n^1YMI~>|u3ja!RzuT2_*g2KR!;vC^N|8rni1Zgj=7+>1ka>N=6fzx) zBV-aPWgd$mv(OKj|0})^nJ-N#^PEVTKuM-ZpDdHkIZkzyil0K}4_))goUq?697!&- zF2bNOQlB|IG&#kzQs>ICA!^%G;b90|^&CT50qg?Y< zw8MQpmd#~4TxsI+xvrdFCVN$!$ILk4N>Fja<#yhaoN64i$9Xr(pNbRy=_*dRGE|&! zd1A#$>2$qMT#GoLN>Oo&bR8$TRGj2;JMTG)KRc^s@LMWdCfz{7m~t{8XYMzu~7E6zday$0}#$aQptg zo}PZ{HB}>D-8a@6-q+rVRc#~H{WB^GV_>1qv}vfPuNS+5b?cVGQtLXq$FO6TcEO<$ zoNHuBmu!@*LzxS#0wZgmyI%YV+J7YNKTZ26y^Essp5+p+LGL3A-xHoc?*m6ZB<(T*xlJenYlS`A;qRdeP+z4CG@lcD>B^w!>JF;tR zw{AC53@q6k%}SkLHQ$|*vhM# zUwxoJm)``l*EMaP7%wxDP9QU=#hRQR5Y6<=Z=v*LrKa2xBQ3HN&AU_l3~Bky%Jj@O z4BwErxim~rX=tshYuAZ@OfCwND&Jccs~tjwb}Wfpu_S$*CWS*gkH7z)YJ<$^QCSD?^Oywg;O zUUJMlP=m5ag=m;&S|@e8O`+5?l|pkL&q|&3kyr{*)4AXk@xM^$zgMSZHp%QlqhUnP zrQp5QoIO#)LcBoBsTE*uRUT*_1zVZ>@ZK4=ii8~7rJgVTz7(V0HPeiP2SFT%%!Dc9 zpz4|WytsUsE9a7vryB=q3@oeT05)YhWYJCwh(n0uWyH~F*=iVjN5heQ*L3ZrUY&;e zCz~woZgI;=uACodpFmVonk{xzWVwY4#odVN;k73c)l}At8I?5P!VAT{i0Yo4=oueb z=yYZ*Dv(*DOB`21`}C5U@xfGws%O>|lbm6~EI%d(F+vE*D!1?@ac71r=h}7AGd~fL z@<7mx)G82`^lsduhZqXlt@16CwJ0RMhZz3)4#hBv_v!FZ%!nQqKS4yl%AGPPaw5p8 zv4nEjo;oQsL9{qWJdYS2&WnyAaz<4(0@_&A2H9#4iZi~&jcx=MUnL$|?#j6-e@e+* zhPC9Vx<6Sm72w6c72k#AzZ^%hDzc_zD}$-!nj~3f?2=95X-IxG@bSFLPjA4Gr{E(*P}QV~&p|>6PT4i?6P5 z#rxhov zO^j8<%xUCTeA{5ocKM+A+$vYaXDY?3&NbcreZwKS`Z**=F4S~*F~*79|91@g?S5W~ z&s!q-ku+N0n9P3^{8w%i7bUD#@@Z2ASEr zV-gOxT1|+x9aM6Qj-he9yc)+k#=--`Sj&*rW+%?*(KQZkrqQlD%sla0hf(pTQ^g-5 zbf6S!9ga#J#9^g_I6Msyt{>`)(-N0<%kO&#d2nmScO zlF>03-qi#pN#P8gMx)|T6*i;ej~ zd{U_~a~Yqn6I5Pm4b~`9Mw)$|Ezkb@X_%B+b(HUBaMnD8pIdP@bT<2m4FWf#Wz?$ ze8Wy9;QK-Ggw~*ulh7A43HTZ*IthKS+tsIupIZVr4JRbw(bL3BN&<3ung!IT_{VAD zuNlhU;Zx&a%X`5?PQ)5+}QX!3%G1)j&sP1eOFR#v_ z4v@AX(2$Kr=-$*dYueD~iFCB=R;0kWqr-)SS*eMw6|Xjm53E_EgVPvGbslR5D7frF zZNaJU=EgzMB0kE?&%$6*h8TidA)UmZ_>6F`A~D zD__Gq)H`^G+F#RgK)#W896<39=^gg1HawQg=&<(NP@Vr=#SL4J`k z4Ku25XhZ>a|7<^THDhOL81FlB)X^oGu=^MOx!XoZ03{tRNtC06F5KC?r;V1-^zgr9 zKTDC!hFmqz$V$y^sl4tCabg7m6oDVn}W-UR+ zshM&mU#ShklxmOI)$X9+;lUpDW@A*|d8T+cQgvljnwEok#Nn8_AJ3|D7SGhGmCtvG zS0fdYwwzj@luHBZ>jr5)}%j9Ga0S^ZznaQ(}9^Gg+zmf2{m+ zNIV&-mon*8Y8}s_L$IVw)VpcXinq=dR~O4}A$r@N)iL-kQ60k$QYU?^g8P zgzOA@eX3LF#TD+vtq|9 zEgX1k?hvjTDlx=nq#5Tu;#^qyS*!Y16z3`{he{g04x^KP>9pmw1@u)aG@Tp>pRmLW zR8)pQO|b%DAv<26;t~Yf5-Sic2#Fi2z(;X4#|lAb#5XINt{GwZ;lq;46xsyuvb>zP4BaDMRCH>XY9Jo*gS7E}g*{&r@W&pFT6} zj30E0tjBkfhUkhP^mqlJJATlqih*CM+!H_WRE42H7KU*Az*829GRoQB_<^S^7`R6j zp?Ad(J!R?emzR;bcgGJtjWUveRz=?(P=CB{2@N?fGBhwSG#DDAP4uJcU_~PHCxFyq zp^d^lxR=KN{;xYq#DCU@fNF=X^9h_;@qlzDOK%6U7Q+uf46tOn$0Z4gVwTk2vi9^lh66!2dP& zzcA9Dw!Vlk{0}*m{I^6T1KqilDlP-Zmob69Cv}^N16kMuq#0)8l>Wy6XASA zbIgn6prQ|!m%;MU1Xd&}rBuGLOL8t){ztP!C02G^sSZC_enl)W=#r>-O4QaUM>}{f zaVehlkvwR#Xuy~1m;ldR%oB>_LF1%&ZU)a2%=6%6(=pdW;QAADz2%4$MeU7}^;>X# zBvI+~mMfBr8WzdrOaa$7G*@yYmux{4TLIX9quHXYAe#!swi9euC2^clhLBByVmk=7 zdn8+GER#|>c2WuWG4n)8B9ls<$HDU^^TaTz$ zS2?&|)?BenD!D@7Iy6hg_*P7lN;awl_i476CY5ZT1>3JQTa+P`NhKT3UvgeH8<9?~ z)N+S0)!c+P!SrcniYn}qiK?$_1(<%oOczEL2+1U?u&Wkae`T)dN-o)CJ$9V~wvQz% zwcd)V>5@%WX4fIGJ)+s7s=JC*)@av#;Cn^$&5NO&s@AUOz;|s5N4p{hpQ_u5Zt#6Q zg<9J*TVpHV1?6TNY7Y~AVEUzGg89uB*x6CEY-ZwX8;Ja=f#fv%+gDuqCHxcf^a1fu|T?O8UB`+#Md|tA2 z5|x2hC2wp?vs^NG(hK0daX#rVG?iRwcK3WRe_JyDA$IPtWNCf(MsWW{a{nr}^_g2{ zf_o3RKY^K=2gI-J-MUqXv^8Woci#y1rzHD>DCO}DqO!#O7}zgLCFyapgr%#TalZlf zds0>HIGAAU#oC1|?P^EhtTpg{lDyI3MR?1`dzS3}rFUwSH#J1FknJ=O!{a)l&!?Jo z1<)tVWT<^?AiV-oc3W4@#5vxX126=|a9k(2wn8 z?xI0{(@v&zN$!LdcCt*Dq6h4BnJz`&W2eh>DSBl7(z`H6aGyPZN|y@pE4znEm-KMC z>>je$k)_I&Gl?#XmaBOZU6n7_zDXXckhwlK$wQSi*CUfWxVX7qndHM|E^*-`A1-)_ zSl}zhi zjH~6l_hn#%)Qj9Y{dP`s9~B zL+O)ii0XQJ^0i+3C2!P=J?W|MuzxyoK432;5^9GU@X)AehhC;QXJ&WAUZjgCmRGZ=Rk6BaoH?fDx{o- z;nB3B6vJ4lk>un#$te(>HBYL!s#F563xKS@njE;WND|^25Sc?}=N)~c3 zhn(bCr)aouBMmv6mj+c(U(%rddh#hsQT#rIPzb-KW6nNJkbZ?}2JvC;o*bCI&qv4& z^D5?*&vUv@O$jbmwke4uD`KfdtY^M5i=={k5NmlPkw_aXQvG5gR9FNR5c_N*Nrth} zBGkiHr&y?^>L!@%)JP9fmdKkdvQn3bRTj}EWVT^cM|wyhAlF!A76M}Jav05z@|cQz z2q?rb>MZJxc{}HAM=I+TNuv!UOot0v2q|`&4Mh~26>1obIak@e&t6P^yNmMS{$VrZNMKg@8OJr%yJ7k$Y@U&jt~4iD44N}~q`x^SQte0%yjfsPLkgnhl?fuWx8MhpSE!?TUxAmq{Iy#u((cXR_X$6rw7@6N+owvU zhMAkk`Ub)=bHtMuj5uP_#6h)R{b{H3h?7Vit?hx1kSdZ*zAliW4)v!aVmq*=)gg}( z?!cwd`F<3TeZ?KM;eGfLSNg#pM?H5~a-)Q(u%y}!qK^I! zyuAUsZuK;rL-)Js2fb+ojw3xIa2)12CkxD1a{$88_?u6qVWj*-V+qDve+2$G;|XAf z{FDc6IOOX`c;K&A9u=trIGStyNPlz(=0pBTCWbKqa15)=hj8>G=0ox^R7<&3Q&>Ms ze}~l1jzd41t5y%f<1hIZjbjdta8n)(&AtRUqB0UvWqM|Bw&6(6Y_O?kfy1bPiN0yW z%YmO~!!c1e>l7RAgNgrX!%qVKbsN3{_mD&SQ%d>wEzPZ9qTWZ`#g{wD*!!iGbi zq%Afa`XtevqVhp_=#%)O4TnC7_t7KTE+V`L)s-OP@euqT-g^l?X&C8Ibjb(0gg?R?Gx@)X z>s$%`OVM$3rt}w(w+wDESNUVdg2GW3vWbrJD*aJbBwoTe@>Sx^jK7D&cQHQ9IP!+Xh07H}~>Hl?xtgquOg*#Dq$lr-F zF5xDIA%^ENJjCz@hM#2!JIHW{6*TRK_%@MU{s+@}1hrkijCW_kzlJG3JN;sGeT2gv z6?XbTyiya6{;8blC)@o$gBN-Dwwd6A(zL51B|2HA-)9WPhkGU^A$bu*9`xxVA81!TNrZw zC4G+ZzbWYE{CBrA-plX;h7T}AJ4*4ppH*-c>Jj0y&|gbf$&mAT*42!Em!S^#y2593 z`ervUelf#q8FIOp{gT3y+5X8J7;j|Q!|-;7_bHg-Vz`7M`XbUZWq{!&438){hwU&Y zgK^Y*;-7=|Si(mb{!78R8yT{F=k_s<@W_8x{`V)&?n3)v0}{fxhl z;mr(L&Y~QJFB)R_q=Jh%pB6L!Voui*w%3wRE53AY-_j2<&U!AbQTS3W-%G#9_)7{d zTh5Tn%d+n){3IX4a~M9skn3~CJcVbl-Wg{zKF07941cd6^_7$#%h?Xg&tv>*h7T&Z z0u2Q5tys^nj$tdqGZ=C?S;6_U0_~U#_g#jZ&nviouXt6_Jt+*=GAv~?H^JgW;yK;i*7cjh>;SCHQV0f4z zr+4Mg8ULq(Sx$zi@T6x}219PovbcTC;_{otjw?e=9?dH|sIRk1%{* z!ByN|tm1fAr7_*hu##al!_yd^$#5^j{R}T;$mL|!os4t4w(4HSzs2xbhQDU`62m_! zh>3cc9xs=B?<&UEF)U%;0zjBjUn7Q-;ZeGEC@R$t3F>$RH8&uY%c)m(m7KgE2%Q80(~ z$l-dI^I@hxuHZV(-*sGm*ImMNuJ5^t3eU}C$o9?M$oOW4EI;=O#@UX!k1+lthMb?d zuPZ#y!I0}!UM=Gt3^{-DE@J!|h9776G{ct_%x5|IZ1?(ch55F+o2D!3PFp1l?-Z-N?r>LkRQoq22g;6`$IwJNI^t4CiyKon2ic z;eGkLMux_R^9w>%19an7sK0A?_vYZ(p0KwdLg@wvfqgz){H533Kg^vM?$L!)}U zufL~i3|F~yjgN&#z25eQrcki0YF}ZKx6RuU@K$YTEGY2q*wEoV+ntK^Ou(CuGh#4F0SLcz(^wbQFglowe(ogx(-T1FUI^hwlo z%6?=vcy(c=;L|CslY*-PB7?^*A(NU5E(9~Pf(~p|9EyE9H782>=!!&Qrc;w*ib0l8 z#UdHgsaa7nC_}9xF`XtUh5%} zouV^IOw3|L(oUcpoxp1cMx>!osGuYiuMCH}L%yQ!?k+!GbMWA7g0=<>;ARjGyX#dm z6Jr!?wm%^@h&dv}(Ik^R^-!m1vKI!? zX>i^iY>GQJ&zEln@A^wY#QVV8*!U9fwFV+-x4Yi%9&5jQ{0(wAwyFn$JNtX+%1cZ< zddG|^%oNmjhC93Zme1p79WIBkH z0*`bfGXc(}m}-zhl2Rr2Z2X@q;4$sT@hVs;1m-g2Q-uE{T0iV|JP(4MuMBt$J_B>A z5qy=vKZT!ubQsLNNj^<~0jNhKfI1b8HaDCO3QuA6qxqubInJJ*Jm*0OiX{(o`lb$W zI-kYATKx2*E_X%Ul{hpZ2C-(%|?B^kUw0`+;$I;KT5Psgt@}lkMLA>T3LSonH zh_avOG59?~4E!*kz*>Xdek-p6uJxnx6-U37R7Rh}Pd_@|DEnod2L_UNc7kr=9!T_~?*kfVW zZ}r*0DetJh`S6RQ-|8{!nR*WX`iY~Tk92F%On{m%%6`5(5Eaq%qxnt-0d8HMu>@g= zdd;N#2onwXXR~t&;o8o*aK}kU$qwwz^1xp|I^HNdZ=3+bZJG&C^F^iOlys~O)K2E3 zJy>@A_EI=)=XG$$(QofCyvT<7(eXyp?f^|cS{~L&P1$f>^;!HQ8T!%gb3xEy;JoUKV0%R~ z+5AS}){(+_=w|Re1P9iJ&Hjz-xf{P(`0;Z+rQe4irNfCI#Y^ehfuEi4D&U%rcr;%_ z6yF2DDLlz@;ivhc2NuAnobB;T0Pn zwNIKaT0gR%)^ACCzK=jBkqv*+@1*#AHx|K9%Udx8U!#qWbdRIojXgF#YAfRLooD0I z?HbuB$}Trj9oP2DokHHtFy}+?r}R=ej1%uCI$)QxnUB)0`J&>z;{o{Tc&Rhdd{Oyv z$0P95_A9sXErr{OA3t|Ii|UO1gyy5$0Lp6{-(47|%%ObKkLDA@5q$Ul6AYc22~hH_ zFDx!D^;nO;sI0iW$dB)yJRbbvQU9?PSW;5r@f4Mpmnq8Gvo8!Z)(MA>PD&&_Y=p10 zQv*P|knv<2JB@AkZ>k@@|DpQfdwmB*(@AFshA+-~YxtW5!fP!1uj)fbGM-IXJO7Ax z?WQN^Ja^Jcr(@Q#ok!+mIUOIaKJ;Y5N^#Le7d;%D_gt#isCl8z^MJ2@cx8g5B|qn0 zIbXVFJ?C7xNxIx;U-Y|IF1q-l!@)$jekXO%|ERsm#P0&A`!D=5ltpolyQXIC6)41hCm^>~*%8^2-FQ5{)Nr=hc^~H$M!$4+1~KIg~y4~*WJAiZ~t>s z=NL&wl1OqSIo%0vmpjp&zmFHI!}KJ0T<6u7@MG9yk=MU4Q2;(_(+=QQDCcfCN0bvT z^I2$!HWN{fR712zk^J8z8$5#4`UT6tsMuH2iik5En7o1&G@2vM+oNvs6gyh2d}o~x^_Au z;5Z&ppGJG|X*43C$XO_y*2mE#%p^p79v$Ihejpt|os>kR55ibOG(VQh%p6WoRclQ{ zsH82VneAi};j8WNmUdRSs->na6x;$b zqTS3Q#&(YnblKge>2QUm>27X8eF?S&WVK;#&~WWnRbykQs;w>1+HR2*Yhz$rpph*| zg{iJZio=OhYEZOJwlk==a>e4AxZQ`Y_tZ|MVPT98HnL7aa^xFMoOVR#yYNGP^Ok!0d1Na>{|vDT7q_+JB!c!(ZQ%c7 z?@i$2tg1fX=gyL(ZMscM8`_Xg)3hWZEi>6eS|H1$4b4U-p)Ev*ER!}gTeGyOf|MPx zB9%p1UN!|pUR)4yLzb!q0TC3$A`1ArlvPxazThk0|J>!-=9$SPRDXQm@0(xK``mNS zJ?GqW&)v70hOl3At&BuSHBDiS6{t@rZ4@}=k;ZylPCz%Mu`&3u3X8V3j# zL!jJG1t!XR#Sg;oLKFa zmlu^51AMk*0kFZMqOh>2sH`whR9aqATvk?69w-Bgb4ig%3sERR=VT8f03`;H(vp%Q zz|P|^N)2Geg%!mWrDcT`CF2@9pNCLtI4eCp-dfDiheM{HskNPFZk`DO{IfvW&Q%%U!4EgW3L&PdDhnGCyqL|D}gJ z=gN(Gc#@fNiylFmqRE(V)x)G>%o*?{J8nPtF3n`wbPpu}y&_&&;8SQ@W8c%^kWs?%(kgq1^WYH>K-7gK8aqHSP)KF9 zqgS=2s!7#5{r#|jpX&G^WU87SjGE&=!8vmV)(B2D!8nidEK~hGstQf1`;`%3P2Te? zjB8=4+L{~dYn*D<-&n#C*K8>-Bk*+eJ^(f;#`R~msb)hJ*RbX~q&%d|H{gVJNCIj++1VOGDkbe;bCc_~{bxzUu zxF{()LEh#8d>#iIWEK2;4mXG^_yrtpu+YttcwFoP3(8o@UpF1z$n%`MgvXDI!?W9U z59aN7LNwR6@TuBgKHoxJl@>l;tVMUlI$pHhMuhHZO-)C2-yltd^bL0RkM~3|F{d`p zqJv69P%#hZPLuNs^O7N=lbG&|XUt3qC5wI@mLf+x-P<}xG>^+Wx((Z#G>^wiV;sy% z8J!RhOVh_j5<67~sAvX6#5eo~p%w&{N5=4g#$~MBPd*p~d9P&^+zUG(@2%_v?nU;K z_fA&nZ=pwvMBMw>iNY%*Kf+EDei{29J6ZT;^jBCFr-qmQI!AT>>rF6SiVY^9E=#=$ zs7rK;U}2_tA8RxNb?KVSP+i7mGgOzfMeyp?1-+HE8z4#YR(6^J)5Y9mz;r1$OC|=r zgX|0wOcKNkT_&I|;>S!tUBZuZHW<~)oQeu01vtohIl@5agv`6Mmh-$*fLGY|<-!Cp ztiT7Y$KV{Lwv@&JOVFWh4A+Ng(1@Yq2J~xl#8yl(JZu!hof5#pjc5Zfo3F8QD#Q)- zO(6jK25FwM7r4nwn%vb3HC_g9ICL7k zqtTrjyAs~|aCL5;zh}t*NrHB7i}sB7NAV8i$VgvwBsZ@T(7w^G+`vQ~|8~MS$G>YE z&e-{L1MNuhjUZY(Inkae5xtX$Hcl#O&%jh9{WgeV|1wgD({vj9EqR+;$vcE;vp>UI zy|JY&cV}n+c$D%EXE!^y4-X-aB}`*`Jv3xH9f95bpU~TxTHYp9#u|X97teh%~jeHe+EMGsbL-@pdiu zvMr?ktu;e~V>cnJGHxq&$^_w2{RTZ@*+>%gUtXOvA%F*x` z>YEm_M4U2Kgx0?2VfWEA3F(Xz68ah&8gA~Th&+}i)Ru@)>S;0Xyv?A_9rEVPC$q< zJR)$FN~|#}A4z3zyDLyB;0;E}Q^eyng6T0;kpmsZx(M6S!B<1DLau()Hqw4sT0dWA zX&do0WD6!OTluSynYbA~Tip!5mzV!N$<`yu^gz}6a<_ginp$nWUy7v^Ypp_JtG=%G zP%`zAiSkFQNc0eJ zA4aV>G*;1so4^w>~w%))CjU`*ZPB{?RoyQNvasmL>Npl zf2mdxWSfg#1}z})-c6ugbMH_VM0-|g55hS}wsp)Cr!7j-hV;Yu&emhH0n)b|D{1#n zVm}7ekD}!W+gXY9tis>1WIIQpvc<7`+zn0h+^Bk~pX)f!ok2l3JCA(TyQb7-8{39U zXOX8%se{{!8*24=;bV}?a$XpHX7P#X;xJByq&@4I1V@kH;8zqPf#rXkm_zL@r|mG|r$O*;pR_Xum7%aVwy_fkx>FBhML3 z#>dSW_s_{r}b|+opoXtlF82oIgIxWP7 zsBLbqZV1t`PMIR#f`zN(h@)RLI!0rTN)@-RCA7IF)PhliZhRJT^cWjdjF^E}y)^{Z zSqEv8R$WrGY2`j7MH+EIYB9jdC2OJO8} zIuvg`tA&-{GF5Ce_6PkN<@6PJwsnq1Xg}Fl-yjjh{^5!1A1pf^%hSHtfL zA$|N4Z!(LAtDBn1ApTGH%RI%R?*%R;GT1mv^0>QqxVyh|bhNK`H`iRQSlOoUb?f}n zBT}2^KM8pYQ;8UHdI|A_7%-ra@o6_!7*7wiHlrDW_ZQ?v8`ac|sty{W=Wc&VFa@CX znP&(fwG;B^76J4u$02plYSG&qp`m$wb-jHegLvtG4MlATP!i=<|b6(s#Sg!j#bJS6_bvs{pVWl9vCjp1)BnY z?(V!i|0*P?S0#v|1||x1?+JReo+(6wK0ocz6M*|#I{W_8dFD<@uMx zD5*Y3B)JV60)Jf!e1yx9C`BSCCFx#MaZ*OnrPZf?b3;wTr=OW( zw&eB}v?U$6z~4p$o-zm&PJwlS=w6C;8gyK*rx;1lTyL0sEt>01!&|7iZl7uNQbnJ? zf%ng=W5#vK4dBG(9=zi$*0DTdue#<*s=qIz{~LPy9^MtfdX-1$NngOSj{`U!9|&BE zWz_jC0-Xc)VIkFrhhVSY!3O}*k&$hkgFRSC*owucUouvCvx|L>9jmGj(P`+_a2@;g zIX>;uNMyn^w*w&4DxY?-EA25-(5_4ho}=$))&0kd7#TGs@X)0C~8zB^O_X)6MNK2n97)#d;FP-sVXED z(=l=Hrm&}N5fr{-M&6Xl{^nX58Qp=ETA1HHp=+!8?SuI}n#$gFE#Y`P(U&^e>7_t? zKb3vmozp!uyqn~;&~(a2qW$$W_8s>M6~#(ku(9Snv3V|yebc+5x3g>1jNfaqG~me} zt5N$7`HAA^VoD|O-n5rSjOyj6L-ogj#ZFadyhH)8#{?jRuPMLDoO>zY9fttGU07M9 zzPM=F34np94j}(6x}P`7M9lSq6$X%7O#Vc4GXZG5z>*+B+9k3YUpL9j#OI?*_k{7j z@(>@-@j}J;kERvt zsv7GXw)i#I59|>%_x&!n$NfW>$HN|V)rK0{sv@Tr1u?*zK#PvX@23hFEW!8$JNF*L z=8am~(TtgSKt$i6s7_-~xLWG{MQeh^!IFx?Qta|8uPCd4z5LQeo1cU*ZB>}>h|sPX zKfUG3o-u`iZ6v&*zOD_UL_GfF4-)%l%?LPzB@u$93gK5Sx!goE>UI(ppzxeaGR0ym z&9_nN0u%fyQ_KSV+8)Z2S&onwkp<`o>x; z0@Dt2+Ir5{gVnOF#%^|t3~Fz3T#Fu5tI@YeJbgySGQrZ>zpHcisGNtPq4-a9#<_UZ zZUp_${9LOj`S~=$6rqT4K#xG{YvDE(%^oXHkMW3GC9S!xE*#Qh#4rMLE(5qcD!G&v zEBg7l&54P7VIo6*cqb%g2YKb(Xyw1r$~Ldqq?Y@ZxwcDkW&wq#^5Ve+3-OD(i9fk@C7!} zN5bwY8^DpFs_yPcQQ-vgaeFj645u}>vw-jB?)0zo=k7p(AES{IemhEw=)05CE^E!CZKr9|{Jh#_r?H!sEDlcbd#rC(rEroLO?5WTLqI@x_0@QCEhh zjH9A})KVB7qA*5N#?^<^ zH3!Rnbem0w3lY{<33lQmp36z%PWROC(5 zvVGb?E^Ke#2-;1EJlGwL>?lL{TK4@kZ~lIFB9i;9B;n;G4>^#;`AZ+hmp=y0Ydi^P zx)xbzl9$sw>_D?92%7)Ho&?QT6Vg1(N)uk9$ueST;@~PKi+hS(sq!uePcETjgNL#MM?4p_8{OeMA4j3u3F>}&a{A6&QxufiJp#1mLG}2is z-VEi&%S{k~8axrK0IsazTDpMH=OR8rKd1;s`X&q$6f_@Xm(TL%Kaw^Dnx6GU6PcUO z1&*PM!&E-c0(LFv-ZWzhbQ$Hgv#dNDJ=@urK=bcYp~*8f4o%7}&x7o4(0p~KFRLnm za({>{q6z`@<;tppsnVCn{lH9o;I_pq6ksar-V)b}l&p=zB0N27W1sk%leMu&e9aSV zhx>XAo%3{f7qE-xc=LZZD@X7=tnP@UMMnO#tl=$&<;s#xTX8$7^2A!$u%S%OBxQ*G z2}~}XGX+C46^gFDgv6g=Z-Mw9r$n4;SCI{IiK8Xbe5pb99*FOsI|a#2MI=6Ps`64V zXBW;z`I|Qt;?#UiCOO)z)YsVMp#A*(d0FNI{bW(r^ZZnToR0ImR=Bf<+jjN!^z>7! zDJpsMgAKm4=gAc4T?cAR8;5%Oda)~5)o$sMYF%gd7 zD4>fz;&PkyO>)m1XJ3Zgzg)cVh*&wVbFzj%yuPz=VNus^S@3urDjOO{ljn8htkvv6 zB<04V|KFDsQ?7`l9A?iWDW6{wYfVOtGFxNVbk`Q}sr=h9#Rr z*}mDn`MmzX*Al~~t%WfCN9?a)zi(+m_E%H8X3gqJ*dGSdeNIft5@%Pl^XGf>FV0NF zbk5AFGG!UrzBwrlOu3?Ge}`QOraw9+Lz;gpF16+=VnqCj^>eYCw zr5*|ug&(&-Qy%YW%ry{*h3KhDZjJuqU2ZaE>!mG(OX?z=PB_r zBXtUyK{ZxvdH~eZGp~ixlkH2t(IG9|iss(Vo<~~lTAq;=M)wVgn?v0Mk%rc~x;B*v z(3GaYp?uu3Q1nH3{?frSBa=Dpc_ZvC(EeU_Mply|qh&R98JclriS;_{+*G|y#YK#a zV1PA4qp};pc_P8B+|cG%I3#pl8&7CY_n5t2n)f8T#OKXFfF5!(!f1ziY1R8cWF|IY zgf&TF4w!_Q|CrGF+)J~4v(g*{;=RlHXRvQWpyzUu6o>{ndLD>QnN=X_rs>-8Z88bu zJ3|OG=kaXcj4wI~ME#ffue1MwKtEWSp4G^+3zddupG(2GRi8Z(-9ikY`P2%0X~G_8 z9tB&O`!Mc|8YaQ}cD{4i`$wbKyDCW@vJ)hE@JvX^gNmo`Wp?orZ~g_xCd&gQ2AWko z;7gbeZrTe%Y#(^M1|AKDu7~}MG(d~na@;K_|AyVS%$t8v(L#G;Wt#YRFjG#M<_^(lTB;OueC3F(-^`3> z&e0|8&tUeqM9gH?s7x0*L&=~{MY7B&dyc-9UFY}a|DiY|e##Q-EGs$~9of2DXmDQE z1ZGfa5>IyAD0$QYvnh1RT=pc`?kV*rU<>myt)wJQBdXVVStIBX47YXSOa!`ih`msk zjntCCWuvc5VM(#F@hW`D#q9j$-uxTN5~xJZS1J9ALdf;+klB!Jjzu;?pJ&L1C<}#b z_*xWKHtIkv&1T<)Y+osNFhm&aShRkyCpw{e!sr>8x*TR*^5TVC6l$aWox2q}>;{EK zfP9&`WTJdFEt7ZWsNxzO?!=v(w!B>W0K0gFH~;>MsmkP-zmv-pR~nvsnXT+fNb}eU zQAo@b??Pn#-0ANToV1r!_l z4qM3|1p4>avCnuUd5Nx*x8oD}SJ$y?JgaC&2k&};GD{PJ5Pi#bL6!#mH&0~ud-7jX9d0$M5Mw(i$7UTv;~2bZhdaii1H)L$;KgPO?&wh^ z4&M?+yY4XaB-c8$%D6RX9+N zbcpN_hsrH#!+KK(nybc6QITYJ3`Vy$LP!!gQ>9U>+*gIo=s0|KYE^A*xk?UC)PxpG zRqAkrYY+?Lq(}ZgZ?v?^7pvIsIW?T&`ta0lt!8g4+303;q3bCKr&a!`nq8EF557#CugjV@-9ov&icF@>fHHB!`tY>>uv7eDjhe&WH zFBF-waAcZ`92sUN>Z-@rvoG*S$m^sdeP#o@RS4KnC0T6|<@uN~Bi# z#0K^aJ$^jBBqH$HdiH=M5MQy02s~NOo=_4r$RzYRCIP3B>`CZ@-mW->{l*|5(=a6p z2TozH3JS>OBn?!n{O2j`A2L=r`B-;tWap=mMQv`2trhI8j#l~FMz%MNcE&a~HdMv2 z3a+foSmlsW-QK`nTbWM{AZ)4ef4GtEMY>$fcP%`TA)FwGy)R3PwT;JJ`xib0P6~#UnZS50H?0_XQ zPYor4M~1^AFET~OH;>#gJTlaSJFhTgLdzvRv@ztcw)V5lY;P`?sc&$ngIrP&l8xk$ z;wjM}*P&*1M+^azY?1)UCkc>F^r@|V;8b>P9#1SMIGL23AfzOM+F_lbc32XOFS`mUGHV=@Mx^m8TiI(u z2-3JMWyBJ?CXSAF5HDpngxO{JdN$fpM?|52PL!0djEgcrOhkH|ZA!#r3!4g?4u9 zalFi1B```qEKlswA+@M>M(yx17i8225DI06#2`mlDV`|C1#$#1`p=oD$WLQ0I5O7j z3-phZV~iSvw2>wl9}xVVF4_-8N&{7hyGHXKEDV9p3Bc;z-#2i|~TeMn~XsIKDWL_Y%7BlJ)j5 zEupFIf5$FKg(GWx)jTuXSJ1Nd>eJa}Yb>H+30Jl|Iha;(lq@rM1W0iO%ghynBktmU zz|p9b5@6h#$yf4)*Z?FHd&Deu2Stw#_K1;(9)EYBpmGzOZK`hS})|N1d@+wm4Nkh(;Hf+~lmrOGw$OjniI-f=M7 zx8|>FzZGFmTjdfeO(fQ28XbZrd7}QE8m;``Om;;HZx-y^{)~npaDiwTHj_9RTg>%_ zsbklHYaw`J&>IkqLN6Y+r^cZ-DE#`y;f@JoLNT*rx7lN=w>u`VHxFlJL1DN4)g?%E zp_2r77n*T$(14?3Ip3F>mhB6iTX|m>`$Y+FXzXb+nwns#=x9=!w8NG(QEyYt%J5z% z+LH;RhTm;`Qd>xYyvwEX6&DUbBMqkH#21Hz5~D@4 zb?M_s#nW+6q(g7`csdRyP%;~`Nu0K9!9%_5DE-iAxV@$(6vneb1_-C=+8c46ClYGK zt*P3%Mo2@bX}!3*2=GrCaB(?$Jzg+rtJ$EPV+7zfAKVC}ooztEIGNerP}Qn^(tx#v zaB8%!s=fg?VrlfeEC11%SPZAMBK*;di6wL{Hj5vN#l?z^ICI30dxrV#ihdl0T|?Vh zvE!8%4*aI?2%Z`$)!0U)8TUQnURZvtRh$*Yy~^T4Bn_v-=%!z~Z8@)yPNhQ9*ho0S z5-(D5IU+SWMZ!XMyhtUbh}7g12@izCja3*RUd>L?3QOWA3-4+mT8mRO9Mp}=t(d3m zRHtacKw;F(Sl@#qZhcutV%K{{sG z89!=*tj9S?jdjJ3I++1<$B&xG41!$bp7@ay8ABmAhG_iA2~DD$a<(^qj+kqle)LXkDi2$cu=dTw*%Hsc9u}%^CCk714Dz6F1-PdA^a^Fey%l~ zw!W|^!uPoa{STNGf!VxYhP;|^dvt1zGlvk-Knfe+7|F!#F(W3Cm0 zOdlw(0p&W66vUQNvTrP<&jHF06^bpfyy5b>fmgwMO=5lEvXY|uM$q~bu)dfgWct8s z#iELZW4Y6T^?<^fWyRt(h(Id@+8-5~O$)rL5NKO~wl`Jsv?+pD2?A{o(C*=AJ|~ru z9lOZ_ekE~ilt`r<=W*b?CvhB9%5nYzoSV`}Bp-8BDPiF}A0DNYSdJ>?SQWr}O<_5y zlw(DJwQq*t_<^HJIT{s$?0;&3716$@RPk zq_0XOo3V2wD!$%jK>E2vI@f9t9ElfUZ!NI?A+hX*oTKq_>^%!;|20d9^?|LVb2MI< zz59UnV})ib?t&>V(cbR@?{$SY*FiW@ti3M*@2Ygkc9{d7DBCG%!24c0)wT;vl`S6& z^366>AEpF=^gE6O_3JgVfkdiJX$R5;vx!ofBNC}Lz6_I~@B(XYEUDo(XB&f&C@S)ZEWr zG&k#p5h-nOJ5Re7=)d6T55mghD@0^T+M_@}&qvhbWQn9MawhFvpx@&YrDKmr+kv$U zZtZ-I)i+}mf}f^fGp%|8$J*@CGent^Pmju?L4r_}vaGcJYq2|XEN9~(fg z17z*Lpa(a{3ZzvzjRnjd0NQVWL6jK;%K&KD41xgww9gEpdD{2m)^r#qn%>k4q6>yI^fYOD02cch?!Lo@4_&qb2(#5eo z%gkV&E&&gj;XGXezTFJx=@M{j{?b@jGWf1Jf=HK$@uE3Eq>Bf5z2*Sk>Ts*_=EuOf zX?dGt;KIJVJ7WTbk$L|sCO}x4_s1~-(%ihS$An0mOIa8bA`LI4LN94X{ld#k%Eui- zcp_6Sa0ubaOu5q`L?krjDTg4D)RcD}f<$6dvmAnCa#QOZ!eoL|2OYv>l2fmC2vb!m zmG9Jt<0Ehdq`na!f$Jgd==cai9ck<1V+gIJjmO6j%1QfDdz(-NGmWW=spH7t7IAPVqC$;-WLJQ>0JzU z6%X#)TSKn^hKI&Sx}zO!Bb|ezz1T}#H$K=s)`tuCJCJ~gapaedq4bSW(O%OH#(Xxw z81{2q+rXaWRPSRvW1SC}7SoT`L;>kQ1_I>kA=B-F*_51NAZu@cqw}pg2Wrz zi)U%#BZFXgKo1eLB`Q3K?#)txL7$lfr;lT1Y2;+h2IcxiwDmdos7ci2qXn{s}n7gMBOy93T%oFBT&aIg1 zPCF^Rev!~ksTC}MWd?A)#49&IBDx=3E37~QonV00FCsvt0T2nxJ#=-V z;Wb1(87e!;8bHDl_+$et#3f*r0W=YrscF^L08Rwp8Urke09bnrloo_N(wpod;nB1@ z1G;(cmbsgd%Jl-Iyc>v^idS!VNU&2(Ua;6GyqeZPAMUiZ>BY#LlaOPL27tUxMz09SFau%ir{Kc90R~^mQgyFFpjPJxPTjP zXY#x)u9E(n@ZVbTR3x9a1ckDF0&9i!SS0DbvGWGEI*gAUC7bh+UqM$ei=9r`Jz`cEl zIS}ZI-<}VF!p`34z)(+g9l8MB(V1HPAn5s_uz~2{*yst!oUWqo?$ua|{18gS8>m8u z-Mw6gh_J}UKo>x^JN@Z~ z*bXddb?}>nJ4)6B)&yZ7J4-rhqdRdBmxm!7H$8V4bZtaLTs;_%-?pDtAErAxmpG&_7$Y`z8e`NB5zWOmg!o|v?0Cm8R>RSDHIGO|fN8zcu4}Ajo(XG;d@IR>h@F0CNFM%IXHII*{XJ)g> zkMzt$7e)N$yR=HE=n<2@0{%TFKPKvCRGa((_=z_EA^uXR{D&t0GWgFm`B%UnGWm~# zU(XZ7UyLmLnJN5O`1hLpkSDd( zZkahhpc{6%DIB)L$e#EQ_$%Sp%PjmQ2sj{vHTVngeK-EdW=3F-C@)9=&# zfBYx?W6GZ`!YQu&QGKEzyq-cPG;IU9XG?dFbT5=H$|Vm+opB7|Jq6n#_ZjJ;9LB} zPcHPnl-#E^EyD)qcz|>FS&Wz|9Co^b+mr6hEg8PxbJpAJ_ewXwQOF#5a;Tpn~{ENx2(s4d|O60#7gHAIXy1V{NQpxPux{`r3?Bz{A%gmF5QQvi~Q!{FH84*;gY=*+=a5n zUDQw99hL59rF(;Pzb9QOuj>Qhccbi3JU48dyC+LGBHd3&cb{~>AYIfa93Oh%?tbCw z`UAg{NiV2Z%g9xF{T9Z~HjhaF^2G_0s>iaA}Hzrw{he-Erx{&bj}0!u2ed zuCzzbZt1^Fx)R?b@l(zb@RZ+6_wT|@JxRJP(v|s_dbjlduW-|3{-?D`f3I{uCEfd_ z`wQv5Alw-!MSONySi1ib z?wobfmHM62C;hN5!k_b=aOcjJ?kee4Nf&lYcypzG=Kfat{~_FY^QHSa>7pGY{CR&6 z?)+})?vSq3D_Rwf=etO{*GTsj=}Ng4Gz$NMk4yKP(mf#Dg;Ea-gVKMAbZ?NZq;pih z@EkdOt?$;h3|f{|f0oDBNYJ zAP8^S@zSl6ZmV=pm#(yvWio%3p&sM$9+R%j=Vh{dFMC74{pr%plWwVWPn2$(bR{2u zm-Nee+<&X|e?_`dpZYp-y;!1%_bazO1mvqmSuC$XCw@bgQ*H+vs{XdcJ z3)20)bYGS3--L^adY+yfY47GWJ<{JVU1{ezvOMQV{p8#x!|#^v zx1}rfl_T|(^JfYFi*%*Eteh$QE0;_6Sn100u<~T--z43SNjECpozj*0w(=_JmvXI? z_Onvv<4S2iD}N#J{wUmhDM!96cln=}@W+LFoXp?jr2QUufrQKQUXUXE1zFOS`Yl)| z{Trn#=@(oo{ZfwwKbHPyr7QEZ;BDbw?UJr6SF3BKzeBn*e^#F-{Z~r&7U@1C-PeS> zM$%a$^}c3}giC#|X_9_Pf6eEl{|@OsC|y}kuKAtxzb@S4S4mf<|M)KHm-Wi=vfLdn z^?dxzGW=`8#pxz)w}BI-dx~&_^QF5)x)Lua^%wk^g#SUfh0;C>Ww|Q6M!@y{;JsL% zfo?Ul|Hb4!Aj4r7yx*THUDTi4UoTzM$K3yE>E0z>@aJ&YIk_&MbWsm-|7Pi)EnTFW z!y!L+UllHG{3X8|^)+{4_uRcux{{y!=hFXo;d&NJ7kVdrPq%cXoStt;|8vs)mvFtP z7YN_GLAry|y;`~`M?4&QB{wBqxHIylEA=vCoA8r<`N$Kl8kem_JQ|l3xwJKy9$cfp zOg5^m!IL-G_6~QO`odiQ8a{g+86NK%>>R-J18WQzj#dps%>X+4Yxd)zzainr1pOEY z?;hX`y2Y%!wg$@#5zNa+w&CE& z>=>?S>mJ$=J$-ixV$jcotR5r+?ebj|772{>owmL@7~0-c5}ORnK}RFq1A#T$5MfId zk5JveX?M}c&X!O~k3)ok(Y{ekT@MUnRb_-n+bYzxtzu(aL;tP;+Cdegu5KO;TJP@W zaY7CBdT?Ys=akM*^tJ998SjmRh`BW>J(!T^=;iA<`q)@W^`?QY(9QrJ{u1aG6Oekq zdWr?SCa6jO06l;~)+WpqOH^cdJ4d%ggz4d%j(m|BYSrU?{XJD<~d@MSelhd}L zF;X9{+F8_?6V7P~D%`fQW@D}J zmchHBA*Y$%77XQts;kO#T0^In=d`qj!sR)ks_Ockg<3;jS58hV9{rAvj^*S)Tm5}q znt5-PzDEpU=F=GQ%-LiZGRdlh<_N3GLAEDjR`%GOq1F6}R5JE&&59gluoOKRi;amc zjD$yzYb7yNhBSofX+cFc3J-Blru5i^7p1}|OhhJ`(&R`6Swe-2Xe3j*Y&0lC4U2;Yr2VGGL^FwjT)Ni+Lw$wE#u;G4P{QDeDRpmHY*X^RzXkE zrc5-ZXHcBLw5>^x{ozc>Amg;OowOaPx(Q~NOw}|xmPCVPR7F#2*A1h9Fv(Ok_PPbp zlBrsz(@-0^4JOG{9lV5F>k7n7rmEmE9rF|frcgCdFJQV=gN!?^s)5IyR@J~`8dgBX zIvF#NRiTLe;i?7`4P?VK+8R#4FcwNeGS*^Ff`jD{nPf~ShK!>b5w$7U(G-Rr=#@qy zk;2kQJR6R5N4kQ&Ww>Vq7ZF7wxSt@r0Ufw$#KR7IQO!8?g!TF-A{C!GFd0pGd2p{C2$zfElkGeg`}a^QsoSweau7pZcjdn1ADV3XXYI z=2srLDisZ;Z~8oh|0u5dDLflJS8a0i+&v)VL=W@&x(xVqKZO54Q~xQxHaridFBv?{ zM`@Hc^;7h0>F`_ygkLKpxN-2j&^tTZ0nett6w=?BljEh5eD}xV@%1Oi^d*0a-VXT9^qztrbCaB25U!#p)1lLQ32eWJaP^b)cwUoT8$I`RQxAZ08P#&va9QiVHAs=Ma ze-h6{^@T})%ie}x$+rgIapdz8JO_X3r}#=cReJG*uXcq(f~)Xs`tyGmVLy(=V_0u6 z%eVY&_?3KQUvcDHz87IH;ZOY(Uz>c{{XigG^;38@`LZc59#TkfB_6vS-zNR7pmZqt z3h^CBz7>xm>{9%xpWaw67pMgS(NsT$XVYKcDzGA$`YAkFZzy{yehZ?nS4ePGIyT_jr03Fd_~+q| z(oulFIO!-wyi`BJ)lc!Y>3Q8YAl$5w;3_;@I!;W(`T(U_{gixj05Hk7gXk+gABXQa z^6fYiK~DK=lW+W9&~U=D$+r{o@zdTw=RcJWo1V|T0&6MHC?vQF59>qbbX?Q}ztS_- zQsSlKqA`gFhyN5kTRJYf5TRE|9C8$%EgctUAnex;cvv?y%XcyCMQ=a+_*Qzp8Q-9- z?CRpfNbi>cQ$NKQ>!i92_}qH~{v#Udr@lV{fQp09y*C5xb%kUK8^O0?iqCy}f%gzT zus*D}Z=_GMw;A}8ziUWO0sN6YyYWYSk(b(L{F(92hF{?kj>6ku!~1XeDL&Ej;!ok( z>D`MkMUUD7g=eSt2ZSklsV2NKe4FJXolyFSFX1bCcD#R@@F;#9yf37i@MfCuZ0Yzy zCc-lCM|@``z$-@B&G;icqOJJa())#H5T?>gWn1B49nzfMFT7yFqw=rt?DG8qVM@Nm z3Gkp7mWyzbZ)tqIYjY5$=q*ctx7LJ5vd59{+BOp&)fMsZ`b~JMUL!r(^m6TmfGPbI zB%rq!>U;>{lwPvKIDEg<0KJ?k@hA@!o{jI9{~KY7FV?hmJX?Nz`Cf!6{Z*Loj>fke zfAaU`Cs3TRr%?Z?I)L)pgm=eJu&1s-$1>^)Hf+JW_piX|wBsFLR8n5zH-5q5@{)?; zAPztI{rHEU_#f+mrKP2Qe{n@cxqzHG^W0EF9djwMK$&S|KPJGp+o%Gdoyhp*YFo6^ zzJK!i;qO1Re)!(N9@e<@%+T=p*&hu5sF3AoOFmP*@2SieJbCk;%E>$V>DezWUG8?x zShD4*+1YN_=d1TU?OD#wJMX-Q>*v1Y%h787Q0Kotuzq;Chr?#Ql(u{x|C;fVd-=)y zEA7nl{`~rR=byK~J_TQY<}#@NsJ_X<-=`q%zwnnSG>W?{r#)6L3gUoz4HjzgjP>By z34RQ$=^z_lxAo&hQK^4?7-RUTzu2GKMQfe@;=;l_f7{Sd{|SD~QDN@LIHiW8MeF;< zHjH=C$)nYyICZzH6D!C3h*6|uO>MYkFuF^gR)VLaWn}2AX!qDCp{q2Ko#HBz$tJY$ zJW+R~ytuQwq@*h-C&KuZ5u6SuLTv$A+{ui^p6%yT8>BW&LPR^%@u-dtO|#5x3$yU@ z2Fm@An=Nr+004UbzwT|i$0Vfu{d;u(bCd41zz6ubVSU}*$6@q8$2VI`)lyliE7hIm zN%N+qq@|{%rOim2nKmmmJ&jr;(RN7*c^!8oXylsZa5>AN_-88Sa7U^ZeCk5iMXYP) z0`12?siNi=`~G?D=$Q$l#J{QD`S792ah3HbrpAs$K^Ey{6Ea=i|F5KrI;`4>|LbBW zr#sKl-1PV-VG)Is|VnQKJ|P%2b}=Wr~A74##*C0 zqj=-5uD^4u9Ak^m{=^xFsLHg1>;6{keCiEO4i%9KCQM0$nUc)Zdg0j5|E%XxCr|A--@= zg62AhdO~&h+kkI4e5Pnb!pTp+TKsLmbza;f{-ZkYM2%6Ouo{0o;&U55N5m(-^xr~_ zg>{ek@M)~o2FlRbsWwoxU`jPDI1qoyK^KK#fuy#oEfk6Pv+JT=et*zk7zmbSqZx}t zXw8BGf`JnXOHT*{1T@@MTLUO;7AV{!&;1gxq5^w~8hB8scD;^9-v(B3piIZ$S9`Z@ zX(2}AgY@>O%R~L~uDrgiBS`78#(ws4WF~^mF{-MFGR><(!hy<7p z5ewRqlg854VI9Fa+$f>pAlJZbnq^6}kQqzoM)te)@8$d*oL3IcUH`le%H35?Z z*v?1$aXuPMh`A(+Pve9%5z_&dGt!n2{gku?8k0n%55%N|sD6wuJ#%D&s#t;%X?ZLX_t2-%s|g{s3wzScCJv&E1x|USu^u-R&~0gK41VnT|Pm=7%l(zw~hDT)9yXPcl<((IZGxG#T@) zdYDvSjxhkMzB*pebororI{?7?x6&r zSHvp|d$$OrKaW_m=TXSQ5jZ@9~8%sFi znl0sJ1fGuG2f!x9xc!!mSd7hJ(@c40Ycy_z)!Mq($i01khK2`h6=Ub?& z(!$4!wK3yS+m%G!^Ct6>A)=F* z?u=*5ObI26ejb)0M?2lyI!82*%R9Oa+nY3x$4g@z%t{%Z5D!b!$3_x6RR^eO21LX+ z{05;G1eHg|@QB7`tlUpN7zBB*Wfj~DJ0S0^>;&#b_LKKcR_Sk{hl@nq``C%XDeU6km9-lnN%B^9ngP?r++@IXDK|?d2EBvq3=>Qe#4BAUpf2LaOh8@2 zk8?H{)ykZT3M2(M$a*=#K<9+ayR(+_yiYdlI`MDTO40m>K$4mnmHL2U5 zpNBAtbqbOu;t;Zpb7w!Fppd9g2HmK}1r+o!$)aFLertP88z@Lt*!7P$h&A>$D!QiT z76c3q4QuRucsJG6!@H}uPh%Ij$xE8t)eALV25&fY8oZ;?of^9m-uiHLZl1qq$p1-# zc5jRJjQ2>Qj!Z^pjYa7nl`Evv9Nb!vzT01$>o+%N% zlZZA>DrwKaR3!a2h+_XTQiv0E8v8AIn_I~{glV%s!&|+vr7d@7Xa9JV@($-WJGT!H zA&(_YV|zU`WIG*!-Tj}?+nHM4CRE0>GhzxF|MNv3dFP$;k`Jx%xF3~mi=30UN3^aK z9kC|mh)lj${)@3e6#uQ!G0ccGwY4^5K^QZ}Y>V-JE%&l5r2efnLxW=@L;V5;bBk-g z<6@t{kRPwp8u4>@jBbhQ9I^6mE_N|hJjA)aC5(B^1Z+8ikfTMbyxYw_ucB5>7L_CD zQ4hJTB#A-EL^*yj1olC5BEwh%!7PaFt4|F)JTQWpBGHP$}RY zM#)pe<28cmK~<3h9mcu{+tR^TL$E@we$+P7epy;SUuJ0=@jPS;CM{d}%aED49X?y# z4!@U||2@gpBgynY)%tR`em0s~ZM|QLbqH&%LSn1FuJ%we^^uA4N2^LgO7NouEyrIr z{#H;vpzg+;d_^DPj@A z?bQh9jbXJzI9}~^fMV1LvTN7+gQe|x{Ii(UpTAn@Kzpj~tC zP!>dcR%v{44w7wMBa71(C22$YfqZA{G1&m=TdjHBKZ*SqR6mNABW!0S(z6PG$CB+F zg~}F3?{Pmg&2yvbrGBpCJa+~K;ru-ERqvWomu+ktZk|P+E~O4`E3T>4=Y@|!F3Wjg z^qIvcri;s(+8eMUR!$D)4EV(UhaJ~a3dHk}Mp^%g%&R2FwUWdU%QtA4|2!UJ;ECo= zYoUcXJ`%Z%70@_?eq>{L_@n)+ADAS=ie)%o zwZo#FW4;1v8ET;Sj_bxFx!Ij`lXEs7Az<*cq3W~{7oxVgy}BVp%Q|I>df z4w>}nhWxx$H2l%nS(FVjH0VFhpKC_}&UUD(J}!lk2n-kha#t8jSw|-Z~su|SRRc;>*|~8+t5P*|95qi2B7eH zke;D&Jg#a-JdF7?5icI8|HTW+XhlrZo`K#-SzQgkFNE~*PrS=49?4;|W=$GeT4x^;{Ad%!YYzX{yDew_4N1_yo zoRp+{O~pyoS{4K&9CCdRat(I!1|V^vR`nuBw;7cn0BR2tHN441MGR{%suoCC(W)4B znu-j_{uE@#K^K>bMSK1e21}P%(N7j$!<#tU4Ln|R>0Tt^HZQGBU`Ju{ijfg4dNGKA z=3`!}L(v^+s14@!VtP(?aZIhUzn4~@`ppeB4WE8yirJFeThNwt>PpMJ?$<;^bkId-h7K18RXm#$>LKF6nB8i`Dp=5_#NTIJI&cBMUr zim=Zq!X7uf&WJ!wkwSN*|23LE)FlGC!geJ7j+@br|c?+|rD%KCyA zI}dbOMKzm<5k-xPWL}fPeqxV02~!ypbB{k$F;#`6Vmc=7-4yn;ErP;#%*dNk+234C zBcnU8QVa9jCvN2uAwN<4TuiA1-kbK)h*7;9 zb*TP0u-K^zjh83@_Lu;K@HOQ(nR71%yyFl6xC<+b)E5^mI{`2d)dA$cMfdYYnTWYw zu)+Xxi^-peZYBV&7g!QRNV`N<7Fp&S03WyIbNt3pZrG}r8E9?jy^zh z99O%ztbC+Mi>o(b^-nCg8uOT6bzvg&E*GVVw4~XbH6xC_$30F(K zzi3UcI9O6qSc+YKtQjF#q7Z_m3gK5Sx!goE>UI(ppzxeaGR0ym&9_nN0u%f?Q_KSV+8)Z2S&onw zkp<`o>x;0@Dt2+Ir5{gVnOF#%^|t3~Fz3 zT#Fu5tI@YeJbgySGQrZ>zpHcisGNtPq4-a9#<_UdZUp_${9LOj`S~=$6rqT4K#xG{ zYvDE(%^oXHkMW3GC9S!xE*#Qh#4rMLE(5qcD!G&vEBg7l&54P7VIo6*cqb%g2YKb(Xyw1 zr$~Ldqq?Y@ZxwcDkW&wq#^5Ve+3-OD(i9fk@C7!}N5bwY8^DpFs_yPcQQ-vgaeFj6 z45u}>vw-jB?)0zo=k7p(AES{IemhEw=)05CE^E!CZKr9|{Jh z#_r?H!sEDpcbd#rC(rEroLO?5WTLqI@x_0@QCEhhjiW3xRs_phM8+`Zk38wyYjoC7YWXwqQOuPVAQw z;cznIyu%HAjC4iJ7)h*s>H9A})KVB7qA*5N#?^<^H3mzdCem0w3 zlY{<33lQmp36z%PWROC(5vVGb?E^Ke#2-;1EJlGwL>?lL{ zTK4@kZ~lIFB9i;9B;n;G4>^#;+wVS%FMkZ0*LV`pbS<*bBrm6V*nuX_bo$u;uqQ$D z)r2(9veJZ?XtIo0nz+Fcm)n)GUxVf^z4J(&(BD>Ei_f#pqELs_XAKXHj)k}N^~$Vv ztw`56lde9@GWSHfJ4bsWJ-tD$>j-QB%s#{3o8irWD8B09V#A4!`6P0xCwiOkLC0>{wBVJe?z0lOA-Z<;X$x{Pw$ zSyrBnp6%>Qp!xTy(BzpKhbHBg=RtNiXudkrmsJ%&xj#e}QH22da%EM)RO!p(eqbg( zaNA-Q3NV#*Z;5L~O4i0<5uTp4u}^%>$=cW>zUB$G!+kx5&Ure#3)sbTy!pSIl_Pi_ z)_LN~BY5H~&3(@-pLW>H^G?{G;EC`I!4qGZf+xQGPCO}{-b>h3;Q5Pm!INbup7bSn z(pQ@M_H-0l6VH@m6i*5lJn2jDq%S9)+_t>$vs=OQ?%61Ir_o+UVV=CuO+Y4!?8%x4 zV`C|wA|roV*6TB$B z(0+dYye#v9ezGX*d44KEPRIFOE8JPbZM*tUy4vu5=q><@$KJ}0JRiL4hX+z*?&@as!?NvC!j9;+zX}f*Jk_X z?r{>HvU|=e>>&vMl;2r+QSz&I7b^Sp=&i1<^OSg*kvfIUpc*SSJpk(Inb$(;$@Zn+ z=#Um}MRRXw&m%2&Ezigbqx*)$&7p3BNJDE~U7Jb-Xi8JyP(E&1DEcBif9c?vk;$C) zyb<;mXn!v|BdbY~(XyJl49&Q*#CjceZmQm<;vz;yFu91=RO zjVH9Hd(2)h&3lqv;`8PoKo2whugB1CItnSHsvl z8nw1v$?8iCord~jRkq+xcH>fS{;zVUz$&5IoLQ0P7A|CWg4M%$Q(=`zdycHQ0vDdk z?gguR^6fJ|+~`zh9977(Mp>LJgy!ibG2?@&4pGjGDJDL{gjs$}4x)z;;YDuYtL*kn zZ~j%s*=K$%Ol3z{+ol~j+;N|p_s75NjgB7J3e*@IwpUobH% zp)Z3KDa@2A-VYJgvSX^a0yBo$V_@~gLe9#0dfutzWetpru7R3r8lc5(Iqnvef5Yxu z=FPvTXraBaGEMwDm?@`BbBAa&EmaCSzH-FYZ)V0b=jamlXE6I)B4#pcRHloZp=3~} zB3WjXJxAZluJe2I|4^I}KV^w^mK7b0j%?j6G&nD70yC&Ii6=X5lsxKy*%Z2DE_)Je z_muh*u!VV{gZ$ZW_q$08e{&og90l!Zbzd@YJA8+D+TX0z`?wy%^s7$OXI zELuO<6P-{!Ve|}4T@JG@dGW$63boPx&fN+fc7sAAK)%deGEqL8mdU$wRB??Ccj8V? zTV5`GfL*-8n}2`BRAq9^-^pc)D-F-R%vN?KqjD?gLl0^nWYIqh`wdJAWH-On6~kDjXeRyiORUCzG>39vxZ$wG)_gLrb*(B8g`oy zWBN3{R?EK4#i$Bzo|Z1&s%1Zsx|k+~Z-&^jLKC=pY&zNT_YnJ|)Wb9>e6^0f!znbj zhij7+LaThaj_pY$J7{dLnnJW|*0a5-*w09%LnJtp7m7?-I5N#ejtnysb=BkR*%x>u z-@11y@#Pta8YxZf{_(t<0wekhUSv zc!qlDIlfh^!f5kY25NSLDg3gbV;Pv$O=+!sqk(;P)hZR8`dFgzST#V=c?)WaPHjhL zcQ-Z4s=Wjm@9!$_ZDjYG$mmV{s(U#ZY6Q(>4%x{ZA~I*KeW#J#b?i!#1_z5rwns&J zC>iy5YLlEUYRJzTuJ7!}T$%jtieev(w)Tl8cEA#ur-l;2Bg5g57nvgCn@8>#9vSMv zomUt#q2-bu+8A$wqQW@swzg>rgYhBZh!UHc5cwlLSaa zB0%D4N*pKIzSqLu6Qt2~-)`2Hqf~gSlq+usT$X`Duhh?>&+eg7`qb7wa4Netk0+KB zoJ>ki5Kof#cJrnhLYrq`wvYCJ}CGebmY55t9)=1yJhupRG-l~ELl5i2gpYGumBd^ zjA4gaqX(F__NmS6x2w6h-F+k7t!qa$!R9A6yBdkI~5$$ER3me5r9zhjrA!jUz;YMzB0;ITtW#)>(5qEJv;Am7z2{3NW|v|uLaQ__2lcT1jLz4Tl3eo--@uOt#S#KCK78hjSfMR zJW>BnjaGheCcC19Hw*S{e@4R)xIi=vn@OCEE#`W|)UoTpwGg~9=naTQp%)L^Q{&JZ z6n=fJp^7&`AQk3(Yt=Xu#32obO9b%k~A% zt-P;`{i1|7H1;$ZO--;=bTlbV+F?tYsJE$RWq7X>?a72u!|ygesV$^H-epsb5OxU= zaHL*NZFH*-y**siF{p2;-h#FQ3WBcvhJv|e0Y1o)>6xVRj> z9xs@*)ojqtF#>R#4{ij~&Nd)noXl)*sA|VRo{Rcu{3(#mH+5WEQV8B z5&r1K#1c9eo5hdC;$p={oH^phJ;VHVML&+huA%L$*zrmW2Y%Cc1Wyf>YHTCYjQbvO zFDyUSD$a`HUS;til7`b^bki^0wwzZ;r&1wlY$P0Ei5IE39FZEGB4HsrUZj#zL~3%1 zga<<6#wrXDuV$xcg(dNmg?BX&t;H!C4(i6`R?Jg&s#COJpfG;gg1FxX{92tN76yvr zC$FfSr!VXjkuo&Cqyc_b@Jy$OcytDLJSWKXARRO8j2|^Y*5jO{#=7E1oy-8b<3~+o z20<=zPyEPSlLo|NmgeFl=IolgQazewXs328ujUPLqbp$KQN!{DxM^C~=Jg8OF z+X3q*J4>kXd6A)kfuX_37%hX2ii;HqERO(EjfFZ2@916_|NLLKjl@UmAfVWx>wW@v zR@~1%NY!>Ad6sRy+J45|uQQBHX8YJlJlt5;ITekxPkR{{m%9jKUn~Z#i!(PczCjps zQrI$Whq_!4Y` z!1=bo30QI9oH))faGn%64~`X`zZB|m`Z#b>P!1{)Z^Yp3HibalvVcDaB z^?<~RvSKk0!qM`8_Nqh+kpgoS9PJ#SUGElsh6sYW1dg^9X!{siLO79<9oxwQ{wQ!l zD3M4R&ToP9k-!NfQik&n;Oy}bO9^^dkrEbu&!^iT6rIIjPNWPg0IY2h zyvI+&ij<+zB>0I$3oBBFb~n&ol4v1<;38#cc>j|9%1CrNc2ct^jA`aNJ_6F60x87U z84^uj=L{hIULaj+H3){prm(XDSRV?k&`HkF*gSS#0JK}8I9s2F%yfpvCbM%J&>oR! zA=90A%4W3lC%}74;>Cqwj!$dnDDZBI7TwMWgU9E#%LBZhMw7QqRGcll7Gw|GkUwXd(AGW}Y(+STpWIy!++Q+WOoZ`qNz!hzfwviMcu5PoByjg3;O_Dg z4_y<{Wn%Yuf&6QR{EzV35tNzqJxhW80mFVNyz~V&Q-Wtbuy4ms&HegI>auPck(36r zbI&fIKg-Y`gq4pk5Uvu><3Rs%0#P4FC4xHFjOPf@_a*SzvDKk%#Jvku;WK`QTsUTPeK;0?`1_01D6-0Ul?1w6hvLKv~e7Oo1(E-5UR>2}50QgB24E`mRcU3sXAmH|76^?O8_$eyf zSlIDqte{#!Zhx3MF<^IRm^v|J_swDIq)Vmw?f&KX2uuL(x5r0d za`2>#kHE#@SvEcfmx`x6CXMvinb_5|%G;L9rM=65k}WY^wT0xjHkG32Xw@V>o;^cBGRuKu2u zU}Hm1Q)h1*o~8EpceeDkOn}#=Y4{2?eVUq@z%I-}IT|MDgb}F%2@oX#5+hm#Ae4|rLXMRMO^cIRleX6c z5pw(-jYgE?l<6Z)i`8(s(ABVEBL@8fepH zeJ;YARE|N}G=fv+geZ-Y^cYaCnz|?g9~I(RP4h`uLA0jLl!d6Mn5bxw&WK}d&MIa} zrV|NCe>P?CWfMwlpf;CfFsv*utC)uiPZ}09m`z#AoXBDL-bNy*Kcoos@ZO(j5y3E&O!oQ)NvX-iGOGRW!_vuLt<8bo%gwSt%>@M$KP zvrE8I6Q~f0)U+~d1tS7*xd|3T0IWCxLd%6cCO{9Byr5}*6MA;sIdNxUl*>3s7MBw- z*{;eg5M!q+MRainFKSvfW$d0M(FIV>snA%B383PNDX1q?T1gq~n@(jG%2ldqXYwMc zx^5byM0Qb6S;{nUn5M0o#;j>|GOX#WWM=DU7cfe;i1|P~M;0{gT#*IS=kY8dH1e#b zeMw?cpKD}cejF78qUfT+`Mkhuns|ZWxM7;><-NABEIMkX40RKvjHb0YS+bTAn&|7C zf>%vz7g@BrfM+#ry{sns9kRfC-XQU*u9FDTeC%Qw(CC&UAYpIhg;S%KpwPn$X;X=> zURltzzCt#G`%9Qa2bOBdV0cr!PL5O42A7Bo1kH})T|lt7;kljlzVixN^9x(^zC>#u z11wm82f6y%n>u_87Ibz6@M=)}3;<8F^wRGV`tj&KUcilSXR^w*^h+lCb?k}%f;466~}f-1`^CXF(n>ZdRD=@qe!xTn>~UM1XE zxG-m7E(~O#u(2XIfM4RWI@IG;&y6PC5F)&-QH`(Pu3BAHPcP{dAG%vwn1_i~!Rhdf z@djzNh}-#fRrq%I^2+ivRCwLWRVylRA76!);p6I+fZ}66n2#IU@J&^`KQDN^`fBNE z^L@SmU3xv4#>|sBq*zTYWxUeUQpU?XW99&_N3@}`{3aQJmS|e^i=s|*XrKNI<=>04 z1IVBs{VSym`ts0ysONVcIj9k3xNCW^dMpRVLG^Be<7o)sYDPyB9qD(30piH#cf%d5o`7f0643sZb%Ck_eRLUo!Z0H2-r$L3kQ|jlU ze7#ZzKkhoE41U}*l`{Boy{(kNkLy0A41Qc!DrNBFGW3D|!H>(Zf6kBdBLyG)IPX@< zi%||B<6EeXR;4}zTd-oJF}16_1H(4dwaB--DBErU&+j`J#>BWC!Z$xR(9JA5rd;WQ z)eLIda!M~2=~j_mAyUjsRu7+X0^vOk+oAM1kzyW2qD&z>!F9-n)z^qrY3C8`Sc-Ph zq8*i~9fPACOJO51gb!cH=%E}d%B&tXJB7-yGQZ^ zrh3@vEJ{D&aJ)K`)$5=)9eEwTgzE9c0xx4OWKkJ&fYrlRSh+})VHd0n{j&NsqJ6U{ zcZ)LQPxTt=CI8c?EXQ#f0wpS6g^NxVj(K@1m4BvbMU+Ah)Svc>NRNpAp%2CfTee59U}duNTF|5e^8|V;VIcW!EKmpEQNn!X|G7XD$-$*{#2xbU)!g= zY{%T8c6Qh}OHUJNK%^Inbel-OE>idth7UQg^kJSF@r`05|Ii$N8BjN zPl!~ud!Lsh#rPtZi}Gb6y-B3PE+XIHQB_$Ww2;NWUghtYd`lJ;c-a7LjfgsgNsH6^55^rAT**^zR}Sd?nWK za^f11{y?OU@ia-uAt_gsuNLXBNCllK*}OcZOQg^6bgIzPRDnNLjBA>Z*R(r1Ub66S z$y-HP@R?H1%PGRXQ|=YzH+VYz1d$4Rnf??nr{;+C0+Bu`QZb*?;&?et@SS$PDEEo< zc9FirQ(7xY?k5O2oN%!y-zd@tc{&3Qg79XXBvQXf>qL64NQIru5c-(`KgQZUAyT2| z8Df6Vc$>q0(ITBE(jt+bBGLwtihg{}qAdKl?>15Xj!1<(eZLgte~I*nNI&K2Os_}_ zMOq?Kp`V$e-zMT!Yea>+;&sqkkR!oOw+ z`^^ycn<4BcL-d=0IE}U6BT~_C#^a*=v`7!~be8ZJvqZnM5(PX{q)S9vCeqVIdY(u( zigc4mFBPeCzet5# zGFwHtL!`paGsS$)6!OXZmZ-l+q(2g=kXNRVQ|4;|{tuA~dzl@{%d=;SbgoFne3*Tj zD4!+LFNriL(gBeQz0JN!lm%b2h5gJHdYmonXZEuK?^T{=3qG>NyvyD$;J@YRi9)|8 z3j00rase0feZGsA=ckKQ$anryQ9eVYg8uw#L|Mpj{v)FNyhw#U=fBU(3v414^J+nb zC^w2!=x4!~MR|uvzbVq^MEWLA7YaHHh1?e|6mTK$g)2l^&|mm9QU10_9~7zZlMDYQ z%5U-Xq&XrL<3Ficl!ae8NzA*Ggq%;hRn&ivr}%Xfv)i0gM0z?;bK^xiU8DjpSI95- zcLIKhr+LCY^2EH#+sWZZJh&hCXCPY*>wf{I4~Tl$1&jOLB8C5Cww|J6c34_;lPW%6}5+Cp>k+FA%^DK$IB#N zcIAmwUY9LFJGw5*w`mKpJGjvJGFh*-5TCrkWA8}U$sG3j7qZRkKzDz0XVV6Jeqf;q z!%wR=1XTe2_E#xE1JV?p}9BRp0txW?p~*IXOy8A{qXkJ_r;H5O!dF zab0n7&Z>eycX5D!w>p%7^+rEh_U6#1kpmZ$uFUByTi;t#pA%?nCSoBi`2z!JuxVW( zHK@+TPlc)i#W{t=fwS3%>XZfsa%T^*5!l$hxS^$MdGOrLg=j&Cf-FBs1lo%>QC%RX zr+xLZvfRq`D+0!;*a&fI&d`3fc$EFSR1l1UEwXkN8dP@syQ&~-44-WKap5Am}d)=m<{ zEB50V`l4kFy|1sZ?5qvVl><5W@E1q7n1GN2Zl_ql3v)G5-asF~AZz31id$4a0wB_OE_*QRbHVhBL~~sNlt76qi?LuB2}ZR%TX~l`hJxt2}d2 zW^G+%{i4ju(z2?7JgvIDIWw~kAN>yY_GM;5S{?1pn)+-Ne?|-s@1aipHO6@6tQdwE zvYerr+^RC6_Q{x4XlvG?)%=OnWbEInicD#+)O<1)JEl1|64rcND;eW5gdrTC6l7y_ z@=))SnLQ!Q^I2g|CL%ML*%X!xR6>)BXiR2yh0q{{nkF$Bw-kl|d2HoZQN+q|Sj2e7 zys(7`PR2P4)@Y$QUi%VlkIT4NTT__FFuz#K<2EbaI>bRAqfIF^j?bVNf#bF&qxI)A zC6i3JJKK}CBk7x9c9U^Uy?v8duuNBUOzXO76kujDt|rvCpxIRgtnlRtH zXdHO%SU9ta#pA%k&}Y|^nYsD@Ljih2Rn55Z`9gMO@IQWGV7Vsv91p*YcWDEX^u)V- z)}rNguYifl4i~ zpTUj-{3X)z5P91{093q1D2Kt*u&-*tTY~cSIOQSRVE>KbNjUaZb)PICm7}Ou@|1lY zf2gfIBwh$TTgBw)*;_#<96jvo8$2Lue+Yj-(>P?mA$SfN-(>KxAEnXQ)$c;nLuwnmH!yc(TqQ8Tj2PgJXwG(g>A2@BdB1IdTD0D<)Ur_T=P8^cn zMwC^0Pos>zNk%UhsiY^yVbB{zx8Fd$JOn+aOQqi_G>!&|gjC`+^1P%sv;V&8bwH+NxFO{QCdhkmsiB@$AJ7a~93Pf+*BSUer~8&v*gUW~HjkL+t4{$^f} zx>20+ko|`6m(c+P!j*@_3*j$=bn%cxLMrg|JCIl8H;cw0`O8Co9R6lKj=F1b%0u=W z!e3@B5GG-NnR|hEw6OkW>zm4akDx7{p`0L*f8sYFl z_!|I!?AP8vXNMd|h@3CI5%*G_lSoJ<9_|mR$TrAce=E@5l1NHj5Aw28WVc-pyoZp%{b6H$BYBd&Mc@?2PLfj& zPO@h^PU;uB)Xv7K;$4ig#3LMuw>$*zZj`A#(R1RIc%k(6qfXMJwLs#9(mRAYNzbj| z6(g_mM>3)DQNM&Q>4oBbtl&}maqzw#t>8r}cp>BXdK&7IaZ;k}bEuQ!rMWHfa34|~@7E6~cr^bdUMPQuP$&7DHUS>wqGzF=_)8rhZ&xPjB)u6E z;4M+`i1%^$+tr}pk*^pJuS3C;evRZ5B9~oP04C)(e*${fL!1wxp2kadI8MK}S3@r6 z3p~=H#0%+n@7<`A{o%e+k&_MU%+V!#XBj#C^z3{9=QdJ3KtjT<`(7pd^rrv|KfgNQBjf4S5%a< zIFG^4kG!<9+OOLrTcE6KWIqbvgGO=y^dvHlEUivk`LolOb^q+4W!*pe^xlzOGd$O3 zX#OeNrff@0UZ32!V`_5Cjx_DA9dTyXW z`C!WJnM7|d(Zg8mG?oJwjoN4=FK*hG>L11^4p{oMQ=bPe01na@+lK7>=6W0bE#C8z z4-LiDJu+nTHhM2Y-n+GN$nI|q;h4AX60O(on>B3PVNX4rX`4k{ocGMf3pp2e9M}k) zma>r-JNFg%_YV2A=K|@;hvwP>uMySq-tvo6(vmX$clcX}?B#9cfzqmV4v_SqIyMLH0Bak*^^Uo~_N8+gM<$W*z@a6p{;)e-`SMHvvZQnj~_mu6^vmGy7n4xV;@m#w-d3)kK z?S;PG$)O$<~FW?%!<-mqf z$LL3+|AdBbd2#K&6L&a=Tr?wQlg->CY{s6xq3mwhjIC@vEapOE{tgG6$+LEx5EvOs z+v(DV);u=X=HH*3zB4Uw#NYPy$dvETCL6woW-ha+4WruVkIKG(pbwNblzsoj?tM%B zcaKEg;tIiZpug{vjUIfH;SKuRyaWFIx7hccI%4x~@Lqbe9pwiqf;(+{rg%5hKUy(x zOOkhBYv(O?e_QJJ{rCGfjo3!@gHIj&ed-4z@&2{tTlRR%yHY+(D)QgQ%AL1(%P&do zPg>~TKXL*r@JPVvANaZp)^dWsZEM?_NA{%6v8B!rJTRN&eh+BfeefQ5(|=`J{O(>9y@!v^Lb$m8At+1d}@1o_|b;<{U$`wG0B-r%r%r{-Nd>`BFV zysasxfFCV&NlO1n+@9F-&hoY3v3MkIR6BT4dE0Poc}HqN((K^`|3JNaICX1qIQo{D z@;-lCd4EbP;4%JzJ<+VZsqWF#LqqU3@MtNpb+Rw*@Kd`J)9SV-mR*PZH-x26_iSgj zt{uK+_YBYV+frs})6Yyh{pl@fRokLdPDsg4iQkr{?b;T*#-AK9*S5_Y_`SC6>#l7v zYs!)%{5NITw#BWv4)R!VaN%~hzd88_86=_Yw9?EY+0>P7J3z8Q3fV+#v+s8AawT6I z28+A_VXXs}&EGVAAj3A3C{+m$TUWM|+1#0BH-J*^HYZVvpAWcWGZuJ}FR&`TMi&k^cKLY!w?7j-A9Y?D8wDFXCr2`0?zH{7kOn zc6)Z&y>d53m^0hc2S)9qmycdCdgbWV z&m1u%OREy`xSn|2sjt9sc0n zj9>iIKkLY+|2aJBVCfNm{vnTl)*+Wa?NAERrATXVUf`c|=t6(`p+UgzMfoBBl0#1; zeab)M&_UGw3w8hS&v{it`iXzmtGDC)q5p(eAMwwB^?85VtAFsH^y-JBQ~f6$cKhca zuJ_M5-0F`%{8yas_@^HJ#2ay^L)>)Bu5=@A zia^{H*b$k0(GEA_rYIgG-Q?Qgr4>W_x%UplQWQ6R8y+?(kmkSNd;73!hco3Bi=UNo z)4N7A^fvscPHSNDdy21>c>gi*C>qkZC!Iy}V~FO55)B(b{T*_S6JNawJRV=Y z42sU7NF{2D7g3XA$jzdr7#1~6SmFEV@L}d3D62a zSR03CAZkk8kvKHNzcv}t$9kT)uc-VY|J?FTsV^qYz-rz&l<0q;ymusit}XeMz>%ah zL{AU+_pkZYNUVQT{nZ5D+BY0CGEIq|(k)|mA(j~#)n6%lrJVUDlE8(CL0VE@nnUZ{ zeYDPDg|ep)l>PWXCwS{cyt95^$q1qhXqx8OgChQPre9k2^8*(nE}HR*uWU=%4=DyE zn@C0c1Uwe^8u8Nwz>9mu%i^b2#7`O`!?sjJyXcigWK1)cmOa4ux(Iw-v@f6RAq69l zc4KIdI3wOKV6vTI#!tg`e?E(!5cNPl_VNJawkGB0BXNj;t{6_*+Jd;Ges~6ApC@1b z-OEp{c`XG|`kGfpbpMj_z7Z{LL;0H2y-9P1bx>KdM?>VAIvm5Ir)h|ud{|K;($Cuw zaiRtaKcM&tu~W@%L`U0wh@DapJ8eenG!3!S)a?<7oqBgqg=Q&sN*J0UVyAcpqu2@B z7BKJbsT47R>h&*w_2nCeW}r6CsEr-+?VgIrY3fkK?sP;>TM#)RefB~YIYr{C$gSxFTZn0P{L|QjwEB?>X!C9wi9*D5^@xTD>b{f# zl&51I08Z)=|3GU0NTUD#@-0~3pFH?GikVV*%;aS;R3c)i4_M5UX2eVm#7t=vGwn%T z^T-@q;DOWybLl$bLAs8hC=;>FotQJfV7}+#vTuQ>`8TI1*RhLFKw%r|ca{O`5&+OGDFO z<78Xf;iq>;AZm(WQPYsH@f1W&WaZl7uk21o)HF>*O_v~QiV{(i8&Ol7h??SA)Z{=E z#iAy}fw>3s4(1;$Kvd$z%I_Q}a-tbd>-z;*-}T+jU5>DklNw)Xh@3Xcm_dobHV8`X zpkyaX)4w*;mO-&Xo$z&4WnW`guq(=bj4Rm1h@6~8J5&xWu@=C-+9mrGMbP>|cIQRRD5B&=9(l7lbhyDQkXOMrzf6AfvQTMJt z{Z$)croA}#<9rn79}zSCdo*@sv73l9g7ehIPDUvR#O^FO1J zqf!1iL{7!8c@QoI`ZkKpA3#> z>CZT?efgT1{;YMk6XX}&^!K%Qv89#7ciix;ljC@n1Ft2;y9>+l41ZTAUTbu+56@iC zJC4{R{XV>FrpVXdjmJBJz5-uXGd%|HE6B^6=WFQd>Nwel$CvO}k@@~2ymV$+d*AZ@ zW_l;hf?m9kX;Tw^RKQ+76DV9*QD55`+$7#(gF<6%PuB&(mcCv>XZvvYLtB`5ORap? zDR;~>QeYX6N3{m?oAUCSbHw9O>_wuC1Zz*Zvzc5@)Ah0Md}NQjkht)0O0ZGBHK(yr z(=5+C^6f$=yK!NE$gWSf;l?oN{r@tTkEAh)3!VKB$o%(;%(a|PaoAyUEiEVFX^_~2 z7|pG@b+^rJ_c%OGkIUoscsvoFNKceI+Cz6I_`M94!5=b=FM>vv%7-m1A4dO~vUBX` zFDgykbcORu$5r;LZ8zwpiRaiI%OevnDy91}0xx0_@XA8)&b2$1Nj%z{$B{ty-SSEk zFTTQYrTr>UBjD4*4@APS@qhB~6a9QXpw#+;FHQdLCAK{5b$*ws+I_u1u7KFJ%()IrRG>s;TM1SL538`?f2?myem)AY?rz6u6zR~b9hsqY=W%B>|`+g zoW@QDL8iThno@>!PZ^2B=@WzzMdkvId+vIk;vEflpF0=`(1+ii!vs3LvAe6crfHCh z=eFbTivSj%+ZkM2gU^6+oRo9$4e0vP20W?DAk>~dj!W%bqJ1DhU$+5?K%f{IP>Fv} zPzeO^4FN)qf8HR3kGlXugz(HGt9#fWM4tlWl<+_+C-r@U6rQf-_}dIxx%iZTAchwq z^V%&YHDZVHl}lX_W9v<7oDVJjY=c@JeJz%=mM4T1UujUwW8O~7$az)o7C9gi5h;s#;AGUF{tHpMl|n>1~t42Tk@7K6yW`lK`r0VK)z6c z_i>Y&(1G_hlbWf7e4z#J*9>X}h87Bh7Q7c5)Cz9!QwxPc3vn-))C?^Y2`$7u zW>6~Xp;%}k zuEC&IEVK|;YEUaSwNNay5Vz2zW@w>UXdy1uq$acw=P{@)GPSTsXd!l&L2Z$tg+)RO zu~!+?76~oHt~05bT395s5WC8xW@urt&_ZmPL2a?nLTsi%ZLz6^#X<|Q@dmZUh87kJ zEyR3cQWIK;dDEn3YGJX^Ld>5HYPs~aQsG2$gdSoZHR$2Z?|kCN>@x`F=9rqu%@L}I z*`ts&bdgKXeUmGRxn3bDv=Ot}BuU>&m5z=(NwjG*NiuiIT^)0TM6%u_Dg2}sbDBcZ z)JblxP)f`Kg`}aCT;>gl@5xCrzepr+F-Z!ysYPFElFV1s!yPBuoTHF5)x(@4k?c@N z3iU*nm?R4n^>FWrHd!V~=0`b~%tI2%DJDtbK=EEVg`}dM0->I$e<&nP^)NRHl2Hdt zlERB>QNJ-s7AorDeiUu)Gf6U!%DH5|l1SdJkQC~Px>6yjsHaeg4HEL=?%*0l_FPm)shhsy+(|N zM6VIKq0y`7hW|f$b-d1^SGImZ!JdnR0!iO8e)X&qYU4)WIo;HlvZCe6CCyW88iBc{ z<;q3PlW7`(T-7`-g`_e^<+|p6Pa$c}QMt0YM@^D)X>FiDy# zT%KIvoM$N{g?gM73Q0vha)om|Z;~`uxIDSSIUY7i$`#JB*CeT|aCvftb8J&cnzM&p z7hpMZY*9!G^*GKqNh&K`o?PJ^H6}@Oh0BvGoa1DZq+H<~X$nb2J;fpbaYQI2P4zH$ z3NGy*nk0q0)$D&ZNiH%2kUZ{g(dJQ;B=fu6E}1(elKT{rLOu393Q0vhix@{}bG=ED z`CU$uxlZWtc7w%Tm?=rc}SJcDZE!up;As%&8wQ&{wjsSbeV;eE|^rxD*BRz2NqGwiWs|=swA!VzyO@9bN5vIN8DP zVO67<^}A)q{Gl?w$4@j};`?JseQa;N9e1~^wE0&1@qZJ|=!$l;`TH%@8);5_`&4)7 zu0*HZ{-WKLh<{V3CZXuGN4XM{kh8m7GXSOBr8AOTvnX%B)Rj2hmE}rw*qmdXU4SyrhECs3CmFbL_21Few=eSaU!P+FcW=yWld9IYHqK$X5{j4$jiJfde z=etspF<|?pi7uZjG2MPqq6=&zNv5*>(v&3ERN|Z@Gu}|s&7pQOQOeP7VFH~*vwqg4 zE7_IjN<4{3Fk$sgw)urzQKDJzWSd>Yn4N0B#FaRe6ipg*<%1R1Y^t$emeDU92*CK6G$DI(C4@>w;ZW)-o5G5aMjQPxr2gyU1}4y`aM z*5=F!?Lp!01d;`BvjQoZFLdIt*{jiOSVLFXgvF4UMEjb_j&3Gv7NUm*0A|^tA`6rMOqnxKB zk6G=?z&RUSN4QQP7r-aIsGCmpWGYOaA5YG-?H_2S4vwM?1R7z#27U)roc0fi%7j9- ze+UAs$D><#KWD-$yIVBi7fEOD5F56dzh0QTqCD(tRC8D-s8dmdS7?EAu?# z;2m(l9MpE3;OU)9xW~Gg0qlRjWSrS0O%u#r4pgb#Hzv*86=;Q3fNYFb%K6B_E5kp) zD5u~Lb2bbCriZnKPaWy@pMjn&YC1Wr!+|CWY3 zsTlfpv|H&lGtx0LQ4pIA~#t2?MWA>YRaCp1t+zTZ*$dUWExlvdwGEBrG< zJ=h)o(Q+6P$1M_3hdnCA-k<0q=fA+zC(UG>@Bz`T@?(kgD$sDENDnapTU=+++RUu> zeYn9%=*|9#B9MQe4U6=)c^DO^{cWNW)>TO9*gsYDz|hAx7O6e^mqA||*jt+>r91m& zXfut)B#0kEV>{@Bjd~Od!vv!?7`Oq%xX4(um*l{|DF^=7aR)B_mi=qM#k4y`#+L;w zzH?2V%EJCi>Y#}JkPl*$7F?qR3ks0qbMhCP!fOdvatQhjA^!ko-KGU>jKD1Ci6>AsGVASVv#zyS~G5R$O*zcV00 zItH-+ePGNqvT7JZx*Vud$8Su`oYXN|T|q$*%n&vvLpsvvEEdM&52lPjfU?JgbWaaV z=q2QQK|do3cfUs~HryZZ(fy97g!K{%qkDi$d?LDoNfjf<PW&PtL0A;h@J%`0wGhA_SE3C9aV|j~Pe>!x;-Ap$mwW^Jp~z_QPog4;rL?WeDZ=JI{@mmg4S`Y)e;9q{1732ji%RuY$whhmX-DK6{z)Vy4rw1XaFwdL7xuu z9_BPIV04I_JiJe#_GwM0_b-WqfzUvuaX+vg;56Dm;{ppG_`$2@y~9d_Kxm-S7yxL{ z!mYO%pjIm_0s%|q2SWAM@y;>S1TGJQTiAm46f0RgVnPkn&hhRU??O(4gt^+I`=7iXPGbdVaF!$=argyJ-20XW1fm8C**FidA}z)d3#?c)RO}`89gd|K zSnSKdI%LIy;m1BX76dG{Ay|#AwSpj@*ptVCfTfsH>>OZaS+QaP@>;P71S~~gF$eIB z+}{{q2@rcij)ldT$5H!)g>1|tyg|K`C5rdq{0XO#1se0MG)7Q+tChxX-aw^sBS70Z zjZDx0mx_#IE=KJZE8~N_fl33@GzQZY4HJAgGp#hvM(w#)8U#WEl?EE(d(pOS)kq;= z$cE)(qnYS~J^uoQeESnVm|W8Od+TLk13@vf!wh(81L7mFcA zJjbyVt|Kt{BOd3SKa0-)Z0+fLsJ+)p<4)c{?R*#@_yZcilQ^HX(zpt>*H~!~2n|#k zivTKP-aP`74)U;VYekC12Xf~5eaJr{@)#WKg2AJz+4N%h7@wHzXlqP%5%`FF(S6~T9JRa0WT4@jn4U}NQ{T;l# z^-fM>K4|1vXt-}e?M{o?GY}f6G%f=ch6mOnvT$OdRk(CtfZ7f#4FaKoN@EE?2*Fek zXt}e;f`A1@%EJvkxRb3|Hh>%!kn0nUr8IQCi)R%OGZEJbIHy{;cKwalD*Q0esAV87 zXw&r+rxDBOs3Uj%1hqf2HXslhC}f>~#M?uy9?SUVJd5@gd|frF(s1q-`Dc-T zN8~?d`d~QDn~?uAhr3q5ZqDU-Vjv=x=jAN09m2C&a5hSJwxNsb|W21j^%)f+0FDY7?w92!sa8*!2CF68Bj_w*qvV6*SDT z6glZP0<_(V1xqH7!XkZ-K!v!rXG>siu^+&{}l3vdEW31pl|pF z%1hrs`HzKfK;G~T$Q!-^dA99Dz5#j5;oxfyrVs|n!YyMM=L05(fxIyc%FAIOZw!O- zTX8Dc5j05^t#yfF;Q%VAJn4g+~(7|0vLpnM0;i#dH`NPt_8SRO_3AyJqmM#Qpw zK$I2ZVOc&L%8Jpj>{d1ymgQritQZPq#Yk9|4}@j;I4CQIL0K^hmgR$BSLgSyutdj-#KNA^yZ^|+u>cs$^W{Y1+0L&t}WDoPtF0|8%#KiKT^<@)gZ zlj00K9T^DFw}z-9H|ONMqLXuSIJCZ@q8!j%hQbP~E9>g3R<0o6;>Gv|Xf>;@oeQGK25L$hmgB87ycYuiXkFFW zf%4^*4F9uAOXx z3x**#EMHYq=F1-gFD)tvgI!8(^78}(f=+GSN`F;#WoW1V%F>2ab(MkTrPcnkR@PNm z8_8PUKQ}}{PgYfcv9J}DXE#)?VA`mwTvk=zP+12BuUgR{7%r_XuMbqM02tkJi3b9G z>-sk|3vw)Ph^{X`&&aQ=#eAu%hc#o`2yDOt^);o{)q&Fb`pUWn6U|Z;tye4qU5#Gi;^$lSjO}XuZH$6sW0M;ah<3Q)_x3 z%J|YV1LWrw<2ST=KR~cH0%dK<87yw&2bdo~O;G`>F-E7N2+TI1Zsz@zp6$!U&ocB2 zMK>r@FMwPmdI2Oax1hLSQGOAA3Z`Eyx&YYhVljSkmtTzEC>AX$EGRB6T$EFcE-ocO zVk|@fKkw4F>I9&{08&&~h#zd|UuG~G4PXU%iwhPP73VE3?AP?mSPhMab!8|ecTqt> zQE>rQj{M@B#f61<;eH`HyIKeBKy@WdMHSyQCOAZj*P1oqg?XKcFiDwy)oj6s%|v^H z2^C`(68@T5Aq1cb`bM+X5CWHdc~*FN?_d%$WFWS!oz<^s*3{Uv}obf^p6PuV=^KC zB?z=;LOvk~Ool;BcTUZ>+Gr>SLAK@r{AC6<$x8TT3~mya@XHz8?7}ch>fuPO-pLR#NF490EK5UQV<$$Y zIdqqJQCrKprXCHCM)j`4Crynvxp|ys5aQ51#&wmzHsA9mo0$;0zH)fXvPq~GRf__B z__gMB`XV2dU=UQ?r7vbh*Z~!9(@$nasGo}8)k}P}{YKmS^iz0IH2$@IDld!HFX*T7 zvS|Kyy_8W4bOf7vjsBM@FoTQb3ee!CN&y-iozA;ZY2K&Ts6d0e6)M!=ait11IIZP< zwHb`wrmr$Vg5+)bY7=I#d6o$?xI9~QV$yp-KTm-Pf-mTe3eaHjOA657a1HAQSHwb7 zL5?H=FX(LyVMEiP(A@W;%0xMSH6V$j!Tmf)vu%)B7JJ^!diFc>=_4jnb&6Fafudl42e){@)+VSqfAg%wU#YmVj*4A9n*JJ!WoOhjWDPWR z^an|I&G?A)`tC01Sim&>dIw#yor}trjth--rh=^rC1chZ{+ng|WiRwKf4dy!b-wie zUi;%>Z4vKE4Q*&`_Ju7eU&xzLOFq%{PE7x`!9MJ!tZ1lPiS1M`whGQ^B60Wjcl7b1 zj-R^s1lN{#b@ugibqH9kw&ce){X$&w_p0sr3zk|0YWRjF@7naM$nj9mRkihX6L!lG z7+cr?ExE_8Z zo}H^)`csk}Mnz%AXeHP&%AtcQ`L#>`i{z!YuBxWA{*2F%PF(jUQY6-vCBJs-@7ou{DU?;=77r6MZ^t}>7HY_is#!PovIc2#X=FhoeIpyU zZ?zegwXu9u7njr`a6#3_JURIX+a%=Kt2o`jN>*pz__}E#l?r3vp*k32m{r zX!RU|V2jBUlpE?MHsEm}3tcQJ7_ zre`9IPO*O}??8w(7f}Y?d|=T{&MM8mQCbjvr<%TWc?pJXz2+HbEt;eaA*c$pY{(hU zdK4QVd5dT2@hyAeMRSa|o|#ntFIo;3FEBqFCvLB4bIEq5z}X^_>|D$Cx#4;#&JDZI zolI4wWfYhhp(%xIed~IslHCSEV`Ezaw-t$?IA{;tSIoB+QP`SCH4zT|Rata-BY(t~2N$z0AXzjg!7> zJD+p|iPCFbm}amUKdxq=5xG&IZq(;|hQbO&J-g$F8-8K+3aI5$1JQd+FRnQ((EXmj6rq|?%BQEOgqic>5+16iMd3JeaEv_025ld=DhJ#P+O{%HCIqy|x&>pRhx z6^a6!^$=CnxD@ree>u_)L*rtssRxK`afczR0D5szX&jkg<*)W7u= zxaW+8z}V}`X$utl%X8=;d3>z1!Bp1OtyoF-2>)x8g-&r-`f{6O8Qp~E->J|oOeJ8pX(Pmw$AAF^kI&d~ck{?v-A=2iz7_+h_6ycmXK3R{u zlw(9pGN$#PNx5Z1cR?1qneWTmJa3+F4hGaF2SiPC2J?*K$wsr*V`v7sTG-@;h_umrS|F5aD#Zc!=7$y0Gi8v3z2E*SM41dA%h|eOfNkO_znNHGcSrE*6 z@by#h)!D=rfXNya&_j%h69Bbe616UTYYI~g`-0L7Oz3E3i%^=949NZlWcxw4HP{nu z{ogQHe5hWXyk>D?wVQa%a~VYp;ag6+H__bQH+jK`1{S%PL_qTiC;3o>Bh?kTS#8*! z6CsYWD*M{#?o)@lP}Akp@06CcS#9$hCf#_xuYm|WZ4$^khOX!H@RG07pksT>We!2J zy{(k+W4m|EVxDHZBhrjgdCXtU;`6dG*L9P-fKy(0=t8WFYcl>0N6j&*cwaRCABgrH zEEK{0CI^?3aRV#lQ$)24k6j2{gWIU_wH%!Rw&6x+ z(59c!sc4D4$KT18(jm!~VF!1_r9TtWK;nlPo>sEQt-ota4fJlrom!aRHZE(c`E7&w zJ?_?z*rqc)Ht1`@+37Vv{Eu7zzCE+0t9vu?YoQrVk3{?X9{tDmS+a?hJnzP;d+O#- z9{mT-S#3?ty()g2#nON$4!vAHv*^HWbnQ=LW+i~{gw94>)r+eR8IJ=?KU1Qy83n*r z1waVjlV!!6+oE`Ml z-2LM>T+MyVJ8js=yvs&oVtBNz=r66Qsy+w1Nk0#5pxN)Y*&X&@*c=Z1aa%=Ybwg?3 z%=}zj;0Tjk4Nm|KurxEL={ z&o5lGxOg$_THy_QbcZ5bw6upHu44ZJ>U6mA?U3iFv*SzFg}5c@+Vl z*c1r4MH1nUHgUU&cGN>jECz)?*+i$f*-HCuG`gI@0>-zd|2edl4HIul*I&XoYgggn zUEU6D%8GKz@NRkiRU5m-TR;lHO~d-CnhM+mrYG3xt9k5xu)J-n>9^Xsf>x~vdoQ|E z-i`jIz%zDaEE_CM9h;gq_lkWOx)guZ=s2sXwY7)cm$tH!olRGmycP`}GaAtSx%vj# zEGwkdJfp?0?Q&=<{r>t&qeb?ZCT1^>i(ZNfB>n6x$b_Cg@P#n+d!W{yvAnDy3(u41 z&c~lT`jd~LAeg3BB*}TKcAgI#<+u>RcqE)#o*xJ8o`*ERr(n^5Q?s-oeA4_pitC=? z95j?2F9#;Ia2%X+N;nRvcWTEtc$qlBGXNWlvj%eJ59H1t$eTYfMgjyGXZ%Dfbo>K+ z^ozoZi-vAxb|9Bg&n+5*FGUrC4+`KWuOI}UV++ylE8c)RzNIZKf&9Ed=y828*o~wv zt7$%an!Cxj)R(mp6TXkGoN#O`%BOr2qn(ctU`J2_2YuOixEm02{|9^F^L!96F!A#! z)>(aj^Ko~!VDg>)jCD4-p2VOS|Kqd&Kv-Fsk~+~MDwU=wf``M3z@)KY5;PtgJ2I2N zxa}1^JX2h~@~i;=5yZK8cn7}+s-)jhz)!vqrt0jf2GsnuxC)O-u3S-l4)%k`X+1g- z4kN>#_#0-|NH>nTM&kFrjOQ;t*R3%6`Gk2j)neYl!mU((ZwPl*aNA4Z&|p+B z;vS2*A0`=6NPb~gSYOCP9S+Bs%d=WymLA6H@6{6W_Tc#=XYIyfT!!Ixx%R2P)t*p` zH|_JX9;07rPpoCroZlVC14$^;RA=QA^{=7KuI$LyBYgj%ev>_(L&Otn_v^dt3EBU! zMW=W6Z)j-h=J(mFY_qiVZajz3htOT`vdwa&vyaQRfh#I{w2TDp1;%V!dk@x4u-w^# z?|$Jc4EhrNXC7zv!}f_tK5Qk4A|v^F7?Si24qRV80-8G=6VS9xwa}y@qj@w8P5R`8 z{)+w-XudHa%?qqFQ6!pr@>rT}^jRWXvHoY!{Dad=;)MLx2AM#$Pb~rsGx~IVnYOQf zU3;5QwQW|k#yV+k$1Zbgprxs|HPG6Y%VZs(uSz7?zM_8=;mm%>71Ei0j@nr`u~<9P zPyUR~NLsd|`jwH+?A>mr0dr&_orROv_`_f_vj_FBf%1E956P^qYm;Jv0F-xi7yw&( zcSTcQ6S$#%xP0IUdfEp~6XY}>)NhD#X8+oA3^X0fh$fVq%@`g-m%d@-NYr$vIU9#FQNJqI znf=~3J!a-O&s)@=%tb>iyM52KT7VvoVllu6Ot zJ|Xev^nZf*tH(r~yen73xWus%X$kIJ{UZ>6IPMrYSEk7L#L4BkZ_uxZ!~F9e3vpV$ zK8tg#TkbdY8$kOn@!oXh%j#?;q>oklJDS$ARTbXSmX6K$x*+@3r3$yFcQ@c;>#ZHM zYH}xE#t<8ta93MP@ce~LVa)f~=}|cJ6D_Fvn_Bwt#H@hEY8foYoRay&(mc~(*zEHx z)1L?T-$?ww#(fCi1tEM#IQ4&m@28W#7{0}7_XS8jgl|>eWabgS(694if=>NE&bKOW z;ybcm-wVF~FfHi|v2x~f(z`#uywkfngUy@8#A7~GEHq(Fp83eA1^R;+%1FxpdqYvQ z!iREH{|kn)efn5yGCfKR4{$BAj`5L4X=YBQI@r0kZ=LiT(Hd^qyq=K|lMv7R2XfO* zn>HhMa;wq5(*K3-x1~=sq(CM#ENEYT_7i10;^~bFr{TuyYPwq6+wkiS zCV7MbSnS0rP|B#Yr6Ae>mYF~=uBu@2T0-ovZL^Y~u$W9R|0~9P4=O@@W$b+Y+hBg{ zjQ>sM$)k>8o`44PaaRcDcV#5RZ4JjfsXO-X`a@v;XT%a(Bt&__FvOzE`1AB1fuTQTPLd(I$T4)lgEA{a6s8%{NjOVkDB(QL zQ0#9r5+c44jv;cL@o(v`fT5qyj!v&(>VnhILibW|-CEuiY-778JS@ZoG}~H1$;0h| z_EGRCb33j(gQiKa*e>A`{XZ#)dgn~C4-o{3K9~|F?1QFf!a@D2>CWuS=T5c{%os>k z_JPub<6x$pSgCJAA8(?MYExF-cy=^sUArbLFMjFN)iG9NiQm;nQk~g<%sPgyCKOxv zu1Io8N&0uu)i38AOIH&~FKky#fJv9?`_a|D?9d$_W^_^+Q}UQeSn{r8S=y#+!vu`>vbmzy?sR#s(PECU_skbz>2GK)agK6Jv zSW^P}@6f}CUr-OdxSkGnh3)8<`k&CzOYv9>h=0VCpfc*7EVZ6*s!D=GWW+)CIg;&SbqYPKllvF z+++>Prh>_HjiJmGJMA?6IZz%wDb!xWNn^bv&BT%3J)oAwmPvcKu9%OUwp-ty?#%ve z&V*eF@fcl+xnXogwE={e;W_4{Txv#-og3SF#}jsGxa$|%#0AQnxF zOF`f(uGl)%&X{si3ia2}*}D^UCR8Jp&NV~BprB&1osoJ{Zqs-BoY{v8lE)v}#4<|{ zb_RRaZsrp7rVnBVl{WE2;6}rv04zkH)8q7~(CyYD-vr&lyp%gB6OR$@)tlafh@e~S z9uazy!5fJsnej%sG;T>_d1Eeo`c?X6Go9JP#S@4`>{m(o^GV3$A4b{WE!M&tp?gi< z&?JfThTPO~d7}U-HADXic>B(xFop<&?F&|Qwgv}fB#g*F2{}|*vgw7lC{zSHnl?*x z*bOEP2PLFsk%_Y1v@{mZk>l#^ZtCe(d@Y+CsSoH^&2nbnzxY^r3aj7G=4o7RnD)}@ z^c~>liIb0!oA4U_Jlv4J(nj@L!Ofpbj+L7*cM;Pkp|9~}gFV|5I`w;IIZN(ZqQ7mQ z)6&u29bk7qyIABxt|JpMj`jJ!qj=u##U=Q8ixnS3qx&0U@m~l2bxZXxJ7#nG^iT!p z7Zdsmc%bj7mHZ1p|JhRgD-J;4tW8ir|z)xB<^)+CGVc9|HHxqjZpINI^#iqnDd}NJP96NKMo##b((&= za}FM`sxQS4$}tYE4*sKZi`a0#sS(RnO%rz{X^ox1wKZUp7*3O8)JnFM;$d|B`0UKm zii$;YIBZaZ+E}WrLT~J062y&hk|X=e7A>vhrBeN6Mh(B=`ux;xE7RYXyyX@h2Xk7< z;WGV77lv2A9OFAq8s9C~ZzdXNVo=9P;_Y(%TbzyKr}4cC{YQ+A()zQHOBVmE&>t1D zI8F*bsMMe5lEACSgy|oHt!O3hRqC$_IUFa2JN^0xj6%(-`ijXip_Lr;>s#Gq2Q{lo zkD=MlW%~7QJe)|ggAX{3O^P%zInvZA$7U9M)o+*SUuTV=>q$5I%5wcS&R}(^=;|Ck z|IB&F%f0;@l&7TmjMPe=T&~}1v>#6{6A}1omHvPrFuq_XBJfm|{-orfS`48*>=5v4 zq|hO>LvA;ouD@s!5Mwwd3Xh$xzriU$%ab%vt>oj=^$$g>`pLJt>kR!e4_VaN4P(7R z=&GZYym^Lxy@wuit*NOl9mgt|u+qi~Ck?{6qgsD+b~Y`5^cVt#Y!snqCd`>rk2OzE zhG#cBMOo(y9o{gWk>IK;dAnNw>YO>UImK9f@tCuLnzI#DX-;cLQ%egi%5uE~8Ry?h z_Sfk5D`bo%e$IYIh897U%T&)6`knt0NT#CAb< zRZ|D{%0#|7i05FmB~PxsY+wyS>wj;o~~BB^9q+tSh+-j9t=6E zE&1w7{rW7%6JBo|hA+X0p3F%J_9ScI>-ClTx5p4rcoPJOKN<)HEMQTj&6;E<9B)6Z z)j#5-5xTGE+9#zO;<0koD!AH+R8Pi_UMbF@Y)e-!Wwj*_oT=}c#|Fy?eioOEAh;!h z+EIg`c2p1?pLbc4uSy)7MkMhab^4o}36glo$f!$D0Wq2dM25;og*EDWsSLBVGVIF#N zqxz_gh~?56&F5`s&fin=^;P<9C$c$j<-nZ%ut5Hd4h>wcGx7-^bt1zbfGNxwVuKQH zrENWUZi4~L_&E)Ze6@ZcY{!PbKzuy8j^RN_8Xn&9>%8OF8^`JRnzQtq=QHJpj96Z} z=v|ZS7wrv?)X!ht+k=$Bkz+s>B{X+*wXCnFTWB);Z`>rP{D17d34EPJ)j$5sU6PxnZMLRK znx?nuZB0Xx=4MaRLX$LULz6Zn>4w4EEH_PPwq|Kl1X|gwxD`Q20R>TU-w;s|r68M# zS`d9f(HDJD7B^57UPSu)o|!Yx^W2-8G>zb2KmYe>Z_b=EXU?2Cb7pzwd7c@`Y{;kP znb}Es&1*k=uDG%wL^V9Z<#ES{Wrc{EW#){4XbzbURt-AJC?cxui3Q1ee ztj{TIY29d2>EAM2zI2}WSqv`+%}}Qj)rmwSCZhrFs{}#^_+x^IhV`vdAi%gOvaI=~bRGvxQcq+;d7f zbD)ySfoPS%R-EZo7Wam$d~ekaLGePFY>QK@tcSOv8>ZJ7BU;#$ej2T0Ii6JIFb6(a zjwfd@vKR`}*t0bGc#l|Uel*&;t+uwV6-QWEBz#S`tqI@r1h7TX))wQC71LO^Wh3@s zQuK>0y4oDQ0jHm|)owB_vLdjX4|W7HF0?4E_%d@_V|9!1PK(x7hp$HKs~Z}zBNoo- z;)}kC#qE?)j9&@9iFIb-(^ZZeli%0i?lj`wclvW1d{bLMJAJnfjgNE%+uKGu21k4F zyrh17uxqRjn`*VodmVbcX{4jOZ=!_0W+>>QJSc)c>>)k$K6fvMe%Eulg8$t<`f<}M zL*W~-(R3qb5?|FktBg(MFB8j*)eG>=^fDk$f&K9sa3qY&XT-&w8RzuiJS%mUOtRZL zO(rUogd?gf0-ZL4lV<4n8A^f-Eun$r^(hvRW5NP(0boQji)$b~X652xY8A&OMMp*V4d3ZxMYn`9$_ zk)h-LFy&&!LBUL-Q(#G)K_F`$BsZj1#9-r46*LU5rj^7S#xjk>#m$S0hv@7DQqAS% z68PKzWc?Ks!0v?v9FX=l89=de5@f`xWMqtDp$2m)NP#mH4SVV(qa69kPzCKJ8S1a5 zn38zKU#JjD;n#Gu%Va_N6(<|ShxSPU!ze94$~6nB7E~^9dd`Y(NL98e3neRJxkcQ_ zd=(Z+CHErN%1|Pa)>x#CsYIx<2r41&r9(-EvCblFgsslBP)pVIFxgq55u_}U*IQ(z zE)lCOqD@GwVbp|1NFgBCT4WXi;)W$Knjij1{#2(B!>G5YI~VL)umh#ss7M;!M8b5s z1`8p@&bFb*VzWYVCLsl!p0)8MsGPGP21DpO*_)0ukS38k{mI4VBDnNXc*^d zPRjEg8p&HgXn@fuLUt=e#dIiy=$I7w6I8BUGKh@2DL~l-DPR~qZVC1fpoZS-W?c=V zkAp~cz6u(~UL8&H`!%9+9?<+0H%J1hJr2nLWDM&Pkg@kEdjnM!(%YQ!+c zN@WWkuaXwszs^X5!Uqxsb)1GVv6cfcw7ljz!eG3^z4>16+e^BOOS_BCqXAG7^7FA+ zGuGG9@6FF29136y0zB%&9qTAPdmP8(Ic&0n{qbew9(r4W-hdnE7#^m*Q%4UDbmF5q z#CG>}039D5##YLs>nbaY{dw|FSy>5ofXMF}9$$y8)5n4n`8X9XKfecf>rl@a9k`dD z-`R&hn2HXMkFBF~JMdQ3KoAngkU4e(X~(y@NI6j08F4%xLgM{B!GWRf;5v-{UBOtR zVGyFcu+>0taBOr9>ZQ|PQj(9E#y?>{9C4t`*VQAq-|>>S@ia2f;n%L9BXAnchTwj@SZ5we(^S}Q$qf^t(wfmY z%wk*U8I$X9#-ulY1E%!Y0Y(MP4PopkX6M%Vl9FGsnWszIXtuK@(ews-a6|$=hYil5 zs=7vcymOw0>u${k;~uaf7%@X|e3~DEkzJ8k^9Ba1t%ahGxOCE#O>yTDBHdTlu5 z=}V*`Uf+KZu^l+NV13DWbn)gz@zExRaUM9PO6Em4#s>590>|_#j_!HnrSyxvPvh8Y z3HpWL&@UFpajOgI@jtdvumTLz|A^9`bD_a`++U~ZNRUx;mAK~w+%=BQF%5T z`MdvW!;!z+tUt&{{_g8+@yOq;{moGMyDM$+$lvv%4aW%Oy3K~K2ENaRqi$XKHXLUX zIR9kBvw?rjhUWr5Xu~o2ajvuBD{;&Bk`0G1IlgSev1gT|--hFiAjb+Dj&l*jGd6q~ z@K4$BRlx1#$COimrY_inWc|*DldZ`gQRgug@E`J>uOJMY#ndqV5!}YT6Z9g+--EEc zfYYVhyOFJM(|@q71sPLgg$lO=d7rt^RX+IA+T_&$OJf5h;|$Q!tbQ@B8z zknv3nZRw&porFji$LR>CbdrvA5>}u&68~D31AHFiG9JE{LO6U+@KPC1b43lZFHFqbO}!wMjGNpyuw8S!xY@*5*>B9j3DYr;_!`?grm($ zd;`aCVtfn7qrPQ2_^pH&FuauE`xt(hAXf6Wt9zldy&15W`Ct-pugZ4B24xS29F> zOB~~kgikO;|4MkYhau`q;q?McQXe+jD@!apV6$`JjR#DfgsXA(ciko$@F_cM<1RK|ad;pZ8C zogwN;>hV2>D38Q{&hQzAe_;4GhHof159J~Ld9kWo^U@g>FkHv*JcbuCJj(FP41dIs z?Kj`4@cG#cx!;`6{yTr1=@`Gr-t#}h@F9jzF??OY1&bNN&cwf9E5kvCmoU7A;XMq0 z!jRilLW;r@au{x6xQF388FGJ=!0j^u{zCaC{87Qgc?`M#NJM>8eBy3~+&&YpVf?EM zxqT)+tMDZDrzCElNo$zCi{Su6_yfsLLj6m~?KA0V#!o7k%lltQgdfTH8yTYhCC>Uf;75czmoP;A zOME>;)W5_pV0aZn)SsloKP7}6B)nHa(|*XW3i6F_V||?<>?`MOU&U0A@ULUaXQy9+ zHEY6Qk8(TxFxI>YzYOd0OkZJ-haXiE{w1vJ6MUNWcu_$C66r_tJ_*le_z{NiU!ps- z{m>ss9DYfV9t%iV!El`64;cPZLDw>dMGOxzypkdFyO=-fB1Mn-HADC%r+ zghYlPWcX8t&nTGK#Sr}%$w_3p(!C1dNtZLcmf`aZS+C?Kg(ts*;a3Qn?owGCZH*BMiAcXD(29ChMKKoAEJ*A7_Yho8&EFdoE!+EV+>BM;YF& z;8JuD#J_Yk!+M4-49{iAezKJ7XDRwIneJhRT+d6neJ}lkqI=^Ru3}im@Jxnn3^^Zf zC*$0Ydv9U<(+t_3-g_8-iQy{@Pb#=9fnh1bDu!G?%Q)X<7?-IW%PwYk1;gtY-o@}< zhFsodKWF?O3T8VQqQR5A>`aE-pJj9Zn$7;3&HkIs{*%r5W`BUw-Ncad&3=gS6AXW) z;BxLSmUF(#lbP;gxRzlJ!?PK_o#8%)2N)h=$bPc?R>rwsTYfv^_cMHo;jbCK!0^us z;^DTmhmZZgtcX?kie(Jn#*o{?iuH`|V0a$GAjAC(x!zV>!#L};g8gR&*W(KIpB0ZW-)|Jm zWj%7a-Q|9W>EBoI46ffZ*niKslaHN%fFe4OF$6f9sl1#I_%0;aRQ3$`%M@(Vu5 z_@@}&&5--af?qQJdj(goWXR=T-N`ujE33KPt!6u~zM12{s36|@ljSWuli}G4`V$#u zFl0VI+t2?4raz-#5&K6Gx2vLS72TW zj!wW{9m4b50{K`nFg)Hl*fD@@BMU4VUWpqB+6nZ|wjIX-4MPgYL)S3~J~$vV=u(eU zjRHJ64&Z@npcii);}vOjR>Gc<;R4RJqZ8+C?=RRhGBiG1P!y;hpqTqD|{vxBX zuhZvi!D(y3(J`M7*6Q!;l+VtwjU7}Aj*NEn%N>p*_@CtC*9M_5-bv``KZu#t)O?HX!@Ej0Hd9`h{R+SrvAkh?tG%%GgiRpp=eQ0utt*1HC_~EY z5%{nMX6M^^4W4)1IF--9nxLJpy%2c+R6fTLXjmW8S3Ak_;8%%XCVnpUb94YgKhw=V z0o;q9zF2oh5eRm9WEZTPNqGf;S{|3fl!vJr2>r3Ywrr%!jsZE**Q1i8`u-301wslh8`qKJ6 z2!c(&q33{W{jfedoqj{4n-4#I>3qZV8>Tuvs+j;aUzmQwpGO?koxZewSPQi4w{IA@ z)-Mm?Y3#S}FyfxZPhUFUF#Se$gW-Le2~hKe={NFw#2uf?C-#75v)}0FfouJ+K0cj( zqjw>Wd{SRJ-!T2gHh^Ik{x?RxOnK`|+Yis`?D~z9ycGPXz2)OKjs3=V;`!~zSL$hWA)O=y~JB+f*lXEqz=Hq@t`{`xRK*UDPWXTgT2;1y@MILZ%XFNBXt{hja z#q)A6;`OET4YTw6N#C0_6QJe`E64j^$GZw-Lw#vJtZCczyJtOctzQnp)7beQvRyoW z`qJ{k^t*@jn9xjsnlDVhd#FEnIRYP^HQ4pL_aWdO{KyZM;-~fNKp3)hecXEj??Zk9 zG=1rO@odG^0l|mH@P}mRONTE2L8n3RA(X)dndYVAMnKV-BKU(%;2TDO?30Nf$xFbm z7eDd^z8?Js0%`bBIh^G&pWe0p4^e8cSW6x9dO zsT_IuO($;><~+`PRHkY8eoN)@GGB>}FCAfOFMRzL`Z?~@7@%&KR5v!h=P}=k`(6Y- zF&x78^54PJ5ze=|xU9I$YhC`5iqgswKfVm~dhs8Z`in<0Wo2M2sjMtgl-;q1>Kf~X zL#qYJ!pM<-%}l;_lo~93C4ei(*lx7mxqjpDoyRv0f9>R#ZY7YB z8aui8XxwCqanEF2T70@EZQjx7Nqi8MC?=!v*O7K4<2_f!^e*eoO^iuQN_+3IxZZ}u z`NyL1HzsW)W8YPtv+M~|;rL0{u_eOTIX`WEZ}nA4_5Mlm%E^;&)JGpnnlvbsR$;8aPk=75`Y6yP zM@FHsez*5n%%ppXFU@mQOu92XM`Mn8CgTB($#~E_B-=Q?bAgndP+!TiqmCu8>_Ve@ zGJ3c8Xmow$k}}RA8nG$|IIVs9djA$(;iE!?rkxSe<)#RM%wWYCHJmBnq)k* zGySUhX~z+sXXS`mU7R+5GBN$KbmM6BvBb1_ld;D#kEYffdF(>eufNwwizC}1Jkq;9 zEiohMLmt#nZrb6rjD!zmr0p(}b$UMV*n|)59wGZuZC>xlsJ=?pW%{+K)%at{Q|m5) z>L}T?tggEX(05Ndj=9raPa99aV>0G?53D05$va|Dg9%iF#}=d|pboV^=sK%Nkac!! zfhpCjFBwyPEPB!bY0*|49h;}?2>Iqv9U<3b_Op4qo)Fgyozl|lCR0)0%0kAo1F+Vj zOw?M7R(Yv%eR=7(U;NK%`P6bEwfr<&%ZD$b<)f|3mJbNO0qvA6AHBy6EuZ?F z*|&Ud;Zs^ZNjYW9zxe;7mVfbE+wwE0g-2-lX||R>8G}}M9$Gxwy=?zz`DpR7<)a6f z(()m5nwAf#6f;B1m-@(-PpuyLCSru)mM?YsH*NWg(el%|<)_J(pE0H7r=#UBu0hZ6 z-Et4L{j~75|3%sMhwEJvhwJAZS@xcf_jcxp`kWJSWQ&QXbHtNEhwplEBPKv1Ma`95Voqz!#eQtb^k(hL@MfHrPLoQ*G1HS5Y_;DN2zHkFD@uww z`C$!hQLZkTo`O52UDgXRbr&nS6i?>D;(4%LZw}Co``VBvo@zqsmbZw`<4%#`a6}o9 z_kT9m56IqPoBzmWbEEJiE~k7}d4?e_oS!t$h&G}{v?JQ-ae3UHC{MJ<7F8!-c$w>R=M|7fd@Uw4Dn`k z0;-rs6n5&Npv(QAUnURTIT~mEGD=({qUZti)R)(=K{?-Rk|P+q`i5Jvscizf!&LM+ z`E+P0&d(!)*o9w4pFC~QWQdmg$nF}$$<%bZk9l0_u0g*_}a2k9qr@TT@xKDM`PDSrx}vQ!LHi7CgeuA6gp_~9W?n4ntTUMzKMriC%khSIr15f?M;gBh^+@A~|L2ka=aIAb$gjqWEz%)FUI$Y?NdBj~(7smL zYJZCU=gXn~_#u$grRIK(=uM;MVa7&tHoC;=Z&@nGMoJsSyOd%_85)xsF)Mu2WE*OZ z=@!mO5hbFM-A?Cw98t;mw-~>L{7V5`i9c?)GX}xrsNz)oDWE_Ug}~{&I4XIeOhDvJ zq88&?ET8b22 z=S9erbax(#N=5)>AW4+;#3Z}3odZ!z-ANQmb|on@^lZn1K~VCWVArHliCz@9r!Dv3P407a5&X{ zHg)>ZuNsbv(BT5o0N}WYrfhtv`z00cd>!{rZy=0&DL^CoWy5*VQFQzW(Co!=QHoB+ z(4i8_N5C$XkRE9{U*&`d7|0+ScisL$ldhoT+n72goGNFHH za8D=&b7&^mwp3Kw(}s!)1!|kO1!}iqlgXU{Z0x8Kaa28` zTDR7>(FUofhzQ#)(u>_9kqPe>Nof(Z_KOT5gzOj@5@YTe8A6>>M3fKGSwq}XS|PJ? zxIon{wVMKEtpUw!CzFUmyI~}A+oo+zHQwSW^y;#b2;9|_rno57Sj{b4>l+&D!ZWR} zt8T+q^np#)jrBXWwrmJZq+?b7RDSrXsxTe30g6S8sN30Aw?%quOWnqX*0#D9RPeSf zZLDy0b8Ty&VGGE}b~B3@>m48Hw1-X8;gC)HXG&!4F{W5H#P>UTU+Z| z+AOkSZLHf~*T@zmXR2?O;;`2~IvHHO`rVVL3Sf^du?MwjqXEaQ!VsY8X`GBwFQ3*P*;Fc*F_3b0=0qGZT0mH zJ7LlOenX@N0?pN^@1mTEyo0N}6W-;^y$21kh{=j-Z8ddO zIIm6$Ln=_E2DbcGA!Rx?iDmk9NlAn8>C$Hg0*za@Y^0x8_G$FT5X)tk3&DX6b+wJH zUTpRl2#{&Ev>GB$2Vt~P@Kgkv8n$@z@p-Bt#(?8PPe~{)DlY?R93=QJk#a6BoG9;6 z7nI+Rn6eTXW0ua&!kj%|J*e`j-s$xhp;y0vvjI-Ifbvex1(YIxNqI>{aajq-7jhOL zTUk^V6%`kk7ZnzlRg{*LmzP!)mLrQpWJr{SB$SpK;;N8qi9L zDoZNM%8M#X#|?3bjG@xVtjtQmlYx@5@)C?i#pQ*SrKSEdeFCm5GWej@bjlR8OT>3(WOgck2-qP1aTpt@~q zQ$uZ}p7rM;@knd;lwTq8T+D?)wi(9ptk_Yzsajgta6G3GGUgvO0_`w8`;$f?fcwS2 zh#gQnk|r;6OqdRTC#zNjYH85I&k(N@0nTJm{y`MfnnihoC~z4`vAT0ge%L`pF$Kyo z59D`AvL#m2FOhUhxTaq!=~fn|TT&iZIFJQZEaz{!jvVA=O}<;EpO!~fx8pWEQkDfV z9A8CHkH7LAMw+NJ%T>J%n68Ab>V<6=PZRsv_L{yydc@W@*wsJY9mHc}{jsl{X6cne z?9ry4UM0*%h$&*O596!DAH-3y=yHiDzW3_t?HDm!4)e65%ni`$0varj% zLp0fmrgmHGR8z;TcB-jqv&yT-RP+|H%_6bLTf}yYW~#ZvqM2ImE0&^EO;w9+jsZe%xMUh7lew5prcCUx^w3R-Iu#sGX$YlsSJ#ElJG>Okllq%U3# zQAN|{>NfPr95p)DG1k{*<2W-A*s>L$^y0R23&`EUuKv;CU{}r{-u@UH9~ne9Q;jKo zYuyIQNAHn>JAs_>(O@^t_;D=6j=Jj2;n4?z9eXJniy_;#R5vzk+)}qe-Wn9+P6T~y zZVqlHhC90UV%>wBn#}FZU4=MGbvBBo(hzf4&K>=7xrA9^3_9&XDyZaPok!D9{FZIC zZIHlOVW$F|_iTul(a~+$+Kh<7pDP0xtk*+eZi5ORaKz&jdtb~PSneAB#w)`2YRu! zjyI=p8%q392;FdMq1~q?^fM&1>6Dsw51fvsUxQG51CA16ry4{2g3zrkgbs}u;#r_I zo15Em_ILD;2dVC`=TgVs;UUy9(+u%G7u~X*i^#723(Rq5gB%m8ri?S{1qb|Qg0^3}({joZ_Q8>BOm$?j!~?=~rChvpQ*WYx9iyHjfN- z;rOT4G4wah=@c3@ zb@UBJR_BT+@k6bSlwwoIOvUP$czB_z9*hz{)4DXbG&EJWZa#&D`kFdM`85`Dq<2M& z-)c2X0ZNtO5yh)b5}LB=!D#Wavl5*`O#@c=rI}Sa*(2BvuT?eBj)S?z`{nB@cO6%Fw#42Jvz*tceis zr3u5-R8s8PwO)VOwpHE>NvkP2lVD_u^-KLsgU4LVGU#!JoZS>|Go1Uh2hq2{RA(2V z*l(r}nS1a>_8yxLCkRqvah)=yact(>%y2bt00z(%eQQ6#Phid z0$4MUj~V{i`&ueNL9c8Y`o7lqG}qNE?`v7an^teIu)M;L)@`Q8gz`@0N|BerOypbi zO(T7GPJ1(~rn-SeY1bxMGgyqDwq{TxdZEC+P+xe83M=7w`3w<{5F^$rs3Er+n7!lJ z$3RYY2c5E)E$psa%V1#$&YE3CFx>bd2sfs&v}==DMA= zbzGX6(8**2zq}v}u zoKMxjv3~Cv-kfk2@a%=D8m5&n62QtE&eqlsR(>ILv%v{kW*F`Cc_6(Vqk&FrmpRrq zNCL6=_BXL<+s3-Uc092}58cy0)G@Y-?nLVwwluV1hJgHEFhsHbmgW-&? zVm(czn@-gK3LNb1#Xw-Lbrtpm%Ij<87NKO1*M%$$4hrA0l^o(9CeC$=N6?o#w93dP zvL@em_6&FRcZ`nq^&FIz%TdqSDZFl-ml0LkRo=5uw{Vq!m8ORn*GwUU3LPJH;(6z} zbuC*l3;}(NP>fMqwxX+pg-SsCG0`-Ep3gi^1h!6{H>Vh+pGY1u2R$u%Su!+k-B?rT z&B+gWto2tjN*d2wI8h<(RYERRG1-{Le`)2ef#H%IWRvI3Ik;+-cO?qcqYFey3nz+9bd8y;`!tfl zF7I)f1;93~9sU1`QmCD7Q7xxeis_P}6j!4Z*v#y7sut{F^{NCw+6|C~V{b?Q6}AYg zQPX45s zwL%!Icgt)`0`uZ7NB?G~Txxl9yA_@tYjO<+gp*&BuvgxJLr0+|oHsSm|; zq;Z2krw7Y(JjJn%%HAG&`qXb9sOk3U2ey>WIX!u8vre4nZ6g6EECEHQk#(M$UaD~# zavZ;pvWj3h{$RtJ4aXlXw8(JW8f(o`)ttXk&d+P6+}F)+5kT!{s%HH1-pr-mrZ-%( zn(uS+w_vvKl2Z{pZ*nO+nGdjB)&nRkdl}7=Pu>U|!DH0KX2mWESK&cwQeu*E!#;Tf z5F8ol?HKIFgM>YJ`1E5Ts&00O4~nS zu1~q~=7FiJ>Skxkh>`|XF|Umh_lGAvMW&n*YmYzBDRqaWQ${S@D^cRnumqYvVnyB* zE&l9S92nh)C$(_DtCX!n-R~;6-$T*j6-S2TlZ8GK$xn}f@$b>%OHNi_ear|8)l#gq*GBJYkB8&R* zE5fgs);K=wkh;n{MS8e;6Q2I52d>sS=4TyP$o!mx$|U({S+TylsiAR~*Km9*Jb~f7 z%i(l6zwL0j#6yk^b&YM+fpd!exWSvih>pSUdz$Dk#r+B1+xWHfHFRd&p!&`n8mF1Q2mmfRm~TQ$}@0`%65w-oywi^pwo$TrZr zsiD3NcZo&be6OFf|B0Q!U#c1WWt!oq4u0H3E9&7QDk0&&9God0w$geVm9B6?o?wDi zfG5IZWicxd^WP|E^ESK=tkNM(O<7@08E(yg3pJEgRlW9stmRu!cS9!5ejtMHtqv^`?>T%KPd02uX znLtSkNkjZw_c-iRi!WaQ66#sgDJW(k-!y{#S|EpObqBcML3I2SMP;0vQV`Z5Fk$5>1Qm(>-iZAKTp*P*+jl+cUW)AOC2uPl-sjrQkGuE8Xq;1if+RDNABi* z<+u&QGjZdjIP6Sn#(7N&7xTpB&g5p<%+=FzypRN(n!3c#5FZ3C@9e0r$MpTH;u>e7 zqVOAQcZp-pq})F_;U$WAhz zl*;z>jbPk_%7b0Oz`kK{Ezq{WWF$?%=1HK0wtLuZK}+k;vyUwP%fT;%pbcG$egg>9vo#S zt1iT#5lWvmJTyAi+S}K|Rqa?FZ^%qK`>@K~9q8&9?GAMJ_@%7_bY@qQIwUzLA7vkO1S5SDmJ2GGcZ(0ixpN=%oQ6!-Mv{rj&6NsI zk&BP1l3dB+806j*a~g65)plfEWi`6?ijPC)UrtA+tkh{_Qf;~J7GHqO7h;pLsteKX zpCgZ`Mg)Z%S=De=3b~x$iA4ZsSY)9AQ(JeJI+jOeZ5~$f@mZVuRA_$I=57^AP}vUm zbz3%<iIB&6TU?Uysy)xo!2eX9h)+{_B9y7}M93Q{ zPb#PT-QpVL`B=QlQ>5uUDWvkGkjHszJQ}Sn&!{CjPl{K0Qb^@Vp-6d3-*W$5+=4v6 zFb~acJH5-O+*3BX3Ft(LU0D;Yc(GJ2krD368s24jF1KuY6}N*rPdp17wu~t=i5e2W zMJ7k)pN6B^8bxQ{jKUumFGBclPD?oTuBsZQ6^@a}NQ(B0*C71f1*f68t%*!8oVvW| z4~WYap#3GBj&K^jPNg}VsG__oeukoaC}XNOSv|@;HNg$B^*k^2D4nvC!9I6;#(H(X5pUp; z&2!mF^O6!}|AA13<KhPu7y_hDYAbRnO+qsQ}V=lHR6&) zckUILGi5qI_H;89Y1v8hqatJ~4L$Gc;%a32-6d)4{w+8sOqxuN-@2n$ual#vcZK!z zW`x`9##_uy1If-1gTbChfodsT4h8WhvBn}M;I0ZTZzRos(6KxP6*kWY<-aSHA3;P| zUpYTdd#c|bJFlh91%$xe#@XoRvzFIsS`_!-Lbxn*ftt(d-{aPw*6 zsmjn&U*Dz+0h#Oyk}B_8Qq){T)-Qc{W>vD3oiHL^gzRr-r)6!?VvMXUot9-BS?YNm z-rUr)O`VInGlB!w4vq3OLgtAAw@61ztc+05gf>~w?yj-$ektLH;@wH^+y^j2o{cib ztFpD4b0Bh)FlCfCu`&D~0BNKRYRAGLk~nbte8^{0|iR){6M7CRttRG>q`I6x_Gc?xJ$_ zL`@5E11*;%)?Vt?X{djy$&x=K zKDyYQ`_r7$$ZAHjMb3&Wmy#krgRJgZbvjwiWW9)4Ndu-F61O9(+j7HKe5BLq%2-$= zt44bqH$waJl3MY>Qip11))JFkVZtgu76&my2*@Uv@`AWE)17;84Vj?h*fmjQ%@s#-hlDAgjd^%Dz2w zQD}iEHCOx!Ioy*Uo(jkl9kJvlC27+o@DA%>8p#@awP`c zB4s7}$VJzS+q2xc-!GgoD>jdr6}JsDE5c{YitLr<7I!17JNz?erR-&8MFz8#O3p)6 zw;Zul(tv5h;$dVpStPTHygVPN%H#WXG+qhFWJmC%L)z#NA?_47EH*RzzQlY;_<|diboT$FoR|+5I;n=hs(S(WDEDQ zJxQ6ljObnyvPLi?80OU@Vox!3BeSGQ-6)i)JZY+KvJ20+LR_-UoqJ>X3?||ADs6w& z2&MfaR5o;*AEFzvCs?{6Ns7`9q10)0qY2dFZ1D}~_UVcUjtGYx3pNaP2PgDQ7&8Og zl*4XI*}Sle!iHdf$3e{wzd@r>q@>Ioa#6XOmMN!m)NzdtcZ`hM`dZmI7Jo-vvD}?| zSLNyI6tR9!t<$vH$lA+n5m!T-hu55@Hj!)epV5ZuEAwe_Gqic4>U6b<@Dwp?7WFl~ zZLns$WKeuzxx4CfYsDX&E4%vph6D2H=a8JaP}kwZ94GYszgO|T-OtzJ^OjJ46pfy5 zOyz$L{8z3M?{ckB^68}t$j5n)cmj$S`d$qc|0LM&TqoY^V)4vwiVx=}@h_|s*Sc2H z8y#}$1<*=%skf!X2^W*WV9hm|LO)?rlr`7H6L5FMz5T8HPP4&q*= zgSdAVIy^TA9lpC>eB8YfFIcr!}`A&=VGHnmp>A9akX-)$D}^U!OqO-+r}(|Cn6R_0XWkW<~-D1Nshmj*z34S}X? zG(-0#tz6lPF;AqSXSXs1&I6rD!>VpnOVuA5#rs#T)X8a%r3R0c1C(5jptj^Rc64-g z(V(oyONep*vg-CGahFYuImEBLU5cSW&@Se=a52x3nDf{EwMl&LZ7WC{d{{iPSKXh< zVl;Fp&1O5qdG?Rb%b@w~F`WNS&}@as<6t5s{`uv3goH==I!I@u?{SY`U=k(vJ#46Bek* zu+z}$MAGe>&EhpB8dLYZs`jbUP4k3m)y-P%0~Bfa=#}O<6zm!rrJ%9)JLiaFt7KuN zz*A`{1wvaAXuN6)G+t$a)9bEditQH1q7hmA>K5@kr36_#tYnlWN<}$F^n>Y2c4Mo! zGS{reu+ouG*k1~b8h@86VK<$1{?Zbiq&*;GgQ+JnN3s6mAB#T>K?pZy@P4so?XW1LC6{&mGN^bpK`C%p2w=QC6mic1;LtBBLRQWy`G2dNA)!jS9$MVmh{*1oE;@;VKfP7Tm7QlnI z;oLQe! z*wVVuq|(1-wtVS4@yXR8ZosxggMulC=48r(zs}W^c)jDv?4*L1)_yf09u3t?nRF(# zPG!*{SW*`1t+Z&>$=%{;sT>x z8TTvPd~vva!dg(wY(Hp6Z2floL^obPkP;7?p-v^L6O$wiJDnKD319%n#4<4{+LN7B zc&O@*PVrc&9B9JJWDPa`GBwepG8wOil!<1WdR0cwIx)aZSUvnfD@bD@Man6g9)$3g z01-zTcxj_c2h8y>wSCZhrFs{}#^_+x^IhV`vdAi%gOvaI=~bRGvxQcq+;d7fbD)yS zfoPS%R-EZo7Wam$d~ekaLGePFY>QK@tcSOv8>ZJ7BU;#$ej2T0Ii6JIFb6(ajwfd@ zvKR`}*t0bGc#l|Uel*&;t+uwVwH3#Um?V75wyg=@^8~O((bg8@kQLKdw`C*tVN&#q zExOtqy#eQ`wAF4hF0vx9n-6vbGA^_zt@tu?TVr*L@lK1@R)?=f>#G|Yu_Kmo0X{F0 z7kv|pp~1iklTnUuVx3v|bXCR}#+dxR26v}3fB!T00|RN&z#sOI9(;PB@kHo%J^$IK z^wPW{4qXM#9;S=RSt*tos~6xq=w(2hIC*hlLn^*j_8D<;XT~`_IHyLPL6hvZPN9hk zCE@Tai;xh7bF?hfFk&pE773FCam3n*M2OP_%@J=W7{)w}67zhG7{&q}v}7k(Bw|in zX;6uhTqv5;6BlO~$rPkON)Arb$wcHr8JLF?-Qy6Y&evHKXQ)6L(QqIR5*Qge-VaMI zRvZ+}Bsv9_#2Ey#=0S2pYDJ7;ELB0n@M>B~ykRWUNL<{!xOj-pULe(6UM_*p4M5gk zK>_S;Nx%VVZ<7HODClkmx2^HL(#C0UNUMpKN+fEFTG@_znWr7;uU|P zLMVk_)A2oevLOA6lMUiCj1mf+9D%+HWk`=MsB5q{93X7zY zdy#8pD3M5OEYikQB2-xfl@RyLp(MjtXAw5SR%cqMrRsW^?5xlTQkKZ;EwWOVh}9O+ zCM4D{YC_90uDw0MwkuaUE!9qx} zvu!A{*sM^TZ%P5DXKj25D(5WJSd&E{bjw1-lPhhd0M1WHl^&|9)G*FbC{=aKA}NXd zqLqRaXj3%9*tSS|)AlrY(~dOh>pOAiH+IS8fSu7bqSu7ZYfp5~-H z-=UGb1%w6|jUr^XLR3tLLWqvZk3T`>+9iX?sG98akF#0%% zROhRpVeHk>B)?xHD(3;sPjQ1JklN#r3_!-PE&&;PpF+-xUkhYJA(^S9*QiD?qLs=P zJYFR&x__OK289nKiWQz@w_!}I0lpx8M%kvN}xC020Dg^X^+&=g9DxTI1aJh zeH}o@hljD*%jmkw%3^<>{8Ls|f}I}nyN1WtVT<&!;6y%7?aR;a0p2>)Ge$@C<>zmJv9)7#4%)!T|e6K4K7j+6n3`L@NB(~Uqa6v3x<$*e@}2=s5`i> zXK17=7;7{PLX;P_8VC-KjjlnxbQYGBt4 zKHQBwy(Qip+DNh+r&i%J^|qm*{xx1?jH3*c`MP?f`3OhBgPr4h2u@=Fe_3Hso*zeA zfoB$0pj|}Qt(GP@Ff_8)3L!bFr@L=|Uw6<;wKvrcb1z+W=piHuHOtoJ%^#XuwR8uE zu@W$cIwgk-x0du0X&=)(-u$hw>(;TpfndZc@a8wDPr>;^Y!eULc;8O9v9{xw$@YNq zzNW%XaE0x~MLRpR!;jkK4j}Dtq5?lWVt;A-hTwj@Kquo6j~!atExBPrR9Z6{hgNLc z-XPCI?mg8EjV1Sc2iyLW;@+Hmr}}5No}W6qUjCv;3x!q z_8Oc+RdtQ@c$JY)cUG+Xv`|RXAoIeA8G_>z{16-;--qDnGUHB~sWFoPe!s?D#>tm} zf0J<+5<`C67i>7>>r12|9$mV5wF8efF`PsQ98)9nqIir2=CuJh#%A*(++H>>a16n5 z2Q&xkXUT9#{p>jOi$gMXA%Op}S7{s@6cBF8BjW)N=y>3m+{SLS;q!s7w&56?Vi(zP zj72e~J&`^U_%pWnB;e}ANDvW^>1E89bUc(neT3)-Jmy**4`C>OOqWV(xRPXfV+w6J z%Io=?$?q^Kfq&12V=(s|w&A$*_SD#L^!RvPg|9?>WQ;2Owhhk)e#nNe1YT#uvG;Ve zX@8{0{?t)Fu*K&BH|>vjNi{9P~F@G{`H*>F6TbnUa@ILF78Z^M_th5ls2R{;N-4F|9Dpbbw4zRrfP!Y$)V zHoO%0muH>cbLcg=&7hcg%dAd)SnnP z8^$JT=bvTx4TkqJd|g3-zJ&M$d`Lo+Rl-dSTNv(Uc)o%T94AA3jvj{4N8%SVguNwx zC&PysKF;v>4AG8=k8bBAOj6KwJ;P5hyp7>q3^^T{hSIrH7{Zq&Uc<1F;kgXE6^z=> zkjoV{$oK@q&oaE7;e8B$$ndue;pdcJ)Ef#$$1CUotqwmAe5-+AHg2u}sqbD&HTHef zH^Cn<{4x3@-~xRy(ZvF$H!-xO^Kd!|kuILo5l-nO9qA;jK=(@gYgrEP`Hai>LUeb8 zm!O*@xRY_zufz{Cei`G?LwejpSYsgmM{p!BK^tAB16{%sSe>AF^e+?U!v8BQ|1mEqSJqCRB$CmH^RA^cO)(bo`kqMjsV{haVmiK9=Ka6Ln`dx;}osy8R> zC*cQGJvh-mW&B4O|D3X`^Gl3>i{tNR{C=p{1%LDrzLas+D+={b?aM%WlI;|JvWRf>56cOne^^2gblLtd!EzJfu;Us# z{SGX05q>9@$_YNM>dp8chOiISBQ5ht2>B9jW(a#o9QKe9@+JH*!&@1mJ|z7F!(TCk zpA+4IzE(n%Pr^EeqYPnJNxzZdHyN_N4)#YU`=2vU#XHwC3^2Ta;Z+Q;WB7T7umk1e zyjMZfe#q}E(2Z~7aRNbY*RNvHkMOS>MunYz3GSl_hdrw7^ut&WBpm&7CDT{g<3EQr zNW#%BO9?*Bdc3Hh0EzSy2@KC>_z{LLDd^DlyMgiVD@fzEEFb(@!f}Q_VE9V~UCS62 zF+9ldN`}nuV*aR$6g}$K4F95F^jQp>8FKwae}VD;RglJC(#O-ru!rHr4DVuyb|d+o zQZOcop^xEOhFs4vM;U*Zp-%U*!ehC7v6~pbgyA&|*)L*WPS?~+S|E6F9#vO`J_#i`!s}g@k!Ne|x`xvraY1T`8NtZLcmLd9G zNoT#1n-re>4u)T0_<({bY=;y-;~3v4eaejtS-g)bap_^5)ZTu-UYpUUN0#P(YB zS;d#e{ae~$##ztwT7{>xf2V($@fQ@#Si+F~B?I$K(rmbKSj@1VA=|~*&3HdU_H!S% zXCK?g_eqZb0>iH{WPAD8PQGWE{wId)FDqgdzG4}}w=v}Quwp&qI~bnFFvxH}L$0?K z*D%g{tziFI!S%R;{b$8v%=a4wb6JmEZg;sKV*2+LJcH}^4EEnME@e8m_q-^D=VdWu z`{u1FEu3pKI%fGslaqd@EbGuv3c3yom z$A3{lyiFzjw(v}bXDjGWWSGH_`TT4@{|}h{jDkh%A4S}*imp|3b3O<^T?^aNeRc`K z$K?FJ0L$(L=1$$CMgg{f9qZ@>?A0MWFDsCbfda$hor4_%*p9EjqTyAefuNm0@50(~ zY^cA9W#Z$qw2!Jy6lPvv6YPrUMf-!GKS0 zq#l-5y&{7I2YO2>L8HH^x}_mdURYWl*cqO{WF8!$^PmFzhAZ2;hBgJyJy?nqblIfq z9d;qR;sC`33P<|3Z>;gx?cGuuQ0Gb6*sbk(kziM~Oi)aPs4)PzIBtM?Z-`C5I= zb-wB~jYUPioogEXeqSp>4Rv*OeqX~5ANIFz-CpLqxV3F_?dA;%EeE=((YKX0(XaE> z)l^sbTI$ZJ@HMy8wO07*a6sn%BBQad)8}i!=~ltfF`o}s?Co`}8T7^r7-+i;>_t>!|x&!)YEDX-2Fwwe!#nN9nND2AI8$(T)h z3X?(AZq?&#I-&>y!e1unB4uXN3$iTg%;)M5oOVv$Ak$i{m->Wn~b@& zM=8LnZ7RZSs@q|&twi!kwK+_m~GO(QBkMkI<9$0B^>l#Y$-v2^Qn8?{9Rg_YRkGecxKh!&5SG$YG} zU^*I}loFjJ*<>BZ!&_s zuyVwI7CcywGOuaMJMUt+1l6&=G+&tglJ5XRB>RQ&r9eM-zZM3_@*G%e)?tcGN4{b` zh4|8ZShKV9Wqb$E9dFc3wm7U|+WE4uwk~~Avub%mAlUpb3u{sG-NLniOYzhG*MTt7 zXgA9`0o;q9zF3~Y^=9(D2!>|O1ju|2@?BfLOVo5!IGrz-SIb)pS)NGs%XZd$ zZ+i|h+VInt){p84Va=C={G9QcNyQN+-oPK5erId~uJt3|o<_ejc0%^6h}W0SH%z|* zvI)u5m*xx8uK;CrKBAcbnNK{3uuZ?BZs1x!tXof~UlEpJ=v_DS()otzS41{GYI2$R z>i$LBuQ&%h_f6#!SmU(oSNwb6TE9Ysr?Fr0>xg?AKYdN3U&&Koc%Nnh)O=y~EA2(x z@u_@b4`?>~l~Fmges~@+oqlB%h&zIxzI47}_A5IMhFSPuc?$SGuZ01!Jh290n||fT zffMgq{QUS$W54pp@s8Qkh}YLN`qkVHhGxwKsQJR|SBre)NvoPw^Kt*8{b1v6h}fu^ zEO{aZVOu#ieHys7b3Ve;lw;F3@GhGd@%qyFhS_=R6JWSmGXZM8uyQm{;G41y5%{oH zZ`beAyMSx`@(`Xzze^uMTs(gI()otzcPZ(Iyv(R}3y+w&a*PUR!HvG`5LcbSbZZU(+<5U2Hv zxABFS<37Zt;Yaz-n}P2snD-&(n{VR_v)}cfKpfeFu*P#whQKrro6CnTyHN&#teKYhsZ%Z>6bM<-;JcVwu^2bRIadmZ_Kput(-v~`IVNJ zI|E;%jZe=HDBm#q-PjG9wzD3mBk2eKi#ZNnDz6@oBJkashj=gZQ61=dOGlX66<@bP zKgVMl1JrGs`eqy7XJFfS@)Lb&J~14^_chA5Q!@cdK3b-bCn;bHi-MumUVlkNX=RBY zU!r-v_>W8d#UrV*vNEr?q_nWKNYZ!59;$1s7Y?1Bl$fLCs(e14=cWMF2);iyT8yoC zuHQI(=kblhUwh@tm()k~9zJT+$6xPSCXN*M{x$kN^$D+>Jo(1;t|P_ut5o<%Vf`}W za9Zu8>&Qs2d-saox}}SEFIlpz(391&baAe6BD-l%{i2%BK5=ob@r%p~&(fGBi=%&X zBC7ZD-A%psFI`;dSrW5*Nx}su=J#G+zjSxgS%-V?-}8??_wM)i)m3>46a1dtOR`!X zeesy9*L$Ss9a+U_kGV+q`fTW)aLl0aGUFqz+VAyxDSW@E7ri$hDKGITti)3< zvhF^ybW?fFyPw#(+W1ArTF=t_=vSfn&5CDtZ@pNOpK$2JyxyCoWU;%q&s!obwENSg zl>X48FMY&yq@*|JY2)d)_3l%Wv%2$)6H6MF)x7VC(mdlAX^{H#33u8|-3yuB zkZIxweOktRI;*?XlV?2o(wE)ee(~v;UUyc@J>K5B-Af8RWa&r$_H6${DD6F-NB{op z6}nWi9ETo#<=H!XbL<*C`U*)gj6)|+o`kEpl*hWnY!@R;pX_?mKEr%74nd{1YT(p# zwPxopk;{BqSFG<91$#P+D~pPGeUG*rRhLXieHyjg^+HVDlR~c1ka@7G5^UF>0JgUq zM#y@)YPN1UfIE*nMTP?l43PK#TN`5y^)0pWk8CzJ3gONto#-^Xy3R1fh4Yi<8PP_x zh;~FfJuZ*i6Xl8acswzlSWjGZyhruQ@mfDXa)UQRMvh$%M?^i${0pu8#c!*VCoXee z?z+PHZpQ~ib@G144`P$wS)FX$cmD$qR>yTDzf&~ERswj>Nxh!rpF8u$GEQ|Op6~^U?9v`Hwt?`jP-WCC_Ph@tv3CA`qzc}l4m$)d( zKCJ7BgObtLDkph=L5K0jKHi-kvp&c9Al%tE+%QOM`MhzRrXSFo&YgQ8*te%wZL2L) zY~F=!B$R; z5P>@)f})@VxJF%B6nUyV8mhHJzzjn)(|99q@ zXSr7}^w;}--v2E;&za@SnKNf*&YXFk84IVw&!hw$%W0X7)8)wyX>_r1poZ+?89Ab6 zjF1_($&8#3&$wRCh!f;R$O@j3BWlKRGGnQpkdxwBGkHQB^^SzvFIDJY0)}YUd&paL z@Q|r*aeCfztUs;N#4PaN)3m6QiI?KBT=7=CyLol;?$;eyJsv$g`gim0~Bh1TVr{X;TQA_!=H)47quEBeNcMl#2*v)%5(kULFTV#e!jo#gmNJR4}FYjJF zlgI|@f`G4gq)1UG;(PO0q_5X#y^fD#c#OxBjUrs7?A=qOYR~fq3xb`&BK{i+hIr~u zYM~mZHWb;|tvd+UbrTd6k3o`dR<|KqlqlP)7f*n&KHWWfc=th;8cwCHC~%o~ED~{P zD3A)OfEYx3cr5b{%Ga8$mJcMp#SQBCgvaL}3O@b<$~a5rzsk`QD!k1o7y z?@^qvH)H_on$PXxXSG=C`2(N&J@IT4(4yRfXV~3<7G)Ejy9;Phwy5a=`FFEwn$Pk4 zrJ4r0#ZPHK*m8?9Qwso^jlX3UCBqbiRfaOcHC2EbWKMqP{89UD!o%|xB~8NtOYm22QPR&1GLx05%(SqEf)Cw=)>J{ux|T05Au{kL zo)v5dD7)2Xgc?6jH9McV%Mra0P|JpA{-q@3BEkiUH)R@w0QZ83>T_oZYQg2DQs9rW zT(hi2)^@6VRBn}7MjkxMLV2h%AAid&;*r z41VOyKSa2lzhT4q8z_VqE{XCt3~<`U6vsIME@yD?V)Uf?DI6}L=Ts5(Ll(&)rhMZ` zZyZ^nxU~2wj)-)Jme?H3NradMBNAs!nVB-tHs+l0xQMaMq>kfx#)P>FD>ZFKVp4K~ zd!dO5aTz$o&oLz~IdS%kv`Ma+v{vF*FT}(DL0{s~e-LSLn;WOCB zI8Dzw3SZ`{XN1XwJY5g`^~7H zHKnoD4uhqq6AP*thB6Y;Ak8>OO44-ONWA84 zQ7VDs#b^;QCM**BN=g-ipd~ygs3D{#GGG0H`D(=AT0$P9*Up?orp!muTD6?GIkwO+ zjGaqmF~E5#2&t2$AS5hwY~~7i42Jf4-bt94M$#I^7% zMYvIfu9m!vl~xqN8&;ODtB#oDMN3{I^0$~qG`DppeB+`b7V8su)aGB|_vEIE>I<24 zjxWURm^+xH@$s1x3re`duAn5Rs46!Pj&SYecwrWKOJ4}iIuN^Io?Ti)L?;n{k%v2; z0doQ-2p2#(&NLUx#YEy_$INRr&5%re4sHfI}QI+t@~AqKsp%B7|-Nf0Ntn*wzfFEa(| z99}Mp!Ae%PRGykh3plFeiv+lQQnuZqfuilSfD=mLKvf0R^#b2V=KJ#f_&T634BC|R zq;$Se#By;8>{|KOySgMyQI|O3SRkaQU=F~>796s?6DKE4Pe4F{a0pwJXl^#gWnfH} zQT(>kf*ex{yTdVk2HtAN;*J}=xE;QzqAV{b2)EDXRaTXkV3>)6NuQoDiI<~&Q;3y7 zP*p`5rl^&chS{SOIHZwj06l78OvIqB3 zS(KkJ&`qC_iincZGK+E+=m<6;VuiB!l1DcdR zF=&`Ax71e0Lvt49`=5p~b zh%YUvEH9Ops=_xL^NdwliX}g8Dl+nmJASa|qb6-WWAqPJWhEbYc*#kr>2Tzpr&y6d zQ_D+paBMZM zb@`9$zk4cAb2kZ>nINRftFp9gMn2Cda#>WdosUrTZZBo8#!<>YaFmi& zP|`d*E4`IN8aslDi5)$cWJkx{D;2%pTX|pOB{eN6B`zJOQiv)yuSluo1u0n-g@#nF zXrp|ov7r-CSt*lgHIcaHjNacy`N<;+gTlllxXMMDYCbU{m@d~*TObn$isM>hHDRWD z`LCZgH43A#KQQcMSO&Pvjqx*5QsJmfSfvF)es`&o9kW;`-c{=YROsZGHvG!TE-KC%qr?SQcxe)t6LAa_i0 zOiq}dkd_pWmI$zVDigT<5+ZFFZI>Y>jyv3J;e4`#NpWrh+}?_KF&R#5Cf>#khI4ZX zvN18X(1@ACY|A)T=akF|qfq!SwVeYw=fcY1n+C$V37Ki}SgdIffA^fvA@!)X>t1aO zb5SdG2u777r#NKP!sfNdqyt>un*KEXgZ>y)|1WBeYTph#lHQ-_VZX4@5^E=vtq z@3^kQ5fqTcZwCkvD+DZlro_!k5KK&(F>_+F*x`xP$fshns&&L+7gbd9HAl3TH!(F~ zPJBWtRt>uHxv-<>n4;x4XW^CP8UyW21UK5UY=%*L7sAceb0Nm4; zRh*ZQHUrZT&^I}XIcoY040VvuScJXB!?XatKXZf!Na-Zlg2o`|ZIOnHgYOpoBoZXg zm^?AW7BtdjTkB^%N(j#uQZr7-D}(E2mcyl%TA*6Tzd?2Z7Jjg_ z)h))Lp!14w$Pk+rk6p@hM9gK(=YJvPoZ_;vK`3T~EvRhYZw5Xm9+}|&`|6gm)99;_sLMi!pa6Zo6QiI{gB*Xu5KT>;< z+LDrVzNtHDqn1koBOZJ`2fj+O!~}5uPOXiLBDtGVsRTf652uEM4R{xWUr-wb&O6X* zIoxS#WI*;6kgWn;9H^I<`@f;E{QNimlbzQ<&)@7uIx%wTD5`M37vGz}32LnujLhI7 z7lR0BzUsxtP?#ghlR|^?;hvKwj%il5<@4RABJ)Jemrt*ma;665kH~0s<`K3GPT;UX zAnXE)9-*3->O2iP*3;fb6)e_oOjxSL`mKS6S*%;z8CI%l^Ct`YeBwFly4Ee=)boFY z;jFIhJ=JeREUnwelG*?V7447XfRrk?M;Z zpEoQP3xK@x@`YI?xp=dD0XCoBQk3XTR^=vTs5X44Mnk?uK@MCoyvpIIG5K~7s92)k zuqx}^b7&dXHkVEus| z*WNW0Cj-2DPOn6|Z{2$%R`qh#q1od|rCg#V6Fmw6%S{11!J`^(Qs;ag@pCf~2)ANq zk=x?x%+3R_5Y+=XzFEh`q|Av~KXeU4kcaC0!OO#9qT{JNCabAr5D!_RHZ`6$%ErXw z%bM(YinAKRDR_=nMT|%B;}RW(KmHwX2={TUw+ddxN|A4_Zp7}Ny5Va0F(0(Tk@=97 z*GZ(~ZpFm7l%(XjHj8zadj^X~lhwo1!-Qy!f}x2|~lQ1fdaHf_JQPyNP?$ z-AP1&!n;;kC^lQUzm3-}q(+X|wdFWsv7kY{2<$ixUN&A+gU zE#9%b0kCP9o|G~Po51|7a{ir^*bmmWZ7s?s54C}2PH%QExza4~AR*q3%?B{-O`Fx6OO*r#XU`)lbLTDBm!T*LGn`#rR(%}7j4 zPtbD&pOeKX9)|z@XL~2X=dN z9PrY4zG2+5{FHNmcK{Yg233cQs16-b9X6u+90~A{7V6Jwx!1p1t^K%W#l_8hS7xh2 z1@+K~bJA;~a!U^i;3jOWTY5D$r;m#5jKopTm2o*ajxk|1Xvf05yfT2apsW$%ZSE{v ztSx9UI(#KxIpMcBVhn%I612yl2Ji@Kfi<>Zyxfft!~X+c_%Is;jFkAMMHH4^g_El< zvape@FYI|ySnEoXl@k27%sy>aR)(a8yNJq6(-6VlW<_Ao7}*LM`_8SIL7>I_rgnHE zGI_>qhx+ltJiNR!W4a@OfB%4S@@O+rbCNO;b1X6muS(9Co;(-+;1+TpKVKR_M*YU& zF0n>hbIuw`-TTttzxc1V!uW?1#%jtq9hI9r+UdKT4Vi{-#%cShVz?Bf9>0AWbOzr*4N-HYU7Z&8p zrnV01U=f967r@J$>&VHf$aUoAhYDFcpaUrEI_3AaUctM)-3n9YnhR@AEUtwqd(g|pE$?7)#j9PBWS5wb8AE zq{>g=z#FstEjX0k$r2!*#GquHksoF#jOcwnla;r@{q5cUuW|3j_gFW++j=Sg0pEwa z|2urk+3sJEx*OkSd2=;y>r_^EK?m*mf1Gc#ygA?Ps+9Y{_glTX|0`N9#+-jc%l%7B z^0I4X#}i|yoM@U=c`-(|AE_`@<(@wO|5e4*Dr!~EDDR^xH}^ePn~V{qqiW!~=ypdN zA5qlN2t(F_%7xmv(ZPZ(o38_WJNkAN;|HGl8ai!Q?0i`5@PhI^ieKCByv48Q^P1~` z_7BCML7{7#E0k+u$BD{{u3o__{mxftr*;=wsM0&Yx081>g$hA;d`4M^LSN|LTdIE= zj>H!t6Z5w=(5tVLW2EyvCF%@*s11B1RU9hTx%3FLp z?Y9odbe(N-}>(fN$sJ%`wlL zyVD6}H<&+cYo2+v=TEE+)AZNV|D49~ZmBWaTtH*+5$oLgAW*MQmsDP#0N)PxG*cI$ zMV+@Q@1rgc4eafo4)YC_>%v=?y4;!+LwQLW;C*(-KAXl z4`@FZ(A$5yM#kblJ=>6s)nDDO!<(C$wW*b&u8g37@#;ZdFe5~nsBoH4w60OjRJ2Qm zsHixdN*@?hW)3OW_<9BJgN580W-Mn!Z`Exet|o5GsM;i%*=J&=>#M5NJFg1xZST_z zL&Cc3da3dh7gP^SX{zHM)Bjv+pDc0H|p z28MPG?%Jb*t_@QP=)hK=b7mFWpDg2ku9~tIP#hcjg%?A#6L}dgW{% zSiM79S%x%%WEr9n&RYiWp1z+bEBkr{Upch3WuV7EvRWCy&RY+mP2CcdwJ75h%1Ab3 zRfcy*^IYey*2+s=I+YfkE3$6em3#Vm1-}z?0Y#lxY|R(NCD*;XvK>Y38FnE>olknr z79|AOy-|4*MePiB_xK2<(;A~km}nYJ<76i^yO>4_qB;KQmlR!ovhFKb(UY2*e$W zzTHnMTm8I(ZyE0H`Ee;!8iIPEhC&$Bb8w3(N(jp^^jlP`heLS{CH(R)l~958bY5w* z1?^GZML{2rIB!*iBgp8n9F@9#{;F^XQO{uI6O^!Lq(Cw$}vZ z2q+&P?XIuQNuy9BEyUqpR&BrUlKf3M&JA?GbhibpR>_6@x#j-R(E zF0bBR3PVv(hn~MERbEC>TwtbJ2|Gj`mYc1W5Mb{zjJLy%*A1F@`@Cv?qOn3Lm%H;T0=PGkM_z23}cZf;TWk`YHD_3kq=E6kd z^a)qKLSa9guQ1s(T48F-@M>_QqP2zb=IOIVxzpwq{Q214E!XV)GV{+X$tzz_t4gqo ze+@jS+=(X*H(ot%fVl~@Z)fEYid`OIJ5RAtFVjxS`Rj<`wTpi_EP^uWJ>to`>%4KX z^cKAFCqGq_&gD&5O?_7?D+YQ6-xYZtku*0Zwb_u^ zK=lhyo&|5)#x|jc8qE@hWneNn%(4{S3#TYd$}7sM)sjPR&}q~lU%w!( zqQaZzC(JoMa8;CL@!N!5J4ZjNtQ_PO+!S@8JT=?C|IAa1+=$lmOH&$|i90Ui5`>)66cSe=FLnW!b=I+rLD4WRO?%Lov!X9z$}93d$T}_p?-3 zE_~<+gpK3+{@)qAZ}&kAK5ubNkE-$gjdRm~jr6Nyl`A|4tMvIx6`+s19oo)~Sf$6| zgL2eEZ4ULLau=~-zbO;bRZ5mRkoaYm!v7MR0fmdWKna~{%7<< z6|bl&HoYY+^Z0fkR2kL5+iCS%rdTtAMYO+^bN4 zDy*5Rd|(ieb+{l3`=%-vKIcOsD&`JF2qu2fr-l~aR*`2@&cL*VNfZlMSI4jGb;IZx@0k=-a1 zxSZ&45o>_2cUtr}$;u5whG^NjjipW=LyCEJF@u`2^SL7{Cx=hU+I$HzULQq2nW8kA z$mmo2kS7HhJ_(x1eCqN{Gw=B6CkuW;~0`nPugrxj6F*OD4=*65%g~oUz2* zFhjXMNbpopQr!$+k`c}u=R>lmu?D`ro}oN&4gnKyk^tvV65uRy0-QbEJkc_5&!sBA ztE6GN7pko<#H5MGm8)FI)nY)UH$Hmhb`F2UT^Ib(5<@Rh?ieO2D+vA*mx3U;fcYcc%J3SHuG8gYrQOH)p%OmK<2)r=R3TJaK_)q|F5c2~NxI#_Q;x7u-{ zkiQ_xg|8_WZveGT{jw8#yRM5h&3mp`hG(j4@J#jnn#@|U zBG0Ua>MFf6&9B->Th1@jc;ANi`A4E}o2hIWF8aJH2S)FQ=Be-KaIt9fjP{0)xg%pd z08?l|&ISi+55l$PI6#gE81}Ot2J%_Ths_qOj~B3yTURhf5H1ZLwcxMSg1^peq2N`s zmGvV;Kvtt=PkADSwBR4w;tv*pgUM6=n-=8?nsc*eiOlB2U_AJ~=I|Wl*hs-{PC)(DsJXl_3qs|Swl2dv1GTp}2!W{RDBm2Cu^m+f*h z+nGFjUP-R7NBt}@TQ61ixU#NFmAmC29%XN{y#JF_JNCR-sm6SgseI$gkdWp1`S}M~ z8VgNc`~NXnet(&A|7aIAkg`OFf+$NbN|d91zF1M>^^T(fzN5a6dBUN*;mVgP((|$P zPZBMKBt@nECnXyF_k3kdxR@5)U;8sAhL9`OiD3?Br}td*xM4EvGI1<~m<;km)JY+q z-#3NHA)ntf1*pF`oLOTy6#X)5&4_8-&aA<^dH7ZqIcxQ&Y?V|tj3k6-V;biG6F3aZ zuD)%20(?Unqo2-J-V7HLjeDJpsU|c+H8gphEN5Km#H~%uDyuRIiI!PD$Fc=i zoVl-6=Jbh5Fo!^+4yNj~%(AlAo#nmJ8}gKs5uz`iBV}!R3)|2#$C%OFO!^kM67@K$ z)IpEy;+VVyQPGaGDQJ1hOnMLelYN=FH@{G)tWkmXUz3Mib+b zl5rxIWhp){5kLM-ES6K2G58ycZ(=?A=g!h=+pn z@se;QjAx*weS3R*58PGdrQRje&C9q=#@jUrx40VtUA%Gkv4P@-V*`mtMqh=eXlD-O z0qwN_Eky@&0It8*P@cGxhFC0}wMTSD@`vGS7|zt|h87;#4XofB^lo5(G>;kEK}{c`B0NW^7LI<|P2v2F z>1N^S&_DTu#S%UWImdU7?i|(G!-sT8>Z!^m!Zlb8j5Go#%XH(6AT_%UrAE01@}TiX z(Bz&xAle8}Gh!|68f3A=8Ud3bE4zUjtWJQ)h-(CAmIqHTf>m~TV4M+XB7)26Cb~ul zA_$H*f+Z0IPU;V#g+d>F(GCeJVzDF|p>sOV?K~T`oU8_E=oC&&%a>#zoUy4U6h%x^ zQHv#+KX~}WbQp`qA!xA_BY>mRdmx^x(hUB9dlh;L4ON@eV!1>`c~htL5|p@Jr1MAq zkfDZIEHirvZJN~^+BCbj(DgZE1tn|S5lA>!LoAkg@)1m5sy^}rnd+m(a+#KrmwCB{ zjOff!T+qq8kJXza^HoHR$x;y>4x=cvi&|=qctk*On7eC zWfm=9Xpi|jV!&umdMR3gE!zp+K+3MyI_PW2vO*gu#KDn5zeSAD9&qE+P0BNE}w<# zI6}?G^_#=x2irU-6E`_#I#d-)3CTu~+d*9XScgp5)0yJ0=2@wvSV z4$Hs&7VPPLDf4jrR#Segy4vSxxTods?}5*jxF-^G`qNA}=xaa42l3h(g9l~;$1tn? zL_CIZ{m0|m=osd5;25U$AICBN>pvTCm{{%g)8keC+C8eLuyX!faPZe|n--7!_`h9* zhT|{-j_dSzX8f<$fmaqRoYv9<$7Iv?hzW;5+qTJscLIK&3CDcY_F5B;`KN7>3GWI# zUBiK(er<;WM^P3}Ur`^QvnCw%@!6xNw^~papGFft7I>Tq4>60htJTsEBG>r^J^*-w zDg7YelT7$<;Ch=NeJ`x)4w~Y@tM_dt9OZlGn{brx&DWvgr!aZ)-|JNqj`F?k zHsL7Wi(eruerow%#Dt@K&p%B#<|0pK!bbx)*AHi7dt&BNf1rnZ2R!~T;Q_$+n($!Y zD@`~I9FM6cdd_`9bh1=at_g-rf_&1hC7F+G4XQvJ1lxY1#KiCWGNupPrwWe89W~4 z33!!+H%f?h6zSekaf>(Bj+~P1M0|>brhGm!pMc2MLFVH) z&nLo>Prz|lQ}g&3Ne6f*iHmsjjUF5yi*C;$%CT{{2kTxAUxKLI!bLiS3-}6F%!pT@ ze;ilZN{BJ3FUO%P1384w3492az#I>jxLx8CB|a5vUmib4hG)v~MG~))uu;P6B)mn! z%`*K?3HM6)ri3RX{7r>cjIEq6Yk-94I|831;iVE5tI(2W$f+0d>GE2EbtlJHS}c*~ z@Tal1<@obhYjb!+t)JyH34fLKg`7ma(H;U$lW?Adg%X0kh+i+^RteEwBK)v~pGb&t zj)z;JqXI(i0wzdUA>j=Y-X-C45=wrp=-)h_2gV8k(Z>axAfZFTr4p`{5dBo7dssrq zLEw8;sLK!K#c=sJp^6-OOFeu7>wbd<7Qt9EUu{nZuXEF~D*3!w4BZ#2o(+ zoDUp-3@#83k4rxOqe2BioIjPg$>CQeM3tRMYjA<6H0L5|@1TiC6JHQosA`koZXz_U$jB)R(@8 zRJ>n^go`9RD531new|g^Px9?IU*eS#-Yem^D&%uAms@`+hyKeXzD7c(!T}f{c)9_j zB}|ksO~QE+N@1OgqlB{D0N7O`{IG5?(6dVhNW>*eIdYlR;Z0F2}V&PfGkH2|twZQwdK>_=5_u zAt3k;lzJaHNaDjK93x?(gid)XeWx6j^ z7%ce+mi;dHW*L4!g~Mh04ww2n{7M-v`}+uQ6(8X*p_K24Scy-QP|_c)Sw$I2bB)(3<%@Q7w@RSNiNjjsX+((U);ZokCrb}GX zA9a(&ACQnqD96cBA4&YQ3P%r-P}YBRw#4PQGFtY#(NfN%H_7-%Rfsnwgx-eOC7i0l z(5@2pl~AS&mGTRHO@@E2!Z4{HVX|L^-KvJ`_TV1uCqcG+T@uP6^b_leQShpb(of;7 zu#Cd-j+I&2fD5%J_`F96hpwZnD!U}B7)Nc5GQ#j0L2;frfWPNv#&M{1sfxo5)e~(Q#oe~>RXY~qO)Z?mq@FLmpuB99EHx_|ca&C-T2NkERW>Tj5m(Glmvt0n zmo1!@R9To880O#sAt9!mE}q~VWGbA^&q8*L3$Lx2x->LAHEf(CP@InJmPy_IMusH| z!+D0}(3H5eBu8XOc%);Fdj>smNjbmd#j&_7DkGvcv>~NOXJCkVROJGcvPrG;>G-!Hm)bCqG6MTt4wvp zLWim}c;?qYa|N!m_mQkkep>@hYRUHG-@U78DSHTBr z>dCXWMnBKVuBwE{-l9&N)3s%@|97k#U4@t4n!e)3ym~pP(RDbP*7Tib$;ht6X|$#< zxzXTFZM0)+2BBsM=(~V9oQu{BeUb>s{Zg)NRg*Up^<)I_3>G9fix;%L+diVuRjz$ZDdTV;HdzVGF*7R7HYk-lb zH9gd58f0iqkK`GQ)ng*03j+*wzX3 z7uN#?0i&6D6ckdAS+uOrNkFva-6dffu{aiPUEEvFAp?pbNxRDCcAm!`HYL!b8su7flt_ zLU=Ru#p)z5bj<&d(U_5x(xS~cN?5D^lkYWTW|U`@RNytD z;>4u7Nytw>YlMX&l%Y6K4 zzZUA@^&S!&)Di)>n*}CY_u7+6E#`Mk~^RKZVy>`^j>xYY?FEfXDU=Q7+d7 z?Wd)?0s*FU9XDa0?=CHoDGt6qbGoiEz~P_Ne;PfMV}ajC`*od}IJ^1Ea=&b_Y1%I3#{Ej-kEAVWlcRPy3pZ=5dEK<%|xqU;B zqB%KBJ=N1)1-W$4sp+y%;2Smb*PqK>y7E7(8-M*bA?ys|v|kJS*?1kMXo&!| zbZ-3Fj)T8u^iSE1Jf`*td>FXK-v~Unz+Ye!;sWuf{j_qE5rAh+E`i5^^EzukEu9;G zgUgWMMJ*AaOsBwCY36ST@0S{XBk|kenGq*8h;^pZh^m`<%r|Ds{OQb-S`{kg9NS6zhRu;hc#k=n*6XQVCFBF z)9a2u-ap_cZi&BOKfH5t9P!$(1^&kVfdr{qB0w#joBYC2FL8^YmQ+h8#|=$iqPBs= zWG#_FPfUs?IgkGj;xsu24gY9Atz0)bPqZPyCM^-5md>pn6L;fXjY-X< zgRj~w=W5Q6#vk_UTH>#ow?zm1X+N!8H~y+^NKmFF0@TvE@mIYDalB2mpOy}L2xk74 zTo0V<0@ni@{xtcyjk`;3!TW9ZAzu4w^sYpJ_Ke5+arlSR(0w^&W67T_;nzL2l`e zo6_-qt67MQ#x(l=W=qB%j#7KBkn zXMIA$0JT2L+s2gcHt^eiTQlht5HO|NasX+v+|!L76A>O|Gk&3C$Aw3Y4aK(-HXHuO zPyH7=E)fwCHd|<9L}*kP51-$zF(Elov1)9AvSJAm|7wL;H?QFxmcOltUy$W;%cajx zm|XV!?#X3O{XKoaj;jxCO}sww*4vczmP7f=J=S?_?6iFH#?JF6Z}iS;bDK5LvawCp zfB*egqHRZ8=YQ_7%ztVA6<_@)aq;}UfTt6)=dYN*=c}(dLu5Js7qIbc*QTUS zYe?hi_@-Cd?I4YB-RA81!U)p%cxUI7vmvDMs)w9)!z)SS^kV0&+r3C*r#a5Yo?cEG zUMzOL?2I4{WjmaoG>sw+-2$Dz@2nv84;`d!UtdY;$3IMaPPmdRW3SMFhn^`fklGjOHcSc<~?l%nKLDw`TV?r%v%2i zYky}U$@n0Yb&7hQr1wr@UEX?)T#^#Yx-ASQGnNiuJ$^Y#QZ`yy@5bF^+O9LKpLHKe zdc&9XZ+wGH{wR+P_~ige_}qg9EVzTje`;ZYZw@AL@0GEk5wi%{zkm(9r3Z<9^fxyA z)Kn6EQ#2bD{Sk>;IFW^1y^BPSAH>35euad4{>bo0@XQcK5XX>)AT2{4g1ihg2xu|T zB%sYu20>X2WfGLlzykp<3_KC=#=s*1uM9jB@Xk;Ng1Ru&iJ)!_btI@OL!Alg&L9H< zSun_iKsF3AB9Ik>%m`%1AVUIKGRV{p*)qu34p}qE+z#0@w1FLM!O$jlv<*WW+0j-E zZDvQ?F|?r_ZOPE4cC;-+8{5&=3~g>l+cW5Z9lF4v6L#nZgO1ptD-1eghwd=wkR7_j zpi_3}7K4u2p=%5}XNT@F=%5|C$e@#U=q7`X+M%lqI%|jSGU%`!y3C-{cIY;Pj@zN@ z3_5Rz?lbfOJNg1cpRl8EF!T{S`U*pzv7_%W^dUR?5<{PgMc-oRW3lLK41F#ZeUG6J z#-cAW^vPKCO@=-ii@wUxXJgTK8TxQ6`Z7bGjzQmM=;JZy>kNI~=>LB|zALHoKGOKt zi@RRwyoxmb8P(MDz#L;-I5V}W?viPw@ux4FZhhrx()gdxnjSk@V2l@Ec{P0+yp%M4 zGOX!r((|P8{l}c`#*Q||kprJP2VHW2G`?_?bM)~xr1ANCoH5038{^B?&zv(?bs~*- z^>$`=2i-M~J4-f=Gsc}7ALo@Hv?Gm+_B&VG05eZG*W^BFj7KEHdDrRRNaN_co%e=Z zPZ|d#Ik#7U4{er>Bzo%1YYB=NVEz`y<*d@Kt?$toJ)c`&@dQEc>g1`c;2KmVI1A z2du3##?6hZ>EM^HC(9ak(4de0Aj>WrPluoJ)W_3hy_eFkpd+O2=TI6x;dWB@MhYD_ z`?N96UbBgh0Y#&6Itqi6`dD#8>#*Aa(daczQ%aHA)e+GT}f(7rqldo`J{HjZd!2N^Ts&- z**mm!+fGvRWF0Mk`Vvxe)k<3R!aRL^uL*dA)_rgvS@L}s+VJHkWC?wSEp+4NT1o22rp0D9ZzUZir$GE9nfBZn39(YWj=ZY6>rtIcYQta2C z?rGysiVnA-d+TQE^IuU!Ablx2lN5eEhwgiO7%9BtEPZ+MGGksmdp$i6{3u!UP#rzE z;X1Nt-cfp}{YibkEO_Q~diYc@Dacz(-<;Q$6!<<$-+Fn0K94RejH2({dk0zAa~plH zOCedX=Nfu+*>n2*x}e7$^uzQ$B%dCn$7n6dU$B^d9JF1Zck`a5y7MxU^HT*qVR?q+-2N~36@L)#vZ5{MGaaXFSRB{(=59pbeS7^>zC5@^F1#cYJ<=o|*76aa=i+{%*G_WT%_+<>-dnc=GWWm1l=T%PGiyJyPJEnP zdUh1%RHxCOXj_p$~=F%ip;xo6Z6_MLbn^{u6l%d|FV+I^psv zp4iNMrroUD6SF^TWNkN2C$r0juy#`(A+tTEuy)@+quUv?hW^DmOnimRd~O}%Jq3%=m5_>yiG9ZpX~ZiBtKfq`s}rkN z!~8xOpxZ-9GY2w%{{S-Oy(gG|lP{Ta>8otO+>N@OGW7Ef=pVn- z?YVKs@>poE05UGECkx%ypG5AP$->4xsM~oFk2JC|bC!|_TM--cRTBxn`71WI`X=4} z!!tt|K^#LGg0u{Ibh{9=7-$mEW+;Q8EQT_5dl9@a@I=5H1CIo}GVrY1k*Etpoe1j2 zP)CBgGSpeOFChyCnGnc^K}H0!Vvw0`cS4p7G9{2LgNzAe%^-8#9z|O)v%QgN_pDDud4Ib})3AL8l3Hn?c73be%!xb^927fuTHyhCWHqHyQdUL0@I)v$~y)zRb|43HmleA1CPR z41Hd=zcCgtj0pr|1H%|WFjg>(8M!c^ZpYZpFvi<4)-#Ox`uYKL z0mGbN$K1d$N7yk}Fw7bHx&m_v!<=Hr+`=%&*fG~I%sKjc19K6>oMgw`#4tzMF;_9n zS^7Eza~Z>&X2;ydFvr<3*D=g_`uYTOA;X+#$K1#;N7^x0GR&F!x&?D7!<=fz+{!S= z+A-HM%(?n{26HjPoNUM3%rHmWF;}xiXRp`SIhe~C=5#yec7{3Lj=7#;&ezvJumu=w z0y}I21{=W+TY#SUAA!Di9d zQLtqgY#KXk8wMN44qJ!8=F!(zu!R_GB0Fp&1{=u^TZt`xW23(Af-S{hQ`uo#G1ypk z*jlXo$SHk223w55CbPpfW3bWeu+><_p`-db4YnMEO=pK~$6({xVe7F>YjG2wR%LrnbYjX0WmC zu(et3hIoBF30s`OCbz>jXRy)ju+{u(Y`ZXomy4Q}i6vLXz zj$7K^nR!x}9XYcl(cYxv_8eO-;UB*U6A7Hdm}HD)Z-Jczr5V=LF<4tOtg&OT)@F@gdFktUti>7DE~bRjCJ|nM|Sl*@ByIo3;cccuDbN? zz^CuJ^}rs$PP-oaW}D$J_^WK!r=jzKciVL~Jp}%Phnm`ruQU7zf6%5unF#+Qs%i8$ zR`?YjY>KHrX!sX?FKL>&F_|>}wx=n3^xuH(n@V;+NKgmW@9^vLrYryR18Mx_;ilD5 z@C*EWsA0?blD`yOU$H#X#EiXSu8b7i)Jx;G7jUQ$@+jPk`{2=e0adw>j3u$~e z(%Gf%SM0zdX9mne1Od8XxZHoDl~(Y_E5w<$g+_qpDx#KH{A7P$+5Kyw-W? zA+*yy?>jI5-eLG_?nrUwMJ^(Zx7Iip&O^P|-Qg^(zr^t4+(4a+U+6&^SMPOJesO{{ zUbD+tdQhuAAUokwgjlkm~oT-0!@)D2+5Ou5+&Z6YWwm z#JTFmHw}N#0*CXu$74ui&S~cj6T!#)Qs<3tp`MzbXzpC++Mf@T#+l5yZsk{`F|D6- zeXrjP|IyT^owtu~M;a4%ht>bE+R;(X>>2Wj|mzw^01$4J9>kTLoiE+Bk2Jh8)46}7 z)$o6@I_Ik?*`(q5M(2TJD@nsswa(Xy?TUeDAVrNyBv~oJYUOHT-B-400api1O+lcYbsi=v0S0kB_J~ z{A+~+ou5s6hcx7^a(?~+{A-RcoL?4pAQ;0{zgxx%=ZVz=NW=6!&QpEhhnw=N^Yr$P zhCePg(fQr}cS%F!<<9SCV;>^4*!jbk%M3r=;9}=5o@YtJfXkh~-U2!GNp$`;2=bHr z6%8GJb^Z}|4QcS+>-_WZ&7{Gy!uhx37J@lO_3Qok1y$@#r2d;#)apHo)PFUQT3_2> z`1{_Epq`m|r2eg))N9aQQvX^Y^*Yth@B^|_v`sDYKR1E;#CehWovUeEpDBia@O}^4 z?p8+X?+KypFZ+?y-I3J~-s`&(%`aKs;}Y68U>m9L*hKrDC?xgXezf0?p+xsr{<53)kG+vB z`_6;H2kyouBS0$t4ZCR=``l|9;9w< z8yd?VA+W(zzimT0h4X{dRi301x+Iah!Wuf^ZSbM_bLUjkiSzFzb<@A1@k82>x`gR8 z{#35v=MDXfCR8IlXbMe?P9b&vtLS9Qb-MqzuH7j*W%c)@PU%FGQhSr7zXs8%J;o8( zh^k-svsgN9qk}9xI-VxyE+9)^A4yY&0c!r@=YOWtpGYN3cO0NIYLIX1Z8SBukKsqY z*_U3jZx2~|%^sR|-L+(CeLhW3O)~t;3vZzrM;|9kFZZJ}@0mlErf;CLvd<9R?`&U2 zXP@p*mX0|_=j^zTEFBg>=T-&i{^+IMUZL~;@*+#ydeTexE+VymMbONZ`wTzz*URYT zo%2ZTv9O-3Q(@IiXdne6%cB$d-&i;)qm@tLZ&c2f_^b8=i$zgQi{vQoLc=#l`Xhtom z9mZ&3x6!25KZF*(^P%n^ul4?g7GK_%)SR74O9nnfYQ9@fOTHLGum({5=I?c)Wko@x z=3q2kJo*+=vwJ>W{KKz?KYiQvw4!!1skv(%t&I7a)T~)ct1LqdKYPt$TD|gWQd5*h zmn3Z^HS>dMO$TcD-zPWG+M5rPn&>5T>C6M9X7n&x*Sm>me)*c7rF7XnD@aW{PgL^*#_8?t3}R`pAp)nuB{t_5MP- zYUCrv{=vg{(pBG8lIo3t^xD)^QoZ&*dhO#wh`z5-y^5|be}PmlJWW@>wVG64nn5Wl0 z8~YQ7f&cypsoMJlz3I|0QuX9r^rl@qiN0@fdn#SCY%{4^?MK%f>q4sPKB8-5YmNO3 z$7H(puNYF5`VGDL@>@vN#B1rz^ecUzqiXP0x~{RFRP`E4*L}=LmCxPu7IN0u|2S1j z*ITkl<%h4(_498am52J$^}C-SSRJ`zTR%ddKn;q%wFYz2o>HQrWK!y>r4N#{SA557G^m zxuoKo61rjjP*U+x5Z%DOC0N5#vG2mJpm#McA{9FZ(7Qgik%~=E(!1@i8~ZU=?4fu6 z)sIw^N6~vOdzMsWZ=?4(XBhi5@r88bGUOja>BbL0H?R%e6kV+E-&A-u&`rP3Cgndp zOgGQnOUge#OgBFlMBrmk_jO+UgKk-JoRmN1Nw>T^hLmHzzBi)L*zdXOb9(R3UZlKo zKfN!5kn-G3^u8y`jeVd=k@Wt>*cTe}6TScN7o>d9Ho6t-9PK@Ya_diY>$lh+`r&%| zK+0gU_|v}hfrkOLeWN}7=(a_8pJB(1blb~+k;NN-rQ3&oVeBV0JW98JaW`39e3m{q zsgx|fjL-+~jW+g~q93LY&1YnB@DchDTS6B1`H?>CKg`&FI@6s#{6P&V`>GdxWPA@& z_D)y&$n6gkeP8N{6ZFxU`$*ZAee}^MlStXx4fHYJmyG?Y(jfZS>)S}#WuMR;qq>l? zN8=;KNLq^$P>`uGEdqzwBkJH2)o`&*x#qC58vC8cl9qfgl8kkZ|Z zKGCp(==)xGm(VB2?;)kvJxiaw{T)(Tdxk#w%NNFe*sROxQ#-LQHt95}*KeX`O{&(mjuA0Q=v0Is@14;3_Z&PRXb)@*EDC&fMYww{HZ~UCnrT38H8%9$4?kQ5dw1~3s5Tftf zWgMdHyZcFT+z)hj^4p|%bO*Y7`=9!LUUA#ObWd(1Df%Ul?%6Yi6n)m0?)6VM_W7Dl z(!K9pLW;J(L|+J>M2c>`mA-IusImW7=1*Uo_5&%(JVIaG_A)6-T25c`x|L}Af<*z0 zzQp>GqRy#wU%xj=;n|~fU(E_*zwpQ*xHhm@YgucI67#T%h?eP>T9CSH-wY&={>|9G!&LVjzgkZZ zto)uVdJFKg5o8g&o*pFgjs3{m=F@|}K1LQ@8AD%7f0ZmM?Mz>L>?32JGVxA&Xu-E+ zQCJ#1^aA!R{T2H90L07peF}b#r?0>JC@DDpEz4kt`aD6g;`}Ch=;quA!ohdVjzHd5f5Pj#b_sPOI z5Bl!BZe-!`_vyP&#q0a23zcH}Ug33Q!RcZ2y?ytR1@9cAM+fdS_E{euMvuPx3|VmN z9{PURBV@r9m(cfb*kJ6x&YDR-h`)?1nD8q7;GR&jV0Z-m;LM*y-%Ci>}P zFOs~byjmHGcBi&R6Tpw>uX+Q3L)x|2_JNdTtDtRM|(H96(eNNi`szdiHuCsiyy>o}No3l{3`f1A6B9E2;Ce zryf66Nos8u^?0C3>Y)Y5;08APN$LZqsK@L(lKOQ~>Jj5BX$lN6c!C}+YDk(9pQ%Un zsghoB<=AoV9{SxSX6~@(LSjNxBkY)O~s;N!O|`bq~8C z>B3qW97Fdey(AstYTYa3mvmnqQunM!Bz?(UCf{&9gQO2{P2JRDNxvdHbz4)dP~MqX-!UI z{!PgkUX;4pvq;9}E2wL~I+F2pNrRv0T5YIgDw&hI=8lp~tsKX#*(vln&F{Zq0%Z9qQX z3QP8!Sxx>!8cX(mE6Hb-mt>zZfPBVzNcKHtNasR)+E@ zAx|sGv)`M%zc!aVkNn8sTAZaMZ(V=#UY1t!`gbMoQFkQoxYh>m;_VeBd2f^=@5*kH zFO3U%XZ8zmmbtJRK$Z4>h57Cmu`wmv^b%MokLj2{(C~fSXdF|14_Pv8WW7QjprY`bvRa z^G(hsd508CKaSeoydnjwf1$R{_foJ+Pm{kHl}!q+D@JYm<&=UKLa41rW+|9_gmf;a zZN}$PsAXqrgFJ4bpxM;s%o-`Q;H=5(O!tsNFRN3V;EYl@H$K zrC7}|)bia=Db}^R$q#KWEydObP|I1Bq}ciN)G`$9*LkFKMJ?;)lHwj~sb&5jQhY>t zYVqx+6ra7!lOYui`YO%1Ll*s&qTEyg(616=H4ylE^RZ7Huq87y}NQre#$m=)w zr1KL@K8e3e$>QnBYuOkn>ET9Ru^FZ0@S&u0OJ0qCNXh-X$*a^LDf!?(@=AS1N@aXu z@=S+frBs)+ zK+2VHp=Plsq@2ev(z&Z<^q-WQS(ciWXd~tJMo`l~EamPVF?lRCS;|*wMNJn!m+~FP zP*bbBl#keBa9T|pos;rMz-<-IBIRFJrY7H;N`;)wOnz(6e5uf*FEyFFM=FdSOijWr zNQHH1|8ZSS>b#T+pM9uF?$=VWaARux;h9uyT;Alpwj7m;lkQUEsq3ZUwyo57#8|0# z&1!I9jjL3aN@Y?}<4o_RQj5Jr&$mdWkwZ*AY)t{Fv~M5Lm;+MjUKgT%eWkL?JJPu^ zDmhImduJx?FZi*rsifUmCY2XuF?q6uGoT-YO3j%76Yvnj4pHD^3oh7FRcb@!2_LxVJ}_r23~sYJ_>XMnOMnv@EC8u%tD3 zxJKP;NsX~Yjq2}_8XGQAqkMIx#`)eRCwHNk)GRoF8Yad|O?T)ZCO(szeY_2RuA#>q zskxy9H7xx=YM!%F!&DWd=EqB9aCQ3^OD(ry)L`Cesnsiy8ian9T5&H7-mXE7no{db zYif|Snbdk8MD<^IOYOWfOb%~VC#l`TN%dn}N$uFsK6jybg>Q;;q*9QYk{_nv6!M_pypWriu&r02ZFw(g| ze3#%m3EwUF4Z?3p-QW34Uhwc&!8sAmO>mBcbCr4%Jq(Tz*CMzk!nFymk#MboYc~19 z)n^3vgm7;J_lR(>r2eW-q;rS3mx6mrxVM6POt{yAdv5ZGaW4eVgz#(x&xr7>q{05h zCa3uElHi#Vo~_^+6P~r;nH&5f`huWO5c-Coj}ZEbG`vuZ46gBfZ$Y0T^esUjBlI;v zpEGzz^hH6RB=k)|A0_lvY4qrl$w6*#6ZC09-xl<7LSGlR5vdJ667PcGoglm$f_H@Q zu87+gCmGyi+#ta_MR>Oa?-=1-6L))Blc#*wQ}9j_-c7+fN_bZV@2tUD;$0TJ(}Z_h z@QxGSb+JrwHTlb983khkVQdhL5rnZqFlLa>WnwH5j46b%MKHz?#v0KU&McVQv!4QG~fl zFlQMYD&{i5oJN@21all=u9Id5mz#X*#!Z4bkuWz3=19U^DVQ@!=TTS;Kz|=48U$ESRGSbG2a3HaXYZ*#&btVQv@9@r1cvJdPAK_*bk21Zx7q z+CZ>IAgmPxYX&m7*aR2Bnu4&l5Ueo>YYp){6l?IZSc?eOB!snzV2wgps|eOC21kpv zj9^VeSlbBJIE1y1c=30WuRT9OuqGm`jRb2X!dgkNW}*`RxLd5H1Zyh7+Dfp-BCNHf z#lCox$DIv6_uEav+Dx!UBdpZ~Yc`Y9{W?#urX#HF1ZzCPT2ESTFHO2$4QoNcnvk$I z6s!>mYem7DkqoYPUq8W`lCZWEtT72|O=-36tik(YEh<=(64s`IH7a4PDp<3c9B_1^ zU`!CAqYoUk?*tkDT;b-|k5`4fF6Tu#Zuvd|GPe&OXGxjoq zJq=-RBiQ2*_BztO$9j`*K37PvCnD^P1bZaHUP;>j*O7GY8G9+go{F%y66~=Edo979 z%jBWQwHEBj2zxWZ9*wY96K`iJlaqerC)m>w_I83j9$~L1*z+0uH1>jmJt1LlDA*$s z_KMPB)f+On>V<;^drHFIQn1G)>@@{@PLsF(GDxr|CG1TFdsM<+RXR@CX>i!s%L?|i zguSg`k4xC=O2?m9Og?)<7r~yGus0U$kqLWc=`2!Cx z!E<9TF4&V3_U3{;I$^Ia*t46Q_ntC>Jw0J>FWBP~_WI%@jSc=Au>e6#fDjuH#0Utn z0zu4xbS@mR1VK!J5L*z$7znWj=?wjY!HXZbCWuK8ViSTG1tC@;h*=mMIbs=tmWMQa9sk654}CP;`43SxwWSfThm zh^92}{&D$7h6!SdgxI1W#z=@Y3Sy21ua8)yASOwOO$uU^gjl8Y*z9L;{D@@=Vw!~5 zrXa>ih;>TOJbz8T-x(^1i4tO?f*2_wRw_NCis;-wA(kqLscML=3Sz7pVy)8i&K5%t zfLN>`CaWPfD~Qo*h}8;WwuVjsv0On+S3_)95aZPl>lOcmMuvU>v0y<=SVL@B5F^$Q zD;C6zHCV$p(_w1(KUAV#erRxQ2Gj5Tx!h-C|6 z+8Scpf*7}kShpbNZRisa3m3%1HN?gRF>(#Da_K#FtETG~5K9-t)HTG`1u=FFv3BYG z_N$?1KrCJmlh+WN7sTi_#OkF_yKRQf0kM2ROkYE6Ul8Nh5bKvdi4P3@19Aa^oPdVh zfFMVpAy**C8ECpL0=Wc1PC-L%L6Bq6kZX{>Lzf$R3FIOKISCE92||M&co1GAQvLYiD<};2y!GEawXDlRD!1KE|5zRIwK~70SZb^`1(vWMC0bV-|y$5npf}E6w+>{_kr6E@( z1D4-5bRfuO336H*a$ABNmxf%I4EP>l=tGbT6Xe7+4h>(~z4JSW;GPlnC}xjaEmPeX1`kmJ*k>ytsg zoelj7a)E-JpoZL_AV;VnS15xvRnl}_3UY~poT7%@q9DhpA=fC#IU0HuAEAZ6auC~16v_rEHtnd0_MWdBZ0*bFc})y3<0B|fz^CnJ- z2pA6ytcQ#|HrmiHfdvsTAsW~a0VAS;6%jBanyzaCOCn%OG_WNC#zX^aA_2bshTaJ* zihxPcz@`Wo6%DM41S}b8=%B!|2$&WPY>R+#(ZIS$z@t}&J_;<1fQiw-#t0Z04XliS znbCCJ6j&MoQ=@^c5im9ySQ`lpsA%Y^z~Ts)91U!afYH&w>PX;@7lzIXERTTc(ZKcy z7#|I+j|3*?HS||tfdovD1~y2*2x(x2B*<-(rt7l65($_h4Q!EsG19;qNsxWBq1OV7 zBw&&>ut@?&Ndv1SK?jQ%IxetG0;Wj=+azF|G_Xzr=E=}^frSzm6G7* z^|ge5x-YO)0;Wm>TP0wuG_Y0@Jm#^X2Lp>GV6rr@Spr5&1FI#$M}8SPF|b?$rb`3c zC1AWXuwDY@%g~R31rsn~8rU!aBc_2BlaOY^v}ONvWnjq!Oqm9@Ou(3FV9g|C)ImdU z1{O`gq-kK&1dN&nR!u@=l&0&@z_JOLHVtf>fN|5nx=F~d4Te4qES!Le)4;|F7B zoP;*iG+nm_mQKLbX<+LFjGYG7PC~;P8G1IbcmgI*1Dhvc^fa(~61sJ{p>qSvCt&(C zuzdo?PXp^Gp|1iA{To<70TZarx+elgPy;I{UMC}0#du!<5k-`mj9fn^jhjT+cS0pqBFb(F9RhYWokSV#dAsez3YFp?Tr zNdYsd>AE|xlmezw16wIzEH$u}5>9swJswz00h6hL%@i=28dyyU4R_x9}ImUSXcoQtAULbFtQq0 zS&7)5Nz-+MU}*(Rtp>JMz}RYFZ6)IIctcMJ7FWRJYG88(jIIV&SHSEVIzzC$0;X33 z+bdvvHL$)C>E$%^hhTvPOt1zvSilHtV1*?zGDy>PiC~EZOtA*GSil%-V2vem-DE?r z2o_nuBx_)k1&p!=R#_siXE$_=V3`F>vj(G5WEnuQGu+aiWS_3OB zQFWVZy6zDywScMCz*Y+wYYnWmMD_h{=pn&k3z%#TY_@>W*1&2@)bzZDP7*A)fa%u2 zb_*D94Xn3BIp-MqNwDAoCR_s>E?~qpu;LQ++^XriO0eVtrd$JCE?~?xu;v2h+|XNs zMHevX8rXCJqppEfmuSsu=rF;u3z&8dY`cJQ*TA|<^x)ZsJ`*gwfQi?@#tRsE4XnIG z&&;jqx=pb30;XOATQ6YjHL&&)z5k1$=LCx{VDdGv`2t2?1FJ95k1U4H6D+@g>DR#a z3mAV5tiOQyH}s#-0thq#8ngidjerKNfW*}Lqv^U(XbA+G0u9;%fyO|C)<9yqh8ucO zXb}XO1P$5*fkr_?Vpd}8oeUi*vmV_!<{0`?Xdwie2o2f@fkr}u zRzhMg*ItGm6XCW zhX!qjK;xl7>mk*aahz4zlKqI0-D1dNgQz1R5U=S|731@iO$c&;kiGK^n9{0*#Oct&rHfmutE%7g{2LrbvUfNT4y& zpfwWP2!BJb3oVjBlcYhLB+w{n&?<>-g5A*ZLdzu3G-=Q_iEU|34O%C$VZQ$7Yo$R8 zCD24^&_)R~QW~^UVv|>f?iX4rfu>4>wo0I}(x9~x+s%509vE6IfhJ3XHcOz<(xBB6 z+ovanP8eD)fu_p>ZI?jfWr5a9p!qWN!_a~WG+`EK!vq>J3$$WlFE_%X>x!Wz6KKjT z(3S}_W)^78#BT94^v2Ml2{dUIXww85H4C(AV)q$s=#Zgh6KL8j(6$LQZWd_W#6GN) zp-+YuPN0diKpQ8}$XTG36Z@z#7G1XtEuBD9XMwg(ps}++YbW-(;|)DCw0Htdo(0-G zfkw{)t)AF7dK)@tX!!)1J`1#c0*#*qT0gN%jG=#q7EquGv_Kmu&Xc8^ZCJHo)7HAd4p4`^ZQA5ip&@@`0Z4_u6 zEzmj&G>?Y98d^w!Cei|Jq(CESfmTu+MT%N<-8Hn70!^g_+Dd`O(gLleII7Gu^w`j1 z3N)D(Xfp*GO$)S|;&2NyblT8z3N)P-XgdWOPYbl3;%K$o&~HNvD$s;lpbZshL@m&Y zilbXMi>~X2mQ?17Dx{71e3_~9dEv!HjYk@XappmseD=UsEY|(Y&(9#MtwH9b=1sYomw6@|{ z(ALnCLyIfWN&o@MCIp#>Ibf-TSn z3pBzOXobbGx1~kbr9(?B&=gysEf$AVwm@qvj)Q#+y*jkW0!^|7+GK%7*#fPyI8NR+ zbnMVF3pC9ZXqyEZXA88>;<&ia(6>ViEzm?;pp6!2q%F`&i{pB-u6wsYOD)h;TcE8L zXsj*JT8rb}0z(fEEw(_D?GA0WK%?yrt+qIxEHQNQw;tlTJn!cYZMQ(t+_ZpeKz#=(4q@8>F&^` z3pDEP(5j2$TdcdT!-tk#plNr9wjJ$3cWB+k@nfW+&xaOXpow>fHeR5ScZXIUE$g~{ zcWCLM-{0s4ZM{Ha?*^?s+CW3k4=uhxlkWy?KH7F}(CVX&*LD7G(DLK>awBN_(Y|g3 ztv}kI|EK@QfB*9V-Pbb5Epq(*yYFO$ku>tqHnh6$Kx9(fM{gVtOPbi|G}@j?)8jnR>V5>2v?Q+^ zj%y~Z>ah!LiKO)jHPGrl1;3Ma*Mq+L&&wpIeF56*Nr#T-Li^9}@Xywy^IiVpcu~@o z1eY55hEOHh<{de}_18j(&-@i!;yK(rEwrEdDOyEc9*~Iez_i7Rz%K?OkWd`ajX? zz6nd68_Mb1qkLJ#`1aHpdj|dD+YaYw|9fcv`96GWbJA%%m#><0O3&_S(>tfW8*2JQe3|2%nP&oy{hYHB@ch4&a?Yv0*7T3~ zyumr&?+A`ZIv2e84{a^yA_sn7_m%jx+qrbrcN|AJm)A>&wt;iS3G^S`Z{p)#=jzuu zpN|pFHTK$Q>pIuvbT@q{K5TVvbZw90;m%FRx}vS<+}yQ~=}+-~sdJk(2*+KWJF-Wj z&E?#=+(8(FQhY1kjdt!iG8xB>ocnxdz{lc)bN}3G=A`E}L{ z_;tK-CYQU3c9Qe^o>QiO$Ngi@U$<~Q_xn2kjF?A`dw-mN|Hh;J=j(CLRi&PR`*ru6 zO4B_7?I4x5%p$b^{66l?S1!Bo`8zdKI(sxZZXZ+Wy+)$_=L2%{^B}0uB}r! zwx2-z&rjs)QI)ItI&xg?q;hA&`CqxOa$g;5`ixvoR(S{aBgf@9m9JI@wAod@A4G=F z^QBU%z~qAD_;0-`*cre3Uu{*W*ayNKo#IP!v9T(=1;2OUm?{#v18o~sw8;`O{7TMu zR>dyi{XKU>6<_R!wudS)ptM&9%u`x8U@Om{warDRLym`zlWk!t)OG%IQUl8 zZnOsNKVOvtmsOoJxPJ${liU;3{Z@F9s`u^&IXH`|zjqfoRJ3X^3h$}z z!{Y3s8s+gKN77N%=r+dvq}s}DHO4{R2X}vFWvREB9Q(qQ704I;2$|FZkGJIaPKUJQ~ z_mX3KE9Et05`140Rg2m^(f;%I-WsG@9!X7(E&r)jlmA0oN44&ZaYXlpN&KkVJi~jJ z*g>`3iu=B4i)t77!1RmRI8=FOwvuDRG39-!71~m&!(xonx{u7dYpPQ3&t|9odw%~st)zLR6+3)S5n^VCXB z`K3eu*8OOfKUO{F;k=gDS3P@Sow00!@~?>ZQ}?M^T3PklkNdtPTJ;`{`?vU%>eG6y z>0h&Gkm`G!YxRzqIhBFF5GYUoak&$D%XI65|EU!jnNB^2JT#dNqF#U0+eNh2} z-;-lnLlsyH@9|Wt3jE4(ioA&aKh{-6EyQ~mAE=`H9yR@U;-0FQ&$vHvC6v{9 zksPDDDO)_=Ki!un_M~#;$9;`Wr5yL-$l<83Vton__A)7cJ+@V9RMCUvuwGZAM&Y?z zv#L=~hMGP;(IIN|=3L~6N>FjR2f)|onu-fYf7JbbA{weOg#H*lM2%U6aW-teiqDAi z*L{CNzNq*M=#L?#)mYchnV*Tun%Fn*KpU-l~aXx{zZ?UN!OgYH|#2q$ah&^U!^T2F9t$ z`NorDz*;pq>M}X{pHh?W;(6n&Mm3HAKzqj{DtZ zikiu|Prhr^tkNq@KO>)OYSyc&4*f8V^ATKMg_>7&%Nu3B`UDLI-nR*TEx_ZzoTi^t>s z>;6hwPqm~2`m<%ATCyvU9PT64(n6aEd-xRJrAAh@^kFG-G#ss#dHRu~!FaW7!yMC( zsoo5=JR~DI>dscnuQeuz>pZo>Ez$bfbSA?uygGct zXXAcUTdY zE=H{_jL($~Q)}(Ge%%ME^Z>Qa3*$$r9%|jj?&K)hNv+R;=d1fe6(_a++Dmd2b5$GM z3z4H}MYUmh3qlMe#W$*O4z+PG`emWiYU3Hap9MatO*PTabU&$lSJbBO=)ZZ7s>Gh? z_jz`z#Df@bb)TtRGt}mZX~~h(p*Fv*MvffA)s~L5TBhDwo6}3G_06EetwLJvasryyAOj0}C?vo>JklL|49XZl;Q9E5K z8$MQ!R3+8UGr?s4>!NnmoJ02C&(yBjd&%&(`ngfd56aWIsPt9c{3i3_q_kztyo+@XtDZOdae0gzTrLs$(ZUli~AqqNqAP1HXIhkvjeb z_xI>Jb)s8kGU|66uBA?vYD)HlU)0I?wq!rBSDk#(l@KFL@daaxI<;*$*`0sX>3q2E zBvGfM>}2?b?bFnmCR542=eIhOFqiDRlhoNvi%lP~o%Ph&i|fh0{i8ZpcQe_yZC2+N z>@fYswv<)p`y`P)@vb_5RLH(*p1M%!5Fv({;ybn>qq^|n7}?hyP!~HNC;QrPb#dPb z(~oTRL-pS%9Iu+E{(FLUWgB&=B|fM7lr7t#F6TN-_N4>V<*)-}Us6C_zM)M2vV~FV z%8FfNUr$K9Nj=(v=Q6mndYor1*$2K;k0Yj;er^3rswdQg?0xsBC#%qp`m|F| zGgKhE?&Ibkqn@67PxhWU)w9|-Z@<;*8902q?(f$1w0iDuC3_ct_52Xtug>q)i}D&F zhMwa4)+x7o@#YWNJFHSKJKQC^cWw1@my--XxVGNvl@0g3^#29CDw17e^{(GvLX1DfSI+IM zdS4}x?2S69_tWCY-r$CM|EZhlH&^$O`jC`{?5=~<$KrSoYrj+qphmfmC@v|#-Lw)=9jqF7`sboLAH-*otWSM08+!bK;eH`BV{PooL zmlz-NCaNFpHktl+xfZCO`5TfwXAbo<3immCocehO_euA~%Q8&;N@z{?On24qOxekv z(OdlG((<{?YWcFEIL4jPv4WVoaS#B*&e;*w6)rk?O{7k+pm)8 z-*+z$r#*IyY@{;X}54(JLMTXzs ze>pi_XPn=K;hb(<0NKu+QoO8HFwt%vnb1C|v z?yER#F6T;(dR9ZuajrTo$u>AW=Nf?iru!}S58+(@cYpe>=UhM9k*)V#&RsP-89t0X zJvsNZsbuqu=G+I{lC9e&&iyH?>Cfn!lk@maAe&DU&NJSNY#oC*&wdv|4mQQNvE6yj z3qJ;1n?Ibly&KtDSLM91-%LM8uXxV;cqG|8wsF4vmB`lYHs|wtZ2CMluEqH_b|stU z$NBE$BAfdd&Y%6X>HpZ^GUpF=CtJOroPX74vehlc`LApudGLvkD3UML9dsCn;7kZED(|srNjNrmP-N=?}JQp5|`<`PZ7v7UZ zh96~?D_o=q&M(s&F4E={*)pc%B6j>v`V^l^n@b%o^56>D(zN8FdE&^H%AbpRz<*M& zxASWp7hN}ztUnfV(VOszOitutSsoH{?2KGHSwCOoVgU`w`tczbTmG1=?>}*||NcL} z%Qv~XcwKz{RVgk$XcAdp)ZpR^T*>gkeA1GO|AOD-qt0BSdR4MM=))y?T_&T>&z*2C zakvy&Z^d$n&nL)wV*-~fKZ3vjr1)lDS;!?P>?P}^6%lak+2h$+{?#%U3)= z)&(QDeD`hyh9brHb50j7ukd_kwdV5gN|SYl#uZBLC&LePN*S&Y_nfSg@^Xb;cCt=L z#}%ICCBr9l%oDEIipV4R*)th7uuE&)#4kK$|39j7mx9K-J>;qR`Qk<+qu5;yco5?yzxJoJu89t=_ zCUcd3eq`+v#8qa$AZssQu5v7bj5 zxlSDV`#(QctIJNV^RzKp(>U0*0Qy;~mh9RRb*^-u)}Oc7byHP}`M!!>@2sJiZ$r6m zjuI53*US2t%yolvQOtYAbyrQGn75<3?v>O8#wf+t^<@^WSN|QwJUhqrh76#XC)2s! z!dqncy*|jx^?o0vn7dcFevL*Hb9)Zghn^kGQi>1k^}JmF@EnS{@*mg#l96IAP3H#X zqfLL<^O?B81b>P-bCetGM_t5IqqxEA#smf`#W(ioS8mw8B*h%w!VP1mQOv=?+;H0; zGW=wbb!n9MCdKTZ#*I9^C}yuGH;UM4`poXw#*J=Hp_pw0*)7X=irG?_-7N5j)$1^B zh-J6s4Jl?_ZFal3ieeHTvwPZX1V$^xmv)5*yAQZaF-yO&`#evIS-hIvPvH6%c1rQ9 zou8U5Rjd>6pmXq7mDNoTi{`nDK-NS9>tfT15uH5F>bBeyWjoTzwB*Ulp%sOt{eGNsQ zD$Q*t;qQ+x=C%s{!McC(p{d-i#A1p*ke=Il-=Jt^=XRs>5g5x9U*o;QxZUGP6us*K zx6gN!qIdXmd(XdQ_#JO1ZofW=qBm~m_BV0;>&vlsmIq|`Ag|8I-Xl?8Z$%V)FB?nI zOJA_}1t%GG_7JNwqUNQRHI_jmT4U7VuZbz$G5%_+L|PWJselnj4o&*9vq z>kf);cAUFRxJJ=UN^_U}KM4$Nitn@A74BNBF-145&RyH}rRaKNxvL|N3_s{vuH5wj z`c?Hw+$}erZpl zZ@Fh;V~ToJk9*$jL|~Blf4Z-|H*gx!1tU1g4q)=W~7j4);3oj-t*M=U(4`QPe4a?p-CL>3@CXHus)VoT3gD z=H6V1qNFSLepiR0od0~W_x;CxI(Sgjo^0G_bX$tr*^>M0=uC!R_GZO>^Yx>sjo-Mh z=MaioUz7Vr1d!pQy=po4y%9-K%dc@i-<}x7{b%Ce$8F^Phw-^F|NOW|XXOFq#!!^Qod@`iqA2Sy z9x%>MhEI3+2_EnQ_b=oN4=fx+Q9-47VC&&z)TxsAQPkiB9(cDaMGZL5gK~Hi z81ocg@7|?(P!Lg6&(=I>Wj%`O9>RkzRVBmk+vgw;u3LbjIy~dS1G7+6`)oXT?q4!| zz+3wA;N&M1Pf?}v@vsE+Gu>yrNNXOR z;V4BF9KgdHY@w)p4jw)Pbv$#Y)LD+ov6Y9P#`kAE!NY&Gqo_>xctkZ<(tXLJT(a_r zskolhrFeuqqDb`X5$}(a;a8sQ&m%idrN}QqJTfkjB0t9Q$ekTcAM@91I3RysihQw$ z13W)dFMBnSH>P~@I4 z4vvp8{nNL_a_}?wrEea?Aq9R=Hid;E^LvDFe{F(3SWR5_#3>xs=O9Ino5*1^r;=J2a1e|;PB2#1Pw-tZ+qBK4&T#`B7^&J`11l38Q{ke1#usAKldRm zIU;%lMGhp6*a+YFeswwG)_2qAy=QTbw2Y?6?zuT~B+kD}I*weHiS+u~k=`#kDizMB z?JbT%d@Qon8IJ0klb{hv@r7@`iK7nV`7~L?QJ?YuwTT>EE*lws@eKxW^jKVX-3}bR z$AcnkTR8f8YBGG}tLEjHmJt+L@ejvD*P_UB&pBqpD>D4$OYCE7)*cjDbOl>2=qH87 zvvmY~=yl)uJe}Ekz5zw%Y{b^TZzwWb3AWW-NxC0>Wcp`pn~Cd5dx~v`;9H+6k!_y> zOrQE6fo%7=ND<#Uuswb>MSQNs_T9Bj|N1xY*im2_MZ7%6jusY*c(#!pk*^3En-pLB z2Lsq~vpGfFZNjnXA}QilQI0Kk*7Uo-e34_@MNq`WjT}1=^~%r1ajXOW__`1N30IEY za-1TLX5rWqMJVFn1CG5v()7nqn!=-U<)MhZeRx!*0Ti*TE{|%mo1g(o@y*|Sn@0tA zqlk^0dDKMs->-}1Q7eC#e)=m*^QcP;DPrkI9`))aMJzhVqg@)BKKpb0d9>>_ikMlI zN5fw{V(NDuJs`yN-yc7NN6*bp5%E2EG<5qBqbu;}W9tYSr4(QOnEgEZTVsldjN`Z* zlPMysHOE!J_vwE9BX4qC*AWykY&pjT?xl#q137L&8q>$W&wGyBH-{qpcXHgtdlcap z$#E|$n*RPizj;hy{9Om;F?CW=L^}tMY2AXLp-S=nZ;^_}#9XC_=E7rU7o&(Kb{?~- zKS67iQV*cfcOG;59YxgN&11gQr3lwxj?Wft)(NQgg5$Nc6j6CK$NPFwLh7i1)Fsaj^yF-9?vNJzAGJCVn)IYZ$)I`VjN zq3|u=c>FbYf<`W-F2Z_^CuG<};R*M7LWxHdzA}y{G$=$yy@W+adBR|v&-?*AA=XLZ zbJFpI`5(+W3R9c$gp+<0KJfuhcrcy9$Ju$p_akO~h1fkjv2qm(w{_x)P5mi6>Mc*~ zK7*j)OR2jMQko}D{6gUYNjz~?1qvVT!xNLbkx`FfKpam54;9|GFi%SRio*T3@}#0g z%sLHSZt0zz?1rKpzsc9d6MO3u^6NM$M=V_BdC~R+Op0*10E%Z7T+w$_XOBX3DaWYSPg}>k6!qZ){ zoAoVLe&Fe@ttf2SK%U-a5QQze#nbzbA!tZb>R!w~!qaCf3Y$@%r*FDJVN*8n^dn!) zdKhD;@boWLC~Wi}o{@AzMZ469FKT* zjyn{VwF%Fz@S5~GA7L&(cy`xJ6qdR(&kjU=^WR%}_V}`9{g1B$c=le6LO(LkzR;RN z-xc85&$|#b!YOq@o*m;k1xHfo<6=CgW)y|q58*j2;>>y>H;VI|$axfc1^+&M1%+Nb z&U4mnFzbk%8o_g}CsF7z;W_UQQ|RGbJU8QMv%W~ucAned28HfT!*jjwQ|QhPJa_O@ zf`&Pz?#QOMJa_&_3SIBUbGLq@(1h_k_rx!=9?8;@Jomc`g)SV%^KxaR(7C&LUZpH% zoswxSd0w|%6gp`p&kM>!q2q4yyb1Zt`X#YLc;3E(6l&eV^Dd%}N#qxv_X4e6*Cfcn z^9$j4#9^La3!fXBp69p3ebnon^qs`>qw-Ry|5=_tBR7TmW#{?G-y3yMI!)vGH!@Rb z`*S@1LwX8rlZ_W-N@LbXX+EA8H26-TjgRsI@6Qx!Ny7^Uza?nEQ|hMFjp7CKA5mzn z9lT)cZ3?aSh8LW;V%AeB-G#e)#7*6Y4tTvEUVOZc zSr2BD2QU7Xl|t4H(KZg=A~Egecf;K(l-Su#P=&NbNOY~r)giFm$@FMkk%S6 zYm-1BUOv36|9FB20WbT%x-}Hb%VxKs5VtwJY*RG~slS1j9m#Iiv#D{Bmwh@%Ayppp z@+_Mvq{3HTUIy2v*SRTKke7FAO(8`q^73JoD5PKmULKdhtbdc!mzQrpL?K!G^YT-; zj*LOP{9z2~b#X#cP2v@~Yg6#AxxAusHVRH&!7G|PH|yoR-_0w67E|zR;T5P;5d8cE zuUOIEtfPav8Y?cQqTt(idByYV6ny;&uS~Votgmz7J+G|kPr+xt@JjTn;1l0@W$(-c z4~LYxI|u&q%4xeOSf%EbYbR3hzO=kj@cCW;>hWw#$1C5Zr{KhNyej=o3SRHRtBNO@ zb$V8$=2h)FQ1IfvylP+>3ZDOqSJ^(B^?Rm&=2eMvDR}ZbUUhUJ1&@EptM1ezcub_! z^@+X9tFvCFVCywrU3L`(N1o@^?m=d~pFrl-!?RNG@Ljw*?gj-9-pH#LtugBW^`674 zPiqw1V*;;!l!=17+IaO3e4kGs!{dU2z58)Oj~9($O+FkQE-*>ye3r$1y^wLnt~0@IzuI9@fxoq z6kNp4YkEzf-~vNb!nw30D|Z|G5mf(9((4Ix)4s80ZIn1u7}`L7OBw;a4-{~HSOxyu{=TSh_Nn|Q-ZZ?isA z3oqVSXd4AJ&&wNY;l9v)-qn3SaqTHG>N%BP z%p0$jrJ&ONdE?uQ6jZz_Z%S`7>pbP#$D8V2rl4F7-qhAXLD`z~rU8|W`cFYFXL!?W zd_L7Q-n6L#1^(*Dn+~5Rc*LaCh5B@rH-VoHd^e91GaskGS6w-=bbwhe>ftp`?BJxp zyK^{kNM8!P>BEVmGMIIwE}rAWtsN-v>_kpH{)GZhdUE2u1!jGz15VzY{T>B6!+CT0 z(GP~H0!J9`6qQH&acyoM43S66$H!nuLDZL)mQY&vh{hR_9*5=KR z#!=v$XT14mc{1u$O=-_tD&xE+q~R@1Q&HfUoxG*n60?4lwIFX9f0Y6wPVkoH!4w!0 z#as4fBY5nj)U_IVjkiGm5IArwZ~1eF0{go1*8CA>y{m3hd8@~I3hdm7xAts8fv5+x zHS~sA2djk}Z(WV^ZuW$?CM}~t!sjp5HS1&5yT{wo^rpbtV|iO4+@I>zcw4QBWYoPXgC3st;2L%>A%-g12C!?NL-YmS0e^X$N&AjdER0_=E&D-9VFzRdtrkTat zi#4HuKd!vp^#TQazs%d)^fv2neaOw*W9$_0dMj_Am6ZaXx8v;_77#p&QtEQu8_(Ns z?4*EOWqJFD#uRWB^|>;hG3#}m{meV+Kcaw>Q+Y@GkrZ&W0`C}@Y}WB|cHtd!vrxdE zx4Z-S=YSpYyyIvwv%c4cZM@@iH40ec$vd;)cUIiwon_nz9!md@sk4r+;`*X}5=emH z5QrNg?(SJ}cOxE%8`5G$iWP5hC=L~z(n5>NS-87EfktLk}Up}K0VT`9T;PF8Di1>JoO)Y?u3^&B#nj%w}5 z40N|&qSnqmjPBOXYVDf1dOn$nms)!x7~S>PsjtQG;pXVB zy-BUhosRCB^7l6_>Um~wWdHf^(e3$KwQgMxbbIWn)*Zf8&pEs0q}F{rf^JursP*k4 z(Cw0yTJI#Bva|El`bY@7wpxEj+WC){_SbQ>LEjSHmdB_KE)&sh(I&Ma>Qg;OZSHSsgUp9+GxgMl zpQ6!i>PWTWcj2r}c%wFKGDEi?tJH?$W6^EoS+(KrOLQ9+t2SyDL)P&6!d>fUqc*yE zqFb*iYGce?bnBt1HWq8w^VllRsg2`KqgzRo+PE+n-3nK#jhh$LbK1nOZM^>tx}`i) zo3v!Vglx6RD5##_7H*?9#Yua?am>n zheL`w6VP?AsiNtXdX8Q1jf#mw(e<0gils-fJHsuuH>QO(kfYT{+m>n9^Y)&Ws%>X~LfwO3)V9ZmQFr^Y+TN&jJ%{gd zw%YDJ6?Nw(tL?(?t2=o}Z7*wA&*wW3rnXO>hPvJT)%K+)QMc`HwS8L~$QpcKxP4Mj z+5UJu>i)@9J9G}9?#~Hohgsu#p5KCZYDeM_)cxYBc9d>H-Rx4eqyMXV&flbcYRA$V z)cy29?bx~ib)%itjx(3)`G12ZsGT}VsFUwW?lc{Nx?YdfPOr_7H3GkI0c#W0PWj$I zT}6Mjvwsolx-3>ZCrzp61?Fg|o&12h3`e!|j2r5bv(?T=rS%-a$YpAmiEssRLhbT= zhq{0dYFC0|Jzvm0QSItC4s}jF)vk$KP-i<+?OOZ*b^mb(O>d}Or{hp(*hKAm*cWwr z&T4nVh4_z0Sf|@l?e_SLI_;m;?s#ceW1ZUFCA*$e`0B0NJ>d`3J~L9gMd#K&^jEu; zMm@jqdLOm>K{{$LPgQ#w3_$Iv@Npv(%o2qfoo9yV|o^&hz&uwdceUeB~f6S*P}DwMXsmht*y~Kh(~<>dHBj@^oUUVouobIB(*={25RlH)c(A8^}I&2aJikb&g)Pe3-A!}%U;XYpbSsj?CftpM5x~3&+&dTdSvw9xn;i>Aty8zVeo2(AD zjzP`N3F@F-2EKA4H;z#UvujbaW`sJ}wGV1m4p9e(4@J%L0qWrFA5pWYw>tRuG}Qds zOf4>fZt)xj%^A!~eo;Yv=u9k^3RrIjF-=rG2aR>PTZb z-+!D-gZt`;kMyVQDRm@C`qx6KBW2Rx|M4$t8ctA0ChtV`=RWF)#Nq09h3d%GwfM@# zd}6PTJX(b6`z_Q_?YXGF`CJ_}nToHx%nO^;(fA>#K0Qwz?a~|7$A+k*-__J}H1|ZP zql?l}y}hG4x+MzLTNCuBadSP7bIf9OY{Lvx4iG46s1EC_j=w9Z=Y9G%P$%qMQ0;zFoj_YuJ1tZvvR>D7Ks!XL6F(5urft-TS-+uL z|EfB%O8VL6PbF*IqPqD2b>d&)hBl5>Ctlg3x`CcL*<2U02JRPb=$mCqR&PPo^Iqy? z+7eVf3Q;HJ^OmnX(d$Rl$)Cefb$PlvxxyS(=Ze+I9q;QoqlX`;lTZIf)xN*gsm9|_ zwX?4}WnP6U2B}j%VW`@up-v?kqiXdIb*l6^s{R_OPW3+sS)=z0mvo`7I<;f~s^%Y5 zr$r|s%_r4yT}(+y6bYU}}Z+GsJVMvPUb-DUs(IHm)%)#>66sOr64o$mb- zRXql&(?9LOSH5ZaOLcl<4XQf-rA{9UKvjOVI(IHSC-BMH~OjT!``l2d2 zL7j<+!dD(@;0AT3#}!ohbXR9a{edcXYjtMcclgRlwHdF@9BhFq%W!q(+F4W?zf@=5 z{#MUVZJnpi+Ipd?Su=Gu_yekRwy3k2JMopP`oUD49hQ#DR|nPEnFgqQIzXKjzU)`t z>a8>C?4?RnULCH^zHmb2MR#>h_i;Uk_1I{2&aXEr4|=L|DZZ%OeOa9=e^bwA-R!2$ zP3ecqwdd5iW&WsKHB_D3`WCVV^A~RGqND2EqdutowU0Wl?TN}cChENLQ+(yQPO4Dn z<7!a(ldd}7*&3B2|5WGuT&d^04tTE4FUUe=pK0p+rk1Gu##fy`wzr=DTJfDa|Je_f zT@2KPc27{5zfN6nS`1ku`U@8}^|`tr+}X;6N$NrmIWF2oT^RL!Jufz}LS0yW6O}%i z>cW8;sC1j7E?i5f=g3+gRTo?Sg-VNRb zQE~2rx|H<)acYm4sZ0HbqGI2l>e3|P((Vjamlhwd=htq?SC>v%phD^mm+tRD#h-oD zWvx2M8rxsEw!cqMmtEJPVxFw~cN+AGgbE^)F&jQ7};bn{^WvoixfhbM&kY=}{vS`*r=|M$g)J)FCaNpC+fd=y zN?ozctLN-mv`|-)$D+b$oVrrp0Tu0Z)s+G3QPFa=x-vNh6}k=8l_hfChC|d9_DA`r z59-Qk;po2oAD8#}Gj+9r56U0asjG(jP=4p8y6RR?&+EN(T3sz1jPkR|>T0i6C_lbS zT^;)?zH)r`tWsCkZAJNZTXpqtGRim4QCDwVs^|Nz8m_LjevNYZ{@69U;V55Jqpm^P z`Q?Ay-`UCPTAdBbr%_!SwhHAF-PE<20r<)T9??==+ntE=!GqMbi>FZD?}57ZT>AGP zC%D@lb={%{<<(y5y3Z4om;R!zC-tu92g~<-ulJY!r(adqCuyNPDM4LdJQA|T`xmZo zxT(5+@<)^hjZoL`H$%D4Lv=%Q9KP~~9XF~Q!bK>zu~0Xnnxoueq`Hy+Q$2^cU5dIf zdNj&g{-bWp*G9Q+dv#;YuzEi6rwi)Fwf-o38?0`;d5N;;^VCiGowck%|Akw8r%2rl zDnZ$`E$U|a1(aPfQ8%kI>UqY;&Z?Ud|H}?~tDAppK-uoe>gEpDdd~5tcy;rMAXxY%%9iD-Tb{j9w%~7dEABSR<~LQhgbz_RvsB&cBb?;_xX9z%s9V3U zK-uVOb!($3%7#(hI{H&RFS)P0|FIfn-zasv?HQESwN|$sBI`NIo!6<`o#eQDU3I(b zXq08;tJ^<3$5*~`+(&hLW;5ZJ&)O>tGZJr*VBH3y3@Y`Wvv^kI}@e<|Kl{5Y0pr1woF3l=d0?@i5Dn+=b-M~ z%dY1)Kia77>KmZ+uBN){{2fZK$Ev##XCaJ%FI?v{C)M2^Kcn=xp}IR#jz3ta?#@lC z=RI$|q3-T)iqcKC>h6^al&+~(cVBJCR}S>j2kM?xACxX|R`>jmqI6zYbuZPvo)10w zzPdN?97@MIsC!d{4?U_<-CH^e!az{}j~hMUn!0z|6QzC3)V&9zQQ9L{-PgKU&yy}Y zqVBs6M`>{rbwBDfN^>LB{Q|ps&UDghb$|2$l*T+z_vf3SG~7zvUsG4lpZ1xk?qAbI zsoO4f|4j}`9p0-4Ef(S{m)g8kJqQ#mq2bT!LE4WfmG8wqsFd^kk5^sV*hM{S6R! zl$gn7H z2qWYR7ku$E^>p7_bos4;diw7rbeYpuJ$=;xUwPpZ-PN-WDd;jbR6Xe(a>bg3Jxp2_-mU-{zl`Pj1)W$2POUp>1!99=S(sAr#r zFP{8A?s)7*_1y6)x`c02&%-{UOVB>`JjbM-NA7l7Js+NlE)Eye^I6@|rQ=ogeC61B zPPxHd_57kjmo^X8^Jiz!rP&kpqVbcj{PHduFVqWfb98?9QoTsSgQO_{u?Fe?`3v zX^hT)Ur;Y)-JH&UoKi1qZ0h;wzwA{nWnHt*v$m<1f25-G)D7z8_5uh4<_kA{^kVh$ zQ7?2JHc!23I2fG=PF1gr#^5VYUG(&;=sDG|2XS8iR#t7 zjp&>nqF$}uiq45{>ec?;=p1dSUR^nW&Y^A8t5-+RIY3LjZgv8lJ)f%A9Zusbm)-V= zdYyb8oh>)3*JT&c*?5_H-Cth+$7}E0@(1;Lk^J4Hn|i(Z0y;OyQ?HMotLM1Cc2TcC zoka0d1NBDl7>e&}sy7aY>iO=MkEu7=J5YRfy?Rr(1;xkbt2e{eK^Qvf&5V^O-d(HS z{J8|hThr8=oxh-Xqqll-wTde#iEHSU!qg{;A&2 zKt0d?Zl-#_QyWFsZPfd7w^4NQwR-<}Up?pk=nVD2cr1$cSE&!~)hOEOt3JfUqDX10 z4~4cUT6aQy=qbmq`c-`xeGNs+yQvTJ2w@~CVI`qxzK;5^zYmIL99JK%q@if?T=n6V zBZQ@-gsFt0k?!iFJ59qMD!I0$n|33~}eT{G0jet{^eG*TZYv_?_q zE9&EdTPVs~q&{xkgrdwk_3`Kg6eUYLw@OeH^HP2M;0<9oDPcLGDDZpr$@UzIyrDh? zFGG>5mim;@AHsT4!hAwehY{-2U_%s{M5#|x@1Ur?w)(V8`q6Ti5;hcynhaN;PN$-% zL4^ABzyyUKHPvU$J1Bgm)Mx#_QTSwl`t1BY3h()<&k@lmy#8E$&TR={OetYaq3}$# z`aFC-3XgSEpJ!E~aQ`Lsd8IRiMWuvEg+i60K3`am!u5^R=cm%nDpEu8g)plq>?#y4 zbf$)384BlJr$)yp6wa7I4Obf!PEMjmfDQ_O(xgV@EfkJeLyeT(C>&f(4f(y2Ft8{r zEEIlwm>NCg_`1Q=7!ZNN3U_LZw1lv-s4?*~3Uen>WA-H!W`t2=(MA*|KB2~{=@6zC zH8%G`VQ3;X_N1ZE{~a}sOTRrAQ{z$-6gp>6H5>Ov zVcX9XRu>AJFQulLJqjD8Q`5cy3N_wS)AJ&P%u$_6%wk z0|i$@DC{p3oWDWMUXM_4att*G??S<0XKId}gMvNBs5z}C3bys4<}Yz5*rZR*<>n|@ zy@8tYeLP`^QCMOqSp0#S2j-*T*SXX@-3tY?gQ~LGm$$F^y@4cw?cs}x9Nc->V zkpC!$4YYlcfBPOAv}yohuu)iS$iL8(4XkG(|Kuz-a4SRpVS6?Rbb+wiD9kqGZ;NJw z)a}UMc#;kBe?Z?g+(iDb+H5fLPvp;<$Oe;oBY&z98_Wqt z{(^>ssqR$vX%`tPeOkG5DF^}`8{{D!EtG)YZ4n=ypH?|InV7S5SAQ; zDTn;rD{S!51Nj-{Y}n`(@)Pf|VVjK*<{X7RhkQI`L%T5K`}bl)PdSgrYc>qtgM6oc zY#2KR`PT2)P`;m(Z$5wxi<%?f;5{2w$#u7pzk5zVepA^#C>8nIvj3RY$onM6PdNr* z-BFl#$b0&X4VR`O?|yeST-_3RH}12cIt*drvEjaP$UAe54NoQ@?^ppF{@Vn3`%kms z-QCFBnaYMQh9hswJ~sRuhP-uQ)Nb+-c`G+iTW=$Tu}5L;A@BDk)OK)3-drPi;k>R}i(Y z^g*8UQfkY3Z^8ITWTLa@T24XE~9(vWz-wyCHY!9_nl}gD?-NbKnqi=ln>W z(*uw@?E!VJIv{sK5_RsMMegVo)Oj@$xx<>Xk)|hd2h_1q(<{jBb%2f9kApB2DJ(_g zR*qsL$6Ltle1naACL=d5l#RlIA*@9Ta}l|TZ`de%3UZ?}*r-bga`7h{)yn(+jVWwK zo#okv$Stk!$!aQAXk4o8!f+#+|~wcv{w3~+ntTJxj-0? z6xJhhJ{qyn>4C@*{$r!79gy>Q2OHhr2Vp@{n2^Z1R>Q`cddRu3nT?xnK+dTaY}~#G z!i=P_BayRb6&pJ)M$R@ZHugzC&c<{$4tFnpR)*T-1#hW=8t3J z+Wrs*C51(aoXNIqJVYVq$6jpwV=;1ulZ}7YfUqhl%u3|+&1U1}VaVz63mdPwik#|u zY`k?SglWmf2P}|NFpz?@MNZaEHohYLN@>Q%_dX&gHiL~{&PGnyOg7Q*Lr%aIHqkwe z94~7&Y1b3N$fU3`kz?~0n>hS|9P{UF;vI_|LmxK54G2qsAk0k)dlQ|WY-1Doy=JF-nrt%G6rHYzvdPr7=yY)~h0%#lr?#-k(%a~C z_&uAf9*j-D0KSgA)8#jh)yf)*yL_c2V7{KonlI;JK7kXLZ?x8@*fZuDRt)t zqm##5>MlNnPEHQg{aemwolo7(4hAd-o%AEF|J$o|lqx*wvD{qlD<)j5vrM@QJSbuom2N@1ZQ`>HLQ+Vn&A`E)jQ*GBe<@7XkP zB7~JnVWuK`*HJc2U5sq?mQC|LkiEVGo0e~eFjXmRRb(&wmQDK~MfUGA*>prMvgeRZ zCtO4Jw3}=?s}|W4blG&l3uKRWWz)X~B70~in{I3XVYE_Mt;p^$7Y?5AiHfQo0X(N7_t+dCO_A(h+%jH`bpAR5w!BIBXjfF67DXd#${rrl} z&BKr-@xHnJ7G#YvVskG)2n(0O#6{MCU^b6)K~}FMHqTg!tgeM@UStJf=2FJ zMwabmHs3ARZE=Uqk0m0@@EMz5*bZU!QkcES60T|UCx0SKyBV9mw?gKpwrrt29m4db zuzivF#F8zHh9L8*)NPO4r(CtTd>9HZpf?+WQ!{okXh!(7WZS3S?I|YFV`S5+m$Uf zIzSl46qYeEV>_~?-aBN5nX;w1oG(D1E$xp&SjQCRF*2PRvt`IaWOn?_mT@hSY5IyS zGx|Z8$P_j*GFx6}%c=xqHa^Fe-%7tU53}X>CdhcVgDpo5N5=DYY&q!xG9D~r%Q+dy zxH*?CMMn!`nZjB|#+hMkxoH$Kj`m{9T@R75ubeH9%6{9kC`@K#Y>Hybo2JNE?ah{t zhazKz^!M#e2(y{OZbrs@4Yq2r0vXdEv6W#fWK6ukR#rWcF=h{i@r;aN|FD&xFER$q zW2^9)$mlhOtrFis7|;|JG%_lR*s9BBWE97+Rh{%Z$BnJ}41}eO#7p}>1|lQ; zHd{@bg^a+%Y&HKagelEd%Q_*$c@|r(UV{vqA#BCA$S^Nwt9?C?VGzewCk`Q_wKH2? zwnv6;E4I2b0vTG*+3ML<2&0;HA)@b<{r)<~4NBZ>7Y(3r(=@ZYh^^EQihBk$zjr3vT*?NT$(g#$s^*VXK7ub5+P6%t8 z!rVrB`D3;|-4*FYyV?56Hl%l&%hva${nVap{jw72adMu|8<8Gv#x}arpMYmjrm((|F5{<7dIZuNuV$Nq$w=26&Nda- zAS`eS6C7#JJF?Ay!AQIRoNY!NLfVaOY%|dq!VG7dSyf0oUC1^I)*$VO1Ka$ig|t1d z*k(gA(zb4=FvgL#VLaO$x`njAbJ^ysJJOb0vCXxC5C%DgMUJ#N>)7UXYotvZ%(j~O zNE;u^woMm8SmhLEInoB7VOtAdqC`5wYZr?AqIX5WNuXOBRd z<$ktZxDRPYW7&3Pa|lbF!c<3EGugg#3epVLF)b$)U&vP)E$-7bCm6yEh#K_q^>?s zJ^B82>WV4Ui@S)_MG4f)G=i|+saKSP)ae_kS2Yc(6ThL}x5tq>#+G{Dw}dd^sW&PC zsr@HYZ_+5F_Kcz4>>Wt0{Xo5ipO9Mi7xh;9Bek%UdK-HoHM<@4cK(UfB>v>4^yFk5%Q;_QZ6ZKvngs|u-OnRhtxX*UY0+DJwi|yL?M5S z7E+Fy9djV(%+ozUY$dV@Dkf=HbzQq zIomh&MM_y?wr^LCl!B#fZ$1SnSqW@!zYQr#_u1a_5mKUmV*3zdq`;BwV`Grwdw}g_ zQl_|7vwgvQq}a>x6$g-FxsdI9yh4gm1ltdg{F3DUu)FVf*!lNWL|c?YD;^`CntUKUj_AGqT_5Nk~4L$o5y(BYE!) zw!e27$=e37{Yz~mZ*0T%pB<4b`CPwADw3CnP`_;-B>#Sb`lhpyJg18KwnXyO57c+R zj^uF@sUOq`$s?_(A1%iXT1)-ZWF+^ErG8!yBzHeg{jw=YuBxSew>3!aEXRF!8p*jo zQGeJQB&VBDf1Cl5qR8KJ}j^Az8zo`X6eL^yVKL=!`(&i^L=v0WLHN9!j zr7x0JyrV(w1SBmQM1$T-kThS527|XEY5GVSj5&)W(KiND9wTY=k2IL4gQTI&X|Ti; zN&Uvt;BQYPecO@-o8ypFGm!?ni;z^>iUvn}A}N0Y4bG27Qf3Pp+?b1`#Gh#JXcdy8 zbZPKrCz66k(@;y=_tB>k@zfwhLyvSc<%rWznO}}>k%{@@H-MOY^33cRY*MP zMnhSTGV$Od8qPd~#9byd{QW!9&Coh`JHKa z+5m~uPtfp+6%r>#(eR!N5=XD4;R`<`4z;7FX|Pe}BZ<4UF=(fK-! z>SiL*CYeTk<{{B+1C55r_2^sCXzUUswj4*JsVk7!=oO9T$@OUz(`d;WB)r)}qrcZ9 z;i)T)Hg7`0-JfZ+TOr}3CH)*=*A8t9FYAU?L@+kDKvVs3kjRv z&{%6X5?1HaxS72EK^nK0_ZN1cv4!k6cQ}n5@bgoX!c{Hz%9A3M_cLpI`H4y1`rBH|yOph>H6#NTqDiIE@TFAt$fM;FAOK1CB3 zE5u74Ht{o%rNsu*B)l2oDf=gCAb!0qO|o7fer11}6yHYtl0!79K9Bfc&1ur}AmV3! zLzC}`_(|JoGHNB_$F`-(q~8!ftdu6Rry#!nKQvkR1LAvX(d4gQh_6kf$%azIm(Hij zjts=-KcvYa=~rd|P0qL@K5-OHu9_o0QqF(BIpTxmJTKlO-n*72pY9;uc`Z#FpF+Hi z22I;+L%dl$O-)uHzWo%M+RQ|Ji;FaM8;+}T4k?R^(<$J)?z@G->g>qOHr8xXf`HchAeintB`(sb@< z#QoiYri-QBWo0y#b!Xy!TSU`Mfry)Rho-wM5jVx2rbl!T_hSuB&)!Ge56ftJ?Fixq z+@tA(e-PJ8w!fN=xVkEuX$(MI*&>?h79y_T2F>(B5tn62GqVneODdw7T|>l0&7zt6 zEyM+%rdi+~#QC(QS=3_0xg^poMfzhil4iM8h%?(tv(gyEwSPymt~Q8k=}EJ`+K6jZ zOS2)@5&QXfnvLCt*w^Q2Hg!H?pGZ6N1|s%OEX|hWBKFE4n*HsA*t7r8Y;zmL9=%I5 z(e<(WOlfvxA7Zzq(d^s;#BLZtv+IKpyJ|hn9?Ee`@6qhF2V#FSrMYG^#Lh~lx$aHG zP998iy)B3xyOQQ+KO=V76`I?1L+pT7H1~)?Y){ZU$ON&q-Dn>59I>TyXr3bH$=^@& zTk7ns<#yY-AeE`Xrz*?p20dVY{k$!KAwgP3(Dw6Hyin7=>^_g@jS zxP%sg-4Qc?I4zK_Po%}!W{9z@q{Y?ah%p>Wi~BPX(|Q&yUKSyy$v?FC+z~OF2Wi>(E~4Mw zpktYEh7dYdVeh~lfn?aeF!Z( zH9+*nskH386Vak8ENey}df6sg_KHUIZ-;3)NC(lguF!JSZbVOhM$1Vf5&dIBTF#C_ z^bhT5xv(Lk2Uyec&+Ulr=}pV^Ll9jXMa%6Wh%U{f<$?Ez&M%?msr87?=t0YWdm%bu z5H0VzAv)qmT0VP#=)f7Y{ID3&o(tGPrv%ZCE7_ry38Jkwv4i0mL>upB2djyQZhMp+ zoZ}JQ^gKKGY9YG8b#@5dgsArq*de|rqMpBC2jR3u-T%N2;)|nhG+>9ynTWcm%MRb9 zBI;yob{L?8sDt|KFnlwjcABum_-_y;I=sUS8$_+PVTWHYAnFeXc33_EQ45^eVNC?0 z=D4$idWEQ|p6sx9DWZPzW{2Yih#Kz84i{S>YM>uG+}w(&UjFRx_*+EP$?IDyM3wo| zO6vro3jAo*Y&fDaeQDL+6H$rYv@*Yrs7Oy**-u7PkUOnB!w}`=LaU(1h>|*+RrFj$ zb+n;XY67B6I?yWj4Wjf+X;r!qQO)#e)in)K4O`Qy&qqXlXiBRgOAz^@A+5${BJ%!6 zT21+c$m=g@HFqf@FFd5x;tWKdxIwFx9}p?LM5~R95V_+Rt#+m$a?>7K9eRz(e>T(V z%zQ*HUq!2{F^K$qA+7E`Lgeh3w0bcOkyFOe>Qf*he;mS&jjkf{hi}=j^(aIRC}T%s zCq(wlX2*`l5Lp|;jxN0sS?bG+Dz+i%5@S?D)++L^>#T9PlF|J1l3%5z?;Fbaotn5Rq+uV81&?;_c8O*|r=xv-!2p1q?GaZQ6Ak6R<+++B8*dQ!wOY5!(1BKB=y$44I! zvF#Ujd@}n9*6aHsLf@X&+nXYy zr4FqR%tM6EHCmr?NBAd2>&rV4{%RJj?_?wVQ7>9Qy@T*uDYSmy58;>XX``)+@Y7nf zX)zn&hc3{@z!BlQR@26E6T-LrL>tF=gs&;1jn_GZuLz_~NEN~twx&(YD}>LvLz}eW z2%oxzHuPlO=)w_0pYFB)8_d~gg04Cn~%N-*X&JOoh=A^8&2C+5eR$Qg0_Zx5q9T1ZLN|J zc4Z-LosJ{yY!BM{WFzcoAZ>9TVSBY{8&`-h9-(de6@;yuLEC~7g#Fc-w&gbww%Crg z-763_?+IOSMw1TB}lt-0-;ZD(=OBo zp?4S1E^Zz|uXdqbMtg*wGoxL>c!VB3PrC|jgzlY2yY2%Kx;2${-#tU<`lhs#>k9pA z7wvw$jL^k{X*Vqcq4WJ{H*YUOe|}24B|!)szm#^XRw8tyw7ba)p@R%*w{to|<+|+- zH$iCEk+eG_?Uo18?#d&C7CfWfy<&uBE~ee{qX_&1LLL>-VRRBg zZhoS}q(2aHX+9lhH$})P&|yI}LJnT0!-_o!+4(&k)>$KDvmC#57()KpK!<&o5wg4! z9Zm!y`aHp((agjba=BEAw$dPsHKIF?>^J9X+A=F%%r2< z8iZ7N($TC1LW&R3(Y691ohs<)rVx_+iH-s75fc3~9V5CTB*cY|i8~SEy^D_7#t3mP zpkwhj2{sOH9*ky2XxvWhoB2R=yYNNf{wqS)5Vhr+W#G$ZW$nG+j}}aE=14<>DQZI z5VT5z&YCw6v}7oqo7y7imj-m!t47fD;dC}#j-Uw*>1^{5K_lgFHx~pAlI{N85!8Da zox@imsH-NO6P_TbY%ra(q+j_T=v*Y*Gy2iFas`6oU(vb80|bSCOXvO$2=aeK=N~E& zrPdx-?q|s$yGy>zd(PhMU2n=_n%Xn$ee;!?? zpGTm3Q@Z@x6oGdA=&~#jf#x^q@=q-S_0#FHc@_d&D7x(0hd>>Bx*UFufR9t@a@HCF zFFw=dY6b!xRMX|&5CmL5L6_$%5O5)gE+5Vz;P^ti>S!Zie{;IFbVGoAKJ03ckAU@; z=xR9<0V^Zv>aY?4iobM4ZZ~x{7o2+gMJuYV!H zcO6}qoj`!AK3)Hj>#*rd*DXc}Fg;Dz-N6WG=S|lmoe|J%DqYVGLqLOPbiKL&{_j)h zdT$r}pZ!7C=eOX0uL)g0>cIbMIo)(@;D2@--C9P&|EMY549elZr!U=I@miMPWf`4)t-F}t+M9Kck%;6t&mu~;~ z!rv>1ZkvPZ((TM-__vn+Tv-DD#;56aSHWMymTu2Z!0)y6 z|NU+FJ=#O}hVS8bt3BOYw1nTKa=PnxfZxe~=x*T+zk`}|w~vM2jug6k6&jqV2%;Ahi^?x(WgXS#{*my6-2_nGdutKioxg6>bgfnS4Bbbs3)zVG(aLu(j( zpEajP)3NZqn@SJ8N$|ZgnI5Jy;Cto-J#6N|_lO=nTo=N3cNRVTmce(+Ge=D z=n=mfzJJK}jP>ySJ%b(vo8c>Y$fJBKd?y{DN4FjD9V6}c-38wv@$?w72flqr(PPX$ z_;%YtkIDPtTmFe2vk$nC`BY)7xA1K|B4gkE|z@V;M3FVh@& zUzGb;D z7~X{&==Fydyfe?!YxP}tC%mWEmLu?vFrnA(HSi7yqSukx@RsN4b#@56?FP{6YB{{k zXVL3k9K730f1f+UyZLE)eP{*mhR-SgApfVl2iZp12eL2a7|5}dHXv!XHOXekg-4+6Oge%86%LfLK!oVu|pX{kg-G=Q;@Mm8Do&K zMj3OEu}2w$kg-S^laR4V8KaP~N*S||u}c}lkg-e|(~z-E8RL+#P8su%u}_%;khwsa z6Og$5$k?iSdwFPl@@E*iXp;kX%5?36R`C$q|rTLCG1A+(F49kX%B^ zDUjSk$uW>zL&-Ui+(XGhkX%H`Ns!z`$x)D8Mafx^+(pS@kX%N|X^`AT$#IZeN6C4R z+(*fQkX%T~iICh#$&rv;Ny(Xz+)2rykX%a1sgT@C$+3`JOUb#A+)K&9kX%g3$&lPk z$5$w`$?=d}Ps#a^+)vQ}5G_E_1Q2aN(FhQ&K+y~k?Lg5G z5G_H`6cBAe(HIb|LD3u#?LpBX5G_K{BoJ*v(I^nDLeVS`?LyHo5G_N|G!Sh=(KryT zL(x1C?L*N(5G_Q}L=bI6(MS-jMA1wT?L^T~5G_T~R1j@N(O3|zMbTUk?M2aG5G_X0 zWDspe(P$8@M$v2#?MBgX5G_a1bP#Pv(RdK8N6~x`?MKmo5G_d2gb-~=(TEVO$bg^w zK(r%8LqfD9MN>kwB}HRGv?fJ!LbNAEgF>_@MUz6bDMh0~v?@ijLbNMI!$PzyMbkpG zEk)x(v@S*SLbNYM14FbhMH54`F-0Rov@%6AL$otRLqoJQMN>nxHAQ1Xv^GU^L$o(V zgG019MUz9cIYpyGv^qtzL$o_Z!$Y(@MbksHJw@X~v_3`iL$p7|13dcngZhfOrjx=YV(*iU)ys5sD{)coT|8fp`^)XMuPZiid%C z8H%TYcpHkxfp{H?=Ye=1iU)#tA&Mu0cq58Of_Np0XM%Vqiid)DDT=3pcq@v>f_N>8 z=Yn`IiU)&uF^VUHcr%JegLpNHXM=b*iid-EIf|!)csq*6gLplP=Yx1ZiU)*vL5e4Y zcteUugm^`YXM}i1iid=FNs6b0cuR`Mgm_Jg=Y)7qiU);wQHm#pcvFf;g?LqpXN7oI ziid@GS&FBHcw36cg?L?x=Y@D*iU)>xVTvb)cw>r3hInO)XNGuZiid`HX^N+Ycx#Hs zhInm?=Z1K1iU)^yaf&C0cyo$Jhj?|0XNP!qiid}Id5WipczXuV(}#F{isy%Te@YDi zQVXEe1R%8mN{s+gE1=X2AhiQZ4FOV1pwtu~wFOFz0a9zA)EpqS2TBbBQj4I}Bp|g3 zN{s?itDw{@Ahioh4Fgikpwu)VwGB#*15)dt)I1=y4@wOLQVXHfL?E>hN{s|kE1}d( zAhi=p4Fyt5q103$wG~Q@1yXCF)LbC77fKBVQj4L~WFWN}N{t3mtD)3vAhjDx4F^)o zq11FBwH->02U6>y)O;YdA4&}fQVXKggdnvcN{t9oE27klAhjb(4GB_9qSTZiwIxc8 z2~umK)SMu-CrS+pQj4P0q#(5^N{tFqtD@AbAhjz>4GaH=qVtZ|f$+aLr77(piT3<9 zR9bXCDnwLNgt9kx&*yor?7jEMp4mG)$4o;;$t*3EG&EF{^n3sQ^1{8(xFkO3ocEhs zmbqyKw=Hwy3T|EI<`vw&%ndBKg_)aJa2qo>vfx%`Zf3#l%-qm|TbjA41-CVGV+(F= z=H?dM-pmayxW$>9TyUE+H@e_fXKr@E?atirf?J-s=>@kvbK?tcedgvD-2TiBFt`Pp zn_zGoG&jQFR%mX9!R^r85QAHyxhV#>MRQ{eZjI*V7~CGs4Klbznww;Bn{<^jgM(Y8 zxmgCcOLM~vZkgt$8QeC_jWf7)nww{E`!qMu;1+6bqH)KurshT(+)B;OG`O9b8)|S% zH8<7Zw(2UKuMKXk=H?pQUd;_QxW$^AY;c=3H`?GIJ<;8tyJ*1_%C+^~aNwz+8sw{3Id4sPA%<{jL=%?&)bg`1mra2q!_^59l( zZsx)5+}zNETe`Wa2e)-|V-Ifa=H?#U-pvg@xW${Bd~lmLH~QdKZ*KO%?cUt*gIm72 z=?AxcbK?(g{pRK$-2P1l5M%)+69}>alMw`2fyoSl?7(CQL6%@Lg&BUAtnronanB3 zo=gT6WKkxQ3bHAaQ3Y9*$*h9x%4AqUmSr-nAlot-SCDm?%qz&gOa>NYVI~s`vN4m9 z1zDNN%!2I9WN1N_W-_%PTQeD3khPi2Ey&(X1{Y*;CX)-YIg`-^S)Ix3g6z&@ctMtD zGQA+%GZ|ly_4(-o-v`;B$pC{a&}4!^HfS=!AS*PPVUQh~3^B+OO{N%RizZ_XvPP3R z2HB&@AcHK@WRgKPX)?+nt2CKqkX@P#GsrScrWs_LCgTjUPLp{C*{8`sgDli!qCqxl zGSVO`HJNFUotg|a$Wl$F8f2>`V-2!aleq@jtI1%4EY@VQK{jhL+90bnnQf5WnhZC{ za!sZiWVO{N@V%O+zEvSyPx z2idd9po1*hWYR%4Z8GX0t2UW+kX@S$JIJz4rX6J4CgTpWZj*Tj*|*8SgDl)+;z2fU zGV&lRH<@{motq3j$kI)w9%Sn#V-K=+leq`kyUE~#EZ$`DK{jtP`XH+}nSGGmn+!k5 z@=c~6Wcw!L53+uf`3Kp*=>P;>0MiKwx&fvm5Of7hXCUYfm<~bEB`}?Wpj%)%20_=r zbPj^3{@X5Yq_>x*?_`5_Cme{nU}5J7PK{L6^jI zN`h{Q>6ipv6Vo{fx+kWC5_C~aCne~nn2t)&RWY5Fpu1u^EJ2sWbXtOLi|M!oT^B#o zV0zGfF&&to3u8JlK{v*9WP+}Y>C6P(8PlN&x-_O!6Lf1#$0q37n9fbmy)hk}po?QV zIYBqabaaBQj_K?K-5t~63A#L{(-U-iOvfka`k2m7(ETwTpr8w6Izd4<$aI8)u8`>r z1>GUjAqu)grc)Gji%iET=o*>MQP4dy9i*U(WI9PfH_3FAg07P3ECt;q(_sp_Os3Nm zbel}aDd;+x&Qs8RG99R(3uQV{QN9`<-!UV~S1xNhQ$csibf|(ZmFZLk-73?u3c6OV zF}zFAy)qrFpo?WXSwT0;bhLu5mg#H--7VAM3c6gT(-m~POvfwedYR5w(ETzUu%HWO zI$=RK%yh(pu9)eJ1>G^zAq%=>rc)Ml%S^{C=$e_%SH_dd^g07nB ztOeaQ(_xEpmA08qThMJY9k-zCW;$;{_sw+RqTH2LOeZer#+i;>(3LZtxu82|I&?vo z&UEU6Zk_4a1zkJSxeK~?rh^xB@k}Q#=;oP@UeMJuoxPyDXF7aAm(O(if^MJb_yt`* z)A@_*yX-a{z@Q6gI)Onq&~yZYuAu1*2Hio^Aq={Nrc)Sn3r)u`=o*^NVbDD^9mJrE zXgY~OH_>zygRY|KEC$_0(_sv{jHc5VbQ?{_G3Yv)&STJhG#$vG3u!u$K{wKLB!jM` z=}ZRQNzAVKr zSJQzFy0E4b8+2n$M>gonn$B#{oi!cWpi65ywL!PmbZmpJt?Aqb-CNVa4Z66dlN)q% zO-DEA>YC1O(A_m1-k{5CI=w-+*K~Y?uCM9*2HjuN0S>yrrV|`=gH1;`${gYIK6)?c z4x0{f&?PpV;-Fh>I>tfQ*mRDA?y>102VG>>F4i>YCYz3O&{Z~_<)FK4I?O?r*>swN zZnNn)2VG~=c@DbIrUM;xp-m?`=ti54bkLPHo#~)EZ93FJm)dlygKo9ySVx(%O-$!H z=w6!+cF@H(o$R2S4QBX`xc0=Orn4P%w@rsT=yID*chK!N9q*v)Z93mU_uF*9gD$w~ zga_Sl(-9B4;-)hmbjMAHJgyyL($ z)`RZ4>97Y~cGGDOy6vXp9(3JJ=RN4Yn+|-?g*Tn}pc`*G@fY}TL+X1s72(|=fQxI$m%*G(t8ko&NustvvgkXzc zHVMHt!E6+Qt%BJs1lt9(VF`21$4gRO?yYy{g4v*8G~ z9A?uIY&*=xBiMSF%}22PFdL9y3t~1Qan0>E8s*X7dwlfBZtKe6R&Fo1kDDWHv&*9Ig6)vm5CvNz zvndL;MP_3ZY>mw3DA*pE4N|a0GMl7en`Aah!B)v^mV)h)*)RoLCbMY@woPW^6l|T$ z<|)`dnGIC1g)*C{U>jvNQo&ZrY^H+kl-W=PTPm}u3bs{dV-;+z%;qZCUYQM6u*EW) ztYDkvI*%R-wpwPh6>PW6hAY@|nN3%)?J^s$VC!WzU%~dvY`}sonAwB{+c2{c3$|ir zGZt*e%!Vx3l9^3euq`tivtVmxHfO>1%xuttEt=V+1=}>UQ46+eX0sM-*UW}3*s_^T zTd-|28@FKVW;SoZ_RVbIf-Ric#0A?pvylt7a%M9ZZ0F2|F4)qUOE<@PaL#+2jS=JhRaYwt8l>7i{;;hA-IinN44??K2y{VC!c#f5G<8Yyg8TpxFcl z+d#7s47P%1GZ<_K&4w`85}Hk6uq`wj!(eM@HiyCX&}-47QkNlNoF?%|p6!B*I8hJ)>}*$@X?VzVg@w#8;+9Bhrv z<~Z0Mn+b@!Peev?t|^U+299Te6z_9 zw)tkGA8hr_W_I;Lcl^WOoV`qU>FGjE5R@m0(OF7C;2_`O<@=n0jt6= zD*|?fVORt#3&XSs*cOIy5wI>?|HkVA_Jv_!1S|~0#0c0JhLI7lG7K{#U}qSHM!?cA zOpSo8VHg_$Yr`-%0``Vsa74)?=eUL30NwIsS>bN3}Yo=tr+G?z+N#7mVm`#m@EOC#V}d|R*PY_1nd^Wa0ys0 zhUpTpT@2$TV7(aTOTd0H448lgW0)`j8^$nV0#=M+#susb!;lGBGKMJ=uw@KmCSc7N z=1jnzF$|i3MPryW0h`7!Y64b`Vb%of8pE&&ST=@f6R>Rz<0fF;80JmDzVR!cb_rNG zhKUofaSS6TVC5KQPQcDF44r_b<5$i^z}7L0oq)Atm^*R7vt0~>Ct&dyCQrcTF^ryo z)nk}F0lUXAd;*q_VfqAYA2)dXi-7fGm_Gsg$1s2b7LZ{A1#BS02nzn$?gp=Q3fMu0 zAr!EL3{xmz3mL{xz#1~lp@2PP7(@Y!$PIcr&L7a!Fp2_Jkzp1E>>@W9doW-b8KzOd zHgbbm5wMO7^C(~+83t0oLNZLGfQ@7rNdYU#4Yn-_*hz+=6tI*GQz>98xxt}z0c*)H zmjd>Z8+?Ctz+y5?rhv_47)=4I$uOG&c9UT^1uQ4SbPCu`hVc}zo(%ITU_TiKRKS8V zOsIejWf)NbE6OmV0(O*PNChk@!;}ixQid@Vu%--iDqv3;235eKGEAy~O=TEW0jtU| zs{(eFVORw$E5o!3*j9#d6|k-h^D1CpxnbW00Sn6whddXsu?!VTuK8F~b-OSYw7c7O=+* zgDhZ?875i4CNqq(fK_IgWdXa)Fw6p$nPHj*Y%{|+3s`4{c^0tG3O|Q!QYt8OB<`S~JYGfW78M{CN+H&5cHn4A^Xj(H5}U46`j@ zx4F^W3IWT_Fx>*Sn_;{KtT)4a3)pXl0T-~~3==M3!x=_gz=|`>xPTpJ7;*ti&M@Ty zwwxRNkQuP%40A4E&lv_?z@jrux`0h*7W0jtk2`vP{KVfY0sKfl^_MZoqmjK6^OXPAEh`_C`{0~VlR0tReA!w3vmfrc3v zumcT4FklH9reMGpG>pN3HE5WF0ejFe2m=ogn(J&bUHltxQ##xCihS?af8x6xTU^yD5W59OwYcHP;SdWJJ7_c7=12SMi z`n7g<2W&{ghzwYfh8Y>KBmG)Y{eUHDn34fo(l90i)}&!h2JA`0pbS`)hDjN)DGj4C zihnTKFe?LgrD0eGEK9?*jNk_a^-8g4Qz%Dfm(|~1an5F^S)G$s1)~Op0EFQ2= z4Ffe`p&BM?z(zHU)PR+0n5h9f)i6{8mZ}>sp=$B#>xQu^SgVG)D%h)r!75m+hRG_} ztcKC5|9Va~%vQl}H4In5ay3j>!FDx_SHXHU%vZsFH4Iq&SNy19!U{I5VZ;hntYO9q zcC2B@3YM&!Tz!sU%eqO~YJxRun6rXCYZ$bGMQfO}f=%lt6+^IU4YO9TYYoFzuxt&} zR5M@Fq7o-cA3E4Z|cB zY+}PG7OY~!EY?5uhZ}~mU>O^xv0xj!>6Lx;&y}CMX_=+^`^;Z%dcz^XLN-if!A3TW zWWh>y(+6MH-{iDSA1e|pWy4e!Y-Ph(7OZ7At@V@seqpAYzIeG{F}rDlM+BSMO`E(b zSj}$Qs(rNL4AWVswqI-*&w};rrmvr?Q&aA7(;m0$RR2nb2`$*rh7m1T z(QZ1bw@%e);iltf3YN5CN(;8MVN46ww3{yYS0{fN?54}F6)bAQq!w&y!>AUlYQwA+ z>}tcX7A$Kw{b;gaTf6E0Rf2WxriXXyWR-W_^vL&ug>9JFf{kq$*@Bhrrhnb5zmD#6 z(|@Z9mbPJP3%0glYzx-5VQ%ZMp?rJQXu;w(Om4yEHjHk;>UOi+cj~W4_Zx<{V0jy+ zw_tl4#FFopC!5&M!8^>yIJ2i^~e5phG8yP=7wo5*ye_DE?DPoHsxLY z(Y2zR&Dtqg=!S_d*yx6lE?DVqw(1N0ar;TbP!}w9!&KLae?Bpcb-`M9vt7q^V&@V! z+xwefu^T44V6z)WyI{4u+0j3BqOiGPxC@rMVY&;pyJ5WRM8)!k`K}Y?&vWy0`TX;L zar29Q5o~zFh!?DQH!uCYet&0%o0t1Wu;dL>Ua;j2V_vZ4-TeN&`aR=OH-C7SV9^^U zyyLqCmervVXF!TjW-!SzBTi-DD1#92UhgQ&U7u{(X{DQ@AnEZmxZy5c8)$itS z{-$4-4K@sa!SXjuf5G-QjDNxUH_U&*{x=Q){aV$=2_W16#t|S~0dBtURsDKaWjFt< zns5mir+{z^7{`Ec4Y>L7v-HcHUdBNnTm;5RAlwATQ6O9e##x|W>TER*1K~0-P6OdK zFpdM^I&h0}6?Octf864hGQx#moCv~=U>pg;mEaZ?H|hA~JKUnu4B=8RP6gpsFpdS` zT5yZ!p3(8@wcX;S+k}h3I2nYS!8jU(tHCW=ZPL#_wKWb0;c_re2jO-wjtAj-aEneA z_4CN2TXervxFC!ZLbxG}BSN?$++xIJ{amS=TZ~HxmxOUj2)BfBObFM6Tg)q_pT6qq z7K`@@7lmYXO2ZnHA7$=5s zV;DzL%1}IQ$x5ljAKK%HjHyaKX$&+I5>oh!#FvFo5L-y9W7iP zZdtyie&n8m!$Y_{jMGE7J&fZ+xIWzS;i3BBgSBp1xsh;z7$=BugBVAMaD}+#bIbKZ zPRcD`DiSUc;}j8Y5w~o5fpCquWviX~;oAG%vco9hA~8-9;U+PT65%Rw%c8G@yTmw5 zgv-P@O@!OTI8Jn|(*d^}{)3LS>E@PW=L;8#aiRz}igBa}SBhKC`BBG8@p=}`6D}3w zR1t0!<5&@{6}Q}QMBgu4=$7wH6)qOH+}>EYS&XAaxLVwD-yVJ6=n>;^5iS?wbP;YB z<9HFS7q|R*jlM6o(k)Nq3KxuV!U#8val{B$jB&>3=$rQ%hm3H^7^jSI%NWOuaLu?? z*>oL!Zh~9gbfa+57$=Qz(-=pMaMifggOBOE6UB|gM!0N@(?+;$jN?YQZrrNozxwWt z#>RmoTsX#wBiuN~kt19=Zq;n1zN@mtt=hB}E*<045pEsh*wMHD^7w`A_3gL+xYg@d z3Kx%CQDw!=V;nug)#Fx!FW0w&DjSE7aQPUgk8t}K$B%IR80U|0{}>05Z~?j1qW^>& z$T)(8E6AKMR+TaS92ykZ}wN*N|K7-mh=E@VNVmgp0^HiG-WTIEsX; z$gPex(Kok#ZyZL#Wn`R2!fj+6N5XaFR%Z_B$OmWKxphyOvce9TupBM)b;v${rSe> zBwS9$=_K4v#_^=DQ(fG;L4m$*`L|m)DJfh~#t9|dP{t7@Tv2YFu}xoJ@U?MB373>{ zN(r}=aZCx z2bgey87G);+~qc}*Ap%^<5UxFHRD(lt~IwAv_^+>r@76D`*rxW|BRDOxY>-O zO}N_JX8I5vzV>qCa1$;!<8%{lH{*B{t~a+?{i;4&pLCn`+l33xIN|i!FrM$dg~Ao* zHapAdvzGhaX3rpf_T0V3DJR@=#xW;cb8d5FpFX>QA3s)2xaf?NPPpleqfWT$+~)7T z`gCC@Cnl4 z-S+N>b?B>F#;K=6AB;7QJ>lAO+e&S8Xi^2Yt@6GO^?BVm`GlL#IQoRE&u#1cu0u~Z zHV!}G@-t39;r26*KjHdw+cpUuJlfT5JMI@QK;r}yZb0J*6s|zGE&5#t2aR{zZgq9A z;0xmv6mCJ|7!ejVtv+HE)X5iUgIL=e<2tX`GP44QU*a!WHRuw++@l`jt2&g-g;nC52nkI3|T_((Nj();_+@ zI4FgS(l{xFo6KxMEGY5^sQn)OQ(^9xCjpI_dF5Ry6AKE*8oN-_Z7p8Gy z3OA;4WC~ZN+ZCOoy)|Ai4o%_GG)_(7)-;Yy;o5Y&p%>|sAOCf`QMHAO(>OVWo6|Tt zg{#x;W?raIhRrYzPvP=3PEX%W<`ZUf@;r=uZP~ieKPEg?nHI7i>3U#|3KWfjx zeQvksHsKOAPEqYyP~JF3g=^I9zTT-lU0N9jsc?}RC#i6g8b_&cmAc)@x!QB{F}M5o zbKx>IPE+AFHI7r^IyKHy;XXAERN+E3PE_GWHI7t$+{12vQ&oMOcF65-&l4_H<5U%H zRpVF{u2r{x8IM!>0pVgbPFCS&HI7z&w0)%8*IJ{G-dbQBuEOPNoUX#{Y8zDpzFmNkx9;hJ^( zes5~`w7G6Sc)M`X8YiuA(;7#ub~irk_LCmdZvK46VJlp=Za=$=aN8Qkt#IAC{nE|a z^}}6mzw(H1;Tk8daN`l(+daP7MNp|#reV1MJ_ z6)s-m! z;|Lb6V0S3}gLalb><;CM3zx8Q3JbTeaSRLBushr%?bv+GIEaOd*f@!Wo7gytg{#;d zp6sU`ZTYtP8^UF5oW|Pm7(ZWUjc^^iL%sL4qa>f-=zwq`8z-`GBO6Dua3#A#hqLq{ z|6Suy7A|GuR2FV!<5(81Wq0UYK_9-v>+exnxR{NTS-6>vqgl9`-C=kGZU1YLaX1T? zvvE3W`+Jj&<5{?#jq_Q!pN#`rxS)*_TDYN&BU-qk-C<2XZI5QgAuU|e#wjh_(#A0@ zT+{BbW28R#`hV{5@hIV&>j96C|uaai7njN#*r;t+3t8@7rnour8{1d6fSM!)D~`SW()z5iV}yiKzZW`7p`!3Z1}a_d+mGU5Em|S;}jQeapM>lu5ouvpQZPT6}n^2DB&VEPIBQU zH;!`QDtE_jP4({de~rUjxXg{yT)54R<6OAT-Eq{VdiR-5?l|rr;X*e~bm2xfj&$Kl zcgNW)we8sN#-T1;>c*)q-0H@$E?n#GxUQbI4Q}C%8!HJHyK%A$H@k7P3s<{4?mVV# z72Y=vcj0n3PIuvUH;#AVdUwaK3-rz>ce>-z2EqkzobbX8ZyfQ$74MFJp3*ys?(X={ z0pXH2PI=*$H;#F|^T2<`Ij?uF`^Y%xg^S)e>4lr#IO>I~-f7n#(N}IwUbYm?HJmUlRztN%TwAX1<+LPIw{xF!TIV6!eEce>^=P8a`#y78-+Q!q!wjblJgv=hIyi0E zd)hp_g40Hi*5=foP8;7+n_I4R+LZgWxpr5l&G=iJD^_*doUPhi?tG^$)7+5 zHr4*bX$OXDQ^k=^J6vCz%Dv>YughrDd6zluyTjUee23G1oT82U2RiN7mfE%!fAAe`DC*$! zN4si6s~epD#ADjP>rH?1H*Kic-|5xoYC}0Wy;gH=IQKWF*C{O@pXv0McgXu2IK5#{ zd1FbZH+f9v&*AhIKgq*0o!)k;T*Tw0)stK9a(edpqQvU-{55jL`<0Pdu z&mH3Q9v^D`@h6<#_jRq`_k+_1A%EX6*6G6zY5kmPP9NQ0>xc3D;~&xb)Fh`*KBDz4 zYdU?#Fs-lkhtuagq4f_(BY!=_{Ym+dofq`r7aG_CDVKhM{`f zKRbQvV|sh`Xs5sTrQROK^X}-Yx06Sl{_%Z!yTt&f@B2h=*Q((3PmA>SgZrHR{hQVeebE`kM`&H* zgfq^4Nb8!9a>j*wwC>r5opDL7);+M#8CPD;RI|_-r59^miEEs3{qtJ;;|gco_=DDd zQqLK;_0ih5`TVW}(6V?aBtUR%x?Lr!Y-^rg-i*;}gzR(Hm@E44cBfHNje)9S`)&X{(eR#!XY zj9F{7`re_=nD>lUUvr}~7JZ~u|M7Xt8*A0kr=79tJFVLFu`}Mz)~eMloU!q5t(y9) zGv4X0RsFj<>Q?5uTF5rp3+)X^)6@ZpQKg)zHnxx;aYJ=OJ`QOP%AF| z)|pj%=&e)joLS>3T7GjS zXHGq+!oE2Mmlrl&ssLRq%+sOqGg@C zJ97h5=ZJo(BE12-lHYg{^6_#dTYs9&7Ae{=UNQE zJ*(0qTKsWEXT@MGUOU-YPk*DuGtPHbjY?WPFxy$RhiNhYJ!J9s_{EKRUG*N<;%al8 z)sTMeb*1?yxpgpha@F*>)yUtl(?bCwCuX5IR*J!~_na=v5ffii2%~{9C zX#VdvIP3Slntv$atdm!2{^p&|I{l*N&%fQ-#fE79$k&}+V!P&d+T-jC&e#0bcR9OM zRn32{i?c85qWKm1@vByAJ~?vswZCirxqN)N|7qUOyPbVgE6v+?i?eT=pm{EI_Fa24 z@6Gp}eP2n<8(P-c4?d}Ri412yQlNRw?CeVOHLvES&WNva3e9ir6va?@4thsA`a(2T@GXEzSb9njC&%`-JOcdxTsPuASm zZgzJ24>h-HrnA%k(cJ&7b#~63ntRoG&Mv60Isd-s>{NHn`DUWCJ1^9n55IFZ|J}}6 zQNh`LN@&icB4-b{S95xAarTf`G$*r^vqyB*oLA~Od(3Rjp}(CyewXIl{*ALI|D`#X z{?FMn%4zn=9B0q2s@Y$xcJ}=Cn*Ht>XD=SC*-NTAd-+n$9>?okwO6yd?Qr(GQ<~l3 za%XS6PP1RE@9eElX!hgdoc&%?&A#bVXMfm5vrCqD_U_4g^LM^3pIC1mn(piahxO*> zBhLQpwBDS5tFyl5=*>>EoPF$Nz1iwpXaAg~H=pC@e;cSbE4Fg>pR@Gl z^?d%{8};TnUpo8DLCxa7+nlpbXx84>oO9kqnzeqMb4uQ#S^PaW=aR~rHRN*VT=Al2 z6+Z8rYuam8(|*pmuCr!6v&A{(M`+f4|2gO8*_u`QG3VUAPP2;TI_K`4nt61-bME^} zGk1OCoCi;6=IV0JdGs93oLb*Gm9N&!euJG;<#x@?-s+sHk7#DY)6S_;T{EA0&^fhV z*37%wJEu-d&AfcFb6(EUjKB9dr@`x*@%07Hd99yjd?4qLkIh(?0X=FDo>);U?#tn6If%9(B&i zshWCMDd(IXt*Mtk;M`&ZH0AGCoLi!^rhHZ8-1DGWBANtw353bkbEf+iYk-3^Y{~qU78l}l2Ydbf(YI3Iz&V9P0Cb#PA+-F|a zxork((x9Hs?U18M`Mi&e`kK^um2-0*)1+#)02shYUsS?Biarim+>J9khsP2{eZJ1jJ@_h9Fax?U4AW;l23-lwaiB9S1bwJUjQJg&KdH z=iA#|pQv4+k)Jy&lWZSA~b3B9o^%XuZL>5WxI&O85dy)mV? z^GbfEH~J2B-X(MNM%Ek7yCPR_G??MMYo5>>RTen!y7TnL9V?tyZkOJ;biMO#8mn<9 z-*Mh;%{1Mq&(3stP+i8);tmfmow%3@cd|uC+G^XEG&g*kfW3sPs-hkm6)9^Cq z4XLRyPhRZ25ydp-&XUd>y+UIyJKuS4bkyimC7d_u295r*nDeH7qS5c3cHYds8V%nf zZ%!qR9{Zc~=KrkGU4L}m;wc*4?px(s)GwQz2O?+G{`6d3=$oR+k=TFqg+kbTaMNewvC7(I} zlCL%5uN}_6qL)T|Zs%WfyGCqVfzjc;IwC(8p zJF98L3k{wBKR*AFXPke3SB)rN(fJQuuMy|n4d2W2>bQol|IYbO z_0#ZKA3MML%^E(K=c~C+!wcp*|G9b^-ejcn>-?nQ)w?*Kf3FR{x4rWlT&Lkzzv%o| zmuT3T%Fb{4jD~%CtMglYs$n}yIloPohSA5%?@&U+Ch~sL$7oout(syV;=84dm8Zs+$Nq@kZ(>iqs?HFOJ)H)yVg z&OhM%VUK9&$hVz8a*Kw-Rm&e+M?+inbpH558d|%p^C!2_(1)IN{V_? z@$)w=(~zexbN)MzYRFxD{(I{*nmy)%i>}n5 z8kf1?l7Sj@-}f%KqJ#!rv%v*dr!?@tF)q0FR}K6w-38aT(ZHQmT|h5v;L0*CxTTH; zPCD*_+c#@q@2xJl`wIt|oQE~q$218=+91&^N5z*5ItP&q>b z{&?F3aaaRB8|s3mpVNS?EnQH3tp+Tp=z?eO)PPavx!}1m8qjIK3+kS&0j=h`;N?sW zsGV}bD~B}Tp;|6@wYmnBz0L(q7Hh!SKe(Vp8TJ2RtqWTBQ2&qnyP(~V>c6(33({Uz z|LM28Aakwy_y5BMxi_glUbTXPzUtp-mVMbWF6g>a{mFp~dS0h~ zr?$ADPiOV}lGoY)OAuDCx?u3r>bK-J7Yv)Beq(=i!Kic8uj@J&jBTxcUZ9J7tE3R9?x^Z{5RBhUu738`b&LX!UfA-RNqT~2@7tj;xvwfor_H0p~<-DH#{P={LE;y8-K0Qmh;P6KE>A1@UUtOg>FY!Fz zv{j!<^<8juwffv#+66zBRG$kEy5RV$>iydU7yLF~y$?2a!5{yq_onhLIQ6W0&-vU1 zr^l)HuqiJ1?_2dwHgn$&jyzUnpkau?pPOTBvUaN#Z2s8_}S7vA1Pz3M;X z!nRR>t#)CBd)2E{%7qW*sOKLQUHHff_5Ad>3m-qFo?GU+P?gnlek&I~ z*;zeDUhl%HR?ninF04^ZJzEZOVXZ3aS*wN%pYNic4;FJ_-Sz5OW|a$H{#QNE%5q_Y z$JOK59WHz|p&q+=KTVda$LdioZ2pUSOs(z0)_1E%zq4G}u8n$R@p&Dms7Hfz7iJt( zk1990Fy{*OxP6}s^J}TcB?DcU=%Ma^RdHd_8g)N>!iAlGRrhyhyRiH1>b~$*7xsEh z-A7;S!oI`Q{q+ql9I#d0Tj#oP@F{iY-xGzy|EKN`@pz+}sC(JIE*v{l-Ag>?!too` z?T2G7ob;Qzef)+Cr`@D(YoB%D%)06}?Qa*(?y7G6`FhM-sBSq8UAXX5b!&9K3zuG? zZcnao;ae5e?atONT-99NF1x~oYX_<8NuGcGN_G7r!-X5aRM&U;b=z7}T^DV0;kys1 z>zF(je(;*QcDccYJ9?;Vo9!;#Jx^VqFLdFa-Rk-U#Z$E<99LUC&9l@bHuB zab&9s7oMn~ z&b_+3@UOb+{PJ!W{+*@HxA46G4$h8qVnd+4OffLvERi`JebfWB3b-L&^C(5r@ z(V-bm+_YOobANE+)}ty)RdC{tGb*ZC=*0i7R8eW3@4h>gI$GR`2cA%BWi=-%)>W!^ zUnd@ItyDc8w^E@}x0Z53{gpiNf)h`US90@EC#ud@a`-MMo>`}4i%Xq&cDs@l`1$7! zDOqf=6LpR$v2(iiv6Zsuf(7TrtiEI_rTkAwo zp$cyK)rropEC0l8PIT+8{LPJ==-FHO{Et1+r@!)>Z*-#nAm!hG!ihmclwXXG8#+vR zJ6~~P#0ce0;(d=Esl4>nPK@K*%151;z>i;4+KI`-m3xTSKW&(D=jJ&vbBJ=2Q=OPS zP`NdBI5DrUaW8b>8>) zE0uZml}`LPOBvtr^*%mI8OvXE;Pj2{;71hb;%1pSK8_4oxJE>rG3!W$x9Y1?Ts!@UOrZ7 z?Z-HIRTrf_y2#1Wt(A7(Rwu8krH*?)b+X+3>NxXPCvUt;9rMq1^5#?OSoJz5Z~Igo zx$7qHv^sqCl#~CPst#~xlK1schps&S1Fh8Ig`|@etExk}{!Tu6i`xG*-pNX5tNprp zPCoIK+7DRcWR(qS-{?IjpPs1pckXwxdP?n1e&b}#`f9iBcPDEz!(IxPg=HW~$ACrcQQDsZFOgPG&r>Hnq~6%)Uu&%49p4`-fV8U*KfHyK22EBx_&n&yHr-|TYEa${UWtG(c8(MpQ_d7K2G+Tr&h!JI@v#|R?Yi4Ip`U+ zx}R@{Ua6M<@#Dk4RLdQF+^7X=IkA_MV-sqb*2Bs1Ppf66u1-!WrIr_Va&pQ(wK$M) za{3gtn4Rb3tafTqnCax4`_-a)dnf6SwYaLKlMCNg^CPc0xul1hFXQXJyr!CWf6mF3 zrPRD`H78epq~Y)H9P*GlWw49>+f`OQyDcIRL;pQpQ_nwS2($CqMF@(zLW1a zQPWeWo&2zzn!bD7$(^66>6ova{Ahxjw%Oz4Cyms!;yX_6FRi8}Ryuj`6E*pGwv(R? zQ|CqK|@D?fGepKf}sH_ylK>(}ZncB`nur_P?F zSAXy3)VVL})lD6ox}bz!9ah(=k}LFTvqzn}xSd|Tue?*2U8_cC&T)!fY@_YRoVq%x zM&oxnb?qH$)M2?(*X>oK$Hq8SuBRHEU*yz{71VHF6Q^!ItcJ6yICWcpHO#-ssXHH5 z!>VUHb@!KQc=-{h?j4{8Uv6=#!b57Xc!pCCex?TOHB%4wR)gnTIQ7`QYH&TDU+ELQ z^5gYRsgqt=^N&+c-lSLh?Q`nsZF;4_GN-Di>6P1uI92mf)&G{Ro^RKA> z$Z}5AIi>n7PCE6{c-614+o}4MRlnFAry6{wdOLalufDE&lNvbHq^#ks)$xA4T-eB|^zC}N`n^tNwbjd46?ZE4EWPyg z9;fmr=%uBzoJv&GOWhJqrFQ70IyIeoy^UTfU&g5}XY}Gvd>y-w(u?cXIMwTJy~tfQ z)n}t#Y{cv6UtcfYd7D!MkE!loC!8A6S#{sp=+yAbRd>{2r$)|D-BvvRm`7CiK|XHW zyQ*9KSEnX4RGnSxoSO8#>P+T!PED###tTl(IA3+1xYnszV^pW)mrl*ORWBUm{m)yf z7v^L;wJ`KT;!&p-f1nqt|L4@Q`g-B2txmo5rJg@Bz^PRo_589rPObSv&v(Ddskb}p z`8o%j+HkI(FF(PlO@sB^&&{0LdbOT=n_uT`6Z9PW&(!-j={fdFsqM4%+?{Qm+If#^ zpS;7V-Ah#aouf|ec}TTK&30<eSbKKclQu-|+p)`<*&kS+z=zbn4g|J$sP%`O_nMcFu)P9bc|z3%5A+TLnE^y|Ys% z7U3BUk{t*{7KdmSEcW+Uv*YxD0U0l>=t)Ao_QPjSSs(iA= zMI95WGNX-)()X%L?)fgtdO%g4oa3ULA*ymIkDGT)arl^v3acp=^m9>iilWn`6b1*e16yY($Nww>QO>kG1W!AUKRh)a8aM7(o1~3`=2k}RN$h4P4vXCm%C{2 zGCko1E*f^8o)}!iMI&C-6R&;cqEQR=#NC}-G`6@Z|9zE<-grrs-(BdU2{TlAOm!Dc z`a_jlA9m5yYO4GYk2igkDxb~Qd*%^U+RfKv_5-Rke0v}}nUpL3&&-a4(v3;Fe1Rb7u)f5t^?hUoDtdA;lQ>;EV^%P=RB zE(+tYxVyWfr9~EVj5We841WWMOf4*TvnnaCdii_jvj{_eVViGf7KzCzDj& z^S)6p`j}XgTSsjVo7iJLbkxXcCicWu9n~u|rhuJ9+% z@8KL>p;WYqeSAxo51lfx&(iDi7aN(_7fp5fg}i>Rrt9)Oc^|#GtjkyUVq)JX)8!Kl zGqE3Q>Taw*f7-yW?x@@LH#u?Ajk*_NmXM$Zia@R@YO!Q7ij;Upwf8^AW zjV~Byvc@_xcYWhb@sBR^`HFF-+N;YPZfu-s-s&=wZWw3!th!8_X2zMZjxJO9rg3H- zp(8x}f7T5;;uQa%{hp4P-PAa9CDsw0uN!BcvN|H7k#Xkhq)XeEjkCa1UHWo8<1Dma zmtK6%IE%c}rF&O5&f=+b>8RtzSu#qOPNIynbZ1@a_I~3mGf9_PQ`R`k?$o6QZ!ymD z4|J(2g^e>Ro-UPorE$g-)+L{0Gfve&m*o1h6N7b0XA0x2JWrRbGuAk(9@Hf>2aU7( zV_o9SVB@S6SC`oR-Z<;z(o~f2kr~F>His_eO<_)Wy2A zHO?-Rb+L$x#@X#ZT`UgIr@PTbFZ1|&-ql5ya67%f>7u=-7-zpEx@c6$I0xj?MU(V4 z&OzmMk=yr;^Y41P$QoXkp`CP*!F!Bz*ic=hN58+OLXDKJTLb)U3ha3 z;~aTh7mnrlkG`o3*MV{V^GX-a%;O&SOBZ^R-Z&>D)P;7tjdN0ZU1-c(vjH1{}|``tvdgr zH^#Yfm(Jg-u5oVOuk%;jY@AyU>->pR8|U_8I^V59#<}yP&bNy9+3wRi-=K2Fx%aHj zS80xM?mwsVrTlH22hZ!gk6IY#VfGt2F6NxhJ0gQ|9y_b^*81BxPn_0yGxEMWbyDYf zRoXbu9MyT4BXgcRtn-ZeV4N5B={$`%u9tS{JUQ1G=anrw_oukVd2OA}eXyNz-dLe? zPuORiw-)N$t_`7^!oe$YY$3hU#21VvX}jADycs$NgC+ zovUPV<9yLv=M3_`dsSQKJpafz-#B#61!ax%T`8Tj`y}K1kVoe%_uM!?rPVnTR5Z>n z@pX>tJif0#bdKdOjr03+ouhx0asIrfb143t`KcVq_;~MTo&A1!BOkviM9LdKOSyUykwZd^$c>TLDS8`mG7 zbhd0+jVswLo%LOB<4SQzXWe_yxKgduS;r+ct~BFy)@H4ZD_vimHSap(%FtM6`RXyQ zOyzVIQ{A|-WYJls%rvg70iC7oQ{&41NM|Wp!nkr8o!QI%|ipLkx zM`udh#keAC>WsHG8CSVHI^(LJ##KI`GY)bXSH+t;Vz>| ze5}*{NN!xMH|ey;>Khk<1!<>EHLmtGblUcpjjLliowj&N(nfz za}9W}Q%A=d*Pv}Wb&|ct_4nU8)$Q-bH8e`6T2s=v{uk7#2KO{B)=8$SyxO>8N9$Cn z9vhdds!sVhvvFAobjnRljBDg6opQt^;~G6yr>w>O{8LS*%osARaq)GESLKY0pNmuM z>}y;T+&aamHO4h5MyF`_(6}ahb&8znjEjHYlYgvZT+{pM1A`i~_X zhs{p?NAI`BwY9kZBbw*A?V7~*BaOE*E-3d+s3tbmQGSR zp>gf6q?6FU?mF;6Cw|n)xDL(Li8oF&t|OIo;^Bvk%kbwl-x=4j**bB?jK+0B=|nH9 z7}v>HI?;}P#&vqKPBe0%ah;9Si5i?Tu5Ld>w={de#mBAm-6d``}w-Ld`>6) zx4&^+?V}SmUtnCZ?Cr4vl$>w@*z3EFituKVS6 zf}$Lc2e);6?=ItdG(^Wg{lK`Mq|@=|#51m^+jaadMU3lt10A39W3CtPbv%2BalIO+ z<6T;0TyOH|c#Do2*V{unUe8y?^}dCUSCRMIhc7x_BHk~b#_PB@c|Ux~t>dm7YFuCU z>9_-UeBT@DxU6(^{dlG0CVygFzhZTq2fPnGsdb$7ybj(qI?n%iUjB+YPWA4_6}YJ5 zq#JKsp$^JE!R>{=D!b!shOj;m0g zYsQ_VkqZ5h(zyS4tb%Lm8h5hZDp>hn<4*2Tfk!8dJLMP^7#=q6)TvY;W0Y~HS)lwo z1{-&}{L0^8lX0ittbFfZ8F$9=%J**$cVhp!&)AFL#me>gSN7#$9ZX`kCgdaTouter(BQ+$9I9A9WfScd0Mx`)j9hNAy+S zN3S>TGVj&*oVSg;YX~ued%Hww?3l2#3^jtmCCEniyInu<<07I#i7PsHJ|!)bBS?RTcAD-;5gMt zr9LHpYuq)*sE_MY7%s&!^dF^{${c?&e?B+vDwxyJZLUwgb~6bSy(z=%+&;B>eVOCYAy&Qao!q!PzEZCf7c%Zn4b-buRgAmyUiAv?jJs=Y z_3{CazuS2A@_*Be`>!wRWxBP--J`jBvDFxN&x7hkU5;1pJnH$IPsZJ6ta|=WeB zUOms9#kl*|SI-V{{03}O&stSA?m=nQ)1NJkd+^`t>GWR4{r4^Pw7AQ-hn7=M&hmQw zZ;pD>b)|6+`>CG9*=gJ(nySZ(Pa1dZcJ;U-kK2_}J-YeQxZSS6Vq#y#e)dho26agQyd9=IwP_qa*wK^E@+-xuosZeEuOG3tKfHpV@1 zrn>j3t8q_yr|wPYXWUanYs+z;I$Pa6Hp;lCy;FDFPcZHoO5O3zFz%T%)SWr=jeFKh zbtht(anC8QZeLns+;hjP+dVfL_q==RHtQMP3yP>)D|Q?A!r|(c+Hc&8&Z(RC4jcE9 zOzNiGk4w9$n`w9-EZeDWY(8b&E8?gdwa*y$%6jVhE8f?u=BewW*sp%BuIFI?UkP<> zKl`;q)wSk)+`6Oc>bKLzy&;LZI)&r2v5~r3P) z?%R5*%L_Q3+qbC8<+d32j_>NyHQw*L%BxF#R~h&2;p);Ki;a8FL3MG>T;tvwQWq;v zHSYadU3fIkxDQzB!f>~7A2jMhh9Sm%D6GzJ?_=CYlsaF(vvHePb?#j&<374iof})< zxR3o(=kioB?h_H}?BVjpeX_4Q+q$T6pIWER{K{e6r(dWuGkCquW>;rQ@cNx=u1=r* zY24?hs?%Nh{&3;6Ivt1i)y0rHwV3C5xvV->agT9d>7`EI{Li?rE>|Z9@O|LgO?5K) z7~{V2hdQxtpmE=Hs1wyX8uzXK>iE-o#(jIGI_``z?mIWt@yrE``(8qIY!~-?znnVO zFlgKlx~ZcdUK{trIqK-Ye1Cg%LLH@d#r^oZGG?`LKg~sW(G=r;R!<%A@VuW7Q%7d; z_4Q)4I#Q~-algEx4qxE=(<`4k+&!&vzsaW#$MYKZ+j{EI(#OXAZiqS*&FlPri8^?D zopFCSsSXaBY}_9|sDmj7829Hi>c9rR|9z>T4%Fa%`n8?f|D3OzZzI)y7vI;uuU7lB zJTmSdXVkvkM~wUDJGHMd@4Mg0)ZR~)aeIoZy%Tu8-uh~90d3sAzG}}gj<0{R+S88b z7ucwFd+!@}@SNH`d!KQK-l*NBIc|0Wwd>*_W5vm>cJ*jrthf%fD?w3X#cQc{E>CEz z_yg6>n5V`{FiGvWbI@1`SF0U^=NK!|VYP!fYb)_BwS8kPVw06QsHV2=8ELGPt<=^gEsd3`kJ|FNgt1avYRkm<#!53oZ7Fci zSZP+Sp^Y zv9hL88xssQR<`VF!*U)^_QGm|Ba5+elvV5Ryf;=(sP%&n7%Nw8wLaBEW94qD)@^KK ztUT@1x|&6dmA9K(``l}+e0|kg_Zeg5AEMS~<#`r}RsZejVyuFr)qhP&8>`U2YR#vR zu?kOCYbKmCR*~syO#wcx=xnw6SSMo@o2OQ{FK(>j3)L#G$5{3JwW{=F zW0hK>R$gpwtkO%>${x9l6~X_tP_2j=W~{RF)bcx(j8$&7TF!YO ztNaYLJmnQ*RhX=nZQ%YYj#tZSv^7@LXtne?$35Dqmb%^;D`tpVnq`x*9R1Xi-2;rJ z{!&XCmot`buNHsw84JzS;_-)!RjH0zoZm85)N!cujNRU^JyK)#w)_4kn*M%r=>f z)oQSs@$0IwTDMj+W=u4UPpTOusv4_pUN!w}z*y}Psp(yJv45wg$LV9N_7~N(#rcfY zVT+np;l8mtPE%8F%rMrU{nga|wT#uNk(!#6_gUvsYRZ3nUYC?=N|j#hKdQ-(dEL66 zSCfa|G*-8@YH|ji=U-#gr0qP9?j6;ndS8vzBU(*-%lootdNuJM-oHIRtBJWeKE2MU z2?sg;y_c&AE&Ca(&oDKf_0v}0Mr!<2zFztjRO5^CzV8=O|DG;utp3;4znxwhYrtAH zE;QR%17p>=1=Wl-sG%BH_NTE1=T&2`u44a7jqTIKSbv{UW0S-+){yz?pH*9pHMFPt z2OOvWMX50lxc^~E)R>|B*xylO(snb}@HJ}mmNdp1F<6bReZ*L?mDH$LJWpqGHEL8w z_IK5&?8l7dTBSzrhYVjH9fKci5j(?go5)j+&udW8KCY-C8*h z@%1?-mx}$Fm;GxMTkLOR{j*Vx=zPjpV+W|=3o{sNTv;{jT37a7H7vfeLcW7;p(Z+S&yP2aBi-r;>WqmSyF^0cvL7F2y|BxnCr z^>#Hj)~p4p*RHw7n%zY8{P4h7bCRl_`FOqO98*2obT-!9VXFI#HO87(QvG$7_v5^m z>aRF_|Cql(b*sQ}TTowh?YF^L3*)LTYu>Zpr8++Qr|v`}6A0 z(XWiPWQ6K?fa9~YsOs>oBm4WRL*YfnS~fwoCx6gdUO}~+mzMoY)t2*c)`}UbZNhQJ zTB%hV$5Hn0RO`Wf-K?6eT5XIl)@rDh&$*w~?^MeyD~z>frfSjXuCe}$QO(DvWdB0Z zI%KT16IIjS!;Q5rLNzVH_uF-MRFkgHjkVsT8ZYK`-;hT&x>1MyY1N49gx1Dhs$pf` zPn%Mx2E(4Q->T|w<8f_ntm-lUU~T@c>g614tSz%t-R8U>w??WulX*XHy{>AX3J#yZwXm5Kh3 z{bv<1koVW|;i~kyH^w@VK$Uu$nEfAb{-P>;mE(T4u_~OnB>P*ckgjd4bFEduA>7Wn zhpNCPzW&a4Q2AdhVEGMr@%4K3w92~m ztg)_DQdwRZ8)$=KX!^sY;t-p0RE>RcWg6b$t7jN*&AlZY6tgsXPrv< zj`#K5EGlJgj_=(GDn(0<&t0!dK8^dm*Igw$osRu2l{A#cSof=_q-9I7->UxT&HL&> zHkD*0$L+ztD)GG*?7yqTsXH6%VLO$mWU*NE9KK@DA5$?<5f7;m*e6XJVX-A;;0b@NY z;_&S~&wi4_TY%T~*(b;ES?`SXyn*9aTrc~rjvoUO8S6zV$G68k{ulimU+eMj!;4Ff z&j&buFN--o6|TsByyFA8X4cDBj`s-~80%GK$J;@z*e`Lse%gt>*YT=BFJrxK;&^e0 zuglk)9M6mLeBLB`i;elSJd$?{+-;dz!J{rf@uX&c82jyEyJQ;(haWzvJ$a zrN(-f%5kUoO7>kHw-)}#exKuJ5}wcdWRB}YH?r^GxcYK4`|XY^O*jr8;yErI-NwGD z<6=qaS3Axxmj0*XTvGNQt2)jMP$_3*j9`{%We18?WD|K`}=g0Isr(T=?*C$k^z*i(l0&6o3z zUCS+FeNE%onQ|EWR*vn?f$Wz$w!ZJl{)J;pD~`{%!j4U+IbPrTI5w7T$bOq+{mL5b ze>m2q=Kb-#oZ~-t8TS8kto~St{XWO4Hrd&G9V^bJG1iZYj^*WfpZ)lsW9cd%`#p{& zX+E<5=~!evG1kur$AVAS+4pnIZ+nvc2FF}-(yX7a9djzIHP){@j#+Cs&cE6^W~Q6K zevV`MC|;jmmmO2T@Vfm@)4CCv<*WJ;Lo;J%j+tHc%9Lsmi(J>hx@B8Fv z`-a!apT*JY#Blc29L<;2W8crwBsK^8d5(rHzOX;$s8@!6r~L06wNp+vRv?X|`ujiG zS9DZ4U5b4N2UdjH|Ko7Dc)WoPj;PiP*fc~bd>rOkA0M*_}Rtc2CmyTJIK88JF z=3Y3)zCq0NF}zRh_AwKqFR z#RT%WKqec=nCnU z@q3EnRUgU*aXpLgTb%FZbN4~yn?vG&7Z13&pv4C)PFV4RiW^e=fZ~V~Pnfu(#1|ya z7|Y&23>N< zl0}s~qGZw}mn7K~$tOsSy3{F4t*X>3O3j*P-ICOy3t@5tXgdEb+JAG~+i8t^_y2fmKM_Y&~^417-o-`ByvE#Tib@NX>m zcOLw#0e;>AKXZYf`@qkh;OAfPGdTD?0Q@cjejftAlY!q0!SANv_haxoIyg@N&Q*Z( zCE%P5IBx{bU4ipw;2a(}j|k3Xg7c~1oGv)849;zX^XuRoKe)~Su62OxE#R6Dxb6h5 zeSzz5;2I#f4hgP>g6py1nlQL74X%xY>+@iZ09dC0)=Gf&8eq)`ShoV!&S1p7Xt0I| ztYZResla+Ju%-;GYXfWR!1_M0#t^J?1Zyq9dQS{nJPWLQ1#54?`d_dH8LWc_Yq7z4 zaIhvFtcwS0^TB)om{9<85@1#X%!`1T6)-mgW_Q5+5SU>Cb5vlK3(S*&nKm$22WI=g zd?A=|1ap>P))UN|f|*w^cME2J!Td3pfd+HfU=|$Aql1}vFqaRq0YE+h$VdP=4InE5 ziuXU;{aDAd3#<;ekv(kP8U12|+$0$Y=yPkszxQI46=z zKZ7_T#8V-z4Doe{Geo>4;!Y8Ni#TM&VJaO@f4^W(h;zblUqxd1kQ7N8GadnC>RGg*aO%->m_+!OkD;`~O z`HD|ioW|l+7PqtbrNwbAo^5e`i*H;HvmxGfaleay-qALQm>csEQ|B0>>6?hIuoqFA z$0924GgO>+0Tq*1MTL=dQ2xggl<%GZ#y%l9foJ!3lEhae&LHvjh&xC8HR6yF zkBhie#AhN-5%GG6TSNR7;+PQ6gSZyNcOcFI;ruswyZDU3_uObY8!c#Fb3 z6z-rV`%n0L!oU*_ov`49$0kfP;gSg(O!!>F$P!MKu%d+5B+Mk?7705@_&vhV5sr

dnFByEv!Allh^5BxmmRz)ClO-Q4 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

    WCnqr}TgeEI3gYEnZqWNc4YlmPr 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

    G@s`IosT|7kIHE@4~|u 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%0D=9|zo?;GZw(A0lE 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ړW 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

    XQp@-^p1{kINWMAA=c}lj4e8c#xZ#{ z4s?!1whm)2gR4yk&gjuK4$lfkZ{1<#N$qtQ6>pv-{uU(zX{cq`&oYPyr3~W11Z3EM z2r~R|wYb^83@=!?5V`d z==k{Tl**bKT;?Lx;r}O$SgOi~BWyuzjFTPtf9|x5iWe%y@0l9D;rj5@ZmJS*Y1!z` zizy3dRQ$P0To8bIZEK<5A=0?5T3kgmPJvQ~NaD3>@kJ@dq0{(UjrbOeQQ5ZfkZkcr zjrg&$#UWDoMy+^OS^`Ip9ZGThqgMP$+2If=e7R1%%@i8fx78#ngi-NQo!FH`e$cqS zathh5UL!6|!pn(NJEX#CTq)92kXeR{39Neb9dsaSQ$ z`e)Tc86O?rYI{ps)<~n`@wMU(Gk-k0Oh(|cdU3BJ5Z|zq5qP3rJgy~ZP%8Ahs(`PN zoGSFgZo5wwzqSY{9i~L#p_9cck^)LOK?gM|{&})^N9AfuJlE~(#JNH8sEzHht%9@H zF)ChNCoT=rYp#ur4V7`cf{m3HYaDW_TN=cxOLM3Lq}LE=K0_n)%#>xz+R*2TRJ80C zQ^ZwACsMJh8)&U~twCJ2Y?;nZV=UQuEZa)ixd*jnr@o`Br-wRa-Cu%?|92I4HHv#| zWXvvp*p8-eG{;rgxt ztd*(f?g-w4F;+g_Bp!;&%-WC=oEZUUUSP|NXU^O?JTlaaGp{gZLeHfl^kT>XW94Pd z;?gXZsef?0i(E<&l8xk0;%U(!*ZyYlr5FM>*%SeiPZ1yyi2#XbXmQ+R`)-SPPm;#a zeTyu8Hj_3_v{b!Hs%;2GDn5FpaSlE942{yGvGU$i#J+4+mI)qAN+t*?iJ)=7BxoE^ z1mnxDQ|J;7)8be(B8y+qDqfXBki{LE5ld)A99{h&o@Up!iA!?KVsvOnL}7m>O2*gD zMFk+sG6==V~rs++S&R^6!4G}T<5hIh(2c&B{7rgJCH$UAq!Jw$4! z{Z$(^mP_lj-nXGT|J91mt`|2Q$8|nh0;~4J^W-}^WES1e=r?@q6&dXTghC0D7!*h^ z?HlRB0dfSe#?NVJ$WIl&ab;|_7Z@KW#uzOKStBSJ@0X1CcgA6S@dj~KE*HK-V?A{d zLkaT5`G+=zpObu_bLHD%RNS{g+_?NWYR~99EY&(250Q`Zv;ZF5jA@76q7MmU<&zu5 zZ;3HBZY($!%GA)oJ3A6;YyL3s?0! znOIhEl`Ji51W0iOOUsgzBMxys;Alii2{2C0{ye5q5s7A+9la&mbNVoPhHN!tJ0Z29+(h%X)= z@*}#oLE!O1$3jTt>=@zpwmeSUeRimo({QVjaw)L$D+(_3yN3#Rq4I z-NoE3IA8m-I)=RSWXG_P#7XV2w;Q&BT_=u(;Le~gPj(7@`6`|-)GbMMV~_-RH@a~O(1BxMIX5LKn30lqPQ~5b;^)QO(KvOo zx|;kFInX4Xi~~_R(P&ez%J8TY{mF#Y!tb;msV}5N9mFLKPt7E+OL`=xMZN5#ScXz5^6C%(wyL8r(M zR$LPiuat0IjIpxr-U_aXFEM&F$B;gbRIJByQV+A^V?Cam#K>aEA#w1SdH45;Bg~IR z+tycC*S6s@Aq#}B>DD*md!8_kC~9ss&aqM&YMa*J93~0>gawy}qu1lMllJPh#@SW^ zPV>QuK*m`XqzzwYu5YMpH9l^^+H3LEXkBG}15U&;=vs3A(KoS}PVwEyMF@-OyV!L8 zEEWeVHsYHj{@k;TPge}#Q`i;sIxF6IrHzA-?KzBViAoHy4m#t!N1O}GpS8+wMRBgO ze2}W)>o7X$mrh&GE}*YcA!%$Te8LhhQ&AZ*HM(WOMs~bR#U;qpC8<$%VYj%oTw*0(;_`2oed>im%5G_?ahj zh5~kmNc_x`x{M?gzM}B!3nR|2m>EHoW$wYw$3T&q*IKSfbkg*VeE;;pnY-S1;!nOF)JXBF}B&; zYOLg^h^0t>Ql*23J)OR76SYWxL#3Y+oldX5hzQd6cqRQ0L^J~3xs)O<0LC{phBq1m z6$Thz0>-l%1BS2*K_?od;F=TReOF`5j>aI@2g<8J`J7J);?R`*8*fR@0?H3GibGlM zxKcd%KzV^sV9+BSd`jf2QJ!|-oadJ~$4BF!&7uKcie~~iUs5>XXdE<766adrJg#u= zi#46Xx*u3?Dy$DY(WI!ok+l8{ti1s#(+B=&ENWO7%bN_Wdo|XKXe@3)Bw7K`{-n_y zR^X;WqICf6(j>*xVF+##B-$>Z-N|SvZYCu^_L2wuLg6?lkx3cnG2pzXa9m8vIDZ4q z^+6ITMYx)ju<$*f@cvj~xtf%*%7OK&#&R<$V}*gWXPV^rfvZUwjVi%+G@7eP8SN`T zdqJZ)3?WU*XgGh#d%<)tjjh!DhB4J#-+Ms%vO;n=J0nr`^&bPIpDCnsq8);fxC;Ag zfc1{Ta#nIi<9h5r6KJ2GA;tQ@QPUZXE3CAPBtgCR1xW&(_%TT##S3q4qG42c+LI63lP5$QBZrHn1K@=glNa zrLIV1+Q7$vbQ>f643*o36x%j%Ji%RCkdm4BDoSfoFriN%5 zik$~`hT(rwpHDUIVt^hu)sXM80rXdZqQ@^7!Oe;W(yp8#^6Ucudfxz(C_4zA0no4= z1P1_Uj~zti4A?jAFe**Jp0&fM%m91W4&z#aGpZKZfoy*OSJ{DVWdOr=AZ9&eK7h}& zgVpE&;4j(1YCr(+<90CQ*HqrL!=ZzMdsFRj=%L{!+Tmu$j+3z>_5{*L=eX3KKsxD! zJM9Ui7s?%keqjfzE*jwX>|oN1v3vW${_Qad(#iavk4cc8=KoPlf^s+iUt>~~ z&jsekq$tM=l$$lpYG1g{1U~AL!b%3tb4g(}1Gl-PNJRrrx+F1Of`+}D~_YBve>kOs8%1d=2J|7Y^bIUTL7*gFe4g8{9$F) zpoX*@Yl7aRakEOg^InXzfaZ2DhCYf1=k2YaTL9aJ#z%T0o$VuCgQI7XhrjKW(8uaah9_#i% zc`YGMC^dqBGh{eY7v(cd}Mg%JW;)wbMFioa0W5$Uyyg~HV@;>T$ ze(Of+Kr{%o$O6m>;D&oE3jeVp)ySA42xGb(NPrm{pfQr|01P>Fl#plXh+)juj~4AY z7Ko7NE;C4@6dzRc24~E`72EVk5A(BdvvwL1kKl)yxKVoslH^_6N6s+hLn^^=(H=4w zi*$NE40)8qpvN?V)5Fm-3<}a`f^z+WvT3+{NIn`yNW+Sf4P&v6%$PBAMlwie%w{o{ zlyZ>iM?ltJN)NaJg#r(#9m@|;D{BrXWMhI#YM}&k=#d_dlQ7)NF%KoYd>%wWy_yH{ zkEfKPWQm_ABa|aw!?CtMPmp|t^9;f>j3Ro#GXDzXJYjal?DE;(;7Q5#3#4sIqQMea zY5~_MyfODvQ)G zPLWY6>eeHf68S|NJ<>zFgc-*ABiWlyO@%jYNM&E&Sj3b(({h2>p(BQIntFuLr^`n| z=#-C!@ez$lJU^-@9LcqZAHk@X9*9kZ9t@+;&%q`N zsG@K7D_ISrUp*q%nex#vw&-M{KcFL$^Hz;dX@f+N>f;bUfX1-afQ-FOMovmziO7hI zq%9!1Ms>t6#)`QHk5{lox34l%A@Gj5Vrg)m-!LXtss|XFe}~%hpf|+(JzGMj7xfkv z_ZEDFI!gvDUyc{P#`?PkLd%yA4ux@yDLxm#TQ8&Z{lYk2@y9{kxMPzOH_;bQ^cC&a zuHj+2e`$2*)@~fUh1A~uE=0$NhjEbf=&JJa!u(wRucV|1r^qhv86IDS>leo&6U!U( z5bs00ZK!YTRNUdSe0g_2{=;_m@c7s&y89PjW^Rpu;ux4?Ex!}z`yuDnyzZEOe+U`3 z_eHi2^+r}A*sc=QAG+j?0n~vg8 zI?_G9iNZL_=a=Lajubiu0Nd;+lg(hPCiYzvv@_` zihOv%_TtW($aZ{;%V|i*Y0sS&T?Y}F*G$F*xa&`?Z=-WM)m?Y1iVIL@Y9t-`U>+iE zk77r^wI0`ZudS_KXNR{ouWzcsR=yoph5OZO0mXeksA^mLaIGqi(2Gp5n0iL~LWeXo z*UgtLO#ZDcf}Sxdj$=Hd;uxtXKV`#TiTE`-?lV64JK~qCxDUug?>t)^^z={6LAu;s zl%P(;(bVc6r=ux1f0UkN#?YT5jvr^}G(^fb;}1HHbuY*l6^DE? zOnV?d{>|88!>71O51G;D&nVaFL=68H+v4bOW|%S|9fR8Gu#x;BJ`3^ZY;p8S)9$rgt^NwAUp zfgj`vJa3Cbp1{qvIOGY8*y4~UP-}}ro&W|O@&|g5$Nv{w9P;>Yvc)lf_MdKxqxbUD zJ*NCa{^Mcx-`L`~lh3!;7RP<3zSC^+48%jWILgZVM_U}Sd2hAFQ5N1aY;nx#y>|Jr z0P1(zmJjCsq0dD*jm&zedGxR`D;X_}5kZn<{>f;{O{Z z*NZBIA2a{Isq}xyI9Rhh9-oS%&XIf`)Lp{&z-LK54}6*9RVuws#g#rDrH`jqrEga0 z!zvCx;{0bz{+{ckT%Ma$c#BGh9%Mhyw^jT{DnIPc`G2kAFR1t%O1`&L`~#Wa3%?_L zFWPvb=S`FOyeKb*Lm$%9TcYA8s(6)(qh4}4>KEgqo#Akc3O}ww)Mti69}122QXlf4 z1r*nQbS|dD6u%I2c{}`WOu{MtJ**p0_>AOh{6U59%8;g^B#(f9bGS~0XumiPxi|!U z4zE(-Eh>CKg-@#RB^ACeL(g;-qRpfH9{4MVqbfwZ!|`iX_+1q$c|EW@rF+qaafr5t z!__JbtMFqggxxq@`M38gDh@j^{6QI-_5;6@K;QU*VU$p)?FxTcO>y{3sU3bU#`_e9 zJx;L0cVWGP;^$-eRl%3p({INb3B^&biYRnH0^hd zia#bpS|*}&Zf5Q}m#9$T`xJfv^@`{Qey>8*Z;DfY&0&iQ zRrw`-RmJ~ThCx;S!FCnzQ{g96c#jHyuEO8Qa9WBAGgY`!g{qvV?N;$eRjBi!zLH$i zm44ILs`$Aoyi$eAFQ&gD<1>`~XPlto4JuUa&WxK>{5vvC_N(wn6{3A6zR6ovc%BNM zl;KQehnZI z>@)kfD*lcP=gd{%xjib}rb1;`>Z^!u3i=TauU6s9DpYdKYn1VMA64Nu zRQQk#=PNtR&sXt_RCuil6`dn;Wc-LB6+R`y1*)7DDEtLVuOpScj{LI3OI7V#>Mj*m zaxScv@rBC27v7=bugGxG(JEB_vgipJKPpd!XR7dV6{`B2He1Hil-y}&sQ8!)Z&u;! zGCW$@^JryA!SA`$QaPb@!7OSvA zg{piOE53^-6#Nq^yikRoRpC7aG!?4$EJO8A8Onb% zl>cTZ|H)8%Gd`p8U9UpLHv{7dru(D{Uy|Vx)m|)7e3#5q@Jto1RAH40PgddSD%_^R z9V$FWh00Hs+@j*DU0ZUOivL)Jzfs}uRrrbu-;^OXJ6P^a<@cFORQxy<7OJpLg~~3O zy(&JSLgnX~sy=5b`(%DmrGHh0-%_EnSEjO4=3f;2Zz@#&vUIwPFI}v{V^yf?!_w6% zzCnc_QDH=d+f}H_ZRwRNuH;&({AZ~u$EC`Dmi}Df{Yi#7N{$>=?{fY}!5@?1ajJZe zQ~rD0c?z!Tdu~9+bJJC*?3=qv#n-7&(a*hD#g!d%f288is!)|@?prdx+@nHOua?)S zc&7?g`7HmWieI6^8&&v>3SX7s3Popyviph^3a;$EqDjRS{S}w1_?J|8p9)nwx#D*! z{#O|uzf6Tn|Kqz=T(v95t9p05vh(pbsPwPN5MPq9-{zgD!jol~KUal|RH*RsmHqO6 zs^EW=VS)0G0#&aHu9k3fJa`wThOn)H{=bmIdsRC8g6CyPDn$Fq@p=`aJ?8kQRCv1z z!Jpyqa|%5vDnvWT@r^1xONG#z;gFxhS7b;pSyP`wT;9u+D%eRrt%FID(28T!#K5Wat{3I|nql?qXhI30GSFpw<6X*nuXcA2(W#>u{m zfoIwo`c+UI?Lq;CAF!QQU^#Y$c^llQu>#i&;Zp;IoAnd+O;+%hKzMk(d$4OOu6$Tw z!SFfT)`%TI-&@<`xLk1v8c*&@S6SoWpq|{im*}%CFth zR2-J~o7-q(fj<)N*_yXvGct5ka)zpb4Lb`*wzt$4_qt@*I@&)tp?`J4VL)!nH)jZm7|*UhH--df6IA z9~&#K+OV~|c6%OfR+H#aC9f32j#LzQMZTfpTj_=oaxLkb*xNH!V1r|fd~f^c=CJup zU)B-as2cAd=&c;XjXB-pW0BF!%=Wd7;rh19?S+k*ZJ8~#nUyCr6cl7`JfR^!KeG)_ z^|iIN`I+?_GI6_N+o>g)pJ;1eSG}%AMoST0+mP8zS2)&Y)>c)PWwzFyQkL1$TH98Z zSzB3EzrDa{=tv>MtxS}C zBEF@pX67bdjygc35~&2y<&mkqma-?}wlUeIr*QVTt`cJg4FcP=Q)5kx1L*Lg4Utgu{QN5WtyJDa z@+r=1*>DQgigO;aH_6-|&XsI54$Y64z#%)4nft?ekVz)0TTj$|bV~$pOQa!6sE@K5 zo+)+ZmM=hd-nOM+~PG$b;cDskjVq~Wj%85t63C@6!YT#+-8u7Yw#6(!|MV1%X` z0_yJ%wINV>52+#Gyob~fa89f6$#WAaeY?I+PaqnJxI!!qXYviC8R{CgzIyo+EK+&_Y}Ui8o!mMs>l8ymIW3FB0h< z0wp6M)kyc@aUoU(m`G9zV^7Ebvjh?n|9M^nE@il5ubxUqL+t1O;71z(nFaA z-O5ebS>vS_i-o!f}cEK8<`P1@Yz0fY-F}o4h^5x<=j(o@50NoEDUH>#+ zhkO~N!&;4mP~$28)AD7!2>Bk5#S>UZwad5cD~N0Pmg6~&e9P`ZS|ETBO%my z4*9b0K-&GWcmn$lcKLEh4=o?o>f_0mvkPhDtNN$;I^;Vp2!sUu?>Lh8E1DQWZNEM| z+w7N1^ycG_>Ie3m;>nkrhIbEMM7sXPk+0;RKxolO2sNI=ex=aMM=<@TX%38BVw=uvY&_D#sQ z^iSix4}i_i6C{teGqnM6wzi*z~wG4RLMfY&^%&YoO9AL+Fge>S|&rz$w%`SGXm z9P~aPLYk&WV?vGRq}PHp;zRV3YkJORONc=!AWI9*P><8j1cQONq` z7nK#47v<-d{=kBorztDbFio_!-mBscone9xWCq3nPpFH<^4njT!)Y zlN-M*^bV(dZ}pnt@7=#<_*);`aYdbP@BH0j_pB`O+|XXJdwOv7ZV@te&)yx}JA2;| z#{Cr3yT)Mo4)m_ zpRvu$>U?!GCw5)D_)|A;?#>cVCf8*VpNSW<#8duH{r=*`by=HlCdd!U`a`=7nfe#J zD5eY!?eiCQ;o=oF zZ7qY59qMB}L^@kWhR%%ijExdH*FF44&5YsEOOplpyprh<8LOF*qN4or;+`V4n#l*I zFbU32PaD}TtA&U?+k)4u$Xr-yigfBv13NKtirR;eO_`quA>RAFVv)xaFhKABx4B+H zW{ayb`#0G9XEvJ~c^}~C<-LI8u!1%#WhRDMNg~OUh2D!ipAnVwdObVleH`f;=Pmfv zSPag$87EcJ@oYv|Rypsi^Su{VHD#rZ_6nhp79N(cdZ?;&4=csgdEmQt9MJ zCB?tV&w}~y*2!}NDHVGrjIVECsA~*Ixf_41{|SwMUL!pG;0MO(LvRMTuy~suFya!w zpoeAn`!+ok;BRj?{;M|v6rAGSbH_RS)Zy8)mLIxgO22o{cVxEoU~4UBWX zch46j=rZq~z4Ga5@1C#7r<=WdZk11Wc=y~OpT6tebFF-O(9H3eN#z;Op4CkFx1K#U z0pp}61L7J_fVQGWx_bL33c`4Q35N;v4eZ3#o%Ff9yeNbm8CtV!Z;qH$)h@J_> zK8ExB$8gO!0YnG>PVeVS*-eC%{dBMv9b?`&gd_j^@k$<{*5mJJ98DDI-f1I%Y9yxV zn?pLzltjIIcAwL+MLxrL9qK+sqjNA{0y_r_b)mqu&oz>8VLD3z4&*l9*?IHyD1 zD5O&FIHvCtZ;wYPl2~HHG>&GP-op{x;@HdG3rV z1mjA8=6lbP zu`)mwpQj>R+OI0ApU_*)Ko3<1?e{yBm9{^=k?4@gKNRDYUxV_+e|Blv&e zT~48Q8Zwi_e}%*>56QcS<^6j+c}eC#2C~gWjzboAIt!f?SV8;)l?%LQ2j(pZl!Ejz zFczfpPLOPY8vM23uN;2`_#>4`D-kFG&KqYTN(7FAnhT)F*$bh-Cl-Rl43%;;(vt#d zoMi>z!^q(A%P|%^=9z}?Y~yOYc}h*6KkDpXRVTnwN5^RV74F1-&9{< z6Thaiy*3;UWz&>6 z<>fe0uYr?lYu1=(^lV`j<&~Nkd|gL-M+-3;AEf(qarzEk2{sX0+FNVt>*~S^M<5e2Xv3L>S)w5YmT3l=KQE6FP=C}3*sxOk+tJzU+g zK3v_5V^TJTagLA7q>}28)Ye?rPDlD2B*AgsNeJhifC({IMDb{yctXTXK-8HhQ7PuB zCsEKC6`>!9DG4!Bu%67qQ3_SIR<8}0w1qXY9ZV$h?1o|F_O)H zYweo)w)Waq6!7|{b|r9SOLbegz6oHkU8hKlZ64p+ZGSdRhpVa0=jImFm-@C^t~LrA zFkI(Z+0YQKY-_7+ZMVP@wW0RZ+6HAoa;CZ#CWn(Gsq*5WGrdCZ-HT@CCkGwrVWqEy zkQ_q+v+~nOa30?H@CKI#t&PJsU;BNu`j-t`4`Yufw$`&~X5*{DN?}r4l7jkTsFJ zGdna9TCyax(-220u!P!hLOXHGMyg3HYa$ywYTK$Ssqw(QsZ0#H0A&em{IZdAAr2l= z@OW8Cg7J9y)576~=B73D7vffi{xif9T-e%<VAHMP|ZZ6U+6G#n<=G_@HbS3kmN zqrfQ(H`e1sB03>ej3JIs5ExKcP+9`eI6&|y0%d(7Z=$qM{viBzq~N$DmRAm3((GfOtC?nxB&8T#RZUp{G!sLvci%gfX`Aa0Jd0^7Zem0mKNj{mXsA2 zm6jHl<&}cPIb=xaLKKRN4Y5lQfRq8Gq`0^cuun3Kv;nNBpuDKOq_m*Cc-#=@atdj~ ztjt2mFDoi4DaD;YrG=$=<;BHVd@csFiv(zg8*1SycJp0qfgM)-l$GLc%u6hU1Z{em zl|!n{ru~csRk|w+Uv4ER1K16{+e$T!AZ=fr&$Yn`ya~bS~FRdha>&-X1aT+TxX^ySSUA|8I&v9ocSg*O&P{s05_Y7 zE~WDYGto56cVYSvRgTQ*-AF0Iao2>NeW=p#Ek_WrL_(5 zT@wx&6&yFLi~E@eXFvi`my#IbAu7YYGT$)97hmh z_*z}vS=B#Ci=F+0Jp<#t5o|{24?8e`#iB?+&Wmxb3-6Zt<|IPIByp%)JeAI6UQ&yG zJ`qr}p`OiMBZkl8mxo&G)2@SlYY^fSL38e;u$^aN$1IQrEewlL3x;fE;V~?2T_Vat z6oW%hbe|~aDExq;H;EHCisGl}ZK5L7LYEcFymyNeWmIK;Sezu|D))0@wT!FmFN;d1 zh8upnMos=}Y%o)bwKkwBOT7(fN_4VhVW)YwXtV=O>6+|NQ^saH)ReSE^6E1My-BRM zK#Jr|;#3P}in+mpnNn_4Oe}iOiPLQ`MG!Z0+JL5rAF%;V2|vngFzZz%6_H39@SNyl zgsoi@s_f2O%w?wmFN-aUr3+%pfd_gYVG;h0qItj~3}_qM>f2~iiK*pUjB7LH=LB;4 z*eIt%#elUnq7T5=42CG9O59N2R0}}=Abo6Lhzc4uSGJ=~R!O5{U1R+{HjER);ihJM zNr8zV4SIVcJp-e|k)EtU>?w|oj|`%jsl<@Jt+s~v=&yG%6UZ7Ljr7upA4iRDsI6S* zOx_Xc+Cs@#o><>h*-*cx3HLC{=AGNvoGeTxhP!&UU?qZ_n#>)_$wnIGIvJ|TJcR7v z+%>=p7z!1}pc7PCKuHfPFB%5*Th~{&gMwm(uhPbGRl0Z!4P8@n3lav0h7IvPq8sY! z5#7<(Z;11}6eUaU=z|$ALA0&*R76K3+YNCAqV;W6S=pi9q0q+(+Os**J3bJ>{m&yK zSiH~5t^l-uv^y(rqK=>4FwPF`*o;rVLs@z2q49MfT61usy;CB38xd_hsHDAHry}XM zKop@bXa%R&q0gPAv(zXo2rKf$3}+KW)Bt|SAN?gK87hjZlt&J zXL61nh3cNM;!TgZkQyH1T;I}$l~2y)&Xy6R94$u0SH0qYbk@p)Wn~02>wd4ePG_As zSk{e%U}pV>PkdQtZE0(nR9?KI(Sswz+s4q|w2&vN4Ym$4*?T^5H!YKp&6tq1*Vxc- zb01~oT!u8;WP~d2_lpO$M2!cLsIjYm&|RDh1L6rS4pXs-W9Cxgm~p346%Pl*^IDdc z*80ZEwsi-wP=90BsMp0^+KwbL0@d%-;5$lnTn9;Jj!UsC65XmG(H!d<_b1XG*(m>aHA%84NTJ2}%fR0f zDhIUPShKIiKqW7{HoT^`skXJgI%Ie=a4+|28o%VJF^t}kXso0Kw@@*4b{JB`BDAfq zLOOSbRW9kcsoMpLStH1L-OoYJ{>z8_$LG`&9WzYr#k8bkT8{Tc& zgXmifnxC8vwWIfOjJx;Pe1Pn&=1Rsr2k{?^>VKo>$not`=z|wOjAO}n zjzD9Jb6{}S1FdtT>7{Y5>pFKTCE+j^l&d*3r6JqcW}GySGChh0xUD#r-dq4p{=@pt17Dm=e3H&VJkOSn19ZRXbWxJ z@l50rkxTOo`jL-ifWc%R`sMP$>aiJ_H3UIc-RP}KwjD*pKwy!lS&~JsVHir14`HXt{G9sJ1 zM)CSn|G-%PAQ8mk+dE?I`ZcxTQ?ZAL7MfoN%chxVU42u1J4OiL|E`JB02E#a=^Yx! zh3Zbk16WU!`QnlKU(tliCeRU>Yh8JL;nKQlKEjIZ@lV0Z)V8)ZHIqa9pBYzWicR73 zJX&P1ahK#VZ{KjwK-cJKf8S2FT$bGVrsq|wLMkG)%?_P}vW2UJtvr2%ctQ*qP{{a{ z7dw!r)wVXH8$$Hw6h$A^)QqMM7NTqJpC*_F(EiLb1W?wg4P_Mq^ep3$IcT@&EknhO3iC{}Z-w zl&I;ks8!k#5-3qK8>IiDlKwwdoOFUA{jx)g;gr-KOeVPl8v=h_34ECAk*r0sBo*mC zTXoW{RuqDj4!OPyxdywq1DL#0>voaR9Zn?)fZ78@4fk+T6~o?(ZUrW7Xmt)JO-%-5 ze*&`Opo`-zBfb9#hoy5B>8C2M6`j1;Ej(_y%qUd&qM!CAaOO_phEW-!>|zlC%}4#z zhGIC_0S?*)`nR$Z~^=^+js&H z85!B!HQ0-dgiY9ddRmBz8$9B2ajb4W!PuSLW02D^WQyy`JGl$Nw z$1TGyulSsmfx04%?n?h_w0vkv1ayt(JwIV2M*S8rLWQcG&=g@HHK`xij85$EQ0k34nXBvq)oc*|QS>6HyaD@f*!JcgjS} z^P6ZGKwi1{6E@uhpfwUpfe2}bENVPmuL={7k7(Ny#``)#e0;}C6XTJ8WYHD)J05>| zw8n9jhh^oNB5kf-kKI4H;cBg8e%XVC%-cPr6XVgcVqIlpeM3jc@OBRLwjZTl)`*W@Fvisqx1WT2Id!Ieu6jm9>vQWHT1?aR^|bbV~4^z++gNu zsSg#d$S=w-E-xs-TYhEbrRDIKr#o6Z>cF2>HbtA-_Z;{KBKQn`lMdNunGSe(6z6vDr%NZKPe^1fQ^tRe)bPQ(4V2 zq`Uwi>LswY1mfZSc6SqdIOzaP3Qe!y=`lV8@#fB z);GECMGxxT=o=NDxgry_z|u9aqig4=T8E*j_>WD-S-7Nj1mn+~tY}eka%hGrQ<32z zGXw3fwYBSP&Rp4Mj)%QkwdT6Iwpues3?ndS8NlTc#igW3)6dC*P3Y}|kVBxK0kvh_ z+N$;}yiA{;i~kDfzd}&MV48A~C9^p-n-X&460=xsTtu$+UUhek%-0cOq+hZ(1kU07i zEvNq5rS@g6=AvPKw6NRrnREbJ;b#l=XvaJ-;FzksNABbJvl$LGi zrsb~qOmTsCUJF-qxjT**k`Sk=&hg{K<%sjlj@o(*-@hrY^v;zK^~TygVxKo9=Wm|m z^uh71?OnripS|9*#7G~;dkA9~x{D#t5??xhnA``cC>o?MyPsoW`}#-FZ$jk3o=A9G zDbiPp?*;ui4|*pf`Cv3jM49A%7n1qKpn19Y5oliRn}nukK@?4jGR*@nGz;;4vG{{{ z0yJNll;)YyG!Z45A~lvKT?3KgDHXp0&8Piy$egg>CS1$HMHgjI7wyxBhepTRHuv|b zqV_CFHke6wKUSH0!#!Q2z2V-ze71EMJ^*H)7Vk~-=iDD~FcTeiW^QJQW+qNJ2s5&l z=YY6ixGg_ACjcuN#)>$?5C*<5GZo_0eH~14^jk@< ziqC-d^K<8<+YZ&>W{8gIs2k|o#0?W#OHVo$-&-Sm#)lp5O&@N@c^$n2)N9H{zKRjs zyRfTmqy(QQS8zYlgZxoat?TL;!yB{o796jyS_S0;*4OJbDtIKm6Ib*rF52{?Z@c%tkY^5SqIUt^gD*v-6 z)|;#rWu_e9M%j91h*}icZr~uHO=FvNyOC^Q%VvK@%FL9x+%6TjYski#oxhx z&ry@Izl!>`=%PLd`vYLQ$Bij@;>;>>?p%M)g=v#9oi%-`Ohsx&%B+A3Q#SO>Z;LCy z^oK{MD)(>2RSj%19yIHQUcOF_mfq)R>CFVc*^IYF9nAzX=x4~jFedqdzQ>cfz8Z>@IPeXN04A^bEu72)EMCjXbM03d?oz8 zjFj2C+=Qp%p7pZ0AHqKwau;59xm7z0wEz0jV+tb>uP~CPP#Dx=#p(l~sn47i(kCM& z`8pR}*o$W0BA$mXw=YgjZ^Q5n%FUvIr_`afuC84x0h-Dc7|QdO`Eo46NEHsp(CcjFH~dZCS>XF8Ay3=B6HPYA$kS1P81h8dbvx<_U#c+0o{fyC^!R zofYlv8FRKvbDj_vrTB9m!U#DLVT=P@Tg@>Lxrsv<=}k(Qhit;keNEc@u=$DxZ3Ph6}vkc^*ELtEMrkU1B*K&@OTwG8Z284 zP^KKK@9p%sYMb;EpO=>oGR%E&P^Tlmo^+5JiSWRXIR?0jkD^)j4RurF<71=A*FYW`Y zyYnY!CGBOgB7@nq;&F&08I;&_FLWZKcg^tntwz zy`=nWarZI)oC^x)J3A}e!oTdR?Bx(-%CvTfPBW@W!N6C|*aqy(xNsI0i@$)`o0Bn9 zMWdO?k|8x{P?0DzDxQTmiO+@nIe#oljj!3{HcO8TMn*R6lop(mK7kcfTEtTWH&TxV zU=D*Wnk}9H+g&B0N!Y@@Y&$8F>xkxcPWlK&1jB0eh|uSovXNO*SvGn~lb#eS8;_b6 zT`107?9aKjbP|)ewMlUc8?w!cl8tiDv1EgP%$Ks^X+d1sXaIFohWHL-yS2>45#g|7 zk@~^j$b=pVV`N|(a@cLj)eEO6)I)+(-mG>@JzMQPki^utI)<(2lLxB=4qs$#0r zxa=aPCs1DTZG$!2qX)%Tm-s7gUnySmF6$ZS9}e^G=MaxvsOiYW7$^GuzXN#R?$;~v zc}p}tRHOZkSp5CKzhss8q;ILDPcKz~KJK%@4k%veI}lC&IiP=UmH4zzkyq#@c_%)R ze`S@p+P93}=-{CjD2t#Jgy=`TE+~S)fBi&pk1w0HwYhna%F-fF2jTY*8ks4c1-+wV z91gcyO^Ee6C}WGxp>a%JjRT!yk*&k}5a$k@(W7e|p1CUF`)j=ah?OU~71v=@ym^xN zTa*l>p_XAk%OD<*5RwE=(>fXzdn)lVIzB!-rLv}`Osm66O&GCMl?_MOg4h@*JM#bBX&DtS zREpm-HGISM;i=tJCEn7q(R~oo)>9D9sQ7c0xF7)a+SWq9L!@zAwYZ9CoC2i|k;H4& z;)_y@L#Oez8u2X_qq1$|A=%=M8u4Rgi$kRFjau=nv;>YGJCx%1N3Hmivcn-#_;Q_i zn<+G|Z>vdE2&3YqI{Gf4tqoX8w3~nT)_?_2OPd zAiiNIBk)AMcw9@+pj7C0RRLckIaTO~-FBZWer*v@I!uYeLnn(@Bn6amf(~j_{PSe- zj>^@Rc&^*miF1SGQ5)N1TLovYV^qAlPFxzKH)9(c8!F>?1sf|Z);Q!;w={@Xm*!9h zNUtH#e1=BonJLSbwV}@wsc6|PriiPKPNZU0H_%$~T7$T3*)pA-##plRShkh2a}R3E zPJKsLPY-p`<-O=6PYttzTGHpKXxfegAa>G zw#fMzt5J^&q#=EMHv-R@!}VPQSSwS{-4VP8W2}6&f@#idy+6K=9_kxL0evXLB0JS`gJ+TSd`6hpu!n<7B+ zDFP%S5g_plEsmRP-)#}^Nzxd)Z;_?XX42+~ma11twGE+2RhL!Jqq@k#Sb6U$VqZ2Z z%LET5B@={{M9?^35;P7dg7Ib7DRg;-X>lwXk;SiQ6|YJm$l?yoh$XZlj;?+XPqS;= z#3eaqF*>v(qOd;`CF5)7q5_a*a@e%1_*}bqIfpB3^m{2*)y-KXt8Ub2nrbdj!#m|1 zyi>kk)47vp5)md26UYqwlb|cQzg+ACgXuha%%O0`GqYIjib&|r_cvoY4+b*^|gTytE~;uZAlmZ8^0*C$XhBSJY6gYn#eL)Lyf;gO*E-Y#__N+(QH$% z%E(zK2ABz}hu?1nX)L5jIc3v>5Z)3X;z$E8ZFK8^IUX+R7&Kq0-hr_(K2-5ix45k& zy2|Dt<$o!*%9Ccc(2A5hrj#=WDybZZRvB!?iLJ6Y9I5i*id#eCT3gxBh#j$v3-Ni0yy%-)+)f#V_!Z$-jPGKd%kcRs!gP(vZ)|Xf8g>6W z{mBi!tIeOu(T2!?CJy{@59z{t-HF%2zwPra1nuqf_(fv;X9jE9pmgE#Y_MX|(qo zKKi0d(2-uR#x#lKAvXLHbc6ig>N1(qcl1Ttnra>JssS=ek<1r5WaX+=1PHd7->NwbrZAv$ZWRC7hC1YQ>a zS$`!3u;U{E2c(@Y11MJZJQ=Y%6&a&gsKFcxQecguVIRU&)No!ZR6+le3ia1gOi{Ap z_bG%@_%$7US*jrY3R4Z@L!U+gbZhxYxo&R7-1523gfo*H7Af15gp(Dq)FRd~UztTx z$vw!mJe)|Rbrz{^5fLgZf=YVmDFozdi_AhmtXT%5`QeXrR#iYDhEZ!#x6j=%cNu}PtZ(MSPj!usSQRL+^Gu_lW^=;nopCs%5w0M4RVBt2ABsbQS0P^#+I#ZnUa zMH>Yv(5`5Pv1PIJrmbo4rfq4`*S8l*Nsd{$VBDb*!#Ib7Q2JaIB!&(ZG>ms?PRjE< zjpWWHG{~r%knM1PlDR>u67$hMt4+~sl zeVzTDyu87oAht}v<5Aq@kJ9tnaXiw*#zZ(%Kt}GQH$3RA!GX@HiTCz~28Mb<8+wOE zxDk*bAkKwQ_UrDI_9Gl64|R?2BpAa2{t{n7 zt{>-vfoB?KpeAdkUr)#*=X;Y3G4s+@hM(x7P_t~^p1h%% z)k{xk7|SX%s8sT}NNY(qk@hjo7=U7N@H20~G*z?0Vy_L;qjgK9tiz)t7cIFUMV zie^VpxnGm73#5pR&1jp94&0w~$n8`*it~N>et5**;*OfoUc8Mc;}DPSZaOTv5kgd2 zGa4s=Y}wi%k9*|JzBl0TO;28plA{9VE;@D;w=}Idsj#{}P`$}cH;>(vGE`FAp_^!X z1HCv`0^bmaW>8h#BfXv(-?!*~&4S6BtT4?@!*I-O!*Fb5kbI_%zYI9KO?AZ?Ctk;# z@^2aiGvp=dGu7jO^GumIaB4SZyv$3W1Gp)RUKXRITHY9)F2XX&n57oAQttbAiN9=y(za{AwGHfhcjvhGVju zxXp&+c=<%ro=A_eD$#3;$Jmr;mKpK$QA8X?tS%rZ->h!}LzEGhBFi)DpbbZPW^Gp7 zNbE4M>M+Z+F>u^FCw$iy?*o374L=Qdl?`7G+^jRCUx6xl+!ntE_;ogXF>sv4p)T;B z4jdB#6G#5;-`H^E@BWevNB(Z}rXT5%zuT-YmA~6OZ2>s)cWHm4@*;oNw`}r|ziZrv zV}NqOCh7wJTA1;#HXM76$9>s`;~a;$F&mx*9K)TukUj@4^G_R&vN{jj@KwO~+HkC4 zII+a7E~L*#6M5Z+<6I@jXKgsnl5q6d@J!&jHheW)!Crn$ImH)k@hgFM+HmA8P>1S5 z{*Wc$)6$>bfIq?CjhFEI3rJ&(Kg&9lG5(lJjhj7q8!qxkc`}I!9j)-OurnHeWG8>@Iwr5XLuj;!7nJi*r;%E7UNwE`@vmn&z-Kcq(Dg7KMUna^& z_dlesV-Xf82rgxO702f=UdizR#G7ewO7xZ>bOJ zQNrgL{+8jN8KRyj-pTqqQ7;mQ-V&nErt&x|7;a(+y{P`3Lkvfm&h~X)%J?-b2knI9 z7&{a{`O_l8wO?J1MGC^NGK>;C{eCQf5dIA;!w`H%mDBhihHolJx9?;R0soK?dP;Z> zL+C4U$d{1qChlVVVTSN$8UG@~zboiSWQh8scn9iDLX=y=_cOeW;nx|mzK#2%6indyPeA`d^n_l9moR*g;nNIXP;eIdH{zd#eoVsk47r|X-N5+c40XCU z6rRZCORQ)7a)viCWWPv!S>Z`+|D<({H!|#Dcn8A=6r}qD(kpo}!?g?t7+%5fh=Q}( z4ztr4Z)S*j0?C>E2*ZCWIA;Sxw(p!i#^GPYKj$q4=gwxhieV)~_$~3xW&6ziIpgSm zi9T;W!|NITnBlJ#oX`E}eDwdsKcDSNeHY;=S2Fw%!dZ(Yy_!z@aG5mvq%h;aF*bd7sV)_jX zA5w5RIta4+^0f?W8MZP!havmPa;~4{=*MKb#~E@xFX#5X{8dHwBr{yiu!P|m4BHuU zKAtYdxgYo3!T8+_*`A(<8GoJOn+#7Vm^qJOF++@(q;DqIPbTM^iTReKU&8Pzh9745 zAj889xxAS_WBh*=%yKeBgC}`e=?u9)%i{4Vi~To?{WpvKCyVpV!niEce}W|4EHg-lp*`cin|!+er?5ljDLsW3k-k7 z@MVU7QV zcTE2yL-v=Ii3(qt$?$ZB+#XhLWPBULcQFhx+{=*bZRJgjvtBFNe^zomu4MmN`84zW zM!_7`BZu2v&Ig$Ogo10he%G-7uDOEg+}?BD3eU}8$o9?M!1yMHEI;=k<7~&=M;L#W zA=hW_8w$^JFywZXSHpM*L$05^%NYM4!%s4NhT-oO%x5|IZ1?AubfNb@wB=Zn)6pU7ssh;i;e#1_Wc z9|ilP7-TxPXTjwZ?`1hCuau8^m+y^ZBSnOCy=yLHm+hmt zpl_saYh9H;uzPcHP@NHFlZ|HtpFC5w15-9G8l3-x8ZxoLf z^Z}?ywsWscwyS(odt?8;0e?YRtYk1-cel(c&`3wz1joH+bza!lx^HB>Hy9u(b|dR^ zRjDX-l6`EfxN6%#S75IXyHhLnusY;|;Q?0|Ip1$EK0v!PlDjB>!}CJ&oV}yFg35Og zrc>a_kBllDaMx3*&pIFVdfV%paNu|4-ohqto3|z4tz6ewP~hFZuF>!JwjtCI2n77z zhHYN#P2aY)#Cu6w`=;tmH3}^STHokxrVa1|-au7lnYT4?cA2-OHPBY(4d8Igy#+>N zUzgY0ij%2Aqhnq#tkvJwB_Ek#%P*)F8X4{Em#;|UWW-QsS6^_v4-eMx1Q7*Sgx=Bd zE(^g&rWS%nq|qL~N!p}$kMLOna#QbPle14^pqG;-wItnsy~<_1sJZF*EZ2saI%?}8 zVbf_|;Wh2m?SYa{r$J0g-h+pB`MYHDm`*s!5bS3&vx81-wN1)>I*l_zd36}E)mBN& zbQ)_^G2C`Z#&jBQgbb=u%PFSQ>qQX|`QW&llsN^Tppj#y4#8<>dRr*tC5;EnC z{XnIT=&(=G32ZWE<^fW`jH};FJ>$C99ROTqI_-a2gO1hSPibtnDiX>}r#(kDU?iJP z`wcsU9BHQ0UacBJg6XtRN-(KXkoFYXBMrqfZI7IGM(t6iol$#~DXnUxwltl3b4glYSo`&UwjIaZcOKb!C-+u7$x6ecQ8~`{gc;U_%E8zwl_4zoX+OUiS)mG9vwD?p4l5cv2Fq&jXrGX;13Ww+DAGE zNAa@WK<)To_gEj!4DX2gZXe#&?}5zD{vJBOz&mDC;)b|RPSFj4V1}z&zg1|slV^$f zVu52ZK5$wh=*~ISX;c^F`^xd$ZmGy{5GffEX+}mIf=h5mErrCVNbW@ZpF={Ye>t$0 zAw}RGU0zs22z!T!^1s7g zx)_bNFoMoE@Q>2!OY=p@i))#lJl8G=iY5)(+Z;cAalYE`O}-~# zmt@TZ$b90T2;1~q{v2?vUk<`C^jm%mWj~I1ed&C;es#WCN5N39nE*8(`3Az8Z$&or zgO28<^~2hqUB6Y-F13DGSB|CM>7=(8KYi(ZBlJ5R`A*e7w0@^Q0KP}GFhH#z)==&G zWnTnb>z9jg4EtqYi@2ls=_`hQtNXz~y!z675%yb6b#X{D0c!nrB5bSQ94d#_56=~1 z>6h~u;tt}cFP(2A2ncJttZ4y04gXv7Y4Cks3sW)(6VwiD`sI?m1^5v?55E}p%k9DY zl}8b;uNeB3)_{Rz>Pz!Q*st^^WJNT6X+G{Zba^XYgU)rD36S~d-6eZDHk1LMhaZ&# z&l_WvV?#aOGw>i@Upn6iJJ;+2!|j?0Q1eBUBanc1JgCh2(tLOpVApSgm90ji@)G@I~19!soz4{;4l556^P!<#;#BYxd8} z5!U7CL>Oswy}cWC;rcXa`qJ|7?8?*?!2|c{4qpg@PJ`e9w4=Bqn#mS7g0RjM z!7C4f?+^m5_@(1V^2jfC;YU8h*ERJlp8Um$AMsJyw&Q2xdms1=AAZC~JerT_c0Q^L zN>6+){4`&ryaR~S@@USb`6A`ri#RPW-o{sousvVc#q@jP*YYCy9<%XL`dEC=Ax`Uu z=aMF0L^-adywdQa@+M8e=Rx(q^`K%CZZ@f3VFzz?z!Px<1xTP%6kKY%zbPy0RTu^m5~e%Bwd@saK^^t=9;jgQ)5 z3_hr5<*UbE$~VF;H;`^br*h=t7fYT8>K;No@%iwJ!S~UlhW^F`!)%iW06 z`4-#wmLTlJkFQ(qg&%xFV}QDCQytp)K6U}Rzs*tj#BdnjJyai^k$h_l%L+<8*5xlM zD=shc`%C;Dk57`-e>`d`DJk)IihTvXB1u0#@zOwJt#D|yAXymM^1qqM{YBKUr8V$< zE8d>m`i+fs!{0bmH+-M(fM_Z^KQMfG)`{V77YMJh^nFz~9@+3h!s>ZP&Ry*}(z1Hv zk=oS#EiJu0%!aeI~M&>+;rvcxG z_(ho>i7x~`*Ztn3b22wdJO%iE#Je*ONPI5v4enW;;&~!f^CUSG5`^W^#kwH`pgP8p`i}$G(btCl2_eHeldHa9(>V znY3J`^~Rc&ue_(A+uv2rYgV+irn;mM>Nm*iHwrO%-vzlIL1x1WLa0N3oz;PnJ#5)m zH6fQA{G5lJVyVO7HX!f+**?PdSTFpS+Wv<&+Z(;5w0P+P@VS>pht7#5&e`rI3lxt# z)gg4b$p-iu?P7x#N@#58G8`Av1g#6d9)tk^4OG3N6HeFp`1Kf~g~EJMUzBTzb^xmQ zb5!s=1i?sD`?bIjZFU^t6hqK$nEgsK#MyQnVdOxWQV!?Y@)vjjQd8L;2nIb_wV^JL z$L}fd`Af6lBEcX%lb{H{Z(TvjI-g%r+uCcYLG?=(iSTF2L@X~a@|8Ers6b7f$wpy| ztH@Vsa>(tN+IO^2M&pCDUpjUhz^fuALrZ&WO+#&Mka={}C^jJ+>ct5JW1b?(%Y^=+ z!JXlh;js}W*uHsI+S3=+)mkykQ%ihB1=uTyijIw?0`0--mMy{RW_$&{J&1h^R3eV5 zMO0gJZ98pYaFU3K&$&JLoEw?&=iHPQLFf-6ZmgEp=GunFKxC%1 zfy#DluobMYY^>eZ+*%W!NXM%Dsr+Vz>8Khg7BwQUy*;p5eq7%gsB36z5456!w`^`_ zg)3XC+ky?7K}NQlSj5<_@qsRT*fbrE9x%hrEod(dZ2{SAm>V=~*Ie1y7_4k-3$(Ud zWX0MT*cxbL3z9R{wn%Z+}M z0&Ufm)Hz_^Ybgw=K$RNU@>`9ROR#SO(_W|d&m(&g`e%q0*l@eO z27-e%f$GLKkKtGu43cR!w;3W=2Vt~P@RS9c8a8|K@aiVMPX>;cASI!&ptJ;}agg9K zM9RLzH&NQFE-1ejF*rVqV$9OnS(vjItov0ymD@f30`#L7ayGyz7f{~KxqwpOFDfl6 zD=aAj`6A8&WGjpEf`Y=r(gI&$Nm+4GX=!npuM}BaN`^#PNJ4S3Ar1&4P+>qRDK0Jq z?J`ND(tuV}P+nACQd&@6JZ^}~Wek-@W@T22zpSXJq_haVe_^Swyto((2F1wiY6027 z#sFN!ZoY#SIl_wXwPKpv``hjT~D0v zRz7aVPqR`!X(nJ-v^nz~W*i&FUICvnBcs&Lr_D&yFjH5~XOu13E|JcDw-w8pgtdix ztmtU<^jRy~)aGQ>^kpglW<|2IKu}rR5MMXx(2?mlAwwLJdB_BaAn8gILp(|;&`7!4 zF}qq@*QEQM{(gAC_e_2WvUSZ-oLcffDRY(?geQpB6O79w&k8-?qpr|ax*uB+;l=x@ zXltkoR<<`cHB?9IS$`H5kF<7Ac@dH4VD+hOra(F7fqa=HTVgf+a!I#@Yx)(EZe?M*CFOCI16feTa{i|4$U$D#*d<8*0{>pW5nyR$O`^%b1_pcEYf$fTdQ@JdD9VMim1ky8aQlyaBQ82Cc}hcZ?X{&wtOn_j1S}eq>!h`lifuh zJ7730SnX*a8tMmg^4~=DVHlU7aIFoWnJ`3-2;vS5p_=<6srbnuNrO1oPgA zxvi~Gbux>h(p$JCs0C4FLE3Ns8d2sU3=To)M@6|r;Rl4?A=XJ0)lcX>qQcWMZl=9o zoS{%o{9SRT!a4QxVxz)2`AecwO2ZEAIJsHpUuUD4TGZQ!rY;ROqN&kYDhs>J`$dzT zXll3FPBnFGwo^?_TU1_j#I#cM4za}|vB*2bR*Pn;xy_=PT5jh|EP2n1b8R#hh@F*f zL{r6g*@&iw=gDkvSIadOQcRlgyy%q-I3$ki?t)BNcbf2$*qy0dkQRdQ9vps4@jH#~ z1D0Y!+tk+3MmLSPb*#s{)~jB%RJVss>UO6Xw6-RU0a&CrL>V>W#)i!S5c&q`MNC6f z(6qU-9epxK(F#>xw~gbBU~qFY-ZaIH9!+|2igW+yaHu;Qr$mOv#zzLx%~WDa-xjE$ zeDwE2xD&`89}V@;j2}CtZ3|Rxij3YD>fBAySbo^Dxw5gLZgZeU-Wn9*P6T~yPBv~P zhC91=W2J$dn#}FVS&cYKbry=I(hze*&Yk^ofr43K4B7xrDyZaPWku6a{MIei?U2A( z;RSk}8-w=*(9vyfZb8K0(6Ax?4s=^>1JHfFeTKNgNhn!zUoXsf4bZm0R-mJyy@vQ8 z(1y0E?A4y0AmI2BF53ZZy4870J5T!#2Lq0Oy?4viS%cR;H)wX|pN z?d%^9QQhHt#LnHrL#Sh>8RFVFx@9{Dk=^|ln&V8391|)gjWcS=8vo@(BHp4e`XeG* zTXjChV+*h0M!cGWOS+vH%%oq66Q9*dTiRNt)VF11s2f|N;`r6> z-7Vya_;OYYTK`s@xSy6u$YxTIve($qaC0vul&K75wy6YF9CC@nTBD|uXw=l%HyB-= ztK8xTS{*6HrjD74)iLqNLREa%Eqf}h5#f#r+HB13Y zmEjS^t4$J~vf{h(;tgjxI)$nRESyU-t8}tQupNS-YM{eW}y0cwDtKRjoRkC6b~Q5dlgb! z&vlJM)9H_FlK->1B$Naf6(|$GEc{kbJ)rN#ntT8g6<@GESQpqFXl(_hyC0kZ|E+VZaH_SVn2 z9z2QvSW^EJJxBS@N|a|6ey5Y~EJSBJHbQ$>(>gc0UYh4dUFS}tD11(idNrq}G-Vsx zg^hAir>D^bw-qOZnCrsJP|Lh7j5)IkV!60<^OiBoutBwI9@)r!$Z5M^$Kd(tp;ZA*a|(Eoz+PjPiM(H1l;`8S8feR zC2E?tR5b?Zu}-NL-+~8M(-V$)(dZc6b5!WGwJm||)qxh=HJHv9rjD7SUZwVu|{jzyU!X3`Y0(>!p|QEH%IC?>3wx~f7c)v4&*PgYllJma?r%E# zMsd0T4kDa>IdzJ#Qfi_q;|Yk}i5ox6wACZV?CdE`xN4P0$KxsGBomX3Y5bQ~?j9H} z%0@Q1p6varS9?~WKsZ88xd0{gO%#~uIx|_%DI|kk-Wz8Y09%-J_WwIdp>}~mwVYZh zVkJW7}Pn{q}*H zZlAtyOWBg$o7+C^#JQe!5^%&4P;d%a=c?(Y8mA%0@rv6jg5h}8hP4=uKUipi;kYZ& znx(2af1{kAS53OFo8Aqa+Gaz|_%T<;^CR_cyAe07`93HA7tHqK5RXykw1n!QE|INTrW=7 z-G`bq^cn&wa1`jlU@+|bYvWcNcK?(^d@wSFPHbW$SSFyAkg9SiE@C zu~hQOLLZFgrw76K_jvJNPH*?n@P5)aOlGutB-#I!Aim~Yp_7D*SJ{NuJ!SKg1o0); zir&tyQ9FNcn5Th{FHtRDY6d319{$OsR*9HDM7BoU)$?74o{xh|oUPepivr<*jX(@v z)VR%^dnw{CQ6fNh;K?G*#ns481l)+41j0XQ;&MtvKEaiV;A7hM#PN5HP(E>Mm5C9Q7g;nPKl0(<1P^gR(brC{j+ukf3arpmuQ9` zJNR)Et*A$eD2IffI5<;0Y^C)!DxGga?(T_IfafA(WiiVT^GlSoWeZ-wRq2qXs>D}S zf?M<7IOHSVBB}s9G;C{Vs=-5Gdc&MvJ(tge^oS zTVUzz-`BZ+l-FVCR{T3=#@X0Wazs9t4p${7hwd;{ED}6wCZOkQZS6W)c0{VxW{U4R zb(AX=kh^!11&9)({3I)~{CidD%c7c#rupH@ z?)6LQ{*p=j+EfwzkN|B8iX!+GH_1oAzFdk;Psb{|yMu)V6R5}Cq0lfuYj$U@e4D$| zv%!Cd^cJnU)C-M>T;ZBX1fq9-Uk=OF+!@wt9G~ zw6S?xP<_a74qo1A-WVa1Dlg~$q+TPHPn4gz6;8n@y&5b*-9vma}(W!W(81=ow zZSo%JhDrBG>e-k1{>9sR6h} zmkE?)inPfxX{+cIN2z!YGJoWnN9Kh6c4C`%S#@CsjZ*rI;i1v7wq1R_T-A;h$%f3N zs}HNpJ;CnI(Vk#WuV30a2p>RZ?-Os$a^)OyM`R{;*fWb}mhjBPx|3u^)^Z#dS0=i0 zZi$yQV3jN)vuO5;T?}b6XGmNR$$ySdAe*(~oKxw%(gi`N#u3Jv;K&%Rp{)i}9F&i; z4?2R8z6r|(mCT34bxE$A?DL9U?Mj;^b$ z#<<<$Q;_-RQ;{hvHHJ*8t+#kzQ3U|h)VHKa8v8hjm=45Q@QK5M%+u^<*%jU8iu2gZ=99PaSlDsO<<7S=+ z#i=|IN^pKTDaAN$&+{JmpUM;QX(~^I(p8=ad7|Y><#b&wZbF_`Wuu#bPLwz;C~ z38&swRYOeS7>SIOc)xfH!Vk|q1FT=h80C`mS_y5#_qJ94FSmDeVZr|6})6-9*rt0LY`o>yAd)qtlRNF{N_$j%< z7+9)@LcL8xJ$=1+D_Hk#$t<-T z{-3$>Gz$2SuSt+wq=F9#Ap{15j zhj$*y-xjYU`x{T2GW(lpTnn%2lVpD!ncf&JQ}V>wRpRpbuAHmVr^<9r;;CjT(y~(K zxT9n$4L$p7;)BTa+so3}{adkpwKSO=zja5iUMI)AI4+{6HzQnTH{Kf7k3$RwdmaTU zrF1zIB%8!4i#QK=Rd9JDWzKgUD;A)_W_zLhx25tUh_LlJ)W^@s6`z6f2bTXkm8Twc zlJZ0}m7n__R{o<|DRU1*Q=Y1O&P(DDlt1E$uDojbRr?FH|Hhf4u4!|3tjdT#h035F zYjSx&G|Mxuh02qalKk-~WszPq_b%~Ml;v}oX&G&pzM*h)XquqP&{|vDt_uN~>zh zQSd5rAMQItmP^PvQp&~R?@KW2T{X=-coM{U$V!+p4{Dw%FN&*{x^k{KeY$y|#lW&U z4`5T4L%McqK-`EtevdpFEn5xa-O*6^*fm{ysavO^{>dgwy+?ffG*`}#vri$bDa{r= zE3({z1>zoL_3-Lb$!aR=Ma@bYaKWYGK4kUfoX8a)>2$g>78b~=(H_T*(7wE+R(!D3 zq1u_X#3Waku*#3cLCg?>vdJxYS=^QG%DHJx4Kpjkr_74%mF5x;A*=iSQ)i{@Wo1PMvz1EDLsYjMwN%o8X~W`iWc85( znN{@V`DiUKV_;lO4fIme06pBs8XqmvE6G0-_b+$lTv@mvaKblz67d7Vc$xk}`D}(Y?;g7{QES zm{*U8eSxVPnI%o?Mxk`&Nt1PxUHHzi&7wpMDO>nG1CtUd(aA-~T&~_w9bR9-p^_^P_0=d}A{IG4NlrL0lHMQpu;6 zDj*+c3*ZSTUg$d>F8+D2e`AAqUmS~Pc2j&LKZ$>NgZNO~DteKPrAaJbd#Laf(8CAa7p8pqA6alB(J zG%$>38M4{zz#cui#Uaczdg~4=PyDRIsQA;F;*ViEPzkjT$D|J8u+l*so`w#`W}w5j zH;PZWR^bJ!wn}_Zj&i8#P#=|tnGMgIIxt){b*hdey<;%6vk6L)!s)t{4WPBqvDs9;#X1{zTtZN((b4dZ)n|UCv|1( zQ&7&R_-&QA(v9M^)uVhflyOhBxS3>}jY7>(#H-cfPNl}oWqh$ld{wGZ*|vQ~ws@^Z ze1~l@LkV9Bh-Z~0u=UtXs^iZA@f)_o3?+QFR{TXuXxh?NGhHQ&iWh6efq3$RrY)7H zknBTs;@Wt;oJg%h6*yfs3Y-U~puNeFW2U38dZJEzSSCVUPdm~3>ct&O!Ny9?YKLln zRy$Pq==gx`Eos#vjfyAh#l2?wSaz98!227-w^%@I!%ijO2Myv$twAFfp)YC?@HJ9o z5&B@a8_p6xvjlJ%PD#R}XNi}U1l0009n`4!$64a9oT_d5sXn(!T%JH4wY`0EuMj!v z7!|+YB(6=M*Ib*L8Y^RXg)~stseFNJGzV zWeS`JIvm27mEvx#c(qZyf7L3ToaR_+@K`lK$>j)YOHN})XLmOZ%6hzn7}qZS3++0E#qx^h)y_3U&{TQqWlct+T~PSIfdmfhW^a3WSy<&^T@i zG>)^t*t+YOLc7JWXhatOV5|7OQi3cVQ8LOBrJ@|8`a!Ic-PR_q$uX-jqI4t__LoA* z_}aOs0#u#6W2LLOrCq#~BO7e^dns1a%~`6NZrE&^TCThe?@;&P9qRp>j{WkEykkGy zL!@=sU$x=6TzZG~z74hcFI0SZi@0NrZ1dq7SgjwPr{2*av*>X~zu{wV$mkEC6xs}_ zK|pyajv&ScazwD^&*|vMw~7~{W^DEsm>*9sWAq?ojRckPF_rPLju;sq+$L_$m6ab+ zVtwl(hNhV>_CK^0_<5D@^HKBNVN^V{O?)zM4fSWEdq(6DM%2ANN; z_NY4>WBpy{iig8hS5~EEIhaQrj;i~~tU7zqOs%^9#SZamxI)sFQ|ogQTUs}oRQi9J zEnk0^xN~io8?Y_WpkT_O8JRNwFEceIUhjB5D<%K+^Gg48AMWz_6XvN!wxXH*6ET4r~h{2ZLUp8WehQa6JtUy?%w8 zFAjH1SPP2j9sBKwt>5mLz`J?)Ru&TWo1rcxstc1O(7P~<6TkqDiRJv1_=Kz!-=!7z zcZsKqQxyz>%@36VfFC)tssqs6e*`{dJw`}0z@2X z;H8aj9WckkMID3YE7dzNHpYi4Ug{RNl|)zB9Hjg&#a4OJ%obXaa>tZ%=0GKt1JNpj ztvIn&7KbBMK3s8YNW5Gk+u|fE>*1~7*4P?jM2ncx$Iwca<9SsMbKsNZczy~ai=haO z6PBkQ>J#d5XX&^Iq12# zaDwAr;+W$W%Z)wuz8Wj}DPkq!k8nKlu*cK4Z6bj9*Es&t@OXOlMT8K4qf^O0A;KBx z%%v1@B{;sKIh^4fXfWXT3^<qIdG*o{9ySdvB02aNoQpaZ$>mH2*S9oR zQaG3FK@?j7*nXqgBCH_03dObqY}dwfo)LzSU4mje0Jbknwv=clB|mnO2mF|MA|#PX zCC?M!d5d|Xm{juo5j>wrAeB-?RFe`HzULFp?=V+XlS-~~aQ$9$MKh`73WDp#St`d9 zQB5k@s1ZD%*`k_MvV9(Gztn6IhEOJzY}kLvd1WFpo!qG98^+Xf!R^B`LK|M6`6tCL6QsMzB4i*&>>| z%2c*!*8|{tMf1&#qMT~huA|_)DVeif9)(Y}ZFd6rzMf3IZK|!amG^@3WgF@b-99k= zLNdYpW{+$!k!jsqz;wlIl2jU%iA?Lh5KQ+-rXQklM-e4$>;44Tj!3qz!DLa`q;1`g zg6&Po_E2;-XZ*alHmlJFSVFH0fmF{*^6tC~r86YO73QLW=ZoUsSbE~K}sHv(s^ zLiAGLY*Acxx)vSX+pEQf1-eUvl6_CQ`FPOp2 z2`AE1IYapD699VO05?%~5VLJ&90Md+T@RTLBeuqROEQYn6Ek5J{35iXZKLXJApt6Vvg=+d=Z&6DWL zzg&AKMJOk8eQZ*M@-){YlOovNT(3-uVV`p^m=wc~=Pox}n$^F^Hsd}oN{lR|`-&(r zvY76BqQt0zx{pMOQbl#Y86`>;Ha;Ut6c;zXHcA{9IDRln92YtM<|uKxOQrT5|8Q&u zX@K}wV>3uQBrJ)|pv;j_7n?&_C1E@^hcZsWr($!kjS`-Y&BCUdC1SI%#byui&tI;vU27C|-;m=T>Kepp#Gs3R@MnxHcSC#x*C&c(Pv-g{qp())R}IZ)fs_(*rC zqkW`vaI_ciQrC_Tc8~R8!~G5vAQ=A1Z=ZaIsE)R$SnIZ5@cX}aEC7zHY~zUhh8Ho>5L>N4!w7&^QKc>)``>Z za1vUHMVRL{44g(yM^sZ1_=km5BVmdljzl|=2uYftIg;%JOer)<%yTqi7;|;dl0DBN z5%c_229+o!4n=b&BqiYpZ3s~#o#+%;mShmfm<`Ddi^^uNn~+4qs0xpeLO`yz$SefJnq@GWAO4tvdI%`QFlsI8_PIOeZbK>S6iK7?BuuAk zun7lAh4dZNuQdPGu zmXgRX+9*hYc11IcEsLc$ZB2tWZA+8BzP(6Fa?HvF;|`4&#yK2>(&wrmF?6V)VZ2Lo zQl95&BzG>MK}Ow#oUafS)2R@myf1nE+ zYazC$uM_C_@Gy>B8{JS|Ug*!2|4K@VuuE)S_we`z9IrSQn#gPN0q+IgHq<+|6=(G1 z<#qMpA0Af^kB@DjvwiX9N~K1A5sqZx?+#(Ly)kyH#9KR6WV~OKzAt7 zXc&Y%I>dJXC;E=AL*@7jN_xBV@J#Y;SP_SzDkFCHN+S}E;)lA%cM^l+9~tr1UNL)cc6CJw6o z2v9qnH-RKlM{9eaBdA=m$=3x^#OD6ARcr^IZFR^kg*$L~biN-BvbVUSCbSn{IDm@A^RXCOf^g zdCTS+JkPh&s&L4908||MgZ4Pki?da+k6vh|_0>Jn>v?+kT9MCmM@0PP`8M3C82V4Ef0q*>K3$m+&B7J%LoD4&dmn z^(Esm9GDly$D0`D1i&$^GB3h0j+ht8$5bu(J(|M$S^7Jqes&!C(VDfokRE?YAJ;h6 z(g-)@p>UWtB=zff;Fx|U;R7gjQQ?8ZMkbDlagx`D&jAh|GalnwB5Y{l&?WI18$KWS zH#H6fEh_%{s$|`(Wb#wc)1$ z|GEud4*cCVdj(S*OTjUYbkK6QrrH|{cHh$>iy4!~19^2Jv!!ho;AX8mPzZPcyl?}(a zeQ~D0ARcF;#+`4A&jP;6hUdV=Ubf-zMduf7IC!1!vf;SzccRYK1^HMcbv$juv4_6n zIvb8N%N=z#9JX|rZ3^i#;X3yESPlFd8$YJEg8WHd;D_ymMh)P!?08rcfafB74}Qe- zTlk|B@D}{!g?PH&EC1sk<6|1nQt?&>vOh778Ab!eykZ#j1YcwL2E*eF|DhlyCq99` zMMCru5~7{S^eF!_l5+&UMerGh&!MeQI+U5{0=AR!O$=@65;&cNNSDm%2&Z(Cj&u^j zhh`H$`T;2q_#DP%JbZc~;YDc91d)%2;P-J~Oz%WEf<4 zA;TLPewg9s8Nv=S-C+ey`ys!LWS9TOvL8Wh*RSB-n((h-DbP;8977}Fut$ZRegL=J zgk$_FXZq>(_|M^npYZ>}8U?|ltjB8#QoADk=+zeq&tmv7hOaB=(Du8P@h23dB@kIY z_`ihX4B_Vz|Am5anGD$<__~Q(9x;GS_$mL6{XZ&)8 zH!)|uBZ!v_>hb}?Mc5MveTnLNPo3Wi4%oXvKaoz6JgJ@L;* ze=Xr74F9R%oDB@wzH|B*hkp_OoVOI5JDcGuhLsHAx5PJ>?KAi1jAJ||`n>rJuV?sU zhQC&DemBEC4B4(2b!7UKD;a)>;Y$ozuhb@mr=G{~OAH@XZ~@z4fuHfK8Q#W_uC}5FXD17W_vCEtl~@K{w?hQCN=kjtC-Gsgc{!7L|3 zG` z?;7^sHCHg5+k38C;kg+M*}l0O7~jN@<>ww`ob8zV2;>(MxONpo zF8|st#<^cv%k6G0+j;Hn9REcH@fDQxTi+QB&r;AopW#x5%;#tO`M=NfUn^L^{!zf~ zs^CM4Zq5hq!}A;1*1-5*MDSZ255J)M0uj#;{innm7@|Lx_XV313!_UJxeSiT+wb_`QVhVaWM8f5`Zs6^vWV5Oyd2xNe55XWYGv z|AgT`6{P!f;&;_E9AtPiL$o6q54#d{Co4EBhauZ#)-HvUedV1gpuR6#k92fjR!C6g zpO008VK15^sTTR$H9O@ z3dchJ7zFPhkQsEV)p;Wyk0XLuzYp%h*RJ?9SDn$fb7VN5bM5Tv8VT*q-#IcgKAc|= ztQ?>dx`O>(!@D*$jO`A23xY)O`D`gkWb}6cAfRkJoh=t^8)_d2w(hU*JgXq+m8Z=` z3J8BO04Ya(bd+-Ng34y!VAbx?rZ!)&w<}84>IDNN*te^g5;XepX;DM4)K^>@l$qOg zHJJxT=(z3Rp5gNL?xFh7Is1!|B0{=8z=(>mkK%&9k-n{URsO*4&BZ}=T(_+lSgH;M zy9a#vyO3ZDfTcI;DX_?OBgxdZ!kVU2WF7BDR;%AEONZPqq~C2^$?~{#K;Yes`0-5p2{&C z{n9l)78><>+v}Tx4Q-Ws3!A)c-j;y3a$RFVfp`15M!(xZ>+*VAaY%S* zbj<68wfg(I4EwuS@(ml%?O$%ha%EdBb8&U+^eT_?qROY^Qjw`;hT*PHqNd~f;nm>P z&PvIr?t-0QW>(ONt%gInPp9QXDBm5?kVwpQT2fRos1j;eBx5=) zD?$cUsO1vV>5`%dpx)Z{1r@0>1CNO1%=z6Ua5^0`t44#&O#O?~&d9lBTFaQH(7t5K z8M~EA{q}syCSzs}B?Zjbo6OX2&y_4O(Vl)!+mCeLL~b{Yfpl7fmDLrU(wJ^J1(cai zR}p{C_zL8Bjt3u3Yju$okGAVbPY5Em}%F*X=l_m z$h0%+8e~e#3#cocjvH`Ss8YYZuE8dQ{o@qJ8Y#eX7D_!GZ?P94isz7+>A21$F;U%! zq@98vox*JgW~9Mju%ILu%ZG#AL0@@KLASrF9E?HiWzbfS3ET|Q;ca}?%|w|6oBdCa z4Pwp+v6acBNIlglnjD3Rvlkz-OiCjA-m(~U|75!Kit-rrDDvgKq}N~gFPfaUH#EhZ zo9D~Bf`9oDk+jv1H)@=<$cF>RCRFC$4eC!wLu+3Eu1b6oL&=Hwffb@kM^v^~s0h8Ln#mDj!xLW{LS?fnzat(OE)|ZH-i?QC*PlE5|p>OGSo*NXdvuGcw{3 zT!N(rDI`8cawp>d9D#^wUyfJ7N-40WA+I9*C(-)iu;WD#?0jXwqwpD6TMgq|4;1S@ z=B3kM4NmfLglGinVT6D#1?XlNK?ljFwEEI~5%L^Zs}&y21gQBU zo9vW;AJ$ThW%$LZpW}8wq@jjF*X$nr^H7K{EpHESyS(=RCqE^5e*CmNE{7@aCS>~& z#OsUY$-1=VyNJrsu9*NeAJ?yzx99-ul02EufwfM%eoL+euJy}9IEH>pU}Hy=dW+OA z9py0U@zYlf{nB56eoty9K<1P04%zJIxf^j>zkGya=;wI=abEoNrSokB0by+y5ArqO zGv=lFBJ7vh4~|DnE>k~&XAXAzW%+<>{m8#!=$Ew-aYymfm(DjrzZD)ZT&tM?HD82& zD?X37LzDT$U7*?Q=cRIJ{R$9{p`Z66#8DrkFP(3Mek&>cH2iPncJPso`eJzk?^@XP zTSf8~;79F)Y#BqpRcUy4>L}v%6+=HC`Dlw~0@QpF_VdF>8v##TwEB(EZ|^S1h{hM8-(Kh^zYM4R>C)whu=4?w!S#${3FE^v zB6~Tmf*+W6#`Ba|<+v)F`2ggl^NlFSRb`01iFpWUzKC*M^(5ks5(8hF56=$m`d$5b z;0gGVKYQ@gcD@~9q|ttL^?fMsr$N(~mWOAhrVa?ce>?t>41MYFg&^oO2)-Zs#=WAM zY;jcaI#UEc0KbhpgaDoqo8ue#E!F2N{P_AXm4Vt3mBWc2%DVw^S{}_EHD9E>Lx|Jz;%$7T2;2304EQ|!C|}~&@*?@3v++^- zSbWE9e2F%`$Z{M5w?}%BliL){fUp-w&ugL$S}SK zfNMVLpEO^Dejho6IIZ8}Dfpg)n`I-O@;xm!-z|tTOeD6GnIGrz^ zYsZpz=M9MS;79qEE|b28fdH)4xJq& z3xo8q5x#nyIsm!jBwipeb{Jc~v9WIW8;9zK@ADlHO*!WWhA+=LG5qZU;Wd`Nujm1~*<}wmq#a%5HL8DI>v_;uH=OB^v;{}gGvj0^_2}Zv1R0utG$nJM49z<_JJTaW zbB-otZj_R|T388U?ymzAzhI_Vw zPutmFOmmUhu%Hp@&|hP9V8jbsCs!`!l7pS|kW(ym;AVp4{6E`=+a3#=e8~!Y$8G;Z zo9zwX30zKiUw8K!tR&1ynQg=y@gm+4?@WkGa3#1C;u8`QW+fyhB*iBuQ0r0SAZsZ5 z!FNJNwp|ZLbUk$b={j@3dn;2fd5_~tF_4&QJo24N8p`nw-d;Pd z4FB@e5bs1oR^=5FTrSuDU&@8S59#mSKnA`Xm1E-3)c2`?ldDVMPG*xt#QN*Lgux=5N#%+0x8&sIf9gCh_fR|$c*x*%(kl_X^PB< z%9)u83Otmlsca7fgPyF~P?yK!_Z0a2rCAv6fX$4M z;m?tYSYD2Iml|bMpr+1bqp-zQ2 zJUVI=2W|}Y;&b;gPm$zhLjTa<&Tz``*a#DB-!?1lG25uF){0@CS>nT-MoMePChCFq zV0FuuV0AOT_TC=Eo&_oqN7W*#t+}?Hwl6qIM8s#?9(=ZqOek{}ilFu3HVHEcVV`b? z#h4#&hfyaL5#@t0))3v46*4P_3sl)!T^}rI3u%JcX0!l_f<{ zxGO15VL`aDT3VZH8yW+Vnbrm>+p(E^u)eafc3X36O?V<5tMU&wJ}0b!Vo@Uk+uH-1 z+=BMf&=!!* zhPgq*(PWj4jls&cwm@sUMOLhhfvtf?wjeoEZHp9#U9r^UX$^WIdC8|F&&M2Q6ca`f z1XA%Zjy7Ggc4>0tV`CAu_Y5-<-$MKr;kTIfUu%O}3ojSW>{jl<_J zH$-ZX?1LH(QscwMW?}(Tg4MycEw$L99cAe6H^ib~u%!|fF36t9-M`v1;aRc5v)>Sl znXITb9?yR42%csN%br+`JOXXimDD-lj5jF^sX&z)*z#MAluNKb0@Gt9B@M=7rB4qA z8=E)R(a$4$5&CC{6*ye39lIp72WtY=jcp#ou`(DW(`;@tM6M3PXrtgM3pO=i;{@8x zO^gA@Tc(mwSWsF5(l|))7$Rj~;+rV#RTq@six_NeNHJ#V>@3XL3)cNApUUkXe*yZ@ z3ppF$lnW^D=3GE2@E4U9;l`*4KvA}6ISM2{Ix+R#kR(57CM0y2oG zR0f$YC|*G1LlF^C5lYp9h+0%sZ~(jxWl}_tUhvxQx7ObK9nN{rX%ear-~aiar|Ew8 z+H0@1_S$RDlLb|2R~r756`&MgSM*g@sHp_0`_9IwHOeawR+Ab_Y#Nepp-VxW+!YR9Z)5cl!Hb0pBczi_O%U5nk~dUHj12FPR?8zb z)M(+)5dR7yziB$$$a79!#_<#4aCUp{!~7m6#PEC-pSu0!c^T@ewDP#JHg4P+ zb5jz!r!_Sl)qR6BVbV9)-9O$F#ZXOe*5z(diW=MD9KW1jnKv0CCW-0JjK8#PE6iqua2h%JBL8G{(W~mDLIHi8OO;q_9&>fR1KCWPHnS5o$$Hd1MTa zd|V;QgXDujkoN{r!Cu$_d2bV^u@~7--n&F)u$3NGl5rmpr%SJj{FpdH`c>>_#F^5s zqQ5Arm>OOq>>M@uud~5SDc0M7rYsFMpefN=l7*e-1ER?eG^J~{Lroc5>`+tER>`Z^ z6!bQ+(E=%ww~2Esm?`Ea3ua2WSuwHbJtNMu!4yHfB4z`cBEHWCG$njLv%#oV$YK>9*H!! zU<)h;derIdiFWso4oACl2Qd#nHa;?lYNiTZ`fyz>@zDpgFcQceAC2}&;UIA~o?i_eWqdN_8HM|Ys>fF3w&rt9`2->|Z+B4oC#aopl zBYn}4+`LLa`$oHR3n%LN+YRHx!Cl*Mt}mEdxDhG71w?C)PPAuAMDHS^O-GfqXJ9Il zehoyiXBsKQ2|h#ohP*9pn&qr^;+~S(Ad&CDZUjuw>>%&3RF;uals z;%HGf6M`A_D?af>9kn&wnp9q_Y5K_UeT@wb zxAam(j%7%-B_mY1&oB0CiJFcgQB!B%pu0GiridSDahQrt95a>@$MnZ0s`9ZE@vN4m zwXLD4DvVVKPO^KBwvO~Qb&hVgv~ppp_@frXBp^i@R=8Rv&X|>trHVJa6{r;OPNd=~ z<8h5(d+=4}K!>${BDQq!stHze^$+El_b_F_J;~8F;`z!}Oj@?_%axh9y*^vtUVkN* z|2>nfM<&w))$7pR=2>j&&YJyF%nv$i6%t$bb&Y+KsgG=w-&<9Z%n3@+Qv7A(ZyDtS z>Tb-**P)|Q7+D`#SJzzE)=(2PyxDj|^i1l%6skUqUU6uuq6xQPDK&QJQp6*KH&!E@ z8^dasaJ(w&0>!8iWY??-hRQbP1wTYm#c?LWV2b%my^5gPT=X(%0fBorg&Pg;4sAiS zPnOz{4aE5!JGk4?7!P_Eu}y{Uul)~FQ~kl@*RoWW##!kj^l=!pXRM1A2=GOR>}^Qs*d z?OgK}P{&XMy?0!L9?8w_qzk6Ad4zz$&-$u!>R5={mW|bob+oLrT9a?Z!qw!6qhB;S zMq`dj9k;%wycIP3F~s?l4JtGgJSCVLivpbOP*p=h3L_EJp?Hs4FRc7V=wf4t-<#hkr!T^@ zt#dR&`_9Jt28kdh-~KMvZ(LUwIR|TmsG)oNhdRgdXe3(S(A?0D9s>BkWui0!h37$f zhQ{&uYb@en%%{nCiAenqUU)_;Vw?6X?2W9hui^ViNFV>eyV3G-?dBFTi2pVHDo?TK zd$C803^wkP{J`5g+}+Cj!SGMVU?b@L7$kgTq&p_V7R3cWKUP3%A4h$${ ze9DUz#&hf1TF?x^`xEk_jcRT|RR;~xle|AAmh`IccdeWRACQ6fX<(jYTJ)P94LMN)420JOZ*?G4MlA zTP`u?<|b9)iWNZ}j#bJy6_bvs{bwzA4-A*&f=xj%cXwW1a0L?7s}n>~3nz+9?`dYV zo+(6wK0oF&6M#EnI{W_}sgT#~;HmGar6N%@q~dC%0_T3GlC?mO$yZ4L)NTSbJOeTM z@6bg|j+z#WQl$-H5;s6>HlrnN!L@+FE6+hMoINSGRb4GA@G-#z{j{8$xqSP7F)B#_)E*^jcr%QO7}j2NEs(UL)iGje zYBC`EeUKdoU0h-o?fG{YEM1yKKUH`wZ}M!n@VMqOy-33Cep;Kr&cn$oMn!Pw#UcWl zPxz@0MR%mJHk8|o={eQKv9-#Q)@eEOj+W@~P5LHnd57X;ghz(I>Z(G*x0 z$nK?Vr$NW_N{W>P!}F@m*J^nFYLM=zK^>iSg-O)J(&wwvEu;7ev`M z!d|xsd%WUCD*`n|8r_xtmuULXlnCe=+m-m6UU9pHO%0i@{&X~EA``PaCNUk6NH49) z8I|9niAR&Ejf|$k%s~ZiVk$5B#Qhc()P|<)t||STUp(kQcQETTcOjGBA?k#Z_1Avv zJTPUI)oe0G6g4W7d0mS5UToB(FjX-z_xM8{Q&&hjrfcHfN)b=RM9}!I8F_1}c-?bC zWON5sYGHnRrLLXkw-@I3c&d2IvxME%FtCslmeo6|isyqn~8&~(d3qW$GG z@pbPq9mPprvT^1;vH3-s_=pH(de%_h4m_`r@)>CjbVbCV>2(GyU8s6EV-P zoiKpBa`Go)nh8MbB$fgZ(k_|R__|ePCO#k6x+jcxw1@ckPL(RgC;v#JtMEr>_X}x` z<5~~P$|FTuT)h>me{#Xqn#cU22NRihdniqeN7IV+RZR_zTY`q?Td@%g??WE1&--nU z&nF)D)Ydh&S4GY)4q<>dffgN&-}f~zREqHlcJ4ia%^S6}qZu>vfXKc>alIj)^t3hv zi&uq8LZuZ&W!U9cUa`6Y_VQB?ZGMu%v{zxiBSO1og7n_3_?ayXY$M_I4fX99CE{VK zV2Id1ZAZXiErk#&(+EHJsO2V_QI9220SdqHD5h9!rTI2WUEu`Z)QVYvU&e-VGRqP2 z9Majk5gTx2JjAIkE37WV(EJY`Ug9mG48WpcxS^>Qi@>zQoVK3xdaz!$HNecAaDLivV#xcRt*}toE_o$kOp`rNqOvbr*aBl?t&-`4cDEav`!jz$iaKMZ} z>uce59W6Fio*CmYuTEM^eSNsjj1k8O%vlC-d0cTRE7A1xbDC_tK`k{Eo6P4tnl`&JL&Xi-&ncci#z0{OT- z8XbnymfKmtySY1qYlFEvP~gXCajvSRw~WZK0@0cHd>a3YwG&E0@l^FNpi&kI7q zz%;}I%q%>P>wc%nY~|#ceUq6@j+06h%b!^Mhh24LY3dY*s_Zl^73_Cafkk8GBxoFn zPnks^VSHOYJhi&9Wm7~RWH=X_ckt9;9i4?hJ^74F(B_7Ag#2c81GY-GG&gR+d~kx; z&nLrSGV;8`%{)fBDsGG<*S^gC7w>8*j1Ey)qbcjUMe6eC+dxSSg+q&RdOfxHOtr?M z&Sq+XY$T7_2hSsEhG(rLEN#ZZF~LC5t=NC$Z{4vP!!WFg8%M+*Z=jXVRI^{q z7MFMzv~n@$_4!O}NP?e=I{Qx%pMsx9c2w7+`~FpNjd#9;s2yt$i5t9u{J(h8vj)cp z+B=8kI(vg>nUOV&eF$Udx{D#tGGEqk%}}(r7gCWo&BzWI&#qozUM_T*J><=TN9i>a&K2M#sY2`g&DX zdzPge%%rOiv&=n_?#|JkNKbEwbseF@s{zl)#oIId`TJ60n29ZRW^QV6G83mAg&Aqf zb68w5)1QB1D(8TevKVG=`bwM()|oddJ_X8uOHCu4wc$NeHeNPC0BZ1ju?BduhHL54 z!+?kQNd2H980nj^Oi zJZ$pBmrwG}Spnm)o#$P!Kgko}8ImWyG9^!Z1>Ja3I{lZ4Yryj->5`|&&^+l& z@}#dc?;YtVv^Jh8Cu*J)E_u?I*?vIR#R5;_D3QDY0r`=&|4DJm^Kad z^z~v_u&&+G71jFA?lJ6`rCo5S1m_sp{Kb`$^R*P+=#pmA)`_Pf{q+mpYtqNaU1AwJ z*BUeY;x)*9aN)6$TeWt_Kwjwp@`(IV_$Z7nf45oYCn35&Vt`--~_vc@lnT+Y2nNwvdGO`16Qe2p_qGx|y zTn(n*IWa?-e;Y2+W|eXKtt)!DogDpQUrbGJ2Kdctyv3qOJYTb)DMG^aq^3E}sg^zRg&YScL431|vG_oGVq z8?pm)_qYj9**)h)u@Ax@47v+1OMdn4B5l7uv(+_qo{}gtQm2p^RAa@b2S77D^I9oA z*@5(1T++f;H1`hiEYfoK(u}Myx^GC_9O@>>G_=*%x9dcJrZNSF^0;N8?2B;z(!nz; zlbQCs5%C&mefWa2B1c9rz?z{^)s0}DNN^h)+WZQa zgwAW{g!Xig#nwynek3jn`122-hddc!jKf@7%{~yBNsKVknv^gHY{JZcLTY{P<=KH* zX)XeB?{fZm;%gA-7dev@hz2=k9>`9aQy}W5nc4|#vI!J8PYN{W2ibuc*SiTsWpe&2 z;=du#x0a`8HF0*K(lBD@QZQ~cXHR6e5CdqQT7fT3+5^p_U@LPU#+^~iB)E?h_^^2A zc=UQ#Op=G{1SuYz2}yZS@eI5mE?wf!zxd?I@<54!W;GA^lBR=AdqJJp3mz|nN28^y zVeB1^I@_+v>PrrthWg`Gw%{&t%L)GcpXW}2RZ_LNvm(tcTqy1Wt4H&u!YY~eTv@RK z7hWLl2dn$?V`qHW=yYZrSHxMPElw3e`}C5W@xfGwEN9jf6VEVVmLHRY=pjV7$Sr(H z+>zaTvvTIy&Ua=uzaX;OG1$SSeqRkocxDKtT}C||q)4v(&k<=~uAm6d>27S%zv(gSnGS=`u4V9}Lg z---VGn^q;ItZZ0Qjw$=`l*xb>{ZTvt%5NTpvNTzfvX#M9bH!2Sj9q-D_!%fae`>6~ zx@lv(Ce7-|8s2I5t0|K{H&$FnF1}IRpXJa0L19u>NFvvQxFcPn{W1LLx5pr@J!XmMMOUnS*V zi3d*d=U-C1Ft)L>P5irDg_;1HDc?xGvmxTzEu1P%wA8%Ol6JEbeS`h z4C+)&mKkNw@wbT^gZ}*Amt-VPS#q6aMF*oJTX#zh&dZv>3@T0Hsg4^Zk2+v63SBZ+ z{0MCKlm(Npg?ZUlQj(_;)$6>h5%dU#+dFY40$n@AUTDfjYRO>P=qpoNQoL+jg)g~O zT(s1mfAi`jDpB)QTK}>Tvi@B%8?w!D$VTY%EZGocp_C0@ixSF49jFts#e&s%Ubsb}Hrn60Tcg8nP-rA5keN#+%Cl*i+?}I}Yjn61 zcX!6*(cRxS9O2c^A?~?Q)scffj&uLtVeGg2 z)fyacapEIsw7wCKe+c+jtQ8mfmP`7ysRH!zh5%MTv7zsOm%!CV93He&3*xgSw(; zbd25MHmeG;wu3UZ=olKu;MF+XF%}&d###m!n=QDbN0&H!D;Vv%!_1Rf>o6)`KSTV* zAp@mQ%W#Ng5c{PJV*ey$I5Z6zzH_Gdynh9@WreG7pd9It*&z>=JJg2trVcb$O`WnL z$?O=6Zf$~)BygrqqfxoH3Y*b!`0VVe+S+oR98T1P5l>a=aD+98g>lj&|IdwN#8h6!*Yl+6$NYpe*yjmk} zmtstx#+Pcv*I10IFfQwzhAv*K72i|3m?nj<)QP91CUEuGbVT@Do%n;&!!#*;v0l8% z6q+`MYbPs&QTal>*po_j(6q5?3em1xC$3Dzenu)CGQpW#C^A*y$g~$Z%92dfRXfN{A2o<4wFHeS34N|fz-gq|B=jK(SDht(Wf4$mm=c8pXNi|21?2K14b-Uo$64a< zDpq*%vF_d=E=nVd+T0#rE5x=sM&-*J#Fc5ZGq$Ozu_}R8u(C4al|x2#N27Roc|J9O zv<-pAGt@)R39MKVMw=%xP_tW1;a3fv$iS>_N?YZtjp7q4R_N%|$C8c5iUEqwEvPLz zwH=+^-P9=S_7Y_LzpcE#NjzjDV>atihVG~nkSpZ0Y_v`4JCpj!{Nw_Y?1NJkvoP* zhI(-46^2Y`xs-=Ch8#B5e4<5MnaeWu4eoT2O9?`# z0TPi2ka&g`$4$0xw2HSSX>{GU+qLB?72Zc>ge;J9fi7L`H{wtBvZ*Wp-HmZK%xOQ~8;V;WroBcM_MVKMaBhk1hD$gnW)Im5x;h2Y}Oa(A5V@kY7o*!nq+)PGCtIi zfbr#<#I*&S`7tThLl-eLNxr!M(3aq5B;RLT`ED^PAK4^6xAGLK&*&VMs-2AkWTQMR zfCaZ;*kRY`0b#5;xLN#WC5zkLH_|mtq5uRO}JE z*c}u-I@lveHpZGe&J&M1MVDHoX*sAz?01#@Xj+}UXu4Wm^FoJs)hQ6`GPyiQ(WN!e zq}2b*botl!iQ7+gn1RwI3KUd1G%Z!GdULv}#P*J7vIDFBy5_49@sv|8snTR(9ZjP{ z&?G17U#Zc`BOee~m2$HXyY0_v7z!_z4Z~&B*=>GxNm5od>T>=Cg zX^<5_N4Nek+rvd2gXWg%Eod84qm?gqi<`^bMK&9$(2I#hj_cV%DiZFH6wYj@SU3Q! zG}w}pSY)w3R^3AlIlEqMr z#Azoj*w-tLGY^f1H`dhDh4F%r1;S~%jZHYu6RB&%t*OQZR!C!A^E!ET5#S%O;PP_x z2E1U>UbEi#uoZyYd~hR>@gWNm#>vc$ja6;Ne^{{gI-DA9*y(B07}{N#i5o2uq?!CFO|JRXk}y_LA@OQ)i&j*cI9YgC1JPRDqT!%!LT)9Tva{Wyg$j!jr!9p0ZNRV1En-n& zN#f)cmvj2UZV@R%6H8jiX9Yjt77>rm;Ev}cnI58JhMkF{Cdqo7lQcwE;;2V6fbPUm zlbJz?Mea!)IhipOu`xswM^0)I<&?9%i6bX9jEV|U_146(lUhfpqMX#dEphZo*oY6c zihes_-Ok0w6<*BwLRy>$>!?$Gr< zi90JE5=T;v9Y~&Io3F872=6NbBa_(yaR!H5%Q|PHkq#Iy0OOM$!q^*+LF?ke3ygaS zV@`@V$=G49t1*)w5X%vMP=$ksJ)F+Ai8_S8rou09hSSy;5k>f3ucUuOI1%X0rGU5u z7+=*GUMB_$3^48l#?u-Dim(eoHyQ-+%!%;6r7`9@G060R@-k3v^eI7NQcCuXrSv&K z`L;%hNh~*90Z#}h&k+g~x;TbUncN!XX$Q{5eu;Cc69;t`b@&3F3E zRVkzWAD}&_(P9)KRmy0%f605vOfZcv)V#x(O0Ms1Abn9G#TYvyQStSk1f(A;qzjw| z!AM+${k6dQyTXbsqtyVXEZL%{=Go^u11R~?vg2&X#a!2dqv~T zbrDV$Yyb1WyCz++J;?=6mhF@@;C&;VYTE_2%9h81yxE58!<0fG{g#oSezQilkVv&D z8-aB3Y@)Q<6^T@v@rj~s8tXRY0MOoIv`5_0Shp#! z0_~PLB-v$iT&c<0GIb&F4lv$xC%WQE-KMSq-k%xo5op#$I;q>#9^hR&m-wO#xS&OP z`zE42=nmq@-Ic(7lyOlI662DlQ^^KiWn6bnE4rlc)ZYX5hIu5zP%^r#_Oy9GevFa- z;+{K-GHX9=EwJBY?C0FIudq22(zXNp^O&i5NIYk6)-5B_+F(0Ry8-AwVf05}<%ty{ zvn1_tpkEju>It$$QI|QB_7>3Z3&_&3$7k%o+67xX&#?w(tU&Nn6pRMX5zLkM3~v58 zI1m#|710c2J9WhH^B>grQ_Z*>-Y3mu$bD=8y#kQ4|AHRe94C-gB+>@7QtO9}3%T4D#X{sCNT2eOs{jM#w~ z^^p1izSs^{y#s*nw1ZWL0N^L>V92kjyl#gh4GQkfu)~oK4L{uuHyd``j1{#9PXR6g;~<9`i09(%KKeHIFTtAyM%BuQ|@vJkqJ#X=n^E8n(~%Q zkW6f9mP?RIZfdZ^$nSPyB(Cq|I!NL!Z} zLuw^$JTZn;PTJ=aV<;V^{UkApQq>HR7)5DpMv4~>s>M?2a_ItNF4v6s4j ze6V}04;SutAOR8Qk>9>CD%z{M!I)zwvH zX@Y)~)=II|ICU->jHU2kgfEV3ScIDnbBtNDPM_sXLu)MGn_l3zUYt&Gf>25-Cp}mAWM|%uouKu)W&$B>;Jb#5jDGKYc?o1EGnOY$A#plVFWd-B;7EUYR{}$vuCA)boN{pbJ=Qka{O>e`^)JAFPxC$ z0kxC)1Ifyr#{qd5fKsxMgZcDHAE!td-rZP$9A3EqqM+O?fcU3UNJ+ZHFO(jN5z=tX z-7gR%U-1Hi@Gyr@ADG5pg_x(!t(;pi*PC`mdcz{An=&U@0#{qWbqcTC0?Ft>aIJ6x z33QqTTDOP*l@>ro#C{tm$S~GgfOXK->6X_L^-QSj3}*ldOW-ptuoRboRTj`jWTs(M zI|G;qz%>?F5dpCFL?|r;dki2S>ZHdo>MiKzxm)ILLMqoukoK-8Vme-ffu&dGo^ZOUL<-(13!JTnS_xJ7#m<6QL#q0f__gwP>B4dZN{|MA7Ty^b|r4thd^OxZ**X&C%P70f$r!`qhS#A zf>78%bZ~6+G-OUFR9@D-5^Iw0LW_6|RVuN&mz79#WQDQHW7A=Enc51jY=N3v#`*@Lt~nB1+2FWp z()0sre*)AFS3OSxb+onDbws2|HWhXO6mz*hT@~AbwXF`mQn;gZRpF`-3}k0%M{RT` zPULbJ!g1wuhebDrh>U9n;}zVE=QM=rvQG8j-P+P36s%fFM}C+$N!z_x)^BUT8{X^d zYBt#6Z7my{Yq6ehhgIW|^*TWD=nu-{Krh}_#XWk_>E>7WNN@1nb<}mOr`_3k`U@^v zQ->c{dpi8M)N}R<;N7d@kYB$|MxZr@k^U zyBXCseiN0Nk2~}|pSJn&X1QmB&3_{Nuvz&-eCSr#^8>mOpR|R;b_CfI|A4<7ezVNN zUy6VOD%gO(0N?lEk8I{%*dxk|aSQ(Vhj99RjQ_`f%0H(4*)p8ssvp%SRQEJc$o+<~ zp4ng)D#XoUPkUeB^+05a<~A!CHNMoYnGB5P=1t^T=Juga5!v<{bkAzyJ0`_pTplT z>5DGqA6EV`={FFrs;mEu3XUP@N1QOhjJfPF7lhhUr_El(xvi1a1Y8NyQsg|9aZiplzX#szoA?u zujh#Ldr`J1o)=|+-7}RNQSJwoyH~lNQ7-Bm#)lr*-7j5Jf8ci}=>_%fYI2dEY#(36 z*qZ!b$5fylei52R@2|X zJ}luWzfw%a$A+F@-Ous<^Lb)rm6f-YghhW<$grDsAovNw4W&V*V3JVazyYM zIm%t5T$Rr=u2TLdl&j;tA^kH|`ev?I{)?1*jdGP;%zR1uXDR*9I!*Z-mD{7-+m!pD zbkqIHMSDSVrlYN5cR;xpEBByuXDdC-&QyMsd%~ZM`kGzTuk8L)x^vblSLt_7pYp@L z2yf2Y(w#e7xhs@grCiu8;muY0nfn{%|GRYO%~$THl#6zb@aO$ry7Rl0yFvgAk7e?p;h&sXk~ z%2nk#bFTDfD!DU1p!{RX{k(GjEM00VN$)2rJ)HO<<-ba~k4X0Ie<2|8VmCq-s@_o{)5*|!fZk}?>lzX~z+m);M1iO@9)#Jh2l>ZCL zRr(A*s{DUd?pw+|BHg9)lv}FYO698jS*rLholx+PDECt3enza%QBzh*1@%~tlCt?VaT@y$j*j^p2|T*WsV{Ue4SRPGDXU8d@b zWs2{z1qz;{+%?LrR_0 z#Y8^KoulkNXPNS!qTFKT)+<-(C8tOE`<1KgJV%x19HpO}+g12I%Ke&hmA-P6o^t-A z;D1rBvX|vErGNQS<({luRUVd~sr;Li`#$AHmAg~9D&Ll0qx?#)<;s4Rt9)Fp>}UB; z6y6`Co3G@^SLH7M(+d6r>7JtU_Y`Hnr(CSys=ODZNPj_=a+Q7y)++x7StB>m!ykR zP;9q_rz`g?>4xSjcZqTpUP$RL^g{*zy>yF|eH5v3Rdk(%oBhH2v3>*H()g%^+=o>- z?1IJxB2~GlKiS`)T-3+x|Cn;`RxbE69Cl8wC!k!^gY4g|+z%-i>1H_OXZI!P(gtDj zdr@Dr3%h6cqsmqMygyd{ze(4(Sh>(U;rqIktK{_EtNg!E?mwmLN4-G!{`JZoRPMFP zMLFVd=#|`*bm`8>SFX~_jBV0S`sI-+Ts)wRL1@e0Wt+q-ua(=!*1r4R71fFt$CK zQxqXUVWBN1k#ye!00QNk>20}4>ALaG`slg4qg%=%IsDpOECJ`n0K^MQ9A+Xi-CCbz$l12s5|KY9bGg&~w|79m5sv-9zgk zSt(+~P}dI_Q8IQ>Sfp^I@0@kjp}OtOr4jjDw=Ef%s*Xmw2MSkhLxe3=9HF{@)9&Jt zovn4HJuVRjM*BuF!#yyJ)t3>Dwsj{*+g7omy|I7S0PVPn=flyU_3mztQ`bnZ4M)av z&g%SNU)!#c@!m)sQL(3cbgT#S_KaS>j?u@)N~<>wbk*%F#6w{c-C+VMVOVx?fLDbK zrt}c|*uqg-61cuKk%lSySeM8NLTIpR4@A}4^ z7J7@YE~l=#sywHy?(FiM*0#EEc}`tbb;Hggqp`0mC#MaMghxlma&n-p{=P25z8A~f zQ-(16>5W9@Y|CktWL-jYq*di0+b3gIv9Xz<)BK6lWbEIW6*<~qDf(nAHZHm}5{{nG zO5&;vWeC&Lf{ttz9^yWk(i0YrK7ckwbLB*X`)xdG5RW)!-%L=F}oQxT$ zs!+y$cU6OphO&<-wlz$^G8T$G8Edg8!Nqcj%w$X_j*P1r5w$7U(G-Rr=#@qyk)pCl zA{&l$N4mPB73IZcJwS}$K7;Ujbl|2D4?FT@HRI9~HtU~=Qi$0j#C0Zdfx4?x5+8)l za}Ex(#6{t{w>$wn6c1;ss7L^Jq0i&VoKW$V@&WaHpwI! z+JGeOkk?z}-S)^Q-b{z9u6jVYv%iO)$;2dN&X`e!*@AVQ(ax?uULeo%*XZqhn1z@j z=8J`%#kfi5cv`wO7I=-CqE&?zIJdk+WO)dbj(`j!%ZJb7G2OsKQUi=V6aUW<2$=NG z^D0m&2Ie*RSAzeEwEn4Y&kF$9@yg+M!80(w>cCqA|1a^Ue>x84;TTWB#X@+4%0rG$ zMWgK-pB|Er;_9Eqi=pSaYI5|vm_Kr*hxvU|27LN3KV;P6PyaOESiDvsOa|{7;8EK2 zPt%J@hwphH*!7nH&;KCA{g5UGSL4O#FO~H7fl1(zdpV(@L(R*z+9>R(fTCs`@(#xaU%Z6uJGsiEL_B)fJ^D zXF@OOCYGr)59T}V@*Up@zm{($z7xoIJm`B4$J2|IFOy`$+^G3WAYUf(%=@H?WyweN zg-w4!%#)h(t-^N#`GOM&%fX-iX}**`oBo2}Yh0y~WElHm^tZGC(C^0M39LKVhNelQhUDu;0Qi-*Te25PwuY3h|dfzU9Bf{;B5? zu73&SD|`?Ltr`ig#*5KkC=IL#rhghw)f>7TmG*$dI*kNZ;R&*Fo1V)kty<5d^91QA zdkFiqf(X|?%{NBRYkv)d&uS#N8ZRatr+*0R1hw&av>(eZ-;RCoYdxQW?*#Jg_!)xS z@;64low=alh8H8>PRPfn!-38}osJki?}0pi@HT%M59>tsbX)>EF!hWzl|<>dxXvvF6)OMw#D`wgsb)ZS$rdowyVp= zklz0SO#d{!iviHz`20i${v#Utr@uc4fE_OrXs>7_Ti6J`HB)?k8nXHJ;bRm2bo)kj zyA6Lc@TY#)J&q45M^rAo_#?iQuFd$f;eCeWE5sk+5st=Nk8e93`6)i(`SGXmV(Af2 zO^@0FjTcLA55hFPR2$xEeB1e64*xv-5nsaB^kVU@x8YIzM0j7Y;mx$+#irvygk|85 z_|8g#cMxHp#UJ6N<4^Nlk8fK#t{;Y<KeAn+mn3ivG z61?kSX1NF_z9%HcyI~)~G`*9O;Qi8uN3ti7?}pcGcvM#;z`K#ss`=`AjbJf)xiJWs z)=L4t6VXFjXY4~brMECK-scZNFCS2NB{sYmzPGPOnC6SM?L>TUZ$(%Tf5f)}e_Fod z@$JQ*`rQsY@L+GD`O|d(<+Tm(3w`LLQabfd;|UP3;e8G3)<&mBg3EZP7MGV72d!VI zq`b7EBorzO1%rhQmj7ctu&k^s7%VLel}N}3W?oR&ST8)99aDr(?RC}H-k=JAb|mAM zYiu#j`R1AHhQGOQ-SGW|dqh+I2kM3|%04puog$HAEctl#-h-iEr{&E%Sd$k#SebX` z!IHc^Pc3}Dpz=u8c?VCbJOcNogNv35&&QT*IXF98cz#m7_bJ~}ap8p*KH8A+{E8f- z=J)l%hYHsXFZD2N;q#eGef+iH`Nd1q_-p?2fu-~KYu@v-mj?N3&hu$Y&*ZP!&wH2d z;jdXAxbRQEyzrt6_czSM*H1YG@;|C$slKAJnT0>f$B*FepGZ3WWlF8%9?fZw`-?+3 z9AAS)Up%2bICfePgLFDP$7{er9AYX9jt^r#AQ~(Q=62D#X|SZIC@ksRL5*bhM5PogeKU8zpok zi+^OJxCZ5DlVf-qsXJ0$(N$Db+FPb3)%dy!iwLzVWR+(M5r3}$Pm_?^Frg9c&?mAw z&_X-r$)$<;xv}%^^NJ-NPl^G0|G(~IbdL#5_2UdY=DPo}P4`CO5&XQczV7Z*Fq1GR zFxyBqQbnpK)tlx^^QWbxrKY8&%}AS>HY+tfjY^Mf2bF|e4;~8|xpp}`?s91U=u4Tu zd#e_F4_-5JIEg7y8KTg`wAP}kwGHJ*E8dc>n#oJ(&Vj`Q!V%4U?^Br7+Rf;rY;hpH4+L46`od9c3NRbLc{H~HGsmdfx;ej9GQR>71+Df z$U$|r>r6EIwy;VHSDP4o^?3W1R$??hNN)q;rUC2+GZ9+b+iDx?>mv$B2aV#vjiFu~ zcOMIuFs=gh4-Ia0LWaji6u@@2SxS$dMoopIkp|dv28FR=87mjt%KV{%mg@&ZaYHE!`lvMToRE! z5K|JOin6}U%uxxdYO7fvDGNt5vK>q$3hjzvw9^5N@w) zLk4ebZdU?Vwbq0q4b1?9?FL0+Y}@!im;KvR9iG`Vzgt>SUK+x6Tx=9JV0fCWsyh8F!!X^e7{G+;S0T$xCY0J~B zTbewpaIuKId&Y)$9KILfZ!z7=KPwWE+gc*qf`&-v)!v%MhH6LQC=68?VnKxTgB*@f z;lssdVxfXWY9ir{^|+!PY3T1a#G*)~wF(+8%AF|Kofn)4E?XAdZHUDRETJ}>;BMRq zo?#NpoyY@^x^PVuRStOLjfo)^pe%unUmju}kNXi6JW*7VU_4R$%t)lMrFk9w1-TZX z{|vE=D>)F3)YjEBhJ%J@c_c!rX$~8rKz~AMqrfSTG&SJj1iH;ljKPmxrVJ=9T3rUv zI6$x%0_A?BaAI|@{6YAg2*K5c6k?{%j-oJofx27rsoES26`>yepkf0*aRKB%6c<2> zLM5w9u+yLf;14Ml09!07ii(PhR~Ho)mz9^6tX^GOUbq@8E+9oBEkvQT)DU|F0Vpwm zl$Dki19l<9C^dkU6jhW|l&vnRC>=M%MI1t@VOD0Qgvv`w%2wn3g4M;V3oA-XG1xB! zv&#f%M;hy3Dt7fR8_%SQQU71%{2$R(5C#)DU*{s@6T2PgCrQuIm0ZIXOMPFrw zno5wmugP`S_tmU1QwLh@*Vw>LDKhEFn6K4(Tyrf4(f+srVf7<&eM-VAifo&PceO~oY7oI9m1m0n_v{R>v8 zlEhIK?y`d2^686Kuqn;avgtlb0D47SS>RJ@+YsL{;gC_m@fxhy$2>R!0*Jbl#1IE4 z1`4UFcFd~QRyFB*r@tQ-@O={>gltu_i%~QFlgybJI3u{#1mhg#X`%ajR2AA%_j4=2 znY?F37+2O*wYM}i)VS5GzjA~luH8~zK;XIPeE@7zjOR~cQ_cD+*0A9@q&=j}KWh)9 zLx<=u+6w}zUi_Qb1hL&Dc|(Q7$nXwnwLDTojTZh4@ecyPm@LTu5(K$sLHYSqQ@laAsg52f-d?AA^vKoF7!!6<(elf!>7N%Jek4rsZK^d#~o2J8!Jm=(P96uor zXSe4*%tRQyD&=pT;UOfEkdmbDvylek&i1xd60ZC2=d+_D%cA@-}gf1vACmWWh`+H!CI< zy=TOEHkcxaSHx^UQ^fb#fTo1+XEqqss+@{SBn@~*^fJOg=Y-0;^OthoX~2tO`%-Cw z7*^ne)_<1Z?*tkLEJ261DclgIK_iBa>(Q^xky}6I@UTe^cS->ZH=zx{jK3kusSr0d zG}i&pH%J>p4N*zm=Bjqo$ts9urTV&U7^g=f%`Mpeih&+=dV8YX{iDOt?%YAl!HVS4({K0WFLKa>qxbJ=EjJjcA+dsy4(1?}~PAr(jG!Y;3M-Y*^QfH=|_r z&UI{lE(R0Bo!#3p(?CW|>JH}TA&g?3g`~+igdD@Uv!5p@6e^TK7rn87k{%{mGz`ga z+gQ^M3W^m@8Q_g%L%e~CuDPWZ0fR%shIj|wP4x}%?&|F`#Km6nk|uZcLXB6z8?HMC z-qGkzLtG7SL%2FOFW55_{11Y5Z;SSf_eb$o<;X~1bR;*g641WUuH3?jdj599_;7I7 zHk|7V<`!;5if;kY+M^TgnG(^vh-lMMCG8oQilkoyQS6sS3UPwZ5WgXBOB;EIMhx*M zc&j(Gw&(8b>>rO(-r>Ax=l0rxSI&VNdfq-ZqH{Irm^CTKWP-l(pF#|x_-~DlVMe66y{)B@_ce$u*895i zP-AQnTS)y|Yla5LMuz%%E_w^*7T0{;BR+^BKVHwZ;^%OTZiVU|vGR3~xRfd$;@r?0 z#uO*Va%am3QjS)m@*c1Fw2oSJw5W_=Mm^*ex9F%7M~k|d5X`7w@rf_$sIB4Fr1D}_ zvm4i;hR0Cfw2~#_WV0r;=53#NfTl@EXG}=yYiww^rI#XdEJLa-8KKI3ez9Lm)N~Yy znmYRi-Nm^yMf^yM!&GeIn6Z>Nrav}Om5-%}XSFP?Z4FITVXQ!KlHGH(b)>JUb9B3< zl?zkFAGH`J0V&F`!qqBq#;klSRlMP?K&60pA{9>=k81?mgRe3NI;^!5v897oOt6Zs zf7CY8{-rGZo#bd6@qA?~CN10e<;qOlUZ1URufLM(kv)^GM<&w))oak*=2>iNwatDh zRwtab3W=@zy2d`$*H!C??)8z4@_VaFLQ3$X1TDp1HvX1TKA`T#oO~TRDut2tk#%*= zb!`nbLBpGkH$=~*{!5|i!{`-~}!nrZ5b_vI;qApO38bNl= znqa7GV_xt>Bvl+|A`GUOztpP;s?9|&gBB3DcT>30@b1tSM0;dueDYx=+qsUGpe>rD z4Vf1JxLc3S21ws}P4A(j*pEf^y=Xboc9tVOEAV$R+0JpOY;n{d_g2$9H>zIh=eo{w zXHXE%>my&yt|@id#@QKJ}H7|@lv;4$#@#^M{jaU&YCkJx| zJhA_7$F-CK`Fy2S*1w?gYLeqxMdFy{8#K&6pU)b2qPa6#XB3Fn48fVatY%C9d zw7-`2)D=+PK%;bIl5+-=@dD>=X5cN6D}f70#=6ShRD^S3n&@4fNh|4SFOu zyOS=M&gKyU20!bo&Z%P|YFjo|H`dXz&T37*6$@9BBaVL2=opPTDs|lY*1F9#b*&gR zn8xQ2$BeOF$A}wvH8?|Ho%N7L56fDt)H?{frE?qVsK$0RWHP54^7B^E@W&A6Q#Pp3 zQ1FysZY&CLwnJ472`P+3P>13@YQ3=X8=;GhA%1Uuqny47&$iCd2<l-A3n0))Y zSif;yUF00B5u%3f?H}qK%cGHKeM56YJ9-G<|CWi;2o#X^y1s_*Cn0_O1Mf!5$F-YV$RPgL^s79@qVL5XEi%}+OY#G6?{Ig2 z=jdo(?{3yyu3Xus@3m`#$|F;o7d!)b3sZ?$ae4{yv^X%Jknt%mRv6E%YimI>1n*DC zi#Dpc1yvn1L{IYmlwcY_>oY$ifYMG~Ft-?>rx}OTL90b?FhXO?y6VDU?n=k9)|+M! zD=%0$f#;;9#*jJQzEQj^&^H#Hd^&XuM=CW?rtt{KZpFY4J#D$fn46nag)3GBbvRZj z<5WyKruLt;+&wT{k_$Ek!Q9<>dBGJ(P_Ir9MJ=2tGQFpn(R!v34f_0;&rAUBi0SPA zccemIvxBF;rr+l!Xei; zAlG0gHvq{CwXPQ#J;tac0Z@CCsNu~pDq>iB(X~L*idM&nrK!n)?Ds)-9CUGsS+wWh zVX$;*7X4J=wYr0=o_;uNW1-X^Xj;9-Q)&v@-h+bILmb`pWM%G_$JlgSJD3ky?q~d zMX+AwlX@~2uwusnjK>3k%dw0)zg40$U@sO@19+_VrX4&0h>nbG>m2OCLc&%oKK)dP z%FlYlr^Ly+`jDN5Ub+hYrksFrc_cDno7(|U7?n?X#MQAebcDTb5%ze+jaCF|iZr?_ z{V&neDy!LKj3{bUCiA)! z@x9onM`5aBV(#&WI;O6WbWGR8y_F)Kiix1{T{H65RPnm!gvjU)tklB%_DWql&2KNv z@9|XemS+j$aiTAGv(w9g_)e<$vNxxDXm~ft>!9hDk3{>+Y2xeNWjczJykz6ddt&p8 zH1QSxvfj?FQ9FLG!_t7KexgS2JLD70zlbZ9!25G-X~d{rjXHFH99ZIPjm9MkfIT(< zA$&>uZRXrd0dKkl0PexcBK5^(%T53cL`?wsKWF;6Q6^%ZUprv{dFA9!#55Ct)=4Y{ zBBWh1tMPTK%1nGdu60is?`RM4@trDFj8FcNMpxmF&g~b{9LKdDmX$|}w77aJR{!LJ zt2K}LMGq!2@Agod7>}kE>#Ld?8n*-u&$nVD7~Y3GUZ3~d9-mJ?PaS@APl7}!R_>l^CZF-pY4RKXCjf7*@^D%A*~GL7(a zk6Lb`8TD8a6`=47k7A0&R+?|4)D=$fO|6&(_+@M;C$k(O&moz z49)-G;U(S@$^a}Hh8vn{u?S2%%xUX6uLtX8TSI)-D>GML zo&CEycaN%h7#fOy&t#m72lqzM|IE*IijtpCBTN~J2nWmvw7wQ@*U@5Q<(V-a^XjCv z)YpgW%ouTuz?@|Om&X;CvJy={KNmWo-3P%Kfqo3s)(z{c+jFs5K2(7Jis-*$P(x>$ zVv#2EI5dwY%F#hZdNf>GUOj#^dma-3rwS24Qgg&1eA(B9uun+|+N-B4fkn+tg40iT zlYqEWygcez{*ENT9)KOIb9WXN>HUERT@Vp=t3`|2jz|6wqxbAnF%vMgG z**BTl$Qo(*#6<9P@PJ+gP_>@@$62`aX!&9ppTQ)`H zL56d&c?VAo*3nrA)RWJ+1Z{3;N62qhH(;w|OLOBE%m*ik{d_VUCL_-~+{|O7tK!B; za_!69fAOxC!srl%HJY-nTBI(Iz6q4XP&l+0r`J=9&s1wHYCTm8WFvXZMp(yWQ-{wN zH#}=4VQDiKjtB;dZpHp1f9sCb7=~d@+&Cikcmu6?BwhN&Y;lQqK`R$?UZ2mzh9vl@ zsI&hR@hSLuWJh&9y6;~V*Ldekh}yCCkhsAc$p4EcJ!^1$puKZguCq6ImKj;Y*oQEN zuDclWEc0az*9=8_dm$Bh(~RtZ@eB*w+c$!C6Cw|GMGWSFt^v=Vq)VP6L-V9B$&ehreUq8b__nxW9t!B9_qg14eUscX$Hjj^?w>ARcucIE>zu6Ncdzd(Tx!&{ zTNOO6LsdiLYVur1&RQuRK~iox{{OwC*m6ZC<*;}bN%{1Wcx$q1l-aU_>(KS=Ak`>c zd;tmWDcL%|=P}Q+g~+hk zIS~FkEc^%pY;_K0)0_fvCxqW~(!W!9s!`*FC!i_(+>a{ZZ^#bJ-Qy-aW%ryH#Xbms zFz7D4Ecw;Di?sdv%vRUbc}k+pNS#7vP>mIz9stes%xk6eWCzl3aY+kX(cC-4vq;O` zOEa><=)NIwbEumj)6iC5->wq@n#vRy%Hx)WvM<8yV>vh<iz03LMiLXJRU*t?u zAR6SDc_2GwPJyVKW@;y}$tFCM4xS z#WV1NxO9m>|KgJ;%L63_n$TJ6vt1mfp8tRW% z*@C;oEhqT%f1W!9R!P<7&Wbd*aG|&htRBsq3aez=b7jQ}TzG-FAFS@nkDc*hqtlsj zToGrDwm4M??bAzg#s^a!vYc5{OgzJcS$<3oqK6RSBDe4*aYv><|C&=`XMP+^RY%Zd zY8iw@y&Eq_fFAIvqesOr!05Sxq)Fk4AgjcZSJ`&* zq|gM>qI~fJI6S&CmVZXnDnl!5;Yj~&Kucl1; z+*olPx%ftLf0jT02Zc#lDfO7FRM{|Dkv}Ob(pQFGJOWk^gp#w8`m$J&!fdJHeu%7= zT~oyh%or9=fYtRy%*uUw-mTjHu3Lb zrc9aU4$){jsuXm5)rhU%&WtnX_)_sFFnc{2GnF+u(`C+3GN@BAS!R?y$KNJy4Epnb zUy_kHWyy7x6&;L@Y~3w2I4^4gGpIC)r#fzwJnDeOD0InO@guO^Qx;6Z7UpGJNlBhY zRIl^0M$jV|ZtujI2z2cbd!Z>CsU?GDqpwV9N%69A6~5$BanVwL{>`hCs6@?IY5mJW z$ohB5Y{)jpAseC3vt&b*g;F+rElMaGb)Zhj77s$UFO<6&A`Esc+A!D?ozOjD^bBlW z4!bV7c;Oa>+Gv00ZjBDRL7|bLKxQtPD9@&4a(9j@uF>I6+}jzGmnS?dE?wr&f2d-r zGP&mO(Pc^~4d-5Fo46X%JaO6-rE$;EcOwnuSLXBLvykSOl~a|*Wfd`N68V)_H<+_M zaZuc|%wKu;8u6-kMR$MSaD-Pshq&iLRYwl`IL`flhq2%8S8H&*#fguk(fUR_{vqIB zu~uB@TQ2F-rV7x<`vF)1#fHAaPV&zH{hMpW$9;;tLO03B;uHCo){5(VD`-atcfCMa zq)9=DzGJ(fNCW<#PZtmQ@@S=)s|T4_n&jC+__|BQ)^ZpgsmKCnTfpVlnW`{gf?ob=nn>x^3HFe60B(q~My0r;HlE9fdjYj3( zDr`o_;j^==YHQ1NayU^FMm$xe!x7dX7RE`B{69BZM&)x=;&)69XSm)ywcD!28(KEH zJzeU03c?wcf2^N@oJ5@U5YV%8eggvUt=+a_757VUZ#d`53Q)t>4uAQt9M&%3jVoxgB zLDR;nDMY(&owza;`x&Wp$OLC{p~zH)Bhy~wC`&R?SN&j}_zXuvUQasG$JdM7q=1c8 ziq#fb{;YB+{iEXpwq4R}2VnZ-dU3BAKapON5%@%dcvulgtk`4(e$*hI)DkqRB=or^ z0jH5-lhB7GTy>WCl|?|MVM-JZoF!h86p+i4G*F}RA7_cbt61U5$GUrixG0S*YIA#h ztq|Ml7?m$?5Lc$r&e*1=#;OEX!OF^vR}LA~9gX7U<@wYA(l!Jd&rlCNC$M5g7;T=& zK+SG3gDmxSz>TBWNdcD3;72B6I$lH=D%WCod;yaIkn}dsL=}lF@*tJ;~{!hWz~D zhR%M>m8tKpDE7e^Yo2Tt2ON<(HIxXB42L5xvPH%>NA4IN8S25ER~Ry(Z-Tj(|-zMS$c}1V}_8K;ju%95>m%(JJ1S zq|tTXZr7HpRCpVemA3<~$iSgj>gUjB_s}SP8fzXtTilSxiDiOEladKSN+M_+HVGPs z6~V-^>yTo*#xZF`8o#*W@7N9V5E&iz ztv0GJm)T+Mx1lnBPvvJeirY@%GVheYD*doLxkrc8qT3n0!^d8bQ6E4klo=9(9BHL^ z5*ZiB5y0v{XQCoMNBr8Au~}cBe>^$Hs6j{@X_E0F$@ox50>+nb64w@R=EtO14_(C2 zB>Ce0LtBEMk$j(V<-5hGd}NdO+{#m^KBIG3s&+OGkd5-N02bVWVTWC#2ZXWa;AZig zl`L*|-$?g3s=`epxO_mD@622RSC9AhV#ADV8yaE2Y0vH=tQPD{jbgmRy^bzM!tP&$ z7o0OX0+-?VVj%Yty6|%L_Ao7>>F$5WE=7fr4PG_R%nlT^uDSMHam6Z!XjsBk?M@D+ z6vENnpqiJ>aqUmaN%?lmkRi{9#%jEJLMVHndon@65BhT$quag>zc1d#8XbWq)L;Cbu^6*L6e-Qf2Bq%k9%g@T+!*v0%0{6#r2HZ2H#ZJfif&3QF|!&U%p^TCZk z#)m9O7$-9~HdeJ6|6#$}>u_qczN(=SH)0td#PJgT(V18br;K9!(F={GbS^fFkHz9* z#U`9N;^UrSzFjehqp+)JJ1cg)(!xQ|_8q}fLuH28fHdR2N8Ag`$6DoCQQWI6KV;Hy zI*e}mrQ4SCis)1-B#n=RBP@v`m6Rh=lUpP#WG9MLT82o?ZjtanNWxe}g~Y4HEm~1& z;$-1n4Mb~oi-v=`3AvSU%FcF+7Ah=CoVF0|w*kL4w}?fBC5e+)T+ZnWyG5i7O)P04 zpB4OoTSPoMgFBv+WO|5>8FnU)nk4ISPSOxviK8CP0J;-LO=bom7P%*JP&rAQn}PGB!g(ZKbqZ@AuwGYK zM?6kaRNqKie+1U`DN?2*ekT@HER5w%2iC(HYnBs>YY>T61hhYBv=}XLRUy%~0PV_D z#WO|`TqXQp_Pzu>j^fI{doGPGOO|9?vV}aB$3~VVc}CV{%La`uOIWgnB%cVzI!2bT zF6;2YayXoZkRT@{k%5o|5^|CdLK4D~U5e!JiIZ+rCWy?XWP)vH(4)z#HilI;lC?iOrm(M(EyY$p%+G4n)7B9jW9$H4P8 z^F%SJ;Q14HKH(;n()6e%B`$o=r`!LHxuTj>aIFK^9~4(KlM1dNxQ@lk9N&p*Qo%-z z;9kWR)ue*$OJMtzVv8_@G^t?2{!8|&5|HWiMlDttQ_FR{4W=(JQ-re%CThOUrC@r3 znJx==2*D(pu(K9iZ!lM6BNuF<9Xl@s+s6~7TJJ=(bipPXv-23(9#(7-&0S_HTD0?C z@V%_~Qlcm)o3-8m4Zd$BQE!`W>1@Tbpjd1}{h`YTre6vsnBVA; zO(rs}Ya5uZNG3_;QJKiJu8Y9*dBOAq8g~>?!nUqYfbFDU`zA~lg-zJj^$6JB6l@Pf zXA`z{y#lsd=aFXD%!?{b_LgxO;Cn>y{pyUUeA2dY8^HHR!S?_x8$~;5+qfR^eI$kQ zMH`617VPam6zain5TD##58ej_FB(E@Ub1u?`M@iJH@c-+E*U)T1@InEB^`!mk}J&a zP6hM#1oNMw*A7b-)^~3N_v?cDSJAD{+@ccP`@nrWW@_%&e`UR`n@*&xA^hBZ9PCdC z_6OkQu?-@t#QlA+zb}oX$EXsPE^Eg9CfM&zlda>3L)(vc7sA`c9BW$qN<=?N(YWD- zMT^cmUfljgbXr6-bwu%~b{dG`a-LNCQ^g+z`nXXHxsDB_mq7|2zhDG6FPunk>Bfy6 zJ7a~c5mX+P;(BWYl}Sb1ZH=IEq23|r$5t}mqCtM!N~UrNZpTt9S(HoC>#TH9E=k{K zrHgV&dU*ZPvoL3HuQh=zmrU_1YlJM9h;TZs5#p{RyvmtBjV@fvxpf*{`j_*-vFuOEdcy(Pms1M2QiFbX^f8MikTa`6w~6 zpstfqqGVBBZ$^odg^kOJ62--htB(@L1&$kv630c3`$&{H)umGVj(adRgD^ncE3p}b z9o$*58KgPfn__cFtGFj(b4cU3Z;#EvHgZ1|n}tmkug7L#i^Ug*_4;^fKGz_~jw*h{ zB!~tAGon+(4>PM8b)@SsCuq;X$tp|Db1^2xv-eeCi*_!C+KLDJ?G@1}fNjGQqurs7 z_R-Fvv0kjDuAdm{9`DD7`yD7iF#MC>{&DJnin@`pm<=!=`vq^rgFWe~&d2z9_e zGX38*QILzfb3zMQf-Wj+rM^sClY$$@G9Y-u*B3M{#7>7^Eiv(|M7tYzV|m_my3;&y z+7(VhD=`VFE=|K})O18OC4qmKNDUIE>BNy>B@!V~5fn#~m4G3ILWy~vLNqN!1x?wh zCW)BmuhghSX$}<4?oLd^5!w`_Kt>);&dx^U0ue~YiP?#Wl4ofzO4MW^lV~_d4+*rz zD&7x6E|DA*%qBVo&Pdb<jWU{ub==!jb>bdC5hhfe`a;};?2`jpC)bt!iD*-4EHrESW>$&y%Z5;rkl zg-MdhJ;-%kIFU%}P12@?M5r_gG9lL6gp)LFqe<8VTb*U1rm9si+1cR{q%4uEOtMs$ zhyjym5t5*3)!`9B2*@=inT3E@dj^c=hd-vF9_l2bY4s*`XUeXW9Vq1{Nm6J72~+7B zO@tIX$ATh@%@WnLCJNZy8Fn_vGc&MyWO*>bjRMoAE zge3BdHVRUpUD7md+alpj+cV)!J2Hi@?<^6LZ1DwP+@%mr+s#2JeVz;wLx&7%+WCr; z^1MJH1u29E8Fdk|Mr?D4P%kG_BVuz+M8>(EFUMtETmH z5UDPdK~3AIqDlUMLS)W^il5?!NFcSxVG)3g5mf>*_I`<+owNbSs6?_Cl3rs9(X{bW z(Sj!`g+&i+)H0#)!TCCMoSJrM0|#Jean1Ecf}0%H@9guOSJJb#w5Rxdx(5nEVIdZD zjrVsBcnS-LhJ)B56rTfNRm&KCpD=+X{Md*aXK0GZz4S#BeI+~CIWj`$D~%lMTRF1#6tlU?KcarbHiZ~2a8nL@q7?E%kKh!m`mtYJt_{)671%6-o zTJX%m7IY5L#x=qa2Zu-ZnIR-cCH3?l=+}2s8PUfPvP);sG*+F2v!x%wT{UPBaJ6qN0`g7mZxwl%)E8He=roaMm&X$ zVOvcaIH=YmK&^Bhc@n9kwY{z*C|$DI*9B6<=Ki!*YzN+Lb%-s6J4%auMSeKQfzpoJ z&;fjrE8-B3EuT9~xe-ESS|b{#;BMRA*hZUm@_~07ON-I4YNZ?*Fm{r*qIj*}+K4l} z8|rE{Tj{M^w{5A#`+O^{8i%acfr>+a&>jbSakeV<(F@JBzPd+yJ@0Lxu6jKMlUJz_ zAnvANIJWi-!?CGn@=EaC#c2pvXOj_WgQg|@jN>$i_Red-pJ3bpX2?(at_6pDb?F|& z%Qujc)BzmbwYo$+ZU@Fi@o@%*F#&K4tBi|q+((Rym8mqxfD4~4_HA#p^-1IO?)5nl+%iwY0C%7SBHoS0|9=K;sPN?zc{eJ$a2 z3y!#iXD#@A;14Jq2+Egm4R9pY9BHCF30o~V%9DU0ioE9Av`U!hdlq~h@FNx+6L#^{ z7TgD%WQz;wm%!xTw%|*FUuMCV1Fy5-tAQJJg7k|}g+H*wp9%bW3l4qaS}i#AiCbpD zp^xho3l4o;->~4&$90tjhdwT&K9E23aT)$E^>My!;fFrXFIn&k;2{f+`<@d#@Cl3i}+tN{F{W-9*Ay3TNDuemw;moKfv%7hTmey`r6)+xE*ba(%I1l1gv5h zWOxz7V+=pW5dDqdhaCibNJ7JY$ghg*f_}H0AnH^2$Jg*|P53u46=dX2u_r zkfuOH`QZNoPB4U@3;dT7I+ihHe{>vX{5por?_hq{C6ey?4a2`k7vU&J@>Z3$D78Lng)U-ydoB8ct`wYF_G?3hFs4}xqUBvMbbS<3|BEMV|W(Bc7~jfr;Bm!$33?( z{yBzhPtSvlzsB%QhVMwYER|s?!%Bu+Kg&4ZWrvu4DZ{H7evIM$3?E|1n@=F^&`IKf#dm&Bgdg&`&b_wS>#LzgW)s zE>CB=m*ED6)eO&Jcpk(33=cBAj3N8U@;eyker@?ZjQ<Ib9*mvNxUG3A=|fLBjcMHviyRhjI$jJ9%lSU47olF{wnc88$)ha zg|&=#Fy#6vd>`WGf#?W*{rl5UI#@4@>U*p{A;N(g?3ME@!9MuzB*1%55VFET{_f(}0? zXiH;=eo){$8D7i~b@Px9r6cD~J04c|Obd+-N!oXJFQ1!mC<~Cojw<}84a)AL79PBHl1WkT?TGSXU_m!3h zMdnsr4d$UyI&M3-e`H;I_i#gK_u*2ch>)%hFrs1{q`07Ow14}iYJc6nEu}$uT(_kd zn5qs1y9a$meMqn?AQDs$>^Qu3^gv5pX-|{{gJb<;nBg8A!P}Qnk!e!C@$u5? z9fMtU2YfgvOtOc$02d6eUBbvkevR=#IxvI0O}Z;yWs&0@80!m4*F%^-5hFL$swesf zdIIA(`lV}PJT&I@wl_2f8`}a0);4?Fye)O!!1|`*V(-rNO@6<(4WY)mx;nqNafcVj z1h#E2^IqE4zPV;|twhU#HZ*y+(piLc-n!~Qg}1ft+zM|?Yh7D~w=PiKc%WEo>hJP; zTX9HuXl&f;g|!CyyEN-sEV-r(i~SI1{dyyoJ6md+i>z9xS9+Bf)jk`yicBps40nGL zH5>mAuL`enSV}${kDZoWI*CXg(@Umx8SDsivw})&HXh1-HmxT@`R<6uL}F&snxcw9 zl~Cg%8MA3!5i+PkO_!KWw-iMH_1KoLs7RGLctk8`F6t(Mv+0~!HM-Hv)xS9HoSaLf zHH~=+?MtMbvs=m3@6D$yGUnz`LcpB8$w>X)T*(v@?G5;>{YdpqTna=8lWp+iU zbYC}}0?N#$tBLGekZd+xi%iB@R7D_!EZ?P63isz7+ z*|^R$F;U%!q@98vox-CBMy0`Eu(&K3%ZG#A!HRWV#l@w)Wnc_qKZCXg4B+OF4lD9y zHxp$fZ1g`tHi$7I#C9grBGpi*WO@_^&t81YGA)Vddn;nl{nP2fE7rxJN0Bd{C%yi) z|D*wWdt-CV@p+MWGWe%I7=%3&yoW_Hu^w$8l2*v8CGyeM$j4qxhpn!9Ah>g&hmOg_ zB&2s-3t+ZjQ)j5Nt6#hz&vDkM<$Rchh}Y-q8MZ~(Nhgb5-D>G}t){rhw+`PeFV=Hx zL`p(Lrk3MCFbmTSLP%Vi;7-8bc{(Cyec4_CE2Y4^hPX=bmqe?J!?s_8VCAa-9)(ZC z{Aw8A2H?-)r!JKS^KgQX>3RlG4Wi;!oVoSi&7=8vMv!~DLX z1A-3B4{5ddsY~S>$=3pg+3?*6J}R5Kl)Q*?IGzWC)qXMfocBWAir9kvM7#Ik&&yHxz6Y9xFCKc>Z<)@gof*!T^dfM~l^Yk!uwfom!(6Gl zk~0x<d5)f&qq0p7=!5{jmOUc_0f>mA>@KpRro*zFYkIP}mL;bp^ z5U(zlC+gCY?*b}EyJ7-Vd|bau-og#AOVV^c8|FK$`eii$SNatq97DgXohbWT)8$3# zmrZ_3GSwABzigD%{&-(po>WXS zPGAxCTb2jv!_)b6ymzqbx9nx$NbK$q zaN?!*;lnS6ek-2A`l;s;udW#S`R)Nji(&#)d=d8ZBOeFR)TQ{i-%#zSbPq&qQcQrV z91RFt>|FLa;L6Sg2*)T#*}Yh&FqwI`#DzVCO)eFoAATA{@!p>Ly6|pxm4*|s&QI4yrZ9Gp5d?`M>KeXz1O&@SK ze&o*{{FI$Pi7?VAzq)1w<^42h>QeHq06~Qj{6Gf&kPLOH@I@e4`7*)wvSPBtjUucv zMesvN?>K<~-V+=5H?k+`9giPhAAJ~s7W}9jcKj$`D%Vc@EPNj${e1WlAMq%@286AA zwZN5KoEE-Fc~n129^DIK$-CGhFV4bOj<7Y~D}ht_NI%M7$&2J8A5eUhJ{I4nEqn}!bkm+;)~F4itMNK zTQmb7?4su(p6s_IHsA645vSxWoq_Ke3m@qoL%-uMTllE2h{1Og(N(^xUn4t3*yW~d z(3JfOW{~HFIZq&-%1eG2Bj4L!fL-=5Ux|e;BHz!{B2MLtciXY#eWnR<9{ecZb@-`# zvkcpq3+R_5`PlvR{T%ASPF>YD0xo61f|B>%AxzOaEh09uiZD^F|H zw%%8@Y2>~Wn?}C=&RsW5rB2%1Rg;O6x<{LwHwEWAxf>ykLeFiRvS~*qlcwe!pRXOc zApTgw@%dg`W>wH}JZ)-TX4T}pPV``c0p?JiMz{| zd^fWKcuT#nX3yPAGUDnpYx**@%!(uKn(mCunxTxfi%%SBm~v)bo*Ag$lT%fH<&)1& zY1vivI@Ln;`=0)yQL-e|6w3DOF;%vcB}SRnpiEbCeJqct52<&iskhSl=)$APR1ZfM z9Nlqr%aU(redoybBZ)_vGjGf6gnj>HvG0?2rGNWX_81L%#829V$JpU99SFIm5PELM zlm?H9Gd#v=c+9-1v`jZV#w9$4tm}exHQ_ay@S4=)F2lNZSl6Yr6kc<_@R|#jd@<`z z!)u0x*9<}LH-y(XO|Mx(UgK0=lSy6^XLyb4xE)^Og4cY(uxWr+S~iO z^7Q(=lWvl8?Qf1QtIzAZox>sg{?Hp#_u;~nTrl`S+3!Gm+G``-0 z88Z5ERV={p;0wYs&%_8O<3gSiPhJ--TJV$<7q9ZP4-XHl_h7OalfdRzsrZy|Q~!9w zL>GN&SU85yY!7x~35fWlFj!ht+txA^I>=uq0_kWO9lkKsJw8V4)M?U1Hwf%Oq-Li5 z(`K}xGA6T2{pFoK<$fPeW{YiND5XqKft|uGRk}WXM-MSUN#?>-VyHuX3)#`3X<=`u zWasX*ku>`WyS~_l$9Ty5|29`I5XdsPM4eIKG~4_Mi_JCPJGks{x$f@On7f;omaN5T zaeACB&hB=&oo<&q&h2)`yA#}raY=3(OJeR<{FQ%5$Hi`bJQCP2lcE1TlF#-x!A7G&Tn?HoDhQ-se5K)bT(@#eSK;^+@SG(Uh|L>Q{fz|b>IY->Y5S>GaT@A4I zOmoQR@wB7w9Z8#JJPj&i3 z=qg{sM*rhDe_RlDfpA;DIIZ1a*yknIMq27co18Zf<3NCZEOo@eA!*t(9T(Ey-TUY- z5^wGp5Y!>s0RNeeA?#cT(BCNlR<1!5_QgM}0(@qWq+;JCK7>(wao0pJC`4$xNL##{ zgoIZVLMI3T0S|UNM83Nv5A6f|3Y4f|99t|3dQ{wZRNrz67S)SRr$y<+o@bO5>1YU) znhlKCr2-?vlYI@V`pL#*oF!~5lwK0tyNQ{sOpmXxt7x(`__g0C0$W>qLOc6sae9p~ zu62Pc+mmc5UA@0eI0_aeYhMkstw!@o@{;$8Ce%atj$5a^#g^>DNT`c<&a%n=unBkW z(BZy_kyD)Z7T(0>8CE6W*Y&u}dT*=ZkgWr5sA#to1S;V=~v6hDDj>~0XrJU^Ufo;!tko_=@pu=>fMZ!RrO0#Ey451Jd zPxe0pLETjV^nfefW>-Ef8kbMAU!vg?28U0yG}|TA@$yBznXN>#T>>0Xvy~x?0SKVx zC_uvJ5rF`8dA3V3IF$l6nNZBBI%Gl`*4ZdWN{9gUmthHoO2wLfE@V?_{c?;A9v7KLk}L`BE5QY0 z97C4&OGOG1R!M}h&JlUp&Oym`g0%;1Dj9`UGKAHolA**#vOSh$6jsR)R+mVI!$e>T zBN-kxjNB-!l2Q1tqSUry2&>CRm5~!xY(dHmvlr!{-xS8BNEYL0uR`iSP-5b45-CJj zr}VU-)gMluRNjNem|hZbtsa+x1VjLRYG zUTHxFQQ{Cb#8Fs@L)Z{U{NmEF1gJL9UKb2{a_d7~9*^Hs?DLnydWfJ^ITYddtuHQH z@AFG)TYGH{sD8mB5Z(ZXi0js2wS1F^s;k{(uu<6LD)E&Y9OAH>_FXNMQP?Pu6rf}+ z?X9(q_4PsKp#dUAjp2y5;a+U8H10uLG6@62Lwmz1Bjck?uY1tO6*^2#zb_TIamQ2J^^@wWQTHj6^X1z;9#703LY!rk{D03Ey zpt)5L2{Q;`n+1i%7~2JfQKuCV<%2NR5W{FQWK<3pD9~Ed5G-p8DrPI0MEI~4g&wxGQQ!vohR@d5Yk|k?X-S)aBwjeoEeTxu>eOMi$dG@Jy zdG_alzZUZ`2u*u^)JW^d9v$cuF-4A0MNagG9;VW5G^wsTLm3VVq!-X$Z?Zv&p*26NNz)p|97`^aCoDFcw1(bi`TtF%Imz0-OtSu`6 z`C`rjWHXC(#l>samKXchmQ|FNl$V!Q_{x#RWn@T{g(Q^Xf%1q>1S$+DWu>KSL3^K| zQE5OcDPC8yuB^OxUFn3TUoK*(G$JdbQv4MqC1vF}Z>xN5xo=%*DPB&MBC~6B$PPBu z!Bwp0J8F_6taz;%6Wy5CnGCbE=?Badve?43A2g|4cDC>hW&|6+YUoKb)-Zy!eNA3; zdw*D1%&>tn`;8WIxbZ(?iHTMPAGO3AI=ov&+${92H|oLaf2gNhjA*Wpi1?2i@zHDL zRwI6vmGUVg0lT8bnQt@V*f7=#xZQ}1QahhEA`QdLTsfbWwq(0RI{W9$Sk@%0EqvaL zj#f`!Fry7^-mRMMrUGD0B{~ZPrL{HvTLv9EGCi`%ur23tK0eHZ_8~hMt>6)WBwcvkTPY|sqm=H;Rq^r>)b%mDF{n(5MFWyh} zHf*sNXy4l0SQD*h{aIK%(po*`*NEJWu?xr+!`ObO@2F`A2n%br7ZpOr{G&pk9fnhX zQYZv)zxWq@2h@(H$zM4pLWjSRRV#uubko8Q)8s^eGnthCCJJiJr2K;@a2Y`{yK_o@ z#70Fi1d4ke$nO(mQ>>z2F6gFkMZZGO%`6PJq&%*+Aq%Ql&fjnyag!G{d5uUPlSfpy z?QXmd69v(1Uqevce~s5JEn@b+cG^r@#Lk`=+}6}|RQC_jD}w%^?tzJ(5FU`!hh<_| zq-Gni@03_|;Ygj05JSXVUnB-1UnKAdOmpZio-yz4>l`(w%pDG=m_m0u%|VDmcNjjGHC-n1rrKg1s z0+ngMp`RsDPW(OnY>9K~=kzLxbMoKo0U-^iXLpVn`ERn&3@sWgL_?QG3(?T%9GQhx z<~Q_aE78zyijPVW^AgPn)C?k-#=>P``UukTx?oRFRaXuZ;6 z{Fcyjz+wz&o7)=O=#di-o(&k+dgZ4|^5L>sJ}i}j*4B)B0A7-7dIdG&rp7IGAoLH> zhfJDYNyFwqJNjgf8XNB%@9(y7oD~di*^1A#@R&%0-kwnRz}QHrJ8uYYuE!@vhtSOg zFr;s*tEGI@h5~pJ$eS1o_0WhPJNWLX3v7;zJ{aoUN70zP*tR9m)VOI2&N!9byXa%{ z^YAb+(%HQaZ>z|u$=sg&RfwZh=b&gZ4KYXL+&Lg#axp86K^qeb1*JU9=_neC-@2`) z9TGSzd=)#0*8y#-+YWRr zbU@QT479PWI&YPyXV~*EMD6Yi^-K(eaJKsBC|-T#t*QjIf2=Fdcc@;3qj6l~IoOAN zC_H(-Z7A`r5L)~0LVHe0=;ujj^Sf%=Gk7YRejP&beIH7Q9VayX7ldwYC3JXH(|-rF zdUH#A-hs}6i4fHt_BZL=H!_SmW}2p7@1RGv-H7ZSxX8HA)QWpT<+S^Zd_jx9VmSqG z9gRCnl*JUZdcyww@VC{G3B!|}wp+?+c{g484_zNZ^WPg9$9&3`_SUVKKTXAy!mds- z_t?aMcr&W+(svQQw`O=~d~|p~vS2E9!#8dEMR?>Nv!)ks6L)npYxIPbf41pYQ^!L& zH@384I(LR_1%rr3o|Sjn^$)3}fp<$P7>uMZ+Vxvi(nIf-bSE(wNx$mQzo3$~w6)Br zFBSrIWBdNLar8GWrZY0_*n393Bd)E`nB zHNT5S&7J*2(bc)yrT7pMQ#z7CxN&Nb&eWjfI#XpxTGVRh?{F`+@Wx;2VH zBYjVngWuAydn1lpZ^4vjt2k*r8>cPhs?(OP7w!MZZ2OVfj6hXq({1b>M4B1nQoLRW z?^O_Kye-yF%%(rGNdDi|CCRFw0xiQY7r*6H59qrwqhE)CiZ9p@+*G%vuC=koquFzD z=6w~7Uwk}mFHs8 zYFf@D7@1=JQoV!VdoD&9^!h=JZhYG``+ns?^i3B%pIm}shri*EaW9&s4;dR)MfV)E0^93^617{mRX5eqOQCWlz6GznW+xouqOoy$=BQL@>s#t}*3`A&sljl*Fm;R+ z4JyU72d~EP7`Tg}pk3656IKJ-yd?fl4O%s=F>T1k&TntmZw1IPM3t37#< zEa2G(Q#HnvFdD?nTYH1ifPSH?W~1pZ7-6*2-vjCE91GGi?eYF05{SvSH}r;Wo9cqw z@rDsSbnn1$=lCjm60L9C(%6m>0`h;;U}*x2mmZ<;Ix8MvH z+z5=hE?;l3yuL>4r$_eqyDkb-*V?*eD>=k}8#vb~UKw9uQz|2y=$brc?;YtL=o}mC z?>#ImmnUD8Q+VS>4!xa-C$BKLo>NE$yIkuq3V=NgI|u$J zN+Gv}M75k+DPko%klC4PAB#Z8~G$++-g)x}%(Cb^! zYp7G)0A_B~s$UfB5l$rqK-z;O4QJd^6T`a~)eFqn(W(@YGL;yJ{db6+fLv_48|wL= za9G;pl`d|)COUJqn|z|@GEfxZGfsLp(bYdbd&6*oFuRySAoEct^`RJ!G}Zd^dNDo6 zLmbOp+0#pJp9ZWqYI=P7fhA>2UT;DBtP>Y_+DX7kQ$X=4WL+SKm-0RhIkuNwW)U>o zD;BIpv;EOTv6}Rb1ap)s$NWuVd|o~6xo&n3aB}lIF>sb&YB}U8b8U9-u{ilZVYKfM zLlMp4c1SznV-WcQE8?4w7QrVT1dif0>iibTE(pi)A~kJ(ns)Pk@ccNYI zy?FWbw60fv(x%^_pQ*YJIcVsmql<3#rfElm!9$k09T0V`@=2Ti;m8y!!Leuwj@b2^ z%mj2RQtVOXf0?Ea4UNFAxT6Yx-L8Me$>i$$Rk%=tK;fTU?1cSZwPEM=*SDJV< zGPQ_NQbgvE0vKD$OAh@WQwn-RL-(j9{ghL`H;g?jvrc1jnCuQ!53#O4cVgv%p{wj> zXUd3@hGa26>eBx$GU>Zy$|*7T_yd(vbx0~@)WW^#(w~e-p!lO!n5Th{FTF;sS`<6({A60I1m7PcTO*$8`Kd#V z$HAqatJp+~0^x{-Kn!12xW%1&DdP1g5un@fW|79?^3F~KJct?u!arr;;-*Z(Y(EdD zfn=AHKUjt=Zgj+D-z2%1M3jTFsuB7GS0;krSGFgPzbS+yIMzrLBPcGiD1FsP`%L+0 zj^iUXp{saOq?fCoz}r9h!quF|{DKV=nP0R~nFJqAE7k{^8=H1{G~2&MCeZBn+w2be zw`~rG{(W0*T~m7?coxsx zTT7#7ZIQpkU%IZi46FPq)|Ib=zdUWD#ZOY1_5kKPg0yPJQ;P4h^k*z_$Try4&{*G& zr$ij2>hV+dKe96517~LNmnnuH+xT@8&8SC;SO*C|v2mt&*-GT%KRc|-zy zh>rwPT38z5mt$Qh`=r#My?U-1n9`zYaMoGTG@#rm-6|Sc{)RNb8i4)fc?Wz22mA#G ziVF@*vj9@&MhWH!5;xKKj>*y?{Ls;x{*tqwDl zRiCjDM^JtSu^Wqba5Q!ueMy0S^0_EcI~&^( z^NaFEES224rD+%DgJYzAekL9vMt&`Ei+Dzwoc4?)-+dYDFW%FuF#3SPe3~-12B#s9 z+PR+8U>Skqyc>a1$RhHzJz<@eMI8>uw8yg+QkE8DO^j)2#h<|XBWKJ0 zay*7%Rf6`8e#D;Eg3pd6t|#kP+0$D@Gna42u^z$h;RFQp%tNS+B@Jm zp=@veDDIn3d8iv7xZ@LUeS?0V+nN86eI}6)g^L6#M7|hBBz-lG=gWs7^P`R#WZD*n z$s|PTec=c|Pq4dltS8vh>ld~T(ueP9w)g9A$2;>+ zxFRyscUd!wW|r{G^!4wO8ClErmVQ-&GykSIQ3GblA~K6+uh_*9HnWHH8zA{Fac;6% z>+nH~3xZHHJYW!PIU}{SL3f&s@{#sIM=;ud$aFy|^8x*XiO&4*xlci+V-v|l<>m{8 zr^&^~RB4WM{W#=)BK{QQ>Qvj&brsd<*r(qPnSVJInW9o-$fVkGJfPnRnJ*=z)dLbjX$ZP|d3!~UHF1h5-<4jM4Eb!VwTCl*-U$NfOB5X<{lYJ zmD!H;_n0;p<#49!SI=|i|1!}l^L)$56CsDp6Ct<#?!+|hEo+{ihyTeu5uYjZL?~P4 ziI68+o>WffHTsRn^Qk16r=F?uq>#*$LT>vVNocf|JY8p~JSkr0Ng9nUfc)uD^t+^Qcp!V-M-#UbKJM${-A#lvVS^1HOI2CjkpuizAW_voqI(^qqnr> zVDh~+BsO)i((O4T?bz+6XMpaSvXi$SXqM*wDY?S54RL72A@WILsr8-R<5)4v)OlL2 z2#HR~`e~_o(hft&=^}qjZVh2zznu9q&{9 zMv{hCHZSI;C8y07{RcveO`i_$Jd(bvzlQ9OEtxUo%1 zdLzPVbmOhY#%5$^3xS11((;-=6%n$JOdS$?1l2*70Qny z!qVqZA3v`^|16Y0vh;sadFoN8DNjU0`IIYJ`Qy21DMz9yPt`r|_xcGaf6^0OdD-%- z4;L%{b>vK|3|Fkmh&zSKpdM>_c|bJEliEV%$xTbTHA-287p2^x{}g5U;X$w|Gb>rhP94=>h3s$TX69^BVzitsU8ZGh zIr4oSR&J`%rpiS=8NmT-hR1jqA@W3lTZN;|Ul*mIsqLbmJ>BDx{Zi@=^=s0c`Hx_P zJR4=Sw?u0-#z5pI5z0t!Vr3q&C^P?2Y4wz&xoL^+C<=+u<^1#XuS21qcxR~)J>(d5 zAO~gP3ehmluuj?zi$ZDVNrmP;mYWto6-^;(lk;EJ{{ssB>x!hDW>H<}G_=UM6g;=m z4v1p*L=Fq_04=6gfVrhV&^!v3GWX-TGi17i7$c=!qW>)mqu!OX%!3C(oQJ4{8S|j# znf7b_>c!6dE6$v49%wPJtjYt}jO7rnonEIOLmq!X9!;jLMzD4?6n^iTt-a)<)9}D_ zlcj%NzjcW-|HpZ!kkyQ4i=Gu(E+a$#JhFOl)v07Pll7uzB@CExnSKwlx;sB|#z#1v zs*DB2qH2`KaU--&FUc7nOm)b1W==7Q879o~V{#B9grI10887K~WIOY3Tpc;{6P76t z1dU8hhcKmg?=*N@gEc zk|Wywbjjqv3xBIW3dyg(i)87thGesXsppy|Syb$zD*YKqetu1)zecmhJ|$Y1BWL7* z73V3F{%Bc=K624b`aL<${KtGVX2s?)vf{R3WJUOlS&_Xmo%#dF>Kp!xtmPROBwnra%Pm)n@*qe*%x`Dgk!mOAsV zTALAhv$9P5M{!djnPvoW(+ulUF!1FkwgGEqqH?lI_1_`0KhKmISBSJW1F#5#E>6*Zh-{CP zd1lBK?qzwCGIJTxy{6`jVni^~-idD_FtkJJ3_~|EOQz6`LfO)jrt2oU@Wof_moIbX z-%>t&f z<5={k85(B{$gr>ITz8htO?P<>@TuYVHSJX?9H z+C+Jam@|v|iftRr*`6_^-?`jb`Na+TEB2M$1N|dG@%D3Aj9jSe@M4S;zW(nmthf8w z27KNU&X1ze`;F=RFM|KNjr#i>E2Ml{Q~~)o?+R}~v7qm*aPiN9{l1O*`yDKv*$wfL z{3QORjrvC&D``cC7{IKPMx*Pm|JWIddv5MXli|#=dR!lw+fB%r?MPJb~ zHZI^utJ#H^%RvRV-Z4CZhga>bj`7go2ydaT@4_BEs>LBJn$oTgT6Kq+Cw|wVRsQ*G z{ZC;!PzjX|FA5#>holbrL$lD~#X0Ek-75Wd=SnQgY75|la+E_>hy18K%xrky)PdVo zbEoV`vO9)Cdz+yoDV(j!s8t>dU@buTK(%njX>MZIoaaXTK(VH7IT#F)jIu0(h}HuY%bODmpc7F*$#7* z@P&H)bs?d7TU+gHmC!1GU9TUBBR^=~7C41uAKj#1ABXjf)H-B=vqhuG=Ejk2ZF1z8 z+32et+oXR?Btl)!I??+Z^xLF@O##komu!D#JCyj?#GqxBv}}=D<>L+dT}Jv?c9}`Q z2O9P7uz=Wxok_qC8}-MP22EUq{-{O3*GQ2?=!e}V&(VKo3g9xFl7vUj(O;4hP|LG) zP_6Rs=jd;6sB&ayNO@&i3iOLgZaXtNg=e{dza8jBRdi3dHaVVXW-w#v!M= zqe=h6ihQ~O(lP{ko}m%CH*Mw0Hr(^{O!Vw#roj0|r)OeT*VS72N|XM9l`Bt8%`1!;p1i%0j#=QB}^MjS;C?HjuQY!{9+b`D^!jKf_atb@@uJibMLBrLHg4HZHp z1`vrCS`s5H5_gP@4)r5f~l zajX8>X#y;|u>jJK1(1p)fYj5JI?;6dR*U|&6pf+#K3V(1Ov*grTJ^A2`vLV#J}QQS ze1wd);XCK*$5)BM3W4vYr4R@$Nuc(YAy9jZ1;*B0#n34!hQ%>yL>B*WtNsV61X(Alj(veWuUkD}RE9asLkacp}N>_PPyZ-xp(O|>ZrI<}O zf3a-3VWVkkx#BUrLq3Cd$n`ZHhs6_l$6>gKp4nktYQtl>><)9i4Ym0@D?hePziqW> z^WhqptskBz*XWR0)O|*+@Ub>z^aoH1HArd@kY3t5igg=;V2+=&(UEW0e;zesqrbrT zcy<}12O(>?WyUxSi86k%BSywYcjzA}5S1TMV)f{v56?1R?0;w}@N+WX=c4AjORIcf zhyJO;)zqKScUaszYmbnRipK(Y@K!u_SS|X9u5CEEQ~yPwP`A5(w0i(dCwhCaMVGucG{J%0KRrlXTk&osgy$VG>gW170b?( z4@UxGf55R2YY8%T%@l9)rP?6OsP?E;?G8#F8tRcxHrj?e&eI zni9)9p36-udTqnkg8Gx;dP$Scq}IDxbQqQth5Bb&wDO%j`edoNEkrK+Gj9yOE98w~ zC#jRU%i3>P26i3T7DC(%dVTVy(CcTM4lBb=!dN)mambud%EfY6ImwnR^u;|15GNE_EuP# zXtb$jWyGixH<&|a4}aJU(!G!(#gI+igs@70h@*`>wb88t#{F<%$B?n4dKd1EaiPlJ zck8#5MOWFlN%?;tTjgmZTWCefy(pD4Zd5`!5X~}JiW6I9{h>&eAF8}Lq`y=q+Tt`T ztJ_=g&9ODc9W7!=A44lqj^|`Kj2oXQ$8$3nSs#wj*u6CUM6bTU_-M3kTTM+}8_u9I zN%)#>TQk1r31W+)t*zQ+W=vDvmQC1)NzyMh>2h=QMx1}rUelmmVn$#$AM6OEU2Ia? z@MY$t0g9$m1xK5WlnjfOuExNRmK%g(zG~}km^D% zCaP)iCQ^fhX*zKvScybPR0PG5WF=@?vO#6wD?%1|#j325D!C z0E(5DDk4^;BV!Z`HJDF93apki?5&rM8ZJzSDrh(9P=5`@lq5-hpF}8yU(wM%({<8s zZMsH$Xr~m=w9+D^T%S^zvM$B$K0B##p|nj|I9U?QP2wizt1wA2xd*wf3nvn3y-C`% zkO-9~K_h3gHkyP@u+>>6YN}cVlbszNLCO-j$|Os5i5M`679lv_uR1(J2m!gq zB(o3@YtMku{P4##)I*&_G_BsG?o8R0vIC{uBuNTwAYm$9qlu7W=U7l=v00*;)pM$?BwKs|7c%(Yttkx>r?D4P%kG_BVuz+M8>(EFUMtETmH5UDPdK~3AIqDlUM zLS)W^il5?!NFcSxVG)3g5mf>*_I`<+owNbSs6?_Cl3rs9!5yzuwBU(KsHABJHfotr z_~3kfg*)A;X@@p&0EQOVTt6?xeGkv*`{aT4J;mqKjZhE@3o&Uk-rqUkDJ&cs4q_Vs zyz;}7>lnR*oWN^3Y_@}a@NIEhxzLC!F z!0M{O5G0NxbLcn=1|SqIX7-Mzwogrnr4u8F+_V_3jn<|{7ngTDSDK(s`6gqz;@L*%6fP*X-*8 zDPprO+WMgbW9|;IMMy_!k*~-Pk2p};Q5!md6?P&H@z}zp!;~8#M5Z;OajM0(?TzAq zL*Br8BaWN&6xK>PGGOcsV?{AcZ^h|*H4Sw&o2_)?ph+P^Cbb+hiMBV`i?b5&U2JF$ zRnzVU-T=i=vO#F!%rtQwcaD1X4hU4S>#K$cBcrr^orf`S$&TGK0V%z~{l6TmG zL!P?yOvJ0_5F&N}M;ELv5sxn3xF|l(z;K@jjxOA|2*uU7F?Sl~3|6BlsYh~ocd!71vxXIOBQ$Nf{4e!fjB18&q8@Dku{ zmUtiVGz-22CjX%YUkZHEf-eWY-Gajwaf>bZB0Tc_(t@7}{5A`Y{9XGkIP!OGwBX1e zkBodlU*zvJ>JK>bcYe+ikNlm=-!#M{f9E-tc;xRSTZs$tYhkwUTJSZ%FSp<*i{mT{ zj{~4OO5msyc_BTX%WV%@aO_n-uLH~Zf$cmcxXkFbfY82)2N_#uR07ya*ye;H+l zU9{v$->8k-X_(eA5fcE1eh;}RB(`XaG^+bv5Xj6jT%+Qi9j?)Q7B?BaB0jrNsYzJm3<197n?vw9rL5 z&;>k+v#=4bquCQqj}rpIN3sa_;`x?f9^<8WfF*n#<8>V0$oN){Kfw4+9Dh5*yBL0( zA^I`O#|FC!2wxHq`3Tr8^|9?`xR2?OPkPxdV*DDJukHPee~jaAX8cne54#AtFLV6s z5>opid3Mx~fUT0xj{J$=j{Zcz%Nc%{;n$>I_HQ!$SEheg(>#>!dyGHDa(^swZI|Sy zdRYiQqkbU&EW)qGbdHt&4Lnd2ejgs|2|gpsL+y;}Lwi#~sy|Ub@EZX)Gu+J(_7il- z7w{tt?_l^KL->V=|20F@6X7c-l4f`R#O0oz1Yb`<8SF{Jz(+0v(PbF6R<(Nw#9QG); z(vM&+g77ObU&8bi*7z@C&V%r;V8(^u^Q_0K5>od>`st|*&tZsuPSDY35wt1$!A}ML zn1u8gNw^*Tfq)YXf4~s;KcYL9F+`s)@WTwRW61mt=678p>8{@}{ELKfXESVJ$n_U@ zC*%Jmp_}X9jsBAIbN4d5l;Qmh;qM~;=Mu)JF+_ht^!N=7xt`-E8Gn?aO7~ZZCvf=^ z8W_Kv;f)O0FA`pocp}?BaXsTr40{;f#_(PVlbj3}Ft`JPMf~&LmM|rm;Yx-9hVWbBOJVz@{DSc}BuqvBP4THW zFhoBi@E0VUkA95s`RK<4WV=#dPk7o@3_r^7_Y7ID^k#{tU%>FI3?Gp&gYA&vXPo=v zj9VCIIScY7zF?T)lM*iEdRoZ*3%Oj2*j|giAo()6f6F|=IO~~JBk?Tu@2tBRe@Vi{ zXE0=cS^PtZFYz(Fkm2JDxjkp6NIaYM&fdfLIK$f+{!zj+*q&#w9nQFz>5~i}kZ>tF z2(tUqH4N(+wldt!ko{yS*UwV)VWW_S+6^BC@Dc#z>`4B1bX-@!QdYs>Fp{NEVJ9n=5Bko{#v zg2Y!WV|XS*ZVxM}7~jG0e1;*02N-g_t+xAy{<#0zp5vV99SGQOE1%P%;}INPz{Va9*Nkn6MHuM#h` zG30htSj%_^L$05~_c8uqhM!{i48uQ2Sj2LQ*zQF|OlNx+ZDE|{7u~@4XBj@gko(D^ zUo!r(glkqZG{Y<5dMjAe-UQqii{n9$Fw4BB{|;N1=y!Tm{%_n zv&F%YiLRl}L2T<)WYVx?VK8JR(3(0cjt#VjC63APaR@#yZDIJ|cBKucX|Pm~0MWBp^8`W+m>D~M5%Z0`Y)tZ&`s_NIY@gZ|=* zSjk|v?rxE$u8EG-2u^s<>Aa}F_2B44Z?KM}gcqd;6WW5kVv}GWA1|%mG1ygiz=s`i zC3{#Ma>4KdB8*(**BBq9o#Dt`q`%>P4tdUjvA&@69faxRY4Rhj8i#821l0M;V_t82 zLo*H;4jfq9>}~V5)OiEzn~ICQJJ&b){oXc&8tdxn{NBbLUhIe6w!O@IX?p){ZO?9)K zQ0}v7C=trb!${3`Lt)&IGY|Qih#(MY~7^HY`Q;|MZNf3 z9fH%&$s0skv-GFn#UkaL{XnLU=sZu+2`n<^<^e*$oU7kRJ?FYt9ROTqHtk;>=1c6e zXz!xU~n_0>-ceOU|c7s{4M) z^eBw`yf~y~S`yL2Rm7nCr_)9Kt&2gAB40eqc>QbtNn^|Q#^#tq%OWwT{ily>f@D6XWo?|0Y5+X9S90!6~ zc)Arr;?e|n0{+g^5i$GAhUau40`nf?D#2fptu7ARZUcctD?Yr(h{mU3o+*rP1K2Pp zX4fBLnzD49K^4f+$z?_k~7Gb_e ztm|0^n2jI#DSoz2K%`M_wg~gQng>61DS5>pSmnJ69CK+J$t%K7$>VY;dE}z*Dg03v z%hT9?iqAtl?TQId@p1hcd@sW;Nz?iCe}HDuZ~0rmm45jM$I#E~M%js1T`J!Q{mATE zgJJ?yd=dJc2_F07)A{u8fo9Qfbp~*yALdMB>9^X8IQpqen(+ zi@1lU^XceMtojw)0$k}=fN%`^6?_SC&*P^qm2ZT8h1Y|De(F+u5&9Kng5iW>0%SgY zFTxi46;U~qewZ_lrC-sDh&zg(x>UXq`mGrO!z}!74cYEXN*JKhZ#}{m{d^>k>X_O` zA$~FJ=erVX+nz_fx?<>8*#m|a#RRDMBJ5Xr53(Yfx)dKdFv6-GRl#=pCdDM<2-D;7 z$5Ia3aK*4Q-lfGVN1zYuc|3?$m&!N7&J9!-pHxhMiZ7xZjd@tVP#c90^W0YbE*=1m zvIsjPO)UK`z8G;y_^C_f8=>FDq~9UM1gQ8T^t*&u{vL%7?;ouCT|zu={KyZM;-~ze z6Jf|!^>Hca&QF7;E|o9dw-`Dgc*W=Nhh(Trg)ag@r9tqDFM;i(VzR`IBCIk+@F?u! zID!EARyKYlkL=lpANc}b*Hbwf@S}3r@gqJe7x{;U?*p~KefSX{@hCn@YvmgUPU(ry ziJ#(&ln4C`c{B!4e39}{UPE4-g|8f8Yrbe7hQCn$N?s)2!xlbDAB*o9#HsRP3}x^| zl;eYxJ`+DGZ{iGmr~`eH`N&^Yz7gfU!CKyV7QW>OTgrO_l~>uB+O?7wq2CSnBTnhJ zXa+u%SIIB~ST1=@F6du?!0z=^jJBV+9sI>dRvB)mr$}eU%( zllappeELWj-{+qNPiG|GnzifJmUzs|Us6%JuEg&zEB1JNf-L{yHBDJrna5L7zSdVE z=z9__t81#)ZAvXj)-|ec3*n0$)L=y^@$H_rU2D6qYSYMlCpL|I{hhmx)jOur+*OnA zN!!V;sq`C@CgZ1U+KDV}GI7c_X`jl_PE00D#rHY;0#ixHoH&LdFqMeE)r)V)Jc@AA z9(^jQuS!s>Ks`FCWwr=s`yWzyMhxfAVuv8IGzXZ8BpDF?qJvqYE{dg zsf4VAzH`Z5eKnaoQ>*s0EPmp+Yf6t&N>?~-(xFPeTt8Eb`&oT{=HCJrW&V4hrQV6s z3kf$lV3W%|dfbUj_f*1it!2ejVqo{4>M3_-*;F#hoBZV6Q}M@b*|0_R(Wh@Q%ASN0 zqx8>f&+E@=zq@40c2kj`rBj-)c|o{A~R_OWydXUf-MbM$2!rmek+U zcR^Nq{jGiHWyUXlGxLr5?mZXWs<+%xKei_rBTY{IH?q?E4)$G8f6J18&3d5zz@CF5 zMc1CTo6<7ltB*bX{ks-?`&Iba4O6MmC>~yR{?zdf)Ll z$+uF2AKo1p&%8EJdpu5Z*5@zYAGmzE9``ek2FoLta`ztFap#_<;|Wu)OgA)j!nd64 zTX#;S3ExVail0no-*Scd)al#txak+-aIg~|iN+ORlEwX1|PySSV*40^cY=ir!60)o6 z^~r?i_2-kHw@ulq-}m(OhFy|j4YG{(yZ!LFRCkT=xr)q3Kb~@H3RW*XwX1OFH!|aw zd?oA4A5W?O&bdV&Ps!@7zb9*3-+{h?CFNNq^}Tz>Z%wHmZ@FjB@Z3_}lnTFl${yS_U#e+`@7e<&!nz$;XSY3{r(Kc z-Iv#|%t)@epniTvdCe|IS=O~4EpVuQVa-rRIbjH|tQpEWa{sHF(8=o=@_yjZ=QNeJ z)?d_p+CCFJ9jAEG4N=3f-?1l{u?1{*5MNsQ%l#EyJSRYr{GRumnvPKzPo~$ zaU^qLjxf}rzE$hMy*}*4j=Y&U#W2`@!mcm2*<2dr{ePRQ_W=K7n?GT(x#oKZmtDM) zS*__8&r3_z;qxH;r|}pXA6fPKS&kpLWn7Nu@uwh= ze({x#tL#@p8WB%&KftH;p2Dsk@2L+6gnvw{>8GO;pz`3t%%&LYI-F>%`2T;oOip@A z)28iK;&5U$6t)f0UO4+h4t=+a-oQ;?y@M?^d0lV}L@t2I;Tu zSX0Lk?LYKP#}I9Y^vv#l92qN8T-<>*Rmhcg?Nb5Xwoy`fJ4cC(_?UOZF9W-Tn!zA# z;P?movHLIEMdb=&D+J)SV-1XAmvlmFwX=Wf(toN)w~?^~O4^F-B$|mQ+*S>dwptZo ztAttEO8cR*mG*|TRSXkpzd1c7Dw8IW(-?jAT38$lg`@TCaUQ*)bCwkR@AU6Rb28O+XUZqCF9OW_eQ$( zQ{S>k^g)zXojz`Nh_>H^yYFd}t;u`2Q@8(8bLp;hr^BA;$^z8w6Inn~fMmH=2*Un! zXPkX`x_!vCG{cp?$d!(N#rQ43uL8eZ{LaCz4!_O#wcxiJKN9C~Rl3rN0Ww@mklaPT zh4?LXWjPb9>Gng&!HtOjN8Xpf$5qw)-*aasnXFBdE@?^AX_}TKP0LL7 zGzB_IW}46}Lo(ekI?Xa^LenJ8(xwQsfI{UVq--X_W2uUu4;NJ2Pzov_C>8+~Tpsuo z3qBPUq)&YE|NhQ$@14mcO-l9S`}}V^Ip_B~zw`V3&hISuZ1)_l0$kF7^j`>keB2t_ z0f_^g3oj2)1j=0@j1#xa;6(-_o)&{Gr^EmeX)vyolt=8cxQtr-RR-G%<}etHwSER; zrPvm6{)x6eQpRGgjJRgNWO7m{C2k#DG941csVJjJ-e&x^;fD-@gPuLT*rr70*C_6BNNL-kESL+obB zVx(tuPlwfSm<|`i82;t}>PvmAk5?N>4IB>B_ckO*_IC=?2Kk>5pm zV}%FuU1P45D_sXPwpgMC)!7`X<*}d~&0)5y1F(g(HfK%FBQn1q$VtPZ|fyWQm}LaTm>6a$!~0P}t+1(+gFNqI>{aajq_mr4;pn<6TUii(TNi`>O!6{RKR z<)szwa)>xchD2J3LuskT4lzPdVt^?tEiDG_3XY@H09R5}SyEY6UQ}5+sh+ zv9B6<=qT~n+{2D>89V|4h`Z24V~C;buuA!>}%Spd;4jsxwpTwZ?r3n5u*BDiFdP%*(oRIsoB$J!^B{5y616vqbJ!Z zS@hUhoE&>~_OuUa#^Kj?F|Uku5wjCwXHH|JCaL2M#BdL`%TJx2cA69>qX4>W6(PEt zwqgxU1434}q3BVz z#Y9P#N7+^rXQ;WH#{mqJW_FR=GmaFQWT;kO_S72j(?8XCTji@_LM=2Tb^DZ~q` zn-kzdQJHraui$y75U;Y`D?||#P-AZc+~%(b zxWBtsV^`S-Bunn^h8eE~*y`H~a5%hAV>bb;Z>`SDcXbW8-cQ)ho^aP_Ul@123=Q>$ zhw}2PfbAXb$a9bRxjz=gWv=}_I4;1I=iY)8-vOqzr)JtUC#Lri)5cS3+O=mcntlmP z@fjOZh_CN8_HzQ8TL>H&(%5eRR&Ndj^Y*p(jfN@jaE?U#?!f`%vBYWYIy(*7E<#{u z-zCO-rk1}Gs;0bW#Ns9X^6dul=-b$v4QR&K_Jn-5$d%mah>?2~&e$vEjI7&M{hhIX zRR3M!5zNmt1zVaM_&!>;!@QpglhrB7}v<+X@*(DhA^$iRSbmFLST-DvVJ3u87C!Q!q8~$o%57IOV*^Dz1_8J)& zZ0@FrJeDTRHWQ<&V-EJH(x~wi8a1}}_QzJ|>NxhaQipS~sAI&E>KJfzqN*OJm0p>h zftLD4Z|mk$Sg5zLeR#KNl`G=eD@qN6fly^|NYE;iM8>RoJf6K_t3;zvU61*8Ze|gW zw+NOClSB@*;ShLSH7y9+#D&iEHWUx)v*yBY1%5b$%kpllX>JT)3bln^kG3q`Zp*RB zn_;fw_5To}M)p^yX-8($164bl%%du(J8SeyFS%ZOM0CN?J{kOpGBE^OtH(L%ws-%b?{9-n(&c z(QJEF38HVAY)I*4NcNd5L&mv6u}hDo42S{*J41_yPEmeLuK$W9N0gmBq$3}{0xCNT z(b$d*(VY-9&yA*+`nfUZxicvU#{eN;jjkzm*+zPB06p^bEb8F4;5I2^UU(UDS=b(a|V;~)8-6vL`@V}C+gj&$gmO_&essJ zgcvhlfsGhyp!bd|MnZWx?R23-4j&<4@KfjA>f=h(HgBnJ@X;buxndu{GTQ8zqhB;U zLSv3971tl|ZLjeKFlsOgUxYeFj5-x#%D}5WG6bd54{g-2tl3O`1mjrg>_HpV5R^kE zW4fUre>Dw%GUscNIKUm1SX(^moX zv=8Ihtlqwn-hN_;$+y3-x-FZ0p{-c4L<`;BH_$$Ui??y#TYXb~5IqFQf6E|g012N5 z=^7aA=nF>^p2U2bh&LUp|6#aH&V?6&G1ukp4wd_B__1eXkH0aV7+g-*)Jz59e+^jX zDVCtG(v`{(6I+v~Y~6#n{(5-0xBCFMT%K5GC;z$Ux+EY{o9{Xwd5fYFGUId;;rc0P zV4>qPHmrAExba->u?lW4H%WiX);o+_dvIy(?9-`YM5Iz7MH=4$+g%v= zp{FgD81wRGG~w#iE)|Yd$|)u$8`JxrTe)-3U`Zat6uR;bK-dH z!1YG7t~o@5T|Q(t5`d%U+WY<)sSv04AzS8_is_;u6*nOjIFDs6Sqt*0d=(79?KW`3 z6-&ea3|mCys8M23t5iXlMUEQLp#3ML_W!i(>@-T@3KU9e4`$LliW&-kRw{gk>yfBM zA}1y5ZcBAityTnq84kU^3cdQ<`3qp?O0C*OP99aL1Osq;gt+0r8meNL7gVjlj18@d z5zSMv0o(6_?I`%-aMN(tKcm3XS)BC9%4>o%XS+$qTP_1c5ZxU(_^w`o1M*Ag{YHIP1uTt{^cuZZasE zgXluhy%g_h@X`M}&P;-)|IPvhH2wD`SfuIqB$~Zc(dTdA{qyQ6fm~6?Wd5d&eZr)s7ny4QR5UI`B<4U=V%kC> z+`p|I)vCTu6OV>a3me6S3kMgt({p*v&c0}JL2GE}9y6tPJJ?qu$RmWc(_}E8MI*aI z)iJ5-&m7o!VCX8E*_i}U)UZhAt#Rx-(NRw!RK~>I z!82Aq67SDC*_UlARg_5fLQG`dlb9bn+2$tBgMgZ_SRu-u*F5c{fz(CYM z5PY`*^OrI)(|;C;1Ii{Qe?mqv0cw+=k|-kDFR~iGJ7s3V`-HMRQM|1Hl4Czdm>6FE zkVQTC72#J*a~!wmTvt9)q{Y=cvHB+#T+MmRPwAM*{IpJK;&e2v==V0(H|%g}`q!f) zXtsxRo89&eTu#oO&})4SL2u~7Vh;v*V|b(E<@a5M^ps+Jf}ML$V)I5V?XSknJTRi~ zQ0&*(_w+!$t9YHK#8X;XREAxC6_w?cC@;_IwE0OW6ZB%fBSgDqT%|a&kv(S#gV<1O zUA;euQ6esaba_bp^Hu^+sUq-{DS{vAa=D3S)T3Ecg2Rt>DHMyXG~Y(4bC2;;*)a?7 zlju;M%nF43C(;?%g6+T}9^zD&xvR@CH2<~Emv~Dk1F&e=THjcUMPSLc0%KQ40M4 zq=C(K)xkXM1osr;PZ9koMpDq3rdVXjd>)$b!bCYbs7Q~(i<0NZL$l{m5sG*O!7U;V z(Tlz=O!AD-AXt668kpQ-X>i_ot{57Sbc&ZxJ)p3yKtYUa9>g3z9|+U z%rxmIUeW2_CsJP#(_GZek5qP_hjaIoO`%t&ilPSxXj4=YMK7p{KN9vp`5r8dc{@8p z#YJPt$KB!ZAe@%G_Cmg!yWMrJD{n6<{0NPl@a!!sCVxBUU5pf9Mo=NgTm{(N4U9Se zgSqg07YqzajXlVPwT|KzfzuSWcJ{))#)ZvJl1voWe|q)58Pis#rPf54%F5F;!J{!v zVDeZy3m%V6O_|AH+W3}yc&5Ced0R+)R&fzF?=&}seDq}o+Q}DU1Z}SmBIM`g_1G%e z+|;lG^TE@^erYBe&PIHFA-)!-&4i+8o0N*`pHqbc*iYU=W+1JP-yCTVCf zPOY&NZ;V_IQwmvFp0N?u8QIifw@(?K1xQ)ij5Ru}r5D|a{YQ?#-f|4XuqLj(!w%Wf z1GsWRz$}G*(3TP4)ts-AXJJDUV5;gIUc+tx%tvE?m#Uvo6A*F;bsBI50fY z+SA)Dvsz!7tZ^Y7y_jY03U#&*cZIsTJ>1qIx^^U8|2Ov61V_QKxF}(4hgDcCvqTDG z>rWw!tfil1A53%kEY%iTuaDqyNmrf~wPtW$! zaTD;_ZQo3U2gh({qXJW1ca-WY;&n{%b=d?YLl&+n$%DfNdPsl`grjQ9=mXHabE0#=3r{fxSGi3fS zS;%CWN+$V)O!7Hx_avjzT4cs8Q!*)B$RwYTNxoPzdD(Kj&5lCm{VAw+TWK$&D4x91 zjX@`hY|kER#l})TMMkhQdvJ$Ya%Ih?t+?&fcw#MV&@?6&5;wqJfsn(gb0}z*O3~3f zBlG9j>tO!tIWec!Rb<1o%<(4D(&IhsuVDV@yg6uYsUp)erzS7{diH^NsDEj5VNS2F zQ)!O(R{U?-_2B*D{IqP#u`j$CqO(o>eeJt=!-UpS&&K3?3%_D2Y{lEM2ZJ~ZrmK(M znxc`f=7hm^tZHlN&KIdDOgS!w_Paq&vgGP-?;OF7S&2>6a=4E-O4d(R&6h4&#<__- z5A7#1{?)XP(!0bg=)BcPaIn{*_wfa1MsNAHI|Eja(!0o_Hx=`QZ?J3AP(c^{i|cK* zH|d=?%03RgpIyA*jFfWT=421PdwXXO^oKhR$co3?Q2C;XS>$;enY5NYjHKMLq};f4YH2cCloZjyjj(l!i&~Tp-pJsjs$C;EW>dB%8kTHMEi$W5A^s$U9*HHCN@7YiyK=sx;OeZIgr+9WRVd5M zNl%T7A(R_B<;(0Q2>sTwOj-O}aMcMn8GnDPhF)wZM@w&yYUzythtZ6;7{`8*oxuh# zd-)dda_;<9kZd5UO=KEIRVeaWdg|l)$_2=7^7B3*m7mN>pLZyh@|4}Fud-uM{g-rD)zg>_w#I(&ODbmp5_XkxXz*80l zj^*Q)1)?v)^Ort6Gc%db5r#;l@u{DLIJE9 z7?#}#E)xlE;RS7eWsHQT1$jcdI!B`0rL?EnHR+Cm$IwHbjWXIvUR#Ym5EYXsWkhL` z$~hligq$fFJD8zf0^WVe11ciQ_J4=OVkYnV5=#)h&MBOyQI_cXi3Z=hC zD3tnCPI|&bEQP2}&i`-rUr^}ltCF)Dd3K@E(4yy3Fm9#u0r~8S=oVrC&8JoXIYoJ( zc@%7A?!~w>Y!(ULM@qkpy}bmz-qo{|Av-}*2G4{UWl;4@f0q^M?qheH_ABn)Fb9Uh1&=n?i~2>Q>$8I!^%g3KCApe)-nCxs@678S6UA>om=(GvJL zQss~w8!BTFXsJCY&iEELx)E4(9XqznQE=P389B=`tT;#2{i&R(055ulJqgZlo`SO| zvIb`}gQ?}3!kK66;*IP%aDM5W=<*uN8oL#1ZjS81eO6dbne@gI#oNfmA7x+6b`(72 zo>7!Ek0DCd4MP;cGm0X6Wjffy5cQyEW>LakrYJI)B~`p1BAVrxsp1CA9Ar;I)I<>% z6?=L{)V@ebnVB_*F^f^eLO! zX4&EX@X)RU!h&hpW0*muNj%wcqvTNsEXtru=dq_D_E4E?2C*n!mX(y5(}?CZEqe$( zf zZ z3%d#0Jh^_3+QiP$ccTsESJq4HE@<f9+g$t9>=?=-^#1aAr=S2=R~DF36mq z|NVLFA$vZp6!YdmB$iJ;5PfgImYc3G>KY#5?qG}AgqYhwIW=n=7{%Zfhm4Pe_Y7h! zgIAj!IHO0^IQS)wcHLp-Nv?HhRew64{UJgJN}1lNH*Ds*6v&O(P1r=i2QHnNX7 zR%3%zs}~=XBOM|;#7E^3X2W_@8(vq9?V=&cYU>a0YJ`%caF$A=R&~US&FJ{}>_TsC zZG}n>Pt=$;m8-Pj5Vs%}#>tNSFMnxiRsZQ_zvSHT4cEKpcC?zkp>(5LIfSj}pqy6q zN;Ugn9Fo^shxDB$kNaxaEyUwOBPLso@{OnE6p>a!V?QE6Ms$TZ9L-AA&8n<}o5bf4Y z?7DbtPNdo)5}d^=MV71_S=K5?1v3k6)l-|;M|dRU^{gZPTOB(p6m0NHQ9DHaGwY#% zhe!8Vc1epGsa1Wij(yIEKb>7>V({U5_D#uPdc)4d;OTnyJ*7c|OhRwWB;aeL=p^*Q zZsQlQpPCG08s@~|u?yI1f&+4SmIYL+`r8HUFEUo^>|=d;GrQ7BC2D(cYO4_a*3qhd zyO~|*q;0N^jSb#uN(DDo)>PwAp}MDm{dQFWy#Q$&0(IG_hn}0hdUY$_c`OqxyD1c~ ze9_^8?VR+uma5-1un(_Zt)f#OOT0W*@1f}Y4Qh!_?~eA)PI@V;_a)dkeo^(sM)r_} zjq!?K{YB1(UV>IOC!*P$AT}3oc(ajx`s`Jt4L&R$+AYRsJQ?-4fF0V`cfipv9;|Qg z!(5s4cZ9JIM%(bcCiYlFWS$yI1dj}dM_y!!3_p+DHaIlUg)^@(WWt+E0<PGaYspj%wc$*l5w~75VZ3p;>yzKyr2g_`; zZncqpxvVyGzYW#-`>Q^(g&keP>wKgJX6;AG6MJ;XEb2X@cKBE;GTH+ug&ZU`$PuNq zdkFhBIKu2dXQ3hA%6=A8u+d(ie>^+EXhFytP9gY&5PYI-8o`IRv0Dmx=0~Mi4PDs4 zEal?-Lra2R5OQCLDR+lf_3$=!_u4hop3!$$vUS!TqcX~e1t`JI7IQyJV=7BY7{Oqi>*dcPlNSsqTNq6 z`QFLJv_eeHvhs#NG_7J;d17$HU7Qa%9F|%FjZ-uEO1@AVh#A!$vZ~!i(Zl^+Vq~Lj zxaU3Wkx12rRcTrd=3$S<)csUeO<8ohR^9M&8~a_PLfn=!>vIZQngdNr{Xfi>e|#_d z#5obgK-v-&3Z@)5EmN+0^K?y#?Hw=Vq_6wqhA)KJGm&};lg^~psVq7GOY%hhBQ09> z&Q3O7%3ll7+y2ZKgZnD+V%SdVWbUxG8j?!4CGr zQvRZePLuhn@sx>rPOroob& z=~ZTrMyvd2)oo$+S{bj4Q>?6BZ$-CFuQA?eQC<3JwBqS_L8QZY@$q!LFoTiVK$OPL z{?2XV1Zog5oe@Q%6-kIBg-{g9 zR)nUdD3FL#6`*PJl-J~)W}=9A{%VaIgvrj23?O9*z0pJqbqVP;krpP2npPbdz?lGDW1=M!AZwSwXdaZubmW6i0Gj4E zvD@eEn70k7+$2y6tRrSBUcCvBVi#CIh}bMZO=}>J&AB1D1etR_a;(ur5ZJU3;Z&5G z$%DHU7V#1)vQ*P96d+}F%VN%n%0(-A$rBVfP1~}Vm!_?mC{5ckd0F3H!a3;)g&^Fa z08P6{dZF}tgqH}~gjdtvt0+n4`xH<(k3d``OVvk@BVeZhL`b^;2#=1DCrwE0!up9J)yDzu0gpkI z0y6eq0i2(_0l<&|vKEnE!wSILu9Vl{(JH8=iunM zI6i$OJhm1$`mJ5t4Y+lndxWm>Tf4TS7k|(l9UL7wm+tPs&Z<3Oa2$bfoCwl}?{g7z zkGrFdUftHM`snPg8$jfJ-Qhh0UEy=P2ZlPsiCTR>Sh--UJ>mY5;q}NDPf=-+du=hQ z=)j&qd<4)xvL4^{HxkVtWDL1V*SX7Fqk~-#>MC*N(J7N%xY7#Wum=YQ`qsN38TT9r z`*n76`w@(khdV}hkvokAJZ0{pLJ#h{0?jPUKu3(8dk(k3{(+(0rVr7PKV7~1db`3d z-iMiDh|^D|qkB4R=tsg+%ddbawz1bx;=_`_P7R)W(koX+t4e=Rt|s zSK3w^-iO_FJPhGDzNO9N8^uJ#HG*-Y#g?u0{IW!Oc=frsy3)0_R`3xX<5U5r|okQKO)9#C_cFlB?&C}O;-!uZo z=lKyZKFp7R(PSp0{WKm_{iGi$$gaKfN5D@?*pA3}BPV^+0)xMLSSG^Jq#I8g;CKVV zEro#5WE&5K<6U4pwSe(%HXeeh_oyBhV7!8p4l9JzPo0m9-ZuLVYW6AYWr*R@KR{6!0FPVX)quBJV4O=GZ`dFF;E%&)%;EuD0NAiUV91Z# zYYB(^xN|KqSxYx&r+zP@Yf(wMXIa#cxc) zpFx^m2EI_h2?*!quLv;8r}ppo@dq$HAL4)UN5WKI`I95UAxk~fzGxkqR+k8OpLAhA z4&NnQhWxKbIBSzI>L-P>4@mb8;p)ev`ip-gEaC!quyUKKl96g*=k0qrMTH-Xh_UkgIn}ctC~^OBnTq^wK{n z;g3uAThf*Cbtzx}rHuav>7Ep>4dt5T+D3&wHt;38*-)QJFWU#P9zibZ2ZwK#^b-Qs zb_jaPkHw(VkiRR*MgA@$SLM@{7)}#>H3t4x{DT<86Z|zy6O#L!NEg*_N}u+YaA_FJ z^8x(1yIHyyNq4t&!JmiUBHeqW`-pT=K6p6V2JXHsTpe|VV7)-PKIy{V9RFeI-Y(s* zN>}QuzawB9+Fqi!6-sxbbY*_pE|DJ{H|d` zC4C&qD}~4XQo4T@ZanH4;o}3+mH8Kczl8rsxK5e>&Y*<5rF*$_ACm45rTa7CCZtO@ zSGpUdEAu&FT*6OESH*inz=<+_iFFdbQo1)wSC)&!*94p-?Vq$>!VS{xlI~IIenq&+ zcp*^wlNU?(9O>?n?p4w~F5DDphm7v{c-8^ZZc|Vsh-fx6Yn=joPr28Z3{z|y>(LNI0{JqkZcBQvC;nUH6 zarai~zA9a*S4N|NGu|iN&rA0);VzJNSm2THHPXFZx{}Yr0s$`^knS_WT_p2qk)&TF z)3sRIYw@Q9U8Zc`G7m{u>baywz)NKLUh+8!zb4$J%cLvI%Tn|cD7|O7rF*e-zb9Q; zpR?u(I7{lCwNt_)(*2lpe=l5W%ZcwYX@_N(N_bql4-0oW8VI6WevWkg(ruCMMbee! zWVy_r`?L#ZM*tzrw{e zWSoBvDm=-_$&#*Y&vIn@nj_0^jx4`9vi#&oxjEO%cy~%y%FRK4it{}#-Is;CQnnW> zrQDSn5}zyG4brWa?gi3)k97A+cfWKGN>`SXmG?+kwreZDDBJEP7+>j z-RDX70^xe*OLwVsC7nmw&+~nW|CMlyWcetP^{VJrfj9btD5o1>TN)>okc)N`{rh#8 zRa|GBQar4!!||6R?HzD?ln?6x>-a2pXmGTnzkLsmB3ozTu+3sm*ovTifL0iXeh&y3 zllUWGd|(e3&?%SQ&MgWN!tJ)iB$mj_ zDJfO4j+T+{ZR2mX@=~&1y_Z$v&?s2c{L4+M%9-+E#+kxVteF0x-SBwaIhI@xG zWi6I9c(h&nc(k6%&B2Dg{d+t`71Kq7**ZIU9A5)n1ri#~y`cS)-j@ACqun7NafwVy z7bfC4dBrA9J~C2Ty=_m2Z=V~d_zLofJd_E;!bt>rokx@K9y-mAii;?3SclSj*NFl_ z#buyB)YlinCv3yK2<{v135ha=@>)`Ua0Dw-vs6pU>yXt>2c5v%OolmgQdF8r)p7xmJMX0P7lZo9O^?U#_p( zTanx1yRafR(Bf;Y$o1iJzi-ks`Z{UPbIsX$T6i;Gpw z`b2DIQ=wwAk@bss%%*}x@t|xs^KmvUQw#=ET18T3HqD~sMXmek76=*lv`PbyYo>k< zrI^P&?Q$SuM>VQ*ECd!Fr&j_vgVWA_BlcEa? z`W#(>5p6d0H{wEN#FY^Y!jw#*xU=Y{$ofdH%hRooGVW>BM;`aI>LZV7 zW+T<5+2o@&z0r9($NDHV;C1@+>LX`h<~DCaXVFo#CLw0lb4I7m`;cVByWY5F7+rYk z@kMlxro2w)(2GX@EEEbAc|tLi40VRErN>k5sptSrsKvLnwGRD`xkbSz-9o<@J;CYv zdq#p(>W#h)_TWzmRGo*CsX^#e=Hk|xDN%ScSuqXX(zjCbc_FBrO3(2z_>0`~6#s)d zsKNTiY5S+^c+dDB-Z75o6QACe5DYA1_Ugfnc6+zUUD<8Hq4xe^?DpE@AMNiP>BS|= zZ80~8;j64J@NDnH#x8vLIih(n@~z{YaK7l9?Wj@P(zLkb1U8>7&==#2k0m(88(V{I z4y~qWox2iize`!RPPk-*WNO)Vc$c8!aW3)coIDYKQyBtg`{<8>k|JPEg+C?uOPtjs z{rcB{u+m|TBo>{9Ijjh}4Os6@R?Og10?7F|{$PGVJ&ro~hz|4``AIH*`cb%$t4sYH zLBK`$sYmkDFn7Y`O1$H0fSHQO64qex!y9)8{!m=?DC0%(i~H;B`0>3SvG`$5)~cVg zA8@S_Y6**`dtjDye*xV@41Q7RNVpy}n4dD9Y0{h6fpx;W3@TIiDEsmC^H}MPrh6aw zIj8c|G52h>%lvNSb&Pz|4@c5vTn>J>Pvxg!PSeV7G3Ks#nN*}Qz4`zUmh!il_>+Dc z@LP_bDu3~P`;6ZgnJxV`W4h*`#!G6h#2(F}Ke}~_qUoP21>9-F4Y4poQLiCde zSC5h#rQg}at4<5U!qS^s5>HK|m3~RdiAIt3uxLTPGE%qLb~5sz)1L zV6jONnfzD+{FZchdjKmtuZ4e_ba=?|1|ntdL6=&@l%hI8>Qc+q#x2^Jc=$#zspGGNrTEv2i8=q`d#h> zOur5I<>06EYlk1aReoF!evXd=ryeC2YejRUl09BYH&_&94VxiXX{Qbmj0{FJIfLzv>H>IbDOir``zdQj_{NY^`4HQ-;H@N`!PvZ40js+ZaaZ6 zm!zXSP;^V+r+Ouy+aW{$p@QJ5x=n4fh3<|QQS7MRsz=c=WT=JiQ`nQGbtodZoX(h~ zz~}ty2F`JLN-9b#OFW*kBA3hUqDTD25>;7QnafpLR#{fU@jDX_`WpO9SK>HF*uc;e z-s87B@RxQi;>p9V#;sr5xM}cf$2JXq>Cd0LZQ?9{@?lN8VoA#6STTJqvz{4rS`n-pMTT5x88Z@@84#Vj)}$6mo||p zee)-lNMGE9oqXeQif-I7De1=3CMDhY{K@o*MMU=)o6MN7Nnh&30_mGKu~7OJO{9}= zJbltOk->c#lM5zNxi58c;RM%eeBOk!M;mAO>vdx@{4ZxQ~+-(YmA=y39B95I)jF zgc`h}^blz!Jw#eb58)#{M5qxrLXVW}jpHeK+HvhS+QeBa^`7d<|VZp>U>bnA-DL$~CPFP_N1F|}vo zc+z;{c#5-be4)!ezQ`3fp4^jnXTdn@Ip5Fx6+Df)zhaV!)b{j@$KP4tXFUgHn1--; z9>#ihj?eQmQ3iVU9!cQX1t_iY!1DM#<^D>J&6tdz(8(v^^vQV>8o`qy)_lOcEJ-*G z^qhmFpBEYb&Vrp4cNX-tFFRjw>Df!X9%mmZm{_pWHIcD%=S2F>yovccdnVF$x+muC z9Gplgak`!3DHDmMPIuaP;zUxJ)15han}Uu;P~>MJe0|T zN!Ak|+a?H$@7Wa7CX{-f7T6@2r=D!$jA0XJluhELO+>8uNVBksfYTN1QyD^@+t5hsMu_tTdT}%b-2aaS3OkM04pf$In8I zSjDZi2qlbjndGS-XOWbXOOVbb%PWs8nOr@g4SZM1JA2>}Kd+6GOU`%hbWWsvWC`@t zCsHQ$o=rUGc?*TIS!uKiy7W1L6QK!cQFw~cS|&_zExyeVx{PZUKdDb-bDs@3;d25f zLXEhSnb0tE!U-K=Eux>y zuQdA(>BBYq4qL${&Wiu;#=1#Sw}?ZQ&<|XNk2svgaS5=iC{L--FBRIQB2R>Vsa(IL zkEC+_k|vk;Y|3MqlhuTetR_N@ zxRZ;a)naJ1Sn-%#%(Ytjk;P~Ymmb$%DLF;06gAdbD}@YdsgjLaxnGt*s+9>wt@Iob zty%`8i*hO8bd)}8xt$M~TTyaJ13i}_Tg7>i@l~y~wo^ODCQ^FhsSLm#vQ#3MNy7Eb8P@X6Tm`4!IiSC89zuGqMD=M`?Jv-h~O=gN&kJFo23Hx9My zxICf$nZK-f$HSKPRDbw**Uy}5(~h^TbsZ0_-FQ50?V)EDytJj_o$QUr6D!_Bi&DT7C85XB__gm8_>j@Hy<6Qhy$4=x45jj$`DzUH8XB ztNabl_!GyI{FOa-5q9TYJumqyHx6?DOC?U{p5vLZ!~B)KE~098_3l(L+IN&sh^1pq^WPO>1v73Q(~?PLRTyY zmb4d_xJ%2_av&YoEFK<_#z54A-^ke1^L+S{4w(mwFyS`!g>+k+rbR5ji|)9C5BP1z zY;38H1qtx`|JKG>a{Y(e_y-mnYwmaO*f7ZI>|CR>2l!D7t{nwj+v;rX*OFH)FrauQp?!etBZX`@J;1qCFw&d?E@p{?FnJ zsdrc3y^-fOXzWZ>cwrj*LozLn|HElX%%a5D?RI`WJAoGI$j+Qg+|J9gl*wLT9K=oj0LeEcAX`MrV! z-*vEUu(7vGhI79RYa3Lak^K}qHPQB#4i}5gHf;x;lg#>@H`&EM+l@9ehz@y+Lzh3$1PENxV{M6!*wK2u?X5BZ*8z0 z`HzFz`PVqv7xbwnEKw#T^YQ6Bzr}nY&{L2Y7nf4%?B5 zg95?RO^DYo*UtZD0(-!2<}_L>dKpvRimD~^_m{|(%wE(Eo;@gD-|bcRYVz{49;k!8 z;sROP#%x|^jR5yWvPyyLAKPR>y9gVe1)AnJpK2Ry#RCppx^XG!El_`f9ya@f14Y|Rk>nYH4xA7N$cLWDyXUEi4vmA^&>XS2 z499}F1pp3`Z$aEyj-?A64qHNoW2tRFP!3yCMx4u$vB16Yf;-S)g&@w_5(rjsX{*BAnu9;YV~uk~Rx8;Wx>?2C@7Z# z9_8i*06W<(kIUf1nViuIU^7KX99YF&fFEf~E~S**3-PPKuhQb42frUbl^a$UIpIj; z*~h~jiIk_8N&iClFGo1#mm@1~IsPWtzO9imjup1UR5}uDH!vjGcJD#1VlBidmB@%Q zs6-lN#BG%k+Tc?9+NjJeupL~!Anv^YRZ__Kuwz^xE+Yg7LTqu6dPxQxvT=+|iIvF} zwu3xrC7cKB;Nn76F(a3X2f0*4NV?)oMFWOh4~MgWju{JhLAJ&wD$+Gp0YhxZO505b z%ZUXHmrFVQ1C7iYXSLg@vXWGwETl?gl?}~FS#C!v9wlkYY=KpV{^y32`goxs<0U9+5=RVYYl;N>Xe)2#3^O&Wle9*P1YnxH68P z7xyI&okI|n9fZJ&@KgHMQ&m|60r4Wb?fqN?R0hk-;$TWg%EHyQgPuZY+Q_k;f`V$I zOUD5x)Yj5FB0<;emua`&%6(cwA`XK=j~lL*7zckIceO+({0rcB^0x}dQ=>}{^(6EQ z5Kex48K*bEk4_z2&G~m6MsWB8`i58Gy1)CIu`bshKO2x=4coBh83|{pp zP8WhuaMF+LG*}70QjG8-l^ky<2E2MWJ14hX0y3NwgQ=Bb8{$ahDqu{P^VHjsOW7?Wg6`-eFOcwA~Ay_LlR**(@khkC&tw%#ayNCGB-{%SLlmhY26d*-$Q+pmSx z`c@yWHj)}RT(9J9Xb5>*TYW7-6D>#^d|Q1D(t=c&`~l7mCw|*`Ro$X?@z{?6esP*X zIU4C@Q-Z``6NCGBBZx*P=0pAc3~cD8L#WMDtMzr*2`kRxm83+s5WhwEErw<+DHIZ4 zFok+t8cXIM3e+^zS4UJNx2FbbMY33{%C9^F4GFuf^n$USJTky()3lK5SgZ_ zRbz$93!@E#rXti>-{e}0&y6)U0vI3Yazt@ac^OcnK%sOID(`alSb4X2p!`0B;A(IR zF;ZtGk(AvaJs{+Gx4S$=Xmc--VgQpAVBRmK08`{CDKDugE-L~0QYivxQ$%G^QE_p3 zk-NC8qO_#EytKky4iN{*kVp%0C@t04Aw~#F3@~M-rNzKq!Euxt;7W=rODfCCiz-V; zHFhNrq113uMy7ZwN=nMgOYo*BE_YX!mU_xOr4V)v1Mg6S4@JdlzQZOu%8DN{Lt-2A zT9aUwHvO;}LnND<_IeX5(=IK1gBc(VU^Vo(8EP0o*uEw&w!LrS7Bg(1%zm>49clbq zEFrP7;8shxp~I;%;x?|g-^d4R`9nV4ZUoExhzkFABRqDl++l>zGE?q0BFLg>Da=QW zFliWT27Js2jFCGZHv$dA%$zx&6t{$2sl4&9+YC=d)}yZC3e4Qj{I1KLpmkJV94KjKwrVpCR>HS zlH*P03V#*Hn<9*2Niwe1A%Zei$~TG*f64QlyoSf0mWF4y{s7ikc|tV(3-GGz1n8@*aZ$)d;3;^fGvv!{JXv+IuG9(0D>w)beG<>tinYQ3Iu_ZtdfH$2Lv8v>p6(*C-6R2_ska~vjV=%(tUMoNjaHs8q;)ePr9}vC$^i8qGs;JxS4Wdn! zLBk{MBfXs#it|FDre=IhjX@!Gdb`4%eZzy{&b)r?ix?Rl>PIuNhp{YWdKh7$Xt1u?2Y;OboVn?#8SH z6>2iKs~{g?6zc*cO~fJMD9P=8d@@6l!WeWIK37oi!z_%#A^9y^YJ%V(Md3gR+zG3( zH_*^EH3tyTKQO4Vw*hYR*8|+&-K(*yYy^@e_jkjL*8*(yZ3Q?S-lwsf0M@rw=jFS) z23+qaY-dlnYqT$nyZMHOdc#9``BlL74tM0a$NbzMi{diZ{vO-_;mUJwL5lAH)7n!r z?V1zQ`-o}dDK+idGZ#(21g7}<9x22p(;E9Zfz2%h4h(7RHvp?Q2ZDL~+WSVsly^8o zt9|$20P1=eEzOv2#^NK}VcsXoLAHa;zpG}Te`IJtu3TdB zal@B&b_s_3xGmI-Ps`tIN2er>9kJ?9I=h-09+F%iXvOU93}QKf&?BH#-EU(zs;J&m zMdbuW)Dt##hl)COs;JwEz=-;JJNuN18fXp7sBd6spcB`_w2q*?2~bH44;hR${MF7L zq-hee8D}KyH8L>R+)WXAEKQhgCPr1q9PCl0QR68zYHaWAkFCztaqMZO4(DP~$A~4> zG2rM#RXrZZUR1gSTIw6Ut(#9_q29*!;oYWHu83!^C^ZZQLY2WGL90v>8MEr~c=m>^ z5{*K2J?6}Leu;RzMX+3ODYCK+7x#?zjR?ZFVeazHGyL^P@5W{L(Kk@bBi@ZQ&5Z#} zaJJCv(Uzs#Z8*Ohy- zVz);Y&i`6X5>kSP60`!p9Q;;NKA`Q!{JoDR)AB>Ja&AbWN$tHqwJj zgOI0ZQ3tmLw|^S*!po4$a$XpHX5qzjae3302CSY{kb^k`z6kJc$F-D#bv?Xl7@hiY@4St1`H?SxjuElc(lkwB$ z401$G6j&$f-KWT~5*f}{_^`kiGhcy?7;2#Rj%(pUc{%NL30DpuAz<)R=iTb#O4K%Q zsc!Jm5>UBfAHX8l?3klpG(19Mjw%(`AMkCj@dYqyFbZFUI!25-6=TZ4t3EOWrPB{> z)Ud4COnn67Sn2FR8`Th$LndSXp&)-X4SzItF=c}c^|;o!@}fyVvm2(WpO(W=2s3Y3 zAyo@2KWD1iXzW*pANBNA06p!)I2yFKZ=|=M7-I76FRX6MCSPbP))Ub}^WCobG!pgK zH`NExLxB9Z43Y+r@OhA~fzgh>a5Ujb%%_QX)3N#=hRc6lco7(LUGDBsxxa=V`AYWq z8{>(=Wx`F(R3QG>fMuRyf%qz2sSGi(HF?U`J=odTK0MspeSljoPppEI|J-w35)i4) zcb$*CMNtWvak`0c{S-8?(D4}?RwFO+wKU^31n`Fh;vLo0jHV72Dgo|U!YKr;&pby6 zX&s*{uNbK3ISrYER*T-?1P#rbs@<-$C;}AKJyv9Z>y2n#bBG4Je8_Gj0LSaL_x&?cAx zEZkhO7UWU+Dj0y&S(!ATc;@GANpZ=t9xG6z^&9(f>QnOoFEW&H@EA{r4tVr0Mr0n!Qxf=WpQs z^Xe(%y4elj#IduY$B(`;){n$DhT81bv1IgrKyP1uW@LBTg`JEAEW5b?g=sG>z`HDb zAaEGVsPhAYoFk54AvJw|x^~-MJ^%<04fVA5cVQu67Z#tMWvuEho!!9BR?Ua#G<0hW zF>=$j!=ccaWo`#Zrd2(ovzwx0s0c@5ML1+*A2lP;t4NW@=GS&R4Xk3U$%z>!Hw1q<5v?ixjeVryA4WSk`iVGJGE^w#k@|vA}(d2^G(9k_* zO7C{CuSAeX2y3UwU_OgRc898CQrDk3u=BvsRW!3R38JWBk<44;*mt6%o^*F+X;)&pTFjw|5L% z>ANFJ8to1j534cuC}Ocg`|*@o3FPmiYa>SWa@3*vDHMyXG~Y(4bC2;GX)p`$lju;M%nF43C(;?%g3Y=j9^zD&xvR@CH2<~Emv~Dk z1F&e=THjcUMPS;EPTSP^dazoy)!1D&kwIIUVy;E^tJUbcC7m%N6EVTk-nYN~z_6T$ zp`rM948eKrU0p+bT{=>gf&v<0icmy&%!okiYpp>QEiWooz7gYbn@U=<-{0ypViZh? zVoG^JN+~N*{0s766WV>?ic;tYAPsD;s}AO2W4)&ke~Rc&F_MDLG{quI=JU{e7beQl zK}C8LUX(mP9-2LmicrKO2yPK^h+gz{VUlNr2Eppn)xhKyOM~;ybH&hrq*J_n>RJAh zG{7E!z2$lP+=cr*h5L#M_f4??VWvqx@rq9WK9Ty0nC7Bxex$PdJe<3yYzn9AVPj#UXQJk%}otEFdsZk?3ZSu;cUdW5x4U(()g4yl34pP_FufK zr7-$*!W>PRmvT^-M_u|tYDgMdj8khY#T(@si(C&=3Rzg5u@Tl8+0g(u?lI{v$_VZ#jlxSQFRYVTWw#fxUQ5i&gOy_CZ@lfLC*|I*tuVfT^l;cn!M& zFdx}bTaWJh7ue0V`2r(%tUbggZRrJn(37+KNB0EV2gN#jy}nY*9>hL`5p>FmGQ)8P5qj65%nkvU<%UAUT%XI+FrW28QNaA0_(wWqgRX0^UDS>r-FdNIq~73yps?h18vd$_Gb zC<74oZ|tuLj)G%xQNq{`tFTyRi4?}xpF$W}OFzjznCK|@XgtpWGi6c2V%cl@WN@3= z!t4fc{&T#OY}PWc-%L`xtosc`iJ8rcT3?a?AcO zyB|DXOH9x9x>4^>P>Jv&fP8wk7e$qPcH1`-;lU*#*{Hx&*Bzz$%DC*!gCaaRdvmYw zrDkvL623GccCfe0v^h_QBZFO?>L~a{Qm&AB(vS(CUC4ybX?q|kT{~%&c^}H3kcse2 zArrnVArn4VESZ!}$2II`$oyflkjXNYO!5ht;109o%9>4Eaoef!#9G*( zX-qC8Zh*Z4A%|1vP|z%uqN8_4=FhR$!Ti^AVot5A$cAZ|<4vTc$9vdc!TiyAbI{yU zMW$y?O;v;q|I+5doL*n2(j4!t_}{YY!TZJeY1!S~BMsqx{to4D!pM_js0PJ4 zI7VM-%N`8w@9pa9qqnALZ}L1uHqplB>VH za|AnPX%`%%r)oLe#~UT<)okWVmn`Gl#GZ%t6B++%+DGYKVit7XY9u(=>(Kl7f-|GH zeA}G?t4HZwWYL?7dBQi?wP~oJi~hy+w%VKYP8?+)hu+UFUT{WAId5~a2j9KDvj_Ua z9S3B^<87#X(ZnqByp2p+%N|Bj?pX4FFDaH>5lK18UPMxETspNhnJr3+=-@`!I>kjT zN(XOb&}8iz=~3-QvW6v_6FKQA>GOH}0pC)yOh+~z$=_msg!m(8%_#mBdap%h^(n-k zgwP|ggi=XNsb*KscNAQmHIvZP#JLJ(nK|jHaWRB)L#KS1-2|cET9zq`e+zD6<0j+p zZ`II??d0ee+oM`~Bfw!a<1G>GIN0E2FW&-Q&Yiysk_}|FiA=+&3PoN^Pkmfpxd0iK zk_+X(#g!jIfThi$Ha@kGeG;eo?6r?$`jI1e%=S9@{>8~^A5#Qp0YdjRdx)@ zA9ux8Uex^R14XL*+Owx*M%;9n5kH5_pcZRtdVn<2lNO-#%{v3%UJK=eg;{?dnMW+rpqX+!LF@cwE}W_FWe zqh&YYI7kKQ*}smx;*W#&IAtUm8>PI{6vhC;k|IsZNEOHk;? zxwBM=202C^h)!9gLexz&tdqXYqEPyKghHuL<)kM}#8Qaru1>;s@_C$0GF@WY%D}bD$JkUG}wleo(+!;2D1n(oIU&h{Ef?n_HS;~-|ASr`q z!i+MgdZxe3u3qXWxa#cL%0P{QWt9v-Gp2(V?F=6~0vW%B3~`Vmx78r_j)o)OU9+{9 z7&;B~O*L7@ee90290fnhn}ets%@$h}S#H4sb{|ANl0O$wGg&XDC~m+72iX@P>Vbmj z86ROtnHdX246*M+!e7pigkg-Q!viq|J;HtrLH}7eV^a7; zkXd61lx2J7q|gM>q5}3ZBs{VdSi*=ZRFyQvM**k3ZBAI{t+{;G=w&%vZZ+pQL=6rq6nT*6xl1&!5)UF z2R$>36817hk-;pf;{6cOEXPb0H(=)fWA9Di>ny51;AifZo26UQB`s-so2DgAlQv0{ zG;LaFnkH>%(u5?XEk-X{ZradnWa**^l}$v{R2EZ2QB(wRK}B3%WD^k)6>&vTz!$ZE zD56MT^p)>_&YXFk=ic0#rUl=h-}n12q-V~VGiT16IkPdU5otrm#>~3J6Ji^k|hjxJp@@YtsP>}jOtP_@s%gG zUUz0(IrGcZACTG0lVv7VV=~hY0DDx*_Dxf3`F;amgmPS$3p9GPLKA zw&2X{gIGbOMLe0fQSoR37Gux_Gt>`|?cws!B-z5fTyIh)FC)6wnb|{_5e&-e5wXv< zbtAK6vThX0(w;O?H}1k0T%j&m?9ab(%_Jr{smg|K)1!2w)H5C3;2*QKZV1gys2fe7 zPRmhWgKoE0#BoG8>`0`pzbkUknftn@9Bx~3^TH_#nGtcaSac)MQGM^)YDki^`MLCeB;L>?zb&V%uQNc45Ez+!BA~?d#Qx-esM=J%eF>`#Hcf7wS54 zF~^DC|92ew?S8c$pSMKwqiFPgV$%co5hkiUl5pTLH`~A8Qg4kYAaG?%b6Qzm`huDI6 zF-~^me|gZdDxa!Szh!CohU<+>yLprPo6(JKw9&Rc3FWNH-)~Zv2T;70ttj6q%DAms zT}Lv`Mxjno#EaGHQ(BEvm+|?{>MN{9Rm-kZvc*fA)wjhKrzqizHR`9@5;%J7RI1~z zHR^X_hf|dBnOgM4a-2Ms%_P9oX$Th!G_*qlhMLl-!U8%35h zjx2YRBgf1_U-i8$>O-6ebv@-o@7=0y)(X~FNmjdc`*Yf%#)n7yT)U)oi?k{q-Ky@e z(C-Nw#Rzj6df8BR*VLuaYy zwFK1i6dly6{O4Kf?~ZxwurY;GRN9}5z*ek@2I#%Ti+tk%T+UDBOP+yh6E7(|B z6OBVobxXZ^VQD@MfV2&Po@Z!=o}0dGSqsKIm5H9+$rQK@bSe|8x`F1(7wgsgmMt^M zX^y1_k7a$7oJUYsavD3@J3DDmHsdA4_PN5 z{VNUX_S2V=Hu$i3XkSE^hl)|x&ZVjApn?4S!MgTdtd&W)BZ7S}*7`@ctB0Zzb7`m$ zoEU%;&vhk6m=m`R4h?kS%qu)HVdN5oHijIx*1xY&U7g1|;nI^hdWj-XkwuAmMm6Yl ztWkY>f&iCpB7pRxg3yEoDhlkdj5_gj`+AdlO^e3VeV^M}akc6atu6pmnfU0H<~bDX z92lmcwf>&7)zRf#SQdC9EmLThvwgb~VP7j)cPgEHs{fyosf&yrES+m(LA0dS8mubn_SJrW-Yz zrk2Z(;cfaEyiM<~X*Ts2COGrwEOg}Os3+rQZ1)$KA5Se~^dMx7 zpw9T1&iGhcf{d@+sje&F%8x0rd2~?&Q_L6VAG!+sgwFSgxcTn3D(~H?K3=$j`ZM|t zOL}MPA@WgvEPw|$;<3YR(T9|^{;^%^*M+QZXU|aQD7wO(LpXfEwC}7uB5xY)?#6~0 zJvP+CfrGz1KwOR3nHs_K4$nF|m7QZ#m%1JM1T7TWS>Z+Ads^Jx`j61nlR*0)vR^AYp5-OIJryq_O;(Wm2h-e8i zPR-;u`C4rdCRKaLt#%tFkMwuxCmU=1EpJixN2{)_O3QLEk9r`k?kBS9w7I8h)%DM` zsTZRaVp~qG&k1blJZMts|82JX%Uji_Rzul&pU zFNf8SqV>`yolLD0S#$uFcAuk^bQQ; z1TcVOVmT{4DVUR9baCZf9qREi9%y3Atn~ofu#aIz9X$ zCrD!x*3_{o?K*S+^kz!U`rwQ2O;oP=FJF2T|T5z$FL&CRgI~wpkPZ&oOH8xup zJ2CY&+qd8xCQZM{q3grZ>u}piYxP#^olXQ!^TCNg)`bqG1z%?FsIO|a-r>+%Yw*=* zZB<=8PQ}ZD+-f zS9)<1a)raVmZ;oP+fZhl_lR?0`LkC2ttie_)&X5Kd>uw7{nBa6%S-61RA@Re5k6r_ zl&G`zJ4s7*Bu;uF2k1KJR+ zlBxG3PCco26tArybMH-@dv*)c-s1+B8WfY)$(6g(F}CwQo6bv9A7pZ-e?Xq7;tpQQ^6FqUnU|K5)G(T(5hgMNxmF zW&Ivp<8;?E^nTqR%|#sxb9vLib&ugnjppJWM6;EE?RSPP#tPh3Xtv#8yE;koj4=dv z37YLN*uKPU>G4cTe(WU=_?hs;NFtLm&-cLdn()LiDf9dpJU0bNrF0e7q{M~q`IPtD z!WGw~%(WI=FBqEdXIU?y(D{>|X}yKu!ea%SUp>^~oD zA4%0}y&lujnT;E>{|ML~G;A@=U1!QI+W$51{n7Bvh@+ft*8Zo#cWs(vyC@EyZrgz% z_`aS-y={i8v*l+&-fTntVW0?1zhNer-|mqeCNgbc2beCMMv~UVWg^oC-VUbQnCXXT z+;K#)Z38!f?J;KiDohrKjcprv2yCx1+r9DG*tUTe!S>PVq}jWt$Cajg%cR-hdx-g- zS{Rp4+cs%E`2NIv_rkJqw9~dt>H^<&GbmrQfjDg8?w*5@E=&jU$=%i9y`Oo}5EAo} zrIW}9US!_*mKM2W@T6zKdvqr0Fff^1HhXX;n7_l!e~w=}BAKlp+yL%ZnER>t))#KB zgy24Ke*!BtcdMt|!@A={#v1JB!J}Y*oZ0V%mnSxeu9D!xV1HLSNl#EEB3;)^@KvyX zDP6aY!#?W*yt`m;=QY;!GUUJDG=nj!ut>rj95X)lQQy{QQrZ^Qn@r z1p265484yHq(6cbJ%7OrZhAD4-pX03$UOm|{RVi5a+Ba0APu@nZ~%~wxJgvcpncg* zquK=Rr*0b68ECJ%Y1~S1M%4m0k?jxS1~-wd3}V<##8VHM59CYTWSJd+{Ao8?CIlcq z>Lx>fBjsf`9c2)@H`7f=ISl;_H{BlCaWYoK9YN(WDXw-$P?=1`m)sFlF4Q{&{mf04 zAsXb@++->jbNd##$y_c?uW{44T$;YmP3LlHdUXBLv#@0FHFpACE}h~jcZ4n%NBI5j z2p)CVtNi&B=v>pm!l|R>^km#n8{* zhferBuMY=m85kYvjI^~5wf7HqV=r~>Xn*HO4-VXKLjl74$uHgjtn5T)yaM1n>T`U| z!#wF`?!7z8}s zt2uRZvHX#1rKX;d>cv&|etp+;hTpkuIuK1l3vmcD1D1uGsOfrYN&??-kZL4MSHzLx zCK4gl5DZ6}n}F$rL5X>~K`d*A2|BW8IwWGAwalUtrTb7cZ!k3#*Jo3Z0<-gQYjzeQ z=Wt*eZp%(Zl)guMUaF-7nMA`SdPra`F!9B(}hTz`|6EK=w39uA5ttjEjYI z(6T~?R+?s6iw%;RIxRH~qH|`jnoHI&$n^t|^_Nlrx0?{~K-%dXK(X>>a>Q~xd{VJc zgZUJszzR*nof{eO>cR}Df-@>Jp#Ca~DNWP-MH-m*j-r$*Ob#t|C%A?7exW*xF5xxqCq?3n`>)L1{k=8k+Epv%b=@4{6?6rv| zS=I)Jum!d{!$BQYH^O9RMn{mcMBeC-wYo&Ca)>S=DVDV8nvu?3V4I-(@Ie}XQIX$ z90H-+=OCV3sgVL$JDtlOs;ktp&ekYZb@M!yM1IjiK?<~Lnq}>n$KG^KCcJ59Cj0uX zQkLXNE&$_hgILzN5`@xk(LrKp(?QF6tKpE8p)bVdJP-IvPR0d1&>y;MfY#8GNJH+S&BMN%R0DT0x&fH zPIYj>V28as`$BIi?OI*dRq|FE3z<+@h|OFhJ?*`r!ovQ6Fpen2rvTW|GECnljAHvf z4&lcAnH;%?zGk8?Wc%6&2kCC5;X{2LI8+ObOWwd9Elt(Y$yWW4ZLNbd*mG4&r?{~(Sv{Rs(NsAWCPvni?1&GB9J(O%&|`2 zhO_&SvahHkdQ2Zcs{P%OzJadD1`Pe3krb=0A2LEPQeUKhWOyAaq`0KCyr>ZGAm4!H zaQUe=TxT~Mj&Kw?(lNS+V1l9-mlu^36c?>o4W22KpY9#nu!;+RU|?vU6GC!SOjpnT zo~}qpzr~;f9cWfFaO%aXioUN{qjsS>Lxlq;Src86LF^VfnffEIiZu+o0-M6NM5wS4 zCTtw(>5Ig*cBrr}>exsd2i1L@r<*PZIufa^xwWP(tX-_3r~{;!gZk;%*EYPTYUAU9 z+salJtt>|6?=NfH9NCYrYdH?_IKH{fksBjKr?sPTqwS7!>RRaFO}V^oLsS!pjD#Am(!7vR4a+y`dJOZ%k@ zhdlFBLB#8~gqqX_9NntwJv4Mp_ZU~sHo zk$!F*`lZqH5C4!J|EGT2;NU0RmWRX`-&3zK@xU=nOnrw7$KaCM>B2FAP2J|grvpd- zr+-L~@h6oAZvFwsc$4xE7d{L4Zw(FvI9M%TI+rKqDi@COq%_(59;*^K^3=as z9&0U3_8k|FMYZJjxbPz2TV42R!0kFi`bDUMhg|VXfM4yxR{(eCKM(k9SN!Ry(x+TF z^hx@Z3x_^QBQ6~JByDuz&?m{RbFEL{7p{2d6R_(G@z5u5p(`Hx1R7j8^a-T8a6AY5 zA9UfUEB_TPd=>B-7mmC2{8ShGLw>lo)b}kHo&(%%-+bWi{4oLYp<4A1>6gI;A9dmI zP46Wx91EG=Di@A(?mhqO!f~&-hx~(okcYceJ)sVo{}8_%uJk`H9Me$s4Hv!? zI0iQT1AiItVi#Tj95x_-^lXJcdJ)8*rw(@gn#Qfa!-o*BvIKw5qz6tv{p5>);6G%l zgFg_1e}wE%I!C%F+2j7xSb3%j&hPI<#wRzre!+(XN<&EvE7m|51Ur3jC75 zyM+(!g83g4h<=dqXNB)i0*`BmV=Gy%%EB`PeF2Azza3c|`EX1%F!LF`>UKxY)@ncA`gLO7Bee80<#6?3S6nv`%49i z-TbYB59#{%LqGBZ>K7S~3A{o0J}L4(FZ8bod_dr%0)Hla$8@>?>`C$huqVTiz?;PV1uXTp;Y3xt1dCmjCOKoI_Q7Qt_5xye$0$v+bu<)?g; z|0q!EEhP;LJ)oz|#p({A6~H2)2k=1z2|g?kc1*zowxF^9aH{s5geQwH_YWkM#Cz6u4RI>#5iJdzu6n zy*%xbu21A#C{XnBz^_>TZ2~dBU|jU{d|&XN3w%c43j+Tp5cZ^WUf7@Ebb-qSLQkec zABOt`9uoL&f!7KAguu@V6urD?Kb#)(c!roSQT=$I7WksTe`!eL64}ca5}2#)<15hi z^1<(@{(Wn;Jl_VvVNa6l6MOn1g7--L1%i(X{!YQK6ggK5{X>G^D)`qmw3@X(=fnklnVS(=xc%wj+m-$3r&+8iZE)6AbuM7t&R`;Rl}q+1vUwk`b+wp z;QymxQ0kw?ManN_jJFB=qQHkVoGo^kT`V~IbCNszMu8${ zPQJ$H3<&&@hI6H!<_iB@Dc3x)*SybYzD()gG7k$bdd{!b_mMC)6Rh^y8tM z1;@BW`Gv%uq5B2@i@;X}zOLconF7lMRtl8*SuFW3J}C5y1YRNVLjvy>_<%qu@8Vwx z{=XXLcm<-tlb$(Q0;NC8k^VJD{5MDZH%I&@NAk^izoffKpyZqLu;7mgd`811(qAl* ze3xVhJy+m*ftv)LCGaf*FA#V@;Kc&PPnO&wxb$mF?iBpn0-qH4TY=9Dd|5-huxESZ zir?oh5qyQf)dFh;id}NM1n(6nex57sIalnH`zeY4oWQRL6no{0opS#m^gjy}e_5KM z@uiCeo-R<@!_tj{?-ck}ff0fG1xmdwy;gA1YpM9pQmMzK;y+6t7rx(Vm@j(dOS{Ye zpwPdk;R>nW72>}uE)}}8_kw`N3$g`@eG4`SzD=OWFSt^0v17r5g8x*Y)MvrpG+yWt zDDA3nv*2w4rG5(ECHOT0KQ8bm0$DKJ^~`#i~gD+{GQ=u0wq814+a0LhQ4_MVRz#9 zbqW+ceRl}{bAkWT(2stB`2AZ2_6xjDAlebf!>$Bror+*`zCf`{@?MRTeHSC%w)6ei zGeh{dv6YA5FN6<%134@4mT{$hYw57H64&A3lQ_V=CWJizEBOU?cyP3%zr7Dv6RmV; z`0Tnb;wI3!AZ{F&01s#!FYZSm_)s5b(5c_dTPv~sAdGkS;k`K70>^OZ`*`;Z4X%`2 z+dDdjBKueF85$TJTv-yX>Z98@!@V7Yd$-k%?2F`WTSqGFZB^lhf4H z>B75wX0O=7>?0#(n|Ahf)a)<9MWC8Js@lb9*k%z$URi7j-bWW=k%ws)#dZ~Pw*A9< z!`j^trcc1h^{h>!J-uC3Be>eFV{{}koSWOawIN*BQni0|LvBlMQ%!Ewy84om++FMH zi;Htx5UQ)GsVUB_+nI}NfLqQf&%LOnbzAke%^F<;bZdQXBi%JzlUuW?sv@_!=In~x zrskTKirkv2O?CTAtoojg+}!5K1-Q^_BsUk<>h0;^jT=MlT|EaY!cYWTT)KM?@#hlc zx43o%I!A_v+k0_gDazj-Y47L>kM@*w+er8DXorK~j86x_<`4(L7M`eGA`YUn?>JOy z=j&XFQ-NzCm^`5=nhqdWJ8&*MY$_fsbz`UI<{916NYqrCT6C@Fnzlj7r_wkkB-j4P z$rC!{1T%=wothO)VyB%_?o(-~G0Jzwv|AE0m4+KvjI?8tF_nfKBZDf`afzw)fN=!S zfZ+Ndn^ZXkk6_<2o1!{N$W;1%QHRE^Q}roHdrA()X&nQeM4RH2r|e2P^&9gemyA<$ zA{KDU9%QF}WA5XKIceW9eGpu2DqYZ&#z3dbIjO0F;|Ne@DqTu!AA)34=|Xfescxj1 zN|)i(FcM6qi=YHCm5P*8=@K}lU5`j~5?ugICQh{rkhG`N1#sF^>H;{WQ}fj2O{MCk z%hRdfSQp@uAwF@E;|L3I9E4I&#Y5ahh~q6JW-9J7L5%G>B;h1{=Oms~Frf{H!^Ndx zx37jf!=>%3ON+|NI}jPh@kT9MX)-r8UVN0NyNx)LWxGEKOJVJ~7)~^s5NW0;r4yqt zzs|+?tP_%O|5=fMUObV`HNG|hJ&t^S%*-ub{coDXx7IZzoWifUlGAFRduG%k7{Jx;akg0S}9F1isrcf_i~ioq6s0=I6ki4KIDEACE{bnG-g9LcVSrQu`nBQDrD+P*l2njm^gkx9 zKAJD}Jm8ep{0v`=ywtm=CNJ$l2#O~UYy58griFlS#-I6_d}H~#z%UiQTfz59BMi{U ziz&x+D*vM==9`g;>bNfsUyS`SuvTTYo|tcT0oKp(Xa7V$+UsZQir{?Io99ZK%Z~H> zS2W*gPh#)*6u*2vxR7F`H@_e4I=&7fhu)ch7vImlnIrfOy3&!_)9*8)OU<7SJV z1|Gtn`I&M=Kyb+mQ9RZuSzZyKktgLa@gv=X!v6ETeS=NJvxz3y#|`g zeyekV8~q9qPN3gv>R*W0{7k+v_FIj7tuey{X!v6ETYU_14^HG$-v!O3U+HIo8~yNp zAd!BhcO&j;{F$H0H%7m*8^Lh3VFEOKG5VF~A@073eCh_!T>6z$IgEZ(_X+G*PIY@F z{>;zh8>8Qv!(f<#|E>86_{cWqC-PJu2rm694g;T!KWcAypOr|zifhr|KaF_vOQ2u% z2pF0S6QJRXv0pXn)<-n+Gknr-nD(|c1QA;d6QC)_dW2o&sM`zN*m(uQ3G7^V5PSSW zh&MlzZ;YLr#=-D0!vtvfV#;xL1>VVQp2)|;woAXuE(DLUGu}re((ke{M72(o7uyeA z`7C(i@x|!(9_YuXz!;IH95HtO;C&bueqxva4IkbWx$QiDEpTJ!b?wq$-r9^N6k^}8V#co2W&&x`P9^dr5I#`x6@1t>4+XnsZ> z-kI8ENARY{@DIr_KNEgC2qq1JH^Fwkc=Co2X);Cdlkh)(2m!n+w#PTJC;4wO{^WNX z{LgbX_; z(p-F75q6d1%cLLaPx7YY&*+DDl2Lq=r{SaaZ}?*L`*H|zM!$KJ@KwOg@(@q?o|c&J z&hrpwMIiQ-Rj~q{VwGjW0yPc1C8iZ4z#_5@*ajc z?-M?%=LGrQb0zF@p752r_+s+C_ZZ?#zIeZ#NZ!3KAubPpq~BT>-+Y9<_>S*$~mqW?c@v(G@8TTLcTKA2m>^i-+f@A!(6-PBsa6Aby8O-Ga*LQY5 zJ?3McnMb|jIy7TE0G>I_<6%j25!P|Qg=_lJnd6F6`s|Q8>KXToGzrzJF~8=kRpY5m zi;p^3TGQh3wE5Q9!o3@zb1Fhv2q6cSppcV?LxJ&h#AP#A%26-Erx72=p`^l^TFj{3xG`@50Wm8|EgWfIw?aDJO~|=C`NF944!mU zjcc#)*`eg4!SNX^ZMq$r0bK)3^V*@n(WLQdOiME%lyI7s2W?ZJyMxUEmZnRHxb!G& zE-?5I>#4?1L%AF*lS|1KN4o4NY~FcQ<4ZEj$4fU|@woN-cN7MHd{GGX9#UfqkCu;T zXKu7E$((1^X0Fa$JC>ap97ForyRG|fDjQ4MRWY_0?IN(NqV^2ysj<-Rmul~^9v@q@ z>yFwz)<4FwcD*!q+IX4ugWZS67L2Q#%B=gx%XV!Xn?Ig3|2}v?=6HbNyxNM*gTUv` ze+>W5ng0v?JA1q=vj{L_yzHY3GlK}FJ1rEglUwPL;QT|@eMbUgdAmYmDbU0Vn0z#a z?WvBYXe%BKqV+yJmQOrrqbX=*%Ms=}9|Nvye=LZ0eEP1?)7EcG#*)T;N2$dwv)l4a zv}N{zqk*v*khT;O0^^>e0asfF_6Az17xgEt6m2(ezBNYWSL5EJ3gJS8O^X4IOBfi> zM@$LDj4$UFT1+W84lPz%Q_}e9;3{CQWeBYx9%=2=Mm7Jm@ui4cMO z-TtYC>X7GX&bYRBsvSx(Z4dcKdmQt@&YS}NR|x+TY%ImJMf5<@D$&RK$FsN;Gr>29 zL#YU9S_)z{%@64_DHbyG*m|r9up;E3#zP{*Gd@pbc!ZXMSWROYPpdP_e18>5%c3N$ zfF$4e0+Hk$&k#vop`{>J)7;ve9wnoI+Z+2^-KCt~?qTXKX58*!>fXUP^@{9mbq5%q zdJp5Vdl(a%w1+_rN$-MoBR$I)X`{y-pXozTJJOqs1<*Tc|4Xt%@X_(btm#bj)0rHi z9$VAM+M4FJ(efx86~ji!768{oSX=7iMi7Te#`g$F1M( z8ZYt6g~K?2=Ri9)j`86n;j)#RTblYK2jrX+AZ<-U1LsFNM}~==CR+5PX{_ZjFQ`h2 zotIgT%6O;MRkXUZdo6bO>33RucqFCN=_#;_?XpoRD=-aT1OoEUHWQf(FCHRo=2Vq7 zJV{5rgw|6*KR=Xu@AIk!9#4S3E&Ts&F7FYwN&js&|Dns~R?+MDdEs)MohvML;q>%r zI7%f+C3%v(L0`}x3yz=c;D@LzpBdE?Dd_Q@ea-Kn6zQJ4`K>uK{|~AXHTAL`>l#Tq{&imMgx{2 zd+(Go`O(nu|NooI6ugWIb>^K(sxUzB*2VbI`z)n@(Y!r_Ex65ZCVH~-(M6w!8@fj7 zBl;HaIuMrk4ALz`#4w%KW?t^0qjHJVFn~+Edaz{~Q3|Zqf1TUYUd$N16xzPKr@cfl z1Xnx3QYTpE1k0V^8Xfc=x%Q&A9+BAABf{ExL{wXk2x{vQF>O5}q^(CpwDnYIS-X4m z^?kdobNd|~JJ0PmDq7YD&plsMz-mF;kmky48`2yI=zI~-`68h6ML_3^fX){Ioo{9v zu7V}|AYkMS8_KXv5y`u88XhxykBnd3Hf*F18|lMF`mm8cXk-l86(Wj@oK^(OYf1xgh{^MBmcYzm}Krfa-1;HzG9dGyu|?($ng8T)A6tJ4&mPg z7B~6F$|HO=N<5QF;ZN}n=)%tjc`nN9PYGlPGO_}5yzk7IO@zRlK!*3ijCmyiu*?q3 zClZw(x_d7Mfo>fDWy1VVJpf>yCy^q16-URpq5|xT`45>XK+aEv+@psNfyj zTSeijrs|e(-FA?X?KTlHvUjwv!yUFwH-g(fOjBrVLVKxeso`cL+@OVVJ86A=xT>Y4 zrn%K2Yu5Ujb870vg5*rKO)L&W2lX*H44r#P1iW9vKR-$Mj6l5fqi2N-Y;>dp?41+u zJu7iYvp&b0xisG#gwa1*^Jt(-4Ttq!|M1?BrP6rIY;}Fzrl`hIRJ_(w8DX*yYB)@d z4;MtJ*+L0dhg){k;;KuOp|{skbHm}LDpS9m36u znYOUJgUgXeO-pqZbq;w>Do|MiSANTpaz4(c6?&qiq`_!Gg7jJ8aDC(UE%X=SUWER! z)RJ%*og4&*H`i3xw}dRu(r}nev%SSq1ttii4TGm5+)#%@Yw1=DH3A%8^D$v{$(nMI zMnQtd5Gn7XqJwL?^$*JLM+~lrp%}Y#ZWiI}2J0c6Pt~qaaS8g-w@Ws_DHl-QA-RB3 zQe3*Gv|@F6DaaQ}79cxWtSu>7y?RYa(dzPwveGqc$|{Q1Ad8F1kSGgDC@ZtnVMPQg z3@GJgWvfAZ7t^RTpp}-aEnQo_retl|sHHC97%B~CWmigZMQLgI8r%cBX7!q)wPj_+ z<;7*l?A;2o!}T?A6}S1WbjUGQe2)_o-6(W zOMS$|f5eWDUn?KA6z)h) zQQ$I6ak_I#e%M1ru?6y&2lBg^?1(k=OPKBmH}p%H?qp%RCFOC22U$?XO8&O%@F34M z`EE|1kcX?=^Ci5H;euG6FC%EiUw*=(sY(;C>ujE|W)yQuJ*KDC)oq)4`e{M9r@ymz zv@3#_F6Qe+o)+0_ML}6Vo;ejEwum=vDV&N$Kc5Q7(@y8!_94sX@el9C=PH)Z=ci{J zym@dYAwCtfpN)h&$tIX&4n?PTa7R!RqAJ28xGec9RS_Z#4ngQqwU$x%0iidmb&R6= z3B65KhMMStdY$$zb%sVI@psgj8kf{hsErzzF3H4^ z_k?Rl`$4I@^A~g78NzdF-(u~8 z`Z<91*Db)`Y4jYh02A7Vmbw;tXvCxAR?KU2_4jl7@vuQZ?v#Pn(tt4luW2n+L5;Y+ zZhH*~J^l1`ouw*i+FaF&K3SrMN7_evI$a!Rgu~k#@xBiadNk?nigfl44@Nrk`tj~` zWOS$>-Aomx^er`;DIaqX2A%}+Mu#I^G~>r@6gz9Gw#7yth_vscXe>YM*j`m%w`F_H zW_~nSjVBTGvH5v;m>6vD+=rD0a%wVnD1SNPDAidgnodK^F*&#Q@&bjh!WeYP1}muL zVd=%tQ2gc{)vb^qS>e;`(N3&u{0$x5_Qobe^bZVL>K{ON*46<%(A{IHOTC1WB@cAN zj8_3|sW}JeaAd!wt^r!tvMFzQsB0kf4x)DMjdYFnM#3HKLqmAIlefGQ)SlsvyrP4( z9FE8F&d`CqI6oznSF{5q{wRcQKC#fQlM;Fx32iu`rd@p}qv=;56d#(RggAA?Qokm& zv6;|;Axr%M=%#H=t$F*~dq*QwcQ}iuec#{!>R4!&y4pvNZ091fv-j=xIJ23@gvtry zjD9tNfBA*JT!Rw-bv~_cdLNdtMc%i@CXC(%@TLtZZ_3-%%6}=Ayy}A{Y1N66GJ~D;m{)z&Bt3Ydq`Qd0PWnZk z`ix21)Y3GmzSxS=iL0erM$q3hktfP4*xgWn{cApT7cG;J%~+7O*T}$NV>cz_RF*c| zWP&R1^Q#ApMhz#>sG+^5KfXFw1k?|VIxNMdj-5)>vGLeKRemR+era@RYOZUjYT0%I z3-vU#5AUi0$sTYy$&a7gnSlSHSi{7#bkn|Ccbg-vx>;pY0%>9|L*Vm+$O z?bdC>oFK~#jXY^w2rL_ai=xKH>c)m9ELt|x@aWCLEucB(7SOA?{U4rcKQfgWsM$Nz zX`gvTn%VPGyhVxbRS;>v7q#x2N`K^%{GZh&>8hXtEyiCC{+3WZpzp?-d<`ZlMd7XC zEj8O~n(L}j6FDBA+DP-4BALUOHx3O|wBQyhqrnbSiir#@J2oMn2g6Nq;zKlHn3#&i zu3sN2F5j^{bRlUqA!ibdOtF4x-Xh4Di&+M}K;YR;(GJUdf$<>v7K^@OcqfV-{VqGf zSTsc+vJYB|?>#ObAbZPub?fdE_>Uv?Khbma{B|kIvkZTylkdzyXNx1%a0ei*bEE5} zd2ZZw?o5ipxoD_YdumEkwvoNKj0|;p8clGUadVlyF1!%6EbGFUGwUFhi`Q)5QI9ub z6$G$mzzh3t^tqNwuyQYVQRcbUx>f3GiqEwo;!UeJSeSo4pYz~};m&HJ7jyh1a+NBe z=M4Ihk1fX^eTPZkEEQ1Qz@l`f4A%@6;}g~lYQ!uQxEJb+PEcW`63=h#@X{`By@DF` zsDar#u9OVt<+Rh~emVSvfQO&0Rp->O5}O-$Y^txJ*E(yA_$Iu#nwoITi-t$&nWNIA zt!=8=RbA7Brv}^kqSUcdY&9t+Jb2Yb$G|&lp^bSgYjjEb=&J&F+)K9ui7m2VBvL;u7S~x z-bgItajd85bcsa$kJ^s=2r&@YYh6X%;Wf3@d=4bp}?+&?&&_nmdn#`wkf<}Lr4%^+U21$QMYiFu#={n7}rf8g9;sg z;m8{&i3B_i&E(0Oi?W-SBgZ*P>O3%3LKntGF1!qn0nO$Ann7DhAVZ4 z|1WG2Q=_)WqE#73m_m)($)NqGMEn1<>ZD_U>9;(z7*0w3!DO1pa6{oQh{A7jJJPL4 z*QAKw=lK&fK`#zqE;C+=(+sS@`75f~(eEcAAC0?V>YSQdXID!|c>9f+U z4`09!0Fj}gz3u&7c#*INFQ0y_ROQD!>I3R@(|zbkL${@nA~)T-G8{hWTH66pS(QKX zsB2dMha&RDS(NkJnvI?I#SRZ+PcRr>Bs%*Yfl*>hTW_yWACh5H@RwvKkcBXGZmlhmu81n@bPwJv(p+4R>_otWs7)aJ z<2KHNG70lM8BGJps~3O5wwr*oMRN&>m=5TwM(8G~Oavb`wkM8%7=-fit56BR$6bP(iI)# zYbvk`@Qc`3E@lN{o>YhAnjsoADBuc9_%F zbABIeUfWvgV_scBJGRGt7u|2(Mt@xR>=l`)1(x>S1MP=~WgUhd#lLN5oQInahWNd7 zv?}@e^n|Hnk>DXa0llAVX*J36Vp1))Q+&s3iq=?L+frkv$e)nJ$>m|mrM%S0&(DKR zX!k)VMxh^qwQ1YdO|5y@EMHuJe@f_|)hG%k)0B!VxtwE{hpt3SIy-T%$3fKNzDQ&cpgFI-fOm7Zhc<-rEMqW#Wfa${oML8$Q_t)hoY~ZJl0vcmiPgU+uB{wP zt%x#}Tc%@z2jZH*kx@7W84pb?nIj-!dRIOCXia_N&anQF;aqIqY1|&Jp>HA3Pd*VR zYFAw=Vt&1*4qGJ~x7Y8+dT@f&Pfy0fV)XY8H}W&m*o0>!{qD=&fANN1h0#Y8&eN20 z7ClXQ%=HMQhVanKIP;EW^+tKeBKtdxLN1YS+7s5BvZ=%8oA7wnM9R`;tkGdBz2qkB zKk_$Sum+D|cwKJ2t`2+Cn=ZgGtv7p2Q!U(4BYQVF^m(8E9cS9>e zgH}$u^#m*1-7|!76Ds$2M#2}YLHv64ji5jO0qw?h1Ex7qhLy@Bw7@UiDhC zKmWc!OlE4gJF|FZiOx)|J3(e-Ezfavd5S;(h9s^5r(`ji#j{u9VzAA;5%mE`{%cZ@ zY}Pz*z~zDN)7Rpq6>BdVi`v|2x5xkm=h(GEuqt ztndW6_?Rl)mx1%C{P{N}pM+dRwH;qqu14QJ^$E!Q>&eLEN=+b>YRh-8`W$3FpOT(k zRfKkbj69+W5ft)dSHV>&f&dQV%|-*Jw(c+UED2<98`SY>+1q+_XnOXxE*+Yw zvmNZ|a%|4!@Mowiru*}MlbWmZJZ|TSkWc4{P|*9O)O72(JI~wTe>zXZXX-o=%F=lv z6pEK8mDB%jbuIFIJWc1RGEJTo(s@!S=)ENkjnO zk>}^8q1l~7dl|KRa-%y4ohY#{`(O(;mhuuA;lb>|-Hzu<%ciZk?bLbVUD%*wOwJ@Q zpni``uAF`nj^=6<9X*o@|A~4D!hd&C!l`%F)sRp)Mj|UcsaU-R;SbC>3C&$iB(ZSn z@{-=KE}Mb&H}hnK)9`g7%`t8zy`bI?*}t4MGuwS`3wabB7%EWS7M z)p`*(-J3nwiW6PBdTG?uo%|+dY;DI|Z7V(aOLB$yhrW&WOB>`c4o|mo zIK-WjbF*HF<1pO%f?L#2q5XKqf136&dY8uNo$OaHLGQ_IGRhc>I(*tobWkXNC?aCSuz_HHZ2#*e~XnLLPSho zIlVxA8pOLs{SSY^oy5(;=RAT(s zXOFtJ%>#)lBk3e6gLX#_X?Ta(BTQGe?;il6x zL6@Pqwzkz20y4!Fn99#Bv-Mnr>z6(}b1Io-&m2-OLH5^kGPAcEF;@0=T%>C-Pquzv zhn<^dwrO(FPeyRS>VaXIMsS`ea5FpFthI3pIRsQw!Y{nyg8>;|qNbQ)IdS_+<9>6AZS zJ<-!bJV5i(3b3H|2UvL+8;la_;BJEKM&K^`w4k9x;egV;M7i5|PAYA^lhG|)TIWEr=q zkDlhw|5@HiWHqVT;%7ycn>}0IhOF*iell52X1%ysu>ogatnNfsU&@bN@nNSkl`*G; ztHyYoG(z|Cl3ww_QipD5&Jq)^FkzJ+i-VXUgt^JheqP;@<-a z!jazD-W5R(C9RHsbFt=x)%TIZ-`}JhhVeWd8Hk(F{p#n)=&6E9i^2;*PKzZ}e0%bu z&;rrieDw@+xW6zqhv*em-3b_DQ6J=LJ#c4yiyPYs%)MIOx6q&e;gyq079Tc}W7_^i z$>hLuf3F^aFik-Jn{REPqUKQ)F@vO1Wh-PzS5AJv4vSiW| zFDvdN=iQ+0%=YJhuV~V{IZ(l+d@2%j`7vR9^G-HWX5DxN$mZ7(M)GMKAWJP*;` za@Z6z2SmUEbdM)`^>aIop{L5F*jvcIA z3;%K4lqJ*JAqLH;E(H@`d1C8zXU3H?zfAoBnY}z&W>Ph#(sj*HF=$dT)y$}R=HIMt z2>J7$EzL|^vdL|h9qEq@?Kz|^I5YboR#0gXPbO|uJeq*T7<9o5^#f#kxI8pTws0@k zo0Q4Ri0*Y}_7G+SgR*)=?6Ym%$Sj$x8-=p8Cr#9iyYK~9s7n_6^KV=;iAiL=%Gh5w zLbiXL%7$*!qjV$onT~EqGF$70(ArLxvrGgGQrC=~;Q?qP&`x#nUm`&HovGmS#9FHMa;&j7bmK(#J0hj z?ZSTbxh4L}+t;fXy~{d#dj`Y&_H%$|F4T48VvZBN|L-{V+x==iK5vQUN73m0#zg*O z;J<2vdY5mhmQR~1ARqU$;SDG@^c{~D{{+~-u|d7pC*pZq0z28tUSrP4y*FzGu5A?bf6L%9geXM>H)2T zdSD7V96JRazO_+(!oLg~tXit@K{?8yt3!WO9%VMXZ)(GE)zGdxlB~A=$eso$NeX9~ zGFp{Ks<0UyAD^9FwRv-eDGnFvpfypd*l>s~h!^8zNB)-wEvxdWD)n2IhHtpuxU`!$ zslOTB=-vx$>yuEkmE zYE-rCIwf1Yv{`*yY;lSbzF4Dvsx5(|$4;d>{#v7cCw4eR37@G|udsxM9W9%us)SYf zOszVcM1Ih)qv|A*UB5+LorKMa)H-y5v$#=YN#n?JH#u_5Ec8|1+oC?iiBQ*5PW0Zb z>SnEAeU)UjTem-_9cp}dw9mCmTDM56^3kp84m*7!yG$nFeRb*{5s=uhlL`1ioqE)0 zP%lO3iCYAGjTBpi9@uT{EcGi#fRy2+Bs_GMdR|LFEl<%wt;&C%rT#9dTBe@r_HF8t zAbHfT)``7B?5JZ^zOYSQ9i(lp4Gr~G3A}=hl{L{g`tb@WuQ};Sk(-7Ycq5WnnB7DI!eTg;E`RiY4P`97Hl(fNz#Y6k_^BEVTu3du; z0MGe@b?v=aE0b_X1p8pD^^a~>4@D*B(oi8dF#so?>q?9;CvF=Y8tB5AS9oN?$R!AE z3^{JCe_x}zI*)bg>E9nmFHuBgYEhz|Q4M+>YgC_}Ai$-Y2q68aAT(itiUK<)1onT-=}MzD&00uv{qfB)dhem6Cb_OJcojv1H%-w*57lsI=Y+-%K}fNB@2YM zB+xo;3$%`lz{I+nnAL8JW6_8#eoeD_K`TKPk0}{tiBeIHas41s$!=^>SLNH)7*jeD z3j4Frc>eJwmag)KR`pyyH`wTXDNfVPU!a?A)NGnsE1XgZy}zdI5I>Q(9fEt{ zHW>F-8=1>xwK@B3sLg+_@jt zdujI&_H8i1nLlTtBR@wy88>6Qzrg%>Y8j&kA!`J6#>aHV$J!EPeC1AcT>)2qOo`2- ziyD|>zBvETRp2LdzE8x>cehn}?@smc!WGn?(RWzVJ6jKtkMd&yJh%~$9d3(0q^$Li z?NYxkWOX}xhB`;l7496u;RB|9XXO!j(`a`$j_A^3Lp>Zg_{#&t)rfa15j^kktfPaO zu=^MB1?LRoMkX0chB}$ZvxJV`fzEv`^a{;P|Jx3T6c%FfTl1`(^n#}K*PW}bS{bDp zUg65PlZ$1AxSD0<4S^}4Vp)0m;fNv52ON%wmLTKQOn#HE)dpcwwTIklw^8y)zrLU; z%UXZSTh#s0s%xv#vK-8#9*C>^iL5$p?x|XJ{WERq#b|}tmXqsq0$Vx{npFCKn=SwH zR`sb>QEni%M1z7U2TsY9D_=QPQ(}9^6FKQC|FZteVfCYEy|hUuQ|m+)9e^ddQ2$Pg zR=$3o8Y|;rA$HrJGcXigst1N$q)z5;cfaA9*tOwU2p$Z&i}aw-T`YL9#_f&6Z3mqN z#jLhNZp77Zw;jZVZ1`3d!^HoRyvw%t`T% zG_hrJhMMAXJ<+5xS;wQwM6*q^D#No*3@`_s9{!LMq_L19dCF!6A?y+$;!vF|ZFHJ| zJs!?&>$kU5@5b1e6sdf!Q{7k|UuAocDt<1p$`fX`(2A5hrj@e?Dpn3erwp#*Bvx5H z5UcV7l^>3%=gYY*PO!2W-by~4SYwQ6F;n^kT5&m^(B-fPJ}$=-lNebI#AqB`lyP6T znqz-7+Ong%x~2uU6*(k)O}C=~-}8iVL{Ve2b+HpuU$cD+&SBE@iyXQ>9K8-Vn6y@J zwchDO;4~kc2xML8P+IV1=8pQRX6qdet+fVUjn-Dx)#F4g>+Sfwgn#r+EFPz<)%YvL zH?iJ@_;i(HENg_nuffx4+_Ue@=QjAJcIByD{fJCx(jXu9kRIloyZ;Z~lgUR#l&i(o zsu}qHc`*v>#a*>?>Tu+ou)Y`m_>97EKIcsWKV-~Gc4jm z`=fwmm90d|bu%hwtexQvo|#rRSKFpMnyiUy9O4$?t8hpZrOACOb1af|MolMu)7`C1RCBbP2(QshgrBSP00~4q1eN zxOpLrRt$ekM?KVN#IkA~>aH2PXY52Nw`h_3k%c`end7DS&$u=CX(CDz&V$HA+?8JdY)jU$jt=0KI}Mlh01po`6&CgngmJ_G z4(-Mh=`g)p9L4K59HN8s?>TZ0?M9#-Zhh^8gLF3P@S(mAd=!V+uAX+Fql1GuDtUOr z+O?~T3;3V%@=~1eP}n&*x&cR{k30*NEY9H)J>;oDoJ>?`VMqhZJ}^+Ob0 zBj1NR<%idyUW!Y~OG^tem3RXNjJj$bnh=hXM>XUFA2i1L4zndGly!;*Vm0Z5b(Wg zZ~q9#SYrP|z%gA*HDy6&q+iO-Hiw7wi^8E_%8e!->G6L`zQJ*D0pYehN{lRzn|LZL z@TXlk?3(NJVDzZW_he~;C6ihF9ja5<$0_knD{9dej4x(yYNN8-|E7b0LP#HLEZ}Z&L3R( zJm9yx@Y8`0xNzhjIKzb_{{U>Ne~^d#{Xcf$$lq_*AL5a>f7BI^{Qbt?EW{&!KmPO& zIP&-Xz=dN#^NqRiRlplvIL^`bp-%M=>2XJa_xmn92lzEE9KPb+>B2Et@}dm-hxE(v zi1uUGxF_GVRJ)=qW02{UwpxYmX7Zov-= zewE<22oAlN{~H1y6gujU>Aw*Cw*p_%bTw1s3Ux<(3O-Nysf~i4D|naSlE0Gt)wM$Z zsPNq?_?HB~Ti_!?7d;g8;QWjp|I&OO^Z`Wo%*I0tLHH2qg6|hx%Hg?6aFm1dk#cxGD|FbC>FAd@-=7J5R_HHloLqtUyuTEPc;fd7 z-G?yac{<()UuL{s@N)z|PvH4N9})Z_!LJl}z0k$ZKG>P%iG6)yU*Eqpzdxws{W*dc z2wpC5qtMS1yjAeG3EV66A;Av|ew9G6pC9(4dhy>X5c)9={TMzZ>3<^WpeNJ+DDdwZ z24FX$)7VOO4PhGeu;hJoKGMcqvxk2qGWui66!~8sU#(!7YZ)e4sOY3~O){ z|2M&p3;ZV*M&!$N`O0?!nNZ`8#jtTsTz*_`bjaHc@CPsUMC4B_7lMSt%(f}=e$eMlhch4J?byiwq1G_-bWfAOGw z8vmP*ylp?c1nYo=UxBqsH~lWGITHR2tcw!-iMGG>-vVFNke1oFUW){769_vqeV;(c zXZ$*Wup{HJ8$;tC&j|hx4L#@+DBhDVutwmp!1oD6xtZ_l0!3fX>l*iBZbtE5*q7l( zf#UDpw+ntm;D-c?UwdH(PWOO@w*8Rb8DyVtT2?v1fVA%~V=b2Oui`PxO}_+FEy7`s zb#D4$EYcEw8Kz`H&vVD$jxL69_+2T%r$vvKG^A-A=|}S`hGz+c-!hK59zl<>--iYN zo`$qMNAX_tUkuS67=B;iZ#48R7KrhK;(dn%UL{cYeZn7jr>4_*Mf`!kYM6xfNqAC| zK&ii^&k6oN8V05QgRO#h3%p3+-2xvM_@su(=qE^iGWrLG>jg?ZCyxpKh(MDL?UVRZ zqXM*p;4Ih@O7A!0QD*Cs6dtXwZ1Z+XQ}5;6obD7CX!? z799OG$(? zj|se2!$s&Ih;Pv()H7E8X14+{MvfmaCpkifeI zJ|IxayZBdv|F4EQUV&)vWS5*QfzqGlNdKB6{+lEInUpA+~Mfnu**u~Y6J zg#KrN;x9{6G`@7Pz|#dvdsww9^wg3AlpW&4(& z$M80GS$_F746_}}?`QZ2>~emVzo_614tBX-ZD?k=hh5H}4OcRJ1H12M_i=WAt=tNh zQ^9txs9-$XyP|_(mS1r_!yjVzYwU76S@AQ5f1})u>)7S=Z|r55+m(%6?>4fXH{QYF zpHwb(vB`4lJ)hkRmFru|?kaYf&d2uieTVVCP_CcLho9?}|7L|Z`-3Q_4X`bZ_bMGm z1y(yM%#+b4jS3vOI~D7NJE(nFr>u~xZ_)AT-qF|yjz6rhaM;>461O90@39@mMFV3B z#^T}>1Rorc5%j5LL!*Kg8?mq$9mMWgZ1q)V{_mL>ui#i?y|_1ef5o1OvFY&&e>5;c zCw@nVd&dX2g{Jn#i~UhTc)d1G5}CYg*9TtjG!aI-s-pWRFKTL!cKM>}%B&<_wIvA* z2L`K&q0QGG=n6$^z16kRUGk)R8-qzaIzhss`^M`dePgZhiw{kd#@ z)H^Y>V{4-?xVNJ^RT->_#iM;A-ikpm><&nV#^Id@D<}4cgVp_M7)BW*w{+SaVVT7a!>#hr9HL9jU37^o}m3SLxK9PSEs*A)kG@#ucP(Kggu zT-=3Q!{U=u#l^7J@K7((6pP1thoS?M(>4I#_F5rW?UyUb6S4lGnL1pXIEAJ6f#HL4 zt9wd$*R`xz6|7?9d^RO3(S*gipb>jEB`t+rWv*n;n7b*ua|XUT)vZELv1e22layCC zFk6*?#AH(o(u(0qK{B$b6-hFvC9?7{o8}~qfRv_;l*y(oV_DQBpKO6(-jgZ~lGjT8 z97?g|Jn3?vxRYAKITiw&jFT$?Qou=PzsY^ld9ND)6qRi1zrMko$g`;Lb9(7n842mx z)aT?147P0QZ^F&%;K`=GS~&!UZ0aX5q+|+s=TIN%9e1+zk$F$5K1$w`s*jS>%0{Y7 z+2kX)KZ^U+)km9*ldF$XfR)>nglw|go`kenKgYIs4!v3QlcLe6-xp02Z?rGk@2%_` zs7J>cPgih9cPn)`=EQ>I9Ml^;O^?icwMW?kX14_2*`x&O_kLAs5IS+ixS1-2MYeEt z8SuVTyv)D)4EQwi<-nxaSNR%s6eFSbjQzw4*;{?hJE#eL)05j8mZ^6QY4k-$Pxsg~ zc6#>oL?&XRli2k+(lR~TH#LNd(tFZw62+I7{g4?O?x$NDFsD*HWdtzT+$#IXw131X z%xTg)RI#CKo>(fDJI=s|U1#F3e(Y3o8cqHRZ#~X6T_p->@y%F>fR#p}3*Iv^T9rcb z@+I|r{9Q~!vws{IZ%YxFzmQKA{*r9{u-|bf5F}dDVLc)poq_qH1iH;wJH}jx`Dodg zSCDiZ;JzQ=N|VY8YfGe?_Y`2_)sIeYlDzrQFB^Fa!Vr{B9_B0U`Yrf4;AS1EEi9St zh3x1SlAR-I7Hc2rOQE+F1^WgzFqn}kX@VW7;$M0SE zQ2Hru{V<)tJfB^^jU->|N98Mn{Wg;Pr}5K|jyFj^?`9BOr-|Tdx+ML)4Is6&Y(Yz9C;2wnQN5`9F=WTT$xI+`c)pSYe*!E-0FE^*5!+f<}zbgs=YyGf> zkV(HQNcV;K=|{(#q~8^!-;5@LtLc*TyW-Obdpr#t))DOb9eN93vLTg&BK)-dV(>$@ z&W}UaVej9+0jD1wFV;;=9pJs%i$5eoKiYp85Sj83&4~<(vS4l@{;LZw9yfN2D+OFujOG)%%n?7$4$!- zwh}*zcfl-l<;Wi5CAx(+x+MF(=Pd}+@h-N}t%2W`-uK)Hn9@n|s9x)IBv!)~6Gw64eY@z9>Ez3k#Y@^fd0mYkS zm!q43({_Q)Gsn!DsjqZa# zL^1hj8agqaK=+wLpot~ZZLF-X^LnhuS5;SCU*+@F_&pwlSAVhWQd3jo@%SsNnEaCY zR|MNyghQ(Z$-=xLv4nB$d(!=|2q8Y@XnL#YGt^MVFV>S zpVg51#*6kanh&Mp!wiK{k)?SU_5h}Ll71q9kuUlYO8`qlGUhN~YEQOk3S8y-d-!P_ zLvqX1H&_PN^yynDV;#e0oM=q)c&aPS++0#-Mp4+3Q7D_Q`TP^FidJ~!bQflN{(r9N zfr*iT{8pGQvo}8&o|%Xb$gf-{;yCgU-`J-4gjj|remdPtA4?~H1q-2BerRiJC;S!o z$~KD+dlOjjwe?AU7mIDwRHCd2w}P}2ZgM_tsh&@px0sGiuxwJmh^Ge-7iPA00LfgiW5KA29KgJd&m5 zb;D1634R>Jr|ERRlW2qZLAGvo98-Wj_~}Q-i#F1(pW{Zr5lv(ZtAgLI-!p(c_>q1T zzt*oDejO>iv|rmeh9Buh{6t6gEXEJbpnjYW!S}3&;A;J-532p}x;_IioQ7@z3~iH_ zOFWb|{b(8F+Ucm@M`JquNV<)*iO1?*c}~>7s>1mSb&@`t{?&&!C-ko(#zkM=vUU8+ z$F`1t{)KDuhJv5IzHsL7!j|QO7Y@2x7Pp9ZJF4C9cD?kkc~yy@zuK#}B&(OAhA^4j#^}b|1~T#hEDi zuyIt}k|%NV;LDZ1`H-z}6pO+cN1eCiQ0UQl@~=UEZQ3|)kvbopFGG`by=7sIyKu_| z?!ya9jK@Cp>C?XQ!slOTS&Y;NK7Bp36ocbF_mKsMjTX_eyzuhuQ@X);G>p{dBDM3C z9N1~Wpm8_{e*<3k5!c}bN9QYfhn+`rZ;@IbcIdPmo_Cb>KI{fgS=|YoOeyG?m(%P{ zN;AtlDs6gH=9FcT!jT&H1?~;TW1p1iJ>KHF76;I{x3sKiIqi^Vz47S077xi=BU;K@ ze9Hfo;}Vki7Jo~<#-bK1QRO)M9<+7C939xv_fOS@re?u#=oLy|yvp1HI z`FXAE{U0`azv>YIDfwzg6(pm?J~DBn9hsOT5)T`QoWBN^z2Pl6Z*^Vme4FE4qG{Q% z;8NcX#D4O*fh(q)bUTK zMz5mYqXXU4B+o9Y@m68qxi}SLXPF+yVNOrZ|Mm3H_kV^FdXc(7Ps+5ZjD8)h*I|q& zg5-G#9{&J5uk^w<-*My;H+k|MN7|&Pz;UG2-4Dz<`L|O3-7NnG<=;;Eceni8C;yJf zzXv4ym5w73>ABW%WS8{Z;5>5o71DQ`^T?;Ka2p|-&=Pk+1r$SB%!;6x_zHe!ljj@w zErf>R+oaeJ4axg6$B|~~dB$;Mi;V9N^6x8zbhr%y982Zj)e^Oq<9BSN1QAia^T@qY z5l55r$QPBboz-=0cN_^zs@I!TaYukSs;UB~=4(3I<9#SB8l@^cK=H)Is zoph3VKtYmw7Ew9J&!pgG&b(#0=L5M7$OXA8@Ha1arH-9kiWzcqSK~(-P>gmBNF!*F zv%oo+J1Hff4a_p#Hq7Rf|SxBNYYsyqo+ro4h`S?T$1z0qc__65vC+2w7iW<*jd%LBZy&CK>rHsw!`- zNg)r;jqDCnMAM^mvlY(T!^aCIK{(RY9BOHaGK~(J#BuRs1Gx8Z%2Oq288JLIx+f7c zJ~hDz+lgOFdrYM?HEG2>)n2??{eCGef+K)~k!VwRd$g$&XQ1th;?zFH#6c|x>h5fb z&;foY2uM22%!9+s5D7)jLgBTJGb3RpBH=)@gb?#cvjl8P5|KU#V-3-UTRt;$I6;A~ zrq*apcT^MG(ImoaH;g2Xv~F*2^i-zc12t7?r~|}P=}$CPxT~`z)D}#Rv?Umb;3(v1 zYoM)VXJ=P)B9jhP@h2Le8JnS4+JNA$NU%d5E!P#?8tRS&yO6=#J0h%bAl%d)4RrvG zXt%M5sln-yUc28k9WIG8{heXdmr!?5RvV@U4j1bL+S;Ol?(Se$#6m05w&0Fn8(WYH zQ%hKi!&%SN`=yy0YL4*G+>m2U>N{A4;xEmeEX!i9pXg4J70hN|r(1MycB2hF!6oG0~=I_x6?+oV*wH3=bP(MKl@?z_$L9 znev0Bo*B=YHJ*cpID^p&YoqZTEX58vQ&`DNDdGrrHwCC!z}-Yr7`T9y8rb411?QPK zFOcz>SV@EFO#B7WXj^B;R{D8l`$2yUu?CkSMVcWv+8k_Z>-HFqwb3YJZI>MCohfPN!K0kjoGz29G1S?l*!*3?y3 z)z((md212H6=X=Hg(Os08{&{41SJNTn(FFG;I5Q7N)2#T{`#u=np%H-^|T@0EJG+Y zGAc7ue05b-HMLb}_bY3?_0`qB8ecUcdz*mlXj>3P#csZ9EOe3;-)@DZH|Dh#L6$as zr^TU?Elv9_3(IL|3tw*qumS9bK5T`WMo_kIDoJne8>Gcd8)&oNXhSC&|0Y{Vx-7Wa z7H;ZrqKvpz>fK`IgT4GApKddQIX{xZ|J4jnpDXV(!?Vnk_nQn{6m5n1PBV-RW6yvO zn1N|>=ikgg(=fAV&WDsO*)GY2{liu$Ym!hGK4Jx@%cqZ8!KOAR%BIg!0?;3ljRm~Q z+J^X&iHDAi$1R59n2bX*Ab_MRO$_k>aiEfNvtu^3wx&t9JHx{$0pBv|A;{J=rzzBu z{t+3oj3ALAT}v=6S$-gNPmh{HTk3vj1tcc#NzonJ8Vy7`+e1z1TGpQ=goD>!QhtuW zi_z}@+GZHXuf)!#)_}CI;dn*^WX$I^0PWBf`ke+LfZN4Cik(n9ohC1GNRkdOlU3`Y zP4v>j&k%nl1PYUd`5R%7YZm73gh7#!7^^ua_CpRziYZXO^MJlmqAjr+|7MA|glqg& z5^qIe7E6lbY6qgAjOF;vq9b4OGAG|A`7_eU>~?$>6V5UrhU0Va>i4fXog9`U_2!fr zfTWXy(J^gm>S-JrrKz}~(Z1p7{&)|L7oSpJVaaY$F5g{&^)R{m%xLi3jy1|YMs}tf9ZgW(`)OjXCvsoC$Z^4$JFoNo$bSK)iqRvAQ z3Iu^iMZE-34hXzcY?2_dpTLiZ22Xg}kPT^SbfJpEF7qDIZbzEhb=a|{j-7U_scBfnHDD@wr`T?xSmd2z zhlMlM+-c!VEq8Gwmb@p#>ufj{h}&;$NK?hv+mNP)|01Koc$RZ2u81_^2{9lEaFI9X z-KFQqywiwh#olvtA*68t?VqE4E~{xAunHa8_U=$O4Hq$JY(>AeSbZ6$28Qiwpi>Q8 zcRStz*!*G$EC+=;+Cm*cAcjWeb^*~q-R3|9Z88VZ&GAEhHj4A3(T+}h7>6Mqb$a{b zeZ!OE@xGE#tPV|0PmH3O37|{g9c-p}^f>|;36xAv#`~$qj}yXo1_RrYgAc@Gdnp(b z58FEeZK16l!Dcx$sKiJFZERTy1{344zP*@Zph8XN_LP+(jJPgD(i9I7C&e5amQxc< z3S-d0=Tbo>4|6IShvau{Z;C(yM}>_UxZ4wxKxpVXI>QJU9UC{q%K&$_ga95G7&63F zP6El22L|GXxE5e{a0kH2_ZAnlr{i6 zG}&9?ooSK&bQG6+4h*98@|1YDBgOB7(B=~h?Vpp-kC4#z6KdK&G8auh525&y5-G$+ zL__?Pz|JlL$0iK%D}asL!jY2wvEk`B3Fc_$!wz^@?TM1xuQp#vTgwZsAp-WX8mG&QtbEIVGz=4SyG66xDxEd<@A_9~3 zGcNH_%^L0w&#G@2TiS3HNcR-ln=q9`oS>rxZT^c(+(XkOWHTv9*=uTSymNpUC6}Sh zHk+V^V>#kJtx@|4G-{6xjiy)U>Rj<%t&WspQ^(|Dbxb%pQ4J5~iYK)$;jU17pnKa1 zEHu;}o7`(z<;pzqORa_}K&di5p=h;95;+?l%o8s<>(MAQhA>Yq&8+xji(tE`P~|`m zE@_z_o>GK8lhQ5FuSVHvJPS}EerG4V8=E@Y!gYsM2MbjJ_kF@?1g+0JP6)P6&{I+g)DI*LnS)k~UX%oFom(5d zo{|j-%UXXjgQW31-kCaSFE7RZl5=Phx9Z`t`0UfEITBK-kt&U^KgQcaObx07dxmHDhSiLiT6WnC7_0NF~ zc6qzYOaP8Dj1B)IQlUezA6Ebb}OXe3dG5Oge{VC z)GV>6Rk|Q#k)tLXwErM${}0Q~KC={_gF;E|!EBl*QA6QRvBIag9;sTSa*{<4*s7Cm zwGs%daOm|V=rtOXFM!!AwQd(Bc~YTL0wC?{Bn@XKQ5D0ypl$_bZD=(|vP>-oV!s8k z(~yh9a^wB~hyqJzyVApz*8*qHc8gB7TqcMld@zUBCh);q_J(1G1iM&5AoJlIYD3W- zX>0bC3}AYWyEwMDvS)x+pN8!(Y8pO$$Ho~h87Plr&0Ow@kbp-m0sc8eU9P&9>OBoP zj^E^3NiZD0wLxLS@w^544aZ&ctzN3?^S8VF3nROA zEM|WVdiyTf6~TIyOWDa>z)BtmNIE$XxCYCpOT&s>B934oHGgToaqB)g0Ekaa48}(L zv5>F_i%;JdqTvpQxL%yAn-A4#7{GRITKS)(=|fW^kZbC+!vEwHAGE0HMW&lS%_bvJi8+{*n4V~KfY#)UhJUAt zM>A5J7%fFc4k>UmOL@*E?zW_$H8gcko6`5^h%Y9PCqx#b$zVB)Ms|m)Gpy@VIoNq% z>Z+RA*&-s=xJu^Dx#FA2tS5++IWhP69nGm5B+Z#NaWCbH$C4N{ecFt?Jx~0>u{t`r z4=c4Oen*t86N}#w6u*b^#7mA9mU#6_A+)+itj*$_nVNe$bIGkusL{*)#Fcn4M%sV}bH?1aET)I<>ceiN22WfJCi zDiH^iQ%(Lv&0+%7Rz<}qB08Y58ot{(GvR$m+ny+1)&Rxh+NewnuYAa&75Ht$&r5S0 zH#wxPa->L$tG8qIPc67w^OzrXU?THl4oZ`xqiMyKKzpcdx5se&doqLJyw~A$Iltm? zxx_<`=3rYS5WT3yoE ztngL&s_XqV*yUGOUt5pz@_h$wep1Rr0+{cJ(ykd#HBJo`kK4i!ZM3^J)Dpoc5f?Rk zd=&i;>;%4QO+ZHgD1sk4c)5vY)RRTjL&A?794QuCX}*n8=be$K{9_j2$H}2GnRN*H zPoy)v9b0b|A9xyTyp1&&n*WbOF7Z}T24K;!JJjBcMPS-nPMglecA?Go3jjlQ6*&8$J*_ILY%cG!*})8F2}YpP!KH(ut~+mC*=Og@WM$lY!RP zx+9vcB#Eok6#5U4hPSmgMoO?v z-dB!4e)?01q@XiRTx7{o8CvSWL^(RBNRP&=lGlQVX3vutuzv;&N?HOB(W|~LO!Ao0 zAkuiU8d%cOX>k7e=`^6&iLaD;mj6W>U=P5)+LHa=^8LQ@{r>X(DHb41hV+xHKEYIWnU)FeOKSp4#)d3pJdm0) zOF%|`TRuEi+t#@=sy<=37@K!GJEB4Q3Igrq6KR5Wg(3*~X>ABwB|AIXc4Iy`1NYOj z(MU0B{q#0DMmn4_MpA2E=KhOUwG>95PgtWV>&$fO@~E{TtgK)Oj%jEyPOq_4Zs9c+ z-ru1WvWYxpBdk-hsl(+;8J>knS=x*>J!$0oZ^!n_F|Yg~onO=Iza0cb^_+bGI6o{-883{Bv@36)3t;?aGz z2;VHe?9M5>&pDgO`w~S0lp>!=Bhpt5nb(W^A@gR}EHWJ{5@Zr6Wgbr>v(g8d|1G`? zna|BC^U_3_07<4;nJN=!M&Q)#TJdAZ{C>_7GAHb}2iHBxtV=Lxn$#DLk4;W>4-O4* zRy)=#G-M>bLzrdmkM_kT`=k8>K56SH$^asJhxp69oU&uNNs)=&_Q=wiB{4Fw=>(CH zwH(LATj%GLy*E$hfR(bO$kN#>b26mOoN;kIB>yqbO*ZQqJ76n9kS43&rg0?6km44|lz&*l8; ze0XpSd?6|@)%Bce$C}*2ZR09@Vd1tR2+E&|6X7dWobVN>IN|f8i<8os^EPoK;{4u16{lFK z<0PMolYDOHT?WnqUFV-$AuT9$DXs`WbT z+|<2I9g7+np#V0GO>#Fv#)$-X$%3}DK21WGL}Wty`=*lHr6u1LZ_CdqdjLJ;Y?LvM z%i3!8fvA`yDWgggEAxO&nWYaatDkmFQT_sV8ii!e^^x)~7cZZQUhldrfi_6qQwO`E%l~f}FA&*C)^XBt*&`K{HaTKv>fI za6>s_@JFojEt7S6RD1_9{P`5cFp2SWd@OB5Ul%_@ME_YnYf|JykX2&|&eH6>daOf6T6WSOyNY!Qz`^3xlW%WFDo?A4;BISR-3+hLwE8A=zG z9RHs2UU7F}PT9A;vqr_{F{9$TVMayptWlA@R_2JWA*y?Pvqz=uWkp2>v!zP*LsYYz zHdWGqE62sdi0T%xcO35^Lh?izUlY)*fkJyIok;%+Cvs(NLk^Nz|$T(|srmLKxWKgFf+sG(;&b(8+ z*OOEBi>j5GQ#QNJ3ge^ki9H9E1(y`gUY@wnqg$)gTfl0jFUCccYk57l^Pi5A7n zwvsY?8qvHiDV#u$V4P=P8)?)kWfq(Cx!@X$m3=>{L87+8>|MJz?|= zY+Vk!EoJq>DGJT;;n+b-@h+Q{51=n^+Tn};{eQJeHR`f9YH{3>`_+yQNV+%Q*d(ySsDW|3c+ zZG$=6vqr@y*5ovNY_s^Sb6wx?(0Ej?evZkW3pE|Z=;I{r|2vNTc0bvS&s!4dku+N0 zNTq)U^w*vzu5_(c@@Z2A%fl{b-ct+|V z?o&F5`?ApCnUm1r8(YK&a@JvkRd)a%lp`G~JJd(z31-83Qx9HO?J?Dm6!eV7_q0Pv zQn)~;(P%glz-DxOe0EWwxfz#ZsN~4MGe)XZ86bKlqy@1sPIi=k|D2UG8h+U*-kOW#b+;mYCn@72P2wh!aS;-Ak|KWFBtEFrIC&YL zY!;uFY6QA>os=zJXcpgOTb!hX&jiH}lqGQV*vVwaAA{n5*bXNt;iE0$Pf|kr_U`6v zl`tB9-Xad=Q8{Se9+(5$&0EEFdDxstwL>MiKvs$Zt{esSDo4e$0BzN`w~F^jCggS2 zOz&tFcPa(j0vy$DRsXDdsNl)z5!)_lRU?gtM_R?FP5w-FnN7euL*lC}AhTg-6Y$-T zctmT^#z`1Tn*@A~l$?Yi*zNFz;wP2>PQ#oeJaD0SPDwy6XIVgvhQD4Y{>)t6*>int zn|QOEO4P1MYO9d^)-f7>y-i%_rfsh6?QMY!r9v93Ak{cjsP1YLzg}BLFF@LcKwUQK zp%>?`Ti1+;N-HH@2zvytmdr^LFSHo}H#5>om)9lp8QZJ8nBg8J>pf+}Tcf|Vo z=%uXRmk^Wlvxd9d#l1E$<|}^P-BJv_1npv;Nfz@AiMe$1pW4O8&Rt8|;KSmHy=r_W zlM#w3rx%Xn((zDi7;|Op?~P+0jIsHV4)H(&vrG*oLNddV%qwin@Jr?%+~?MhGp{gY z!kdc$+8A=&*!<2;ab1bjX=rqR8ogK%u~La*^|Wfx>zPjRp%ei&-B9lHOZ-|XK^9L+8AXXyQH*KJL8g@5)-A3r zGqW)%btDw_mqOE(k5ibshWAFqvt_cvChkkIs&3gTRdo}3(^PZiFuX^N!F$yHnx2Dl zMBZ}{#Y3#@v2V5EzFa|%wcm#7{3jaTvt8V|Ue@_U4XoOa5~%j*P{Q?lM(^;kS7fvY zPzrU1)F4Nd(t!!=+mHyW|6G8Ee1~`{ZNz4Kf&OuJ5u*hmYq(X!&!~u>>B$iBH9N&k zL( zPp|l1wS3Ver^$NN_-a%~lhR}yPe>E>HubEG>~-P=Gh?;z2Q4qX3n@@`+4M^Yy95Y1 z5mF66PoMUf@52>6qvn?C-FP?V#T%aO6Svi*SJ`|?`JTzR%wl9Q zmZY)!>}AIW#OdZoqutw^nu6W9lE^~gYr5_2_?{<Z?f>} zaP$!FE{Qa?8kbuEIL!wq0vT_#Fx~hvb9-B$%Xou@iv;o2XiFf}h7+-j%kX)LeCV54 z45y4r{HpM)#&@yKv+(&U{Pc{=Z*2CQ=o_Guy#$Q94g6^jX(G>3z#YB`=eGV|zRizT zAC`QK{w`izf0t97or^V&J#oH+5Cd5u&?I~pB^M;`@y`sMb3!?HLbfPa}I~koO3q-f}>*%ru&~Mva^D#h7l&*UP?fulD$~NA1!=td$C5 z)IaYM)43y9Hv8vJ%LJ!D&11uW3{P`9sLY|<<6|>=9OL-&WKs^nigzU?R1yOZw^p2E zY&;FD=KyfxR=m?gxW>m-Y%ExC{sJd1E6Z6bobI*mWjU+eOL1%Xl3aYimWaaT^%jD{ zL8w`9Nwfttfl*1AZ$}c#0*%lV3+)KQSfoKBUaSGbI8A#k*-I=G5ieb5P>S+hNSf2V z0QXieBQJTDm*76@0tB8eJ&SOI(EHYV)m&36o#GrgWc{_|!HJXP zI3Vp@=|QqemdJq8Wr!HbLJpRZmptng4(A{)LpnArlb3c^EQ9(RDWqzlqW3C*ID8t9 zwse^w{VJCkM2E6P9yF^J;M{at!)f)WIo%g546RVMsYygDWUYnV%5-%WO0jzoYkeY; zP@62&))jw7^B;*Q!#K}EY=y1Pw?IqPEil;yi23qfGV=?JHy)JY!02(OSORAs4QT%aH`SBq|r(W;OkIW!jgmmBk7LpU8RI$yWbAzkxM1OC022x*SV4MCYQQk2s$~tHZjct; zf1a@t3LjW1sI4`Ona%8hq2+V3p8}(Yg87ua@}A%7e*fzYjo7dO6KqpMv0=}K4WnaG z923R~r*>@U8=pQ8$K6lGXExws!VMb+0C$fKOwkpG8#eR~;SYun3AqyM_0?@a-|$sf50_FXNyi7)cX3F|J8^%s1OZwyEn9rGW zZc;%@wv#L!(lVxDJR3S;(ax!%k$76;dp3j;zV0_+VC}aq*zx?`J)wGVEoVY_4`pG0bx(7AKQ=+iFoffj9epKzsu0C%MvIF_w(khZ z`y=^`@$+z-r)NX6lA}E4;XQT`BdIQ2kl553Y}#hWoA-E18H&|*izlkw$N;Xhz^BXc zIcHSg#DGVccy8kw-Hs)?3zynpyd@K0^lB4ejH(u*X*8cY^c%mUA(!#W?*V_EVHb!Y zZ^7qnF!z!PBbFmvj}Zyc1K1{8hND?G9}3SiA-vlG(^bCuAsFui^YH*imutb58pHZg zH%vVash=H&ehbhERS)>_fBvl+MjxMGQyvnB_y7DM9Zrb_e31>t%V&PQ4TkLb=h)!I zfK8pjkN49&+<~kfz<3|cd&~wSujYMG!vLWByte@cso~0(>6y2~1|vQ5%o`AvItJ-`&J7AJDG`oNt5AMixA7gVz9luMJ)g_+M=B8Gwsy@VOYe{N4s5 z{@gFvV8ow$l?_JxxotKW@#g}k9_WYob4+^yM*KNnvxOu6oWnL4@#o+^67_(7BVgp2 z30K0558GgzZ|=I<2IKAsSE~(1+FZy(^*~-3ip=+HFgiTWn{Dtqz}szb1z>ypm`8Cu zXbZ<(PL4x18248=F0jEUOAh3*dJumpio!Q+FuIxIEjAcu=L@qug1#DIFWbV);r|VO zRG$8d^5lg3Q~dsh-wOG`z$i$4s1APF|@!QpRD3ZK$&k&;Kc z@I&p3f%4pfdPjEvNEc;Dx@e1ngl{yAR&p<7ct693nC@Ei_9^^EcHhVDhuQrs)1jV8 zxnE`X0haeD%ljeYpJMnIDqNt<5T7Vw7&aw+1j;t)CoW|e>6CPDQt^sw*nKynDD!!l`^TAzlZ{X^33tC*5M03b2t2lai&s1uwa1&!zhq z+77@XPr(A^RN~v&wejUKpLD^ufcXd}K8XjPbdgUBiGDN70lbJ|8IJs1PB82xOGt#_ zT@24K{6>bM$Js>x044{>g&ocy*M^sJfS2xf4PzyR{{V9UT-9XBc&ZkW=I(JmTnolNT-Br*o8eL+{iB483}i=yOZ5Z z*u9k91MI#*=`XHe_bR0)l`ARdI);xhd=ta(W%zb>?_&2;?0%75)B`C8v#FR{z|I$lw*^DK7J9ub{$3%gNvFJl+wLx#VHU9>wAh8?7PpK?w6A-)F4Grod3 zD{^69Ssy=#Do*ehP?hcYH)9@%VA!M9jz5HXB!b_9xh}@9wTFMqFzN_Kx%86zH0$w# zas^PNpIE}~h3x(-yT4biL)-6GhEa}Xy4>v6u{+J~ci8=za$V=Ji+45gxel_6awcJ> zcQJkLSM@WbqCz84idpVK!V?GW+Le>1x`vdiUS{&Nam!1iCTiQzVO``Nvd zU9=}8kH!(wJ%ini?2fRD_DhC8s@z3vheZVpce0EA1JNx)yCmJeD|hjE?6Q3q4>64L zMRbe*qTJIKvAd4l0J|u+M0Xn7=d_1z@vd3M_+oZ9 zv)jn-h3vkL-F@sHVD}1kxty%Ii(zip*4)kTH`#rP-Tz|uId=b`Tr3z#dlYlIFJ8m& zdUh+>ZDE(~Qryq*FuPpNi@81*vwey`$l;%0_w($sy^7gR#lK?w@7U$?vUa|L*Pg@f zx$JU%Si6Pco$S7z-8j4Z+2wp&dn3cF*IF(=YdIg+a`{>NJ*N8~<(9D?WnAyd-p%-L zD|bET?|Lr3>#t%w*Z1;V1(z4H%l0ilkKt|Xvi$OE7-l<`-_P(5*ya2ze^J339PDzv z+R)5!54)T{8?I#d26o@i?&IwKTDcW0r-JQXQNeh&cSQ%oEWhGEr=;qB~3*+qLU@vw(#O_7x?q)Z}F6&Qr#5kw|Q_>aYN#v781&+9#iuJ-B z)IO{sRmjDW==gN+Xlw+>4OUn4fbQM6bIM^7dEA9$jR977C3U=2O2XW2ke!tN+)LUHKg*&?9lT*dTu-5QUuUx;A z2gK2SQCtogkM#~k2PUU`EdZa@S^ySh*$$I^vEg3at&&n!jikLjNxOei>W8kC#i}S4 zBS*3+i)>|+J4KI*J`$BprAf@cVqMCKJ)2^l!rqV7!HPl2p0Q}9n1M^r$yq@&TQ!bi z&!);HDX%VDwrU`W$)*aX6~i@>WMoq%lVqH_3?)fc;mW2}WL4;0aI(dLc~7b=NM1|h zIaCM9dD5joaVIsxb1VWj87G(jQoyUvd{c~N$82(5SN<&Pepas$tF9|uAUm5ZwXzWm z+0^Ca$_ut^>TbdX>)^?zuBOQ!aAwokT9pwD+2jbY@~oCa+14Y%<$!2`l4?dk#52hYmD4XVGZXS07E$IocPk zj>UX^{#YF-qFuoq-L2HEnF9k(Yfv>gO&8Ft;!#er*)PFoG%11lbzPMjgkEDYE}lwZ zkISwlJRlY_&(@3a2W5={Yc8_249&tiv_+&N=W$MgBRuBDn z`%zD1A~rgS4S*vp)1!S;L%0RKC(Uj_d{o&FiLv2+x{#rG%D}+g*eW~VhJd#)r%CTp zG;$Zt6HCQ%#~Juw>r6qj1k0R8lfS}Sk2SniqL3D~jfDtUX%u4IZJdcwu@sV*FRAC_ z?_v^~{o}yApA>;{wtTAamt^aQ{f;|;Akmr*^APFi49w>x&~3&XKpAlQp(N0Qc^^q9 z0niKpT+RSFIvH&?KfKP%@P~Nyqv?|5IWfPIjXc+L5R^_H=95hw;LT~lpJx2@qvK7c zyA}l5(0vzlH)>&UwY;QsW+&WWRY2K+-N#niX#n-F(b5ihEP( z95(@{b%1vP=7&TYd5)_S=@vmh=WVI-49v&cVtgiYR358x&Ek-Q50v^-9SDGz+^TM(`vZ40)araKe! z(?&!S!PRt}znX3pbayUHr4xSz&Zgg4WD~6))u#;lomGdllWp{)<4w}fgLD|Jnh36@ zOVZCX1N|OJr4yJZwCh*g3|Q-jIloN$6_ZVh@zalvH%Y%@#A_VZL~u1-l74Hc4BVee zC#Wvi?6;QEp!F+g{Pd&aP13LA4iIEf{z_g1-N&^sxGYc9!Ee*A^bWww@uT{&0ly6P zE4>?Q=1(JBKN<9^x)B6nO$1ldCE2g)7l?{*`q6aUZs>YczXc+;Y9hEg9eMEE(y@tb zr|nz;A*-g{q}p&Zj7g)OS1FK9iXAIp&u;|>p}K(%={QI zm1!z3XXB^soYX$gJdJnjzad;dS{~NFOkLr9(_8R|WavlxF9SmJ!22fTuj_tIWDA>s zUl$g5uY#Ri$KdJ0uK+)iN9AG=zj^raa}8`P!T=~8PW*_D(uMrA)4iSS2^&f}qS17% zNp#l%CVrBagP*2LmPhqN%geRVCCj@XVOk!QbuF(Jep@=;{s>@7AH_@bndqLf(Gh

    o?yxZ?gjC8{&2PFunbga%y_fE<;El-zw(l;sIcYfSPN4jUw@16JC=%_Ac zqN9A%@#^<4#hYZ8cfJUmwqN-y^8N~Q9z!^#m-0D7yzjXec4=igbgyNXrsFoc3HSQ4V@TIp!?8|K@&@++gRoG`#jd;tE#K6 zuk!h7{2q^2qSaq47}eC&cyLFw&xas9m(0H+*w!K(S}jNxvcGCWeCZffY}(0-r^MK8 z?D+DQt>a%lwsrjOCGKs9oW-xaSyYK4WA&MhA9%FtDfjv%k9Mv1JleW`%cJM7KlIr0 zrz`7UDGWVYSpN##w?Ddcjd0xBc=R#%ngil>S6;Pk%_aDSiZ5w;`urlJ>3jDsX<4#$ ze9g~|pCIgPgqeBIWNEE2o7GoSIpFsV;1no1n?*;7sz-{Tc7<%S zMF=Bz5q1&4m5*sEG8twV;ywDau$~^nNSF#%RV+uo9G%CUVwD4%l}XP3v%6(?%p&sh z+SvU+Y<4%iui$aYsoeF3c;n*yMfe0PPvklBoNkvp$DQlWbGzO1-1FTF@)o-3EtuFB zBo$AEj1s#Zj`Vuy`03rFpYH{hUGWxi>HKBJ{f+d_f1K+t-#47?_j|e)yo$OTNc_~) z5T~N@>SSWxL$ymesATy6e?48_qlBIRV~40-m^iPlGr|zmLwkVJFUg0xWv}x4z}-dn zP?^_30&xSHEPR}eiik#D(2XmJJmxsSOxpyL9 zb&m6NILmW#mgg>WZXn_uk-HK!SC9vIXPA(=t8$#6V8UGD$p*7Lg=;PtXmr^!yav>J zKpGBT#a(V-bDJDQ?JyjdQzNqjzl-4~ii`349^(n7M}^DrlR~I|Ux^x0(W@+?yh))n zD5KD@A;=rS?_%YJ&wQ2`;vy4Jo(z%&7D$={kzh3HDQb!LdOSXl-|MR_!mBSDr8Nr* z@Od}+Yc_fP3fmoNZUWXPNhHAENE5QYzRFwQCWC^_TTL?ZTU1rvT9ZN^K^55@rii9T z>5O=saDeS2CP6sT)f{SRi8752n#942V*|KBW6Dz{X&Es*Ho7MfGd?xJ2-^qON_+a8 zyGbkNsrJ@*tNb`XiIR@Pw1SanQ+Ru{sS}@|?~3BA1jWQbEePuFY>CjZ2`30h`j*^- zZ^;n}e@jlh@LFG!Cm<5OCr=15zbH?@rX&&RgLKvqjhE#!Glvrt=xS<>)^tZTu^mk! zymrG#;z;ZE_C`--3O-O%m4-S%JeB@LV}-jqTS9HYp$&}B#7Y`WXW}o2M%y|&w$jfdTM_zWh&4E5Jkkuo(dJ-NTert>tc^y=G#%ZB zDA!&XZ4xwf(e_Y>X9G5A8e$4CwmV8hrN6cYsA-^3VhC08Chtt`fO??(euUu4Gzu|O zXD4CG0gxV4@dS2xe15c}mvJS;r~ zS%y$*WK?FR`0A>vYHF*{`d8L^>#M7MHNI*@_BH|8(Y7FpirswISm-1xzTFB*Z_H~g zf-G(NPK!e&TblM=7M9b_7QWsJU<23$ji7AbRFdA_H%N<_Hqd6j(S}Ym{!O-! zbXjn-E!@=ML>Y0b)VsyZ2YdNLKHX*pbABX+|En3EK3CpnhG&^6?>8B^DB241on{yt z#-0HmFay)%&cB&~reS8!oDV5mvR#r3`-iPi)+C`We8dV)mrozHf=z8slue(d1fW+W z8w+@qwGHtl6Av93k6S^+F&T$sKmbWsni%2%;y@+kX2)!5ZB3JIcZP>i0={L^Ly)a$ zPE)8Q{Ub7F89^dLx|U#Cviv~k{vI`jw$%O53P?=elcGDcH5!O?wuhS1wX8o$2nVmd zr2HI#7o+z9w9PP%Ux}SftpRCa!|{v;$e7P-0NSBL^g9hg0Jn>O6g#1II!#{WkR%;m zCacy(o9Ly5pCSHA2oxp@^EbjE*DTE634>6^ z3D@|mB;Ja`ES40<)eb~K8O!mTMMu8mWlp|L@@J%x+3ol&X8L4849Dl-)$d<92Tom; zupEyzr;K%z&VZt>bW=~`&?rqd42|{;Pxr^sVbXh3(Luz3md9*3LQ&04EXhWQDdJ?0 zD@&PYp=8nH61hCu=^Knq7%oT7RPKNi+VfHk_$Ns|{)D60#vpjV@GC*k#@$+U-bFyAC_n)Unf!H8l;Z zxCTr`?-biD6pOr5?67dAnma9=spT$?#FF=fc%2Q$0&$wO4QZwDuNhRz(eaytMFS*HrWzi$tKm*HaNX^A2Vf_tA+Vt|)X^5|2m&!QN*gr|(LmkiKm=_v2hnuaP@j$B z{AjeJ6Z=px(4$T-Zmu4l9FO;v;AYJD)bzwCnwbE)^xeT`ibsDbgpokW^klrBdi*%1 zZD%mBEjjo=JhqpDG5xT;BhVJw+7WD)LxW0;M9{{Tm0&P29_!nSnFcDv0*tu!K5$-ojxZORPr!qqj5-n*Y>6eByd#NSdY7M4Dliwx{l5;0!GKi z4e>I-oh>1N2L^@=ag~!mvgCmQnDJVG-N79IC*%7KaRb0mcVkJZr+>`z2Ez6Y#`~v- z7`yjOW#6tV$B=jRBwEcvd z_K(a()6YXFHZCKD_>{~LKP9lUi@>o7L;MP0&kE+E#cr{i%)h5;Y;T7>J3Ont;fb+69K+f@h4v;)B@ti9YC)U-;u81JGzr;E z3R3o(8XNB%AV$e$D6`EbsNq9LgovbSE}y7vU-$CCQbSaMYVb}iDg4!?7$ z?3|9qc4~so%cgm5G`-Z%O*_xMl7jHzIP%r(no^f-Y7nRNB2QOS2e%8iqL}l-XCaq) zUKo95<;8SyZO8UDtccZ-gE<2^vHxnvwUmO2LD@vtnW4-XOvY!-8RUqbD6mh|dry#I zRU9r??XYN@4eSU?C7L_8H?{?7S*KQu4`bmf zJK^XTO-|96qe1hwgoC@9f?*xgIZ_5*p~MiB&K78+hh?2s>JtQ~OXnck zsI~|Xnat^iveI=l{K2`Ulnor}^Q`xjB$I$glrp24j=aUK|=RH8e^BG5Pjq(Yk$WFuDV4glM4$hR0%4xIh;77KJ)O5%drc|4SxG z8%X3lNdMS$?{GYs@Hpnv6kjG$|0{4Qk_RsWbFRxf5Up)#k_TmwJ^m_WVsOb)M<*4C zznL)SDHeUNa%hziO?pkf?Hm}#HLjDBLjwn;x1qN;V`cYyHU#lE(9RXX>QAycGLO&Y?-%Xn@NXvrnhyNJyndsx-a= zv3oG^Lr+^RF_x6fYQlBvJUSe!lqn`A8`Jw=TDfmzys8AzlzU1JmX>4K0&j+$)H{)4RjKP)@@%u;v`3MI7%vuU104TV3&3ZLS7 zq-v4MNftd|t4_MrN+7Vpq1Tt7*Jw<>0A{b$x?PmyNrg%YfV8iZG<>E^RSffjx)qqU zq17D8GPM|p{T9SdLoN=(iueB`3M`%8L=RV93!FXMEjrn9nIMwz!5mtf=pCBM-Z0FN zU>8dWWImijZ78}UZOy)t0Zh+v7svKi_6*SK)3E(TO~a?}*f_%_1Lcvdnae#967Z-c zz(0qm%T@PMy{93^@ta&L35MghHYjX3p0_~1;kawQ)k{@<{x;b^Z%i52WjBCR2XLq! zKl;j8Khk?_v+D0N`)knKcgd~@)~j5~PUZqu@;E@!$$`K%SVmnMR^$?K1PiJ8xQ+JK zeR2R0pO_eojrL<9VGkCczAr?>9S(85I9E3xs?#uF2yo!8!)v0^ggd{DTZPf^m_yu< z%%K^Mq+>Yb6z{bd=vAc2)5`xOO&^*Xfm~Ck75*ou_@G5iFEZWyX*L;&O3XpqL={pf zdZJO>BWv7gH2gbFJerZ(#Aqopa!7%jS;})RaknJ}t)Z!V+LXROM|?4XJR!1}xs#by zonc*{%E8V9Q&-i@&K40;ITKgOyg65VGnw@SkuoRd9>1eGb%Ufi(Jr<}!oW8()&-vpWI z@{weJ$}PU&T%%bM#j9u%^PZylkz0HwXU#yYchXLe!|QC>2ReR4liqhIzcBt$O05Ll z^U1Xlqk0~7=>9mU#6_A+)+itj*$_nVNe$bI^8f|>DNO+I4y-IvUtGP}34wvAi6Hp> zCM;jdB+T(tA`U30n*52H#RRCWii%N0bUL$tG8qIPc67w^OzrXU?THl4oZ`xqiMyKKzpcdx5se&doqLJ zyw~A$IlqDncEv-E=3rYS5WT3yoEtngL&s_XqV*yUGOUt5pz@_h$wep1Rr0+{cJ(ykeN`-c(jt>uhQ14w@WgDJ)hj4{%t_DDGefxC#!)aEu9AEpYKVd0mV*yrPQai&pw) zkdJ%g@o_j^C9!h3n>*$?&r`Aw6@H3FPI&g!RFXd?Wmh5vm=V;-8BZBDcLQV1|6ne> z)B^*9(h&E^$hxO-?(9iMwjuk-zAPilE+$Tt)IYQOUrlQ(%TntTOl6m8nc%*(Ca`2| z$U?>gsVTDrWaPKy!(+8=ojarILxzj7d8e}@iu>e)U1%qtNE5Ux6hX*OYeU#7+1b&y z8}q>#xSyVlMv772JKQG6NQYC#NNVlN+<)<^mcr;G3TrfF9ZyJI9)0*Fslha~7^l}* zD!1?&3-9mH3fV-SvJuuP+0@~3r3}x)q%3X5!ncL_{@bztC?~wH7Q-;Ci5stoL(cs0 zKD?&YwdRY&Tb;|ovYN}~^a5;10!&q1!t2HLfaS=J+In=~KPPT#%bv39RG>dY_u zonv9)==4Y=Hm=s$Lyk2@;W+joOrh&8#vE&0h3W!&XhopgD9SgUkjf4WP2jx=l}G#H z(S5ZD-z>iD&MCXkIh)A)5=8=(BA-bk(pL?c*Ngih^Jdp9G94=tWD+Q49#12)(g&IU zExrqx&&?|H(nOg6Nv2qtDw9sA&Ue&`A4BH%bC!@fVZS{%&Ru3*f(w zh>Wb|I4<5gKd0=yc`^sAlqE%$&R&_5A#LW2i|Zlzk9lsgSr;x@m4#OpK_HrNZL&r< z3dfu2IKq4f#iQ(lhG1f7#wvnJ=GVl#7UYyY=$?a2*H)5=%q^1&r^v;}RQaxD;wa?a zK5q_k1?6^nU1c`9_KFWc<{#%GQ)X%gnUq_uuZd4U=5zD&3jy0xcm@GMN~j62+F2_YuOZ3q@q9hf6vUBd+&R>FHK7IE&YcM$fpUr>@}!X0eOn?Ltu4>kc{)#uS9wxM%8I^m=MmGkXC~-{YSPM3m$|W+wy_thsEYIbZOsq@6UutCe1GLzT= z@q1))dGZt-&DJP7dL|V9w0H}`e>WxJ)Vr!`h$QIg67NCy!IUXzZfhdZg;SRo z_i=Ga3ff=lRD{#;bu`T}ZpFPWJ`UN>PfyLX9|%AmMJEK*_O@@6{SbOfS0)zUn?pN8 zL&G6E-JLnux~r$FtCvPi)yc1sjIHf>t8Mta&yy>RfTe06)ZH-9)zgh#!Mb-#WU007 zog>&WOS|CE2__p^G9)`Cc^AS^dsoj`vE?wb^?BEdXQ2J{Y5#57N9bJ=p?ADTyal}v z%{V@K^JsS*tRA7a-QMKp@!u0yq@sb&`Y+epZg0|i+Nk&f^#0lG8OO!TWuKEd_`&U+ zInW>K*v$=3_Mtq`IJ&&-BNOt)gDA=^bN=rY#a1h-C`ZKeD9R`2j`t?3M@do>+%Q`w z`Kd?gkev+9FxfV;UH2P_242}5&hjPsrpx{Vp}Ce%TQhd*RujK3-bVKOPna@e*~HCcgmDJF=>ssXu2nNZ^lHKCQqAcrXoGdmmKSmsWf!bx5U-R^!xMD+5MYw z#I-b;9KUr(ueOt;r;mx~>CFg_*^M`c_2UqO!JbEffRrwWf<%+J#v-QTsR}M{_>zC< zS~vq0mXrUi+VDG16B!~?WkS^?%&{y^&}*vj04=gyGj5^`?mJ74@`4raZJCz%IN zf;bOZ2@~c)&C~aa*gMygd+~{r%>yk4meqLxo3I?xwbN?Ee&q2w@~F3LHHf{Vq42S5 zvi4GsP6NH;O_p|txa9;-?$2|kkky1{bIyt^H)Dpl16e(^WGY!rWIe~MqycAKAnrw0 z_vA*d_(-SIl`*qeR*m*JZiM#bCAH#%r4H53tR*J7!h}_REDmCZ5R^@B#%toX3{UPg zOCwi)!ZPKFpqZ)V5SH{#+(3vNid!xJmc^PG6hA=@e>+Y&4C8q^G~k%gL*f_6=%u^~ ziy{|-tQJcs`}V{|p#`E@x#AV%@KAna4&f`RsuR%0qCUaadf?9Z7B{jJn02K%Fwc{F zQ^ACi*@v~{h_*joGCA<9--|~f`JJOkRxWEwwknuWhMK_**A)NGd;PF6;7BHo5#$G+lHAH;S**>_Dc7N2a(l%MH6SG z>}6#|2D6n)&O=nU>{u#k!1O`!D6+b~SZ3wCJnz)F!4W?VJ8(pAk+ zF=$dT+03YV=G-c7^m}rDTaq5VWE0ygGt?g%+O}I+Fg0@wE2y-H#}hXy9!Z-4q-+x$g4-hKEu?F%#tp3qfmzOr184RE`07@anS-# z?#(MEFbPjgwEa~hl=gS1Z0MF8rW>)RTDl?045b@Fv!d!o6Q~oi#J8c_m&zR+5e_>N zs_X9xjp>;%W(Kw?huxO4dEpd=>QHa{Zp{wAL8DP5Uq%kOs9a6UkkdKpxP}MYv4|H@ zmnS?R_Ad0~-d{0QogC};=sHE!M%G?Nv$z`CJbKa;wQ;V|526j#SH{cYv(V<*%BgDO z@D?$167?0`HdwQr*Dvl`=&8JOrFhf5xU;usFeu-C4#=4cbsgE5S z*H($^Viwbm4mtILWZ_kcko>Uig2D^_Kb|b^k6A)*ie>kp3QLPTTZq4>-^lj4W_1mZ zNI2MRbs^S%Ldh-K21epdQTgXn#Gk@+ zpb}~w4oe-xL8XH@I0+pNAA=6xUoAfGS&R)OLhFEM*NQLaEubZTr1v@ z5*jwPR8Lk3qwSGc-fb_AOrAf-z5|qi44=1` zcBtnwS&TYdyb0~=IsjZ}57xE!Vy%qB9U<(4F;+glK|B(cSeAwgArk}0#ItOP5tfPD z28RZ^aOM>rnJ{uOLK{Pl7%Q)86j$a*oqGCrI_SlUkZz<0tEW|iUWXgS?c)U4bYlUe z9}6HANdT#5Xmy-)`%aU1Pl?9VeTS-jX(nx+aILynt8)NFIzD=(c@70T2ZkwVtbE`! zal;Z>SSj#mT1tV?k^~w@Oo7G`78qT39kbkSaV#2<#jkD_uPY_U;t?gIEKw@T(a{g0 zmF(sgaYe3KjS;0Ip|HOcO2*gDMHQgxl9rO;+b4FbwbaYZo>kRyUMf6hQhe!6(kF=Mm8!2Eb}8KVawYj{=0 zhgHUh+oEKA`6h8~o~-R>L|!x6-Hi=1 zYHX;71ACv}MO=+|w-Unhj+}LLNG9z5MSR}r!$W|Qj*ukESwaVHvfj}`uh8`Lzik&w zk<5mCYo3wi%WGPB?HS^Vf-u$a3YW*7Y%D7{YL<~R1g5BpW#p)bBMEUn;Bbhw1R1Ah z$~XB+Z4f3@d&sVK8zm3*cc~{EW94mUiig5gS5~EEIhaQrbkzN5R!y39tX5t5N}G5y zTp?-8iS;>(Ev*MlD*eCBmT#XWzPK#R4cL}wP%!1dF`2U9ontj6ws$<209jmhHYZkhGQY* zV9;Ht28C{1Y)^wjcag%)jl*qY)`DV2+ip8z>$ls+us09i%0j|!Gt{9(bzqVNdIyGa z0vNzCv7GLU^Je)9FQ~k)Lp)U~2b#z-Swl@xnVM))nT#W0Wun=pUX_uvPK+mGRu8}1 z3es3ek#fqW2O;bdAmUIRFKu+{fH@w{YU?+*RByr97#FI1wNu<&=B%+`M5_$8;zUxe1Ic1|l@}&QCkgEoPb@jkav8s;X&e!8IQy3E#49Y{2(CK^#%k*lb*2 z#njhqSc`L*6#XL>T^){IhZ{^aw}peaYN*T*>rp_Q_lR?0+%p;2=zDU{y|ZgonCOJ{J#^8}S% zM4uV9M^8FI)#E!!Lv%z>dNc>? z9iyUx^xhUd^@QG0R8dam-X1;qBzzj1d^%v|rg!bMSkqh$Ra zT-V1co!<9^b5X}4x!j51dO&j}gmcLrM6nfv?RT0j!V0phP;6Vkc4Zvr8DR+7B`CH% zV7o`M`J7Bje(WX>_&M`LNFtL;p2xuR9`iVuRPy`@JfHEBNzd2Sq>?KLuKn>U$M+pgD%q$Jd|R_QnpCoV1#B;Awg^KglS($6zvRAj8ZsT< zsO1i0YPm7*f$7W46yfZWiJGrxKA3*WOc#VZgk+LU*i#LzzcE*2BbRKl9ed6O+ouzh zTJJ}+bjc6p zQg54P>ulw-pxkUj{b6h&n0_UhV1BblwwTDYu^Yj3aS};d;mAa$jXf7kcSxq6qH#Nj zlD3Wg4A>4ywr{~?4s6o4v5$c5UCH*KGn=$+?3-Y_C7Cq4EZI?->Mi4DfbS8>_tHE^ zK4sgumEilMi>`zJd2jS(>4Wg>V`y;Sl=p*S-s)VJhn(@91_IrG) zb?k{T&cVA2>FsJqVEkf4KS|LT@WP^H=N&JHe;MtIh^CGx9@S10G5kD-^!Zfrmjiv= zEQZ?02GScKh0k9wgG&x4(px!06xt^MwBG;^QFanM1EfJa2@U|#emjZk8MJTMX;hn_ zJ!7X)oq_hQohDle&ZwGeCrbN+xXMnHRt7O>C*rAx%m?ztb~4WnK)&5h<_Q7FkK4)6 zUrYJ3osKdv-JNcyqa2!kvYl=Y>^K=KWRIZo=oDAlBdAO|;vRbhl?(L_K|i;Xd58x2 zJv*7oCAnkf+sU$Aie6)<%W^6D4m(|zOVPvYm!5?=gKygtsB)!d zj`S)|?l`)1El=Y(y7Dj2&T$dS$vmGP7oj}O^YFL`b~n!(<6_w7VrPttVaJQDFk70{ zzsNQd`yq!IS;*Ln9b#lLWAAW?Q3Z`X&L9mC_hxhkX$S9|=nTpn-nG#=lvTW=(K(cHyq}NG!8Ye|u%&XFD*xZj2X1Z5lKPvd&z8^nT6WGmMKtcQN$ zjC`y&*8+@}!`A|iA;bT!C4wxB%c*zLzsbpD3;I!ME5!n1SqcV>1winGFJ{)w!bykO zMnb~L32rY&V|Cwjn#a0vIyRhyR$>uSV+{khQPUOGlmz}^Ayr7|6T~siP9#EtCTNaC zI{{M)jS_RRMhqiG2QAsD7KxarFE*$|z8DnE?M+C)71|V}z>FN+oSlKlnKF=s8?zG- zrS8(6onWXyI?-^E9ugRHb$k&Fd4l4gUU@iqIuvF1- z??xJGI6n=l;GD`dsK1P2N)i=+p+YD{k)~tqK24B*%hL?v!x}yXu#8`TlqaQBrc|W3 zy{9DB%~G~03nwe$3X8aw`N}PlO72Il72!l8on(>L<pkMNkQ`-zJ=77^^J8TG;Aj z3$;{T4U?S`9zn_yd9_7W>Jl+v5p6=I8OECM2q^^QDvQiQK&+kzqZPp)eW-^Tg&0Py zMctgTC1n#zxmJ-hx{ieDbafU&ik)ghk;Qt28b&<@+}@RmC8(TJP-6`ifzS;z5l^nv zNCB*$&XOLgs?;z}Qz%t+^K2=J{Gx?|6lhg6!`L`mdeiCY@TN`a($_baNJ*~vJTPw2 zh+&+;K`4Eu3KBz`3L3^)nv?SUkVf)S2n{kCOUPD*sF-$z5FIa0i&9mtoid1wx+p-| zgeYJb-5v?H5uk>?-NU*XMh^#(>TDG>j2$|fSh z7ftk)Y+w7}AlKNTdFp3e1$_k6~iV9aO2hSudLAMaCS|-h~YhY-H6+&`UQCH8-p01Ez&SM$=`zw#rk(uxjWBTI zNKaqLu`c}ibzw(LnmDNTt3T~@KKzkLZOyGUZI~*OD>f8%fE014KOGU*7) zo*->U@jAb`4tIC2tEpOVr#Cll+)$18_;%VFT&`XNDlYp$JM8PmovJuLFLZ3R)j8Dd z{~*(I-P389{FDv>VgwDtahzuuj)Odte+oXGhVbv((ys)*SK~3p`)>o+n-*fgO!E6V zo^Z(5Kal}ky>(QiHsI)@^-soQ2rz#XA7^5i2LQ)Z%KQOv@qir}Rtu zp~j&N^b5nGU(!Q59_jIaQlrMfPq--$i7{75qWdo84>+crNoE;J|K3ZkPa!saFped2y)!=X>y*K9cSiQ8_& zF}lU&+VEvK*VdjM&)u<~w#Cl{zQu;)9@JRqsD98V3oibO4To&c7i~BuQ=T3hz8E;l zq<%;bTgTY*$2s{ipRmPaEg)vS4aYs@e9J0`NDp6if8Q3r0Qg=Tz6AJM8;-i5#})NM z`bB8MroRF&1#b7JJm6$M^2ev(k7zHhCQeTIZ1|yBO1?=_Lp_TB$GdYB#zmPck21+mBj}kwb`PVSs z$nh--H`*+HXCs}d_eGch6OMl3Bs={+Jo^*=UBf6N2tT6yjo&bQm-T`Dq+YO#gy^3n zJcHp5hLA7m*D}0~;X@1$F?@yLKNNJq4wTM?zEr{*hQkc6Vt6yd?=WP2UGFR0jlPl6 zyWw9Fu4WiycrL^J3_r#2D-2-=neL#1ru~rLYO)LZ%@qW-KYRo0A%uSm%eQv=MVQ(U z4trGE>3gtDLii87n?coD;E7_whXdrjd9Z2yFl7_Vp8#qd^!-&Qcu!*DjkWeocmUd-^2f=O(LqzuN< zzDd6%j0X}v%!uCn|CFAI~h@Ogm zSHe#)M87KW-zqr0li@iG*{+y1NIu`C46kGODnr&QtwG^wA7c1*hL0#XgY7V*i1Eu9 z-pr8Y%*<8z%mIc^DmaVlX%_R(;&RPqd(Hl`;!EfLEqxE;tmm96h0kICo^v;^Ib5;^p7yy%kWbS?`L?BA(wZ- z3ylA-f>~~cXz*m0tPF5d2!G+vk zEaZF_rZGL6;Yx;U7@o@TOorz$+{N$$hU_N`Z)2SMwT1UG{sV?DGW<2e*BJg;LA-pC z_Q+r9Df(XZ!%`)7BD=KA-9J`s~O+K@GOQQhC3N@y)C+ian@@Q`_Ce-$3^Tvi=JY>-zk{OdgOAu z%l#zNA5(BC*Y8sH-=!Bbo!fg}titm$8M1xzRx!SwAzP zF#Wd*7PEg8bGs_OPSMTz;JtXHfNc$o|H}zJ!13@4IggKHi2hUJbqvuTOZ=k@?_`Ml zB^`cF(B)%@eo*3@8J@=w<(72lFX3wn(xz_0-RQ3+gx^be2}91${Zq#OqF~HyhOj&F z$8<7eJ!9@>{1*)WrJx7>0`Ys+G3;k}Ekm>;84tS>j7?N9K9?ceC4RfY$-WD~XWIEO zyv!sV`j!%epOYK|{WxF&R)P!6Tj++30$gu|PaFWZ>k!`O6v$T;!NJjv{`NjxHBn&E z@EKiS$WEZ|yzMwHbsSJQR=!6dcz2)7pi{kDF$(Z1DTuc(!R`1`8J|_F`xUnh4Hj^& z?HwIMp`8WWh6Y9l3yOn*KDu2k*xNCe)W`K+54lx&%9TcA&Aaf6b2JhL*x$cZWktwK)U{c5NrY z!TKV66jm2pQCPYnC^NTfYBKi^(M9ROa|SC~I|tT<&e&aw6cN(()l-mNzKi05g+o23 zuU%7AvtvVPP+hccvjSc=go2%Yg$3J@U`s$ISkt>{_wu2gO*N%m4hi~(dxmK{%OKvH z4asENcFJViE7rHx_wMSWy>jF8k;!25&Q6)8rk?JJ4vuD@+J0_N^RA)M?qCf`v6p*z zqzi9eBzyT<$v!etx@J>fN6pScT=AyZ!yJGMhF4}`sMt+5 zjz+t`#uMoalyOwrN;aNIyMpc12puEUi_jr5d$~)@E)JUm!_WvFO6(vsHJHjrKa3{va|nWf#$J zk*LXZT;XjfTlX}Sd@^0lxa6vJ%j8j;_qd*(Tkx@2K_|9)J<5GD-Cl(9oe{ktiJ43{ z=qLtNLcJo%m`t}AA;Z~!3OY&LWCk(^ah8WoW_WTC@WC96W(UXWU7YrqTuY|4%07kG zB~u==Q>oM+%%f~Fj?JBIlj)WwHOsKNAyp*Eo{W1~ zE`bD->1HDP6(pNXx1y49#UssRx{+vgjpUQ*HYmAii^Iyez2 zF$FK0!jmE%BZ9#oKG<C0^!!;X+Rn4I{>PDK|s46ZftiaI#b48|$NQsC@H!@=o zoP$*%DJ0G(xu@aZWPymu|6H$wmy%#TO8!dlFUi(F4!d3g!Om9>+=0))dUzP$N}wcD z|8yFxn@T>Wi$S0nn#mSdZwn*nx)T3TTK&_-jgaR$JUMxCACi+iypOT#7qb<3wa(NQ z7s>a9N%BEI18a%qFG@K)h2VJB%C~vG6QBLKEuwPskWKD+e0OV2L`p5dYo(4hd zilFx`{PVD8vf^Anu)-7@e=pW*Z>A9cw2Tvh>o9^zP539Dc?jryzk)Eqw;~zhT_^0I!0JqEg67W>~kvy!KoAS6EraY{Jd#^{l z{;@oR?X3A`Q8`*Q6QJhfdNcXpFYd(gd@k}Un|}13*3^&egR;_}wzHNu=KyF&5T}1S z-w6FOP>zZGPs=0Ix*ylV0JZ%nf17@O;?efQyOL=7`Cmj_HvaT4ihc_yexGIn)O->4 zTR=PykLMFV1I?yi7S)B;ZyCa*KmH=^m(>OO%lOkjoo|Hw7FL7dO3ehQ`6BdNcnEO^ z#`B3UfM(M#o64c}D@GW)Iq8@ES z0qSzpB5W(i3bL`b^HPMPlw*Y-`{?jz{&c<(c0PGEI6iA~nfb~-7HPD8C%=sMXVv5R zXy2h-zoBg4+Rk`)6ivUOazr`RZ-jn3uY?RIz6d+-d>MVTlV3&HdCzvd1A7`W^-tRc z@Ad5E*t-(AwsRiBQS7{z^d&z1)AAz9v6uASrKdoQH_;J~@DDM{#uYWpUyx%r;K=7*b@DIt*KOH_71f2%KtM-8HWd!t3#|?p? zodv;9ZpD<$j{x55o8ueV3HG;tPjLMn;0N$W<#6MV@}+WZ#$P=C_;k%}42@ z@g1`9O|$Vumg8l_rQ?tCO~9X)7s+=7ar>Ar(Z&~1-WxAR9O+N;l5Ko=e{3)BjU-F+ zQU4Sr-y5$-oYrsl1blbH&2kV=`JND+@1|!Fr{&F`fbT6EAL$-NzniHHS|0Tk(fIr} zKHcw9+6cScTn?JHOCG|}ghe7t51tF?9DcPGcw-SmrM(DKD)kDJm)}_WKL{^i%)h&23p(ncrVhR$g8r>075= zP*YzkTsk{Q7P4G6!W~`I0Z6M+nKv67zq@+v;CBzK9sK6IcVBsZl6Un!&p!8|jn^md zOSs(L<*l%plNxg7;Vd|c_De2y=Ior1b8%(`u?&bSLdeheJ zwF_#?-+ll6e`Sfdr_w*V&BJPFsA7>eXrrMa=@*51IooLM69k@hs z2hO`D<_5#!y)ic1NdHHmBmKvLCS!kc4Cy~ft9gV!gNc?-SJ&YQVK9(0cw=(9_XfA3cvl}v1I07X*e;Cq+XF`Z_6v=MT2ZlQ;0a^r zwkNh;y0v<%8y815Kl#VIQ@;0Bm?c_{Vu_2=FDE<9{Y2_Tu*8LPn_!8{VTtnE1(ds! zB^0eT2KH&wmdFw(8nD@S1LviGG*GSWaAPd&bCF-f9aw0jdjn?}Ozjoe2ak+5aR2!4}nR_lbK6Ju?yD!WYhZ5F&=TO;;xl2+HEnnh4v|`EXL(7)z zd2+?e#h}l4(F^)?&}V|41p3mKQ_J7aM7aEYz&(fDa}OMfTXXl5^B0Qk9oM_aMla7X zLo*zC<88cd&6{r=iuvg0w%@8`-0k@u^=_&Sk&Dl|_pN(AHY4Vqi)t6oNUHi!?erNd zscMaj z6|b5WskK(ED^^%Th2^w=rh`{lu~y1InUH20WQWy47_mtP4i(`Z#54<;2WwoRHvK(p z8~U=a*CncR^vLOt`+!@_b-7|8>Hl9FV-@?~YU7{UY-|+1kDnVuNoVI$L!6iFOETh& zI1%THb9-aF9&fBS&g=EYd#8C5;u5_yr@m z-#ReR3+C|e^9^x48o9ECtC!2-`9EA1*Fh>w-EXM7cu|#$zB)68X-V&&sO~+THu_zCechUHjL`_+1j+ z&#t(B{uwQ_Bg@gHKXTsx#Xu3ZXTY&fpN=qT?}^<2ILZ9M=KjS; zWV-m+bWf`LJSy#MnBc<*Xu@n2A>0>`_*sZOUlt36L;BuEPm((>_ESI>yNMF(r`SwM ztum=dnN4&u0ZNV{xI`@1t8_=75p%wA-F5IkAO02_uJf}cG+YM|#&Z`SIj!q_G;95% zwuW^y*ZCmOdK$hxb)D~*5N*nEpMMAu2$08zC6oeODxq9_iBSn@NW+K0Dj@>Yn!^&h zu)E%Mh9OP^*p9zJ6}$$)n`KZ+rd(B15-kX#MNyiK0Gx(`oCZPtlW7WYA%iA>i^WiW zN{nm&R#T1&D?uuJH{u>JWLOK4BGPdpDx&bbPMWlu5@e7yA*xDGRQ;1SUL2;BCP69v zlcZ#si6%*y5tdMsYzZYP#+Fdv{dRSrwI&$!XVr!}{Qe?;abeMlEOcDKAiZ*?h@!%i zipx$aELPN(*6J!yizJIg_%IbBR#adoZoQ1Esa|WcQP|=tDO_Q4$O}_iw=_{kqy2QF zG0sQAUTBk{skOPfuC_MFJUVI^*Mtppv z(u(;@3vp0Saj}%vimP90T7y+h8-rDiIICuJ5GO6EL>yI%sFudsRyuU)C=naO51sMj z&>3VxnX^y?tz&0Mm`MmbcqS~yJbEUKI57;XqSWOR#PO$jEj*ix}BH z+Sg$Zo2J9%;AXh73GJn>rA9Uz<^~NHss`%ogMpTon&wuEtXS)7POqtF3z9R{Hc4?f z%M)EAe)IKOwQCT)i?Yv83 zE_Ls9T_!fA84v&9ksq4*(wZc#$<3uZi4uZAwZ|~H-H#zcZo#RluUiw=#0rZl43QQj zE5lEM)P%8lUCdxguqxQHu@=|Uz!JT^hL{x$HU&^m#W`bnyO;RK{0kTQcN=0hlNHs* zsrfVvpmZ!3i%6{u1JTYgKBat_XjVtTZsq`_#k^clfmedC6; z^yim-5&dI`g}7L^6(>ct2CHkT>RbGVYf&&rrrFSfGc9xwMjHlCd9a}lhey%p2Vw*` zzSEF|<;5$?KpF)Jen+I7j}(rr=vF@{zY{Sy)|q0=(%D&^#^-W2 zz$q6{KFqm*Qe0HBqNIFzSqaGJaTXw3SyU7kFJHc*xNvz{d1=Xt6{Y2cE0DznWJr{S zB$SpKVvisK6$X^D($eLiT_|Z(8qi9LD@rQLRuos1jvC@38AGL!S(%kmR9;e2wgPuI ztysRIu%fiIsH~_InO!CzJ6K->SFxM#a*G^c#gAGs&c?jLVwj{&ud-68VoTG0+@f;X z*}|W&BG>?SL+`Ugi@Pn(HGX{?lf>bFJKB#!s?RK4&IiSF}0vt!5k>#$ExRHzOTt=L=?}X_$#C z=XPaFwo9b5f60nvO~Ts39agkcJ$>1VHnllgHQhr6z}!l976>Y98{#`A9Xc{Su-Om? zWF9gBB1pQ@#1M~A3N%vgcFeBU)-~yVr?(d#@MDu7f^1#0gHucX$7RkkgYX1SJ;A6< z@{G{4M(PS}rTe)R5njCKMGKDY3$!*i)Kxk4tS^McBdy(2UP0s;n8Sc$>mIDC%YqoLZy>10U%6sR6BV^OQax^UB;vG4OmeHL+Sc^+ z)AD0ae`oJ#R|re!`l|^{b7^rzt&ZS49Q9TrbuvOs5yx$-y zxSL#f}Ba1@T~lKnDJ36JsVl2h7EUwxOl2g&sZe0J;wI+HAESUp-_tsE4Lf z&{`TW2H}|EYIvl5q^HxyadI%Yp%Gss;Bk>A zyPeXHGxfgpG_2^`n~!U`pRoQ%(8kPn_{2kTW_Q>Y^DxPKDi66IdS^y(`qd zgQBsBv2jD7zHaRX+?T1kciG40=HOvsu)T8!)+@-V$=v?jC5WR`r=n;o4KYXL+}nFEa+co4x+C6%MJ5bScHD-P9bSO z$870jR_BD3e|Cwz)bUWxbxkc;)s?B7vy}`o9t*XVce%wUb<)7ml1c_M>0!6HMJF9Q zTGGwLU?%-~jQFxn+SJlCp}yEp(21kqTSm~|G?6EUhD<>#--{9V(J~3yObSx=8W|XD z?52b=m7&Zwk)X;09&u1>)NmAy8rpmMoz>YJE1uBmNGUdT%v7w7iANTy@`thFd96!R zb6rEAW&Kes)YH&Dyu-4}g>mBdS`AZxQe|*R@oJNVr>y*8ocOD|0-XZx$mTp%I@u%G zF1uG%*=Bd^wqdCOjfUz+W1}B`3-E`-!E9qAuI_Ha(r2^0wL1eh_hjjtd(^!>dyq8z z&0CayWHK{Q-Pv@Sr1@_$#Cgp%M#1DE?zf{crRfVraWnLG? zoLL32T)bk##(KP0D<^<81NnO3gFe?%3DniyR$KoP*VQDSYgxo`t2bC!{$gUR2Tu%l zMiaf>lTRX7h&;R%mOt{XJp9pjTJ$Z{GO8O`ls>waHG{?Ys5OHc(F+Ckh5EvyR9Fee z%Xfcx_2*cxpoTqaVD^qHV1hYW?R3dTmV83M!_T_F=`~V`>c)+0>TBrb&o^OpiZ?IGd`0V~hMt{W*~=;MoCF)kT#s6ht4|y3TAszZAOJ7~;2P z813{`AluuAgR~QDq^F+*V)5;7V%^5IHNn&IrV%}Kcke*^$P#)It*zTo*NPbe@_*N4 zsRxT(2k9CZ#l`oLj7PAZrqV?d^>?uW_kv&`FxR>YyMrrgtKp zJY)`fTl81SP~W(AO`$(0KkT*EJ7$zLp1*LcT-vLUa(~y|GmKl6dPYK%FQ-lsR!U7& zWqcoEx8cDLGi~*XF(+q26E0rt*YS8uInKmnV;cXZl{@zk|qAdC{VX9 z5G5@fD>l)S%w%0tNCvxnG{!6dPFZX3{ZEua9aM*EnOZ5LB||B$Mk#O*!&Isk>=E^< z1VGwNkcKO;hW`_`h^SH1W6`R#BTS-3&1BI2i>&>BtUBp{NBS-CFMv~0e=w2e5!_Jt zYpn2bZbzyWshVWb-L~eWd#x}AD;|1%2YU6l%K>2GMy>lr$sXZUN&uuiMAC3yDm5{@ zd(pkXgdMF;5h+uPf!H5I>?q{o5YSN9f5Ktu*h%_v}0;cihK@`eDXoya=b>J-lW(i zVLx7^`lkDgo6eCB0HL9w?d|J@L$@K2BHL$N9t@7z z)^H=W320o9_&0YbyeN$L>W=ikSgYNvEm1jNsp2#r^MRhPjpJ%A?cKkg?l$v zJQu~qm5BK{~oOstYSMte1U+(0mmxJ*iapG(4 z?9PF~-K1}rOs9Gz*5=kE^lH1P3HRO#J| z@??o$jBAzP`(tEl#A*vab?EsxxWs9iO|~cy_Sgu-@Kuf5+_{?~-f@Tk-Gw)cG#6JR zI}z|8Y7z+loQcapnS{As45xwQR*OGD(@j8HtGJj%OuJN7BlH=rOayQ;H_?iEq=*Vg_=Srz#miP& zZ==!`j?wAoIEh<48yPE$S&o>OP|l`}*v6~UAa>Afz7N)~Z4L2Rx2m9x8yw$7_v^ROpJP6AMJ8;4rM-7o`|e?0hoMLDAD9{E z;IiQ%%s+E;!d1!5r6)`kiv*9D3F!S?ORG*6nQDod;)iZsw8q-nmKrm~xQvjw)B(Bt zh;u0`(eiV1U=!MX;Ezz~r(kVbziv%y4z}DE<>8-V`Ul@J=U_5TsmPK`Wb6`JD8~d9 z<Ul&0eCvk+%mn-V9RkCqI{T8eTM@jwiL_AWA`fB24`HZx0+%uATe`@Z(_&~2y z=~E2rY05hJmZm)VSY}d#dFW-F-aEK_HNRuw_o-STo5RDZ073iI5s2!r=~9PrQ#F7 z<&z!t^_aeYLtNvYt|+`??S65C+n4(%S7K)WXkTmlpnA_<=UQlF4q_j|2&V30z_l>$m2~>(a>>#qJ z6f!>{9)`^8VkVI3niVFKP$~0>gUsbckog<&1Z2K8q0F|14v9}d@?YY-WV2@6=`NjDx*!Nu1HC4}l{r{VC(-&`l#j9xI)b5|G0O#&%m>BC z6Fj*;^iDx$%vzF(%FUGukCTg!seCbM;s(h5O#Bq&3aV{qU1c@K>=2)a%)d-UrmWN` zGO4y=9u#*$=4;b@nSnyI`@`fB0Yp&9l^KAmQYgm#z%&GK>~1C+Ftv40scT_u=K4Vu zpP0G6M}?9z*LSH*h-r^~XrEQcpe>`nIM{wg6`<$1)+6QLNDCqiELJqbSJh&|6c z;D0Jl#HXt~5z0_`BII|THEnf+wggxCs&|rh-ffv80hNh#;#zUPa;dL zZSNexj#=6ThfXlr$dV!1DaqqmhT6M&#)>V6k*&|WRy+gkuTT4L(>_A)k_f%yJ>o6s zeQ3t<(VIuR<6!j&z3uiUH;@0GxFQt|bk={l-gbMF-qS|K7ohjgX3sb-UM~Bb%)t+C z?@Syu)Ulfzp6o+;pmB70*+(Yiiw9AZTju=VD~hdFR8fwI=TVeT&K>VfR*#aTCb(g? zPV!Ta(jm{ZL6@~{WV`M+5)HhvIh^H7@=cfh2SRf#pSEV~)U76dU%ZX%_n$Cf_Se$5 z7GBjy$^Hm3-S3nsd1BHUanW>7?%s@vGEJT~)l5ZtmM=NhAyaASq;H9fd|US2F2UQNk);&v#%Xa0XudFoNeDNjUG`IJjo`5Ur)DSMohr|M3A zRUClwhy2dUtCqiJcd_>0n9OmN5gV;C;-*j;)MJe=4~S-YQk$qeS-!+u9LgfSDCIWs zJj!zCg7nN5Oy5wrWSV%YGBnrLw(3GaCcA>9%IB6DYA#~GIFz5BrR>xp@fKu%Co4U3 zgBD|CZs@Qq#%cE&o*@~>d6QWST!)r(+HU-3fwFmZF+@6K~r00LAyFfBKxJ( zC&XnwPwpd_Ax}mb!6UFT~0q!d=m=& zB72ew(L;_|2WnClt`JSrOzZeI*%b1fsT4|nEXx;vy^})Jbxwan{00jB&!WW423cL` zG>pi#6g;<@t0!t&hzDr7v;xel{DBq|u$8$7&z+%&Ig;;u@sBx}^)8-d9y|%+JY*$I zmhVeWd8gR_$A@K`j^itl0MUe|Z zR*NN+eS6}f&;rq{T=5EWcql(Ihwv3u)d^^0Q6FS$J#c4yiyPSq%(_w>nCHp8sbE6M z?891eMB5)PnJReJ@5Q5#{LWD%E0;ATTNO+_*Eq?tVrQ=wPeby{%Od^N$r?MfXlahj z!JT%TmrQz`vXalgvu_mlW_ofT!_n4ZE3fnjZ7pT9dCaW1ZJ1dRK4Dg5uXK-i5Lw+< zG;vnSURG9QFk7kQJVbTNj-`?YOdk}FBCG3*WmeA1^G+=rycB$|6@w-flg*5(XU?tSM!zTbw4aB1yeJ}u!2g9csy~V;?V>w z!k}|g#1qJNPnmy$Y~fzEHz^aB5#4KQ<`8BCgS>h~>@!T=$SmnnHwtAaPa3bA?84{n z6&Ee=?Wf(B|37scPf!7BO=Y z^%dPVShJniFYa3Csl0Qgc+4mQw8MXUKhLp#fH8k;o_eI`*&A~kHxTfW;ex0@{{=2R*CCk z7SoOnIrV~M;Z=%|{IKnU!VCUCo-FQ$Eh(CqtKqb^V z9F{tWgGvW+a1uHkJ_a4Wzgm3Wvl!d5S_1f>9OY2ep*|`PGaKGFwPCnwXjjF`XzLGc zYk-oZa7J5?QrxKAAHZgGe0+9Vpt`zT7e^Lq%os0~Z8#(?h!^8zNBOTDw2aD^0^-+F z8ouHB;L>hgBmSy&qdN?gt*4-zQTh8d;?h_YuVo#|cZ@Rbs1nzbjMGr4V-)dbmH47k z=w9gfG{Mccg@d zjV;xaRl=xzrB>{TBR^=^7??t`>(+`ZILxm5I_Stqxs}^ZgKE6)eZKjWAmx%;iRVN-`0nrUR zk$@-a#N%3ndM-kbV-fH*Qe+W&V7GmziWe*aT!tx0c;r;^nv#H8o}_~smH#|d{Ebt! zOg`0}>%~Q0@~F+N<9mh3QOBr!eZ9ESOFLs58tMa4yh0i)W4v+5scx$muP@4_0g$#K z(DMw<(6fDu7q?){6Y1#LtxSRQKqu0%svFx}`DVSiYVl&7oaR_+@L1eO$>j)YOHN}) zduJyN%6hzn7|*XN?`;tG+r*ed{Nj717#alaVh%@&IZR^CUinUgxbwtCqzyhS9@-I7 z<)LEK;m&0O9W;=iJy_S?i?uQicZ9GH##s6I2JuK(Vp$q0giH(|6VI|GMp!0p8yp(w z!kJfiWWvbB2yF~GVywKXQCyiLb?WKg>7W-YLb{P2te#d4dL3>Qw~rHG(~Sj?ek_1g zBmtzJq1AEH?K@54JtZ1b_Z@a?IckMVtEKVI0Tk)@=#}O<6zm)rrl7I%fz!kdOJrfC zz@up?1wu;_XdE#G8b?@Qblr8#a=XQ`Xhasjx>>xglpu>ol#H^3ttm%GKZsVcn_I*c zxn?y+l#YbL{!%CzUpp67fU1+@R=Ua?Tg9unvcZP$OR<`6?p)P$!)DXea^+)qn|cOs zQ~PV$cFQO7w%u?Kk=|zCYQuB6j5ce(4Ym2ZDnGSR+`3e@`EU)a)(_89dvwSwdYsWa zeC!Pw{Q;Chn;|s_C@;l5^*BI|2-f^L10DJ4;zh@d&He)Ov86R$o zlJVu6#I<>{@*_&DA6>-2B=g1jhqeMgr}BNyG2bml<%65V=kk|Qe@5S7aqnzALOv=V z3*flf$ZJNsyRl(LjScm1VDIz0 zh^rAhQ$u*(k+Y5t$%Ng%h|fEHcnDC^5t2kXOX%nw=-kmluh8`Lzik&wk<5mCYo3wi z%WGPB?HS^Vf-u$a3YW*7Y%D7{YL<~R1g5BpW#p)bBMEUn;Bbhw1R1Ah$~XB+Z4f3@ zd&sVK8zm3*cc~{EW94mUiig5gS5~EEIhaQrbkzN5R!y39tX5t5N}G5yTp?-8iS;>( zEv*MlD*eCBmT#XWzPK#R4cL}wP%!1dF`2U9ontj6ws$<209jmhHYZkhGQY*V9;Ht28He- z#)}kgZX9kKvlbLH+IHI!Tff~lhP`?CRu;p{ZZp)OM0H@21bPRCaRL~?F|nNPi}Pmr z3NNU?kwufshktySxc^Q{P+=7SS~jPoo?3%<YUHXpg1D+CSxn3A^W>B|l2~9YOF@+{0OH0iv@`2)Q(8>6k&tk5f*W_Z zdDJ~bX&&n)qS$bfVZ>R4)L7gHZlSmY+(N35&?ksvnw?051WnK!iFSfvBx#hGlQn|N z7j@8*oobPYdHQ05O5}?{(cIny+*O}OK?=;s!Hr58h@2?{Nx0EC0a5CXrP&FF3ZxSa zmm(p7F;~YI!C_BO92CqTItAt>7z8qtAh~WTz+aV_(eTO^g-k6bIli9|ZdBCVZ8gi4E`5@OvXoMafQEW%pY>SPPGR9y{|oe~~F z$`X0CMONw(F<=pGLU3W?n(zoI1mr4<%tAn{o(H29!5@97hZ=<#My*BNoU$cl6H2*O zkuuGB~Y+@Uc`dZ?;W z!#GW$RMpM1r6lr;779|JRnZJ%<80|or>Dc4Hl<5n-&`Ukx#IJ{xJ4s|aRvvW^qDG1 z3~efC7-wlt%JV}S$x9&=ojo-lS1ci06{2F=6+(1OfQwR9uAMT7jJha5*@P%y7~LKT zwh^F)zTLyR8b%KXk?L#}G>jcOn&kItMCIJ4`6;fS1X6n(kO9aT)FmKepQDgd5?2Bl zQb@)u(rZ{FhA~nqTkvQlR5Fa6tBiCgylc8xSHT807J{)v3^2~p#bYJJN##s zbS*FKDn855g#3Ig%#HN4_xkhm`v-zJ>H)8Hu{tqK@0myODi#MS;VuLjxs7(F&~C@R z_Q63qCwF*vUk5&rL~K`2JJ8X=K^&VsysDyNc~PGHr>v|5r+wsi4vwzEG5I5*v3y*P zn4jMbyao5I(>06v`5is@2ag?tqa&;6juz~o>kC2R2r|dXFKze^8!7t=JKD?<4No%# z14y;AJJdJO65Z3uU;@ zZfQ8eQRGm^=r)2;ie6M!Se#dc3(deYiSpAKva6QK!tWXw+F^x|92L{mv$Llw6>1i$)1N;u#hT~}4PxbID)mQR6=@jh3eps&CH(n~Fk$0JPhZH< z+W!2yupgv#Gp z+EyLfiJg)%4)HjOr_GWZAw;D$qj5XQ#_;PySK<0le}1)+qXOm$KXw$4Tg|vdv1(mS z)p|SKyf{?KP)TjqhN6A-b>q$peBT_JN*#3$b^DcdC;jZByDA$@Tx&xx3Wni0S|JR_ zp$cI*y1~RsTY7{O(N(HnjPd^4m^c1Yqeu+-32)hO$k#vNMLfD`^VbF(cb)5>j5lS2 zO7ZC5&0jTejJM{GaGDY7pC34e)r5yMf%U_)Hve2wKRXWn5*l7n8n@ks? z{;_A;aO58g8R`dpkiX}DZ8-AxJYmC;zvnYH9BDmg+3+&p^KCd@H^2`9Wi*APJGTg`TN0`%7{PPOBb~4<9rv%Vl(3j-7zJdn{g5Sj> z0U-5l^GU;p;nM^mN5aR^W(kKM5>EFwNILo*32o`ToK8ZdOXPHfQ#wgUItfuXNff`5 z6n_Zs zKnTLVlKw11_}N^dzryjqWBfJ7|H$}X7)QI8{Qp!q`5DO-UWVu!C7#X@ZC~Q>aS4|) zM4OTL$qcI*!fuidJ4lFrL&9!`XDhu$Kf@uVkJ!cWA7*?H~77<*) zcrN1wjIY9i1;qy#Kb`S281G;l_L231b|dQ-{xBQq4EWbVf+bjUA*lW2B0QoKz88xL zcKUr-7$6+wEhC8XQU26_NQn9;NRP%6LcWCS8A30K?_db|62F$=Z46;YNrzub_zFYx zLxj7gF@!xNUc+#hA?i`mZ)W%%hODpaeTBPWU*dD4PnB>r!yvd+31=E+<r#-euUxu44-27 zqJr^0hUjl7zxb65xt`;f{7l6vl(KnCOs4T7+%cqkb+5UholU~8yTWMqjX6RGyIo=$*UN$eUp0_hkp@& z@_P!VBr#mfFu)LgOMEG8pOjxR{x=0v(SK2V>L(cfoZ)X3oZiXs9ENOHnl(^5-=z$% zWB4jV)+?<+;b|XY_;rSlC^&=dFr$d^%NX9wkmbzGRrt&ShEFOui|c6?^UvaP&1QSe z{<7jr=l(5y596%ooGOLSVgH_UH{-7~}$M8V~=c9ulzWK`-)-r5ncm_lEllfdf^U;sVbdNIR zdY;eid;Xh>?oVX6gkc%OlNq)$t_MyyI_pzA7Qwc;inkh&+s5aF7JXD82?`dafO}KFAEKx^vud&$o*Ls_pe#( zzgg_RS?oVqoNw00Io)R%a=uwVV*C)pR}@^x{l!AgcVQaSvl*^rxQ5}W49{eE4#Qmx zFJQ=ivhX&>xnEm&FXKO8_#(q!GklHVpB2Ol7-^4e_WSIGj4x%loMA0Pwo7&wo z&$GEbXS02>zsT`-G5jV&wpTXWDf<;(A=f{lw2AyvrG9JLWyi_%jT-KJ)&n@O&3TZddu$jJGl5`pLhL@v9krj^Wb` zUstezlB3|){S&U~hp2v{;HNpCcwanMV5PnL}4dQHuD7VDVWB4M&Kd?O1vwY4# z8tT8y`E?rO84MRO-~S`;OW@`=Kt+E=Z~>Pe`g19`;Yxp^^8cQ@ zyk#3!+;h%7cX@Yv_aeVIJ=#_7wo3Or>7qR+Jf#!kn{v#`mYXMb zPiW;h3U)Hq19w3Aux3)u7X*y4sh*M8FplLbw{X~UG#s}hXiuyi#sT=F0>(neBp4qU z<^p=fN`_WW)BafNFb1%z6I)QlS@gTd$I7MDSP$+q-dDbRd~|B8yut_!(@E6EP|w)F z*3jghcu|Ex2%pau)3K7!i%20~3=~GJt#8ln_MKIGaK3W~VG<*WZ8C_kf1sKowE5cu zT_K~^S6yrDq_J01BkYJACERr zzct!6w13!NQI{$j?A6=L;{@C2J{)7J=-k-FgI)W_r}~W`ad9T44=Wg)ylx98pPa02 z+%en}+~>nl)`HxTc`{*GTymhx{hEY_=}1Q^C!(NXkxm;d7bStp$>@kNG-TjA&Iw-j z_Du{JqA;Og&{gtOu(U?plGhhd7p6}X6-8Uyacg*BUuAnyq$nIL3T$kvs3_XGvCZ!< zioh2N27~^h(2gP;a39%TQ}pIYbZgVrW&zd$Y;7y*q*L^RMZv~ET~Sx?yt<-rS1?jn z6vPdg`zo}y!JeX`E?jRFpO`Evf)$4bd-yVz*mH!7`zEpA*FSWCZ_c4oIU~TnYlR4K z;usQz4Lz|ToYn1E6SDwoOH*QW>rgjy$J2}orK)j}D8NN1D(RG9nKx!^($-wA>m@Gf z)G}v=7pZDN(bK6HGop*4$fKt$i!&@Bi`$7AKt;ByC`nJJjwUECE-<#LEU`(a&L(Ap z+@LBWt?b9ka16_81T4Ovgc3dJ2-Posv<>7{JtAh@SfgA=PPqNP(~9aohjPC7Nz z${IvSr$$l)D>o2n4$U#Wd{49n%D5*~19{vNs)0PFm49<=f<^4tRs(H3POJuU239sx z64J?M+47pPtvn|VX=J(~IqOp_J|A_$F=bRko96wM^4^qM^v>^YthsNU*TGlS3@EyA5oGotV| zur3AOKNHV$tUd)k34f74{>s;>XB!Q*r|j64^Dg!4-lKMOrsud92V>Br;{dSfrk~u@ z(;Xd;jZ9z<-Ehm)Nblqz?jG-U?zO{LjD27h8|tGQ5Q-+X07l2Hv3RU!kZ<%T@HDCI zeOgBLJhp@_)lbD2Qp@>L{Zf}lYpN*sVNbihf)(gAw9ZCIzE-z$ zB8Gr;A06{4oB_t`{Hel!;;bI&*FOmaF;;X~7fMEl?@XL@n=q&F2yp751mMx%gMXM) zQ4gk3`TiUY^EO%tKaz`|eg|C0)umilHsA{U)Fb)P{sFF^#Jey*LTk_Fqm0r9jPk?l zZoxl_s~#1Wz|Vbedi*>e2BT#BFkfPqn?dPmRzhuIiFBBMN{j9~(A}DZUqU)E*Ma8A zH0b^an~x=-OR(Sk9?(S7pnC|(|G`W;d?)0vOE%J>V~)^#WPa$EIq4SNg|*u|O)87W z8BV&~jes%tY(9$L05G=lmwO>#Dlb(2PRCD`Kg?(G@&|{WT#DxyS$}q4bhmD%VQxW$+`8$?quCOP0SfKNQ`{gNT7If8vO%jJ zsUO4qxLv=3=K(AIF!z^Azk-*b>oJ6@NAlAW^jnQ|(4HUjQFICV75bpxlO~m!zw9t@ zwtQRrcfd+N%-yHbZylwz2tV~Gxe5BMgIw(fMFdyTCFr;AFv1?iPd$>3VZPd~-x*f| zR{9a|6#09`%?NuQKlLcN3HlXJg5X+31Xs}|=!a!DO*>5ge^B*Hk9kd9`^tZYs~hxH1(e)}oUl%31qPodxb0fc4ar=Ar0 z?Vkhz>8Kt>m!RMNpCe5-D*ke(F7w z13%dnYd`9_hHQKYKS~F6jz})0i|T`&j%??{kLajRq3BxSx6?fenBo&%CVq-8k>8UD zQ~Zct(IxWxJHiw{lB4Kq;kU_sJK-sPBzHc3spyv4=oZXESA;O7AK6IpOGwAtqX^5# zkK`_#g>DGhqtda+MwgJ@cThP{bd(+?m--gA^uFT~8(p4_F2OGExDsK?E?Da``6Z;| z9hAQ+9V=#``!5v7VuVwA3sTcv_YA@mKUF^{T?ulp`;Co``iv^Q33S&JUhylPg%0K3 zq*MI}lAB<^>#KlMc2@86B>G*y31&YGT1u~aZzZ9-mCET+Nk@60(vcwdwx1(R$*r@| zEr*}#pL}kEUG#4%2(D@as135w-T4_blhk)tkD_B^4!ZjZ-=m1&ayn~f!(UxKdZyQ3 zRaaeK<@eWAc)dO^J>oxB$7*V7yxyu>P;mT(^WPF|Yhk()$2k@&zCzANXtNpL`HBC< zcw3+M`ORC#K7V-2*r#9q_~o~{vNqqqZqSZYYnR=M;n(f%{CO>Rt<#KK)}RCR#;+RL zEuYG{Ag6!joon^wcNp7pE;#5~qrdU1r{(4taKD-J#+6@K{@0v+2U}YDoBCT$ZyH@% zv-F(he?7Pe@I=$l(v?e#R<1m_wPm8Z|{}75uco zt-$1G-KGgl*5)HQx3OFGL%O!@P@@(-bh#Ee^vFTa!Dg-N;1vfS@nsc+o_guyo-e-i z`lVr|BMr-6&osQ+a@rbpi0OB8l7mmxK3@U+(jR33zXbSGfL{pw`sZ`%UM+yX?p3%4kGNJGK9bq^@uyB-!v=bU zt)E|R`j#f8ooAzUDcTL%5%=5f8Ms&QAgiO`x<&bSv$;)?poI6Hv`-9A#`Uh$LTI=T zKFQo6ZgA~2`l|bUv6_0HoM)uNRK>$1QcFthz-Gp@jD^_u50^itS;#z?@`-n=Z{E7Q zHO(=FFB$<4?>4v&yVwdH(;vj=|5qDhE>}LUkB$G^W@F9wDjpY~b6>BqOBUrWM29Jp zW$Kx(EO(YCDUK0zL%7c&!d67=_@^N zbzkMWTEC73^7iRQ-kT8SRpD@tL&FY%=D|STev8k!;M30eJR$43ysbH%uNz-e9S=Ca zx7FCmsN}*H_zH->v)vw4O8ostrbXXKi3wdnDfx*=7oV9J8wK!B^mx|7L;K3y8RS7{ z)Ag%9cnaOU_>VrD>uK_!6Xhx<4|-OvQ^*s9M<-7Q+QZ*dlpSvRe<6=JfY2C)?uDm= zJQxzWt|rgb@Jx~iombak^4tT@1LS!Cp4-XuId~eh(C1KF*ke%iQMgp<>PW}mLEsVc zVAsF?33zDwSAQpj>$xOcM^9LPGkMm4h}751;2}{uHpnp&rJoJY?G$ATX|0EOM08*E zYzmDb^#90n5q=fq*^l4pcnl)Xw>chqYU0<;)Hp+Z zkr#sz>e?@Q9JmVx#hES{C!XUI3^85DN_(h)l?L$Tc|Kzr(Zan;f;*yKa_ zi6_j%*=1&20RIO3 z&cP4dJo8+c@a1JJRlie~x-NzPR3JRe5|gM)jZ>G5eA40ceAguz`1huay!?}^!{10J zN_V~|$8`yLPK8z81dl?TDgv16EwEe0GK3-ulE+Qv8tU{cL`vTcF6+oZc^O^`E#TND z6N{KdT#QKlx{N%G1$aKAc(Q9W{ZeE-T#elYe-U>zy$=3j6km*dP=xhMmx|)X|38ZV zkBNA2>B~s{QZIKkc9n<+mx{kL9!N0r!R7H85Vwry2L2Hd4=&YwM?CgU@cNF%&V%zj zen+`i&jz!l+>0puq58(I(^!N%JkB;N4!kN3yz1d`?$hWiQuQb{B=0)>zJq#yp~;8) zB_rV{Gt~$h2a6jt7DluiI13gvIgnRrLS7M{ul?b(rHve zjXNb0YM(Pf`J9*2s6c6p1epr98rs@*jvyXhz1SATi6os z@p}E<3ZK8WkO$CmKLz-G8!Kuy`YHrA5^Zh**3U^euszrn33YZ5vcA5`SKr2ig3Vh@ zGV)tgRlZu2f*+h1-4!N5QzLY<3C`ESUSX3U9PMfjwX_(LMg>jaxZu%#+!ZwGt>Uy2 zF*G`|+ld*Q9G3{&2_QmyI$xwoDdw&A)%dC^Dmb?&j(`kCji&H6qp1^TqU1>J8p*_b5NI2ZYi^EMIgoI0`w4DY=nY0=+5RL;*NQ_Bp9&zHp&PXEChbU4* z41g@3nK?2+fv%=jqb6b~Vmq2x`0R$^#L?Dm?Ty~b8Tdd=RTAm|#i^`t8Y|q@*%E3C zCJJo{2BJ6$(`XH}we0BZYIa6ap+dgX_%dQM6iXTq+!+ma@Y329+!BgJgI&nrZ5>gm za3I_iF+v?cL+n<`Vsc<=xX11{O@~W@On+w>^(7Pu8dPm0HE_6CA<))l1R{}OSJXla z(zf9CV4Jic6{eOjXNPk>-Mo69&fl`|>S*WmdixwA4;TN?b=2~($;6elHp@DZP%p5FNlSF6;74=Qr$Po>U>IVrq%q*tST^6T)YKMgbW{nSzg}Z`23ZC9YEYHK?TT!v z#28IRWLrxMPT?`ULqiyg7)Ce%yH*rWmmMhaPJ7p^@gC6FsS+))HX84N67-@?X2sJb zkP(bD1*l2Dy%d}oVgbuFu*oYy%;h*cNa9mPB@L!h#b0F@ZJixk=;!5a2mRC78eE7G zZ3bhbIoQ+|@oM^7!ywaiL^M{WyfE4XXzGmiP=|K|zLwC~Bw&1Bz!8-dwKYIZ0fllx zsNy&Krfd7f1LgN21lM~~h?zP&iKOfY=>Z`pu+!_WK{$D}0qTb=6h1wbgaLT8MZH84_tB4%Ha`9At!`!~j!MU0n&> zWgJJT0j{c|zN)^awxYgzN@JJv5K0XfWoC-MuBxi0whC>2Wv#Eiy4qjkuZFOz8F(9Q zK@=6c`3_m=1S`JH3Q2CvYb=5^ZTb!?hDbIy?R6Gbrd?Y2dMiL0z;5UptWeVk!uCzY z$?bg;x0q=IW%iqGXs7YtWeZ7`1-ID3O&yMx5qEICTg-g0mp|mwoo2AikA(2|nBmED z9$&^kFO5)aH2E^dKbweIedhz$>hcITsTT9VH$&Sh2%g29JOM;x077%nZdqC6&#N z+0@#aCe`i?4WR^l-J}O2ThpARP;>exxnwTD86jCqFvX*Mm#JPJHHEg+ea{MTChs{G z32iX~(a!czQ?i!zhmLT>wU?BiBJh0lIe@kqM*kJt(bO8?7S{Bm3Ls9VRA=rV~6SbH@BO$)?B6GUOPicOW*dxpmLP0JaKi@=$WDMOd8> zH_I|dM3OqwM5t&MhDJv2EDN?6g%MO|(0w@9usSb6C=dkR#_BnUazNm{Y$FGe{RH06 z8oc2tGwws|Yyry1kF#?GEMq^*HVarre}M%!H{75Sn=s{XvEfWDT5U*EmyiujCWc8bh-pjUGD9Q3(w%x*+YVNRbrj|RU5R2cl>;fB3 zGQ`aXHl(TI8*E5Z!#8p<7|Y6>iVGrzc$W2Z0$k!M^X{V6Jnt0Z1-56kD1tQT$1ZdH zX!c^dAO=V1 z%La`#P`5b{MVl;x=+@xDUK_>PhSAZ9Z#gi$qfT#Mymx3~EZ$p;Tb$#QQ{y9OW&-Ha zM}o~HM}3-$kwEd(M7)oB{5UOiM=-E8F?fGGwugc->9DOM&=%U#5p3o|gG!7<(8iV) zV=yrm>)nI-1uE2JZf|J`!YJ0cNScU4#0ipPLws67lEN5t2r5@l@Wb4S!Xf!x+nS=_ zAVuNRHQei_u|K1s>*x$4U}SVmW3K?*(GmiCOZgzX)O_e~AOalg*^_+WgzxTFEt!HJ$?-*gN2C!@I3yMF**dV7m~ z+mPbBz_j`JO#9}<^nPO6eq2rahUcQ`r@<5-{~(3tO%P&k4KV=gDTSWY1H z2x|=wxY#>Y)WGqgaso5zQ5U;QMV&rg)SX0NM*W1FeON^eN5Zq}8y+9+#nIom9=&%@ zm`Y-N++?)rZ*KMwO_Pw#I3r=N$D67hJ8V7sJBWMwxFWykg2g0Nd$qPo-(H*Yn)?9io{Nq}3B5zb$RjY-12)M1zzi?iLd$?LD#R^q*cw3;EA z7(*!LFV)(CeCMKoh$Y!-bHDaA#|#Y-eF()K=RUK zD+6S2Iab25*zD!U;`;Acazy`jEz+|NzcZ-poPx%7a-8mHpm}aIz0}W5I?tU?K{%-e z`D%7esmnGwfWzXErz@$0+l3pv%z5F{kjrvj7=32p#dL9P$F?@CgVm9PIRieO|60ej zlmd~JR$c#)%&RoVwUWh2%QskV3z_uqqkO*XpoTmo#62bqqDod&iX@MsZ<`E?+3* zBLob7S_9jIT#4q+ZH;Ywji*+z4`aD1J?7{aO-$05qd~=O2?uvJ1;ZFMn1#=wjv1p> z#h5Yh3OPeiI$NNP8kTihsdq3=md*jRQEgEzjwX2IFST2 zdtjgfvr24WL95@~Q~a&UwgV)E^;taaO#ps^h* zgJ_}qhel(Qxa=Hv?1ef)QS=ZX|7DY;4J3RXq;GVpXDFUXcntGtB3>$1|Hp8FpBFCz zbFRzRZ`8Il@e`}a9)D*%F}M)0qmx$m{$av0PqEZ{g|1YFnB(EbBb z`+r$>_L`+|H3}uQ2eWCOKn;aICKW!(^+?nrk&}{jzpXl{R?9(Pg+s5;L9dY*e*w&1 zsa3nk$rB2dU;u7kA#OO_gQ^(j1yw6BYeTDIB=S^j!1n84I|aTtkTTx)uPCr|j3Pa< z@><~R*>2JCmdgZ@gb#RVZ33H@(>IKa;INCu1U$dtp*9rVk+x=kaX+T#WEaQwR`&MO z>eG<@MNPw}Z`opoi~Gx>X-6*eMv1`@i$TR4M3;%~rFc(+kN%qsD+!wZTN@PC^xs)v zg{I#(-|D4`K7SkUpEu4J*QGar6X#sR z62}3Yjt>M5VHtHvSdeqXjaW#{#WlQl?BxT1`1trhY@`nh3A?fQ^fY4)@73A$> zh)zSl#t;KnbssW}Y1`ZmkW6cMN@q7E#!wM%Ocvpwi`{NTpjVM1Ps;zJG<|4l1ad{4 zl=)v=>;o1xy~tGar=oEoA~6RN64PxMxbs}QS8MnJO+1=HZEO@5E*xCorsndZn|;dS zg4WQ~J!wks@vzT2$Q{CBG#Sii(a7#lbz18BBM){Sn7WE)b~Zs2H7=5QO9uN|V$|aZ zl`%2*_$?JvHApIE(!{--!JbNppy-okxlb^r2+s^biPN$z&gM74?pe9Uy%jJd@=k@%~sA`;2RiisEE1#5nVw#C$)CeZsS* zKh`s0r|)-^G|DRiMl_l0qVG`IqOm9SaL8L(?yvG!*H_eFmtS3dZ9U4%(>iT_ z63RpanC~!X*NnFs=i0GnY+(>P-S%@5SZEWi&ELwPdm5b{4rXLuX7-HLdK(^%tctijOy7dl_! zt)dLTqG2S|-i$?H+E-2+&iQ(+{|0GzYinb)7+d81W%yS?|M2a4F*?%}i!52fLrc7v zC`Shs=}~x5@>=lF?0G_j3LZglbHpKf(bt7Zo)Q{F8&6aNi(4`c&OY0lL<5pe@k*#? z`7_c0djR&<7Vqzy!vcg!k$&QpnErht^>sbjhyi8 zt*In`jPtHU3NRz6kkj5$Z0-ien*YIEc!?JV2BpRx;=&?RH~{_xg>6V**yp*h^d!kd zas5-P|D~k1vMjaUVJbUM%LI=kHG#!rLmE6Do0&3;LCW~He0Zw1t#gMVK3_N=n|JUf zPmsQVKs)(tlAxWTC_;W*8^Tt}&W^TSm=8`7`}x^uI2-Ym!<~GLbi<4>l34pP_g}oG zr7-$*!WvCkrvOuzM;$LsYDgMd08@JhD>utE7P+3P6tb~AX(OzYvZ=%Eo-sTNld`lK zYidHvt+*Tek38YMwHStBO9^Lm(vYTB?1V-*ydzjtk$}Ro9o?S39H5`qNiFNi6KJG3U!#;#bblusgzQ$cJ z)-)RL?}t_dW@&}F+Ou5Q{=sp)H=*)KZ`{~hi||eC^I4wKM_jY9e8kBTAZK|r2}^w8 zos041qu_aqdlsJhG6zorInQHBcvkws^MBd5!Slsgd0yn?36OZQ{Fyxaaiv49Udw&} zo=Zd|Ftv(91AB&jbL8=aVp3=H(-`X+AtSxVQinnCiNxT3?eb7v zXl|<_shLxgmw6q#axv;(&Rm$&>+5)$$ORkNmywjamjCA^#g;1~DaY7zNXk1`%q&e-i?UF3a2>W@ z=%p5=hc_~4vUX1nsCFY;!;;O>!rXf9(JyuaJMejEV_ZRMge_CY9r@brJB^33A*r6sBo0iLoba4a9UEERnbp1<_rnU%?$cg{F_3A{g7 zm|xJL*k}bEJ(gwk0aG6MO7cXc_>XRfiC(0Ar*E^Zm zF6DfiU7hPGeGEP1bd=GK@!D$kfvA`yC?iUfROT_8GE2T8tiJeAVeW#gBnt7~<&q27 zr=igIi_%nx203OPh)$VPA?l`?*2&#rQz-WWq0pjl7Us^oHJL)xbT0V~`(G&Zg|*oQ z?L52CXlRLZDHyk!vnQfkhygU8S^<>XUOH+pI z1W6e@6K0h`)id{}?5Y)>(ksqLR|aYfEURPynl&A~Xy*mljgawc$PfqYaa)aH?`Yil z?n>8QV(2tFG}B~x_p`fJdP=`nJO@#;nk~5~vfR?8?0$&)O37SA&1Su%qPPKA@fjw}@?&xkJp_KWY3|Y&*?p@# zr8lonocVDGl^sD-s8t{=?!CAL7!oR?R{7@1I>lh$f`q@GBncB3Psc}-3i=BBJ_P+w z*{n(76G2vuB~X^_*^@#OM9WIqPa)we8xkcrXH-Qapo~RrkgfKhIOAK~#71D*we0X| zp3*zYXXPx*u;QFh_h)jZ0=(>(>>J?xm*a32Mb_kOWiYi|GdS~%J#{mC2ArQiGqJoT zv&J69nwz6wY@Z#LQznDSMDaHA)Z5vo3OuFX^vxxL$R z^AFiWr+Z4@TDdgwWo4WAPf|=dXPP_2OViP$pyMk?Y(sWoJad*;vtL2jA7>LLvqojQ z$Qeoobt=*oM%lCcUUs|JQ~L9&{M0F%-DU;xk@)!T1Hyti1=E;8rAa*5aiio>2Q0y$ zD;BeFL+rsC?<`_bylg8ev!@ZwYfiy9dIV!~_K3)rn!1r$^0{v0TO~@;Ox<{|X~k9S z^3|TwJ8Ne#iJY%e_7|0q+doNWL$^f^-H1HL(hX6T3fofpM`E8s!LK3 zQD7(Ip^?7$wCV|?XJG4c*lo$H7fw-Vjt|8SC~}k=R2qTGT~$m)l+UKE;@vrFxF*J8 zIQ};wFIRqvUA4wj`f&YRbxNAQ$JZ&PHaz!Mb+MbE%{MmAQJdsB`dYN1{95%qdoQ&4 zLBm|NNwSJqkVbx`whiWNPa9zmtnoB_WE1Z(ZRc3;LNgwBE;XZU65sg{yhutN#Qp}qNkyx7K*+uk&BU(|e zzN~LzlDlJFRuf`v2j$ePdvpqeSM6B$WPErGYZ<)S?7|s6s>Z=DakT3WGf#4@Lu>fs zIqdfi9VmrLhof8v_K47dJ(7kFM^8Y9uWn}V^Q^-Lt4IJJlp`G?JH$uj4zppssT;4W z_Lyi$R&|fWceg`HQh1e0qt z(i;9Jz<$QL;Tx{k&h6et_GhIV-FqQyJqP8qhF>z`%7HLjb39aF$E$m<>m4o(efjLCGWedAD6PpvMc8CP8;+0~RtQ@QCRgMbg zDzsJK+``_?BO$NTj`a3ccCS#dEg(hh67|ojhXS6M8n*3{7By09c(Rp!+>D>fF0(Os zM~Hn%GDvOM*%*8~#GX_dw8ywY|M9kfKy@W38HL94b`z zwXt8XEu|MAZ9|~(4E4~9a@Vbk;GKuN9!6}10+PkNvU*>Fjpru~pK50h+t`?|_;sJ+Z0IFuXLB@>%~4`=(Wbw& zvyYsymbAf##p8S8B0ZFh5bmrdr-xqT7mbBtLzpX*{+>AY!DySF>|l>MBJRFKAd@lArszQ5}=JC$FxoF=w#OxbDai9_9f9vDnh!E9#TD}8uU8a z$v!xPflW8bfb^3LNJU~m>S;=yWV(GW%>E`=qwBuMZmpzR^+~Pv!e#mR=#~08h-v{+uZpUllIO0FfsrEp-jIN7)Odyuv#7rC3$BbcLw8 zj@~rYTs{o%7Gv;kvA?GK03VTeA3*V7`Q7%dHnK0bs@vLcLv{XvhIemc_pax4-l>6A z`%&`59vw1^de5jGKK6=?_5ezu&X5}9h*H`=j(r;(VfCL^p&{SSew0+O*jmF zv0+BM8`@BSv!2^eRGrwF8pn8t_d0qw5qAF~ylnf#I9!g0k0W_6p=W5ccTa?t&{X%o zd%xtui8a1zzN#>{EWGJm=d)|d9jajoSH5?OFs+bOvsK08AWEs&s$wxX;x5hyoQO*; zfySwsd?jC~4aBT!kK5Jmrs(mJJ~6V9Lcx@yCuGX-Pxb4q+G5D?!FNU3@PW~=?yJ73t zb>mnF{xazIiI+mZU&4L?n;VC_r>zOaRow^dfUVu`p2prhd@GCB%K_8ZBUtsIlLUMZ zUgPB81&)s8lHAO!!d%~58XoFl->K#=n#43&uNr@i=x9=!v}2AmQEyYt%J5z%UNF;E z3xB}!(z}oXd6!MSgs@A1kmDgawb83Q=KFA2_lUWrdKcb}nem1fdfA;d$yGLAQvMfG zt30D;3#~}Gqe40JMa7i^(n^CZIjL1_V_?B&3JHF>Ja70mO zm-ZGbq%GL71?Mmc{F^PjI2=8MdrP8Ct=gql08aD4i9p&V7AAr(Gq<$`y0kZ0xM&bx zjkW|rZ8#AN7bVGuzKO+fir?!@mnv1`yI9w0_oM-FBLD>=xKd})cuFlZ3-y>8OZFlY?(ob+Rf!1ULUU#tI&hy5XGIx*Ct z%NPG6(u>swGre`TG}hbv^v*$o)zhZF)7Kvc>L)2O8WUxYB?+?IMlz&oQOj0qXD&v? zSPj618;(y2;hG?Kk+xvL*$Z4*n&uJr3*~vN8-_BRC{4?>5IGsRd))$Yv%3W}A!05g ziuraVAr>fvqR6%*G;N^*iFlC$G;Oi+TD)^C6cI03r%{S>-AI}%Yrz6snM7XlEG@=O zNvjZe3im9;4M__SB<@Z+b%7>4`Gmv4>4>1MP~m=*-IaoZysHRLp3@d+|Z#b2Zo0a;L}xhpfMrJUG#k939-w;2tEaIEM$6 zW) zlLyUqIbv>H+_1QQu`BDG?9eh{n;IutAZsn;7D-oUp+s~qq}Dr;gxYAKwk#t=gM|(` z9OPKLg&?rw6ogYz>Ld^D+E~U*sK`=HJ5PX=)m^7@PE;-;;8 z00@tcvOh;i?d4tw>LU+{iIYdu`aRs)O%7G`0gu#G(*~s%u`Uu`P1~b_iT{uSgydmG zPhlg(km}=;-UMJ=0IQafUK0wyEs@o{22V9WCENyimX;5N_b*{< zv+_KeHoZxDU}*lF=%>bb6=1$*kN1MAzRK#piZ^Hqv0(!y@FoXiL*5M=Mn(-BOM&HI z%wkN?dh`^QY;o`s?o8l;yJ-gt?TQ?Zjg8THx)TS6d+;G8Li+||0H?;ra4^usS@rdm z{xbfrrlty~f^6s=n>q`}=}*R|H{jC44IBCaM@IW6>H5SC8+r!u55tqOsmZhGE*I>y z8;*nHB!uIHm~MQpjhMr}o^JDvhLL^wC}QpFj}MRb#n0*=9q*0L*Fq!U;f0Zg<0F$3 z8<8QnmaVFHLnZ3w30~#`k+|?e7_PUU8;)QkIo>n1o7@yh_t*F;%KW(a3^Zw^pU#>+ z>r9^b{iEZ1EFYpHWBLa74fe&oly3(Ac!gWw#FG_p-oY+FGf}+=w(TK) z5v4q^{487x>fO*R_y~`A5|AClu&fKWEjG0Vo3`5V=7pe~hlpys4ixokxF2_8;5+E} zT=J-Qyx%LVoAwwg%dNtZ8jJ$m-#fN<`2Trft_#OXaE?p z=bJVFjQ7vH7i{!+-^_c`1}_2pNd*Hy`sQ5?7*REME>F+A3v4jbGjFv?uWOho$@(7~ z4BfKsvB5sT7uw*JfK7du=-TPX0^C3?9>8k=zuyM02RvYdPX%0NgU`Sy|79Bt`5BMd zV93vSrwxYu3`!4wg#3(B8w~lLf7oEi_k7z1L%!#38w~lLH`rjjdpt;!c)3!C-@0$90mG9!1##=Fm!YM(gveL zewz)({TDiR28ajpkheN)WWpsV3O};J=ti>l*xdr1iuaNgEIW9@bd>SJ@@ke_$Oha<&T6X6eD=eQEmuN zb51m#LqaEV(LlWLA;VB7UEa5jx_$mosBkaYllP=mL zp1ya>@H-^@UJ1Wn!uLz~0SP}S;m=CTX{Ij zF^5r(IgEUv@~0zTxVuf_-+(z3!p9_hk%UJid?_YPDEu-B<2}pa+a-Ljgzpou)+P8; z`Co>3W<9tZ6AA<)|7z^`hcH<|@aHjQLN4k9@u&8TyC~n}(ombbNEdgvO80!}?vXC| z^YC{`7kY6R`N>_>JMR8ex~~XVpD*1~=?0}cA>DUK_fF}4PP$TG{Z#?GP@jmut4z9^ zrHgXU@fST92YC%-moH*YiCoy1w>zIi(?#%S&}7;1mt&rW zVA!M9jz5Tb9)hpLT$IGGwTFKM^GO7M46|9}J}>onNw^Fs(vRgx_gv||N4hBI6s{}# zp&oMho5H0bI!|Anbf={IE$RM5xbD@`#e0J2-3O$5jdUeF^#dq8LzdHwpGg?)BjGdA zPH{IZU73HG4@mg`gqtPvKPxKXe(Anhx@Z@OPu6#&i~3IRyj3V4CE|ALJYZj)}Gbnlfe+B4#p?UC-O(nWjD z@x#)+Lb^wUyHMI;;VKDtN*DbDins7l>Hbr=i_Vg+wC|!p38Q=w{i44Kckx2$u9I#+ zx+u3qw^-U|@sB0^SK;O?k?!@<{hoAxF5D$}k5K$2d!;MwN^KnBbKfdm*>2^&AYrLj zUb}$v-YDHqNcS<}E|qpz>X-1<(!EoAp|8zZ33h(w?VDJDhfj#NQy@FAMi{G!P{J^fRT~BHb?Oo-bWlPEMEkb2{2F z9`75{mHB+Stly{qR^Ywa(k+p0jdahJZdAHbj<-j`vK{x{E8!1GSK8D26$$@Ax-U!j zRpGAAk#4ng(GMbhSIhiaE#%JN$%%TJ+{TX>y}ceiw<+`=a$d_=lG7490@UaXOF*W^ijk#sjn zw^6$1O7{Zk?v?I->App}vYf2BPr|ZYTk|Oie@(hSlJ3u>`=WIJC|oS)aC;QVa$mGY z!t145Dcu(7O1l*GNq9)QvYZ#m`dlRKQ}h8D{(y8pEnR7^B59|hUrGG$r7O$J+W7)r zyIQ(uNLSW}wVNfpL%MH}Zd|(iq$~4n?adOFdaae^XRXY~wX*!I{f?yjg>Xxy9;LG0 zmA+HrzbV}HGJn_0^1J>DiI?@gEJMI$1=5xFEjvrXTcs=cmmQL@v}4($68^4qWqy|Z zS-=}~>B@Swp;^M+(v|tM;W7!|B;9+Y`;2sdE!=X+r(D{-yjWrUp1DrCGW}=vNLaQjXUckarnK{!@0H;n6)tu^@p9`sTe{~8*S|!% zE2Jyw{L+5@Z%O>mg~I7^e$J7y5BHB3)@W)+hN4OFZ=9bSOXEMLp;4OVWKs(Cb+O)|W~6bmL~F4+O&o^s3rmzyVvPiW;hqINRY19w3AutrnP z7a)wWsh*M8Fpdi>w{X}BH5|7iXs@mv#=-of0>;A1Bp4qU<^p=f%86D^%M4gsF$S>P z6kB7(8Tq@%$I7MDSP$-5-dDbRd~|B8yut_!(+SzeP|w)F*3jghcu|Ex2%pau)3I{V zi%7ftF;E!O;mV0!6UOh{wxRvQSe{B14fg8o z<#B>-bWe{lRdjCb;=!){<5T@ckhnOL(uWljPF}Z#lTS`oH|`kj3GVaZh;2dc$UK=a zEM_^-<$g`V!*tXnl@n3Wuqa4HX5YksAqoxrbd^07AgvL%^z{YQh3ykXMbXxF+*%&k zSJ_?^DGCRR0vp>ZDvEY)Z1ekzBJhQR!Jxk=w4(?I>_@iO6umhT-P*LZS%9?wTic2{ z=@kE9QLr&kSJV|eudXQE6^zss1#v^?z6z~vu&1b~3)gGKCnk%EV6CCS9=<##c0A$Y zz)375_75H48-b|w%?PmXh9Lr+c!oq_^H6Naz-NerQfqA%U~Q;MjBXt&XYRL}QE^mt zEfNK_2t^{Dk}C7SjBQt~yqCD7Q=6O_TcnCVMNg;v&xkIH9FLx|%+0WXELJCG02SG) ziahOU)Wrnl#RbY%)g(6Q)Xk)9kQ-E0iAOqhHGv1^rBxczY2=bHP~~*ag@IlTCt4C@ z+!HDWJg$}OIaC53^Mnh4h@H?d&oTFHJWed@IfE0OCkJtDdAD=>9X^2U1GCsrA6=eMG^t_mt!;_LV?Bd>;9lTqQak>%jO=-A30tb4 zijS+7GaBjUxwNK=av%1&>nm7+PN-}IwPQ%=rgKm=;?*l6yN&-EYYv6Po01f6C80HVmMZY#v2j#pKGsX`oXJna+^L-|@2`N@%%sx?fWthRdT7mt?>WO*5qhm4anL2`S2~2y!!zmFg}~YDx1MxT`eD8{m453tA?y%- z>PeyBda_9x<*zIsbpNH8!BzIFgx{tg&Gl1Pm@jh}i_=r{d5 z2*wluZy_RI=;74-FulOa><=f~eek!_Rgem>z+vpO~aV^2bljLH3%H)?w zHzwa(L`P*z$xTS_^#cea{fTaojgI;Zw)9>PekL82OT{li?)B3MQ~I4c3*8MUW|U@< zyD~N14WC7r;-|_z>AMp@n|?POvC)z4DfGMHsEv;5VhXw&5oF3$?_ZLeV3!+7H^Ngo z%J56Y&kJ=ABb?}b_@$t`{dw3$@vE}YCCI&l(xK?Ezry6V9DWym^10(Bl!H$y2(GHz zl!rFDyWWRlLiI;IijIvr=sx@*5X2M_Tuygpm9MJSYd!v|y6XBWzrUu!>-BN8_>UE$ znwlD~x2n=t4F}JK^WPF|Yhk()$2k@&zCz9&7jnhO8u<1UEllU>9!@G&8ZPdZGct92 z_QtL+W^ih-x>^zI#dq&~28T|*6c3M#nnmSeGhp0U&XZ${~7~%7hmal ztNSX~)%ta^5I!mEs=O6f&Kf1Fs5EP7FZZvZo(7yBEo$s!R8*cuwo0bQgGzj#5Q3O<@Pxjx$kU? zoJX>xng67rXooQ3qc-kbv`{CBuO?bM4|7#!u#7y9D`Oe_my&PU=8U|IJXc0W2#_bE z5dT?5q0Ta-E~J*Oc`ns%x#bq_#l8kjzmz%__Q$QU^8iz=JlpoElO)O3SXfarOj%_CEQ-?y=%W}~k{U?b7yCSd)Xgah&eQ9{<&SNZDO zcu=r;i%CX)i>k_3Yf|vTe4@L;Bxq`cPTR(}+}I~#5`?2&&7qbSL(-_A2^?WJ+K=<= zC%sjiRw9N*M|L|gW0T_&Vf)%tXiwj=HYvrt)xH{ERYe8o7R9kd!Kl#`-exp);``g3 z2EGaxkz`N{f+C$QQTjmqH~|SC(t7bBEriGqX(=we)~B=%gyUmcM~L}3tphtFiAW!~ zOAXP`Sw1s!WP$=+O|3>v#8AX`G_mm64a13}t=rlgy_GZYftso$)B%c9S>ZHRxT~`z z)D}z>+7b*zaXgdJ8fa_T(b?7PjHE(^d`dscs>m=E)C|Rv1_XCTgB|>{=C0tDPz2Y= zBZIefM5V%ka8twx(e3gOyH&E79GDvJvHMNa;oy4HFD|H$1bMZQ)WG4e-#}ZN5r{;B zT~P}iY7c?5Ex0|{CM`&XsU^(W;p{2VzgnZl&CH7$`<=uWm8!*X>7|#46%1F_+AQk? z9K9TeHi&aQBrVaMf*6Hcgafc`Me%gmffDbucg-5_0gat1(E@9u@g69_ z&PkJ5@pK7f1S3rWY8G%_GG~TZz;X?2@=6eMIlfhw_*79zgQ-;UR~bfIXU7)$d3pOm z|1`D+2Q^2V!PsaHHnl~(n!eUB$TS@hjg=`cj5Yz9I-@<*;oX4UavGZijD2SuQCU%2 z1Jo2yC@X|2ezR}7wqHC@ejh?`?G%NWsk4(v%6^a@5OM-Lz5WWcpchLqfJq84Z<11g zsqk0TR@GJ3Q~`a76alm)qQ0V{va+_qS6Ne6T~%9KUFWNXh_{d-krv`mU9GW$j1ZI< zU}~zXD}lR=<0v)2RaMki)z{Qk)K^bw>~bDLso|o`O!3!MRn^p1q1~^n_0?Bb`)mBw z5Oy^KZ`1)46}$NkS?B~SzRe0rZp>>ef;4UV4l9O8HaG2c7FMQRTKIY^KpMbq=o_q1 z(+I-$O~uLWeG|8sX#-{Un{8;P@!w?&NtOk-*uqU6j+YU4aJ^g1e6W{4i+?>)-dMmZtgW%nnRw_Z@wi!m9p*B41OyOwp$QIN zqZp{9ve_}4T3gek+MS^xlz^|B^k8Ibnv)c2PX8pA%mp|jBx?z#c$Dul)zhP<(3ZOI zSpm-EJ;x%UEk+>P*&b?2*0TQ45stX_lJZjoo{xS9&^E*9zhXO@S_9m|ntoIPWX#_w z0NSA|^m_$@fovE5#CAaKWSab0h9v0l3R$(zXrh-Eej58bAyAks%s&W&T(dC$Bn*lS z$5_odML(!hQcQ;Yod@(~9Br{x_{%xoVy^I4aJ(hLES4nWDjgyyW2Jnv=bwM@KoEEvtLGrf0fG0jjT}Vw z6L>#s@P?<%xDTPhSAZ94S^WqQKuKT{|-%z#e0i!yI_2BYJ3FE zOaNW_NU)jYs82R95-6UUi1$&CAE#682nMz$2Jer@_E0b;9=3G^+Cp18g3WwrP>GQU z+St-!3?{~6y?ZdnK!uvj?JX@q7{xjlNfU91I6-o3h)+#OQW%2{-Qo%gewb5HI3&Mo zTT>Jqq$q4@#(g6i`!gE4j?ORwMn=ap_6ooqEg^vW`v*04g^NJ4L|moxx7IMGw=n{MI$WE7Wr_YdGp zA8)a58&Z51m^L4uY2Tcf-cL;1kE?0l@LV+gG?-!sDN=~fUo`e(0z111939u#uK+e~ z4M&Uj#fGNhly~^{E4F8B6nQLh8oSm_L$>n~*gJHw`JQR!?}UaK?-?=4ivN81LLQ5j zeDQ)-JzP)7cZ-~DPK@YW^Ehd*l#?>M-0)AvMo|5C$0sot(h=?IY~$fq@?(0|iq8*m-qkCX#kAxR8~&){AZRH$6pmm&0GE?o zEGH0pgtdkTTP{jsqkh88KCGgKBjH)~4UdoZ;;2c? zSoiJ;Q%S^Eii**uzq#2%G)+P_v1eJ*dCkMV_D_0O!iBqhRHyv zGBz$~MM(-vNZGUD@l5t-S3Meq#!yts6!CbAV7oj)#OTIi0a%tl zeg*iQ?szvgb+(5wUD-viN7pLd?J9K16XLJs_5WbH?MOO3P_IE29l@?p6LO+Z zceBmZfAPsaj9P1G57300x0+sd=u*ri!0mhp=P$#?B;j7_FwBg_*>2k8_1A1G@m@k& z&5%rtAr$kMYW+aIbJ5G7r32o(@om#wdsPXdy@ix#mm=BDm8KN$qBP5p`AKl{(qk(F zWN)?7^zd=YkHz)hvE+!dvli*0wZk*0?3{wec5GFE~g?W3l>Qe~7kuqb`y z#d8Le@hNi#Iie;C>=X6A<78Ns4Cm{0SguQ&ufRHn8tA>_h-ss^Fh+;{7V;4S20yKV z?O3+KN$i4eq7AKN`W)Dmi zO37i|z|0%&c2Nr}KW3`hXzb^vANBMF00XfJd@4UUG&wjz3^DokSJt|1OVHSk)j_n- z{X?U%NnFB-yI(>bp(uI?kpHqt(gqSf57IX})iV@NBs_-sG!ZWqtN&xTSjLMNfjQUZ z>o;m!n)rzYWRJfyo)}zI)6q!<;vXg~^AyXySLjM*h)J%=H(mW>xC(P(VzB=Jw_LGU z(DI|Sk#)zOKj4i>5c z?rFj)1g+0JLkMY|ptraZsPA$bG6$^|{h1TAb#7_&d5bqVmbLz3265wgebaT^UOtlk zvTJYxr?%q)yY$nkVmMN%kRpw*g6(b${Ls@DON_>}oh}h7-A{FA`4P?vQ zQjsbeQgIVffiEKGlC>aD$XCGt-0lE39I-#~udqczj+!MFwMrF)G;-982JJr}wf~o8 zXRlcbSEEo;doY{k3Di*dV^ZOhT#rO85;-YZ_uHzIYPB2$Ryg$f9P}EA@fX1Cm0Gon zoIIgW2?pTy72<|3N2!WoUQo3Hvo^FUMj}te25i3$wo~AX1Bv2&|B3=j$LP=_E3XC4 zp6wPLZ@EkmN%(+=)+TVwO!|hA5gc~0n1JUuJk*AwJJQzdFYd?mob2M*-pby7T74R_ zzo=>W^etP=aB+WGH0{V`-Y79RVlk+ggXl8Ry%g_h@X>#hVI@J+e`|xnn*KWrtkCrP z=3Bi~(dTdD{qx2d*+i4qG~ z2@6tTPR9oVhp>#gBrM1|;zlf_=Hha=JNEJcKzw|BAU4v6g@oN$e0rL(hWG01dUl3t zK18RXUt@@YD2W=1)cALPTN?*e0rwLe^~&D8547l-%>GEgQQ|6P29^F?5TtZiau#Z-kr(*sITOAI}_cF!q(2>cO#156PfH~ zeFdlEi9VF9oE`$+*9gJ-gQB;Fs(VxMuXQBj=ig&1evlbG*ku}^r` z^v8N8?DYMPk_I~YuqL(Rkbn94{Ta0qbiYfijTqI-QHSb}gNmJ}$aswc;-C#d1Rqtf ztvL5nz+aLC0Iy?Zk^17|%}xjmL`?+2_n0t$DHAjOM@}42E;0FIn8gIBErLp-h-kma zYWVJ!nF;R`%JxL@iULTE`%GbCc=M|4UPr=w}bmOy)`ZI@TmzmOO~b3LrP+^#R;l2Z1B-W+U;28{D6{TSd)U(iFEeK5ff0R&$`*}1sfR<}%5r~|zq-Dn2D|*~>TBy!UY^!z z^OH~}8o+#qLAz$W)i^YTJ!1=lSR>LJYKdZ$h)aUJeiHv(JAuDi5%_Bq!S{5z+(a|# zi7e{D;rqH2ip5r%Z==-trul)2m<9MjVkl2$9YX#G=?rhf)>{z|aT;rUjWrmW|3c?W zyj7F|STu};+MBTmOnb{|(>Y%cR?D^;d#_7m(6)}GYtbWWHToV&XU@ntCRk!a`(pF2-eM<9uD(sY+=njW9(hB0OeBp!Ky#R7ERJh*e_7c-*Cu*4fe$37RoV zXGF22JRzmjR4M+Y#jpwOKJX?e^xq&2Z*6Ui7Gu}7zYPB>=wBt0g3dI>B1@L=&=M~u z%F#hZdK6xiycRq(d!7)Xf=3YC9C3(V^mSp9r-TO4#uL@R;+9N(SW2=yb|hJ z{){xh9)P{I#ru3^`}}45D$4fFumE9Fq@Q>trhlJEeO*#>Q8(YI>^?u|?ys3auS}Id z4-U|#qAG!2P!oS7?7`Y$ER6+vdyUG9Y2@Rcczg^_S8=S2@8*tq&+-=UMTMWFkrST1 zHI?L#ao&|k0cHdha@t#p&E3FQ^FNpiFY&^_pw!qyTv%iZ2Y{ZSunp-8`#cwxo+Ozl zu77Ivzm(KgmZjD^Ol9Y3nc$J6Ca`#HNQ1{?GgD?UNEzRj4^P#$b?z|4Ck*Ff^G;`n zfjhZ_U1%qtO%k*-6h+97YeU#7+1b&y3-iG#Vn06{4QC_1bhwj`k#3kVMiOgZ=KhP< zv=m04PgtWV>vTBk@~C46NexLui*ag=rE;@eW0C8rN+BD|lQzOSDVsXn?is_gFeyu$ zv8E=p+={!g|Hu>GTZ>^B*2J|}*+Exs7*{q5m@Q;)b>)S5HRr43tFR#nFjaL9uV>c- z<|8|5>(PDxB)i$QL}28OwTIbluH4e!>)8b(Q^V2Nm{?~I>1(utG3-N_MAw~->TBEu z{7&zFXhmR_R+y_j%a!dP9LIYTDv$KyvTWQ$%{H;mXL(8=am~i^5hqK4oaNCZEd98( z8{^AI!SfdPEIjpP4xR*Zp2w2#tn`ED|FUm`=ZmxQyvWHDAn|1RGkNw`R^Sw}TJ{6* zeA<&k=7jxr<4A3ubq<3jNqxcC=)`1XV6b0iwZ0}><3f4{G0WU%^u{LojJ|$9x3z&X z0AX)uf1BqiJ)DssjP0@uOJ)|QFt+hH!pK_sG4|H^p3>Vhc@9`9OAwaKUa6D8ZRU!z z>%sX?nOS7BF5E523okE%Ks4cMScT9F#+vDvxLlp&2>YNR7$2OrilE^6Wp>>HPwC@X zbKvRTLOhYVrCi||eDN_=t~-z22EKRCn*(1)xt&~Bo{jE3?0w+*r@8RtnVNzp<(B)) z>;dq6aei(=fbM-iN+lwI0P^Vt0Tfm8xm{nH4-byTD?kONy6&mg*JKoI9TVZ%1zQJ& zZ&AV4KHbWRfq-bze3rtxaaeX-X!A3z_5-GRc=r zCNEo_SJ=If`M^R{yX~}>Q4~*J>87C*MRpfVN3gM!PmvLvRWP>8D!H;|(^lLVHJ(@t z8%rp_8Kdl%5OQeI915DPQuGYY%KRDj5}5yDPRyxw71@xIIo?ECZl<684a^@|JO|Bf zRU|cYDr1?~u`3s&{^iVtIlaD)r#aqRnZIV&f%kJuatiwUC)?s9s@2g727xd?Xh&@5B-SszU@we)f4o#+nb8{yf3nAa!^5+{hRA;w>RlMe~P^ydOv;Y(vwokd7D!( z_S)@TFgggsHy)@^<=1V#bxoURq{@uUIb;U4SToZDq?w+aFr}w3H~X$6 zY2l@4@qO$$q~#;4^9v&Az9DgosN*Tp(AClsRfzykSrj;yk6V_Cz6j4>`tZ!kWX?Nh zoV^6zpDWBS=um95f{q@`GJ1hnufxtw)!S53#K;H*uxWHcb|bh5`U^PSa^k(L6_XfcRB2*mj@y)( z|Fp9D-0SnRGScEGBuAI?FBG4KLf`WysSr(a%sfzovS@{9m}XihYllsttP7PwbH1LR zm3~J&g{bMA|10rRDD0gBTs=|4LQJ6L(h9INRUT*^1zVZ> zG4G66MM944vMv>`FTtpHRg!V=Ac*6TnJ{G>R6Vm^64x$u7hd(2WaB`Mfn{|Zz@|)x zEZW&YaWmq06>&6Mwi?0S(MWXPm8`wg)MZ;g<YBB$eNO^ z45pTAl4O~&i#LhyK=O<0V#{khYwXjar8)9O4%l&CGU<;Om24vy-zgr+a~FQyH)T|8 z9y2Pg8)j65PZ<^2E5|Lqh^QX*PaT!AmlYKm%$6!S4pGf=+*C;e=8TA^5!D?fGOGB? z^YLn4-r$598tA2_L3+8(t945955=R)+=bVaE{N@{YzzN!im8-LYlrAGqnZ>9e0jz; zV2?~@&XRKROGNgEsUqX7(V4DthLS;piew|B>{)VD-05)_{;Vt~amuE)Szcr)GP?V) zvf#YDLs&tjMLZt3QSxX27Guz*bHz6i?U4%46w#u1+1{i~okldT^YTV9A{gP-BVu1* z>PBYCk-Cv9SCyp6y2&Pd>9yj@8yQIxAm%7P>u96{jGgz>Y_nhI%81^hg*Z1KW_pZcACcaEd~GWT5M?W=FX} zrBS4;+yW}1ay2bi4(F)h8XM^v9kaEyvT~gD1##^Pcj4pJ)72?%{+?c^gxbj5%WW68 zK%1x6Pg9%tIr?U_q5R5yQQQk{zF#w4ZQ{H|%u6D_659rAwr3BChgZ039@-#&?OfF} z&_5EEZ$F3S$c35?FUC00`~Oa1zugZv;PaMfek6_FZ%pPt3H}>4iYr_zm3-P%0r@x= z9&bRgq3=|*_!D4%Y@>LGi^Vg$DL$5;#J{pp-0oUMJ38dh3z9{eQiSA3Z5I@2;Q!4z z;&In%dQ&W$2bEY_Q~%dx0;Y+S;TcB=`owu4G;(K$SU$*Xayb38IQf_E9R z+U&v^J-Wuh%{1C|hm|LO*J0HB;au_CC>AYP1<9pzuyX&E*D9S}c}((nz}o0oR9R{TlpMn`-rTTeqdqvjX2 z;+hmBFVu+i%}~aJb>cRXaXu0?LlM8O6CYA)%v{FD>cyv}8iCNx8QJ1@_2SEHiy2Dz zL{L1hEP~4qCParV;G+&Em#X zY)+)wp%R=cD@86>j$C_{qk@@>w(9Gf#d~BRh~!Kv@)>gl0QS@)L^q%*j|WCrQlS4S#MC54~k2X@d`oNB2ckdMFu9xDb&*H+AHDN1D0@uvW(I?g;k5 z7#p71Dvn15mZ_mc$iM(H@FH7axMkqZkew$1dw`$RwtfrpKBAZDbX0Z@3UJgu2#LQ z)qX&cgO6TmoI}o@;W2U=8@_P9c<*YNSSj#yT1tV?k^~y3Oo7HJ7MNIf?Ne&EI2Mh_ z;9ehxkCz8fwqR_K(Utb*OngPGwY13s8bvG3~Hh^tdoKJiAl;s7R{Y(?8lX zfu?ZBC=MUc^*gtK$h8xFeb_Lg`i5o{;ItncB(7GxTZv%4BS#(Gk_o$i;lFnK*eIZ+ z!zGDwl+cZPh4+Q%6`CIYcOGOZlG%`N&2#g!*0yc9?E-N_ag=I!h0Fbp7t0E9HOnm+ z1ye%BatqYtNJ5+sI2K_oLB^?>@=d-{8-yv<9<{68Nx>sSy=rD-Y`FhI@kF%h%Br+1 z2lI$0$)xsZ;zqS|Mr6sr5OHEv<J<8L%{X-qeSU?T8;3g&SqqA}ormp+t=;ZC zguQwARu&Qto33spsvCnO(7Vx%6F>)!f#v+H)U^C8-{m!rc8hP7%Z?^CO;%UquTTR` zN|SLaDor%n)T=Ub)QSG&kk!H;ww%-#lBXQ9=}ri{1c*4=#7i4J+F|yGi#mtQE!Dfw zH>O5vUhWZhSHxG@?4!X2&PfabgN1i{TiJ)0Sl)>k|vjk48h=>gs}_ z5U%+!N%)p+TMNGD3FC;O)^_7^%cnWGbu-RkQuNC#x;h-a33r!t)HNEHS{^vf2PXm< zmspe#zRcX#9B4P*ZqYh|_-eEv(A10*v5brHd5L`Jn^;Vzj8go{@J+1qY<#*ZedwN4 z`rKys>AwG&>19qdWZ=(wNDFz60`B&vI1ShTBR7P}BO)rqa%0_GeD}N@DRbgRzJ*P= z>c!vj;8O9O>FqUe6KL%!JDGqYx5}h1pXBY(XWMWqB@Hvn0GB{^^^Apr-Zy+t~Ztb%#cV|6wnMzWBDh2$j1 z8b!lddD$qtMcGgV-DNE!{7FnrF#DGP#3Bl#Lwb33@2*`C7nT3E@e>RNfM|sRbJ_HqF z7!4M6=iFU$cOaFU6-lFwBus~EvJg`2JR6EAwkXsvn#tiz+mKm?%sCf1)?yI|-MSF| zRFqoDf%_5`$r7rv)G*FhC}nl~VkwErMTnf_=ukAn*tS@frtLW>O*?XAS>IVEB{|a9 zf^nBd4C4ZJLg@>YlNdUc(=gtuIVsM!X=LqOLc@%v5OR@1luwsJh>pRIf1Zl9M>-Kv zFF7ch2ssR+&n>}j0#woWxLH@j=w~NF?Nv_0*r&Zo{(weQ%!8Vr{Dw#%)yHA!fQ%8H z0y6e~g`AtY0m!IAau<T?=5+&p$SDrScDnx?;7wF6%7rCakKzl;bA5^M(-3S@Y)TB=iuCX z>A9PBA<)jY!LE@JIumv5@L)GShJ$Z!e;3e+kr5p3GPbe0y41f`{;8-a!^sXsJtGqv zaU}Y9egVii*1X@drc9k%{q*bRP$HOASUKaU7B3l#fn)bBmCJ zzV1%yknI;g77rujfxgJ#aBpN|-|%QpWR}r11UViUYA`Z1K8D+nM{vDXWmOTz4{ySH zxVS(WucuEMk8mVA(mk=8V1nfPD|{tu{kXsiJW1Gq&J5kSP8#6g@aR6vh2Y4X-u?sq zy%7)PU5piGp0q&p)uReE6V~G?8lFLp^hQQ7v;cQ zB(CK>MNLtkf15a{_G9_&bp9}#NS(O1u`{fST#K(8q?iM@==g?C43azLF&~}f#lB)c z3c`W%&icp!?2?my@W(MM`u^g{LR45YTHH*rZF`fvV2}@?-iYfSJw^3Oj&hi%yVy|- zwcBxnUR`6bZi}66Ui2tssGzoM9#P*0`*7a@zHN<6H=lY&`#j3R)4NSpw_(vR<2oCT z9x@8YC-zY|M&223xA9|Ul~Jd0m+{8$frBO=7nn)j8XFFI`VsTsujdg&>;!JRpIrK* zNjD$zPc%cKIG9SXx7nqL+IEGuZ{;DZTzghpLaU383{i1N_H|r|xkMQ_EYre+8 z4?NwJM}dL=xAv#R0{@B)N5_-?A2u9=+w}L?aNNn9ez^@t-;~~K!_gO|Z?@skC7sSE zk`EB1FYO;d5VhgTlIcnNrVU4W(r%T^_%q*OQ~=*@!+pRJhkD?T8`x9-%Z8r?{2exY z8SoYxz5+N6Y2}0P$m^8v+3>}{@3P@<0lwFUBmNY>4M+U$zuR!c?>=tB5x@I38;!y>Z8-WUSI~yz{A(B4Rz3)iy9JzIvf=r_&GH2Q zLg04$V6fvf%MbilVT$*xEj;qlah(mvJlj!c!*SP-_?r#K{RZMcZTNEFm)Y>uz|Xbe z7-E|0Q~uN0>QCDI*TVe?{D`R*<;My5LHy(coSxg|U;JU*OfTc(+CN|MTM^3kz(5_S zqdZu^5H_qO9C6nZL>ywV@`mCzP0mBUGha2Xtqa0(~s z2q$3`E$4J-%vY{sQO%H#sVQ5Izi5zjKhk7MFV@M&DZO3+4^e4tB+`j3FWhq>Aus4Wq(Ne-slo!XLx5k>Gcf zJmaSf|H|@F7Gyj~pM+Z&Uchi4L&%r@sAm%1&+rL`D8G{a62sRObimF;cN8*2J(Bns z!*?>go8jjevc8Tt6z)VBr*KY`4+%Fh3^Tl#;mr)+!|2&*w3( zCaCTDDHH|5KZ7i{)33x_m2lXj(oR2uxh~;XV?NIGm3IG!45Ny0wEI4SFR~uLQ;@0$ z=_lqfJdfe~82(;ChqfQuPvUocT|rt7km*CYm2iR~>W##Ite|T-L$oPGcO7PU14HI_ zF@MUXik|WlhJREr73~RyPiz8s~pn2jhJVFJt&P!*4NsLBaGahF*pn z7;-+R-^BRS40X6aDSQ^EZ&oAYS2DbnA(x9;uP8i&?Vqup@n(kTcPX72M;U%r!Av*9 z#SGDB5MSmX!>brRtKe+5!|YtfTN$F=q;RvJVu<=r_?(Rl*}il78Ath&{;w%GcQ(US z3F#$abZ+jO1or!w~&|#9wB}dS$mL zJo{}7Kf&<0f(zIV3;c|uzau#d?q_>y%v8&@#S#) zmUD!0)^kan!k2LQUh;9qUr})B*$lb7EJgcG`km!txR>EG47on%&Q*9W>z#WM!WEtnrGPGkd+|vv>pOr4+>&YTiV0R<=(r3@ih!f88$FvyLfvUA7IGk+{^XZ%l7ep zi2WaC_-Tf0FE884`%9+(mLZpym9rGSayi4dFy#8Mauee_7`~NZgy8{(oNp^{Wt{a| z$>nDy=i^E)KP$h*d_PyPko73!dRO@GO#ixqYdC+`aQR(x71O!CuT4?-+B}AA-?bYV z-@=gPuf3jew&U8T7=NB2=jYl#DZI$Rkn2@ZJ>#7WIe&_-VEh(_A7J<$hOa7E%yNp^ z?#0DSXL}cKWt`;~znk$7GyEb$ZYPU>%=oVqT(^oLr+-~HH^+m=@lFJ`rE$LBVH9Hp zsMtIicFZWok%Qx1-GFH}gR8?$P0ik>ZkYV31Bc z4G(mW?Ag*ZzAxe}2@}ERvxS_rg4u(B=Z_OtxOwM(Z=`8tXVsRfu(~fKCZKvFivS1r zl*<7AmOy(`xYAc%8Qv+6`LzWwnTJM6Sa|t`@JE!nu5Wg-`ljq zi$jw`+bg`6g*vv>ZK+piCD6uZZ!4Y59P|cj16AJk;Q3YFw)SAC${WP3YX?e<=KgN4 zw;fleM8?LwURZ0OzZ+@ligb1Nhx^7RYzW?RaB9bTx(2#&pnYtCv=s_YuC7~NRieDe z@??rswC%jQgi-KhirA#!DpzIjgxNZ&hH}omIn}MwPO&Fb++&ni_fA@+pTs0n{Nsw@ z+CVarsSYtRVzaxrhXf_l0L2kx6^LXSBo;ue@Jveshn-PTkYO#2r%{Au$Qc&`6*{K< zn`Q~H$(UL8O95{>?@cL|8I#F)UG-7WlBxOn##UlaqNXcdz?@8uTDgb-$<*Z7s*7OB z)ZD0>W)UWtnmRdq5HOjVNdZkOB$FXr6RA&|X-(v?GpdO)tW|`P$v3;kRvuC|5SX|Q8(+38+ zY(CUTgO23+@yV*{uj357%#J+Fd1nqnu$Op}r|#v;CVOG5=EdzBlY+>mtSSNBKbbBK zUY&p*N4}hVc>SgSr14-!Q%l0(V6hyC{?o^yQA5y~ycJJ0godn6`tdtOL`%(YoM1-rS^^+0n8*f%Q3Kg$(HA?)7x;2l+1K7Uo3De z#;)}xIEfgqbDc(ANwKdQFOrsuJO`07;gMtHx!_!asi+i^nkBhs;qM#)kE9>RLtv#4 zSeuYf8UB)J{jl4CHHauaylaTZXJ9QTif;q(TKx1wDWC^y29i%A_;VRhtT&jCPDL{) z+D*=P;SYt?kM@g^CtgWTp5rwLiYE_ik@k3<+kw~XNNs+xe0L_vhqVxc(x#sT>2MW- z;aSZDn1~PQ5FYsJNAtzlF9mBN#!k%yn22u_em73$bKGhR182%V@TVgV-!;*EsaVr; z-aVO*-oKkVz&YzT_(L@PuzrpK5U{SJpNt&1((tRsFBd;5r}#PE28b}am}Pi?(@#HI z9@Y+{xbpZytKueeG&|D?4rxPmbYL7?2@U40kS;t zI^4GOE^Y*_^`kP8K)=PvTgNH*>nDMJOOXzPWa>xrQC+a5V=2<=d`2@VKf=UQ_+!&A zuNS!1Zw=fD^vfHEpBF#<=y;n!u*I84Hoi$SDL;wD=(nr@RMJI1EKgu<)2`pLUjf(p zt%W;*e#`y_zZdb-PXhfsFM#1j%>=0VV)R?S2Y$yU^NC*2Z1&5ibZGskY$nhzzY2cW zeK6dsnE*9kOgc6k!XAVAIDA-(w(B?iIB=~W-p3`AxM$<=#nhwyx!_5|kIKO^{IvaI+THzL?6bNL{`%4J;+=@81DprG zia#VnKiYjU2s#X$2asOZG0kN2qkc*k0yy7(Blt$(Xv2?mC3$4eJ@}>L$Is<|gTsR# zrNfCI@lm>V;%DPKLNa{#5g+krzDBt1d}KcgPke6tG+(T|4)|$#R5mqVth}q?r{$&E z_^4jm<3)PS@Urc(h zSPMU$-Z?hD6>!_qdqtUzkJ=}lju`!}*Z@DR-{L9wkRPG|{-oboiTSR)1b$kcF88Ew zOuSd#YU3l_6X-X&{Qim(kH;s;>M!1^R8&-WJY{9R5=FUa*5$$G2I0_ZL9#F?ziotjuBHl0 zyZi7I7~74|W1BXQJa%mJ$frkEW#-QbU;DNzSI!Fub3VDGeTBoDYTT9A``q6OjUPGl zF08%tg|lCD)B^r+$q|RKcgerk#^agIJn2Vjk6g3bc-C?Dk-xt2#y>tk(y;WGKgI8l zGH%j|R9Up#I3kV&j$E-B#u1syjxI6%`6s@ZFYY;G-&mZ9`^=~q8Mpv7{&EcT#qv#W zcXdTYmA{*pZ|DRu^~k`eaa680;RfxL+4%kwP(G%4$V`}0M>_Rh|ISXsh*}v_neUd} zhVz(HEOj_ixX-`g5XW&He8Z2ez0TN}PN@Hnx2*VD7c5SPr!nvKo;sUp>p>P&N` zxzke8Qq$7X($i+8Wu#`NQJ)Y!;vo&sgp2~a9*($rnDJAKsGq%o>`Sh8UE{pg@h({e zXZRKJo2#RN=#PaAaV9FMOrf}s+Z{J56#ggsWy!x_diGL+&i$ZM_*0@*i=nF74@jQ= z5RIi)^?>~g{rGM!GA<92HLq{Vg~vnk5K1}bI@Rzqv>_#1LCwOiPwaFK1MhBbiZc;clcbTCOS%{Gk+@)|nI!#6mftUJ}@wW4CaYrUeAP0@T z%Bj8A!*PxwFyb^H%6J68;+Xl+;H_8%?1mGUcau2%EP`Wcvqg0`pA z5TqfAg)cefBk=a1KF|>ihducXk#3L2?r;V>=elZW58zNBKkuS8Kp9rbmf z;v#OaNQ6ILaK`qyr%duPVPJS@cQj>We3S{cFYc7~^gUmlR?JiGtMHYT z;8t`>I*!{2c7*HNw&A*Ne1nMl)_t57_G*AvsI{SkKAKh15_-gZOz6SKgouPcCZw=% zTAvd}5u!dQjPfx*DU6~{N+Qw+>8v5@o#iq!hxHD$*ENPKLSfBpCzA-=$!-}&GIum? zYpL~=PND}Y%HnVbC=70vCw)x=x3#x6G~r76m`EFffesuy5^fAMH|%I_ua6F-eO3HX z^0Zey6pQN-+}RP_DnIRP4{mM>;d*3b@V2cTtZ<;ME);H}Tayv(78WtSXJWA1?lw(F zcckkwt}b2<1!c8iZqRUuWuUn^90-Mi?Hv}msig_5&B5)#X0{*|riL~t4(F<jOko9wRwIsJs4hTF3eFIf z!Vn5nsevuN)d;x+-}*8=QBcxgB2oCtPj7V5i4lg4Xw9js`fz0?OMt7Ent3WtC-Br4?l$U&2vh|Ls46e3tSqncRU(SZ$&g43NhrtY>WCl$B?gp=^72y9u8=fJ4QOR0)n(Nc zl_k~X6Nb1_`cP_QRA#35tIEnMDlx0CEUolamzVo1{N;%3Isw_JKPW18^IdO|W32dZ zmQQ?R-e55#Y14OFAyl%ZY2Rg0IqhuWcUvB80K1`YvV2V=DBIT+#JBe?(qg6!wApX9 zk)w@&o6RR)7Tj+0H+48&M%*R!ZZPw~UjC3zcbndvA2I&#GyUV|$~~rkl9}=WGXNJw zTVXzG`mtf`8Sp{VGfwW@XL_23nL2YmtZd14i7o68SiY=DR9$$`@{X5JAF;emZBCa> zpQHp}EF~KYIF+>x@i~(Y9hr{P#>FuihYSD@lCCr{#BmCNO3KZS+0@#aCf)7~44?#j z&E$t5Thkn;P)q)2WXv*x=m7Crf(aSqd7(#%)D+rM_g%{)I(a`3p{C8@Ku2p!Q(e54 z^@maZ2x~7XFTwKyj9Eao8OHHTv7@drAT4Y-PHKdV`5TQuI}D?Kt5FExcJYs52h@(I z$)DIKMu*qQs#W1S>a_5~hv7s(VX`QHCkk@SqWps>C^C{_HRlxkh=Y=13Y2{w$X7_R zC05g~lypnDre7uLRupEjq&Tj1APUM@j^8XgvXhrNd7TWOkVj^>ac8gmub^M!cG*gR48`0FI$wo9aI!{Gmm-(n@u@g=0 zw%Vztj;(g8scD;vi>~WbiXIi)EE0=6Dz;lRQ_UR~&D3%yM`Fo4AuhDhSRhWRv=L1e z-)bY88oo_NgSjy0R75dp!U@qQ8F1ka=iT1rGVe6uWwCF$DuQYrK+9ogYz}mw zO=d5;;i{T;Ha=q9cS(a;3+U|+u>u5uDemOR)8Gu{9+6xa7?H}td@EvN9?sy!RdJgWvmr|Yr-!`Q99tf>J zz0lri34M@+wwzYe-ofc;`e_KoR$!zM-$WVWM})Sv6FNLSq7n}V|z3dZeCiOFFRTO{at0-%=G|r1CT3vL0mHQSx z!!$Nvbg(nlrJRws1vUQ=VhGiLcVryvC|f()Tbt#c1hLCHza6WjVwc!O=HJcxW@!l> zv^HbIXB^^UO!=|gZiScUn(yjSTWpQ^0c-x?5Z6+}LoqkCg|GxFWyX(IGUzyK9(Ia< z*FgiP3o04RpeLQ;9v$@1>4NSg1~cd}#Wvh%Y_0 zpbf9N#G|xKLN=3vl)c7>M_T(RpbW)kn@Uj4F}HY9Yt(WYjas_;hvKVqZHoA&R!2&) zsbhv>bxb@qQ8iyl5kJtnw6!<21VUR*W1;?*uCaZVRjx=CztC!!0+cEvql#CRq&CL1 zJ!`&_D*oiGMx#*Mg!OqzR^eoeU^`G;h3Le~Aza0#7(3O4XVe?22ld(T;I|w<96Dg@ z8|zwI+OX8wPTiw3*Wq&JJNe|~8)f}Jf}ruiF^qms(Gs8qH%~crb{JAjX26YA@RyxoZ5)3O4Hzbel43V(@c1jXt@d0(T1|?X z1S3+cU+Q-c+~;DHL9ZR;=*G9raPHS7i1vlj{Nz$3`%IQ0^ONfMrN>qVQ~`pWp~d5; zDLJm7RrXY{y6Gj8$6aM$=2<+_>x9Ipl>eppmcU(3FO3<9l$p zBl7et8sN6$v~_b`_-y1duM1<$tejXbuH3q<8Sl}m2w=@Xz7BY^^IA$l@g7+<%)0&n z=T(yPS{8A}@(mW2kIQ9EJki}5ZS*=%&O~kyYw5cMdZ=vCD^l8nO#AfLQQp9!^eS2A z3>M=P<_vN~FBI4p>V2olurl_S@A~knFK)hq8a36x=p9G)h70n$=&;m$IYYqYr!lY{ zuYB;PpuTlmZF7)b232bDZFt?4oN$bb#>Q#RQKQ2)v;}w81=}!dFbiLlI%bGQ9b(eN zt0~$CrLzIr=xJH2mHH^b@zS{mZB%myPnpc+hQigWX!>J_y_5~?>-Vhj6vVQCXCF+} zlu*KG7%OkM??As;`H|4o#t=U<-KeK81KHCx7VgIB2jl%iBoK>le-Vw_HV4Do@n#V% zbl<>m*ElYw!+i)%TbnvCLO}d~HCdX$BG*BBhbOuRBC(98u%4#EB@*>N0+%g#&=Htx zUB13>Wka1j@qz5|Hz5;)%Nw?~Qi1rpiF2OfRq<60tumsCugTY)eIvLYZfvZ-@36F7 zfqEZK?u{EgjHuME_MD5nMNtV`Vfu)1{UkD|(D6AZ-b-E(Y;Q$31oT^kqL13zilz=0 zDg*7?MAHO%Kl2?Tuyul-f>My4mpo(+dRz1-$>tA^*tpaw`E=?KQK{5KmBu$9b~h$|7-_3lj0FW#nsC)BkM=(t$HZh~>i?yc zdj?0!3J}d&Pr>2Ut39ibAY4bIiU8$~?@)<}t~Z1AP9qrX@^3CP0XTJ|Yv6w)73$y; zWXtqYkti5aaSKv`&swLGwP26QS0w<_?t(NNSw8l^VT+g?HA^gNl`aTL$lU@FaHxS{ZWu)=4!9;sTSa*{>&*{YLnwW1g-f9Ul&=rzVr6PE5c@TVoq${%>J;hy-zczj3=utC zc`bD6Y`6Gi%VnZS!iU`SZlb$?JbA-#fGE3ILLl>LH?^S{jx^W%3;M7;$3q-juk7ig zw@(B1j+&-V->`*jE9hI>k#yj-o(>Z5tRvEBBP^wx`ul3B4IaPK7Ct=ntL7M-Qq2} z`A~xf?5RWuT&s3{I2?7CsBsrA4t~xdZix+{1Kb=hz!9go(+WUck!Fu8|6{a#Xlev@ z%^g?xpPk}E7B_Wdy7|+=WF#sv_RF=ALeUux<9<5hs8REuwD4#~Y7?WS$jBiDFtLwpw&G0NuEn3@c!2J}n?)LntDc<*n24GL!arc*vQs8uju)b7AUW0IPuMIbAZ=D$ zOd_U(Dy!joKW8SKU)8oJj@LCp@wnD06T>MVvZx=w68uVOjpH_l)K$(D>E-JC@%B%> zaJAMkKjOeb=0grjljNgi#fCsjQ}Zs5;rP$k0EY8%htuW!JTC7OUv<<6n>zyG^Gp4h z;2lDbj?V9En&>ab`~*Aqp2p^ldfEq#m3dIq*rBw+5YIT;nmnb&{xW}gbx8$w`Bha{ zR-?Rp+d-S3lrkLwtapTI*NmqeC*O$g*!&P}IMmqG(1BSZE?M#TDf;K_4EQpP8T=KR z;kyog-9#(uu_CG=;d>5_6faw8y^T`mJ0uUJ#45n|V|`^ZtKjqBNN3wNY}-}g5T>@m zS6hLp`Oh8l6>k}30A3n~np*1d5}5X`)2?*+K3KoDHN?G6l|kFK#(ft(q~At=fceZ7 znWzPpu7QJHhsSswhNj|QHX|;;v5BMdy>zrHg@rW3RK5ss+zdeP*FqgSSV2sv)n84en@~eC1o-EiksvkVV|rV#H+DDPfxhC_>$kr31xpoA@0I@9)qG*+ibP z8P*xu)ZubXnx3_hva}g%V$8@YxflD7+->_SF%82zapMhf#F^EGj|demW{Yc_*=@3# z%eUmY*pLLAs=CD2h<5{*GdpVQF?|1&xYapdQFzDN8si-$2-Jp>F&Z~DKU|WUG~W0nI$?hvHmoXk+mGB#5J?r zg?FaP9I#Rr6IncaB~FI4nKL5Z4at8@O(UDN<8D4#cx4d;!Mr3L1V^5EeLV6-*#`~5 zX#XLr2r8Lh6z|G#7k(ve8Zup*NhUJ4P%1o0E371R7 z30Io)lNnjYDSMm`qWq~i;h&@8gezCY3702coRm)Yb>ddU`K?S9r^wN9l1s%&t~BTU znW(h3I8)Bnagx7^lUyoJa>a{NmM!<|;wa*Lcs8otcG}CR%B!q&bWJ@4cI6!kVPmOW zA|pI4Z)8_JolTkLKn>xVO{OGmU~qqPd`T_fIMOJK}c` z{_|-Gr`ABeVtBo^joQ~ zig!Ww59ZIy>+2hDjtp7NP(KLf0R?C+9eG%MZ;u>^jE+U@bZ6d3$HD&I-T~@0RU=<3 z89Tc0R@=x*`vDb&aj;Nl+A`eR--lhnI-X3H+R)WAjvceK3l44G93x-4WTVsrMZ%+9 zz5RzutO6rjk+jX?d1!w}_P?6;F?yH9=$-Bszk}Y-E;uuKb8mMBtRADc-QHBp(?2h6 zn1>3w=wDoKyS+*8Srg(u=>6@*3(iO>mu*ho$eXu!-tbVQ`!H8L*@kjQ6Sv6AhB%{0 zd=W{xXUYG4NwMXMO3Eqm10?0&mrgECR*N!Q4RE7uJ=;SqO1Ere&}8i%-=o`&OarfM zPUdIL&YCaV54e_EW!f6CQ?r`+CGmSifAd*WMt>XiYtdPKn&?j<(wpN&N+of2t+;Z& zyYSlFsUn>-Yr2t&ocydgDRCl|hMxTyaSI~-(%Cs&{M&JAv^1IQzjZ^ewv(f!cg3{y zria^X#@nOXafm@@&%HoEN|#+hrb(=|i1RS3LXkJJ=6uD0Q$puw&Gth1FG=M`si}|7 zra5cHhoStDW&fMXQ;RxDc_Nz1&%K(Je{X))+#~Unr|h2dvN#6ipY_C7Ue)~C!zH@> zy7DGvMoOa0NS#Jz$N^YvW)RU#&%8EDPkvVBJ#o?^OVQl>#Sf5{hnDB$g)n?W;^xr6 zQ>CH3p`k-30y4QMNU9wDEl^_-nZNYmnU%>>_PkN?JIMZAeoo$2Eyl>(+HG0Jk*D6* zVdthEZR%Lm_!0%MZg`A`5o*MlH_|Q(+WhJ`37yv=6WZG|9@{R>`=+=q%UyUJBjjY1 zF;28P}UBcLRl9oh30%cKP&x?cnVR|IsaGUr%>oWS7zq5$m~L+VZ^SbVBTu3 zo~U6VCeU(e1z4IY544Vgt<3$HcSfutA;)%Emx|YyVAQ)R$vAir#Bs<>m@*Eko>?!6 zYnQqUuX;EMxy(!WbLJm_|%6f65k_KFGxp)LoeX=li#YYx8y@ywa)k-2{8$`B*AtdiZow&!>^BimWNw%3x}_CP|hVyLglM4kW+0F1EbJv&KFxTACwo@tRy>i^*i-_t`|I|?_ds$JD!EC9L z;}F#>$4!+qV9tnm8d2R*BBP4GJRh&-4MnK z%C_*Y`YL-qq)ExNc8E?hs!74XmuGAP_Q+)BEGZYiL}Y)MDl*O*9hu4*N(K!ol8ubA zXUS1Sj6s*q72ia(M=Cs1 zM2q5Ody_JC8qvJY%NxarV1!qXh<$;n8<{0X>PD_yRgxy_CY$i3*NQ8by9@8GoWdmW z+N6Y;4c+EM=|-XFS-PQoEKs_^wJ4!(G=MrQUwjt2Jx~>=AfmvIN1BFuBZu@z7$XBc ztclYe<>3^C`p7`nVa-kxm#z^-%E~REA}UwYa^-N28m_UCE-d23r1{53mPDP790rtl>ig&nJJhPkPWBEz^D;ve_u2r<7Lk_(l zS)?gNNPg6IL6HXj-<%^Jcde#3#j<%&iKRuJUBur%WO%b2i+ab#B^+tDnh+?EFA|eU*+~>Tt+VUzXc#$4MTQ3C4SDO1Atf`xv9k`MKR^Td^D zRHAlvOl}ooI|-xa&Mo4`G}@Kg($XAAP%5Ocawi*y3f1#l#H%X{slTFK12p}h0kt=4 zpiXF!;=KqbYlUe9}6HANdT#5 zXm#T0cCuBxrbJ_;z0Yo~xLWnHR{H@(4!%*PVF@{VhR4WhZ1{DXc<*YNSSj#yT1tV? zk^~y3Oo7HJ7MNIf?Ne&EIM#T`;!mD0UR6qv#bZ)NQNq>~W889(C}m%77dI4|*%*^L z5(@iEp=5krxF`cuo}97N)qE`^UM`dsHhLS0RdrW?O;z2f!7tTZIcx4zQ|3;!9j5cJ zoIrOTM)43io%WqEJiN^9w6@1koqxFIc!xN;M%MXg4XoOalBc%RkXdv;qc`N(D>B*x zD1|yhY7kJR6qoekyf-3P!`)moHT7snOa5`03%dm?VUyD*v9E<~XHlIr&KkM>NUDcmuNvjTMe&MhEv?L=Q6_P40Mp&11@?FR>ms}&nb zBbc7h03f$pGGVhW{MWk2Mgb)qE=iQ5gl^pBye~v=yv!NNL6#z!4f&EgH$Q958ylY5 zC2lB=QVnlhx!>_(6(Fu=xdo$ON~l@;gT-{G+)!BwLYh@r8O_4 z)c@0LdGA}rht@?E1GXh96ihihBU2XNH&at$H^zzltm1n&{N!!oxoEwVNvBflbQT?k zC1s-inHH`2*hS)|a@j4!?$Wb5249Kl7>}X=sWOX&ZpR0i;rO7xIl_nZ(>O~Ye>O_BX$ZFvaTTbc=$x{y5bSH$D z`a~RUQVl?7k9L^-;iAqVa|iS;^o^;Jnmc;L-4*dwHajW*9f?(*G_r+Oq})lRoY_%H zDnD8Cbgy`&Le|AeR@U8H$$5!2MvoRVq)(ugOvee84zuHv={PZk zk;QO~#%ar{?v02Kx>sS&6AIw4LS&NDKF+XDo#7`s@h+sLORZApb`C{$x1jHo9h2^^ zjO-`+#6t6{(a^TKx?l*m4p}68%(krsAM}KAMp0|Kak=Hw9NfAY2Qex7WfonXj^2ce zPde%vjY};L9Or{0fs9KmN(i53Zfg#-8*jI09YK6H+7M`J#*tVC-33bzeG`km#-Ll1 zD)CLM^K5*&3O79?^81?Ir~CfrOx;!`&$#=4?8Y}~-)gbkST`5nJuin*ow!|bVH570 za(Ru6jB_%aX}F+L-7k~vwr-e7i6-IZWQ#B_1^1F#C~hCMkU9j+62vjfP9#ExCTNaK zJHaq!Ym}JhXv8q)YNsW8o<$<&`Kt^{QI-oybEakB?poX)CKi%oK>=>c$%W@a>6ne1 zI5Xg-?#@}9VJJrq(Qp9{0vJoRzaJIqEX6_2T%wcX>jog}uOtUfvn1evw6{nHl2tHIdaTYy#7Gu$u#lYO zSfgk-H!mC2qbM7y;Ox9?sK1VU$}$zdPazb-uj%;yJX?@{rP&7Y;g(c#pc)n<MUkU~JNv&bw2#QL*gG(XB?7V;se z5W{G&s5|HGn!5w3+^k3%Z6skjT$6>6V&~aVM6pGohS5w8XWE9$GGxxV$gviSK?S}JeUF=UHH?0CBGg{xG>m=Po8%8@M8!O)`N?mH1X6t*mJY}m z(J3Hf?^npVnHzwNDkOIi={2Si+|phyYw$#kwCI72Mh+A{IA5$x%f_X^hc>VShL+Dv zKNrPp8k6{ao(s!*OUrvp-bxoSN&;}6EHBNO8r={^qZmKuye;y5D5DIcBq z<`y9beche3D4@Rc>K~_14vU8o@<3l?aJV^Co;=u8iE`T3^f=T8Xv>;izB#R ztE#N16!mj>a0I*hhsM|AL;V)w89@Z2p7LT}g=b=<7cqLuJOy-YWH0Wh!bj;H!@~pX zJ%|<;7bxTP^hx6pj$}u=Cw3D|kbHlIuVk$s7g&KO2^-Lvp&Qpp0~{P4-DkNF9GTPG zf1tlN;*pnVMq6R#Nee{ZH=Y)&__{%gIdF@PZ|Fqv>6FKObfWAO z`%w@Mly}xg4q%s@^n*W+VbOO{PZpxWn$hBBif!AQ73nFeS8|lYJl(~P zVx--U8}#ZLgLPZ%bn}u(DMJOdT@i`;HrR*z4)ASjWV-p(Gur1-7M|Yiz`6~Kh8g$U zaP*K-I6kqD!trr^6pkh`<4#+6)b@;Sjk}CDeh+**<1Pdy`RCbi$k&gU2Y)o-=F{ec%Kc& za5B9`<4^|q5v3pS^fK)aVMu>E&E24y;mVTfP5X`wM|#uD{G9JFs(}xf;T;Cjnnve8 z%Lo2w(^F5{a7^7(KWxMEfcMz&eBdi>_$p-it2P|6Q~tw-F9kkk!wZ4e+Hl05VwM5u zgZSOg+x!u~+q5VA5x;xT=8yQ@n`}7Zcf(BT0YBn*{ltbNe%F0A9Pce%Z?oYQ!0B!t z`5-*p&J#9#IqF!SFehY2dgJTG9o0r9aBOgtl;L98N-n%j9r` zQ#eUSI0>szJ&At<%K<)zap{kGzL0R#pKOANN2cI7=A48-jVoDW=#md~2~p3NkpC-; z|AyfoFo7ldYglw9_z#7PY)l@3ll{qG2GJgBaC0e@CJrAF}#)e-ply=6i)ds?E(8OhW-ZZ zx`H6=dNx6A*DEotBm7!SK<)HLF_|R%F)Tq5{Eo7d@l%F>WxJtmllFsr3AZr3fFaT+ z>5wnsZ4B>c_yoge8NS5ubp;)>7#1=NGDQ1C@*MAEcsIk(F=TxmZz$Y}Hi7t^sB02# zVu<{Z_{9uwX80b4A7uzTNWLc(H0_7@&L#VN9?NtDwOv1j$u;4hF^noZ{Yng435Pvu z?DQj;cN2a!)&`iq+V1}lstn<1r^^Vw$a?%vL8{)QpP0w+JccL_lKy)I9ol|(G5&Q0 zX}LqD5A{*P35MTb_+tfK%Ne2#CO+3;hA5X3XMPv+r(CM&DL-NOM+H;QW!T1$^Dp&b z#{WmbG|vCD4#xW!UdHfohTmfNf`aK;4AIt-Ug;Ycaz3Zu#Q4(;b+|t%d={r~RwLtA zGQ5=`my21iC_IDhpRt~Cv;!1xMlZvo3_q)2CfaE7&s@w9ZMwt<8D7QkSp{da9cJe; zj`p7TXQLmG@F|99*9f1pks;f6PCw%)U()|I1?SFYxQbzbA<8ZB&1L({{So7TQE=XT zhVN$hU4}nXa6ZN#6n_4GhHO{#PLiI5_Kf_qZfE#1L)I(1Md8_RWB3V%#}!<_c39wN z{5pnrGh{gn3l+X_nBj8@F5-Mz#QcjmU5nXXi$9|Ha=3lVIl?&Wxuj0vOSpV5`8eaR zD7f@&hFo5jqFm*F!ExjyI4Rd_DzoqG}E;|xE@5d9j-qqbZ^w!_(%Fn$xm zFDkeU4FvHmTgR}0VLQVM7;-sT#`&`h?U)SrG(*nkWn90P{aVp!m`{A3bcXX8<}*B> z;SPq}?s`TTzn9_t3_r$@_4jbO^00k9e^CC*Io{=OVZ4Z8IYUn8a_)zg?`Jx>C!g(_&++DS{mb9Vd>n87LB=m<$oZ822;&@Y z{*#PMy2je$0d@sWfFl7B! zaCu$vEvEl~;ZGR;SwSz`#hcCeSqxV&tYFCY@pdrY$*`9p+sn&#@^X9Oy@&m|ym&vy z__GYToO-#OdVj0vD^nO|GF-rLB}2})m354>UMso$tmJ%L$>nF|70h?5f~#4NLauLx z0Yxvom?7tHA(!7ZC5pc0eGEU%@EZ)-zH5HP_-hKTW%+9>8D~4L9b=r^`L&#%Yd^^J zPcYbtH$&lp~vE7S)#B{cI(ccwb%<_xRVSGEoA%<^f z_)dmAJ}G{laZdlb`3hf`&yefgI=1t=R;Is|A-AjRe$Dv*DCj%J@M{d2&(HSrb35w4 zMfsO-`6%IfRT5-6x0fZ?GOqbqe{(!|9PesS?`Zx~?l6k6!c}aZd^=_o<4DEvu5Q3R z+J*J#V!6;79+~JK>KerHR>c+#djSR`b^>iyv*S2OdRXCDL>`CW!-Fz{9<@Sj6w{(I z){w({u-yuK!_=A1yGKWgIo7Uj+zWc3c=zb=#7J>TI50>jx`qe3NA_%K8s8W3mV}Am z^Vvd@$fy-u(H&{wvtdLNE2B}!~Sb&w>3-2GP?&ukAj9hTIJX}e_?b7vem5^O^ko>~F(f;k5YyH7}TgxXa zW1V%00J{P*K<&Ve!=?iu2C7t zM#I8=6uH=MFg{4fqfuE=g$*x3jQ(O(8mO!c4}}LKgFOSICE*GxPY1^KgjI=xo9<<% z(q+`ryMutfeR$04?PzSl6}*81r7hl&w=L)mtZyzU@$OvT?Du;^a5V*kLBF?YhZm*fxW7|s3NUT-_@ ziiwPkd%ZB@K!5k7cLcT~!|BtN$*YQx7nzkz8HzTRR~IP?o=lmV6kKJa44yC_Csj$# zsyC;)RlF(oWXgAp^6DZ@tGJVxWXgM7F?@cL|8I#F)UG-7WlBxOn z3R+@MqNXcdz?@8uTDgb-$<*Z7s*7OB)ZD16a}g$)nmRdq5HOjVNdZkOB$FXr6R8uM zX-(v?GpdO)tW|`P$v3;kRvuCcfEY7$r;podui%z*Ymcgd&NuGMJP&U~MV>~ZzC7BdNwun^;=>ExcnQzqz=yBw$ zobs3clZJ~OO)UvWi^X!B`cEIGMvYKsvRfe02ph6G>BoByI_rjq#z%(-u#Kl-VyI`l zA9v(-PTnVkPk4GEv1h6~>5A)o0dV7+Ql9?{%iv^Cw_&i_< zPH4s!QK#FeD=GF><21XaBF{mzO!(v&c`i7Ypu$NhsacYJ7XHq`vP9C4<0-IG0IbQ# zrwo5dvVPd@z?yj!AKp>K<1+?g_%;CFi=Tcd0eBoAz#pt5m=C?%#d;9ElQbIeqj>Ri zydMzyIkbL{0LOZp`LH~Cmn!ws9$x@DPa`(JW}BOw-^3pZs~>H=7*hqb3<_*{A5!+R3*(eh%_;pzhi)``p~0iU}9>QbKQNAtzl zF9mCR#!k%yn1C;p8)0-Y%lsX14}SV#c?Rd3=9^7vC0Y8>@nWsa z9`9_jr{={vq!}-#*Ob=@_3qHZ0Cl{aADVCBpWxRKhY#WH=~#ra;>?`PCte55W|t)- zOY4Vqw?z6a>4l9>O_pcG=$A`+Aa3)~>4?!U_de+NjLBuDS3CupO+R{fVd_V=)%g}< zKhF{PdGXVajyFa>&wXIHNizXzz8L+Mm%;C;$$WB;iA}%dWD{*aAKWhW)8$#`TRxS& z7xB}NjyFcX{F7j~Q8NK*z8L*hjKlBPWIoXgnoU11r9niy!G(A9zXr)cw_YQ zJ_80SGy2hdG5W3afZ?N>36S{&*3#|ztt5F1@Y{f&AHM|pt$Y#P0)FPBPtKmF)< zWAxik`i*NQK+PAU-{?;GJsXD)Yxs8k#tML^;YZ~lA3v>MO#3|M!#=kA;IAJYFW#A$ zI>348JNQE~^rPJugP_B}c?jus9n(xUzfrh#A%OGJJHU4n93A-S{)6nf2S2=z)z6jo zbT~n!cqv_E2Rk3qLHmVddZ{dFzQ!27i-1#jvP&v{nlDz~9{6c_#IN~cjor}t{|(|p-Bz8Je)O}Y^;$y;ROi%G}T1@P19SULsYCZvOS zNnT!JzH9ctPs`KwgY=Dw_nIR%zEyDR^v3etVdKNtHzD80ZG3usK=H=d@0zcIMs!Mt z?x*AF_bkkQjQMnb6o>EKH-Sf|m-0ZTV+q_;ulRZQ1E{8uX+FAcQ`>Cg`}afGC-k7n zWwilfB#Q5z<>2X#TquPE_&e3GpG;%!kyMTN&xR$5jKfajuF zmj|00ghQ(Z$-*d*f6YkVx5-WJGD#>f&NsF`wrTUoW5+g+eEN_5*Y$sC@&7D-pw&Jt&n*6NOHS=4o)rx%HtpN%TKwb1FE!kl^V7io#ougrbn%a+&)BAY7daccmaGUg zf%*tjdp7M`d;&7gTl^d-pL|wq>Tk%X-F4B`7X{ucRvXVcmm3#7(IvV9A9sBIcbC8M z#v4#HQ(4d@W-v1@^%wV?v9Dsz#0_**fDBw&n_vYAXBYN_Baxooo=BCCSDfe&IrYfE zsB2WBHVI**%*GA6fbucTLuSHcKhmkc&gkqkjHsnQ)%Cb#$KpKZ6iXeL_>!Fe?`@6M zJ%0Wvw*D`htqmWF_Zv>EIQI0cF~lWvvSy=eO%D=1!;C*yYN7rd3S=L?+I@}dTIY3+cZrL$-wyIjza4*5^)wLu ziI*YHL`9Wp6d&cb$Bjyb|4Dxj^skp5^gP(V{4uBSr$jGu<8U|KEl8gJ5REKWZ3O!@ z{rK83GA@t*H80(wBG4y~4wWO2Qw>j}9Vr8`YOrz!X-U1jgf=yXD}aeUTWM9t*QSwU^p(N5^(^(LvSwu z)Q`+5LxeOAxCy`JXcCo(if9rjWcc#|NcKgBzeliv{O z_IUiB5}&^^AGQpK=~V%F_!Fb=(cq5P7Kkxy^&tJINfAu>u9fUYG{x*s)I*+jp1~y;Xa&%J?<%! zyi6Dv9@-sE85tjCg6$her9FK?X{zrj_f`1tVXu_df%8p*9pSpRZMYyEUwz_+dmks6 zy&B*ZYHjGC&y);rK%*BGt{g*CICOd@=C!${_i#%(RNp3+J5Kt)*`?f``;Er~W(TYGCm zQ*$sj(uQE51LwSi8w1S^J6hZ8qXTJQ6@RqxIbb~$i|Y~G*%90-Kc;ODZf*+ULTY62 zwyhnkaGsuArL7BRkOVzArpHcdyj((9_AuDT8dWwl{$&~OfEpt(652!(>} z9TvH%r3tLf!R^6jwjdRzhBhe9pt6dOnMi}=u(;NNp9uJ1F@?~dTb5pIZt+G=1{MClY4wGGw zvtg=qxIIKHU`n_y9NN~^1o`C^FETU`dVcC)bdAs`|&x#eE!}xZL$%<;@!FBG2 z$T5W#99oSyf}y$qH3~S$RSH8WP^AX8_*Nt25_})c^h7~PgNa1pbHli6eCuZVd1UKB ze+;ogHf|6ct`F8VhdhR3WjIWx*%~s$TJ40<#=uh*ZfV-;DZ&m$LyQB*mOn`-Evc*k zX#yma6e1N|<~vl`ryeMO06w_BhJ4J_*;$yg53Gk(Jb|4ae+k;pi#ZzL6bmSC=U6}~ z@t0MWRh3qhfqV%^0kRcEbxBESX=RD8w4$oKtg^Da%2$afE+<1GEhM45+z>|u5hyXB zRFs#Of_8e^ZCkWyD=l?*=m;?Bx&nbhqiv`4Qv) zKGQ#buH0k#Cz&Z9FavN=v=!!~rXL%|o&g^;J>%rgeWs^rn5i@8!^)Oym)OGofaS}Y zMAd}{E$?{w^byP3)aG>A^hrtpMnkf(fKyr95T7&Y(2?ml@?9L0amWDhAn8gILma0N zsHEKNm`$y%Y0~Y^zyM0X*Gzs0vNg?d3bo{aM#d~7hz=01C76&wo)>zYM@^wEb>Fo- zqLcRn5o+2T4s^7(G}XmxS$`PikFfTV@)A5Rz^DUcn_(Qk6g%n~1Jc5V>N&Kc_`%|&C5TfwljuCBATe~13eR$S_H>OJn0}7!!S*7< z<#N;92CG-rAjBoo%sCNrrm`cpC-gy4<7t~P!#*m`Q78xgia1x{9QuUVq;L-YvIt0NIC2;_hwAt@+i0d1jW(jG zOOuUgYIL58!Y=bs(PAf>+HJK{O&we9R8!M76&GD`suVpcwpk<=c~oq-Xr`JwESjn1 zPL9NqcS2lfqp?676>1}zD!$c5G&Ovij0Uq=&Z&rE(u5PDPcqZ(>}^sY%cKp>Mv`t29g@kU4b3vm)>K6i5D}3@ z78Q5_QBXu&5fzc8Dj=eQfC_>yxE64ir7!r(|9kE|_j#UKl1@VP) zW7%PQYi)DWmexRnoEns3CW1D$ARm*7NKa@VRv5^rN!^};bqJ$Wry*-94MmRO+%qT_ zCO9gTK^Hwq0Tn&0sAxZAzhirS7bq|*9EHb22!?nC4P9$nI|7DBB8GSq=+4F_pa=Q~ z3~|1bP}1aqeyH(cpq+soK*z$9xEBRzQ)gZNI#1t-=iTHR+8geh7!2b=>e11G@M!+J zYWNO}_2&Dg8l^i?jB`8(_To}APrh$Ea(n}bHXNO3->it?ZZ^;WM==3KkM;zU~n3!jvD2-Bx<9Oc7GYZ;iwWtN-Q@ z7gEDRoSWJ^J7#1nBPcoAjp{p`;-flg?a`9T2xij5PH}@yI(4+9yC{O0^vf>sIi0k< zvwcQ++eb%2xb6_^|Dk>DWQq8CR1>Os!zJ#bWfIbvB&75;J`!o`r-U*Ut8FGi)%Ux_ zAuUnMQ6y^V85mA1&V?!BM_L?7#U_rKip4SU*i2PFlp>zdvb1+JwbXWQJBo$|T6)Iz zSz392s`#B2!z7?YiHxea%97d{)B3D_C{?`T+=xb@t_ch0(p#mIErRV?qHI)O}Zmh)zXpua) zHMk|v8t7=MM@i&4T;fz3zxa3zqjwrwYH7jEQ%;>7h7|D;@N5{uWoKBIAlyR(hWJ#H zY)y^FU$K3i=RG7<9A_d7rdYq!y9eCoVw6D}2Xb`d+ip1bYYU>Yo7ko^&Ox>l?UTjz zMM>Ha235h(kgs@eV(YQl0O_0OO2$1$u^)@-f1>3m+gXGB(D|v8$aaoHV>>=d_tMfj zH=14==O$d|&ZZ!IJdJWSho&@S8{dlyF;S)`&;Yjs7u1{U!YfhAye^C}vvOj&xUzM7 zGj_tN2w=@XF6h7Ac`fBY6{S_zKg(s6GB?u>TYkdrf!i$x*L zGw4S)whn)^ak(CUg;X}sC~e@%lEGs9v?YTQ(F+Ckg?isn3apI7k^hLe50ls z7`@|~<6wSX4_z>uCuazl{A{h=flV9i6g0GLuWJs_c21=x-;NEdKG2R?gK2zG;+QG6>J)Jkucqh_SZ5=o(bKXvEB8@^6XkO++NkC(o-&!s4F&7g z()7m=XHzk7sNb{RlOG!earQw~P18~s4PxaDyPbMt*FpM5CVB_M zu@R48Jx!&Xj@17MyieglM_{gX`TB#EjrH=<3DUY$-A_&q^>+Jp9Io+J;}PQa623a_VR98w4E7QG@PG`DT3 z^Lg@%qPDeOHG`z`Jie(asV^UKf89AShMU9jvR3l>)G4BJsXbL5-vZe^nD}9&t+p8R z^Ji4y+O-}XelUTGNypUxOD%_nB4zntQ|QS*xNeG-BfOmvf(tZx>{ zpqCH1%nabdj-J7PM=sPQGbonXw>x!n6aVNDPn1AG9deX zkevWsToe`V`*#>DU2Q}^uDljHbFo|TWXolu$igjd+MDPd7*Ad?oFGas77@^V#7%7| zh9k`l{``I{&+!n))+>AZY4>T+-ci%^>4&zI?fLzMT}dY{^mGw{$1DORvtV7QhL@_J z1|7#AQmiZ(jz8M4cEj-}3oS7mx6ZdlscOvMEXU_{ar3(5CUCZ+jcOmurOvP?xsS!k z{{^FcmmG>&^n_UzPMm^|iT!+`2A9si=V^in^S0qYsu2WoV zC7`ZIM^8u}r+{yWimqcPB>t*X++xM1j!ZXyI+$Eh=aYXU^#--QpWj(W994&|O`FlANE z>`aU(X;@|RniTQ9*rZ2c$|1B-@~cmb;k-BPiFd}M0R=+BEFd_zUcIZMj{7E-YA-h%8_V)F-?5kxmqWQ zCa>5;mp!rhS(^B=dv$+L@0dM)zimkr^@wKW@+a!`c|-YS?a$(BC1U+4wl-o`&$A9a z9!D&3x{fAm6gGan-Yv2PUGX2jQPIaoH&oF~_sf ze(-Xt#h;*QCh)?JAyHy4igZ8~HC#7xVZ!;a);+~|QzOL3wLz&EPWdB^(zkZ>9i5NX zIIea`4sxbQo2xfs_fKuOTI-mfb6_F!b_Yo!2iJ> z4<3q#9SwozuG-+~rG8BCrqH9K^ZUN`^p|6Pf|GlX;P6HRon*$!JbcvHp|sHuk2>0$ zJf+3{GJpBTk_w#itJ+w(5%%(ggAP9_VY+Iu-VvlzGoEtXiX)!1g@J9bb8Ay$7iNig zn8xEL_D|U(_{((!e}#_lQwMK1(TaL3iH)G}GY2!pW-G0?QSN+G@{&ue0{lESRA#dZ zA^(khwr|J5Ta^xJ>MDG76_}d;)*-ie%cuabY1rA+(tu51I(<&(%H@8r-nKQwO-@xn z+glUvMGx!U=udJyb44aCWlxg|}`OpcSKJdf{^kYPA-?p`` zD<6mC{e}3ig#If3*{J~B0t(+SzaT4w0a(s0MBY6fua_bhT^NS zE>!ZklAx<@t`b<(5=n6K$%!N&?v!pFjVymf65tHL{>uDGU*V*`aI&OuGEM{JGfn=9 zR&4$!Rqm@2s*8sC(ZWvpC3SyATzsvnnE0RoX-djs;;Yz19~t{fUYD1x5X~`7I zabGwb0qDr@DU_$Vdpw&x`TJ4f$7$w--~NhHa`#BurN{wR1hwasrvQh$;bX1;U@d%| z2MR_^L);~qbxzl38+`I8##o>BYY{p{^`Vt&dWbou;LNLkU%2(I`rS z#)I)Wvj|L^-c}BeS2nlp45|+p&cNZFw$>n?_6>BPoqRe$(5|K~ggjT-grkyetNtgY{vz?|3M09hRP={p){TNR*^!%W5un$#ZZZ2{=`CiLV!z0hcp7YU?q4|Ejpkxmfw|iM4ygC!ARYe|BW#4o?hq z^+eP@dy`|eksHA|gmDbr#fW3ID>qU<67KJZRD`DC)o|l!DQy41DEdu^JRAxK_g5mk zM%@{qZc!FTV?#*SKb&=~xy;lTbTKot! zUz(BT+0itC5>1gEPm`Xj&vI0XpM&NT?o3iA^tT6Boy($&QfPwQ=i;^R@y@*i{an9Zkq<_wF=K>6>fX{56byk{tlSDGL^%$Mrn;mD0N(CvR& z4&tNqgN9&qV9GK{T|uRt zSXNn#u6^QDp!xUN(3FKb4NWR7*L~s+(0plrR&K2i_5LtfL@ffy<;bmtsgld(ymvkv zxa=?&6`1O}yWFulC3jmyg=ge$8&Ix=x!d}bD^symcjN17Pv+=eA}(C$F8F1-SMfYz z@`TH!c*2$D{7O1KZ*Svy8|+W#B-jTH@%5jI30@cmu=_Et-Yowkk3`ak8=0OT`6?Q2#P#L!7#=qe+f_EA?e@DQG{l zI5W4uf4n(7Y&Amz@G!3jKx^s9#o~KMcrrXX7Pk94b0b{`2KxF2sn=AEe4UKg)q`Da zBP;D0GKFzOq0Y2rq;H@fr-C(~45r%H6B@^fSvm!WHgBPkCtb2p3PF(IXiwk3REcFU zvK2|&BA$ZuA7ApHCVhhk=w3sGV^)g78hrtf-d_H zm)ovyl6(Gy_%!5xV)@czV&$^U$&I{yedpp;@7{x4@njpy9Zf=$mkn`xk+=_8x#9T# zds(rSipt6n@eH!^(G~I5WVI*@)Brb1*9$z;nbGY=hJh`c!+BW?vKGts z1FjX8OUy6i!SP;us;H(S0rLembjo!oVVCraAD3&Oc&0d zEmM)5m$fh@0aK~y1z#6eg6VfwX0!Qs;6`bwGTDFYhF%>fM@#RDY3a=Xx7mz$M784} zgU+6Nfm%sjb_E%xXPxDliCGm)-pE?`kYn{y6xaeUg#V5dew3Q}=wez}C_V$>&pq+q zDLl2Pal(_QDg2@fSolxmWi2{4k?>U93ttrXL-@x$iG^1+zwTg(wqI9nTw$b4R~V_Y zC=6<`;`0MfGe4Q_l%Kq;j2jZaECOs#Tyf3G_y-)v@bLs+b(7PNPIBMUGN}A$jJy}9Feuv90QS=#0aCT ziG_L4Cd}eTl-3trl$VvBmOvmmx?Fsw_!-Q#)BZZ31PT zsRUa1gS@PHA5SC@HJyw9Abt&jzO^PJw?!5g8Vw_MEd}#dbM-_G3o(I~ODn+Als(Wo z3XU=lVBQ(FOhS(Bvd$529*URnM#!#Dy!|1?QiXEDzKeXjbz8 zHe)`dX)g(gE5PGr@MyMl6~WojaCG05tiIILX=E^7WlL@oH=N)u_-XzuSk0)m#H>hj zOP7kQME} zT4ItbOjzZ|;vl-7psaFBUlOgeg;PWT{vS_=JSRN_W9^#WPZ78`hL#>V7#u6OVxMt4E=%OxC1q z6)?42ag=4jEp{rA0g*xKZ|K02ZUr6^q1=!1mk<&kSr~UbdZ-ne&L|H8Xb-%O;!f6&H&0R=EqVube?8iQ1%T3mdX6jFOE~XIiqsK9(xk;954V zY&3v6Ay0e*vVFEHfg!?R$HPs-ec>rR62{2DHsrADQdTeAqR^Z2T!){P%lvh?x zKAEUoP0NwPIcm7ZB0X5diz&+!?iClVb{E{UakergEZ?KcG_5qU^m01Hm5}Cp$SDk zHa?NRd$YL4wU$n3$e|QsiZmq%(T_U*C(;oA-jl^Wu64BYE33O4c1a7~P4NeY4R4lX zS>M>Wgpm%bNwAK0(h|>Z(LFMO$*6HeUS5m62}J~V?&un{yL*8B=oB4Rl6ddJs6KRx z_;ZvDltW1sG8~pNh(k&SaVQBH4$nb`D^C@la<9dKsm@w_AdY;f;!q!nN2v|_N8RXt zT6$E&kkdUJ-qQjhN#GovN2B_MQ*pQ)ACsM4+t5&@vm-M#WyDiu9ga#3Vxyb%DF2t8 z5Kea1ieE`;_$KS^Q~O)3cty)b7oaO$&q6q(`mQ?hffQt~b1U*UM;iZAC$1(Mrz2By zB=PNfaf=dT?lk^cFTN(lsO{V}Ctcj%Ail@Cm?MSv2gFlK6SzujF2(VkfcP!zVU85u z2#8lDg_iA|4ao{&RDZcqoSRB^(6YUD7Ri3sC@x9GVMD4ND#JOlQsi*u$gx*BGRz#b zRo871ACrkt)=4M&#TIe160o_JS?yN!&#H$CADbAmoqAR^(x|?EtN4*+G*F}Z z(bL3hoT@YVRBxUp&PyYU+SL``D#Z3W`0`_KhGsqg3sg{V{3{Uyk_e_4G&i@3)|#_ZzPULeU(Cuk>gIF`&|B6D`l_gcj5C#@lA z@S*VNzOc#=w=K5CgU{qq68_I-C3?LIPvn7UG zChm@mj`ZOUD@=jVb1^~(J&qVP&$Wt6@}*1z!;=Z*VnIkYl7q$5qCu{2w29Be5wOX| z1V}z6Kq3+W63@`$B$Dkz?cxnZ8bk4Yc5Nk;s*k1G4=A$n5i5;z$Qc?LBd1Yw>FMGV z>ttpn!J|nj2|`LDXdE#K8b_Gm^s?)aQoF{n2t*qH_37eeB?M_aCTGMFx+abZ?O?i` z{h>o#TwoSsOzwy%^e>5$^0jeM0jM%LX1S|=sZ+dIAS-P2ITNeuu6s#U-Kfzt)m%BP z?pAZ^ZgpO!`=Fd*cOQg#i0p3r(HS1g<#b!;XQZEXJh+E$GLSj z9wZx;(*js<8>St0jXo%hnwxfs=Zd7bp@GrR1e(H~qqs~!*YBKs@~)fc@5ccc)i*T5 zfYY8iK(X3z(lm_ujvRIL%1AiPi}1p=W21o5A1>)BM+v=n2zp;9ZHejOfA;~VA|o4e z7d$5~tI$*P+uh>g;waIuCCmMe7s~_*CCkYlMWks3%gI-hBMEWe-&mNXgg0)%lsofE zY|JX$WL z(wW3Mnnp*UNtvmCrADiNe3rPpTy_hw$M~#{!PluehFv61_HKK-VH?A_F9u2Q??pFG03A36 zmW#7e)AF)>ZPgd{il3CrjwUuwR#)RsQ3FlNlW`;}Pc+)pt1@!biT-5DYT*xBPU;IO zP!8F2Cxl&p@*HjArHznwnEm0h?qTzY^ltQxsp0BxhQ#$1iA6R$DgQU87ddWZ3#mxB z!%8@_qmshG)5?P_JJX9S4#kRmsQTqT@lu7Xi*Z`k-CN1N=_N*w7Bi%uMk<+)r&T`8 zj!)*}=^2zPMq(sRJF)7fu=r!lnj=pIL`cPv~zoXeE>DVu)Od& z-S!rI&=bTRMQt6%`>c@WKQk8nr(Z<@QW?YG7(0i@)qis*OXSK+2#M1Ehh=V;&m z9IH2?l&iqMd1Z zQRKyI4a!lL3t4lfrQ^L?Jme*gBgfKwympg=z~iI?PtPt(N055|W_h}y9NFZD%de5Z zSfRuH7|5NVVvsY3{K>I0-5`*=0F;}SRn5bNpvq|&9_?3#w{TZ!Bt3mWdIm`6Es|oc zu9U#*1|aRPAqQ?HB;WwGlcWRL%FmPm>z05qvV{^XASXH2D?i+ow*=LrXbD8Yx8+M9 z{ssyu%TV!s3ZWE!?T`AlM38)?OALyKdPfe!C@)6JO^d1*ZCvC`J0+uOnbJ)~w72rC zv^=+Pyei8}CHH{q#%NFS+GKfcSw#B{nQ3n9Tyv!P(IO`&+_jU3Ljnv60O&M7Fd7R!Us*5eRPrqo6byqB;{TBs^g z!#G``RMZ{IB_*EkDd$$7m070^4-BJO}sQ%fLN!3V}|x4fRAK zbSLWA!J*!f!7+sP4fFt=h(vI?%h=|P8%zC#^1q6TGTiJ?6pBo2#+B&f;i)1#T~}1p z54;nfsL~^NMMb>>_zy$U$i(<&dXEFArG~c)$vAlF$L&8M=9cRKS6e(S4Q+$x%3c1Cs-NVUK*eGFl6B z&suHtdm{=pGZyj`jm)7$`oa;c5X`nL$;x7tBuzuA#ng(Ys153D8y^@7C)B*Bs4436 zZxfHX3fb<@A7+zRH(qV*4l0vt@%6$h<}-1+zJWfP=5MLXi+#m@7{X+EcSCp*r{rW9 z!f_3YehoUFi2N+u3dYM6+jlg{=LPu^>dkoU(Nol*=qQJIyNeygNV@|s=+$ox)Nix< zo6kH-8Y-#nkw?_Gp?NYGIruW)#^pH`wBL>IE_31&x zpW-xxW6EOwFf&U(L1QlCt-k_Cdn4djc$A>aHnbvV)!$rm+__=KDE zC^7J_>u|~}@EdJ7I-+?WwBZ=+&Kt4ec=3APP8$y0&8xBD=$q!9Xu}r+H+2F8`AhpL z!ok{bWy$=c-D<;;pR_@pez60O&>CrU-;w+Q_d%tHZFm{*&)9I3ZEDDdLzYy!uUr0* zel_l1c-e-p2mVDHz8v_N4L=EZoec;76tm1g5B%Lv*}}o!eS-}LfA^3L2Y>geHXQuj zP>cG39{9U{Wy8VW^=TWv0r)#@cqwptQ$YTZ9`|88pSIz6YruJ(4bKDKW5Wx8+x3IN zkHfSd&|3@qv$pss3rEm~W8UpRp4AWW@%E2+(uPAeaitAk1$>7MUk4m{RzIZ2kkk0N z4JX;Iwc&+ue+YkMKU1(D*tao`Kl#gp_25Tg{G+|sFb}2ps27qR@P&-aaM;jsgu`~05Ck6&!3Qx{ zB>0G7WXJf+c<`6-N0?<&_)CociQ(Tc@g)B@FmELIPlXHAxs!mCo+(`9sc-?^Q#?_m z(hEPsjqD#_h@P6O_F2fC*aexYGh+Wqgs{E+awF<&JJ`y_oBzh?M4>j$T`ZD}#hPN_&fZ<~dUtsvAf)3aTrE?T8gnlJH#_%HyuV?s8hAgk+ErmN# zrzo8hbwR>Y8KPcF{9O#MUzLo$ z{m(OuQwfJYs_g#fVscIR1$aZ8{ny&VZ^xXTaJ0LAg3q%Ye^HRCFUcn|8J@=QzZm{i zL5J2K+Bb^t_<@4793k_EdMDuo!yhvIrGln7c=DeE{>maj`C0W6~n(P zn0gAsc7|Mjsdq5`KMJOC`KNU;-p>&Ag7~N1!|*2zpH*;P7DF$?8iriX^Dbxn5r#V5 zD+-^_`J2C$@$(p7#gOe{{!0o^XZ@#dV!WAQAH$m&enY_wH^b!&(MM5!GKLtQ&+st? z7qA`{4I8U9AW#UY0K8M0o{`^flNA7FS5!xtH{TuWLMzT}+@zs&GK1(&iO zmiie-yGU{@y`CY{Ij%tA$Bi(2T)|~rPRls{GS1g>*4OgSsd(AkzGa`wILmo_y~2-Y z`#%0ljK8Gdij@r6URI$0A^A@5F+7{$qYSw|=PXiq4$GZ$7USa#KgAIJ7ty0WT0+*t z%J(pSIm7!D%;kLNzNPRJmody^$ox*+$oO`KY=+z~q_TRy9 z55r3sev~2ScNN-QN$-aYpJ4b4hJR2HOUyD}9@|SEmw#R{`?Fo;G2cA4>pZs0Jm#DC zagKiz!!I*@iXrpO`!(ZSukbaKZ{rR z^9;Yj@NR~O7_xk;|HwGE^Q*ZZ_d1oom+j8WdhwRAe+|P1hC3Oue!LTmbA9u2`{8AM zd09_hZnwN__g=Oa?=zhKuMA&j$n{}Oroz{p#IT5AIm1SVTyAUn7-zZGu>Gvza$Ljq zv*u=w_caCAu^a_l?+SXAe*yQ$1zf)C*?!k|s_^yqGW;pSKQUze7A{bD;Ry_xe&H_0 zS&xO>9u?lg{#>4g-(~zK47pwvEme3?Aww>oqSF}Pw7!SDr! zFDdBfcz)KO|G(J(P6bQYK1#S=mGmorb3FJUHeeivoTrpHjAE=n6`MEHjv2+c@^HMT z7jUn3VZFFmE`$an6TQPdL%4pb*z&_x{7~5LL1)G6I4*h~0l9-il59w=+Zx5R)Qgqf z;9i_@!htMx)AF9tNHO#3>BVcElf`>RMw*c;iqt!aE;*jo}L51-GL zGH&%agoLM$Q>imIyt>y8;ST|52 z!R}g_pl)#I!P3#m_CR@Gf&@cj17ldx9ExByeYAKllI@w4$@XsC*3~?CU zLLr$Z&`d8r1ShBD8MDtc4_ zveK}e9_3x^Hy9tHOUuYYl!;+$!YIaWz&M%E87WV$=|5Mt51Ek`T^iEueWP! z3tqvkoh)tfc6!?b-r7ygB_-Zno0|Q8Zzo($fk43TZQAL@h0UEiD!lLQ?AlhptwEuc zK({t~+vry4fHzQATjlKtoL=Q^?+A2Oc>{RyZL-8@9_aOYJMdgfcx>G3h0X>CdgGSq zZT7*L(e=fv?8S?cNycEJHRILxL&=jdpt$6!%w+Ou3oWkxak;!b(Jfmh?#UQ)jPU9$ zOUt&2OftrukPO>8(MZPFV`#*;E<`Aq<|P3k%OH|zZkPbItaG&nPCF-4kZCQ6XJNuJ z<(!Q`rH*OcW@!O78gnatN#Jdly-CGVV=@J=t3C`ZnVPR(fu-n4)N~~aA}3R#Rw*Ju zGBr82>LOV(H8<+@TBJ#)rp6Z!5++kKDWR!_WD109BK25vt%;m=PBl@cwM;0PaRch z`ajc9pvm+03*_ne7oM(;;)V+LJd=N%rUcBfLmqa#Y zRnz$USgSqH$hVQ_Hl&JT>tAmya)_hL&^LX`gOr3|igv$NTo( z^&`XMqa%Zu6*Nu^hsFo+zHE2=85?}v(g%t?gMD<Bq^Mz43KE+AG;mb!NVS}3V5P;SI5M|nvd}w{OO-g(+v;1sNYcg z8akR8)*KyAJPe%D>Yt_&L(kz&j-He9n}}XD{55SjotNXk2K?!t4vUTVBqAgc&y|gM zlsEm;^kVYi>O+LbbR@uO;<=Fz@udXuV)U2t8^pnSk@?f~V&bLNfFAaX%pb>dTnrzb z2F^6f>&MMlW|-sMG4Y;-4zG`oXJ9SPPA_8$IQi+H=8Lr*W3l!`Ew~A8k`HUy2G(Jv zExNGR)de@wP)(s<#%J-Lhg|&A^wt2k(<8ge#2?YyfIrZpKb;Sg-p|1{L4IXf+V~z9 zL3)x!|Cq0|HG918LN6IQ5+KJDSWC0ZmrXXH<->aKbn<0C51Ef3T>ms*E?=FG6Oa#M ztBwSy*wJ_H||e5=NRYx%J5JDq&1EEv63{LgJL zNNmxOZ1nyCw=EwPq+6}$b#PCk=ZaHtM#Y10{nLD7^t|~jM7T*u0@U$h@^LbPN*fZy z`wskU^6jTMT0ZQfO()-eD%%YF>7V8sBj5hB5Mf+L0@U$hqxe+y>M%$ zaGtXi@rWkY=*@m16YgF3n}Bb@Sa!u0VjxBy|A-ib5Bqw>}9NcL&uyWmb+JZht+i$`{#>FNHQ^c16)3w{GX zt-rz<==}leydU9|U$Vn#_+I*XglWE1Hagz%a69qGze~T1YV}o(0qVL)Wn+tX1@`dL z!wKSvNL0M*pGBOW*mxVtaKhhX{rqKByGC<}wi+vag?GgVkRO^9E_Uk8S!kd~f0B#8O!(wB8W!S(vo|9Z#xAb)-7eTxssKl(f{ew6u9?^V8B(Gt#Jy zjviT%O&kjv`F1%RrW|RGG)s;|{HeEkjO!@B2AIUx6Q;Spjrv&|{e_Pqjzt9}_0mtc zI8Sa=Cj9%qoF^(G{Q8fleCLtX+%v$5A5ux}+Yqp=pS2Ym)!; z+~kF_mOt5E4Jx{5fsPqn)ttGV&J8IdWrJCcpT9B>S_%ef0hI#$zD*?+n|vk8x3jCE9=>=?8Brv{A3Ble z#*JmZjmyxl3kEoBr zqC(8i!lHcRvWWbFI!lPkV7bh~VYzEN>bC|fI)gg0-J3|@U2RJ-GIH0}?Jael(m4Ox zin0W;Ybgz02Pb(=1-Ey!H8$Z{@ffC!f!Z$I91+}F+uXRbt)n42kq%Y-qv+|N1_+ig zAh4?|&?-OA>j-RV>ckVbDB$g_T`X{IdwplHiC(@1+igr@eDB0iuib5`j^4S}Hm)Ae z?F`6j!?EFqiwkR;n}fBToq>)n%e$$i2~nE^I|9wDK{BSsc1aF*W2ljjSI;Ho+UFDT zjhU{;&?#2uv0Cp;Ta#wp?BFQI$H?k?b&g5#sHIzmzvc8UeR>dY!qOIHaIeP@8FCY- zzPYI`s#^H`8x64}NSZ;}2C3TNMFO#ueS-DD&h3qj_v8Dbnb&M--j(vr#wcul|ywnAR{@AXYp_NyO+pF{|r#Gnu}clIb8vma3pDn7Nl zJpK~2pzmTfz=;cd-pyR#Q{peHEUPN5D1-NVm<7Bo78^@SN=qwCe5DmtiJrSC9u~20j(#<)!d@zx1Qrz^|-iW7)=v%94%c6NWfXhEQ%KE3;7i zRb^!rm1Su6ODlaF%gg;0{&Fz;pa5;u0ho$ieHU5YF@atx!`5O852oiS>P@)R?IQt@f*I-qFgx+7^afxnsmD}I0y^)z8N2cY)x|lqn7a>m7FDm z=md#cf(e=ADWOMt)D+rs_fsn%I(yHE&ZaHF+OD>irusxJ>o20hk=AZ0FCg#?j62|M zQ;g&HVrTtUJZcXa498)OkTU?r{w24C@UsG+2_Ig{nFbatNqWD{uXiVf4=m$ zSeRx>JT7#A1r;pwH%&)&^0Fj9DAP|HM;5o^D_9ef8Nsq1oVx#&>wh#%eemaH21ar5}AfP7aIoj0oQws+G0OWQdp~=6cmg+-#k)ML(BF z;dxGIZ_lXVa=6F#;>?BNa=B@CgEbIq5aJSP=B$WgrTewB29YIw=x^wno zQRN{F20`d2#72q24hX$jY?3I7pU~SxwWoc;Ona9&S)rWxA#sYrIrY=xRE2Z$7e%e4 zhFePU8lmRD#pY*9vDM~j%F<->G$lGsv9Qy;OSITMP3c-<}vJ&^%xT2DB}mO`SAd#H4X6#oiJO~R1MnCart@NksHS0aZ5P^P4x*QK212$NCkKPA zZ8!~wDIN`a@iO7ySR@?E$ID0I@rlu4G&8jr(su?Lh>t%0kC{OJ#8|kGM*O&CWoMvv zTWs)waL+yp#=^t)*4pN#EvgBN!^};bqJ$Wry*-9 z4MmRO+%qVbCO9gTL6^r!0Tn&0sc1iBzhirS7bq|*obAQk>4ta(4P9$nI|7DBB8GSq z=+4F_pa=Q~3~|1bP}1aqeyH(cpq+soK*z$9xSIiJQ)gZNI#1t-=iTHR+8geh7!2bM z+tE?H^qs%18omQ#z4^YWM(Iuz;~dX{z4&&-lkeM(9Nz$<4M!*1H!GsI5z&^TO4>Ix z8%e(gqFAX$4)LvsA)X_&t%Fd!W-fjYv~F8_SN>$r;6#|p4qp`Y?2C+`jM>i+m$+!k zb_N1NgYPo?nFiS>RLAu*Y7rFw%WVa|RVeYM0jALhP=SA=5|M(;%&vo7VBEC5&k zQ;1S$}0d%a?}b?-J7N%02IZc_gqK5Iw|r|@exYQF9e@4}RyHlWP( z@;>U_A$2U#NSv_xZw_%GH9W+*slBsfMz%77=2?A*Q+!k>tvy;&8Np0?*ePz%NvDpM zbQeW1lYZGHKBtqmcec+cZ~N#-2v?}#NwLtrcCti#`=$xiyx|ge(J~3?OcGN18Xt+Y z^;1Hbiq$p~q3ZkH;*gf8m8QUWp<^QZENfiZUXchkQ z@VA=E0c|%{;{zC|_<~!5TLP_tj;4B)M4rPXPNngSkH;{2uc4)u7Ti4L)Y)N35g!3B z4Ix~1hII+TJv3m5PbJCL)Oh?A+t+#CLsG?YCcoFhhI7BR zAUa1!Wp)m-9lb*|O<$Cx4Pj6f3=R2;_a?R;n+=e@Q`D}wanDig$D;b5XgO+py9W88 zoxPLDc8)`1J3dNxUD7%?nqC^`CS2#vrXYL`igGoFrZi+5--}E3P^Kr)0Jj5|UYqN} zD^be4E{rj=a$>o-vUPhi_QI+NV9h`->A&51E#*KJrB&BI%Vm}1yp~BEvvPxm<U~Ek zurdyp`*ql^OIWV(jhbp;^p2}jgZX(qbZKRtoFQQHv$b{ywr#Le(9pKMt~o#(I+dDy zJGQKnBaU&=*f`BOs&(4N_Q0Ab7()*o!a0#|MUqAQsmYq26TO4s*oa54o~F`GN9unB?!5P)BQV#xeEq@7#(Mb;Jn7>fLS_bc z=(o0!LHw_YbD3hh_k4#I8Eg_u@&jjo1kZYnjSci4l$y&|d)nmQyxGHu%I!MODJWZ* zO3+HvPZ2l8dBYbnKJLWc;u(RCHgrQke?lnwsMa<#bJ(AA z)SfDjZ-ML{O#Cp?R$Gku`7^3;?OKlxKbSzpq+{y;rItfOk+OWSDfHwYT({1%78$}b zBFY4)bbM1KCc4Q?);Eh}(94HhW(IHrLC@g7BNyr_2NcWfaxq;pC2CqMYLzyGBudmw2I+5M>HlrT88WSK6^xSFgPA0ci4B3j z$O0eZdZcQRDoG~YZ>vta)ryK>g+s1yLayN+*#XR4sdc+3qsJJPA^>U+5H-BBPE`!+ zg1Qx$v7yx|VrgnJAp3ogod8{2a})0ScNi>P%tAk|ycRlhv0L$E%Vna-!Yyvvo9G=F zPhK&cAWAP55zu_ZO>HQKBh3x|{C+IY@es$>D|`BB_i51HQPcG4hqjdM`Td1mNhdD! zbP<8aECMC7U|pz&m#Uuz9mgM1tSlIgKiaT%!|^8zEioLo&bLOXYRum($LDo%^Sb0F zaO&%IIdE2UGnYCIZMc#e?{o5h!D!zlha%Xoaw$ET8(6XP02xnC1TMlh>f&}4U3y%B zjnpi>PIldXIROZdj_&Ol?!!jH9&A26Aw=~}4sn?{NjD#A(9mxPq`-4n7X^b+Z$KK? z;lbC(9pcK^6gt5bi4vUa6xUh_s4LRZ6Vm?zEgzZ^A-ay8koc=kaf=n3Ix^k->12|L z%8dO{WaLnE2ZMN5%(xk^;L^gQ$<#(hQ<2O;1#o&QFS*2>78SIHrtArG`boF=MpX1D zW<9hRELYK3)G3zrSvO7|n6j#7b|yy16E zLnD!cBySYWMCC}dznCVz?p&>tM3Yx+qRXDx{47m;*}b~Ir+3UAzu&ebih4w|a`_YW z`oy99%JFA$wGy%Z6k8iHtLIsV9*-lII9*4RH3}Z*+B_)27c_1&=Y9%!H9-LU9oSi< zvAF8l$paHn(}VC&nz-zgiJ0TrXg_#4)#6XkG!uAjQL)&IA{|gg4cCoam~cLTst#!=LIk1p2iJ>kEn@<9SwozuG-+~rG8BCrqH9K^ZUN`^p|6Pf|GlX z;P6HRon^+#JbcvHp|sHuk2>0$Jf+3{GJpBTk_w#itJ+w(5%%(ggAP9_VY+Iu-Vvlz zGoEtX79yUsg@J9bb8Ay$7iNig?84(G_D|U(_{((!e}#_lQwMJs(TaL3iH)G}GY2!p zW-G0?QSN+G@`^sJ0{lESRA#dZA^(khwr|JLTa^xJ>MDG76_}d;)*-ie%cuabY1rA+ z(tu51I)6?l%jJHs-nKQwO-@xn+glUvMGx!U=udJyb44aCW zlxg|}`OpcSKJdf{^kYPA-?p``D<8+?{e}3ig#If3*{J~B0t(+ zSzaT4w0a(sphPB6)S}W*d^OgEN*-4dbk)sO0*hKA2~IxQlRyIEPU+Us$nsYt0nPyI zugstH6;ApKCrb(^<1|1%)8wCM#pZuf<-RJRx@edmE$pOUQukNH#n-Bei4O{prlc$; zzKTusk+H8-4q_l3g|fR6m0LV23I$Ftd!zaJHToMuk=?XM^$caNl9 ziX31?PdMm8`Y2V|X<8~clu!j0jiMxIJQ$xdi@>z$ZRPNIWpmrkp!$U23>@BRYYpPL&_D;; z$)^(p?P}^m$a9rVI4arJ+PoXR zW>eM`X*A@~_wSJy9EUdJ^nPmTsl3O+`>9$W8_8of!#XC1I$W-}=~+7oONX&0#*D0z z8*%=~-M+sP(=hCb8*hnoomuU8T3g{_f%t%PNxQ7(a+f>@2atDK9K51&}OM|{GWRq$s=M(*&$P*+bx?Xx#IRvWnyoI@DL&|Qo;R=aW|^&?@t z%C68fJTz=PErsnL7)8Gck%vR!;QmU4*ND5*+y#f6Gm$(LO%kXic{l+{JXxHD`Q>*( z^BUI-G#$&LXc8)E9!WqGFZE`LUyC1s=1ViuJUf~uP@*Za<7v_h*IABA@pI68!ktO# zg#Py6dS+R4Q3_3v``pOL*m&pOfqpJ(2X1bcOnL{f%G?(W^^Ele`}+M-*Fkz-JR9v8|+Wbder9oIZh!xHb9mTlh6do#IM}mC`k=LR z&0|R}1gVbxPM!rr)?CQa;wvmqEKhrGSWBDk5j># zPX<$M>h6m?t%+*W@5T<{%o0w?7XanDG8WLMKAcexDrgi zvof2_zXLbzN|nj}TQ~ITI5}E+S4>N92Dr^;yd$a|2N`ts+zZr7>ar`yFg@!m&rHm! zVDd)R!iOBIm!iNHcp?0Er0}EE)JGT7!b0&G2!HO0|4!klMU4}lJWb&jUBJSBA}?#v zxrv0Q;$HZoxF5nl=1DBPs`+&XOSJvEa^ngkWxB#hokd|#ixrWo6uu zATQF27TqeIL0)cOm7Uv(;TtlykOrPA4;_t-T{;t>$)+HEvxxapH5QTOOCO$Dg)C`j zj*7p4_BZpgb6YhTBe%8J(u^Zl?bqStrXFo-E|{l*0}QZ!WQ>Oq(gzvtkcPH+V}guk zcFBzPg~nssrOY3R4`#Uw9>fSa8DWegvbLIIATpB}VU#toFb~>i3Flq&*DFb zUqhg8t;xu3k;R2Z!-!o=!MxR6JyF9#OrYh`3a~U~544Vgqs#-CcZMyKkj-<}IpWRZ zG3s5LBo7`0F%MY?GxDJ7ne~FWaD}_z{F9R90Xu_cH4n17nRrOkUJ?*jfXB<=(QN4| zg0rLH=)NmieW|I_$Y8w6mfR+8IKf@;)BIVmno(_uS&`=|# zByP=d7hJVIcI79EDGvlqrj|ii)I)e%3>-?jEc=$(IxZ-F2oA3uBMxJjPlrbmGI~J# z42=G}aK^02g&?cO63Vtcb5>}9Xjy@H0URDEisc}evvdjZ+)yivP+RSRIpbU0*hXO4 zCF1^-?t<%zXQa$FtSQIT{dme`z{`Fo9s%W7k3w0QtV!7_U~0MID9eIfeyVs9l%L-a zYp;p4u}_nh>d1{u+Hqbo8A!xRwvo%P6?f*k3x436krk`QWW{yEWJUOltVmzkZgC%2 z-Q}N|mC~2RiWFwcl^lntCNp8Kqyn=e;t{a=c!^|{czHfi&C4B{P(uT~)HFn!+q_z* zDE~s-b)viA1Eou2J1g75zv`>(<&Y*R)7l|A&8Q{?17Du84ceK>!a2TN{2t8yHWM>0 z8qG|V3}u4`70EKA;yM0iajnN)@SC#i>2o%-&T_-U;n6(@l?F3&r?7%bi+DV6qwLWD zEJmR#7KtB$?YR}68Q8+SY&$74=Ml|oX6`6P1QA|6qUcLa*+?zfQZ{nsC`*c$O*Y{x zE)?gjau-}*IfF_PwMo+!He_2EB^#yAv}A*QELF0>wQO41XaIFWp7;i2`)pMLLxjPO zhnt4`!c%%AjFEwD$YIx|tX{Z9p&>ljb5KWz-JsGaudJMWGEupjmLrFA)NqYOda#HW zQ2-rO+m*xOj@9n!+iS!hoohpb1CgNI{Tz`a7iv1Z7~@2r|2u;7cE6~> z=Pl9kku}=ih>w35@h{#i-tStY=+mJJ(8rzX*a5|Xz9Z4(pGNe%H;WIum^?=}$;ZYg z@-J-`*SOZwi4HmR0%eh=1R?rS#|1?i;{WMnagS>q?G(%AL1mT}d3IC$fnmd&fo87phN7p#G*^f@$VdaVUI*jVSog)4m zB?IM9%WzoAAPy-R#Gxc)I6Ma#zH_ShlzS}>SasIogL33U6^Ht$JW6fYZ|X*O)zYIH zlAP}0@SYY3Ndo8SJQ~$k)Z#EYK0Z6WwxOX)XGdmg%7~}RIvkZ6#Kt)3QT{JGEu;Fs zYsIf5HGISM_Nm=mCtlIA(dFAp*Rv4LsQz7@_&^G>*SQt>nc!PW<8)+djwJqA zFK$s{%$>#;8pPM67`2_d=A?_iG>Gr9F6Kz#%K`C}(gdy^n@e&0Js^I|dYB`H&ozoy zC54vloejwfVN}1+D9%kKJ80QnJBwu3Y!R2F;&39>4wc~?St)Y3a^%>n92sT~+NvLH z5g(I@P}WH&`tVk9vl6hmmRapq_0Ot@3Ll#ovYnDvHPWblbgTH1nSMIG%tYWLP2yfA zFuh`DBJiUo@u-%dnX@pEFbnt^DK-lO(A(vwiCx^(0qnQ=-#ZgYdg{BiEOm&7E|Ed(c$rtysVUt>OVG%kE~s*lhYVWbslSnD7oxG zZON(c=m~|WQ`Y?@$hd!5eP@ff$418N;@93O$xtU~Cv!NK%wZyPcFn6T;`Wo)kTm$P zcywP_<%hD-g!lgl^ioHDcBH9i5Nl=Z?hWI0K%?f-R`Fm|VwoGtgiH(|6ECwRhFd1? zj*O1<;m#{enb31FLI*>R7&RYh6PM&mnFfX@6UfDakZdFei>F0{T!-7lXW|IhWMcv( z9}^%Ei2#XbXmJwB_RV(jh9Zrj`#!t25=w;!6s7X^1Bz^X^h)C#a)w66$Z6Evd%F0< zI+f{>C38b?fm#t|ksz3e)q)UI(X8j;4Y><}+2AxPsfIU|~8x}8y?H$bX(_bsLtO}{ju%h=Jm49M@wMUepue_2KnYD z)S~+teZt3HkF*2WC{? z&_^k;f@O2nYRwDX;*Ze+ zNnOq?&rx(~O*AR@|1w?v^&R4t4N+#mxI*4Q4%u`kgi`|KIoiZa8zJp5`@?13!{(9d-RK)r!__Z_#Pt=4MK(Jr|BKU$95=Fs zR3zMCC7jt&N#WpW<-wMn=|vWYVnseweO*|*R3YnPoR)R>R&w3+5~D|p8PZQ9mCVP} zDj#OYC-d?23`!OwF%qYpxa9tRah&8J=*s_bAE)0#ti&j4~e0_ z>-m52B`WvpI0HbPP~|RToayrae0mO^pn$_c)`)F-ile`wqA=#iT1*S zpq58w3f_IRP`vJFA@xX@B`C&xyC-?1YY!bG!|q`i3p7fR7iz>X7HOwNJJa%_$cxt+ zl%p&cvgS-n$J?Mw$VrZ+`FQmv2Z6^)#{#@|la3(u4$ks)Lpid^50_vgfw4k|`!PT} zLB$|v4*8Q~Wx7EicL69jEvuS`i$RssFg)6?EWjoh0 zuOSC+CnVqiwUeX+*~-t90qd54F|vgcEFdR2)+;~UnYRQcT(ktD;2ZNL5Pt)Olx3*+ zK7~*UzxGGHTOvrl(j^APL;WL%VU!mm<)%f|i#9HDrk#?}v`p!yBHCMdR$880I9`?I zrILHVbz`(Ad2O=1wk#u$YRf|<#9TSr%P=-u9$TQRlP%N|^;D?rl;{8wmb_23yp_1* zS!;RPh~O!>y66B&1m5+QHxq$p!%8U44|~i)IRq497>$wo@ti|#mwDmZIlPR^41Mem*lNPFq)G$t0C>3?b za!HBoqLZBD=u&=$v3<9t(qi=_%|mL&RE(#n4H|759~cTJRKBOEDe6;j6Nj(;ihjF4f22)b z-FU;XJE+XA#n%h3n9H~5Du-?in7iebAKm4}zG6RYVY0ltAv}o_b21F!xROP`F&s}s zr8U{&m5S{fBI2-af#0uHji1RA{u{qf|W0r(bnTW{2r}Z5VpVC>)>LN8uRxr{ie_^M_eh`f822 zjJN&@d^zJTL?(JPYNH?Fpr?OgDR4cfAkS{#^4V<_Lx!VSH-8jP@80WQ18@wF%pc+C z56qtjIEGyFf2w_yeDkgRI!L}K9P-WY)$x&@Nd86Rke+ap9wi2TuMVfo0>9OUqw|?} zsSU>fciyB8$D7IX-f6?pKh3MR;pmU%t+nBJLwz1-s2>pIFYQ@iU~RavWPZ|ax8cZ7 z+I|%q<8X&j0US-S`T_SrrGK#Dc=0@y(#s#hPXNBhhU1<4)O9v|HRfl3w&Cl6f7OP= z7E%t_aJ*}u(rClMKLt8cKkx&8_s?xO_`5%8!@=JjvEktFHuZ({;O|~)3kQGKZ*4gE zyFO#XHvm7&hC??l@K8U{!(G_UU)XTGGvNF$8=eO|WWx)9gNOPd{W6&R%QhTk>G+%t z$GuaIvurr#+z#_~1Ej~hKjJA{INmxCSK07Yz<1hklnqv)_=ofuW*Sf1aJpyxIvZXH z_lNLD_A?*$;{+VXpZw*)dhnw#{!#rlQZU(~kVoJo_#=itfo%d8sFUO`P_8n(g`q87 zDyNeW>C!nJ;gnALBb|g*cvPI?*DxL63mBK-u%V@d!*-AZM8b@Z;6s=!68r(4PmS@H z@!&7vj}0T6!vDbdUl_iE87KMw!!SI6qy~xaviK~s(>)IpAHpv*j0(H|U6@o6emACe z1fRrYlHjiyzOEom3CLd{KN4+Ug2*c|cev=`~>v&7yPS_x&cfxigJe6UP;ky`K!SG`YKhF?)km(L7XqFfFRfDea zZOnZM>T*PTQbYLHQN(ut^Dv(z9QvrV`=5*XDB%}i&dmO6?BTZ?Mit>-#C2~3pJzEx z?j#qLvxJ!pPh*IBFa1#m2s*U>P@g0Ydm>0vb_rpp5>7DuA;VuP=vu`Pb)Mq64l=x$ zA;))d{FHN)f6A{I{$0V;Qy8{0gg7dN% zdKuO*py)HP;bRIeU_C6zVZ4nY+CfUU;JXa}so=uR3|YSm2N;KaQT&B(D7a_= z!?g@+8NzNU-Xhk|qURWYO~K5?3@>B&Q-;4$a54H9O22qNL)I&`UF4tj0fyHwe32o` zwWLMiOWw)w%M2e>a4G9ysh{x=GQ6H4(>bm{;m3_Id|bh0Tu#e4{xZ(ja@N=KFX z+`eU>%Q(wON_sy;EI(D*i*u{|fczPMrhG8AU(-@w~a6iKX4By9)?PT?> zjB~rT`cB5b$M9K(zhd|j!@ntrg=eV`FWbF$HRJ0UmNIN)$a?YiF+RwU?cB@t*~|Lz z-ooK`F#H-r)|Z#{FwAh0A(z{ls~Bgw z*0BAo;c{HV_Os?E9PhUZ7O)%zT<;1#%Kkr4a6OmrdbZ#7=d(Z8_rer~7v?f#{T6O! zd>cciUw9GYtjEIdGX4}pF3-YO6kg{~#$G_LnMjAE?N z6q~oWjv2+c9&o&;7jUn3VNJDIt`!C&6TQPdL%6D`*z&_R^ibIDLFc6GI4(sV0l9-i zl59vVZ5qY24v59i;9i{X!C@qIEAgJuNHO#3>BY;Ilf`>RMgp|GsiWWR=GT>{h+Fx3aOMldp9x*A^o+%O>*jr8sn*A-c z9ZkVXUwLJ4m%NGBmcWcWJW9lZ`y(5>LL*zlXB;d?3i{b1>l+tAyXpXi1%0CfJGRvM z1N&ObuVdz*H8al3Kn zjtcL4JG-{kZ);F!CD5(S-Zr{IIp7V{)mC{s0;gAb+dBfCRo(!eN1H4$ng@El-VVHN z5*{1(dZDwyf!_F~Y+IRgZgh?DDueN&Xp*s*Xw`VN0a5Z~EGRCyDm0mV+ERmv19bFGV< zc20FsrnPJ+nS!%RY!xEaqhv}kD)rl|i&FNe;+sdC$CK*eQvncslj7>4_ z2?m4yjlnpXgP~xF|Nmp}OW@QI zTa0hWGHFAzHA|bSNC8DeM0g0w@>r^%i0D%h6_HH^MC5^hTHL_rQb1fm`$XmcJ$LzS z^P6N6svqC`{C}TJ?!D)pd(OG%?t8qVvZt~V81&|Qq!}HExdgz`QPFBU^se;gJSLM* z?}}hgZ-S?4>&p|p&><_pD;Nnucy(5t1Rh9)bCuU5fjiLW1B-${**~be7Y(;2?d^&F z=RdrgY3X6kYe70$7a7F5=_l8>v2S2xa(r|Mql3n&k-o`6Jj&YbuptF!Jo-VhXQ-c_ z;F;8d7$-LM#Cv)N`MiFfw_a_8!MfuDwv4TCorwM8C*e+DET+1(`qC1A4VHygu{;-n zvfz=U<#}K|2?I?|Bt4sBFU0@F3?3qY>GuEN7Qf+HTr z#TL9RaAQtH|44rNFdxA2xC8$h;as5{CchSwovfH&Uxwxjq1xk^$DVEAX$-0qqON^*ceX`()bXVV{^s@M2Sa&|mfZ>Vxq`VENQq>x}L zdVho66c5^@tLwQC_9XEr&&56uANVsS51FW?rlW)`yKZ=X`6knTsqa+`tvHBFAO}FcseWVK>P)MtLs-KgtKE z;HUIwt9Qq)#Ga>*!(V-h-a!DA9oGHj_(wFI#lYA#9$Gh-y z_$hiSKa;#Rz88Mngh#R`k?%rE4@HmasAPCl))byBFBkqAFr~lZ8R#KB7CZ=l ziZA8EBz!+`H~bXeaueQ3u)Fb--v^#Ru_9dcsj^6EW5T=Q5VFZ$g#=UKu`vtYb+5p$ z$BuVeIhIg-#uq5BuBa&w1S(5?K0gPG|5y^KtgQ6;%F9YCVBkA<;RT_VM&?rNIA=<4 z6X1qRsld_>JbZ=P*;?e@ZB1kMKG-z&#igqc{rSx||Nb>9VImBnu3V!XVuylOL<(zoV+6Q3IsXnlPfHTJH>*^AI1rL%Nbx;w*@;mt_PNYBW~Sdg(WBQrfK zgX(T;kAw2W@t{#?mc!*Jht7WmmqPqo7+n7D_qeX$S@0=YR^{t@DIY+1YvnX(Jtw2F z<55sm44Fs9$%{gTzyHl~q7H|4#(Q0CW14lsmaf)NH8w{Yj8Lycj7pJkbw< z7izBasd+bl9*uP zN9c%lHiR1+`5VZ}} zrN6usFGo|AW{1BQ$Kf-NnvU?dXij2hr@YZ$04p|e9RQiGJ48ap^S+&v+BL z$>(05NvzydIfhPgodBlx-5KjLj2jbNCD@rS&VftJxwM8^I(0F}PCTe@Pks4S^k#f! z4DYqlYG`ba4@X$|VpDxfxXx0f{DB&cEsv2_kuPFYWbs-6TOlE_`dFl^u@R>UW4@sw zjjg0-tC23Hh5R+=Y2VtlzJnS&QGx~3goEdsar#FmRye%@JVKHBAXO>2XOR;_C_uRc zCVuqT`AIkfDdEY2k_1!9!so{Dws2b${d~Ocp??}%%d18Zjx~hpTOvNqwJsJT)wD%4 zR;;X0+5~W_W3Ayf-zJPzG&Tu0woGwAS!q=zKvMuApAo3=-TvvS0r5fj{qVta738DG z&Ws{42Y`A|@Cokp1xiu-zC*Hso45e-PRRw3(m;7td39N3Il%9dEC4oG)RdN%l~tAc z%POlY%B!j>s{K`9aRDh3aUlv7Xm<}W0#IZCsjR3d1MET$qu2meURqOLQ(0A7Q!%Bn zi?|QPhO^QWB~V>nURhO+HlwV{UsF*Ls0>tq+4~r1qx>MNnALZw0k&!J{f3XTGA}a_ zQq<`OjSwQ*T(wsiP#Jfr;SU)eQUPW~UupR2N)WoQFLc)T)m&q`4wTwIYyw-Ae~rn< zDG9DM`Rg*wmJl~^xf}I#Fy}v{(~Y{fOb?s?f9U?ssdAIwZ!( z<^=ed?&**^AJ;u~#mt;IpAfo~da-BrPa3{b5=&XQ!|--Wr%xH)x-_#T)8{Dy=u7d+ z0#>1IjeSLjLq-Y5jm+#p&VvVl2T>Q2XzURRfkG;)9lfeGRZXhi85%+k_?C_jLZ+(O zAyaewCpc%$z#71*CYa(uo@1()NL8UJcHc8RtkHX(MZ!(7V6?q8T<=t~{?Ou&u;!fd zB0SGQp9Nr(VqCvsJL;S9;5=l|Tt}6Il=&OwfOP0a{Z=_aK-P_0(wLr?I~h0GY{v{EZ+;H3RZ@f*{Lqh*6zW@Ix+&icXNXc>rI?!3J3czlg&P z;tGB-hZ`*PY)L#Wae)OTtmLm}9p1?Elzbl#pA?5Dx9jtmXW|jjTwj1ywZHnTMh72x zH6)DaY*#8!2fV(!Zg7N#zk?%vLsR{6Oed+Wc)Uxc?%~4uMm{U)S(*wFoy2@^|4115 ztDcyLrO7c;-=3av&ExV;?7`*^&ExUX$O!W)MkmC>GV~FZ#7@@%DwqKg;SIMzr~_Wr zF}mONGFI&)7cvAnuVXdbiF`oL!)!BmBKgUA2dnjUOzC0oVW$hH4E!iNL%3z=BW#;+ z%iu4uAg6{KLGee2<=PLSS@v%gHhDU(u-cf8SFD*oF0p{ zwPV{IhKJPY#jAls6JzndLcB^8pPU*WK{XRZmp&3|AU^7}0Y(CaQxoxi>ha^&lO3Vp zcDwh1c+Xz)#-v48Td*bE)D~*sLxVDmL{P^T6=E=fcg^==eu6SJsoPhy0e%$fOhiqD zA!Hlpo*_Q1AyJ_Wy3BC`eY=M~r*QHTD`Ry0-QXc#MpWY3vO+ zcQl6KJTNe*v5Vd0BuyR|fEq7@GZH!*&WZSbja?0AI8s-*!Ph_PdnZBr_QdIoc#*Uy6qj&!u|A~J*6E^F!k&m8$}vRn8q&m(2(sM zc=ipwLvLpqc$-k0(9VbnRs82m74o_r=Y zBPjm6CBcRD4w-qO53%j}7=0QQkQLmF?s> z-9Jh5+^Bk~pX)f!okLzYe2R3{yQb7-o7{s-?~tY^QwO&bH&W~K!mE+Wa$XpHW?{v2 zaaCJa3)a!9$-tZeUk-Sy<64RVHav=?k}HOvlxdaXxK@%lZs`UM^Uvck2A*i{v<_O% z<0FyFSTWAf^N$3lJxa7cl=hFFMri|$(rF-`GMJ1{nleZcHBn%msQ1s3VCB-Euk~T6 z&oNyAwG1`Td&hOAvBLZwxcFT$&wLhf^bpM|M8d!;Z1q9zY=kswSk`XD-a^g+OVF6KN>ral0o_gd>eg*b`;?3g{s0yDU8Q3^M*U&)xye;nJP9K`?+pMIeiHZ zyssYX#liE*!4V>e$+thT=B}nt>};$oqJ|zA8ts|H<6XEjKHL_LqK5$ff7Vf2fWqfN z`bVdFhvIg`W0+49;gXU1ABGF*eP{^uxi0@etg5k|AGs%e{FU*@;DY&n zu~dAqONk6N&XRoFJurqRv?eA72M%)06^iw6vTxn$lMWHv4Zbsww#X_mBg_CHZcYFL z3K^evV_ou`P-i=uAvnKFPP9>N?WpRYp>n{UA(#Tt`pmNgklG3P3d;a`j^mIzXtn4y zj?mKHROj~z4<@x;6)m&eG;{Ip%-~?_6#=|$M$5Vx{#8Lr89Nz@l-5B_x zr!AHk3kzpd;rjJH<$usY#iV0u|GAd?hR4ba!KT<(cyPl8-+Dv{Pj-kbK&j)OF4diz z^n4x_zP1OBH?o7T!OvL)X_ju1jqaK%A2oJ$^nm z^N1b4T59W9GWb8Bx9{Oy5v*5vgr4*TEc-Zs(Qs|EKKSR@pxF{ZbA*_SQo7G^y(8O&$Vq^Q$U z)*pGX^FWtXRI@WNLM*4_BAVBxv2WUg&calN#N6X|R7h1JsgRD5`*Rw5+7>|JJ0|4K z>Ff`#llhyFgm;zDwKe-)h3xlOI{UM0702U|zSJq7UJArF(%EO-1%0Dq2T5KFO{a7u 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

    _s;>4Ml7m=Y+#;?cvTKCU-RG#Z8yPljG4y0dCTY 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%0AJyd_NE%&?Z>E{1F$?>OUJ-@M#@c-dZF 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%0A=g4FAmbqU}h#;b#evKMBuexQ`*^ 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

    dS6P9ns7F-*}|tkyTfG1N&(MEVefHAL@cyR6LN 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 z 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℘ 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àvePHT%aHw*+^n2-Eyl=c@3%bT$WhPh z@aCqTZE7uQeu)ZLH$KVJ2sPu(33thgwzMinM$>y_Mh6F`qWh)v?})c$xbh#u3^@^F zjFYmpnsXqkCQ-(y+Qh~@WHV;zBg*SbuFK6xb;mGB&Muc;B)$lPe&|imAiBvh%Ro)a zA`PNx8mhN4C}Wq+pp1)@L5m;F%~SO!tox%4;UzhTh7Z%E5&lf{Kj!-!r>!F{W_ zdZMOrafNto6=uB~6V$I_PG@Tq2_OGiN?z)y`}XH$%sZ(9vr7DvWnWLy==wqW)61PU9o9U6%O? z@qx2k`9H{;hpIW<7F!j0ZrL*N38;E-(|lCT<-M4yqyv{-Dei@;&*w+4_{d79*Xx!S z%c9XWjvJwUc}cDKV5vj3Gi!-St}tPhAB%$+dV;daEqg)SmF>#Eb#wH}PlQsQ2%1W* z3Smhfz)5z{P~2nHZ<(#-LGf*9_|qBEFp2x=(0EKm4~ic`(a#Fz%!*tHvRW*mT({@W z3M~+=$QRE+!-Iv<8svSXE+M`*)XpN*)_PE#@hxt2C$QoMacqq%|Bj+LC379tlB3%G zY{^uCSNuvm0?DtQLb9r|rev#tsppy{Sr+Wd?czyDes)WAeU0Uf{aUniM^5;l9p@#J z;aI9FZwt4GAX%(RW%k|k}UP`0W`vu%@I`08uLRqI^&cUH{dl30CG z+`@)!iz95K)ajOOs2|IeZ3wN1Ya30V&dL>EhHZCO#;AyLQMzSpFf^lQ!k8K8X-$m& zC==?RhDOcODvxj*o;USkxN7TD9Z7cYSZHq>j3k4zbsmlC zn*(?m9Uq^aAE>Xd)Y*}lnlWZeWgkvR58}Z%`BDCrgO*YKvw--yl!kA(-ng`*wc-_R z8||8|d_522jOt(2ink^sd)>{*-)YMDM4h;eWSoyoou-JF>cq#C8K*DfGxg$&(u_d& z?$h$c%k|=$?2FTs@VN%@edP&kJ$5?9@y7=7OZLNQO88`>cvVVh+u2>8s1Zi>bB*Fi z3e|(Qoq>5IyS+)=kb;*JsdcCfXUj%`v!)cZH#w@9+32etZ4&R1iBQ%FCwfP-II0Y6 z4X~;`s{L8*P~nr)qqeuCRf{yLA8Qt$HPgrQ%UlB9*&@Ei0^&P%E&<PXi#mhCuf-G(-1hY~0w5 zF;8TnXSb9B=YdXSVO2M|tNNu@@y?AKb#j_xslj98C?%I8s4Y2-9eo1>G$`xw5@K9G zt-iNS+;0uy|s>x<8ZIXu*k+u)d`q zz;S7~rEdglWgPAg;cWt==COA1P()&x8_I-C3?LJ)uq8%VChiSSj1OYZE8H?+#9y=JrE;fX0BRkkUZ5r%4(IGxQOMuNb7C`o~05XvTka>nSCzfqr z=@fraqA_*fuS#FKNxLV~Djdlvop%6GWZ|P%n&(h(V0@B-M$OmG7w_97Gb;t2%1S8^ zR+2#Dq$$ui$pYisu48D&f79bwG$N1R(j{J0Mv%v&az-kVE7BOV9>mMpo!#R4e6tv% zaz{epe<_rluPYZ7fGU$Smb>cr_lW27WrK};FU4xQ`KwjajhIbS%aym`z3LvkSG`}; zdsyC)_Z~*|5LvzUS8aGMm)&csk_)fjtJKLIU61M1>%{Qip~B4^W(%6qX!{xxRv4)O7V%_IEt^^ zC2lK_g&&n;ed{8|6V!|S4{aHKO6h$nrrte9^#i-ahYL4Te>Qnw0-G?(-r0DF>ZrUe zKn?D|ZHL{X4+*2@@!jGlh0@%C;faB1bcMSnu=#*)-`ROYuALql!V5EMY-mLVc0YZH zxH|A=Y6$l`a@Nr=neg^6;tMXA#3>#;mP`ytqMRjI=XdDofA1ldB83?8sd;v8MnPxI zZ5N8`iy})Aef2bG_oFNQ0y==eFk*zO-&M zDffRjU;h4L@v$ut)qs781_f7+pO!0&UOin`;`NTFax;p4U-N~acp}m+<bwH z@LgGbU%&WnnH*@M^JEP*{&F?Zq&yiXBl1MEO}#23XPp>NW~?6muoa}SkRs)jO%FnN zOMr+IExfcbpabT3xT1H=e5HC1#>SLT_45Pb&hpqMn}d}9`S>Q!n%TlCGVX*j&K#(u zaUfcGuw^H{$>Mml$;Yej2#FWUWm}x(Wj(wV-x1$pjA&6)`Z!j}d_1M{VGevUA5YEU zWHBCPv3qUiu_3YC{Ajd$XI))GH_lA7Ncfg*XB)of31W+)jxOU$E2g!fy$Sm;Df*i& zy4oDQ1t*vE)HNGdSP|IG2Ri~8ms^x>e3`kkHPB`Ji$&{cz*nPGI#nh)l7!QaEkb%S&JwjyoET~$bx4>Yh-0ChNQ6{P&>U%Y0?uOBC^0YAh+!<8x6`)MiR2-bf@CH*-Q#jU|Akc$H_+Iav4~JQ*lxerOwM)nQEv&7SRl2 z6%rV$b-W)Fxw8}p1+$4xfiPV7dY_kYW@YOjMYMHtnE;~0ef{Z2d zc8jdcC1SuL+JxX3x7x@EDFoy?i_AhmtX~7C`B5J;P!0_WF^oowx_il+LpgyNh+YCeu+LM~B=is@4b(J?vlrz@=kG6+S36d*Mr3K+(aOM<-w zsG;w3v8{$N%t55OR0R!Vzm6vPBN|bfM>RjijgdfVkK-}`8DX6Ra`pj*oSRkyWI`d? zE6A=%jo@6qGTDNst6>sO_}gY=!Qewn#RhjK&J>=h;Q$;huhad!6r&&R(f4~UDjh5- z8!W!q(1gN5EZR&B_lQD1*A4dV7gCdZNR z;819Ed@!_aXnbNIw9sf7gBTC|G#VP4n%s&q@fQ!4lon#T@dliSa}Jd628N{X2uH3% z{nL91#>u_E+*e%S$9Y%aNx%iP#pt#zGXIChC-z$*BuCi{4j&vI40)*NBAsyhISWJ{ z0jp3mUjv@P@%fj>U?_~`fq51r)v#y}$!Z~eV!Fgr*a2U5Obw5QV!GW^*b?!nxQT;m z-@@Nc=a0CF)Qb}ydxNUFwfXu%irSouwtDEr9J^O;3DR3uYXb^tc;K&DVI6@%rz9)1K{gC4rgbXDC$SkgqS1hIoDNLBw9*@+f!3A>+}l zn-|5Wm>9-(;OMr^i*Sqw=H&s7Dc8cEYl^aO;grU)=>Y7Dz+vCQF&&TeB=WBs2S4Ga zJW34w5gkvN1^#&(j=^Wa`)xQTxC^eb;W!<80r^*6NRRPpL5B^;c(j1-*W`uxrNHUT z7oUxZfg~@n@;SC};hQ#mCGfY~@UwyAX{Wlt5Bmi$oXbD`b2dLt8pGr;`xr(l{OA zlupu-PQpsu+Y&$Ql=6TtW?aU@pUVkHxnvTA9uL9exc?;hkYQv+(Ip?~5Jafc@)aOy-9xfLBit-n*M{n8uAbN%~FE!udE+vXWIz>67JpY^s5YGJK^w0rJa5R zH_n8ke=BGDMtl6HaKBFYzhSk2;InMU%L-C6B>O}y3eqi* z%pdB%gs4vvqWwttQw5XOF+^WQ^d$6u5?;@c`IDGG`3gl({yD=xDwuLE!%l`=eku1b z{yz%3x%}PeFG!Djh~b+V-p}y644+YOK?Xy#GfKChh9Q^pf}0qBgrQFNiozFi{uVYf zeig%88FIZ?_=3Vy+5f3q8E<8Xc1rqFk23tSf@$c7h@OTqN<#Dl5{@#wn&IOLE@D3{ z%4WQSA^K-Zx9A%T|5w4q+ZeKc7Y{Rz`bGSU|DxcMMGQAG3@}8!CB7x>pCvzG{7(v| zFJ<^HhCg8V3k8=BFy#JeDf^X15t5tnR)*-OB>p@@wkxwu;hAq@_&J6TDY%UNu*}am z`aP1f>`sO(XL-KDmya`iLctYWPAiyy1?Oue`)lPV6<-$jZ&^neXFFHbDSQ>z?^T~= z`~?M9uVKjbW%YLyewL5nr3@cq$n80MiNdql?(9n#pJMnChQC#i#!AZf8ur7Q%Nf6k z;R6b;MF&BAYqv0LWZ1>ghnMTUcRk~q8I~|?WXOK;4l+K%kn6dZ+q0Mbc+~Rd6$x?`E#Qo3Ca%xA%f%g%{*7Wd9ayV|)igmS1okfSj2LQ*zZL}OlN-=wKLB0i{8cf#~D7r zko(D^pECX%1-EQu$ob#W&p7uhTe#hAVLxyA5XXN;LA+5Q>#gq`hUY2hU&?SbL+10d z|NP%(`Y#kL=K4|0?W*{8MK|Yzs25w|Te@E;b{IuiVJb3rshu>6u>IjwUq9eJ9l~00 zkzC~rhNt_-`bM!8Rgp!*WA@RIoj~t_*>P<8Jg#so;7&pC;ZdnzKrPQ2MYNWQ1>E31 zyvc;uuGId^dndw0thKKnXLueg+B-2m9WE*k21aT3)!;~fc;Akesr?~uagYc;pDktd z^5_849hxSl;0613?yes$>puUyil92WBr2VHKuihtl~ICLe_NodC0OArs|fCvI}Y0t zn9O4nBrJF!T-7r$-WMAs_q@K#hPw_;Ob-PcNJ?Z@2C*P3*(;kQ`_xof?XJ=OhJ!xr;Huao z%8&hkMe_)9k>6l^ly)+ss-o%|oJ?f6 zw7J#WL7PN3cpGX1mENv~^DDibT@Brp-Ub{1cd*!K9q#vfyKs6-XmZNyg||kA`;n)< zP+$LWaJYDg^EWxrH`0&Y^rLE^trl?pbX)SOD&$2OCsKzZo#oY4ijpT%r)DKr#VC`< zEyr0cl8fq%nQm2Y(w<2Djxt`Id1+O55|c=Mk12+$Kgmd>{zu7(D(#{Hl9Nb>6GM(w z9}?++SO9gpr&}2~?P=8nnbxv+9yM5|JncH5Qb+Z7^Q-_i8K+nJQotK6dQ*ty#YDK92GO5U@+*f2u4{P90*no4VCr}mHH4*XWVx;(*z@7c6=zSM(P-IEOQ7C za>1F?54^!VD^ic|rL&_jE%V~ck6B4%H&z*k?w?JU?yibMk0D>)W_bN2f2XNmPfJ_e znO~8dbN=0@oDs9l`95HeH&ce3Ui$H)`rdB5o`W}O8mGqwriO9!Z11esY49D(Af)w; z4AM@*SQYV383EibHp!W;d_tGws?+cB7|Cf1#8R=$u@bMzufo>Hc(~&<>WYheRoEqN zwa9T0DGd=>Motoft8l+5g`{Li?uGcfSRf+N%kfEYQUa_$$g328NwU5;?Dzl(c0N2$ zh{cEZjU)MLfM0{3zO-zt3rKmIehg@uMr?7dwlD=B!yihkFP+&ad5*lquE;4R%(lj=EFKkB78|%;G?|hD^5O=2Ejmi)>j-pmk;LNubBWfUzGone}lN5 zQ}d;42hY8;`5agmGG!x}@(TXE9D|R_T-$)4`xkgdcjs(A1M78mzO*C2vG!wLEW@!M z6s+CoEA4KC-1t@DhqXyr7nATD4C{L&kJ<@cX`jU(4~6*B@~~bNA@6bE>G+X6tR0&2 zI3K3GXQB4Jh}Rd(lVxesyBzD%G5yT-RLfhAvUR3uVSp@8`~_iKezSfAT-&!9VdRy5 zjwt)GPJnh2ar%m5-&xOsp;m5+1Wc;ABZtS`-n^=7+$2S~oQFCXDJem+3*)9}-mmKSB;0kSWwnE*9klzj(& zgecObFU?2&z0H3U&j3eWr2jmC+PErPovGFam@kQt3Cd6goM|xA|;JX`fAHt9LsJ?2wQTe@^aI&BH7TfsN zBW%m>)t$gKAJt1OFUr2F3D@?moP!U35qXFwy=TSeyXL)!)AH8N!S`7kAK4zqzH1(~ z@ljtEkMCI&ZHBnu-?{xy}{c{ep!dJ_;=o^ig> z{?+YG;jbQR3g4TaZ#=%LHKX?EkFxTOpDfGSp7ZvU?>(M0Q6wpdVIl5 z9ffDE&OQS8jx`H%x}JFT{`98sj8k%@X1^VjlSH}l_19mA0ZA&yNn$?tla%v;Gxov7 znK%oLs*ZufQ+Z9L%(esrW3d3!SK;@SR22{M0t{_ErY@P1`dTXa?LrvIiwt}s$%SOP zh1`RC<4~`D^S>9PR>abls%|bh06331#cGEm8Iu10^)VK?{;od$FPo1IAFA`~PBhMe zfz5`vd~wDiBL#1cr#Moa?j*O%o$O9=yWI=i3*D(HX>RJ(Bj+qs4bFs&Ji8r^*mh|B z+0qL2r!$aw8iXDP`mKf9`zc~OD`l9L41dqVPGUMc9{ui?}b-DsmG75PFZ&K=*lAd#)LoASM`!a>9aPC zyOm7zmTy?5q552xa2_*~h0EzYZe#-a+Lg(f3Q1mzkZ>-P(B-_0$d@N?2GNzgQbr{w z*AeEtEIAYZidehWb4ozo*#euYgQM&|*79_)3#!p(j|^xf2I?<4Z%F!0zL`a8x6rx;q+s=(AWQEp9~ACxae*G6*I7 z$snag(E4aFf)Mf9U_^}h;a~)HRu+*zNM{StVOb%waMAEmUhA<%=3NP^9Q*2Y~OUGB5JAOEd@R7RO$AB4$Z#jM|@LLHD zA{C8hik@Nz_j&M$L_R94Yi+5GXb?Vsl_4^N0i_qa@tmy|4+j+Z_=h;y*po9O3}JqP_U#CqAWL2$6Xp{}(XrLZ9wB-gZe z8=^o5;j~HcR0i8x+C7DMWzP^(!13~%B$O0aU`+AQ21lz< zjF~$-3v&*E^{~3(Nq1U2A4O@0Wn zbA2Pb6;!aS->f=vke4O-Hkm#yk1TG-=drLSGh#TtfS?|K<$5tq zRpQ;BMs4pw)91S0+Tk%;fEXSd7?~anVG&QiKq;q1`u-H(s>+q%r1V6Dm?BPh51Ls^ zFO)61qW5}>T3x`(mNf}U5^nQ;XkcI8gpuU1HjdMa5*CH-i;~>AoP8rN}{L-gdP=JC5qxF^b?}m(>ZOXy-%E@P)__UajwES^;2TI!a4c#A|Rz< z_gb84sr5J6Xr>j-Hlk@ui;ZYnbe>XSmwBIPvlC70+U-=+#tu8xw6s&{qT@G}p-06| zi^L+2iVG~7Y344AW?H$Mm00qg5*OKMED*a++K8r!7u$%Yg>RB-a3{+p6;e!^@RS&m z3^?$J%kI*3vg|bBd9i<;s)Fi%fu6O{>cm-eAFvt|+P3bNZn{y#?P4?LwO;k!pt>b& zQ@1!}pmn!l48W?qAu6d6x3;u5fG|8pZxtG%nx@Tx9`wl^MJF~557;=)2?pCc@X91^ z?r74B6D~(4!=ZsZoS+q&nw}U#Hxs~=zPq8G^yu$Ka3_#AJsBFL89#R5+0_u(5gmOf z)VH6avE;C`JP44#OZ$ccUIuBV>X^1&W zbKi(ulwejkgEkhD1}b@2k&|Qr! zKo1QK8{%pwq2$R!LvZ8uK)V|*06G~uXoy>YwshC#ZSo9`d;W!}1N%aQ(<345Z9Fl7 z6XWwXRf9S_*`Mc|X_Vnu99MV_?Zf9ro;=@9Q`q`9TD8w;sYPi(c4LD|u1RNvzi@775Jr%Ear%%mrr;sZMA z%&C&@CI&O<=aR%Hb<)o6&N=PvoERU#)_ORaZeV{W)kJ(PsRh;iB}v>z%OvD8DMytj#g8ed({DE*?MS{lSX>CCkMZ^5o2RrM_VTrD!XWSbY?q}oViZk z3Hb)uj~q#~A4y~esyiF&n>n(~oR{K>L1eFjNb6b5F`n!4bH>>HkxlYHSC^!Uf-rhJeQMIvow=nD8>4vesaKLE@m0@&_K>^d^-*2 z0bPUWy-T`3xdPcvXe>&w4w>I2$F4oLIzax`&&TdRMg6g){xjAbHNV|}{Ls7JXH(r- zj?Q*!g7!eAb#8RMG|!E>&YeY3_>36kYEDgQ$~LtR8!)0w&!P!#7j{oK*M--hlzCkk zb7mF9a&blb&Q?4Ht0aIm1G$+0M(=AW2Sxj27p3oO`MIl+=zT4VIAi4o56dh1DS9V8 zjFWdF*NXzW&!CIy*e3kw-BWtstbob}9;NTNWXWJLK5ogNMD#*|eWBiWiUKR;c=@Cb z59(r;E2t5-8koIfOWj~zZXa!Enk(-RaP!j~xBw4q@T8!=V`pt^13k*A(BeDsuqrX( zm={e>(LG1CPTSbou)D6I6L$?}<%=-KOwp`U%)0SviHt$*Y=kxXwyeX-eT3jx`P_#- zs-?Q117tI2m{cu%FTnQ6Fti0j;0{vj+Cqg$HL;S)F zqn$nvWMAK8upe6pObw5bKrFufNi^?lY6xC{=Yr^=hepQxrf|?4&NpajZ|T7d0s8-J zvb2Ilu7eDYPxp_6q8U$OJx!&HC+dF$4o~o4ATZaud_%#C#yYue0{P>wLS_bsF|>D3 zh4`C^bD82n@6`@%GStMjMnn2HIo+JW$r@@m~0@C*- z54nS$7QG@FT05F*eV)9+h{sy5no-hu9^Xu*^p}sc|JgY_iCwC3NK@kZ)F~ozsfj9& zuS4u!-1uRptsXJv<<05BjT=2W{%{NzlaFcqmtGzi4VUIYO@Sxx@TN_kjmQv=mr+%K zO2;=-Y@%DuWP|fa2EV*L$;<$@uIL;2N9027{()kdUoPS$LoRMXF7UzVe2NzAQRS)x zK-wLUhAqV>{}H~3Dp9k>qE+dNkU)u=$zc7**!q81aSoWZa2+Zo^#^lV9>ooV|BVek z!|h15B2|(sddSwCbgvb`V8z3(ufVRcJ~;r)-KcfHDA}Vbl@b7H50bR;iBW1|SQpg2 zz?>beP7y6ri-FkxgxG1w#l}dX!GA=BrM-OU;>K&Ca~HeCCwndvMHW8hqPMU5ho=&E z3@3>2izNgyA8}D1is?vey+3aV%X2)%v5m@}A$s~WVjrmK_UYTUl%07)1w9ETF7Wh_ zfX6KX#q&^Ipr)5<{07+wnet%VjFj=L6Gvs5+bZJj<*4>AiGz=L6DR4~Mb-`f7*`UT9 zI0*O&hqxs=g-&pDtOQ4#;{8?v8j3V~O!=RoGECzDE4 zX6%P$BZs0l7{qyV#!;jC-)Z5|RB98WrAXzF0vKP)3rXT$OA2~J)ApD-{jf`XIf6Yx zSsyJ1%T+Wsb%t$y#)UTzOj}hqJC`Elawep*d3&<>W^~e1DCLw`d;GResXHW{GG^xf zoGhM*N}%~;7UTz0#2*}I$@5Ez?`Gxe$m(}9s^7yY;?IuNl22y(x>)t}IxxPLBL2h8+99-gj%_dtE2uExLV)%^4ZPj^*B3_LV0lEWE7HKZ7 zMs_0LM${w_{$UfBgE9$oJQGO+$*C59@UE~N=!nbNq_~(wltZeh5&9q(CV~%Z-xJ4c z8X*ZuTa=3tloxrl2tWGP-$!d4w>hM(@=lQ+u6__t|I`ClYaR2G4lHDT%0YROe6+0C z7-(y0-QzJF{~n#daNh55COQ8Dhw+Jr9rX>ZJ%Ql)C4SuC&0s{w;P;=J=r6xHAU#Zyw`FZGvI6_?{JzsjnLD%6+nIq2mlWlT>1>m5OQ zYsOQCJ!Qm`wm7H_b~m>)_TVlN2cdZUr2hMM27Iu^4E}P>@B;@wZlV?SXc1MA@IwbH z#lu!wZ=>A#X5_ApSOxe|bgax~C1QSte0J`{OSdW=($tpwYRhqJ{!52^#9K-QfQN?N zEp7F92uyFD(>vwzd9Z$LYlsgyRRQg6kNGTmOh1kOF!Px!G7$?beItkZ4o~tr4Bd)< z(^Q;?!<#1LbLmJ^^7H8qQ^g{|LuLYczSiBNljTLF+GM8qmQ!b~qp`8O!Ay}qD~YA$ zVb)S!s^#bB!6)?gfhWqK{{n00j^^5)JiH+9FTkH-`cs0eU@}dq$dj97>?RKu$}vGj zel%UxyhdEKdLEUaSSC=?BGM4Qn(M+PPbdp|YERb!OIj=o&N;^u!vfMy={C{K^5(*5PL__eE|_#pw- z6qiQvD{hjHjD5ah6pzLN0|UX5;u)0V{!l0k(3RI$Am8Th^KA3v9YBMhqB|#C2g*w* z+$Uw1AO~0x)WjK2K3?ty#ajQtTKFap91KoF+$WWFPh%I-(^OWNxU#QGWr=CxOiBCW zoBy?#zOp>EIl@(TnU)KV$8>=uqc8y(56#Y*B_M8kTRA*Y(b};qs6Jk}5HIg^v@Tz1-d+Q#o2ggbM>|8ujjQYmmPI-@X)2w?W^&W=#{)IxL zpJp0~-AU1h6V~07wTm82dGrpAWCrul!#MqnrDS{L^Du3YP2?H7!$M}7hNqgR`{``5 z!bu#ucc>403#+lHtf;=bb1Za-&ocwki}wRA4Gm095<5&*SCV;xta*FZNygI4Skse6 zM)3#n{*kMbj^?AM;Ku9Xh%=*;zN=PG#TSXUIx{Z`tIbpnqFomhR7zUP$~0d44EZ#BKUuc??C1YbIQClQYKK6DY9nEq?6Ax92Me6koi4V zI=K`6+l#HeWzj`AG)C@o!sC-u-TQ`zxTqcL(+sJke;BLGgTaBm$-&^@kYD;bNFNnt zINl-tvcQ#pEICS<*ke}~%Po=0#MVp# z7bO2N#Z5lz!uff!^2#a*f_dmU2#y@{ICzwc@(((KiQyTm3M!coh#ON~`QLKSLuOJF z$wcAiOM_?0#m7_`Ntxn(ko&;}^N=g3v}4;Ui!o`x_y}bFaXvC-p~jI(rIqx6xCb&{ zSeTI$@S)wGpc)aN?~4&~^&b!-JO3WjbrX5uc@W zB9yIkBIJpslk(|$o46G^zni9XiY%>@LP{rv+|Ikw&}eNslh_dES<7$ zxn2`Tq4SprDPD%~U(QQ7^{%QI;tIz|WMriH#a|%& z_>y^8Zfhd(g;ST8a-+Cr3EE%!e1y~Rbt=m-Zl$~^ZiMWom!{_o4NbL%)HnXJ8yW_o zainjr?3mD7I&!f1-W56+nwSjP>CT*R&!OSL!4VoYRVQC78GHKhRNKgKKTTC(3M@33 zwv7)C58KEJXM8Nwf0!Gd>_d5=iCN`kADLPx9za$;uIeY)RBGw{gfL~h2SjHR;wKxnm9r>z+~ zb*pJ#7r%%4o6nk4{cSX^MHclb)SraXn`0@Znz*P|T(#7de{J?$N*6DjuTqhfo3S`K zhEnP1MPCxPKPQ5bRp7F`%b zH1m_*N%_gmNc%vHyvSO#e;5&qUM*VfOX@OJdIE@ z&YWxj8u0FgXHXT=|$p;FzAQg1P!8_9J376q%6`Pnx>(8D}yq2*$m3KNEx*F z(cFv$?~P>;b)8FpBmNr({riTroHkip=roMzwG`a9nyV*jT8JBHxwHbzt?C1o>JPBeQvJmFfLCrJcIdSc3SN_#!C#r*PHq0d=YCm)4 zLssp~25~cVya*kwmaoEicQh0^b|vaBb?Y=fGTUXDpAa87%a#9wym_da(`~U;k>{2z z6Q6*p2RF?})m+|-sY*I<*_Gm6sQP?<^oozHbb7sRd9f@SUE{bB+LxEqiVv1LR6Dbl znB)o*R{60wh@mGao7}P i60{989iulz(P<%yuF)T$7c^Z}ek2MxtNR{fUQS{@YN zhK4_#Aq|tbpAL=3RP>6?nz3#3PXW>M10vDr-u% z3YdDXS(0VJuG}u3gyd(pMAz3?-q^22OLydi5882FG8vAgO7@W}-!JaXapgbin^P6L z$5h2_!&F81oT|uQSuXJaRNd#FTb1&crHUM8%axpmsBSrCuA~FA!r~FAdT+5*6?=I; zR?Ev7omNu=z0@>H54W+#M~n1I@{h%RYhC$oEm;;lSlJf-)mUXO2e*_=Ylj##Bf1n! zeEE)T#I8&h&Z;u;Ybg7}T*|m;v@%sPlnt6xB&v*xXVp>hevd2v7o}P8b2hinazbOF ziM@xF2h($Au!2g9csy~V?9l`)%Au>5i0?q{k#f%*YEivxPg3U2Bf8i0oC(Yb!n}G! z?8{8s$SqmYHVS2{nl#%s*@dsZR$R5tm49c&94?8~C&evn*tR&rHcFjt*@pVDOxcFe zinzAX1nR6@@nzU{cV&!Nz$#s)((dM1pSfu7dH=#O%+i$Z;9r0=k1ryG~Pup(t- z=TQ}vt7+MCI!7JXWVjEDcu{3}*4Ms|TxSIyU^nB{wFo8np{OE0@i+yZMJ**Z^a zVwdO}v4+Yk`&scJSo5Rm`C1d>DPkh!72h{lvt2VL?pg1u{#1>4$+>Z0WH=m@Pd~@y z%!RrRFXlLr@Bf{|`*uIB!RIZJ{Ky(T-2Q#Q!hvsZe<9`k9b{BxWWJ1bHx2go9Icg z>>gBRX_03S@ehv~-VDczL2P47Fx+KzA=dkZl3VnSPvhp*IN3WD8V%!FhHN%_ut$$> zaR@Vw-nzre6F=)Ps{e4V_+5kzltXR932B2ku51v;6R_dLY1r`f?cyV@jd;PTJAe<$ zkq=cI>Z9@qx8ZqHFNUkOKGl(A_l|}3w!ug;I9un@sJ=OXm(lU@+4+I``bwQ0nW-6L zwp8}vg!CXDjFTVbUpZ(Q)jtb}pG#@@hU<+>J6bDV(YDbp>dM#iFwUs{RjqhyGP2j* zjQpLZj8D{w+epUw$kb_yc&Sc&Oqp@|GCor;z9`KIbniYbU%Xr|zRA8gO$ncC5Z_mx zz}91@QyhP65Wi$UoTh|NHi}oJgtndC^@$o`R6o}!j-*gMXxkZ>N3z?S#0@EUIgwh2 z%5b)96xrN3vh7WdDrPqNsz;l|dt@S%b;60>(JYQC16u>EYL9AvRy$Pqv`f&oT@wVRG-=*u5we2+TAm|SBM^UjOrJ6h#TDWnrmBI zYamXokj~1U?HsC9ceRQaH{{a*NUtH#{S3{}y%`%fc4N#FS?Jjhbv~#F#_;#(Sk08U*cP zPDG12L1Hegd9_V^>g)|<4L&TM*st!-WHwrGS|qG*=?8FJ8gA(u!CD!I`$Kq}z^Hkw zT|5+#SmuT@Ark}0#4Bux5tfO2!xQ6!*z*dvOc=Qsp%+6=8a40i5I5vWn}){@#;}VG zA=}6fHcy)dyH0e7kIxcdvyBCieJp@XBmrceq0Nb9+gCcpUzBJ}-S?}~mu}MTiL?sG zZA#}I02EpH=#}O<6dV|zq@Yprwe!XMHp$FNfv2)k3WSv;&^T!dG)}U>__pg9Itjq^ zI2Mh_}Jv+tG&9co$T41$))I9Z$4!K2-Gx`l5dqYNl0HaWXWCj6MOL3kqHjpEN zHGj@VM}C2LCZ=Muzrg%BF~#UX$Qy2@_=Hk?qBoA>>voCT3S{9&k5T==F7e^Q&D5Vw9+;To-r0DF>ZrUeKn?D|ZHL{X4+*2@@!jGlh0@%C z;faB1bcMSnu=#*)-`ROYuALql!V5EMY-mLVc0YZHxH|A=Y6$l`a@Nr=neg^6;tMXA z#OWS9mP`ytqMRjI=X&VrfA1ldB83?8sd;v8MnPxIZ5N8`iy})Aef2bG_oFNQ0y==eFk*zO-&MDffRjU;h4L@v$ut)qs781_f7+ zpO!0&UOin`;`NTFax;p4U-N~acp}m+<bwH@LgGbU%&WnnH*@M^JEP*{&F?Z zq&yiXBl1MEO}#23XPp>NW~?6muoa}SkRs)jO%FnNOMr+IExfcbpabT3xT1H=e5HC1 z#>SLT_45Pb&hpqMn}d}9`S>Q!n%TlCGVX*j&K#(uaUfcGuw^H{$>Mml$;Yej2#FWU zWm}x(Wj(wV-x1$pjA&6)`Z!j}d_1M{VGevUA5YEUWHBCPv3qUiu_3YC{Ajd$XI))G zcQ=mtFiH59ZD$+4=LuqqqK+=(N-L(dp}h(FFe&<*ExOtqy#=S1^wc#QS6C6)%?CRI z8JAm>ZhV=!vo+9V{EJ2FX~0*bje(X{?1*JtroTy{Z(?yfWt8Aoif>|_Yw+nRM~=wv zYx++0{m=Z5r=rOMf6znvd4D?u>GK{V>HqXOY|%R{oMLBjd{^@${C>?Yms?7di*?49 zCHPKy9jH#6k+{4CN5dp}jnve0Qk`xbHmlB*$#hw#$|OgUaFVe_NKeK&p%#kMKrN&W z2{Qz7EVL7ekg5rqBh5}Qj71tH=EWK@j3qi~$xgRO#JqH)K{?7uLe`w_RGcN7NkIxM z%fsn7*@#>&1B-AfPAa0*c{wXn4Hd{DnqjO$0%Ns~_hTY=mg1mbHqj}tCeY4O*4#j8c9uEl$r+7xl5#(>nkMix&X-g8z_KX3<)?O?Q9u9w(`$mSQ@6uq=SD`5u|(c(k(Ieb3|K^)5FA)s8yO*mfLv#hSqO;r zYv43L>SG4Vp+O-yyv?HSUb1J&F66RFku=&&!gRV83n9bKv!PJ2L!pMzN&%<4Can~O zb1q7(%_0!mz8vvXl{zSZ^A%Re8mfxaFwR#f6?NB2DT(SuHw7usqiBY)bET|J7i6I} z?aGpMeRrvpNROpg5NO6!0OLeU@vNKJ?WhB4%lU@rk`==)r3t6>at5UDOzLBrUuqe=dVMwI4J z%};S-B#_$UxC}r>Sm%J8eLx}SrquwMP)PO)vTIT!hA~wpTkv!>Ofrmv+l(w2d}yiI z;LgN(!80`+fTQJgx}TR~{KGx^e$PdvgC%8y#TOfzP*{jXo2lWx5l>;^*mw|I5#W*E z$T&8=#52fgJf_2DJJ=^*M((Az7U)g5(Y|n)_E4QXJla1#GKtv1;Xa_#;V?FXncP-Y zRpKv@f6B{Cu@gk$KzMo^woso6%@pG7yu!jE;NAG7l@81+EbJe~A52NZ(^K2%{0_Wb zH5!7%DJaLTAielT7b!=5{k=4d)5ofKJW5A2BiX^B(CGMJXxq^E#6W1F(J}@h9(ZXq zG&VK46(!;?9;_TF#AM?QxDKZrD9;THNzW0EJcs(H_Y#bgcYnFBxWJFouE3Lk189TM zZChmS4~>yOP%~Epp2G3@mc?KwjD>-D6(QBE zXy3@{AiZHa!&BG+FLq1~kA`A8+*8;R@rk&JM|~r1r}M|#MC!$SOby<9!S((<^pf&?1i?TizlP>jNCOi? z9_8Ld5BJsGl?|o_YzRie2ppf@N8p&1r_za~ot%bnx@XWA?!agwrmiI8_1|MMN$1+q zl>}zUUwA^H5{GP{RRHZQ_42AG!zIHp+( zzp5#0U#rHk(E!XMjemzB=Sj(gP(9y9wi2TRL7GufnRUKG2kqiu;G~0F1XN! zhRl!qJvJQqabK*sk=TL5 za1Hlb8}5TkpRwVk!0)i(X93@3!;v7n0c)(POypY)V19{Q8)`P%{7{n3VhFo;|v0)-JV?F7un+Tf!qCyNsi;cZSfm{oAm|uVNWUtjxkXeaI`H4 zP3GhU9KIG$*l?VKAa1hZ>wtIL@J+y%*>FrPjqlrV+JpT)HoO4gx8q0krxW$Z2{?tH zymC={a8Vpz)V`^})=FX=GD>lreC67wftq3Fp!XZS}2Q_f}B$&kx0 zi-j*JJeB>Qx|Q)(hJy@`GW@cFX_%9c|I$`6L_Z+$QHE&G5`SF5MeK(~*^GBE zL_bS>i_q^#_`eD+-o}vqyLgy!)Gy*&{1*k6EMmBkVSpj(E%7a3|19|l<9|{xeJR6t zG5i6;UnsbAfZ+j#>{pBiQf|gu8Q#wDd4_CPW}Ct@-^B293?EW(8T(L&WP;dp8(+cKa!TDOr{#yA-#h1nXThO;cpeBF_X$^4f|ou<&59N@BszaqJtp5 zwObfAGVEe_Aw#YwYq@;Zq92p#9%0Dkyq4Sd+LsjFlg4lp!*Yh_FzjK-dOZD%b3g7m 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 u{5e^`Q{*git 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

    mW55p1u%s2EEo|oYXXP)o4Zj?Mv#}%%eynB>9 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�v9BGqp%v9CaRXQdyg+;jU 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 literal 0 HcmV?d00001 diff --git a/Chapter04/bare/platform/CMSIS/Lib/ARM/arm_cortexM0l_math.lib b/Chapter04/bare/platform/CMSIS/Lib/ARM/arm_cortexM0l_math.lib new file mode 100644 index 0000000000000000000000000000000000000000..73aef8a2356d878b71c22e6040d0fb787e95de94 GIT binary patch literal 13063030 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%0A+1!kej4%y(4YcPb{l{R{t7 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 D0vdE1UdI8~)~a^S(_ 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�a@%ed49yfaBoGYJtOlQQfq zvGTLK!B=BsEkSq;~6Y%b*H-SY=RzHS znWUgC^jj-~LU&uz&a(a$3>@h^%gWbaVcIZ*RF5kwh<-2biKPW$XAi|JQi^yMU08IH z;_*06@U}%RPCdl_y7GbQD)`2`!<%Dm=vib+jD5ILCzlRbx^9*c2_0jj--5x)G*8_z zsG9DDzFaY`8krVE)PZ$r@WJVLkzVy_@Gksi3I!|wMg78_NJrXk;abrl{g?MgZC%mX zej|V}oNG54e0u4pzBcG>>>E!Gbl_s&mdTNUi6rj4?R9+UgY7ee;MO-hNJnoMW82sS z3$v^4kpt6jndl&<5pv#0Gt--kQYk&aFn`Es+bA5Hf*AoM%=;e%vWtcfgsN$|7gzc$c8MUnpkfH0@{ovGz2ouZ&4 zfBk4#M!G4w6zHOw2vF0NIpiJyT^{_`<5!8FmTSaU@p}?m~8oqkWEzH3u)u+lm8E5Mq?V=ns9 zTC`Qa7mG~&FfEu?zgI!$mJgivD_F_cH5uslG0=U>h3*=Mel%yU(>FMSe&>Sj1s8r! z{dzG+eWeSX(|#|3?tlwjpF_Wotupn~b-xecocZrdpu60KpHsgLD1e#dzw1HwNf&-q z4*fQipgsT{l@F@-NjEqBdO-IAHGk>>8}T^xt3n}*DnA06&S}3(Ku0$O>POQV^^3~u zFVv#F(w-K6^v#SlpO(~{cE+@O+IZA~E|9IIn)*58v2_Dux0_^X<8csl%~Y|dN2~fc z+*bY8Pnh~)+CHs*?V!um%m6jNY5IXK(6cG9e$QS=P`ob~gU zK=)y^UHZ}bT?~YNC%@izNgkR`C-pfFx_5%^676a68^gP$x??Y1fb;-e5AXr}Ck>B}He)i%=bUFBK#m`E2uZ52KQkt&KLH8o)C_M3_Y@_L%{C;cUNA#M` z$#40kCO^_g(;=JN^eYCPuGgs8rK78|(4omrOV@0nqx_}$Ipfg-Iy7A(zVl|F8wMRE zIN4>sh0Yn@;r(WODLz^*YmK{oO)`WzV$y7GG}4)%6DDFQ@&=Ku35=58aO- zw=*79pgRD=6CG7s>Eiq9wWeH315HOGA}Uw<$$cOC5tf3g>j0`-taQ&@&)9n@gQ`c< z5d>XI;}f@I%Z_#cYC16?u_K8?=g+QPJ9<(eSXEbDUsYaPTOJ7DKOXrP3qmzDHGx1? zCDy7-^7k!2v+yrZrS4C)ezGz9CyP^{D|}qIt6E@6 zzb1LPp~aF%;p@T=-;KWc<^?`PN7~oNGafW+`wbki9WQVBqB+V}^x$S%HJ?-^C!dtA zn0uA%%ZH)Ondj4fL{%^y^2#?PIfKMyT!HqZ8Cdvkm_ z{+z6w?3|pOqjKit%+1ctL1Sa>ACZbjf=7u%50ASZLO#jU52`;FT6Eqe-b+3E`Pp+8 zv2T6*q0rn`{en;UfB?-S_^I+b2N@Fo53!-~!?&7i+wrvVC^DO^y_De9^rj84R^I>wT z14H3_JDg|W>^dAe8js^72n7a_93wB?yo5 z{>3Zg5#e9oMXy=Q;lEglJj(lu@b(^M5M6q%Agc27f~-Z@vLQP()Mk0vdF)1d8N|=S z&dVh@B;N&`PMZ;!TNQTI}*SImP%IMg;! zLe`_RTi-6c!p*G)8NHiS=noqd;`kN1l^(Q{BdRXLS2qShw5Pi{($XSst_O|w8ppjo zqeD1xd?HXKXcc03bY#07lbRS)2(%APO7kw8hwyOhjtyXUEQFA7#T2jR{#asWAZ$BiZ9c{xSt%UxKp>?F z>JRhHu(?t^)ZNq;uZhJqu@y}$%B=nB zJB7A{Lp?YrC*BrnZ`sn--E0q}eWiT6kyXHEDCX)B-r5uH6nm1p!>y4R?(;@MZtCn& z3WuUiv3P{8`G(kyip9i^$zA={cf)izLELzkH-*Q-qBJOK;Be|{sJ%TNip9d+JtjKR z5dmp?cyqX2S&%YKOH{DKCSU3YVoF=h8PP2J>u}i`YgI0BvJ2j@2uO#|n5WfXAE*~6 z($EYKDhdae2myxNfhM}NcT!Pp{;>n1?t3elo+^43NY_dQh=!lR@GM3 zRn}AieXbG#v?-##qN1|0wxYbUrmniGwzj&iycQxZAVVT9#G$&H@qL^S6d7P@s;eu3 zyHMaLHo#R?)K}Hl)K=72PcnXy@S)fUQAVN!>#C}1YO7F_V*;bTx;j`BtcI}5ICvxb zBdb`=ce#mnSn=JakGnCiFbOiW>3hu(GTOqlSD9E9cV*$LO%G)NtD&zkeGMZ>+c%ZC z+xt3UF~bJh?AKe+cH`e*@o`In8!i5Z4u?vJn}yyjMmkvYAJXX-!&{|?!~eewfA>_m z)$q?SQSLATsH|wo%y$}o$}rXh_>kf0k~$wYJPpIloH!qqwp4a;X7-PnzDg5YS-9Ku zc1x#^o8E>thf1bFc~OHCMmh(e%{s%pom zYAschu6KrqkpsSC(1VesYIe!gg8nffSqQKPaH|O>MUWqG-FKs^&=R{JnjZG(JS!d4YF!oyonku{22c`A&{9&%s&W&R5LOEBn+~Qz?juJ1>fhP zs2B`In+NoT0&TL@_=^PIWUlcS3%n`9$d)8yzXu{HVU>I%>xf2Pq~v8Hd|Dcj+@59ym#u=X*q+14mnemX|hSQaC>#CODYQY&=v{{gbE)fgT(C9QN!om}Jby$&xcAZwN zp<|a7YiJskvgmqPp(sqT$wWz(z-=~hhMHSUoT24bCB)zd5TkppQQKx2`drzWoCwXHkVN++QJ<{44ZWcp>N{mEM$Cj30Fp=sT*ohfX%G6}; zK+FicV`MbN_#1F;X^FtOXDG?|#a?ofCHD-$j90)J3vY&VJh7Yc>)?#U8cS9O21f($ zBJ9A9#NZ?jhU@Pe8%rj}N>(=jn;h>iDW7T)?`{<51@`Pf?G-2~--H<73Z~76W;!@4 zrgsz5jzelXxNA0=egRDJi8f-0Z)_QVo}69X) z9kC|mh%A0I{FCz$6#wms2~2}@_H=jQyBsl7Z{8OmoE%f|V~Ooeqazd8HYrJXl&$}w zho6HXKW+ms!^?|$1{A4#z=l72_KLJvI)>XB zsfLHM__JDWokgBA{B&{}yJ!Hef+5A;+Jt~F9 z2&U16nPoUpBUlcwmnqPT13Pi`pCs(X1$*M&5Yz*rCSW*PgV6*&&Arhanb9^jb#+8B zQ`t?;qj$N-=PmO3FiCf%pxcMPnbsqj^g#7`KK8<>4amga=$B$`#9pgVt1kPx2k@r) zx--^C7S8`!Rg$zMJ06ghNmh#ZaE`hg6YgPjRLbLR@z!u>xI5B>lqmA}_y+2~l&e0B zUOngt(S%!|ni@NFDW((PhBWw##<0=FKR_LZ>7fMM_3Hz{noX+%=aN>_Boku@#r&mS zB2aBEdKt7jAbL0Do0#`(k%Qz?3$1w_@jQf1ReWGq`Pv=sxyOQ)^A%o+H^f}vOJ;DD(QZ(K_; zkV&b^`o~24@Q3*_9M>uqM=ae)Ha*U-4WhKjMk5gnIm>9MK^c&(#*Y>#PsFbbKS~=| zlvcDw%3v}+ZOR};^hAMmqQ3kP309^2#gZIW}c39WN>BqeFU�UX{ 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%0ASS)cQxBm($9|h0r62{><&*M^)oW%2BES~uE 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

    ql(!dOIvI;rtyr4tJ)P6I} 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%0AFr)%Q?o5VfG5jxve`RRwcQf1NyA0`0 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%0AwYq77r*LOK#+d8A|L)}r_YTDo5746Sj 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

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_GPIO_H +#define __STM32F0xx_HAL_GPIO_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup GPIO + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup GPIO_Exported_Types GPIO Exported Types + * @{ + */ +/** + * @brief GPIO Init structure definition + */ +typedef struct +{ + uint32_t Pin; /*!< Specifies the GPIO pins to be configured. + This parameter can be any value of @ref GPIO_pins */ + + uint32_t Mode; /*!< Specifies the operating mode for the selected pins. + This parameter can be a value of @ref GPIO_mode */ + + uint32_t Pull; /*!< Specifies the Pull-up or Pull-Down activation for the selected pins. + This parameter can be a value of @ref GPIO_pull */ + + uint32_t Speed; /*!< Specifies the speed for the selected pins. + This parameter can be a value of @ref GPIO_speed */ + + uint32_t Alternate; /*!< Peripheral to be connected to the selected pins + This parameter can be a value of @ref GPIOEx_Alternate_function_selection */ +}GPIO_InitTypeDef; + +/** + * @brief GPIO Bit SET and Bit RESET enumeration + */ +typedef enum +{ + GPIO_PIN_RESET = 0U, + GPIO_PIN_SET +}GPIO_PinState; +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup GPIO_Exported_Constants GPIO Exported Constants + * @{ + */ +/** @defgroup GPIO_pins GPIO pins + * @{ + */ +#define GPIO_PIN_0 ((uint16_t)0x0001U) /* Pin 0 selected */ +#define GPIO_PIN_1 ((uint16_t)0x0002U) /* Pin 1 selected */ +#define GPIO_PIN_2 ((uint16_t)0x0004U) /* Pin 2 selected */ +#define GPIO_PIN_3 ((uint16_t)0x0008U) /* Pin 3 selected */ +#define GPIO_PIN_4 ((uint16_t)0x0010U) /* Pin 4 selected */ +#define GPIO_PIN_5 ((uint16_t)0x0020U) /* Pin 5 selected */ +#define GPIO_PIN_6 ((uint16_t)0x0040U) /* Pin 6 selected */ +#define GPIO_PIN_7 ((uint16_t)0x0080U) /* Pin 7 selected */ +#define GPIO_PIN_8 ((uint16_t)0x0100U) /* Pin 8 selected */ +#define GPIO_PIN_9 ((uint16_t)0x0200U) /* Pin 9 selected */ +#define GPIO_PIN_10 ((uint16_t)0x0400U) /* Pin 10 selected */ +#define GPIO_PIN_11 ((uint16_t)0x0800U) /* Pin 11 selected */ +#define GPIO_PIN_12 ((uint16_t)0x1000U) /* Pin 12 selected */ +#define GPIO_PIN_13 ((uint16_t)0x2000U) /* Pin 13 selected */ +#define GPIO_PIN_14 ((uint16_t)0x4000U) /* Pin 14 selected */ +#define GPIO_PIN_15 ((uint16_t)0x8000U) /* Pin 15 selected */ +#define GPIO_PIN_All ((uint16_t)0xFFFFU) /* All pins selected */ + +#define GPIO_PIN_MASK (0x0000FFFFU) /* PIN mask for assert test */ +/** + * @} + */ + +/** @defgroup GPIO_mode GPIO mode + * @brief GPIO Configuration Mode + * Elements values convention: 0x00WX00YZ + * - W : EXTI trigger detection on 3 bits + * - X : EXTI mode (IT or Event) on 2 bits + * - Y : Output type (Push Pull or Open Drain) on 1 bit + * - Z : GPIO mode (Input, Output, Alternate or Analog) on 2 bits + * @{ + */ +#define GPIO_MODE_INPUT MODE_INPUT /*!< Input Floating Mode */ +#define GPIO_MODE_OUTPUT_PP (MODE_OUTPUT | OUTPUT_PP) /*!< Output Push Pull Mode */ +#define GPIO_MODE_OUTPUT_OD (MODE_OUTPUT | OUTPUT_OD) /*!< Output Open Drain Mode */ +#define GPIO_MODE_AF_PP (MODE_AF | OUTPUT_PP) /*!< Alternate Function Push Pull Mode */ +#define GPIO_MODE_AF_OD (MODE_AF | OUTPUT_OD) /*!< Alternate Function Open Drain Mode */ + +#define GPIO_MODE_ANALOG MODE_ANALOG /*!< Analog Mode */ + +#define GPIO_MODE_IT_RISING (MODE_INPUT | EXTI_IT | TRIGGER_RISING) /*!< External Interrupt Mode with Rising edge trigger detection */ +#define GPIO_MODE_IT_FALLING (MODE_INPUT | EXTI_IT | TRIGGER_FALLING) /*!< External Interrupt Mode with Falling edge trigger detection */ +#define GPIO_MODE_IT_RISING_FALLING (MODE_INPUT | EXTI_IT | TRIGGER_RISING | TRIGGER_FALLING) /*!< External Interrupt Mode with Rising/Falling edge trigger detection */ + +#define GPIO_MODE_EVT_RISING (MODE_INPUT | EXTI_EVT | TRIGGER_RISING) /*!< External Event Mode with Rising edge trigger detection */ +#define GPIO_MODE_EVT_FALLING (MODE_INPUT | EXTI_EVT | TRIGGER_FALLING) /*!< External Event Mode with Falling edge trigger detection */ +#define GPIO_MODE_EVT_RISING_FALLING (MODE_INPUT | EXTI_EVT | TRIGGER_RISING | TRIGGER_FALLING) /*!< External Event Mode with Rising/Falling edge trigger detection *//** + * @} + */ + +/** @defgroup GPIO_speed GPIO speed + * @brief GPIO Output Maximum frequency + * @{ + */ +#define GPIO_SPEED_FREQ_LOW (0x00000000U) /*!< range up to 2 MHz, please refer to the product datasheet */ +#define GPIO_SPEED_FREQ_MEDIUM (0x00000001U) /*!< range 4 MHz to 10 MHz, please refer to the product datasheet */ +#define GPIO_SPEED_FREQ_HIGH (0x00000003U) /*!< range 10 MHz to 50 MHz, please refer to the product datasheet */ +/** + * @} + */ + + /** @defgroup GPIO_pull GPIO pull + * @brief GPIO Pull-Up or Pull-Down Activation + * @{ + */ +#define GPIO_NOPULL (0x00000000U) /*!< No Pull-up or Pull-down activation */ +#define GPIO_PULLUP (0x00000001U) /*!< Pull-up activation */ +#define GPIO_PULLDOWN (0x00000002U) /*!< Pull-down activation */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup GPIO_Exported_Macros GPIO Exported Macros + * @{ + */ + +/** + * @brief Check whether the specified EXTI line flag is set or not. + * @param __EXTI_LINE__ specifies the EXTI line flag to check. + * This parameter can be GPIO_PIN_x where x can be(0..15) + * @retval The new state of __EXTI_LINE__ (SET or RESET). + */ +#define __HAL_GPIO_EXTI_GET_FLAG(__EXTI_LINE__) (EXTI->PR & (__EXTI_LINE__)) + +/** + * @brief Clear the EXTI's line pending flags. + * @param __EXTI_LINE__ specifies the EXTI lines flags to clear. + * This parameter can be any combination of GPIO_PIN_x where x can be (0..15) + * @retval None + */ +#define __HAL_GPIO_EXTI_CLEAR_FLAG(__EXTI_LINE__) (EXTI->PR = (__EXTI_LINE__)) + +/** + * @brief Check whether the specified EXTI line is asserted or not. + * @param __EXTI_LINE__ specifies the EXTI line to check. + * This parameter can be GPIO_PIN_x where x can be(0..15) + * @retval The new state of __EXTI_LINE__ (SET or RESET). + */ +#define __HAL_GPIO_EXTI_GET_IT(__EXTI_LINE__) (EXTI->PR & (__EXTI_LINE__)) + +/** + * @brief Clear the EXTI's line pending bits. + * @param __EXTI_LINE__ specifies the EXTI lines to clear. + * This parameter can be any combination of GPIO_PIN_x where x can be (0..15) + * @retval None + */ +#define __HAL_GPIO_EXTI_CLEAR_IT(__EXTI_LINE__) (EXTI->PR = (__EXTI_LINE__)) + +/** + * @brief Generate a Software interrupt on selected EXTI line. + * @param __EXTI_LINE__ specifies the EXTI line to check. + * This parameter can be GPIO_PIN_x where x can be(0..15) + * @retval None + */ +#define __HAL_GPIO_EXTI_GENERATE_SWIT(__EXTI_LINE__) (EXTI->SWIER |= (__EXTI_LINE__)) + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup GPIO_Private_Constants GPIO Private Constants + * @{ + */ +#define GPIO_MODE_Pos 0U +#define GPIO_MODE (0x3UL << GPIO_MODE_Pos) +#define MODE_INPUT (0x0UL << GPIO_MODE_Pos) +#define MODE_OUTPUT (0x1UL << GPIO_MODE_Pos) +#define MODE_AF (0x2UL << GPIO_MODE_Pos) +#define MODE_ANALOG (0x3UL << GPIO_MODE_Pos) +#define OUTPUT_TYPE_Pos 4U +#define OUTPUT_TYPE (0x1UL << OUTPUT_TYPE_Pos) +#define OUTPUT_PP (0x0UL << OUTPUT_TYPE_Pos) +#define OUTPUT_OD (0x1UL << OUTPUT_TYPE_Pos) +#define EXTI_MODE_Pos 16U +#define EXTI_MODE (0x3UL << EXTI_MODE_Pos) +#define EXTI_IT (0x1UL << EXTI_MODE_Pos) +#define EXTI_EVT (0x2UL << EXTI_MODE_Pos) +#define TRIGGER_MODE_Pos 20U +#define TRIGGER_MODE (0x7UL << TRIGGER_MODE_Pos) +#define TRIGGER_RISING (0x1UL << TRIGGER_MODE_Pos) +#define TRIGGER_FALLING (0x2UL << TRIGGER_MODE_Pos) +/** + * @} + */ + +/** @addtogroup GPIO_Private_Macros GPIO Private Macros + * @{ + */ +#define IS_GPIO_PIN_ACTION(ACTION) (((ACTION) == GPIO_PIN_RESET) || ((ACTION) == GPIO_PIN_SET)) + +#define IS_GPIO_PIN(__PIN__) (((((uint32_t)__PIN__) & GPIO_PIN_MASK) != 0x00U) &&\ + ((((uint32_t)__PIN__) & ~GPIO_PIN_MASK) == 0x00U)) + +#define IS_GPIO_MODE(__MODE__) (((__MODE__) == GPIO_MODE_INPUT) ||\ + ((__MODE__) == GPIO_MODE_OUTPUT_PP) ||\ + ((__MODE__) == GPIO_MODE_OUTPUT_OD) ||\ + ((__MODE__) == GPIO_MODE_AF_PP) ||\ + ((__MODE__) == GPIO_MODE_AF_OD) ||\ + ((__MODE__) == GPIO_MODE_IT_RISING) ||\ + ((__MODE__) == GPIO_MODE_IT_FALLING) ||\ + ((__MODE__) == GPIO_MODE_IT_RISING_FALLING) ||\ + ((__MODE__) == GPIO_MODE_EVT_RISING) ||\ + ((__MODE__) == GPIO_MODE_EVT_FALLING) ||\ + ((__MODE__) == GPIO_MODE_EVT_RISING_FALLING) ||\ + ((__MODE__) == GPIO_MODE_ANALOG)) + +#define IS_GPIO_SPEED(__SPEED__) (((__SPEED__) == GPIO_SPEED_FREQ_LOW) ||\ + ((__SPEED__) == GPIO_SPEED_FREQ_MEDIUM) ||\ + ((__SPEED__) == GPIO_SPEED_FREQ_HIGH)) + +#define IS_GPIO_PULL(__PULL__) (((__PULL__) == GPIO_NOPULL) ||\ + ((__PULL__) == GPIO_PULLUP) || \ + ((__PULL__) == GPIO_PULLDOWN)) +/** + * @} + */ + +/* Include GPIO HAL Extended module */ +#include "stm32f0xx_hal_gpio_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup GPIO_Exported_Functions GPIO Exported Functions + * @{ + */ + +/** @addtogroup GPIO_Exported_Functions_Group1 Initialization/de-initialization functions + * @brief Initialization and Configuration functions + * @{ + */ + +/* Initialization and de-initialization functions *****************************/ +void HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_Init); +void HAL_GPIO_DeInit(GPIO_TypeDef *GPIOx, uint32_t GPIO_Pin); + +/** + * @} + */ + +/** @addtogroup GPIO_Exported_Functions_Group2 IO operation functions + * @{ + */ + +/* IO operation functions *****************************************************/ +GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin); +void HAL_GPIO_WritePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState); +void HAL_GPIO_TogglePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin); +HAL_StatusTypeDef HAL_GPIO_LockPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin); +void HAL_GPIO_EXTI_IRQHandler(uint16_t GPIO_Pin); +void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_GPIO_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_gpio_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_gpio_ex.h new file mode 100644 index 0000000..33b27e3 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_gpio_ex.h @@ -0,0 +1,800 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_gpio_ex.h + * @author MCD Application Team + * @brief Header file of GPIO HAL Extension module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_GPIO_EX_H +#define __STM32F0xx_HAL_GPIO_EX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup GPIOEx GPIOEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup GPIOEx_Exported_Constants GPIOEx Exported Constants + * @{ + */ + +/** @defgroup GPIOEx_Alternate_function_selection GPIOEx Alternate function selection + * @{ + */ + +#if defined (STM32F030x6) +/*------------------------- STM32F030x6---------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_TIM3 ((uint8_t)0x00U) /*!< AF0: TIM3 Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_I2C1 ((uint8_t)0x04U) /*!< AF4: I2C1 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x06U) + +#endif /* STM32F030x6 */ + +/*---------------------------------- STM32F030x8 -------------------------------------------*/ +#if defined (STM32F030x8) +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2 Alternate Function mapping */ +#define GPIO_AF0_TIM15 ((uint8_t)0x00U) /*!< AF0: TIM15 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_TIM3 ((uint8_t)0x00U) /*!< AF0: TIM3 Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_TIM15 ((uint8_t)0x01U) /*!< AF1: TIM15 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_I2C2 ((uint8_t)0x01U) /*!< AF1: I2C2 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ +#define GPIO_AF3_TIM15 ((uint8_t)0x03U) /*!< AF3: TIM15 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x06U) + +#endif /* STM32F030x8 */ + +#if defined (STM32F031x6) || defined (STM32F038xx) +/*--------------------------- STM32F031x6/STM32F038xx ---------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1/I2S1 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_SWDAT ((uint8_t)0x00U) /*!< AF0: SWDAT Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM2 ((uint8_t)0x02U) /*!< AF2: TIM2 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_I2C1 ((uint8_t)0x04U) /*!< AF4: I2C1 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x06U) + +#endif /* STM32F031x6 || STM32F038xx */ + +#if defined (STM32F051x8) || defined (STM32F058xx) +/*--------------------------- STM32F051x8/STM32F058xx---------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1/I2S1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2 Alternate Function mapping */ +#define GPIO_AF0_TIM15 ((uint8_t)0x00U) /*!< AF0: TIM15 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_CEC ((uint8_t)0x00U) /*!< AF0: CEC Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_TIM15 ((uint8_t)0x01U) /*!< AF1: TIM15 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_I2C2 ((uint8_t)0x01U) /*!< AF1: I2C2 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_CEC ((uint8_t)0x01U) /*!< AF1: CEC Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM2 ((uint8_t)0x02U) /*!< AF2: TIM2 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ +#define GPIO_AF3_TIM15 ((uint8_t)0x03U) /*!< AF3: TIM15 Alternate Function mapping */ +#define GPIO_AF3_TSC ((uint8_t)0x03U) /*!< AF3: TSC Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +/* AF 7 */ +#define GPIO_AF7_COMP1 ((uint8_t)0x07U) /*!< AF7: COMP1 Alternate Function mapping */ +#define GPIO_AF7_COMP2 ((uint8_t)0x07U) /*!< AF7: COMP2 Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x07U) + +#endif /* STM32F051x8/STM32F058xx */ + +#if defined (STM32F071xB) +/*--------------------------- STM32F071xB ---------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: AEVENTOUT Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_CEC ((uint8_t)0x00U) /*!< AF0: CEC Alternate Function mapping */ +#define GPIO_AF0_CRS ((uint8_t)0x00U) /*!< AF0: CRS Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1/I2S1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2/I2S2 Alternate Function mapping */ +#define GPIO_AF0_TIM1 ((uint8_t)0x00U) /*!< AF0: TIM1 Alternate Function mapping */ +#define GPIO_AF0_TIM3 ((uint8_t)0x00U) /*!< AF0: TIM3 Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_TIM15 ((uint8_t)0x00U) /*!< AF0: TIM15 Alternate Function mapping */ +#define GPIO_AF0_TIM16 ((uint8_t)0x00U) /*!< AF0: TIM16 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_TSC ((uint8_t)0x00U) /*!< AF0: TSC Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_USART2 ((uint8_t)0x00U) /*!< AF0: USART2 Alternate Function mapping */ +#define GPIO_AF0_USART3 ((uint8_t)0x00U) /*!< AF0: USART3 Alternate Function mapping */ +#define GPIO_AF0_USART4 ((uint8_t)0x00U) /*!< AF0: USART4 Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_TIM15 ((uint8_t)0x01U) /*!< AF1: TIM15 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_USART3 ((uint8_t)0x01U) /*!< AF1: USART3 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_CEC ((uint8_t)0x01U) /*!< AF1: CEC Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_I2C2 ((uint8_t)0x01U) /*!< AF1: I2C2 Alternate Function mapping */ +#define GPIO_AF1_TSC ((uint8_t)0x01U) /*!< AF1: TSC Alternate Function mapping */ +#define GPIO_AF1_SPI1 ((uint8_t)0x01U) /*!< AF1: SPI1 Alternate Function mapping */ +#define GPIO_AF1_SPI2 ((uint8_t)0x01U) /*!< AF1: SPI2 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM2 ((uint8_t)0x02U) /*!< AF2: TIM2 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_TSC ((uint8_t)0x03U) /*!< AF3: TSC Alternate Function mapping */ +#define GPIO_AF3_TIM15 ((uint8_t)0x03U) /*!< AF3: TIM15 Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_USART4 ((uint8_t)0x04U) /*!< AF4: USART4 Alternate Function mapping */ +#define GPIO_AF4_USART3 ((uint8_t)0x04U) /*!< AF4: USART3 Alternate Function mapping */ +#define GPIO_AF4_CRS ((uint8_t)0x04U) /*!< AF4: CRS Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM15 ((uint8_t)0x05U) /*!< AF5: TIM15 Alternate Function mapping */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ +#define GPIO_AF5_SPI2 ((uint8_t)0x05U) /*!< AF5: SPI2 Alternate Function mapping */ +#define GPIO_AF5_I2C2 ((uint8_t)0x05U) /*!< AF5: I2C2 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +/* AF 7 */ +#define GPIO_AF7_COMP1 ((uint8_t)0x07U) /*!< AF7: COMP1 Alternate Function mapping */ +#define GPIO_AF7_COMP2 ((uint8_t)0x07U) /*!< AF7: COMP2 Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x07U) + +#endif /* STM32F071xB */ + + +#if defined(STM32F091xC) || defined(STM32F098xx) +/*--------------------------- STM32F091xC || STM32F098xx ------------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_CEC ((uint8_t)0x00U) /*!< AF0: CEC Alternate Function mapping */ +#define GPIO_AF0_CRS ((uint8_t)0x00U) /*!< AF0: CRS Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1/I2S1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2/I2S2 Alternate Function mapping */ +#define GPIO_AF0_TIM1 ((uint8_t)0x00U) /*!< AF0: TIM1 Alternate Function mapping */ +#define GPIO_AF0_TIM3 ((uint8_t)0x00U) /*!< AF0: TIM3 Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_TIM15 ((uint8_t)0x00U) /*!< AF0: TIM15 Alternate Function mapping */ +#define GPIO_AF0_TIM16 ((uint8_t)0x00U) /*!< AF0: TIM16 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_TSC ((uint8_t)0x00U) /*!< AF0: TSC Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_USART2 ((uint8_t)0x00U) /*!< AF0: USART2 Alternate Function mapping */ +#define GPIO_AF0_USART3 ((uint8_t)0x00U) /*!< AF0: USART3 Alternate Function mapping */ +#define GPIO_AF0_USART4 ((uint8_t)0x00U) /*!< AF0: USART4 Alternate Function mapping */ +#define GPIO_AF0_USART8 ((uint8_t)0x00U) /*!< AF0: USART8 Alternate Function mapping */ +#define GPIO_AF0_CAN ((uint8_t)0x00U) /*!< AF0: CAN Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_TIM15 ((uint8_t)0x01U) /*!< AF1: TIM15 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_USART3 ((uint8_t)0x01U) /*!< AF1: USART3 Alternate Function mapping */ +#define GPIO_AF1_USART4 ((uint8_t)0x01U) /*!< AF1: USART4 Alternate Function mapping */ +#define GPIO_AF1_USART5 ((uint8_t)0x01U) /*!< AF1: USART5 Alternate Function mapping */ +#define GPIO_AF1_USART6 ((uint8_t)0x01U) /*!< AF1: USART6 Alternate Function mapping */ +#define GPIO_AF1_USART7 ((uint8_t)0x01U) /*!< AF1: USART7 Alternate Function mapping */ +#define GPIO_AF1_USART8 ((uint8_t)0x01U) /*!< AF1: USART8 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_CEC ((uint8_t)0x01U) /*!< AF1: CEC Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_I2C2 ((uint8_t)0x01U) /*!< AF1: I2C2 Alternate Function mapping */ +#define GPIO_AF1_TSC ((uint8_t)0x01U) /*!< AF1: TSC Alternate Function mapping */ +#define GPIO_AF1_SPI1 ((uint8_t)0x01U) /*!< AF1: SPI1 Alternate Function mapping */ +#define GPIO_AF1_SPI2 ((uint8_t)0x01U) /*!< AF1: SPI2 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM2 ((uint8_t)0x02U) /*!< AF2: TIM2 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ +#define GPIO_AF2_USART5 ((uint8_t)0x02U) /*!< AF2: USART5 Alternate Function mapping */ +#define GPIO_AF2_USART6 ((uint8_t)0x02U) /*!< AF2: USART6 Alternate Function mapping */ +#define GPIO_AF2_USART7 ((uint8_t)0x02U) /*!< AF2: USART7 Alternate Function mapping */ +#define GPIO_AF2_USART8 ((uint8_t)0x02U) /*!< AF2: USART8 Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_TSC ((uint8_t)0x03U) /*!< AF3: TSC Alternate Function mapping */ +#define GPIO_AF3_TIM15 ((uint8_t)0x03U) /*!< AF3: TIM15 Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_USART4 ((uint8_t)0x04U) /*!< AF4: USART4 Alternate Function mapping */ +#define GPIO_AF4_USART3 ((uint8_t)0x04U) /*!< AF4: USART3 Alternate Function mapping */ +#define GPIO_AF4_CRS ((uint8_t)0x04U) /*!< AF4: CRS Alternate Function mapping */ +#define GPIO_AF4_CAN ((uint8_t)0x04U) /*!< AF4: CAN Alternate Function mapping */ +#define GPIO_AF4_I2C1 ((uint8_t)0x04U) /*!< AF4: I2C1 Alternate Function mapping */ +#define GPIO_AF4_USART5 ((uint8_t)0x04U) /*!< AF4: USART5 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM15 ((uint8_t)0x05U) /*!< AF5: TIM15 Alternate Function mapping */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ +#define GPIO_AF5_SPI2 ((uint8_t)0x05U) /*!< AF5: SPI2 Alternate Function mapping */ +#define GPIO_AF5_I2C2 ((uint8_t)0x05U) /*!< AF5: I2C2 Alternate Function mapping */ +#define GPIO_AF5_MCO ((uint8_t)0x05U) /*!< AF5: MCO Alternate Function mapping */ +#define GPIO_AF5_USART6 ((uint8_t)0x05U) /*!< AF5: USART6 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +/* AF 7 */ +#define GPIO_AF7_COMP1 ((uint8_t)0x07U) /*!< AF7: COMP1 Alternate Function mapping */ +#define GPIO_AF7_COMP2 ((uint8_t)0x07U) /*!< AF7: COMP2 Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x07U) + +#endif /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F030xC) +/*--------------------------- STM32F030xC ----------------------------------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2 Alternate Function mapping */ +#define GPIO_AF0_TIM3 ((uint8_t)0x00U) /*!< AF0: TIM3 Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_TIM15 ((uint8_t)0x00U) /*!< AF0: TIM15 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_USART4 ((uint8_t)0x00U) /*!< AF0: USART4 Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_TIM15 ((uint8_t)0x01U) /*!< AF1: TIM15 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_USART3 ((uint8_t)0x01U) /*!< AF1: USART3 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_I2C2 ((uint8_t)0x01U) /*!< AF1: I2C2 Alternate Function mapping */ +#define GPIO_AF1_SPI2 ((uint8_t)0x01U) /*!< AF1: SPI2 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ +#define GPIO_AF2_USART5 ((uint8_t)0x02U) /*!< AF2: USART5 Alternate Function mapping */ +#define GPIO_AF2_USART6 ((uint8_t)0x02U) /*!< AF2: USART6 Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_TIM15 ((uint8_t)0x03U) /*!< AF3: TIM15 Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_USART4 ((uint8_t)0x04U) /*!< AF4: USART4 Alternate Function mapping */ +#define GPIO_AF4_USART3 ((uint8_t)0x04U) /*!< AF4: USART3 Alternate Function mapping */ +#define GPIO_AF4_I2C1 ((uint8_t)0x04U) /*!< AF4: I2C1 Alternate Function mapping */ +#define GPIO_AF4_USART5 ((uint8_t)0x04U) /*!< AF4: USART5 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM15 ((uint8_t)0x05U) /*!< AF5: TIM15 Alternate Function mapping */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ +#define GPIO_AF5_SPI2 ((uint8_t)0x05U) /*!< AF5: SPI2 Alternate Function mapping */ +#define GPIO_AF5_I2C2 ((uint8_t)0x05U) /*!< AF5: I2C2 Alternate Function mapping */ +#define GPIO_AF5_MCO ((uint8_t)0x05U) /*!< AF5: MCO Alternate Function mapping */ +#define GPIO_AF5_USART6 ((uint8_t)0x05U) /*!< AF5: USART6 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x06U) + +#endif /* STM32F030xC */ + +#if defined (STM32F072xB) || defined (STM32F078xx) +/*--------------------------- STM32F072xB/STM32F078xx ---------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_CEC ((uint8_t)0x00U) /*!< AF0: CEC Alternate Function mapping */ +#define GPIO_AF0_CRS ((uint8_t)0x00U) /*!< AF0: CRS Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1/I2S1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2/I2S2 Alternate Function mapping */ +#define GPIO_AF0_TIM1 ((uint8_t)0x00U) /*!< AF0: TIM1 Alternate Function mapping */ +#define GPIO_AF0_TIM3 ((uint8_t)0x00U) /*!< AF0: TIM3 Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_TIM15 ((uint8_t)0x00U) /*!< AF0: TIM15 Alternate Function mapping */ +#define GPIO_AF0_TIM16 ((uint8_t)0x00U) /*!< AF0: TIM16 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_TSC ((uint8_t)0x00U) /*!< AF0: TSC Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_USART2 ((uint8_t)0x00U) /*!< AF0: USART2 Alternate Function mapping */ +#define GPIO_AF0_USART3 ((uint8_t)0x00U) /*!< AF0: USART2 Alternate Function mapping */ +#define GPIO_AF0_USART4 ((uint8_t)0x00U) /*!< AF0: USART4 Alternate Function mapping */ +#define GPIO_AF0_CAN ((uint8_t)0x00U) /*!< AF0: CAN Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_TIM15 ((uint8_t)0x01U) /*!< AF1: TIM15 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_USART3 ((uint8_t)0x01U) /*!< AF1: USART3 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_CEC ((uint8_t)0x01U) /*!< AF1: CEC Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_I2C2 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_TSC ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_SPI1 ((uint8_t)0x01U) /*!< AF1: SPI1 Alternate Function mapping */ +#define GPIO_AF1_SPI2 ((uint8_t)0x01U) /*!< AF1: SPI2 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM2 ((uint8_t)0x02U) /*!< AF2: TIM2 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ +#define GPIO_AF2_USB ((uint8_t)0x02U) /*!< AF2: USB Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_TSC ((uint8_t)0x03U) /*!< AF3: TSC Alternate Function mapping */ +#define GPIO_AF3_TIM15 ((uint8_t)0x03U) /*!< AF3: TIM15 Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_USART4 ((uint8_t)0x04U) /*!< AF4: USART4 Alternate Function mapping */ +#define GPIO_AF4_USART3 ((uint8_t)0x04U) /*!< AF4: USART3 Alternate Function mapping */ +#define GPIO_AF4_CRS ((uint8_t)0x04U) /*!< AF4: CRS Alternate Function mapping */ +#define GPIO_AF4_CAN ((uint8_t)0x04U) /*!< AF4: CAN Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM15 ((uint8_t)0x05U) /*!< AF5: TIM15 Alternate Function mapping */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ +#define GPIO_AF5_SPI2 ((uint8_t)0x05U) /*!< AF5: SPI2 Alternate Function mapping */ +#define GPIO_AF5_I2C2 ((uint8_t)0x05U) /*!< AF5: I2C2 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +/* AF 7 */ +#define GPIO_AF7_COMP1 ((uint8_t)0x07U) /*!< AF7: COMP1 Alternate Function mapping */ +#define GPIO_AF7_COMP2 ((uint8_t)0x07U) /*!< AF7: COMP2 Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x07U) + +#endif /* STM32F072xB || STM32F078xx */ + +#if defined (STM32F070xB) +/*---------------------------------- STM32F070xB ---------------------------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2 Alternate Function mapping */ +#define GPIO_AF0_TIM3 ((uint8_t)0x00U) /*!< AF0: TIM3 Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_TIM15 ((uint8_t)0x00U) /*!< AF0: TIM15 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ +#define GPIO_AF0_USART4 ((uint8_t)0x00U) /*!< AF0: USART4 Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ +#define GPIO_AF1_TIM15 ((uint8_t)0x01U) /*!< AF1: TIM15 Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_USART3 ((uint8_t)0x01U) /*!< AF1: USART4 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_I2C2 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_SPI2 ((uint8_t)0x01U) /*!< AF1: SPI2 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ +#define GPIO_AF2_USB ((uint8_t)0x02U) /*!< AF2: USB Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ +#define GPIO_AF3_TIM15 ((uint8_t)0x03U) /*!< AF3: TIM15 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_USART4 ((uint8_t)0x04U) /*!< AF4: USART4 Alternate Function mapping */ +#define GPIO_AF4_USART3 ((uint8_t)0x04U) /*!< AF4: USART3 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_TIM15 ((uint8_t)0x05U) /*!< AF5: TIM15 Alternate Function mapping */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ +#define GPIO_AF5_SPI2 ((uint8_t)0x05U) /*!< AF5: SPI2 Alternate Function mapping */ +#define GPIO_AF5_I2C2 ((uint8_t)0x05U) /*!< AF5: I2C2 Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x06U) + +#endif /* STM32F070xB */ + +#if defined (STM32F042x6) || defined (STM32F048xx) +/*--------------------------- STM32F042x6/STM32F048xx ---------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_CEC ((uint8_t)0x00U) /*!< AF0: CEC Alternate Function mapping */ +#define GPIO_AF0_CRS ((uint8_t)0x00U) /*!< AF0: CRS Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1/I2S1 Alternate Function mapping */ +#define GPIO_AF0_SPI2 ((uint8_t)0x00U) /*!< AF0: SPI2/I2S2 Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_CEC ((uint8_t)0x01U) /*!< AF1: CEC Alternate Function mapping */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM2 ((uint8_t)0x02U) /*!< AF2: TIM2 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_USB ((uint8_t)0x02U) /*!< AF2: USB Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ +#define GPIO_AF3_TSC ((uint8_t)0x03U) /*!< AF3: TSC Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_CAN ((uint8_t)0x04U) /*!< AF4: CAN Alternate Function mapping */ +#define GPIO_AF4_CRS ((uint8_t)0x04U) /*!< AF4: CRS Alternate Function mapping */ +#define GPIO_AF4_I2C1 ((uint8_t)0x04U) /*!< AF4: I2C1 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_MCO ((uint8_t)0x05U) /*!< AF5: MCO Alternate Function mapping */ +#define GPIO_AF5_I2C1 ((uint8_t)0x05U) /*!< AF5: I2C1 Alternate Function mapping */ +#define GPIO_AF5_I2C2 ((uint8_t)0x05U) /*!< AF5: I2C2 Alternate Function mapping */ +#define GPIO_AF5_SPI2 ((uint8_t)0x05U) /*!< AF5: SPI2 Alternate Function mapping */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ +#define GPIO_AF5_USB ((uint8_t)0x05U) /*!< AF5: USB Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x06U) + +#endif /* STM32F042x6 || STM32F048xx */ + +#if defined (STM32F070x6) +/*--------------------------------------- STM32F070x6 ----------------------------------------*/ +/* AF 0 */ +#define GPIO_AF0_EVENTOUT ((uint8_t)0x00U) /*!< AF0: EVENTOUT Alternate Function mapping */ +#define GPIO_AF0_IR ((uint8_t)0x00U) /*!< AF0: IR Alternate Function mapping */ +#define GPIO_AF0_MCO ((uint8_t)0x00U) /*!< AF0: MCO Alternate Function mapping */ +#define GPIO_AF0_SPI1 ((uint8_t)0x00U) /*!< AF0: SPI1 Alternate Function mapping */ +#define GPIO_AF0_SWDIO ((uint8_t)0x00U) /*!< AF0: SWDIO Alternate Function mapping */ +#define GPIO_AF0_SWCLK ((uint8_t)0x00U) /*!< AF0: SWCLK Alternate Function mapping */ +#define GPIO_AF0_TIM14 ((uint8_t)0x00U) /*!< AF0: TIM14 Alternate Function mapping */ +#define GPIO_AF0_TIM17 ((uint8_t)0x00U) /*!< AF0: TIM17 Alternate Function mapping */ +#define GPIO_AF0_USART1 ((uint8_t)0x00U) /*!< AF0: USART1 Alternate Function mapping */ + +/* AF 1 */ +#define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /*!< AF1: EVENTOUT Alternate Function mapping */ +#define GPIO_AF1_I2C1 ((uint8_t)0x01U) /*!< AF1: I2C1 Alternate Function mapping */ +#define GPIO_AF1_IR ((uint8_t)0x01U) /*!< AF1: IR Alternate Function mapping */ +#define GPIO_AF1_USART1 ((uint8_t)0x01U) /*!< AF1: USART1 Alternate Function mapping */ +#define GPIO_AF1_USART2 ((uint8_t)0x01U) /*!< AF1: USART2 Alternate Function mapping */ +#define GPIO_AF1_TIM3 ((uint8_t)0x01U) /*!< AF1: TIM3 Alternate Function mapping */ + +/* AF 2 */ +#define GPIO_AF2_EVENTOUT ((uint8_t)0x02U) /*!< AF2: EVENTOUT Alternate Function mapping */ +#define GPIO_AF2_TIM1 ((uint8_t)0x02U) /*!< AF2: TIM1 Alternate Function mapping */ +#define GPIO_AF2_TIM16 ((uint8_t)0x02U) /*!< AF2: TIM16 Alternate Function mapping */ +#define GPIO_AF2_TIM17 ((uint8_t)0x02U) /*!< AF2: TIM17 Alternate Function mapping */ +#define GPIO_AF2_USB ((uint8_t)0x02U) /*!< AF2: USB Alternate Function mapping */ + +/* AF 3 */ +#define GPIO_AF3_EVENTOUT ((uint8_t)0x03U) /*!< AF3: EVENTOUT Alternate Function mapping */ +#define GPIO_AF3_I2C1 ((uint8_t)0x03U) /*!< AF3: I2C1 Alternate Function mapping */ + +/* AF 4 */ +#define GPIO_AF4_TIM14 ((uint8_t)0x04U) /*!< AF4: TIM14 Alternate Function mapping */ +#define GPIO_AF4_I2C1 ((uint8_t)0x04U) /*!< AF4: I2C1 Alternate Function mapping */ + +/* AF 5 */ +#define GPIO_AF5_MCO ((uint8_t)0x05U) /*!< AF5: MCO Alternate Function mapping */ +#define GPIO_AF5_I2C1 ((uint8_t)0x05U) /*!< AF5: I2C1 Alternate Function mapping */ +#define GPIO_AF5_TIM16 ((uint8_t)0x05U) /*!< AF5: TIM16 Alternate Function mapping */ +#define GPIO_AF5_TIM17 ((uint8_t)0x05U) /*!< AF5: TIM17 Alternate Function mapping */ +#define GPIO_AF5_USB ((uint8_t)0x05U) /*!< AF5: USB Alternate Function mapping */ + +/* AF 6 */ +#define GPIO_AF6_EVENTOUT ((uint8_t)0x06U) /*!< AF6: EVENTOUT Alternate Function mapping */ + +#define IS_GPIO_AF(AF) ((AF) <= (uint8_t)0x06U) + +#endif /* STM32F070x6 */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup GPIOEx_Exported_Macros GPIOEx Exported Macros + * @{ + */ + +/** @defgroup GPIOEx_Get_Port_Index GPIOEx_Get Port Index +* @{ + */ +#if defined(GPIOD) && defined(GPIOE) +#define GPIO_GET_INDEX(__GPIOx__) (((__GPIOx__) == (GPIOA))? 0U :\ + ((__GPIOx__) == (GPIOB))? 1U :\ + ((__GPIOx__) == (GPIOC))? 2U :\ + ((__GPIOx__) == (GPIOD))? 3U :\ + ((__GPIOx__) == (GPIOE))? 4U : 5U) +#endif + +#if defined(GPIOD) && !defined(GPIOE) +#define GPIO_GET_INDEX(__GPIOx__) (((__GPIOx__) == (GPIOA))? 0U :\ + ((__GPIOx__) == (GPIOB))? 1U :\ + ((__GPIOx__) == (GPIOC))? 2U :\ + ((__GPIOx__) == (GPIOD))? 3U : 5U) +#endif + +#if !defined(GPIOD) && defined(GPIOE) +#define GPIO_GET_INDEX(__GPIOx__) (((__GPIOx__) == (GPIOA))? 0U :\ + ((__GPIOx__) == (GPIOB))? 1U :\ + ((__GPIOx__) == (GPIOC))? 2U :\ + ((__GPIOx__) == (GPIOE))? 4U : 5U) +#endif + +#if !defined(GPIOD) && !defined(GPIOE) +#define GPIO_GET_INDEX(__GPIOx__) (((__GPIOx__) == (GPIOA))? 0U :\ + ((__GPIOx__) == (GPIOB))? 1U :\ + ((__GPIOx__) == (GPIOC))? 2U : 5U) +#endif + +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_GPIO_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c.h new file mode 100644 index 0000000..06b9973 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c.h @@ -0,0 +1,838 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_i2c.h + * @author MCD Application Team + * @brief Header file of I2C HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_I2C_H +#define STM32F0xx_HAL_I2C_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup I2C + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup I2C_Exported_Types I2C Exported Types + * @{ + */ + +/** @defgroup I2C_Configuration_Structure_definition I2C Configuration Structure definition + * @brief I2C Configuration Structure definition + * @{ + */ +typedef struct +{ + uint32_t Timing; /*!< Specifies the I2C_TIMINGR_register value. + This parameter calculated by referring to I2C initialization section + in Reference manual */ + + uint32_t OwnAddress1; /*!< Specifies the first device own address. + This parameter can be a 7-bit or 10-bit address. */ + + uint32_t AddressingMode; /*!< Specifies if 7-bit or 10-bit addressing mode is selected. + This parameter can be a value of @ref I2C_ADDRESSING_MODE */ + + uint32_t DualAddressMode; /*!< Specifies if dual addressing mode is selected. + This parameter can be a value of @ref I2C_DUAL_ADDRESSING_MODE */ + + uint32_t OwnAddress2; /*!< Specifies the second device own address if dual addressing mode is selected + This parameter can be a 7-bit address. */ + + uint32_t OwnAddress2Masks; /*!< Specifies the acknowledge mask address second device own address if dual addressing + mode is selected. + This parameter can be a value of @ref I2C_OWN_ADDRESS2_MASKS */ + + uint32_t GeneralCallMode; /*!< Specifies if general call mode is selected. + This parameter can be a value of @ref I2C_GENERAL_CALL_ADDRESSING_MODE */ + + uint32_t NoStretchMode; /*!< Specifies if nostretch mode is selected. + This parameter can be a value of @ref I2C_NOSTRETCH_MODE */ + +} I2C_InitTypeDef; + +/** + * @} + */ + +/** @defgroup HAL_state_structure_definition HAL state structure definition + * @brief HAL State structure definition + * @note HAL I2C State value coding follow below described bitmap :\n + * b7-b6 Error information\n + * 00 : No Error\n + * 01 : Abort (Abort user request on going)\n + * 10 : Timeout\n + * 11 : Error\n + * b5 Peripheral initialization status\n + * 0 : Reset (peripheral not initialized)\n + * 1 : Init done (peripheral initialized and ready to use. HAL I2C Init function called)\n + * b4 (not used)\n + * x : Should be set to 0\n + * b3\n + * 0 : Ready or Busy (No Listen mode ongoing)\n + * 1 : Listen (peripheral in Address Listen Mode)\n + * b2 Intrinsic process state\n + * 0 : Ready\n + * 1 : Busy (peripheral busy with some configuration or internal operations)\n + * b1 Rx state\n + * 0 : Ready (no Rx operation ongoing)\n + * 1 : Busy (Rx operation ongoing)\n + * b0 Tx state\n + * 0 : Ready (no Tx operation ongoing)\n + * 1 : Busy (Tx operation ongoing) + * @{ + */ +typedef enum +{ + HAL_I2C_STATE_RESET = 0x00U, /*!< Peripheral is not yet Initialized */ + HAL_I2C_STATE_READY = 0x20U, /*!< Peripheral Initialized and ready for use */ + HAL_I2C_STATE_BUSY = 0x24U, /*!< An internal process is ongoing */ + HAL_I2C_STATE_BUSY_TX = 0x21U, /*!< Data Transmission process is ongoing */ + HAL_I2C_STATE_BUSY_RX = 0x22U, /*!< Data Reception process is ongoing */ + HAL_I2C_STATE_LISTEN = 0x28U, /*!< Address Listen Mode is ongoing */ + HAL_I2C_STATE_BUSY_TX_LISTEN = 0x29U, /*!< Address Listen Mode and Data Transmission + process is ongoing */ + HAL_I2C_STATE_BUSY_RX_LISTEN = 0x2AU, /*!< Address Listen Mode and Data Reception + process is ongoing */ + HAL_I2C_STATE_ABORT = 0x60U, /*!< Abort user request ongoing */ + HAL_I2C_STATE_TIMEOUT = 0xA0U, /*!< Timeout state */ + HAL_I2C_STATE_ERROR = 0xE0U /*!< Error */ + +} HAL_I2C_StateTypeDef; + +/** + * @} + */ + +/** @defgroup HAL_mode_structure_definition HAL mode structure definition + * @brief HAL Mode structure definition + * @note HAL I2C Mode value coding follow below described bitmap :\n + * b7 (not used)\n + * x : Should be set to 0\n + * b6\n + * 0 : None\n + * 1 : Memory (HAL I2C communication is in Memory Mode)\n + * b5\n + * 0 : None\n + * 1 : Slave (HAL I2C communication is in Slave Mode)\n + * b4\n + * 0 : None\n + * 1 : Master (HAL I2C communication is in Master Mode)\n + * b3-b2-b1-b0 (not used)\n + * xxxx : Should be set to 0000 + * @{ + */ +typedef enum +{ + HAL_I2C_MODE_NONE = 0x00U, /*!< No I2C communication on going */ + HAL_I2C_MODE_MASTER = 0x10U, /*!< I2C communication is in Master Mode */ + HAL_I2C_MODE_SLAVE = 0x20U, /*!< I2C communication is in Slave Mode */ + HAL_I2C_MODE_MEM = 0x40U /*!< I2C communication is in Memory Mode */ + +} HAL_I2C_ModeTypeDef; + +/** + * @} + */ + +/** @defgroup I2C_Error_Code_definition I2C Error Code definition + * @brief I2C Error Code definition + * @{ + */ +#define HAL_I2C_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_I2C_ERROR_BERR (0x00000001U) /*!< BERR error */ +#define HAL_I2C_ERROR_ARLO (0x00000002U) /*!< ARLO error */ +#define HAL_I2C_ERROR_AF (0x00000004U) /*!< ACKF error */ +#define HAL_I2C_ERROR_OVR (0x00000008U) /*!< OVR error */ +#define HAL_I2C_ERROR_DMA (0x00000010U) /*!< DMA transfer error */ +#define HAL_I2C_ERROR_TIMEOUT (0x00000020U) /*!< Timeout error */ +#define HAL_I2C_ERROR_SIZE (0x00000040U) /*!< Size Management error */ +#define HAL_I2C_ERROR_DMA_PARAM (0x00000080U) /*!< DMA Parameter Error */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) +#define HAL_I2C_ERROR_INVALID_CALLBACK (0x00000100U) /*!< Invalid Callback error */ +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ +#define HAL_I2C_ERROR_INVALID_PARAM (0x00000200U) /*!< Invalid Parameters error */ +/** + * @} + */ + +/** @defgroup I2C_handle_Structure_definition I2C handle Structure definition + * @brief I2C handle Structure definition + * @{ + */ +typedef struct __I2C_HandleTypeDef +{ + I2C_TypeDef *Instance; /*!< I2C registers base address */ + + I2C_InitTypeDef Init; /*!< I2C communication parameters */ + + uint8_t *pBuffPtr; /*!< Pointer to I2C transfer buffer */ + + uint16_t XferSize; /*!< I2C transfer size */ + + __IO uint16_t XferCount; /*!< I2C transfer counter */ + + __IO uint32_t XferOptions; /*!< I2C sequantial transfer options, this parameter can + be a value of @ref I2C_XFEROPTIONS */ + + __IO uint32_t PreviousState; /*!< I2C communication Previous state */ + + HAL_StatusTypeDef(*XferISR)(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, uint32_t ITSources); + /*!< I2C transfer IRQ handler function pointer */ + + DMA_HandleTypeDef *hdmatx; /*!< I2C Tx DMA handle parameters */ + + DMA_HandleTypeDef *hdmarx; /*!< I2C Rx DMA handle parameters */ + + HAL_LockTypeDef Lock; /*!< I2C locking object */ + + __IO HAL_I2C_StateTypeDef State; /*!< I2C communication state */ + + __IO HAL_I2C_ModeTypeDef Mode; /*!< I2C communication mode */ + + __IO uint32_t ErrorCode; /*!< I2C Error code */ + + __IO uint32_t AddrEventCount; /*!< I2C Address Event counter */ + +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + void (* MasterTxCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Master Tx Transfer completed callback */ + void (* MasterRxCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Master Rx Transfer completed callback */ + void (* SlaveTxCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Slave Tx Transfer completed callback */ + void (* SlaveRxCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Slave Rx Transfer completed callback */ + void (* ListenCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Listen Complete callback */ + void (* MemTxCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Memory Tx Transfer completed callback */ + void (* MemRxCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Memory Rx Transfer completed callback */ + void (* ErrorCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Error callback */ + void (* AbortCpltCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Abort callback */ + + void (* AddrCallback)(struct __I2C_HandleTypeDef *hi2c, uint8_t TransferDirection, uint16_t AddrMatchCode); + /*!< I2C Slave Address Match callback */ + + void (* MspInitCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Msp Init callback */ + void (* MspDeInitCallback)(struct __I2C_HandleTypeDef *hi2c); + /*!< I2C Msp DeInit callback */ + +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ +} I2C_HandleTypeDef; + +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) +/** + * @brief HAL I2C Callback ID enumeration definition + */ +typedef enum +{ + HAL_I2C_MASTER_TX_COMPLETE_CB_ID = 0x00U, /*!< I2C Master Tx Transfer completed callback ID */ + HAL_I2C_MASTER_RX_COMPLETE_CB_ID = 0x01U, /*!< I2C Master Rx Transfer completed callback ID */ + HAL_I2C_SLAVE_TX_COMPLETE_CB_ID = 0x02U, /*!< I2C Slave Tx Transfer completed callback ID */ + HAL_I2C_SLAVE_RX_COMPLETE_CB_ID = 0x03U, /*!< I2C Slave Rx Transfer completed callback ID */ + HAL_I2C_LISTEN_COMPLETE_CB_ID = 0x04U, /*!< I2C Listen Complete callback ID */ + HAL_I2C_MEM_TX_COMPLETE_CB_ID = 0x05U, /*!< I2C Memory Tx Transfer callback ID */ + HAL_I2C_MEM_RX_COMPLETE_CB_ID = 0x06U, /*!< I2C Memory Rx Transfer completed callback ID */ + HAL_I2C_ERROR_CB_ID = 0x07U, /*!< I2C Error callback ID */ + HAL_I2C_ABORT_CB_ID = 0x08U, /*!< I2C Abort callback ID */ + + HAL_I2C_MSPINIT_CB_ID = 0x09U, /*!< I2C Msp Init callback ID */ + HAL_I2C_MSPDEINIT_CB_ID = 0x0AU /*!< I2C Msp DeInit callback ID */ + +} HAL_I2C_CallbackIDTypeDef; + +/** + * @brief HAL I2C Callback pointer definition + */ +typedef void (*pI2C_CallbackTypeDef)(I2C_HandleTypeDef *hi2c); +/*!< pointer to an I2C callback function */ +typedef void (*pI2C_AddrCallbackTypeDef)(I2C_HandleTypeDef *hi2c, uint8_t TransferDirection, + uint16_t AddrMatchCode); +/*!< pointer to an I2C Address Match callback function */ + +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** + * @} + */ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup I2C_Exported_Constants I2C Exported Constants + * @{ + */ + +/** @defgroup I2C_XFEROPTIONS I2C Sequential Transfer Options + * @{ + */ +#define I2C_FIRST_FRAME ((uint32_t)I2C_SOFTEND_MODE) +#define I2C_FIRST_AND_NEXT_FRAME ((uint32_t)(I2C_RELOAD_MODE | I2C_SOFTEND_MODE)) +#define I2C_NEXT_FRAME ((uint32_t)(I2C_RELOAD_MODE | I2C_SOFTEND_MODE)) +#define I2C_FIRST_AND_LAST_FRAME ((uint32_t)I2C_AUTOEND_MODE) +#define I2C_LAST_FRAME ((uint32_t)I2C_AUTOEND_MODE) +#define I2C_LAST_FRAME_NO_STOP ((uint32_t)I2C_SOFTEND_MODE) + +/* List of XferOptions in usage of : + * 1- Restart condition in all use cases (direction change or not) + */ +#define I2C_OTHER_FRAME (0x000000AAU) +#define I2C_OTHER_AND_LAST_FRAME (0x0000AA00U) +/** + * @} + */ + +/** @defgroup I2C_ADDRESSING_MODE I2C Addressing Mode + * @{ + */ +#define I2C_ADDRESSINGMODE_7BIT (0x00000001U) +#define I2C_ADDRESSINGMODE_10BIT (0x00000002U) +/** + * @} + */ + +/** @defgroup I2C_DUAL_ADDRESSING_MODE I2C Dual Addressing Mode + * @{ + */ +#define I2C_DUALADDRESS_DISABLE (0x00000000U) +#define I2C_DUALADDRESS_ENABLE I2C_OAR2_OA2EN +/** + * @} + */ + +/** @defgroup I2C_OWN_ADDRESS2_MASKS I2C Own Address2 Masks + * @{ + */ +#define I2C_OA2_NOMASK ((uint8_t)0x00U) +#define I2C_OA2_MASK01 ((uint8_t)0x01U) +#define I2C_OA2_MASK02 ((uint8_t)0x02U) +#define I2C_OA2_MASK03 ((uint8_t)0x03U) +#define I2C_OA2_MASK04 ((uint8_t)0x04U) +#define I2C_OA2_MASK05 ((uint8_t)0x05U) +#define I2C_OA2_MASK06 ((uint8_t)0x06U) +#define I2C_OA2_MASK07 ((uint8_t)0x07U) +/** + * @} + */ + +/** @defgroup I2C_GENERAL_CALL_ADDRESSING_MODE I2C General Call Addressing Mode + * @{ + */ +#define I2C_GENERALCALL_DISABLE (0x00000000U) +#define I2C_GENERALCALL_ENABLE I2C_CR1_GCEN +/** + * @} + */ + +/** @defgroup I2C_NOSTRETCH_MODE I2C No-Stretch Mode + * @{ + */ +#define I2C_NOSTRETCH_DISABLE (0x00000000U) +#define I2C_NOSTRETCH_ENABLE I2C_CR1_NOSTRETCH +/** + * @} + */ + +/** @defgroup I2C_MEMORY_ADDRESS_SIZE I2C Memory Address Size + * @{ + */ +#define I2C_MEMADD_SIZE_8BIT (0x00000001U) +#define I2C_MEMADD_SIZE_16BIT (0x00000002U) +/** + * @} + */ + +/** @defgroup I2C_XFERDIRECTION I2C Transfer Direction Master Point of View + * @{ + */ +#define I2C_DIRECTION_TRANSMIT (0x00000000U) +#define I2C_DIRECTION_RECEIVE (0x00000001U) +/** + * @} + */ + +/** @defgroup I2C_RELOAD_END_MODE I2C Reload End Mode + * @{ + */ +#define I2C_RELOAD_MODE I2C_CR2_RELOAD +#define I2C_AUTOEND_MODE I2C_CR2_AUTOEND +#define I2C_SOFTEND_MODE (0x00000000U) +/** + * @} + */ + +/** @defgroup I2C_START_STOP_MODE I2C Start or Stop Mode + * @{ + */ +#define I2C_NO_STARTSTOP (0x00000000U) +#define I2C_GENERATE_STOP (uint32_t)(0x80000000U | I2C_CR2_STOP) +#define I2C_GENERATE_START_READ (uint32_t)(0x80000000U | I2C_CR2_START | I2C_CR2_RD_WRN) +#define I2C_GENERATE_START_WRITE (uint32_t)(0x80000000U | I2C_CR2_START) +/** + * @} + */ + +/** @defgroup I2C_Interrupt_configuration_definition I2C Interrupt configuration definition + * @brief I2C Interrupt definition + * Elements values convention: 0xXXXXXXXX + * - XXXXXXXX : Interrupt control mask + * @{ + */ +#define I2C_IT_ERRI I2C_CR1_ERRIE +#define I2C_IT_TCI I2C_CR1_TCIE +#define I2C_IT_STOPI I2C_CR1_STOPIE +#define I2C_IT_NACKI I2C_CR1_NACKIE +#define I2C_IT_ADDRI I2C_CR1_ADDRIE +#define I2C_IT_RXI I2C_CR1_RXIE +#define I2C_IT_TXI I2C_CR1_TXIE +/** + * @} + */ + +/** @defgroup I2C_Flag_definition I2C Flag definition + * @{ + */ +#define I2C_FLAG_TXE I2C_ISR_TXE +#define I2C_FLAG_TXIS I2C_ISR_TXIS +#define I2C_FLAG_RXNE I2C_ISR_RXNE +#define I2C_FLAG_ADDR I2C_ISR_ADDR +#define I2C_FLAG_AF I2C_ISR_NACKF +#define I2C_FLAG_STOPF I2C_ISR_STOPF +#define I2C_FLAG_TC I2C_ISR_TC +#define I2C_FLAG_TCR I2C_ISR_TCR +#define I2C_FLAG_BERR I2C_ISR_BERR +#define I2C_FLAG_ARLO I2C_ISR_ARLO +#define I2C_FLAG_OVR I2C_ISR_OVR +#define I2C_FLAG_PECERR I2C_ISR_PECERR +#define I2C_FLAG_TIMEOUT I2C_ISR_TIMEOUT +#define I2C_FLAG_ALERT I2C_ISR_ALERT +#define I2C_FLAG_BUSY I2C_ISR_BUSY +#define I2C_FLAG_DIR I2C_ISR_DIR +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ + +/** @defgroup I2C_Exported_Macros I2C Exported Macros + * @{ + */ + +/** @brief Reset I2C handle state. + * @param __HANDLE__ specifies the I2C Handle. + * @retval None + */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) +#define __HAL_I2C_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_I2C_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_I2C_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_I2C_STATE_RESET) +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + +/** @brief Enable the specified I2C interrupt. + * @param __HANDLE__ specifies the I2C Handle. + * @param __INTERRUPT__ specifies the interrupt source to enable. + * This parameter can be one of the following values: + * @arg @ref I2C_IT_ERRI Errors interrupt enable + * @arg @ref I2C_IT_TCI Transfer complete interrupt enable + * @arg @ref I2C_IT_STOPI STOP detection interrupt enable + * @arg @ref I2C_IT_NACKI NACK received interrupt enable + * @arg @ref I2C_IT_ADDRI Address match interrupt enable + * @arg @ref I2C_IT_RXI RX interrupt enable + * @arg @ref I2C_IT_TXI TX interrupt enable + * + * @retval None + */ +#define __HAL_I2C_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 |= (__INTERRUPT__)) + +/** @brief Disable the specified I2C interrupt. + * @param __HANDLE__ specifies the I2C Handle. + * @param __INTERRUPT__ specifies the interrupt source to disable. + * This parameter can be one of the following values: + * @arg @ref I2C_IT_ERRI Errors interrupt enable + * @arg @ref I2C_IT_TCI Transfer complete interrupt enable + * @arg @ref I2C_IT_STOPI STOP detection interrupt enable + * @arg @ref I2C_IT_NACKI NACK received interrupt enable + * @arg @ref I2C_IT_ADDRI Address match interrupt enable + * @arg @ref I2C_IT_RXI RX interrupt enable + * @arg @ref I2C_IT_TXI TX interrupt enable + * + * @retval None + */ +#define __HAL_I2C_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 &= (~(__INTERRUPT__))) + +/** @brief Check whether the specified I2C interrupt source is enabled or not. + * @param __HANDLE__ specifies the I2C Handle. + * @param __INTERRUPT__ specifies the I2C interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref I2C_IT_ERRI Errors interrupt enable + * @arg @ref I2C_IT_TCI Transfer complete interrupt enable + * @arg @ref I2C_IT_STOPI STOP detection interrupt enable + * @arg @ref I2C_IT_NACKI NACK received interrupt enable + * @arg @ref I2C_IT_ADDRI Address match interrupt enable + * @arg @ref I2C_IT_RXI RX interrupt enable + * @arg @ref I2C_IT_TXI TX interrupt enable + * + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_I2C_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->CR1 & \ + (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET) + +/** @brief Check whether the specified I2C flag is set or not. + * @param __HANDLE__ specifies the I2C Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref I2C_FLAG_TXE Transmit data register empty + * @arg @ref I2C_FLAG_TXIS Transmit interrupt status + * @arg @ref I2C_FLAG_RXNE Receive data register not empty + * @arg @ref I2C_FLAG_ADDR Address matched (slave mode) + * @arg @ref I2C_FLAG_AF Acknowledge failure received flag + * @arg @ref I2C_FLAG_STOPF STOP detection flag + * @arg @ref I2C_FLAG_TC Transfer complete (master mode) + * @arg @ref I2C_FLAG_TCR Transfer complete reload + * @arg @ref I2C_FLAG_BERR Bus error + * @arg @ref I2C_FLAG_ARLO Arbitration lost + * @arg @ref I2C_FLAG_OVR Overrun/Underrun + * @arg @ref I2C_FLAG_PECERR PEC error in reception + * @arg @ref I2C_FLAG_TIMEOUT Timeout or Tlow detection flag + * @arg @ref I2C_FLAG_ALERT SMBus alert + * @arg @ref I2C_FLAG_BUSY Bus busy + * @arg @ref I2C_FLAG_DIR Transfer direction (slave mode) + * + * @retval The new state of __FLAG__ (SET or RESET). + */ +#define I2C_FLAG_MASK (0x0001FFFFU) +#define __HAL_I2C_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & \ + (__FLAG__)) == (__FLAG__)) ? SET : RESET) + +/** @brief Clear the I2C pending flags which are cleared by writing 1 in a specific bit. + * @param __HANDLE__ specifies the I2C Handle. + * @param __FLAG__ specifies the flag to clear. + * This parameter can be any combination of the following values: + * @arg @ref I2C_FLAG_TXE Transmit data register empty + * @arg @ref I2C_FLAG_ADDR Address matched (slave mode) + * @arg @ref I2C_FLAG_AF Acknowledge failure received flag + * @arg @ref I2C_FLAG_STOPF STOP detection flag + * @arg @ref I2C_FLAG_BERR Bus error + * @arg @ref I2C_FLAG_ARLO Arbitration lost + * @arg @ref I2C_FLAG_OVR Overrun/Underrun + * @arg @ref I2C_FLAG_PECERR PEC error in reception + * @arg @ref I2C_FLAG_TIMEOUT Timeout or Tlow detection flag + * @arg @ref I2C_FLAG_ALERT SMBus alert + * + * @retval None + */ +#define __HAL_I2C_CLEAR_FLAG(__HANDLE__, __FLAG__) (((__FLAG__) == I2C_FLAG_TXE) ? \ + ((__HANDLE__)->Instance->ISR |= (__FLAG__)) : \ + ((__HANDLE__)->Instance->ICR = (__FLAG__))) + +/** @brief Enable the specified I2C peripheral. + * @param __HANDLE__ specifies the I2C Handle. + * @retval None + */ +#define __HAL_I2C_ENABLE(__HANDLE__) (SET_BIT((__HANDLE__)->Instance->CR1, I2C_CR1_PE)) + +/** @brief Disable the specified I2C peripheral. + * @param __HANDLE__ specifies the I2C Handle. + * @retval None + */ +#define __HAL_I2C_DISABLE(__HANDLE__) (CLEAR_BIT((__HANDLE__)->Instance->CR1, I2C_CR1_PE)) + +/** @brief Generate a Non-Acknowledge I2C peripheral in Slave mode. + * @param __HANDLE__ specifies the I2C Handle. + * @retval None + */ +#define __HAL_I2C_GENERATE_NACK(__HANDLE__) (SET_BIT((__HANDLE__)->Instance->CR2, I2C_CR2_NACK)) +/** + * @} + */ + +/* Include I2C HAL Extended module */ +#include "stm32f0xx_hal_i2c_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup I2C_Exported_Functions + * @{ + */ + +/** @addtogroup I2C_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ +/* Initialization and de-initialization functions******************************/ +HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c); +HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c); +void HAL_I2C_MspInit(I2C_HandleTypeDef *hi2c); +void HAL_I2C_MspDeInit(I2C_HandleTypeDef *hi2c); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_I2C_RegisterCallback(I2C_HandleTypeDef *hi2c, HAL_I2C_CallbackIDTypeDef CallbackID, + pI2C_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_I2C_UnRegisterCallback(I2C_HandleTypeDef *hi2c, HAL_I2C_CallbackIDTypeDef CallbackID); + +HAL_StatusTypeDef HAL_I2C_RegisterAddrCallback(I2C_HandleTypeDef *hi2c, pI2C_AddrCallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_I2C_UnRegisterAddrCallback(I2C_HandleTypeDef *hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @addtogroup I2C_Exported_Functions_Group2 Input and Output operation functions + * @{ + */ +/* IO operation functions ****************************************************/ +/******* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_I2C_Master_Transmit(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_I2C_Master_Receive(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_I2C_Slave_Transmit(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t Timeout); +HAL_StatusTypeDef HAL_I2C_Slave_Receive(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t Timeout); +HAL_StatusTypeDef HAL_I2C_Mem_Write(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_I2C_Mem_Read(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint32_t Trials, + uint32_t Timeout); + +/******* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_I2C_Master_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Master_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Slave_Transmit_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Slave_Receive_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Mem_Write_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Mem_Read_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size); + +HAL_StatusTypeDef HAL_I2C_Master_Seq_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions); +HAL_StatusTypeDef HAL_I2C_Master_Seq_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions); +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Transmit_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions); +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Receive_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions); +HAL_StatusTypeDef HAL_I2C_EnableListen_IT(I2C_HandleTypeDef *hi2c); +HAL_StatusTypeDef HAL_I2C_DisableListen_IT(I2C_HandleTypeDef *hi2c); +HAL_StatusTypeDef HAL_I2C_Master_Abort_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress); + +/******* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_I2C_Master_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Master_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Slave_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Slave_Receive_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Mem_Write_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2C_Mem_Read_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size); + +HAL_StatusTypeDef HAL_I2C_Master_Seq_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions); +HAL_StatusTypeDef HAL_I2C_Master_Seq_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions); +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions); +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Receive_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions); +/** + * @} + */ + +/** @addtogroup I2C_IRQ_Handler_and_Callbacks IRQ Handler and Callbacks + * @{ + */ +/******* I2C IRQHandler and Callbacks used in non blocking modes (Interrupt and DMA) */ +void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c); +void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c); +void HAL_I2C_MasterTxCpltCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_SlaveTxCpltCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_AddrCallback(I2C_HandleTypeDef *hi2c, uint8_t TransferDirection, uint16_t AddrMatchCode); +void HAL_I2C_ListenCpltCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_MemTxCpltCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_ErrorCallback(I2C_HandleTypeDef *hi2c); +void HAL_I2C_AbortCpltCallback(I2C_HandleTypeDef *hi2c); +/** + * @} + */ + +/** @addtogroup I2C_Exported_Functions_Group3 Peripheral State, Mode and Error functions + * @{ + */ +/* Peripheral State, Mode and Error functions *********************************/ +HAL_I2C_StateTypeDef HAL_I2C_GetState(I2C_HandleTypeDef *hi2c); +HAL_I2C_ModeTypeDef HAL_I2C_GetMode(I2C_HandleTypeDef *hi2c); +uint32_t HAL_I2C_GetError(I2C_HandleTypeDef *hi2c); + +/** + * @} + */ + +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup I2C_Private_Constants I2C Private Constants + * @{ + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup I2C_Private_Macro I2C Private Macros + * @{ + */ + +#define IS_I2C_ADDRESSING_MODE(MODE) (((MODE) == I2C_ADDRESSINGMODE_7BIT) || \ + ((MODE) == I2C_ADDRESSINGMODE_10BIT)) + +#define IS_I2C_DUAL_ADDRESS(ADDRESS) (((ADDRESS) == I2C_DUALADDRESS_DISABLE) || \ + ((ADDRESS) == I2C_DUALADDRESS_ENABLE)) + +#define IS_I2C_OWN_ADDRESS2_MASK(MASK) (((MASK) == I2C_OA2_NOMASK) || \ + ((MASK) == I2C_OA2_MASK01) || \ + ((MASK) == I2C_OA2_MASK02) || \ + ((MASK) == I2C_OA2_MASK03) || \ + ((MASK) == I2C_OA2_MASK04) || \ + ((MASK) == I2C_OA2_MASK05) || \ + ((MASK) == I2C_OA2_MASK06) || \ + ((MASK) == I2C_OA2_MASK07)) + +#define IS_I2C_GENERAL_CALL(CALL) (((CALL) == I2C_GENERALCALL_DISABLE) || \ + ((CALL) == I2C_GENERALCALL_ENABLE)) + +#define IS_I2C_NO_STRETCH(STRETCH) (((STRETCH) == I2C_NOSTRETCH_DISABLE) || \ + ((STRETCH) == I2C_NOSTRETCH_ENABLE)) + +#define IS_I2C_MEMADD_SIZE(SIZE) (((SIZE) == I2C_MEMADD_SIZE_8BIT) || \ + ((SIZE) == I2C_MEMADD_SIZE_16BIT)) + +#define IS_TRANSFER_MODE(MODE) (((MODE) == I2C_RELOAD_MODE) || \ + ((MODE) == I2C_AUTOEND_MODE) || \ + ((MODE) == I2C_SOFTEND_MODE)) + +#define IS_TRANSFER_REQUEST(REQUEST) (((REQUEST) == I2C_GENERATE_STOP) || \ + ((REQUEST) == I2C_GENERATE_START_READ) || \ + ((REQUEST) == I2C_GENERATE_START_WRITE) || \ + ((REQUEST) == I2C_NO_STARTSTOP)) + +#define IS_I2C_TRANSFER_OPTIONS_REQUEST(REQUEST) (((REQUEST) == I2C_FIRST_FRAME) || \ + ((REQUEST) == I2C_FIRST_AND_NEXT_FRAME) || \ + ((REQUEST) == I2C_NEXT_FRAME) || \ + ((REQUEST) == I2C_FIRST_AND_LAST_FRAME) || \ + ((REQUEST) == I2C_LAST_FRAME) || \ + ((REQUEST) == I2C_LAST_FRAME_NO_STOP) || \ + IS_I2C_TRANSFER_OTHER_OPTIONS_REQUEST(REQUEST)) + +#define IS_I2C_TRANSFER_OTHER_OPTIONS_REQUEST(REQUEST) (((REQUEST) == I2C_OTHER_FRAME) || \ + ((REQUEST) == I2C_OTHER_AND_LAST_FRAME)) + +#define I2C_RESET_CR2(__HANDLE__) ((__HANDLE__)->Instance->CR2 &= \ + (uint32_t)~((uint32_t)(I2C_CR2_SADD | I2C_CR2_HEAD10R | \ + I2C_CR2_NBYTES | I2C_CR2_RELOAD | \ + I2C_CR2_RD_WRN))) + +#define I2C_GET_ADDR_MATCH(__HANDLE__) ((uint16_t)(((__HANDLE__)->Instance->ISR & I2C_ISR_ADDCODE) \ + >> 16U)) +#define I2C_GET_DIR(__HANDLE__) ((uint8_t)(((__HANDLE__)->Instance->ISR & I2C_ISR_DIR) \ + >> 16U)) +#define I2C_GET_STOP_MODE(__HANDLE__) ((__HANDLE__)->Instance->CR2 & I2C_CR2_AUTOEND) +#define I2C_GET_OWN_ADDRESS1(__HANDLE__) ((uint16_t)((__HANDLE__)->Instance->OAR1 & I2C_OAR1_OA1)) +#define I2C_GET_OWN_ADDRESS2(__HANDLE__) ((uint16_t)((__HANDLE__)->Instance->OAR2 & I2C_OAR2_OA2)) + +#define IS_I2C_OWN_ADDRESS1(ADDRESS1) ((ADDRESS1) <= 0x000003FFU) +#define IS_I2C_OWN_ADDRESS2(ADDRESS2) ((ADDRESS2) <= (uint16_t)0x00FFU) + +#define I2C_MEM_ADD_MSB(__ADDRESS__) ((uint8_t)((uint16_t)(((uint16_t)((__ADDRESS__) & \ + (uint16_t)(0xFF00U))) >> 8U))) +#define I2C_MEM_ADD_LSB(__ADDRESS__) ((uint8_t)((uint16_t)((__ADDRESS__) & (uint16_t)(0x00FFU)))) + +#define I2C_GENERATE_START(__ADDMODE__,__ADDRESS__) (((__ADDMODE__) == I2C_ADDRESSINGMODE_7BIT) ? \ + (uint32_t)((((uint32_t)(__ADDRESS__) & (I2C_CR2_SADD)) | \ + (I2C_CR2_START) | (I2C_CR2_AUTOEND)) & \ + (~I2C_CR2_RD_WRN)) : \ + (uint32_t)((((uint32_t)(__ADDRESS__) & (I2C_CR2_SADD)) | \ + (I2C_CR2_ADD10) | (I2C_CR2_START)) & \ + (~I2C_CR2_RD_WRN))) + +#define I2C_CHECK_FLAG(__ISR__, __FLAG__) ((((__ISR__) & ((__FLAG__) & I2C_FLAG_MASK)) == \ + ((__FLAG__) & I2C_FLAG_MASK)) ? SET : RESET) +#define I2C_CHECK_IT_SOURCE(__CR1__, __IT__) ((((__CR1__) & (__IT__)) == (__IT__)) ? SET : RESET) +/** + * @} + */ + +/* Private Functions ---------------------------------------------------------*/ +/** @defgroup I2C_Private_Functions I2C Private Functions + * @{ + */ +/* Private functions are defined in stm32f0xx_hal_i2c.c file */ +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + + +#endif /* STM32F0xx_HAL_I2C_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c_ex.h new file mode 100644 index 0000000..f8dbcf0 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2c_ex.h @@ -0,0 +1,193 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_i2c_ex.h + * @author MCD Application Team + * @brief Header file of I2C HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_I2C_EX_H +#define STM32F0xx_HAL_I2C_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup I2CEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup I2CEx_Exported_Constants I2C Extended Exported Constants + * @{ + */ + +/** @defgroup I2CEx_Analog_Filter I2C Extended Analog Filter + * @{ + */ +#define I2C_ANALOGFILTER_ENABLE 0x00000000U +#define I2C_ANALOGFILTER_DISABLE I2C_CR1_ANFOFF +/** + * @} + */ + +/** @defgroup I2CEx_FastModePlus I2C Extended Fast Mode Plus + * @{ + */ +#define I2C_FMP_NOT_SUPPORTED 0xAAAA0000U /*!< Fast Mode Plus not supported */ +#if defined(SYSCFG_CFGR1_I2C_FMP_PA9) +#define I2C_FASTMODEPLUS_PA9 SYSCFG_CFGR1_I2C_FMP_PA9 /*!< Enable Fast Mode Plus on PA9 */ +#define I2C_FASTMODEPLUS_PA10 SYSCFG_CFGR1_I2C_FMP_PA10 /*!< Enable Fast Mode Plus on PA10 */ +#else +#define I2C_FASTMODEPLUS_PA9 (uint32_t)(0x00000001U | I2C_FMP_NOT_SUPPORTED) /*!< Fast Mode Plus PA9 not supported */ +#define I2C_FASTMODEPLUS_PA10 (uint32_t)(0x00000002U | I2C_FMP_NOT_SUPPORTED) /*!< Fast Mode Plus PA10 not supported */ +#endif /* SYSCFG_CFGR1_I2C_FMP_PA9 */ +#define I2C_FASTMODEPLUS_PB6 SYSCFG_CFGR1_I2C_FMP_PB6 /*!< Enable Fast Mode Plus on PB6 */ +#define I2C_FASTMODEPLUS_PB7 SYSCFG_CFGR1_I2C_FMP_PB7 /*!< Enable Fast Mode Plus on PB7 */ +#define I2C_FASTMODEPLUS_PB8 SYSCFG_CFGR1_I2C_FMP_PB8 /*!< Enable Fast Mode Plus on PB8 */ +#define I2C_FASTMODEPLUS_PB9 SYSCFG_CFGR1_I2C_FMP_PB9 /*!< Enable Fast Mode Plus on PB9 */ +#if defined(SYSCFG_CFGR1_I2C_FMP_I2C1) +#define I2C_FASTMODEPLUS_I2C1 SYSCFG_CFGR1_I2C_FMP_I2C1 /*!< Enable Fast Mode Plus on I2C1 pins */ +#else +#define I2C_FASTMODEPLUS_I2C1 (uint32_t)(0x00000100U | I2C_FMP_NOT_SUPPORTED) /*!< Fast Mode Plus I2C1 not supported */ +#endif /* SYSCFG_CFGR1_I2C_FMP_I2C1 */ +#if defined(SYSCFG_CFGR1_I2C_FMP_I2C2) +#define I2C_FASTMODEPLUS_I2C2 SYSCFG_CFGR1_I2C_FMP_I2C2 /*!< Enable Fast Mode Plus on I2C2 pins */ +#else +#define I2C_FASTMODEPLUS_I2C2 (uint32_t)(0x00000200U | I2C_FMP_NOT_SUPPORTED) /*!< Fast Mode Plus I2C2 not supported */ +#endif /* SYSCFG_CFGR1_I2C_FMP_I2C2 */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup I2CEx_Exported_Functions I2C Extended Exported Functions + * @{ + */ + +/** @addtogroup I2CEx_Exported_Functions_Group1 Extended features functions + * @brief Extended features functions + * @{ + */ + +/** @addtogroup I2CEx_Exported_Functions_Group1 Filter Mode Functions + * @{ + */ +HAL_StatusTypeDef HAL_I2CEx_ConfigAnalogFilter(I2C_HandleTypeDef *hi2c, + uint32_t AnalogFilter); +HAL_StatusTypeDef HAL_I2CEx_ConfigDigitalFilter(I2C_HandleTypeDef *hi2c, + uint32_t DigitalFilter); +/** + * @} + */ +#if defined(I2C_CR1_WUPEN) + +/** @addtogroup I2CEx_Exported_Functions_Group2 WakeUp Mode Functions + * @{ + */ +HAL_StatusTypeDef HAL_I2CEx_EnableWakeUp(I2C_HandleTypeDef *hi2c); +HAL_StatusTypeDef HAL_I2CEx_DisableWakeUp(I2C_HandleTypeDef *hi2c); +/** + * @} + */ +#endif /* I2C_CR1_WUPEN */ + +/** @addtogroup I2CEx_Exported_Functions_Group3 Fast Mode Plus Functions + * @{ + */ +void HAL_I2CEx_EnableFastModePlus(uint32_t ConfigFastModePlus); +void HAL_I2CEx_DisableFastModePlus(uint32_t ConfigFastModePlus); +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup I2CEx_Private_Constants I2C Extended Private Constants + * @{ + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup I2CEx_Private_Macro I2C Extended Private Macros + * @{ + */ +#define IS_I2C_ANALOG_FILTER(FILTER) (((FILTER) == I2C_ANALOGFILTER_ENABLE) || \ + ((FILTER) == I2C_ANALOGFILTER_DISABLE)) + +#define IS_I2C_DIGITAL_FILTER(FILTER) ((FILTER) <= 0x0000000FU) + +#define IS_I2C_FASTMODEPLUS(__CONFIG__) ((((__CONFIG__) & I2C_FMP_NOT_SUPPORTED) != I2C_FMP_NOT_SUPPORTED) && \ + ((((__CONFIG__) & (I2C_FASTMODEPLUS_PA9)) == I2C_FASTMODEPLUS_PA9) || \ + (((__CONFIG__) & (I2C_FASTMODEPLUS_PA10)) == I2C_FASTMODEPLUS_PA10) || \ + (((__CONFIG__) & (I2C_FASTMODEPLUS_PB6)) == I2C_FASTMODEPLUS_PB6) || \ + (((__CONFIG__) & (I2C_FASTMODEPLUS_PB7)) == I2C_FASTMODEPLUS_PB7) || \ + (((__CONFIG__) & (I2C_FASTMODEPLUS_PB8)) == I2C_FASTMODEPLUS_PB8) || \ + (((__CONFIG__) & (I2C_FASTMODEPLUS_PB9)) == I2C_FASTMODEPLUS_PB9) || \ + (((__CONFIG__) & (I2C_FASTMODEPLUS_I2C1)) == I2C_FASTMODEPLUS_I2C1) || \ + (((__CONFIG__) & (I2C_FASTMODEPLUS_I2C2)) == I2C_FASTMODEPLUS_I2C2))) +/** + * @} + */ + +/* Private Functions ---------------------------------------------------------*/ +/** @defgroup I2CEx_Private_Functions I2C Extended Private Functions + * @{ + */ +/* Private functions are defined in stm32f0xx_hal_i2c_ex.c file */ +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_I2C_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2s.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2s.h new file mode 100644 index 0000000..e13c670 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_i2s.h @@ -0,0 +1,546 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_i2s.h + * @author MCD Application Team + * @brief Header file of I2S HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_I2S_H +#define STM32F0xx_HAL_I2S_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +#if defined(SPI_I2S_SUPPORT) +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup I2S + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup I2S_Exported_Types I2S Exported Types + * @{ + */ + +/** + * @brief I2S Init structure definition + */ +typedef struct +{ + uint32_t Mode; /*!< Specifies the I2S operating mode. + This parameter can be a value of @ref I2S_Mode */ + + uint32_t Standard; /*!< Specifies the standard used for the I2S communication. + This parameter can be a value of @ref I2S_Standard */ + + uint32_t DataFormat; /*!< Specifies the data format for the I2S communication. + This parameter can be a value of @ref I2S_Data_Format */ + + uint32_t MCLKOutput; /*!< Specifies whether the I2S MCLK output is enabled or not. + This parameter can be a value of @ref I2S_MCLK_Output */ + + uint32_t AudioFreq; /*!< Specifies the frequency selected for the I2S communication. + This parameter can be a value of @ref I2S_Audio_Frequency */ + + uint32_t CPOL; /*!< Specifies the idle state of the I2S clock. + This parameter can be a value of @ref I2S_Clock_Polarity */ +} I2S_InitTypeDef; + +/** + * @brief HAL State structures definition + */ +typedef enum +{ + HAL_I2S_STATE_RESET = 0x00U, /*!< I2S not yet initialized or disabled */ + HAL_I2S_STATE_READY = 0x01U, /*!< I2S initialized and ready for use */ + HAL_I2S_STATE_BUSY = 0x02U, /*!< I2S internal process is ongoing */ + HAL_I2S_STATE_BUSY_TX = 0x03U, /*!< Data Transmission process is ongoing */ + HAL_I2S_STATE_BUSY_RX = 0x04U, /*!< Data Reception process is ongoing */ + HAL_I2S_STATE_TIMEOUT = 0x06U, /*!< I2S timeout state */ + HAL_I2S_STATE_ERROR = 0x07U /*!< I2S error state */ +} HAL_I2S_StateTypeDef; + +/** + * @brief I2S handle Structure definition + */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1) +typedef struct __I2S_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +{ + SPI_TypeDef *Instance; /*!< I2S registers base address */ + + I2S_InitTypeDef Init; /*!< I2S communication parameters */ + + uint16_t *pTxBuffPtr; /*!< Pointer to I2S Tx transfer buffer */ + + __IO uint16_t TxXferSize; /*!< I2S Tx transfer size */ + + __IO uint16_t TxXferCount; /*!< I2S Tx transfer Counter */ + + uint16_t *pRxBuffPtr; /*!< Pointer to I2S Rx transfer buffer */ + + __IO uint16_t RxXferSize; /*!< I2S Rx transfer size */ + + __IO uint16_t RxXferCount; /*!< I2S Rx transfer counter + (This field is initialized at the + same value as transfer size at the + beginning of the transfer and + decremented when a sample is received + NbSamplesReceived = RxBufferSize-RxBufferCount) */ + DMA_HandleTypeDef *hdmatx; /*!< I2S Tx DMA handle parameters */ + + DMA_HandleTypeDef *hdmarx; /*!< I2S Rx DMA handle parameters */ + + __IO HAL_LockTypeDef Lock; /*!< I2S locking object */ + + __IO HAL_I2S_StateTypeDef State; /*!< I2S communication state */ + + __IO uint32_t ErrorCode; /*!< I2S Error code + This parameter can be a value of @ref I2S_Error */ + +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + void (* TxCpltCallback)(struct __I2S_HandleTypeDef *hi2s); /*!< I2S Tx Completed callback */ + void (* RxCpltCallback)(struct __I2S_HandleTypeDef *hi2s); /*!< I2S Rx Completed callback */ + void (* TxHalfCpltCallback)(struct __I2S_HandleTypeDef *hi2s); /*!< I2S Tx Half Completed callback */ + void (* RxHalfCpltCallback)(struct __I2S_HandleTypeDef *hi2s); /*!< I2S Rx Half Completed callback */ + void (* ErrorCallback)(struct __I2S_HandleTypeDef *hi2s); /*!< I2S Error callback */ + void (* MspInitCallback)(struct __I2S_HandleTypeDef *hi2s); /*!< I2S Msp Init callback */ + void (* MspDeInitCallback)(struct __I2S_HandleTypeDef *hi2s); /*!< I2S Msp DeInit callback */ + +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +} I2S_HandleTypeDef; + +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) +/** + * @brief HAL I2S Callback ID enumeration definition + */ +typedef enum +{ + HAL_I2S_TX_COMPLETE_CB_ID = 0x00U, /*!< I2S Tx Completed callback ID */ + HAL_I2S_RX_COMPLETE_CB_ID = 0x01U, /*!< I2S Rx Completed callback ID */ + HAL_I2S_TX_HALF_COMPLETE_CB_ID = 0x03U, /*!< I2S Tx Half Completed callback ID */ + HAL_I2S_RX_HALF_COMPLETE_CB_ID = 0x04U, /*!< I2S Rx Half Completed callback ID */ + HAL_I2S_ERROR_CB_ID = 0x06U, /*!< I2S Error callback ID */ + HAL_I2S_MSPINIT_CB_ID = 0x07U, /*!< I2S Msp Init callback ID */ + HAL_I2S_MSPDEINIT_CB_ID = 0x08U /*!< I2S Msp DeInit callback ID */ + +} HAL_I2S_CallbackIDTypeDef; + +/** + * @brief HAL I2S Callback pointer definition + */ +typedef void (*pI2S_CallbackTypeDef)(I2S_HandleTypeDef *hi2s); /*!< pointer to an I2S callback function */ + +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup I2S_Exported_Constants I2S Exported Constants + * @{ + */ +/** @defgroup I2S_Error I2S Error + * @{ + */ +#define HAL_I2S_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_I2S_ERROR_TIMEOUT (0x00000001U) /*!< Timeout error */ +#define HAL_I2S_ERROR_OVR (0x00000002U) /*!< OVR error */ +#define HAL_I2S_ERROR_UDR (0x00000004U) /*!< UDR error */ +#define HAL_I2S_ERROR_DMA (0x00000008U) /*!< DMA transfer error */ +#define HAL_I2S_ERROR_PRESCALER (0x00000010U) /*!< Prescaler Calculation error */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) +#define HAL_I2S_ERROR_INVALID_CALLBACK (0x00000020U) /*!< Invalid Callback error */ +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup I2S_Mode I2S Mode + * @{ + */ +#define I2S_MODE_SLAVE_TX (0x00000000U) +#define I2S_MODE_SLAVE_RX (SPI_I2SCFGR_I2SCFG_0) +#define I2S_MODE_MASTER_TX (SPI_I2SCFGR_I2SCFG_1) +#define I2S_MODE_MASTER_RX ((SPI_I2SCFGR_I2SCFG_0 | SPI_I2SCFGR_I2SCFG_1)) +/** + * @} + */ + +/** @defgroup I2S_Standard I2S Standard + * @{ + */ +#define I2S_STANDARD_PHILIPS (0x00000000U) +#define I2S_STANDARD_MSB (SPI_I2SCFGR_I2SSTD_0) +#define I2S_STANDARD_LSB (SPI_I2SCFGR_I2SSTD_1) +#define I2S_STANDARD_PCM_SHORT ((SPI_I2SCFGR_I2SSTD_0 | SPI_I2SCFGR_I2SSTD_1)) +#define I2S_STANDARD_PCM_LONG ((SPI_I2SCFGR_I2SSTD_0 | SPI_I2SCFGR_I2SSTD_1 | SPI_I2SCFGR_PCMSYNC)) +/** + * @} + */ + +/** @defgroup I2S_Data_Format I2S Data Format + * @{ + */ +#define I2S_DATAFORMAT_16B (0x00000000U) +#define I2S_DATAFORMAT_16B_EXTENDED (SPI_I2SCFGR_CHLEN) +#define I2S_DATAFORMAT_24B ((SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN_0)) +#define I2S_DATAFORMAT_32B ((SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN_1)) +/** + * @} + */ + +/** @defgroup I2S_MCLK_Output I2S MCLK Output + * @{ + */ +#define I2S_MCLKOUTPUT_ENABLE (SPI_I2SPR_MCKOE) +#define I2S_MCLKOUTPUT_DISABLE (0x00000000U) +/** + * @} + */ + +/** @defgroup I2S_Audio_Frequency I2S Audio Frequency + * @{ + */ +#define I2S_AUDIOFREQ_192K (192000U) +#define I2S_AUDIOFREQ_96K (96000U) +#define I2S_AUDIOFREQ_48K (48000U) +#define I2S_AUDIOFREQ_44K (44100U) +#define I2S_AUDIOFREQ_32K (32000U) +#define I2S_AUDIOFREQ_22K (22050U) +#define I2S_AUDIOFREQ_16K (16000U) +#define I2S_AUDIOFREQ_11K (11025U) +#define I2S_AUDIOFREQ_8K (8000U) +#define I2S_AUDIOFREQ_DEFAULT (2U) +/** + * @} + */ + +/** @defgroup I2S_Clock_Polarity I2S Clock Polarity + * @{ + */ +#define I2S_CPOL_LOW (0x00000000U) +#define I2S_CPOL_HIGH (SPI_I2SCFGR_CKPOL) +/** + * @} + */ + +/** @defgroup I2S_Interrupts_Definition I2S Interrupts Definition + * @{ + */ +#define I2S_IT_TXE SPI_CR2_TXEIE +#define I2S_IT_RXNE SPI_CR2_RXNEIE +#define I2S_IT_ERR SPI_CR2_ERRIE +/** + * @} + */ + +/** @defgroup I2S_Flags_Definition I2S Flags Definition + * @{ + */ +#define I2S_FLAG_TXE SPI_SR_TXE +#define I2S_FLAG_RXNE SPI_SR_RXNE + +#define I2S_FLAG_UDR SPI_SR_UDR +#define I2S_FLAG_OVR SPI_SR_OVR +#define I2S_FLAG_FRE SPI_SR_FRE + +#define I2S_FLAG_CHSIDE SPI_SR_CHSIDE +#define I2S_FLAG_BSY SPI_SR_BSY + +#define I2S_FLAG_MASK (SPI_SR_RXNE\ + | SPI_SR_TXE | SPI_SR_UDR | SPI_SR_OVR | SPI_SR_FRE | SPI_SR_CHSIDE | SPI_SR_BSY) +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup I2S_Exported_macros I2S Exported Macros + * @{ + */ + +/** @brief Reset I2S handle state + * @param __HANDLE__ specifies the I2S Handle. + * @retval None + */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) +#define __HAL_I2S_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_I2S_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_I2S_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_I2S_STATE_RESET) +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ + +/** @brief Enable the specified SPI peripheral (in I2S mode). + * @param __HANDLE__ specifies the I2S Handle. + * @retval None + */ +#define __HAL_I2S_ENABLE(__HANDLE__) (SET_BIT((__HANDLE__)->Instance->I2SCFGR, SPI_I2SCFGR_I2SE)) + +/** @brief Disable the specified SPI peripheral (in I2S mode). + * @param __HANDLE__ specifies the I2S Handle. + * @retval None + */ +#define __HAL_I2S_DISABLE(__HANDLE__) (CLEAR_BIT((__HANDLE__)->Instance->I2SCFGR, SPI_I2SCFGR_I2SE)) + +/** @brief Enable the specified I2S interrupts. + * @param __HANDLE__ specifies the I2S Handle. + * @param __INTERRUPT__ specifies the interrupt source to enable or disable. + * This parameter can be one of the following values: + * @arg I2S_IT_TXE: Tx buffer empty interrupt enable + * @arg I2S_IT_RXNE: RX buffer not empty interrupt enable + * @arg I2S_IT_ERR: Error interrupt enable + * @retval None + */ +#define __HAL_I2S_ENABLE_IT(__HANDLE__, __INTERRUPT__) (SET_BIT((__HANDLE__)->Instance->CR2,(__INTERRUPT__))) + +/** @brief Disable the specified I2S interrupts. + * @param __HANDLE__ specifies the I2S Handle. + * @param __INTERRUPT__ specifies the interrupt source to enable or disable. + * This parameter can be one of the following values: + * @arg I2S_IT_TXE: Tx buffer empty interrupt enable + * @arg I2S_IT_RXNE: RX buffer not empty interrupt enable + * @arg I2S_IT_ERR: Error interrupt enable + * @retval None + */ +#define __HAL_I2S_DISABLE_IT(__HANDLE__, __INTERRUPT__) (CLEAR_BIT((__HANDLE__)->Instance->CR2,(__INTERRUPT__))) + +/** @brief Checks if the specified I2S interrupt source is enabled or disabled. + * @param __HANDLE__ specifies the I2S Handle. + * This parameter can be I2S where x: 1, 2, or 3 to select the I2S peripheral. + * @param __INTERRUPT__ specifies the I2S interrupt source to check. + * This parameter can be one of the following values: + * @arg I2S_IT_TXE: Tx buffer empty interrupt enable + * @arg I2S_IT_RXNE: RX buffer not empty interrupt enable + * @arg I2S_IT_ERR: Error interrupt enable + * @retval The new state of __IT__ (TRUE or FALSE). + */ +#define __HAL_I2S_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->CR2\ + & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET) + +/** @brief Checks whether the specified I2S flag is set or not. + * @param __HANDLE__ specifies the I2S Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg I2S_FLAG_RXNE: Receive buffer not empty flag + * @arg I2S_FLAG_TXE: Transmit buffer empty flag + * @arg I2S_FLAG_UDR: Underrun flag + * @arg I2S_FLAG_OVR: Overrun flag + * @arg I2S_FLAG_FRE: Frame error flag + * @arg I2S_FLAG_CHSIDE: Channel Side flag + * @arg I2S_FLAG_BSY: Busy flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_I2S_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->SR) & (__FLAG__)) == (__FLAG__)) + +/** @brief Clears the I2S OVR pending flag. + * @param __HANDLE__ specifies the I2S Handle. + * @retval None + */ +#define __HAL_I2S_CLEAR_OVRFLAG(__HANDLE__) do{ \ + __IO uint32_t tmpreg_ovr = 0x00U; \ + tmpreg_ovr = (__HANDLE__)->Instance->DR; \ + tmpreg_ovr = (__HANDLE__)->Instance->SR; \ + UNUSED(tmpreg_ovr); \ + }while(0U) +/** @brief Clears the I2S UDR pending flag. + * @param __HANDLE__ specifies the I2S Handle. + * @retval None + */ +#define __HAL_I2S_CLEAR_UDRFLAG(__HANDLE__) do{\ + __IO uint32_t tmpreg_udr = 0x00U;\ + tmpreg_udr = ((__HANDLE__)->Instance->SR);\ + UNUSED(tmpreg_udr); \ + }while(0U) +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup I2S_Exported_Functions + * @{ + */ + +/** @addtogroup I2S_Exported_Functions_Group1 + * @{ + */ +/* Initialization/de-initialization functions ********************************/ +HAL_StatusTypeDef HAL_I2S_Init(I2S_HandleTypeDef *hi2s); +HAL_StatusTypeDef HAL_I2S_DeInit(I2S_HandleTypeDef *hi2s); +void HAL_I2S_MspInit(I2S_HandleTypeDef *hi2s); +void HAL_I2S_MspDeInit(I2S_HandleTypeDef *hi2s); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) +HAL_StatusTypeDef HAL_I2S_RegisterCallback(I2S_HandleTypeDef *hi2s, HAL_I2S_CallbackIDTypeDef CallbackID, + pI2S_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_I2S_UnRegisterCallback(I2S_HandleTypeDef *hi2s, HAL_I2S_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @addtogroup I2S_Exported_Functions_Group2 + * @{ + */ +/* I/O operation functions ***************************************************/ +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_I2S_Transmit(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_I2S_Receive(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size, uint32_t Timeout); + +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_I2S_Transmit_IT(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2S_Receive_IT(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size); +void HAL_I2S_IRQHandler(I2S_HandleTypeDef *hi2s); + +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_I2S_Transmit_DMA(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_I2S_Receive_DMA(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size); + +HAL_StatusTypeDef HAL_I2S_DMAPause(I2S_HandleTypeDef *hi2s); +HAL_StatusTypeDef HAL_I2S_DMAResume(I2S_HandleTypeDef *hi2s); +HAL_StatusTypeDef HAL_I2S_DMAStop(I2S_HandleTypeDef *hi2s); + +/* Callbacks used in non blocking modes (Interrupt and DMA) *******************/ +void HAL_I2S_TxHalfCpltCallback(I2S_HandleTypeDef *hi2s); +void HAL_I2S_TxCpltCallback(I2S_HandleTypeDef *hi2s); +void HAL_I2S_RxHalfCpltCallback(I2S_HandleTypeDef *hi2s); +void HAL_I2S_RxCpltCallback(I2S_HandleTypeDef *hi2s); +void HAL_I2S_ErrorCallback(I2S_HandleTypeDef *hi2s); +/** + * @} + */ + +/** @addtogroup I2S_Exported_Functions_Group3 + * @{ + */ +/* Peripheral Control and State functions ************************************/ +HAL_I2S_StateTypeDef HAL_I2S_GetState(I2S_HandleTypeDef *hi2s); +uint32_t HAL_I2S_GetError(I2S_HandleTypeDef *hi2s); +/** + * @} + */ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @defgroup I2S_Private_Macros I2S Private Macros + * @{ + */ + +/** @brief Check whether the specified SPI flag is set or not. + * @param __SR__ copy of I2S SR register. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg I2S_FLAG_RXNE: Receive buffer not empty flag + * @arg I2S_FLAG_TXE: Transmit buffer empty flag + * @arg I2S_FLAG_UDR: Underrun error flag + * @arg I2S_FLAG_OVR: Overrun flag + * @arg I2S_FLAG_CHSIDE: Channel side flag + * @arg I2S_FLAG_BSY: Busy flag + * @retval SET or RESET. + */ +#define I2S_CHECK_FLAG(__SR__, __FLAG__) ((((__SR__)\ + & ((__FLAG__) & I2S_FLAG_MASK)) == ((__FLAG__) & I2S_FLAG_MASK)) ? SET : RESET) + +/** @brief Check whether the specified SPI Interrupt is set or not. + * @param __CR2__ copy of I2S CR2 register. + * @param __INTERRUPT__ specifies the SPI interrupt source to check. + * This parameter can be one of the following values: + * @arg I2S_IT_TXE: Tx buffer empty interrupt enable + * @arg I2S_IT_RXNE: RX buffer not empty interrupt enable + * @arg I2S_IT_ERR: Error interrupt enable + * @retval SET or RESET. + */ +#define I2S_CHECK_IT_SOURCE(__CR2__, __INTERRUPT__) ((((__CR2__)\ + & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET) + +/** @brief Checks if I2S Mode parameter is in allowed range. + * @param __MODE__ specifies the I2S Mode. + * This parameter can be a value of @ref I2S_Mode + * @retval None + */ +#define IS_I2S_MODE(__MODE__) (((__MODE__) == I2S_MODE_SLAVE_TX) || \ + ((__MODE__) == I2S_MODE_SLAVE_RX) || \ + ((__MODE__) == I2S_MODE_MASTER_TX) || \ + ((__MODE__) == I2S_MODE_MASTER_RX)) + +#define IS_I2S_STANDARD(__STANDARD__) (((__STANDARD__) == I2S_STANDARD_PHILIPS) || \ + ((__STANDARD__) == I2S_STANDARD_MSB) || \ + ((__STANDARD__) == I2S_STANDARD_LSB) || \ + ((__STANDARD__) == I2S_STANDARD_PCM_SHORT) || \ + ((__STANDARD__) == I2S_STANDARD_PCM_LONG)) + +#define IS_I2S_DATA_FORMAT(__FORMAT__) (((__FORMAT__) == I2S_DATAFORMAT_16B) || \ + ((__FORMAT__) == I2S_DATAFORMAT_16B_EXTENDED) || \ + ((__FORMAT__) == I2S_DATAFORMAT_24B) || \ + ((__FORMAT__) == I2S_DATAFORMAT_32B)) + +#define IS_I2S_MCLK_OUTPUT(__OUTPUT__) (((__OUTPUT__) == I2S_MCLKOUTPUT_ENABLE) || \ + ((__OUTPUT__) == I2S_MCLKOUTPUT_DISABLE)) + +#define IS_I2S_AUDIO_FREQ(__FREQ__) ((((__FREQ__) >= I2S_AUDIOFREQ_8K) && \ + ((__FREQ__) <= I2S_AUDIOFREQ_192K)) || \ + ((__FREQ__) == I2S_AUDIOFREQ_DEFAULT)) + +/** @brief Checks if I2S Serial clock steady state parameter is in allowed range. + * @param __CPOL__ specifies the I2S serial clock steady state. + * This parameter can be a value of @ref I2S_Clock_Polarity + * @retval None + */ +#define IS_I2S_CPOL(__CPOL__) (((__CPOL__) == I2S_CPOL_LOW) || \ + ((__CPOL__) == I2S_CPOL_HIGH)) + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* SPI_I2S_SUPPORT */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_I2S_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda.h new file mode 100644 index 0000000..a31ad8f --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda.h @@ -0,0 +1,856 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_irda.h + * @author MCD Application Team + * @brief Header file of IRDA HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_IRDA_H +#define STM32F0xx_HAL_IRDA_H + +#ifdef __cplusplus +extern "C" { +#endif + +#if defined(USART_IRDA_SUPPORT) +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup IRDA + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup IRDA_Exported_Types IRDA Exported Types + * @{ + */ + +/** + * @brief IRDA Init Structure definition + */ +typedef struct +{ + uint32_t BaudRate; /*!< This member configures the IRDA communication baud rate. + The baud rate register is computed using the following formula: + Baud Rate Register = ((usart_ker_clk) / ((hirda->Init.BaudRate))) + where usart_ker_clk is the IRDA input clock */ + + uint32_t WordLength; /*!< Specifies the number of data bits transmitted or received in a frame. + This parameter can be a value of @ref IRDAEx_Word_Length */ + + uint32_t Parity; /*!< Specifies the parity mode. + This parameter can be a value of @ref IRDA_Parity + @note When parity is enabled, the computed parity is inserted + at the MSB position of the transmitted data (9th bit when + the word length is set to 9 data bits; 8th bit when the + word length is set to 8 data bits). */ + + uint32_t Mode; /*!< Specifies whether the Receive or Transmit mode is enabled or disabled. + This parameter can be a value of @ref IRDA_Transfer_Mode */ + + uint8_t Prescaler; /*!< Specifies the Prescaler value for dividing the UART/USART source clock + to achieve low-power frequency. + @note Prescaler value 0 is forbidden */ + + uint16_t PowerMode; /*!< Specifies the IRDA power mode. + This parameter can be a value of @ref IRDA_Low_Power */ + +} IRDA_InitTypeDef; + +/** + * @brief HAL IRDA State definition + * @note HAL IRDA State value is a combination of 2 different substates: + * gState and RxState (see @ref IRDA_State_Definition). + * - gState contains IRDA state information related to global Handle management + * and also information related to Tx operations. + * gState value coding follow below described bitmap : + * b7-b6 Error information + * 00 : No Error + * 01 : (Not Used) + * 10 : Timeout + * 11 : Error + * b5 Peripheral initialization status + * 0 : Reset (Peripheral not initialized) + * 1 : Init done (Peripheral initialized. HAL IRDA Init function already called) + * b4-b3 (not used) + * xx : Should be set to 00 + * b2 Intrinsic process state + * 0 : Ready + * 1 : Busy (Peripheral busy with some configuration or internal operations) + * b1 (not used) + * x : Should be set to 0 + * b0 Tx state + * 0 : Ready (no Tx operation ongoing) + * 1 : Busy (Tx operation ongoing) + * - RxState contains information related to Rx operations. + * RxState value coding follow below described bitmap : + * b7-b6 (not used) + * xx : Should be set to 00 + * b5 Peripheral initialization status + * 0 : Reset (Peripheral not initialized) + * 1 : Init done (Peripheral initialized) + * b4-b2 (not used) + * xxx : Should be set to 000 + * b1 Rx state + * 0 : Ready (no Rx operation ongoing) + * 1 : Busy (Rx operation ongoing) + * b0 (not used) + * x : Should be set to 0. + */ +typedef uint32_t HAL_IRDA_StateTypeDef; + +/** + * @brief IRDA clock sources definition + */ +typedef enum +{ + IRDA_CLOCKSOURCE_PCLK1 = 0x00U, /*!< PCLK1 clock source */ + IRDA_CLOCKSOURCE_HSI = 0x02U, /*!< HSI clock source */ + IRDA_CLOCKSOURCE_SYSCLK = 0x04U, /*!< SYSCLK clock source */ + IRDA_CLOCKSOURCE_LSE = 0x10U, /*!< LSE clock source */ + IRDA_CLOCKSOURCE_UNDEFINED = 0x20U /*!< Undefined clock source */ +} IRDA_ClockSourceTypeDef; + +/** + * @brief IRDA handle Structure definition + */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) +typedef struct __IRDA_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ +{ + USART_TypeDef *Instance; /*!< USART registers base address */ + + IRDA_InitTypeDef Init; /*!< IRDA communication parameters */ + + uint8_t *pTxBuffPtr; /*!< Pointer to IRDA Tx transfer Buffer */ + + uint16_t TxXferSize; /*!< IRDA Tx Transfer size */ + + __IO uint16_t TxXferCount; /*!< IRDA Tx Transfer Counter */ + + uint8_t *pRxBuffPtr; /*!< Pointer to IRDA Rx transfer Buffer */ + + uint16_t RxXferSize; /*!< IRDA Rx Transfer size */ + + __IO uint16_t RxXferCount; /*!< IRDA Rx Transfer Counter */ + + uint16_t Mask; /*!< USART RX RDR register mask */ + + DMA_HandleTypeDef *hdmatx; /*!< IRDA Tx DMA Handle parameters */ + + DMA_HandleTypeDef *hdmarx; /*!< IRDA Rx DMA Handle parameters */ + + HAL_LockTypeDef Lock; /*!< Locking object */ + + __IO HAL_IRDA_StateTypeDef gState; /*!< IRDA state information related to global Handle management + and also related to Tx operations. + This parameter can be a value of @ref HAL_IRDA_StateTypeDef */ + + __IO HAL_IRDA_StateTypeDef RxState; /*!< IRDA state information related to Rx operations. + This parameter can be a value of @ref HAL_IRDA_StateTypeDef */ + + __IO uint32_t ErrorCode; /*!< IRDA Error code */ + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + void (* TxHalfCpltCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Tx Half Complete Callback */ + + void (* TxCpltCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Tx Complete Callback */ + + void (* RxHalfCpltCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Rx Half Complete Callback */ + + void (* RxCpltCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Rx Complete Callback */ + + void (* ErrorCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Error Callback */ + + void (* AbortCpltCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Abort Complete Callback */ + + void (* AbortTransmitCpltCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Abort Transmit Complete Callback */ + + void (* AbortReceiveCpltCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Abort Receive Complete Callback */ + + + void (* MspInitCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Msp Init callback */ + + void (* MspDeInitCallback)(struct __IRDA_HandleTypeDef *hirda); /*!< IRDA Msp DeInit callback */ +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + +} IRDA_HandleTypeDef; + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) +/** + * @brief HAL IRDA Callback ID enumeration definition + */ +typedef enum +{ + HAL_IRDA_TX_HALFCOMPLETE_CB_ID = 0x00U, /*!< IRDA Tx Half Complete Callback ID */ + HAL_IRDA_TX_COMPLETE_CB_ID = 0x01U, /*!< IRDA Tx Complete Callback ID */ + HAL_IRDA_RX_HALFCOMPLETE_CB_ID = 0x02U, /*!< IRDA Rx Half Complete Callback ID */ + HAL_IRDA_RX_COMPLETE_CB_ID = 0x03U, /*!< IRDA Rx Complete Callback ID */ + HAL_IRDA_ERROR_CB_ID = 0x04U, /*!< IRDA Error Callback ID */ + HAL_IRDA_ABORT_COMPLETE_CB_ID = 0x05U, /*!< IRDA Abort Complete Callback ID */ + HAL_IRDA_ABORT_TRANSMIT_COMPLETE_CB_ID = 0x06U, /*!< IRDA Abort Transmit Complete Callback ID */ + HAL_IRDA_ABORT_RECEIVE_COMPLETE_CB_ID = 0x07U, /*!< IRDA Abort Receive Complete Callback ID */ + + HAL_IRDA_MSPINIT_CB_ID = 0x08U, /*!< IRDA MspInit callback ID */ + HAL_IRDA_MSPDEINIT_CB_ID = 0x09U /*!< IRDA MspDeInit callback ID */ + +} HAL_IRDA_CallbackIDTypeDef; + +/** + * @brief HAL IRDA Callback pointer definition + */ +typedef void (*pIRDA_CallbackTypeDef)(IRDA_HandleTypeDef *hirda); /*!< pointer to an IRDA callback function */ + +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup IRDA_Exported_Constants IRDA Exported Constants + * @{ + */ + +/** @defgroup IRDA_State_Definition IRDA State Code Definition + * @{ + */ +#define HAL_IRDA_STATE_RESET 0x00000000U /*!< Peripheral is not initialized + Value is allowed for gState and RxState */ +#define HAL_IRDA_STATE_READY 0x00000020U /*!< Peripheral Initialized and ready for use + Value is allowed for gState and RxState */ +#define HAL_IRDA_STATE_BUSY 0x00000024U /*!< An internal process is ongoing + Value is allowed for gState only */ +#define HAL_IRDA_STATE_BUSY_TX 0x00000021U /*!< Data Transmission process is ongoing + Value is allowed for gState only */ +#define HAL_IRDA_STATE_BUSY_RX 0x00000022U /*!< Data Reception process is ongoing + Value is allowed for RxState only */ +#define HAL_IRDA_STATE_BUSY_TX_RX 0x00000023U /*!< Data Transmission and Reception process is ongoing + Not to be used for neither gState nor RxState. + Value is result of combination (Or) between + gState and RxState values */ +#define HAL_IRDA_STATE_TIMEOUT 0x000000A0U /*!< Timeout state + Value is allowed for gState only */ +#define HAL_IRDA_STATE_ERROR 0x000000E0U /*!< Error + Value is allowed for gState only */ +/** + * @} + */ + +/** @defgroup IRDA_Error_Definition IRDA Error Code Definition + * @{ + */ +#define HAL_IRDA_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_IRDA_ERROR_PE (0x00000001U) /*!< Parity error */ +#define HAL_IRDA_ERROR_NE (0x00000002U) /*!< Noise error */ +#define HAL_IRDA_ERROR_FE (0x00000004U) /*!< frame error */ +#define HAL_IRDA_ERROR_ORE (0x00000008U) /*!< Overrun error */ +#define HAL_IRDA_ERROR_DMA (0x00000010U) /*!< DMA transfer error */ +#define HAL_IRDA_ERROR_BUSY (0x00000020U) /*!< Busy Error */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) +#define HAL_IRDA_ERROR_INVALID_CALLBACK (0x00000040U) /*!< Invalid Callback error */ +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup IRDA_Parity IRDA Parity + * @{ + */ +#define IRDA_PARITY_NONE 0x00000000U /*!< No parity */ +#define IRDA_PARITY_EVEN USART_CR1_PCE /*!< Even parity */ +#define IRDA_PARITY_ODD (USART_CR1_PCE | USART_CR1_PS) /*!< Odd parity */ +/** + * @} + */ + +/** @defgroup IRDA_Transfer_Mode IRDA Transfer Mode + * @{ + */ +#define IRDA_MODE_RX USART_CR1_RE /*!< RX mode */ +#define IRDA_MODE_TX USART_CR1_TE /*!< TX mode */ +#define IRDA_MODE_TX_RX (USART_CR1_TE |USART_CR1_RE) /*!< RX and TX mode */ +/** + * @} + */ + +/** @defgroup IRDA_Low_Power IRDA Low Power + * @{ + */ +#define IRDA_POWERMODE_NORMAL 0x00000000U /*!< IRDA normal power mode */ +#define IRDA_POWERMODE_LOWPOWER USART_CR3_IRLP /*!< IRDA low power mode */ +/** + * @} + */ + +/** @defgroup IRDA_State IRDA State + * @{ + */ +#define IRDA_STATE_DISABLE 0x00000000U /*!< IRDA disabled */ +#define IRDA_STATE_ENABLE USART_CR1_UE /*!< IRDA enabled */ +/** + * @} + */ + +/** @defgroup IRDA_Mode IRDA Mode + * @{ + */ +#define IRDA_MODE_DISABLE 0x00000000U /*!< Associated UART disabled in IRDA mode */ +#define IRDA_MODE_ENABLE USART_CR3_IREN /*!< Associated UART enabled in IRDA mode */ +/** + * @} + */ + +/** @defgroup IRDA_One_Bit IRDA One Bit Sampling + * @{ + */ +#define IRDA_ONE_BIT_SAMPLE_DISABLE 0x00000000U /*!< One-bit sampling disabled */ +#define IRDA_ONE_BIT_SAMPLE_ENABLE USART_CR3_ONEBIT /*!< One-bit sampling enabled */ +/** + * @} + */ + +/** @defgroup IRDA_DMA_Tx IRDA DMA Tx + * @{ + */ +#define IRDA_DMA_TX_DISABLE 0x00000000U /*!< IRDA DMA TX disabled */ +#define IRDA_DMA_TX_ENABLE USART_CR3_DMAT /*!< IRDA DMA TX enabled */ +/** + * @} + */ + +/** @defgroup IRDA_DMA_Rx IRDA DMA Rx + * @{ + */ +#define IRDA_DMA_RX_DISABLE 0x00000000U /*!< IRDA DMA RX disabled */ +#define IRDA_DMA_RX_ENABLE USART_CR3_DMAR /*!< IRDA DMA RX enabled */ +/** + * @} + */ + +/** @defgroup IRDA_Request_Parameters IRDA Request Parameters + * @{ + */ +#define IRDA_AUTOBAUD_REQUEST USART_RQR_ABRRQ /*!< Auto-Baud Rate Request */ +#define IRDA_RXDATA_FLUSH_REQUEST USART_RQR_RXFRQ /*!< Receive Data flush Request */ +#define IRDA_TXDATA_FLUSH_REQUEST USART_RQR_TXFRQ /*!< Transmit data flush Request */ +/** + * @} + */ + +/** @defgroup IRDA_Flags IRDA Flags + * Elements values convention: 0xXXXX + * - 0xXXXX : Flag mask in the ISR register + * @{ + */ +#define IRDA_FLAG_REACK USART_ISR_REACK /*!< IRDA receive enable acknowledge flag */ +#define IRDA_FLAG_TEACK USART_ISR_TEACK /*!< IRDA transmit enable acknowledge flag */ +#define IRDA_FLAG_BUSY USART_ISR_BUSY /*!< IRDA busy flag */ +#define IRDA_FLAG_ABRF USART_ISR_ABRF /*!< IRDA auto Baud rate flag */ +#define IRDA_FLAG_ABRE USART_ISR_ABRE /*!< IRDA auto Baud rate error */ +#define IRDA_FLAG_TXE USART_ISR_TXE /*!< IRDA transmit data register empty */ +#define IRDA_FLAG_TC USART_ISR_TC /*!< IRDA transmission complete */ +#define IRDA_FLAG_RXNE USART_ISR_RXNE /*!< IRDA read data register not empty */ +#define IRDA_FLAG_ORE USART_ISR_ORE /*!< IRDA overrun error */ +#define IRDA_FLAG_NE USART_ISR_NE /*!< IRDA noise error */ +#define IRDA_FLAG_FE USART_ISR_FE /*!< IRDA frame error */ +#define IRDA_FLAG_PE USART_ISR_PE /*!< IRDA parity error */ +/** + * @} + */ + +/** @defgroup IRDA_Interrupt_definition IRDA Interrupts Definition + * Elements values convention: 0000ZZZZ0XXYYYYYb + * - YYYYY : Interrupt source position in the XX register (5bits) + * - XX : Interrupt source register (2bits) + * - 01: CR1 register + * - 10: CR2 register + * - 11: CR3 register + * - ZZZZ : Flag position in the ISR register(4bits) + * @{ + */ +#define IRDA_IT_PE 0x0028U /*!< IRDA Parity error interruption */ +#define IRDA_IT_TXE 0x0727U /*!< IRDA Transmit data register empty interruption */ +#define IRDA_IT_TC 0x0626U /*!< IRDA Transmission complete interruption */ +#define IRDA_IT_RXNE 0x0525U /*!< IRDA Read data register not empty interruption */ +#define IRDA_IT_IDLE 0x0424U /*!< IRDA Idle interruption */ + +/* Elements values convention: 000000000XXYYYYYb + - YYYYY : Interrupt source position in the XX register (5bits) + - XX : Interrupt source register (2bits) + - 01: CR1 register + - 10: CR2 register + - 11: CR3 register */ +#define IRDA_IT_ERR 0x0060U /*!< IRDA Error interruption */ + +/* Elements values convention: 0000ZZZZ00000000b + - ZZZZ : Flag position in the ISR register(4bits) */ +#define IRDA_IT_ORE 0x0300U /*!< IRDA Overrun error interruption */ +#define IRDA_IT_NE 0x0200U /*!< IRDA Noise error interruption */ +#define IRDA_IT_FE 0x0100U /*!< IRDA Frame error interruption */ +/** + * @} + */ + +/** @defgroup IRDA_IT_CLEAR_Flags IRDA Interruption Clear Flags + * @{ + */ +#define IRDA_CLEAR_PEF USART_ICR_PECF /*!< Parity Error Clear Flag */ +#define IRDA_CLEAR_FEF USART_ICR_FECF /*!< Framing Error Clear Flag */ +#define IRDA_CLEAR_NEF USART_ICR_NCF /*!< Noise Error detected Clear Flag */ +#define IRDA_CLEAR_OREF USART_ICR_ORECF /*!< OverRun Error Clear Flag */ +#define IRDA_CLEAR_IDLEF USART_ICR_IDLECF /*!< IDLE line detected Clear Flag */ +#define IRDA_CLEAR_TCF USART_ICR_TCCF /*!< Transmission Complete Clear Flag */ +/** + * @} + */ + +/** @defgroup IRDA_Interruption_Mask IRDA interruptions flags mask + * @{ + */ +#define IRDA_IT_MASK 0x001FU /*!< IRDA Interruptions flags mask */ +#define IRDA_CR_MASK 0x00E0U /*!< IRDA control register mask */ +#define IRDA_CR_POS 5U /*!< IRDA control register position */ +#define IRDA_ISR_MASK 0x1F00U /*!< IRDA ISR register mask */ +#define IRDA_ISR_POS 8U /*!< IRDA ISR register position */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup IRDA_Exported_Macros IRDA Exported Macros + * @{ + */ + +/** @brief Reset IRDA handle state. + * @param __HANDLE__ IRDA handle. + * @retval None + */ +#if USE_HAL_IRDA_REGISTER_CALLBACKS == 1 +#define __HAL_IRDA_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_IRDA_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_IRDA_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0U) +#else +#define __HAL_IRDA_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_IRDA_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_IRDA_STATE_RESET; \ + } while(0U) +#endif /*USE_HAL_IRDA_REGISTER_CALLBACKS */ + +/** @brief Flush the IRDA DR register. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_FLUSH_DRREGISTER(__HANDLE__) \ + do{ \ + SET_BIT((__HANDLE__)->Instance->RQR, IRDA_RXDATA_FLUSH_REQUEST); \ + SET_BIT((__HANDLE__)->Instance->RQR, IRDA_TXDATA_FLUSH_REQUEST); \ + } while(0U) + +/** @brief Clear the specified IRDA pending flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be any combination of the following values: + * @arg @ref IRDA_CLEAR_PEF + * @arg @ref IRDA_CLEAR_FEF + * @arg @ref IRDA_CLEAR_NEF + * @arg @ref IRDA_CLEAR_OREF + * @arg @ref IRDA_CLEAR_TCF + * @arg @ref IRDA_CLEAR_IDLEF + * @retval None + */ +#define __HAL_IRDA_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__)) + +/** @brief Clear the IRDA PE pending flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_CLEAR_PEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_PEF) + + +/** @brief Clear the IRDA FE pending flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_CLEAR_FEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_FEF) + +/** @brief Clear the IRDA NE pending flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_CLEAR_NEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_NEF) + +/** @brief Clear the IRDA ORE pending flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_CLEAR_OREFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_OREF) + +/** @brief Clear the IRDA IDLE pending flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_CLEAR_IDLEFLAG(__HANDLE__) __HAL_IRDA_CLEAR_FLAG((__HANDLE__), IRDA_CLEAR_IDLEF) + +/** @brief Check whether the specified IRDA flag is set or not. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref IRDA_FLAG_REACK Receive enable acknowledge flag + * @arg @ref IRDA_FLAG_TEACK Transmit enable acknowledge flag + * @arg @ref IRDA_FLAG_BUSY Busy flag + * @arg @ref IRDA_FLAG_ABRF Auto Baud rate detection flag + * @arg @ref IRDA_FLAG_ABRE Auto Baud rate detection error flag + * @arg @ref IRDA_FLAG_TXE Transmit data register empty flag + * @arg @ref IRDA_FLAG_TC Transmission Complete flag + * @arg @ref IRDA_FLAG_RXNE Receive data register not empty flag + * @arg @ref IRDA_FLAG_ORE OverRun Error flag + * @arg @ref IRDA_FLAG_NE Noise Error flag + * @arg @ref IRDA_FLAG_FE Framing Error flag + * @arg @ref IRDA_FLAG_PE Parity Error flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_IRDA_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->ISR & (__FLAG__)) == (__FLAG__)) + + +/** @brief Enable the specified IRDA interrupt. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __INTERRUPT__ specifies the IRDA interrupt source to enable. + * This parameter can be one of the following values: + * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt + * @arg @ref IRDA_IT_TC Transmission complete interrupt + * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt + * @arg @ref IRDA_IT_IDLE Idle line detection interrupt + * @arg @ref IRDA_IT_PE Parity Error interrupt + * @arg @ref IRDA_IT_ERR Error interrupt(Frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_IRDA_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((((__INTERRUPT__) & IRDA_CR_MASK) >> IRDA_CR_POS) == 1U)? \ + ((__HANDLE__)->Instance->CR1 |= (1U << \ + ((__INTERRUPT__) & IRDA_IT_MASK))):\ + ((((__INTERRUPT__) & IRDA_CR_MASK) >> IRDA_CR_POS) == 2U)? \ + ((__HANDLE__)->Instance->CR2 |= (1U << \ + ((__INTERRUPT__) & IRDA_IT_MASK))):\ + ((__HANDLE__)->Instance->CR3 |= (1U << \ + ((__INTERRUPT__) & IRDA_IT_MASK)))) + +/** @brief Disable the specified IRDA interrupt. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __INTERRUPT__ specifies the IRDA interrupt source to disable. + * This parameter can be one of the following values: + * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt + * @arg @ref IRDA_IT_TC Transmission complete interrupt + * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt + * @arg @ref IRDA_IT_IDLE Idle line detection interrupt + * @arg @ref IRDA_IT_PE Parity Error interrupt + * @arg @ref IRDA_IT_ERR Error interrupt(Frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_IRDA_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((((__INTERRUPT__) & IRDA_CR_MASK) >> IRDA_CR_POS) == 1U)? \ + ((__HANDLE__)->Instance->CR1 &= ~ (1U << \ + ((__INTERRUPT__) & IRDA_IT_MASK))): \ + ((((__INTERRUPT__) & IRDA_CR_MASK) >> IRDA_CR_POS) == 2U)? \ + ((__HANDLE__)->Instance->CR2 &= ~ (1U << \ + ((__INTERRUPT__) & IRDA_IT_MASK))): \ + ((__HANDLE__)->Instance->CR3 &= ~ (1U << \ + ((__INTERRUPT__) & IRDA_IT_MASK)))) + +/** @brief Check whether the specified IRDA interrupt has occurred or not. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __INTERRUPT__ specifies the IRDA interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt + * @arg @ref IRDA_IT_TC Transmission complete interrupt + * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt + * @arg @ref IRDA_IT_IDLE Idle line detection interrupt + * @arg @ref IRDA_IT_ORE OverRun Error interrupt + * @arg @ref IRDA_IT_NE Noise Error interrupt + * @arg @ref IRDA_IT_FE Framing Error interrupt + * @arg @ref IRDA_IT_PE Parity Error interrupt + * @retval The new state of __IT__ (SET or RESET). + */ +#define __HAL_IRDA_GET_IT(__HANDLE__, __INTERRUPT__) \ + ((((__HANDLE__)->Instance->ISR& (0x01U << (((__INTERRUPT__) & IRDA_ISR_MASK)>>IRDA_ISR_POS))) != 0U) ? SET : RESET) + +/** @brief Check whether the specified IRDA interrupt source is enabled or not. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __INTERRUPT__ specifies the IRDA interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref IRDA_IT_TXE Transmit Data Register empty interrupt + * @arg @ref IRDA_IT_TC Transmission complete interrupt + * @arg @ref IRDA_IT_RXNE Receive Data register not empty interrupt + * @arg @ref IRDA_IT_IDLE Idle line detection interrupt + * @arg @ref IRDA_IT_ERR Framing, overrun or noise error interrupt + * @arg @ref IRDA_IT_PE Parity Error interrupt + * @retval The new state of __IT__ (SET or RESET). + */ +#define __HAL_IRDA_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) \ + ((((((((__INTERRUPT__) & IRDA_CR_MASK) >>IRDA_CR_POS) == 0x01U)? (__HANDLE__)->Instance->CR1 :(((((__INTERRUPT__) \ + & IRDA_CR_MASK) >> IRDA_CR_POS)== 0x02U)? (__HANDLE__)->Instance->CR2 :(__HANDLE__)->Instance->CR3)) \ + & (0x01U <<(((uint16_t)(__INTERRUPT__)) & IRDA_IT_MASK))) != 0U) ? SET : RESET) + +/** @brief Clear the specified IRDA ISR flag, in setting the proper ICR register flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __IT_CLEAR__ specifies the interrupt clear register flag that needs to be set + * to clear the corresponding interrupt + * This parameter can be one of the following values: + * @arg @ref IRDA_CLEAR_PEF Parity Error Clear Flag + * @arg @ref IRDA_CLEAR_FEF Framing Error Clear Flag + * @arg @ref IRDA_CLEAR_NEF Noise detected Clear Flag + * @arg @ref IRDA_CLEAR_OREF OverRun Error Clear Flag + * @arg @ref IRDA_CLEAR_TCF Transmission Complete Clear Flag + * @retval None + */ +#define __HAL_IRDA_CLEAR_IT(__HANDLE__, __IT_CLEAR__) ((__HANDLE__)->Instance->ICR = (uint32_t)(__IT_CLEAR__)) + + +/** @brief Set a specific IRDA request flag. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __REQ__ specifies the request flag to set + * This parameter can be one of the following values: + * @arg @ref IRDA_AUTOBAUD_REQUEST Auto-Baud Rate Request + * @arg @ref IRDA_RXDATA_FLUSH_REQUEST Receive Data flush Request + * @arg @ref IRDA_TXDATA_FLUSH_REQUEST Transmit data flush Request + * @retval None + */ +#define __HAL_IRDA_SEND_REQ(__HANDLE__, __REQ__) ((__HANDLE__)->Instance->RQR |= (uint16_t)(__REQ__)) + +/** @brief Enable the IRDA one bit sample method. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_ONE_BIT_SAMPLE_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3|= USART_CR3_ONEBIT) + +/** @brief Disable the IRDA one bit sample method. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_ONE_BIT_SAMPLE_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3\ + &= (uint32_t)~((uint32_t)USART_CR3_ONEBIT)) + +/** @brief Enable UART/USART associated to IRDA Handle. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= USART_CR1_UE) + +/** @brief Disable UART/USART associated to IRDA Handle. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None + */ +#define __HAL_IRDA_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~USART_CR1_UE) + +/** + * @} + */ + +/* Private macros --------------------------------------------------------*/ +/** @addtogroup IRDA_Private_Macros + * @{ + */ + +/** @brief Ensure that IRDA Baud rate is less or equal to maximum value. + * @param __BAUDRATE__ specifies the IRDA Baudrate set by the user. + * @retval True or False + */ +#define IS_IRDA_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) < 115201U) + +/** @brief Ensure that IRDA prescaler value is strictly larger than 0. + * @param __PRESCALER__ specifies the IRDA prescaler value set by the user. + * @retval True or False + */ +#define IS_IRDA_PRESCALER(__PRESCALER__) ((__PRESCALER__) > 0U) + +/** @brief Ensure that IRDA frame parity is valid. + * @param __PARITY__ IRDA frame parity. + * @retval SET (__PARITY__ is valid) or RESET (__PARITY__ is invalid) + */ +#define IS_IRDA_PARITY(__PARITY__) (((__PARITY__) == IRDA_PARITY_NONE) || \ + ((__PARITY__) == IRDA_PARITY_EVEN) || \ + ((__PARITY__) == IRDA_PARITY_ODD)) + +/** @brief Ensure that IRDA communication mode is valid. + * @param __MODE__ IRDA communication mode. + * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid) + */ +#define IS_IRDA_TX_RX_MODE(__MODE__) ((((__MODE__)\ + & (~((uint32_t)(IRDA_MODE_TX_RX)))) == 0x00U) && ((__MODE__) != 0x00U)) + +/** @brief Ensure that IRDA power mode is valid. + * @param __MODE__ IRDA power mode. + * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid) + */ +#define IS_IRDA_POWERMODE(__MODE__) (((__MODE__) == IRDA_POWERMODE_LOWPOWER) || \ + ((__MODE__) == IRDA_POWERMODE_NORMAL)) + +/** @brief Ensure that IRDA state is valid. + * @param __STATE__ IRDA state mode. + * @retval SET (__STATE__ is valid) or RESET (__STATE__ is invalid) + */ +#define IS_IRDA_STATE(__STATE__) (((__STATE__) == IRDA_STATE_DISABLE) || \ + ((__STATE__) == IRDA_STATE_ENABLE)) + +/** @brief Ensure that IRDA associated UART/USART mode is valid. + * @param __MODE__ IRDA associated UART/USART mode. + * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid) + */ +#define IS_IRDA_MODE(__MODE__) (((__MODE__) == IRDA_MODE_DISABLE) || \ + ((__MODE__) == IRDA_MODE_ENABLE)) + +/** @brief Ensure that IRDA sampling rate is valid. + * @param __ONEBIT__ IRDA sampling rate. + * @retval SET (__ONEBIT__ is valid) or RESET (__ONEBIT__ is invalid) + */ +#define IS_IRDA_ONE_BIT_SAMPLE(__ONEBIT__) (((__ONEBIT__) == IRDA_ONE_BIT_SAMPLE_DISABLE) || \ + ((__ONEBIT__) == IRDA_ONE_BIT_SAMPLE_ENABLE)) + +/** @brief Ensure that IRDA DMA TX mode is valid. + * @param __DMATX__ IRDA DMA TX mode. + * @retval SET (__DMATX__ is valid) or RESET (__DMATX__ is invalid) + */ +#define IS_IRDA_DMA_TX(__DMATX__) (((__DMATX__) == IRDA_DMA_TX_DISABLE) || \ + ((__DMATX__) == IRDA_DMA_TX_ENABLE)) + +/** @brief Ensure that IRDA DMA RX mode is valid. + * @param __DMARX__ IRDA DMA RX mode. + * @retval SET (__DMARX__ is valid) or RESET (__DMARX__ is invalid) + */ +#define IS_IRDA_DMA_RX(__DMARX__) (((__DMARX__) == IRDA_DMA_RX_DISABLE) || \ + ((__DMARX__) == IRDA_DMA_RX_ENABLE)) + +/** @brief Ensure that IRDA request is valid. + * @param __PARAM__ IRDA request. + * @retval SET (__PARAM__ is valid) or RESET (__PARAM__ is invalid) + */ +#define IS_IRDA_REQUEST_PARAMETER(__PARAM__) (((__PARAM__) == IRDA_AUTOBAUD_REQUEST) || \ + ((__PARAM__) == IRDA_RXDATA_FLUSH_REQUEST) || \ + ((__PARAM__) == IRDA_TXDATA_FLUSH_REQUEST)) +/** + * @} + */ + +/* Include IRDA HAL Extended module */ +#include "stm32f0xx_hal_irda_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup IRDA_Exported_Functions IRDA Exported Functions + * @{ + */ + +/** @addtogroup IRDA_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_IRDA_Init(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_DeInit(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_MspInit(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_MspDeInit(IRDA_HandleTypeDef *hirda); + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) +/* Callbacks Register/UnRegister functions ***********************************/ +HAL_StatusTypeDef HAL_IRDA_RegisterCallback(IRDA_HandleTypeDef *hirda, HAL_IRDA_CallbackIDTypeDef CallbackID, + pIRDA_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_IRDA_UnRegisterCallback(IRDA_HandleTypeDef *hirda, HAL_IRDA_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @addtogroup IRDA_Exported_Functions_Group2 IO operation functions + * @{ + */ + +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_IRDA_Transmit(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_IRDA_Receive(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_IRDA_Transmit_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_IRDA_Receive_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_IRDA_Transmit_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_IRDA_Receive_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_IRDA_DMAPause(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_DMAResume(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_DMAStop(IRDA_HandleTypeDef *hirda); +/* Transfer Abort functions */ +HAL_StatusTypeDef HAL_IRDA_Abort(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_AbortTransmit(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_AbortReceive(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_Abort_IT(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_AbortTransmit_IT(IRDA_HandleTypeDef *hirda); +HAL_StatusTypeDef HAL_IRDA_AbortReceive_IT(IRDA_HandleTypeDef *hirda); + +void HAL_IRDA_IRQHandler(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_TxCpltCallback(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_RxCpltCallback(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_TxHalfCpltCallback(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_RxHalfCpltCallback(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_ErrorCallback(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_AbortCpltCallback(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_AbortTransmitCpltCallback(IRDA_HandleTypeDef *hirda); +void HAL_IRDA_AbortReceiveCpltCallback(IRDA_HandleTypeDef *hirda); + +/** + * @} + */ + +/* Peripheral Control functions ************************************************/ + +/** @addtogroup IRDA_Exported_Functions_Group4 Peripheral State and Error functions + * @{ + */ + +/* Peripheral State and Error functions ***************************************/ +HAL_IRDA_StateTypeDef HAL_IRDA_GetState(IRDA_HandleTypeDef *hirda); +uint32_t HAL_IRDA_GetError(IRDA_HandleTypeDef *hirda); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* USART_IRDA_SUPPORT */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_IRDA_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda_ex.h new file mode 100644 index 0000000..a62b15b --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_irda_ex.h @@ -0,0 +1,399 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_irda_ex.h + * @author MCD Application Team + * @brief Header file of IRDA HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_IRDA_EX_H +#define STM32F0xx_HAL_IRDA_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +#if defined(USART_IRDA_SUPPORT) +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup IRDAEx IRDAEx + * @brief IRDA Extended HAL module driver + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup IRDAEx_Extended_Exported_Constants IRDAEx Extended Exported Constants + * @{ + */ + +/** @defgroup IRDAEx_Word_Length IRDAEx Word Length + * @{ + */ +#if defined(USART_CR1_M1)&&defined(USART_CR1_M0) +#define IRDA_WORDLENGTH_7B USART_CR1_M1 /*!< 7-bit long frame */ +#define IRDA_WORDLENGTH_8B 0x00000000U /*!< 8-bit long frame */ +#define IRDA_WORDLENGTH_9B USART_CR1_M0 /*!< 9-bit long frame */ +#elif defined(USART_CR1_M) +#define IRDA_WORDLENGTH_8B (0x00000000U) /*!< 8-bit long frame */ +#define IRDA_WORDLENGTH_9B USART_CR1_M /*!< 9-bit long frame */ +#endif +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ + +/* Private macros ------------------------------------------------------------*/ + +/** @defgroup IRDAEx_Private_Macros IRDAEx Private Macros + * @{ + */ + +/** @brief Report the IRDA clock source. + * @param __HANDLE__ specifies the IRDA Handle. + * @param __CLOCKSOURCE__ output variable. + * @retval IRDA clocking source, written in __CLOCKSOURCE__. + */ + +#if defined(STM32F031x6) || defined(STM32F038xx) +#define IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } while(0) +#elif defined (STM32F042x6) || defined (STM32F048xx) || defined (STM32F051x8) || defined (STM32F058xx) +#define IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) +#define IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F091xC) || defined(STM32F098xx) +#define IRDA_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + switch(__HAL_RCC_GET_USART3_SOURCE()) \ + { \ + case RCC_USART3CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART3CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART3CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART3CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART5) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART6) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART7) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART8) \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = IRDA_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) + +#endif /* defined(STM32F031x6) || defined(STM32F038xx) */ + + +/** @brief Compute the mask to apply to retrieve the received data + * according to the word length and to the parity bits activation. + * @note If PCE = 1, the parity bit is not included in the data extracted + * by the reception API(). + * This masking operation is not carried out in the case of + * DMA transfers. + * @param __HANDLE__ specifies the IRDA Handle. + * @retval None, the mask to apply to the associated UART RDR register is stored in (__HANDLE__)->Mask field. + */ +#if defined(USART_CR1_M1)&&defined(USART_CR1_M0) +#define IRDA_MASK_COMPUTATION(__HANDLE__) \ + do { \ + if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_9B) \ + { \ + if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x01FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_8B) \ + { \ + if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x007FU ; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_7B) \ + { \ + if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x007FU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x003FU ; \ + } \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x0000U; \ + } \ + } while(0U) +#elif defined(USART_CR1_M) +#define IRDA_MASK_COMPUTATION(__HANDLE__) \ + do { \ + if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_9B) \ + { \ + if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x01FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == IRDA_WORDLENGTH_8B) \ + { \ + if ((__HANDLE__)->Init.Parity == IRDA_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x007FU ; \ + } \ + } \ +} while(0U) +#endif + +/** @brief Ensure that IRDA frame length is valid. + * @param __LENGTH__ IRDA frame length. + * @retval SET (__LENGTH__ is valid) or RESET (__LENGTH__ is invalid) + */ +#if defined(USART_CR1_M1)&&defined(USART_CR1_M0) +#define IS_IRDA_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == IRDA_WORDLENGTH_7B) || \ + ((__LENGTH__) == IRDA_WORDLENGTH_8B) || \ + ((__LENGTH__) == IRDA_WORDLENGTH_9B)) +#elif defined(USART_CR1_M) +#define IS_IRDA_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == IRDA_WORDLENGTH_8B) || \ + ((__LENGTH__) == IRDA_WORDLENGTH_9B)) +#endif +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** + * @} + */ + +/** + * @} + */ +#endif /* USART_IRDA_SUPPORT */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_IRDA_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_iwdg.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_iwdg.h new file mode 100644 index 0000000..e0d9754 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_iwdg.h @@ -0,0 +1,240 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_iwdg.h + * @author MCD Application Team + * @brief Header file of IWDG HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_IWDG_H +#define STM32F0xx_HAL_IWDG_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup IWDG IWDG + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup IWDG_Exported_Types IWDG Exported Types + * @{ + */ + +/** + * @brief IWDG Init structure definition + */ +typedef struct +{ + uint32_t Prescaler; /*!< Select the prescaler of the IWDG. + This parameter can be a value of @ref IWDG_Prescaler */ + + uint32_t Reload; /*!< Specifies the IWDG down-counter reload value. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x0FFF */ + + uint32_t Window; /*!< Specifies the window value to be compared to the down-counter. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x0FFF */ + +} IWDG_InitTypeDef; + +/** + * @brief IWDG Handle Structure definition + */ +typedef struct +{ + IWDG_TypeDef *Instance; /*!< Register base address */ + + IWDG_InitTypeDef Init; /*!< IWDG required parameters */ +} IWDG_HandleTypeDef; + + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup IWDG_Exported_Constants IWDG Exported Constants + * @{ + */ + +/** @defgroup IWDG_Prescaler IWDG Prescaler + * @{ + */ +#define IWDG_PRESCALER_4 0x00000000u /*!< IWDG prescaler set to 4 */ +#define IWDG_PRESCALER_8 IWDG_PR_PR_0 /*!< IWDG prescaler set to 8 */ +#define IWDG_PRESCALER_16 IWDG_PR_PR_1 /*!< IWDG prescaler set to 16 */ +#define IWDG_PRESCALER_32 (IWDG_PR_PR_1 | IWDG_PR_PR_0) /*!< IWDG prescaler set to 32 */ +#define IWDG_PRESCALER_64 IWDG_PR_PR_2 /*!< IWDG prescaler set to 64 */ +#define IWDG_PRESCALER_128 (IWDG_PR_PR_2 | IWDG_PR_PR_0) /*!< IWDG prescaler set to 128 */ +#define IWDG_PRESCALER_256 (IWDG_PR_PR_2 | IWDG_PR_PR_1) /*!< IWDG prescaler set to 256 */ +/** + * @} + */ + +/** @defgroup IWDG_Window_option IWDG Window option + * @{ + */ +#define IWDG_WINDOW_DISABLE IWDG_WINR_WIN +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup IWDG_Exported_Macros IWDG Exported Macros + * @{ + */ + +/** + * @brief Enable the IWDG peripheral. + * @param __HANDLE__ IWDG handle + * @retval None + */ +#define __HAL_IWDG_START(__HANDLE__) WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_ENABLE) + +/** + * @brief Reload IWDG counter with value defined in the reload register + * (write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers disabled). + * @param __HANDLE__ IWDG handle + * @retval None + */ +#define __HAL_IWDG_RELOAD_COUNTER(__HANDLE__) WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_RELOAD) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup IWDG_Exported_Functions IWDG Exported Functions + * @{ + */ + +/** @defgroup IWDG_Exported_Functions_Group1 Initialization and Start functions + * @{ + */ +/* Initialization/Start functions ********************************************/ +HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg); +/** + * @} + */ + +/** @defgroup IWDG_Exported_Functions_Group2 IO operation functions + * @{ + */ +/* I/O operation functions ****************************************************/ +HAL_StatusTypeDef HAL_IWDG_Refresh(IWDG_HandleTypeDef *hiwdg); +/** + * @} + */ + +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup IWDG_Private_Constants IWDG Private Constants + * @{ + */ + +/** + * @brief IWDG Key Register BitMask + */ +#define IWDG_KEY_RELOAD 0x0000AAAAu /*!< IWDG Reload Counter Enable */ +#define IWDG_KEY_ENABLE 0x0000CCCCu /*!< IWDG Peripheral Enable */ +#define IWDG_KEY_WRITE_ACCESS_ENABLE 0x00005555u /*!< IWDG KR Write Access Enable */ +#define IWDG_KEY_WRITE_ACCESS_DISABLE 0x00000000u /*!< IWDG KR Write Access Disable */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup IWDG_Private_Macros IWDG Private Macros + * @{ + */ + +/** + * @brief Enable write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers. + * @param __HANDLE__ IWDG handle + * @retval None + */ +#define IWDG_ENABLE_WRITE_ACCESS(__HANDLE__) WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_ENABLE) + +/** + * @brief Disable write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers. + * @param __HANDLE__ IWDG handle + * @retval None + */ +#define IWDG_DISABLE_WRITE_ACCESS(__HANDLE__) WRITE_REG((__HANDLE__)->Instance->KR, IWDG_KEY_WRITE_ACCESS_DISABLE) + +/** + * @brief Check IWDG prescaler value. + * @param __PRESCALER__ IWDG prescaler value + * @retval None + */ +#define IS_IWDG_PRESCALER(__PRESCALER__) (((__PRESCALER__) == IWDG_PRESCALER_4) || \ + ((__PRESCALER__) == IWDG_PRESCALER_8) || \ + ((__PRESCALER__) == IWDG_PRESCALER_16) || \ + ((__PRESCALER__) == IWDG_PRESCALER_32) || \ + ((__PRESCALER__) == IWDG_PRESCALER_64) || \ + ((__PRESCALER__) == IWDG_PRESCALER_128)|| \ + ((__PRESCALER__) == IWDG_PRESCALER_256)) + +/** + * @brief Check IWDG reload value. + * @param __RELOAD__ IWDG reload value + * @retval None + */ +#define IS_IWDG_RELOAD(__RELOAD__) ((__RELOAD__) <= IWDG_RLR_RL) + +/** + * @brief Check IWDG window value. + * @param __WINDOW__ IWDG window value + * @retval None + */ +#define IS_IWDG_WINDOW(__WINDOW__) ((__WINDOW__) <= IWDG_WINR_WIN) + + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_IWDG_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd.h new file mode 100644 index 0000000..f45f85e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd.h @@ -0,0 +1,1004 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pcd.h + * @author MCD Application Team + * @brief Header file of PCD HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_PCD_H +#define STM32F0xx_HAL_PCD_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_usb.h" + +#if defined (USB) + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup PCD + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup PCD_Exported_Types PCD Exported Types + * @{ + */ + +/** + * @brief PCD State structure definition + */ +typedef enum +{ + HAL_PCD_STATE_RESET = 0x00, + HAL_PCD_STATE_READY = 0x01, + HAL_PCD_STATE_ERROR = 0x02, + HAL_PCD_STATE_BUSY = 0x03, + HAL_PCD_STATE_TIMEOUT = 0x04 +} PCD_StateTypeDef; + +/* Device LPM suspend state */ +typedef enum +{ + LPM_L0 = 0x00, /* on */ + LPM_L1 = 0x01, /* LPM L1 sleep */ + LPM_L2 = 0x02, /* suspend */ + LPM_L3 = 0x03, /* off */ +} PCD_LPM_StateTypeDef; + +typedef enum +{ + PCD_LPM_L0_ACTIVE = 0x00, /* on */ + PCD_LPM_L1_ACTIVE = 0x01, /* LPM L1 sleep */ +} PCD_LPM_MsgTypeDef; + +typedef enum +{ + PCD_BCD_ERROR = 0xFF, + PCD_BCD_CONTACT_DETECTION = 0xFE, + PCD_BCD_STD_DOWNSTREAM_PORT = 0xFD, + PCD_BCD_CHARGING_DOWNSTREAM_PORT = 0xFC, + PCD_BCD_DEDICATED_CHARGING_PORT = 0xFB, + PCD_BCD_DISCOVERY_COMPLETED = 0x00, + +} PCD_BCD_MsgTypeDef; + + + + + +typedef USB_TypeDef PCD_TypeDef; +typedef USB_CfgTypeDef PCD_InitTypeDef; +typedef USB_EPTypeDef PCD_EPTypeDef; + + +/** + * @brief PCD Handle Structure definition + */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) +typedef struct __PCD_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ +{ + PCD_TypeDef *Instance; /*!< Register base address */ + PCD_InitTypeDef Init; /*!< PCD required parameters */ + __IO uint8_t USB_Address; /*!< USB Address */ + PCD_EPTypeDef IN_ep[8]; /*!< IN endpoint parameters */ + PCD_EPTypeDef OUT_ep[8]; /*!< OUT endpoint parameters */ + HAL_LockTypeDef Lock; /*!< PCD peripheral status */ + __IO PCD_StateTypeDef State; /*!< PCD communication state */ + __IO uint32_t ErrorCode; /*!< PCD Error code */ + uint32_t Setup[12]; /*!< Setup packet buffer */ + PCD_LPM_StateTypeDef LPM_State; /*!< LPM State */ + uint32_t BESL; + + + uint32_t lpm_active; /*!< Enable or disable the Link Power Management . + This parameter can be set to ENABLE or DISABLE */ + + uint32_t battery_charging_active; /*!< Enable or disable Battery charging. + This parameter can be set to ENABLE or DISABLE */ + void *pData; /*!< Pointer to upper stack Handler */ + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + void (* SOFCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD SOF callback */ + void (* SetupStageCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Setup Stage callback */ + void (* ResetCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Reset callback */ + void (* SuspendCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Suspend callback */ + void (* ResumeCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Resume callback */ + void (* ConnectCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Connect callback */ + void (* DisconnectCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Disconnect callback */ + + void (* DataOutStageCallback)(struct __PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< USB OTG PCD Data OUT Stage callback */ + void (* DataInStageCallback)(struct __PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< USB OTG PCD Data IN Stage callback */ + void (* ISOOUTIncompleteCallback)(struct __PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< USB OTG PCD ISO OUT Incomplete callback */ + void (* ISOINIncompleteCallback)(struct __PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< USB OTG PCD ISO IN Incomplete callback */ + void (* BCDCallback)(struct __PCD_HandleTypeDef *hpcd, PCD_BCD_MsgTypeDef msg); /*!< USB OTG PCD BCD callback */ + void (* LPMCallback)(struct __PCD_HandleTypeDef *hpcd, PCD_LPM_MsgTypeDef msg); /*!< USB OTG PCD LPM callback */ + + void (* MspInitCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Msp Init callback */ + void (* MspDeInitCallback)(struct __PCD_HandleTypeDef *hpcd); /*!< USB OTG PCD Msp DeInit callback */ +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ +} PCD_HandleTypeDef; + +/** + * @} + */ + +/* Include PCD HAL Extended module */ +#include "stm32f0xx_hal_pcd_ex.h" + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup PCD_Exported_Constants PCD Exported Constants + * @{ + */ + +/** @defgroup PCD_Speed PCD Speed + * @{ + */ +#define PCD_SPEED_FULL USBD_FS_SPEED +/** + * @} + */ + +/** @defgroup PCD_PHY_Module PCD PHY Module + * @{ + */ +#define PCD_PHY_ULPI 1U +#define PCD_PHY_EMBEDDED 2U +#define PCD_PHY_UTMI 3U +/** + * @} + */ + +/** @defgroup PCD_Error_Code_definition PCD Error Code definition + * @brief PCD Error Code definition + * @{ + */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) +#define HAL_PCD_ERROR_INVALID_CALLBACK (0x00000010U) /*!< Invalid Callback error */ +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup PCD_Exported_Macros PCD Exported Macros + * @brief macros to handle interrupts and specific clock configurations + * @{ + */ + + +#define __HAL_PCD_ENABLE(__HANDLE__) (void)USB_EnableGlobalInt ((__HANDLE__)->Instance) +#define __HAL_PCD_DISABLE(__HANDLE__) (void)USB_DisableGlobalInt ((__HANDLE__)->Instance) +#define __HAL_PCD_GET_FLAG(__HANDLE__, __INTERRUPT__) ((USB_ReadInterrupts((__HANDLE__)->Instance)\ + & (__INTERRUPT__)) == (__INTERRUPT__)) + +#define __HAL_PCD_CLEAR_FLAG(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->ISTR)\ + &= (uint16_t)(~(__INTERRUPT__))) + +#define __HAL_USB_WAKEUP_EXTI_ENABLE_IT() EXTI->IMR |= USB_WAKEUP_EXTI_LINE +#define __HAL_USB_WAKEUP_EXTI_DISABLE_IT() EXTI->IMR &= ~(USB_WAKEUP_EXTI_LINE) + + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup PCD_Exported_Functions PCD Exported Functions + * @{ + */ + +/* Initialization/de-initialization functions ********************************/ +/** @addtogroup PCD_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ +HAL_StatusTypeDef HAL_PCD_Init(PCD_HandleTypeDef *hpcd); +HAL_StatusTypeDef HAL_PCD_DeInit(PCD_HandleTypeDef *hpcd); +void HAL_PCD_MspInit(PCD_HandleTypeDef *hpcd); +void HAL_PCD_MspDeInit(PCD_HandleTypeDef *hpcd); + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) +/** @defgroup HAL_PCD_Callback_ID_enumeration_definition HAL USB OTG PCD Callback ID enumeration definition + * @brief HAL USB OTG PCD Callback ID enumeration definition + * @{ + */ +typedef enum +{ + HAL_PCD_SOF_CB_ID = 0x01, /*!< USB PCD SOF callback ID */ + HAL_PCD_SETUPSTAGE_CB_ID = 0x02, /*!< USB PCD Setup Stage callback ID */ + HAL_PCD_RESET_CB_ID = 0x03, /*!< USB PCD Reset callback ID */ + HAL_PCD_SUSPEND_CB_ID = 0x04, /*!< USB PCD Suspend callback ID */ + HAL_PCD_RESUME_CB_ID = 0x05, /*!< USB PCD Resume callback ID */ + HAL_PCD_CONNECT_CB_ID = 0x06, /*!< USB PCD Connect callback ID */ + HAL_PCD_DISCONNECT_CB_ID = 0x07, /*!< USB PCD Disconnect callback ID */ + + HAL_PCD_MSPINIT_CB_ID = 0x08, /*!< USB PCD MspInit callback ID */ + HAL_PCD_MSPDEINIT_CB_ID = 0x09 /*!< USB PCD MspDeInit callback ID */ + +} HAL_PCD_CallbackIDTypeDef; +/** + * @} + */ + +/** @defgroup HAL_PCD_Callback_pointer_definition HAL USB OTG PCD Callback pointer definition + * @brief HAL USB OTG PCD Callback pointer definition + * @{ + */ + +typedef void (*pPCD_CallbackTypeDef)(PCD_HandleTypeDef *hpcd); /*!< pointer to a common USB OTG PCD callback function */ +typedef void (*pPCD_DataOutStageCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< pointer to USB OTG PCD Data OUT Stage callback */ +typedef void (*pPCD_DataInStageCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< pointer to USB OTG PCD Data IN Stage callback */ +typedef void (*pPCD_IsoOutIncpltCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< pointer to USB OTG PCD ISO OUT Incomplete callback */ +typedef void (*pPCD_IsoInIncpltCallbackTypeDef)(PCD_HandleTypeDef *hpcd, uint8_t epnum); /*!< pointer to USB OTG PCD ISO IN Incomplete callback */ +typedef void (*pPCD_LpmCallbackTypeDef)(PCD_HandleTypeDef *hpcd, PCD_LPM_MsgTypeDef msg); /*!< pointer to USB OTG PCD LPM callback */ +typedef void (*pPCD_BcdCallbackTypeDef)(PCD_HandleTypeDef *hpcd, PCD_BCD_MsgTypeDef msg); /*!< pointer to USB OTG PCD BCD callback */ + +/** + * @} + */ + +HAL_StatusTypeDef HAL_PCD_RegisterCallback(PCD_HandleTypeDef *hpcd, + HAL_PCD_CallbackIDTypeDef CallbackID, + pPCD_CallbackTypeDef pCallback); + +HAL_StatusTypeDef HAL_PCD_UnRegisterCallback(PCD_HandleTypeDef *hpcd, + HAL_PCD_CallbackIDTypeDef CallbackID); + +HAL_StatusTypeDef HAL_PCD_RegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd, + pPCD_DataOutStageCallbackTypeDef pCallback); + +HAL_StatusTypeDef HAL_PCD_UnRegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd); + +HAL_StatusTypeDef HAL_PCD_RegisterDataInStageCallback(PCD_HandleTypeDef *hpcd, + pPCD_DataInStageCallbackTypeDef pCallback); + +HAL_StatusTypeDef HAL_PCD_UnRegisterDataInStageCallback(PCD_HandleTypeDef *hpcd); + +HAL_StatusTypeDef HAL_PCD_RegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd, + pPCD_IsoOutIncpltCallbackTypeDef pCallback); + +HAL_StatusTypeDef HAL_PCD_UnRegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd); + +HAL_StatusTypeDef HAL_PCD_RegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd, + pPCD_IsoInIncpltCallbackTypeDef pCallback); + +HAL_StatusTypeDef HAL_PCD_UnRegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd); + +HAL_StatusTypeDef HAL_PCD_RegisterBcdCallback(PCD_HandleTypeDef *hpcd, + pPCD_BcdCallbackTypeDef pCallback); + +HAL_StatusTypeDef HAL_PCD_UnRegisterBcdCallback(PCD_HandleTypeDef *hpcd); + +HAL_StatusTypeDef HAL_PCD_RegisterLpmCallback(PCD_HandleTypeDef *hpcd, + pPCD_LpmCallbackTypeDef pCallback); + +HAL_StatusTypeDef HAL_PCD_UnRegisterLpmCallback(PCD_HandleTypeDef *hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ +/** + * @} + */ + +/* I/O operation functions ***************************************************/ +/* Non-Blocking mode: Interrupt */ +/** @addtogroup PCD_Exported_Functions_Group2 Input and Output operation functions + * @{ + */ +HAL_StatusTypeDef HAL_PCD_Start(PCD_HandleTypeDef *hpcd); +HAL_StatusTypeDef HAL_PCD_Stop(PCD_HandleTypeDef *hpcd); +void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd); + +void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd); +void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd); +void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd); +void HAL_PCD_SuspendCallback(PCD_HandleTypeDef *hpcd); +void HAL_PCD_ResumeCallback(PCD_HandleTypeDef *hpcd); +void HAL_PCD_ConnectCallback(PCD_HandleTypeDef *hpcd); +void HAL_PCD_DisconnectCallback(PCD_HandleTypeDef *hpcd); + +void HAL_PCD_DataOutStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum); +void HAL_PCD_DataInStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum); +void HAL_PCD_ISOOUTIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum); +void HAL_PCD_ISOINIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum); +/** + * @} + */ + +/* Peripheral Control functions **********************************************/ +/** @addtogroup PCD_Exported_Functions_Group3 Peripheral Control functions + * @{ + */ +HAL_StatusTypeDef HAL_PCD_DevConnect(PCD_HandleTypeDef *hpcd); +HAL_StatusTypeDef HAL_PCD_DevDisconnect(PCD_HandleTypeDef *hpcd); +HAL_StatusTypeDef HAL_PCD_SetAddress(PCD_HandleTypeDef *hpcd, uint8_t address); +HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, + uint16_t ep_mps, uint8_t ep_type); + +HAL_StatusTypeDef HAL_PCD_EP_Close(PCD_HandleTypeDef *hpcd, uint8_t ep_addr); +HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, + uint8_t *pBuf, uint32_t len); + +HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, + uint8_t *pBuf, uint32_t len); + + +HAL_StatusTypeDef HAL_PCD_EP_SetStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr); +HAL_StatusTypeDef HAL_PCD_EP_ClrStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr); +HAL_StatusTypeDef HAL_PCD_EP_Flush(PCD_HandleTypeDef *hpcd, uint8_t ep_addr); +HAL_StatusTypeDef HAL_PCD_ActivateRemoteWakeup(PCD_HandleTypeDef *hpcd); +HAL_StatusTypeDef HAL_PCD_DeActivateRemoteWakeup(PCD_HandleTypeDef *hpcd); + +uint32_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr); +/** + * @} + */ + +/* Peripheral State functions ************************************************/ +/** @addtogroup PCD_Exported_Functions_Group4 Peripheral State functions + * @{ + */ +PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd); +/** + * @} + */ + +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup PCD_Private_Constants PCD Private Constants + * @{ + */ +/** @defgroup USB_EXTI_Line_Interrupt USB EXTI line interrupt + * @{ + */ + + +#define USB_WAKEUP_EXTI_LINE (0x1U << 18) /*!< USB FS EXTI Line WakeUp Interrupt */ + + +/** + * @} + */ + +/** @defgroup PCD_EP0_MPS PCD EP0 MPS + * @{ + */ +#define PCD_EP0MPS_64 EP_MPS_64 +#define PCD_EP0MPS_32 EP_MPS_32 +#define PCD_EP0MPS_16 EP_MPS_16 +#define PCD_EP0MPS_08 EP_MPS_8 +/** + * @} + */ + +/** @defgroup PCD_ENDP PCD ENDP + * @{ + */ +#define PCD_ENDP0 0U +#define PCD_ENDP1 1U +#define PCD_ENDP2 2U +#define PCD_ENDP3 3U +#define PCD_ENDP4 4U +#define PCD_ENDP5 5U +#define PCD_ENDP6 6U +#define PCD_ENDP7 7U +/** + * @} + */ + +/** @defgroup PCD_ENDP_Kind PCD Endpoint Kind + * @{ + */ +#define PCD_SNG_BUF 0U +#define PCD_DBL_BUF 1U +/** + * @} + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup PCD_Private_Macros PCD Private Macros + * @{ + */ + +/******************** Bit definition for USB_COUNTn_RX register *************/ +#define USB_CNTRX_NBLK_MSK (0x1FU << 10) +#define USB_CNTRX_BLSIZE (0x1U << 15) + +/* SetENDPOINT */ +#define PCD_SET_ENDPOINT(USBx, bEpNum, wRegValue) (*(__IO uint16_t *)\ + (&(USBx)->EP0R + ((bEpNum) * 2U)) = (uint16_t)(wRegValue)) + +/* GetENDPOINT */ +#define PCD_GET_ENDPOINT(USBx, bEpNum) (*(__IO uint16_t *)(&(USBx)->EP0R + ((bEpNum) * 2U))) + +/* ENDPOINT transfer */ +#define USB_EP0StartXfer USB_EPStartXfer + +/** + * @brief sets the type in the endpoint register(bits EP_TYPE[1:0]) + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wType Endpoint Type. + * @retval None + */ +#define PCD_SET_EPTYPE(USBx, bEpNum, wType) (PCD_SET_ENDPOINT((USBx), (bEpNum), ((PCD_GET_ENDPOINT((USBx), (bEpNum))\ + & USB_EP_T_MASK) | (wType) | USB_EP_CTR_TX | USB_EP_CTR_RX))) + + +/** + * @brief gets the type in the endpoint register(bits EP_TYPE[1:0]) + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval Endpoint Type + */ +#define PCD_GET_EPTYPE(USBx, bEpNum) (PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EP_T_FIELD) + +/** + * @brief free buffer used from the application realizing it to the line + * toggles bit SW_BUF in the double buffered endpoint register + * @param USBx USB device. + * @param bEpNum, bDir + * @retval None + */ +#define PCD_FreeUserBuffer(USBx, bEpNum, bDir) \ + do { \ + if ((bDir) == 0U) \ + { \ + /* OUT double buffered endpoint */ \ + PCD_TX_DTOG((USBx), (bEpNum)); \ + } \ + else if ((bDir) == 1U) \ + { \ + /* IN double buffered endpoint */ \ + PCD_RX_DTOG((USBx), (bEpNum)); \ + } \ + } while(0) + +/** + * @brief sets the status for tx transfer (bits STAT_TX[1:0]). + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wState new state + * @retval None + */ +#define PCD_SET_EP_TX_STATUS(USBx, bEpNum, wState) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPTX_DTOGMASK; \ + /* toggle first bit ? */ \ + if ((USB_EPTX_DTOG1 & (wState))!= 0U) \ + { \ + _wRegVal ^= USB_EPTX_DTOG1; \ + } \ + /* toggle second bit ? */ \ + if ((USB_EPTX_DTOG2 & (wState))!= 0U) \ + { \ + _wRegVal ^= USB_EPTX_DTOG2; \ + } \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \ + } while(0) /* PCD_SET_EP_TX_STATUS */ + +/** + * @brief sets the status for rx transfer (bits STAT_TX[1:0]) + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wState new state + * @retval None + */ +#define PCD_SET_EP_RX_STATUS(USBx, bEpNum,wState) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPRX_DTOGMASK; \ + /* toggle first bit ? */ \ + if ((USB_EPRX_DTOG1 & (wState))!= 0U) \ + { \ + _wRegVal ^= USB_EPRX_DTOG1; \ + } \ + /* toggle second bit ? */ \ + if ((USB_EPRX_DTOG2 & (wState))!= 0U) \ + { \ + _wRegVal ^= USB_EPRX_DTOG2; \ + } \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \ + } while(0) /* PCD_SET_EP_RX_STATUS */ + +/** + * @brief sets the status for rx & tx (bits STAT_TX[1:0] & STAT_RX[1:0]) + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wStaterx new state. + * @param wStatetx new state. + * @retval None + */ +#define PCD_SET_EP_TXRX_STATUS(USBx, bEpNum, wStaterx, wStatetx) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (USB_EPRX_DTOGMASK | USB_EPTX_STAT); \ + /* toggle first bit ? */ \ + if ((USB_EPRX_DTOG1 & (wStaterx))!= 0U) \ + { \ + _wRegVal ^= USB_EPRX_DTOG1; \ + } \ + /* toggle second bit ? */ \ + if ((USB_EPRX_DTOG2 & (wStaterx))!= 0U) \ + { \ + _wRegVal ^= USB_EPRX_DTOG2; \ + } \ + /* toggle first bit ? */ \ + if ((USB_EPTX_DTOG1 & (wStatetx))!= 0U) \ + { \ + _wRegVal ^= USB_EPTX_DTOG1; \ + } \ + /* toggle second bit ? */ \ + if ((USB_EPTX_DTOG2 & (wStatetx))!= 0U) \ + { \ + _wRegVal ^= USB_EPTX_DTOG2; \ + } \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \ + } while(0) /* PCD_SET_EP_TXRX_STATUS */ + +/** + * @brief gets the status for tx/rx transfer (bits STAT_TX[1:0] + * /STAT_RX[1:0]) + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval status + */ +#define PCD_GET_EP_TX_STATUS(USBx, bEpNum) ((uint16_t)PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPTX_STAT) +#define PCD_GET_EP_RX_STATUS(USBx, bEpNum) ((uint16_t)PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPRX_STAT) + +/** + * @brief sets directly the VALID tx/rx-status into the endpoint register + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_SET_EP_TX_VALID(USBx, bEpNum) (PCD_SET_EP_TX_STATUS((USBx), (bEpNum), USB_EP_TX_VALID)) +#define PCD_SET_EP_RX_VALID(USBx, bEpNum) (PCD_SET_EP_RX_STATUS((USBx), (bEpNum), USB_EP_RX_VALID)) + +/** + * @brief checks stall condition in an endpoint. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval TRUE = endpoint in stall condition. + */ +#define PCD_GET_EP_TX_STALL_STATUS(USBx, bEpNum) (PCD_GET_EP_TX_STATUS((USBx), (bEpNum)) == USB_EP_TX_STALL) +#define PCD_GET_EP_RX_STALL_STATUS(USBx, bEpNum) (PCD_GET_EP_RX_STATUS((USBx), (bEpNum)) == USB_EP_RX_STALL) + +/** + * @brief set & clear EP_KIND bit. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_SET_EP_KIND(USBx, bEpNum) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX | USB_EP_KIND)); \ + } while(0) /* PCD_SET_EP_KIND */ + +#define PCD_CLEAR_EP_KIND(USBx, bEpNum) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPKIND_MASK; \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \ + } while(0) /* PCD_CLEAR_EP_KIND */ + +/** + * @brief Sets/clears directly STATUS_OUT bit in the endpoint register. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_SET_OUT_STATUS(USBx, bEpNum) PCD_SET_EP_KIND((USBx), (bEpNum)) +#define PCD_CLEAR_OUT_STATUS(USBx, bEpNum) PCD_CLEAR_EP_KIND((USBx), (bEpNum)) + +/** + * @brief Sets/clears directly EP_KIND bit in the endpoint register. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_SET_BULK_EP_DBUF(USBx, bEpNum) PCD_SET_EP_KIND((USBx), (bEpNum)) +#define PCD_CLEAR_BULK_EP_DBUF(USBx, bEpNum) PCD_CLEAR_EP_KIND((USBx), (bEpNum)) + +/** + * @brief Clears bit CTR_RX / CTR_TX in the endpoint register. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_CLEAR_RX_EP_CTR(USBx, bEpNum) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (0x7FFFU & USB_EPREG_MASK); \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_TX)); \ + } while(0) /* PCD_CLEAR_RX_EP_CTR */ + +#define PCD_CLEAR_TX_EP_CTR(USBx, bEpNum) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & (0xFF7FU & USB_EPREG_MASK); \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX)); \ + } while(0) /* PCD_CLEAR_TX_EP_CTR */ + +/** + * @brief Toggles DTOG_RX / DTOG_TX bit in the endpoint register. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_RX_DTOG(USBx, bEpNum) \ + do { \ + uint16_t _wEPVal; \ + \ + _wEPVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wEPVal | USB_EP_CTR_RX | USB_EP_CTR_TX | USB_EP_DTOG_RX)); \ + } while(0) /* PCD_RX_DTOG */ + +#define PCD_TX_DTOG(USBx, bEpNum) \ + do { \ + uint16_t _wEPVal; \ + \ + _wEPVal = PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK; \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wEPVal | USB_EP_CTR_RX | USB_EP_CTR_TX | USB_EP_DTOG_TX)); \ + } while(0) /* PCD_TX_DTOG */ +/** + * @brief Clears DTOG_RX / DTOG_TX bit in the endpoint register. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_CLEAR_RX_DTOG(USBx, bEpNum) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)); \ + \ + if ((_wRegVal & USB_EP_DTOG_RX) != 0U)\ + { \ + PCD_RX_DTOG((USBx), (bEpNum)); \ + } \ + } while(0) /* PCD_CLEAR_RX_DTOG */ + +#define PCD_CLEAR_TX_DTOG(USBx, bEpNum) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = PCD_GET_ENDPOINT((USBx), (bEpNum)); \ + \ + if ((_wRegVal & USB_EP_DTOG_TX) != 0U)\ + { \ + PCD_TX_DTOG((USBx), (bEpNum)); \ + } \ + } while(0) /* PCD_CLEAR_TX_DTOG */ + +/** + * @brief Sets address in an endpoint register. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param bAddr Address. + * @retval None + */ +#define PCD_SET_EP_ADDRESS(USBx, bEpNum, bAddr) \ + do { \ + uint16_t _wRegVal; \ + \ + _wRegVal = (PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPREG_MASK) | (bAddr); \ + \ + PCD_SET_ENDPOINT((USBx), (bEpNum), (_wRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); \ + } while(0) /* PCD_SET_EP_ADDRESS */ + +/** + * @brief Gets address in an endpoint register. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_GET_EP_ADDRESS(USBx, bEpNum) ((uint8_t)(PCD_GET_ENDPOINT((USBx), (bEpNum)) & USB_EPADDR_FIELD)) + +#define PCD_EP_TX_CNT(USBx, bEpNum) ((uint16_t *)((((uint32_t)(USBx)->BTABLE\ + + ((uint32_t)(bEpNum) * 8U) + 2U) * PMA_ACCESS) + ((uint32_t)(USBx) + 0x400U))) + +#define PCD_EP_RX_CNT(USBx, bEpNum) ((uint16_t *)((((uint32_t)(USBx)->BTABLE\ + + ((uint32_t)(bEpNum) * 8U) + 6U) * PMA_ACCESS) + ((uint32_t)(USBx) + 0x400U))) + + +/** + * @brief sets address of the tx/rx buffer. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wAddr address to be set (must be word aligned). + * @retval None + */ +#define PCD_SET_EP_TX_ADDRESS(USBx, bEpNum, wAddr) \ + do { \ + __IO uint16_t *_wRegVal; \ + uint32_t _wRegBase = (uint32_t)USBx; \ + \ + _wRegBase += (uint32_t)(USBx)->BTABLE; \ + _wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + (((uint32_t)(bEpNum) * 8U) * PMA_ACCESS)); \ + *_wRegVal = ((wAddr) >> 1) << 1; \ + } while(0) /* PCD_SET_EP_TX_ADDRESS */ + +#define PCD_SET_EP_RX_ADDRESS(USBx, bEpNum, wAddr) \ + do { \ + __IO uint16_t *_wRegVal; \ + uint32_t _wRegBase = (uint32_t)USBx; \ + \ + _wRegBase += (uint32_t)(USBx)->BTABLE; \ + _wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 4U) * PMA_ACCESS)); \ + *_wRegVal = ((wAddr) >> 1) << 1; \ + } while(0) /* PCD_SET_EP_RX_ADDRESS */ + +/** + * @brief Gets address of the tx/rx buffer. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval address of the buffer. + */ +#define PCD_GET_EP_TX_ADDRESS(USBx, bEpNum) ((uint16_t)*PCD_EP_TX_ADDRESS((USBx), (bEpNum))) +#define PCD_GET_EP_RX_ADDRESS(USBx, bEpNum) ((uint16_t)*PCD_EP_RX_ADDRESS((USBx), (bEpNum))) + +/** + * @brief Sets counter of rx buffer with no. of blocks. + * @param pdwReg Register pointer + * @param wCount Counter. + * @param wNBlocks no. of Blocks. + * @retval None + */ +#define PCD_CALC_BLK32(pdwReg, wCount, wNBlocks) \ + do { \ + (wNBlocks) = (wCount) >> 5; \ + if (((wCount) & 0x1fU) == 0U) \ + { \ + (wNBlocks)--; \ + } \ + *(pdwReg) = (uint16_t)(((wNBlocks) << 10) | USB_CNTRX_BLSIZE); \ + } while(0) /* PCD_CALC_BLK32 */ + +#define PCD_CALC_BLK2(pdwReg, wCount, wNBlocks) \ + do { \ + (wNBlocks) = (wCount) >> 1; \ + if (((wCount) & 0x1U) != 0U) \ + { \ + (wNBlocks)++; \ + } \ + *(pdwReg) = (uint16_t)((wNBlocks) << 10); \ + } while(0) /* PCD_CALC_BLK2 */ + +#define PCD_SET_EP_CNT_RX_REG(pdwReg, wCount) \ + do { \ + uint32_t wNBlocks; \ + if ((wCount) == 0U) \ + { \ + *(pdwReg) &= (uint16_t)~USB_CNTRX_NBLK_MSK; \ + *(pdwReg) |= USB_CNTRX_BLSIZE; \ + } \ + else if((wCount) <= 62U) \ + { \ + PCD_CALC_BLK2((pdwReg), (wCount), wNBlocks); \ + } \ + else \ + { \ + PCD_CALC_BLK32((pdwReg), (wCount), wNBlocks); \ + } \ + } while(0) /* PCD_SET_EP_CNT_RX_REG */ + +#define PCD_SET_EP_RX_DBUF0_CNT(USBx, bEpNum, wCount) \ + do { \ + uint32_t _wRegBase = (uint32_t)(USBx); \ + __IO uint16_t *pdwReg; \ + \ + _wRegBase += (uint32_t)(USBx)->BTABLE; \ + pdwReg = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 2U) * PMA_ACCESS)); \ + PCD_SET_EP_CNT_RX_REG(pdwReg, (wCount)); \ + } while(0) + +/** + * @brief sets counter for the tx/rx buffer. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wCount Counter value. + * @retval None + */ +#define PCD_SET_EP_TX_CNT(USBx, bEpNum, wCount) \ + do { \ + uint32_t _wRegBase = (uint32_t)(USBx); \ + __IO uint16_t *_wRegVal; \ + \ + _wRegBase += (uint32_t)(USBx)->BTABLE; \ + _wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 2U) * PMA_ACCESS)); \ + *_wRegVal = (uint16_t)(wCount); \ + } while(0) + +#define PCD_SET_EP_RX_CNT(USBx, bEpNum, wCount) \ + do { \ + uint32_t _wRegBase = (uint32_t)(USBx); \ + __IO uint16_t *_wRegVal; \ + \ + _wRegBase += (uint32_t)(USBx)->BTABLE; \ + _wRegVal = (__IO uint16_t *)(_wRegBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 6U) * PMA_ACCESS)); \ + PCD_SET_EP_CNT_RX_REG(_wRegVal, (wCount)); \ + } while(0) + +/** + * @brief gets counter of the tx buffer. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval Counter value + */ +#define PCD_GET_EP_TX_CNT(USBx, bEpNum) ((uint32_t)(*PCD_EP_TX_CNT((USBx), (bEpNum))) & 0x3ffU) +#define PCD_GET_EP_RX_CNT(USBx, bEpNum) ((uint32_t)(*PCD_EP_RX_CNT((USBx), (bEpNum))) & 0x3ffU) + +/** + * @brief Sets buffer 0/1 address in a double buffer endpoint. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wBuf0Addr buffer 0 address. + * @retval Counter value + */ +#define PCD_SET_EP_DBUF0_ADDR(USBx, bEpNum, wBuf0Addr) \ + do { \ + PCD_SET_EP_TX_ADDRESS((USBx), (bEpNum), (wBuf0Addr)); \ + } while(0) /* PCD_SET_EP_DBUF0_ADDR */ + +#define PCD_SET_EP_DBUF1_ADDR(USBx, bEpNum, wBuf1Addr) \ + do { \ + PCD_SET_EP_RX_ADDRESS((USBx), (bEpNum), (wBuf1Addr)); \ + } while(0) /* PCD_SET_EP_DBUF1_ADDR */ + +/** + * @brief Sets addresses in a double buffer endpoint. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param wBuf0Addr: buffer 0 address. + * @param wBuf1Addr = buffer 1 address. + * @retval None + */ +#define PCD_SET_EP_DBUF_ADDR(USBx, bEpNum, wBuf0Addr, wBuf1Addr) \ + do { \ + PCD_SET_EP_DBUF0_ADDR((USBx), (bEpNum), (wBuf0Addr)); \ + PCD_SET_EP_DBUF1_ADDR((USBx), (bEpNum), (wBuf1Addr)); \ + } while(0) /* PCD_SET_EP_DBUF_ADDR */ + +/** + * @brief Gets buffer 0/1 address of a double buffer endpoint. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_GET_EP_DBUF0_ADDR(USBx, bEpNum) (PCD_GET_EP_TX_ADDRESS((USBx), (bEpNum))) +#define PCD_GET_EP_DBUF1_ADDR(USBx, bEpNum) (PCD_GET_EP_RX_ADDRESS((USBx), (bEpNum))) + +/** + * @brief Gets buffer 0/1 address of a double buffer endpoint. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @param bDir endpoint dir EP_DBUF_OUT = OUT + * EP_DBUF_IN = IN + * @param wCount: Counter value + * @retval None + */ +#define PCD_SET_EP_DBUF0_CNT(USBx, bEpNum, bDir, wCount) \ + do { \ + if ((bDir) == 0U) \ + /* OUT endpoint */ \ + { \ + PCD_SET_EP_RX_DBUF0_CNT((USBx), (bEpNum), (wCount)); \ + } \ + else \ + { \ + if ((bDir) == 1U) \ + { \ + /* IN endpoint */ \ + PCD_SET_EP_TX_CNT((USBx), (bEpNum), (wCount)); \ + } \ + } \ + } while(0) /* SetEPDblBuf0Count*/ + +#define PCD_SET_EP_DBUF1_CNT(USBx, bEpNum, bDir, wCount) \ + do { \ + uint32_t _wBase = (uint32_t)(USBx); \ + __IO uint16_t *_wEPRegVal; \ + \ + if ((bDir) == 0U) \ + { \ + /* OUT endpoint */ \ + PCD_SET_EP_RX_CNT((USBx), (bEpNum), (wCount)); \ + } \ + else \ + { \ + if ((bDir) == 1U) \ + { \ + /* IN endpoint */ \ + _wBase += (uint32_t)(USBx)->BTABLE; \ + _wEPRegVal = (__IO uint16_t *)(_wBase + 0x400U + ((((uint32_t)(bEpNum) * 8U) + 6U) * PMA_ACCESS)); \ + *_wEPRegVal = (uint16_t)(wCount); \ + } \ + } \ + } while(0) /* SetEPDblBuf1Count */ + +#define PCD_SET_EP_DBUF_CNT(USBx, bEpNum, bDir, wCount) \ + do { \ + PCD_SET_EP_DBUF0_CNT((USBx), (bEpNum), (bDir), (wCount)); \ + PCD_SET_EP_DBUF1_CNT((USBx), (bEpNum), (bDir), (wCount)); \ + } while(0) /* PCD_SET_EP_DBUF_CNT */ + +/** + * @brief Gets buffer 0/1 rx/tx counter for double buffering. + * @param USBx USB peripheral instance register address. + * @param bEpNum Endpoint Number. + * @retval None + */ +#define PCD_GET_EP_DBUF0_CNT(USBx, bEpNum) (PCD_GET_EP_TX_CNT((USBx), (bEpNum))) +#define PCD_GET_EP_DBUF1_CNT(USBx, bEpNum) (PCD_GET_EP_RX_CNT((USBx), (bEpNum))) + + + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* defined (USB) */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_PCD_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd_ex.h new file mode 100644 index 0000000..d9a37d2 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pcd_ex.h @@ -0,0 +1,91 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pcd_ex.h + * @author MCD Application Team + * @brief Header file of PCD HAL Extension module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_PCD_EX_H +#define STM32F0xx_HAL_PCD_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +#if defined (USB) +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup PCDEx + * @{ + */ +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/* Exported macros -----------------------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup PCDEx_Exported_Functions PCDEx Exported Functions + * @{ + */ +/** @addtogroup PCDEx_Exported_Functions_Group1 Peripheral Control functions + * @{ + */ + + + +HAL_StatusTypeDef HAL_PCDEx_PMAConfig(PCD_HandleTypeDef *hpcd, uint16_t ep_addr, + uint16_t ep_kind, uint32_t pmaadress); + + +HAL_StatusTypeDef HAL_PCDEx_ActivateLPM(PCD_HandleTypeDef *hpcd); +HAL_StatusTypeDef HAL_PCDEx_DeActivateLPM(PCD_HandleTypeDef *hpcd); + + +HAL_StatusTypeDef HAL_PCDEx_ActivateBCD(PCD_HandleTypeDef *hpcd); +HAL_StatusTypeDef HAL_PCDEx_DeActivateBCD(PCD_HandleTypeDef *hpcd); +void HAL_PCDEx_BCD_VBUSDetect(PCD_HandleTypeDef *hpcd); + +void HAL_PCDEx_LPM_Callback(PCD_HandleTypeDef *hpcd, PCD_LPM_MsgTypeDef msg); +void HAL_PCDEx_BCD_Callback(PCD_HandleTypeDef *hpcd, PCD_BCD_MsgTypeDef msg); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* defined (USB) */ + +#ifdef __cplusplus +} +#endif + + +#endif /* STM32F0xx_HAL_PCD_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr.h new file mode 100644 index 0000000..e716606 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr.h @@ -0,0 +1,189 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pwr.h + * @author MCD Application Team + * @brief Header file of PWR HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_PWR_H +#define __STM32F0xx_HAL_PWR_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup PWR PWR + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup PWR_Exported_Constants PWR Exported Constants + * @{ + */ + +/** @defgroup PWR_Regulator_state_in_STOP_mode PWR Regulator state in STOP mode + * @{ + */ +#define PWR_MAINREGULATOR_ON (0x00000000U) +#define PWR_LOWPOWERREGULATOR_ON PWR_CR_LPDS + +#define IS_PWR_REGULATOR(REGULATOR) (((REGULATOR) == PWR_MAINREGULATOR_ON) || \ + ((REGULATOR) == PWR_LOWPOWERREGULATOR_ON)) +/** + * @} + */ + +/** @defgroup PWR_SLEEP_mode_entry PWR SLEEP mode entry + * @{ + */ +#define PWR_SLEEPENTRY_WFI ((uint8_t)0x01U) +#define PWR_SLEEPENTRY_WFE ((uint8_t)0x02U) +#define IS_PWR_SLEEP_ENTRY(ENTRY) (((ENTRY) == PWR_SLEEPENTRY_WFI) || ((ENTRY) == PWR_SLEEPENTRY_WFE)) +/** + * @} + */ + +/** @defgroup PWR_STOP_mode_entry PWR STOP mode entry + * @{ + */ +#define PWR_STOPENTRY_WFI ((uint8_t)0x01U) +#define PWR_STOPENTRY_WFE ((uint8_t)0x02U) +#define IS_PWR_STOP_ENTRY(ENTRY) (((ENTRY) == PWR_STOPENTRY_WFI) || ((ENTRY) == PWR_STOPENTRY_WFE)) +/** + * @} + */ + + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup PWR_Exported_Macro PWR Exported Macro + * @{ + */ + +/** @brief Check PWR flag is set or not. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg PWR_FLAG_WU: Wake Up flag. This flag indicates that a wakeup event + * was received from the WKUP pin or from the RTC alarm (Alarm A), + * RTC Tamper event, RTC TimeStamp event or RTC Wakeup. + * An additional wakeup event is detected if the WKUP pin is enabled + * (by setting the EWUP bit) when the WKUP pin level is already high. + * @arg PWR_FLAG_SB: StandBy flag. This flag indicates that the system was + * resumed from StandBy mode. + * @arg PWR_FLAG_PVDO: PVD Output. This flag is valid only if PVD is enabled + * by the HAL_PWR_EnablePVD() function. The PVD is stopped by Standby mode + * For this reason, this bit is equal to 0 after Standby or reset + * until the PVDE bit is set. + * Warning: this Flag is not available on STM32F030x8 products + * @arg PWR_FLAG_VREFINTRDY: This flag indicates that the internal reference + * voltage VREFINT is ready. + * Warning: this Flag is not available on STM32F030x8 products + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_PWR_GET_FLAG(__FLAG__) ((PWR->CSR & (__FLAG__)) == (__FLAG__)) + +/** @brief Clear the PWR's pending flags. + * @param __FLAG__ specifies the flag to clear. + * This parameter can be one of the following values: + * @arg PWR_FLAG_WU: Wake Up flag + * @arg PWR_FLAG_SB: StandBy flag + */ +#define __HAL_PWR_CLEAR_FLAG(__FLAG__) (PWR->CR |= (__FLAG__) << 2U) + + +/** + * @} + */ + +/* Include PWR HAL Extension module */ +#include "stm32f0xx_hal_pwr_ex.h" + +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup PWR_Exported_Functions PWR Exported Functions + * @{ + */ + +/** @addtogroup PWR_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ + +/* Initialization and de-initialization functions *****************************/ +void HAL_PWR_DeInit(void); + +/** + * @} + */ + +/** @addtogroup PWR_Exported_Functions_Group2 Peripheral Control functions + * @{ + */ + +/* Peripheral Control functions **********************************************/ +void HAL_PWR_EnableBkUpAccess(void); +void HAL_PWR_DisableBkUpAccess(void); + +/* WakeUp pins configuration functions ****************************************/ +void HAL_PWR_EnableWakeUpPin(uint32_t WakeUpPinx); +void HAL_PWR_DisableWakeUpPin(uint32_t WakeUpPinx); + +/* Low Power modes configuration functions ************************************/ +void HAL_PWR_EnterSTOPMode(uint32_t Regulator, uint8_t STOPEntry); +void HAL_PWR_EnterSLEEPMode(uint32_t Regulator, uint8_t SLEEPEntry); +void HAL_PWR_EnterSTANDBYMode(void); + +void HAL_PWR_EnableSleepOnExit(void); +void HAL_PWR_DisableSleepOnExit(void); +void HAL_PWR_EnableSEVOnPend(void); +void HAL_PWR_DisableSEVOnPend(void); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + + +#endif /* __STM32F0xx_HAL_PWR_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr_ex.h new file mode 100644 index 0000000..a9ed6eb --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_pwr_ex.h @@ -0,0 +1,459 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pwr_ex.h + * @author MCD Application Team + * @brief Header file of PWR HAL Extension module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_PWR_EX_H +#define __STM32F0xx_HAL_PWR_EX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup PWREx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup PWREx_Exported_Types PWREx Exported Types + * @{ + */ + +#if defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F072xB) || \ + defined (STM32F091xC) + +/** + * @brief PWR PVD configuration structure definition + */ +typedef struct +{ + uint32_t PVDLevel; /*!< PVDLevel: Specifies the PVD detection level + This parameter can be a value of @ref PWREx_PVD_detection_level */ + + uint32_t Mode; /*!< Mode: Specifies the operating mode for the selected pins. + This parameter can be a value of @ref PWREx_PVD_Mode */ +}PWR_PVDTypeDef; + +#endif /* defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F072xB) || */ + /* defined (STM32F091xC) */ +/** + * @} + */ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup PWREx_Exported_Constants PWREx Exported Constants + * @{ + */ + + +/** @defgroup PWREx_WakeUp_Pins PWREx Wakeup Pins + * @{ + */ +#if defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) +#define PWR_WAKEUP_PIN1 ((uint32_t)PWR_CSR_EWUP1) +#define PWR_WAKEUP_PIN2 ((uint32_t)PWR_CSR_EWUP2) +#define PWR_WAKEUP_PIN3 ((uint32_t)PWR_CSR_EWUP3) +#define PWR_WAKEUP_PIN4 ((uint32_t)PWR_CSR_EWUP4) +#define PWR_WAKEUP_PIN5 ((uint32_t)PWR_CSR_EWUP5) +#define PWR_WAKEUP_PIN6 ((uint32_t)PWR_CSR_EWUP6) +#define PWR_WAKEUP_PIN7 ((uint32_t)PWR_CSR_EWUP7) +#define PWR_WAKEUP_PIN8 ((uint32_t)PWR_CSR_EWUP8) + +#define IS_PWR_WAKEUP_PIN(PIN) (((PIN) == PWR_WAKEUP_PIN1) || \ + ((PIN) == PWR_WAKEUP_PIN2) || \ + ((PIN) == PWR_WAKEUP_PIN3) || \ + ((PIN) == PWR_WAKEUP_PIN4) || \ + ((PIN) == PWR_WAKEUP_PIN5) || \ + ((PIN) == PWR_WAKEUP_PIN6) || \ + ((PIN) == PWR_WAKEUP_PIN7) || \ + ((PIN) == PWR_WAKEUP_PIN8)) + +#elif defined(STM32F030xC) || defined (STM32F070xB) +#define PWR_WAKEUP_PIN1 ((uint32_t)PWR_CSR_EWUP1) +#define PWR_WAKEUP_PIN2 ((uint32_t)PWR_CSR_EWUP2) +#define PWR_WAKEUP_PIN4 ((uint32_t)PWR_CSR_EWUP4) +#define PWR_WAKEUP_PIN5 ((uint32_t)PWR_CSR_EWUP5) +#define PWR_WAKEUP_PIN6 ((uint32_t)PWR_CSR_EWUP6) +#define PWR_WAKEUP_PIN7 ((uint32_t)PWR_CSR_EWUP7) + +#define IS_PWR_WAKEUP_PIN(PIN) (((PIN) == PWR_WAKEUP_PIN1) || \ + ((PIN) == PWR_WAKEUP_PIN2) || \ + ((PIN) == PWR_WAKEUP_PIN4) || \ + ((PIN) == PWR_WAKEUP_PIN5) || \ + ((PIN) == PWR_WAKEUP_PIN6) || \ + ((PIN) == PWR_WAKEUP_PIN7)) + +#elif defined(STM32F042x6) || defined (STM32F048xx) +#define PWR_WAKEUP_PIN1 ((uint32_t)PWR_CSR_EWUP1) +#define PWR_WAKEUP_PIN2 ((uint32_t)PWR_CSR_EWUP2) +#define PWR_WAKEUP_PIN4 ((uint32_t)PWR_CSR_EWUP4) +#define PWR_WAKEUP_PIN6 ((uint32_t)PWR_CSR_EWUP6) +#define PWR_WAKEUP_PIN7 ((uint32_t)PWR_CSR_EWUP7) + +#define IS_PWR_WAKEUP_PIN(PIN) (((PIN) == PWR_WAKEUP_PIN1) || \ + ((PIN) == PWR_WAKEUP_PIN2) || \ + ((PIN) == PWR_WAKEUP_PIN4) || \ + ((PIN) == PWR_WAKEUP_PIN6) || \ + ((PIN) == PWR_WAKEUP_PIN7)) + +#else +#define PWR_WAKEUP_PIN1 ((uint32_t)PWR_CSR_EWUP1) +#define PWR_WAKEUP_PIN2 ((uint32_t)PWR_CSR_EWUP2) + + +#define IS_PWR_WAKEUP_PIN(PIN) (((PIN) == PWR_WAKEUP_PIN1) || \ + ((PIN) == PWR_WAKEUP_PIN2)) + +#endif + +/** + * @} + */ + +/** @defgroup PWREx_EXTI_Line PWREx EXTI Line + * @{ + */ +#if defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F072xB) || \ + defined (STM32F091xC) + +#define PWR_EXTI_LINE_PVD ((uint32_t)EXTI_IMR_MR16) /*!< External interrupt line 16 Connected to the PVD EXTI Line */ + +#endif /* defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F072xB) || */ + /* defined (STM32F091xC) */ + +#if defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) + +#define PWR_EXTI_LINE_VDDIO2 ((uint32_t)EXTI_IMR_MR31) /*!< External interrupt line 31 Connected to the Vddio2 Monitor EXTI Line */ + +#endif /* defined (STM32F042x6) || defined (STM32F048xx) ||\ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) ||*/ +/** + * @} + */ + +#if defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F072xB) || \ + defined (STM32F091xC) +/** @defgroup PWREx_PVD_detection_level PWREx PVD detection level + * @{ + */ +#define PWR_PVDLEVEL_0 PWR_CR_PLS_LEV0 +#define PWR_PVDLEVEL_1 PWR_CR_PLS_LEV1 +#define PWR_PVDLEVEL_2 PWR_CR_PLS_LEV2 +#define PWR_PVDLEVEL_3 PWR_CR_PLS_LEV3 +#define PWR_PVDLEVEL_4 PWR_CR_PLS_LEV4 +#define PWR_PVDLEVEL_5 PWR_CR_PLS_LEV5 +#define PWR_PVDLEVEL_6 PWR_CR_PLS_LEV6 +#define PWR_PVDLEVEL_7 PWR_CR_PLS_LEV7 +#define IS_PWR_PVD_LEVEL(LEVEL) (((LEVEL) == PWR_PVDLEVEL_0) || ((LEVEL) == PWR_PVDLEVEL_1)|| \ + ((LEVEL) == PWR_PVDLEVEL_2) || ((LEVEL) == PWR_PVDLEVEL_3)|| \ + ((LEVEL) == PWR_PVDLEVEL_4) || ((LEVEL) == PWR_PVDLEVEL_5)|| \ + ((LEVEL) == PWR_PVDLEVEL_6) || ((LEVEL) == PWR_PVDLEVEL_7)) +/** + * @} + */ + +/** @defgroup PWREx_PVD_Mode PWREx PVD Mode + * @{ + */ +#define PWR_PVD_MODE_NORMAL (0x00000000U) /*!< basic mode is used */ +#define PWR_PVD_MODE_IT_RISING (0x00010001U) /*!< External Interrupt Mode with Rising edge trigger detection */ +#define PWR_PVD_MODE_IT_FALLING (0x00010002U) /*!< External Interrupt Mode with Falling edge trigger detection */ +#define PWR_PVD_MODE_IT_RISING_FALLING (0x00010003U) /*!< External Interrupt Mode with Rising/Falling edge trigger detection */ +#define PWR_PVD_MODE_EVENT_RISING (0x00020001U) /*!< Event Mode with Rising edge trigger detection */ +#define PWR_PVD_MODE_EVENT_FALLING (0x00020002U) /*!< Event Mode with Falling edge trigger detection */ +#define PWR_PVD_MODE_EVENT_RISING_FALLING (0x00020003U) /*!< Event Mode with Rising/Falling edge trigger detection */ + +#define IS_PWR_PVD_MODE(MODE) (((MODE) == PWR_PVD_MODE_IT_RISING)|| ((MODE) == PWR_PVD_MODE_IT_FALLING) || \ + ((MODE) == PWR_PVD_MODE_IT_RISING_FALLING) || ((MODE) == PWR_PVD_MODE_EVENT_RISING) || \ + ((MODE) == PWR_PVD_MODE_EVENT_FALLING) || ((MODE) == PWR_PVD_MODE_EVENT_RISING_FALLING) || \ + ((MODE) == PWR_PVD_MODE_NORMAL)) +/** + * @} + */ +#endif /* defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F072xB) || */ + /* defined (STM32F091xC) */ + +/** @defgroup PWREx_Flag PWREx Flag + * @{ + */ +#if defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F072xB) || \ + defined (STM32F091xC) + +#define PWR_FLAG_WU PWR_CSR_WUF +#define PWR_FLAG_SB PWR_CSR_SBF +#define PWR_FLAG_PVDO PWR_CSR_PVDO +#define PWR_FLAG_VREFINTRDY PWR_CSR_VREFINTRDYF +#elif defined (STM32F070x6) || defined (STM32F070xB) || defined (STM32F030xC) +#define PWR_FLAG_WU PWR_CSR_WUF +#define PWR_FLAG_SB PWR_CSR_SBF +#define PWR_FLAG_VREFINTRDY PWR_CSR_VREFINTRDYF +#else +#define PWR_FLAG_WU PWR_CSR_WUF +#define PWR_FLAG_SB PWR_CSR_SBF + +#endif /* defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F072xB) || */ + /* defined (STM32F091xC) */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup PWREx_Exported_Macros PWREx Exported Macros + * @{ + */ +#if defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F072xB) || \ + defined (STM32F091xC) +/** + * @brief Enable interrupt on PVD Exti Line 16. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_ENABLE_IT() (EXTI->IMR |= (PWR_EXTI_LINE_PVD)) + +/** + * @brief Disable interrupt on PVD Exti Line 16. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_DISABLE_IT() (EXTI->IMR &= ~(PWR_EXTI_LINE_PVD)) + +/** + * @brief Enable event on PVD Exti Line 16. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_ENABLE_EVENT() (EXTI->EMR |= (PWR_EXTI_LINE_PVD)) + +/** + * @brief Disable event on PVD Exti Line 16. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_DISABLE_EVENT() (EXTI->EMR &= ~(PWR_EXTI_LINE_PVD)) + +/** + * @brief Disable the PVD Extended Interrupt Rising Trigger. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_DISABLE_RISING_EDGE() CLEAR_BIT(EXTI->RTSR, PWR_EXTI_LINE_PVD) + +/** + * @brief Disable the PVD Extended Interrupt Falling Trigger. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_DISABLE_FALLING_EDGE() CLEAR_BIT(EXTI->FTSR, PWR_EXTI_LINE_PVD) + +/** + * @brief Disable the PVD Extended Interrupt Rising & Falling Trigger. + * @retval None + */ +#define __HAL_PWR_PVD_EXTI_DISABLE_RISING_FALLING_EDGE() __HAL_PWR_PVD_EXTI_DISABLE_RISING_EDGE();__HAL_PWR_PVD_EXTI_DISABLE_FALLING_EDGE(); + + +/** + * @brief PVD EXTI line configuration: set falling edge trigger. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_ENABLE_FALLING_EDGE() EXTI->FTSR |= (PWR_EXTI_LINE_PVD) + +/** + * @brief PVD EXTI line configuration: set rising edge trigger. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_ENABLE_RISING_EDGE() EXTI->RTSR |= (PWR_EXTI_LINE_PVD) + +/** + * @brief Enable the PVD Extended Interrupt Rising & Falling Trigger. + * @retval None + */ +#define __HAL_PWR_PVD_EXTI_ENABLE_RISING_FALLING_EDGE() __HAL_PWR_PVD_EXTI_ENABLE_RISING_EDGE();__HAL_PWR_PVD_EXTI_ENABLE_FALLING_EDGE(); + +/** + * @brief Check whether the specified PVD EXTI interrupt flag is set or not. + * @retval EXTI PVD Line Status. + */ +#define __HAL_PWR_PVD_EXTI_GET_FLAG() (EXTI->PR & (PWR_EXTI_LINE_PVD)) + +/** + * @brief Clear the PVD EXTI flag. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_CLEAR_FLAG() (EXTI->PR = (PWR_EXTI_LINE_PVD)) + +/** + * @brief Generate a Software interrupt on selected EXTI line. + * @retval None. + */ +#define __HAL_PWR_PVD_EXTI_GENERATE_SWIT() (EXTI->SWIER |= (PWR_EXTI_LINE_PVD)) + +#endif /* defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F072xB) || */ + /* defined (STM32F091xC) */ + + +#if defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) +/** + * @brief Enable interrupt on Vddio2 Monitor Exti Line 31. + * @retval None. + */ +#define __HAL_PWR_VDDIO2_EXTI_ENABLE_IT() (EXTI->IMR |= (PWR_EXTI_LINE_VDDIO2)) + +/** + * @brief Disable interrupt on Vddio2 Monitor Exti Line 31. + * @retval None. + */ +#define __HAL_PWR_VDDIO2_EXTI_DISABLE_IT() (EXTI->IMR &= ~(PWR_EXTI_LINE_VDDIO2)) + +/** + * @brief Vddio2 Monitor EXTI line configuration: clear falling edge and rising edge trigger. + * @retval None. + */ +#define __HAL_PWR_VDDIO2_EXTI_DISABLE_FALLING_EDGE() \ + do{ \ + EXTI->FTSR &= ~(PWR_EXTI_LINE_VDDIO2); \ + EXTI->RTSR &= ~(PWR_EXTI_LINE_VDDIO2); \ + } while(0) + +/** + * @brief Vddio2 Monitor EXTI line configuration: set falling edge trigger. + * @retval None. + */ +#define __HAL_PWR_VDDIO2_EXTI_ENABLE_FALLING_EDGE() EXTI->FTSR |= (PWR_EXTI_LINE_VDDIO2) + +/** + * @brief Check whether the specified VDDIO2 monitor EXTI interrupt flag is set or not. + * @retval EXTI VDDIO2 Monitor Line Status. + */ +#define __HAL_PWR_VDDIO2_EXTI_GET_FLAG() (EXTI->PR & (PWR_EXTI_LINE_VDDIO2)) + +/** + * @brief Clear the VDDIO2 Monitor EXTI flag. + * @retval None. + */ +#define __HAL_PWR_VDDIO2_EXTI_CLEAR_FLAG() (EXTI->PR = (PWR_EXTI_LINE_VDDIO2)) + +/** + * @brief Generate a Software interrupt on selected EXTI line. + * @retval None. + */ +#define __HAL_PWR_VDDIO2_EXTI_GENERATE_SWIT() (EXTI->SWIER |= (PWR_EXTI_LINE_VDDIO2)) + + +#endif /* defined (STM32F042x6) || defined (STM32F048xx) ||\ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup PWREx_Exported_Functions PWREx Exported Functions + * @{ + */ + +/** @addtogroup PWREx_Exported_Functions_Group1 + * @{ + */ +/* I/O operation functions ***************************************************/ +#if defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F072xB) || \ + defined (STM32F091xC) +void HAL_PWR_PVD_IRQHandler(void); +void HAL_PWR_PVDCallback(void); +#endif /* defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F072xB) || */ + /* defined (STM32F091xC) */ + +#if defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) +void HAL_PWREx_Vddio2Monitor_IRQHandler(void); +void HAL_PWREx_Vddio2MonitorCallback(void); +#endif /* defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) */ + +/* Peripheral Control functions **********************************************/ +#if defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F072xB) || \ + defined (STM32F091xC) +void HAL_PWR_ConfigPVD(PWR_PVDTypeDef *sConfigPVD); +void HAL_PWR_EnablePVD(void); +void HAL_PWR_DisablePVD(void); +#endif /* defined (STM32F031x6) || defined (STM32F042x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F072xB) || */ + /* defined (STM32F091xC) */ + +#if defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) +void HAL_PWREx_EnableVddio2Monitor(void); +void HAL_PWREx_DisableVddio2Monitor(void); +#endif /* defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_PWR_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc.h new file mode 100644 index 0000000..4239c51 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc.h @@ -0,0 +1,1686 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rcc.h + * @author MCD Application Team + * @brief Header file of RCC HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_RCC_H +#define __STM32F0xx_HAL_RCC_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup RCC + * @{ + */ + +/** @addtogroup RCC_Private_Constants + * @{ + */ + +/** @defgroup RCC_Timeout RCC Timeout + * @{ + */ + +/* Disable Backup domain write protection state change timeout */ +#define RCC_DBP_TIMEOUT_VALUE (100U) /* 100 ms */ +/* LSE state change timeout */ +#define RCC_LSE_TIMEOUT_VALUE LSE_STARTUP_TIMEOUT +#define CLOCKSWITCH_TIMEOUT_VALUE (5000U) /* 5 s */ +#define HSE_TIMEOUT_VALUE HSE_STARTUP_TIMEOUT +#define HSI_TIMEOUT_VALUE (2U) /* 2 ms (minimum Tick + 1U) */ +#define LSI_TIMEOUT_VALUE (2U) /* 2 ms (minimum Tick + 1U) */ +#define PLL_TIMEOUT_VALUE (2U) /* 2 ms (minimum Tick + 1U) */ +#define HSI14_TIMEOUT_VALUE (2U) /* 2 ms (minimum Tick + 1U) */ +#if defined(RCC_HSI48_SUPPORT) +#define HSI48_TIMEOUT_VALUE (2U) /* 2 ms (minimum Tick + 1U) */ +#endif /* RCC_HSI48_SUPPORT */ +/** + * @} + */ + +/** @defgroup RCC_Register_Offset Register offsets + * @{ + */ +#define RCC_OFFSET (RCC_BASE - PERIPH_BASE) +#define RCC_CR_OFFSET 0x00 +#define RCC_CFGR_OFFSET 0x04 +#define RCC_CIR_OFFSET 0x08 +#define RCC_BDCR_OFFSET 0x20 +#define RCC_CSR_OFFSET 0x24 + +/** + * @} + */ + + +/* CR register byte 2 (Bits[23:16]) base address */ +#define RCC_CR_BYTE2_ADDRESS ((uint32_t)(RCC_BASE + RCC_CR_OFFSET + 0x02U)) + +/* CIR register byte 1 (Bits[15:8]) base address */ +#define RCC_CIR_BYTE1_ADDRESS ((uint32_t)(RCC_BASE + RCC_CIR_OFFSET + 0x01U)) + +/* CIR register byte 2 (Bits[23:16]) base address */ +#define RCC_CIR_BYTE2_ADDRESS ((uint32_t)(RCC_BASE + RCC_CIR_OFFSET + 0x02U)) + +/* Defines used for Flags */ +#define CR_REG_INDEX ((uint8_t)1U) +#define CR2_REG_INDEX ((uint8_t)2U) +#define BDCR_REG_INDEX ((uint8_t)3U) +#define CSR_REG_INDEX ((uint8_t)4U) + +/* Bits position in in the CFGR register */ +#define RCC_CFGR_PLLMUL_BITNUMBER 18U +#define RCC_CFGR_HPRE_BITNUMBER 4U +#define RCC_CFGR_PPRE_BITNUMBER 8U +/* Flags in the CFGR2 register */ +#define RCC_CFGR2_PREDIV_BITNUMBER 0 +/* Flags in the CR register */ +#define RCC_CR_HSIRDY_BitNumber 1 +#define RCC_CR_HSERDY_BitNumber 17 +#define RCC_CR_PLLRDY_BitNumber 25 +/* Flags in the CR2 register */ +#define RCC_CR2_HSI14RDY_BitNumber 1 +#define RCC_CR2_HSI48RDY_BitNumber 16 +/* Flags in the BDCR register */ +#define RCC_BDCR_LSERDY_BitNumber 1 +/* Flags in the CSR register */ +#define RCC_CSR_LSIRDY_BitNumber 1 +#define RCC_CSR_V18PWRRSTF_BitNumber 23 +#define RCC_CSR_RMVF_BitNumber 24 +#define RCC_CSR_OBLRSTF_BitNumber 25 +#define RCC_CSR_PINRSTF_BitNumber 26 +#define RCC_CSR_PORRSTF_BitNumber 27 +#define RCC_CSR_SFTRSTF_BitNumber 28 +#define RCC_CSR_IWDGRSTF_BitNumber 29 +#define RCC_CSR_WWDGRSTF_BitNumber 30 +#define RCC_CSR_LPWRRSTF_BitNumber 31 +/* Flags in the HSITRIM register */ +#define RCC_CR_HSITRIM_BitNumber 3 +#define RCC_HSI14TRIM_BIT_NUMBER 3 +#define RCC_FLAG_MASK ((uint8_t)0x1FU) + +/** + * @} + */ + +/** @addtogroup RCC_Private_Macros + * @{ + */ +#define IS_RCC_HSE(__HSE__) (((__HSE__) == RCC_HSE_OFF) || ((__HSE__) == RCC_HSE_ON) || \ + ((__HSE__) == RCC_HSE_BYPASS)) +#define IS_RCC_LSE(__LSE__) (((__LSE__) == RCC_LSE_OFF) || ((__LSE__) == RCC_LSE_ON) || \ + ((__LSE__) == RCC_LSE_BYPASS)) +#define IS_RCC_HSI(__HSI__) (((__HSI__) == RCC_HSI_OFF) || ((__HSI__) == RCC_HSI_ON)) +#define IS_RCC_HSI14(__HSI14__) (((__HSI14__) == RCC_HSI14_OFF) || ((__HSI14__) == RCC_HSI14_ON) || ((__HSI14__) == RCC_HSI14_ADC_CONTROL)) +#define IS_RCC_CALIBRATION_VALUE(__VALUE__) ((__VALUE__) <= 0x1FU) +#define IS_RCC_LSI(__LSI__) (((__LSI__) == RCC_LSI_OFF) || ((__LSI__) == RCC_LSI_ON)) +#define IS_RCC_PLL(__PLL__) (((__PLL__) == RCC_PLL_NONE) || ((__PLL__) == RCC_PLL_OFF) || \ + ((__PLL__) == RCC_PLL_ON)) +#define IS_RCC_PREDIV(__PREDIV__) (((__PREDIV__) == RCC_PREDIV_DIV1) || ((__PREDIV__) == RCC_PREDIV_DIV2) || \ + ((__PREDIV__) == RCC_PREDIV_DIV3) || ((__PREDIV__) == RCC_PREDIV_DIV4) || \ + ((__PREDIV__) == RCC_PREDIV_DIV5) || ((__PREDIV__) == RCC_PREDIV_DIV6) || \ + ((__PREDIV__) == RCC_PREDIV_DIV7) || ((__PREDIV__) == RCC_PREDIV_DIV8) || \ + ((__PREDIV__) == RCC_PREDIV_DIV9) || ((__PREDIV__) == RCC_PREDIV_DIV10) || \ + ((__PREDIV__) == RCC_PREDIV_DIV11) || ((__PREDIV__) == RCC_PREDIV_DIV12) || \ + ((__PREDIV__) == RCC_PREDIV_DIV13) || ((__PREDIV__) == RCC_PREDIV_DIV14) || \ + ((__PREDIV__) == RCC_PREDIV_DIV15) || ((__PREDIV__) == RCC_PREDIV_DIV16)) + +#define IS_RCC_PLL_MUL(__MUL__) (((__MUL__) == RCC_PLL_MUL2) || ((__MUL__) == RCC_PLL_MUL3) || \ + ((__MUL__) == RCC_PLL_MUL4) || ((__MUL__) == RCC_PLL_MUL5) || \ + ((__MUL__) == RCC_PLL_MUL6) || ((__MUL__) == RCC_PLL_MUL7) || \ + ((__MUL__) == RCC_PLL_MUL8) || ((__MUL__) == RCC_PLL_MUL9) || \ + ((__MUL__) == RCC_PLL_MUL10) || ((__MUL__) == RCC_PLL_MUL11) || \ + ((__MUL__) == RCC_PLL_MUL12) || ((__MUL__) == RCC_PLL_MUL13) || \ + ((__MUL__) == RCC_PLL_MUL14) || ((__MUL__) == RCC_PLL_MUL15) || \ + ((__MUL__) == RCC_PLL_MUL16)) +#define IS_RCC_CLOCKTYPE(__CLK__) ((((__CLK__) & RCC_CLOCKTYPE_SYSCLK) == RCC_CLOCKTYPE_SYSCLK) || \ + (((__CLK__) & RCC_CLOCKTYPE_HCLK) == RCC_CLOCKTYPE_HCLK) || \ + (((__CLK__) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1)) +#define IS_RCC_HCLK(__HCLK__) (((__HCLK__) == RCC_SYSCLK_DIV1) || ((__HCLK__) == RCC_SYSCLK_DIV2) || \ + ((__HCLK__) == RCC_SYSCLK_DIV4) || ((__HCLK__) == RCC_SYSCLK_DIV8) || \ + ((__HCLK__) == RCC_SYSCLK_DIV16) || ((__HCLK__) == RCC_SYSCLK_DIV64) || \ + ((__HCLK__) == RCC_SYSCLK_DIV128) || ((__HCLK__) == RCC_SYSCLK_DIV256) || \ + ((__HCLK__) == RCC_SYSCLK_DIV512)) +#define IS_RCC_PCLK(__PCLK__) (((__PCLK__) == RCC_HCLK_DIV1) || ((__PCLK__) == RCC_HCLK_DIV2) || \ + ((__PCLK__) == RCC_HCLK_DIV4) || ((__PCLK__) == RCC_HCLK_DIV8) || \ + ((__PCLK__) == RCC_HCLK_DIV16)) +#define IS_RCC_MCO(__MCO__) ((__MCO__) == RCC_MCO) +#define IS_RCC_RTCCLKSOURCE(__SOURCE__) (((__SOURCE__) == RCC_RTCCLKSOURCE_NO_CLK) || \ + ((__SOURCE__) == RCC_RTCCLKSOURCE_LSE) || \ + ((__SOURCE__) == RCC_RTCCLKSOURCE_LSI) || \ + ((__SOURCE__) == RCC_RTCCLKSOURCE_HSE_DIV32)) +#define IS_RCC_USART1CLKSOURCE(__SOURCE__) (((__SOURCE__) == RCC_USART1CLKSOURCE_PCLK1) || \ + ((__SOURCE__) == RCC_USART1CLKSOURCE_SYSCLK) || \ + ((__SOURCE__) == RCC_USART1CLKSOURCE_LSE) || \ + ((__SOURCE__) == RCC_USART1CLKSOURCE_HSI)) +#define IS_RCC_I2C1CLKSOURCE(__SOURCE__) (((__SOURCE__) == RCC_I2C1CLKSOURCE_HSI) || \ + ((__SOURCE__) == RCC_I2C1CLKSOURCE_SYSCLK)) + +/** + * @} + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup RCC_Exported_Types RCC Exported Types + * @{ + */ + +/** + * @brief RCC PLL configuration structure definition + */ +typedef struct +{ + uint32_t PLLState; /*!< PLLState: The new state of the PLL. + This parameter can be a value of @ref RCC_PLL_Config */ + + uint32_t PLLSource; /*!< PLLSource: PLL entry clock source. + This parameter must be a value of @ref RCC_PLL_Clock_Source */ + + uint32_t PLLMUL; /*!< PLLMUL: Multiplication factor for PLL VCO input clock + This parameter must be a value of @ref RCC_PLL_Multiplication_Factor*/ + + uint32_t PREDIV; /*!< PREDIV: Predivision factor for PLL VCO input clock + This parameter must be a value of @ref RCC_PLL_Prediv_Factor */ + +} RCC_PLLInitTypeDef; + +/** + * @brief RCC Internal/External Oscillator (HSE, HSI, LSE and LSI) configuration structure definition + */ +typedef struct +{ + uint32_t OscillatorType; /*!< The oscillators to be configured. + This parameter can be a value of @ref RCC_Oscillator_Type */ + + uint32_t HSEState; /*!< The new state of the HSE. + This parameter can be a value of @ref RCC_HSE_Config */ + + uint32_t LSEState; /*!< The new state of the LSE. + This parameter can be a value of @ref RCC_LSE_Config */ + + uint32_t HSIState; /*!< The new state of the HSI. + This parameter can be a value of @ref RCC_HSI_Config */ + + uint32_t HSICalibrationValue; /*!< The HSI calibration trimming value (default is RCC_HSICALIBRATION_DEFAULT). + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x1FU */ + + uint32_t HSI14State; /*!< The new state of the HSI14. + This parameter can be a value of @ref RCC_HSI14_Config */ + + uint32_t HSI14CalibrationValue; /*!< The HSI14 calibration trimming value (default is RCC_HSI14CALIBRATION_DEFAULT). + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x1FU */ + + uint32_t LSIState; /*!< The new state of the LSI. + This parameter can be a value of @ref RCC_LSI_Config */ + +#if defined(RCC_HSI48_SUPPORT) + uint32_t HSI48State; /*!< The new state of the HSI48. + This parameter can be a value of @ref RCC_HSI48_Config */ + +#endif /* RCC_HSI48_SUPPORT */ + RCC_PLLInitTypeDef PLL; /*!< PLL structure parameters */ + +} RCC_OscInitTypeDef; + +/** + * @brief RCC System, AHB and APB busses clock configuration structure definition + */ +typedef struct +{ + uint32_t ClockType; /*!< The clock to be configured. + This parameter can be a value of @ref RCC_System_Clock_Type */ + + uint32_t SYSCLKSource; /*!< The clock source (SYSCLKS) used as system clock. + This parameter can be a value of @ref RCC_System_Clock_Source */ + + uint32_t AHBCLKDivider; /*!< The AHB clock (HCLK) divider. This clock is derived from the system clock (SYSCLK). + This parameter can be a value of @ref RCC_AHB_Clock_Source */ + + uint32_t APB1CLKDivider; /*!< The APB1 clock (PCLK1) divider. This clock is derived from the AHB clock (HCLK). + This parameter can be a value of @ref RCC_APB1_Clock_Source */ + +} RCC_ClkInitTypeDef; + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup RCC_Exported_Constants RCC Exported Constants + * @{ + */ + +/** @defgroup RCC_PLL_Clock_Source PLL Clock Source + * @{ + */ + +#define RCC_PLLSOURCE_HSE RCC_CFGR_PLLSRC_HSE_PREDIV /*!< HSE clock selected as PLL entry clock source */ + +/** + * @} + */ + +/** @defgroup RCC_Oscillator_Type Oscillator Type + * @{ + */ +#define RCC_OSCILLATORTYPE_NONE (0x00000000U) +#define RCC_OSCILLATORTYPE_HSE (0x00000001U) +#define RCC_OSCILLATORTYPE_HSI (0x00000002U) +#define RCC_OSCILLATORTYPE_LSE (0x00000004U) +#define RCC_OSCILLATORTYPE_LSI (0x00000008U) +#define RCC_OSCILLATORTYPE_HSI14 (0x00000010U) +#if defined(RCC_HSI48_SUPPORT) +#define RCC_OSCILLATORTYPE_HSI48 (0x00000020U) +#endif /* RCC_HSI48_SUPPORT */ +/** + * @} + */ + +/** @defgroup RCC_HSE_Config HSE Config + * @{ + */ +#define RCC_HSE_OFF (0x00000000U) /*!< HSE clock deactivation */ +#define RCC_HSE_ON (0x00000001U) /*!< HSE clock activation */ +#define RCC_HSE_BYPASS (0x00000005U) /*!< External clock source for HSE clock */ +/** + * @} + */ + +/** @defgroup RCC_LSE_Config LSE Config + * @{ + */ +#define RCC_LSE_OFF (0x00000000U) /*!< LSE clock deactivation */ +#define RCC_LSE_ON (0x00000001U) /*!< LSE clock activation */ +#define RCC_LSE_BYPASS (0x00000005U) /*!< External clock source for LSE clock */ + +/** + * @} + */ + +/** @defgroup RCC_HSI_Config HSI Config + * @{ + */ +#define RCC_HSI_OFF (0x00000000U) /*!< HSI clock deactivation */ +#define RCC_HSI_ON RCC_CR_HSION /*!< HSI clock activation */ + +#define RCC_HSICALIBRATION_DEFAULT (0x10U) /* Default HSI calibration trimming value */ + +/** + * @} + */ + +/** @defgroup RCC_HSI14_Config RCC HSI14 Config + * @{ + */ +#define RCC_HSI14_OFF (0x00000000U) +#define RCC_HSI14_ON RCC_CR2_HSI14ON +#define RCC_HSI14_ADC_CONTROL (~RCC_CR2_HSI14DIS) + +#define RCC_HSI14CALIBRATION_DEFAULT (0x10U) /* Default HSI14 calibration trimming value */ +/** + * @} + */ + +/** @defgroup RCC_LSI_Config LSI Config + * @{ + */ +#define RCC_LSI_OFF (0x00000000U) /*!< LSI clock deactivation */ +#define RCC_LSI_ON RCC_CSR_LSION /*!< LSI clock activation */ + +/** + * @} + */ + +#if defined(RCC_HSI48_SUPPORT) +/** @defgroup RCC_HSI48_Config HSI48 Config + * @{ + */ +#define RCC_HSI48_OFF ((uint8_t)0x00U) +#define RCC_HSI48_ON ((uint8_t)0x01U) + +/** + * @} + */ +#endif /* RCC_HSI48_SUPPORT */ + +/** @defgroup RCC_PLL_Config PLL Config + * @{ + */ +#define RCC_PLL_NONE (0x00000000U) /*!< PLL is not configured */ +#define RCC_PLL_OFF (0x00000001U) /*!< PLL deactivation */ +#define RCC_PLL_ON (0x00000002U) /*!< PLL activation */ + +/** + * @} + */ + +/** @defgroup RCC_System_Clock_Type System Clock Type + * @{ + */ +#define RCC_CLOCKTYPE_SYSCLK (0x00000001U) /*!< SYSCLK to configure */ +#define RCC_CLOCKTYPE_HCLK (0x00000002U) /*!< HCLK to configure */ +#define RCC_CLOCKTYPE_PCLK1 (0x00000004U) /*!< PCLK1 to configure */ + +/** + * @} + */ + +/** @defgroup RCC_System_Clock_Source System Clock Source + * @{ + */ +#define RCC_SYSCLKSOURCE_HSI RCC_CFGR_SW_HSI /*!< HSI selected as system clock */ +#define RCC_SYSCLKSOURCE_HSE RCC_CFGR_SW_HSE /*!< HSE selected as system clock */ +#define RCC_SYSCLKSOURCE_PLLCLK RCC_CFGR_SW_PLL /*!< PLL selected as system clock */ + +/** + * @} + */ + +/** @defgroup RCC_System_Clock_Source_Status System Clock Source Status + * @{ + */ +#define RCC_SYSCLKSOURCE_STATUS_HSI RCC_CFGR_SWS_HSI /*!< HSI used as system clock */ +#define RCC_SYSCLKSOURCE_STATUS_HSE RCC_CFGR_SWS_HSE /*!< HSE used as system clock */ +#define RCC_SYSCLKSOURCE_STATUS_PLLCLK RCC_CFGR_SWS_PLL /*!< PLL used as system clock */ + +/** + * @} + */ + +/** @defgroup RCC_AHB_Clock_Source AHB Clock Source + * @{ + */ +#define RCC_SYSCLK_DIV1 RCC_CFGR_HPRE_DIV1 /*!< SYSCLK not divided */ +#define RCC_SYSCLK_DIV2 RCC_CFGR_HPRE_DIV2 /*!< SYSCLK divided by 2 */ +#define RCC_SYSCLK_DIV4 RCC_CFGR_HPRE_DIV4 /*!< SYSCLK divided by 4 */ +#define RCC_SYSCLK_DIV8 RCC_CFGR_HPRE_DIV8 /*!< SYSCLK divided by 8 */ +#define RCC_SYSCLK_DIV16 RCC_CFGR_HPRE_DIV16 /*!< SYSCLK divided by 16 */ +#define RCC_SYSCLK_DIV64 RCC_CFGR_HPRE_DIV64 /*!< SYSCLK divided by 64 */ +#define RCC_SYSCLK_DIV128 RCC_CFGR_HPRE_DIV128 /*!< SYSCLK divided by 128 */ +#define RCC_SYSCLK_DIV256 RCC_CFGR_HPRE_DIV256 /*!< SYSCLK divided by 256 */ +#define RCC_SYSCLK_DIV512 RCC_CFGR_HPRE_DIV512 /*!< SYSCLK divided by 512 */ + +/** + * @} + */ + +/** @defgroup RCC_APB1_Clock_Source RCC APB1 Clock Source + * @{ + */ +#define RCC_HCLK_DIV1 RCC_CFGR_PPRE_DIV1 /*!< HCLK not divided */ +#define RCC_HCLK_DIV2 RCC_CFGR_PPRE_DIV2 /*!< HCLK divided by 2 */ +#define RCC_HCLK_DIV4 RCC_CFGR_PPRE_DIV4 /*!< HCLK divided by 4 */ +#define RCC_HCLK_DIV8 RCC_CFGR_PPRE_DIV8 /*!< HCLK divided by 8 */ +#define RCC_HCLK_DIV16 RCC_CFGR_PPRE_DIV16 /*!< HCLK divided by 16 */ + +/** + * @} + */ + +/** @defgroup RCC_RTC_Clock_Source RTC Clock Source + * @{ + */ +#define RCC_RTCCLKSOURCE_NO_CLK (0x00000000U) /*!< No clock */ +#define RCC_RTCCLKSOURCE_LSE RCC_BDCR_RTCSEL_LSE /*!< LSE oscillator clock used as RTC clock */ +#define RCC_RTCCLKSOURCE_LSI RCC_BDCR_RTCSEL_LSI /*!< LSI oscillator clock used as RTC clock */ +#define RCC_RTCCLKSOURCE_HSE_DIV32 RCC_BDCR_RTCSEL_HSE /*!< HSE oscillator clock divided by 32 used as RTC clock */ +/** + * @} + */ + +/** @defgroup RCC_PLL_Multiplication_Factor RCC PLL Multiplication Factor + * @{ + */ +#define RCC_PLL_MUL2 RCC_CFGR_PLLMUL2 +#define RCC_PLL_MUL3 RCC_CFGR_PLLMUL3 +#define RCC_PLL_MUL4 RCC_CFGR_PLLMUL4 +#define RCC_PLL_MUL5 RCC_CFGR_PLLMUL5 +#define RCC_PLL_MUL6 RCC_CFGR_PLLMUL6 +#define RCC_PLL_MUL7 RCC_CFGR_PLLMUL7 +#define RCC_PLL_MUL8 RCC_CFGR_PLLMUL8 +#define RCC_PLL_MUL9 RCC_CFGR_PLLMUL9 +#define RCC_PLL_MUL10 RCC_CFGR_PLLMUL10 +#define RCC_PLL_MUL11 RCC_CFGR_PLLMUL11 +#define RCC_PLL_MUL12 RCC_CFGR_PLLMUL12 +#define RCC_PLL_MUL13 RCC_CFGR_PLLMUL13 +#define RCC_PLL_MUL14 RCC_CFGR_PLLMUL14 +#define RCC_PLL_MUL15 RCC_CFGR_PLLMUL15 +#define RCC_PLL_MUL16 RCC_CFGR_PLLMUL16 + +/** + * @} + */ + +/** @defgroup RCC_PLL_Prediv_Factor RCC PLL Prediv Factor + * @{ + */ + +#define RCC_PREDIV_DIV1 RCC_CFGR2_PREDIV_DIV1 +#define RCC_PREDIV_DIV2 RCC_CFGR2_PREDIV_DIV2 +#define RCC_PREDIV_DIV3 RCC_CFGR2_PREDIV_DIV3 +#define RCC_PREDIV_DIV4 RCC_CFGR2_PREDIV_DIV4 +#define RCC_PREDIV_DIV5 RCC_CFGR2_PREDIV_DIV5 +#define RCC_PREDIV_DIV6 RCC_CFGR2_PREDIV_DIV6 +#define RCC_PREDIV_DIV7 RCC_CFGR2_PREDIV_DIV7 +#define RCC_PREDIV_DIV8 RCC_CFGR2_PREDIV_DIV8 +#define RCC_PREDIV_DIV9 RCC_CFGR2_PREDIV_DIV9 +#define RCC_PREDIV_DIV10 RCC_CFGR2_PREDIV_DIV10 +#define RCC_PREDIV_DIV11 RCC_CFGR2_PREDIV_DIV11 +#define RCC_PREDIV_DIV12 RCC_CFGR2_PREDIV_DIV12 +#define RCC_PREDIV_DIV13 RCC_CFGR2_PREDIV_DIV13 +#define RCC_PREDIV_DIV14 RCC_CFGR2_PREDIV_DIV14 +#define RCC_PREDIV_DIV15 RCC_CFGR2_PREDIV_DIV15 +#define RCC_PREDIV_DIV16 RCC_CFGR2_PREDIV_DIV16 + +/** + * @} + */ + + +/** @defgroup RCC_USART1_Clock_Source RCC USART1 Clock Source + * @{ + */ +#define RCC_USART1CLKSOURCE_PCLK1 RCC_CFGR3_USART1SW_PCLK +#define RCC_USART1CLKSOURCE_SYSCLK RCC_CFGR3_USART1SW_SYSCLK +#define RCC_USART1CLKSOURCE_LSE RCC_CFGR3_USART1SW_LSE +#define RCC_USART1CLKSOURCE_HSI RCC_CFGR3_USART1SW_HSI + +/** + * @} + */ + +/** @defgroup RCC_I2C1_Clock_Source RCC I2C1 Clock Source + * @{ + */ +#define RCC_I2C1CLKSOURCE_HSI RCC_CFGR3_I2C1SW_HSI +#define RCC_I2C1CLKSOURCE_SYSCLK RCC_CFGR3_I2C1SW_SYSCLK + +/** + * @} + */ +/** @defgroup RCC_MCO_Index MCO Index + * @{ + */ +#define RCC_MCO1 (0x00000000U) +#define RCC_MCO RCC_MCO1 /*!< MCO1 to be compliant with other families with 2 MCOs*/ + +/** + * @} + */ + +/** @defgroup RCC_MCO_Clock_Source RCC MCO Clock Source + * @{ + */ +#define RCC_MCO1SOURCE_NOCLOCK RCC_CFGR_MCO_NOCLOCK +#define RCC_MCO1SOURCE_LSI RCC_CFGR_MCO_LSI +#define RCC_MCO1SOURCE_LSE RCC_CFGR_MCO_LSE +#define RCC_MCO1SOURCE_SYSCLK RCC_CFGR_MCO_SYSCLK +#define RCC_MCO1SOURCE_HSI RCC_CFGR_MCO_HSI +#define RCC_MCO1SOURCE_HSE RCC_CFGR_MCO_HSE +#define RCC_MCO1SOURCE_PLLCLK_DIV2 RCC_CFGR_MCO_PLL +#define RCC_MCO1SOURCE_HSI14 RCC_CFGR_MCO_HSI14 + +/** + * @} + */ + +/** @defgroup RCC_Interrupt Interrupts + * @{ + */ +#define RCC_IT_LSIRDY ((uint8_t)RCC_CIR_LSIRDYF) /*!< LSI Ready Interrupt flag */ +#define RCC_IT_LSERDY ((uint8_t)RCC_CIR_LSERDYF) /*!< LSE Ready Interrupt flag */ +#define RCC_IT_HSIRDY ((uint8_t)RCC_CIR_HSIRDYF) /*!< HSI Ready Interrupt flag */ +#define RCC_IT_HSERDY ((uint8_t)RCC_CIR_HSERDYF) /*!< HSE Ready Interrupt flag */ +#define RCC_IT_PLLRDY ((uint8_t)RCC_CIR_PLLRDYF) /*!< PLL Ready Interrupt flag */ +#define RCC_IT_HSI14RDY ((uint8_t)RCC_CIR_HSI14RDYF) /*!< HSI14 Ready Interrupt flag */ +#if defined(RCC_CIR_HSI48RDYF) +#define RCC_IT_HSI48RDY ((uint8_t)RCC_CIR_HSI48RDYF) /*!< HSI48 Ready Interrupt flag */ +#endif +#define RCC_IT_CSS ((uint8_t)RCC_CIR_CSSF) /*!< Clock Security System Interrupt flag */ +/** + * @} + */ + +/** @defgroup RCC_Flag Flags + * Elements values convention: XXXYYYYYb + * - YYYYY : Flag position in the register + * - XXX : Register index + * - 001: CR register + * - 010: CR2 register + * - 011: BDCR register + * - 0100: CSR register + * @{ + */ +/* Flags in the CR register */ +#define RCC_FLAG_HSIRDY ((uint8_t)((CR_REG_INDEX << 5U) | RCC_CR_HSIRDY_BitNumber)) +#define RCC_FLAG_HSERDY ((uint8_t)((CR_REG_INDEX << 5U) | RCC_CR_HSERDY_BitNumber)) +#define RCC_FLAG_PLLRDY ((uint8_t)((CR_REG_INDEX << 5U) | RCC_CR_PLLRDY_BitNumber)) +/* Flags in the CR2 register */ +#define RCC_FLAG_HSI14RDY ((uint8_t)((CR2_REG_INDEX << 5U) | RCC_CR2_HSI14RDY_BitNumber)) + +/* Flags in the CSR register */ +#define RCC_FLAG_LSIRDY ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_LSIRDY_BitNumber)) +#if defined(RCC_CSR_V18PWRRSTF) +#define RCC_FLAG_V18PWRRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_V18PWRRSTF_BitNumber)) +#endif +#define RCC_FLAG_OBLRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_OBLRSTF_BitNumber)) +#define RCC_FLAG_PINRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_PINRSTF_BitNumber)) /*!< PIN reset flag */ +#define RCC_FLAG_PORRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_PORRSTF_BitNumber)) /*!< POR/PDR reset flag */ +#define RCC_FLAG_SFTRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_SFTRSTF_BitNumber)) /*!< Software Reset flag */ +#define RCC_FLAG_IWDGRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_IWDGRSTF_BitNumber)) /*!< Independent Watchdog reset flag */ +#define RCC_FLAG_WWDGRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_WWDGRSTF_BitNumber)) /*!< Window watchdog reset flag */ +#define RCC_FLAG_LPWRRST ((uint8_t)((CSR_REG_INDEX << 5U) | RCC_CSR_LPWRRSTF_BitNumber)) /*!< Low-Power reset flag */ + +/* Flags in the BDCR register */ +#define RCC_FLAG_LSERDY ((uint8_t)((BDCR_REG_INDEX << 5U) | RCC_BDCR_LSERDY_BitNumber)) /*!< External Low Speed oscillator Ready */ + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ + +/** @defgroup RCC_Exported_Macros RCC Exported Macros + * @{ + */ + +/** @defgroup RCC_AHB_Clock_Enable_Disable RCC AHB Clock Enable Disable + * @brief Enable or disable the AHB peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +#define __HAL_RCC_GPIOA_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOAEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOAEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_GPIOB_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOBEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOBEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_GPIOC_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOCEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOCEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_GPIOF_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOFEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOFEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_CRC_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_CRCEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_CRCEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_DMA1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_DMA1EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_DMA1EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_SRAM_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_SRAMEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_SRAMEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_FLITF_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_FLITFEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_FLITFEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_GPIOA_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOAEN)) +#define __HAL_RCC_GPIOB_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOBEN)) +#define __HAL_RCC_GPIOC_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOCEN)) +#define __HAL_RCC_GPIOF_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOFEN)) +#define __HAL_RCC_CRC_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_CRCEN)) +#define __HAL_RCC_DMA1_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_DMA1EN)) +#define __HAL_RCC_SRAM_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_SRAMEN)) +#define __HAL_RCC_FLITF_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_FLITFEN)) +/** + * @} + */ + +/** @defgroup RCC_AHB_Peripheral_Clock_Enable_Disable_Status AHB Peripheral Clock Enable Disable Status + * @brief Get the enable or disable status of the AHB peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +#define __HAL_RCC_GPIOA_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOAEN)) != RESET) +#define __HAL_RCC_GPIOB_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOBEN)) != RESET) +#define __HAL_RCC_GPIOC_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOCEN)) != RESET) +#define __HAL_RCC_GPIOF_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOFEN)) != RESET) +#define __HAL_RCC_CRC_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_CRCEN)) != RESET) +#define __HAL_RCC_DMA1_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA1EN)) != RESET) +#define __HAL_RCC_SRAM_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_SRAMEN)) != RESET) +#define __HAL_RCC_FLITF_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_FLITFEN)) != RESET) +#define __HAL_RCC_GPIOA_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOAEN)) == RESET) +#define __HAL_RCC_GPIOB_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOBEN)) == RESET) +#define __HAL_RCC_GPIOC_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOCEN)) == RESET) +#define __HAL_RCC_GPIOF_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOFEN)) == RESET) +#define __HAL_RCC_CRC_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_CRCEN)) == RESET) +#define __HAL_RCC_DMA1_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA1EN)) == RESET) +#define __HAL_RCC_SRAM_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_SRAMEN)) == RESET) +#define __HAL_RCC_FLITF_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_FLITFEN)) == RESET) +/** + * @} + */ + +/** @defgroup RCC_APB1_Clock_Enable_Disable RCC APB1 Clock Enable Disable + * @brief Enable or disable the Low Speed APB (APB1) peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +#define __HAL_RCC_TIM3_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM3EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_TIM14_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM14EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM14EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_WWDG_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_WWDGEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_WWDGEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_I2C1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C1EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C1EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_PWR_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_PWREN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_PWREN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_TIM3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM3EN)) +#define __HAL_RCC_TIM14_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM14EN)) +#define __HAL_RCC_WWDG_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_WWDGEN)) +#define __HAL_RCC_I2C1_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C1EN)) +#define __HAL_RCC_PWR_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_PWREN)) +/** + * @} + */ + +/** @defgroup RCC_APB1_Peripheral_Clock_Enable_Disable_Status APB1 Peripheral Clock Enable Disable Status + * @brief Get the enable or disable status of the APB1 peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +#define __HAL_RCC_TIM3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) != RESET) +#define __HAL_RCC_TIM14_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM14EN)) != RESET) +#define __HAL_RCC_WWDG_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_WWDGEN)) != RESET) +#define __HAL_RCC_I2C1_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C1EN)) != RESET) +#define __HAL_RCC_PWR_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_PWREN)) != RESET) +#define __HAL_RCC_TIM3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM3EN)) == RESET) +#define __HAL_RCC_TIM14_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM14EN)) == RESET) +#define __HAL_RCC_WWDG_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_WWDGEN)) == RESET) +#define __HAL_RCC_I2C1_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C1EN)) == RESET) +#define __HAL_RCC_PWR_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_PWREN)) == RESET) +/** + * @} + */ + + +/** @defgroup RCC_APB2_Clock_Enable_Disable RCC APB2 Clock Enable Disable + * @brief Enable or disable the High Speed APB (APB2) peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +#define __HAL_RCC_SYSCFG_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SYSCFGEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SYSCFGEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_ADC1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_ADC1EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_ADC1EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_TIM1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM1EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_SPI1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_SPI1EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_TIM16_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM16EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM16EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_TIM17_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM17EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM17EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_USART1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART1EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_DBGMCU_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_DBGMCUEN);\ + /* Delay after an RCC peripheral clock enabling */\ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_DBGMCUEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_SYSCFG_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SYSCFGEN)) +#define __HAL_RCC_ADC1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_ADC1EN)) +#define __HAL_RCC_TIM1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM1EN)) +#define __HAL_RCC_SPI1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_SPI1EN)) +#define __HAL_RCC_TIM16_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM16EN)) +#define __HAL_RCC_TIM17_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM17EN)) +#define __HAL_RCC_USART1_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_USART1EN)) +#define __HAL_RCC_DBGMCU_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_DBGMCUEN)) +/** + * @} + */ + +/** @defgroup RCC_APB2_Peripheral_Clock_Enable_Disable_Status APB2 Peripheral Clock Enable Disable Status + * @brief Get the enable or disable status of the APB2 peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +#define __HAL_RCC_SYSCFG_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SYSCFGEN)) != RESET) +#define __HAL_RCC_ADC1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_ADC1EN)) != RESET) +#define __HAL_RCC_TIM1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM1EN)) != RESET) +#define __HAL_RCC_SPI1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) != RESET) +#define __HAL_RCC_TIM16_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM16EN)) != RESET) +#define __HAL_RCC_TIM17_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM17EN)) != RESET) +#define __HAL_RCC_USART1_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART1EN)) != RESET) +#define __HAL_RCC_DBGMCU_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_DBGMCUEN)) != RESET) +#define __HAL_RCC_SYSCFG_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SYSCFGEN)) == RESET) +#define __HAL_RCC_ADC1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_ADC1EN)) == RESET) +#define __HAL_RCC_TIM1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM1EN)) == RESET) +#define __HAL_RCC_SPI1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_SPI1EN)) == RESET) +#define __HAL_RCC_TIM16_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM16EN)) == RESET) +#define __HAL_RCC_TIM17_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM17EN)) == RESET) +#define __HAL_RCC_USART1_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART1EN)) == RESET) +#define __HAL_RCC_DBGMCU_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_DBGMCUEN)) == RESET) +/** + * @} + */ + +/** @defgroup RCC_AHB_Force_Release_Reset RCC AHB Force Release Reset + * @brief Force or release AHB peripheral reset. + * @{ + */ +#define __HAL_RCC_AHB_FORCE_RESET() (RCC->AHBRSTR = 0xFFFFFFFFU) +#define __HAL_RCC_GPIOA_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOARST)) +#define __HAL_RCC_GPIOB_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOBRST)) +#define __HAL_RCC_GPIOC_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOCRST)) +#define __HAL_RCC_GPIOF_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOFRST)) + +#define __HAL_RCC_AHB_RELEASE_RESET() (RCC->AHBRSTR = 0x00000000U) +#define __HAL_RCC_GPIOA_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOARST)) +#define __HAL_RCC_GPIOB_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOBRST)) +#define __HAL_RCC_GPIOC_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOCRST)) +#define __HAL_RCC_GPIOF_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOFRST)) +/** + * @} + */ + +/** @defgroup RCC_APB1_Force_Release_Reset RCC APB1 Force Release Reset + * @brief Force or release APB1 peripheral reset. + * @{ + */ +#define __HAL_RCC_APB1_FORCE_RESET() (RCC->APB1RSTR = 0xFFFFFFFFU) +#define __HAL_RCC_TIM3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM3RST)) +#define __HAL_RCC_TIM14_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM14RST)) +#define __HAL_RCC_WWDG_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_WWDGRST)) +#define __HAL_RCC_I2C1_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C1RST)) +#define __HAL_RCC_PWR_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_PWRRST)) + +#define __HAL_RCC_APB1_RELEASE_RESET() (RCC->APB1RSTR = 0x00000000U) +#define __HAL_RCC_TIM3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM3RST)) +#define __HAL_RCC_TIM14_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM14RST)) +#define __HAL_RCC_WWDG_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_WWDGRST)) +#define __HAL_RCC_I2C1_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C1RST)) +#define __HAL_RCC_PWR_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_PWRRST)) +/** + * @} + */ + +/** @defgroup RCC_APB2_Force_Release_Reset RCC APB2 Force Release Reset + * @brief Force or release APB2 peripheral reset. + * @{ + */ +#define __HAL_RCC_APB2_FORCE_RESET() (RCC->APB2RSTR = 0xFFFFFFFFU) +#define __HAL_RCC_SYSCFG_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SYSCFGRST)) +#define __HAL_RCC_ADC1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_ADC1RST)) +#define __HAL_RCC_TIM1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM1RST)) +#define __HAL_RCC_SPI1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_SPI1RST)) +#define __HAL_RCC_USART1_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_USART1RST)) +#define __HAL_RCC_TIM16_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM16RST)) +#define __HAL_RCC_TIM17_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM17RST)) +#define __HAL_RCC_DBGMCU_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_DBGMCURST)) + +#define __HAL_RCC_APB2_RELEASE_RESET() (RCC->APB2RSTR = 0x00000000U) +#define __HAL_RCC_SYSCFG_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SYSCFGRST)) +#define __HAL_RCC_ADC1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_ADC1RST)) +#define __HAL_RCC_TIM1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM1RST)) +#define __HAL_RCC_SPI1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_SPI1RST)) +#define __HAL_RCC_USART1_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_USART1RST)) +#define __HAL_RCC_TIM16_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM16RST)) +#define __HAL_RCC_TIM17_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM17RST)) +#define __HAL_RCC_DBGMCU_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_DBGMCURST)) +/** + * @} + */ +/** @defgroup RCC_HSI_Configuration HSI Configuration + * @{ + */ + +/** @brief Macros to enable or disable the Internal High Speed oscillator (HSI). + * @note The HSI is stopped by hardware when entering STOP and STANDBY modes. + * @note HSI can not be stopped if it is used as system clock source. In this case, + * you have to select another source of the system clock then stop the HSI. + * @note After enabling the HSI, the application software should wait on HSIRDY + * flag to be set indicating that HSI clock is stable and can be used as + * system clock source. + * @note When the HSI is stopped, HSIRDY flag goes low after 6 HSI oscillator + * clock cycles. + */ +#define __HAL_RCC_HSI_ENABLE() SET_BIT(RCC->CR, RCC_CR_HSION) +#define __HAL_RCC_HSI_DISABLE() CLEAR_BIT(RCC->CR, RCC_CR_HSION) + +/** @brief Macro to adjust the Internal High Speed oscillator (HSI) calibration value. + * @note The calibration is used to compensate for the variations in voltage + * and temperature that influence the frequency of the internal HSI RC. + * @param _HSICALIBRATIONVALUE_ specifies the calibration trimming value. + * (default is RCC_HSICALIBRATION_DEFAULT). + * This parameter must be a number between 0 and 0x1F. + */ +#define __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(_HSICALIBRATIONVALUE_) \ + MODIFY_REG(RCC->CR, RCC_CR_HSITRIM, (uint32_t)(_HSICALIBRATIONVALUE_) << RCC_CR_HSITRIM_BitNumber) + +/** + * @} + */ + +/** @defgroup RCC_LSI_Configuration LSI Configuration + * @{ + */ + +/** @brief Macro to enable the Internal Low Speed oscillator (LSI). + * @note After enabling the LSI, the application software should wait on + * LSIRDY flag to be set indicating that LSI clock is stable and can + * be used to clock the IWDG and/or the RTC. + */ +#define __HAL_RCC_LSI_ENABLE() SET_BIT(RCC->CSR, RCC_CSR_LSION) + +/** @brief Macro to disable the Internal Low Speed oscillator (LSI). + * @note LSI can not be disabled if the IWDG is running. + * @note When the LSI is stopped, LSIRDY flag goes low after 6 LSI oscillator + * clock cycles. + */ +#define __HAL_RCC_LSI_DISABLE() CLEAR_BIT(RCC->CSR, RCC_CSR_LSION) + +/** + * @} + */ + +/** @defgroup RCC_HSE_Configuration HSE Configuration + * @{ + */ + +/** + * @brief Macro to configure the External High Speed oscillator (HSE). + * @note Transition HSE Bypass to HSE On and HSE On to HSE Bypass are not + * supported by this macro. User should request a transition to HSE Off + * first and then HSE On or HSE Bypass. + * @note After enabling the HSE (RCC_HSE_ON or RCC_HSE_Bypass), the application + * software should wait on HSERDY flag to be set indicating that HSE clock + * is stable and can be used to clock the PLL and/or system clock. + * @note HSE state can not be changed if it is used directly or through the + * PLL as system clock. In this case, you have to select another source + * of the system clock then change the HSE state (ex. disable it). + * @note The HSE is stopped by hardware when entering STOP and STANDBY modes. + * @note This function reset the CSSON bit, so if the clock security system(CSS) + * was previously enabled you have to enable it again after calling this + * function. + * @param __STATE__ specifies the new state of the HSE. + * This parameter can be one of the following values: + * @arg @ref RCC_HSE_OFF turn OFF the HSE oscillator, HSERDY flag goes low after + * 6 HSE oscillator clock cycles. + * @arg @ref RCC_HSE_ON turn ON the HSE oscillator + * @arg @ref RCC_HSE_BYPASS HSE oscillator bypassed with external clock + */ +#define __HAL_RCC_HSE_CONFIG(__STATE__) \ + do{ \ + if ((__STATE__) == RCC_HSE_ON) \ + { \ + SET_BIT(RCC->CR, RCC_CR_HSEON); \ + } \ + else if ((__STATE__) == RCC_HSE_OFF) \ + { \ + CLEAR_BIT(RCC->CR, RCC_CR_HSEON); \ + CLEAR_BIT(RCC->CR, RCC_CR_HSEBYP); \ + } \ + else if ((__STATE__) == RCC_HSE_BYPASS) \ + { \ + SET_BIT(RCC->CR, RCC_CR_HSEBYP); \ + SET_BIT(RCC->CR, RCC_CR_HSEON); \ + } \ + else \ + { \ + CLEAR_BIT(RCC->CR, RCC_CR_HSEON); \ + CLEAR_BIT(RCC->CR, RCC_CR_HSEBYP); \ + } \ + }while(0U) + +/** + * @brief Macro to configure the External High Speed oscillator (HSE) Predivision factor for PLL. + * @note Predivision factor can not be changed if PLL is used as system clock + * In this case, you have to select another source of the system clock, disable the PLL and + * then change the HSE predivision factor. + * @param __HSE_PREDIV_VALUE__ specifies the division value applied to HSE. + * This parameter must be a number between RCC_HSE_PREDIV_DIV1 and RCC_HSE_PREDIV_DIV16. + */ +#define __HAL_RCC_HSE_PREDIV_CONFIG(__HSE_PREDIV_VALUE__) \ + MODIFY_REG(RCC->CFGR2, RCC_CFGR2_PREDIV, (uint32_t)(__HSE_PREDIV_VALUE__)) + +/** + * @} + */ + +/** @defgroup RCC_LSE_Configuration LSE Configuration + * @{ + */ + +/** + * @brief Macro to configure the External Low Speed oscillator (LSE). + * @note Transitions LSE Bypass to LSE On and LSE On to LSE Bypass are not supported by this macro. + * @note As the LSE is in the Backup domain and write access is denied to + * this domain after reset, you have to enable write access using + * @ref HAL_PWR_EnableBkUpAccess() function before to configure the LSE + * (to be done once after reset). + * @note After enabling the LSE (RCC_LSE_ON or RCC_LSE_BYPASS), the application + * software should wait on LSERDY flag to be set indicating that LSE clock + * is stable and can be used to clock the RTC. + * @param __STATE__ specifies the new state of the LSE. + * This parameter can be one of the following values: + * @arg @ref RCC_LSE_OFF turn OFF the LSE oscillator, LSERDY flag goes low after + * 6 LSE oscillator clock cycles. + * @arg @ref RCC_LSE_ON turn ON the LSE oscillator. + * @arg @ref RCC_LSE_BYPASS LSE oscillator bypassed with external clock. + */ +#define __HAL_RCC_LSE_CONFIG(__STATE__) \ + do{ \ + if ((__STATE__) == RCC_LSE_ON) \ + { \ + SET_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ + } \ + else if ((__STATE__) == RCC_LSE_OFF) \ + { \ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); \ + } \ + else if ((__STATE__) == RCC_LSE_BYPASS) \ + { \ + SET_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); \ + SET_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ + } \ + else \ + { \ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEON); \ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); \ + } \ + }while(0U) + +/** + * @} + */ + +/** @defgroup RCC_HSI14_Configuration RCC_HSI14_Configuration + * @{ + */ + +/** @brief Macro to enable the Internal 14Mhz High Speed oscillator (HSI14). + * @note After enabling the HSI14 with @ref __HAL_RCC_HSI14_ENABLE(), the application software + * should wait on HSI14RDY flag to be set indicating that HSI clock is stable and can be + * used as system clock source. This is not necessary if @ref HAL_RCC_OscConfig() is used. + * clock cycles. + */ +#define __HAL_RCC_HSI14_ENABLE() SET_BIT(RCC->CR2, RCC_CR2_HSI14ON) + +/** @brief Macro to disable the Internal 14Mhz High Speed oscillator (HSI14). + * @note The HSI14 is stopped by hardware when entering STOP and STANDBY modes. + * @note HSI14 can not be stopped if it is used as system clock source. In this case, + * you have to select another source of the system clock then stop the HSI14. + * @note When the HSI14 is stopped, HSI14RDY flag goes low after 6 HSI14 oscillator + * clock cycles. + */ +#define __HAL_RCC_HSI14_DISABLE() CLEAR_BIT(RCC->CR2, RCC_CR2_HSI14ON) + +/** @brief Macro to enable the Internal 14Mhz High Speed oscillator (HSI14) used by ADC. + */ +#define __HAL_RCC_HSI14ADC_ENABLE() CLEAR_BIT(RCC->CR2, RCC_CR2_HSI14DIS) + +/** @brief Macro to disable the Internal 14Mhz High Speed oscillator (HSI14) used by ADC. + */ +#define __HAL_RCC_HSI14ADC_DISABLE() SET_BIT(RCC->CR2, RCC_CR2_HSI14DIS) + +/** @brief Macro to adjust the Internal 14Mhz High Speed oscillator (HSI) calibration value. + * @note The calibration is used to compensate for the variations in voltage + * and temperature that influence the frequency of the internal HSI14 RC. + * @param __HSI14CALIBRATIONVALUE__ specifies the calibration trimming value + * (default is RCC_HSI14CALIBRATION_DEFAULT). + * This parameter must be a number between 0 and 0x1F. + */ +#define __HAL_RCC_HSI14_CALIBRATIONVALUE_ADJUST(__HSI14CALIBRATIONVALUE__) \ + MODIFY_REG(RCC->CR2, RCC_CR2_HSI14TRIM, (uint32_t)(__HSI14CALIBRATIONVALUE__) << RCC_HSI14TRIM_BIT_NUMBER) +/** + * @} + */ + +/** @defgroup RCC_USARTx_Clock_Config RCC USARTx Clock Config + * @{ + */ + +/** @brief Macro to configure the USART1 clock (USART1CLK). + * @param __USART1CLKSOURCE__ specifies the USART1 clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_USART1CLKSOURCE_PCLK1 PCLK1 selected as USART1 clock + * @arg @ref RCC_USART1CLKSOURCE_HSI HSI selected as USART1 clock + * @arg @ref RCC_USART1CLKSOURCE_SYSCLK System Clock selected as USART1 clock + * @arg @ref RCC_USART1CLKSOURCE_LSE LSE selected as USART1 clock + */ +#define __HAL_RCC_USART1_CONFIG(__USART1CLKSOURCE__) \ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_USART1SW, (uint32_t)(__USART1CLKSOURCE__)) + +/** @brief Macro to get the USART1 clock source. + * @retval The clock source can be one of the following values: + * @arg @ref RCC_USART1CLKSOURCE_PCLK1 PCLK1 selected as USART1 clock + * @arg @ref RCC_USART1CLKSOURCE_HSI HSI selected as USART1 clock + * @arg @ref RCC_USART1CLKSOURCE_SYSCLK System Clock selected as USART1 clock + * @arg @ref RCC_USART1CLKSOURCE_LSE LSE selected as USART1 clock + */ +#define __HAL_RCC_GET_USART1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_USART1SW))) + +/** + * @} + */ + +/** @defgroup RCC_I2Cx_Clock_Config RCC I2Cx Clock Config + * @{ + */ + +/** @brief Macro to configure the I2C1 clock (I2C1CLK). + * @param __I2C1CLKSOURCE__ specifies the I2C1 clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_I2C1CLKSOURCE_HSI HSI selected as I2C1 clock + * @arg @ref RCC_I2C1CLKSOURCE_SYSCLK System Clock selected as I2C1 clock + */ +#define __HAL_RCC_I2C1_CONFIG(__I2C1CLKSOURCE__) \ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_I2C1SW, (uint32_t)(__I2C1CLKSOURCE__)) + +/** @brief Macro to get the I2C1 clock source. + * @retval The clock source can be one of the following values: + * @arg @ref RCC_I2C1CLKSOURCE_HSI HSI selected as I2C1 clock + * @arg @ref RCC_I2C1CLKSOURCE_SYSCLK System Clock selected as I2C1 clock + */ +#define __HAL_RCC_GET_I2C1_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_I2C1SW))) +/** + * @} + */ + +/** @defgroup RCC_PLL_Configuration PLL Configuration + * @{ + */ + +/** @brief Macro to enable the main PLL. + * @note After enabling the main PLL, the application software should wait on + * PLLRDY flag to be set indicating that PLL clock is stable and can + * be used as system clock source. + * @note The main PLL is disabled by hardware when entering STOP and STANDBY modes. + */ +#define __HAL_RCC_PLL_ENABLE() SET_BIT(RCC->CR, RCC_CR_PLLON) + +/** @brief Macro to disable the main PLL. + * @note The main PLL can not be disabled if it is used as system clock source + */ +#define __HAL_RCC_PLL_DISABLE() CLEAR_BIT(RCC->CR, RCC_CR_PLLON) + +/** @brief Macro to configure the PLL clock source, multiplication and division factors. + * @note This function must be used only when the main PLL is disabled. + * + * @param __RCC_PLLSOURCE__ specifies the PLL entry clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_PLLSOURCE_HSI HSI oscillator clock selected as PLL clock entry + * @arg @ref RCC_PLLSOURCE_HSE HSE oscillator clock selected as PLL clock entry + * @param __PLLMUL__ specifies the multiplication factor for PLL VCO output clock + * This parameter can be one of the following values: + * This parameter must be a number between RCC_PLL_MUL2 and RCC_PLL_MUL16. + * @param __PREDIV__ specifies the predivider factor for PLL VCO input clock + * This parameter must be a number between RCC_PREDIV_DIV1 and RCC_PREDIV_DIV16. + * + */ +#define __HAL_RCC_PLL_CONFIG(__RCC_PLLSOURCE__ , __PREDIV__, __PLLMUL__) \ + do { \ + MODIFY_REG(RCC->CFGR2, RCC_CFGR2_PREDIV, (__PREDIV__)); \ + MODIFY_REG(RCC->CFGR, RCC_CFGR_PLLMUL | RCC_CFGR_PLLSRC, (uint32_t)((__PLLMUL__)|(__RCC_PLLSOURCE__))); \ + } while(0U) + + +/** @brief Get oscillator clock selected as PLL input clock + * @retval The clock source used for PLL entry. The returned value can be one + * of the following: + * @arg @ref RCC_PLLSOURCE_HSE HSE oscillator clock selected as PLL input clock + */ +#define __HAL_RCC_GET_PLL_OSCSOURCE() ((uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_PLLSRC))) + +/** + * @} + */ + +/** @defgroup RCC_Get_Clock_source Get Clock source + * @{ + */ + +/** + * @brief Macro to configure the system clock source. + * @param __SYSCLKSOURCE__ specifies the system clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_SYSCLKSOURCE_HSI HSI oscillator is used as system clock source. + * @arg @ref RCC_SYSCLKSOURCE_HSE HSE oscillator is used as system clock source. + * @arg @ref RCC_SYSCLKSOURCE_PLLCLK PLL output is used as system clock source. + */ +#define __HAL_RCC_SYSCLK_CONFIG(__SYSCLKSOURCE__) \ + MODIFY_REG(RCC->CFGR, RCC_CFGR_SW, (__SYSCLKSOURCE__)) + +/** @brief Macro to get the clock source used as system clock. + * @retval The clock source used as system clock. The returned value can be one + * of the following: + * @arg @ref RCC_SYSCLKSOURCE_STATUS_HSI HSI used as system clock + * @arg @ref RCC_SYSCLKSOURCE_STATUS_HSE HSE used as system clock + * @arg @ref RCC_SYSCLKSOURCE_STATUS_PLLCLK PLL used as system clock + */ +#define __HAL_RCC_GET_SYSCLK_SOURCE() ((uint32_t)(RCC->CFGR & RCC_CFGR_SWS)) + +/** + * @} + */ + +/** @defgroup RCCEx_MCOx_Clock_Config RCC Extended MCOx Clock Config + * @{ + */ + +#if defined(RCC_CFGR_MCOPRE) +/** @brief Macro to configure the MCO clock. + * @param __MCOCLKSOURCE__ specifies the MCO clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_MCO1SOURCE_NOCLOCK No clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_SYSCLK System Clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI HSI oscillator clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSE HSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSI LSI selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSE LSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI14 HSI14 selected as MCO clock + @if STM32F042x6 + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F048xx + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F071xB + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F072xB + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F078xx + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F091xC + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F098xx + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F030x6 + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F030xC + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F031x6 + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F038xx + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F070x6 + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F070xB + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @endif + * @arg @ref RCC_MCO1SOURCE_PLLCLK_DIV2 PLLCLK Divided by 2 selected as MCO clock + * @param __MCODIV__ specifies the MCO clock prescaler. + * This parameter can be one of the following values: + * @arg @ref RCC_MCODIV_1 MCO clock source is divided by 1 + * @arg @ref RCC_MCODIV_2 MCO clock source is divided by 2 + * @arg @ref RCC_MCODIV_4 MCO clock source is divided by 4 + * @arg @ref RCC_MCODIV_8 MCO clock source is divided by 8 + * @arg @ref RCC_MCODIV_16 MCO clock source is divided by 16 + * @arg @ref RCC_MCODIV_32 MCO clock source is divided by 32 + * @arg @ref RCC_MCODIV_64 MCO clock source is divided by 64 + * @arg @ref RCC_MCODIV_128 MCO clock source is divided by 128 + */ +#else +/** @brief Macro to configure the MCO clock. + * @param __MCOCLKSOURCE__ specifies the MCO clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_MCO1SOURCE_NOCLOCK No clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_SYSCLK System Clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI HSI selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSE HSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSI LSI selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSE LSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI14 HSI14 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK_DIV2 PLLCLK Divided by 2 selected as MCO clock + * @param __MCODIV__ specifies the MCO clock prescaler. + * This parameter can be one of the following values: + * @arg @ref RCC_MCODIV_1 No division applied on MCO clock source + */ +#endif +#if defined(RCC_CFGR_MCOPRE) +#define __HAL_RCC_MCO1_CONFIG(__MCOCLKSOURCE__, __MCODIV__) \ + MODIFY_REG(RCC->CFGR, (RCC_CFGR_MCO | RCC_CFGR_MCOPRE), ((__MCOCLKSOURCE__) | (__MCODIV__))) +#else + +#define __HAL_RCC_MCO1_CONFIG(__MCOCLKSOURCE__, __MCODIV__) \ + MODIFY_REG(RCC->CFGR, RCC_CFGR_MCO, (__MCOCLKSOURCE__)) + +#endif + +/** + * @} + */ + + /** @defgroup RCC_RTC_Clock_Configuration RCC RTC Clock Configuration + * @{ + */ + +/** @brief Macro to configure the RTC clock (RTCCLK). + * @note As the RTC clock configuration bits are in the Backup domain and write + * access is denied to this domain after reset, you have to enable write + * access using the Power Backup Access macro before to configure + * the RTC clock source (to be done once after reset). + * @note Once the RTC clock is configured it cannot be changed unless the + * Backup domain is reset using @ref __HAL_RCC_BACKUPRESET_FORCE() macro, or by + * a Power On Reset (POR). + * + * @param __RTC_CLKSOURCE__ specifies the RTC clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_RTCCLKSOURCE_NO_CLK No clock selected as RTC clock + * @arg @ref RCC_RTCCLKSOURCE_LSE LSE selected as RTC clock + * @arg @ref RCC_RTCCLKSOURCE_LSI LSI selected as RTC clock + * @arg @ref RCC_RTCCLKSOURCE_HSE_DIV32 HSE clock divided by 32 + * @note If the LSE or LSI is used as RTC clock source, the RTC continues to + * work in STOP and STANDBY modes, and can be used as wakeup source. + * However, when the LSI clock and HSE clock divided by 32 is used as RTC clock source, + * the RTC cannot be used in STOP and STANDBY modes. + * @note The system must always be configured so as to get a PCLK frequency greater than or + * equal to the RTCCLK frequency for a proper operation of the RTC. + */ +#define __HAL_RCC_RTC_CONFIG(__RTC_CLKSOURCE__) MODIFY_REG(RCC->BDCR, RCC_BDCR_RTCSEL, (__RTC_CLKSOURCE__)) + +/** @brief Macro to get the RTC clock source. + * @retval The clock source can be one of the following values: + * @arg @ref RCC_RTCCLKSOURCE_NO_CLK No clock selected as RTC clock + * @arg @ref RCC_RTCCLKSOURCE_LSE LSE selected as RTC clock + * @arg @ref RCC_RTCCLKSOURCE_LSI LSI selected as RTC clock + * @arg @ref RCC_RTCCLKSOURCE_HSE_DIV32 HSE clock divided by 32 + */ +#define __HAL_RCC_GET_RTC_SOURCE() (READ_BIT(RCC->BDCR, RCC_BDCR_RTCSEL)) + +/** @brief Macro to enable the the RTC clock. + * @note These macros must be used only after the RTC clock source was selected. + */ +#define __HAL_RCC_RTC_ENABLE() SET_BIT(RCC->BDCR, RCC_BDCR_RTCEN) + +/** @brief Macro to disable the the RTC clock. + * @note These macros must be used only after the RTC clock source was selected. + */ +#define __HAL_RCC_RTC_DISABLE() CLEAR_BIT(RCC->BDCR, RCC_BDCR_RTCEN) + +/** @brief Macro to force the Backup domain reset. + * @note This function resets the RTC peripheral (including the backup registers) + * and the RTC clock source selection in RCC_BDCR register. + */ +#define __HAL_RCC_BACKUPRESET_FORCE() SET_BIT(RCC->BDCR, RCC_BDCR_BDRST) + +/** @brief Macros to release the Backup domain reset. + */ +#define __HAL_RCC_BACKUPRESET_RELEASE() CLEAR_BIT(RCC->BDCR, RCC_BDCR_BDRST) + +/** + * @} + */ + +/** @defgroup RCC_Flags_Interrupts_Management Flags Interrupts Management + * @brief macros to manage the specified RCC Flags and interrupts. + * @{ + */ + +/** @brief Enable RCC interrupt. + * @param __INTERRUPT__ specifies the RCC interrupt sources to be enabled. + * This parameter can be any combination of the following values: + * @arg @ref RCC_IT_LSIRDY LSI ready interrupt + * @arg @ref RCC_IT_LSERDY LSE ready interrupt + * @arg @ref RCC_IT_HSIRDY HSI ready interrupt + * @arg @ref RCC_IT_HSERDY HSE ready interrupt + * @arg @ref RCC_IT_PLLRDY main PLL ready interrupt + * @arg @ref RCC_IT_HSI14RDY HSI14 ready interrupt + @if STM32F042x6 + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F048xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F071xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F072xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F078xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F091xC + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F098xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @endif + */ +#define __HAL_RCC_ENABLE_IT(__INTERRUPT__) (*(__IO uint8_t *) RCC_CIR_BYTE1_ADDRESS |= (__INTERRUPT__)) + +/** @brief Disable RCC interrupt. + * @param __INTERRUPT__ specifies the RCC interrupt sources to be disabled. + * This parameter can be any combination of the following values: + * @arg @ref RCC_IT_LSIRDY LSI ready interrupt + * @arg @ref RCC_IT_LSERDY LSE ready interrupt + * @arg @ref RCC_IT_HSIRDY HSI ready interrupt + * @arg @ref RCC_IT_HSERDY HSE ready interrupt + * @arg @ref RCC_IT_PLLRDY main PLL ready interrupt + * @arg @ref RCC_IT_HSI14RDY HSI14 ready interrupt + @if STM32F042x6 + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F048xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F071xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F072xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F078xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F091xC + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F098xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @endif + */ +#define __HAL_RCC_DISABLE_IT(__INTERRUPT__) (*(__IO uint8_t *) RCC_CIR_BYTE1_ADDRESS &= (uint8_t)(~(__INTERRUPT__))) + +/** @brief Clear the RCC's interrupt pending bits. + * @param __INTERRUPT__ specifies the interrupt pending bit to clear. + * This parameter can be any combination of the following values: + * @arg @ref RCC_IT_LSIRDY LSI ready interrupt. + * @arg @ref RCC_IT_LSERDY LSE ready interrupt. + * @arg @ref RCC_IT_HSIRDY HSI ready interrupt. + * @arg @ref RCC_IT_HSERDY HSE ready interrupt. + * @arg @ref RCC_IT_PLLRDY Main PLL ready interrupt. + * @arg @ref RCC_IT_CSS Clock Security System interrupt + * @arg @ref RCC_IT_HSI14RDY HSI14 ready interrupt + @if STM32F042x6 + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F048xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F071xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F072xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F078xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F091xC + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F098xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @endif + */ +#define __HAL_RCC_CLEAR_IT(__INTERRUPT__) (*(__IO uint8_t *) RCC_CIR_BYTE2_ADDRESS = (__INTERRUPT__)) + +/** @brief Check the RCC's interrupt has occurred or not. + * @param __INTERRUPT__ specifies the RCC interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref RCC_IT_LSIRDY LSI ready interrupt. + * @arg @ref RCC_IT_LSERDY LSE ready interrupt. + * @arg @ref RCC_IT_HSIRDY HSI ready interrupt. + * @arg @ref RCC_IT_HSERDY HSE ready interrupt. + * @arg @ref RCC_IT_PLLRDY Main PLL ready interrupt. + * @arg @ref RCC_IT_CSS Clock Security System interrupt + * @arg @ref RCC_IT_HSI14RDY HSI14 ready interrupt enable + @if STM32F042x6 + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F048xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F071xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F072xB + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F078xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F091xC + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @elseif STM32F098xx + * @arg @ref RCC_IT_HSI48RDY HSI48 ready interrupt + @endif + * @retval The new state of __INTERRUPT__ (TRUE or FALSE). + */ +#define __HAL_RCC_GET_IT(__INTERRUPT__) ((RCC->CIR & (__INTERRUPT__)) == (__INTERRUPT__)) + +/** @brief Set RMVF bit to clear the reset flags. + * The reset flags are RCC_FLAG_PINRST, RCC_FLAG_PORRST, RCC_FLAG_SFTRST, + * RCC_FLAG_OBLRST, RCC_FLAG_IWDGRST, RCC_FLAG_WWDGRST, RCC_FLAG_LPWRRST + */ +#define __HAL_RCC_CLEAR_RESET_FLAGS() (RCC->CSR |= RCC_CSR_RMVF) + +/** @brief Check RCC flag is set or not. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref RCC_FLAG_HSIRDY HSI oscillator clock ready. + * @arg @ref RCC_FLAG_HSERDY HSE oscillator clock ready. + * @arg @ref RCC_FLAG_PLLRDY Main PLL clock ready. + * @arg @ref RCC_FLAG_HSI14RDY HSI14 oscillator clock ready + @if STM32F038xx + * @arg @ref RCC_FLAG_V18PWRRST Reset flag of the 1.8 V domain + @elseif STM32F042x6 + * @arg @ref RCC_FLAG_HSI48RDY HSI48 oscillator clock ready + @elseif STM32F048xx + * @arg @ref RCC_FLAG_HSI48RDY HSI48 oscillator clock ready + * @arg @ref RCC_FLAG_V18PWRRST Reset flag of the 1.8 V domain + @elseif STM32F058xx + * @arg @ref RCC_FLAG_V18PWRRST Reset flag of the 1.8 V domain + @elseif STM32F071xB + * @arg @ref RCC_FLAG_HSI48RDY HSI48 oscillator clock ready + @elseif STM32F072xB + * @arg @ref RCC_FLAG_HSI48RDY HSI48 oscillator clock ready + @elseif STM32F078xx + * @arg @ref RCC_FLAG_HSI48RDY HSI48 oscillator clock ready + * @arg @ref RCC_FLAG_V18PWRRST Reset flag of the 1.8 V domain + @elseif STM32F091xC + * @arg @ref RCC_FLAG_HSI48RDY HSI48 oscillator clock ready + @elseif STM32F098xx + * @arg @ref RCC_FLAG_HSI48RDY HSI48 oscillator clock ready + * @arg @ref RCC_FLAG_V18PWRRST Reset flag of the 1.8 V domain + @endif + * @arg @ref RCC_FLAG_LSERDY LSE oscillator clock ready. + * @arg @ref RCC_FLAG_LSIRDY LSI oscillator clock ready. + * @arg @ref RCC_FLAG_OBLRST Option Byte Load reset + * @arg @ref RCC_FLAG_PINRST Pin reset. + * @arg @ref RCC_FLAG_PORRST POR/PDR reset. + * @arg @ref RCC_FLAG_SFTRST Software reset. + * @arg @ref RCC_FLAG_IWDGRST Independent Watchdog reset. + * @arg @ref RCC_FLAG_WWDGRST Window Watchdog reset. + * @arg @ref RCC_FLAG_LPWRRST Low Power reset. + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_RCC_GET_FLAG(__FLAG__) (((((__FLAG__) >> 5U) == CR_REG_INDEX)? RCC->CR : \ + (((__FLAG__) >> 5U) == CR2_REG_INDEX)? RCC->CR2 : \ + (((__FLAG__) >> 5U) == BDCR_REG_INDEX) ? RCC->BDCR : \ + RCC->CSR) & (1U << ((__FLAG__) & RCC_FLAG_MASK))) + +/** + * @} + */ + +/** + * @} + */ + +/* Include RCC HAL Extension module */ +#include "stm32f0xx_hal_rcc_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup RCC_Exported_Functions + * @{ + */ + +/** @addtogroup RCC_Exported_Functions_Group1 + * @{ + */ + +/* Initialization and de-initialization functions ******************************/ +HAL_StatusTypeDef HAL_RCC_DeInit(void); +HAL_StatusTypeDef HAL_RCC_OscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct); +HAL_StatusTypeDef HAL_RCC_ClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t FLatency); + +/** + * @} + */ + +/** @addtogroup RCC_Exported_Functions_Group2 + * @{ + */ + +/* Peripheral Control functions ************************************************/ +void HAL_RCC_MCOConfig(uint32_t RCC_MCOx, uint32_t RCC_MCOSource, uint32_t RCC_MCODiv); +void HAL_RCC_EnableCSS(void); +/* CSS NMI IRQ handler */ +void HAL_RCC_NMI_IRQHandler(void); +/* User Callbacks in non blocking mode (IT mode) */ +void HAL_RCC_CSSCallback(void); +void HAL_RCC_DisableCSS(void); +uint32_t HAL_RCC_GetSysClockFreq(void); +uint32_t HAL_RCC_GetHCLKFreq(void); +uint32_t HAL_RCC_GetPCLK1Freq(void); +void HAL_RCC_GetOscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct); +void HAL_RCC_GetClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t *pFLatency); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_RCC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc_ex.h new file mode 100644 index 0000000..e599e97 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rcc_ex.h @@ -0,0 +1,2085 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rcc_ex.h + * @author MCD Application Team + * @brief Header file of RCC HAL Extension module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_RCC_EX_H +#define __STM32F0xx_HAL_RCC_EX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup RCC + * @{ + */ + +/** @addtogroup RCC_Private_Macros + * @{ + */ +#if defined(RCC_HSI48_SUPPORT) +#define IS_RCC_OSCILLATORTYPE(OSCILLATOR) (((OSCILLATOR) == RCC_OSCILLATORTYPE_NONE) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_HSI14) == RCC_OSCILLATORTYPE_HSI14) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_HSI48) == RCC_OSCILLATORTYPE_HSI48)) + +#define IS_RCC_SYSCLKSOURCE(SOURCE) (((SOURCE) == RCC_SYSCLKSOURCE_HSI) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_HSE) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_PLLCLK) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_HSI48)) + +#define IS_RCC_SYSCLKSOURCE_STATUS(SOURCE) (((SOURCE) == RCC_SYSCLKSOURCE_STATUS_HSI) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_STATUS_HSE) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_STATUS_PLLCLK) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_STATUS_HSI48)) + +#define IS_RCC_PLLSOURCE(SOURCE) (((SOURCE) == RCC_PLLSOURCE_HSI) || \ + ((SOURCE) == RCC_PLLSOURCE_HSI48) || \ + ((SOURCE) == RCC_PLLSOURCE_HSE)) + +#define IS_RCC_HSI48(HSI48) (((HSI48) == RCC_HSI48_OFF) || ((HSI48) == RCC_HSI48_ON)) + +#else + +#define IS_RCC_OSCILLATORTYPE(OSCILLATOR) (((OSCILLATOR) == RCC_OSCILLATORTYPE_NONE) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE) || \ + (((OSCILLATOR) & RCC_OSCILLATORTYPE_HSI14) == RCC_OSCILLATORTYPE_HSI14)) +#define IS_RCC_SYSCLKSOURCE(SOURCE) (((SOURCE) == RCC_SYSCLKSOURCE_HSI) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_HSE) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_PLLCLK)) + +#define IS_RCC_SYSCLKSOURCE_STATUS(SOURCE) (((SOURCE) == RCC_SYSCLKSOURCE_STATUS_HSI) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_STATUS_HSE) || \ + ((SOURCE) == RCC_SYSCLKSOURCE_STATUS_PLLCLK)) +#define IS_RCC_PLLSOURCE(SOURCE) (((SOURCE) == RCC_PLLSOURCE_HSI) || \ + ((SOURCE) == RCC_PLLSOURCE_HSE)) + +#endif /* RCC_HSI48_SUPPORT */ + +#if defined(RCC_CFGR_PLLNODIV) && !defined(RCC_CFGR_MCO_HSI48) + +#define IS_RCC_MCO1SOURCE(SOURCE) (((SOURCE) == RCC_MCO1SOURCE_NOCLOCK) || \ + ((SOURCE) == RCC_MCO1SOURCE_LSI) || \ + ((SOURCE) == RCC_MCO1SOURCE_LSE) || \ + ((SOURCE) == RCC_MCO1SOURCE_SYSCLK) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSI) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSE) || \ + ((SOURCE) == RCC_MCO1SOURCE_PLLCLK) || \ + ((SOURCE) == RCC_MCO1SOURCE_PLLCLK_DIV2) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSI14)) + +#elif defined(RCC_CFGR_PLLNODIV) && defined(RCC_CFGR_MCO_HSI48) + +#define IS_RCC_MCO1SOURCE(SOURCE) (((SOURCE) == RCC_MCO1SOURCE_NOCLOCK) || \ + ((SOURCE) == RCC_MCO1SOURCE_LSI) || \ + ((SOURCE) == RCC_MCO1SOURCE_LSE) || \ + ((SOURCE) == RCC_MCO1SOURCE_SYSCLK) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSI) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSE) || \ + ((SOURCE) == RCC_MCO1SOURCE_PLLCLK) || \ + ((SOURCE) == RCC_MCO1SOURCE_PLLCLK_DIV2) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSI14) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSI48)) + +#elif !defined(RCC_CFGR_PLLNODIV) && !defined(RCC_CFGR_MCO_HSI48) + +#define IS_RCC_MCO1SOURCE(SOURCE) (((SOURCE) == RCC_MCO1SOURCE_NOCLOCK) || \ + ((SOURCE) == RCC_MCO1SOURCE_LSI) || \ + ((SOURCE) == RCC_MCO1SOURCE_LSE) || \ + ((SOURCE) == RCC_MCO1SOURCE_SYSCLK) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSI) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSE) || \ + ((SOURCE) == RCC_MCO1SOURCE_PLLCLK_DIV2) || \ + ((SOURCE) == RCC_MCO1SOURCE_HSI14)) + +#endif /* RCC_CFGR_PLLNODIV && !RCC_CFGR_MCO_HSI48 */ + +/** + * @} + */ + +/** @addtogroup RCC_Exported_Constants + * @{ + */ +#if defined(RCC_HSI48_SUPPORT) + +/** @addtogroup RCC_PLL_Clock_Source + * @{ + */ +#define RCC_PLLSOURCE_HSI RCC_CFGR_PLLSRC_HSI_PREDIV +#define RCC_PLLSOURCE_HSI48 RCC_CFGR_PLLSRC_HSI48_PREDIV + +/** + * @} + */ + +/** @addtogroup RCC_Interrupt + * @{ + */ +#define RCC_IT_HSI48 RCC_CIR_HSI48RDYF /*!< HSI48 Ready Interrupt flag */ +/** + * @} + */ + +/** @addtogroup RCC_Flag + * @{ + */ +#define RCC_FLAG_HSI48RDY ((uint8_t)((CR2_REG_INDEX << 5U) | RCC_CR2_HSI48RDY_BitNumber)) +/** + * @} + */ + +/** @addtogroup RCC_System_Clock_Source + * @{ + */ +#define RCC_SYSCLKSOURCE_HSI48 RCC_CFGR_SW_HSI48 +/** + * @} + */ + +/** @addtogroup RCC_System_Clock_Source_Status + * @{ + */ +#define RCC_SYSCLKSOURCE_STATUS_HSI48 RCC_CFGR_SWS_HSI48 +/** + * @} + */ + +#else +/** @addtogroup RCC_PLL_Clock_Source + * @{ + */ + +#if defined(STM32F070xB) || defined(STM32F070x6) || defined(STM32F030xC) +#define RCC_PLLSOURCE_HSI RCC_CFGR_PLLSRC_HSI_PREDIV +#else +#define RCC_PLLSOURCE_HSI RCC_CFGR_PLLSRC_HSI_DIV2 +#endif + +/** + * @} + */ + +#endif /* RCC_HSI48_SUPPORT */ + +/** @addtogroup RCC_MCO_Clock_Source + * @{ + */ + +#if defined(RCC_CFGR_PLLNODIV) + +#define RCC_MCO1SOURCE_PLLCLK (RCC_CFGR_MCO_PLL | RCC_CFGR_PLLNODIV) + +#endif /* RCC_CFGR_PLLNODIV */ + +#if defined(RCC_CFGR_MCO_HSI48) + +#define RCC_MCO1SOURCE_HSI48 RCC_CFGR_MCO_HSI48 + +#endif /* SRCC_CFGR_MCO_HSI48 */ +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup RCCEx + * @{ + */ + +/* Private Constants -------------------------------------------------------------*/ +#if defined(CRS) +/** @addtogroup RCCEx_Private_Constants + * @{ + */ + +/* CRS IT Error Mask */ +#define RCC_CRS_IT_ERROR_MASK ((uint32_t)(RCC_CRS_IT_TRIMOVF | RCC_CRS_IT_SYNCERR | RCC_CRS_IT_SYNCMISS)) + +/* CRS Flag Error Mask */ +#define RCC_CRS_FLAG_ERROR_MASK ((uint32_t)(RCC_CRS_FLAG_TRIMOVF | RCC_CRS_FLAG_SYNCERR | RCC_CRS_FLAG_SYNCMISS)) + +/** + * @} + */ +#endif /* CRS */ + +/* Private macro -------------------------------------------------------------*/ +/** @defgroup RCCEx_Private_Macros RCCEx Private Macros + * @{ + */ +#if defined(STM32F030x6) || defined(STM32F030x8) || defined(STM32F031x6) || defined(STM32F038xx)\ + || defined(STM32F030xC) + +#define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_I2C1 | \ + RCC_PERIPHCLK_RTC)) +#endif /* STM32F030x6 || STM32F030x8 || STM32F031x6 || STM32F038xx || + STM32F030xC */ + +#if defined(STM32F070x6) || defined(STM32F070xB) + +#define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_I2C1 | \ + RCC_PERIPHCLK_RTC | RCC_PERIPHCLK_USB)) +#endif /* STM32F070x6 || STM32F070xB */ + +#if defined(STM32F042x6) || defined(STM32F048xx) + +#define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_I2C1 | \ + RCC_PERIPHCLK_CEC | RCC_PERIPHCLK_RTC | \ + RCC_PERIPHCLK_USB)) +#endif /* STM32F042x6 || STM32F048xx */ + +#if defined(STM32F051x8) || defined(STM32F058xx) + +#define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_I2C1 | \ + RCC_PERIPHCLK_CEC | RCC_PERIPHCLK_RTC)) +#endif /* STM32F051x8 || STM32F058xx */ + +#if defined(STM32F071xB) + +#define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | \ + RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_CEC | \ + RCC_PERIPHCLK_RTC)) +#endif /* STM32F071xB */ + +#if defined(STM32F072xB) || defined(STM32F078xx) + +#define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | \ + RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_CEC | \ + RCC_PERIPHCLK_RTC | RCC_PERIPHCLK_USB)) +#endif /* STM32F072xB || STM32F078xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +#define IS_RCC_PERIPHCLOCK(SELECTION) ((SELECTION) <= (RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_USART2 | \ + RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_CEC | \ + RCC_PERIPHCLK_RTC | RCC_PERIPHCLK_USART3 )) +#endif /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB) || defined(STM32F078xx) + +#define IS_RCC_USBCLKSOURCE(SOURCE) (((SOURCE) == RCC_USBCLKSOURCE_HSI48) || \ + ((SOURCE) == RCC_USBCLKSOURCE_PLL)) + +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || STM32F078xx */ + +#if defined(STM32F070x6) || defined(STM32F070xB) + +#define IS_RCC_USBCLKSOURCE(SOURCE) (((SOURCE) == RCC_USBCLKSOURCE_NONE) || \ + ((SOURCE) == RCC_USBCLKSOURCE_PLL)) + +#endif /* STM32F070x6 || STM32F070xB */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define IS_RCC_USART2CLKSOURCE(SOURCE) (((SOURCE) == RCC_USART2CLKSOURCE_PCLK1) || \ + ((SOURCE) == RCC_USART2CLKSOURCE_SYSCLK) || \ + ((SOURCE) == RCC_USART2CLKSOURCE_LSE) || \ + ((SOURCE) == RCC_USART2CLKSOURCE_HSI)) + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +#define IS_RCC_USART3CLKSOURCE(SOURCE) (((SOURCE) == RCC_USART3CLKSOURCE_PCLK1) || \ + ((SOURCE) == RCC_USART3CLKSOURCE_SYSCLK) || \ + ((SOURCE) == RCC_USART3CLKSOURCE_LSE) || \ + ((SOURCE) == RCC_USART3CLKSOURCE_HSI)) +#endif /* STM32F091xC || STM32F098xx */ + + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define IS_RCC_CECCLKSOURCE(SOURCE) (((SOURCE) == RCC_CECCLKSOURCE_HSI) || \ + ((SOURCE) == RCC_CECCLKSOURCE_LSE)) +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(RCC_CFGR_MCOPRE) + +#define IS_RCC_MCODIV(DIV) (((DIV) == RCC_MCODIV_1) || ((DIV) == RCC_MCODIV_2) || \ + ((DIV) == RCC_MCODIV_4) || ((DIV) == RCC_MCODIV_8) || \ + ((DIV) == RCC_MCODIV_16) || ((DIV) == RCC_MCODIV_32) || \ + ((DIV) == RCC_MCODIV_64) || ((DIV) == RCC_MCODIV_128)) +#else + +#define IS_RCC_MCODIV(DIV) (((DIV) == RCC_MCODIV_1)) + +#endif /* RCC_CFGR_MCOPRE */ + +#define IS_RCC_LSE_DRIVE(__DRIVE__) (((__DRIVE__) == RCC_LSEDRIVE_LOW) || \ + ((__DRIVE__) == RCC_LSEDRIVE_MEDIUMLOW) || \ + ((__DRIVE__) == RCC_LSEDRIVE_MEDIUMHIGH) || \ + ((__DRIVE__) == RCC_LSEDRIVE_HIGH)) + +#if defined(CRS) + +#define IS_RCC_CRS_SYNC_SOURCE(_SOURCE_) (((_SOURCE_) == RCC_CRS_SYNC_SOURCE_GPIO) || \ + ((_SOURCE_) == RCC_CRS_SYNC_SOURCE_LSE) || \ + ((_SOURCE_) == RCC_CRS_SYNC_SOURCE_USB)) +#define IS_RCC_CRS_SYNC_DIV(_DIV_) (((_DIV_) == RCC_CRS_SYNC_DIV1) || ((_DIV_) == RCC_CRS_SYNC_DIV2) || \ + ((_DIV_) == RCC_CRS_SYNC_DIV4) || ((_DIV_) == RCC_CRS_SYNC_DIV8) || \ + ((_DIV_) == RCC_CRS_SYNC_DIV16) || ((_DIV_) == RCC_CRS_SYNC_DIV32) || \ + ((_DIV_) == RCC_CRS_SYNC_DIV64) || ((_DIV_) == RCC_CRS_SYNC_DIV128)) +#define IS_RCC_CRS_SYNC_POLARITY(_POLARITY_) (((_POLARITY_) == RCC_CRS_SYNC_POLARITY_RISING) || \ + ((_POLARITY_) == RCC_CRS_SYNC_POLARITY_FALLING)) +#define IS_RCC_CRS_RELOADVALUE(_VALUE_) (((_VALUE_) <= 0xFFFFU)) +#define IS_RCC_CRS_ERRORLIMIT(_VALUE_) (((_VALUE_) <= 0xFFU)) +#define IS_RCC_CRS_HSI48CALIBRATION(_VALUE_) (((_VALUE_) <= 0x3FU)) +#define IS_RCC_CRS_FREQERRORDIR(_DIR_) (((_DIR_) == RCC_CRS_FREQERRORDIR_UP) || \ + ((_DIR_) == RCC_CRS_FREQERRORDIR_DOWN)) +#endif /* CRS */ +/** + * @} + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup RCCEx_Exported_Types RCCEx Exported Types + * @{ + */ + +/** + * @brief RCC extended clocks structure definition + */ +#if defined(STM32F030x6) || defined(STM32F030x8) || defined(STM32F031x6) || defined(STM32F038xx)\ + || defined(STM32F030xC) +typedef struct +{ + uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured. + This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */ + + uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection + This parameter can be a value of @ref RCC_RTC_Clock_Source */ + + uint32_t Usart1ClockSelection; /*!< USART1 clock source + This parameter can be a value of @ref RCC_USART1_Clock_Source */ + + uint32_t I2c1ClockSelection; /*!< I2C1 clock source + This parameter can be a value of @ref RCC_I2C1_Clock_Source */ + +}RCC_PeriphCLKInitTypeDef; +#endif /* STM32F030x6 || STM32F030x8 || STM32F031x6 || STM32F038xx || + STM32F030xC */ + +#if defined(STM32F070x6) || defined(STM32F070xB) +typedef struct +{ + uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured. + This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */ + + uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection + This parameter can be a value of @ref RCC_RTC_Clock_Source */ + + uint32_t Usart1ClockSelection; /*!< USART1 clock source + This parameter can be a value of @ref RCC_USART1_Clock_Source */ + + uint32_t I2c1ClockSelection; /*!< I2C1 clock source + This parameter can be a value of @ref RCC_I2C1_Clock_Source */ + + uint32_t UsbClockSelection; /*!< USB clock source + This parameter can be a value of @ref RCCEx_USB_Clock_Source */ + +}RCC_PeriphCLKInitTypeDef; +#endif /* STM32F070x6 || STM32F070xB */ + +#if defined(STM32F042x6) || defined(STM32F048xx) +typedef struct +{ + uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured. + This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */ + + uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection + This parameter can be a value of @ref RCC_RTC_Clock_Source */ + + uint32_t Usart1ClockSelection; /*!< USART1 clock source + This parameter can be a value of @ref RCC_USART1_Clock_Source */ + + uint32_t I2c1ClockSelection; /*!< I2C1 clock source + This parameter can be a value of @ref RCC_I2C1_Clock_Source */ + + uint32_t CecClockSelection; /*!< HDMI CEC clock source + This parameter can be a value of @ref RCCEx_CEC_Clock_Source */ + + uint32_t UsbClockSelection; /*!< USB clock source + This parameter can be a value of @ref RCCEx_USB_Clock_Source */ + +}RCC_PeriphCLKInitTypeDef; +#endif /* STM32F042x6 || STM32F048xx */ + +#if defined(STM32F051x8) || defined(STM32F058xx) +typedef struct +{ + uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured. + This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */ + + uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection + This parameter can be a value of @ref RCC_RTC_Clock_Source */ + + uint32_t Usart1ClockSelection; /*!< USART1 clock source + This parameter can be a value of @ref RCC_USART1_Clock_Source */ + + uint32_t I2c1ClockSelection; /*!< I2C1 clock source + This parameter can be a value of @ref RCC_I2C1_Clock_Source */ + + uint32_t CecClockSelection; /*!< HDMI CEC clock source + This parameter can be a value of @ref RCCEx_CEC_Clock_Source */ + +}RCC_PeriphCLKInitTypeDef; +#endif /* STM32F051x8 || STM32F058xx */ + +#if defined(STM32F071xB) +typedef struct +{ + uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured. + This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */ + + uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection + This parameter can be a value of @ref RCC_RTC_Clock_Source */ + + uint32_t Usart1ClockSelection; /*!< USART1 clock source + This parameter can be a value of @ref RCC_USART1_Clock_Source */ + + uint32_t Usart2ClockSelection; /*!< USART2 clock source + This parameter can be a value of @ref RCCEx_USART2_Clock_Source */ + + uint32_t I2c1ClockSelection; /*!< I2C1 clock source + This parameter can be a value of @ref RCC_I2C1_Clock_Source */ + + uint32_t CecClockSelection; /*!< HDMI CEC clock source + This parameter can be a value of @ref RCCEx_CEC_Clock_Source */ + +}RCC_PeriphCLKInitTypeDef; +#endif /* STM32F071xB */ + +#if defined(STM32F072xB) || defined(STM32F078xx) +typedef struct +{ + uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured. + This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */ + + uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection + This parameter can be a value of @ref RCC_RTC_Clock_Source */ + + uint32_t Usart1ClockSelection; /*!< USART1 clock source + This parameter can be a value of @ref RCC_USART1_Clock_Source */ + + uint32_t Usart2ClockSelection; /*!< USART2 clock source + This parameter can be a value of @ref RCCEx_USART2_Clock_Source */ + + uint32_t I2c1ClockSelection; /*!< I2C1 clock source + This parameter can be a value of @ref RCC_I2C1_Clock_Source */ + + uint32_t CecClockSelection; /*!< HDMI CEC clock source + This parameter can be a value of @ref RCCEx_CEC_Clock_Source */ + + uint32_t UsbClockSelection; /*!< USB clock source + This parameter can be a value of @ref RCCEx_USB_Clock_Source */ + +}RCC_PeriphCLKInitTypeDef; +#endif /* STM32F072xB || STM32F078xx */ + + +#if defined(STM32F091xC) || defined(STM32F098xx) +typedef struct +{ + uint32_t PeriphClockSelection; /*!< The Extended Clock to be configured. + This parameter can be a value of @ref RCCEx_Periph_Clock_Selection */ + + uint32_t RTCClockSelection; /*!< Specifies RTC Clock Prescalers Selection + This parameter can be a value of @ref RCC_RTC_Clock_Source */ + + uint32_t Usart1ClockSelection; /*!< USART1 clock source + This parameter can be a value of @ref RCC_USART1_Clock_Source */ + + uint32_t Usart2ClockSelection; /*!< USART2 clock source + This parameter can be a value of @ref RCCEx_USART2_Clock_Source */ + + uint32_t Usart3ClockSelection; /*!< USART3 clock source + This parameter can be a value of @ref RCCEx_USART3_Clock_Source */ + + uint32_t I2c1ClockSelection; /*!< I2C1 clock source + This parameter can be a value of @ref RCC_I2C1_Clock_Source */ + + uint32_t CecClockSelection; /*!< HDMI CEC clock source + This parameter can be a value of @ref RCCEx_CEC_Clock_Source */ + +}RCC_PeriphCLKInitTypeDef; +#endif /* STM32F091xC || STM32F098xx */ + +#if defined(CRS) + +/** + * @brief RCC_CRS Init structure definition + */ +typedef struct +{ + uint32_t Prescaler; /*!< Specifies the division factor of the SYNC signal. + This parameter can be a value of @ref RCCEx_CRS_SynchroDivider */ + + uint32_t Source; /*!< Specifies the SYNC signal source. + This parameter can be a value of @ref RCCEx_CRS_SynchroSource */ + + uint32_t Polarity; /*!< Specifies the input polarity for the SYNC signal source. + This parameter can be a value of @ref RCCEx_CRS_SynchroPolarity */ + + uint32_t ReloadValue; /*!< Specifies the value to be loaded in the frequency error counter with each SYNC event. + It can be calculated in using macro @ref __HAL_RCC_CRS_RELOADVALUE_CALCULATE(__FTARGET__, __FSYNC__) + This parameter must be a number between 0 and 0xFFFF or a value of @ref RCCEx_CRS_ReloadValueDefault .*/ + + uint32_t ErrorLimitValue; /*!< Specifies the value to be used to evaluate the captured frequency error value. + This parameter must be a number between 0 and 0xFF or a value of @ref RCCEx_CRS_ErrorLimitDefault */ + + uint32_t HSI48CalibrationValue; /*!< Specifies a user-programmable trimming value to the HSI48 oscillator. + This parameter must be a number between 0 and 0x3F or a value of @ref RCCEx_CRS_HSI48CalibrationDefault */ + +}RCC_CRSInitTypeDef; + +/** + * @brief RCC_CRS Synchronization structure definition + */ +typedef struct +{ + uint32_t ReloadValue; /*!< Specifies the value loaded in the Counter reload value. + This parameter must be a number between 0 and 0xFFFFU */ + + uint32_t HSI48CalibrationValue; /*!< Specifies value loaded in HSI48 oscillator smooth trimming. + This parameter must be a number between 0 and 0x3FU */ + + uint32_t FreqErrorCapture; /*!< Specifies the value loaded in the .FECAP, the frequency error counter + value latched in the time of the last SYNC event. + This parameter must be a number between 0 and 0xFFFFU */ + + uint32_t FreqErrorDirection; /*!< Specifies the value loaded in the .FEDIR, the counting direction of the + frequency error counter latched in the time of the last SYNC event. + It shows whether the actual frequency is below or above the target. + This parameter must be a value of @ref RCCEx_CRS_FreqErrorDirection*/ + +}RCC_CRSSynchroInfoTypeDef; + +#endif /* CRS */ + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup RCCEx_Exported_Constants RCCEx Exported Constants + * @{ + */ + +/** @defgroup RCCEx_Periph_Clock_Selection RCCEx Periph Clock Selection + * @{ + */ +#if defined(STM32F030x6) || defined(STM32F030x8) || defined(STM32F031x6) || defined(STM32F038xx)\ + || defined(STM32F030xC) +#define RCC_PERIPHCLK_USART1 (0x00000001U) +#define RCC_PERIPHCLK_I2C1 (0x00000020U) +#define RCC_PERIPHCLK_RTC (0x00010000U) + +#endif /* STM32F030x6 || STM32F030x8 || STM32F031x6 || STM32F038xx || + STM32F030xC */ + +#if defined(STM32F070x6) || defined(STM32F070xB) +#define RCC_PERIPHCLK_USART1 (0x00000001U) +#define RCC_PERIPHCLK_I2C1 (0x00000020U) +#define RCC_PERIPHCLK_RTC (0x00010000U) +#define RCC_PERIPHCLK_USB (0x00020000U) + +#endif /* STM32F070x6 || STM32F070xB */ + +#if defined(STM32F042x6) || defined(STM32F048xx) +#define RCC_PERIPHCLK_USART1 (0x00000001U) +#define RCC_PERIPHCLK_I2C1 (0x00000020U) +#define RCC_PERIPHCLK_CEC (0x00000400U) +#define RCC_PERIPHCLK_RTC (0x00010000U) +#define RCC_PERIPHCLK_USB (0x00020000U) + +#endif /* STM32F042x6 || STM32F048xx */ + +#if defined(STM32F051x8) || defined(STM32F058xx) +#define RCC_PERIPHCLK_USART1 (0x00000001U) +#define RCC_PERIPHCLK_I2C1 (0x00000020U) +#define RCC_PERIPHCLK_CEC (0x00000400U) +#define RCC_PERIPHCLK_RTC (0x00010000U) + +#endif /* STM32F051x8 || STM32F058xx */ + +#if defined(STM32F071xB) +#define RCC_PERIPHCLK_USART1 (0x00000001U) +#define RCC_PERIPHCLK_USART2 (0x00000002U) +#define RCC_PERIPHCLK_I2C1 (0x00000020U) +#define RCC_PERIPHCLK_CEC (0x00000400U) +#define RCC_PERIPHCLK_RTC (0x00010000U) + +#endif /* STM32F071xB */ + +#if defined(STM32F072xB) || defined(STM32F078xx) +#define RCC_PERIPHCLK_USART1 (0x00000001U) +#define RCC_PERIPHCLK_USART2 (0x00000002U) +#define RCC_PERIPHCLK_I2C1 (0x00000020U) +#define RCC_PERIPHCLK_CEC (0x00000400U) +#define RCC_PERIPHCLK_RTC (0x00010000U) +#define RCC_PERIPHCLK_USB (0x00020000U) + +#endif /* STM32F072xB || STM32F078xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) +#define RCC_PERIPHCLK_USART1 (0x00000001U) +#define RCC_PERIPHCLK_USART2 (0x00000002U) +#define RCC_PERIPHCLK_I2C1 (0x00000020U) +#define RCC_PERIPHCLK_CEC (0x00000400U) +#define RCC_PERIPHCLK_RTC (0x00010000U) +#define RCC_PERIPHCLK_USART3 (0x00040000U) + +#endif /* STM32F091xC || STM32F098xx */ + +/** + * @} + */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB) || defined(STM32F078xx) + +/** @defgroup RCCEx_USB_Clock_Source RCCEx USB Clock Source + * @{ + */ +#define RCC_USBCLKSOURCE_HSI48 RCC_CFGR3_USBSW_HSI48 /*!< HSI48 clock selected as USB clock source */ +#define RCC_USBCLKSOURCE_PLL RCC_CFGR3_USBSW_PLLCLK /*!< PLL clock (PLLCLK) selected as USB clock */ + +/** + * @} + */ + +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || STM32F078xx */ + +#if defined(STM32F070x6) || defined(STM32F070xB) + +/** @defgroup RCCEx_USB_Clock_Source RCCEx USB Clock Source + * @{ + */ +#define RCC_USBCLKSOURCE_NONE (0x00000000U) /*!< USB clock disabled */ +#define RCC_USBCLKSOURCE_PLL RCC_CFGR3_USBSW_PLLCLK /*!< PLL clock (PLLCLK) selected as USB clock */ + +/** + * @} + */ + +#endif /* STM32F070x6 || STM32F070xB */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +/** @defgroup RCCEx_USART2_Clock_Source RCCEx USART2 Clock Source + * @{ + */ +#define RCC_USART2CLKSOURCE_PCLK1 RCC_CFGR3_USART2SW_PCLK +#define RCC_USART2CLKSOURCE_SYSCLK RCC_CFGR3_USART2SW_SYSCLK +#define RCC_USART2CLKSOURCE_LSE RCC_CFGR3_USART2SW_LSE +#define RCC_USART2CLKSOURCE_HSI RCC_CFGR3_USART2SW_HSI + +/** + * @} + */ + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +/** @defgroup RCCEx_USART3_Clock_Source RCCEx USART3 Clock Source + * @{ + */ +#define RCC_USART3CLKSOURCE_PCLK1 RCC_CFGR3_USART3SW_PCLK +#define RCC_USART3CLKSOURCE_SYSCLK RCC_CFGR3_USART3SW_SYSCLK +#define RCC_USART3CLKSOURCE_LSE RCC_CFGR3_USART3SW_LSE +#define RCC_USART3CLKSOURCE_HSI RCC_CFGR3_USART3SW_HSI + +/** + * @} + */ + +#endif /* STM32F091xC || STM32F098xx */ + + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +/** @defgroup RCCEx_CEC_Clock_Source RCCEx CEC Clock Source + * @{ + */ +#define RCC_CECCLKSOURCE_HSI RCC_CFGR3_CECSW_HSI_DIV244 +#define RCC_CECCLKSOURCE_LSE RCC_CFGR3_CECSW_LSE + +/** + * @} + */ + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +/** @defgroup RCCEx_MCOx_Clock_Prescaler RCCEx MCOx Clock Prescaler + * @{ + */ + +#if defined(RCC_CFGR_MCOPRE) + +#define RCC_MCODIV_1 (0x00000000U) +#define RCC_MCODIV_2 (0x10000000U) +#define RCC_MCODIV_4 (0x20000000U) +#define RCC_MCODIV_8 (0x30000000U) +#define RCC_MCODIV_16 (0x40000000U) +#define RCC_MCODIV_32 (0x50000000U) +#define RCC_MCODIV_64 (0x60000000U) +#define RCC_MCODIV_128 (0x70000000U) + +#else + +#define RCC_MCODIV_1 (0x00000000U) + +#endif /* RCC_CFGR_MCOPRE */ + +/** + * @} + */ + +/** @defgroup RCCEx_LSEDrive_Configuration RCC LSE Drive Configuration + * @{ + */ + +#define RCC_LSEDRIVE_LOW (0x00000000U) /*!< Xtal mode lower driving capability */ +#define RCC_LSEDRIVE_MEDIUMLOW RCC_BDCR_LSEDRV_1 /*!< Xtal mode medium low driving capability */ +#define RCC_LSEDRIVE_MEDIUMHIGH RCC_BDCR_LSEDRV_0 /*!< Xtal mode medium high driving capability */ +#define RCC_LSEDRIVE_HIGH RCC_BDCR_LSEDRV /*!< Xtal mode higher driving capability */ + +/** + * @} + */ + +#if defined(CRS) + +/** @defgroup RCCEx_CRS_Status RCCEx CRS Status + * @{ + */ +#define RCC_CRS_NONE (0x00000000U) +#define RCC_CRS_TIMEOUT (0x00000001U) +#define RCC_CRS_SYNCOK (0x00000002U) +#define RCC_CRS_SYNCWARN (0x00000004U) +#define RCC_CRS_SYNCERR (0x00000008U) +#define RCC_CRS_SYNCMISS (0x00000010U) +#define RCC_CRS_TRIMOVF (0x00000020U) + +/** + * @} + */ + +/** @defgroup RCCEx_CRS_SynchroSource RCCEx CRS Synchronization Source + * @{ + */ +#define RCC_CRS_SYNC_SOURCE_GPIO (0x00000000U) /*!< Synchro Signal source GPIO */ +#define RCC_CRS_SYNC_SOURCE_LSE CRS_CFGR_SYNCSRC_0 /*!< Synchro Signal source LSE */ +#define RCC_CRS_SYNC_SOURCE_USB CRS_CFGR_SYNCSRC_1 /*!< Synchro Signal source USB SOF (default)*/ +/** + * @} + */ + +/** @defgroup RCCEx_CRS_SynchroDivider RCCEx CRS Synchronization Divider + * @{ + */ +#define RCC_CRS_SYNC_DIV1 (0x00000000U) /*!< Synchro Signal not divided (default) */ +#define RCC_CRS_SYNC_DIV2 CRS_CFGR_SYNCDIV_0 /*!< Synchro Signal divided by 2 */ +#define RCC_CRS_SYNC_DIV4 CRS_CFGR_SYNCDIV_1 /*!< Synchro Signal divided by 4 */ +#define RCC_CRS_SYNC_DIV8 (CRS_CFGR_SYNCDIV_1 | CRS_CFGR_SYNCDIV_0) /*!< Synchro Signal divided by 8 */ +#define RCC_CRS_SYNC_DIV16 CRS_CFGR_SYNCDIV_2 /*!< Synchro Signal divided by 16 */ +#define RCC_CRS_SYNC_DIV32 (CRS_CFGR_SYNCDIV_2 | CRS_CFGR_SYNCDIV_0) /*!< Synchro Signal divided by 32 */ +#define RCC_CRS_SYNC_DIV64 (CRS_CFGR_SYNCDIV_2 | CRS_CFGR_SYNCDIV_1) /*!< Synchro Signal divided by 64 */ +#define RCC_CRS_SYNC_DIV128 CRS_CFGR_SYNCDIV /*!< Synchro Signal divided by 128 */ +/** + * @} + */ + +/** @defgroup RCCEx_CRS_SynchroPolarity RCCEx CRS Synchronization Polarity + * @{ + */ +#define RCC_CRS_SYNC_POLARITY_RISING (0x00000000U) /*!< Synchro Active on rising edge (default) */ +#define RCC_CRS_SYNC_POLARITY_FALLING CRS_CFGR_SYNCPOL /*!< Synchro Active on falling edge */ +/** + * @} + */ + +/** @defgroup RCCEx_CRS_ReloadValueDefault RCCEx CRS Default Reload Value + * @{ + */ +#define RCC_CRS_RELOADVALUE_DEFAULT (0x0000BB7FU) /*!< The reset value of the RELOAD field corresponds + to a target frequency of 48 MHz and a synchronization signal frequency of 1 kHz (SOF signal from USB). */ +/** + * @} + */ + +/** @defgroup RCCEx_CRS_ErrorLimitDefault RCCEx CRS Default Error Limit Value + * @{ + */ +#define RCC_CRS_ERRORLIMIT_DEFAULT (0x00000022U) /*!< Default Frequency error limit */ +/** + * @} + */ + +/** @defgroup RCCEx_CRS_HSI48CalibrationDefault RCCEx CRS Default HSI48 Calibration vakye + * @{ + */ +#define RCC_CRS_HSI48CALIBRATION_DEFAULT (0x00000020U) /*!< The default value is 32, which corresponds to the middle of the trimming interval. + The trimming step is around 67 kHz between two consecutive TRIM steps. A higher TRIM value + corresponds to a higher output frequency */ +/** + * @} + */ + +/** @defgroup RCCEx_CRS_FreqErrorDirection RCCEx CRS Frequency Error Direction + * @{ + */ +#define RCC_CRS_FREQERRORDIR_UP (0x00000000U) /*!< Upcounting direction, the actual frequency is above the target */ +#define RCC_CRS_FREQERRORDIR_DOWN ((uint32_t)CRS_ISR_FEDIR) /*!< Downcounting direction, the actual frequency is below the target */ +/** + * @} + */ + +/** @defgroup RCCEx_CRS_Interrupt_Sources RCCEx CRS Interrupt Sources + * @{ + */ +#define RCC_CRS_IT_SYNCOK CRS_CR_SYNCOKIE /*!< SYNC event OK */ +#define RCC_CRS_IT_SYNCWARN CRS_CR_SYNCWARNIE /*!< SYNC warning */ +#define RCC_CRS_IT_ERR CRS_CR_ERRIE /*!< Error */ +#define RCC_CRS_IT_ESYNC CRS_CR_ESYNCIE /*!< Expected SYNC */ +#define RCC_CRS_IT_SYNCERR CRS_CR_ERRIE /*!< SYNC error */ +#define RCC_CRS_IT_SYNCMISS CRS_CR_ERRIE /*!< SYNC missed */ +#define RCC_CRS_IT_TRIMOVF CRS_CR_ERRIE /*!< Trimming overflow or underflow */ + +/** + * @} + */ + +/** @defgroup RCCEx_CRS_Flags RCCEx CRS Flags + * @{ + */ +#define RCC_CRS_FLAG_SYNCOK CRS_ISR_SYNCOKF /*!< SYNC event OK flag */ +#define RCC_CRS_FLAG_SYNCWARN CRS_ISR_SYNCWARNF /*!< SYNC warning flag */ +#define RCC_CRS_FLAG_ERR CRS_ISR_ERRF /*!< Error flag */ +#define RCC_CRS_FLAG_ESYNC CRS_ISR_ESYNCF /*!< Expected SYNC flag */ +#define RCC_CRS_FLAG_SYNCERR CRS_ISR_SYNCERR /*!< SYNC error */ +#define RCC_CRS_FLAG_SYNCMISS CRS_ISR_SYNCMISS /*!< SYNC missed*/ +#define RCC_CRS_FLAG_TRIMOVF CRS_ISR_TRIMOVF /*!< Trimming overflow or underflow */ + +/** + * @} + */ + +#endif /* CRS */ + +/** + * @} + */ + +/* Exported macros ------------------------------------------------------------*/ +/** @defgroup RCCEx_Exported_Macros RCCEx Exported Macros + * @{ + */ + +/** @defgroup RCCEx_Peripheral_Clock_Enable_Disable RCCEx_Peripheral_Clock_Enable_Disable + * @brief Enables or disables the AHB1 peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +#if defined(GPIOD) + +#define __HAL_RCC_GPIOD_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIODEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIODEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_GPIOD_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIODEN)) + +#endif /* GPIOD */ + +#if defined(GPIOE) + +#define __HAL_RCC_GPIOE_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_GPIOEEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_GPIOEEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_GPIOE_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_GPIOEEN)) + +#endif /* GPIOE */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_TSC_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_TSCEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_TSCEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_TSC_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_TSCEN)) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_DMA2_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->AHBENR, RCC_AHBENR_DMA2EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->AHBENR, RCC_AHBENR_DMA2EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_DMA2_CLK_DISABLE() (RCC->AHBENR &= ~(RCC_AHBENR_DMA2EN)) + +#endif /* STM32F091xC || STM32F098xx */ + +/** @brief Enable or disable the Low Speed APB (APB1) peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + */ +#if defined(STM32F030x8)\ + || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART2_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_USART2EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_USART2EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_USART2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_USART2EN)) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || STM32F070x6 || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F030x8)\ + || defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_SPI2_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_SPI2EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_SPI2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_SPI2EN)) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F031x6) || defined(STM32F038xx)\ + || defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_TIM2_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM2EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM2EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_TIM2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM2EN)) + +#endif /* STM32F031x6 || STM32F038xx || */ + /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F030x8) \ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM6_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM6EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM6EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_I2C2_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_I2C2EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_TIM6_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM6EN)) +#define __HAL_RCC_I2C2_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C2EN)) + +#endif /* STM32F030x8 || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_DAC1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_DACEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_DACEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_DAC1_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_DACEN)) + +#endif /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_CEC_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_CECEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_CECEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_CEC_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_CECEN)) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM7_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM7EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_TIM7EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_USART3_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_USART3EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_USART3EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_USART4_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_USART4EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_USART4EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_TIM7_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_TIM7EN)) +#define __HAL_RCC_USART3_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_USART3EN)) +#define __HAL_RCC_USART4_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_USART4EN)) + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) + +#define __HAL_RCC_USB_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_USBEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_USBEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_USB_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_USBEN)) + +#endif /* STM32F042x6 || STM32F048xx || STM32F070x6 || */ + /* STM32F072xB || STM32F078xx || STM32F070xB */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_CAN1_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_CANEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_CANEN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_CAN1_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_CANEN)) + +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(CRS) + +#define __HAL_RCC_CRS_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_CRSEN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_CRSEN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_CRS_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_CRSEN)) + +#endif /* CRS */ + +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART5_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB1ENR, RCC_APB1ENR_USART5EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB1ENR, RCC_APB1ENR_USART5EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_USART5_CLK_DISABLE() (RCC->APB1ENR &= ~(RCC_APB1ENR_USART5EN)) + +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + +/** @brief Enable or disable the High Speed APB (APB2) peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + */ +#if defined(STM32F030x8) || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM15_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM15EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_TIM15EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_TIM15_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_TIM15EN)) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || STM32F070x6 || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART6_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_USART6EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART6EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_USART6_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_USART6EN)) + +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_USART7_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_USART7EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART7EN);\ + UNUSED(tmpreg); \ + } while(0U) +#define __HAL_RCC_USART8_CLK_ENABLE() do { \ + __IO uint32_t tmpreg; \ + SET_BIT(RCC->APB2ENR, RCC_APB2ENR_USART8EN);\ + /* Delay after an RCC peripheral clock enabling */ \ + tmpreg = READ_BIT(RCC->APB2ENR, RCC_APB2ENR_USART8EN);\ + UNUSED(tmpreg); \ + } while(0U) + +#define __HAL_RCC_USART7_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_USART7EN)) +#define __HAL_RCC_USART8_CLK_DISABLE() (RCC->APB2ENR &= ~(RCC_APB2ENR_USART8EN)) + +#endif /* STM32F091xC || STM32F098xx */ + +/** + * @} + */ + + +/** @defgroup RCCEx_Force_Release_Peripheral_Reset RCCEx Force Release Peripheral Reset + * @brief Forces or releases peripheral reset. + * @{ + */ + +/** @brief Force or release AHB peripheral reset. + */ +#if defined(GPIOD) + +#define __HAL_RCC_GPIOD_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIODRST)) + +#define __HAL_RCC_GPIOD_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIODRST)) + +#endif /* GPIOD */ + +#if defined(GPIOE) + +#define __HAL_RCC_GPIOE_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_GPIOERST)) + +#define __HAL_RCC_GPIOE_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_GPIOERST)) + +#endif /* GPIOE */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_TSC_FORCE_RESET() (RCC->AHBRSTR |= (RCC_AHBRSTR_TSCRST)) + +#define __HAL_RCC_TSC_RELEASE_RESET() (RCC->AHBRSTR &= ~(RCC_AHBRSTR_TSCRST)) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +/** @brief Force or release APB1 peripheral reset. + */ +#if defined(STM32F030x8) \ + || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_USART2RST)) +#define __HAL_RCC_SPI2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_SPI2RST)) + +#define __HAL_RCC_USART2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_USART2RST)) +#define __HAL_RCC_SPI2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_SPI2RST)) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || STM32F070x6 || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F031x6) || defined(STM32F038xx)\ + || defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_TIM2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM2RST)) + +#define __HAL_RCC_TIM2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM2RST)) + +#endif /* STM32F031x6 || STM32F038xx || */ + /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F030x8) \ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM6_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM6RST)) +#define __HAL_RCC_I2C2_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_I2C2RST)) + +#define __HAL_RCC_TIM6_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM6RST)) +#define __HAL_RCC_I2C2_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_I2C2RST)) + +#endif /* STM32F030x8 || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_DAC1_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_DACRST)) + +#define __HAL_RCC_DAC1_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_DACRST)) + +#endif /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_CEC_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_CECRST)) + +#define __HAL_RCC_CEC_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_CECRST)) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM7_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_TIM7RST)) +#define __HAL_RCC_USART3_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_USART3RST)) +#define __HAL_RCC_USART4_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_USART4RST)) + +#define __HAL_RCC_TIM7_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_TIM7RST)) +#define __HAL_RCC_USART3_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_USART3RST)) +#define __HAL_RCC_USART4_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_USART4RST)) + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) + +#define __HAL_RCC_USB_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_USBRST)) + +#define __HAL_RCC_USB_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_USBRST)) + +#endif /* STM32F042x6 || STM32F048xx || STM32F070x6 || */ + /* STM32F072xB || STM32F078xx || STM32F070xB */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_CAN1_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_CANRST)) + +#define __HAL_RCC_CAN1_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_CANRST)) + +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(CRS) + +#define __HAL_RCC_CRS_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_CRSRST)) + +#define __HAL_RCC_CRS_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_CRSRST)) + +#endif /* CRS */ + +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART5_FORCE_RESET() (RCC->APB1RSTR |= (RCC_APB1RSTR_USART5RST)) + +#define __HAL_RCC_USART5_RELEASE_RESET() (RCC->APB1RSTR &= ~(RCC_APB1RSTR_USART5RST)) + +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + + +/** @brief Force or release APB2 peripheral reset. + */ +#if defined(STM32F030x8) || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM15_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_TIM15RST)) + +#define __HAL_RCC_TIM15_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_TIM15RST)) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || STM32F070x6 || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART6_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_USART6RST)) + +#define __HAL_RCC_USART6_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_USART6RST)) + +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_USART7_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_USART7RST)) +#define __HAL_RCC_USART8_FORCE_RESET() (RCC->APB2RSTR |= (RCC_APB2RSTR_USART8RST)) + +#define __HAL_RCC_USART7_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_USART7RST)) +#define __HAL_RCC_USART8_RELEASE_RESET() (RCC->APB2RSTR &= ~(RCC_APB2RSTR_USART8RST)) + +#endif /* STM32F091xC || STM32F098xx */ + +/** + * @} + */ + +/** @defgroup RCCEx_Peripheral_Clock_Enable_Disable_Status Peripheral Clock Enable Disable Status + * @brief Get the enable or disable status of peripheral clock. + * @note After reset, the peripheral clock (used for registers read/write access) + * is disabled and the application software has to enable this clock before + * using it. + * @{ + */ +/** @brief AHB Peripheral Clock Enable Disable Status + */ +#if defined(GPIOD) + +#define __HAL_RCC_GPIOD_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIODEN)) != RESET) +#define __HAL_RCC_GPIOD_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIODEN)) == RESET) + +#endif /* GPIOD */ + +#if defined(GPIOE) + +#define __HAL_RCC_GPIOE_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOEEN)) != RESET) +#define __HAL_RCC_GPIOE_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_GPIOEEN)) == RESET) + +#endif /* GPIOE */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_TSC_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_TSCEN)) != RESET) +#define __HAL_RCC_TSC_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_TSCEN)) == RESET) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_DMA2_IS_CLK_ENABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA2EN)) != RESET) +#define __HAL_RCC_DMA2_IS_CLK_DISABLED() ((RCC->AHBENR & (RCC_AHBENR_DMA2EN)) == RESET) + +#endif /* STM32F091xC || STM32F098xx */ + +/** @brief APB1 Peripheral Clock Enable Disable Status + */ +#if defined(STM32F030x8)\ + || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART2EN)) != RESET) +#define __HAL_RCC_USART2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART2EN)) == RESET) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || STM32F070x6 || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F030x8)\ + || defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_SPI2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) != RESET) +#define __HAL_RCC_SPI2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_SPI2EN)) == RESET) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F031x6) || defined(STM32F038xx)\ + || defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_TIM2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM2EN)) != RESET) +#define __HAL_RCC_TIM2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM2EN)) == RESET) + +#endif /* STM32F031x6 || STM32F038xx || */ + /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F030x8) \ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM6_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM6EN)) != RESET) +#define __HAL_RCC_I2C2_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) != RESET) +#define __HAL_RCC_TIM6_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM6EN)) == RESET) +#define __HAL_RCC_I2C2_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_I2C2EN)) == RESET) + +#endif /* STM32F030x8 || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_DAC1_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_DAC1EN)) != RESET) +#define __HAL_RCC_DAC1_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_DAC1EN)) == RESET) + +#endif /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_CEC_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CECEN)) != RESET) +#define __HAL_RCC_CEC_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CECEN)) == RESET) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM7_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM7EN)) != RESET) +#define __HAL_RCC_USART3_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART3EN)) != RESET) +#define __HAL_RCC_USART4_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART4EN)) != RESET) +#define __HAL_RCC_TIM7_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_TIM7EN)) == RESET) +#define __HAL_RCC_USART3_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART3EN)) == RESET) +#define __HAL_RCC_USART4_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART4EN)) == RESET) + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) + +#define __HAL_RCC_USB_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USBEN)) != RESET) +#define __HAL_RCC_USB_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USBEN)) == RESET) + +#endif /* STM32F042x6 || STM32F048xx || STM32F070x6 || */ + /* STM32F072xB || STM32F078xx || STM32F070xB */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_CAN1_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CAN1EN)) != RESET) +#define __HAL_RCC_CAN1_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CAN1EN)) == RESET) + +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(CRS) + +#define __HAL_RCC_CRS_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CRSEN)) != RESET) +#define __HAL_RCC_CRS_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_CRSEN)) == RESET) + +#endif /* CRS */ + +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART5_IS_CLK_ENABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART5EN)) != RESET) +#define __HAL_RCC_USART5_IS_CLK_DISABLED() ((RCC->APB1ENR & (RCC_APB1ENR_USART5EN)) == RESET) + +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + +/** @brief APB1 Peripheral Clock Enable Disable Status + */ +#if defined(STM32F030x8) || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB)\ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_TIM15_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM15EN)) != RESET) +#define __HAL_RCC_TIM15_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_TIM15EN)) == RESET) + +#endif /* STM32F030x8 || STM32F042x6 || STM32F048xx || STM32F070x6 || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || */ + /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + +#define __HAL_RCC_USART6_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART6EN)) != RESET) +#define __HAL_RCC_USART6_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART6EN)) == RESET) + +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + +#define __HAL_RCC_USART7_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART7EN)) != RESET) +#define __HAL_RCC_USART8_IS_CLK_ENABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART8EN)) != RESET) +#define __HAL_RCC_USART7_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART7EN)) == RESET) +#define __HAL_RCC_USART8_IS_CLK_DISABLED() ((RCC->APB2ENR & (RCC_APB2ENR_USART8EN)) == RESET) + +#endif /* STM32F091xC || STM32F098xx */ +/** + * @} + */ + + +/** @defgroup RCCEx_HSI48_Enable_Disable RCCEx HSI48 Enable Disable + * @brief Macros to enable or disable the Internal 48Mhz High Speed oscillator (HSI48). + * @note The HSI48 is stopped by hardware when entering STOP and STANDBY modes. + * @note HSI48 can not be stopped if it is used as system clock source. In this case, + * you have to select another source of the system clock then stop the HSI14. + * @note After enabling the HSI48 with __HAL_RCC_HSI48_ENABLE(), the application software + * should wait on HSI48RDY flag to be set indicating that HSI48 clock is stable and can be + * used as system clock source. This is not necessary if HAL_RCC_OscConfig() is used. + * @note When the HSI48 is stopped, HSI48RDY flag goes low after 6 HSI48 oscillator + * clock cycles. + * @{ + */ +#if defined(RCC_HSI48_SUPPORT) + +#define __HAL_RCC_HSI48_ENABLE() SET_BIT(RCC->CR2, RCC_CR2_HSI48ON) +#define __HAL_RCC_HSI48_DISABLE() CLEAR_BIT(RCC->CR2, RCC_CR2_HSI48ON) + +/** @brief Macro to get the Internal 48Mhz High Speed oscillator (HSI48) state. + * @retval The clock source can be one of the following values: + * @arg @ref RCC_HSI48_ON HSI48 enabled + * @arg @ref RCC_HSI48_OFF HSI48 disabled + */ +#define __HAL_RCC_GET_HSI48_STATE() \ + (((uint32_t)(READ_BIT(RCC->CR2, RCC_CR2_HSI48ON)) != RESET) ? RCC_HSI48_ON : RCC_HSI48_OFF) + +#endif /* RCC_HSI48_SUPPORT */ + +/** + * @} + */ + +/** @defgroup RCCEx_Peripheral_Clock_Source_Config RCCEx Peripheral Clock Source Config + * @{ + */ +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F070x6) || defined(STM32F070xB) + +/** @brief Macro to configure the USB clock (USBCLK). + * @param __USBCLKSOURCE__ specifies the USB clock source. + * This parameter can be one of the following values: +@if STM32F070xB +@elseif STM32F070x6 +@else + * @arg @ref RCC_USBCLKSOURCE_HSI48 HSI48 selected as USB clock +@endif + * @arg @ref RCC_USBCLKSOURCE_PLL PLL Clock selected as USB clock + */ +#define __HAL_RCC_USB_CONFIG(__USBCLKSOURCE__) \ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_USBSW, (uint32_t)(__USBCLKSOURCE__)) + +/** @brief Macro to get the USB clock source. + * @retval The clock source can be one of the following values: +@if STM32F070xB +@elseif STM32F070x6 +@else + * @arg @ref RCC_USBCLKSOURCE_HSI48 HSI48 selected as USB clock +@endif + * @arg @ref RCC_USBCLKSOURCE_PLL PLL Clock selected as USB clock + */ +#define __HAL_RCC_GET_USB_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_USBSW))) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F072xB || STM32F078xx || */ + /* STM32F070x6 || STM32F070xB */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + +/** @brief Macro to configure the CEC clock. + * @param __CECCLKSOURCE__ specifies the CEC clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_CECCLKSOURCE_HSI HSI selected as CEC clock + * @arg @ref RCC_CECCLKSOURCE_LSE LSE selected as CEC clock + */ +#define __HAL_RCC_CEC_CONFIG(__CECCLKSOURCE__) \ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_CECSW, (uint32_t)(__CECCLKSOURCE__)) + +/** @brief Macro to get the HDMI CEC clock source. + * @retval The clock source can be one of the following values: + * @arg @ref RCC_CECCLKSOURCE_HSI HSI selected as CEC clock + * @arg @ref RCC_CECCLKSOURCE_LSE LSE selected as CEC clock + */ +#define __HAL_RCC_GET_CEC_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_CECSW))) + +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || defined(STM32F098xx) */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) +/** @brief Macro to configure the USART2 clock (USART2CLK). + * @param __USART2CLKSOURCE__ specifies the USART2 clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_USART2CLKSOURCE_PCLK1 PCLK1 selected as USART2 clock + * @arg @ref RCC_USART2CLKSOURCE_HSI HSI selected as USART2 clock + * @arg @ref RCC_USART2CLKSOURCE_SYSCLK System Clock selected as USART2 clock + * @arg @ref RCC_USART2CLKSOURCE_LSE LSE selected as USART2 clock + */ +#define __HAL_RCC_USART2_CONFIG(__USART2CLKSOURCE__) \ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_USART2SW, (uint32_t)(__USART2CLKSOURCE__)) + +/** @brief Macro to get the USART2 clock source. + * @retval The clock source can be one of the following values: + * @arg @ref RCC_USART2CLKSOURCE_PCLK1 PCLK1 selected as USART2 clock + * @arg @ref RCC_USART2CLKSOURCE_HSI HSI selected as USART2 clock + * @arg @ref RCC_USART2CLKSOURCE_SYSCLK System Clock selected as USART2 clock + * @arg @ref RCC_USART2CLKSOURCE_LSE LSE selected as USART2 clock + */ +#define __HAL_RCC_GET_USART2_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_USART2SW))) +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F091xC || STM32F098xx*/ + +#if defined(STM32F091xC) || defined(STM32F098xx) +/** @brief Macro to configure the USART3 clock (USART3CLK). + * @param __USART3CLKSOURCE__ specifies the USART3 clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_USART3CLKSOURCE_PCLK1 PCLK1 selected as USART3 clock + * @arg @ref RCC_USART3CLKSOURCE_HSI HSI selected as USART3 clock + * @arg @ref RCC_USART3CLKSOURCE_SYSCLK System Clock selected as USART3 clock + * @arg @ref RCC_USART3CLKSOURCE_LSE LSE selected as USART3 clock + */ +#define __HAL_RCC_USART3_CONFIG(__USART3CLKSOURCE__) \ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_USART3SW, (uint32_t)(__USART3CLKSOURCE__)) + +/** @brief Macro to get the USART3 clock source. + * @retval The clock source can be one of the following values: + * @arg @ref RCC_USART3CLKSOURCE_PCLK1 PCLK1 selected as USART3 clock + * @arg @ref RCC_USART3CLKSOURCE_HSI HSI selected as USART3 clock + * @arg @ref RCC_USART3CLKSOURCE_SYSCLK System Clock selected as USART3 clock + * @arg @ref RCC_USART3CLKSOURCE_LSE LSE selected as USART3 clock + */ +#define __HAL_RCC_GET_USART3_SOURCE() ((uint32_t)(READ_BIT(RCC->CFGR3, RCC_CFGR3_USART3SW))) + +#endif /* STM32F091xC || STM32F098xx */ +/** + * @} + */ + +/** @defgroup RCCEx_LSE_Configuration LSE Drive Configuration + * @{ + */ + +/** + * @brief Macro to configure the External Low Speed oscillator (LSE) drive capability. + * @param __RCC_LSEDRIVE__ specifies the new state of the LSE drive capability. + * This parameter can be one of the following values: + * @arg @ref RCC_LSEDRIVE_LOW LSE oscillator low drive capability. + * @arg @ref RCC_LSEDRIVE_MEDIUMLOW LSE oscillator medium low drive capability. + * @arg @ref RCC_LSEDRIVE_MEDIUMHIGH LSE oscillator medium high drive capability. + * @arg @ref RCC_LSEDRIVE_HIGH LSE oscillator high drive capability. + * @retval None + */ +#define __HAL_RCC_LSEDRIVE_CONFIG(__RCC_LSEDRIVE__) (MODIFY_REG(RCC->BDCR,\ + RCC_BDCR_LSEDRV, (uint32_t)(__RCC_LSEDRIVE__) )) + +/** + * @} + */ + +#if defined(CRS) + +/** @defgroup RCCEx_IT_And_Flag RCCEx IT and Flag + * @{ + */ +/* Interrupt & Flag management */ + +/** + * @brief Enable the specified CRS interrupts. + * @param __INTERRUPT__ specifies the CRS interrupt sources to be enabled. + * This parameter can be any combination of the following values: + * @arg @ref RCC_CRS_IT_SYNCOK SYNC event OK interrupt + * @arg @ref RCC_CRS_IT_SYNCWARN SYNC warning interrupt + * @arg @ref RCC_CRS_IT_ERR Synchronization or trimming error interrupt + * @arg @ref RCC_CRS_IT_ESYNC Expected SYNC interrupt + * @retval None + */ +#define __HAL_RCC_CRS_ENABLE_IT(__INTERRUPT__) SET_BIT(CRS->CR, (__INTERRUPT__)) + +/** + * @brief Disable the specified CRS interrupts. + * @param __INTERRUPT__ specifies the CRS interrupt sources to be disabled. + * This parameter can be any combination of the following values: + * @arg @ref RCC_CRS_IT_SYNCOK SYNC event OK interrupt + * @arg @ref RCC_CRS_IT_SYNCWARN SYNC warning interrupt + * @arg @ref RCC_CRS_IT_ERR Synchronization or trimming error interrupt + * @arg @ref RCC_CRS_IT_ESYNC Expected SYNC interrupt + * @retval None + */ +#define __HAL_RCC_CRS_DISABLE_IT(__INTERRUPT__) CLEAR_BIT(CRS->CR, (__INTERRUPT__)) + +/** @brief Check whether the CRS interrupt has occurred or not. + * @param __INTERRUPT__ specifies the CRS interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref RCC_CRS_IT_SYNCOK SYNC event OK interrupt + * @arg @ref RCC_CRS_IT_SYNCWARN SYNC warning interrupt + * @arg @ref RCC_CRS_IT_ERR Synchronization or trimming error interrupt + * @arg @ref RCC_CRS_IT_ESYNC Expected SYNC interrupt + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_RCC_CRS_GET_IT_SOURCE(__INTERRUPT__) ((READ_BIT(CRS->CR, (__INTERRUPT__)) != RESET) ? SET : RESET) + +/** @brief Clear the CRS interrupt pending bits + * @param __INTERRUPT__ specifies the interrupt pending bit to clear. + * This parameter can be any combination of the following values: + * @arg @ref RCC_CRS_IT_SYNCOK SYNC event OK interrupt + * @arg @ref RCC_CRS_IT_SYNCWARN SYNC warning interrupt + * @arg @ref RCC_CRS_IT_ERR Synchronization or trimming error interrupt + * @arg @ref RCC_CRS_IT_ESYNC Expected SYNC interrupt + * @arg @ref RCC_CRS_IT_TRIMOVF Trimming overflow or underflow interrupt + * @arg @ref RCC_CRS_IT_SYNCERR SYNC error interrupt + * @arg @ref RCC_CRS_IT_SYNCMISS SYNC missed interrupt + */ +#define __HAL_RCC_CRS_CLEAR_IT(__INTERRUPT__) do { \ + if(((__INTERRUPT__) & RCC_CRS_IT_ERROR_MASK) != RESET) \ + { \ + WRITE_REG(CRS->ICR, CRS_ICR_ERRC | ((__INTERRUPT__) & ~RCC_CRS_IT_ERROR_MASK)); \ + } \ + else \ + { \ + WRITE_REG(CRS->ICR, (__INTERRUPT__)); \ + } \ + } while(0U) + +/** + * @brief Check whether the specified CRS flag is set or not. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref RCC_CRS_FLAG_SYNCOK SYNC event OK + * @arg @ref RCC_CRS_FLAG_SYNCWARN SYNC warning + * @arg @ref RCC_CRS_FLAG_ERR Error + * @arg @ref RCC_CRS_FLAG_ESYNC Expected SYNC + * @arg @ref RCC_CRS_FLAG_TRIMOVF Trimming overflow or underflow + * @arg @ref RCC_CRS_FLAG_SYNCERR SYNC error + * @arg @ref RCC_CRS_FLAG_SYNCMISS SYNC missed + * @retval The new state of _FLAG_ (TRUE or FALSE). + */ +#define __HAL_RCC_CRS_GET_FLAG(__FLAG__) (READ_BIT(CRS->ISR, (__FLAG__)) == (__FLAG__)) + +/** + * @brief Clear the CRS specified FLAG. + * @param __FLAG__ specifies the flag to clear. + * This parameter can be one of the following values: + * @arg @ref RCC_CRS_FLAG_SYNCOK SYNC event OK + * @arg @ref RCC_CRS_FLAG_SYNCWARN SYNC warning + * @arg @ref RCC_CRS_FLAG_ERR Error + * @arg @ref RCC_CRS_FLAG_ESYNC Expected SYNC + * @arg @ref RCC_CRS_FLAG_TRIMOVF Trimming overflow or underflow + * @arg @ref RCC_CRS_FLAG_SYNCERR SYNC error + * @arg @ref RCC_CRS_FLAG_SYNCMISS SYNC missed + * @note RCC_CRS_FLAG_ERR clears RCC_CRS_FLAG_TRIMOVF, RCC_CRS_FLAG_SYNCERR, RCC_CRS_FLAG_SYNCMISS and consequently RCC_CRS_FLAG_ERR + * @retval None + */ +#define __HAL_RCC_CRS_CLEAR_FLAG(__FLAG__) do { \ + if(((__FLAG__) & RCC_CRS_FLAG_ERROR_MASK) != RESET) \ + { \ + WRITE_REG(CRS->ICR, CRS_ICR_ERRC | ((__FLAG__) & ~RCC_CRS_FLAG_ERROR_MASK)); \ + } \ + else \ + { \ + WRITE_REG(CRS->ICR, (__FLAG__)); \ + } \ + } while(0U) + +/** + * @} + */ + +/** @defgroup RCCEx_CRS_Extended_Features RCCEx CRS Extended Features + * @{ + */ +/** + * @brief Enable the oscillator clock for frequency error counter. + * @note when the CEN bit is set the CRS_CFGR register becomes write-protected. + * @retval None + */ +#define __HAL_RCC_CRS_FREQ_ERROR_COUNTER_ENABLE() SET_BIT(CRS->CR, CRS_CR_CEN) + +/** + * @brief Disable the oscillator clock for frequency error counter. + * @retval None + */ +#define __HAL_RCC_CRS_FREQ_ERROR_COUNTER_DISABLE() CLEAR_BIT(CRS->CR, CRS_CR_CEN) + +/** + * @brief Enable the automatic hardware adjustment of TRIM bits. + * @note When the AUTOTRIMEN bit is set the CRS_CFGR register becomes write-protected. + * @retval None + */ +#define __HAL_RCC_CRS_AUTOMATIC_CALIB_ENABLE() SET_BIT(CRS->CR, CRS_CR_AUTOTRIMEN) + +/** + * @brief Disable the automatic hardware adjustment of TRIM bits. + * @retval None + */ +#define __HAL_RCC_CRS_AUTOMATIC_CALIB_DISABLE() CLEAR_BIT(CRS->CR, CRS_CR_AUTOTRIMEN) + +/** + * @brief Macro to calculate reload value to be set in CRS register according to target and sync frequencies + * @note The RELOAD value should be selected according to the ratio between the target frequency and the frequency + * of the synchronization source after prescaling. It is then decreased by one in order to + * reach the expected synchronization on the zero value. The formula is the following: + * RELOAD = (fTARGET / fSYNC) -1 + * @param __FTARGET__ Target frequency (value in Hz) + * @param __FSYNC__ Synchronization signal frequency (value in Hz) + * @retval None + */ +#define __HAL_RCC_CRS_RELOADVALUE_CALCULATE(__FTARGET__, __FSYNC__) (((__FTARGET__) / (__FSYNC__)) - 1U) + +/** + * @} + */ + +#endif /* CRS */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup RCCEx_Exported_Functions + * @{ + */ + +/** @addtogroup RCCEx_Exported_Functions_Group1 + * @{ + */ + +HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef *PeriphClkInit); +void HAL_RCCEx_GetPeriphCLKConfig(RCC_PeriphCLKInitTypeDef *PeriphClkInit); +uint32_t HAL_RCCEx_GetPeriphCLKFreq(uint32_t PeriphClk); + +/** + * @} + */ + +#if defined(CRS) + +/** @addtogroup RCCEx_Exported_Functions_Group3 + * @{ + */ + +void HAL_RCCEx_CRSConfig(RCC_CRSInitTypeDef *pInit); +void HAL_RCCEx_CRSSoftwareSynchronizationGenerate(void); +void HAL_RCCEx_CRSGetSynchronizationInfo(RCC_CRSSynchroInfoTypeDef *pSynchroInfo); +uint32_t HAL_RCCEx_CRSWaitSynchronization(uint32_t Timeout); +void HAL_RCCEx_CRS_IRQHandler(void); +void HAL_RCCEx_CRS_SyncOkCallback(void); +void HAL_RCCEx_CRS_SyncWarnCallback(void); +void HAL_RCCEx_CRS_ExpectedSyncCallback(void); +void HAL_RCCEx_CRS_ErrorCallback(uint32_t Error); + +/** + * @} + */ + +#endif /* CRS */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_RCC_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc.h new file mode 100644 index 0000000..9b110b6 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc.h @@ -0,0 +1,854 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rtc.h + * @author MCD Application Team + * @brief Header file of RTC HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_RTC_H +#define __STM32F0xx_HAL_RTC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup RTC RTC + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup RTC_Exported_Types RTC Exported Types + * @{ + */ + +/** + * @brief HAL State structures definition + */ +typedef enum +{ + HAL_RTC_STATE_RESET = 0x00U, /*!< RTC not yet initialized or disabled */ + HAL_RTC_STATE_READY = 0x01U, /*!< RTC initialized and ready for use */ + HAL_RTC_STATE_BUSY = 0x02U, /*!< RTC process is ongoing */ + HAL_RTC_STATE_TIMEOUT = 0x03U, /*!< RTC timeout state */ + HAL_RTC_STATE_ERROR = 0x04U /*!< RTC error state */ + +} HAL_RTCStateTypeDef; + +/** + * @brief RTC Configuration Structure definition + */ +typedef struct +{ + uint32_t HourFormat; /*!< Specifies the RTC Hour Format. + This parameter can be a value of @ref RTC_Hour_Formats */ + + uint32_t AsynchPrediv; /*!< Specifies the RTC Asynchronous Predivider value. + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x7F */ + + uint32_t SynchPrediv; /*!< Specifies the RTC Synchronous Predivider value. + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x7FFF */ + + uint32_t OutPut; /*!< Specifies which signal will be routed to the RTC output. + This parameter can be a value of @ref RTCEx_Output_selection_Definitions */ + + uint32_t OutPutPolarity; /*!< Specifies the polarity of the output signal. + This parameter can be a value of @ref RTC_Output_Polarity_Definitions */ + + uint32_t OutPutType; /*!< Specifies the RTC Output Pin mode. + This parameter can be a value of @ref RTC_Output_Type_ALARM_OUT */ +} RTC_InitTypeDef; + +/** + * @brief RTC Time structure definition + */ +typedef struct +{ + uint8_t Hours; /*!< Specifies the RTC Time Hour. + This parameter must be a number between Min_Data = 0 and Max_Data = 12 if the RTC_HourFormat_12 is selected. + This parameter must be a number between Min_Data = 0 and Max_Data = 23 if the RTC_HourFormat_24 is selected */ + + uint8_t Minutes; /*!< Specifies the RTC Time Minutes. + This parameter must be a number between Min_Data = 0 and Max_Data = 59 */ + + uint8_t Seconds; /*!< Specifies the RTC Time Seconds. + This parameter must be a number between Min_Data = 0 and Max_Data = 59 */ + + uint8_t TimeFormat; /*!< Specifies the RTC AM/PM Time. + This parameter can be a value of @ref RTC_AM_PM_Definitions */ + + uint32_t SubSeconds; /*!< Specifies the RTC_SSR RTC Sub Second register content. + This parameter corresponds to a time unit range between [0-1] Second + with [1 Sec / SecondFraction +1] granularity */ + + uint32_t SecondFraction; /*!< Specifies the range or granularity of Sub Second register content + corresponding to Synchronous pre-scaler factor value (PREDIV_S) + This parameter corresponds to a time unit range between [0-1] Second + with [1 Sec / SecondFraction +1] granularity. + This field will be used only by HAL_RTC_GetTime function */ + + uint32_t DayLightSaving; /*!< This interface is deprecated. To manage Daylight + Saving Time, please use HAL_RTC_DST_xxx functions */ + + uint32_t StoreOperation; /*!< This interface is deprecated. To manage Daylight + Saving Time, please use HAL_RTC_DST_xxx functions */ +} RTC_TimeTypeDef; + +/** + * @brief RTC Date structure definition + */ +typedef struct +{ + uint8_t WeekDay; /*!< Specifies the RTC Date WeekDay. + This parameter can be a value of @ref RTC_WeekDay_Definitions */ + + uint8_t Month; /*!< Specifies the RTC Date Month (in BCD format). + This parameter can be a value of @ref RTC_Month_Date_Definitions */ + + uint8_t Date; /*!< Specifies the RTC Date. + This parameter must be a number between Min_Data = 1 and Max_Data = 31 */ + + uint8_t Year; /*!< Specifies the RTC Date Year. + This parameter must be a number between Min_Data = 0 and Max_Data = 99 */ + +} RTC_DateTypeDef; + +/** + * @brief RTC Alarm structure definition + */ +typedef struct +{ + RTC_TimeTypeDef AlarmTime; /*!< Specifies the RTC Alarm Time members */ + + uint32_t AlarmMask; /*!< Specifies the RTC Alarm Masks. + This parameter can be a value of @ref RTC_AlarmMask_Definitions */ + + uint32_t AlarmSubSecondMask; /*!< Specifies the RTC Alarm SubSeconds Masks. + This parameter can be a value of @ref RTC_Alarm_Sub_Seconds_Masks_Definitions */ + + uint32_t AlarmDateWeekDaySel; /*!< Specifies the RTC Alarm is on Date or WeekDay. + This parameter can be a value of @ref RTC_AlarmDateWeekDay_Definitions */ + + uint8_t AlarmDateWeekDay; /*!< Specifies the RTC Alarm Date/WeekDay. + If the Alarm Date is selected, this parameter must be set to a value in the 1-31 range. + If the Alarm WeekDay is selected, this parameter can be a value of @ref RTC_WeekDay_Definitions */ + + uint32_t Alarm; /*!< Specifies the alarm . + This parameter can be a value of @ref RTC_Alarms_Definitions */ +} RTC_AlarmTypeDef; + +/** + * @brief RTC Handle Structure definition + */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) +typedef struct __RTC_HandleTypeDef +#else +typedef struct +#endif /* (USE_HAL_RTC_REGISTER_CALLBACKS) */ +{ + RTC_TypeDef *Instance; /*!< Register base address */ + + RTC_InitTypeDef Init; /*!< RTC required parameters */ + + HAL_LockTypeDef Lock; /*!< RTC locking object */ + + __IO HAL_RTCStateTypeDef State; /*!< Time communication state */ + +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + void (* AlarmAEventCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC Alarm A Event callback */ + + void (* TimeStampEventCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC TimeStamp Event callback */ + +#if defined(RTC_WAKEUP_SUPPORT) + void (* WakeUpTimerEventCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC WakeUpTimer Event callback */ + +#endif /* RTC_WAKEUP_SUPPORT */ + void (* Tamper1EventCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC Tamper 1 Event callback */ + + void (* Tamper2EventCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC Tamper 2 Event callback */ + +#if defined(RTC_TAMPER3_SUPPORT) + void (* Tamper3EventCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC Tamper 3 Event callback */ + +#endif /* RTC_TAMPER3_SUPPORT */ + void (* MspInitCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC Msp Init callback */ + + void (* MspDeInitCallback)(struct __RTC_HandleTypeDef *hrtc); /*!< RTC Msp DeInit callback */ + +#endif /* (USE_HAL_RTC_REGISTER_CALLBACKS) */ + +} RTC_HandleTypeDef; + +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) +/** + * @brief HAL RTC Callback ID enumeration definition + */ +typedef enum +{ + HAL_RTC_ALARM_A_EVENT_CB_ID = 0x00u, /*!< RTC Alarm A Event Callback ID */ + HAL_RTC_TIMESTAMP_EVENT_CB_ID = 0x02u, /*!< RTC TimeStamp Event Callback ID */ +#if defined(RTC_WAKEUP_SUPPORT) + HAL_RTC_WAKEUPTIMER_EVENT_CB_ID = 0x03u, /*!< RTC WakeUp Timer Event Callback ID */ +#endif /* RTC_WAKEUP_SUPPORT */ + HAL_RTC_TAMPER1_EVENT_CB_ID = 0x04u, /*!< RTC Tamper 1 Callback ID */ + HAL_RTC_TAMPER2_EVENT_CB_ID = 0x05u, /*!< RTC Tamper 2 Callback ID */ +#if defined(RTC_TAMPER3_SUPPORT) + HAL_RTC_TAMPER3_EVENT_CB_ID = 0x06u, /*!< RTC Tamper 3 Callback ID */ +#endif /* RTC_TAMPER3_SUPPORT */ + HAL_RTC_MSPINIT_CB_ID = 0x0Eu, /*!< RTC Msp Init callback ID */ + HAL_RTC_MSPDEINIT_CB_ID = 0x0Fu /*!< RTC Msp DeInit callback ID */ +} HAL_RTC_CallbackIDTypeDef; + +/** + * @brief HAL RTC Callback pointer definition + */ +typedef void (*pRTC_CallbackTypeDef)(RTC_HandleTypeDef *hrtc); /*!< pointer to an RTC callback function */ +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup RTC_Exported_Constants RTC Exported Constants + * @{ + */ + +/** @defgroup RTC_Hour_Formats RTC Hour Formats + * @{ + */ +#define RTC_HOURFORMAT_24 0x00000000U +#define RTC_HOURFORMAT_12 0x00000040U + +/** + * @} + */ + +/** @defgroup RTC_Output_Polarity_Definitions RTC Output Polarity Definitions + * @{ + */ +#define RTC_OUTPUT_POLARITY_HIGH 0x00000000U +#define RTC_OUTPUT_POLARITY_LOW 0x00100000U +/** + * @} + */ + +/** @defgroup RTC_Output_Type_ALARM_OUT RTC Output Type ALARM OUT + * @{ + */ +#define RTC_OUTPUT_TYPE_OPENDRAIN 0x00000000U +#define RTC_OUTPUT_TYPE_PUSHPULL 0x00040000U +/** + * @} + */ + +/** @defgroup RTC_AM_PM_Definitions RTC AM PM Definitions + * @{ + */ +#define RTC_HOURFORMAT12_AM ((uint8_t)0x00) +#define RTC_HOURFORMAT12_PM ((uint8_t)0x40) +/** + * @} + */ + +/** @defgroup RTC_DayLightSaving_Definitions RTC DayLight Saving Definitions + * @{ + */ +#define RTC_DAYLIGHTSAVING_SUB1H 0x00020000U +#define RTC_DAYLIGHTSAVING_ADD1H 0x00010000U +#define RTC_DAYLIGHTSAVING_NONE 0x00000000U +/** + * @} + */ + +/** @defgroup RTC_StoreOperation_Definitions RTC Store Operation Definitions + * @{ + */ +#define RTC_STOREOPERATION_RESET 0x00000000U +#define RTC_STOREOPERATION_SET 0x00040000U +/** + * @} + */ + +/** @defgroup RTC_Input_parameter_format_definitions RTC Input parameter format definitions + * @{ + */ +#define RTC_FORMAT_BIN 0x000000000U +#define RTC_FORMAT_BCD 0x000000001U +/** + * @} + */ + +/** @defgroup RTC_Month_Date_Definitions RTC Month Date Definitions + * @{ + */ +/* Coded in BCD format */ +#define RTC_MONTH_JANUARY ((uint8_t)0x01) +#define RTC_MONTH_FEBRUARY ((uint8_t)0x02) +#define RTC_MONTH_MARCH ((uint8_t)0x03) +#define RTC_MONTH_APRIL ((uint8_t)0x04) +#define RTC_MONTH_MAY ((uint8_t)0x05) +#define RTC_MONTH_JUNE ((uint8_t)0x06) +#define RTC_MONTH_JULY ((uint8_t)0x07) +#define RTC_MONTH_AUGUST ((uint8_t)0x08) +#define RTC_MONTH_SEPTEMBER ((uint8_t)0x09) +#define RTC_MONTH_OCTOBER ((uint8_t)0x10) +#define RTC_MONTH_NOVEMBER ((uint8_t)0x11) +#define RTC_MONTH_DECEMBER ((uint8_t)0x12) +/** + * @} + */ + +/** @defgroup RTC_WeekDay_Definitions RTC WeekDay Definitions + * @{ + */ +#define RTC_WEEKDAY_MONDAY ((uint8_t)0x01) +#define RTC_WEEKDAY_TUESDAY ((uint8_t)0x02) +#define RTC_WEEKDAY_WEDNESDAY ((uint8_t)0x03) +#define RTC_WEEKDAY_THURSDAY ((uint8_t)0x04) +#define RTC_WEEKDAY_FRIDAY ((uint8_t)0x05) +#define RTC_WEEKDAY_SATURDAY ((uint8_t)0x06) +#define RTC_WEEKDAY_SUNDAY ((uint8_t)0x07) +/** + * @} + */ + +/** @defgroup RTC_AlarmDateWeekDay_Definitions RTC Alarm Date WeekDay Definitions + * @{ + */ +#define RTC_ALARMDATEWEEKDAYSEL_DATE 0x00000000U +#define RTC_ALARMDATEWEEKDAYSEL_WEEKDAY 0x40000000U +/** + * @} + */ + +/** @defgroup RTC_AlarmMask_Definitions RTC Alarm Mask Definitions + * @{ + */ +#define RTC_ALARMMASK_NONE 0x00000000U +#define RTC_ALARMMASK_DATEWEEKDAY RTC_ALRMAR_MSK4 +#define RTC_ALARMMASK_HOURS RTC_ALRMAR_MSK3 +#define RTC_ALARMMASK_MINUTES RTC_ALRMAR_MSK2 +#define RTC_ALARMMASK_SECONDS RTC_ALRMAR_MSK1 +#define RTC_ALARMMASK_ALL 0x80808080U +/** + * @} + */ + +/** @defgroup RTC_Alarms_Definitions RTC Alarms Definitions + * @{ + */ +#define RTC_ALARM_A RTC_CR_ALRAE + +/** + * @} + */ + +/** @defgroup RTC_Alarm_Sub_Seconds_Masks_Definitions RTC Alarm Sub Seconds Masks Definitions + * @{ + */ +#define RTC_ALARMSUBSECONDMASK_ALL 0x00000000U /*!< All Alarm SS fields are masked. + There is no comparison on sub seconds + for Alarm */ +#define RTC_ALARMSUBSECONDMASK_SS14_1 0x01000000U /*!< SS[14:1] are don't care in Alarm + comparison. Only SS[0] is compared. */ +#define RTC_ALARMSUBSECONDMASK_SS14_2 0x02000000U /*!< SS[14:2] are don't care in Alarm + comparison. Only SS[1:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_3 0x03000000U /*!< SS[14:3] are don't care in Alarm + comparison. Only SS[2:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_4 0x04000000U /*!< SS[14:4] are don't care in Alarm + comparison. Only SS[3:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_5 0x05000000U /*!< SS[14:5] are don't care in Alarm + comparison. Only SS[4:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_6 0x06000000U /*!< SS[14:6] are don't care in Alarm + comparison. Only SS[5:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_7 0x07000000U /*!< SS[14:7] are don't care in Alarm + comparison. Only SS[6:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_8 0x08000000U /*!< SS[14:8] are don't care in Alarm + comparison. Only SS[7:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_9 0x09000000U /*!< SS[14:9] are don't care in Alarm + comparison. Only SS[8:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_10 0x0A000000U /*!< SS[14:10] are don't care in Alarm + comparison. Only SS[9:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_11 0x0B000000U /*!< SS[14:11] are don't care in Alarm + comparison. Only SS[10:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_12 0x0C000000U /*!< SS[14:12] are don't care in Alarm + comparison.Only SS[11:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14_13 0x0D000000U /*!< SS[14:13] are don't care in Alarm + comparison. Only SS[12:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_SS14 0x0E000000U /*!< SS[14] is don't care in Alarm + comparison.Only SS[13:0] are compared */ +#define RTC_ALARMSUBSECONDMASK_NONE 0x0F000000U /*!< SS[14:0] are compared and must match + to activate alarm. */ +/** + * @} + */ + +/** @defgroup RTC_Interrupts_Definitions RTC Interrupts Definitions + * @{ + */ +#define RTC_IT_TS 0x00008000U +#define RTC_IT_WUT 0x00004000U +#define RTC_IT_ALRA 0x00001000U +#define RTC_IT_TAMP 0x00000004U /* Used only to Enable the Tamper Interrupt */ +#define RTC_IT_TAMP1 0x00020000U /*only for RTC_ISR flag check*/ +#define RTC_IT_TAMP2 0x00040000U /*only for RTC_ISR flag check*/ +#define RTC_IT_TAMP3 0x00080000U /*only for RTC_ISR flag check*/ +/** + * @} + */ + +/** @defgroup RTC_Flags_Definitions RTC Flags Definitions + * @{ + */ +#define RTC_FLAG_RECALPF 0x00010000U +#define RTC_FLAG_TAMP3F 0x00008000U +#define RTC_FLAG_TAMP2F 0x00004000U +#define RTC_FLAG_TAMP1F 0x00002000U +#define RTC_FLAG_TSOVF 0x00001000U +#define RTC_FLAG_TSF 0x00000800U +#define RTC_FLAG_WUTF 0x00000400U +#define RTC_FLAG_ALRAF 0x00000100U +#define RTC_FLAG_INITF 0x00000040U +#define RTC_FLAG_RSF 0x00000020U +#define RTC_FLAG_INITS 0x00000010U +#define RTC_FLAG_SHPF 0x00000008U +#define RTC_FLAG_WUTWF 0x00000004U +#define RTC_FLAG_ALRAWF 0x00000001U +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros ------------------------------------------------------------*/ +/** @defgroup RTC_Exported_Macros RTC Exported Macros + * @{ + */ + +/** @brief Reset RTC handle state + * @param __HANDLE__ RTC handle. + * @retval None + */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) +#define __HAL_RTC_RESET_HANDLE_STATE(__HANDLE__) do{\ + (__HANDLE__)->State = HAL_RTC_STATE_RESET;\ + (__HANDLE__)->MspInitCallback = NULL;\ + (__HANDLE__)->MspDeInitCallback = NULL;\ + }while(0u) +#else +#define __HAL_RTC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_RTC_STATE_RESET) +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + +/** + * @brief Disable the write protection for RTC registers. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_WRITEPROTECTION_DISABLE(__HANDLE__) \ + do{ \ + (__HANDLE__)->Instance->WPR = 0xCAU; \ + (__HANDLE__)->Instance->WPR = 0x53U; \ + } while(0) + +/** + * @brief Enable the write protection for RTC registers. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_WRITEPROTECTION_ENABLE(__HANDLE__) \ + do{ \ + (__HANDLE__)->Instance->WPR = 0xFFU; \ + } while(0) + +/** + * @brief Enable the RTC ALARMA peripheral. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_ALARMA_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_ALRAE)) + +/** + * @brief Disable the RTC ALARMA peripheral. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_ALARMA_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_ALRAE)) + +/** + * @brief Enable the RTC Alarm interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Alarm interrupt sources to be enabled or disabled. + * This parameter can be any combination of the following values: + * @arg RTC_IT_ALRA: Alarm A interrupt + * @retval None + */ +#define __HAL_RTC_ALARM_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR |= (__INTERRUPT__)) + +/** + * @brief Disable the RTC Alarm interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Alarm interrupt sources to be enabled or disabled. + * This parameter can be any combination of the following values: + * @arg RTC_IT_ALRA: Alarm A interrupt + * @retval None + */ +#define __HAL_RTC_ALARM_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR &= ~(__INTERRUPT__)) + +/** + * @brief Check whether the specified RTC Alarm interrupt has occurred or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Alarm interrupt to check. + * This parameter can be: + * @arg RTC_IT_ALRA: Alarm A interrupt + * @retval None + */ +#define __HAL_RTC_ALARM_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR)& ((__INTERRUPT__)>> 4U)) != RESET)? SET : RESET) + +/** + * @brief Check whether the specified RTC Alarm interrupt has been enabled or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Alarm interrupt sources to check. + * This parameter can be: + * @arg RTC_IT_ALRA: Alarm A interrupt + * @retval None + */ +#define __HAL_RTC_ALARM_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->CR) & (__INTERRUPT__)) != RESET) ? SET : RESET) + +/** + * @brief Get the selected RTC Alarm's flag status. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC Alarm Flag sources to check. + * This parameter can be: + * @arg RTC_FLAG_ALRAF + * @arg RTC_FLAG_ALRAWF + * @retval None + */ +#define __HAL_RTC_ALARM_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET)? SET : RESET) + +/** + * @brief Clear the RTC Alarm's pending flags. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC Alarm Flag sources to clear. + * This parameter can be: + * @arg RTC_FLAG_ALRAF + * @retval None + */ +#define __HAL_RTC_ALARM_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT) | ((__HANDLE__)->Instance->ISR & RTC_ISR_INIT)) + +/** + * @brief Enable interrupt on the RTC Alarm associated Exti line. + * @retval None + */ +#define __HAL_RTC_ALARM_EXTI_ENABLE_IT() (EXTI->IMR |= RTC_EXTI_LINE_ALARM_EVENT) + +/** + * @brief Disable interrupt on the RTC Alarm associated Exti line. + * @retval None + */ +#define __HAL_RTC_ALARM_EXTI_DISABLE_IT() (EXTI->IMR &= ~(RTC_EXTI_LINE_ALARM_EVENT)) + +/** + * @brief Enable event on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_ENABLE_EVENT() (EXTI->EMR |= RTC_EXTI_LINE_ALARM_EVENT) + +/** + * @brief Disable event on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_DISABLE_EVENT() (EXTI->EMR &= ~(RTC_EXTI_LINE_ALARM_EVENT)) + +/** + * @brief Enable falling edge trigger on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_ENABLE_FALLING_EDGE() (EXTI->FTSR |= RTC_EXTI_LINE_ALARM_EVENT) + +/** + * @brief Disable falling edge trigger on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_DISABLE_FALLING_EDGE() (EXTI->FTSR &= ~(RTC_EXTI_LINE_ALARM_EVENT)) + +/** + * @brief Enable rising edge trigger on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_ENABLE_RISING_EDGE() (EXTI->RTSR |= RTC_EXTI_LINE_ALARM_EVENT) + +/** + * @brief Disable rising edge trigger on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_DISABLE_RISING_EDGE() (EXTI->RTSR &= ~(RTC_EXTI_LINE_ALARM_EVENT)) + +/** + * @brief Enable rising & falling edge trigger on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_ENABLE_RISING_FALLING_EDGE() __HAL_RTC_ALARM_EXTI_ENABLE_RISING_EDGE();__HAL_RTC_ALARM_EXTI_ENABLE_FALLING_EDGE(); + +/** + * @brief Disable rising & falling edge trigger on the RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_DISABLE_RISING_FALLING_EDGE() __HAL_RTC_ALARM_EXTI_DISABLE_RISING_EDGE();__HAL_RTC_ALARM_EXTI_DISABLE_FALLING_EDGE(); + +/** + * @brief Check whether the RTC Alarm associated Exti line interrupt flag is set or not. + * @retval Line Status. + */ +#define __HAL_RTC_ALARM_EXTI_GET_FLAG() (EXTI->PR & RTC_EXTI_LINE_ALARM_EVENT) + +/** + * @brief Clear the RTC Alarm associated Exti line flag. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_CLEAR_FLAG() (EXTI->PR = RTC_EXTI_LINE_ALARM_EVENT) + +/** + * @brief Generate a Software interrupt on RTC Alarm associated Exti line. + * @retval None. + */ +#define __HAL_RTC_ALARM_EXTI_GENERATE_SWIT() (EXTI->SWIER |= RTC_EXTI_LINE_ALARM_EVENT) +/** + * @} + */ + +/* Include RTC HAL Extended module */ +#include "stm32f0xx_hal_rtc_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup RTC_Exported_Functions RTC Exported Functions + * @{ + */ + +/** @defgroup RTC_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_RTC_Init(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTC_DeInit(RTC_HandleTypeDef *hrtc); +void HAL_RTC_MspInit(RTC_HandleTypeDef *hrtc); +void HAL_RTC_MspDeInit(RTC_HandleTypeDef *hrtc); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_RTC_RegisterCallback(RTC_HandleTypeDef *hrtc, HAL_RTC_CallbackIDTypeDef CallbackID, pRTC_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_RTC_UnRegisterCallback(RTC_HandleTypeDef *hrtc, HAL_RTC_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup RTC_Exported_Functions_Group2 RTC Time and Date functions + * @{ + */ + +/* RTC Time and Date functions ************************************************/ +HAL_StatusTypeDef HAL_RTC_SetTime(RTC_HandleTypeDef *hrtc, RTC_TimeTypeDef *sTime, uint32_t Format); +HAL_StatusTypeDef HAL_RTC_GetTime(RTC_HandleTypeDef *hrtc, RTC_TimeTypeDef *sTime, uint32_t Format); +HAL_StatusTypeDef HAL_RTC_SetDate(RTC_HandleTypeDef *hrtc, RTC_DateTypeDef *sDate, uint32_t Format); +HAL_StatusTypeDef HAL_RTC_GetDate(RTC_HandleTypeDef *hrtc, RTC_DateTypeDef *sDate, uint32_t Format); + + +/* RTC Daylight Saving Time functions *****************************************/ +void HAL_RTC_DST_Add1Hour(RTC_HandleTypeDef *hrtc); +void HAL_RTC_DST_Sub1Hour(RTC_HandleTypeDef *hrtc); +void HAL_RTC_DST_SetStoreOperation(RTC_HandleTypeDef *hrtc); +void HAL_RTC_DST_ClearStoreOperation(RTC_HandleTypeDef *hrtc); +uint32_t HAL_RTC_DST_ReadStoreOperation(RTC_HandleTypeDef *hrtc); +/** + * @} + */ + +/** @defgroup RTC_Exported_Functions_Group3 RTC Alarm functions + * @{ + */ +/* RTC Alarm functions ********************************************************/ +HAL_StatusTypeDef HAL_RTC_SetAlarm(RTC_HandleTypeDef *hrtc, RTC_AlarmTypeDef *sAlarm, uint32_t Format); +HAL_StatusTypeDef HAL_RTC_SetAlarm_IT(RTC_HandleTypeDef *hrtc, RTC_AlarmTypeDef *sAlarm, uint32_t Format); +HAL_StatusTypeDef HAL_RTC_DeactivateAlarm(RTC_HandleTypeDef *hrtc, uint32_t Alarm); +HAL_StatusTypeDef HAL_RTC_GetAlarm(RTC_HandleTypeDef *hrtc, RTC_AlarmTypeDef *sAlarm, uint32_t Alarm, uint32_t Format); +void HAL_RTC_AlarmIRQHandler(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTC_PollForAlarmAEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout); +void HAL_RTC_AlarmAEventCallback(RTC_HandleTypeDef *hrtc); +/** + * @} + */ + +/** @defgroup RTC_Exported_Functions_Group4 Peripheral Control functions + * @{ + */ +/* Peripheral Control functions ***********************************************/ +HAL_StatusTypeDef HAL_RTC_WaitForSynchro(RTC_HandleTypeDef *hrtc); +/** + * @} + */ + +/** @defgroup RTC_Exported_Functions_Group5 Peripheral State functions + * @{ + */ +/* Peripheral State functions *************************************************/ +HAL_RTCStateTypeDef HAL_RTC_GetState(RTC_HandleTypeDef *hrtc); +/** + * @} + */ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup RTC_Private_Constants RTC Private Constants + * @{ + */ +/* Masks Definition */ +#define RTC_TR_RESERVED_MASK 0x007F7F7FU +#define RTC_DR_RESERVED_MASK 0x00FFFF3FU +#define RTC_INIT_MASK 0xFFFFFFFFU +#define RTC_RSF_MASK 0xFFFFFF5FU +#define RTC_FLAGS_MASK ((uint32_t) (RTC_FLAG_RECALPF | RTC_FLAG_TAMP3F | RTC_FLAG_TAMP2F | \ + RTC_FLAG_TAMP1F| RTC_FLAG_TSOVF | RTC_FLAG_TSF | \ + RTC_FLAG_WUTF | RTC_FLAG_ALRAF | \ + RTC_FLAG_INITF | RTC_FLAG_RSF | RTC_FLAG_INITS | \ + RTC_FLAG_SHPF | RTC_FLAG_WUTWF | RTC_FLAG_ALRAWF)) + +#define RTC_TIMEOUT_VALUE 1000U + +#define RTC_EXTI_LINE_ALARM_EVENT ((uint32_t)EXTI_IMR_MR17) /*!< External interrupt line 17 Connected to the RTC Alarm event */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup RTC_Private_Macros RTC Private Macros + * @{ + */ + +/** @defgroup RTC_IS_RTC_Definitions RTC Private macros to check input parameters + * @{ + */ +#define IS_RTC_HOUR_FORMAT(FORMAT) (((FORMAT) == RTC_HOURFORMAT_12) || \ + ((FORMAT) == RTC_HOURFORMAT_24)) + +#define IS_RTC_OUTPUT_POL(POL) (((POL) == RTC_OUTPUT_POLARITY_HIGH) || \ + ((POL) == RTC_OUTPUT_POLARITY_LOW)) +#define IS_RTC_OUTPUT_TYPE(TYPE) (((TYPE) == RTC_OUTPUT_TYPE_OPENDRAIN) || \ + ((TYPE) == RTC_OUTPUT_TYPE_PUSHPULL)) +#define IS_RTC_HOUR12(HOUR) (((HOUR) > 0U) && ((HOUR) <= 12U)) +#define IS_RTC_HOUR24(HOUR) ((HOUR) <= 23U) +#define IS_RTC_ASYNCH_PREDIV(PREDIV) ((PREDIV) <= 0x7FU) +#define IS_RTC_SYNCH_PREDIV(PREDIV) ((PREDIV) <= 0x7FFFU) +#define IS_RTC_MINUTES(MINUTES) ((MINUTES) <= 59U) +#define IS_RTC_SECONDS(SECONDS) ((SECONDS) <= 59U) + +#define IS_RTC_HOURFORMAT12(PM) (((PM) == RTC_HOURFORMAT12_AM) || \ + ((PM) == RTC_HOURFORMAT12_PM)) + +#define IS_RTC_DAYLIGHT_SAVING(SAVE) (((SAVE) == RTC_DAYLIGHTSAVING_SUB1H) || \ + ((SAVE) == RTC_DAYLIGHTSAVING_ADD1H) || \ + ((SAVE) == RTC_DAYLIGHTSAVING_NONE)) +#define IS_RTC_STORE_OPERATION(OPERATION) (((OPERATION) == RTC_STOREOPERATION_RESET) || \ + ((OPERATION) == RTC_STOREOPERATION_SET)) +#define IS_RTC_FORMAT(FORMAT) (((FORMAT) == RTC_FORMAT_BIN) || ((FORMAT) == RTC_FORMAT_BCD)) +#define IS_RTC_YEAR(YEAR) ((YEAR) <= 99U) +#define IS_RTC_MONTH(MONTH) (((MONTH) >= 1U) && ((MONTH) <= 12U)) +#define IS_RTC_DATE(DATE) (((DATE) >= 1U) && ((DATE) <= 31U)) +#define IS_RTC_WEEKDAY(WEEKDAY) (((WEEKDAY) == RTC_WEEKDAY_MONDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_TUESDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_WEDNESDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_THURSDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_FRIDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_SATURDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_SUNDAY)) +#define IS_RTC_ALARM_DATE_WEEKDAY_DATE(DATE) (((DATE) > 0U) && ((DATE) <= 31U)) +#define IS_RTC_ALARM_DATE_WEEKDAY_WEEKDAY(WEEKDAY) (((WEEKDAY) == RTC_WEEKDAY_MONDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_TUESDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_WEDNESDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_THURSDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_FRIDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_SATURDAY) || \ + ((WEEKDAY) == RTC_WEEKDAY_SUNDAY)) +#define IS_RTC_ALARM_DATE_WEEKDAY_SEL(SEL) (((SEL) == RTC_ALARMDATEWEEKDAYSEL_DATE) || \ + ((SEL) == RTC_ALARMDATEWEEKDAYSEL_WEEKDAY)) +#define IS_RTC_ALARM_MASK(MASK) (((MASK) & 0x7F7F7F7FU) == (uint32_t)RESET) +#define IS_RTC_ALARM(ALARM) ((ALARM) == RTC_ALARM_A) +#define IS_RTC_ALARM_SUB_SECOND_VALUE(VALUE) ((VALUE) <= 0x00007FFFU) + +#define IS_RTC_ALARM_SUB_SECOND_MASK(MASK) (((MASK) == RTC_ALARMSUBSECONDMASK_ALL) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_1) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_2) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_3) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_4) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_5) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_6) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_7) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_8) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_9) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_10) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_11) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_12) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14_13) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_SS14) || \ + ((MASK) == RTC_ALARMSUBSECONDMASK_NONE)) +/** + * @} + */ + +/** + * @} + */ + +/* Private functions ---------------------------------------------------------*/ +/** @defgroup RTC_Private_Functions RTC Private Functions + * @{ + */ +HAL_StatusTypeDef RTC_EnterInitMode(RTC_HandleTypeDef *hrtc); +uint8_t RTC_ByteToBcd2(uint8_t Value); +uint8_t RTC_Bcd2ToByte(uint8_t Value); +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_RTC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc_ex.h new file mode 100644 index 0000000..6cdc954 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_rtc_ex.h @@ -0,0 +1,1048 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rtc_ex.h + * @author MCD Application Team + * @brief Header file of RTC HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_RTC_EX_H +#define __STM32F0xx_HAL_RTC_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup RTCEx RTCEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup RTCEx_Exported_Types RTCEx Exported Types + * @{ + */ + +/** + * @brief RTC Tamper structure definition + */ +typedef struct +{ + uint32_t Tamper; /*!< Specifies the Tamper Pin. + This parameter can be a value of @ref RTCEx_Tamper_Pins_Definitions */ + + uint32_t Trigger; /*!< Specifies the Tamper Trigger. + This parameter can be a value of @ref RTCEx_Tamper_Trigger_Definitions */ + + uint32_t Filter; /*!< Specifies the RTC Filter Tamper. + This parameter can be a value of @ref RTCEx_Tamper_Filter_Definitions */ + + uint32_t SamplingFrequency; /*!< Specifies the sampling frequency. + This parameter can be a value of @ref RTCEx_Tamper_Sampling_Frequencies_Definitions */ + + uint32_t PrechargeDuration; /*!< Specifies the Precharge Duration . + This parameter can be a value of @ref RTCEx_Tamper_Pin_Precharge_Duration_Definitions */ + + uint32_t TamperPullUp; /*!< Specifies the Tamper PullUp . + This parameter can be a value of @ref RTCEx_Tamper_Pull_UP_Definitions */ + + uint32_t TimeStampOnTamperDetection; /*!< Specifies the TimeStampOnTamperDetection. + This parameter can be a value of @ref RTCEx_Tamper_TimeStampOnTamperDetection_Definitions */ +} RTC_TamperTypeDef; +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup RTCEx_Exported_Constants RTCEx Exported Constants + * @{ + */ + +/** @defgroup RTCEx_Output_selection_Definitions RTCEx Output Selection Definition + * @{ + */ +#define RTC_OUTPUT_DISABLE 0x00000000U +#define RTC_OUTPUT_ALARMA 0x00200000U +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +#define RTC_OUTPUT_WAKEUP 0x00600000U +#endif + +/** + * @} + */ + +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F030xC) && !defined(STM32F070x6) && !defined(STM32F070xB) +/** @defgroup RTCEx_Backup_Registers_Definitions RTCEx Backup Registers Definition + * @{ + */ +#define RTC_BKP_DR0 0x00000000U +#define RTC_BKP_DR1 0x00000001U +#define RTC_BKP_DR2 0x00000002U +#define RTC_BKP_DR3 0x00000003U +#define RTC_BKP_DR4 0x00000004U +/** + * @} + */ +#endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F030xC) && !defined(STM32F070x6) && !defined(STM32F070xB) */ + +/** @defgroup RTCEx_Time_Stamp_Edges_definitions RTCEx Time Stamp Edges definition + * @{ + */ +#define RTC_TIMESTAMPEDGE_RISING 0x00000000U +#define RTC_TIMESTAMPEDGE_FALLING 0x00000008U + +/** + * @} + */ + +/** @defgroup RTCEx_TimeStamp_Pin_Selections RTCEx TimeStamp Pin Selection + * @{ + */ +#define RTC_TIMESTAMPPIN_DEFAULT 0x00000000U + +/** + * @} + */ + + +/** @defgroup RTCEx_Tamper_Pins_Definitions RTCEx Tamper Pins Definition + * @{ + */ +#define RTC_TAMPER_1 RTC_TAFCR_TAMP1E +#define RTC_TAMPER_2 RTC_TAFCR_TAMP2E +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) +#define RTC_TAMPER_3 RTC_TAFCR_TAMP3E +#endif + +/** + * @} + */ + + + +/** @defgroup RTCEx_Tamper_Trigger_Definitions RTCEx Tamper Trigger Definition + * @{ + */ +#define RTC_TAMPERTRIGGER_RISINGEDGE 0x00000000U +#define RTC_TAMPERTRIGGER_FALLINGEDGE 0x00000002U +#define RTC_TAMPERTRIGGER_LOWLEVEL RTC_TAMPERTRIGGER_RISINGEDGE +#define RTC_TAMPERTRIGGER_HIGHLEVEL RTC_TAMPERTRIGGER_FALLINGEDGE + + +/** + * @} + */ + +/** @defgroup RTCEx_Tamper_Filter_Definitions RTCEx Tamper Filter Definition + * @{ + */ +#define RTC_TAMPERFILTER_DISABLE 0x00000000U /*!< Tamper filter is disabled */ + +#define RTC_TAMPERFILTER_2SAMPLE 0x00000800U /*!< Tamper is activated after 2 + consecutive samples at the active level */ +#define RTC_TAMPERFILTER_4SAMPLE 0x00001000U /*!< Tamper is activated after 4 + consecutive samples at the active level */ +#define RTC_TAMPERFILTER_8SAMPLE 0x00001800U /*!< Tamper is activated after 8 + consecutive samples at the active level. */ + +/** + * @} + */ + +/** @defgroup RTCEx_Tamper_Sampling_Frequencies_Definitions RTCEx Tamper Sampling Frequencies Definition + * @{ + */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV32768 0x00000000U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 32768 */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV16384 0x00000100U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 16384 */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV8192 0x00000200U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 8192 */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV4096 0x00000300U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 4096 */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV2048 0x00000400U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 2048 */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV1024 0x00000500U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 1024 */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV512 0x00000600U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 512 */ +#define RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV256 0x00000700U /*!< Each of the tamper inputs are sampled + with a frequency = RTCCLK / 256 */ + +/** + * @} + */ + +/** @defgroup RTCEx_Tamper_Pin_Precharge_Duration_Definitions RTCEx Tamper Pin Precharge Duration Definition + * @{ + */ +#define RTC_TAMPERPRECHARGEDURATION_1RTCCLK 0x00000000U /*!< Tamper pins are pre-charged before + sampling during 1 RTCCLK cycle */ +#define RTC_TAMPERPRECHARGEDURATION_2RTCCLK 0x00002000U /*!< Tamper pins are pre-charged before + sampling during 2 RTCCLK cycles */ +#define RTC_TAMPERPRECHARGEDURATION_4RTCCLK 0x00004000U /*!< Tamper pins are pre-charged before + sampling during 4 RTCCLK cycles */ +#define RTC_TAMPERPRECHARGEDURATION_8RTCCLK 0x00006000U /*!< Tamper pins are pre-charged before + sampling during 8 RTCCLK cycles */ + +/** + * @} + */ + +/** @defgroup RTCEx_Tamper_TimeStampOnTamperDetection_Definitions RTCEx Tamper TimeStampOnTamperDetection Definition + * @{ + */ +#define RTC_TIMESTAMPONTAMPERDETECTION_ENABLE ((uint32_t)RTC_TAFCR_TAMPTS) /*!< TimeStamp on Tamper Detection event saved */ +#define RTC_TIMESTAMPONTAMPERDETECTION_DISABLE 0x00000000U /*!< TimeStamp on Tamper Detection event is not saved */ + +/** + * @} + */ + +/** @defgroup RTCEx_Tamper_Pull_UP_Definitions RTCEx Tamper Pull UP Definition + * @{ + */ +#define RTC_TAMPER_PULLUP_ENABLE 0x00000000U /*!< Tamper pins are pre-charged before sampling */ +#define RTC_TAMPER_PULLUP_DISABLE ((uint32_t)RTC_TAFCR_TAMPPUDIS) /*!< Tamper pins are not pre-charged before sampling */ + +/** + * @} + */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +/** @defgroup RTCEx_Wakeup_Timer_Definitions RTCEx Wakeup Timer Definition + * @{ + */ +#define RTC_WAKEUPCLOCK_RTCCLK_DIV16 0x00000000U +#define RTC_WAKEUPCLOCK_RTCCLK_DIV8 0x00000001U +#define RTC_WAKEUPCLOCK_RTCCLK_DIV4 0x00000002U +#define RTC_WAKEUPCLOCK_RTCCLK_DIV2 0x00000003U +#define RTC_WAKEUPCLOCK_CK_SPRE_16BITS 0x00000004U +#define RTC_WAKEUPCLOCK_CK_SPRE_17BITS 0x00000006U + + +/** + * @} + */ +#endif /* defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) */ + +/** @defgroup RTCEx_Smooth_calib_period_Definitions RTCEx Smooth calib period Definition + * @{ + */ +#define RTC_SMOOTHCALIB_PERIOD_32SEC 0x00000000U /*!< If RTCCLK = 32768 Hz, Smooth calibation + period is 32s, else 2exp20 RTCCLK seconds */ +#define RTC_SMOOTHCALIB_PERIOD_16SEC 0x00002000U /*!< If RTCCLK = 32768 Hz, Smooth calibation + period is 16s, else 2exp19 RTCCLK seconds */ +#define RTC_SMOOTHCALIB_PERIOD_8SEC 0x00004000U /*!< If RTCCLK = 32768 Hz, Smooth calibation + period is 8s, else 2exp18 RTCCLK seconds */ + +/** + * @} + */ + +/** @defgroup RTCEx_Smooth_calib_Plus_pulses_Definitions RTCEx Smooth calib Plus pulses Definition + * @{ + */ +#define RTC_SMOOTHCALIB_PLUSPULSES_SET 0x00008000U /*!< The number of RTCCLK pulses added + during a X -second window = Y - CALM[8:0] + with Y = 512, 256, 128 when X = 32, 16, 8 */ +#define RTC_SMOOTHCALIB_PLUSPULSES_RESET 0x00000000U /*!< The number of RTCCLK pulses subbstited + during a 32-second window = CALM[8:0] */ + +/** + * @} + */ +/** @defgroup RTCEx_Calib_Output_selection_Definitions RTCEx Calib Output selection Definitions + * @{ + */ +#define RTC_CALIBOUTPUT_512HZ 0x00000000U +#define RTC_CALIBOUTPUT_1HZ 0x00080000U + +/** + * @} + */ + +/** @defgroup RTCEx_Add_1_Second_Parameter_Definition RTCEx Add 1 Second Parameter Definition + * @{ + */ +#define RTC_SHIFTADD1S_RESET 0x00000000U +#define RTC_SHIFTADD1S_SET 0x80000000U + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup RTCEx_Exported_Macros RTCEx Exported Macros + * @{ + */ + +/* ---------------------------------WAKEUPTIMER---------------------------------*/ +/** @defgroup RTCEx_WakeUp_Timer RTC WakeUp Timer + * @{ + */ +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +/** + * @brief Enable the RTC WakeUp Timer peripheral. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_WUTE)) + +/** + * @brief Disable the RTC WakeUp Timer peripheral. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_WUTE)) + +/** + * @brief Enable the RTC WakeUpTimer interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC WakeUpTimer interrupt sources to be enabled. + * This parameter can be: + * @arg RTC_IT_WUT: WakeUpTimer interrupt + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR |= (__INTERRUPT__)) + +/** + * @brief Disable the RTC WakeUpTimer interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC WakeUpTimer interrupt sources to be disabled. + * This parameter can be: + * @arg RTC_IT_WUT: WakeUpTimer interrupt + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR &= ~(__INTERRUPT__)) + +/** + * @brief Check whether the specified RTC WakeUpTimer interrupt has occurred or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC WakeUpTimer interrupt to check. + * This parameter can be: + * @arg RTC_IT_WUT: WakeUpTimer interrupt + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 4U)) != RESET) ? SET : RESET) + +/** + * @brief Check whether the specified RTC Wake Up timer interrupt has been enabled or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Wake Up timer interrupt sources to check. + * This parameter can be: + * @arg RTC_IT_WUT: WakeUpTimer interrupt + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->CR) & (__INTERRUPT__)) != RESET) ? SET : RESET) + +/** + * @brief Get the selected RTC WakeUpTimer's flag status. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC WakeUpTimer Flag is pending or not. + * This parameter can be: + * @arg RTC_FLAG_WUTF + * @arg RTC_FLAG_WUTWF + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET) ? SET : RESET) + +/** + * @brief Clear the RTC Wake Up timer's pending flags. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC WakeUpTimer Flag to clear. + * This parameter can be: + * @arg RTC_FLAG_WUTF + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT)) + +/* WAKE-UP TIMER EXTI */ +/* ------------------ */ +/** + * @brief Enable interrupt on the RTC WakeUp Timer associated Exti line. + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_IT() (EXTI->IMR |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT) + +/** + * @brief Disable interrupt on the RTC WakeUp Timer associated Exti line. + * @retval None + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_IT() (EXTI->IMR &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT)) + +/** + * @brief Enable event on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_EVENT() (EXTI->EMR |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT) + +/** + * @brief Disable event on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_EVENT() (EXTI->EMR &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT)) + +/** + * @brief Enable falling edge trigger on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_FALLING_EDGE() (EXTI->FTSR |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT) + +/** + * @brief Disable falling edge trigger on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_FALLING_EDGE() (EXTI->FTSR &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT)) + +/** + * @brief Enable rising edge trigger on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE() (EXTI->RTSR |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT) + +/** + * @brief Disable rising edge trigger on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_RISING_EDGE() (EXTI->RTSR &= ~(RTC_EXTI_LINE_WAKEUPTIMER_EVENT)) + +/** + * @brief Enable rising & falling edge trigger on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_FALLING_EDGE() __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE();__HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_FALLING_EDGE(); + +/** + * @brief Disable rising & falling edge trigger on the RTC WakeUp Timer associated Exti line. + * This parameter can be: + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_RISING_FALLING_EDGE() __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_RISING_EDGE();__HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_FALLING_EDGE(); + +/** + * @brief Check whether the RTC WakeUp Timer associated Exti line interrupt flag is set or not. + * @retval Line Status. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_GET_FLAG() (EXTI->PR & RTC_EXTI_LINE_WAKEUPTIMER_EVENT) + +/** + * @brief Clear the RTC WakeUp Timer associated Exti line flag. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_CLEAR_FLAG() (EXTI->PR = RTC_EXTI_LINE_WAKEUPTIMER_EVENT) + +/** + * @brief Generate a Software interrupt on the RTC WakeUp Timer associated Exti line. + * @retval None. + */ +#define __HAL_RTC_WAKEUPTIMER_EXTI_GENERATE_SWIT() (EXTI->SWIER |= RTC_EXTI_LINE_WAKEUPTIMER_EVENT) +#endif /* defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) */ +/** + * @} + */ + +/* ---------------------------------TIMESTAMP---------------------------------*/ +/** @defgroup RTCEx_Timestamp RTC Timestamp + * @{ + */ +/** + * @brief Enable the RTC TimeStamp peripheral. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_TSE)) + +/** + * @brief Disable the RTC TimeStamp peripheral. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_TSE)) + +/** + * @brief Enable the RTC TimeStamp interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC TimeStamp interrupt source to be enabled. + * This parameter can be: + * @arg RTC_IT_TS: TimeStamp interrupt + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR |= (__INTERRUPT__)) + +/** + * @brief Disable the RTC TimeStamp interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC TimeStamp interrupt source to be disabled. + * This parameter can be: + * @arg RTC_IT_TS: TimeStamp interrupt + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR &= ~(__INTERRUPT__)) + +/** + * @brief Check whether the specified RTC TimeStamp interrupt has occurred or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC TimeStamp interrupt to check. + * This parameter can be: + * @arg RTC_IT_TS: TimeStamp interrupt + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 4U)) != RESET)? SET : RESET) + +/** + * @brief Check whether the specified RTC Time Stamp interrupt has been enabled or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Time Stamp interrupt source to check. + * This parameter can be: + * @arg RTC_IT_TS: TimeStamp interrupt + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->CR) & (__INTERRUPT__)) != RESET) ? SET : RESET) + +/** + * @brief Get the selected RTC TimeStamp's flag status. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC TimeStamp Flag is pending or not. + * This parameter can be: + * @arg RTC_FLAG_TSF + * @arg RTC_FLAG_TSOVF + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET)? SET : RESET) + +/** + * @brief Clear the RTC Time Stamp's pending flags. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC Alarm Flag to clear. + * This parameter can be: + * @arg RTC_FLAG_TSF + * @retval None + */ +#define __HAL_RTC_TIMESTAMP_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT)) + +/** + * @} + */ + +/* ---------------------------------TAMPER------------------------------------*/ +/** @defgroup RTCEx_Tamper RTC Tamper + * @{ + */ + +/** + * @brief Enable the RTC Tamper1 input detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TAMPER1_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->TAFCR |= (RTC_TAFCR_TAMP1E)) + +/** + * @brief Disable the RTC Tamper1 input detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TAMPER1_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->TAFCR &= ~(RTC_TAFCR_TAMP1E)) + +/** + * @brief Enable the RTC Tamper2 input detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TAMPER2_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->TAFCR |= (RTC_TAFCR_TAMP2E)) + +/** + * @brief Disable the RTC Tamper2 input detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TAMPER2_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->TAFCR &= ~(RTC_TAFCR_TAMP2E)) + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +/** + * @brief Enable the RTC Tamper3 input detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TAMPER3_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->TAFCR |= (RTC_TAFCR_TAMP3E)) + +/** + * @brief Disable the RTC Tamper3 input detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_TAMPER3_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->TAFCR &= ~(RTC_TAFCR_TAMP3E)) + +#endif /* defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) */ +/** + * @brief Enable the RTC Tamper interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Tamper interrupt sources to be enabled. + * This parameter can be any combination of the following values: + * @arg RTC_IT_TAMP: Tamper interrupt + * @retval None + */ +#define __HAL_RTC_TAMPER_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->TAFCR |= (__INTERRUPT__)) + +/** + * @brief Disable the RTC Tamper interrupt. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Tamper interrupt sources to be disabled. + * This parameter can be any combination of the following values: + * @arg RTC_IT_TAMP: Tamper interrupt + * @retval None + */ +#define __HAL_RTC_TAMPER_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->TAFCR &= ~(__INTERRUPT__)) + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +/** + * @brief Check whether the specified RTC Tamper interrupt has occurred or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Tamper interrupt to check. + * This parameter can be: + * @arg RTC_IT_TAMP1: Tamper1 interrupt + * @arg RTC_IT_TAMP2: Tamper2 interrupt + * @arg RTC_IT_TAMP3: Tamper3 interrupt + * @retval None + */ +#define __HAL_RTC_TAMPER_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 4U)) != RESET)? SET : RESET) +#else + +/** + * @brief Check whether the specified RTC Tamper interrupt has occurred or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Tamper interrupt to check. + * This parameter can be: + * @arg RTC_IT_TAMP1: Tamper1 interrupt + * @arg RTC_IT_TAMP2: Tamper2 interrupt + * @retval None + */ +#define __HAL_RTC_TAMPER_GET_IT(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->ISR) & ((__INTERRUPT__)>> 4U)) != RESET)? SET : RESET) + +#endif /* defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) */ + +/** + * @brief Check whether the specified RTC Tamper interrupt has been enabled or not. + * @param __HANDLE__ specifies the RTC handle. + * @param __INTERRUPT__ specifies the RTC Tamper interrupt source to check. + * This parameter can be: + * @arg RTC_IT_TAMP: Tamper interrupt + * @retval None + */ +#define __HAL_RTC_TAMPER_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((((__HANDLE__)->Instance->TAFCR) & (__INTERRUPT__)) != RESET) ? SET : RESET) + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +/** + * @brief Get the selected RTC Tamper's flag status. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC Tamper Flag is pending or not. + * This parameter can be: + * @arg RTC_FLAG_TAMP1F + * @arg RTC_FLAG_TAMP2F + * @arg RTC_FLAG_TAMP3F + * @retval None + */ +#define __HAL_RTC_TAMPER_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET)? SET : RESET) + + +/** + * @brief Clear the RTC Tamper's pending flags. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC Tamper Flag to clear. + * This parameter can be: + * @arg RTC_FLAG_TAMP1F + * @arg RTC_FLAG_TAMP2F + * @arg RTC_FLAG_TAMP3F + * @retval None + */ +#define __HAL_RTC_TAMPER_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT)) + +#else + +/** + * @brief Get the selected RTC Tamper's flag status. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC Tamper Flag is pending or not. + * This parameter can be: + * @arg RTC_FLAG_TAMP1F + * @arg RTC_FLAG_TAMP2F + * @retval None + */ +#define __HAL_RTC_TAMPER_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET)? SET : RESET) + + +/** + * @brief Clear the RTC Tamper's pending flags. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC Tamper Flag to clear. + * This parameter can be: + * @arg RTC_FLAG_TAMP1F + * @arg RTC_FLAG_TAMP2F + * @retval None + */ +#define __HAL_RTC_TAMPER_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR) = (~((__FLAG__) | RTC_ISR_INIT)|((__HANDLE__)->Instance->ISR & RTC_ISR_INIT)) + +#endif /* defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) */ +/** + * @} + */ + +/* --------------------------TAMPER/TIMESTAMP---------------------------------*/ +/** @defgroup RTCEx_Tamper_Timestamp EXTI RTC Tamper Timestamp EXTI + * @{ + */ + +/* TAMPER TIMESTAMP EXTI */ +/* --------------------- */ +/** + * @brief Enable interrupt on the RTC Tamper and Timestamp associated Exti line. + * @retval None + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_IT() (EXTI->IMR |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT) + +/** + * @brief Disable interrupt on the RTC Tamper and Timestamp associated Exti line. + * @retval None + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_IT() (EXTI->IMR &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)) + +/** + * @brief Enable event on the RTC Tamper and Timestamp associated Exti line. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_EVENT() (EXTI->EMR |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT) + +/** + * @brief Disable event on the RTC Tamper and Timestamp associated Exti line. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_EVENT() (EXTI->EMR &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)) + +/** + * @brief Enable falling edge trigger on the RTC Tamper and Timestamp associated Exti line. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_FALLING_EDGE() (EXTI->FTSR |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT) + +/** + * @brief Disable falling edge trigger on the RTC Tamper and Timestamp associated Exti line. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_FALLING_EDGE() (EXTI->FTSR &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)) + +/** + * @brief Enable rising edge trigger on the RTC Tamper and Timestamp associated Exti line. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_EDGE() (EXTI->RTSR |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT) + +/** + * @brief Disable rising edge trigger on the RTC Tamper and Timestamp associated Exti line. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_RISING_EDGE() (EXTI->RTSR &= ~(RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT)) + +/** + * @brief Enable rising & falling edge trigger on the RTC Tamper and Timestamp associated Exti line. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_FALLING_EDGE() __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_EDGE();__HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_FALLING_EDGE(); + +/** + * @brief Disable rising & falling edge trigger on the RTC Tamper and Timestamp associated Exti line. + * This parameter can be: + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_RISING_FALLING_EDGE() __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_RISING_EDGE();__HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_FALLING_EDGE(); + +/** + * @brief Check whether the RTC Tamper and Timestamp associated Exti line interrupt flag is set or not. + * @retval Line Status. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_GET_FLAG() (EXTI->PR & RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT) + +/** + * @brief Clear the RTC Tamper and Timestamp associated Exti line flag. + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_CLEAR_FLAG() (EXTI->PR = RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT) + +/** + * @brief Generate a Software interrupt on the RTC Tamper and Timestamp associated Exti line + * @retval None. + */ +#define __HAL_RTC_TAMPER_TIMESTAMP_EXTI_GENERATE_SWIT() (EXTI->SWIER |= RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT) +/** + * @} + */ + +/* ------------------------------Calibration----------------------------------*/ +/** @defgroup RTCEx_Calibration RTC Calibration + * @{ + */ + +/** + * @brief Enable the RTC calibration output. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_CALIBRATION_OUTPUT_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_COE)) + +/** + * @brief Disable the calibration output. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_CALIBRATION_OUTPUT_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_COE)) + +/** + * @brief Enable the clock reference detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_CLOCKREF_DETECTION_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= (RTC_CR_REFCKON)) + +/** + * @brief Disable the clock reference detection. + * @param __HANDLE__ specifies the RTC handle. + * @retval None + */ +#define __HAL_RTC_CLOCKREF_DETECTION_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(RTC_CR_REFCKON)) + +/** + * @brief Get the selected RTC shift operation's flag status. + * @param __HANDLE__ specifies the RTC handle. + * @param __FLAG__ specifies the RTC shift operation Flag is pending or not. + * This parameter can be: + * @arg RTC_FLAG_SHPF + * @retval None + */ +#define __HAL_RTC_SHIFT_GET_FLAG(__HANDLE__, __FLAG__) (((((__HANDLE__)->Instance->ISR) & (__FLAG__)) != RESET)? SET : RESET) +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup RTCEx_Exported_Functions RTCEx Exported Functions + * @{ + */ + +/* RTC TimeStamp and Tamper functions *****************************************/ +/** @defgroup RTCEx_Exported_Functions_Group1 Extended RTC TimeStamp and Tamper functions + * @{ + */ + +HAL_StatusTypeDef HAL_RTCEx_SetTimeStamp(RTC_HandleTypeDef *hrtc, uint32_t TimeStampEdge, uint32_t RTC_TimeStampPin); +HAL_StatusTypeDef HAL_RTCEx_SetTimeStamp_IT(RTC_HandleTypeDef *hrtc, uint32_t TimeStampEdge, uint32_t RTC_TimeStampPin); +HAL_StatusTypeDef HAL_RTCEx_DeactivateTimeStamp(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTCEx_GetTimeStamp(RTC_HandleTypeDef *hrtc, RTC_TimeTypeDef *sTimeStamp, RTC_DateTypeDef *sTimeStampDate, uint32_t Format); + +HAL_StatusTypeDef HAL_RTCEx_SetTamper(RTC_HandleTypeDef *hrtc, RTC_TamperTypeDef *sTamper); +HAL_StatusTypeDef HAL_RTCEx_SetTamper_IT(RTC_HandleTypeDef *hrtc, RTC_TamperTypeDef *sTamper); +HAL_StatusTypeDef HAL_RTCEx_DeactivateTamper(RTC_HandleTypeDef *hrtc, uint32_t Tamper); +void HAL_RTCEx_TamperTimeStampIRQHandler(RTC_HandleTypeDef *hrtc); + +void HAL_RTCEx_Tamper1EventCallback(RTC_HandleTypeDef *hrtc); +void HAL_RTCEx_Tamper2EventCallback(RTC_HandleTypeDef *hrtc); +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +void HAL_RTCEx_Tamper3EventCallback(RTC_HandleTypeDef *hrtc); +#endif +void HAL_RTCEx_TimeStampEventCallback(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTCEx_PollForTimeStampEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout); +HAL_StatusTypeDef HAL_RTCEx_PollForTamper1Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout); +HAL_StatusTypeDef HAL_RTCEx_PollForTamper2Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout); +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +HAL_StatusTypeDef HAL_RTCEx_PollForTamper3Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout); +#endif +/** + * @} + */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +/* RTC Wake-up functions ******************************************************/ +/** @defgroup RTCEx_Exported_Functions_Group2 Extended RTC Wake-up functions + * @{ + */ + +HAL_StatusTypeDef HAL_RTCEx_SetWakeUpTimer(RTC_HandleTypeDef *hrtc, uint32_t WakeUpCounter, uint32_t WakeUpClock); +HAL_StatusTypeDef HAL_RTCEx_SetWakeUpTimer_IT(RTC_HandleTypeDef *hrtc, uint32_t WakeUpCounter, uint32_t WakeUpClock); +uint32_t HAL_RTCEx_DeactivateWakeUpTimer(RTC_HandleTypeDef *hrtc); +uint32_t HAL_RTCEx_GetWakeUpTimer(RTC_HandleTypeDef *hrtc); +void HAL_RTCEx_WakeUpTimerIRQHandler(RTC_HandleTypeDef *hrtc); +void HAL_RTCEx_WakeUpTimerEventCallback(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTCEx_PollForWakeUpTimerEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout); +#endif +/** + * @} + */ + +/* Extended Control functions ************************************************/ +/** @defgroup RTCEx_Exported_Functions_Group3 Extended Peripheral Control functions + * @{ + */ + +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F030xC) && !defined(STM32F070x6) && !defined(STM32F070xB) +void HAL_RTCEx_BKUPWrite(RTC_HandleTypeDef *hrtc, uint32_t BackupRegister, uint32_t Data); +uint32_t HAL_RTCEx_BKUPRead(RTC_HandleTypeDef *hrtc, uint32_t BackupRegister); +#endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F030xC) && !defined(STM32F070x6) && !defined(STM32F070xB) */ + +HAL_StatusTypeDef HAL_RTCEx_SetSmoothCalib(RTC_HandleTypeDef *hrtc, uint32_t SmoothCalibPeriod, uint32_t SmoothCalibPlusPulses, uint32_t SmoothCalibMinusPulsesValue); +HAL_StatusTypeDef HAL_RTCEx_SetSynchroShift(RTC_HandleTypeDef *hrtc, uint32_t ShiftAdd1S, uint32_t ShiftSubFS); +HAL_StatusTypeDef HAL_RTCEx_SetCalibrationOutPut(RTC_HandleTypeDef *hrtc, uint32_t CalibOutput); +HAL_StatusTypeDef HAL_RTCEx_DeactivateCalibrationOutPut(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTCEx_SetRefClock(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTCEx_DeactivateRefClock(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTCEx_EnableBypassShadow(RTC_HandleTypeDef *hrtc); +HAL_StatusTypeDef HAL_RTCEx_DisableBypassShadow(RTC_HandleTypeDef *hrtc); +/** + * @} + */ + +/* Extended RTC features functions *******************************************/ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup RTCEx_Private_Constants RTCEx Private Constants + * @{ + */ +#define RTC_EXTI_LINE_TAMPER_TIMESTAMP_EVENT ((uint32_t)EXTI_IMR_MR19) /*!< External interrupt line 19 Connected to the RTC Tamper and Time Stamp events */ +#define RTC_EXTI_LINE_WAKEUPTIMER_EVENT ((uint32_t)EXTI_IMR_MR20) /*!< External interrupt line 20 Connected to the RTC Wakeup event */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup RTCEx_Private_Macros RTCEx Private Macros + * @{ + */ + +/** @defgroup RTCEx_IS_RTC_Definitions Private macros to check input parameters + * @{ + */ +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F070xB) || defined(STM32F030xC) +#define IS_RTC_OUTPUT(OUTPUT) (((OUTPUT) == RTC_OUTPUT_DISABLE) || \ + ((OUTPUT) == RTC_OUTPUT_ALARMA) || \ + ((OUTPUT) == RTC_OUTPUT_WAKEUP)) +#else +#define IS_RTC_OUTPUT(OUTPUT) (((OUTPUT) == RTC_OUTPUT_DISABLE) || \ + ((OUTPUT) == RTC_OUTPUT_ALARMA)) +#endif + +#define IS_RTC_BKP(BKP) ((BKP) < (uint32_t) RTC_BKP_NUMBER) + +#define IS_TIMESTAMP_EDGE(EDGE) (((EDGE) == RTC_TIMESTAMPEDGE_RISING) || \ + ((EDGE) == RTC_TIMESTAMPEDGE_FALLING)) +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) +#define IS_RTC_TAMPER(TAMPER) ((((TAMPER) & (uint32_t)0xFFFFFFD6U) == 0x00U) && ((TAMPER) != (uint32_t)RESET)) + +#else +#define IS_RTC_TAMPER(TAMPER) ((((TAMPER) & (uint32_t)0xFFFFFFF6U) == 0x00U) && ((TAMPER) != (uint32_t)RESET)) + +#endif + +#define IS_RTC_TIMESTAMP_PIN(PIN) (((PIN) == RTC_TIMESTAMPPIN_DEFAULT)) + + +#define IS_RTC_TAMPER_TRIGGER(TRIGGER) (((TRIGGER) == RTC_TAMPERTRIGGER_RISINGEDGE) || \ + ((TRIGGER) == RTC_TAMPERTRIGGER_FALLINGEDGE) || \ + ((TRIGGER) == RTC_TAMPERTRIGGER_LOWLEVEL) || \ + ((TRIGGER) == RTC_TAMPERTRIGGER_HIGHLEVEL)) +#define IS_RTC_TAMPER_FILTER(FILTER) (((FILTER) == RTC_TAMPERFILTER_DISABLE) || \ + ((FILTER) == RTC_TAMPERFILTER_2SAMPLE) || \ + ((FILTER) == RTC_TAMPERFILTER_4SAMPLE) || \ + ((FILTER) == RTC_TAMPERFILTER_8SAMPLE)) +#define IS_RTC_TAMPER_SAMPLING_FREQ(FREQ) (((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV32768)|| \ + ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV16384)|| \ + ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV8192) || \ + ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV4096) || \ + ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV2048) || \ + ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV1024) || \ + ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV512) || \ + ((FREQ) == RTC_TAMPERSAMPLINGFREQ_RTCCLK_DIV256)) +#define IS_RTC_TAMPER_PRECHARGE_DURATION(DURATION) (((DURATION) == RTC_TAMPERPRECHARGEDURATION_1RTCCLK) || \ + ((DURATION) == RTC_TAMPERPRECHARGEDURATION_2RTCCLK) || \ + ((DURATION) == RTC_TAMPERPRECHARGEDURATION_4RTCCLK) || \ + ((DURATION) == RTC_TAMPERPRECHARGEDURATION_8RTCCLK)) +#define IS_RTC_TAMPER_TIMESTAMPONTAMPER_DETECTION(DETECTION) (((DETECTION) == RTC_TIMESTAMPONTAMPERDETECTION_ENABLE) || \ + ((DETECTION) == RTC_TIMESTAMPONTAMPERDETECTION_DISABLE)) +#define IS_RTC_TAMPER_PULLUP_STATE(STATE) (((STATE) == RTC_TAMPER_PULLUP_ENABLE) || \ + ((STATE) == RTC_TAMPER_PULLUP_DISABLE)) +#define IS_RTC_WAKEUP_CLOCK(CLOCK) (((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV16) || \ + ((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV8) || \ + ((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV4) || \ + ((CLOCK) == RTC_WAKEUPCLOCK_RTCCLK_DIV2) || \ + ((CLOCK) == RTC_WAKEUPCLOCK_CK_SPRE_16BITS) || \ + ((CLOCK) == RTC_WAKEUPCLOCK_CK_SPRE_17BITS)) + +#define IS_RTC_WAKEUP_COUNTER(COUNTER) ((COUNTER) <= 0xFFFFU) + + +#define IS_RTC_SMOOTH_CALIB_PERIOD(PERIOD) (((PERIOD) == RTC_SMOOTHCALIB_PERIOD_32SEC) || \ + ((PERIOD) == RTC_SMOOTHCALIB_PERIOD_16SEC) || \ + ((PERIOD) == RTC_SMOOTHCALIB_PERIOD_8SEC)) +#define IS_RTC_SMOOTH_CALIB_PLUS(PLUS) (((PLUS) == RTC_SMOOTHCALIB_PLUSPULSES_SET) || \ + ((PLUS) == RTC_SMOOTHCALIB_PLUSPULSES_RESET)) + + +#define IS_RTC_SMOOTH_CALIB_MINUS(VALUE) ((VALUE) <= 0x000001FFU) +#define IS_RTC_SHIFT_ADD1S(SEL) (((SEL) == RTC_SHIFTADD1S_RESET) || \ + ((SEL) == RTC_SHIFTADD1S_SET)) +#define IS_RTC_SHIFT_SUBFS(FS) ((FS) <= 0x00007FFFU) +#define IS_RTC_CALIB_OUTPUT(OUTPUT) (((OUTPUT) == RTC_CALIBOUTPUT_512HZ) || \ + ((OUTPUT) == RTC_CALIBOUTPUT_1HZ)) +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_RTC_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard.h new file mode 100644 index 0000000..de58417 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard.h @@ -0,0 +1,1058 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_smartcard.h + * @author MCD Application Team + * @brief Header file of SMARTCARD HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_SMARTCARD_H +#define STM32F0xx_HAL_SMARTCARD_H + +#ifdef __cplusplus +extern "C" { +#endif +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup SMARTCARD + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup SMARTCARD_Exported_Types SMARTCARD Exported Types + * @{ + */ + +/** + * @brief SMARTCARD Init Structure definition + */ +typedef struct +{ + uint32_t BaudRate; /*!< Configures the SmartCard communication baud rate. + The baud rate register is computed using the following formula: + Baud Rate Register = ((usart_ker_ckpres) / ((hsmartcard->Init.BaudRate))) + where usart_ker_ckpres is the USART input clock divided by a prescaler */ + + uint32_t WordLength; /*!< Specifies the number of data bits transmitted or received in a frame. + This parameter @ref SMARTCARD_Word_Length can only be + set to 9 (8 data + 1 parity bits). */ + + uint32_t StopBits; /*!< Specifies the number of stop bits. + This parameter can be a value of @ref SMARTCARD_Stop_Bits. */ + + uint16_t Parity; /*!< Specifies the parity mode. + This parameter can be a value of @ref SMARTCARD_Parity + @note The parity is enabled by default (PCE is forced to 1). + Since the WordLength is forced to 8 bits + parity, M is + forced to 1 and the parity bit is the 9th bit. */ + + uint16_t Mode; /*!< Specifies whether the Receive or Transmit mode is enabled or disabled. + This parameter can be a value of @ref SMARTCARD_Mode */ + + uint16_t CLKPolarity; /*!< Specifies the steady state of the serial clock. + This parameter can be a value of @ref SMARTCARD_Clock_Polarity */ + + uint16_t CLKPhase; /*!< Specifies the clock transition on which the bit capture is made. + This parameter can be a value of @ref SMARTCARD_Clock_Phase */ + + uint16_t CLKLastBit; /*!< Specifies whether the clock pulse corresponding to the last transmitted + data bit (MSB) has to be output on the SCLK pin in synchronous mode. + This parameter can be a value of @ref SMARTCARD_Last_Bit */ + + uint16_t OneBitSampling; /*!< Specifies whether a single sample or three samples' majority vote + is selected. Selecting the single sample method increases + the receiver tolerance to clock deviations. This parameter can be a value + of @ref SMARTCARD_OneBit_Sampling. */ + + uint8_t Prescaler; /*!< Specifies the SmartCard Prescaler. + This parameter can be any value from 0x01 to 0x1F. Prescaler value is + multiplied by 2 to give the division factor of the source clock frequency */ + + uint8_t GuardTime; /*!< Specifies the SmartCard Guard Time applied after stop bits. */ + + uint16_t NACKEnable; /*!< Specifies whether the SmartCard NACK transmission is enabled + in case of parity error. + This parameter can be a value of @ref SMARTCARD_NACK_Enable */ + + uint32_t TimeOutEnable; /*!< Specifies whether the receiver timeout is enabled. + This parameter can be a value of @ref SMARTCARD_Timeout_Enable*/ + + uint32_t TimeOutValue; /*!< Specifies the receiver time out value in number of baud blocks: + it is used to implement the Character Wait Time (CWT) and + Block Wait Time (BWT). It is coded over 24 bits. */ + + uint8_t BlockLength; /*!< Specifies the SmartCard Block Length in T=1 Reception mode. + This parameter can be any value from 0x0 to 0xFF */ + + uint8_t AutoRetryCount; /*!< Specifies the SmartCard auto-retry count (number of retries in + receive and transmit mode). When set to 0, retransmission is + disabled. Otherwise, its maximum value is 7 (before signalling + an error) */ + +} SMARTCARD_InitTypeDef; + +/** + * @brief SMARTCARD advanced features initialization structure definition + */ +typedef struct +{ + uint32_t AdvFeatureInit; /*!< Specifies which advanced SMARTCARD features is initialized. Several + advanced features may be initialized at the same time. This parameter + can be a value of @ref SMARTCARDEx_Advanced_Features_Initialization_Type */ + + uint32_t TxPinLevelInvert; /*!< Specifies whether the TX pin active level is inverted. + This parameter can be a value of @ref SMARTCARD_Tx_Inv */ + + uint32_t RxPinLevelInvert; /*!< Specifies whether the RX pin active level is inverted. + This parameter can be a value of @ref SMARTCARD_Rx_Inv */ + + uint32_t DataInvert; /*!< Specifies whether data are inverted (positive/direct logic + vs negative/inverted logic). + This parameter can be a value of @ref SMARTCARD_Data_Inv */ + + uint32_t Swap; /*!< Specifies whether TX and RX pins are swapped. + This parameter can be a value of @ref SMARTCARD_Rx_Tx_Swap */ + + uint32_t OverrunDisable; /*!< Specifies whether the reception overrun detection is disabled. + This parameter can be a value of @ref SMARTCARD_Overrun_Disable */ + + uint32_t DMADisableonRxError; /*!< Specifies whether the DMA is disabled in case of reception error. + This parameter can be a value of @ref SMARTCARD_DMA_Disable_on_Rx_Error */ + + uint32_t MSBFirst; /*!< Specifies whether MSB is sent first on UART line. + This parameter can be a value of @ref SMARTCARD_MSB_First */ + + uint16_t TxCompletionIndication; /*!< Specifies which transmission completion indication is used: before (when + relevant flag is available) or once guard time period has elapsed. + This parameter can be a value + of @ref SMARTCARDEx_Transmission_Completion_Indication. */ +} SMARTCARD_AdvFeatureInitTypeDef; + +/** + * @brief HAL SMARTCARD State definition + * @note HAL SMARTCARD State value is a combination of 2 different substates: + * gState and RxState (see @ref SMARTCARD_State_Definition). + * - gState contains SMARTCARD state information related to global Handle management + * and also information related to Tx operations. + * gState value coding follow below described bitmap : + * b7-b6 Error information + * 00 : No Error + * 01 : (Not Used) + * 10 : Timeout + * 11 : Error + * b5 Peripheral initialization status + * 0 : Reset (Peripheral not initialized) + * 1 : Init done (Peripheral initialized. HAL SMARTCARD Init function already called) + * b4-b3 (not used) + * xx : Should be set to 00 + * b2 Intrinsic process state + * 0 : Ready + * 1 : Busy (Peripheral busy with some configuration or internal operations) + * b1 (not used) + * x : Should be set to 0 + * b0 Tx state + * 0 : Ready (no Tx operation ongoing) + * 1 : Busy (Tx operation ongoing) + * - RxState contains information related to Rx operations. + * RxState value coding follow below described bitmap : + * b7-b6 (not used) + * xx : Should be set to 00 + * b5 Peripheral initialization status + * 0 : Reset (Peripheral not initialized) + * 1 : Init done (Peripheral initialized) + * b4-b2 (not used) + * xxx : Should be set to 000 + * b1 Rx state + * 0 : Ready (no Rx operation ongoing) + * 1 : Busy (Rx operation ongoing) + * b0 (not used) + * x : Should be set to 0. + */ +typedef uint32_t HAL_SMARTCARD_StateTypeDef; + +/** + * @brief SMARTCARD handle Structure definition + */ +typedef struct __SMARTCARD_HandleTypeDef +{ + USART_TypeDef *Instance; /*!< USART registers base address */ + + SMARTCARD_InitTypeDef Init; /*!< SmartCard communication parameters */ + + SMARTCARD_AdvFeatureInitTypeDef AdvancedInit; /*!< SmartCard advanced features initialization parameters */ + + uint8_t *pTxBuffPtr; /*!< Pointer to SmartCard Tx transfer Buffer */ + + uint16_t TxXferSize; /*!< SmartCard Tx Transfer size */ + + __IO uint16_t TxXferCount; /*!< SmartCard Tx Transfer Counter */ + + uint8_t *pRxBuffPtr; /*!< Pointer to SmartCard Rx transfer Buffer */ + + uint16_t RxXferSize; /*!< SmartCard Rx Transfer size */ + + __IO uint16_t RxXferCount; /*!< SmartCard Rx Transfer Counter */ + + + void (*RxISR)(struct __SMARTCARD_HandleTypeDef *huart); /*!< Function pointer on Rx IRQ handler */ + + void (*TxISR)(struct __SMARTCARD_HandleTypeDef *huart); /*!< Function pointer on Tx IRQ handler */ + + DMA_HandleTypeDef *hdmatx; /*!< SmartCard Tx DMA Handle parameters */ + + DMA_HandleTypeDef *hdmarx; /*!< SmartCard Rx DMA Handle parameters */ + + HAL_LockTypeDef Lock; /*!< Locking object */ + + __IO HAL_SMARTCARD_StateTypeDef gState; /*!< SmartCard state information related to global + Handle management and also related to Tx operations. + This parameter can be a value + of @ref HAL_SMARTCARD_StateTypeDef */ + + __IO HAL_SMARTCARD_StateTypeDef RxState; /*!< SmartCard state information related to Rx operations. + This parameter can be a value + of @ref HAL_SMARTCARD_StateTypeDef */ + + __IO uint32_t ErrorCode; /*!< SmartCard Error code */ + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + void (* TxCpltCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Tx Complete Callback */ + + void (* RxCpltCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Rx Complete Callback */ + + void (* ErrorCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Error Callback */ + + void (* AbortCpltCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Abort Complete Callback */ + + void (* AbortTransmitCpltCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Abort Transmit Complete Callback */ + + void (* AbortReceiveCpltCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Abort Receive Complete Callback */ + + void (* MspInitCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Msp Init callback */ + + void (* MspDeInitCallback)(struct __SMARTCARD_HandleTypeDef *hsmartcard); /*!< SMARTCARD Msp DeInit callback */ +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + +} SMARTCARD_HandleTypeDef; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) +/** + * @brief HAL SMARTCARD Callback ID enumeration definition + */ +typedef enum +{ + HAL_SMARTCARD_TX_COMPLETE_CB_ID = 0x00U, /*!< SMARTCARD Tx Complete Callback ID */ + HAL_SMARTCARD_RX_COMPLETE_CB_ID = 0x01U, /*!< SMARTCARD Rx Complete Callback ID */ + HAL_SMARTCARD_ERROR_CB_ID = 0x02U, /*!< SMARTCARD Error Callback ID */ + HAL_SMARTCARD_ABORT_COMPLETE_CB_ID = 0x03U, /*!< SMARTCARD Abort Complete Callback ID */ + HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID = 0x04U, /*!< SMARTCARD Abort Transmit Complete Callback ID */ + HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID = 0x05U, /*!< SMARTCARD Abort Receive Complete Callback ID */ + + HAL_SMARTCARD_MSPINIT_CB_ID = 0x08U, /*!< SMARTCARD MspInit callback ID */ + HAL_SMARTCARD_MSPDEINIT_CB_ID = 0x09U /*!< SMARTCARD MspDeInit callback ID */ + +} HAL_SMARTCARD_CallbackIDTypeDef; + +/** + * @brief HAL SMARTCARD Callback pointer definition + */ +typedef void (*pSMARTCARD_CallbackTypeDef)(SMARTCARD_HandleTypeDef *hsmartcard); /*!< pointer to an SMARTCARD callback function */ + +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + +/** + * @brief SMARTCARD clock sources + */ +typedef enum +{ + SMARTCARD_CLOCKSOURCE_PCLK1 = 0x00U, /*!< PCLK1 clock source */ + SMARTCARD_CLOCKSOURCE_HSI = 0x02U, /*!< HSI clock source */ + SMARTCARD_CLOCKSOURCE_SYSCLK = 0x04U, /*!< SYSCLK clock source */ + SMARTCARD_CLOCKSOURCE_LSE = 0x08U, /*!< LSE clock source */ + SMARTCARD_CLOCKSOURCE_UNDEFINED = 0x10U /*!< undefined clock source */ +} SMARTCARD_ClockSourceTypeDef; + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup SMARTCARD_Exported_Constants SMARTCARD Exported Constants + * @{ + */ + +/** @defgroup SMARTCARD_State_Definition SMARTCARD State Code Definition + * @{ + */ +#define HAL_SMARTCARD_STATE_RESET 0x00000000U /*!< Peripheral is not initialized. Value + is allowed for gState and RxState */ +#define HAL_SMARTCARD_STATE_READY 0x00000020U /*!< Peripheral Initialized and ready for + use. Value is allowed for gState + and RxState */ +#define HAL_SMARTCARD_STATE_BUSY 0x00000024U /*!< an internal process is ongoing + Value is allowed for gState only */ +#define HAL_SMARTCARD_STATE_BUSY_TX 0x00000021U /*!< Data Transmission process is ongoing + Value is allowed for gState only */ +#define HAL_SMARTCARD_STATE_BUSY_RX 0x00000022U /*!< Data Reception process is ongoing + Value is allowed for RxState only */ +#define HAL_SMARTCARD_STATE_BUSY_TX_RX 0x00000023U /*!< Data Transmission and Reception + process is ongoing Not to be used for + neither gState nor RxState. + Value is result of combination (Or) + between gState and RxState values */ +#define HAL_SMARTCARD_STATE_TIMEOUT 0x000000A0U /*!< Timeout state + Value is allowed for gState only */ +#define HAL_SMARTCARD_STATE_ERROR 0x000000E0U /*!< Error + Value is allowed for gState only */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Error_Definition SMARTCARD Error Code Definition + * @{ + */ +#define HAL_SMARTCARD_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_SMARTCARD_ERROR_PE (0x00000001U) /*!< Parity error */ +#define HAL_SMARTCARD_ERROR_NE (0x00000002U) /*!< Noise error */ +#define HAL_SMARTCARD_ERROR_FE (0x00000004U) /*!< frame error */ +#define HAL_SMARTCARD_ERROR_ORE (0x00000008U) /*!< Overrun error */ +#define HAL_SMARTCARD_ERROR_DMA (0x00000010U) /*!< DMA transfer error */ +#define HAL_SMARTCARD_ERROR_RTO (0x00000020U) /*!< Receiver TimeOut error */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) +#define HAL_SMARTCARD_ERROR_INVALID_CALLBACK (0x00000040U) /*!< Invalid Callback error */ +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Word_Length SMARTCARD Word Length + * @{ + */ +#if defined(USART_CR1_M0) +#define SMARTCARD_WORDLENGTH_9B USART_CR1_M0 /*!< SMARTCARD frame length */ +#else +#define SMARTCARD_WORDLENGTH_9B USART_CR1_M /*!< SMARTCARD frame length */ +#endif /* USART_CR1_M0 */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Stop_Bits SMARTCARD Number of Stop Bits + * @{ + */ +#define SMARTCARD_STOPBITS_0_5 USART_CR2_STOP_0 /*!< SMARTCARD frame with 0.5 stop bit */ +#define SMARTCARD_STOPBITS_1_5 USART_CR2_STOP /*!< SMARTCARD frame with 1.5 stop bits */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Parity SMARTCARD Parity + * @{ + */ +#define SMARTCARD_PARITY_EVEN USART_CR1_PCE /*!< SMARTCARD frame even parity */ +#define SMARTCARD_PARITY_ODD (USART_CR1_PCE | USART_CR1_PS) /*!< SMARTCARD frame odd parity */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Mode SMARTCARD Transfer Mode + * @{ + */ +#define SMARTCARD_MODE_RX USART_CR1_RE /*!< SMARTCARD RX mode */ +#define SMARTCARD_MODE_TX USART_CR1_TE /*!< SMARTCARD TX mode */ +#define SMARTCARD_MODE_TX_RX (USART_CR1_TE |USART_CR1_RE) /*!< SMARTCARD RX and TX mode */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Clock_Polarity SMARTCARD Clock Polarity + * @{ + */ +#define SMARTCARD_POLARITY_LOW 0x00000000U /*!< SMARTCARD frame low polarity */ +#define SMARTCARD_POLARITY_HIGH USART_CR2_CPOL /*!< SMARTCARD frame high polarity */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Clock_Phase SMARTCARD Clock Phase + * @{ + */ +#define SMARTCARD_PHASE_1EDGE 0x00000000U /*!< SMARTCARD frame phase on first clock transition */ +#define SMARTCARD_PHASE_2EDGE USART_CR2_CPHA /*!< SMARTCARD frame phase on second clock transition */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Last_Bit SMARTCARD Last Bit + * @{ + */ +#define SMARTCARD_LASTBIT_DISABLE 0x00000000U /*!< SMARTCARD frame last data bit clock pulse not output to SCLK pin */ +#define SMARTCARD_LASTBIT_ENABLE USART_CR2_LBCL /*!< SMARTCARD frame last data bit clock pulse output to SCLK pin */ +/** + * @} + */ + +/** @defgroup SMARTCARD_OneBit_Sampling SMARTCARD One Bit Sampling Method + * @{ + */ +#define SMARTCARD_ONE_BIT_SAMPLE_DISABLE 0x00000000U /*!< SMARTCARD frame one-bit sample disabled */ +#define SMARTCARD_ONE_BIT_SAMPLE_ENABLE USART_CR3_ONEBIT /*!< SMARTCARD frame one-bit sample enabled */ +/** + * @} + */ + +/** @defgroup SMARTCARD_NACK_Enable SMARTCARD NACK Enable + * @{ + */ +#define SMARTCARD_NACK_DISABLE 0x00000000U /*!< SMARTCARD NACK transmission disabled */ +#define SMARTCARD_NACK_ENABLE USART_CR3_NACK /*!< SMARTCARD NACK transmission enabled */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Timeout_Enable SMARTCARD Timeout Enable + * @{ + */ +#define SMARTCARD_TIMEOUT_DISABLE 0x00000000U /*!< SMARTCARD receiver timeout disabled */ +#define SMARTCARD_TIMEOUT_ENABLE USART_CR2_RTOEN /*!< SMARTCARD receiver timeout enabled */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Tx_Inv SMARTCARD advanced feature TX pin active level inversion + * @{ + */ +#define SMARTCARD_ADVFEATURE_TXINV_DISABLE 0x00000000U /*!< TX pin active level inversion disable */ +#define SMARTCARD_ADVFEATURE_TXINV_ENABLE USART_CR2_TXINV /*!< TX pin active level inversion enable */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Rx_Inv SMARTCARD advanced feature RX pin active level inversion + * @{ + */ +#define SMARTCARD_ADVFEATURE_RXINV_DISABLE 0x00000000U /*!< RX pin active level inversion disable */ +#define SMARTCARD_ADVFEATURE_RXINV_ENABLE USART_CR2_RXINV /*!< RX pin active level inversion enable */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Data_Inv SMARTCARD advanced feature Binary Data inversion + * @{ + */ +#define SMARTCARD_ADVFEATURE_DATAINV_DISABLE 0x00000000U /*!< Binary data inversion disable */ +#define SMARTCARD_ADVFEATURE_DATAINV_ENABLE USART_CR2_DATAINV /*!< Binary data inversion enable */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Rx_Tx_Swap SMARTCARD advanced feature RX TX pins swap + * @{ + */ +#define SMARTCARD_ADVFEATURE_SWAP_DISABLE 0x00000000U /*!< TX/RX pins swap disable */ +#define SMARTCARD_ADVFEATURE_SWAP_ENABLE USART_CR2_SWAP /*!< TX/RX pins swap enable */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Overrun_Disable SMARTCARD advanced feature Overrun Disable + * @{ + */ +#define SMARTCARD_ADVFEATURE_OVERRUN_ENABLE 0x00000000U /*!< RX overrun enable */ +#define SMARTCARD_ADVFEATURE_OVERRUN_DISABLE USART_CR3_OVRDIS /*!< RX overrun disable */ +/** + * @} + */ + +/** @defgroup SMARTCARD_DMA_Disable_on_Rx_Error SMARTCARD advanced feature DMA Disable on Rx Error + * @{ + */ +#define SMARTCARD_ADVFEATURE_DMA_ENABLEONRXERROR 0x00000000U /*!< DMA enable on Reception Error */ +#define SMARTCARD_ADVFEATURE_DMA_DISABLEONRXERROR USART_CR3_DDRE /*!< DMA disable on Reception Error */ +/** + * @} + */ + +/** @defgroup SMARTCARD_MSB_First SMARTCARD advanced feature MSB first + * @{ + */ +#define SMARTCARD_ADVFEATURE_MSBFIRST_DISABLE 0x00000000U /*!< Most significant bit sent/received first disable */ +#define SMARTCARD_ADVFEATURE_MSBFIRST_ENABLE USART_CR2_MSBFIRST /*!< Most significant bit sent/received first enable */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Request_Parameters SMARTCARD Request Parameters + * @{ + */ +#define SMARTCARD_RXDATA_FLUSH_REQUEST USART_RQR_RXFRQ /*!< Receive data flush request */ +#define SMARTCARD_TXDATA_FLUSH_REQUEST USART_RQR_TXFRQ /*!< Transmit data flush request */ +/** + * @} + */ + +/** @defgroup SMARTCARD_Interruption_Mask SMARTCARD interruptions flags mask + * @{ + */ +#define SMARTCARD_IT_MASK 0x001FU /*!< SMARTCARD interruptions flags mask */ +#define SMARTCARD_CR_MASK 0x00E0U /*!< SMARTCARD control register mask */ +#define SMARTCARD_CR_POS 5U /*!< SMARTCARD control register position */ +#define SMARTCARD_ISR_MASK 0x1F00U /*!< SMARTCARD ISR register mask */ +#define SMARTCARD_ISR_POS 8U /*!< SMARTCARD ISR register position */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup SMARTCARD_Exported_Macros SMARTCARD Exported Macros + * @{ + */ + +/** @brief Reset SMARTCARD handle states. + * @param __HANDLE__ SMARTCARD handle. + * @retval None + */ +#if USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1 +#define __HAL_SMARTCARD_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_SMARTCARD_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_SMARTCARD_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0U) +#else +#define __HAL_SMARTCARD_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_SMARTCARD_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_SMARTCARD_STATE_RESET; \ + } while(0U) +#endif /*USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + +/** @brief Flush the Smartcard Data registers. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_FLUSH_DRREGISTER(__HANDLE__) \ + do{ \ + SET_BIT((__HANDLE__)->Instance->RQR, SMARTCARD_RXDATA_FLUSH_REQUEST); \ + SET_BIT((__HANDLE__)->Instance->RQR, SMARTCARD_TXDATA_FLUSH_REQUEST); \ + } while(0U) + +/** @brief Clear the specified SMARTCARD pending flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be any combination of the following values: + * @arg @ref SMARTCARD_CLEAR_PEF Parity error clear flag + * @arg @ref SMARTCARD_CLEAR_FEF Framing error clear flag + * @arg @ref SMARTCARD_CLEAR_NEF Noise detected clear flag + * @arg @ref SMARTCARD_CLEAR_OREF OverRun error clear flag + * @arg @ref SMARTCARD_CLEAR_IDLEF Idle line detected clear flag + * @arg @ref SMARTCARD_CLEAR_TCF Transmission complete clear flag + * @arg @ref SMARTCARD_CLEAR_TCBGTF Transmission complete before guard time clear flag + * @arg @ref SMARTCARD_CLEAR_RTOF Receiver timeout clear flag + * @arg @ref SMARTCARD_CLEAR_EOBF End of block clear flag + * @retval None + */ +#define __HAL_SMARTCARD_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__)) + +/** @brief Clear the SMARTCARD PE pending flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_CLEAR_PEFLAG(__HANDLE__) __HAL_SMARTCARD_CLEAR_FLAG((__HANDLE__), SMARTCARD_CLEAR_PEF) + +/** @brief Clear the SMARTCARD FE pending flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_CLEAR_FEFLAG(__HANDLE__) __HAL_SMARTCARD_CLEAR_FLAG((__HANDLE__), SMARTCARD_CLEAR_FEF) + +/** @brief Clear the SMARTCARD NE pending flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_CLEAR_NEFLAG(__HANDLE__) __HAL_SMARTCARD_CLEAR_FLAG((__HANDLE__), SMARTCARD_CLEAR_NEF) + +/** @brief Clear the SMARTCARD ORE pending flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_CLEAR_OREFLAG(__HANDLE__) __HAL_SMARTCARD_CLEAR_FLAG((__HANDLE__), SMARTCARD_CLEAR_OREF) + +/** @brief Clear the SMARTCARD IDLE pending flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_CLEAR_IDLEFLAG(__HANDLE__) __HAL_SMARTCARD_CLEAR_FLAG((__HANDLE__), SMARTCARD_CLEAR_IDLEF) + +/** @brief Check whether the specified Smartcard flag is set or not. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref SMARTCARD_FLAG_TCBGT Transmission complete before guard time flag (when flag available) + * @arg @ref SMARTCARD_FLAG_REACK Receive enable acknowledge flag + * @arg @ref SMARTCARD_FLAG_TEACK Transmit enable acknowledge flag + * @arg @ref SMARTCARD_FLAG_BUSY Busy flag + * @arg @ref SMARTCARD_FLAG_EOBF End of block flag + * @arg @ref SMARTCARD_FLAG_RTOF Receiver timeout flag + * @arg @ref SMARTCARD_FLAG_TXE Transmit data register empty flag + * @arg @ref SMARTCARD_FLAG_TC Transmission complete flag + * @arg @ref SMARTCARD_FLAG_RXNE Receive data register not empty flag + * @arg @ref SMARTCARD_FLAG_IDLE Idle line detection flag + * @arg @ref SMARTCARD_FLAG_ORE Overrun error flag + * @arg @ref SMARTCARD_FLAG_NE Noise error flag + * @arg @ref SMARTCARD_FLAG_FE Framing error flag + * @arg @ref SMARTCARD_FLAG_PE Parity error flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_SMARTCARD_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->ISR & (__FLAG__)) == (__FLAG__)) + +/** @brief Enable the specified SmartCard interrupt. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __INTERRUPT__ specifies the SMARTCARD interrupt to enable. + * This parameter can be one of the following values: + * @arg @ref SMARTCARD_IT_EOB End of block interrupt + * @arg @ref SMARTCARD_IT_RTO Receive timeout interrupt + * @arg @ref SMARTCARD_IT_TXE Transmit data register empty interrupt + * @arg @ref SMARTCARD_IT_TC Transmission complete interrupt + * @arg @ref SMARTCARD_IT_TCBGT Transmission complete before + * guard time interrupt (when interruption available) + * @arg @ref SMARTCARD_IT_RXNE Receive data register not empty interrupt + * @arg @ref SMARTCARD_IT_IDLE Idle line detection interrupt + * @arg @ref SMARTCARD_IT_PE Parity error interrupt + * @arg @ref SMARTCARD_IT_ERR Error interrupt(frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_SMARTCARD_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((((__INTERRUPT__) & SMARTCARD_CR_MASK) >>\ + SMARTCARD_CR_POS) == 1U)?\ + ((__HANDLE__)->Instance->CR1 |= (1UL <<\ + ((__INTERRUPT__) & SMARTCARD_IT_MASK))):\ + ((((__INTERRUPT__) & SMARTCARD_CR_MASK) >>\ + SMARTCARD_CR_POS) == 2U)?\ + ((__HANDLE__)->Instance->CR2 |= (1UL <<\ + ((__INTERRUPT__) & SMARTCARD_IT_MASK))): \ + ((__HANDLE__)->Instance->CR3 |= (1UL <<\ + ((__INTERRUPT__) & SMARTCARD_IT_MASK)))) + +/** @brief Disable the specified SmartCard interrupt. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __INTERRUPT__ specifies the SMARTCARD interrupt to disable. + * This parameter can be one of the following values: + * @arg @ref SMARTCARD_IT_EOB End of block interrupt + * @arg @ref SMARTCARD_IT_RTO Receive timeout interrupt + * @arg @ref SMARTCARD_IT_TXE Transmit data register empty interrupt + * @arg @ref SMARTCARD_IT_TC Transmission complete interrupt + * @arg @ref SMARTCARD_IT_TCBGT Transmission complete before guard + * time interrupt (when interruption available) + * @arg @ref SMARTCARD_IT_RXNE Receive data register not empty interrupt + * @arg @ref SMARTCARD_IT_IDLE Idle line detection interrupt + * @arg @ref SMARTCARD_IT_PE Parity error interrupt + * @arg @ref SMARTCARD_IT_ERR Error interrupt(frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_SMARTCARD_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((((__INTERRUPT__) & SMARTCARD_CR_MASK) >>\ + SMARTCARD_CR_POS) == 1U)?\ + ((__HANDLE__)->Instance->CR1 &= ~ (1U <<\ + ((__INTERRUPT__) & SMARTCARD_IT_MASK))): \ + ((((__INTERRUPT__) & SMARTCARD_CR_MASK) >>\ + SMARTCARD_CR_POS) == 2U)?\ + ((__HANDLE__)->Instance->CR2 &= ~ (1U <<\ + ((__INTERRUPT__) & SMARTCARD_IT_MASK))): \ + ((__HANDLE__)->Instance->CR3 &= ~ (1U <<\ + ((__INTERRUPT__) & SMARTCARD_IT_MASK)))) + +/** @brief Check whether the specified SmartCard interrupt has occurred or not. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __INTERRUPT__ specifies the SMARTCARD interrupt to check. + * This parameter can be one of the following values: + * @arg @ref SMARTCARD_IT_EOB End of block interrupt + * @arg @ref SMARTCARD_IT_RTO Receive timeout interrupt + * @arg @ref SMARTCARD_IT_TXE Transmit data register empty interrupt + * @arg @ref SMARTCARD_IT_TC Transmission complete interrupt + * @arg @ref SMARTCARD_IT_TCBGT Transmission complete before guard time + * interrupt (when interruption available) + * @arg @ref SMARTCARD_IT_RXNE Receive data register not empty interrupt + * @arg @ref SMARTCARD_IT_IDLE Idle line detection interrupt + * @arg @ref SMARTCARD_IT_PE Parity error interrupt + * @arg @ref SMARTCARD_IT_ERR Error interrupt(frame error, noise error, overrun error) + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_SMARTCARD_GET_IT(__HANDLE__, __INTERRUPT__) (\ + (((__HANDLE__)->Instance->ISR & (0x01UL << (((__INTERRUPT__)\ + & SMARTCARD_ISR_MASK)>> SMARTCARD_ISR_POS)))!= 0U)\ + ? SET : RESET) + +/** @brief Check whether the specified SmartCard interrupt source is enabled or not. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __INTERRUPT__ specifies the SMARTCARD interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref SMARTCARD_IT_EOB End of block interrupt + * @arg @ref SMARTCARD_IT_RTO Receive timeout interrupt + * @arg @ref SMARTCARD_IT_TXE Transmit data register empty interrupt + * @arg @ref SMARTCARD_IT_TC Transmission complete interrupt + * @arg @ref SMARTCARD_IT_TCBGT Transmission complete before guard time + * interrupt (when interruption available) + * @arg @ref SMARTCARD_IT_RXNE Receive data register not empty interrupt + * @arg @ref SMARTCARD_IT_IDLE Idle line detection interrupt + * @arg @ref SMARTCARD_IT_PE Parity error interrupt + * @arg @ref SMARTCARD_IT_ERR Error interrupt(frame error, noise error, overrun error) + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_SMARTCARD_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((((((__INTERRUPT__) & SMARTCARD_CR_MASK) >>\ + SMARTCARD_CR_POS) == 0x01U)?\ + (__HANDLE__)->Instance->CR1 : \ + (((((__INTERRUPT__) & SMARTCARD_CR_MASK) >>\ + SMARTCARD_CR_POS) == 0x02U)?\ + (__HANDLE__)->Instance->CR2 : \ + (__HANDLE__)->Instance->CR3)) &\ + (0x01UL << (((uint16_t)(__INTERRUPT__))\ + & SMARTCARD_IT_MASK))) != 0U)\ + ? SET : RESET) + +/** @brief Clear the specified SMARTCARD ISR flag, in setting the proper ICR register flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __IT_CLEAR__ specifies the interrupt clear register flag that needs to be set + * to clear the corresponding interrupt. + * This parameter can be one of the following values: + * @arg @ref SMARTCARD_CLEAR_PEF Parity error clear flag + * @arg @ref SMARTCARD_CLEAR_FEF Framing error clear flag + * @arg @ref SMARTCARD_CLEAR_NEF Noise detected clear flag + * @arg @ref SMARTCARD_CLEAR_OREF OverRun error clear flag + * @arg @ref SMARTCARD_CLEAR_IDLEF Idle line detection clear flag + * @arg @ref SMARTCARD_CLEAR_TCF Transmission complete clear flag + * @arg @ref SMARTCARD_CLEAR_TCBGTF Transmission complete before guard time clear flag (when flag available) + * @arg @ref SMARTCARD_CLEAR_RTOF Receiver timeout clear flag + * @arg @ref SMARTCARD_CLEAR_EOBF End of block clear flag + * @retval None + */ +#define __HAL_SMARTCARD_CLEAR_IT(__HANDLE__, __IT_CLEAR__) ((__HANDLE__)->Instance->ICR |= (uint32_t)(__IT_CLEAR__)) + +/** @brief Set a specific SMARTCARD request flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __REQ__ specifies the request flag to set + * This parameter can be one of the following values: + * @arg @ref SMARTCARD_RXDATA_FLUSH_REQUEST Receive data flush Request + * @arg @ref SMARTCARD_TXDATA_FLUSH_REQUEST Transmit data flush Request + * @retval None + */ +#define __HAL_SMARTCARD_SEND_REQ(__HANDLE__, __REQ__) ((__HANDLE__)->Instance->RQR |= (uint16_t)(__REQ__)) + +/** @brief Enable the SMARTCARD one bit sample method. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_ONE_BIT_SAMPLE_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3|= USART_CR3_ONEBIT) + +/** @brief Disable the SMARTCARD one bit sample method. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_ONE_BIT_SAMPLE_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3\ + &= (uint32_t)~((uint32_t)USART_CR3_ONEBIT)) + +/** @brief Enable the USART associated to the SMARTCARD Handle. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= USART_CR1_UE) + +/** @brief Disable the USART associated to the SMARTCARD Handle + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @retval None + */ +#define __HAL_SMARTCARD_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~USART_CR1_UE) + +/** + * @} + */ + +/* Private macros -------------------------------------------------------------*/ +/** @defgroup SMARTCARD_Private_Macros SMARTCARD Private Macros + * @{ + */ + + +/** @brief Check the Baud rate range. + * @note The maximum Baud Rate is derived from the maximum clock on F0 (48 MHz) + * divided by the oversampling used on the SMARTCARD (i.e. 16). + * @param __BAUDRATE__ Baud rate set by the configuration function. + * @retval Test result (TRUE or FALSE) + */ +#define IS_SMARTCARD_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) < 6000000U) + +/** @brief Check the block length range. + * @note The maximum SMARTCARD block length is 0xFF. + * @param __LENGTH__ block length. + * @retval Test result (TRUE or FALSE) + */ +#define IS_SMARTCARD_BLOCKLENGTH(__LENGTH__) ((__LENGTH__) <= 0xFFU) + +/** @brief Check the receiver timeout value. + * @note The maximum SMARTCARD receiver timeout value is 0xFFFFFF. + * @param __TIMEOUTVALUE__ receiver timeout value. + * @retval Test result (TRUE or FALSE) + */ +#define IS_SMARTCARD_TIMEOUT_VALUE(__TIMEOUTVALUE__) ((__TIMEOUTVALUE__) <= 0xFFFFFFU) + +/** @brief Check the SMARTCARD autoretry counter value. + * @note The maximum number of retransmissions is 0x7. + * @param __COUNT__ number of retransmissions. + * @retval Test result (TRUE or FALSE) + */ +#define IS_SMARTCARD_AUTORETRY_COUNT(__COUNT__) ((__COUNT__) <= 0x7U) + +/** @brief Ensure that SMARTCARD frame length is valid. + * @param __LENGTH__ SMARTCARD frame length. + * @retval SET (__LENGTH__ is valid) or RESET (__LENGTH__ is invalid) + */ +#define IS_SMARTCARD_WORD_LENGTH(__LENGTH__) ((__LENGTH__) == SMARTCARD_WORDLENGTH_9B) + +/** @brief Ensure that SMARTCARD frame number of stop bits is valid. + * @param __STOPBITS__ SMARTCARD frame number of stop bits. + * @retval SET (__STOPBITS__ is valid) or RESET (__STOPBITS__ is invalid) + */ +#define IS_SMARTCARD_STOPBITS(__STOPBITS__) (((__STOPBITS__) == SMARTCARD_STOPBITS_0_5) ||\ + ((__STOPBITS__) == SMARTCARD_STOPBITS_1_5)) + +/** @brief Ensure that SMARTCARD frame parity is valid. + * @param __PARITY__ SMARTCARD frame parity. + * @retval SET (__PARITY__ is valid) or RESET (__PARITY__ is invalid) + */ +#define IS_SMARTCARD_PARITY(__PARITY__) (((__PARITY__) == SMARTCARD_PARITY_EVEN) || \ + ((__PARITY__) == SMARTCARD_PARITY_ODD)) + +/** @brief Ensure that SMARTCARD communication mode is valid. + * @param __MODE__ SMARTCARD communication mode. + * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid) + */ +#define IS_SMARTCARD_MODE(__MODE__) ((((__MODE__) & 0xFFF3U) == 0x00U) && ((__MODE__) != 0x00U)) + +/** @brief Ensure that SMARTCARD frame polarity is valid. + * @param __CPOL__ SMARTCARD frame polarity. + * @retval SET (__CPOL__ is valid) or RESET (__CPOL__ is invalid) + */ +#define IS_SMARTCARD_POLARITY(__CPOL__) (((__CPOL__) == SMARTCARD_POLARITY_LOW)\ + || ((__CPOL__) == SMARTCARD_POLARITY_HIGH)) + +/** @brief Ensure that SMARTCARD frame phase is valid. + * @param __CPHA__ SMARTCARD frame phase. + * @retval SET (__CPHA__ is valid) or RESET (__CPHA__ is invalid) + */ +#define IS_SMARTCARD_PHASE(__CPHA__) (((__CPHA__) == SMARTCARD_PHASE_1EDGE) || ((__CPHA__) == SMARTCARD_PHASE_2EDGE)) + +/** @brief Ensure that SMARTCARD frame last bit clock pulse setting is valid. + * @param __LASTBIT__ SMARTCARD frame last bit clock pulse setting. + * @retval SET (__LASTBIT__ is valid) or RESET (__LASTBIT__ is invalid) + */ +#define IS_SMARTCARD_LASTBIT(__LASTBIT__) (((__LASTBIT__) == SMARTCARD_LASTBIT_DISABLE) || \ + ((__LASTBIT__) == SMARTCARD_LASTBIT_ENABLE)) + +/** @brief Ensure that SMARTCARD frame sampling is valid. + * @param __ONEBIT__ SMARTCARD frame sampling. + * @retval SET (__ONEBIT__ is valid) or RESET (__ONEBIT__ is invalid) + */ +#define IS_SMARTCARD_ONE_BIT_SAMPLE(__ONEBIT__) (((__ONEBIT__) == SMARTCARD_ONE_BIT_SAMPLE_DISABLE) || \ + ((__ONEBIT__) == SMARTCARD_ONE_BIT_SAMPLE_ENABLE)) + +/** @brief Ensure that SMARTCARD NACK transmission setting is valid. + * @param __NACK__ SMARTCARD NACK transmission setting. + * @retval SET (__NACK__ is valid) or RESET (__NACK__ is invalid) + */ +#define IS_SMARTCARD_NACK(__NACK__) (((__NACK__) == SMARTCARD_NACK_ENABLE) || \ + ((__NACK__) == SMARTCARD_NACK_DISABLE)) + +/** @brief Ensure that SMARTCARD receiver timeout setting is valid. + * @param __TIMEOUT__ SMARTCARD receiver timeout setting. + * @retval SET (__TIMEOUT__ is valid) or RESET (__TIMEOUT__ is invalid) + */ +#define IS_SMARTCARD_TIMEOUT(__TIMEOUT__) (((__TIMEOUT__) == SMARTCARD_TIMEOUT_DISABLE) || \ + ((__TIMEOUT__) == SMARTCARD_TIMEOUT_ENABLE)) + +/** @brief Ensure that SMARTCARD advanced features initialization is valid. + * @param __INIT__ SMARTCARD advanced features initialization. + * @retval SET (__INIT__ is valid) or RESET (__INIT__ is invalid) + */ +#define IS_SMARTCARD_ADVFEATURE_INIT(__INIT__) ((__INIT__) <= (SMARTCARD_ADVFEATURE_NO_INIT | \ + SMARTCARD_ADVFEATURE_TXINVERT_INIT | \ + SMARTCARD_ADVFEATURE_RXINVERT_INIT | \ + SMARTCARD_ADVFEATURE_DATAINVERT_INIT | \ + SMARTCARD_ADVFEATURE_SWAP_INIT | \ + SMARTCARD_ADVFEATURE_RXOVERRUNDISABLE_INIT | \ + SMARTCARD_ADVFEATURE_DMADISABLEONERROR_INIT | \ + SMARTCARD_ADVFEATURE_MSBFIRST_INIT)) + +/** @brief Ensure that SMARTCARD frame TX inversion setting is valid. + * @param __TXINV__ SMARTCARD frame TX inversion setting. + * @retval SET (__TXINV__ is valid) or RESET (__TXINV__ is invalid) + */ +#define IS_SMARTCARD_ADVFEATURE_TXINV(__TXINV__) (((__TXINV__) == SMARTCARD_ADVFEATURE_TXINV_DISABLE) || \ + ((__TXINV__) == SMARTCARD_ADVFEATURE_TXINV_ENABLE)) + +/** @brief Ensure that SMARTCARD frame RX inversion setting is valid. + * @param __RXINV__ SMARTCARD frame RX inversion setting. + * @retval SET (__RXINV__ is valid) or RESET (__RXINV__ is invalid) + */ +#define IS_SMARTCARD_ADVFEATURE_RXINV(__RXINV__) (((__RXINV__) == SMARTCARD_ADVFEATURE_RXINV_DISABLE) || \ + ((__RXINV__) == SMARTCARD_ADVFEATURE_RXINV_ENABLE)) + +/** @brief Ensure that SMARTCARD frame data inversion setting is valid. + * @param __DATAINV__ SMARTCARD frame data inversion setting. + * @retval SET (__DATAINV__ is valid) or RESET (__DATAINV__ is invalid) + */ +#define IS_SMARTCARD_ADVFEATURE_DATAINV(__DATAINV__) (((__DATAINV__) == SMARTCARD_ADVFEATURE_DATAINV_DISABLE) || \ + ((__DATAINV__) == SMARTCARD_ADVFEATURE_DATAINV_ENABLE)) + +/** @brief Ensure that SMARTCARD frame RX/TX pins swap setting is valid. + * @param __SWAP__ SMARTCARD frame RX/TX pins swap setting. + * @retval SET (__SWAP__ is valid) or RESET (__SWAP__ is invalid) + */ +#define IS_SMARTCARD_ADVFEATURE_SWAP(__SWAP__) (((__SWAP__) == SMARTCARD_ADVFEATURE_SWAP_DISABLE) || \ + ((__SWAP__) == SMARTCARD_ADVFEATURE_SWAP_ENABLE)) + +/** @brief Ensure that SMARTCARD frame overrun setting is valid. + * @param __OVERRUN__ SMARTCARD frame overrun setting. + * @retval SET (__OVERRUN__ is valid) or RESET (__OVERRUN__ is invalid) + */ +#define IS_SMARTCARD_OVERRUN(__OVERRUN__) (((__OVERRUN__) == SMARTCARD_ADVFEATURE_OVERRUN_ENABLE) || \ + ((__OVERRUN__) == SMARTCARD_ADVFEATURE_OVERRUN_DISABLE)) + +/** @brief Ensure that SMARTCARD DMA enabling or disabling on error setting is valid. + * @param __DMA__ SMARTCARD DMA enabling or disabling on error setting. + * @retval SET (__DMA__ is valid) or RESET (__DMA__ is invalid) + */ +#define IS_SMARTCARD_ADVFEATURE_DMAONRXERROR(__DMA__) (((__DMA__) == SMARTCARD_ADVFEATURE_DMA_ENABLEONRXERROR) || \ + ((__DMA__) == SMARTCARD_ADVFEATURE_DMA_DISABLEONRXERROR)) + +/** @brief Ensure that SMARTCARD frame MSB first setting is valid. + * @param __MSBFIRST__ SMARTCARD frame MSB first setting. + * @retval SET (__MSBFIRST__ is valid) or RESET (__MSBFIRST__ is invalid) + */ +#define IS_SMARTCARD_ADVFEATURE_MSBFIRST(__MSBFIRST__) (((__MSBFIRST__) == SMARTCARD_ADVFEATURE_MSBFIRST_DISABLE) || \ + ((__MSBFIRST__) == SMARTCARD_ADVFEATURE_MSBFIRST_ENABLE)) + +/** @brief Ensure that SMARTCARD request parameter is valid. + * @param __PARAM__ SMARTCARD request parameter. + * @retval SET (__PARAM__ is valid) or RESET (__PARAM__ is invalid) + */ +#define IS_SMARTCARD_REQUEST_PARAMETER(__PARAM__) (((__PARAM__) == SMARTCARD_RXDATA_FLUSH_REQUEST) || \ + ((__PARAM__) == SMARTCARD_TXDATA_FLUSH_REQUEST)) + +/** + * @} + */ + +/* Include SMARTCARD HAL Extended module */ +#include "stm32f0xx_hal_smartcard_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup SMARTCARD_Exported_Functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +/** @addtogroup SMARTCARD_Exported_Functions_Group1 + * @{ + */ + +HAL_StatusTypeDef HAL_SMARTCARD_Init(SMARTCARD_HandleTypeDef *hsmartcard); +HAL_StatusTypeDef HAL_SMARTCARD_DeInit(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_MspInit(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_MspDeInit(SMARTCARD_HandleTypeDef *hsmartcard); + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) +/* Callbacks Register/UnRegister functions ***********************************/ +HAL_StatusTypeDef HAL_SMARTCARD_RegisterCallback(SMARTCARD_HandleTypeDef *hsmartcard, + HAL_SMARTCARD_CallbackIDTypeDef CallbackID, + pSMARTCARD_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_SMARTCARD_UnRegisterCallback(SMARTCARD_HandleTypeDef *hsmartcard, + HAL_SMARTCARD_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* IO operation functions *****************************************************/ +/** @addtogroup SMARTCARD_Exported_Functions_Group2 + * @{ + */ + +HAL_StatusTypeDef HAL_SMARTCARD_Transmit(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size, + uint32_t Timeout); +HAL_StatusTypeDef HAL_SMARTCARD_Receive(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size, + uint32_t Timeout); +HAL_StatusTypeDef HAL_SMARTCARD_Transmit_IT(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_SMARTCARD_Receive_IT(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_SMARTCARD_Transmit_DMA(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_SMARTCARD_Receive_DMA(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size); +/* Transfer Abort functions */ +HAL_StatusTypeDef HAL_SMARTCARD_Abort(SMARTCARD_HandleTypeDef *hsmartcard); +HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit(SMARTCARD_HandleTypeDef *hsmartcard); +HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive(SMARTCARD_HandleTypeDef *hsmartcard); +HAL_StatusTypeDef HAL_SMARTCARD_Abort_IT(SMARTCARD_HandleTypeDef *hsmartcard); +HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit_IT(SMARTCARD_HandleTypeDef *hsmartcard); +HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive_IT(SMARTCARD_HandleTypeDef *hsmartcard); + +void HAL_SMARTCARD_IRQHandler(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_TxCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_RxCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_ErrorCallback(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_AbortCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_AbortTransmitCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard); +void HAL_SMARTCARD_AbortReceiveCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard); + +/** + * @} + */ + +/* Peripheral State and Error functions ***************************************/ +/** @addtogroup SMARTCARD_Exported_Functions_Group4 + * @{ + */ + +HAL_SMARTCARD_StateTypeDef HAL_SMARTCARD_GetState(SMARTCARD_HandleTypeDef *hsmartcard); +uint32_t HAL_SMARTCARD_GetError(SMARTCARD_HandleTypeDef *hsmartcard); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) */ +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_SMARTCARD_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard_ex.h new file mode 100644 index 0000000..eaf7a9c --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smartcard_ex.h @@ -0,0 +1,568 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_smartcard_ex.h + * @author MCD Application Team + * @brief Header file of SMARTCARD HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_SMARTCARD_EX_H +#define STM32F0xx_HAL_SMARTCARD_EX_H + +#ifdef __cplusplus +extern "C" { +#endif +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup SMARTCARDEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/** @addtogroup SMARTCARDEx_Exported_Constants SMARTCARD Extended Exported Constants + * @{ + */ + +/** @defgroup SMARTCARDEx_Transmission_Completion_Indication SMARTCARD Transmission Completion Indication + * @{ + */ +#if defined(USART_TCBGT_SUPPORT) +#define SMARTCARD_TCBGT SMARTCARD_IT_TCBGT /*!< SMARTCARD transmission complete before guard time */ +#endif /* USART_TCBGT_SUPPORT */ +#define SMARTCARD_TC SMARTCARD_IT_TC /*!< SMARTCARD transmission complete (flag raised when guard time has elapsed) */ +/** + * @} + */ + +/** @defgroup SMARTCARDEx_Advanced_Features_Initialization_Type SMARTCARD advanced feature initialization type + * @{ + */ +#define SMARTCARD_ADVFEATURE_NO_INIT 0x00000000U /*!< No advanced feature initialization */ +#define SMARTCARD_ADVFEATURE_TXINVERT_INIT 0x00000001U /*!< TX pin active level inversion */ +#define SMARTCARD_ADVFEATURE_RXINVERT_INIT 0x00000002U /*!< RX pin active level inversion */ +#define SMARTCARD_ADVFEATURE_DATAINVERT_INIT 0x00000004U /*!< Binary data inversion */ +#define SMARTCARD_ADVFEATURE_SWAP_INIT 0x00000008U /*!< TX/RX pins swap */ +#define SMARTCARD_ADVFEATURE_RXOVERRUNDISABLE_INIT 0x00000010U /*!< RX overrun disable */ +#define SMARTCARD_ADVFEATURE_DMADISABLEONERROR_INIT 0x00000020U /*!< DMA disable on Reception Error */ +#define SMARTCARD_ADVFEATURE_MSBFIRST_INIT 0x00000080U /*!< Most significant bit sent/received first */ +#if defined(USART_TCBGT_SUPPORT) +#define SMARTCARD_ADVFEATURE_TXCOMPLETION 0x00000100U /*!< TX completion indication before of after guard time */ +#endif /* USART_TCBGT_SUPPORT */ +/** + * @} + */ + +/** @defgroup SMARTCARDEx_Flags SMARTCARD Flags + * Elements values convention: 0xXXXX + * - 0xXXXX : Flag mask in the ISR register + * @{ + */ +#if defined(USART_TCBGT_SUPPORT) +#define SMARTCARD_FLAG_TCBGT USART_ISR_TCBGT /*!< SMARTCARD transmission complete before guard time completion */ +#endif /* USART_TCBGT_SUPPORT */ +#define SMARTCARD_FLAG_REACK USART_ISR_REACK /*!< SMARTCARD receive enable acknowledge flag */ +#define SMARTCARD_FLAG_TEACK USART_ISR_TEACK /*!< SMARTCARD transmit enable acknowledge flag */ +#define SMARTCARD_FLAG_BUSY USART_ISR_BUSY /*!< SMARTCARD busy flag */ +#define SMARTCARD_FLAG_EOBF USART_ISR_EOBF /*!< SMARTCARD end of block flag */ +#define SMARTCARD_FLAG_RTOF USART_ISR_RTOF /*!< SMARTCARD receiver timeout flag */ +#define SMARTCARD_FLAG_TXE USART_ISR_TXE /*!< SMARTCARD transmit data register empty */ +#define SMARTCARD_FLAG_TC USART_ISR_TC /*!< SMARTCARD transmission complete */ +#define SMARTCARD_FLAG_RXNE USART_ISR_RXNE /*!< SMARTCARD read data register not empty */ +#define SMARTCARD_FLAG_IDLE USART_ISR_IDLE /*!< SMARTCARD idle line detection */ +#define SMARTCARD_FLAG_ORE USART_ISR_ORE /*!< SMARTCARD overrun error */ +#define SMARTCARD_FLAG_NE USART_ISR_NE /*!< SMARTCARD noise error */ +#define SMARTCARD_FLAG_FE USART_ISR_FE /*!< SMARTCARD frame error */ +#define SMARTCARD_FLAG_PE USART_ISR_PE /*!< SMARTCARD parity error */ +/** + * @} + */ + +/** @defgroup SMARTCARDEx_Interrupt_definition SMARTCARD Interrupts Definition + * Elements values convention: 000ZZZZZ0XXYYYYYb + * - YYYYY : Interrupt source position in the XX register (5 bits) + * - XX : Interrupt source register (2 bits) + * - 01: CR1 register + * - 10: CR2 register + * - 11: CR3 register + * - ZZZZZ : Flag position in the ISR register(5 bits) + * @{ + */ +#define SMARTCARD_IT_PE 0x0028U /*!< SMARTCARD parity error interruption */ +#define SMARTCARD_IT_TXE 0x0727U /*!< SMARTCARD transmit data register empty interruption */ +#define SMARTCARD_IT_TC 0x0626U /*!< SMARTCARD transmission complete interruption */ +#define SMARTCARD_IT_RXNE 0x0525U /*!< SMARTCARD read data register not empty interruption */ +#define SMARTCARD_IT_IDLE 0x0424U /*!< SMARTCARD idle line detection interruption */ + +#define SMARTCARD_IT_ERR 0x0060U /*!< SMARTCARD error interruption */ +#define SMARTCARD_IT_ORE 0x0300U /*!< SMARTCARD overrun error interruption */ +#define SMARTCARD_IT_NE 0x0200U /*!< SMARTCARD noise error interruption */ +#define SMARTCARD_IT_FE 0x0100U /*!< SMARTCARD frame error interruption */ + +#define SMARTCARD_IT_EOB 0x0C3BU /*!< SMARTCARD end of block interruption */ +#define SMARTCARD_IT_RTO 0x0B3AU /*!< SMARTCARD receiver timeout interruption */ +#if defined(USART_TCBGT_SUPPORT) +#define SMARTCARD_IT_TCBGT 0x1978U /*!< SMARTCARD transmission complete before guard time completion interruption */ +#endif /* USART_TCBGT_SUPPORT */ + +/** + * @} + */ + +/** @defgroup SMARTCARDEx_IT_CLEAR_Flags SMARTCARD Interruption Clear Flags + * @{ + */ +#define SMARTCARD_CLEAR_PEF USART_ICR_PECF /*!< SMARTCARD parity error clear flag */ +#define SMARTCARD_CLEAR_FEF USART_ICR_FECF /*!< SMARTCARD framing error clear flag */ +#define SMARTCARD_CLEAR_NEF USART_ICR_NCF /*!< SMARTCARD noise error detected clear flag */ +#define SMARTCARD_CLEAR_OREF USART_ICR_ORECF /*!< SMARTCARD overrun error clear flag */ +#define SMARTCARD_CLEAR_IDLEF USART_ICR_IDLECF /*!< SMARTCARD idle line detected clear flag */ +#define SMARTCARD_CLEAR_TCF USART_ICR_TCCF /*!< SMARTCARD transmission complete clear flag */ +#if defined(USART_TCBGT_SUPPORT) +#define SMARTCARD_CLEAR_TCBGTF USART_ICR_TCBGTCF /*!< SMARTCARD transmission complete before guard time completion clear flag */ +#endif /* USART_TCBGT_SUPPORT */ +#define SMARTCARD_CLEAR_RTOF USART_ICR_RTOCF /*!< SMARTCARD receiver time out clear flag */ +#define SMARTCARD_CLEAR_EOBF USART_ICR_EOBCF /*!< SMARTCARD end of block clear flag */ +/** + * @} + */ + +/** + * @} + */ +/* Exported macros -----------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @defgroup SMARTCARDEx_Private_Macros SMARTCARD Extended Private Macros + * @{ + */ + +/** @brief Report the SMARTCARD clock source. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @param __CLOCKSOURCE__ output variable. + * @retval the SMARTCARD clocking source, written in __CLOCKSOURCE__. + */ +#if defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) +#define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } while(0) +#elif defined (STM32F030x8) || defined (STM32F070x6) || defined (STM32F042x6) || defined (STM32F048xx) || defined (STM32F051x8) || defined (STM32F058xx) +#define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined (STM32F070xB) +#define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) +#define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F091xC) || defined (STM32F098xx) +#define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + switch(__HAL_RCC_GET_USART3_SOURCE()) \ + { \ + case RCC_USART3CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART3CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART3CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART3CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART5) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART6) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART7) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART8) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F030xC) +#define SMARTCARD_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART5) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART6) \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = SMARTCARD_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#endif /* defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) */ +/** @brief Set the Transmission Completion flag + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @note If TCBGT (Transmission Complete Before Guard Time) flag is not available or if + * AdvancedInit.TxCompletionIndication is not already filled, the latter is forced + * to SMARTCARD_TC (transmission completion indication when guard time has elapsed). + * @retval None + */ +#if defined(USART_TCBGT_SUPPORT) +#define SMARTCARD_TRANSMISSION_COMPLETION_SETTING(__HANDLE__) \ + do { \ + if (HAL_IS_BIT_CLR((__HANDLE__)->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_TXCOMPLETION)) \ + { \ + (__HANDLE__)->AdvancedInit.TxCompletionIndication = SMARTCARD_TC; \ + } \ + else \ + { \ + assert_param(IS_SMARTCARD_TRANSMISSION_COMPLETION((__HANDLE__)->AdvancedInit.TxCompletionIndication)); \ + } \ + } while(0U) +#else +#define SMARTCARD_TRANSMISSION_COMPLETION_SETTING(__HANDLE__) \ + do { \ + (__HANDLE__)->AdvancedInit.TxCompletionIndication = SMARTCARD_TC; \ + } while(0U) +#endif /* USART_TCBGT_SUPPORT */ + +/** @brief Return the transmission completion flag. + * @param __HANDLE__ specifies the SMARTCARD Handle. + * @note Based on AdvancedInit.TxCompletionIndication setting, return TC or TCBGT flag. + * When TCBGT flag (Transmission Complete Before Guard Time) is not available, TC flag is + * reported. + * @retval Transmission completion flag + */ +#if defined(USART_TCBGT_SUPPORT) +#define SMARTCARD_TRANSMISSION_COMPLETION_FLAG(__HANDLE__) \ + (((__HANDLE__)->AdvancedInit.TxCompletionIndication == SMARTCARD_TC) ? (SMARTCARD_FLAG_TC) : (SMARTCARD_FLAG_TCBGT)) +#else +#define SMARTCARD_TRANSMISSION_COMPLETION_FLAG(__HANDLE__) (SMARTCARD_FLAG_TC) +#endif /* USART_TCBGT_SUPPORT */ + + +/** @brief Ensure that SMARTCARD frame transmission completion used flag is valid. + * @param __TXCOMPLETE__ SMARTCARD frame transmission completion used flag. + * @retval SET (__TXCOMPLETE__ is valid) or RESET (__TXCOMPLETE__ is invalid) + */ +#if defined(USART_TCBGT_SUPPORT) +#define IS_SMARTCARD_TRANSMISSION_COMPLETION(__TXCOMPLETE__) (((__TXCOMPLETE__) == SMARTCARD_TCBGT) || \ + ((__TXCOMPLETE__) == SMARTCARD_TC)) +#else +#define IS_SMARTCARD_TRANSMISSION_COMPLETION(__TXCOMPLETE__) ((__TXCOMPLETE__) == SMARTCARD_TC) +#endif /* USART_TCBGT_SUPPORT */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup SMARTCARDEx_Exported_Functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +/* IO operation methods *******************************************************/ + +/** @addtogroup SMARTCARDEx_Exported_Functions_Group1 + * @{ + */ + +/* Peripheral Control functions ***********************************************/ +void HAL_SMARTCARDEx_BlockLength_Config(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t BlockLength); +void HAL_SMARTCARDEx_TimeOut_Config(SMARTCARD_HandleTypeDef *hsmartcard, uint32_t TimeOutValue); +HAL_StatusTypeDef HAL_SMARTCARDEx_EnableReceiverTimeOut(SMARTCARD_HandleTypeDef *hsmartcard); +HAL_StatusTypeDef HAL_SMARTCARDEx_DisableReceiverTimeOut(SMARTCARD_HandleTypeDef *hsmartcard); + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup SMARTCARDEx_Exported_Functions_Group2 + * @{ + */ + +/* IO operation functions *****************************************************/ + +/** + * @} + */ + + +/** + * @} + */ + +/* Private functions ---------------------------------------------------------*/ + +/** + * @} + */ + +/** + * @} + */ +#endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) */ +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_SMARTCARD_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smbus.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smbus.h new file mode 100644 index 0000000..a4d7629 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_smbus.h @@ -0,0 +1,789 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_smbus.h + * @author MCD Application Team + * @brief Header file of SMBUS HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_SMBUS_H +#define STM32F0xx_HAL_SMBUS_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup SMBUS + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup SMBUS_Exported_Types SMBUS Exported Types + * @{ + */ + +/** @defgroup SMBUS_Configuration_Structure_definition SMBUS Configuration Structure definition + * @brief SMBUS Configuration Structure definition + * @{ + */ +typedef struct +{ + uint32_t Timing; /*!< Specifies the SMBUS_TIMINGR_register value. + This parameter calculated by referring to SMBUS initialization section + in Reference manual */ + uint32_t AnalogFilter; /*!< Specifies if Analog Filter is enable or not. + This parameter can be a value of @ref SMBUS_Analog_Filter */ + + uint32_t OwnAddress1; /*!< Specifies the first device own address. + This parameter can be a 7-bit or 10-bit address. */ + + uint32_t AddressingMode; /*!< Specifies if 7-bit or 10-bit addressing mode for master is selected. + This parameter can be a value of @ref SMBUS_addressing_mode */ + + uint32_t DualAddressMode; /*!< Specifies if dual addressing mode is selected. + This parameter can be a value of @ref SMBUS_dual_addressing_mode */ + + uint32_t OwnAddress2; /*!< Specifies the second device own address if dual addressing mode is selected + This parameter can be a 7-bit address. */ + + uint32_t OwnAddress2Masks; /*!< Specifies the acknowledge mask address second device own address + if dual addressing mode is selected + This parameter can be a value of @ref SMBUS_own_address2_masks. */ + + uint32_t GeneralCallMode; /*!< Specifies if general call mode is selected. + This parameter can be a value of @ref SMBUS_general_call_addressing_mode. */ + + uint32_t NoStretchMode; /*!< Specifies if nostretch mode is selected. + This parameter can be a value of @ref SMBUS_nostretch_mode */ + + uint32_t PacketErrorCheckMode; /*!< Specifies if Packet Error Check mode is selected. + This parameter can be a value of @ref SMBUS_packet_error_check_mode */ + + uint32_t PeripheralMode; /*!< Specifies which mode of Periphal is selected. + This parameter can be a value of @ref SMBUS_peripheral_mode */ + + uint32_t SMBusTimeout; /*!< Specifies the content of the 32 Bits SMBUS_TIMEOUT_register value. + (Enable bits and different timeout values) + This parameter calculated by referring to SMBUS initialization section + in Reference manual */ +} SMBUS_InitTypeDef; +/** + * @} + */ + +/** @defgroup HAL_state_definition HAL state definition + * @brief HAL State definition + * @{ + */ +#define HAL_SMBUS_STATE_RESET (0x00000000U) /*!< SMBUS not yet initialized or disabled */ +#define HAL_SMBUS_STATE_READY (0x00000001U) /*!< SMBUS initialized and ready for use */ +#define HAL_SMBUS_STATE_BUSY (0x00000002U) /*!< SMBUS internal process is ongoing */ +#define HAL_SMBUS_STATE_MASTER_BUSY_TX (0x00000012U) /*!< Master Data Transmission process is ongoing */ +#define HAL_SMBUS_STATE_MASTER_BUSY_RX (0x00000022U) /*!< Master Data Reception process is ongoing */ +#define HAL_SMBUS_STATE_SLAVE_BUSY_TX (0x00000032U) /*!< Slave Data Transmission process is ongoing */ +#define HAL_SMBUS_STATE_SLAVE_BUSY_RX (0x00000042U) /*!< Slave Data Reception process is ongoing */ +#define HAL_SMBUS_STATE_TIMEOUT (0x00000003U) /*!< Timeout state */ +#define HAL_SMBUS_STATE_ERROR (0x00000004U) /*!< Reception process is ongoing */ +#define HAL_SMBUS_STATE_LISTEN (0x00000008U) /*!< Address Listen Mode is ongoing */ +/** + * @} + */ + +/** @defgroup SMBUS_Error_Code_definition SMBUS Error Code definition + * @brief SMBUS Error Code definition + * @{ + */ +#define HAL_SMBUS_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_SMBUS_ERROR_BERR (0x00000001U) /*!< BERR error */ +#define HAL_SMBUS_ERROR_ARLO (0x00000002U) /*!< ARLO error */ +#define HAL_SMBUS_ERROR_ACKF (0x00000004U) /*!< ACKF error */ +#define HAL_SMBUS_ERROR_OVR (0x00000008U) /*!< OVR error */ +#define HAL_SMBUS_ERROR_HALTIMEOUT (0x00000010U) /*!< Timeout error */ +#define HAL_SMBUS_ERROR_BUSTIMEOUT (0x00000020U) /*!< Bus Timeout error */ +#define HAL_SMBUS_ERROR_ALERT (0x00000040U) /*!< Alert error */ +#define HAL_SMBUS_ERROR_PECERR (0x00000080U) /*!< PEC error */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) +#define HAL_SMBUS_ERROR_INVALID_CALLBACK (0x00000100U) /*!< Invalid Callback error */ +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ +#define HAL_SMBUS_ERROR_INVALID_PARAM (0x00000200U) /*!< Invalid Parameters error */ +/** + * @} + */ + +/** @defgroup SMBUS_handle_Structure_definition SMBUS handle Structure definition + * @brief SMBUS handle Structure definition + * @{ + */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) +typedef struct __SMBUS_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ +{ + I2C_TypeDef *Instance; /*!< SMBUS registers base address */ + + SMBUS_InitTypeDef Init; /*!< SMBUS communication parameters */ + + uint8_t *pBuffPtr; /*!< Pointer to SMBUS transfer buffer */ + + uint16_t XferSize; /*!< SMBUS transfer size */ + + __IO uint16_t XferCount; /*!< SMBUS transfer counter */ + + __IO uint32_t XferOptions; /*!< SMBUS transfer options */ + + __IO uint32_t PreviousState; /*!< SMBUS communication Previous state */ + + HAL_LockTypeDef Lock; /*!< SMBUS locking object */ + + __IO uint32_t State; /*!< SMBUS communication state */ + + __IO uint32_t ErrorCode; /*!< SMBUS Error code */ + +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + void (* MasterTxCpltCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Master Tx Transfer completed callback */ + void (* MasterRxCpltCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Master Rx Transfer completed callback */ + void (* SlaveTxCpltCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Slave Tx Transfer completed callback */ + void (* SlaveRxCpltCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Slave Rx Transfer completed callback */ + void (* ListenCpltCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Listen Complete callback */ + void (* ErrorCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Error callback */ + + void (* AddrCallback)(struct __SMBUS_HandleTypeDef *hsmbus, uint8_t TransferDirection, uint16_t AddrMatchCode); + /*!< SMBUS Slave Address Match callback */ + + void (* MspInitCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Msp Init callback */ + void (* MspDeInitCallback)(struct __SMBUS_HandleTypeDef *hsmbus); + /*!< SMBUS Msp DeInit callback */ + +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ +} SMBUS_HandleTypeDef; + +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) +/** + * @brief HAL SMBUS Callback ID enumeration definition + */ +typedef enum +{ + HAL_SMBUS_MASTER_TX_COMPLETE_CB_ID = 0x00U, /*!< SMBUS Master Tx Transfer completed callback ID */ + HAL_SMBUS_MASTER_RX_COMPLETE_CB_ID = 0x01U, /*!< SMBUS Master Rx Transfer completed callback ID */ + HAL_SMBUS_SLAVE_TX_COMPLETE_CB_ID = 0x02U, /*!< SMBUS Slave Tx Transfer completed callback ID */ + HAL_SMBUS_SLAVE_RX_COMPLETE_CB_ID = 0x03U, /*!< SMBUS Slave Rx Transfer completed callback ID */ + HAL_SMBUS_LISTEN_COMPLETE_CB_ID = 0x04U, /*!< SMBUS Listen Complete callback ID */ + HAL_SMBUS_ERROR_CB_ID = 0x05U, /*!< SMBUS Error callback ID */ + + HAL_SMBUS_MSPINIT_CB_ID = 0x06U, /*!< SMBUS Msp Init callback ID */ + HAL_SMBUS_MSPDEINIT_CB_ID = 0x07U /*!< SMBUS Msp DeInit callback ID */ + +} HAL_SMBUS_CallbackIDTypeDef; + +/** + * @brief HAL SMBUS Callback pointer definition + */ +typedef void (*pSMBUS_CallbackTypeDef)(SMBUS_HandleTypeDef *hsmbus); +/*!< pointer to an SMBUS callback function */ +typedef void (*pSMBUS_AddrCallbackTypeDef)(SMBUS_HandleTypeDef *hsmbus, uint8_t TransferDirection, + uint16_t AddrMatchCode); +/*!< pointer to an SMBUS Address Match callback function */ + +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** + * @} + */ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup SMBUS_Exported_Constants SMBUS Exported Constants + * @{ + */ + +/** @defgroup SMBUS_Analog_Filter SMBUS Analog Filter + * @{ + */ +#define SMBUS_ANALOGFILTER_ENABLE (0x00000000U) +#define SMBUS_ANALOGFILTER_DISABLE I2C_CR1_ANFOFF +/** + * @} + */ + +/** @defgroup SMBUS_addressing_mode SMBUS addressing mode + * @{ + */ +#define SMBUS_ADDRESSINGMODE_7BIT (0x00000001U) +#define SMBUS_ADDRESSINGMODE_10BIT (0x00000002U) +/** + * @} + */ + +/** @defgroup SMBUS_dual_addressing_mode SMBUS dual addressing mode + * @{ + */ + +#define SMBUS_DUALADDRESS_DISABLE (0x00000000U) +#define SMBUS_DUALADDRESS_ENABLE I2C_OAR2_OA2EN +/** + * @} + */ + +/** @defgroup SMBUS_own_address2_masks SMBUS ownaddress2 masks + * @{ + */ + +#define SMBUS_OA2_NOMASK ((uint8_t)0x00U) +#define SMBUS_OA2_MASK01 ((uint8_t)0x01U) +#define SMBUS_OA2_MASK02 ((uint8_t)0x02U) +#define SMBUS_OA2_MASK03 ((uint8_t)0x03U) +#define SMBUS_OA2_MASK04 ((uint8_t)0x04U) +#define SMBUS_OA2_MASK05 ((uint8_t)0x05U) +#define SMBUS_OA2_MASK06 ((uint8_t)0x06U) +#define SMBUS_OA2_MASK07 ((uint8_t)0x07U) +/** + * @} + */ + + +/** @defgroup SMBUS_general_call_addressing_mode SMBUS general call addressing mode + * @{ + */ +#define SMBUS_GENERALCALL_DISABLE (0x00000000U) +#define SMBUS_GENERALCALL_ENABLE I2C_CR1_GCEN +/** + * @} + */ + +/** @defgroup SMBUS_nostretch_mode SMBUS nostretch mode + * @{ + */ +#define SMBUS_NOSTRETCH_DISABLE (0x00000000U) +#define SMBUS_NOSTRETCH_ENABLE I2C_CR1_NOSTRETCH +/** + * @} + */ + +/** @defgroup SMBUS_packet_error_check_mode SMBUS packet error check mode + * @{ + */ +#define SMBUS_PEC_DISABLE (0x00000000U) +#define SMBUS_PEC_ENABLE I2C_CR1_PECEN +/** + * @} + */ + +/** @defgroup SMBUS_peripheral_mode SMBUS peripheral mode + * @{ + */ +#define SMBUS_PERIPHERAL_MODE_SMBUS_HOST I2C_CR1_SMBHEN +#define SMBUS_PERIPHERAL_MODE_SMBUS_SLAVE (0x00000000U) +#define SMBUS_PERIPHERAL_MODE_SMBUS_SLAVE_ARP I2C_CR1_SMBDEN +/** + * @} + */ + +/** @defgroup SMBUS_ReloadEndMode_definition SMBUS ReloadEndMode definition + * @{ + */ + +#define SMBUS_SOFTEND_MODE (0x00000000U) +#define SMBUS_RELOAD_MODE I2C_CR2_RELOAD +#define SMBUS_AUTOEND_MODE I2C_CR2_AUTOEND +#define SMBUS_SENDPEC_MODE I2C_CR2_PECBYTE +/** + * @} + */ + +/** @defgroup SMBUS_StartStopMode_definition SMBUS StartStopMode definition + * @{ + */ + +#define SMBUS_NO_STARTSTOP (0x00000000U) +#define SMBUS_GENERATE_STOP (uint32_t)(0x80000000U | I2C_CR2_STOP) +#define SMBUS_GENERATE_START_READ (uint32_t)(0x80000000U | I2C_CR2_START | I2C_CR2_RD_WRN) +#define SMBUS_GENERATE_START_WRITE (uint32_t)(0x80000000U | I2C_CR2_START) +/** + * @} + */ + +/** @defgroup SMBUS_XferOptions_definition SMBUS XferOptions definition + * @{ + */ + +/* List of XferOptions in usage of : + * 1- Restart condition when direction change + * 2- No Restart condition in other use cases + */ +#define SMBUS_FIRST_FRAME SMBUS_SOFTEND_MODE +#define SMBUS_NEXT_FRAME ((uint32_t)(SMBUS_RELOAD_MODE | SMBUS_SOFTEND_MODE)) +#define SMBUS_FIRST_AND_LAST_FRAME_NO_PEC SMBUS_AUTOEND_MODE +#define SMBUS_LAST_FRAME_NO_PEC SMBUS_AUTOEND_MODE +#define SMBUS_FIRST_FRAME_WITH_PEC ((uint32_t)(SMBUS_SOFTEND_MODE | SMBUS_SENDPEC_MODE)) +#define SMBUS_FIRST_AND_LAST_FRAME_WITH_PEC ((uint32_t)(SMBUS_AUTOEND_MODE | SMBUS_SENDPEC_MODE)) +#define SMBUS_LAST_FRAME_WITH_PEC ((uint32_t)(SMBUS_AUTOEND_MODE | SMBUS_SENDPEC_MODE)) + +/* List of XferOptions in usage of : + * 1- Restart condition in all use cases (direction change or not) + */ +#define SMBUS_OTHER_FRAME_NO_PEC (0x000000AAU) +#define SMBUS_OTHER_FRAME_WITH_PEC (0x0000AA00U) +#define SMBUS_OTHER_AND_LAST_FRAME_NO_PEC (0x00AA0000U) +#define SMBUS_OTHER_AND_LAST_FRAME_WITH_PEC (0xAA000000U) +/** + * @} + */ + +/** @defgroup SMBUS_Interrupt_configuration_definition SMBUS Interrupt configuration definition + * @brief SMBUS Interrupt definition + * Elements values convention: 0xXXXXXXXX + * - XXXXXXXX : Interrupt control mask + * @{ + */ +#define SMBUS_IT_ERRI I2C_CR1_ERRIE +#define SMBUS_IT_TCI I2C_CR1_TCIE +#define SMBUS_IT_STOPI I2C_CR1_STOPIE +#define SMBUS_IT_NACKI I2C_CR1_NACKIE +#define SMBUS_IT_ADDRI I2C_CR1_ADDRIE +#define SMBUS_IT_RXI I2C_CR1_RXIE +#define SMBUS_IT_TXI I2C_CR1_TXIE +#define SMBUS_IT_TX (SMBUS_IT_ERRI | SMBUS_IT_TCI | SMBUS_IT_STOPI | \ + SMBUS_IT_NACKI | SMBUS_IT_TXI) +#define SMBUS_IT_RX (SMBUS_IT_ERRI | SMBUS_IT_TCI | SMBUS_IT_NACKI | \ + SMBUS_IT_RXI) +#define SMBUS_IT_ALERT (SMBUS_IT_ERRI) +#define SMBUS_IT_ADDR (SMBUS_IT_ADDRI | SMBUS_IT_STOPI | SMBUS_IT_NACKI) +/** + * @} + */ + +/** @defgroup SMBUS_Flag_definition SMBUS Flag definition + * @brief Flag definition + * Elements values convention: 0xXXXXYYYY + * - XXXXXXXX : Flag mask + * @{ + */ + +#define SMBUS_FLAG_TXE I2C_ISR_TXE +#define SMBUS_FLAG_TXIS I2C_ISR_TXIS +#define SMBUS_FLAG_RXNE I2C_ISR_RXNE +#define SMBUS_FLAG_ADDR I2C_ISR_ADDR +#define SMBUS_FLAG_AF I2C_ISR_NACKF +#define SMBUS_FLAG_STOPF I2C_ISR_STOPF +#define SMBUS_FLAG_TC I2C_ISR_TC +#define SMBUS_FLAG_TCR I2C_ISR_TCR +#define SMBUS_FLAG_BERR I2C_ISR_BERR +#define SMBUS_FLAG_ARLO I2C_ISR_ARLO +#define SMBUS_FLAG_OVR I2C_ISR_OVR +#define SMBUS_FLAG_PECERR I2C_ISR_PECERR +#define SMBUS_FLAG_TIMEOUT I2C_ISR_TIMEOUT +#define SMBUS_FLAG_ALERT I2C_ISR_ALERT +#define SMBUS_FLAG_BUSY I2C_ISR_BUSY +#define SMBUS_FLAG_DIR I2C_ISR_DIR +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros ------------------------------------------------------------*/ +/** @defgroup SMBUS_Exported_Macros SMBUS Exported Macros + * @{ + */ + +/** @brief Reset SMBUS handle state. + * @param __HANDLE__ specifies the SMBUS Handle. + * @retval None + */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) +#define __HAL_SMBUS_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_SMBUS_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_SMBUS_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_SMBUS_STATE_RESET) +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + +/** @brief Enable the specified SMBUS interrupts. + * @param __HANDLE__ specifies the SMBUS Handle. + * @param __INTERRUPT__ specifies the interrupt source to enable. + * This parameter can be one of the following values: + * @arg @ref SMBUS_IT_ERRI Errors interrupt enable + * @arg @ref SMBUS_IT_TCI Transfer complete interrupt enable + * @arg @ref SMBUS_IT_STOPI STOP detection interrupt enable + * @arg @ref SMBUS_IT_NACKI NACK received interrupt enable + * @arg @ref SMBUS_IT_ADDRI Address match interrupt enable + * @arg @ref SMBUS_IT_RXI RX interrupt enable + * @arg @ref SMBUS_IT_TXI TX interrupt enable + * + * @retval None + */ +#define __HAL_SMBUS_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 |= (__INTERRUPT__)) + +/** @brief Disable the specified SMBUS interrupts. + * @param __HANDLE__ specifies the SMBUS Handle. + * @param __INTERRUPT__ specifies the interrupt source to disable. + * This parameter can be one of the following values: + * @arg @ref SMBUS_IT_ERRI Errors interrupt enable + * @arg @ref SMBUS_IT_TCI Transfer complete interrupt enable + * @arg @ref SMBUS_IT_STOPI STOP detection interrupt enable + * @arg @ref SMBUS_IT_NACKI NACK received interrupt enable + * @arg @ref SMBUS_IT_ADDRI Address match interrupt enable + * @arg @ref SMBUS_IT_RXI RX interrupt enable + * @arg @ref SMBUS_IT_TXI TX interrupt enable + * + * @retval None + */ +#define __HAL_SMBUS_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CR1 &= (~(__INTERRUPT__))) + +/** @brief Check whether the specified SMBUS interrupt source is enabled or not. + * @param __HANDLE__ specifies the SMBUS Handle. + * @param __INTERRUPT__ specifies the SMBUS interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref SMBUS_IT_ERRI Errors interrupt enable + * @arg @ref SMBUS_IT_TCI Transfer complete interrupt enable + * @arg @ref SMBUS_IT_STOPI STOP detection interrupt enable + * @arg @ref SMBUS_IT_NACKI NACK received interrupt enable + * @arg @ref SMBUS_IT_ADDRI Address match interrupt enable + * @arg @ref SMBUS_IT_RXI RX interrupt enable + * @arg @ref SMBUS_IT_TXI TX interrupt enable + * + * @retval The new state of __IT__ (SET or RESET). + */ +#define __HAL_SMBUS_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) \ + ((((__HANDLE__)->Instance->CR1 & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET) + +/** @brief Check whether the specified SMBUS flag is set or not. + * @param __HANDLE__ specifies the SMBUS Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref SMBUS_FLAG_TXE Transmit data register empty + * @arg @ref SMBUS_FLAG_TXIS Transmit interrupt status + * @arg @ref SMBUS_FLAG_RXNE Receive data register not empty + * @arg @ref SMBUS_FLAG_ADDR Address matched (slave mode) + * @arg @ref SMBUS_FLAG_AF NACK received flag + * @arg @ref SMBUS_FLAG_STOPF STOP detection flag + * @arg @ref SMBUS_FLAG_TC Transfer complete (master mode) + * @arg @ref SMBUS_FLAG_TCR Transfer complete reload + * @arg @ref SMBUS_FLAG_BERR Bus error + * @arg @ref SMBUS_FLAG_ARLO Arbitration lost + * @arg @ref SMBUS_FLAG_OVR Overrun/Underrun + * @arg @ref SMBUS_FLAG_PECERR PEC error in reception + * @arg @ref SMBUS_FLAG_TIMEOUT Timeout or Tlow detection flag + * @arg @ref SMBUS_FLAG_ALERT SMBus alert + * @arg @ref SMBUS_FLAG_BUSY Bus busy + * @arg @ref SMBUS_FLAG_DIR Transfer direction (slave mode) + * + * @retval The new state of __FLAG__ (SET or RESET). + */ +#define SMBUS_FLAG_MASK (0x0001FFFFU) +#define __HAL_SMBUS_GET_FLAG(__HANDLE__, __FLAG__) \ + (((((__HANDLE__)->Instance->ISR) & ((__FLAG__) & SMBUS_FLAG_MASK)) == \ + ((__FLAG__) & SMBUS_FLAG_MASK)) ? SET : RESET) + +/** @brief Clear the SMBUS pending flags which are cleared by writing 1 in a specific bit. + * @param __HANDLE__ specifies the SMBUS Handle. + * @param __FLAG__ specifies the flag to clear. + * This parameter can be any combination of the following values: + * @arg @ref SMBUS_FLAG_ADDR Address matched (slave mode) + * @arg @ref SMBUS_FLAG_AF NACK received flag + * @arg @ref SMBUS_FLAG_STOPF STOP detection flag + * @arg @ref SMBUS_FLAG_BERR Bus error + * @arg @ref SMBUS_FLAG_ARLO Arbitration lost + * @arg @ref SMBUS_FLAG_OVR Overrun/Underrun + * @arg @ref SMBUS_FLAG_PECERR PEC error in reception + * @arg @ref SMBUS_FLAG_TIMEOUT Timeout or Tlow detection flag + * @arg @ref SMBUS_FLAG_ALERT SMBus alert + * + * @retval None + */ +#define __HAL_SMBUS_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__)) + +/** @brief Enable the specified SMBUS peripheral. + * @param __HANDLE__ specifies the SMBUS Handle. + * @retval None + */ +#define __HAL_SMBUS_ENABLE(__HANDLE__) (SET_BIT((__HANDLE__)->Instance->CR1, I2C_CR1_PE)) + +/** @brief Disable the specified SMBUS peripheral. + * @param __HANDLE__ specifies the SMBUS Handle. + * @retval None + */ +#define __HAL_SMBUS_DISABLE(__HANDLE__) (CLEAR_BIT((__HANDLE__)->Instance->CR1, I2C_CR1_PE)) + +/** @brief Generate a Non-Acknowledge SMBUS peripheral in Slave mode. + * @param __HANDLE__ specifies the SMBUS Handle. + * @retval None + */ +#define __HAL_SMBUS_GENERATE_NACK(__HANDLE__) (SET_BIT((__HANDLE__)->Instance->CR2, I2C_CR2_NACK)) + +/** + * @} + */ + + +/* Private constants ---------------------------------------------------------*/ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup SMBUS_Private_Macro SMBUS Private Macros + * @{ + */ + +#define IS_SMBUS_ANALOG_FILTER(FILTER) (((FILTER) == SMBUS_ANALOGFILTER_ENABLE) || \ + ((FILTER) == SMBUS_ANALOGFILTER_DISABLE)) + +#define IS_SMBUS_DIGITAL_FILTER(FILTER) ((FILTER) <= 0x0000000FU) + +#define IS_SMBUS_ADDRESSING_MODE(MODE) (((MODE) == SMBUS_ADDRESSINGMODE_7BIT) || \ + ((MODE) == SMBUS_ADDRESSINGMODE_10BIT)) + +#define IS_SMBUS_DUAL_ADDRESS(ADDRESS) (((ADDRESS) == SMBUS_DUALADDRESS_DISABLE) || \ + ((ADDRESS) == SMBUS_DUALADDRESS_ENABLE)) + +#define IS_SMBUS_OWN_ADDRESS2_MASK(MASK) (((MASK) == SMBUS_OA2_NOMASK) || \ + ((MASK) == SMBUS_OA2_MASK01) || \ + ((MASK) == SMBUS_OA2_MASK02) || \ + ((MASK) == SMBUS_OA2_MASK03) || \ + ((MASK) == SMBUS_OA2_MASK04) || \ + ((MASK) == SMBUS_OA2_MASK05) || \ + ((MASK) == SMBUS_OA2_MASK06) || \ + ((MASK) == SMBUS_OA2_MASK07)) + +#define IS_SMBUS_GENERAL_CALL(CALL) (((CALL) == SMBUS_GENERALCALL_DISABLE) || \ + ((CALL) == SMBUS_GENERALCALL_ENABLE)) + +#define IS_SMBUS_NO_STRETCH(STRETCH) (((STRETCH) == SMBUS_NOSTRETCH_DISABLE) || \ + ((STRETCH) == SMBUS_NOSTRETCH_ENABLE)) + +#define IS_SMBUS_PEC(PEC) (((PEC) == SMBUS_PEC_DISABLE) || \ + ((PEC) == SMBUS_PEC_ENABLE)) + +#define IS_SMBUS_PERIPHERAL_MODE(MODE) (((MODE) == SMBUS_PERIPHERAL_MODE_SMBUS_HOST) || \ + ((MODE) == SMBUS_PERIPHERAL_MODE_SMBUS_SLAVE) || \ + ((MODE) == SMBUS_PERIPHERAL_MODE_SMBUS_SLAVE_ARP)) + +#define IS_SMBUS_TRANSFER_MODE(MODE) (((MODE) == SMBUS_RELOAD_MODE) || \ + ((MODE) == SMBUS_AUTOEND_MODE) || \ + ((MODE) == SMBUS_SOFTEND_MODE) || \ + ((MODE) == SMBUS_SENDPEC_MODE) || \ + ((MODE) == (SMBUS_RELOAD_MODE | SMBUS_SENDPEC_MODE)) || \ + ((MODE) == (SMBUS_AUTOEND_MODE | SMBUS_SENDPEC_MODE)) || \ + ((MODE) == (SMBUS_AUTOEND_MODE | SMBUS_RELOAD_MODE)) || \ + ((MODE) == (SMBUS_AUTOEND_MODE | SMBUS_SENDPEC_MODE | \ + SMBUS_RELOAD_MODE ))) + + +#define IS_SMBUS_TRANSFER_REQUEST(REQUEST) (((REQUEST) == SMBUS_GENERATE_STOP) || \ + ((REQUEST) == SMBUS_GENERATE_START_READ) || \ + ((REQUEST) == SMBUS_GENERATE_START_WRITE) || \ + ((REQUEST) == SMBUS_NO_STARTSTOP)) + + +#define IS_SMBUS_TRANSFER_OPTIONS_REQUEST(REQUEST) (IS_SMBUS_TRANSFER_OTHER_OPTIONS_REQUEST(REQUEST) || \ + ((REQUEST) == SMBUS_FIRST_FRAME) || \ + ((REQUEST) == SMBUS_NEXT_FRAME) || \ + ((REQUEST) == SMBUS_FIRST_AND_LAST_FRAME_NO_PEC) || \ + ((REQUEST) == SMBUS_LAST_FRAME_NO_PEC) || \ + ((REQUEST) == SMBUS_FIRST_FRAME_WITH_PEC) || \ + ((REQUEST) == SMBUS_FIRST_AND_LAST_FRAME_WITH_PEC) || \ + ((REQUEST) == SMBUS_LAST_FRAME_WITH_PEC)) + +#define IS_SMBUS_TRANSFER_OTHER_OPTIONS_REQUEST(REQUEST) (((REQUEST) == SMBUS_OTHER_FRAME_NO_PEC) || \ + ((REQUEST) == SMBUS_OTHER_AND_LAST_FRAME_NO_PEC) || \ + ((REQUEST) == SMBUS_OTHER_FRAME_WITH_PEC) || \ + ((REQUEST) == SMBUS_OTHER_AND_LAST_FRAME_WITH_PEC)) + +#define SMBUS_RESET_CR1(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= \ + (uint32_t)~((uint32_t)(I2C_CR1_SMBHEN | I2C_CR1_SMBDEN | \ + I2C_CR1_PECEN))) +#define SMBUS_RESET_CR2(__HANDLE__) ((__HANDLE__)->Instance->CR2 &= \ + (uint32_t)~((uint32_t)(I2C_CR2_SADD | I2C_CR2_HEAD10R | \ + I2C_CR2_NBYTES | I2C_CR2_RELOAD | \ + I2C_CR2_RD_WRN))) + +#define SMBUS_GENERATE_START(__ADDMODE__,__ADDRESS__) (((__ADDMODE__) == SMBUS_ADDRESSINGMODE_7BIT) ? \ + (uint32_t)((((uint32_t)(__ADDRESS__) & (I2C_CR2_SADD)) | \ + (I2C_CR2_START) | (I2C_CR2_AUTOEND)) & \ + (~I2C_CR2_RD_WRN)) : \ + (uint32_t)((((uint32_t)(__ADDRESS__) & \ + (I2C_CR2_SADD)) | (I2C_CR2_ADD10) | \ + (I2C_CR2_START)) & (~I2C_CR2_RD_WRN))) + +#define SMBUS_GET_ADDR_MATCH(__HANDLE__) (((__HANDLE__)->Instance->ISR & I2C_ISR_ADDCODE) >> 17U) +#define SMBUS_GET_DIR(__HANDLE__) (((__HANDLE__)->Instance->ISR & I2C_ISR_DIR) >> 16U) +#define SMBUS_GET_STOP_MODE(__HANDLE__) ((__HANDLE__)->Instance->CR2 & I2C_CR2_AUTOEND) +#define SMBUS_GET_PEC_MODE(__HANDLE__) ((__HANDLE__)->Instance->CR2 & I2C_CR2_PECBYTE) +#define SMBUS_GET_ALERT_ENABLED(__HANDLE__) ((__HANDLE__)->Instance->CR1 & I2C_CR1_ALERTEN) + +#define SMBUS_CHECK_FLAG(__ISR__, __FLAG__) ((((__ISR__) & ((__FLAG__) & SMBUS_FLAG_MASK)) == \ + ((__FLAG__) & SMBUS_FLAG_MASK)) ? SET : RESET) +#define SMBUS_CHECK_IT_SOURCE(__CR1__, __IT__) ((((__CR1__) & (__IT__)) == (__IT__)) ? SET : RESET) + +#define IS_SMBUS_OWN_ADDRESS1(ADDRESS1) ((ADDRESS1) <= 0x000003FFU) +#define IS_SMBUS_OWN_ADDRESS2(ADDRESS2) ((ADDRESS2) <= (uint16_t)0x00FFU) + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup SMBUS_Exported_Functions SMBUS Exported Functions + * @{ + */ + +/** @addtogroup SMBUS_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_SMBUS_Init(SMBUS_HandleTypeDef *hsmbus); +HAL_StatusTypeDef HAL_SMBUS_DeInit(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_MspInit(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_MspDeInit(SMBUS_HandleTypeDef *hsmbus); +HAL_StatusTypeDef HAL_SMBUS_ConfigAnalogFilter(SMBUS_HandleTypeDef *hsmbus, uint32_t AnalogFilter); +HAL_StatusTypeDef HAL_SMBUS_ConfigDigitalFilter(SMBUS_HandleTypeDef *hsmbus, uint32_t DigitalFilter); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_SMBUS_RegisterCallback(SMBUS_HandleTypeDef *hsmbus, + HAL_SMBUS_CallbackIDTypeDef CallbackID, + pSMBUS_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_SMBUS_UnRegisterCallback(SMBUS_HandleTypeDef *hsmbus, + HAL_SMBUS_CallbackIDTypeDef CallbackID); + +HAL_StatusTypeDef HAL_SMBUS_RegisterAddrCallback(SMBUS_HandleTypeDef *hsmbus, + pSMBUS_AddrCallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_SMBUS_UnRegisterAddrCallback(SMBUS_HandleTypeDef *hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @addtogroup SMBUS_Exported_Functions_Group2 Input and Output operation functions + * @{ + */ + +/* IO operation functions *****************************************************/ +/** @addtogroup Blocking_mode_Polling Blocking mode Polling + * @{ + */ +/******* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_SMBUS_IsDeviceReady(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, uint32_t Trials, + uint32_t Timeout); +/** + * @} + */ + +/** @addtogroup Non-Blocking_mode_Interrupt Non-Blocking mode Interrupt + * @{ + */ +/******* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_SMBUS_Master_Transmit_IT(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, + uint8_t *pData, uint16_t Size, uint32_t XferOptions); +HAL_StatusTypeDef HAL_SMBUS_Master_Receive_IT(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, + uint8_t *pData, uint16_t Size, uint32_t XferOptions); +HAL_StatusTypeDef HAL_SMBUS_Master_Abort_IT(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress); +HAL_StatusTypeDef HAL_SMBUS_Slave_Transmit_IT(SMBUS_HandleTypeDef *hsmbus, uint8_t *pData, uint16_t Size, + uint32_t XferOptions); +HAL_StatusTypeDef HAL_SMBUS_Slave_Receive_IT(SMBUS_HandleTypeDef *hsmbus, uint8_t *pData, uint16_t Size, + uint32_t XferOptions); + +HAL_StatusTypeDef HAL_SMBUS_EnableAlert_IT(SMBUS_HandleTypeDef *hsmbus); +HAL_StatusTypeDef HAL_SMBUS_DisableAlert_IT(SMBUS_HandleTypeDef *hsmbus); +HAL_StatusTypeDef HAL_SMBUS_EnableListen_IT(SMBUS_HandleTypeDef *hsmbus); +HAL_StatusTypeDef HAL_SMBUS_DisableListen_IT(SMBUS_HandleTypeDef *hsmbus); +/** + * @} + */ + +/** @addtogroup SMBUS_IRQ_Handler_and_Callbacks IRQ Handler and Callbacks + * @{ + */ +/******* SMBUS IRQHandler and Callbacks used in non blocking modes (Interrupt) */ +void HAL_SMBUS_EV_IRQHandler(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_ER_IRQHandler(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_MasterTxCpltCallback(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_MasterRxCpltCallback(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_SlaveTxCpltCallback(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_SlaveRxCpltCallback(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_AddrCallback(SMBUS_HandleTypeDef *hsmbus, uint8_t TransferDirection, uint16_t AddrMatchCode); +void HAL_SMBUS_ListenCpltCallback(SMBUS_HandleTypeDef *hsmbus); +void HAL_SMBUS_ErrorCallback(SMBUS_HandleTypeDef *hsmbus); + +/** + * @} + */ + +/** @addtogroup SMBUS_Exported_Functions_Group3 Peripheral State and Errors functions + * @{ + */ + +/* Peripheral State and Errors functions **************************************************/ +uint32_t HAL_SMBUS_GetState(SMBUS_HandleTypeDef *hsmbus); +uint32_t HAL_SMBUS_GetError(SMBUS_HandleTypeDef *hsmbus); + +/** + * @} + */ + +/** + * @} + */ + +/* Private Functions ---------------------------------------------------------*/ +/** @defgroup SMBUS_Private_Functions SMBUS Private Functions + * @{ + */ +/* Private functions are defined in stm32f0xx_hal_smbus.c file */ +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + + +#endif /* STM32F0xx_HAL_SMBUS_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi.h new file mode 100644 index 0000000..a1255d5 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi.h @@ -0,0 +1,852 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_spi.h + * @author MCD Application Team + * @brief Header file of SPI HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_SPI_H +#define STM32F0xx_HAL_SPI_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup SPI + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup SPI_Exported_Types SPI Exported Types + * @{ + */ + +/** + * @brief SPI Configuration Structure definition + */ +typedef struct +{ + uint32_t Mode; /*!< Specifies the SPI operating mode. + This parameter can be a value of @ref SPI_Mode */ + + uint32_t Direction; /*!< Specifies the SPI bidirectional mode state. + This parameter can be a value of @ref SPI_Direction */ + + uint32_t DataSize; /*!< Specifies the SPI data size. + This parameter can be a value of @ref SPI_Data_Size */ + + uint32_t CLKPolarity; /*!< Specifies the serial clock steady state. + This parameter can be a value of @ref SPI_Clock_Polarity */ + + uint32_t CLKPhase; /*!< Specifies the clock active edge for the bit capture. + This parameter can be a value of @ref SPI_Clock_Phase */ + + uint32_t NSS; /*!< Specifies whether the NSS signal is managed by + hardware (NSS pin) or by software using the SSI bit. + This parameter can be a value of @ref SPI_Slave_Select_management */ + + uint32_t BaudRatePrescaler; /*!< Specifies the Baud Rate prescaler value which will be + used to configure the transmit and receive SCK clock. + This parameter can be a value of @ref SPI_BaudRate_Prescaler + @note The communication clock is derived from the master + clock. The slave clock does not need to be set. */ + + uint32_t FirstBit; /*!< Specifies whether data transfers start from MSB or LSB bit. + This parameter can be a value of @ref SPI_MSB_LSB_transmission */ + + uint32_t TIMode; /*!< Specifies if the TI mode is enabled or not. + This parameter can be a value of @ref SPI_TI_mode */ + + uint32_t CRCCalculation; /*!< Specifies if the CRC calculation is enabled or not. + This parameter can be a value of @ref SPI_CRC_Calculation */ + + uint32_t CRCPolynomial; /*!< Specifies the polynomial used for the CRC calculation. + This parameter must be an odd number between Min_Data = 1 and Max_Data = 65535 */ + + uint32_t CRCLength; /*!< Specifies the CRC Length used for the CRC calculation. + CRC Length is only used with Data8 and Data16, not other data size + This parameter can be a value of @ref SPI_CRC_length */ + + uint32_t NSSPMode; /*!< Specifies whether the NSSP signal is enabled or not . + This parameter can be a value of @ref SPI_NSSP_Mode + This mode is activated by the NSSP bit in the SPIx_CR2 register and + it takes effect only if the SPI interface is configured as Motorola SPI + master (FRF=0) with capture on the first edge (SPIx_CR1 CPHA = 0, + CPOL setting is ignored).. */ +} SPI_InitTypeDef; + +/** + * @brief HAL SPI State structure definition + */ +typedef enum +{ + HAL_SPI_STATE_RESET = 0x00U, /*!< Peripheral not Initialized */ + HAL_SPI_STATE_READY = 0x01U, /*!< Peripheral Initialized and ready for use */ + HAL_SPI_STATE_BUSY = 0x02U, /*!< an internal process is ongoing */ + HAL_SPI_STATE_BUSY_TX = 0x03U, /*!< Data Transmission process is ongoing */ + HAL_SPI_STATE_BUSY_RX = 0x04U, /*!< Data Reception process is ongoing */ + HAL_SPI_STATE_BUSY_TX_RX = 0x05U, /*!< Data Transmission and Reception process is ongoing */ + HAL_SPI_STATE_ERROR = 0x06U, /*!< SPI error state */ + HAL_SPI_STATE_ABORT = 0x07U /*!< SPI abort is ongoing */ +} HAL_SPI_StateTypeDef; + +/** + * @brief SPI handle Structure definition + */ +typedef struct __SPI_HandleTypeDef +{ + SPI_TypeDef *Instance; /*!< SPI registers base address */ + + SPI_InitTypeDef Init; /*!< SPI communication parameters */ + + uint8_t *pTxBuffPtr; /*!< Pointer to SPI Tx transfer Buffer */ + + uint16_t TxXferSize; /*!< SPI Tx Transfer size */ + + __IO uint16_t TxXferCount; /*!< SPI Tx Transfer Counter */ + + uint8_t *pRxBuffPtr; /*!< Pointer to SPI Rx transfer Buffer */ + + uint16_t RxXferSize; /*!< SPI Rx Transfer size */ + + __IO uint16_t RxXferCount; /*!< SPI Rx Transfer Counter */ + + uint32_t CRCSize; /*!< SPI CRC size used for the transfer */ + + void (*RxISR)(struct __SPI_HandleTypeDef *hspi); /*!< function pointer on Rx ISR */ + + void (*TxISR)(struct __SPI_HandleTypeDef *hspi); /*!< function pointer on Tx ISR */ + + DMA_HandleTypeDef *hdmatx; /*!< SPI Tx DMA Handle parameters */ + + DMA_HandleTypeDef *hdmarx; /*!< SPI Rx DMA Handle parameters */ + + HAL_LockTypeDef Lock; /*!< Locking object */ + + __IO HAL_SPI_StateTypeDef State; /*!< SPI communication state */ + + __IO uint32_t ErrorCode; /*!< SPI Error code */ + +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + void (* TxCpltCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Tx Completed callback */ + void (* RxCpltCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Rx Completed callback */ + void (* TxRxCpltCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI TxRx Completed callback */ + void (* TxHalfCpltCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Tx Half Completed callback */ + void (* RxHalfCpltCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Rx Half Completed callback */ + void (* TxRxHalfCpltCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI TxRx Half Completed callback */ + void (* ErrorCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Error callback */ + void (* AbortCpltCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Abort callback */ + void (* MspInitCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Msp Init callback */ + void (* MspDeInitCallback)(struct __SPI_HandleTypeDef *hspi); /*!< SPI Msp DeInit callback */ + +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} SPI_HandleTypeDef; + +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) +/** + * @brief HAL SPI Callback ID enumeration definition + */ +typedef enum +{ + HAL_SPI_TX_COMPLETE_CB_ID = 0x00U, /*!< SPI Tx Completed callback ID */ + HAL_SPI_RX_COMPLETE_CB_ID = 0x01U, /*!< SPI Rx Completed callback ID */ + HAL_SPI_TX_RX_COMPLETE_CB_ID = 0x02U, /*!< SPI TxRx Completed callback ID */ + HAL_SPI_TX_HALF_COMPLETE_CB_ID = 0x03U, /*!< SPI Tx Half Completed callback ID */ + HAL_SPI_RX_HALF_COMPLETE_CB_ID = 0x04U, /*!< SPI Rx Half Completed callback ID */ + HAL_SPI_TX_RX_HALF_COMPLETE_CB_ID = 0x05U, /*!< SPI TxRx Half Completed callback ID */ + HAL_SPI_ERROR_CB_ID = 0x06U, /*!< SPI Error callback ID */ + HAL_SPI_ABORT_CB_ID = 0x07U, /*!< SPI Abort callback ID */ + HAL_SPI_MSPINIT_CB_ID = 0x08U, /*!< SPI Msp Init callback ID */ + HAL_SPI_MSPDEINIT_CB_ID = 0x09U /*!< SPI Msp DeInit callback ID */ + +} HAL_SPI_CallbackIDTypeDef; + +/** + * @brief HAL SPI Callback pointer definition + */ +typedef void (*pSPI_CallbackTypeDef)(SPI_HandleTypeDef *hspi); /*!< pointer to an SPI callback function */ + +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup SPI_Exported_Constants SPI Exported Constants + * @{ + */ + +/** @defgroup SPI_Error_Code SPI Error Code + * @{ + */ +#define HAL_SPI_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_SPI_ERROR_MODF (0x00000001U) /*!< MODF error */ +#define HAL_SPI_ERROR_CRC (0x00000002U) /*!< CRC error */ +#define HAL_SPI_ERROR_OVR (0x00000004U) /*!< OVR error */ +#define HAL_SPI_ERROR_FRE (0x00000008U) /*!< FRE error */ +#define HAL_SPI_ERROR_DMA (0x00000010U) /*!< DMA transfer error */ +#define HAL_SPI_ERROR_FLAG (0x00000020U) /*!< Error on RXNE/TXE/BSY/FTLVL/FRLVL Flag */ +#define HAL_SPI_ERROR_ABORT (0x00000040U) /*!< Error during SPI Abort procedure */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) +#define HAL_SPI_ERROR_INVALID_CALLBACK (0x00000080U) /*!< Invalid Callback error */ +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup SPI_Mode SPI Mode + * @{ + */ +#define SPI_MODE_SLAVE (0x00000000U) +#define SPI_MODE_MASTER (SPI_CR1_MSTR | SPI_CR1_SSI) +/** + * @} + */ + +/** @defgroup SPI_Direction SPI Direction Mode + * @{ + */ +#define SPI_DIRECTION_2LINES (0x00000000U) +#define SPI_DIRECTION_2LINES_RXONLY SPI_CR1_RXONLY +#define SPI_DIRECTION_1LINE SPI_CR1_BIDIMODE +/** + * @} + */ + +/** @defgroup SPI_Data_Size SPI Data Size + * @{ + */ +#define SPI_DATASIZE_4BIT (0x00000300U) +#define SPI_DATASIZE_5BIT (0x00000400U) +#define SPI_DATASIZE_6BIT (0x00000500U) +#define SPI_DATASIZE_7BIT (0x00000600U) +#define SPI_DATASIZE_8BIT (0x00000700U) +#define SPI_DATASIZE_9BIT (0x00000800U) +#define SPI_DATASIZE_10BIT (0x00000900U) +#define SPI_DATASIZE_11BIT (0x00000A00U) +#define SPI_DATASIZE_12BIT (0x00000B00U) +#define SPI_DATASIZE_13BIT (0x00000C00U) +#define SPI_DATASIZE_14BIT (0x00000D00U) +#define SPI_DATASIZE_15BIT (0x00000E00U) +#define SPI_DATASIZE_16BIT (0x00000F00U) +/** + * @} + */ + +/** @defgroup SPI_Clock_Polarity SPI Clock Polarity + * @{ + */ +#define SPI_POLARITY_LOW (0x00000000U) +#define SPI_POLARITY_HIGH SPI_CR1_CPOL +/** + * @} + */ + +/** @defgroup SPI_Clock_Phase SPI Clock Phase + * @{ + */ +#define SPI_PHASE_1EDGE (0x00000000U) +#define SPI_PHASE_2EDGE SPI_CR1_CPHA +/** + * @} + */ + +/** @defgroup SPI_Slave_Select_management SPI Slave Select Management + * @{ + */ +#define SPI_NSS_SOFT SPI_CR1_SSM +#define SPI_NSS_HARD_INPUT (0x00000000U) +#define SPI_NSS_HARD_OUTPUT (SPI_CR2_SSOE << 16U) +/** + * @} + */ + +/** @defgroup SPI_NSSP_Mode SPI NSS Pulse Mode + * @{ + */ +#define SPI_NSS_PULSE_ENABLE SPI_CR2_NSSP +#define SPI_NSS_PULSE_DISABLE (0x00000000U) +/** + * @} + */ + +/** @defgroup SPI_BaudRate_Prescaler SPI BaudRate Prescaler + * @{ + */ +#define SPI_BAUDRATEPRESCALER_2 (0x00000000U) +#define SPI_BAUDRATEPRESCALER_4 (SPI_CR1_BR_0) +#define SPI_BAUDRATEPRESCALER_8 (SPI_CR1_BR_1) +#define SPI_BAUDRATEPRESCALER_16 (SPI_CR1_BR_1 | SPI_CR1_BR_0) +#define SPI_BAUDRATEPRESCALER_32 (SPI_CR1_BR_2) +#define SPI_BAUDRATEPRESCALER_64 (SPI_CR1_BR_2 | SPI_CR1_BR_0) +#define SPI_BAUDRATEPRESCALER_128 (SPI_CR1_BR_2 | SPI_CR1_BR_1) +#define SPI_BAUDRATEPRESCALER_256 (SPI_CR1_BR_2 | SPI_CR1_BR_1 | SPI_CR1_BR_0) +/** + * @} + */ + +/** @defgroup SPI_MSB_LSB_transmission SPI MSB LSB Transmission + * @{ + */ +#define SPI_FIRSTBIT_MSB (0x00000000U) +#define SPI_FIRSTBIT_LSB SPI_CR1_LSBFIRST +/** + * @} + */ + +/** @defgroup SPI_TI_mode SPI TI Mode + * @{ + */ +#define SPI_TIMODE_DISABLE (0x00000000U) +#define SPI_TIMODE_ENABLE SPI_CR2_FRF +/** + * @} + */ + +/** @defgroup SPI_CRC_Calculation SPI CRC Calculation + * @{ + */ +#define SPI_CRCCALCULATION_DISABLE (0x00000000U) +#define SPI_CRCCALCULATION_ENABLE SPI_CR1_CRCEN +/** + * @} + */ + +/** @defgroup SPI_CRC_length SPI CRC Length + * @{ + * This parameter can be one of the following values: + * SPI_CRC_LENGTH_DATASIZE: aligned with the data size + * SPI_CRC_LENGTH_8BIT : CRC 8bit + * SPI_CRC_LENGTH_16BIT : CRC 16bit + */ +#define SPI_CRC_LENGTH_DATASIZE (0x00000000U) +#define SPI_CRC_LENGTH_8BIT (0x00000001U) +#define SPI_CRC_LENGTH_16BIT (0x00000002U) +/** + * @} + */ + +/** @defgroup SPI_FIFO_reception_threshold SPI FIFO Reception Threshold + * @{ + * This parameter can be one of the following values: + * SPI_RXFIFO_THRESHOLD or SPI_RXFIFO_THRESHOLD_QF : + * RXNE event is generated if the FIFO + * level is greater or equal to 1/4(8-bits). + * SPI_RXFIFO_THRESHOLD_HF: RXNE event is generated if the FIFO + * level is greater or equal to 1/2(16 bits). */ +#define SPI_RXFIFO_THRESHOLD SPI_CR2_FRXTH +#define SPI_RXFIFO_THRESHOLD_QF SPI_CR2_FRXTH +#define SPI_RXFIFO_THRESHOLD_HF (0x00000000U) +/** + * @} + */ + +/** @defgroup SPI_Interrupt_definition SPI Interrupt Definition + * @{ + */ +#define SPI_IT_TXE SPI_CR2_TXEIE +#define SPI_IT_RXNE SPI_CR2_RXNEIE +#define SPI_IT_ERR SPI_CR2_ERRIE +/** + * @} + */ + +/** @defgroup SPI_Flags_definition SPI Flags Definition + * @{ + */ +#define SPI_FLAG_RXNE SPI_SR_RXNE /* SPI status flag: Rx buffer not empty flag */ +#define SPI_FLAG_TXE SPI_SR_TXE /* SPI status flag: Tx buffer empty flag */ +#define SPI_FLAG_BSY SPI_SR_BSY /* SPI status flag: Busy flag */ +#define SPI_FLAG_CRCERR SPI_SR_CRCERR /* SPI Error flag: CRC error flag */ +#define SPI_FLAG_MODF SPI_SR_MODF /* SPI Error flag: Mode fault flag */ +#define SPI_FLAG_OVR SPI_SR_OVR /* SPI Error flag: Overrun flag */ +#define SPI_FLAG_FRE SPI_SR_FRE /* SPI Error flag: TI mode frame format error flag */ +#define SPI_FLAG_FTLVL SPI_SR_FTLVL /* SPI fifo transmission level */ +#define SPI_FLAG_FRLVL SPI_SR_FRLVL /* SPI fifo reception level */ +#define SPI_FLAG_MASK (SPI_SR_RXNE | SPI_SR_TXE | SPI_SR_BSY | SPI_SR_CRCERR\ + | SPI_SR_MODF | SPI_SR_OVR | SPI_SR_FRE | SPI_SR_FTLVL | SPI_SR_FRLVL) +/** + * @} + */ + +/** @defgroup SPI_transmission_fifo_status_level SPI Transmission FIFO Status Level + * @{ + */ +#define SPI_FTLVL_EMPTY (0x00000000U) +#define SPI_FTLVL_QUARTER_FULL (0x00000800U) +#define SPI_FTLVL_HALF_FULL (0x00001000U) +#define SPI_FTLVL_FULL (0x00001800U) + +/** + * @} + */ + +/** @defgroup SPI_reception_fifo_status_level SPI Reception FIFO Status Level + * @{ + */ +#define SPI_FRLVL_EMPTY (0x00000000U) +#define SPI_FRLVL_QUARTER_FULL (0x00000200U) +#define SPI_FRLVL_HALF_FULL (0x00000400U) +#define SPI_FRLVL_FULL (0x00000600U) +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup SPI_Exported_Macros SPI Exported Macros + * @{ + */ + +/** @brief Reset SPI handle state. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) +#define __HAL_SPI_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_SPI_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_SPI_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_SPI_STATE_RESET) +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + +/** @brief Enable the specified SPI interrupts. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @param __INTERRUPT__ specifies the interrupt source to enable. + * This parameter can be one of the following values: + * @arg SPI_IT_TXE: Tx buffer empty interrupt enable + * @arg SPI_IT_RXNE: RX buffer not empty interrupt enable + * @arg SPI_IT_ERR: Error interrupt enable + * @retval None + */ +#define __HAL_SPI_ENABLE_IT(__HANDLE__, __INTERRUPT__) SET_BIT((__HANDLE__)->Instance->CR2, (__INTERRUPT__)) + +/** @brief Disable the specified SPI interrupts. + * @param __HANDLE__ specifies the SPI handle. + * This parameter can be SPIx where x: 1, 2, or 3 to select the SPI peripheral. + * @param __INTERRUPT__ specifies the interrupt source to disable. + * This parameter can be one of the following values: + * @arg SPI_IT_TXE: Tx buffer empty interrupt enable + * @arg SPI_IT_RXNE: RX buffer not empty interrupt enable + * @arg SPI_IT_ERR: Error interrupt enable + * @retval None + */ +#define __HAL_SPI_DISABLE_IT(__HANDLE__, __INTERRUPT__) CLEAR_BIT((__HANDLE__)->Instance->CR2, (__INTERRUPT__)) + +/** @brief Check whether the specified SPI interrupt source is enabled or not. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @param __INTERRUPT__ specifies the SPI interrupt source to check. + * This parameter can be one of the following values: + * @arg SPI_IT_TXE: Tx buffer empty interrupt enable + * @arg SPI_IT_RXNE: RX buffer not empty interrupt enable + * @arg SPI_IT_ERR: Error interrupt enable + * @retval The new state of __IT__ (TRUE or FALSE). + */ +#define __HAL_SPI_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->CR2\ + & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET) + +/** @brief Check whether the specified SPI flag is set or not. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg SPI_FLAG_RXNE: Receive buffer not empty flag + * @arg SPI_FLAG_TXE: Transmit buffer empty flag + * @arg SPI_FLAG_CRCERR: CRC error flag + * @arg SPI_FLAG_MODF: Mode fault flag + * @arg SPI_FLAG_OVR: Overrun flag + * @arg SPI_FLAG_BSY: Busy flag + * @arg SPI_FLAG_FRE: Frame format error flag + * @arg SPI_FLAG_FTLVL: SPI fifo transmission level + * @arg SPI_FLAG_FRLVL: SPI fifo reception level + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_SPI_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->SR) & (__FLAG__)) == (__FLAG__)) + +/** @brief Clear the SPI CRCERR pending flag. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define __HAL_SPI_CLEAR_CRCERRFLAG(__HANDLE__) ((__HANDLE__)->Instance->SR = (uint16_t)(~SPI_FLAG_CRCERR)) + +/** @brief Clear the SPI MODF pending flag. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define __HAL_SPI_CLEAR_MODFFLAG(__HANDLE__) \ + do{ \ + __IO uint32_t tmpreg_modf = 0x00U; \ + tmpreg_modf = (__HANDLE__)->Instance->SR; \ + CLEAR_BIT((__HANDLE__)->Instance->CR1, SPI_CR1_SPE); \ + UNUSED(tmpreg_modf); \ + } while(0U) + +/** @brief Clear the SPI OVR pending flag. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define __HAL_SPI_CLEAR_OVRFLAG(__HANDLE__) \ + do{ \ + __IO uint32_t tmpreg_ovr = 0x00U; \ + tmpreg_ovr = (__HANDLE__)->Instance->DR; \ + tmpreg_ovr = (__HANDLE__)->Instance->SR; \ + UNUSED(tmpreg_ovr); \ + } while(0U) + +/** @brief Clear the SPI FRE pending flag. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define __HAL_SPI_CLEAR_FREFLAG(__HANDLE__) \ + do{ \ + __IO uint32_t tmpreg_fre = 0x00U; \ + tmpreg_fre = (__HANDLE__)->Instance->SR; \ + UNUSED(tmpreg_fre); \ + }while(0U) + +/** @brief Enable the SPI peripheral. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define __HAL_SPI_ENABLE(__HANDLE__) SET_BIT((__HANDLE__)->Instance->CR1, SPI_CR1_SPE) + +/** @brief Disable the SPI peripheral. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define __HAL_SPI_DISABLE(__HANDLE__) CLEAR_BIT((__HANDLE__)->Instance->CR1, SPI_CR1_SPE) + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup SPI_Private_Macros SPI Private Macros + * @{ + */ + +/** @brief Set the SPI transmit-only mode. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define SPI_1LINE_TX(__HANDLE__) SET_BIT((__HANDLE__)->Instance->CR1, SPI_CR1_BIDIOE) + +/** @brief Set the SPI receive-only mode. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define SPI_1LINE_RX(__HANDLE__) CLEAR_BIT((__HANDLE__)->Instance->CR1, SPI_CR1_BIDIOE) + +/** @brief Reset the CRC calculation of the SPI. + * @param __HANDLE__ specifies the SPI Handle. + * This parameter can be SPI where x: 1, 2, or 3 to select the SPI peripheral. + * @retval None + */ +#define SPI_RESET_CRC(__HANDLE__) do{CLEAR_BIT((__HANDLE__)->Instance->CR1, SPI_CR1_CRCEN);\ + SET_BIT((__HANDLE__)->Instance->CR1, SPI_CR1_CRCEN);}while(0U) + +/** @brief Check whether the specified SPI flag is set or not. + * @param __SR__ copy of SPI SR register. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg SPI_FLAG_RXNE: Receive buffer not empty flag + * @arg SPI_FLAG_TXE: Transmit buffer empty flag + * @arg SPI_FLAG_CRCERR: CRC error flag + * @arg SPI_FLAG_MODF: Mode fault flag + * @arg SPI_FLAG_OVR: Overrun flag + * @arg SPI_FLAG_BSY: Busy flag + * @arg SPI_FLAG_FRE: Frame format error flag + * @arg SPI_FLAG_FTLVL: SPI fifo transmission level + * @arg SPI_FLAG_FRLVL: SPI fifo reception level + * @retval SET or RESET. + */ +#define SPI_CHECK_FLAG(__SR__, __FLAG__) ((((__SR__) & ((__FLAG__) & SPI_FLAG_MASK)) == \ + ((__FLAG__) & SPI_FLAG_MASK)) ? SET : RESET) + +/** @brief Check whether the specified SPI Interrupt is set or not. + * @param __CR2__ copy of SPI CR2 register. + * @param __INTERRUPT__ specifies the SPI interrupt source to check. + * This parameter can be one of the following values: + * @arg SPI_IT_TXE: Tx buffer empty interrupt enable + * @arg SPI_IT_RXNE: RX buffer not empty interrupt enable + * @arg SPI_IT_ERR: Error interrupt enable + * @retval SET or RESET. + */ +#define SPI_CHECK_IT_SOURCE(__CR2__, __INTERRUPT__) ((((__CR2__) & (__INTERRUPT__)) == \ + (__INTERRUPT__)) ? SET : RESET) + +/** @brief Checks if SPI Mode parameter is in allowed range. + * @param __MODE__ specifies the SPI Mode. + * This parameter can be a value of @ref SPI_Mode + * @retval None + */ +#define IS_SPI_MODE(__MODE__) (((__MODE__) == SPI_MODE_SLAVE) || \ + ((__MODE__) == SPI_MODE_MASTER)) + +/** @brief Checks if SPI Direction Mode parameter is in allowed range. + * @param __MODE__ specifies the SPI Direction Mode. + * This parameter can be a value of @ref SPI_Direction + * @retval None + */ +#define IS_SPI_DIRECTION(__MODE__) (((__MODE__) == SPI_DIRECTION_2LINES) || \ + ((__MODE__) == SPI_DIRECTION_2LINES_RXONLY) || \ + ((__MODE__) == SPI_DIRECTION_1LINE)) + +/** @brief Checks if SPI Direction Mode parameter is 2 lines. + * @param __MODE__ specifies the SPI Direction Mode. + * @retval None + */ +#define IS_SPI_DIRECTION_2LINES(__MODE__) ((__MODE__) == SPI_DIRECTION_2LINES) + +/** @brief Checks if SPI Direction Mode parameter is 1 or 2 lines. + * @param __MODE__ specifies the SPI Direction Mode. + * @retval None + */ +#define IS_SPI_DIRECTION_2LINES_OR_1LINE(__MODE__) (((__MODE__) == SPI_DIRECTION_2LINES) || \ + ((__MODE__) == SPI_DIRECTION_1LINE)) + +/** @brief Checks if SPI Data Size parameter is in allowed range. + * @param __DATASIZE__ specifies the SPI Data Size. + * This parameter can be a value of @ref SPI_Data_Size + * @retval None + */ +#define IS_SPI_DATASIZE(__DATASIZE__) (((__DATASIZE__) == SPI_DATASIZE_16BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_15BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_14BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_13BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_12BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_11BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_10BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_9BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_8BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_7BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_6BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_5BIT) || \ + ((__DATASIZE__) == SPI_DATASIZE_4BIT)) + +/** @brief Checks if SPI Serial clock steady state parameter is in allowed range. + * @param __CPOL__ specifies the SPI serial clock steady state. + * This parameter can be a value of @ref SPI_Clock_Polarity + * @retval None + */ +#define IS_SPI_CPOL(__CPOL__) (((__CPOL__) == SPI_POLARITY_LOW) || \ + ((__CPOL__) == SPI_POLARITY_HIGH)) + +/** @brief Checks if SPI Clock Phase parameter is in allowed range. + * @param __CPHA__ specifies the SPI Clock Phase. + * This parameter can be a value of @ref SPI_Clock_Phase + * @retval None + */ +#define IS_SPI_CPHA(__CPHA__) (((__CPHA__) == SPI_PHASE_1EDGE) || \ + ((__CPHA__) == SPI_PHASE_2EDGE)) + +/** @brief Checks if SPI Slave Select parameter is in allowed range. + * @param __NSS__ specifies the SPI Slave Select management parameter. + * This parameter can be a value of @ref SPI_Slave_Select_management + * @retval None + */ +#define IS_SPI_NSS(__NSS__) (((__NSS__) == SPI_NSS_SOFT) || \ + ((__NSS__) == SPI_NSS_HARD_INPUT) || \ + ((__NSS__) == SPI_NSS_HARD_OUTPUT)) + +/** @brief Checks if SPI NSS Pulse parameter is in allowed range. + * @param __NSSP__ specifies the SPI NSS Pulse Mode parameter. + * This parameter can be a value of @ref SPI_NSSP_Mode + * @retval None + */ +#define IS_SPI_NSSP(__NSSP__) (((__NSSP__) == SPI_NSS_PULSE_ENABLE) || \ + ((__NSSP__) == SPI_NSS_PULSE_DISABLE)) + +/** @brief Checks if SPI Baudrate prescaler parameter is in allowed range. + * @param __PRESCALER__ specifies the SPI Baudrate prescaler. + * This parameter can be a value of @ref SPI_BaudRate_Prescaler + * @retval None + */ +#define IS_SPI_BAUDRATE_PRESCALER(__PRESCALER__) (((__PRESCALER__) == SPI_BAUDRATEPRESCALER_2) || \ + ((__PRESCALER__) == SPI_BAUDRATEPRESCALER_4) || \ + ((__PRESCALER__) == SPI_BAUDRATEPRESCALER_8) || \ + ((__PRESCALER__) == SPI_BAUDRATEPRESCALER_16) || \ + ((__PRESCALER__) == SPI_BAUDRATEPRESCALER_32) || \ + ((__PRESCALER__) == SPI_BAUDRATEPRESCALER_64) || \ + ((__PRESCALER__) == SPI_BAUDRATEPRESCALER_128) || \ + ((__PRESCALER__) == SPI_BAUDRATEPRESCALER_256)) + +/** @brief Checks if SPI MSB LSB transmission parameter is in allowed range. + * @param __BIT__ specifies the SPI MSB LSB transmission (whether data transfer starts from MSB or LSB bit). + * This parameter can be a value of @ref SPI_MSB_LSB_transmission + * @retval None + */ +#define IS_SPI_FIRST_BIT(__BIT__) (((__BIT__) == SPI_FIRSTBIT_MSB) || \ + ((__BIT__) == SPI_FIRSTBIT_LSB)) + +/** @brief Checks if SPI TI mode parameter is in allowed range. + * @param __MODE__ specifies the SPI TI mode. + * This parameter can be a value of @ref SPI_TI_mode + * @retval None + */ +#define IS_SPI_TIMODE(__MODE__) (((__MODE__) == SPI_TIMODE_DISABLE) || \ + ((__MODE__) == SPI_TIMODE_ENABLE)) + +/** @brief Checks if SPI CRC calculation enabled state is in allowed range. + * @param __CALCULATION__ specifies the SPI CRC calculation enable state. + * This parameter can be a value of @ref SPI_CRC_Calculation + * @retval None + */ +#define IS_SPI_CRC_CALCULATION(__CALCULATION__) (((__CALCULATION__) == SPI_CRCCALCULATION_DISABLE) || \ + ((__CALCULATION__) == SPI_CRCCALCULATION_ENABLE)) + +/** @brief Checks if SPI CRC length is in allowed range. + * @param __LENGTH__ specifies the SPI CRC length. + * This parameter can be a value of @ref SPI_CRC_length + * @retval None + */ +#define IS_SPI_CRC_LENGTH(__LENGTH__) (((__LENGTH__) == SPI_CRC_LENGTH_DATASIZE) || \ + ((__LENGTH__) == SPI_CRC_LENGTH_8BIT) || \ + ((__LENGTH__) == SPI_CRC_LENGTH_16BIT)) + +/** @brief Checks if SPI polynomial value to be used for the CRC calculation, is in allowed range. + * @param __POLYNOMIAL__ specifies the SPI polynomial value to be used for the CRC calculation. + * This parameter must be a number between Min_Data = 0 and Max_Data = 65535 + * @retval None + */ +#define IS_SPI_CRC_POLYNOMIAL(__POLYNOMIAL__) (((__POLYNOMIAL__) >= 0x1U) && \ + ((__POLYNOMIAL__) <= 0xFFFFU) && \ + (((__POLYNOMIAL__)&0x1U) != 0U)) + +/** @brief Checks if DMA handle is valid. + * @param __HANDLE__ specifies a DMA Handle. + * @retval None + */ +#define IS_SPI_DMA_HANDLE(__HANDLE__) ((__HANDLE__) != NULL) + +/** + * @} + */ + +/* Include SPI HAL Extended module */ +#include "stm32f0xx_hal_spi_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup SPI_Exported_Functions + * @{ + */ + +/** @addtogroup SPI_Exported_Functions_Group1 + * @{ + */ +/* Initialization/de-initialization functions ********************************/ +HAL_StatusTypeDef HAL_SPI_Init(SPI_HandleTypeDef *hspi); +HAL_StatusTypeDef HAL_SPI_DeInit(SPI_HandleTypeDef *hspi); +void HAL_SPI_MspInit(SPI_HandleTypeDef *hspi); +void HAL_SPI_MspDeInit(SPI_HandleTypeDef *hspi); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) +HAL_StatusTypeDef HAL_SPI_RegisterCallback(SPI_HandleTypeDef *hspi, HAL_SPI_CallbackIDTypeDef CallbackID, pSPI_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_SPI_UnRegisterCallback(SPI_HandleTypeDef *hspi, HAL_SPI_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @addtogroup SPI_Exported_Functions_Group2 + * @{ + */ +/* I/O operation functions ***************************************************/ +HAL_StatusTypeDef HAL_SPI_Transmit(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_SPI_Receive(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_SPI_TransmitReceive(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size, + uint32_t Timeout); +HAL_StatusTypeDef HAL_SPI_Transmit_IT(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_SPI_Receive_IT(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_SPI_TransmitReceive_IT(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size); +HAL_StatusTypeDef HAL_SPI_Transmit_DMA(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_SPI_Receive_DMA(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_SPI_TransmitReceive_DMA(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size); +HAL_StatusTypeDef HAL_SPI_DMAPause(SPI_HandleTypeDef *hspi); +HAL_StatusTypeDef HAL_SPI_DMAResume(SPI_HandleTypeDef *hspi); +HAL_StatusTypeDef HAL_SPI_DMAStop(SPI_HandleTypeDef *hspi); +/* Transfer Abort functions */ +HAL_StatusTypeDef HAL_SPI_Abort(SPI_HandleTypeDef *hspi); +HAL_StatusTypeDef HAL_SPI_Abort_IT(SPI_HandleTypeDef *hspi); + +void HAL_SPI_IRQHandler(SPI_HandleTypeDef *hspi); +void HAL_SPI_TxCpltCallback(SPI_HandleTypeDef *hspi); +void HAL_SPI_RxCpltCallback(SPI_HandleTypeDef *hspi); +void HAL_SPI_TxRxCpltCallback(SPI_HandleTypeDef *hspi); +void HAL_SPI_TxHalfCpltCallback(SPI_HandleTypeDef *hspi); +void HAL_SPI_RxHalfCpltCallback(SPI_HandleTypeDef *hspi); +void HAL_SPI_TxRxHalfCpltCallback(SPI_HandleTypeDef *hspi); +void HAL_SPI_ErrorCallback(SPI_HandleTypeDef *hspi); +void HAL_SPI_AbortCpltCallback(SPI_HandleTypeDef *hspi); +/** + * @} + */ + +/** @addtogroup SPI_Exported_Functions_Group3 + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +HAL_SPI_StateTypeDef HAL_SPI_GetState(SPI_HandleTypeDef *hspi); +uint32_t HAL_SPI_GetError(SPI_HandleTypeDef *hspi); +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_SPI_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi_ex.h new file mode 100644 index 0000000..5fbac8f --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_spi_ex.h @@ -0,0 +1,75 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_spi_ex.h + * @author MCD Application Team + * @brief Header file of SPI HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_SPI_EX_H +#define STM32F0xx_HAL_SPI_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup SPIEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/* Exported macros -----------------------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup SPIEx_Exported_Functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +/* IO operation functions *****************************************************/ +/** @addtogroup SPIEx_Exported_Functions_Group1 + * @{ + */ +HAL_StatusTypeDef HAL_SPIEx_FlushRxFifo(SPI_HandleTypeDef *hspi); +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_SPI_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim.h new file mode 100644 index 0000000..1f96b8c --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim.h @@ -0,0 +1,2131 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_tim.h + * @author MCD Application Team + * @brief Header file of TIM HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_TIM_H +#define STM32F0xx_HAL_TIM_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup TIM + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup TIM_Exported_Types TIM Exported Types + * @{ + */ + +/** + * @brief TIM Time base Configuration Structure definition + */ +typedef struct +{ + uint32_t Prescaler; /*!< Specifies the prescaler value used to divide the TIM clock. + This parameter can be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF */ + + uint32_t CounterMode; /*!< Specifies the counter mode. + This parameter can be a value of @ref TIM_Counter_Mode */ + + uint32_t Period; /*!< Specifies the period value to be loaded into the active + Auto-Reload Register at the next update event. + This parameter can be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t ClockDivision; /*!< Specifies the clock division. + This parameter can be a value of @ref TIM_ClockDivision */ + + uint32_t RepetitionCounter; /*!< Specifies the repetition counter value. Each time the RCR downcounter + reaches zero, an update event is generated and counting restarts + from the RCR value (N). + This means in PWM mode that (N+1) corresponds to: + - the number of PWM periods in edge-aligned mode + - the number of half PWM period in center-aligned mode + GP timers: this parameter must be a number between Min_Data = 0x00 and + Max_Data = 0xFF. + Advanced timers: this parameter must be a number between Min_Data = 0x0000 and + Max_Data = 0xFFFF. */ + + uint32_t AutoReloadPreload; /*!< Specifies the auto-reload preload. + This parameter can be a value of @ref TIM_AutoReloadPreload */ +} TIM_Base_InitTypeDef; + +/** + * @brief TIM Output Compare Configuration Structure definition + */ +typedef struct +{ + uint32_t OCMode; /*!< Specifies the TIM mode. + This parameter can be a value of @ref TIM_Output_Compare_and_PWM_modes */ + + uint32_t Pulse; /*!< Specifies the pulse value to be loaded into the Capture Compare Register. + This parameter can be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF */ + + uint32_t OCPolarity; /*!< Specifies the output polarity. + This parameter can be a value of @ref TIM_Output_Compare_Polarity */ + + uint32_t OCNPolarity; /*!< Specifies the complementary output polarity. + This parameter can be a value of @ref TIM_Output_Compare_N_Polarity + @note This parameter is valid only for timer instances supporting break feature. */ + + uint32_t OCFastMode; /*!< Specifies the Fast mode state. + This parameter can be a value of @ref TIM_Output_Fast_State + @note This parameter is valid only in PWM1 and PWM2 mode. */ + + + uint32_t OCIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state. + This parameter can be a value of @ref TIM_Output_Compare_Idle_State + @note This parameter is valid only for timer instances supporting break feature. */ + + uint32_t OCNIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state. + This parameter can be a value of @ref TIM_Output_Compare_N_Idle_State + @note This parameter is valid only for timer instances supporting break feature. */ +} TIM_OC_InitTypeDef; + +/** + * @brief TIM One Pulse Mode Configuration Structure definition + */ +typedef struct +{ + uint32_t OCMode; /*!< Specifies the TIM mode. + This parameter can be a value of @ref TIM_Output_Compare_and_PWM_modes */ + + uint32_t Pulse; /*!< Specifies the pulse value to be loaded into the Capture Compare Register. + This parameter can be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF */ + + uint32_t OCPolarity; /*!< Specifies the output polarity. + This parameter can be a value of @ref TIM_Output_Compare_Polarity */ + + uint32_t OCNPolarity; /*!< Specifies the complementary output polarity. + This parameter can be a value of @ref TIM_Output_Compare_N_Polarity + @note This parameter is valid only for timer instances supporting break feature. */ + + uint32_t OCIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state. + This parameter can be a value of @ref TIM_Output_Compare_Idle_State + @note This parameter is valid only for timer instances supporting break feature. */ + + uint32_t OCNIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state. + This parameter can be a value of @ref TIM_Output_Compare_N_Idle_State + @note This parameter is valid only for timer instances supporting break feature. */ + + uint32_t ICPolarity; /*!< Specifies the active edge of the input signal. + This parameter can be a value of @ref TIM_Input_Capture_Polarity */ + + uint32_t ICSelection; /*!< Specifies the input. + This parameter can be a value of @ref TIM_Input_Capture_Selection */ + + uint32_t ICFilter; /*!< Specifies the input capture filter. + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ +} TIM_OnePulse_InitTypeDef; + +/** + * @brief TIM Input Capture Configuration Structure definition + */ +typedef struct +{ + uint32_t ICPolarity; /*!< Specifies the active edge of the input signal. + This parameter can be a value of @ref TIM_Input_Capture_Polarity */ + + uint32_t ICSelection; /*!< Specifies the input. + This parameter can be a value of @ref TIM_Input_Capture_Selection */ + + uint32_t ICPrescaler; /*!< Specifies the Input Capture Prescaler. + This parameter can be a value of @ref TIM_Input_Capture_Prescaler */ + + uint32_t ICFilter; /*!< Specifies the input capture filter. + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ +} TIM_IC_InitTypeDef; + +/** + * @brief TIM Encoder Configuration Structure definition + */ +typedef struct +{ + uint32_t EncoderMode; /*!< Specifies the active edge of the input signal. + This parameter can be a value of @ref TIM_Encoder_Mode */ + + uint32_t IC1Polarity; /*!< Specifies the active edge of the input signal. + This parameter can be a value of @ref TIM_Encoder_Input_Polarity */ + + uint32_t IC1Selection; /*!< Specifies the input. + This parameter can be a value of @ref TIM_Input_Capture_Selection */ + + uint32_t IC1Prescaler; /*!< Specifies the Input Capture Prescaler. + This parameter can be a value of @ref TIM_Input_Capture_Prescaler */ + + uint32_t IC1Filter; /*!< Specifies the input capture filter. + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ + + uint32_t IC2Polarity; /*!< Specifies the active edge of the input signal. + This parameter can be a value of @ref TIM_Encoder_Input_Polarity */ + + uint32_t IC2Selection; /*!< Specifies the input. + This parameter can be a value of @ref TIM_Input_Capture_Selection */ + + uint32_t IC2Prescaler; /*!< Specifies the Input Capture Prescaler. + This parameter can be a value of @ref TIM_Input_Capture_Prescaler */ + + uint32_t IC2Filter; /*!< Specifies the input capture filter. + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ +} TIM_Encoder_InitTypeDef; + +/** + * @brief Clock Configuration Handle Structure definition + */ +typedef struct +{ + uint32_t ClockSource; /*!< TIM clock sources + This parameter can be a value of @ref TIM_Clock_Source */ + uint32_t ClockPolarity; /*!< TIM clock polarity + This parameter can be a value of @ref TIM_Clock_Polarity */ + uint32_t ClockPrescaler; /*!< TIM clock prescaler + This parameter can be a value of @ref TIM_Clock_Prescaler */ + uint32_t ClockFilter; /*!< TIM clock filter + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ +} TIM_ClockConfigTypeDef; + +/** + * @brief TIM Clear Input Configuration Handle Structure definition + */ +typedef struct +{ + uint32_t ClearInputState; /*!< TIM clear Input state + This parameter can be ENABLE or DISABLE */ + uint32_t ClearInputSource; /*!< TIM clear Input sources + This parameter can be a value of @ref TIM_ClearInput_Source */ + uint32_t ClearInputPolarity; /*!< TIM Clear Input polarity + This parameter can be a value of @ref TIM_ClearInput_Polarity */ + uint32_t ClearInputPrescaler; /*!< TIM Clear Input prescaler + This parameter must be 0: When OCRef clear feature is used with ETR source, + ETR prescaler must be off */ + uint32_t ClearInputFilter; /*!< TIM Clear Input filter + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ +} TIM_ClearInputConfigTypeDef; + +/** + * @brief TIM Master configuration Structure definition + */ +typedef struct +{ + uint32_t MasterOutputTrigger; /*!< Trigger output (TRGO) selection + This parameter can be a value of @ref TIM_Master_Mode_Selection */ + uint32_t MasterSlaveMode; /*!< Master/slave mode selection + This parameter can be a value of @ref TIM_Master_Slave_Mode + @note When the Master/slave mode is enabled, the effect of + an event on the trigger input (TRGI) is delayed to allow a + perfect synchronization between the current timer and its + slaves (through TRGO). It is not mandatory in case of timer + synchronization mode. */ +} TIM_MasterConfigTypeDef; + +/** + * @brief TIM Slave configuration Structure definition + */ +typedef struct +{ + uint32_t SlaveMode; /*!< Slave mode selection + This parameter can be a value of @ref TIM_Slave_Mode */ + uint32_t InputTrigger; /*!< Input Trigger source + This parameter can be a value of @ref TIM_Trigger_Selection */ + uint32_t TriggerPolarity; /*!< Input Trigger polarity + This parameter can be a value of @ref TIM_Trigger_Polarity */ + uint32_t TriggerPrescaler; /*!< Input trigger prescaler + This parameter can be a value of @ref TIM_Trigger_Prescaler */ + uint32_t TriggerFilter; /*!< Input trigger filter + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ + +} TIM_SlaveConfigTypeDef; + +/** + * @brief TIM Break input(s) and Dead time configuration Structure definition + * @note 2 break inputs can be configured (BKIN and BKIN2) with configurable + * filter and polarity. + */ +typedef struct +{ + uint32_t OffStateRunMode; /*!< TIM off state in run mode, This parameter can be a value of @ref TIM_OSSR_Off_State_Selection_for_Run_mode_state */ + + uint32_t OffStateIDLEMode; /*!< TIM off state in IDLE mode, This parameter can be a value of @ref TIM_OSSI_Off_State_Selection_for_Idle_mode_state */ + + uint32_t LockLevel; /*!< TIM Lock level, This parameter can be a value of @ref TIM_Lock_level */ + + uint32_t DeadTime; /*!< TIM dead Time, This parameter can be a number between Min_Data = 0x00 and Max_Data = 0xFF */ + + uint32_t BreakState; /*!< TIM Break State, This parameter can be a value of @ref TIM_Break_Input_enable_disable */ + + uint32_t BreakPolarity; /*!< TIM Break input polarity, This parameter can be a value of @ref TIM_Break_Polarity */ + + uint32_t BreakFilter; /*!< Specifies the break input filter.This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ + + uint32_t AutomaticOutput; /*!< TIM Automatic Output Enable state, This parameter can be a value of @ref TIM_AOE_Bit_Set_Reset */ + +} TIM_BreakDeadTimeConfigTypeDef; + +/** + * @brief HAL State structures definition + */ +typedef enum +{ + HAL_TIM_STATE_RESET = 0x00U, /*!< Peripheral not yet initialized or disabled */ + HAL_TIM_STATE_READY = 0x01U, /*!< Peripheral Initialized and ready for use */ + HAL_TIM_STATE_BUSY = 0x02U, /*!< An internal process is ongoing */ + HAL_TIM_STATE_TIMEOUT = 0x03U, /*!< Timeout state */ + HAL_TIM_STATE_ERROR = 0x04U /*!< Reception process is ongoing */ +} HAL_TIM_StateTypeDef; + +/** + * @brief TIM Channel States definition + */ +typedef enum +{ + HAL_TIM_CHANNEL_STATE_RESET = 0x00U, /*!< TIM Channel initial state */ + HAL_TIM_CHANNEL_STATE_READY = 0x01U, /*!< TIM Channel ready for use */ + HAL_TIM_CHANNEL_STATE_BUSY = 0x02U, /*!< An internal process is ongoing on the TIM channel */ +} HAL_TIM_ChannelStateTypeDef; + +/** + * @brief DMA Burst States definition + */ +typedef enum +{ + HAL_DMA_BURST_STATE_RESET = 0x00U, /*!< DMA Burst initial state */ + HAL_DMA_BURST_STATE_READY = 0x01U, /*!< DMA Burst ready for use */ + HAL_DMA_BURST_STATE_BUSY = 0x02U, /*!< Ongoing DMA Burst */ +} HAL_TIM_DMABurstStateTypeDef; + +/** + * @brief HAL Active channel structures definition + */ +typedef enum +{ + HAL_TIM_ACTIVE_CHANNEL_1 = 0x01U, /*!< The active channel is 1 */ + HAL_TIM_ACTIVE_CHANNEL_2 = 0x02U, /*!< The active channel is 2 */ + HAL_TIM_ACTIVE_CHANNEL_3 = 0x04U, /*!< The active channel is 3 */ + HAL_TIM_ACTIVE_CHANNEL_4 = 0x08U, /*!< The active channel is 4 */ + HAL_TIM_ACTIVE_CHANNEL_CLEARED = 0x00U /*!< All active channels cleared */ +} HAL_TIM_ActiveChannel; + +/** + * @brief TIM Time Base Handle Structure definition + */ +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) +typedef struct __TIM_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +{ + TIM_TypeDef *Instance; /*!< Register base address */ + TIM_Base_InitTypeDef Init; /*!< TIM Time Base required parameters */ + HAL_TIM_ActiveChannel Channel; /*!< Active channel */ + DMA_HandleTypeDef *hdma[7]; /*!< DMA Handlers array + This array is accessed by a @ref DMA_Handle_index */ + HAL_LockTypeDef Lock; /*!< Locking object */ + __IO HAL_TIM_StateTypeDef State; /*!< TIM operation state */ + __IO HAL_TIM_ChannelStateTypeDef ChannelState[4]; /*!< TIM channel operation state */ + __IO HAL_TIM_ChannelStateTypeDef ChannelNState[4]; /*!< TIM complementary channel operation state */ + __IO HAL_TIM_DMABurstStateTypeDef DMABurstState; /*!< DMA burst operation state */ + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + void (* Base_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Base Msp Init Callback */ + void (* Base_MspDeInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Base Msp DeInit Callback */ + void (* IC_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM IC Msp Init Callback */ + void (* IC_MspDeInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM IC Msp DeInit Callback */ + void (* OC_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM OC Msp Init Callback */ + void (* OC_MspDeInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM OC Msp DeInit Callback */ + void (* PWM_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM PWM Msp Init Callback */ + void (* PWM_MspDeInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM PWM Msp DeInit Callback */ + void (* OnePulse_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM One Pulse Msp Init Callback */ + void (* OnePulse_MspDeInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM One Pulse Msp DeInit Callback */ + void (* Encoder_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Encoder Msp Init Callback */ + void (* Encoder_MspDeInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Encoder Msp DeInit Callback */ + void (* HallSensor_MspInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Hall Sensor Msp Init Callback */ + void (* HallSensor_MspDeInitCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Hall Sensor Msp DeInit Callback */ + void (* PeriodElapsedCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Period Elapsed Callback */ + void (* PeriodElapsedHalfCpltCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Period Elapsed half complete Callback */ + void (* TriggerCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Trigger Callback */ + void (* TriggerHalfCpltCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Trigger half complete Callback */ + void (* IC_CaptureCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Input Capture Callback */ + void (* IC_CaptureHalfCpltCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Input Capture half complete Callback */ + void (* OC_DelayElapsedCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Output Compare Delay Elapsed Callback */ + void (* PWM_PulseFinishedCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM PWM Pulse Finished Callback */ + void (* PWM_PulseFinishedHalfCpltCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM PWM Pulse Finished half complete Callback */ + void (* ErrorCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Error Callback */ + void (* CommutationCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Commutation Callback */ + void (* CommutationHalfCpltCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Commutation half complete Callback */ + void (* BreakCallback)(struct __TIM_HandleTypeDef *htim); /*!< TIM Break Callback */ +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +} TIM_HandleTypeDef; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) +/** + * @brief HAL TIM Callback ID enumeration definition + */ +typedef enum +{ + HAL_TIM_BASE_MSPINIT_CB_ID = 0x00U /*!< TIM Base MspInit Callback ID */ + , HAL_TIM_BASE_MSPDEINIT_CB_ID = 0x01U /*!< TIM Base MspDeInit Callback ID */ + , HAL_TIM_IC_MSPINIT_CB_ID = 0x02U /*!< TIM IC MspInit Callback ID */ + , HAL_TIM_IC_MSPDEINIT_CB_ID = 0x03U /*!< TIM IC MspDeInit Callback ID */ + , HAL_TIM_OC_MSPINIT_CB_ID = 0x04U /*!< TIM OC MspInit Callback ID */ + , HAL_TIM_OC_MSPDEINIT_CB_ID = 0x05U /*!< TIM OC MspDeInit Callback ID */ + , HAL_TIM_PWM_MSPINIT_CB_ID = 0x06U /*!< TIM PWM MspInit Callback ID */ + , HAL_TIM_PWM_MSPDEINIT_CB_ID = 0x07U /*!< TIM PWM MspDeInit Callback ID */ + , HAL_TIM_ONE_PULSE_MSPINIT_CB_ID = 0x08U /*!< TIM One Pulse MspInit Callback ID */ + , HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID = 0x09U /*!< TIM One Pulse MspDeInit Callback ID */ + , HAL_TIM_ENCODER_MSPINIT_CB_ID = 0x0AU /*!< TIM Encoder MspInit Callback ID */ + , HAL_TIM_ENCODER_MSPDEINIT_CB_ID = 0x0BU /*!< TIM Encoder MspDeInit Callback ID */ + , HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID = 0x0CU /*!< TIM Hall Sensor MspDeInit Callback ID */ + , HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID = 0x0DU /*!< TIM Hall Sensor MspDeInit Callback ID */ + , HAL_TIM_PERIOD_ELAPSED_CB_ID = 0x0EU /*!< TIM Period Elapsed Callback ID */ + , HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID = 0x0FU /*!< TIM Period Elapsed half complete Callback ID */ + , HAL_TIM_TRIGGER_CB_ID = 0x10U /*!< TIM Trigger Callback ID */ + , HAL_TIM_TRIGGER_HALF_CB_ID = 0x11U /*!< TIM Trigger half complete Callback ID */ + + , HAL_TIM_IC_CAPTURE_CB_ID = 0x12U /*!< TIM Input Capture Callback ID */ + , HAL_TIM_IC_CAPTURE_HALF_CB_ID = 0x13U /*!< TIM Input Capture half complete Callback ID */ + , HAL_TIM_OC_DELAY_ELAPSED_CB_ID = 0x14U /*!< TIM Output Compare Delay Elapsed Callback ID */ + , HAL_TIM_PWM_PULSE_FINISHED_CB_ID = 0x15U /*!< TIM PWM Pulse Finished Callback ID */ + , HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID = 0x16U /*!< TIM PWM Pulse Finished half complete Callback ID */ + , HAL_TIM_ERROR_CB_ID = 0x17U /*!< TIM Error Callback ID */ + , HAL_TIM_COMMUTATION_CB_ID = 0x18U /*!< TIM Commutation Callback ID */ + , HAL_TIM_COMMUTATION_HALF_CB_ID = 0x19U /*!< TIM Commutation half complete Callback ID */ + , HAL_TIM_BREAK_CB_ID = 0x1AU /*!< TIM Break Callback ID */ +} HAL_TIM_CallbackIDTypeDef; + +/** + * @brief HAL TIM Callback pointer definition + */ +typedef void (*pTIM_CallbackTypeDef)(TIM_HandleTypeDef *htim); /*!< pointer to the TIM callback function */ + +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + +/** + * @} + */ +/* End of exported types -----------------------------------------------------*/ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup TIM_Exported_Constants TIM Exported Constants + * @{ + */ + +/** @defgroup TIM_ClearInput_Source TIM Clear Input Source + * @{ + */ +#define TIM_CLEARINPUTSOURCE_NONE 0x00000000U /*!< OCREF_CLR is disabled */ +#define TIM_CLEARINPUTSOURCE_ETR 0x00000001U /*!< OCREF_CLR is connected to ETRF input */ +#define TIM_CLEARINPUTSOURCE_OCREFCLR 0x00000002U /*!< OCREF_CLR is connected to OCREF_CLR_INT */ +/** + * @} + */ + +/** @defgroup TIM_DMA_Base_address TIM DMA Base Address + * @{ + */ +#define TIM_DMABASE_CR1 0x00000000U +#define TIM_DMABASE_CR2 0x00000001U +#define TIM_DMABASE_SMCR 0x00000002U +#define TIM_DMABASE_DIER 0x00000003U +#define TIM_DMABASE_SR 0x00000004U +#define TIM_DMABASE_EGR 0x00000005U +#define TIM_DMABASE_CCMR1 0x00000006U +#define TIM_DMABASE_CCMR2 0x00000007U +#define TIM_DMABASE_CCER 0x00000008U +#define TIM_DMABASE_CNT 0x00000009U +#define TIM_DMABASE_PSC 0x0000000AU +#define TIM_DMABASE_ARR 0x0000000BU +#define TIM_DMABASE_RCR 0x0000000CU +#define TIM_DMABASE_CCR1 0x0000000DU +#define TIM_DMABASE_CCR2 0x0000000EU +#define TIM_DMABASE_CCR3 0x0000000FU +#define TIM_DMABASE_CCR4 0x00000010U +#define TIM_DMABASE_BDTR 0x00000011U +#define TIM_DMABASE_DCR 0x00000012U +#define TIM_DMABASE_DMAR 0x00000013U +/** + * @} + */ + +/** @defgroup TIM_Event_Source TIM Event Source + * @{ + */ +#define TIM_EVENTSOURCE_UPDATE TIM_EGR_UG /*!< Reinitialize the counter and generates an update of the registers */ +#define TIM_EVENTSOURCE_CC1 TIM_EGR_CC1G /*!< A capture/compare event is generated on channel 1 */ +#define TIM_EVENTSOURCE_CC2 TIM_EGR_CC2G /*!< A capture/compare event is generated on channel 2 */ +#define TIM_EVENTSOURCE_CC3 TIM_EGR_CC3G /*!< A capture/compare event is generated on channel 3 */ +#define TIM_EVENTSOURCE_CC4 TIM_EGR_CC4G /*!< A capture/compare event is generated on channel 4 */ +#define TIM_EVENTSOURCE_COM TIM_EGR_COMG /*!< A commutation event is generated */ +#define TIM_EVENTSOURCE_TRIGGER TIM_EGR_TG /*!< A trigger event is generated */ +#define TIM_EVENTSOURCE_BREAK TIM_EGR_BG /*!< A break event is generated */ +/** + * @} + */ + +/** @defgroup TIM_Input_Channel_Polarity TIM Input Channel polarity + * @{ + */ +#define TIM_INPUTCHANNELPOLARITY_RISING 0x00000000U /*!< Polarity for TIx source */ +#define TIM_INPUTCHANNELPOLARITY_FALLING TIM_CCER_CC1P /*!< Polarity for TIx source */ +#define TIM_INPUTCHANNELPOLARITY_BOTHEDGE (TIM_CCER_CC1P | TIM_CCER_CC1NP) /*!< Polarity for TIx source */ +/** + * @} + */ + +/** @defgroup TIM_ETR_Polarity TIM ETR Polarity + * @{ + */ +#define TIM_ETRPOLARITY_INVERTED TIM_SMCR_ETP /*!< Polarity for ETR source */ +#define TIM_ETRPOLARITY_NONINVERTED 0x00000000U /*!< Polarity for ETR source */ +/** + * @} + */ + +/** @defgroup TIM_ETR_Prescaler TIM ETR Prescaler + * @{ + */ +#define TIM_ETRPRESCALER_DIV1 0x00000000U /*!< No prescaler is used */ +#define TIM_ETRPRESCALER_DIV2 TIM_SMCR_ETPS_0 /*!< ETR input source is divided by 2 */ +#define TIM_ETRPRESCALER_DIV4 TIM_SMCR_ETPS_1 /*!< ETR input source is divided by 4 */ +#define TIM_ETRPRESCALER_DIV8 TIM_SMCR_ETPS /*!< ETR input source is divided by 8 */ +/** + * @} + */ + +/** @defgroup TIM_Counter_Mode TIM Counter Mode + * @{ + */ +#define TIM_COUNTERMODE_UP 0x00000000U /*!< Counter used as up-counter */ +#define TIM_COUNTERMODE_DOWN TIM_CR1_DIR /*!< Counter used as down-counter */ +#define TIM_COUNTERMODE_CENTERALIGNED1 TIM_CR1_CMS_0 /*!< Center-aligned mode 1 */ +#define TIM_COUNTERMODE_CENTERALIGNED2 TIM_CR1_CMS_1 /*!< Center-aligned mode 2 */ +#define TIM_COUNTERMODE_CENTERALIGNED3 TIM_CR1_CMS /*!< Center-aligned mode 3 */ +/** + * @} + */ + +/** @defgroup TIM_ClockDivision TIM Clock Division + * @{ + */ +#define TIM_CLOCKDIVISION_DIV1 0x00000000U /*!< Clock division: tDTS=tCK_INT */ +#define TIM_CLOCKDIVISION_DIV2 TIM_CR1_CKD_0 /*!< Clock division: tDTS=2*tCK_INT */ +#define TIM_CLOCKDIVISION_DIV4 TIM_CR1_CKD_1 /*!< Clock division: tDTS=4*tCK_INT */ +/** + * @} + */ + +/** @defgroup TIM_Output_Compare_State TIM Output Compare State + * @{ + */ +#define TIM_OUTPUTSTATE_DISABLE 0x00000000U /*!< Capture/Compare 1 output disabled */ +#define TIM_OUTPUTSTATE_ENABLE TIM_CCER_CC1E /*!< Capture/Compare 1 output enabled */ +/** + * @} + */ + +/** @defgroup TIM_AutoReloadPreload TIM Auto-Reload Preload + * @{ + */ +#define TIM_AUTORELOAD_PRELOAD_DISABLE 0x00000000U /*!< TIMx_ARR register is not buffered */ +#define TIM_AUTORELOAD_PRELOAD_ENABLE TIM_CR1_ARPE /*!< TIMx_ARR register is buffered */ + +/** + * @} + */ + +/** @defgroup TIM_Output_Fast_State TIM Output Fast State + * @{ + */ +#define TIM_OCFAST_DISABLE 0x00000000U /*!< Output Compare fast disable */ +#define TIM_OCFAST_ENABLE TIM_CCMR1_OC1FE /*!< Output Compare fast enable */ +/** + * @} + */ + +/** @defgroup TIM_Output_Compare_N_State TIM Complementary Output Compare State + * @{ + */ +#define TIM_OUTPUTNSTATE_DISABLE 0x00000000U /*!< OCxN is disabled */ +#define TIM_OUTPUTNSTATE_ENABLE TIM_CCER_CC1NE /*!< OCxN is enabled */ +/** + * @} + */ + +/** @defgroup TIM_Output_Compare_Polarity TIM Output Compare Polarity + * @{ + */ +#define TIM_OCPOLARITY_HIGH 0x00000000U /*!< Capture/Compare output polarity */ +#define TIM_OCPOLARITY_LOW TIM_CCER_CC1P /*!< Capture/Compare output polarity */ +/** + * @} + */ + +/** @defgroup TIM_Output_Compare_N_Polarity TIM Complementary Output Compare Polarity + * @{ + */ +#define TIM_OCNPOLARITY_HIGH 0x00000000U /*!< Capture/Compare complementary output polarity */ +#define TIM_OCNPOLARITY_LOW TIM_CCER_CC1NP /*!< Capture/Compare complementary output polarity */ +/** + * @} + */ + +/** @defgroup TIM_Output_Compare_Idle_State TIM Output Compare Idle State + * @{ + */ +#define TIM_OCIDLESTATE_SET TIM_CR2_OIS1 /*!< Output Idle state: OCx=1 when MOE=0 */ +#define TIM_OCIDLESTATE_RESET 0x00000000U /*!< Output Idle state: OCx=0 when MOE=0 */ +/** + * @} + */ + +/** @defgroup TIM_Output_Compare_N_Idle_State TIM Complementary Output Compare Idle State + * @{ + */ +#define TIM_OCNIDLESTATE_SET TIM_CR2_OIS1N /*!< Complementary output Idle state: OCxN=1 when MOE=0 */ +#define TIM_OCNIDLESTATE_RESET 0x00000000U /*!< Complementary output Idle state: OCxN=0 when MOE=0 */ +/** + * @} + */ + +/** @defgroup TIM_Input_Capture_Polarity TIM Input Capture Polarity + * @{ + */ +#define TIM_ICPOLARITY_RISING TIM_INPUTCHANNELPOLARITY_RISING /*!< Capture triggered by rising edge on timer input */ +#define TIM_ICPOLARITY_FALLING TIM_INPUTCHANNELPOLARITY_FALLING /*!< Capture triggered by falling edge on timer input */ +#define TIM_ICPOLARITY_BOTHEDGE TIM_INPUTCHANNELPOLARITY_BOTHEDGE /*!< Capture triggered by both rising and falling edges on timer input*/ +/** + * @} + */ + +/** @defgroup TIM_Encoder_Input_Polarity TIM Encoder Input Polarity + * @{ + */ +#define TIM_ENCODERINPUTPOLARITY_RISING TIM_INPUTCHANNELPOLARITY_RISING /*!< Encoder input with rising edge polarity */ +#define TIM_ENCODERINPUTPOLARITY_FALLING TIM_INPUTCHANNELPOLARITY_FALLING /*!< Encoder input with falling edge polarity */ +/** + * @} + */ + +/** @defgroup TIM_Input_Capture_Selection TIM Input Capture Selection + * @{ + */ +#define TIM_ICSELECTION_DIRECTTI TIM_CCMR1_CC1S_0 /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to IC1, IC2, IC3 or IC4, respectively */ +#define TIM_ICSELECTION_INDIRECTTI TIM_CCMR1_CC1S_1 /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to IC2, IC1, IC4 or IC3, respectively */ +#define TIM_ICSELECTION_TRC TIM_CCMR1_CC1S /*!< TIM Input 1, 2, 3 or 4 is selected to be connected to TRC */ +/** + * @} + */ + +/** @defgroup TIM_Input_Capture_Prescaler TIM Input Capture Prescaler + * @{ + */ +#define TIM_ICPSC_DIV1 0x00000000U /*!< Capture performed each time an edge is detected on the capture input */ +#define TIM_ICPSC_DIV2 TIM_CCMR1_IC1PSC_0 /*!< Capture performed once every 2 events */ +#define TIM_ICPSC_DIV4 TIM_CCMR1_IC1PSC_1 /*!< Capture performed once every 4 events */ +#define TIM_ICPSC_DIV8 TIM_CCMR1_IC1PSC /*!< Capture performed once every 8 events */ +/** + * @} + */ + +/** @defgroup TIM_One_Pulse_Mode TIM One Pulse Mode + * @{ + */ +#define TIM_OPMODE_SINGLE TIM_CR1_OPM /*!< Counter stops counting at the next update event */ +#define TIM_OPMODE_REPETITIVE 0x00000000U /*!< Counter is not stopped at update event */ +/** + * @} + */ + +/** @defgroup TIM_Encoder_Mode TIM Encoder Mode + * @{ + */ +#define TIM_ENCODERMODE_TI1 TIM_SMCR_SMS_0 /*!< Quadrature encoder mode 1, x2 mode, counts up/down on TI1FP1 edge depending on TI2FP2 level */ +#define TIM_ENCODERMODE_TI2 TIM_SMCR_SMS_1 /*!< Quadrature encoder mode 2, x2 mode, counts up/down on TI2FP2 edge depending on TI1FP1 level. */ +#define TIM_ENCODERMODE_TI12 (TIM_SMCR_SMS_1 | TIM_SMCR_SMS_0) /*!< Quadrature encoder mode 3, x4 mode, counts up/down on both TI1FP1 and TI2FP2 edges depending on the level of the other input. */ +/** + * @} + */ + +/** @defgroup TIM_Interrupt_definition TIM interrupt Definition + * @{ + */ +#define TIM_IT_UPDATE TIM_DIER_UIE /*!< Update interrupt */ +#define TIM_IT_CC1 TIM_DIER_CC1IE /*!< Capture/Compare 1 interrupt */ +#define TIM_IT_CC2 TIM_DIER_CC2IE /*!< Capture/Compare 2 interrupt */ +#define TIM_IT_CC3 TIM_DIER_CC3IE /*!< Capture/Compare 3 interrupt */ +#define TIM_IT_CC4 TIM_DIER_CC4IE /*!< Capture/Compare 4 interrupt */ +#define TIM_IT_COM TIM_DIER_COMIE /*!< Commutation interrupt */ +#define TIM_IT_TRIGGER TIM_DIER_TIE /*!< Trigger interrupt */ +#define TIM_IT_BREAK TIM_DIER_BIE /*!< Break interrupt */ +/** + * @} + */ + +/** @defgroup TIM_Commutation_Source TIM Commutation Source + * @{ + */ +#define TIM_COMMUTATION_TRGI TIM_CR2_CCUS /*!< When Capture/compare control bits are preloaded, they are updated by setting the COMG bit or when an rising edge occurs on trigger input */ +#define TIM_COMMUTATION_SOFTWARE 0x00000000U /*!< When Capture/compare control bits are preloaded, they are updated by setting the COMG bit */ +/** + * @} + */ + +/** @defgroup TIM_DMA_sources TIM DMA Sources + * @{ + */ +#define TIM_DMA_UPDATE TIM_DIER_UDE /*!< DMA request is triggered by the update event */ +#define TIM_DMA_CC1 TIM_DIER_CC1DE /*!< DMA request is triggered by the capture/compare macth 1 event */ +#define TIM_DMA_CC2 TIM_DIER_CC2DE /*!< DMA request is triggered by the capture/compare macth 2 event event */ +#define TIM_DMA_CC3 TIM_DIER_CC3DE /*!< DMA request is triggered by the capture/compare macth 3 event event */ +#define TIM_DMA_CC4 TIM_DIER_CC4DE /*!< DMA request is triggered by the capture/compare macth 4 event event */ +#define TIM_DMA_COM TIM_DIER_COMDE /*!< DMA request is triggered by the commutation event */ +#define TIM_DMA_TRIGGER TIM_DIER_TDE /*!< DMA request is triggered by the trigger event */ +/** + * @} + */ + +/** @defgroup TIM_Flag_definition TIM Flag Definition + * @{ + */ +#define TIM_FLAG_UPDATE TIM_SR_UIF /*!< Update interrupt flag */ +#define TIM_FLAG_CC1 TIM_SR_CC1IF /*!< Capture/Compare 1 interrupt flag */ +#define TIM_FLAG_CC2 TIM_SR_CC2IF /*!< Capture/Compare 2 interrupt flag */ +#define TIM_FLAG_CC3 TIM_SR_CC3IF /*!< Capture/Compare 3 interrupt flag */ +#define TIM_FLAG_CC4 TIM_SR_CC4IF /*!< Capture/Compare 4 interrupt flag */ +#define TIM_FLAG_COM TIM_SR_COMIF /*!< Commutation interrupt flag */ +#define TIM_FLAG_TRIGGER TIM_SR_TIF /*!< Trigger interrupt flag */ +#define TIM_FLAG_BREAK TIM_SR_BIF /*!< Break interrupt flag */ +#define TIM_FLAG_CC1OF TIM_SR_CC1OF /*!< Capture 1 overcapture flag */ +#define TIM_FLAG_CC2OF TIM_SR_CC2OF /*!< Capture 2 overcapture flag */ +#define TIM_FLAG_CC3OF TIM_SR_CC3OF /*!< Capture 3 overcapture flag */ +#define TIM_FLAG_CC4OF TIM_SR_CC4OF /*!< Capture 4 overcapture flag */ +/** + * @} + */ + +/** @defgroup TIM_Channel TIM Channel + * @{ + */ +#define TIM_CHANNEL_1 0x00000000U /*!< Capture/compare channel 1 identifier */ +#define TIM_CHANNEL_2 0x00000004U /*!< Capture/compare channel 2 identifier */ +#define TIM_CHANNEL_3 0x00000008U /*!< Capture/compare channel 3 identifier */ +#define TIM_CHANNEL_4 0x0000000CU /*!< Capture/compare channel 4 identifier */ +#define TIM_CHANNEL_ALL 0x0000003CU /*!< Global Capture/compare channel identifier */ +/** + * @} + */ + +/** @defgroup TIM_Clock_Source TIM Clock Source + * @{ + */ +#define TIM_CLOCKSOURCE_ETRMODE2 TIM_SMCR_ETPS_1 /*!< External clock source mode 2 */ +#define TIM_CLOCKSOURCE_INTERNAL TIM_SMCR_ETPS_0 /*!< Internal clock source */ +#define TIM_CLOCKSOURCE_ITR0 TIM_TS_ITR0 /*!< External clock source mode 1 (ITR0) */ +#define TIM_CLOCKSOURCE_ITR1 TIM_TS_ITR1 /*!< External clock source mode 1 (ITR1) */ +#define TIM_CLOCKSOURCE_ITR2 TIM_TS_ITR2 /*!< External clock source mode 1 (ITR2) */ +#define TIM_CLOCKSOURCE_ITR3 TIM_TS_ITR3 /*!< External clock source mode 1 (ITR3) */ +#define TIM_CLOCKSOURCE_TI1ED TIM_TS_TI1F_ED /*!< External clock source mode 1 (TTI1FP1 + edge detect.) */ +#define TIM_CLOCKSOURCE_TI1 TIM_TS_TI1FP1 /*!< External clock source mode 1 (TTI1FP1) */ +#define TIM_CLOCKSOURCE_TI2 TIM_TS_TI2FP2 /*!< External clock source mode 1 (TTI2FP2) */ +#define TIM_CLOCKSOURCE_ETRMODE1 TIM_TS_ETRF /*!< External clock source mode 1 (ETRF) */ +/** + * @} + */ + +/** @defgroup TIM_Clock_Polarity TIM Clock Polarity + * @{ + */ +#define TIM_CLOCKPOLARITY_INVERTED TIM_ETRPOLARITY_INVERTED /*!< Polarity for ETRx clock sources */ +#define TIM_CLOCKPOLARITY_NONINVERTED TIM_ETRPOLARITY_NONINVERTED /*!< Polarity for ETRx clock sources */ +#define TIM_CLOCKPOLARITY_RISING TIM_INPUTCHANNELPOLARITY_RISING /*!< Polarity for TIx clock sources */ +#define TIM_CLOCKPOLARITY_FALLING TIM_INPUTCHANNELPOLARITY_FALLING /*!< Polarity for TIx clock sources */ +#define TIM_CLOCKPOLARITY_BOTHEDGE TIM_INPUTCHANNELPOLARITY_BOTHEDGE /*!< Polarity for TIx clock sources */ +/** + * @} + */ + +/** @defgroup TIM_Clock_Prescaler TIM Clock Prescaler + * @{ + */ +#define TIM_CLOCKPRESCALER_DIV1 TIM_ETRPRESCALER_DIV1 /*!< No prescaler is used */ +#define TIM_CLOCKPRESCALER_DIV2 TIM_ETRPRESCALER_DIV2 /*!< Prescaler for External ETR Clock: Capture performed once every 2 events. */ +#define TIM_CLOCKPRESCALER_DIV4 TIM_ETRPRESCALER_DIV4 /*!< Prescaler for External ETR Clock: Capture performed once every 4 events. */ +#define TIM_CLOCKPRESCALER_DIV8 TIM_ETRPRESCALER_DIV8 /*!< Prescaler for External ETR Clock: Capture performed once every 8 events. */ +/** + * @} + */ + +/** @defgroup TIM_ClearInput_Polarity TIM Clear Input Polarity + * @{ + */ +#define TIM_CLEARINPUTPOLARITY_INVERTED TIM_ETRPOLARITY_INVERTED /*!< Polarity for ETRx pin */ +#define TIM_CLEARINPUTPOLARITY_NONINVERTED TIM_ETRPOLARITY_NONINVERTED /*!< Polarity for ETRx pin */ +/** + * @} + */ + +/** @defgroup TIM_ClearInput_Prescaler TIM Clear Input Prescaler + * @{ + */ +#define TIM_CLEARINPUTPRESCALER_DIV1 TIM_ETRPRESCALER_DIV1 /*!< No prescaler is used */ +#define TIM_CLEARINPUTPRESCALER_DIV2 TIM_ETRPRESCALER_DIV2 /*!< Prescaler for External ETR pin: Capture performed once every 2 events. */ +#define TIM_CLEARINPUTPRESCALER_DIV4 TIM_ETRPRESCALER_DIV4 /*!< Prescaler for External ETR pin: Capture performed once every 4 events. */ +#define TIM_CLEARINPUTPRESCALER_DIV8 TIM_ETRPRESCALER_DIV8 /*!< Prescaler for External ETR pin: Capture performed once every 8 events. */ +/** + * @} + */ + +/** @defgroup TIM_OSSR_Off_State_Selection_for_Run_mode_state TIM OSSR OffState Selection for Run mode state + * @{ + */ +#define TIM_OSSR_ENABLE TIM_BDTR_OSSR /*!< When inactive, OC/OCN outputs are enabled (still controlled by the timer) */ +#define TIM_OSSR_DISABLE 0x00000000U /*!< When inactive, OC/OCN outputs are disabled (not controlled any longer by the timer) */ +/** + * @} + */ + +/** @defgroup TIM_OSSI_Off_State_Selection_for_Idle_mode_state TIM OSSI OffState Selection for Idle mode state + * @{ + */ +#define TIM_OSSI_ENABLE TIM_BDTR_OSSI /*!< When inactive, OC/OCN outputs are enabled (still controlled by the timer) */ +#define TIM_OSSI_DISABLE 0x00000000U /*!< When inactive, OC/OCN outputs are disabled (not controlled any longer by the timer) */ +/** + * @} + */ +/** @defgroup TIM_Lock_level TIM Lock level + * @{ + */ +#define TIM_LOCKLEVEL_OFF 0x00000000U /*!< LOCK OFF */ +#define TIM_LOCKLEVEL_1 TIM_BDTR_LOCK_0 /*!< LOCK Level 1 */ +#define TIM_LOCKLEVEL_2 TIM_BDTR_LOCK_1 /*!< LOCK Level 2 */ +#define TIM_LOCKLEVEL_3 TIM_BDTR_LOCK /*!< LOCK Level 3 */ +/** + * @} + */ + +/** @defgroup TIM_Break_Input_enable_disable TIM Break Input Enable + * @{ + */ +#define TIM_BREAK_ENABLE TIM_BDTR_BKE /*!< Break input BRK is enabled */ +#define TIM_BREAK_DISABLE 0x00000000U /*!< Break input BRK is disabled */ +/** + * @} + */ + +/** @defgroup TIM_Break_Polarity TIM Break Input Polarity + * @{ + */ +#define TIM_BREAKPOLARITY_LOW 0x00000000U /*!< Break input BRK is active low */ +#define TIM_BREAKPOLARITY_HIGH TIM_BDTR_BKP /*!< Break input BRK is active high */ +/** + * @} + */ + +/** @defgroup TIM_AOE_Bit_Set_Reset TIM Automatic Output Enable + * @{ + */ +#define TIM_AUTOMATICOUTPUT_DISABLE 0x00000000U /*!< MOE can be set only by software */ +#define TIM_AUTOMATICOUTPUT_ENABLE TIM_BDTR_AOE /*!< MOE can be set by software or automatically at the next update event (if none of the break inputs BRK and BRK2 is active) */ +/** + * @} + */ + +/** @defgroup TIM_Master_Mode_Selection TIM Master Mode Selection + * @{ + */ +#define TIM_TRGO_RESET 0x00000000U /*!< TIMx_EGR.UG bit is used as trigger output (TRGO) */ +#define TIM_TRGO_ENABLE TIM_CR2_MMS_0 /*!< TIMx_CR1.CEN bit is used as trigger output (TRGO) */ +#define TIM_TRGO_UPDATE TIM_CR2_MMS_1 /*!< Update event is used as trigger output (TRGO) */ +#define TIM_TRGO_OC1 (TIM_CR2_MMS_1 | TIM_CR2_MMS_0) /*!< Capture or a compare match 1 is used as trigger output (TRGO) */ +#define TIM_TRGO_OC1REF TIM_CR2_MMS_2 /*!< OC1REF signal is used as trigger output (TRGO) */ +#define TIM_TRGO_OC2REF (TIM_CR2_MMS_2 | TIM_CR2_MMS_0) /*!< OC2REF signal is used as trigger output(TRGO) */ +#define TIM_TRGO_OC3REF (TIM_CR2_MMS_2 | TIM_CR2_MMS_1) /*!< OC3REF signal is used as trigger output(TRGO) */ +#define TIM_TRGO_OC4REF (TIM_CR2_MMS_2 | TIM_CR2_MMS_1 | TIM_CR2_MMS_0) /*!< OC4REF signal is used as trigger output(TRGO) */ +/** + * @} + */ + +/** @defgroup TIM_Master_Slave_Mode TIM Master/Slave Mode + * @{ + */ +#define TIM_MASTERSLAVEMODE_ENABLE TIM_SMCR_MSM /*!< No action */ +#define TIM_MASTERSLAVEMODE_DISABLE 0x00000000U /*!< Master/slave mode is selected */ +/** + * @} + */ + +/** @defgroup TIM_Slave_Mode TIM Slave mode + * @{ + */ +#define TIM_SLAVEMODE_DISABLE 0x00000000U /*!< Slave mode disabled */ +#define TIM_SLAVEMODE_RESET TIM_SMCR_SMS_2 /*!< Reset Mode */ +#define TIM_SLAVEMODE_GATED (TIM_SMCR_SMS_2 | TIM_SMCR_SMS_0) /*!< Gated Mode */ +#define TIM_SLAVEMODE_TRIGGER (TIM_SMCR_SMS_2 | TIM_SMCR_SMS_1) /*!< Trigger Mode */ +#define TIM_SLAVEMODE_EXTERNAL1 (TIM_SMCR_SMS_2 | TIM_SMCR_SMS_1 | TIM_SMCR_SMS_0) /*!< External Clock Mode 1 */ +/** + * @} + */ + +/** @defgroup TIM_Output_Compare_and_PWM_modes TIM Output Compare and PWM Modes + * @{ + */ +#define TIM_OCMODE_TIMING 0x00000000U /*!< Frozen */ +#define TIM_OCMODE_ACTIVE TIM_CCMR1_OC1M_0 /*!< Set channel to active level on match */ +#define TIM_OCMODE_INACTIVE TIM_CCMR1_OC1M_1 /*!< Set channel to inactive level on match */ +#define TIM_OCMODE_TOGGLE (TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_0) /*!< Toggle */ +#define TIM_OCMODE_PWM1 (TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC1M_1) /*!< PWM mode 1 */ +#define TIM_OCMODE_PWM2 (TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_0) /*!< PWM mode 2 */ +#define TIM_OCMODE_FORCED_ACTIVE (TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC1M_0) /*!< Force active level */ +#define TIM_OCMODE_FORCED_INACTIVE TIM_CCMR1_OC1M_2 /*!< Force inactive level */ +/** + * @} + */ + +/** @defgroup TIM_Trigger_Selection TIM Trigger Selection + * @{ + */ +#define TIM_TS_ITR0 0x00000000U /*!< Internal Trigger 0 (ITR0) */ +#define TIM_TS_ITR1 TIM_SMCR_TS_0 /*!< Internal Trigger 1 (ITR1) */ +#define TIM_TS_ITR2 TIM_SMCR_TS_1 /*!< Internal Trigger 2 (ITR2) */ +#define TIM_TS_ITR3 (TIM_SMCR_TS_0 | TIM_SMCR_TS_1) /*!< Internal Trigger 3 (ITR3) */ +#define TIM_TS_TI1F_ED TIM_SMCR_TS_2 /*!< TI1 Edge Detector (TI1F_ED) */ +#define TIM_TS_TI1FP1 (TIM_SMCR_TS_0 | TIM_SMCR_TS_2) /*!< Filtered Timer Input 1 (TI1FP1) */ +#define TIM_TS_TI2FP2 (TIM_SMCR_TS_1 | TIM_SMCR_TS_2) /*!< Filtered Timer Input 2 (TI2FP2) */ +#define TIM_TS_ETRF (TIM_SMCR_TS_0 | TIM_SMCR_TS_1 | TIM_SMCR_TS_2) /*!< Filtered External Trigger input (ETRF) */ +#define TIM_TS_NONE 0x0000FFFFU /*!< No trigger selected */ +/** + * @} + */ + +/** @defgroup TIM_Trigger_Polarity TIM Trigger Polarity + * @{ + */ +#define TIM_TRIGGERPOLARITY_INVERTED TIM_ETRPOLARITY_INVERTED /*!< Polarity for ETRx trigger sources */ +#define TIM_TRIGGERPOLARITY_NONINVERTED TIM_ETRPOLARITY_NONINVERTED /*!< Polarity for ETRx trigger sources */ +#define TIM_TRIGGERPOLARITY_RISING TIM_INPUTCHANNELPOLARITY_RISING /*!< Polarity for TIxFPx or TI1_ED trigger sources */ +#define TIM_TRIGGERPOLARITY_FALLING TIM_INPUTCHANNELPOLARITY_FALLING /*!< Polarity for TIxFPx or TI1_ED trigger sources */ +#define TIM_TRIGGERPOLARITY_BOTHEDGE TIM_INPUTCHANNELPOLARITY_BOTHEDGE /*!< Polarity for TIxFPx or TI1_ED trigger sources */ +/** + * @} + */ + +/** @defgroup TIM_Trigger_Prescaler TIM Trigger Prescaler + * @{ + */ +#define TIM_TRIGGERPRESCALER_DIV1 TIM_ETRPRESCALER_DIV1 /*!< No prescaler is used */ +#define TIM_TRIGGERPRESCALER_DIV2 TIM_ETRPRESCALER_DIV2 /*!< Prescaler for External ETR Trigger: Capture performed once every 2 events. */ +#define TIM_TRIGGERPRESCALER_DIV4 TIM_ETRPRESCALER_DIV4 /*!< Prescaler for External ETR Trigger: Capture performed once every 4 events. */ +#define TIM_TRIGGERPRESCALER_DIV8 TIM_ETRPRESCALER_DIV8 /*!< Prescaler for External ETR Trigger: Capture performed once every 8 events. */ +/** + * @} + */ + +/** @defgroup TIM_TI1_Selection TIM TI1 Input Selection + * @{ + */ +#define TIM_TI1SELECTION_CH1 0x00000000U /*!< The TIMx_CH1 pin is connected to TI1 input */ +#define TIM_TI1SELECTION_XORCOMBINATION TIM_CR2_TI1S /*!< The TIMx_CH1, CH2 and CH3 pins are connected to the TI1 input (XOR combination) */ +/** + * @} + */ + +/** @defgroup TIM_DMA_Burst_Length TIM DMA Burst Length + * @{ + */ +#define TIM_DMABURSTLENGTH_1TRANSFER 0x00000000U /*!< The transfer is done to 1 register starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_2TRANSFERS 0x00000100U /*!< The transfer is done to 2 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_3TRANSFERS 0x00000200U /*!< The transfer is done to 3 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_4TRANSFERS 0x00000300U /*!< The transfer is done to 4 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_5TRANSFERS 0x00000400U /*!< The transfer is done to 5 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_6TRANSFERS 0x00000500U /*!< The transfer is done to 6 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_7TRANSFERS 0x00000600U /*!< The transfer is done to 7 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_8TRANSFERS 0x00000700U /*!< The transfer is done to 8 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_9TRANSFERS 0x00000800U /*!< The transfer is done to 9 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_10TRANSFERS 0x00000900U /*!< The transfer is done to 10 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_11TRANSFERS 0x00000A00U /*!< The transfer is done to 11 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_12TRANSFERS 0x00000B00U /*!< The transfer is done to 12 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_13TRANSFERS 0x00000C00U /*!< The transfer is done to 13 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_14TRANSFERS 0x00000D00U /*!< The transfer is done to 14 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_15TRANSFERS 0x00000E00U /*!< The transfer is done to 15 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_16TRANSFERS 0x00000F00U /*!< The transfer is done to 16 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_17TRANSFERS 0x00001000U /*!< The transfer is done to 17 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +#define TIM_DMABURSTLENGTH_18TRANSFERS 0x00001100U /*!< The transfer is done to 18 registers starting from TIMx_CR1 + TIMx_DCR.DBA */ +/** + * @} + */ + +/** @defgroup DMA_Handle_index TIM DMA Handle Index + * @{ + */ +#define TIM_DMA_ID_UPDATE ((uint16_t) 0x0000) /*!< Index of the DMA handle used for Update DMA requests */ +#define TIM_DMA_ID_CC1 ((uint16_t) 0x0001) /*!< Index of the DMA handle used for Capture/Compare 1 DMA requests */ +#define TIM_DMA_ID_CC2 ((uint16_t) 0x0002) /*!< Index of the DMA handle used for Capture/Compare 2 DMA requests */ +#define TIM_DMA_ID_CC3 ((uint16_t) 0x0003) /*!< Index of the DMA handle used for Capture/Compare 3 DMA requests */ +#define TIM_DMA_ID_CC4 ((uint16_t) 0x0004) /*!< Index of the DMA handle used for Capture/Compare 4 DMA requests */ +#define TIM_DMA_ID_COMMUTATION ((uint16_t) 0x0005) /*!< Index of the DMA handle used for Commutation DMA requests */ +#define TIM_DMA_ID_TRIGGER ((uint16_t) 0x0006) /*!< Index of the DMA handle used for Trigger DMA requests */ +/** + * @} + */ + +/** @defgroup Channel_CC_State TIM Capture/Compare Channel State + * @{ + */ +#define TIM_CCx_ENABLE 0x00000001U /*!< Input or output channel is enabled */ +#define TIM_CCx_DISABLE 0x00000000U /*!< Input or output channel is disabled */ +#define TIM_CCxN_ENABLE 0x00000004U /*!< Complementary output channel is enabled */ +#define TIM_CCxN_DISABLE 0x00000000U /*!< Complementary output channel is enabled */ +/** + * @} + */ + +/** + * @} + */ +/* End of exported constants -------------------------------------------------*/ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup TIM_Exported_Macros TIM Exported Macros + * @{ + */ + +/** @brief Reset TIM handle state. + * @param __HANDLE__ TIM handle. + * @retval None + */ +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) +#define __HAL_TIM_RESET_HANDLE_STATE(__HANDLE__) do { \ + (__HANDLE__)->State = HAL_TIM_STATE_RESET; \ + (__HANDLE__)->ChannelState[0] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelState[1] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelState[2] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelState[3] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[0] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[1] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[2] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[3] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->DMABurstState = HAL_DMA_BURST_STATE_RESET; \ + (__HANDLE__)->Base_MspInitCallback = NULL; \ + (__HANDLE__)->Base_MspDeInitCallback = NULL; \ + (__HANDLE__)->IC_MspInitCallback = NULL; \ + (__HANDLE__)->IC_MspDeInitCallback = NULL; \ + (__HANDLE__)->OC_MspInitCallback = NULL; \ + (__HANDLE__)->OC_MspDeInitCallback = NULL; \ + (__HANDLE__)->PWM_MspInitCallback = NULL; \ + (__HANDLE__)->PWM_MspDeInitCallback = NULL; \ + (__HANDLE__)->OnePulse_MspInitCallback = NULL; \ + (__HANDLE__)->OnePulse_MspDeInitCallback = NULL; \ + (__HANDLE__)->Encoder_MspInitCallback = NULL; \ + (__HANDLE__)->Encoder_MspDeInitCallback = NULL; \ + (__HANDLE__)->HallSensor_MspInitCallback = NULL; \ + (__HANDLE__)->HallSensor_MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_TIM_RESET_HANDLE_STATE(__HANDLE__) do { \ + (__HANDLE__)->State = HAL_TIM_STATE_RESET; \ + (__HANDLE__)->ChannelState[0] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelState[1] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelState[2] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelState[3] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[0] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[1] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[2] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->ChannelNState[3] = HAL_TIM_CHANNEL_STATE_RESET; \ + (__HANDLE__)->DMABurstState = HAL_DMA_BURST_STATE_RESET; \ + } while(0) +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + +/** + * @brief Enable the TIM peripheral. + * @param __HANDLE__ TIM handle + * @retval None + */ +#define __HAL_TIM_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1|=(TIM_CR1_CEN)) + +/** + * @brief Enable the TIM main Output. + * @param __HANDLE__ TIM handle + * @retval None + */ +#define __HAL_TIM_MOE_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->BDTR|=(TIM_BDTR_MOE)) + +/** + * @brief Disable the TIM peripheral. + * @param __HANDLE__ TIM handle + * @retval None + */ +#define __HAL_TIM_DISABLE(__HANDLE__) \ + do { \ + if (((__HANDLE__)->Instance->CCER & TIM_CCER_CCxE_MASK) == 0UL) \ + { \ + if(((__HANDLE__)->Instance->CCER & TIM_CCER_CCxNE_MASK) == 0UL) \ + { \ + (__HANDLE__)->Instance->CR1 &= ~(TIM_CR1_CEN); \ + } \ + } \ + } while(0) + +/** + * @brief Disable the TIM main Output. + * @param __HANDLE__ TIM handle + * @retval None + * @note The Main Output Enable of a timer instance is disabled only if all the CCx and CCxN channels have been + * disabled + */ +#define __HAL_TIM_MOE_DISABLE(__HANDLE__) \ + do { \ + if (((__HANDLE__)->Instance->CCER & TIM_CCER_CCxE_MASK) == 0UL) \ + { \ + if(((__HANDLE__)->Instance->CCER & TIM_CCER_CCxNE_MASK) == 0UL) \ + { \ + (__HANDLE__)->Instance->BDTR &= ~(TIM_BDTR_MOE); \ + } \ + } \ + } while(0) + +/** + * @brief Disable the TIM main Output. + * @param __HANDLE__ TIM handle + * @retval None + * @note The Main Output Enable of a timer instance is disabled unconditionally + */ +#define __HAL_TIM_MOE_DISABLE_UNCONDITIONALLY(__HANDLE__) (__HANDLE__)->Instance->BDTR &= ~(TIM_BDTR_MOE) + +/** @brief Enable the specified TIM interrupt. + * @param __HANDLE__ specifies the TIM Handle. + * @param __INTERRUPT__ specifies the TIM interrupt source to enable. + * This parameter can be one of the following values: + * @arg TIM_IT_UPDATE: Update interrupt + * @arg TIM_IT_CC1: Capture/Compare 1 interrupt + * @arg TIM_IT_CC2: Capture/Compare 2 interrupt + * @arg TIM_IT_CC3: Capture/Compare 3 interrupt + * @arg TIM_IT_CC4: Capture/Compare 4 interrupt + * @arg TIM_IT_COM: Commutation interrupt + * @arg TIM_IT_TRIGGER: Trigger interrupt + * @arg TIM_IT_BREAK: Break interrupt + * @retval None + */ +#define __HAL_TIM_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->DIER |= (__INTERRUPT__)) + +/** @brief Disable the specified TIM interrupt. + * @param __HANDLE__ specifies the TIM Handle. + * @param __INTERRUPT__ specifies the TIM interrupt source to disable. + * This parameter can be one of the following values: + * @arg TIM_IT_UPDATE: Update interrupt + * @arg TIM_IT_CC1: Capture/Compare 1 interrupt + * @arg TIM_IT_CC2: Capture/Compare 2 interrupt + * @arg TIM_IT_CC3: Capture/Compare 3 interrupt + * @arg TIM_IT_CC4: Capture/Compare 4 interrupt + * @arg TIM_IT_COM: Commutation interrupt + * @arg TIM_IT_TRIGGER: Trigger interrupt + * @arg TIM_IT_BREAK: Break interrupt + * @retval None + */ +#define __HAL_TIM_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->DIER &= ~(__INTERRUPT__)) + +/** @brief Enable the specified DMA request. + * @param __HANDLE__ specifies the TIM Handle. + * @param __DMA__ specifies the TIM DMA request to enable. + * This parameter can be one of the following values: + * @arg TIM_DMA_UPDATE: Update DMA request + * @arg TIM_DMA_CC1: Capture/Compare 1 DMA request + * @arg TIM_DMA_CC2: Capture/Compare 2 DMA request + * @arg TIM_DMA_CC3: Capture/Compare 3 DMA request + * @arg TIM_DMA_CC4: Capture/Compare 4 DMA request + * @arg TIM_DMA_COM: Commutation DMA request + * @arg TIM_DMA_TRIGGER: Trigger DMA request + * @retval None + */ +#define __HAL_TIM_ENABLE_DMA(__HANDLE__, __DMA__) ((__HANDLE__)->Instance->DIER |= (__DMA__)) + +/** @brief Disable the specified DMA request. + * @param __HANDLE__ specifies the TIM Handle. + * @param __DMA__ specifies the TIM DMA request to disable. + * This parameter can be one of the following values: + * @arg TIM_DMA_UPDATE: Update DMA request + * @arg TIM_DMA_CC1: Capture/Compare 1 DMA request + * @arg TIM_DMA_CC2: Capture/Compare 2 DMA request + * @arg TIM_DMA_CC3: Capture/Compare 3 DMA request + * @arg TIM_DMA_CC4: Capture/Compare 4 DMA request + * @arg TIM_DMA_COM: Commutation DMA request + * @arg TIM_DMA_TRIGGER: Trigger DMA request + * @retval None + */ +#define __HAL_TIM_DISABLE_DMA(__HANDLE__, __DMA__) ((__HANDLE__)->Instance->DIER &= ~(__DMA__)) + +/** @brief Check whether the specified TIM interrupt flag is set or not. + * @param __HANDLE__ specifies the TIM Handle. + * @param __FLAG__ specifies the TIM interrupt flag to check. + * This parameter can be one of the following values: + * @arg TIM_FLAG_UPDATE: Update interrupt flag + * @arg TIM_FLAG_CC1: Capture/Compare 1 interrupt flag + * @arg TIM_FLAG_CC2: Capture/Compare 2 interrupt flag + * @arg TIM_FLAG_CC3: Capture/Compare 3 interrupt flag + * @arg TIM_FLAG_CC4: Capture/Compare 4 interrupt flag + * @arg TIM_FLAG_COM: Commutation interrupt flag + * @arg TIM_FLAG_TRIGGER: Trigger interrupt flag + * @arg TIM_FLAG_BREAK: Break interrupt flag + * @arg TIM_FLAG_CC1OF: Capture/Compare 1 overcapture flag + * @arg TIM_FLAG_CC2OF: Capture/Compare 2 overcapture flag + * @arg TIM_FLAG_CC3OF: Capture/Compare 3 overcapture flag + * @arg TIM_FLAG_CC4OF: Capture/Compare 4 overcapture flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_TIM_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->SR &(__FLAG__)) == (__FLAG__)) + +/** @brief Clear the specified TIM interrupt flag. + * @param __HANDLE__ specifies the TIM Handle. + * @param __FLAG__ specifies the TIM interrupt flag to clear. + * This parameter can be one of the following values: + * @arg TIM_FLAG_UPDATE: Update interrupt flag + * @arg TIM_FLAG_CC1: Capture/Compare 1 interrupt flag + * @arg TIM_FLAG_CC2: Capture/Compare 2 interrupt flag + * @arg TIM_FLAG_CC3: Capture/Compare 3 interrupt flag + * @arg TIM_FLAG_CC4: Capture/Compare 4 interrupt flag + * @arg TIM_FLAG_COM: Commutation interrupt flag + * @arg TIM_FLAG_TRIGGER: Trigger interrupt flag + * @arg TIM_FLAG_BREAK: Break interrupt flag + * @arg TIM_FLAG_CC1OF: Capture/Compare 1 overcapture flag + * @arg TIM_FLAG_CC2OF: Capture/Compare 2 overcapture flag + * @arg TIM_FLAG_CC3OF: Capture/Compare 3 overcapture flag + * @arg TIM_FLAG_CC4OF: Capture/Compare 4 overcapture flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_TIM_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->SR = ~(__FLAG__)) + +/** + * @brief Check whether the specified TIM interrupt source is enabled or not. + * @param __HANDLE__ TIM handle + * @param __INTERRUPT__ specifies the TIM interrupt source to check. + * This parameter can be one of the following values: + * @arg TIM_IT_UPDATE: Update interrupt + * @arg TIM_IT_CC1: Capture/Compare 1 interrupt + * @arg TIM_IT_CC2: Capture/Compare 2 interrupt + * @arg TIM_IT_CC3: Capture/Compare 3 interrupt + * @arg TIM_IT_CC4: Capture/Compare 4 interrupt + * @arg TIM_IT_COM: Commutation interrupt + * @arg TIM_IT_TRIGGER: Trigger interrupt + * @arg TIM_IT_BREAK: Break interrupt + * @retval The state of TIM_IT (SET or RESET). + */ +#define __HAL_TIM_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->DIER & (__INTERRUPT__)) \ + == (__INTERRUPT__)) ? SET : RESET) + +/** @brief Clear the TIM interrupt pending bits. + * @param __HANDLE__ TIM handle + * @param __INTERRUPT__ specifies the interrupt pending bit to clear. + * This parameter can be one of the following values: + * @arg TIM_IT_UPDATE: Update interrupt + * @arg TIM_IT_CC1: Capture/Compare 1 interrupt + * @arg TIM_IT_CC2: Capture/Compare 2 interrupt + * @arg TIM_IT_CC3: Capture/Compare 3 interrupt + * @arg TIM_IT_CC4: Capture/Compare 4 interrupt + * @arg TIM_IT_COM: Commutation interrupt + * @arg TIM_IT_TRIGGER: Trigger interrupt + * @arg TIM_IT_BREAK: Break interrupt + * @retval None + */ +#define __HAL_TIM_CLEAR_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->SR = ~(__INTERRUPT__)) + +/** + * @brief Indicates whether or not the TIM Counter is used as downcounter. + * @param __HANDLE__ TIM handle. + * @retval False (Counter used as upcounter) or True (Counter used as downcounter) + * @note This macro is particularly useful to get the counting mode when the timer operates in Center-aligned mode + * or Encoder mode. + */ +#define __HAL_TIM_IS_TIM_COUNTING_DOWN(__HANDLE__) (((__HANDLE__)->Instance->CR1 &(TIM_CR1_DIR)) == (TIM_CR1_DIR)) + +/** + * @brief Set the TIM Prescaler on runtime. + * @param __HANDLE__ TIM handle. + * @param __PRESC__ specifies the Prescaler new value. + * @retval None + */ +#define __HAL_TIM_SET_PRESCALER(__HANDLE__, __PRESC__) ((__HANDLE__)->Instance->PSC = (__PRESC__)) + +/** + * @brief Set the TIM Counter Register value on runtime. + * @param __HANDLE__ TIM handle. + * @param __COUNTER__ specifies the Counter register new value. + * @retval None + */ +#define __HAL_TIM_SET_COUNTER(__HANDLE__, __COUNTER__) ((__HANDLE__)->Instance->CNT = (__COUNTER__)) + +/** + * @brief Get the TIM Counter Register value on runtime. + * @param __HANDLE__ TIM handle. + * @retval 16-bit or 32-bit value of the timer counter register (TIMx_CNT) + */ +#define __HAL_TIM_GET_COUNTER(__HANDLE__) ((__HANDLE__)->Instance->CNT) + +/** + * @brief Set the TIM Autoreload Register value on runtime without calling another time any Init function. + * @param __HANDLE__ TIM handle. + * @param __AUTORELOAD__ specifies the Counter register new value. + * @retval None + */ +#define __HAL_TIM_SET_AUTORELOAD(__HANDLE__, __AUTORELOAD__) \ + do{ \ + (__HANDLE__)->Instance->ARR = (__AUTORELOAD__); \ + (__HANDLE__)->Init.Period = (__AUTORELOAD__); \ + } while(0) + +/** + * @brief Get the TIM Autoreload Register value on runtime. + * @param __HANDLE__ TIM handle. + * @retval 16-bit or 32-bit value of the timer auto-reload register(TIMx_ARR) + */ +#define __HAL_TIM_GET_AUTORELOAD(__HANDLE__) ((__HANDLE__)->Instance->ARR) + +/** + * @brief Set the TIM Clock Division value on runtime without calling another time any Init function. + * @param __HANDLE__ TIM handle. + * @param __CKD__ specifies the clock division value. + * This parameter can be one of the following value: + * @arg TIM_CLOCKDIVISION_DIV1: tDTS=tCK_INT + * @arg TIM_CLOCKDIVISION_DIV2: tDTS=2*tCK_INT + * @arg TIM_CLOCKDIVISION_DIV4: tDTS=4*tCK_INT + * @retval None + */ +#define __HAL_TIM_SET_CLOCKDIVISION(__HANDLE__, __CKD__) \ + do{ \ + (__HANDLE__)->Instance->CR1 &= (~TIM_CR1_CKD); \ + (__HANDLE__)->Instance->CR1 |= (__CKD__); \ + (__HANDLE__)->Init.ClockDivision = (__CKD__); \ + } while(0) + +/** + * @brief Get the TIM Clock Division value on runtime. + * @param __HANDLE__ TIM handle. + * @retval The clock division can be one of the following values: + * @arg TIM_CLOCKDIVISION_DIV1: tDTS=tCK_INT + * @arg TIM_CLOCKDIVISION_DIV2: tDTS=2*tCK_INT + * @arg TIM_CLOCKDIVISION_DIV4: tDTS=4*tCK_INT + */ +#define __HAL_TIM_GET_CLOCKDIVISION(__HANDLE__) ((__HANDLE__)->Instance->CR1 & TIM_CR1_CKD) + +/** + * @brief Set the TIM Input Capture prescaler on runtime without calling another time HAL_TIM_IC_ConfigChannel() + * function. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @param __ICPSC__ specifies the Input Capture4 prescaler new value. + * This parameter can be one of the following values: + * @arg TIM_ICPSC_DIV1: no prescaler + * @arg TIM_ICPSC_DIV2: capture is done once every 2 events + * @arg TIM_ICPSC_DIV4: capture is done once every 4 events + * @arg TIM_ICPSC_DIV8: capture is done once every 8 events + * @retval None + */ +#define __HAL_TIM_SET_ICPRESCALER(__HANDLE__, __CHANNEL__, __ICPSC__) \ + do{ \ + TIM_RESET_ICPRESCALERVALUE((__HANDLE__), (__CHANNEL__)); \ + TIM_SET_ICPRESCALERVALUE((__HANDLE__), (__CHANNEL__), (__ICPSC__)); \ + } while(0) + +/** + * @brief Get the TIM Input Capture prescaler on runtime. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: get input capture 1 prescaler value + * @arg TIM_CHANNEL_2: get input capture 2 prescaler value + * @arg TIM_CHANNEL_3: get input capture 3 prescaler value + * @arg TIM_CHANNEL_4: get input capture 4 prescaler value + * @retval The input capture prescaler can be one of the following values: + * @arg TIM_ICPSC_DIV1: no prescaler + * @arg TIM_ICPSC_DIV2: capture is done once every 2 events + * @arg TIM_ICPSC_DIV4: capture is done once every 4 events + * @arg TIM_ICPSC_DIV8: capture is done once every 8 events + */ +#define __HAL_TIM_GET_ICPRESCALER(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCMR1 & TIM_CCMR1_IC1PSC) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? (((__HANDLE__)->Instance->CCMR1 & TIM_CCMR1_IC2PSC) >> 8U) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCMR2 & TIM_CCMR2_IC3PSC) :\ + (((__HANDLE__)->Instance->CCMR2 & TIM_CCMR2_IC4PSC)) >> 8U) + +/** + * @brief Set the TIM Capture Compare Register value on runtime without calling another time ConfigChannel function. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @param __COMPARE__ specifies the Capture Compare register new value. + * @retval None + */ +#define __HAL_TIM_SET_COMPARE(__HANDLE__, __CHANNEL__, __COMPARE__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCR1 = (__COMPARE__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCR2 = (__COMPARE__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCR3 = (__COMPARE__)) :\ + ((__HANDLE__)->Instance->CCR4 = (__COMPARE__))) + +/** + * @brief Get the TIM Capture Compare Register value on runtime. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channel associated with the capture compare register + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: get capture/compare 1 register value + * @arg TIM_CHANNEL_2: get capture/compare 2 register value + * @arg TIM_CHANNEL_3: get capture/compare 3 register value + * @arg TIM_CHANNEL_4: get capture/compare 4 register value + * @retval 16-bit or 32-bit value of the capture/compare register (TIMx_CCRy) + */ +#define __HAL_TIM_GET_COMPARE(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCR1) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCR2) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCR3) :\ + ((__HANDLE__)->Instance->CCR4)) + +/** + * @brief Set the TIM Output compare preload. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval None + */ +#define __HAL_TIM_ENABLE_OCxPRELOAD(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCMR1 |= TIM_CCMR1_OC1PE) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCMR1 |= TIM_CCMR1_OC2PE) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCMR2 |= TIM_CCMR2_OC3PE) :\ + ((__HANDLE__)->Instance->CCMR2 |= TIM_CCMR2_OC4PE)) + +/** + * @brief Reset the TIM Output compare preload. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval None + */ +#define __HAL_TIM_DISABLE_OCxPRELOAD(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCMR1 &= ~TIM_CCMR1_OC1PE) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCMR1 &= ~TIM_CCMR1_OC2PE) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCMR2 &= ~TIM_CCMR2_OC3PE) :\ + ((__HANDLE__)->Instance->CCMR2 &= ~TIM_CCMR2_OC4PE)) + +/** + * @brief Enable fast mode for a given channel. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @note When fast mode is enabled an active edge on the trigger input acts + * like a compare match on CCx output. Delay to sample the trigger + * input and to activate CCx output is reduced to 3 clock cycles. + * @note Fast mode acts only if the channel is configured in PWM1 or PWM2 mode. + * @retval None + */ +#define __HAL_TIM_ENABLE_OCxFAST(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCMR1 |= TIM_CCMR1_OC1FE) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCMR1 |= TIM_CCMR1_OC2FE) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCMR2 |= TIM_CCMR2_OC3FE) :\ + ((__HANDLE__)->Instance->CCMR2 |= TIM_CCMR2_OC4FE)) + +/** + * @brief Disable fast mode for a given channel. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @note When fast mode is disabled CCx output behaves normally depending + * on counter and CCRx values even when the trigger is ON. The minimum + * delay to activate CCx output when an active edge occurs on the + * trigger input is 5 clock cycles. + * @retval None + */ +#define __HAL_TIM_DISABLE_OCxFAST(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCMR1 &= ~TIM_CCMR1_OC1FE) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCMR1 &= ~TIM_CCMR1_OC2FE) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCMR2 &= ~TIM_CCMR2_OC3FE) :\ + ((__HANDLE__)->Instance->CCMR2 &= ~TIM_CCMR2_OC4FE)) + +/** + * @brief Set the Update Request Source (URS) bit of the TIMx_CR1 register. + * @param __HANDLE__ TIM handle. + * @note When the URS bit of the TIMx_CR1 register is set, only counter + * overflow/underflow generates an update interrupt or DMA request (if + * enabled) + * @retval None + */ +#define __HAL_TIM_URS_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1|= TIM_CR1_URS) + +/** + * @brief Reset the Update Request Source (URS) bit of the TIMx_CR1 register. + * @param __HANDLE__ TIM handle. + * @note When the URS bit of the TIMx_CR1 register is reset, any of the + * following events generate an update interrupt or DMA request (if + * enabled): + * _ Counter overflow underflow + * _ Setting the UG bit + * _ Update generation through the slave mode controller + * @retval None + */ +#define __HAL_TIM_URS_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1&=~TIM_CR1_URS) + +/** + * @brief Set the TIM Capture x input polarity on runtime. + * @param __HANDLE__ TIM handle. + * @param __CHANNEL__ TIM Channels to be configured. + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @param __POLARITY__ Polarity for TIx source + * @arg TIM_INPUTCHANNELPOLARITY_RISING: Rising Edge + * @arg TIM_INPUTCHANNELPOLARITY_FALLING: Falling Edge + * @arg TIM_INPUTCHANNELPOLARITY_BOTHEDGE: Rising and Falling Edge + * @retval None + */ +#define __HAL_TIM_SET_CAPTUREPOLARITY(__HANDLE__, __CHANNEL__, __POLARITY__) \ + do{ \ + TIM_RESET_CAPTUREPOLARITY((__HANDLE__), (__CHANNEL__)); \ + TIM_SET_CAPTUREPOLARITY((__HANDLE__), (__CHANNEL__), (__POLARITY__)); \ + }while(0) + +/** + * @} + */ +/* End of exported macros ----------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup TIM_Private_Constants TIM Private Constants + * @{ + */ +/* The counter of a timer instance is disabled only if all the CCx and CCxN + channels have been disabled */ +#define TIM_CCER_CCxE_MASK ((uint32_t)(TIM_CCER_CC1E | TIM_CCER_CC2E | TIM_CCER_CC3E | TIM_CCER_CC4E)) +#define TIM_CCER_CCxNE_MASK ((uint32_t)(TIM_CCER_CC1NE | TIM_CCER_CC2NE | TIM_CCER_CC3NE)) +/** + * @} + */ +/* End of private constants --------------------------------------------------*/ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup TIM_Private_Macros TIM Private Macros + * @{ + */ +#define IS_TIM_CLEARINPUT_SOURCE(__MODE__) (((__MODE__) == TIM_CLEARINPUTSOURCE_NONE) || \ + ((__MODE__) == TIM_CLEARINPUTSOURCE_ETR) || \ + ((__MODE__) == TIM_CLEARINPUTSOURCE_OCREFCLR)) + +#define IS_TIM_DMA_BASE(__BASE__) (((__BASE__) == TIM_DMABASE_CR1) || \ + ((__BASE__) == TIM_DMABASE_CR2) || \ + ((__BASE__) == TIM_DMABASE_SMCR) || \ + ((__BASE__) == TIM_DMABASE_DIER) || \ + ((__BASE__) == TIM_DMABASE_SR) || \ + ((__BASE__) == TIM_DMABASE_EGR) || \ + ((__BASE__) == TIM_DMABASE_CCMR1) || \ + ((__BASE__) == TIM_DMABASE_CCMR2) || \ + ((__BASE__) == TIM_DMABASE_CCER) || \ + ((__BASE__) == TIM_DMABASE_CNT) || \ + ((__BASE__) == TIM_DMABASE_PSC) || \ + ((__BASE__) == TIM_DMABASE_ARR) || \ + ((__BASE__) == TIM_DMABASE_RCR) || \ + ((__BASE__) == TIM_DMABASE_CCR1) || \ + ((__BASE__) == TIM_DMABASE_CCR2) || \ + ((__BASE__) == TIM_DMABASE_CCR3) || \ + ((__BASE__) == TIM_DMABASE_CCR4) || \ + ((__BASE__) == TIM_DMABASE_BDTR)) + +#define IS_TIM_EVENT_SOURCE(__SOURCE__) ((((__SOURCE__) & 0xFFFFFF00U) == 0x00000000U) && ((__SOURCE__) != 0x00000000U)) + +#define IS_TIM_COUNTER_MODE(__MODE__) (((__MODE__) == TIM_COUNTERMODE_UP) || \ + ((__MODE__) == TIM_COUNTERMODE_DOWN) || \ + ((__MODE__) == TIM_COUNTERMODE_CENTERALIGNED1) || \ + ((__MODE__) == TIM_COUNTERMODE_CENTERALIGNED2) || \ + ((__MODE__) == TIM_COUNTERMODE_CENTERALIGNED3)) + +#define IS_TIM_CLOCKDIVISION_DIV(__DIV__) (((__DIV__) == TIM_CLOCKDIVISION_DIV1) || \ + ((__DIV__) == TIM_CLOCKDIVISION_DIV2) || \ + ((__DIV__) == TIM_CLOCKDIVISION_DIV4)) + +#define IS_TIM_AUTORELOAD_PRELOAD(PRELOAD) (((PRELOAD) == TIM_AUTORELOAD_PRELOAD_DISABLE) || \ + ((PRELOAD) == TIM_AUTORELOAD_PRELOAD_ENABLE)) + +#define IS_TIM_FAST_STATE(__STATE__) (((__STATE__) == TIM_OCFAST_DISABLE) || \ + ((__STATE__) == TIM_OCFAST_ENABLE)) + +#define IS_TIM_OC_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_OCPOLARITY_HIGH) || \ + ((__POLARITY__) == TIM_OCPOLARITY_LOW)) + +#define IS_TIM_OCN_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_OCNPOLARITY_HIGH) || \ + ((__POLARITY__) == TIM_OCNPOLARITY_LOW)) + +#define IS_TIM_OCIDLE_STATE(__STATE__) (((__STATE__) == TIM_OCIDLESTATE_SET) || \ + ((__STATE__) == TIM_OCIDLESTATE_RESET)) + +#define IS_TIM_OCNIDLE_STATE(__STATE__) (((__STATE__) == TIM_OCNIDLESTATE_SET) || \ + ((__STATE__) == TIM_OCNIDLESTATE_RESET)) + +#define IS_TIM_ENCODERINPUT_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_ENCODERINPUTPOLARITY_RISING) || \ + ((__POLARITY__) == TIM_ENCODERINPUTPOLARITY_FALLING)) + +#define IS_TIM_IC_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_ICPOLARITY_RISING) || \ + ((__POLARITY__) == TIM_ICPOLARITY_FALLING) || \ + ((__POLARITY__) == TIM_ICPOLARITY_BOTHEDGE)) + +#define IS_TIM_IC_SELECTION(__SELECTION__) (((__SELECTION__) == TIM_ICSELECTION_DIRECTTI) || \ + ((__SELECTION__) == TIM_ICSELECTION_INDIRECTTI) || \ + ((__SELECTION__) == TIM_ICSELECTION_TRC)) + +#define IS_TIM_IC_PRESCALER(__PRESCALER__) (((__PRESCALER__) == TIM_ICPSC_DIV1) || \ + ((__PRESCALER__) == TIM_ICPSC_DIV2) || \ + ((__PRESCALER__) == TIM_ICPSC_DIV4) || \ + ((__PRESCALER__) == TIM_ICPSC_DIV8)) + +#define IS_TIM_OPM_MODE(__MODE__) (((__MODE__) == TIM_OPMODE_SINGLE) || \ + ((__MODE__) == TIM_OPMODE_REPETITIVE)) + +#define IS_TIM_ENCODER_MODE(__MODE__) (((__MODE__) == TIM_ENCODERMODE_TI1) || \ + ((__MODE__) == TIM_ENCODERMODE_TI2) || \ + ((__MODE__) == TIM_ENCODERMODE_TI12)) + +#define IS_TIM_DMA_SOURCE(__SOURCE__) ((((__SOURCE__) & 0xFFFF80FFU) == 0x00000000U) && ((__SOURCE__) != 0x00000000U)) + +#define IS_TIM_CHANNELS(__CHANNEL__) (((__CHANNEL__) == TIM_CHANNEL_1) || \ + ((__CHANNEL__) == TIM_CHANNEL_2) || \ + ((__CHANNEL__) == TIM_CHANNEL_3) || \ + ((__CHANNEL__) == TIM_CHANNEL_4) || \ + ((__CHANNEL__) == TIM_CHANNEL_ALL)) + +#define IS_TIM_OPM_CHANNELS(__CHANNEL__) (((__CHANNEL__) == TIM_CHANNEL_1) || \ + ((__CHANNEL__) == TIM_CHANNEL_2)) + +#define IS_TIM_COMPLEMENTARY_CHANNELS(__CHANNEL__) (((__CHANNEL__) == TIM_CHANNEL_1) || \ + ((__CHANNEL__) == TIM_CHANNEL_2) || \ + ((__CHANNEL__) == TIM_CHANNEL_3)) + +#define IS_TIM_CLOCKSOURCE(__CLOCK__) (((__CLOCK__) == TIM_CLOCKSOURCE_INTERNAL) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_ETRMODE2) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_ITR0) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_ITR1) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_ITR2) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_ITR3) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_TI1ED) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_TI1) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_TI2) || \ + ((__CLOCK__) == TIM_CLOCKSOURCE_ETRMODE1)) + +#define IS_TIM_CLOCKPOLARITY(__POLARITY__) (((__POLARITY__) == TIM_CLOCKPOLARITY_INVERTED) || \ + ((__POLARITY__) == TIM_CLOCKPOLARITY_NONINVERTED) || \ + ((__POLARITY__) == TIM_CLOCKPOLARITY_RISING) || \ + ((__POLARITY__) == TIM_CLOCKPOLARITY_FALLING) || \ + ((__POLARITY__) == TIM_CLOCKPOLARITY_BOTHEDGE)) + +#define IS_TIM_CLOCKPRESCALER(__PRESCALER__) (((__PRESCALER__) == TIM_CLOCKPRESCALER_DIV1) || \ + ((__PRESCALER__) == TIM_CLOCKPRESCALER_DIV2) || \ + ((__PRESCALER__) == TIM_CLOCKPRESCALER_DIV4) || \ + ((__PRESCALER__) == TIM_CLOCKPRESCALER_DIV8)) + +#define IS_TIM_CLOCKFILTER(__ICFILTER__) ((__ICFILTER__) <= 0xFU) + +#define IS_TIM_CLEARINPUT_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_CLEARINPUTPOLARITY_INVERTED) || \ + ((__POLARITY__) == TIM_CLEARINPUTPOLARITY_NONINVERTED)) + +#define IS_TIM_CLEARINPUT_PRESCALER(__PRESCALER__) (((__PRESCALER__) == TIM_CLEARINPUTPRESCALER_DIV1) || \ + ((__PRESCALER__) == TIM_CLEARINPUTPRESCALER_DIV2) || \ + ((__PRESCALER__) == TIM_CLEARINPUTPRESCALER_DIV4) || \ + ((__PRESCALER__) == TIM_CLEARINPUTPRESCALER_DIV8)) + +#define IS_TIM_CLEARINPUT_FILTER(__ICFILTER__) ((__ICFILTER__) <= 0xFU) + +#define IS_TIM_OSSR_STATE(__STATE__) (((__STATE__) == TIM_OSSR_ENABLE) || \ + ((__STATE__) == TIM_OSSR_DISABLE)) + +#define IS_TIM_OSSI_STATE(__STATE__) (((__STATE__) == TIM_OSSI_ENABLE) || \ + ((__STATE__) == TIM_OSSI_DISABLE)) + +#define IS_TIM_LOCK_LEVEL(__LEVEL__) (((__LEVEL__) == TIM_LOCKLEVEL_OFF) || \ + ((__LEVEL__) == TIM_LOCKLEVEL_1) || \ + ((__LEVEL__) == TIM_LOCKLEVEL_2) || \ + ((__LEVEL__) == TIM_LOCKLEVEL_3)) + +#define IS_TIM_BREAK_FILTER(__BRKFILTER__) ((__BRKFILTER__) <= 0xFUL) + + +#define IS_TIM_BREAK_STATE(__STATE__) (((__STATE__) == TIM_BREAK_ENABLE) || \ + ((__STATE__) == TIM_BREAK_DISABLE)) + +#define IS_TIM_BREAK_POLARITY(__POLARITY__) (((__POLARITY__) == TIM_BREAKPOLARITY_LOW) || \ + ((__POLARITY__) == TIM_BREAKPOLARITY_HIGH)) + +#define IS_TIM_AUTOMATIC_OUTPUT_STATE(__STATE__) (((__STATE__) == TIM_AUTOMATICOUTPUT_ENABLE) || \ + ((__STATE__) == TIM_AUTOMATICOUTPUT_DISABLE)) + +#define IS_TIM_TRGO_SOURCE(__SOURCE__) (((__SOURCE__) == TIM_TRGO_RESET) || \ + ((__SOURCE__) == TIM_TRGO_ENABLE) || \ + ((__SOURCE__) == TIM_TRGO_UPDATE) || \ + ((__SOURCE__) == TIM_TRGO_OC1) || \ + ((__SOURCE__) == TIM_TRGO_OC1REF) || \ + ((__SOURCE__) == TIM_TRGO_OC2REF) || \ + ((__SOURCE__) == TIM_TRGO_OC3REF) || \ + ((__SOURCE__) == TIM_TRGO_OC4REF)) + +#define IS_TIM_MSM_STATE(__STATE__) (((__STATE__) == TIM_MASTERSLAVEMODE_ENABLE) || \ + ((__STATE__) == TIM_MASTERSLAVEMODE_DISABLE)) + +#define IS_TIM_SLAVE_MODE(__MODE__) (((__MODE__) == TIM_SLAVEMODE_DISABLE) || \ + ((__MODE__) == TIM_SLAVEMODE_RESET) || \ + ((__MODE__) == TIM_SLAVEMODE_GATED) || \ + ((__MODE__) == TIM_SLAVEMODE_TRIGGER) || \ + ((__MODE__) == TIM_SLAVEMODE_EXTERNAL1)) + +#define IS_TIM_PWM_MODE(__MODE__) (((__MODE__) == TIM_OCMODE_PWM1) || \ + ((__MODE__) == TIM_OCMODE_PWM2)) + +#define IS_TIM_OC_MODE(__MODE__) (((__MODE__) == TIM_OCMODE_TIMING) || \ + ((__MODE__) == TIM_OCMODE_ACTIVE) || \ + ((__MODE__) == TIM_OCMODE_INACTIVE) || \ + ((__MODE__) == TIM_OCMODE_TOGGLE) || \ + ((__MODE__) == TIM_OCMODE_FORCED_ACTIVE) || \ + ((__MODE__) == TIM_OCMODE_FORCED_INACTIVE)) + +#define IS_TIM_TRIGGER_SELECTION(__SELECTION__) (((__SELECTION__) == TIM_TS_ITR0) || \ + ((__SELECTION__) == TIM_TS_ITR1) || \ + ((__SELECTION__) == TIM_TS_ITR2) || \ + ((__SELECTION__) == TIM_TS_ITR3) || \ + ((__SELECTION__) == TIM_TS_TI1F_ED) || \ + ((__SELECTION__) == TIM_TS_TI1FP1) || \ + ((__SELECTION__) == TIM_TS_TI2FP2) || \ + ((__SELECTION__) == TIM_TS_ETRF)) + +#define IS_TIM_INTERNAL_TRIGGEREVENT_SELECTION(__SELECTION__) (((__SELECTION__) == TIM_TS_ITR0) || \ + ((__SELECTION__) == TIM_TS_ITR1) || \ + ((__SELECTION__) == TIM_TS_ITR2) || \ + ((__SELECTION__) == TIM_TS_ITR3) || \ + ((__SELECTION__) == TIM_TS_NONE)) + +#define IS_TIM_TRIGGERPOLARITY(__POLARITY__) (((__POLARITY__) == TIM_TRIGGERPOLARITY_INVERTED ) || \ + ((__POLARITY__) == TIM_TRIGGERPOLARITY_NONINVERTED) || \ + ((__POLARITY__) == TIM_TRIGGERPOLARITY_RISING ) || \ + ((__POLARITY__) == TIM_TRIGGERPOLARITY_FALLING ) || \ + ((__POLARITY__) == TIM_TRIGGERPOLARITY_BOTHEDGE )) + +#define IS_TIM_TRIGGERPRESCALER(__PRESCALER__) (((__PRESCALER__) == TIM_TRIGGERPRESCALER_DIV1) || \ + ((__PRESCALER__) == TIM_TRIGGERPRESCALER_DIV2) || \ + ((__PRESCALER__) == TIM_TRIGGERPRESCALER_DIV4) || \ + ((__PRESCALER__) == TIM_TRIGGERPRESCALER_DIV8)) + +#define IS_TIM_TRIGGERFILTER(__ICFILTER__) ((__ICFILTER__) <= 0xFU) + +#define IS_TIM_TI1SELECTION(__TI1SELECTION__) (((__TI1SELECTION__) == TIM_TI1SELECTION_CH1) || \ + ((__TI1SELECTION__) == TIM_TI1SELECTION_XORCOMBINATION)) + +#define IS_TIM_DMA_LENGTH(__LENGTH__) (((__LENGTH__) == TIM_DMABURSTLENGTH_1TRANSFER) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_2TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_3TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_4TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_5TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_6TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_7TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_8TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_9TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_10TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_11TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_12TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_13TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_14TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_15TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_16TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_17TRANSFERS) || \ + ((__LENGTH__) == TIM_DMABURSTLENGTH_18TRANSFERS)) + +#define IS_TIM_DMA_DATA_LENGTH(LENGTH) (((LENGTH) >= 0x1U) && ((LENGTH) < 0x10000U)) + +#define IS_TIM_IC_FILTER(__ICFILTER__) ((__ICFILTER__) <= 0xFU) + +#define IS_TIM_DEADTIME(__DEADTIME__) ((__DEADTIME__) <= 0xFFU) + +#define IS_TIM_SLAVEMODE_TRIGGER_ENABLED(__TRIGGER__) ((__TRIGGER__) == TIM_SLAVEMODE_TRIGGER) + +#define TIM_SET_ICPRESCALERVALUE(__HANDLE__, __CHANNEL__, __ICPSC__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCMR1 |= (__ICPSC__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCMR1 |= ((__ICPSC__) << 8U)) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCMR2 |= (__ICPSC__)) :\ + ((__HANDLE__)->Instance->CCMR2 |= ((__ICPSC__) << 8U))) + +#define TIM_RESET_ICPRESCALERVALUE(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCMR1 &= ~TIM_CCMR1_IC1PSC) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCMR1 &= ~TIM_CCMR1_IC2PSC) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCMR2 &= ~TIM_CCMR2_IC3PSC) :\ + ((__HANDLE__)->Instance->CCMR2 &= ~TIM_CCMR2_IC4PSC)) + +#define TIM_SET_CAPTUREPOLARITY(__HANDLE__, __CHANNEL__, __POLARITY__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCER |= (__POLARITY__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCER |= ((__POLARITY__) << 4U)) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCER |= ((__POLARITY__) << 8U)) :\ + ((__HANDLE__)->Instance->CCER |= (((__POLARITY__) << 12U)))) + +#define TIM_RESET_CAPTUREPOLARITY(__HANDLE__, __CHANNEL__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP)) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP)) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC3P | TIM_CCER_CC3NP)) :\ + ((__HANDLE__)->Instance->CCER &= ~(TIM_CCER_CC4P | TIM_CCER_CC4NP))) + +#define TIM_CHANNEL_STATE_GET(__HANDLE__, __CHANNEL__)\ + (((__CHANNEL__) == TIM_CHANNEL_1) ? (__HANDLE__)->ChannelState[0] :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? (__HANDLE__)->ChannelState[1] :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? (__HANDLE__)->ChannelState[2] :\ + (__HANDLE__)->ChannelState[3]) + +#define TIM_CHANNEL_STATE_SET(__HANDLE__, __CHANNEL__, __CHANNEL_STATE__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->ChannelState[0] = (__CHANNEL_STATE__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->ChannelState[1] = (__CHANNEL_STATE__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->ChannelState[2] = (__CHANNEL_STATE__)) :\ + ((__HANDLE__)->ChannelState[3] = (__CHANNEL_STATE__))) + +#define TIM_CHANNEL_STATE_SET_ALL(__HANDLE__, __CHANNEL_STATE__) do { \ + (__HANDLE__)->ChannelState[0] = (__CHANNEL_STATE__); \ + (__HANDLE__)->ChannelState[1] = (__CHANNEL_STATE__); \ + (__HANDLE__)->ChannelState[2] = (__CHANNEL_STATE__); \ + (__HANDLE__)->ChannelState[3] = (__CHANNEL_STATE__); \ + } while(0) + +#define TIM_CHANNEL_N_STATE_GET(__HANDLE__, __CHANNEL__)\ + (((__CHANNEL__) == TIM_CHANNEL_1) ? (__HANDLE__)->ChannelNState[0] :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? (__HANDLE__)->ChannelNState[1] :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? (__HANDLE__)->ChannelNState[2] :\ + (__HANDLE__)->ChannelNState[3]) + +#define TIM_CHANNEL_N_STATE_SET(__HANDLE__, __CHANNEL__, __CHANNEL_STATE__) \ + (((__CHANNEL__) == TIM_CHANNEL_1) ? ((__HANDLE__)->ChannelNState[0] = (__CHANNEL_STATE__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_2) ? ((__HANDLE__)->ChannelNState[1] = (__CHANNEL_STATE__)) :\ + ((__CHANNEL__) == TIM_CHANNEL_3) ? ((__HANDLE__)->ChannelNState[2] = (__CHANNEL_STATE__)) :\ + ((__HANDLE__)->ChannelNState[3] = (__CHANNEL_STATE__))) + +#define TIM_CHANNEL_N_STATE_SET_ALL(__HANDLE__, __CHANNEL_STATE__) do { \ + (__HANDLE__)->ChannelNState[0] = \ + (__CHANNEL_STATE__); \ + (__HANDLE__)->ChannelNState[1] = \ + (__CHANNEL_STATE__); \ + (__HANDLE__)->ChannelNState[2] = \ + (__CHANNEL_STATE__); \ + (__HANDLE__)->ChannelNState[3] = \ + (__CHANNEL_STATE__); \ + } while(0) + +/** + * @} + */ +/* End of private macros -----------------------------------------------------*/ + +/* Include TIM HAL Extended module */ +#include "stm32f0xx_hal_tim_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup TIM_Exported_Functions TIM Exported Functions + * @{ + */ + +/** @addtogroup TIM_Exported_Functions_Group1 TIM Time Base functions + * @brief Time Base functions + * @{ + */ +/* Time Base functions ********************************************************/ +HAL_StatusTypeDef HAL_TIM_Base_Init(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIM_Base_DeInit(TIM_HandleTypeDef *htim); +void HAL_TIM_Base_MspInit(TIM_HandleTypeDef *htim); +void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef *htim); +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIM_Base_Start(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIM_Base_Stop(TIM_HandleTypeDef *htim); +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIM_Base_Start_IT(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIM_Base_Stop_IT(TIM_HandleTypeDef *htim); +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIM_Base_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length); +HAL_StatusTypeDef HAL_TIM_Base_Stop_DMA(TIM_HandleTypeDef *htim); +/** + * @} + */ + +/** @addtogroup TIM_Exported_Functions_Group2 TIM Output Compare functions + * @brief TIM Output Compare functions + * @{ + */ +/* Timer Output Compare functions *********************************************/ +HAL_StatusTypeDef HAL_TIM_OC_Init(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIM_OC_DeInit(TIM_HandleTypeDef *htim); +void HAL_TIM_OC_MspInit(TIM_HandleTypeDef *htim); +void HAL_TIM_OC_MspDeInit(TIM_HandleTypeDef *htim); +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIM_OC_Start(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_OC_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIM_OC_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_OC_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIM_OC_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); +HAL_StatusTypeDef HAL_TIM_OC_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); +/** + * @} + */ + +/** @addtogroup TIM_Exported_Functions_Group3 TIM PWM functions + * @brief TIM PWM functions + * @{ + */ +/* Timer PWM functions ********************************************************/ +HAL_StatusTypeDef HAL_TIM_PWM_Init(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIM_PWM_DeInit(TIM_HandleTypeDef *htim); +void HAL_TIM_PWM_MspInit(TIM_HandleTypeDef *htim); +void HAL_TIM_PWM_MspDeInit(TIM_HandleTypeDef *htim); +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIM_PWM_Start(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_PWM_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIM_PWM_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_PWM_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIM_PWM_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); +HAL_StatusTypeDef HAL_TIM_PWM_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); +/** + * @} + */ + +/** @addtogroup TIM_Exported_Functions_Group4 TIM Input Capture functions + * @brief TIM Input Capture functions + * @{ + */ +/* Timer Input Capture functions **********************************************/ +HAL_StatusTypeDef HAL_TIM_IC_Init(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIM_IC_DeInit(TIM_HandleTypeDef *htim); +void HAL_TIM_IC_MspInit(TIM_HandleTypeDef *htim); +void HAL_TIM_IC_MspDeInit(TIM_HandleTypeDef *htim); +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIM_IC_Start(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_IC_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIM_IC_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_IC_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIM_IC_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); +HAL_StatusTypeDef HAL_TIM_IC_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); +/** + * @} + */ + +/** @addtogroup TIM_Exported_Functions_Group5 TIM One Pulse functions + * @brief TIM One Pulse functions + * @{ + */ +/* Timer One Pulse functions **************************************************/ +HAL_StatusTypeDef HAL_TIM_OnePulse_Init(TIM_HandleTypeDef *htim, uint32_t OnePulseMode); +HAL_StatusTypeDef HAL_TIM_OnePulse_DeInit(TIM_HandleTypeDef *htim); +void HAL_TIM_OnePulse_MspInit(TIM_HandleTypeDef *htim); +void HAL_TIM_OnePulse_MspDeInit(TIM_HandleTypeDef *htim); +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIM_OnePulse_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel); +HAL_StatusTypeDef HAL_TIM_OnePulse_Stop(TIM_HandleTypeDef *htim, uint32_t OutputChannel); +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIM_OnePulse_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel); +HAL_StatusTypeDef HAL_TIM_OnePulse_Stop_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel); +/** + * @} + */ + +/** @addtogroup TIM_Exported_Functions_Group6 TIM Encoder functions + * @brief TIM Encoder functions + * @{ + */ +/* Timer Encoder functions ****************************************************/ +HAL_StatusTypeDef HAL_TIM_Encoder_Init(TIM_HandleTypeDef *htim, TIM_Encoder_InitTypeDef *sConfig); +HAL_StatusTypeDef HAL_TIM_Encoder_DeInit(TIM_HandleTypeDef *htim); +void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim); +void HAL_TIM_Encoder_MspDeInit(TIM_HandleTypeDef *htim); +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIM_Encoder_Start(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_Encoder_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIM_Encoder_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_Encoder_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIM_Encoder_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData1, + uint32_t *pData2, uint16_t Length); +HAL_StatusTypeDef HAL_TIM_Encoder_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); +/** + * @} + */ + +/** @addtogroup TIM_Exported_Functions_Group7 TIM IRQ handler management + * @brief IRQ handler management + * @{ + */ +/* Interrupt Handler functions ***********************************************/ +void HAL_TIM_IRQHandler(TIM_HandleTypeDef *htim); +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group8 TIM Peripheral Control functions + * @brief Peripheral Control functions + * @{ + */ +/* Control functions *********************************************************/ +HAL_StatusTypeDef HAL_TIM_OC_ConfigChannel(TIM_HandleTypeDef *htim, TIM_OC_InitTypeDef *sConfig, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_PWM_ConfigChannel(TIM_HandleTypeDef *htim, TIM_OC_InitTypeDef *sConfig, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_IC_ConfigChannel(TIM_HandleTypeDef *htim, TIM_IC_InitTypeDef *sConfig, uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_OnePulse_ConfigChannel(TIM_HandleTypeDef *htim, TIM_OnePulse_InitTypeDef *sConfig, + uint32_t OutputChannel, uint32_t InputChannel); +HAL_StatusTypeDef HAL_TIM_ConfigOCrefClear(TIM_HandleTypeDef *htim, TIM_ClearInputConfigTypeDef *sClearInputConfig, + uint32_t Channel); +HAL_StatusTypeDef HAL_TIM_ConfigClockSource(TIM_HandleTypeDef *htim, TIM_ClockConfigTypeDef *sClockSourceConfig); +HAL_StatusTypeDef HAL_TIM_ConfigTI1Input(TIM_HandleTypeDef *htim, uint32_t TI1_Selection); +HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro(TIM_HandleTypeDef *htim, TIM_SlaveConfigTypeDef *sSlaveConfig); +HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro_IT(TIM_HandleTypeDef *htim, TIM_SlaveConfigTypeDef *sSlaveConfig); +HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength); +HAL_StatusTypeDef HAL_TIM_DMABurst_MultiWriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, + uint32_t BurstLength, uint32_t DataLength); +HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc); +HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength); +HAL_StatusTypeDef HAL_TIM_DMABurst_MultiReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, + uint32_t BurstLength, uint32_t DataLength); +HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc); +HAL_StatusTypeDef HAL_TIM_GenerateEvent(TIM_HandleTypeDef *htim, uint32_t EventSource); +uint32_t HAL_TIM_ReadCapturedValue(TIM_HandleTypeDef *htim, uint32_t Channel); +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group9 TIM Callbacks functions + * @brief TIM Callbacks functions + * @{ + */ +/* Callback in non blocking modes (Interrupt and DMA) *************************/ +void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_PeriodElapsedHalfCpltCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_OC_DelayElapsedCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_IC_CaptureHalfCpltCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_PWM_PulseFinishedCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_PWM_PulseFinishedHalfCpltCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_TriggerCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_TriggerHalfCpltCallback(TIM_HandleTypeDef *htim); +void HAL_TIM_ErrorCallback(TIM_HandleTypeDef *htim); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_TIM_RegisterCallback(TIM_HandleTypeDef *htim, HAL_TIM_CallbackIDTypeDef CallbackID, + pTIM_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_TIM_UnRegisterCallback(TIM_HandleTypeDef *htim, HAL_TIM_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group10 TIM Peripheral State functions + * @brief Peripheral State functions + * @{ + */ +/* Peripheral State functions ************************************************/ +HAL_TIM_StateTypeDef HAL_TIM_Base_GetState(TIM_HandleTypeDef *htim); +HAL_TIM_StateTypeDef HAL_TIM_OC_GetState(TIM_HandleTypeDef *htim); +HAL_TIM_StateTypeDef HAL_TIM_PWM_GetState(TIM_HandleTypeDef *htim); +HAL_TIM_StateTypeDef HAL_TIM_IC_GetState(TIM_HandleTypeDef *htim); +HAL_TIM_StateTypeDef HAL_TIM_OnePulse_GetState(TIM_HandleTypeDef *htim); +HAL_TIM_StateTypeDef HAL_TIM_Encoder_GetState(TIM_HandleTypeDef *htim); + +/* Peripheral Channel state functions ************************************************/ +HAL_TIM_ActiveChannel HAL_TIM_GetActiveChannel(TIM_HandleTypeDef *htim); +HAL_TIM_ChannelStateTypeDef HAL_TIM_GetChannelState(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_TIM_DMABurstStateTypeDef HAL_TIM_DMABurstState(TIM_HandleTypeDef *htim); +/** + * @} + */ + +/** + * @} + */ +/* End of exported functions -------------------------------------------------*/ + +/* Private functions----------------------------------------------------------*/ +/** @defgroup TIM_Private_Functions TIM Private Functions + * @{ + */ +void TIM_Base_SetConfig(TIM_TypeDef *TIMx, TIM_Base_InitTypeDef *Structure); +void TIM_TI1_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, uint32_t TIM_ICFilter); +void TIM_OC2_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config); +void TIM_ETR_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ExtTRGPrescaler, + uint32_t TIM_ExtTRGPolarity, uint32_t ExtTRGFilter); + +void TIM_DMADelayPulseHalfCplt(DMA_HandleTypeDef *hdma); +void TIM_DMAError(DMA_HandleTypeDef *hdma); +void TIM_DMACaptureCplt(DMA_HandleTypeDef *hdma); +void TIM_DMACaptureHalfCplt(DMA_HandleTypeDef *hdma); +void TIM_CCxChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ChannelState); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) +void TIM_ResetCallback(TIM_HandleTypeDef *htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + +/** + * @} + */ +/* End of private functions --------------------------------------------------*/ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_TIM_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim_ex.h new file mode 100644 index 0000000..23f6642 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tim_ex.h @@ -0,0 +1,268 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_tim_ex.h + * @author MCD Application Team + * @brief Header file of TIM HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_TIM_EX_H +#define STM32F0xx_HAL_TIM_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup TIMEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup TIMEx_Exported_Types TIM Extended Exported Types + * @{ + */ + +/** + * @brief TIM Hall sensor Configuration Structure definition + */ + +typedef struct +{ + uint32_t IC1Polarity; /*!< Specifies the active edge of the input signal. + This parameter can be a value of @ref TIM_Input_Capture_Polarity */ + + uint32_t IC1Prescaler; /*!< Specifies the Input Capture Prescaler. + This parameter can be a value of @ref TIM_Input_Capture_Prescaler */ + + uint32_t IC1Filter; /*!< Specifies the input capture filter. + This parameter can be a number between Min_Data = 0x0 and Max_Data = 0xF */ + + uint32_t Commutation_Delay; /*!< Specifies the pulse value to be loaded into the Capture Compare Register. + This parameter can be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF */ +} TIM_HallSensor_InitTypeDef; +/** + * @} + */ +/* End of exported types -----------------------------------------------------*/ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup TIMEx_Exported_Constants TIM Extended Exported Constants + * @{ + */ + +/** @defgroup TIMEx_Remap TIM Extended Remapping + * @{ + */ +#define TIM_TIM14_GPIO (0x00000000U) /*!< TIM14 TI1 is connected to GPIO */ +#define TIM_TIM14_RTC (0x00000001U) /*!< TIM14 TI1 is connected to RTC_clock */ +#define TIM_TIM14_HSE (0x00000002U) /*!< TIM14 TI1 is connected to HSE/32U */ +#define TIM_TIM14_MCO (0x00000003U) /*!< TIM14 TI1 is connected to MCO */ +/** + * @} + */ + +/** + * @} + */ +/* End of exported constants -------------------------------------------------*/ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup TIMEx_Exported_Macros TIM Extended Exported Macros + * @{ + */ + +/** + * @} + */ +/* End of exported macro -----------------------------------------------------*/ + +/* Private macro -------------------------------------------------------------*/ +/** @defgroup TIMEx_Private_Macros TIM Extended Private Macros + * @{ + */ +#define IS_TIM_REMAP(__INSTANCE__, __REMAP__) \ + (((__INSTANCE__) == TIM14) && (((__REMAP__) & 0xFFFFFFFCU) == 0x00000000U)) + +/** + * @} + */ +/* End of private macro ------------------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup TIMEx_Exported_Functions TIM Extended Exported Functions + * @{ + */ + +/** @addtogroup TIMEx_Exported_Functions_Group1 Extended Timer Hall Sensor functions + * @brief Timer Hall Sensor functions + * @{ + */ +/* Timer Hall Sensor functions **********************************************/ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, TIM_HallSensor_InitTypeDef *sConfig); +HAL_StatusTypeDef HAL_TIMEx_HallSensor_DeInit(TIM_HandleTypeDef *htim); + +void HAL_TIMEx_HallSensor_MspInit(TIM_HandleTypeDef *htim); +void HAL_TIMEx_HallSensor_MspDeInit(TIM_HandleTypeDef *htim); + +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop(TIM_HandleTypeDef *htim); +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_IT(TIM_HandleTypeDef *htim); +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_IT(TIM_HandleTypeDef *htim); +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length); +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_DMA(TIM_HandleTypeDef *htim); +/** + * @} + */ + +/** @addtogroup TIMEx_Exported_Functions_Group2 Extended Timer Complementary Output Compare functions + * @brief Timer Complementary Output Compare functions + * @{ + */ +/* Timer Complementary Output Compare functions *****************************/ +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Start(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIMEx_OCN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); + +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); + +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); +HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); +/** + * @} + */ + +/** @addtogroup TIMEx_Exported_Functions_Group3 Extended Timer Complementary PWM functions + * @brief Timer Complementary PWM functions + * @{ + */ +/* Timer Complementary PWM functions ****************************************/ +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Start(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel); + +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel); +/* Non-Blocking mode: DMA */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length); +HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel); +/** + * @} + */ + +/** @addtogroup TIMEx_Exported_Functions_Group4 Extended Timer Complementary One Pulse functions + * @brief Timer Complementary One Pulse functions + * @{ + */ +/* Timer Complementary One Pulse functions **********************************/ +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel); +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t OutputChannel); + +/* Non-Blocking mode: Interrupt */ +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel); +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel); +/** + * @} + */ + +/** @addtogroup TIMEx_Exported_Functions_Group5 Extended Peripheral Control functions + * @brief Peripheral Control functions + * @{ + */ +/* Extended Control functions ************************************************/ +HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent(TIM_HandleTypeDef *htim, uint32_t InputTrigger, + uint32_t CommutationSource); +HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_IT(TIM_HandleTypeDef *htim, uint32_t InputTrigger, + uint32_t CommutationSource); +HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_DMA(TIM_HandleTypeDef *htim, uint32_t InputTrigger, + uint32_t CommutationSource); +HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim, + TIM_MasterConfigTypeDef *sMasterConfig); +HAL_StatusTypeDef HAL_TIMEx_ConfigBreakDeadTime(TIM_HandleTypeDef *htim, + TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig); +HAL_StatusTypeDef HAL_TIMEx_RemapConfig(TIM_HandleTypeDef *htim, uint32_t Remap); +/** + * @} + */ + +/** @addtogroup TIMEx_Exported_Functions_Group6 Extended Callbacks functions + * @brief Extended Callbacks functions + * @{ + */ +/* Extended Callback **********************************************************/ +void HAL_TIMEx_CommutCallback(TIM_HandleTypeDef *htim); +void HAL_TIMEx_CommutHalfCpltCallback(TIM_HandleTypeDef *htim); +void HAL_TIMEx_BreakCallback(TIM_HandleTypeDef *htim); +/** + * @} + */ + +/** @addtogroup TIMEx_Exported_Functions_Group7 Extended Peripheral State functions + * @brief Extended Peripheral State functions + * @{ + */ +/* Extended Peripheral State functions ***************************************/ +HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim); +HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim, uint32_t ChannelN); +/** + * @} + */ + +/** + * @} + */ +/* End of exported functions -------------------------------------------------*/ + +/* Private functions----------------------------------------------------------*/ +/** @addtogroup TIMEx_Private_Functions TIMEx Private Functions + * @{ + */ +void TIMEx_DMACommutationCplt(DMA_HandleTypeDef *hdma); +void TIMEx_DMACommutationHalfCplt(DMA_HandleTypeDef *hdma); +/** + * @} + */ +/* End of private functions --------------------------------------------------*/ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + + +#endif /* STM32F0xx_HAL_TIM_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tsc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tsc.h new file mode 100644 index 0000000..8ac1f91 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_tsc.h @@ -0,0 +1,800 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_tsc.h + * @author MCD Application Team + * @brief Header file of TSC HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_TSC_H +#define STM32F0xx_HAL_TSC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +#if defined(TSC) + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup TSC + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup TSC_Exported_Types TSC Exported Types + * @{ + */ + +/** + * @brief TSC state structure definition + */ +typedef enum +{ + HAL_TSC_STATE_RESET = 0x00UL, /*!< TSC registers have their reset value */ + HAL_TSC_STATE_READY = 0x01UL, /*!< TSC registers are initialized or acquisition is completed with success */ + HAL_TSC_STATE_BUSY = 0x02UL, /*!< TSC initialization or acquisition is on-going */ + HAL_TSC_STATE_ERROR = 0x03UL /*!< Acquisition is completed with max count error */ +} HAL_TSC_StateTypeDef; + +/** + * @brief TSC group status structure definition + */ +typedef enum +{ + TSC_GROUP_ONGOING = 0x00UL, /*!< Acquisition on group is on-going or not started */ + TSC_GROUP_COMPLETED = 0x01UL /*!< Acquisition on group is completed with success (no max count error) */ +} TSC_GroupStatusTypeDef; + +/** + * @brief TSC init structure definition + */ +typedef struct +{ + uint32_t CTPulseHighLength; /*!< Charge-transfer high pulse length + This parameter can be a value of @ref TSC_CTPulseHL_Config */ + uint32_t CTPulseLowLength; /*!< Charge-transfer low pulse length + This parameter can be a value of @ref TSC_CTPulseLL_Config */ + FunctionalState SpreadSpectrum; /*!< Spread spectrum activation + This parameter can be set to ENABLE or DISABLE. */ + uint32_t SpreadSpectrumDeviation; /*!< Spread spectrum deviation + This parameter must be a number between Min_Data = 0 and Max_Data = 127 */ + uint32_t SpreadSpectrumPrescaler; /*!< Spread spectrum prescaler + This parameter can be a value of @ref TSC_SpreadSpec_Prescaler */ + uint32_t PulseGeneratorPrescaler; /*!< Pulse generator prescaler + This parameter can be a value of @ref TSC_PulseGenerator_Prescaler */ + uint32_t MaxCountValue; /*!< Max count value + This parameter can be a value of @ref TSC_MaxCount_Value */ + uint32_t IODefaultMode; /*!< IO default mode + This parameter can be a value of @ref TSC_IO_Default_Mode */ + uint32_t SynchroPinPolarity; /*!< Synchro pin polarity + This parameter can be a value of @ref TSC_Synchro_Pin_Polarity */ + uint32_t AcquisitionMode; /*!< Acquisition mode + This parameter can be a value of @ref TSC_Acquisition_Mode */ + FunctionalState MaxCountInterrupt;/*!< Max count interrupt activation + This parameter can be set to ENABLE or DISABLE. */ + uint32_t ChannelIOs; /*!< Channel IOs mask */ + uint32_t ShieldIOs; /*!< Shield IOs mask */ + uint32_t SamplingIOs; /*!< Sampling IOs mask */ +} TSC_InitTypeDef; + +/** + * @brief TSC IOs configuration structure definition + */ +typedef struct +{ + uint32_t ChannelIOs; /*!< Channel IOs mask */ + uint32_t ShieldIOs; /*!< Shield IOs mask */ + uint32_t SamplingIOs; /*!< Sampling IOs mask */ +} TSC_IOConfigTypeDef; + +/** + * @brief TSC handle Structure definition + */ +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) +typedef struct __TSC_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ +{ + TSC_TypeDef *Instance; /*!< Register base address */ + TSC_InitTypeDef Init; /*!< Initialization parameters */ + __IO HAL_TSC_StateTypeDef State; /*!< Peripheral state */ + HAL_LockTypeDef Lock; /*!< Lock feature */ + __IO uint32_t ErrorCode; /*!< TSC Error code */ + +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) + void (* ConvCpltCallback)(struct __TSC_HandleTypeDef *htsc); /*!< TSC Conversion complete callback */ + void (* ErrorCallback)(struct __TSC_HandleTypeDef *htsc); /*!< TSC Error callback */ + + void (* MspInitCallback)(struct __TSC_HandleTypeDef *htsc); /*!< TSC Msp Init callback */ + void (* MspDeInitCallback)(struct __TSC_HandleTypeDef *htsc); /*!< TSC Msp DeInit callback */ + +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ +} TSC_HandleTypeDef; + +enum +{ + TSC_GROUP1_IDX = 0x00UL, + TSC_GROUP2_IDX, + TSC_GROUP3_IDX, + TSC_GROUP4_IDX, + TSC_GROUP5_IDX, + TSC_GROUP6_IDX, + TSC_GROUP7_IDX, + TSC_GROUP8_IDX, + TSC_NB_OF_GROUPS +}; + +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) +/** + * @brief HAL TSC Callback ID enumeration definition + */ +typedef enum +{ + HAL_TSC_CONV_COMPLETE_CB_ID = 0x00UL, /*!< TSC Conversion completed callback ID */ + HAL_TSC_ERROR_CB_ID = 0x01UL, /*!< TSC Error callback ID */ + + HAL_TSC_MSPINIT_CB_ID = 0x02UL, /*!< TSC Msp Init callback ID */ + HAL_TSC_MSPDEINIT_CB_ID = 0x03UL /*!< TSC Msp DeInit callback ID */ + +} HAL_TSC_CallbackIDTypeDef; + +/** + * @brief HAL TSC Callback pointer definition + */ +typedef void (*pTSC_CallbackTypeDef)(TSC_HandleTypeDef *htsc); /*!< pointer to an TSC callback function */ + +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup TSC_Exported_Constants TSC Exported Constants + * @{ + */ + +/** @defgroup TSC_Error_Code_definition TSC Error Code definition + * @brief TSC Error Code definition + * @{ + */ +#define HAL_TSC_ERROR_NONE 0x00000000UL /*!< No error */ +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) +#define HAL_TSC_ERROR_INVALID_CALLBACK 0x00000001UL /*!< Invalid Callback error */ +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup TSC_CTPulseHL_Config CTPulse High Length + * @{ + */ +#define TSC_CTPH_1CYCLE 0x00000000UL /*!< Charge transfer pulse high during 1 cycle (PGCLK) */ +#define TSC_CTPH_2CYCLES TSC_CR_CTPH_0 /*!< Charge transfer pulse high during 2 cycles (PGCLK) */ +#define TSC_CTPH_3CYCLES TSC_CR_CTPH_1 /*!< Charge transfer pulse high during 3 cycles (PGCLK) */ +#define TSC_CTPH_4CYCLES (TSC_CR_CTPH_1 | TSC_CR_CTPH_0) /*!< Charge transfer pulse high during 4 cycles (PGCLK) */ +#define TSC_CTPH_5CYCLES TSC_CR_CTPH_2 /*!< Charge transfer pulse high during 5 cycles (PGCLK) */ +#define TSC_CTPH_6CYCLES (TSC_CR_CTPH_2 | TSC_CR_CTPH_0) /*!< Charge transfer pulse high during 6 cycles (PGCLK) */ +#define TSC_CTPH_7CYCLES (TSC_CR_CTPH_2 | TSC_CR_CTPH_1) /*!< Charge transfer pulse high during 7 cycles (PGCLK) */ +#define TSC_CTPH_8CYCLES (TSC_CR_CTPH_2 | TSC_CR_CTPH_1 | TSC_CR_CTPH_0) /*!< Charge transfer pulse high during 8 cycles (PGCLK) */ +#define TSC_CTPH_9CYCLES TSC_CR_CTPH_3 /*!< Charge transfer pulse high during 9 cycles (PGCLK) */ +#define TSC_CTPH_10CYCLES (TSC_CR_CTPH_3 | TSC_CR_CTPH_0) /*!< Charge transfer pulse high during 10 cycles (PGCLK) */ +#define TSC_CTPH_11CYCLES (TSC_CR_CTPH_3 | TSC_CR_CTPH_1) /*!< Charge transfer pulse high during 11 cycles (PGCLK) */ +#define TSC_CTPH_12CYCLES (TSC_CR_CTPH_3 | TSC_CR_CTPH_1 | TSC_CR_CTPH_0) /*!< Charge transfer pulse high during 12 cycles (PGCLK) */ +#define TSC_CTPH_13CYCLES (TSC_CR_CTPH_3 | TSC_CR_CTPH_2) /*!< Charge transfer pulse high during 13 cycles (PGCLK) */ +#define TSC_CTPH_14CYCLES (TSC_CR_CTPH_3 | TSC_CR_CTPH_2 | TSC_CR_CTPH_0) /*!< Charge transfer pulse high during 14 cycles (PGCLK) */ +#define TSC_CTPH_15CYCLES (TSC_CR_CTPH_3 | TSC_CR_CTPH_2 | TSC_CR_CTPH_1) /*!< Charge transfer pulse high during 15 cycles (PGCLK) */ +#define TSC_CTPH_16CYCLES (TSC_CR_CTPH_3 | TSC_CR_CTPH_2 | TSC_CR_CTPH_1 | TSC_CR_CTPH_0) /*!< Charge transfer pulse high during 16 cycles (PGCLK) */ +/** + * @} + */ + +/** @defgroup TSC_CTPulseLL_Config CTPulse Low Length + * @{ + */ +#define TSC_CTPL_1CYCLE 0x00000000UL /*!< Charge transfer pulse low during 1 cycle (PGCLK) */ +#define TSC_CTPL_2CYCLES TSC_CR_CTPL_0 /*!< Charge transfer pulse low during 2 cycles (PGCLK) */ +#define TSC_CTPL_3CYCLES TSC_CR_CTPL_1 /*!< Charge transfer pulse low during 3 cycles (PGCLK) */ +#define TSC_CTPL_4CYCLES (TSC_CR_CTPL_1 | TSC_CR_CTPL_0) /*!< Charge transfer pulse low during 4 cycles (PGCLK) */ +#define TSC_CTPL_5CYCLES TSC_CR_CTPL_2 /*!< Charge transfer pulse low during 5 cycles (PGCLK) */ +#define TSC_CTPL_6CYCLES (TSC_CR_CTPL_2 | TSC_CR_CTPL_0) /*!< Charge transfer pulse low during 6 cycles (PGCLK) */ +#define TSC_CTPL_7CYCLES (TSC_CR_CTPL_2 | TSC_CR_CTPL_1) /*!< Charge transfer pulse low during 7 cycles (PGCLK) */ +#define TSC_CTPL_8CYCLES (TSC_CR_CTPL_2 | TSC_CR_CTPL_1 | TSC_CR_CTPL_0) /*!< Charge transfer pulse low during 8 cycles (PGCLK) */ +#define TSC_CTPL_9CYCLES TSC_CR_CTPL_3 /*!< Charge transfer pulse low during 9 cycles (PGCLK) */ +#define TSC_CTPL_10CYCLES (TSC_CR_CTPL_3 | TSC_CR_CTPL_0) /*!< Charge transfer pulse low during 10 cycles (PGCLK) */ +#define TSC_CTPL_11CYCLES (TSC_CR_CTPL_3 | TSC_CR_CTPL_1) /*!< Charge transfer pulse low during 11 cycles (PGCLK) */ +#define TSC_CTPL_12CYCLES (TSC_CR_CTPL_3 | TSC_CR_CTPL_1 | TSC_CR_CTPL_0) /*!< Charge transfer pulse low during 12 cycles (PGCLK) */ +#define TSC_CTPL_13CYCLES (TSC_CR_CTPL_3 | TSC_CR_CTPL_2) /*!< Charge transfer pulse low during 13 cycles (PGCLK) */ +#define TSC_CTPL_14CYCLES (TSC_CR_CTPL_3 | TSC_CR_CTPL_2 | TSC_CR_CTPL_0) /*!< Charge transfer pulse low during 14 cycles (PGCLK) */ +#define TSC_CTPL_15CYCLES (TSC_CR_CTPL_3 | TSC_CR_CTPL_2 | TSC_CR_CTPL_1) /*!< Charge transfer pulse low during 15 cycles (PGCLK) */ +#define TSC_CTPL_16CYCLES (TSC_CR_CTPL_3 | TSC_CR_CTPL_2 | TSC_CR_CTPL_1 | TSC_CR_CTPL_0) /*!< Charge transfer pulse low during 16 cycles (PGCLK) */ +/** + * @} + */ + +/** @defgroup TSC_SpreadSpec_Prescaler Spread Spectrum Prescaler + * @{ + */ +#define TSC_SS_PRESC_DIV1 0x00000000UL /*!< Spread Spectrum Prescaler Div1 */ +#define TSC_SS_PRESC_DIV2 TSC_CR_SSPSC /*!< Spread Spectrum Prescaler Div2 */ +/** + * @} + */ + +/** @defgroup TSC_PulseGenerator_Prescaler Pulse Generator Prescaler + * @{ + */ +#define TSC_PG_PRESC_DIV1 0x00000000UL /*!< Pulse Generator HCLK Div1 */ +#define TSC_PG_PRESC_DIV2 TSC_CR_PGPSC_0 /*!< Pulse Generator HCLK Div2 */ +#define TSC_PG_PRESC_DIV4 TSC_CR_PGPSC_1 /*!< Pulse Generator HCLK Div4 */ +#define TSC_PG_PRESC_DIV8 (TSC_CR_PGPSC_1 | TSC_CR_PGPSC_0) /*!< Pulse Generator HCLK Div8 */ +#define TSC_PG_PRESC_DIV16 TSC_CR_PGPSC_2 /*!< Pulse Generator HCLK Div16 */ +#define TSC_PG_PRESC_DIV32 (TSC_CR_PGPSC_2 | TSC_CR_PGPSC_0) /*!< Pulse Generator HCLK Div32 */ +#define TSC_PG_PRESC_DIV64 (TSC_CR_PGPSC_2 | TSC_CR_PGPSC_1) /*!< Pulse Generator HCLK Div64 */ +#define TSC_PG_PRESC_DIV128 (TSC_CR_PGPSC_2 | TSC_CR_PGPSC_1 | TSC_CR_PGPSC_0) /*!< Pulse Generator HCLK Div128 */ +/** + * @} + */ + +/** @defgroup TSC_MaxCount_Value Max Count Value + * @{ + */ +#define TSC_MCV_255 0x00000000UL /*!< 255 maximum number of charge transfer pulses */ +#define TSC_MCV_511 TSC_CR_MCV_0 /*!< 511 maximum number of charge transfer pulses */ +#define TSC_MCV_1023 TSC_CR_MCV_1 /*!< 1023 maximum number of charge transfer pulses */ +#define TSC_MCV_2047 (TSC_CR_MCV_1 | TSC_CR_MCV_0) /*!< 2047 maximum number of charge transfer pulses */ +#define TSC_MCV_4095 TSC_CR_MCV_2 /*!< 4095 maximum number of charge transfer pulses */ +#define TSC_MCV_8191 (TSC_CR_MCV_2 | TSC_CR_MCV_0) /*!< 8191 maximum number of charge transfer pulses */ +#define TSC_MCV_16383 (TSC_CR_MCV_2 | TSC_CR_MCV_1) /*!< 16383 maximum number of charge transfer pulses */ +/** + * @} + */ + +/** @defgroup TSC_IO_Default_Mode IO Default Mode + * @{ + */ +#define TSC_IODEF_OUT_PP_LOW 0x00000000UL /*!< I/Os are forced to output push-pull low */ +#define TSC_IODEF_IN_FLOAT TSC_CR_IODEF /*!< I/Os are in input floating */ +/** + * @} + */ + +/** @defgroup TSC_Synchro_Pin_Polarity Synchro Pin Polarity + * @{ + */ +#define TSC_SYNC_POLARITY_FALLING 0x00000000UL /*!< Falling edge only */ +#define TSC_SYNC_POLARITY_RISING TSC_CR_SYNCPOL /*!< Rising edge and high level */ +/** + * @} + */ + +/** @defgroup TSC_Acquisition_Mode Acquisition Mode + * @{ + */ +#define TSC_ACQ_MODE_NORMAL 0x00000000UL /*!< Normal acquisition mode (acquisition starts as soon as START bit is set) */ +#define TSC_ACQ_MODE_SYNCHRO TSC_CR_AM /*!< Synchronized acquisition mode (acquisition starts if START bit is set and when the selected signal is detected on the SYNC input pin) */ +/** + * @} + */ + +/** @defgroup TSC_interrupts_definition Interrupts definition + * @{ + */ +#define TSC_IT_EOA TSC_IER_EOAIE /*!< End of acquisition interrupt enable */ +#define TSC_IT_MCE TSC_IER_MCEIE /*!< Max count error interrupt enable */ +/** + * @} + */ + +/** @defgroup TSC_flags_definition Flags definition + * @{ + */ +#define TSC_FLAG_EOA TSC_ISR_EOAF /*!< End of acquisition flag */ +#define TSC_FLAG_MCE TSC_ISR_MCEF /*!< Max count error flag */ +/** + * @} + */ + +/** @defgroup TSC_Group_definition Group definition + * @{ + */ +#define TSC_GROUP1 (0x1UL << TSC_GROUP1_IDX) +#define TSC_GROUP2 (0x1UL << TSC_GROUP2_IDX) +#define TSC_GROUP3 (0x1UL << TSC_GROUP3_IDX) +#define TSC_GROUP4 (0x1UL << TSC_GROUP4_IDX) +#define TSC_GROUP5 (0x1UL << TSC_GROUP5_IDX) +#define TSC_GROUP6 (0x1UL << TSC_GROUP6_IDX) +#define TSC_GROUP7 (0x1UL << TSC_GROUP7_IDX) +#define TSC_GROUP8 (0x1UL << TSC_GROUP8_IDX) + +#define TSC_GROUP1_IO1 TSC_IOCCR_G1_IO1 /*!< TSC Group1 IO1 */ +#define TSC_GROUP1_IO2 TSC_IOCCR_G1_IO2 /*!< TSC Group1 IO2 */ +#define TSC_GROUP1_IO3 TSC_IOCCR_G1_IO3 /*!< TSC Group1 IO3 */ +#define TSC_GROUP1_IO4 TSC_IOCCR_G1_IO4 /*!< TSC Group1 IO4 */ + +#define TSC_GROUP2_IO1 TSC_IOCCR_G2_IO1 /*!< TSC Group2 IO1 */ +#define TSC_GROUP2_IO2 TSC_IOCCR_G2_IO2 /*!< TSC Group2 IO2 */ +#define TSC_GROUP2_IO3 TSC_IOCCR_G2_IO3 /*!< TSC Group2 IO3 */ +#define TSC_GROUP2_IO4 TSC_IOCCR_G2_IO4 /*!< TSC Group2 IO4 */ + +#define TSC_GROUP3_IO1 TSC_IOCCR_G3_IO1 /*!< TSC Group3 IO1 */ +#define TSC_GROUP3_IO2 TSC_IOCCR_G3_IO2 /*!< TSC Group3 IO2 */ +#define TSC_GROUP3_IO3 TSC_IOCCR_G3_IO3 /*!< TSC Group3 IO3 */ +#define TSC_GROUP3_IO4 TSC_IOCCR_G3_IO4 /*!< TSC Group3 IO4 */ + +#define TSC_GROUP4_IO1 TSC_IOCCR_G4_IO1 /*!< TSC Group4 IO1 */ +#define TSC_GROUP4_IO2 TSC_IOCCR_G4_IO2 /*!< TSC Group4 IO2 */ +#define TSC_GROUP4_IO3 TSC_IOCCR_G4_IO3 /*!< TSC Group4 IO3 */ +#define TSC_GROUP4_IO4 TSC_IOCCR_G4_IO4 /*!< TSC Group4 IO4 */ + +#define TSC_GROUP5_IO1 TSC_IOCCR_G5_IO1 /*!< TSC Group5 IO1 */ +#define TSC_GROUP5_IO2 TSC_IOCCR_G5_IO2 /*!< TSC Group5 IO2 */ +#define TSC_GROUP5_IO3 TSC_IOCCR_G5_IO3 /*!< TSC Group5 IO3 */ +#define TSC_GROUP5_IO4 TSC_IOCCR_G5_IO4 /*!< TSC Group5 IO4 */ + +#define TSC_GROUP6_IO1 TSC_IOCCR_G6_IO1 /*!< TSC Group6 IO1 */ +#define TSC_GROUP6_IO2 TSC_IOCCR_G6_IO2 /*!< TSC Group6 IO2 */ +#define TSC_GROUP6_IO3 TSC_IOCCR_G6_IO3 /*!< TSC Group6 IO3 */ +#define TSC_GROUP6_IO4 TSC_IOCCR_G6_IO4 /*!< TSC Group6 IO4 */ + +#define TSC_GROUP7_IO1 TSC_IOCCR_G7_IO1 /*!< TSC Group7 IO1 */ +#define TSC_GROUP7_IO2 TSC_IOCCR_G7_IO2 /*!< TSC Group7 IO2 */ +#define TSC_GROUP7_IO3 TSC_IOCCR_G7_IO3 /*!< TSC Group7 IO3 */ +#define TSC_GROUP7_IO4 TSC_IOCCR_G7_IO4 /*!< TSC Group7 IO4 */ + +#define TSC_GROUP8_IO1 TSC_IOCCR_G8_IO1 /*!< TSC Group8 IO1 */ +#define TSC_GROUP8_IO2 TSC_IOCCR_G8_IO2 /*!< TSC Group8 IO2 */ +#define TSC_GROUP8_IO3 TSC_IOCCR_G8_IO3 /*!< TSC Group8 IO3 */ +#define TSC_GROUP8_IO4 TSC_IOCCR_G8_IO4 /*!< TSC Group8 IO4 */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ + +/** @defgroup TSC_Exported_Macros TSC Exported Macros + * @{ + */ + +/** @brief Reset TSC handle state. + * @param __HANDLE__ TSC handle + * @retval None + */ +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) +#define __HAL_TSC_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_TSC_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_TSC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_TSC_STATE_RESET) +#endif /* (USE_HAL_TSC_REGISTER_CALLBACKS == 1) */ + +/** + * @brief Enable the TSC peripheral. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_TSCE) + +/** + * @brief Disable the TSC peripheral. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= (~TSC_CR_TSCE)) + +/** + * @brief Start acquisition. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_START_ACQ(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_START) + +/** + * @brief Stop acquisition. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_STOP_ACQ(__HANDLE__) ((__HANDLE__)->Instance->CR &= (~TSC_CR_START)) + +/** + * @brief Set IO default mode to output push-pull low. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_SET_IODEF_OUTPPLOW(__HANDLE__) ((__HANDLE__)->Instance->CR &= (~TSC_CR_IODEF)) + +/** + * @brief Set IO default mode to input floating. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_SET_IODEF_INFLOAT(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_IODEF) + +/** + * @brief Set synchronization polarity to falling edge. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_SET_SYNC_POL_FALL(__HANDLE__) ((__HANDLE__)->Instance->CR &= (~TSC_CR_SYNCPOL)) + +/** + * @brief Set synchronization polarity to rising edge and high level. + * @param __HANDLE__ TSC handle + * @retval None + */ +#define __HAL_TSC_SET_SYNC_POL_RISE_HIGH(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_SYNCPOL) + +/** + * @brief Enable TSC interrupt. + * @param __HANDLE__ TSC handle + * @param __INTERRUPT__ TSC interrupt + * @retval None + */ +#define __HAL_TSC_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER |= (__INTERRUPT__)) + +/** + * @brief Disable TSC interrupt. + * @param __HANDLE__ TSC handle + * @param __INTERRUPT__ TSC interrupt + * @retval None + */ +#define __HAL_TSC_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER &= (~(__INTERRUPT__))) + +/** @brief Check whether the specified TSC interrupt source is enabled or not. + * @param __HANDLE__ TSC Handle + * @param __INTERRUPT__ TSC interrupt + * @retval SET or RESET + */ +#define __HAL_TSC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->IER\ + & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET :\ + RESET) + +/** + * @brief Check whether the specified TSC flag is set or not. + * @param __HANDLE__ TSC handle + * @param __FLAG__ TSC flag + * @retval SET or RESET + */ +#define __HAL_TSC_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->ISR\ + & (__FLAG__)) == (__FLAG__)) ? SET : RESET) + +/** + * @brief Clear the TSC's pending flag. + * @param __HANDLE__ TSC handle + * @param __FLAG__ TSC flag + * @retval None + */ +#define __HAL_TSC_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__)) + +/** + * @brief Enable schmitt trigger hysteresis on a group of IOs. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_ENABLE_HYSTERESIS(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOHCR |= (__GX_IOY_MASK__)) + +/** + * @brief Disable schmitt trigger hysteresis on a group of IOs. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_DISABLE_HYSTERESIS(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOHCR\ + &= (~(__GX_IOY_MASK__))) + +/** + * @brief Open analog switch on a group of IOs. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_OPEN_ANALOG_SWITCH(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOASCR\ + &= (~(__GX_IOY_MASK__))) + +/** + * @brief Close analog switch on a group of IOs. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_CLOSE_ANALOG_SWITCH(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOASCR |= (__GX_IOY_MASK__)) + +/** + * @brief Enable a group of IOs in channel mode. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_ENABLE_CHANNEL(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOCCR |= (__GX_IOY_MASK__)) + +/** + * @brief Disable a group of channel IOs. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_DISABLE_CHANNEL(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOCCR\ + &= (~(__GX_IOY_MASK__))) + +/** + * @brief Enable a group of IOs in sampling mode. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_ENABLE_SAMPLING(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOSCR |= (__GX_IOY_MASK__)) + +/** + * @brief Disable a group of sampling IOs. + * @param __HANDLE__ TSC handle + * @param __GX_IOY_MASK__ IOs mask + * @retval None + */ +#define __HAL_TSC_DISABLE_SAMPLING(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOSCR &= (~(__GX_IOY_MASK__))) + +/** + * @brief Enable acquisition groups. + * @param __HANDLE__ TSC handle + * @param __GX_MASK__ Groups mask + * @retval None + */ +#define __HAL_TSC_ENABLE_GROUP(__HANDLE__, __GX_MASK__) ((__HANDLE__)->Instance->IOGCSR |= (__GX_MASK__)) + +/** + * @brief Disable acquisition groups. + * @param __HANDLE__ TSC handle + * @param __GX_MASK__ Groups mask + * @retval None + */ +#define __HAL_TSC_DISABLE_GROUP(__HANDLE__, __GX_MASK__) ((__HANDLE__)->Instance->IOGCSR &= (~(__GX_MASK__))) + +/** @brief Gets acquisition group status. + * @param __HANDLE__ TSC Handle + * @param __GX_INDEX__ Group index + * @retval SET or RESET + */ +#define __HAL_TSC_GET_GROUP_STATUS(__HANDLE__, __GX_INDEX__) \ + ((((__HANDLE__)->Instance->IOGCSR & (uint32_t)(1UL << (((__GX_INDEX__) & 0xFUL) + 16UL))) == \ + (uint32_t)(1UL << (((__GX_INDEX__) & 0xFUL) + 16UL))) ? TSC_GROUP_COMPLETED : TSC_GROUP_ONGOING) + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ + +/** @defgroup TSC_Private_Macros TSC Private Macros + * @{ + */ + +#define IS_TSC_CTPH(__VALUE__) (((__VALUE__) == TSC_CTPH_1CYCLE) || \ + ((__VALUE__) == TSC_CTPH_2CYCLES) || \ + ((__VALUE__) == TSC_CTPH_3CYCLES) || \ + ((__VALUE__) == TSC_CTPH_4CYCLES) || \ + ((__VALUE__) == TSC_CTPH_5CYCLES) || \ + ((__VALUE__) == TSC_CTPH_6CYCLES) || \ + ((__VALUE__) == TSC_CTPH_7CYCLES) || \ + ((__VALUE__) == TSC_CTPH_8CYCLES) || \ + ((__VALUE__) == TSC_CTPH_9CYCLES) || \ + ((__VALUE__) == TSC_CTPH_10CYCLES) || \ + ((__VALUE__) == TSC_CTPH_11CYCLES) || \ + ((__VALUE__) == TSC_CTPH_12CYCLES) || \ + ((__VALUE__) == TSC_CTPH_13CYCLES) || \ + ((__VALUE__) == TSC_CTPH_14CYCLES) || \ + ((__VALUE__) == TSC_CTPH_15CYCLES) || \ + ((__VALUE__) == TSC_CTPH_16CYCLES)) + +#define IS_TSC_CTPL(__VALUE__) (((__VALUE__) == TSC_CTPL_1CYCLE) || \ + ((__VALUE__) == TSC_CTPL_2CYCLES) || \ + ((__VALUE__) == TSC_CTPL_3CYCLES) || \ + ((__VALUE__) == TSC_CTPL_4CYCLES) || \ + ((__VALUE__) == TSC_CTPL_5CYCLES) || \ + ((__VALUE__) == TSC_CTPL_6CYCLES) || \ + ((__VALUE__) == TSC_CTPL_7CYCLES) || \ + ((__VALUE__) == TSC_CTPL_8CYCLES) || \ + ((__VALUE__) == TSC_CTPL_9CYCLES) || \ + ((__VALUE__) == TSC_CTPL_10CYCLES) || \ + ((__VALUE__) == TSC_CTPL_11CYCLES) || \ + ((__VALUE__) == TSC_CTPL_12CYCLES) || \ + ((__VALUE__) == TSC_CTPL_13CYCLES) || \ + ((__VALUE__) == TSC_CTPL_14CYCLES) || \ + ((__VALUE__) == TSC_CTPL_15CYCLES) || \ + ((__VALUE__) == TSC_CTPL_16CYCLES)) + +#define IS_TSC_SS(__VALUE__) (((FunctionalState)(__VALUE__) == DISABLE)\ + || ((FunctionalState)(__VALUE__) == ENABLE)) + +#define IS_TSC_SSD(__VALUE__) (((__VALUE__) == 0UL) || (((__VALUE__) > 0UL) && ((__VALUE__) < 128UL))) + +#define IS_TSC_SS_PRESC(__VALUE__) (((__VALUE__) == TSC_SS_PRESC_DIV1) || ((__VALUE__) == TSC_SS_PRESC_DIV2)) + +#define IS_TSC_PG_PRESC(__VALUE__) (((__VALUE__) == TSC_PG_PRESC_DIV1) || \ + ((__VALUE__) == TSC_PG_PRESC_DIV2) || \ + ((__VALUE__) == TSC_PG_PRESC_DIV4) || \ + ((__VALUE__) == TSC_PG_PRESC_DIV8) || \ + ((__VALUE__) == TSC_PG_PRESC_DIV16) || \ + ((__VALUE__) == TSC_PG_PRESC_DIV32) || \ + ((__VALUE__) == TSC_PG_PRESC_DIV64) || \ + ((__VALUE__) == TSC_PG_PRESC_DIV128)) + +#define IS_TSC_PG_PRESC_VS_CTPL(__PGPSC__, __CTPL__) ((((__PGPSC__) == TSC_PG_PRESC_DIV1) && \ + ((__CTPL__) > TSC_CTPL_2CYCLES)) || \ + (((__PGPSC__) == TSC_PG_PRESC_DIV2) && \ + ((__CTPL__) > TSC_CTPL_1CYCLE)) || \ + (((__PGPSC__) > TSC_PG_PRESC_DIV2) && \ + (((__CTPL__) == TSC_CTPL_1CYCLE) || \ + ((__CTPL__) > TSC_CTPL_1CYCLE)))) + +#define IS_TSC_MCV(__VALUE__) (((__VALUE__) == TSC_MCV_255) || \ + ((__VALUE__) == TSC_MCV_511) || \ + ((__VALUE__) == TSC_MCV_1023) || \ + ((__VALUE__) == TSC_MCV_2047) || \ + ((__VALUE__) == TSC_MCV_4095) || \ + ((__VALUE__) == TSC_MCV_8191) || \ + ((__VALUE__) == TSC_MCV_16383)) + +#define IS_TSC_IODEF(__VALUE__) (((__VALUE__) == TSC_IODEF_OUT_PP_LOW) || ((__VALUE__) == TSC_IODEF_IN_FLOAT)) + +#define IS_TSC_SYNC_POL(__VALUE__) (((__VALUE__) == TSC_SYNC_POLARITY_FALLING)\ + || ((__VALUE__) == TSC_SYNC_POLARITY_RISING)) + +#define IS_TSC_ACQ_MODE(__VALUE__) (((__VALUE__) == TSC_ACQ_MODE_NORMAL) || ((__VALUE__) == TSC_ACQ_MODE_SYNCHRO)) + +#define IS_TSC_MCE_IT(__VALUE__) (((FunctionalState)(__VALUE__) == DISABLE)\ + || ((FunctionalState)(__VALUE__) == ENABLE)) + +#define IS_TSC_GROUP_INDEX(__VALUE__) (((__VALUE__) == 0UL)\ + || (((__VALUE__) > 0UL) && ((__VALUE__) < (uint32_t)TSC_NB_OF_GROUPS))) + +#define IS_TSC_GROUP(__VALUE__) (((__VALUE__) == 0UL) ||\ + (((__VALUE__) & TSC_GROUP1_IO1) == TSC_GROUP1_IO1) ||\ + (((__VALUE__) & TSC_GROUP1_IO2) == TSC_GROUP1_IO2) ||\ + (((__VALUE__) & TSC_GROUP1_IO3) == TSC_GROUP1_IO3) ||\ + (((__VALUE__) & TSC_GROUP1_IO4) == TSC_GROUP1_IO4) ||\ + (((__VALUE__) & TSC_GROUP2_IO1) == TSC_GROUP2_IO1) ||\ + (((__VALUE__) & TSC_GROUP2_IO2) == TSC_GROUP2_IO2) ||\ + (((__VALUE__) & TSC_GROUP2_IO3) == TSC_GROUP2_IO3) ||\ + (((__VALUE__) & TSC_GROUP2_IO4) == TSC_GROUP2_IO4) ||\ + (((__VALUE__) & TSC_GROUP3_IO1) == TSC_GROUP3_IO1) ||\ + (((__VALUE__) & TSC_GROUP3_IO2) == TSC_GROUP3_IO2) ||\ + (((__VALUE__) & TSC_GROUP3_IO3) == TSC_GROUP3_IO3) ||\ + (((__VALUE__) & TSC_GROUP3_IO4) == TSC_GROUP3_IO4) ||\ + (((__VALUE__) & TSC_GROUP4_IO1) == TSC_GROUP4_IO1) ||\ + (((__VALUE__) & TSC_GROUP4_IO2) == TSC_GROUP4_IO2) ||\ + (((__VALUE__) & TSC_GROUP4_IO3) == TSC_GROUP4_IO3) ||\ + (((__VALUE__) & TSC_GROUP4_IO4) == TSC_GROUP4_IO4) ||\ + (((__VALUE__) & TSC_GROUP5_IO1) == TSC_GROUP5_IO1) ||\ + (((__VALUE__) & TSC_GROUP5_IO2) == TSC_GROUP5_IO2) ||\ + (((__VALUE__) & TSC_GROUP5_IO3) == TSC_GROUP5_IO3) ||\ + (((__VALUE__) & TSC_GROUP5_IO4) == TSC_GROUP5_IO4) ||\ + (((__VALUE__) & TSC_GROUP6_IO1) == TSC_GROUP6_IO1) ||\ + (((__VALUE__) & TSC_GROUP6_IO2) == TSC_GROUP6_IO2) ||\ + (((__VALUE__) & TSC_GROUP6_IO3) == TSC_GROUP6_IO3) ||\ + (((__VALUE__) & TSC_GROUP6_IO4) == TSC_GROUP6_IO4) ||\ + (((__VALUE__) & TSC_GROUP7_IO1) == TSC_GROUP7_IO1) ||\ + (((__VALUE__) & TSC_GROUP7_IO2) == TSC_GROUP7_IO2) ||\ + (((__VALUE__) & TSC_GROUP7_IO3) == TSC_GROUP7_IO3) ||\ + (((__VALUE__) & TSC_GROUP7_IO4) == TSC_GROUP7_IO4) ||\ + (((__VALUE__) & TSC_GROUP8_IO1) == TSC_GROUP8_IO1) ||\ + (((__VALUE__) & TSC_GROUP8_IO2) == TSC_GROUP8_IO2) ||\ + (((__VALUE__) & TSC_GROUP8_IO3) == TSC_GROUP8_IO3) ||\ + (((__VALUE__) & TSC_GROUP8_IO4) == TSC_GROUP8_IO4)) +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup TSC_Exported_Functions + * @{ + */ + +/** @addtogroup TSC_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ +/* Initialization and de-initialization functions *****************************/ +HAL_StatusTypeDef HAL_TSC_Init(TSC_HandleTypeDef *htsc); +HAL_StatusTypeDef HAL_TSC_DeInit(TSC_HandleTypeDef *htsc); +void HAL_TSC_MspInit(TSC_HandleTypeDef *htsc); +void HAL_TSC_MspDeInit(TSC_HandleTypeDef *htsc); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_TSC_RegisterCallback(TSC_HandleTypeDef *htsc, HAL_TSC_CallbackIDTypeDef CallbackID, + pTSC_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_TSC_UnRegisterCallback(TSC_HandleTypeDef *htsc, HAL_TSC_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @addtogroup TSC_Exported_Functions_Group2 Input and Output operation functions + * @{ + */ +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_TSC_Start(TSC_HandleTypeDef *htsc); +HAL_StatusTypeDef HAL_TSC_Start_IT(TSC_HandleTypeDef *htsc); +HAL_StatusTypeDef HAL_TSC_Stop(TSC_HandleTypeDef *htsc); +HAL_StatusTypeDef HAL_TSC_Stop_IT(TSC_HandleTypeDef *htsc); +HAL_StatusTypeDef HAL_TSC_PollForAcquisition(TSC_HandleTypeDef *htsc); +TSC_GroupStatusTypeDef HAL_TSC_GroupGetStatus(TSC_HandleTypeDef *htsc, uint32_t gx_index); +uint32_t HAL_TSC_GroupGetValue(TSC_HandleTypeDef *htsc, uint32_t gx_index); +/** + * @} + */ + +/** @addtogroup TSC_Exported_Functions_Group3 Peripheral Control functions + * @{ + */ +/* Peripheral Control functions ***********************************************/ +HAL_StatusTypeDef HAL_TSC_IOConfig(TSC_HandleTypeDef *htsc, TSC_IOConfigTypeDef *config); +HAL_StatusTypeDef HAL_TSC_IODischarge(TSC_HandleTypeDef *htsc, FunctionalState choice); +/** + * @} + */ + +/** @addtogroup TSC_Exported_Functions_Group4 Peripheral State and Errors functions + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +HAL_TSC_StateTypeDef HAL_TSC_GetState(TSC_HandleTypeDef *htsc); +/** + * @} + */ + +/** @addtogroup TSC_IRQ_Handler_and_Callbacks IRQ Handler and Callbacks + * @{ + */ +/******* TSC IRQHandler and Callbacks used in Interrupt mode */ +void HAL_TSC_IRQHandler(TSC_HandleTypeDef *htsc); +void HAL_TSC_ConvCpltCallback(TSC_HandleTypeDef *htsc); +void HAL_TSC_ErrorCallback(TSC_HandleTypeDef *htsc); +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* TSC */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_TSC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart.h new file mode 100644 index 0000000..997911b --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart.h @@ -0,0 +1,1633 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_uart.h + * @author MCD Application Team + * @brief Header file of UART HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_UART_H +#define STM32F0xx_HAL_UART_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup UART + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup UART_Exported_Types UART Exported Types + * @{ + */ + +/** + * @brief UART Init Structure definition + */ +typedef struct +{ + uint32_t BaudRate; /*!< This member configures the UART communication baud rate. + The baud rate register is computed using the following formula: + - If oversampling is 16 or in LIN mode, + Baud Rate Register = ((uart_ker_ck) / ((huart->Init.BaudRate))) + - If oversampling is 8, + Baud Rate Register[15:4] = ((2 * uart_ker_ck) / + ((huart->Init.BaudRate)))[15:4] + Baud Rate Register[3] = 0 + Baud Rate Register[2:0] = (((2 * uart_ker_ck) / + ((huart->Init.BaudRate)))[3:0]) >> 1 + where uart_ker_ck is the UART input clock */ + + uint32_t WordLength; /*!< Specifies the number of data bits transmitted or received in a frame. + This parameter can be a value of @ref UARTEx_Word_Length. */ + + uint32_t StopBits; /*!< Specifies the number of stop bits transmitted. + This parameter can be a value of @ref UART_Stop_Bits. */ + + uint32_t Parity; /*!< Specifies the parity mode. + This parameter can be a value of @ref UART_Parity + @note When parity is enabled, the computed parity is inserted + at the MSB position of the transmitted data (9th bit when + the word length is set to 9 data bits; 8th bit when the + word length is set to 8 data bits). */ + + uint32_t Mode; /*!< Specifies whether the Receive or Transmit mode is enabled or disabled. + This parameter can be a value of @ref UART_Mode. */ + + uint32_t HwFlowCtl; /*!< Specifies whether the hardware flow control mode is enabled + or disabled. + This parameter can be a value of @ref UART_Hardware_Flow_Control. */ + + uint32_t OverSampling; /*!< Specifies whether the Over sampling 8 is enabled or disabled, + to achieve higher speed (up to f_PCLK/8). + This parameter can be a value of @ref UART_Over_Sampling. */ + + uint32_t OneBitSampling; /*!< Specifies whether a single sample or three samples' majority vote is selected. + Selecting the single sample method increases the receiver tolerance to clock + deviations. This parameter can be a value of @ref UART_OneBit_Sampling. */ + + +} UART_InitTypeDef; + +/** + * @brief UART Advanced Features initialization structure definition + */ +typedef struct +{ + uint32_t AdvFeatureInit; /*!< Specifies which advanced UART features is initialized. Several + Advanced Features may be initialized at the same time . + This parameter can be a value of + @ref UART_Advanced_Features_Initialization_Type. */ + + uint32_t TxPinLevelInvert; /*!< Specifies whether the TX pin active level is inverted. + This parameter can be a value of @ref UART_Tx_Inv. */ + + uint32_t RxPinLevelInvert; /*!< Specifies whether the RX pin active level is inverted. + This parameter can be a value of @ref UART_Rx_Inv. */ + + uint32_t DataInvert; /*!< Specifies whether data are inverted (positive/direct logic + vs negative/inverted logic). + This parameter can be a value of @ref UART_Data_Inv. */ + + uint32_t Swap; /*!< Specifies whether TX and RX pins are swapped. + This parameter can be a value of @ref UART_Rx_Tx_Swap. */ + + uint32_t OverrunDisable; /*!< Specifies whether the reception overrun detection is disabled. + This parameter can be a value of @ref UART_Overrun_Disable. */ + + uint32_t DMADisableonRxError; /*!< Specifies whether the DMA is disabled in case of reception error. + This parameter can be a value of @ref UART_DMA_Disable_on_Rx_Error. */ + + uint32_t AutoBaudRateEnable; /*!< Specifies whether auto Baud rate detection is enabled. + This parameter can be a value of @ref UART_AutoBaudRate_Enable. */ + + uint32_t AutoBaudRateMode; /*!< If auto Baud rate detection is enabled, specifies how the rate + detection is carried out. + This parameter can be a value of @ref UART_AutoBaud_Rate_Mode. */ + + uint32_t MSBFirst; /*!< Specifies whether MSB is sent first on UART line. + This parameter can be a value of @ref UART_MSB_First. */ +} UART_AdvFeatureInitTypeDef; + +/** + * @brief HAL UART State definition + * @note HAL UART State value is a combination of 2 different substates: + * gState and RxState (see @ref UART_State_Definition). + * - gState contains UART state information related to global Handle management + * and also information related to Tx operations. + * gState value coding follow below described bitmap : + * b7-b6 Error information + * 00 : No Error + * 01 : (Not Used) + * 10 : Timeout + * 11 : Error + * b5 Peripheral initialization status + * 0 : Reset (Peripheral not initialized) + * 1 : Init done (Peripheral initialized. HAL UART Init function already called) + * b4-b3 (not used) + * xx : Should be set to 00 + * b2 Intrinsic process state + * 0 : Ready + * 1 : Busy (Peripheral busy with some configuration or internal operations) + * b1 (not used) + * x : Should be set to 0 + * b0 Tx state + * 0 : Ready (no Tx operation ongoing) + * 1 : Busy (Tx operation ongoing) + * - RxState contains information related to Rx operations. + * RxState value coding follow below described bitmap : + * b7-b6 (not used) + * xx : Should be set to 00 + * b5 Peripheral initialization status + * 0 : Reset (Peripheral not initialized) + * 1 : Init done (Peripheral initialized) + * b4-b2 (not used) + * xxx : Should be set to 000 + * b1 Rx state + * 0 : Ready (no Rx operation ongoing) + * 1 : Busy (Rx operation ongoing) + * b0 (not used) + * x : Should be set to 0. + */ +typedef uint32_t HAL_UART_StateTypeDef; + +/** + * @brief UART clock sources definition + */ +typedef enum +{ + UART_CLOCKSOURCE_PCLK1 = 0x00U, /*!< PCLK1 clock source */ + UART_CLOCKSOURCE_HSI = 0x02U, /*!< HSI clock source */ + UART_CLOCKSOURCE_SYSCLK = 0x04U, /*!< SYSCLK clock source */ + UART_CLOCKSOURCE_LSE = 0x08U, /*!< LSE clock source */ + UART_CLOCKSOURCE_UNDEFINED = 0x10U /*!< Undefined clock source */ +} UART_ClockSourceTypeDef; + +/** + * @brief HAL UART Reception type definition + * @note HAL UART Reception type value aims to identify which type of Reception is ongoing. + * It is expected to admit following values : + * HAL_UART_RECEPTION_STANDARD = 0x00U, + * HAL_UART_RECEPTION_TOIDLE = 0x01U, + * HAL_UART_RECEPTION_TORTO = 0x02U, + * HAL_UART_RECEPTION_TOCHARMATCH = 0x03U, + */ +typedef uint32_t HAL_UART_RxTypeTypeDef; + +/** + * @brief UART handle Structure definition + */ +typedef struct __UART_HandleTypeDef +{ + USART_TypeDef *Instance; /*!< UART registers base address */ + + UART_InitTypeDef Init; /*!< UART communication parameters */ + + UART_AdvFeatureInitTypeDef AdvancedInit; /*!< UART Advanced Features initialization parameters */ + + uint8_t *pTxBuffPtr; /*!< Pointer to UART Tx transfer Buffer */ + + uint16_t TxXferSize; /*!< UART Tx Transfer size */ + + __IO uint16_t TxXferCount; /*!< UART Tx Transfer Counter */ + + uint8_t *pRxBuffPtr; /*!< Pointer to UART Rx transfer Buffer */ + + uint16_t RxXferSize; /*!< UART Rx Transfer size */ + + __IO uint16_t RxXferCount; /*!< UART Rx Transfer Counter */ + + uint16_t Mask; /*!< UART Rx RDR register mask */ + + __IO HAL_UART_RxTypeTypeDef ReceptionType; /*!< Type of ongoing reception */ + + void (*RxISR)(struct __UART_HandleTypeDef *huart); /*!< Function pointer on Rx IRQ handler */ + + void (*TxISR)(struct __UART_HandleTypeDef *huart); /*!< Function pointer on Tx IRQ handler */ + + DMA_HandleTypeDef *hdmatx; /*!< UART Tx DMA Handle parameters */ + + DMA_HandleTypeDef *hdmarx; /*!< UART Rx DMA Handle parameters */ + + HAL_LockTypeDef Lock; /*!< Locking object */ + + __IO HAL_UART_StateTypeDef gState; /*!< UART state information related to global Handle management + and also related to Tx operations. This parameter + can be a value of @ref HAL_UART_StateTypeDef */ + + __IO HAL_UART_StateTypeDef RxState; /*!< UART state information related to Rx operations. This + parameter can be a value of @ref HAL_UART_StateTypeDef */ + + __IO uint32_t ErrorCode; /*!< UART Error code */ + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + void (* TxHalfCpltCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Tx Half Complete Callback */ + void (* TxCpltCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Tx Complete Callback */ + void (* RxHalfCpltCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Rx Half Complete Callback */ + void (* RxCpltCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Rx Complete Callback */ + void (* ErrorCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Error Callback */ + void (* AbortCpltCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Abort Complete Callback */ + void (* AbortTransmitCpltCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Abort Transmit Complete Callback */ + void (* AbortReceiveCpltCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Abort Receive Complete Callback */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + void (* WakeupCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Wakeup Callback */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + void (* RxEventCallback)(struct __UART_HandleTypeDef *huart, uint16_t Pos); /*!< UART Reception Event Callback */ + + void (* MspInitCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Msp Init callback */ + void (* MspDeInitCallback)(struct __UART_HandleTypeDef *huart); /*!< UART Msp DeInit callback */ +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + +} UART_HandleTypeDef; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) +/** + * @brief HAL UART Callback ID enumeration definition + */ +typedef enum +{ + HAL_UART_TX_HALFCOMPLETE_CB_ID = 0x00U, /*!< UART Tx Half Complete Callback ID */ + HAL_UART_TX_COMPLETE_CB_ID = 0x01U, /*!< UART Tx Complete Callback ID */ + HAL_UART_RX_HALFCOMPLETE_CB_ID = 0x02U, /*!< UART Rx Half Complete Callback ID */ + HAL_UART_RX_COMPLETE_CB_ID = 0x03U, /*!< UART Rx Complete Callback ID */ + HAL_UART_ERROR_CB_ID = 0x04U, /*!< UART Error Callback ID */ + HAL_UART_ABORT_COMPLETE_CB_ID = 0x05U, /*!< UART Abort Complete Callback ID */ + HAL_UART_ABORT_TRANSMIT_COMPLETE_CB_ID = 0x06U, /*!< UART Abort Transmit Complete Callback ID */ + HAL_UART_ABORT_RECEIVE_COMPLETE_CB_ID = 0x07U, /*!< UART Abort Receive Complete Callback ID */ + HAL_UART_WAKEUP_CB_ID = 0x08U, /*!< UART Wakeup Callback ID */ + + HAL_UART_MSPINIT_CB_ID = 0x0BU, /*!< UART MspInit callback ID */ + HAL_UART_MSPDEINIT_CB_ID = 0x0CU /*!< UART MspDeInit callback ID */ + +} HAL_UART_CallbackIDTypeDef; + +/** + * @brief HAL UART Callback pointer definition + */ +typedef void (*pUART_CallbackTypeDef)(UART_HandleTypeDef *huart); /*!< pointer to an UART callback function */ +typedef void (*pUART_RxEventCallbackTypeDef) +(struct __UART_HandleTypeDef *huart, uint16_t Pos); /*!< pointer to a UART Rx Event specific callback function */ + +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup UART_Exported_Constants UART Exported Constants + * @{ + */ + +/** @defgroup UART_State_Definition UART State Code Definition + * @{ + */ +#define HAL_UART_STATE_RESET 0x00000000U /*!< Peripheral is not initialized + Value is allowed for gState and RxState */ +#define HAL_UART_STATE_READY 0x00000020U /*!< Peripheral Initialized and ready for use + Value is allowed for gState and RxState */ +#define HAL_UART_STATE_BUSY 0x00000024U /*!< an internal process is ongoing + Value is allowed for gState only */ +#define HAL_UART_STATE_BUSY_TX 0x00000021U /*!< Data Transmission process is ongoing + Value is allowed for gState only */ +#define HAL_UART_STATE_BUSY_RX 0x00000022U /*!< Data Reception process is ongoing + Value is allowed for RxState only */ +#define HAL_UART_STATE_BUSY_TX_RX 0x00000023U /*!< Data Transmission and Reception process is ongoing + Not to be used for neither gState nor RxState.Value is result + of combination (Or) between gState and RxState values */ +#define HAL_UART_STATE_TIMEOUT 0x000000A0U /*!< Timeout state + Value is allowed for gState only */ +#define HAL_UART_STATE_ERROR 0x000000E0U /*!< Error + Value is allowed for gState only */ +/** + * @} + */ + +/** @defgroup UART_Error_Definition UART Error Definition + * @{ + */ +#define HAL_UART_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_UART_ERROR_PE (0x00000001U) /*!< Parity error */ +#define HAL_UART_ERROR_NE (0x00000002U) /*!< Noise error */ +#define HAL_UART_ERROR_FE (0x00000004U) /*!< Frame error */ +#define HAL_UART_ERROR_ORE (0x00000008U) /*!< Overrun error */ +#define HAL_UART_ERROR_DMA (0x00000010U) /*!< DMA transfer error */ +#define HAL_UART_ERROR_RTO (0x00000020U) /*!< Receiver Timeout error */ + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) +#define HAL_UART_ERROR_INVALID_CALLBACK (0x00000040U) /*!< Invalid Callback error */ +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup UART_Stop_Bits UART Number of Stop Bits + * @{ + */ +#define UART_STOPBITS_0_5 USART_CR2_STOP_0 /*!< UART frame with 0.5 stop bit */ +#define UART_STOPBITS_1 0x00000000U /*!< UART frame with 1 stop bit */ +#define UART_STOPBITS_1_5 (USART_CR2_STOP_0 | USART_CR2_STOP_1) /*!< UART frame with 1.5 stop bits */ +#define UART_STOPBITS_2 USART_CR2_STOP_1 /*!< UART frame with 2 stop bits */ +/** + * @} + */ + +/** @defgroup UART_Parity UART Parity + * @{ + */ +#define UART_PARITY_NONE 0x00000000U /*!< No parity */ +#define UART_PARITY_EVEN USART_CR1_PCE /*!< Even parity */ +#define UART_PARITY_ODD (USART_CR1_PCE | USART_CR1_PS) /*!< Odd parity */ +/** + * @} + */ + +/** @defgroup UART_Hardware_Flow_Control UART Hardware Flow Control + * @{ + */ +#define UART_HWCONTROL_NONE 0x00000000U /*!< No hardware control */ +#define UART_HWCONTROL_RTS USART_CR3_RTSE /*!< Request To Send */ +#define UART_HWCONTROL_CTS USART_CR3_CTSE /*!< Clear To Send */ +#define UART_HWCONTROL_RTS_CTS (USART_CR3_RTSE | USART_CR3_CTSE) /*!< Request and Clear To Send */ +/** + * @} + */ + +/** @defgroup UART_Mode UART Transfer Mode + * @{ + */ +#define UART_MODE_RX USART_CR1_RE /*!< RX mode */ +#define UART_MODE_TX USART_CR1_TE /*!< TX mode */ +#define UART_MODE_TX_RX (USART_CR1_TE |USART_CR1_RE) /*!< RX and TX mode */ +/** + * @} + */ + +/** @defgroup UART_State UART State + * @{ + */ +#define UART_STATE_DISABLE 0x00000000U /*!< UART disabled */ +#define UART_STATE_ENABLE USART_CR1_UE /*!< UART enabled */ +/** + * @} + */ + +/** @defgroup UART_Over_Sampling UART Over Sampling + * @{ + */ +#define UART_OVERSAMPLING_16 0x00000000U /*!< Oversampling by 16 */ +#define UART_OVERSAMPLING_8 USART_CR1_OVER8 /*!< Oversampling by 8 */ +/** + * @} + */ + +/** @defgroup UART_OneBit_Sampling UART One Bit Sampling Method + * @{ + */ +#define UART_ONE_BIT_SAMPLE_DISABLE 0x00000000U /*!< One-bit sampling disable */ +#define UART_ONE_BIT_SAMPLE_ENABLE USART_CR3_ONEBIT /*!< One-bit sampling enable */ +/** + * @} + */ + +/** @defgroup UART_AutoBaud_Rate_Mode UART Advanced Feature AutoBaud Rate Mode + * @{ + */ +#define UART_ADVFEATURE_AUTOBAUDRATE_ONSTARTBIT 0x00000000U /*!< Auto Baud rate detection + on start bit */ +#define UART_ADVFEATURE_AUTOBAUDRATE_ONFALLINGEDGE USART_CR2_ABRMODE_0 /*!< Auto Baud rate detection + on falling edge */ +#define UART_ADVFEATURE_AUTOBAUDRATE_ON0X7FFRAME USART_CR2_ABRMODE_1 /*!< Auto Baud rate detection + on 0x7F frame detection */ +#define UART_ADVFEATURE_AUTOBAUDRATE_ON0X55FRAME USART_CR2_ABRMODE /*!< Auto Baud rate detection + on 0x55 frame detection */ +/** + * @} + */ + +/** @defgroup UART_Receiver_Timeout UART Receiver Timeout + * @{ + */ +#define UART_RECEIVER_TIMEOUT_DISABLE 0x00000000U /*!< UART Receiver Timeout disable */ +#define UART_RECEIVER_TIMEOUT_ENABLE USART_CR2_RTOEN /*!< UART Receiver Timeout enable */ +/** + * @} + */ + +/** @defgroup UART_LIN UART Local Interconnection Network mode + * @{ + */ +#define UART_LIN_DISABLE 0x00000000U /*!< Local Interconnect Network disable */ +#define UART_LIN_ENABLE USART_CR2_LINEN /*!< Local Interconnect Network enable */ +/** + * @} + */ + +/** @defgroup UART_LIN_Break_Detection UART LIN Break Detection + * @{ + */ +#define UART_LINBREAKDETECTLENGTH_10B 0x00000000U /*!< LIN 10-bit break detection length */ +#define UART_LINBREAKDETECTLENGTH_11B USART_CR2_LBDL /*!< LIN 11-bit break detection length */ +/** + * @} + */ + +/** @defgroup UART_DMA_Tx UART DMA Tx + * @{ + */ +#define UART_DMA_TX_DISABLE 0x00000000U /*!< UART DMA TX disabled */ +#define UART_DMA_TX_ENABLE USART_CR3_DMAT /*!< UART DMA TX enabled */ +/** + * @} + */ + +/** @defgroup UART_DMA_Rx UART DMA Rx + * @{ + */ +#define UART_DMA_RX_DISABLE 0x00000000U /*!< UART DMA RX disabled */ +#define UART_DMA_RX_ENABLE USART_CR3_DMAR /*!< UART DMA RX enabled */ +/** + * @} + */ + +/** @defgroup UART_Half_Duplex_Selection UART Half Duplex Selection + * @{ + */ +#define UART_HALF_DUPLEX_DISABLE 0x00000000U /*!< UART half-duplex disabled */ +#define UART_HALF_DUPLEX_ENABLE USART_CR3_HDSEL /*!< UART half-duplex enabled */ +/** + * @} + */ + +/** @defgroup UART_WakeUp_Methods UART WakeUp Methods + * @{ + */ +#define UART_WAKEUPMETHOD_IDLELINE 0x00000000U /*!< UART wake-up on idle line */ +#define UART_WAKEUPMETHOD_ADDRESSMARK USART_CR1_WAKE /*!< UART wake-up on address mark */ +/** + * @} + */ + +/** @defgroup UART_Request_Parameters UART Request Parameters + * @{ + */ +#define UART_AUTOBAUD_REQUEST USART_RQR_ABRRQ /*!< Auto-Baud Rate Request */ +#define UART_SENDBREAK_REQUEST USART_RQR_SBKRQ /*!< Send Break Request */ +#define UART_MUTE_MODE_REQUEST USART_RQR_MMRQ /*!< Mute Mode Request */ +#define UART_RXDATA_FLUSH_REQUEST USART_RQR_RXFRQ /*!< Receive Data flush Request */ +#define UART_TXDATA_FLUSH_REQUEST USART_RQR_TXFRQ /*!< Transmit data flush Request */ +/** + * @} + */ + +/** @defgroup UART_Advanced_Features_Initialization_Type UART Advanced Feature Initialization Type + * @{ + */ +#define UART_ADVFEATURE_NO_INIT 0x00000000U /*!< No advanced feature initialization */ +#define UART_ADVFEATURE_TXINVERT_INIT 0x00000001U /*!< TX pin active level inversion */ +#define UART_ADVFEATURE_RXINVERT_INIT 0x00000002U /*!< RX pin active level inversion */ +#define UART_ADVFEATURE_DATAINVERT_INIT 0x00000004U /*!< Binary data inversion */ +#define UART_ADVFEATURE_SWAP_INIT 0x00000008U /*!< TX/RX pins swap */ +#define UART_ADVFEATURE_RXOVERRUNDISABLE_INIT 0x00000010U /*!< RX overrun disable */ +#define UART_ADVFEATURE_DMADISABLEONERROR_INIT 0x00000020U /*!< DMA disable on Reception Error */ +#define UART_ADVFEATURE_AUTOBAUDRATE_INIT 0x00000040U /*!< Auto Baud rate detection initialization */ +#define UART_ADVFEATURE_MSBFIRST_INIT 0x00000080U /*!< Most significant bit sent/received first */ +/** + * @} + */ + +/** @defgroup UART_Tx_Inv UART Advanced Feature TX Pin Active Level Inversion + * @{ + */ +#define UART_ADVFEATURE_TXINV_DISABLE 0x00000000U /*!< TX pin active level inversion disable */ +#define UART_ADVFEATURE_TXINV_ENABLE USART_CR2_TXINV /*!< TX pin active level inversion enable */ +/** + * @} + */ + +/** @defgroup UART_Rx_Inv UART Advanced Feature RX Pin Active Level Inversion + * @{ + */ +#define UART_ADVFEATURE_RXINV_DISABLE 0x00000000U /*!< RX pin active level inversion disable */ +#define UART_ADVFEATURE_RXINV_ENABLE USART_CR2_RXINV /*!< RX pin active level inversion enable */ +/** + * @} + */ + +/** @defgroup UART_Data_Inv UART Advanced Feature Binary Data Inversion + * @{ + */ +#define UART_ADVFEATURE_DATAINV_DISABLE 0x00000000U /*!< Binary data inversion disable */ +#define UART_ADVFEATURE_DATAINV_ENABLE USART_CR2_DATAINV /*!< Binary data inversion enable */ +/** + * @} + */ + +/** @defgroup UART_Rx_Tx_Swap UART Advanced Feature RX TX Pins Swap + * @{ + */ +#define UART_ADVFEATURE_SWAP_DISABLE 0x00000000U /*!< TX/RX pins swap disable */ +#define UART_ADVFEATURE_SWAP_ENABLE USART_CR2_SWAP /*!< TX/RX pins swap enable */ +/** + * @} + */ + +/** @defgroup UART_Overrun_Disable UART Advanced Feature Overrun Disable + * @{ + */ +#define UART_ADVFEATURE_OVERRUN_ENABLE 0x00000000U /*!< RX overrun enable */ +#define UART_ADVFEATURE_OVERRUN_DISABLE USART_CR3_OVRDIS /*!< RX overrun disable */ +/** + * @} + */ + +/** @defgroup UART_AutoBaudRate_Enable UART Advanced Feature Auto BaudRate Enable + * @{ + */ +#define UART_ADVFEATURE_AUTOBAUDRATE_DISABLE 0x00000000U /*!< RX Auto Baud rate detection enable */ +#define UART_ADVFEATURE_AUTOBAUDRATE_ENABLE USART_CR2_ABREN /*!< RX Auto Baud rate detection disable */ +/** + * @} + */ + +/** @defgroup UART_DMA_Disable_on_Rx_Error UART Advanced Feature DMA Disable On Rx Error + * @{ + */ +#define UART_ADVFEATURE_DMA_ENABLEONRXERROR 0x00000000U /*!< DMA enable on Reception Error */ +#define UART_ADVFEATURE_DMA_DISABLEONRXERROR USART_CR3_DDRE /*!< DMA disable on Reception Error */ +/** + * @} + */ + +/** @defgroup UART_MSB_First UART Advanced Feature MSB First + * @{ + */ +#define UART_ADVFEATURE_MSBFIRST_DISABLE 0x00000000U /*!< Most significant bit sent/received + first disable */ +#define UART_ADVFEATURE_MSBFIRST_ENABLE USART_CR2_MSBFIRST /*!< Most significant bit sent/received + first enable */ +/** + * @} + */ +#if defined(USART_CR1_UESM) + +/** @defgroup UART_Stop_Mode_Enable UART Advanced Feature Stop Mode Enable + * @{ + */ +#define UART_ADVFEATURE_STOPMODE_DISABLE 0x00000000U /*!< UART stop mode disable */ +#define UART_ADVFEATURE_STOPMODE_ENABLE USART_CR1_UESM /*!< UART stop mode enable */ +/** + * @} + */ +#endif /* USART_CR1_UESM */ + +/** @defgroup UART_Mute_Mode UART Advanced Feature Mute Mode Enable + * @{ + */ +#define UART_ADVFEATURE_MUTEMODE_DISABLE 0x00000000U /*!< UART mute mode disable */ +#define UART_ADVFEATURE_MUTEMODE_ENABLE USART_CR1_MME /*!< UART mute mode enable */ +/** + * @} + */ + +/** @defgroup UART_CR2_ADDRESS_LSB_POS UART Address-matching LSB Position In CR2 Register + * @{ + */ +#define UART_CR2_ADDRESS_LSB_POS 24U /*!< UART address-matching LSB position in CR2 register */ +/** + * @} + */ +#if defined(USART_CR1_UESM) + +/** @defgroup UART_WakeUp_from_Stop_Selection UART WakeUp From Stop Selection + * @{ + */ +#if defined(USART_CR3_WUS) +#define UART_WAKEUP_ON_ADDRESS 0x00000000U /*!< UART wake-up on address */ +#define UART_WAKEUP_ON_STARTBIT USART_CR3_WUS_1 /*!< UART wake-up on start bit */ +#define UART_WAKEUP_ON_READDATA_NONEMPTY USART_CR3_WUS /*!< UART wake-up on receive data register + not empty or RXFIFO is not empty */ +#else +#define UART_WAKEUP_ON_ADDRESS 0x00000000U /*!< UART wake-up on address */ +#define UART_WAKEUP_ON_READDATA_NONEMPTY 0x00000001U /*!< UART wake-up on receive data register + not empty or RXFIFO is not empty */ +#endif /* USART_CR3_WUS */ +/** + * @} + */ +#endif /* USART_CR1_UESM */ + +/** @defgroup UART_DriverEnable_Polarity UART DriverEnable Polarity + * @{ + */ +#define UART_DE_POLARITY_HIGH 0x00000000U /*!< Driver enable signal is active high */ +#define UART_DE_POLARITY_LOW USART_CR3_DEP /*!< Driver enable signal is active low */ +/** + * @} + */ + +/** @defgroup UART_CR1_DEAT_ADDRESS_LSB_POS UART Driver Enable Assertion Time LSB Position In CR1 Register + * @{ + */ +#define UART_CR1_DEAT_ADDRESS_LSB_POS 21U /*!< UART Driver Enable assertion time LSB + position in CR1 register */ +/** + * @} + */ + +/** @defgroup UART_CR1_DEDT_ADDRESS_LSB_POS UART Driver Enable DeAssertion Time LSB Position In CR1 Register + * @{ + */ +#define UART_CR1_DEDT_ADDRESS_LSB_POS 16U /*!< UART Driver Enable de-assertion time LSB + position in CR1 register */ +/** + * @} + */ + +/** @defgroup UART_Interruption_Mask UART Interruptions Flag Mask + * @{ + */ +#define UART_IT_MASK 0x001FU /*!< UART interruptions flags mask */ +/** + * @} + */ + +/** @defgroup UART_TimeOut_Value UART polling-based communications time-out value + * @{ + */ +#define HAL_UART_TIMEOUT_VALUE 0x1FFFFFFU /*!< UART polling-based communications time-out value */ +/** + * @} + */ + +/** @defgroup UART_Flags UART Status Flags + * Elements values convention: 0xXXXX + * - 0xXXXX : Flag mask in the ISR register + * @{ + */ +#define UART_FLAG_REACK USART_ISR_REACK /*!< UART receive enable acknowledge flag */ +#define UART_FLAG_TEACK USART_ISR_TEACK /*!< UART transmit enable acknowledge flag */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +#define UART_FLAG_WUF USART_ISR_WUF /*!< UART wake-up from stop mode flag */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +#define UART_FLAG_RWU USART_ISR_RWU /*!< UART receiver wake-up from mute mode flag */ +#define UART_FLAG_SBKF USART_ISR_SBKF /*!< UART send break flag */ +#define UART_FLAG_CMF USART_ISR_CMF /*!< UART character match flag */ +#define UART_FLAG_BUSY USART_ISR_BUSY /*!< UART busy flag */ +#define UART_FLAG_ABRF USART_ISR_ABRF /*!< UART auto Baud rate flag */ +#define UART_FLAG_ABRE USART_ISR_ABRE /*!< UART auto Baud rate error */ +#define UART_FLAG_RTOF USART_ISR_RTOF /*!< UART receiver timeout flag */ +#define UART_FLAG_CTS USART_ISR_CTS /*!< UART clear to send flag */ +#define UART_FLAG_CTSIF USART_ISR_CTSIF /*!< UART clear to send interrupt flag */ +#define UART_FLAG_LBDF USART_ISR_LBDF /*!< UART LIN break detection flag */ +#define UART_FLAG_TXE USART_ISR_TXE /*!< UART transmit data register empty */ +#define UART_FLAG_TC USART_ISR_TC /*!< UART transmission complete */ +#define UART_FLAG_RXNE USART_ISR_RXNE /*!< UART read data register not empty */ +#define UART_FLAG_IDLE USART_ISR_IDLE /*!< UART idle flag */ +#define UART_FLAG_ORE USART_ISR_ORE /*!< UART overrun error */ +#define UART_FLAG_NE USART_ISR_NE /*!< UART noise error */ +#define UART_FLAG_FE USART_ISR_FE /*!< UART frame error */ +#define UART_FLAG_PE USART_ISR_PE /*!< UART parity error */ +/** + * @} + */ + +/** @defgroup UART_Interrupt_definition UART Interrupts Definition + * Elements values convention: 000ZZZZZ0XXYYYYYb + * - YYYYY : Interrupt source position in the XX register (5bits) + * - XX : Interrupt source register (2bits) + * - 01: CR1 register + * - 10: CR2 register + * - 11: CR3 register + * - ZZZZZ : Flag position in the ISR register(5bits) + * Elements values convention: 000000000XXYYYYYb + * - YYYYY : Interrupt source position in the XX register (5bits) + * - XX : Interrupt source register (2bits) + * - 01: CR1 register + * - 10: CR2 register + * - 11: CR3 register + * Elements values convention: 0000ZZZZ00000000b + * - ZZZZ : Flag position in the ISR register(4bits) + * @{ + */ +#define UART_IT_PE 0x0028U /*!< UART parity error interruption */ +#define UART_IT_TXE 0x0727U /*!< UART transmit data register empty interruption */ +#define UART_IT_TC 0x0626U /*!< UART transmission complete interruption */ +#define UART_IT_RXNE 0x0525U /*!< UART read data register not empty interruption */ +#define UART_IT_IDLE 0x0424U /*!< UART idle interruption */ +#define UART_IT_LBD 0x0846U /*!< UART LIN break detection interruption */ +#define UART_IT_CTS 0x096AU /*!< UART CTS interruption */ +#define UART_IT_CM 0x112EU /*!< UART character match interruption */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +#define UART_IT_WUF 0x1476U /*!< UART wake-up from stop mode interruption */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +#define UART_IT_RTO 0x0B3AU /*!< UART receiver timeout interruption */ + +#define UART_IT_ERR 0x0060U /*!< UART error interruption */ + +#define UART_IT_ORE 0x0300U /*!< UART overrun error interruption */ +#define UART_IT_NE 0x0200U /*!< UART noise error interruption */ +#define UART_IT_FE 0x0100U /*!< UART frame error interruption */ +/** + * @} + */ + +/** @defgroup UART_IT_CLEAR_Flags UART Interruption Clear Flags + * @{ + */ +#define UART_CLEAR_PEF USART_ICR_PECF /*!< Parity Error Clear Flag */ +#define UART_CLEAR_FEF USART_ICR_FECF /*!< Framing Error Clear Flag */ +#define UART_CLEAR_NEF USART_ICR_NCF /*!< Noise Error detected Clear Flag */ +#define UART_CLEAR_OREF USART_ICR_ORECF /*!< Overrun Error Clear Flag */ +#define UART_CLEAR_IDLEF USART_ICR_IDLECF /*!< IDLE line detected Clear Flag */ +#define UART_CLEAR_TCF USART_ICR_TCCF /*!< Transmission Complete Clear Flag */ +#define UART_CLEAR_LBDF USART_ICR_LBDCF /*!< LIN Break Detection Clear Flag */ +#define UART_CLEAR_CTSF USART_ICR_CTSCF /*!< CTS Interrupt Clear Flag */ +#define UART_CLEAR_CMF USART_ICR_CMCF /*!< Character Match Clear Flag */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +#define UART_CLEAR_WUF USART_ICR_WUCF /*!< Wake Up from stop mode Clear Flag */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +#define UART_CLEAR_RTOF USART_ICR_RTOCF /*!< UART receiver timeout clear flag */ +/** + * @} + */ + +/** @defgroup UART_RECEPTION_TYPE_Values UART Reception type values + * @{ + */ +#define HAL_UART_RECEPTION_STANDARD (0x00000000U) /*!< Standard reception */ +#define HAL_UART_RECEPTION_TOIDLE (0x00000001U) /*!< Reception till completion or IDLE event */ +#define HAL_UART_RECEPTION_TORTO (0x00000002U) /*!< Reception till completion or RTO event */ +#define HAL_UART_RECEPTION_TOCHARMATCH (0x00000003U) /*!< Reception till completion or CM event */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup UART_Exported_Macros UART Exported Macros + * @{ + */ + +/** @brief Reset UART handle states. + * @param __HANDLE__ UART handle. + * @retval None + */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) +#define __HAL_UART_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_UART_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_UART_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0U) +#else +#define __HAL_UART_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_UART_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_UART_STATE_RESET; \ + } while(0U) +#endif /*USE_HAL_UART_REGISTER_CALLBACKS */ + +/** @brief Flush the UART Data registers. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_FLUSH_DRREGISTER(__HANDLE__) \ + do{ \ + SET_BIT((__HANDLE__)->Instance->RQR, UART_RXDATA_FLUSH_REQUEST); \ + SET_BIT((__HANDLE__)->Instance->RQR, UART_TXDATA_FLUSH_REQUEST); \ + } while(0U) + +/** @brief Clear the specified UART pending flag. + * @param __HANDLE__ specifies the UART Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be any combination of the following values: + * @arg @ref UART_CLEAR_PEF Parity Error Clear Flag + * @arg @ref UART_CLEAR_FEF Framing Error Clear Flag + * @arg @ref UART_CLEAR_NEF Noise detected Clear Flag + * @arg @ref UART_CLEAR_OREF Overrun Error Clear Flag + * @arg @ref UART_CLEAR_IDLEF IDLE line detected Clear Flag + * @arg @ref UART_CLEAR_TCF Transmission Complete Clear Flag + * @arg @ref UART_CLEAR_RTOF Receiver Timeout clear flag + * @arg @ref UART_CLEAR_LBDF LIN Break Detection Clear Flag + * @arg @ref UART_CLEAR_CTSF CTS Interrupt Clear Flag + * @arg @ref UART_CLEAR_CMF Character Match Clear Flag +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + * @arg @ref UART_CLEAR_WUF Wake Up from stop mode Clear Flag +#endif +#endif + * @retval None + */ +#define __HAL_UART_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__)) + +/** @brief Clear the UART PE pending flag. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_CLEAR_PEFLAG(__HANDLE__) __HAL_UART_CLEAR_FLAG((__HANDLE__), UART_CLEAR_PEF) + +/** @brief Clear the UART FE pending flag. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_CLEAR_FEFLAG(__HANDLE__) __HAL_UART_CLEAR_FLAG((__HANDLE__), UART_CLEAR_FEF) + +/** @brief Clear the UART NE pending flag. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_CLEAR_NEFLAG(__HANDLE__) __HAL_UART_CLEAR_FLAG((__HANDLE__), UART_CLEAR_NEF) + +/** @brief Clear the UART ORE pending flag. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_CLEAR_OREFLAG(__HANDLE__) __HAL_UART_CLEAR_FLAG((__HANDLE__), UART_CLEAR_OREF) + +/** @brief Clear the UART IDLE pending flag. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_CLEAR_IDLEFLAG(__HANDLE__) __HAL_UART_CLEAR_FLAG((__HANDLE__), UART_CLEAR_IDLEF) + + +/** @brief Check whether the specified UART flag is set or not. + * @param __HANDLE__ specifies the UART Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref UART_FLAG_REACK Receive enable acknowledge flag + * @arg @ref UART_FLAG_TEACK Transmit enable acknowledge flag +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + * @arg @ref UART_FLAG_WUF Wake up from stop mode flag +#endif +#endif + * @arg @ref UART_FLAG_RWU Receiver wake up flag (if the UART in mute mode) + * @arg @ref UART_FLAG_SBKF Send Break flag + * @arg @ref UART_FLAG_CMF Character match flag + * @arg @ref UART_FLAG_BUSY Busy flag + * @arg @ref UART_FLAG_ABRF Auto Baud rate detection flag + * @arg @ref UART_FLAG_ABRE Auto Baud rate detection error flag + * @arg @ref UART_FLAG_CTS CTS Change flag + * @arg @ref UART_FLAG_LBDF LIN Break detection flag + * @arg @ref UART_FLAG_TXE Transmit data register empty flag + * @arg @ref UART_FLAG_TC Transmission Complete flag + * @arg @ref UART_FLAG_RXNE Receive data register not empty flag + * @arg @ref UART_FLAG_RTOF Receiver Timeout flag + * @arg @ref UART_FLAG_IDLE Idle Line detection flag + * @arg @ref UART_FLAG_ORE Overrun Error flag + * @arg @ref UART_FLAG_NE Noise Error flag + * @arg @ref UART_FLAG_FE Framing Error flag + * @arg @ref UART_FLAG_PE Parity Error flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_UART_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->ISR & (__FLAG__)) == (__FLAG__)) + +/** @brief Enable the specified UART interrupt. + * @param __HANDLE__ specifies the UART Handle. + * @param __INTERRUPT__ specifies the UART interrupt source to enable. + * This parameter can be one of the following values: +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + * @arg @ref UART_IT_WUF Wakeup from stop mode interrupt +#endif +#endif + * @arg @ref UART_IT_CM Character match interrupt + * @arg @ref UART_IT_CTS CTS change interrupt + * @arg @ref UART_IT_LBD LIN Break detection interrupt + * @arg @ref UART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref UART_IT_TC Transmission complete interrupt + * @arg @ref UART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref UART_IT_RTO Receive Timeout interrupt + * @arg @ref UART_IT_IDLE Idle line detection interrupt + * @arg @ref UART_IT_PE Parity Error interrupt + * @arg @ref UART_IT_ERR Error interrupt (frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_UART_ENABLE_IT(__HANDLE__, __INTERRUPT__) (\ + ((((uint8_t)(__INTERRUPT__)) >> 5U) == 1U)?\ + ((__HANDLE__)->Instance->CR1 |= (1U <<\ + ((__INTERRUPT__) & UART_IT_MASK))): \ + ((((uint8_t)(__INTERRUPT__)) >> 5U) == 2U)?\ + ((__HANDLE__)->Instance->CR2 |= (1U <<\ + ((__INTERRUPT__) & UART_IT_MASK))): \ + ((__HANDLE__)->Instance->CR3 |= (1U <<\ + ((__INTERRUPT__) & UART_IT_MASK)))) + +/** @brief Disable the specified UART interrupt. + * @param __HANDLE__ specifies the UART Handle. + * @param __INTERRUPT__ specifies the UART interrupt source to disable. + * This parameter can be one of the following values: +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + * @arg @ref UART_IT_WUF Wakeup from stop mode interrupt +#endif +#endif + * @arg @ref UART_IT_CM Character match interrupt + * @arg @ref UART_IT_CTS CTS change interrupt + * @arg @ref UART_IT_LBD LIN Break detection interrupt + * @arg @ref UART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref UART_IT_TC Transmission complete interrupt + * @arg @ref UART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref UART_IT_RTO Receive Timeout interrupt + * @arg @ref UART_IT_IDLE Idle line detection interrupt + * @arg @ref UART_IT_PE Parity Error interrupt + * @arg @ref UART_IT_ERR Error interrupt (Frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_UART_DISABLE_IT(__HANDLE__, __INTERRUPT__) (\ + ((((uint8_t)(__INTERRUPT__)) >> 5U) == 1U)?\ + ((__HANDLE__)->Instance->CR1 &= ~ (1U <<\ + ((__INTERRUPT__) & UART_IT_MASK))): \ + ((((uint8_t)(__INTERRUPT__)) >> 5U) == 2U)?\ + ((__HANDLE__)->Instance->CR2 &= ~ (1U <<\ + ((__INTERRUPT__) & UART_IT_MASK))): \ + ((__HANDLE__)->Instance->CR3 &= ~ (1U <<\ + ((__INTERRUPT__) & UART_IT_MASK)))) + +/** @brief Check whether the specified UART interrupt has occurred or not. + * @param __HANDLE__ specifies the UART Handle. + * @param __INTERRUPT__ specifies the UART interrupt to check. + * This parameter can be one of the following values: +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + * @arg @ref UART_IT_WUF Wakeup from stop mode interrupt +#endif +#endif + * @arg @ref UART_IT_CM Character match interrupt + * @arg @ref UART_IT_CTS CTS change interrupt + * @arg @ref UART_IT_LBD LIN Break detection interrupt + * @arg @ref UART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref UART_IT_TC Transmission complete interrupt + * @arg @ref UART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref UART_IT_RTO Receive Timeout interrupt + * @arg @ref UART_IT_IDLE Idle line detection interrupt + * @arg @ref UART_IT_PE Parity Error interrupt + * @arg @ref UART_IT_ERR Error interrupt (Frame error, noise error, overrun error) + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_UART_GET_IT(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->ISR\ + & (1U << ((__INTERRUPT__)>> 8U))) != RESET) ? SET : RESET) + +/** @brief Check whether the specified UART interrupt source is enabled or not. + * @param __HANDLE__ specifies the UART Handle. + * @param __INTERRUPT__ specifies the UART interrupt source to check. + * This parameter can be one of the following values: +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + * @arg @ref UART_IT_WUF Wakeup from stop mode interrupt +#endif +#endif + * @arg @ref UART_IT_CM Character match interrupt + * @arg @ref UART_IT_CTS CTS change interrupt + * @arg @ref UART_IT_LBD LIN Break detection interrupt + * @arg @ref UART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref UART_IT_TC Transmission complete interrupt + * @arg @ref UART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref UART_IT_RTO Receive Timeout interrupt + * @arg @ref UART_IT_IDLE Idle line detection interrupt + * @arg @ref UART_IT_PE Parity Error interrupt + * @arg @ref UART_IT_ERR Error interrupt (Frame error, noise error, overrun error) + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_UART_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((((((uint8_t)(__INTERRUPT__)) >> 5U) == 1U) ?\ + (__HANDLE__)->Instance->CR1 : \ + (((((uint8_t)(__INTERRUPT__)) >> 5U) == 2U) ?\ + (__HANDLE__)->Instance->CR2 : \ + (__HANDLE__)->Instance->CR3)) & (1U <<\ + (((uint16_t)(__INTERRUPT__)) &\ + UART_IT_MASK))) != RESET) ? SET : RESET) + +/** @brief Clear the specified UART ISR flag, in setting the proper ICR register flag. + * @param __HANDLE__ specifies the UART Handle. + * @param __IT_CLEAR__ specifies the interrupt clear register flag that needs to be set + * to clear the corresponding interrupt + * This parameter can be one of the following values: + * @arg @ref UART_CLEAR_PEF Parity Error Clear Flag + * @arg @ref UART_CLEAR_FEF Framing Error Clear Flag + * @arg @ref UART_CLEAR_NEF Noise detected Clear Flag + * @arg @ref UART_CLEAR_OREF Overrun Error Clear Flag + * @arg @ref UART_CLEAR_IDLEF IDLE line detected Clear Flag + * @arg @ref UART_CLEAR_RTOF Receiver timeout clear flag + * @arg @ref UART_CLEAR_TCF Transmission Complete Clear Flag + * @arg @ref UART_CLEAR_LBDF LIN Break Detection Clear Flag + * @arg @ref UART_CLEAR_CTSF CTS Interrupt Clear Flag + * @arg @ref UART_CLEAR_CMF Character Match Clear Flag +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + * @arg @ref UART_CLEAR_WUF Wake Up from stop mode Clear Flag +#endif +#endif + * @retval None + */ +#define __HAL_UART_CLEAR_IT(__HANDLE__, __IT_CLEAR__) ((__HANDLE__)->Instance->ICR = (uint32_t)(__IT_CLEAR__)) + +/** @brief Set a specific UART request flag. + * @param __HANDLE__ specifies the UART Handle. + * @param __REQ__ specifies the request flag to set + * This parameter can be one of the following values: + * @arg @ref UART_AUTOBAUD_REQUEST Auto-Baud Rate Request + * @arg @ref UART_SENDBREAK_REQUEST Send Break Request + * @arg @ref UART_MUTE_MODE_REQUEST Mute Mode Request + * @arg @ref UART_RXDATA_FLUSH_REQUEST Receive Data flush Request + * @arg @ref UART_TXDATA_FLUSH_REQUEST Transmit data flush Request + * @retval None + */ +#define __HAL_UART_SEND_REQ(__HANDLE__, __REQ__) ((__HANDLE__)->Instance->RQR |= (uint16_t)(__REQ__)) + +/** @brief Enable the UART one bit sample method. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_ONE_BIT_SAMPLE_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3|= USART_CR3_ONEBIT) + +/** @brief Disable the UART one bit sample method. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_ONE_BIT_SAMPLE_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3 &= ~USART_CR3_ONEBIT) + +/** @brief Enable UART. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= USART_CR1_UE) + +/** @brief Disable UART. + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~USART_CR1_UE) + +/** @brief Enable CTS flow control. + * @note This macro allows to enable CTS hardware flow control for a given UART instance, + * without need to call HAL_UART_Init() function. + * As involving direct access to UART registers, usage of this macro should be fully endorsed by user. + * @note As macro is expected to be used for modifying CTS Hw flow control feature activation, without need + * for USART instance Deinit/Init, following conditions for macro call should be fulfilled : + * - UART instance should have already been initialised (through call of HAL_UART_Init() ) + * - macro could only be called when corresponding UART instance is disabled + * (i.e. __HAL_UART_DISABLE(__HANDLE__)) and should be followed by an Enable + * macro (i.e. __HAL_UART_ENABLE(__HANDLE__)). + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_HWCONTROL_CTS_ENABLE(__HANDLE__) \ + do{ \ + ATOMIC_SET_BIT((__HANDLE__)->Instance->CR3, USART_CR3_CTSE); \ + (__HANDLE__)->Init.HwFlowCtl |= USART_CR3_CTSE; \ + } while(0U) + +/** @brief Disable CTS flow control. + * @note This macro allows to disable CTS hardware flow control for a given UART instance, + * without need to call HAL_UART_Init() function. + * As involving direct access to UART registers, usage of this macro should be fully endorsed by user. + * @note As macro is expected to be used for modifying CTS Hw flow control feature activation, without need + * for USART instance Deinit/Init, following conditions for macro call should be fulfilled : + * - UART instance should have already been initialised (through call of HAL_UART_Init() ) + * - macro could only be called when corresponding UART instance is disabled + * (i.e. __HAL_UART_DISABLE(__HANDLE__)) and should be followed by an Enable + * macro (i.e. __HAL_UART_ENABLE(__HANDLE__)). + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_HWCONTROL_CTS_DISABLE(__HANDLE__) \ + do{ \ + ATOMIC_CLEAR_BIT((__HANDLE__)->Instance->CR3, USART_CR3_CTSE); \ + (__HANDLE__)->Init.HwFlowCtl &= ~(USART_CR3_CTSE); \ + } while(0U) + +/** @brief Enable RTS flow control. + * @note This macro allows to enable RTS hardware flow control for a given UART instance, + * without need to call HAL_UART_Init() function. + * As involving direct access to UART registers, usage of this macro should be fully endorsed by user. + * @note As macro is expected to be used for modifying RTS Hw flow control feature activation, without need + * for USART instance Deinit/Init, following conditions for macro call should be fulfilled : + * - UART instance should have already been initialised (through call of HAL_UART_Init() ) + * - macro could only be called when corresponding UART instance is disabled + * (i.e. __HAL_UART_DISABLE(__HANDLE__)) and should be followed by an Enable + * macro (i.e. __HAL_UART_ENABLE(__HANDLE__)). + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_HWCONTROL_RTS_ENABLE(__HANDLE__) \ + do{ \ + ATOMIC_SET_BIT((__HANDLE__)->Instance->CR3, USART_CR3_RTSE); \ + (__HANDLE__)->Init.HwFlowCtl |= USART_CR3_RTSE; \ + } while(0U) + +/** @brief Disable RTS flow control. + * @note This macro allows to disable RTS hardware flow control for a given UART instance, + * without need to call HAL_UART_Init() function. + * As involving direct access to UART registers, usage of this macro should be fully endorsed by user. + * @note As macro is expected to be used for modifying RTS Hw flow control feature activation, without need + * for USART instance Deinit/Init, following conditions for macro call should be fulfilled : + * - UART instance should have already been initialised (through call of HAL_UART_Init() ) + * - macro could only be called when corresponding UART instance is disabled + * (i.e. __HAL_UART_DISABLE(__HANDLE__)) and should be followed by an Enable + * macro (i.e. __HAL_UART_ENABLE(__HANDLE__)). + * @param __HANDLE__ specifies the UART Handle. + * @retval None + */ +#define __HAL_UART_HWCONTROL_RTS_DISABLE(__HANDLE__) \ + do{ \ + ATOMIC_CLEAR_BIT((__HANDLE__)->Instance->CR3, USART_CR3_RTSE);\ + (__HANDLE__)->Init.HwFlowCtl &= ~(USART_CR3_RTSE); \ + } while(0U) +/** + * @} + */ + +/* Private macros --------------------------------------------------------*/ +/** @defgroup UART_Private_Macros UART Private Macros + * @{ + */ + + +/** @brief BRR division operation to set BRR register in 8-bit oversampling mode. + * @param __PCLK__ UART clock. + * @param __BAUD__ Baud rate set by the user. + * @retval Division result + */ +#define UART_DIV_SAMPLING8(__PCLK__, __BAUD__) ((((__PCLK__)*2U) + ((__BAUD__)/2U)) / (__BAUD__)) + +/** @brief BRR division operation to set BRR register in 16-bit oversampling mode. + * @param __PCLK__ UART clock. + * @param __BAUD__ Baud rate set by the user. + * @retval Division result + */ +#define UART_DIV_SAMPLING16(__PCLK__, __BAUD__) (((__PCLK__) + ((__BAUD__)/2U)) / (__BAUD__)) + + +/** @brief Check UART Baud rate. + * @param __BAUDRATE__ Baudrate specified by the user. + * The maximum Baud Rate is derived from the maximum clock on F0 (i.e. 48 MHz) + * divided by the smallest oversampling used on the USART (i.e. 8) + * @retval SET (__BAUDRATE__ is valid) or RESET (__BAUDRATE__ is invalid) + */ +#define IS_UART_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) < 6000001U) + +/** @brief Check UART assertion time. + * @param __TIME__ 5-bit value assertion time. + * @retval Test result (TRUE or FALSE). + */ +#define IS_UART_ASSERTIONTIME(__TIME__) ((__TIME__) <= 0x1FU) + +/** @brief Check UART deassertion time. + * @param __TIME__ 5-bit value deassertion time. + * @retval Test result (TRUE or FALSE). + */ +#define IS_UART_DEASSERTIONTIME(__TIME__) ((__TIME__) <= 0x1FU) + +/** + * @brief Ensure that UART frame number of stop bits is valid. + * @param __STOPBITS__ UART frame number of stop bits. + * @retval SET (__STOPBITS__ is valid) or RESET (__STOPBITS__ is invalid) + */ +#define IS_UART_STOPBITS(__STOPBITS__) (((__STOPBITS__) == UART_STOPBITS_0_5) || \ + ((__STOPBITS__) == UART_STOPBITS_1) || \ + ((__STOPBITS__) == UART_STOPBITS_1_5) || \ + ((__STOPBITS__) == UART_STOPBITS_2)) + + +/** + * @brief Ensure that UART frame parity is valid. + * @param __PARITY__ UART frame parity. + * @retval SET (__PARITY__ is valid) or RESET (__PARITY__ is invalid) + */ +#define IS_UART_PARITY(__PARITY__) (((__PARITY__) == UART_PARITY_NONE) || \ + ((__PARITY__) == UART_PARITY_EVEN) || \ + ((__PARITY__) == UART_PARITY_ODD)) + +/** + * @brief Ensure that UART hardware flow control is valid. + * @param __CONTROL__ UART hardware flow control. + * @retval SET (__CONTROL__ is valid) or RESET (__CONTROL__ is invalid) + */ +#define IS_UART_HARDWARE_FLOW_CONTROL(__CONTROL__)\ + (((__CONTROL__) == UART_HWCONTROL_NONE) || \ + ((__CONTROL__) == UART_HWCONTROL_RTS) || \ + ((__CONTROL__) == UART_HWCONTROL_CTS) || \ + ((__CONTROL__) == UART_HWCONTROL_RTS_CTS)) + +/** + * @brief Ensure that UART communication mode is valid. + * @param __MODE__ UART communication mode. + * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid) + */ +#define IS_UART_MODE(__MODE__) ((((__MODE__) & (~((uint32_t)(UART_MODE_TX_RX)))) == 0x00U) && ((__MODE__) != 0x00U)) + +/** + * @brief Ensure that UART state is valid. + * @param __STATE__ UART state. + * @retval SET (__STATE__ is valid) or RESET (__STATE__ is invalid) + */ +#define IS_UART_STATE(__STATE__) (((__STATE__) == UART_STATE_DISABLE) || \ + ((__STATE__) == UART_STATE_ENABLE)) + +/** + * @brief Ensure that UART oversampling is valid. + * @param __SAMPLING__ UART oversampling. + * @retval SET (__SAMPLING__ is valid) or RESET (__SAMPLING__ is invalid) + */ +#define IS_UART_OVERSAMPLING(__SAMPLING__) (((__SAMPLING__) == UART_OVERSAMPLING_16) || \ + ((__SAMPLING__) == UART_OVERSAMPLING_8)) + +/** + * @brief Ensure that UART frame sampling is valid. + * @param __ONEBIT__ UART frame sampling. + * @retval SET (__ONEBIT__ is valid) or RESET (__ONEBIT__ is invalid) + */ +#define IS_UART_ONE_BIT_SAMPLE(__ONEBIT__) (((__ONEBIT__) == UART_ONE_BIT_SAMPLE_DISABLE) || \ + ((__ONEBIT__) == UART_ONE_BIT_SAMPLE_ENABLE)) + +/** + * @brief Ensure that UART auto Baud rate detection mode is valid. + * @param __MODE__ UART auto Baud rate detection mode. + * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid) + */ +#define IS_UART_ADVFEATURE_AUTOBAUDRATEMODE(__MODE__) (((__MODE__) == UART_ADVFEATURE_AUTOBAUDRATE_ONSTARTBIT) || \ + ((__MODE__) == UART_ADVFEATURE_AUTOBAUDRATE_ONFALLINGEDGE) || \ + ((__MODE__) == UART_ADVFEATURE_AUTOBAUDRATE_ON0X7FFRAME) || \ + ((__MODE__) == UART_ADVFEATURE_AUTOBAUDRATE_ON0X55FRAME)) + +/** + * @brief Ensure that UART receiver timeout setting is valid. + * @param __TIMEOUT__ UART receiver timeout setting. + * @retval SET (__TIMEOUT__ is valid) or RESET (__TIMEOUT__ is invalid) + */ +#define IS_UART_RECEIVER_TIMEOUT(__TIMEOUT__) (((__TIMEOUT__) == UART_RECEIVER_TIMEOUT_DISABLE) || \ + ((__TIMEOUT__) == UART_RECEIVER_TIMEOUT_ENABLE)) + +/** @brief Check the receiver timeout value. + * @note The maximum UART receiver timeout value is 0xFFFFFF. + * @param __TIMEOUTVALUE__ receiver timeout value. + * @retval Test result (TRUE or FALSE) + */ +#define IS_UART_RECEIVER_TIMEOUT_VALUE(__TIMEOUTVALUE__) ((__TIMEOUTVALUE__) <= 0xFFFFFFU) + +/** + * @brief Ensure that UART LIN state is valid. + * @param __LIN__ UART LIN state. + * @retval SET (__LIN__ is valid) or RESET (__LIN__ is invalid) + */ +#define IS_UART_LIN(__LIN__) (((__LIN__) == UART_LIN_DISABLE) || \ + ((__LIN__) == UART_LIN_ENABLE)) + +/** + * @brief Ensure that UART LIN break detection length is valid. + * @param __LENGTH__ UART LIN break detection length. + * @retval SET (__LENGTH__ is valid) or RESET (__LENGTH__ is invalid) + */ +#define IS_UART_LIN_BREAK_DETECT_LENGTH(__LENGTH__) (((__LENGTH__) == UART_LINBREAKDETECTLENGTH_10B) || \ + ((__LENGTH__) == UART_LINBREAKDETECTLENGTH_11B)) + +/** + * @brief Ensure that UART DMA TX state is valid. + * @param __DMATX__ UART DMA TX state. + * @retval SET (__DMATX__ is valid) or RESET (__DMATX__ is invalid) + */ +#define IS_UART_DMA_TX(__DMATX__) (((__DMATX__) == UART_DMA_TX_DISABLE) || \ + ((__DMATX__) == UART_DMA_TX_ENABLE)) + +/** + * @brief Ensure that UART DMA RX state is valid. + * @param __DMARX__ UART DMA RX state. + * @retval SET (__DMARX__ is valid) or RESET (__DMARX__ is invalid) + */ +#define IS_UART_DMA_RX(__DMARX__) (((__DMARX__) == UART_DMA_RX_DISABLE) || \ + ((__DMARX__) == UART_DMA_RX_ENABLE)) + +/** + * @brief Ensure that UART half-duplex state is valid. + * @param __HDSEL__ UART half-duplex state. + * @retval SET (__HDSEL__ is valid) or RESET (__HDSEL__ is invalid) + */ +#define IS_UART_HALF_DUPLEX(__HDSEL__) (((__HDSEL__) == UART_HALF_DUPLEX_DISABLE) || \ + ((__HDSEL__) == UART_HALF_DUPLEX_ENABLE)) + +/** + * @brief Ensure that UART wake-up method is valid. + * @param __WAKEUP__ UART wake-up method . + * @retval SET (__WAKEUP__ is valid) or RESET (__WAKEUP__ is invalid) + */ +#define IS_UART_WAKEUPMETHOD(__WAKEUP__) (((__WAKEUP__) == UART_WAKEUPMETHOD_IDLELINE) || \ + ((__WAKEUP__) == UART_WAKEUPMETHOD_ADDRESSMARK)) + +/** + * @brief Ensure that UART request parameter is valid. + * @param __PARAM__ UART request parameter. + * @retval SET (__PARAM__ is valid) or RESET (__PARAM__ is invalid) + */ +#define IS_UART_REQUEST_PARAMETER(__PARAM__) (((__PARAM__) == UART_AUTOBAUD_REQUEST) || \ + ((__PARAM__) == UART_SENDBREAK_REQUEST) || \ + ((__PARAM__) == UART_MUTE_MODE_REQUEST) || \ + ((__PARAM__) == UART_RXDATA_FLUSH_REQUEST) || \ + ((__PARAM__) == UART_TXDATA_FLUSH_REQUEST)) + +/** + * @brief Ensure that UART advanced features initialization is valid. + * @param __INIT__ UART advanced features initialization. + * @retval SET (__INIT__ is valid) or RESET (__INIT__ is invalid) + */ +#define IS_UART_ADVFEATURE_INIT(__INIT__) ((__INIT__) <= (UART_ADVFEATURE_NO_INIT | \ + UART_ADVFEATURE_TXINVERT_INIT | \ + UART_ADVFEATURE_RXINVERT_INIT | \ + UART_ADVFEATURE_DATAINVERT_INIT | \ + UART_ADVFEATURE_SWAP_INIT | \ + UART_ADVFEATURE_RXOVERRUNDISABLE_INIT | \ + UART_ADVFEATURE_DMADISABLEONERROR_INIT | \ + UART_ADVFEATURE_AUTOBAUDRATE_INIT | \ + UART_ADVFEATURE_MSBFIRST_INIT)) + +/** + * @brief Ensure that UART frame TX inversion setting is valid. + * @param __TXINV__ UART frame TX inversion setting. + * @retval SET (__TXINV__ is valid) or RESET (__TXINV__ is invalid) + */ +#define IS_UART_ADVFEATURE_TXINV(__TXINV__) (((__TXINV__) == UART_ADVFEATURE_TXINV_DISABLE) || \ + ((__TXINV__) == UART_ADVFEATURE_TXINV_ENABLE)) + +/** + * @brief Ensure that UART frame RX inversion setting is valid. + * @param __RXINV__ UART frame RX inversion setting. + * @retval SET (__RXINV__ is valid) or RESET (__RXINV__ is invalid) + */ +#define IS_UART_ADVFEATURE_RXINV(__RXINV__) (((__RXINV__) == UART_ADVFEATURE_RXINV_DISABLE) || \ + ((__RXINV__) == UART_ADVFEATURE_RXINV_ENABLE)) + +/** + * @brief Ensure that UART frame data inversion setting is valid. + * @param __DATAINV__ UART frame data inversion setting. + * @retval SET (__DATAINV__ is valid) or RESET (__DATAINV__ is invalid) + */ +#define IS_UART_ADVFEATURE_DATAINV(__DATAINV__) (((__DATAINV__) == UART_ADVFEATURE_DATAINV_DISABLE) || \ + ((__DATAINV__) == UART_ADVFEATURE_DATAINV_ENABLE)) + +/** + * @brief Ensure that UART frame RX/TX pins swap setting is valid. + * @param __SWAP__ UART frame RX/TX pins swap setting. + * @retval SET (__SWAP__ is valid) or RESET (__SWAP__ is invalid) + */ +#define IS_UART_ADVFEATURE_SWAP(__SWAP__) (((__SWAP__) == UART_ADVFEATURE_SWAP_DISABLE) || \ + ((__SWAP__) == UART_ADVFEATURE_SWAP_ENABLE)) + +/** + * @brief Ensure that UART frame overrun setting is valid. + * @param __OVERRUN__ UART frame overrun setting. + * @retval SET (__OVERRUN__ is valid) or RESET (__OVERRUN__ is invalid) + */ +#define IS_UART_OVERRUN(__OVERRUN__) (((__OVERRUN__) == UART_ADVFEATURE_OVERRUN_ENABLE) || \ + ((__OVERRUN__) == UART_ADVFEATURE_OVERRUN_DISABLE)) + +/** + * @brief Ensure that UART auto Baud rate state is valid. + * @param __AUTOBAUDRATE__ UART auto Baud rate state. + * @retval SET (__AUTOBAUDRATE__ is valid) or RESET (__AUTOBAUDRATE__ is invalid) + */ +#define IS_UART_ADVFEATURE_AUTOBAUDRATE(__AUTOBAUDRATE__) (((__AUTOBAUDRATE__) == \ + UART_ADVFEATURE_AUTOBAUDRATE_DISABLE) || \ + ((__AUTOBAUDRATE__) == UART_ADVFEATURE_AUTOBAUDRATE_ENABLE)) + +/** + * @brief Ensure that UART DMA enabling or disabling on error setting is valid. + * @param __DMA__ UART DMA enabling or disabling on error setting. + * @retval SET (__DMA__ is valid) or RESET (__DMA__ is invalid) + */ +#define IS_UART_ADVFEATURE_DMAONRXERROR(__DMA__) (((__DMA__) == UART_ADVFEATURE_DMA_ENABLEONRXERROR) || \ + ((__DMA__) == UART_ADVFEATURE_DMA_DISABLEONRXERROR)) + +/** + * @brief Ensure that UART frame MSB first setting is valid. + * @param __MSBFIRST__ UART frame MSB first setting. + * @retval SET (__MSBFIRST__ is valid) or RESET (__MSBFIRST__ is invalid) + */ +#define IS_UART_ADVFEATURE_MSBFIRST(__MSBFIRST__) (((__MSBFIRST__) == UART_ADVFEATURE_MSBFIRST_DISABLE) || \ + ((__MSBFIRST__) == UART_ADVFEATURE_MSBFIRST_ENABLE)) + +#if defined(USART_CR1_UESM) +/** + * @brief Ensure that UART stop mode state is valid. + * @param __STOPMODE__ UART stop mode state. + * @retval SET (__STOPMODE__ is valid) or RESET (__STOPMODE__ is invalid) + */ +#define IS_UART_ADVFEATURE_STOPMODE(__STOPMODE__) (((__STOPMODE__) == UART_ADVFEATURE_STOPMODE_DISABLE) || \ + ((__STOPMODE__) == UART_ADVFEATURE_STOPMODE_ENABLE)) + +#endif /* USART_CR1_UESM */ +/** + * @brief Ensure that UART mute mode state is valid. + * @param __MUTE__ UART mute mode state. + * @retval SET (__MUTE__ is valid) or RESET (__MUTE__ is invalid) + */ +#define IS_UART_MUTE_MODE(__MUTE__) (((__MUTE__) == UART_ADVFEATURE_MUTEMODE_DISABLE) || \ + ((__MUTE__) == UART_ADVFEATURE_MUTEMODE_ENABLE)) +#if defined(USART_CR1_UESM) + +/** + * @brief Ensure that UART wake-up selection is valid. + * @param __WAKE__ UART wake-up selection. + * @retval SET (__WAKE__ is valid) or RESET (__WAKE__ is invalid) + */ +#if defined(USART_CR3_WUFIE) +#define IS_UART_WAKEUP_SELECTION(__WAKE__) (((__WAKE__) == UART_WAKEUP_ON_ADDRESS) || \ + ((__WAKE__) == UART_WAKEUP_ON_STARTBIT) || \ + ((__WAKE__) == UART_WAKEUP_ON_READDATA_NONEMPTY)) +#else +#define IS_UART_WAKEUP_SELECTION(__WAKE__) (((__WAKE__) == UART_WAKEUP_ON_ADDRESS) || \ + ((__WAKE__) == UART_WAKEUP_ON_READDATA_NONEMPTY)) +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + +/** + * @brief Ensure that UART driver enable polarity is valid. + * @param __POLARITY__ UART driver enable polarity. + * @retval SET (__POLARITY__ is valid) or RESET (__POLARITY__ is invalid) + */ +#define IS_UART_DE_POLARITY(__POLARITY__) (((__POLARITY__) == UART_DE_POLARITY_HIGH) || \ + ((__POLARITY__) == UART_DE_POLARITY_LOW)) + + +/** + * @} + */ + +/* Include UART HAL Extended module */ +#include "stm32f0xx_hal_uart_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup UART_Exported_Functions UART Exported Functions + * @{ + */ + +/** @addtogroup UART_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_UART_Init(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_HalfDuplex_Init(UART_HandleTypeDef *huart); +#if defined(USART_CR2_LINEN) +HAL_StatusTypeDef HAL_LIN_Init(UART_HandleTypeDef *huart, uint32_t BreakDetectLength); +#endif /* USART_CR2_LINEN */ +HAL_StatusTypeDef HAL_MultiProcessor_Init(UART_HandleTypeDef *huart, uint8_t Address, uint32_t WakeUpMethod); +HAL_StatusTypeDef HAL_UART_DeInit(UART_HandleTypeDef *huart); +void HAL_UART_MspInit(UART_HandleTypeDef *huart); +void HAL_UART_MspDeInit(UART_HandleTypeDef *huart); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_UART_RegisterCallback(UART_HandleTypeDef *huart, HAL_UART_CallbackIDTypeDef CallbackID, + pUART_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_UART_UnRegisterCallback(UART_HandleTypeDef *huart, HAL_UART_CallbackIDTypeDef CallbackID); + +HAL_StatusTypeDef HAL_UART_RegisterRxEventCallback(UART_HandleTypeDef *huart, pUART_RxEventCallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_UART_UnRegisterRxEventCallback(UART_HandleTypeDef *huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @addtogroup UART_Exported_Functions_Group2 IO operation functions + * @{ + */ + +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_UART_Receive(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_UART_Transmit_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_UART_Receive_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_UART_Transmit_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_UART_Receive_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_UART_DMAPause(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_DMAResume(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_DMAStop(UART_HandleTypeDef *huart); +/* Transfer Abort functions */ +HAL_StatusTypeDef HAL_UART_Abort(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_AbortTransmit(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_AbortReceive(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_Abort_IT(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_AbortTransmit_IT(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_AbortReceive_IT(UART_HandleTypeDef *huart); + +void HAL_UART_IRQHandler(UART_HandleTypeDef *huart); +void HAL_UART_TxHalfCpltCallback(UART_HandleTypeDef *huart); +void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart); +void HAL_UART_RxHalfCpltCallback(UART_HandleTypeDef *huart); +void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart); +void HAL_UART_ErrorCallback(UART_HandleTypeDef *huart); +void HAL_UART_AbortCpltCallback(UART_HandleTypeDef *huart); +void HAL_UART_AbortTransmitCpltCallback(UART_HandleTypeDef *huart); +void HAL_UART_AbortReceiveCpltCallback(UART_HandleTypeDef *huart); + +void HAL_UARTEx_RxEventCallback(UART_HandleTypeDef *huart, uint16_t Size); + +/** + * @} + */ + +/** @addtogroup UART_Exported_Functions_Group3 Peripheral Control functions + * @{ + */ + +/* Peripheral Control functions ************************************************/ +void HAL_UART_ReceiverTimeout_Config(UART_HandleTypeDef *huart, uint32_t TimeoutValue); +HAL_StatusTypeDef HAL_UART_EnableReceiverTimeout(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UART_DisableReceiverTimeout(UART_HandleTypeDef *huart); + +#if defined(USART_CR2_LINEN) +HAL_StatusTypeDef HAL_LIN_SendBreak(UART_HandleTypeDef *huart); +#endif /* USART_CR2_LINEN */ +HAL_StatusTypeDef HAL_MultiProcessor_EnableMuteMode(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_MultiProcessor_DisableMuteMode(UART_HandleTypeDef *huart); +void HAL_MultiProcessor_EnterMuteMode(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_HalfDuplex_EnableTransmitter(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_HalfDuplex_EnableReceiver(UART_HandleTypeDef *huart); + +/** + * @} + */ + +/** @addtogroup UART_Exported_Functions_Group4 Peripheral State and Error functions + * @{ + */ + +/* Peripheral State and Errors functions **************************************************/ +HAL_UART_StateTypeDef HAL_UART_GetState(UART_HandleTypeDef *huart); +uint32_t HAL_UART_GetError(UART_HandleTypeDef *huart); + +/** + * @} + */ + +/** + * @} + */ + +/* Private functions -----------------------------------------------------------*/ +/** @addtogroup UART_Private_Functions UART Private Functions + * @{ + */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) +void UART_InitCallbacksToDefault(UART_HandleTypeDef *huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +HAL_StatusTypeDef UART_SetConfig(UART_HandleTypeDef *huart); +HAL_StatusTypeDef UART_CheckIdleState(UART_HandleTypeDef *huart); +HAL_StatusTypeDef UART_WaitOnFlagUntilTimeout(UART_HandleTypeDef *huart, uint32_t Flag, FlagStatus Status, + uint32_t Tickstart, uint32_t Timeout); +void UART_AdvFeatureConfig(UART_HandleTypeDef *huart); +HAL_StatusTypeDef UART_Start_Receive_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef UART_Start_Receive_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); + +/** + * @} + */ + +/* Private variables -----------------------------------------------------------*/ +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_UART_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart_ex.h new file mode 100644 index 0000000..a1e8d97 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_uart_ex.h @@ -0,0 +1,592 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_uart_ex.h + * @author MCD Application Team + * @brief Header file of UART HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_UART_EX_H +#define STM32F0xx_HAL_UART_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup UARTEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup UARTEx_Exported_Types UARTEx Exported Types + * @{ + */ + +#if defined(USART_CR1_UESM) +/** + * @brief UART wake up from stop mode parameters + */ +typedef struct +{ + uint32_t WakeUpEvent; /*!< Specifies which event will activate the Wakeup from Stop mode flag (WUF). + This parameter can be a value of @ref UART_WakeUp_from_Stop_Selection. + If set to UART_WAKEUP_ON_ADDRESS, the two other fields below must + be filled up. */ + + uint16_t AddressLength; /*!< Specifies whether the address is 4 or 7-bit long. + This parameter can be a value of @ref UARTEx_WakeUp_Address_Length. */ + + uint8_t Address; /*!< UART/USART node address (7-bit long max). */ +} UART_WakeUpTypeDef; + +#endif /* USART_CR1_UESM */ +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup UARTEx_Exported_Constants UARTEx Exported Constants + * @{ + */ + +/** @defgroup UARTEx_Word_Length UARTEx Word Length + * @{ + */ +#if defined(USART_CR1_M1) +#define UART_WORDLENGTH_7B USART_CR1_M1 /*!< 7-bit long UART frame */ +#endif /* USART_CR1_M1 */ +#define UART_WORDLENGTH_8B 0x00000000U /*!< 8-bit long UART frame */ +#if defined (USART_CR1_M0) +#define UART_WORDLENGTH_9B USART_CR1_M0 /*!< 9-bit long UART frame */ +#else +#define UART_WORDLENGTH_9B USART_CR1_M /*!< 9-bit long UART frame */ +#endif /* USART_CR1_M0 */ +/** + * @} + */ + +/** @defgroup UARTEx_WakeUp_Address_Length UARTEx WakeUp Address Length + * @{ + */ +#define UART_ADDRESS_DETECT_4B 0x00000000U /*!< 4-bit long wake-up address */ +#define UART_ADDRESS_DETECT_7B USART_CR2_ADDM7 /*!< 7-bit long wake-up address */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup UARTEx_Exported_Functions + * @{ + */ + +/** @addtogroup UARTEx_Exported_Functions_Group1 + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_RS485Ex_Init(UART_HandleTypeDef *huart, uint32_t Polarity, uint32_t AssertionTime, + uint32_t DeassertionTime); + +/** + * @} + */ + +/** @addtogroup UARTEx_Exported_Functions_Group2 + * @{ + */ + +#if defined(USART_CR1_UESM) +void HAL_UARTEx_WakeupCallback(UART_HandleTypeDef *huart); + +#endif /* USART_CR1_UESM */ +/** + * @} + */ + +/** @addtogroup UARTEx_Exported_Functions_Group3 + * @{ + */ + +/* Peripheral Control functions **********************************************/ +#if defined(USART_CR1_UESM) +HAL_StatusTypeDef HAL_UARTEx_StopModeWakeUpSourceConfig(UART_HandleTypeDef *huart, UART_WakeUpTypeDef WakeUpSelection); +HAL_StatusTypeDef HAL_UARTEx_EnableStopMode(UART_HandleTypeDef *huart); +HAL_StatusTypeDef HAL_UARTEx_DisableStopMode(UART_HandleTypeDef *huart); + +#endif/* USART_CR1_UESM */ +HAL_StatusTypeDef HAL_MultiProcessorEx_AddressLength_Set(UART_HandleTypeDef *huart, uint32_t AddressLength); + + +HAL_StatusTypeDef HAL_UARTEx_ReceiveToIdle(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint16_t *RxLen, + uint32_t Timeout); +HAL_StatusTypeDef HAL_UARTEx_ReceiveToIdle_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); +HAL_StatusTypeDef HAL_UARTEx_ReceiveToIdle_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size); + + +/** + * @} + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup UARTEx_Private_Macros UARTEx Private Macros + * @{ + */ + +/** @brief Report the UART clock source. + * @param __HANDLE__ specifies the UART Handle. + * @param __CLOCKSOURCE__ output variable. + * @retval UART clocking source, written in __CLOCKSOURCE__. + */ + +#if defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) +#define UART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } while(0) +#elif defined (STM32F030x8) || defined (STM32F070x6) || defined (STM32F042x6) || defined (STM32F048xx) || defined (STM32F051x8) || defined (STM32F058xx) +#define UART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F070xB) +#define UART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) +#define UART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F091xC) || defined (STM32F098xx) +#define UART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + switch(__HAL_RCC_GET_USART3_SOURCE()) \ + { \ + case RCC_USART3CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART3CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART3CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART3CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART5) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART6) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART7) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART8) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F030xC) +#define UART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART5) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART6) \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = UART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) + +#endif /* defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) */ + +/** @brief Report the UART mask to apply to retrieve the received data + * according to the word length and to the parity bits activation. + * @note If PCE = 1, the parity bit is not included in the data extracted + * by the reception API(). + * This masking operation is not carried out in the case of + * DMA transfers. + * @param __HANDLE__ specifies the UART Handle. + * @retval None, the mask to apply to UART RDR register is stored in (__HANDLE__)->Mask field. + */ +#if defined (USART_CR1_M1) +#define UART_MASK_COMPUTATION(__HANDLE__) \ + do { \ + if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_9B) \ + { \ + if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x01FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_8B) \ + { \ + if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x007FU ; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_7B) \ + { \ + if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x007FU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x003FU ; \ + } \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x0000U; \ + } \ + } while(0U) + +#else +#define UART_MASK_COMPUTATION(__HANDLE__) \ + do { \ + if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_9B) \ + { \ + if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x01FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == UART_WORDLENGTH_8B) \ + { \ + if ((__HANDLE__)->Init.Parity == UART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x00FFU ; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x007FU ; \ + } \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x0000U; \ + } \ + } while(0U) + +#endif /* USART_CR1_M1 */ + +/** + * @brief Ensure that UART frame length is valid. + * @param __LENGTH__ UART frame length. + * @retval SET (__LENGTH__ is valid) or RESET (__LENGTH__ is invalid) + */ +#if defined (USART_CR1_M1) +#define IS_UART_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == UART_WORDLENGTH_7B) || \ + ((__LENGTH__) == UART_WORDLENGTH_8B) || \ + ((__LENGTH__) == UART_WORDLENGTH_9B)) +#else +#define IS_UART_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == UART_WORDLENGTH_8B) || \ + ((__LENGTH__) == UART_WORDLENGTH_9B)) +#endif /* USART_CR1_M1 */ + +/** + * @brief Ensure that UART wake-up address length is valid. + * @param __ADDRESS__ UART wake-up address length. + * @retval SET (__ADDRESS__ is valid) or RESET (__ADDRESS__ is invalid) + */ +#define IS_UART_ADDRESSLENGTH_DETECT(__ADDRESS__) (((__ADDRESS__) == UART_ADDRESS_DETECT_4B) || \ + ((__ADDRESS__) == UART_ADDRESS_DETECT_7B)) + +/** + * @} + */ + +/* Private functions ---------------------------------------------------------*/ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_UART_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart.h new file mode 100644 index 0000000..9657daa --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart.h @@ -0,0 +1,795 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_usart.h + * @author MCD Application Team + * @brief Header file of USART HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_USART_H +#define STM32F0xx_HAL_USART_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup USART + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup USART_Exported_Types USART Exported Types + * @{ + */ + +/** + * @brief USART Init Structure definition + */ +typedef struct +{ + uint32_t BaudRate; /*!< This member configures the Usart communication baud rate. + The baud rate is computed using the following formula: + Baud Rate Register[15:4] = ((2 * fclk_pres) / + ((huart->Init.BaudRate)))[15:4] + Baud Rate Register[3] = 0 + Baud Rate Register[2:0] = (((2 * fclk_pres) / + ((huart->Init.BaudRate)))[3:0]) >> 1 + where fclk_pres is the USART input clock frequency + @note Oversampling by 8 is systematically applied to + achieve high baud rates. */ + + uint32_t WordLength; /*!< Specifies the number of data bits transmitted or received in a frame. + This parameter can be a value of @ref USARTEx_Word_Length. */ + + uint32_t StopBits; /*!< Specifies the number of stop bits transmitted. + This parameter can be a value of @ref USART_Stop_Bits. */ + + uint32_t Parity; /*!< Specifies the parity mode. + This parameter can be a value of @ref USART_Parity + @note When parity is enabled, the computed parity is inserted + at the MSB position of the transmitted data (9th bit when + the word length is set to 9 data bits; 8th bit when the + word length is set to 8 data bits). */ + + uint32_t Mode; /*!< Specifies whether the Receive or Transmit mode is enabled or disabled. + This parameter can be a value of @ref USART_Mode. */ + + uint32_t CLKPolarity; /*!< Specifies the steady state of the serial clock. + This parameter can be a value of @ref USART_Clock_Polarity. */ + + uint32_t CLKPhase; /*!< Specifies the clock transition on which the bit capture is made. + This parameter can be a value of @ref USART_Clock_Phase. */ + + uint32_t CLKLastBit; /*!< Specifies whether the clock pulse corresponding to the last transmitted + data bit (MSB) has to be output on the SCLK pin in synchronous mode. + This parameter can be a value of @ref USART_Last_Bit. */ + +} USART_InitTypeDef; + +/** + * @brief HAL USART State structures definition + */ +typedef enum +{ + HAL_USART_STATE_RESET = 0x00U, /*!< Peripheral is not initialized */ + HAL_USART_STATE_READY = 0x01U, /*!< Peripheral Initialized and ready for use */ + HAL_USART_STATE_BUSY = 0x02U, /*!< an internal process is ongoing */ + HAL_USART_STATE_BUSY_TX = 0x12U, /*!< Data Transmission process is ongoing */ + HAL_USART_STATE_BUSY_RX = 0x22U, /*!< Data Reception process is ongoing */ + HAL_USART_STATE_BUSY_TX_RX = 0x32U, /*!< Data Transmission Reception process is ongoing */ + HAL_USART_STATE_TIMEOUT = 0x03U, /*!< Timeout state */ + HAL_USART_STATE_ERROR = 0x04U /*!< Error */ +} HAL_USART_StateTypeDef; + +/** + * @brief USART clock sources definitions + */ +typedef enum +{ + USART_CLOCKSOURCE_PCLK1 = 0x00U, /*!< PCLK1 clock source */ + USART_CLOCKSOURCE_HSI = 0x02U, /*!< HSI clock source */ + USART_CLOCKSOURCE_SYSCLK = 0x04U, /*!< SYSCLK clock source */ + USART_CLOCKSOURCE_LSE = 0x08U, /*!< LSE clock source */ + USART_CLOCKSOURCE_UNDEFINED = 0x10U /*!< Undefined clock source */ +} USART_ClockSourceTypeDef; + +/** + * @brief USART handle Structure definition + */ +typedef struct __USART_HandleTypeDef +{ + USART_TypeDef *Instance; /*!< USART registers base address */ + + USART_InitTypeDef Init; /*!< USART communication parameters */ + + uint8_t *pTxBuffPtr; /*!< Pointer to USART Tx transfer Buffer */ + + uint16_t TxXferSize; /*!< USART Tx Transfer size */ + + __IO uint16_t TxXferCount; /*!< USART Tx Transfer Counter */ + + uint8_t *pRxBuffPtr; /*!< Pointer to USART Rx transfer Buffer */ + + uint16_t RxXferSize; /*!< USART Rx Transfer size */ + + __IO uint16_t RxXferCount; /*!< USART Rx Transfer Counter */ + + uint16_t Mask; /*!< USART Rx RDR register mask */ + + void (*RxISR)(struct __USART_HandleTypeDef *husart); /*!< Function pointer on Rx IRQ handler */ + + void (*TxISR)(struct __USART_HandleTypeDef *husart); /*!< Function pointer on Tx IRQ handler */ + + DMA_HandleTypeDef *hdmatx; /*!< USART Tx DMA Handle parameters */ + + DMA_HandleTypeDef *hdmarx; /*!< USART Rx DMA Handle parameters */ + + HAL_LockTypeDef Lock; /*!< Locking object */ + + __IO HAL_USART_StateTypeDef State; /*!< USART communication state */ + + __IO uint32_t ErrorCode; /*!< USART Error code */ + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + void (* TxHalfCpltCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Tx Half Complete Callback */ + void (* TxCpltCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Tx Complete Callback */ + void (* RxHalfCpltCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Rx Half Complete Callback */ + void (* RxCpltCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Rx Complete Callback */ + void (* TxRxCpltCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Tx Rx Complete Callback */ + void (* ErrorCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Error Callback */ + void (* AbortCpltCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Abort Complete Callback */ + + void (* MspInitCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Msp Init callback */ + void (* MspDeInitCallback)(struct __USART_HandleTypeDef *husart); /*!< USART Msp DeInit callback */ +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + +} USART_HandleTypeDef; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) +/** + * @brief HAL USART Callback ID enumeration definition + */ +typedef enum +{ + HAL_USART_TX_HALFCOMPLETE_CB_ID = 0x00U, /*!< USART Tx Half Complete Callback ID */ + HAL_USART_TX_COMPLETE_CB_ID = 0x01U, /*!< USART Tx Complete Callback ID */ + HAL_USART_RX_HALFCOMPLETE_CB_ID = 0x02U, /*!< USART Rx Half Complete Callback ID */ + HAL_USART_RX_COMPLETE_CB_ID = 0x03U, /*!< USART Rx Complete Callback ID */ + HAL_USART_TX_RX_COMPLETE_CB_ID = 0x04U, /*!< USART Tx Rx Complete Callback ID */ + HAL_USART_ERROR_CB_ID = 0x05U, /*!< USART Error Callback ID */ + HAL_USART_ABORT_COMPLETE_CB_ID = 0x06U, /*!< USART Abort Complete Callback ID */ + + HAL_USART_MSPINIT_CB_ID = 0x09U, /*!< USART MspInit callback ID */ + HAL_USART_MSPDEINIT_CB_ID = 0x0AU /*!< USART MspDeInit callback ID */ + +} HAL_USART_CallbackIDTypeDef; + +/** + * @brief HAL USART Callback pointer definition + */ +typedef void (*pUSART_CallbackTypeDef)(USART_HandleTypeDef *husart); /*!< pointer to an USART callback function */ + +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup USART_Exported_Constants USART Exported Constants + * @{ + */ + +/** @defgroup USART_Error_Definition USART Error Definition + * @{ + */ +#define HAL_USART_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_USART_ERROR_PE (0x00000001U) /*!< Parity error */ +#define HAL_USART_ERROR_NE (0x00000002U) /*!< Noise error */ +#define HAL_USART_ERROR_FE (0x00000004U) /*!< Frame error */ +#define HAL_USART_ERROR_ORE (0x00000008U) /*!< Overrun error */ +#define HAL_USART_ERROR_DMA (0x00000010U) /*!< DMA transfer error */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) +#define HAL_USART_ERROR_INVALID_CALLBACK (0x00000040U) /*!< Invalid Callback error */ +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ +#define HAL_USART_ERROR_RTO (0x00000080U) /*!< Receiver Timeout error */ +/** + * @} + */ + +/** @defgroup USART_Stop_Bits USART Number of Stop Bits + * @{ + */ +#if defined(USART_SMARTCARD_SUPPORT) +#define USART_STOPBITS_0_5 USART_CR2_STOP_0 /*!< USART frame with 0.5 stop bit */ +#define USART_STOPBITS_1 0x00000000U /*!< USART frame with 1 stop bit */ +#define USART_STOPBITS_1_5 (USART_CR2_STOP_0 | USART_CR2_STOP_1) /*!< USART frame with 1.5 stop bits */ +#define USART_STOPBITS_2 USART_CR2_STOP_1 /*!< USART frame with 2 stop bits */ +#else +#define USART_STOPBITS_1 (0x00000000U) /*!< USART frame with 1 stop bit */ +#define USART_STOPBITS_2 (USART_CR2_STOP_1) /*!< USART frame with 2 stop bits */ +#endif /* USART_SMARTCARD_SUPPORT */ +/** + * @} + */ + +/** @defgroup USART_Parity USART Parity + * @{ + */ +#define USART_PARITY_NONE 0x00000000U /*!< No parity */ +#define USART_PARITY_EVEN USART_CR1_PCE /*!< Even parity */ +#define USART_PARITY_ODD (USART_CR1_PCE | USART_CR1_PS) /*!< Odd parity */ +/** + * @} + */ + +/** @defgroup USART_Mode USART Mode + * @{ + */ +#define USART_MODE_RX USART_CR1_RE /*!< RX mode */ +#define USART_MODE_TX USART_CR1_TE /*!< TX mode */ +#define USART_MODE_TX_RX (USART_CR1_TE |USART_CR1_RE) /*!< RX and TX mode */ +/** + * @} + */ + +/** @defgroup USART_Clock USART Clock + * @{ + */ +#define USART_CLOCK_DISABLE 0x00000000U /*!< USART clock disable */ +#define USART_CLOCK_ENABLE USART_CR2_CLKEN /*!< USART clock enable */ +/** + * @} + */ + +/** @defgroup USART_Clock_Polarity USART Clock Polarity + * @{ + */ +#define USART_POLARITY_LOW 0x00000000U /*!< Driver enable signal is active high */ +#define USART_POLARITY_HIGH USART_CR2_CPOL /*!< Driver enable signal is active low */ +/** + * @} + */ + +/** @defgroup USART_Clock_Phase USART Clock Phase + * @{ + */ +#define USART_PHASE_1EDGE 0x00000000U /*!< USART frame phase on first clock transition */ +#define USART_PHASE_2EDGE USART_CR2_CPHA /*!< USART frame phase on second clock transition */ +/** + * @} + */ + +/** @defgroup USART_Last_Bit USART Last Bit + * @{ + */ +#define USART_LASTBIT_DISABLE 0x00000000U /*!< USART frame last data bit clock pulse not output to SCLK pin */ +#define USART_LASTBIT_ENABLE USART_CR2_LBCL /*!< USART frame last data bit clock pulse output to SCLK pin */ +/** + * @} + */ + + +/** @defgroup USART_Request_Parameters USART Request Parameters + * @{ + */ +#define USART_RXDATA_FLUSH_REQUEST USART_RQR_RXFRQ /*!< Receive Data flush Request */ +#if defined(USART_RQR_TXFRQ) +#define USART_TXDATA_FLUSH_REQUEST USART_RQR_TXFRQ /*!< Transmit data flush Request */ +#endif /* USART_RQR_TXFRQ */ +/** + * @} + */ + +/** @defgroup USART_Flags USART Flags + * Elements values convention: 0xXXXX + * - 0xXXXX : Flag mask in the ISR register + * @{ + */ +#define USART_FLAG_REACK USART_ISR_REACK /*!< USART receive enable acknowledge flag */ +#define USART_FLAG_TEACK USART_ISR_TEACK /*!< USART transmit enable acknowledge flag */ +#define USART_FLAG_BUSY USART_ISR_BUSY /*!< USART busy flag */ +#define USART_FLAG_TXE USART_ISR_TXE /*!< USART transmit data register empty */ +#define USART_FLAG_RTOF USART_ISR_RTOF /*!< USART receiver timeout flag */ +#define USART_FLAG_TC USART_ISR_TC /*!< USART transmission complete */ +#define USART_FLAG_RXNE USART_ISR_RXNE /*!< USART read data register not empty */ +#define USART_FLAG_IDLE USART_ISR_IDLE /*!< USART idle flag */ +#define USART_FLAG_ORE USART_ISR_ORE /*!< USART overrun error */ +#define USART_FLAG_NE USART_ISR_NE /*!< USART noise error */ +#define USART_FLAG_FE USART_ISR_FE /*!< USART frame error */ +#define USART_FLAG_PE USART_ISR_PE /*!< USART parity error */ +/** + * @} + */ + +/** @defgroup USART_Interrupt_definition USART Interrupts Definition + * Elements values convention: 0000ZZZZ0XXYYYYYb + * - YYYYY : Interrupt source position in the XX register (5bits) + * - XX : Interrupt source register (2bits) + * - 01: CR1 register + * - 10: CR2 register + * - 11: CR3 register + * - ZZZZ : Flag position in the ISR register(4bits) + * @{ + */ + +#define USART_IT_PE 0x0028U /*!< USART parity error interruption */ +#define USART_IT_TXE 0x0727U /*!< USART transmit data register empty interruption */ +#define USART_IT_TC 0x0626U /*!< USART transmission complete interruption */ +#define USART_IT_RXNE 0x0525U /*!< USART read data register not empty interruption */ +#define USART_IT_IDLE 0x0424U /*!< USART idle interruption */ +#define USART_IT_ERR 0x0060U /*!< USART error interruption */ +#define USART_IT_ORE 0x0300U /*!< USART overrun error interruption */ +#define USART_IT_NE 0x0200U /*!< USART noise error interruption */ +#define USART_IT_FE 0x0100U /*!< USART frame error interruption */ + +/** + * @} + */ + +/** @defgroup USART_IT_CLEAR_Flags USART Interruption Clear Flags + * @{ + */ +#define USART_CLEAR_PEF USART_ICR_PECF /*!< Parity Error Clear Flag */ +#define USART_CLEAR_FEF USART_ICR_FECF /*!< Framing Error Clear Flag */ +#define USART_CLEAR_NEF USART_ICR_NCF /*!< Noise Error detected Clear Flag */ +#define USART_CLEAR_OREF USART_ICR_ORECF /*!< OverRun Error Clear Flag */ +#define USART_CLEAR_IDLEF USART_ICR_IDLECF /*!< IDLE line detected Clear Flag */ +#define USART_CLEAR_TCF USART_ICR_TCCF /*!< Transmission Complete Clear Flag */ +#define USART_CLEAR_CTSF USART_ICR_CTSCF /*!< CTS Interrupt Clear Flag */ +#define USART_CLEAR_RTOF USART_ICR_RTOCF /*!< USART receiver timeout clear flag */ +/** + * @} + */ + +/** @defgroup USART_Interruption_Mask USART Interruption Flags Mask + * @{ + */ +#define USART_IT_MASK 0x001FU /*!< USART interruptions flags mask */ +#define USART_CR_MASK 0x00E0U /*!< USART control register mask */ +#define USART_CR_POS 5U /*!< USART control register position */ +#define USART_ISR_MASK 0x1F00U /*!< USART ISR register mask */ +#define USART_ISR_POS 8U /*!< USART ISR register position */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup USART_Exported_Macros USART Exported Macros + * @{ + */ + +/** @brief Reset USART handle state. + * @param __HANDLE__ USART handle. + * @retval None + */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) +#define __HAL_USART_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_USART_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0U) +#else +#define __HAL_USART_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_USART_STATE_RESET) +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + +/** @brief Check whether the specified USART flag is set or not. + * @param __HANDLE__ specifies the USART Handle + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg @ref USART_FLAG_REACK Receive enable acknowledge flag + * @arg @ref USART_FLAG_TEACK Transmit enable acknowledge flag + * @arg @ref USART_FLAG_BUSY Busy flag + * @arg @ref USART_FLAG_CTS CTS Change flag + * @arg @ref USART_FLAG_TXE Transmit data register empty flag + * @arg @ref USART_FLAG_TC Transmission Complete flag + * @arg @ref USART_FLAG_RXNE Receive data register not empty flag + * @arg @ref USART_FLAG_RTOF Receiver Timeout flag + * @arg @ref USART_FLAG_IDLE Idle Line detection flag + * @arg @ref USART_FLAG_ORE OverRun Error flag + * @arg @ref USART_FLAG_NE Noise Error flag + * @arg @ref USART_FLAG_FE Framing Error flag + * @arg @ref USART_FLAG_PE Parity Error flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_USART_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->ISR & (__FLAG__)) == (__FLAG__)) + +/** @brief Clear the specified USART pending flag. + * @param __HANDLE__ specifies the USART Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be any combination of the following values: + * @arg @ref USART_CLEAR_PEF Parity Error Clear Flag + * @arg @ref USART_CLEAR_FEF Framing Error Clear Flag + * @arg @ref USART_CLEAR_NEF Noise detected Clear Flag + * @arg @ref USART_CLEAR_OREF Overrun Error Clear Flag + * @arg @ref USART_CLEAR_IDLEF IDLE line detected Clear Flag + * @arg @ref USART_CLEAR_TCF Transmission Complete Clear Flag + * @arg @ref USART_CLEAR_RTOF Receiver Timeout clear flag + * @arg @ref USART_CLEAR_CTSF + * @retval None + */ +#define __HAL_USART_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__)) + +/** @brief Clear the USART PE pending flag. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_CLEAR_PEFLAG(__HANDLE__) __HAL_USART_CLEAR_FLAG((__HANDLE__), USART_CLEAR_PEF) + +/** @brief Clear the USART FE pending flag. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_CLEAR_FEFLAG(__HANDLE__) __HAL_USART_CLEAR_FLAG((__HANDLE__), USART_CLEAR_FEF) + +/** @brief Clear the USART NE pending flag. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_CLEAR_NEFLAG(__HANDLE__) __HAL_USART_CLEAR_FLAG((__HANDLE__), USART_CLEAR_NEF) + +/** @brief Clear the USART ORE pending flag. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_CLEAR_OREFLAG(__HANDLE__) __HAL_USART_CLEAR_FLAG((__HANDLE__), USART_CLEAR_OREF) + +/** @brief Clear the USART IDLE pending flag. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_CLEAR_IDLEFLAG(__HANDLE__) __HAL_USART_CLEAR_FLAG((__HANDLE__), USART_CLEAR_IDLEF) + + + +/** @brief Enable the specified USART interrupt. + * @param __HANDLE__ specifies the USART Handle. + * @param __INTERRUPT__ specifies the USART interrupt source to enable. + * This parameter can be one of the following values: + * @arg @ref USART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref USART_IT_TC Transmission complete interrupt + * @arg @ref USART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref USART_IT_IDLE Idle line detection interrupt + * @arg @ref USART_IT_PE Parity Error interrupt + * @arg @ref USART_IT_ERR Error interrupt(Frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_USART_ENABLE_IT(__HANDLE__, __INTERRUPT__)\ + (((((__INTERRUPT__) & USART_CR_MASK) >> USART_CR_POS) == 1U)?\ + ((__HANDLE__)->Instance->CR1 |= (1U << ((__INTERRUPT__) & USART_IT_MASK))): \ + ((((__INTERRUPT__) & USART_CR_MASK) >> USART_CR_POS) == 2U)?\ + ((__HANDLE__)->Instance->CR2 |= (1U << ((__INTERRUPT__) & USART_IT_MASK))): \ + ((__HANDLE__)->Instance->CR3 |= (1U << ((__INTERRUPT__) & USART_IT_MASK)))) + +/** @brief Disable the specified USART interrupt. + * @param __HANDLE__ specifies the USART Handle. + * @param __INTERRUPT__ specifies the USART interrupt source to disable. + * This parameter can be one of the following values: + * @arg @ref USART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref USART_IT_TC Transmission complete interrupt + * @arg @ref USART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref USART_IT_IDLE Idle line detection interrupt + * @arg @ref USART_IT_PE Parity Error interrupt + * @arg @ref USART_IT_ERR Error interrupt(Frame error, noise error, overrun error) + * @retval None + */ +#define __HAL_USART_DISABLE_IT(__HANDLE__, __INTERRUPT__)\ + (((((__INTERRUPT__) & USART_CR_MASK) >> USART_CR_POS) == 1U)?\ + ((__HANDLE__)->Instance->CR1 &= ~ (1U << ((__INTERRUPT__) & USART_IT_MASK))): \ + ((((__INTERRUPT__) & USART_CR_MASK) >> USART_CR_POS) == 2U)?\ + ((__HANDLE__)->Instance->CR2 &= ~ (1U << ((__INTERRUPT__) & USART_IT_MASK))): \ + ((__HANDLE__)->Instance->CR3 &= ~ (1U << ((__INTERRUPT__) & USART_IT_MASK)))) + +/** @brief Check whether the specified USART interrupt has occurred or not. + * @param __HANDLE__ specifies the USART Handle. + * @param __INTERRUPT__ specifies the USART interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref USART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref USART_IT_TC Transmission complete interrupt + * @arg @ref USART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref USART_IT_IDLE Idle line detection interrupt + * @arg @ref USART_IT_ORE OverRun Error interrupt + * @arg @ref USART_IT_NE Noise Error interrupt + * @arg @ref USART_IT_FE Framing Error interrupt + * @arg @ref USART_IT_PE Parity Error interrupt + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_USART_GET_IT(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->ISR\ + & (0x01U << (((__INTERRUPT__) & USART_ISR_MASK)>>\ + USART_ISR_POS))) != 0U) ? SET : RESET) + +/** @brief Check whether the specified USART interrupt source is enabled or not. + * @param __HANDLE__ specifies the USART Handle. + * @param __INTERRUPT__ specifies the USART interrupt source to check. + * This parameter can be one of the following values: + * @arg @ref USART_IT_TXE Transmit Data Register empty interrupt + * @arg @ref USART_IT_TC Transmission complete interrupt + * @arg @ref USART_IT_RXNE Receive Data register not empty interrupt + * @arg @ref USART_IT_IDLE Idle line detection interrupt + * @arg @ref USART_IT_ORE OverRun Error interrupt + * @arg @ref USART_IT_NE Noise Error interrupt + * @arg @ref USART_IT_FE Framing Error interrupt + * @arg @ref USART_IT_PE Parity Error interrupt + * @retval The new state of __INTERRUPT__ (SET or RESET). + */ +#define __HAL_USART_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((((((uint8_t)(__INTERRUPT__)) >> 0x05U) == 0x01U) ?\ + (__HANDLE__)->Instance->CR1 : \ + (((((uint8_t)(__INTERRUPT__)) >> 0x05U) == 0x02U) ?\ + (__HANDLE__)->Instance->CR2 : \ + (__HANDLE__)->Instance->CR3)) & (0x01U <<\ + (((uint16_t)(__INTERRUPT__)) &\ + USART_IT_MASK))) != 0U) ? SET : RESET) + +/** @brief Clear the specified USART ISR flag, in setting the proper ICR register flag. + * @param __HANDLE__ specifies the USART Handle. + * @param __IT_CLEAR__ specifies the interrupt clear register flag that needs to be set + * to clear the corresponding interrupt. + * This parameter can be one of the following values: + * @arg @ref USART_CLEAR_PEF Parity Error Clear Flag + * @arg @ref USART_CLEAR_FEF Framing Error Clear Flag + * @arg @ref USART_CLEAR_NEF Noise detected Clear Flag + * @arg @ref USART_CLEAR_OREF Overrun Error Clear Flag + * @arg @ref USART_CLEAR_IDLEF IDLE line detected Clear Flag + * @arg @ref USART_CLEAR_RTOF Receiver timeout clear flag + * @arg @ref USART_CLEAR_TCF Transmission Complete Clear Flag + * @retval None + */ +#define __HAL_USART_CLEAR_IT(__HANDLE__, __IT_CLEAR__) ((__HANDLE__)->Instance->ICR = (uint32_t)(__IT_CLEAR__)) + +/** @brief Set a specific USART request flag. + * @param __HANDLE__ specifies the USART Handle. + * @param __REQ__ specifies the request flag to set. + * This parameter can be one of the following values: + * @arg @ref USART_RXDATA_FLUSH_REQUEST Receive Data flush Request +#if defined(USART_RQR_TXFRQ) + * @arg @ref USART_TXDATA_FLUSH_REQUEST Transmit data flush Request +#endif + * + * @retval None + */ +#define __HAL_USART_SEND_REQ(__HANDLE__, __REQ__) ((__HANDLE__)->Instance->RQR |= (uint16_t)(__REQ__)) + +/** @brief Enable the USART one bit sample method. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_ONE_BIT_SAMPLE_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3|= USART_CR3_ONEBIT) + +/** @brief Disable the USART one bit sample method. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_ONE_BIT_SAMPLE_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR3 &= ~USART_CR3_ONEBIT) + +/** @brief Enable USART. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 |= USART_CR1_UE) + +/** @brief Disable USART. + * @param __HANDLE__ specifies the USART Handle. + * @retval None + */ +#define __HAL_USART_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR1 &= ~USART_CR1_UE) + +/** + * @} + */ + +/* Private macros --------------------------------------------------------*/ +/** @defgroup USART_Private_Macros USART Private Macros + * @{ + */ + +/** @brief BRR division operation to set BRR register in 8-bit oversampling mode. + * @param __PCLK__ USART clock. + * @param __BAUD__ Baud rate set by the user. + * @retval Division result + */ +#define USART_DIV_SAMPLING8(__PCLK__, __BAUD__) ((((__PCLK__)*2U) + ((__BAUD__)/2U)) / (__BAUD__)) + +/** @brief Check USART Baud rate. + * @param __BAUDRATE__ Baudrate specified by the user. + * The maximum Baud Rate is derived from the maximum clock on F0 (i.e. 48 MHz) + * divided by the smallest oversampling used on the USART (i.e. 8) + * @retval SET (__BAUDRATE__ is valid) or RESET (__BAUDRATE__ is invalid) */ +#define IS_USART_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) <= 6000000U) + +/** + * @brief Ensure that USART frame number of stop bits is valid. + * @param __STOPBITS__ USART frame number of stop bits. + * @retval SET (__STOPBITS__ is valid) or RESET (__STOPBITS__ is invalid) + */ +#if defined(USART_SMARTCARD_SUPPORT) +#define IS_USART_STOPBITS(__STOPBITS__) (((__STOPBITS__) == USART_STOPBITS_0_5) || \ + ((__STOPBITS__) == USART_STOPBITS_1) || \ + ((__STOPBITS__) == USART_STOPBITS_1_5) || \ + ((__STOPBITS__) == USART_STOPBITS_2)) +#else +#define IS_USART_STOPBITS(__STOPBITS__) (((__STOPBITS__) == USART_STOPBITS_1) || \ + ((__STOPBITS__) == USART_STOPBITS_2)) +#endif /* USART_SMARTCARD_SUPPORT */ + +/** + * @brief Ensure that USART frame parity is valid. + * @param __PARITY__ USART frame parity. + * @retval SET (__PARITY__ is valid) or RESET (__PARITY__ is invalid) + */ +#define IS_USART_PARITY(__PARITY__) (((__PARITY__) == USART_PARITY_NONE) || \ + ((__PARITY__) == USART_PARITY_EVEN) || \ + ((__PARITY__) == USART_PARITY_ODD)) + +/** + * @brief Ensure that USART communication mode is valid. + * @param __MODE__ USART communication mode. + * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid) + */ +#define IS_USART_MODE(__MODE__) ((((__MODE__) & 0xFFFFFFF3U) == 0x00U) && ((__MODE__) != 0x00U)) + +/** + * @brief Ensure that USART clock state is valid. + * @param __CLOCK__ USART clock state. + * @retval SET (__CLOCK__ is valid) or RESET (__CLOCK__ is invalid) + */ +#define IS_USART_CLOCK(__CLOCK__) (((__CLOCK__) == USART_CLOCK_DISABLE) || \ + ((__CLOCK__) == USART_CLOCK_ENABLE)) + +/** + * @brief Ensure that USART frame polarity is valid. + * @param __CPOL__ USART frame polarity. + * @retval SET (__CPOL__ is valid) or RESET (__CPOL__ is invalid) + */ +#define IS_USART_POLARITY(__CPOL__) (((__CPOL__) == USART_POLARITY_LOW) || ((__CPOL__) == USART_POLARITY_HIGH)) + +/** + * @brief Ensure that USART frame phase is valid. + * @param __CPHA__ USART frame phase. + * @retval SET (__CPHA__ is valid) or RESET (__CPHA__ is invalid) + */ +#define IS_USART_PHASE(__CPHA__) (((__CPHA__) == USART_PHASE_1EDGE) || ((__CPHA__) == USART_PHASE_2EDGE)) + +/** + * @brief Ensure that USART frame last bit clock pulse setting is valid. + * @param __LASTBIT__ USART frame last bit clock pulse setting. + * @retval SET (__LASTBIT__ is valid) or RESET (__LASTBIT__ is invalid) + */ +#define IS_USART_LASTBIT(__LASTBIT__) (((__LASTBIT__) == USART_LASTBIT_DISABLE) || \ + ((__LASTBIT__) == USART_LASTBIT_ENABLE)) + +/** + * @brief Ensure that USART request parameter is valid. + * @param __PARAM__ USART request parameter. + * @retval SET (__PARAM__ is valid) or RESET (__PARAM__ is invalid) + */ +#if defined(USART_RQR_TXFRQ) +#define IS_USART_REQUEST_PARAMETER(__PARAM__) (((__PARAM__) == USART_RXDATA_FLUSH_REQUEST) || \ + ((__PARAM__) == USART_TXDATA_FLUSH_REQUEST)) +#else +#define IS_USART_REQUEST_PARAMETER(__PARAM__) ((__PARAM__) == USART_RXDATA_FLUSH_REQUEST) +#endif /* USART_RQR_TXFRQ */ + +/** + * @} + */ + +/* Include USART HAL Extended module */ +#include "stm32f0xx_hal_usart_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup USART_Exported_Functions USART Exported Functions + * @{ + */ + +/** @addtogroup USART_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_USART_Init(USART_HandleTypeDef *husart); +HAL_StatusTypeDef HAL_USART_DeInit(USART_HandleTypeDef *husart); +void HAL_USART_MspInit(USART_HandleTypeDef *husart); +void HAL_USART_MspDeInit(USART_HandleTypeDef *husart); + +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_USART_RegisterCallback(USART_HandleTypeDef *husart, HAL_USART_CallbackIDTypeDef CallbackID, + pUSART_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_USART_UnRegisterCallback(USART_HandleTypeDef *husart, HAL_USART_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @addtogroup USART_Exported_Functions_Group2 IO operation functions + * @{ + */ + +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_USART_Transmit(USART_HandleTypeDef *husart, uint8_t *pTxData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_USART_Receive(USART_HandleTypeDef *husart, uint8_t *pRxData, uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_USART_TransmitReceive(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size, uint32_t Timeout); +HAL_StatusTypeDef HAL_USART_Transmit_IT(USART_HandleTypeDef *husart, uint8_t *pTxData, uint16_t Size); +HAL_StatusTypeDef HAL_USART_Receive_IT(USART_HandleTypeDef *husart, uint8_t *pRxData, uint16_t Size); +HAL_StatusTypeDef HAL_USART_TransmitReceive_IT(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size); +HAL_StatusTypeDef HAL_USART_Transmit_DMA(USART_HandleTypeDef *husart, uint8_t *pTxData, uint16_t Size); +HAL_StatusTypeDef HAL_USART_Receive_DMA(USART_HandleTypeDef *husart, uint8_t *pRxData, uint16_t Size); +HAL_StatusTypeDef HAL_USART_TransmitReceive_DMA(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size); +HAL_StatusTypeDef HAL_USART_DMAPause(USART_HandleTypeDef *husart); +HAL_StatusTypeDef HAL_USART_DMAResume(USART_HandleTypeDef *husart); +HAL_StatusTypeDef HAL_USART_DMAStop(USART_HandleTypeDef *husart); +/* Transfer Abort functions */ +HAL_StatusTypeDef HAL_USART_Abort(USART_HandleTypeDef *husart); +HAL_StatusTypeDef HAL_USART_Abort_IT(USART_HandleTypeDef *husart); + +void HAL_USART_IRQHandler(USART_HandleTypeDef *husart); +void HAL_USART_TxHalfCpltCallback(USART_HandleTypeDef *husart); +void HAL_USART_TxCpltCallback(USART_HandleTypeDef *husart); +void HAL_USART_RxCpltCallback(USART_HandleTypeDef *husart); +void HAL_USART_RxHalfCpltCallback(USART_HandleTypeDef *husart); +void HAL_USART_TxRxCpltCallback(USART_HandleTypeDef *husart); +void HAL_USART_ErrorCallback(USART_HandleTypeDef *husart); +void HAL_USART_AbortCpltCallback(USART_HandleTypeDef *husart); + +/** + * @} + */ + +/** @addtogroup USART_Exported_Functions_Group4 Peripheral State and Error functions + * @{ + */ + +/* Peripheral State and Error functions ***************************************/ +HAL_USART_StateTypeDef HAL_USART_GetState(USART_HandleTypeDef *husart); +uint32_t HAL_USART_GetError(USART_HandleTypeDef *husart); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_USART_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart_ex.h new file mode 100644 index 0000000..f8bd0ca --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_usart_ex.h @@ -0,0 +1,520 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_usart_ex.h + * @author MCD Application Team + * @brief Header file of USART HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_USART_EX_H +#define STM32F0xx_HAL_USART_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup USARTEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup USARTEx_Exported_Constants USARTEx Exported Constants + * @{ + */ + +/** @defgroup USARTEx_Word_Length USARTEx Word Length + * @{ + */ +#if defined(USART_CR1_M0)&& defined(USART_CR1_M1) +#define USART_WORDLENGTH_7B (USART_CR1_M1) /*!< 7-bit long USART frame */ +#define USART_WORDLENGTH_8B (0x00000000U) /*!< 8-bit long USART frame */ +#define USART_WORDLENGTH_9B (USART_CR1_M0) /*!< 9-bit long USART frame */ +#elif defined(USART_CR1_M) +#define USART_WORDLENGTH_8B (0x00000000U) /*!< 8-bit long USART frame */ +#define USART_WORDLENGTH_9B (USART_CR1_M) /*!< 9-bit long USART frame */ +#endif +/** + * @} + */ + + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup USARTEx_Private_Macros USARTEx Private Macros + * @{ + */ + +/** @brief Report the USART clock source. + * @param __HANDLE__ specifies the USART Handle. + * @param __CLOCKSOURCE__ output variable. + * @retval the USART clocking source, written in __CLOCKSOURCE__. + */ +/** @brief Report the UART clock source. + * @param __HANDLE__ specifies the UART Handle. + * @param __CLOCKSOURCE__ output variable. + * @retval UART clocking source, written in __CLOCKSOURCE__. + */ + +#if defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) +#define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } while(0) +#elif defined (STM32F030x8) || defined (STM32F070x6) || defined (STM32F042x6) || defined (STM32F048xx) || defined (STM32F051x8) || defined (STM32F058xx) +#define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined (STM32F070xB) +#define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) +#define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F091xC) || defined (STM32F098xx) +#define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + switch(__HAL_RCC_GET_USART2_SOURCE()) \ + { \ + case RCC_USART2CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART2CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART2CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART2CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + switch(__HAL_RCC_GET_USART3_SOURCE()) \ + { \ + case RCC_USART3CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART3CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART3CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART3CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART5) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART6) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART7) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART8) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#elif defined(STM32F030xC) +#define USART_GETCLOCKSOURCE(__HANDLE__,__CLOCKSOURCE__) \ + do { \ + if((__HANDLE__)->Instance == USART1) \ + { \ + switch(__HAL_RCC_GET_USART1_SOURCE()) \ + { \ + case RCC_USART1CLKSOURCE_PCLK1: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + break; \ + case RCC_USART1CLKSOURCE_HSI: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_HSI; \ + break; \ + case RCC_USART1CLKSOURCE_SYSCLK: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_SYSCLK; \ + break; \ + case RCC_USART1CLKSOURCE_LSE: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_LSE; \ + break; \ + default: \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + break; \ + } \ + } \ + else if((__HANDLE__)->Instance == USART2) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART3) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART4) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART5) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else if((__HANDLE__)->Instance == USART6) \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_PCLK1; \ + } \ + else \ + { \ + (__CLOCKSOURCE__) = USART_CLOCKSOURCE_UNDEFINED; \ + } \ + } while(0) +#endif /* defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) */ +/** @brief Compute the USART mask to apply to retrieve the received data + * according to the word length and to the parity bits activation. + * @note If PCE = 1, the parity bit is not included in the data extracted + * by the reception API(). + * This masking operation is not carried out in the case of + * DMA transfers. + * @param __HANDLE__ specifies the USART Handle. + * @retval None, the mask to apply to USART RDR register is stored in (__HANDLE__)->Mask field. + */ +#if defined(USART_CR1_M0)&& defined(USART_CR1_M1) +#define USART_MASK_COMPUTATION(__HANDLE__) \ + do { \ + if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_9B) \ + { \ + if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x01FFU; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x00FFU; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_8B) \ + { \ + if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x00FFU; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x007FU; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_7B) \ + { \ + if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x007FU; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x003FU; \ + } \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x0000U; \ + } \ + } while(0U) +#elif defined(USART_CR1_M) +#define USART_MASK_COMPUTATION(__HANDLE__) \ + do { \ + if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_9B) \ + { \ + if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x01FFU; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x00FFU; \ + } \ + } \ + else if ((__HANDLE__)->Init.WordLength == USART_WORDLENGTH_8B) \ + { \ + if ((__HANDLE__)->Init.Parity == USART_PARITY_NONE) \ + { \ + (__HANDLE__)->Mask = 0x00FFU; \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x007FU; \ + } \ + } \ + else \ + { \ + (__HANDLE__)->Mask = 0x0000U; \ + } \ + } while(0U) +#endif + +/** + * @brief Ensure that USART frame length is valid. + * @param __LENGTH__ USART frame length. + * @retval SET (__LENGTH__ is valid) or RESET (__LENGTH__ is invalid) + */ +#if defined(USART_CR1_M0)&& defined(USART_CR1_M1) +#define IS_USART_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == USART_WORDLENGTH_7B) || \ + ((__LENGTH__) == USART_WORDLENGTH_8B) || \ + ((__LENGTH__) == USART_WORDLENGTH_9B)) +#elif defined(USART_CR1_M) +#define IS_USART_WORD_LENGTH(__LENGTH__) (((__LENGTH__) == USART_WORDLENGTH_8B) || \ + ((__LENGTH__) == USART_WORDLENGTH_9B)) +#endif + + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup USARTEx_Exported_Functions + * @{ + */ + +/** @addtogroup USARTEx_Exported_Functions_Group1 + * @{ + */ + +/* IO operation functions *****************************************************/ + +/** + * @} + */ + +/** @addtogroup USARTEx_Exported_Functions_Group2 + * @{ + */ + +/* Peripheral Control functions ***********************************************/ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_USART_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_wwdg.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_wwdg.h new file mode 100644 index 0000000..6ba19ae --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_wwdg.h @@ -0,0 +1,301 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_wwdg.h + * @author MCD Application Team + * @brief Header file of WWDG HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_WWDG_H +#define STM32F0xx_HAL_WWDG_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup WWDG + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup WWDG_Exported_Types WWDG Exported Types + * @{ + */ + +/** + * @brief WWDG Init structure definition + */ +typedef struct +{ + uint32_t Prescaler; /*!< Specifies the prescaler value of the WWDG. + This parameter can be a value of @ref WWDG_Prescaler */ + + uint32_t Window; /*!< Specifies the WWDG window value to be compared to the downcounter. + This parameter must be a number Min_Data = 0x40 and Max_Data = 0x7F */ + + uint32_t Counter; /*!< Specifies the WWDG free-running downcounter value. + This parameter must be a number between Min_Data = 0x40 and Max_Data = 0x7F */ + + uint32_t EWIMode ; /*!< Specifies if WWDG Early Wakeup Interrupt is enable or not. + This parameter can be a value of @ref WWDG_EWI_Mode */ + +} WWDG_InitTypeDef; + +/** + * @brief WWDG handle Structure definition + */ +#if (USE_HAL_WWDG_REGISTER_CALLBACKS == 1) +typedef struct __WWDG_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_WWDG_REGISTER_CALLBACKS */ +{ + WWDG_TypeDef *Instance; /*!< Register base address */ + + WWDG_InitTypeDef Init; /*!< WWDG required parameters */ + +#if (USE_HAL_WWDG_REGISTER_CALLBACKS == 1) + void (* EwiCallback)(struct __WWDG_HandleTypeDef *hwwdg); /*!< WWDG Early WakeUp Interrupt callback */ + + void (* MspInitCallback)(struct __WWDG_HandleTypeDef *hwwdg); /*!< WWDG Msp Init callback */ +#endif /* USE_HAL_WWDG_REGISTER_CALLBACKS */ +} WWDG_HandleTypeDef; + +#if (USE_HAL_WWDG_REGISTER_CALLBACKS == 1) +/** + * @brief HAL WWDG common Callback ID enumeration definition + */ +typedef enum +{ + HAL_WWDG_EWI_CB_ID = 0x00U, /*!< WWDG EWI callback ID */ + HAL_WWDG_MSPINIT_CB_ID = 0x01U, /*!< WWDG MspInit callback ID */ +} HAL_WWDG_CallbackIDTypeDef; + +/** + * @brief HAL WWDG Callback pointer definition + */ +typedef void (*pWWDG_CallbackTypeDef)(WWDG_HandleTypeDef *hppp); /*!< pointer to a WWDG common callback functions */ + +#endif /* USE_HAL_WWDG_REGISTER_CALLBACKS */ +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup WWDG_Exported_Constants WWDG Exported Constants + * @{ + */ + +/** @defgroup WWDG_Interrupt_definition WWDG Interrupt definition + * @{ + */ +#define WWDG_IT_EWI WWDG_CFR_EWI /*!< Early wakeup interrupt */ +/** + * @} + */ + +/** @defgroup WWDG_Flag_definition WWDG Flag definition + * @brief WWDG Flag definition + * @{ + */ +#define WWDG_FLAG_EWIF WWDG_SR_EWIF /*!< Early wakeup interrupt flag */ +/** + * @} + */ + +/** @defgroup WWDG_Prescaler WWDG Prescaler + * @{ + */ +#define WWDG_PRESCALER_1 0x00000000u /*!< WWDG counter clock = (PCLK1/4096)/1 */ +#define WWDG_PRESCALER_2 WWDG_CFR_WDGTB_0 /*!< WWDG counter clock = (PCLK1/4096)/2 */ +#define WWDG_PRESCALER_4 WWDG_CFR_WDGTB_1 /*!< WWDG counter clock = (PCLK1/4096)/4 */ +#define WWDG_PRESCALER_8 (WWDG_CFR_WDGTB_1 | WWDG_CFR_WDGTB_0) /*!< WWDG counter clock = (PCLK1/4096)/8 */ +/** + * @} + */ + +/** @defgroup WWDG_EWI_Mode WWDG Early Wakeup Interrupt Mode + * @{ + */ +#define WWDG_EWI_DISABLE 0x00000000u /*!< EWI Disable */ +#define WWDG_EWI_ENABLE WWDG_CFR_EWI /*!< EWI Enable */ +/** + * @} + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ + +/** @defgroup WWDG_Private_Macros WWDG Private Macros + * @{ + */ +#define IS_WWDG_PRESCALER(__PRESCALER__) (((__PRESCALER__) == WWDG_PRESCALER_1) || \ + ((__PRESCALER__) == WWDG_PRESCALER_2) || \ + ((__PRESCALER__) == WWDG_PRESCALER_4) || \ + ((__PRESCALER__) == WWDG_PRESCALER_8)) + +#define IS_WWDG_WINDOW(__WINDOW__) (((__WINDOW__) >= WWDG_CFR_W_6) && ((__WINDOW__) <= WWDG_CFR_W)) + +#define IS_WWDG_COUNTER(__COUNTER__) (((__COUNTER__) >= WWDG_CR_T_6) && ((__COUNTER__) <= WWDG_CR_T)) + +#define IS_WWDG_EWI_MODE(__MODE__) (((__MODE__) == WWDG_EWI_ENABLE) || \ + ((__MODE__) == WWDG_EWI_DISABLE)) +/** + * @} + */ + + +/* Exported macros ------------------------------------------------------------*/ + +/** @defgroup WWDG_Exported_Macros WWDG Exported Macros + * @{ + */ + +/** + * @brief Enable the WWDG peripheral. + * @param __HANDLE__ WWDG handle + * @retval None + */ +#define __HAL_WWDG_ENABLE(__HANDLE__) SET_BIT((__HANDLE__)->Instance->CR, WWDG_CR_WDGA) + +/** + * @brief Enable the WWDG early wakeup interrupt. + * @param __HANDLE__: WWDG handle + * @param __INTERRUPT__ specifies the interrupt to enable. + * This parameter can be one of the following values: + * @arg WWDG_IT_EWI: Early wakeup interrupt + * @note Once enabled this interrupt cannot be disabled except by a system reset. + * @retval None + */ +#define __HAL_WWDG_ENABLE_IT(__HANDLE__, __INTERRUPT__) SET_BIT((__HANDLE__)->Instance->CFR, (__INTERRUPT__)) + +/** + * @brief Check whether the selected WWDG interrupt has occurred or not. + * @param __HANDLE__ WWDG handle + * @param __INTERRUPT__ specifies the it to check. + * This parameter can be one of the following values: + * @arg WWDG_FLAG_EWIF: Early wakeup interrupt IT + * @retval The new state of WWDG_FLAG (SET or RESET). + */ +#define __HAL_WWDG_GET_IT(__HANDLE__, __INTERRUPT__) __HAL_WWDG_GET_FLAG((__HANDLE__),(__INTERRUPT__)) + +/** @brief Clear the WWDG interrupt pending bits. + * bits to clear the selected interrupt pending bits. + * @param __HANDLE__ WWDG handle + * @param __INTERRUPT__ specifies the interrupt pending bit to clear. + * This parameter can be one of the following values: + * @arg WWDG_FLAG_EWIF: Early wakeup interrupt flag + */ +#define __HAL_WWDG_CLEAR_IT(__HANDLE__, __INTERRUPT__) __HAL_WWDG_CLEAR_FLAG((__HANDLE__), (__INTERRUPT__)) + +/** + * @brief Check whether the specified WWDG flag is set or not. + * @param __HANDLE__ WWDG handle + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg WWDG_FLAG_EWIF: Early wakeup interrupt flag + * @retval The new state of WWDG_FLAG (SET or RESET). + */ +#define __HAL_WWDG_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->SR & (__FLAG__)) == (__FLAG__)) + +/** + * @brief Clear the WWDG's pending flags. + * @param __HANDLE__ WWDG handle + * @param __FLAG__ specifies the flag to clear. + * This parameter can be one of the following values: + * @arg WWDG_FLAG_EWIF: Early wakeup interrupt flag + * @retval None + */ +#define __HAL_WWDG_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->SR = ~(__FLAG__)) + +/** @brief Check whether the specified WWDG interrupt source is enabled or not. + * @param __HANDLE__ WWDG Handle. + * @param __INTERRUPT__ specifies the WWDG interrupt source to check. + * This parameter can be one of the following values: + * @arg WWDG_IT_EWI: Early Wakeup Interrupt + * @retval state of __INTERRUPT__ (TRUE or FALSE). + */ +#define __HAL_WWDG_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CFR\ + & (__INTERRUPT__)) == (__INTERRUPT__)) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup WWDG_Exported_Functions + * @{ + */ + +/** @addtogroup WWDG_Exported_Functions_Group1 + * @{ + */ +/* Initialization/de-initialization functions **********************************/ +HAL_StatusTypeDef HAL_WWDG_Init(WWDG_HandleTypeDef *hwwdg); +void HAL_WWDG_MspInit(WWDG_HandleTypeDef *hwwdg); +/* Callbacks Register/UnRegister functions ***********************************/ +#if (USE_HAL_WWDG_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_WWDG_RegisterCallback(WWDG_HandleTypeDef *hwwdg, HAL_WWDG_CallbackIDTypeDef CallbackID, + pWWDG_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_WWDG_UnRegisterCallback(WWDG_HandleTypeDef *hwwdg, HAL_WWDG_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_WWDG_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @addtogroup WWDG_Exported_Functions_Group2 + * @{ + */ +/* I/O operation functions ******************************************************/ +HAL_StatusTypeDef HAL_WWDG_Refresh(WWDG_HandleTypeDef *hwwdg); +void HAL_WWDG_IRQHandler(WWDG_HandleTypeDef *hwwdg); +void HAL_WWDG_EarlyWakeupCallback(WWDG_HandleTypeDef *hwwdg); +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_WWDG_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_adc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_adc.h new file mode 100644 index 0000000..d96a8c0 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_adc.h @@ -0,0 +1,3411 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_adc.h + * @author MCD Application Team + * @brief Header file of ADC LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_ADC_H +#define __STM32F0xx_LL_ADC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (ADC1) + +/** @defgroup ADC_LL ADC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup ADC_LL_Private_Constants ADC Private Constants + * @{ + */ + +/* Internal mask for ADC group regular trigger: */ +/* To select into literal LL_ADC_REG_TRIG_x the relevant bits for: */ +/* - regular trigger source */ +/* - regular trigger edge */ +#define ADC_REG_TRIG_EXT_EDGE_DEFAULT (ADC_CFGR1_EXTEN_0) /* Trigger edge set to rising edge (default setting for compatibility with some ADC on other STM32 families having this setting set by HW default value) */ + +/* Mask containing trigger source masks for each of possible */ +/* trigger edge selection duplicated with shifts [0; 4; 8; 12] */ +/* corresponding to {SW start; ext trigger; ext trigger; ext trigger}. */ +#define ADC_REG_TRIG_SOURCE_MASK (((LL_ADC_REG_TRIG_SOFTWARE & ADC_CFGR1_EXTSEL) << (4U * 0U)) | \ + ((ADC_CFGR1_EXTSEL) << (4U * 1U)) | \ + ((ADC_CFGR1_EXTSEL) << (4U * 2U)) | \ + ((ADC_CFGR1_EXTSEL) << (4U * 3U)) ) + +/* Mask containing trigger edge masks for each of possible */ +/* trigger edge selection duplicated with shifts [0; 4; 8; 12] */ +/* corresponding to {SW start; ext trigger; ext trigger; ext trigger}. */ +#define ADC_REG_TRIG_EDGE_MASK (((LL_ADC_REG_TRIG_SOFTWARE & ADC_CFGR1_EXTEN) << (4U * 0U)) | \ + ((ADC_REG_TRIG_EXT_EDGE_DEFAULT) << (4U * 1U)) | \ + ((ADC_REG_TRIG_EXT_EDGE_DEFAULT) << (4U * 2U)) | \ + ((ADC_REG_TRIG_EXT_EDGE_DEFAULT) << (4U * 3U)) ) + +/* Definition of ADC group regular trigger bits information. */ +#define ADC_REG_TRIG_EXTSEL_BITOFFSET_POS ( 6U) /* Value equivalent to POSITION_VAL(ADC_CFGR1_EXTSEL) */ +#define ADC_REG_TRIG_EXTEN_BITOFFSET_POS (10U) /* Value equivalent to POSITION_VAL(ADC_CFGR1_EXTEN) */ + + + +/* Internal mask for ADC channel: */ +/* To select into literal LL_ADC_CHANNEL_x the relevant bits for: */ +/* - channel identifier defined by number */ +/* - channel identifier defined by bitfield */ +/* - channel differentiation between external channels (connected to */ +/* GPIO pins) and internal channels (connected to internal paths) */ +#define ADC_CHANNEL_ID_NUMBER_MASK (ADC_CFGR1_AWDCH) +#define ADC_CHANNEL_ID_BITFIELD_MASK (ADC_CHSELR_CHSEL) +#define ADC_CHANNEL_ID_NUMBER_BITOFFSET_POS (26U)/* Value equivalent to POSITION_VAL(ADC_CHANNEL_ID_NUMBER_MASK) */ +#define ADC_CHANNEL_ID_MASK (ADC_CHANNEL_ID_NUMBER_MASK | ADC_CHANNEL_ID_BITFIELD_MASK | ADC_CHANNEL_ID_INTERNAL_CH_MASK) +/* Equivalent mask of ADC_CHANNEL_NUMBER_MASK aligned on register LSB (bit 0) */ +#define ADC_CHANNEL_ID_NUMBER_MASK_POSBIT0 (0x0000001FU) /* Equivalent to shift: (ADC_CHANNEL_NUMBER_MASK >> POSITION_VAL(ADC_CHANNEL_NUMBER_MASK)) */ + +/* Channel differentiation between external and internal channels */ +#define ADC_CHANNEL_ID_INTERNAL_CH (0x80000000U) /* Marker of internal channel */ +#define ADC_CHANNEL_ID_INTERNAL_CH_MASK (ADC_CHANNEL_ID_INTERNAL_CH) + +/* Definition of channels ID number information to be inserted into */ +/* channels literals definition. */ +#define ADC_CHANNEL_0_NUMBER (0x00000000U) +#define ADC_CHANNEL_1_NUMBER ( ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_2_NUMBER ( ADC_CFGR1_AWDCH_1 ) +#define ADC_CHANNEL_3_NUMBER ( ADC_CFGR1_AWDCH_1 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_4_NUMBER ( ADC_CFGR1_AWDCH_2 ) +#define ADC_CHANNEL_5_NUMBER ( ADC_CFGR1_AWDCH_2 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_6_NUMBER ( ADC_CFGR1_AWDCH_2 | ADC_CFGR1_AWDCH_1 ) +#define ADC_CHANNEL_7_NUMBER ( ADC_CFGR1_AWDCH_2 | ADC_CFGR1_AWDCH_1 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_8_NUMBER ( ADC_CFGR1_AWDCH_3 ) +#define ADC_CHANNEL_9_NUMBER ( ADC_CFGR1_AWDCH_3 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_10_NUMBER ( ADC_CFGR1_AWDCH_3 | ADC_CFGR1_AWDCH_1 ) +#define ADC_CHANNEL_11_NUMBER ( ADC_CFGR1_AWDCH_3 | ADC_CFGR1_AWDCH_1 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_12_NUMBER ( ADC_CFGR1_AWDCH_3 | ADC_CFGR1_AWDCH_2 ) +#define ADC_CHANNEL_13_NUMBER ( ADC_CFGR1_AWDCH_3 | ADC_CFGR1_AWDCH_2 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_14_NUMBER ( ADC_CFGR1_AWDCH_3 | ADC_CFGR1_AWDCH_2 | ADC_CFGR1_AWDCH_1 ) +#define ADC_CHANNEL_15_NUMBER ( ADC_CFGR1_AWDCH_3 | ADC_CFGR1_AWDCH_2 | ADC_CFGR1_AWDCH_1 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_16_NUMBER (ADC_CFGR1_AWDCH_4 ) +#define ADC_CHANNEL_17_NUMBER (ADC_CFGR1_AWDCH_4 | ADC_CFGR1_AWDCH_0) +#define ADC_CHANNEL_18_NUMBER (ADC_CFGR1_AWDCH_4 | ADC_CFGR1_AWDCH_1 ) + +/* Definition of channels ID bitfield information to be inserted into */ +/* channels literals definition. */ +#define ADC_CHANNEL_0_BITFIELD (ADC_CHSELR_CHSEL0) +#define ADC_CHANNEL_1_BITFIELD (ADC_CHSELR_CHSEL1) +#define ADC_CHANNEL_2_BITFIELD (ADC_CHSELR_CHSEL2) +#define ADC_CHANNEL_3_BITFIELD (ADC_CHSELR_CHSEL3) +#define ADC_CHANNEL_4_BITFIELD (ADC_CHSELR_CHSEL4) +#define ADC_CHANNEL_5_BITFIELD (ADC_CHSELR_CHSEL5) +#define ADC_CHANNEL_6_BITFIELD (ADC_CHSELR_CHSEL6) +#define ADC_CHANNEL_7_BITFIELD (ADC_CHSELR_CHSEL7) +#define ADC_CHANNEL_8_BITFIELD (ADC_CHSELR_CHSEL8) +#define ADC_CHANNEL_9_BITFIELD (ADC_CHSELR_CHSEL9) +#define ADC_CHANNEL_10_BITFIELD (ADC_CHSELR_CHSEL10) +#define ADC_CHANNEL_11_BITFIELD (ADC_CHSELR_CHSEL11) +#define ADC_CHANNEL_12_BITFIELD (ADC_CHSELR_CHSEL12) +#define ADC_CHANNEL_13_BITFIELD (ADC_CHSELR_CHSEL13) +#define ADC_CHANNEL_14_BITFIELD (ADC_CHSELR_CHSEL14) +#define ADC_CHANNEL_15_BITFIELD (ADC_CHSELR_CHSEL15) +#define ADC_CHANNEL_16_BITFIELD (ADC_CHSELR_CHSEL16) +#define ADC_CHANNEL_17_BITFIELD (ADC_CHSELR_CHSEL17) +#define ADC_CHANNEL_18_BITFIELD (ADC_CHSELR_CHSEL18) + +/* Internal mask for ADC analog watchdog: */ +/* To select into literals LL_ADC_AWD_CHANNELx_xxx the relevant bits for: */ +/* (concatenation of multiple bits used in different analog watchdogs, */ +/* (feature of several watchdogs not available on all STM32 families)). */ +/* - analog watchdog 1: monitored channel defined by number, */ +/* selection of ADC group (ADC group regular). */ + +/* Internal register offset for ADC analog watchdog channel configuration */ +#define ADC_AWD_CR1_REGOFFSET (0x00000000U) + +#define ADC_AWD_CRX_REGOFFSET_MASK (ADC_AWD_CR1_REGOFFSET) + +#define ADC_AWD_CR1_CHANNEL_MASK (ADC_CFGR1_AWDCH | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) +#define ADC_AWD_CR_ALL_CHANNEL_MASK (ADC_AWD_CR1_CHANNEL_MASK) + +/* Internal register offset for ADC analog watchdog threshold configuration */ +#define ADC_AWD_TR1_REGOFFSET (ADC_AWD_CR1_REGOFFSET) +#define ADC_AWD_TRX_REGOFFSET_MASK (ADC_AWD_TR1_REGOFFSET) + + +/* ADC registers bits positions */ +#define ADC_CFGR1_RES_BITOFFSET_POS ( 3U) /* Value equivalent to POSITION_VAL(ADC_CFGR1_RES) */ +#define ADC_CFGR1_AWDSGL_BITOFFSET_POS (22U) /* Value equivalent to POSITION_VAL(ADC_CFGR1_AWDSGL) */ +#define ADC_TR_HT_BITOFFSET_POS (16U) /* Value equivalent to POSITION_VAL(ADC_TR_HT) */ +#define ADC_CHSELR_CHSEL0_BITOFFSET_POS ( 0U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL0) */ +#define ADC_CHSELR_CHSEL1_BITOFFSET_POS ( 1U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL1) */ +#define ADC_CHSELR_CHSEL2_BITOFFSET_POS ( 2U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL2) */ +#define ADC_CHSELR_CHSEL3_BITOFFSET_POS ( 3U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL3) */ +#define ADC_CHSELR_CHSEL4_BITOFFSET_POS ( 4U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL4) */ +#define ADC_CHSELR_CHSEL5_BITOFFSET_POS ( 5U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL5) */ +#define ADC_CHSELR_CHSEL6_BITOFFSET_POS ( 6U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL6) */ +#define ADC_CHSELR_CHSEL7_BITOFFSET_POS ( 7U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL7) */ +#define ADC_CHSELR_CHSEL8_BITOFFSET_POS ( 8U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL8) */ +#define ADC_CHSELR_CHSEL9_BITOFFSET_POS ( 9U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL9) */ +#define ADC_CHSELR_CHSEL10_BITOFFSET_POS (10U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL10) */ +#define ADC_CHSELR_CHSEL11_BITOFFSET_POS (11U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL11) */ +#define ADC_CHSELR_CHSEL12_BITOFFSET_POS (12U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL12) */ +#define ADC_CHSELR_CHSEL13_BITOFFSET_POS (13U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL13) */ +#define ADC_CHSELR_CHSEL14_BITOFFSET_POS (14U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL14) */ +#define ADC_CHSELR_CHSEL15_BITOFFSET_POS (15U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL15) */ +#define ADC_CHSELR_CHSEL16_BITOFFSET_POS (16U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL16) */ +#define ADC_CHSELR_CHSEL17_BITOFFSET_POS (17U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL17) */ +#define ADC_CHSELR_CHSEL18_BITOFFSET_POS (18U) /* Value equivalent to POSITION_VAL(ADC_CHSELR_CHSEL18) */ + + +/* ADC registers bits groups */ +#define ADC_CR_BITS_PROPERTY_RS (ADC_CR_ADCAL | ADC_CR_ADSTP | ADC_CR_ADSTART | ADC_CR_ADDIS | ADC_CR_ADEN) /* ADC register CR bits with HW property "rs": Software can read as well as set this bit. Writing '0' has no effect on the bit value. */ + + +/* ADC internal channels related definitions */ +/* Internal voltage reference VrefInt */ +#define VREFINT_CAL_ADDR ((uint16_t*) (0x1FFFF7BAU)) /* Internal voltage reference, address of parameter VREFINT_CAL: VrefInt ADC raw data acquired at temperature 30 DegC (tolerance: +-5 DegC), Vref+ = 3.3 V (tolerance: +-10 mV). */ +#define VREFINT_CAL_VREF ( 3300U) /* Analog voltage reference (Vref+) value with which temperature sensor has been calibrated in production (tolerance: +-10 mV) (unit: mV). */ +/* Temperature sensor */ +#define TEMPSENSOR_CAL1_ADDR ((uint16_t*) (0x1FFFF7B8U)) /* Internal temperature sensor, address of parameter TS_CAL1: On STM32F0, temperature sensor ADC raw data acquired at temperature 30 DegC (tolerance: +-5 DegC), Vref+ = 3.3 V (tolerance: +-10 mV). */ +#define TEMPSENSOR_CAL2_ADDR ((uint16_t*) (0x1FFFF7C2U)) /* Internal temperature sensor, address of parameter TS_CAL2: On STM32F0, temperature sensor ADC raw data acquired at temperature 110 DegC (tolerance: +-5 DegC), Vref+ = 3.3 V (tolerance: +-10 mV). */ +#define TEMPSENSOR_CAL1_TEMP (( int32_t) 30) /* Internal temperature sensor, temperature at which temperature sensor has been calibrated in production for data into TEMPSENSOR_CAL1_ADDR (tolerance: +-5 DegC) (unit: DegC). */ +#define TEMPSENSOR_CAL2_TEMP (( int32_t) 110) /* Internal temperature sensor, temperature at which temperature sensor has been calibrated in production for data into TEMPSENSOR_CAL2_ADDR (tolerance: +-5 DegC) (unit: DegC). */ +#define TEMPSENSOR_CAL_VREFANALOG ( 3300U) /* Analog voltage reference (Vref+) voltage with which temperature sensor has been calibrated in production (+-10 mV) (unit: mV). */ + + +/** + * @} + */ + + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup ADC_LL_ES_INIT ADC Exported Init structure + * @{ + */ + +/** + * @brief Structure definition of some features of ADC instance. + * @note These parameters have an impact on ADC scope: ADC instance. + * Refer to corresponding unitary functions into + * @ref ADC_LL_EF_Configuration_ADC_Instance . + * @note The setting of these parameters by function @ref LL_ADC_Init() + * is conditioned to ADC state: + * ADC instance must be disabled. + * This condition is applied to all ADC features, for efficiency + * and compatibility over all STM32 families. However, the different + * features can be set under different ADC state conditions + * (setting possible with ADC enabled without conversion on going, + * ADC enabled with conversion on going, ...) + * Each feature can be updated afterwards with a unitary function + * and potentially with ADC in a different state than disabled, + * refer to description of each function for setting + * conditioned to ADC state. + */ +typedef struct +{ + uint32_t Clock; /*!< Set ADC instance clock source and prescaler. + This parameter can be a value of @ref ADC_LL_EC_CLOCK_SOURCE + @note On this STM32 serie, this parameter has some clock ratio constraints: + ADC clock synchronous (from PCLK) with prescaler 1 must be enabled only if PCLK has a 50% duty clock cycle + (APB prescaler configured inside the RCC must be bypassed and the system clock must by 50% duty cycle). + + + This feature can be modified afterwards using unitary function @ref LL_ADC_SetClock(). + For more details, refer to description of this function. */ + + uint32_t Resolution; /*!< Set ADC resolution. + This parameter can be a value of @ref ADC_LL_EC_RESOLUTION + + This feature can be modified afterwards using unitary function @ref LL_ADC_SetResolution(). */ + + uint32_t DataAlignment; /*!< Set ADC conversion data alignment. + This parameter can be a value of @ref ADC_LL_EC_DATA_ALIGN + + This feature can be modified afterwards using unitary function @ref LL_ADC_SetDataAlignment(). */ + + uint32_t LowPowerMode; /*!< Set ADC low power mode. + This parameter can be a value of @ref ADC_LL_EC_LP_MODE + + This feature can be modified afterwards using unitary function @ref LL_ADC_SetLowPowerMode(). */ + +} LL_ADC_InitTypeDef; + +/** + * @brief Structure definition of some features of ADC group regular. + * @note These parameters have an impact on ADC scope: ADC group regular. + * Refer to corresponding unitary functions into + * @ref ADC_LL_EF_Configuration_ADC_Group_Regular + * (functions with prefix "REG"). + * @note The setting of these parameters by function @ref LL_ADC_REG_Init() + * is conditioned to ADC state: + * ADC instance must be disabled. + * This condition is applied to all ADC features, for efficiency + * and compatibility over all STM32 families. However, the different + * features can be set under different ADC state conditions + * (setting possible with ADC enabled without conversion on going, + * ADC enabled with conversion on going, ...) + * Each feature can be updated afterwards with a unitary function + * and potentially with ADC in a different state than disabled, + * refer to description of each function for setting + * conditioned to ADC state. + */ +typedef struct +{ + uint32_t TriggerSource; /*!< Set ADC group regular conversion trigger source: internal (SW start) or from external IP (timer event, external interrupt line). + This parameter can be a value of @ref ADC_LL_EC_REG_TRIGGER_SOURCE + @note On this STM32 serie, setting trigger source to external trigger also set trigger polarity to rising edge + (default setting for compatibility with some ADC on other STM32 families having this setting set by HW default value). + In case of need to modify trigger edge, use function @ref LL_ADC_REG_SetTriggerEdge(). + + This feature can be modified afterwards using unitary function @ref LL_ADC_REG_SetTriggerSource(). */ + + uint32_t SequencerDiscont; /*!< Set ADC group regular sequencer discontinuous mode: sequence subdivided and scan conversions interrupted every selected number of ranks. + This parameter can be a value of @ref ADC_LL_EC_REG_SEQ_DISCONT_MODE + @note This parameter has an effect only if group regular sequencer is enabled + (several ADC channels enabled in group regular sequencer). + + This feature can be modified afterwards using unitary function @ref LL_ADC_REG_SetSequencerDiscont(). */ + + uint32_t ContinuousMode; /*!< Set ADC continuous conversion mode on ADC group regular, whether ADC conversions are performed in single mode (one conversion per trigger) or in continuous mode (after the first trigger, following conversions launched successively automatically). + This parameter can be a value of @ref ADC_LL_EC_REG_CONTINUOUS_MODE + Note: It is not possible to enable both ADC group regular continuous mode and discontinuous mode. + + This feature can be modified afterwards using unitary function @ref LL_ADC_REG_SetContinuousMode(). */ + + uint32_t DMATransfer; /*!< Set ADC group regular conversion data transfer: no transfer or transfer by DMA, and DMA requests mode. + This parameter can be a value of @ref ADC_LL_EC_REG_DMA_TRANSFER + + This feature can be modified afterwards using unitary function @ref LL_ADC_REG_SetDMATransfer(). */ + + uint32_t Overrun; /*!< Set ADC group regular behavior in case of overrun: + data preserved or overwritten. + This parameter can be a value of @ref ADC_LL_EC_REG_OVR_DATA_BEHAVIOR + + This feature can be modified afterwards using unitary function @ref LL_ADC_REG_SetOverrun(). */ + +} LL_ADC_REG_InitTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup ADC_LL_Exported_Constants ADC Exported Constants + * @{ + */ + +/** @defgroup ADC_LL_EC_FLAG ADC flags + * @brief Flags defines which can be used with LL_ADC_ReadReg function + * @{ + */ +#define LL_ADC_FLAG_ADRDY ADC_ISR_ADRDY /*!< ADC flag ADC instance ready */ +#define LL_ADC_FLAG_EOC ADC_ISR_EOC /*!< ADC flag ADC group regular end of unitary conversion */ +#define LL_ADC_FLAG_EOS ADC_ISR_EOS /*!< ADC flag ADC group regular end of sequence conversions */ +#define LL_ADC_FLAG_OVR ADC_ISR_OVR /*!< ADC flag ADC group regular overrun */ +#define LL_ADC_FLAG_EOSMP ADC_ISR_EOSMP /*!< ADC flag ADC group regular end of sampling phase */ +#define LL_ADC_FLAG_AWD1 ADC_ISR_AWD /*!< ADC flag ADC analog watchdog 1 */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_IT ADC interruptions for configuration (interruption enable or disable) + * @brief IT defines which can be used with LL_ADC_ReadReg and LL_ADC_WriteReg functions + * @{ + */ +#define LL_ADC_IT_ADRDY ADC_IER_ADRDYIE /*!< ADC interruption ADC instance ready */ +#define LL_ADC_IT_EOC ADC_IER_EOCIE /*!< ADC interruption ADC group regular end of unitary conversion */ +#define LL_ADC_IT_EOS ADC_IER_EOSIE /*!< ADC interruption ADC group regular end of sequence conversions */ +#define LL_ADC_IT_OVR ADC_IER_OVRIE /*!< ADC interruption ADC group regular overrun */ +#define LL_ADC_IT_EOSMP ADC_IER_EOSMPIE /*!< ADC interruption ADC group regular end of sampling phase */ +#define LL_ADC_IT_AWD1 ADC_IER_AWDIE /*!< ADC interruption ADC analog watchdog 1 */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REGISTERS ADC registers compliant with specific purpose + * @{ + */ +/* List of ADC registers intended to be used (most commonly) with */ +/* DMA transfer. */ +/* Refer to function @ref LL_ADC_DMA_GetRegAddr(). */ +#define LL_ADC_DMA_REG_REGULAR_DATA (0x00000000U) /* ADC group regular conversion data register (corresponding to register DR) to be used with ADC configured in independent mode. Without DMA transfer, register accessed by LL function @ref LL_ADC_REG_ReadConversionData32() and other functions @ref LL_ADC_REG_ReadConversionDatax() */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_COMMON_PATH_INTERNAL ADC common - Measurement path to internal channels + * @{ + */ +/* Note: Other measurement paths to internal channels may be available */ +/* (connections to other peripherals). */ +/* If they are not listed below, they do not require any specific */ +/* path enable. In this case, Access to measurement path is done */ +/* only by selecting the corresponding ADC internal channel. */ +#define LL_ADC_PATH_INTERNAL_NONE (0x00000000U)/*!< ADC measurement pathes all disabled */ +#define LL_ADC_PATH_INTERNAL_VREFINT (ADC_CCR_VREFEN) /*!< ADC measurement path to internal channel VrefInt */ +#define LL_ADC_PATH_INTERNAL_TEMPSENSOR (ADC_CCR_TSEN) /*!< ADC measurement path to internal channel temperature sensor */ +#if defined(ADC_CCR_VBATEN) +#define LL_ADC_PATH_INTERNAL_VBAT (ADC_CCR_VBATEN) /*!< ADC measurement path to internal channel Vbat */ +#endif +/** + * @} + */ + +/** @defgroup ADC_LL_EC_CLOCK_SOURCE ADC instance - Clock source + * @{ + */ +#define LL_ADC_CLOCK_SYNC_PCLK_DIV4 (ADC_CFGR2_CKMODE_1) /*!< ADC synchronous clock derived from AHB clock divided by 4 */ +#define LL_ADC_CLOCK_SYNC_PCLK_DIV2 (ADC_CFGR2_CKMODE_0) /*!< ADC synchronous clock derived from AHB clock divided by 2 */ +#define LL_ADC_CLOCK_ASYNC (0x00000000U) /*!< ADC asynchronous clock. On this STM32 serie, asynchronous clock has no prescaler. */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_RESOLUTION ADC instance - Resolution + * @{ + */ +#define LL_ADC_RESOLUTION_12B (0x00000000U) /*!< ADC resolution 12 bits */ +#define LL_ADC_RESOLUTION_10B ( ADC_CFGR1_RES_0) /*!< ADC resolution 10 bits */ +#define LL_ADC_RESOLUTION_8B (ADC_CFGR1_RES_1 ) /*!< ADC resolution 8 bits */ +#define LL_ADC_RESOLUTION_6B (ADC_CFGR1_RES_1 | ADC_CFGR1_RES_0) /*!< ADC resolution 6 bits */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_DATA_ALIGN ADC instance - Data alignment + * @{ + */ +#define LL_ADC_DATA_ALIGN_RIGHT (0x00000000U)/*!< ADC conversion data alignment: right aligned (alignment on data register LSB bit 0)*/ +#define LL_ADC_DATA_ALIGN_LEFT (ADC_CFGR1_ALIGN) /*!< ADC conversion data alignment: left aligned (aligment on data register MSB bit 15)*/ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_LP_MODE ADC instance - Low power mode + * @{ + */ +#define LL_ADC_LP_MODE_NONE (0x00000000U) /*!< No ADC low power mode activated */ +#define LL_ADC_LP_AUTOWAIT (ADC_CFGR1_WAIT) /*!< ADC low power mode auto delay: Dynamic low power mode, ADC conversions are performed only when necessary (when previous ADC conversion data is read). See description with function @ref LL_ADC_SetLowPowerMode(). */ +#define LL_ADC_LP_AUTOPOWEROFF (ADC_CFGR1_AUTOFF) /*!< ADC low power mode auto power-off: the ADC automatically powers-off after a ADC conversion and automatically wakes up when a new ADC conversion is triggered (with startup time between trigger and start of sampling). See description with function @ref LL_ADC_SetLowPowerMode(). Note: On STM32F0, if enabled, this feature also turns off the ADC dedicated 14 MHz RC oscillator (HSI14) during auto wait phase. */ +#define LL_ADC_LP_AUTOWAIT_AUTOPOWEROFF (ADC_CFGR1_WAIT | ADC_CFGR1_AUTOFF) /*!< ADC low power modes auto wait and auto power-off combined. See description with function @ref LL_ADC_SetLowPowerMode(). */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_GROUPS ADC instance - Groups + * @{ + */ +#define LL_ADC_GROUP_REGULAR (0x00000001U) /*!< ADC group regular (available on all STM32 devices) */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_CHANNEL ADC instance - Channel number + * @{ + */ +#define LL_ADC_CHANNEL_0 (ADC_CHANNEL_0_NUMBER | ADC_CHANNEL_0_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN0 */ +#define LL_ADC_CHANNEL_1 (ADC_CHANNEL_1_NUMBER | ADC_CHANNEL_1_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN1 */ +#define LL_ADC_CHANNEL_2 (ADC_CHANNEL_2_NUMBER | ADC_CHANNEL_2_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN2 */ +#define LL_ADC_CHANNEL_3 (ADC_CHANNEL_3_NUMBER | ADC_CHANNEL_3_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN3 */ +#define LL_ADC_CHANNEL_4 (ADC_CHANNEL_4_NUMBER | ADC_CHANNEL_4_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN4 */ +#define LL_ADC_CHANNEL_5 (ADC_CHANNEL_5_NUMBER | ADC_CHANNEL_5_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN5 */ +#define LL_ADC_CHANNEL_6 (ADC_CHANNEL_6_NUMBER | ADC_CHANNEL_6_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN6 */ +#define LL_ADC_CHANNEL_7 (ADC_CHANNEL_7_NUMBER | ADC_CHANNEL_7_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN7 */ +#define LL_ADC_CHANNEL_8 (ADC_CHANNEL_8_NUMBER | ADC_CHANNEL_8_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN8 */ +#define LL_ADC_CHANNEL_9 (ADC_CHANNEL_9_NUMBER | ADC_CHANNEL_9_BITFIELD ) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN9 */ +#define LL_ADC_CHANNEL_10 (ADC_CHANNEL_10_NUMBER | ADC_CHANNEL_10_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN10 */ +#define LL_ADC_CHANNEL_11 (ADC_CHANNEL_11_NUMBER | ADC_CHANNEL_11_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN11 */ +#define LL_ADC_CHANNEL_12 (ADC_CHANNEL_12_NUMBER | ADC_CHANNEL_12_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN12 */ +#define LL_ADC_CHANNEL_13 (ADC_CHANNEL_13_NUMBER | ADC_CHANNEL_13_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN13 */ +#define LL_ADC_CHANNEL_14 (ADC_CHANNEL_14_NUMBER | ADC_CHANNEL_14_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN14 */ +#define LL_ADC_CHANNEL_15 (ADC_CHANNEL_15_NUMBER | ADC_CHANNEL_15_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN15 */ +#define LL_ADC_CHANNEL_16 (ADC_CHANNEL_16_NUMBER | ADC_CHANNEL_16_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN16 */ +#define LL_ADC_CHANNEL_17 (ADC_CHANNEL_17_NUMBER | ADC_CHANNEL_17_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN17 */ +#define LL_ADC_CHANNEL_VREFINT (LL_ADC_CHANNEL_17 | ADC_CHANNEL_ID_INTERNAL_CH) /*!< ADC internal channel connected to VrefInt: Internal voltage reference. */ +#define LL_ADC_CHANNEL_TEMPSENSOR (LL_ADC_CHANNEL_16 | ADC_CHANNEL_ID_INTERNAL_CH) /*!< ADC internal channel connected to Temperature sensor. */ +#if defined(ADC_CCR_VBATEN) +#define LL_ADC_CHANNEL_18 (ADC_CHANNEL_18_NUMBER | ADC_CHANNEL_18_BITFIELD) /*!< ADC external channel (channel connected to GPIO pin) ADCx_IN18 */ +#define LL_ADC_CHANNEL_VBAT (LL_ADC_CHANNEL_18 | ADC_CHANNEL_ID_INTERNAL_CH) /*!< ADC internal channel connected to Vbat/2: Vbat voltage through a divider ladder of factor 1/2 to have Vbat always below Vdda. */ +#endif +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REG_TRIGGER_SOURCE ADC group regular - Trigger source + * @{ + */ +#define LL_ADC_REG_TRIG_SOFTWARE (0x00000000U) /*!< ADC group regular conversion trigger internal: SW start. */ +#define LL_ADC_REG_TRIG_EXT_TIM1_TRGO (ADC_REG_TRIG_EXT_EDGE_DEFAULT) /*!< ADC group regular conversion trigger from external IP: TIM1 TRGO. Trigger edge set to rising edge (default setting). */ +#define LL_ADC_REG_TRIG_EXT_TIM1_CH4 (ADC_CFGR1_EXTSEL_0 | ADC_REG_TRIG_EXT_EDGE_DEFAULT) /*!< ADC group regular conversion trigger from external IP: TIM1 channel 4 event (capture compare: input capture or output capture). Trigger edge set to rising edge (default setting). */ +#define LL_ADC_REG_TRIG_EXT_TIM2_TRGO (ADC_CFGR1_EXTSEL_1 | ADC_REG_TRIG_EXT_EDGE_DEFAULT) /*!< ADC group regular conversion trigger from external IP: TIM2 TRGO. Trigger edge set to rising edge (default setting). */ +#define LL_ADC_REG_TRIG_EXT_TIM3_TRGO (ADC_CFGR1_EXTSEL_1 | ADC_CFGR1_EXTSEL_0 | ADC_REG_TRIG_EXT_EDGE_DEFAULT) /*!< ADC group regular conversion trigger from external IP: TIM3 TRGO. Trigger edge set to rising edge (default setting). */ +#define LL_ADC_REG_TRIG_EXT_TIM15_TRGO (ADC_CFGR1_EXTSEL_2 | ADC_REG_TRIG_EXT_EDGE_DEFAULT) /*!< ADC group regular conversion trigger from external IP: TIM15 TRGO. Trigger edge set to rising edge (default setting). */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REG_TRIGGER_EDGE ADC group regular - Trigger edge + * @{ + */ +#define LL_ADC_REG_TRIG_EXT_RISING ( ADC_CFGR1_EXTEN_0) /*!< ADC group regular conversion trigger polarity set to rising edge */ +#define LL_ADC_REG_TRIG_EXT_FALLING (ADC_CFGR1_EXTEN_1 ) /*!< ADC group regular conversion trigger polarity set to falling edge */ +#define LL_ADC_REG_TRIG_EXT_RISINGFALLING (ADC_CFGR1_EXTEN_1 | ADC_CFGR1_EXTEN_0) /*!< ADC group regular conversion trigger polarity set to both rising and falling edges */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REG_CONTINUOUS_MODE ADC group regular - Continuous mode +* @{ +*/ +#define LL_ADC_REG_CONV_SINGLE (0x00000000U) /*!< ADC conversions are performed in single mode: one conversion per trigger */ +#define LL_ADC_REG_CONV_CONTINUOUS (ADC_CFGR1_CONT) /*!< ADC conversions are performed in continuous mode: after the first trigger, following conversions launched successively automatically */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REG_DMA_TRANSFER ADC group regular - DMA transfer of ADC conversion data + * @{ + */ +#define LL_ADC_REG_DMA_TRANSFER_NONE (0x00000000U) /*!< ADC conversions are not transferred by DMA */ +#define LL_ADC_REG_DMA_TRANSFER_LIMITED ( ADC_CFGR1_DMAEN) /*!< ADC conversion data are transferred by DMA, in limited mode (one shot mode): DMA transfer requests are stopped when number of DMA data transfers (number of ADC conversions) is reached. This ADC mode is intended to be used with DMA mode non-circular. */ +#define LL_ADC_REG_DMA_TRANSFER_UNLIMITED (ADC_CFGR1_DMACFG | ADC_CFGR1_DMAEN) /*!< ADC conversion data are transferred by DMA, in unlimited mode: DMA transfer requests are unlimited, whatever number of DMA data transferred (number of ADC conversions). This ADC mode is intended to be used with DMA mode circular. */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REG_OVR_DATA_BEHAVIOR ADC group regular - Overrun behavior on conversion data +* @{ +*/ +#define LL_ADC_REG_OVR_DATA_PRESERVED (0x00000000U)/*!< ADC group regular behavior in case of overrun: data preserved */ +#define LL_ADC_REG_OVR_DATA_OVERWRITTEN (ADC_CFGR1_OVRMOD) /*!< ADC group regular behavior in case of overrun: data overwritten */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REG_SEQ_SCAN_DIRECTION ADC group regular - Sequencer scan direction + * @{ + */ +#define LL_ADC_REG_SEQ_SCAN_DIR_FORWARD (0x00000000U)/*!< ADC group regular sequencer scan direction forward: from lowest channel number to highest channel number (scan of all ranks, ADC conversion of ranks with channels enabled in sequencer). On some other STM32 families, this setting is not available and the default scan direction is forward. */ +#define LL_ADC_REG_SEQ_SCAN_DIR_BACKWARD (ADC_CFGR1_SCANDIR) /*!< ADC group regular sequencer scan direction backward: from highest channel number to lowest channel number (scan of all ranks, ADC conversion of ranks with channels enabled in sequencer) */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_REG_SEQ_DISCONT_MODE ADC group regular - Sequencer discontinuous mode + * @{ + */ +#define LL_ADC_REG_SEQ_DISCONT_DISABLE (0x00000000U) /*!< ADC group regular sequencer discontinuous mode disable */ +#define LL_ADC_REG_SEQ_DISCONT_1RANK (ADC_CFGR1_DISCEN) /*!< ADC group regular sequencer discontinuous mode enable with sequence interruption every rank */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_CHANNEL_SAMPLINGTIME Channel - Sampling time + * @{ + */ +#define LL_ADC_SAMPLINGTIME_1CYCLE_5 (0x00000000U) /*!< Sampling time 1.5 ADC clock cycle */ +#define LL_ADC_SAMPLINGTIME_7CYCLES_5 (ADC_SMPR_SMP_0) /*!< Sampling time 7.5 ADC clock cycles */ +#define LL_ADC_SAMPLINGTIME_13CYCLES_5 (ADC_SMPR_SMP_1) /*!< Sampling time 13.5 ADC clock cycles */ +#define LL_ADC_SAMPLINGTIME_28CYCLES_5 (ADC_SMPR_SMP_1 | ADC_SMPR_SMP_0) /*!< Sampling time 28.5 ADC clock cycles */ +#define LL_ADC_SAMPLINGTIME_41CYCLES_5 (ADC_SMPR_SMP_2) /*!< Sampling time 41.5 ADC clock cycles */ +#define LL_ADC_SAMPLINGTIME_55CYCLES_5 (ADC_SMPR_SMP_2 | ADC_SMPR_SMP_0) /*!< Sampling time 55.5 ADC clock cycles */ +#define LL_ADC_SAMPLINGTIME_71CYCLES_5 (ADC_SMPR_SMP_2 | ADC_SMPR_SMP_1) /*!< Sampling time 71.5 ADC clock cycles */ +#define LL_ADC_SAMPLINGTIME_239CYCLES_5 (ADC_SMPR_SMP_2 | ADC_SMPR_SMP_1 | ADC_SMPR_SMP_0) /*!< Sampling time 239.5 ADC clock cycles */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_AWD_NUMBER Analog watchdog - Analog watchdog number + * @{ + */ +#define LL_ADC_AWD1 (ADC_AWD_CR1_CHANNEL_MASK | ADC_AWD_CR1_REGOFFSET) /*!< ADC analog watchdog number 1 */ +/** + * @} + */ + +/** @defgroup ADC_LL_EC_AWD_CHANNELS Analog watchdog - Monitored channels + * @{ + */ +#define LL_ADC_AWD_DISABLE (0x00000000U) /*!< ADC analog watchdog monitoring disabled */ +#define LL_ADC_AWD_ALL_CHANNELS_REG ( ADC_CFGR1_AWDEN ) /*!< ADC analog watchdog monitoring of all channels, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_0_REG ((LL_ADC_CHANNEL_0 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN0, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_1_REG ((LL_ADC_CHANNEL_1 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN1, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_2_REG ((LL_ADC_CHANNEL_2 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN2, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_3_REG ((LL_ADC_CHANNEL_3 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN3, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_4_REG ((LL_ADC_CHANNEL_4 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN4, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_5_REG ((LL_ADC_CHANNEL_5 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN5, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_6_REG ((LL_ADC_CHANNEL_6 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN6, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_7_REG ((LL_ADC_CHANNEL_7 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN7, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_8_REG ((LL_ADC_CHANNEL_8 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN8, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_9_REG ((LL_ADC_CHANNEL_9 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN9, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_10_REG ((LL_ADC_CHANNEL_10 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN10, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_11_REG ((LL_ADC_CHANNEL_11 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN11, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_12_REG ((LL_ADC_CHANNEL_12 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN12, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_13_REG ((LL_ADC_CHANNEL_13 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN13, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_14_REG ((LL_ADC_CHANNEL_14 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN14, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_15_REG ((LL_ADC_CHANNEL_15 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN15, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_16_REG ((LL_ADC_CHANNEL_16 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN16, converted by group regular only */ +#define LL_ADC_AWD_CHANNEL_17_REG ((LL_ADC_CHANNEL_17 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN17, converted by group regular only */ +#define LL_ADC_AWD_CH_VREFINT_REG ((LL_ADC_CHANNEL_VREFINT & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC internal channel connected to VrefInt: Internal voltage reference, converted by group regular only */ +#define LL_ADC_AWD_CH_TEMPSENSOR_REG ((LL_ADC_CHANNEL_TEMPSENSOR & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC internal channel connected to Temperature sensor, converted by group regular only */ +#if defined(ADC_CCR_VBATEN) +#define LL_ADC_AWD_CHANNEL_18_REG ((LL_ADC_CHANNEL_18 & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC external channel (channel connected to GPIO pin) ADCx_IN18, converted by group regular only */ +#define LL_ADC_AWD_CH_VBAT_REG ((LL_ADC_CHANNEL_VBAT & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) /*!< ADC analog watchdog monitoring of ADC internal channel connected to Vbat/3: Vbat voltage through a divider ladder of factor 1/3 to have Vbat always below Vdda, converted by group regular only */ +#endif +/** + * @} + */ + +/** @defgroup ADC_LL_EC_AWD_THRESHOLDS Analog watchdog - Thresholds + * @{ + */ +#define LL_ADC_AWD_THRESHOLD_HIGH (ADC_TR_HT ) /*!< ADC analog watchdog threshold high */ +#define LL_ADC_AWD_THRESHOLD_LOW ( ADC_TR_LT) /*!< ADC analog watchdog threshold low */ +#define LL_ADC_AWD_THRESHOLDS_HIGH_LOW (ADC_TR_HT | ADC_TR_LT) /*!< ADC analog watchdog both thresholds high and low concatenated into the same data */ +/** + * @} + */ + + +/** @defgroup ADC_LL_EC_HW_DELAYS Definitions of ADC hardware constraints delays + * @note Only ADC IP HW delays are defined in ADC LL driver driver, + * not timeout values. + * For details on delays values, refer to descriptions in source code + * above each literal definition. + * @{ + */ + +/* Note: Only ADC IP HW delays are defined in ADC LL driver driver, */ +/* not timeout values. */ +/* Timeout values for ADC operations are dependent to device clock */ +/* configuration (system clock versus ADC clock), */ +/* and therefore must be defined in user application. */ +/* Indications for estimation of ADC timeout delays, for this */ +/* STM32 serie: */ +/* - ADC calibration time: maximum delay is 83/fADC. */ +/* (refer to device datasheet, parameter "tCAL") */ +/* - ADC enable time: maximum delay is 1 conversion cycle. */ +/* (refer to device datasheet, parameter "tSTAB") */ +/* - ADC disable time: maximum delay should be a few ADC clock cycles */ +/* - ADC stop conversion time: maximum delay should be a few ADC clock */ +/* cycles */ +/* - ADC conversion time: duration depending on ADC clock and ADC */ +/* configuration. */ +/* (refer to device reference manual, section "Timing") */ + + +/* Delay for internal voltage reference stabilization time. */ +/* Delay set to maximum value (refer to device datasheet, */ +/* parameter "tSTART"). */ +/* Unit: us */ +#define LL_ADC_DELAY_VREFINT_STAB_US ( 10U) /*!< Delay for internal voltage reference stabilization time */ + +/* Delay for temperature sensor stabilization time. */ +/* Literal set to maximum value (refer to device datasheet, */ +/* parameter "tSTART"). */ +/* Unit: us */ +#define LL_ADC_DELAY_TEMPSENSOR_STAB_US ( 10U) /*!< Delay for temperature sensor stabilization time */ + +/* Delay required between ADC end of calibration and ADC enable. */ +/* Note: On this STM32 serie, a minimum number of ADC clock cycles */ +/* are required between ADC end of calibration and ADC enable. */ +/* Wait time can be computed in user application by waiting for the */ +/* equivalent number of CPU cycles, by taking into account */ +/* ratio of CPU clock versus ADC clock prescalers. */ +/* Unit: ADC clock cycles. */ +#define LL_ADC_DELAY_CALIB_ENABLE_ADC_CYCLES ( 2U) /*!< Delay required between ADC end of calibration and ADC enable */ + +/** + * @} + */ + +/** + * @} + */ + + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup ADC_LL_Exported_Macros ADC Exported Macros + * @{ + */ + +/** @defgroup ADC_LL_EM_WRITE_READ Common write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in ADC register + * @param __INSTANCE__ ADC Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_ADC_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in ADC register + * @param __INSTANCE__ ADC Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_ADC_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** @defgroup ADC_LL_EM_HELPER_MACRO ADC helper macro + * @{ + */ + +/** + * @brief Helper macro to get ADC channel number in decimal format + * from literals LL_ADC_CHANNEL_x. + * @note Example: + * __LL_ADC_CHANNEL_TO_DECIMAL_NB(LL_ADC_CHANNEL_4) + * will return decimal number "4". + * @note The input can be a value from functions where a channel + * number is returned, either defined with number + * or with bitfield (only one bit must be set). + * @param __CHANNEL__ This parameter can be one of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval Value between Min_Data=0 and Max_Data=18 + */ +#define __LL_ADC_CHANNEL_TO_DECIMAL_NB(__CHANNEL__) \ + ((((__CHANNEL__) & ADC_CHANNEL_ID_BITFIELD_MASK) == 0U) \ + ? ( \ + ((__CHANNEL__) & ADC_CHANNEL_ID_NUMBER_MASK) >> ADC_CHANNEL_ID_NUMBER_BITOFFSET_POS \ + ) \ + : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL0) == ADC_CHSELR_CHSEL0) ? (0U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL1) == ADC_CHSELR_CHSEL1) ? (1U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL2) == ADC_CHSELR_CHSEL2) ? (2U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL3) == ADC_CHSELR_CHSEL3) ? (3U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL4) == ADC_CHSELR_CHSEL4) ? (4U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL5) == ADC_CHSELR_CHSEL5) ? (5U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL6) == ADC_CHSELR_CHSEL6) ? (6U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL7) == ADC_CHSELR_CHSEL7) ? (7U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL8) == ADC_CHSELR_CHSEL8) ? (8U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL9) == ADC_CHSELR_CHSEL9) ? (9U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL10) == ADC_CHSELR_CHSEL10) ? (10U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL11) == ADC_CHSELR_CHSEL11) ? (11U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL12) == ADC_CHSELR_CHSEL12) ? (12U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL13) == ADC_CHSELR_CHSEL13) ? (13U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL14) == ADC_CHSELR_CHSEL14) ? (14U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL15) == ADC_CHSELR_CHSEL15) ? (15U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL16) == ADC_CHSELR_CHSEL16) ? (16U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL17) == ADC_CHSELR_CHSEL17) ? (17U) : \ + ( \ + (((__CHANNEL__) & ADC_CHSELR_CHSEL18) == ADC_CHSELR_CHSEL18) ? (18U) : \ + (0U) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) \ + ) + +/** + * @brief Helper macro to get ADC channel in literal format LL_ADC_CHANNEL_x + * from number in decimal format. + * @note Example: + * __LL_ADC_DECIMAL_NB_TO_CHANNEL(4) + * will return a data equivalent to "LL_ADC_CHANNEL_4". + * @param __DECIMAL_NB__ Value between Min_Data=0 and Max_Data=18 + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT (2) + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR (2) + * @arg @ref LL_ADC_CHANNEL_VBAT (1)(2) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB.\n + * (2) For ADC channel read back from ADC register, + * comparison with internal channel parameter to be done + * using helper macro @ref __LL_ADC_CHANNEL_INTERNAL_TO_EXTERNAL(). + */ +#define __LL_ADC_DECIMAL_NB_TO_CHANNEL(__DECIMAL_NB__) \ + ( \ + ((__DECIMAL_NB__) << ADC_CHANNEL_ID_NUMBER_BITOFFSET_POS) | \ + (ADC_CHSELR_CHSEL0 << (__DECIMAL_NB__)) \ + ) + +/** + * @brief Helper macro to determine whether the selected channel + * corresponds to literal definitions of driver. + * @note The different literal definitions of ADC channels are: + * - ADC internal channel: + * LL_ADC_CHANNEL_VREFINT, LL_ADC_CHANNEL_TEMPSENSOR, ... + * - ADC external channel (channel connected to a GPIO pin): + * LL_ADC_CHANNEL_1, LL_ADC_CHANNEL_2, ... + * @note The channel parameter must be a value defined from literal + * definition of a ADC internal channel (LL_ADC_CHANNEL_VREFINT, + * LL_ADC_CHANNEL_TEMPSENSOR, ...), + * ADC external channel (LL_ADC_CHANNEL_1, LL_ADC_CHANNEL_2, ...), + * must not be a value from functions where a channel number is + * returned from ADC registers, + * because internal and external channels share the same channel + * number in ADC registers. The differentiation is made only with + * parameters definitions of driver. + * @param __CHANNEL__ This parameter can be one of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval Value "0" if the channel corresponds to a parameter definition of a ADC external channel (channel connected to a GPIO pin). + * Value "1" if the channel corresponds to a parameter definition of a ADC internal channel. + */ +#define __LL_ADC_IS_CHANNEL_INTERNAL(__CHANNEL__) \ + (((__CHANNEL__) & ADC_CHANNEL_ID_INTERNAL_CH_MASK) != 0U) + +/** + * @brief Helper macro to convert a channel defined from parameter + * definition of a ADC internal channel (LL_ADC_CHANNEL_VREFINT, + * LL_ADC_CHANNEL_TEMPSENSOR, ...), + * to its equivalent parameter definition of a ADC external channel + * (LL_ADC_CHANNEL_1, LL_ADC_CHANNEL_2, ...). + * @note The channel parameter can be, additionally to a value + * defined from parameter definition of a ADC internal channel + * (LL_ADC_CHANNEL_VREFINT, LL_ADC_CHANNEL_TEMPSENSOR, ...), + * a value defined from parameter definition of + * ADC external channel (LL_ADC_CHANNEL_1, LL_ADC_CHANNEL_2, ...) + * or a value from functions where a channel number is returned + * from ADC registers. + * @param __CHANNEL__ This parameter can be one of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 + */ +#define __LL_ADC_CHANNEL_INTERNAL_TO_EXTERNAL(__CHANNEL__) \ + ((__CHANNEL__) & ~ADC_CHANNEL_ID_INTERNAL_CH_MASK) + +/** + * @brief Helper macro to determine whether the internal channel + * selected is available on the ADC instance selected. + * @note The channel parameter must be a value defined from parameter + * definition of a ADC internal channel (LL_ADC_CHANNEL_VREFINT, + * LL_ADC_CHANNEL_TEMPSENSOR, ...), + * must not be a value defined from parameter definition of + * ADC external channel (LL_ADC_CHANNEL_1, LL_ADC_CHANNEL_2, ...) + * or a value from functions where a channel number is + * returned from ADC registers, + * because internal and external channels share the same channel + * number in ADC registers. The differentiation is made only with + * parameters definitions of driver. + * @param __ADC_INSTANCE__ ADC instance + * @param __CHANNEL__ This parameter can be one of the following values: + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval Value "0" if the internal channel selected is not available on the ADC instance selected. + * Value "1" if the internal channel selected is available on the ADC instance selected. + */ +#if defined(ADC_CCR_VBATEN) +#define __LL_ADC_IS_CHANNEL_INTERNAL_AVAILABLE(__ADC_INSTANCE__, __CHANNEL__) \ + ( \ + ((__CHANNEL__) == LL_ADC_CHANNEL_VREFINT) || \ + ((__CHANNEL__) == LL_ADC_CHANNEL_TEMPSENSOR) || \ + ((__CHANNEL__) == LL_ADC_CHANNEL_VBAT) \ + ) +#else +#define __LL_ADC_IS_CHANNEL_INTERNAL_AVAILABLE(__ADC_INSTANCE__, __CHANNEL__) \ + ( \ + ((__CHANNEL__) == LL_ADC_CHANNEL_VREFINT) || \ + ((__CHANNEL__) == LL_ADC_CHANNEL_TEMPSENSOR) \ + ) +#endif + +/** + * @brief Helper macro to define ADC analog watchdog parameter: + * define a single channel to monitor with analog watchdog + * from sequencer channel and groups definition. + * @note To be used with function @ref LL_ADC_SetAnalogWDMonitChannels(). + * Example: + * LL_ADC_SetAnalogWDMonitChannels( + * ADC1, LL_ADC_AWD1, + * __LL_ADC_ANALOGWD_CHANNEL_GROUP(LL_ADC_CHANNEL4, LL_ADC_GROUP_REGULAR)) + * @param __CHANNEL__ This parameter can be one of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT (2) + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR (2) + * @arg @ref LL_ADC_CHANNEL_VBAT (1)(2) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB.\n + * (2) For ADC channel read back from ADC register, + * comparison with internal channel parameter to be done + * using helper macro @ref __LL_ADC_CHANNEL_INTERNAL_TO_EXTERNAL(). + * @param __GROUP__ This parameter can be one of the following values: + * @arg @ref LL_ADC_GROUP_REGULAR + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_AWD_DISABLE + * @arg @ref LL_ADC_AWD_ALL_CHANNELS_REG + * @arg @ref LL_ADC_AWD_CHANNEL_0_REG + * @arg @ref LL_ADC_AWD_CHANNEL_1_REG + * @arg @ref LL_ADC_AWD_CHANNEL_2_REG + * @arg @ref LL_ADC_AWD_CHANNEL_3_REG + * @arg @ref LL_ADC_AWD_CHANNEL_4_REG + * @arg @ref LL_ADC_AWD_CHANNEL_5_REG + * @arg @ref LL_ADC_AWD_CHANNEL_6_REG + * @arg @ref LL_ADC_AWD_CHANNEL_7_REG + * @arg @ref LL_ADC_AWD_CHANNEL_8_REG + * @arg @ref LL_ADC_AWD_CHANNEL_9_REG + * @arg @ref LL_ADC_AWD_CHANNEL_10_REG + * @arg @ref LL_ADC_AWD_CHANNEL_11_REG + * @arg @ref LL_ADC_AWD_CHANNEL_12_REG + * @arg @ref LL_ADC_AWD_CHANNEL_13_REG + * @arg @ref LL_ADC_AWD_CHANNEL_14_REG + * @arg @ref LL_ADC_AWD_CHANNEL_15_REG + * @arg @ref LL_ADC_AWD_CHANNEL_16_REG + * @arg @ref LL_ADC_AWD_CHANNEL_17_REG + * @arg @ref LL_ADC_AWD_CHANNEL_18_REG (1) + * @arg @ref LL_ADC_AWD_CH_VREFINT_REG + * @arg @ref LL_ADC_AWD_CH_TEMPSENSOR_REG + * @arg @ref LL_ADC_AWD_CH_VBAT_REG (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + */ +#define __LL_ADC_ANALOGWD_CHANNEL_GROUP(__CHANNEL__, __GROUP__) \ + (((__CHANNEL__) & ADC_CHANNEL_ID_MASK) | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL) + +/** + * @brief Helper macro to set the value of ADC analog watchdog threshold high + * or low in function of ADC resolution, when ADC resolution is + * different of 12 bits. + * @note To be used with function @ref LL_ADC_ConfigAnalogWDThresholds() + * or @ref LL_ADC_SetAnalogWDThresholds(). + * Example, with a ADC resolution of 8 bits, to set the value of + * analog watchdog threshold high (on 8 bits): + * LL_ADC_SetAnalogWDThresholds + * (< ADCx param >, + * __LL_ADC_ANALOGWD_SET_THRESHOLD_RESOLUTION(LL_ADC_RESOLUTION_8B, ) + * ); + * @param __ADC_RESOLUTION__ This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @param __AWD_THRESHOLD__ Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval Value between Min_Data=0x000 and Max_Data=0xFFF + */ +#define __LL_ADC_ANALOGWD_SET_THRESHOLD_RESOLUTION(__ADC_RESOLUTION__, __AWD_THRESHOLD__) \ + ((__AWD_THRESHOLD__) << ((__ADC_RESOLUTION__) >> (ADC_CFGR1_RES_BITOFFSET_POS - 1U ))) + +/** + * @brief Helper macro to get the value of ADC analog watchdog threshold high + * or low in function of ADC resolution, when ADC resolution is + * different of 12 bits. + * @note To be used with function @ref LL_ADC_GetAnalogWDThresholds(). + * Example, with a ADC resolution of 8 bits, to get the value of + * analog watchdog threshold high (on 8 bits): + * < threshold_value_6_bits > = __LL_ADC_ANALOGWD_GET_THRESHOLD_RESOLUTION + * (LL_ADC_RESOLUTION_8B, + * LL_ADC_GetAnalogWDThresholds(, LL_ADC_AWD_THRESHOLD_HIGH) + * ); + * @param __ADC_RESOLUTION__ This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @param __AWD_THRESHOLD_12_BITS__ Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval Value between Min_Data=0x000 and Max_Data=0xFFF + */ +#define __LL_ADC_ANALOGWD_GET_THRESHOLD_RESOLUTION(__ADC_RESOLUTION__, __AWD_THRESHOLD_12_BITS__) \ + ((__AWD_THRESHOLD_12_BITS__) >> ((__ADC_RESOLUTION__) >> (ADC_CFGR1_RES_BITOFFSET_POS - 1U ))) + +/** + * @brief Helper macro to get the ADC analog watchdog threshold high + * or low from raw value containing both thresholds concatenated. + * @note To be used with function @ref LL_ADC_GetAnalogWDThresholds(). + * Example, to get analog watchdog threshold high from the register raw value: + * __LL_ADC_ANALOGWD_THRESHOLDS_HIGH_LOW(LL_ADC_AWD_THRESHOLD_HIGH, ); + * @param __AWD_THRESHOLD_TYPE__ This parameter can be one of the following values: + * @arg @ref LL_ADC_AWD_THRESHOLD_HIGH + * @arg @ref LL_ADC_AWD_THRESHOLD_LOW + * @param __AWD_THRESHOLDS__ Value between Min_Data=0x00000000 and Max_Data=0xFFFFFFFF + * @retval Value between Min_Data=0x000 and Max_Data=0xFFF + */ +#define __LL_ADC_ANALOGWD_THRESHOLDS_HIGH_LOW(__AWD_THRESHOLD_TYPE__, __AWD_THRESHOLDS__) \ + (((__AWD_THRESHOLD_TYPE__) == LL_ADC_AWD_THRESHOLD_LOW) \ + ? ( \ + (__AWD_THRESHOLDS__) & LL_ADC_AWD_THRESHOLD_LOW \ + ) \ + : \ + ( \ + ((__AWD_THRESHOLDS__) >> ADC_TR_HT_BITOFFSET_POS) & LL_ADC_AWD_THRESHOLD_LOW \ + ) \ + ) + +/** + * @brief Helper macro to select the ADC common instance + * to which is belonging the selected ADC instance. + * @note ADC common register instance can be used for: + * - Set parameters common to several ADC instances + * - Multimode (for devices with several ADC instances) + * Refer to functions having argument "ADCxy_COMMON" as parameter. + * @param __ADCx__ ADC instance + * @retval ADC common register instance + */ +#define __LL_ADC_COMMON_INSTANCE(__ADCx__) \ + (ADC1_COMMON) + +/** + * @brief Helper macro to check if all ADC instances sharing the same + * ADC common instance are disabled. + * @note This check is required by functions with setting conditioned to + * ADC state: + * All ADC instances of the ADC common group must be disabled. + * Refer to functions having argument "ADCxy_COMMON" as parameter. + * @note On devices with only 1 ADC common instance, parameter of this macro + * is useless and can be ignored (parameter kept for compatibility + * with devices featuring several ADC common instances). + * @param __ADCXY_COMMON__ ADC common instance + * (can be set directly from CMSIS definition or by using helper macro @ref __LL_ADC_COMMON_INSTANCE() ) + * @retval Value "0" if all ADC instances sharing the same ADC common instance + * are disabled. + * Value "1" if at least one ADC instance sharing the same ADC common instance + * is enabled. + */ +#define __LL_ADC_IS_ENABLED_ALL_COMMON_INSTANCE(__ADCXY_COMMON__) \ + LL_ADC_IsEnabled(ADC1) + +/** + * @brief Helper macro to define the ADC conversion data full-scale digital + * value corresponding to the selected ADC resolution. + * @note ADC conversion data full-scale corresponds to voltage range + * determined by analog voltage references Vref+ and Vref- + * (refer to reference manual). + * @param __ADC_RESOLUTION__ This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @retval ADC conversion data equivalent voltage value (unit: mVolt) + */ +#define __LL_ADC_DIGITAL_SCALE(__ADC_RESOLUTION__) \ + (0xFFFU >> ((__ADC_RESOLUTION__) >> (ADC_CFGR1_RES_BITOFFSET_POS - 1U))) + +/** + * @brief Helper macro to convert the ADC conversion data from + * a resolution to another resolution. + * @param __DATA__ ADC conversion data to be converted + * @param __ADC_RESOLUTION_CURRENT__ Resolution of to the data to be converted + * This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @param __ADC_RESOLUTION_TARGET__ Resolution of the data after conversion + * This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @retval ADC conversion data to the requested resolution + */ +#define __LL_ADC_CONVERT_DATA_RESOLUTION(__DATA__, __ADC_RESOLUTION_CURRENT__, __ADC_RESOLUTION_TARGET__) \ + (((__DATA__) \ + << ((__ADC_RESOLUTION_CURRENT__) >> (ADC_CFGR1_RES_BITOFFSET_POS - 1U))) \ + >> ((__ADC_RESOLUTION_TARGET__) >> (ADC_CFGR1_RES_BITOFFSET_POS - 1U)) \ + ) + +/** + * @brief Helper macro to calculate the voltage (unit: mVolt) + * corresponding to a ADC conversion data (unit: digital value). + * @note Analog reference voltage (Vref+) must be either known from + * user board environment or can be calculated using ADC measurement + * and ADC helper macro @ref __LL_ADC_CALC_VREFANALOG_VOLTAGE(). + * @param __VREFANALOG_VOLTAGE__ Analog reference voltage (unit: mV) + * @param __ADC_DATA__ ADC conversion data (resolution 12 bits) + * (unit: digital value). + * @param __ADC_RESOLUTION__ This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @retval ADC conversion data equivalent voltage value (unit: mVolt) + */ +#define __LL_ADC_CALC_DATA_TO_VOLTAGE(__VREFANALOG_VOLTAGE__,\ + __ADC_DATA__,\ + __ADC_RESOLUTION__) \ + ((__ADC_DATA__) * (__VREFANALOG_VOLTAGE__) \ + / __LL_ADC_DIGITAL_SCALE(__ADC_RESOLUTION__) \ + ) + +/** + * @brief Helper macro to calculate analog reference voltage (Vref+) + * (unit: mVolt) from ADC conversion data of internal voltage + * reference VrefInt. + * @note Computation is using VrefInt calibration value + * stored in system memory for each device during production. + * @note This voltage depends on user board environment: voltage level + * connected to pin Vref+. + * On devices with small package, the pin Vref+ is not present + * and internally bonded to pin Vdda. + * @note On this STM32 serie, calibration data of internal voltage reference + * VrefInt corresponds to a resolution of 12 bits, + * this is the recommended ADC resolution to convert voltage of + * internal voltage reference VrefInt. + * Otherwise, this macro performs the processing to scale + * ADC conversion data to 12 bits. + * @param __VREFINT_ADC_DATA__ ADC conversion data (resolution 12 bits) + * of internal voltage reference VrefInt (unit: digital value). + * @param __ADC_RESOLUTION__ This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @retval Analog reference voltage (unit: mV) + */ +#define __LL_ADC_CALC_VREFANALOG_VOLTAGE(__VREFINT_ADC_DATA__,\ + __ADC_RESOLUTION__) \ + (((uint32_t)(*VREFINT_CAL_ADDR) * VREFINT_CAL_VREF) \ + / __LL_ADC_CONVERT_DATA_RESOLUTION((__VREFINT_ADC_DATA__), \ + (__ADC_RESOLUTION__), \ + LL_ADC_RESOLUTION_12B) \ + ) + +/** + * @brief Helper macro to calculate the temperature (unit: degree Celsius) + * from ADC conversion data of internal temperature sensor. + * @note Computation is using temperature sensor calibration values + * stored in system memory for each device during production. + * @note Calculation formula: + * Temperature = ((TS_ADC_DATA - TS_CAL1) + * * (TS_CAL2_TEMP - TS_CAL1_TEMP)) + * / (TS_CAL2 - TS_CAL1) + TS_CAL1_TEMP + * with TS_ADC_DATA = temperature sensor raw data measured by ADC + * Avg_Slope = (TS_CAL2 - TS_CAL1) + * / (TS_CAL2_TEMP - TS_CAL1_TEMP) + * TS_CAL1 = equivalent TS_ADC_DATA at temperature + * TEMP_DEGC_CAL1 (calibrated in factory) + * TS_CAL2 = equivalent TS_ADC_DATA at temperature + * TEMP_DEGC_CAL2 (calibrated in factory) + * Caution: Calculation relevancy under reserve that calibration + * parameters are correct (address and data). + * To calculate temperature using temperature sensor + * datasheet typical values (generic values less, therefore + * less accurate than calibrated values), + * use helper macro @ref __LL_ADC_CALC_TEMPERATURE_TYP_PARAMS(). + * @note As calculation input, the analog reference voltage (Vref+) must be + * defined as it impacts the ADC LSB equivalent voltage. + * @note Analog reference voltage (Vref+) must be either known from + * user board environment or can be calculated using ADC measurement + * and ADC helper macro @ref __LL_ADC_CALC_VREFANALOG_VOLTAGE(). + * @note On this STM32 serie, calibration data of temperature sensor + * corresponds to a resolution of 12 bits, + * this is the recommended ADC resolution to convert voltage of + * temperature sensor. + * Otherwise, this macro performs the processing to scale + * ADC conversion data to 12 bits. + * @param __VREFANALOG_VOLTAGE__ Analog reference voltage (unit: mV) + * @param __TEMPSENSOR_ADC_DATA__ ADC conversion data of internal + * temperature sensor (unit: digital value). + * @param __ADC_RESOLUTION__ ADC resolution at which internal temperature + * sensor voltage has been measured. + * This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @retval Temperature (unit: degree Celsius) + */ +#define __LL_ADC_CALC_TEMPERATURE(__VREFANALOG_VOLTAGE__,\ + __TEMPSENSOR_ADC_DATA__,\ + __ADC_RESOLUTION__) \ + (((( ((int32_t)((__LL_ADC_CONVERT_DATA_RESOLUTION((__TEMPSENSOR_ADC_DATA__), \ + (__ADC_RESOLUTION__), \ + LL_ADC_RESOLUTION_12B) \ + * (__VREFANALOG_VOLTAGE__)) \ + / TEMPSENSOR_CAL_VREFANALOG) \ + - (int32_t) *TEMPSENSOR_CAL1_ADDR) \ + ) * (int32_t)(TEMPSENSOR_CAL2_TEMP - TEMPSENSOR_CAL1_TEMP) \ + ) / (int32_t)((int32_t)*TEMPSENSOR_CAL2_ADDR - (int32_t)*TEMPSENSOR_CAL1_ADDR) \ + ) + TEMPSENSOR_CAL1_TEMP \ + ) + +/** + * @brief Helper macro to calculate the temperature (unit: degree Celsius) + * from ADC conversion data of internal temperature sensor. + * @note Computation is using temperature sensor typical values + * (refer to device datasheet). + * @note Calculation formula: + * Temperature = (TS_TYP_CALx_VOLT(uV) - TS_ADC_DATA * Conversion_uV) + * / Avg_Slope + CALx_TEMP + * with TS_ADC_DATA = temperature sensor raw data measured by ADC + * (unit: digital value) + * Avg_Slope = temperature sensor slope + * (unit: uV/Degree Celsius) + * TS_TYP_CALx_VOLT = temperature sensor digital value at + * temperature CALx_TEMP (unit: mV) + * Caution: Calculation relevancy under reserve the temperature sensor + * of the current device has characteristics in line with + * datasheet typical values. + * If temperature sensor calibration values are available on + * on this device (presence of macro __LL_ADC_CALC_TEMPERATURE()), + * temperature calculation will be more accurate using + * helper macro @ref __LL_ADC_CALC_TEMPERATURE(). + * @note As calculation input, the analog reference voltage (Vref+) must be + * defined as it impacts the ADC LSB equivalent voltage. + * @note Analog reference voltage (Vref+) must be either known from + * user board environment or can be calculated using ADC measurement + * and ADC helper macro @ref __LL_ADC_CALC_VREFANALOG_VOLTAGE(). + * @note ADC measurement data must correspond to a resolution of 12bits + * (full scale digital value 4095). If not the case, the data must be + * preliminarily rescaled to an equivalent resolution of 12 bits. + * @param __TEMPSENSOR_TYP_AVGSLOPE__ Device datasheet data: Temperature sensor slope typical value (unit: uV/DegCelsius). + * On STM32F0, refer to device datasheet parameter "Avg_Slope". + * @param __TEMPSENSOR_TYP_CALX_V__ Device datasheet data: Temperature sensor voltage typical value (at temperature and Vref+ defined in parameters below) (unit: mV). + * On STM32F0, refer to device datasheet parameter "V30" (corresponding to TS_CAL1). + * @param __TEMPSENSOR_CALX_TEMP__ Device datasheet data: Temperature at which temperature sensor voltage (see parameter above) is corresponding (unit: mV) + * @param __VREFANALOG_VOLTAGE__ Analog voltage reference (Vref+) voltage (unit: mV) + * @param __TEMPSENSOR_ADC_DATA__ ADC conversion data of internal temperature sensor (unit: digital value). + * @param __ADC_RESOLUTION__ ADC resolution at which internal temperature sensor voltage has been measured. + * This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @retval Temperature (unit: degree Celsius) + */ +#define __LL_ADC_CALC_TEMPERATURE_TYP_PARAMS(__TEMPSENSOR_TYP_AVGSLOPE__,\ + __TEMPSENSOR_TYP_CALX_V__,\ + __TEMPSENSOR_CALX_TEMP__,\ + __VREFANALOG_VOLTAGE__,\ + __TEMPSENSOR_ADC_DATA__,\ + __ADC_RESOLUTION__) \ + ((( ( \ + (int32_t)(((__TEMPSENSOR_TYP_CALX_V__)) \ + * 1000) \ + - \ + (int32_t)((((__TEMPSENSOR_ADC_DATA__) * (__VREFANALOG_VOLTAGE__)) \ + / __LL_ADC_DIGITAL_SCALE(__ADC_RESOLUTION__)) \ + * 1000) \ + ) \ + ) / (__TEMPSENSOR_TYP_AVGSLOPE__) \ + ) + (__TEMPSENSOR_CALX_TEMP__) \ + ) + +/** + * @} + */ + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup ADC_LL_Exported_Functions ADC Exported Functions + * @{ + */ + +/** @defgroup ADC_LL_EF_DMA_Management ADC DMA management + * @{ + */ +/* Note: LL ADC functions to set DMA transfer are located into sections of */ +/* configuration of ADC instance, groups and multimode (if available): */ +/* @ref LL_ADC_REG_SetDMATransfer(), ... */ + +/** + * @brief Function to help to configure DMA transfer from ADC: retrieve the + * ADC register address from ADC instance and a list of ADC registers + * intended to be used (most commonly) with DMA transfer. + * @note These ADC registers are data registers: + * when ADC conversion data is available in ADC data registers, + * ADC generates a DMA transfer request. + * @note This macro is intended to be used with LL DMA driver, refer to + * function "LL_DMA_ConfigAddresses()". + * Example: + * LL_DMA_ConfigAddresses(DMA1, + * LL_DMA_CHANNEL_1, + * LL_ADC_DMA_GetRegAddr(ADC1, LL_ADC_DMA_REG_REGULAR_DATA), + * (uint32_t)&< array or variable >, + * LL_DMA_DIRECTION_PERIPH_TO_MEMORY); + * @note For devices with several ADC: in multimode, some devices + * use a different data register outside of ADC instance scope + * (common data register). This macro manages this register difference, + * only ADC instance has to be set as parameter. + * @rmtoll DR DATA LL_ADC_DMA_GetRegAddr + * @param ADCx ADC instance + * @param Register This parameter can be one of the following values: + * @arg @ref LL_ADC_DMA_REG_REGULAR_DATA + * @retval ADC register address + */ +__STATIC_INLINE uint32_t LL_ADC_DMA_GetRegAddr(ADC_TypeDef *ADCx, uint32_t Register) +{ + /* Prevent unused argument compilation warning */ + (void)Register; + + /* Retrieve address of register DR */ + return (uint32_t)&(ADCx->DR); +} + +/** + * @} + */ + +/** @defgroup ADC_LL_EF_Configuration_ADC_Common Configuration of ADC hierarchical scope: common to several ADC instances + * @{ + */ + +/** + * @brief Set parameter common to several ADC: measurement path to internal + * channels (VrefInt, temperature sensor, ...). + * @note One or several values can be selected. + * Example: (LL_ADC_PATH_INTERNAL_VREFINT | + * LL_ADC_PATH_INTERNAL_TEMPSENSOR) + * @note Stabilization time of measurement path to internal channel: + * After enabling internal paths, before starting ADC conversion, + * a delay is required for internal voltage reference and + * temperature sensor stabilization time. + * Refer to device datasheet. + * Refer to literal @ref LL_ADC_DELAY_VREFINT_STAB_US. + * Refer to literal @ref LL_ADC_DELAY_TEMPSENSOR_STAB_US. + * @note ADC internal channel sampling time constraint: + * For ADC conversion of internal channels, + * a sampling time minimum value is required. + * Refer to device datasheet. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * All ADC instances of the ADC common group must be disabled. + * This check can be done with function @ref LL_ADC_IsEnabled() for each + * ADC instance or by using helper macro helper macro + * @ref __LL_ADC_IS_ENABLED_ALL_COMMON_INSTANCE(). + * @rmtoll CCR VREFEN LL_ADC_SetCommonPathInternalCh\n + * CCR TSEN LL_ADC_SetCommonPathInternalCh\n + * CCR VBATEN LL_ADC_SetCommonPathInternalCh + * @param ADCxy_COMMON ADC common instance + * (can be set directly from CMSIS definition or by using helper macro @ref __LL_ADC_COMMON_INSTANCE() ) + * @param PathInternal This parameter can be a combination of the following values: + * @arg @ref LL_ADC_PATH_INTERNAL_NONE + * @arg @ref LL_ADC_PATH_INTERNAL_VREFINT + * @arg @ref LL_ADC_PATH_INTERNAL_TEMPSENSOR + * @arg @ref LL_ADC_PATH_INTERNAL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetCommonPathInternalCh(ADC_Common_TypeDef *ADCxy_COMMON, uint32_t PathInternal) +{ +#if defined(ADC_CCR_VBATEN) + MODIFY_REG(ADCxy_COMMON->CCR, ADC_CCR_VREFEN | ADC_CCR_TSEN | ADC_CCR_VBATEN, PathInternal); +#else + MODIFY_REG(ADCxy_COMMON->CCR, ADC_CCR_VREFEN | ADC_CCR_TSEN, PathInternal); +#endif +} + +/** + * @brief Get parameter common to several ADC: measurement path to internal + * channels (VrefInt, temperature sensor, ...). + * @note One or several values can be selected. + * Example: (LL_ADC_PATH_INTERNAL_VREFINT | + * LL_ADC_PATH_INTERNAL_TEMPSENSOR) + * @rmtoll CCR VREFEN LL_ADC_GetCommonPathInternalCh\n + * CCR TSEN LL_ADC_GetCommonPathInternalCh\n + * CCR VBATEN LL_ADC_GetCommonPathInternalCh + * @param ADCxy_COMMON ADC common instance + * (can be set directly from CMSIS definition or by using helper macro @ref __LL_ADC_COMMON_INSTANCE() ) + * @retval Returned value can be a combination of the following values: + * @arg @ref LL_ADC_PATH_INTERNAL_NONE + * @arg @ref LL_ADC_PATH_INTERNAL_VREFINT + * @arg @ref LL_ADC_PATH_INTERNAL_TEMPSENSOR + * @arg @ref LL_ADC_PATH_INTERNAL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + */ +__STATIC_INLINE uint32_t LL_ADC_GetCommonPathInternalCh(ADC_Common_TypeDef *ADCxy_COMMON) +{ +#if defined(ADC_CCR_VBATEN) + return (uint32_t)(READ_BIT(ADCxy_COMMON->CCR, ADC_CCR_VREFEN | ADC_CCR_TSEN | ADC_CCR_VBATEN)); +#else + return (uint32_t)(READ_BIT(ADCxy_COMMON->CCR, ADC_CCR_VREFEN | ADC_CCR_TSEN)); +#endif +} + +/** + * @} + */ + +/** @defgroup ADC_LL_EF_Configuration_ADC_Instance Configuration of ADC hierarchical scope: ADC instance + * @{ + */ + +/** + * @brief Set ADC instance clock source and prescaler. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled. + * @rmtoll CFGR2 CKMODE LL_ADC_SetClock + * @param ADCx ADC instance + * @param ClockSource This parameter can be one of the following values: + * @arg @ref LL_ADC_CLOCK_SYNC_PCLK_DIV4 + * @arg @ref LL_ADC_CLOCK_SYNC_PCLK_DIV2 + * @arg @ref LL_ADC_CLOCK_ASYNC (1) + * + * (1) On this STM32 serie, synchronous clock has no prescaler. + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetClock(ADC_TypeDef *ADCx, uint32_t ClockSource) +{ + MODIFY_REG(ADCx->CFGR2, ADC_CFGR2_CKMODE, ClockSource); +} + +/** + * @brief Get ADC instance clock source and prescaler. + * @rmtoll CFGR2 CKMODE LL_ADC_GetClock + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_CLOCK_SYNC_PCLK_DIV4 + * @arg @ref LL_ADC_CLOCK_SYNC_PCLK_DIV2 + * @arg @ref LL_ADC_CLOCK_ASYNC (1) + * + * (1) On this STM32 serie, synchronous clock has no prescaler. + */ +__STATIC_INLINE uint32_t LL_ADC_GetClock(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR2, ADC_CFGR2_CKMODE)); +} + +/** + * @brief Set ADC resolution. + * Refer to reference manual for alignments formats + * dependencies to ADC resolutions. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 RES LL_ADC_SetResolution + * @param ADCx ADC instance + * @param Resolution This parameter can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetResolution(ADC_TypeDef *ADCx, uint32_t Resolution) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_RES, Resolution); +} + +/** + * @brief Get ADC resolution. + * Refer to reference manual for alignments formats + * dependencies to ADC resolutions. + * @rmtoll CFGR1 RES LL_ADC_GetResolution + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_RESOLUTION_12B + * @arg @ref LL_ADC_RESOLUTION_10B + * @arg @ref LL_ADC_RESOLUTION_8B + * @arg @ref LL_ADC_RESOLUTION_6B + */ +__STATIC_INLINE uint32_t LL_ADC_GetResolution(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_RES)); +} + +/** + * @brief Set ADC conversion data alignment. + * @note Refer to reference manual for alignments formats + * dependencies to ADC resolutions. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 ALIGN LL_ADC_SetDataAlignment + * @param ADCx ADC instance + * @param DataAlignment This parameter can be one of the following values: + * @arg @ref LL_ADC_DATA_ALIGN_RIGHT + * @arg @ref LL_ADC_DATA_ALIGN_LEFT + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetDataAlignment(ADC_TypeDef *ADCx, uint32_t DataAlignment) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_ALIGN, DataAlignment); +} + +/** + * @brief Get ADC conversion data alignment. + * @note Refer to reference manual for alignments formats + * dependencies to ADC resolutions. + * @rmtoll CFGR1 ALIGN LL_ADC_GetDataAlignment + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_DATA_ALIGN_RIGHT + * @arg @ref LL_ADC_DATA_ALIGN_LEFT + */ +__STATIC_INLINE uint32_t LL_ADC_GetDataAlignment(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_ALIGN)); +} + +/** + * @brief Set ADC low power mode. + * @note Description of ADC low power modes: + * - ADC low power mode "auto wait": Dynamic low power mode, + * ADC conversions occurrences are limited to the minimum necessary + * in order to reduce power consumption. + * New ADC conversion starts only when the previous + * unitary conversion data (for ADC group regular) + * has been retrieved by user software. + * In the meantime, ADC remains idle: does not performs any + * other conversion. + * This mode allows to automatically adapt the ADC conversions + * triggers to the speed of the software that reads the data. + * Moreover, this avoids risk of overrun for low frequency + * applications. + * How to use this low power mode: + * - Do not use with interruption or DMA since these modes + * have to clear immediately the EOC flag to free the + * IRQ vector sequencer. + * - Do use with polling: 1. Start conversion, + * 2. Later on, when conversion data is needed: poll for end of + * conversion to ensure that conversion is completed and + * retrieve ADC conversion data. This will trig another + * ADC conversion start. + * - ADC low power mode "auto power-off" (feature available on + * this device if parameter LL_ADC_LP_MODE_AUTOOFF is available): + * the ADC automatically powers-off after a conversion and + * automatically wakes up when a new conversion is triggered + * (with startup time between trigger and start of sampling). + * This feature can be combined with low power mode "auto wait". + * @note With ADC low power mode "auto wait", the ADC conversion data read + * is corresponding to previous ADC conversion start, independently + * of delay during which ADC was idle. + * Therefore, the ADC conversion data may be outdated: does not + * correspond to the current voltage level on the selected + * ADC channel. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 WAIT LL_ADC_SetLowPowerMode\n + * CFGR1 AUTOFF LL_ADC_SetLowPowerMode + * @param ADCx ADC instance + * @param LowPowerMode This parameter can be one of the following values: + * @arg @ref LL_ADC_LP_MODE_NONE + * @arg @ref LL_ADC_LP_AUTOWAIT + * @arg @ref LL_ADC_LP_AUTOPOWEROFF + * @arg @ref LL_ADC_LP_AUTOWAIT_AUTOPOWEROFF + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetLowPowerMode(ADC_TypeDef *ADCx, uint32_t LowPowerMode) +{ + MODIFY_REG(ADCx->CFGR1, (ADC_CFGR1_WAIT | ADC_CFGR1_AUTOFF), LowPowerMode); +} + +/** + * @brief Get ADC low power mode: + * @note Description of ADC low power modes: + * - ADC low power mode "auto wait": Dynamic low power mode, + * ADC conversions occurrences are limited to the minimum necessary + * in order to reduce power consumption. + * New ADC conversion starts only when the previous + * unitary conversion data (for ADC group regular) + * has been retrieved by user software. + * In the meantime, ADC remains idle: does not performs any + * other conversion. + * This mode allows to automatically adapt the ADC conversions + * triggers to the speed of the software that reads the data. + * Moreover, this avoids risk of overrun for low frequency + * applications. + * How to use this low power mode: + * - Do not use with interruption or DMA since these modes + * have to clear immediately the EOC flag to free the + * IRQ vector sequencer. + * - Do use with polling: 1. Start conversion, + * 2. Later on, when conversion data is needed: poll for end of + * conversion to ensure that conversion is completed and + * retrieve ADC conversion data. This will trig another + * ADC conversion start. + * - ADC low power mode "auto power-off" (feature available on + * this device if parameter LL_ADC_LP_MODE_AUTOOFF is available): + * the ADC automatically powers-off after a conversion and + * automatically wakes up when a new conversion is triggered + * (with startup time between trigger and start of sampling). + * This feature can be combined with low power mode "auto wait". + * @note With ADC low power mode "auto wait", the ADC conversion data read + * is corresponding to previous ADC conversion start, independently + * of delay during which ADC was idle. + * Therefore, the ADC conversion data may be outdated: does not + * correspond to the current voltage level on the selected + * ADC channel. + * @rmtoll CFGR1 WAIT LL_ADC_GetLowPowerMode\n + * CFGR1 AUTOFF LL_ADC_GetLowPowerMode + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_LP_MODE_NONE + * @arg @ref LL_ADC_LP_AUTOWAIT + * @arg @ref LL_ADC_LP_AUTOPOWEROFF + * @arg @ref LL_ADC_LP_AUTOWAIT_AUTOPOWEROFF + */ +__STATIC_INLINE uint32_t LL_ADC_GetLowPowerMode(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, (ADC_CFGR1_WAIT | ADC_CFGR1_AUTOFF))); +} + +/** + * @brief Set sampling time common to a group of channels. + * @note Unit: ADC clock cycles. + * @note On this STM32 serie, sampling time scope is on ADC instance: + * Sampling time common to all channels. + * (on some other STM32 families, sampling time is channel wise) + * @note In case of internal channel (VrefInt, TempSensor, ...) to be + * converted: + * sampling time constraints must be respected (sampling time can be + * adjusted in function of ADC clock frequency and sampling time + * setting). + * Refer to device datasheet for timings values (parameters TS_vrefint, + * TS_temp, ...). + * @note Conversion time is the addition of sampling time and processing time. + * On this STM32 serie, ADC processing time is: + * - 12.5 ADC clock cycles at ADC resolution 12 bits + * - 10.5 ADC clock cycles at ADC resolution 10 bits + * - 8.5 ADC clock cycles at ADC resolution 8 bits + * - 6.5 ADC clock cycles at ADC resolution 6 bits + * @note In case of ADC conversion of internal channel (VrefInt, + * temperature sensor, ...), a sampling time minimum value + * is required. + * Refer to device datasheet. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll SMPR SMP LL_ADC_SetSamplingTimeCommonChannels + * @param ADCx ADC instance + * @param SamplingTime This parameter can be one of the following values: + * @arg @ref LL_ADC_SAMPLINGTIME_1CYCLE_5 + * @arg @ref LL_ADC_SAMPLINGTIME_7CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_13CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_28CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_41CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_55CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_71CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_239CYCLES_5 + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetSamplingTimeCommonChannels(ADC_TypeDef *ADCx, uint32_t SamplingTime) +{ + MODIFY_REG(ADCx->SMPR, ADC_SMPR_SMP, SamplingTime); +} + +/** + * @brief Get sampling time common to a group of channels. + * @note Unit: ADC clock cycles. + * @note On this STM32 serie, sampling time scope is on ADC instance: + * Sampling time common to all channels. + * (on some other STM32 families, sampling time is channel wise) + * @note Conversion time is the addition of sampling time and processing time. + * Refer to reference manual for ADC processing time of + * this STM32 serie. + * @rmtoll SMPR SMP LL_ADC_GetSamplingTimeCommonChannels + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_SAMPLINGTIME_1CYCLE_5 + * @arg @ref LL_ADC_SAMPLINGTIME_7CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_13CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_28CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_41CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_55CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_71CYCLES_5 + * @arg @ref LL_ADC_SAMPLINGTIME_239CYCLES_5 + */ +__STATIC_INLINE uint32_t LL_ADC_GetSamplingTimeCommonChannels(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->SMPR, ADC_SMPR_SMP)); +} + +/** + * @} + */ + +/** @defgroup ADC_LL_EF_Configuration_ADC_Group_Regular Configuration of ADC hierarchical scope: group regular + * @{ + */ + +/** + * @brief Set ADC group regular conversion trigger source: + * internal (SW start) or from external IP (timer event, + * external interrupt line). + * @note On this STM32 serie, setting trigger source to external trigger + * also set trigger polarity to rising edge + * (default setting for compatibility with some ADC on other + * STM32 families having this setting set by HW default value). + * In case of need to modify trigger edge, use + * function @ref LL_ADC_REG_SetTriggerEdge(). + * @note Availability of parameters of trigger sources from timer + * depends on timers availability on the selected device. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 EXTSEL LL_ADC_REG_SetTriggerSource\n + * CFGR1 EXTEN LL_ADC_REG_SetTriggerSource + * @param ADCx ADC instance + * @param TriggerSource This parameter can be one of the following values: + * @arg @ref LL_ADC_REG_TRIG_SOFTWARE + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM1_TRGO + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM1_CH4 + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM2_TRGO (1) + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM3_TRGO + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM15_TRGO (1) + * + * (1) On STM32F0, parameter not available on all devices + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetTriggerSource(ADC_TypeDef *ADCx, uint32_t TriggerSource) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_EXTEN | ADC_CFGR1_EXTSEL, TriggerSource); +} + +/** + * @brief Get ADC group regular conversion trigger source: + * internal (SW start) or from external IP (timer event, + * external interrupt line). + * @note To determine whether group regular trigger source is + * internal (SW start) or external, without detail + * of which peripheral is selected as external trigger, + * (equivalent to + * "if(LL_ADC_REG_GetTriggerSource(ADC1) == LL_ADC_REG_TRIG_SOFTWARE)") + * use function @ref LL_ADC_REG_IsTriggerSourceSWStart. + * @note Availability of parameters of trigger sources from timer + * depends on timers availability on the selected device. + * @rmtoll CFGR1 EXTSEL LL_ADC_REG_GetTriggerSource\n + * CFGR1 EXTEN LL_ADC_REG_GetTriggerSource + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_REG_TRIG_SOFTWARE + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM1_TRGO + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM1_CH4 + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM2_TRGO (1) + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM3_TRGO + * @arg @ref LL_ADC_REG_TRIG_EXT_TIM15_TRGO (1) + * + * (1) On STM32F0, parameter not available on all devices + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetTriggerSource(ADC_TypeDef *ADCx) +{ + uint32_t TriggerSource = READ_BIT(ADCx->CFGR1, ADC_CFGR1_EXTSEL | ADC_CFGR1_EXTEN); + + /* Value for shift of {0; 4; 8; 12} depending on value of bitfield */ + /* corresponding to ADC_CFGR1_EXTEN {0; 1; 2; 3}. */ + uint32_t ShiftExten = ((TriggerSource & ADC_CFGR1_EXTEN) >> (ADC_REG_TRIG_EXTEN_BITOFFSET_POS - 2U)); + + /* Set bitfield corresponding to ADC_CFGR1_EXTEN and ADC_CFGR1_EXTSEL */ + /* to match with triggers literals definition. */ + return ((TriggerSource + & (ADC_REG_TRIG_SOURCE_MASK >> ShiftExten) & ADC_CFGR1_EXTSEL) + | ((ADC_REG_TRIG_EDGE_MASK >> ShiftExten) & ADC_CFGR1_EXTEN) + ); +} + +/** + * @brief Get ADC group regular conversion trigger source internal (SW start) + or external. + * @note In case of group regular trigger source set to external trigger, + * to determine which peripheral is selected as external trigger, + * use function @ref LL_ADC_REG_GetTriggerSource(). + * @rmtoll CFGR1 EXTEN LL_ADC_REG_IsTriggerSourceSWStart + * @param ADCx ADC instance + * @retval Value "0" if trigger source external trigger + * Value "1" if trigger source SW start. + */ +__STATIC_INLINE uint32_t LL_ADC_REG_IsTriggerSourceSWStart(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->CFGR1, ADC_CFGR1_EXTEN) == (LL_ADC_REG_TRIG_SOFTWARE & ADC_CFGR1_EXTEN)); +} + +/** + * @brief Set ADC group regular conversion trigger polarity. + * @note Applicable only for trigger source set to external trigger. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 EXTEN LL_ADC_REG_SetTriggerEdge + * @param ADCx ADC instance + * @param ExternalTriggerEdge This parameter can be one of the following values: + * @arg @ref LL_ADC_REG_TRIG_EXT_RISING + * @arg @ref LL_ADC_REG_TRIG_EXT_FALLING + * @arg @ref LL_ADC_REG_TRIG_EXT_RISINGFALLING + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetTriggerEdge(ADC_TypeDef *ADCx, uint32_t ExternalTriggerEdge) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_EXTEN, ExternalTriggerEdge); +} + +/** + * @brief Get ADC group regular conversion trigger polarity. + * @note Applicable only for trigger source set to external trigger. + * @rmtoll CFGR1 EXTEN LL_ADC_REG_GetTriggerEdge + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_REG_TRIG_EXT_RISING + * @arg @ref LL_ADC_REG_TRIG_EXT_FALLING + * @arg @ref LL_ADC_REG_TRIG_EXT_RISINGFALLING + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetTriggerEdge(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_EXTEN)); +} + + +/** + * @brief Set ADC group regular sequencer scan direction. + * @note On some other STM32 families, this setting is not available and + * the default scan direction is forward. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 SCANDIR LL_ADC_REG_SetSequencerScanDirection + * @param ADCx ADC instance + * @param ScanDirection This parameter can be one of the following values: + * @arg @ref LL_ADC_REG_SEQ_SCAN_DIR_FORWARD + * @arg @ref LL_ADC_REG_SEQ_SCAN_DIR_BACKWARD + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetSequencerScanDirection(ADC_TypeDef *ADCx, uint32_t ScanDirection) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_SCANDIR, ScanDirection); +} + +/** + * @brief Get ADC group regular sequencer scan direction. + * @note On some other STM32 families, this setting is not available and + * the default scan direction is forward. + * @rmtoll CFGR1 SCANDIR LL_ADC_REG_GetSequencerScanDirection + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_REG_SEQ_SCAN_DIR_FORWARD + * @arg @ref LL_ADC_REG_SEQ_SCAN_DIR_BACKWARD + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetSequencerScanDirection(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_SCANDIR)); +} + +/** + * @brief Set ADC group regular sequencer discontinuous mode: + * sequence subdivided and scan conversions interrupted every selected + * number of ranks. + * @note It is not possible to enable both ADC group regular + * continuous mode and sequencer discontinuous mode. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 DISCEN LL_ADC_REG_SetSequencerDiscont\n + * @param ADCx ADC instance + * @param SeqDiscont This parameter can be one of the following values: + * @arg @ref LL_ADC_REG_SEQ_DISCONT_DISABLE + * @arg @ref LL_ADC_REG_SEQ_DISCONT_1RANK + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetSequencerDiscont(ADC_TypeDef *ADCx, uint32_t SeqDiscont) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_DISCEN, SeqDiscont); +} + +/** + * @brief Get ADC group regular sequencer discontinuous mode: + * sequence subdivided and scan conversions interrupted every selected + * number of ranks. + * @rmtoll CFGR1 DISCEN LL_ADC_REG_GetSequencerDiscont\n + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_REG_SEQ_DISCONT_DISABLE + * @arg @ref LL_ADC_REG_SEQ_DISCONT_1RANK + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetSequencerDiscont(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_DISCEN)); +} + +/** + * @brief Set ADC group regular sequence: channel on rank corresponding to + * channel number. + * @note This function performs: + * - Channels ordering into each rank of scan sequence: + * rank of each channel is fixed by channel HW number + * (channel 0 fixed on rank 0, channel 1 fixed on rank1, ...). + * - Set channels selected by overwriting the current sequencer + * configuration. + * @note On this STM32 serie, ADC group regular sequencer is + * not fully configurable: sequencer length and each rank + * affectation to a channel are fixed by channel HW number. + * @note Depending on devices and packages, some channels may not be available. + * Refer to device datasheet for channels availability. + * @note On this STM32 serie, to measure internal channels (VrefInt, + * TempSensor, ...), measurement paths to internal channels must be + * enabled separately. + * This can be done using function @ref LL_ADC_SetCommonPathInternalCh(). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @note One or several values can be selected. + * Example: (LL_ADC_CHANNEL_4 | LL_ADC_CHANNEL_12 | ...) + * @rmtoll CHSELR CHSEL0 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL1 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL2 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL3 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL4 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL5 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL6 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL7 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL8 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL9 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL10 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL11 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL12 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL13 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL14 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL15 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL16 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL17 LL_ADC_REG_SetSequencerChannels\n + * CHSELR CHSEL18 LL_ADC_REG_SetSequencerChannels + * @param ADCx ADC instance + * @param Channel This parameter can be a combination of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetSequencerChannels(ADC_TypeDef *ADCx, uint32_t Channel) +{ + /* Parameter "Channel" is used with masks because containing */ + /* other bits reserved for other purpose. */ + WRITE_REG(ADCx->CHSELR, (Channel & ADC_CHANNEL_ID_BITFIELD_MASK)); +} + +/** + * @brief Add channel to ADC group regular sequence: channel on rank corresponding to + * channel number. + * @note This function performs: + * - Channels ordering into each rank of scan sequence: + * rank of each channel is fixed by channel HW number + * (channel 0 fixed on rank 0, channel 1 fixed on rank1, ...). + * - Set channels selected by adding them to the current sequencer + * configuration. + * @note On this STM32 serie, ADC group regular sequencer is + * not fully configurable: sequencer length and each rank + * affectation to a channel are fixed by channel HW number. + * @note Depending on devices and packages, some channels may not be available. + * Refer to device datasheet for channels availability. + * @note On this STM32 serie, to measure internal channels (VrefInt, + * TempSensor, ...), measurement paths to internal channels must be + * enabled separately. + * This can be done using function @ref LL_ADC_SetCommonPathInternalCh(). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @note One or several values can be selected. + * Example: (LL_ADC_CHANNEL_4 | LL_ADC_CHANNEL_12 | ...) + * @rmtoll CHSELR CHSEL0 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL1 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL2 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL3 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL4 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL5 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL6 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL7 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL8 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL9 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL10 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL11 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL12 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL13 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL14 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL15 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL16 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL17 LL_ADC_REG_SetSequencerChAdd\n + * CHSELR CHSEL18 LL_ADC_REG_SetSequencerChAdd + * @param ADCx ADC instance + * @param Channel This parameter can be a combination of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetSequencerChAdd(ADC_TypeDef *ADCx, uint32_t Channel) +{ + /* Parameter "Channel" is used with masks because containing */ + /* other bits reserved for other purpose. */ + SET_BIT(ADCx->CHSELR, (Channel & ADC_CHANNEL_ID_BITFIELD_MASK)); +} + +/** + * @brief Remove channel to ADC group regular sequence: channel on rank corresponding to + * channel number. + * @note This function performs: + * - Channels ordering into each rank of scan sequence: + * rank of each channel is fixed by channel HW number + * (channel 0 fixed on rank 0, channel 1 fixed on rank1, ...). + * - Set channels selected by removing them to the current sequencer + * configuration. + * @note On this STM32 serie, ADC group regular sequencer is + * not fully configurable: sequencer length and each rank + * affectation to a channel are fixed by channel HW number. + * @note Depending on devices and packages, some channels may not be available. + * Refer to device datasheet for channels availability. + * @note On this STM32 serie, to measure internal channels (VrefInt, + * TempSensor, ...), measurement paths to internal channels must be + * enabled separately. + * This can be done using function @ref LL_ADC_SetCommonPathInternalCh(). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @note One or several values can be selected. + * Example: (LL_ADC_CHANNEL_4 | LL_ADC_CHANNEL_12 | ...) + * @rmtoll CHSELR CHSEL0 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL1 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL2 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL3 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL4 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL5 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL6 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL7 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL8 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL9 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL10 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL11 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL12 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL13 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL14 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL15 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL16 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL17 LL_ADC_REG_SetSequencerChRem\n + * CHSELR CHSEL18 LL_ADC_REG_SetSequencerChRem + * @param ADCx ADC instance + * @param Channel This parameter can be a combination of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetSequencerChRem(ADC_TypeDef *ADCx, uint32_t Channel) +{ + /* Parameter "Channel" is used with masks because containing */ + /* other bits reserved for other purpose. */ + CLEAR_BIT(ADCx->CHSELR, (Channel & ADC_CHANNEL_ID_BITFIELD_MASK)); +} + +/** + * @brief Get ADC group regular sequence: channel on rank corresponding to + * channel number. + * @note This function performs: + * - Channels order reading into each rank of scan sequence: + * rank of each channel is fixed by channel HW number + * (channel 0 fixed on rank 0, channel 1 fixed on rank1, ...). + * @note On this STM32 serie, ADC group regular sequencer is + * not fully configurable: sequencer length and each rank + * affectation to a channel are fixed by channel HW number. + * @note Depending on devices and packages, some channels may not be available. + * Refer to device datasheet for channels availability. + * @note On this STM32 serie, to measure internal channels (VrefInt, + * TempSensor, ...), measurement paths to internal channels must be + * enabled separately. + * This can be done using function @ref LL_ADC_SetCommonPathInternalCh(). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @note One or several values can be retrieved. + * Example: (LL_ADC_CHANNEL_4 | LL_ADC_CHANNEL_12 | ...) + * @rmtoll CHSELR CHSEL0 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL1 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL2 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL3 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL4 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL5 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL6 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL7 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL8 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL9 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL10 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL11 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL12 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL13 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL14 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL15 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL16 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL17 LL_ADC_REG_GetSequencerChannels\n + * CHSELR CHSEL18 LL_ADC_REG_GetSequencerChannels + * @param ADCx ADC instance + * @retval Returned value can be a combination of the following values: + * @arg @ref LL_ADC_CHANNEL_0 + * @arg @ref LL_ADC_CHANNEL_1 + * @arg @ref LL_ADC_CHANNEL_2 + * @arg @ref LL_ADC_CHANNEL_3 + * @arg @ref LL_ADC_CHANNEL_4 + * @arg @ref LL_ADC_CHANNEL_5 + * @arg @ref LL_ADC_CHANNEL_6 + * @arg @ref LL_ADC_CHANNEL_7 + * @arg @ref LL_ADC_CHANNEL_8 + * @arg @ref LL_ADC_CHANNEL_9 + * @arg @ref LL_ADC_CHANNEL_10 + * @arg @ref LL_ADC_CHANNEL_11 + * @arg @ref LL_ADC_CHANNEL_12 + * @arg @ref LL_ADC_CHANNEL_13 + * @arg @ref LL_ADC_CHANNEL_14 + * @arg @ref LL_ADC_CHANNEL_15 + * @arg @ref LL_ADC_CHANNEL_16 + * @arg @ref LL_ADC_CHANNEL_17 + * @arg @ref LL_ADC_CHANNEL_18 (1) + * @arg @ref LL_ADC_CHANNEL_VREFINT + * @arg @ref LL_ADC_CHANNEL_TEMPSENSOR + * @arg @ref LL_ADC_CHANNEL_VBAT (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetSequencerChannels(ADC_TypeDef *ADCx) +{ + uint32_t ChannelsBitfield = READ_BIT(ADCx->CHSELR, ADC_CHSELR_CHSEL); + + return ( (((ChannelsBitfield & ADC_CHSELR_CHSEL0) >> ADC_CHSELR_CHSEL0_BITOFFSET_POS) * LL_ADC_CHANNEL_0) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL1) >> ADC_CHSELR_CHSEL1_BITOFFSET_POS) * LL_ADC_CHANNEL_1) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL2) >> ADC_CHSELR_CHSEL2_BITOFFSET_POS) * LL_ADC_CHANNEL_2) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL3) >> ADC_CHSELR_CHSEL3_BITOFFSET_POS) * LL_ADC_CHANNEL_3) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL4) >> ADC_CHSELR_CHSEL4_BITOFFSET_POS) * LL_ADC_CHANNEL_4) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL5) >> ADC_CHSELR_CHSEL5_BITOFFSET_POS) * LL_ADC_CHANNEL_5) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL6) >> ADC_CHSELR_CHSEL6_BITOFFSET_POS) * LL_ADC_CHANNEL_6) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL7) >> ADC_CHSELR_CHSEL7_BITOFFSET_POS) * LL_ADC_CHANNEL_7) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL8) >> ADC_CHSELR_CHSEL8_BITOFFSET_POS) * LL_ADC_CHANNEL_8) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL9) >> ADC_CHSELR_CHSEL9_BITOFFSET_POS) * LL_ADC_CHANNEL_9) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL10) >> ADC_CHSELR_CHSEL10_BITOFFSET_POS) * LL_ADC_CHANNEL_10) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL11) >> ADC_CHSELR_CHSEL11_BITOFFSET_POS) * LL_ADC_CHANNEL_11) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL12) >> ADC_CHSELR_CHSEL12_BITOFFSET_POS) * LL_ADC_CHANNEL_12) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL13) >> ADC_CHSELR_CHSEL13_BITOFFSET_POS) * LL_ADC_CHANNEL_13) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL14) >> ADC_CHSELR_CHSEL14_BITOFFSET_POS) * LL_ADC_CHANNEL_14) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL15) >> ADC_CHSELR_CHSEL15_BITOFFSET_POS) * LL_ADC_CHANNEL_15) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL16) >> ADC_CHSELR_CHSEL16_BITOFFSET_POS) * LL_ADC_CHANNEL_16) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL17) >> ADC_CHSELR_CHSEL17_BITOFFSET_POS) * LL_ADC_CHANNEL_17) +#if defined(ADC_CCR_VBATEN) + | (((ChannelsBitfield & ADC_CHSELR_CHSEL18) >> ADC_CHSELR_CHSEL18_BITOFFSET_POS) * LL_ADC_CHANNEL_18) +#endif + ); +} +/** + * @brief Set ADC continuous conversion mode on ADC group regular. + * @note Description of ADC continuous conversion mode: + * - single mode: one conversion per trigger + * - continuous mode: after the first trigger, following + * conversions launched successively automatically. + * @note It is not possible to enable both ADC group regular + * continuous mode and sequencer discontinuous mode. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 CONT LL_ADC_REG_SetContinuousMode + * @param ADCx ADC instance + * @param Continuous This parameter can be one of the following values: + * @arg @ref LL_ADC_REG_CONV_SINGLE + * @arg @ref LL_ADC_REG_CONV_CONTINUOUS + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetContinuousMode(ADC_TypeDef *ADCx, uint32_t Continuous) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_CONT, Continuous); +} + +/** + * @brief Get ADC continuous conversion mode on ADC group regular. + * @note Description of ADC continuous conversion mode: + * - single mode: one conversion per trigger + * - continuous mode: after the first trigger, following + * conversions launched successively automatically. + * @rmtoll CFGR1 CONT LL_ADC_REG_GetContinuousMode + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_REG_CONV_SINGLE + * @arg @ref LL_ADC_REG_CONV_CONTINUOUS + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetContinuousMode(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_CONT)); +} + +/** + * @brief Set ADC group regular conversion data transfer: no transfer or + * transfer by DMA, and DMA requests mode. + * @note If transfer by DMA selected, specifies the DMA requests + * mode: + * - Limited mode (One shot mode): DMA transfer requests are stopped + * when number of DMA data transfers (number of + * ADC conversions) is reached. + * This ADC mode is intended to be used with DMA mode non-circular. + * - Unlimited mode: DMA transfer requests are unlimited, + * whatever number of DMA data transfers (number of + * ADC conversions). + * This ADC mode is intended to be used with DMA mode circular. + * @note If ADC DMA requests mode is set to unlimited and DMA is set to + * mode non-circular: + * when DMA transfers size will be reached, DMA will stop transfers of + * ADC conversions data ADC will raise an overrun error + * (overrun flag and interruption if enabled). + * @note To configure DMA source address (peripheral address), + * use function @ref LL_ADC_DMA_GetRegAddr(). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 DMAEN LL_ADC_REG_SetDMATransfer\n + * CFGR1 DMACFG LL_ADC_REG_SetDMATransfer + * @param ADCx ADC instance + * @param DMATransfer This parameter can be one of the following values: + * @arg @ref LL_ADC_REG_DMA_TRANSFER_NONE + * @arg @ref LL_ADC_REG_DMA_TRANSFER_LIMITED + * @arg @ref LL_ADC_REG_DMA_TRANSFER_UNLIMITED + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetDMATransfer(ADC_TypeDef *ADCx, uint32_t DMATransfer) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_DMAEN | ADC_CFGR1_DMACFG, DMATransfer); +} + +/** + * @brief Get ADC group regular conversion data transfer: no transfer or + * transfer by DMA, and DMA requests mode. + * @note If transfer by DMA selected, specifies the DMA requests + * mode: + * - Limited mode (One shot mode): DMA transfer requests are stopped + * when number of DMA data transfers (number of + * ADC conversions) is reached. + * This ADC mode is intended to be used with DMA mode non-circular. + * - Unlimited mode: DMA transfer requests are unlimited, + * whatever number of DMA data transfers (number of + * ADC conversions). + * This ADC mode is intended to be used with DMA mode circular. + * @note If ADC DMA requests mode is set to unlimited and DMA is set to + * mode non-circular: + * when DMA transfers size will be reached, DMA will stop transfers of + * ADC conversions data ADC will raise an overrun error + * (overrun flag and interruption if enabled). + * @note To configure DMA source address (peripheral address), + * use function @ref LL_ADC_DMA_GetRegAddr(). + * @rmtoll CFGR1 DMAEN LL_ADC_REG_GetDMATransfer\n + * CFGR1 DMACFG LL_ADC_REG_GetDMATransfer + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_REG_DMA_TRANSFER_NONE + * @arg @ref LL_ADC_REG_DMA_TRANSFER_LIMITED + * @arg @ref LL_ADC_REG_DMA_TRANSFER_UNLIMITED + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetDMATransfer(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_DMAEN | ADC_CFGR1_DMACFG)); +} + +/** + * @brief Set ADC group regular behavior in case of overrun: + * data preserved or overwritten. + * @note Compatibility with devices without feature overrun: + * other devices without this feature have a behavior + * equivalent to data overwritten. + * The default setting of overrun is data preserved. + * Therefore, for compatibility with all devices, parameter + * overrun should be set to data overwritten. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 OVRMOD LL_ADC_REG_SetOverrun + * @param ADCx ADC instance + * @param Overrun This parameter can be one of the following values: + * @arg @ref LL_ADC_REG_OVR_DATA_PRESERVED + * @arg @ref LL_ADC_REG_OVR_DATA_OVERWRITTEN + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_SetOverrun(ADC_TypeDef *ADCx, uint32_t Overrun) +{ + MODIFY_REG(ADCx->CFGR1, ADC_CFGR1_OVRMOD, Overrun); +} + +/** + * @brief Get ADC group regular behavior in case of overrun: + * data preserved or overwritten. + * @rmtoll CFGR1 OVRMOD LL_ADC_REG_GetOverrun + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_REG_OVR_DATA_PRESERVED + * @arg @ref LL_ADC_REG_OVR_DATA_OVERWRITTEN + */ +__STATIC_INLINE uint32_t LL_ADC_REG_GetOverrun(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->CFGR1, ADC_CFGR1_OVRMOD)); +} + +/** + * @} + */ + + +/** @defgroup ADC_LL_EF_Configuration_ADC_AnalogWatchdog Configuration of ADC transversal scope: analog watchdog + * @{ + */ + +/** + * @brief Set ADC analog watchdog monitored channels: + * a single channel or all channels, + * on ADC group regular. + * @note Once monitored channels are selected, analog watchdog + * is enabled. + * @note In case of need to define a single channel to monitor + * with analog watchdog from sequencer channel definition, + * use helper macro @ref __LL_ADC_ANALOGWD_CHANNEL_GROUP(). + * @note On this STM32 serie, there is only 1 kind of analog watchdog + * instance: + * - AWD standard (instance AWD1): + * - channels monitored: can monitor 1 channel or all channels. + * - groups monitored: ADC group regular. + * - resolution: resolution is not limited (corresponds to + * ADC resolution configured). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 AWDCH LL_ADC_SetAnalogWDMonitChannels\n + * CFGR1 AWDSGL LL_ADC_SetAnalogWDMonitChannels\n + * CFGR1 AWDEN LL_ADC_SetAnalogWDMonitChannels + * @param ADCx ADC instance + * @param AWDChannelGroup This parameter can be one of the following values: + * @arg @ref LL_ADC_AWD_DISABLE + * @arg @ref LL_ADC_AWD_ALL_CHANNELS_REG + * @arg @ref LL_ADC_AWD_CHANNEL_0_REG + * @arg @ref LL_ADC_AWD_CHANNEL_1_REG + * @arg @ref LL_ADC_AWD_CHANNEL_2_REG + * @arg @ref LL_ADC_AWD_CHANNEL_3_REG + * @arg @ref LL_ADC_AWD_CHANNEL_4_REG + * @arg @ref LL_ADC_AWD_CHANNEL_5_REG + * @arg @ref LL_ADC_AWD_CHANNEL_6_REG + * @arg @ref LL_ADC_AWD_CHANNEL_7_REG + * @arg @ref LL_ADC_AWD_CHANNEL_8_REG + * @arg @ref LL_ADC_AWD_CHANNEL_9_REG + * @arg @ref LL_ADC_AWD_CHANNEL_10_REG + * @arg @ref LL_ADC_AWD_CHANNEL_11_REG + * @arg @ref LL_ADC_AWD_CHANNEL_12_REG + * @arg @ref LL_ADC_AWD_CHANNEL_13_REG + * @arg @ref LL_ADC_AWD_CHANNEL_14_REG + * @arg @ref LL_ADC_AWD_CHANNEL_15_REG + * @arg @ref LL_ADC_AWD_CHANNEL_16_REG + * @arg @ref LL_ADC_AWD_CHANNEL_17_REG + * @arg @ref LL_ADC_AWD_CHANNEL_18_REG (1) + * @arg @ref LL_ADC_AWD_CH_VREFINT_REG + * @arg @ref LL_ADC_AWD_CH_TEMPSENSOR_REG + * @arg @ref LL_ADC_AWD_CH_VBAT_REG (1) + * + * (1) On STM32F0, parameter not available on all devices: all devices except STM32F030x6, STM32F030x8, STM32F030xC, STM32F070x6, STM32F070xB. + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetAnalogWDMonitChannels(ADC_TypeDef *ADCx, uint32_t AWDChannelGroup) +{ + MODIFY_REG(ADCx->CFGR1, + (ADC_CFGR1_AWDCH | ADC_CFGR1_AWDSGL | ADC_CFGR1_AWDEN), + (AWDChannelGroup & ADC_AWD_CR_ALL_CHANNEL_MASK)); +} + +/** + * @brief Get ADC analog watchdog monitored channel. + * @note Usage of the returned channel number: + * - To reinject this channel into another function LL_ADC_xxx: + * the returned channel number is only partly formatted on definition + * of literals LL_ADC_CHANNEL_x. Therefore, it has to be compared + * with parts of literals LL_ADC_CHANNEL_x or using + * helper macro @ref __LL_ADC_CHANNEL_TO_DECIMAL_NB(). + * Then the selected literal LL_ADC_CHANNEL_x can be used + * as parameter for another function. + * - To get the channel number in decimal format: + * process the returned value with the helper macro + * @ref __LL_ADC_CHANNEL_TO_DECIMAL_NB(). + * Applicable only when the analog watchdog is set to monitor + * one channel. + * @note On this STM32 serie, there is only 1 kind of analog watchdog + * instance: + * - AWD standard (instance AWD1): + * - channels monitored: can monitor 1 channel or all channels. + * - groups monitored: ADC group regular. + * - resolution: resolution is not limited (corresponds to + * ADC resolution configured). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll CFGR1 AWDCH LL_ADC_GetAnalogWDMonitChannels\n + * CFGR1 AWDSGL LL_ADC_GetAnalogWDMonitChannels\n + * CFGR1 AWDEN LL_ADC_GetAnalogWDMonitChannels + * @param ADCx ADC instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_ADC_AWD_DISABLE + * @arg @ref LL_ADC_AWD_ALL_CHANNELS_REG + * @arg @ref LL_ADC_AWD_CHANNEL_0_REG + * @arg @ref LL_ADC_AWD_CHANNEL_1_REG + * @arg @ref LL_ADC_AWD_CHANNEL_2_REG + * @arg @ref LL_ADC_AWD_CHANNEL_3_REG + * @arg @ref LL_ADC_AWD_CHANNEL_4_REG + * @arg @ref LL_ADC_AWD_CHANNEL_5_REG + * @arg @ref LL_ADC_AWD_CHANNEL_6_REG + * @arg @ref LL_ADC_AWD_CHANNEL_7_REG + * @arg @ref LL_ADC_AWD_CHANNEL_8_REG + * @arg @ref LL_ADC_AWD_CHANNEL_9_REG + * @arg @ref LL_ADC_AWD_CHANNEL_10_REG + * @arg @ref LL_ADC_AWD_CHANNEL_11_REG + * @arg @ref LL_ADC_AWD_CHANNEL_12_REG + * @arg @ref LL_ADC_AWD_CHANNEL_13_REG + * @arg @ref LL_ADC_AWD_CHANNEL_14_REG + * @arg @ref LL_ADC_AWD_CHANNEL_15_REG + * @arg @ref LL_ADC_AWD_CHANNEL_16_REG + * @arg @ref LL_ADC_AWD_CHANNEL_17_REG + * @arg @ref LL_ADC_AWD_CHANNEL_18_REG + */ +__STATIC_INLINE uint32_t LL_ADC_GetAnalogWDMonitChannels(ADC_TypeDef *ADCx) +{ + uint32_t AWDChannelGroup = READ_BIT(ADCx->CFGR1, (ADC_CFGR1_AWDCH | ADC_CFGR1_AWDSGL | ADC_CFGR1_AWDEN)); + + /* Note: Set variable according to channel definition including channel ID */ + /* with bitfield. */ + uint32_t AWDChannelSingle = ((AWDChannelGroup & ADC_CFGR1_AWDSGL) >> ADC_CFGR1_AWDSGL_BITOFFSET_POS); + uint32_t AWDChannelBitField = (ADC_CHANNEL_0_BITFIELD << ((AWDChannelGroup & ADC_CHANNEL_ID_NUMBER_MASK) >> ADC_CHANNEL_ID_NUMBER_BITOFFSET_POS)); + + return (AWDChannelGroup | (AWDChannelBitField * AWDChannelSingle)); +} + +/** + * @brief Set ADC analog watchdog thresholds value of both thresholds + * high and low. + * @note If value of only one threshold high or low must be set, + * use function @ref LL_ADC_SetAnalogWDThresholds(). + * @note In case of ADC resolution different of 12 bits, + * analog watchdog thresholds data require a specific shift. + * Use helper macro @ref __LL_ADC_ANALOGWD_SET_THRESHOLD_RESOLUTION(). + * @note On this STM32 serie, there is only 1 kind of analog watchdog + * instance: + * - AWD standard (instance AWD1): + * - channels monitored: can monitor 1 channel or all channels. + * - groups monitored: ADC group regular. + * - resolution: resolution is not limited (corresponds to + * ADC resolution configured). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll TR HT LL_ADC_ConfigAnalogWDThresholds\n + * TR LT LL_ADC_ConfigAnalogWDThresholds + * @param ADCx ADC instance + * @param AWDThresholdHighValue Value between Min_Data=0x000 and Max_Data=0xFFF + * @param AWDThresholdLowValue Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval None + */ +__STATIC_INLINE void LL_ADC_ConfigAnalogWDThresholds(ADC_TypeDef *ADCx, uint32_t AWDThresholdHighValue, uint32_t AWDThresholdLowValue) +{ + MODIFY_REG(ADCx->TR, + ADC_TR_HT | ADC_TR_LT, + (AWDThresholdHighValue << ADC_TR_HT_BITOFFSET_POS) | AWDThresholdLowValue); +} + +/** + * @brief Set ADC analog watchdog threshold value of threshold + * high or low. + * @note If values of both thresholds high or low must be set, + * use function @ref LL_ADC_ConfigAnalogWDThresholds(). + * @note In case of ADC resolution different of 12 bits, + * analog watchdog thresholds data require a specific shift. + * Use helper macro @ref __LL_ADC_ANALOGWD_SET_THRESHOLD_RESOLUTION(). + * @note On this STM32 serie, there is only 1 kind of analog watchdog + * instance: + * - AWD standard (instance AWD1): + * - channels monitored: can monitor 1 channel or all channels. + * - groups monitored: ADC group regular. + * - resolution: resolution is not limited (corresponds to + * ADC resolution configured). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be disabled or enabled without conversion on going + * on group regular. + * @rmtoll TR HT LL_ADC_SetAnalogWDThresholds\n + * TR LT LL_ADC_SetAnalogWDThresholds + * @param ADCx ADC instance + * @param AWDThresholdsHighLow This parameter can be one of the following values: + * @arg @ref LL_ADC_AWD_THRESHOLD_HIGH + * @arg @ref LL_ADC_AWD_THRESHOLD_LOW + * @param AWDThresholdValue Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval None + */ +__STATIC_INLINE void LL_ADC_SetAnalogWDThresholds(ADC_TypeDef *ADCx, uint32_t AWDThresholdsHighLow, uint32_t AWDThresholdValue) +{ + /* Parameter "AWDThresholdsHighLow" is used with mask "0x00000010" */ + /* to be equivalent to "POSITION_VAL(AWDThresholdsHighLow)": if threshold */ + /* high is selected, then data is shifted to LSB. Else(threshold low), */ + /* data is not shifted. */ + MODIFY_REG(ADCx->TR, + AWDThresholdsHighLow, + AWDThresholdValue << ((AWDThresholdsHighLow >> ADC_TR_HT_BITOFFSET_POS) & 0x00000010U)); +} + +/** + * @brief Get ADC analog watchdog threshold value of threshold high, + * threshold low or raw data with ADC thresholds high and low + * concatenated. + * @note If raw data with ADC thresholds high and low is retrieved, + * the data of each threshold high or low can be isolated + * using helper macro: + * @ref __LL_ADC_ANALOGWD_THRESHOLDS_HIGH_LOW(). + * @note In case of ADC resolution different of 12 bits, + * analog watchdog thresholds data require a specific shift. + * Use helper macro @ref __LL_ADC_ANALOGWD_GET_THRESHOLD_RESOLUTION(). + * @rmtoll TR1 HT1 LL_ADC_GetAnalogWDThresholds\n + * TR2 HT2 LL_ADC_GetAnalogWDThresholds\n + * TR3 HT3 LL_ADC_GetAnalogWDThresholds\n + * TR1 LT1 LL_ADC_GetAnalogWDThresholds\n + * TR2 LT2 LL_ADC_GetAnalogWDThresholds\n + * TR3 LT3 LL_ADC_GetAnalogWDThresholds + * @param ADCx ADC instance + * @param AWDThresholdsHighLow This parameter can be one of the following values: + * @arg @ref LL_ADC_AWD_THRESHOLD_HIGH + * @arg @ref LL_ADC_AWD_THRESHOLD_LOW + * @arg @ref LL_ADC_AWD_THRESHOLDS_HIGH_LOW + * @retval Value between Min_Data=0x000 and Max_Data=0xFFF +*/ +__STATIC_INLINE uint32_t LL_ADC_GetAnalogWDThresholds(ADC_TypeDef *ADCx, uint32_t AWDThresholdsHighLow) +{ + /* Parameter "AWDThresholdsHighLow" is used with mask "0x00000010" */ + /* to be equivalent to "POSITION_VAL(AWDThresholdsHighLow)": if threshold */ + /* high is selected, then data is shifted to LSB. Else(threshold low or */ + /* both thresholds), data is not shifted. */ + return (uint32_t)(READ_BIT(ADCx->TR, + (AWDThresholdsHighLow | ADC_TR_LT)) + >> ((~AWDThresholdsHighLow) & 0x00000010U) + ); +} + +/** + * @} + */ + +/** @defgroup ADC_LL_EF_Operation_ADC_Instance Operation on ADC hierarchical scope: ADC instance + * @{ + */ + +/** + * @brief Enable the selected ADC instance. + * @note On this STM32 serie, after ADC enable, a delay for + * ADC internal analog stabilization is required before performing a + * ADC conversion start. + * Refer to device datasheet, parameter tSTAB. + * @note On this STM32 serie, flag LL_ADC_FLAG_ADRDY is raised when the ADC + * is enabled and when conversion clock is active. + * (not only core clock: this ADC has a dual clock domain) + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be ADC disabled and ADC internal voltage regulator enabled. + * @rmtoll CR ADEN LL_ADC_Enable + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_Enable(ADC_TypeDef *ADCx) +{ + /* Note: Write register with some additional bits forced to state reset */ + /* instead of modifying only the selected bit for this function, */ + /* to not interfere with bits with HW property "rs". */ + MODIFY_REG(ADCx->CR, + ADC_CR_BITS_PROPERTY_RS, + ADC_CR_ADEN); +} + +/** + * @brief Disable the selected ADC instance. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be not disabled. Must be enabled without conversion on going + * on group regular. + * @rmtoll CR ADDIS LL_ADC_Disable + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_Disable(ADC_TypeDef *ADCx) +{ + /* Note: Write register with some additional bits forced to state reset */ + /* instead of modifying only the selected bit for this function, */ + /* to not interfere with bits with HW property "rs". */ + MODIFY_REG(ADCx->CR, + ADC_CR_BITS_PROPERTY_RS, + ADC_CR_ADDIS); +} + +/** + * @brief Get the selected ADC instance enable state. + * @note On this STM32 serie, flag LL_ADC_FLAG_ADRDY is raised when the ADC + * is enabled and when conversion clock is active. + * (not only core clock: this ADC has a dual clock domain) + * @rmtoll CR ADEN LL_ADC_IsEnabled + * @param ADCx ADC instance + * @retval 0: ADC is disabled, 1: ADC is enabled. + */ +__STATIC_INLINE uint32_t LL_ADC_IsEnabled(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->CR, ADC_CR_ADEN) == (ADC_CR_ADEN)); +} + +/** + * @brief Get the selected ADC instance disable state. + * @rmtoll CR ADDIS LL_ADC_IsDisableOngoing + * @param ADCx ADC instance + * @retval 0: no ADC disable command on going. + */ +__STATIC_INLINE uint32_t LL_ADC_IsDisableOngoing(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->CR, ADC_CR_ADDIS) == (ADC_CR_ADDIS)); +} + +/** + * @brief Start ADC calibration in the mode single-ended + * or differential (for devices with differential mode available). + * @note On this STM32 serie, a minimum number of ADC clock cycles + * are required between ADC end of calibration and ADC enable. + * Refer to literal @ref LL_ADC_DELAY_CALIB_ENABLE_ADC_CYCLES. + * @note In case of usage of ADC with DMA transfer: + * On this STM32 serie, ADC DMA transfer request should be disabled + * during calibration: + * Calibration factor is available in data register + * and also transfered by DMA. + * To not insert ADC calibration factor among ADC conversion data + * in array variable, DMA transfer must be disabled during + * calibration. + * (DMA transfer setting backup and disable before calibration, + * DMA transfer setting restore after calibration. + * Refer to functions @ref LL_ADC_REG_GetDMATransfer(), + * @ref LL_ADC_REG_SetDMATransfer() ). + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be ADC disabled. + * @rmtoll CR ADCAL LL_ADC_StartCalibration + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_StartCalibration(ADC_TypeDef *ADCx) +{ + /* Note: Write register with some additional bits forced to state reset */ + /* instead of modifying only the selected bit for this function, */ + /* to not interfere with bits with HW property "rs". */ + MODIFY_REG(ADCx->CR, + ADC_CR_BITS_PROPERTY_RS, + ADC_CR_ADCAL); +} + +/** + * @brief Get ADC calibration state. + * @rmtoll CR ADCAL LL_ADC_IsCalibrationOnGoing + * @param ADCx ADC instance + * @retval 0: calibration complete, 1: calibration in progress. + */ +__STATIC_INLINE uint32_t LL_ADC_IsCalibrationOnGoing(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->CR, ADC_CR_ADCAL) == (ADC_CR_ADCAL)); +} + +/** + * @} + */ + +/** @defgroup ADC_LL_EF_Operation_ADC_Group_Regular Operation on ADC hierarchical scope: group regular + * @{ + */ + +/** + * @brief Start ADC group regular conversion. + * @note On this STM32 serie, this function is relevant for both + * internal trigger (SW start) and external trigger: + * - If ADC trigger has been set to software start, ADC conversion + * starts immediately. + * - If ADC trigger has been set to external trigger, ADC conversion + * will start at next trigger event (on the selected trigger edge) + * following the ADC start conversion command. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be enabled without conversion on going on group regular, + * without conversion stop command on going on group regular, + * without ADC disable command on going. + * @rmtoll CR ADSTART LL_ADC_REG_StartConversion + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_StartConversion(ADC_TypeDef *ADCx) +{ + /* Note: Write register with some additional bits forced to state reset */ + /* instead of modifying only the selected bit for this function, */ + /* to not interfere with bits with HW property "rs". */ + MODIFY_REG(ADCx->CR, + ADC_CR_BITS_PROPERTY_RS, + ADC_CR_ADSTART); +} + +/** + * @brief Stop ADC group regular conversion. + * @note On this STM32 serie, setting of this feature is conditioned to + * ADC state: + * ADC must be enabled with conversion on going on group regular, + * without ADC disable command on going. + * @rmtoll CR ADSTP LL_ADC_REG_StopConversion + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_REG_StopConversion(ADC_TypeDef *ADCx) +{ + /* Note: Write register with some additional bits forced to state reset */ + /* instead of modifying only the selected bit for this function, */ + /* to not interfere with bits with HW property "rs". */ + MODIFY_REG(ADCx->CR, + ADC_CR_BITS_PROPERTY_RS, + ADC_CR_ADSTP); +} + +/** + * @brief Get ADC group regular conversion state. + * @rmtoll CR ADSTART LL_ADC_REG_IsConversionOngoing + * @param ADCx ADC instance + * @retval 0: no conversion is on going on ADC group regular. + */ +__STATIC_INLINE uint32_t LL_ADC_REG_IsConversionOngoing(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->CR, ADC_CR_ADSTART) == (ADC_CR_ADSTART)); +} + +/** + * @brief Get ADC group regular command of conversion stop state + * @rmtoll CR ADSTP LL_ADC_REG_IsStopConversionOngoing + * @param ADCx ADC instance + * @retval 0: no command of conversion stop is on going on ADC group regular. + */ +__STATIC_INLINE uint32_t LL_ADC_REG_IsStopConversionOngoing(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->CR, ADC_CR_ADSTP) == (ADC_CR_ADSTP)); +} + +/** + * @brief Get ADC group regular conversion data, range fit for + * all ADC configurations: all ADC resolutions and + * all oversampling increased data width (for devices + * with feature oversampling). + * @rmtoll DR DATA LL_ADC_REG_ReadConversionData32 + * @param ADCx ADC instance + * @retval Value between Min_Data=0x00000000 and Max_Data=0xFFFFFFFF + */ +__STATIC_INLINE uint32_t LL_ADC_REG_ReadConversionData32(ADC_TypeDef *ADCx) +{ + return (uint32_t)(READ_BIT(ADCx->DR, ADC_DR_DATA)); +} + +/** + * @brief Get ADC group regular conversion data, range fit for + * ADC resolution 12 bits. + * @note For devices with feature oversampling: Oversampling + * can increase data width, function for extended range + * may be needed: @ref LL_ADC_REG_ReadConversionData32. + * @rmtoll DR DATA LL_ADC_REG_ReadConversionData12 + * @param ADCx ADC instance + * @retval Value between Min_Data=0x000 and Max_Data=0xFFF + */ +__STATIC_INLINE uint16_t LL_ADC_REG_ReadConversionData12(ADC_TypeDef *ADCx) +{ + return (uint16_t)(READ_BIT(ADCx->DR, ADC_DR_DATA)); +} + +/** + * @brief Get ADC group regular conversion data, range fit for + * ADC resolution 10 bits. + * @note For devices with feature oversampling: Oversampling + * can increase data width, function for extended range + * may be needed: @ref LL_ADC_REG_ReadConversionData32. + * @rmtoll DR DATA LL_ADC_REG_ReadConversionData10 + * @param ADCx ADC instance + * @retval Value between Min_Data=0x000 and Max_Data=0x3FF + */ +__STATIC_INLINE uint16_t LL_ADC_REG_ReadConversionData10(ADC_TypeDef *ADCx) +{ + return (uint16_t)(READ_BIT(ADCx->DR, ADC_DR_DATA)); +} + +/** + * @brief Get ADC group regular conversion data, range fit for + * ADC resolution 8 bits. + * @note For devices with feature oversampling: Oversampling + * can increase data width, function for extended range + * may be needed: @ref LL_ADC_REG_ReadConversionData32. + * @rmtoll DR DATA LL_ADC_REG_ReadConversionData8 + * @param ADCx ADC instance + * @retval Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint8_t LL_ADC_REG_ReadConversionData8(ADC_TypeDef *ADCx) +{ + return (uint8_t)(READ_BIT(ADCx->DR, ADC_DR_DATA)); +} + +/** + * @brief Get ADC group regular conversion data, range fit for + * ADC resolution 6 bits. + * @note For devices with feature oversampling: Oversampling + * can increase data width, function for extended range + * may be needed: @ref LL_ADC_REG_ReadConversionData32. + * @rmtoll DR DATA LL_ADC_REG_ReadConversionData6 + * @param ADCx ADC instance + * @retval Value between Min_Data=0x00 and Max_Data=0x3F + */ +__STATIC_INLINE uint8_t LL_ADC_REG_ReadConversionData6(ADC_TypeDef *ADCx) +{ + return (uint8_t)(READ_BIT(ADCx->DR, ADC_DR_DATA)); +} + +/** + * @} + */ + +/** @defgroup ADC_LL_EF_FLAG_Management ADC flag management + * @{ + */ + +/** + * @brief Get flag ADC ready. + * @note On this STM32 serie, flag LL_ADC_FLAG_ADRDY is raised when the ADC + * is enabled and when conversion clock is active. + * (not only core clock: this ADC has a dual clock domain) + * @rmtoll ISR ADRDY LL_ADC_IsActiveFlag_ADRDY + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsActiveFlag_ADRDY(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->ISR, LL_ADC_FLAG_ADRDY) == (LL_ADC_FLAG_ADRDY)); +} + +/** + * @brief Get flag ADC group regular end of unitary conversion. + * @rmtoll ISR EOC LL_ADC_IsActiveFlag_EOC + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsActiveFlag_EOC(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->ISR, ADC_ISR_EOC) == (ADC_ISR_EOC)); +} + +/** + * @brief Get flag ADC group regular end of sequence conversions. + * @rmtoll ISR EOSEQ LL_ADC_IsActiveFlag_EOS + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsActiveFlag_EOS(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->ISR, LL_ADC_FLAG_EOS) == (LL_ADC_FLAG_EOS)); +} + +/** + * @brief Get flag ADC group regular overrun. + * @rmtoll ISR OVR LL_ADC_IsActiveFlag_OVR + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsActiveFlag_OVR(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->ISR, LL_ADC_FLAG_OVR) == (LL_ADC_FLAG_OVR)); +} + +/** + * @brief Get flag ADC group regular end of sampling phase. + * @rmtoll ISR EOSMP LL_ADC_IsActiveFlag_EOSMP + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsActiveFlag_EOSMP(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->ISR, LL_ADC_FLAG_EOSMP) == (LL_ADC_FLAG_EOSMP)); +} + +/** + * @brief Get flag ADC analog watchdog 1 flag + * @rmtoll ISR AWD LL_ADC_IsActiveFlag_AWD1 + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsActiveFlag_AWD1(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->ISR, LL_ADC_FLAG_AWD1) == (LL_ADC_FLAG_AWD1)); +} + +/** + * @brief Clear flag ADC ready. + * @note On this STM32 serie, flag LL_ADC_FLAG_ADRDY is raised when the ADC + * is enabled and when conversion clock is active. + * (not only core clock: this ADC has a dual clock domain) + * @rmtoll ISR ADRDY LL_ADC_ClearFlag_ADRDY + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_ClearFlag_ADRDY(ADC_TypeDef *ADCx) +{ + WRITE_REG(ADCx->ISR, LL_ADC_FLAG_ADRDY); +} + +/** + * @brief Clear flag ADC group regular end of unitary conversion. + * @rmtoll ISR EOC LL_ADC_ClearFlag_EOC + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_ClearFlag_EOC(ADC_TypeDef *ADCx) +{ + WRITE_REG(ADCx->ISR, LL_ADC_FLAG_EOC); +} + +/** + * @brief Clear flag ADC group regular end of sequence conversions. + * @rmtoll ISR EOSEQ LL_ADC_ClearFlag_EOS + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_ClearFlag_EOS(ADC_TypeDef *ADCx) +{ + WRITE_REG(ADCx->ISR, LL_ADC_FLAG_EOS); +} + +/** + * @brief Clear flag ADC group regular overrun. + * @rmtoll ISR OVR LL_ADC_ClearFlag_OVR + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_ClearFlag_OVR(ADC_TypeDef *ADCx) +{ + WRITE_REG(ADCx->ISR, LL_ADC_FLAG_OVR); +} + +/** + * @brief Clear flag ADC group regular end of sampling phase. + * @rmtoll ISR EOSMP LL_ADC_ClearFlag_EOSMP + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_ClearFlag_EOSMP(ADC_TypeDef *ADCx) +{ + WRITE_REG(ADCx->ISR, LL_ADC_FLAG_EOSMP); +} + +/** + * @brief Clear flag ADC analog watchdog 1. + * @rmtoll ISR AWD LL_ADC_ClearFlag_AWD1 + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_ClearFlag_AWD1(ADC_TypeDef *ADCx) +{ + WRITE_REG(ADCx->ISR, LL_ADC_FLAG_AWD1); +} + +/** + * @} + */ + +/** @defgroup ADC_LL_EF_IT_Management ADC IT management + * @{ + */ + +/** + * @brief Enable ADC ready. + * @rmtoll IER ADRDYIE LL_ADC_EnableIT_ADRDY + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_EnableIT_ADRDY(ADC_TypeDef *ADCx) +{ + SET_BIT(ADCx->IER, LL_ADC_IT_ADRDY); +} + +/** + * @brief Enable interruption ADC group regular end of unitary conversion. + * @rmtoll IER EOCIE LL_ADC_EnableIT_EOC + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_EnableIT_EOC(ADC_TypeDef *ADCx) +{ + SET_BIT(ADCx->IER, LL_ADC_IT_EOC); +} + +/** + * @brief Enable interruption ADC group regular end of sequence conversions. + * @rmtoll IER EOSEQIE LL_ADC_EnableIT_EOS + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_EnableIT_EOS(ADC_TypeDef *ADCx) +{ + SET_BIT(ADCx->IER, LL_ADC_IT_EOS); +} + +/** + * @brief Enable ADC group regular interruption overrun. + * @rmtoll IER OVRIE LL_ADC_EnableIT_OVR + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_EnableIT_OVR(ADC_TypeDef *ADCx) +{ + SET_BIT(ADCx->IER, LL_ADC_IT_OVR); +} + +/** + * @brief Enable interruption ADC group regular end of sampling. + * @rmtoll IER EOSMPIE LL_ADC_EnableIT_EOSMP + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_EnableIT_EOSMP(ADC_TypeDef *ADCx) +{ + SET_BIT(ADCx->IER, LL_ADC_IT_EOSMP); +} + +/** + * @brief Enable interruption ADC analog watchdog 1. + * @rmtoll IER AWDIE LL_ADC_EnableIT_AWD1 + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_EnableIT_AWD1(ADC_TypeDef *ADCx) +{ + SET_BIT(ADCx->IER, LL_ADC_IT_AWD1); +} + +/** + * @brief Disable interruption ADC ready. + * @rmtoll IER ADRDYIE LL_ADC_DisableIT_ADRDY + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_DisableIT_ADRDY(ADC_TypeDef *ADCx) +{ + CLEAR_BIT(ADCx->IER, LL_ADC_IT_ADRDY); +} + +/** + * @brief Disable interruption ADC group regular end of unitary conversion. + * @rmtoll IER EOCIE LL_ADC_DisableIT_EOC + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_DisableIT_EOC(ADC_TypeDef *ADCx) +{ + CLEAR_BIT(ADCx->IER, LL_ADC_IT_EOC); +} + +/** + * @brief Disable interruption ADC group regular end of sequence conversions. + * @rmtoll IER EOSEQIE LL_ADC_DisableIT_EOS + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_DisableIT_EOS(ADC_TypeDef *ADCx) +{ + CLEAR_BIT(ADCx->IER, LL_ADC_IT_EOS); +} + +/** + * @brief Disable interruption ADC group regular overrun. + * @rmtoll IER OVRIE LL_ADC_DisableIT_OVR + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_DisableIT_OVR(ADC_TypeDef *ADCx) +{ + CLEAR_BIT(ADCx->IER, LL_ADC_IT_OVR); +} + +/** + * @brief Disable interruption ADC group regular end of sampling. + * @rmtoll IER EOSMPIE LL_ADC_DisableIT_EOSMP + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_DisableIT_EOSMP(ADC_TypeDef *ADCx) +{ + CLEAR_BIT(ADCx->IER, LL_ADC_IT_EOSMP); +} + +/** + * @brief Disable interruption ADC analog watchdog 1. + * @rmtoll IER AWDIE LL_ADC_DisableIT_AWD1 + * @param ADCx ADC instance + * @retval None + */ +__STATIC_INLINE void LL_ADC_DisableIT_AWD1(ADC_TypeDef *ADCx) +{ + CLEAR_BIT(ADCx->IER, LL_ADC_IT_AWD1); +} + +/** + * @brief Get state of interruption ADC ready + * (0: interrupt disabled, 1: interrupt enabled). + * @rmtoll IER ADRDYIE LL_ADC_IsEnabledIT_ADRDY + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsEnabledIT_ADRDY(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->IER, LL_ADC_IT_ADRDY) == (LL_ADC_IT_ADRDY)); +} + +/** + * @brief Get state of interruption ADC group regular end of unitary conversion + * (0: interrupt disabled, 1: interrupt enabled). + * @rmtoll IER EOCIE LL_ADC_IsEnabledIT_EOC + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsEnabledIT_EOC(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->IER, LL_ADC_IT_EOC) == (LL_ADC_IT_EOC)); +} + +/** + * @brief Get state of interruption ADC group regular end of sequence conversions + * (0: interrupt disabled, 1: interrupt enabled). + * @rmtoll IER EOSEQIE LL_ADC_IsEnabledIT_EOS + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsEnabledIT_EOS(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->IER, LL_ADC_IT_EOS) == (LL_ADC_IT_EOS)); +} + +/** + * @brief Get state of interruption ADC group regular overrun + * (0: interrupt disabled, 1: interrupt enabled). + * @rmtoll IER OVRIE LL_ADC_IsEnabledIT_OVR + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsEnabledIT_OVR(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->IER, LL_ADC_IT_OVR) == (LL_ADC_IT_OVR)); +} + +/** + * @brief Get state of interruption ADC group regular end of sampling + * (0: interrupt disabled, 1: interrupt enabled). + * @rmtoll IER EOSMPIE LL_ADC_IsEnabledIT_EOSMP + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsEnabledIT_EOSMP(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->IER, LL_ADC_IT_EOSMP) == (LL_ADC_IT_EOSMP)); +} + +/** + * @brief Get state of interruption ADC analog watchdog 1 + * (0: interrupt disabled, 1: interrupt enabled). + * @rmtoll IER AWDIE LL_ADC_IsEnabledIT_AWD1 + * @param ADCx ADC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_ADC_IsEnabledIT_AWD1(ADC_TypeDef *ADCx) +{ + return (READ_BIT(ADCx->IER, LL_ADC_IT_AWD1) == (LL_ADC_IT_AWD1)); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup ADC_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +/* Initialization of some features of ADC common parameters and multimode */ +/* Note: On this STM32 serie, there is no ADC common initialization */ +/* function. */ +ErrorStatus LL_ADC_CommonDeInit(ADC_Common_TypeDef *ADCxy_COMMON); + +/* De-initialization of ADC instance */ +ErrorStatus LL_ADC_DeInit(ADC_TypeDef *ADCx); + +/* Initialization of some features of ADC instance */ +ErrorStatus LL_ADC_Init(ADC_TypeDef *ADCx, LL_ADC_InitTypeDef *ADC_InitStruct); +void LL_ADC_StructInit(LL_ADC_InitTypeDef *ADC_InitStruct); + +/* Initialization of some features of ADC instance and ADC group regular */ +ErrorStatus LL_ADC_REG_Init(ADC_TypeDef *ADCx, LL_ADC_REG_InitTypeDef *ADC_REG_InitStruct); +void LL_ADC_REG_StructInit(LL_ADC_REG_InitTypeDef *ADC_REG_InitStruct); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* ADC1 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_ADC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_bus.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_bus.h new file mode 100644 index 0000000..b85c02f --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_bus.h @@ -0,0 +1,845 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_bus.h + * @author MCD Application Team + * @brief Header file of BUS LL module. + + @verbatim + ##### RCC Limitations ##### + ============================================================================== + [..] + A delay between an RCC peripheral clock enable and the effective peripheral + enabling should be taken into account in order to manage the peripheral read/write + from/to registers. + (+) This delay depends on the peripheral mapping. + (++) AHB & APB peripherals, 1 dummy read is necessary + + [..] + Workarounds: + (#) For AHB & APB peripherals, a dummy read to the peripheral register has been + inserted in each LL_{BUS}_GRP{x}_EnableClock() function. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_BUS_H +#define __STM32F0xx_LL_BUS_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(RCC) + +/** @defgroup BUS_LL BUS + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ + +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup BUS_LL_Exported_Constants BUS Exported Constants + * @{ + */ + +/** @defgroup BUS_LL_EC_AHB1_GRP1_PERIPH AHB1 GRP1 PERIPH + * @{ + */ +#define LL_AHB1_GRP1_PERIPH_ALL (uint32_t)0xFFFFFFFFU +#define LL_AHB1_GRP1_PERIPH_DMA1 RCC_AHBENR_DMA1EN +#if defined(DMA2) +#define LL_AHB1_GRP1_PERIPH_DMA2 RCC_AHBENR_DMA2EN +#endif /*DMA2*/ +#define LL_AHB1_GRP1_PERIPH_SRAM RCC_AHBENR_SRAMEN +#define LL_AHB1_GRP1_PERIPH_FLASH RCC_AHBENR_FLITFEN +#define LL_AHB1_GRP1_PERIPH_CRC RCC_AHBENR_CRCEN +#define LL_AHB1_GRP1_PERIPH_GPIOA RCC_AHBENR_GPIOAEN +#define LL_AHB1_GRP1_PERIPH_GPIOB RCC_AHBENR_GPIOBEN +#define LL_AHB1_GRP1_PERIPH_GPIOC RCC_AHBENR_GPIOCEN +#if defined(GPIOD) +#define LL_AHB1_GRP1_PERIPH_GPIOD RCC_AHBENR_GPIODEN +#endif /*GPIOD*/ +#if defined(GPIOE) +#define LL_AHB1_GRP1_PERIPH_GPIOE RCC_AHBENR_GPIOEEN +#endif /*GPIOE*/ +#define LL_AHB1_GRP1_PERIPH_GPIOF RCC_AHBENR_GPIOFEN +#if defined(TSC) +#define LL_AHB1_GRP1_PERIPH_TSC RCC_AHBENR_TSCEN +#endif /*TSC*/ +/** + * @} + */ + +/** @defgroup BUS_LL_EC_APB1_GRP1_PERIPH APB1 GRP1 PERIPH + * @{ + */ +#define LL_APB1_GRP1_PERIPH_ALL (uint32_t)0xFFFFFFFFU +#if defined(TIM2) +#define LL_APB1_GRP1_PERIPH_TIM2 RCC_APB1ENR_TIM2EN +#endif /*TIM2*/ +#define LL_APB1_GRP1_PERIPH_TIM3 RCC_APB1ENR_TIM3EN +#if defined(TIM6) +#define LL_APB1_GRP1_PERIPH_TIM6 RCC_APB1ENR_TIM6EN +#endif /*TIM6*/ +#if defined(TIM7) +#define LL_APB1_GRP1_PERIPH_TIM7 RCC_APB1ENR_TIM7EN +#endif /*TIM7*/ +#define LL_APB1_GRP1_PERIPH_TIM14 RCC_APB1ENR_TIM14EN +#define LL_APB1_GRP1_PERIPH_WWDG RCC_APB1ENR_WWDGEN +#if defined(SPI2) +#define LL_APB1_GRP1_PERIPH_SPI2 RCC_APB1ENR_SPI2EN +#endif /*SPI2*/ +#if defined(USART2) +#define LL_APB1_GRP1_PERIPH_USART2 RCC_APB1ENR_USART2EN +#endif /* USART2 */ +#if defined(USART3) +#define LL_APB1_GRP1_PERIPH_USART3 RCC_APB1ENR_USART3EN +#endif /* USART3 */ +#if defined(USART4) +#define LL_APB1_GRP1_PERIPH_USART4 RCC_APB1ENR_USART4EN +#endif /* USART4 */ +#if defined(USART5) +#define LL_APB1_GRP1_PERIPH_USART5 RCC_APB1ENR_USART5EN +#endif /* USART5 */ +#define LL_APB1_GRP1_PERIPH_I2C1 RCC_APB1ENR_I2C1EN +#if defined(I2C2) +#define LL_APB1_GRP1_PERIPH_I2C2 RCC_APB1ENR_I2C2EN +#endif /*I2C2*/ +#if defined(USB) +#define LL_APB1_GRP1_PERIPH_USB RCC_APB1ENR_USBEN +#endif /* USB */ +#if defined(CAN) +#define LL_APB1_GRP1_PERIPH_CAN RCC_APB1ENR_CANEN +#endif /*CAN*/ +#if defined(CRS) +#define LL_APB1_GRP1_PERIPH_CRS RCC_APB1ENR_CRSEN +#endif /*CRS*/ +#define LL_APB1_GRP1_PERIPH_PWR RCC_APB1ENR_PWREN +#if defined(DAC) +#define LL_APB1_GRP1_PERIPH_DAC1 RCC_APB1ENR_DACEN +#endif /*DAC*/ +#if defined(CEC) +#define LL_APB1_GRP1_PERIPH_CEC RCC_APB1ENR_CECEN +#endif /*CEC*/ +/** + * @} + */ + +/** @defgroup BUS_LL_EC_APB1_GRP2_PERIPH APB1 GRP2 PERIPH + * @{ + */ +#define LL_APB1_GRP2_PERIPH_ALL (uint32_t)0xFFFFFFFFU +#define LL_APB1_GRP2_PERIPH_SYSCFG RCC_APB2ENR_SYSCFGEN +#define LL_APB1_GRP2_PERIPH_ADC1 RCC_APB2ENR_ADC1EN +#if defined(USART8) +#define LL_APB1_GRP2_PERIPH_USART8 RCC_APB2ENR_USART8EN +#endif /*USART8*/ +#if defined(USART7) +#define LL_APB1_GRP2_PERIPH_USART7 RCC_APB2ENR_USART7EN +#endif /*USART7*/ +#if defined(USART6) +#define LL_APB1_GRP2_PERIPH_USART6 RCC_APB2ENR_USART6EN +#endif /*USART6*/ +#define LL_APB1_GRP2_PERIPH_TIM1 RCC_APB2ENR_TIM1EN +#define LL_APB1_GRP2_PERIPH_SPI1 RCC_APB2ENR_SPI1EN +#define LL_APB1_GRP2_PERIPH_USART1 RCC_APB2ENR_USART1EN +#if defined(TIM15) +#define LL_APB1_GRP2_PERIPH_TIM15 RCC_APB2ENR_TIM15EN +#endif /*TIM15*/ +#define LL_APB1_GRP2_PERIPH_TIM16 RCC_APB2ENR_TIM16EN +#define LL_APB1_GRP2_PERIPH_TIM17 RCC_APB2ENR_TIM17EN +#define LL_APB1_GRP2_PERIPH_DBGMCU RCC_APB2ENR_DBGMCUEN +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ +/** @defgroup BUS_LL_Exported_Functions BUS Exported Functions + * @{ + */ + +/** @defgroup BUS_LL_EF_AHB1 AHB1 + * @{ + */ + +/** + * @brief Enable AHB1 peripherals clock. + * @rmtoll AHBENR DMA1EN LL_AHB1_GRP1_EnableClock\n + * AHBENR DMA2EN LL_AHB1_GRP1_EnableClock\n + * AHBENR SRAMEN LL_AHB1_GRP1_EnableClock\n + * AHBENR FLITFEN LL_AHB1_GRP1_EnableClock\n + * AHBENR CRCEN LL_AHB1_GRP1_EnableClock\n + * AHBENR GPIOAEN LL_AHB1_GRP1_EnableClock\n + * AHBENR GPIOBEN LL_AHB1_GRP1_EnableClock\n + * AHBENR GPIOCEN LL_AHB1_GRP1_EnableClock\n + * AHBENR GPIODEN LL_AHB1_GRP1_EnableClock\n + * AHBENR GPIOEEN LL_AHB1_GRP1_EnableClock\n + * AHBENR GPIOFEN LL_AHB1_GRP1_EnableClock\n + * AHBENR TSCEN LL_AHB1_GRP1_EnableClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_AHB1_GRP1_PERIPH_DMA1 + * @arg @ref LL_AHB1_GRP1_PERIPH_DMA2 (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM + * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH + * @arg @ref LL_AHB1_GRP1_PERIPH_CRC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOA + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOB + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOD (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOE (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOF + * @arg @ref LL_AHB1_GRP1_PERIPH_TSC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_AHB1_GRP1_EnableClock(uint32_t Periphs) +{ + __IO uint32_t tmpreg; + SET_BIT(RCC->AHBENR, Periphs); + /* Delay after an RCC peripheral clock enabling */ + tmpreg = READ_BIT(RCC->AHBENR, Periphs); + (void)tmpreg; +} + +/** + * @brief Check if AHB1 peripheral clock is enabled or not + * @rmtoll AHBENR DMA1EN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR DMA2EN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR SRAMEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR FLITFEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR CRCEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR GPIOAEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR GPIOBEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR GPIOCEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR GPIODEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR GPIOEEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR GPIOFEN LL_AHB1_GRP1_IsEnabledClock\n + * AHBENR TSCEN LL_AHB1_GRP1_IsEnabledClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_AHB1_GRP1_PERIPH_DMA1 + * @arg @ref LL_AHB1_GRP1_PERIPH_DMA2 (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM + * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH + * @arg @ref LL_AHB1_GRP1_PERIPH_CRC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOA + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOB + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOD (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOE (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOF + * @arg @ref LL_AHB1_GRP1_PERIPH_TSC (*) + * + * (*) value not defined in all devices. + * @retval State of Periphs (1 or 0). +*/ +__STATIC_INLINE uint32_t LL_AHB1_GRP1_IsEnabledClock(uint32_t Periphs) +{ + return (READ_BIT(RCC->AHBENR, Periphs) == Periphs); +} + +/** + * @brief Disable AHB1 peripherals clock. + * @rmtoll AHBENR DMA1EN LL_AHB1_GRP1_DisableClock\n + * AHBENR DMA2EN LL_AHB1_GRP1_DisableClock\n + * AHBENR SRAMEN LL_AHB1_GRP1_DisableClock\n + * AHBENR FLITFEN LL_AHB1_GRP1_DisableClock\n + * AHBENR CRCEN LL_AHB1_GRP1_DisableClock\n + * AHBENR GPIOAEN LL_AHB1_GRP1_DisableClock\n + * AHBENR GPIOBEN LL_AHB1_GRP1_DisableClock\n + * AHBENR GPIOCEN LL_AHB1_GRP1_DisableClock\n + * AHBENR GPIODEN LL_AHB1_GRP1_DisableClock\n + * AHBENR GPIOEEN LL_AHB1_GRP1_DisableClock\n + * AHBENR GPIOFEN LL_AHB1_GRP1_DisableClock\n + * AHBENR TSCEN LL_AHB1_GRP1_DisableClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_AHB1_GRP1_PERIPH_DMA1 + * @arg @ref LL_AHB1_GRP1_PERIPH_DMA2 (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_SRAM + * @arg @ref LL_AHB1_GRP1_PERIPH_FLASH + * @arg @ref LL_AHB1_GRP1_PERIPH_CRC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOA + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOB + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOD (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOE (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOF + * @arg @ref LL_AHB1_GRP1_PERIPH_TSC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_AHB1_GRP1_DisableClock(uint32_t Periphs) +{ + CLEAR_BIT(RCC->AHBENR, Periphs); +} + +/** + * @brief Force AHB1 peripherals reset. + * @rmtoll AHBRSTR GPIOARST LL_AHB1_GRP1_ForceReset\n + * AHBRSTR GPIOBRST LL_AHB1_GRP1_ForceReset\n + * AHBRSTR GPIOCRST LL_AHB1_GRP1_ForceReset\n + * AHBRSTR GPIODRST LL_AHB1_GRP1_ForceReset\n + * AHBRSTR GPIOERST LL_AHB1_GRP1_ForceReset\n + * AHBRSTR GPIOFRST LL_AHB1_GRP1_ForceReset\n + * AHBRSTR TSCRST LL_AHB1_GRP1_ForceReset + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_AHB1_GRP1_PERIPH_ALL + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOA + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOB + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOD (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOE (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOF + * @arg @ref LL_AHB1_GRP1_PERIPH_TSC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_AHB1_GRP1_ForceReset(uint32_t Periphs) +{ + SET_BIT(RCC->AHBRSTR, Periphs); +} + +/** + * @brief Release AHB1 peripherals reset. + * @rmtoll AHBRSTR GPIOARST LL_AHB1_GRP1_ReleaseReset\n + * AHBRSTR GPIOBRST LL_AHB1_GRP1_ReleaseReset\n + * AHBRSTR GPIOCRST LL_AHB1_GRP1_ReleaseReset\n + * AHBRSTR GPIODRST LL_AHB1_GRP1_ReleaseReset\n + * AHBRSTR GPIOERST LL_AHB1_GRP1_ReleaseReset\n + * AHBRSTR GPIOFRST LL_AHB1_GRP1_ReleaseReset\n + * AHBRSTR TSCRST LL_AHB1_GRP1_ReleaseReset + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_AHB1_GRP1_PERIPH_ALL + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOA + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOB + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOC + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOD (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOE (*) + * @arg @ref LL_AHB1_GRP1_PERIPH_GPIOF + * @arg @ref LL_AHB1_GRP1_PERIPH_TSC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_AHB1_GRP1_ReleaseReset(uint32_t Periphs) +{ + CLEAR_BIT(RCC->AHBRSTR, Periphs); +} + +/** + * @} + */ + +/** @defgroup BUS_LL_EF_APB1_GRP1 APB1 GRP1 + * @{ + */ + +/** + * @brief Enable APB1 peripherals clock (available in register 1). + * @rmtoll APB1ENR TIM2EN LL_APB1_GRP1_EnableClock\n + * APB1ENR TIM3EN LL_APB1_GRP1_EnableClock\n + * APB1ENR TIM6EN LL_APB1_GRP1_EnableClock\n + * APB1ENR TIM7EN LL_APB1_GRP1_EnableClock\n + * APB1ENR TIM14EN LL_APB1_GRP1_EnableClock\n + * APB1ENR WWDGEN LL_APB1_GRP1_EnableClock\n + * APB1ENR SPI2EN LL_APB1_GRP1_EnableClock\n + * APB1ENR USART2EN LL_APB1_GRP1_EnableClock\n + * APB1ENR USART3EN LL_APB1_GRP1_EnableClock\n + * APB1ENR USART4EN LL_APB1_GRP1_EnableClock\n + * APB1ENR USART5EN LL_APB1_GRP1_EnableClock\n + * APB1ENR I2C1EN LL_APB1_GRP1_EnableClock\n + * APB1ENR I2C2EN LL_APB1_GRP1_EnableClock\n + * APB1ENR USBEN LL_APB1_GRP1_EnableClock\n + * APB1ENR CANEN LL_APB1_GRP1_EnableClock\n + * APB1ENR CRSEN LL_APB1_GRP1_EnableClock\n + * APB1ENR PWREN LL_APB1_GRP1_EnableClock\n + * APB1ENR DACEN LL_APB1_GRP1_EnableClock\n + * APB1ENR CECEN LL_APB1_GRP1_EnableClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP1_PERIPH_TIM2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM3 + * @arg @ref LL_APB1_GRP1_PERIPH_TIM6 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM7 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 + * @arg @ref LL_APB1_GRP1_PERIPH_WWDG + * @arg @ref LL_APB1_GRP1_PERIPH_SPI2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART3 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART4 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART5 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_I2C1 + * @arg @ref LL_APB1_GRP1_PERIPH_I2C2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USB (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CAN (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CRS (*) + * @arg @ref LL_APB1_GRP1_PERIPH_PWR + * @arg @ref LL_APB1_GRP1_PERIPH_DAC1 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP1_EnableClock(uint32_t Periphs) +{ + __IO uint32_t tmpreg; + SET_BIT(RCC->APB1ENR, Periphs); + /* Delay after an RCC peripheral clock enabling */ + tmpreg = READ_BIT(RCC->APB1ENR, Periphs); + (void)tmpreg; +} + +/** + * @brief Check if APB1 peripheral clock is enabled or not (available in register 1). + * @rmtoll APB1ENR TIM2EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR TIM3EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR TIM6EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR TIM7EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR TIM14EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR WWDGEN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR SPI2EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR USART2EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR USART3EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR USART4EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR USART5EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR I2C1EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR I2C2EN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR USBEN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR CANEN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR CRSEN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR PWREN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR DACEN LL_APB1_GRP1_IsEnabledClock\n + * APB1ENR CECEN LL_APB1_GRP1_IsEnabledClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP1_PERIPH_TIM2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM3 + * @arg @ref LL_APB1_GRP1_PERIPH_TIM6 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM7 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 + * @arg @ref LL_APB1_GRP1_PERIPH_WWDG + * @arg @ref LL_APB1_GRP1_PERIPH_SPI2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART3 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART4 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART5 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_I2C1 + * @arg @ref LL_APB1_GRP1_PERIPH_I2C2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USB (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CAN (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CRS (*) + * @arg @ref LL_APB1_GRP1_PERIPH_PWR + * @arg @ref LL_APB1_GRP1_PERIPH_DAC1 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*) + * + * (*) value not defined in all devices. + * @retval State of Periphs (1 or 0). +*/ +__STATIC_INLINE uint32_t LL_APB1_GRP1_IsEnabledClock(uint32_t Periphs) +{ + return (READ_BIT(RCC->APB1ENR, Periphs) == Periphs); +} + +/** + * @brief Disable APB1 peripherals clock (available in register 1). + * @rmtoll APB1ENR TIM2EN LL_APB1_GRP1_DisableClock\n + * APB1ENR TIM3EN LL_APB1_GRP1_DisableClock\n + * APB1ENR TIM6EN LL_APB1_GRP1_DisableClock\n + * APB1ENR TIM7EN LL_APB1_GRP1_DisableClock\n + * APB1ENR TIM14EN LL_APB1_GRP1_DisableClock\n + * APB1ENR WWDGEN LL_APB1_GRP1_DisableClock\n + * APB1ENR SPI2EN LL_APB1_GRP1_DisableClock\n + * APB1ENR USART2EN LL_APB1_GRP1_DisableClock\n + * APB1ENR USART3EN LL_APB1_GRP1_DisableClock\n + * APB1ENR USART4EN LL_APB1_GRP1_DisableClock\n + * APB1ENR USART5EN LL_APB1_GRP1_DisableClock\n + * APB1ENR I2C1EN LL_APB1_GRP1_DisableClock\n + * APB1ENR I2C2EN LL_APB1_GRP1_DisableClock\n + * APB1ENR USBEN LL_APB1_GRP1_DisableClock\n + * APB1ENR CANEN LL_APB1_GRP1_DisableClock\n + * APB1ENR CRSEN LL_APB1_GRP1_DisableClock\n + * APB1ENR PWREN LL_APB1_GRP1_DisableClock\n + * APB1ENR DACEN LL_APB1_GRP1_DisableClock\n + * APB1ENR CECEN LL_APB1_GRP1_DisableClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP1_PERIPH_TIM2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM3 + * @arg @ref LL_APB1_GRP1_PERIPH_TIM6 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM7 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 + * @arg @ref LL_APB1_GRP1_PERIPH_WWDG + * @arg @ref LL_APB1_GRP1_PERIPH_SPI2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART3 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART4 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART5 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_I2C1 + * @arg @ref LL_APB1_GRP1_PERIPH_I2C2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USB (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CAN (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CRS (*) + * @arg @ref LL_APB1_GRP1_PERIPH_PWR + * @arg @ref LL_APB1_GRP1_PERIPH_DAC1 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP1_DisableClock(uint32_t Periphs) +{ + CLEAR_BIT(RCC->APB1ENR, Periphs); +} + +/** + * @brief Force APB1 peripherals reset (available in register 1). + * @rmtoll APB1RSTR TIM2RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR TIM3RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR TIM6RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR TIM7RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR TIM14RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR WWDGRST LL_APB1_GRP1_ForceReset\n + * APB1RSTR SPI2RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR USART2RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR USART3RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR USART4RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR USART5RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR I2C1RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR I2C2RST LL_APB1_GRP1_ForceReset\n + * APB1RSTR USBRST LL_APB1_GRP1_ForceReset\n + * APB1RSTR CANRST LL_APB1_GRP1_ForceReset\n + * APB1RSTR CRSRST LL_APB1_GRP1_ForceReset\n + * APB1RSTR PWRRST LL_APB1_GRP1_ForceReset\n + * APB1RSTR DACRST LL_APB1_GRP1_ForceReset\n + * APB1RSTR CECRST LL_APB1_GRP1_ForceReset + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP1_PERIPH_ALL + * @arg @ref LL_APB1_GRP1_PERIPH_TIM2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM3 + * @arg @ref LL_APB1_GRP1_PERIPH_TIM6 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM7 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 + * @arg @ref LL_APB1_GRP1_PERIPH_WWDG + * @arg @ref LL_APB1_GRP1_PERIPH_SPI2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART3 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART4 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART5 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_I2C1 + * @arg @ref LL_APB1_GRP1_PERIPH_I2C2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USB (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CAN (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CRS (*) + * @arg @ref LL_APB1_GRP1_PERIPH_PWR + * @arg @ref LL_APB1_GRP1_PERIPH_DAC1 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP1_ForceReset(uint32_t Periphs) +{ + SET_BIT(RCC->APB1RSTR, Periphs); +} + +/** + * @brief Release APB1 peripherals reset (available in register 1). + * @rmtoll APB1RSTR TIM2RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR TIM3RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR TIM6RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR TIM7RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR TIM14RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR WWDGRST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR SPI2RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR USART2RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR USART3RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR USART4RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR USART5RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR I2C1RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR I2C2RST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR USBRST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR CANRST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR CRSRST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR PWRRST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR DACRST LL_APB1_GRP1_ReleaseReset\n + * APB1RSTR CECRST LL_APB1_GRP1_ReleaseReset + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP1_PERIPH_ALL + * @arg @ref LL_APB1_GRP1_PERIPH_TIM2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM3 + * @arg @ref LL_APB1_GRP1_PERIPH_TIM6 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM7 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_TIM14 + * @arg @ref LL_APB1_GRP1_PERIPH_WWDG + * @arg @ref LL_APB1_GRP1_PERIPH_SPI2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART3 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART4 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USART5 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_I2C1 + * @arg @ref LL_APB1_GRP1_PERIPH_I2C2 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_USB (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CAN (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CRS (*) + * @arg @ref LL_APB1_GRP1_PERIPH_PWR + * @arg @ref LL_APB1_GRP1_PERIPH_DAC1 (*) + * @arg @ref LL_APB1_GRP1_PERIPH_CEC (*) + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP1_ReleaseReset(uint32_t Periphs) +{ + CLEAR_BIT(RCC->APB1RSTR, Periphs); +} + +/** + * @} + */ + +/** @defgroup BUS_LL_EF_APB1_GRP2 APB1 GRP2 + * @{ + */ + +/** + * @brief Enable APB1 peripherals clock (available in register 2). + * @rmtoll APB2ENR SYSCFGEN LL_APB1_GRP2_EnableClock\n + * APB2ENR ADC1EN LL_APB1_GRP2_EnableClock\n + * APB2ENR USART8EN LL_APB1_GRP2_EnableClock\n + * APB2ENR USART7EN LL_APB1_GRP2_EnableClock\n + * APB2ENR USART6EN LL_APB1_GRP2_EnableClock\n + * APB2ENR TIM1EN LL_APB1_GRP2_EnableClock\n + * APB2ENR SPI1EN LL_APB1_GRP2_EnableClock\n + * APB2ENR USART1EN LL_APB1_GRP2_EnableClock\n + * APB2ENR TIM15EN LL_APB1_GRP2_EnableClock\n + * APB2ENR TIM16EN LL_APB1_GRP2_EnableClock\n + * APB2ENR TIM17EN LL_APB1_GRP2_EnableClock\n + * APB2ENR DBGMCUEN LL_APB1_GRP2_EnableClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP2_PERIPH_SYSCFG + * @arg @ref LL_APB1_GRP2_PERIPH_ADC1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART8 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART7 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART6 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM1 + * @arg @ref LL_APB1_GRP2_PERIPH_SPI1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART1 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM15 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM16 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM17 + * @arg @ref LL_APB1_GRP2_PERIPH_DBGMCU + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP2_EnableClock(uint32_t Periphs) +{ + __IO uint32_t tmpreg; + SET_BIT(RCC->APB2ENR, Periphs); + /* Delay after an RCC peripheral clock enabling */ + tmpreg = READ_BIT(RCC->APB2ENR, Periphs); + (void)tmpreg; +} + +/** + * @brief Check if APB1 peripheral clock is enabled or not (available in register 2). + * @rmtoll APB2ENR SYSCFGEN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR ADC1EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR USART8EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR USART7EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR USART6EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR TIM1EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR SPI1EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR USART1EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR TIM15EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR TIM16EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR TIM17EN LL_APB1_GRP2_IsEnabledClock\n + * APB2ENR DBGMCUEN LL_APB1_GRP2_IsEnabledClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP2_PERIPH_SYSCFG + * @arg @ref LL_APB1_GRP2_PERIPH_ADC1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART8 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART7 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART6 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM1 + * @arg @ref LL_APB1_GRP2_PERIPH_SPI1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART1 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM15 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM16 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM17 + * @arg @ref LL_APB1_GRP2_PERIPH_DBGMCU + * + * (*) value not defined in all devices. + * @retval State of Periphs (1 or 0). +*/ +__STATIC_INLINE uint32_t LL_APB1_GRP2_IsEnabledClock(uint32_t Periphs) +{ + return (READ_BIT(RCC->APB2ENR, Periphs) == Periphs); +} + +/** + * @brief Disable APB1 peripherals clock (available in register 2). + * @rmtoll APB2ENR SYSCFGEN LL_APB1_GRP2_DisableClock\n + * APB2ENR ADC1EN LL_APB1_GRP2_DisableClock\n + * APB2ENR USART8EN LL_APB1_GRP2_DisableClock\n + * APB2ENR USART7EN LL_APB1_GRP2_DisableClock\n + * APB2ENR USART6EN LL_APB1_GRP2_DisableClock\n + * APB2ENR TIM1EN LL_APB1_GRP2_DisableClock\n + * APB2ENR SPI1EN LL_APB1_GRP2_DisableClock\n + * APB2ENR USART1EN LL_APB1_GRP2_DisableClock\n + * APB2ENR TIM15EN LL_APB1_GRP2_DisableClock\n + * APB2ENR TIM16EN LL_APB1_GRP2_DisableClock\n + * APB2ENR TIM17EN LL_APB1_GRP2_DisableClock\n + * APB2ENR DBGMCUEN LL_APB1_GRP2_DisableClock + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP2_PERIPH_SYSCFG + * @arg @ref LL_APB1_GRP2_PERIPH_ADC1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART8 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART7 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART6 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM1 + * @arg @ref LL_APB1_GRP2_PERIPH_SPI1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART1 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM15 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM16 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM17 + * @arg @ref LL_APB1_GRP2_PERIPH_DBGMCU + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP2_DisableClock(uint32_t Periphs) +{ + CLEAR_BIT(RCC->APB2ENR, Periphs); +} + +/** + * @brief Force APB1 peripherals reset (available in register 2). + * @rmtoll APB2RSTR SYSCFGRST LL_APB1_GRP2_ForceReset\n + * APB2RSTR ADC1RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR USART8RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR USART7RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR USART6RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR TIM1RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR SPI1RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR USART1RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR TIM15RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR TIM16RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR TIM17RST LL_APB1_GRP2_ForceReset\n + * APB2RSTR DBGMCURST LL_APB1_GRP2_ForceReset + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP2_PERIPH_ALL + * @arg @ref LL_APB1_GRP2_PERIPH_SYSCFG + * @arg @ref LL_APB1_GRP2_PERIPH_ADC1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART8 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART7 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART6 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM1 + * @arg @ref LL_APB1_GRP2_PERIPH_SPI1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART1 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM15 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM16 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM17 + * @arg @ref LL_APB1_GRP2_PERIPH_DBGMCU + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP2_ForceReset(uint32_t Periphs) +{ + SET_BIT(RCC->APB2RSTR, Periphs); +} + +/** + * @brief Release APB1 peripherals reset (available in register 2). + * @rmtoll APB2RSTR SYSCFGRST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR ADC1RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR USART8RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR USART7RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR USART6RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR TIM1RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR SPI1RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR USART1RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR TIM15RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR TIM16RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR TIM17RST LL_APB1_GRP2_ReleaseReset\n + * APB2RSTR DBGMCURST LL_APB1_GRP2_ReleaseReset + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_APB1_GRP2_PERIPH_ALL + * @arg @ref LL_APB1_GRP2_PERIPH_SYSCFG + * @arg @ref LL_APB1_GRP2_PERIPH_ADC1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART8 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART7 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_USART6 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM1 + * @arg @ref LL_APB1_GRP2_PERIPH_SPI1 + * @arg @ref LL_APB1_GRP2_PERIPH_USART1 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM15 (*) + * @arg @ref LL_APB1_GRP2_PERIPH_TIM16 + * @arg @ref LL_APB1_GRP2_PERIPH_TIM17 + * @arg @ref LL_APB1_GRP2_PERIPH_DBGMCU + * + * (*) value not defined in all devices. + * @retval None +*/ +__STATIC_INLINE void LL_APB1_GRP2_ReleaseReset(uint32_t Periphs) +{ + CLEAR_BIT(RCC->APB2RSTR, Periphs); +} + +/** + * @} + */ + + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(RCC) */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_BUS_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_comp.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_comp.h new file mode 100644 index 0000000..1dcde86 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_comp.h @@ -0,0 +1,831 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_comp.h + * @author MCD Application Team + * @brief Header file of COMP LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_COMP_H +#define __STM32F0xx_LL_COMP_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (COMP1) || defined (COMP2) + +/** @defgroup COMP_LL COMP + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup COMP_LL_Private_Constants COMP Private Constants + * @{ + */ + +/* Differentiation between COMP instances */ +/* Note: Value not corresponding to a register offset since both */ +/* COMP instances are sharing the same register) . */ +#define COMPX_BASE COMP_BASE +#define COMPX (COMP1 - COMP2) + +/* COMP registers bits positions */ +#define LL_COMP_OUTPUT_LEVEL_BITOFFSET_POS ((uint32_t)14U) /* Value equivalent to POSITION_VAL(COMP_CSR_COMP1OUT) */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup COMP_LL_Private_Macros COMP Private Macros + * @{ + */ + +/** + * @brief Driver macro reserved for internal use: if COMP instance selected + * is odd (COMP1, COMP3, ...), return value '1', else return '0'. + * @param __COMP_INSTANCE__ COMP instance + * @retval If COMP instance is odd, value '1'. Else, value '0'. +*/ +#define __COMP_IS_INSTANCE_ODD(__COMP_INSTANCE__) \ + ((~(((uint32_t)(__COMP_INSTANCE__) - COMP_BASE) >> 1U)) & 0x00000001) + +/** + * @brief Driver macro reserved for internal use: if COMP instance selected + * is even (COMP2, COMP4, ...), return value '1', else return '0'. + * @param __COMP_INSTANCE__ COMP instance + * @retval If COMP instance is even, value '1'. Else, value '0'. +*/ +#define __COMP_IS_INSTANCE_EVEN(__COMP_INSTANCE__) \ + (((uint32_t)(__COMP_INSTANCE__) - COMP_BASE) >> 1U) + +/** + * @brief Driver macro reserved for internal use: from COMP instance + * selected, set offset of bits into COMP register. + * @note Since both COMP instances are sharing the same register + * with 2 area of bits with an offset of 16 bits, this function + * returns value "0" if COMP1 is selected and "16" if COMP2 is + * selected. + * @param __COMP_INSTANCE__ COMP instance + * @retval Bits offset in register 32 bits +*/ +#define __COMP_BITOFFSET_INSTANCE(__COMP_INSTANCE__) \ + (((uint32_t)(__COMP_INSTANCE__) - COMP_BASE) << 3U) + +/** + * @} + */ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup COMP_LL_ES_INIT COMP Exported Init structure + * @{ + */ + +/** + * @brief Structure definition of some features of COMP instance. + */ +typedef struct +{ + uint32_t PowerMode; /*!< Set comparator operating mode to adjust power and speed. + This parameter can be a value of @ref COMP_LL_EC_POWERMODE + + This feature can be modified afterwards using unitary function @ref LL_COMP_SetPowerMode(). */ + + uint32_t InputPlus; /*!< Set comparator input plus (non-inverting input). + This parameter can be a value of @ref COMP_LL_EC_INPUT_PLUS + + This feature can be modified afterwards using unitary function @ref LL_COMP_SetInputPlus(). */ + + uint32_t InputMinus; /*!< Set comparator input minus (inverting input). + This parameter can be a value of @ref COMP_LL_EC_INPUT_MINUS + + This feature can be modified afterwards using unitary function @ref LL_COMP_SetInputMinus(). */ + + uint32_t InputHysteresis; /*!< Set comparator hysteresis mode of the input minus. + This parameter can be a value of @ref COMP_LL_EC_INPUT_HYSTERESIS + + This feature can be modified afterwards using unitary function @ref LL_COMP_SetInputHysteresis(). */ + + uint32_t OutputSelection; /*!< Set comparator output selection. + This parameter can be a value of @ref COMP_LL_EC_OUTPUT_SELECTION + + This feature can be modified afterwards using unitary function @ref LL_COMP_SetOutputSelection(). */ + + uint32_t OutputPolarity; /*!< Set comparator output polarity. + This parameter can be a value of @ref COMP_LL_EC_OUTPUT_POLARITY + + This feature can be modified afterwards using unitary function @ref LL_COMP_SetOutputPolarity(). */ + +} LL_COMP_InitTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup COMP_LL_Exported_Constants COMP Exported Constants + * @{ + */ + +/** @defgroup COMP_LL_EC_COMMON_WINDOWMODE Comparator common modes - Window mode + * @{ + */ +#define LL_COMP_WINDOWMODE_DISABLE ((uint32_t)0x00000000U) /*!< Window mode disable: Comparators 1 and 2 are independent */ +#define LL_COMP_WINDOWMODE_COMP1_INPUT_PLUS_COMMON (COMP_CSR_WNDWEN) /*!< Window mode enable: Comparators instances pair COMP1 and COMP2 have their input plus connected together. The common input is COMP1 input plus (COMP2 input plus is no more accessible). */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_POWERMODE Comparator modes - Power mode + * @{ + */ +#define LL_COMP_POWERMODE_HIGHSPEED ((uint32_t)0x00000000U) /*!< COMP power mode to high speed */ +#define LL_COMP_POWERMODE_MEDIUMSPEED (COMP_CSR_COMP1MODE_0) /*!< COMP power mode to medium speed */ +#define LL_COMP_POWERMODE_LOWPOWER (COMP_CSR_COMP1MODE_1) /*!< COMP power mode to low power */ +#define LL_COMP_POWERMODE_ULTRALOWPOWER (COMP_CSR_COMP1MODE_1 | COMP_CSR_COMP1MODE_0) /*!< COMP power mode to ultra-low power */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_INPUT_PLUS Comparator inputs - Input plus (input non-inverting) selection + * @{ + */ +#define LL_COMP_INPUT_PLUS_IO1 ((uint32_t)0x00000000U) /*!< Comparator input plus connected to IO1 (pin PA1 for COMP1, pin PA3 for COMP2) */ +#define LL_COMP_INPUT_PLUS_DAC1_CH1 (COMP_CSR_COMP1SW1) /*!< Comparator input plus connected to DAC1 channel 1 (DAC_OUT1), through dedicated switch (Note: this switch is solely intended to redirect signals onto high impedance input, such as COMP1 input plus (highly resistive switch)) (specific to COMP instance: COMP1) */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_INPUT_MINUS Comparator inputs - Input minus (input inverting) selection + * @{ + */ +#define LL_COMP_INPUT_MINUS_1_4VREFINT ((uint32_t)0x00000000U) /*!< Comparator input minus connected to 1/4 VrefInt */ +#define LL_COMP_INPUT_MINUS_1_2VREFINT ( COMP_CSR_COMP1INSEL_0) /*!< Comparator input minus connected to 1/2 VrefInt */ +#define LL_COMP_INPUT_MINUS_3_4VREFINT ( COMP_CSR_COMP1INSEL_1 ) /*!< Comparator input minus connected to 3/4 VrefInt */ +#define LL_COMP_INPUT_MINUS_VREFINT ( COMP_CSR_COMP1INSEL_1 | COMP_CSR_COMP1INSEL_0) /*!< Comparator input minus connected to VrefInt */ +#define LL_COMP_INPUT_MINUS_DAC1_CH1 (COMP_CSR_COMP1INSEL_2 ) /*!< Comparator input minus connected to DAC1 channel 1 (DAC_OUT1) */ +#define LL_COMP_INPUT_MINUS_DAC1_CH2 (COMP_CSR_COMP1INSEL_2 | COMP_CSR_COMP1INSEL_0) /*!< Comparator input minus connected to DAC1 channel 2 (DAC_OUT2) */ +#define LL_COMP_INPUT_MINUS_IO1 (COMP_CSR_COMP1INSEL_2 | COMP_CSR_COMP1INSEL_1 ) /*!< Comparator input minus connected to IO1 (pin PA0 for COMP1, pin PA2 for COMP2) */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_INPUT_HYSTERESIS Comparator input - Hysteresis + * @{ + */ +#define LL_COMP_HYSTERESIS_NONE ((uint32_t)0x00000000U) /*!< No hysteresis */ +#define LL_COMP_HYSTERESIS_LOW ( COMP_CSR_COMP1HYST_0) /*!< Hysteresis level low */ +#define LL_COMP_HYSTERESIS_MEDIUM (COMP_CSR_COMP1HYST_1 ) /*!< Hysteresis level medium */ +#define LL_COMP_HYSTERESIS_HIGH (COMP_CSR_COMP1HYST_1 | COMP_CSR_COMP1HYST_0) /*!< Hysteresis level high */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_OUTPUT_SELECTION Comparator output - Output selection + * @{ + */ +/* Note: Output redirection is common for COMP1 and COMP2 */ +#define LL_COMP_OUTPUT_NONE ((uint32_t)0x00000000U) /*!< COMP output is not connected to other peripherals (except GPIO and EXTI that are always connected to COMP output) */ +#define LL_COMP_OUTPUT_TIM1_BKIN (COMP_CSR_COMP1OUTSEL_0) /*!< COMP output connected to TIM1 break input (BKIN) */ +#define LL_COMP_OUTPUT_TIM1_IC1 (COMP_CSR_COMP1OUTSEL_1) /*!< COMP output connected to TIM1 input capture 1 */ +#define LL_COMP_OUTPUT_TIM1_OCCLR (COMP_CSR_COMP1OUTSEL_1 | COMP_CSR_COMP1OUTSEL_0) /*!< COMP output connected to TIM1 OCREF clear */ +#define LL_COMP_OUTPUT_TIM2_IC4 (COMP_CSR_COMP1OUTSEL_2) /*!< COMP output connected to TIM2 input capture 4 */ +#define LL_COMP_OUTPUT_TIM2_OCCLR (COMP_CSR_COMP1OUTSEL_2 | COMP_CSR_COMP1OUTSEL_0) /*!< COMP output connected to TIM2 OCREF clear */ +#define LL_COMP_OUTPUT_TIM3_IC1 (COMP_CSR_COMP1OUTSEL_2 | COMP_CSR_COMP1OUTSEL_1) /*!< COMP output connected to TIM3 input capture 1 */ +#define LL_COMP_OUTPUT_TIM3_OCCLR (COMP_CSR_COMP1OUTSEL_2 | COMP_CSR_COMP1OUTSEL_1 | COMP_CSR_COMP1OUTSEL_0) /*!< COMP output connected to TIM3 OCREF clear */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_OUTPUT_POLARITY Comparator output - Output polarity + * @{ + */ +#define LL_COMP_OUTPUTPOL_NONINVERTED ((uint32_t)0x00000000U) /*!< COMP output polarity is not inverted: comparator output is high when the plus (non-inverting) input is at a higher voltage than the minus (inverting) input */ +#define LL_COMP_OUTPUTPOL_INVERTED (COMP_CSR_COMP1POL) /*!< COMP output polarity is inverted: comparator output is low when the plus (non-inverting) input is at a lower voltage than the minus (inverting) input */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_OUTPUT_LEVEL Comparator output - Output level + * @{ + */ +#define LL_COMP_OUTPUT_LEVEL_LOW ((uint32_t)0x00000000U) /*!< Comparator output level low (if the polarity is not inverted, otherwise to be complemented) */ +#define LL_COMP_OUTPUT_LEVEL_HIGH ((uint32_t)0x00000001U) /*!< Comparator output level high (if the polarity is not inverted, otherwise to be complemented) */ +/** + * @} + */ + +/** @defgroup COMP_LL_EC_HW_DELAYS Definitions of COMP hardware constraints delays + * @note Only COMP IP HW delays are defined in COMP LL driver driver, + * not timeout values. + * For details on delays values, refer to descriptions in source code + * above each literal definition. + * @{ + */ + +/* Delay for comparator startup time. */ +/* Note: Delay required to reach propagation delay specification. */ +/* Literal set to maximum value (refer to device datasheet, */ +/* parameter "tSTART"). */ +/* Unit: us */ +#define LL_COMP_DELAY_STARTUP_US ((uint32_t) 60U) /*!< Delay for COMP startup time */ + +/* Delay for comparator voltage scaler stabilization time */ +/* (voltage from VrefInt, delay based on VrefInt startup time). */ +/* Literal set to maximum value (refer to device datasheet, */ +/* parameter "tS_SC"). */ +/* Unit: us */ +#define LL_COMP_DELAY_VOLTAGE_SCALER_STAB_US ((uint32_t) 200U) /*!< Delay for COMP voltage scaler stabilization time */ + + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup COMP_LL_Exported_Macros COMP Exported Macros + * @{ + */ +/** @defgroup COMP_LL_EM_WRITE_READ Common write and read registers macro + * @{ + */ + +/** + * @brief Write a value in COMP register + * @param __INSTANCE__ comparator instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_COMP_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in COMP register + * @param __INSTANCE__ comparator instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_COMP_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** @defgroup COMP_LL_EM_HELPER_MACRO COMP helper macro + * @{ + */ + +/** + * @brief Helper macro to select the COMP common instance + * to which is belonging the selected COMP instance. + * @note COMP common register instance can be used to + * set parameters common to several COMP instances. + * Refer to functions having argument "COMPxy_COMMON" as parameter. + * @param __COMPx__ COMP instance + * @retval COMP common instance or value "0" if there is no COMP common instance. + */ +#define __LL_COMP_COMMON_INSTANCE(__COMPx__) \ + (COMP12_COMMON) + +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup COMP_LL_Exported_Functions COMP Exported Functions + * @{ + */ + +/** @defgroup COMP_LL_EF_Configuration_comparator_common Configuration of COMP hierarchical scope: common to several COMP instances + * @{ + */ + +/** + * @brief Set window mode of a pair of comparators instances + * (2 consecutive COMP instances odd and even COMP and COMP). + * @rmtoll CSR WNDWEN LL_COMP_SetCommonWindowMode + * @param COMPxy_COMMON Comparator common instance + * (can be set directly from CMSIS definition or by using helper macro @ref __LL_COMP_COMMON_INSTANCE() ) + * @param WindowMode This parameter can be one of the following values: + * @arg @ref LL_COMP_WINDOWMODE_DISABLE + * @arg @ref LL_COMP_WINDOWMODE_COMP1_INPUT_PLUS_COMMON + * @retval None + */ +__STATIC_INLINE void LL_COMP_SetCommonWindowMode(COMP_Common_TypeDef *COMPxy_COMMON, uint32_t WindowMode) +{ + MODIFY_REG(COMPxy_COMMON->CSR, COMP_CSR_WNDWEN, WindowMode); +} + +/** + * @brief Get window mode of a pair of comparators instances + * (2 consecutive COMP instances odd and even COMP and COMP). + * @rmtoll CSR WNDWEN LL_COMP_GetCommonWindowMode + * @param COMPxy_COMMON Comparator common instance + * (can be set directly from CMSIS definition or by using helper macro @ref __LL_COMP_COMMON_INSTANCE() ) + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_WINDOWMODE_DISABLE + * @arg @ref LL_COMP_WINDOWMODE_COMP1_INPUT_PLUS_COMMON + */ +__STATIC_INLINE uint32_t LL_COMP_GetCommonWindowMode(COMP_Common_TypeDef *COMPxy_COMMON) +{ + return (uint32_t)(READ_BIT(COMPxy_COMMON->CSR, COMP_CSR_WNDWEN)); +} + +/** + * @} + */ + +/** @defgroup COMP_LL_EF_Configuration_comparator_modes Configuration of comparator modes + * @{ + */ + +/** + * @brief Set comparator instance operating mode to adjust power and speed. + * @rmtoll CSR COMP1MODE LL_COMP_SetPowerMode\n + * COMP2MODE LL_COMP_SetPowerMode + * @param COMPx Comparator instance + * @param PowerMode This parameter can be one of the following values: + * @arg @ref LL_COMP_POWERMODE_HIGHSPEED + * @arg @ref LL_COMP_POWERMODE_MEDIUMSPEED + * @arg @ref LL_COMP_POWERMODE_LOWPOWER + * @arg @ref LL_COMP_POWERMODE_ULTRALOWPOWER + * @retval None + */ +__STATIC_INLINE void LL_COMP_SetPowerMode(COMP_TypeDef *COMPx, uint32_t PowerMode) +{ + MODIFY_REG(COMP->CSR, + COMP_CSR_COMP1MODE << __COMP_BITOFFSET_INSTANCE(COMPx), + PowerMode << __COMP_BITOFFSET_INSTANCE(COMPx) ); +} + +/** + * @brief Get comparator instance operating mode to adjust power and speed. + * @rmtoll CSR COMP1MODE LL_COMP_GetPowerMode\n + * COMP2MODE LL_COMP_GetPowerMode + * @param COMPx Comparator instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_POWERMODE_HIGHSPEED + * @arg @ref LL_COMP_POWERMODE_MEDIUMSPEED + * @arg @ref LL_COMP_POWERMODE_LOWPOWER + * @arg @ref LL_COMP_POWERMODE_ULTRALOWPOWER + */ +__STATIC_INLINE uint32_t LL_COMP_GetPowerMode(COMP_TypeDef *COMPx) +{ + return (uint32_t)(READ_BIT(COMP->CSR, + COMP_CSR_COMP1MODE << __COMP_BITOFFSET_INSTANCE(COMPx)) + >> __COMP_BITOFFSET_INSTANCE(COMPx) + ); +} + +/** + * @} + */ + +/** @defgroup COMP_LL_EF_Configuration_comparator_inputs Configuration of comparator inputs + * @{ + */ + +/** + * @brief Set comparator inputs minus (inverting) and plus (non-inverting). + * @note In case of comparator input selected to be connected to IO: + * GPIO pins are specific to each comparator instance. + * Refer to description of parameters or to reference manual. + * @rmtoll CSR COMP1INSEL LL_COMP_ConfigInputs\n + * CSR COMP2INSEL LL_COMP_ConfigInputs\n + * CSR COMP1SW1 LL_COMP_ConfigInputs + * @param COMPx Comparator instance + * @param InputMinus This parameter can be one of the following values: + * @arg @ref LL_COMP_INPUT_MINUS_1_4VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_1_2VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_3_4VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_DAC1_CH1 + * @arg @ref LL_COMP_INPUT_MINUS_DAC1_CH2 + * @arg @ref LL_COMP_INPUT_MINUS_IO1 + * @param InputPlus This parameter can be one of the following values: + * @arg @ref LL_COMP_INPUT_PLUS_IO1 + * @arg @ref LL_COMP_INPUT_PLUS_DAC1_CH1 (1) + * + * (1) Parameter available only on COMP instance: COMP1. + * @retval None + */ +__STATIC_INLINE void LL_COMP_ConfigInputs(COMP_TypeDef *COMPx, uint32_t InputMinus, uint32_t InputPlus) +{ + /* Note: Connection switch is applicable only to COMP instance COMP1, */ + /* therefore if COMP2 is selected the equivalent bit is */ + /* kept unmodified. */ + MODIFY_REG(COMP->CSR, + (COMP_CSR_COMP1INSEL | (COMP_CSR_COMP1SW1 * __COMP_IS_INSTANCE_ODD(COMPx))) << __COMP_BITOFFSET_INSTANCE(COMPx), + (InputMinus | InputPlus) << __COMP_BITOFFSET_INSTANCE(COMPx) ); +} + +/** + * @brief Set comparator input plus (non-inverting). + * @note In case of comparator input selected to be connected to IO: + * GPIO pins are specific to each comparator instance. + * Refer to description of parameters or to reference manual. + * @rmtoll CSR COMP1INSEL LL_COMP_SetInputPlus\n + * CSR COMP2INSEL LL_COMP_SetInputPlus + * @param COMPx Comparator instance + * @param InputPlus This parameter can be one of the following values: + * @arg @ref LL_COMP_INPUT_PLUS_IO1 + * @arg @ref LL_COMP_INPUT_PLUS_DAC1_CH1 (1) + * + * (1) Parameter available only on COMP instance: COMP1. + * @retval None + */ +__STATIC_INLINE void LL_COMP_SetInputPlus(COMP_TypeDef *COMPx, uint32_t InputPlus) +{ + /* Note: Connection switch is applicable only to COMP instance COMP1, */ + /* therefore if COMP2 is selected the equivalent bit is */ + /* kept unmodified. */ + MODIFY_REG(COMP->CSR, + (COMP_CSR_COMP1SW1 * __COMP_IS_INSTANCE_ODD(COMPx)) << __COMP_BITOFFSET_INSTANCE(COMPx), + InputPlus << __COMP_BITOFFSET_INSTANCE(COMPx) ); +} + +/** + * @brief Get comparator input plus (non-inverting). + * @note In case of comparator input selected to be connected to IO: + * GPIO pins are specific to each comparator instance. + * Refer to description of parameters or to reference manual. + * @rmtoll CSR COMP1INSEL LL_COMP_GetInputPlus\n + * CSR COMP2INSEL LL_COMP_GetInputPlus + * @param COMPx Comparator instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_INPUT_PLUS_IO1 + * @arg @ref LL_COMP_INPUT_PLUS_DAC1_CH1 (1) + * + * (1) Parameter available only on COMP instance: COMP1. + */ +__STATIC_INLINE uint32_t LL_COMP_GetInputPlus(COMP_TypeDef *COMPx) +{ + /* Note: Connection switch is applicable only to COMP instance COMP1, */ + /* therefore is COMP2 is selected the returned value will be null. */ + return (uint32_t)(READ_BIT(COMP->CSR, + COMP_CSR_COMP1SW1 << __COMP_BITOFFSET_INSTANCE(COMPx)) + >> __COMP_BITOFFSET_INSTANCE(COMPx) + ); +} + +/** + * @brief Set comparator input minus (inverting). + * @note In case of comparator input selected to be connected to IO: + * GPIO pins are specific to each comparator instance. + * Refer to description of parameters or to reference manual. + * @rmtoll CSR COMP1SW1 LL_COMP_SetInputMinus + * @param COMPx Comparator instance + * @param InputMinus This parameter can be one of the following values: + * @arg @ref LL_COMP_INPUT_MINUS_1_4VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_1_2VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_3_4VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_DAC1_CH1 + * @arg @ref LL_COMP_INPUT_MINUS_DAC1_CH2 + * @arg @ref LL_COMP_INPUT_MINUS_IO1 + * @retval None + */ +__STATIC_INLINE void LL_COMP_SetInputMinus(COMP_TypeDef *COMPx, uint32_t InputMinus) +{ + MODIFY_REG(COMP->CSR, + COMP_CSR_COMP1INSEL << __COMP_BITOFFSET_INSTANCE(COMPx), + InputMinus << __COMP_BITOFFSET_INSTANCE(COMPx) ); +} + +/** + * @brief Get comparator input minus (inverting). + * @note In case of comparator input selected to be connected to IO: + * GPIO pins are specific to each comparator instance. + * Refer to description of parameters or to reference manual. + * @rmtoll CSR COMP1SW1 LL_COMP_GetInputMinus + * @param COMPx Comparator instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_INPUT_MINUS_1_4VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_1_2VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_3_4VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_VREFINT + * @arg @ref LL_COMP_INPUT_MINUS_DAC1_CH1 + * @arg @ref LL_COMP_INPUT_MINUS_DAC1_CH2 + * @arg @ref LL_COMP_INPUT_MINUS_IO1 + */ +__STATIC_INLINE uint32_t LL_COMP_GetInputMinus(COMP_TypeDef *COMPx) +{ + return (uint32_t)(READ_BIT(COMP->CSR, + COMP_CSR_COMP1INSEL << __COMP_BITOFFSET_INSTANCE(COMPx)) + >> __COMP_BITOFFSET_INSTANCE(COMPx) + ); +} + +/** + * @brief Set comparator instance hysteresis mode of the input minus (inverting input). + * @rmtoll CSR COMP1HYST LL_COMP_SetInputHysteresis\n + * COMP2HYST LL_COMP_SetInputHysteresis + * @param COMPx Comparator instance + * @param InputHysteresis This parameter can be one of the following values: + * @arg @ref LL_COMP_HYSTERESIS_NONE + * @arg @ref LL_COMP_HYSTERESIS_LOW + * @arg @ref LL_COMP_HYSTERESIS_MEDIUM + * @arg @ref LL_COMP_HYSTERESIS_HIGH + * @retval None + */ +__STATIC_INLINE void LL_COMP_SetInputHysteresis(COMP_TypeDef *COMPx, uint32_t InputHysteresis) +{ + MODIFY_REG(COMP->CSR, + COMP_CSR_COMP1HYST << __COMP_BITOFFSET_INSTANCE(COMPx), + InputHysteresis << __COMP_BITOFFSET_INSTANCE(COMPx) ); +} + +/** + * @brief Get comparator instance hysteresis mode of the minus (inverting) input. + * @rmtoll CSR COMP1HYST LL_COMP_GetInputHysteresis\n + * COMP2HYST LL_COMP_GetInputHysteresis + * @param COMPx Comparator instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_HYSTERESIS_NONE + * @arg @ref LL_COMP_HYSTERESIS_LOW + * @arg @ref LL_COMP_HYSTERESIS_MEDIUM + * @arg @ref LL_COMP_HYSTERESIS_HIGH + */ +__STATIC_INLINE uint32_t LL_COMP_GetInputHysteresis(COMP_TypeDef *COMPx) +{ + return (uint32_t)(READ_BIT(COMP->CSR, + COMP_CSR_COMP1HYST << __COMP_BITOFFSET_INSTANCE(COMPx)) + >> __COMP_BITOFFSET_INSTANCE(COMPx) + ); + +} + +/** + * @} + */ + +/** @defgroup COMP_LL_EF_Configuration_comparator_output Configuration of comparator output + * @{ + */ + +/** + * @brief Set comparator output selection. + * @note Availability of parameters of output selection to timer + * depends on timers availability on the selected device. + * @rmtoll CSR COMP1OUTSEL LL_COMP_SetOutputSelection\n + * COMP2OUTSEL LL_COMP_SetOutputSelection + * @param COMPx Comparator instance + * @param OutputSelection This parameter can be one of the following values: + * @arg @ref LL_COMP_OUTPUT_NONE + * @arg @ref LL_COMP_OUTPUT_TIM1_BKIN (1) + * @arg @ref LL_COMP_OUTPUT_TIM1_IC1 (1) + * @arg @ref LL_COMP_OUTPUT_TIM1_OCCLR (1) + * @arg @ref LL_COMP_OUTPUT_TIM2_IC4 (1) + * @arg @ref LL_COMP_OUTPUT_TIM2_OCCLR (1) + * @arg @ref LL_COMP_OUTPUT_TIM3_IC1 (1) + * @arg @ref LL_COMP_OUTPUT_TIM3_OCCLR (1) + * + * (1) Parameter availability depending on timer availability + * on the selected device. + * @retval None + */ +__STATIC_INLINE void LL_COMP_SetOutputSelection(COMP_TypeDef *COMPx, uint32_t OutputSelection) +{ + MODIFY_REG(COMP->CSR, + COMP_CSR_COMP1OUTSEL << __COMP_BITOFFSET_INSTANCE(COMPx), + OutputSelection << __COMP_BITOFFSET_INSTANCE(COMPx) ); +} + +/** + * @brief Get comparator output selection. + * @note Availability of parameters of output selection to timer + * depends on timers availability on the selected device. + * @rmtoll CSR COMP1OUTSEL LL_COMP_GetOutputSelection\n + * COMP2OUTSEL LL_COMP_GetOutputSelection + * @param COMPx Comparator instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_OUTPUT_NONE + * @arg @ref LL_COMP_OUTPUT_TIM1_BKIN (1) + * @arg @ref LL_COMP_OUTPUT_TIM1_IC1 (1) + * @arg @ref LL_COMP_OUTPUT_TIM1_OCCLR (1) + * @arg @ref LL_COMP_OUTPUT_TIM2_IC4 (1) + * @arg @ref LL_COMP_OUTPUT_TIM2_OCCLR (1) + * @arg @ref LL_COMP_OUTPUT_TIM3_IC1 (1) + * @arg @ref LL_COMP_OUTPUT_TIM3_OCCLR (1) + * + * (1) Parameter availability depending on timer availability + * on the selected device. + */ +__STATIC_INLINE uint32_t LL_COMP_GetOutputSelection(COMP_TypeDef *COMPx) +{ + return (uint32_t)(READ_BIT(COMP->CSR, + COMP_CSR_COMP1OUTSEL << __COMP_BITOFFSET_INSTANCE(COMPx)) + >> __COMP_BITOFFSET_INSTANCE(COMPx) + ); +} + +/** + * @brief Set comparator instance output polarity. + * @rmtoll CSR COMP1POL LL_COMP_SetOutputPolarity\n + * COMP2POL LL_COMP_SetOutputPolarity + * @param COMPx Comparator instance + * @param OutputPolarity This parameter can be one of the following values: + * @arg @ref LL_COMP_OUTPUTPOL_NONINVERTED + * @arg @ref LL_COMP_OUTPUTPOL_INVERTED + * @retval None + */ +__STATIC_INLINE void LL_COMP_SetOutputPolarity(COMP_TypeDef *COMPx, uint32_t OutputPolarity) +{ + MODIFY_REG(COMP->CSR, + COMP_CSR_COMP1POL << __COMP_BITOFFSET_INSTANCE(COMPx), + OutputPolarity << __COMP_BITOFFSET_INSTANCE(COMPx) ); +} + +/** + * @brief Get comparator instance output polarity. + * @rmtoll CSR COMP1POL LL_COMP_GetOutputPolarity\n + * COMP2POL LL_COMP_GetOutputPolarity + * @param COMPx Comparator instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_OUTPUTPOL_NONINVERTED + * @arg @ref LL_COMP_OUTPUTPOL_INVERTED + */ +__STATIC_INLINE uint32_t LL_COMP_GetOutputPolarity(COMP_TypeDef *COMPx) +{ + return (uint32_t)(READ_BIT(COMP->CSR, + COMP_CSR_COMP1POL << __COMP_BITOFFSET_INSTANCE(COMPx)) + >> __COMP_BITOFFSET_INSTANCE(COMPx) + ); +} + +/** + * @} + */ + +/** @defgroup COMP_LL_EF_Operation Operation on comparator instance + * @{ + */ + +/** + * @brief Enable comparator instance. + * @note After enable from off state, comparator requires a delay + * to reach reach propagation delay specification. + * Refer to device datasheet, parameter "tSTART". + * @rmtoll CSR COMP1EN LL_COMP_Enable\n + * CSR COMP2EN LL_COMP_Enable + * @param COMPx Comparator instance + * @retval None + */ +__STATIC_INLINE void LL_COMP_Enable(COMP_TypeDef *COMPx) +{ + SET_BIT(COMP->CSR, COMP_CSR_COMP1EN << __COMP_BITOFFSET_INSTANCE(COMPx)); +} + +/** + * @brief Disable comparator instance. + * @rmtoll CSR COMP1EN LL_COMP_Disable\n + * CSR COMP2EN LL_COMP_Disable + * @param COMPx Comparator instance + * @retval None + */ +__STATIC_INLINE void LL_COMP_Disable(COMP_TypeDef *COMPx) +{ + CLEAR_BIT(COMP->CSR, COMP_CSR_COMP1EN << __COMP_BITOFFSET_INSTANCE(COMPx)); +} + +/** + * @brief Get comparator enable state + * (0: COMP is disabled, 1: COMP is enabled) + * @rmtoll CSR COMP1EN LL_COMP_IsEnabled\n + * CSR COMP2EN LL_COMP_IsEnabled + * @param COMPx Comparator instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_COMP_IsEnabled(COMP_TypeDef *COMPx) +{ + return (READ_BIT(COMP->CSR, COMP_CSR_COMP1EN << __COMP_BITOFFSET_INSTANCE(COMPx)) == COMP_CSR_COMP1EN << __COMP_BITOFFSET_INSTANCE(COMPx)); +} + +/** + * @brief Lock comparator instance. + * @note Once locked, comparator configuration can be accessed in read-only. + * @note The only way to unlock the comparator is a device hardware reset. + * @rmtoll CSR COMP1LOCK LL_COMP_Lock\n + * CSR COMP2LOCK LL_COMP_Lock + * @param COMPx Comparator instance + * @retval None + */ +__STATIC_INLINE void LL_COMP_Lock(COMP_TypeDef *COMPx) +{ + SET_BIT(COMP->CSR, COMP_CSR_COMP1LOCK << __COMP_BITOFFSET_INSTANCE(COMPx)); +} + +/** + * @brief Get comparator lock state + * (0: COMP is unlocked, 1: COMP is locked). + * @note Once locked, comparator configuration can be accessed in read-only. + * @note The only way to unlock the comparator is a device hardware reset. + * @rmtoll CSR COMP1LOCK LL_COMP_IsLocked\n + * CSR COMP2LOCK LL_COMP_IsLocked + * @param COMPx Comparator instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_COMP_IsLocked(COMP_TypeDef *COMPx) +{ + return (READ_BIT(COMP->CSR, COMP_CSR_COMP1LOCK << __COMP_BITOFFSET_INSTANCE(COMPx)) == COMP_CSR_COMP1LOCK << __COMP_BITOFFSET_INSTANCE(COMPx)); +} + +/** + * @brief Read comparator instance output level. + * @note The comparator output level depends on the selected polarity + * (Refer to function @ref LL_COMP_SetOutputPolarity()). + * If the comparator polarity is not inverted: + * - Comparator output is low when the input plus + * is at a lower voltage than the input minus + * - Comparator output is high when the input plus + * is at a higher voltage than the input minus + * If the comparator polarity is inverted: + * - Comparator output is high when the input plus + * is at a lower voltage than the input minus + * - Comparator output is low when the input plus + * is at a higher voltage than the input minus + * @rmtoll CSR COMP1OUT LL_COMP_ReadOutputLevel\n + * CSR COMP2OUT LL_COMP_ReadOutputLevel + * @param COMPx Comparator instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_COMP_OUTPUT_LEVEL_LOW + * @arg @ref LL_COMP_OUTPUT_LEVEL_HIGH + */ +__STATIC_INLINE uint32_t LL_COMP_ReadOutputLevel(COMP_TypeDef *COMPx) +{ + return (uint32_t)(READ_BIT(COMP->CSR, + COMP_CSR_COMP1OUT << __COMP_BITOFFSET_INSTANCE(COMPx)) + >> (__COMP_BITOFFSET_INSTANCE(COMPx) + LL_COMP_OUTPUT_LEVEL_BITOFFSET_POS) + ); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup COMP_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_COMP_DeInit(COMP_TypeDef *COMPx); +ErrorStatus LL_COMP_Init(COMP_TypeDef *COMPx, LL_COMP_InitTypeDef *COMP_InitStruct); +void LL_COMP_StructInit(LL_COMP_InitTypeDef *COMP_InitStruct); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* COMP1 || COMP2 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_COMP_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_cortex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_cortex.h new file mode 100644 index 0000000..1b3005e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_cortex.h @@ -0,0 +1,320 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_cortex.h + * @author MCD Application Team + * @brief Header file of CORTEX LL module. + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The LL CORTEX driver contains a set of generic APIs that can be + used by user: + (+) SYSTICK configuration used by LL_mDelay and LL_Init1msTick + functions + (+) Low power mode configuration (SCB register of Cortex-MCU) + (+) API to access to MCU info (CPUID register) + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_CORTEX_H +#define __STM32F0xx_LL_CORTEX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +/** @defgroup CORTEX_LL CORTEX + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ + +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup CORTEX_LL_Exported_Constants CORTEX Exported Constants + * @{ + */ + +/** @defgroup CORTEX_LL_EC_CLKSOURCE_HCLK SYSTICK Clock Source + * @{ + */ +#define LL_SYSTICK_CLKSOURCE_HCLK_DIV8 0x00000000U /*!< AHB clock divided by 8 selected as SysTick clock source.*/ +#define LL_SYSTICK_CLKSOURCE_HCLK SysTick_CTRL_CLKSOURCE_Msk /*!< AHB clock selected as SysTick clock source. */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup CORTEX_LL_Exported_Functions CORTEX Exported Functions + * @{ + */ + +/** @defgroup CORTEX_LL_EF_SYSTICK SYSTICK + * @{ + */ + +/** + * @brief This function checks if the Systick counter flag is active or not. + * @note It can be used in timeout function on application side. + * @rmtoll STK_CTRL COUNTFLAG LL_SYSTICK_IsActiveCounterFlag + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSTICK_IsActiveCounterFlag(void) +{ + return ((SysTick->CTRL & SysTick_CTRL_COUNTFLAG_Msk) == (SysTick_CTRL_COUNTFLAG_Msk)); +} + +/** + * @brief Configures the SysTick clock source + * @rmtoll STK_CTRL CLKSOURCE LL_SYSTICK_SetClkSource + * @param Source This parameter can be one of the following values: + * @arg @ref LL_SYSTICK_CLKSOURCE_HCLK_DIV8 + * @arg @ref LL_SYSTICK_CLKSOURCE_HCLK + * @retval None + */ +__STATIC_INLINE void LL_SYSTICK_SetClkSource(uint32_t Source) +{ + if (Source == LL_SYSTICK_CLKSOURCE_HCLK) + { + SET_BIT(SysTick->CTRL, LL_SYSTICK_CLKSOURCE_HCLK); + } + else + { + CLEAR_BIT(SysTick->CTRL, LL_SYSTICK_CLKSOURCE_HCLK); + } +} + +/** + * @brief Get the SysTick clock source + * @rmtoll STK_CTRL CLKSOURCE LL_SYSTICK_GetClkSource + * @retval Returned value can be one of the following values: + * @arg @ref LL_SYSTICK_CLKSOURCE_HCLK_DIV8 + * @arg @ref LL_SYSTICK_CLKSOURCE_HCLK + */ +__STATIC_INLINE uint32_t LL_SYSTICK_GetClkSource(void) +{ + return READ_BIT(SysTick->CTRL, LL_SYSTICK_CLKSOURCE_HCLK); +} + +/** + * @brief Enable SysTick exception request + * @rmtoll STK_CTRL TICKINT LL_SYSTICK_EnableIT + * @retval None + */ +__STATIC_INLINE void LL_SYSTICK_EnableIT(void) +{ + SET_BIT(SysTick->CTRL, SysTick_CTRL_TICKINT_Msk); +} + +/** + * @brief Disable SysTick exception request + * @rmtoll STK_CTRL TICKINT LL_SYSTICK_DisableIT + * @retval None + */ +__STATIC_INLINE void LL_SYSTICK_DisableIT(void) +{ + CLEAR_BIT(SysTick->CTRL, SysTick_CTRL_TICKINT_Msk); +} + +/** + * @brief Checks if the SYSTICK interrupt is enabled or disabled. + * @rmtoll STK_CTRL TICKINT LL_SYSTICK_IsEnabledIT + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSTICK_IsEnabledIT(void) +{ + return (READ_BIT(SysTick->CTRL, SysTick_CTRL_TICKINT_Msk) == (SysTick_CTRL_TICKINT_Msk)); +} + +/** + * @} + */ + +/** @defgroup CORTEX_LL_EF_LOW_POWER_MODE LOW POWER MODE + * @{ + */ + +/** + * @brief Processor uses sleep as its low power mode + * @rmtoll SCB_SCR SLEEPDEEP LL_LPM_EnableSleep + * @retval None + */ +__STATIC_INLINE void LL_LPM_EnableSleep(void) +{ + /* Clear SLEEPDEEP bit of Cortex System Control Register */ + CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPDEEP_Msk)); +} + +/** + * @brief Processor uses deep sleep as its low power mode + * @rmtoll SCB_SCR SLEEPDEEP LL_LPM_EnableDeepSleep + * @retval None + */ +__STATIC_INLINE void LL_LPM_EnableDeepSleep(void) +{ + /* Set SLEEPDEEP bit of Cortex System Control Register */ + SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPDEEP_Msk)); +} + +/** + * @brief Configures sleep-on-exit when returning from Handler mode to Thread mode. + * @note Setting this bit to 1 enables an interrupt-driven application to avoid returning to an + * empty main application. + * @rmtoll SCB_SCR SLEEPONEXIT LL_LPM_EnableSleepOnExit + * @retval None + */ +__STATIC_INLINE void LL_LPM_EnableSleepOnExit(void) +{ + /* Set SLEEPONEXIT bit of Cortex System Control Register */ + SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPONEXIT_Msk)); +} + +/** + * @brief Do not sleep when returning to Thread mode. + * @rmtoll SCB_SCR SLEEPONEXIT LL_LPM_DisableSleepOnExit + * @retval None + */ +__STATIC_INLINE void LL_LPM_DisableSleepOnExit(void) +{ + /* Clear SLEEPONEXIT bit of Cortex System Control Register */ + CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPONEXIT_Msk)); +} + +/** + * @brief Enabled events and all interrupts, including disabled interrupts, can wakeup the + * processor. + * @rmtoll SCB_SCR SEVEONPEND LL_LPM_EnableEventOnPend + * @retval None + */ +__STATIC_INLINE void LL_LPM_EnableEventOnPend(void) +{ + /* Set SEVEONPEND bit of Cortex System Control Register */ + SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SEVONPEND_Msk)); +} + +/** + * @brief Only enabled interrupts or events can wakeup the processor, disabled interrupts are + * excluded + * @rmtoll SCB_SCR SEVEONPEND LL_LPM_DisableEventOnPend + * @retval None + */ +__STATIC_INLINE void LL_LPM_DisableEventOnPend(void) +{ + /* Clear SEVEONPEND bit of Cortex System Control Register */ + CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SEVONPEND_Msk)); +} + +/** + * @} + */ + +/** @defgroup CORTEX_LL_EF_MCU_INFO MCU INFO + * @{ + */ + +/** + * @brief Get Implementer code + * @rmtoll SCB_CPUID IMPLEMENTER LL_CPUID_GetImplementer + * @retval Value should be equal to 0x41 for ARM + */ +__STATIC_INLINE uint32_t LL_CPUID_GetImplementer(void) +{ + return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_IMPLEMENTER_Msk) >> SCB_CPUID_IMPLEMENTER_Pos); +} + +/** + * @brief Get Variant number (The r value in the rnpn product revision identifier) + * @rmtoll SCB_CPUID VARIANT LL_CPUID_GetVariant + * @retval Value between 0 and 255 (0x0: revision 0) + */ +__STATIC_INLINE uint32_t LL_CPUID_GetVariant(void) +{ + return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_VARIANT_Msk) >> SCB_CPUID_VARIANT_Pos); +} + +/** + * @brief Get Architecture number + * @rmtoll SCB_CPUID ARCHITECTURE LL_CPUID_GetArchitecture + * @retval Value should be equal to 0xC for Cortex-M0 devices + */ +__STATIC_INLINE uint32_t LL_CPUID_GetArchitecture(void) +{ + return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_ARCHITECTURE_Msk) >> SCB_CPUID_ARCHITECTURE_Pos); +} + +/** + * @brief Get Part number + * @rmtoll SCB_CPUID PARTNO LL_CPUID_GetParNo + * @retval Value should be equal to 0xC20 for Cortex-M0 + */ +__STATIC_INLINE uint32_t LL_CPUID_GetParNo(void) +{ + return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_PARTNO_Msk) >> SCB_CPUID_PARTNO_Pos); +} + +/** + * @brief Get Revision number (The p value in the rnpn product revision identifier, indicates patch release) + * @rmtoll SCB_CPUID REVISION LL_CPUID_GetRevision + * @retval Value between 0 and 255 (0x1: patch 1) + */ +__STATIC_INLINE uint32_t LL_CPUID_GetRevision(void) +{ + return (uint32_t)(READ_BIT(SCB->CPUID, SCB_CPUID_REVISION_Msk) >> SCB_CPUID_REVISION_Pos); +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_CORTEX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crc.h new file mode 100644 index 0000000..8b7e2da --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crc.h @@ -0,0 +1,474 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_crc.h + * @author MCD Application Team + * @brief Header file of CRC LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_LL_CRC_H +#define STM32F0xx_LL_CRC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(CRC) + +/** @defgroup CRC_LL CRC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup CRC_LL_Exported_Constants CRC Exported Constants + * @{ + */ + +#if defined(CRC_POL_POL) +/** @defgroup CRC_LL_EC_POLYLENGTH Polynomial length + * @{ + */ +#define LL_CRC_POLYLENGTH_32B 0x00000000U /*!< 32 bits Polynomial size */ +#define LL_CRC_POLYLENGTH_16B CRC_CR_POLYSIZE_0 /*!< 16 bits Polynomial size */ +#define LL_CRC_POLYLENGTH_8B CRC_CR_POLYSIZE_1 /*!< 8 bits Polynomial size */ +#define LL_CRC_POLYLENGTH_7B (CRC_CR_POLYSIZE_1 | CRC_CR_POLYSIZE_0) /*!< 7 bits Polynomial size */ +/** + * @} + */ +#endif /* CRC_POL_POL */ + +/** @defgroup CRC_LL_EC_INDATA_REVERSE Input Data Reverse + * @{ + */ +#define LL_CRC_INDATA_REVERSE_NONE 0x00000000U /*!< Input Data bit order not affected */ +#define LL_CRC_INDATA_REVERSE_BYTE CRC_CR_REV_IN_0 /*!< Input Data bit reversal done by byte */ +#define LL_CRC_INDATA_REVERSE_HALFWORD CRC_CR_REV_IN_1 /*!< Input Data bit reversal done by half-word */ +#define LL_CRC_INDATA_REVERSE_WORD (CRC_CR_REV_IN_1 | CRC_CR_REV_IN_0) /*!< Input Data bit reversal done by word */ +/** + * @} + */ + +/** @defgroup CRC_LL_EC_OUTDATA_REVERSE Output Data Reverse + * @{ + */ +#define LL_CRC_OUTDATA_REVERSE_NONE 0x00000000U /*!< Output Data bit order not affected */ +#define LL_CRC_OUTDATA_REVERSE_BIT CRC_CR_REV_OUT /*!< Output Data bit reversal done by bit */ +/** + * @} + */ + +#if defined(CRC_POL_POL) +/** @defgroup CRC_LL_EC_Default_Polynomial_Value Default CRC generating polynomial value + * @brief Normal representation of this polynomial value is + * X^32 + X^26 + X^23 + X^22 + X^16 + X^12 + X^11 + X^10 +X^8 + X^7 + X^5 + X^4 + X^2 + X + 1 . + * @{ + */ +#define LL_CRC_DEFAULT_CRC32_POLY 0x04C11DB7U /*!< Default CRC generating polynomial value */ +/** + * @} + */ +#endif /* CRC_POL_POL */ + +/** @defgroup CRC_LL_EC_Default_InitValue Default CRC computation initialization value + * @{ + */ +#define LL_CRC_DEFAULT_CRC_INITVALUE 0xFFFFFFFFU /*!< Default CRC computation initialization value */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup CRC_LL_Exported_Macros CRC Exported Macros + * @{ + */ + +/** @defgroup CRC_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in CRC register + * @param __INSTANCE__ CRC Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_CRC_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, __VALUE__) + +/** + * @brief Read a value in CRC register + * @param __INSTANCE__ CRC Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_CRC_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup CRC_LL_Exported_Functions CRC Exported Functions + * @{ + */ + +/** @defgroup CRC_LL_EF_Configuration CRC Configuration functions + * @{ + */ + +/** + * @brief Reset the CRC calculation unit. + * @note If Programmable Initial CRC value feature + * is available, also set the Data Register to the value stored in the + * CRC_INIT register, otherwise, reset Data Register to its default value. + * @rmtoll CR RESET LL_CRC_ResetCRCCalculationUnit + * @param CRCx CRC Instance + * @retval None + */ +__STATIC_INLINE void LL_CRC_ResetCRCCalculationUnit(CRC_TypeDef *CRCx) +{ + SET_BIT(CRCx->CR, CRC_CR_RESET); +} + +#if defined(CRC_POL_POL) +/** + * @brief Configure size of the polynomial. + * @rmtoll CR POLYSIZE LL_CRC_SetPolynomialSize + * @param CRCx CRC Instance + * @param PolySize This parameter can be one of the following values: + * @arg @ref LL_CRC_POLYLENGTH_32B + * @arg @ref LL_CRC_POLYLENGTH_16B + * @arg @ref LL_CRC_POLYLENGTH_8B + * @arg @ref LL_CRC_POLYLENGTH_7B + * @retval None + */ +__STATIC_INLINE void LL_CRC_SetPolynomialSize(CRC_TypeDef *CRCx, uint32_t PolySize) +{ + MODIFY_REG(CRCx->CR, CRC_CR_POLYSIZE, PolySize); +} + +/** + * @brief Return size of the polynomial. + * @rmtoll CR POLYSIZE LL_CRC_GetPolynomialSize + * @param CRCx CRC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_CRC_POLYLENGTH_32B + * @arg @ref LL_CRC_POLYLENGTH_16B + * @arg @ref LL_CRC_POLYLENGTH_8B + * @arg @ref LL_CRC_POLYLENGTH_7B + */ +__STATIC_INLINE uint32_t LL_CRC_GetPolynomialSize(CRC_TypeDef *CRCx) +{ + return (uint32_t)(READ_BIT(CRCx->CR, CRC_CR_POLYSIZE)); +} +#endif /* CRC_POL_POL */ + +/** + * @brief Configure the reversal of the bit order of the input data + * @rmtoll CR REV_IN LL_CRC_SetInputDataReverseMode + * @param CRCx CRC Instance + * @param ReverseMode This parameter can be one of the following values: + * @arg @ref LL_CRC_INDATA_REVERSE_NONE + * @arg @ref LL_CRC_INDATA_REVERSE_BYTE + * @arg @ref LL_CRC_INDATA_REVERSE_HALFWORD + * @arg @ref LL_CRC_INDATA_REVERSE_WORD + * @retval None + */ +__STATIC_INLINE void LL_CRC_SetInputDataReverseMode(CRC_TypeDef *CRCx, uint32_t ReverseMode) +{ + MODIFY_REG(CRCx->CR, CRC_CR_REV_IN, ReverseMode); +} + +/** + * @brief Return type of reversal for input data bit order + * @rmtoll CR REV_IN LL_CRC_GetInputDataReverseMode + * @param CRCx CRC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_CRC_INDATA_REVERSE_NONE + * @arg @ref LL_CRC_INDATA_REVERSE_BYTE + * @arg @ref LL_CRC_INDATA_REVERSE_HALFWORD + * @arg @ref LL_CRC_INDATA_REVERSE_WORD + */ +__STATIC_INLINE uint32_t LL_CRC_GetInputDataReverseMode(CRC_TypeDef *CRCx) +{ + return (uint32_t)(READ_BIT(CRCx->CR, CRC_CR_REV_IN)); +} + +/** + * @brief Configure the reversal of the bit order of the Output data + * @rmtoll CR REV_OUT LL_CRC_SetOutputDataReverseMode + * @param CRCx CRC Instance + * @param ReverseMode This parameter can be one of the following values: + * @arg @ref LL_CRC_OUTDATA_REVERSE_NONE + * @arg @ref LL_CRC_OUTDATA_REVERSE_BIT + * @retval None + */ +__STATIC_INLINE void LL_CRC_SetOutputDataReverseMode(CRC_TypeDef *CRCx, uint32_t ReverseMode) +{ + MODIFY_REG(CRCx->CR, CRC_CR_REV_OUT, ReverseMode); +} + +/** + * @brief Configure the reversal of the bit order of the Output data + * @rmtoll CR REV_OUT LL_CRC_GetOutputDataReverseMode + * @param CRCx CRC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_CRC_OUTDATA_REVERSE_NONE + * @arg @ref LL_CRC_OUTDATA_REVERSE_BIT + */ +__STATIC_INLINE uint32_t LL_CRC_GetOutputDataReverseMode(CRC_TypeDef *CRCx) +{ + return (uint32_t)(READ_BIT(CRCx->CR, CRC_CR_REV_OUT)); +} + +/** + * @brief Initialize the Programmable initial CRC value. + * @note If the CRC size is less than 32 bits, the least significant bits + * are used to write the correct value + * @note LL_CRC_DEFAULT_CRC_INITVALUE could be used as value for InitCrc parameter. + * @rmtoll INIT INIT LL_CRC_SetInitialData + * @param CRCx CRC Instance + * @param InitCrc Value to be programmed in Programmable initial CRC value register + * @retval None + */ +__STATIC_INLINE void LL_CRC_SetInitialData(CRC_TypeDef *CRCx, uint32_t InitCrc) +{ + WRITE_REG(CRCx->INIT, InitCrc); +} + +/** + * @brief Return current Initial CRC value. + * @note If the CRC size is less than 32 bits, the least significant bits + * are used to read the correct value + * @rmtoll INIT INIT LL_CRC_GetInitialData + * @param CRCx CRC Instance + * @retval Value programmed in Programmable initial CRC value register + */ +__STATIC_INLINE uint32_t LL_CRC_GetInitialData(CRC_TypeDef *CRCx) +{ + return (uint32_t)(READ_REG(CRCx->INIT)); +} + +#if defined(CRC_POL_POL) +/** + * @brief Initialize the Programmable polynomial value + * (coefficients of the polynomial to be used for CRC calculation). + * @note LL_CRC_DEFAULT_CRC32_POLY could be used as value for PolynomCoef parameter. + * @note Please check Reference Manual and existing Errata Sheets, + * regarding possible limitations for Polynomial values usage. + * For example, for a polynomial of degree 7, X^7 + X^6 + X^5 + X^2 + 1 is written 0x65 + * @rmtoll POL POL LL_CRC_SetPolynomialCoef + * @param CRCx CRC Instance + * @param PolynomCoef Value to be programmed in Programmable Polynomial value register + * @retval None + */ +__STATIC_INLINE void LL_CRC_SetPolynomialCoef(CRC_TypeDef *CRCx, uint32_t PolynomCoef) +{ + WRITE_REG(CRCx->POL, PolynomCoef); +} + +/** + * @brief Return current Programmable polynomial value + * @note Please check Reference Manual and existing Errata Sheets, + * regarding possible limitations for Polynomial values usage. + * For example, for a polynomial of degree 7, X^7 + X^6 + X^5 + X^2 + 1 is written 0x65 + * @rmtoll POL POL LL_CRC_GetPolynomialCoef + * @param CRCx CRC Instance + * @retval Value programmed in Programmable Polynomial value register + */ +__STATIC_INLINE uint32_t LL_CRC_GetPolynomialCoef(CRC_TypeDef *CRCx) +{ + return (uint32_t)(READ_REG(CRCx->POL)); +} +#endif /* CRC_POL_POL */ + +/** + * @} + */ + +/** @defgroup CRC_LL_EF_Data_Management Data_Management + * @{ + */ + +/** + * @brief Write given 32-bit data to the CRC calculator + * @rmtoll DR DR LL_CRC_FeedData32 + * @param CRCx CRC Instance + * @param InData value to be provided to CRC calculator between between Min_Data=0 and Max_Data=0xFFFFFFFF + * @retval None + */ +__STATIC_INLINE void LL_CRC_FeedData32(CRC_TypeDef *CRCx, uint32_t InData) +{ + WRITE_REG(CRCx->DR, InData); +} + +/** + * @brief Write given 16-bit data to the CRC calculator + * @rmtoll DR DR LL_CRC_FeedData16 + * @param CRCx CRC Instance + * @param InData 16 bit value to be provided to CRC calculator between between Min_Data=0 and Max_Data=0xFFFF + * @retval None + */ +__STATIC_INLINE void LL_CRC_FeedData16(CRC_TypeDef *CRCx, uint16_t InData) +{ + __IO uint16_t *pReg; + + pReg = (__IO uint16_t *)(__IO void *)(&CRCx->DR); /* Derogation MisraC2012 R.11.5 */ + *pReg = InData; +} + +/** + * @brief Write given 8-bit data to the CRC calculator + * @rmtoll DR DR LL_CRC_FeedData8 + * @param CRCx CRC Instance + * @param InData 8 bit value to be provided to CRC calculator between between Min_Data=0 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_CRC_FeedData8(CRC_TypeDef *CRCx, uint8_t InData) +{ + *(uint8_t __IO *)(&CRCx->DR) = (uint8_t) InData; +} + +/** + * @brief Return current CRC calculation result. 32 bits value is returned. + * @rmtoll DR DR LL_CRC_ReadData32 + * @param CRCx CRC Instance + * @retval Current CRC calculation result as stored in CRC_DR register (32 bits). + */ +__STATIC_INLINE uint32_t LL_CRC_ReadData32(CRC_TypeDef *CRCx) +{ + return (uint32_t)(READ_REG(CRCx->DR)); +} + +#if defined(CRC_POL_POL) +/** + * @brief Return current CRC calculation result. 16 bits value is returned. + * @note This function is expected to be used in a 16 bits CRC polynomial size context. + * @rmtoll DR DR LL_CRC_ReadData16 + * @param CRCx CRC Instance + * @retval Current CRC calculation result as stored in CRC_DR register (16 bits). + */ +__STATIC_INLINE uint16_t LL_CRC_ReadData16(CRC_TypeDef *CRCx) +{ + return (uint16_t)READ_REG(CRCx->DR); +} + +/** + * @brief Return current CRC calculation result. 8 bits value is returned. + * @note This function is expected to be used in a 8 bits CRC polynomial size context. + * @rmtoll DR DR LL_CRC_ReadData8 + * @param CRCx CRC Instance + * @retval Current CRC calculation result as stored in CRC_DR register (8 bits). + */ +__STATIC_INLINE uint8_t LL_CRC_ReadData8(CRC_TypeDef *CRCx) +{ + return (uint8_t)READ_REG(CRCx->DR); +} + +/** + * @brief Return current CRC calculation result. 7 bits value is returned. + * @note This function is expected to be used in a 7 bits CRC polynomial size context. + * @rmtoll DR DR LL_CRC_ReadData7 + * @param CRCx CRC Instance + * @retval Current CRC calculation result as stored in CRC_DR register (7 bits). + */ +__STATIC_INLINE uint8_t LL_CRC_ReadData7(CRC_TypeDef *CRCx) +{ + return (uint8_t)(READ_REG(CRCx->DR) & 0x7FU); +} +#endif /* CRC_POL_POL */ + +/** + * @brief Return data stored in the Independent Data(IDR) register. + * @note This register can be used as a temporary storage location for one byte. + * @rmtoll IDR IDR LL_CRC_Read_IDR + * @param CRCx CRC Instance + * @retval Value stored in CRC_IDR register (General-purpose 8-bit data register). + */ +__STATIC_INLINE uint32_t LL_CRC_Read_IDR(CRC_TypeDef *CRCx) +{ + return (uint32_t)(READ_REG(CRCx->IDR)); +} + +/** + * @brief Store data in the Independent Data(IDR) register. + * @note This register can be used as a temporary storage location for one byte. + * @rmtoll IDR IDR LL_CRC_Write_IDR + * @param CRCx CRC Instance + * @param InData value to be stored in CRC_IDR register (8-bit) between Min_Data=0 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_CRC_Write_IDR(CRC_TypeDef *CRCx, uint32_t InData) +{ + *((uint8_t __IO *)(&CRCx->IDR)) = (uint8_t) InData; +} +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup CRC_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_CRC_DeInit(CRC_TypeDef *CRCx); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(CRC) */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_LL_CRC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crs.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crs.h new file mode 100644 index 0000000..0781698 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_crs.h @@ -0,0 +1,783 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_crs.h + * @author MCD Application Team + * @brief Header file of CRS LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_CRS_H +#define __STM32F0xx_LL_CRS_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(CRS) + +/** @defgroup CRS_LL CRS + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup CRS_LL_Exported_Constants CRS Exported Constants + * @{ + */ + +/** @defgroup CRS_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_CRS_ReadReg function + * @{ + */ +#define LL_CRS_ISR_SYNCOKF CRS_ISR_SYNCOKF +#define LL_CRS_ISR_SYNCWARNF CRS_ISR_SYNCWARNF +#define LL_CRS_ISR_ERRF CRS_ISR_ERRF +#define LL_CRS_ISR_ESYNCF CRS_ISR_ESYNCF +#define LL_CRS_ISR_SYNCERR CRS_ISR_SYNCERR +#define LL_CRS_ISR_SYNCMISS CRS_ISR_SYNCMISS +#define LL_CRS_ISR_TRIMOVF CRS_ISR_TRIMOVF +/** + * @} + */ + +/** @defgroup CRS_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_CRS_ReadReg and LL_CRS_WriteReg functions + * @{ + */ +#define LL_CRS_CR_SYNCOKIE CRS_CR_SYNCOKIE +#define LL_CRS_CR_SYNCWARNIE CRS_CR_SYNCWARNIE +#define LL_CRS_CR_ERRIE CRS_CR_ERRIE +#define LL_CRS_CR_ESYNCIE CRS_CR_ESYNCIE +/** + * @} + */ + +/** @defgroup CRS_LL_EC_SYNC_DIV Synchronization Signal Divider + * @{ + */ +#define LL_CRS_SYNC_DIV_1 ((uint32_t)0x00U) /*!< Synchro Signal not divided (default) */ +#define LL_CRS_SYNC_DIV_2 CRS_CFGR_SYNCDIV_0 /*!< Synchro Signal divided by 2 */ +#define LL_CRS_SYNC_DIV_4 CRS_CFGR_SYNCDIV_1 /*!< Synchro Signal divided by 4 */ +#define LL_CRS_SYNC_DIV_8 (CRS_CFGR_SYNCDIV_1 | CRS_CFGR_SYNCDIV_0) /*!< Synchro Signal divided by 8 */ +#define LL_CRS_SYNC_DIV_16 CRS_CFGR_SYNCDIV_2 /*!< Synchro Signal divided by 16 */ +#define LL_CRS_SYNC_DIV_32 (CRS_CFGR_SYNCDIV_2 | CRS_CFGR_SYNCDIV_0) /*!< Synchro Signal divided by 32 */ +#define LL_CRS_SYNC_DIV_64 (CRS_CFGR_SYNCDIV_2 | CRS_CFGR_SYNCDIV_1) /*!< Synchro Signal divided by 64 */ +#define LL_CRS_SYNC_DIV_128 CRS_CFGR_SYNCDIV /*!< Synchro Signal divided by 128 */ +/** + * @} + */ + +/** @defgroup CRS_LL_EC_SYNC_SOURCE Synchronization Signal Source + * @{ + */ +#define LL_CRS_SYNC_SOURCE_GPIO ((uint32_t)0x00U) /*!< Synchro Signal soucre GPIO */ +#define LL_CRS_SYNC_SOURCE_LSE CRS_CFGR_SYNCSRC_0 /*!< Synchro Signal source LSE */ +#define LL_CRS_SYNC_SOURCE_USB CRS_CFGR_SYNCSRC_1 /*!< Synchro Signal source USB SOF (default)*/ +/** + * @} + */ + +/** @defgroup CRS_LL_EC_SYNC_POLARITY Synchronization Signal Polarity + * @{ + */ +#define LL_CRS_SYNC_POLARITY_RISING ((uint32_t)0x00U) /*!< Synchro Active on rising edge (default) */ +#define LL_CRS_SYNC_POLARITY_FALLING CRS_CFGR_SYNCPOL /*!< Synchro Active on falling edge */ +/** + * @} + */ + +/** @defgroup CRS_LL_EC_FREQERRORDIR Frequency Error Direction + * @{ + */ +#define LL_CRS_FREQ_ERROR_DIR_UP ((uint32_t)0x00U) /*!< Upcounting direction, the actual frequency is above the target */ +#define LL_CRS_FREQ_ERROR_DIR_DOWN ((uint32_t)CRS_ISR_FEDIR) /*!< Downcounting direction, the actual frequency is below the target */ +/** + * @} + */ + +/** @defgroup CRS_LL_EC_DEFAULTVALUES Default Values + * @{ + */ +/** + * @brief Reset value of the RELOAD field + * @note The reset value of the RELOAD field corresponds to a target frequency of 48 MHz + * and a synchronization signal frequency of 1 kHz (SOF signal from USB) + */ +#define LL_CRS_RELOADVALUE_DEFAULT ((uint32_t)0xBB7FU) + +/** + * @brief Reset value of Frequency error limit. + */ +#define LL_CRS_ERRORLIMIT_DEFAULT ((uint32_t)0x22U) + +/** + * @brief Reset value of the HSI48 Calibration field + * @note The default value is 32, which corresponds to the middle of the trimming interval. + * The trimming step is around 67 kHz between two consecutive TRIM steps. + * A higher TRIM value corresponds to a higher output frequency + */ +#define LL_CRS_HSI48CALIBRATION_DEFAULT ((uint32_t)0x20U) +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup CRS_LL_Exported_Macros CRS Exported Macros + * @{ + */ + +/** @defgroup CRS_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in CRS register + * @param __INSTANCE__ CRS Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_CRS_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in CRS register + * @param __INSTANCE__ CRS Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_CRS_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** @defgroup CRS_LL_EM_Exported_Macros_Calculate_Reload Exported_Macros_Calculate_Reload + * @{ + */ + +/** + * @brief Macro to calculate reload value to be set in CRS register according to target and sync frequencies + * @note The RELOAD value should be selected according to the ratio between + * the target frequency and the frequency of the synchronization source after + * prescaling. It is then decreased by one in order to reach the expected + * synchronization on the zero value. The formula is the following: + * RELOAD = (fTARGET / fSYNC) -1 + * @param __FTARGET__ Target frequency (value in Hz) + * @param __FSYNC__ Synchronization signal frequency (value in Hz) + * @retval Reload value (in Hz) + */ +#define __LL_CRS_CALC_CALCULATE_RELOADVALUE(__FTARGET__, __FSYNC__) (((__FTARGET__) / (__FSYNC__)) - 1U) + +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup CRS_LL_Exported_Functions CRS Exported Functions + * @{ + */ + +/** @defgroup CRS_LL_EF_Configuration Configuration + * @{ + */ + +/** + * @brief Enable Frequency error counter + * @note When this bit is set, the CRS_CFGR register is write-protected and cannot be modified + * @rmtoll CR CEN LL_CRS_EnableFreqErrorCounter + * @retval None + */ +__STATIC_INLINE void LL_CRS_EnableFreqErrorCounter(void) +{ + SET_BIT(CRS->CR, CRS_CR_CEN); +} + +/** + * @brief Disable Frequency error counter + * @rmtoll CR CEN LL_CRS_DisableFreqErrorCounter + * @retval None + */ +__STATIC_INLINE void LL_CRS_DisableFreqErrorCounter(void) +{ + CLEAR_BIT(CRS->CR, CRS_CR_CEN); +} + +/** + * @brief Check if Frequency error counter is enabled or not + * @rmtoll CR CEN LL_CRS_IsEnabledFreqErrorCounter + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsEnabledFreqErrorCounter(void) +{ + return (READ_BIT(CRS->CR, CRS_CR_CEN) == (CRS_CR_CEN)); +} + +/** + * @brief Enable Automatic trimming counter + * @rmtoll CR AUTOTRIMEN LL_CRS_EnableAutoTrimming + * @retval None + */ +__STATIC_INLINE void LL_CRS_EnableAutoTrimming(void) +{ + SET_BIT(CRS->CR, CRS_CR_AUTOTRIMEN); +} + +/** + * @brief Disable Automatic trimming counter + * @rmtoll CR AUTOTRIMEN LL_CRS_DisableAutoTrimming + * @retval None + */ +__STATIC_INLINE void LL_CRS_DisableAutoTrimming(void) +{ + CLEAR_BIT(CRS->CR, CRS_CR_AUTOTRIMEN); +} + +/** + * @brief Check if Automatic trimming is enabled or not + * @rmtoll CR AUTOTRIMEN LL_CRS_IsEnabledAutoTrimming + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsEnabledAutoTrimming(void) +{ + return (READ_BIT(CRS->CR, CRS_CR_AUTOTRIMEN) == (CRS_CR_AUTOTRIMEN)); +} + +/** + * @brief Set HSI48 oscillator smooth trimming + * @note When the AUTOTRIMEN bit is set, this field is controlled by hardware and is read-only + * @rmtoll CR TRIM LL_CRS_SetHSI48SmoothTrimming + * @param Value a number between Min_Data = 0 and Max_Data = 63 + * @note Default value can be set thanks to @ref LL_CRS_HSI48CALIBRATION_DEFAULT + * @retval None + */ +__STATIC_INLINE void LL_CRS_SetHSI48SmoothTrimming(uint32_t Value) +{ + MODIFY_REG(CRS->CR, CRS_CR_TRIM, Value << CRS_CR_TRIM_Pos); +} + +/** + * @brief Get HSI48 oscillator smooth trimming + * @rmtoll CR TRIM LL_CRS_GetHSI48SmoothTrimming + * @retval a number between Min_Data = 0 and Max_Data = 63 + */ +__STATIC_INLINE uint32_t LL_CRS_GetHSI48SmoothTrimming(void) +{ + return (uint32_t)(READ_BIT(CRS->CR, CRS_CR_TRIM) >> CRS_CR_TRIM_Pos); +} + +/** + * @brief Set counter reload value + * @rmtoll CFGR RELOAD LL_CRS_SetReloadCounter + * @param Value a number between Min_Data = 0 and Max_Data = 0xFFFF + * @note Default value can be set thanks to @ref LL_CRS_RELOADVALUE_DEFAULT + * Otherwise it can be calculated in using macro @ref __LL_CRS_CALC_CALCULATE_RELOADVALUE (_FTARGET_, _FSYNC_) + * @retval None + */ +__STATIC_INLINE void LL_CRS_SetReloadCounter(uint32_t Value) +{ + MODIFY_REG(CRS->CFGR, CRS_CFGR_RELOAD, Value); +} + +/** + * @brief Get counter reload value + * @rmtoll CFGR RELOAD LL_CRS_GetReloadCounter + * @retval a number between Min_Data = 0 and Max_Data = 0xFFFF + */ +__STATIC_INLINE uint32_t LL_CRS_GetReloadCounter(void) +{ + return (uint32_t)(READ_BIT(CRS->CFGR, CRS_CFGR_RELOAD)); +} + +/** + * @brief Set frequency error limit + * @rmtoll CFGR FELIM LL_CRS_SetFreqErrorLimit + * @param Value a number between Min_Data = 0 and Max_Data = 255 + * @note Default value can be set thanks to @ref LL_CRS_ERRORLIMIT_DEFAULT + * @retval None + */ +__STATIC_INLINE void LL_CRS_SetFreqErrorLimit(uint32_t Value) +{ + MODIFY_REG(CRS->CFGR, CRS_CFGR_FELIM, Value << CRS_CFGR_FELIM_Pos); +} + +/** + * @brief Get frequency error limit + * @rmtoll CFGR FELIM LL_CRS_GetFreqErrorLimit + * @retval A number between Min_Data = 0 and Max_Data = 255 + */ +__STATIC_INLINE uint32_t LL_CRS_GetFreqErrorLimit(void) +{ + return (uint32_t)(READ_BIT(CRS->CFGR, CRS_CFGR_FELIM) >> CRS_CFGR_FELIM_Pos); +} + +/** + * @brief Set division factor for SYNC signal + * @rmtoll CFGR SYNCDIV LL_CRS_SetSyncDivider + * @param Divider This parameter can be one of the following values: + * @arg @ref LL_CRS_SYNC_DIV_1 + * @arg @ref LL_CRS_SYNC_DIV_2 + * @arg @ref LL_CRS_SYNC_DIV_4 + * @arg @ref LL_CRS_SYNC_DIV_8 + * @arg @ref LL_CRS_SYNC_DIV_16 + * @arg @ref LL_CRS_SYNC_DIV_32 + * @arg @ref LL_CRS_SYNC_DIV_64 + * @arg @ref LL_CRS_SYNC_DIV_128 + * @retval None + */ +__STATIC_INLINE void LL_CRS_SetSyncDivider(uint32_t Divider) +{ + MODIFY_REG(CRS->CFGR, CRS_CFGR_SYNCDIV, Divider); +} + +/** + * @brief Get division factor for SYNC signal + * @rmtoll CFGR SYNCDIV LL_CRS_GetSyncDivider + * @retval Returned value can be one of the following values: + * @arg @ref LL_CRS_SYNC_DIV_1 + * @arg @ref LL_CRS_SYNC_DIV_2 + * @arg @ref LL_CRS_SYNC_DIV_4 + * @arg @ref LL_CRS_SYNC_DIV_8 + * @arg @ref LL_CRS_SYNC_DIV_16 + * @arg @ref LL_CRS_SYNC_DIV_32 + * @arg @ref LL_CRS_SYNC_DIV_64 + * @arg @ref LL_CRS_SYNC_DIV_128 + */ +__STATIC_INLINE uint32_t LL_CRS_GetSyncDivider(void) +{ + return (uint32_t)(READ_BIT(CRS->CFGR, CRS_CFGR_SYNCDIV)); +} + +/** + * @brief Set SYNC signal source + * @rmtoll CFGR SYNCSRC LL_CRS_SetSyncSignalSource + * @param Source This parameter can be one of the following values: + * @arg @ref LL_CRS_SYNC_SOURCE_GPIO + * @arg @ref LL_CRS_SYNC_SOURCE_LSE + * @arg @ref LL_CRS_SYNC_SOURCE_USB + * @retval None + */ +__STATIC_INLINE void LL_CRS_SetSyncSignalSource(uint32_t Source) +{ + MODIFY_REG(CRS->CFGR, CRS_CFGR_SYNCSRC, Source); +} + +/** + * @brief Get SYNC signal source + * @rmtoll CFGR SYNCSRC LL_CRS_GetSyncSignalSource + * @retval Returned value can be one of the following values: + * @arg @ref LL_CRS_SYNC_SOURCE_GPIO + * @arg @ref LL_CRS_SYNC_SOURCE_LSE + * @arg @ref LL_CRS_SYNC_SOURCE_USB + */ +__STATIC_INLINE uint32_t LL_CRS_GetSyncSignalSource(void) +{ + return (uint32_t)(READ_BIT(CRS->CFGR, CRS_CFGR_SYNCSRC)); +} + +/** + * @brief Set input polarity for the SYNC signal source + * @rmtoll CFGR SYNCPOL LL_CRS_SetSyncPolarity + * @param Polarity This parameter can be one of the following values: + * @arg @ref LL_CRS_SYNC_POLARITY_RISING + * @arg @ref LL_CRS_SYNC_POLARITY_FALLING + * @retval None + */ +__STATIC_INLINE void LL_CRS_SetSyncPolarity(uint32_t Polarity) +{ + MODIFY_REG(CRS->CFGR, CRS_CFGR_SYNCPOL, Polarity); +} + +/** + * @brief Get input polarity for the SYNC signal source + * @rmtoll CFGR SYNCPOL LL_CRS_GetSyncPolarity + * @retval Returned value can be one of the following values: + * @arg @ref LL_CRS_SYNC_POLARITY_RISING + * @arg @ref LL_CRS_SYNC_POLARITY_FALLING + */ +__STATIC_INLINE uint32_t LL_CRS_GetSyncPolarity(void) +{ + return (uint32_t)(READ_BIT(CRS->CFGR, CRS_CFGR_SYNCPOL)); +} + +/** + * @brief Configure CRS for the synchronization + * @rmtoll CR TRIM LL_CRS_ConfigSynchronization\n + * CFGR RELOAD LL_CRS_ConfigSynchronization\n + * CFGR FELIM LL_CRS_ConfigSynchronization\n + * CFGR SYNCDIV LL_CRS_ConfigSynchronization\n + * CFGR SYNCSRC LL_CRS_ConfigSynchronization\n + * CFGR SYNCPOL LL_CRS_ConfigSynchronization + * @param HSI48CalibrationValue a number between Min_Data = 0 and Max_Data = 63 + * @param ErrorLimitValue a number between Min_Data = 0 and Max_Data = 0xFFFF + * @param ReloadValue a number between Min_Data = 0 and Max_Data = 255 + * @param Settings This parameter can be a combination of the following values: + * @arg @ref LL_CRS_SYNC_DIV_1 or @ref LL_CRS_SYNC_DIV_2 or @ref LL_CRS_SYNC_DIV_4 or @ref LL_CRS_SYNC_DIV_8 + * or @ref LL_CRS_SYNC_DIV_16 or @ref LL_CRS_SYNC_DIV_32 or @ref LL_CRS_SYNC_DIV_64 or @ref LL_CRS_SYNC_DIV_128 + * @arg @ref LL_CRS_SYNC_SOURCE_GPIO or @ref LL_CRS_SYNC_SOURCE_LSE or @ref LL_CRS_SYNC_SOURCE_USB + * @arg @ref LL_CRS_SYNC_POLARITY_RISING or @ref LL_CRS_SYNC_POLARITY_FALLING + * @retval None + */ +__STATIC_INLINE void LL_CRS_ConfigSynchronization(uint32_t HSI48CalibrationValue, uint32_t ErrorLimitValue, uint32_t ReloadValue, uint32_t Settings) +{ + MODIFY_REG(CRS->CR, CRS_CR_TRIM, HSI48CalibrationValue << CRS_CR_TRIM_Pos); + MODIFY_REG(CRS->CFGR, + CRS_CFGR_RELOAD | CRS_CFGR_FELIM | CRS_CFGR_SYNCDIV | CRS_CFGR_SYNCSRC | CRS_CFGR_SYNCPOL, + ReloadValue | (ErrorLimitValue << CRS_CFGR_FELIM_Pos) | Settings); +} + +/** + * @} + */ + +/** @defgroup CRS_LL_EF_CRS_Management CRS_Management + * @{ + */ + +/** + * @brief Generate software SYNC event + * @rmtoll CR SWSYNC LL_CRS_GenerateEvent_SWSYNC + * @retval None + */ +__STATIC_INLINE void LL_CRS_GenerateEvent_SWSYNC(void) +{ + SET_BIT(CRS->CR, CRS_CR_SWSYNC); +} + +/** + * @brief Get the frequency error direction latched in the time of the last + * SYNC event + * @rmtoll ISR FEDIR LL_CRS_GetFreqErrorDirection + * @retval Returned value can be one of the following values: + * @arg @ref LL_CRS_FREQ_ERROR_DIR_UP + * @arg @ref LL_CRS_FREQ_ERROR_DIR_DOWN + */ +__STATIC_INLINE uint32_t LL_CRS_GetFreqErrorDirection(void) +{ + return (uint32_t)(READ_BIT(CRS->ISR, CRS_ISR_FEDIR)); +} + +/** + * @brief Get the frequency error counter value latched in the time of the last SYNC event + * @rmtoll ISR FECAP LL_CRS_GetFreqErrorCapture + * @retval A number between Min_Data = 0x0000 and Max_Data = 0xFFFF + */ +__STATIC_INLINE uint32_t LL_CRS_GetFreqErrorCapture(void) +{ + return (uint32_t)(READ_BIT(CRS->ISR, CRS_ISR_FECAP) >> CRS_ISR_FECAP_Pos); +} + +/** + * @} + */ + +/** @defgroup CRS_LL_EF_FLAG_Management FLAG_Management + * @{ + */ + +/** + * @brief Check if SYNC event OK signal occurred or not + * @rmtoll ISR SYNCOKF LL_CRS_IsActiveFlag_SYNCOK + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsActiveFlag_SYNCOK(void) +{ + return (READ_BIT(CRS->ISR, CRS_ISR_SYNCOKF) == (CRS_ISR_SYNCOKF)); +} + +/** + * @brief Check if SYNC warning signal occurred or not + * @rmtoll ISR SYNCWARNF LL_CRS_IsActiveFlag_SYNCWARN + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsActiveFlag_SYNCWARN(void) +{ + return (READ_BIT(CRS->ISR, CRS_ISR_SYNCWARNF) == (CRS_ISR_SYNCWARNF)); +} + +/** + * @brief Check if Synchronization or trimming error signal occurred or not + * @rmtoll ISR ERRF LL_CRS_IsActiveFlag_ERR + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsActiveFlag_ERR(void) +{ + return (READ_BIT(CRS->ISR, CRS_ISR_ERRF) == (CRS_ISR_ERRF)); +} + +/** + * @brief Check if Expected SYNC signal occurred or not + * @rmtoll ISR ESYNCF LL_CRS_IsActiveFlag_ESYNC + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsActiveFlag_ESYNC(void) +{ + return (READ_BIT(CRS->ISR, CRS_ISR_ESYNCF) == (CRS_ISR_ESYNCF)); +} + +/** + * @brief Check if SYNC error signal occurred or not + * @rmtoll ISR SYNCERR LL_CRS_IsActiveFlag_SYNCERR + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsActiveFlag_SYNCERR(void) +{ + return (READ_BIT(CRS->ISR, CRS_ISR_SYNCERR) == (CRS_ISR_SYNCERR)); +} + +/** + * @brief Check if SYNC missed error signal occurred or not + * @rmtoll ISR SYNCMISS LL_CRS_IsActiveFlag_SYNCMISS + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsActiveFlag_SYNCMISS(void) +{ + return (READ_BIT(CRS->ISR, CRS_ISR_SYNCMISS) == (CRS_ISR_SYNCMISS)); +} + +/** + * @brief Check if Trimming overflow or underflow occurred or not + * @rmtoll ISR TRIMOVF LL_CRS_IsActiveFlag_TRIMOVF + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsActiveFlag_TRIMOVF(void) +{ + return (READ_BIT(CRS->ISR, CRS_ISR_TRIMOVF) == (CRS_ISR_TRIMOVF)); +} + +/** + * @brief Clear the SYNC event OK flag + * @rmtoll ICR SYNCOKC LL_CRS_ClearFlag_SYNCOK + * @retval None + */ +__STATIC_INLINE void LL_CRS_ClearFlag_SYNCOK(void) +{ + WRITE_REG(CRS->ICR, CRS_ICR_SYNCOKC); +} + +/** + * @brief Clear the SYNC warning flag + * @rmtoll ICR SYNCWARNC LL_CRS_ClearFlag_SYNCWARN + * @retval None + */ +__STATIC_INLINE void LL_CRS_ClearFlag_SYNCWARN(void) +{ + WRITE_REG(CRS->ICR, CRS_ICR_SYNCWARNC); +} + +/** + * @brief Clear TRIMOVF, SYNCMISS and SYNCERR bits and consequently also + * the ERR flag + * @rmtoll ICR ERRC LL_CRS_ClearFlag_ERR + * @retval None + */ +__STATIC_INLINE void LL_CRS_ClearFlag_ERR(void) +{ + WRITE_REG(CRS->ICR, CRS_ICR_ERRC); +} + +/** + * @brief Clear Expected SYNC flag + * @rmtoll ICR ESYNCC LL_CRS_ClearFlag_ESYNC + * @retval None + */ +__STATIC_INLINE void LL_CRS_ClearFlag_ESYNC(void) +{ + WRITE_REG(CRS->ICR, CRS_ICR_ESYNCC); +} + +/** + * @} + */ + +/** @defgroup CRS_LL_EF_IT_Management IT_Management + * @{ + */ + +/** + * @brief Enable SYNC event OK interrupt + * @rmtoll CR SYNCOKIE LL_CRS_EnableIT_SYNCOK + * @retval None + */ +__STATIC_INLINE void LL_CRS_EnableIT_SYNCOK(void) +{ + SET_BIT(CRS->CR, CRS_CR_SYNCOKIE); +} + +/** + * @brief Disable SYNC event OK interrupt + * @rmtoll CR SYNCOKIE LL_CRS_DisableIT_SYNCOK + * @retval None + */ +__STATIC_INLINE void LL_CRS_DisableIT_SYNCOK(void) +{ + CLEAR_BIT(CRS->CR, CRS_CR_SYNCOKIE); +} + +/** + * @brief Check if SYNC event OK interrupt is enabled or not + * @rmtoll CR SYNCOKIE LL_CRS_IsEnabledIT_SYNCOK + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsEnabledIT_SYNCOK(void) +{ + return (READ_BIT(CRS->CR, CRS_CR_SYNCOKIE) == (CRS_CR_SYNCOKIE)); +} + +/** + * @brief Enable SYNC warning interrupt + * @rmtoll CR SYNCWARNIE LL_CRS_EnableIT_SYNCWARN + * @retval None + */ +__STATIC_INLINE void LL_CRS_EnableIT_SYNCWARN(void) +{ + SET_BIT(CRS->CR, CRS_CR_SYNCWARNIE); +} + +/** + * @brief Disable SYNC warning interrupt + * @rmtoll CR SYNCWARNIE LL_CRS_DisableIT_SYNCWARN + * @retval None + */ +__STATIC_INLINE void LL_CRS_DisableIT_SYNCWARN(void) +{ + CLEAR_BIT(CRS->CR, CRS_CR_SYNCWARNIE); +} + +/** + * @brief Check if SYNC warning interrupt is enabled or not + * @rmtoll CR SYNCWARNIE LL_CRS_IsEnabledIT_SYNCWARN + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsEnabledIT_SYNCWARN(void) +{ + return (READ_BIT(CRS->CR, CRS_CR_SYNCWARNIE) == (CRS_CR_SYNCWARNIE)); +} + +/** + * @brief Enable Synchronization or trimming error interrupt + * @rmtoll CR ERRIE LL_CRS_EnableIT_ERR + * @retval None + */ +__STATIC_INLINE void LL_CRS_EnableIT_ERR(void) +{ + SET_BIT(CRS->CR, CRS_CR_ERRIE); +} + +/** + * @brief Disable Synchronization or trimming error interrupt + * @rmtoll CR ERRIE LL_CRS_DisableIT_ERR + * @retval None + */ +__STATIC_INLINE void LL_CRS_DisableIT_ERR(void) +{ + CLEAR_BIT(CRS->CR, CRS_CR_ERRIE); +} + +/** + * @brief Check if Synchronization or trimming error interrupt is enabled or not + * @rmtoll CR ERRIE LL_CRS_IsEnabledIT_ERR + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsEnabledIT_ERR(void) +{ + return (READ_BIT(CRS->CR, CRS_CR_ERRIE) == (CRS_CR_ERRIE)); +} + +/** + * @brief Enable Expected SYNC interrupt + * @rmtoll CR ESYNCIE LL_CRS_EnableIT_ESYNC + * @retval None + */ +__STATIC_INLINE void LL_CRS_EnableIT_ESYNC(void) +{ + SET_BIT(CRS->CR, CRS_CR_ESYNCIE); +} + +/** + * @brief Disable Expected SYNC interrupt + * @rmtoll CR ESYNCIE LL_CRS_DisableIT_ESYNC + * @retval None + */ +__STATIC_INLINE void LL_CRS_DisableIT_ESYNC(void) +{ + CLEAR_BIT(CRS->CR, CRS_CR_ESYNCIE); +} + +/** + * @brief Check if Expected SYNC interrupt is enabled or not + * @rmtoll CR ESYNCIE LL_CRS_IsEnabledIT_ESYNC + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_CRS_IsEnabledIT_ESYNC(void) +{ + return (READ_BIT(CRS->CR, CRS_CR_ESYNCIE) == (CRS_CR_ESYNCIE)); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup CRS_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_CRS_DeInit(void); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(CRS) */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_CRS_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dac.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dac.h new file mode 100644 index 0000000..7ec899f --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dac.h @@ -0,0 +1,1422 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_dac.h + * @author MCD Application Team + * @brief Header file of DAC LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_DAC_H +#define __STM32F0xx_LL_DAC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (DAC1) + +/** @defgroup DAC_LL DAC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup DAC_LL_Private_Constants DAC Private Constants + * @{ + */ + +/* Internal masks for DAC channels definition */ +/* To select into literal LL_DAC_CHANNEL_x the relevant bits for: */ +/* - channel bits position into register CR */ +/* - channel bits position into register SWTRIG */ +/* - channel register offset of data holding register DHRx */ +/* - channel register offset of data output register DORx */ +#define DAC_CR_CH1_BITOFFSET 0U /* Position of channel bits into registers CR, MCR, CCR, SHHR, SHRR of channel 1 */ +#define DAC_CR_CH2_BITOFFSET 16U /* Position of channel bits into registers CR, MCR, CCR, SHHR, SHRR of channel 2 */ +#define DAC_CR_CHX_BITOFFSET_MASK (DAC_CR_CH1_BITOFFSET | DAC_CR_CH2_BITOFFSET) + +#define DAC_SWTR_CH1 (DAC_SWTRIGR_SWTRIG1) /* Channel bit into register SWTRIGR of channel 1. This bit is into area of LL_DAC_CR_CHx_BITOFFSET but excluded by mask DAC_CR_CHX_BITOFFSET_MASK (done to be enable to trig SW start of both DAC channels simultaneously). */ +#if defined(DAC_CHANNEL2_SUPPORT) +#define DAC_SWTR_CH2 (DAC_SWTRIGR_SWTRIG2) /* Channel bit into register SWTRIGR of channel 2. This bit is into area of LL_DAC_CR_CHx_BITOFFSET but excluded by mask DAC_CR_CHX_BITOFFSET_MASK (done to be enable to trig SW start of both DAC channels simultaneously). */ +#define DAC_SWTR_CHX_MASK (DAC_SWTR_CH1 | DAC_SWTR_CH2) +#else +#define DAC_SWTR_CHX_MASK (DAC_SWTR_CH1) +#endif /* DAC_CHANNEL2_SUPPORT */ + +#define DAC_REG_DHR12R1_REGOFFSET 0x00000000U /* Register DHR12Rx channel 1 taken as reference */ +#define DAC_REG_DHR12L1_REGOFFSET 0x00100000U /* Register offset of DHR12Lx channel 1 versus DHR12Rx channel 1 (shifted left of 20 bits) */ +#define DAC_REG_DHR8R1_REGOFFSET 0x02000000U /* Register offset of DHR8Rx channel 1 versus DHR12Rx channel 1 (shifted left of 24 bits) */ +#if defined(DAC_CHANNEL2_SUPPORT) +#define DAC_REG_DHR12R2_REGOFFSET 0x00030000U /* Register offset of DHR12Rx channel 2 versus DHR12Rx channel 1 (shifted left of 16 bits) */ +#define DAC_REG_DHR12L2_REGOFFSET 0x00400000U /* Register offset of DHR12Lx channel 2 versus DHR12Rx channel 1 (shifted left of 20 bits) */ +#define DAC_REG_DHR8R2_REGOFFSET 0x05000000U /* Register offset of DHR8Rx channel 2 versus DHR12Rx channel 1 (shifted left of 24 bits) */ +#endif /* DAC_CHANNEL2_SUPPORT */ +#define DAC_REG_DHR12RX_REGOFFSET_MASK 0x000F0000U +#define DAC_REG_DHR12LX_REGOFFSET_MASK 0x00F00000U +#define DAC_REG_DHR8RX_REGOFFSET_MASK 0x0F000000U +#define DAC_REG_DHRX_REGOFFSET_MASK (DAC_REG_DHR12RX_REGOFFSET_MASK | DAC_REG_DHR12LX_REGOFFSET_MASK | DAC_REG_DHR8RX_REGOFFSET_MASK) + +#define DAC_REG_DOR1_REGOFFSET 0x00000000U /* Register DORx channel 1 taken as reference */ +#if defined(DAC_CHANNEL2_SUPPORT) +#define DAC_REG_DOR2_REGOFFSET 0x10000000U /* Register offset of DORx channel 1 versus DORx channel 2 (shifted left of 28 bits) */ +#define DAC_REG_DORX_REGOFFSET_MASK (DAC_REG_DOR1_REGOFFSET | DAC_REG_DOR2_REGOFFSET) +#else +#define DAC_REG_DORX_REGOFFSET_MASK (DAC_REG_DOR1_REGOFFSET) +#endif /* DAC_CHANNEL2_SUPPORT */ + +#define DAC_REG_REGOFFSET_MASK_POSBIT0 0x0000000FU /* Mask of registers offset (DHR12Rx, DHR12Lx, DHR8Rx, DORx, ...) when shifted to position 0 */ + +#define DAC_REG_DHR12RX_REGOFFSET_BITOFFSET_POS 16U /* Position of bits register offset of DHR12Rx channel 1 or 2 versus DHR12Rx channel 1 (shifted left of 16 bits) */ +#define DAC_REG_DHR12LX_REGOFFSET_BITOFFSET_POS 20U /* Position of bits register offset of DHR12Lx channel 1 or 2 versus DHR12Rx channel 1 (shifted left of 20 bits) */ +#define DAC_REG_DHR8RX_REGOFFSET_BITOFFSET_POS 24U /* Position of bits register offset of DHR8Rx channel 1 or 2 versus DHR12Rx channel 1 (shifted left of 24 bits) */ +#define DAC_REG_DORX_REGOFFSET_BITOFFSET_POS 28U /* Position of bits register offset of DORx channel 1 or 2 versus DORx channel 1 (shifted left of 28 bits) */ + +/* DAC registers bits positions */ +#if defined(DAC_CHANNEL2_SUPPORT) +#define DAC_DHR12RD_DACC2DHR_BITOFFSET_POS 16U /* Value equivalent to POSITION_VAL(DAC_DHR12RD_DACC2DHR) */ +#define DAC_DHR12LD_DACC2DHR_BITOFFSET_POS 20U /* Value equivalent to POSITION_VAL(DAC_DHR12LD_DACC2DHR) */ +#define DAC_DHR8RD_DACC2DHR_BITOFFSET_POS 8U /* Value equivalent to POSITION_VAL(DAC_DHR8RD_DACC2DHR) */ +#endif /* DAC_CHANNEL2_SUPPORT */ + +/* Miscellaneous data */ +#define DAC_DIGITAL_SCALE_12BITS 4095U /* Full-scale digital value with a resolution of 12 bits (voltage range determined by analog voltage references Vref+ and Vref-, refer to reference manual) */ + +/** + * @} + */ + + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup DAC_LL_Private_Macros DAC Private Macros + * @{ + */ + +/** + * @brief Driver macro reserved for internal use: set a pointer to + * a register from a register basis from which an offset + * is applied. + * @param __REG__ Register basis from which the offset is applied. + * @param __REG_OFFFSET__ Offset to be applied (unit: number of registers). + * @retval Pointer to register address +*/ +#define __DAC_PTR_REG_OFFSET(__REG__, __REG_OFFFSET__) \ + ((uint32_t *)((uint32_t) ((uint32_t)(&(__REG__)) + ((__REG_OFFFSET__) << 2U)))) + +/** + * @} + */ + + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup DAC_LL_ES_INIT DAC Exported Init structure + * @{ + */ + +/** + * @brief Structure definition of some features of DAC instance. + */ +typedef struct +{ + uint32_t TriggerSource; /*!< Set the conversion trigger source for the selected DAC channel: internal (SW start) or from external IP (timer event, external interrupt line). + This parameter can be a value of @ref DAC_LL_EC_TRIGGER_SOURCE + + This feature can be modified afterwards using unitary function @ref LL_DAC_SetTriggerSource(). */ + +#if defined(DAC_CR_WAVE1) + uint32_t WaveAutoGeneration; /*!< Set the waveform automatic generation mode for the selected DAC channel. + This parameter can be a value of @ref DAC_LL_EC_WAVE_AUTO_GENERATION_MODE + + This feature can be modified afterwards using unitary function @ref LL_DAC_SetWaveAutoGeneration(). */ + + uint32_t WaveAutoGenerationConfig; /*!< Set the waveform automatic generation mode for the selected DAC channel. + If waveform automatic generation mode is set to noise, this parameter can be a value of @ref DAC_LL_EC_WAVE_NOISE_LFSR_UNMASK_BITS + If waveform automatic generation mode is set to triangle, this parameter can be a value of @ref DAC_LL_EC_WAVE_TRIANGLE_AMPLITUDE + @note If waveform automatic generation mode is disabled, this parameter is discarded. + + This feature can be modified afterwards using unitary function @ref LL_DAC_SetWaveNoiseLFSR() or @ref LL_DAC_SetWaveTriangleAmplitude(), depending on the wave automatic generation selected. */ +#endif + + uint32_t OutputBuffer; /*!< Set the output buffer for the selected DAC channel. + This parameter can be a value of @ref DAC_LL_EC_OUTPUT_BUFFER + + This feature can be modified afterwards using unitary function @ref LL_DAC_SetOutputBuffer(). */ + +} LL_DAC_InitTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup DAC_LL_Exported_Constants DAC Exported Constants + * @{ + */ + +/** @defgroup DAC_LL_EC_GET_FLAG DAC flags + * @brief Flags defines which can be used with LL_DAC_ReadReg function + * @{ + */ +/* DAC channel 1 flags */ +#define LL_DAC_FLAG_DMAUDR1 (DAC_SR_DMAUDR1) /*!< DAC channel 1 flag DMA underrun */ + +#if defined(DAC_CHANNEL2_SUPPORT) +/* DAC channel 2 flags */ +#define LL_DAC_FLAG_DMAUDR2 (DAC_SR_DMAUDR2) /*!< DAC channel 2 flag DMA underrun */ +#endif /* DAC_CHANNEL2_SUPPORT */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_IT DAC interruptions + * @brief IT defines which can be used with LL_DAC_ReadReg and LL_DAC_WriteReg functions + * @{ + */ +#define LL_DAC_IT_DMAUDRIE1 (DAC_CR_DMAUDRIE1) /*!< DAC channel 1 interruption DMA underrun */ +#if defined(DAC_CHANNEL2_SUPPORT) +#define LL_DAC_IT_DMAUDRIE2 (DAC_CR_DMAUDRIE2) /*!< DAC channel 2 interruption DMA underrun */ +#endif /* DAC_CHANNEL2_SUPPORT */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_CHANNEL DAC channels + * @{ + */ +#define LL_DAC_CHANNEL_1 (DAC_REG_DOR1_REGOFFSET | DAC_REG_DHR12R1_REGOFFSET | DAC_REG_DHR12L1_REGOFFSET | DAC_REG_DHR8R1_REGOFFSET | DAC_CR_CH1_BITOFFSET | DAC_SWTR_CH1) /*!< DAC channel 1 */ +#if defined(DAC_CHANNEL2_SUPPORT) +#define LL_DAC_CHANNEL_2 (DAC_REG_DOR2_REGOFFSET | DAC_REG_DHR12R2_REGOFFSET | DAC_REG_DHR12L2_REGOFFSET | DAC_REG_DHR8R2_REGOFFSET | DAC_CR_CH2_BITOFFSET | DAC_SWTR_CH2) /*!< DAC channel 2 */ +#endif /* DAC_CHANNEL2_SUPPORT */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_TRIGGER_SOURCE DAC trigger source + * @{ + */ +#define LL_DAC_TRIG_SOFTWARE (DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0) /*!< DAC channel conversion trigger internal (SW start) */ +#define LL_DAC_TRIG_EXT_TIM2_TRGO (DAC_CR_TSEL1_2 ) /*!< DAC channel conversion trigger from external IP: TIM2 TRGO. */ +#define LL_DAC_TRIG_EXT_TIM3_TRGO ( DAC_CR_TSEL1_0) /*!< DAC channel conversion trigger from external IP: TIM3 TRGO. */ +#define LL_DAC_TRIG_EXT_TIM4_TRGO (DAC_CR_TSEL1_2 | DAC_CR_TSEL1_0) /*!< DAC channel conversion trigger from external IP: TIM4 TRGO. */ +#define LL_DAC_TRIG_EXT_TIM6_TRGO 0x00000000U /*!< DAC channel conversion trigger from external IP: TIM6 TRGO. */ +#define LL_DAC_TRIG_EXT_TIM7_TRGO ( DAC_CR_TSEL1_1 ) /*!< DAC channel conversion trigger from external IP: TIM7 TRGO. */ +#define LL_DAC_TRIG_EXT_TIM15_TRGO ( DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0) /*!< DAC channel conversion trigger from external IP: TIM15 TRGO. */ +#define LL_DAC_TRIG_EXT_EXTI_LINE9 (DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 ) /*!< DAC channel conversion trigger from external IP: external interrupt line 9. */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_WAVE_AUTO_GENERATION_MODE DAC waveform automatic generation mode + * @{ + */ +#define LL_DAC_WAVE_AUTO_GENERATION_NONE 0x00000000U /*!< DAC channel wave auto generation mode disabled. */ +#define LL_DAC_WAVE_AUTO_GENERATION_NOISE (DAC_CR_WAVE1_0) /*!< DAC channel wave auto generation mode enabled, set generated noise waveform. */ +#define LL_DAC_WAVE_AUTO_GENERATION_TRIANGLE (DAC_CR_WAVE1_1) /*!< DAC channel wave auto generation mode enabled, set generated triangle waveform. */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_WAVE_NOISE_LFSR_UNMASK_BITS DAC wave generation - Noise LFSR unmask bits + * @{ + */ +#define LL_DAC_NOISE_LFSR_UNMASK_BIT0 0x00000000U /*!< Noise wave generation, unmask LFSR bit0, for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS1_0 ( DAC_CR_MAMP1_0) /*!< Noise wave generation, unmask LFSR bits[1:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS2_0 ( DAC_CR_MAMP1_1 ) /*!< Noise wave generation, unmask LFSR bits[2:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS3_0 ( DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Noise wave generation, unmask LFSR bits[3:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS4_0 ( DAC_CR_MAMP1_2 ) /*!< Noise wave generation, unmask LFSR bits[4:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS5_0 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_0) /*!< Noise wave generation, unmask LFSR bits[5:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS6_0 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 ) /*!< Noise wave generation, unmask LFSR bits[6:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS7_0 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Noise wave generation, unmask LFSR bits[7:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS8_0 (DAC_CR_MAMP1_3 ) /*!< Noise wave generation, unmask LFSR bits[8:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS9_0 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_0) /*!< Noise wave generation, unmask LFSR bits[9:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS10_0 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 ) /*!< Noise wave generation, unmask LFSR bits[10:0], for the selected DAC channel */ +#define LL_DAC_NOISE_LFSR_UNMASK_BITS11_0 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Noise wave generation, unmask LFSR bits[11:0], for the selected DAC channel */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_WAVE_TRIANGLE_AMPLITUDE DAC wave generation - Triangle amplitude + * @{ + */ +#define LL_DAC_TRIANGLE_AMPLITUDE_1 0x00000000U /*!< Triangle wave generation, amplitude of 1 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_3 ( DAC_CR_MAMP1_0) /*!< Triangle wave generation, amplitude of 3 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_7 ( DAC_CR_MAMP1_1 ) /*!< Triangle wave generation, amplitude of 7 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_15 ( DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Triangle wave generation, amplitude of 15 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_31 ( DAC_CR_MAMP1_2 ) /*!< Triangle wave generation, amplitude of 31 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_63 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_0) /*!< Triangle wave generation, amplitude of 63 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_127 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 ) /*!< Triangle wave generation, amplitude of 127 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_255 ( DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Triangle wave generation, amplitude of 255 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_511 (DAC_CR_MAMP1_3 ) /*!< Triangle wave generation, amplitude of 512 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_1023 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_0) /*!< Triangle wave generation, amplitude of 1023 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_2047 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 ) /*!< Triangle wave generation, amplitude of 2047 LSB of DAC output range, for the selected DAC channel */ +#define LL_DAC_TRIANGLE_AMPLITUDE_4095 (DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Triangle wave generation, amplitude of 4095 LSB of DAC output range, for the selected DAC channel */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_OUTPUT_BUFFER DAC channel output buffer + * @{ + */ +#define LL_DAC_OUTPUT_BUFFER_ENABLE 0x00000000U /*!< The selected DAC channel output is buffered: higher drive current capability, but also higher current consumption */ +#define LL_DAC_OUTPUT_BUFFER_DISABLE (DAC_CR_BOFF1) /*!< The selected DAC channel output is not buffered: lower drive current capability, but also lower current consumption */ +/** + * @} + */ + + +/** @defgroup DAC_LL_EC_RESOLUTION DAC channel output resolution + * @{ + */ +#define LL_DAC_RESOLUTION_12B 0x00000000U /*!< DAC channel resolution 12 bits */ +#define LL_DAC_RESOLUTION_8B 0x00000002U /*!< DAC channel resolution 8 bits */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_REGISTERS DAC registers compliant with specific purpose + * @{ + */ +/* List of DAC registers intended to be used (most commonly) with */ +/* DMA transfer. */ +/* Refer to function @ref LL_DAC_DMA_GetRegAddr(). */ +#define LL_DAC_DMA_REG_DATA_12BITS_RIGHT_ALIGNED DAC_REG_DHR12RX_REGOFFSET_BITOFFSET_POS /*!< DAC channel data holding register 12 bits right aligned */ +#define LL_DAC_DMA_REG_DATA_12BITS_LEFT_ALIGNED DAC_REG_DHR12LX_REGOFFSET_BITOFFSET_POS /*!< DAC channel data holding register 12 bits left aligned */ +#define LL_DAC_DMA_REG_DATA_8BITS_RIGHT_ALIGNED DAC_REG_DHR8RX_REGOFFSET_BITOFFSET_POS /*!< DAC channel data holding register 8 bits right aligned */ +/** + * @} + */ + +/** @defgroup DAC_LL_EC_HW_DELAYS Definitions of DAC hardware constraints delays + * @note Only DAC IP HW delays are defined in DAC LL driver driver, + * not timeout values. + * For details on delays values, refer to descriptions in source code + * above each literal definition. + * @{ + */ + +/* Delay for DAC channel voltage settling time from DAC channel startup */ +/* (transition from disable to enable). */ +/* Note: DAC channel startup time depends on board application environment: */ +/* impedance connected to DAC channel output. */ +/* The delay below is specified under conditions: */ +/* - voltage maximum transition (lowest to highest value) */ +/* - until voltage reaches final value +-1LSB */ +/* - DAC channel output buffer enabled */ +/* - load impedance of 5kOhm (min), 50pF (max) */ +/* Literal set to maximum value (refer to device datasheet, */ +/* parameter "tWAKEUP"). */ +/* Unit: us */ +#define LL_DAC_DELAY_STARTUP_VOLTAGE_SETTLING_US 15U /*!< Delay for DAC channel voltage settling time from DAC channel startup (transition from disable to enable) */ + +/* Delay for DAC channel voltage settling time. */ +/* Note: DAC channel startup time depends on board application environment: */ +/* impedance connected to DAC channel output. */ +/* The delay below is specified under conditions: */ +/* - voltage maximum transition (lowest to highest value) */ +/* - until voltage reaches final value +-1LSB */ +/* - DAC channel output buffer enabled */ +/* - load impedance of 5kOhm min, 50pF max */ +/* Literal set to maximum value (refer to device datasheet, */ +/* parameter "tSETTLING"). */ +/* Unit: us */ +#define LL_DAC_DELAY_VOLTAGE_SETTLING_US 12U /*!< Delay for DAC channel voltage settling time */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup DAC_LL_Exported_Macros DAC Exported Macros + * @{ + */ + +/** @defgroup DAC_LL_EM_WRITE_READ Common write and read registers macros + * @{ + */ + +/** + * @brief Write a value in DAC register + * @param __INSTANCE__ DAC Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_DAC_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in DAC register + * @param __INSTANCE__ DAC Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_DAC_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) + +/** + * @} + */ + +/** @defgroup DAC_LL_EM_HELPER_MACRO DAC helper macro + * @{ + */ + +/** + * @brief Helper macro to get DAC channel number in decimal format + * from literals LL_DAC_CHANNEL_x. + * Example: + * __LL_DAC_CHANNEL_TO_DECIMAL_NB(LL_DAC_CHANNEL_1) + * will return decimal number "1". + * @note The input can be a value from functions where a channel + * number is returned. + * @param __CHANNEL__ This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval 1...2 (value "2" depending on DAC channel 2 availability) + */ +#define __LL_DAC_CHANNEL_TO_DECIMAL_NB(__CHANNEL__) \ + ((__CHANNEL__) & DAC_SWTR_CHX_MASK) + +/** + * @brief Helper macro to get DAC channel in literal format LL_DAC_CHANNEL_x + * from number in decimal format. + * Example: + * __LL_DAC_DECIMAL_NB_TO_CHANNEL(1) + * will return a data equivalent to "LL_DAC_CHANNEL_1". + * @note If the input parameter does not correspond to a DAC channel, + * this macro returns value '0'. + * @param __DECIMAL_NB__ 1...2 (value "2" depending on DAC channel 2 availability) + * @retval Returned value can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + */ +#if defined(DAC_CHANNEL2_SUPPORT) +#define __LL_DAC_DECIMAL_NB_TO_CHANNEL(__DECIMAL_NB__) \ + (((__DECIMAL_NB__) == 1U) \ + ? ( \ + LL_DAC_CHANNEL_1 \ + ) \ + : \ + (((__DECIMAL_NB__) == 2U) \ + ? ( \ + LL_DAC_CHANNEL_2 \ + ) \ + : \ + ( \ + 0 \ + ) \ + ) \ + ) +#else +#define __LL_DAC_DECIMAL_NB_TO_CHANNEL(__DECIMAL_NB__) \ + (((__DECIMAL_NB__) == 1U) \ + ? ( \ + LL_DAC_CHANNEL_1 \ + ) \ + : \ + ( \ + 0 \ + ) \ + ) +#endif /* DAC_CHANNEL2_SUPPORT */ + +/** + * @brief Helper macro to define the DAC conversion data full-scale digital + * value corresponding to the selected DAC resolution. + * @note DAC conversion data full-scale corresponds to voltage range + * determined by analog voltage references Vref+ and Vref- + * (refer to reference manual). + * @param __DAC_RESOLUTION__ This parameter can be one of the following values: + * @arg @ref LL_DAC_RESOLUTION_12B + * @arg @ref LL_DAC_RESOLUTION_8B + * @retval ADC conversion data equivalent voltage value (unit: mVolt) + */ +#define __LL_DAC_DIGITAL_SCALE(__DAC_RESOLUTION__) \ + ((0x00000FFFU) >> ((__DAC_RESOLUTION__) << 1U)) + +/** + * @brief Helper macro to calculate the DAC conversion data (unit: digital + * value) corresponding to a voltage (unit: mVolt). + * @note This helper macro is intended to provide input data in voltage + * rather than digital value, + * to be used with LL DAC functions such as + * @ref LL_DAC_ConvertData12RightAligned(). + * @note Analog reference voltage (Vref+) must be either known from + * user board environment or can be calculated using ADC measurement + * and ADC helper macro @ref __LL_ADC_CALC_VREFANALOG_VOLTAGE(). + * @param __VREFANALOG_VOLTAGE__ Analog reference voltage (unit: mV) + * @param __DAC_VOLTAGE__ Voltage to be generated by DAC channel + * (unit: mVolt). + * @param __DAC_RESOLUTION__ This parameter can be one of the following values: + * @arg @ref LL_DAC_RESOLUTION_12B + * @arg @ref LL_DAC_RESOLUTION_8B + * @retval DAC conversion data (unit: digital value) + */ +#define __LL_DAC_CALC_VOLTAGE_TO_DATA(__VREFANALOG_VOLTAGE__,\ + __DAC_VOLTAGE__,\ + __DAC_RESOLUTION__) \ + ((__DAC_VOLTAGE__) * __LL_DAC_DIGITAL_SCALE(__DAC_RESOLUTION__) \ + / (__VREFANALOG_VOLTAGE__) \ + ) + +/** + * @} + */ + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup DAC_LL_Exported_Functions DAC Exported Functions + * @{ + */ +/** @defgroup DAC_LL_EF_Configuration Configuration of DAC channels + * @{ + */ + +/** + * @brief Set the conversion trigger source for the selected DAC channel. + * @note For conversion trigger source to be effective, DAC trigger + * must be enabled using function @ref LL_DAC_EnableTrigger(). + * @note To set conversion trigger source, DAC channel must be disabled. + * Otherwise, the setting is discarded. + * @note Availability of parameters of trigger sources from timer + * depends on timers availability on the selected device. + * @rmtoll CR TSEL1 LL_DAC_SetTriggerSource\n + * CR TSEL2 LL_DAC_SetTriggerSource + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param TriggerSource This parameter can be one of the following values: + * @arg @ref LL_DAC_TRIG_SOFTWARE + * @arg @ref LL_DAC_TRIG_EXT_TIM2_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM3_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM4_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM6_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM7_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM15_TRGO + * @arg @ref LL_DAC_TRIG_EXT_EXTI_LINE9 + * @retval None + */ +__STATIC_INLINE void LL_DAC_SetTriggerSource(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t TriggerSource) +{ + MODIFY_REG(DACx->CR, + DAC_CR_TSEL1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK), + TriggerSource << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Get the conversion trigger source for the selected DAC channel. + * @note For conversion trigger source to be effective, DAC trigger + * must be enabled using function @ref LL_DAC_EnableTrigger(). + * @note Availability of parameters of trigger sources from timer + * depends on timers availability on the selected device. + * @rmtoll CR TSEL1 LL_DAC_GetTriggerSource\n + * CR TSEL2 LL_DAC_GetTriggerSource + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval Returned value can be one of the following values: + * @arg @ref LL_DAC_TRIG_SOFTWARE + * @arg @ref LL_DAC_TRIG_EXT_TIM2_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM3_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM4_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM6_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM7_TRGO + * @arg @ref LL_DAC_TRIG_EXT_TIM15_TRGO + * @arg @ref LL_DAC_TRIG_EXT_EXTI_LINE9 + */ +__STATIC_INLINE uint32_t LL_DAC_GetTriggerSource(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (uint32_t)(READ_BIT(DACx->CR, DAC_CR_TSEL1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + >> (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + ); +} + +#if defined(DAC_CR_WAVE1) +/** + * @brief Set the waveform automatic generation mode + * for the selected DAC channel. + * @rmtoll CR WAVE1 LL_DAC_SetWaveAutoGeneration\n + * CR WAVE2 LL_DAC_SetWaveAutoGeneration + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param WaveAutoGeneration This parameter can be one of the following values: + * @arg @ref LL_DAC_WAVE_AUTO_GENERATION_NONE + * @arg @ref LL_DAC_WAVE_AUTO_GENERATION_NOISE + * @arg @ref LL_DAC_WAVE_AUTO_GENERATION_TRIANGLE + * @retval None + */ +__STATIC_INLINE void LL_DAC_SetWaveAutoGeneration(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t WaveAutoGeneration) +{ + MODIFY_REG(DACx->CR, + DAC_CR_WAVE1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK), + WaveAutoGeneration << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Get the waveform automatic generation mode + * for the selected DAC channel. + * @rmtoll CR WAVE1 LL_DAC_GetWaveAutoGeneration\n + * CR WAVE2 LL_DAC_GetWaveAutoGeneration + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval Returned value can be one of the following values: + * @arg @ref LL_DAC_WAVE_AUTO_GENERATION_NONE + * @arg @ref LL_DAC_WAVE_AUTO_GENERATION_NOISE + * @arg @ref LL_DAC_WAVE_AUTO_GENERATION_TRIANGLE + */ +__STATIC_INLINE uint32_t LL_DAC_GetWaveAutoGeneration(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (uint32_t)(READ_BIT(DACx->CR, DAC_CR_WAVE1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + >> (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + ); +} + +/** + * @brief Set the noise waveform generation for the selected DAC channel: + * Noise mode and parameters LFSR (linear feedback shift register). + * @note For wave generation to be effective, DAC channel + * wave generation mode must be enabled using + * function @ref LL_DAC_SetWaveAutoGeneration(). + * @note This setting can be set when the selected DAC channel is disabled + * (otherwise, the setting operation is ignored). + * @rmtoll CR MAMP1 LL_DAC_SetWaveNoiseLFSR\n + * CR MAMP2 LL_DAC_SetWaveNoiseLFSR + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param NoiseLFSRMask This parameter can be one of the following values: + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BIT0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS1_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS2_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS3_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS4_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS5_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS6_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS7_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS8_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS9_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS10_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS11_0 + * @retval None + */ +__STATIC_INLINE void LL_DAC_SetWaveNoiseLFSR(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t NoiseLFSRMask) +{ + MODIFY_REG(DACx->CR, + DAC_CR_MAMP1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK), + NoiseLFSRMask << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Set the noise waveform generation for the selected DAC channel: + * Noise mode and parameters LFSR (linear feedback shift register). + * @rmtoll CR MAMP1 LL_DAC_GetWaveNoiseLFSR\n + * CR MAMP2 LL_DAC_GetWaveNoiseLFSR + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval Returned value can be one of the following values: + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BIT0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS1_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS2_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS3_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS4_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS5_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS6_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS7_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS8_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS9_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS10_0 + * @arg @ref LL_DAC_NOISE_LFSR_UNMASK_BITS11_0 + */ +__STATIC_INLINE uint32_t LL_DAC_GetWaveNoiseLFSR(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (uint32_t)(READ_BIT(DACx->CR, DAC_CR_MAMP1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + >> (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + ); +} + +/** + * @brief Set the triangle waveform generation for the selected DAC channel: + * triangle mode and amplitude. + * @note For wave generation to be effective, DAC channel + * wave generation mode must be enabled using + * function @ref LL_DAC_SetWaveAutoGeneration(). + * @note This setting can be set when the selected DAC channel is disabled + * (otherwise, the setting operation is ignored). + * @rmtoll CR MAMP1 LL_DAC_SetWaveTriangleAmplitude\n + * CR MAMP2 LL_DAC_SetWaveTriangleAmplitude + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param TriangleAmplitude This parameter can be one of the following values: + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_1 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_3 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_7 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_15 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_31 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_63 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_127 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_255 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_511 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_1023 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_2047 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_4095 + * @retval None + */ +__STATIC_INLINE void LL_DAC_SetWaveTriangleAmplitude(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t TriangleAmplitude) +{ + MODIFY_REG(DACx->CR, + DAC_CR_MAMP1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK), + TriangleAmplitude << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Set the triangle waveform generation for the selected DAC channel: + * triangle mode and amplitude. + * @rmtoll CR MAMP1 LL_DAC_GetWaveTriangleAmplitude\n + * CR MAMP2 LL_DAC_GetWaveTriangleAmplitude + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval Returned value can be one of the following values: + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_1 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_3 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_7 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_15 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_31 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_63 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_127 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_255 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_511 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_1023 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_2047 + * @arg @ref LL_DAC_TRIANGLE_AMPLITUDE_4095 + */ +__STATIC_INLINE uint32_t LL_DAC_GetWaveTriangleAmplitude(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (uint32_t)(READ_BIT(DACx->CR, DAC_CR_MAMP1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + >> (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + ); +} +#endif + +/** + * @brief Set the output buffer for the selected DAC channel. + * @rmtoll CR BOFF1 LL_DAC_SetOutputBuffer\n + * CR BOFF2 LL_DAC_SetOutputBuffer + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param OutputBuffer This parameter can be one of the following values: + * @arg @ref LL_DAC_OUTPUT_BUFFER_ENABLE + * @arg @ref LL_DAC_OUTPUT_BUFFER_DISABLE + * @retval None + */ +__STATIC_INLINE void LL_DAC_SetOutputBuffer(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t OutputBuffer) +{ + MODIFY_REG(DACx->CR, + DAC_CR_BOFF1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK), + OutputBuffer << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Get the output buffer state for the selected DAC channel. + * @rmtoll CR BOFF1 LL_DAC_GetOutputBuffer\n + * CR BOFF2 LL_DAC_GetOutputBuffer + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval Returned value can be one of the following values: + * @arg @ref LL_DAC_OUTPUT_BUFFER_ENABLE + * @arg @ref LL_DAC_OUTPUT_BUFFER_DISABLE + */ +__STATIC_INLINE uint32_t LL_DAC_GetOutputBuffer(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (uint32_t)(READ_BIT(DACx->CR, DAC_CR_BOFF1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + >> (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + ); +} + +/** + * @} + */ + +/** @defgroup DAC_LL_EF_DMA_Management DMA Management + * @{ + */ + +/** + * @brief Enable DAC DMA transfer request of the selected channel. + * @note To configure DMA source address (peripheral address), + * use function @ref LL_DAC_DMA_GetRegAddr(). + * @rmtoll CR DMAEN1 LL_DAC_EnableDMAReq\n + * CR DMAEN2 LL_DAC_EnableDMAReq + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval None + */ +__STATIC_INLINE void LL_DAC_EnableDMAReq(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + SET_BIT(DACx->CR, + DAC_CR_DMAEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Disable DAC DMA transfer request of the selected channel. + * @note To configure DMA source address (peripheral address), + * use function @ref LL_DAC_DMA_GetRegAddr(). + * @rmtoll CR DMAEN1 LL_DAC_DisableDMAReq\n + * CR DMAEN2 LL_DAC_DisableDMAReq + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval None + */ +__STATIC_INLINE void LL_DAC_DisableDMAReq(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + CLEAR_BIT(DACx->CR, + DAC_CR_DMAEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Get DAC DMA transfer request state of the selected channel. + * (0: DAC DMA transfer request is disabled, 1: DAC DMA transfer request is enabled) + * @rmtoll CR DMAEN1 LL_DAC_IsDMAReqEnabled\n + * CR DMAEN2 LL_DAC_IsDMAReqEnabled + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DAC_IsDMAReqEnabled(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (READ_BIT(DACx->CR, + DAC_CR_DMAEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + == (DAC_CR_DMAEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK))); +} + +/** + * @brief Function to help to configure DMA transfer to DAC: retrieve the + * DAC register address from DAC instance and a list of DAC registers + * intended to be used (most commonly) with DMA transfer. + * @note These DAC registers are data holding registers: + * when DAC conversion is requested, DAC generates a DMA transfer + * request to have data available in DAC data holding registers. + * @note This macro is intended to be used with LL DMA driver, refer to + * function "LL_DMA_ConfigAddresses()". + * Example: + * LL_DMA_ConfigAddresses(DMA1, + * LL_DMA_CHANNEL_1, + * (uint32_t)&< array or variable >, + * LL_DAC_DMA_GetRegAddr(DAC1, LL_DAC_CHANNEL_1, LL_DAC_DMA_REG_DATA_12BITS_RIGHT_ALIGNED), + * LL_DMA_DIRECTION_MEMORY_TO_PERIPH); + * @rmtoll DHR12R1 DACC1DHR LL_DAC_DMA_GetRegAddr\n + * DHR12L1 DACC1DHR LL_DAC_DMA_GetRegAddr\n + * DHR8R1 DACC1DHR LL_DAC_DMA_GetRegAddr\n + * DHR12R2 DACC2DHR LL_DAC_DMA_GetRegAddr\n + * DHR12L2 DACC2DHR LL_DAC_DMA_GetRegAddr\n + * DHR8R2 DACC2DHR LL_DAC_DMA_GetRegAddr + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param Register This parameter can be one of the following values: + * @arg @ref LL_DAC_DMA_REG_DATA_12BITS_RIGHT_ALIGNED + * @arg @ref LL_DAC_DMA_REG_DATA_12BITS_LEFT_ALIGNED + * @arg @ref LL_DAC_DMA_REG_DATA_8BITS_RIGHT_ALIGNED + * @retval DAC register address + */ +__STATIC_INLINE uint32_t LL_DAC_DMA_GetRegAddr(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t Register) +{ + /* Retrieve address of register DHR12Rx, DHR12Lx or DHR8Rx depending on */ + /* DAC channel selected. */ + return ((uint32_t)(__DAC_PTR_REG_OFFSET((DACx)->DHR12R1, ((DAC_Channel >> Register) & DAC_REG_REGOFFSET_MASK_POSBIT0)))); +} +/** + * @} + */ + +/** @defgroup DAC_LL_EF_Operation Operation on DAC channels + * @{ + */ + +/** + * @brief Enable DAC selected channel. + * @rmtoll CR EN1 LL_DAC_Enable\n + * CR EN2 LL_DAC_Enable + * @note After enable from off state, DAC channel requires a delay + * for output voltage to reach accuracy +/- 1 LSB. + * Refer to device datasheet, parameter "tWAKEUP". + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval None + */ +__STATIC_INLINE void LL_DAC_Enable(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + SET_BIT(DACx->CR, + DAC_CR_EN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Disable DAC selected channel. + * @rmtoll CR EN1 LL_DAC_Disable\n + * CR EN2 LL_DAC_Disable + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval None + */ +__STATIC_INLINE void LL_DAC_Disable(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + CLEAR_BIT(DACx->CR, + DAC_CR_EN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Get DAC enable state of the selected channel. + * (0: DAC channel is disabled, 1: DAC channel is enabled) + * @rmtoll CR EN1 LL_DAC_IsEnabled\n + * CR EN2 LL_DAC_IsEnabled + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DAC_IsEnabled(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (READ_BIT(DACx->CR, + DAC_CR_EN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + == (DAC_CR_EN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK))); +} + +/** + * @brief Enable DAC trigger of the selected channel. + * @note - If DAC trigger is disabled, DAC conversion is performed + * automatically once the data holding register is updated, + * using functions "LL_DAC_ConvertData{8; 12}{Right; Left} Aligned()": + * @ref LL_DAC_ConvertData12RightAligned(), ... + * - If DAC trigger is enabled, DAC conversion is performed + * only when a hardware of software trigger event is occurring. + * Select trigger source using + * function @ref LL_DAC_SetTriggerSource(). + * @rmtoll CR TEN1 LL_DAC_EnableTrigger\n + * CR TEN2 LL_DAC_EnableTrigger + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval None + */ +__STATIC_INLINE void LL_DAC_EnableTrigger(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + SET_BIT(DACx->CR, + DAC_CR_TEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Disable DAC trigger of the selected channel. + * @rmtoll CR TEN1 LL_DAC_DisableTrigger\n + * CR TEN2 LL_DAC_DisableTrigger + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval None + */ +__STATIC_INLINE void LL_DAC_DisableTrigger(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + CLEAR_BIT(DACx->CR, + DAC_CR_TEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)); +} + +/** + * @brief Get DAC trigger state of the selected channel. + * (0: DAC trigger is disabled, 1: DAC trigger is enabled) + * @rmtoll CR TEN1 LL_DAC_IsTriggerEnabled\n + * CR TEN2 LL_DAC_IsTriggerEnabled + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DAC_IsTriggerEnabled(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + return (READ_BIT(DACx->CR, + DAC_CR_TEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK)) + == (DAC_CR_TEN1 << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK))); +} + +/** + * @brief Trig DAC conversion by software for the selected DAC channel. + * @note Preliminarily, DAC trigger must be set to software trigger + * using function @ref LL_DAC_SetTriggerSource() + * with parameter "LL_DAC_TRIGGER_SOFTWARE". + * and DAC trigger must be enabled using + * function @ref LL_DAC_EnableTrigger(). + * @note For devices featuring DAC with 2 channels: this function + * can perform a SW start of both DAC channels simultaneously. + * Two channels can be selected as parameter. + * Example: (LL_DAC_CHANNEL_1 | LL_DAC_CHANNEL_2) + * @rmtoll SWTRIGR SWTRIG1 LL_DAC_TrigSWConversion\n + * SWTRIGR SWTRIG2 LL_DAC_TrigSWConversion + * @param DACx DAC instance + * @param DAC_Channel This parameter can a combination of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval None + */ +__STATIC_INLINE void LL_DAC_TrigSWConversion(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + SET_BIT(DACx->SWTRIGR, + (DAC_Channel & DAC_SWTR_CHX_MASK)); +} + +/** + * @brief Set the data to be loaded in the data holding register + * in format 12 bits left alignment (LSB aligned on bit 0), + * for the selected DAC channel. + * @rmtoll DHR12R1 DACC1DHR LL_DAC_ConvertData12RightAligned\n + * DHR12R2 DACC2DHR LL_DAC_ConvertData12RightAligned + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param Data Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval None + */ +__STATIC_INLINE void LL_DAC_ConvertData12RightAligned(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t Data) +{ + __IO uint32_t *preg = __DAC_PTR_REG_OFFSET(DACx->DHR12R1, (DAC_Channel >> DAC_REG_DHR12RX_REGOFFSET_BITOFFSET_POS) & DAC_REG_REGOFFSET_MASK_POSBIT0); + + MODIFY_REG(*preg, + DAC_DHR12R1_DACC1DHR, + Data); +} + +/** + * @brief Set the data to be loaded in the data holding register + * in format 12 bits left alignment (MSB aligned on bit 15), + * for the selected DAC channel. + * @rmtoll DHR12L1 DACC1DHR LL_DAC_ConvertData12LeftAligned\n + * DHR12L2 DACC2DHR LL_DAC_ConvertData12LeftAligned + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param Data Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval None + */ +__STATIC_INLINE void LL_DAC_ConvertData12LeftAligned(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t Data) +{ + __IO uint32_t *preg = __DAC_PTR_REG_OFFSET(DACx->DHR12R1, (DAC_Channel >> DAC_REG_DHR12LX_REGOFFSET_BITOFFSET_POS) & DAC_REG_REGOFFSET_MASK_POSBIT0); + + MODIFY_REG(*preg, + DAC_DHR12L1_DACC1DHR, + Data); +} + +/** + * @brief Set the data to be loaded in the data holding register + * in format 8 bits left alignment (LSB aligned on bit 0), + * for the selected DAC channel. + * @rmtoll DHR8R1 DACC1DHR LL_DAC_ConvertData8RightAligned\n + * DHR8R2 DACC2DHR LL_DAC_ConvertData8RightAligned + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param Data Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_DAC_ConvertData8RightAligned(DAC_TypeDef *DACx, uint32_t DAC_Channel, uint32_t Data) +{ + __IO uint32_t *preg = __DAC_PTR_REG_OFFSET(DACx->DHR12R1, (DAC_Channel >> DAC_REG_DHR8RX_REGOFFSET_BITOFFSET_POS) & DAC_REG_REGOFFSET_MASK_POSBIT0); + + MODIFY_REG(*preg, + DAC_DHR8R1_DACC1DHR, + Data); +} + +#if defined(DAC_CHANNEL2_SUPPORT) +/** + * @brief Set the data to be loaded in the data holding register + * in format 12 bits left alignment (LSB aligned on bit 0), + * for both DAC channels. + * @rmtoll DHR12RD DACC1DHR LL_DAC_ConvertDualData12RightAligned\n + * DHR12RD DACC2DHR LL_DAC_ConvertDualData12RightAligned + * @param DACx DAC instance + * @param DataChannel1 Value between Min_Data=0x000 and Max_Data=0xFFF + * @param DataChannel2 Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval None + */ +__STATIC_INLINE void LL_DAC_ConvertDualData12RightAligned(DAC_TypeDef *DACx, uint32_t DataChannel1, uint32_t DataChannel2) +{ + MODIFY_REG(DACx->DHR12RD, + (DAC_DHR12RD_DACC2DHR | DAC_DHR12RD_DACC1DHR), + ((DataChannel2 << DAC_DHR12RD_DACC2DHR_BITOFFSET_POS) | DataChannel1)); +} + +/** + * @brief Set the data to be loaded in the data holding register + * in format 12 bits left alignment (MSB aligned on bit 15), + * for both DAC channels. + * @rmtoll DHR12LD DACC1DHR LL_DAC_ConvertDualData12LeftAligned\n + * DHR12LD DACC2DHR LL_DAC_ConvertDualData12LeftAligned + * @param DACx DAC instance + * @param DataChannel1 Value between Min_Data=0x000 and Max_Data=0xFFF + * @param DataChannel2 Value between Min_Data=0x000 and Max_Data=0xFFF + * @retval None + */ +__STATIC_INLINE void LL_DAC_ConvertDualData12LeftAligned(DAC_TypeDef *DACx, uint32_t DataChannel1, uint32_t DataChannel2) +{ + /* Note: Data of DAC channel 2 shift value subtracted of 4 because */ + /* data on 16 bits and DAC channel 2 bits field is on the 12 MSB, */ + /* the 4 LSB must be taken into account for the shift value. */ + MODIFY_REG(DACx->DHR12LD, + (DAC_DHR12LD_DACC2DHR | DAC_DHR12LD_DACC1DHR), + ((DataChannel2 << (DAC_DHR12LD_DACC2DHR_BITOFFSET_POS - 4U)) | DataChannel1)); +} + +/** + * @brief Set the data to be loaded in the data holding register + * in format 8 bits left alignment (LSB aligned on bit 0), + * for both DAC channels. + * @rmtoll DHR8RD DACC1DHR LL_DAC_ConvertDualData8RightAligned\n + * DHR8RD DACC2DHR LL_DAC_ConvertDualData8RightAligned + * @param DACx DAC instance + * @param DataChannel1 Value between Min_Data=0x00 and Max_Data=0xFF + * @param DataChannel2 Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_DAC_ConvertDualData8RightAligned(DAC_TypeDef *DACx, uint32_t DataChannel1, uint32_t DataChannel2) +{ + MODIFY_REG(DACx->DHR8RD, + (DAC_DHR8RD_DACC2DHR | DAC_DHR8RD_DACC1DHR), + ((DataChannel2 << DAC_DHR8RD_DACC2DHR_BITOFFSET_POS) | DataChannel1)); +} + +#endif /* DAC_CHANNEL2_SUPPORT */ +/** + * @brief Retrieve output data currently generated for the selected DAC channel. + * @note Whatever alignment and resolution settings + * (using functions "LL_DAC_ConvertData{8; 12}{Right; Left} Aligned()": + * @ref LL_DAC_ConvertData12RightAligned(), ...), + * output data format is 12 bits right aligned (LSB aligned on bit 0). + * @rmtoll DOR1 DACC1DOR LL_DAC_RetrieveOutputData\n + * DOR2 DACC2DOR LL_DAC_RetrieveOutputData + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @retval Value between Min_Data=0x000 and Max_Data=0xFFF + */ +__STATIC_INLINE uint32_t LL_DAC_RetrieveOutputData(DAC_TypeDef *DACx, uint32_t DAC_Channel) +{ + __IO uint32_t *preg = __DAC_PTR_REG_OFFSET(DACx->DOR1, (DAC_Channel >> DAC_REG_DORX_REGOFFSET_BITOFFSET_POS) & DAC_REG_REGOFFSET_MASK_POSBIT0); + + return (uint16_t) READ_BIT(*preg, DAC_DOR1_DACC1DOR); +} + +/** + * @} + */ + +/** @defgroup DAC_LL_EF_FLAG_Management FLAG Management + * @{ + */ +/** + * @brief Get DAC underrun flag for DAC channel 1 + * @rmtoll SR DMAUDR1 LL_DAC_IsActiveFlag_DMAUDR1 + * @param DACx DAC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DAC_IsActiveFlag_DMAUDR1(DAC_TypeDef *DACx) +{ + return (READ_BIT(DACx->SR, LL_DAC_FLAG_DMAUDR1) == (LL_DAC_FLAG_DMAUDR1)); +} + +#if defined(DAC_CHANNEL2_SUPPORT) +/** + * @brief Get DAC underrun flag for DAC channel 2 + * @rmtoll SR DMAUDR2 LL_DAC_IsActiveFlag_DMAUDR2 + * @param DACx DAC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DAC_IsActiveFlag_DMAUDR2(DAC_TypeDef *DACx) +{ + return (READ_BIT(DACx->SR, LL_DAC_FLAG_DMAUDR2) == (LL_DAC_FLAG_DMAUDR2)); +} +#endif /* DAC_CHANNEL2_SUPPORT */ + +/** + * @brief Clear DAC underrun flag for DAC channel 1 + * @rmtoll SR DMAUDR1 LL_DAC_ClearFlag_DMAUDR1 + * @param DACx DAC instance + * @retval None + */ +__STATIC_INLINE void LL_DAC_ClearFlag_DMAUDR1(DAC_TypeDef *DACx) +{ + WRITE_REG(DACx->SR, LL_DAC_FLAG_DMAUDR1); +} + +#if defined(DAC_CHANNEL2_SUPPORT) +/** + * @brief Clear DAC underrun flag for DAC channel 2 + * @rmtoll SR DMAUDR2 LL_DAC_ClearFlag_DMAUDR2 + * @param DACx DAC instance + * @retval None + */ +__STATIC_INLINE void LL_DAC_ClearFlag_DMAUDR2(DAC_TypeDef *DACx) +{ + WRITE_REG(DACx->SR, LL_DAC_FLAG_DMAUDR2); +} +#endif /* DAC_CHANNEL2_SUPPORT */ + +/** + * @} + */ + +/** @defgroup DAC_LL_EF_IT_Management IT management + * @{ + */ + +/** + * @brief Enable DMA underrun interrupt for DAC channel 1 + * @rmtoll CR DMAUDRIE1 LL_DAC_EnableIT_DMAUDR1 + * @param DACx DAC instance + * @retval None + */ +__STATIC_INLINE void LL_DAC_EnableIT_DMAUDR1(DAC_TypeDef *DACx) +{ + SET_BIT(DACx->CR, LL_DAC_IT_DMAUDRIE1); +} + +#if defined(DAC_CHANNEL2_SUPPORT) +/** + * @brief Enable DMA underrun interrupt for DAC channel 2 + * @rmtoll CR DMAUDRIE2 LL_DAC_EnableIT_DMAUDR2 + * @param DACx DAC instance + * @retval None + */ +__STATIC_INLINE void LL_DAC_EnableIT_DMAUDR2(DAC_TypeDef *DACx) +{ + SET_BIT(DACx->CR, LL_DAC_IT_DMAUDRIE2); +} +#endif /* DAC_CHANNEL2_SUPPORT */ + +/** + * @brief Disable DMA underrun interrupt for DAC channel 1 + * @rmtoll CR DMAUDRIE1 LL_DAC_DisableIT_DMAUDR1 + * @param DACx DAC instance + * @retval None + */ +__STATIC_INLINE void LL_DAC_DisableIT_DMAUDR1(DAC_TypeDef *DACx) +{ + CLEAR_BIT(DACx->CR, LL_DAC_IT_DMAUDRIE1); +} + +#if defined(DAC_CHANNEL2_SUPPORT) +/** + * @brief Disable DMA underrun interrupt for DAC channel 2 + * @rmtoll CR DMAUDRIE2 LL_DAC_DisableIT_DMAUDR2 + * @param DACx DAC instance + * @retval None + */ +__STATIC_INLINE void LL_DAC_DisableIT_DMAUDR2(DAC_TypeDef *DACx) +{ + CLEAR_BIT(DACx->CR, LL_DAC_IT_DMAUDRIE2); +} +#endif /* DAC_CHANNEL2_SUPPORT */ + +/** + * @brief Get DMA underrun interrupt for DAC channel 1 + * @rmtoll CR DMAUDRIE1 LL_DAC_IsEnabledIT_DMAUDR1 + * @param DACx DAC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DAC_IsEnabledIT_DMAUDR1(DAC_TypeDef *DACx) +{ + return (READ_BIT(DACx->CR, LL_DAC_IT_DMAUDRIE1) == (LL_DAC_IT_DMAUDRIE1)); +} + +#if defined(DAC_CHANNEL2_SUPPORT) +/** + * @brief Get DMA underrun interrupt for DAC channel 2 + * @rmtoll CR DMAUDRIE2 LL_DAC_IsEnabledIT_DMAUDR2 + * @param DACx DAC instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DAC_IsEnabledIT_DMAUDR2(DAC_TypeDef *DACx) +{ + return (READ_BIT(DACx->CR, LL_DAC_IT_DMAUDRIE2) == (LL_DAC_IT_DMAUDRIE2)); +} +#endif /* DAC_CHANNEL2_SUPPORT */ + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup DAC_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_DAC_DeInit(DAC_TypeDef* DACx); +ErrorStatus LL_DAC_Init(DAC_TypeDef* DACx, uint32_t DAC_Channel, LL_DAC_InitTypeDef* DAC_InitStruct); +void LL_DAC_StructInit(LL_DAC_InitTypeDef* DAC_InitStruct); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* DAC1 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_DAC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dma.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dma.h new file mode 100644 index 0000000..5fe1d92 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_dma.h @@ -0,0 +1,2236 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_dma.h + * @author MCD Application Team + * @brief Header file of DMA LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_DMA_H +#define __STM32F0xx_LL_DMA_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (DMA1) || defined (DMA2) + +/** @defgroup DMA_LL DMA + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/** @defgroup DMA_LL_Private_Variables DMA Private Variables + * @{ + */ +/* Array used to get the DMA channel register offset versus channel index LL_DMA_CHANNEL_x */ +static const uint8_t CHANNEL_OFFSET_TAB[] = +{ + (uint8_t)(DMA1_Channel1_BASE - DMA1_BASE), + (uint8_t)(DMA1_Channel2_BASE - DMA1_BASE), + (uint8_t)(DMA1_Channel3_BASE - DMA1_BASE), + (uint8_t)(DMA1_Channel4_BASE - DMA1_BASE), + (uint8_t)(DMA1_Channel5_BASE - DMA1_BASE), +#if defined(DMA1_Channel6) + (uint8_t)(DMA1_Channel6_BASE - DMA1_BASE), +#endif /*DMA1_Channel6*/ +#if defined(DMA1_Channel7) + (uint8_t)(DMA1_Channel7_BASE - DMA1_BASE) +#endif /*DMA1_Channel7*/ +}; +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup DMA_LL_Private_Constants DMA Private Constants + * @{ + */ +/* Define used to get CSELR register offset */ +#define DMA_CSELR_OFFSET (uint32_t)(DMA1_CSELR_BASE - DMA1_BASE) + +/* Defines used for the bit position in the register and perform offsets */ +#define DMA_POSITION_CSELR_CXS ((Channel-1U)*4U) +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup DMA_LL_Private_Macros DMA Private Macros + * @{ + */ +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup DMA_LL_ES_INIT DMA Exported Init structure + * @{ + */ +typedef struct +{ + uint32_t PeriphOrM2MSrcAddress; /*!< Specifies the peripheral base address for DMA transfer + or as Source base address in case of memory to memory transfer direction. + + This parameter must be a value between Min_Data = 0 and Max_Data = 0xFFFFFFFF. */ + + uint32_t MemoryOrM2MDstAddress; /*!< Specifies the memory base address for DMA transfer + or as Destination base address in case of memory to memory transfer direction. + + This parameter must be a value between Min_Data = 0 and Max_Data = 0xFFFFFFFF. */ + + uint32_t Direction; /*!< Specifies if the data will be transferred from memory to peripheral, + from memory to memory or from peripheral to memory. + This parameter can be a value of @ref DMA_LL_EC_DIRECTION + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetDataTransferDirection(). */ + + uint32_t Mode; /*!< Specifies the normal or circular operation mode. + This parameter can be a value of @ref DMA_LL_EC_MODE + @note: The circular buffer mode cannot be used if the memory to memory + data transfer direction is configured on the selected Channel + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetMode(). */ + + uint32_t PeriphOrM2MSrcIncMode; /*!< Specifies whether the Peripheral address or Source address in case of memory to memory transfer direction + is incremented or not. + This parameter can be a value of @ref DMA_LL_EC_PERIPH + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetPeriphIncMode(). */ + + uint32_t MemoryOrM2MDstIncMode; /*!< Specifies whether the Memory address or Destination address in case of memory to memory transfer direction + is incremented or not. + This parameter can be a value of @ref DMA_LL_EC_MEMORY + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetMemoryIncMode(). */ + + uint32_t PeriphOrM2MSrcDataSize; /*!< Specifies the Peripheral data size alignment or Source data size alignment (byte, half word, word) + in case of memory to memory transfer direction. + This parameter can be a value of @ref DMA_LL_EC_PDATAALIGN + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetPeriphSize(). */ + + uint32_t MemoryOrM2MDstDataSize; /*!< Specifies the Memory data size alignment or Destination data size alignment (byte, half word, word) + in case of memory to memory transfer direction. + This parameter can be a value of @ref DMA_LL_EC_MDATAALIGN + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetMemorySize(). */ + + uint32_t NbData; /*!< Specifies the number of data to transfer, in data unit. + The data unit is equal to the source buffer configuration set in PeripheralSize + or MemorySize parameters depending in the transfer direction. + This parameter must be a value between Min_Data = 0 and Max_Data = 0x0000FFFF + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetDataLength(). */ +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) + + uint32_t PeriphRequest; /*!< Specifies the peripheral request. + This parameter can be a value of @ref DMA_LL_EC_REQUEST + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetPeriphRequest(). */ +#endif + + uint32_t Priority; /*!< Specifies the channel priority level. + This parameter can be a value of @ref DMA_LL_EC_PRIORITY + + This feature can be modified afterwards using unitary function @ref LL_DMA_SetChannelPriorityLevel(). */ + +} LL_DMA_InitTypeDef; +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup DMA_LL_Exported_Constants DMA Exported Constants + * @{ + */ +/** @defgroup DMA_LL_EC_CLEAR_FLAG Clear Flags Defines + * @brief Flags defines which can be used with LL_DMA_WriteReg function + * @{ + */ +#define LL_DMA_IFCR_CGIF1 DMA_IFCR_CGIF1 /*!< Channel 1 global flag */ +#define LL_DMA_IFCR_CTCIF1 DMA_IFCR_CTCIF1 /*!< Channel 1 transfer complete flag */ +#define LL_DMA_IFCR_CHTIF1 DMA_IFCR_CHTIF1 /*!< Channel 1 half transfer flag */ +#define LL_DMA_IFCR_CTEIF1 DMA_IFCR_CTEIF1 /*!< Channel 1 transfer error flag */ +#define LL_DMA_IFCR_CGIF2 DMA_IFCR_CGIF2 /*!< Channel 2 global flag */ +#define LL_DMA_IFCR_CTCIF2 DMA_IFCR_CTCIF2 /*!< Channel 2 transfer complete flag */ +#define LL_DMA_IFCR_CHTIF2 DMA_IFCR_CHTIF2 /*!< Channel 2 half transfer flag */ +#define LL_DMA_IFCR_CTEIF2 DMA_IFCR_CTEIF2 /*!< Channel 2 transfer error flag */ +#define LL_DMA_IFCR_CGIF3 DMA_IFCR_CGIF3 /*!< Channel 3 global flag */ +#define LL_DMA_IFCR_CTCIF3 DMA_IFCR_CTCIF3 /*!< Channel 3 transfer complete flag */ +#define LL_DMA_IFCR_CHTIF3 DMA_IFCR_CHTIF3 /*!< Channel 3 half transfer flag */ +#define LL_DMA_IFCR_CTEIF3 DMA_IFCR_CTEIF3 /*!< Channel 3 transfer error flag */ +#define LL_DMA_IFCR_CGIF4 DMA_IFCR_CGIF4 /*!< Channel 4 global flag */ +#define LL_DMA_IFCR_CTCIF4 DMA_IFCR_CTCIF4 /*!< Channel 4 transfer complete flag */ +#define LL_DMA_IFCR_CHTIF4 DMA_IFCR_CHTIF4 /*!< Channel 4 half transfer flag */ +#define LL_DMA_IFCR_CTEIF4 DMA_IFCR_CTEIF4 /*!< Channel 4 transfer error flag */ +#define LL_DMA_IFCR_CGIF5 DMA_IFCR_CGIF5 /*!< Channel 5 global flag */ +#define LL_DMA_IFCR_CTCIF5 DMA_IFCR_CTCIF5 /*!< Channel 5 transfer complete flag */ +#define LL_DMA_IFCR_CHTIF5 DMA_IFCR_CHTIF5 /*!< Channel 5 half transfer flag */ +#define LL_DMA_IFCR_CTEIF5 DMA_IFCR_CTEIF5 /*!< Channel 5 transfer error flag */ +#if defined(DMA1_Channel6) +#define LL_DMA_IFCR_CGIF6 DMA_IFCR_CGIF6 /*!< Channel 6 global flag */ +#define LL_DMA_IFCR_CTCIF6 DMA_IFCR_CTCIF6 /*!< Channel 6 transfer complete flag */ +#define LL_DMA_IFCR_CHTIF6 DMA_IFCR_CHTIF6 /*!< Channel 6 half transfer flag */ +#define LL_DMA_IFCR_CTEIF6 DMA_IFCR_CTEIF6 /*!< Channel 6 transfer error flag */ +#endif +#if defined(DMA1_Channel7) +#define LL_DMA_IFCR_CGIF7 DMA_IFCR_CGIF7 /*!< Channel 7 global flag */ +#define LL_DMA_IFCR_CTCIF7 DMA_IFCR_CTCIF7 /*!< Channel 7 transfer complete flag */ +#define LL_DMA_IFCR_CHTIF7 DMA_IFCR_CHTIF7 /*!< Channel 7 half transfer flag */ +#define LL_DMA_IFCR_CTEIF7 DMA_IFCR_CTEIF7 /*!< Channel 7 transfer error flag */ +#endif +/** + * @} + */ + +/** @defgroup DMA_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_DMA_ReadReg function + * @{ + */ +#define LL_DMA_ISR_GIF1 DMA_ISR_GIF1 /*!< Channel 1 global flag */ +#define LL_DMA_ISR_TCIF1 DMA_ISR_TCIF1 /*!< Channel 1 transfer complete flag */ +#define LL_DMA_ISR_HTIF1 DMA_ISR_HTIF1 /*!< Channel 1 half transfer flag */ +#define LL_DMA_ISR_TEIF1 DMA_ISR_TEIF1 /*!< Channel 1 transfer error flag */ +#define LL_DMA_ISR_GIF2 DMA_ISR_GIF2 /*!< Channel 2 global flag */ +#define LL_DMA_ISR_TCIF2 DMA_ISR_TCIF2 /*!< Channel 2 transfer complete flag */ +#define LL_DMA_ISR_HTIF2 DMA_ISR_HTIF2 /*!< Channel 2 half transfer flag */ +#define LL_DMA_ISR_TEIF2 DMA_ISR_TEIF2 /*!< Channel 2 transfer error flag */ +#define LL_DMA_ISR_GIF3 DMA_ISR_GIF3 /*!< Channel 3 global flag */ +#define LL_DMA_ISR_TCIF3 DMA_ISR_TCIF3 /*!< Channel 3 transfer complete flag */ +#define LL_DMA_ISR_HTIF3 DMA_ISR_HTIF3 /*!< Channel 3 half transfer flag */ +#define LL_DMA_ISR_TEIF3 DMA_ISR_TEIF3 /*!< Channel 3 transfer error flag */ +#define LL_DMA_ISR_GIF4 DMA_ISR_GIF4 /*!< Channel 4 global flag */ +#define LL_DMA_ISR_TCIF4 DMA_ISR_TCIF4 /*!< Channel 4 transfer complete flag */ +#define LL_DMA_ISR_HTIF4 DMA_ISR_HTIF4 /*!< Channel 4 half transfer flag */ +#define LL_DMA_ISR_TEIF4 DMA_ISR_TEIF4 /*!< Channel 4 transfer error flag */ +#define LL_DMA_ISR_GIF5 DMA_ISR_GIF5 /*!< Channel 5 global flag */ +#define LL_DMA_ISR_TCIF5 DMA_ISR_TCIF5 /*!< Channel 5 transfer complete flag */ +#define LL_DMA_ISR_HTIF5 DMA_ISR_HTIF5 /*!< Channel 5 half transfer flag */ +#define LL_DMA_ISR_TEIF5 DMA_ISR_TEIF5 /*!< Channel 5 transfer error flag */ +#if defined(DMA1_Channel6) +#define LL_DMA_ISR_GIF6 DMA_ISR_GIF6 /*!< Channel 6 global flag */ +#define LL_DMA_ISR_TCIF6 DMA_ISR_TCIF6 /*!< Channel 6 transfer complete flag */ +#define LL_DMA_ISR_HTIF6 DMA_ISR_HTIF6 /*!< Channel 6 half transfer flag */ +#define LL_DMA_ISR_TEIF6 DMA_ISR_TEIF6 /*!< Channel 6 transfer error flag */ +#endif +#if defined(DMA1_Channel7) +#define LL_DMA_ISR_GIF7 DMA_ISR_GIF7 /*!< Channel 7 global flag */ +#define LL_DMA_ISR_TCIF7 DMA_ISR_TCIF7 /*!< Channel 7 transfer complete flag */ +#define LL_DMA_ISR_HTIF7 DMA_ISR_HTIF7 /*!< Channel 7 half transfer flag */ +#define LL_DMA_ISR_TEIF7 DMA_ISR_TEIF7 /*!< Channel 7 transfer error flag */ +#endif +/** + * @} + */ + +/** @defgroup DMA_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_DMA_ReadReg and LL_DMA_WriteReg functions + * @{ + */ +#define LL_DMA_CCR_TCIE DMA_CCR_TCIE /*!< Transfer complete interrupt */ +#define LL_DMA_CCR_HTIE DMA_CCR_HTIE /*!< Half Transfer interrupt */ +#define LL_DMA_CCR_TEIE DMA_CCR_TEIE /*!< Transfer error interrupt */ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_CHANNEL CHANNEL + * @{ + */ +#define LL_DMA_CHANNEL_1 0x00000001U /*!< DMA Channel 1 */ +#define LL_DMA_CHANNEL_2 0x00000002U /*!< DMA Channel 2 */ +#define LL_DMA_CHANNEL_3 0x00000003U /*!< DMA Channel 3 */ +#define LL_DMA_CHANNEL_4 0x00000004U /*!< DMA Channel 4 */ +#define LL_DMA_CHANNEL_5 0x00000005U /*!< DMA Channel 5 */ +#if defined(DMA1_Channel6) +#define LL_DMA_CHANNEL_6 0x00000006U /*!< DMA Channel 6 */ +#endif +#if defined(DMA1_Channel7) +#define LL_DMA_CHANNEL_7 0x00000007U /*!< DMA Channel 7 */ +#endif +#if defined(USE_FULL_LL_DRIVER) +#define LL_DMA_CHANNEL_ALL 0xFFFF0000U /*!< DMA Channel all (used only for function @ref LL_DMA_DeInit(). */ +#endif /*USE_FULL_LL_DRIVER*/ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_DIRECTION Transfer Direction + * @{ + */ +#define LL_DMA_DIRECTION_PERIPH_TO_MEMORY 0x00000000U /*!< Peripheral to memory direction */ +#define LL_DMA_DIRECTION_MEMORY_TO_PERIPH DMA_CCR_DIR /*!< Memory to peripheral direction */ +#define LL_DMA_DIRECTION_MEMORY_TO_MEMORY DMA_CCR_MEM2MEM /*!< Memory to memory direction */ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_MODE Transfer mode + * @{ + */ +#define LL_DMA_MODE_NORMAL 0x00000000U /*!< Normal Mode */ +#define LL_DMA_MODE_CIRCULAR DMA_CCR_CIRC /*!< Circular Mode */ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_PERIPH Peripheral increment mode + * @{ + */ +#define LL_DMA_PERIPH_INCREMENT DMA_CCR_PINC /*!< Peripheral increment mode Enable */ +#define LL_DMA_PERIPH_NOINCREMENT 0x00000000U /*!< Peripheral increment mode Disable */ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_MEMORY Memory increment mode + * @{ + */ +#define LL_DMA_MEMORY_INCREMENT DMA_CCR_MINC /*!< Memory increment mode Enable */ +#define LL_DMA_MEMORY_NOINCREMENT 0x00000000U /*!< Memory increment mode Disable */ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_PDATAALIGN Peripheral data alignment + * @{ + */ +#define LL_DMA_PDATAALIGN_BYTE 0x00000000U /*!< Peripheral data alignment : Byte */ +#define LL_DMA_PDATAALIGN_HALFWORD DMA_CCR_PSIZE_0 /*!< Peripheral data alignment : HalfWord */ +#define LL_DMA_PDATAALIGN_WORD DMA_CCR_PSIZE_1 /*!< Peripheral data alignment : Word */ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_MDATAALIGN Memory data alignment + * @{ + */ +#define LL_DMA_MDATAALIGN_BYTE 0x00000000U /*!< Memory data alignment : Byte */ +#define LL_DMA_MDATAALIGN_HALFWORD DMA_CCR_MSIZE_0 /*!< Memory data alignment : HalfWord */ +#define LL_DMA_MDATAALIGN_WORD DMA_CCR_MSIZE_1 /*!< Memory data alignment : Word */ +/** + * @} + */ + +/** @defgroup DMA_LL_EC_PRIORITY Transfer Priority level + * @{ + */ +#define LL_DMA_PRIORITY_LOW 0x00000000U /*!< Priority level : Low */ +#define LL_DMA_PRIORITY_MEDIUM DMA_CCR_PL_0 /*!< Priority level : Medium */ +#define LL_DMA_PRIORITY_HIGH DMA_CCR_PL_1 /*!< Priority level : High */ +#define LL_DMA_PRIORITY_VERYHIGH DMA_CCR_PL /*!< Priority level : Very_High */ +/** + * @} + */ + +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) +/** @defgroup DMA_LL_EC_REQUEST Transfer peripheral request + * @{ + */ +#define LL_DMA_REQUEST_0 0x00000000U /*!< DMA peripheral request 0 */ +#define LL_DMA_REQUEST_1 0x00000001U /*!< DMA peripheral request 1 */ +#define LL_DMA_REQUEST_2 0x00000002U /*!< DMA peripheral request 2 */ +#define LL_DMA_REQUEST_3 0x00000003U /*!< DMA peripheral request 3 */ +#define LL_DMA_REQUEST_4 0x00000004U /*!< DMA peripheral request 4 */ +#define LL_DMA_REQUEST_5 0x00000005U /*!< DMA peripheral request 5 */ +#define LL_DMA_REQUEST_6 0x00000006U /*!< DMA peripheral request 6 */ +#define LL_DMA_REQUEST_7 0x00000007U /*!< DMA peripheral request 7 */ +#define LL_DMA_REQUEST_8 0x00000008U /*!< DMA peripheral request 8 */ +#define LL_DMA_REQUEST_9 0x00000009U /*!< DMA peripheral request 9 */ +#define LL_DMA_REQUEST_10 0x0000000AU /*!< DMA peripheral request 10 */ +#define LL_DMA_REQUEST_11 0x0000000BU /*!< DMA peripheral request 11 */ +#define LL_DMA_REQUEST_12 0x0000000CU /*!< DMA peripheral request 12 */ +#define LL_DMA_REQUEST_13 0x0000000DU /*!< DMA peripheral request 13 */ +#define LL_DMA_REQUEST_14 0x0000000EU /*!< DMA peripheral request 14 */ +#define LL_DMA_REQUEST_15 0x0000000FU /*!< DMA peripheral request 15 */ +/** + * @} + */ +#endif + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup DMA_LL_Exported_Macros DMA Exported Macros + * @{ + */ + +/** @defgroup DMA_LL_EM_WRITE_READ Common Write and read registers macros + * @{ + */ +/** + * @brief Write a value in DMA register + * @param __INSTANCE__ DMA Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_DMA_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in DMA register + * @param __INSTANCE__ DMA Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_DMA_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** @defgroup DMA_LL_EM_CONVERT_DMAxCHANNELy Convert DMAxChannely + * @{ + */ +/** + * @brief Convert DMAx_Channely into DMAx + * @param __CHANNEL_INSTANCE__ DMAx_Channely + * @retval DMAx + */ +#if defined(DMA2) +#define __LL_DMA_GET_INSTANCE(__CHANNEL_INSTANCE__) \ +(((uint32_t)(__CHANNEL_INSTANCE__) > ((uint32_t)DMA1_Channel7)) ? DMA2 : DMA1) +#else +#define __LL_DMA_GET_INSTANCE(__CHANNEL_INSTANCE__) (DMA1) +#endif + +/** + * @brief Convert DMAx_Channely into LL_DMA_CHANNEL_y + * @param __CHANNEL_INSTANCE__ DMAx_Channely + * @retval LL_DMA_CHANNEL_y + */ +#if defined (DMA2) +#if defined (DMA2_Channel6) && defined (DMA2_Channel7) +#define __LL_DMA_GET_CHANNEL(__CHANNEL_INSTANCE__) \ +(((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel1)) ? LL_DMA_CHANNEL_1 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel1)) ? LL_DMA_CHANNEL_1 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel2)) ? LL_DMA_CHANNEL_2 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel2)) ? LL_DMA_CHANNEL_2 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel3)) ? LL_DMA_CHANNEL_3 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel3)) ? LL_DMA_CHANNEL_3 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel4)) ? LL_DMA_CHANNEL_4 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel4)) ? LL_DMA_CHANNEL_4 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel5)) ? LL_DMA_CHANNEL_5 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel5)) ? LL_DMA_CHANNEL_5 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel6)) ? LL_DMA_CHANNEL_6 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel6)) ? LL_DMA_CHANNEL_6 : \ + LL_DMA_CHANNEL_7) +#else +#define __LL_DMA_GET_CHANNEL(__CHANNEL_INSTANCE__) \ +(((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel1)) ? LL_DMA_CHANNEL_1 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel1)) ? LL_DMA_CHANNEL_1 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel2)) ? LL_DMA_CHANNEL_2 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel2)) ? LL_DMA_CHANNEL_2 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel3)) ? LL_DMA_CHANNEL_3 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel3)) ? LL_DMA_CHANNEL_3 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel4)) ? LL_DMA_CHANNEL_4 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel4)) ? LL_DMA_CHANNEL_4 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel5)) ? LL_DMA_CHANNEL_5 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA2_Channel5)) ? LL_DMA_CHANNEL_5 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel6)) ? LL_DMA_CHANNEL_6 : \ + LL_DMA_CHANNEL_7) +#endif +#else +#if defined (DMA1_Channel6) && defined (DMA1_Channel7) +#define __LL_DMA_GET_CHANNEL(__CHANNEL_INSTANCE__) \ +(((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel1)) ? LL_DMA_CHANNEL_1 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel2)) ? LL_DMA_CHANNEL_2 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel3)) ? LL_DMA_CHANNEL_3 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel4)) ? LL_DMA_CHANNEL_4 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel5)) ? LL_DMA_CHANNEL_5 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel6)) ? LL_DMA_CHANNEL_6 : \ + LL_DMA_CHANNEL_7) +#elif defined (DMA1_Channel6) +#define __LL_DMA_GET_CHANNEL(__CHANNEL_INSTANCE__) \ +(((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel1)) ? LL_DMA_CHANNEL_1 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel2)) ? LL_DMA_CHANNEL_2 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel3)) ? LL_DMA_CHANNEL_3 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel4)) ? LL_DMA_CHANNEL_4 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel5)) ? LL_DMA_CHANNEL_5 : \ + LL_DMA_CHANNEL_6) +#else +#define __LL_DMA_GET_CHANNEL(__CHANNEL_INSTANCE__) \ +(((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel1)) ? LL_DMA_CHANNEL_1 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel2)) ? LL_DMA_CHANNEL_2 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel3)) ? LL_DMA_CHANNEL_3 : \ + ((uint32_t)(__CHANNEL_INSTANCE__) == ((uint32_t)DMA1_Channel4)) ? LL_DMA_CHANNEL_4 : \ + LL_DMA_CHANNEL_5) +#endif /* DMA1_Channel6 && DMA1_Channel7 */ +#endif + +/** + * @brief Convert DMA Instance DMAx and LL_DMA_CHANNEL_y into DMAx_Channely + * @param __DMA_INSTANCE__ DMAx + * @param __CHANNEL__ LL_DMA_CHANNEL_y + * @retval DMAx_Channely + */ +#if defined (DMA2) +#if defined (DMA2_Channel6) && defined (DMA2_Channel7) +#define __LL_DMA_GET_CHANNEL_INSTANCE(__DMA_INSTANCE__, __CHANNEL__) \ +((((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_1))) ? DMA1_Channel1 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_1))) ? DMA2_Channel1 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_2))) ? DMA1_Channel2 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_2))) ? DMA2_Channel2 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_3))) ? DMA1_Channel3 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_3))) ? DMA2_Channel3 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_4))) ? DMA1_Channel4 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_4))) ? DMA2_Channel4 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_5))) ? DMA1_Channel5 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_5))) ? DMA2_Channel5 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_6))) ? DMA1_Channel6 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_6))) ? DMA2_Channel6 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_7))) ? DMA1_Channel7 : \ + DMA2_Channel7) +#else +#define __LL_DMA_GET_CHANNEL_INSTANCE(__DMA_INSTANCE__, __CHANNEL__) \ +((((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_1))) ? DMA1_Channel1 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_1))) ? DMA2_Channel1 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_2))) ? DMA1_Channel2 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_2))) ? DMA2_Channel2 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_3))) ? DMA1_Channel3 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_3))) ? DMA2_Channel3 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_4))) ? DMA1_Channel4 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_4))) ? DMA2_Channel4 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_5))) ? DMA1_Channel5 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA2)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_5))) ? DMA2_Channel5 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_6))) ? DMA1_Channel6 : \ + DMA1_Channel7) +#endif +#else +#if defined (DMA1_Channel6) && defined (DMA1_Channel7) +#define __LL_DMA_GET_CHANNEL_INSTANCE(__DMA_INSTANCE__, __CHANNEL__) \ +((((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_1))) ? DMA1_Channel1 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_2))) ? DMA1_Channel2 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_3))) ? DMA1_Channel3 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_4))) ? DMA1_Channel4 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_5))) ? DMA1_Channel5 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_6))) ? DMA1_Channel6 : \ + DMA1_Channel7) +#elif defined (DMA1_Channel6) +#define __LL_DMA_GET_CHANNEL_INSTANCE(__DMA_INSTANCE__, __CHANNEL__) \ +((((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_1))) ? DMA1_Channel1 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_2))) ? DMA1_Channel2 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_3))) ? DMA1_Channel3 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_4))) ? DMA1_Channel4 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_5))) ? DMA1_Channel5 : \ + DMA1_Channel6) +#else +#define __LL_DMA_GET_CHANNEL_INSTANCE(__DMA_INSTANCE__, __CHANNEL__) \ +((((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_1))) ? DMA1_Channel1 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_2))) ? DMA1_Channel2 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_3))) ? DMA1_Channel3 : \ + (((uint32_t)(__DMA_INSTANCE__) == ((uint32_t)DMA1)) && ((uint32_t)(__CHANNEL__) == ((uint32_t)LL_DMA_CHANNEL_4))) ? DMA1_Channel4 : \ + DMA1_Channel5) +#endif /* DMA1_Channel6 && DMA1_Channel7 */ +#endif + +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup DMA_LL_Exported_Functions DMA Exported Functions + * @{ + */ + +/** @defgroup DMA_LL_EF_Configuration Configuration + * @{ + */ +/** + * @brief Enable DMA channel. + * @rmtoll CCR EN LL_DMA_EnableChannel + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_EnableChannel(DMA_TypeDef *DMAx, uint32_t Channel) +{ + SET_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_EN); +} + +/** + * @brief Disable DMA channel. + * @rmtoll CCR EN LL_DMA_DisableChannel + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_DisableChannel(DMA_TypeDef *DMAx, uint32_t Channel) +{ + CLEAR_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_EN); +} + +/** + * @brief Check if DMA channel is enabled or disabled. + * @rmtoll CCR EN LL_DMA_IsEnabledChannel + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsEnabledChannel(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_EN) == (DMA_CCR_EN)); +} + +/** + * @brief Configure all parameters link to DMA transfer. + * @rmtoll CCR DIR LL_DMA_ConfigTransfer\n + * CCR MEM2MEM LL_DMA_ConfigTransfer\n + * CCR CIRC LL_DMA_ConfigTransfer\n + * CCR PINC LL_DMA_ConfigTransfer\n + * CCR MINC LL_DMA_ConfigTransfer\n + * CCR PSIZE LL_DMA_ConfigTransfer\n + * CCR MSIZE LL_DMA_ConfigTransfer\n + * CCR PL LL_DMA_ConfigTransfer + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param Configuration This parameter must be a combination of all the following values: + * @arg @ref LL_DMA_DIRECTION_PERIPH_TO_MEMORY or @ref LL_DMA_DIRECTION_MEMORY_TO_PERIPH or @ref LL_DMA_DIRECTION_MEMORY_TO_MEMORY + * @arg @ref LL_DMA_MODE_NORMAL or @ref LL_DMA_MODE_CIRCULAR + * @arg @ref LL_DMA_PERIPH_INCREMENT or @ref LL_DMA_PERIPH_NOINCREMENT + * @arg @ref LL_DMA_MEMORY_INCREMENT or @ref LL_DMA_MEMORY_NOINCREMENT + * @arg @ref LL_DMA_PDATAALIGN_BYTE or @ref LL_DMA_PDATAALIGN_HALFWORD or @ref LL_DMA_PDATAALIGN_WORD + * @arg @ref LL_DMA_MDATAALIGN_BYTE or @ref LL_DMA_MDATAALIGN_HALFWORD or @ref LL_DMA_MDATAALIGN_WORD + * @arg @ref LL_DMA_PRIORITY_LOW or @ref LL_DMA_PRIORITY_MEDIUM or @ref LL_DMA_PRIORITY_HIGH or @ref LL_DMA_PRIORITY_VERYHIGH + * @retval None + */ +__STATIC_INLINE void LL_DMA_ConfigTransfer(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t Configuration) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_DIR | DMA_CCR_MEM2MEM | DMA_CCR_CIRC | DMA_CCR_PINC | DMA_CCR_MINC | DMA_CCR_PSIZE | DMA_CCR_MSIZE | DMA_CCR_PL, + Configuration); +} + +/** + * @brief Set Data transfer direction (read from peripheral or from memory). + * @rmtoll CCR DIR LL_DMA_SetDataTransferDirection\n + * CCR MEM2MEM LL_DMA_SetDataTransferDirection + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param Direction This parameter can be one of the following values: + * @arg @ref LL_DMA_DIRECTION_PERIPH_TO_MEMORY + * @arg @ref LL_DMA_DIRECTION_MEMORY_TO_PERIPH + * @arg @ref LL_DMA_DIRECTION_MEMORY_TO_MEMORY + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetDataTransferDirection(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t Direction) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_DIR | DMA_CCR_MEM2MEM, Direction); +} + +/** + * @brief Get Data transfer direction (read from peripheral or from memory). + * @rmtoll CCR DIR LL_DMA_GetDataTransferDirection\n + * CCR MEM2MEM LL_DMA_GetDataTransferDirection + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_DIRECTION_PERIPH_TO_MEMORY + * @arg @ref LL_DMA_DIRECTION_MEMORY_TO_PERIPH + * @arg @ref LL_DMA_DIRECTION_MEMORY_TO_MEMORY + */ +__STATIC_INLINE uint32_t LL_DMA_GetDataTransferDirection(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_DIR | DMA_CCR_MEM2MEM)); +} + +/** + * @brief Set DMA mode circular or normal. + * @note The circular buffer mode cannot be used if the memory-to-memory + * data transfer is configured on the selected Channel. + * @rmtoll CCR CIRC LL_DMA_SetMode + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param Mode This parameter can be one of the following values: + * @arg @ref LL_DMA_MODE_NORMAL + * @arg @ref LL_DMA_MODE_CIRCULAR + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetMode(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t Mode) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_CIRC, + Mode); +} + +/** + * @brief Get DMA mode circular or normal. + * @rmtoll CCR CIRC LL_DMA_GetMode + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_MODE_NORMAL + * @arg @ref LL_DMA_MODE_CIRCULAR + */ +__STATIC_INLINE uint32_t LL_DMA_GetMode(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_CIRC)); +} + +/** + * @brief Set Peripheral increment mode. + * @rmtoll CCR PINC LL_DMA_SetPeriphIncMode + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param PeriphOrM2MSrcIncMode This parameter can be one of the following values: + * @arg @ref LL_DMA_PERIPH_INCREMENT + * @arg @ref LL_DMA_PERIPH_NOINCREMENT + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetPeriphIncMode(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t PeriphOrM2MSrcIncMode) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_PINC, + PeriphOrM2MSrcIncMode); +} + +/** + * @brief Get Peripheral increment mode. + * @rmtoll CCR PINC LL_DMA_GetPeriphIncMode + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_PERIPH_INCREMENT + * @arg @ref LL_DMA_PERIPH_NOINCREMENT + */ +__STATIC_INLINE uint32_t LL_DMA_GetPeriphIncMode(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_PINC)); +} + +/** + * @brief Set Memory increment mode. + * @rmtoll CCR MINC LL_DMA_SetMemoryIncMode + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param MemoryOrM2MDstIncMode This parameter can be one of the following values: + * @arg @ref LL_DMA_MEMORY_INCREMENT + * @arg @ref LL_DMA_MEMORY_NOINCREMENT + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetMemoryIncMode(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t MemoryOrM2MDstIncMode) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_MINC, + MemoryOrM2MDstIncMode); +} + +/** + * @brief Get Memory increment mode. + * @rmtoll CCR MINC LL_DMA_GetMemoryIncMode + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_MEMORY_INCREMENT + * @arg @ref LL_DMA_MEMORY_NOINCREMENT + */ +__STATIC_INLINE uint32_t LL_DMA_GetMemoryIncMode(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_MINC)); +} + +/** + * @brief Set Peripheral size. + * @rmtoll CCR PSIZE LL_DMA_SetPeriphSize + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param PeriphOrM2MSrcDataSize This parameter can be one of the following values: + * @arg @ref LL_DMA_PDATAALIGN_BYTE + * @arg @ref LL_DMA_PDATAALIGN_HALFWORD + * @arg @ref LL_DMA_PDATAALIGN_WORD + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetPeriphSize(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t PeriphOrM2MSrcDataSize) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_PSIZE, + PeriphOrM2MSrcDataSize); +} + +/** + * @brief Get Peripheral size. + * @rmtoll CCR PSIZE LL_DMA_GetPeriphSize + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_PDATAALIGN_BYTE + * @arg @ref LL_DMA_PDATAALIGN_HALFWORD + * @arg @ref LL_DMA_PDATAALIGN_WORD + */ +__STATIC_INLINE uint32_t LL_DMA_GetPeriphSize(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_PSIZE)); +} + +/** + * @brief Set Memory size. + * @rmtoll CCR MSIZE LL_DMA_SetMemorySize + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param MemoryOrM2MDstDataSize This parameter can be one of the following values: + * @arg @ref LL_DMA_MDATAALIGN_BYTE + * @arg @ref LL_DMA_MDATAALIGN_HALFWORD + * @arg @ref LL_DMA_MDATAALIGN_WORD + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetMemorySize(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t MemoryOrM2MDstDataSize) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_MSIZE, + MemoryOrM2MDstDataSize); +} + +/** + * @brief Get Memory size. + * @rmtoll CCR MSIZE LL_DMA_GetMemorySize + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_MDATAALIGN_BYTE + * @arg @ref LL_DMA_MDATAALIGN_HALFWORD + * @arg @ref LL_DMA_MDATAALIGN_WORD + */ +__STATIC_INLINE uint32_t LL_DMA_GetMemorySize(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_MSIZE)); +} + +/** + * @brief Set Channel priority level. + * @rmtoll CCR PL LL_DMA_SetChannelPriorityLevel + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param Priority This parameter can be one of the following values: + * @arg @ref LL_DMA_PRIORITY_LOW + * @arg @ref LL_DMA_PRIORITY_MEDIUM + * @arg @ref LL_DMA_PRIORITY_HIGH + * @arg @ref LL_DMA_PRIORITY_VERYHIGH + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetChannelPriorityLevel(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t Priority) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_PL, + Priority); +} + +/** + * @brief Get Channel priority level. + * @rmtoll CCR PL LL_DMA_GetChannelPriorityLevel + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_PRIORITY_LOW + * @arg @ref LL_DMA_PRIORITY_MEDIUM + * @arg @ref LL_DMA_PRIORITY_HIGH + * @arg @ref LL_DMA_PRIORITY_VERYHIGH + */ +__STATIC_INLINE uint32_t LL_DMA_GetChannelPriorityLevel(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_PL)); +} + +/** + * @brief Set Number of data to transfer. + * @note This action has no effect if + * channel is enabled. + * @rmtoll CNDTR NDT LL_DMA_SetDataLength + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param NbData Between Min_Data = 0 and Max_Data = 0x0000FFFF + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetDataLength(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t NbData) +{ + MODIFY_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CNDTR, + DMA_CNDTR_NDT, NbData); +} + +/** + * @brief Get Number of data to transfer. + * @note Once the channel is enabled, the return value indicate the + * remaining bytes to be transmitted. + * @rmtoll CNDTR NDT LL_DMA_GetDataLength + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + */ +__STATIC_INLINE uint32_t LL_DMA_GetDataLength(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CNDTR, + DMA_CNDTR_NDT)); +} + +/** + * @brief Configure the Source and Destination addresses. + * @note This API must not be called when the DMA channel is enabled. + * @note Each IP using DMA provides an API to get directly the register adress (LL_PPP_DMA_GetRegAddr). + * @rmtoll CPAR PA LL_DMA_ConfigAddresses\n + * CMAR MA LL_DMA_ConfigAddresses + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param SrcAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + * @param DstAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + * @param Direction This parameter can be one of the following values: + * @arg @ref LL_DMA_DIRECTION_PERIPH_TO_MEMORY + * @arg @ref LL_DMA_DIRECTION_MEMORY_TO_PERIPH + * @arg @ref LL_DMA_DIRECTION_MEMORY_TO_MEMORY + * @retval None + */ +__STATIC_INLINE void LL_DMA_ConfigAddresses(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t SrcAddress, + uint32_t DstAddress, uint32_t Direction) +{ + /* Direction Memory to Periph */ + if (Direction == LL_DMA_DIRECTION_MEMORY_TO_PERIPH) + { + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CMAR, SrcAddress); + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CPAR, DstAddress); + } + /* Direction Periph to Memory and Memory to Memory */ + else + { + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CPAR, SrcAddress); + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CMAR, DstAddress); + } +} + +/** + * @brief Set the Memory address. + * @note Interface used for direction LL_DMA_DIRECTION_PERIPH_TO_MEMORY or LL_DMA_DIRECTION_MEMORY_TO_PERIPH only. + * @note This API must not be called when the DMA channel is enabled. + * @rmtoll CMAR MA LL_DMA_SetMemoryAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param MemoryAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetMemoryAddress(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t MemoryAddress) +{ + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CMAR, MemoryAddress); +} + +/** + * @brief Set the Peripheral address. + * @note Interface used for direction LL_DMA_DIRECTION_PERIPH_TO_MEMORY or LL_DMA_DIRECTION_MEMORY_TO_PERIPH only. + * @note This API must not be called when the DMA channel is enabled. + * @rmtoll CPAR PA LL_DMA_SetPeriphAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param PeriphAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetPeriphAddress(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t PeriphAddress) +{ + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CPAR, PeriphAddress); +} + +/** + * @brief Get Memory address. + * @note Interface used for direction LL_DMA_DIRECTION_PERIPH_TO_MEMORY or LL_DMA_DIRECTION_MEMORY_TO_PERIPH only. + * @rmtoll CMAR MA LL_DMA_GetMemoryAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + */ +__STATIC_INLINE uint32_t LL_DMA_GetMemoryAddress(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CMAR)); +} + +/** + * @brief Get Peripheral address. + * @note Interface used for direction LL_DMA_DIRECTION_PERIPH_TO_MEMORY or LL_DMA_DIRECTION_MEMORY_TO_PERIPH only. + * @rmtoll CPAR PA LL_DMA_GetPeriphAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + */ +__STATIC_INLINE uint32_t LL_DMA_GetPeriphAddress(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CPAR)); +} + +/** + * @brief Set the Memory to Memory Source address. + * @note Interface used for direction LL_DMA_DIRECTION_MEMORY_TO_MEMORY only. + * @note This API must not be called when the DMA channel is enabled. + * @rmtoll CPAR PA LL_DMA_SetM2MSrcAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param MemoryAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetM2MSrcAddress(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t MemoryAddress) +{ + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CPAR, MemoryAddress); +} + +/** + * @brief Set the Memory to Memory Destination address. + * @note Interface used for direction LL_DMA_DIRECTION_MEMORY_TO_MEMORY only. + * @note This API must not be called when the DMA channel is enabled. + * @rmtoll CMAR MA LL_DMA_SetM2MDstAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param MemoryAddress Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetM2MDstAddress(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t MemoryAddress) +{ + WRITE_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CMAR, MemoryAddress); +} + +/** + * @brief Get the Memory to Memory Source address. + * @note Interface used for direction LL_DMA_DIRECTION_MEMORY_TO_MEMORY only. + * @rmtoll CPAR PA LL_DMA_GetM2MSrcAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + */ +__STATIC_INLINE uint32_t LL_DMA_GetM2MSrcAddress(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CPAR)); +} + +/** + * @brief Get the Memory to Memory Destination address. + * @note Interface used for direction LL_DMA_DIRECTION_MEMORY_TO_MEMORY only. + * @rmtoll CMAR MA LL_DMA_GetM2MDstAddress + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Between Min_Data = 0 and Max_Data = 0xFFFFFFFF + */ +__STATIC_INLINE uint32_t LL_DMA_GetM2MDstAddress(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_REG(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CMAR)); +} + +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) +/** + * @brief Set DMA request for DMA instance on Channel x. + * @note Please refer to Reference Manual to get the available mapping of Request value link to Channel Selection. + * @rmtoll CSELR C1S LL_DMA_SetPeriphRequest\n + * CSELR C2S LL_DMA_SetPeriphRequest\n + * CSELR C3S LL_DMA_SetPeriphRequest\n + * CSELR C4S LL_DMA_SetPeriphRequest\n + * CSELR C5S LL_DMA_SetPeriphRequest\n + * CSELR C6S LL_DMA_SetPeriphRequest\n + * CSELR C7S LL_DMA_SetPeriphRequest + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @param PeriphRequest This parameter can be one of the following values: + * @arg @ref LL_DMA_REQUEST_0 + * @arg @ref LL_DMA_REQUEST_1 + * @arg @ref LL_DMA_REQUEST_2 + * @arg @ref LL_DMA_REQUEST_3 + * @arg @ref LL_DMA_REQUEST_4 + * @arg @ref LL_DMA_REQUEST_5 + * @arg @ref LL_DMA_REQUEST_6 + * @arg @ref LL_DMA_REQUEST_7 + * @arg @ref LL_DMA_REQUEST_8 + * @arg @ref LL_DMA_REQUEST_9 + * @arg @ref LL_DMA_REQUEST_10 + * @arg @ref LL_DMA_REQUEST_11 + * @arg @ref LL_DMA_REQUEST_12 + * @arg @ref LL_DMA_REQUEST_13 + * @arg @ref LL_DMA_REQUEST_14 + * @arg @ref LL_DMA_REQUEST_15 + * @retval None + */ +__STATIC_INLINE void LL_DMA_SetPeriphRequest(DMA_TypeDef *DMAx, uint32_t Channel, uint32_t PeriphRequest) +{ + MODIFY_REG(DMAx->CSELR, + DMA_CSELR_C1S << ((Channel - 1U) * 4U), PeriphRequest << DMA_POSITION_CSELR_CXS); +} + +/** + * @brief Get DMA request for DMA instance on Channel x. + * @rmtoll CSELR C1S LL_DMA_GetPeriphRequest\n + * CSELR C2S LL_DMA_GetPeriphRequest\n + * CSELR C3S LL_DMA_GetPeriphRequest\n + * CSELR C4S LL_DMA_GetPeriphRequest\n + * CSELR C5S LL_DMA_GetPeriphRequest\n + * CSELR C6S LL_DMA_GetPeriphRequest\n + * CSELR C7S LL_DMA_GetPeriphRequest + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_DMA_REQUEST_0 + * @arg @ref LL_DMA_REQUEST_1 + * @arg @ref LL_DMA_REQUEST_2 + * @arg @ref LL_DMA_REQUEST_3 + * @arg @ref LL_DMA_REQUEST_4 + * @arg @ref LL_DMA_REQUEST_5 + * @arg @ref LL_DMA_REQUEST_6 + * @arg @ref LL_DMA_REQUEST_7 + * @arg @ref LL_DMA_REQUEST_8 + * @arg @ref LL_DMA_REQUEST_9 + * @arg @ref LL_DMA_REQUEST_10 + * @arg @ref LL_DMA_REQUEST_11 + * @arg @ref LL_DMA_REQUEST_12 + * @arg @ref LL_DMA_REQUEST_13 + * @arg @ref LL_DMA_REQUEST_14 + * @arg @ref LL_DMA_REQUEST_15 + */ +__STATIC_INLINE uint32_t LL_DMA_GetPeriphRequest(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(DMAx->CSELR, + DMA_CSELR_C1S << ((Channel - 1U) * 4U)) >> DMA_POSITION_CSELR_CXS); +} +#endif + +/** + * @} + */ + +/** @defgroup DMA_LL_EF_FLAG_Management FLAG_Management + * @{ + */ + +/** + * @brief Get Channel 1 global interrupt flag. + * @rmtoll ISR GIF1 LL_DMA_IsActiveFlag_GI1 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_GI1(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_GIF1) == (DMA_ISR_GIF1)); +} + +/** + * @brief Get Channel 2 global interrupt flag. + * @rmtoll ISR GIF2 LL_DMA_IsActiveFlag_GI2 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_GI2(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_GIF2) == (DMA_ISR_GIF2)); +} + +/** + * @brief Get Channel 3 global interrupt flag. + * @rmtoll ISR GIF3 LL_DMA_IsActiveFlag_GI3 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_GI3(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_GIF3) == (DMA_ISR_GIF3)); +} + +/** + * @brief Get Channel 4 global interrupt flag. + * @rmtoll ISR GIF4 LL_DMA_IsActiveFlag_GI4 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_GI4(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_GIF4) == (DMA_ISR_GIF4)); +} + +/** + * @brief Get Channel 5 global interrupt flag. + * @rmtoll ISR GIF5 LL_DMA_IsActiveFlag_GI5 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_GI5(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_GIF5) == (DMA_ISR_GIF5)); +} + +#if defined(DMA1_Channel6) +/** + * @brief Get Channel 6 global interrupt flag. + * @rmtoll ISR GIF6 LL_DMA_IsActiveFlag_GI6 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_GI6(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_GIF6) == (DMA_ISR_GIF6)); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Get Channel 7 global interrupt flag. + * @rmtoll ISR GIF7 LL_DMA_IsActiveFlag_GI7 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_GI7(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_GIF7) == (DMA_ISR_GIF7)); +} +#endif + +/** + * @brief Get Channel 1 transfer complete flag. + * @rmtoll ISR TCIF1 LL_DMA_IsActiveFlag_TC1 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TC1(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TCIF1) == (DMA_ISR_TCIF1)); +} + +/** + * @brief Get Channel 2 transfer complete flag. + * @rmtoll ISR TCIF2 LL_DMA_IsActiveFlag_TC2 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TC2(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TCIF2) == (DMA_ISR_TCIF2)); +} + +/** + * @brief Get Channel 3 transfer complete flag. + * @rmtoll ISR TCIF3 LL_DMA_IsActiveFlag_TC3 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TC3(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TCIF3) == (DMA_ISR_TCIF3)); +} + +/** + * @brief Get Channel 4 transfer complete flag. + * @rmtoll ISR TCIF4 LL_DMA_IsActiveFlag_TC4 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TC4(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TCIF4) == (DMA_ISR_TCIF4)); +} + +/** + * @brief Get Channel 5 transfer complete flag. + * @rmtoll ISR TCIF5 LL_DMA_IsActiveFlag_TC5 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TC5(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TCIF5) == (DMA_ISR_TCIF5)); +} + +#if defined(DMA1_Channel6) +/** + * @brief Get Channel 6 transfer complete flag. + * @rmtoll ISR TCIF6 LL_DMA_IsActiveFlag_TC6 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TC6(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TCIF6) == (DMA_ISR_TCIF6)); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Get Channel 7 transfer complete flag. + * @rmtoll ISR TCIF7 LL_DMA_IsActiveFlag_TC7 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TC7(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TCIF7) == (DMA_ISR_TCIF7)); +} +#endif + +/** + * @brief Get Channel 1 half transfer flag. + * @rmtoll ISR HTIF1 LL_DMA_IsActiveFlag_HT1 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_HT1(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_HTIF1) == (DMA_ISR_HTIF1)); +} + +/** + * @brief Get Channel 2 half transfer flag. + * @rmtoll ISR HTIF2 LL_DMA_IsActiveFlag_HT2 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_HT2(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_HTIF2) == (DMA_ISR_HTIF2)); +} + +/** + * @brief Get Channel 3 half transfer flag. + * @rmtoll ISR HTIF3 LL_DMA_IsActiveFlag_HT3 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_HT3(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_HTIF3) == (DMA_ISR_HTIF3)); +} + +/** + * @brief Get Channel 4 half transfer flag. + * @rmtoll ISR HTIF4 LL_DMA_IsActiveFlag_HT4 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_HT4(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_HTIF4) == (DMA_ISR_HTIF4)); +} + +/** + * @brief Get Channel 5 half transfer flag. + * @rmtoll ISR HTIF5 LL_DMA_IsActiveFlag_HT5 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_HT5(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_HTIF5) == (DMA_ISR_HTIF5)); +} + +#if defined(DMA1_Channel6) +/** + * @brief Get Channel 6 half transfer flag. + * @rmtoll ISR HTIF6 LL_DMA_IsActiveFlag_HT6 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_HT6(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_HTIF6) == (DMA_ISR_HTIF6)); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Get Channel 7 half transfer flag. + * @rmtoll ISR HTIF7 LL_DMA_IsActiveFlag_HT7 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_HT7(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_HTIF7) == (DMA_ISR_HTIF7)); +} +#endif + +/** + * @brief Get Channel 1 transfer error flag. + * @rmtoll ISR TEIF1 LL_DMA_IsActiveFlag_TE1 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TE1(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TEIF1) == (DMA_ISR_TEIF1)); +} + +/** + * @brief Get Channel 2 transfer error flag. + * @rmtoll ISR TEIF2 LL_DMA_IsActiveFlag_TE2 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TE2(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TEIF2) == (DMA_ISR_TEIF2)); +} + +/** + * @brief Get Channel 3 transfer error flag. + * @rmtoll ISR TEIF3 LL_DMA_IsActiveFlag_TE3 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TE3(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TEIF3) == (DMA_ISR_TEIF3)); +} + +/** + * @brief Get Channel 4 transfer error flag. + * @rmtoll ISR TEIF4 LL_DMA_IsActiveFlag_TE4 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TE4(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TEIF4) == (DMA_ISR_TEIF4)); +} + +/** + * @brief Get Channel 5 transfer error flag. + * @rmtoll ISR TEIF5 LL_DMA_IsActiveFlag_TE5 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TE5(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TEIF5) == (DMA_ISR_TEIF5)); +} + +#if defined(DMA1_Channel6) +/** + * @brief Get Channel 6 transfer error flag. + * @rmtoll ISR TEIF6 LL_DMA_IsActiveFlag_TE6 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TE6(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TEIF6) == (DMA_ISR_TEIF6)); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Get Channel 7 transfer error flag. + * @rmtoll ISR TEIF7 LL_DMA_IsActiveFlag_TE7 + * @param DMAx DMAx Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsActiveFlag_TE7(DMA_TypeDef *DMAx) +{ + return (READ_BIT(DMAx->ISR, DMA_ISR_TEIF7) == (DMA_ISR_TEIF7)); +} +#endif + +/** + * @brief Clear Channel 1 global interrupt flag. + * @note Do not Clear Channel 1 global interrupt flag when the channel in ON. + Instead clear specific flags transfer complete, half transfer & transfer + error flag with LL_DMA_ClearFlag_TC1, LL_DMA_ClearFlag_HT1, + LL_DMA_ClearFlag_TE1. bug id 2.4.1 in Product Errata Sheet. + * @rmtoll IFCR CGIF1 LL_DMA_ClearFlag_GI1 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_GI1(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CGIF1); +} + +/** + * @brief Clear Channel 2 global interrupt flag. + * @note Do not Clear Channel 2 global interrupt flag when the channel in ON. + Instead clear specific flags transfer complete, half transfer & transfer + error flag with LL_DMA_ClearFlag_TC2, LL_DMA_ClearFlag_HT2, + LL_DMA_ClearFlag_TE2. bug id 2.4.1 in Product Errata Sheet. + * @rmtoll IFCR CGIF2 LL_DMA_ClearFlag_GI2 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_GI2(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CGIF2); +} + +/** + * @brief Clear Channel 3 global interrupt flag. + * @note Do not Clear Channel 3 global interrupt flag when the channel in ON. + Instead clear specific flags transfer complete, half transfer & transfer + error flag with LL_DMA_ClearFlag_TC3, LL_DMA_ClearFlag_HT3, + LL_DMA_ClearFlag_TE3. bug id 2.4.1 in Product Errata Sheet. + * @rmtoll IFCR CGIF3 LL_DMA_ClearFlag_GI3 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_GI3(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CGIF3); +} + +/** + * @brief Clear Channel 4 global interrupt flag. + * @note Do not Clear Channel 4 global interrupt flag when the channel in ON. + Instead clear specific flags transfer complete, half transfer & transfer + error flag with LL_DMA_ClearFlag_TC4, LL_DMA_ClearFlag_HT4, + LL_DMA_ClearFlag_TE4. bug id 2.4.1 in Product Errata Sheet. + * @rmtoll IFCR CGIF4 LL_DMA_ClearFlag_GI4 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_GI4(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CGIF4); +} + +/** + * @brief Clear Channel 5 global interrupt flag. + * @note Do not Clear Channel 5 global interrupt flag when the channel in ON. + Instead clear specific flags transfer complete, half transfer & transfer + error flag with LL_DMA_ClearFlag_TC5, LL_DMA_ClearFlag_HT5, + LL_DMA_ClearFlag_TE5. bug id 2.4.1 in Product Errata Sheet. + * @rmtoll IFCR CGIF5 LL_DMA_ClearFlag_GI5 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_GI5(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CGIF5); +} + +#if defined(DMA1_Channel6) +/** + * @brief Clear Channel 6 global interrupt flag. + * @note Do not Clear Channel 6 global interrupt flag when the channel in ON. + Instead clear specific flags transfer complete, half transfer & transfer + error flag with LL_DMA_ClearFlag_TC6, LL_DMA_ClearFlag_HT6, + LL_DMA_ClearFlag_TE6. bug id 2.4.1 in Product Errata Sheet. + * @rmtoll IFCR CGIF6 LL_DMA_ClearFlag_GI6 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_GI6(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CGIF6); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Clear Channel 7 global interrupt flag. + * @note Do not Clear Channel 7 global interrupt flag when the channel in ON. + Instead clear specific flags transfer complete, half transfer & transfer + error flag with LL_DMA_ClearFlag_TC7, LL_DMA_ClearFlag_HT7, + LL_DMA_ClearFlag_TE7. bug id 2.4.1 in Product Errata Sheet. + * @rmtoll IFCR CGIF7 LL_DMA_ClearFlag_GI7 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_GI7(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CGIF7); +} +#endif + +/** + * @brief Clear Channel 1 transfer complete flag. + * @rmtoll IFCR CTCIF1 LL_DMA_ClearFlag_TC1 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TC1(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTCIF1); +} + +/** + * @brief Clear Channel 2 transfer complete flag. + * @rmtoll IFCR CTCIF2 LL_DMA_ClearFlag_TC2 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TC2(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTCIF2); +} + +/** + * @brief Clear Channel 3 transfer complete flag. + * @rmtoll IFCR CTCIF3 LL_DMA_ClearFlag_TC3 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TC3(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTCIF3); +} + +/** + * @brief Clear Channel 4 transfer complete flag. + * @rmtoll IFCR CTCIF4 LL_DMA_ClearFlag_TC4 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TC4(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTCIF4); +} + +/** + * @brief Clear Channel 5 transfer complete flag. + * @rmtoll IFCR CTCIF5 LL_DMA_ClearFlag_TC5 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TC5(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTCIF5); +} + +#if defined(DMA1_Channel6) +/** + * @brief Clear Channel 6 transfer complete flag. + * @rmtoll IFCR CTCIF6 LL_DMA_ClearFlag_TC6 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TC6(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTCIF6); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Clear Channel 7 transfer complete flag. + * @rmtoll IFCR CTCIF7 LL_DMA_ClearFlag_TC7 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TC7(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTCIF7); +} +#endif + +/** + * @brief Clear Channel 1 half transfer flag. + * @rmtoll IFCR CHTIF1 LL_DMA_ClearFlag_HT1 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_HT1(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CHTIF1); +} + +/** + * @brief Clear Channel 2 half transfer flag. + * @rmtoll IFCR CHTIF2 LL_DMA_ClearFlag_HT2 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_HT2(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CHTIF2); +} + +/** + * @brief Clear Channel 3 half transfer flag. + * @rmtoll IFCR CHTIF3 LL_DMA_ClearFlag_HT3 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_HT3(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CHTIF3); +} + +/** + * @brief Clear Channel 4 half transfer flag. + * @rmtoll IFCR CHTIF4 LL_DMA_ClearFlag_HT4 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_HT4(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CHTIF4); +} + +/** + * @brief Clear Channel 5 half transfer flag. + * @rmtoll IFCR CHTIF5 LL_DMA_ClearFlag_HT5 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_HT5(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CHTIF5); +} + +#if defined(DMA1_Channel6) +/** + * @brief Clear Channel 6 half transfer flag. + * @rmtoll IFCR CHTIF6 LL_DMA_ClearFlag_HT6 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_HT6(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CHTIF6); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Clear Channel 7 half transfer flag. + * @rmtoll IFCR CHTIF7 LL_DMA_ClearFlag_HT7 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_HT7(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CHTIF7); +} +#endif + +/** + * @brief Clear Channel 1 transfer error flag. + * @rmtoll IFCR CTEIF1 LL_DMA_ClearFlag_TE1 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TE1(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTEIF1); +} + +/** + * @brief Clear Channel 2 transfer error flag. + * @rmtoll IFCR CTEIF2 LL_DMA_ClearFlag_TE2 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TE2(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTEIF2); +} + +/** + * @brief Clear Channel 3 transfer error flag. + * @rmtoll IFCR CTEIF3 LL_DMA_ClearFlag_TE3 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TE3(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTEIF3); +} + +/** + * @brief Clear Channel 4 transfer error flag. + * @rmtoll IFCR CTEIF4 LL_DMA_ClearFlag_TE4 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TE4(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTEIF4); +} + +/** + * @brief Clear Channel 5 transfer error flag. + * @rmtoll IFCR CTEIF5 LL_DMA_ClearFlag_TE5 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TE5(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTEIF5); +} + +#if defined(DMA1_Channel6) +/** + * @brief Clear Channel 6 transfer error flag. + * @rmtoll IFCR CTEIF6 LL_DMA_ClearFlag_TE6 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TE6(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTEIF6); +} +#endif + +#if defined(DMA1_Channel7) +/** + * @brief Clear Channel 7 transfer error flag. + * @rmtoll IFCR CTEIF7 LL_DMA_ClearFlag_TE7 + * @param DMAx DMAx Instance + * @retval None + */ +__STATIC_INLINE void LL_DMA_ClearFlag_TE7(DMA_TypeDef *DMAx) +{ + WRITE_REG(DMAx->IFCR, DMA_IFCR_CTEIF7); +} +#endif + +/** + * @} + */ + +/** @defgroup DMA_LL_EF_IT_Management IT_Management + * @{ + */ +/** + * @brief Enable Transfer complete interrupt. + * @rmtoll CCR TCIE LL_DMA_EnableIT_TC + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_EnableIT_TC(DMA_TypeDef *DMAx, uint32_t Channel) +{ + SET_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_TCIE); +} + +/** + * @brief Enable Half transfer interrupt. + * @rmtoll CCR HTIE LL_DMA_EnableIT_HT + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_EnableIT_HT(DMA_TypeDef *DMAx, uint32_t Channel) +{ + SET_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_HTIE); +} + +/** + * @brief Enable Transfer error interrupt. + * @rmtoll CCR TEIE LL_DMA_EnableIT_TE + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_EnableIT_TE(DMA_TypeDef *DMAx, uint32_t Channel) +{ + SET_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_TEIE); +} + +/** + * @brief Disable Transfer complete interrupt. + * @rmtoll CCR TCIE LL_DMA_DisableIT_TC + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_DisableIT_TC(DMA_TypeDef *DMAx, uint32_t Channel) +{ + CLEAR_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_TCIE); +} + +/** + * @brief Disable Half transfer interrupt. + * @rmtoll CCR HTIE LL_DMA_DisableIT_HT + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_DisableIT_HT(DMA_TypeDef *DMAx, uint32_t Channel) +{ + CLEAR_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_HTIE); +} + +/** + * @brief Disable Transfer error interrupt. + * @rmtoll CCR TEIE LL_DMA_DisableIT_TE + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval None + */ +__STATIC_INLINE void LL_DMA_DisableIT_TE(DMA_TypeDef *DMAx, uint32_t Channel) +{ + CLEAR_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, DMA_CCR_TEIE); +} + +/** + * @brief Check if Transfer complete Interrupt is enabled. + * @rmtoll CCR TCIE LL_DMA_IsEnabledIT_TC + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsEnabledIT_TC(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_TCIE) == (DMA_CCR_TCIE)); +} + +/** + * @brief Check if Half transfer Interrupt is enabled. + * @rmtoll CCR HTIE LL_DMA_IsEnabledIT_HT + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsEnabledIT_HT(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_HTIE) == (DMA_CCR_HTIE)); +} + +/** + * @brief Check if Transfer error Interrupt is enabled. + * @rmtoll CCR TEIE LL_DMA_IsEnabledIT_TE + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 + * @arg @ref LL_DMA_CHANNEL_7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_DMA_IsEnabledIT_TE(DMA_TypeDef *DMAx, uint32_t Channel) +{ + return (READ_BIT(((DMA_Channel_TypeDef *)((uint32_t)((uint32_t)DMAx + CHANNEL_OFFSET_TAB[Channel - 1U])))->CCR, + DMA_CCR_TEIE) == (DMA_CCR_TEIE)); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup DMA_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +uint32_t LL_DMA_Init(DMA_TypeDef *DMAx, uint32_t Channel, LL_DMA_InitTypeDef *DMA_InitStruct); +uint32_t LL_DMA_DeInit(DMA_TypeDef *DMAx, uint32_t Channel); +void LL_DMA_StructInit(LL_DMA_InitTypeDef *DMA_InitStruct); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* DMA1 || DMA2 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_DMA_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_exti.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_exti.h new file mode 100644 index 0000000..b26dc0a --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_exti.h @@ -0,0 +1,1016 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_exti.h + * @author MCD Application Team + * @brief Header file of EXTI LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_EXTI_H +#define __STM32F0xx_LL_EXTI_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (EXTI) + +/** @defgroup EXTI_LL EXTI + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private Macros ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup EXTI_LL_Private_Macros EXTI Private Macros + * @{ + */ +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup EXTI_LL_ES_INIT EXTI Exported Init structure + * @{ + */ +typedef struct +{ + + uint32_t Line_0_31; /*!< Specifies the EXTI lines to be enabled or disabled for Lines in range 0 to 31 + This parameter can be any combination of @ref EXTI_LL_EC_LINE */ + + FunctionalState LineCommand; /*!< Specifies the new state of the selected EXTI lines. + This parameter can be set either to ENABLE or DISABLE */ + + uint8_t Mode; /*!< Specifies the mode for the EXTI lines. + This parameter can be a value of @ref EXTI_LL_EC_MODE. */ + + uint8_t Trigger; /*!< Specifies the trigger signal active edge for the EXTI lines. + This parameter can be a value of @ref EXTI_LL_EC_TRIGGER. */ +} LL_EXTI_InitTypeDef; + +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup EXTI_LL_Exported_Constants EXTI Exported Constants + * @{ + */ + +/** @defgroup EXTI_LL_EC_LINE LINE + * @{ + */ +#define LL_EXTI_LINE_0 EXTI_IMR_IM0 /*!< Extended line 0 */ +#define LL_EXTI_LINE_1 EXTI_IMR_IM1 /*!< Extended line 1 */ +#define LL_EXTI_LINE_2 EXTI_IMR_IM2 /*!< Extended line 2 */ +#define LL_EXTI_LINE_3 EXTI_IMR_IM3 /*!< Extended line 3 */ +#define LL_EXTI_LINE_4 EXTI_IMR_IM4 /*!< Extended line 4 */ +#define LL_EXTI_LINE_5 EXTI_IMR_IM5 /*!< Extended line 5 */ +#define LL_EXTI_LINE_6 EXTI_IMR_IM6 /*!< Extended line 6 */ +#define LL_EXTI_LINE_7 EXTI_IMR_IM7 /*!< Extended line 7 */ +#define LL_EXTI_LINE_8 EXTI_IMR_IM8 /*!< Extended line 8 */ +#define LL_EXTI_LINE_9 EXTI_IMR_IM9 /*!< Extended line 9 */ +#define LL_EXTI_LINE_10 EXTI_IMR_IM10 /*!< Extended line 10 */ +#define LL_EXTI_LINE_11 EXTI_IMR_IM11 /*!< Extended line 11 */ +#define LL_EXTI_LINE_12 EXTI_IMR_IM12 /*!< Extended line 12 */ +#define LL_EXTI_LINE_13 EXTI_IMR_IM13 /*!< Extended line 13 */ +#define LL_EXTI_LINE_14 EXTI_IMR_IM14 /*!< Extended line 14 */ +#define LL_EXTI_LINE_15 EXTI_IMR_IM15 /*!< Extended line 15 */ +#if defined(EXTI_IMR_IM16) +#define LL_EXTI_LINE_16 EXTI_IMR_IM16 /*!< Extended line 16 */ +#endif +#define LL_EXTI_LINE_17 EXTI_IMR_IM17 /*!< Extended line 17 */ +#if defined(EXTI_IMR_IM18) +#define LL_EXTI_LINE_18 EXTI_IMR_IM18 /*!< Extended line 18 */ +#endif +#define LL_EXTI_LINE_19 EXTI_IMR_IM19 /*!< Extended line 19 */ +#if defined(EXTI_IMR_IM20) +#define LL_EXTI_LINE_20 EXTI_IMR_IM20 /*!< Extended line 20 */ +#endif +#if defined(EXTI_IMR_IM21) +#define LL_EXTI_LINE_21 EXTI_IMR_IM21 /*!< Extended line 21 */ +#endif +#if defined(EXTI_IMR_IM22) +#define LL_EXTI_LINE_22 EXTI_IMR_IM22 /*!< Extended line 22 */ +#endif +#define LL_EXTI_LINE_23 EXTI_IMR_IM23 /*!< Extended line 23 */ +#if defined(EXTI_IMR_IM24) +#define LL_EXTI_LINE_24 EXTI_IMR_IM24 /*!< Extended line 24 */ +#endif +#if defined(EXTI_IMR_IM25) +#define LL_EXTI_LINE_25 EXTI_IMR_IM25 /*!< Extended line 25 */ +#endif +#if defined(EXTI_IMR_IM26) +#define LL_EXTI_LINE_26 EXTI_IMR_IM26 /*!< Extended line 26 */ +#endif +#if defined(EXTI_IMR_IM27) +#define LL_EXTI_LINE_27 EXTI_IMR_IM27 /*!< Extended line 27 */ +#endif +#if defined(EXTI_IMR_IM28) +#define LL_EXTI_LINE_28 EXTI_IMR_IM28 /*!< Extended line 28 */ +#endif +#if defined(EXTI_IMR_IM29) +#define LL_EXTI_LINE_29 EXTI_IMR_IM29 /*!< Extended line 29 */ +#endif +#if defined(EXTI_IMR_IM30) +#define LL_EXTI_LINE_30 EXTI_IMR_IM30 /*!< Extended line 30 */ +#endif +#if defined(EXTI_IMR_IM31) +#define LL_EXTI_LINE_31 EXTI_IMR_IM31 /*!< Extended line 31 */ +#endif +#define LL_EXTI_LINE_ALL_0_31 EXTI_IMR_IM /*!< All Extended line not reserved*/ + + +#define LL_EXTI_LINE_ALL (0xFFFFFFFFU) /*!< All Extended line */ + +#if defined(USE_FULL_LL_DRIVER) +#define LL_EXTI_LINE_NONE (0x00000000U) /*!< None Extended line */ +#endif /*USE_FULL_LL_DRIVER*/ + +/** + * @} + */ +#if defined(USE_FULL_LL_DRIVER) + +/** @defgroup EXTI_LL_EC_MODE Mode + * @{ + */ +#define LL_EXTI_MODE_IT ((uint8_t)0x00U) /*!< Interrupt Mode */ +#define LL_EXTI_MODE_EVENT ((uint8_t)0x01U) /*!< Event Mode */ +#define LL_EXTI_MODE_IT_EVENT ((uint8_t)0x02U) /*!< Interrupt & Event Mode */ +/** + * @} + */ + +/** @defgroup EXTI_LL_EC_TRIGGER Edge Trigger + * @{ + */ +#define LL_EXTI_TRIGGER_NONE ((uint8_t)0x00U) /*!< No Trigger Mode */ +#define LL_EXTI_TRIGGER_RISING ((uint8_t)0x01U) /*!< Trigger Rising Mode */ +#define LL_EXTI_TRIGGER_FALLING ((uint8_t)0x02U) /*!< Trigger Falling Mode */ +#define LL_EXTI_TRIGGER_RISING_FALLING ((uint8_t)0x03U) /*!< Trigger Rising & Falling Mode */ + +/** + * @} + */ + + +#endif /*USE_FULL_LL_DRIVER*/ + + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup EXTI_LL_Exported_Macros EXTI Exported Macros + * @{ + */ + +/** @defgroup EXTI_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in EXTI register + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_EXTI_WriteReg(__REG__, __VALUE__) WRITE_REG(EXTI->__REG__, (__VALUE__)) + +/** + * @brief Read a value in EXTI register + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_EXTI_ReadReg(__REG__) READ_REG(EXTI->__REG__) +/** + * @} + */ + + +/** + * @} + */ + + + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup EXTI_LL_Exported_Functions EXTI Exported Functions + * @{ + */ +/** @defgroup EXTI_LL_EF_IT_Management IT_Management + * @{ + */ + +/** + * @brief Enable ExtiLine Interrupt request for Lines in range 0 to 31 + * @note The reset value for the direct or internal lines (see RM) + * is set to 1 in order to enable the interrupt by default. + * Bits are set automatically at Power on. + * @rmtoll IMR IMx LL_EXTI_EnableIT_0_31 + * @param ExtiLine This parameter can be one of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_17 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_23 + * @arg @ref LL_EXTI_LINE_24 + * @arg @ref LL_EXTI_LINE_25 + * @arg @ref LL_EXTI_LINE_26 + * @arg @ref LL_EXTI_LINE_27 + * @arg @ref LL_EXTI_LINE_28 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @arg @ref LL_EXTI_LINE_ALL_0_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_EnableIT_0_31(uint32_t ExtiLine) +{ + SET_BIT(EXTI->IMR, ExtiLine); +} + +/** + * @brief Disable ExtiLine Interrupt request for Lines in range 0 to 31 + * @note The reset value for the direct or internal lines (see RM) + * is set to 1 in order to enable the interrupt by default. + * Bits are set automatically at Power on. + * @rmtoll IMR IMx LL_EXTI_DisableIT_0_31 + * @param ExtiLine This parameter can be one of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_17 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_23 + * @arg @ref LL_EXTI_LINE_24 + * @arg @ref LL_EXTI_LINE_25 + * @arg @ref LL_EXTI_LINE_26 + * @arg @ref LL_EXTI_LINE_27 + * @arg @ref LL_EXTI_LINE_28 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @arg @ref LL_EXTI_LINE_ALL_0_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_DisableIT_0_31(uint32_t ExtiLine) +{ + CLEAR_BIT(EXTI->IMR, ExtiLine); +} + + +/** + * @brief Indicate if ExtiLine Interrupt request is enabled for Lines in range 0 to 31 + * @note The reset value for the direct or internal lines (see RM) + * is set to 1 in order to enable the interrupt by default. + * Bits are set automatically at Power on. + * @rmtoll IMR IMx LL_EXTI_IsEnabledIT_0_31 + * @param ExtiLine This parameter can be one of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_17 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_23 + * @arg @ref LL_EXTI_LINE_24 + * @arg @ref LL_EXTI_LINE_25 + * @arg @ref LL_EXTI_LINE_26 + * @arg @ref LL_EXTI_LINE_27 + * @arg @ref LL_EXTI_LINE_28 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @arg @ref LL_EXTI_LINE_ALL_0_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_EXTI_IsEnabledIT_0_31(uint32_t ExtiLine) +{ + return (READ_BIT(EXTI->IMR, ExtiLine) == (ExtiLine)); +} + + +/** + * @} + */ + +/** @defgroup EXTI_LL_EF_Event_Management Event_Management + * @{ + */ + +/** + * @brief Enable ExtiLine Event request for Lines in range 0 to 31 + * @rmtoll EMR EMx LL_EXTI_EnableEvent_0_31 + * @param ExtiLine This parameter can be one of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_17 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_23 + * @arg @ref LL_EXTI_LINE_24 + * @arg @ref LL_EXTI_LINE_25 + * @arg @ref LL_EXTI_LINE_26 + * @arg @ref LL_EXTI_LINE_27 + * @arg @ref LL_EXTI_LINE_28 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @arg @ref LL_EXTI_LINE_ALL_0_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_EnableEvent_0_31(uint32_t ExtiLine) +{ + SET_BIT(EXTI->EMR, ExtiLine); + +} + + +/** + * @brief Disable ExtiLine Event request for Lines in range 0 to 31 + * @rmtoll EMR EMx LL_EXTI_DisableEvent_0_31 + * @param ExtiLine This parameter can be one of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_17 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_23 + * @arg @ref LL_EXTI_LINE_24 + * @arg @ref LL_EXTI_LINE_25 + * @arg @ref LL_EXTI_LINE_26 + * @arg @ref LL_EXTI_LINE_27 + * @arg @ref LL_EXTI_LINE_28 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @arg @ref LL_EXTI_LINE_ALL_0_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_DisableEvent_0_31(uint32_t ExtiLine) +{ + CLEAR_BIT(EXTI->EMR, ExtiLine); +} + + +/** + * @brief Indicate if ExtiLine Event request is enabled for Lines in range 0 to 31 + * @rmtoll EMR EMx LL_EXTI_IsEnabledEvent_0_31 + * @param ExtiLine This parameter can be one of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_17 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_23 + * @arg @ref LL_EXTI_LINE_24 + * @arg @ref LL_EXTI_LINE_25 + * @arg @ref LL_EXTI_LINE_26 + * @arg @ref LL_EXTI_LINE_27 + * @arg @ref LL_EXTI_LINE_28 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @arg @ref LL_EXTI_LINE_ALL_0_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_EXTI_IsEnabledEvent_0_31(uint32_t ExtiLine) +{ + return (READ_BIT(EXTI->EMR, ExtiLine) == (ExtiLine)); + +} + + +/** + * @} + */ + +/** @defgroup EXTI_LL_EF_Rising_Trigger_Management Rising_Trigger_Management + * @{ + */ + +/** + * @brief Enable ExtiLine Rising Edge Trigger for Lines in range 0 to 31 + * @note The configurable wakeup lines are edge-triggered. No glitch must be + * generated on these lines. If a rising edge on a configurable interrupt + * line occurs during a write operation in the EXTI_RTSR register, the + * pending bit is not set. + * Rising and falling edge triggers can be set for + * the same interrupt line. In this case, both generate a trigger + * condition. + * @rmtoll RTSR RTx LL_EXTI_EnableRisingTrig_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_EnableRisingTrig_0_31(uint32_t ExtiLine) +{ + SET_BIT(EXTI->RTSR, ExtiLine); + +} + + +/** + * @brief Disable ExtiLine Rising Edge Trigger for Lines in range 0 to 31 + * @note The configurable wakeup lines are edge-triggered. No glitch must be + * generated on these lines. If a rising edge on a configurable interrupt + * line occurs during a write operation in the EXTI_RTSR register, the + * pending bit is not set. + * Rising and falling edge triggers can be set for + * the same interrupt line. In this case, both generate a trigger + * condition. + * @rmtoll RTSR RTx LL_EXTI_DisableRisingTrig_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_DisableRisingTrig_0_31(uint32_t ExtiLine) +{ + CLEAR_BIT(EXTI->RTSR, ExtiLine); + +} + + +/** + * @brief Check if rising edge trigger is enabled for Lines in range 0 to 31 + * @rmtoll RTSR RTx LL_EXTI_IsEnabledRisingTrig_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_EXTI_IsEnabledRisingTrig_0_31(uint32_t ExtiLine) +{ + return (READ_BIT(EXTI->RTSR, ExtiLine) == (ExtiLine)); +} + + +/** + * @} + */ + +/** @defgroup EXTI_LL_EF_Falling_Trigger_Management Falling_Trigger_Management + * @{ + */ + +/** + * @brief Enable ExtiLine Falling Edge Trigger for Lines in range 0 to 31 + * @note The configurable wakeup lines are edge-triggered. No glitch must be + * generated on these lines. If a falling edge on a configurable interrupt + * line occurs during a write operation in the EXTI_FTSR register, the + * pending bit is not set. + * Rising and falling edge triggers can be set for + * the same interrupt line. In this case, both generate a trigger + * condition. + * @rmtoll FTSR FTx LL_EXTI_EnableFallingTrig_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_EnableFallingTrig_0_31(uint32_t ExtiLine) +{ + SET_BIT(EXTI->FTSR, ExtiLine); +} + + +/** + * @brief Disable ExtiLine Falling Edge Trigger for Lines in range 0 to 31 + * @note The configurable wakeup lines are edge-triggered. No glitch must be + * generated on these lines. If a Falling edge on a configurable interrupt + * line occurs during a write operation in the EXTI_FTSR register, the + * pending bit is not set. + * Rising and falling edge triggers can be set for the same interrupt line. + * In this case, both generate a trigger condition. + * @rmtoll FTSR FTx LL_EXTI_DisableFallingTrig_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_DisableFallingTrig_0_31(uint32_t ExtiLine) +{ + CLEAR_BIT(EXTI->FTSR, ExtiLine); +} + + +/** + * @brief Check if falling edge trigger is enabled for Lines in range 0 to 31 + * @rmtoll FTSR FTx LL_EXTI_IsEnabledFallingTrig_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_EXTI_IsEnabledFallingTrig_0_31(uint32_t ExtiLine) +{ + return (READ_BIT(EXTI->FTSR, ExtiLine) == (ExtiLine)); +} + + +/** + * @} + */ + +/** @defgroup EXTI_LL_EF_Software_Interrupt_Management Software_Interrupt_Management + * @{ + */ + +/** + * @brief Generate a software Interrupt Event for Lines in range 0 to 31 + * @note If the interrupt is enabled on this line in the EXTI_IMR, writing a 1 to + * this bit when it is at '0' sets the corresponding pending bit in EXTI_PR + * resulting in an interrupt request generation. + * This bit is cleared by clearing the corresponding bit in the EXTI_PR + * register (by writing a 1 into the bit) + * @rmtoll SWIER SWIx LL_EXTI_GenerateSWI_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_GenerateSWI_0_31(uint32_t ExtiLine) +{ + SET_BIT(EXTI->SWIER, ExtiLine); +} + + +/** + * @} + */ + +/** @defgroup EXTI_LL_EF_Flag_Management Flag_Management + * @{ + */ + +/** + * @brief Check if the ExtLine Flag is set or not for Lines in range 0 to 31 + * @note This bit is set when the selected edge event arrives on the interrupt + * line. This bit is cleared by writing a 1 to the bit. + * @rmtoll PR PIFx LL_EXTI_IsActiveFlag_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_EXTI_IsActiveFlag_0_31(uint32_t ExtiLine) +{ + return (READ_BIT(EXTI->PR, ExtiLine) == (ExtiLine)); +} + + +/** + * @brief Read ExtLine Combination Flag for Lines in range 0 to 31 + * @note This bit is set when the selected edge event arrives on the interrupt + * line. This bit is cleared by writing a 1 to the bit. + * @rmtoll PR PIFx LL_EXTI_ReadFlag_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval @note This bit is set when the selected edge event arrives on the interrupt + */ +__STATIC_INLINE uint32_t LL_EXTI_ReadFlag_0_31(uint32_t ExtiLine) +{ + return (uint32_t)(READ_BIT(EXTI->PR, ExtiLine)); +} + + +/** + * @brief Clear ExtLine Flags for Lines in range 0 to 31 + * @note This bit is set when the selected edge event arrives on the interrupt + * line. This bit is cleared by writing a 1 to the bit. + * @rmtoll PR PIFx LL_EXTI_ClearFlag_0_31 + * @param ExtiLine This parameter can be a combination of the following values: + * @arg @ref LL_EXTI_LINE_0 + * @arg @ref LL_EXTI_LINE_1 + * @arg @ref LL_EXTI_LINE_2 + * @arg @ref LL_EXTI_LINE_3 + * @arg @ref LL_EXTI_LINE_4 + * @arg @ref LL_EXTI_LINE_5 + * @arg @ref LL_EXTI_LINE_6 + * @arg @ref LL_EXTI_LINE_7 + * @arg @ref LL_EXTI_LINE_8 + * @arg @ref LL_EXTI_LINE_9 + * @arg @ref LL_EXTI_LINE_10 + * @arg @ref LL_EXTI_LINE_11 + * @arg @ref LL_EXTI_LINE_12 + * @arg @ref LL_EXTI_LINE_13 + * @arg @ref LL_EXTI_LINE_14 + * @arg @ref LL_EXTI_LINE_15 + * @arg @ref LL_EXTI_LINE_16 + * @arg @ref LL_EXTI_LINE_18 + * @arg @ref LL_EXTI_LINE_19 + * @arg @ref LL_EXTI_LINE_20 + * @arg @ref LL_EXTI_LINE_21 + * @arg @ref LL_EXTI_LINE_22 + * @arg @ref LL_EXTI_LINE_29 + * @arg @ref LL_EXTI_LINE_30 + * @arg @ref LL_EXTI_LINE_31 + * @note Please check each device line mapping for EXTI Line availability + * @retval None + */ +__STATIC_INLINE void LL_EXTI_ClearFlag_0_31(uint32_t ExtiLine) +{ + WRITE_REG(EXTI->PR, ExtiLine); +} + + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup EXTI_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +uint32_t LL_EXTI_Init(LL_EXTI_InitTypeDef *EXTI_InitStruct); +uint32_t LL_EXTI_DeInit(void); +void LL_EXTI_StructInit(LL_EXTI_InitTypeDef *EXTI_InitStruct); + + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* EXTI */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_EXTI_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_gpio.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_gpio.h new file mode 100644 index 0000000..bd4460e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_gpio.h @@ -0,0 +1,940 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_gpio.h + * @author MCD Application Team + * @brief Header file of GPIO LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_GPIO_H +#define __STM32F0xx_LL_GPIO_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (GPIOA) || defined (GPIOB) || defined (GPIOC) || defined (GPIOD) || defined (GPIOE) || defined (GPIOF) + +/** @defgroup GPIO_LL GPIO + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup GPIO_LL_Private_Macros GPIO Private Macros + * @{ + */ + +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup GPIO_LL_ES_INIT GPIO Exported Init structures + * @{ + */ + +/** + * @brief LL GPIO Init Structure definition + */ +typedef struct +{ + uint32_t Pin; /*!< Specifies the GPIO pins to be configured. + This parameter can be any value of @ref GPIO_LL_EC_PIN */ + + uint32_t Mode; /*!< Specifies the operating mode for the selected pins. + This parameter can be a value of @ref GPIO_LL_EC_MODE. + + GPIO HW configuration can be modified afterwards using unitary function @ref LL_GPIO_SetPinMode().*/ + + uint32_t Speed; /*!< Specifies the speed for the selected pins. + This parameter can be a value of @ref GPIO_LL_EC_SPEED. + + GPIO HW configuration can be modified afterwards using unitary function @ref LL_GPIO_SetPinSpeed().*/ + + uint32_t OutputType; /*!< Specifies the operating output type for the selected pins. + This parameter can be a value of @ref GPIO_LL_EC_OUTPUT. + + GPIO HW configuration can be modified afterwards using unitary function @ref LL_GPIO_SetPinOutputType().*/ + + uint32_t Pull; /*!< Specifies the operating Pull-up/Pull down for the selected pins. + This parameter can be a value of @ref GPIO_LL_EC_PULL. + + GPIO HW configuration can be modified afterwards using unitary function @ref LL_GPIO_SetPinPull().*/ + + uint32_t Alternate; /*!< Specifies the Peripheral to be connected to the selected pins. + This parameter can be a value of @ref GPIO_LL_EC_AF. + + GPIO HW configuration can be modified afterwards using unitary function @ref LL_GPIO_SetAFPin_0_7() and LL_GPIO_SetAFPin_8_15().*/ +} LL_GPIO_InitTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup GPIO_LL_Exported_Constants GPIO Exported Constants + * @{ + */ + +/** @defgroup GPIO_LL_EC_PIN PIN + * @{ + */ +#define LL_GPIO_PIN_0 GPIO_BSRR_BS_0 /*!< Select pin 0 */ +#define LL_GPIO_PIN_1 GPIO_BSRR_BS_1 /*!< Select pin 1 */ +#define LL_GPIO_PIN_2 GPIO_BSRR_BS_2 /*!< Select pin 2 */ +#define LL_GPIO_PIN_3 GPIO_BSRR_BS_3 /*!< Select pin 3 */ +#define LL_GPIO_PIN_4 GPIO_BSRR_BS_4 /*!< Select pin 4 */ +#define LL_GPIO_PIN_5 GPIO_BSRR_BS_5 /*!< Select pin 5 */ +#define LL_GPIO_PIN_6 GPIO_BSRR_BS_6 /*!< Select pin 6 */ +#define LL_GPIO_PIN_7 GPIO_BSRR_BS_7 /*!< Select pin 7 */ +#define LL_GPIO_PIN_8 GPIO_BSRR_BS_8 /*!< Select pin 8 */ +#define LL_GPIO_PIN_9 GPIO_BSRR_BS_9 /*!< Select pin 9 */ +#define LL_GPIO_PIN_10 GPIO_BSRR_BS_10 /*!< Select pin 10 */ +#define LL_GPIO_PIN_11 GPIO_BSRR_BS_11 /*!< Select pin 11 */ +#define LL_GPIO_PIN_12 GPIO_BSRR_BS_12 /*!< Select pin 12 */ +#define LL_GPIO_PIN_13 GPIO_BSRR_BS_13 /*!< Select pin 13 */ +#define LL_GPIO_PIN_14 GPIO_BSRR_BS_14 /*!< Select pin 14 */ +#define LL_GPIO_PIN_15 GPIO_BSRR_BS_15 /*!< Select pin 15 */ +#define LL_GPIO_PIN_ALL (GPIO_BSRR_BS_0 | GPIO_BSRR_BS_1 | GPIO_BSRR_BS_2 | \ + GPIO_BSRR_BS_3 | GPIO_BSRR_BS_4 | GPIO_BSRR_BS_5 | \ + GPIO_BSRR_BS_6 | GPIO_BSRR_BS_7 | GPIO_BSRR_BS_8 | \ + GPIO_BSRR_BS_9 | GPIO_BSRR_BS_10 | GPIO_BSRR_BS_11 | \ + GPIO_BSRR_BS_12 | GPIO_BSRR_BS_13 | GPIO_BSRR_BS_14 | \ + GPIO_BSRR_BS_15) /*!< Select all pins */ +/** + * @} + */ + +/** @defgroup GPIO_LL_EC_MODE Mode + * @{ + */ +#define LL_GPIO_MODE_INPUT (0x00000000U) /*!< Select input mode */ +#define LL_GPIO_MODE_OUTPUT GPIO_MODER_MODER0_0 /*!< Select output mode */ +#define LL_GPIO_MODE_ALTERNATE GPIO_MODER_MODER0_1 /*!< Select alternate function mode */ +#define LL_GPIO_MODE_ANALOG GPIO_MODER_MODER0 /*!< Select analog mode */ +/** + * @} + */ + +/** @defgroup GPIO_LL_EC_OUTPUT Output Type + * @{ + */ +#define LL_GPIO_OUTPUT_PUSHPULL (0x00000000U) /*!< Select push-pull as output type */ +#define LL_GPIO_OUTPUT_OPENDRAIN GPIO_OTYPER_OT_0 /*!< Select open-drain as output type */ +/** + * @} + */ + +/** @defgroup GPIO_LL_EC_SPEED Output Speed + * @{ + */ +#define LL_GPIO_SPEED_FREQ_LOW (0x00000000U) /*!< Select I/O low output speed */ +#define LL_GPIO_SPEED_FREQ_MEDIUM GPIO_OSPEEDR_OSPEEDR0_0 /*!< Select I/O medium output speed */ +#define LL_GPIO_SPEED_FREQ_HIGH GPIO_OSPEEDR_OSPEEDR0 /*!< Select I/O high output speed */ +/** + * @} + */ +#define LL_GPIO_SPEED_LOW LL_GPIO_SPEED_FREQ_LOW +#define LL_GPIO_SPEED_MEDIUM LL_GPIO_SPEED_FREQ_MEDIUM +#define LL_GPIO_SPEED_HIGH LL_GPIO_SPEED_FREQ_HIGH + +/** @defgroup GPIO_LL_EC_PULL Pull Up Pull Down + * @{ + */ +#define LL_GPIO_PULL_NO (0x00000000U) /*!< Select I/O no pull */ +#define LL_GPIO_PULL_UP GPIO_PUPDR_PUPDR0_0 /*!< Select I/O pull up */ +#define LL_GPIO_PULL_DOWN GPIO_PUPDR_PUPDR0_1 /*!< Select I/O pull down */ +/** + * @} + */ + +/** @defgroup GPIO_LL_EC_AF Alternate Function + * @{ + */ +#define LL_GPIO_AF_0 (0x0000000U) /*!< Select alternate function 0 */ +#define LL_GPIO_AF_1 (0x0000001U) /*!< Select alternate function 1 */ +#define LL_GPIO_AF_2 (0x0000002U) /*!< Select alternate function 2 */ +#define LL_GPIO_AF_3 (0x0000003U) /*!< Select alternate function 3 */ +#define LL_GPIO_AF_4 (0x0000004U) /*!< Select alternate function 4 */ +#define LL_GPIO_AF_5 (0x0000005U) /*!< Select alternate function 5 */ +#define LL_GPIO_AF_6 (0x0000006U) /*!< Select alternate function 6 */ +#define LL_GPIO_AF_7 (0x0000007U) /*!< Select alternate function 7 */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup GPIO_LL_Exported_Macros GPIO Exported Macros + * @{ + */ + +/** @defgroup GPIO_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in GPIO register + * @param __INSTANCE__ GPIO Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_GPIO_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in GPIO register + * @param __INSTANCE__ GPIO Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_GPIO_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup GPIO_LL_Exported_Functions GPIO Exported Functions + * @{ + */ + +/** @defgroup GPIO_LL_EF_Port_Configuration Port Configuration + * @{ + */ + +/** + * @brief Configure gpio mode for a dedicated pin on dedicated port. + * @note I/O mode can be Input mode, General purpose output, Alternate function mode or Analog. + * @note Warning: only one pin can be passed as parameter. + * @rmtoll MODER MODEy LL_GPIO_SetPinMode + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @param Mode This parameter can be one of the following values: + * @arg @ref LL_GPIO_MODE_INPUT + * @arg @ref LL_GPIO_MODE_OUTPUT + * @arg @ref LL_GPIO_MODE_ALTERNATE + * @arg @ref LL_GPIO_MODE_ANALOG + * @retval None + */ +__STATIC_INLINE void LL_GPIO_SetPinMode(GPIO_TypeDef *GPIOx, uint32_t Pin, uint32_t Mode) +{ + MODIFY_REG(GPIOx->MODER, ((Pin * Pin) * GPIO_MODER_MODER0), ((Pin * Pin) * Mode)); +} + +/** + * @brief Return gpio mode for a dedicated pin on dedicated port. + * @note I/O mode can be Input mode, General purpose output, Alternate function mode or Analog. + * @note Warning: only one pin can be passed as parameter. + * @rmtoll MODER MODEy LL_GPIO_GetPinMode + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @retval Returned value can be one of the following values: + * @arg @ref LL_GPIO_MODE_INPUT + * @arg @ref LL_GPIO_MODE_OUTPUT + * @arg @ref LL_GPIO_MODE_ALTERNATE + * @arg @ref LL_GPIO_MODE_ANALOG + */ +__STATIC_INLINE uint32_t LL_GPIO_GetPinMode(GPIO_TypeDef *GPIOx, uint32_t Pin) +{ + return (uint32_t)(READ_BIT(GPIOx->MODER, ((Pin * Pin) * GPIO_MODER_MODER0)) / (Pin * Pin)); +} + +/** + * @brief Configure gpio output type for several pins on dedicated port. + * @note Output type as to be set when gpio pin is in output or + * alternate modes. Possible type are Push-pull or Open-drain. + * @rmtoll OTYPER OTy LL_GPIO_SetPinOutputType + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @param OutputType This parameter can be one of the following values: + * @arg @ref LL_GPIO_OUTPUT_PUSHPULL + * @arg @ref LL_GPIO_OUTPUT_OPENDRAIN + * @retval None + */ +__STATIC_INLINE void LL_GPIO_SetPinOutputType(GPIO_TypeDef *GPIOx, uint32_t PinMask, uint32_t OutputType) +{ + MODIFY_REG(GPIOx->OTYPER, PinMask, (PinMask * OutputType)); +} + +/** + * @brief Return gpio output type for several pins on dedicated port. + * @note Output type as to be set when gpio pin is in output or + * alternate modes. Possible type are Push-pull or Open-drain. + * @note Warning: only one pin can be passed as parameter. + * @rmtoll OTYPER OTy LL_GPIO_GetPinOutputType + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval Returned value can be one of the following values: + * @arg @ref LL_GPIO_OUTPUT_PUSHPULL + * @arg @ref LL_GPIO_OUTPUT_OPENDRAIN + */ +__STATIC_INLINE uint32_t LL_GPIO_GetPinOutputType(GPIO_TypeDef *GPIOx, uint32_t Pin) +{ + return (uint32_t)(READ_BIT(GPIOx->OTYPER, Pin) / Pin); +} + +/** + * @brief Configure gpio speed for a dedicated pin on dedicated port. + * @note I/O speed can be Low, Medium, Fast or High speed. + * @note Warning: only one pin can be passed as parameter. + * @note Refer to datasheet for frequency specifications and the power + * supply and load conditions for each speed. + * @rmtoll OSPEEDR OSPEEDy LL_GPIO_SetPinSpeed + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @param Speed This parameter can be one of the following values: + * @arg @ref LL_GPIO_SPEED_FREQ_LOW + * @arg @ref LL_GPIO_SPEED_FREQ_MEDIUM + * @arg @ref LL_GPIO_SPEED_FREQ_HIGH + * @retval None + */ +__STATIC_INLINE void LL_GPIO_SetPinSpeed(GPIO_TypeDef *GPIOx, uint32_t Pin, uint32_t Speed) +{ + MODIFY_REG(GPIOx->OSPEEDR, ((Pin * Pin) * GPIO_OSPEEDR_OSPEEDR0), ((Pin * Pin) * Speed)); +} + +/** + * @brief Return gpio speed for a dedicated pin on dedicated port. + * @note I/O speed can be Low, Medium, Fast or High speed. + * @note Warning: only one pin can be passed as parameter. + * @note Refer to datasheet for frequency specifications and the power + * supply and load conditions for each speed. + * @rmtoll OSPEEDR OSPEEDy LL_GPIO_GetPinSpeed + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @retval Returned value can be one of the following values: + * @arg @ref LL_GPIO_SPEED_FREQ_LOW + * @arg @ref LL_GPIO_SPEED_FREQ_MEDIUM + * @arg @ref LL_GPIO_SPEED_FREQ_HIGH + */ +__STATIC_INLINE uint32_t LL_GPIO_GetPinSpeed(GPIO_TypeDef *GPIOx, uint32_t Pin) +{ + return (uint32_t)(READ_BIT(GPIOx->OSPEEDR, ((Pin * Pin) * GPIO_OSPEEDR_OSPEEDR0)) / (Pin * Pin)); +} + +/** + * @brief Configure gpio pull-up or pull-down for a dedicated pin on a dedicated port. + * @note Warning: only one pin can be passed as parameter. + * @rmtoll PUPDR PUPDy LL_GPIO_SetPinPull + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @param Pull This parameter can be one of the following values: + * @arg @ref LL_GPIO_PULL_NO + * @arg @ref LL_GPIO_PULL_UP + * @arg @ref LL_GPIO_PULL_DOWN + * @retval None + */ +__STATIC_INLINE void LL_GPIO_SetPinPull(GPIO_TypeDef *GPIOx, uint32_t Pin, uint32_t Pull) +{ + MODIFY_REG(GPIOx->PUPDR, ((Pin * Pin) * GPIO_PUPDR_PUPDR0), ((Pin * Pin) * Pull)); +} + +/** + * @brief Return gpio pull-up or pull-down for a dedicated pin on a dedicated port + * @note Warning: only one pin can be passed as parameter. + * @rmtoll PUPDR PUPDy LL_GPIO_GetPinPull + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @retval Returned value can be one of the following values: + * @arg @ref LL_GPIO_PULL_NO + * @arg @ref LL_GPIO_PULL_UP + * @arg @ref LL_GPIO_PULL_DOWN + */ +__STATIC_INLINE uint32_t LL_GPIO_GetPinPull(GPIO_TypeDef *GPIOx, uint32_t Pin) +{ + return (uint32_t)(READ_BIT(GPIOx->PUPDR, ((Pin * Pin) * GPIO_PUPDR_PUPDR0)) / (Pin * Pin)); +} + +/** + * @brief Configure gpio alternate function of a dedicated pin from 0 to 7 for a dedicated port. + * @note Possible values are from AF0 to AF7 depending on target. + * @note Warning: only one pin can be passed as parameter. + * @rmtoll AFRL AFSELy LL_GPIO_SetAFPin_0_7 + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @param Alternate This parameter can be one of the following values: + * @arg @ref LL_GPIO_AF_0 + * @arg @ref LL_GPIO_AF_1 + * @arg @ref LL_GPIO_AF_2 + * @arg @ref LL_GPIO_AF_3 + * @arg @ref LL_GPIO_AF_4 + * @arg @ref LL_GPIO_AF_5 + * @arg @ref LL_GPIO_AF_6 + * @arg @ref LL_GPIO_AF_7 + * @retval None + */ +__STATIC_INLINE void LL_GPIO_SetAFPin_0_7(GPIO_TypeDef *GPIOx, uint32_t Pin, uint32_t Alternate) +{ + MODIFY_REG(GPIOx->AFR[0], ((((Pin * Pin) * Pin) * Pin) * GPIO_AFRL_AFSEL0), + ((((Pin * Pin) * Pin) * Pin) * Alternate)); +} + +/** + * @brief Return gpio alternate function of a dedicated pin from 0 to 7 for a dedicated port. + * @rmtoll AFRL AFSELy LL_GPIO_GetAFPin_0_7 + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @retval Returned value can be one of the following values: + * @arg @ref LL_GPIO_AF_0 + * @arg @ref LL_GPIO_AF_1 + * @arg @ref LL_GPIO_AF_2 + * @arg @ref LL_GPIO_AF_3 + * @arg @ref LL_GPIO_AF_4 + * @arg @ref LL_GPIO_AF_5 + * @arg @ref LL_GPIO_AF_6 + * @arg @ref LL_GPIO_AF_7 + */ +__STATIC_INLINE uint32_t LL_GPIO_GetAFPin_0_7(GPIO_TypeDef *GPIOx, uint32_t Pin) +{ + return (uint32_t)(READ_BIT(GPIOx->AFR[0], + ((((Pin * Pin) * Pin) * Pin) * GPIO_AFRL_AFSEL0)) / (((Pin * Pin) * Pin) * Pin)); +} + +/** + * @brief Configure gpio alternate function of a dedicated pin from 8 to 15 for a dedicated port. + * @note Possible values are from AF0 to AF7 depending on target. + * @note Warning: only one pin can be passed as parameter. + * @rmtoll AFRH AFSELy LL_GPIO_SetAFPin_8_15 + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @param Alternate This parameter can be one of the following values: + * @arg @ref LL_GPIO_AF_0 + * @arg @ref LL_GPIO_AF_1 + * @arg @ref LL_GPIO_AF_2 + * @arg @ref LL_GPIO_AF_3 + * @arg @ref LL_GPIO_AF_4 + * @arg @ref LL_GPIO_AF_5 + * @arg @ref LL_GPIO_AF_6 + * @arg @ref LL_GPIO_AF_7 + * @retval None + */ +__STATIC_INLINE void LL_GPIO_SetAFPin_8_15(GPIO_TypeDef *GPIOx, uint32_t Pin, uint32_t Alternate) +{ + MODIFY_REG(GPIOx->AFR[1], (((((Pin >> 8U) * (Pin >> 8U)) * (Pin >> 8U)) * (Pin >> 8U)) * GPIO_AFRH_AFSEL8), + (((((Pin >> 8U) * (Pin >> 8U)) * (Pin >> 8U)) * (Pin >> 8U)) * Alternate)); +} + +/** + * @brief Return gpio alternate function of a dedicated pin from 8 to 15 for a dedicated port. + * @note Possible values are from AF0 to AF7 depending on target. + * @rmtoll AFRH AFSELy LL_GPIO_GetAFPin_8_15 + * @param GPIOx GPIO Port + * @param Pin This parameter can be one of the following values: + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @retval Returned value can be one of the following values: + * @arg @ref LL_GPIO_AF_0 + * @arg @ref LL_GPIO_AF_1 + * @arg @ref LL_GPIO_AF_2 + * @arg @ref LL_GPIO_AF_3 + * @arg @ref LL_GPIO_AF_4 + * @arg @ref LL_GPIO_AF_5 + * @arg @ref LL_GPIO_AF_6 + * @arg @ref LL_GPIO_AF_7 + */ +__STATIC_INLINE uint32_t LL_GPIO_GetAFPin_8_15(GPIO_TypeDef *GPIOx, uint32_t Pin) +{ + return (uint32_t)(READ_BIT(GPIOx->AFR[1], + (((((Pin >> 8U) * (Pin >> 8U)) * (Pin >> 8U)) * (Pin >> 8U)) * GPIO_AFRH_AFSEL8)) / ((((Pin >> 8U) * + (Pin >> 8U)) * (Pin >> 8U)) * (Pin >> 8U))); +} + + +/** + * @brief Lock configuration of several pins for a dedicated port. + * @note When the lock sequence has been applied on a port bit, the + * value of this port bit can no longer be modified until the + * next reset. + * @note Each lock bit freezes a specific configuration register + * (control and alternate function registers). + * @rmtoll LCKR LCKK LL_GPIO_LockPin + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval None + */ +__STATIC_INLINE void LL_GPIO_LockPin(GPIO_TypeDef *GPIOx, uint32_t PinMask) +{ + __IO uint32_t temp; + WRITE_REG(GPIOx->LCKR, GPIO_LCKR_LCKK | PinMask); + WRITE_REG(GPIOx->LCKR, PinMask); + WRITE_REG(GPIOx->LCKR, GPIO_LCKR_LCKK | PinMask); + temp = READ_REG(GPIOx->LCKR); + (void) temp; +} + +/** + * @brief Return 1 if all pins passed as parameter, of a dedicated port, are locked. else Return 0. + * @rmtoll LCKR LCKy LL_GPIO_IsPinLocked + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_GPIO_IsPinLocked(GPIO_TypeDef *GPIOx, uint32_t PinMask) +{ + return (READ_BIT(GPIOx->LCKR, PinMask) == (PinMask)); +} + +/** + * @brief Return 1 if one of the pin of a dedicated port is locked. else return 0. + * @rmtoll LCKR LCKK LL_GPIO_IsAnyPinLocked + * @param GPIOx GPIO Port + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_GPIO_IsAnyPinLocked(GPIO_TypeDef *GPIOx) +{ + return (READ_BIT(GPIOx->LCKR, GPIO_LCKR_LCKK) == (GPIO_LCKR_LCKK)); +} + +/** + * @} + */ + +/** @defgroup GPIO_LL_EF_Data_Access Data Access + * @{ + */ + +/** + * @brief Return full input data register value for a dedicated port. + * @rmtoll IDR IDy LL_GPIO_ReadInputPort + * @param GPIOx GPIO Port + * @retval Input data register value of port + */ +__STATIC_INLINE uint32_t LL_GPIO_ReadInputPort(GPIO_TypeDef *GPIOx) +{ + return (uint32_t)(READ_REG(GPIOx->IDR)); +} + +/** + * @brief Return if input data level for several pins of dedicated port is high or low. + * @rmtoll IDR IDy LL_GPIO_IsInputPinSet + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_GPIO_IsInputPinSet(GPIO_TypeDef *GPIOx, uint32_t PinMask) +{ + return (READ_BIT(GPIOx->IDR, PinMask) == (PinMask)); +} + +/** + * @brief Write output data register for the port. + * @rmtoll ODR ODy LL_GPIO_WriteOutputPort + * @param GPIOx GPIO Port + * @param PortValue Level value for each pin of the port + * @retval None + */ +__STATIC_INLINE void LL_GPIO_WriteOutputPort(GPIO_TypeDef *GPIOx, uint32_t PortValue) +{ + WRITE_REG(GPIOx->ODR, PortValue); +} + +/** + * @brief Return full output data register value for a dedicated port. + * @rmtoll ODR ODy LL_GPIO_ReadOutputPort + * @param GPIOx GPIO Port + * @retval Output data register value of port + */ +__STATIC_INLINE uint32_t LL_GPIO_ReadOutputPort(GPIO_TypeDef *GPIOx) +{ + return (uint32_t)(READ_REG(GPIOx->ODR)); +} + +/** + * @brief Return if input data level for several pins of dedicated port is high or low. + * @rmtoll ODR ODy LL_GPIO_IsOutputPinSet + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_GPIO_IsOutputPinSet(GPIO_TypeDef *GPIOx, uint32_t PinMask) +{ + return (READ_BIT(GPIOx->ODR, PinMask) == (PinMask)); +} + +/** + * @brief Set several pins to high level on dedicated gpio port. + * @rmtoll BSRR BSy LL_GPIO_SetOutputPin + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval None + */ +__STATIC_INLINE void LL_GPIO_SetOutputPin(GPIO_TypeDef *GPIOx, uint32_t PinMask) +{ + WRITE_REG(GPIOx->BSRR, PinMask); +} + +/** + * @brief Set several pins to low level on dedicated gpio port. + * @rmtoll BRR BRy LL_GPIO_ResetOutputPin + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval None + */ +__STATIC_INLINE void LL_GPIO_ResetOutputPin(GPIO_TypeDef *GPIOx, uint32_t PinMask) +{ + WRITE_REG(GPIOx->BRR, PinMask); +} + +/** + * @brief Toggle data value for several pin of dedicated port. + * @rmtoll ODR ODy LL_GPIO_TogglePin + * @param GPIOx GPIO Port + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_GPIO_PIN_0 + * @arg @ref LL_GPIO_PIN_1 + * @arg @ref LL_GPIO_PIN_2 + * @arg @ref LL_GPIO_PIN_3 + * @arg @ref LL_GPIO_PIN_4 + * @arg @ref LL_GPIO_PIN_5 + * @arg @ref LL_GPIO_PIN_6 + * @arg @ref LL_GPIO_PIN_7 + * @arg @ref LL_GPIO_PIN_8 + * @arg @ref LL_GPIO_PIN_9 + * @arg @ref LL_GPIO_PIN_10 + * @arg @ref LL_GPIO_PIN_11 + * @arg @ref LL_GPIO_PIN_12 + * @arg @ref LL_GPIO_PIN_13 + * @arg @ref LL_GPIO_PIN_14 + * @arg @ref LL_GPIO_PIN_15 + * @arg @ref LL_GPIO_PIN_ALL + * @retval None + */ +__STATIC_INLINE void LL_GPIO_TogglePin(GPIO_TypeDef *GPIOx, uint32_t PinMask) +{ + uint32_t odr = READ_REG(GPIOx->ODR); + WRITE_REG(GPIOx->BSRR, ((odr & PinMask) << 16u) | (~odr & PinMask)); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup GPIO_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_GPIO_DeInit(GPIO_TypeDef *GPIOx); +ErrorStatus LL_GPIO_Init(GPIO_TypeDef *GPIOx, LL_GPIO_InitTypeDef *GPIO_InitStruct); +void LL_GPIO_StructInit(LL_GPIO_InitTypeDef *GPIO_InitStruct); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined (GPIOA) || defined (GPIOB) || defined (GPIOC) || defined (GPIOD) || defined (GPIOE) || defined (GPIOF) */ +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_GPIO_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_i2c.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_i2c.h new file mode 100644 index 0000000..2557f88 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_i2c.h @@ -0,0 +1,2277 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_i2c.h + * @author MCD Application Team + * @brief Header file of I2C LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_LL_I2C_H +#define STM32F0xx_LL_I2C_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (I2C1) || defined (I2C2) + +/** @defgroup I2C_LL I2C + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup I2C_LL_Private_Constants I2C Private Constants + * @{ + */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup I2C_LL_Private_Macros I2C Private Macros + * @{ + */ +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup I2C_LL_ES_INIT I2C Exported Init structure + * @{ + */ +typedef struct +{ + uint32_t PeripheralMode; /*!< Specifies the peripheral mode. + This parameter can be a value of @ref I2C_LL_EC_PERIPHERAL_MODE. + + This feature can be modified afterwards using unitary function + @ref LL_I2C_SetMode(). */ + + uint32_t Timing; /*!< Specifies the SDA setup, hold time and the SCL high, low period values. + This parameter must be set by referring to the STM32CubeMX Tool and + the helper macro @ref __LL_I2C_CONVERT_TIMINGS(). + + This feature can be modified afterwards using unitary function + @ref LL_I2C_SetTiming(). */ + + uint32_t AnalogFilter; /*!< Enables or disables analog noise filter. + This parameter can be a value of @ref I2C_LL_EC_ANALOGFILTER_SELECTION. + + This feature can be modified afterwards using unitary functions + @ref LL_I2C_EnableAnalogFilter() or LL_I2C_DisableAnalogFilter(). */ + + uint32_t DigitalFilter; /*!< Configures the digital noise filter. + This parameter can be a number between Min_Data = 0x00 and Max_Data = 0x0F. + + This feature can be modified afterwards using unitary function + @ref LL_I2C_SetDigitalFilter(). */ + + uint32_t OwnAddress1; /*!< Specifies the device own address 1. + This parameter must be a value between Min_Data = 0x00 and Max_Data = 0x3FF. + + This feature can be modified afterwards using unitary function + @ref LL_I2C_SetOwnAddress1(). */ + + uint32_t TypeAcknowledge; /*!< Specifies the ACKnowledge or Non ACKnowledge condition after the address receive + match code or next received byte. + This parameter can be a value of @ref I2C_LL_EC_I2C_ACKNOWLEDGE. + + This feature can be modified afterwards using unitary function + @ref LL_I2C_AcknowledgeNextData(). */ + + uint32_t OwnAddrSize; /*!< Specifies the device own address 1 size (7-bit or 10-bit). + This parameter can be a value of @ref I2C_LL_EC_OWNADDRESS1. + + This feature can be modified afterwards using unitary function + @ref LL_I2C_SetOwnAddress1(). */ +} LL_I2C_InitTypeDef; +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup I2C_LL_Exported_Constants I2C Exported Constants + * @{ + */ + +/** @defgroup I2C_LL_EC_CLEAR_FLAG Clear Flags Defines + * @brief Flags defines which can be used with LL_I2C_WriteReg function + * @{ + */ +#define LL_I2C_ICR_ADDRCF I2C_ICR_ADDRCF /*!< Address Matched flag */ +#define LL_I2C_ICR_NACKCF I2C_ICR_NACKCF /*!< Not Acknowledge flag */ +#define LL_I2C_ICR_STOPCF I2C_ICR_STOPCF /*!< Stop detection flag */ +#define LL_I2C_ICR_BERRCF I2C_ICR_BERRCF /*!< Bus error flag */ +#define LL_I2C_ICR_ARLOCF I2C_ICR_ARLOCF /*!< Arbitration Lost flag */ +#define LL_I2C_ICR_OVRCF I2C_ICR_OVRCF /*!< Overrun/Underrun flag */ +#define LL_I2C_ICR_PECCF I2C_ICR_PECCF /*!< PEC error flag */ +#define LL_I2C_ICR_TIMOUTCF I2C_ICR_TIMOUTCF /*!< Timeout detection flag */ +#define LL_I2C_ICR_ALERTCF I2C_ICR_ALERTCF /*!< Alert flag */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_I2C_ReadReg function + * @{ + */ +#define LL_I2C_ISR_TXE I2C_ISR_TXE /*!< Transmit data register empty */ +#define LL_I2C_ISR_TXIS I2C_ISR_TXIS /*!< Transmit interrupt status */ +#define LL_I2C_ISR_RXNE I2C_ISR_RXNE /*!< Receive data register not empty */ +#define LL_I2C_ISR_ADDR I2C_ISR_ADDR /*!< Address matched (slave mode) */ +#define LL_I2C_ISR_NACKF I2C_ISR_NACKF /*!< Not Acknowledge received flag */ +#define LL_I2C_ISR_STOPF I2C_ISR_STOPF /*!< Stop detection flag */ +#define LL_I2C_ISR_TC I2C_ISR_TC /*!< Transfer Complete (master mode) */ +#define LL_I2C_ISR_TCR I2C_ISR_TCR /*!< Transfer Complete Reload */ +#define LL_I2C_ISR_BERR I2C_ISR_BERR /*!< Bus error */ +#define LL_I2C_ISR_ARLO I2C_ISR_ARLO /*!< Arbitration lost */ +#define LL_I2C_ISR_OVR I2C_ISR_OVR /*!< Overrun/Underrun (slave mode) */ +#define LL_I2C_ISR_PECERR I2C_ISR_PECERR /*!< PEC Error in reception (SMBus mode) */ +#define LL_I2C_ISR_TIMEOUT I2C_ISR_TIMEOUT /*!< Timeout detection flag (SMBus mode) */ +#define LL_I2C_ISR_ALERT I2C_ISR_ALERT /*!< SMBus alert (SMBus mode) */ +#define LL_I2C_ISR_BUSY I2C_ISR_BUSY /*!< Bus busy */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_I2C_ReadReg and LL_I2C_WriteReg functions + * @{ + */ +#define LL_I2C_CR1_TXIE I2C_CR1_TXIE /*!< TX Interrupt enable */ +#define LL_I2C_CR1_RXIE I2C_CR1_RXIE /*!< RX Interrupt enable */ +#define LL_I2C_CR1_ADDRIE I2C_CR1_ADDRIE /*!< Address match Interrupt enable (slave only) */ +#define LL_I2C_CR1_NACKIE I2C_CR1_NACKIE /*!< Not acknowledge received Interrupt enable */ +#define LL_I2C_CR1_STOPIE I2C_CR1_STOPIE /*!< STOP detection Interrupt enable */ +#define LL_I2C_CR1_TCIE I2C_CR1_TCIE /*!< Transfer Complete interrupt enable */ +#define LL_I2C_CR1_ERRIE I2C_CR1_ERRIE /*!< Error interrupts enable */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_PERIPHERAL_MODE Peripheral Mode + * @{ + */ +#define LL_I2C_MODE_I2C 0x00000000U /*!< I2C Master or Slave mode */ +#define LL_I2C_MODE_SMBUS_HOST I2C_CR1_SMBHEN /*!< SMBus Host address acknowledge */ +#define LL_I2C_MODE_SMBUS_DEVICE 0x00000000U /*!< SMBus Device default mode + (Default address not acknowledge) */ +#define LL_I2C_MODE_SMBUS_DEVICE_ARP I2C_CR1_SMBDEN /*!< SMBus Device Default address acknowledge */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_ANALOGFILTER_SELECTION Analog Filter Selection + * @{ + */ +#define LL_I2C_ANALOGFILTER_ENABLE 0x00000000U /*!< Analog filter is enabled. */ +#define LL_I2C_ANALOGFILTER_DISABLE I2C_CR1_ANFOFF /*!< Analog filter is disabled. */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_ADDRESSING_MODE Master Addressing Mode + * @{ + */ +#define LL_I2C_ADDRESSING_MODE_7BIT 0x00000000U /*!< Master operates in 7-bit addressing mode. */ +#define LL_I2C_ADDRESSING_MODE_10BIT I2C_CR2_ADD10 /*!< Master operates in 10-bit addressing mode.*/ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_OWNADDRESS1 Own Address 1 Length + * @{ + */ +#define LL_I2C_OWNADDRESS1_7BIT 0x00000000U /*!< Own address 1 is a 7-bit address. */ +#define LL_I2C_OWNADDRESS1_10BIT I2C_OAR1_OA1MODE /*!< Own address 1 is a 10-bit address.*/ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_OWNADDRESS2 Own Address 2 Masks + * @{ + */ +#define LL_I2C_OWNADDRESS2_NOMASK I2C_OAR2_OA2NOMASK /*!< Own Address2 No mask. */ +#define LL_I2C_OWNADDRESS2_MASK01 I2C_OAR2_OA2MASK01 /*!< Only Address2 bits[7:2] are compared. */ +#define LL_I2C_OWNADDRESS2_MASK02 I2C_OAR2_OA2MASK02 /*!< Only Address2 bits[7:3] are compared. */ +#define LL_I2C_OWNADDRESS2_MASK03 I2C_OAR2_OA2MASK03 /*!< Only Address2 bits[7:4] are compared. */ +#define LL_I2C_OWNADDRESS2_MASK04 I2C_OAR2_OA2MASK04 /*!< Only Address2 bits[7:5] are compared. */ +#define LL_I2C_OWNADDRESS2_MASK05 I2C_OAR2_OA2MASK05 /*!< Only Address2 bits[7:6] are compared. */ +#define LL_I2C_OWNADDRESS2_MASK06 I2C_OAR2_OA2MASK06 /*!< Only Address2 bits[7] are compared. */ +#define LL_I2C_OWNADDRESS2_MASK07 I2C_OAR2_OA2MASK07 /*!< No comparison is done. + All Address2 are acknowledged. */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_I2C_ACKNOWLEDGE Acknowledge Generation + * @{ + */ +#define LL_I2C_ACK 0x00000000U /*!< ACK is sent after current received byte. */ +#define LL_I2C_NACK I2C_CR2_NACK /*!< NACK is sent after current received byte.*/ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_ADDRSLAVE Slave Address Length + * @{ + */ +#define LL_I2C_ADDRSLAVE_7BIT 0x00000000U /*!< Slave Address in 7-bit. */ +#define LL_I2C_ADDRSLAVE_10BIT I2C_CR2_ADD10 /*!< Slave Address in 10-bit.*/ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_REQUEST Transfer Request Direction + * @{ + */ +#define LL_I2C_REQUEST_WRITE 0x00000000U /*!< Master request a write transfer. */ +#define LL_I2C_REQUEST_READ I2C_CR2_RD_WRN /*!< Master request a read transfer. */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_MODE Transfer End Mode + * @{ + */ +#define LL_I2C_MODE_RELOAD I2C_CR2_RELOAD /*!< Enable I2C Reload mode. */ +#define LL_I2C_MODE_AUTOEND I2C_CR2_AUTOEND /*!< Enable I2C Automatic end mode + with no HW PEC comparison. */ +#define LL_I2C_MODE_SOFTEND 0x00000000U /*!< Enable I2C Software end mode + with no HW PEC comparison. */ +#define LL_I2C_MODE_SMBUS_RELOAD LL_I2C_MODE_RELOAD /*!< Enable SMBUS Automatic end mode + with HW PEC comparison. */ +#define LL_I2C_MODE_SMBUS_AUTOEND_NO_PEC LL_I2C_MODE_AUTOEND /*!< Enable SMBUS Automatic end mode + with HW PEC comparison. */ +#define LL_I2C_MODE_SMBUS_SOFTEND_NO_PEC LL_I2C_MODE_SOFTEND /*!< Enable SMBUS Software end mode + with HW PEC comparison. */ +#define LL_I2C_MODE_SMBUS_AUTOEND_WITH_PEC (uint32_t)(LL_I2C_MODE_AUTOEND | I2C_CR2_PECBYTE) +/*!< Enable SMBUS Automatic end mode with HW PEC comparison. */ +#define LL_I2C_MODE_SMBUS_SOFTEND_WITH_PEC (uint32_t)(LL_I2C_MODE_SOFTEND | I2C_CR2_PECBYTE) +/*!< Enable SMBUS Software end mode with HW PEC comparison. */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_GENERATE Start And Stop Generation + * @{ + */ +#define LL_I2C_GENERATE_NOSTARTSTOP 0x00000000U +/*!< Don't Generate Stop and Start condition. */ +#define LL_I2C_GENERATE_STOP (uint32_t)(0x80000000U | I2C_CR2_STOP) +/*!< Generate Stop condition (Size should be set to 0). */ +#define LL_I2C_GENERATE_START_READ (uint32_t)(0x80000000U | I2C_CR2_START | I2C_CR2_RD_WRN) +/*!< Generate Start for read request. */ +#define LL_I2C_GENERATE_START_WRITE (uint32_t)(0x80000000U | I2C_CR2_START) +/*!< Generate Start for write request. */ +#define LL_I2C_GENERATE_RESTART_7BIT_READ (uint32_t)(0x80000000U | I2C_CR2_START | I2C_CR2_RD_WRN) +/*!< Generate Restart for read request, slave 7Bit address. */ +#define LL_I2C_GENERATE_RESTART_7BIT_WRITE (uint32_t)(0x80000000U | I2C_CR2_START) +/*!< Generate Restart for write request, slave 7Bit address. */ +#define LL_I2C_GENERATE_RESTART_10BIT_READ (uint32_t)(0x80000000U | I2C_CR2_START | \ + I2C_CR2_RD_WRN | I2C_CR2_HEAD10R) +/*!< Generate Restart for read request, slave 10Bit address. */ +#define LL_I2C_GENERATE_RESTART_10BIT_WRITE (uint32_t)(0x80000000U | I2C_CR2_START) +/*!< Generate Restart for write request, slave 10Bit address.*/ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_DIRECTION Read Write Direction + * @{ + */ +#define LL_I2C_DIRECTION_WRITE 0x00000000U /*!< Write transfer request by master, + slave enters receiver mode. */ +#define LL_I2C_DIRECTION_READ I2C_ISR_DIR /*!< Read transfer request by master, + slave enters transmitter mode.*/ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_DMA_REG_DATA DMA Register Data + * @{ + */ +#define LL_I2C_DMA_REG_DATA_TRANSMIT 0x00000000U /*!< Get address of data register used for + transmission */ +#define LL_I2C_DMA_REG_DATA_RECEIVE 0x00000001U /*!< Get address of data register used for + reception */ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_SMBUS_TIMEOUTA_MODE SMBus TimeoutA Mode SCL SDA Timeout + * @{ + */ +#define LL_I2C_SMBUS_TIMEOUTA_MODE_SCL_LOW 0x00000000U /*!< TimeoutA is used to detect + SCL low level timeout. */ +#define LL_I2C_SMBUS_TIMEOUTA_MODE_SDA_SCL_HIGH I2C_TIMEOUTR_TIDLE /*!< TimeoutA is used to detect + both SCL and SDA high level timeout.*/ +/** + * @} + */ + +/** @defgroup I2C_LL_EC_SMBUS_TIMEOUT_SELECTION SMBus Timeout Selection + * @{ + */ +#define LL_I2C_SMBUS_TIMEOUTA I2C_TIMEOUTR_TIMOUTEN /*!< TimeoutA enable bit */ +#define LL_I2C_SMBUS_TIMEOUTB I2C_TIMEOUTR_TEXTEN /*!< TimeoutB (extended clock) + enable bit */ +#define LL_I2C_SMBUS_ALL_TIMEOUT (uint32_t)(I2C_TIMEOUTR_TIMOUTEN | \ + I2C_TIMEOUTR_TEXTEN) /*!< TimeoutA and TimeoutB +(extended clock) enable bits */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup I2C_LL_Exported_Macros I2C Exported Macros + * @{ + */ + +/** @defgroup I2C_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in I2C register + * @param __INSTANCE__ I2C Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_I2C_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in I2C register + * @param __INSTANCE__ I2C Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_I2C_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** @defgroup I2C_LL_EM_CONVERT_TIMINGS Convert SDA SCL timings + * @{ + */ +/** + * @brief Configure the SDA setup, hold time and the SCL high, low period. + * @param __PRESCALER__ This parameter must be a value between Min_Data=0 and Max_Data=0xF. + * @param __SETUP_TIME__ This parameter must be a value between Min_Data=0 and Max_Data=0xF. + (tscldel = (SCLDEL+1)xtpresc) + * @param __HOLD_TIME__ This parameter must be a value between Min_Data=0 and Max_Data=0xF. + (tsdadel = SDADELxtpresc) + * @param __SCLH_PERIOD__ This parameter must be a value between Min_Data=0 and Max_Data=0xFF. + (tsclh = (SCLH+1)xtpresc) + * @param __SCLL_PERIOD__ This parameter must be a value between Min_Data=0 and Max_Data=0xFF. + (tscll = (SCLL+1)xtpresc) + * @retval Value between Min_Data=0 and Max_Data=0xFFFFFFFF + */ +#define __LL_I2C_CONVERT_TIMINGS(__PRESCALER__, __SETUP_TIME__, __HOLD_TIME__, __SCLH_PERIOD__, __SCLL_PERIOD__) \ + ((((uint32_t)(__PRESCALER__) << I2C_TIMINGR_PRESC_Pos) & I2C_TIMINGR_PRESC) | \ + (((uint32_t)(__SETUP_TIME__) << I2C_TIMINGR_SCLDEL_Pos) & I2C_TIMINGR_SCLDEL) | \ + (((uint32_t)(__HOLD_TIME__) << I2C_TIMINGR_SDADEL_Pos) & I2C_TIMINGR_SDADEL) | \ + (((uint32_t)(__SCLH_PERIOD__) << I2C_TIMINGR_SCLH_Pos) & I2C_TIMINGR_SCLH) | \ + (((uint32_t)(__SCLL_PERIOD__) << I2C_TIMINGR_SCLL_Pos) & I2C_TIMINGR_SCLL)) +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup I2C_LL_Exported_Functions I2C Exported Functions + * @{ + */ + +/** @defgroup I2C_LL_EF_Configuration Configuration + * @{ + */ + +/** + * @brief Enable I2C peripheral (PE = 1). + * @rmtoll CR1 PE LL_I2C_Enable + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_Enable(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_PE); +} + +/** + * @brief Disable I2C peripheral (PE = 0). + * @note When PE = 0, the I2C SCL and SDA lines are released. + * Internal state machines and status bits are put back to their reset value. + * When cleared, PE must be kept low for at least 3 APB clock cycles. + * @rmtoll CR1 PE LL_I2C_Disable + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_Disable(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_PE); +} + +/** + * @brief Check if the I2C peripheral is enabled or disabled. + * @rmtoll CR1 PE LL_I2C_IsEnabled + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabled(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_PE) == (I2C_CR1_PE)) ? 1UL : 0UL); +} + +/** + * @brief Configure Noise Filters (Analog and Digital). + * @note If the analog filter is also enabled, the digital filter is added to analog filter. + * The filters can only be programmed when the I2C is disabled (PE = 0). + * @rmtoll CR1 ANFOFF LL_I2C_ConfigFilters\n + * CR1 DNF LL_I2C_ConfigFilters + * @param I2Cx I2C Instance. + * @param AnalogFilter This parameter can be one of the following values: + * @arg @ref LL_I2C_ANALOGFILTER_ENABLE + * @arg @ref LL_I2C_ANALOGFILTER_DISABLE + * @param DigitalFilter This parameter must be a value between Min_Data=0x00 (Digital filter disabled) + and Max_Data=0x0F (Digital filter enabled and filtering capability up to 15*ti2cclk). + * This parameter is used to configure the digital noise filter on SDA and SCL input. + * The digital filter will filter spikes with a length of up to DNF[3:0]*ti2cclk. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ConfigFilters(I2C_TypeDef *I2Cx, uint32_t AnalogFilter, uint32_t DigitalFilter) +{ + MODIFY_REG(I2Cx->CR1, I2C_CR1_ANFOFF | I2C_CR1_DNF, AnalogFilter | (DigitalFilter << I2C_CR1_DNF_Pos)); +} + +/** + * @brief Configure Digital Noise Filter. + * @note If the analog filter is also enabled, the digital filter is added to analog filter. + * This filter can only be programmed when the I2C is disabled (PE = 0). + * @rmtoll CR1 DNF LL_I2C_SetDigitalFilter + * @param I2Cx I2C Instance. + * @param DigitalFilter This parameter must be a value between Min_Data=0x00 (Digital filter disabled) + and Max_Data=0x0F (Digital filter enabled and filtering capability up to 15*ti2cclk). + * This parameter is used to configure the digital noise filter on SDA and SCL input. + * The digital filter will filter spikes with a length of up to DNF[3:0]*ti2cclk. + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetDigitalFilter(I2C_TypeDef *I2Cx, uint32_t DigitalFilter) +{ + MODIFY_REG(I2Cx->CR1, I2C_CR1_DNF, DigitalFilter << I2C_CR1_DNF_Pos); +} + +/** + * @brief Get the current Digital Noise Filter configuration. + * @rmtoll CR1 DNF LL_I2C_GetDigitalFilter + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x0 and Max_Data=0xF + */ +__STATIC_INLINE uint32_t LL_I2C_GetDigitalFilter(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->CR1, I2C_CR1_DNF) >> I2C_CR1_DNF_Pos); +} + +/** + * @brief Enable Analog Noise Filter. + * @note This filter can only be programmed when the I2C is disabled (PE = 0). + * @rmtoll CR1 ANFOFF LL_I2C_EnableAnalogFilter + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableAnalogFilter(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_ANFOFF); +} + +/** + * @brief Disable Analog Noise Filter. + * @note This filter can only be programmed when the I2C is disabled (PE = 0). + * @rmtoll CR1 ANFOFF LL_I2C_DisableAnalogFilter + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableAnalogFilter(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_ANFOFF); +} + +/** + * @brief Check if Analog Noise Filter is enabled or disabled. + * @rmtoll CR1 ANFOFF LL_I2C_IsEnabledAnalogFilter + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledAnalogFilter(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_ANFOFF) != (I2C_CR1_ANFOFF)) ? 1UL : 0UL); +} + +/** + * @brief Enable DMA transmission requests. + * @rmtoll CR1 TXDMAEN LL_I2C_EnableDMAReq_TX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableDMAReq_TX(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_TXDMAEN); +} + +/** + * @brief Disable DMA transmission requests. + * @rmtoll CR1 TXDMAEN LL_I2C_DisableDMAReq_TX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableDMAReq_TX(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_TXDMAEN); +} + +/** + * @brief Check if DMA transmission requests are enabled or disabled. + * @rmtoll CR1 TXDMAEN LL_I2C_IsEnabledDMAReq_TX + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledDMAReq_TX(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_TXDMAEN) == (I2C_CR1_TXDMAEN)) ? 1UL : 0UL); +} + +/** + * @brief Enable DMA reception requests. + * @rmtoll CR1 RXDMAEN LL_I2C_EnableDMAReq_RX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableDMAReq_RX(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_RXDMAEN); +} + +/** + * @brief Disable DMA reception requests. + * @rmtoll CR1 RXDMAEN LL_I2C_DisableDMAReq_RX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableDMAReq_RX(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_RXDMAEN); +} + +/** + * @brief Check if DMA reception requests are enabled or disabled. + * @rmtoll CR1 RXDMAEN LL_I2C_IsEnabledDMAReq_RX + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledDMAReq_RX(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_RXDMAEN) == (I2C_CR1_RXDMAEN)) ? 1UL : 0UL); +} + +/** + * @brief Get the data register address used for DMA transfer + * @rmtoll TXDR TXDATA LL_I2C_DMA_GetRegAddr\n + * RXDR RXDATA LL_I2C_DMA_GetRegAddr + * @param I2Cx I2C Instance + * @param Direction This parameter can be one of the following values: + * @arg @ref LL_I2C_DMA_REG_DATA_TRANSMIT + * @arg @ref LL_I2C_DMA_REG_DATA_RECEIVE + * @retval Address of data register + */ +__STATIC_INLINE uint32_t LL_I2C_DMA_GetRegAddr(I2C_TypeDef *I2Cx, uint32_t Direction) +{ + uint32_t data_reg_addr; + + if (Direction == LL_I2C_DMA_REG_DATA_TRANSMIT) + { + /* return address of TXDR register */ + data_reg_addr = (uint32_t) &(I2Cx->TXDR); + } + else + { + /* return address of RXDR register */ + data_reg_addr = (uint32_t) &(I2Cx->RXDR); + } + + return data_reg_addr; +} + +/** + * @brief Enable Clock stretching. + * @note This bit can only be programmed when the I2C is disabled (PE = 0). + * @rmtoll CR1 NOSTRETCH LL_I2C_EnableClockStretching + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableClockStretching(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_NOSTRETCH); +} + +/** + * @brief Disable Clock stretching. + * @note This bit can only be programmed when the I2C is disabled (PE = 0). + * @rmtoll CR1 NOSTRETCH LL_I2C_DisableClockStretching + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableClockStretching(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_NOSTRETCH); +} + +/** + * @brief Check if Clock stretching is enabled or disabled. + * @rmtoll CR1 NOSTRETCH LL_I2C_IsEnabledClockStretching + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledClockStretching(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_NOSTRETCH) != (I2C_CR1_NOSTRETCH)) ? 1UL : 0UL); +} + +/** + * @brief Enable hardware byte control in slave mode. + * @rmtoll CR1 SBC LL_I2C_EnableSlaveByteControl + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableSlaveByteControl(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_SBC); +} + +/** + * @brief Disable hardware byte control in slave mode. + * @rmtoll CR1 SBC LL_I2C_DisableSlaveByteControl + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableSlaveByteControl(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_SBC); +} + +/** + * @brief Check if hardware byte control in slave mode is enabled or disabled. + * @rmtoll CR1 SBC LL_I2C_IsEnabledSlaveByteControl + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledSlaveByteControl(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_SBC) == (I2C_CR1_SBC)) ? 1UL : 0UL); +} + +#if defined(I2C_CR1_WUPEN) +/** + * @brief Enable Wakeup from STOP. + * @note The macro IS_I2C_WAKEUP_FROMSTOP_INSTANCE(I2Cx) can be used to check whether or not + * WakeUpFromStop feature is supported by the I2Cx Instance. + * @note This bit can only be programmed when Digital Filter is disabled. + * @rmtoll CR1 WUPEN LL_I2C_EnableWakeUpFromStop + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableWakeUpFromStop(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_WUPEN); +} + +/** + * @brief Disable Wakeup from STOP. + * @note The macro IS_I2C_WAKEUP_FROMSTOP_INSTANCE(I2Cx) can be used to check whether or not + * WakeUpFromStop feature is supported by the I2Cx Instance. + * @rmtoll CR1 WUPEN LL_I2C_DisableWakeUpFromStop + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableWakeUpFromStop(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_WUPEN); +} + +/** + * @brief Check if Wakeup from STOP is enabled or disabled. + * @note The macro IS_I2C_WAKEUP_FROMSTOP_INSTANCE(I2Cx) can be used to check whether or not + * WakeUpFromStop feature is supported by the I2Cx Instance. + * @rmtoll CR1 WUPEN LL_I2C_IsEnabledWakeUpFromStop + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledWakeUpFromStop(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_WUPEN) == (I2C_CR1_WUPEN)) ? 1UL : 0UL); +} + +#endif /* I2C_CR1_WUPEN */ +/** + * @brief Enable General Call. + * @note When enabled the Address 0x00 is ACKed. + * @rmtoll CR1 GCEN LL_I2C_EnableGeneralCall + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableGeneralCall(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_GCEN); +} + +/** + * @brief Disable General Call. + * @note When disabled the Address 0x00 is NACKed. + * @rmtoll CR1 GCEN LL_I2C_DisableGeneralCall + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableGeneralCall(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_GCEN); +} + +/** + * @brief Check if General Call is enabled or disabled. + * @rmtoll CR1 GCEN LL_I2C_IsEnabledGeneralCall + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledGeneralCall(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_GCEN) == (I2C_CR1_GCEN)) ? 1UL : 0UL); +} + +/** + * @brief Configure the Master to operate in 7-bit or 10-bit addressing mode. + * @note Changing this bit is not allowed, when the START bit is set. + * @rmtoll CR2 ADD10 LL_I2C_SetMasterAddressingMode + * @param I2Cx I2C Instance. + * @param AddressingMode This parameter can be one of the following values: + * @arg @ref LL_I2C_ADDRESSING_MODE_7BIT + * @arg @ref LL_I2C_ADDRESSING_MODE_10BIT + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetMasterAddressingMode(I2C_TypeDef *I2Cx, uint32_t AddressingMode) +{ + MODIFY_REG(I2Cx->CR2, I2C_CR2_ADD10, AddressingMode); +} + +/** + * @brief Get the Master addressing mode. + * @rmtoll CR2 ADD10 LL_I2C_GetMasterAddressingMode + * @param I2Cx I2C Instance. + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2C_ADDRESSING_MODE_7BIT + * @arg @ref LL_I2C_ADDRESSING_MODE_10BIT + */ +__STATIC_INLINE uint32_t LL_I2C_GetMasterAddressingMode(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->CR2, I2C_CR2_ADD10)); +} + +/** + * @brief Set the Own Address1. + * @rmtoll OAR1 OA1 LL_I2C_SetOwnAddress1\n + * OAR1 OA1MODE LL_I2C_SetOwnAddress1 + * @param I2Cx I2C Instance. + * @param OwnAddress1 This parameter must be a value between Min_Data=0 and Max_Data=0x3FF. + * @param OwnAddrSize This parameter can be one of the following values: + * @arg @ref LL_I2C_OWNADDRESS1_7BIT + * @arg @ref LL_I2C_OWNADDRESS1_10BIT + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetOwnAddress1(I2C_TypeDef *I2Cx, uint32_t OwnAddress1, uint32_t OwnAddrSize) +{ + MODIFY_REG(I2Cx->OAR1, I2C_OAR1_OA1 | I2C_OAR1_OA1MODE, OwnAddress1 | OwnAddrSize); +} + +/** + * @brief Enable acknowledge on Own Address1 match address. + * @rmtoll OAR1 OA1EN LL_I2C_EnableOwnAddress1 + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableOwnAddress1(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->OAR1, I2C_OAR1_OA1EN); +} + +/** + * @brief Disable acknowledge on Own Address1 match address. + * @rmtoll OAR1 OA1EN LL_I2C_DisableOwnAddress1 + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableOwnAddress1(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->OAR1, I2C_OAR1_OA1EN); +} + +/** + * @brief Check if Own Address1 acknowledge is enabled or disabled. + * @rmtoll OAR1 OA1EN LL_I2C_IsEnabledOwnAddress1 + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledOwnAddress1(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->OAR1, I2C_OAR1_OA1EN) == (I2C_OAR1_OA1EN)) ? 1UL : 0UL); +} + +/** + * @brief Set the 7bits Own Address2. + * @note This action has no effect if own address2 is enabled. + * @rmtoll OAR2 OA2 LL_I2C_SetOwnAddress2\n + * OAR2 OA2MSK LL_I2C_SetOwnAddress2 + * @param I2Cx I2C Instance. + * @param OwnAddress2 Value between Min_Data=0 and Max_Data=0x7F. + * @param OwnAddrMask This parameter can be one of the following values: + * @arg @ref LL_I2C_OWNADDRESS2_NOMASK + * @arg @ref LL_I2C_OWNADDRESS2_MASK01 + * @arg @ref LL_I2C_OWNADDRESS2_MASK02 + * @arg @ref LL_I2C_OWNADDRESS2_MASK03 + * @arg @ref LL_I2C_OWNADDRESS2_MASK04 + * @arg @ref LL_I2C_OWNADDRESS2_MASK05 + * @arg @ref LL_I2C_OWNADDRESS2_MASK06 + * @arg @ref LL_I2C_OWNADDRESS2_MASK07 + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetOwnAddress2(I2C_TypeDef *I2Cx, uint32_t OwnAddress2, uint32_t OwnAddrMask) +{ + MODIFY_REG(I2Cx->OAR2, I2C_OAR2_OA2 | I2C_OAR2_OA2MSK, OwnAddress2 | OwnAddrMask); +} + +/** + * @brief Enable acknowledge on Own Address2 match address. + * @rmtoll OAR2 OA2EN LL_I2C_EnableOwnAddress2 + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableOwnAddress2(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->OAR2, I2C_OAR2_OA2EN); +} + +/** + * @brief Disable acknowledge on Own Address2 match address. + * @rmtoll OAR2 OA2EN LL_I2C_DisableOwnAddress2 + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableOwnAddress2(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->OAR2, I2C_OAR2_OA2EN); +} + +/** + * @brief Check if Own Address1 acknowledge is enabled or disabled. + * @rmtoll OAR2 OA2EN LL_I2C_IsEnabledOwnAddress2 + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledOwnAddress2(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->OAR2, I2C_OAR2_OA2EN) == (I2C_OAR2_OA2EN)) ? 1UL : 0UL); +} + +/** + * @brief Configure the SDA setup, hold time and the SCL high, low period. + * @note This bit can only be programmed when the I2C is disabled (PE = 0). + * @rmtoll TIMINGR TIMINGR LL_I2C_SetTiming + * @param I2Cx I2C Instance. + * @param Timing This parameter must be a value between Min_Data=0 and Max_Data=0xFFFFFFFF. + * @note This parameter is computed with the STM32CubeMX Tool. + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetTiming(I2C_TypeDef *I2Cx, uint32_t Timing) +{ + WRITE_REG(I2Cx->TIMINGR, Timing); +} + +/** + * @brief Get the Timing Prescaler setting. + * @rmtoll TIMINGR PRESC LL_I2C_GetTimingPrescaler + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x0 and Max_Data=0xF + */ +__STATIC_INLINE uint32_t LL_I2C_GetTimingPrescaler(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMINGR, I2C_TIMINGR_PRESC) >> I2C_TIMINGR_PRESC_Pos); +} + +/** + * @brief Get the SCL low period setting. + * @rmtoll TIMINGR SCLL LL_I2C_GetClockLowPeriod + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint32_t LL_I2C_GetClockLowPeriod(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMINGR, I2C_TIMINGR_SCLL) >> I2C_TIMINGR_SCLL_Pos); +} + +/** + * @brief Get the SCL high period setting. + * @rmtoll TIMINGR SCLH LL_I2C_GetClockHighPeriod + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint32_t LL_I2C_GetClockHighPeriod(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMINGR, I2C_TIMINGR_SCLH) >> I2C_TIMINGR_SCLH_Pos); +} + +/** + * @brief Get the SDA hold time. + * @rmtoll TIMINGR SDADEL LL_I2C_GetDataHoldTime + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x0 and Max_Data=0xF + */ +__STATIC_INLINE uint32_t LL_I2C_GetDataHoldTime(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMINGR, I2C_TIMINGR_SDADEL) >> I2C_TIMINGR_SDADEL_Pos); +} + +/** + * @brief Get the SDA setup time. + * @rmtoll TIMINGR SCLDEL LL_I2C_GetDataSetupTime + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x0 and Max_Data=0xF + */ +__STATIC_INLINE uint32_t LL_I2C_GetDataSetupTime(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMINGR, I2C_TIMINGR_SCLDEL) >> I2C_TIMINGR_SCLDEL_Pos); +} + +/** + * @brief Configure peripheral mode. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll CR1 SMBHEN LL_I2C_SetMode\n + * CR1 SMBDEN LL_I2C_SetMode + * @param I2Cx I2C Instance. + * @param PeripheralMode This parameter can be one of the following values: + * @arg @ref LL_I2C_MODE_I2C + * @arg @ref LL_I2C_MODE_SMBUS_HOST + * @arg @ref LL_I2C_MODE_SMBUS_DEVICE + * @arg @ref LL_I2C_MODE_SMBUS_DEVICE_ARP + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetMode(I2C_TypeDef *I2Cx, uint32_t PeripheralMode) +{ + MODIFY_REG(I2Cx->CR1, I2C_CR1_SMBHEN | I2C_CR1_SMBDEN, PeripheralMode); +} + +/** + * @brief Get peripheral mode. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll CR1 SMBHEN LL_I2C_GetMode\n + * CR1 SMBDEN LL_I2C_GetMode + * @param I2Cx I2C Instance. + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2C_MODE_I2C + * @arg @ref LL_I2C_MODE_SMBUS_HOST + * @arg @ref LL_I2C_MODE_SMBUS_DEVICE + * @arg @ref LL_I2C_MODE_SMBUS_DEVICE_ARP + */ +__STATIC_INLINE uint32_t LL_I2C_GetMode(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->CR1, I2C_CR1_SMBHEN | I2C_CR1_SMBDEN)); +} + +/** + * @brief Enable SMBus alert (Host or Device mode) + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note SMBus Device mode: + * - SMBus Alert pin is drived low and + * Alert Response Address Header acknowledge is enabled. + * SMBus Host mode: + * - SMBus Alert pin management is supported. + * @rmtoll CR1 ALERTEN LL_I2C_EnableSMBusAlert + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableSMBusAlert(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_ALERTEN); +} + +/** + * @brief Disable SMBus alert (Host or Device mode) + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note SMBus Device mode: + * - SMBus Alert pin is not drived (can be used as a standard GPIO) and + * Alert Response Address Header acknowledge is disabled. + * SMBus Host mode: + * - SMBus Alert pin management is not supported. + * @rmtoll CR1 ALERTEN LL_I2C_DisableSMBusAlert + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableSMBusAlert(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_ALERTEN); +} + +/** + * @brief Check if SMBus alert (Host or Device mode) is enabled or disabled. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll CR1 ALERTEN LL_I2C_IsEnabledSMBusAlert + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledSMBusAlert(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_ALERTEN) == (I2C_CR1_ALERTEN)) ? 1UL : 0UL); +} + +/** + * @brief Enable SMBus Packet Error Calculation (PEC). + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll CR1 PECEN LL_I2C_EnableSMBusPEC + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableSMBusPEC(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_PECEN); +} + +/** + * @brief Disable SMBus Packet Error Calculation (PEC). + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll CR1 PECEN LL_I2C_DisableSMBusPEC + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableSMBusPEC(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_PECEN); +} + +/** + * @brief Check if SMBus Packet Error Calculation (PEC) is enabled or disabled. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll CR1 PECEN LL_I2C_IsEnabledSMBusPEC + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledSMBusPEC(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_PECEN) == (I2C_CR1_PECEN)) ? 1UL : 0UL); +} + +/** + * @brief Configure the SMBus Clock Timeout. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note This configuration can only be programmed when associated Timeout is disabled (TimeoutA and/orTimeoutB). + * @rmtoll TIMEOUTR TIMEOUTA LL_I2C_ConfigSMBusTimeout\n + * TIMEOUTR TIDLE LL_I2C_ConfigSMBusTimeout\n + * TIMEOUTR TIMEOUTB LL_I2C_ConfigSMBusTimeout + * @param I2Cx I2C Instance. + * @param TimeoutA This parameter must be a value between Min_Data=0 and Max_Data=0xFFF. + * @param TimeoutAMode This parameter can be one of the following values: + * @arg @ref LL_I2C_SMBUS_TIMEOUTA_MODE_SCL_LOW + * @arg @ref LL_I2C_SMBUS_TIMEOUTA_MODE_SDA_SCL_HIGH + * @param TimeoutB + * @retval None + */ +__STATIC_INLINE void LL_I2C_ConfigSMBusTimeout(I2C_TypeDef *I2Cx, uint32_t TimeoutA, uint32_t TimeoutAMode, + uint32_t TimeoutB) +{ + MODIFY_REG(I2Cx->TIMEOUTR, I2C_TIMEOUTR_TIMEOUTA | I2C_TIMEOUTR_TIDLE | I2C_TIMEOUTR_TIMEOUTB, + TimeoutA | TimeoutAMode | (TimeoutB << I2C_TIMEOUTR_TIMEOUTB_Pos)); +} + +/** + * @brief Configure the SMBus Clock TimeoutA (SCL low timeout or SCL and SDA high timeout depends on TimeoutA mode). + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note These bits can only be programmed when TimeoutA is disabled. + * @rmtoll TIMEOUTR TIMEOUTA LL_I2C_SetSMBusTimeoutA + * @param I2Cx I2C Instance. + * @param TimeoutA This parameter must be a value between Min_Data=0 and Max_Data=0xFFF. + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetSMBusTimeoutA(I2C_TypeDef *I2Cx, uint32_t TimeoutA) +{ + WRITE_REG(I2Cx->TIMEOUTR, TimeoutA); +} + +/** + * @brief Get the SMBus Clock TimeoutA setting. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll TIMEOUTR TIMEOUTA LL_I2C_GetSMBusTimeoutA + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0 and Max_Data=0xFFF + */ +__STATIC_INLINE uint32_t LL_I2C_GetSMBusTimeoutA(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMEOUTR, I2C_TIMEOUTR_TIMEOUTA)); +} + +/** + * @brief Set the SMBus Clock TimeoutA mode. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note This bit can only be programmed when TimeoutA is disabled. + * @rmtoll TIMEOUTR TIDLE LL_I2C_SetSMBusTimeoutAMode + * @param I2Cx I2C Instance. + * @param TimeoutAMode This parameter can be one of the following values: + * @arg @ref LL_I2C_SMBUS_TIMEOUTA_MODE_SCL_LOW + * @arg @ref LL_I2C_SMBUS_TIMEOUTA_MODE_SDA_SCL_HIGH + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetSMBusTimeoutAMode(I2C_TypeDef *I2Cx, uint32_t TimeoutAMode) +{ + WRITE_REG(I2Cx->TIMEOUTR, TimeoutAMode); +} + +/** + * @brief Get the SMBus Clock TimeoutA mode. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll TIMEOUTR TIDLE LL_I2C_GetSMBusTimeoutAMode + * @param I2Cx I2C Instance. + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2C_SMBUS_TIMEOUTA_MODE_SCL_LOW + * @arg @ref LL_I2C_SMBUS_TIMEOUTA_MODE_SDA_SCL_HIGH + */ +__STATIC_INLINE uint32_t LL_I2C_GetSMBusTimeoutAMode(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMEOUTR, I2C_TIMEOUTR_TIDLE)); +} + +/** + * @brief Configure the SMBus Extended Cumulative Clock TimeoutB (Master or Slave mode). + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note These bits can only be programmed when TimeoutB is disabled. + * @rmtoll TIMEOUTR TIMEOUTB LL_I2C_SetSMBusTimeoutB + * @param I2Cx I2C Instance. + * @param TimeoutB This parameter must be a value between Min_Data=0 and Max_Data=0xFFF. + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetSMBusTimeoutB(I2C_TypeDef *I2Cx, uint32_t TimeoutB) +{ + WRITE_REG(I2Cx->TIMEOUTR, TimeoutB << I2C_TIMEOUTR_TIMEOUTB_Pos); +} + +/** + * @brief Get the SMBus Extended Cumulative Clock TimeoutB setting. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll TIMEOUTR TIMEOUTB LL_I2C_GetSMBusTimeoutB + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0 and Max_Data=0xFFF + */ +__STATIC_INLINE uint32_t LL_I2C_GetSMBusTimeoutB(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->TIMEOUTR, I2C_TIMEOUTR_TIMEOUTB) >> I2C_TIMEOUTR_TIMEOUTB_Pos); +} + +/** + * @brief Enable the SMBus Clock Timeout. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll TIMEOUTR TIMOUTEN LL_I2C_EnableSMBusTimeout\n + * TIMEOUTR TEXTEN LL_I2C_EnableSMBusTimeout + * @param I2Cx I2C Instance. + * @param ClockTimeout This parameter can be one of the following values: + * @arg @ref LL_I2C_SMBUS_TIMEOUTA + * @arg @ref LL_I2C_SMBUS_TIMEOUTB + * @arg @ref LL_I2C_SMBUS_ALL_TIMEOUT + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableSMBusTimeout(I2C_TypeDef *I2Cx, uint32_t ClockTimeout) +{ + SET_BIT(I2Cx->TIMEOUTR, ClockTimeout); +} + +/** + * @brief Disable the SMBus Clock Timeout. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll TIMEOUTR TIMOUTEN LL_I2C_DisableSMBusTimeout\n + * TIMEOUTR TEXTEN LL_I2C_DisableSMBusTimeout + * @param I2Cx I2C Instance. + * @param ClockTimeout This parameter can be one of the following values: + * @arg @ref LL_I2C_SMBUS_TIMEOUTA + * @arg @ref LL_I2C_SMBUS_TIMEOUTB + * @arg @ref LL_I2C_SMBUS_ALL_TIMEOUT + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableSMBusTimeout(I2C_TypeDef *I2Cx, uint32_t ClockTimeout) +{ + CLEAR_BIT(I2Cx->TIMEOUTR, ClockTimeout); +} + +/** + * @brief Check if the SMBus Clock Timeout is enabled or disabled. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll TIMEOUTR TIMOUTEN LL_I2C_IsEnabledSMBusTimeout\n + * TIMEOUTR TEXTEN LL_I2C_IsEnabledSMBusTimeout + * @param I2Cx I2C Instance. + * @param ClockTimeout This parameter can be one of the following values: + * @arg @ref LL_I2C_SMBUS_TIMEOUTA + * @arg @ref LL_I2C_SMBUS_TIMEOUTB + * @arg @ref LL_I2C_SMBUS_ALL_TIMEOUT + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledSMBusTimeout(I2C_TypeDef *I2Cx, uint32_t ClockTimeout) +{ + return ((READ_BIT(I2Cx->TIMEOUTR, (I2C_TIMEOUTR_TIMOUTEN | I2C_TIMEOUTR_TEXTEN)) == \ + (ClockTimeout)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup I2C_LL_EF_IT_Management IT_Management + * @{ + */ + +/** + * @brief Enable TXIS interrupt. + * @rmtoll CR1 TXIE LL_I2C_EnableIT_TX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableIT_TX(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_TXIE); +} + +/** + * @brief Disable TXIS interrupt. + * @rmtoll CR1 TXIE LL_I2C_DisableIT_TX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableIT_TX(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_TXIE); +} + +/** + * @brief Check if the TXIS Interrupt is enabled or disabled. + * @rmtoll CR1 TXIE LL_I2C_IsEnabledIT_TX + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledIT_TX(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_TXIE) == (I2C_CR1_TXIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable RXNE interrupt. + * @rmtoll CR1 RXIE LL_I2C_EnableIT_RX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableIT_RX(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_RXIE); +} + +/** + * @brief Disable RXNE interrupt. + * @rmtoll CR1 RXIE LL_I2C_DisableIT_RX + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableIT_RX(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_RXIE); +} + +/** + * @brief Check if the RXNE Interrupt is enabled or disabled. + * @rmtoll CR1 RXIE LL_I2C_IsEnabledIT_RX + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledIT_RX(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_RXIE) == (I2C_CR1_RXIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable Address match interrupt (slave mode only). + * @rmtoll CR1 ADDRIE LL_I2C_EnableIT_ADDR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableIT_ADDR(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_ADDRIE); +} + +/** + * @brief Disable Address match interrupt (slave mode only). + * @rmtoll CR1 ADDRIE LL_I2C_DisableIT_ADDR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableIT_ADDR(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_ADDRIE); +} + +/** + * @brief Check if Address match interrupt is enabled or disabled. + * @rmtoll CR1 ADDRIE LL_I2C_IsEnabledIT_ADDR + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledIT_ADDR(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_ADDRIE) == (I2C_CR1_ADDRIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable Not acknowledge received interrupt. + * @rmtoll CR1 NACKIE LL_I2C_EnableIT_NACK + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableIT_NACK(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_NACKIE); +} + +/** + * @brief Disable Not acknowledge received interrupt. + * @rmtoll CR1 NACKIE LL_I2C_DisableIT_NACK + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableIT_NACK(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_NACKIE); +} + +/** + * @brief Check if Not acknowledge received interrupt is enabled or disabled. + * @rmtoll CR1 NACKIE LL_I2C_IsEnabledIT_NACK + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledIT_NACK(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_NACKIE) == (I2C_CR1_NACKIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable STOP detection interrupt. + * @rmtoll CR1 STOPIE LL_I2C_EnableIT_STOP + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableIT_STOP(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_STOPIE); +} + +/** + * @brief Disable STOP detection interrupt. + * @rmtoll CR1 STOPIE LL_I2C_DisableIT_STOP + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableIT_STOP(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_STOPIE); +} + +/** + * @brief Check if STOP detection interrupt is enabled or disabled. + * @rmtoll CR1 STOPIE LL_I2C_IsEnabledIT_STOP + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledIT_STOP(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_STOPIE) == (I2C_CR1_STOPIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable Transfer Complete interrupt. + * @note Any of these events will generate interrupt : + * Transfer Complete (TC) + * Transfer Complete Reload (TCR) + * @rmtoll CR1 TCIE LL_I2C_EnableIT_TC + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableIT_TC(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_TCIE); +} + +/** + * @brief Disable Transfer Complete interrupt. + * @note Any of these events will generate interrupt : + * Transfer Complete (TC) + * Transfer Complete Reload (TCR) + * @rmtoll CR1 TCIE LL_I2C_DisableIT_TC + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableIT_TC(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_TCIE); +} + +/** + * @brief Check if Transfer Complete interrupt is enabled or disabled. + * @rmtoll CR1 TCIE LL_I2C_IsEnabledIT_TC + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledIT_TC(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_TCIE) == (I2C_CR1_TCIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable Error interrupts. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note Any of these errors will generate interrupt : + * Arbitration Loss (ARLO) + * Bus Error detection (BERR) + * Overrun/Underrun (OVR) + * SMBus Timeout detection (TIMEOUT) + * SMBus PEC error detection (PECERR) + * SMBus Alert pin event detection (ALERT) + * @rmtoll CR1 ERRIE LL_I2C_EnableIT_ERR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableIT_ERR(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR1, I2C_CR1_ERRIE); +} + +/** + * @brief Disable Error interrupts. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note Any of these errors will generate interrupt : + * Arbitration Loss (ARLO) + * Bus Error detection (BERR) + * Overrun/Underrun (OVR) + * SMBus Timeout detection (TIMEOUT) + * SMBus PEC error detection (PECERR) + * SMBus Alert pin event detection (ALERT) + * @rmtoll CR1 ERRIE LL_I2C_DisableIT_ERR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableIT_ERR(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR1, I2C_CR1_ERRIE); +} + +/** + * @brief Check if Error interrupts are enabled or disabled. + * @rmtoll CR1 ERRIE LL_I2C_IsEnabledIT_ERR + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledIT_ERR(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR1, I2C_CR1_ERRIE) == (I2C_CR1_ERRIE)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup I2C_LL_EF_FLAG_management FLAG_management + * @{ + */ + +/** + * @brief Indicate the status of Transmit data register empty flag. + * @note RESET: When next data is written in Transmit data register. + * SET: When Transmit data register is empty. + * @rmtoll ISR TXE LL_I2C_IsActiveFlag_TXE + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_TXE(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_TXE) == (I2C_ISR_TXE)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Transmit interrupt flag. + * @note RESET: When next data is written in Transmit data register. + * SET: When Transmit data register is empty. + * @rmtoll ISR TXIS LL_I2C_IsActiveFlag_TXIS + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_TXIS(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_TXIS) == (I2C_ISR_TXIS)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Receive data register not empty flag. + * @note RESET: When Receive data register is read. + * SET: When the received data is copied in Receive data register. + * @rmtoll ISR RXNE LL_I2C_IsActiveFlag_RXNE + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_RXNE(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_RXNE) == (I2C_ISR_RXNE)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Address matched flag (slave mode). + * @note RESET: Clear default value. + * SET: When the received slave address matched with one of the enabled slave address. + * @rmtoll ISR ADDR LL_I2C_IsActiveFlag_ADDR + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_ADDR(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_ADDR) == (I2C_ISR_ADDR)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Not Acknowledge received flag. + * @note RESET: Clear default value. + * SET: When a NACK is received after a byte transmission. + * @rmtoll ISR NACKF LL_I2C_IsActiveFlag_NACK + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_NACK(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_NACKF) == (I2C_ISR_NACKF)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Stop detection flag. + * @note RESET: Clear default value. + * SET: When a Stop condition is detected. + * @rmtoll ISR STOPF LL_I2C_IsActiveFlag_STOP + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_STOP(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_STOPF) == (I2C_ISR_STOPF)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Transfer complete flag (master mode). + * @note RESET: Clear default value. + * SET: When RELOAD=0, AUTOEND=0 and NBYTES date have been transferred. + * @rmtoll ISR TC LL_I2C_IsActiveFlag_TC + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_TC(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_TC) == (I2C_ISR_TC)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Transfer complete flag (master mode). + * @note RESET: Clear default value. + * SET: When RELOAD=1 and NBYTES date have been transferred. + * @rmtoll ISR TCR LL_I2C_IsActiveFlag_TCR + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_TCR(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_TCR) == (I2C_ISR_TCR)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Bus error flag. + * @note RESET: Clear default value. + * SET: When a misplaced Start or Stop condition is detected. + * @rmtoll ISR BERR LL_I2C_IsActiveFlag_BERR + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_BERR(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_BERR) == (I2C_ISR_BERR)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Arbitration lost flag. + * @note RESET: Clear default value. + * SET: When arbitration lost. + * @rmtoll ISR ARLO LL_I2C_IsActiveFlag_ARLO + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_ARLO(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_ARLO) == (I2C_ISR_ARLO)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Overrun/Underrun flag (slave mode). + * @note RESET: Clear default value. + * SET: When an overrun/underrun error occurs (Clock Stretching Disabled). + * @rmtoll ISR OVR LL_I2C_IsActiveFlag_OVR + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_OVR(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_OVR) == (I2C_ISR_OVR)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of SMBus PEC error flag in reception. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note RESET: Clear default value. + * SET: When the received PEC does not match with the PEC register content. + * @rmtoll ISR PECERR LL_I2C_IsActiveSMBusFlag_PECERR + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveSMBusFlag_PECERR(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_PECERR) == (I2C_ISR_PECERR)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of SMBus Timeout detection flag. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note RESET: Clear default value. + * SET: When a timeout or extended clock timeout occurs. + * @rmtoll ISR TIMEOUT LL_I2C_IsActiveSMBusFlag_TIMEOUT + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveSMBusFlag_TIMEOUT(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_TIMEOUT) == (I2C_ISR_TIMEOUT)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of SMBus alert flag. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note RESET: Clear default value. + * SET: When SMBus host configuration, SMBus alert enabled and + * a falling edge event occurs on SMBA pin. + * @rmtoll ISR ALERT LL_I2C_IsActiveSMBusFlag_ALERT + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveSMBusFlag_ALERT(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_ALERT) == (I2C_ISR_ALERT)) ? 1UL : 0UL); +} + +/** + * @brief Indicate the status of Bus Busy flag. + * @note RESET: Clear default value. + * SET: When a Start condition is detected. + * @rmtoll ISR BUSY LL_I2C_IsActiveFlag_BUSY + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsActiveFlag_BUSY(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->ISR, I2C_ISR_BUSY) == (I2C_ISR_BUSY)) ? 1UL : 0UL); +} + +/** + * @brief Clear Address Matched flag. + * @rmtoll ICR ADDRCF LL_I2C_ClearFlag_ADDR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearFlag_ADDR(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_ADDRCF); +} + +/** + * @brief Clear Not Acknowledge flag. + * @rmtoll ICR NACKCF LL_I2C_ClearFlag_NACK + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearFlag_NACK(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_NACKCF); +} + +/** + * @brief Clear Stop detection flag. + * @rmtoll ICR STOPCF LL_I2C_ClearFlag_STOP + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearFlag_STOP(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_STOPCF); +} + +/** + * @brief Clear Transmit data register empty flag (TXE). + * @note This bit can be clear by software in order to flush the transmit data register (TXDR). + * @rmtoll ISR TXE LL_I2C_ClearFlag_TXE + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearFlag_TXE(I2C_TypeDef *I2Cx) +{ + WRITE_REG(I2Cx->ISR, I2C_ISR_TXE); +} + +/** + * @brief Clear Bus error flag. + * @rmtoll ICR BERRCF LL_I2C_ClearFlag_BERR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearFlag_BERR(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_BERRCF); +} + +/** + * @brief Clear Arbitration lost flag. + * @rmtoll ICR ARLOCF LL_I2C_ClearFlag_ARLO + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearFlag_ARLO(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_ARLOCF); +} + +/** + * @brief Clear Overrun/Underrun flag. + * @rmtoll ICR OVRCF LL_I2C_ClearFlag_OVR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearFlag_OVR(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_OVRCF); +} + +/** + * @brief Clear SMBus PEC error flag. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll ICR PECCF LL_I2C_ClearSMBusFlag_PECERR + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearSMBusFlag_PECERR(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_PECCF); +} + +/** + * @brief Clear SMBus Timeout detection flag. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll ICR TIMOUTCF LL_I2C_ClearSMBusFlag_TIMEOUT + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearSMBusFlag_TIMEOUT(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_TIMOUTCF); +} + +/** + * @brief Clear SMBus Alert flag. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll ICR ALERTCF LL_I2C_ClearSMBusFlag_ALERT + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_ClearSMBusFlag_ALERT(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->ICR, I2C_ICR_ALERTCF); +} + +/** + * @} + */ + +/** @defgroup I2C_LL_EF_Data_Management Data_Management + * @{ + */ + +/** + * @brief Enable automatic STOP condition generation (master mode). + * @note Automatic end mode : a STOP condition is automatically sent when NBYTES data are transferred. + * This bit has no effect in slave mode or when RELOAD bit is set. + * @rmtoll CR2 AUTOEND LL_I2C_EnableAutoEndMode + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableAutoEndMode(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR2, I2C_CR2_AUTOEND); +} + +/** + * @brief Disable automatic STOP condition generation (master mode). + * @note Software end mode : TC flag is set when NBYTES data are transferre, stretching SCL low. + * @rmtoll CR2 AUTOEND LL_I2C_DisableAutoEndMode + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableAutoEndMode(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR2, I2C_CR2_AUTOEND); +} + +/** + * @brief Check if automatic STOP condition is enabled or disabled. + * @rmtoll CR2 AUTOEND LL_I2C_IsEnabledAutoEndMode + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledAutoEndMode(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR2, I2C_CR2_AUTOEND) == (I2C_CR2_AUTOEND)) ? 1UL : 0UL); +} + +/** + * @brief Enable reload mode (master mode). + * @note The transfer is not completed after the NBYTES data transfer, NBYTES will be reloaded when TCR flag is set. + * @rmtoll CR2 RELOAD LL_I2C_EnableReloadMode + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableReloadMode(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR2, I2C_CR2_RELOAD); +} + +/** + * @brief Disable reload mode (master mode). + * @note The transfer is completed after the NBYTES data transfer(STOP or RESTART will follow). + * @rmtoll CR2 RELOAD LL_I2C_DisableReloadMode + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableReloadMode(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR2, I2C_CR2_RELOAD); +} + +/** + * @brief Check if reload mode is enabled or disabled. + * @rmtoll CR2 RELOAD LL_I2C_IsEnabledReloadMode + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledReloadMode(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR2, I2C_CR2_RELOAD) == (I2C_CR2_RELOAD)) ? 1UL : 0UL); +} + +/** + * @brief Configure the number of bytes for transfer. + * @note Changing these bits when START bit is set is not allowed. + * @rmtoll CR2 NBYTES LL_I2C_SetTransferSize + * @param I2Cx I2C Instance. + * @param TransferSize This parameter must be a value between Min_Data=0x00 and Max_Data=0xFF. + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetTransferSize(I2C_TypeDef *I2Cx, uint32_t TransferSize) +{ + MODIFY_REG(I2Cx->CR2, I2C_CR2_NBYTES, TransferSize << I2C_CR2_NBYTES_Pos); +} + +/** + * @brief Get the number of bytes configured for transfer. + * @rmtoll CR2 NBYTES LL_I2C_GetTransferSize + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x0 and Max_Data=0xFF + */ +__STATIC_INLINE uint32_t LL_I2C_GetTransferSize(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->CR2, I2C_CR2_NBYTES) >> I2C_CR2_NBYTES_Pos); +} + +/** + * @brief Prepare the generation of a ACKnowledge or Non ACKnowledge condition after the address receive match code + or next received byte. + * @note Usage in Slave mode only. + * @rmtoll CR2 NACK LL_I2C_AcknowledgeNextData + * @param I2Cx I2C Instance. + * @param TypeAcknowledge This parameter can be one of the following values: + * @arg @ref LL_I2C_ACK + * @arg @ref LL_I2C_NACK + * @retval None + */ +__STATIC_INLINE void LL_I2C_AcknowledgeNextData(I2C_TypeDef *I2Cx, uint32_t TypeAcknowledge) +{ + MODIFY_REG(I2Cx->CR2, I2C_CR2_NACK, TypeAcknowledge); +} + +/** + * @brief Generate a START or RESTART condition + * @note The START bit can be set even if bus is BUSY or I2C is in slave mode. + * This action has no effect when RELOAD is set. + * @rmtoll CR2 START LL_I2C_GenerateStartCondition + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_GenerateStartCondition(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR2, I2C_CR2_START); +} + +/** + * @brief Generate a STOP condition after the current byte transfer (master mode). + * @rmtoll CR2 STOP LL_I2C_GenerateStopCondition + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_GenerateStopCondition(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR2, I2C_CR2_STOP); +} + +/** + * @brief Enable automatic RESTART Read request condition for 10bit address header (master mode). + * @note The master sends the complete 10bit slave address read sequence : + * Start + 2 bytes 10bit address in Write direction + Restart + first 7 bits of 10bit address + in Read direction. + * @rmtoll CR2 HEAD10R LL_I2C_EnableAuto10BitRead + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableAuto10BitRead(I2C_TypeDef *I2Cx) +{ + CLEAR_BIT(I2Cx->CR2, I2C_CR2_HEAD10R); +} + +/** + * @brief Disable automatic RESTART Read request condition for 10bit address header (master mode). + * @note The master only sends the first 7 bits of 10bit address in Read direction. + * @rmtoll CR2 HEAD10R LL_I2C_DisableAuto10BitRead + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_DisableAuto10BitRead(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR2, I2C_CR2_HEAD10R); +} + +/** + * @brief Check if automatic RESTART Read request condition for 10bit address header is enabled or disabled. + * @rmtoll CR2 HEAD10R LL_I2C_IsEnabledAuto10BitRead + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledAuto10BitRead(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR2, I2C_CR2_HEAD10R) != (I2C_CR2_HEAD10R)) ? 1UL : 0UL); +} + +/** + * @brief Configure the transfer direction (master mode). + * @note Changing these bits when START bit is set is not allowed. + * @rmtoll CR2 RD_WRN LL_I2C_SetTransferRequest + * @param I2Cx I2C Instance. + * @param TransferRequest This parameter can be one of the following values: + * @arg @ref LL_I2C_REQUEST_WRITE + * @arg @ref LL_I2C_REQUEST_READ + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetTransferRequest(I2C_TypeDef *I2Cx, uint32_t TransferRequest) +{ + MODIFY_REG(I2Cx->CR2, I2C_CR2_RD_WRN, TransferRequest); +} + +/** + * @brief Get the transfer direction requested (master mode). + * @rmtoll CR2 RD_WRN LL_I2C_GetTransferRequest + * @param I2Cx I2C Instance. + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2C_REQUEST_WRITE + * @arg @ref LL_I2C_REQUEST_READ + */ +__STATIC_INLINE uint32_t LL_I2C_GetTransferRequest(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->CR2, I2C_CR2_RD_WRN)); +} + +/** + * @brief Configure the slave address for transfer (master mode). + * @note Changing these bits when START bit is set is not allowed. + * @rmtoll CR2 SADD LL_I2C_SetSlaveAddr + * @param I2Cx I2C Instance. + * @param SlaveAddr This parameter must be a value between Min_Data=0x00 and Max_Data=0x3F. + * @retval None + */ +__STATIC_INLINE void LL_I2C_SetSlaveAddr(I2C_TypeDef *I2Cx, uint32_t SlaveAddr) +{ + MODIFY_REG(I2Cx->CR2, I2C_CR2_SADD, SlaveAddr); +} + +/** + * @brief Get the slave address programmed for transfer. + * @rmtoll CR2 SADD LL_I2C_GetSlaveAddr + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x0 and Max_Data=0x3F + */ +__STATIC_INLINE uint32_t LL_I2C_GetSlaveAddr(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->CR2, I2C_CR2_SADD)); +} + +/** + * @brief Handles I2Cx communication when starting transfer or during transfer (TC or TCR flag are set). + * @rmtoll CR2 SADD LL_I2C_HandleTransfer\n + * CR2 ADD10 LL_I2C_HandleTransfer\n + * CR2 RD_WRN LL_I2C_HandleTransfer\n + * CR2 START LL_I2C_HandleTransfer\n + * CR2 STOP LL_I2C_HandleTransfer\n + * CR2 RELOAD LL_I2C_HandleTransfer\n + * CR2 NBYTES LL_I2C_HandleTransfer\n + * CR2 AUTOEND LL_I2C_HandleTransfer\n + * CR2 HEAD10R LL_I2C_HandleTransfer + * @param I2Cx I2C Instance. + * @param SlaveAddr Specifies the slave address to be programmed. + * @param SlaveAddrSize This parameter can be one of the following values: + * @arg @ref LL_I2C_ADDRSLAVE_7BIT + * @arg @ref LL_I2C_ADDRSLAVE_10BIT + * @param TransferSize Specifies the number of bytes to be programmed. + * This parameter must be a value between Min_Data=0 and Max_Data=255. + * @param EndMode This parameter can be one of the following values: + * @arg @ref LL_I2C_MODE_RELOAD + * @arg @ref LL_I2C_MODE_AUTOEND + * @arg @ref LL_I2C_MODE_SOFTEND + * @arg @ref LL_I2C_MODE_SMBUS_RELOAD + * @arg @ref LL_I2C_MODE_SMBUS_AUTOEND_NO_PEC + * @arg @ref LL_I2C_MODE_SMBUS_SOFTEND_NO_PEC + * @arg @ref LL_I2C_MODE_SMBUS_AUTOEND_WITH_PEC + * @arg @ref LL_I2C_MODE_SMBUS_SOFTEND_WITH_PEC + * @param Request This parameter can be one of the following values: + * @arg @ref LL_I2C_GENERATE_NOSTARTSTOP + * @arg @ref LL_I2C_GENERATE_STOP + * @arg @ref LL_I2C_GENERATE_START_READ + * @arg @ref LL_I2C_GENERATE_START_WRITE + * @arg @ref LL_I2C_GENERATE_RESTART_7BIT_READ + * @arg @ref LL_I2C_GENERATE_RESTART_7BIT_WRITE + * @arg @ref LL_I2C_GENERATE_RESTART_10BIT_READ + * @arg @ref LL_I2C_GENERATE_RESTART_10BIT_WRITE + * @retval None + */ +__STATIC_INLINE void LL_I2C_HandleTransfer(I2C_TypeDef *I2Cx, uint32_t SlaveAddr, uint32_t SlaveAddrSize, + uint32_t TransferSize, uint32_t EndMode, uint32_t Request) +{ + MODIFY_REG(I2Cx->CR2, I2C_CR2_SADD | I2C_CR2_ADD10 | + (I2C_CR2_RD_WRN & (uint32_t)(Request >> (31U - I2C_CR2_RD_WRN_Pos))) | + I2C_CR2_START | I2C_CR2_STOP | I2C_CR2_RELOAD | + I2C_CR2_NBYTES | I2C_CR2_AUTOEND | I2C_CR2_HEAD10R, + SlaveAddr | SlaveAddrSize | (TransferSize << I2C_CR2_NBYTES_Pos) | EndMode | Request); +} + +/** + * @brief Indicate the value of transfer direction (slave mode). + * @note RESET: Write transfer, Slave enters in receiver mode. + * SET: Read transfer, Slave enters in transmitter mode. + * @rmtoll ISR DIR LL_I2C_GetTransferDirection + * @param I2Cx I2C Instance. + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2C_DIRECTION_WRITE + * @arg @ref LL_I2C_DIRECTION_READ + */ +__STATIC_INLINE uint32_t LL_I2C_GetTransferDirection(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->ISR, I2C_ISR_DIR)); +} + +/** + * @brief Return the slave matched address. + * @rmtoll ISR ADDCODE LL_I2C_GetAddressMatchCode + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x00 and Max_Data=0x3F + */ +__STATIC_INLINE uint32_t LL_I2C_GetAddressMatchCode(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->ISR, I2C_ISR_ADDCODE) >> I2C_ISR_ADDCODE_Pos << 1); +} + +/** + * @brief Enable internal comparison of the SMBus Packet Error byte (transmission or reception mode). + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @note This feature is cleared by hardware when the PEC byte is transferred, or when a STOP condition + or an Address Matched is received. + * This bit has no effect when RELOAD bit is set. + * This bit has no effect in device mode when SBC bit is not set. + * @rmtoll CR2 PECBYTE LL_I2C_EnableSMBusPECCompare + * @param I2Cx I2C Instance. + * @retval None + */ +__STATIC_INLINE void LL_I2C_EnableSMBusPECCompare(I2C_TypeDef *I2Cx) +{ + SET_BIT(I2Cx->CR2, I2C_CR2_PECBYTE); +} + +/** + * @brief Check if the SMBus Packet Error byte internal comparison is requested or not. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll CR2 PECBYTE LL_I2C_IsEnabledSMBusPECCompare + * @param I2Cx I2C Instance. + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2C_IsEnabledSMBusPECCompare(I2C_TypeDef *I2Cx) +{ + return ((READ_BIT(I2Cx->CR2, I2C_CR2_PECBYTE) == (I2C_CR2_PECBYTE)) ? 1UL : 0UL); +} + +/** + * @brief Get the SMBus Packet Error byte calculated. + * @note The macro IS_SMBUS_ALL_INSTANCE(I2Cx) can be used to check whether or not + * SMBus feature is supported by the I2Cx Instance. + * @rmtoll PECR PEC LL_I2C_GetSMBusPEC + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint32_t LL_I2C_GetSMBusPEC(I2C_TypeDef *I2Cx) +{ + return (uint32_t)(READ_BIT(I2Cx->PECR, I2C_PECR_PEC)); +} + +/** + * @brief Read Receive Data register. + * @rmtoll RXDR RXDATA LL_I2C_ReceiveData8 + * @param I2Cx I2C Instance. + * @retval Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint8_t LL_I2C_ReceiveData8(I2C_TypeDef *I2Cx) +{ + return (uint8_t)(READ_BIT(I2Cx->RXDR, I2C_RXDR_RXDATA)); +} + +/** + * @brief Write in Transmit Data Register . + * @rmtoll TXDR TXDATA LL_I2C_TransmitData8 + * @param I2Cx I2C Instance. + * @param Data Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_I2C_TransmitData8(I2C_TypeDef *I2Cx, uint8_t Data) +{ + WRITE_REG(I2Cx->TXDR, Data); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup I2C_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_I2C_Init(I2C_TypeDef *I2Cx, LL_I2C_InitTypeDef *I2C_InitStruct); +ErrorStatus LL_I2C_DeInit(I2C_TypeDef *I2Cx); +void LL_I2C_StructInit(LL_I2C_InitTypeDef *I2C_InitStruct); + + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* I2C1 || I2C2 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_LL_I2C_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_iwdg.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_iwdg.h new file mode 100644 index 0000000..f43e430 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_iwdg.h @@ -0,0 +1,341 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_iwdg.h + * @author MCD Application Team + * @brief Header file of IWDG LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_LL_IWDG_H +#define STM32F0xx_LL_IWDG_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(IWDG) + +/** @defgroup IWDG_LL IWDG + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup IWDG_LL_Private_Constants IWDG Private Constants + * @{ + */ +#define LL_IWDG_KEY_RELOAD 0x0000AAAAU /*!< IWDG Reload Counter Enable */ +#define LL_IWDG_KEY_ENABLE 0x0000CCCCU /*!< IWDG Peripheral Enable */ +#define LL_IWDG_KEY_WR_ACCESS_ENABLE 0x00005555U /*!< IWDG KR Write Access Enable */ +#define LL_IWDG_KEY_WR_ACCESS_DISABLE 0x00000000U /*!< IWDG KR Write Access Disable */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup IWDG_LL_Exported_Constants IWDG Exported Constants + * @{ + */ + +/** @defgroup IWDG_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_IWDG_ReadReg function + * @{ + */ +#define LL_IWDG_SR_PVU IWDG_SR_PVU /*!< Watchdog prescaler value update */ +#define LL_IWDG_SR_RVU IWDG_SR_RVU /*!< Watchdog counter reload value update */ +#define LL_IWDG_SR_WVU IWDG_SR_WVU /*!< Watchdog counter window value update */ +/** + * @} + */ + +/** @defgroup IWDG_LL_EC_PRESCALER Prescaler Divider + * @{ + */ +#define LL_IWDG_PRESCALER_4 0x00000000U /*!< Divider by 4 */ +#define LL_IWDG_PRESCALER_8 (IWDG_PR_PR_0) /*!< Divider by 8 */ +#define LL_IWDG_PRESCALER_16 (IWDG_PR_PR_1) /*!< Divider by 16 */ +#define LL_IWDG_PRESCALER_32 (IWDG_PR_PR_1 | IWDG_PR_PR_0) /*!< Divider by 32 */ +#define LL_IWDG_PRESCALER_64 (IWDG_PR_PR_2) /*!< Divider by 64 */ +#define LL_IWDG_PRESCALER_128 (IWDG_PR_PR_2 | IWDG_PR_PR_0) /*!< Divider by 128 */ +#define LL_IWDG_PRESCALER_256 (IWDG_PR_PR_2 | IWDG_PR_PR_1) /*!< Divider by 256 */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup IWDG_LL_Exported_Macros IWDG Exported Macros + * @{ + */ + +/** @defgroup IWDG_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in IWDG register + * @param __INSTANCE__ IWDG Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_IWDG_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in IWDG register + * @param __INSTANCE__ IWDG Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_IWDG_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup IWDG_LL_Exported_Functions IWDG Exported Functions + * @{ + */ +/** @defgroup IWDG_LL_EF_Configuration Configuration + * @{ + */ + +/** + * @brief Start the Independent Watchdog + * @note Except if the hardware watchdog option is selected + * @rmtoll KR KEY LL_IWDG_Enable + * @param IWDGx IWDG Instance + * @retval None + */ +__STATIC_INLINE void LL_IWDG_Enable(IWDG_TypeDef *IWDGx) +{ + WRITE_REG(IWDGx->KR, LL_IWDG_KEY_ENABLE); +} + +/** + * @brief Reloads IWDG counter with value defined in the reload register + * @rmtoll KR KEY LL_IWDG_ReloadCounter + * @param IWDGx IWDG Instance + * @retval None + */ +__STATIC_INLINE void LL_IWDG_ReloadCounter(IWDG_TypeDef *IWDGx) +{ + WRITE_REG(IWDGx->KR, LL_IWDG_KEY_RELOAD); +} + +/** + * @brief Enable write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers + * @rmtoll KR KEY LL_IWDG_EnableWriteAccess + * @param IWDGx IWDG Instance + * @retval None + */ +__STATIC_INLINE void LL_IWDG_EnableWriteAccess(IWDG_TypeDef *IWDGx) +{ + WRITE_REG(IWDGx->KR, LL_IWDG_KEY_WR_ACCESS_ENABLE); +} + +/** + * @brief Disable write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers + * @rmtoll KR KEY LL_IWDG_DisableWriteAccess + * @param IWDGx IWDG Instance + * @retval None + */ +__STATIC_INLINE void LL_IWDG_DisableWriteAccess(IWDG_TypeDef *IWDGx) +{ + WRITE_REG(IWDGx->KR, LL_IWDG_KEY_WR_ACCESS_DISABLE); +} + +/** + * @brief Select the prescaler of the IWDG + * @rmtoll PR PR LL_IWDG_SetPrescaler + * @param IWDGx IWDG Instance + * @param Prescaler This parameter can be one of the following values: + * @arg @ref LL_IWDG_PRESCALER_4 + * @arg @ref LL_IWDG_PRESCALER_8 + * @arg @ref LL_IWDG_PRESCALER_16 + * @arg @ref LL_IWDG_PRESCALER_32 + * @arg @ref LL_IWDG_PRESCALER_64 + * @arg @ref LL_IWDG_PRESCALER_128 + * @arg @ref LL_IWDG_PRESCALER_256 + * @retval None + */ +__STATIC_INLINE void LL_IWDG_SetPrescaler(IWDG_TypeDef *IWDGx, uint32_t Prescaler) +{ + WRITE_REG(IWDGx->PR, IWDG_PR_PR & Prescaler); +} + +/** + * @brief Get the selected prescaler of the IWDG + * @rmtoll PR PR LL_IWDG_GetPrescaler + * @param IWDGx IWDG Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_IWDG_PRESCALER_4 + * @arg @ref LL_IWDG_PRESCALER_8 + * @arg @ref LL_IWDG_PRESCALER_16 + * @arg @ref LL_IWDG_PRESCALER_32 + * @arg @ref LL_IWDG_PRESCALER_64 + * @arg @ref LL_IWDG_PRESCALER_128 + * @arg @ref LL_IWDG_PRESCALER_256 + */ +__STATIC_INLINE uint32_t LL_IWDG_GetPrescaler(IWDG_TypeDef *IWDGx) +{ + return (READ_REG(IWDGx->PR)); +} + +/** + * @brief Specify the IWDG down-counter reload value + * @rmtoll RLR RL LL_IWDG_SetReloadCounter + * @param IWDGx IWDG Instance + * @param Counter Value between Min_Data=0 and Max_Data=0x0FFF + * @retval None + */ +__STATIC_INLINE void LL_IWDG_SetReloadCounter(IWDG_TypeDef *IWDGx, uint32_t Counter) +{ + WRITE_REG(IWDGx->RLR, IWDG_RLR_RL & Counter); +} + +/** + * @brief Get the specified IWDG down-counter reload value + * @rmtoll RLR RL LL_IWDG_GetReloadCounter + * @param IWDGx IWDG Instance + * @retval Value between Min_Data=0 and Max_Data=0x0FFF + */ +__STATIC_INLINE uint32_t LL_IWDG_GetReloadCounter(IWDG_TypeDef *IWDGx) +{ + return (READ_REG(IWDGx->RLR)); +} + +/** + * @brief Specify high limit of the window value to be compared to the down-counter. + * @rmtoll WINR WIN LL_IWDG_SetWindow + * @param IWDGx IWDG Instance + * @param Window Value between Min_Data=0 and Max_Data=0x0FFF + * @retval None + */ +__STATIC_INLINE void LL_IWDG_SetWindow(IWDG_TypeDef *IWDGx, uint32_t Window) +{ + WRITE_REG(IWDGx->WINR, IWDG_WINR_WIN & Window); +} + +/** + * @brief Get the high limit of the window value specified. + * @rmtoll WINR WIN LL_IWDG_GetWindow + * @param IWDGx IWDG Instance + * @retval Value between Min_Data=0 and Max_Data=0x0FFF + */ +__STATIC_INLINE uint32_t LL_IWDG_GetWindow(IWDG_TypeDef *IWDGx) +{ + return (READ_REG(IWDGx->WINR)); +} + +/** + * @} + */ + +/** @defgroup IWDG_LL_EF_FLAG_Management FLAG_Management + * @{ + */ + +/** + * @brief Check if flag Prescaler Value Update is set or not + * @rmtoll SR PVU LL_IWDG_IsActiveFlag_PVU + * @param IWDGx IWDG Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_IWDG_IsActiveFlag_PVU(IWDG_TypeDef *IWDGx) +{ + return ((READ_BIT(IWDGx->SR, IWDG_SR_PVU) == (IWDG_SR_PVU)) ? 1UL : 0UL); +} + +/** + * @brief Check if flag Reload Value Update is set or not + * @rmtoll SR RVU LL_IWDG_IsActiveFlag_RVU + * @param IWDGx IWDG Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_IWDG_IsActiveFlag_RVU(IWDG_TypeDef *IWDGx) +{ + return ((READ_BIT(IWDGx->SR, IWDG_SR_RVU) == (IWDG_SR_RVU)) ? 1UL : 0UL); +} + +/** + * @brief Check if flag Window Value Update is set or not + * @rmtoll SR WVU LL_IWDG_IsActiveFlag_WVU + * @param IWDGx IWDG Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_IWDG_IsActiveFlag_WVU(IWDG_TypeDef *IWDGx) +{ + return ((READ_BIT(IWDGx->SR, IWDG_SR_WVU) == (IWDG_SR_WVU)) ? 1UL : 0UL); +} + +/** + * @brief Check if all flags Prescaler, Reload & Window Value Update are reset or not + * @rmtoll SR PVU LL_IWDG_IsReady\n + * SR RVU LL_IWDG_IsReady\n + * SR WVU LL_IWDG_IsReady + * @param IWDGx IWDG Instance + * @retval State of bits (1 or 0). + */ +__STATIC_INLINE uint32_t LL_IWDG_IsReady(IWDG_TypeDef *IWDGx) +{ + return ((READ_BIT(IWDGx->SR, IWDG_SR_PVU | IWDG_SR_RVU | IWDG_SR_WVU) == 0U) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* IWDG */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_LL_IWDG_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_pwr.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_pwr.h new file mode 100644 index 0000000..9a9b423 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_pwr.h @@ -0,0 +1,552 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_pwr.h + * @author MCD Application Team + * @brief Header file of PWR LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_PWR_H +#define __STM32F0xx_LL_PWR_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(PWR) + +/** @defgroup PWR_LL PWR + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup PWR_LL_Exported_Constants PWR Exported Constants + * @{ + */ + +/** @defgroup PWR_LL_EC_CLEAR_FLAG Clear Flags Defines + * @brief Flags defines which can be used with LL_PWR_WriteReg function + * @{ + */ +#define LL_PWR_CR_CSBF PWR_CR_CSBF /*!< Clear standby flag */ +#define LL_PWR_CR_CWUF PWR_CR_CWUF /*!< Clear wakeup flag */ +/** + * @} + */ + +/** @defgroup PWR_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_PWR_ReadReg function + * @{ + */ +#define LL_PWR_CSR_WUF PWR_CSR_WUF /*!< Wakeup flag */ +#define LL_PWR_CSR_SBF PWR_CSR_SBF /*!< Standby flag */ +#if defined(PWR_PVD_SUPPORT) +#define LL_PWR_CSR_PVDO PWR_CSR_PVDO /*!< Power voltage detector output flag */ +#endif /* PWR_PVD_SUPPORT */ +#if defined(PWR_CSR_VREFINTRDYF) +#define LL_PWR_CSR_VREFINTRDYF PWR_CSR_VREFINTRDYF /*!< VREFINT ready flag */ +#endif /* PWR_CSR_VREFINTRDYF */ +#define LL_PWR_CSR_EWUP1 PWR_CSR_EWUP1 /*!< Enable WKUP pin 1 */ +#define LL_PWR_CSR_EWUP2 PWR_CSR_EWUP2 /*!< Enable WKUP pin 2 */ +#if defined(PWR_CSR_EWUP3) +#define LL_PWR_CSR_EWUP3 PWR_CSR_EWUP3 /*!< Enable WKUP pin 3 */ +#endif /* PWR_CSR_EWUP3 */ +#if defined(PWR_CSR_EWUP4) +#define LL_PWR_CSR_EWUP4 PWR_CSR_EWUP4 /*!< Enable WKUP pin 4 */ +#endif /* PWR_CSR_EWUP4 */ +#if defined(PWR_CSR_EWUP5) +#define LL_PWR_CSR_EWUP5 PWR_CSR_EWUP5 /*!< Enable WKUP pin 5 */ +#endif /* PWR_CSR_EWUP5 */ +#if defined(PWR_CSR_EWUP6) +#define LL_PWR_CSR_EWUP6 PWR_CSR_EWUP6 /*!< Enable WKUP pin 6 */ +#endif /* PWR_CSR_EWUP6 */ +#if defined(PWR_CSR_EWUP7) +#define LL_PWR_CSR_EWUP7 PWR_CSR_EWUP7 /*!< Enable WKUP pin 7 */ +#endif /* PWR_CSR_EWUP7 */ +#if defined(PWR_CSR_EWUP8) +#define LL_PWR_CSR_EWUP8 PWR_CSR_EWUP8 /*!< Enable WKUP pin 8 */ +#endif /* PWR_CSR_EWUP8 */ +/** + * @} + */ + + +/** @defgroup PWR_LL_EC_MODE_PWR Mode Power + * @{ + */ +#define LL_PWR_MODE_STOP_MAINREGU 0x00000000U /*!< Enter Stop mode when the CPU enters deepsleep */ +#define LL_PWR_MODE_STOP_LPREGU (PWR_CR_LPDS) /*!< Enter Stop mode (with low power Regulator ON) when the CPU enters deepsleep */ +#define LL_PWR_MODE_STANDBY (PWR_CR_PDDS) /*!< Enter Standby mode when the CPU enters deepsleep */ +/** + * @} + */ + +#if defined(PWR_CR_LPDS) +/** @defgroup PWR_LL_EC_REGU_MODE_DS_MODE Regulator Mode In Deep Sleep Mode + * @{ + */ +#define LL_PWR_REGU_DSMODE_MAIN 0x00000000U /*!< Voltage Regulator in main mode during deepsleep mode */ +#define LL_PWR_REGU_DSMODE_LOW_POWER (PWR_CR_LPDS) /*!< Voltage Regulator in low-power mode during deepsleep mode */ +/** + * @} + */ +#endif /* PWR_CR_LPDS */ + +#if defined(PWR_PVD_SUPPORT) +/** @defgroup PWR_LL_EC_PVDLEVEL Power Voltage Detector Level + * @{ + */ +#define LL_PWR_PVDLEVEL_0 (PWR_CR_PLS_LEV0) /*!< Voltage threshold 0 */ +#define LL_PWR_PVDLEVEL_1 (PWR_CR_PLS_LEV1) /*!< Voltage threshold 1 */ +#define LL_PWR_PVDLEVEL_2 (PWR_CR_PLS_LEV2) /*!< Voltage threshold 2 */ +#define LL_PWR_PVDLEVEL_3 (PWR_CR_PLS_LEV3) /*!< Voltage threshold 3 */ +#define LL_PWR_PVDLEVEL_4 (PWR_CR_PLS_LEV4) /*!< Voltage threshold 4 */ +#define LL_PWR_PVDLEVEL_5 (PWR_CR_PLS_LEV5) /*!< Voltage threshold 5 */ +#define LL_PWR_PVDLEVEL_6 (PWR_CR_PLS_LEV6) /*!< Voltage threshold 6 */ +#define LL_PWR_PVDLEVEL_7 (PWR_CR_PLS_LEV7) /*!< Voltage threshold 7 */ +/** + * @} + */ +#endif /* PWR_PVD_SUPPORT */ +/** @defgroup PWR_LL_EC_WAKEUP_PIN Wakeup Pins + * @{ + */ +#define LL_PWR_WAKEUP_PIN1 (PWR_CSR_EWUP1) /*!< WKUP pin 1 : PA0 */ +#define LL_PWR_WAKEUP_PIN2 (PWR_CSR_EWUP2) /*!< WKUP pin 2 : PC13 */ +#if defined(PWR_CSR_EWUP3) +#define LL_PWR_WAKEUP_PIN3 (PWR_CSR_EWUP3) /*!< WKUP pin 3 : PE6 or PA2 according to device */ +#endif /* PWR_CSR_EWUP3 */ +#if defined(PWR_CSR_EWUP4) +#define LL_PWR_WAKEUP_PIN4 (PWR_CSR_EWUP4) /*!< WKUP pin 4 : LLG TBD */ +#endif /* PWR_CSR_EWUP4 */ +#if defined(PWR_CSR_EWUP5) +#define LL_PWR_WAKEUP_PIN5 (PWR_CSR_EWUP5) /*!< WKUP pin 5 : LLG TBD */ +#endif /* PWR_CSR_EWUP5 */ +#if defined(PWR_CSR_EWUP6) +#define LL_PWR_WAKEUP_PIN6 (PWR_CSR_EWUP6) /*!< WKUP pin 6 : LLG TBD */ +#endif /* PWR_CSR_EWUP6 */ +#if defined(PWR_CSR_EWUP7) +#define LL_PWR_WAKEUP_PIN7 (PWR_CSR_EWUP7) /*!< WKUP pin 7 : LLG TBD */ +#endif /* PWR_CSR_EWUP7 */ +#if defined(PWR_CSR_EWUP8) +#define LL_PWR_WAKEUP_PIN8 (PWR_CSR_EWUP8) /*!< WKUP pin 8 : LLG TBD */ +#endif /* PWR_CSR_EWUP8 */ +/** + * @} + */ + +/** + * @} + */ + + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup PWR_LL_Exported_Macros PWR Exported Macros + * @{ + */ + +/** @defgroup PWR_LL_EM_WRITE_READ Common write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in PWR register + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_PWR_WriteReg(__REG__, __VALUE__) WRITE_REG(PWR->__REG__, (__VALUE__)) + +/** + * @brief Read a value in PWR register + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_PWR_ReadReg(__REG__) READ_REG(PWR->__REG__) +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup PWR_LL_Exported_Functions PWR Exported Functions + * @{ + */ + +/** @defgroup PWR_LL_EF_Configuration Configuration + * @{ + */ + +/** + * @brief Enable access to the backup domain + * @rmtoll CR DBP LL_PWR_EnableBkUpAccess + * @retval None + */ +__STATIC_INLINE void LL_PWR_EnableBkUpAccess(void) +{ + SET_BIT(PWR->CR, PWR_CR_DBP); +} + +/** + * @brief Disable access to the backup domain + * @rmtoll CR DBP LL_PWR_DisableBkUpAccess + * @retval None + */ +__STATIC_INLINE void LL_PWR_DisableBkUpAccess(void) +{ + CLEAR_BIT(PWR->CR, PWR_CR_DBP); +} + +/** + * @brief Check if the backup domain is enabled + * @rmtoll CR DBP LL_PWR_IsEnabledBkUpAccess + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_PWR_IsEnabledBkUpAccess(void) +{ + return (READ_BIT(PWR->CR, PWR_CR_DBP) == (PWR_CR_DBP)); +} + +#if defined(PWR_CR_LPDS) +/** + * @brief Set voltage Regulator mode during deep sleep mode + * @rmtoll CR LPDS LL_PWR_SetRegulModeDS + * @param RegulMode This parameter can be one of the following values: + * @arg @ref LL_PWR_REGU_DSMODE_MAIN + * @arg @ref LL_PWR_REGU_DSMODE_LOW_POWER + * @retval None + */ +__STATIC_INLINE void LL_PWR_SetRegulModeDS(uint32_t RegulMode) +{ + MODIFY_REG(PWR->CR, PWR_CR_LPDS, RegulMode); +} + +/** + * @brief Get voltage Regulator mode during deep sleep mode + * @rmtoll CR LPDS LL_PWR_GetRegulModeDS + * @retval Returned value can be one of the following values: + * @arg @ref LL_PWR_REGU_DSMODE_MAIN + * @arg @ref LL_PWR_REGU_DSMODE_LOW_POWER + */ +__STATIC_INLINE uint32_t LL_PWR_GetRegulModeDS(void) +{ + return (uint32_t)(READ_BIT(PWR->CR, PWR_CR_LPDS)); +} +#endif /* PWR_CR_LPDS */ + +/** + * @brief Set Power Down mode when CPU enters deepsleep + * @rmtoll CR PDDS LL_PWR_SetPowerMode\n + * @rmtoll CR LPDS LL_PWR_SetPowerMode + * @param PDMode This parameter can be one of the following values: + * @arg @ref LL_PWR_MODE_STOP_MAINREGU + * @arg @ref LL_PWR_MODE_STOP_LPREGU + * @arg @ref LL_PWR_MODE_STANDBY + * @retval None + */ +__STATIC_INLINE void LL_PWR_SetPowerMode(uint32_t PDMode) +{ + MODIFY_REG(PWR->CR, (PWR_CR_PDDS| PWR_CR_LPDS), PDMode); +} + +/** + * @brief Get Power Down mode when CPU enters deepsleep + * @rmtoll CR PDDS LL_PWR_GetPowerMode\n + * @rmtoll CR LPDS LL_PWR_GetPowerMode + * @retval Returned value can be one of the following values: + * @arg @ref LL_PWR_MODE_STOP_MAINREGU + * @arg @ref LL_PWR_MODE_STOP_LPREGU + * @arg @ref LL_PWR_MODE_STANDBY + */ +__STATIC_INLINE uint32_t LL_PWR_GetPowerMode(void) +{ + return (uint32_t)(READ_BIT(PWR->CR, (PWR_CR_PDDS| PWR_CR_LPDS))); +} + +#if defined(PWR_PVD_SUPPORT) +/** + * @brief Configure the voltage threshold detected by the Power Voltage Detector + * @rmtoll CR PLS LL_PWR_SetPVDLevel + * @param PVDLevel This parameter can be one of the following values: + * @arg @ref LL_PWR_PVDLEVEL_0 + * @arg @ref LL_PWR_PVDLEVEL_1 + * @arg @ref LL_PWR_PVDLEVEL_2 + * @arg @ref LL_PWR_PVDLEVEL_3 + * @arg @ref LL_PWR_PVDLEVEL_4 + * @arg @ref LL_PWR_PVDLEVEL_5 + * @arg @ref LL_PWR_PVDLEVEL_6 + * @arg @ref LL_PWR_PVDLEVEL_7 + * @retval None + */ +__STATIC_INLINE void LL_PWR_SetPVDLevel(uint32_t PVDLevel) +{ + MODIFY_REG(PWR->CR, PWR_CR_PLS, PVDLevel); +} + +/** + * @brief Get the voltage threshold detection + * @rmtoll CR PLS LL_PWR_GetPVDLevel + * @retval Returned value can be one of the following values: + * @arg @ref LL_PWR_PVDLEVEL_0 + * @arg @ref LL_PWR_PVDLEVEL_1 + * @arg @ref LL_PWR_PVDLEVEL_2 + * @arg @ref LL_PWR_PVDLEVEL_3 + * @arg @ref LL_PWR_PVDLEVEL_4 + * @arg @ref LL_PWR_PVDLEVEL_5 + * @arg @ref LL_PWR_PVDLEVEL_6 + * @arg @ref LL_PWR_PVDLEVEL_7 + */ +__STATIC_INLINE uint32_t LL_PWR_GetPVDLevel(void) +{ + return (uint32_t)(READ_BIT(PWR->CR, PWR_CR_PLS)); +} + +/** + * @brief Enable Power Voltage Detector + * @rmtoll CR PVDE LL_PWR_EnablePVD + * @retval None + */ +__STATIC_INLINE void LL_PWR_EnablePVD(void) +{ + SET_BIT(PWR->CR, PWR_CR_PVDE); +} + +/** + * @brief Disable Power Voltage Detector + * @rmtoll CR PVDE LL_PWR_DisablePVD + * @retval None + */ +__STATIC_INLINE void LL_PWR_DisablePVD(void) +{ + CLEAR_BIT(PWR->CR, PWR_CR_PVDE); +} + +/** + * @brief Check if Power Voltage Detector is enabled + * @rmtoll CR PVDE LL_PWR_IsEnabledPVD + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_PWR_IsEnabledPVD(void) +{ + return (READ_BIT(PWR->CR, PWR_CR_PVDE) == (PWR_CR_PVDE)); +} +#endif /* PWR_PVD_SUPPORT */ + +/** + * @brief Enable the WakeUp PINx functionality + * @rmtoll CSR EWUP1 LL_PWR_EnableWakeUpPin\n + * @rmtoll CSR EWUP2 LL_PWR_EnableWakeUpPin\n + * @rmtoll CSR EWUP3 LL_PWR_EnableWakeUpPin\n + * @rmtoll CSR EWUP4 LL_PWR_EnableWakeUpPin\n + * @rmtoll CSR EWUP5 LL_PWR_EnableWakeUpPin\n + * @rmtoll CSR EWUP6 LL_PWR_EnableWakeUpPin\n + * @rmtoll CSR EWUP7 LL_PWR_EnableWakeUpPin\n + * @rmtoll CSR EWUP8 LL_PWR_EnableWakeUpPin + * @param WakeUpPin This parameter can be one of the following values: + * @arg @ref LL_PWR_WAKEUP_PIN1 + * @arg @ref LL_PWR_WAKEUP_PIN2 + * @arg @ref LL_PWR_WAKEUP_PIN3 (*) + * @arg @ref LL_PWR_WAKEUP_PIN4 (*) + * @arg @ref LL_PWR_WAKEUP_PIN5 (*) + * @arg @ref LL_PWR_WAKEUP_PIN6 (*) + * @arg @ref LL_PWR_WAKEUP_PIN7 (*) + * @arg @ref LL_PWR_WAKEUP_PIN8 (*) + * + * (*) not available on all devices + * @retval None + */ +__STATIC_INLINE void LL_PWR_EnableWakeUpPin(uint32_t WakeUpPin) +{ + SET_BIT(PWR->CSR, WakeUpPin); +} + +/** + * @brief Disable the WakeUp PINx functionality + * @rmtoll CSR EWUP1 LL_PWR_DisableWakeUpPin\n + * @rmtoll CSR EWUP2 LL_PWR_DisableWakeUpPin\n + * @rmtoll CSR EWUP3 LL_PWR_DisableWakeUpPin\n + * @rmtoll CSR EWUP4 LL_PWR_DisableWakeUpPin\n + * @rmtoll CSR EWUP5 LL_PWR_DisableWakeUpPin\n + * @rmtoll CSR EWUP6 LL_PWR_DisableWakeUpPin\n + * @rmtoll CSR EWUP7 LL_PWR_DisableWakeUpPin\n + * @rmtoll CSR EWUP8 LL_PWR_DisableWakeUpPin + * @param WakeUpPin This parameter can be one of the following values: + * @arg @ref LL_PWR_WAKEUP_PIN1 + * @arg @ref LL_PWR_WAKEUP_PIN2 + * @arg @ref LL_PWR_WAKEUP_PIN3 (*) + * @arg @ref LL_PWR_WAKEUP_PIN4 (*) + * @arg @ref LL_PWR_WAKEUP_PIN5 (*) + * @arg @ref LL_PWR_WAKEUP_PIN6 (*) + * @arg @ref LL_PWR_WAKEUP_PIN7 (*) + * @arg @ref LL_PWR_WAKEUP_PIN8 (*) + * + * (*) not available on all devices + * @retval None + */ +__STATIC_INLINE void LL_PWR_DisableWakeUpPin(uint32_t WakeUpPin) +{ + CLEAR_BIT(PWR->CSR, WakeUpPin); +} + +/** + * @brief Check if the WakeUp PINx functionality is enabled + * @rmtoll CSR EWUP1 LL_PWR_IsEnabledWakeUpPin\n + * @rmtoll CSR EWUP2 LL_PWR_IsEnabledWakeUpPin\n + * @rmtoll CSR EWUP3 LL_PWR_IsEnabledWakeUpPin\n + * @rmtoll CSR EWUP4 LL_PWR_IsEnabledWakeUpPin\n + * @rmtoll CSR EWUP5 LL_PWR_IsEnabledWakeUpPin\n + * @rmtoll CSR EWUP6 LL_PWR_IsEnabledWakeUpPin\n + * @rmtoll CSR EWUP7 LL_PWR_IsEnabledWakeUpPin\n + * @rmtoll CSR EWUP8 LL_PWR_IsEnabledWakeUpPin + * @param WakeUpPin This parameter can be one of the following values: + * @arg @ref LL_PWR_WAKEUP_PIN1 + * @arg @ref LL_PWR_WAKEUP_PIN2 + * @arg @ref LL_PWR_WAKEUP_PIN3 (*) + * @arg @ref LL_PWR_WAKEUP_PIN4 (*) + * @arg @ref LL_PWR_WAKEUP_PIN5 (*) + * @arg @ref LL_PWR_WAKEUP_PIN6 (*) + * @arg @ref LL_PWR_WAKEUP_PIN7 (*) + * @arg @ref LL_PWR_WAKEUP_PIN8 (*) + * + * (*) not available on all devices + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_PWR_IsEnabledWakeUpPin(uint32_t WakeUpPin) +{ + return (READ_BIT(PWR->CSR, WakeUpPin) == (WakeUpPin)); +} + + +/** + * @} + */ + +/** @defgroup PWR_LL_EF_FLAG_Management FLAG_Management + * @{ + */ + +/** + * @brief Get Wake-up Flag + * @rmtoll CSR WUF LL_PWR_IsActiveFlag_WU + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_PWR_IsActiveFlag_WU(void) +{ + return (READ_BIT(PWR->CSR, PWR_CSR_WUF) == (PWR_CSR_WUF)); +} + +/** + * @brief Get Standby Flag + * @rmtoll CSR SBF LL_PWR_IsActiveFlag_SB + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_PWR_IsActiveFlag_SB(void) +{ + return (READ_BIT(PWR->CSR, PWR_CSR_SBF) == (PWR_CSR_SBF)); +} + +#if defined(PWR_PVD_SUPPORT) +/** + * @brief Indicate whether VDD voltage is below the selected PVD threshold + * @rmtoll CSR PVDO LL_PWR_IsActiveFlag_PVDO + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_PWR_IsActiveFlag_PVDO(void) +{ + return (READ_BIT(PWR->CSR, PWR_CSR_PVDO) == (PWR_CSR_PVDO)); +} +#endif /* PWR_PVD_SUPPORT */ + +#if defined(PWR_CSR_VREFINTRDYF) +/** + * @brief Get Internal Reference VrefInt Flag + * @rmtoll CSR VREFINTRDYF LL_PWR_IsActiveFlag_VREFINTRDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_PWR_IsActiveFlag_VREFINTRDY(void) +{ + return (READ_BIT(PWR->CSR, PWR_CSR_VREFINTRDYF) == (PWR_CSR_VREFINTRDYF)); +} +#endif /* PWR_CSR_VREFINTRDYF */ +/** + * @brief Clear Standby Flag + * @rmtoll CR CSBF LL_PWR_ClearFlag_SB + * @retval None + */ +__STATIC_INLINE void LL_PWR_ClearFlag_SB(void) +{ + SET_BIT(PWR->CR, PWR_CR_CSBF); +} + +/** + * @brief Clear Wake-up Flags + * @rmtoll CR CWUF LL_PWR_ClearFlag_WU + * @retval None + */ +__STATIC_INLINE void LL_PWR_ClearFlag_WU(void) +{ + SET_BIT(PWR->CR, PWR_CR_CWUF); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup PWR_LL_EF_Init De-initialization function + * @{ + */ +ErrorStatus LL_PWR_DeInit(void); +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(PWR) */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_PWR_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rcc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rcc.h new file mode 100644 index 0000000..626b273 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rcc.h @@ -0,0 +1,2261 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_rcc.h + * @author MCD Application Team + * @brief Header file of RCC LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_RCC_H +#define __STM32F0xx_LL_RCC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(RCC) + +/** @defgroup RCC_LL RCC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup RCC_LL_Private_Constants RCC Private Constants + * @{ + */ +/* Defines used for the bit position in the register and perform offsets*/ +#define RCC_POSITION_HPRE (uint32_t)4U /*!< field position in register RCC_CFGR */ +#define RCC_POSITION_PPRE1 (uint32_t)8U /*!< field position in register RCC_CFGR */ +#define RCC_POSITION_PLLMUL (uint32_t)18U /*!< field position in register RCC_CFGR */ +#define RCC_POSITION_HSICAL (uint32_t)8U /*!< field position in register RCC_CR */ +#define RCC_POSITION_HSITRIM (uint32_t)3U /*!< field position in register RCC_CR */ +#define RCC_POSITION_HSI14TRIM (uint32_t)3U /*!< field position in register RCC_CR2 */ +#define RCC_POSITION_HSI14CAL (uint32_t)8U /*!< field position in register RCC_CR2 */ +#if defined(RCC_HSI48_SUPPORT) +#define RCC_POSITION_HSI48CAL (uint32_t)24U /*!< field position in register RCC_CR2 */ +#endif /* RCC_HSI48_SUPPORT */ +#define RCC_POSITION_USART1SW (uint32_t)0U /*!< field position in register RCC_CFGR3 */ +#define RCC_POSITION_USART2SW (uint32_t)16U /*!< field position in register RCC_CFGR3 */ +#define RCC_POSITION_USART3SW (uint32_t)18U /*!< field position in register RCC_CFGR3 */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RCC_LL_Private_Macros RCC Private Macros + * @{ + */ +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RCC_LL_Exported_Types RCC Exported Types + * @{ + */ + +/** @defgroup LL_ES_CLOCK_FREQ Clocks Frequency Structure + * @{ + */ + +/** + * @brief RCC Clocks Frequency Structure + */ +typedef struct +{ + uint32_t SYSCLK_Frequency; /*!< SYSCLK clock frequency */ + uint32_t HCLK_Frequency; /*!< HCLK clock frequency */ + uint32_t PCLK1_Frequency; /*!< PCLK1 clock frequency */ +} LL_RCC_ClocksTypeDef; + +/** + * @} + */ + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup RCC_LL_Exported_Constants RCC Exported Constants + * @{ + */ + +/** @defgroup RCC_LL_EC_OSC_VALUES Oscillator Values adaptation + * @brief Defines used to adapt values of different oscillators + * @note These values could be modified in the user environment according to + * HW set-up. + * @{ + */ +#if !defined (HSE_VALUE) +#define HSE_VALUE 8000000U /*!< Value of the HSE oscillator in Hz */ +#endif /* HSE_VALUE */ + +#if !defined (HSI_VALUE) +#define HSI_VALUE 8000000U /*!< Value of the HSI oscillator in Hz */ +#endif /* HSI_VALUE */ + +#if !defined (LSE_VALUE) +#define LSE_VALUE 32768U /*!< Value of the LSE oscillator in Hz */ +#endif /* LSE_VALUE */ + +#if !defined (LSI_VALUE) +#define LSI_VALUE 32000U /*!< Value of the LSI oscillator in Hz */ +#endif /* LSI_VALUE */ +#if defined(RCC_HSI48_SUPPORT) + +#if !defined (HSI48_VALUE) +#define HSI48_VALUE 48000000U /*!< Value of the HSI48 oscillator in Hz */ +#endif /* HSI48_VALUE */ +#endif /* RCC_HSI48_SUPPORT */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_CLEAR_FLAG Clear Flags Defines + * @brief Flags defines which can be used with LL_RCC_WriteReg function + * @{ + */ +#define LL_RCC_CIR_LSIRDYC RCC_CIR_LSIRDYC /*!< LSI Ready Interrupt Clear */ +#define LL_RCC_CIR_LSERDYC RCC_CIR_LSERDYC /*!< LSE Ready Interrupt Clear */ +#define LL_RCC_CIR_HSIRDYC RCC_CIR_HSIRDYC /*!< HSI Ready Interrupt Clear */ +#define LL_RCC_CIR_HSERDYC RCC_CIR_HSERDYC /*!< HSE Ready Interrupt Clear */ +#define LL_RCC_CIR_PLLRDYC RCC_CIR_PLLRDYC /*!< PLL Ready Interrupt Clear */ +#define LL_RCC_CIR_HSI14RDYC RCC_CIR_HSI14RDYC /*!< HSI14 Ready Interrupt Clear */ +#if defined(RCC_HSI48_SUPPORT) +#define LL_RCC_CIR_HSI48RDYC RCC_CIR_HSI48RDYC /*!< HSI48 Ready Interrupt Clear */ +#endif /* RCC_HSI48_SUPPORT */ +#define LL_RCC_CIR_CSSC RCC_CIR_CSSC /*!< Clock Security System Interrupt Clear */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_RCC_ReadReg function + * @{ + */ +#define LL_RCC_CIR_LSIRDYF RCC_CIR_LSIRDYF /*!< LSI Ready Interrupt flag */ +#define LL_RCC_CIR_LSERDYF RCC_CIR_LSERDYF /*!< LSE Ready Interrupt flag */ +#define LL_RCC_CIR_HSIRDYF RCC_CIR_HSIRDYF /*!< HSI Ready Interrupt flag */ +#define LL_RCC_CIR_HSERDYF RCC_CIR_HSERDYF /*!< HSE Ready Interrupt flag */ +#define LL_RCC_CIR_PLLRDYF RCC_CIR_PLLRDYF /*!< PLL Ready Interrupt flag */ +#define LL_RCC_CIR_HSI14RDYF RCC_CIR_HSI14RDYF /*!< HSI14 Ready Interrupt flag */ +#if defined(RCC_HSI48_SUPPORT) +#define LL_RCC_CIR_HSI48RDYF RCC_CIR_HSI48RDYF /*!< HSI48 Ready Interrupt flag */ +#endif /* RCC_HSI48_SUPPORT */ +#define LL_RCC_CIR_CSSF RCC_CIR_CSSF /*!< Clock Security System Interrupt flag */ +#define LL_RCC_CSR_OBLRSTF RCC_CSR_OBLRSTF /*!< OBL reset flag */ +#define LL_RCC_CSR_PINRSTF RCC_CSR_PINRSTF /*!< PIN reset flag */ +#define LL_RCC_CSR_PORRSTF RCC_CSR_PORRSTF /*!< POR/PDR reset flag */ +#define LL_RCC_CSR_SFTRSTF RCC_CSR_SFTRSTF /*!< Software Reset flag */ +#define LL_RCC_CSR_IWDGRSTF RCC_CSR_IWDGRSTF /*!< Independent Watchdog reset flag */ +#define LL_RCC_CSR_WWDGRSTF RCC_CSR_WWDGRSTF /*!< Window watchdog reset flag */ +#define LL_RCC_CSR_LPWRRSTF RCC_CSR_LPWRRSTF /*!< Low-Power reset flag */ +#if defined(RCC_CSR_V18PWRRSTF) +#define LL_RCC_CSR_V18PWRRSTF RCC_CSR_V18PWRRSTF /*!< Reset flag of the 1.8 V domain. */ +#endif /* RCC_CSR_V18PWRRSTF */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_RCC_ReadReg and LL_RCC_WriteReg functions + * @{ + */ +#define LL_RCC_CIR_LSIRDYIE RCC_CIR_LSIRDYIE /*!< LSI Ready Interrupt Enable */ +#define LL_RCC_CIR_LSERDYIE RCC_CIR_LSERDYIE /*!< LSE Ready Interrupt Enable */ +#define LL_RCC_CIR_HSIRDYIE RCC_CIR_HSIRDYIE /*!< HSI Ready Interrupt Enable */ +#define LL_RCC_CIR_HSERDYIE RCC_CIR_HSERDYIE /*!< HSE Ready Interrupt Enable */ +#define LL_RCC_CIR_PLLRDYIE RCC_CIR_PLLRDYIE /*!< PLL Ready Interrupt Enable */ +#define LL_RCC_CIR_HSI14RDYIE RCC_CIR_HSI14RDYIE /*!< HSI14 Ready Interrupt Enable */ +#if defined(RCC_HSI48_SUPPORT) +#define LL_RCC_CIR_HSI48RDYIE RCC_CIR_HSI48RDYIE /*!< HSI48 Ready Interrupt Enable */ +#endif /* RCC_HSI48_SUPPORT */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_LSEDRIVE LSE oscillator drive capability + * @{ + */ +#define LL_RCC_LSEDRIVE_LOW ((uint32_t)0x00000000U) /*!< Xtal mode lower driving capability */ +#define LL_RCC_LSEDRIVE_MEDIUMLOW RCC_BDCR_LSEDRV_1 /*!< Xtal mode medium low driving capability */ +#define LL_RCC_LSEDRIVE_MEDIUMHIGH RCC_BDCR_LSEDRV_0 /*!< Xtal mode medium high driving capability */ +#define LL_RCC_LSEDRIVE_HIGH RCC_BDCR_LSEDRV /*!< Xtal mode higher driving capability */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_SYS_CLKSOURCE System clock switch + * @{ + */ +#define LL_RCC_SYS_CLKSOURCE_HSI RCC_CFGR_SW_HSI /*!< HSI selection as system clock */ +#define LL_RCC_SYS_CLKSOURCE_HSE RCC_CFGR_SW_HSE /*!< HSE selection as system clock */ +#define LL_RCC_SYS_CLKSOURCE_PLL RCC_CFGR_SW_PLL /*!< PLL selection as system clock */ +#if defined(RCC_CFGR_SW_HSI48) +#define LL_RCC_SYS_CLKSOURCE_HSI48 RCC_CFGR_SW_HSI48 /*!< HSI48 selection as system clock */ +#endif /* RCC_CFGR_SW_HSI48 */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_SYS_CLKSOURCE_STATUS System clock switch status + * @{ + */ +#define LL_RCC_SYS_CLKSOURCE_STATUS_HSI RCC_CFGR_SWS_HSI /*!< HSI used as system clock */ +#define LL_RCC_SYS_CLKSOURCE_STATUS_HSE RCC_CFGR_SWS_HSE /*!< HSE used as system clock */ +#define LL_RCC_SYS_CLKSOURCE_STATUS_PLL RCC_CFGR_SWS_PLL /*!< PLL used as system clock */ +#if defined(RCC_CFGR_SWS_HSI48) +#define LL_RCC_SYS_CLKSOURCE_STATUS_HSI48 RCC_CFGR_SWS_HSI48 /*!< HSI48 used as system clock */ +#endif /* RCC_CFGR_SWS_HSI48 */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_SYSCLK_DIV AHB prescaler + * @{ + */ +#define LL_RCC_SYSCLK_DIV_1 RCC_CFGR_HPRE_DIV1 /*!< SYSCLK not divided */ +#define LL_RCC_SYSCLK_DIV_2 RCC_CFGR_HPRE_DIV2 /*!< SYSCLK divided by 2 */ +#define LL_RCC_SYSCLK_DIV_4 RCC_CFGR_HPRE_DIV4 /*!< SYSCLK divided by 4 */ +#define LL_RCC_SYSCLK_DIV_8 RCC_CFGR_HPRE_DIV8 /*!< SYSCLK divided by 8 */ +#define LL_RCC_SYSCLK_DIV_16 RCC_CFGR_HPRE_DIV16 /*!< SYSCLK divided by 16 */ +#define LL_RCC_SYSCLK_DIV_64 RCC_CFGR_HPRE_DIV64 /*!< SYSCLK divided by 64 */ +#define LL_RCC_SYSCLK_DIV_128 RCC_CFGR_HPRE_DIV128 /*!< SYSCLK divided by 128 */ +#define LL_RCC_SYSCLK_DIV_256 RCC_CFGR_HPRE_DIV256 /*!< SYSCLK divided by 256 */ +#define LL_RCC_SYSCLK_DIV_512 RCC_CFGR_HPRE_DIV512 /*!< SYSCLK divided by 512 */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_APB1_DIV APB low-speed prescaler (APB1) + * @{ + */ +#define LL_RCC_APB1_DIV_1 RCC_CFGR_PPRE_DIV1 /*!< HCLK not divided */ +#define LL_RCC_APB1_DIV_2 RCC_CFGR_PPRE_DIV2 /*!< HCLK divided by 2 */ +#define LL_RCC_APB1_DIV_4 RCC_CFGR_PPRE_DIV4 /*!< HCLK divided by 4 */ +#define LL_RCC_APB1_DIV_8 RCC_CFGR_PPRE_DIV8 /*!< HCLK divided by 8 */ +#define LL_RCC_APB1_DIV_16 RCC_CFGR_PPRE_DIV16 /*!< HCLK divided by 16 */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_MCO1SOURCE MCO1 SOURCE selection + * @{ + */ +#define LL_RCC_MCO1SOURCE_NOCLOCK RCC_CFGR_MCOSEL_NOCLOCK /*!< MCO output disabled, no clock on MCO */ +#define LL_RCC_MCO1SOURCE_HSI14 RCC_CFGR_MCOSEL_HSI14 /*!< HSI14 oscillator clock selected */ +#define LL_RCC_MCO1SOURCE_SYSCLK RCC_CFGR_MCOSEL_SYSCLK /*!< SYSCLK selection as MCO source */ +#define LL_RCC_MCO1SOURCE_HSI RCC_CFGR_MCOSEL_HSI /*!< HSI selection as MCO source */ +#define LL_RCC_MCO1SOURCE_HSE RCC_CFGR_MCOSEL_HSE /*!< HSE selection as MCO source */ +#define LL_RCC_MCO1SOURCE_LSI RCC_CFGR_MCOSEL_LSI /*!< LSI selection as MCO source */ +#define LL_RCC_MCO1SOURCE_LSE RCC_CFGR_MCOSEL_LSE /*!< LSE selection as MCO source */ +#if defined(RCC_CFGR_MCOSEL_HSI48) +#define LL_RCC_MCO1SOURCE_HSI48 RCC_CFGR_MCOSEL_HSI48 /*!< HSI48 selection as MCO source */ +#endif /* RCC_CFGR_MCOSEL_HSI48 */ +#define LL_RCC_MCO1SOURCE_PLLCLK_DIV_2 RCC_CFGR_MCOSEL_PLL_DIV2 /*!< PLL clock divided by 2*/ +#if defined(RCC_CFGR_PLLNODIV) +#define LL_RCC_MCO1SOURCE_PLLCLK (RCC_CFGR_MCOSEL_PLL_DIV2 | RCC_CFGR_PLLNODIV) /*!< PLL clock selected*/ +#endif /* RCC_CFGR_PLLNODIV */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_MCO1_DIV MCO1 prescaler + * @{ + */ +#define LL_RCC_MCO1_DIV_1 ((uint32_t)0x00000000U)/*!< MCO Clock divided by 1 */ +#if defined(RCC_CFGR_MCOPRE) +#define LL_RCC_MCO1_DIV_2 RCC_CFGR_MCOPRE_DIV2 /*!< MCO Clock divided by 2 */ +#define LL_RCC_MCO1_DIV_4 RCC_CFGR_MCOPRE_DIV4 /*!< MCO Clock divided by 4 */ +#define LL_RCC_MCO1_DIV_8 RCC_CFGR_MCOPRE_DIV8 /*!< MCO Clock divided by 8 */ +#define LL_RCC_MCO1_DIV_16 RCC_CFGR_MCOPRE_DIV16 /*!< MCO Clock divided by 16 */ +#define LL_RCC_MCO1_DIV_32 RCC_CFGR_MCOPRE_DIV32 /*!< MCO Clock divided by 32 */ +#define LL_RCC_MCO1_DIV_64 RCC_CFGR_MCOPRE_DIV64 /*!< MCO Clock divided by 64 */ +#define LL_RCC_MCO1_DIV_128 RCC_CFGR_MCOPRE_DIV128 /*!< MCO Clock divided by 128 */ +#endif /* RCC_CFGR_MCOPRE */ +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RCC_LL_EC_PERIPH_FREQUENCY Peripheral clock frequency + * @{ + */ +#define LL_RCC_PERIPH_FREQUENCY_NO 0x00000000U /*!< No clock enabled for the peripheral */ +#define LL_RCC_PERIPH_FREQUENCY_NA 0xFFFFFFFFU /*!< Frequency cannot be provided as external clock */ +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** @defgroup RCC_LL_EC_USART1_CLKSOURCE Peripheral USART clock source selection + * @{ + */ +#define LL_RCC_USART1_CLKSOURCE_PCLK1 (uint32_t)((RCC_POSITION_USART1SW << 24) | RCC_CFGR3_USART1SW_PCLK) /*!< PCLK1 clock used as USART1 clock source */ +#define LL_RCC_USART1_CLKSOURCE_SYSCLK (uint32_t)((RCC_POSITION_USART1SW << 24) | RCC_CFGR3_USART1SW_SYSCLK) /*!< System clock selected as USART1 clock source */ +#define LL_RCC_USART1_CLKSOURCE_LSE (uint32_t)((RCC_POSITION_USART1SW << 24) | RCC_CFGR3_USART1SW_LSE) /*!< LSE oscillator clock used as USART1 clock source */ +#define LL_RCC_USART1_CLKSOURCE_HSI (uint32_t)((RCC_POSITION_USART1SW << 24) | RCC_CFGR3_USART1SW_HSI) /*!< HSI oscillator clock used as USART1 clock source */ +#if defined(RCC_CFGR3_USART2SW) +#define LL_RCC_USART2_CLKSOURCE_PCLK1 (uint32_t)((RCC_POSITION_USART2SW << 24) | RCC_CFGR3_USART2SW_PCLK) /*!< PCLK1 clock used as USART2 clock source */ +#define LL_RCC_USART2_CLKSOURCE_SYSCLK (uint32_t)((RCC_POSITION_USART2SW << 24) | RCC_CFGR3_USART2SW_SYSCLK) /*!< System clock selected as USART2 clock source */ +#define LL_RCC_USART2_CLKSOURCE_LSE (uint32_t)((RCC_POSITION_USART2SW << 24) | RCC_CFGR3_USART2SW_LSE) /*!< LSE oscillator clock used as USART2 clock source */ +#define LL_RCC_USART2_CLKSOURCE_HSI (uint32_t)((RCC_POSITION_USART2SW << 24) | RCC_CFGR3_USART2SW_HSI) /*!< HSI oscillator clock used as USART2 clock source */ +#endif /* RCC_CFGR3_USART2SW */ +#if defined(RCC_CFGR3_USART3SW) +#define LL_RCC_USART3_CLKSOURCE_PCLK1 (uint32_t)((RCC_POSITION_USART3SW << 24) | RCC_CFGR3_USART3SW_PCLK) /*!< PCLK1 clock used as USART3 clock source */ +#define LL_RCC_USART3_CLKSOURCE_SYSCLK (uint32_t)((RCC_POSITION_USART3SW << 24) | RCC_CFGR3_USART3SW_SYSCLK) /*!< System clock selected as USART3 clock source */ +#define LL_RCC_USART3_CLKSOURCE_LSE (uint32_t)((RCC_POSITION_USART3SW << 24) | RCC_CFGR3_USART3SW_LSE) /*!< LSE oscillator clock used as USART3 clock source */ +#define LL_RCC_USART3_CLKSOURCE_HSI (uint32_t)((RCC_POSITION_USART3SW << 24) | RCC_CFGR3_USART3SW_HSI) /*!< HSI oscillator clock used as USART3 clock source */ +#endif /* RCC_CFGR3_USART3SW */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_I2C1_CLKSOURCE Peripheral I2C clock source selection + * @{ + */ +#define LL_RCC_I2C1_CLKSOURCE_HSI RCC_CFGR3_I2C1SW_HSI /*!< HSI oscillator clock used as I2C1 clock source */ +#define LL_RCC_I2C1_CLKSOURCE_SYSCLK RCC_CFGR3_I2C1SW_SYSCLK /*!< System clock selected as I2C1 clock source */ +/** + * @} + */ + +#if defined(CEC) +/** @defgroup RCC_LL_EC_CEC_CLKSOURCE Peripheral CEC clock source selection + * @{ + */ +#define LL_RCC_CEC_CLKSOURCE_HSI_DIV244 RCC_CFGR3_CECSW_HSI_DIV244 /*!< HSI clock divided by 244 selected as HDMI CEC entry clock source */ +#define LL_RCC_CEC_CLKSOURCE_LSE RCC_CFGR3_CECSW_LSE /*!< LSE clock selected as HDMI CEC entry clock source */ +/** + * @} + */ + +#endif /* CEC */ + +#if defined(USB) +/** @defgroup RCC_LL_EC_USB_CLKSOURCE Peripheral USB clock source selection + * @{ + */ +#if defined(RCC_CFGR3_USBSW_HSI48) +#define LL_RCC_USB_CLKSOURCE_HSI48 RCC_CFGR3_USBSW_HSI48 /*!< HSI48 oscillator clock used as USB clock source */ +#else +#define LL_RCC_USB_CLKSOURCE_NONE ((uint32_t)0x00000000) /*!< USB Clock disabled */ +#endif /*RCC_CFGR3_USBSW_HSI48*/ +#define LL_RCC_USB_CLKSOURCE_PLL RCC_CFGR3_USBSW_PLLCLK /*!< PLL selected as USB clock source */ +/** + * @} + */ + +#endif /* USB */ + +/** @defgroup RCC_LL_EC_USART1 Peripheral USART get clock source + * @{ + */ +#define LL_RCC_USART1_CLKSOURCE RCC_POSITION_USART1SW /*!< USART1 Clock source selection */ +#if defined(RCC_CFGR3_USART2SW) +#define LL_RCC_USART2_CLKSOURCE RCC_POSITION_USART2SW /*!< USART2 Clock source selection */ +#endif /* RCC_CFGR3_USART2SW */ +#if defined(RCC_CFGR3_USART3SW) +#define LL_RCC_USART3_CLKSOURCE RCC_POSITION_USART3SW /*!< USART3 Clock source selection */ +#endif /* RCC_CFGR3_USART3SW */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_I2C1 Peripheral I2C get clock source + * @{ + */ +#define LL_RCC_I2C1_CLKSOURCE RCC_CFGR3_I2C1SW /*!< I2C1 Clock source selection */ +/** + * @} + */ + +#if defined(CEC) +/** @defgroup RCC_LL_EC_CEC Peripheral CEC get clock source + * @{ + */ +#define LL_RCC_CEC_CLKSOURCE RCC_CFGR3_CECSW /*!< CEC Clock source selection */ +/** + * @} + */ +#endif /* CEC */ + +#if defined(USB) +/** @defgroup RCC_LL_EC_USB Peripheral USB get clock source + * @{ + */ +#define LL_RCC_USB_CLKSOURCE RCC_CFGR3_USBSW /*!< USB Clock source selection */ +/** + * @} + */ +#endif /* USB */ + +/** @defgroup RCC_LL_EC_RTC_CLKSOURCE RTC clock source selection + * @{ + */ +#define LL_RCC_RTC_CLKSOURCE_NONE 0x00000000U /*!< No clock used as RTC clock */ +#define LL_RCC_RTC_CLKSOURCE_LSE RCC_BDCR_RTCSEL_0 /*!< LSE oscillator clock used as RTC clock */ +#define LL_RCC_RTC_CLKSOURCE_LSI RCC_BDCR_RTCSEL_1 /*!< LSI oscillator clock used as RTC clock */ +#define LL_RCC_RTC_CLKSOURCE_HSE_DIV32 RCC_BDCR_RTCSEL /*!< HSE oscillator clock divided by 32 used as RTC clock */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_PLL_MUL PLL Multiplicator factor + * @{ + */ +#define LL_RCC_PLL_MUL_2 RCC_CFGR_PLLMUL2 /*!< PLL input clock*2 */ +#define LL_RCC_PLL_MUL_3 RCC_CFGR_PLLMUL3 /*!< PLL input clock*3 */ +#define LL_RCC_PLL_MUL_4 RCC_CFGR_PLLMUL4 /*!< PLL input clock*4 */ +#define LL_RCC_PLL_MUL_5 RCC_CFGR_PLLMUL5 /*!< PLL input clock*5 */ +#define LL_RCC_PLL_MUL_6 RCC_CFGR_PLLMUL6 /*!< PLL input clock*6 */ +#define LL_RCC_PLL_MUL_7 RCC_CFGR_PLLMUL7 /*!< PLL input clock*7 */ +#define LL_RCC_PLL_MUL_8 RCC_CFGR_PLLMUL8 /*!< PLL input clock*8 */ +#define LL_RCC_PLL_MUL_9 RCC_CFGR_PLLMUL9 /*!< PLL input clock*9 */ +#define LL_RCC_PLL_MUL_10 RCC_CFGR_PLLMUL10 /*!< PLL input clock*10 */ +#define LL_RCC_PLL_MUL_11 RCC_CFGR_PLLMUL11 /*!< PLL input clock*11 */ +#define LL_RCC_PLL_MUL_12 RCC_CFGR_PLLMUL12 /*!< PLL input clock*12 */ +#define LL_RCC_PLL_MUL_13 RCC_CFGR_PLLMUL13 /*!< PLL input clock*13 */ +#define LL_RCC_PLL_MUL_14 RCC_CFGR_PLLMUL14 /*!< PLL input clock*14 */ +#define LL_RCC_PLL_MUL_15 RCC_CFGR_PLLMUL15 /*!< PLL input clock*15 */ +#define LL_RCC_PLL_MUL_16 RCC_CFGR_PLLMUL16 /*!< PLL input clock*16 */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_PLLSOURCE PLL SOURCE + * @{ + */ +#define LL_RCC_PLLSOURCE_NONE 0x00000000U /*!< No clock selected as main PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE RCC_CFGR_PLLSRC_HSE_PREDIV /*!< HSE/PREDIV clock selected as PLL entry clock source */ +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) +#define LL_RCC_PLLSOURCE_HSI RCC_CFGR_PLLSRC_HSI_PREDIV /*!< HSI/PREDIV clock selected as PLL entry clock source */ +#if defined(RCC_CFGR_SW_HSI48) +#define LL_RCC_PLLSOURCE_HSI48 RCC_CFGR_PLLSRC_HSI48_PREDIV /*!< HSI48/PREDIV clock selected as PLL entry clock source */ +#endif /* RCC_CFGR_SW_HSI48 */ +#else +#define LL_RCC_PLLSOURCE_HSI_DIV_2 RCC_CFGR_PLLSRC_HSI_DIV2 /*!< HSI clock divided by 2 selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_1 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV1) /*!< HSE clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_2 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV2) /*!< HSE/2 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_3 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV3) /*!< HSE/3 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_4 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV4) /*!< HSE/4 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_5 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV5) /*!< HSE/5 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_6 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV6) /*!< HSE/6 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_7 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV7) /*!< HSE/7 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_8 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV8) /*!< HSE/8 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_9 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV9) /*!< HSE/9 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_10 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV10) /*!< HSE/10 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_11 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV11) /*!< HSE/11 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_12 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV12) /*!< HSE/12 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_13 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV13) /*!< HSE/13 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_14 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV14) /*!< HSE/14 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_15 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV15) /*!< HSE/15 clock selected as PLL entry clock source */ +#define LL_RCC_PLLSOURCE_HSE_DIV_16 (RCC_CFGR_PLLSRC_HSE_PREDIV | RCC_CFGR2_PREDIV_DIV16) /*!< HSE/16 clock selected as PLL entry clock source */ +#endif /* RCC_PLLSRC_PREDIV1_SUPPORT */ +/** + * @} + */ + +/** @defgroup RCC_LL_EC_PREDIV_DIV PREDIV Division factor + * @{ + */ +#define LL_RCC_PREDIV_DIV_1 RCC_CFGR2_PREDIV_DIV1 /*!< PREDIV input clock not divided */ +#define LL_RCC_PREDIV_DIV_2 RCC_CFGR2_PREDIV_DIV2 /*!< PREDIV input clock divided by 2 */ +#define LL_RCC_PREDIV_DIV_3 RCC_CFGR2_PREDIV_DIV3 /*!< PREDIV input clock divided by 3 */ +#define LL_RCC_PREDIV_DIV_4 RCC_CFGR2_PREDIV_DIV4 /*!< PREDIV input clock divided by 4 */ +#define LL_RCC_PREDIV_DIV_5 RCC_CFGR2_PREDIV_DIV5 /*!< PREDIV input clock divided by 5 */ +#define LL_RCC_PREDIV_DIV_6 RCC_CFGR2_PREDIV_DIV6 /*!< PREDIV input clock divided by 6 */ +#define LL_RCC_PREDIV_DIV_7 RCC_CFGR2_PREDIV_DIV7 /*!< PREDIV input clock divided by 7 */ +#define LL_RCC_PREDIV_DIV_8 RCC_CFGR2_PREDIV_DIV8 /*!< PREDIV input clock divided by 8 */ +#define LL_RCC_PREDIV_DIV_9 RCC_CFGR2_PREDIV_DIV9 /*!< PREDIV input clock divided by 9 */ +#define LL_RCC_PREDIV_DIV_10 RCC_CFGR2_PREDIV_DIV10 /*!< PREDIV input clock divided by 10 */ +#define LL_RCC_PREDIV_DIV_11 RCC_CFGR2_PREDIV_DIV11 /*!< PREDIV input clock divided by 11 */ +#define LL_RCC_PREDIV_DIV_12 RCC_CFGR2_PREDIV_DIV12 /*!< PREDIV input clock divided by 12 */ +#define LL_RCC_PREDIV_DIV_13 RCC_CFGR2_PREDIV_DIV13 /*!< PREDIV input clock divided by 13 */ +#define LL_RCC_PREDIV_DIV_14 RCC_CFGR2_PREDIV_DIV14 /*!< PREDIV input clock divided by 14 */ +#define LL_RCC_PREDIV_DIV_15 RCC_CFGR2_PREDIV_DIV15 /*!< PREDIV input clock divided by 15 */ +#define LL_RCC_PREDIV_DIV_16 RCC_CFGR2_PREDIV_DIV16 /*!< PREDIV input clock divided by 16 */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup RCC_LL_Exported_Macros RCC Exported Macros + * @{ + */ + +/** @defgroup RCC_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in RCC register + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_RCC_WriteReg(__REG__, __VALUE__) WRITE_REG(RCC->__REG__, (__VALUE__)) + +/** + * @brief Read a value in RCC register + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_RCC_ReadReg(__REG__) READ_REG(RCC->__REG__) +/** + * @} + */ + +/** @defgroup RCC_LL_EM_CALC_FREQ Calculate frequencies + * @{ + */ + +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) +/** + * @brief Helper macro to calculate the PLLCLK frequency + * @note ex: @ref __LL_RCC_CALC_PLLCLK_FREQ (HSE_VALUE, @ref LL_RCC_PLL_GetMultiplicator() + * , @ref LL_RCC_PLL_GetPrediv()); + * @param __INPUTFREQ__ PLL Input frequency (based on HSE/HSI/HSI48) + * @param __PLLMUL__ This parameter can be one of the following values: + * @arg @ref LL_RCC_PLL_MUL_2 + * @arg @ref LL_RCC_PLL_MUL_3 + * @arg @ref LL_RCC_PLL_MUL_4 + * @arg @ref LL_RCC_PLL_MUL_5 + * @arg @ref LL_RCC_PLL_MUL_6 + * @arg @ref LL_RCC_PLL_MUL_7 + * @arg @ref LL_RCC_PLL_MUL_8 + * @arg @ref LL_RCC_PLL_MUL_9 + * @arg @ref LL_RCC_PLL_MUL_10 + * @arg @ref LL_RCC_PLL_MUL_11 + * @arg @ref LL_RCC_PLL_MUL_12 + * @arg @ref LL_RCC_PLL_MUL_13 + * @arg @ref LL_RCC_PLL_MUL_14 + * @arg @ref LL_RCC_PLL_MUL_15 + * @arg @ref LL_RCC_PLL_MUL_16 + * @param __PLLPREDIV__ This parameter can be one of the following values: + * @arg @ref LL_RCC_PREDIV_DIV_1 + * @arg @ref LL_RCC_PREDIV_DIV_2 + * @arg @ref LL_RCC_PREDIV_DIV_3 + * @arg @ref LL_RCC_PREDIV_DIV_4 + * @arg @ref LL_RCC_PREDIV_DIV_5 + * @arg @ref LL_RCC_PREDIV_DIV_6 + * @arg @ref LL_RCC_PREDIV_DIV_7 + * @arg @ref LL_RCC_PREDIV_DIV_8 + * @arg @ref LL_RCC_PREDIV_DIV_9 + * @arg @ref LL_RCC_PREDIV_DIV_10 + * @arg @ref LL_RCC_PREDIV_DIV_11 + * @arg @ref LL_RCC_PREDIV_DIV_12 + * @arg @ref LL_RCC_PREDIV_DIV_13 + * @arg @ref LL_RCC_PREDIV_DIV_14 + * @arg @ref LL_RCC_PREDIV_DIV_15 + * @arg @ref LL_RCC_PREDIV_DIV_16 + * @retval PLL clock frequency (in Hz) + */ +#define __LL_RCC_CALC_PLLCLK_FREQ(__INPUTFREQ__, __PLLMUL__, __PLLPREDIV__) \ + (((__INPUTFREQ__) / ((((__PLLPREDIV__) & RCC_CFGR2_PREDIV) + 1U))) * ((((__PLLMUL__) & RCC_CFGR_PLLMUL) >> RCC_POSITION_PLLMUL) + 2U)) + +#else +/** + * @brief Helper macro to calculate the PLLCLK frequency + * @note ex: @ref __LL_RCC_CALC_PLLCLK_FREQ (HSE_VALUE / (@ref LL_RCC_PLL_GetPrediv () + 1), @ref LL_RCC_PLL_GetMultiplicator()); + * @param __INPUTFREQ__ PLL Input frequency (based on HSE div Prediv / HSI div 2) + * @param __PLLMUL__ This parameter can be one of the following values: + * @arg @ref LL_RCC_PLL_MUL_2 + * @arg @ref LL_RCC_PLL_MUL_3 + * @arg @ref LL_RCC_PLL_MUL_4 + * @arg @ref LL_RCC_PLL_MUL_5 + * @arg @ref LL_RCC_PLL_MUL_6 + * @arg @ref LL_RCC_PLL_MUL_7 + * @arg @ref LL_RCC_PLL_MUL_8 + * @arg @ref LL_RCC_PLL_MUL_9 + * @arg @ref LL_RCC_PLL_MUL_10 + * @arg @ref LL_RCC_PLL_MUL_11 + * @arg @ref LL_RCC_PLL_MUL_12 + * @arg @ref LL_RCC_PLL_MUL_13 + * @arg @ref LL_RCC_PLL_MUL_14 + * @arg @ref LL_RCC_PLL_MUL_15 + * @arg @ref LL_RCC_PLL_MUL_16 + * @retval PLL clock frequency (in Hz) + */ +#define __LL_RCC_CALC_PLLCLK_FREQ(__INPUTFREQ__, __PLLMUL__) \ + ((__INPUTFREQ__) * ((((__PLLMUL__) & RCC_CFGR_PLLMUL) >> RCC_POSITION_PLLMUL) + 2U)) +#endif /* RCC_PLLSRC_PREDIV1_SUPPORT */ +/** + * @brief Helper macro to calculate the HCLK frequency + * @note: __AHBPRESCALER__ be retrieved by @ref LL_RCC_GetAHBPrescaler + * ex: __LL_RCC_CALC_HCLK_FREQ(LL_RCC_GetAHBPrescaler()) + * @param __SYSCLKFREQ__ SYSCLK frequency (based on HSE/HSI/PLLCLK) + * @param __AHBPRESCALER__ This parameter can be one of the following values: + * @arg @ref LL_RCC_SYSCLK_DIV_1 + * @arg @ref LL_RCC_SYSCLK_DIV_2 + * @arg @ref LL_RCC_SYSCLK_DIV_4 + * @arg @ref LL_RCC_SYSCLK_DIV_8 + * @arg @ref LL_RCC_SYSCLK_DIV_16 + * @arg @ref LL_RCC_SYSCLK_DIV_64 + * @arg @ref LL_RCC_SYSCLK_DIV_128 + * @arg @ref LL_RCC_SYSCLK_DIV_256 + * @arg @ref LL_RCC_SYSCLK_DIV_512 + * @retval HCLK clock frequency (in Hz) + */ +#define __LL_RCC_CALC_HCLK_FREQ(__SYSCLKFREQ__, __AHBPRESCALER__) ((__SYSCLKFREQ__) >> AHBPrescTable[((__AHBPRESCALER__) & RCC_CFGR_HPRE) >> RCC_CFGR_HPRE_Pos]) + +/** + * @brief Helper macro to calculate the PCLK1 frequency (ABP1) + * @note: __APB1PRESCALER__ be retrieved by @ref LL_RCC_GetAPB1Prescaler + * ex: __LL_RCC_CALC_PCLK1_FREQ(LL_RCC_GetAPB1Prescaler()) + * @param __HCLKFREQ__ HCLK frequency + * @param __APB1PRESCALER__ This parameter can be one of the following values: + * @arg @ref LL_RCC_APB1_DIV_1 + * @arg @ref LL_RCC_APB1_DIV_2 + * @arg @ref LL_RCC_APB1_DIV_4 + * @arg @ref LL_RCC_APB1_DIV_8 + * @arg @ref LL_RCC_APB1_DIV_16 + * @retval PCLK1 clock frequency (in Hz) + */ +#define __LL_RCC_CALC_PCLK1_FREQ(__HCLKFREQ__, __APB1PRESCALER__) ((__HCLKFREQ__) >> APBPrescTable[(__APB1PRESCALER__) >> RCC_CFGR_PPRE_Pos]) + +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup RCC_LL_Exported_Functions RCC Exported Functions + * @{ + */ + +/** @defgroup RCC_LL_EF_HSE HSE + * @{ + */ + +/** + * @brief Enable the Clock Security System. + * @rmtoll CR CSSON LL_RCC_HSE_EnableCSS + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSE_EnableCSS(void) +{ + SET_BIT(RCC->CR, RCC_CR_CSSON); +} + +/** + * @brief Disable the Clock Security System. + * @note Cannot be disabled in HSE is ready (only by hardware) + * @rmtoll CR CSSON LL_RCC_HSE_DisableCSS + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSE_DisableCSS(void) +{ + CLEAR_BIT(RCC->CR, RCC_CR_CSSON); +} + +/** + * @brief Enable HSE external oscillator (HSE Bypass) + * @rmtoll CR HSEBYP LL_RCC_HSE_EnableBypass + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSE_EnableBypass(void) +{ + SET_BIT(RCC->CR, RCC_CR_HSEBYP); +} + +/** + * @brief Disable HSE external oscillator (HSE Bypass) + * @rmtoll CR HSEBYP LL_RCC_HSE_DisableBypass + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSE_DisableBypass(void) +{ + CLEAR_BIT(RCC->CR, RCC_CR_HSEBYP); +} + +/** + * @brief Enable HSE crystal oscillator (HSE ON) + * @rmtoll CR HSEON LL_RCC_HSE_Enable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSE_Enable(void) +{ + SET_BIT(RCC->CR, RCC_CR_HSEON); +} + +/** + * @brief Disable HSE crystal oscillator (HSE ON) + * @rmtoll CR HSEON LL_RCC_HSE_Disable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSE_Disable(void) +{ + CLEAR_BIT(RCC->CR, RCC_CR_HSEON); +} + +/** + * @brief Check if HSE oscillator Ready + * @rmtoll CR HSERDY LL_RCC_HSE_IsReady + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_HSE_IsReady(void) +{ + return (READ_BIT(RCC->CR, RCC_CR_HSERDY) == (RCC_CR_HSERDY)); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_HSI HSI + * @{ + */ + +/** + * @brief Enable HSI oscillator + * @rmtoll CR HSION LL_RCC_HSI_Enable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI_Enable(void) +{ + SET_BIT(RCC->CR, RCC_CR_HSION); +} + +/** + * @brief Disable HSI oscillator + * @rmtoll CR HSION LL_RCC_HSI_Disable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI_Disable(void) +{ + CLEAR_BIT(RCC->CR, RCC_CR_HSION); +} + +/** + * @brief Check if HSI clock is ready + * @rmtoll CR HSIRDY LL_RCC_HSI_IsReady + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_HSI_IsReady(void) +{ + return (READ_BIT(RCC->CR, RCC_CR_HSIRDY) == (RCC_CR_HSIRDY)); +} + +/** + * @brief Get HSI Calibration value + * @note When HSITRIM is written, HSICAL is updated with the sum of + * HSITRIM and the factory trim value + * @rmtoll CR HSICAL LL_RCC_HSI_GetCalibration + * @retval Between Min_Data = 0x00 and Max_Data = 0xFF + */ +__STATIC_INLINE uint32_t LL_RCC_HSI_GetCalibration(void) +{ + return (uint32_t)(READ_BIT(RCC->CR, RCC_CR_HSICAL) >> RCC_CR_HSICAL_Pos); +} + +/** + * @brief Set HSI Calibration trimming + * @note user-programmable trimming value that is added to the HSICAL + * @note Default value is 16, which, when added to the HSICAL value, + * should trim the HSI to 16 MHz +/- 1 % + * @rmtoll CR HSITRIM LL_RCC_HSI_SetCalibTrimming + * @param Value between Min_Data = 0x00 and Max_Data = 0x1F + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI_SetCalibTrimming(uint32_t Value) +{ + MODIFY_REG(RCC->CR, RCC_CR_HSITRIM, Value << RCC_CR_HSITRIM_Pos); +} + +/** + * @brief Get HSI Calibration trimming + * @rmtoll CR HSITRIM LL_RCC_HSI_GetCalibTrimming + * @retval Between Min_Data = 0x00 and Max_Data = 0x1F + */ +__STATIC_INLINE uint32_t LL_RCC_HSI_GetCalibTrimming(void) +{ + return (uint32_t)(READ_BIT(RCC->CR, RCC_CR_HSITRIM) >> RCC_CR_HSITRIM_Pos); +} + +/** + * @} + */ + +#if defined(RCC_HSI48_SUPPORT) +/** @defgroup RCC_LL_EF_HSI48 HSI48 + * @{ + */ + +/** + * @brief Enable HSI48 + * @rmtoll CR2 HSI48ON LL_RCC_HSI48_Enable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI48_Enable(void) +{ + SET_BIT(RCC->CR2, RCC_CR2_HSI48ON); +} + +/** + * @brief Disable HSI48 + * @rmtoll CR2 HSI48ON LL_RCC_HSI48_Disable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI48_Disable(void) +{ + CLEAR_BIT(RCC->CR2, RCC_CR2_HSI48ON); +} + +/** + * @brief Check if HSI48 oscillator Ready + * @rmtoll CR2 HSI48RDY LL_RCC_HSI48_IsReady + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_HSI48_IsReady(void) +{ + return (READ_BIT(RCC->CR2, RCC_CR2_HSI48RDY) == (RCC_CR2_HSI48RDY)); +} + +/** + * @brief Get HSI48 Calibration value + * @rmtoll CR2 HSI48CAL LL_RCC_HSI48_GetCalibration + * @retval Between Min_Data = 0x00 and Max_Data = 0xFF + */ +__STATIC_INLINE uint32_t LL_RCC_HSI48_GetCalibration(void) +{ + return (uint32_t)(READ_BIT(RCC->CR2, RCC_CR2_HSI48CAL) >> RCC_POSITION_HSI48CAL); +} + +/** + * @} + */ + +#endif /* RCC_HSI48_SUPPORT */ + +/** @defgroup RCC_LL_EF_HSI14 HSI14 + * @{ + */ + +/** + * @brief Enable HSI14 + * @rmtoll CR2 HSI14ON LL_RCC_HSI14_Enable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI14_Enable(void) +{ + SET_BIT(RCC->CR2, RCC_CR2_HSI14ON); +} + +/** + * @brief Disable HSI14 + * @rmtoll CR2 HSI14ON LL_RCC_HSI14_Disable + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI14_Disable(void) +{ + CLEAR_BIT(RCC->CR2, RCC_CR2_HSI14ON); +} + +/** + * @brief Check if HSI14 oscillator Ready + * @rmtoll CR2 HSI14RDY LL_RCC_HSI14_IsReady + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_HSI14_IsReady(void) +{ + return (READ_BIT(RCC->CR2, RCC_CR2_HSI14RDY) == (RCC_CR2_HSI14RDY)); +} + +/** + * @brief ADC interface can turn on the HSI14 oscillator + * @rmtoll CR2 HSI14DIS LL_RCC_HSI14_EnableADCControl + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI14_EnableADCControl(void) +{ + CLEAR_BIT(RCC->CR2, RCC_CR2_HSI14DIS); +} + +/** + * @brief ADC interface can not turn on the HSI14 oscillator + * @rmtoll CR2 HSI14DIS LL_RCC_HSI14_DisableADCControl + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI14_DisableADCControl(void) +{ + SET_BIT(RCC->CR2, RCC_CR2_HSI14DIS); +} + +/** + * @brief Set HSI14 Calibration trimming + * @note user-programmable trimming value that is added to the HSI14CAL + * @note Default value is 16, which, when added to the HSI14CAL value, + * should trim the HSI14 to 14 MHz +/- 1 % + * @rmtoll CR2 HSI14TRIM LL_RCC_HSI14_SetCalibTrimming + * @param Value between Min_Data = 0x00 and Max_Data = 0xFF + * @retval None + */ +__STATIC_INLINE void LL_RCC_HSI14_SetCalibTrimming(uint32_t Value) +{ + MODIFY_REG(RCC->CR2, RCC_CR2_HSI14TRIM, Value << RCC_POSITION_HSI14TRIM); +} + +/** + * @brief Get HSI14 Calibration value + * @note When HSI14TRIM is written, HSI14CAL is updated with the sum of + * HSI14TRIM and the factory trim value + * @rmtoll CR2 HSI14TRIM LL_RCC_HSI14_GetCalibTrimming + * @retval Between Min_Data = 0x00 and Max_Data = 0x1F + */ +__STATIC_INLINE uint32_t LL_RCC_HSI14_GetCalibTrimming(void) +{ + return (uint32_t)(READ_BIT(RCC->CR2, RCC_CR2_HSI14TRIM) >> RCC_POSITION_HSI14TRIM); +} + +/** + * @brief Get HSI14 Calibration trimming + * @rmtoll CR2 HSI14CAL LL_RCC_HSI14_GetCalibration + * @retval Between Min_Data = 0x00 and Max_Data = 0x1F + */ +__STATIC_INLINE uint32_t LL_RCC_HSI14_GetCalibration(void) +{ + return (uint32_t)(READ_BIT(RCC->CR2, RCC_CR2_HSI14CAL) >> RCC_POSITION_HSI14CAL); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_LSE LSE + * @{ + */ + +/** + * @brief Enable Low Speed External (LSE) crystal. + * @rmtoll BDCR LSEON LL_RCC_LSE_Enable + * @retval None + */ +__STATIC_INLINE void LL_RCC_LSE_Enable(void) +{ + SET_BIT(RCC->BDCR, RCC_BDCR_LSEON); +} + +/** + * @brief Disable Low Speed External (LSE) crystal. + * @rmtoll BDCR LSEON LL_RCC_LSE_Disable + * @retval None + */ +__STATIC_INLINE void LL_RCC_LSE_Disable(void) +{ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEON); +} + +/** + * @brief Enable external clock source (LSE bypass). + * @rmtoll BDCR LSEBYP LL_RCC_LSE_EnableBypass + * @retval None + */ +__STATIC_INLINE void LL_RCC_LSE_EnableBypass(void) +{ + SET_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); +} + +/** + * @brief Disable external clock source (LSE bypass). + * @rmtoll BDCR LSEBYP LL_RCC_LSE_DisableBypass + * @retval None + */ +__STATIC_INLINE void LL_RCC_LSE_DisableBypass(void) +{ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEBYP); +} + +/** + * @brief Set LSE oscillator drive capability + * @note The oscillator is in Xtal mode when it is not in bypass mode. + * @rmtoll BDCR LSEDRV LL_RCC_LSE_SetDriveCapability + * @param LSEDrive This parameter can be one of the following values: + * @arg @ref LL_RCC_LSEDRIVE_LOW + * @arg @ref LL_RCC_LSEDRIVE_MEDIUMLOW + * @arg @ref LL_RCC_LSEDRIVE_MEDIUMHIGH + * @arg @ref LL_RCC_LSEDRIVE_HIGH + * @retval None + */ +__STATIC_INLINE void LL_RCC_LSE_SetDriveCapability(uint32_t LSEDrive) +{ + MODIFY_REG(RCC->BDCR, RCC_BDCR_LSEDRV, LSEDrive); +} + +/** + * @brief Get LSE oscillator drive capability + * @rmtoll BDCR LSEDRV LL_RCC_LSE_GetDriveCapability + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_LSEDRIVE_LOW + * @arg @ref LL_RCC_LSEDRIVE_MEDIUMLOW + * @arg @ref LL_RCC_LSEDRIVE_MEDIUMHIGH + * @arg @ref LL_RCC_LSEDRIVE_HIGH + */ +__STATIC_INLINE uint32_t LL_RCC_LSE_GetDriveCapability(void) +{ + return (uint32_t)(READ_BIT(RCC->BDCR, RCC_BDCR_LSEDRV)); +} + +/** + * @brief Check if LSE oscillator Ready + * @rmtoll BDCR LSERDY LL_RCC_LSE_IsReady + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_LSE_IsReady(void) +{ + return (READ_BIT(RCC->BDCR, RCC_BDCR_LSERDY) == (RCC_BDCR_LSERDY)); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_LSI LSI + * @{ + */ + +/** + * @brief Enable LSI Oscillator + * @rmtoll CSR LSION LL_RCC_LSI_Enable + * @retval None + */ +__STATIC_INLINE void LL_RCC_LSI_Enable(void) +{ + SET_BIT(RCC->CSR, RCC_CSR_LSION); +} + +/** + * @brief Disable LSI Oscillator + * @rmtoll CSR LSION LL_RCC_LSI_Disable + * @retval None + */ +__STATIC_INLINE void LL_RCC_LSI_Disable(void) +{ + CLEAR_BIT(RCC->CSR, RCC_CSR_LSION); +} + +/** + * @brief Check if LSI is Ready + * @rmtoll CSR LSIRDY LL_RCC_LSI_IsReady + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_LSI_IsReady(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_LSIRDY) == (RCC_CSR_LSIRDY)); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_System System + * @{ + */ + +/** + * @brief Configure the system clock source + * @rmtoll CFGR SW LL_RCC_SetSysClkSource + * @param Source This parameter can be one of the following values: + * @arg @ref LL_RCC_SYS_CLKSOURCE_HSI + * @arg @ref LL_RCC_SYS_CLKSOURCE_HSE + * @arg @ref LL_RCC_SYS_CLKSOURCE_PLL + * @arg @ref LL_RCC_SYS_CLKSOURCE_HSI48 (*) + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetSysClkSource(uint32_t Source) +{ + MODIFY_REG(RCC->CFGR, RCC_CFGR_SW, Source); +} + +/** + * @brief Get the system clock source + * @rmtoll CFGR SWS LL_RCC_GetSysClkSource + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_SYS_CLKSOURCE_STATUS_HSI + * @arg @ref LL_RCC_SYS_CLKSOURCE_STATUS_HSE + * @arg @ref LL_RCC_SYS_CLKSOURCE_STATUS_PLL + * @arg @ref LL_RCC_SYS_CLKSOURCE_STATUS_HSI48 (*) + * + * (*) value not defined in all devices + */ +__STATIC_INLINE uint32_t LL_RCC_GetSysClkSource(void) +{ + return (uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_SWS)); +} + +/** + * @brief Set AHB prescaler + * @rmtoll CFGR HPRE LL_RCC_SetAHBPrescaler + * @param Prescaler This parameter can be one of the following values: + * @arg @ref LL_RCC_SYSCLK_DIV_1 + * @arg @ref LL_RCC_SYSCLK_DIV_2 + * @arg @ref LL_RCC_SYSCLK_DIV_4 + * @arg @ref LL_RCC_SYSCLK_DIV_8 + * @arg @ref LL_RCC_SYSCLK_DIV_16 + * @arg @ref LL_RCC_SYSCLK_DIV_64 + * @arg @ref LL_RCC_SYSCLK_DIV_128 + * @arg @ref LL_RCC_SYSCLK_DIV_256 + * @arg @ref LL_RCC_SYSCLK_DIV_512 + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetAHBPrescaler(uint32_t Prescaler) +{ + MODIFY_REG(RCC->CFGR, RCC_CFGR_HPRE, Prescaler); +} + +/** + * @brief Set APB1 prescaler + * @rmtoll CFGR PPRE LL_RCC_SetAPB1Prescaler + * @param Prescaler This parameter can be one of the following values: + * @arg @ref LL_RCC_APB1_DIV_1 + * @arg @ref LL_RCC_APB1_DIV_2 + * @arg @ref LL_RCC_APB1_DIV_4 + * @arg @ref LL_RCC_APB1_DIV_8 + * @arg @ref LL_RCC_APB1_DIV_16 + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetAPB1Prescaler(uint32_t Prescaler) +{ + MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE, Prescaler); +} + +/** + * @brief Get AHB prescaler + * @rmtoll CFGR HPRE LL_RCC_GetAHBPrescaler + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_SYSCLK_DIV_1 + * @arg @ref LL_RCC_SYSCLK_DIV_2 + * @arg @ref LL_RCC_SYSCLK_DIV_4 + * @arg @ref LL_RCC_SYSCLK_DIV_8 + * @arg @ref LL_RCC_SYSCLK_DIV_16 + * @arg @ref LL_RCC_SYSCLK_DIV_64 + * @arg @ref LL_RCC_SYSCLK_DIV_128 + * @arg @ref LL_RCC_SYSCLK_DIV_256 + * @arg @ref LL_RCC_SYSCLK_DIV_512 + */ +__STATIC_INLINE uint32_t LL_RCC_GetAHBPrescaler(void) +{ + return (uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_HPRE)); +} + +/** + * @brief Get APB1 prescaler + * @rmtoll CFGR PPRE LL_RCC_GetAPB1Prescaler + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_APB1_DIV_1 + * @arg @ref LL_RCC_APB1_DIV_2 + * @arg @ref LL_RCC_APB1_DIV_4 + * @arg @ref LL_RCC_APB1_DIV_8 + * @arg @ref LL_RCC_APB1_DIV_16 + */ +__STATIC_INLINE uint32_t LL_RCC_GetAPB1Prescaler(void) +{ + return (uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_PPRE)); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_MCO MCO + * @{ + */ + +/** + * @brief Configure MCOx + * @rmtoll CFGR MCO LL_RCC_ConfigMCO\n + * CFGR MCOPRE LL_RCC_ConfigMCO\n + * CFGR PLLNODIV LL_RCC_ConfigMCO + * @param MCOxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_MCO1SOURCE_NOCLOCK + * @arg @ref LL_RCC_MCO1SOURCE_HSI14 + * @arg @ref LL_RCC_MCO1SOURCE_SYSCLK + * @arg @ref LL_RCC_MCO1SOURCE_HSI + * @arg @ref LL_RCC_MCO1SOURCE_HSE + * @arg @ref LL_RCC_MCO1SOURCE_LSI + * @arg @ref LL_RCC_MCO1SOURCE_LSE + * @arg @ref LL_RCC_MCO1SOURCE_HSI48 (*) + * @arg @ref LL_RCC_MCO1SOURCE_PLLCLK (*) + * @arg @ref LL_RCC_MCO1SOURCE_PLLCLK_DIV_2 + * + * (*) value not defined in all devices + * @param MCOxPrescaler This parameter can be one of the following values: + * @arg @ref LL_RCC_MCO1_DIV_1 + * @arg @ref LL_RCC_MCO1_DIV_2 (*) + * @arg @ref LL_RCC_MCO1_DIV_4 (*) + * @arg @ref LL_RCC_MCO1_DIV_8 (*) + * @arg @ref LL_RCC_MCO1_DIV_16 (*) + * @arg @ref LL_RCC_MCO1_DIV_32 (*) + * @arg @ref LL_RCC_MCO1_DIV_64 (*) + * @arg @ref LL_RCC_MCO1_DIV_128 (*) + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_RCC_ConfigMCO(uint32_t MCOxSource, uint32_t MCOxPrescaler) +{ +#if defined(RCC_CFGR_MCOPRE) +#if defined(RCC_CFGR_PLLNODIV) + MODIFY_REG(RCC->CFGR, RCC_CFGR_MCOSEL | RCC_CFGR_MCOPRE | RCC_CFGR_PLLNODIV, MCOxSource | MCOxPrescaler); +#else + MODIFY_REG(RCC->CFGR, RCC_CFGR_MCOSEL | RCC_CFGR_MCOPRE, MCOxSource | MCOxPrescaler); +#endif /* RCC_CFGR_PLLNODIV */ +#else + MODIFY_REG(RCC->CFGR, RCC_CFGR_MCOSEL, MCOxSource); +#endif /* RCC_CFGR_MCOPRE */ +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_Peripheral_Clock_Source Peripheral Clock Source + * @{ + */ + +/** + * @brief Configure USARTx clock source + * @rmtoll CFGR3 USART1SW LL_RCC_SetUSARTClockSource\n + * CFGR3 USART2SW LL_RCC_SetUSARTClockSource\n + * CFGR3 USART3SW LL_RCC_SetUSARTClockSource + * @param USARTxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_USART1_CLKSOURCE_PCLK1 + * @arg @ref LL_RCC_USART1_CLKSOURCE_SYSCLK + * @arg @ref LL_RCC_USART1_CLKSOURCE_LSE + * @arg @ref LL_RCC_USART1_CLKSOURCE_HSI + * @arg @ref LL_RCC_USART2_CLKSOURCE_PCLK1 (*) + * @arg @ref LL_RCC_USART2_CLKSOURCE_SYSCLK (*) + * @arg @ref LL_RCC_USART2_CLKSOURCE_LSE (*) + * @arg @ref LL_RCC_USART2_CLKSOURCE_HSI (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_PCLK1 (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_SYSCLK (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_LSE (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_HSI (*) + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetUSARTClockSource(uint32_t USARTxSource) +{ + MODIFY_REG(RCC->CFGR3, (RCC_CFGR3_USART1SW << ((USARTxSource & 0xFF000000U) >> 24U)), (USARTxSource & 0x00FFFFFFU)); +} + +/** + * @brief Configure I2Cx clock source + * @rmtoll CFGR3 I2C1SW LL_RCC_SetI2CClockSource + * @param I2CxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_I2C1_CLKSOURCE_HSI + * @arg @ref LL_RCC_I2C1_CLKSOURCE_SYSCLK + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetI2CClockSource(uint32_t I2CxSource) +{ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_I2C1SW, I2CxSource); +} + +#if defined(CEC) +/** + * @brief Configure CEC clock source + * @rmtoll CFGR3 CECSW LL_RCC_SetCECClockSource + * @param CECxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_CEC_CLKSOURCE_HSI_DIV244 + * @arg @ref LL_RCC_CEC_CLKSOURCE_LSE + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetCECClockSource(uint32_t CECxSource) +{ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_CECSW, CECxSource); +} +#endif /* CEC */ + +#if defined(USB) +/** + * @brief Configure USB clock source + * @rmtoll CFGR3 USBSW LL_RCC_SetUSBClockSource + * @param USBxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_USB_CLKSOURCE_HSI48 (*) + * @arg @ref LL_RCC_USB_CLKSOURCE_NONE (*) + * @arg @ref LL_RCC_USB_CLKSOURCE_PLL + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetUSBClockSource(uint32_t USBxSource) +{ + MODIFY_REG(RCC->CFGR3, RCC_CFGR3_USBSW, USBxSource); +} +#endif /* USB */ + +/** + * @brief Get USARTx clock source + * @rmtoll CFGR3 USART1SW LL_RCC_GetUSARTClockSource\n + * CFGR3 USART2SW LL_RCC_GetUSARTClockSource\n + * CFGR3 USART3SW LL_RCC_GetUSARTClockSource + * @param USARTx This parameter can be one of the following values: + * @arg @ref LL_RCC_USART1_CLKSOURCE + * @arg @ref LL_RCC_USART2_CLKSOURCE (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE (*) + * + * (*) value not defined in all devices. + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_USART1_CLKSOURCE_PCLK1 + * @arg @ref LL_RCC_USART1_CLKSOURCE_SYSCLK + * @arg @ref LL_RCC_USART1_CLKSOURCE_LSE + * @arg @ref LL_RCC_USART1_CLKSOURCE_HSI + * @arg @ref LL_RCC_USART2_CLKSOURCE_PCLK1 (*) + * @arg @ref LL_RCC_USART2_CLKSOURCE_SYSCLK (*) + * @arg @ref LL_RCC_USART2_CLKSOURCE_LSE (*) + * @arg @ref LL_RCC_USART2_CLKSOURCE_HSI (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_PCLK1 (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_SYSCLK (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_LSE (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE_HSI (*) + * + * (*) value not defined in all devices. + */ +__STATIC_INLINE uint32_t LL_RCC_GetUSARTClockSource(uint32_t USARTx) +{ + return (uint32_t)(READ_BIT(RCC->CFGR3, (RCC_CFGR3_USART1SW << USARTx)) | (USARTx << 24U)); +} + +/** + * @brief Get I2Cx clock source + * @rmtoll CFGR3 I2C1SW LL_RCC_GetI2CClockSource + * @param I2Cx This parameter can be one of the following values: + * @arg @ref LL_RCC_I2C1_CLKSOURCE + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_I2C1_CLKSOURCE_HSI + * @arg @ref LL_RCC_I2C1_CLKSOURCE_SYSCLK + */ +__STATIC_INLINE uint32_t LL_RCC_GetI2CClockSource(uint32_t I2Cx) +{ + return (uint32_t)(READ_BIT(RCC->CFGR3, I2Cx)); +} + +#if defined(CEC) +/** + * @brief Get CEC clock source + * @rmtoll CFGR3 CECSW LL_RCC_GetCECClockSource + * @param CECx This parameter can be one of the following values: + * @arg @ref LL_RCC_CEC_CLKSOURCE + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_CEC_CLKSOURCE_HSI_DIV244 + * @arg @ref LL_RCC_CEC_CLKSOURCE_LSE + */ +__STATIC_INLINE uint32_t LL_RCC_GetCECClockSource(uint32_t CECx) +{ + return (uint32_t)(READ_BIT(RCC->CFGR3, CECx)); +} +#endif /* CEC */ + +#if defined(USB) +/** + * @brief Get USBx clock source + * @rmtoll CFGR3 USBSW LL_RCC_GetUSBClockSource + * @param USBx This parameter can be one of the following values: + * @arg @ref LL_RCC_USB_CLKSOURCE + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_USB_CLKSOURCE_HSI48 (*) + * @arg @ref LL_RCC_USB_CLKSOURCE_NONE (*) + * @arg @ref LL_RCC_USB_CLKSOURCE_PLL + * + * (*) value not defined in all devices. + */ +__STATIC_INLINE uint32_t LL_RCC_GetUSBClockSource(uint32_t USBx) +{ + return (uint32_t)(READ_BIT(RCC->CFGR3, USBx)); +} +#endif /* USB */ + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_RTC RTC + * @{ + */ + +/** + * @brief Set RTC Clock Source + * @note Once the RTC clock source has been selected, it cannot be changed any more unless + * the Backup domain is reset. The BDRST bit can be used to reset them. + * @rmtoll BDCR RTCSEL LL_RCC_SetRTCClockSource + * @param Source This parameter can be one of the following values: + * @arg @ref LL_RCC_RTC_CLKSOURCE_NONE + * @arg @ref LL_RCC_RTC_CLKSOURCE_LSE + * @arg @ref LL_RCC_RTC_CLKSOURCE_LSI + * @arg @ref LL_RCC_RTC_CLKSOURCE_HSE_DIV32 + * @retval None + */ +__STATIC_INLINE void LL_RCC_SetRTCClockSource(uint32_t Source) +{ + MODIFY_REG(RCC->BDCR, RCC_BDCR_RTCSEL, Source); +} + +/** + * @brief Get RTC Clock Source + * @rmtoll BDCR RTCSEL LL_RCC_GetRTCClockSource + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_RTC_CLKSOURCE_NONE + * @arg @ref LL_RCC_RTC_CLKSOURCE_LSE + * @arg @ref LL_RCC_RTC_CLKSOURCE_LSI + * @arg @ref LL_RCC_RTC_CLKSOURCE_HSE_DIV32 + */ +__STATIC_INLINE uint32_t LL_RCC_GetRTCClockSource(void) +{ + return (uint32_t)(READ_BIT(RCC->BDCR, RCC_BDCR_RTCSEL)); +} + +/** + * @brief Enable RTC + * @rmtoll BDCR RTCEN LL_RCC_EnableRTC + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableRTC(void) +{ + SET_BIT(RCC->BDCR, RCC_BDCR_RTCEN); +} + +/** + * @brief Disable RTC + * @rmtoll BDCR RTCEN LL_RCC_DisableRTC + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableRTC(void) +{ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_RTCEN); +} + +/** + * @brief Check if RTC has been enabled or not + * @rmtoll BDCR RTCEN LL_RCC_IsEnabledRTC + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledRTC(void) +{ + return (READ_BIT(RCC->BDCR, RCC_BDCR_RTCEN) == (RCC_BDCR_RTCEN)); +} + +/** + * @brief Force the Backup domain reset + * @rmtoll BDCR BDRST LL_RCC_ForceBackupDomainReset + * @retval None + */ +__STATIC_INLINE void LL_RCC_ForceBackupDomainReset(void) +{ + SET_BIT(RCC->BDCR, RCC_BDCR_BDRST); +} + +/** + * @brief Release the Backup domain reset + * @rmtoll BDCR BDRST LL_RCC_ReleaseBackupDomainReset + * @retval None + */ +__STATIC_INLINE void LL_RCC_ReleaseBackupDomainReset(void) +{ + CLEAR_BIT(RCC->BDCR, RCC_BDCR_BDRST); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_PLL PLL + * @{ + */ + +/** + * @brief Enable PLL + * @rmtoll CR PLLON LL_RCC_PLL_Enable + * @retval None + */ +__STATIC_INLINE void LL_RCC_PLL_Enable(void) +{ + SET_BIT(RCC->CR, RCC_CR_PLLON); +} + +/** + * @brief Disable PLL + * @note Cannot be disabled if the PLL clock is used as the system clock + * @rmtoll CR PLLON LL_RCC_PLL_Disable + * @retval None + */ +__STATIC_INLINE void LL_RCC_PLL_Disable(void) +{ + CLEAR_BIT(RCC->CR, RCC_CR_PLLON); +} + +/** + * @brief Check if PLL Ready + * @rmtoll CR PLLRDY LL_RCC_PLL_IsReady + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_PLL_IsReady(void) +{ + return (READ_BIT(RCC->CR, RCC_CR_PLLRDY) == (RCC_CR_PLLRDY)); +} + +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) +/** + * @brief Configure PLL used for SYSCLK Domain + * @rmtoll CFGR PLLSRC LL_RCC_PLL_ConfigDomain_SYS\n + * CFGR PLLMUL LL_RCC_PLL_ConfigDomain_SYS\n + * CFGR2 PREDIV LL_RCC_PLL_ConfigDomain_SYS + * @param Source This parameter can be one of the following values: + * @arg @ref LL_RCC_PLLSOURCE_HSI + * @arg @ref LL_RCC_PLLSOURCE_HSE + * @arg @ref LL_RCC_PLLSOURCE_HSI48 (*) + * + * (*) value not defined in all devices + * @param PLLMul This parameter can be one of the following values: + * @arg @ref LL_RCC_PLL_MUL_2 + * @arg @ref LL_RCC_PLL_MUL_3 + * @arg @ref LL_RCC_PLL_MUL_4 + * @arg @ref LL_RCC_PLL_MUL_5 + * @arg @ref LL_RCC_PLL_MUL_6 + * @arg @ref LL_RCC_PLL_MUL_7 + * @arg @ref LL_RCC_PLL_MUL_8 + * @arg @ref LL_RCC_PLL_MUL_9 + * @arg @ref LL_RCC_PLL_MUL_10 + * @arg @ref LL_RCC_PLL_MUL_11 + * @arg @ref LL_RCC_PLL_MUL_12 + * @arg @ref LL_RCC_PLL_MUL_13 + * @arg @ref LL_RCC_PLL_MUL_14 + * @arg @ref LL_RCC_PLL_MUL_15 + * @arg @ref LL_RCC_PLL_MUL_16 + * @param PLLDiv This parameter can be one of the following values: + * @arg @ref LL_RCC_PREDIV_DIV_1 + * @arg @ref LL_RCC_PREDIV_DIV_2 + * @arg @ref LL_RCC_PREDIV_DIV_3 + * @arg @ref LL_RCC_PREDIV_DIV_4 + * @arg @ref LL_RCC_PREDIV_DIV_5 + * @arg @ref LL_RCC_PREDIV_DIV_6 + * @arg @ref LL_RCC_PREDIV_DIV_7 + * @arg @ref LL_RCC_PREDIV_DIV_8 + * @arg @ref LL_RCC_PREDIV_DIV_9 + * @arg @ref LL_RCC_PREDIV_DIV_10 + * @arg @ref LL_RCC_PREDIV_DIV_11 + * @arg @ref LL_RCC_PREDIV_DIV_12 + * @arg @ref LL_RCC_PREDIV_DIV_13 + * @arg @ref LL_RCC_PREDIV_DIV_14 + * @arg @ref LL_RCC_PREDIV_DIV_15 + * @arg @ref LL_RCC_PREDIV_DIV_16 + * @retval None + */ +__STATIC_INLINE void LL_RCC_PLL_ConfigDomain_SYS(uint32_t Source, uint32_t PLLMul, uint32_t PLLDiv) +{ + MODIFY_REG(RCC->CFGR, RCC_CFGR_PLLSRC | RCC_CFGR_PLLMUL, Source | PLLMul); + MODIFY_REG(RCC->CFGR2, RCC_CFGR2_PREDIV, PLLDiv); +} + +#else + +/** + * @brief Configure PLL used for SYSCLK Domain + * @rmtoll CFGR PLLSRC LL_RCC_PLL_ConfigDomain_SYS\n + * CFGR PLLMUL LL_RCC_PLL_ConfigDomain_SYS\n + * CFGR2 PREDIV LL_RCC_PLL_ConfigDomain_SYS + * @param Source This parameter can be one of the following values: + * @arg @ref LL_RCC_PLLSOURCE_HSI_DIV_2 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_1 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_2 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_3 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_4 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_5 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_6 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_7 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_8 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_9 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_10 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_11 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_12 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_13 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_14 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_15 + * @arg @ref LL_RCC_PLLSOURCE_HSE_DIV_16 + * @param PLLMul This parameter can be one of the following values: + * @arg @ref LL_RCC_PLL_MUL_2 + * @arg @ref LL_RCC_PLL_MUL_3 + * @arg @ref LL_RCC_PLL_MUL_4 + * @arg @ref LL_RCC_PLL_MUL_5 + * @arg @ref LL_RCC_PLL_MUL_6 + * @arg @ref LL_RCC_PLL_MUL_7 + * @arg @ref LL_RCC_PLL_MUL_8 + * @arg @ref LL_RCC_PLL_MUL_9 + * @arg @ref LL_RCC_PLL_MUL_10 + * @arg @ref LL_RCC_PLL_MUL_11 + * @arg @ref LL_RCC_PLL_MUL_12 + * @arg @ref LL_RCC_PLL_MUL_13 + * @arg @ref LL_RCC_PLL_MUL_14 + * @arg @ref LL_RCC_PLL_MUL_15 + * @arg @ref LL_RCC_PLL_MUL_16 + * @retval None + */ +__STATIC_INLINE void LL_RCC_PLL_ConfigDomain_SYS(uint32_t Source, uint32_t PLLMul) +{ + MODIFY_REG(RCC->CFGR, RCC_CFGR_PLLSRC | RCC_CFGR_PLLMUL, (Source & RCC_CFGR_PLLSRC) | PLLMul); + MODIFY_REG(RCC->CFGR2, RCC_CFGR2_PREDIV, (Source & RCC_CFGR2_PREDIV)); +} +#endif /* RCC_PLLSRC_PREDIV1_SUPPORT */ + +/** + * @brief Configure PLL clock source + * @rmtoll CFGR PLLSRC LL_RCC_PLL_SetMainSource + * @param PLLSource This parameter can be one of the following values: + * @arg @ref LL_RCC_PLLSOURCE_NONE + * @arg @ref LL_RCC_PLLSOURCE_HSI (*) + * @arg @ref LL_RCC_PLLSOURCE_HSI_DIV_2 (*) + * @arg @ref LL_RCC_PLLSOURCE_HSE + * @arg @ref LL_RCC_PLLSOURCE_HSI48 (*) + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_RCC_PLL_SetMainSource(uint32_t PLLSource) +{ + MODIFY_REG(RCC->CFGR, RCC_CFGR_PLLSRC, PLLSource); +} + +/** + * @brief Get the oscillator used as PLL clock source. + * @rmtoll CFGR PLLSRC LL_RCC_PLL_GetMainSource + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_PLLSOURCE_NONE + * @arg @ref LL_RCC_PLLSOURCE_HSI (*) + * @arg @ref LL_RCC_PLLSOURCE_HSI_DIV_2 (*) + * @arg @ref LL_RCC_PLLSOURCE_HSE + * @arg @ref LL_RCC_PLLSOURCE_HSI48 (*) + * + * (*) value not defined in all devices + */ +__STATIC_INLINE uint32_t LL_RCC_PLL_GetMainSource(void) +{ + return (uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_PLLSRC)); +} + +/** + * @brief Get PLL multiplication Factor + * @rmtoll CFGR PLLMUL LL_RCC_PLL_GetMultiplicator + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_PLL_MUL_2 + * @arg @ref LL_RCC_PLL_MUL_3 + * @arg @ref LL_RCC_PLL_MUL_4 + * @arg @ref LL_RCC_PLL_MUL_5 + * @arg @ref LL_RCC_PLL_MUL_6 + * @arg @ref LL_RCC_PLL_MUL_7 + * @arg @ref LL_RCC_PLL_MUL_8 + * @arg @ref LL_RCC_PLL_MUL_9 + * @arg @ref LL_RCC_PLL_MUL_10 + * @arg @ref LL_RCC_PLL_MUL_11 + * @arg @ref LL_RCC_PLL_MUL_12 + * @arg @ref LL_RCC_PLL_MUL_13 + * @arg @ref LL_RCC_PLL_MUL_14 + * @arg @ref LL_RCC_PLL_MUL_15 + * @arg @ref LL_RCC_PLL_MUL_16 + */ +__STATIC_INLINE uint32_t LL_RCC_PLL_GetMultiplicator(void) +{ + return (uint32_t)(READ_BIT(RCC->CFGR, RCC_CFGR_PLLMUL)); +} + +/** + * @brief Get PREDIV division factor for the main PLL + * @note They can be written only when the PLL is disabled + * @rmtoll CFGR2 PREDIV LL_RCC_PLL_GetPrediv + * @retval Returned value can be one of the following values: + * @arg @ref LL_RCC_PREDIV_DIV_1 + * @arg @ref LL_RCC_PREDIV_DIV_2 + * @arg @ref LL_RCC_PREDIV_DIV_3 + * @arg @ref LL_RCC_PREDIV_DIV_4 + * @arg @ref LL_RCC_PREDIV_DIV_5 + * @arg @ref LL_RCC_PREDIV_DIV_6 + * @arg @ref LL_RCC_PREDIV_DIV_7 + * @arg @ref LL_RCC_PREDIV_DIV_8 + * @arg @ref LL_RCC_PREDIV_DIV_9 + * @arg @ref LL_RCC_PREDIV_DIV_10 + * @arg @ref LL_RCC_PREDIV_DIV_11 + * @arg @ref LL_RCC_PREDIV_DIV_12 + * @arg @ref LL_RCC_PREDIV_DIV_13 + * @arg @ref LL_RCC_PREDIV_DIV_14 + * @arg @ref LL_RCC_PREDIV_DIV_15 + * @arg @ref LL_RCC_PREDIV_DIV_16 + */ +__STATIC_INLINE uint32_t LL_RCC_PLL_GetPrediv(void) +{ + return (uint32_t)(READ_BIT(RCC->CFGR2, RCC_CFGR2_PREDIV)); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_FLAG_Management FLAG Management + * @{ + */ + +/** + * @brief Clear LSI ready interrupt flag + * @rmtoll CIR LSIRDYC LL_RCC_ClearFlag_LSIRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_LSIRDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_LSIRDYC); +} + +/** + * @brief Clear LSE ready interrupt flag + * @rmtoll CIR LSERDYC LL_RCC_ClearFlag_LSERDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_LSERDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_LSERDYC); +} + +/** + * @brief Clear HSI ready interrupt flag + * @rmtoll CIR HSIRDYC LL_RCC_ClearFlag_HSIRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_HSIRDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSIRDYC); +} + +/** + * @brief Clear HSE ready interrupt flag + * @rmtoll CIR HSERDYC LL_RCC_ClearFlag_HSERDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_HSERDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSERDYC); +} + +/** + * @brief Clear PLL ready interrupt flag + * @rmtoll CIR PLLRDYC LL_RCC_ClearFlag_PLLRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_PLLRDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_PLLRDYC); +} + +/** + * @brief Clear HSI14 ready interrupt flag + * @rmtoll CIR HSI14RDYC LL_RCC_ClearFlag_HSI14RDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_HSI14RDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSI14RDYC); +} + +#if defined(RCC_HSI48_SUPPORT) +/** + * @brief Clear HSI48 ready interrupt flag + * @rmtoll CIR HSI48RDYC LL_RCC_ClearFlag_HSI48RDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_HSI48RDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSI48RDYC); +} +#endif /* RCC_HSI48_SUPPORT */ + +/** + * @brief Clear Clock security system interrupt flag + * @rmtoll CIR CSSC LL_RCC_ClearFlag_HSECSS + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearFlag_HSECSS(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_CSSC); +} + +/** + * @brief Check if LSI ready interrupt occurred or not + * @rmtoll CIR LSIRDYF LL_RCC_IsActiveFlag_LSIRDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_LSIRDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_LSIRDYF) == (RCC_CIR_LSIRDYF)); +} + +/** + * @brief Check if LSE ready interrupt occurred or not + * @rmtoll CIR LSERDYF LL_RCC_IsActiveFlag_LSERDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_LSERDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_LSERDYF) == (RCC_CIR_LSERDYF)); +} + +/** + * @brief Check if HSI ready interrupt occurred or not + * @rmtoll CIR HSIRDYF LL_RCC_IsActiveFlag_HSIRDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_HSIRDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSIRDYF) == (RCC_CIR_HSIRDYF)); +} + +/** + * @brief Check if HSE ready interrupt occurred or not + * @rmtoll CIR HSERDYF LL_RCC_IsActiveFlag_HSERDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_HSERDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSERDYF) == (RCC_CIR_HSERDYF)); +} + +/** + * @brief Check if PLL ready interrupt occurred or not + * @rmtoll CIR PLLRDYF LL_RCC_IsActiveFlag_PLLRDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_PLLRDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_PLLRDYF) == (RCC_CIR_PLLRDYF)); +} + +/** + * @brief Check if HSI14 ready interrupt occurred or not + * @rmtoll CIR HSI14RDYF LL_RCC_IsActiveFlag_HSI14RDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_HSI14RDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSI14RDYF) == (RCC_CIR_HSI14RDYF)); +} + +#if defined(RCC_HSI48_SUPPORT) +/** + * @brief Check if HSI48 ready interrupt occurred or not + * @rmtoll CIR HSI48RDYF LL_RCC_IsActiveFlag_HSI48RDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_HSI48RDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSI48RDYF) == (RCC_CIR_HSI48RDYF)); +} +#endif /* RCC_HSI48_SUPPORT */ + +/** + * @brief Check if Clock security system interrupt occurred or not + * @rmtoll CIR CSSF LL_RCC_IsActiveFlag_HSECSS + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_HSECSS(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_CSSF) == (RCC_CIR_CSSF)); +} + +/** + * @brief Check if RCC flag Independent Watchdog reset is set or not. + * @rmtoll CSR IWDGRSTF LL_RCC_IsActiveFlag_IWDGRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_IWDGRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_IWDGRSTF) == (RCC_CSR_IWDGRSTF)); +} + +/** + * @brief Check if RCC flag Low Power reset is set or not. + * @rmtoll CSR LPWRRSTF LL_RCC_IsActiveFlag_LPWRRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_LPWRRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_LPWRRSTF) == (RCC_CSR_LPWRRSTF)); +} + +/** + * @brief Check if RCC flag is set or not. + * @rmtoll CSR OBLRSTF LL_RCC_IsActiveFlag_OBLRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_OBLRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_OBLRSTF) == (RCC_CSR_OBLRSTF)); +} + +/** + * @brief Check if RCC flag Pin reset is set or not. + * @rmtoll CSR PINRSTF LL_RCC_IsActiveFlag_PINRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_PINRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_PINRSTF) == (RCC_CSR_PINRSTF)); +} + +/** + * @brief Check if RCC flag POR/PDR reset is set or not. + * @rmtoll CSR PORRSTF LL_RCC_IsActiveFlag_PORRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_PORRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_PORRSTF) == (RCC_CSR_PORRSTF)); +} + +/** + * @brief Check if RCC flag Software reset is set or not. + * @rmtoll CSR SFTRSTF LL_RCC_IsActiveFlag_SFTRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_SFTRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_SFTRSTF) == (RCC_CSR_SFTRSTF)); +} + +/** + * @brief Check if RCC flag Window Watchdog reset is set or not. + * @rmtoll CSR WWDGRSTF LL_RCC_IsActiveFlag_WWDGRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_WWDGRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_WWDGRSTF) == (RCC_CSR_WWDGRSTF)); +} + +#if defined(RCC_CSR_V18PWRRSTF) +/** + * @brief Check if RCC Reset flag of the 1.8 V domain is set or not. + * @rmtoll CSR V18PWRRSTF LL_RCC_IsActiveFlag_V18PWRRST + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsActiveFlag_V18PWRRST(void) +{ + return (READ_BIT(RCC->CSR, RCC_CSR_V18PWRRSTF) == (RCC_CSR_V18PWRRSTF)); +} +#endif /* RCC_CSR_V18PWRRSTF */ + +/** + * @brief Set RMVF bit to clear the reset flags. + * @rmtoll CSR RMVF LL_RCC_ClearResetFlags + * @retval None + */ +__STATIC_INLINE void LL_RCC_ClearResetFlags(void) +{ + SET_BIT(RCC->CSR, RCC_CSR_RMVF); +} + +/** + * @} + */ + +/** @defgroup RCC_LL_EF_IT_Management IT Management + * @{ + */ + +/** + * @brief Enable LSI ready interrupt + * @rmtoll CIR LSIRDYIE LL_RCC_EnableIT_LSIRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableIT_LSIRDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_LSIRDYIE); +} + +/** + * @brief Enable LSE ready interrupt + * @rmtoll CIR LSERDYIE LL_RCC_EnableIT_LSERDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableIT_LSERDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_LSERDYIE); +} + +/** + * @brief Enable HSI ready interrupt + * @rmtoll CIR HSIRDYIE LL_RCC_EnableIT_HSIRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableIT_HSIRDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSIRDYIE); +} + +/** + * @brief Enable HSE ready interrupt + * @rmtoll CIR HSERDYIE LL_RCC_EnableIT_HSERDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableIT_HSERDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSERDYIE); +} + +/** + * @brief Enable PLL ready interrupt + * @rmtoll CIR PLLRDYIE LL_RCC_EnableIT_PLLRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableIT_PLLRDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_PLLRDYIE); +} + +/** + * @brief Enable HSI14 ready interrupt + * @rmtoll CIR HSI14RDYIE LL_RCC_EnableIT_HSI14RDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableIT_HSI14RDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSI14RDYIE); +} + +#if defined(RCC_HSI48_SUPPORT) +/** + * @brief Enable HSI48 ready interrupt + * @rmtoll CIR HSI48RDYIE LL_RCC_EnableIT_HSI48RDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_EnableIT_HSI48RDY(void) +{ + SET_BIT(RCC->CIR, RCC_CIR_HSI48RDYIE); +} +#endif /* RCC_HSI48_SUPPORT */ + +/** + * @brief Disable LSI ready interrupt + * @rmtoll CIR LSIRDYIE LL_RCC_DisableIT_LSIRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableIT_LSIRDY(void) +{ + CLEAR_BIT(RCC->CIR, RCC_CIR_LSIRDYIE); +} + +/** + * @brief Disable LSE ready interrupt + * @rmtoll CIR LSERDYIE LL_RCC_DisableIT_LSERDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableIT_LSERDY(void) +{ + CLEAR_BIT(RCC->CIR, RCC_CIR_LSERDYIE); +} + +/** + * @brief Disable HSI ready interrupt + * @rmtoll CIR HSIRDYIE LL_RCC_DisableIT_HSIRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableIT_HSIRDY(void) +{ + CLEAR_BIT(RCC->CIR, RCC_CIR_HSIRDYIE); +} + +/** + * @brief Disable HSE ready interrupt + * @rmtoll CIR HSERDYIE LL_RCC_DisableIT_HSERDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableIT_HSERDY(void) +{ + CLEAR_BIT(RCC->CIR, RCC_CIR_HSERDYIE); +} + +/** + * @brief Disable PLL ready interrupt + * @rmtoll CIR PLLRDYIE LL_RCC_DisableIT_PLLRDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableIT_PLLRDY(void) +{ + CLEAR_BIT(RCC->CIR, RCC_CIR_PLLRDYIE); +} + +/** + * @brief Disable HSI14 ready interrupt + * @rmtoll CIR HSI14RDYIE LL_RCC_DisableIT_HSI14RDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableIT_HSI14RDY(void) +{ + CLEAR_BIT(RCC->CIR, RCC_CIR_HSI14RDYIE); +} + +#if defined(RCC_HSI48_SUPPORT) +/** + * @brief Disable HSI48 ready interrupt + * @rmtoll CIR HSI48RDYIE LL_RCC_DisableIT_HSI48RDY + * @retval None + */ +__STATIC_INLINE void LL_RCC_DisableIT_HSI48RDY(void) +{ + CLEAR_BIT(RCC->CIR, RCC_CIR_HSI48RDYIE); +} +#endif /* RCC_HSI48_SUPPORT */ + +/** + * @brief Checks if LSI ready interrupt source is enabled or disabled. + * @rmtoll CIR LSIRDYIE LL_RCC_IsEnabledIT_LSIRDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledIT_LSIRDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_LSIRDYIE) == (RCC_CIR_LSIRDYIE)); +} + +/** + * @brief Checks if LSE ready interrupt source is enabled or disabled. + * @rmtoll CIR LSERDYIE LL_RCC_IsEnabledIT_LSERDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledIT_LSERDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_LSERDYIE) == (RCC_CIR_LSERDYIE)); +} + +/** + * @brief Checks if HSI ready interrupt source is enabled or disabled. + * @rmtoll CIR HSIRDYIE LL_RCC_IsEnabledIT_HSIRDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledIT_HSIRDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSIRDYIE) == (RCC_CIR_HSIRDYIE)); +} + +/** + * @brief Checks if HSE ready interrupt source is enabled or disabled. + * @rmtoll CIR HSERDYIE LL_RCC_IsEnabledIT_HSERDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledIT_HSERDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSERDYIE) == (RCC_CIR_HSERDYIE)); +} + +/** + * @brief Checks if PLL ready interrupt source is enabled or disabled. + * @rmtoll CIR PLLRDYIE LL_RCC_IsEnabledIT_PLLRDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledIT_PLLRDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_PLLRDYIE) == (RCC_CIR_PLLRDYIE)); +} + +/** + * @brief Checks if HSI14 ready interrupt source is enabled or disabled. + * @rmtoll CIR HSI14RDYIE LL_RCC_IsEnabledIT_HSI14RDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledIT_HSI14RDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSI14RDYIE) == (RCC_CIR_HSI14RDYIE)); +} + +#if defined(RCC_HSI48_SUPPORT) +/** + * @brief Checks if HSI48 ready interrupt source is enabled or disabled. + * @rmtoll CIR HSI48RDYIE LL_RCC_IsEnabledIT_HSI48RDY + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RCC_IsEnabledIT_HSI48RDY(void) +{ + return (READ_BIT(RCC->CIR, RCC_CIR_HSI48RDYIE) == (RCC_CIR_HSI48RDYIE)); +} +#endif /* RCC_HSI48_SUPPORT */ + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RCC_LL_EF_Init De-initialization function + * @{ + */ +ErrorStatus LL_RCC_DeInit(void); +/** + * @} + */ + +/** @defgroup RCC_LL_EF_Get_Freq Get system and peripherals clocks frequency functions + * @{ + */ +void LL_RCC_GetSystemClocksFreq(LL_RCC_ClocksTypeDef *RCC_Clocks); +uint32_t LL_RCC_GetUSARTClockFreq(uint32_t USARTxSource); +uint32_t LL_RCC_GetI2CClockFreq(uint32_t I2CxSource); +#if defined(USB_OTG_FS) || defined(USB) +uint32_t LL_RCC_GetUSBClockFreq(uint32_t USBxSource); +#endif /* USB_OTG_FS || USB */ +#if defined(CEC) +uint32_t LL_RCC_GetCECClockFreq(uint32_t CECxSource); +#endif /* CEC */ +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* RCC */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_RCC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rtc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rtc.h new file mode 100644 index 0000000..6527075 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_rtc.h @@ -0,0 +1,3169 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_rtc.h + * @author MCD Application Team + * @brief Header file of RTC LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_RTC_H +#define __STM32F0xx_LL_RTC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(RTC) + +/** @defgroup RTC_LL RTC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup RTC_LL_Private_Constants RTC Private Constants + * @{ + */ +/* Masks Definition */ +#define RTC_INIT_MASK 0xFFFFFFFFU +#define RTC_RSF_MASK 0xFFFFFF5FU + +/* Write protection defines */ +#define RTC_WRITE_PROTECTION_DISABLE ((uint8_t)0xFFU) +#define RTC_WRITE_PROTECTION_ENABLE_1 ((uint8_t)0xCAU) +#define RTC_WRITE_PROTECTION_ENABLE_2 ((uint8_t)0x53U) + +/* Defines used to combine date & time */ +#define RTC_OFFSET_WEEKDAY 24U +#define RTC_OFFSET_DAY 16U +#define RTC_OFFSET_MONTH 8U +#define RTC_OFFSET_HOUR 16U +#define RTC_OFFSET_MINUTE 8U + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RTC_LL_Private_Macros RTC Private Macros + * @{ + */ +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RTC_LL_ES_INIT RTC Exported Init structure + * @{ + */ + +/** + * @brief RTC Init structures definition + */ +typedef struct +{ + uint32_t HourFormat; /*!< Specifies the RTC Hours Format. + This parameter can be a value of @ref RTC_LL_EC_HOURFORMAT + + This feature can be modified afterwards using unitary function + @ref LL_RTC_SetHourFormat(). */ + + uint32_t AsynchPrescaler; /*!< Specifies the RTC Asynchronous Predivider value. + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x7F + + This feature can be modified afterwards using unitary function + @ref LL_RTC_SetAsynchPrescaler(). */ + + uint32_t SynchPrescaler; /*!< Specifies the RTC Synchronous Predivider value. + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0x7FFF + + This feature can be modified afterwards using unitary function + @ref LL_RTC_SetSynchPrescaler(). */ +} LL_RTC_InitTypeDef; + +/** + * @brief RTC Time structure definition + */ +typedef struct +{ + uint32_t TimeFormat; /*!< Specifies the RTC AM/PM Time. + This parameter can be a value of @ref RTC_LL_EC_TIME_FORMAT + + This feature can be modified afterwards using unitary function @ref LL_RTC_TIME_SetFormat(). */ + + uint8_t Hours; /*!< Specifies the RTC Time Hours. + This parameter must be a number between Min_Data = 0 and Max_Data = 12 if the @ref LL_RTC_TIME_FORMAT_PM is selected. + This parameter must be a number between Min_Data = 0 and Max_Data = 23 if the @ref LL_RTC_TIME_FORMAT_AM_OR_24 is selected. + + This feature can be modified afterwards using unitary function @ref LL_RTC_TIME_SetHour(). */ + + uint8_t Minutes; /*!< Specifies the RTC Time Minutes. + This parameter must be a number between Min_Data = 0 and Max_Data = 59 + + This feature can be modified afterwards using unitary function @ref LL_RTC_TIME_SetMinute(). */ + + uint8_t Seconds; /*!< Specifies the RTC Time Seconds. + This parameter must be a number between Min_Data = 0 and Max_Data = 59 + + This feature can be modified afterwards using unitary function @ref LL_RTC_TIME_SetSecond(). */ +} LL_RTC_TimeTypeDef; + +/** + * @brief RTC Date structure definition + */ +typedef struct +{ + uint8_t WeekDay; /*!< Specifies the RTC Date WeekDay. + This parameter can be a value of @ref RTC_LL_EC_WEEKDAY + + This feature can be modified afterwards using unitary function @ref LL_RTC_DATE_SetWeekDay(). */ + + uint8_t Month; /*!< Specifies the RTC Date Month. + This parameter can be a value of @ref RTC_LL_EC_MONTH + + This feature can be modified afterwards using unitary function @ref LL_RTC_DATE_SetMonth(). */ + + uint8_t Day; /*!< Specifies the RTC Date Day. + This parameter must be a number between Min_Data = 1 and Max_Data = 31 + + This feature can be modified afterwards using unitary function @ref LL_RTC_DATE_SetDay(). */ + + uint8_t Year; /*!< Specifies the RTC Date Year. + This parameter must be a number between Min_Data = 0 and Max_Data = 99 + + This feature can be modified afterwards using unitary function @ref LL_RTC_DATE_SetYear(). */ +} LL_RTC_DateTypeDef; + +/** + * @brief RTC Alarm structure definition + */ +typedef struct +{ + LL_RTC_TimeTypeDef AlarmTime; /*!< Specifies the RTC Alarm Time members. */ + + uint32_t AlarmMask; /*!< Specifies the RTC Alarm Masks. + + This parameter can be a value of @ref RTC_LL_EC_ALMA_MASK + This feature can be modified afterwards using unitary function @ref LL_RTC_ALMA_SetMask() for ALARM A. + */ + + uint32_t AlarmDateWeekDaySel; /*!< Specifies the RTC Alarm is on day or WeekDay. + This parameter can be a value of @ref RTC_LL_EC_ALMA_WEEKDAY_SELECTION + + This feature can be modified afterwards using unitary function @ref LL_RTC_ALMA_EnableWeekday() or @ref LL_RTC_ALMA_DisableWeekday() + */ + + uint8_t AlarmDateWeekDay; /*!< Specifies the RTC Alarm Day/WeekDay. + If AlarmDateWeekDaySel set to day, this parameter must be a number between Min_Data = 1 and Max_Data = 31. + + This feature can be modified afterwards using unitary function @ref LL_RTC_ALMA_SetDay() + + If AlarmDateWeekDaySel set to Weekday, this parameter can be a value of @ref RTC_LL_EC_WEEKDAY. + + This feature can be modified afterwards using unitary function @ref LL_RTC_ALMA_SetWeekDay() + */ +} LL_RTC_AlarmTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup RTC_LL_Exported_Constants RTC Exported Constants + * @{ + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RTC_LL_EC_FORMAT FORMAT + * @{ + */ +#define LL_RTC_FORMAT_BIN 0x000000000U /*!< Binary data format */ +#define LL_RTC_FORMAT_BCD 0x000000001U /*!< BCD data format */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_ALMA_WEEKDAY_SELECTION RTC Alarm A Date WeekDay + * @{ + */ +#define LL_RTC_ALMA_DATEWEEKDAYSEL_DATE 0x00000000U /*!< Alarm A Date is selected */ +#define LL_RTC_ALMA_DATEWEEKDAYSEL_WEEKDAY RTC_ALRMAR_WDSEL /*!< Alarm A WeekDay is selected */ +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/** @defgroup RTC_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_RTC_ReadReg function + * @{ + */ +#define LL_RTC_ISR_RECALPF RTC_ISR_RECALPF +#define LL_RTC_ISR_TAMP3F RTC_ISR_TAMP3F +#define LL_RTC_ISR_TAMP2F RTC_ISR_TAMP2F +#define LL_RTC_ISR_TAMP1F RTC_ISR_TAMP1F +#define LL_RTC_ISR_TSOVF RTC_ISR_TSOVF +#define LL_RTC_ISR_TSF RTC_ISR_TSF +#define LL_RTC_ISR_WUTF RTC_ISR_WUTF +#define LL_RTC_ISR_ALRAF RTC_ISR_ALRAF +#define LL_RTC_ISR_INITF RTC_ISR_INITF +#define LL_RTC_ISR_RSF RTC_ISR_RSF +#define LL_RTC_ISR_INITS RTC_ISR_INITS +#define LL_RTC_ISR_SHPF RTC_ISR_SHPF +#define LL_RTC_ISR_WUTWF RTC_ISR_WUTWF +#define LL_RTC_ISR_ALRAWF RTC_ISR_ALRAWF +/** + * @} + */ + +/** @defgroup RTC_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_RTC_ReadReg and LL_RTC_WriteReg functions + * @{ + */ +#define LL_RTC_CR_TSIE RTC_CR_TSIE +#define LL_RTC_CR_WUTIE RTC_CR_WUTIE +#define LL_RTC_CR_ALRAIE RTC_CR_ALRAIE +#define LL_RTC_TAFCR_TAMPIE RTC_TAFCR_TAMPIE +/** + * @} + */ + +/** @defgroup RTC_LL_EC_WEEKDAY WEEK DAY + * @{ + */ +#define LL_RTC_WEEKDAY_MONDAY ((uint8_t)0x01U) /*!< Monday */ +#define LL_RTC_WEEKDAY_TUESDAY ((uint8_t)0x02U) /*!< Tuesday */ +#define LL_RTC_WEEKDAY_WEDNESDAY ((uint8_t)0x03U) /*!< Wednesday */ +#define LL_RTC_WEEKDAY_THURSDAY ((uint8_t)0x04U) /*!< Thrusday */ +#define LL_RTC_WEEKDAY_FRIDAY ((uint8_t)0x05U) /*!< Friday */ +#define LL_RTC_WEEKDAY_SATURDAY ((uint8_t)0x06U) /*!< Saturday */ +#define LL_RTC_WEEKDAY_SUNDAY ((uint8_t)0x07U) /*!< Sunday */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_MONTH MONTH + * @{ + */ +#define LL_RTC_MONTH_JANUARY ((uint8_t)0x01U) /*!< January */ +#define LL_RTC_MONTH_FEBRUARY ((uint8_t)0x02U) /*!< February */ +#define LL_RTC_MONTH_MARCH ((uint8_t)0x03U) /*!< March */ +#define LL_RTC_MONTH_APRIL ((uint8_t)0x04U) /*!< April */ +#define LL_RTC_MONTH_MAY ((uint8_t)0x05U) /*!< May */ +#define LL_RTC_MONTH_JUNE ((uint8_t)0x06U) /*!< June */ +#define LL_RTC_MONTH_JULY ((uint8_t)0x07U) /*!< July */ +#define LL_RTC_MONTH_AUGUST ((uint8_t)0x08U) /*!< August */ +#define LL_RTC_MONTH_SEPTEMBER ((uint8_t)0x09U) /*!< September */ +#define LL_RTC_MONTH_OCTOBER ((uint8_t)0x10U) /*!< October */ +#define LL_RTC_MONTH_NOVEMBER ((uint8_t)0x11U) /*!< November */ +#define LL_RTC_MONTH_DECEMBER ((uint8_t)0x12U) /*!< December */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_HOURFORMAT HOUR FORMAT + * @{ + */ +#define LL_RTC_HOURFORMAT_24HOUR 0x00000000U /*!< 24 hour/day format */ +#define LL_RTC_HOURFORMAT_AMPM RTC_CR_FMT /*!< AM/PM hour format */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_ALARMOUT ALARM OUTPUT + * @{ + */ +#define LL_RTC_ALARMOUT_DISABLE 0x00000000U /*!< Output disabled */ +#define LL_RTC_ALARMOUT_ALMA RTC_CR_OSEL_0 /*!< Alarm A output enabled */ +#define LL_RTC_ALARMOUT_ALMB RTC_CR_OSEL_1 /*!< Alarm B output enabled */ +#define LL_RTC_ALARMOUT_WAKEUP RTC_CR_OSEL /*!< Wakeup output enabled */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_ALARM_OUTPUTTYPE ALARM OUTPUT TYPE + * @{ + */ +#define LL_RTC_ALARM_OUTPUTTYPE_OPENDRAIN 0x00000000U /*!< RTC_ALARM, when mapped on PC13, is open-drain output */ +#define LL_RTC_ALARM_OUTPUTTYPE_PUSHPULL RTC_TAFCR_ALARMOUTTYPE /*!< RTC_ALARM, when mapped on PC13, is push-pull output */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_PIN PIN + * @{ + */ +#define LL_RTC_PIN_PC13 RTC_TAFCR_PC13MODE /*!< PC13 is forced to push-pull output if all RTC alternate functions are disabled */ +#define LL_RTC_PIN_PC14 RTC_TAFCR_PC14MODE /*!< PC14 is forced to push-pull output if LSE is disabled */ +#define LL_RTC_PIN_PC15 RTC_TAFCR_PC15MODE /*!< PC15 is forced to push-pull output if LSE is disabled */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_OUTPUTPOLARITY_PIN OUTPUT POLARITY PIN + * @{ + */ +#define LL_RTC_OUTPUTPOLARITY_PIN_HIGH 0x00000000U /*!< Pin is high when ALRAF/ALRBF/WUTF is asserted (depending on OSEL)*/ +#define LL_RTC_OUTPUTPOLARITY_PIN_LOW RTC_CR_POL /*!< Pin is low when ALRAF/ALRBF/WUTF is asserted (depending on OSEL) */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_TIME_FORMAT TIME FORMAT + * @{ + */ +#define LL_RTC_TIME_FORMAT_AM_OR_24 0x00000000U /*!< AM or 24-hour format */ +#define LL_RTC_TIME_FORMAT_PM RTC_TR_PM /*!< PM */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_SHIFT_SECOND SHIFT SECOND + * @{ + */ +#define LL_RTC_SHIFT_SECOND_DELAY 0x00000000U /* Delay (seconds) = SUBFS / (PREDIV_S + 1) */ +#define LL_RTC_SHIFT_SECOND_ADVANCE RTC_SHIFTR_ADD1S /* Advance (seconds) = (1 - (SUBFS / (PREDIV_S + 1))) */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_ALMA_MASK ALARMA MASK + * @{ + */ +#define LL_RTC_ALMA_MASK_NONE 0x00000000U /*!< No masks applied on Alarm A*/ +#define LL_RTC_ALMA_MASK_DATEWEEKDAY RTC_ALRMAR_MSK4 /*!< Date/day do not care in Alarm A comparison */ +#define LL_RTC_ALMA_MASK_HOURS RTC_ALRMAR_MSK3 /*!< Hours do not care in Alarm A comparison */ +#define LL_RTC_ALMA_MASK_MINUTES RTC_ALRMAR_MSK2 /*!< Minutes do not care in Alarm A comparison */ +#define LL_RTC_ALMA_MASK_SECONDS RTC_ALRMAR_MSK1 /*!< Seconds do not care in Alarm A comparison */ +#define LL_RTC_ALMA_MASK_ALL (RTC_ALRMAR_MSK4 | RTC_ALRMAR_MSK3 | RTC_ALRMAR_MSK2 | RTC_ALRMAR_MSK1) /*!< Masks all */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_ALMA_TIME_FORMAT ALARMA TIME FORMAT + * @{ + */ +#define LL_RTC_ALMA_TIME_FORMAT_AM 0x00000000U /*!< AM or 24-hour format */ +#define LL_RTC_ALMA_TIME_FORMAT_PM RTC_ALRMAR_PM /*!< PM */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_TIMESTAMP_EDGE TIMESTAMP EDGE + * @{ + */ +#define LL_RTC_TIMESTAMP_EDGE_RISING 0x00000000U /*!< RTC_TS input rising edge generates a time-stamp event */ +#define LL_RTC_TIMESTAMP_EDGE_FALLING RTC_CR_TSEDGE /*!< RTC_TS input falling edge generates a time-stamp even */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_TS_TIME_FORMAT TIMESTAMP TIME FORMAT + * @{ + */ +#define LL_RTC_TS_TIME_FORMAT_AM 0x00000000U /*!< AM or 24-hour format */ +#define LL_RTC_TS_TIME_FORMAT_PM RTC_TSTR_PM /*!< PM */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_TAMPER TAMPER + * @{ + */ +#if defined(RTC_TAMPER1_SUPPORT) +#define LL_RTC_TAMPER_1 RTC_TAFCR_TAMP1E /*!< RTC_TAMP1 input detection */ +#endif /* RTC_TAMPER1_SUPPORT */ +#if defined(RTC_TAMPER2_SUPPORT) +#define LL_RTC_TAMPER_2 RTC_TAFCR_TAMP2E /*!< RTC_TAMP2 input detection */ +#endif /* RTC_TAMPER2_SUPPORT */ +#if defined(RTC_TAMPER3_SUPPORT) +#define LL_RTC_TAMPER_3 RTC_TAFCR_TAMP3E /*!< RTC_TAMP3 input detection */ +#endif /* RTC_TAMPER3_SUPPORT */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_TAMPER_MASK TAMPER MASK + * @{ + */ +#if defined(RTC_TAMPER1_SUPPORT) +#define LL_RTC_TAMPER_MASK_TAMPER1 RTC_TAFCR_TAMP1MF /*!< Tamper 1 event generates a trigger event. TAMP1F is masked and internally cleared by hardware.The backup registers are not erased */ +#endif /* RTC_TAMPER1_SUPPORT */ +#if defined(RTC_TAMPER2_SUPPORT) +#define LL_RTC_TAMPER_MASK_TAMPER2 RTC_TAFCR_TAMP2MF /*!< Tamper 2 event generates a trigger event. TAMP2F is masked and internally cleared by hardware. The backup registers are not erased. */ +#endif /* RTC_TAMPER2_SUPPORT */ +#if defined(RTC_TAMPER3_SUPPORT) +#define LL_RTC_TAMPER_MASK_TAMPER3 RTC_TAFCR_TAMP3MF /*!< Tamper 3 event generates a trigger event. TAMP3F is masked and internally cleared by hardware. The backup registers are not erased */ +#endif /* RTC_TAMPER3_SUPPORT */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_TAMPER_NOERASE TAMPER NO ERASE + * @{ + */ +#if defined(RTC_TAMPER1_SUPPORT) +#define LL_RTC_TAMPER_NOERASE_TAMPER1 RTC_TAFCR_TAMP1NOERASE /*!< Tamper 1 event does not erase the backup registers. */ +#endif /* RTC_TAMPER1_SUPPORT */ +#if defined(RTC_TAMPER2_SUPPORT) +#define LL_RTC_TAMPER_NOERASE_TAMPER2 RTC_TAFCR_TAMP2NOERASE /*!< Tamper 2 event does not erase the backup registers. */ +#endif /* RTC_TAMPER2_SUPPORT */ +#if defined(RTC_TAMPER3_SUPPORT) +#define LL_RTC_TAMPER_NOERASE_TAMPER3 RTC_TAFCR_TAMP3NOERASE /*!< Tamper 3 event does not erase the backup registers. */ +#endif /* RTC_TAMPER3_SUPPORT */ +/** + * @} + */ + +#if defined(RTC_TAFCR_TAMPPRCH) +/** @defgroup RTC_LL_EC_TAMPER_DURATION TAMPER DURATION + * @{ + */ +#define LL_RTC_TAMPER_DURATION_1RTCCLK 0x00000000U /*!< Tamper pins are pre-charged before sampling during 1 RTCCLK cycle */ +#define LL_RTC_TAMPER_DURATION_2RTCCLK RTC_TAFCR_TAMPPRCH_0 /*!< Tamper pins are pre-charged before sampling during 2 RTCCLK cycles */ +#define LL_RTC_TAMPER_DURATION_4RTCCLK RTC_TAFCR_TAMPPRCH_1 /*!< Tamper pins are pre-charged before sampling during 4 RTCCLK cycles */ +#define LL_RTC_TAMPER_DURATION_8RTCCLK RTC_TAFCR_TAMPPRCH /*!< Tamper pins are pre-charged before sampling during 8 RTCCLK cycles */ +/** + * @} + */ +#endif /* RTC_TAFCR_TAMPPRCH */ + +#if defined(RTC_TAFCR_TAMPFLT) +/** @defgroup RTC_LL_EC_TAMPER_FILTER TAMPER FILTER + * @{ + */ +#define LL_RTC_TAMPER_FILTER_DISABLE 0x00000000U /*!< Tamper filter is disabled */ +#define LL_RTC_TAMPER_FILTER_2SAMPLE RTC_TAFCR_TAMPFLT_0 /*!< Tamper is activated after 2 consecutive samples at the active level */ +#define LL_RTC_TAMPER_FILTER_4SAMPLE RTC_TAFCR_TAMPFLT_1 /*!< Tamper is activated after 4 consecutive samples at the active level */ +#define LL_RTC_TAMPER_FILTER_8SAMPLE RTC_TAFCR_TAMPFLT /*!< Tamper is activated after 8 consecutive samples at the active level. */ +/** + * @} + */ +#endif /* RTC_TAFCR_TAMPFLT */ + +#if defined(RTC_TAFCR_TAMPFREQ) +/** @defgroup RTC_LL_EC_TAMPER_SAMPLFREQDIV TAMPER SAMPLING FREQUENCY DIVIDER + * @{ + */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_32768 0x00000000U /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 32768 */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_16384 RTC_TAFCR_TAMPFREQ_0 /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 16384 */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_8192 RTC_TAFCR_TAMPFREQ_1 /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 8192 */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_4096 (RTC_TAFCR_TAMPFREQ_1 | RTC_TAFCR_TAMPFREQ_0) /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 4096 */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_2048 RTC_TAFCR_TAMPFREQ_2 /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 2048 */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_1024 (RTC_TAFCR_TAMPFREQ_2 | RTC_TAFCR_TAMPFREQ_0) /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 1024 */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_512 (RTC_TAFCR_TAMPFREQ_2 | RTC_TAFCR_TAMPFREQ_1) /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 512 */ +#define LL_RTC_TAMPER_SAMPLFREQDIV_256 RTC_TAFCR_TAMPFREQ /*!< Each of the tamper inputs are sampled with a frequency = RTCCLK / 256 */ +/** + * @} + */ +#endif /* RTC_TAFCR_TAMPFREQ */ + +/** @defgroup RTC_LL_EC_TAMPER_ACTIVELEVEL TAMPER ACTIVE LEVEL + * @{ + */ +#if defined(RTC_TAMPER1_SUPPORT) +#define LL_RTC_TAMPER_ACTIVELEVEL_TAMP1 RTC_TAFCR_TAMP1TRG /*!< RTC_TAMP1 input falling edge (if TAMPFLT = 00) or staying high (if TAMPFLT != 00) triggers a tamper detection event*/ +#endif /* RTC_TAMPER1_SUPPORT */ +#if defined(RTC_TAMPER2_SUPPORT) +#define LL_RTC_TAMPER_ACTIVELEVEL_TAMP2 RTC_TAFCR_TAMP2TRG /*!< RTC_TAMP2 input falling edge (if TAMPFLT = 00) or staying high (if TAMPFLT != 00) triggers a tamper detection event*/ +#endif /* RTC_TAMPER2_SUPPORT */ +#if defined(RTC_TAMPER3_SUPPORT) +#define LL_RTC_TAMPER_ACTIVELEVEL_TAMP3 RTC_TAFCR_TAMP3TRG /*!< RTC_TAMP3 input falling edge (if TAMPFLT = 00) or staying high (if TAMPFLT != 00) triggers a tamper detection event*/ +#endif /* RTC_TAMPER3_SUPPORT */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_WAKEUPCLOCK_DIV WAKEUP CLOCK DIV + * @{ + */ +#define LL_RTC_WAKEUPCLOCK_DIV_16 0x00000000U /*!< RTC/16 clock is selected */ +#define LL_RTC_WAKEUPCLOCK_DIV_8 (RTC_CR_WUCKSEL_0) /*!< RTC/8 clock is selected */ +#define LL_RTC_WAKEUPCLOCK_DIV_4 (RTC_CR_WUCKSEL_1) /*!< RTC/4 clock is selected */ +#define LL_RTC_WAKEUPCLOCK_DIV_2 (RTC_CR_WUCKSEL_1 | RTC_CR_WUCKSEL_0) /*!< RTC/2 clock is selected */ +#define LL_RTC_WAKEUPCLOCK_CKSPRE (RTC_CR_WUCKSEL_2) /*!< ck_spre (usually 1 Hz) clock is selected */ +#define LL_RTC_WAKEUPCLOCK_CKSPRE_WUT (RTC_CR_WUCKSEL_2 | RTC_CR_WUCKSEL_1) /*!< ck_spre (usually 1 Hz) clock is selected and 2exp16 is added to the WUT counter value*/ +/** + * @} + */ + +#if defined(RTC_BACKUP_SUPPORT) +/** @defgroup RTC_LL_EC_BKP BACKUP + * @{ + */ +#define LL_RTC_BKP_DR0 0x00000000U +#define LL_RTC_BKP_DR1 0x00000001U +#define LL_RTC_BKP_DR2 0x00000002U +#define LL_RTC_BKP_DR3 0x00000003U +#define LL_RTC_BKP_DR4 0x00000004U +/** + * @} + */ +#endif /* RTC_BACKUP_SUPPORT */ + +/** @defgroup RTC_LL_EC_CALIB_OUTPUT Calibration output + * @{ + */ +#define LL_RTC_CALIB_OUTPUT_NONE 0x00000000U /*!< Calibration output disabled */ +#define LL_RTC_CALIB_OUTPUT_1HZ (RTC_CR_COE | RTC_CR_COSEL) /*!< Calibration output is 1 Hz */ +#define LL_RTC_CALIB_OUTPUT_512HZ (RTC_CR_COE) /*!< Calibration output is 512 Hz */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_CALIB_INSERTPULSE Calibration pulse insertion + * @{ + */ +#define LL_RTC_CALIB_INSERTPULSE_NONE 0x00000000U /*!< No RTCCLK pulses are added */ +#define LL_RTC_CALIB_INSERTPULSE_SET RTC_CALR_CALP /*!< One RTCCLK pulse is effectively inserted every 2exp11 pulses (frequency increased by 488.5 ppm) */ +/** + * @} + */ + +/** @defgroup RTC_LL_EC_CALIB_PERIOD Calibration period + * @{ + */ +#define LL_RTC_CALIB_PERIOD_32SEC 0x00000000U /*!< Use a 32-second calibration cycle period */ +#define LL_RTC_CALIB_PERIOD_16SEC RTC_CALR_CALW16 /*!< Use a 16-second calibration cycle period */ +#define LL_RTC_CALIB_PERIOD_8SEC RTC_CALR_CALW8 /*!< Use a 8-second calibration cycle period */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup RTC_LL_Exported_Macros RTC Exported Macros + * @{ + */ + +/** @defgroup RTC_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in RTC register + * @param __INSTANCE__ RTC Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_RTC_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in RTC register + * @param __INSTANCE__ RTC Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_RTC_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** @defgroup RTC_LL_EM_Convert Convert helper Macros + * @{ + */ + +/** + * @brief Helper macro to convert a value from 2 digit decimal format to BCD format + * @param __VALUE__ Byte to be converted + * @retval Converted byte + */ +#define __LL_RTC_CONVERT_BIN2BCD(__VALUE__) (uint8_t)((((__VALUE__) / 10U) << 4U) | ((__VALUE__) % 10U)) + +/** + * @brief Helper macro to convert a value from BCD format to 2 digit decimal format + * @param __VALUE__ BCD value to be converted + * @retval Converted byte + */ +#define __LL_RTC_CONVERT_BCD2BIN(__VALUE__) (uint8_t)(((uint8_t)((__VALUE__) & (uint8_t)0xF0U) >> (uint8_t)0x4U) * 10U + ((__VALUE__) & (uint8_t)0x0FU)) + +/** + * @} + */ + +/** @defgroup RTC_LL_EM_Date Date helper Macros + * @{ + */ + +/** + * @brief Helper macro to retrieve weekday. + * @param __RTC_DATE__ Date returned by @ref LL_RTC_DATE_Get function. + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_WEEKDAY_MONDAY + * @arg @ref LL_RTC_WEEKDAY_TUESDAY + * @arg @ref LL_RTC_WEEKDAY_WEDNESDAY + * @arg @ref LL_RTC_WEEKDAY_THURSDAY + * @arg @ref LL_RTC_WEEKDAY_FRIDAY + * @arg @ref LL_RTC_WEEKDAY_SATURDAY + * @arg @ref LL_RTC_WEEKDAY_SUNDAY + */ +#define __LL_RTC_GET_WEEKDAY(__RTC_DATE__) (((__RTC_DATE__) >> RTC_OFFSET_WEEKDAY) & 0x000000FFU) + +/** + * @brief Helper macro to retrieve Year in BCD format + * @param __RTC_DATE__ Value returned by @ref LL_RTC_DATE_Get + * @retval Year in BCD format (0x00 . . . 0x99) + */ +#define __LL_RTC_GET_YEAR(__RTC_DATE__) ((__RTC_DATE__) & 0x000000FFU) + +/** + * @brief Helper macro to retrieve Month in BCD format + * @param __RTC_DATE__ Value returned by @ref LL_RTC_DATE_Get + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_MONTH_JANUARY + * @arg @ref LL_RTC_MONTH_FEBRUARY + * @arg @ref LL_RTC_MONTH_MARCH + * @arg @ref LL_RTC_MONTH_APRIL + * @arg @ref LL_RTC_MONTH_MAY + * @arg @ref LL_RTC_MONTH_JUNE + * @arg @ref LL_RTC_MONTH_JULY + * @arg @ref LL_RTC_MONTH_AUGUST + * @arg @ref LL_RTC_MONTH_SEPTEMBER + * @arg @ref LL_RTC_MONTH_OCTOBER + * @arg @ref LL_RTC_MONTH_NOVEMBER + * @arg @ref LL_RTC_MONTH_DECEMBER + */ +#define __LL_RTC_GET_MONTH(__RTC_DATE__) (((__RTC_DATE__) >>RTC_OFFSET_MONTH) & 0x000000FFU) + +/** + * @brief Helper macro to retrieve Day in BCD format + * @param __RTC_DATE__ Value returned by @ref LL_RTC_DATE_Get + * @retval Day in BCD format (0x01 . . . 0x31) + */ +#define __LL_RTC_GET_DAY(__RTC_DATE__) (((__RTC_DATE__) >>RTC_OFFSET_DAY) & 0x000000FFU) + +/** + * @} + */ + +/** @defgroup RTC_LL_EM_Time Time helper Macros + * @{ + */ + +/** + * @brief Helper macro to retrieve hour in BCD format + * @param __RTC_TIME__ RTC time returned by @ref LL_RTC_TIME_Get function + * @retval Hours in BCD format (0x01. . .0x12 or between Min_Data=0x00 and Max_Data=0x23) + */ +#define __LL_RTC_GET_HOUR(__RTC_TIME__) (((__RTC_TIME__) >> RTC_OFFSET_HOUR) & 0x000000FFU) + +/** + * @brief Helper macro to retrieve minute in BCD format + * @param __RTC_TIME__ RTC time returned by @ref LL_RTC_TIME_Get function + * @retval Minutes in BCD format (0x00. . .0x59) + */ +#define __LL_RTC_GET_MINUTE(__RTC_TIME__) (((__RTC_TIME__) >> RTC_OFFSET_MINUTE) & 0x000000FFU) + +/** + * @brief Helper macro to retrieve second in BCD format + * @param __RTC_TIME__ RTC time returned by @ref LL_RTC_TIME_Get function + * @retval Seconds in format (0x00. . .0x59) + */ +#define __LL_RTC_GET_SECOND(__RTC_TIME__) ((__RTC_TIME__) & 0x000000FFU) + +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup RTC_LL_Exported_Functions RTC Exported Functions + * @{ + */ + +/** @defgroup RTC_LL_EF_Configuration Configuration + * @{ + */ + +/** + * @brief Set Hours format (24 hour/day or AM/PM hour format) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @rmtoll CR FMT LL_RTC_SetHourFormat + * @param RTCx RTC Instance + * @param HourFormat This parameter can be one of the following values: + * @arg @ref LL_RTC_HOURFORMAT_24HOUR + * @arg @ref LL_RTC_HOURFORMAT_AMPM + * @retval None + */ +__STATIC_INLINE void LL_RTC_SetHourFormat(RTC_TypeDef *RTCx, uint32_t HourFormat) +{ + MODIFY_REG(RTCx->CR, RTC_CR_FMT, HourFormat); +} + +/** + * @brief Get Hours format (24 hour/day or AM/PM hour format) + * @rmtoll CR FMT LL_RTC_GetHourFormat + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_HOURFORMAT_24HOUR + * @arg @ref LL_RTC_HOURFORMAT_AMPM + */ +__STATIC_INLINE uint32_t LL_RTC_GetHourFormat(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CR, RTC_CR_FMT)); +} + +/** + * @brief Select the flag to be routed to RTC_ALARM output + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR OSEL LL_RTC_SetAlarmOutEvent + * @param RTCx RTC Instance + * @param AlarmOutput This parameter can be one of the following values: + * @arg @ref LL_RTC_ALARMOUT_DISABLE + * @arg @ref LL_RTC_ALARMOUT_ALMA + * @arg @ref LL_RTC_ALARMOUT_ALMB + * @arg @ref LL_RTC_ALARMOUT_WAKEUP + * @retval None + */ +__STATIC_INLINE void LL_RTC_SetAlarmOutEvent(RTC_TypeDef *RTCx, uint32_t AlarmOutput) +{ + MODIFY_REG(RTCx->CR, RTC_CR_OSEL, AlarmOutput); +} + +/** + * @brief Get the flag to be routed to RTC_ALARM output + * @rmtoll CR OSEL LL_RTC_GetAlarmOutEvent + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_ALARMOUT_DISABLE + * @arg @ref LL_RTC_ALARMOUT_ALMA + * @arg @ref LL_RTC_ALARMOUT_ALMB + * @arg @ref LL_RTC_ALARMOUT_WAKEUP + */ +__STATIC_INLINE uint32_t LL_RTC_GetAlarmOutEvent(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CR, RTC_CR_OSEL)); +} + +/** + * @brief Set RTC_ALARM output type (ALARM in push-pull or open-drain output) + * @note Used only when RTC_ALARM is mapped on PC13 + * @note If all RTC alternate functions are disabled and PC13MODE = 1, PC13VALUE configures the + * PC13 output data + * @rmtoll TAFCR ALARMOUTTYPE LL_RTC_SetAlarmOutputType + * @param RTCx RTC Instance + * @param Output This parameter can be one of the following values: + * @arg @ref LL_RTC_ALARM_OUTPUTTYPE_OPENDRAIN + * @arg @ref LL_RTC_ALARM_OUTPUTTYPE_PUSHPULL + * @retval None + */ +__STATIC_INLINE void LL_RTC_SetAlarmOutputType(RTC_TypeDef *RTCx, uint32_t Output) +{ + MODIFY_REG(RTCx->TAFCR, RTC_TAFCR_ALARMOUTTYPE, Output); +} + +/** + * @brief Get RTC_ALARM output type (ALARM in push-pull or open-drain output) + * @note used only when RTC_ALARM is mapped on PC13 + * @note If all RTC alternate functions are disabled and PC13MODE = 1, PC13VALUE configures the + * PC13 output data + * @rmtoll TAFCR ALARMOUTTYPE LL_RTC_GetAlarmOutputType + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_ALARM_OUTPUTTYPE_OPENDRAIN + * @arg @ref LL_RTC_ALARM_OUTPUTTYPE_PUSHPULL + */ +__STATIC_INLINE uint32_t LL_RTC_GetAlarmOutputType(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TAFCR, RTC_TAFCR_ALARMOUTTYPE)); +} + +/** + * @brief Enable push-pull output on PC13, PC14 and/or PC15 + * @note PC13 forced to push-pull output if all RTC alternate functions are disabled + * @note PC14 and PC15 forced to push-pull output if LSE is disabled + * @rmtoll TAFCR PC13MODE LL_RTC_EnablePushPullMode\n + * @rmtoll TAFCR PC14MODE LL_RTC_EnablePushPullMode\n + * @rmtoll TAFCR PC15MODE LL_RTC_EnablePushPullMode + * @param RTCx RTC Instance + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_RTC_PIN_PC13 + * @arg @ref LL_RTC_PIN_PC14 + * @arg @ref LL_RTC_PIN_PC15 + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnablePushPullMode(RTC_TypeDef *RTCx, uint32_t PinMask) +{ + SET_BIT(RTCx->TAFCR, PinMask); +} + +/** + * @brief Disable push-pull output on PC13, PC14 and/or PC15 + * @note PC13, PC14 and/or PC15 are controlled by the GPIO configuration registers. + * Consequently PC13, PC14 and/or PC15 are floating in Standby mode. + * @rmtoll TAFCR PC13MODE LL_RTC_DisablePushPullMode\n + * TAFCR PC14MODE LL_RTC_DisablePushPullMode\n + * TAFCR PC15MODE LL_RTC_DisablePushPullMode + * @param RTCx RTC Instance + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_RTC_PIN_PC13 + * @arg @ref LL_RTC_PIN_PC14 + * @arg @ref LL_RTC_PIN_PC15 + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisablePushPullMode(RTC_TypeDef *RTCx, uint32_t PinMask) +{ + CLEAR_BIT(RTCx->TAFCR, PinMask); +} + +/** + * @brief Set PC14 and/or PC15 to high level. + * @note Output data configuration is possible if the LSE is disabled and PushPull output is enabled (through @ref LL_RTC_EnablePushPullMode) + * @rmtoll TAFCR PC14VALUE LL_RTC_SetOutputPin\n + * TAFCR PC15VALUE LL_RTC_SetOutputPin + * @param RTCx RTC Instance + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_RTC_PIN_PC14 + * @arg @ref LL_RTC_PIN_PC15 + * @retval None + */ +__STATIC_INLINE void LL_RTC_SetOutputPin(RTC_TypeDef *RTCx, uint32_t PinMask) +{ + SET_BIT(RTCx->TAFCR, (PinMask >> 1)); +} + +/** + * @brief Set PC14 and/or PC15 to low level. + * @note Output data configuration is possible if the LSE is disabled and PushPull output is enabled (through @ref LL_RTC_EnablePushPullMode) + * @rmtoll TAFCR PC14VALUE LL_RTC_ResetOutputPin\n + * TAFCR PC15VALUE LL_RTC_ResetOutputPin + * @param RTCx RTC Instance + * @param PinMask This parameter can be a combination of the following values: + * @arg @ref LL_RTC_PIN_PC14 + * @arg @ref LL_RTC_PIN_PC15 + * @retval None + */ +__STATIC_INLINE void LL_RTC_ResetOutputPin(RTC_TypeDef *RTCx, uint32_t PinMask) +{ + CLEAR_BIT(RTCx->TAFCR, (PinMask >> 1)); +} + +/** + * @brief Enable initialization mode + * @note Initialization mode is used to program time and date register (RTC_TR and RTC_DR) + * and prescaler register (RTC_PRER). + * Counters are stopped and start counting from the new value when INIT is reset. + * @rmtoll ISR INIT LL_RTC_EnableInitMode + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableInitMode(RTC_TypeDef *RTCx) +{ + /* Set the Initialization mode */ + WRITE_REG(RTCx->ISR, RTC_INIT_MASK); +} + +/** + * @brief Disable initialization mode (Free running mode) + * @rmtoll ISR INIT LL_RTC_DisableInitMode + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableInitMode(RTC_TypeDef *RTCx) +{ + /* Exit Initialization mode */ + WRITE_REG(RTCx->ISR, (uint32_t)~RTC_ISR_INIT); +} + +/** + * @brief Set Output polarity (pin is low when ALRAF/ALRBF/WUTF is asserted) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR POL LL_RTC_SetOutputPolarity + * @param RTCx RTC Instance + * @param Polarity This parameter can be one of the following values: + * @arg @ref LL_RTC_OUTPUTPOLARITY_PIN_HIGH + * @arg @ref LL_RTC_OUTPUTPOLARITY_PIN_LOW + * @retval None + */ +__STATIC_INLINE void LL_RTC_SetOutputPolarity(RTC_TypeDef *RTCx, uint32_t Polarity) +{ + MODIFY_REG(RTCx->CR, RTC_CR_POL, Polarity); +} + +/** + * @brief Get Output polarity + * @rmtoll CR POL LL_RTC_GetOutputPolarity + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_OUTPUTPOLARITY_PIN_HIGH + * @arg @ref LL_RTC_OUTPUTPOLARITY_PIN_LOW + */ +__STATIC_INLINE uint32_t LL_RTC_GetOutputPolarity(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CR, RTC_CR_POL)); +} + +/** + * @brief Enable Bypass the shadow registers + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR BYPSHAD LL_RTC_EnableShadowRegBypass + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableShadowRegBypass(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_BYPSHAD); +} + +/** + * @brief Disable Bypass the shadow registers + * @rmtoll CR BYPSHAD LL_RTC_DisableShadowRegBypass + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableShadowRegBypass(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_BYPSHAD); +} + +/** + * @brief Check if Shadow registers bypass is enabled or not. + * @rmtoll CR BYPSHAD LL_RTC_IsShadowRegBypassEnabled + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsShadowRegBypassEnabled(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->CR, RTC_CR_BYPSHAD) == (RTC_CR_BYPSHAD)); +} + +/** + * @brief Enable RTC_REFIN reference clock detection (50 or 60 Hz) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @rmtoll CR REFCKON LL_RTC_EnableRefClock + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableRefClock(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_REFCKON); +} + +/** + * @brief Disable RTC_REFIN reference clock detection (50 or 60 Hz) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @rmtoll CR REFCKON LL_RTC_DisableRefClock + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableRefClock(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_REFCKON); +} + +/** + * @brief Set Asynchronous prescaler factor + * @rmtoll PRER PREDIV_A LL_RTC_SetAsynchPrescaler + * @param RTCx RTC Instance + * @param AsynchPrescaler Value between Min_Data = 0 and Max_Data = 0x7F + * @retval None + */ +__STATIC_INLINE void LL_RTC_SetAsynchPrescaler(RTC_TypeDef *RTCx, uint32_t AsynchPrescaler) +{ + MODIFY_REG(RTCx->PRER, RTC_PRER_PREDIV_A, AsynchPrescaler << RTC_PRER_PREDIV_A_Pos); +} + +/** + * @brief Set Synchronous prescaler factor + * @rmtoll PRER PREDIV_S LL_RTC_SetSynchPrescaler + * @param RTCx RTC Instance + * @param SynchPrescaler Value between Min_Data = 0 and Max_Data = 0x7FFF + * @retval None + */ +__STATIC_INLINE void LL_RTC_SetSynchPrescaler(RTC_TypeDef *RTCx, uint32_t SynchPrescaler) +{ + MODIFY_REG(RTCx->PRER, RTC_PRER_PREDIV_S, SynchPrescaler); +} + +/** + * @brief Get Asynchronous prescaler factor + * @rmtoll PRER PREDIV_A LL_RTC_GetAsynchPrescaler + * @param RTCx RTC Instance + * @retval Value between Min_Data = 0 and Max_Data = 0x7F + */ +__STATIC_INLINE uint32_t LL_RTC_GetAsynchPrescaler(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->PRER, RTC_PRER_PREDIV_A) >> RTC_PRER_PREDIV_A_Pos); +} + +/** + * @brief Get Synchronous prescaler factor + * @rmtoll PRER PREDIV_S LL_RTC_GetSynchPrescaler + * @param RTCx RTC Instance + * @retval Value between Min_Data = 0 and Max_Data = 0x7FFF + */ +__STATIC_INLINE uint32_t LL_RTC_GetSynchPrescaler(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->PRER, RTC_PRER_PREDIV_S)); +} + +/** + * @brief Enable the write protection for RTC registers. + * @rmtoll WPR KEY LL_RTC_EnableWriteProtection + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableWriteProtection(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->WPR, RTC_WRITE_PROTECTION_DISABLE); +} + +/** + * @brief Disable the write protection for RTC registers. + * @rmtoll WPR KEY LL_RTC_DisableWriteProtection + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableWriteProtection(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->WPR, RTC_WRITE_PROTECTION_ENABLE_1); + WRITE_REG(RTCx->WPR, RTC_WRITE_PROTECTION_ENABLE_2); +} + +/** + * @} + */ + +/** @defgroup RTC_LL_EF_Time Time + * @{ + */ + +/** + * @brief Set time format (AM/24-hour or PM notation) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @rmtoll TR PM LL_RTC_TIME_SetFormat + * @param RTCx RTC Instance + * @param TimeFormat This parameter can be one of the following values: + * @arg @ref LL_RTC_TIME_FORMAT_AM_OR_24 + * @arg @ref LL_RTC_TIME_FORMAT_PM + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_SetFormat(RTC_TypeDef *RTCx, uint32_t TimeFormat) +{ + MODIFY_REG(RTCx->TR, RTC_TR_PM, TimeFormat); +} + +/** + * @brief Get time format (AM or PM notation) + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note Read either RTC_SSR or RTC_TR locks the values in the higher-order calendar + * shadow registers until RTC_DR is read (LL_RTC_ReadReg(RTC, DR)). + * @rmtoll TR PM LL_RTC_TIME_GetFormat + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_TIME_FORMAT_AM_OR_24 + * @arg @ref LL_RTC_TIME_FORMAT_PM + */ +__STATIC_INLINE uint32_t LL_RTC_TIME_GetFormat(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TR, RTC_TR_PM)); +} + +/** + * @brief Set Hours in BCD format + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert hour from binary to BCD format + * @rmtoll TR HT LL_RTC_TIME_SetHour\n + * TR HU LL_RTC_TIME_SetHour + * @param RTCx RTC Instance + * @param Hours Value between Min_Data=0x01 and Max_Data=0x12 or between Min_Data=0x00 and Max_Data=0x23 + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_SetHour(RTC_TypeDef *RTCx, uint32_t Hours) +{ + MODIFY_REG(RTCx->TR, (RTC_TR_HT | RTC_TR_HU), + (((Hours & 0xF0U) << (RTC_TR_HT_Pos - 4U)) | ((Hours & 0x0FU) << RTC_TR_HU_Pos))); +} + +/** + * @brief Get Hours in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note Read either RTC_SSR or RTC_TR locks the values in the higher-order calendar + * shadow registers until RTC_DR is read (LL_RTC_ReadReg(RTC, DR)). + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert hour from BCD to + * Binary format + * @rmtoll TR HT LL_RTC_TIME_GetHour\n + * TR HU LL_RTC_TIME_GetHour + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x01 and Max_Data=0x12 or between Min_Data=0x00 and Max_Data=0x23 + */ +__STATIC_INLINE uint32_t LL_RTC_TIME_GetHour(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->TR, (RTC_TR_HT | RTC_TR_HU))) >> RTC_TR_HU_Pos); +} + +/** + * @brief Set Minutes in BCD format + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Minutes from binary to BCD format + * @rmtoll TR MNT LL_RTC_TIME_SetMinute\n + * TR MNU LL_RTC_TIME_SetMinute + * @param RTCx RTC Instance + * @param Minutes Value between Min_Data=0x00 and Max_Data=0x59 + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_SetMinute(RTC_TypeDef *RTCx, uint32_t Minutes) +{ + MODIFY_REG(RTCx->TR, (RTC_TR_MNT | RTC_TR_MNU), + (((Minutes & 0xF0U) << (RTC_TR_MNT_Pos - 4U)) | ((Minutes & 0x0FU) << RTC_TR_MNU_Pos))); +} + +/** + * @brief Get Minutes in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note Read either RTC_SSR or RTC_TR locks the values in the higher-order calendar + * shadow registers until RTC_DR is read (LL_RTC_ReadReg(RTC, DR)). + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert minute from BCD + * to Binary format + * @rmtoll TR MNT LL_RTC_TIME_GetMinute\n + * TR MNU LL_RTC_TIME_GetMinute + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x59 + */ +__STATIC_INLINE uint32_t LL_RTC_TIME_GetMinute(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->TR, (RTC_TR_MNT | RTC_TR_MNU))) >> RTC_TR_MNU_Pos); +} + +/** + * @brief Set Seconds in BCD format + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Seconds from binary to BCD format + * @rmtoll TR ST LL_RTC_TIME_SetSecond\n + * TR SU LL_RTC_TIME_SetSecond + * @param RTCx RTC Instance + * @param Seconds Value between Min_Data=0x00 and Max_Data=0x59 + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_SetSecond(RTC_TypeDef *RTCx, uint32_t Seconds) +{ + MODIFY_REG(RTCx->TR, (RTC_TR_ST | RTC_TR_SU), + (((Seconds & 0xF0U) << (RTC_TR_ST_Pos - 4U)) | ((Seconds & 0x0FU) << RTC_TR_SU_Pos))); +} + +/** + * @brief Get Seconds in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note Read either RTC_SSR or RTC_TR locks the values in the higher-order calendar + * shadow registers until RTC_DR is read (LL_RTC_ReadReg(RTC, DR)). + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Seconds from BCD + * to Binary format + * @rmtoll TR ST LL_RTC_TIME_GetSecond\n + * TR SU LL_RTC_TIME_GetSecond + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x59 + */ +__STATIC_INLINE uint32_t LL_RTC_TIME_GetSecond(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->TR, (RTC_TR_ST | RTC_TR_SU))) >> RTC_TR_SU_Pos); +} + +/** + * @brief Set time (hour, minute and second) in BCD format + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note It can be written in initialization mode only (@ref LL_RTC_EnableInitMode function) + * @note TimeFormat and Hours should follow the same format + * @rmtoll TR PM LL_RTC_TIME_Config\n + * TR HT LL_RTC_TIME_Config\n + * TR HU LL_RTC_TIME_Config\n + * TR MNT LL_RTC_TIME_Config\n + * TR MNU LL_RTC_TIME_Config\n + * TR ST LL_RTC_TIME_Config\n + * TR SU LL_RTC_TIME_Config + * @param RTCx RTC Instance + * @param Format12_24 This parameter can be one of the following values: + * @arg @ref LL_RTC_TIME_FORMAT_AM_OR_24 + * @arg @ref LL_RTC_TIME_FORMAT_PM + * @param Hours Value between Min_Data=0x01 and Max_Data=0x12 or between Min_Data=0x00 and Max_Data=0x23 + * @param Minutes Value between Min_Data=0x00 and Max_Data=0x59 + * @param Seconds Value between Min_Data=0x00 and Max_Data=0x59 + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_Config(RTC_TypeDef *RTCx, uint32_t Format12_24, uint32_t Hours, uint32_t Minutes, uint32_t Seconds) +{ + uint32_t temp = 0U; + + temp = Format12_24 | \ + (((Hours & 0xF0U) << (RTC_TR_HT_Pos - 4U)) | ((Hours & 0x0FU) << RTC_TR_HU_Pos)) | \ + (((Minutes & 0xF0U) << (RTC_TR_MNT_Pos - 4U)) | ((Minutes & 0x0FU) << RTC_TR_MNU_Pos)) | \ + (((Seconds & 0xF0U) << (RTC_TR_ST_Pos - 4U)) | ((Seconds & 0x0FU) << RTC_TR_SU_Pos)); + MODIFY_REG(RTCx->TR, (RTC_TR_PM | RTC_TR_HT | RTC_TR_HU | RTC_TR_MNT | RTC_TR_MNU | RTC_TR_ST | RTC_TR_SU), temp); +} + +/** + * @brief Get time (hour, minute and second) in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note Read either RTC_SSR or RTC_TR locks the values in the higher-order calendar + * shadow registers until RTC_DR is read (LL_RTC_ReadReg(RTC, DR)). + * @note helper macros __LL_RTC_GET_HOUR, __LL_RTC_GET_MINUTE and __LL_RTC_GET_SECOND + * are available to get independently each parameter. + * @rmtoll TR HT LL_RTC_TIME_Get\n + * TR HU LL_RTC_TIME_Get\n + * TR MNT LL_RTC_TIME_Get\n + * TR MNU LL_RTC_TIME_Get\n + * TR ST LL_RTC_TIME_Get\n + * TR SU LL_RTC_TIME_Get + * @param RTCx RTC Instance + * @retval Combination of hours, minutes and seconds (Format: 0x00HHMMSS). + */ +__STATIC_INLINE uint32_t LL_RTC_TIME_Get(RTC_TypeDef *RTCx) +{ + uint32_t temp = 0U; + + temp = READ_BIT(RTCx->TR, (RTC_TR_HT | RTC_TR_HU | RTC_TR_MNT | RTC_TR_MNU | RTC_TR_ST | RTC_TR_SU)); + return (uint32_t)((((((temp & RTC_TR_HT) >> RTC_TR_HT_Pos) << 4U) | ((temp & RTC_TR_HU) >> RTC_TR_HU_Pos)) << RTC_OFFSET_HOUR) | \ + (((((temp & RTC_TR_MNT) >> RTC_TR_MNT_Pos) << 4U) | ((temp & RTC_TR_MNU) >> RTC_TR_MNU_Pos)) << RTC_OFFSET_MINUTE) | \ + ((((temp & RTC_TR_ST) >> RTC_TR_ST_Pos) << 4U) | ((temp & RTC_TR_SU) >> RTC_TR_SU_Pos))); +} + +/** + * @brief Memorize whether the daylight saving time change has been performed + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR BKP LL_RTC_TIME_EnableDayLightStore + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_EnableDayLightStore(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_BKP); +} + +/** + * @brief Disable memorization whether the daylight saving time change has been performed. + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR BKP LL_RTC_TIME_DisableDayLightStore + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_DisableDayLightStore(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_BKP); +} + +/** + * @brief Check if RTC Day Light Saving stored operation has been enabled or not + * @rmtoll CR BKP LL_RTC_TIME_IsDayLightStoreEnabled + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_TIME_IsDayLightStoreEnabled(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->CR, RTC_CR_BKP) == (RTC_CR_BKP)); +} + +/** + * @brief Subtract 1 hour (winter time change) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR SUB1H LL_RTC_TIME_DecHour + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_DecHour(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_SUB1H); +} + +/** + * @brief Add 1 hour (summer time change) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR ADD1H LL_RTC_TIME_IncHour + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_IncHour(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_ADD1H); +} + +/** + * @brief Get Sub second value in the synchronous prescaler counter. + * @note You can use both SubSeconds value and SecondFraction (PREDIV_S through + * LL_RTC_GetSynchPrescaler function) terms returned to convert Calendar + * SubSeconds value in second fraction ratio with time unit following + * generic formula: + * ==> Seconds fraction ratio * time_unit= [(SecondFraction-SubSeconds)/(SecondFraction+1)] * time_unit + * This conversion can be performed only if no shift operation is pending + * (ie. SHFP=0) when PREDIV_S >= SS. + * @rmtoll SSR SS LL_RTC_TIME_GetSubSecond + * @param RTCx RTC Instance + * @retval Sub second value (number between 0 and 65535) + */ +__STATIC_INLINE uint32_t LL_RTC_TIME_GetSubSecond(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->SSR, RTC_SSR_SS)); +} + +/** + * @brief Synchronize to a remote clock with a high degree of precision. + * @note This operation effectively subtracts from (delays) or advance the clock of a fraction of a second. + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note When REFCKON is set, firmware must not write to Shift control register. + * @rmtoll SHIFTR ADD1S LL_RTC_TIME_Synchronize\n + * SHIFTR SUBFS LL_RTC_TIME_Synchronize + * @param RTCx RTC Instance + * @param ShiftSecond This parameter can be one of the following values: + * @arg @ref LL_RTC_SHIFT_SECOND_DELAY + * @arg @ref LL_RTC_SHIFT_SECOND_ADVANCE + * @param Fraction Number of Seconds Fractions (any value from 0 to 0x7FFF) + * @retval None + */ +__STATIC_INLINE void LL_RTC_TIME_Synchronize(RTC_TypeDef *RTCx, uint32_t ShiftSecond, uint32_t Fraction) +{ + WRITE_REG(RTCx->SHIFTR, ShiftSecond | Fraction); +} + +/** + * @} + */ + +/** @defgroup RTC_LL_EF_Date Date + * @{ + */ + +/** + * @brief Set Year in BCD format + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Year from binary to BCD format + * @rmtoll DR YT LL_RTC_DATE_SetYear\n + * DR YU LL_RTC_DATE_SetYear + * @param RTCx RTC Instance + * @param Year Value between Min_Data=0x00 and Max_Data=0x99 + * @retval None + */ +__STATIC_INLINE void LL_RTC_DATE_SetYear(RTC_TypeDef *RTCx, uint32_t Year) +{ + MODIFY_REG(RTCx->DR, (RTC_DR_YT | RTC_DR_YU), + (((Year & 0xF0U) << (RTC_DR_YT_Pos - 4U)) | ((Year & 0x0FU) << RTC_DR_YU_Pos))); +} + +/** + * @brief Get Year in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Year from BCD to Binary format + * @rmtoll DR YT LL_RTC_DATE_GetYear\n + * DR YU LL_RTC_DATE_GetYear + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x99 + */ +__STATIC_INLINE uint32_t LL_RTC_DATE_GetYear(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->DR, (RTC_DR_YT | RTC_DR_YU))) >> RTC_DR_YU_Pos); +} + +/** + * @brief Set Week day + * @rmtoll DR WDU LL_RTC_DATE_SetWeekDay + * @param RTCx RTC Instance + * @param WeekDay This parameter can be one of the following values: + * @arg @ref LL_RTC_WEEKDAY_MONDAY + * @arg @ref LL_RTC_WEEKDAY_TUESDAY + * @arg @ref LL_RTC_WEEKDAY_WEDNESDAY + * @arg @ref LL_RTC_WEEKDAY_THURSDAY + * @arg @ref LL_RTC_WEEKDAY_FRIDAY + * @arg @ref LL_RTC_WEEKDAY_SATURDAY + * @arg @ref LL_RTC_WEEKDAY_SUNDAY + * @retval None + */ +__STATIC_INLINE void LL_RTC_DATE_SetWeekDay(RTC_TypeDef *RTCx, uint32_t WeekDay) +{ + MODIFY_REG(RTCx->DR, RTC_DR_WDU, WeekDay << RTC_DR_WDU_Pos); +} + +/** + * @brief Get Week day + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @rmtoll DR WDU LL_RTC_DATE_GetWeekDay + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_WEEKDAY_MONDAY + * @arg @ref LL_RTC_WEEKDAY_TUESDAY + * @arg @ref LL_RTC_WEEKDAY_WEDNESDAY + * @arg @ref LL_RTC_WEEKDAY_THURSDAY + * @arg @ref LL_RTC_WEEKDAY_FRIDAY + * @arg @ref LL_RTC_WEEKDAY_SATURDAY + * @arg @ref LL_RTC_WEEKDAY_SUNDAY + */ +__STATIC_INLINE uint32_t LL_RTC_DATE_GetWeekDay(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->DR, RTC_DR_WDU) >> RTC_DR_WDU_Pos); +} + +/** + * @brief Set Month in BCD format + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Month from binary to BCD format + * @rmtoll DR MT LL_RTC_DATE_SetMonth\n + * DR MU LL_RTC_DATE_SetMonth + * @param RTCx RTC Instance + * @param Month This parameter can be one of the following values: + * @arg @ref LL_RTC_MONTH_JANUARY + * @arg @ref LL_RTC_MONTH_FEBRUARY + * @arg @ref LL_RTC_MONTH_MARCH + * @arg @ref LL_RTC_MONTH_APRIL + * @arg @ref LL_RTC_MONTH_MAY + * @arg @ref LL_RTC_MONTH_JUNE + * @arg @ref LL_RTC_MONTH_JULY + * @arg @ref LL_RTC_MONTH_AUGUST + * @arg @ref LL_RTC_MONTH_SEPTEMBER + * @arg @ref LL_RTC_MONTH_OCTOBER + * @arg @ref LL_RTC_MONTH_NOVEMBER + * @arg @ref LL_RTC_MONTH_DECEMBER + * @retval None + */ +__STATIC_INLINE void LL_RTC_DATE_SetMonth(RTC_TypeDef *RTCx, uint32_t Month) +{ + MODIFY_REG(RTCx->DR, (RTC_DR_MT | RTC_DR_MU), + (((Month & 0xF0U) << (RTC_DR_MT_Pos - 4U)) | ((Month & 0x0FU) << RTC_DR_MU_Pos))); +} + +/** + * @brief Get Month in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Month from BCD to Binary format + * @rmtoll DR MT LL_RTC_DATE_GetMonth\n + * DR MU LL_RTC_DATE_GetMonth + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_MONTH_JANUARY + * @arg @ref LL_RTC_MONTH_FEBRUARY + * @arg @ref LL_RTC_MONTH_MARCH + * @arg @ref LL_RTC_MONTH_APRIL + * @arg @ref LL_RTC_MONTH_MAY + * @arg @ref LL_RTC_MONTH_JUNE + * @arg @ref LL_RTC_MONTH_JULY + * @arg @ref LL_RTC_MONTH_AUGUST + * @arg @ref LL_RTC_MONTH_SEPTEMBER + * @arg @ref LL_RTC_MONTH_OCTOBER + * @arg @ref LL_RTC_MONTH_NOVEMBER + * @arg @ref LL_RTC_MONTH_DECEMBER + */ +__STATIC_INLINE uint32_t LL_RTC_DATE_GetMonth(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->DR, (RTC_DR_MT | RTC_DR_MU))) >> RTC_DR_MU_Pos); +} + +/** + * @brief Set Day in BCD format + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Day from binary to BCD format + * @rmtoll DR DT LL_RTC_DATE_SetDay\n + * DR DU LL_RTC_DATE_SetDay + * @param RTCx RTC Instance + * @param Day Value between Min_Data=0x01 and Max_Data=0x31 + * @retval None + */ +__STATIC_INLINE void LL_RTC_DATE_SetDay(RTC_TypeDef *RTCx, uint32_t Day) +{ + MODIFY_REG(RTCx->DR, (RTC_DR_DT | RTC_DR_DU), + (((Day & 0xF0U) << (RTC_DR_DT_Pos - 4U)) | ((Day & 0x0FU) << RTC_DR_DU_Pos))); +} + +/** + * @brief Get Day in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Day from BCD to Binary format + * @rmtoll DR DT LL_RTC_DATE_GetDay\n + * DR DU LL_RTC_DATE_GetDay + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x01 and Max_Data=0x31 + */ +__STATIC_INLINE uint32_t LL_RTC_DATE_GetDay(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->DR, (RTC_DR_DT | RTC_DR_DU))) >> RTC_DR_DU_Pos); +} + +/** + * @brief Set date (WeekDay, Day, Month and Year) in BCD format + * @rmtoll DR WDU LL_RTC_DATE_Config\n + * DR MT LL_RTC_DATE_Config\n + * DR MU LL_RTC_DATE_Config\n + * DR DT LL_RTC_DATE_Config\n + * DR DU LL_RTC_DATE_Config\n + * DR YT LL_RTC_DATE_Config\n + * DR YU LL_RTC_DATE_Config + * @param RTCx RTC Instance + * @param WeekDay This parameter can be one of the following values: + * @arg @ref LL_RTC_WEEKDAY_MONDAY + * @arg @ref LL_RTC_WEEKDAY_TUESDAY + * @arg @ref LL_RTC_WEEKDAY_WEDNESDAY + * @arg @ref LL_RTC_WEEKDAY_THURSDAY + * @arg @ref LL_RTC_WEEKDAY_FRIDAY + * @arg @ref LL_RTC_WEEKDAY_SATURDAY + * @arg @ref LL_RTC_WEEKDAY_SUNDAY + * @param Day Value between Min_Data=0x01 and Max_Data=0x31 + * @param Month This parameter can be one of the following values: + * @arg @ref LL_RTC_MONTH_JANUARY + * @arg @ref LL_RTC_MONTH_FEBRUARY + * @arg @ref LL_RTC_MONTH_MARCH + * @arg @ref LL_RTC_MONTH_APRIL + * @arg @ref LL_RTC_MONTH_MAY + * @arg @ref LL_RTC_MONTH_JUNE + * @arg @ref LL_RTC_MONTH_JULY + * @arg @ref LL_RTC_MONTH_AUGUST + * @arg @ref LL_RTC_MONTH_SEPTEMBER + * @arg @ref LL_RTC_MONTH_OCTOBER + * @arg @ref LL_RTC_MONTH_NOVEMBER + * @arg @ref LL_RTC_MONTH_DECEMBER + * @param Year Value between Min_Data=0x00 and Max_Data=0x99 + * @retval None + */ +__STATIC_INLINE void LL_RTC_DATE_Config(RTC_TypeDef *RTCx, uint32_t WeekDay, uint32_t Day, uint32_t Month, uint32_t Year) +{ + uint32_t temp = 0U; + + temp = (WeekDay << RTC_DR_WDU_Pos) | \ + (((Year & 0xF0U) << (RTC_DR_YT_Pos - 4U)) | ((Year & 0x0FU) << RTC_DR_YU_Pos)) | \ + (((Month & 0xF0U) << (RTC_DR_MT_Pos - 4U)) | ((Month & 0x0FU) << RTC_DR_MU_Pos)) | \ + (((Day & 0xF0U) << (RTC_DR_DT_Pos - 4U)) | ((Day & 0x0FU) << RTC_DR_DU_Pos)); + + MODIFY_REG(RTCx->DR, (RTC_DR_WDU | RTC_DR_MT | RTC_DR_MU | RTC_DR_DT | RTC_DR_DU | RTC_DR_YT | RTC_DR_YU), temp); +} + +/** + * @brief Get date (WeekDay, Day, Month and Year) in BCD format + * @note if shadow mode is disabled (BYPSHAD=0), need to check if RSF flag is set + * before reading this bit + * @note helper macros __LL_RTC_GET_WEEKDAY, __LL_RTC_GET_YEAR, __LL_RTC_GET_MONTH, + * and __LL_RTC_GET_DAY are available to get independently each parameter. + * @rmtoll DR WDU LL_RTC_DATE_Get\n + * DR MT LL_RTC_DATE_Get\n + * DR MU LL_RTC_DATE_Get\n + * DR DT LL_RTC_DATE_Get\n + * DR DU LL_RTC_DATE_Get\n + * DR YT LL_RTC_DATE_Get\n + * DR YU LL_RTC_DATE_Get + * @param RTCx RTC Instance + * @retval Combination of WeekDay, Day, Month and Year (Format: 0xWWDDMMYY). + */ +__STATIC_INLINE uint32_t LL_RTC_DATE_Get(RTC_TypeDef *RTCx) +{ + uint32_t temp = 0U; + + temp = READ_BIT(RTCx->DR, (RTC_DR_WDU | RTC_DR_MT | RTC_DR_MU | RTC_DR_DT | RTC_DR_DU | RTC_DR_YT | RTC_DR_YU)); + return (uint32_t)((((temp & RTC_DR_WDU) >> RTC_DR_WDU_Pos) << RTC_OFFSET_WEEKDAY) | \ + (((((temp & RTC_DR_DT) >> RTC_DR_DT_Pos) << 4U) | ((temp & RTC_DR_DU) >> RTC_DR_DU_Pos)) << RTC_OFFSET_DAY) | \ + (((((temp & RTC_DR_MT) >> RTC_DR_MT_Pos) << 4U) | ((temp & RTC_DR_MU) >> RTC_DR_MU_Pos)) << RTC_OFFSET_MONTH) | \ + ((((temp & RTC_DR_YT) >> RTC_DR_YT_Pos) << 4U) | ((temp & RTC_DR_YU) >> RTC_DR_YU_Pos))); +} + +/** + * @} + */ + +/** @defgroup RTC_LL_EF_ALARMA ALARMA + * @{ + */ + +/** + * @brief Enable Alarm A + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR ALRAE LL_RTC_ALMA_Enable + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_Enable(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_ALRAE); +} + +/** + * @brief Disable Alarm A + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR ALRAE LL_RTC_ALMA_Disable + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_Disable(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_ALRAE); +} + +/** + * @brief Specify the Alarm A masks. + * @rmtoll ALRMAR MSK4 LL_RTC_ALMA_SetMask\n + * ALRMAR MSK3 LL_RTC_ALMA_SetMask\n + * ALRMAR MSK2 LL_RTC_ALMA_SetMask\n + * ALRMAR MSK1 LL_RTC_ALMA_SetMask + * @param RTCx RTC Instance + * @param Mask This parameter can be a combination of the following values: + * @arg @ref LL_RTC_ALMA_MASK_NONE + * @arg @ref LL_RTC_ALMA_MASK_DATEWEEKDAY + * @arg @ref LL_RTC_ALMA_MASK_HOURS + * @arg @ref LL_RTC_ALMA_MASK_MINUTES + * @arg @ref LL_RTC_ALMA_MASK_SECONDS + * @arg @ref LL_RTC_ALMA_MASK_ALL + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetMask(RTC_TypeDef *RTCx, uint32_t Mask) +{ + MODIFY_REG(RTCx->ALRMAR, RTC_ALRMAR_MSK4 | RTC_ALRMAR_MSK3 | RTC_ALRMAR_MSK2 | RTC_ALRMAR_MSK1, Mask); +} + +/** + * @brief Get the Alarm A masks. + * @rmtoll ALRMAR MSK4 LL_RTC_ALMA_GetMask\n + * ALRMAR MSK3 LL_RTC_ALMA_GetMask\n + * ALRMAR MSK2 LL_RTC_ALMA_GetMask\n + * ALRMAR MSK1 LL_RTC_ALMA_GetMask + * @param RTCx RTC Instance + * @retval Returned value can be can be a combination of the following values: + * @arg @ref LL_RTC_ALMA_MASK_NONE + * @arg @ref LL_RTC_ALMA_MASK_DATEWEEKDAY + * @arg @ref LL_RTC_ALMA_MASK_HOURS + * @arg @ref LL_RTC_ALMA_MASK_MINUTES + * @arg @ref LL_RTC_ALMA_MASK_SECONDS + * @arg @ref LL_RTC_ALMA_MASK_ALL + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetMask(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->ALRMAR, RTC_ALRMAR_MSK4 | RTC_ALRMAR_MSK3 | RTC_ALRMAR_MSK2 | RTC_ALRMAR_MSK1)); +} + +/** + * @brief Enable AlarmA Week day selection (DU[3:0] represents the week day. DT[1:0] is do not care) + * @rmtoll ALRMAR WDSEL LL_RTC_ALMA_EnableWeekday + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_EnableWeekday(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->ALRMAR, RTC_ALRMAR_WDSEL); +} + +/** + * @brief Disable AlarmA Week day selection (DU[3:0] represents the date ) + * @rmtoll ALRMAR WDSEL LL_RTC_ALMA_DisableWeekday + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_DisableWeekday(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->ALRMAR, RTC_ALRMAR_WDSEL); +} + +/** + * @brief Set ALARM A Day in BCD format + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Day from binary to BCD format + * @rmtoll ALRMAR DT LL_RTC_ALMA_SetDay\n + * ALRMAR DU LL_RTC_ALMA_SetDay + * @param RTCx RTC Instance + * @param Day Value between Min_Data=0x01 and Max_Data=0x31 + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetDay(RTC_TypeDef *RTCx, uint32_t Day) +{ + MODIFY_REG(RTCx->ALRMAR, (RTC_ALRMAR_DT | RTC_ALRMAR_DU), + (((Day & 0xF0U) << (RTC_ALRMAR_DT_Pos - 4U)) | ((Day & 0x0FU) << RTC_ALRMAR_DU_Pos))); +} + +/** + * @brief Get ALARM A Day in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Day from BCD to Binary format + * @rmtoll ALRMAR DT LL_RTC_ALMA_GetDay\n + * ALRMAR DU LL_RTC_ALMA_GetDay + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x01 and Max_Data=0x31 + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetDay(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->ALRMAR, (RTC_ALRMAR_DT | RTC_ALRMAR_DU))) >> RTC_ALRMAR_DU_Pos); +} + +/** + * @brief Set ALARM A Weekday + * @rmtoll ALRMAR DU LL_RTC_ALMA_SetWeekDay + * @param RTCx RTC Instance + * @param WeekDay This parameter can be one of the following values: + * @arg @ref LL_RTC_WEEKDAY_MONDAY + * @arg @ref LL_RTC_WEEKDAY_TUESDAY + * @arg @ref LL_RTC_WEEKDAY_WEDNESDAY + * @arg @ref LL_RTC_WEEKDAY_THURSDAY + * @arg @ref LL_RTC_WEEKDAY_FRIDAY + * @arg @ref LL_RTC_WEEKDAY_SATURDAY + * @arg @ref LL_RTC_WEEKDAY_SUNDAY + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetWeekDay(RTC_TypeDef *RTCx, uint32_t WeekDay) +{ + MODIFY_REG(RTCx->ALRMAR, RTC_ALRMAR_DU, WeekDay << RTC_ALRMAR_DU_Pos); +} + +/** + * @brief Get ALARM A Weekday + * @rmtoll ALRMAR DU LL_RTC_ALMA_GetWeekDay + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_WEEKDAY_MONDAY + * @arg @ref LL_RTC_WEEKDAY_TUESDAY + * @arg @ref LL_RTC_WEEKDAY_WEDNESDAY + * @arg @ref LL_RTC_WEEKDAY_THURSDAY + * @arg @ref LL_RTC_WEEKDAY_FRIDAY + * @arg @ref LL_RTC_WEEKDAY_SATURDAY + * @arg @ref LL_RTC_WEEKDAY_SUNDAY + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetWeekDay(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->ALRMAR, RTC_ALRMAR_DU) >> RTC_ALRMAR_DU_Pos); +} + +/** + * @brief Set Alarm A time format (AM/24-hour or PM notation) + * @rmtoll ALRMAR PM LL_RTC_ALMA_SetTimeFormat + * @param RTCx RTC Instance + * @param TimeFormat This parameter can be one of the following values: + * @arg @ref LL_RTC_ALMA_TIME_FORMAT_AM + * @arg @ref LL_RTC_ALMA_TIME_FORMAT_PM + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetTimeFormat(RTC_TypeDef *RTCx, uint32_t TimeFormat) +{ + MODIFY_REG(RTCx->ALRMAR, RTC_ALRMAR_PM, TimeFormat); +} + +/** + * @brief Get Alarm A time format (AM or PM notation) + * @rmtoll ALRMAR PM LL_RTC_ALMA_GetTimeFormat + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_ALMA_TIME_FORMAT_AM + * @arg @ref LL_RTC_ALMA_TIME_FORMAT_PM + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetTimeFormat(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->ALRMAR, RTC_ALRMAR_PM)); +} + +/** + * @brief Set ALARM A Hours in BCD format + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Hours from binary to BCD format + * @rmtoll ALRMAR HT LL_RTC_ALMA_SetHour\n + * ALRMAR HU LL_RTC_ALMA_SetHour + * @param RTCx RTC Instance + * @param Hours Value between Min_Data=0x01 and Max_Data=0x12 or between Min_Data=0x00 and Max_Data=0x23 + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetHour(RTC_TypeDef *RTCx, uint32_t Hours) +{ + MODIFY_REG(RTCx->ALRMAR, (RTC_ALRMAR_HT | RTC_ALRMAR_HU), + (((Hours & 0xF0U) << (RTC_ALRMAR_HT_Pos - 4U)) | ((Hours & 0x0FU) << RTC_ALRMAR_HU_Pos))); +} + +/** + * @brief Get ALARM A Hours in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Hours from BCD to Binary format + * @rmtoll ALRMAR HT LL_RTC_ALMA_GetHour\n + * ALRMAR HU LL_RTC_ALMA_GetHour + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x01 and Max_Data=0x12 or between Min_Data=0x00 and Max_Data=0x23 + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetHour(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->ALRMAR, (RTC_ALRMAR_HT | RTC_ALRMAR_HU))) >> RTC_ALRMAR_HU_Pos); +} + +/** + * @brief Set ALARM A Minutes in BCD format + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Minutes from binary to BCD format + * @rmtoll ALRMAR MNT LL_RTC_ALMA_SetMinute\n + * ALRMAR MNU LL_RTC_ALMA_SetMinute + * @param RTCx RTC Instance + * @param Minutes Value between Min_Data=0x00 and Max_Data=0x59 + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetMinute(RTC_TypeDef *RTCx, uint32_t Minutes) +{ + MODIFY_REG(RTCx->ALRMAR, (RTC_ALRMAR_MNT | RTC_ALRMAR_MNU), + (((Minutes & 0xF0U) << (RTC_ALRMAR_MNT_Pos - 4U)) | ((Minutes & 0x0FU) << RTC_ALRMAR_MNU_Pos))); +} + +/** + * @brief Get ALARM A Minutes in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Minutes from BCD to Binary format + * @rmtoll ALRMAR MNT LL_RTC_ALMA_GetMinute\n + * ALRMAR MNU LL_RTC_ALMA_GetMinute + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x59 + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetMinute(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->ALRMAR, (RTC_ALRMAR_MNT | RTC_ALRMAR_MNU))) >> RTC_ALRMAR_MNU_Pos); +} + +/** + * @brief Set ALARM A Seconds in BCD format + * @note helper macro __LL_RTC_CONVERT_BIN2BCD is available to convert Seconds from binary to BCD format + * @rmtoll ALRMAR ST LL_RTC_ALMA_SetSecond\n + * ALRMAR SU LL_RTC_ALMA_SetSecond + * @param RTCx RTC Instance + * @param Seconds Value between Min_Data=0x00 and Max_Data=0x59 + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetSecond(RTC_TypeDef *RTCx, uint32_t Seconds) +{ + MODIFY_REG(RTCx->ALRMAR, (RTC_ALRMAR_ST | RTC_ALRMAR_SU), + (((Seconds & 0xF0U) << (RTC_ALRMAR_ST_Pos - 4U)) | ((Seconds & 0x0FU) << RTC_ALRMAR_SU_Pos))); +} + +/** + * @brief Get ALARM A Seconds in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Seconds from BCD to Binary format + * @rmtoll ALRMAR ST LL_RTC_ALMA_GetSecond\n + * ALRMAR SU LL_RTC_ALMA_GetSecond + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x59 + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetSecond(RTC_TypeDef *RTCx) +{ + return (uint32_t)((READ_BIT(RTCx->ALRMAR, (RTC_ALRMAR_ST | RTC_ALRMAR_SU))) >> RTC_ALRMAR_SU_Pos); +} + +/** + * @brief Set Alarm A Time (hour, minute and second) in BCD format + * @rmtoll ALRMAR PM LL_RTC_ALMA_ConfigTime\n + * ALRMAR HT LL_RTC_ALMA_ConfigTime\n + * ALRMAR HU LL_RTC_ALMA_ConfigTime\n + * ALRMAR MNT LL_RTC_ALMA_ConfigTime\n + * ALRMAR MNU LL_RTC_ALMA_ConfigTime\n + * ALRMAR ST LL_RTC_ALMA_ConfigTime\n + * ALRMAR SU LL_RTC_ALMA_ConfigTime + * @param RTCx RTC Instance + * @param Format12_24 This parameter can be one of the following values: + * @arg @ref LL_RTC_ALMA_TIME_FORMAT_AM + * @arg @ref LL_RTC_ALMA_TIME_FORMAT_PM + * @param Hours Value between Min_Data=0x01 and Max_Data=0x12 or between Min_Data=0x00 and Max_Data=0x23 + * @param Minutes Value between Min_Data=0x00 and Max_Data=0x59 + * @param Seconds Value between Min_Data=0x00 and Max_Data=0x59 + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_ConfigTime(RTC_TypeDef *RTCx, uint32_t Format12_24, uint32_t Hours, uint32_t Minutes, uint32_t Seconds) +{ + uint32_t temp = 0U; + + temp = Format12_24 | (((Hours & 0xF0U) << (RTC_ALRMAR_HT_Pos - 4U)) | ((Hours & 0x0FU) << RTC_ALRMAR_HU_Pos)) | \ + (((Minutes & 0xF0U) << (RTC_ALRMAR_MNT_Pos - 4U)) | ((Minutes & 0x0FU) << RTC_ALRMAR_MNU_Pos)) | \ + (((Seconds & 0xF0U) << (RTC_ALRMAR_ST_Pos - 4U)) | ((Seconds & 0x0FU) << RTC_ALRMAR_SU_Pos)); + + MODIFY_REG(RTCx->ALRMAR, RTC_ALRMAR_PM | RTC_ALRMAR_HT | RTC_ALRMAR_HU | RTC_ALRMAR_MNT | RTC_ALRMAR_MNU | RTC_ALRMAR_ST | RTC_ALRMAR_SU, temp); +} + +/** + * @brief Get Alarm B Time (hour, minute and second) in BCD format + * @note helper macros __LL_RTC_GET_HOUR, __LL_RTC_GET_MINUTE and __LL_RTC_GET_SECOND + * are available to get independently each parameter. + * @rmtoll ALRMAR HT LL_RTC_ALMA_GetTime\n + * ALRMAR HU LL_RTC_ALMA_GetTime\n + * ALRMAR MNT LL_RTC_ALMA_GetTime\n + * ALRMAR MNU LL_RTC_ALMA_GetTime\n + * ALRMAR ST LL_RTC_ALMA_GetTime\n + * ALRMAR SU LL_RTC_ALMA_GetTime + * @param RTCx RTC Instance + * @retval Combination of hours, minutes and seconds. + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetTime(RTC_TypeDef *RTCx) +{ + return (uint32_t)((LL_RTC_ALMA_GetHour(RTCx) << RTC_OFFSET_HOUR) | (LL_RTC_ALMA_GetMinute(RTCx) << RTC_OFFSET_MINUTE) | LL_RTC_ALMA_GetSecond(RTCx)); +} + +/** + * @brief Set Alarm A Mask the most-significant bits starting at this bit + * @note This register can be written only when ALRAE is reset in RTC_CR register, + * or in initialization mode. + * @rmtoll ALRMASSR MASKSS LL_RTC_ALMA_SetSubSecondMask + * @param RTCx RTC Instance + * @param Mask Value between Min_Data=0x00 and Max_Data=0xF + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetSubSecondMask(RTC_TypeDef *RTCx, uint32_t Mask) +{ + MODIFY_REG(RTCx->ALRMASSR, RTC_ALRMASSR_MASKSS, Mask << RTC_ALRMASSR_MASKSS_Pos); +} + +/** + * @brief Get Alarm A Mask the most-significant bits starting at this bit + * @rmtoll ALRMASSR MASKSS LL_RTC_ALMA_GetSubSecondMask + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0xF + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetSubSecondMask(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->ALRMASSR, RTC_ALRMASSR_MASKSS) >> RTC_ALRMASSR_MASKSS_Pos); +} + +/** + * @brief Set Alarm A Sub seconds value + * @rmtoll ALRMASSR SS LL_RTC_ALMA_SetSubSecond + * @param RTCx RTC Instance + * @param Subsecond Value between Min_Data=0x00 and Max_Data=0x7FFF + * @retval None + */ +__STATIC_INLINE void LL_RTC_ALMA_SetSubSecond(RTC_TypeDef *RTCx, uint32_t Subsecond) +{ + MODIFY_REG(RTCx->ALRMASSR, RTC_ALRMASSR_SS, Subsecond); +} + +/** + * @brief Get Alarm A Sub seconds value + * @rmtoll ALRMASSR SS LL_RTC_ALMA_GetSubSecond + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x7FFF + */ +__STATIC_INLINE uint32_t LL_RTC_ALMA_GetSubSecond(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->ALRMASSR, RTC_ALRMASSR_SS)); +} + +/** + * @} + */ + +/** @defgroup RTC_LL_EF_Timestamp Timestamp + * @{ + */ + +/** + * @brief Enable Timestamp + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR TSE LL_RTC_TS_Enable + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TS_Enable(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_TSE); +} + +/** + * @brief Disable Timestamp + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR TSE LL_RTC_TS_Disable + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TS_Disable(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_TSE); +} + +/** + * @brief Set Time-stamp event active edge + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note TSE must be reset when TSEDGE is changed to avoid unwanted TSF setting + * @rmtoll CR TSEDGE LL_RTC_TS_SetActiveEdge + * @param RTCx RTC Instance + * @param Edge This parameter can be one of the following values: + * @arg @ref LL_RTC_TIMESTAMP_EDGE_RISING + * @arg @ref LL_RTC_TIMESTAMP_EDGE_FALLING + * @retval None + */ +__STATIC_INLINE void LL_RTC_TS_SetActiveEdge(RTC_TypeDef *RTCx, uint32_t Edge) +{ + MODIFY_REG(RTCx->CR, RTC_CR_TSEDGE, Edge); +} + +/** + * @brief Get Time-stamp event active edge + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR TSEDGE LL_RTC_TS_GetActiveEdge + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_TIMESTAMP_EDGE_RISING + * @arg @ref LL_RTC_TIMESTAMP_EDGE_FALLING + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetActiveEdge(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CR, RTC_CR_TSEDGE)); +} + +/** + * @brief Get Timestamp AM/PM notation (AM or 24-hour format) + * @rmtoll TSTR PM LL_RTC_TS_GetTimeFormat + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_TS_TIME_FORMAT_AM + * @arg @ref LL_RTC_TS_TIME_FORMAT_PM + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetTimeFormat(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSTR, RTC_TSTR_PM)); +} + +/** + * @brief Get Timestamp Hours in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Hours from BCD to Binary format + * @rmtoll TSTR HT LL_RTC_TS_GetHour\n + * TSTR HU LL_RTC_TS_GetHour + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x01 and Max_Data=0x12 or between Min_Data=0x00 and Max_Data=0x23 + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetHour(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSTR, RTC_TSTR_HT | RTC_TSTR_HU) >> RTC_TSTR_HU_Pos); +} + +/** + * @brief Get Timestamp Minutes in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Minutes from BCD to Binary format + * @rmtoll TSTR MNT LL_RTC_TS_GetMinute\n + * TSTR MNU LL_RTC_TS_GetMinute + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x59 + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetMinute(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSTR, RTC_TSTR_MNT | RTC_TSTR_MNU) >> RTC_TSTR_MNU_Pos); +} + +/** + * @brief Get Timestamp Seconds in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Seconds from BCD to Binary format + * @rmtoll TSTR ST LL_RTC_TS_GetSecond\n + * TSTR SU LL_RTC_TS_GetSecond + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x59 + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetSecond(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSTR, RTC_TSTR_ST | RTC_TSTR_SU)); +} + +/** + * @brief Get Timestamp time (hour, minute and second) in BCD format + * @note helper macros __LL_RTC_GET_HOUR, __LL_RTC_GET_MINUTE and __LL_RTC_GET_SECOND + * are available to get independently each parameter. + * @rmtoll TSTR HT LL_RTC_TS_GetTime\n + * TSTR HU LL_RTC_TS_GetTime\n + * TSTR MNT LL_RTC_TS_GetTime\n + * TSTR MNU LL_RTC_TS_GetTime\n + * TSTR ST LL_RTC_TS_GetTime\n + * TSTR SU LL_RTC_TS_GetTime + * @param RTCx RTC Instance + * @retval Combination of hours, minutes and seconds. + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetTime(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSTR, + RTC_TSTR_HT | RTC_TSTR_HU | RTC_TSTR_MNT | RTC_TSTR_MNU | RTC_TSTR_ST | RTC_TSTR_SU)); +} + +/** + * @brief Get Timestamp Week day + * @rmtoll TSDR WDU LL_RTC_TS_GetWeekDay + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_WEEKDAY_MONDAY + * @arg @ref LL_RTC_WEEKDAY_TUESDAY + * @arg @ref LL_RTC_WEEKDAY_WEDNESDAY + * @arg @ref LL_RTC_WEEKDAY_THURSDAY + * @arg @ref LL_RTC_WEEKDAY_FRIDAY + * @arg @ref LL_RTC_WEEKDAY_SATURDAY + * @arg @ref LL_RTC_WEEKDAY_SUNDAY + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetWeekDay(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSDR, RTC_TSDR_WDU) >> RTC_TSDR_WDU_Pos); +} + +/** + * @brief Get Timestamp Month in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Month from BCD to Binary format + * @rmtoll TSDR MT LL_RTC_TS_GetMonth\n + * TSDR MU LL_RTC_TS_GetMonth + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_MONTH_JANUARY + * @arg @ref LL_RTC_MONTH_FEBRUARY + * @arg @ref LL_RTC_MONTH_MARCH + * @arg @ref LL_RTC_MONTH_APRIL + * @arg @ref LL_RTC_MONTH_MAY + * @arg @ref LL_RTC_MONTH_JUNE + * @arg @ref LL_RTC_MONTH_JULY + * @arg @ref LL_RTC_MONTH_AUGUST + * @arg @ref LL_RTC_MONTH_SEPTEMBER + * @arg @ref LL_RTC_MONTH_OCTOBER + * @arg @ref LL_RTC_MONTH_NOVEMBER + * @arg @ref LL_RTC_MONTH_DECEMBER + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetMonth(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSDR, RTC_TSDR_MT | RTC_TSDR_MU) >> RTC_TSDR_MU_Pos); +} + +/** + * @brief Get Timestamp Day in BCD format + * @note helper macro __LL_RTC_CONVERT_BCD2BIN is available to convert Day from BCD to Binary format + * @rmtoll TSDR DT LL_RTC_TS_GetDay\n + * TSDR DU LL_RTC_TS_GetDay + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x01 and Max_Data=0x31 + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetDay(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSDR, RTC_TSDR_DT | RTC_TSDR_DU)); +} + +/** + * @brief Get Timestamp date (WeekDay, Day and Month) in BCD format + * @note helper macros __LL_RTC_GET_WEEKDAY, __LL_RTC_GET_MONTH, + * and __LL_RTC_GET_DAY are available to get independently each parameter. + * @rmtoll TSDR WDU LL_RTC_TS_GetDate\n + * TSDR MT LL_RTC_TS_GetDate\n + * TSDR MU LL_RTC_TS_GetDate\n + * TSDR DT LL_RTC_TS_GetDate\n + * TSDR DU LL_RTC_TS_GetDate + * @param RTCx RTC Instance + * @retval Combination of Weekday, Day and Month + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetDate(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSDR, RTC_TSDR_WDU | RTC_TSDR_MT | RTC_TSDR_MU | RTC_TSDR_DT | RTC_TSDR_DU)); +} + +/** + * @brief Get time-stamp sub second value + * @rmtoll TSSSR SS LL_RTC_TS_GetSubSecond + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0xFFFF + */ +__STATIC_INLINE uint32_t LL_RTC_TS_GetSubSecond(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TSSSR, RTC_TSSSR_SS)); +} + +#if defined(RTC_TAFCR_TAMPTS) +/** + * @brief Activate timestamp on tamper detection event + * @rmtoll TAFCR TAMPTS LL_RTC_TS_EnableOnTamper + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TS_EnableOnTamper(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPTS); +} + +/** + * @brief Disable timestamp on tamper detection event + * @rmtoll TAFCR TAMPTS LL_RTC_TS_DisableOnTamper + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TS_DisableOnTamper(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPTS); +} +#endif /* RTC_TAFCR_TAMPTS */ + +/** + * @} + */ + +/** @defgroup RTC_LL_EF_Tamper Tamper + * @{ + */ + +/** + * @brief Enable RTC_TAMPx input detection + * @rmtoll TAFCR TAMP1E LL_RTC_TAMPER_Enable\n + * TAFCR TAMP2E LL_RTC_TAMPER_Enable\n + * TAFCR TAMP3E LL_RTC_TAMPER_Enable + * @param RTCx RTC Instance + * @param Tamper This parameter can be a combination of the following values: + * @arg @ref LL_RTC_TAMPER_1 + * @arg @ref LL_RTC_TAMPER_2 + * @arg @ref LL_RTC_TAMPER_3 (*) + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_Enable(RTC_TypeDef *RTCx, uint32_t Tamper) +{ + SET_BIT(RTCx->TAFCR, Tamper); +} + +/** + * @brief Clear RTC_TAMPx input detection + * @rmtoll TAFCR TAMP1E LL_RTC_TAMPER_Disable\n + * TAFCR TAMP2E LL_RTC_TAMPER_Disable\n + * TAFCR TAMP3E LL_RTC_TAMPER_Disable + * @param RTCx RTC Instance + * @param Tamper This parameter can be a combination of the following values: + * @arg @ref LL_RTC_TAMPER_1 + * @arg @ref LL_RTC_TAMPER_2 + * @arg @ref LL_RTC_TAMPER_3 (*) + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_Disable(RTC_TypeDef *RTCx, uint32_t Tamper) +{ + CLEAR_BIT(RTCx->TAFCR, Tamper); +} + +#if defined(RTC_TAFCR_TAMPPUDIS) +/** + * @brief Disable RTC_TAMPx pull-up disable (Disable precharge of RTC_TAMPx pins) + * @rmtoll TAFCR TAMPPUDIS LL_RTC_TAMPER_DisablePullUp + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_DisablePullUp(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPPUDIS); +} + +/** + * @brief Enable RTC_TAMPx pull-up disable ( Precharge RTC_TAMPx pins before sampling) + * @rmtoll TAFCR TAMPPUDIS LL_RTC_TAMPER_EnablePullUp + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_EnablePullUp(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPPUDIS); +} +#endif /* RTC_TAFCR_TAMPPUDIS */ + +#if defined(RTC_TAFCR_TAMPPRCH) +/** + * @brief Set RTC_TAMPx precharge duration + * @rmtoll TAFCR TAMPPRCH LL_RTC_TAMPER_SetPrecharge + * @param RTCx RTC Instance + * @param Duration This parameter can be one of the following values: + * @arg @ref LL_RTC_TAMPER_DURATION_1RTCCLK + * @arg @ref LL_RTC_TAMPER_DURATION_2RTCCLK + * @arg @ref LL_RTC_TAMPER_DURATION_4RTCCLK + * @arg @ref LL_RTC_TAMPER_DURATION_8RTCCLK + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_SetPrecharge(RTC_TypeDef *RTCx, uint32_t Duration) +{ + MODIFY_REG(RTCx->TAFCR, RTC_TAFCR_TAMPPRCH, Duration); +} + +/** + * @brief Get RTC_TAMPx precharge duration + * @rmtoll TAFCR TAMPPRCH LL_RTC_TAMPER_GetPrecharge + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_TAMPER_DURATION_1RTCCLK + * @arg @ref LL_RTC_TAMPER_DURATION_2RTCCLK + * @arg @ref LL_RTC_TAMPER_DURATION_4RTCCLK + * @arg @ref LL_RTC_TAMPER_DURATION_8RTCCLK + */ +__STATIC_INLINE uint32_t LL_RTC_TAMPER_GetPrecharge(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPPRCH)); +} +#endif /* RTC_TAFCR_TAMPPRCH */ + +#if defined(RTC_TAFCR_TAMPFLT) +/** + * @brief Set RTC_TAMPx filter count + * @rmtoll TAFCR TAMPFLT LL_RTC_TAMPER_SetFilterCount + * @param RTCx RTC Instance + * @param FilterCount This parameter can be one of the following values: + * @arg @ref LL_RTC_TAMPER_FILTER_DISABLE + * @arg @ref LL_RTC_TAMPER_FILTER_2SAMPLE + * @arg @ref LL_RTC_TAMPER_FILTER_4SAMPLE + * @arg @ref LL_RTC_TAMPER_FILTER_8SAMPLE + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_SetFilterCount(RTC_TypeDef *RTCx, uint32_t FilterCount) +{ + MODIFY_REG(RTCx->TAFCR, RTC_TAFCR_TAMPFLT, FilterCount); +} + +/** + * @brief Get RTC_TAMPx filter count + * @rmtoll TAFCR TAMPFLT LL_RTC_TAMPER_GetFilterCount + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_TAMPER_FILTER_DISABLE + * @arg @ref LL_RTC_TAMPER_FILTER_2SAMPLE + * @arg @ref LL_RTC_TAMPER_FILTER_4SAMPLE + * @arg @ref LL_RTC_TAMPER_FILTER_8SAMPLE + */ +__STATIC_INLINE uint32_t LL_RTC_TAMPER_GetFilterCount(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPFLT)); +} +#endif /* RTC_TAFCR_TAMPFLT */ + +#if defined(RTC_TAFCR_TAMPFREQ) +/** + * @brief Set Tamper sampling frequency + * @rmtoll TAFCR TAMPFREQ LL_RTC_TAMPER_SetSamplingFreq + * @param RTCx RTC Instance + * @param SamplingFreq This parameter can be one of the following values: + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_32768 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_16384 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_8192 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_4096 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_2048 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_1024 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_512 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_256 + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_SetSamplingFreq(RTC_TypeDef *RTCx, uint32_t SamplingFreq) +{ + MODIFY_REG(RTCx->TAFCR, RTC_TAFCR_TAMPFREQ, SamplingFreq); +} + +/** + * @brief Get Tamper sampling frequency + * @rmtoll TAFCR TAMPFREQ LL_RTC_TAMPER_GetSamplingFreq + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_32768 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_16384 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_8192 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_4096 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_2048 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_1024 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_512 + * @arg @ref LL_RTC_TAMPER_SAMPLFREQDIV_256 + */ +__STATIC_INLINE uint32_t LL_RTC_TAMPER_GetSamplingFreq(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPFREQ)); +} +#endif /* RTC_TAFCR_TAMPFREQ */ + +/** + * @brief Enable Active level for Tamper input + * @rmtoll TAFCR TAMP1TRG LL_RTC_TAMPER_EnableActiveLevel\n + * TAFCR TAMP2TRG LL_RTC_TAMPER_EnableActiveLevel\n + * TAFCR TAMP3TRG LL_RTC_TAMPER_EnableActiveLevel + * @param RTCx RTC Instance + * @param Tamper This parameter can be a combination of the following values: + * @arg @ref LL_RTC_TAMPER_ACTIVELEVEL_TAMP1 + * @arg @ref LL_RTC_TAMPER_ACTIVELEVEL_TAMP2 + * @arg @ref LL_RTC_TAMPER_ACTIVELEVEL_TAMP3 (*) + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_EnableActiveLevel(RTC_TypeDef *RTCx, uint32_t Tamper) +{ + SET_BIT(RTCx->TAFCR, Tamper); +} + +/** + * @brief Disable Active level for Tamper input + * @rmtoll TAFCR TAMP1TRG LL_RTC_TAMPER_DisableActiveLevel\n + * TAFCR TAMP2TRG LL_RTC_TAMPER_DisableActiveLevel\n + * TAFCR TAMP3TRG LL_RTC_TAMPER_DisableActiveLevel + * @param RTCx RTC Instance + * @param Tamper This parameter can be a combination of the following values: + * @arg @ref LL_RTC_TAMPER_ACTIVELEVEL_TAMP1 + * @arg @ref LL_RTC_TAMPER_ACTIVELEVEL_TAMP2 + * @arg @ref LL_RTC_TAMPER_ACTIVELEVEL_TAMP3 (*) + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_RTC_TAMPER_DisableActiveLevel(RTC_TypeDef *RTCx, uint32_t Tamper) +{ + CLEAR_BIT(RTCx->TAFCR, Tamper); +} + +/** + * @} + */ + +#if defined(RTC_WAKEUP_SUPPORT) +/** @defgroup RTC_LL_EF_Wakeup Wakeup + * @{ + */ + +/** + * @brief Enable Wakeup timer + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR WUTE LL_RTC_WAKEUP_Enable + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_WAKEUP_Enable(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_WUTE); +} + +/** + * @brief Disable Wakeup timer + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR WUTE LL_RTC_WAKEUP_Disable + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_WAKEUP_Disable(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_WUTE); +} + +/** + * @brief Check if Wakeup timer is enabled or not + * @rmtoll CR WUTE LL_RTC_WAKEUP_IsEnabled + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_WAKEUP_IsEnabled(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->CR, RTC_CR_WUTE) == (RTC_CR_WUTE)); +} + +/** + * @brief Select Wakeup clock + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note Bit can be written only when RTC_CR WUTE bit = 0 and RTC_ISR WUTWF bit = 1 + * @rmtoll CR WUCKSEL LL_RTC_WAKEUP_SetClock + * @param RTCx RTC Instance + * @param WakeupClock This parameter can be one of the following values: + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_16 + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_8 + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_4 + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_2 + * @arg @ref LL_RTC_WAKEUPCLOCK_CKSPRE + * @arg @ref LL_RTC_WAKEUPCLOCK_CKSPRE_WUT + * @retval None + */ +__STATIC_INLINE void LL_RTC_WAKEUP_SetClock(RTC_TypeDef *RTCx, uint32_t WakeupClock) +{ + MODIFY_REG(RTCx->CR, RTC_CR_WUCKSEL, WakeupClock); +} + +/** + * @brief Get Wakeup clock + * @rmtoll CR WUCKSEL LL_RTC_WAKEUP_GetClock + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_16 + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_8 + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_4 + * @arg @ref LL_RTC_WAKEUPCLOCK_DIV_2 + * @arg @ref LL_RTC_WAKEUPCLOCK_CKSPRE + * @arg @ref LL_RTC_WAKEUPCLOCK_CKSPRE_WUT + */ +__STATIC_INLINE uint32_t LL_RTC_WAKEUP_GetClock(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CR, RTC_CR_WUCKSEL)); +} + +/** + * @brief Set Wakeup auto-reload value + * @note Bit can be written only when WUTWF is set to 1 in RTC_ISR + * @rmtoll WUTR WUT LL_RTC_WAKEUP_SetAutoReload + * @param RTCx RTC Instance + * @param Value Value between Min_Data=0x00 and Max_Data=0xFFFF + * @retval None + */ +__STATIC_INLINE void LL_RTC_WAKEUP_SetAutoReload(RTC_TypeDef *RTCx, uint32_t Value) +{ + MODIFY_REG(RTCx->WUTR, RTC_WUTR_WUT, Value); +} + +/** + * @brief Get Wakeup auto-reload value + * @rmtoll WUTR WUT LL_RTC_WAKEUP_GetAutoReload + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data=0xFFFF + */ +__STATIC_INLINE uint32_t LL_RTC_WAKEUP_GetAutoReload(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->WUTR, RTC_WUTR_WUT)); +} + +/** + * @} + */ +#endif /* RTC_WAKEUP_SUPPORT */ + +#if defined(RTC_BACKUP_SUPPORT) +/** @defgroup RTC_LL_EF_Backup_Registers Backup_Registers + * @{ + */ + +/** + * @brief Writes a data in a specified RTC Backup data register. + * @rmtoll BKPxR BKP LL_RTC_BAK_SetRegister + * @param RTCx RTC Instance + * @param BackupRegister This parameter can be one of the following values: + * @arg @ref LL_RTC_BKP_DR0 + * @arg @ref LL_RTC_BKP_DR1 + * @arg @ref LL_RTC_BKP_DR2 + * @arg @ref LL_RTC_BKP_DR3 + * @arg @ref LL_RTC_BKP_DR4 + * @param Data Value between Min_Data=0x00 and Max_Data=0xFFFFFFFF + * @retval None + */ +__STATIC_INLINE void LL_RTC_BAK_SetRegister(RTC_TypeDef *RTCx, uint32_t BackupRegister, uint32_t Data) +{ + uint32_t tmp = 0U; + + tmp = (uint32_t)(&(RTCx->BKP0R)); + tmp += (BackupRegister * 4U); + + /* Write the specified register */ + *(__IO uint32_t *)tmp = (uint32_t)Data; +} + +/** + * @brief Reads data from the specified RTC Backup data Register. + * @rmtoll BKPxR BKP LL_RTC_BAK_GetRegister + * @param RTCx RTC Instance + * @param BackupRegister This parameter can be one of the following values: + * @arg @ref LL_RTC_BKP_DR0 + * @arg @ref LL_RTC_BKP_DR1 + * @arg @ref LL_RTC_BKP_DR2 + * @arg @ref LL_RTC_BKP_DR3 + * @arg @ref LL_RTC_BKP_DR4 + * @retval Value between Min_Data=0x00 and Max_Data=0xFFFFFFFF + */ +__STATIC_INLINE uint32_t LL_RTC_BAK_GetRegister(RTC_TypeDef *RTCx, uint32_t BackupRegister) +{ + uint32_t tmp = 0U; + + tmp = (uint32_t)(&(RTCx->BKP0R)); + tmp += (BackupRegister * 4U); + + /* Read the specified register */ + return (*(__IO uint32_t *)tmp); +} + +/** + * @} + */ +#endif /* RTC_BACKUP_SUPPORT */ + +/** @defgroup RTC_LL_EF_Calibration Calibration + * @{ + */ + +/** + * @brief Set Calibration output frequency (1 Hz or 512 Hz) + * @note Bits are write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR COE LL_RTC_CAL_SetOutputFreq\n + * CR COSEL LL_RTC_CAL_SetOutputFreq + * @param RTCx RTC Instance + * @param Frequency This parameter can be one of the following values: + * @arg @ref LL_RTC_CALIB_OUTPUT_NONE + * @arg @ref LL_RTC_CALIB_OUTPUT_1HZ + * @arg @ref LL_RTC_CALIB_OUTPUT_512HZ + * @retval None + */ +__STATIC_INLINE void LL_RTC_CAL_SetOutputFreq(RTC_TypeDef *RTCx, uint32_t Frequency) +{ + MODIFY_REG(RTCx->CR, RTC_CR_COE | RTC_CR_COSEL, Frequency); +} + +/** + * @brief Get Calibration output frequency (1 Hz or 512 Hz) + * @rmtoll CR COE LL_RTC_CAL_GetOutputFreq\n + * CR COSEL LL_RTC_CAL_GetOutputFreq + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_CALIB_OUTPUT_NONE + * @arg @ref LL_RTC_CALIB_OUTPUT_1HZ + * @arg @ref LL_RTC_CALIB_OUTPUT_512HZ + */ +__STATIC_INLINE uint32_t LL_RTC_CAL_GetOutputFreq(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CR, RTC_CR_COE | RTC_CR_COSEL)); +} + +/** + * @brief Insert or not One RTCCLK pulse every 2exp11 pulses (frequency increased by 488.5 ppm) + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note Bit can be written only when RECALPF is set to 0 in RTC_ISR + * @rmtoll CALR CALP LL_RTC_CAL_SetPulse + * @param RTCx RTC Instance + * @param Pulse This parameter can be one of the following values: + * @arg @ref LL_RTC_CALIB_INSERTPULSE_NONE + * @arg @ref LL_RTC_CALIB_INSERTPULSE_SET + * @retval None + */ +__STATIC_INLINE void LL_RTC_CAL_SetPulse(RTC_TypeDef *RTCx, uint32_t Pulse) +{ + MODIFY_REG(RTCx->CALR, RTC_CALR_CALP, Pulse); +} + +/** + * @brief Check if one RTCCLK has been inserted or not every 2exp11 pulses (frequency increased by 488.5 ppm) + * @rmtoll CALR CALP LL_RTC_CAL_IsPulseInserted + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_CAL_IsPulseInserted(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->CALR, RTC_CALR_CALP) == (RTC_CALR_CALP)); +} + +/** + * @brief Set the calibration cycle period + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note Bit can be written only when RECALPF is set to 0 in RTC_ISR + * @rmtoll CALR CALW8 LL_RTC_CAL_SetPeriod\n + * CALR CALW16 LL_RTC_CAL_SetPeriod + * @param RTCx RTC Instance + * @param Period This parameter can be one of the following values: + * @arg @ref LL_RTC_CALIB_PERIOD_32SEC + * @arg @ref LL_RTC_CALIB_PERIOD_16SEC + * @arg @ref LL_RTC_CALIB_PERIOD_8SEC + * @retval None + */ +__STATIC_INLINE void LL_RTC_CAL_SetPeriod(RTC_TypeDef *RTCx, uint32_t Period) +{ + MODIFY_REG(RTCx->CALR, RTC_CALR_CALW8 | RTC_CALR_CALW16, Period); +} + +/** + * @brief Get the calibration cycle period + * @rmtoll CALR CALW8 LL_RTC_CAL_GetPeriod\n + * CALR CALW16 LL_RTC_CAL_GetPeriod + * @param RTCx RTC Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_RTC_CALIB_PERIOD_32SEC + * @arg @ref LL_RTC_CALIB_PERIOD_16SEC + * @arg @ref LL_RTC_CALIB_PERIOD_8SEC + */ +__STATIC_INLINE uint32_t LL_RTC_CAL_GetPeriod(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CALR, RTC_CALR_CALW8 | RTC_CALR_CALW16)); +} + +/** + * @brief Set Calibration minus + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @note Bit can be written only when RECALPF is set to 0 in RTC_ISR + * @rmtoll CALR CALM LL_RTC_CAL_SetMinus + * @param RTCx RTC Instance + * @param CalibMinus Value between Min_Data=0x00 and Max_Data=0x1FF + * @retval None + */ +__STATIC_INLINE void LL_RTC_CAL_SetMinus(RTC_TypeDef *RTCx, uint32_t CalibMinus) +{ + MODIFY_REG(RTCx->CALR, RTC_CALR_CALM, CalibMinus); +} + +/** + * @brief Get Calibration minus + * @rmtoll CALR CALM LL_RTC_CAL_GetMinus + * @param RTCx RTC Instance + * @retval Value between Min_Data=0x00 and Max_Data= 0x1FF + */ +__STATIC_INLINE uint32_t LL_RTC_CAL_GetMinus(RTC_TypeDef *RTCx) +{ + return (uint32_t)(READ_BIT(RTCx->CALR, RTC_CALR_CALM)); +} + +/** + * @} + */ + +/** @defgroup RTC_LL_EF_FLAG_Management FLAG_Management + * @{ + */ + +/** + * @brief Get Recalibration pending Flag + * @rmtoll ISR RECALPF LL_RTC_IsActiveFlag_RECALP + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_RECALP(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_RECALPF) == (RTC_ISR_RECALPF)); +} + +#if defined(RTC_TAMPER3_SUPPORT) +/** + * @brief Get RTC_TAMP3 detection flag + * @rmtoll ISR TAMP3F LL_RTC_IsActiveFlag_TAMP3 + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_TAMP3(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_TAMP3F) == (RTC_ISR_TAMP3F)); +} +#endif /* RTC_TAMPER3_SUPPORT */ + +#if defined(RTC_TAMPER2_SUPPORT) +/** + * @brief Get RTC_TAMP2 detection flag + * @rmtoll ISR TAMP2F LL_RTC_IsActiveFlag_TAMP2 + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_TAMP2(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_TAMP2F) == (RTC_ISR_TAMP2F)); +} +#endif /* RTC_TAMPER2_SUPPORT */ + +#if defined(RTC_TAMPER1_SUPPORT) +/** + * @brief Get RTC_TAMP1 detection flag + * @rmtoll ISR TAMP1F LL_RTC_IsActiveFlag_TAMP1 + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_TAMP1(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_TAMP1F) == (RTC_ISR_TAMP1F)); +} +#endif /* RTC_TAMPER1_SUPPORT */ + +/** + * @brief Get Time-stamp overflow flag + * @rmtoll ISR TSOVF LL_RTC_IsActiveFlag_TSOV + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_TSOV(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_TSOVF) == (RTC_ISR_TSOVF)); +} + +/** + * @brief Get Time-stamp flag + * @rmtoll ISR TSF LL_RTC_IsActiveFlag_TS + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_TS(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_TSF) == (RTC_ISR_TSF)); +} + +#if defined(RTC_WAKEUP_SUPPORT) +/** + * @brief Get Wakeup timer flag + * @rmtoll ISR WUTF LL_RTC_IsActiveFlag_WUT + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_WUT(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_WUTF) == (RTC_ISR_WUTF)); +} +#endif /* RTC_WAKEUP_SUPPORT */ + +/** + * @brief Get Alarm A flag + * @rmtoll ISR ALRAF LL_RTC_IsActiveFlag_ALRA + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_ALRA(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_ALRAF) == (RTC_ISR_ALRAF)); +} + +#if defined(RTC_TAMPER3_SUPPORT) +/** + * @brief Clear RTC_TAMP3 detection flag + * @rmtoll ISR TAMP3F LL_RTC_ClearFlag_TAMP3 + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_TAMP3(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_TAMP3F | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} +#endif /* RTC_TAMPER3_SUPPORT */ + +#if defined(RTC_TAMPER2_SUPPORT) +/** + * @brief Clear RTC_TAMP2 detection flag + * @rmtoll ISR TAMP2F LL_RTC_ClearFlag_TAMP2 + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_TAMP2(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_TAMP2F | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} +#endif /* RTC_TAMPER2_SUPPORT */ + +#if defined(RTC_TAMPER1_SUPPORT) +/** + * @brief Clear RTC_TAMP1 detection flag + * @rmtoll ISR TAMP1F LL_RTC_ClearFlag_TAMP1 + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_TAMP1(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_TAMP1F | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} +#endif /* RTC_TAMPER1_SUPPORT */ + +/** + * @brief Clear Time-stamp overflow flag + * @rmtoll ISR TSOVF LL_RTC_ClearFlag_TSOV + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_TSOV(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_TSOVF | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} + +/** + * @brief Clear Time-stamp flag + * @rmtoll ISR TSF LL_RTC_ClearFlag_TS + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_TS(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_TSF | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} + +#if defined(RTC_WAKEUP_SUPPORT) +/** + * @brief Clear Wakeup timer flag + * @rmtoll ISR WUTF LL_RTC_ClearFlag_WUT + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_WUT(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_WUTF | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} +#endif /* RTC_WAKEUP_SUPPORT */ + +/** + * @brief Clear Alarm A flag + * @rmtoll ISR ALRAF LL_RTC_ClearFlag_ALRA + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_ALRA(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_ALRAF | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} + +/** + * @brief Get Initialization flag + * @rmtoll ISR INITF LL_RTC_IsActiveFlag_INIT + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_INIT(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_INITF) == (RTC_ISR_INITF)); +} + +/** + * @brief Get Registers synchronization flag + * @rmtoll ISR RSF LL_RTC_IsActiveFlag_RS + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_RS(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_RSF) == (RTC_ISR_RSF)); +} + +/** + * @brief Clear Registers synchronization flag + * @rmtoll ISR RSF LL_RTC_ClearFlag_RS + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_ClearFlag_RS(RTC_TypeDef *RTCx) +{ + WRITE_REG(RTCx->ISR, (~((RTC_ISR_RSF | RTC_ISR_INIT) & 0x0000FFFFU) | (RTCx->ISR & RTC_ISR_INIT))); +} + +/** + * @brief Get Initialization status flag + * @rmtoll ISR INITS LL_RTC_IsActiveFlag_INITS + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_INITS(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_INITS) == (RTC_ISR_INITS)); +} + +/** + * @brief Get Shift operation pending flag + * @rmtoll ISR SHPF LL_RTC_IsActiveFlag_SHP + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_SHP(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_SHPF) == (RTC_ISR_SHPF)); +} + +#if defined(RTC_WAKEUP_SUPPORT) +/** + * @brief Get Wakeup timer write flag + * @rmtoll ISR WUTWF LL_RTC_IsActiveFlag_WUTW + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_WUTW(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_WUTWF) == (RTC_ISR_WUTWF)); +} +#endif /* RTC_WAKEUP_SUPPORT */ + +/** + * @brief Get Alarm A write flag + * @rmtoll ISR ALRAWF LL_RTC_IsActiveFlag_ALRAW + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsActiveFlag_ALRAW(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->ISR, RTC_ISR_ALRAWF) == (RTC_ISR_ALRAWF)); +} + +/** + * @} + */ + +/** @defgroup RTC_LL_EF_IT_Management IT_Management + * @{ + */ + +/** + * @brief Enable Time-stamp interrupt + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR TSIE LL_RTC_EnableIT_TS + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableIT_TS(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_TSIE); +} + +/** + * @brief Disable Time-stamp interrupt + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR TSIE LL_RTC_DisableIT_TS + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableIT_TS(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_TSIE); +} + +#if defined(RTC_WAKEUP_SUPPORT) +/** + * @brief Enable Wakeup timer interrupt + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR WUTIE LL_RTC_EnableIT_WUT + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableIT_WUT(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_WUTIE); +} + +/** + * @brief Disable Wakeup timer interrupt + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR WUTIE LL_RTC_DisableIT_WUT + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableIT_WUT(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_WUTIE); +} +#endif /* RTC_WAKEUP_SUPPORT */ + +/** + * @brief Enable Alarm A interrupt + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR ALRAIE LL_RTC_EnableIT_ALRA + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableIT_ALRA(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->CR, RTC_CR_ALRAIE); +} + +/** + * @brief Disable Alarm A interrupt + * @note Bit is write-protected. @ref LL_RTC_DisableWriteProtection function should be called before. + * @rmtoll CR ALRAIE LL_RTC_DisableIT_ALRA + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableIT_ALRA(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->CR, RTC_CR_ALRAIE); +} + +/** + * @brief Enable all Tamper Interrupt + * @rmtoll TAFCR TAMPIE LL_RTC_EnableIT_TAMP + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_EnableIT_TAMP(RTC_TypeDef *RTCx) +{ + SET_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPIE); +} + +/** + * @brief Disable all Tamper Interrupt + * @rmtoll TAFCR TAMPIE LL_RTC_DisableIT_TAMP + * @param RTCx RTC Instance + * @retval None + */ +__STATIC_INLINE void LL_RTC_DisableIT_TAMP(RTC_TypeDef *RTCx) +{ + CLEAR_BIT(RTCx->TAFCR, RTC_TAFCR_TAMPIE); +} + +/** + * @brief Check if Time-stamp interrupt is enabled or not + * @rmtoll CR TSIE LL_RTC_IsEnabledIT_TS + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsEnabledIT_TS(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->CR, RTC_CR_TSIE) == (RTC_CR_TSIE)); +} + +#if defined(RTC_WAKEUP_SUPPORT) +/** + * @brief Check if Wakeup timer interrupt is enabled or not + * @rmtoll CR WUTIE LL_RTC_IsEnabledIT_WUT + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsEnabledIT_WUT(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->CR, RTC_CR_WUTIE) == (RTC_CR_WUTIE)); +} +#endif /* RTC_WAKEUP_SUPPORT */ + +/** + * @brief Check if Alarm A interrupt is enabled or not + * @rmtoll CR ALRAIE LL_RTC_IsEnabledIT_ALRA + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsEnabledIT_ALRA(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->CR, RTC_CR_ALRAIE) == (RTC_CR_ALRAIE)); +} + +/** + * @brief Check if all the TAMPER interrupts are enabled or not + * @rmtoll TAFCR TAMPIE LL_RTC_IsEnabledIT_TAMP + * @param RTCx RTC Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_RTC_IsEnabledIT_TAMP(RTC_TypeDef *RTCx) +{ + return (READ_BIT(RTCx->TAFCR, + RTC_TAFCR_TAMPIE) == (RTC_TAFCR_TAMPIE)); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup RTC_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_RTC_DeInit(RTC_TypeDef *RTCx); +ErrorStatus LL_RTC_Init(RTC_TypeDef *RTCx, LL_RTC_InitTypeDef *RTC_InitStruct); +void LL_RTC_StructInit(LL_RTC_InitTypeDef *RTC_InitStruct); +ErrorStatus LL_RTC_TIME_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_TimeTypeDef *RTC_TimeStruct); +void LL_RTC_TIME_StructInit(LL_RTC_TimeTypeDef *RTC_TimeStruct); +ErrorStatus LL_RTC_DATE_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_DateTypeDef *RTC_DateStruct); +void LL_RTC_DATE_StructInit(LL_RTC_DateTypeDef *RTC_DateStruct); +ErrorStatus LL_RTC_ALMA_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_AlarmTypeDef *RTC_AlarmStruct); +void LL_RTC_ALMA_StructInit(LL_RTC_AlarmTypeDef *RTC_AlarmStruct); +ErrorStatus LL_RTC_EnterInitMode(RTC_TypeDef *RTCx); +ErrorStatus LL_RTC_ExitInitMode(RTC_TypeDef *RTCx); +ErrorStatus LL_RTC_WaitForSynchro(RTC_TypeDef *RTCx); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(RTC) */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_RTC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_spi.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_spi.h new file mode 100644 index 0000000..606d793 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_spi.h @@ -0,0 +1,2286 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_spi.h + * @author MCD Application Team + * @brief Header file of SPI LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_LL_SPI_H +#define STM32F0xx_LL_SPI_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (SPI1) || defined (SPI2) + +/** @defgroup SPI_LL SPI + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup SPI_LL_ES_INIT SPI Exported Init structure + * @{ + */ + +/** + * @brief SPI Init structures definition + */ +typedef struct +{ + uint32_t TransferDirection; /*!< Specifies the SPI unidirectional or bidirectional data mode. + This parameter can be a value of @ref SPI_LL_EC_TRANSFER_MODE. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetTransferDirection().*/ + + uint32_t Mode; /*!< Specifies the SPI mode (Master/Slave). + This parameter can be a value of @ref SPI_LL_EC_MODE. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetMode().*/ + + uint32_t DataWidth; /*!< Specifies the SPI data width. + This parameter can be a value of @ref SPI_LL_EC_DATAWIDTH. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetDataWidth().*/ + + uint32_t ClockPolarity; /*!< Specifies the serial clock steady state. + This parameter can be a value of @ref SPI_LL_EC_POLARITY. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetClockPolarity().*/ + + uint32_t ClockPhase; /*!< Specifies the clock active edge for the bit capture. + This parameter can be a value of @ref SPI_LL_EC_PHASE. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetClockPhase().*/ + + uint32_t NSS; /*!< Specifies whether the NSS signal is managed by hardware (NSS pin) or by software using the SSI bit. + This parameter can be a value of @ref SPI_LL_EC_NSS_MODE. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetNSSMode().*/ + + uint32_t BaudRate; /*!< Specifies the BaudRate prescaler value which will be used to configure the transmit and receive SCK clock. + This parameter can be a value of @ref SPI_LL_EC_BAUDRATEPRESCALER. + @note The communication clock is derived from the master clock. The slave clock does not need to be set. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetBaudRatePrescaler().*/ + + uint32_t BitOrder; /*!< Specifies whether data transfers start from MSB or LSB bit. + This parameter can be a value of @ref SPI_LL_EC_BIT_ORDER. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetTransferBitOrder().*/ + + uint32_t CRCCalculation; /*!< Specifies if the CRC calculation is enabled or not. + This parameter can be a value of @ref SPI_LL_EC_CRC_CALCULATION. + + This feature can be modified afterwards using unitary functions @ref LL_SPI_EnableCRC() and @ref LL_SPI_DisableCRC().*/ + + uint32_t CRCPoly; /*!< Specifies the polynomial used for the CRC calculation. + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFFFF. + + This feature can be modified afterwards using unitary function @ref LL_SPI_SetCRCPolynomial().*/ + +} LL_SPI_InitTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup SPI_LL_Exported_Constants SPI Exported Constants + * @{ + */ + +/** @defgroup SPI_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_SPI_ReadReg function + * @{ + */ +#define LL_SPI_SR_RXNE SPI_SR_RXNE /*!< Rx buffer not empty flag */ +#define LL_SPI_SR_TXE SPI_SR_TXE /*!< Tx buffer empty flag */ +#define LL_SPI_SR_BSY SPI_SR_BSY /*!< Busy flag */ +#define LL_SPI_SR_CRCERR SPI_SR_CRCERR /*!< CRC error flag */ +#define LL_SPI_SR_MODF SPI_SR_MODF /*!< Mode fault flag */ +#define LL_SPI_SR_OVR SPI_SR_OVR /*!< Overrun flag */ +#define LL_SPI_SR_FRE SPI_SR_FRE /*!< TI mode frame format error flag */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_SPI_ReadReg and LL_SPI_WriteReg functions + * @{ + */ +#define LL_SPI_CR2_RXNEIE SPI_CR2_RXNEIE /*!< Rx buffer not empty interrupt enable */ +#define LL_SPI_CR2_TXEIE SPI_CR2_TXEIE /*!< Tx buffer empty interrupt enable */ +#define LL_SPI_CR2_ERRIE SPI_CR2_ERRIE /*!< Error interrupt enable */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_MODE Operation Mode + * @{ + */ +#define LL_SPI_MODE_MASTER (SPI_CR1_MSTR | SPI_CR1_SSI) /*!< Master configuration */ +#define LL_SPI_MODE_SLAVE 0x00000000U /*!< Slave configuration */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_PROTOCOL Serial Protocol + * @{ + */ +#define LL_SPI_PROTOCOL_MOTOROLA 0x00000000U /*!< Motorola mode. Used as default value */ +#define LL_SPI_PROTOCOL_TI (SPI_CR2_FRF) /*!< TI mode */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_PHASE Clock Phase + * @{ + */ +#define LL_SPI_PHASE_1EDGE 0x00000000U /*!< First clock transition is the first data capture edge */ +#define LL_SPI_PHASE_2EDGE (SPI_CR1_CPHA) /*!< Second clock transition is the first data capture edge */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_POLARITY Clock Polarity + * @{ + */ +#define LL_SPI_POLARITY_LOW 0x00000000U /*!< Clock to 0 when idle */ +#define LL_SPI_POLARITY_HIGH (SPI_CR1_CPOL) /*!< Clock to 1 when idle */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_BAUDRATEPRESCALER Baud Rate Prescaler + * @{ + */ +#define LL_SPI_BAUDRATEPRESCALER_DIV2 0x00000000U /*!< BaudRate control equal to fPCLK/2 */ +#define LL_SPI_BAUDRATEPRESCALER_DIV4 (SPI_CR1_BR_0) /*!< BaudRate control equal to fPCLK/4 */ +#define LL_SPI_BAUDRATEPRESCALER_DIV8 (SPI_CR1_BR_1) /*!< BaudRate control equal to fPCLK/8 */ +#define LL_SPI_BAUDRATEPRESCALER_DIV16 (SPI_CR1_BR_1 | SPI_CR1_BR_0) /*!< BaudRate control equal to fPCLK/16 */ +#define LL_SPI_BAUDRATEPRESCALER_DIV32 (SPI_CR1_BR_2) /*!< BaudRate control equal to fPCLK/32 */ +#define LL_SPI_BAUDRATEPRESCALER_DIV64 (SPI_CR1_BR_2 | SPI_CR1_BR_0) /*!< BaudRate control equal to fPCLK/64 */ +#define LL_SPI_BAUDRATEPRESCALER_DIV128 (SPI_CR1_BR_2 | SPI_CR1_BR_1) /*!< BaudRate control equal to fPCLK/128 */ +#define LL_SPI_BAUDRATEPRESCALER_DIV256 (SPI_CR1_BR_2 | SPI_CR1_BR_1 | SPI_CR1_BR_0) /*!< BaudRate control equal to fPCLK/256 */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_BIT_ORDER Transmission Bit Order + * @{ + */ +#define LL_SPI_LSB_FIRST (SPI_CR1_LSBFIRST) /*!< Data is transmitted/received with the LSB first */ +#define LL_SPI_MSB_FIRST 0x00000000U /*!< Data is transmitted/received with the MSB first */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_TRANSFER_MODE Transfer Mode + * @{ + */ +#define LL_SPI_FULL_DUPLEX 0x00000000U /*!< Full-Duplex mode. Rx and Tx transfer on 2 lines */ +#define LL_SPI_SIMPLEX_RX (SPI_CR1_RXONLY) /*!< Simplex Rx mode. Rx transfer only on 1 line */ +#define LL_SPI_HALF_DUPLEX_RX (SPI_CR1_BIDIMODE) /*!< Half-Duplex Rx mode. Rx transfer on 1 line */ +#define LL_SPI_HALF_DUPLEX_TX (SPI_CR1_BIDIMODE | SPI_CR1_BIDIOE) /*!< Half-Duplex Tx mode. Tx transfer on 1 line */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_NSS_MODE Slave Select Pin Mode + * @{ + */ +#define LL_SPI_NSS_SOFT (SPI_CR1_SSM) /*!< NSS managed internally. NSS pin not used and free */ +#define LL_SPI_NSS_HARD_INPUT 0x00000000U /*!< NSS pin used in Input. Only used in Master mode */ +#define LL_SPI_NSS_HARD_OUTPUT (((uint32_t)SPI_CR2_SSOE << 16U)) /*!< NSS pin used in Output. Only used in Slave mode as chip select */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_DATAWIDTH Datawidth + * @{ + */ +#define LL_SPI_DATAWIDTH_4BIT (SPI_CR2_DS_0 | SPI_CR2_DS_1) /*!< Data length for SPI transfer: 4 bits */ +#define LL_SPI_DATAWIDTH_5BIT (SPI_CR2_DS_2) /*!< Data length for SPI transfer: 5 bits */ +#define LL_SPI_DATAWIDTH_6BIT (SPI_CR2_DS_2 | SPI_CR2_DS_0) /*!< Data length for SPI transfer: 6 bits */ +#define LL_SPI_DATAWIDTH_7BIT (SPI_CR2_DS_2 | SPI_CR2_DS_1) /*!< Data length for SPI transfer: 7 bits */ +#define LL_SPI_DATAWIDTH_8BIT (SPI_CR2_DS_2 | SPI_CR2_DS_1 | SPI_CR2_DS_0) /*!< Data length for SPI transfer: 8 bits */ +#define LL_SPI_DATAWIDTH_9BIT (SPI_CR2_DS_3) /*!< Data length for SPI transfer: 9 bits */ +#define LL_SPI_DATAWIDTH_10BIT (SPI_CR2_DS_3 | SPI_CR2_DS_0) /*!< Data length for SPI transfer: 10 bits */ +#define LL_SPI_DATAWIDTH_11BIT (SPI_CR2_DS_3 | SPI_CR2_DS_1) /*!< Data length for SPI transfer: 11 bits */ +#define LL_SPI_DATAWIDTH_12BIT (SPI_CR2_DS_3 | SPI_CR2_DS_1 | SPI_CR2_DS_0) /*!< Data length for SPI transfer: 12 bits */ +#define LL_SPI_DATAWIDTH_13BIT (SPI_CR2_DS_3 | SPI_CR2_DS_2) /*!< Data length for SPI transfer: 13 bits */ +#define LL_SPI_DATAWIDTH_14BIT (SPI_CR2_DS_3 | SPI_CR2_DS_2 | SPI_CR2_DS_0) /*!< Data length for SPI transfer: 14 bits */ +#define LL_SPI_DATAWIDTH_15BIT (SPI_CR2_DS_3 | SPI_CR2_DS_2 | SPI_CR2_DS_1) /*!< Data length for SPI transfer: 15 bits */ +#define LL_SPI_DATAWIDTH_16BIT (SPI_CR2_DS_3 | SPI_CR2_DS_2 | SPI_CR2_DS_1 | SPI_CR2_DS_0) /*!< Data length for SPI transfer: 16 bits */ +/** + * @} + */ +#if defined(USE_FULL_LL_DRIVER) + +/** @defgroup SPI_LL_EC_CRC_CALCULATION CRC Calculation + * @{ + */ +#define LL_SPI_CRCCALCULATION_DISABLE 0x00000000U /*!< CRC calculation disabled */ +#define LL_SPI_CRCCALCULATION_ENABLE (SPI_CR1_CRCEN) /*!< CRC calculation enabled */ +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** @defgroup SPI_LL_EC_CRC_LENGTH CRC Length + * @{ + */ +#define LL_SPI_CRC_8BIT 0x00000000U /*!< 8-bit CRC length */ +#define LL_SPI_CRC_16BIT (SPI_CR1_CRCL) /*!< 16-bit CRC length */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_RX_FIFO_TH RX FIFO Threshold + * @{ + */ +#define LL_SPI_RX_FIFO_TH_HALF 0x00000000U /*!< RXNE event is generated if FIFO level is greater than or equal to 1/2 (16-bit) */ +#define LL_SPI_RX_FIFO_TH_QUARTER (SPI_CR2_FRXTH) /*!< RXNE event is generated if FIFO level is greater than or equal to 1/4 (8-bit) */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_RX_FIFO RX FIFO Level + * @{ + */ +#define LL_SPI_RX_FIFO_EMPTY 0x00000000U /*!< FIFO reception empty */ +#define LL_SPI_RX_FIFO_QUARTER_FULL (SPI_SR_FRLVL_0) /*!< FIFO reception 1/4 */ +#define LL_SPI_RX_FIFO_HALF_FULL (SPI_SR_FRLVL_1) /*!< FIFO reception 1/2 */ +#define LL_SPI_RX_FIFO_FULL (SPI_SR_FRLVL_1 | SPI_SR_FRLVL_0) /*!< FIFO reception full */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_TX_FIFO TX FIFO Level + * @{ + */ +#define LL_SPI_TX_FIFO_EMPTY 0x00000000U /*!< FIFO transmission empty */ +#define LL_SPI_TX_FIFO_QUARTER_FULL (SPI_SR_FTLVL_0) /*!< FIFO transmission 1/4 */ +#define LL_SPI_TX_FIFO_HALF_FULL (SPI_SR_FTLVL_1) /*!< FIFO transmission 1/2 */ +#define LL_SPI_TX_FIFO_FULL (SPI_SR_FTLVL_1 | SPI_SR_FTLVL_0) /*!< FIFO transmission full */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_DMA_PARITY DMA Parity + * @{ + */ +#define LL_SPI_DMA_PARITY_EVEN 0x00000000U /*!< Select DMA parity Even */ +#define LL_SPI_DMA_PARITY_ODD 0x00000001U /*!< Select DMA parity Odd */ + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup SPI_LL_Exported_Macros SPI Exported Macros + * @{ + */ + +/** @defgroup SPI_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in SPI register + * @param __INSTANCE__ SPI Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_SPI_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in SPI register + * @param __INSTANCE__ SPI Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_SPI_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup SPI_LL_Exported_Functions SPI Exported Functions + * @{ + */ + +/** @defgroup SPI_LL_EF_Configuration Configuration + * @{ + */ + +/** + * @brief Enable SPI peripheral + * @rmtoll CR1 SPE LL_SPI_Enable + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_Enable(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR1, SPI_CR1_SPE); +} + +/** + * @brief Disable SPI peripheral + * @note When disabling the SPI, follow the procedure described in the Reference Manual. + * @rmtoll CR1 SPE LL_SPI_Disable + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_Disable(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR1, SPI_CR1_SPE); +} + +/** + * @brief Check if SPI peripheral is enabled + * @rmtoll CR1 SPE LL_SPI_IsEnabled + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabled(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR1, SPI_CR1_SPE) == (SPI_CR1_SPE)) ? 1UL : 0UL); +} + +/** + * @brief Set SPI operation mode to Master or Slave + * @note This bit should not be changed when communication is ongoing. + * @rmtoll CR1 MSTR LL_SPI_SetMode\n + * CR1 SSI LL_SPI_SetMode + * @param SPIx SPI Instance + * @param Mode This parameter can be one of the following values: + * @arg @ref LL_SPI_MODE_MASTER + * @arg @ref LL_SPI_MODE_SLAVE + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetMode(SPI_TypeDef *SPIx, uint32_t Mode) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_MSTR | SPI_CR1_SSI, Mode); +} + +/** + * @brief Get SPI operation mode (Master or Slave) + * @rmtoll CR1 MSTR LL_SPI_GetMode\n + * CR1 SSI LL_SPI_GetMode + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_MODE_MASTER + * @arg @ref LL_SPI_MODE_SLAVE + */ +__STATIC_INLINE uint32_t LL_SPI_GetMode(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR1, SPI_CR1_MSTR | SPI_CR1_SSI)); +} + +/** + * @brief Set serial protocol used + * @note This bit should be written only when SPI is disabled (SPE = 0) for correct operation. + * @rmtoll CR2 FRF LL_SPI_SetStandard + * @param SPIx SPI Instance + * @param Standard This parameter can be one of the following values: + * @arg @ref LL_SPI_PROTOCOL_MOTOROLA + * @arg @ref LL_SPI_PROTOCOL_TI + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetStandard(SPI_TypeDef *SPIx, uint32_t Standard) +{ + MODIFY_REG(SPIx->CR2, SPI_CR2_FRF, Standard); +} + +/** + * @brief Get serial protocol used + * @rmtoll CR2 FRF LL_SPI_GetStandard + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_PROTOCOL_MOTOROLA + * @arg @ref LL_SPI_PROTOCOL_TI + */ +__STATIC_INLINE uint32_t LL_SPI_GetStandard(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR2, SPI_CR2_FRF)); +} + +/** + * @brief Set clock phase + * @note This bit should not be changed when communication is ongoing. + * This bit is not used in SPI TI mode. + * @rmtoll CR1 CPHA LL_SPI_SetClockPhase + * @param SPIx SPI Instance + * @param ClockPhase This parameter can be one of the following values: + * @arg @ref LL_SPI_PHASE_1EDGE + * @arg @ref LL_SPI_PHASE_2EDGE + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetClockPhase(SPI_TypeDef *SPIx, uint32_t ClockPhase) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_CPHA, ClockPhase); +} + +/** + * @brief Get clock phase + * @rmtoll CR1 CPHA LL_SPI_GetClockPhase + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_PHASE_1EDGE + * @arg @ref LL_SPI_PHASE_2EDGE + */ +__STATIC_INLINE uint32_t LL_SPI_GetClockPhase(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR1, SPI_CR1_CPHA)); +} + +/** + * @brief Set clock polarity + * @note This bit should not be changed when communication is ongoing. + * This bit is not used in SPI TI mode. + * @rmtoll CR1 CPOL LL_SPI_SetClockPolarity + * @param SPIx SPI Instance + * @param ClockPolarity This parameter can be one of the following values: + * @arg @ref LL_SPI_POLARITY_LOW + * @arg @ref LL_SPI_POLARITY_HIGH + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetClockPolarity(SPI_TypeDef *SPIx, uint32_t ClockPolarity) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_CPOL, ClockPolarity); +} + +/** + * @brief Get clock polarity + * @rmtoll CR1 CPOL LL_SPI_GetClockPolarity + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_POLARITY_LOW + * @arg @ref LL_SPI_POLARITY_HIGH + */ +__STATIC_INLINE uint32_t LL_SPI_GetClockPolarity(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR1, SPI_CR1_CPOL)); +} + +/** + * @brief Set baud rate prescaler + * @note These bits should not be changed when communication is ongoing. SPI BaudRate = fPCLK/Prescaler. + * @rmtoll CR1 BR LL_SPI_SetBaudRatePrescaler + * @param SPIx SPI Instance + * @param BaudRate This parameter can be one of the following values: + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV2 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV4 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV8 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV16 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV32 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV64 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV128 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV256 + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetBaudRatePrescaler(SPI_TypeDef *SPIx, uint32_t BaudRate) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_BR, BaudRate); +} + +/** + * @brief Get baud rate prescaler + * @rmtoll CR1 BR LL_SPI_GetBaudRatePrescaler + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV2 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV4 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV8 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV16 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV32 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV64 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV128 + * @arg @ref LL_SPI_BAUDRATEPRESCALER_DIV256 + */ +__STATIC_INLINE uint32_t LL_SPI_GetBaudRatePrescaler(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR1, SPI_CR1_BR)); +} + +/** + * @brief Set transfer bit order + * @note This bit should not be changed when communication is ongoing. This bit is not used in SPI TI mode. + * @rmtoll CR1 LSBFIRST LL_SPI_SetTransferBitOrder + * @param SPIx SPI Instance + * @param BitOrder This parameter can be one of the following values: + * @arg @ref LL_SPI_LSB_FIRST + * @arg @ref LL_SPI_MSB_FIRST + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetTransferBitOrder(SPI_TypeDef *SPIx, uint32_t BitOrder) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_LSBFIRST, BitOrder); +} + +/** + * @brief Get transfer bit order + * @rmtoll CR1 LSBFIRST LL_SPI_GetTransferBitOrder + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_LSB_FIRST + * @arg @ref LL_SPI_MSB_FIRST + */ +__STATIC_INLINE uint32_t LL_SPI_GetTransferBitOrder(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR1, SPI_CR1_LSBFIRST)); +} + +/** + * @brief Set transfer direction mode + * @note For Half-Duplex mode, Rx Direction is set by default. + * In master mode, the MOSI pin is used and in slave mode, the MISO pin is used for Half-Duplex. + * @rmtoll CR1 RXONLY LL_SPI_SetTransferDirection\n + * CR1 BIDIMODE LL_SPI_SetTransferDirection\n + * CR1 BIDIOE LL_SPI_SetTransferDirection + * @param SPIx SPI Instance + * @param TransferDirection This parameter can be one of the following values: + * @arg @ref LL_SPI_FULL_DUPLEX + * @arg @ref LL_SPI_SIMPLEX_RX + * @arg @ref LL_SPI_HALF_DUPLEX_RX + * @arg @ref LL_SPI_HALF_DUPLEX_TX + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetTransferDirection(SPI_TypeDef *SPIx, uint32_t TransferDirection) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_RXONLY | SPI_CR1_BIDIMODE | SPI_CR1_BIDIOE, TransferDirection); +} + +/** + * @brief Get transfer direction mode + * @rmtoll CR1 RXONLY LL_SPI_GetTransferDirection\n + * CR1 BIDIMODE LL_SPI_GetTransferDirection\n + * CR1 BIDIOE LL_SPI_GetTransferDirection + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_FULL_DUPLEX + * @arg @ref LL_SPI_SIMPLEX_RX + * @arg @ref LL_SPI_HALF_DUPLEX_RX + * @arg @ref LL_SPI_HALF_DUPLEX_TX + */ +__STATIC_INLINE uint32_t LL_SPI_GetTransferDirection(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR1, SPI_CR1_RXONLY | SPI_CR1_BIDIMODE | SPI_CR1_BIDIOE)); +} + +/** + * @brief Set frame data width + * @rmtoll CR2 DS LL_SPI_SetDataWidth + * @param SPIx SPI Instance + * @param DataWidth This parameter can be one of the following values: + * @arg @ref LL_SPI_DATAWIDTH_4BIT + * @arg @ref LL_SPI_DATAWIDTH_5BIT + * @arg @ref LL_SPI_DATAWIDTH_6BIT + * @arg @ref LL_SPI_DATAWIDTH_7BIT + * @arg @ref LL_SPI_DATAWIDTH_8BIT + * @arg @ref LL_SPI_DATAWIDTH_9BIT + * @arg @ref LL_SPI_DATAWIDTH_10BIT + * @arg @ref LL_SPI_DATAWIDTH_11BIT + * @arg @ref LL_SPI_DATAWIDTH_12BIT + * @arg @ref LL_SPI_DATAWIDTH_13BIT + * @arg @ref LL_SPI_DATAWIDTH_14BIT + * @arg @ref LL_SPI_DATAWIDTH_15BIT + * @arg @ref LL_SPI_DATAWIDTH_16BIT + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetDataWidth(SPI_TypeDef *SPIx, uint32_t DataWidth) +{ + MODIFY_REG(SPIx->CR2, SPI_CR2_DS, DataWidth); +} + +/** + * @brief Get frame data width + * @rmtoll CR2 DS LL_SPI_GetDataWidth + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_DATAWIDTH_4BIT + * @arg @ref LL_SPI_DATAWIDTH_5BIT + * @arg @ref LL_SPI_DATAWIDTH_6BIT + * @arg @ref LL_SPI_DATAWIDTH_7BIT + * @arg @ref LL_SPI_DATAWIDTH_8BIT + * @arg @ref LL_SPI_DATAWIDTH_9BIT + * @arg @ref LL_SPI_DATAWIDTH_10BIT + * @arg @ref LL_SPI_DATAWIDTH_11BIT + * @arg @ref LL_SPI_DATAWIDTH_12BIT + * @arg @ref LL_SPI_DATAWIDTH_13BIT + * @arg @ref LL_SPI_DATAWIDTH_14BIT + * @arg @ref LL_SPI_DATAWIDTH_15BIT + * @arg @ref LL_SPI_DATAWIDTH_16BIT + */ +__STATIC_INLINE uint32_t LL_SPI_GetDataWidth(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR2, SPI_CR2_DS)); +} + +/** + * @brief Set threshold of RXFIFO that triggers an RXNE event + * @rmtoll CR2 FRXTH LL_SPI_SetRxFIFOThreshold + * @param SPIx SPI Instance + * @param Threshold This parameter can be one of the following values: + * @arg @ref LL_SPI_RX_FIFO_TH_HALF + * @arg @ref LL_SPI_RX_FIFO_TH_QUARTER + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetRxFIFOThreshold(SPI_TypeDef *SPIx, uint32_t Threshold) +{ + MODIFY_REG(SPIx->CR2, SPI_CR2_FRXTH, Threshold); +} + +/** + * @brief Get threshold of RXFIFO that triggers an RXNE event + * @rmtoll CR2 FRXTH LL_SPI_GetRxFIFOThreshold + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_RX_FIFO_TH_HALF + * @arg @ref LL_SPI_RX_FIFO_TH_QUARTER + */ +__STATIC_INLINE uint32_t LL_SPI_GetRxFIFOThreshold(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR2, SPI_CR2_FRXTH)); +} + +/** + * @} + */ + +/** @defgroup SPI_LL_EF_CRC_Management CRC Management + * @{ + */ + +/** + * @brief Enable CRC + * @note This bit should be written only when SPI is disabled (SPE = 0) for correct operation. + * @rmtoll CR1 CRCEN LL_SPI_EnableCRC + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_EnableCRC(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR1, SPI_CR1_CRCEN); +} + +/** + * @brief Disable CRC + * @note This bit should be written only when SPI is disabled (SPE = 0) for correct operation. + * @rmtoll CR1 CRCEN LL_SPI_DisableCRC + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_DisableCRC(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR1, SPI_CR1_CRCEN); +} + +/** + * @brief Check if CRC is enabled + * @note This bit should be written only when SPI is disabled (SPE = 0) for correct operation. + * @rmtoll CR1 CRCEN LL_SPI_IsEnabledCRC + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabledCRC(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR1, SPI_CR1_CRCEN) == (SPI_CR1_CRCEN)) ? 1UL : 0UL); +} + +/** + * @brief Set CRC Length + * @note This bit should be written only when SPI is disabled (SPE = 0) for correct operation. + * @rmtoll CR1 CRCL LL_SPI_SetCRCWidth + * @param SPIx SPI Instance + * @param CRCLength This parameter can be one of the following values: + * @arg @ref LL_SPI_CRC_8BIT + * @arg @ref LL_SPI_CRC_16BIT + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetCRCWidth(SPI_TypeDef *SPIx, uint32_t CRCLength) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_CRCL, CRCLength); +} + +/** + * @brief Get CRC Length + * @rmtoll CR1 CRCL LL_SPI_GetCRCWidth + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_CRC_8BIT + * @arg @ref LL_SPI_CRC_16BIT + */ +__STATIC_INLINE uint32_t LL_SPI_GetCRCWidth(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR1, SPI_CR1_CRCL)); +} + +/** + * @brief Set CRCNext to transfer CRC on the line + * @note This bit has to be written as soon as the last data is written in the SPIx_DR register. + * @rmtoll CR1 CRCNEXT LL_SPI_SetCRCNext + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetCRCNext(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR1, SPI_CR1_CRCNEXT); +} + +/** + * @brief Set polynomial for CRC calculation + * @rmtoll CRCPR CRCPOLY LL_SPI_SetCRCPolynomial + * @param SPIx SPI Instance + * @param CRCPoly This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFFFF + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetCRCPolynomial(SPI_TypeDef *SPIx, uint32_t CRCPoly) +{ + WRITE_REG(SPIx->CRCPR, (uint16_t)CRCPoly); +} + +/** + * @brief Get polynomial for CRC calculation + * @rmtoll CRCPR CRCPOLY LL_SPI_GetCRCPolynomial + * @param SPIx SPI Instance + * @retval Returned value is a number between Min_Data = 0x00 and Max_Data = 0xFFFF + */ +__STATIC_INLINE uint32_t LL_SPI_GetCRCPolynomial(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_REG(SPIx->CRCPR)); +} + +/** + * @brief Get Rx CRC + * @rmtoll RXCRCR RXCRC LL_SPI_GetRxCRC + * @param SPIx SPI Instance + * @retval Returned value is a number between Min_Data = 0x00 and Max_Data = 0xFFFF + */ +__STATIC_INLINE uint32_t LL_SPI_GetRxCRC(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_REG(SPIx->RXCRCR)); +} + +/** + * @brief Get Tx CRC + * @rmtoll TXCRCR TXCRC LL_SPI_GetTxCRC + * @param SPIx SPI Instance + * @retval Returned value is a number between Min_Data = 0x00 and Max_Data = 0xFFFF + */ +__STATIC_INLINE uint32_t LL_SPI_GetTxCRC(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_REG(SPIx->TXCRCR)); +} + +/** + * @} + */ + +/** @defgroup SPI_LL_EF_NSS_Management Slave Select Pin Management + * @{ + */ + +/** + * @brief Set NSS mode + * @note LL_SPI_NSS_SOFT Mode is not used in SPI TI mode. + * @rmtoll CR1 SSM LL_SPI_SetNSSMode\n + * @rmtoll CR2 SSOE LL_SPI_SetNSSMode + * @param SPIx SPI Instance + * @param NSS This parameter can be one of the following values: + * @arg @ref LL_SPI_NSS_SOFT + * @arg @ref LL_SPI_NSS_HARD_INPUT + * @arg @ref LL_SPI_NSS_HARD_OUTPUT + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetNSSMode(SPI_TypeDef *SPIx, uint32_t NSS) +{ + MODIFY_REG(SPIx->CR1, SPI_CR1_SSM, NSS); + MODIFY_REG(SPIx->CR2, SPI_CR2_SSOE, ((uint32_t)(NSS >> 16U))); +} + +/** + * @brief Get NSS mode + * @rmtoll CR1 SSM LL_SPI_GetNSSMode\n + * @rmtoll CR2 SSOE LL_SPI_GetNSSMode + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_NSS_SOFT + * @arg @ref LL_SPI_NSS_HARD_INPUT + * @arg @ref LL_SPI_NSS_HARD_OUTPUT + */ +__STATIC_INLINE uint32_t LL_SPI_GetNSSMode(SPI_TypeDef *SPIx) +{ + uint32_t Ssm = (READ_BIT(SPIx->CR1, SPI_CR1_SSM)); + uint32_t Ssoe = (READ_BIT(SPIx->CR2, SPI_CR2_SSOE) << 16U); + return (Ssm | Ssoe); +} + +/** + * @brief Enable NSS pulse management + * @note This bit should not be changed when communication is ongoing. This bit is not used in SPI TI mode. + * @rmtoll CR2 NSSP LL_SPI_EnableNSSPulseMgt + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_EnableNSSPulseMgt(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR2, SPI_CR2_NSSP); +} + +/** + * @brief Disable NSS pulse management + * @note This bit should not be changed when communication is ongoing. This bit is not used in SPI TI mode. + * @rmtoll CR2 NSSP LL_SPI_DisableNSSPulseMgt + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_DisableNSSPulseMgt(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR2, SPI_CR2_NSSP); +} + +/** + * @brief Check if NSS pulse is enabled + * @note This bit should not be changed when communication is ongoing. This bit is not used in SPI TI mode. + * @rmtoll CR2 NSSP LL_SPI_IsEnabledNSSPulse + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabledNSSPulse(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR2, SPI_CR2_NSSP) == (SPI_CR2_NSSP)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup SPI_LL_EF_FLAG_Management FLAG Management + * @{ + */ + +/** + * @brief Check if Rx buffer is not empty + * @rmtoll SR RXNE LL_SPI_IsActiveFlag_RXNE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsActiveFlag_RXNE(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_RXNE) == (SPI_SR_RXNE)) ? 1UL : 0UL); +} + +/** + * @brief Check if Tx buffer is empty + * @rmtoll SR TXE LL_SPI_IsActiveFlag_TXE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsActiveFlag_TXE(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_TXE) == (SPI_SR_TXE)) ? 1UL : 0UL); +} + +/** + * @brief Get CRC error flag + * @rmtoll SR CRCERR LL_SPI_IsActiveFlag_CRCERR + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsActiveFlag_CRCERR(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_CRCERR) == (SPI_SR_CRCERR)) ? 1UL : 0UL); +} + +/** + * @brief Get mode fault error flag + * @rmtoll SR MODF LL_SPI_IsActiveFlag_MODF + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsActiveFlag_MODF(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_MODF) == (SPI_SR_MODF)) ? 1UL : 0UL); +} + +/** + * @brief Get overrun error flag + * @rmtoll SR OVR LL_SPI_IsActiveFlag_OVR + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsActiveFlag_OVR(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_OVR) == (SPI_SR_OVR)) ? 1UL : 0UL); +} + +/** + * @brief Get busy flag + * @note The BSY flag is cleared under any one of the following conditions: + * -When the SPI is correctly disabled + * -When a fault is detected in Master mode (MODF bit set to 1) + * -In Master mode, when it finishes a data transmission and no new data is ready to be + * sent + * -In Slave mode, when the BSY flag is set to '0' for at least one SPI clock cycle between + * each data transfer. + * @rmtoll SR BSY LL_SPI_IsActiveFlag_BSY + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsActiveFlag_BSY(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_BSY) == (SPI_SR_BSY)) ? 1UL : 0UL); +} + +/** + * @brief Get frame format error flag + * @rmtoll SR FRE LL_SPI_IsActiveFlag_FRE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsActiveFlag_FRE(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_FRE) == (SPI_SR_FRE)) ? 1UL : 0UL); +} + +/** + * @brief Get FIFO reception Level + * @rmtoll SR FRLVL LL_SPI_GetRxFIFOLevel + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_RX_FIFO_EMPTY + * @arg @ref LL_SPI_RX_FIFO_QUARTER_FULL + * @arg @ref LL_SPI_RX_FIFO_HALF_FULL + * @arg @ref LL_SPI_RX_FIFO_FULL + */ +__STATIC_INLINE uint32_t LL_SPI_GetRxFIFOLevel(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->SR, SPI_SR_FRLVL)); +} + +/** + * @brief Get FIFO Transmission Level + * @rmtoll SR FTLVL LL_SPI_GetTxFIFOLevel + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_TX_FIFO_EMPTY + * @arg @ref LL_SPI_TX_FIFO_QUARTER_FULL + * @arg @ref LL_SPI_TX_FIFO_HALF_FULL + * @arg @ref LL_SPI_TX_FIFO_FULL + */ +__STATIC_INLINE uint32_t LL_SPI_GetTxFIFOLevel(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->SR, SPI_SR_FTLVL)); +} + +/** + * @brief Clear CRC error flag + * @rmtoll SR CRCERR LL_SPI_ClearFlag_CRCERR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_ClearFlag_CRCERR(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->SR, SPI_SR_CRCERR); +} + +/** + * @brief Clear mode fault error flag + * @note Clearing this flag is done by a read access to the SPIx_SR + * register followed by a write access to the SPIx_CR1 register + * @rmtoll SR MODF LL_SPI_ClearFlag_MODF + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_ClearFlag_MODF(SPI_TypeDef *SPIx) +{ + __IO uint32_t tmpreg_sr; + tmpreg_sr = SPIx->SR; + (void) tmpreg_sr; + CLEAR_BIT(SPIx->CR1, SPI_CR1_SPE); +} + +/** + * @brief Clear overrun error flag + * @note Clearing this flag is done by a read access to the SPIx_DR + * register followed by a read access to the SPIx_SR register + * @rmtoll SR OVR LL_SPI_ClearFlag_OVR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_ClearFlag_OVR(SPI_TypeDef *SPIx) +{ + __IO uint32_t tmpreg; + tmpreg = SPIx->DR; + (void) tmpreg; + tmpreg = SPIx->SR; + (void) tmpreg; +} + +/** + * @brief Clear frame format error flag + * @note Clearing this flag is done by reading SPIx_SR register + * @rmtoll SR FRE LL_SPI_ClearFlag_FRE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_ClearFlag_FRE(SPI_TypeDef *SPIx) +{ + __IO uint32_t tmpreg; + tmpreg = SPIx->SR; + (void) tmpreg; +} + +/** + * @} + */ + +/** @defgroup SPI_LL_EF_IT_Management Interrupt Management + * @{ + */ + +/** + * @brief Enable error interrupt + * @note This bit controls the generation of an interrupt when an error condition occurs (CRCERR, OVR, MODF in SPI mode, FRE at TI mode). + * @rmtoll CR2 ERRIE LL_SPI_EnableIT_ERR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_EnableIT_ERR(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR2, SPI_CR2_ERRIE); +} + +/** + * @brief Enable Rx buffer not empty interrupt + * @rmtoll CR2 RXNEIE LL_SPI_EnableIT_RXNE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_EnableIT_RXNE(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR2, SPI_CR2_RXNEIE); +} + +/** + * @brief Enable Tx buffer empty interrupt + * @rmtoll CR2 TXEIE LL_SPI_EnableIT_TXE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_EnableIT_TXE(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR2, SPI_CR2_TXEIE); +} + +/** + * @brief Disable error interrupt + * @note This bit controls the generation of an interrupt when an error condition occurs (CRCERR, OVR, MODF in SPI mode, FRE at TI mode). + * @rmtoll CR2 ERRIE LL_SPI_DisableIT_ERR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_DisableIT_ERR(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR2, SPI_CR2_ERRIE); +} + +/** + * @brief Disable Rx buffer not empty interrupt + * @rmtoll CR2 RXNEIE LL_SPI_DisableIT_RXNE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_DisableIT_RXNE(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR2, SPI_CR2_RXNEIE); +} + +/** + * @brief Disable Tx buffer empty interrupt + * @rmtoll CR2 TXEIE LL_SPI_DisableIT_TXE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_DisableIT_TXE(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR2, SPI_CR2_TXEIE); +} + +/** + * @brief Check if error interrupt is enabled + * @rmtoll CR2 ERRIE LL_SPI_IsEnabledIT_ERR + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabledIT_ERR(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR2, SPI_CR2_ERRIE) == (SPI_CR2_ERRIE)) ? 1UL : 0UL); +} + +/** + * @brief Check if Rx buffer not empty interrupt is enabled + * @rmtoll CR2 RXNEIE LL_SPI_IsEnabledIT_RXNE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabledIT_RXNE(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR2, SPI_CR2_RXNEIE) == (SPI_CR2_RXNEIE)) ? 1UL : 0UL); +} + +/** + * @brief Check if Tx buffer empty interrupt + * @rmtoll CR2 TXEIE LL_SPI_IsEnabledIT_TXE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabledIT_TXE(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR2, SPI_CR2_TXEIE) == (SPI_CR2_TXEIE)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup SPI_LL_EF_DMA_Management DMA Management + * @{ + */ + +/** + * @brief Enable DMA Rx + * @rmtoll CR2 RXDMAEN LL_SPI_EnableDMAReq_RX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_EnableDMAReq_RX(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR2, SPI_CR2_RXDMAEN); +} + +/** + * @brief Disable DMA Rx + * @rmtoll CR2 RXDMAEN LL_SPI_DisableDMAReq_RX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_DisableDMAReq_RX(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR2, SPI_CR2_RXDMAEN); +} + +/** + * @brief Check if DMA Rx is enabled + * @rmtoll CR2 RXDMAEN LL_SPI_IsEnabledDMAReq_RX + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabledDMAReq_RX(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR2, SPI_CR2_RXDMAEN) == (SPI_CR2_RXDMAEN)) ? 1UL : 0UL); +} + +/** + * @brief Enable DMA Tx + * @rmtoll CR2 TXDMAEN LL_SPI_EnableDMAReq_TX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_EnableDMAReq_TX(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->CR2, SPI_CR2_TXDMAEN); +} + +/** + * @brief Disable DMA Tx + * @rmtoll CR2 TXDMAEN LL_SPI_DisableDMAReq_TX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_SPI_DisableDMAReq_TX(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->CR2, SPI_CR2_TXDMAEN); +} + +/** + * @brief Check if DMA Tx is enabled + * @rmtoll CR2 TXDMAEN LL_SPI_IsEnabledDMAReq_TX + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SPI_IsEnabledDMAReq_TX(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->CR2, SPI_CR2_TXDMAEN) == (SPI_CR2_TXDMAEN)) ? 1UL : 0UL); +} + +/** + * @brief Set parity of Last DMA reception + * @rmtoll CR2 LDMARX LL_SPI_SetDMAParity_RX + * @param SPIx SPI Instance + * @param Parity This parameter can be one of the following values: + * @arg @ref LL_SPI_DMA_PARITY_ODD + * @arg @ref LL_SPI_DMA_PARITY_EVEN + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetDMAParity_RX(SPI_TypeDef *SPIx, uint32_t Parity) +{ + MODIFY_REG(SPIx->CR2, SPI_CR2_LDMARX, (Parity << SPI_CR2_LDMARX_Pos)); +} + +/** + * @brief Get parity configuration for Last DMA reception + * @rmtoll CR2 LDMARX LL_SPI_GetDMAParity_RX + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_DMA_PARITY_ODD + * @arg @ref LL_SPI_DMA_PARITY_EVEN + */ +__STATIC_INLINE uint32_t LL_SPI_GetDMAParity_RX(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR2, SPI_CR2_LDMARX) >> SPI_CR2_LDMARX_Pos); +} + +/** + * @brief Set parity of Last DMA transmission + * @rmtoll CR2 LDMATX LL_SPI_SetDMAParity_TX + * @param SPIx SPI Instance + * @param Parity This parameter can be one of the following values: + * @arg @ref LL_SPI_DMA_PARITY_ODD + * @arg @ref LL_SPI_DMA_PARITY_EVEN + * @retval None + */ +__STATIC_INLINE void LL_SPI_SetDMAParity_TX(SPI_TypeDef *SPIx, uint32_t Parity) +{ + MODIFY_REG(SPIx->CR2, SPI_CR2_LDMATX, (Parity << SPI_CR2_LDMATX_Pos)); +} + +/** + * @brief Get parity configuration for Last DMA transmission + * @rmtoll CR2 LDMATX LL_SPI_GetDMAParity_TX + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_SPI_DMA_PARITY_ODD + * @arg @ref LL_SPI_DMA_PARITY_EVEN + */ +__STATIC_INLINE uint32_t LL_SPI_GetDMAParity_TX(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->CR2, SPI_CR2_LDMATX) >> SPI_CR2_LDMATX_Pos); +} + +/** + * @brief Get the data register address used for DMA transfer + * @rmtoll DR DR LL_SPI_DMA_GetRegAddr + * @param SPIx SPI Instance + * @retval Address of data register + */ +__STATIC_INLINE uint32_t LL_SPI_DMA_GetRegAddr(SPI_TypeDef *SPIx) +{ + return (uint32_t) &(SPIx->DR); +} + +/** + * @} + */ + +/** @defgroup SPI_LL_EF_DATA_Management DATA Management + * @{ + */ + +/** + * @brief Read 8-Bits in the data register + * @rmtoll DR DR LL_SPI_ReceiveData8 + * @param SPIx SPI Instance + * @retval RxData Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint8_t LL_SPI_ReceiveData8(SPI_TypeDef *SPIx) +{ + return (*((__IO uint8_t *)&SPIx->DR)); +} + +/** + * @brief Read 16-Bits in the data register + * @rmtoll DR DR LL_SPI_ReceiveData16 + * @param SPIx SPI Instance + * @retval RxData Value between Min_Data=0x00 and Max_Data=0xFFFF + */ +__STATIC_INLINE uint16_t LL_SPI_ReceiveData16(SPI_TypeDef *SPIx) +{ + return (uint16_t)(READ_REG(SPIx->DR)); +} + +/** + * @brief Write 8-Bits in the data register + * @rmtoll DR DR LL_SPI_TransmitData8 + * @param SPIx SPI Instance + * @param TxData Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_SPI_TransmitData8(SPI_TypeDef *SPIx, uint8_t TxData) +{ +#if defined (__GNUC__) + __IO uint8_t *spidr = ((__IO uint8_t *)&SPIx->DR); + *spidr = TxData; +#else + *((__IO uint8_t *)&SPIx->DR) = TxData; +#endif /* __GNUC__ */ +} + +/** + * @brief Write 16-Bits in the data register + * @rmtoll DR DR LL_SPI_TransmitData16 + * @param SPIx SPI Instance + * @param TxData Value between Min_Data=0x00 and Max_Data=0xFFFF + * @retval None + */ +__STATIC_INLINE void LL_SPI_TransmitData16(SPI_TypeDef *SPIx, uint16_t TxData) +{ +#if defined (__GNUC__) + __IO uint16_t *spidr = ((__IO uint16_t *)&SPIx->DR); + *spidr = TxData; +#else + SPIx->DR = TxData; +#endif /* __GNUC__ */ +} + +/** + * @} + */ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup SPI_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_SPI_DeInit(SPI_TypeDef *SPIx); +ErrorStatus LL_SPI_Init(SPI_TypeDef *SPIx, LL_SPI_InitTypeDef *SPI_InitStruct); +void LL_SPI_StructInit(LL_SPI_InitTypeDef *SPI_InitStruct); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ +/** + * @} + */ + +/** + * @} + */ + +#if defined(SPI_I2S_SUPPORT) +/** @defgroup I2S_LL I2S + * @{ + */ + +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup I2S_LL_ES_INIT I2S Exported Init structure + * @{ + */ + +/** + * @brief I2S Init structure definition + */ + +typedef struct +{ + uint32_t Mode; /*!< Specifies the I2S operating mode. + This parameter can be a value of @ref I2S_LL_EC_MODE + + This feature can be modified afterwards using unitary function @ref LL_I2S_SetTransferMode().*/ + + uint32_t Standard; /*!< Specifies the standard used for the I2S communication. + This parameter can be a value of @ref I2S_LL_EC_STANDARD + + This feature can be modified afterwards using unitary function @ref LL_I2S_SetStandard().*/ + + + uint32_t DataFormat; /*!< Specifies the data format for the I2S communication. + This parameter can be a value of @ref I2S_LL_EC_DATA_FORMAT + + This feature can be modified afterwards using unitary function @ref LL_I2S_SetDataFormat().*/ + + + uint32_t MCLKOutput; /*!< Specifies whether the I2S MCLK output is enabled or not. + This parameter can be a value of @ref I2S_LL_EC_MCLK_OUTPUT + + This feature can be modified afterwards using unitary functions @ref LL_I2S_EnableMasterClock() or @ref LL_I2S_DisableMasterClock.*/ + + + uint32_t AudioFreq; /*!< Specifies the frequency selected for the I2S communication. + This parameter can be a value of @ref I2S_LL_EC_AUDIO_FREQ + + Audio Frequency can be modified afterwards using Reference manual formulas to calculate Prescaler Linear, Parity + and unitary functions @ref LL_I2S_SetPrescalerLinear() and @ref LL_I2S_SetPrescalerParity() to set it.*/ + + + uint32_t ClockPolarity; /*!< Specifies the idle state of the I2S clock. + This parameter can be a value of @ref I2S_LL_EC_POLARITY + + This feature can be modified afterwards using unitary function @ref LL_I2S_SetClockPolarity().*/ + +} LL_I2S_InitTypeDef; + +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup I2S_LL_Exported_Constants I2S Exported Constants + * @{ + */ + +/** @defgroup I2S_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_I2S_ReadReg function + * @{ + */ +#define LL_I2S_SR_RXNE LL_SPI_SR_RXNE /*!< Rx buffer not empty flag */ +#define LL_I2S_SR_TXE LL_SPI_SR_TXE /*!< Tx buffer empty flag */ +#define LL_I2S_SR_BSY LL_SPI_SR_BSY /*!< Busy flag */ +#define LL_I2S_SR_UDR SPI_SR_UDR /*!< Underrun flag */ +#define LL_I2S_SR_OVR LL_SPI_SR_OVR /*!< Overrun flag */ +#define LL_I2S_SR_FRE LL_SPI_SR_FRE /*!< TI mode frame format error flag */ +/** + * @} + */ + +/** @defgroup SPI_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_SPI_ReadReg and LL_SPI_WriteReg functions + * @{ + */ +#define LL_I2S_CR2_RXNEIE LL_SPI_CR2_RXNEIE /*!< Rx buffer not empty interrupt enable */ +#define LL_I2S_CR2_TXEIE LL_SPI_CR2_TXEIE /*!< Tx buffer empty interrupt enable */ +#define LL_I2S_CR2_ERRIE LL_SPI_CR2_ERRIE /*!< Error interrupt enable */ +/** + * @} + */ + +/** @defgroup I2S_LL_EC_DATA_FORMAT Data format + * @{ + */ +#define LL_I2S_DATAFORMAT_16B 0x00000000U /*!< Data length 16 bits, Channel length 16bit */ +#define LL_I2S_DATAFORMAT_16B_EXTENDED (SPI_I2SCFGR_CHLEN) /*!< Data length 16 bits, Channel length 32bit */ +#define LL_I2S_DATAFORMAT_24B (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN_0) /*!< Data length 24 bits, Channel length 32bit */ +#define LL_I2S_DATAFORMAT_32B (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN_1) /*!< Data length 16 bits, Channel length 32bit */ +/** + * @} + */ + +/** @defgroup I2S_LL_EC_POLARITY Clock Polarity + * @{ + */ +#define LL_I2S_POLARITY_LOW 0x00000000U /*!< Clock steady state is low level */ +#define LL_I2S_POLARITY_HIGH (SPI_I2SCFGR_CKPOL) /*!< Clock steady state is high level */ +/** + * @} + */ + +/** @defgroup I2S_LL_EC_STANDARD I2s Standard + * @{ + */ +#define LL_I2S_STANDARD_PHILIPS 0x00000000U /*!< I2S standard philips */ +#define LL_I2S_STANDARD_MSB (SPI_I2SCFGR_I2SSTD_0) /*!< MSB justified standard (left justified) */ +#define LL_I2S_STANDARD_LSB (SPI_I2SCFGR_I2SSTD_1) /*!< LSB justified standard (right justified) */ +#define LL_I2S_STANDARD_PCM_SHORT (SPI_I2SCFGR_I2SSTD_0 | SPI_I2SCFGR_I2SSTD_1) /*!< PCM standard, short frame synchronization */ +#define LL_I2S_STANDARD_PCM_LONG (SPI_I2SCFGR_I2SSTD_0 | SPI_I2SCFGR_I2SSTD_1 | SPI_I2SCFGR_PCMSYNC) /*!< PCM standard, long frame synchronization */ +/** + * @} + */ + +/** @defgroup I2S_LL_EC_MODE Operation Mode + * @{ + */ +#define LL_I2S_MODE_SLAVE_TX 0x00000000U /*!< Slave Tx configuration */ +#define LL_I2S_MODE_SLAVE_RX (SPI_I2SCFGR_I2SCFG_0) /*!< Slave Rx configuration */ +#define LL_I2S_MODE_MASTER_TX (SPI_I2SCFGR_I2SCFG_1) /*!< Master Tx configuration */ +#define LL_I2S_MODE_MASTER_RX (SPI_I2SCFGR_I2SCFG_0 | SPI_I2SCFGR_I2SCFG_1) /*!< Master Rx configuration */ +/** + * @} + */ + +/** @defgroup I2S_LL_EC_PRESCALER_FACTOR Prescaler Factor + * @{ + */ +#define LL_I2S_PRESCALER_PARITY_EVEN 0x00000000U /*!< Odd factor: Real divider value is = I2SDIV * 2 */ +#define LL_I2S_PRESCALER_PARITY_ODD (SPI_I2SPR_ODD >> 8U) /*!< Odd factor: Real divider value is = (I2SDIV * 2)+1 */ +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) + +/** @defgroup I2S_LL_EC_MCLK_OUTPUT MCLK Output + * @{ + */ +#define LL_I2S_MCLK_OUTPUT_DISABLE 0x00000000U /*!< Master clock output is disabled */ +#define LL_I2S_MCLK_OUTPUT_ENABLE (SPI_I2SPR_MCKOE) /*!< Master clock output is enabled */ +/** + * @} + */ + +/** @defgroup I2S_LL_EC_AUDIO_FREQ Audio Frequency + * @{ + */ + +#define LL_I2S_AUDIOFREQ_192K 192000U /*!< Audio Frequency configuration 192000 Hz */ +#define LL_I2S_AUDIOFREQ_96K 96000U /*!< Audio Frequency configuration 96000 Hz */ +#define LL_I2S_AUDIOFREQ_48K 48000U /*!< Audio Frequency configuration 48000 Hz */ +#define LL_I2S_AUDIOFREQ_44K 44100U /*!< Audio Frequency configuration 44100 Hz */ +#define LL_I2S_AUDIOFREQ_32K 32000U /*!< Audio Frequency configuration 32000 Hz */ +#define LL_I2S_AUDIOFREQ_22K 22050U /*!< Audio Frequency configuration 22050 Hz */ +#define LL_I2S_AUDIOFREQ_16K 16000U /*!< Audio Frequency configuration 16000 Hz */ +#define LL_I2S_AUDIOFREQ_11K 11025U /*!< Audio Frequency configuration 11025 Hz */ +#define LL_I2S_AUDIOFREQ_8K 8000U /*!< Audio Frequency configuration 8000 Hz */ +#define LL_I2S_AUDIOFREQ_DEFAULT 2U /*!< Audio Freq not specified. Register I2SDIV = 2 */ +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup I2S_LL_Exported_Macros I2S Exported Macros + * @{ + */ + +/** @defgroup I2S_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in I2S register + * @param __INSTANCE__ I2S Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_I2S_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in I2S register + * @param __INSTANCE__ I2S Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_I2S_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup I2S_LL_Exported_Functions I2S Exported Functions + * @{ + */ + +/** @defgroup I2S_LL_EF_Configuration Configuration + * @{ + */ + +/** + * @brief Select I2S mode and Enable I2S peripheral + * @rmtoll I2SCFGR I2SMOD LL_I2S_Enable\n + * I2SCFGR I2SE LL_I2S_Enable + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_Enable(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_I2SMOD | SPI_I2SCFGR_I2SE); +} + +/** + * @brief Disable I2S peripheral + * @rmtoll I2SCFGR I2SE LL_I2S_Disable + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_Disable(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_I2SMOD | SPI_I2SCFGR_I2SE); +} + +/** + * @brief Check if I2S peripheral is enabled + * @rmtoll I2SCFGR I2SE LL_I2S_IsEnabled + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabled(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_I2SE) == (SPI_I2SCFGR_I2SE)) ? 1UL : 0UL); +} + +/** + * @brief Set I2S data frame length + * @rmtoll I2SCFGR DATLEN LL_I2S_SetDataFormat\n + * I2SCFGR CHLEN LL_I2S_SetDataFormat + * @param SPIx SPI Instance + * @param DataFormat This parameter can be one of the following values: + * @arg @ref LL_I2S_DATAFORMAT_16B + * @arg @ref LL_I2S_DATAFORMAT_16B_EXTENDED + * @arg @ref LL_I2S_DATAFORMAT_24B + * @arg @ref LL_I2S_DATAFORMAT_32B + * @retval None + */ +__STATIC_INLINE void LL_I2S_SetDataFormat(SPI_TypeDef *SPIx, uint32_t DataFormat) +{ + MODIFY_REG(SPIx->I2SCFGR, SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN, DataFormat); +} + +/** + * @brief Get I2S data frame length + * @rmtoll I2SCFGR DATLEN LL_I2S_GetDataFormat\n + * I2SCFGR CHLEN LL_I2S_GetDataFormat + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2S_DATAFORMAT_16B + * @arg @ref LL_I2S_DATAFORMAT_16B_EXTENDED + * @arg @ref LL_I2S_DATAFORMAT_24B + * @arg @ref LL_I2S_DATAFORMAT_32B + */ +__STATIC_INLINE uint32_t LL_I2S_GetDataFormat(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN)); +} + +/** + * @brief Set I2S clock polarity + * @rmtoll I2SCFGR CKPOL LL_I2S_SetClockPolarity + * @param SPIx SPI Instance + * @param ClockPolarity This parameter can be one of the following values: + * @arg @ref LL_I2S_POLARITY_LOW + * @arg @ref LL_I2S_POLARITY_HIGH + * @retval None + */ +__STATIC_INLINE void LL_I2S_SetClockPolarity(SPI_TypeDef *SPIx, uint32_t ClockPolarity) +{ + SET_BIT(SPIx->I2SCFGR, ClockPolarity); +} + +/** + * @brief Get I2S clock polarity + * @rmtoll I2SCFGR CKPOL LL_I2S_GetClockPolarity + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2S_POLARITY_LOW + * @arg @ref LL_I2S_POLARITY_HIGH + */ +__STATIC_INLINE uint32_t LL_I2S_GetClockPolarity(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_CKPOL)); +} + +/** + * @brief Set I2S standard protocol + * @rmtoll I2SCFGR I2SSTD LL_I2S_SetStandard\n + * I2SCFGR PCMSYNC LL_I2S_SetStandard + * @param SPIx SPI Instance + * @param Standard This parameter can be one of the following values: + * @arg @ref LL_I2S_STANDARD_PHILIPS + * @arg @ref LL_I2S_STANDARD_MSB + * @arg @ref LL_I2S_STANDARD_LSB + * @arg @ref LL_I2S_STANDARD_PCM_SHORT + * @arg @ref LL_I2S_STANDARD_PCM_LONG + * @retval None + */ +__STATIC_INLINE void LL_I2S_SetStandard(SPI_TypeDef *SPIx, uint32_t Standard) +{ + MODIFY_REG(SPIx->I2SCFGR, SPI_I2SCFGR_I2SSTD | SPI_I2SCFGR_PCMSYNC, Standard); +} + +/** + * @brief Get I2S standard protocol + * @rmtoll I2SCFGR I2SSTD LL_I2S_GetStandard\n + * I2SCFGR PCMSYNC LL_I2S_GetStandard + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2S_STANDARD_PHILIPS + * @arg @ref LL_I2S_STANDARD_MSB + * @arg @ref LL_I2S_STANDARD_LSB + * @arg @ref LL_I2S_STANDARD_PCM_SHORT + * @arg @ref LL_I2S_STANDARD_PCM_LONG + */ +__STATIC_INLINE uint32_t LL_I2S_GetStandard(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_I2SSTD | SPI_I2SCFGR_PCMSYNC)); +} + +/** + * @brief Set I2S transfer mode + * @rmtoll I2SCFGR I2SCFG LL_I2S_SetTransferMode + * @param SPIx SPI Instance + * @param Mode This parameter can be one of the following values: + * @arg @ref LL_I2S_MODE_SLAVE_TX + * @arg @ref LL_I2S_MODE_SLAVE_RX + * @arg @ref LL_I2S_MODE_MASTER_TX + * @arg @ref LL_I2S_MODE_MASTER_RX + * @retval None + */ +__STATIC_INLINE void LL_I2S_SetTransferMode(SPI_TypeDef *SPIx, uint32_t Mode) +{ + MODIFY_REG(SPIx->I2SCFGR, SPI_I2SCFGR_I2SCFG, Mode); +} + +/** + * @brief Get I2S transfer mode + * @rmtoll I2SCFGR I2SCFG LL_I2S_GetTransferMode + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2S_MODE_SLAVE_TX + * @arg @ref LL_I2S_MODE_SLAVE_RX + * @arg @ref LL_I2S_MODE_MASTER_TX + * @arg @ref LL_I2S_MODE_MASTER_RX + */ +__STATIC_INLINE uint32_t LL_I2S_GetTransferMode(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_I2SCFG)); +} + +/** + * @brief Set I2S linear prescaler + * @rmtoll I2SPR I2SDIV LL_I2S_SetPrescalerLinear + * @param SPIx SPI Instance + * @param PrescalerLinear Value between Min_Data=0x02 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_I2S_SetPrescalerLinear(SPI_TypeDef *SPIx, uint8_t PrescalerLinear) +{ + MODIFY_REG(SPIx->I2SPR, SPI_I2SPR_I2SDIV, PrescalerLinear); +} + +/** + * @brief Get I2S linear prescaler + * @rmtoll I2SPR I2SDIV LL_I2S_GetPrescalerLinear + * @param SPIx SPI Instance + * @retval PrescalerLinear Value between Min_Data=0x02 and Max_Data=0xFF + */ +__STATIC_INLINE uint32_t LL_I2S_GetPrescalerLinear(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->I2SPR, SPI_I2SPR_I2SDIV)); +} + +/** + * @brief Set I2S parity prescaler + * @rmtoll I2SPR ODD LL_I2S_SetPrescalerParity + * @param SPIx SPI Instance + * @param PrescalerParity This parameter can be one of the following values: + * @arg @ref LL_I2S_PRESCALER_PARITY_EVEN + * @arg @ref LL_I2S_PRESCALER_PARITY_ODD + * @retval None + */ +__STATIC_INLINE void LL_I2S_SetPrescalerParity(SPI_TypeDef *SPIx, uint32_t PrescalerParity) +{ + MODIFY_REG(SPIx->I2SPR, SPI_I2SPR_ODD, PrescalerParity << 8U); +} + +/** + * @brief Get I2S parity prescaler + * @rmtoll I2SPR ODD LL_I2S_GetPrescalerParity + * @param SPIx SPI Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_I2S_PRESCALER_PARITY_EVEN + * @arg @ref LL_I2S_PRESCALER_PARITY_ODD + */ +__STATIC_INLINE uint32_t LL_I2S_GetPrescalerParity(SPI_TypeDef *SPIx) +{ + return (uint32_t)(READ_BIT(SPIx->I2SPR, SPI_I2SPR_ODD) >> 8U); +} + +/** + * @brief Enable the master clock output (Pin MCK) + * @rmtoll I2SPR MCKOE LL_I2S_EnableMasterClock + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_EnableMasterClock(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->I2SPR, SPI_I2SPR_MCKOE); +} + +/** + * @brief Disable the master clock output (Pin MCK) + * @rmtoll I2SPR MCKOE LL_I2S_DisableMasterClock + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_DisableMasterClock(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->I2SPR, SPI_I2SPR_MCKOE); +} + +/** + * @brief Check if the master clock output (Pin MCK) is enabled + * @rmtoll I2SPR MCKOE LL_I2S_IsEnabledMasterClock + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabledMasterClock(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->I2SPR, SPI_I2SPR_MCKOE) == (SPI_I2SPR_MCKOE)) ? 1UL : 0UL); +} + +#if defined(SPI_I2SCFGR_ASTRTEN) +/** + * @brief Enable asynchronous start + * @rmtoll I2SCFGR ASTRTEN LL_I2S_EnableAsyncStart + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_EnableAsyncStart(SPI_TypeDef *SPIx) +{ + SET_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_ASTRTEN); +} + +/** + * @brief Disable asynchronous start + * @rmtoll I2SCFGR ASTRTEN LL_I2S_DisableAsyncStart + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_DisableAsyncStart(SPI_TypeDef *SPIx) +{ + CLEAR_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_ASTRTEN); +} + +/** + * @brief Check if asynchronous start is enabled + * @rmtoll I2SCFGR ASTRTEN LL_I2S_IsEnabledAsyncStart + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabledAsyncStart(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_ASTRTEN) == (SPI_I2SCFGR_ASTRTEN)) ? 1UL : 0UL); +} +#endif /* SPI_I2SCFGR_ASTRTEN */ + +/** + * @} + */ + +/** @defgroup I2S_LL_EF_FLAG FLAG Management + * @{ + */ + +/** + * @brief Check if Rx buffer is not empty + * @rmtoll SR RXNE LL_I2S_IsActiveFlag_RXNE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsActiveFlag_RXNE(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsActiveFlag_RXNE(SPIx); +} + +/** + * @brief Check if Tx buffer is empty + * @rmtoll SR TXE LL_I2S_IsActiveFlag_TXE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsActiveFlag_TXE(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsActiveFlag_TXE(SPIx); +} + +/** + * @brief Get busy flag + * @rmtoll SR BSY LL_I2S_IsActiveFlag_BSY + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsActiveFlag_BSY(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsActiveFlag_BSY(SPIx); +} + +/** + * @brief Get overrun error flag + * @rmtoll SR OVR LL_I2S_IsActiveFlag_OVR + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsActiveFlag_OVR(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsActiveFlag_OVR(SPIx); +} + +/** + * @brief Get underrun error flag + * @rmtoll SR UDR LL_I2S_IsActiveFlag_UDR + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsActiveFlag_UDR(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_UDR) == (SPI_SR_UDR)) ? 1UL : 0UL); +} + +/** + * @brief Get frame format error flag + * @rmtoll SR FRE LL_I2S_IsActiveFlag_FRE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsActiveFlag_FRE(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsActiveFlag_FRE(SPIx); +} + +/** + * @brief Get channel side flag. + * @note 0: Channel Left has to be transmitted or has been received\n + * 1: Channel Right has to be transmitted or has been received\n + * It has no significance in PCM mode. + * @rmtoll SR CHSIDE LL_I2S_IsActiveFlag_CHSIDE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsActiveFlag_CHSIDE(SPI_TypeDef *SPIx) +{ + return ((READ_BIT(SPIx->SR, SPI_SR_CHSIDE) == (SPI_SR_CHSIDE)) ? 1UL : 0UL); +} + +/** + * @brief Clear overrun error flag + * @rmtoll SR OVR LL_I2S_ClearFlag_OVR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_ClearFlag_OVR(SPI_TypeDef *SPIx) +{ + LL_SPI_ClearFlag_OVR(SPIx); +} + +/** + * @brief Clear underrun error flag + * @rmtoll SR UDR LL_I2S_ClearFlag_UDR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_ClearFlag_UDR(SPI_TypeDef *SPIx) +{ + __IO uint32_t tmpreg; + tmpreg = SPIx->SR; + (void)tmpreg; +} + +/** + * @brief Clear frame format error flag + * @rmtoll SR FRE LL_I2S_ClearFlag_FRE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_ClearFlag_FRE(SPI_TypeDef *SPIx) +{ + LL_SPI_ClearFlag_FRE(SPIx); +} + +/** + * @} + */ + +/** @defgroup I2S_LL_EF_IT Interrupt Management + * @{ + */ + +/** + * @brief Enable error IT + * @note This bit controls the generation of an interrupt when an error condition occurs (OVR, UDR and FRE in I2S mode). + * @rmtoll CR2 ERRIE LL_I2S_EnableIT_ERR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_EnableIT_ERR(SPI_TypeDef *SPIx) +{ + LL_SPI_EnableIT_ERR(SPIx); +} + +/** + * @brief Enable Rx buffer not empty IT + * @rmtoll CR2 RXNEIE LL_I2S_EnableIT_RXNE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_EnableIT_RXNE(SPI_TypeDef *SPIx) +{ + LL_SPI_EnableIT_RXNE(SPIx); +} + +/** + * @brief Enable Tx buffer empty IT + * @rmtoll CR2 TXEIE LL_I2S_EnableIT_TXE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_EnableIT_TXE(SPI_TypeDef *SPIx) +{ + LL_SPI_EnableIT_TXE(SPIx); +} + +/** + * @brief Disable error IT + * @note This bit controls the generation of an interrupt when an error condition occurs (OVR, UDR and FRE in I2S mode). + * @rmtoll CR2 ERRIE LL_I2S_DisableIT_ERR + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_DisableIT_ERR(SPI_TypeDef *SPIx) +{ + LL_SPI_DisableIT_ERR(SPIx); +} + +/** + * @brief Disable Rx buffer not empty IT + * @rmtoll CR2 RXNEIE LL_I2S_DisableIT_RXNE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_DisableIT_RXNE(SPI_TypeDef *SPIx) +{ + LL_SPI_DisableIT_RXNE(SPIx); +} + +/** + * @brief Disable Tx buffer empty IT + * @rmtoll CR2 TXEIE LL_I2S_DisableIT_TXE + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_DisableIT_TXE(SPI_TypeDef *SPIx) +{ + LL_SPI_DisableIT_TXE(SPIx); +} + +/** + * @brief Check if ERR IT is enabled + * @rmtoll CR2 ERRIE LL_I2S_IsEnabledIT_ERR + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabledIT_ERR(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsEnabledIT_ERR(SPIx); +} + +/** + * @brief Check if RXNE IT is enabled + * @rmtoll CR2 RXNEIE LL_I2S_IsEnabledIT_RXNE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabledIT_RXNE(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsEnabledIT_RXNE(SPIx); +} + +/** + * @brief Check if TXE IT is enabled + * @rmtoll CR2 TXEIE LL_I2S_IsEnabledIT_TXE + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabledIT_TXE(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsEnabledIT_TXE(SPIx); +} + +/** + * @} + */ + +/** @defgroup I2S_LL_EF_DMA DMA Management + * @{ + */ + +/** + * @brief Enable DMA Rx + * @rmtoll CR2 RXDMAEN LL_I2S_EnableDMAReq_RX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_EnableDMAReq_RX(SPI_TypeDef *SPIx) +{ + LL_SPI_EnableDMAReq_RX(SPIx); +} + +/** + * @brief Disable DMA Rx + * @rmtoll CR2 RXDMAEN LL_I2S_DisableDMAReq_RX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_DisableDMAReq_RX(SPI_TypeDef *SPIx) +{ + LL_SPI_DisableDMAReq_RX(SPIx); +} + +/** + * @brief Check if DMA Rx is enabled + * @rmtoll CR2 RXDMAEN LL_I2S_IsEnabledDMAReq_RX + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabledDMAReq_RX(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsEnabledDMAReq_RX(SPIx); +} + +/** + * @brief Enable DMA Tx + * @rmtoll CR2 TXDMAEN LL_I2S_EnableDMAReq_TX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_EnableDMAReq_TX(SPI_TypeDef *SPIx) +{ + LL_SPI_EnableDMAReq_TX(SPIx); +} + +/** + * @brief Disable DMA Tx + * @rmtoll CR2 TXDMAEN LL_I2S_DisableDMAReq_TX + * @param SPIx SPI Instance + * @retval None + */ +__STATIC_INLINE void LL_I2S_DisableDMAReq_TX(SPI_TypeDef *SPIx) +{ + LL_SPI_DisableDMAReq_TX(SPIx); +} + +/** + * @brief Check if DMA Tx is enabled + * @rmtoll CR2 TXDMAEN LL_I2S_IsEnabledDMAReq_TX + * @param SPIx SPI Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_I2S_IsEnabledDMAReq_TX(SPI_TypeDef *SPIx) +{ + return LL_SPI_IsEnabledDMAReq_TX(SPIx); +} + +/** + * @} + */ + +/** @defgroup I2S_LL_EF_DATA DATA Management + * @{ + */ + +/** + * @brief Read 16-Bits in data register + * @rmtoll DR DR LL_I2S_ReceiveData16 + * @param SPIx SPI Instance + * @retval RxData Value between Min_Data=0x0000 and Max_Data=0xFFFF + */ +__STATIC_INLINE uint16_t LL_I2S_ReceiveData16(SPI_TypeDef *SPIx) +{ + return LL_SPI_ReceiveData16(SPIx); +} + +/** + * @brief Write 16-Bits in data register + * @rmtoll DR DR LL_I2S_TransmitData16 + * @param SPIx SPI Instance + * @param TxData Value between Min_Data=0x0000 and Max_Data=0xFFFF + * @retval None + */ +__STATIC_INLINE void LL_I2S_TransmitData16(SPI_TypeDef *SPIx, uint16_t TxData) +{ + LL_SPI_TransmitData16(SPIx, TxData); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup I2S_LL_EF_Init Initialization and de-initialization functions + * @{ + */ + +ErrorStatus LL_I2S_DeInit(SPI_TypeDef *SPIx); +ErrorStatus LL_I2S_Init(SPI_TypeDef *SPIx, LL_I2S_InitTypeDef *I2S_InitStruct); +void LL_I2S_StructInit(LL_I2S_InitTypeDef *I2S_InitStruct); +void LL_I2S_ConfigPrescaler(SPI_TypeDef *SPIx, uint32_t PrescalerLinear, uint32_t PrescalerParity); + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* SPI_I2S_SUPPORT */ + +#endif /* defined (SPI1) || defined (SPI2) */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_LL_SPI_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_system.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_system.h new file mode 100644 index 0000000..78d4107 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_system.h @@ -0,0 +1,1852 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_system.h + * @author MCD Application Team + * @brief Header file of SYSTEM LL module. + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The LL SYSTEM driver contains a set of generic APIs that can be + used by user: + (+) Some of the FLASH features need to be handled in the SYSTEM file. + (+) Access to DBGCMU registers + (+) Access to SYSCFG registers + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_SYSTEM_H +#define __STM32F0xx_LL_SYSTEM_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (FLASH) || defined (SYSCFG) || defined (DBGMCU) + +/** @defgroup SYSTEM_LL SYSTEM + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup SYSTEM_LL_Private_Constants SYSTEM Private Constants + * @{ + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup SYSTEM_LL_Exported_Constants SYSTEM Exported Constants + * @{ + */ + +/** @defgroup SYSTEM_LL_EC_REMAP SYSCFG Remap +* @{ +*/ +#define LL_SYSCFG_REMAP_FLASH (uint32_t)0x00000000U /*!< Main Flash memory mapped at 0x00000000 */ +#define LL_SYSCFG_REMAP_SYSTEMFLASH SYSCFG_CFGR1_MEM_MODE_0 /*!< System Flash memory mapped at 0x00000000 */ +#define LL_SYSCFG_REMAP_SRAM (SYSCFG_CFGR1_MEM_MODE_1 | SYSCFG_CFGR1_MEM_MODE_0) /*!< Embedded SRAM mapped at 0x00000000 */ +/** + * @} + */ + +#if defined(SYSCFG_CFGR1_IR_MOD) +/** @defgroup SYSTEM_LL_EC_IR_MOD SYSCFG IR Modulation + * @{ + */ +#define LL_SYSCFG_IR_MOD_TIM16 (SYSCFG_CFGR1_IR_MOD_0 & SYSCFG_CFGR1_IR_MOD_1) /*!< Timer16 is selected as IR Modulation enveloppe source */ +#define LL_SYSCFG_IR_MOD_USART1 (SYSCFG_CFGR1_IR_MOD_0) /*!< USART1 is selected as IR Modulation enveloppe source */ +#define LL_SYSCFG_IR_MOD_USART4 (SYSCFG_CFGR1_IR_MOD_1) /*!< USART4 is selected as IR Modulation enveloppe source */ +/** + * @} + */ + +#endif /* SYSCFG_CFGR1_IR_MOD */ + +#if defined(SYSCFG_CFGR1_USART1TX_DMA_RMP) || defined(SYSCFG_CFGR1_USART1RX_DMA_RMP) || defined(SYSCFG_CFGR1_USART2_DMA_RMP) || defined(SYSCFG_CFGR1_USART3_DMA_RMP) +/** @defgroup SYSTEM_LL_EC_USART1TX_RMP SYSCFG USART DMA Remap + * @{ + */ +#if defined (SYSCFG_CFGR1_USART1TX_DMA_RMP) +#define LL_SYSCFG_USART1TX_RMP_DMA1CH2 ((SYSCFG_CFGR1_USART1TX_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< USART1_TX DMA request mapped on DMA channel 2U */ +#define LL_SYSCFG_USART1TX_RMP_DMA1CH4 ((SYSCFG_CFGR1_USART1TX_DMA_RMP >> 8U) | SYSCFG_CFGR1_USART1TX_DMA_RMP) /*!< USART1_TX DMA request mapped on DMA channel 4U */ +#endif /*SYSCFG_CFGR1_USART1TX_DMA_RMP*/ +#if defined (SYSCFG_CFGR1_USART1RX_DMA_RMP) +#define LL_SYSCFG_USART1RX_RMP_DMA1CH3 ((SYSCFG_CFGR1_USART1RX_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< USART1_RX DMA request mapped on DMA channel 3U */ +#define LL_SYSCFG_USART1RX_RMP_DMA1CH5 ((SYSCFG_CFGR1_USART1RX_DMA_RMP >> 8U) | SYSCFG_CFGR1_USART1RX_DMA_RMP) /*!< USART1_RX DMA request mapped on DMA channel 5 */ +#endif /*SYSCFG_CFGR1_USART1RX_DMA_RMP*/ +#if defined (SYSCFG_CFGR1_USART2_DMA_RMP) +#define LL_SYSCFG_USART2_RMP_DMA1CH54 ((SYSCFG_CFGR1_USART2_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< USART2_RX and USART2_TX DMA requests mapped on DMA channel 5 and 4U respectively */ +#define LL_SYSCFG_USART2_RMP_DMA1CH67 ((SYSCFG_CFGR1_USART2_DMA_RMP >> 8U) | SYSCFG_CFGR1_USART2_DMA_RMP) /*!< USART2_RX and USART2_TX DMA requests mapped on DMA channel 6 and 7 respectively */ +#endif /*SYSCFG_CFGR1_USART2_DMA_RMP*/ +#if defined (SYSCFG_CFGR1_USART3_DMA_RMP) +#define LL_SYSCFG_USART3_RMP_DMA1CH67 ((SYSCFG_CFGR1_USART3_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< USART3_RX and USART3_TX DMA requests mapped on DMA channel 6 and 7 respectively */ +#define LL_SYSCFG_USART3_RMP_DMA1CH32 ((SYSCFG_CFGR1_USART3_DMA_RMP >> 8U) | SYSCFG_CFGR1_USART3_DMA_RMP) /*!< USART3_RX and USART3_TX DMA requests mapped on DMA channel 3U and 2U respectively */ +#endif /* SYSCFG_CFGR1_USART3_DMA_RMP */ +/** + * @} + */ +#endif /* SYSCFG_CFGR1_USART1TX_DMA_RMP || SYSCFG_CFGR1_USART1RX_DMA_RMP || SYSCFG_CFGR1_USART2_DMA_RMP || SYSCFG_CFGR1_USART3_DMA_RMP */ + +#if defined (SYSCFG_CFGR1_SPI2_DMA_RMP) +/** @defgroup SYSTEM_LL_EC_SPI2_RMP_DMA1 SYSCFG SPI2 DMA Remap + * @{ + */ +#define LL_SYSCFG_SPI2_RMP_DMA1_CH45 (uint32_t)0x00000000U /*!< SPI2_RX and SPI2_TX DMA requests mapped on DMA channel 4U and 5 respectively */ +#define LL_SYSCFG_SPI2_RMP_DMA1_CH67 SYSCFG_CFGR1_SPI2_DMA_RMP /*!< SPI2_RX and SPI2_TX DMA requests mapped on DMA channel 6 and 7 respectively */ +/** + * @} + */ + +#endif /*SYSCFG_CFGR1_SPI2_DMA_RMP*/ + +#if defined (SYSCFG_CFGR1_I2C1_DMA_RMP) +/** @defgroup SYSTEM_LL_EC_I2C1_RMP_DMA1 SYSCFG I2C1 DMA Remap + * @{ + */ +#define LL_SYSCFG_I2C1_RMP_DMA1_CH32 (uint32_t)0x00000000U /*!< I2C1_RX and I2C1_TX DMA requests mapped on DMA channel 3U and 2U respectively */ +#define LL_SYSCFG_I2C1_RMP_DMA1_CH76 SYSCFG_CFGR1_I2C1_DMA_RMP /*!< I2C1_RX and I2C1_TX DMA requests mapped on DMA channel 7 and 6 respectively */ +/** + * @} + */ + +#endif /*SYSCFG_CFGR1_I2C1_DMA_RMP*/ + +#if defined(SYSCFG_CFGR1_ADC_DMA_RMP) +/** @defgroup SYSTEM_LL_EC_ADC1_RMP_DMA1 SYSCFG ADC1 DMA Remap + * @{ + */ +#define LL_SYSCFG_ADC1_RMP_DMA1_CH1 (uint32_t)0x00000000U /*!< ADC DMA request mapped on DMA channel 1U */ +#define LL_SYSCFG_ADC1_RMP_DMA1_CH2 SYSCFG_CFGR1_ADC_DMA_RMP /*!< ADC DMA request mapped on DMA channel 2U */ +/** + * @} + */ + +#endif /* SYSCFG_CFGR1_ADC_DMA_RMP */ + +#if defined(SYSCFG_CFGR1_TIM16_DMA_RMP) || defined(SYSCFG_CFGR1_TIM17_DMA_RMP) || defined(SYSCFG_CFGR1_TIM1_DMA_RMP) || defined(SYSCFG_CFGR1_TIM2_DMA_RMP) || defined(SYSCFG_CFGR1_TIM3_DMA_RMP) +/** @defgroup SYSTEM_LL_EC_TIM16_RMP_DMA1 SYSCFG TIM DMA Remap + * @{ + */ +#if defined(SYSCFG_CFGR1_TIM16_DMA_RMP) +#if defined (SYSCFG_CFGR1_TIM16_DMA_RMP2) +#define LL_SYSCFG_TIM16_RMP_DMA1_CH3 (((SYSCFG_CFGR1_TIM16_DMA_RMP | SYSCFG_CFGR1_TIM16_DMA_RMP2) >> 8U) | (uint32_t)0x00000000U) /*!< TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 3 */ +#define LL_SYSCFG_TIM16_RMP_DMA1_CH4 (((SYSCFG_CFGR1_TIM16_DMA_RMP | SYSCFG_CFGR1_TIM16_DMA_RMP2) >> 8U) | SYSCFG_CFGR1_TIM16_DMA_RMP) /*!< TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 4 */ +#define LL_SYSCFG_TIM16_RMP_DMA1_CH6 ((SYSCFG_CFGR1_TIM16_DMA_RMP2 >> 8U) | SYSCFG_CFGR1_TIM16_DMA_RMP2) /*!< TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 6 */ +#else +#define LL_SYSCFG_TIM16_RMP_DMA1_CH3 ((SYSCFG_CFGR1_TIM16_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 3 */ +#define LL_SYSCFG_TIM16_RMP_DMA1_CH4 ((SYSCFG_CFGR1_TIM16_DMA_RMP >> 8U) | SYSCFG_CFGR1_TIM16_DMA_RMP) /*!< TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 4 */ +#endif /* SYSCFG_CFGR1_TIM16_DMA_RMP2 */ +#endif /* SYSCFG_CFGR1_TIM16_DMA_RMP */ +#if defined(SYSCFG_CFGR1_TIM17_DMA_RMP) +#if defined (SYSCFG_CFGR1_TIM17_DMA_RMP2) +#define LL_SYSCFG_TIM17_RMP_DMA1_CH1 (((SYSCFG_CFGR1_TIM17_DMA_RMP | SYSCFG_CFGR1_TIM17_DMA_RMP2) >> 8U) | (uint32_t)0x00000000U) /*!< TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 1 */ +#define LL_SYSCFG_TIM17_RMP_DMA1_CH2 (((SYSCFG_CFGR1_TIM17_DMA_RMP | SYSCFG_CFGR1_TIM17_DMA_RMP2) >> 8U) | SYSCFG_CFGR1_TIM17_DMA_RMP) /*!< TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 2 */ +#define LL_SYSCFG_TIM17_RMP_DMA1_CH7 ((SYSCFG_CFGR1_TIM17_DMA_RMP2 >> 8U) | SYSCFG_CFGR1_TIM17_DMA_RMP2) /*!< TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 7 */ +#else +#define LL_SYSCFG_TIM17_RMP_DMA1_CH1 ((SYSCFG_CFGR1_TIM17_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 1 */ +#define LL_SYSCFG_TIM17_RMP_DMA1_CH2 ((SYSCFG_CFGR1_TIM17_DMA_RMP >> 8U) | SYSCFG_CFGR1_TIM17_DMA_RMP) /*!< TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 2 */ +#endif /* SYSCFG_CFGR1_TIM17_DMA_RMP2 */ +#endif /* SYSCFG_CFGR1_TIM17_DMA_RMP */ +#if defined (SYSCFG_CFGR1_TIM1_DMA_RMP) +#define LL_SYSCFG_TIM1_RMP_DMA1_CH234 ((SYSCFG_CFGR1_TIM1_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< TIM1_CH1, TIM1_CH2 and TIM1_CH3 DMA requests mapped on DMAchannel 2, 3 and 4 respectively */ +#define LL_SYSCFG_TIM1_RMP_DMA1_CH6 ((SYSCFG_CFGR1_TIM1_DMA_RMP >> 8U) | SYSCFG_CFGR1_TIM1_DMA_RMP) /*!< TIM1_CH1, TIM1_CH2 and TIM1_CH3 DMA requests mapped on DMA channel 6 */ +#endif /*SYSCFG_CFGR1_TIM1_DMA_RMP*/ +#if defined (SYSCFG_CFGR1_TIM2_DMA_RMP) +#define LL_SYSCFG_TIM2_RMP_DMA1_CH34 ((SYSCFG_CFGR1_TIM2_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< TIM2_CH2 and TIM2_CH4 DMA requests mapped on DMA channel 3 and 4 respectively */ +#define LL_SYSCFG_TIM2_RMP_DMA1_CH7 ((SYSCFG_CFGR1_TIM2_DMA_RMP >> 8U) | SYSCFG_CFGR1_TIM2_DMA_RMP) /*!< TIM2_CH2 and TIM2_CH4 DMA requests mapped on DMA channel 7 */ +#endif /*SYSCFG_CFGR1_TIM2_DMA_RMP*/ +#if defined (SYSCFG_CFGR1_TIM3_DMA_RMP) +#define LL_SYSCFG_TIM3_RMP_DMA1_CH4 ((SYSCFG_CFGR1_TIM3_DMA_RMP >> 8U) | (uint32_t)0x00000000U) /*!< TIM3_CH1 and TIM3_TRIG DMA requests mapped on DMA channel 4 */ +#define LL_SYSCFG_TIM3_RMP_DMA1_CH6 ((SYSCFG_CFGR1_TIM3_DMA_RMP >> 8U) | SYSCFG_CFGR1_TIM3_DMA_RMP) /*!< TIM3_CH1 and TIM3_TRIG DMA requests mapped on DMA channel 6 */ +#endif /*SYSCFG_CFGR1_TIM3_DMA_RMP*/ +/** + * @} + */ + +#endif /* SYSCFG_CFGR1_TIM16_DMA_RMP || SYSCFG_CFGR1_TIM17_DMA_RMP || SYSCFG_CFGR1_TIM1_DMA_RMP || SYSCFG_CFGR1_TIM2_DMA_RMP || SYSCFG_CFGR1_TIM3_DMA_RMP */ + +/** @defgroup SYSTEM_LL_EC_I2C_FASTMODEPLUS SYSCFG I2C FASTMODEPLUS + * @{ + */ +#define LL_SYSCFG_I2C_FASTMODEPLUS_PB6 SYSCFG_CFGR1_I2C_FMP_PB6 /*!< I2C PB6 Fast mode plus */ +#define LL_SYSCFG_I2C_FASTMODEPLUS_PB7 SYSCFG_CFGR1_I2C_FMP_PB7 /*!< I2C PB7 Fast mode plus */ +#define LL_SYSCFG_I2C_FASTMODEPLUS_PB8 SYSCFG_CFGR1_I2C_FMP_PB8 /*!< I2C PB8 Fast mode plus */ +#define LL_SYSCFG_I2C_FASTMODEPLUS_PB9 SYSCFG_CFGR1_I2C_FMP_PB9 /*!< I2C PB9 Fast mode plus */ +#if defined(SYSCFG_CFGR1_I2C_FMP_I2C1) +#define LL_SYSCFG_I2C_FASTMODEPLUS_I2C1 SYSCFG_CFGR1_I2C_FMP_I2C1 /*!< Enable Fast Mode Plus on PB10, PB11, PF6 and PF7 */ +#endif /*SYSCFG_CFGR1_I2C_FMP_I2C1*/ +#if defined(SYSCFG_CFGR1_I2C_FMP_I2C2) +#define LL_SYSCFG_I2C_FASTMODEPLUS_I2C2 SYSCFG_CFGR1_I2C_FMP_I2C2 /*!< Enable I2C2 Fast mode plus */ +#endif /*SYSCFG_CFGR1_I2C_FMP_I2C2*/ +#if defined(SYSCFG_CFGR1_I2C_FMP_PA9) +#define LL_SYSCFG_I2C_FASTMODEPLUS_PA9 SYSCFG_CFGR1_I2C_FMP_PA9 /*!< Enable Fast Mode Plus on PA9 */ +#endif /*SYSCFG_CFGR1_I2C_FMP_PA9*/ +#if defined(SYSCFG_CFGR1_I2C_FMP_PA10) +#define LL_SYSCFG_I2C_FASTMODEPLUS_PA10 SYSCFG_CFGR1_I2C_FMP_PA10 /*!< Enable Fast Mode Plus on PA10 */ +#endif /*SYSCFG_CFGR1_I2C_FMP_PA10*/ +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EC_EXTI_PORT SYSCFG EXTI PORT + * @{ + */ +#define LL_SYSCFG_EXTI_PORTA (uint32_t)0U /*!< EXTI PORT A */ +#define LL_SYSCFG_EXTI_PORTB (uint32_t)1U /*!< EXTI PORT B */ +#define LL_SYSCFG_EXTI_PORTC (uint32_t)2U /*!< EXTI PORT C */ +#if defined(GPIOD_BASE) +#define LL_SYSCFG_EXTI_PORTD (uint32_t)3U /*!< EXTI PORT D */ +#endif /*GPIOD_BASE*/ +#if defined(GPIOE_BASE) +#define LL_SYSCFG_EXTI_PORTE (uint32_t)4U /*!< EXTI PORT E */ +#endif /*GPIOE_BASE*/ +#define LL_SYSCFG_EXTI_PORTF (uint32_t)5U /*!< EXTI PORT F */ +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EC_EXTI_LINE SYSCFG EXTI LINE + * @{ + */ +#define LL_SYSCFG_EXTI_LINE0 (uint32_t)(0U << 16U | 0U) /*!< EXTI_POSITION_0 | EXTICR[0] */ +#define LL_SYSCFG_EXTI_LINE1 (uint32_t)(4U << 16U | 0U) /*!< EXTI_POSITION_4 | EXTICR[0] */ +#define LL_SYSCFG_EXTI_LINE2 (uint32_t)(8U << 16U | 0U) /*!< EXTI_POSITION_8 | EXTICR[0] */ +#define LL_SYSCFG_EXTI_LINE3 (uint32_t)(12U << 16U | 0U) /*!< EXTI_POSITION_12 | EXTICR[0] */ +#define LL_SYSCFG_EXTI_LINE4 (uint32_t)(0U << 16U | 1U) /*!< EXTI_POSITION_0 | EXTICR[1] */ +#define LL_SYSCFG_EXTI_LINE5 (uint32_t)(4U << 16U | 1U) /*!< EXTI_POSITION_4 | EXTICR[1] */ +#define LL_SYSCFG_EXTI_LINE6 (uint32_t)(8U << 16U | 1U) /*!< EXTI_POSITION_8 | EXTICR[1] */ +#define LL_SYSCFG_EXTI_LINE7 (uint32_t)(12U << 16U | 1U) /*!< EXTI_POSITION_12 | EXTICR[1] */ +#define LL_SYSCFG_EXTI_LINE8 (uint32_t)(0U << 16U | 2U) /*!< EXTI_POSITION_0 | EXTICR[2] */ +#define LL_SYSCFG_EXTI_LINE9 (uint32_t)(4U << 16U | 2U) /*!< EXTI_POSITION_4 | EXTICR[2] */ +#define LL_SYSCFG_EXTI_LINE10 (uint32_t)(8U << 16U | 2U) /*!< EXTI_POSITION_8 | EXTICR[2] */ +#define LL_SYSCFG_EXTI_LINE11 (uint32_t)(12U << 16U | 2U) /*!< EXTI_POSITION_12 | EXTICR[2] */ +#define LL_SYSCFG_EXTI_LINE12 (uint32_t)(0U << 16U | 3U) /*!< EXTI_POSITION_0 | EXTICR[3] */ +#define LL_SYSCFG_EXTI_LINE13 (uint32_t)(4U << 16U | 3U) /*!< EXTI_POSITION_4 | EXTICR[3] */ +#define LL_SYSCFG_EXTI_LINE14 (uint32_t)(8U << 16U | 3U) /*!< EXTI_POSITION_8 | EXTICR[3] */ +#define LL_SYSCFG_EXTI_LINE15 (uint32_t)(12U << 16U | 3U) /*!< EXTI_POSITION_12 | EXTICR[3] */ +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EC_TIMBREAK SYSCFG TIMER BREAK + * @{ + */ +#if defined(SYSCFG_CFGR2_PVD_LOCK) +#define LL_SYSCFG_TIMBREAK_PVD SYSCFG_CFGR2_PVD_LOCK /*!< Enables and locks the PVD connection + with TIM1/15/16U/17 Break Input and also + the PVDE and PLS bits of the Power Control Interface */ +#endif /*SYSCFG_CFGR2_PVD_LOCK*/ +#define LL_SYSCFG_TIMBREAK_SRAM_PARITY SYSCFG_CFGR2_SRAM_PARITY_LOCK /*!< Enables and locks the SRAM_PARITY error signal + with Break Input of TIM1/15/16/17 */ +#define LL_SYSCFG_TIMBREAK_LOCKUP SYSCFG_CFGR2_LOCKUP_LOCK /*!< Enables and locks the LOCKUP (Hardfault) output of + CortexM0 with Break Input of TIM1/15/16/17 */ +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EC_APB1_GRP1_STOP_IP DBGMCU APB1 GRP1 STOP IP + * @{ + */ +#if defined(DBGMCU_APB1_FZ_DBG_TIM2_STOP) +#define LL_DBGMCU_APB1_GRP1_TIM2_STOP DBGMCU_APB1_FZ_DBG_TIM2_STOP /*!< TIM2 counter stopped when core is halted */ +#endif /*DBGMCU_APB1_FZ_DBG_TIM2_STOP*/ +#define LL_DBGMCU_APB1_GRP1_TIM3_STOP DBGMCU_APB1_FZ_DBG_TIM3_STOP /*!< TIM3 counter stopped when core is halted */ +#if defined(DBGMCU_APB1_FZ_DBG_TIM6_STOP) +#define LL_DBGMCU_APB1_GRP1_TIM6_STOP DBGMCU_APB1_FZ_DBG_TIM6_STOP /*!< TIM6 counter stopped when core is halted */ +#endif /*DBGMCU_APB1_FZ_DBG_TIM6_STOP*/ +#if defined(DBGMCU_APB1_FZ_DBG_TIM7_STOP) +#define LL_DBGMCU_APB1_GRP1_TIM7_STOP DBGMCU_APB1_FZ_DBG_TIM7_STOP /*!< TIM7 counter stopped when core is halted */ +#endif /*DBGMCU_APB1_FZ_DBG_TIM7_STOP*/ +#define LL_DBGMCU_APB1_GRP1_TIM14_STOP DBGMCU_APB1_FZ_DBG_TIM14_STOP /*!< TIM14 counter stopped when core is halted */ +#define LL_DBGMCU_APB1_GRP1_RTC_STOP DBGMCU_APB1_FZ_DBG_RTC_STOP /*!< RTC Calendar frozen when core is halted */ +#define LL_DBGMCU_APB1_GRP1_WWDG_STOP DBGMCU_APB1_FZ_DBG_WWDG_STOP /*!< Debug Window Watchdog stopped when Core is halted */ +#define LL_DBGMCU_APB1_GRP1_IWDG_STOP DBGMCU_APB1_FZ_DBG_IWDG_STOP /*!< Debug Independent Watchdog stopped when Core is halted */ +#define LL_DBGMCU_APB1_GRP1_I2C1_STOP DBGMCU_APB1_FZ_DBG_I2C1_SMBUS_TIMEOUT /*!< I2C1 SMBUS timeout mode stopped when Core is halted */ +#if defined(DBGMCU_APB1_FZ_DBG_CAN_STOP) +#define LL_DBGMCU_APB1_GRP1_CAN_STOP DBGMCU_APB1_FZ_DBG_CAN_STOP /*!< CAN debug stopped when Core is halted */ +#endif /*DBGMCU_APB1_FZ_DBG_CAN_STOP*/ +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EC_APB1 GRP2_STOP_IP DBGMCU APB1 GRP2 STOP IP + * @{ + */ +#define LL_DBGMCU_APB1_GRP2_TIM1_STOP DBGMCU_APB2_FZ_DBG_TIM1_STOP /*!< TIM1 counter stopped when core is halted */ +#if defined(DBGMCU_APB2_FZ_DBG_TIM15_STOP) +#define LL_DBGMCU_APB1_GRP2_TIM15_STOP DBGMCU_APB2_FZ_DBG_TIM15_STOP /*!< TIM15 counter stopped when core is halted */ +#endif /*DBGMCU_APB2_FZ_DBG_TIM15_STOP*/ +#define LL_DBGMCU_APB1_GRP2_TIM16_STOP DBGMCU_APB2_FZ_DBG_TIM16_STOP /*!< TIM16 counter stopped when core is halted */ +#define LL_DBGMCU_APB1_GRP2_TIM17_STOP DBGMCU_APB2_FZ_DBG_TIM17_STOP /*!< TIM17 counter stopped when core is halted */ +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EC_LATENCY FLASH LATENCY + * @{ + */ +#define LL_FLASH_LATENCY_0 0x00000000U /*!< FLASH Zero Latency cycle */ +#define LL_FLASH_LATENCY_1 FLASH_ACR_LATENCY /*!< FLASH One Latency cycle */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup SYSTEM_LL_Exported_Functions SYSTEM Exported Functions + * @{ + */ + +/** @defgroup SYSTEM_LL_EF_SYSCFG SYSCFG + * @{ + */ + +/** + * @brief Set memory mapping at address 0x00000000 + * @rmtoll SYSCFG_CFGR1 MEM_MODE LL_SYSCFG_SetRemapMemory + * @param Memory This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_REMAP_FLASH + * @arg @ref LL_SYSCFG_REMAP_SYSTEMFLASH + * @arg @ref LL_SYSCFG_REMAP_SRAM + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetRemapMemory(uint32_t Memory) +{ + MODIFY_REG(SYSCFG->CFGR1, SYSCFG_CFGR1_MEM_MODE, Memory); +} + +/** + * @brief Get memory mapping at address 0x00000000 + * @rmtoll SYSCFG_CFGR1 MEM_MODE LL_SYSCFG_GetRemapMemory + * @retval Returned value can be one of the following values: + * @arg @ref LL_SYSCFG_REMAP_FLASH + * @arg @ref LL_SYSCFG_REMAP_SYSTEMFLASH + * @arg @ref LL_SYSCFG_REMAP_SRAM + */ +__STATIC_INLINE uint32_t LL_SYSCFG_GetRemapMemory(void) +{ + return (uint32_t)(READ_BIT(SYSCFG->CFGR1, SYSCFG_CFGR1_MEM_MODE)); +} + +#if defined(SYSCFG_CFGR1_IR_MOD) +/** + * @brief Set IR Modulation Envelope signal source. + * @rmtoll SYSCFG_CFGR1 IR_MOD LL_SYSCFG_SetIRModEnvelopeSignal + * @param Source This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_IR_MOD_TIM16 + * @arg @ref LL_SYSCFG_IR_MOD_USART1 + * @arg @ref LL_SYSCFG_IR_MOD_USART4 + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetIRModEnvelopeSignal(uint32_t Source) +{ + MODIFY_REG(SYSCFG->CFGR1, SYSCFG_CFGR1_IR_MOD, Source); +} + +/** + * @brief Get IR Modulation Envelope signal source. + * @rmtoll SYSCFG_CFGR1 IR_MOD LL_SYSCFG_GetIRModEnvelopeSignal + * @retval Returned value can be one of the following values: + * @arg @ref LL_SYSCFG_IR_MOD_TIM16 + * @arg @ref LL_SYSCFG_IR_MOD_USART1 + * @arg @ref LL_SYSCFG_IR_MOD_USART4 + */ +__STATIC_INLINE uint32_t LL_SYSCFG_GetIRModEnvelopeSignal(void) +{ + return (uint32_t)(READ_BIT(SYSCFG->CFGR1, SYSCFG_CFGR1_IR_MOD)); +} +#endif /* SYSCFG_CFGR1_IR_MOD */ + +#if defined(SYSCFG_CFGR1_USART1TX_DMA_RMP) || defined(SYSCFG_CFGR1_USART1RX_DMA_RMP) || defined(SYSCFG_CFGR1_USART2_DMA_RMP) || defined(SYSCFG_CFGR1_USART3_DMA_RMP) +/** + * @brief Set DMA request remapping bits for USART + * @rmtoll SYSCFG_CFGR1 USART1TX_DMA_RMP LL_SYSCFG_SetRemapDMA_USART\n + * SYSCFG_CFGR1 USART1RX_DMA_RMP LL_SYSCFG_SetRemapDMA_USART\n + * SYSCFG_CFGR1 USART2_DMA_RMP LL_SYSCFG_SetRemapDMA_USART\n + * SYSCFG_CFGR1 USART3_DMA_RMP LL_SYSCFG_SetRemapDMA_USART + * @param Remap This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_USART1TX_RMP_DMA1CH2 (*) + * @arg @ref LL_SYSCFG_USART1TX_RMP_DMA1CH4 (*) + * @arg @ref LL_SYSCFG_USART1RX_RMP_DMA1CH3 (*) + * @arg @ref LL_SYSCFG_USART1RX_RMP_DMA1CH5 (*) + * @arg @ref LL_SYSCFG_USART2_RMP_DMA1CH54 (*) + * @arg @ref LL_SYSCFG_USART2_RMP_DMA1CH67 (*) + * @arg @ref LL_SYSCFG_USART3_RMP_DMA1CH67 (*) + * @arg @ref LL_SYSCFG_USART3_RMP_DMA1CH32 (*) + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetRemapDMA_USART(uint32_t Remap) +{ + MODIFY_REG(SYSCFG->CFGR1, (Remap & 0x00FF00FFU) << 8U, (Remap & 0xFF00FF00U)); +} +#endif /* SYSCFG_CFGR1_USART1TX_DMA_RMP || SYSCFG_CFGR1_USART1RX_DMA_RMP || SYSCFG_CFGR1_USART2_DMA_RMP || SYSCFG_CFGR1_USART3_DMA_RMP */ + +#if defined(SYSCFG_CFGR1_SPI2_DMA_RMP) +/** + * @brief Set DMA request remapping bits for SPI + * @rmtoll SYSCFG_CFGR1 SPI2_DMA_RMP LL_SYSCFG_SetRemapDMA_SPI + * @param Remap This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_SPI2_RMP_DMA1_CH45 + * @arg @ref LL_SYSCFG_SPI2_RMP_DMA1_CH67 + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetRemapDMA_SPI(uint32_t Remap) +{ + MODIFY_REG(SYSCFG->CFGR1, SYSCFG_CFGR1_SPI2_DMA_RMP, Remap); +} +#endif /* SYSCFG_CFGR1_SPI2_DMA_RMP */ + +#if defined(SYSCFG_CFGR1_I2C1_DMA_RMP) +/** + * @brief Set DMA request remapping bits for I2C + * @rmtoll SYSCFG_CFGR1 I2C1_DMA_RMP LL_SYSCFG_SetRemapDMA_I2C + * @param Remap This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_I2C1_RMP_DMA1_CH32 + * @arg @ref LL_SYSCFG_I2C1_RMP_DMA1_CH76 + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetRemapDMA_I2C(uint32_t Remap) +{ + MODIFY_REG(SYSCFG->CFGR1, SYSCFG_CFGR1_I2C1_DMA_RMP, Remap); +} +#endif /* SYSCFG_CFGR1_I2C1_DMA_RMP */ + +#if defined(SYSCFG_CFGR1_ADC_DMA_RMP) +/** + * @brief Set DMA request remapping bits for ADC + * @rmtoll SYSCFG_CFGR1 ADC_DMA_RMP LL_SYSCFG_SetRemapDMA_ADC + * @param Remap This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_ADC1_RMP_DMA1_CH1 + * @arg @ref LL_SYSCFG_ADC1_RMP_DMA1_CH2 + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetRemapDMA_ADC(uint32_t Remap) +{ + MODIFY_REG(SYSCFG->CFGR1, SYSCFG_CFGR1_ADC_DMA_RMP, Remap); +} +#endif /* SYSCFG_CFGR1_ADC_DMA_RMP */ + +#if defined(SYSCFG_CFGR1_TIM16_DMA_RMP) || defined(SYSCFG_CFGR1_TIM17_DMA_RMP) || defined(SYSCFG_CFGR1_TIM1_DMA_RMP) || defined(SYSCFG_CFGR1_TIM2_DMA_RMP) || defined(SYSCFG_CFGR1_TIM3_DMA_RMP) +/** + * @brief Set DMA request remapping bits for TIM + * @rmtoll SYSCFG_CFGR1 TIM16_DMA_RMP LL_SYSCFG_SetRemapDMA_TIM\n + * SYSCFG_CFGR1 TIM17_DMA_RMP LL_SYSCFG_SetRemapDMA_TIM\n + * SYSCFG_CFGR1 TIM16_DMA_RMP2 LL_SYSCFG_SetRemapDMA_TIM\n + * SYSCFG_CFGR1 TIM17_DMA_RMP2 LL_SYSCFG_SetRemapDMA_TIM\n + * SYSCFG_CFGR1 TIM1_DMA_RMP LL_SYSCFG_SetRemapDMA_TIM\n + * SYSCFG_CFGR1 TIM2_DMA_RMP LL_SYSCFG_SetRemapDMA_TIM\n + * SYSCFG_CFGR1 TIM3_DMA_RMP LL_SYSCFG_SetRemapDMA_TIM + * @param Remap This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_TIM16_RMP_DMA1_CH3 (*) + * @arg @ref LL_SYSCFG_TIM16_RMP_DMA1_CH4 (*) + * @arg @ref LL_SYSCFG_TIM16_RMP_DMA1_CH6 (*) + * @arg @ref LL_SYSCFG_TIM17_RMP_DMA1_CH1 (*) + * @arg @ref LL_SYSCFG_TIM17_RMP_DMA1_CH2 (*) + * @arg @ref LL_SYSCFG_TIM17_RMP_DMA1_CH7 (*) + * @arg @ref LL_SYSCFG_TIM1_RMP_DMA1_CH234 (*) + * @arg @ref LL_SYSCFG_TIM1_RMP_DMA1_CH6 (*) + * @arg @ref LL_SYSCFG_TIM2_RMP_DMA1_CH34 (*) + * @arg @ref LL_SYSCFG_TIM2_RMP_DMA1_CH7 (*) + * @arg @ref LL_SYSCFG_TIM3_RMP_DMA1_CH4 (*) + * @arg @ref LL_SYSCFG_TIM3_RMP_DMA1_CH6 (*) + * + * (*) value not defined in all devices. + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetRemapDMA_TIM(uint32_t Remap) +{ + MODIFY_REG(SYSCFG->CFGR1, (Remap & 0x00FF00FFU) << 8U, (Remap & 0xFF00FF00U)); +} +#endif /* SYSCFG_CFGR1_TIM16_DMA_RMP || SYSCFG_CFGR1_TIM17_DMA_RMP || SYSCFG_CFGR1_TIM1_DMA_RMP || SYSCFG_CFGR1_TIM2_DMA_RMP || SYSCFG_CFGR1_TIM3_DMA_RMP */ + +#if defined(SYSCFG_CFGR1_PA11_PA12_RMP) +/** + * @brief Enable PIN pair PA11/12 mapped instead of PA9/10 (control the mapping of either + * PA9/10 or PA11/12 pin pair on small pin-count packages) + * @rmtoll SYSCFG_CFGR1 PA11_PA12_RMP LL_SYSCFG_EnablePinRemap + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_EnablePinRemap(void) +{ + SET_BIT(SYSCFG->CFGR1, SYSCFG_CFGR1_PA11_PA12_RMP); +} + +/** + * @brief Disable PIN pair PA11/12 mapped instead of PA9/10 (control the mapping of either + * PA9/10 or PA11/12 pin pair on small pin-count packages) + * @rmtoll SYSCFG_CFGR1 PA11_PA12_RMP LL_SYSCFG_DisablePinRemap + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_DisablePinRemap(void) +{ + CLEAR_BIT(SYSCFG->CFGR1, SYSCFG_CFGR1_PA11_PA12_RMP); +} +#endif /* SYSCFG_CFGR1_PA11_PA12_RMP */ + +/** + * @brief Enable the I2C fast mode plus driving capability. + * @rmtoll SYSCFG_CFGR1 I2C_FMP_PB6 LL_SYSCFG_EnableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PB7 LL_SYSCFG_EnableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PB8 LL_SYSCFG_EnableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PB9 LL_SYSCFG_EnableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_I2C1 LL_SYSCFG_EnableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_I2C2 LL_SYSCFG_EnableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PA9 LL_SYSCFG_EnableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PA10 LL_SYSCFG_EnableFastModePlus + * @param ConfigFastModePlus This parameter can be a combination of the following values: + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB6 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB7 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB8 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB9 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_I2C1 (*) + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_I2C2 (*) + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PA9 (*) + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PA10 (*) + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_EnableFastModePlus(uint32_t ConfigFastModePlus) +{ + SET_BIT(SYSCFG->CFGR1, ConfigFastModePlus); +} + +/** + * @brief Disable the I2C fast mode plus driving capability. + * @rmtoll SYSCFG_CFGR1 I2C_FMP_PB6 LL_SYSCFG_DisableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PB7 LL_SYSCFG_DisableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PB8 LL_SYSCFG_DisableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PB9 LL_SYSCFG_DisableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_I2C1 LL_SYSCFG_DisableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_I2C2 LL_SYSCFG_DisableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PA9 LL_SYSCFG_DisableFastModePlus\n + * SYSCFG_CFGR1 I2C_FMP_PA10 LL_SYSCFG_DisableFastModePlus + * @param ConfigFastModePlus This parameter can be a combination of the following values: + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB6 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB7 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB8 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PB9 + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_I2C1 (*) + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_I2C2 (*) + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PA9 (*) + * @arg @ref LL_SYSCFG_I2C_FASTMODEPLUS_PA10 (*) + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_DisableFastModePlus(uint32_t ConfigFastModePlus) +{ + CLEAR_BIT(SYSCFG->CFGR1, ConfigFastModePlus); +} + +/** + * @brief Configure source input for the EXTI external interrupt. + * @rmtoll SYSCFG_EXTICR1 EXTI0 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR1 EXTI1 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR1 EXTI2 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR1 EXTI3 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI4 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI5 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI6 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI7 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI8 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI9 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI10 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI11 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI12 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI13 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI14 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI15 LL_SYSCFG_SetEXTISource + * @param Port This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_EXTI_PORTA + * @arg @ref LL_SYSCFG_EXTI_PORTB + * @arg @ref LL_SYSCFG_EXTI_PORTC + * @arg @ref LL_SYSCFG_EXTI_PORTD (*) + * @arg @ref LL_SYSCFG_EXTI_PORTE (*) + * @arg @ref LL_SYSCFG_EXTI_PORTF + * + * (*) value not defined in all devices + * @param Line This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_EXTI_LINE0 + * @arg @ref LL_SYSCFG_EXTI_LINE1 + * @arg @ref LL_SYSCFG_EXTI_LINE2 + * @arg @ref LL_SYSCFG_EXTI_LINE3 + * @arg @ref LL_SYSCFG_EXTI_LINE4 + * @arg @ref LL_SYSCFG_EXTI_LINE5 + * @arg @ref LL_SYSCFG_EXTI_LINE6 + * @arg @ref LL_SYSCFG_EXTI_LINE7 + * @arg @ref LL_SYSCFG_EXTI_LINE8 + * @arg @ref LL_SYSCFG_EXTI_LINE9 + * @arg @ref LL_SYSCFG_EXTI_LINE10 + * @arg @ref LL_SYSCFG_EXTI_LINE11 + * @arg @ref LL_SYSCFG_EXTI_LINE12 + * @arg @ref LL_SYSCFG_EXTI_LINE13 + * @arg @ref LL_SYSCFG_EXTI_LINE14 + * @arg @ref LL_SYSCFG_EXTI_LINE15 + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetEXTISource(uint32_t Port, uint32_t Line) +{ + MODIFY_REG(SYSCFG->EXTICR[Line & 0xFF], SYSCFG_EXTICR1_EXTI0 << (Line >> 16), Port << (Line >> 16)); +} + +/** + * @brief Get the configured defined for specific EXTI Line + * @rmtoll SYSCFG_EXTICR1 EXTI0 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR1 EXTI1 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR1 EXTI2 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR1 EXTI3 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI4 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI5 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI6 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR2 EXTI7 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI8 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI9 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI10 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR3 EXTI11 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI12 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI13 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI14 LL_SYSCFG_SetEXTISource\n + * SYSCFG_EXTICR4 EXTI15 LL_SYSCFG_SetEXTISource + * @param Line This parameter can be one of the following values: + * @arg @ref LL_SYSCFG_EXTI_LINE0 + * @arg @ref LL_SYSCFG_EXTI_LINE1 + * @arg @ref LL_SYSCFG_EXTI_LINE2 + * @arg @ref LL_SYSCFG_EXTI_LINE3 + * @arg @ref LL_SYSCFG_EXTI_LINE4 + * @arg @ref LL_SYSCFG_EXTI_LINE5 + * @arg @ref LL_SYSCFG_EXTI_LINE6 + * @arg @ref LL_SYSCFG_EXTI_LINE7 + * @arg @ref LL_SYSCFG_EXTI_LINE8 + * @arg @ref LL_SYSCFG_EXTI_LINE9 + * @arg @ref LL_SYSCFG_EXTI_LINE10 + * @arg @ref LL_SYSCFG_EXTI_LINE11 + * @arg @ref LL_SYSCFG_EXTI_LINE12 + * @arg @ref LL_SYSCFG_EXTI_LINE13 + * @arg @ref LL_SYSCFG_EXTI_LINE14 + * @arg @ref LL_SYSCFG_EXTI_LINE15 + * @retval Returned value can be one of the following values: + * @arg @ref LL_SYSCFG_EXTI_PORTA + * @arg @ref LL_SYSCFG_EXTI_PORTB + * @arg @ref LL_SYSCFG_EXTI_PORTC + * @arg @ref LL_SYSCFG_EXTI_PORTD (*) + * @arg @ref LL_SYSCFG_EXTI_PORTE (*) + * @arg @ref LL_SYSCFG_EXTI_PORTF + * + * (*) value not defined in all devices + */ +__STATIC_INLINE uint32_t LL_SYSCFG_GetEXTISource(uint32_t Line) +{ + return (uint32_t)(READ_BIT(SYSCFG->EXTICR[Line & 0xFF], (SYSCFG_EXTICR1_EXTI0 << (Line >> 16))) >> (Line >> 16)); +} + +#if defined(SYSCFG_ITLINE0_SR_EWDG) +/** + * @brief Check if Window watchdog interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE0 SR_EWDG LL_SYSCFG_IsActiveFlag_WWDG + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_WWDG(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[0], SYSCFG_ITLINE0_SR_EWDG) == (SYSCFG_ITLINE0_SR_EWDG)); +} +#endif /* SYSCFG_ITLINE0_SR_EWDG */ + +#if defined(SYSCFG_ITLINE1_SR_PVDOUT) +/** + * @brief Check if PVD supply monitoring interrupt occurred or not (EXTI line 16). + * @rmtoll SYSCFG_ITLINE1 SR_PVDOUT LL_SYSCFG_IsActiveFlag_PVDOUT + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_PVDOUT(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[1], SYSCFG_ITLINE1_SR_PVDOUT) == (SYSCFG_ITLINE1_SR_PVDOUT)); +} +#endif /* SYSCFG_ITLINE1_SR_PVDOUT */ + +#if defined(SYSCFG_ITLINE1_SR_VDDIO2) +/** + * @brief Check if VDDIO2 supply monitoring interrupt occurred or not (EXTI line 31). + * @rmtoll SYSCFG_ITLINE1 SR_VDDIO2 LL_SYSCFG_IsActiveFlag_VDDIO2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_VDDIO2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[1], SYSCFG_ITLINE1_SR_VDDIO2) == (SYSCFG_ITLINE1_SR_VDDIO2)); +} +#endif /* SYSCFG_ITLINE1_SR_VDDIO2 */ + +#if defined(SYSCFG_ITLINE2_SR_RTC_WAKEUP) +/** + * @brief Check if RTC Wake Up interrupt occurred or not (EXTI line 20). + * @rmtoll SYSCFG_ITLINE2 SR_RTC_WAKEUP LL_SYSCFG_IsActiveFlag_RTC_WAKEUP + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_RTC_WAKEUP(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[2], SYSCFG_ITLINE2_SR_RTC_WAKEUP) == (SYSCFG_ITLINE2_SR_RTC_WAKEUP)); +} +#endif /* SYSCFG_ITLINE2_SR_RTC_WAKEUP */ + +#if defined(SYSCFG_ITLINE2_SR_RTC_TSTAMP) +/** + * @brief Check if RTC Tamper and TimeStamp interrupt occurred or not (EXTI line 19). + * @rmtoll SYSCFG_ITLINE2 SR_RTC_TSTAMP LL_SYSCFG_IsActiveFlag_RTC_TSTAMP + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_RTC_TSTAMP(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[2], SYSCFG_ITLINE2_SR_RTC_TSTAMP) == (SYSCFG_ITLINE2_SR_RTC_TSTAMP)); +} +#endif /* SYSCFG_ITLINE2_SR_RTC_TSTAMP */ + +#if defined(SYSCFG_ITLINE2_SR_RTC_ALRA) +/** + * @brief Check if RTC Alarm interrupt occurred or not (EXTI line 17). + * @rmtoll SYSCFG_ITLINE2 SR_RTC_ALRA LL_SYSCFG_IsActiveFlag_RTC_ALRA + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_RTC_ALRA(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[2], SYSCFG_ITLINE2_SR_RTC_ALRA) == (SYSCFG_ITLINE2_SR_RTC_ALRA)); +} +#endif /* SYSCFG_ITLINE2_SR_RTC_ALRA */ + +#if defined(SYSCFG_ITLINE3_SR_FLASH_ITF) +/** + * @brief Check if Flash interface interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE3 SR_FLASH_ITF LL_SYSCFG_IsActiveFlag_FLASH_ITF + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_FLASH_ITF(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[3], SYSCFG_ITLINE3_SR_FLASH_ITF) == (SYSCFG_ITLINE3_SR_FLASH_ITF)); +} +#endif /* SYSCFG_ITLINE3_SR_FLASH_ITF */ + +#if defined(SYSCFG_ITLINE4_SR_CRS) +/** + * @brief Check if Clock recovery system interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE4 SR_CRS LL_SYSCFG_IsActiveFlag_CRS + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_CRS(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[4], SYSCFG_ITLINE4_SR_CRS) == (SYSCFG_ITLINE4_SR_CRS)); +} +#endif /* SYSCFG_ITLINE4_SR_CRS */ + +#if defined(SYSCFG_ITLINE4_SR_CLK_CTRL) +/** + * @brief Check if Reset and clock control interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE4 SR_CLK_CTRL LL_SYSCFG_IsActiveFlag_CLK_CTRL + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_CLK_CTRL(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[4], SYSCFG_ITLINE4_SR_CLK_CTRL) == (SYSCFG_ITLINE4_SR_CLK_CTRL)); +} +#endif /* SYSCFG_ITLINE4_SR_CLK_CTRL */ + +#if defined(SYSCFG_ITLINE5_SR_EXTI0) +/** + * @brief Check if EXTI line 0 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE5 SR_EXTI0 LL_SYSCFG_IsActiveFlag_EXTI0 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI0(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[5], SYSCFG_ITLINE5_SR_EXTI0) == (SYSCFG_ITLINE5_SR_EXTI0)); +} +#endif /* SYSCFG_ITLINE5_SR_EXTI0 */ + +#if defined(SYSCFG_ITLINE5_SR_EXTI1) +/** + * @brief Check if EXTI line 1 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE5 SR_EXTI1 LL_SYSCFG_IsActiveFlag_EXTI1 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI1(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[5], SYSCFG_ITLINE5_SR_EXTI1) == (SYSCFG_ITLINE5_SR_EXTI1)); +} +#endif /* SYSCFG_ITLINE5_SR_EXTI1 */ + +#if defined(SYSCFG_ITLINE6_SR_EXTI2) +/** + * @brief Check if EXTI line 2 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE6 SR_EXTI2 LL_SYSCFG_IsActiveFlag_EXTI2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[6], SYSCFG_ITLINE6_SR_EXTI2) == (SYSCFG_ITLINE6_SR_EXTI2)); +} +#endif /* SYSCFG_ITLINE6_SR_EXTI2 */ + +#if defined(SYSCFG_ITLINE6_SR_EXTI3) +/** + * @brief Check if EXTI line 3 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE6 SR_EXTI3 LL_SYSCFG_IsActiveFlag_EXTI3 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI3(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[6], SYSCFG_ITLINE6_SR_EXTI3) == (SYSCFG_ITLINE6_SR_EXTI3)); +} +#endif /* SYSCFG_ITLINE6_SR_EXTI3 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI4) +/** + * @brief Check if EXTI line 4 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI4 LL_SYSCFG_IsActiveFlag_EXTI4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI4(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI4) == (SYSCFG_ITLINE7_SR_EXTI4)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI4 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI5) +/** + * @brief Check if EXTI line 5 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI5 LL_SYSCFG_IsActiveFlag_EXTI5 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI5(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI5) == (SYSCFG_ITLINE7_SR_EXTI5)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI5 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI6) +/** + * @brief Check if EXTI line 6 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI6 LL_SYSCFG_IsActiveFlag_EXTI6 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI6(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI6) == (SYSCFG_ITLINE7_SR_EXTI6)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI6 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI7) +/** + * @brief Check if EXTI line 7 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI7 LL_SYSCFG_IsActiveFlag_EXTI7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI7(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI7) == (SYSCFG_ITLINE7_SR_EXTI7)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI7 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI8) +/** + * @brief Check if EXTI line 8 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI8 LL_SYSCFG_IsActiveFlag_EXTI8 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI8(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI8) == (SYSCFG_ITLINE7_SR_EXTI8)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI8 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI9) +/** + * @brief Check if EXTI line 9 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI9 LL_SYSCFG_IsActiveFlag_EXTI9 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI9(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI9) == (SYSCFG_ITLINE7_SR_EXTI9)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI9 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI10) +/** + * @brief Check if EXTI line 10 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI10 LL_SYSCFG_IsActiveFlag_EXTI10 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI10(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI10) == (SYSCFG_ITLINE7_SR_EXTI10)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI10 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI11) +/** + * @brief Check if EXTI line 11 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI11 LL_SYSCFG_IsActiveFlag_EXTI11 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI11(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI11) == (SYSCFG_ITLINE7_SR_EXTI11)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI11 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI12) +/** + * @brief Check if EXTI line 12 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI12 LL_SYSCFG_IsActiveFlag_EXTI12 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI12(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI12) == (SYSCFG_ITLINE7_SR_EXTI12)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI12 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI13) +/** + * @brief Check if EXTI line 13 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI13 LL_SYSCFG_IsActiveFlag_EXTI13 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI13(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI13) == (SYSCFG_ITLINE7_SR_EXTI13)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI13 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI14) +/** + * @brief Check if EXTI line 14 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI14 LL_SYSCFG_IsActiveFlag_EXTI14 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI14(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI14) == (SYSCFG_ITLINE7_SR_EXTI14)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI14 */ + +#if defined(SYSCFG_ITLINE7_SR_EXTI15) +/** + * @brief Check if EXTI line 15 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE7 SR_EXTI15 LL_SYSCFG_IsActiveFlag_EXTI15 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_EXTI15(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[7], SYSCFG_ITLINE7_SR_EXTI15) == (SYSCFG_ITLINE7_SR_EXTI15)); +} +#endif /* SYSCFG_ITLINE7_SR_EXTI15 */ + +#if defined(SYSCFG_ITLINE8_SR_TSC_EOA) +/** + * @brief Check if Touch sensing controller end of acquisition interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE8 SR_TSC_EOA LL_SYSCFG_IsActiveFlag_TSC_EOA + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TSC_EOA(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[8], SYSCFG_ITLINE8_SR_TSC_EOA) == (SYSCFG_ITLINE8_SR_TSC_EOA)); +} +#endif /* SYSCFG_ITLINE8_SR_TSC_EOA */ + +#if defined(SYSCFG_ITLINE8_SR_TSC_MCE) +/** + * @brief Check if Touch sensing controller max counterror interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE8 SR_TSC_MCE LL_SYSCFG_IsActiveFlag_TSC_MCE + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TSC_MCE(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[8], SYSCFG_ITLINE8_SR_TSC_MCE) == (SYSCFG_ITLINE8_SR_TSC_MCE)); +} +#endif /* SYSCFG_ITLINE8_SR_TSC_MCE */ + +#if defined(SYSCFG_ITLINE9_SR_DMA1_CH1) +/** + * @brief Check if DMA1 channel 1 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE9 SR_DMA1_CH1 LL_SYSCFG_IsActiveFlag_DMA1_CH1 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA1_CH1(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[9], SYSCFG_ITLINE9_SR_DMA1_CH1) == (SYSCFG_ITLINE9_SR_DMA1_CH1)); +} +#endif /* SYSCFG_ITLINE9_SR_DMA1_CH1 */ + +#if defined(SYSCFG_ITLINE10_SR_DMA1_CH2) +/** + * @brief Check if DMA1 channel 2 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE10 SR_DMA1_CH2 LL_SYSCFG_IsActiveFlag_DMA1_CH2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA1_CH2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[10], SYSCFG_ITLINE10_SR_DMA1_CH2) == (SYSCFG_ITLINE10_SR_DMA1_CH2)); +} +#endif /* SYSCFG_ITLINE10_SR_DMA1_CH2 */ + +#if defined(SYSCFG_ITLINE10_SR_DMA1_CH3) +/** + * @brief Check if DMA1 channel 3 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE10 SR_DMA1_CH3 LL_SYSCFG_IsActiveFlag_DMA1_CH3 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA1_CH3(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[10], SYSCFG_ITLINE10_SR_DMA1_CH3) == (SYSCFG_ITLINE10_SR_DMA1_CH3)); +} +#endif /* SYSCFG_ITLINE10_SR_DMA1_CH3 */ + +#if defined(SYSCFG_ITLINE10_SR_DMA2_CH1) +/** + * @brief Check if DMA2 channel 1 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE10 SR_DMA2_CH1 LL_SYSCFG_IsActiveFlag_DMA2_CH1 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA2_CH1(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[10], SYSCFG_ITLINE10_SR_DMA2_CH1) == (SYSCFG_ITLINE10_SR_DMA2_CH1)); +} +#endif /* SYSCFG_ITLINE10_SR_DMA2_CH1 */ + +#if defined(SYSCFG_ITLINE10_SR_DMA2_CH2) +/** + * @brief Check if DMA2 channel 2 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE10 SR_DMA2_CH2 LL_SYSCFG_IsActiveFlag_DMA2_CH2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA2_CH2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[10], SYSCFG_ITLINE10_SR_DMA2_CH2) == (SYSCFG_ITLINE10_SR_DMA2_CH2)); +} +#endif /* SYSCFG_ITLINE10_SR_DMA2_CH2 */ + +#if defined(SYSCFG_ITLINE11_SR_DMA1_CH4) +/** + * @brief Check if DMA1 channel 4 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE11 SR_DMA1_CH4 LL_SYSCFG_IsActiveFlag_DMA1_CH4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA1_CH4(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[11], SYSCFG_ITLINE11_SR_DMA1_CH4) == (SYSCFG_ITLINE11_SR_DMA1_CH4)); +} +#endif /* SYSCFG_ITLINE11_SR_DMA1_CH4 */ + +#if defined(SYSCFG_ITLINE11_SR_DMA1_CH5) +/** + * @brief Check if DMA1 channel 5 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE11 SR_DMA1_CH5 LL_SYSCFG_IsActiveFlag_DMA1_CH5 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA1_CH5(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[11], SYSCFG_ITLINE11_SR_DMA1_CH5) == (SYSCFG_ITLINE11_SR_DMA1_CH5)); +} +#endif /* SYSCFG_ITLINE11_SR_DMA1_CH5 */ + +#if defined(SYSCFG_ITLINE11_SR_DMA1_CH6) +/** + * @brief Check if DMA1 channel 6 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE11 SR_DMA1_CH6 LL_SYSCFG_IsActiveFlag_DMA1_CH6 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA1_CH6(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[11], SYSCFG_ITLINE11_SR_DMA1_CH6) == (SYSCFG_ITLINE11_SR_DMA1_CH6)); +} +#endif /* SYSCFG_ITLINE11_SR_DMA1_CH6 */ + +#if defined(SYSCFG_ITLINE11_SR_DMA1_CH7) +/** + * @brief Check if DMA1 channel 7 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE11 SR_DMA1_CH7 LL_SYSCFG_IsActiveFlag_DMA1_CH7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA1_CH7(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[11], SYSCFG_ITLINE11_SR_DMA1_CH7) == (SYSCFG_ITLINE11_SR_DMA1_CH7)); +} +#endif /* SYSCFG_ITLINE11_SR_DMA1_CH7 */ + +#if defined(SYSCFG_ITLINE11_SR_DMA2_CH3) +/** + * @brief Check if DMA2 channel 3 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE11 SR_DMA2_CH3 LL_SYSCFG_IsActiveFlag_DMA2_CH3 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA2_CH3(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[11], SYSCFG_ITLINE11_SR_DMA2_CH3) == (SYSCFG_ITLINE11_SR_DMA2_CH3)); +} +#endif /* SYSCFG_ITLINE11_SR_DMA2_CH3 */ + +#if defined(SYSCFG_ITLINE11_SR_DMA2_CH4) +/** + * @brief Check if DMA2 channel 4 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE11 SR_DMA2_CH4 LL_SYSCFG_IsActiveFlag_DMA2_CH4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA2_CH4(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[11], SYSCFG_ITLINE11_SR_DMA2_CH4) == (SYSCFG_ITLINE11_SR_DMA2_CH4)); +} +#endif /* SYSCFG_ITLINE11_SR_DMA2_CH4 */ + +#if defined(SYSCFG_ITLINE11_SR_DMA2_CH5) +/** + * @brief Check if DMA2 channel 5 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE11 SR_DMA2_CH5 LL_SYSCFG_IsActiveFlag_DMA2_CH5 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DMA2_CH5(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[11], SYSCFG_ITLINE11_SR_DMA2_CH5) == (SYSCFG_ITLINE11_SR_DMA2_CH5)); +} +#endif /* SYSCFG_ITLINE11_SR_DMA2_CH5 */ + +#if defined(SYSCFG_ITLINE12_SR_ADC) +/** + * @brief Check if ADC interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE12 SR_ADC LL_SYSCFG_IsActiveFlag_ADC + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_ADC(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[12], SYSCFG_ITLINE12_SR_ADC) == (SYSCFG_ITLINE12_SR_ADC)); +} +#endif /* SYSCFG_ITLINE12_SR_ADC */ + +#if defined(SYSCFG_ITLINE12_SR_COMP1) +/** + * @brief Check if Comparator 1 interrupt occurred or not (EXTI line 21). + * @rmtoll SYSCFG_ITLINE12 SR_COMP1 LL_SYSCFG_IsActiveFlag_COMP1 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_COMP1(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[12], SYSCFG_ITLINE12_SR_COMP1) == (SYSCFG_ITLINE12_SR_COMP1)); +} +#endif /* SYSCFG_ITLINE12_SR_COMP1 */ + +#if defined(SYSCFG_ITLINE12_SR_COMP2) +/** + * @brief Check if Comparator 2 interrupt occurred or not (EXTI line 22). + * @rmtoll SYSCFG_ITLINE12 SR_COMP2 LL_SYSCFG_IsActiveFlag_COMP2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_COMP2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[12], SYSCFG_ITLINE12_SR_COMP2) == (SYSCFG_ITLINE12_SR_COMP2)); +} +#endif /* SYSCFG_ITLINE12_SR_COMP2 */ + +#if defined(SYSCFG_ITLINE13_SR_TIM1_BRK) +/** + * @brief Check if Timer 1 break interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE13 SR_TIM1_BRK LL_SYSCFG_IsActiveFlag_TIM1_BRK + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM1_BRK(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[13], SYSCFG_ITLINE13_SR_TIM1_BRK) == (SYSCFG_ITLINE13_SR_TIM1_BRK)); +} +#endif /* SYSCFG_ITLINE13_SR_TIM1_BRK */ + +#if defined(SYSCFG_ITLINE13_SR_TIM1_UPD) +/** + * @brief Check if Timer 1 update interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE13 SR_TIM1_UPD LL_SYSCFG_IsActiveFlag_TIM1_UPD + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM1_UPD(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[13], SYSCFG_ITLINE13_SR_TIM1_UPD) == (SYSCFG_ITLINE13_SR_TIM1_UPD)); +} +#endif /* SYSCFG_ITLINE13_SR_TIM1_UPD */ + +#if defined(SYSCFG_ITLINE13_SR_TIM1_TRG) +/** + * @brief Check if Timer 1 trigger interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE13 SR_TIM1_TRG LL_SYSCFG_IsActiveFlag_TIM1_TRG + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM1_TRG(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[13], SYSCFG_ITLINE13_SR_TIM1_TRG) == (SYSCFG_ITLINE13_SR_TIM1_TRG)); +} +#endif /* SYSCFG_ITLINE13_SR_TIM1_TRG */ + +#if defined(SYSCFG_ITLINE13_SR_TIM1_CCU) +/** + * @brief Check if Timer 1 commutation interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE13 SR_TIM1_CCU LL_SYSCFG_IsActiveFlag_TIM1_CCU + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM1_CCU(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[13], SYSCFG_ITLINE13_SR_TIM1_CCU) == (SYSCFG_ITLINE13_SR_TIM1_CCU)); +} +#endif /* SYSCFG_ITLINE13_SR_TIM1_CCU */ + +#if defined(SYSCFG_ITLINE14_SR_TIM1_CC) +/** + * @brief Check if Timer 1 capture compare interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE14 SR_TIM1_CC LL_SYSCFG_IsActiveFlag_TIM1_CC + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM1_CC(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[14], SYSCFG_ITLINE14_SR_TIM1_CC) == (SYSCFG_ITLINE14_SR_TIM1_CC)); +} +#endif /* SYSCFG_ITLINE14_SR_TIM1_CC */ + +#if defined(SYSCFG_ITLINE15_SR_TIM2_GLB) +/** + * @brief Check if Timer 2 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE15 SR_TIM2_GLB LL_SYSCFG_IsActiveFlag_TIM2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[15], SYSCFG_ITLINE15_SR_TIM2_GLB) == (SYSCFG_ITLINE15_SR_TIM2_GLB)); +} +#endif /* SYSCFG_ITLINE15_SR_TIM2_GLB */ + +#if defined(SYSCFG_ITLINE16_SR_TIM3_GLB) +/** + * @brief Check if Timer 3 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE16 SR_TIM3_GLB LL_SYSCFG_IsActiveFlag_TIM3 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM3(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[16], SYSCFG_ITLINE16_SR_TIM3_GLB) == (SYSCFG_ITLINE16_SR_TIM3_GLB)); +} +#endif /* SYSCFG_ITLINE16_SR_TIM3_GLB */ + +#if defined(SYSCFG_ITLINE17_SR_DAC) +/** + * @brief Check if DAC underrun interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE17 SR_DAC LL_SYSCFG_IsActiveFlag_DAC + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_DAC(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[17], SYSCFG_ITLINE17_SR_DAC) == (SYSCFG_ITLINE17_SR_DAC)); +} +#endif /* SYSCFG_ITLINE17_SR_DAC */ + +#if defined(SYSCFG_ITLINE17_SR_TIM6_GLB) +/** + * @brief Check if Timer 6 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE17 SR_TIM6_GLB LL_SYSCFG_IsActiveFlag_TIM6 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM6(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[17], SYSCFG_ITLINE17_SR_TIM6_GLB) == (SYSCFG_ITLINE17_SR_TIM6_GLB)); +} +#endif /* SYSCFG_ITLINE17_SR_TIM6_GLB */ + +#if defined(SYSCFG_ITLINE18_SR_TIM7_GLB) +/** + * @brief Check if Timer 7 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE18 SR_TIM7_GLB LL_SYSCFG_IsActiveFlag_TIM7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM7(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[18], SYSCFG_ITLINE18_SR_TIM7_GLB) == (SYSCFG_ITLINE18_SR_TIM7_GLB)); +} +#endif /* SYSCFG_ITLINE18_SR_TIM7_GLB */ + +#if defined(SYSCFG_ITLINE19_SR_TIM14_GLB) +/** + * @brief Check if Timer 14 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE19 SR_TIM14_GLB LL_SYSCFG_IsActiveFlag_TIM14 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM14(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[19], SYSCFG_ITLINE19_SR_TIM14_GLB) == (SYSCFG_ITLINE19_SR_TIM14_GLB)); +} +#endif /* SYSCFG_ITLINE19_SR_TIM14_GLB */ + +#if defined(SYSCFG_ITLINE20_SR_TIM15_GLB) +/** + * @brief Check if Timer 15 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE20 SR_TIM15_GLB LL_SYSCFG_IsActiveFlag_TIM15 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM15(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[20], SYSCFG_ITLINE20_SR_TIM15_GLB) == (SYSCFG_ITLINE20_SR_TIM15_GLB)); +} +#endif /* SYSCFG_ITLINE20_SR_TIM15_GLB */ + +#if defined(SYSCFG_ITLINE21_SR_TIM16_GLB) +/** + * @brief Check if Timer 16 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE21 SR_TIM16_GLB LL_SYSCFG_IsActiveFlag_TIM16 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM16(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[21], SYSCFG_ITLINE21_SR_TIM16_GLB) == (SYSCFG_ITLINE21_SR_TIM16_GLB)); +} +#endif /* SYSCFG_ITLINE21_SR_TIM16_GLB */ + +#if defined(SYSCFG_ITLINE22_SR_TIM17_GLB) +/** + * @brief Check if Timer 17 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE22 SR_TIM17_GLB LL_SYSCFG_IsActiveFlag_TIM17 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_TIM17(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[22], SYSCFG_ITLINE22_SR_TIM17_GLB) == (SYSCFG_ITLINE22_SR_TIM17_GLB)); +} +#endif /* SYSCFG_ITLINE22_SR_TIM17_GLB */ + +#if defined(SYSCFG_ITLINE23_SR_I2C1_GLB) +/** + * @brief Check if I2C1 interrupt occurred or not, combined with EXTI line 23. + * @rmtoll SYSCFG_ITLINE23 SR_I2C1_GLB LL_SYSCFG_IsActiveFlag_I2C1 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_I2C1(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[23], SYSCFG_ITLINE23_SR_I2C1_GLB) == (SYSCFG_ITLINE23_SR_I2C1_GLB)); +} +#endif /* SYSCFG_ITLINE23_SR_I2C1_GLB */ + +#if defined(SYSCFG_ITLINE24_SR_I2C2_GLB) +/** + * @brief Check if I2C2 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE24 SR_I2C2_GLB LL_SYSCFG_IsActiveFlag_I2C2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_I2C2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[24], SYSCFG_ITLINE24_SR_I2C2_GLB) == (SYSCFG_ITLINE24_SR_I2C2_GLB)); +} +#endif /* SYSCFG_ITLINE24_SR_I2C2_GLB */ + +#if defined(SYSCFG_ITLINE25_SR_SPI1) +/** + * @brief Check if SPI1 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE25 SR_SPI1 LL_SYSCFG_IsActiveFlag_SPI1 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_SPI1(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[25], SYSCFG_ITLINE25_SR_SPI1) == (SYSCFG_ITLINE25_SR_SPI1)); +} +#endif /* SYSCFG_ITLINE25_SR_SPI1 */ + +#if defined(SYSCFG_ITLINE26_SR_SPI2) +/** + * @brief Check if SPI2 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE26 SR_SPI2 LL_SYSCFG_IsActiveFlag_SPI2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_SPI2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[26], SYSCFG_ITLINE26_SR_SPI2) == (SYSCFG_ITLINE26_SR_SPI2)); +} +#endif /* SYSCFG_ITLINE26_SR_SPI2 */ + +#if defined(SYSCFG_ITLINE27_SR_USART1_GLB) +/** + * @brief Check if USART1 interrupt occurred or not, combined with EXTI line 25. + * @rmtoll SYSCFG_ITLINE27 SR_USART1_GLB LL_SYSCFG_IsActiveFlag_USART1 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART1(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[27], SYSCFG_ITLINE27_SR_USART1_GLB) == (SYSCFG_ITLINE27_SR_USART1_GLB)); +} +#endif /* SYSCFG_ITLINE27_SR_USART1_GLB */ + +#if defined(SYSCFG_ITLINE28_SR_USART2_GLB) +/** + * @brief Check if USART2 interrupt occurred or not, combined with EXTI line 26. + * @rmtoll SYSCFG_ITLINE28 SR_USART2_GLB LL_SYSCFG_IsActiveFlag_USART2 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART2(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[28], SYSCFG_ITLINE28_SR_USART2_GLB) == (SYSCFG_ITLINE28_SR_USART2_GLB)); +} +#endif /* SYSCFG_ITLINE28_SR_USART2_GLB */ + +#if defined(SYSCFG_ITLINE29_SR_USART3_GLB) +/** + * @brief Check if USART3 interrupt occurred or not, combined with EXTI line 28. + * @rmtoll SYSCFG_ITLINE29 SR_USART3_GLB LL_SYSCFG_IsActiveFlag_USART3 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART3(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[29], SYSCFG_ITLINE29_SR_USART3_GLB) == (SYSCFG_ITLINE29_SR_USART3_GLB)); +} +#endif /* SYSCFG_ITLINE29_SR_USART3_GLB */ + +#if defined(SYSCFG_ITLINE29_SR_USART4_GLB) +/** + * @brief Check if USART4 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE29 SR_USART4_GLB LL_SYSCFG_IsActiveFlag_USART4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART4(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[29], SYSCFG_ITLINE29_SR_USART4_GLB) == (SYSCFG_ITLINE29_SR_USART4_GLB)); +} +#endif /* SYSCFG_ITLINE29_SR_USART4_GLB */ + +#if defined(SYSCFG_ITLINE29_SR_USART5_GLB) +/** + * @brief Check if USART5 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE29 SR_USART5_GLB LL_SYSCFG_IsActiveFlag_USART5 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART5(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[29], SYSCFG_ITLINE29_SR_USART5_GLB) == (SYSCFG_ITLINE29_SR_USART5_GLB)); +} +#endif /* SYSCFG_ITLINE29_SR_USART5_GLB */ + +#if defined(SYSCFG_ITLINE29_SR_USART6_GLB) +/** + * @brief Check if USART6 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE29 SR_USART6_GLB LL_SYSCFG_IsActiveFlag_USART6 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART6(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[29], SYSCFG_ITLINE29_SR_USART6_GLB) == (SYSCFG_ITLINE29_SR_USART6_GLB)); +} +#endif /* SYSCFG_ITLINE29_SR_USART6_GLB */ + +#if defined(SYSCFG_ITLINE29_SR_USART7_GLB) +/** + * @brief Check if USART7 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE29 SR_USART7_GLB LL_SYSCFG_IsActiveFlag_USART7 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART7(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[29], SYSCFG_ITLINE29_SR_USART7_GLB) == (SYSCFG_ITLINE29_SR_USART7_GLB)); +} +#endif /* SYSCFG_ITLINE29_SR_USART7_GLB */ + +#if defined(SYSCFG_ITLINE29_SR_USART8_GLB) +/** + * @brief Check if USART8 interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE29 SR_USART8_GLB LL_SYSCFG_IsActiveFlag_USART8 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_USART8(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[29], SYSCFG_ITLINE29_SR_USART8_GLB) == (SYSCFG_ITLINE29_SR_USART8_GLB)); +} +#endif /* SYSCFG_ITLINE29_SR_USART8_GLB */ + +#if defined(SYSCFG_ITLINE30_SR_CAN) +/** + * @brief Check if CAN interrupt occurred or not. + * @rmtoll SYSCFG_ITLINE30 SR_CAN LL_SYSCFG_IsActiveFlag_CAN + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_CAN(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[30], SYSCFG_ITLINE30_SR_CAN) == (SYSCFG_ITLINE30_SR_CAN)); +} +#endif /* SYSCFG_ITLINE30_SR_CAN */ + +#if defined(SYSCFG_ITLINE30_SR_CEC) +/** + * @brief Check if CEC interrupt occurred or not, combined with EXTI line 27. + * @rmtoll SYSCFG_ITLINE30 SR_CEC LL_SYSCFG_IsActiveFlag_CEC + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_CEC(void) +{ + return (READ_BIT(SYSCFG->IT_LINE_SR[30], SYSCFG_ITLINE30_SR_CEC) == (SYSCFG_ITLINE30_SR_CEC)); +} +#endif /* SYSCFG_ITLINE30_SR_CEC */ + +/** + * @brief Set connections to TIMx Break inputs + * @rmtoll SYSCFG_CFGR2 LOCKUP_LOCK LL_SYSCFG_SetTIMBreakInputs\n + * SYSCFG_CFGR2 SRAM_PARITY_LOCK LL_SYSCFG_SetTIMBreakInputs\n + * SYSCFG_CFGR2 PVD_LOCK LL_SYSCFG_SetTIMBreakInputs + * @param Break This parameter can be a combination of the following values: + * @arg @ref LL_SYSCFG_TIMBREAK_PVD (*) + * @arg @ref LL_SYSCFG_TIMBREAK_SRAM_PARITY + * @arg @ref LL_SYSCFG_TIMBREAK_LOCKUP + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_SetTIMBreakInputs(uint32_t Break) +{ +#if defined(SYSCFG_CFGR2_PVD_LOCK) + MODIFY_REG(SYSCFG->CFGR2, SYSCFG_CFGR2_LOCKUP_LOCK | SYSCFG_CFGR2_SRAM_PARITY_LOCK | SYSCFG_CFGR2_PVD_LOCK, Break); +#else + MODIFY_REG(SYSCFG->CFGR2, SYSCFG_CFGR2_LOCKUP_LOCK | SYSCFG_CFGR2_SRAM_PARITY_LOCK, Break); +#endif /*SYSCFG_CFGR2_PVD_LOCK*/ +} + +/** + * @brief Get connections to TIMx Break inputs + * @rmtoll SYSCFG_CFGR2 LOCKUP_LOCK LL_SYSCFG_GetTIMBreakInputs\n + * SYSCFG_CFGR2 SRAM_PARITY_LOCK LL_SYSCFG_GetTIMBreakInputs\n + * SYSCFG_CFGR2 PVD_LOCK LL_SYSCFG_GetTIMBreakInputs + * @retval Returned value can be can be a combination of the following values: + * @arg @ref LL_SYSCFG_TIMBREAK_PVD (*) + * @arg @ref LL_SYSCFG_TIMBREAK_SRAM_PARITY + * @arg @ref LL_SYSCFG_TIMBREAK_LOCKUP + * + * (*) value not defined in all devices + */ +__STATIC_INLINE uint32_t LL_SYSCFG_GetTIMBreakInputs(void) +{ +#if defined(SYSCFG_CFGR2_PVD_LOCK) + return (uint32_t)(READ_BIT(SYSCFG->CFGR2, + SYSCFG_CFGR2_LOCKUP_LOCK | SYSCFG_CFGR2_SRAM_PARITY_LOCK | SYSCFG_CFGR2_PVD_LOCK)); +#else + return (uint32_t)(READ_BIT(SYSCFG->CFGR2, SYSCFG_CFGR2_LOCKUP_LOCK | SYSCFG_CFGR2_SRAM_PARITY_LOCK)); +#endif /*SYSCFG_CFGR2_PVD_LOCK*/ +} + +/** + * @brief Check if SRAM parity error detected + * @rmtoll SYSCFG_CFGR2 SRAM_PEF LL_SYSCFG_IsActiveFlag_SP + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_SYSCFG_IsActiveFlag_SP(void) +{ + return (READ_BIT(SYSCFG->CFGR2, SYSCFG_CFGR2_SRAM_PEF) == (SYSCFG_CFGR2_SRAM_PEF)); +} + +/** + * @brief Clear SRAM parity error flag + * @rmtoll SYSCFG_CFGR2 SRAM_PEF LL_SYSCFG_ClearFlag_SP + * @retval None + */ +__STATIC_INLINE void LL_SYSCFG_ClearFlag_SP(void) +{ + SET_BIT(SYSCFG->CFGR2, SYSCFG_CFGR2_SRAM_PEF); +} + +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EF_DBGMCU DBGMCU + * @{ + */ + +/** + * @brief Return the device identifier + * @note For STM32F03x devices, the device ID is 0x444 + * @note For STM32F04x devices, the device ID is 0x445. + * @note For STM32F05x devices, the device ID is 0x440 + * @note For STM32F07x devices, the device ID is 0x448 + * @note For STM32F09x devices, the device ID is 0x442 + * @rmtoll DBGMCU_IDCODE DEV_ID LL_DBGMCU_GetDeviceID + * @retval Values between Min_Data=0x00 and Max_Data=0xFFF + */ +__STATIC_INLINE uint32_t LL_DBGMCU_GetDeviceID(void) +{ + return (uint32_t)(READ_BIT(DBGMCU->IDCODE, DBGMCU_IDCODE_DEV_ID)); +} + +/** + * @brief Return the device revision identifier + * @note This field indicates the revision of the device. + For example, it is read as 0x1000 for Revision 1.0. + * @rmtoll DBGMCU_IDCODE REV_ID LL_DBGMCU_GetRevisionID + * @retval Values between Min_Data=0x00 and Max_Data=0xFFFF + */ +__STATIC_INLINE uint32_t LL_DBGMCU_GetRevisionID(void) +{ + return (uint32_t)(READ_BIT(DBGMCU->IDCODE, DBGMCU_IDCODE_REV_ID) >> DBGMCU_IDCODE_REV_ID_Pos); +} + +/** + * @brief Enable the Debug Module during STOP mode + * @rmtoll DBGMCU_CR DBG_STOP LL_DBGMCU_EnableDBGStopMode + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_EnableDBGStopMode(void) +{ + SET_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STOP); +} + +/** + * @brief Disable the Debug Module during STOP mode + * @rmtoll DBGMCU_CR DBG_STOP LL_DBGMCU_DisableDBGStopMode + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_DisableDBGStopMode(void) +{ + CLEAR_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STOP); +} + +/** + * @brief Enable the Debug Module during STANDBY mode + * @rmtoll DBGMCU_CR DBG_STANDBY LL_DBGMCU_EnableDBGStandbyMode + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_EnableDBGStandbyMode(void) +{ + SET_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STANDBY); +} + +/** + * @brief Disable the Debug Module during STANDBY mode + * @rmtoll DBGMCU_CR DBG_STANDBY LL_DBGMCU_DisableDBGStandbyMode + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_DisableDBGStandbyMode(void) +{ + CLEAR_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STANDBY); +} + +/** + * @brief Freeze APB1 peripherals (group1 peripherals) + * @rmtoll DBGMCU_APB1FZ DBG_TIM2_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM3_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM6_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM7_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM14_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_RTC_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_WWDG_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_IWDG_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_I2C1_SMBUS_TIMEOUT LL_DBGMCU_APB1_GRP1_FreezePeriph\n + * DBGMCU_APB1FZ DBG_CAN_STOP LL_DBGMCU_APB1_GRP1_FreezePeriph + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM2_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM3_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM6_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM7_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM14_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_RTC_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_WWDG_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_IWDG_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_I2C1_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_CAN_STOP (*) + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_APB1_GRP1_FreezePeriph(uint32_t Periphs) +{ + SET_BIT(DBGMCU->APB1FZ, Periphs); +} + +/** + * @brief Unfreeze APB1 peripherals (group1 peripherals) + * @rmtoll DBGMCU_APB1FZ DBG_TIM2_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM3_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM6_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM7_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_TIM14_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_RTC_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_WWDG_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_IWDG_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_I2C1_SMBUS_TIMEOUT LL_DBGMCU_APB1_GRP1_UnFreezePeriph\n + * DBGMCU_APB1FZ DBG_CAN_STOP LL_DBGMCU_APB1_GRP1_UnFreezePeriph + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM2_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM3_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM6_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM7_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP1_TIM14_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_RTC_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_WWDG_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_IWDG_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_I2C1_STOP + * @arg @ref LL_DBGMCU_APB1_GRP1_CAN_STOP (*) + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_APB1_GRP1_UnFreezePeriph(uint32_t Periphs) +{ + CLEAR_BIT(DBGMCU->APB1FZ, Periphs); +} + +/** + * @brief Freeze APB1 peripherals (group2 peripherals) + * @rmtoll DBGMCU_APB2FZ DBG_TIM1_STOP LL_DBGMCU_APB1_GRP2_FreezePeriph\n + * DBGMCU_APB2FZ DBG_TIM15_STOP LL_DBGMCU_APB1_GRP2_FreezePeriph\n + * DBGMCU_APB2FZ DBG_TIM16_STOP LL_DBGMCU_APB1_GRP2_FreezePeriph\n + * DBGMCU_APB2FZ DBG_TIM17_STOP LL_DBGMCU_APB1_GRP2_FreezePeriph + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM1_STOP + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM15_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM16_STOP + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM17_STOP + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_APB1_GRP2_FreezePeriph(uint32_t Periphs) +{ + SET_BIT(DBGMCU->APB2FZ, Periphs); +} + +/** + * @brief Unfreeze APB1 peripherals (group2 peripherals) + * @rmtoll DBGMCU_APB2FZ DBG_TIM1_STOP LL_DBGMCU_APB1_GRP2_UnFreezePeriph\n + * DBGMCU_APB2FZ DBG_TIM15_STOP LL_DBGMCU_APB1_GRP2_UnFreezePeriph\n + * DBGMCU_APB2FZ DBG_TIM16_STOP LL_DBGMCU_APB1_GRP2_UnFreezePeriph\n + * DBGMCU_APB2FZ DBG_TIM17_STOP LL_DBGMCU_APB1_GRP2_UnFreezePeriph + * @param Periphs This parameter can be a combination of the following values: + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM1_STOP + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM15_STOP (*) + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM16_STOP + * @arg @ref LL_DBGMCU_APB1_GRP2_TIM17_STOP + * + * (*) value not defined in all devices + * @retval None + */ +__STATIC_INLINE void LL_DBGMCU_APB1_GRP2_UnFreezePeriph(uint32_t Periphs) +{ + CLEAR_BIT(DBGMCU->APB2FZ, Periphs); +} +/** + * @} + */ + +/** @defgroup SYSTEM_LL_EF_FLASH FLASH + * @{ + */ + +/** + * @brief Set FLASH Latency + * @rmtoll FLASH_ACR LATENCY LL_FLASH_SetLatency + * @param Latency This parameter can be one of the following values: + * @arg @ref LL_FLASH_LATENCY_0 + * @arg @ref LL_FLASH_LATENCY_1 + * @retval None + */ +__STATIC_INLINE void LL_FLASH_SetLatency(uint32_t Latency) +{ + MODIFY_REG(FLASH->ACR, FLASH_ACR_LATENCY, Latency); +} + +/** + * @brief Get FLASH Latency + * @rmtoll FLASH_ACR LATENCY LL_FLASH_GetLatency + * @retval Returned value can be one of the following values: + * @arg @ref LL_FLASH_LATENCY_0 + * @arg @ref LL_FLASH_LATENCY_1 + */ +__STATIC_INLINE uint32_t LL_FLASH_GetLatency(void) +{ + return (uint32_t)(READ_BIT(FLASH->ACR, FLASH_ACR_LATENCY)); +} + +/** + * @brief Enable Prefetch + * @rmtoll FLASH_ACR PRFTBE LL_FLASH_EnablePrefetch + * @retval None + */ +__STATIC_INLINE void LL_FLASH_EnablePrefetch(void) +{ + SET_BIT(FLASH->ACR, FLASH_ACR_PRFTBE); +} + +/** + * @brief Disable Prefetch + * @rmtoll FLASH_ACR PRFTBE LL_FLASH_DisablePrefetch + * @retval None + */ +__STATIC_INLINE void LL_FLASH_DisablePrefetch(void) +{ + CLEAR_BIT(FLASH->ACR, FLASH_ACR_PRFTBE); +} + +/** + * @brief Check if Prefetch buffer is enabled + * @rmtoll FLASH_ACR PRFTBS LL_FLASH_IsPrefetchEnabled + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_FLASH_IsPrefetchEnabled(void) +{ + return (READ_BIT(FLASH->ACR, FLASH_ACR_PRFTBS) == (FLASH_ACR_PRFTBS)); +} + + + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined (FLASH) || defined (SYSCFG) || defined (DBGMCU) */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_SYSTEM_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_tim.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_tim.h new file mode 100644 index 0000000..b19ee8c --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_tim.h @@ -0,0 +1,4015 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_tim.h + * @author MCD Application Team + * @brief Header file of TIM LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_TIM_H +#define __STM32F0xx_LL_TIM_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (TIM1) || defined (TIM2) || defined (TIM3) || defined (TIM14) || defined (TIM15) || defined (TIM16) || defined (TIM17) || defined (TIM6) || defined (TIM7) + +/** @defgroup TIM_LL TIM + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/** @defgroup TIM_LL_Private_Variables TIM Private Variables + * @{ + */ +static const uint8_t OFFSET_TAB_CCMRx[] = +{ + 0x00U, /* 0: TIMx_CH1 */ + 0x00U, /* 1: TIMx_CH1N */ + 0x00U, /* 2: TIMx_CH2 */ + 0x00U, /* 3: TIMx_CH2N */ + 0x04U, /* 4: TIMx_CH3 */ + 0x04U, /* 5: TIMx_CH3N */ + 0x04U /* 6: TIMx_CH4 */ +}; + +static const uint8_t SHIFT_TAB_OCxx[] = +{ + 0U, /* 0: OC1M, OC1FE, OC1PE */ + 0U, /* 1: - NA */ + 8U, /* 2: OC2M, OC2FE, OC2PE */ + 0U, /* 3: - NA */ + 0U, /* 4: OC3M, OC3FE, OC3PE */ + 0U, /* 5: - NA */ + 8U /* 6: OC4M, OC4FE, OC4PE */ +}; + +static const uint8_t SHIFT_TAB_ICxx[] = +{ + 0U, /* 0: CC1S, IC1PSC, IC1F */ + 0U, /* 1: - NA */ + 8U, /* 2: CC2S, IC2PSC, IC2F */ + 0U, /* 3: - NA */ + 0U, /* 4: CC3S, IC3PSC, IC3F */ + 0U, /* 5: - NA */ + 8U /* 6: CC4S, IC4PSC, IC4F */ +}; + +static const uint8_t SHIFT_TAB_CCxP[] = +{ + 0U, /* 0: CC1P */ + 2U, /* 1: CC1NP */ + 4U, /* 2: CC2P */ + 6U, /* 3: CC2NP */ + 8U, /* 4: CC3P */ + 10U, /* 5: CC3NP */ + 12U /* 6: CC4P */ +}; + +static const uint8_t SHIFT_TAB_OISx[] = +{ + 0U, /* 0: OIS1 */ + 1U, /* 1: OIS1N */ + 2U, /* 2: OIS2 */ + 3U, /* 3: OIS2N */ + 4U, /* 4: OIS3 */ + 5U, /* 5: OIS3N */ + 6U /* 6: OIS4 */ +}; +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup TIM_LL_Private_Constants TIM Private Constants + * @{ + */ + + +#define TIMx_OR_RMP_SHIFT 16U +#define TIMx_OR_RMP_MASK 0x0000FFFFU +#define TIM14_OR_RMP_MASK (TIM14_OR_TI1_RMP << TIMx_OR_RMP_SHIFT) + +/* Mask used to set the TDG[x:0] of the DTG bits of the TIMx_BDTR register */ +#define DT_DELAY_1 ((uint8_t)0x7F) +#define DT_DELAY_2 ((uint8_t)0x3F) +#define DT_DELAY_3 ((uint8_t)0x1F) +#define DT_DELAY_4 ((uint8_t)0x1F) + +/* Mask used to set the DTG[7:5] bits of the DTG bits of the TIMx_BDTR register */ +#define DT_RANGE_1 ((uint8_t)0x00) +#define DT_RANGE_2 ((uint8_t)0x80) +#define DT_RANGE_3 ((uint8_t)0xC0) +#define DT_RANGE_4 ((uint8_t)0xE0) + + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup TIM_LL_Private_Macros TIM Private Macros + * @{ + */ +/** @brief Convert channel id into channel index. + * @param __CHANNEL__ This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval none + */ +#define TIM_GET_CHANNEL_INDEX( __CHANNEL__) \ + (((__CHANNEL__) == LL_TIM_CHANNEL_CH1) ? 0U :\ + ((__CHANNEL__) == LL_TIM_CHANNEL_CH1N) ? 1U :\ + ((__CHANNEL__) == LL_TIM_CHANNEL_CH2) ? 2U :\ + ((__CHANNEL__) == LL_TIM_CHANNEL_CH2N) ? 3U :\ + ((__CHANNEL__) == LL_TIM_CHANNEL_CH3) ? 4U :\ + ((__CHANNEL__) == LL_TIM_CHANNEL_CH3N) ? 5U : 6U) + +/** @brief Calculate the deadtime sampling period(in ps). + * @param __TIMCLK__ timer input clock frequency (in Hz). + * @param __CKD__ This parameter can be one of the following values: + * @arg @ref LL_TIM_CLOCKDIVISION_DIV1 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV2 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV4 + * @retval none + */ +#define TIM_CALC_DTS(__TIMCLK__, __CKD__) \ + (((__CKD__) == LL_TIM_CLOCKDIVISION_DIV1) ? ((uint64_t)1000000000000U/(__TIMCLK__)) : \ + ((__CKD__) == LL_TIM_CLOCKDIVISION_DIV2) ? ((uint64_t)1000000000000U/((__TIMCLK__) >> 1U)) : \ + ((uint64_t)1000000000000U/((__TIMCLK__) >> 2U))) +/** + * @} + */ + + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup TIM_LL_ES_INIT TIM Exported Init structure + * @{ + */ + +/** + * @brief TIM Time Base configuration structure definition. + */ +typedef struct +{ + uint16_t Prescaler; /*!< Specifies the prescaler value used to divide the TIM clock. + This parameter can be a number between Min_Data=0x0000 and Max_Data=0xFFFF. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetPrescaler().*/ + + uint32_t CounterMode; /*!< Specifies the counter mode. + This parameter can be a value of @ref TIM_LL_EC_COUNTERMODE. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetCounterMode().*/ + + uint32_t Autoreload; /*!< Specifies the auto reload value to be loaded into the active + Auto-Reload Register at the next update event. + This parameter must be a number between Min_Data=0x0000 and Max_Data=0xFFFF. + Some timer instances may support 32 bits counters. In that case this parameter must + be a number between 0x0000 and 0xFFFFFFFF. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetAutoReload().*/ + + uint32_t ClockDivision; /*!< Specifies the clock division. + This parameter can be a value of @ref TIM_LL_EC_CLOCKDIVISION. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetClockDivision().*/ + + uint32_t RepetitionCounter; /*!< Specifies the repetition counter value. Each time the RCR downcounter + reaches zero, an update event is generated and counting restarts + from the RCR value (N). + This means in PWM mode that (N+1) corresponds to: + - the number of PWM periods in edge-aligned mode + - the number of half PWM period in center-aligned mode + GP timers: this parameter must be a number between Min_Data = 0x00 and + Max_Data = 0xFF. + Advanced timers: this parameter must be a number between Min_Data = 0x0000 and + Max_Data = 0xFFFF. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetRepetitionCounter().*/ +} LL_TIM_InitTypeDef; + +/** + * @brief TIM Output Compare configuration structure definition. + */ +typedef struct +{ + uint32_t OCMode; /*!< Specifies the output mode. + This parameter can be a value of @ref TIM_LL_EC_OCMODE. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_OC_SetMode().*/ + + uint32_t OCState; /*!< Specifies the TIM Output Compare state. + This parameter can be a value of @ref TIM_LL_EC_OCSTATE. + + This feature can be modified afterwards using unitary functions + @ref LL_TIM_CC_EnableChannel() or @ref LL_TIM_CC_DisableChannel().*/ + + uint32_t OCNState; /*!< Specifies the TIM complementary Output Compare state. + This parameter can be a value of @ref TIM_LL_EC_OCSTATE. + + This feature can be modified afterwards using unitary functions + @ref LL_TIM_CC_EnableChannel() or @ref LL_TIM_CC_DisableChannel().*/ + + uint32_t CompareValue; /*!< Specifies the Compare value to be loaded into the Capture Compare Register. + This parameter can be a number between Min_Data=0x0000 and Max_Data=0xFFFF. + + This feature can be modified afterwards using unitary function + LL_TIM_OC_SetCompareCHx (x=1..6).*/ + + uint32_t OCPolarity; /*!< Specifies the output polarity. + This parameter can be a value of @ref TIM_LL_EC_OCPOLARITY. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_OC_SetPolarity().*/ + + uint32_t OCNPolarity; /*!< Specifies the complementary output polarity. + This parameter can be a value of @ref TIM_LL_EC_OCPOLARITY. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_OC_SetPolarity().*/ + + + uint32_t OCIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state. + This parameter can be a value of @ref TIM_LL_EC_OCIDLESTATE. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_OC_SetIdleState().*/ + + uint32_t OCNIdleState; /*!< Specifies the TIM Output Compare pin state during Idle state. + This parameter can be a value of @ref TIM_LL_EC_OCIDLESTATE. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_OC_SetIdleState().*/ +} LL_TIM_OC_InitTypeDef; + +/** + * @brief TIM Input Capture configuration structure definition. + */ + +typedef struct +{ + + uint32_t ICPolarity; /*!< Specifies the active edge of the input signal. + This parameter can be a value of @ref TIM_LL_EC_IC_POLARITY. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPolarity().*/ + + uint32_t ICActiveInput; /*!< Specifies the input. + This parameter can be a value of @ref TIM_LL_EC_ACTIVEINPUT. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetActiveInput().*/ + + uint32_t ICPrescaler; /*!< Specifies the Input Capture Prescaler. + This parameter can be a value of @ref TIM_LL_EC_ICPSC. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPrescaler().*/ + + uint32_t ICFilter; /*!< Specifies the input capture filter. + This parameter can be a value of @ref TIM_LL_EC_IC_FILTER. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetFilter().*/ +} LL_TIM_IC_InitTypeDef; + + +/** + * @brief TIM Encoder interface configuration structure definition. + */ +typedef struct +{ + uint32_t EncoderMode; /*!< Specifies the encoder resolution (x2 or x4). + This parameter can be a value of @ref TIM_LL_EC_ENCODERMODE. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetEncoderMode().*/ + + uint32_t IC1Polarity; /*!< Specifies the active edge of TI1 input. + This parameter can be a value of @ref TIM_LL_EC_IC_POLARITY. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPolarity().*/ + + uint32_t IC1ActiveInput; /*!< Specifies the TI1 input source + This parameter can be a value of @ref TIM_LL_EC_ACTIVEINPUT. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetActiveInput().*/ + + uint32_t IC1Prescaler; /*!< Specifies the TI1 input prescaler value. + This parameter can be a value of @ref TIM_LL_EC_ICPSC. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPrescaler().*/ + + uint32_t IC1Filter; /*!< Specifies the TI1 input filter. + This parameter can be a value of @ref TIM_LL_EC_IC_FILTER. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetFilter().*/ + + uint32_t IC2Polarity; /*!< Specifies the active edge of TI2 input. + This parameter can be a value of @ref TIM_LL_EC_IC_POLARITY. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPolarity().*/ + + uint32_t IC2ActiveInput; /*!< Specifies the TI2 input source + This parameter can be a value of @ref TIM_LL_EC_ACTIVEINPUT. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetActiveInput().*/ + + uint32_t IC2Prescaler; /*!< Specifies the TI2 input prescaler value. + This parameter can be a value of @ref TIM_LL_EC_ICPSC. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPrescaler().*/ + + uint32_t IC2Filter; /*!< Specifies the TI2 input filter. + This parameter can be a value of @ref TIM_LL_EC_IC_FILTER. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetFilter().*/ + +} LL_TIM_ENCODER_InitTypeDef; + +/** + * @brief TIM Hall sensor interface configuration structure definition. + */ +typedef struct +{ + + uint32_t IC1Polarity; /*!< Specifies the active edge of TI1 input. + This parameter can be a value of @ref TIM_LL_EC_IC_POLARITY. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPolarity().*/ + + uint32_t IC1Prescaler; /*!< Specifies the TI1 input prescaler value. + Prescaler must be set to get a maximum counter period longer than the + time interval between 2 consecutive changes on the Hall inputs. + This parameter can be a value of @ref TIM_LL_EC_ICPSC. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetPrescaler().*/ + + uint32_t IC1Filter; /*!< Specifies the TI1 input filter. + This parameter can be a value of + @ref TIM_LL_EC_IC_FILTER. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_IC_SetFilter().*/ + + uint32_t CommutationDelay; /*!< Specifies the compare value to be loaded into the Capture Compare Register. + A positive pulse (TRGO event) is generated with a programmable delay every time + a change occurs on the Hall inputs. + This parameter can be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_OC_SetCompareCH2().*/ +} LL_TIM_HALLSENSOR_InitTypeDef; + +/** + * @brief BDTR (Break and Dead Time) structure definition + */ +typedef struct +{ + uint32_t OSSRState; /*!< Specifies the Off-State selection used in Run mode. + This parameter can be a value of @ref TIM_LL_EC_OSSR + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetOffStates() + + @note This bit-field cannot be modified as long as LOCK level 2 has been + programmed. */ + + uint32_t OSSIState; /*!< Specifies the Off-State used in Idle state. + This parameter can be a value of @ref TIM_LL_EC_OSSI + + This feature can be modified afterwards using unitary function + @ref LL_TIM_SetOffStates() + + @note This bit-field cannot be modified as long as LOCK level 2 has been + programmed. */ + + uint32_t LockLevel; /*!< Specifies the LOCK level parameters. + This parameter can be a value of @ref TIM_LL_EC_LOCKLEVEL + + @note The LOCK bits can be written only once after the reset. Once the TIMx_BDTR + register has been written, their content is frozen until the next reset.*/ + + uint8_t DeadTime; /*!< Specifies the delay time between the switching-off and the + switching-on of the outputs. + This parameter can be a number between Min_Data = 0x00 and Max_Data = 0xFF. + + This feature can be modified afterwards using unitary function + @ref LL_TIM_OC_SetDeadTime() + + @note This bit-field can not be modified as long as LOCK level 1, 2 or 3 has been + programmed. */ + + uint16_t BreakState; /*!< Specifies whether the TIM Break input is enabled or not. + This parameter can be a value of @ref TIM_LL_EC_BREAK_ENABLE + + This feature can be modified afterwards using unitary functions + @ref LL_TIM_EnableBRK() or @ref LL_TIM_DisableBRK() + + @note This bit-field can not be modified as long as LOCK level 1 has been + programmed. */ + + uint32_t BreakPolarity; /*!< Specifies the TIM Break Input pin polarity. + This parameter can be a value of @ref TIM_LL_EC_BREAK_POLARITY + + This feature can be modified afterwards using unitary function + @ref LL_TIM_ConfigBRK() + + @note This bit-field can not be modified as long as LOCK level 1 has been + programmed. */ + + uint32_t AutomaticOutput; /*!< Specifies whether the TIM Automatic Output feature is enabled or not. + This parameter can be a value of @ref TIM_LL_EC_AUTOMATICOUTPUT_ENABLE + + This feature can be modified afterwards using unitary functions + @ref LL_TIM_EnableAutomaticOutput() or @ref LL_TIM_DisableAutomaticOutput() + + @note This bit-field can not be modified as long as LOCK level 1 has been + programmed. */ +} LL_TIM_BDTR_InitTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup TIM_LL_Exported_Constants TIM Exported Constants + * @{ + */ + +/** @defgroup TIM_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_TIM_ReadReg function. + * @{ + */ +#define LL_TIM_SR_UIF TIM_SR_UIF /*!< Update interrupt flag */ +#define LL_TIM_SR_CC1IF TIM_SR_CC1IF /*!< Capture/compare 1 interrupt flag */ +#define LL_TIM_SR_CC2IF TIM_SR_CC2IF /*!< Capture/compare 2 interrupt flag */ +#define LL_TIM_SR_CC3IF TIM_SR_CC3IF /*!< Capture/compare 3 interrupt flag */ +#define LL_TIM_SR_CC4IF TIM_SR_CC4IF /*!< Capture/compare 4 interrupt flag */ +#define LL_TIM_SR_COMIF TIM_SR_COMIF /*!< COM interrupt flag */ +#define LL_TIM_SR_TIF TIM_SR_TIF /*!< Trigger interrupt flag */ +#define LL_TIM_SR_BIF TIM_SR_BIF /*!< Break interrupt flag */ +#define LL_TIM_SR_CC1OF TIM_SR_CC1OF /*!< Capture/Compare 1 overcapture flag */ +#define LL_TIM_SR_CC2OF TIM_SR_CC2OF /*!< Capture/Compare 2 overcapture flag */ +#define LL_TIM_SR_CC3OF TIM_SR_CC3OF /*!< Capture/Compare 3 overcapture flag */ +#define LL_TIM_SR_CC4OF TIM_SR_CC4OF /*!< Capture/Compare 4 overcapture flag */ +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup TIM_LL_EC_BREAK_ENABLE Break Enable + * @{ + */ +#define LL_TIM_BREAK_DISABLE 0x00000000U /*!< Break function disabled */ +#define LL_TIM_BREAK_ENABLE TIM_BDTR_BKE /*!< Break function enabled */ +/** + * @} + */ + +/** @defgroup TIM_LL_EC_AUTOMATICOUTPUT_ENABLE Automatic output enable + * @{ + */ +#define LL_TIM_AUTOMATICOUTPUT_DISABLE 0x00000000U /*!< MOE can be set only by software */ +#define LL_TIM_AUTOMATICOUTPUT_ENABLE TIM_BDTR_AOE /*!< MOE can be set by software or automatically at the next update event */ +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** @defgroup TIM_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_TIM_ReadReg and LL_TIM_WriteReg functions. + * @{ + */ +#define LL_TIM_DIER_UIE TIM_DIER_UIE /*!< Update interrupt enable */ +#define LL_TIM_DIER_CC1IE TIM_DIER_CC1IE /*!< Capture/compare 1 interrupt enable */ +#define LL_TIM_DIER_CC2IE TIM_DIER_CC2IE /*!< Capture/compare 2 interrupt enable */ +#define LL_TIM_DIER_CC3IE TIM_DIER_CC3IE /*!< Capture/compare 3 interrupt enable */ +#define LL_TIM_DIER_CC4IE TIM_DIER_CC4IE /*!< Capture/compare 4 interrupt enable */ +#define LL_TIM_DIER_COMIE TIM_DIER_COMIE /*!< COM interrupt enable */ +#define LL_TIM_DIER_TIE TIM_DIER_TIE /*!< Trigger interrupt enable */ +#define LL_TIM_DIER_BIE TIM_DIER_BIE /*!< Break interrupt enable */ +/** + * @} + */ + +/** @defgroup TIM_LL_EC_UPDATESOURCE Update Source + * @{ + */ +#define LL_TIM_UPDATESOURCE_REGULAR 0x00000000U /*!< Counter overflow/underflow, Setting the UG bit or Update generation through the slave mode controller generates an update request */ +#define LL_TIM_UPDATESOURCE_COUNTER TIM_CR1_URS /*!< Only counter overflow/underflow generates an update request */ +/** + * @} + */ + +/** @defgroup TIM_LL_EC_ONEPULSEMODE One Pulse Mode + * @{ + */ +#define LL_TIM_ONEPULSEMODE_SINGLE TIM_CR1_OPM /*!< Counter stops counting at the next update event */ +#define LL_TIM_ONEPULSEMODE_REPETITIVE 0x00000000U /*!< Counter is not stopped at update event */ +/** + * @} + */ + +/** @defgroup TIM_LL_EC_COUNTERMODE Counter Mode + * @{ + */ +#define LL_TIM_COUNTERMODE_UP 0x00000000U /*!TIMx_CCRy else active.*/ +#define LL_TIM_OCMODE_PWM2 (TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_0) /*!TIMx_CCRy else inactive*/ +/** + * @} + */ + +/** @defgroup TIM_LL_EC_OCPOLARITY Output Configuration Polarity + * @{ + */ +#define LL_TIM_OCPOLARITY_HIGH 0x00000000U /*!< OCxactive high*/ +#define LL_TIM_OCPOLARITY_LOW TIM_CCER_CC1P /*!< OCxactive low*/ +/** + * @} + */ + +/** @defgroup TIM_LL_EC_OCIDLESTATE Output Configuration Idle State + * @{ + */ +#define LL_TIM_OCIDLESTATE_LOW 0x00000000U /*!__REG__, (__VALUE__)) + +/** + * @brief Read a value in TIM register. + * @param __INSTANCE__ TIM Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_TIM_ReadReg(__INSTANCE__, __REG__) READ_REG((__INSTANCE__)->__REG__) +/** + * @} + */ + +/** @defgroup TIM_LL_EM_Exported_Macros Exported_Macros + * @{ + */ + +/** + * @brief HELPER macro calculating DTG[0:7] in the TIMx_BDTR register to achieve the requested dead time duration. + * @note ex: @ref __LL_TIM_CALC_DEADTIME (80000000, @ref LL_TIM_GetClockDivision (), 120); + * @param __TIMCLK__ timer input clock frequency (in Hz) + * @param __CKD__ This parameter can be one of the following values: + * @arg @ref LL_TIM_CLOCKDIVISION_DIV1 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV2 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV4 + * @param __DT__ deadtime duration (in ns) + * @retval DTG[0:7] + */ +#define __LL_TIM_CALC_DEADTIME(__TIMCLK__, __CKD__, __DT__) \ + ( (((uint64_t)((__DT__)*1000U)) < ((DT_DELAY_1+1U) * TIM_CALC_DTS((__TIMCLK__), (__CKD__)))) ? \ + (uint8_t)(((uint64_t)((__DT__)*1000U) / TIM_CALC_DTS((__TIMCLK__), (__CKD__))) & DT_DELAY_1) : \ + (((uint64_t)((__DT__)*1000U)) < ((64U + (DT_DELAY_2+1U)) * 2U * TIM_CALC_DTS((__TIMCLK__), (__CKD__)))) ? \ + (uint8_t)(DT_RANGE_2 | ((uint8_t)((uint8_t)((((uint64_t)((__DT__)*1000U))/ TIM_CALC_DTS((__TIMCLK__), \ + (__CKD__))) >> 1U) - (uint8_t) 64) & DT_DELAY_2)) :\ + (((uint64_t)((__DT__)*1000U)) < ((32U + (DT_DELAY_3+1U)) * 8U * TIM_CALC_DTS((__TIMCLK__), (__CKD__)))) ? \ + (uint8_t)(DT_RANGE_3 | ((uint8_t)((uint8_t)(((((uint64_t)(__DT__)*1000U))/ TIM_CALC_DTS((__TIMCLK__), \ + (__CKD__))) >> 3U) - (uint8_t) 32) & DT_DELAY_3)) :\ + (((uint64_t)((__DT__)*1000U)) < ((32U + (DT_DELAY_4+1U)) * 16U * TIM_CALC_DTS((__TIMCLK__), (__CKD__)))) ? \ + (uint8_t)(DT_RANGE_4 | ((uint8_t)((uint8_t)(((((uint64_t)(__DT__)*1000U))/ TIM_CALC_DTS((__TIMCLK__), \ + (__CKD__))) >> 4U) - (uint8_t) 32) & DT_DELAY_4)) :\ + 0U) + +/** + * @brief HELPER macro calculating the prescaler value to achieve the required counter clock frequency. + * @note ex: @ref __LL_TIM_CALC_PSC (80000000, 1000000); + * @param __TIMCLK__ timer input clock frequency (in Hz) + * @param __CNTCLK__ counter clock frequency (in Hz) + * @retval Prescaler value (between Min_Data=0 and Max_Data=65535) + */ +#define __LL_TIM_CALC_PSC(__TIMCLK__, __CNTCLK__) \ + (((__TIMCLK__) >= (__CNTCLK__)) ? (uint32_t)(((__TIMCLK__)/(__CNTCLK__)) - 1U) : 0U) + +/** + * @brief HELPER macro calculating the auto-reload value to achieve the required output signal frequency. + * @note ex: @ref __LL_TIM_CALC_ARR (1000000, @ref LL_TIM_GetPrescaler (), 10000); + * @param __TIMCLK__ timer input clock frequency (in Hz) + * @param __PSC__ prescaler + * @param __FREQ__ output signal frequency (in Hz) + * @retval Auto-reload value (between Min_Data=0 and Max_Data=65535) + */ +#define __LL_TIM_CALC_ARR(__TIMCLK__, __PSC__, __FREQ__) \ + ((((__TIMCLK__)/((__PSC__) + 1U)) >= (__FREQ__)) ? (((__TIMCLK__)/((__FREQ__) * ((__PSC__) + 1U))) - 1U) : 0U) + +/** + * @brief HELPER macro calculating the compare value required to achieve the required timer output compare + * active/inactive delay. + * @note ex: @ref __LL_TIM_CALC_DELAY (1000000, @ref LL_TIM_GetPrescaler (), 10); + * @param __TIMCLK__ timer input clock frequency (in Hz) + * @param __PSC__ prescaler + * @param __DELAY__ timer output compare active/inactive delay (in us) + * @retval Compare value (between Min_Data=0 and Max_Data=65535) + */ +#define __LL_TIM_CALC_DELAY(__TIMCLK__, __PSC__, __DELAY__) \ + ((uint32_t)(((uint64_t)(__TIMCLK__) * (uint64_t)(__DELAY__)) \ + / ((uint64_t)1000000U * (uint64_t)((__PSC__) + 1U)))) + +/** + * @brief HELPER macro calculating the auto-reload value to achieve the required pulse duration + * (when the timer operates in one pulse mode). + * @note ex: @ref __LL_TIM_CALC_PULSE (1000000, @ref LL_TIM_GetPrescaler (), 10, 20); + * @param __TIMCLK__ timer input clock frequency (in Hz) + * @param __PSC__ prescaler + * @param __DELAY__ timer output compare active/inactive delay (in us) + * @param __PULSE__ pulse duration (in us) + * @retval Auto-reload value (between Min_Data=0 and Max_Data=65535) + */ +#define __LL_TIM_CALC_PULSE(__TIMCLK__, __PSC__, __DELAY__, __PULSE__) \ + ((uint32_t)(__LL_TIM_CALC_DELAY((__TIMCLK__), (__PSC__), (__PULSE__)) \ + + __LL_TIM_CALC_DELAY((__TIMCLK__), (__PSC__), (__DELAY__)))) + +/** + * @brief HELPER macro retrieving the ratio of the input capture prescaler + * @note ex: @ref __LL_TIM_GET_ICPSC_RATIO (@ref LL_TIM_IC_GetPrescaler ()); + * @param __ICPSC__ This parameter can be one of the following values: + * @arg @ref LL_TIM_ICPSC_DIV1 + * @arg @ref LL_TIM_ICPSC_DIV2 + * @arg @ref LL_TIM_ICPSC_DIV4 + * @arg @ref LL_TIM_ICPSC_DIV8 + * @retval Input capture prescaler ratio (1, 2, 4 or 8) + */ +#define __LL_TIM_GET_ICPSC_RATIO(__ICPSC__) \ + ((uint32_t)(0x01U << (((__ICPSC__) >> 16U) >> TIM_CCMR1_IC1PSC_Pos))) + + +/** + * @} + */ + + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup TIM_LL_Exported_Functions TIM Exported Functions + * @{ + */ + +/** @defgroup TIM_LL_EF_Time_Base Time Base configuration + * @{ + */ +/** + * @brief Enable timer counter. + * @rmtoll CR1 CEN LL_TIM_EnableCounter + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableCounter(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->CR1, TIM_CR1_CEN); +} + +/** + * @brief Disable timer counter. + * @rmtoll CR1 CEN LL_TIM_DisableCounter + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableCounter(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->CR1, TIM_CR1_CEN); +} + +/** + * @brief Indicates whether the timer counter is enabled. + * @rmtoll CR1 CEN LL_TIM_IsEnabledCounter + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledCounter(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->CR1, TIM_CR1_CEN) == (TIM_CR1_CEN)) ? 1UL : 0UL); +} + +/** + * @brief Enable update event generation. + * @rmtoll CR1 UDIS LL_TIM_EnableUpdateEvent + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableUpdateEvent(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->CR1, TIM_CR1_UDIS); +} + +/** + * @brief Disable update event generation. + * @rmtoll CR1 UDIS LL_TIM_DisableUpdateEvent + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableUpdateEvent(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->CR1, TIM_CR1_UDIS); +} + +/** + * @brief Indicates whether update event generation is enabled. + * @rmtoll CR1 UDIS LL_TIM_IsEnabledUpdateEvent + * @param TIMx Timer instance + * @retval Inverted state of bit (0 or 1). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledUpdateEvent(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->CR1, TIM_CR1_UDIS) == (uint32_t)RESET) ? 1UL : 0UL); +} + +/** + * @brief Set update event source + * @note Update event source set to LL_TIM_UPDATESOURCE_REGULAR: any of the following events + * generate an update interrupt or DMA request if enabled: + * - Counter overflow/underflow + * - Setting the UG bit + * - Update generation through the slave mode controller + * @note Update event source set to LL_TIM_UPDATESOURCE_COUNTER: only counter + * overflow/underflow generates an update interrupt or DMA request if enabled. + * @rmtoll CR1 URS LL_TIM_SetUpdateSource + * @param TIMx Timer instance + * @param UpdateSource This parameter can be one of the following values: + * @arg @ref LL_TIM_UPDATESOURCE_REGULAR + * @arg @ref LL_TIM_UPDATESOURCE_COUNTER + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetUpdateSource(TIM_TypeDef *TIMx, uint32_t UpdateSource) +{ + MODIFY_REG(TIMx->CR1, TIM_CR1_URS, UpdateSource); +} + +/** + * @brief Get actual event update source + * @rmtoll CR1 URS LL_TIM_GetUpdateSource + * @param TIMx Timer instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_UPDATESOURCE_REGULAR + * @arg @ref LL_TIM_UPDATESOURCE_COUNTER + */ +__STATIC_INLINE uint32_t LL_TIM_GetUpdateSource(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_BIT(TIMx->CR1, TIM_CR1_URS)); +} + +/** + * @brief Set one pulse mode (one shot v.s. repetitive). + * @rmtoll CR1 OPM LL_TIM_SetOnePulseMode + * @param TIMx Timer instance + * @param OnePulseMode This parameter can be one of the following values: + * @arg @ref LL_TIM_ONEPULSEMODE_SINGLE + * @arg @ref LL_TIM_ONEPULSEMODE_REPETITIVE + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetOnePulseMode(TIM_TypeDef *TIMx, uint32_t OnePulseMode) +{ + MODIFY_REG(TIMx->CR1, TIM_CR1_OPM, OnePulseMode); +} + +/** + * @brief Get actual one pulse mode. + * @rmtoll CR1 OPM LL_TIM_GetOnePulseMode + * @param TIMx Timer instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_ONEPULSEMODE_SINGLE + * @arg @ref LL_TIM_ONEPULSEMODE_REPETITIVE + */ +__STATIC_INLINE uint32_t LL_TIM_GetOnePulseMode(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_BIT(TIMx->CR1, TIM_CR1_OPM)); +} + +/** + * @brief Set the timer counter counting mode. + * @note Macro IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx) can be used to + * check whether or not the counter mode selection feature is supported + * by a timer instance. + * @note Switching from Center Aligned counter mode to Edge counter mode (or reverse) + * requires a timer reset to avoid unexpected direction + * due to DIR bit readonly in center aligned mode. + * @rmtoll CR1 DIR LL_TIM_SetCounterMode\n + * CR1 CMS LL_TIM_SetCounterMode + * @param TIMx Timer instance + * @param CounterMode This parameter can be one of the following values: + * @arg @ref LL_TIM_COUNTERMODE_UP + * @arg @ref LL_TIM_COUNTERMODE_DOWN + * @arg @ref LL_TIM_COUNTERMODE_CENTER_UP + * @arg @ref LL_TIM_COUNTERMODE_CENTER_DOWN + * @arg @ref LL_TIM_COUNTERMODE_CENTER_UP_DOWN + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetCounterMode(TIM_TypeDef *TIMx, uint32_t CounterMode) +{ + MODIFY_REG(TIMx->CR1, (TIM_CR1_DIR | TIM_CR1_CMS), CounterMode); +} + +/** + * @brief Get actual counter mode. + * @note Macro IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx) can be used to + * check whether or not the counter mode selection feature is supported + * by a timer instance. + * @rmtoll CR1 DIR LL_TIM_GetCounterMode\n + * CR1 CMS LL_TIM_GetCounterMode + * @param TIMx Timer instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_COUNTERMODE_UP + * @arg @ref LL_TIM_COUNTERMODE_DOWN + * @arg @ref LL_TIM_COUNTERMODE_CENTER_UP + * @arg @ref LL_TIM_COUNTERMODE_CENTER_DOWN + * @arg @ref LL_TIM_COUNTERMODE_CENTER_UP_DOWN + */ +__STATIC_INLINE uint32_t LL_TIM_GetCounterMode(TIM_TypeDef *TIMx) +{ + uint32_t counter_mode; + + counter_mode = (uint32_t)(READ_BIT(TIMx->CR1, TIM_CR1_CMS)); + + if (counter_mode == 0U) + { + counter_mode = (uint32_t)(READ_BIT(TIMx->CR1, TIM_CR1_DIR)); + } + + return counter_mode; +} + +/** + * @brief Enable auto-reload (ARR) preload. + * @rmtoll CR1 ARPE LL_TIM_EnableARRPreload + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableARRPreload(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->CR1, TIM_CR1_ARPE); +} + +/** + * @brief Disable auto-reload (ARR) preload. + * @rmtoll CR1 ARPE LL_TIM_DisableARRPreload + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableARRPreload(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->CR1, TIM_CR1_ARPE); +} + +/** + * @brief Indicates whether auto-reload (ARR) preload is enabled. + * @rmtoll CR1 ARPE LL_TIM_IsEnabledARRPreload + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledARRPreload(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->CR1, TIM_CR1_ARPE) == (TIM_CR1_ARPE)) ? 1UL : 0UL); +} + +/** + * @brief Set the division ratio between the timer clock and the sampling clock used by the dead-time generators + * (when supported) and the digital filters. + * @note Macro IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx) can be used to check + * whether or not the clock division feature is supported by the timer + * instance. + * @rmtoll CR1 CKD LL_TIM_SetClockDivision + * @param TIMx Timer instance + * @param ClockDivision This parameter can be one of the following values: + * @arg @ref LL_TIM_CLOCKDIVISION_DIV1 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV2 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetClockDivision(TIM_TypeDef *TIMx, uint32_t ClockDivision) +{ + MODIFY_REG(TIMx->CR1, TIM_CR1_CKD, ClockDivision); +} + +/** + * @brief Get the actual division ratio between the timer clock and the sampling clock used by the dead-time + * generators (when supported) and the digital filters. + * @note Macro IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx) can be used to check + * whether or not the clock division feature is supported by the timer + * instance. + * @rmtoll CR1 CKD LL_TIM_GetClockDivision + * @param TIMx Timer instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_CLOCKDIVISION_DIV1 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV2 + * @arg @ref LL_TIM_CLOCKDIVISION_DIV4 + */ +__STATIC_INLINE uint32_t LL_TIM_GetClockDivision(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_BIT(TIMx->CR1, TIM_CR1_CKD)); +} + +/** + * @brief Set the counter value. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @rmtoll CNT CNT LL_TIM_SetCounter + * @param TIMx Timer instance + * @param Counter Counter value (between Min_Data=0 and Max_Data=0xFFFF or 0xFFFFFFFF) + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetCounter(TIM_TypeDef *TIMx, uint32_t Counter) +{ + WRITE_REG(TIMx->CNT, Counter); +} + +/** + * @brief Get the counter value. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @rmtoll CNT CNT LL_TIM_GetCounter + * @param TIMx Timer instance + * @retval Counter value (between Min_Data=0 and Max_Data=0xFFFF or 0xFFFFFFFF) + */ +__STATIC_INLINE uint32_t LL_TIM_GetCounter(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CNT)); +} + +/** + * @brief Get the current direction of the counter + * @rmtoll CR1 DIR LL_TIM_GetDirection + * @param TIMx Timer instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_COUNTERDIRECTION_UP + * @arg @ref LL_TIM_COUNTERDIRECTION_DOWN + */ +__STATIC_INLINE uint32_t LL_TIM_GetDirection(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_BIT(TIMx->CR1, TIM_CR1_DIR)); +} + +/** + * @brief Set the prescaler value. + * @note The counter clock frequency CK_CNT is equal to fCK_PSC / (PSC[15:0] + 1). + * @note The prescaler can be changed on the fly as this control register is buffered. The new + * prescaler ratio is taken into account at the next update event. + * @note Helper macro @ref __LL_TIM_CALC_PSC can be used to calculate the Prescaler parameter + * @rmtoll PSC PSC LL_TIM_SetPrescaler + * @param TIMx Timer instance + * @param Prescaler between Min_Data=0 and Max_Data=65535 + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetPrescaler(TIM_TypeDef *TIMx, uint32_t Prescaler) +{ + WRITE_REG(TIMx->PSC, Prescaler); +} + +/** + * @brief Get the prescaler value. + * @rmtoll PSC PSC LL_TIM_GetPrescaler + * @param TIMx Timer instance + * @retval Prescaler value between Min_Data=0 and Max_Data=65535 + */ +__STATIC_INLINE uint32_t LL_TIM_GetPrescaler(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->PSC)); +} + +/** + * @brief Set the auto-reload value. + * @note The counter is blocked while the auto-reload value is null. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Helper macro @ref __LL_TIM_CALC_ARR can be used to calculate the AutoReload parameter + * @rmtoll ARR ARR LL_TIM_SetAutoReload + * @param TIMx Timer instance + * @param AutoReload between Min_Data=0 and Max_Data=65535 + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetAutoReload(TIM_TypeDef *TIMx, uint32_t AutoReload) +{ + WRITE_REG(TIMx->ARR, AutoReload); +} + +/** + * @brief Get the auto-reload value. + * @rmtoll ARR ARR LL_TIM_GetAutoReload + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @param TIMx Timer instance + * @retval Auto-reload value + */ +__STATIC_INLINE uint32_t LL_TIM_GetAutoReload(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->ARR)); +} + +/** + * @brief Set the repetition counter value. + * @note Macro IS_TIM_REPETITION_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a repetition counter. + * @rmtoll RCR REP LL_TIM_SetRepetitionCounter + * @param TIMx Timer instance + * @param RepetitionCounter between Min_Data=0 and Max_Data=255 or 65535 for advanced timer. + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetRepetitionCounter(TIM_TypeDef *TIMx, uint32_t RepetitionCounter) +{ + WRITE_REG(TIMx->RCR, RepetitionCounter); +} + +/** + * @brief Get the repetition counter value. + * @note Macro IS_TIM_REPETITION_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a repetition counter. + * @rmtoll RCR REP LL_TIM_GetRepetitionCounter + * @param TIMx Timer instance + * @retval Repetition counter value + */ +__STATIC_INLINE uint32_t LL_TIM_GetRepetitionCounter(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->RCR)); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_Capture_Compare Capture Compare configuration + * @{ + */ +/** + * @brief Enable the capture/compare control bits (CCxE, CCxNE and OCxM) preload. + * @note CCxE, CCxNE and OCxM bits are preloaded, after having been written, + * they are updated only when a commutation event (COM) occurs. + * @note Only on channels that have a complementary output. + * @note Macro IS_TIM_COMMUTATION_EVENT_INSTANCE(TIMx) can be used to check + * whether or not a timer instance is able to generate a commutation event. + * @rmtoll CR2 CCPC LL_TIM_CC_EnablePreload + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_CC_EnablePreload(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->CR2, TIM_CR2_CCPC); +} + +/** + * @brief Disable the capture/compare control bits (CCxE, CCxNE and OCxM) preload. + * @note Macro IS_TIM_COMMUTATION_EVENT_INSTANCE(TIMx) can be used to check + * whether or not a timer instance is able to generate a commutation event. + * @rmtoll CR2 CCPC LL_TIM_CC_DisablePreload + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_CC_DisablePreload(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->CR2, TIM_CR2_CCPC); +} + +/** + * @brief Set the updated source of the capture/compare control bits (CCxE, CCxNE and OCxM). + * @note Macro IS_TIM_COMMUTATION_EVENT_INSTANCE(TIMx) can be used to check + * whether or not a timer instance is able to generate a commutation event. + * @rmtoll CR2 CCUS LL_TIM_CC_SetUpdate + * @param TIMx Timer instance + * @param CCUpdateSource This parameter can be one of the following values: + * @arg @ref LL_TIM_CCUPDATESOURCE_COMG_ONLY + * @arg @ref LL_TIM_CCUPDATESOURCE_COMG_AND_TRGI + * @retval None + */ +__STATIC_INLINE void LL_TIM_CC_SetUpdate(TIM_TypeDef *TIMx, uint32_t CCUpdateSource) +{ + MODIFY_REG(TIMx->CR2, TIM_CR2_CCUS, CCUpdateSource); +} + +/** + * @brief Set the trigger of the capture/compare DMA request. + * @rmtoll CR2 CCDS LL_TIM_CC_SetDMAReqTrigger + * @param TIMx Timer instance + * @param DMAReqTrigger This parameter can be one of the following values: + * @arg @ref LL_TIM_CCDMAREQUEST_CC + * @arg @ref LL_TIM_CCDMAREQUEST_UPDATE + * @retval None + */ +__STATIC_INLINE void LL_TIM_CC_SetDMAReqTrigger(TIM_TypeDef *TIMx, uint32_t DMAReqTrigger) +{ + MODIFY_REG(TIMx->CR2, TIM_CR2_CCDS, DMAReqTrigger); +} + +/** + * @brief Get actual trigger of the capture/compare DMA request. + * @rmtoll CR2 CCDS LL_TIM_CC_GetDMAReqTrigger + * @param TIMx Timer instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_CCDMAREQUEST_CC + * @arg @ref LL_TIM_CCDMAREQUEST_UPDATE + */ +__STATIC_INLINE uint32_t LL_TIM_CC_GetDMAReqTrigger(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_BIT(TIMx->CR2, TIM_CR2_CCDS)); +} + +/** + * @brief Set the lock level to freeze the + * configuration of several capture/compare parameters. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * the lock mechanism is supported by a timer instance. + * @rmtoll BDTR LOCK LL_TIM_CC_SetLockLevel + * @param TIMx Timer instance + * @param LockLevel This parameter can be one of the following values: + * @arg @ref LL_TIM_LOCKLEVEL_OFF + * @arg @ref LL_TIM_LOCKLEVEL_1 + * @arg @ref LL_TIM_LOCKLEVEL_2 + * @arg @ref LL_TIM_LOCKLEVEL_3 + * @retval None + */ +__STATIC_INLINE void LL_TIM_CC_SetLockLevel(TIM_TypeDef *TIMx, uint32_t LockLevel) +{ + MODIFY_REG(TIMx->BDTR, TIM_BDTR_LOCK, LockLevel); +} + +/** + * @brief Enable capture/compare channels. + * @rmtoll CCER CC1E LL_TIM_CC_EnableChannel\n + * CCER CC1NE LL_TIM_CC_EnableChannel\n + * CCER CC2E LL_TIM_CC_EnableChannel\n + * CCER CC2NE LL_TIM_CC_EnableChannel\n + * CCER CC3E LL_TIM_CC_EnableChannel\n + * CCER CC3NE LL_TIM_CC_EnableChannel\n + * CCER CC4E LL_TIM_CC_EnableChannel + * @param TIMx Timer instance + * @param Channels This parameter can be a combination of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_CC_EnableChannel(TIM_TypeDef *TIMx, uint32_t Channels) +{ + SET_BIT(TIMx->CCER, Channels); +} + +/** + * @brief Disable capture/compare channels. + * @rmtoll CCER CC1E LL_TIM_CC_DisableChannel\n + * CCER CC1NE LL_TIM_CC_DisableChannel\n + * CCER CC2E LL_TIM_CC_DisableChannel\n + * CCER CC2NE LL_TIM_CC_DisableChannel\n + * CCER CC3E LL_TIM_CC_DisableChannel\n + * CCER CC3NE LL_TIM_CC_DisableChannel\n + * CCER CC4E LL_TIM_CC_DisableChannel + * @param TIMx Timer instance + * @param Channels This parameter can be a combination of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_CC_DisableChannel(TIM_TypeDef *TIMx, uint32_t Channels) +{ + CLEAR_BIT(TIMx->CCER, Channels); +} + +/** + * @brief Indicate whether channel(s) is(are) enabled. + * @rmtoll CCER CC1E LL_TIM_CC_IsEnabledChannel\n + * CCER CC1NE LL_TIM_CC_IsEnabledChannel\n + * CCER CC2E LL_TIM_CC_IsEnabledChannel\n + * CCER CC2NE LL_TIM_CC_IsEnabledChannel\n + * CCER CC3E LL_TIM_CC_IsEnabledChannel\n + * CCER CC3NE LL_TIM_CC_IsEnabledChannel\n + * CCER CC4E LL_TIM_CC_IsEnabledChannel + * @param TIMx Timer instance + * @param Channels This parameter can be a combination of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_CC_IsEnabledChannel(TIM_TypeDef *TIMx, uint32_t Channels) +{ + return ((READ_BIT(TIMx->CCER, Channels) == (Channels)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_Output_Channel Output channel configuration + * @{ + */ +/** + * @brief Configure an output channel. + * @rmtoll CCMR1 CC1S LL_TIM_OC_ConfigOutput\n + * CCMR1 CC2S LL_TIM_OC_ConfigOutput\n + * CCMR2 CC3S LL_TIM_OC_ConfigOutput\n + * CCMR2 CC4S LL_TIM_OC_ConfigOutput\n + * CCER CC1P LL_TIM_OC_ConfigOutput\n + * CCER CC2P LL_TIM_OC_ConfigOutput\n + * CCER CC3P LL_TIM_OC_ConfigOutput\n + * CCER CC4P LL_TIM_OC_ConfigOutput\n + * CR2 OIS1 LL_TIM_OC_ConfigOutput\n + * CR2 OIS2 LL_TIM_OC_ConfigOutput\n + * CR2 OIS3 LL_TIM_OC_ConfigOutput\n + * CR2 OIS4 LL_TIM_OC_ConfigOutput + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param Configuration This parameter must be a combination of all the following values: + * @arg @ref LL_TIM_OCPOLARITY_HIGH or @ref LL_TIM_OCPOLARITY_LOW + * @arg @ref LL_TIM_OCIDLESTATE_LOW or @ref LL_TIM_OCIDLESTATE_HIGH + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_ConfigOutput(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Configuration) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + CLEAR_BIT(*pReg, (TIM_CCMR1_CC1S << SHIFT_TAB_OCxx[iChannel])); + MODIFY_REG(TIMx->CCER, (TIM_CCER_CC1P << SHIFT_TAB_CCxP[iChannel]), + (Configuration & TIM_CCER_CC1P) << SHIFT_TAB_CCxP[iChannel]); + MODIFY_REG(TIMx->CR2, (TIM_CR2_OIS1 << SHIFT_TAB_OISx[iChannel]), + (Configuration & TIM_CR2_OIS1) << SHIFT_TAB_OISx[iChannel]); +} + +/** + * @brief Define the behavior of the output reference signal OCxREF from which + * OCx and OCxN (when relevant) are derived. + * @rmtoll CCMR1 OC1M LL_TIM_OC_SetMode\n + * CCMR1 OC2M LL_TIM_OC_SetMode\n + * CCMR2 OC3M LL_TIM_OC_SetMode\n + * CCMR2 OC4M LL_TIM_OC_SetMode + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param Mode This parameter can be one of the following values: + * @arg @ref LL_TIM_OCMODE_FROZEN + * @arg @ref LL_TIM_OCMODE_ACTIVE + * @arg @ref LL_TIM_OCMODE_INACTIVE + * @arg @ref LL_TIM_OCMODE_TOGGLE + * @arg @ref LL_TIM_OCMODE_FORCED_INACTIVE + * @arg @ref LL_TIM_OCMODE_FORCED_ACTIVE + * @arg @ref LL_TIM_OCMODE_PWM1 + * @arg @ref LL_TIM_OCMODE_PWM2 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetMode(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Mode) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + MODIFY_REG(*pReg, ((TIM_CCMR1_OC1M | TIM_CCMR1_CC1S) << SHIFT_TAB_OCxx[iChannel]), Mode << SHIFT_TAB_OCxx[iChannel]); +} + +/** + * @brief Get the output compare mode of an output channel. + * @rmtoll CCMR1 OC1M LL_TIM_OC_GetMode\n + * CCMR1 OC2M LL_TIM_OC_GetMode\n + * CCMR2 OC3M LL_TIM_OC_GetMode\n + * CCMR2 OC4M LL_TIM_OC_GetMode + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_OCMODE_FROZEN + * @arg @ref LL_TIM_OCMODE_ACTIVE + * @arg @ref LL_TIM_OCMODE_INACTIVE + * @arg @ref LL_TIM_OCMODE_TOGGLE + * @arg @ref LL_TIM_OCMODE_FORCED_INACTIVE + * @arg @ref LL_TIM_OCMODE_FORCED_ACTIVE + * @arg @ref LL_TIM_OCMODE_PWM1 + * @arg @ref LL_TIM_OCMODE_PWM2 + */ +__STATIC_INLINE uint32_t LL_TIM_OC_GetMode(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + const __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + return (READ_BIT(*pReg, ((TIM_CCMR1_OC1M | TIM_CCMR1_CC1S) << SHIFT_TAB_OCxx[iChannel])) >> SHIFT_TAB_OCxx[iChannel]); +} + +/** + * @brief Set the polarity of an output channel. + * @rmtoll CCER CC1P LL_TIM_OC_SetPolarity\n + * CCER CC1NP LL_TIM_OC_SetPolarity\n + * CCER CC2P LL_TIM_OC_SetPolarity\n + * CCER CC2NP LL_TIM_OC_SetPolarity\n + * CCER CC3P LL_TIM_OC_SetPolarity\n + * CCER CC3NP LL_TIM_OC_SetPolarity\n + * CCER CC4P LL_TIM_OC_SetPolarity + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param Polarity This parameter can be one of the following values: + * @arg @ref LL_TIM_OCPOLARITY_HIGH + * @arg @ref LL_TIM_OCPOLARITY_LOW + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetPolarity(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Polarity) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + MODIFY_REG(TIMx->CCER, (TIM_CCER_CC1P << SHIFT_TAB_CCxP[iChannel]), Polarity << SHIFT_TAB_CCxP[iChannel]); +} + +/** + * @brief Get the polarity of an output channel. + * @rmtoll CCER CC1P LL_TIM_OC_GetPolarity\n + * CCER CC1NP LL_TIM_OC_GetPolarity\n + * CCER CC2P LL_TIM_OC_GetPolarity\n + * CCER CC2NP LL_TIM_OC_GetPolarity\n + * CCER CC3P LL_TIM_OC_GetPolarity\n + * CCER CC3NP LL_TIM_OC_GetPolarity\n + * CCER CC4P LL_TIM_OC_GetPolarity + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_OCPOLARITY_HIGH + * @arg @ref LL_TIM_OCPOLARITY_LOW + */ +__STATIC_INLINE uint32_t LL_TIM_OC_GetPolarity(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + return (READ_BIT(TIMx->CCER, (TIM_CCER_CC1P << SHIFT_TAB_CCxP[iChannel])) >> SHIFT_TAB_CCxP[iChannel]); +} + +/** + * @brief Set the IDLE state of an output channel + * @note This function is significant only for the timer instances + * supporting the break feature. Macro IS_TIM_BREAK_INSTANCE(TIMx) + * can be used to check whether or not a timer instance provides + * a break input. + * @rmtoll CR2 OIS1 LL_TIM_OC_SetIdleState\n + * CR2 OIS1N LL_TIM_OC_SetIdleState\n + * CR2 OIS2 LL_TIM_OC_SetIdleState\n + * CR2 OIS2N LL_TIM_OC_SetIdleState\n + * CR2 OIS3 LL_TIM_OC_SetIdleState\n + * CR2 OIS3N LL_TIM_OC_SetIdleState\n + * CR2 OIS4 LL_TIM_OC_SetIdleState + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param IdleState This parameter can be one of the following values: + * @arg @ref LL_TIM_OCIDLESTATE_LOW + * @arg @ref LL_TIM_OCIDLESTATE_HIGH + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetIdleState(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t IdleState) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + MODIFY_REG(TIMx->CR2, (TIM_CR2_OIS1 << SHIFT_TAB_OISx[iChannel]), IdleState << SHIFT_TAB_OISx[iChannel]); +} + +/** + * @brief Get the IDLE state of an output channel + * @rmtoll CR2 OIS1 LL_TIM_OC_GetIdleState\n + * CR2 OIS1N LL_TIM_OC_GetIdleState\n + * CR2 OIS2 LL_TIM_OC_GetIdleState\n + * CR2 OIS2N LL_TIM_OC_GetIdleState\n + * CR2 OIS3 LL_TIM_OC_GetIdleState\n + * CR2 OIS3N LL_TIM_OC_GetIdleState\n + * CR2 OIS4 LL_TIM_OC_GetIdleState + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH1N + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH2N + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH3N + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_OCIDLESTATE_LOW + * @arg @ref LL_TIM_OCIDLESTATE_HIGH + */ +__STATIC_INLINE uint32_t LL_TIM_OC_GetIdleState(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + return (READ_BIT(TIMx->CR2, (TIM_CR2_OIS1 << SHIFT_TAB_OISx[iChannel])) >> SHIFT_TAB_OISx[iChannel]); +} + +/** + * @brief Enable fast mode for the output channel. + * @note Acts only if the channel is configured in PWM1 or PWM2 mode. + * @rmtoll CCMR1 OC1FE LL_TIM_OC_EnableFast\n + * CCMR1 OC2FE LL_TIM_OC_EnableFast\n + * CCMR2 OC3FE LL_TIM_OC_EnableFast\n + * CCMR2 OC4FE LL_TIM_OC_EnableFast + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_EnableFast(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + SET_BIT(*pReg, (TIM_CCMR1_OC1FE << SHIFT_TAB_OCxx[iChannel])); + +} + +/** + * @brief Disable fast mode for the output channel. + * @rmtoll CCMR1 OC1FE LL_TIM_OC_DisableFast\n + * CCMR1 OC2FE LL_TIM_OC_DisableFast\n + * CCMR2 OC3FE LL_TIM_OC_DisableFast\n + * CCMR2 OC4FE LL_TIM_OC_DisableFast + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_DisableFast(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + CLEAR_BIT(*pReg, (TIM_CCMR1_OC1FE << SHIFT_TAB_OCxx[iChannel])); + +} + +/** + * @brief Indicates whether fast mode is enabled for the output channel. + * @rmtoll CCMR1 OC1FE LL_TIM_OC_IsEnabledFast\n + * CCMR1 OC2FE LL_TIM_OC_IsEnabledFast\n + * CCMR2 OC3FE LL_TIM_OC_IsEnabledFast\n + * CCMR2 OC4FE LL_TIM_OC_IsEnabledFast\n + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_OC_IsEnabledFast(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + const __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + uint32_t bitfield = TIM_CCMR1_OC1FE << SHIFT_TAB_OCxx[iChannel]; + return ((READ_BIT(*pReg, bitfield) == bitfield) ? 1UL : 0UL); +} + +/** + * @brief Enable compare register (TIMx_CCRx) preload for the output channel. + * @rmtoll CCMR1 OC1PE LL_TIM_OC_EnablePreload\n + * CCMR1 OC2PE LL_TIM_OC_EnablePreload\n + * CCMR2 OC3PE LL_TIM_OC_EnablePreload\n + * CCMR2 OC4PE LL_TIM_OC_EnablePreload + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_EnablePreload(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + SET_BIT(*pReg, (TIM_CCMR1_OC1PE << SHIFT_TAB_OCxx[iChannel])); +} + +/** + * @brief Disable compare register (TIMx_CCRx) preload for the output channel. + * @rmtoll CCMR1 OC1PE LL_TIM_OC_DisablePreload\n + * CCMR1 OC2PE LL_TIM_OC_DisablePreload\n + * CCMR2 OC3PE LL_TIM_OC_DisablePreload\n + * CCMR2 OC4PE LL_TIM_OC_DisablePreload + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_DisablePreload(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + CLEAR_BIT(*pReg, (TIM_CCMR1_OC1PE << SHIFT_TAB_OCxx[iChannel])); +} + +/** + * @brief Indicates whether compare register (TIMx_CCRx) preload is enabled for the output channel. + * @rmtoll CCMR1 OC1PE LL_TIM_OC_IsEnabledPreload\n + * CCMR1 OC2PE LL_TIM_OC_IsEnabledPreload\n + * CCMR2 OC3PE LL_TIM_OC_IsEnabledPreload\n + * CCMR2 OC4PE LL_TIM_OC_IsEnabledPreload\n + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_OC_IsEnabledPreload(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + const __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + uint32_t bitfield = TIM_CCMR1_OC1PE << SHIFT_TAB_OCxx[iChannel]; + return ((READ_BIT(*pReg, bitfield) == bitfield) ? 1UL : 0UL); +} + +/** + * @brief Enable clearing the output channel on an external event. + * @note This function can only be used in Output compare and PWM modes. It does not work in Forced mode. + * @note Macro IS_TIM_OCXREF_CLEAR_INSTANCE(TIMx) can be used to check whether + * or not a timer instance can clear the OCxREF signal on an external event. + * @rmtoll CCMR1 OC1CE LL_TIM_OC_EnableClear\n + * CCMR1 OC2CE LL_TIM_OC_EnableClear\n + * CCMR2 OC3CE LL_TIM_OC_EnableClear\n + * CCMR2 OC4CE LL_TIM_OC_EnableClear + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_EnableClear(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + SET_BIT(*pReg, (TIM_CCMR1_OC1CE << SHIFT_TAB_OCxx[iChannel])); +} + +/** + * @brief Disable clearing the output channel on an external event. + * @note Macro IS_TIM_OCXREF_CLEAR_INSTANCE(TIMx) can be used to check whether + * or not a timer instance can clear the OCxREF signal on an external event. + * @rmtoll CCMR1 OC1CE LL_TIM_OC_DisableClear\n + * CCMR1 OC2CE LL_TIM_OC_DisableClear\n + * CCMR2 OC3CE LL_TIM_OC_DisableClear\n + * CCMR2 OC4CE LL_TIM_OC_DisableClear + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_DisableClear(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + CLEAR_BIT(*pReg, (TIM_CCMR1_OC1CE << SHIFT_TAB_OCxx[iChannel])); +} + +/** + * @brief Indicates clearing the output channel on an external event is enabled for the output channel. + * @note This function enables clearing the output channel on an external event. + * @note This function can only be used in Output compare and PWM modes. It does not work in Forced mode. + * @note Macro IS_TIM_OCXREF_CLEAR_INSTANCE(TIMx) can be used to check whether + * or not a timer instance can clear the OCxREF signal on an external event. + * @rmtoll CCMR1 OC1CE LL_TIM_OC_IsEnabledClear\n + * CCMR1 OC2CE LL_TIM_OC_IsEnabledClear\n + * CCMR2 OC3CE LL_TIM_OC_IsEnabledClear\n + * CCMR2 OC4CE LL_TIM_OC_IsEnabledClear\n + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_OC_IsEnabledClear(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + const __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + uint32_t bitfield = TIM_CCMR1_OC1CE << SHIFT_TAB_OCxx[iChannel]; + return ((READ_BIT(*pReg, bitfield) == bitfield) ? 1UL : 0UL); +} + +/** + * @brief Set the dead-time delay (delay inserted between the rising edge of the OCxREF signal and the rising edge of + * the Ocx and OCxN signals). + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * dead-time insertion feature is supported by a timer instance. + * @note Helper macro @ref __LL_TIM_CALC_DEADTIME can be used to calculate the DeadTime parameter + * @rmtoll BDTR DTG LL_TIM_OC_SetDeadTime + * @param TIMx Timer instance + * @param DeadTime between Min_Data=0 and Max_Data=255 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetDeadTime(TIM_TypeDef *TIMx, uint32_t DeadTime) +{ + MODIFY_REG(TIMx->BDTR, TIM_BDTR_DTG, DeadTime); +} + +/** + * @brief Set compare value for output channel 1 (TIMx_CCR1). + * @note In 32-bit timer implementations compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC1_INSTANCE(TIMx) can be used to check whether or not + * output channel 1 is supported by a timer instance. + * @rmtoll CCR1 CCR1 LL_TIM_OC_SetCompareCH1 + * @param TIMx Timer instance + * @param CompareValue between Min_Data=0 and Max_Data=65535 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetCompareCH1(TIM_TypeDef *TIMx, uint32_t CompareValue) +{ + WRITE_REG(TIMx->CCR1, CompareValue); +} + +/** + * @brief Set compare value for output channel 2 (TIMx_CCR2). + * @note In 32-bit timer implementations compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC2_INSTANCE(TIMx) can be used to check whether or not + * output channel 2 is supported by a timer instance. + * @rmtoll CCR2 CCR2 LL_TIM_OC_SetCompareCH2 + * @param TIMx Timer instance + * @param CompareValue between Min_Data=0 and Max_Data=65535 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetCompareCH2(TIM_TypeDef *TIMx, uint32_t CompareValue) +{ + WRITE_REG(TIMx->CCR2, CompareValue); +} + +/** + * @brief Set compare value for output channel 3 (TIMx_CCR3). + * @note In 32-bit timer implementations compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC3_INSTANCE(TIMx) can be used to check whether or not + * output channel is supported by a timer instance. + * @rmtoll CCR3 CCR3 LL_TIM_OC_SetCompareCH3 + * @param TIMx Timer instance + * @param CompareValue between Min_Data=0 and Max_Data=65535 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetCompareCH3(TIM_TypeDef *TIMx, uint32_t CompareValue) +{ + WRITE_REG(TIMx->CCR3, CompareValue); +} + +/** + * @brief Set compare value for output channel 4 (TIMx_CCR4). + * @note In 32-bit timer implementations compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC4_INSTANCE(TIMx) can be used to check whether or not + * output channel 4 is supported by a timer instance. + * @rmtoll CCR4 CCR4 LL_TIM_OC_SetCompareCH4 + * @param TIMx Timer instance + * @param CompareValue between Min_Data=0 and Max_Data=65535 + * @retval None + */ +__STATIC_INLINE void LL_TIM_OC_SetCompareCH4(TIM_TypeDef *TIMx, uint32_t CompareValue) +{ + WRITE_REG(TIMx->CCR4, CompareValue); +} + +/** + * @brief Get compare value (TIMx_CCR1) set for output channel 1. + * @note In 32-bit timer implementations returned compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC1_INSTANCE(TIMx) can be used to check whether or not + * output channel 1 is supported by a timer instance. + * @rmtoll CCR1 CCR1 LL_TIM_OC_GetCompareCH1 + * @param TIMx Timer instance + * @retval CompareValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_OC_GetCompareCH1(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR1)); +} + +/** + * @brief Get compare value (TIMx_CCR2) set for output channel 2. + * @note In 32-bit timer implementations returned compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC2_INSTANCE(TIMx) can be used to check whether or not + * output channel 2 is supported by a timer instance. + * @rmtoll CCR2 CCR2 LL_TIM_OC_GetCompareCH2 + * @param TIMx Timer instance + * @retval CompareValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_OC_GetCompareCH2(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR2)); +} + +/** + * @brief Get compare value (TIMx_CCR3) set for output channel 3. + * @note In 32-bit timer implementations returned compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC3_INSTANCE(TIMx) can be used to check whether or not + * output channel 3 is supported by a timer instance. + * @rmtoll CCR3 CCR3 LL_TIM_OC_GetCompareCH3 + * @param TIMx Timer instance + * @retval CompareValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_OC_GetCompareCH3(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR3)); +} + +/** + * @brief Get compare value (TIMx_CCR4) set for output channel 4. + * @note In 32-bit timer implementations returned compare value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC4_INSTANCE(TIMx) can be used to check whether or not + * output channel 4 is supported by a timer instance. + * @rmtoll CCR4 CCR4 LL_TIM_OC_GetCompareCH4 + * @param TIMx Timer instance + * @retval CompareValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_OC_GetCompareCH4(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR4)); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_Input_Channel Input channel configuration + * @{ + */ +/** + * @brief Configure input channel. + * @rmtoll CCMR1 CC1S LL_TIM_IC_Config\n + * CCMR1 IC1PSC LL_TIM_IC_Config\n + * CCMR1 IC1F LL_TIM_IC_Config\n + * CCMR1 CC2S LL_TIM_IC_Config\n + * CCMR1 IC2PSC LL_TIM_IC_Config\n + * CCMR1 IC2F LL_TIM_IC_Config\n + * CCMR2 CC3S LL_TIM_IC_Config\n + * CCMR2 IC3PSC LL_TIM_IC_Config\n + * CCMR2 IC3F LL_TIM_IC_Config\n + * CCMR2 CC4S LL_TIM_IC_Config\n + * CCMR2 IC4PSC LL_TIM_IC_Config\n + * CCMR2 IC4F LL_TIM_IC_Config\n + * CCER CC1P LL_TIM_IC_Config\n + * CCER CC1NP LL_TIM_IC_Config\n + * CCER CC2P LL_TIM_IC_Config\n + * CCER CC2NP LL_TIM_IC_Config\n + * CCER CC3P LL_TIM_IC_Config\n + * CCER CC3NP LL_TIM_IC_Config\n + * CCER CC4P LL_TIM_IC_Config\n + * CCER CC4NP LL_TIM_IC_Config + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param Configuration This parameter must be a combination of all the following values: + * @arg @ref LL_TIM_ACTIVEINPUT_DIRECTTI or @ref LL_TIM_ACTIVEINPUT_INDIRECTTI or @ref LL_TIM_ACTIVEINPUT_TRC + * @arg @ref LL_TIM_ICPSC_DIV1 or ... or @ref LL_TIM_ICPSC_DIV8 + * @arg @ref LL_TIM_IC_FILTER_FDIV1 or ... or @ref LL_TIM_IC_FILTER_FDIV32_N8 + * @arg @ref LL_TIM_IC_POLARITY_RISING or @ref LL_TIM_IC_POLARITY_FALLING or @ref LL_TIM_IC_POLARITY_BOTHEDGE + * @retval None + */ +__STATIC_INLINE void LL_TIM_IC_Config(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t Configuration) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + MODIFY_REG(*pReg, ((TIM_CCMR1_IC1F | TIM_CCMR1_IC1PSC | TIM_CCMR1_CC1S) << SHIFT_TAB_ICxx[iChannel]), + ((Configuration >> 16U) & (TIM_CCMR1_IC1F | TIM_CCMR1_IC1PSC | TIM_CCMR1_CC1S)) \ + << SHIFT_TAB_ICxx[iChannel]); + MODIFY_REG(TIMx->CCER, ((TIM_CCER_CC1NP | TIM_CCER_CC1P) << SHIFT_TAB_CCxP[iChannel]), + (Configuration & (TIM_CCER_CC1NP | TIM_CCER_CC1P)) << SHIFT_TAB_CCxP[iChannel]); +} + +/** + * @brief Set the active input. + * @rmtoll CCMR1 CC1S LL_TIM_IC_SetActiveInput\n + * CCMR1 CC2S LL_TIM_IC_SetActiveInput\n + * CCMR2 CC3S LL_TIM_IC_SetActiveInput\n + * CCMR2 CC4S LL_TIM_IC_SetActiveInput + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param ICActiveInput This parameter can be one of the following values: + * @arg @ref LL_TIM_ACTIVEINPUT_DIRECTTI + * @arg @ref LL_TIM_ACTIVEINPUT_INDIRECTTI + * @arg @ref LL_TIM_ACTIVEINPUT_TRC + * @retval None + */ +__STATIC_INLINE void LL_TIM_IC_SetActiveInput(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ICActiveInput) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + MODIFY_REG(*pReg, ((TIM_CCMR1_CC1S) << SHIFT_TAB_ICxx[iChannel]), (ICActiveInput >> 16U) << SHIFT_TAB_ICxx[iChannel]); +} + +/** + * @brief Get the current active input. + * @rmtoll CCMR1 CC1S LL_TIM_IC_GetActiveInput\n + * CCMR1 CC2S LL_TIM_IC_GetActiveInput\n + * CCMR2 CC3S LL_TIM_IC_GetActiveInput\n + * CCMR2 CC4S LL_TIM_IC_GetActiveInput + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_ACTIVEINPUT_DIRECTTI + * @arg @ref LL_TIM_ACTIVEINPUT_INDIRECTTI + * @arg @ref LL_TIM_ACTIVEINPUT_TRC + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetActiveInput(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + const __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + return ((READ_BIT(*pReg, ((TIM_CCMR1_CC1S) << SHIFT_TAB_ICxx[iChannel])) >> SHIFT_TAB_ICxx[iChannel]) << 16U); +} + +/** + * @brief Set the prescaler of input channel. + * @rmtoll CCMR1 IC1PSC LL_TIM_IC_SetPrescaler\n + * CCMR1 IC2PSC LL_TIM_IC_SetPrescaler\n + * CCMR2 IC3PSC LL_TIM_IC_SetPrescaler\n + * CCMR2 IC4PSC LL_TIM_IC_SetPrescaler + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param ICPrescaler This parameter can be one of the following values: + * @arg @ref LL_TIM_ICPSC_DIV1 + * @arg @ref LL_TIM_ICPSC_DIV2 + * @arg @ref LL_TIM_ICPSC_DIV4 + * @arg @ref LL_TIM_ICPSC_DIV8 + * @retval None + */ +__STATIC_INLINE void LL_TIM_IC_SetPrescaler(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ICPrescaler) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + MODIFY_REG(*pReg, ((TIM_CCMR1_IC1PSC) << SHIFT_TAB_ICxx[iChannel]), (ICPrescaler >> 16U) << SHIFT_TAB_ICxx[iChannel]); +} + +/** + * @brief Get the current prescaler value acting on an input channel. + * @rmtoll CCMR1 IC1PSC LL_TIM_IC_GetPrescaler\n + * CCMR1 IC2PSC LL_TIM_IC_GetPrescaler\n + * CCMR2 IC3PSC LL_TIM_IC_GetPrescaler\n + * CCMR2 IC4PSC LL_TIM_IC_GetPrescaler + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_ICPSC_DIV1 + * @arg @ref LL_TIM_ICPSC_DIV2 + * @arg @ref LL_TIM_ICPSC_DIV4 + * @arg @ref LL_TIM_ICPSC_DIV8 + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetPrescaler(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + const __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + return ((READ_BIT(*pReg, ((TIM_CCMR1_IC1PSC) << SHIFT_TAB_ICxx[iChannel])) >> SHIFT_TAB_ICxx[iChannel]) << 16U); +} + +/** + * @brief Set the input filter duration. + * @rmtoll CCMR1 IC1F LL_TIM_IC_SetFilter\n + * CCMR1 IC2F LL_TIM_IC_SetFilter\n + * CCMR2 IC3F LL_TIM_IC_SetFilter\n + * CCMR2 IC4F LL_TIM_IC_SetFilter + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param ICFilter This parameter can be one of the following values: + * @arg @ref LL_TIM_IC_FILTER_FDIV1 + * @arg @ref LL_TIM_IC_FILTER_FDIV1_N2 + * @arg @ref LL_TIM_IC_FILTER_FDIV1_N4 + * @arg @ref LL_TIM_IC_FILTER_FDIV1_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV2_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV2_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV4_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV4_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV8_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV8_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV16_N5 + * @arg @ref LL_TIM_IC_FILTER_FDIV16_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV16_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV32_N5 + * @arg @ref LL_TIM_IC_FILTER_FDIV32_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV32_N8 + * @retval None + */ +__STATIC_INLINE void LL_TIM_IC_SetFilter(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ICFilter) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + MODIFY_REG(*pReg, ((TIM_CCMR1_IC1F) << SHIFT_TAB_ICxx[iChannel]), (ICFilter >> 16U) << SHIFT_TAB_ICxx[iChannel]); +} + +/** + * @brief Get the input filter duration. + * @rmtoll CCMR1 IC1F LL_TIM_IC_GetFilter\n + * CCMR1 IC2F LL_TIM_IC_GetFilter\n + * CCMR2 IC3F LL_TIM_IC_GetFilter\n + * CCMR2 IC4F LL_TIM_IC_GetFilter + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_IC_FILTER_FDIV1 + * @arg @ref LL_TIM_IC_FILTER_FDIV1_N2 + * @arg @ref LL_TIM_IC_FILTER_FDIV1_N4 + * @arg @ref LL_TIM_IC_FILTER_FDIV1_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV2_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV2_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV4_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV4_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV8_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV8_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV16_N5 + * @arg @ref LL_TIM_IC_FILTER_FDIV16_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV16_N8 + * @arg @ref LL_TIM_IC_FILTER_FDIV32_N5 + * @arg @ref LL_TIM_IC_FILTER_FDIV32_N6 + * @arg @ref LL_TIM_IC_FILTER_FDIV32_N8 + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetFilter(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + const __IO uint32_t *pReg = (__IO uint32_t *)((uint32_t)((uint32_t)(&TIMx->CCMR1) + OFFSET_TAB_CCMRx[iChannel])); + return ((READ_BIT(*pReg, ((TIM_CCMR1_IC1F) << SHIFT_TAB_ICxx[iChannel])) >> SHIFT_TAB_ICxx[iChannel]) << 16U); +} + +/** + * @brief Set the input channel polarity. + * @rmtoll CCER CC1P LL_TIM_IC_SetPolarity\n + * CCER CC1NP LL_TIM_IC_SetPolarity\n + * CCER CC2P LL_TIM_IC_SetPolarity\n + * CCER CC2NP LL_TIM_IC_SetPolarity\n + * CCER CC3P LL_TIM_IC_SetPolarity\n + * CCER CC3NP LL_TIM_IC_SetPolarity\n + * CCER CC4P LL_TIM_IC_SetPolarity\n + * CCER CC4NP LL_TIM_IC_SetPolarity + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param ICPolarity This parameter can be one of the following values: + * @arg @ref LL_TIM_IC_POLARITY_RISING + * @arg @ref LL_TIM_IC_POLARITY_FALLING + * @arg @ref LL_TIM_IC_POLARITY_BOTHEDGE + * @retval None + */ +__STATIC_INLINE void LL_TIM_IC_SetPolarity(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ICPolarity) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + MODIFY_REG(TIMx->CCER, ((TIM_CCER_CC1NP | TIM_CCER_CC1P) << SHIFT_TAB_CCxP[iChannel]), + ICPolarity << SHIFT_TAB_CCxP[iChannel]); +} + +/** + * @brief Get the current input channel polarity. + * @rmtoll CCER CC1P LL_TIM_IC_GetPolarity\n + * CCER CC1NP LL_TIM_IC_GetPolarity\n + * CCER CC2P LL_TIM_IC_GetPolarity\n + * CCER CC2NP LL_TIM_IC_GetPolarity\n + * CCER CC3P LL_TIM_IC_GetPolarity\n + * CCER CC3NP LL_TIM_IC_GetPolarity\n + * CCER CC4P LL_TIM_IC_GetPolarity\n + * CCER CC4NP LL_TIM_IC_GetPolarity + * @param TIMx Timer instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @retval Returned value can be one of the following values: + * @arg @ref LL_TIM_IC_POLARITY_RISING + * @arg @ref LL_TIM_IC_POLARITY_FALLING + * @arg @ref LL_TIM_IC_POLARITY_BOTHEDGE + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetPolarity(TIM_TypeDef *TIMx, uint32_t Channel) +{ + uint8_t iChannel = TIM_GET_CHANNEL_INDEX(Channel); + return (READ_BIT(TIMx->CCER, ((TIM_CCER_CC1NP | TIM_CCER_CC1P) << SHIFT_TAB_CCxP[iChannel])) >> + SHIFT_TAB_CCxP[iChannel]); +} + +/** + * @brief Connect the TIMx_CH1, CH2 and CH3 pins to the TI1 input (XOR combination). + * @note Macro IS_TIM_XOR_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides an XOR input. + * @rmtoll CR2 TI1S LL_TIM_IC_EnableXORCombination + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_IC_EnableXORCombination(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->CR2, TIM_CR2_TI1S); +} + +/** + * @brief Disconnect the TIMx_CH1, CH2 and CH3 pins from the TI1 input. + * @note Macro IS_TIM_XOR_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides an XOR input. + * @rmtoll CR2 TI1S LL_TIM_IC_DisableXORCombination + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_IC_DisableXORCombination(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->CR2, TIM_CR2_TI1S); +} + +/** + * @brief Indicates whether the TIMx_CH1, CH2 and CH3 pins are connectected to the TI1 input. + * @note Macro IS_TIM_XOR_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides an XOR input. + * @rmtoll CR2 TI1S LL_TIM_IC_IsEnabledXORCombination + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IC_IsEnabledXORCombination(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->CR2, TIM_CR2_TI1S) == (TIM_CR2_TI1S)) ? 1UL : 0UL); +} + +/** + * @brief Get captured value for input channel 1. + * @note In 32-bit timer implementations returned captured value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC1_INSTANCE(TIMx) can be used to check whether or not + * input channel 1 is supported by a timer instance. + * @rmtoll CCR1 CCR1 LL_TIM_IC_GetCaptureCH1 + * @param TIMx Timer instance + * @retval CapturedValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetCaptureCH1(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR1)); +} + +/** + * @brief Get captured value for input channel 2. + * @note In 32-bit timer implementations returned captured value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC2_INSTANCE(TIMx) can be used to check whether or not + * input channel 2 is supported by a timer instance. + * @rmtoll CCR2 CCR2 LL_TIM_IC_GetCaptureCH2 + * @param TIMx Timer instance + * @retval CapturedValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetCaptureCH2(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR2)); +} + +/** + * @brief Get captured value for input channel 3. + * @note In 32-bit timer implementations returned captured value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC3_INSTANCE(TIMx) can be used to check whether or not + * input channel 3 is supported by a timer instance. + * @rmtoll CCR3 CCR3 LL_TIM_IC_GetCaptureCH3 + * @param TIMx Timer instance + * @retval CapturedValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetCaptureCH3(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR3)); +} + +/** + * @brief Get captured value for input channel 4. + * @note In 32-bit timer implementations returned captured value can be between 0x00000000 and 0xFFFFFFFF. + * @note Macro IS_TIM_32B_COUNTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports a 32 bits counter. + * @note Macro IS_TIM_CC4_INSTANCE(TIMx) can be used to check whether or not + * input channel 4 is supported by a timer instance. + * @rmtoll CCR4 CCR4 LL_TIM_IC_GetCaptureCH4 + * @param TIMx Timer instance + * @retval CapturedValue (between Min_Data=0 and Max_Data=65535) + */ +__STATIC_INLINE uint32_t LL_TIM_IC_GetCaptureCH4(TIM_TypeDef *TIMx) +{ + return (uint32_t)(READ_REG(TIMx->CCR4)); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_Clock_Selection Counter clock selection + * @{ + */ +/** + * @brief Enable external clock mode 2. + * @note When external clock mode 2 is enabled the counter is clocked by any active edge on the ETRF signal. + * @note Macro IS_TIM_CLOCKSOURCE_ETRMODE2_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports external clock mode2. + * @rmtoll SMCR ECE LL_TIM_EnableExternalClock + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableExternalClock(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->SMCR, TIM_SMCR_ECE); +} + +/** + * @brief Disable external clock mode 2. + * @note Macro IS_TIM_CLOCKSOURCE_ETRMODE2_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports external clock mode2. + * @rmtoll SMCR ECE LL_TIM_DisableExternalClock + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableExternalClock(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->SMCR, TIM_SMCR_ECE); +} + +/** + * @brief Indicate whether external clock mode 2 is enabled. + * @note Macro IS_TIM_CLOCKSOURCE_ETRMODE2_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports external clock mode2. + * @rmtoll SMCR ECE LL_TIM_IsEnabledExternalClock + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledExternalClock(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SMCR, TIM_SMCR_ECE) == (TIM_SMCR_ECE)) ? 1UL : 0UL); +} + +/** + * @brief Set the clock source of the counter clock. + * @note when selected clock source is external clock mode 1, the timer input + * the external clock is applied is selected by calling the @ref LL_TIM_SetTriggerInput() + * function. This timer input must be configured by calling + * the @ref LL_TIM_IC_Config() function. + * @note Macro IS_TIM_CLOCKSOURCE_ETRMODE1_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports external clock mode1. + * @note Macro IS_TIM_CLOCKSOURCE_ETRMODE2_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports external clock mode2. + * @rmtoll SMCR SMS LL_TIM_SetClockSource\n + * SMCR ECE LL_TIM_SetClockSource + * @param TIMx Timer instance + * @param ClockSource This parameter can be one of the following values: + * @arg @ref LL_TIM_CLOCKSOURCE_INTERNAL + * @arg @ref LL_TIM_CLOCKSOURCE_EXT_MODE1 + * @arg @ref LL_TIM_CLOCKSOURCE_EXT_MODE2 + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetClockSource(TIM_TypeDef *TIMx, uint32_t ClockSource) +{ + MODIFY_REG(TIMx->SMCR, TIM_SMCR_SMS | TIM_SMCR_ECE, ClockSource); +} + +/** + * @brief Set the encoder interface mode. + * @note Macro IS_TIM_ENCODER_INTERFACE_INSTANCE(TIMx) can be used to check + * whether or not a timer instance supports the encoder mode. + * @rmtoll SMCR SMS LL_TIM_SetEncoderMode + * @param TIMx Timer instance + * @param EncoderMode This parameter can be one of the following values: + * @arg @ref LL_TIM_ENCODERMODE_X2_TI1 + * @arg @ref LL_TIM_ENCODERMODE_X2_TI2 + * @arg @ref LL_TIM_ENCODERMODE_X4_TI12 + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetEncoderMode(TIM_TypeDef *TIMx, uint32_t EncoderMode) +{ + MODIFY_REG(TIMx->SMCR, TIM_SMCR_SMS, EncoderMode); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_Timer_Synchronization Timer synchronisation configuration + * @{ + */ +/** + * @brief Set the trigger output (TRGO) used for timer synchronization . + * @note Macro IS_TIM_MASTER_INSTANCE(TIMx) can be used to check + * whether or not a timer instance can operate as a master timer. + * @rmtoll CR2 MMS LL_TIM_SetTriggerOutput + * @param TIMx Timer instance + * @param TimerSynchronization This parameter can be one of the following values: + * @arg @ref LL_TIM_TRGO_RESET + * @arg @ref LL_TIM_TRGO_ENABLE + * @arg @ref LL_TIM_TRGO_UPDATE + * @arg @ref LL_TIM_TRGO_CC1IF + * @arg @ref LL_TIM_TRGO_OC1REF + * @arg @ref LL_TIM_TRGO_OC2REF + * @arg @ref LL_TIM_TRGO_OC3REF + * @arg @ref LL_TIM_TRGO_OC4REF + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetTriggerOutput(TIM_TypeDef *TIMx, uint32_t TimerSynchronization) +{ + MODIFY_REG(TIMx->CR2, TIM_CR2_MMS, TimerSynchronization); +} + +/** + * @brief Set the synchronization mode of a slave timer. + * @note Macro IS_TIM_SLAVE_INSTANCE(TIMx) can be used to check whether or not + * a timer instance can operate as a slave timer. + * @rmtoll SMCR SMS LL_TIM_SetSlaveMode + * @param TIMx Timer instance + * @param SlaveMode This parameter can be one of the following values: + * @arg @ref LL_TIM_SLAVEMODE_DISABLED + * @arg @ref LL_TIM_SLAVEMODE_RESET + * @arg @ref LL_TIM_SLAVEMODE_GATED + * @arg @ref LL_TIM_SLAVEMODE_TRIGGER + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetSlaveMode(TIM_TypeDef *TIMx, uint32_t SlaveMode) +{ + MODIFY_REG(TIMx->SMCR, TIM_SMCR_SMS, SlaveMode); +} + +/** + * @brief Set the selects the trigger input to be used to synchronize the counter. + * @note Macro IS_TIM_SLAVE_INSTANCE(TIMx) can be used to check whether or not + * a timer instance can operate as a slave timer. + * @rmtoll SMCR TS LL_TIM_SetTriggerInput + * @param TIMx Timer instance + * @param TriggerInput This parameter can be one of the following values: + * @arg @ref LL_TIM_TS_ITR0 + * @arg @ref LL_TIM_TS_ITR1 + * @arg @ref LL_TIM_TS_ITR2 + * @arg @ref LL_TIM_TS_ITR3 + * @arg @ref LL_TIM_TS_TI1F_ED + * @arg @ref LL_TIM_TS_TI1FP1 + * @arg @ref LL_TIM_TS_TI2FP2 + * @arg @ref LL_TIM_TS_ETRF + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetTriggerInput(TIM_TypeDef *TIMx, uint32_t TriggerInput) +{ + MODIFY_REG(TIMx->SMCR, TIM_SMCR_TS, TriggerInput); +} + +/** + * @brief Enable the Master/Slave mode. + * @note Macro IS_TIM_SLAVE_INSTANCE(TIMx) can be used to check whether or not + * a timer instance can operate as a slave timer. + * @rmtoll SMCR MSM LL_TIM_EnableMasterSlaveMode + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableMasterSlaveMode(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->SMCR, TIM_SMCR_MSM); +} + +/** + * @brief Disable the Master/Slave mode. + * @note Macro IS_TIM_SLAVE_INSTANCE(TIMx) can be used to check whether or not + * a timer instance can operate as a slave timer. + * @rmtoll SMCR MSM LL_TIM_DisableMasterSlaveMode + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableMasterSlaveMode(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->SMCR, TIM_SMCR_MSM); +} + +/** + * @brief Indicates whether the Master/Slave mode is enabled. + * @note Macro IS_TIM_SLAVE_INSTANCE(TIMx) can be used to check whether or not + * a timer instance can operate as a slave timer. + * @rmtoll SMCR MSM LL_TIM_IsEnabledMasterSlaveMode + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledMasterSlaveMode(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SMCR, TIM_SMCR_MSM) == (TIM_SMCR_MSM)) ? 1UL : 0UL); +} + +/** + * @brief Configure the external trigger (ETR) input. + * @note Macro IS_TIM_ETR_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides an external trigger input. + * @rmtoll SMCR ETP LL_TIM_ConfigETR\n + * SMCR ETPS LL_TIM_ConfigETR\n + * SMCR ETF LL_TIM_ConfigETR + * @param TIMx Timer instance + * @param ETRPolarity This parameter can be one of the following values: + * @arg @ref LL_TIM_ETR_POLARITY_NONINVERTED + * @arg @ref LL_TIM_ETR_POLARITY_INVERTED + * @param ETRPrescaler This parameter can be one of the following values: + * @arg @ref LL_TIM_ETR_PRESCALER_DIV1 + * @arg @ref LL_TIM_ETR_PRESCALER_DIV2 + * @arg @ref LL_TIM_ETR_PRESCALER_DIV4 + * @arg @ref LL_TIM_ETR_PRESCALER_DIV8 + * @param ETRFilter This parameter can be one of the following values: + * @arg @ref LL_TIM_ETR_FILTER_FDIV1 + * @arg @ref LL_TIM_ETR_FILTER_FDIV1_N2 + * @arg @ref LL_TIM_ETR_FILTER_FDIV1_N4 + * @arg @ref LL_TIM_ETR_FILTER_FDIV1_N8 + * @arg @ref LL_TIM_ETR_FILTER_FDIV2_N6 + * @arg @ref LL_TIM_ETR_FILTER_FDIV2_N8 + * @arg @ref LL_TIM_ETR_FILTER_FDIV4_N6 + * @arg @ref LL_TIM_ETR_FILTER_FDIV4_N8 + * @arg @ref LL_TIM_ETR_FILTER_FDIV8_N6 + * @arg @ref LL_TIM_ETR_FILTER_FDIV8_N8 + * @arg @ref LL_TIM_ETR_FILTER_FDIV16_N5 + * @arg @ref LL_TIM_ETR_FILTER_FDIV16_N6 + * @arg @ref LL_TIM_ETR_FILTER_FDIV16_N8 + * @arg @ref LL_TIM_ETR_FILTER_FDIV32_N5 + * @arg @ref LL_TIM_ETR_FILTER_FDIV32_N6 + * @arg @ref LL_TIM_ETR_FILTER_FDIV32_N8 + * @retval None + */ +__STATIC_INLINE void LL_TIM_ConfigETR(TIM_TypeDef *TIMx, uint32_t ETRPolarity, uint32_t ETRPrescaler, + uint32_t ETRFilter) +{ + MODIFY_REG(TIMx->SMCR, TIM_SMCR_ETP | TIM_SMCR_ETPS | TIM_SMCR_ETF, ETRPolarity | ETRPrescaler | ETRFilter); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_Break_Function Break function configuration + * @{ + */ +/** + * @brief Enable the break function. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR BKE LL_TIM_EnableBRK + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableBRK(TIM_TypeDef *TIMx) +{ + __IO uint32_t tmpreg; + SET_BIT(TIMx->BDTR, TIM_BDTR_BKE); + /* Note: Any write operation to this bit takes a delay of 1 APB clock cycle to become effective. */ + tmpreg = READ_REG(TIMx->BDTR); + (void)(tmpreg); +} + +/** + * @brief Disable the break function. + * @rmtoll BDTR BKE LL_TIM_DisableBRK + * @param TIMx Timer instance + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableBRK(TIM_TypeDef *TIMx) +{ + __IO uint32_t tmpreg; + CLEAR_BIT(TIMx->BDTR, TIM_BDTR_BKE); + /* Note: Any write operation to this bit takes a delay of 1 APB clock cycle to become effective. */ + tmpreg = READ_REG(TIMx->BDTR); + (void)(tmpreg); +} + +/** + * @brief Configure the break input. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR BKP LL_TIM_ConfigBRK + * @param TIMx Timer instance + * @param BreakPolarity This parameter can be one of the following values: + * @arg @ref LL_TIM_BREAK_POLARITY_LOW + * @arg @ref LL_TIM_BREAK_POLARITY_HIGH + * @retval None + */ +__STATIC_INLINE void LL_TIM_ConfigBRK(TIM_TypeDef *TIMx, uint32_t BreakPolarity) +{ + __IO uint32_t tmpreg; + MODIFY_REG(TIMx->BDTR, TIM_BDTR_BKP, BreakPolarity); + /* Note: Any write operation to BKP bit takes a delay of 1 APB clock cycle to become effective. */ + tmpreg = READ_REG(TIMx->BDTR); + (void)(tmpreg); +} + +/** + * @brief Select the outputs off state (enabled v.s. disabled) in Idle and Run modes. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR OSSI LL_TIM_SetOffStates\n + * BDTR OSSR LL_TIM_SetOffStates + * @param TIMx Timer instance + * @param OffStateIdle This parameter can be one of the following values: + * @arg @ref LL_TIM_OSSI_DISABLE + * @arg @ref LL_TIM_OSSI_ENABLE + * @param OffStateRun This parameter can be one of the following values: + * @arg @ref LL_TIM_OSSR_DISABLE + * @arg @ref LL_TIM_OSSR_ENABLE + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetOffStates(TIM_TypeDef *TIMx, uint32_t OffStateIdle, uint32_t OffStateRun) +{ + MODIFY_REG(TIMx->BDTR, TIM_BDTR_OSSI | TIM_BDTR_OSSR, OffStateIdle | OffStateRun); +} + +/** + * @brief Enable automatic output (MOE can be set by software or automatically when a break input is active). + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR AOE LL_TIM_EnableAutomaticOutput + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableAutomaticOutput(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->BDTR, TIM_BDTR_AOE); +} + +/** + * @brief Disable automatic output (MOE can be set only by software). + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR AOE LL_TIM_DisableAutomaticOutput + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableAutomaticOutput(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->BDTR, TIM_BDTR_AOE); +} + +/** + * @brief Indicate whether automatic output is enabled. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR AOE LL_TIM_IsEnabledAutomaticOutput + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledAutomaticOutput(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->BDTR, TIM_BDTR_AOE) == (TIM_BDTR_AOE)) ? 1UL : 0UL); +} + +/** + * @brief Enable the outputs (set the MOE bit in TIMx_BDTR register). + * @note The MOE bit in TIMx_BDTR register allows to enable /disable the outputs by + * software and is reset in case of break or break2 event + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR MOE LL_TIM_EnableAllOutputs + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableAllOutputs(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->BDTR, TIM_BDTR_MOE); +} + +/** + * @brief Disable the outputs (reset the MOE bit in TIMx_BDTR register). + * @note The MOE bit in TIMx_BDTR register allows to enable /disable the outputs by + * software and is reset in case of break or break2 event. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR MOE LL_TIM_DisableAllOutputs + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableAllOutputs(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->BDTR, TIM_BDTR_MOE); +} + +/** + * @brief Indicates whether outputs are enabled. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @rmtoll BDTR MOE LL_TIM_IsEnabledAllOutputs + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledAllOutputs(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->BDTR, TIM_BDTR_MOE) == (TIM_BDTR_MOE)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_DMA_Burst_Mode DMA burst mode configuration + * @{ + */ +/** + * @brief Configures the timer DMA burst feature. + * @note Macro IS_TIM_DMABURST_INSTANCE(TIMx) can be used to check whether or + * not a timer instance supports the DMA burst mode. + * @rmtoll DCR DBL LL_TIM_ConfigDMABurst\n + * DCR DBA LL_TIM_ConfigDMABurst + * @param TIMx Timer instance + * @param DMABurstBaseAddress This parameter can be one of the following values: + * @arg @ref LL_TIM_DMABURST_BASEADDR_CR1 + * @arg @ref LL_TIM_DMABURST_BASEADDR_CR2 + * @arg @ref LL_TIM_DMABURST_BASEADDR_SMCR + * @arg @ref LL_TIM_DMABURST_BASEADDR_DIER + * @arg @ref LL_TIM_DMABURST_BASEADDR_SR + * @arg @ref LL_TIM_DMABURST_BASEADDR_EGR + * @arg @ref LL_TIM_DMABURST_BASEADDR_CCMR1 + * @arg @ref LL_TIM_DMABURST_BASEADDR_CCMR2 + * @arg @ref LL_TIM_DMABURST_BASEADDR_CCER + * @arg @ref LL_TIM_DMABURST_BASEADDR_CNT + * @arg @ref LL_TIM_DMABURST_BASEADDR_PSC + * @arg @ref LL_TIM_DMABURST_BASEADDR_ARR + * @arg @ref LL_TIM_DMABURST_BASEADDR_RCR + * @arg @ref LL_TIM_DMABURST_BASEADDR_CCR1 + * @arg @ref LL_TIM_DMABURST_BASEADDR_CCR2 + * @arg @ref LL_TIM_DMABURST_BASEADDR_CCR3 + * @arg @ref LL_TIM_DMABURST_BASEADDR_CCR4 + * @arg @ref LL_TIM_DMABURST_BASEADDR_BDTR + * @param DMABurstLength This parameter can be one of the following values: + * @arg @ref LL_TIM_DMABURST_LENGTH_1TRANSFER + * @arg @ref LL_TIM_DMABURST_LENGTH_2TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_3TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_4TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_5TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_6TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_7TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_8TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_9TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_10TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_11TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_12TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_13TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_14TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_15TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_16TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_17TRANSFERS + * @arg @ref LL_TIM_DMABURST_LENGTH_18TRANSFERS + * @retval None + */ +__STATIC_INLINE void LL_TIM_ConfigDMABurst(TIM_TypeDef *TIMx, uint32_t DMABurstBaseAddress, uint32_t DMABurstLength) +{ + MODIFY_REG(TIMx->DCR, (TIM_DCR_DBL | TIM_DCR_DBA), (DMABurstBaseAddress | DMABurstLength)); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_Timer_Inputs_Remapping Timer input remapping + * @{ + */ +/** + * @brief Remap TIM inputs (input channel, internal/external triggers). + * @note Macro IS_TIM_REMAP_INSTANCE(TIMx) can be used to check whether or not + * a some timer inputs can be remapped. + * @rmtoll TIM14_OR TI1_RMP LL_TIM_SetRemap + * @param TIMx Timer instance + * @param Remap This parameter can be one of the following values: + * @arg @ref LL_TIM_TIM14_TI1_RMP_GPIO + * @arg @ref LL_TIM_TIM14_TI1_RMP_RTC_CLK + * @arg @ref LL_TIM_TIM14_TI1_RMP_HSE + * @arg @ref LL_TIM_TIM14_TI1_RMP_MCO + * + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetRemap(TIM_TypeDef *TIMx, uint32_t Remap) +{ + MODIFY_REG(TIMx->OR, (Remap >> TIMx_OR_RMP_SHIFT), (Remap & TIMx_OR_RMP_MASK)); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_OCREF_Clear OCREF_Clear_Management + * @{ + */ +/** + * @brief Set the OCREF clear input source + * @note The OCxREF signal of a given channel can be cleared when a high level is applied on the OCREF_CLR_INPUT + * @note This function can only be used in Output compare and PWM modes. + * @rmtoll SMCR OCCS LL_TIM_SetOCRefClearInputSource + * @param TIMx Timer instance + * @param OCRefClearInputSource This parameter can be one of the following values: + * @arg @ref LL_TIM_OCREF_CLR_INT_OCREF_CLR + * @arg @ref LL_TIM_OCREF_CLR_INT_ETR + * @retval None + */ +__STATIC_INLINE void LL_TIM_SetOCRefClearInputSource(TIM_TypeDef *TIMx, uint32_t OCRefClearInputSource) +{ + MODIFY_REG(TIMx->SMCR, TIM_SMCR_OCCS, OCRefClearInputSource); +} +/** + * @} + */ + +/** @defgroup TIM_LL_EF_FLAG_Management FLAG-Management + * @{ + */ +/** + * @brief Clear the update interrupt flag (UIF). + * @rmtoll SR UIF LL_TIM_ClearFlag_UPDATE + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_UPDATE(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_UIF)); +} + +/** + * @brief Indicate whether update interrupt flag (UIF) is set (update interrupt is pending). + * @rmtoll SR UIF LL_TIM_IsActiveFlag_UPDATE + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_UPDATE(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_UIF) == (TIM_SR_UIF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 1 interrupt flag (CC1F). + * @rmtoll SR CC1IF LL_TIM_ClearFlag_CC1 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC1(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC1IF)); +} + +/** + * @brief Indicate whether Capture/Compare 1 interrupt flag (CC1F) is set (Capture/Compare 1 interrupt is pending). + * @rmtoll SR CC1IF LL_TIM_IsActiveFlag_CC1 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC1(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC1IF) == (TIM_SR_CC1IF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 2 interrupt flag (CC2F). + * @rmtoll SR CC2IF LL_TIM_ClearFlag_CC2 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC2(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC2IF)); +} + +/** + * @brief Indicate whether Capture/Compare 2 interrupt flag (CC2F) is set (Capture/Compare 2 interrupt is pending). + * @rmtoll SR CC2IF LL_TIM_IsActiveFlag_CC2 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC2(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC2IF) == (TIM_SR_CC2IF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 3 interrupt flag (CC3F). + * @rmtoll SR CC3IF LL_TIM_ClearFlag_CC3 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC3(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC3IF)); +} + +/** + * @brief Indicate whether Capture/Compare 3 interrupt flag (CC3F) is set (Capture/Compare 3 interrupt is pending). + * @rmtoll SR CC3IF LL_TIM_IsActiveFlag_CC3 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC3(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC3IF) == (TIM_SR_CC3IF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 4 interrupt flag (CC4F). + * @rmtoll SR CC4IF LL_TIM_ClearFlag_CC4 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC4(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC4IF)); +} + +/** + * @brief Indicate whether Capture/Compare 4 interrupt flag (CC4F) is set (Capture/Compare 4 interrupt is pending). + * @rmtoll SR CC4IF LL_TIM_IsActiveFlag_CC4 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC4(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC4IF) == (TIM_SR_CC4IF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the commutation interrupt flag (COMIF). + * @rmtoll SR COMIF LL_TIM_ClearFlag_COM + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_COM(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_COMIF)); +} + +/** + * @brief Indicate whether commutation interrupt flag (COMIF) is set (commutation interrupt is pending). + * @rmtoll SR COMIF LL_TIM_IsActiveFlag_COM + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_COM(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_COMIF) == (TIM_SR_COMIF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the trigger interrupt flag (TIF). + * @rmtoll SR TIF LL_TIM_ClearFlag_TRIG + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_TRIG(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_TIF)); +} + +/** + * @brief Indicate whether trigger interrupt flag (TIF) is set (trigger interrupt is pending). + * @rmtoll SR TIF LL_TIM_IsActiveFlag_TRIG + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_TRIG(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_TIF) == (TIM_SR_TIF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the break interrupt flag (BIF). + * @rmtoll SR BIF LL_TIM_ClearFlag_BRK + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_BRK(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_BIF)); +} + +/** + * @brief Indicate whether break interrupt flag (BIF) is set (break interrupt is pending). + * @rmtoll SR BIF LL_TIM_IsActiveFlag_BRK + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_BRK(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_BIF) == (TIM_SR_BIF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 1 over-capture interrupt flag (CC1OF). + * @rmtoll SR CC1OF LL_TIM_ClearFlag_CC1OVR + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC1OVR(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC1OF)); +} + +/** + * @brief Indicate whether Capture/Compare 1 over-capture interrupt flag (CC1OF) is set + * (Capture/Compare 1 interrupt is pending). + * @rmtoll SR CC1OF LL_TIM_IsActiveFlag_CC1OVR + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC1OVR(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC1OF) == (TIM_SR_CC1OF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 2 over-capture interrupt flag (CC2OF). + * @rmtoll SR CC2OF LL_TIM_ClearFlag_CC2OVR + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC2OVR(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC2OF)); +} + +/** + * @brief Indicate whether Capture/Compare 2 over-capture interrupt flag (CC2OF) is set + * (Capture/Compare 2 over-capture interrupt is pending). + * @rmtoll SR CC2OF LL_TIM_IsActiveFlag_CC2OVR + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC2OVR(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC2OF) == (TIM_SR_CC2OF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 3 over-capture interrupt flag (CC3OF). + * @rmtoll SR CC3OF LL_TIM_ClearFlag_CC3OVR + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC3OVR(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC3OF)); +} + +/** + * @brief Indicate whether Capture/Compare 3 over-capture interrupt flag (CC3OF) is set + * (Capture/Compare 3 over-capture interrupt is pending). + * @rmtoll SR CC3OF LL_TIM_IsActiveFlag_CC3OVR + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC3OVR(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC3OF) == (TIM_SR_CC3OF)) ? 1UL : 0UL); +} + +/** + * @brief Clear the Capture/Compare 4 over-capture interrupt flag (CC4OF). + * @rmtoll SR CC4OF LL_TIM_ClearFlag_CC4OVR + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_ClearFlag_CC4OVR(TIM_TypeDef *TIMx) +{ + WRITE_REG(TIMx->SR, ~(TIM_SR_CC4OF)); +} + +/** + * @brief Indicate whether Capture/Compare 4 over-capture interrupt flag (CC4OF) is set + * (Capture/Compare 4 over-capture interrupt is pending). + * @rmtoll SR CC4OF LL_TIM_IsActiveFlag_CC4OVR + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsActiveFlag_CC4OVR(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->SR, TIM_SR_CC4OF) == (TIM_SR_CC4OF)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_IT_Management IT-Management + * @{ + */ +/** + * @brief Enable update interrupt (UIE). + * @rmtoll DIER UIE LL_TIM_EnableIT_UPDATE + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_UPDATE(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_UIE); +} + +/** + * @brief Disable update interrupt (UIE). + * @rmtoll DIER UIE LL_TIM_DisableIT_UPDATE + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_UPDATE(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_UIE); +} + +/** + * @brief Indicates whether the update interrupt (UIE) is enabled. + * @rmtoll DIER UIE LL_TIM_IsEnabledIT_UPDATE + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_UPDATE(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_UIE) == (TIM_DIER_UIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 1 interrupt (CC1IE). + * @rmtoll DIER CC1IE LL_TIM_EnableIT_CC1 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_CC1(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC1IE); +} + +/** + * @brief Disable capture/compare 1 interrupt (CC1IE). + * @rmtoll DIER CC1IE LL_TIM_DisableIT_CC1 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_CC1(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC1IE); +} + +/** + * @brief Indicates whether the capture/compare 1 interrupt (CC1IE) is enabled. + * @rmtoll DIER CC1IE LL_TIM_IsEnabledIT_CC1 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_CC1(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC1IE) == (TIM_DIER_CC1IE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 2 interrupt (CC2IE). + * @rmtoll DIER CC2IE LL_TIM_EnableIT_CC2 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_CC2(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC2IE); +} + +/** + * @brief Disable capture/compare 2 interrupt (CC2IE). + * @rmtoll DIER CC2IE LL_TIM_DisableIT_CC2 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_CC2(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC2IE); +} + +/** + * @brief Indicates whether the capture/compare 2 interrupt (CC2IE) is enabled. + * @rmtoll DIER CC2IE LL_TIM_IsEnabledIT_CC2 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_CC2(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC2IE) == (TIM_DIER_CC2IE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 3 interrupt (CC3IE). + * @rmtoll DIER CC3IE LL_TIM_EnableIT_CC3 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_CC3(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC3IE); +} + +/** + * @brief Disable capture/compare 3 interrupt (CC3IE). + * @rmtoll DIER CC3IE LL_TIM_DisableIT_CC3 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_CC3(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC3IE); +} + +/** + * @brief Indicates whether the capture/compare 3 interrupt (CC3IE) is enabled. + * @rmtoll DIER CC3IE LL_TIM_IsEnabledIT_CC3 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_CC3(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC3IE) == (TIM_DIER_CC3IE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 4 interrupt (CC4IE). + * @rmtoll DIER CC4IE LL_TIM_EnableIT_CC4 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_CC4(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC4IE); +} + +/** + * @brief Disable capture/compare 4 interrupt (CC4IE). + * @rmtoll DIER CC4IE LL_TIM_DisableIT_CC4 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_CC4(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC4IE); +} + +/** + * @brief Indicates whether the capture/compare 4 interrupt (CC4IE) is enabled. + * @rmtoll DIER CC4IE LL_TIM_IsEnabledIT_CC4 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_CC4(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC4IE) == (TIM_DIER_CC4IE)) ? 1UL : 0UL); +} + +/** + * @brief Enable commutation interrupt (COMIE). + * @rmtoll DIER COMIE LL_TIM_EnableIT_COM + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_COM(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_COMIE); +} + +/** + * @brief Disable commutation interrupt (COMIE). + * @rmtoll DIER COMIE LL_TIM_DisableIT_COM + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_COM(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_COMIE); +} + +/** + * @brief Indicates whether the commutation interrupt (COMIE) is enabled. + * @rmtoll DIER COMIE LL_TIM_IsEnabledIT_COM + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_COM(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_COMIE) == (TIM_DIER_COMIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable trigger interrupt (TIE). + * @rmtoll DIER TIE LL_TIM_EnableIT_TRIG + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_TRIG(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_TIE); +} + +/** + * @brief Disable trigger interrupt (TIE). + * @rmtoll DIER TIE LL_TIM_DisableIT_TRIG + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_TRIG(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_TIE); +} + +/** + * @brief Indicates whether the trigger interrupt (TIE) is enabled. + * @rmtoll DIER TIE LL_TIM_IsEnabledIT_TRIG + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_TRIG(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_TIE) == (TIM_DIER_TIE)) ? 1UL : 0UL); +} + +/** + * @brief Enable break interrupt (BIE). + * @rmtoll DIER BIE LL_TIM_EnableIT_BRK + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableIT_BRK(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_BIE); +} + +/** + * @brief Disable break interrupt (BIE). + * @rmtoll DIER BIE LL_TIM_DisableIT_BRK + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableIT_BRK(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_BIE); +} + +/** + * @brief Indicates whether the break interrupt (BIE) is enabled. + * @rmtoll DIER BIE LL_TIM_IsEnabledIT_BRK + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledIT_BRK(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_BIE) == (TIM_DIER_BIE)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_DMA_Management DMA Management + * @{ + */ +/** + * @brief Enable update DMA request (UDE). + * @rmtoll DIER UDE LL_TIM_EnableDMAReq_UPDATE + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableDMAReq_UPDATE(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_UDE); +} + +/** + * @brief Disable update DMA request (UDE). + * @rmtoll DIER UDE LL_TIM_DisableDMAReq_UPDATE + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableDMAReq_UPDATE(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_UDE); +} + +/** + * @brief Indicates whether the update DMA request (UDE) is enabled. + * @rmtoll DIER UDE LL_TIM_IsEnabledDMAReq_UPDATE + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledDMAReq_UPDATE(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_UDE) == (TIM_DIER_UDE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 1 DMA request (CC1DE). + * @rmtoll DIER CC1DE LL_TIM_EnableDMAReq_CC1 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableDMAReq_CC1(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC1DE); +} + +/** + * @brief Disable capture/compare 1 DMA request (CC1DE). + * @rmtoll DIER CC1DE LL_TIM_DisableDMAReq_CC1 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableDMAReq_CC1(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC1DE); +} + +/** + * @brief Indicates whether the capture/compare 1 DMA request (CC1DE) is enabled. + * @rmtoll DIER CC1DE LL_TIM_IsEnabledDMAReq_CC1 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledDMAReq_CC1(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC1DE) == (TIM_DIER_CC1DE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 2 DMA request (CC2DE). + * @rmtoll DIER CC2DE LL_TIM_EnableDMAReq_CC2 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableDMAReq_CC2(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC2DE); +} + +/** + * @brief Disable capture/compare 2 DMA request (CC2DE). + * @rmtoll DIER CC2DE LL_TIM_DisableDMAReq_CC2 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableDMAReq_CC2(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC2DE); +} + +/** + * @brief Indicates whether the capture/compare 2 DMA request (CC2DE) is enabled. + * @rmtoll DIER CC2DE LL_TIM_IsEnabledDMAReq_CC2 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledDMAReq_CC2(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC2DE) == (TIM_DIER_CC2DE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 3 DMA request (CC3DE). + * @rmtoll DIER CC3DE LL_TIM_EnableDMAReq_CC3 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableDMAReq_CC3(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC3DE); +} + +/** + * @brief Disable capture/compare 3 DMA request (CC3DE). + * @rmtoll DIER CC3DE LL_TIM_DisableDMAReq_CC3 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableDMAReq_CC3(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC3DE); +} + +/** + * @brief Indicates whether the capture/compare 3 DMA request (CC3DE) is enabled. + * @rmtoll DIER CC3DE LL_TIM_IsEnabledDMAReq_CC3 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledDMAReq_CC3(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC3DE) == (TIM_DIER_CC3DE)) ? 1UL : 0UL); +} + +/** + * @brief Enable capture/compare 4 DMA request (CC4DE). + * @rmtoll DIER CC4DE LL_TIM_EnableDMAReq_CC4 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableDMAReq_CC4(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_CC4DE); +} + +/** + * @brief Disable capture/compare 4 DMA request (CC4DE). + * @rmtoll DIER CC4DE LL_TIM_DisableDMAReq_CC4 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableDMAReq_CC4(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_CC4DE); +} + +/** + * @brief Indicates whether the capture/compare 4 DMA request (CC4DE) is enabled. + * @rmtoll DIER CC4DE LL_TIM_IsEnabledDMAReq_CC4 + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledDMAReq_CC4(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_CC4DE) == (TIM_DIER_CC4DE)) ? 1UL : 0UL); +} + +/** + * @brief Enable commutation DMA request (COMDE). + * @rmtoll DIER COMDE LL_TIM_EnableDMAReq_COM + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableDMAReq_COM(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_COMDE); +} + +/** + * @brief Disable commutation DMA request (COMDE). + * @rmtoll DIER COMDE LL_TIM_DisableDMAReq_COM + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableDMAReq_COM(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_COMDE); +} + +/** + * @brief Indicates whether the commutation DMA request (COMDE) is enabled. + * @rmtoll DIER COMDE LL_TIM_IsEnabledDMAReq_COM + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledDMAReq_COM(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_COMDE) == (TIM_DIER_COMDE)) ? 1UL : 0UL); +} + +/** + * @brief Enable trigger interrupt (TDE). + * @rmtoll DIER TDE LL_TIM_EnableDMAReq_TRIG + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_EnableDMAReq_TRIG(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->DIER, TIM_DIER_TDE); +} + +/** + * @brief Disable trigger interrupt (TDE). + * @rmtoll DIER TDE LL_TIM_DisableDMAReq_TRIG + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_DisableDMAReq_TRIG(TIM_TypeDef *TIMx) +{ + CLEAR_BIT(TIMx->DIER, TIM_DIER_TDE); +} + +/** + * @brief Indicates whether the trigger interrupt (TDE) is enabled. + * @rmtoll DIER TDE LL_TIM_IsEnabledDMAReq_TRIG + * @param TIMx Timer instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_TIM_IsEnabledDMAReq_TRIG(TIM_TypeDef *TIMx) +{ + return ((READ_BIT(TIMx->DIER, TIM_DIER_TDE) == (TIM_DIER_TDE)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** @defgroup TIM_LL_EF_EVENT_Management EVENT-Management + * @{ + */ +/** + * @brief Generate an update event. + * @rmtoll EGR UG LL_TIM_GenerateEvent_UPDATE + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_UPDATE(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_UG); +} + +/** + * @brief Generate Capture/Compare 1 event. + * @rmtoll EGR CC1G LL_TIM_GenerateEvent_CC1 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_CC1(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_CC1G); +} + +/** + * @brief Generate Capture/Compare 2 event. + * @rmtoll EGR CC2G LL_TIM_GenerateEvent_CC2 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_CC2(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_CC2G); +} + +/** + * @brief Generate Capture/Compare 3 event. + * @rmtoll EGR CC3G LL_TIM_GenerateEvent_CC3 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_CC3(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_CC3G); +} + +/** + * @brief Generate Capture/Compare 4 event. + * @rmtoll EGR CC4G LL_TIM_GenerateEvent_CC4 + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_CC4(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_CC4G); +} + +/** + * @brief Generate commutation event. + * @rmtoll EGR COMG LL_TIM_GenerateEvent_COM + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_COM(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_COMG); +} + +/** + * @brief Generate trigger event. + * @rmtoll EGR TG LL_TIM_GenerateEvent_TRIG + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_TRIG(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_TG); +} + +/** + * @brief Generate break event. + * @rmtoll EGR BG LL_TIM_GenerateEvent_BRK + * @param TIMx Timer instance + * @retval None + */ +__STATIC_INLINE void LL_TIM_GenerateEvent_BRK(TIM_TypeDef *TIMx) +{ + SET_BIT(TIMx->EGR, TIM_EGR_BG); +} + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup TIM_LL_EF_Init Initialisation and deinitialisation functions + * @{ + */ + +ErrorStatus LL_TIM_DeInit(TIM_TypeDef *TIMx); +void LL_TIM_StructInit(LL_TIM_InitTypeDef *TIM_InitStruct); +ErrorStatus LL_TIM_Init(TIM_TypeDef *TIMx, LL_TIM_InitTypeDef *TIM_InitStruct); +void LL_TIM_OC_StructInit(LL_TIM_OC_InitTypeDef *TIM_OC_InitStruct); +ErrorStatus LL_TIM_OC_Init(TIM_TypeDef *TIMx, uint32_t Channel, LL_TIM_OC_InitTypeDef *TIM_OC_InitStruct); +void LL_TIM_IC_StructInit(LL_TIM_IC_InitTypeDef *TIM_ICInitStruct); +ErrorStatus LL_TIM_IC_Init(TIM_TypeDef *TIMx, uint32_t Channel, LL_TIM_IC_InitTypeDef *TIM_IC_InitStruct); +void LL_TIM_ENCODER_StructInit(LL_TIM_ENCODER_InitTypeDef *TIM_EncoderInitStruct); +ErrorStatus LL_TIM_ENCODER_Init(TIM_TypeDef *TIMx, LL_TIM_ENCODER_InitTypeDef *TIM_EncoderInitStruct); +void LL_TIM_HALLSENSOR_StructInit(LL_TIM_HALLSENSOR_InitTypeDef *TIM_HallSensorInitStruct); +ErrorStatus LL_TIM_HALLSENSOR_Init(TIM_TypeDef *TIMx, LL_TIM_HALLSENSOR_InitTypeDef *TIM_HallSensorInitStruct); +void LL_TIM_BDTR_StructInit(LL_TIM_BDTR_InitTypeDef *TIM_BDTRInitStruct); +ErrorStatus LL_TIM_BDTR_Init(TIM_TypeDef *TIMx, LL_TIM_BDTR_InitTypeDef *TIM_BDTRInitStruct); +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* TIM1 || TIM2 || TIM3 || TIM14 || TIM15 || TIM16 || TIM17 || TIM6 || TIM7 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_TIM_H */ +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usart.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usart.h new file mode 100644 index 0000000..4e87edd --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usart.h @@ -0,0 +1,3840 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_usart.h + * @author MCD Application Team + * @brief Header file of USART LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_LL_USART_H +#define STM32F0xx_LL_USART_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (USART1) || defined (USART2) || defined (USART3) || defined (UART4) || defined (UART5) || defined (USART6) || defined (USART7) || defined (USART8) + +/** @defgroup USART_LL USART + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup USART_LL_Private_Macros USART Private Macros + * @{ + */ +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/* Exported types ------------------------------------------------------------*/ +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup USART_LL_ES_INIT USART Exported Init structures + * @{ + */ + +/** + * @brief LL USART Init Structure definition + */ +typedef struct +{ + + uint32_t BaudRate; /*!< This field defines expected Usart communication baud rate. + + This feature can be modified afterwards using unitary + function @ref LL_USART_SetBaudRate().*/ + + uint32_t DataWidth; /*!< Specifies the number of data bits transmitted or received in a frame. + This parameter can be a value of @ref USART_LL_EC_DATAWIDTH. + + This feature can be modified afterwards using unitary + function @ref LL_USART_SetDataWidth().*/ + + uint32_t StopBits; /*!< Specifies the number of stop bits transmitted. + This parameter can be a value of @ref USART_LL_EC_STOPBITS. + + This feature can be modified afterwards using unitary + function @ref LL_USART_SetStopBitsLength().*/ + + uint32_t Parity; /*!< Specifies the parity mode. + This parameter can be a value of @ref USART_LL_EC_PARITY. + + This feature can be modified afterwards using unitary + function @ref LL_USART_SetParity().*/ + + uint32_t TransferDirection; /*!< Specifies whether the Receive and/or Transmit mode is enabled or disabled. + This parameter can be a value of @ref USART_LL_EC_DIRECTION. + + This feature can be modified afterwards using unitary + function @ref LL_USART_SetTransferDirection().*/ + + uint32_t HardwareFlowControl; /*!< Specifies whether the hardware flow control mode is enabled or disabled. + This parameter can be a value of @ref USART_LL_EC_HWCONTROL. + + This feature can be modified afterwards using unitary + function @ref LL_USART_SetHWFlowCtrl().*/ + + uint32_t OverSampling; /*!< Specifies whether USART oversampling mode is 16 or 8. + This parameter can be a value of @ref USART_LL_EC_OVERSAMPLING. + + This feature can be modified afterwards using unitary + function @ref LL_USART_SetOverSampling().*/ + +} LL_USART_InitTypeDef; + +/** + * @brief LL USART Clock Init Structure definition + */ +typedef struct +{ + uint32_t ClockOutput; /*!< Specifies whether the USART clock is enabled or disabled. + This parameter can be a value of @ref USART_LL_EC_CLOCK. + + USART HW configuration can be modified afterwards using unitary functions + @ref LL_USART_EnableSCLKOutput() or @ref LL_USART_DisableSCLKOutput(). + For more details, refer to description of this function. */ + + uint32_t ClockPolarity; /*!< Specifies the steady state of the serial clock. + This parameter can be a value of @ref USART_LL_EC_POLARITY. + + USART HW configuration can be modified afterwards using unitary + functions @ref LL_USART_SetClockPolarity(). + For more details, refer to description of this function. */ + + uint32_t ClockPhase; /*!< Specifies the clock transition on which the bit capture is made. + This parameter can be a value of @ref USART_LL_EC_PHASE. + + USART HW configuration can be modified afterwards using unitary + functions @ref LL_USART_SetClockPhase(). + For more details, refer to description of this function. */ + + uint32_t LastBitClockPulse; /*!< Specifies whether the clock pulse corresponding to the last transmitted + data bit (MSB) has to be output on the SCLK pin in synchronous mode. + This parameter can be a value of @ref USART_LL_EC_LASTCLKPULSE. + + USART HW configuration can be modified afterwards using unitary + functions @ref LL_USART_SetLastClkPulseOutput(). + For more details, refer to description of this function. */ + +} LL_USART_ClockInitTypeDef; + +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup USART_LL_Exported_Constants USART Exported Constants + * @{ + */ + +/** @defgroup USART_LL_EC_CLEAR_FLAG Clear Flags Defines + * @brief Flags defines which can be used with LL_USART_WriteReg function + * @{ + */ +#define LL_USART_ICR_PECF USART_ICR_PECF /*!< Parity error clear flag */ +#define LL_USART_ICR_FECF USART_ICR_FECF /*!< Framing error clear flag */ +#define LL_USART_ICR_NCF USART_ICR_NCF /*!< Noise error detected clear flag */ +#define LL_USART_ICR_ORECF USART_ICR_ORECF /*!< Overrun error clear flag */ +#define LL_USART_ICR_IDLECF USART_ICR_IDLECF /*!< Idle line detected clear flag */ +#define LL_USART_ICR_TCCF USART_ICR_TCCF /*!< Transmission complete clear flag */ +#if defined USART_LIN_SUPPORT +#define LL_USART_ICR_LBDCF USART_ICR_LBDCF /*!< LIN break detection clear flag */ +#endif /* USART_LIN_SUPPORT */ +#define LL_USART_ICR_CTSCF USART_ICR_CTSCF /*!< CTS clear flag */ +#define LL_USART_ICR_RTOCF USART_ICR_RTOCF /*!< Receiver timeout clear flag */ +#if defined USART_SMARTCARD_SUPPORT +#define LL_USART_ICR_EOBCF USART_ICR_EOBCF /*!< End of block clear flag */ +#endif /* USART_SMARTCARD_SUPPORT */ +#define LL_USART_ICR_CMCF USART_ICR_CMCF /*!< Character match clear flag */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +#define LL_USART_ICR_WUCF USART_ICR_WUCF /*!< Wakeup from Stop mode clear flag */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_GET_FLAG Get Flags Defines + * @brief Flags defines which can be used with LL_USART_ReadReg function + * @{ + */ +#define LL_USART_ISR_PE USART_ISR_PE /*!< Parity error flag */ +#define LL_USART_ISR_FE USART_ISR_FE /*!< Framing error flag */ +#define LL_USART_ISR_NE USART_ISR_NE /*!< Noise detected flag */ +#define LL_USART_ISR_ORE USART_ISR_ORE /*!< Overrun error flag */ +#define LL_USART_ISR_IDLE USART_ISR_IDLE /*!< Idle line detected flag */ +#define LL_USART_ISR_RXNE USART_ISR_RXNE /*!< Read data register not empty flag */ +#define LL_USART_ISR_TC USART_ISR_TC /*!< Transmission complete flag */ +#define LL_USART_ISR_TXE USART_ISR_TXE /*!< Transmit data register empty flag */ +#if defined USART_LIN_SUPPORT +#define LL_USART_ISR_LBDF USART_ISR_LBDF /*!< LIN break detection flag */ +#endif /* USART_LIN_SUPPORT */ +#define LL_USART_ISR_CTSIF USART_ISR_CTSIF /*!< CTS interrupt flag */ +#define LL_USART_ISR_CTS USART_ISR_CTS /*!< CTS flag */ +#define LL_USART_ISR_RTOF USART_ISR_RTOF /*!< Receiver timeout flag */ +#if defined USART_SMARTCARD_SUPPORT +#define LL_USART_ISR_EOBF USART_ISR_EOBF /*!< End of block flag */ +#endif /* USART_SMARTCARD_SUPPORT */ +#define LL_USART_ISR_ABRE USART_ISR_ABRE /*!< Auto baud rate error flag */ +#define LL_USART_ISR_ABRF USART_ISR_ABRF /*!< Auto baud rate flag */ +#define LL_USART_ISR_BUSY USART_ISR_BUSY /*!< Busy flag */ +#define LL_USART_ISR_CMF USART_ISR_CMF /*!< Character match flag */ +#define LL_USART_ISR_SBKF USART_ISR_SBKF /*!< Send break flag */ +#define LL_USART_ISR_RWU USART_ISR_RWU /*!< Receiver wakeup from Mute mode flag */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +#define LL_USART_ISR_WUF USART_ISR_WUF /*!< Wakeup from Stop mode flag */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +#define LL_USART_ISR_TEACK USART_ISR_TEACK /*!< Transmit enable acknowledge flag */ +#define LL_USART_ISR_REACK USART_ISR_REACK /*!< Receive enable acknowledge flag */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_USART_ReadReg and LL_USART_WriteReg functions + * @{ + */ +#define LL_USART_CR1_IDLEIE USART_CR1_IDLEIE /*!< IDLE interrupt enable */ +#define LL_USART_CR1_RXNEIE USART_CR1_RXNEIE /*!< Read data register not empty interrupt enable */ +#define LL_USART_CR1_TCIE USART_CR1_TCIE /*!< Transmission complete interrupt enable */ +#define LL_USART_CR1_TXEIE USART_CR1_TXEIE /*!< Transmit data register empty interrupt enable */ +#define LL_USART_CR1_PEIE USART_CR1_PEIE /*!< Parity error */ +#define LL_USART_CR1_CMIE USART_CR1_CMIE /*!< Character match interrupt enable */ +#define LL_USART_CR1_RTOIE USART_CR1_RTOIE /*!< Receiver timeout interrupt enable */ +#if defined(USART_SMARTCARD_SUPPORT) +#define LL_USART_CR1_EOBIE USART_CR1_EOBIE /*!< End of Block interrupt enable */ +#endif /* USART_SMARTCARD_SUPPORT */ +#if defined(USART_LIN_SUPPORT) +#define LL_USART_CR2_LBDIE USART_CR2_LBDIE /*!< LIN break detection interrupt enable */ +#endif /* USART_LIN_SUPPORT */ +#define LL_USART_CR3_EIE USART_CR3_EIE /*!< Error interrupt enable */ +#define LL_USART_CR3_CTSIE USART_CR3_CTSIE /*!< CTS interrupt enable */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +#define LL_USART_CR3_WUFIE USART_CR3_WUFIE /*!< Wakeup from Stop mode interrupt enable */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_DIRECTION Communication Direction + * @{ + */ +#define LL_USART_DIRECTION_NONE 0x00000000U /*!< Transmitter and Receiver are disabled */ +#define LL_USART_DIRECTION_RX USART_CR1_RE /*!< Transmitter is disabled and Receiver is enabled */ +#define LL_USART_DIRECTION_TX USART_CR1_TE /*!< Transmitter is enabled and Receiver is disabled */ +#define LL_USART_DIRECTION_TX_RX (USART_CR1_TE |USART_CR1_RE) /*!< Transmitter and Receiver are enabled */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_PARITY Parity Control + * @{ + */ +#define LL_USART_PARITY_NONE 0x00000000U /*!< Parity control disabled */ +#define LL_USART_PARITY_EVEN USART_CR1_PCE /*!< Parity control enabled and Even Parity is selected */ +#define LL_USART_PARITY_ODD (USART_CR1_PCE | USART_CR1_PS) /*!< Parity control enabled and Odd Parity is selected */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_WAKEUP Wakeup + * @{ + */ +#define LL_USART_WAKEUP_IDLELINE 0x00000000U /*!< USART wake up from Mute mode on Idle Line */ +#define LL_USART_WAKEUP_ADDRESSMARK USART_CR1_WAKE /*!< USART wake up from Mute mode on Address Mark */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_DATAWIDTH Datawidth + * @{ + */ +#if defined(USART_7BITS_SUPPORT) +#define LL_USART_DATAWIDTH_7B USART_CR1_M1 /*!< 7 bits word length : Start bit, 7 data bits, n stop bits */ +#define LL_USART_DATAWIDTH_8B 0x00000000U /*!< 8 bits word length : Start bit, 8 data bits, n stop bits */ +#define LL_USART_DATAWIDTH_9B USART_CR1_M0 /*!< 9 bits word length : Start bit, 9 data bits, n stop bits */ +#else +#define LL_USART_DATAWIDTH_8B 0x00000000U /*!< 8 bits word length : Start bit, 8 data bits, n stop bits */ +#define LL_USART_DATAWIDTH_9B USART_CR1_M /*!< 9 bits word length : Start bit, 9 data bits, n stop bits */ +#endif/* USART_7BITS_SUPPORT */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_OVERSAMPLING Oversampling + * @{ + */ +#define LL_USART_OVERSAMPLING_16 0x00000000U /*!< Oversampling by 16 */ +#define LL_USART_OVERSAMPLING_8 USART_CR1_OVER8 /*!< Oversampling by 8 */ +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup USART_LL_EC_CLOCK Clock Signal + * @{ + */ + +#define LL_USART_CLOCK_DISABLE 0x00000000U /*!< Clock signal not provided */ +#define LL_USART_CLOCK_ENABLE USART_CR2_CLKEN /*!< Clock signal provided */ +/** + * @} + */ +#endif /*USE_FULL_LL_DRIVER*/ + +/** @defgroup USART_LL_EC_LASTCLKPULSE Last Clock Pulse + * @{ + */ +#define LL_USART_LASTCLKPULSE_NO_OUTPUT 0x00000000U /*!< The clock pulse of the last data bit is not output to the SCLK pin */ +#define LL_USART_LASTCLKPULSE_OUTPUT USART_CR2_LBCL /*!< The clock pulse of the last data bit is output to the SCLK pin */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_PHASE Clock Phase + * @{ + */ +#define LL_USART_PHASE_1EDGE 0x00000000U /*!< The first clock transition is the first data capture edge */ +#define LL_USART_PHASE_2EDGE USART_CR2_CPHA /*!< The second clock transition is the first data capture edge */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_POLARITY Clock Polarity + * @{ + */ +#define LL_USART_POLARITY_LOW 0x00000000U /*!< Steady low value on SCLK pin outside transmission window*/ +#define LL_USART_POLARITY_HIGH USART_CR2_CPOL /*!< Steady high value on SCLK pin outside transmission window */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_STOPBITS Stop Bits + * @{ + */ +#if defined(USART_SMARTCARD_SUPPORT) +#define LL_USART_STOPBITS_0_5 USART_CR2_STOP_0 /*!< 0.5 stop bit */ +#endif /* USART_SMARTCARD_SUPPORT */ +#define LL_USART_STOPBITS_1 0x00000000U /*!< 1 stop bit */ +#if defined(USART_SMARTCARD_SUPPORT) +#define LL_USART_STOPBITS_1_5 (USART_CR2_STOP_0 | USART_CR2_STOP_1) /*!< 1.5 stop bits */ +#endif /* USART_SMARTCARD_SUPPORT */ +#define LL_USART_STOPBITS_2 USART_CR2_STOP_1 /*!< 2 stop bits */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_TXRX TX RX Pins Swap + * @{ + */ +#define LL_USART_TXRX_STANDARD 0x00000000U /*!< TX/RX pins are used as defined in standard pinout */ +#define LL_USART_TXRX_SWAPPED (USART_CR2_SWAP) /*!< TX and RX pins functions are swapped. */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_RXPIN_LEVEL RX Pin Active Level Inversion + * @{ + */ +#define LL_USART_RXPIN_LEVEL_STANDARD 0x00000000U /*!< RX pin signal works using the standard logic levels */ +#define LL_USART_RXPIN_LEVEL_INVERTED (USART_CR2_RXINV) /*!< RX pin signal values are inverted. */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_TXPIN_LEVEL TX Pin Active Level Inversion + * @{ + */ +#define LL_USART_TXPIN_LEVEL_STANDARD 0x00000000U /*!< TX pin signal works using the standard logic levels */ +#define LL_USART_TXPIN_LEVEL_INVERTED (USART_CR2_TXINV) /*!< TX pin signal values are inverted. */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_BINARY_LOGIC Binary Data Inversion + * @{ + */ +#define LL_USART_BINARY_LOGIC_POSITIVE 0x00000000U /*!< Logical data from the data register are send/received in positive/direct logic. (1=H, 0=L) */ +#define LL_USART_BINARY_LOGIC_NEGATIVE USART_CR2_DATAINV /*!< Logical data from the data register are send/received in negative/inverse logic. (1=L, 0=H). The parity bit is also inverted. */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_BITORDER Bit Order + * @{ + */ +#define LL_USART_BITORDER_LSBFIRST 0x00000000U /*!< data is transmitted/received with data bit 0 first, following the start bit */ +#define LL_USART_BITORDER_MSBFIRST USART_CR2_MSBFIRST /*!< data is transmitted/received with the MSB first, following the start bit */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_AUTOBAUD_DETECT_ON Autobaud Detection + * @{ + */ +#define LL_USART_AUTOBAUD_DETECT_ON_STARTBIT 0x00000000U /*!< Measurement of the start bit is used to detect the baud rate */ +#define LL_USART_AUTOBAUD_DETECT_ON_FALLINGEDGE USART_CR2_ABRMODE_0 /*!< Falling edge to falling edge measurement. Received frame must start with a single bit = 1 -> Frame = Start10xxxxxx */ +#if defined(USART_FABR_SUPPORT) +#define LL_USART_AUTOBAUD_DETECT_ON_7F_FRAME USART_CR2_ABRMODE_1 /*!< 0x7F frame detection */ +#define LL_USART_AUTOBAUD_DETECT_ON_55_FRAME (USART_CR2_ABRMODE_1 | USART_CR2_ABRMODE_0) /*!< 0x55 frame detection */ +#endif /* USART_FABR_SUPPORT */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_ADDRESS_DETECT Address Length Detection + * @{ + */ +#define LL_USART_ADDRESS_DETECT_4B 0x00000000U /*!< 4-bit address detection method selected */ +#define LL_USART_ADDRESS_DETECT_7B USART_CR2_ADDM7 /*!< 7-bit address detection (in 8-bit data mode) method selected */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_HWCONTROL Hardware Control + * @{ + */ +#define LL_USART_HWCONTROL_NONE 0x00000000U /*!< CTS and RTS hardware flow control disabled */ +#define LL_USART_HWCONTROL_RTS USART_CR3_RTSE /*!< RTS output enabled, data is only requested when there is space in the receive buffer */ +#define LL_USART_HWCONTROL_CTS USART_CR3_CTSE /*!< CTS mode enabled, data is only transmitted when the nCTS input is asserted (tied to 0) */ +#define LL_USART_HWCONTROL_RTS_CTS (USART_CR3_RTSE | USART_CR3_CTSE) /*!< CTS and RTS hardware flow control enabled */ +/** + * @} + */ + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUS) +/** @defgroup USART_LL_EC_WAKEUP_ON Wakeup Activation + * @{ + */ +#define LL_USART_WAKEUP_ON_ADDRESS 0x00000000U /*!< Wake up active on address match */ +#define LL_USART_WAKEUP_ON_STARTBIT USART_CR3_WUS_1 /*!< Wake up active on Start bit detection */ +#define LL_USART_WAKEUP_ON_RXNE (USART_CR3_WUS_0 | USART_CR3_WUS_1) /*!< Wake up active on RXNE */ +/** + * @} + */ + +#endif /* USART_CR3_WUS */ +#endif /* USART_CR1_UESM */ +#if defined(USART_IRDA_SUPPORT) +/** @defgroup USART_LL_EC_IRDA_POWER IrDA Power + * @{ + */ +#define LL_USART_IRDA_POWER_NORMAL 0x00000000U /*!< IrDA normal power mode */ +#define LL_USART_IRDA_POWER_LOW USART_CR3_IRLP /*!< IrDA low power mode */ +/** + * @} + */ +#endif /* USART_IRDA_SUPPORT */ + +#if defined(USART_LIN_SUPPORT) +/** @defgroup USART_LL_EC_LINBREAK_DETECT LIN Break Detection Length + * @{ + */ +#define LL_USART_LINBREAK_DETECT_10B 0x00000000U /*!< 10-bit break detection method selected */ +#define LL_USART_LINBREAK_DETECT_11B USART_CR2_LBDL /*!< 11-bit break detection method selected */ +/** + * @} + */ +#endif /* USART_LIN_SUPPORT */ + +/** @defgroup USART_LL_EC_DE_POLARITY Driver Enable Polarity + * @{ + */ +#define LL_USART_DE_POLARITY_HIGH 0x00000000U /*!< DE signal is active high */ +#define LL_USART_DE_POLARITY_LOW USART_CR3_DEP /*!< DE signal is active low */ +/** + * @} + */ + +/** @defgroup USART_LL_EC_DMA_REG_DATA DMA Register Data + * @{ + */ +#define LL_USART_DMA_REG_DATA_TRANSMIT 0x00000000U /*!< Get address of data register used for transmission */ +#define LL_USART_DMA_REG_DATA_RECEIVE 0x00000001U /*!< Get address of data register used for reception */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup USART_LL_Exported_Macros USART Exported Macros + * @{ + */ + +/** @defgroup USART_LL_EM_WRITE_READ Common Write and read registers Macros + * @{ + */ + +/** + * @brief Write a value in USART register + * @param __INSTANCE__ USART Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_USART_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in USART register + * @param __INSTANCE__ USART Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_USART_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** @defgroup USART_LL_EM_Exported_Macros_Helper Exported_Macros_Helper + * @{ + */ + +/** + * @brief Compute USARTDIV value according to Peripheral Clock and + * expected Baud Rate in 8 bits sampling mode (32 bits value of USARTDIV is returned) + * @param __PERIPHCLK__ Peripheral Clock frequency used for USART instance + * @param __BAUDRATE__ Baud rate value to achieve + * @retval USARTDIV value to be used for BRR register filling in OverSampling_8 case + */ +#define __LL_USART_DIV_SAMPLING8(__PERIPHCLK__, __BAUDRATE__) ((((__PERIPHCLK__)*2U)\ + + ((__BAUDRATE__)/2U))/(__BAUDRATE__)) + +/** + * @brief Compute USARTDIV value according to Peripheral Clock and + * expected Baud Rate in 16 bits sampling mode (32 bits value of USARTDIV is returned) + * @param __PERIPHCLK__ Peripheral Clock frequency used for USART instance + * @param __BAUDRATE__ Baud rate value to achieve + * @retval USARTDIV value to be used for BRR register filling in OverSampling_16 case + */ +#define __LL_USART_DIV_SAMPLING16(__PERIPHCLK__, __BAUDRATE__) (((__PERIPHCLK__) + ((__BAUDRATE__)/2U))/(__BAUDRATE__)) + +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup USART_LL_Exported_Functions USART Exported Functions + * @{ + */ + +/** @defgroup USART_LL_EF_Configuration Configuration functions + * @{ + */ + +/** + * @brief USART Enable + * @rmtoll CR1 UE LL_USART_Enable + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_Enable(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR1, USART_CR1_UE); +} + +/** + * @brief USART Disable (all USART prescalers and outputs are disabled) + * @note When USART is disabled, USART prescalers and outputs are stopped immediately, + * and current operations are discarded. The configuration of the USART is kept, but all the status + * flags, in the USARTx_ISR are set to their default values. + * @rmtoll CR1 UE LL_USART_Disable + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_Disable(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR1, USART_CR1_UE); +} + +/** + * @brief Indicate if USART is enabled + * @rmtoll CR1 UE LL_USART_IsEnabled + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabled(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_UE) == (USART_CR1_UE)) ? 1UL : 0UL); +} + +#if defined(USART_CR1_UESM) +/** + * @brief USART enabled in STOP Mode. + * @note When this function is enabled, USART is able to wake up the MCU from Stop mode, provided that + * USART clock selection is HSI or LSE in RCC. + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR1 UESM LL_USART_EnableInStopMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableInStopMode(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_UESM); +} + +/** + * @brief USART disabled in STOP Mode. + * @note When this function is disabled, USART is not able to wake up the MCU from Stop mode + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR1 UESM LL_USART_DisableInStopMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableInStopMode(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_UESM); +} + +/** + * @brief Indicate if USART is enabled in STOP Mode (able to wake up MCU from Stop mode or not) + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR1 UESM LL_USART_IsEnabledInStopMode + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledInStopMode(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_UESM) == (USART_CR1_UESM)) ? 1UL : 0UL); +} + +#endif /* USART_CR1_UESM*/ +/** + * @brief Receiver Enable (Receiver is enabled and begins searching for a start bit) + * @rmtoll CR1 RE LL_USART_EnableDirectionRx + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableDirectionRx(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_RE); +} + +/** + * @brief Receiver Disable + * @rmtoll CR1 RE LL_USART_DisableDirectionRx + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableDirectionRx(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_RE); +} + +/** + * @brief Transmitter Enable + * @rmtoll CR1 TE LL_USART_EnableDirectionTx + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableDirectionTx(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_TE); +} + +/** + * @brief Transmitter Disable + * @rmtoll CR1 TE LL_USART_DisableDirectionTx + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableDirectionTx(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_TE); +} + +/** + * @brief Configure simultaneously enabled/disabled states + * of Transmitter and Receiver + * @rmtoll CR1 RE LL_USART_SetTransferDirection\n + * CR1 TE LL_USART_SetTransferDirection + * @param USARTx USART Instance + * @param TransferDirection This parameter can be one of the following values: + * @arg @ref LL_USART_DIRECTION_NONE + * @arg @ref LL_USART_DIRECTION_RX + * @arg @ref LL_USART_DIRECTION_TX + * @arg @ref LL_USART_DIRECTION_TX_RX + * @retval None + */ +__STATIC_INLINE void LL_USART_SetTransferDirection(USART_TypeDef *USARTx, uint32_t TransferDirection) +{ + ATOMIC_MODIFY_REG(USARTx->CR1, USART_CR1_RE | USART_CR1_TE, TransferDirection); +} + +/** + * @brief Return enabled/disabled states of Transmitter and Receiver + * @rmtoll CR1 RE LL_USART_GetTransferDirection\n + * CR1 TE LL_USART_GetTransferDirection + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_DIRECTION_NONE + * @arg @ref LL_USART_DIRECTION_RX + * @arg @ref LL_USART_DIRECTION_TX + * @arg @ref LL_USART_DIRECTION_TX_RX + */ +__STATIC_INLINE uint32_t LL_USART_GetTransferDirection(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR1, USART_CR1_RE | USART_CR1_TE)); +} + +/** + * @brief Configure Parity (enabled/disabled and parity mode if enabled). + * @note This function selects if hardware parity control (generation and detection) is enabled or disabled. + * When the parity control is enabled (Odd or Even), computed parity bit is inserted at the MSB position + * (9th or 8th bit depending on data width) and parity is checked on the received data. + * @rmtoll CR1 PS LL_USART_SetParity\n + * CR1 PCE LL_USART_SetParity + * @param USARTx USART Instance + * @param Parity This parameter can be one of the following values: + * @arg @ref LL_USART_PARITY_NONE + * @arg @ref LL_USART_PARITY_EVEN + * @arg @ref LL_USART_PARITY_ODD + * @retval None + */ +__STATIC_INLINE void LL_USART_SetParity(USART_TypeDef *USARTx, uint32_t Parity) +{ + MODIFY_REG(USARTx->CR1, USART_CR1_PS | USART_CR1_PCE, Parity); +} + +/** + * @brief Return Parity configuration (enabled/disabled and parity mode if enabled) + * @rmtoll CR1 PS LL_USART_GetParity\n + * CR1 PCE LL_USART_GetParity + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_PARITY_NONE + * @arg @ref LL_USART_PARITY_EVEN + * @arg @ref LL_USART_PARITY_ODD + */ +__STATIC_INLINE uint32_t LL_USART_GetParity(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR1, USART_CR1_PS | USART_CR1_PCE)); +} + +/** + * @brief Set Receiver Wake Up method from Mute mode. + * @rmtoll CR1 WAKE LL_USART_SetWakeUpMethod + * @param USARTx USART Instance + * @param Method This parameter can be one of the following values: + * @arg @ref LL_USART_WAKEUP_IDLELINE + * @arg @ref LL_USART_WAKEUP_ADDRESSMARK + * @retval None + */ +__STATIC_INLINE void LL_USART_SetWakeUpMethod(USART_TypeDef *USARTx, uint32_t Method) +{ + MODIFY_REG(USARTx->CR1, USART_CR1_WAKE, Method); +} + +/** + * @brief Return Receiver Wake Up method from Mute mode + * @rmtoll CR1 WAKE LL_USART_GetWakeUpMethod + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_WAKEUP_IDLELINE + * @arg @ref LL_USART_WAKEUP_ADDRESSMARK + */ +__STATIC_INLINE uint32_t LL_USART_GetWakeUpMethod(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR1, USART_CR1_WAKE)); +} + +/** + * @brief Set Word length (i.e. nb of data bits, excluding start and stop bits) + * @rmtoll CR1 M0 LL_USART_SetDataWidth\n + * CR1 M1 LL_USART_SetDataWidth + * @param USARTx USART Instance + * @param DataWidth This parameter can be one of the following values: + * @arg @ref LL_USART_DATAWIDTH_7B (*) + * @arg @ref LL_USART_DATAWIDTH_8B + * @arg @ref LL_USART_DATAWIDTH_9B + * + * (*) Values not available on all devices + * @retval None + */ +__STATIC_INLINE void LL_USART_SetDataWidth(USART_TypeDef *USARTx, uint32_t DataWidth) +{ + MODIFY_REG(USARTx->CR1, USART_CR1_M, DataWidth); +} + +/** + * @brief Return Word length (i.e. nb of data bits, excluding start and stop bits) + * @rmtoll CR1 M0 LL_USART_GetDataWidth\n + * CR1 M1 LL_USART_GetDataWidth + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_DATAWIDTH_7B (*) + * @arg @ref LL_USART_DATAWIDTH_8B + * @arg @ref LL_USART_DATAWIDTH_9B + * + * (*) Values not available on all devices + */ +__STATIC_INLINE uint32_t LL_USART_GetDataWidth(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR1, USART_CR1_M)); +} + +/** + * @brief Allow switch between Mute Mode and Active mode + * @rmtoll CR1 MME LL_USART_EnableMuteMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableMuteMode(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_MME); +} + +/** + * @brief Prevent Mute Mode use. Set Receiver in active mode permanently. + * @rmtoll CR1 MME LL_USART_DisableMuteMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableMuteMode(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_MME); +} + +/** + * @brief Indicate if switch between Mute Mode and Active mode is allowed + * @rmtoll CR1 MME LL_USART_IsEnabledMuteMode + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledMuteMode(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_MME) == (USART_CR1_MME)) ? 1UL : 0UL); +} + +/** + * @brief Set Oversampling to 8-bit or 16-bit mode + * @rmtoll CR1 OVER8 LL_USART_SetOverSampling + * @param USARTx USART Instance + * @param OverSampling This parameter can be one of the following values: + * @arg @ref LL_USART_OVERSAMPLING_16 + * @arg @ref LL_USART_OVERSAMPLING_8 + * @retval None + */ +__STATIC_INLINE void LL_USART_SetOverSampling(USART_TypeDef *USARTx, uint32_t OverSampling) +{ + MODIFY_REG(USARTx->CR1, USART_CR1_OVER8, OverSampling); +} + +/** + * @brief Return Oversampling mode + * @rmtoll CR1 OVER8 LL_USART_GetOverSampling + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_OVERSAMPLING_16 + * @arg @ref LL_USART_OVERSAMPLING_8 + */ +__STATIC_INLINE uint32_t LL_USART_GetOverSampling(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR1, USART_CR1_OVER8)); +} + +/** + * @brief Configure if Clock pulse of the last data bit is output to the SCLK pin or not + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 LBCL LL_USART_SetLastClkPulseOutput + * @param USARTx USART Instance + * @param LastBitClockPulse This parameter can be one of the following values: + * @arg @ref LL_USART_LASTCLKPULSE_NO_OUTPUT + * @arg @ref LL_USART_LASTCLKPULSE_OUTPUT + * @retval None + */ +__STATIC_INLINE void LL_USART_SetLastClkPulseOutput(USART_TypeDef *USARTx, uint32_t LastBitClockPulse) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_LBCL, LastBitClockPulse); +} + +/** + * @brief Retrieve Clock pulse of the last data bit output configuration + * (Last bit Clock pulse output to the SCLK pin or not) + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 LBCL LL_USART_GetLastClkPulseOutput + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_LASTCLKPULSE_NO_OUTPUT + * @arg @ref LL_USART_LASTCLKPULSE_OUTPUT + */ +__STATIC_INLINE uint32_t LL_USART_GetLastClkPulseOutput(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_LBCL)); +} + +/** + * @brief Select the phase of the clock output on the SCLK pin in synchronous mode + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 CPHA LL_USART_SetClockPhase + * @param USARTx USART Instance + * @param ClockPhase This parameter can be one of the following values: + * @arg @ref LL_USART_PHASE_1EDGE + * @arg @ref LL_USART_PHASE_2EDGE + * @retval None + */ +__STATIC_INLINE void LL_USART_SetClockPhase(USART_TypeDef *USARTx, uint32_t ClockPhase) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_CPHA, ClockPhase); +} + +/** + * @brief Return phase of the clock output on the SCLK pin in synchronous mode + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 CPHA LL_USART_GetClockPhase + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_PHASE_1EDGE + * @arg @ref LL_USART_PHASE_2EDGE + */ +__STATIC_INLINE uint32_t LL_USART_GetClockPhase(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_CPHA)); +} + +/** + * @brief Select the polarity of the clock output on the SCLK pin in synchronous mode + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 CPOL LL_USART_SetClockPolarity + * @param USARTx USART Instance + * @param ClockPolarity This parameter can be one of the following values: + * @arg @ref LL_USART_POLARITY_LOW + * @arg @ref LL_USART_POLARITY_HIGH + * @retval None + */ +__STATIC_INLINE void LL_USART_SetClockPolarity(USART_TypeDef *USARTx, uint32_t ClockPolarity) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_CPOL, ClockPolarity); +} + +/** + * @brief Return polarity of the clock output on the SCLK pin in synchronous mode + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 CPOL LL_USART_GetClockPolarity + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_POLARITY_LOW + * @arg @ref LL_USART_POLARITY_HIGH + */ +__STATIC_INLINE uint32_t LL_USART_GetClockPolarity(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_CPOL)); +} + +/** + * @brief Configure Clock signal format (Phase Polarity and choice about output of last bit clock pulse) + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @note Call of this function is equivalent to following function call sequence : + * - Clock Phase configuration using @ref LL_USART_SetClockPhase() function + * - Clock Polarity configuration using @ref LL_USART_SetClockPolarity() function + * - Output of Last bit Clock pulse configuration using @ref LL_USART_SetLastClkPulseOutput() function + * @rmtoll CR2 CPHA LL_USART_ConfigClock\n + * CR2 CPOL LL_USART_ConfigClock\n + * CR2 LBCL LL_USART_ConfigClock + * @param USARTx USART Instance + * @param Phase This parameter can be one of the following values: + * @arg @ref LL_USART_PHASE_1EDGE + * @arg @ref LL_USART_PHASE_2EDGE + * @param Polarity This parameter can be one of the following values: + * @arg @ref LL_USART_POLARITY_LOW + * @arg @ref LL_USART_POLARITY_HIGH + * @param LBCPOutput This parameter can be one of the following values: + * @arg @ref LL_USART_LASTCLKPULSE_NO_OUTPUT + * @arg @ref LL_USART_LASTCLKPULSE_OUTPUT + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigClock(USART_TypeDef *USARTx, uint32_t Phase, uint32_t Polarity, uint32_t LBCPOutput) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_CPHA | USART_CR2_CPOL | USART_CR2_LBCL, Phase | Polarity | LBCPOutput); +} + +/** + * @brief Enable Clock output on SCLK pin + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 CLKEN LL_USART_EnableSCLKOutput + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableSCLKOutput(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR2, USART_CR2_CLKEN); +} + +/** + * @brief Disable Clock output on SCLK pin + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 CLKEN LL_USART_DisableSCLKOutput + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableSCLKOutput(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR2, USART_CR2_CLKEN); +} + +/** + * @brief Indicate if Clock output on SCLK pin is enabled + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @rmtoll CR2 CLKEN LL_USART_IsEnabledSCLKOutput + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledSCLKOutput(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR2, USART_CR2_CLKEN) == (USART_CR2_CLKEN)) ? 1UL : 0UL); +} + +/** + * @brief Set the length of the stop bits + * @rmtoll CR2 STOP LL_USART_SetStopBitsLength + * @param USARTx USART Instance + * @param StopBits This parameter can be one of the following values: + * @arg @ref LL_USART_STOPBITS_0_5 (*) + * @arg @ref LL_USART_STOPBITS_1 + * @arg @ref LL_USART_STOPBITS_1_5 (*) + * @arg @ref LL_USART_STOPBITS_2 + * + * (*) Values not available on all devices + * @retval None + */ +__STATIC_INLINE void LL_USART_SetStopBitsLength(USART_TypeDef *USARTx, uint32_t StopBits) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_STOP, StopBits); +} + +/** + * @brief Retrieve the length of the stop bits + * @rmtoll CR2 STOP LL_USART_GetStopBitsLength + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_STOPBITS_0_5 (*) + * @arg @ref LL_USART_STOPBITS_1 + * @arg @ref LL_USART_STOPBITS_1_5 (*) + * @arg @ref LL_USART_STOPBITS_2 + * + * (*) Values not available on all devices + */ +__STATIC_INLINE uint32_t LL_USART_GetStopBitsLength(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_STOP)); +} + +/** + * @brief Configure Character frame format (Datawidth, Parity control, Stop Bits) + * @note Call of this function is equivalent to following function call sequence : + * - Data Width configuration using @ref LL_USART_SetDataWidth() function + * - Parity Control and mode configuration using @ref LL_USART_SetParity() function + * - Stop bits configuration using @ref LL_USART_SetStopBitsLength() function + * @rmtoll CR1 PS LL_USART_ConfigCharacter\n + * CR1 PCE LL_USART_ConfigCharacter\n + * CR1 M0 LL_USART_ConfigCharacter\n + * CR1 M1 LL_USART_ConfigCharacter\n + * CR2 STOP LL_USART_ConfigCharacter + * @param USARTx USART Instance + * @param DataWidth This parameter can be one of the following values: + * @arg @ref LL_USART_DATAWIDTH_7B (*) + * @arg @ref LL_USART_DATAWIDTH_8B + * @arg @ref LL_USART_DATAWIDTH_9B + * @param Parity This parameter can be one of the following values: + * @arg @ref LL_USART_PARITY_NONE + * @arg @ref LL_USART_PARITY_EVEN + * @arg @ref LL_USART_PARITY_ODD + * @param StopBits This parameter can be one of the following values: + * @arg @ref LL_USART_STOPBITS_0_5 (*) + * @arg @ref LL_USART_STOPBITS_1 + * @arg @ref LL_USART_STOPBITS_1_5 (*) + * @arg @ref LL_USART_STOPBITS_2 + * + * (*) Values not available on all devices + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigCharacter(USART_TypeDef *USARTx, uint32_t DataWidth, uint32_t Parity, + uint32_t StopBits) +{ + MODIFY_REG(USARTx->CR1, USART_CR1_PS | USART_CR1_PCE | USART_CR1_M, Parity | DataWidth); + MODIFY_REG(USARTx->CR2, USART_CR2_STOP, StopBits); +} + +/** + * @brief Configure TX/RX pins swapping setting. + * @rmtoll CR2 SWAP LL_USART_SetTXRXSwap + * @param USARTx USART Instance + * @param SwapConfig This parameter can be one of the following values: + * @arg @ref LL_USART_TXRX_STANDARD + * @arg @ref LL_USART_TXRX_SWAPPED + * @retval None + */ +__STATIC_INLINE void LL_USART_SetTXRXSwap(USART_TypeDef *USARTx, uint32_t SwapConfig) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_SWAP, SwapConfig); +} + +/** + * @brief Retrieve TX/RX pins swapping configuration. + * @rmtoll CR2 SWAP LL_USART_GetTXRXSwap + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_TXRX_STANDARD + * @arg @ref LL_USART_TXRX_SWAPPED + */ +__STATIC_INLINE uint32_t LL_USART_GetTXRXSwap(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_SWAP)); +} + +/** + * @brief Configure RX pin active level logic + * @rmtoll CR2 RXINV LL_USART_SetRXPinLevel + * @param USARTx USART Instance + * @param PinInvMethod This parameter can be one of the following values: + * @arg @ref LL_USART_RXPIN_LEVEL_STANDARD + * @arg @ref LL_USART_RXPIN_LEVEL_INVERTED + * @retval None + */ +__STATIC_INLINE void LL_USART_SetRXPinLevel(USART_TypeDef *USARTx, uint32_t PinInvMethod) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_RXINV, PinInvMethod); +} + +/** + * @brief Retrieve RX pin active level logic configuration + * @rmtoll CR2 RXINV LL_USART_GetRXPinLevel + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_RXPIN_LEVEL_STANDARD + * @arg @ref LL_USART_RXPIN_LEVEL_INVERTED + */ +__STATIC_INLINE uint32_t LL_USART_GetRXPinLevel(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_RXINV)); +} + +/** + * @brief Configure TX pin active level logic + * @rmtoll CR2 TXINV LL_USART_SetTXPinLevel + * @param USARTx USART Instance + * @param PinInvMethod This parameter can be one of the following values: + * @arg @ref LL_USART_TXPIN_LEVEL_STANDARD + * @arg @ref LL_USART_TXPIN_LEVEL_INVERTED + * @retval None + */ +__STATIC_INLINE void LL_USART_SetTXPinLevel(USART_TypeDef *USARTx, uint32_t PinInvMethod) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_TXINV, PinInvMethod); +} + +/** + * @brief Retrieve TX pin active level logic configuration + * @rmtoll CR2 TXINV LL_USART_GetTXPinLevel + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_TXPIN_LEVEL_STANDARD + * @arg @ref LL_USART_TXPIN_LEVEL_INVERTED + */ +__STATIC_INLINE uint32_t LL_USART_GetTXPinLevel(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_TXINV)); +} + +/** + * @brief Configure Binary data logic. + * @note Allow to define how Logical data from the data register are send/received : + * either in positive/direct logic (1=H, 0=L) or in negative/inverse logic (1=L, 0=H) + * @rmtoll CR2 DATAINV LL_USART_SetBinaryDataLogic + * @param USARTx USART Instance + * @param DataLogic This parameter can be one of the following values: + * @arg @ref LL_USART_BINARY_LOGIC_POSITIVE + * @arg @ref LL_USART_BINARY_LOGIC_NEGATIVE + * @retval None + */ +__STATIC_INLINE void LL_USART_SetBinaryDataLogic(USART_TypeDef *USARTx, uint32_t DataLogic) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_DATAINV, DataLogic); +} + +/** + * @brief Retrieve Binary data configuration + * @rmtoll CR2 DATAINV LL_USART_GetBinaryDataLogic + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_BINARY_LOGIC_POSITIVE + * @arg @ref LL_USART_BINARY_LOGIC_NEGATIVE + */ +__STATIC_INLINE uint32_t LL_USART_GetBinaryDataLogic(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_DATAINV)); +} + +/** + * @brief Configure transfer bit order (either Less or Most Significant Bit First) + * @note MSB First means data is transmitted/received with the MSB first, following the start bit. + * LSB First means data is transmitted/received with data bit 0 first, following the start bit. + * @rmtoll CR2 MSBFIRST LL_USART_SetTransferBitOrder + * @param USARTx USART Instance + * @param BitOrder This parameter can be one of the following values: + * @arg @ref LL_USART_BITORDER_LSBFIRST + * @arg @ref LL_USART_BITORDER_MSBFIRST + * @retval None + */ +__STATIC_INLINE void LL_USART_SetTransferBitOrder(USART_TypeDef *USARTx, uint32_t BitOrder) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_MSBFIRST, BitOrder); +} + +/** + * @brief Return transfer bit order (either Less or Most Significant Bit First) + * @note MSB First means data is transmitted/received with the MSB first, following the start bit. + * LSB First means data is transmitted/received with data bit 0 first, following the start bit. + * @rmtoll CR2 MSBFIRST LL_USART_GetTransferBitOrder + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_BITORDER_LSBFIRST + * @arg @ref LL_USART_BITORDER_MSBFIRST + */ +__STATIC_INLINE uint32_t LL_USART_GetTransferBitOrder(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_MSBFIRST)); +} + +/** + * @brief Enable Auto Baud-Rate Detection + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll CR2 ABREN LL_USART_EnableAutoBaudRate + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableAutoBaudRate(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR2, USART_CR2_ABREN); +} + +/** + * @brief Disable Auto Baud-Rate Detection + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll CR2 ABREN LL_USART_DisableAutoBaudRate + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableAutoBaudRate(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR2, USART_CR2_ABREN); +} + +/** + * @brief Indicate if Auto Baud-Rate Detection mechanism is enabled + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll CR2 ABREN LL_USART_IsEnabledAutoBaud + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledAutoBaud(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR2, USART_CR2_ABREN) == (USART_CR2_ABREN)) ? 1UL : 0UL); +} + +/** + * @brief Set Auto Baud-Rate mode bits + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll CR2 ABRMODE LL_USART_SetAutoBaudRateMode + * @param USARTx USART Instance + * @param AutoBaudRateMode This parameter can be one of the following values: + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_STARTBIT + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_FALLINGEDGE + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_7F_FRAME (*) + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_55_FRAME (*) + * + * (*) Values not available on all devices + * @retval None + */ +__STATIC_INLINE void LL_USART_SetAutoBaudRateMode(USART_TypeDef *USARTx, uint32_t AutoBaudRateMode) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_ABRMODE, AutoBaudRateMode); +} + +/** + * @brief Return Auto Baud-Rate mode + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll CR2 ABRMODE LL_USART_GetAutoBaudRateMode + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_STARTBIT + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_FALLINGEDGE + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_7F_FRAME (*) + * @arg @ref LL_USART_AUTOBAUD_DETECT_ON_55_FRAME (*) + * + * (*) Values not available on all devices + */ +__STATIC_INLINE uint32_t LL_USART_GetAutoBaudRateMode(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_ABRMODE)); +} + +/** + * @brief Enable Receiver Timeout + * @rmtoll CR2 RTOEN LL_USART_EnableRxTimeout + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableRxTimeout(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR2, USART_CR2_RTOEN); +} + +/** + * @brief Disable Receiver Timeout + * @rmtoll CR2 RTOEN LL_USART_DisableRxTimeout + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableRxTimeout(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR2, USART_CR2_RTOEN); +} + +/** + * @brief Indicate if Receiver Timeout feature is enabled + * @rmtoll CR2 RTOEN LL_USART_IsEnabledRxTimeout + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledRxTimeout(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR2, USART_CR2_RTOEN) == (USART_CR2_RTOEN)) ? 1UL : 0UL); +} + +/** + * @brief Set Address of the USART node. + * @note This is used in multiprocessor communication during Mute mode or Stop mode, + * for wake up with address mark detection. + * @note 4bits address node is used when 4-bit Address Detection is selected in ADDM7. + * (b7-b4 should be set to 0) + * 8bits address node is used when 7-bit Address Detection is selected in ADDM7. + * (This is used in multiprocessor communication during Mute mode or Stop mode, + * for wake up with 7-bit address mark detection. + * The MSB of the character sent by the transmitter should be equal to 1. + * It may also be used for character detection during normal reception, + * Mute mode inactive (for example, end of block detection in ModBus protocol). + * In this case, the whole received character (8-bit) is compared to the ADD[7:0] + * value and CMF flag is set on match) + * @rmtoll CR2 ADD LL_USART_ConfigNodeAddress\n + * CR2 ADDM7 LL_USART_ConfigNodeAddress + * @param USARTx USART Instance + * @param AddressLen This parameter can be one of the following values: + * @arg @ref LL_USART_ADDRESS_DETECT_4B + * @arg @ref LL_USART_ADDRESS_DETECT_7B + * @param NodeAddress 4 or 7 bit Address of the USART node. + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigNodeAddress(USART_TypeDef *USARTx, uint32_t AddressLen, uint32_t NodeAddress) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_ADD | USART_CR2_ADDM7, + (uint32_t)(AddressLen | (NodeAddress << USART_CR2_ADD_Pos))); +} + +/** + * @brief Return 8 bit Address of the USART node as set in ADD field of CR2. + * @note If 4-bit Address Detection is selected in ADDM7, + * only 4bits (b3-b0) of returned value are relevant (b31-b4 are not relevant) + * If 7-bit Address Detection is selected in ADDM7, + * only 8bits (b7-b0) of returned value are relevant (b31-b8 are not relevant) + * @rmtoll CR2 ADD LL_USART_GetNodeAddress + * @param USARTx USART Instance + * @retval Address of the USART node (Value between Min_Data=0 and Max_Data=255) + */ +__STATIC_INLINE uint32_t LL_USART_GetNodeAddress(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_ADD) >> USART_CR2_ADD_Pos); +} + +/** + * @brief Return Length of Node Address used in Address Detection mode (7-bit or 4-bit) + * @rmtoll CR2 ADDM7 LL_USART_GetNodeAddressLen + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_ADDRESS_DETECT_4B + * @arg @ref LL_USART_ADDRESS_DETECT_7B + */ +__STATIC_INLINE uint32_t LL_USART_GetNodeAddressLen(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_ADDM7)); +} + +/** + * @brief Enable RTS HW Flow Control + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 RTSE LL_USART_EnableRTSHWFlowCtrl + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableRTSHWFlowCtrl(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_RTSE); +} + +/** + * @brief Disable RTS HW Flow Control + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 RTSE LL_USART_DisableRTSHWFlowCtrl + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableRTSHWFlowCtrl(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_RTSE); +} + +/** + * @brief Enable CTS HW Flow Control + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 CTSE LL_USART_EnableCTSHWFlowCtrl + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableCTSHWFlowCtrl(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_CTSE); +} + +/** + * @brief Disable CTS HW Flow Control + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 CTSE LL_USART_DisableCTSHWFlowCtrl + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableCTSHWFlowCtrl(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_CTSE); +} + +/** + * @brief Configure HW Flow Control mode (both CTS and RTS) + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 RTSE LL_USART_SetHWFlowCtrl\n + * CR3 CTSE LL_USART_SetHWFlowCtrl + * @param USARTx USART Instance + * @param HardwareFlowControl This parameter can be one of the following values: + * @arg @ref LL_USART_HWCONTROL_NONE + * @arg @ref LL_USART_HWCONTROL_RTS + * @arg @ref LL_USART_HWCONTROL_CTS + * @arg @ref LL_USART_HWCONTROL_RTS_CTS + * @retval None + */ +__STATIC_INLINE void LL_USART_SetHWFlowCtrl(USART_TypeDef *USARTx, uint32_t HardwareFlowControl) +{ + MODIFY_REG(USARTx->CR3, USART_CR3_RTSE | USART_CR3_CTSE, HardwareFlowControl); +} + +/** + * @brief Return HW Flow Control configuration (both CTS and RTS) + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 RTSE LL_USART_GetHWFlowCtrl\n + * CR3 CTSE LL_USART_GetHWFlowCtrl + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_HWCONTROL_NONE + * @arg @ref LL_USART_HWCONTROL_RTS + * @arg @ref LL_USART_HWCONTROL_CTS + * @arg @ref LL_USART_HWCONTROL_RTS_CTS + */ +__STATIC_INLINE uint32_t LL_USART_GetHWFlowCtrl(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR3, USART_CR3_RTSE | USART_CR3_CTSE)); +} + +/** + * @brief Enable One bit sampling method + * @rmtoll CR3 ONEBIT LL_USART_EnableOneBitSamp + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableOneBitSamp(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_ONEBIT); +} + +/** + * @brief Disable One bit sampling method + * @rmtoll CR3 ONEBIT LL_USART_DisableOneBitSamp + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableOneBitSamp(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_ONEBIT); +} + +/** + * @brief Indicate if One bit sampling method is enabled + * @rmtoll CR3 ONEBIT LL_USART_IsEnabledOneBitSamp + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledOneBitSamp(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_ONEBIT) == (USART_CR3_ONEBIT)) ? 1UL : 0UL); +} + +/** + * @brief Enable Overrun detection + * @rmtoll CR3 OVRDIS LL_USART_EnableOverrunDetect + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableOverrunDetect(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_OVRDIS); +} + +/** + * @brief Disable Overrun detection + * @rmtoll CR3 OVRDIS LL_USART_DisableOverrunDetect + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableOverrunDetect(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_OVRDIS); +} + +/** + * @brief Indicate if Overrun detection is enabled + * @rmtoll CR3 OVRDIS LL_USART_IsEnabledOverrunDetect + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledOverrunDetect(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_OVRDIS) != USART_CR3_OVRDIS) ? 1UL : 0UL); +} + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUS) +/** + * @brief Select event type for Wake UP Interrupt Flag (WUS[1:0] bits) + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR3 WUS LL_USART_SetWKUPType + * @param USARTx USART Instance + * @param Type This parameter can be one of the following values: + * @arg @ref LL_USART_WAKEUP_ON_ADDRESS + * @arg @ref LL_USART_WAKEUP_ON_STARTBIT + * @arg @ref LL_USART_WAKEUP_ON_RXNE + * @retval None + */ +__STATIC_INLINE void LL_USART_SetWKUPType(USART_TypeDef *USARTx, uint32_t Type) +{ + MODIFY_REG(USARTx->CR3, USART_CR3_WUS, Type); +} + +/** + * @brief Return event type for Wake UP Interrupt Flag (WUS[1:0] bits) + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR3 WUS LL_USART_GetWKUPType + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_WAKEUP_ON_ADDRESS + * @arg @ref LL_USART_WAKEUP_ON_STARTBIT + * @arg @ref LL_USART_WAKEUP_ON_RXNE + */ +__STATIC_INLINE uint32_t LL_USART_GetWKUPType(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR3, USART_CR3_WUS)); +} + +#endif /* USART_CR3_WUS */ +#endif /* USART_CR1_UESM */ +/** + * @brief Configure USART BRR register for achieving expected Baud Rate value. + * @note Compute and set USARTDIV value in BRR Register (full BRR content) + * according to used Peripheral Clock, Oversampling mode, and expected Baud Rate values + * @note Peripheral clock and Baud rate values provided as function parameters should be valid + * (Baud rate value != 0) + * @note In case of oversampling by 16 and 8, BRR content must be greater than or equal to 16d. + * @rmtoll BRR BRR LL_USART_SetBaudRate + * @param USARTx USART Instance + * @param PeriphClk Peripheral Clock + * @param OverSampling This parameter can be one of the following values: + * @arg @ref LL_USART_OVERSAMPLING_16 + * @arg @ref LL_USART_OVERSAMPLING_8 + * @param BaudRate Baud Rate + * @retval None + */ +__STATIC_INLINE void LL_USART_SetBaudRate(USART_TypeDef *USARTx, uint32_t PeriphClk, uint32_t OverSampling, + uint32_t BaudRate) +{ + uint32_t usartdiv; + uint32_t brrtemp; + + if (OverSampling == LL_USART_OVERSAMPLING_8) + { + usartdiv = (uint16_t)(__LL_USART_DIV_SAMPLING8(PeriphClk, BaudRate)); + brrtemp = usartdiv & 0xFFF0U; + brrtemp |= (uint16_t)((usartdiv & (uint16_t)0x000FU) >> 1U); + USARTx->BRR = brrtemp; + } + else + { + USARTx->BRR = (uint16_t)(__LL_USART_DIV_SAMPLING16(PeriphClk, BaudRate)); + } +} + +/** + * @brief Return current Baud Rate value, according to USARTDIV present in BRR register + * (full BRR content), and to used Peripheral Clock and Oversampling mode values + * @note In case of non-initialized or invalid value stored in BRR register, value 0 will be returned. + * @note In case of oversampling by 16 and 8, BRR content must be greater than or equal to 16d. + * @rmtoll BRR BRR LL_USART_GetBaudRate + * @param USARTx USART Instance + * @param PeriphClk Peripheral Clock + * @param OverSampling This parameter can be one of the following values: + * @arg @ref LL_USART_OVERSAMPLING_16 + * @arg @ref LL_USART_OVERSAMPLING_8 + * @retval Baud Rate + */ +__STATIC_INLINE uint32_t LL_USART_GetBaudRate(USART_TypeDef *USARTx, uint32_t PeriphClk, uint32_t OverSampling) +{ + uint32_t usartdiv; + uint32_t brrresult = 0x0U; + + usartdiv = USARTx->BRR; + + if (usartdiv == 0U) + { + /* Do not perform a division by 0 */ + } + else if (OverSampling == LL_USART_OVERSAMPLING_8) + { + usartdiv = (uint16_t)((usartdiv & 0xFFF0U) | ((usartdiv & 0x0007U) << 1U)) ; + if (usartdiv != 0U) + { + brrresult = (PeriphClk * 2U) / usartdiv; + } + } + else + { + if ((usartdiv & 0xFFFFU) != 0U) + { + brrresult = PeriphClk / usartdiv; + } + } + return (brrresult); +} + +/** + * @brief Set Receiver Time Out Value (expressed in nb of bits duration) + * @rmtoll RTOR RTO LL_USART_SetRxTimeout + * @param USARTx USART Instance + * @param Timeout Value between Min_Data=0x00 and Max_Data=0x00FFFFFF + * @retval None + */ +__STATIC_INLINE void LL_USART_SetRxTimeout(USART_TypeDef *USARTx, uint32_t Timeout) +{ + MODIFY_REG(USARTx->RTOR, USART_RTOR_RTO, Timeout); +} + +/** + * @brief Get Receiver Time Out Value (expressed in nb of bits duration) + * @rmtoll RTOR RTO LL_USART_GetRxTimeout + * @param USARTx USART Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x00FFFFFF + */ +__STATIC_INLINE uint32_t LL_USART_GetRxTimeout(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->RTOR, USART_RTOR_RTO)); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Set Block Length value in reception + * @rmtoll RTOR BLEN LL_USART_SetBlockLength + * @param USARTx USART Instance + * @param BlockLength Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_USART_SetBlockLength(USART_TypeDef *USARTx, uint32_t BlockLength) +{ + MODIFY_REG(USARTx->RTOR, USART_RTOR_BLEN, BlockLength << USART_RTOR_BLEN_Pos); +} + +/** + * @brief Get Block Length value in reception + * @rmtoll RTOR BLEN LL_USART_GetBlockLength + * @param USARTx USART Instance + * @retval Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint32_t LL_USART_GetBlockLength(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->RTOR, USART_RTOR_BLEN) >> USART_RTOR_BLEN_Pos); +} +#endif /* USART_SMARTCARD_SUPPORT */ + +/** + * @} + */ + +#if defined(USART_IRDA_SUPPORT) +/** @defgroup USART_LL_EF_Configuration_IRDA Configuration functions related to Irda feature + * @{ + */ + +/** + * @brief Enable IrDA mode + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @rmtoll CR3 IREN LL_USART_EnableIrda + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIrda(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_IREN); +} + +/** + * @brief Disable IrDA mode + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @rmtoll CR3 IREN LL_USART_DisableIrda + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIrda(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_IREN); +} + +/** + * @brief Indicate if IrDA mode is enabled + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @rmtoll CR3 IREN LL_USART_IsEnabledIrda + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIrda(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_IREN) == (USART_CR3_IREN)) ? 1UL : 0UL); +} + +/** + * @brief Configure IrDA Power Mode (Normal or Low Power) + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @rmtoll CR3 IRLP LL_USART_SetIrdaPowerMode + * @param USARTx USART Instance + * @param PowerMode This parameter can be one of the following values: + * @arg @ref LL_USART_IRDA_POWER_NORMAL + * @arg @ref LL_USART_IRDA_POWER_LOW + * @retval None + */ +__STATIC_INLINE void LL_USART_SetIrdaPowerMode(USART_TypeDef *USARTx, uint32_t PowerMode) +{ + MODIFY_REG(USARTx->CR3, USART_CR3_IRLP, PowerMode); +} + +/** + * @brief Retrieve IrDA Power Mode configuration (Normal or Low Power) + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @rmtoll CR3 IRLP LL_USART_GetIrdaPowerMode + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_IRDA_POWER_NORMAL + * @arg @ref LL_USART_PHASE_2EDGE + */ +__STATIC_INLINE uint32_t LL_USART_GetIrdaPowerMode(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR3, USART_CR3_IRLP)); +} + +/** + * @brief Set Irda prescaler value, used for dividing the USART clock source + * to achieve the Irda Low Power frequency (8 bits value) + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @rmtoll GTPR PSC LL_USART_SetIrdaPrescaler + * @param USARTx USART Instance + * @param PrescalerValue Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_USART_SetIrdaPrescaler(USART_TypeDef *USARTx, uint32_t PrescalerValue) +{ + MODIFY_REG(USARTx->GTPR, (uint16_t)USART_GTPR_PSC, (uint16_t)PrescalerValue); +} + +/** + * @brief Return Irda prescaler value, used for dividing the USART clock source + * to achieve the Irda Low Power frequency (8 bits value) + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @rmtoll GTPR PSC LL_USART_GetIrdaPrescaler + * @param USARTx USART Instance + * @retval Irda prescaler value (Value between Min_Data=0x00 and Max_Data=0xFF) + */ +__STATIC_INLINE uint32_t LL_USART_GetIrdaPrescaler(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->GTPR, USART_GTPR_PSC)); +} + +/** + * @} + */ +#endif /* USART_IRDA_SUPPORT */ + +#if defined(USART_SMARTCARD_SUPPORT) +/** @defgroup USART_LL_EF_Configuration_Smartcard Configuration functions related to Smartcard feature + * @{ + */ + +/** + * @brief Enable Smartcard NACK transmission + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR3 NACK LL_USART_EnableSmartcardNACK + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableSmartcardNACK(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_NACK); +} + +/** + * @brief Disable Smartcard NACK transmission + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR3 NACK LL_USART_DisableSmartcardNACK + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableSmartcardNACK(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_NACK); +} + +/** + * @brief Indicate if Smartcard NACK transmission is enabled + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR3 NACK LL_USART_IsEnabledSmartcardNACK + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledSmartcardNACK(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_NACK) == (USART_CR3_NACK)) ? 1UL : 0UL); +} + +/** + * @brief Enable Smartcard mode + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR3 SCEN LL_USART_EnableSmartcard + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableSmartcard(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_SCEN); +} + +/** + * @brief Disable Smartcard mode + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR3 SCEN LL_USART_DisableSmartcard + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableSmartcard(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_SCEN); +} + +/** + * @brief Indicate if Smartcard mode is enabled + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR3 SCEN LL_USART_IsEnabledSmartcard + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledSmartcard(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_SCEN) == (USART_CR3_SCEN)) ? 1UL : 0UL); +} + +/** + * @brief Set Smartcard Auto-Retry Count value (SCARCNT[2:0] bits) + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @note This bit-field specifies the number of retries in transmit and receive, in Smartcard mode. + * In transmission mode, it specifies the number of automatic retransmission retries, before + * generating a transmission error (FE bit set). + * In reception mode, it specifies the number or erroneous reception trials, before generating a + * reception error (RXNE and PE bits set) + * @rmtoll CR3 SCARCNT LL_USART_SetSmartcardAutoRetryCount + * @param USARTx USART Instance + * @param AutoRetryCount Value between Min_Data=0 and Max_Data=7 + * @retval None + */ +__STATIC_INLINE void LL_USART_SetSmartcardAutoRetryCount(USART_TypeDef *USARTx, uint32_t AutoRetryCount) +{ + MODIFY_REG(USARTx->CR3, USART_CR3_SCARCNT, AutoRetryCount << USART_CR3_SCARCNT_Pos); +} + +/** + * @brief Return Smartcard Auto-Retry Count value (SCARCNT[2:0] bits) + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR3 SCARCNT LL_USART_GetSmartcardAutoRetryCount + * @param USARTx USART Instance + * @retval Smartcard Auto-Retry Count value (Value between Min_Data=0 and Max_Data=7) + */ +__STATIC_INLINE uint32_t LL_USART_GetSmartcardAutoRetryCount(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR3, USART_CR3_SCARCNT) >> USART_CR3_SCARCNT_Pos); +} + +/** + * @brief Set Smartcard prescaler value, used for dividing the USART clock + * source to provide the SMARTCARD Clock (5 bits value) + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll GTPR PSC LL_USART_SetSmartcardPrescaler + * @param USARTx USART Instance + * @param PrescalerValue Value between Min_Data=0 and Max_Data=31 + * @retval None + */ +__STATIC_INLINE void LL_USART_SetSmartcardPrescaler(USART_TypeDef *USARTx, uint32_t PrescalerValue) +{ + MODIFY_REG(USARTx->GTPR, (uint16_t)USART_GTPR_PSC, (uint16_t)PrescalerValue); +} + +/** + * @brief Return Smartcard prescaler value, used for dividing the USART clock + * source to provide the SMARTCARD Clock (5 bits value) + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll GTPR PSC LL_USART_GetSmartcardPrescaler + * @param USARTx USART Instance + * @retval Smartcard prescaler value (Value between Min_Data=0 and Max_Data=31) + */ +__STATIC_INLINE uint32_t LL_USART_GetSmartcardPrescaler(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->GTPR, USART_GTPR_PSC)); +} + +/** + * @brief Set Smartcard Guard time value, expressed in nb of baud clocks periods + * (GT[7:0] bits : Guard time value) + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll GTPR GT LL_USART_SetSmartcardGuardTime + * @param USARTx USART Instance + * @param GuardTime Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_USART_SetSmartcardGuardTime(USART_TypeDef *USARTx, uint32_t GuardTime) +{ + MODIFY_REG(USARTx->GTPR, (uint16_t)USART_GTPR_GT, (uint16_t)(GuardTime << USART_GTPR_GT_Pos)); +} + +/** + * @brief Return Smartcard Guard time value, expressed in nb of baud clocks periods + * (GT[7:0] bits : Guard time value) + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll GTPR GT LL_USART_GetSmartcardGuardTime + * @param USARTx USART Instance + * @retval Smartcard Guard time value (Value between Min_Data=0x00 and Max_Data=0xFF) + */ +__STATIC_INLINE uint32_t LL_USART_GetSmartcardGuardTime(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->GTPR, USART_GTPR_GT) >> USART_GTPR_GT_Pos); +} + +/** + * @} + */ +#endif /* USART_SMARTCARD_SUPPORT */ + +/** @defgroup USART_LL_EF_Configuration_HalfDuplex Configuration functions related to Half Duplex feature + * @{ + */ + +/** + * @brief Enable Single Wire Half-Duplex mode + * @note Macro IS_UART_HALFDUPLEX_INSTANCE(USARTx) can be used to check whether or not + * Half-Duplex mode is supported by the USARTx instance. + * @rmtoll CR3 HDSEL LL_USART_EnableHalfDuplex + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableHalfDuplex(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_HDSEL); +} + +/** + * @brief Disable Single Wire Half-Duplex mode + * @note Macro IS_UART_HALFDUPLEX_INSTANCE(USARTx) can be used to check whether or not + * Half-Duplex mode is supported by the USARTx instance. + * @rmtoll CR3 HDSEL LL_USART_DisableHalfDuplex + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableHalfDuplex(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_HDSEL); +} + +/** + * @brief Indicate if Single Wire Half-Duplex mode is enabled + * @note Macro IS_UART_HALFDUPLEX_INSTANCE(USARTx) can be used to check whether or not + * Half-Duplex mode is supported by the USARTx instance. + * @rmtoll CR3 HDSEL LL_USART_IsEnabledHalfDuplex + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledHalfDuplex(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_HDSEL) == (USART_CR3_HDSEL)) ? 1UL : 0UL); +} + +/** + * @} + */ + +#if defined(USART_LIN_SUPPORT) +/** @defgroup USART_LL_EF_Configuration_LIN Configuration functions related to LIN feature + * @{ + */ + +/** + * @brief Set LIN Break Detection Length + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LBDL LL_USART_SetLINBrkDetectionLen + * @param USARTx USART Instance + * @param LINBDLength This parameter can be one of the following values: + * @arg @ref LL_USART_LINBREAK_DETECT_10B + * @arg @ref LL_USART_LINBREAK_DETECT_11B + * @retval None + */ +__STATIC_INLINE void LL_USART_SetLINBrkDetectionLen(USART_TypeDef *USARTx, uint32_t LINBDLength) +{ + MODIFY_REG(USARTx->CR2, USART_CR2_LBDL, LINBDLength); +} + +/** + * @brief Return LIN Break Detection Length + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LBDL LL_USART_GetLINBrkDetectionLen + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_LINBREAK_DETECT_10B + * @arg @ref LL_USART_LINBREAK_DETECT_11B + */ +__STATIC_INLINE uint32_t LL_USART_GetLINBrkDetectionLen(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR2, USART_CR2_LBDL)); +} + +/** + * @brief Enable LIN mode + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LINEN LL_USART_EnableLIN + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableLIN(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR2, USART_CR2_LINEN); +} + +/** + * @brief Disable LIN mode + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LINEN LL_USART_DisableLIN + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableLIN(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR2, USART_CR2_LINEN); +} + +/** + * @brief Indicate if LIN mode is enabled + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LINEN LL_USART_IsEnabledLIN + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledLIN(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR2, USART_CR2_LINEN) == (USART_CR2_LINEN)) ? 1UL : 0UL); +} + +/** + * @} + */ +#endif /* USART_LIN_SUPPORT */ + +/** @defgroup USART_LL_EF_Configuration_DE Configuration functions related to Driver Enable feature + * @{ + */ + +/** + * @brief Set DEDT (Driver Enable De-Assertion Time), Time value expressed on 5 bits ([4:0] bits). + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR1 DEDT LL_USART_SetDEDeassertionTime + * @param USARTx USART Instance + * @param Time Value between Min_Data=0 and Max_Data=31 + * @retval None + */ +__STATIC_INLINE void LL_USART_SetDEDeassertionTime(USART_TypeDef *USARTx, uint32_t Time) +{ + MODIFY_REG(USARTx->CR1, USART_CR1_DEDT, Time << USART_CR1_DEDT_Pos); +} + +/** + * @brief Return DEDT (Driver Enable De-Assertion Time) + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR1 DEDT LL_USART_GetDEDeassertionTime + * @param USARTx USART Instance + * @retval Time value expressed on 5 bits ([4:0] bits) : Value between Min_Data=0 and Max_Data=31 + */ +__STATIC_INLINE uint32_t LL_USART_GetDEDeassertionTime(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR1, USART_CR1_DEDT) >> USART_CR1_DEDT_Pos); +} + +/** + * @brief Set DEAT (Driver Enable Assertion Time), Time value expressed on 5 bits ([4:0] bits). + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR1 DEAT LL_USART_SetDEAssertionTime + * @param USARTx USART Instance + * @param Time Value between Min_Data=0 and Max_Data=31 + * @retval None + */ +__STATIC_INLINE void LL_USART_SetDEAssertionTime(USART_TypeDef *USARTx, uint32_t Time) +{ + MODIFY_REG(USARTx->CR1, USART_CR1_DEAT, Time << USART_CR1_DEAT_Pos); +} + +/** + * @brief Return DEAT (Driver Enable Assertion Time) + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR1 DEAT LL_USART_GetDEAssertionTime + * @param USARTx USART Instance + * @retval Time value expressed on 5 bits ([4:0] bits) : Value between Min_Data=0 and Max_Data=31 + */ +__STATIC_INLINE uint32_t LL_USART_GetDEAssertionTime(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR1, USART_CR1_DEAT) >> USART_CR1_DEAT_Pos); +} + +/** + * @brief Enable Driver Enable (DE) Mode + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR3 DEM LL_USART_EnableDEMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableDEMode(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_DEM); +} + +/** + * @brief Disable Driver Enable (DE) Mode + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR3 DEM LL_USART_DisableDEMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableDEMode(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_DEM); +} + +/** + * @brief Indicate if Driver Enable (DE) Mode is enabled + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR3 DEM LL_USART_IsEnabledDEMode + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledDEMode(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_DEM) == (USART_CR3_DEM)) ? 1UL : 0UL); +} + +/** + * @brief Select Driver Enable Polarity + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR3 DEP LL_USART_SetDESignalPolarity + * @param USARTx USART Instance + * @param Polarity This parameter can be one of the following values: + * @arg @ref LL_USART_DE_POLARITY_HIGH + * @arg @ref LL_USART_DE_POLARITY_LOW + * @retval None + */ +__STATIC_INLINE void LL_USART_SetDESignalPolarity(USART_TypeDef *USARTx, uint32_t Polarity) +{ + MODIFY_REG(USARTx->CR3, USART_CR3_DEP, Polarity); +} + +/** + * @brief Return Driver Enable Polarity + * @note Macro IS_UART_DRIVER_ENABLE_INSTANCE(USARTx) can be used to check whether or not + * Driver Enable feature is supported by the USARTx instance. + * @rmtoll CR3 DEP LL_USART_GetDESignalPolarity + * @param USARTx USART Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_USART_DE_POLARITY_HIGH + * @arg @ref LL_USART_DE_POLARITY_LOW + */ +__STATIC_INLINE uint32_t LL_USART_GetDESignalPolarity(USART_TypeDef *USARTx) +{ + return (uint32_t)(READ_BIT(USARTx->CR3, USART_CR3_DEP)); +} + +/** + * @} + */ + +/** @defgroup USART_LL_EF_AdvancedConfiguration Advanced Configurations services + * @{ + */ + +/** + * @brief Perform basic configuration of USART for enabling use in Asynchronous Mode (UART) + * @note In UART mode, the following bits must be kept cleared: + * - LINEN bit in the USART_CR2 register (if LIN feature is supported), + * - CLKEN bit in the USART_CR2 register, + * - SCEN bit in the USART_CR3 register (if Smartcard feature is supported), + * - IREN bit in the USART_CR3 register (if Irda feature is supported), + * - HDSEL bit in the USART_CR3 register. + * @note Call of this function is equivalent to following function call sequence : + * - Clear LINEN in CR2 using @ref LL_USART_DisableLIN() function (if LIN feature is supported) + * - Clear CLKEN in CR2 using @ref LL_USART_DisableSCLKOutput() function + * - Clear SCEN in CR3 using @ref LL_USART_DisableSmartcard() function (if Smartcard feature is supported) + * - Clear IREN in CR3 using @ref LL_USART_DisableIrda() function (if Irda feature is supported) + * - Clear HDSEL in CR3 using @ref LL_USART_DisableHalfDuplex() function + * @note Other remaining configurations items related to Asynchronous Mode + * (as Baud Rate, Word length, Parity, ...) should be set using + * dedicated functions + * @rmtoll CR2 LINEN LL_USART_ConfigAsyncMode\n + * CR2 CLKEN LL_USART_ConfigAsyncMode\n + * CR3 SCEN LL_USART_ConfigAsyncMode\n + * CR3 IREN LL_USART_ConfigAsyncMode\n + * CR3 HDSEL LL_USART_ConfigAsyncMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigAsyncMode(USART_TypeDef *USARTx) +{ + /* In Asynchronous mode, the following bits must be kept cleared: + - LINEN (if LIN feature is supported), CLKEN bits in the USART_CR2 register, + - SCEN (if Smartcard feature is supported), IREN (if Irda feature is supported) and HDSEL bits in the USART_CR3 register. + */ +#if defined(USART_LIN_SUPPORT) + CLEAR_BIT(USARTx->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN)); +#else + CLEAR_BIT(USARTx->CR2, USART_CR2_CLKEN); +#endif /* USART_LIN_SUPPORT */ +#if defined(USART_SMARTCARD_SUPPORT) +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_IREN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#endif /* USART_IRDA_SUPPORT */ +#else +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_IREN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, USART_CR3_HDSEL); +#endif /* USART_IRDA_SUPPORT */ +#endif /* USART_SMARTCARD_SUPPORT */ +} + +/** + * @brief Perform basic configuration of USART for enabling use in Synchronous Mode + * @note In Synchronous mode, the following bits must be kept cleared: + * - LINEN bit in the USART_CR2 register (if LIN feature is supported), + * - SCEN bit in the USART_CR3 register (if Smartcard feature is supported), + * - IREN bit in the USART_CR3 register (if Irda feature is supported), + * - HDSEL bit in the USART_CR3 register. + * This function also sets the USART in Synchronous mode. + * @note Macro IS_USART_INSTANCE(USARTx) can be used to check whether or not + * Synchronous mode is supported by the USARTx instance. + * @note Call of this function is equivalent to following function call sequence : + * - Clear LINEN in CR2 using @ref LL_USART_DisableLIN() function (if LIN feature is supported) + * - Clear IREN in CR3 using @ref LL_USART_DisableIrda() function (if Irda feature is supported) + * - Clear SCEN in CR3 using @ref LL_USART_DisableSmartcard() function (if Smartcard feature is supported) + * - Clear HDSEL in CR3 using @ref LL_USART_DisableHalfDuplex() function + * - Set CLKEN in CR2 using @ref LL_USART_EnableSCLKOutput() function + * @note Other remaining configurations items related to Synchronous Mode + * (as Baud Rate, Word length, Parity, Clock Polarity, ...) should be set using + * dedicated functions + * @rmtoll CR2 LINEN LL_USART_ConfigSyncMode\n + * CR2 CLKEN LL_USART_ConfigSyncMode\n + * CR3 SCEN LL_USART_ConfigSyncMode\n + * CR3 IREN LL_USART_ConfigSyncMode\n + * CR3 HDSEL LL_USART_ConfigSyncMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigSyncMode(USART_TypeDef *USARTx) +{ + /* In Synchronous mode, the following bits must be kept cleared: + - LINEN (if LIN feature is supported) bit in the USART_CR2 register, + - SCEN (if Smartcard feature is supported), IREN (if Irda feature is supported) and HDSEL bits in the USART_CR3 register. + */ +#if defined(USART_LIN_SUPPORT) + CLEAR_BIT(USARTx->CR2, (USART_CR2_LINEN)); +#endif /* USART_LIN_SUPPORT */ +#if defined(USART_SMARTCARD_SUPPORT) +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_IREN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#endif /* USART_IRDA_SUPPORT */ +#else +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_IREN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, USART_CR3_HDSEL); +#endif /* USART_IRDA_SUPPORT */ +#endif /* USART_SMARTCARD_SUPPORT */ + /* set the UART/USART in Synchronous mode */ + SET_BIT(USARTx->CR2, USART_CR2_CLKEN); +} + +#if defined(USART_LIN_SUPPORT) +/** + * @brief Perform basic configuration of USART for enabling use in LIN Mode + * @note In LIN mode, the following bits must be kept cleared: + * - STOP and CLKEN bits in the USART_CR2 register, + * - SCEN bit in the USART_CR3 register (if Smartcard feature is supported), + * - IREN bit in the USART_CR3 register (if Irda feature is supported), + * - HDSEL bit in the USART_CR3 register. + * This function also set the UART/USART in LIN mode. + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @note Call of this function is equivalent to following function call sequence : + * - Clear CLKEN in CR2 using @ref LL_USART_DisableSCLKOutput() function + * - Clear STOP in CR2 using @ref LL_USART_SetStopBitsLength() function + * - Clear SCEN in CR3 using @ref LL_USART_DisableSmartcard() function (if Smartcard feature is supported) + * - Clear IREN in CR3 using @ref LL_USART_DisableIrda() function (if Irda feature is supported) + * - Clear HDSEL in CR3 using @ref LL_USART_DisableHalfDuplex() function + * - Set LINEN in CR2 using @ref LL_USART_EnableLIN() function + * @note Other remaining configurations items related to LIN Mode + * (as Baud Rate, Word length, LIN Break Detection Length, ...) should be set using + * dedicated functions + * @rmtoll CR2 CLKEN LL_USART_ConfigLINMode\n + * CR2 STOP LL_USART_ConfigLINMode\n + * CR2 LINEN LL_USART_ConfigLINMode\n + * CR3 IREN LL_USART_ConfigLINMode\n + * CR3 SCEN LL_USART_ConfigLINMode\n + * CR3 HDSEL LL_USART_ConfigLINMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigLINMode(USART_TypeDef *USARTx) +{ + /* In LIN mode, the following bits must be kept cleared: + - STOP and CLKEN bits in the USART_CR2 register, + - IREN (if Irda feature is supported) , SCEN (if Smartcard feature is supported)and HDSEL bits in the USART_CR3 register. + */ + CLEAR_BIT(USARTx->CR2, (USART_CR2_CLKEN | USART_CR2_STOP)); +#if defined(USART_SMARTCARD_SUPPORT) +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_IREN | USART_CR3_SCEN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#endif /* USART_IRDA_SUPPORT */ +#else +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_IREN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, USART_CR3_HDSEL); +#endif /* USART_IRDA_SUPPORT */ +#endif /* USART_SMARTCARD_SUPPORT */ + /* Set the UART/USART in LIN mode */ + SET_BIT(USARTx->CR2, USART_CR2_LINEN); +} +#endif /* USART_LIN_SUPPORT */ + +/** + * @brief Perform basic configuration of USART for enabling use in Half Duplex Mode + * @note In Half Duplex mode, the following bits must be kept cleared: + * - LINEN bit in the USART_CR2 register (if LIN feature is supported), + * - CLKEN bit in the USART_CR2 register, + * - SCEN bit in the USART_CR3 register (if Smartcard feature is supported), + * - IREN bit in the USART_CR3 register (if Irda feature is supported), + * This function also sets the UART/USART in Half Duplex mode. + * @note Macro IS_UART_HALFDUPLEX_INSTANCE(USARTx) can be used to check whether or not + * Half-Duplex mode is supported by the USARTx instance. + * @note Call of this function is equivalent to following function call sequence : + * - Clear LINEN in CR2 using @ref LL_USART_DisableLIN() function (if LIN feature is supported) + * - Clear CLKEN in CR2 using @ref LL_USART_DisableSCLKOutput() function + * - Clear SCEN in CR3 using @ref LL_USART_DisableSmartcard() function (if Smartcard feature is supported) + * - Clear IREN in CR3 using @ref LL_USART_DisableIrda() function (if Irda feature is supported) + * - Set HDSEL in CR3 using @ref LL_USART_EnableHalfDuplex() function + * @note Other remaining configurations items related to Half Duplex Mode + * (as Baud Rate, Word length, Parity, ...) should be set using + * dedicated functions + * @rmtoll CR2 LINEN LL_USART_ConfigHalfDuplexMode\n + * CR2 CLKEN LL_USART_ConfigHalfDuplexMode\n + * CR3 HDSEL LL_USART_ConfigHalfDuplexMode\n + * CR3 SCEN LL_USART_ConfigHalfDuplexMode\n + * CR3 IREN LL_USART_ConfigHalfDuplexMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigHalfDuplexMode(USART_TypeDef *USARTx) +{ + /* In Half Duplex mode, the following bits must be kept cleared: + - LINEN (if LIN feature is supported) and CLKEN bits in the USART_CR2 register, + - SCEN (if Smartcard feature is supported) and IREN (if Irda feature is supported) bits in the USART_CR3 register. + */ +#if defined(USART_LIN_SUPPORT) + CLEAR_BIT(USARTx->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN)); +#else + CLEAR_BIT(USARTx->CR2, USART_CR2_CLKEN); +#endif /* USART_LIN_SUPPORT */ +#if defined(USART_SMARTCARD_SUPPORT) +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_IREN)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN)); +#endif /* USART_IRDA_SUPPORT */ +#else +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_IREN)); +#endif /* USART_IRDA_SUPPORT */ +#endif /* USART_SMARTCARD_SUPPORT */ + /* set the UART/USART in Half Duplex mode */ + SET_BIT(USARTx->CR3, USART_CR3_HDSEL); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Perform basic configuration of USART for enabling use in Smartcard Mode + * @note In Smartcard mode, the following bits must be kept cleared: + * - LINEN bit in the USART_CR2 register (if LIN feature is supported), + * - IREN bit in the USART_CR3 register (if Irda feature is supported), + * - HDSEL bit in the USART_CR3 register. + * This function also configures Stop bits to 1.5 bits and + * sets the USART in Smartcard mode (SCEN bit). + * Clock Output is also enabled (CLKEN). + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @note Call of this function is equivalent to following function call sequence : + * - Clear LINEN in CR2 using @ref LL_USART_DisableLIN() function (if LIN feature is supported) + * - Clear IREN in CR3 using @ref LL_USART_DisableIrda() function (if Irda feature is supported) + * - Clear HDSEL in CR3 using @ref LL_USART_DisableHalfDuplex() function + * - Configure STOP in CR2 using @ref LL_USART_SetStopBitsLength() function + * - Set CLKEN in CR2 using @ref LL_USART_EnableSCLKOutput() function + * - Set SCEN in CR3 using @ref LL_USART_EnableSmartcard() function + * @note Other remaining configurations items related to Smartcard Mode + * (as Baud Rate, Word length, Parity, ...) should be set using + * dedicated functions + * @rmtoll CR2 LINEN LL_USART_ConfigSmartcardMode\n + * CR2 STOP LL_USART_ConfigSmartcardMode\n + * CR2 CLKEN LL_USART_ConfigSmartcardMode\n + * CR3 HDSEL LL_USART_ConfigSmartcardMode\n + * CR3 SCEN LL_USART_ConfigSmartcardMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigSmartcardMode(USART_TypeDef *USARTx) +{ + /* In Smartcard mode, the following bits must be kept cleared: + - LINEN (if LIN feature is supported) bit in the USART_CR2 register, + - IREN (if Irda feature is supported) and HDSEL bits in the USART_CR3 register. + */ +#if defined(USART_LIN_SUPPORT) + CLEAR_BIT(USARTx->CR2, (USART_CR2_LINEN)); +#endif /* USART_LIN_SUPPORT */ +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_IREN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_HDSEL)); +#endif /* USART_IRDA_SUPPORT */ + /* Configure Stop bits to 1.5 bits */ + /* Synchronous mode is activated by default */ + SET_BIT(USARTx->CR2, (USART_CR2_STOP_0 | USART_CR2_STOP_1 | USART_CR2_CLKEN)); + /* set the UART/USART in Smartcard mode */ + SET_BIT(USARTx->CR3, USART_CR3_SCEN); +} +#endif /* USART_SMARTCARD_SUPPORT */ + +#if defined(USART_IRDA_SUPPORT) +/** + * @brief Perform basic configuration of USART for enabling use in Irda Mode + * @note In IRDA mode, the following bits must be kept cleared: + * - LINEN bit in the USART_CR2 register (if LIN feature is supported), + * - STOP and CLKEN bits in the USART_CR2 register, + * - SCEN bit in the USART_CR3 register (if Smartcard feature is supported), + * - HDSEL bit in the USART_CR3 register. + * This function also sets the UART/USART in IRDA mode (IREN bit). + * @note Macro IS_IRDA_INSTANCE(USARTx) can be used to check whether or not + * IrDA feature is supported by the USARTx instance. + * @note Call of this function is equivalent to following function call sequence : + * - Clear LINEN in CR2 using @ref LL_USART_DisableLIN() function (if LIN feature is supported) + * - Clear CLKEN in CR2 using @ref LL_USART_DisableSCLKOutput() function + * - Clear SCEN in CR3 using @ref LL_USART_DisableSmartcard() function (if Smartcard feature is supported) + * - Clear HDSEL in CR3 using @ref LL_USART_DisableHalfDuplex() function + * - Configure STOP in CR2 using @ref LL_USART_SetStopBitsLength() function + * - Set IREN in CR3 using @ref LL_USART_EnableIrda() function + * @note Other remaining configurations items related to Irda Mode + * (as Baud Rate, Word length, Power mode, ...) should be set using + * dedicated functions + * @rmtoll CR2 LINEN LL_USART_ConfigIrdaMode\n + * CR2 CLKEN LL_USART_ConfigIrdaMode\n + * CR2 STOP LL_USART_ConfigIrdaMode\n + * CR3 SCEN LL_USART_ConfigIrdaMode\n + * CR3 HDSEL LL_USART_ConfigIrdaMode\n + * CR3 IREN LL_USART_ConfigIrdaMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigIrdaMode(USART_TypeDef *USARTx) +{ + /* In IRDA mode, the following bits must be kept cleared: + - LINEN (if LIN feature is supported), STOP and CLKEN bits in the USART_CR2 register, + - SCEN (if Smartcard feature is supported) and HDSEL bits in the USART_CR3 register. + */ +#if defined(USART_LIN_SUPPORT) + CLEAR_BIT(USARTx->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN | USART_CR2_STOP)); +#else + CLEAR_BIT(USARTx->CR2, (USART_CR2_CLKEN | USART_CR2_STOP)); +#endif /* USART_LIN_SUPPORT */ +#if defined(USART_SMARTCARD_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_HDSEL)); +#endif /* USART_SMARTCARD_SUPPORT */ + /* set the UART/USART in IRDA mode */ + SET_BIT(USARTx->CR3, USART_CR3_IREN); +} +#endif /* USART_IRDA_SUPPORT */ + +/** + * @brief Perform basic configuration of USART for enabling use in Multi processor Mode + * (several USARTs connected in a network, one of the USARTs can be the master, + * its TX output connected to the RX inputs of the other slaves USARTs). + * @note In MultiProcessor mode, the following bits must be kept cleared: + * - LINEN bit in the USART_CR2 register (if LIN feature is supported), + * - CLKEN bit in the USART_CR2 register, + * - SCEN bit in the USART_CR3 register (if Smartcard feature is supported), + * - IREN bit in the USART_CR3 register (if Irda feature is supported), + * - HDSEL bit in the USART_CR3 register. + * @note Call of this function is equivalent to following function call sequence : + * - Clear LINEN in CR2 using @ref LL_USART_DisableLIN() function (if LIN feature is supported) + * - Clear CLKEN in CR2 using @ref LL_USART_DisableSCLKOutput() function + * - Clear SCEN in CR3 using @ref LL_USART_DisableSmartcard() function (if Smartcard feature is supported) + * - Clear IREN in CR3 using @ref LL_USART_DisableIrda() function (if Irda feature is supported) + * - Clear HDSEL in CR3 using @ref LL_USART_DisableHalfDuplex() function + * @note Other remaining configurations items related to Multi processor Mode + * (as Baud Rate, Wake Up Method, Node address, ...) should be set using + * dedicated functions + * @rmtoll CR2 LINEN LL_USART_ConfigMultiProcessMode\n + * CR2 CLKEN LL_USART_ConfigMultiProcessMode\n + * CR3 SCEN LL_USART_ConfigMultiProcessMode\n + * CR3 HDSEL LL_USART_ConfigMultiProcessMode\n + * CR3 IREN LL_USART_ConfigMultiProcessMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ConfigMultiProcessMode(USART_TypeDef *USARTx) +{ + /* In Multi Processor mode, the following bits must be kept cleared: + - LINEN (if LIN feature is supported) and CLKEN bits in the USART_CR2 register, + - IREN (if Irda feature is supported), SCEN (if Smartcard feature is supported) and HDSEL bits in the USART_CR3 register. + */ +#if defined(USART_LIN_SUPPORT) + CLEAR_BIT(USARTx->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN)); +#else + CLEAR_BIT(USARTx->CR2, USART_CR2_CLKEN); +#endif /* USART_LIN_SUPPORT */ +#if defined(USART_SMARTCARD_SUPPORT) +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#endif /* USART_IRDA_SUPPORT */ +#else +#if defined(USART_IRDA_SUPPORT) + CLEAR_BIT(USARTx->CR3, (USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(USARTx->CR3, (USART_CR3_HDSEL)); +#endif /* USART_IRDA_SUPPORT */ +#endif /* USART_SMARTCARD_SUPPORT*/ +} + +/** + * @} + */ + +/** @defgroup USART_LL_EF_FLAG_Management FLAG_Management + * @{ + */ + +/** + * @brief Check if the USART Parity Error Flag is set or not + * @rmtoll ISR PE LL_USART_IsActiveFlag_PE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_PE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_PE) == (USART_ISR_PE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Framing Error Flag is set or not + * @rmtoll ISR FE LL_USART_IsActiveFlag_FE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_FE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_FE) == (USART_ISR_FE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Noise error detected Flag is set or not + * @rmtoll ISR NE LL_USART_IsActiveFlag_NE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_NE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_NE) == (USART_ISR_NE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART OverRun Error Flag is set or not + * @rmtoll ISR ORE LL_USART_IsActiveFlag_ORE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_ORE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_ORE) == (USART_ISR_ORE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART IDLE line detected Flag is set or not + * @rmtoll ISR IDLE LL_USART_IsActiveFlag_IDLE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_IDLE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_IDLE) == (USART_ISR_IDLE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Read Data Register Not Empty Flag is set or not + * @rmtoll ISR RXNE LL_USART_IsActiveFlag_RXNE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_RXNE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_RXNE) == (USART_ISR_RXNE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Transmission Complete Flag is set or not + * @rmtoll ISR TC LL_USART_IsActiveFlag_TC + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_TC(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_TC) == (USART_ISR_TC)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Transmit Data Register Empty Flag is set or not + * @rmtoll ISR TXE LL_USART_IsActiveFlag_TXE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_TXE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_TXE) == (USART_ISR_TXE)) ? 1UL : 0UL); +} + +#if defined(USART_LIN_SUPPORT) +/** + * @brief Check if the USART LIN Break Detection Flag is set or not + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll ISR LBDF LL_USART_IsActiveFlag_LBD + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_LBD(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_LBDF) == (USART_ISR_LBDF)) ? 1UL : 0UL); +} +#endif /* USART_LIN_SUPPORT */ + +/** + * @brief Check if the USART CTS interrupt Flag is set or not + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll ISR CTSIF LL_USART_IsActiveFlag_nCTS + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_nCTS(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_CTSIF) == (USART_ISR_CTSIF)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART CTS Flag is set or not + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll ISR CTS LL_USART_IsActiveFlag_CTS + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_CTS(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_CTS) == (USART_ISR_CTS)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Receiver Time Out Flag is set or not + * @rmtoll ISR RTOF LL_USART_IsActiveFlag_RTO + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_RTO(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_RTOF) == (USART_ISR_RTOF)) ? 1UL : 0UL); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Check if the USART End Of Block Flag is set or not + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll ISR EOBF LL_USART_IsActiveFlag_EOB + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_EOB(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_EOBF) == (USART_ISR_EOBF)) ? 1UL : 0UL); +} +#endif /* USART_SMARTCARD_SUPPORT */ + +/** + * @brief Check if the USART Auto-Baud Rate Error Flag is set or not + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll ISR ABRE LL_USART_IsActiveFlag_ABRE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_ABRE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_ABRE) == (USART_ISR_ABRE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Auto-Baud Rate Flag is set or not + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll ISR ABRF LL_USART_IsActiveFlag_ABR + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_ABR(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_ABRF) == (USART_ISR_ABRF)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Busy Flag is set or not + * @rmtoll ISR BUSY LL_USART_IsActiveFlag_BUSY + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_BUSY(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_BUSY) == (USART_ISR_BUSY)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Character Match Flag is set or not + * @rmtoll ISR CMF LL_USART_IsActiveFlag_CM + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_CM(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_CMF) == (USART_ISR_CMF)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Send Break Flag is set or not + * @rmtoll ISR SBKF LL_USART_IsActiveFlag_SBK + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_SBK(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_SBKF) == (USART_ISR_SBKF)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Receive Wake Up from mute mode Flag is set or not + * @rmtoll ISR RWU LL_USART_IsActiveFlag_RWU + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_RWU(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_RWU) == (USART_ISR_RWU)) ? 1UL : 0UL); +} + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +/** + * @brief Check if the USART Wake Up from stop mode Flag is set or not + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll ISR WUF LL_USART_IsActiveFlag_WKUP + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_WKUP(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_WUF) == (USART_ISR_WUF)) ? 1UL : 0UL); +} + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +/** + * @brief Check if the USART Transmit Enable Acknowledge Flag is set or not + * @rmtoll ISR TEACK LL_USART_IsActiveFlag_TEACK + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_TEACK(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_TEACK) == (USART_ISR_TEACK)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Receive Enable Acknowledge Flag is set or not + * @rmtoll ISR REACK LL_USART_IsActiveFlag_REACK + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsActiveFlag_REACK(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->ISR, USART_ISR_REACK) == (USART_ISR_REACK)) ? 1UL : 0UL); +} + +/** + * @brief Clear Parity Error Flag + * @rmtoll ICR PECF LL_USART_ClearFlag_PE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_PE(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_PECF); +} + +/** + * @brief Clear Framing Error Flag + * @rmtoll ICR FECF LL_USART_ClearFlag_FE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_FE(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_FECF); +} + +/** + * @brief Clear Noise Error detected Flag + * @rmtoll ICR NCF LL_USART_ClearFlag_NE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_NE(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_NCF); +} + +/** + * @brief Clear OverRun Error Flag + * @rmtoll ICR ORECF LL_USART_ClearFlag_ORE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_ORE(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_ORECF); +} + +/** + * @brief Clear IDLE line detected Flag + * @rmtoll ICR IDLECF LL_USART_ClearFlag_IDLE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_IDLE(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_IDLECF); +} + +/** + * @brief Clear Transmission Complete Flag + * @rmtoll ICR TCCF LL_USART_ClearFlag_TC + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_TC(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_TCCF); +} + + +#if defined(USART_LIN_SUPPORT) +/** + * @brief Clear LIN Break Detection Flag + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll ICR LBDCF LL_USART_ClearFlag_LBD + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_LBD(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_LBDCF); +} +#endif /* USART_LIN_SUPPORT */ + +/** + * @brief Clear CTS Interrupt Flag + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll ICR CTSCF LL_USART_ClearFlag_nCTS + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_nCTS(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_CTSCF); +} + +/** + * @brief Clear Receiver Time Out Flag + * @rmtoll ICR RTOCF LL_USART_ClearFlag_RTO + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_RTO(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_RTOCF); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Clear End Of Block Flag + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll ICR EOBCF LL_USART_ClearFlag_EOB + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_EOB(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_EOBCF); +} +#endif /* USART_SMARTCARD_SUPPORT */ + +/** + * @brief Clear Character Match Flag + * @rmtoll ICR CMCF LL_USART_ClearFlag_CM + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_CM(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_CMCF); +} + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +/** + * @brief Clear Wake Up from stop mode Flag + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll ICR WUCF LL_USART_ClearFlag_WKUP + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_ClearFlag_WKUP(USART_TypeDef *USARTx) +{ + WRITE_REG(USARTx->ICR, USART_ICR_WUCF); +} + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ +/** + * @} + */ + +/** @defgroup USART_LL_EF_IT_Management IT_Management + * @{ + */ + +/** + * @brief Enable IDLE Interrupt + * @rmtoll CR1 IDLEIE LL_USART_EnableIT_IDLE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_IDLE(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_IDLEIE); +} + +/** + * @brief Enable RX Not Empty Interrupt + * @rmtoll CR1 RXNEIE LL_USART_EnableIT_RXNE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_RXNE(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_RXNEIE); +} + +/** + * @brief Enable Transmission Complete Interrupt + * @rmtoll CR1 TCIE LL_USART_EnableIT_TC + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_TC(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_TCIE); +} + +/** + * @brief Enable TX Empty Interrupt + * @rmtoll CR1 TXEIE LL_USART_EnableIT_TXE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_TXE(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_TXEIE); +} + +/** + * @brief Enable Parity Error Interrupt + * @rmtoll CR1 PEIE LL_USART_EnableIT_PE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_PE(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_PEIE); +} + +/** + * @brief Enable Character Match Interrupt + * @rmtoll CR1 CMIE LL_USART_EnableIT_CM + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_CM(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_CMIE); +} + +/** + * @brief Enable Receiver Timeout Interrupt + * @rmtoll CR1 RTOIE LL_USART_EnableIT_RTO + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_RTO(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_RTOIE); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Enable End Of Block Interrupt + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR1 EOBIE LL_USART_EnableIT_EOB + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_EOB(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR1, USART_CR1_EOBIE); +} +#endif /* USART_SMARTCARD_SUPPORT */ + +#if defined(USART_LIN_SUPPORT) +/** + * @brief Enable LIN Break Detection Interrupt + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LBDIE LL_USART_EnableIT_LBD + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_LBD(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR2, USART_CR2_LBDIE); +} + +#endif/* USART_LIN_SUPPORT */ +/** + * @brief Enable Error Interrupt + * @note When set, Error Interrupt Enable Bit is enabling interrupt generation in case of a framing + * error, overrun error or noise flag (FE=1 or ORE=1 or NF=1 in the USARTx_ISR register). + * 0: Interrupt is inhibited + * 1: An interrupt is generated when FE=1 or ORE=1 or NF=1 in the USARTx_ISR register. + * @rmtoll CR3 EIE LL_USART_EnableIT_ERROR + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_ERROR(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR3, USART_CR3_EIE); +} + +/** + * @brief Enable CTS Interrupt + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 CTSIE LL_USART_EnableIT_CTS + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_CTS(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR3, USART_CR3_CTSIE); +} + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +/** + * @brief Enable Wake Up from Stop Mode Interrupt + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR3 WUFIE LL_USART_EnableIT_WKUP + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableIT_WKUP(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR3, USART_CR3_WUFIE); +} + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + +/** + * @brief Disable IDLE Interrupt + * @rmtoll CR1 IDLEIE LL_USART_DisableIT_IDLE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_IDLE(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_IDLEIE); +} + +/** + * @brief Disable RX Not Empty Interrupt + * @rmtoll CR1 RXNEIE LL_USART_DisableIT_RXNE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_RXNE(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_RXNEIE); +} + +/** + * @brief Disable Transmission Complete Interrupt + * @rmtoll CR1 TCIE LL_USART_DisableIT_TC + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_TC(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_TCIE); +} + +/** + * @brief Disable TX Empty Interrupt + * @rmtoll CR1 TXEIE LL_USART_DisableIT_TXE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_TXE(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_TXEIE); +} + +/** + * @brief Disable Parity Error Interrupt + * @rmtoll CR1 PEIE LL_USART_DisableIT_PE + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_PE(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_PEIE); +} + +/** + * @brief Disable Character Match Interrupt + * @rmtoll CR1 CMIE LL_USART_DisableIT_CM + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_CM(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_CMIE); +} + +/** + * @brief Disable Receiver Timeout Interrupt + * @rmtoll CR1 RTOIE LL_USART_DisableIT_RTO + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_RTO(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_RTOIE); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Disable End Of Block Interrupt + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR1 EOBIE LL_USART_DisableIT_EOB + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_EOB(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR1, USART_CR1_EOBIE); +} +#endif /* USART_SMARTCARD_SUPPORT */ + +#if defined(USART_LIN_SUPPORT) +/** + * @brief Disable LIN Break Detection Interrupt + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LBDIE LL_USART_DisableIT_LBD + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_LBD(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR2, USART_CR2_LBDIE); +} +#endif /* USART_LIN_SUPPORT */ + +/** + * @brief Disable Error Interrupt + * @note When set, Error Interrupt Enable Bit is enabling interrupt generation in case of a framing + * error, overrun error or noise flag (FE=1 or ORE=1 or NF=1 in the USARTx_ISR register). + * 0: Interrupt is inhibited + * 1: An interrupt is generated when FE=1 or ORE=1 or NF=1 in the USARTx_ISR register. + * @rmtoll CR3 EIE LL_USART_DisableIT_ERROR + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_ERROR(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR3, USART_CR3_EIE); +} + +/** + * @brief Disable CTS Interrupt + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 CTSIE LL_USART_DisableIT_CTS + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_CTS(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR3, USART_CR3_CTSIE); +} + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +/** + * @brief Disable Wake Up from Stop Mode Interrupt + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR3 WUFIE LL_USART_DisableIT_WKUP + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableIT_WKUP(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR3, USART_CR3_WUFIE); +} + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + +/** + * @brief Check if the USART IDLE Interrupt source is enabled or disabled. + * @rmtoll CR1 IDLEIE LL_USART_IsEnabledIT_IDLE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_IDLE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_IDLEIE) == (USART_CR1_IDLEIE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART RX Not Empty Interrupt is enabled or disabled. + * @rmtoll CR1 RXNEIE LL_USART_IsEnabledIT_RXNE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_RXNE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_RXNEIE) == (USART_CR1_RXNEIE)) ? 1U : 0U); +} + +/** + * @brief Check if the USART Transmission Complete Interrupt is enabled or disabled. + * @rmtoll CR1 TCIE LL_USART_IsEnabledIT_TC + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_TC(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_TCIE) == (USART_CR1_TCIE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART TX Empty Interrupt is enabled or disabled. + * @rmtoll CR1 TXEIE LL_USART_IsEnabledIT_TXE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_TXE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_TXEIE) == (USART_CR1_TXEIE)) ? 1U : 0U); +} + +/** + * @brief Check if the USART Parity Error Interrupt is enabled or disabled. + * @rmtoll CR1 PEIE LL_USART_IsEnabledIT_PE + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_PE(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_PEIE) == (USART_CR1_PEIE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Character Match Interrupt is enabled or disabled. + * @rmtoll CR1 CMIE LL_USART_IsEnabledIT_CM + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_CM(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_CMIE) == (USART_CR1_CMIE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART Receiver Timeout Interrupt is enabled or disabled. + * @rmtoll CR1 RTOIE LL_USART_IsEnabledIT_RTO + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_RTO(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_RTOIE) == (USART_CR1_RTOIE)) ? 1UL : 0UL); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Check if the USART End Of Block Interrupt is enabled or disabled. + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll CR1 EOBIE LL_USART_IsEnabledIT_EOB + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_EOB(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR1, USART_CR1_EOBIE) == (USART_CR1_EOBIE)) ? 1UL : 0UL); +} + +#endif /* USART_SMARTCARD_SUPPORT */ +#if defined(USART_LIN_SUPPORT) +/** + * @brief Check if the USART LIN Break Detection Interrupt is enabled or disabled. + * @note Macro IS_UART_LIN_INSTANCE(USARTx) can be used to check whether or not + * LIN feature is supported by the USARTx instance. + * @rmtoll CR2 LBDIE LL_USART_IsEnabledIT_LBD + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_LBD(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR2, USART_CR2_LBDIE) == (USART_CR2_LBDIE)) ? 1UL : 0UL); +} +#endif /* USART_LIN_SUPPORT */ + +/** + * @brief Check if the USART Error Interrupt is enabled or disabled. + * @rmtoll CR3 EIE LL_USART_IsEnabledIT_ERROR + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_ERROR(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_EIE) == (USART_CR3_EIE)) ? 1UL : 0UL); +} + +/** + * @brief Check if the USART CTS Interrupt is enabled or disabled. + * @note Macro IS_UART_HWFLOW_INSTANCE(USARTx) can be used to check whether or not + * Hardware Flow control feature is supported by the USARTx instance. + * @rmtoll CR3 CTSIE LL_USART_IsEnabledIT_CTS + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_CTS(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_CTSIE) == (USART_CR3_CTSIE)) ? 1UL : 0UL); +} + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +/** + * @brief Check if the USART Wake Up from Stop Mode Interrupt is enabled or disabled. + * @note Macro IS_UART_WAKEUP_FROMSTOP_INSTANCE(USARTx) can be used to check whether or not + * Wake-up from Stop mode feature is supported by the USARTx instance. + * @rmtoll CR3 WUFIE LL_USART_IsEnabledIT_WKUP + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledIT_WKUP(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_WUFIE) == (USART_CR3_WUFIE)) ? 1UL : 0UL); +} + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + +/** + * @} + */ + +/** @defgroup USART_LL_EF_DMA_Management DMA_Management + * @{ + */ + +/** + * @brief Enable DMA Mode for reception + * @rmtoll CR3 DMAR LL_USART_EnableDMAReq_RX + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableDMAReq_RX(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR3, USART_CR3_DMAR); +} + +/** + * @brief Disable DMA Mode for reception + * @rmtoll CR3 DMAR LL_USART_DisableDMAReq_RX + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableDMAReq_RX(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR3, USART_CR3_DMAR); +} + +/** + * @brief Check if DMA Mode is enabled for reception + * @rmtoll CR3 DMAR LL_USART_IsEnabledDMAReq_RX + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledDMAReq_RX(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_DMAR) == (USART_CR3_DMAR)) ? 1UL : 0UL); +} + +/** + * @brief Enable DMA Mode for transmission + * @rmtoll CR3 DMAT LL_USART_EnableDMAReq_TX + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableDMAReq_TX(USART_TypeDef *USARTx) +{ + ATOMIC_SET_BIT(USARTx->CR3, USART_CR3_DMAT); +} + +/** + * @brief Disable DMA Mode for transmission + * @rmtoll CR3 DMAT LL_USART_DisableDMAReq_TX + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableDMAReq_TX(USART_TypeDef *USARTx) +{ + ATOMIC_CLEAR_BIT(USARTx->CR3, USART_CR3_DMAT); +} + +/** + * @brief Check if DMA Mode is enabled for transmission + * @rmtoll CR3 DMAT LL_USART_IsEnabledDMAReq_TX + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledDMAReq_TX(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_DMAT) == (USART_CR3_DMAT)) ? 1UL : 0UL); +} + +/** + * @brief Enable DMA Disabling on Reception Error + * @rmtoll CR3 DDRE LL_USART_EnableDMADeactOnRxErr + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_EnableDMADeactOnRxErr(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->CR3, USART_CR3_DDRE); +} + +/** + * @brief Disable DMA Disabling on Reception Error + * @rmtoll CR3 DDRE LL_USART_DisableDMADeactOnRxErr + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_DisableDMADeactOnRxErr(USART_TypeDef *USARTx) +{ + CLEAR_BIT(USARTx->CR3, USART_CR3_DDRE); +} + +/** + * @brief Indicate if DMA Disabling on Reception Error is disabled + * @rmtoll CR3 DDRE LL_USART_IsEnabledDMADeactOnRxErr + * @param USARTx USART Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_USART_IsEnabledDMADeactOnRxErr(USART_TypeDef *USARTx) +{ + return ((READ_BIT(USARTx->CR3, USART_CR3_DDRE) == (USART_CR3_DDRE)) ? 1UL : 0UL); +} + +/** + * @brief Get the data register address used for DMA transfer + * @rmtoll RDR RDR LL_USART_DMA_GetRegAddr\n + * @rmtoll TDR TDR LL_USART_DMA_GetRegAddr + * @param USARTx USART Instance + * @param Direction This parameter can be one of the following values: + * @arg @ref LL_USART_DMA_REG_DATA_TRANSMIT + * @arg @ref LL_USART_DMA_REG_DATA_RECEIVE + * @retval Address of data register + */ +__STATIC_INLINE uint32_t LL_USART_DMA_GetRegAddr(USART_TypeDef *USARTx, uint32_t Direction) +{ + uint32_t data_reg_addr; + + if (Direction == LL_USART_DMA_REG_DATA_TRANSMIT) + { + /* return address of TDR register */ + data_reg_addr = (uint32_t) &(USARTx->TDR); + } + else + { + /* return address of RDR register */ + data_reg_addr = (uint32_t) &(USARTx->RDR); + } + + return data_reg_addr; +} + +/** + * @} + */ + +/** @defgroup USART_LL_EF_Data_Management Data_Management + * @{ + */ + +/** + * @brief Read Receiver Data register (Receive Data value, 8 bits) + * @rmtoll RDR RDR LL_USART_ReceiveData8 + * @param USARTx USART Instance + * @retval Value between Min_Data=0x00 and Max_Data=0xFF + */ +__STATIC_INLINE uint8_t LL_USART_ReceiveData8(USART_TypeDef *USARTx) +{ + return (uint8_t)(READ_BIT(USARTx->RDR, USART_RDR_RDR) & 0xFFU); +} + +/** + * @brief Read Receiver Data register (Receive Data value, 9 bits) + * @rmtoll RDR RDR LL_USART_ReceiveData9 + * @param USARTx USART Instance + * @retval Value between Min_Data=0x00 and Max_Data=0x1FF + */ +__STATIC_INLINE uint16_t LL_USART_ReceiveData9(USART_TypeDef *USARTx) +{ + return (uint16_t)(READ_BIT(USARTx->RDR, USART_RDR_RDR)); +} + +/** + * @brief Write in Transmitter Data Register (Transmit Data value, 8 bits) + * @rmtoll TDR TDR LL_USART_TransmitData8 + * @param USARTx USART Instance + * @param Value between Min_Data=0x00 and Max_Data=0xFF + * @retval None + */ +__STATIC_INLINE void LL_USART_TransmitData8(USART_TypeDef *USARTx, uint8_t Value) +{ + USARTx->TDR = Value; +} + +/** + * @brief Write in Transmitter Data Register (Transmit Data value, 9 bits) + * @rmtoll TDR TDR LL_USART_TransmitData9 + * @param USARTx USART Instance + * @param Value between Min_Data=0x00 and Max_Data=0x1FF + * @retval None + */ +__STATIC_INLINE void LL_USART_TransmitData9(USART_TypeDef *USARTx, uint16_t Value) +{ + USARTx->TDR = (uint16_t)(Value & 0x1FFUL); +} + +/** + * @} + */ + +/** @defgroup USART_LL_EF_Execution Execution + * @{ + */ + +/** + * @brief Request an Automatic Baud Rate measurement on next received data frame + * @note Macro IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(USARTx) can be used to check whether or not + * Auto Baud Rate detection feature is supported by the USARTx instance. + * @rmtoll RQR ABRRQ LL_USART_RequestAutoBaudRate + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_RequestAutoBaudRate(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->RQR, (uint16_t)USART_RQR_ABRRQ); +} + +/** + * @brief Request Break sending + * @rmtoll RQR SBKRQ LL_USART_RequestBreakSending + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_RequestBreakSending(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->RQR, (uint16_t)USART_RQR_SBKRQ); +} + +/** + * @brief Put USART in mute mode and set the RWU flag + * @rmtoll RQR MMRQ LL_USART_RequestEnterMuteMode + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_RequestEnterMuteMode(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->RQR, (uint16_t)USART_RQR_MMRQ); +} + +/** + * @brief Request a Receive Data flush + * @note Allows to discard the received data without reading them, and avoid an overrun + * condition. + * @rmtoll RQR RXFRQ LL_USART_RequestRxDataFlush + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_RequestRxDataFlush(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->RQR, (uint16_t)USART_RQR_RXFRQ); +} + +#if defined(USART_SMARTCARD_SUPPORT) +/** + * @brief Request a Transmit data flush + * @note Macro IS_SMARTCARD_INSTANCE(USARTx) can be used to check whether or not + * Smartcard feature is supported by the USARTx instance. + * @rmtoll RQR TXFRQ LL_USART_RequestTxDataFlush + * @param USARTx USART Instance + * @retval None + */ +__STATIC_INLINE void LL_USART_RequestTxDataFlush(USART_TypeDef *USARTx) +{ + SET_BIT(USARTx->RQR, (uint16_t)USART_RQR_TXFRQ); +} +#endif /*USART_SMARTCARD_SUPPORT*/ + +/** + * @} + */ + +#if defined(USE_FULL_LL_DRIVER) +/** @defgroup USART_LL_EF_Init Initialization and de-initialization functions + * @{ + */ +ErrorStatus LL_USART_DeInit(USART_TypeDef *USARTx); +ErrorStatus LL_USART_Init(USART_TypeDef *USARTx, LL_USART_InitTypeDef *USART_InitStruct); +void LL_USART_StructInit(LL_USART_InitTypeDef *USART_InitStruct); +ErrorStatus LL_USART_ClockInit(USART_TypeDef *USARTx, LL_USART_ClockInitTypeDef *USART_ClockInitStruct); +void LL_USART_ClockStructInit(LL_USART_ClockInitTypeDef *USART_ClockInitStruct); +/** + * @} + */ +#endif /* USE_FULL_LL_DRIVER */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* USART1 || USART2 || USART3 || UART4 || UART5 || USART6 || USART7 || USART8 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_LL_USART_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usb.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usb.h new file mode 100644 index 0000000..0660247 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_usb.h @@ -0,0 +1,238 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_usb.h + * @author MCD Application Team + * @brief Header file of USB Low Layer HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_LL_USB_H +#define STM32F0xx_LL_USB_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +#if defined (USB) +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup USB_LL + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** + * @brief USB Mode definition + */ + + + +typedef enum +{ + USB_DEVICE_MODE = 0 +} USB_ModeTypeDef; + +/** + * @brief USB Initialization Structure definition + */ +typedef struct +{ + uint32_t dev_endpoints; /*!< Device Endpoints number. + This parameter depends on the used USB core. + This parameter must be a number between Min_Data = 1 and Max_Data = 15 */ + + uint32_t speed; /*!< USB Core speed. + This parameter can be any value of @ref PCD_Speed/HCD_Speed + (HCD_SPEED_xxx, HCD_SPEED_xxx) */ + + uint32_t ep0_mps; /*!< Set the Endpoint 0 Max Packet size. */ + + uint32_t phy_itface; /*!< Select the used PHY interface. + This parameter can be any value of @ref PCD_PHY_Module/HCD_PHY_Module */ + + uint32_t Sof_enable; /*!< Enable or disable the output of the SOF signal. */ + + uint32_t low_power_enable; /*!< Enable or disable Low Power mode */ + + uint32_t lpm_enable; /*!< Enable or disable Battery charging. */ + + uint32_t battery_charging_enable; /*!< Enable or disable Battery charging. */ +} USB_CfgTypeDef; + +typedef struct +{ + uint8_t num; /*!< Endpoint number + This parameter must be a number between Min_Data = 1 and Max_Data = 15 */ + + uint8_t is_in; /*!< Endpoint direction + This parameter must be a number between Min_Data = 0 and Max_Data = 1 */ + + uint8_t is_stall; /*!< Endpoint stall condition + This parameter must be a number between Min_Data = 0 and Max_Data = 1 */ + + uint8_t type; /*!< Endpoint type + This parameter can be any value of @ref USB_EP_Type */ + + uint8_t data_pid_start; /*!< Initial data PID + This parameter must be a number between Min_Data = 0 and Max_Data = 1 */ + + uint16_t pmaadress; /*!< PMA Address + This parameter can be any value between Min_addr = 0 and Max_addr = 1K */ + + uint16_t pmaaddr0; /*!< PMA Address0 + This parameter can be any value between Min_addr = 0 and Max_addr = 1K */ + + uint16_t pmaaddr1; /*!< PMA Address1 + This parameter can be any value between Min_addr = 0 and Max_addr = 1K */ + + uint8_t doublebuffer; /*!< Double buffer enable + This parameter can be 0 or 1 */ + + uint16_t tx_fifo_num; /*!< This parameter is not required by USB Device FS peripheral, it is used + only by USB OTG FS peripheral + This parameter is added to ensure compatibility across USB peripherals */ + + uint32_t maxpacket; /*!< Endpoint Max packet size + This parameter must be a number between Min_Data = 0 and Max_Data = 64KB */ + + uint8_t *xfer_buff; /*!< Pointer to transfer buffer */ + + uint32_t xfer_len; /*!< Current transfer length */ + + uint32_t xfer_count; /*!< Partial transfer length in case of multi packet transfer */ + + uint32_t xfer_len_db; /*!< double buffer transfer length used with bulk double buffer in */ + + uint8_t xfer_fill_db; /*!< double buffer Need to Fill new buffer used with bulk_in */ + +} USB_EPTypeDef; + + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup PCD_Exported_Constants PCD Exported Constants + * @{ + */ + + +/** @defgroup USB_LL_EP0_MPS USB Low Layer EP0 MPS + * @{ + */ +#define EP_MPS_64 0U +#define EP_MPS_32 1U +#define EP_MPS_16 2U +#define EP_MPS_8 3U +/** + * @} + */ + +/** @defgroup USB_LL_EP_Type USB Low Layer EP Type + * @{ + */ +#define EP_TYPE_CTRL 0U +#define EP_TYPE_ISOC 1U +#define EP_TYPE_BULK 2U +#define EP_TYPE_INTR 3U +#define EP_TYPE_MSK 3U +/** + * @} + */ + +/** @defgroup USB_LL Device Speed + * @{ + */ +#define USBD_FS_SPEED 2U +/** + * @} + */ + +#define BTABLE_ADDRESS 0x000U +#define PMA_ACCESS 1U + +#define EP_ADDR_MSK 0x7U +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup USB_LL_Exported_Functions USB Low Layer Exported Functions + * @{ + */ + + +HAL_StatusTypeDef USB_CoreInit(USB_TypeDef *USBx, USB_CfgTypeDef cfg); +HAL_StatusTypeDef USB_DevInit(USB_TypeDef *USBx, USB_CfgTypeDef cfg); +HAL_StatusTypeDef USB_EnableGlobalInt(USB_TypeDef *USBx); +HAL_StatusTypeDef USB_DisableGlobalInt(USB_TypeDef *USBx); +HAL_StatusTypeDef USB_SetCurrentMode(USB_TypeDef *USBx, USB_ModeTypeDef mode); + +#if defined (HAL_PCD_MODULE_ENABLED) +HAL_StatusTypeDef USB_ActivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep); +HAL_StatusTypeDef USB_DeactivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep); +HAL_StatusTypeDef USB_EPStartXfer(USB_TypeDef *USBx, USB_EPTypeDef *ep); +HAL_StatusTypeDef USB_EPSetStall(USB_TypeDef *USBx, USB_EPTypeDef *ep); +HAL_StatusTypeDef USB_EPClearStall(USB_TypeDef *USBx, USB_EPTypeDef *ep); +#endif /* defined (HAL_PCD_MODULE_ENABLED) */ + +HAL_StatusTypeDef USB_SetDevAddress(USB_TypeDef *USBx, uint8_t address); +HAL_StatusTypeDef USB_DevConnect(USB_TypeDef *USBx); +HAL_StatusTypeDef USB_DevDisconnect(USB_TypeDef *USBx); +HAL_StatusTypeDef USB_StopDevice(USB_TypeDef *USBx); +uint32_t USB_ReadInterrupts(USB_TypeDef *USBx); +HAL_StatusTypeDef USB_ActivateRemoteWakeup(USB_TypeDef *USBx); +HAL_StatusTypeDef USB_DeActivateRemoteWakeup(USB_TypeDef *USBx); + +void USB_WritePMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf, + uint16_t wPMABufAddr, uint16_t wNBytes); + +void USB_ReadPMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf, + uint16_t wPMABufAddr, uint16_t wNBytes); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* defined (USB) */ + +#ifdef __cplusplus +} +#endif + + +#endif /* STM32F0xx_LL_USB_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_utils.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_utils.h new file mode 100644 index 0000000..f2488cc --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_utils.h @@ -0,0 +1,274 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_utils.h + * @author MCD Application Team + * @brief Header file of UTILS LL module. + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The LL UTILS driver contains a set of generic APIs that can be + used by user: + (+) Device electronic signature + (+) Timing functions + (+) PLL configuration functions + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_LL_UTILS_H +#define __STM32F0xx_LL_UTILS_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +/** @defgroup UTILS_LL UTILS + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup UTILS_LL_Private_Constants UTILS Private Constants + * @{ + */ + +/* Max delay can be used in LL_mDelay */ +#define LL_MAX_DELAY 0xFFFFFFFFU + +/** + * @brief Unique device ID register base address + */ +#define UID_BASE_ADDRESS UID_BASE + +/** + * @brief Flash size data register base address + */ +#define FLASHSIZE_BASE_ADDRESS FLASHSIZE_BASE + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup UTILS_LL_Private_Macros UTILS Private Macros + * @{ + */ +/** + * @} + */ +/* Exported types ------------------------------------------------------------*/ +/** @defgroup UTILS_LL_ES_INIT UTILS Exported structures + * @{ + */ +/** + * @brief UTILS PLL structure definition + */ +typedef struct +{ + uint32_t PLLMul; /*!< Multiplication factor for PLL VCO input clock. + This parameter can be a value of @ref RCC_LL_EC_PLL_MUL + + This feature can be modified afterwards using unitary function + @ref LL_RCC_PLL_ConfigDomain_SYS(). */ + +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + uint32_t PLLDiv; /*!< Division factor for PLL VCO output clock. + This parameter can be a value of @ref RCC_LL_EC_PREDIV_DIV + + This feature can be modified afterwards using unitary function + @ref LL_RCC_PLL_ConfigDomain_SYS(). */ +#else + uint32_t Prediv; /*!< Division factor for HSE used as PLL clock source. + This parameter can be a value of @ref RCC_LL_EC_PREDIV_DIV + + This feature can be modified afterwards using unitary function + @ref LL_RCC_PLL_ConfigDomain_SYS(). */ +#endif /* RCC_PLLSRC_PREDIV1_SUPPORT */ +} LL_UTILS_PLLInitTypeDef; + +/** + * @brief UTILS System, AHB and APB buses clock configuration structure definition + */ +typedef struct +{ + uint32_t AHBCLKDivider; /*!< The AHB clock (HCLK) divider. This clock is derived from the system clock (SYSCLK). + This parameter can be a value of @ref RCC_LL_EC_SYSCLK_DIV + + This feature can be modified afterwards using unitary function + @ref LL_RCC_SetAHBPrescaler(). */ + + uint32_t APB1CLKDivider; /*!< The APB1 clock (PCLK1) divider. This clock is derived from the AHB clock (HCLK). + This parameter can be a value of @ref RCC_LL_EC_APB1_DIV + + This feature can be modified afterwards using unitary function + @ref LL_RCC_SetAPB1Prescaler(). */ +} LL_UTILS_ClkInitTypeDef; + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup UTILS_LL_Exported_Constants UTILS Exported Constants + * @{ + */ + +/** @defgroup UTILS_EC_HSE_BYPASS HSE Bypass activation + * @{ + */ +#define LL_UTILS_HSEBYPASS_OFF 0x00000000U /*!< HSE Bypass is not enabled */ +#define LL_UTILS_HSEBYPASS_ON 0x00000001U /*!< HSE Bypass is enabled */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup UTILS_LL_Exported_Functions UTILS Exported Functions + * @{ + */ + +/** @defgroup UTILS_EF_DEVICE_ELECTRONIC_SIGNATURE DEVICE ELECTRONIC SIGNATURE + * @{ + */ + +/** + * @brief Get Word0 of the unique device identifier (UID based on 96 bits) + * @retval UID[31:0]: X and Y coordinates on the wafer expressed in BCD format + */ +__STATIC_INLINE uint32_t LL_GetUID_Word0(void) +{ + return (uint32_t)(READ_REG(*((uint32_t *)UID_BASE_ADDRESS))); +} + +/** + * @brief Get Word1 of the unique device identifier (UID based on 96 bits) + * @retval UID[63:32]: Wafer number (UID[39:32]) & LOT_NUM[23:0] (UID[63:40]) + */ +__STATIC_INLINE uint32_t LL_GetUID_Word1(void) +{ + return (uint32_t)(READ_REG(*((uint32_t *)(UID_BASE_ADDRESS + 4U)))); +} + +/** + * @brief Get Word2 of the unique device identifier (UID based on 96 bits) + * @retval UID[95:64]: Lot number (ASCII encoded) - LOT_NUM[55:24] + */ +__STATIC_INLINE uint32_t LL_GetUID_Word2(void) +{ + return (uint32_t)(READ_REG(*((uint32_t *)(UID_BASE_ADDRESS + 8U)))); +} + +/** + * @brief Get Flash memory size + * @note This bitfield indicates the size of the device Flash memory expressed in + * Kbytes. As an example, 0x040 corresponds to 64 Kbytes. + * @retval FLASH_SIZE[15:0]: Flash memory size + */ +__STATIC_INLINE uint32_t LL_GetFlashSize(void) +{ + return (uint16_t)(READ_REG(*((uint32_t *)FLASHSIZE_BASE_ADDRESS))); +} + + +/** + * @} + */ + +/** @defgroup UTILS_LL_EF_DELAY DELAY + * @{ + */ + +/** + * @brief This function configures the Cortex-M SysTick source of the time base. + * @param HCLKFrequency HCLK frequency in Hz (can be calculated thanks to RCC helper macro) + * @note When a RTOS is used, it is recommended to avoid changing the SysTick + * configuration by calling this function, for a delay use rather osDelay RTOS service. + * @param Ticks Number of ticks + * @retval None + */ +__STATIC_INLINE void LL_InitTick(uint32_t HCLKFrequency, uint32_t Ticks) +{ + /* Configure the SysTick to have interrupt in 1ms time base */ + SysTick->LOAD = (uint32_t)((HCLKFrequency / Ticks) - 1UL); /* set reload register */ + SysTick->VAL = 0UL; /* Load the SysTick Counter Value */ + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | + SysTick_CTRL_ENABLE_Msk; /* Enable the Systick Timer */ +} + +void LL_Init1msTick(uint32_t HCLKFrequency); +void LL_mDelay(uint32_t Delay); + +/** + * @} + */ + +/** @defgroup UTILS_EF_SYSTEM SYSTEM + * @{ + */ + +void LL_SetSystemCoreClock(uint32_t HCLKFrequency); +#if defined(FLASH_ACR_LATENCY) +ErrorStatus LL_SetFlashLatency(uint32_t Frequency); +#endif /* FLASH_ACR_LATENCY */ +ErrorStatus LL_PLL_ConfigSystemClock_HSI(LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, + LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct); +#if defined(RCC_CFGR_SW_HSI48) +ErrorStatus LL_PLL_ConfigSystemClock_HSI48(LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, + LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct); +#endif /*RCC_CFGR_SW_HSI48*/ +ErrorStatus LL_PLL_ConfigSystemClock_HSE(uint32_t HSEFrequency, uint32_t HSEBypass, + LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_LL_UTILS_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_wwdg.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_wwdg.h new file mode 100644 index 0000000..d835f04 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_ll_wwdg.h @@ -0,0 +1,319 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_wwdg.h + * @author MCD Application Team + * @brief Header file of WWDG LL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_LL_WWDG_H +#define STM32F0xx_LL_WWDG_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (WWDG) + +/** @defgroup WWDG_LL WWDG + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup WWDG_LL_Exported_Constants WWDG Exported Constants + * @{ + */ + +/** @defgroup WWDG_LL_EC_IT IT Defines + * @brief IT defines which can be used with LL_WWDG_ReadReg and LL_WWDG_WriteReg functions + * @{ + */ +#define LL_WWDG_CFR_EWI WWDG_CFR_EWI +/** + * @} + */ + +/** @defgroup WWDG_LL_EC_PRESCALER PRESCALER + * @{ + */ +#define LL_WWDG_PRESCALER_1 0x00000000u /*!< WWDG counter clock = (PCLK1/4096)/1 */ +#define LL_WWDG_PRESCALER_2 WWDG_CFR_WDGTB_0 /*!< WWDG counter clock = (PCLK1/4096)/2 */ +#define LL_WWDG_PRESCALER_4 WWDG_CFR_WDGTB_1 /*!< WWDG counter clock = (PCLK1/4096)/4 */ +#define LL_WWDG_PRESCALER_8 (WWDG_CFR_WDGTB_0 | WWDG_CFR_WDGTB_1) /*!< WWDG counter clock = (PCLK1/4096)/8 */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup WWDG_LL_Exported_Macros WWDG Exported Macros + * @{ + */ +/** @defgroup WWDG_LL_EM_WRITE_READ Common Write and read registers macros + * @{ + */ +/** + * @brief Write a value in WWDG register + * @param __INSTANCE__ WWDG Instance + * @param __REG__ Register to be written + * @param __VALUE__ Value to be written in the register + * @retval None + */ +#define LL_WWDG_WriteReg(__INSTANCE__, __REG__, __VALUE__) WRITE_REG(__INSTANCE__->__REG__, (__VALUE__)) + +/** + * @brief Read a value in WWDG register + * @param __INSTANCE__ WWDG Instance + * @param __REG__ Register to be read + * @retval Register value + */ +#define LL_WWDG_ReadReg(__INSTANCE__, __REG__) READ_REG(__INSTANCE__->__REG__) +/** + * @} + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup WWDG_LL_Exported_Functions WWDG Exported Functions + * @{ + */ + +/** @defgroup WWDG_LL_EF_Configuration Configuration + * @{ + */ +/** + * @brief Enable Window Watchdog. The watchdog is always disabled after a reset. + * @note It is enabled by setting the WDGA bit in the WWDG_CR register, + * then it cannot be disabled again except by a reset. + * This bit is set by software and only cleared by hardware after a reset. + * When WDGA = 1, the watchdog can generate a reset. + * @rmtoll CR WDGA LL_WWDG_Enable + * @param WWDGx WWDG Instance + * @retval None + */ +__STATIC_INLINE void LL_WWDG_Enable(WWDG_TypeDef *WWDGx) +{ + SET_BIT(WWDGx->CR, WWDG_CR_WDGA); +} + +/** + * @brief Checks if Window Watchdog is enabled + * @rmtoll CR WDGA LL_WWDG_IsEnabled + * @param WWDGx WWDG Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_WWDG_IsEnabled(WWDG_TypeDef *WWDGx) +{ + return ((READ_BIT(WWDGx->CR, WWDG_CR_WDGA) == (WWDG_CR_WDGA)) ? 1UL : 0UL); +} + +/** + * @brief Set the Watchdog counter value to provided value (7-bits T[6:0]) + * @note When writing to the WWDG_CR register, always write 1 in the MSB b6 to avoid generating an immediate reset + * This counter is decremented every (4096 x 2expWDGTB) PCLK cycles + * A reset is produced when it rolls over from 0x40 to 0x3F (bit T6 becomes cleared) + * Setting the counter lower then 0x40 causes an immediate reset (if WWDG enabled) + * @rmtoll CR T LL_WWDG_SetCounter + * @param WWDGx WWDG Instance + * @param Counter 0..0x7F (7 bit counter value) + * @retval None + */ +__STATIC_INLINE void LL_WWDG_SetCounter(WWDG_TypeDef *WWDGx, uint32_t Counter) +{ + MODIFY_REG(WWDGx->CR, WWDG_CR_T, Counter); +} + +/** + * @brief Return current Watchdog Counter Value (7 bits counter value) + * @rmtoll CR T LL_WWDG_GetCounter + * @param WWDGx WWDG Instance + * @retval 7 bit Watchdog Counter value + */ +__STATIC_INLINE uint32_t LL_WWDG_GetCounter(WWDG_TypeDef *WWDGx) +{ + return (READ_BIT(WWDGx->CR, WWDG_CR_T)); +} + +/** + * @brief Set the time base of the prescaler (WDGTB). + * @note Prescaler is used to apply ratio on PCLK clock, so that Watchdog counter + * is decremented every (4096 x 2expWDGTB) PCLK cycles + * @rmtoll CFR WDGTB LL_WWDG_SetPrescaler + * @param WWDGx WWDG Instance + * @param Prescaler This parameter can be one of the following values: + * @arg @ref LL_WWDG_PRESCALER_1 + * @arg @ref LL_WWDG_PRESCALER_2 + * @arg @ref LL_WWDG_PRESCALER_4 + * @arg @ref LL_WWDG_PRESCALER_8 + * @retval None + */ +__STATIC_INLINE void LL_WWDG_SetPrescaler(WWDG_TypeDef *WWDGx, uint32_t Prescaler) +{ + MODIFY_REG(WWDGx->CFR, WWDG_CFR_WDGTB, Prescaler); +} + +/** + * @brief Return current Watchdog Prescaler Value + * @rmtoll CFR WDGTB LL_WWDG_GetPrescaler + * @param WWDGx WWDG Instance + * @retval Returned value can be one of the following values: + * @arg @ref LL_WWDG_PRESCALER_1 + * @arg @ref LL_WWDG_PRESCALER_2 + * @arg @ref LL_WWDG_PRESCALER_4 + * @arg @ref LL_WWDG_PRESCALER_8 + */ +__STATIC_INLINE uint32_t LL_WWDG_GetPrescaler(WWDG_TypeDef *WWDGx) +{ + return (READ_BIT(WWDGx->CFR, WWDG_CFR_WDGTB)); +} + +/** + * @brief Set the Watchdog Window value to be compared to the downcounter (7-bits W[6:0]). + * @note This window value defines when write in the WWDG_CR register + * to program Watchdog counter is allowed. + * Watchdog counter value update must occur only when the counter value + * is lower than the Watchdog window register value. + * Otherwise, a MCU reset is generated if the 7-bit Watchdog counter value + * (in the control register) is refreshed before the downcounter has reached + * the watchdog window register value. + * Physically is possible to set the Window lower then 0x40 but it is not recommended. + * To generate an immediate reset, it is possible to set the Counter lower than 0x40. + * @rmtoll CFR W LL_WWDG_SetWindow + * @param WWDGx WWDG Instance + * @param Window 0x00..0x7F (7 bit Window value) + * @retval None + */ +__STATIC_INLINE void LL_WWDG_SetWindow(WWDG_TypeDef *WWDGx, uint32_t Window) +{ + MODIFY_REG(WWDGx->CFR, WWDG_CFR_W, Window); +} + +/** + * @brief Return current Watchdog Window Value (7 bits value) + * @rmtoll CFR W LL_WWDG_GetWindow + * @param WWDGx WWDG Instance + * @retval 7 bit Watchdog Window value + */ +__STATIC_INLINE uint32_t LL_WWDG_GetWindow(WWDG_TypeDef *WWDGx) +{ + return (READ_BIT(WWDGx->CFR, WWDG_CFR_W)); +} + +/** + * @} + */ + +/** @defgroup WWDG_LL_EF_FLAG_Management FLAG_Management + * @{ + */ +/** + * @brief Indicates if the WWDG Early Wakeup Interrupt Flag is set or not. + * @note This bit is set by hardware when the counter has reached the value 0x40. + * It must be cleared by software by writing 0. + * A write of 1 has no effect. This bit is also set if the interrupt is not enabled. + * @rmtoll SR EWIF LL_WWDG_IsActiveFlag_EWKUP + * @param WWDGx WWDG Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_WWDG_IsActiveFlag_EWKUP(WWDG_TypeDef *WWDGx) +{ + return ((READ_BIT(WWDGx->SR, WWDG_SR_EWIF) == (WWDG_SR_EWIF)) ? 1UL : 0UL); +} + +/** + * @brief Clear WWDG Early Wakeup Interrupt Flag (EWIF) + * @rmtoll SR EWIF LL_WWDG_ClearFlag_EWKUP + * @param WWDGx WWDG Instance + * @retval None + */ +__STATIC_INLINE void LL_WWDG_ClearFlag_EWKUP(WWDG_TypeDef *WWDGx) +{ + WRITE_REG(WWDGx->SR, ~WWDG_SR_EWIF); +} + +/** + * @} + */ + +/** @defgroup WWDG_LL_EF_IT_Management IT_Management + * @{ + */ +/** + * @brief Enable the Early Wakeup Interrupt. + * @note When set, an interrupt occurs whenever the counter reaches value 0x40. + * This interrupt is only cleared by hardware after a reset + * @rmtoll CFR EWI LL_WWDG_EnableIT_EWKUP + * @param WWDGx WWDG Instance + * @retval None + */ +__STATIC_INLINE void LL_WWDG_EnableIT_EWKUP(WWDG_TypeDef *WWDGx) +{ + SET_BIT(WWDGx->CFR, WWDG_CFR_EWI); +} + +/** + * @brief Check if Early Wakeup Interrupt is enabled + * @rmtoll CFR EWI LL_WWDG_IsEnabledIT_EWKUP + * @param WWDGx WWDG Instance + * @retval State of bit (1 or 0). + */ +__STATIC_INLINE uint32_t LL_WWDG_IsEnabledIT_EWKUP(WWDG_TypeDef *WWDGx) +{ + return ((READ_BIT(WWDGx->CFR, WWDG_CFR_EWI) == (WWDG_CFR_EWI)) ? 1UL : 0UL); +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* WWDG */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_LL_WWDG_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/License.md b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/License.md new file mode 100644 index 0000000..cea8325 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/License.md @@ -0,0 +1,3 @@ +# Copyright (c) 2016 STMicroelectronics + +This software component is licensed by STMicroelectronics under the **BSD 3-Clause** license. You may not use this file except in compliance with this license. You may obtain a copy of the license [here](https://opensource.org/licenses/BSD-3-Clause). \ No newline at end of file diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal.c new file mode 100644 index 0000000..9d80f5e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal.c @@ -0,0 +1,514 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal.c + * @author MCD Application Team + * @brief HAL module driver. + * This is the common part of the HAL initialization + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The common HAL driver contains a set of generic and common APIs that can be + used by the PPP peripheral drivers and the user to start using the HAL. + [..] + The HAL contains two APIs categories: + (+) HAL Initialization and de-initialization functions + (+) HAL Control functions + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup HAL HAL + * @brief HAL module driver. + * @{ + */ + +#ifdef HAL_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup HAL_Private_Constants HAL Private Constants + * @{ + */ +/** + * @brief STM32F0xx HAL Driver version number V1.7.6 + */ +#define __STM32F0xx_HAL_VERSION_MAIN (0x01U) /*!< [31:24] main version */ +#define __STM32F0xx_HAL_VERSION_SUB1 (0x07U) /*!< [23:16] sub1 version */ +#define __STM32F0xx_HAL_VERSION_SUB2 (0x06U) /*!< [15:8] sub2 version */ +#define __STM32F0xx_HAL_VERSION_RC (0x00U) /*!< [7:0] release candidate */ +#define __STM32F0xx_HAL_VERSION ((__STM32F0xx_HAL_VERSION_MAIN << 24U)\ + |(__STM32F0xx_HAL_VERSION_SUB1 << 16U)\ + |(__STM32F0xx_HAL_VERSION_SUB2 << 8U )\ + |(__STM32F0xx_HAL_VERSION_RC)) + +#define IDCODE_DEVID_MASK (0x00000FFFU) +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/** @defgroup HAL_Private_Macros HAL Private Macros + * @{ + */ +/** + * @} + */ + +/* Exported variables ---------------------------------------------------------*/ +/** @defgroup HAL_Private_Variables HAL Exported Variables + * @{ + */ +__IO uint32_t uwTick; +uint32_t uwTickPrio = (1UL << __NVIC_PRIO_BITS); /* Invalid PRIO */ +HAL_TickFreqTypeDef uwTickFreq = HAL_TICK_FREQ_DEFAULT; /* 1KHz */ +/** + * @} + */ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup HAL_Exported_Functions HAL Exported Functions + * @{ + */ + +/** @defgroup HAL_Exported_Functions_Group1 Initialization and de-initialization Functions + * @brief Initialization and de-initialization functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Initializes the Flash interface, the NVIC allocation and initial clock + configuration. It initializes the systick also when timeout is needed + and the backup domain when enabled. + (+) de-Initializes common part of the HAL. + (+) Configure The time base source to have 1ms time base with a dedicated + Tick interrupt priority. + (++) SysTick timer is used by default as source of time base, but user + can eventually implement his proper time base source (a general purpose + timer for example or other time source), keeping in mind that Time base + duration should be kept 1ms since PPP_TIMEOUT_VALUEs are defined and + handled in milliseconds basis. + (++) Time base configuration function (HAL_InitTick ()) is called automatically + at the beginning of the program after reset by HAL_Init() or at any time + when clock is configured, by HAL_RCC_ClockConfig(). + (++) Source of time base is configured to generate interrupts at regular + time intervals. Care must be taken if HAL_Delay() is called from a + peripheral ISR process, the Tick interrupt line must have higher priority + (numerically lower) than the peripheral interrupt. Otherwise the caller + ISR process will be blocked. + (++) functions affecting time base configurations are declared as __Weak + to make override possible in case of other implementations in user file. + +@endverbatim + * @{ + */ + +/** + * @brief This function configures the Flash prefetch, + * Configures time base source, NVIC and Low level hardware + * @note This function is called at the beginning of program after reset and before + * the clock configuration + * @note The time base configuration is based on HSI clock when exiting from Reset. + * Once done, time base tick start incrementing. + * In the default implementation,Systick is used as source of time base. + * The tick variable is incremented each 1ms in its ISR. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_Init(void) +{ + /* Configure Flash prefetch */ +#if (PREFETCH_ENABLE != 0) + __HAL_FLASH_PREFETCH_BUFFER_ENABLE(); +#endif /* PREFETCH_ENABLE */ + + /* Use systick as time base source and configure 1ms tick (default clock after Reset is HSI) */ + + HAL_InitTick(TICK_INT_PRIORITY); + + /* Init the low level hardware */ + HAL_MspInit(); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief This function de-Initialize common part of the HAL and stops the SysTick + * of time base. + * @note This function is optional. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DeInit(void) +{ + /* Reset of all peripherals */ + __HAL_RCC_APB1_FORCE_RESET(); + __HAL_RCC_APB1_RELEASE_RESET(); + + __HAL_RCC_APB2_FORCE_RESET(); + __HAL_RCC_APB2_RELEASE_RESET(); + + __HAL_RCC_AHB_FORCE_RESET(); + __HAL_RCC_AHB_RELEASE_RESET(); + + /* De-Init the low level hardware */ + HAL_MspDeInit(); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Initialize the MSP. + * @retval None + */ +__weak void HAL_MspInit(void) +{ + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes the MSP. + * @retval None + */ +__weak void HAL_MspDeInit(void) +{ + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief This function configures the source of the time base. + * The time source is configured to have 1ms time base with a dedicated + * Tick interrupt priority. + * @note This function is called automatically at the beginning of program after + * reset by HAL_Init() or at any time when clock is reconfigured by HAL_RCC_ClockConfig(). + * @note In the default implementation, SysTick timer is the source of time base. + * It is used to generate interrupts at regular time intervals. + * Care must be taken if HAL_Delay() is called from a peripheral ISR process, + * The SysTick interrupt must have higher priority (numerically lower) + * than the peripheral interrupt. Otherwise the caller ISR process will be blocked. + * The function is declared as __Weak to be overwritten in case of other + * implementation in user file. + * @param TickPriority Tick interrupt priority. + * @retval HAL status + */ +__weak HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority) +{ + /*Configure the SysTick to have interrupt in 1ms time basis*/ + if (HAL_SYSTICK_Config(SystemCoreClock / (1000U / uwTickFreq)) > 0U) + { + return HAL_ERROR; + } + + /* Configure the SysTick IRQ priority */ + if (TickPriority < (1UL << __NVIC_PRIO_BITS)) + { + HAL_NVIC_SetPriority(SysTick_IRQn, TickPriority, 0U); + uwTickPrio = TickPriority; + } + else + { + return HAL_ERROR; + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup HAL_Exported_Functions_Group2 HAL Control functions + * @brief HAL Control functions + * +@verbatim + =============================================================================== + ##### HAL Control functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Provide a tick value in millisecond + (+) Provide a blocking delay in millisecond + (+) Suspend the time base source interrupt + (+) Resume the time base source interrupt + (+) Get the HAL API driver version + (+) Get the device identifier + (+) Get the device revision identifier + (+) Enable/Disable Debug module during Sleep mode + (+) Enable/Disable Debug module during STOP mode + (+) Enable/Disable Debug module during STANDBY mode + +@endverbatim + * @{ + */ + +/** + * @brief This function is called to increment a global variable "uwTick" + * used as application time base. + * @note In the default implementation, this variable is incremented each 1ms + * in SysTick ISR. + * @note This function is declared as __weak to be overwritten in case of other + * implementations in user file. + * @retval None + */ +__weak void HAL_IncTick(void) +{ + uwTick += uwTickFreq; +} + +/** + * @brief Provides a tick value in millisecond. + * @note This function is declared as __weak to be overwritten in case of other + * implementations in user file. + * @retval tick value + */ +__weak uint32_t HAL_GetTick(void) +{ + return uwTick; +} + +/** + * @brief This function returns a tick priority. + * @retval tick priority + */ +uint32_t HAL_GetTickPrio(void) +{ + return uwTickPrio; +} + +/** + * @brief Set new tick Freq. + * @retval status + */ +HAL_StatusTypeDef HAL_SetTickFreq(HAL_TickFreqTypeDef Freq) +{ + HAL_StatusTypeDef status = HAL_OK; + HAL_TickFreqTypeDef prevTickFreq; + + assert_param(IS_TICKFREQ(Freq)); + + if (uwTickFreq != Freq) + { + /* Back up uwTickFreq frequency */ + prevTickFreq = uwTickFreq; + + /* Update uwTickFreq global variable used by HAL_InitTick() */ + uwTickFreq = Freq; + + /* Apply the new tick Freq */ + status = HAL_InitTick(uwTickPrio); + + if (status != HAL_OK) + { + /* Restore previous tick frequency */ + uwTickFreq = prevTickFreq; + } + } + + return status; +} + +/** + * @brief return tick frequency. + * @retval tick period in Hz + */ +HAL_TickFreqTypeDef HAL_GetTickFreq(void) +{ + return uwTickFreq; +} + +/** + * @brief This function provides accurate delay (in milliseconds) based + * on variable incremented. + * @note In the default implementation , SysTick timer is the source of time base. + * It is used to generate interrupts at regular time intervals where uwTick + * is incremented. + * @note ThiS function is declared as __weak to be overwritten in case of other + * implementations in user file. + * @param Delay specifies the delay time length, in milliseconds. + * @retval None + */ +__weak void HAL_Delay(uint32_t Delay) +{ + uint32_t tickstart = HAL_GetTick(); + uint32_t wait = Delay; + + /* Add a freq to guarantee minimum wait */ + if (wait < HAL_MAX_DELAY) + { + wait += (uint32_t)(uwTickFreq); + } + + while((HAL_GetTick() - tickstart) < wait) + { + } +} + +/** + * @brief Suspend Tick increment. + * @note In the default implementation , SysTick timer is the source of time base. It is + * used to generate interrupts at regular time intervals. Once HAL_SuspendTick() + * is called, the the SysTick interrupt will be disabled and so Tick increment + * is suspended. + * @note This function is declared as __weak to be overwritten in case of other + * implementations in user file. + * @retval None + */ +__weak void HAL_SuspendTick(void) + +{ + /* Disable SysTick Interrupt */ + CLEAR_BIT(SysTick->CTRL,SysTick_CTRL_TICKINT_Msk); +} + +/** + * @brief Resume Tick increment. + * @note In the default implementation , SysTick timer is the source of time base. It is + * used to generate interrupts at regular time intervals. Once HAL_ResumeTick() + * is called, the the SysTick interrupt will be enabled and so Tick increment + * is resumed. + * @note This function is declared as __weak to be overwritten in case of other + * implementations in user file. + * @retval None + */ +__weak void HAL_ResumeTick(void) +{ + /* Enable SysTick Interrupt */ + SET_BIT(SysTick->CTRL,SysTick_CTRL_TICKINT_Msk); +} + +/** + * @brief This method returns the HAL revision + * @retval version 0xXYZR (8bits for each decimal, R for RC) + */ +uint32_t HAL_GetHalVersion(void) +{ + return __STM32F0xx_HAL_VERSION; +} + +/** + * @brief Returns the device revision identifier. + * @retval Device revision identifier + */ +uint32_t HAL_GetREVID(void) +{ + return((DBGMCU->IDCODE) >> 16U); +} + +/** + * @brief Returns the device identifier. + * @retval Device identifier + */ +uint32_t HAL_GetDEVID(void) +{ + return((DBGMCU->IDCODE) & IDCODE_DEVID_MASK); +} + +/** + * @brief Returns first word of the unique device identifier (UID based on 96 bits) + * @retval Device identifier + */ +uint32_t HAL_GetUIDw0(void) +{ + return(READ_REG(*((uint32_t *)UID_BASE))); +} + +/** + * @brief Returns second word of the unique device identifier (UID based on 96 bits) + * @retval Device identifier + */ +uint32_t HAL_GetUIDw1(void) +{ + return(READ_REG(*((uint32_t *)(UID_BASE + 4U)))); +} + +/** + * @brief Returns third word of the unique device identifier (UID based on 96 bits) + * @retval Device identifier + */ +uint32_t HAL_GetUIDw2(void) +{ + return(READ_REG(*((uint32_t *)(UID_BASE + 8U)))); +} + +/** + * @brief Enable the Debug Module during STOP mode + * @retval None + */ +void HAL_DBGMCU_EnableDBGStopMode(void) +{ + SET_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STOP); +} + +/** + * @brief Disable the Debug Module during STOP mode + * @retval None + */ +void HAL_DBGMCU_DisableDBGStopMode(void) +{ + CLEAR_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STOP); +} + +/** + * @brief Enable the Debug Module during STANDBY mode + * @retval None + */ +void HAL_DBGMCU_EnableDBGStandbyMode(void) +{ + SET_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STANDBY); +} + +/** + * @brief Disable the Debug Module during STANDBY mode + * @retval None + */ +void HAL_DBGMCU_DisableDBGStandbyMode(void) +{ + CLEAR_BIT(DBGMCU->CR, DBGMCU_CR_DBG_STANDBY); +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc.c new file mode 100644 index 0000000..3bcf1c1 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc.c @@ -0,0 +1,2497 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_adc.c + * @author MCD Application Team + * @brief This file provides firmware functions to manage the following + * functionalities of the Analog to Digital Convertor (ADC) + * peripheral: + * + Initialization and de-initialization functions + * ++ Initialization and Configuration of ADC + * + Operation functions + * ++ Start, stop, get result of conversions of regular + * group, using 3 possible modes: polling, interruption or DMA. + * + Control functions + * ++ Channels configuration on regular group + * ++ Analog Watchdog configuration + * + State functions + * ++ ADC state machine management + * ++ Interrupts and flags management + * Other functions (extended functions) are available in file + * "stm32f0xx_hal_adc_ex.c". + * + @verbatim + ============================================================================== + ##### ADC peripheral features ##### + ============================================================================== + [..] + (+) 12-bit, 10-bit, 8-bit or 6-bit configurable resolution + + (+) Interrupt generation at the end of regular conversion and in case of + analog watchdog or overrun events. + + (+) Single and continuous conversion modes. + + (+) Scan mode for conversion of several channels sequentially. + + (+) Data alignment with in-built data coherency. + + (+) Programmable sampling time (common for all channels) + + (+) ADC conversion of regular group. + + (+) External trigger (timer or EXTI) with configurable polarity + + (+) DMA request generation for transfer of conversions data of regular group. + + (+) ADC calibration + + (+) ADC supply requirements: 2.4 V to 3.6 V at full speed and down to 1.8 V at + slower speed. + + (+) ADC input range: from Vref- (connected to Vssa) to Vref+ (connected to + Vdda or to an external voltage reference). + + + ##### How to use this driver ##### + ============================================================================== + [..] + + *** Configuration of top level parameters related to ADC *** + ============================================================ + [..] + + (#) Enable the ADC interface + (++) As prerequisite, ADC clock must be configured at RCC top level. + Caution: On STM32F0, ADC clock frequency max is 14MHz (refer + to device datasheet). + Therefore, ADC clock prescaler must be configured in + function of ADC clock source frequency to remain below + this maximum frequency. + + (++) Two clock settings are mandatory: + (+++) ADC clock (core clock, also possibly conversion clock). + + (+++) ADC clock (conversions clock). + Two possible clock sources: synchronous clock derived from APB clock + or asynchronous clock derived from ADC dedicated HSI RC oscillator + 14MHz. + If asynchronous clock is selected, parameter "HSI14State" must be set either: + - to "...HSI14State = RCC_HSI14_ADC_CONTROL" to let the ADC control + the HSI14 oscillator enable/disable (if not used to supply the main + system clock): feature used if ADC mode LowPowerAutoPowerOff is + enabled. + - to "...HSI14State = RCC_HSI14_ON" to maintain the HSI14 oscillator + always enabled: can be used to supply the main system clock. + + (+++) Example: + Into HAL_ADC_MspInit() (recommended code location) or with + other device clock parameters configuration: + (+++) __HAL_RCC_ADC1_CLK_ENABLE(); (mandatory) + + HI14 enable or let under control of ADC: (optional: if asynchronous clock selected) + (+++) RCC_OscInitTypeDef RCC_OscInitStructure; + (+++) RCC_OscInitStructure.OscillatorType = RCC_OSCILLATORTYPE_HSI14; + (+++) RCC_OscInitStructure.HSI14CalibrationValue = RCC_HSI14CALIBRATION_DEFAULT; + (+++) RCC_OscInitStructure.HSI14State = RCC_HSI14_ADC_CONTROL; + (+++) RCC_OscInitStructure.PLL... (optional if used for system clock) + (+++) HAL_RCC_OscConfig(&RCC_OscInitStructure); + + (++) ADC clock source and clock prescaler are configured at ADC level with + parameter "ClockPrescaler" using function HAL_ADC_Init(). + + (#) ADC pins configuration + (++) Enable the clock for the ADC GPIOs + using macro __HAL_RCC_GPIOx_CLK_ENABLE() + (++) Configure these ADC pins in analog mode + using function HAL_GPIO_Init() + + (#) Optionally, in case of usage of ADC with interruptions: + (++) Configure the NVIC for ADC + using function HAL_NVIC_EnableIRQ(ADCx_IRQn) + (++) Insert the ADC interruption handler function HAL_ADC_IRQHandler() + into the function of corresponding ADC interruption vector + ADCx_IRQHandler(). + + (#) Optionally, in case of usage of DMA: + (++) Configure the DMA (DMA channel, mode normal or circular, ...) + using function HAL_DMA_Init(). + (++) Configure the NVIC for DMA + using function HAL_NVIC_EnableIRQ(DMAx_Channelx_IRQn) + (++) Insert the ADC interruption handler function HAL_ADC_IRQHandler() + into the function of corresponding DMA interruption vector + DMAx_Channelx_IRQHandler(). + + *** Configuration of ADC, group regular, channels parameters *** + ================================================================ + [..] + + (#) Configure the ADC parameters (resolution, data alignment, ...) + and regular group parameters (conversion trigger, sequencer, ...) + using function HAL_ADC_Init(). + + (#) Configure the channels for regular group parameters (channel number, + channel rank into sequencer, ..., into regular group) + using function HAL_ADC_ConfigChannel(). + + (#) Optionally, configure the analog watchdog parameters (channels + monitored, thresholds, ...) + using function HAL_ADC_AnalogWDGConfig(). + + *** Execution of ADC conversions *** + ==================================== + [..] + + (#) Optionally, perform an automatic ADC calibration to improve the + conversion accuracy + using function HAL_ADCEx_Calibration_Start(). + + (#) ADC driver can be used among three modes: polling, interruption, + transfer by DMA. + + (++) ADC conversion by polling: + (+++) Activate the ADC peripheral and start conversions + using function HAL_ADC_Start() + (+++) Wait for ADC conversion completion + using function HAL_ADC_PollForConversion() + (+++) Retrieve conversion results + using function HAL_ADC_GetValue() + (+++) Stop conversion and disable the ADC peripheral + using function HAL_ADC_Stop() + + (++) ADC conversion by interruption: + (+++) Activate the ADC peripheral and start conversions + using function HAL_ADC_Start_IT() + (+++) Wait for ADC conversion completion by call of function + HAL_ADC_ConvCpltCallback() + (this function must be implemented in user program) + (+++) Retrieve conversion results + using function HAL_ADC_GetValue() + (+++) Stop conversion and disable the ADC peripheral + using function HAL_ADC_Stop_IT() + + (++) ADC conversion with transfer by DMA: + (+++) Activate the ADC peripheral and start conversions + using function HAL_ADC_Start_DMA() + (+++) Wait for ADC conversion completion by call of function + HAL_ADC_ConvCpltCallback() or HAL_ADC_ConvHalfCpltCallback() + (these functions must be implemented in user program) + (+++) Conversion results are automatically transferred by DMA into + destination variable address. + (+++) Stop conversion and disable the ADC peripheral + using function HAL_ADC_Stop_DMA() + + [..] + + (@) Callback functions must be implemented in user program: + (+@) HAL_ADC_ErrorCallback() + (+@) HAL_ADC_LevelOutOfWindowCallback() (callback of analog watchdog) + (+@) HAL_ADC_ConvCpltCallback() + (+@) HAL_ADC_ConvHalfCpltCallback + + *** Deinitialization of ADC *** + ============================================================ + [..] + + (#) Disable the ADC interface + (++) ADC clock can be hard reset and disabled at RCC top level. + (++) Hard reset of ADC peripherals + using macro __ADCx_FORCE_RESET(), __ADCx_RELEASE_RESET(). + (++) ADC clock disable + using the equivalent macro/functions as configuration step. + (+++) Example: + Into HAL_ADC_MspDeInit() (recommended code location) or with + other device clock parameters configuration: + (+++) RCC_OscInitStructure.OscillatorType = RCC_OSCILLATORTYPE_HSI14; + (+++) RCC_OscInitStructure.HSI14State = RCC_HSI14_OFF; (if not used for system clock) + (+++) HAL_RCC_OscConfig(&RCC_OscInitStructure); + + (#) ADC pins configuration + (++) Disable the clock for the ADC GPIOs + using macro __HAL_RCC_GPIOx_CLK_DISABLE() + + (#) Optionally, in case of usage of ADC with interruptions: + (++) Disable the NVIC for ADC + using function HAL_NVIC_DisableIRQ(ADCx_IRQn) + + (#) Optionally, in case of usage of DMA: + (++) Deinitialize the DMA + using function HAL_DMA_DeInit(). + (++) Disable the NVIC for DMA + using function HAL_NVIC_DisableIRQ(DMAx_Channelx_IRQn) + + [..] + + *** Callback registration *** + ============================================= + [..] + + The compilation flag USE_HAL_ADC_REGISTER_CALLBACKS, when set to 1, + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_ADC_RegisterCallback() + to register an interrupt callback. + [..] + + Function HAL_ADC_RegisterCallback() allows to register following callbacks: + (+) ConvCpltCallback : ADC conversion complete callback + (+) ConvHalfCpltCallback : ADC conversion DMA half-transfer callback + (+) LevelOutOfWindowCallback : ADC analog watchdog 1 callback + (+) ErrorCallback : ADC error callback + (+) MspInitCallback : ADC Msp Init callback + (+) MspDeInitCallback : ADC Msp DeInit callback + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + [..] + + Use function HAL_ADC_UnRegisterCallback to reset a callback to the default + weak function. + [..] + + HAL_ADC_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) ConvCpltCallback : ADC conversion complete callback + (+) ConvHalfCpltCallback : ADC conversion DMA half-transfer callback + (+) LevelOutOfWindowCallback : ADC analog watchdog 1 callback + (+) ErrorCallback : ADC error callback + (+) MspInitCallback : ADC Msp Init callback + (+) MspDeInitCallback : ADC Msp DeInit callback + [..] + + By default, after the HAL_ADC_Init() and when the state is HAL_ADC_STATE_RESET + all callbacks are set to the corresponding weak functions: + examples HAL_ADC_ConvCpltCallback(), HAL_ADC_ErrorCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak functions in the HAL_ADC_Init()/ HAL_ADC_DeInit() only when + these callbacks are null (not registered beforehand). + [..] + + If MspInit or MspDeInit are not null, the HAL_ADC_Init()/ HAL_ADC_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state. + [..] + + Callbacks can be registered/unregistered in HAL_ADC_STATE_READY state only. + Exception done MspInit/MspDeInit functions that can be registered/unregistered + in HAL_ADC_STATE_READY or HAL_ADC_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + [..] + + Then, the user first registers the MspInit/MspDeInit user callbacks + using HAL_ADC_RegisterCallback() before calling HAL_ADC_DeInit() + or HAL_ADC_Init() function. + [..] + + When the compilation flag USE_HAL_ADC_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup ADC ADC + * @brief ADC HAL module driver + * @{ + */ + +#ifdef HAL_ADC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup ADC_Private_Constants ADC Private Constants + * @{ + */ + + /* Fixed timeout values for ADC calibration, enable settling time, disable */ + /* settling time. */ + /* Values defined to be higher than worst cases: low clock frequency, */ + /* maximum prescaler. */ + /* Ex of profile low frequency : Clock source at 0.1 MHz, ADC clock */ + /* prescaler 4, sampling time 7.5 ADC clock cycles, resolution 12 bits. */ + /* Unit: ms */ + #define ADC_ENABLE_TIMEOUT ( 2U) + #define ADC_DISABLE_TIMEOUT ( 2U) + #define ADC_STOP_CONVERSION_TIMEOUT ( 2U) + + /* Delay for ADC stabilization time. */ + /* Maximum delay is 1us (refer to device datasheet, parameter tSTAB). */ + /* Unit: us */ + #define ADC_STAB_DELAY_US ( 1U) + + /* Delay for temperature sensor stabilization time. */ + /* Maximum delay is 10us (refer to device datasheet, parameter tSTART). */ + /* Unit: us */ + #define ADC_TEMPSENSOR_DELAY_US ( 10U) + +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup ADC_Private_Functions ADC Private Functions + * @{ + */ +static HAL_StatusTypeDef ADC_Enable(ADC_HandleTypeDef* hadc); +static HAL_StatusTypeDef ADC_Disable(ADC_HandleTypeDef* hadc); +static HAL_StatusTypeDef ADC_ConversionStop(ADC_HandleTypeDef* hadc); +static void ADC_DMAConvCplt(DMA_HandleTypeDef *hdma); +static void ADC_DMAHalfConvCplt(DMA_HandleTypeDef *hdma); +static void ADC_DMAError(DMA_HandleTypeDef *hdma); +/** + * @} + */ + +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup ADC_Exported_Functions ADC Exported Functions + * @{ + */ + +/** @defgroup ADC_Exported_Functions_Group1 Initialization/de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Initialize and configure the ADC. + (+) De-initialize the ADC +@endverbatim + * @{ + */ + +/** + * @brief Initializes the ADC peripheral and regular group according to + * parameters specified in structure "ADC_InitTypeDef". + * @note As prerequisite, ADC clock must be configured at RCC top level + * depending on both possible clock sources: APB clock of HSI clock. + * See commented example code below that can be copied and uncommented + * into HAL_ADC_MspInit(). + * @note Possibility to update parameters on the fly: + * This function initializes the ADC MSP (HAL_ADC_MspInit()) only when + * coming from ADC state reset. Following calls to this function can + * be used to reconfigure some parameters of ADC_InitTypeDef + * structure on the fly, without modifying MSP configuration. If ADC + * MSP has to be modified again, HAL_ADC_DeInit() must be called + * before HAL_ADC_Init(). + * The setting of these parameters is conditioned to ADC state. + * For parameters constraints, see comments of structure + * "ADC_InitTypeDef". + * @note This function configures the ADC within 2 scopes: scope of entire + * ADC and scope of regular group. For parameters details, see comments + * of structure "ADC_InitTypeDef". + * @param hadc ADC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_Init(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + uint32_t tmpCFGR1 = 0U; + + /* Check ADC handle */ + if(hadc == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + assert_param(IS_ADC_CLOCKPRESCALER(hadc->Init.ClockPrescaler)); + assert_param(IS_ADC_RESOLUTION(hadc->Init.Resolution)); + assert_param(IS_ADC_DATA_ALIGN(hadc->Init.DataAlign)); + assert_param(IS_ADC_SCAN_MODE(hadc->Init.ScanConvMode)); + assert_param(IS_FUNCTIONAL_STATE(hadc->Init.ContinuousConvMode)); + assert_param(IS_FUNCTIONAL_STATE(hadc->Init.DiscontinuousConvMode)); + assert_param(IS_ADC_EXTTRIG_EDGE(hadc->Init.ExternalTrigConvEdge)); + assert_param(IS_ADC_EXTTRIG(hadc->Init.ExternalTrigConv)); + assert_param(IS_FUNCTIONAL_STATE(hadc->Init.DMAContinuousRequests)); + assert_param(IS_ADC_EOC_SELECTION(hadc->Init.EOCSelection)); + assert_param(IS_ADC_OVERRUN(hadc->Init.Overrun)); + assert_param(IS_FUNCTIONAL_STATE(hadc->Init.LowPowerAutoWait)); + assert_param(IS_FUNCTIONAL_STATE(hadc->Init.LowPowerAutoPowerOff)); + + /* As prerequisite, into HAL_ADC_MspInit(), ADC clock must be configured */ + /* at RCC top level depending on both possible clock sources: */ + /* APB clock or HSI clock. */ + /* Refer to header of this file for more details on clock enabling procedure*/ + + /* Actions performed only if ADC is coming from state reset: */ + /* - Initialization of ADC MSP */ + /* - ADC voltage regulator enable */ + if (hadc->State == HAL_ADC_STATE_RESET) + { + /* Initialize ADC error code */ + ADC_CLEAR_ERRORCODE(hadc); + + /* Allocate lock resource and initialize it */ + hadc->Lock = HAL_UNLOCKED; + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + /* Init the ADC Callback settings */ + hadc->ConvCpltCallback = HAL_ADC_ConvCpltCallback; /* Legacy weak callback */ + hadc->ConvHalfCpltCallback = HAL_ADC_ConvHalfCpltCallback; /* Legacy weak callback */ + hadc->LevelOutOfWindowCallback = HAL_ADC_LevelOutOfWindowCallback; /* Legacy weak callback */ + hadc->ErrorCallback = HAL_ADC_ErrorCallback; /* Legacy weak callback */ + + if (hadc->MspInitCallback == NULL) + { + hadc->MspInitCallback = HAL_ADC_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware */ + hadc->MspInitCallback(hadc); +#else + /* Init the low level hardware */ + HAL_ADC_MspInit(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + } + + /* Configuration of ADC parameters if previous preliminary actions are */ + /* correctly completed. */ + /* and if there is no conversion on going on regular group (ADC can be */ + /* enabled anyway, in case of call of this function to update a parameter */ + /* on the fly). */ + if (HAL_IS_BIT_CLR(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL) && + (tmp_hal_status == HAL_OK) && + (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) ) + { + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_BUSY_INTERNAL); + + /* Parameters update conditioned to ADC state: */ + /* Parameters that can be updated only when ADC is disabled: */ + /* - ADC clock mode */ + /* - ADC clock prescaler */ + /* - ADC resolution */ + if (ADC_IS_ENABLE(hadc) == RESET) + { + /* Some parameters of this register are not reset, since they are set */ + /* by other functions and must be kept in case of usage of this */ + /* function on the fly (update of a parameter of ADC_InitTypeDef */ + /* without needing to reconfigure all other ADC groups/channels */ + /* parameters): */ + /* - internal measurement paths: Vbat, temperature sensor, Vref */ + /* (set into HAL_ADC_ConfigChannel() ) */ + + /* Configuration of ADC resolution */ + MODIFY_REG(hadc->Instance->CFGR1, + ADC_CFGR1_RES , + hadc->Init.Resolution ); + + /* Configuration of ADC clock mode: clock source AHB or HSI with */ + /* selectable prescaler */ + MODIFY_REG(hadc->Instance->CFGR2 , + ADC_CFGR2_CKMODE , + hadc->Init.ClockPrescaler ); + } + + /* Configuration of ADC: */ + /* - discontinuous mode */ + /* - LowPowerAutoWait mode */ + /* - LowPowerAutoPowerOff mode */ + /* - continuous conversion mode */ + /* - overrun */ + /* - external trigger to start conversion */ + /* - external trigger polarity */ + /* - data alignment */ + /* - resolution */ + /* - scan direction */ + /* - DMA continuous request */ + hadc->Instance->CFGR1 &= ~( ADC_CFGR1_DISCEN | + ADC_CFGR1_AUTOFF | + ADC_CFGR1_AUTDLY | + ADC_CFGR1_CONT | + ADC_CFGR1_OVRMOD | + ADC_CFGR1_EXTSEL | + ADC_CFGR1_EXTEN | + ADC_CFGR1_ALIGN | + ADC_CFGR1_SCANDIR | + ADC_CFGR1_DMACFG ); + + tmpCFGR1 |= (ADC_CFGR1_AUTOWAIT((uint32_t)hadc->Init.LowPowerAutoWait) | + ADC_CFGR1_AUTOOFF((uint32_t)hadc->Init.LowPowerAutoPowerOff) | + ADC_CFGR1_CONTINUOUS((uint32_t)hadc->Init.ContinuousConvMode) | + ADC_CFGR1_OVERRUN(hadc->Init.Overrun) | + hadc->Init.DataAlign | + ADC_SCANDIR(hadc->Init.ScanConvMode) | + ADC_CFGR1_DMACONTREQ((uint32_t)hadc->Init.DMAContinuousRequests) ); + + /* Enable discontinuous mode only if continuous mode is disabled */ + if (hadc->Init.DiscontinuousConvMode == ENABLE) + { + if (hadc->Init.ContinuousConvMode == DISABLE) + { + /* Enable the selected ADC group regular discontinuous mode */ + tmpCFGR1 |= ADC_CFGR1_DISCEN; + } + else + { + /* ADC regular group discontinuous was intended to be enabled, */ + /* but ADC regular group modes continuous and sequencer discontinuous */ + /* cannot be enabled simultaneously. */ + + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + } + } + + /* Enable external trigger if trigger selection is different of software */ + /* start. */ + /* Note: This configuration keeps the hardware feature of parameter */ + /* ExternalTrigConvEdge "trigger edge none" equivalent to */ + /* software start. */ + if (hadc->Init.ExternalTrigConv != ADC_SOFTWARE_START) + { + tmpCFGR1 |= ( hadc->Init.ExternalTrigConv | + hadc->Init.ExternalTrigConvEdge ); + } + + /* Update ADC configuration register with previous settings */ + hadc->Instance->CFGR1 |= tmpCFGR1; + + /* Channel sampling time configuration */ + /* Management of parameters "SamplingTimeCommon" and "SamplingTime" */ + /* (obsolete): sampling time set in this function if parameter */ + /* "SamplingTimeCommon" has been set to a valid sampling time. */ + /* Otherwise, sampling time is set into ADC channel initialization */ + /* structure with parameter "SamplingTime" (obsolete). */ + if (IS_ADC_SAMPLE_TIME(hadc->Init.SamplingTimeCommon)) + { + /* Channel sampling time configuration */ + /* Clear the old sample time */ + hadc->Instance->SMPR &= ~(ADC_SMPR_SMP); + + /* Set the new sample time */ + hadc->Instance->SMPR |= ADC_SMPR_SET(hadc->Init.SamplingTimeCommon); + } + + /* Check back that ADC registers have effectively been configured to */ + /* ensure of no potential problem of ADC core IP clocking. */ + /* Check through register CFGR1 (excluding analog watchdog configuration: */ + /* set into separate dedicated function, and bits of ADC resolution set */ + /* out of temporary variable 'tmpCFGR1'). */ + if ((hadc->Instance->CFGR1 & ~(ADC_CFGR1_AWDCH | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL | ADC_CFGR1_RES)) + == tmpCFGR1) + { + /* Set ADC error code to none */ + ADC_CLEAR_ERRORCODE(hadc); + + /* Set the ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_BUSY_INTERNAL, + HAL_ADC_STATE_READY); + } + else + { + /* Update ADC state machine to error */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_BUSY_INTERNAL, + HAL_ADC_STATE_ERROR_INTERNAL); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + + tmp_hal_status = HAL_ERROR; + } + + } + else + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL); + + tmp_hal_status = HAL_ERROR; + } + + /* Return function status */ + return tmp_hal_status; +} + + +/** + * @brief Deinitialize the ADC peripheral registers to their default reset + * values, with deinitialization of the ADC MSP. + * @note For devices with several ADCs: reset of ADC common registers is done + * only if all ADCs sharing the same common group are disabled. + * If this is not the case, reset of these common parameters reset is + * bypassed without error reporting: it can be the intended behaviour in + * case of reset of a single ADC while the other ADCs sharing the same + * common group is still running. + * @param hadc ADC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_DeInit(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + /* Check ADC handle */ + if(hadc == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Set ADC state */ + SET_BIT(hadc->State, HAL_ADC_STATE_BUSY_INTERNAL); + + /* Stop potential conversion on going, on regular group */ + tmp_hal_status = ADC_ConversionStop(hadc); + + /* Disable ADC peripheral if conversions are effectively stopped */ + if (tmp_hal_status == HAL_OK) + { + /* Disable the ADC peripheral */ + tmp_hal_status = ADC_Disable(hadc); + + /* Check if ADC is effectively disabled */ + if (tmp_hal_status != HAL_ERROR) + { + /* Change ADC state */ + hadc->State = HAL_ADC_STATE_READY; + } + } + + + /* Configuration of ADC parameters if previous preliminary actions are */ + /* correctly completed. */ + if (tmp_hal_status != HAL_ERROR) + { + + /* ========== Reset ADC registers ========== */ + /* Reset register IER */ + __HAL_ADC_DISABLE_IT(hadc, (ADC_IT_AWD | ADC_IT_OVR | + ADC_IT_EOS | ADC_IT_EOC | + ADC_IT_EOSMP | ADC_IT_RDY ) ); + + /* Reset register ISR */ + __HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_AWD | ADC_FLAG_OVR | + ADC_FLAG_EOS | ADC_FLAG_EOC | + ADC_FLAG_EOSMP | ADC_FLAG_RDY ) ); + + /* Reset register CR */ + /* Bits ADC_CR_ADCAL, ADC_CR_ADSTP, ADC_CR_ADSTART are in access mode */ + /* "read-set": no direct reset applicable. */ + + /* Reset register CFGR1 */ + hadc->Instance->CFGR1 &= ~(ADC_CFGR1_AWDCH | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL | ADC_CFGR1_DISCEN | + ADC_CFGR1_AUTOFF | ADC_CFGR1_WAIT | ADC_CFGR1_CONT | ADC_CFGR1_OVRMOD | + ADC_CFGR1_EXTEN | ADC_CFGR1_EXTSEL | ADC_CFGR1_ALIGN | ADC_CFGR1_RES | + ADC_CFGR1_SCANDIR | ADC_CFGR1_DMACFG | ADC_CFGR1_DMAEN ); + + /* Reset register CFGR2 */ + /* Note: Update of ADC clock mode is conditioned to ADC state disabled: */ + /* already done above. */ + hadc->Instance->CFGR2 &= ~ADC_CFGR2_CKMODE; + + /* Reset register SMPR */ + hadc->Instance->SMPR &= ~ADC_SMPR_SMP; + + /* Reset register TR1 */ + hadc->Instance->TR &= ~(ADC_TR_HT | ADC_TR_LT); + + /* Reset register CHSELR */ + hadc->Instance->CHSELR &= ~(ADC_CHSELR_CHSEL18 | ADC_CHSELR_CHSEL17 | ADC_CHSELR_CHSEL16 | + ADC_CHSELR_CHSEL15 | ADC_CHSELR_CHSEL14 | ADC_CHSELR_CHSEL13 | ADC_CHSELR_CHSEL12 | + ADC_CHSELR_CHSEL11 | ADC_CHSELR_CHSEL10 | ADC_CHSELR_CHSEL9 | ADC_CHSELR_CHSEL8 | + ADC_CHSELR_CHSEL7 | ADC_CHSELR_CHSEL6 | ADC_CHSELR_CHSEL5 | ADC_CHSELR_CHSEL4 | + ADC_CHSELR_CHSEL3 | ADC_CHSELR_CHSEL2 | ADC_CHSELR_CHSEL1 | ADC_CHSELR_CHSEL0 ); + + /* Reset register DR */ + /* bits in access mode read only, no direct reset applicable*/ + + /* Reset register CCR */ + ADC->CCR &= ~(ADC_CCR_ALL); + + /* ========== Hard reset ADC peripheral ========== */ + /* Performs a global reset of the entire ADC peripheral: ADC state is */ + /* forced to a similar state after device power-on. */ + /* If needed, copy-paste and uncomment the following reset code into */ + /* function "void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)": */ + /* */ + /* __HAL_RCC_ADC1_FORCE_RESET() */ + /* __HAL_RCC_ADC1_RELEASE_RESET() */ + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + if (hadc->MspDeInitCallback == NULL) + { + hadc->MspDeInitCallback = HAL_ADC_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware */ + hadc->MspDeInitCallback(hadc); +#else + /* DeInit the low level hardware */ + HAL_ADC_MspDeInit(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + + /* Set ADC error code to none */ + ADC_CLEAR_ERRORCODE(hadc); + + /* Set ADC state */ + hadc->State = HAL_ADC_STATE_RESET; + } + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + /* Return function status */ + return tmp_hal_status; +} + + +/** + * @brief Initializes the ADC MSP. + * @param hadc ADC handle + * @retval None + */ +__weak void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hadc); + + /* NOTE : This function should not be modified. When the callback is needed, + function HAL_ADC_MspInit must be implemented in the user file. + */ +} + +/** + * @brief DeInitializes the ADC MSP. + * @param hadc ADC handle + * @retval None + */ +__weak void HAL_ADC_MspDeInit(ADC_HandleTypeDef* hadc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hadc); + + /* NOTE : This function should not be modified. When the callback is needed, + function HAL_ADC_MspDeInit must be implemented in the user file. + */ +} + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User ADC Callback + * To be used instead of the weak predefined callback + * @param hadc Pointer to a ADC_HandleTypeDef structure that contains + * the configuration information for the specified ADC. + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_ADC_CONVERSION_COMPLETE_CB_ID ADC conversion complete callback ID + * @arg @ref HAL_ADC_CONVERSION_HALF_CB_ID ADC conversion complete callback ID + * @arg @ref HAL_ADC_LEVEL_OUT_OF_WINDOW_1_CB_ID ADC analog watchdog 1 callback ID + * @arg @ref HAL_ADC_ERROR_CB_ID ADC error callback ID + * @arg @ref HAL_ADC_INJ_CONVERSION_COMPLETE_CB_ID ADC group injected conversion complete callback ID + * @arg @ref HAL_ADC_MSPINIT_CB_ID ADC Msp Init callback ID + * @arg @ref HAL_ADC_MSPDEINIT_CB_ID ADC Msp DeInit callback ID + * @arg @ref HAL_ADC_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_ADC_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_RegisterCallback(ADC_HandleTypeDef *hadc, HAL_ADC_CallbackIDTypeDef CallbackID, pADC_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hadc->ErrorCode |= HAL_ADC_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + if ((hadc->State & HAL_ADC_STATE_READY) != 0) + { + switch (CallbackID) + { + case HAL_ADC_CONVERSION_COMPLETE_CB_ID : + hadc->ConvCpltCallback = pCallback; + break; + + case HAL_ADC_CONVERSION_HALF_CB_ID : + hadc->ConvHalfCpltCallback = pCallback; + break; + + case HAL_ADC_LEVEL_OUT_OF_WINDOW_1_CB_ID : + hadc->LevelOutOfWindowCallback = pCallback; + break; + + case HAL_ADC_ERROR_CB_ID : + hadc->ErrorCallback = pCallback; + break; + + case HAL_ADC_MSPINIT_CB_ID : + hadc->MspInitCallback = pCallback; + break; + + case HAL_ADC_MSPDEINIT_CB_ID : + hadc->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hadc->ErrorCode |= HAL_ADC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_ADC_STATE_RESET == hadc->State) + { + switch (CallbackID) + { + case HAL_ADC_MSPINIT_CB_ID : + hadc->MspInitCallback = pCallback; + break; + + case HAL_ADC_MSPDEINIT_CB_ID : + hadc->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hadc->ErrorCode |= HAL_ADC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hadc->ErrorCode |= HAL_ADC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + return status; +} + +/** + * @brief Unregister a ADC Callback + * ADC callback is redirected to the weak predefined callback + * @param hadc Pointer to a ADC_HandleTypeDef structure that contains + * the configuration information for the specified ADC. + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_ADC_CONVERSION_COMPLETE_CB_ID ADC conversion complete callback ID + * @arg @ref HAL_ADC_CONVERSION_HALF_CB_ID ADC conversion complete callback ID + * @arg @ref HAL_ADC_LEVEL_OUT_OF_WINDOW_1_CB_ID ADC analog watchdog 1 callback ID + * @arg @ref HAL_ADC_ERROR_CB_ID ADC error callback ID + * @arg @ref HAL_ADC_INJ_CONVERSION_COMPLETE_CB_ID ADC group injected conversion complete callback ID + * @arg @ref HAL_ADC_MSPINIT_CB_ID ADC Msp Init callback ID + * @arg @ref HAL_ADC_MSPDEINIT_CB_ID ADC Msp DeInit callback ID + * @arg @ref HAL_ADC_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_ADC_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_UnRegisterCallback(ADC_HandleTypeDef *hadc, HAL_ADC_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + if ((hadc->State & HAL_ADC_STATE_READY) != 0) + { + switch (CallbackID) + { + case HAL_ADC_CONVERSION_COMPLETE_CB_ID : + hadc->ConvCpltCallback = HAL_ADC_ConvCpltCallback; + break; + + case HAL_ADC_CONVERSION_HALF_CB_ID : + hadc->ConvHalfCpltCallback = HAL_ADC_ConvHalfCpltCallback; + break; + + case HAL_ADC_LEVEL_OUT_OF_WINDOW_1_CB_ID : + hadc->LevelOutOfWindowCallback = HAL_ADC_LevelOutOfWindowCallback; + break; + + case HAL_ADC_ERROR_CB_ID : + hadc->ErrorCallback = HAL_ADC_ErrorCallback; + break; + + case HAL_ADC_MSPINIT_CB_ID : + hadc->MspInitCallback = HAL_ADC_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_ADC_MSPDEINIT_CB_ID : + hadc->MspDeInitCallback = HAL_ADC_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hadc->ErrorCode |= HAL_ADC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_ADC_STATE_RESET == hadc->State) + { + switch (CallbackID) + { + case HAL_ADC_MSPINIT_CB_ID : + hadc->MspInitCallback = HAL_ADC_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_ADC_MSPDEINIT_CB_ID : + hadc->MspDeInitCallback = HAL_ADC_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hadc->ErrorCode |= HAL_ADC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hadc->ErrorCode |= HAL_ADC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + return status; +} + +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup ADC_Exported_Functions_Group2 IO operation functions + * @brief IO operation functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Start conversion of regular group. + (+) Stop conversion of regular group. + (+) Poll for conversion complete on regular group. + (+) Poll for conversion event. + (+) Get result of regular channel conversion. + (+) Start conversion of regular group and enable interruptions. + (+) Stop conversion of regular group and disable interruptions. + (+) Handle ADC interrupt request + (+) Start conversion of regular group and enable DMA transfer. + (+) Stop conversion of regular group and disable ADC DMA transfer. +@endverbatim + * @{ + */ + +/** + * @brief Enables ADC, starts conversion of regular group. + * Interruptions enabled in this function: None. + * @param hadc ADC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_Start(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Perform ADC enable and conversion start if no conversion is on going */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Process locked */ + __HAL_LOCK(hadc); + + /* Enable the ADC peripheral */ + /* If low power mode AutoPowerOff is enabled, power-on/off phases are */ + /* performed automatically by hardware. */ + if (hadc->Init.LowPowerAutoPowerOff != ENABLE) + { + tmp_hal_status = ADC_Enable(hadc); + } + + /* Start conversion if ADC is effectively enabled */ + if (tmp_hal_status == HAL_OK) + { + /* Set ADC state */ + /* - Clear state bitfield related to regular group conversion results */ + /* - Set state bitfield related to regular operation */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_READY | HAL_ADC_STATE_REG_EOC | HAL_ADC_STATE_REG_OVR | HAL_ADC_STATE_REG_EOSMP, + HAL_ADC_STATE_REG_BUSY); + + /* Reset ADC all error code fields */ + ADC_CLEAR_ERRORCODE(hadc); + + /* Process unlocked */ + /* Unlock before starting ADC conversions: in case of potential */ + /* interruption, to let the process to ADC IRQ Handler. */ + __HAL_UNLOCK(hadc); + + /* Clear regular group conversion flag and overrun flag */ + /* (To ensure of no unknown state from potential previous ADC */ + /* operations) */ + __HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_EOC | ADC_FLAG_EOS | ADC_FLAG_OVR)); + + /* Enable conversion of regular group. */ + /* If software start has been selected, conversion starts immediately. */ + /* If external trigger has been selected, conversion will start at next */ + /* trigger event. */ + hadc->Instance->CR |= ADC_CR_ADSTART; + } + } + else + { + tmp_hal_status = HAL_BUSY; + } + + /* Return function status */ + return tmp_hal_status; +} + +/** + * @brief Stop ADC conversion of regular group, disable ADC peripheral. + * @param hadc ADC handle + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_ADC_Stop(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Process locked */ + __HAL_LOCK(hadc); + + /* 1. Stop potential conversion on going, on regular group */ + tmp_hal_status = ADC_ConversionStop(hadc); + + /* Disable ADC peripheral if conversions are effectively stopped */ + if (tmp_hal_status == HAL_OK) + { + /* 2. Disable the ADC peripheral */ + tmp_hal_status = ADC_Disable(hadc); + + /* Check if ADC is effectively disabled */ + if (tmp_hal_status == HAL_OK) + { + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_READY); + } + } + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + /* Return function status */ + return tmp_hal_status; +} + +/** + * @brief Wait for regular group conversion to be completed. + * @note ADC conversion flags EOS (end of sequence) and EOC (end of + * conversion) are cleared by this function, with an exception: + * if low power feature "LowPowerAutoWait" is enabled, flags are + * not cleared to not interfere with this feature until data register + * is read using function HAL_ADC_GetValue(). + * @note This function cannot be used in a particular setup: ADC configured + * in DMA mode and polling for end of each conversion (ADC init + * parameter "EOCSelection" set to ADC_EOC_SINGLE_CONV). + * In this case, DMA resets the flag EOC and polling cannot be + * performed on each conversion. Nevertheless, polling can still + * be performed on the complete sequence (ADC init + * parameter "EOCSelection" set to ADC_EOC_SEQ_CONV). + * @param hadc ADC handle + * @param Timeout Timeout value in millisecond. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_PollForConversion(ADC_HandleTypeDef* hadc, uint32_t Timeout) +{ + uint32_t tickstart; + uint32_t tmp_Flag_EOC; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* If end of conversion selected to end of sequence */ + if (hadc->Init.EOCSelection == ADC_EOC_SEQ_CONV) + { + tmp_Flag_EOC = ADC_FLAG_EOS; + } + /* If end of conversion selected to end of each conversion */ + else /* ADC_EOC_SINGLE_CONV */ + { + /* Verification that ADC configuration is compliant with polling for */ + /* each conversion: */ + /* Particular case is ADC configured in DMA mode and ADC sequencer with */ + /* several ranks and polling for end of each conversion. */ + /* For code simplicity sake, this particular case is generalized to */ + /* ADC configured in DMA mode and and polling for end of each conversion. */ + if (HAL_IS_BIT_SET(hadc->Instance->CFGR1, ADC_CFGR1_DMAEN)) + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + return HAL_ERROR; + } + else + { + tmp_Flag_EOC = (ADC_FLAG_EOC | ADC_FLAG_EOS); + } + } + + /* Get tick count */ + tickstart = HAL_GetTick(); + + /* Wait until End of Conversion flag is raised */ + while(HAL_IS_BIT_CLR(hadc->Instance->ISR, tmp_Flag_EOC)) + { + /* Check if timeout is disabled (set to infinite wait) */ + if(Timeout != HAL_MAX_DELAY) + { + if((Timeout == 0) || ((HAL_GetTick()-tickstart) > Timeout)) + { + /* New check to avoid false timeout detection in case of preemption */ + if(HAL_IS_BIT_CLR(hadc->Instance->ISR, tmp_Flag_EOC)) + { + /* Update ADC state machine to timeout */ + SET_BIT(hadc->State, HAL_ADC_STATE_TIMEOUT); + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + return HAL_TIMEOUT; + } + } + } + } + + /* Update ADC state machine */ + SET_BIT(hadc->State, HAL_ADC_STATE_REG_EOC); + + /* Determine whether any further conversion upcoming on group regular */ + /* by external trigger, continuous mode or scan sequence on going. */ + if(ADC_IS_SOFTWARE_START_REGULAR(hadc) && + (hadc->Init.ContinuousConvMode == DISABLE) ) + { + /* If End of Sequence is reached, disable interrupts */ + if( __HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) ) + { + /* Allowed to modify bits ADC_IT_EOC/ADC_IT_EOS only if bit */ + /* ADSTART==0 (no conversion on going) */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Disable ADC end of single conversion interrupt on group regular */ + /* Note: Overrun interrupt was enabled with EOC interrupt in */ + /* HAL_Start_IT(), but is not disabled here because can be used */ + /* by overrun IRQ process below. */ + __HAL_ADC_DISABLE_IT(hadc, ADC_IT_EOC | ADC_IT_EOS); + + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_READY); + } + else + { + /* Change ADC state to error state */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + } + } + } + + /* Clear end of conversion flag of regular group if low power feature */ + /* "LowPowerAutoWait " is disabled, to not interfere with this feature */ + /* until data register is read using function HAL_ADC_GetValue(). */ + if (hadc->Init.LowPowerAutoWait == DISABLE) + { + /* Clear regular group conversion flag */ + __HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_EOC | ADC_FLAG_EOS)); + } + + /* Return ADC state */ + return HAL_OK; +} + +/** + * @brief Poll for conversion event. + * @param hadc ADC handle + * @param EventType the ADC event type. + * This parameter can be one of the following values: + * @arg ADC_AWD_EVENT: ADC Analog watchdog event + * @arg ADC_OVR_EVENT: ADC Overrun event + * @param Timeout Timeout value in millisecond. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_PollForEvent(ADC_HandleTypeDef* hadc, uint32_t EventType, uint32_t Timeout) +{ + uint32_t tickstart=0; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + assert_param(IS_ADC_EVENT_TYPE(EventType)); + + /* Get tick count */ + tickstart = HAL_GetTick(); + + /* Check selected event flag */ + while(__HAL_ADC_GET_FLAG(hadc, EventType) == RESET) + { + /* Check if timeout is disabled (set to infinite wait) */ + if(Timeout != HAL_MAX_DELAY) + { + if((Timeout == 0U) || ((HAL_GetTick()-tickstart) > Timeout)) + { + /* New check to avoid false timeout detection in case of preemption */ + if(__HAL_ADC_GET_FLAG(hadc, EventType) == RESET) + { + /* Update ADC state machine to timeout */ + SET_BIT(hadc->State, HAL_ADC_STATE_TIMEOUT); + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + return HAL_TIMEOUT; + } + } + } + } + + switch(EventType) + { + /* Analog watchdog (level out of window) event */ + case ADC_AWD_EVENT: + /* Set ADC state */ + SET_BIT(hadc->State, HAL_ADC_STATE_AWD1); + + /* Clear ADC analog watchdog flag */ + __HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_AWD); + break; + + /* Overrun event */ + default: /* Case ADC_OVR_EVENT */ + /* If overrun is set to overwrite previous data, overrun event is not */ + /* considered as an error. */ + /* (cf ref manual "Managing conversions without using the DMA and without */ + /* overrun ") */ + if (hadc->Init.Overrun == ADC_OVR_DATA_PRESERVED) + { + /* Set ADC state */ + SET_BIT(hadc->State, HAL_ADC_STATE_REG_OVR); + + /* Set ADC error code to overrun */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_OVR); + } + + /* Clear ADC Overrun flag */ + __HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_OVR); + break; + } + + /* Return ADC state */ + return HAL_OK; +} + +/** + * @brief Enables ADC, starts conversion of regular group with interruption. + * Interruptions enabled in this function: + * - EOC (end of conversion of regular group) or EOS (end of + * sequence of regular group) depending on ADC initialization + * parameter "EOCSelection" + * - overrun (if available) + * Each of these interruptions has its dedicated callback function. + * @param hadc ADC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_Start_IT(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Perform ADC enable and conversion start if no conversion is on going */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Process locked */ + __HAL_LOCK(hadc); + + /* Enable the ADC peripheral */ + /* If low power mode AutoPowerOff is enabled, power-on/off phases are */ + /* performed automatically by hardware. */ + if (hadc->Init.LowPowerAutoPowerOff != ENABLE) + { + tmp_hal_status = ADC_Enable(hadc); + } + + /* Start conversion if ADC is effectively enabled */ + if (tmp_hal_status == HAL_OK) + { + /* Set ADC state */ + /* - Clear state bitfield related to regular group conversion results */ + /* - Set state bitfield related to regular operation */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_READY | HAL_ADC_STATE_REG_EOC | HAL_ADC_STATE_REG_OVR | HAL_ADC_STATE_REG_EOSMP, + HAL_ADC_STATE_REG_BUSY); + + /* Reset ADC all error code fields */ + ADC_CLEAR_ERRORCODE(hadc); + + /* Process unlocked */ + /* Unlock before starting ADC conversions: in case of potential */ + /* interruption, to let the process to ADC IRQ Handler. */ + __HAL_UNLOCK(hadc); + + /* Clear regular group conversion flag and overrun flag */ + /* (To ensure of no unknown state from potential previous ADC */ + /* operations) */ + __HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_EOC | ADC_FLAG_EOS | ADC_FLAG_OVR)); + + /* Enable ADC end of conversion interrupt */ + /* Enable ADC overrun interrupt */ + switch(hadc->Init.EOCSelection) + { + case ADC_EOC_SEQ_CONV: + __HAL_ADC_DISABLE_IT(hadc, ADC_IT_EOC); + __HAL_ADC_ENABLE_IT(hadc, (ADC_IT_EOS | ADC_IT_OVR)); + break; + /* case ADC_EOC_SINGLE_CONV */ + default: + __HAL_ADC_ENABLE_IT(hadc, (ADC_IT_EOC | ADC_IT_EOS | ADC_IT_OVR)); + break; + } + + /* Enable conversion of regular group. */ + /* If software start has been selected, conversion starts immediately. */ + /* If external trigger has been selected, conversion will start at next */ + /* trigger event. */ + hadc->Instance->CR |= ADC_CR_ADSTART; + } + } + else + { + tmp_hal_status = HAL_BUSY; + } + + /* Return function status */ + return tmp_hal_status; +} + + +/** + * @brief Stop ADC conversion of regular group, disable interruption of + * end-of-conversion, disable ADC peripheral. + * @param hadc ADC handle + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_ADC_Stop_IT(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Process locked */ + __HAL_LOCK(hadc); + + /* 1. Stop potential conversion on going, on regular group */ + tmp_hal_status = ADC_ConversionStop(hadc); + + /* Disable ADC peripheral if conversions are effectively stopped */ + if (tmp_hal_status == HAL_OK) + { + /* Disable ADC end of conversion interrupt for regular group */ + /* Disable ADC overrun interrupt */ + __HAL_ADC_DISABLE_IT(hadc, (ADC_IT_EOC | ADC_IT_EOS | ADC_IT_OVR)); + + /* 2. Disable the ADC peripheral */ + tmp_hal_status = ADC_Disable(hadc); + + /* Check if ADC is effectively disabled */ + if (tmp_hal_status == HAL_OK) + { + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_READY); + } + } + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + /* Return function status */ + return tmp_hal_status; +} + +/** + * @brief Enables ADC, starts conversion of regular group and transfers result + * through DMA. + * Interruptions enabled in this function: + * - DMA transfer complete + * - DMA half transfer + * - overrun + * Each of these interruptions has its dedicated callback function. + * @param hadc ADC handle + * @param pData The destination Buffer address. + * @param Length The length of data to be transferred from ADC peripheral to memory. + * @retval None + */ +HAL_StatusTypeDef HAL_ADC_Start_DMA(ADC_HandleTypeDef* hadc, uint32_t* pData, uint32_t Length) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Perform ADC enable and conversion start if no conversion is on going */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Process locked */ + __HAL_LOCK(hadc); + + /* Enable the ADC peripheral */ + /* If low power mode AutoPowerOff is enabled, power-on/off phases are */ + /* performed automatically by hardware. */ + if (hadc->Init.LowPowerAutoPowerOff != ENABLE) + { + tmp_hal_status = ADC_Enable(hadc); + } + + /* Start conversion if ADC is effectively enabled */ + if (tmp_hal_status == HAL_OK) + { + /* Set ADC state */ + /* - Clear state bitfield related to regular group conversion results */ + /* - Set state bitfield related to regular operation */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_READY | HAL_ADC_STATE_REG_EOC | HAL_ADC_STATE_REG_OVR | HAL_ADC_STATE_REG_EOSMP, + HAL_ADC_STATE_REG_BUSY); + + /* Reset ADC all error code fields */ + ADC_CLEAR_ERRORCODE(hadc); + + /* Process unlocked */ + /* Unlock before starting ADC conversions: in case of potential */ + /* interruption, to let the process to ADC IRQ Handler. */ + __HAL_UNLOCK(hadc); + + /* Set the DMA transfer complete callback */ + hadc->DMA_Handle->XferCpltCallback = ADC_DMAConvCplt; + + /* Set the DMA half transfer complete callback */ + hadc->DMA_Handle->XferHalfCpltCallback = ADC_DMAHalfConvCplt; + + /* Set the DMA error callback */ + hadc->DMA_Handle->XferErrorCallback = ADC_DMAError; + + + /* Manage ADC and DMA start: ADC overrun interruption, DMA start, ADC */ + /* start (in case of SW start): */ + + /* Clear regular group conversion flag and overrun flag */ + /* (To ensure of no unknown state from potential previous ADC */ + /* operations) */ + __HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_EOC | ADC_FLAG_EOS | ADC_FLAG_OVR)); + + /* Enable ADC overrun interrupt */ + __HAL_ADC_ENABLE_IT(hadc, ADC_IT_OVR); + + /* Enable ADC DMA mode */ + hadc->Instance->CFGR1 |= ADC_CFGR1_DMAEN; + + /* Start the DMA channel */ + HAL_DMA_Start_IT(hadc->DMA_Handle, (uint32_t)&hadc->Instance->DR, (uint32_t)pData, Length); + + /* Enable conversion of regular group. */ + /* If software start has been selected, conversion starts immediately. */ + /* If external trigger has been selected, conversion will start at next */ + /* trigger event. */ + hadc->Instance->CR |= ADC_CR_ADSTART; + } + } + else + { + tmp_hal_status = HAL_BUSY; + } + + /* Return function status */ + return tmp_hal_status; +} + +/** + * @brief Stop ADC conversion of regular group, disable ADC DMA transfer, disable + * ADC peripheral. + * Each of these interruptions has its dedicated callback function. + * @param hadc ADC handle + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_ADC_Stop_DMA(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Process locked */ + __HAL_LOCK(hadc); + + /* 1. Stop potential conversion on going, on regular group */ + tmp_hal_status = ADC_ConversionStop(hadc); + + /* Disable ADC peripheral if conversions are effectively stopped */ + if (tmp_hal_status == HAL_OK) + { + /* Disable ADC DMA (ADC DMA configuration ADC_CFGR_DMACFG is kept) */ + hadc->Instance->CFGR1 &= ~ADC_CFGR1_DMAEN; + + /* Disable the DMA channel (in case of DMA in circular mode or stop while */ + /* while DMA transfer is on going) */ + if (hadc->DMA_Handle->State == HAL_DMA_STATE_BUSY) + { + tmp_hal_status = HAL_DMA_Abort(hadc->DMA_Handle); + + /* Check if DMA channel effectively disabled */ + if (tmp_hal_status != HAL_OK) + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_DMA); + } + } + + /* Disable ADC overrun interrupt */ + __HAL_ADC_DISABLE_IT(hadc, ADC_IT_OVR); + + /* 2. Disable the ADC peripheral */ + /* Update "tmp_hal_status" only if DMA channel disabling passed, to keep */ + /* in memory a potential failing status. */ + if (tmp_hal_status == HAL_OK) + { + tmp_hal_status = ADC_Disable(hadc); + } + else + { + ADC_Disable(hadc); + } + + /* Check if ADC is effectively disabled */ + if (tmp_hal_status == HAL_OK) + { + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_READY); + } + + } + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + /* Return function status */ + return tmp_hal_status; +} + +/** + * @brief Get ADC regular group conversion result. + * @note Reading register DR automatically clears ADC flag EOC + * (ADC group regular end of unitary conversion). + * @note This function does not clear ADC flag EOS + * (ADC group regular end of sequence conversion). + * Occurrence of flag EOS rising: + * - If sequencer is composed of 1 rank, flag EOS is equivalent + * to flag EOC. + * - If sequencer is composed of several ranks, during the scan + * sequence flag EOC only is raised, at the end of the scan sequence + * both flags EOC and EOS are raised. + * To clear this flag, either use function: + * in programming model IT: @ref HAL_ADC_IRQHandler(), in programming + * model polling: @ref HAL_ADC_PollForConversion() + * or @ref __HAL_ADC_CLEAR_FLAG(&hadc, ADC_FLAG_EOS). + * @param hadc ADC handle + * @retval ADC group regular conversion data + */ +uint32_t HAL_ADC_GetValue(ADC_HandleTypeDef* hadc) +{ + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Note: EOC flag is not cleared here by software because automatically */ + /* cleared by hardware when reading register DR. */ + + /* Return ADC converted value */ + return hadc->Instance->DR; +} + +/** + * @brief Handles ADC interrupt request. + * @param hadc ADC handle + * @retval None + */ +void HAL_ADC_IRQHandler(ADC_HandleTypeDef* hadc) +{ + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + assert_param(IS_FUNCTIONAL_STATE(hadc->Init.ContinuousConvMode)); + assert_param(IS_ADC_EOC_SELECTION(hadc->Init.EOCSelection)); + + /* ========== Check End of Conversion flag for regular group ========== */ + if( (__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOC) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_EOC)) || + (__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_EOS)) ) + { + /* Update state machine on conversion status if not in error state */ + if (HAL_IS_BIT_CLR(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL)) + { + /* Set ADC state */ + SET_BIT(hadc->State, HAL_ADC_STATE_REG_EOC); + } + + /* Determine whether any further conversion upcoming on group regular */ + /* by external trigger, continuous mode or scan sequence on going. */ + if(ADC_IS_SOFTWARE_START_REGULAR(hadc) && + (hadc->Init.ContinuousConvMode == DISABLE) ) + { + /* If End of Sequence is reached, disable interrupts */ + if( __HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) ) + { + /* Allowed to modify bits ADC_IT_EOC/ADC_IT_EOS only if bit */ + /* ADSTART==0 (no conversion on going) */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Disable ADC end of single conversion interrupt on group regular */ + /* Note: Overrun interrupt was enabled with EOC interrupt in */ + /* HAL_Start_IT(), but is not disabled here because can be used */ + /* by overrun IRQ process below. */ + __HAL_ADC_DISABLE_IT(hadc, ADC_IT_EOC | ADC_IT_EOS); + + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_READY); + } + else + { + /* Change ADC state to error state */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + } + } + } + + /* Note: into callback, to determine if conversion has been triggered */ + /* from EOC or EOS, possibility to use: */ + /* " if( __HAL_ADC_GET_FLAG(&hadc, ADC_FLAG_EOS)) " */ +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + hadc->ConvCpltCallback(hadc); +#else + HAL_ADC_ConvCpltCallback(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + + + /* Clear regular group conversion flag */ + /* Note: in case of overrun set to ADC_OVR_DATA_PRESERVED, end of */ + /* conversion flags clear induces the release of the preserved data.*/ + /* Therefore, if the preserved data value is needed, it must be */ + /* read preliminarily into HAL_ADC_ConvCpltCallback(). */ + __HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_EOC | ADC_FLAG_EOS) ); + } + + /* ========== Check Analog watchdog flags ========== */ + if(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_AWD) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_AWD)) + { + /* Set ADC state */ + SET_BIT(hadc->State, HAL_ADC_STATE_AWD1); + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + hadc->LevelOutOfWindowCallback(hadc); +#else + HAL_ADC_LevelOutOfWindowCallback(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + + /* Clear ADC Analog watchdog flag */ + __HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_AWD); + + } + + + /* ========== Check Overrun flag ========== */ + if(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_OVR) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_OVR)) + { + /* If overrun is set to overwrite previous data (default setting), */ + /* overrun event is not considered as an error. */ + /* (cf ref manual "Managing conversions without using the DMA and without */ + /* overrun ") */ + /* Exception for usage with DMA overrun event always considered as an */ + /* error. */ + if ((hadc->Init.Overrun == ADC_OVR_DATA_PRESERVED) || + HAL_IS_BIT_SET(hadc->Instance->CFGR1, ADC_CFGR1_DMAEN) ) + { + /* Set ADC error code to overrun */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_OVR); + + /* Clear ADC overrun flag */ + __HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_OVR); + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + hadc->ErrorCallback(hadc); +#else + HAL_ADC_ErrorCallback(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + } + + /* Clear the Overrun flag */ + __HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_OVR); + } + +} + + +/** + * @brief Conversion complete callback in non blocking mode + * @param hadc ADC handle + * @retval None + */ +__weak void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hadc); + + /* NOTE : This function should not be modified. When the callback is needed, + function HAL_ADC_ConvCpltCallback must be implemented in the user file. + */ +} + +/** + * @brief Conversion DMA half-transfer callback in non blocking mode + * @param hadc ADC handle + * @retval None + */ +__weak void HAL_ADC_ConvHalfCpltCallback(ADC_HandleTypeDef* hadc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hadc); + + /* NOTE : This function should not be modified. When the callback is needed, + function HAL_ADC_ConvHalfCpltCallback must be implemented in the user file. + */ +} + +/** + * @brief Analog watchdog callback in non blocking mode. + * @param hadc ADC handle + * @retval None + */ +__weak void HAL_ADC_LevelOutOfWindowCallback(ADC_HandleTypeDef* hadc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hadc); + + /* NOTE : This function should not be modified. When the callback is needed, + function HAL_ADC_LevelOoutOfWindowCallback must be implemented in the user file. + */ +} + +/** + * @brief ADC error callback in non blocking mode + * (ADC conversion with interruption or transfer by DMA) + * @param hadc ADC handle + * @retval None + */ +__weak void HAL_ADC_ErrorCallback(ADC_HandleTypeDef *hadc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hadc); + + /* NOTE : This function should not be modified. When the callback is needed, + function HAL_ADC_ErrorCallback must be implemented in the user file. + */ +} + + +/** + * @} + */ + +/** @defgroup ADC_Exported_Functions_Group3 Peripheral Control functions + * @brief Peripheral Control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Configure channels on regular group + (+) Configure the analog watchdog + +@endverbatim + * @{ + */ + +/** + * @brief Configures the the selected channel to be linked to the regular + * group. + * @note In case of usage of internal measurement channels: + * VrefInt/Vbat/TempSensor. + * Sampling time constraints must be respected (sampling time can be + * adjusted in function of ADC clock frequency and sampling time + * setting). + * Refer to device datasheet for timings values, parameters TS_vrefint, + * TS_vbat, TS_temp (values rough order: 5us to 17us). + * These internal paths can be be disabled using function + * HAL_ADC_DeInit(). + * @note Possibility to update parameters on the fly: + * This function initializes channel into regular group, following + * calls to this function can be used to reconfigure some parameters + * of structure "ADC_ChannelConfTypeDef" on the fly, without reseting + * the ADC. + * The setting of these parameters is conditioned to ADC state. + * For parameters constraints, see comments of structure + * "ADC_ChannelConfTypeDef". + * @param hadc ADC handle + * @param sConfig Structure of ADC channel for regular group. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_ConfigChannel(ADC_HandleTypeDef* hadc, ADC_ChannelConfTypeDef* sConfig) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + __IO uint32_t wait_loop_index = 0U; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + assert_param(IS_ADC_CHANNEL(sConfig->Channel)); + assert_param(IS_ADC_RANK(sConfig->Rank)); + + if (! IS_ADC_SAMPLE_TIME(hadc->Init.SamplingTimeCommon)) + { + assert_param(IS_ADC_SAMPLE_TIME(sConfig->SamplingTime)); + } + + /* Process locked */ + __HAL_LOCK(hadc); + + /* Parameters update conditioned to ADC state: */ + /* Parameters that can be updated when ADC is disabled or enabled without */ + /* conversion on going on regular group: */ + /* - Channel number */ + /* - Channel sampling time */ + /* - Management of internal measurement channels: VrefInt/TempSensor/Vbat */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Configure channel: depending on rank setting, add it or remove it from */ + /* ADC conversion sequencer. */ + if (sConfig->Rank != ADC_RANK_NONE) + { + /* Regular sequence configuration */ + /* Set the channel selection register from the selected channel */ + hadc->Instance->CHSELR |= ADC_CHSELR_CHANNEL(sConfig->Channel); + + /* Channel sampling time configuration */ + /* Management of parameters "SamplingTimeCommon" and "SamplingTime" */ + /* (obsolete): sampling time set in this function with */ + /* parameter "SamplingTime" (obsolete) only if not already set into */ + /* ADC initialization structure with parameter "SamplingTimeCommon". */ + if (! IS_ADC_SAMPLE_TIME(hadc->Init.SamplingTimeCommon)) + { + /* Modify sampling time if needed (not needed in case of reoccurrence */ + /* for several channels programmed consecutively into the sequencer) */ + if (sConfig->SamplingTime != ADC_GET_SAMPLINGTIME(hadc)) + { + /* Channel sampling time configuration */ + /* Clear the old sample time */ + hadc->Instance->SMPR &= ~(ADC_SMPR_SMP); + + /* Set the new sample time */ + hadc->Instance->SMPR |= ADC_SMPR_SET(sConfig->SamplingTime); + } + } + + /* Management of internal measurement channels: VrefInt/TempSensor/Vbat */ + /* internal measurement paths enable: If internal channel selected, */ + /* enable dedicated internal buffers and path. */ + /* Note: these internal measurement paths can be disabled using */ + /* HAL_ADC_DeInit() or removing the channel from sequencer with */ + /* channel configuration parameter "Rank". */ + if(ADC_IS_CHANNEL_INTERNAL(sConfig->Channel)) + { + /* If Channel_16 is selected, enable Temp. sensor measurement path. */ + /* If Channel_17 is selected, enable VREFINT measurement path. */ + /* If Channel_18 is selected, enable VBAT measurement path. */ + ADC->CCR |= ADC_CHANNEL_INTERNAL_PATH(sConfig->Channel); + + /* If Temp. sensor is selected, wait for stabilization delay */ + if (sConfig->Channel == ADC_CHANNEL_TEMPSENSOR) + { + /* Delay for temperature sensor stabilization time */ + /* Compute number of CPU cycles to wait for */ + wait_loop_index = (ADC_TEMPSENSOR_DELAY_US * (SystemCoreClock / 1000000U)); + while(wait_loop_index != 0U) + { + wait_loop_index--; + } + } + } + } + else + { + /* Regular sequence configuration */ + /* Reset the channel selection register from the selected channel */ + hadc->Instance->CHSELR &= ~ADC_CHSELR_CHANNEL(sConfig->Channel); + + /* Management of internal measurement channels: VrefInt/TempSensor/Vbat */ + /* internal measurement paths disable: If internal channel selected, */ + /* disable dedicated internal buffers and path. */ + if(ADC_IS_CHANNEL_INTERNAL(sConfig->Channel)) + { + /* If Channel_16 is selected, disable Temp. sensor measurement path. */ + /* If Channel_17 is selected, disable VREFINT measurement path. */ + /* If Channel_18 is selected, disable VBAT measurement path. */ + ADC->CCR &= ~ADC_CHANNEL_INTERNAL_PATH(sConfig->Channel); + } + } + + } + + /* If a conversion is on going on regular group, no update on regular */ + /* channel could be done on neither of the channel configuration structure */ + /* parameters. */ + else + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + tmp_hal_status = HAL_ERROR; + } + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + /* Return function status */ + return tmp_hal_status; +} + + +/** + * @brief Configures the analog watchdog. + * @note Possibility to update parameters on the fly: + * This function initializes the selected analog watchdog, following + * calls to this function can be used to reconfigure some parameters + * of structure "ADC_AnalogWDGConfTypeDef" on the fly, without reseting + * the ADC. + * The setting of these parameters is conditioned to ADC state. + * For parameters constraints, see comments of structure + * "ADC_AnalogWDGConfTypeDef". + * @param hadc ADC handle + * @param AnalogWDGConfig Structure of ADC analog watchdog configuration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADC_AnalogWDGConfig(ADC_HandleTypeDef* hadc, ADC_AnalogWDGConfTypeDef* AnalogWDGConfig) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + + uint32_t tmpAWDHighThresholdShifted; + uint32_t tmpAWDLowThresholdShifted; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + assert_param(IS_ADC_ANALOG_WATCHDOG_MODE(AnalogWDGConfig->WatchdogMode)); + assert_param(IS_FUNCTIONAL_STATE(AnalogWDGConfig->ITMode)); + + /* Verify if threshold is within the selected ADC resolution */ + assert_param(IS_ADC_RANGE(ADC_GET_RESOLUTION(hadc), AnalogWDGConfig->HighThreshold)); + assert_param(IS_ADC_RANGE(ADC_GET_RESOLUTION(hadc), AnalogWDGConfig->LowThreshold)); + + if(AnalogWDGConfig->WatchdogMode == ADC_ANALOGWATCHDOG_SINGLE_REG) + { + assert_param(IS_ADC_CHANNEL(AnalogWDGConfig->Channel)); + } + + /* Process locked */ + __HAL_LOCK(hadc); + + /* Parameters update conditioned to ADC state: */ + /* Parameters that can be updated when ADC is disabled or enabled without */ + /* conversion on going on regular group: */ + /* - Analog watchdog channels */ + /* - Analog watchdog thresholds */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Configuration of analog watchdog: */ + /* - Set the analog watchdog enable mode: one or overall group of */ + /* channels. */ + /* - Set the Analog watchdog channel (is not used if watchdog */ + /* mode "all channels": ADC_CFGR_AWD1SGL=0). */ + hadc->Instance->CFGR1 &= ~( ADC_CFGR1_AWDSGL | + ADC_CFGR1_AWDEN | + ADC_CFGR1_AWDCH ); + + hadc->Instance->CFGR1 |= ( AnalogWDGConfig->WatchdogMode | + ADC_CFGR_AWDCH(AnalogWDGConfig->Channel) ); + + /* Shift the offset in function of the selected ADC resolution: Thresholds*/ + /* have to be left-aligned on bit 11, the LSB (right bits) are set to 0 */ + tmpAWDHighThresholdShifted = ADC_AWD1THRESHOLD_SHIFT_RESOLUTION(hadc, AnalogWDGConfig->HighThreshold); + tmpAWDLowThresholdShifted = ADC_AWD1THRESHOLD_SHIFT_RESOLUTION(hadc, AnalogWDGConfig->LowThreshold); + + /* Set the high and low thresholds */ + hadc->Instance->TR &= ~(ADC_TR_HT | ADC_TR_LT); + hadc->Instance->TR |= ( ADC_TRX_HIGHTHRESHOLD (tmpAWDHighThresholdShifted) | + tmpAWDLowThresholdShifted ); + + /* Clear the ADC Analog watchdog flag (in case of left enabled by */ + /* previous ADC operations) to be ready to use for HAL_ADC_IRQHandler() */ + /* or HAL_ADC_PollForEvent(). */ + __HAL_ADC_CLEAR_FLAG(hadc, ADC_IT_AWD); + + /* Configure ADC Analog watchdog interrupt */ + if(AnalogWDGConfig->ITMode == ENABLE) + { + /* Enable the ADC Analog watchdog interrupt */ + __HAL_ADC_ENABLE_IT(hadc, ADC_IT_AWD); + } + else + { + /* Disable the ADC Analog watchdog interrupt */ + __HAL_ADC_DISABLE_IT(hadc, ADC_IT_AWD); + } + + } + /* If a conversion is on going on regular group, no update could be done */ + /* on neither of the AWD configuration structure parameters. */ + else + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + tmp_hal_status = HAL_ERROR; + } + + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + /* Return function status */ + return tmp_hal_status; +} + + +/** + * @} + */ + + +/** @defgroup ADC_Exported_Functions_Group4 Peripheral State functions + * @brief Peripheral State functions + * +@verbatim + =============================================================================== + ##### Peripheral State and Errors functions ##### + =============================================================================== + [..] + This subsection provides functions to get in run-time the status of the + peripheral. + (+) Check the ADC state + (+) Check the ADC error code + +@endverbatim + * @{ + */ + +/** + * @brief Return the ADC state + * @note ADC state machine is managed by bitfields, ADC status must be + * compared with states bits. + * For example: + * " if (HAL_IS_BIT_SET(HAL_ADC_GetState(hadc1), HAL_ADC_STATE_REG_BUSY)) " + * " if (HAL_IS_BIT_SET(HAL_ADC_GetState(hadc1), HAL_ADC_STATE_AWD1) ) " + * @param hadc ADC handle + * @retval HAL state + */ +uint32_t HAL_ADC_GetState(ADC_HandleTypeDef* hadc) +{ + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Return ADC state */ + return hadc->State; +} + +/** + * @brief Return the ADC error code + * @param hadc ADC handle + * @retval ADC Error Code + */ +uint32_t HAL_ADC_GetError(ADC_HandleTypeDef *hadc) +{ + return hadc->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup ADC_Private_Functions ADC Private Functions + * @{ + */ + +/** + * @brief Enable the selected ADC. + * @note Prerequisite condition to use this function: ADC must be disabled + * and voltage regulator must be enabled (done into HAL_ADC_Init()). + * @note If low power mode AutoPowerOff is enabled, power-on/off phases are + * performed automatically by hardware. + * In this mode, this function is useless and must not be called because + * flag ADC_FLAG_RDY is not usable. + * Therefore, this function must be called under condition of + * "if (hadc->Init.LowPowerAutoPowerOff != ENABLE)". + * @param hadc ADC handle + * @retval HAL status. + */ +static HAL_StatusTypeDef ADC_Enable(ADC_HandleTypeDef* hadc) +{ + uint32_t tickstart = 0U; + __IO uint32_t wait_loop_index = 0U; + + /* ADC enable and wait for ADC ready (in case of ADC is disabled or */ + /* enabling phase not yet completed: flag ADC ready not yet set). */ + /* Timeout implemented to not be stuck if ADC cannot be enabled (possible */ + /* causes: ADC clock not running, ...). */ + if (ADC_IS_ENABLE(hadc) == RESET) + { + /* Check if conditions to enable the ADC are fulfilled */ + if (ADC_ENABLING_CONDITIONS(hadc) == RESET) + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + + return HAL_ERROR; + } + + /* Enable the ADC peripheral */ + __HAL_ADC_ENABLE(hadc); + + /* Delay for ADC stabilization time */ + /* Compute number of CPU cycles to wait for */ + wait_loop_index = (ADC_STAB_DELAY_US * (SystemCoreClock / 1000000U)); + while(wait_loop_index != 0U) + { + wait_loop_index--; + } + + /* Get tick count */ + tickstart = HAL_GetTick(); + + /* Wait for ADC effectively enabled */ + while(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_RDY) == RESET) + { + if((HAL_GetTick() - tickstart) > ADC_ENABLE_TIMEOUT) + { + /* New check to avoid false timeout detection in case of preemption */ + if(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_RDY) == RESET) + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + + return HAL_ERROR; + } + } + } + } + + /* Return HAL status */ + return HAL_OK; +} + +/** + * @brief Disable the selected ADC. + * @note Prerequisite condition to use this function: ADC conversions must be + * stopped. + * @param hadc ADC handle + * @retval HAL status. + */ +static HAL_StatusTypeDef ADC_Disable(ADC_HandleTypeDef* hadc) +{ + uint32_t tickstart = 0U; + + /* Verification if ADC is not already disabled: */ + /* Note: forbidden to disable ADC (set bit ADC_CR_ADDIS) if ADC is already */ + /* disabled. */ + if (ADC_IS_ENABLE(hadc) != RESET) + { + /* Check if conditions to disable the ADC are fulfilled */ + if (ADC_DISABLING_CONDITIONS(hadc) != RESET) + { + /* Disable the ADC peripheral */ + __HAL_ADC_DISABLE(hadc); + } + else + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + + return HAL_ERROR; + } + + /* Wait for ADC effectively disabled */ + /* Get tick count */ + tickstart = HAL_GetTick(); + + while(HAL_IS_BIT_SET(hadc->Instance->CR, ADC_CR_ADEN)) + { + if((HAL_GetTick() - tickstart) > ADC_DISABLE_TIMEOUT) + { + /* New check to avoid false timeout detection in case of preemption */ + if(HAL_IS_BIT_SET(hadc->Instance->CR, ADC_CR_ADEN)) + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + + return HAL_ERROR; + } + } + } + } + + /* Return HAL status */ + return HAL_OK; +} + + +/** + * @brief Stop ADC conversion. + * @note Prerequisite condition to use this function: ADC conversions must be + * stopped to disable the ADC. + * @param hadc ADC handle + * @retval HAL status. + */ +static HAL_StatusTypeDef ADC_ConversionStop(ADC_HandleTypeDef* hadc) +{ + uint32_t tickstart = 0U; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Verification if ADC is not already stopped on regular group to bypass */ + /* this function if not needed. */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc)) + { + + /* Stop potential conversion on going on regular group */ + /* Software is allowed to set ADSTP only when ADSTART=1 and ADDIS=0 */ + if (HAL_IS_BIT_SET(hadc->Instance->CR, ADC_CR_ADSTART) && + HAL_IS_BIT_CLR(hadc->Instance->CR, ADC_CR_ADDIS) ) + { + /* Stop conversions on regular group */ + hadc->Instance->CR |= ADC_CR_ADSTP; + } + + /* Wait for conversion effectively stopped */ + /* Get tick count */ + tickstart = HAL_GetTick(); + + while((hadc->Instance->CR & ADC_CR_ADSTART) != RESET) + { + if((HAL_GetTick() - tickstart) > ADC_STOP_CONVERSION_TIMEOUT) + { + /* New check to avoid false timeout detection in case of preemption */ + if((hadc->Instance->CR & ADC_CR_ADSTART) != RESET) + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + + return HAL_ERROR; + } + } + } + } + + /* Return HAL status */ + return HAL_OK; +} + + +/** + * @brief DMA transfer complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +static void ADC_DMAConvCplt(DMA_HandleTypeDef *hdma) +{ + /* Retrieve ADC handle corresponding to current DMA handle */ + ADC_HandleTypeDef* hadc = ( ADC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + + /* Update state machine on conversion status if not in error state */ + if (HAL_IS_BIT_CLR(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL | HAL_ADC_STATE_ERROR_DMA)) + { + /* Set ADC state */ + SET_BIT(hadc->State, HAL_ADC_STATE_REG_EOC); + + /* Determine whether any further conversion upcoming on group regular */ + /* by external trigger, continuous mode or scan sequence on going. */ + if(ADC_IS_SOFTWARE_START_REGULAR(hadc) && + (hadc->Init.ContinuousConvMode == DISABLE) ) + { + /* If End of Sequence is reached, disable interrupts */ + if( __HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) ) + { + /* Allowed to modify bits ADC_IT_EOC/ADC_IT_EOS only if bit */ + /* ADSTART==0 (no conversion on going) */ + if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET) + { + /* Disable ADC end of single conversion interrupt on group regular */ + /* Note: Overrun interrupt was enabled with EOC interrupt in */ + /* HAL_Start_IT(), but is not disabled here because can be used */ + /* by overrun IRQ process below. */ + __HAL_ADC_DISABLE_IT(hadc, ADC_IT_EOC | ADC_IT_EOS); + + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_READY); + } + else + { + /* Change ADC state to error state */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + /* Set ADC error code to ADC IP internal error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL); + } + } + } + + /* Conversion complete callback */ +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + hadc->ConvCpltCallback(hadc); +#else + HAL_ADC_ConvCpltCallback(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + } + else + { + /* Call DMA error callback */ + hadc->DMA_Handle->XferErrorCallback(hdma); + } + +} + +/** + * @brief DMA half transfer complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +static void ADC_DMAHalfConvCplt(DMA_HandleTypeDef *hdma) +{ + /* Retrieve ADC handle corresponding to current DMA handle */ + ADC_HandleTypeDef* hadc = ( ADC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + + /* Half conversion callback */ +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + hadc->ConvHalfCpltCallback(hadc); +#else + HAL_ADC_ConvHalfCpltCallback(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA error callback + * @param hdma pointer to DMA handle. + * @retval None + */ +static void ADC_DMAError(DMA_HandleTypeDef *hdma) +{ + /* Retrieve ADC handle corresponding to current DMA handle */ + ADC_HandleTypeDef* hadc = ( ADC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + + /* Set ADC state */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_DMA); + + /* Set ADC error code to DMA error */ + SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_DMA); + + /* Error callback */ +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + hadc->ErrorCallback(hadc); +#else + HAL_ADC_ErrorCallback(hadc); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ +} + +/** + * @} + */ + +#endif /* HAL_ADC_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc_ex.c new file mode 100644 index 0000000..4f914be --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_adc_ex.c @@ -0,0 +1,192 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_adc_ex.c + * @author MCD Application Team + * @brief This file provides firmware functions to manage the following + * functionalities of the Analog to Digital Convertor (ADC) + * peripheral: + * + Operation functions + * ++ Calibration (ADC automatic self-calibration) + * Other functions (generic functions) are available in file + * "stm32f0xx_hal_adc.c". + * + @verbatim + [..] + (@) Sections "ADC peripheral features" and "How to use this driver" are + available in file of generic functions "stm32l1xx_hal_adc.c". + [..] + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup ADCEx ADCEx + * @brief ADC HAL module driver + * @{ + */ + +#ifdef HAL_ADC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup ADCEx_Private_Constants ADCEx Private Constants + * @{ + */ + +/* Fixed timeout values for ADC calibration, enable settling time, disable */ + /* settling time. */ + /* Values defined to be higher than worst cases: low clock frequency, */ + /* maximum prescaler. */ + /* Ex of profile low frequency : Clock source at 0.1 MHz, ADC clock */ + /* prescaler 4. */ + /* Unit: ms */ + #define ADC_DISABLE_TIMEOUT 2 + #define ADC_CALIBRATION_TIMEOUT 2U +/** + * @} + */ + +/* Private macros -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + +/** @defgroup ADCEx_Exported_Functions ADCEx Exported Functions + * @{ + */ + +/** @defgroup ADCEx_Exported_Functions_Group1 Extended Initialization/de-initialization functions + * @brief Extended Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Perform the ADC calibration. +@endverbatim + * @{ + */ + +/** + * @brief Perform an ADC automatic self-calibration + * Calibration prerequisite: ADC must be disabled (execute this + * function before HAL_ADC_Start() or after HAL_ADC_Stop() ). + * @note Calibration factor can be read after calibration, using function + * HAL_ADC_GetValue() (value on 7 bits: from DR[6;0]). + * @param hadc ADC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_ADCEx_Calibration_Start(ADC_HandleTypeDef* hadc) +{ + HAL_StatusTypeDef tmp_hal_status = HAL_OK; + uint32_t tickstart = 0U; + uint32_t backup_setting_adc_dma_transfer = 0; /* Note: Variable not declared as volatile because register read is already declared as volatile */ + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance)); + + /* Process locked */ + __HAL_LOCK(hadc); + + /* Calibration prerequisite: ADC must be disabled. */ + if (ADC_IS_ENABLE(hadc) == RESET) + { + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_REG_BUSY, + HAL_ADC_STATE_BUSY_INTERNAL); + + /* Disable ADC DMA transfer request during calibration */ + /* Note: Specificity of this STM32 serie: Calibration factor is */ + /* available in data register and also transfered by DMA. */ + /* To not insert ADC calibration factor among ADC conversion data */ + /* in array variable, DMA transfer must be disabled during */ + /* calibration. */ + backup_setting_adc_dma_transfer = READ_BIT(hadc->Instance->CFGR1, ADC_CFGR1_DMAEN | ADC_CFGR1_DMACFG); + CLEAR_BIT(hadc->Instance->CFGR1, ADC_CFGR1_DMAEN | ADC_CFGR1_DMACFG); + + /* Start ADC calibration */ + hadc->Instance->CR |= ADC_CR_ADCAL; + + tickstart = HAL_GetTick(); + + /* Wait for calibration completion */ + while(HAL_IS_BIT_SET(hadc->Instance->CR, ADC_CR_ADCAL)) + { + if((HAL_GetTick() - tickstart) > ADC_CALIBRATION_TIMEOUT) + { + /* New check to avoid false timeout detection in case of preemption */ + if(HAL_IS_BIT_SET(hadc->Instance->CR, ADC_CR_ADCAL)) + { + /* Update ADC state machine to error */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_BUSY_INTERNAL, + HAL_ADC_STATE_ERROR_INTERNAL); + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + return HAL_ERROR; + } + } + } + + /* Restore ADC DMA transfer request after calibration */ + SET_BIT(hadc->Instance->CFGR1, backup_setting_adc_dma_transfer); + + /* Set ADC state */ + ADC_STATE_CLR_SET(hadc->State, + HAL_ADC_STATE_BUSY_INTERNAL, + HAL_ADC_STATE_READY); + } + else + { + /* Update ADC state machine to error */ + SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG); + + tmp_hal_status = HAL_ERROR; + } + + /* Process unlocked */ + __HAL_UNLOCK(hadc); + + /* Return function status */ + return tmp_hal_status; +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_ADC_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_can.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_can.c new file mode 100644 index 0000000..e199b99 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_can.c @@ -0,0 +1,2432 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_can.c + * @author MCD Application Team + * @brief CAN HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Controller Area Network (CAN) peripheral: + * + Initialization and de-initialization functions + * + Configuration functions + * + Control functions + * + Interrupts management + * + Callbacks functions + * + Peripheral State and Error functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + (#) Initialize the CAN low level resources by implementing the + HAL_CAN_MspInit(): + (++) Enable the CAN interface clock using __HAL_RCC_CANx_CLK_ENABLE() + (++) Configure CAN pins + (+++) Enable the clock for the CAN GPIOs + (+++) Configure CAN pins as alternate function open-drain + (++) In case of using interrupts (e.g. HAL_CAN_ActivateNotification()) + (+++) Configure the CAN interrupt priority using + HAL_NVIC_SetPriority() + (+++) Enable the CAN IRQ handler using HAL_NVIC_EnableIRQ() + (+++) In CAN IRQ handler, call HAL_CAN_IRQHandler() + + (#) Initialize the CAN peripheral using HAL_CAN_Init() function. This + function resorts to HAL_CAN_MspInit() for low-level initialization. + + (#) Configure the reception filters using the following configuration + functions: + (++) HAL_CAN_ConfigFilter() + + (#) Start the CAN module using HAL_CAN_Start() function. At this level + the node is active on the bus: it receive messages, and can send + messages. + + (#) To manage messages transmission, the following Tx control functions + can be used: + (++) HAL_CAN_AddTxMessage() to request transmission of a new + message. + (++) HAL_CAN_AbortTxRequest() to abort transmission of a pending + message. + (++) HAL_CAN_GetTxMailboxesFreeLevel() to get the number of free Tx + mailboxes. + (++) HAL_CAN_IsTxMessagePending() to check if a message is pending + in a Tx mailbox. + (++) HAL_CAN_GetTxTimestamp() to get the timestamp of Tx message + sent, if time triggered communication mode is enabled. + + (#) When a message is received into the CAN Rx FIFOs, it can be retrieved + using the HAL_CAN_GetRxMessage() function. The function + HAL_CAN_GetRxFifoFillLevel() allows to know how many Rx message are + stored in the Rx Fifo. + + (#) Calling the HAL_CAN_Stop() function stops the CAN module. + + (#) The deinitialization is achieved with HAL_CAN_DeInit() function. + + + *** Polling mode operation *** + ============================== + [..] + (#) Reception: + (++) Monitor reception of message using HAL_CAN_GetRxFifoFillLevel() + until at least one message is received. + (++) Then get the message using HAL_CAN_GetRxMessage(). + + (#) Transmission: + (++) Monitor the Tx mailboxes availability until at least one Tx + mailbox is free, using HAL_CAN_GetTxMailboxesFreeLevel(). + (++) Then request transmission of a message using + HAL_CAN_AddTxMessage(). + + + *** Interrupt mode operation *** + ================================ + [..] + (#) Notifications are activated using HAL_CAN_ActivateNotification() + function. Then, the process can be controlled through the + available user callbacks: HAL_CAN_xxxCallback(), using same APIs + HAL_CAN_GetRxMessage() and HAL_CAN_AddTxMessage(). + + (#) Notifications can be deactivated using + HAL_CAN_DeactivateNotification() function. + + (#) Special care should be taken for CAN_IT_RX_FIFO0_MSG_PENDING and + CAN_IT_RX_FIFO1_MSG_PENDING notifications. These notifications trig + the callbacks HAL_CAN_RxFIFO0MsgPendingCallback() and + HAL_CAN_RxFIFO1MsgPendingCallback(). User has two possible options + here. + (++) Directly get the Rx message in the callback, using + HAL_CAN_GetRxMessage(). + (++) Or deactivate the notification in the callback without + getting the Rx message. The Rx message can then be got later + using HAL_CAN_GetRxMessage(). Once the Rx message have been + read, the notification can be activated again. + + + *** Sleep mode *** + ================== + [..] + (#) The CAN peripheral can be put in sleep mode (low power), using + HAL_CAN_RequestSleep(). The sleep mode will be entered as soon as the + current CAN activity (transmission or reception of a CAN frame) will + be completed. + + (#) A notification can be activated to be informed when the sleep mode + will be entered. + + (#) It can be checked if the sleep mode is entered using + HAL_CAN_IsSleepActive(). + Note that the CAN state (accessible from the API HAL_CAN_GetState()) + is HAL_CAN_STATE_SLEEP_PENDING as soon as the sleep mode request is + submitted (the sleep mode is not yet entered), and become + HAL_CAN_STATE_SLEEP_ACTIVE when the sleep mode is effective. + + (#) The wake-up from sleep mode can be triggered by two ways: + (++) Using HAL_CAN_WakeUp(). When returning from this function, + the sleep mode is exited (if return status is HAL_OK). + (++) When a start of Rx CAN frame is detected by the CAN peripheral, + if automatic wake up mode is enabled. + + *** Callback registration *** + ============================================= + + The compilation define USE_HAL_CAN_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + Use Function HAL_CAN_RegisterCallback() to register an interrupt callback. + + Function HAL_CAN_RegisterCallback() allows to register following callbacks: + (+) TxMailbox0CompleteCallback : Tx Mailbox 0 Complete Callback. + (+) TxMailbox1CompleteCallback : Tx Mailbox 1 Complete Callback. + (+) TxMailbox2CompleteCallback : Tx Mailbox 2 Complete Callback. + (+) TxMailbox0AbortCallback : Tx Mailbox 0 Abort Callback. + (+) TxMailbox1AbortCallback : Tx Mailbox 1 Abort Callback. + (+) TxMailbox2AbortCallback : Tx Mailbox 2 Abort Callback. + (+) RxFifo0MsgPendingCallback : Rx Fifo 0 Message Pending Callback. + (+) RxFifo0FullCallback : Rx Fifo 0 Full Callback. + (+) RxFifo1MsgPendingCallback : Rx Fifo 1 Message Pending Callback. + (+) RxFifo1FullCallback : Rx Fifo 1 Full Callback. + (+) SleepCallback : Sleep Callback. + (+) WakeUpFromRxMsgCallback : Wake Up From Rx Message Callback. + (+) ErrorCallback : Error Callback. + (+) MspInitCallback : CAN MspInit. + (+) MspDeInitCallback : CAN MspDeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + Use function HAL_CAN_UnRegisterCallback() to reset a callback to the default + weak function. + HAL_CAN_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) TxMailbox0CompleteCallback : Tx Mailbox 0 Complete Callback. + (+) TxMailbox1CompleteCallback : Tx Mailbox 1 Complete Callback. + (+) TxMailbox2CompleteCallback : Tx Mailbox 2 Complete Callback. + (+) TxMailbox0AbortCallback : Tx Mailbox 0 Abort Callback. + (+) TxMailbox1AbortCallback : Tx Mailbox 1 Abort Callback. + (+) TxMailbox2AbortCallback : Tx Mailbox 2 Abort Callback. + (+) RxFifo0MsgPendingCallback : Rx Fifo 0 Message Pending Callback. + (+) RxFifo0FullCallback : Rx Fifo 0 Full Callback. + (+) RxFifo1MsgPendingCallback : Rx Fifo 1 Message Pending Callback. + (+) RxFifo1FullCallback : Rx Fifo 1 Full Callback. + (+) SleepCallback : Sleep Callback. + (+) WakeUpFromRxMsgCallback : Wake Up From Rx Message Callback. + (+) ErrorCallback : Error Callback. + (+) MspInitCallback : CAN MspInit. + (+) MspDeInitCallback : CAN MspDeInit. + + By default, after the HAL_CAN_Init() and when the state is HAL_CAN_STATE_RESET, + all callbacks are set to the corresponding weak functions: + example HAL_CAN_ErrorCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak function in the HAL_CAN_Init()/ HAL_CAN_DeInit() only when + these callbacks are null (not registered beforehand). + if not, MspInit or MspDeInit are not null, the HAL_CAN_Init()/ HAL_CAN_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) + + Callbacks can be registered/unregistered in HAL_CAN_STATE_READY state only. + Exception done MspInit/MspDeInit that can be registered/unregistered + in HAL_CAN_STATE_READY or HAL_CAN_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_CAN_RegisterCallback() before calling HAL_CAN_DeInit() + or HAL_CAN_Init() function. + + When The compilation define USE_HAL_CAN_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#if defined(CAN) + +/** @defgroup CAN CAN + * @brief CAN driver modules + * @{ + */ + +#ifdef HAL_CAN_MODULE_ENABLED + +#ifdef HAL_CAN_LEGACY_MODULE_ENABLED + #error "The CAN driver cannot be used with its legacy, Please enable only one CAN module at once" +#endif + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup CAN_Private_Constants CAN Private Constants + * @{ + */ +#define CAN_TIMEOUT_VALUE 10U +/** + * @} + */ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup CAN_Exported_Functions CAN Exported Functions + * @{ + */ + +/** @defgroup CAN_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + ============================================================================== + ##### Initialization and de-initialization functions ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) HAL_CAN_Init : Initialize and configure the CAN. + (+) HAL_CAN_DeInit : De-initialize the CAN. + (+) HAL_CAN_MspInit : Initialize the CAN MSP. + (+) HAL_CAN_MspDeInit : DeInitialize the CAN MSP. + +@endverbatim + * @{ + */ + +/** + * @brief Initializes the CAN peripheral according to the specified + * parameters in the CAN_InitStruct. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_Init(CAN_HandleTypeDef *hcan) +{ + uint32_t tickstart; + + /* Check CAN handle */ + if (hcan == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_CAN_ALL_INSTANCE(hcan->Instance)); + assert_param(IS_FUNCTIONAL_STATE(hcan->Init.TimeTriggeredMode)); + assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoBusOff)); + assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoWakeUp)); + assert_param(IS_FUNCTIONAL_STATE(hcan->Init.AutoRetransmission)); + assert_param(IS_FUNCTIONAL_STATE(hcan->Init.ReceiveFifoLocked)); + assert_param(IS_FUNCTIONAL_STATE(hcan->Init.TransmitFifoPriority)); + assert_param(IS_CAN_MODE(hcan->Init.Mode)); + assert_param(IS_CAN_SJW(hcan->Init.SyncJumpWidth)); + assert_param(IS_CAN_BS1(hcan->Init.TimeSeg1)); + assert_param(IS_CAN_BS2(hcan->Init.TimeSeg2)); + assert_param(IS_CAN_PRESCALER(hcan->Init.Prescaler)); + +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + if (hcan->State == HAL_CAN_STATE_RESET) + { + /* Reset callbacks to legacy functions */ + hcan->RxFifo0MsgPendingCallback = HAL_CAN_RxFifo0MsgPendingCallback; /* Legacy weak RxFifo0MsgPendingCallback */ + hcan->RxFifo0FullCallback = HAL_CAN_RxFifo0FullCallback; /* Legacy weak RxFifo0FullCallback */ + hcan->RxFifo1MsgPendingCallback = HAL_CAN_RxFifo1MsgPendingCallback; /* Legacy weak RxFifo1MsgPendingCallback */ + hcan->RxFifo1FullCallback = HAL_CAN_RxFifo1FullCallback; /* Legacy weak RxFifo1FullCallback */ + hcan->TxMailbox0CompleteCallback = HAL_CAN_TxMailbox0CompleteCallback; /* Legacy weak TxMailbox0CompleteCallback */ + hcan->TxMailbox1CompleteCallback = HAL_CAN_TxMailbox1CompleteCallback; /* Legacy weak TxMailbox1CompleteCallback */ + hcan->TxMailbox2CompleteCallback = HAL_CAN_TxMailbox2CompleteCallback; /* Legacy weak TxMailbox2CompleteCallback */ + hcan->TxMailbox0AbortCallback = HAL_CAN_TxMailbox0AbortCallback; /* Legacy weak TxMailbox0AbortCallback */ + hcan->TxMailbox1AbortCallback = HAL_CAN_TxMailbox1AbortCallback; /* Legacy weak TxMailbox1AbortCallback */ + hcan->TxMailbox2AbortCallback = HAL_CAN_TxMailbox2AbortCallback; /* Legacy weak TxMailbox2AbortCallback */ + hcan->SleepCallback = HAL_CAN_SleepCallback; /* Legacy weak SleepCallback */ + hcan->WakeUpFromRxMsgCallback = HAL_CAN_WakeUpFromRxMsgCallback; /* Legacy weak WakeUpFromRxMsgCallback */ + hcan->ErrorCallback = HAL_CAN_ErrorCallback; /* Legacy weak ErrorCallback */ + + if (hcan->MspInitCallback == NULL) + { + hcan->MspInitCallback = HAL_CAN_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware: CLOCK, NVIC */ + hcan->MspInitCallback(hcan); + } + +#else + if (hcan->State == HAL_CAN_STATE_RESET) + { + /* Init the low level hardware: CLOCK, NVIC */ + HAL_CAN_MspInit(hcan); + } +#endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */ + + /* Request initialisation */ + SET_BIT(hcan->Instance->MCR, CAN_MCR_INRQ); + + /* Get tick */ + tickstart = HAL_GetTick(); + + /* Wait initialisation acknowledge */ + while ((hcan->Instance->MSR & CAN_MSR_INAK) == 0U) + { + if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT; + + /* Change CAN state */ + hcan->State = HAL_CAN_STATE_ERROR; + + return HAL_ERROR; + } + } + + /* Exit from sleep mode */ + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP); + + /* Get tick */ + tickstart = HAL_GetTick(); + + /* Check Sleep mode leave acknowledge */ + while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U) + { + if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT; + + /* Change CAN state */ + hcan->State = HAL_CAN_STATE_ERROR; + + return HAL_ERROR; + } + } + + /* Set the time triggered communication mode */ + if (hcan->Init.TimeTriggeredMode == ENABLE) + { + SET_BIT(hcan->Instance->MCR, CAN_MCR_TTCM); + } + else + { + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_TTCM); + } + + /* Set the automatic bus-off management */ + if (hcan->Init.AutoBusOff == ENABLE) + { + SET_BIT(hcan->Instance->MCR, CAN_MCR_ABOM); + } + else + { + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_ABOM); + } + + /* Set the automatic wake-up mode */ + if (hcan->Init.AutoWakeUp == ENABLE) + { + SET_BIT(hcan->Instance->MCR, CAN_MCR_AWUM); + } + else + { + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_AWUM); + } + + /* Set the automatic retransmission */ + if (hcan->Init.AutoRetransmission == ENABLE) + { + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_NART); + } + else + { + SET_BIT(hcan->Instance->MCR, CAN_MCR_NART); + } + + /* Set the receive FIFO locked mode */ + if (hcan->Init.ReceiveFifoLocked == ENABLE) + { + SET_BIT(hcan->Instance->MCR, CAN_MCR_RFLM); + } + else + { + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_RFLM); + } + + /* Set the transmit FIFO priority */ + if (hcan->Init.TransmitFifoPriority == ENABLE) + { + SET_BIT(hcan->Instance->MCR, CAN_MCR_TXFP); + } + else + { + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_TXFP); + } + + /* Set the bit timing register */ + WRITE_REG(hcan->Instance->BTR, (uint32_t)(hcan->Init.Mode | + hcan->Init.SyncJumpWidth | + hcan->Init.TimeSeg1 | + hcan->Init.TimeSeg2 | + (hcan->Init.Prescaler - 1U))); + + /* Initialize the error code */ + hcan->ErrorCode = HAL_CAN_ERROR_NONE; + + /* Initialize the CAN state */ + hcan->State = HAL_CAN_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Deinitializes the CAN peripheral registers to their default + * reset values. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_DeInit(CAN_HandleTypeDef *hcan) +{ + /* Check CAN handle */ + if (hcan == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_CAN_ALL_INSTANCE(hcan->Instance)); + + /* Stop the CAN module */ + (void)HAL_CAN_Stop(hcan); + +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + if (hcan->MspDeInitCallback == NULL) + { + hcan->MspDeInitCallback = HAL_CAN_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware: CLOCK, NVIC */ + hcan->MspDeInitCallback(hcan); + +#else + /* DeInit the low level hardware: CLOCK, NVIC */ + HAL_CAN_MspDeInit(hcan); +#endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */ + + /* Reset the CAN peripheral */ + SET_BIT(hcan->Instance->MCR, CAN_MCR_RESET); + + /* Reset the CAN ErrorCode */ + hcan->ErrorCode = HAL_CAN_ERROR_NONE; + + /* Change CAN state */ + hcan->State = HAL_CAN_STATE_RESET; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Initializes the CAN MSP. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_MspInit(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes the CAN MSP. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_MspDeInit(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_MspDeInit could be implemented in the user file + */ +} + +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 +/** + * @brief Register a CAN CallBack. + * To be used instead of the weak predefined callback + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for CAN module + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID Tx Mailbox 0 Complete callback ID + * @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID Tx Mailbox 1 Complete callback ID + * @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID Tx Mailbox 2 Complete callback ID + * @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CB_ID Tx Mailbox 0 Abort callback ID + * @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CB_ID Tx Mailbox 1 Abort callback ID + * @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CB_ID Tx Mailbox 2 Abort callback ID + * @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID Rx Fifo 0 message pending callback ID + * @arg @ref HAL_CAN_RX_FIFO0_FULL_CB_ID Rx Fifo 0 full callback ID + * @arg @ref HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID Rx Fifo 1 message pending callback ID + * @arg @ref HAL_CAN_RX_FIFO1_FULL_CB_ID Rx Fifo 1 full callback ID + * @arg @ref HAL_CAN_SLEEP_CB_ID Sleep callback ID + * @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID Wake Up from Rx message callback ID + * @arg @ref HAL_CAN_ERROR_CB_ID Error callback ID + * @arg @ref HAL_CAN_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_CAN_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID, void (* pCallback)(CAN_HandleTypeDef *_hcan)) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + if (hcan->State == HAL_CAN_STATE_READY) + { + switch (CallbackID) + { + case HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID : + hcan->TxMailbox0CompleteCallback = pCallback; + break; + + case HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID : + hcan->TxMailbox1CompleteCallback = pCallback; + break; + + case HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID : + hcan->TxMailbox2CompleteCallback = pCallback; + break; + + case HAL_CAN_TX_MAILBOX0_ABORT_CB_ID : + hcan->TxMailbox0AbortCallback = pCallback; + break; + + case HAL_CAN_TX_MAILBOX1_ABORT_CB_ID : + hcan->TxMailbox1AbortCallback = pCallback; + break; + + case HAL_CAN_TX_MAILBOX2_ABORT_CB_ID : + hcan->TxMailbox2AbortCallback = pCallback; + break; + + case HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID : + hcan->RxFifo0MsgPendingCallback = pCallback; + break; + + case HAL_CAN_RX_FIFO0_FULL_CB_ID : + hcan->RxFifo0FullCallback = pCallback; + break; + + case HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID : + hcan->RxFifo1MsgPendingCallback = pCallback; + break; + + case HAL_CAN_RX_FIFO1_FULL_CB_ID : + hcan->RxFifo1FullCallback = pCallback; + break; + + case HAL_CAN_SLEEP_CB_ID : + hcan->SleepCallback = pCallback; + break; + + case HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID : + hcan->WakeUpFromRxMsgCallback = pCallback; + break; + + case HAL_CAN_ERROR_CB_ID : + hcan->ErrorCallback = pCallback; + break; + + case HAL_CAN_MSPINIT_CB_ID : + hcan->MspInitCallback = pCallback; + break; + + case HAL_CAN_MSPDEINIT_CB_ID : + hcan->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hcan->State == HAL_CAN_STATE_RESET) + { + switch (CallbackID) + { + case HAL_CAN_MSPINIT_CB_ID : + hcan->MspInitCallback = pCallback; + break; + + case HAL_CAN_MSPDEINIT_CB_ID : + hcan->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + return status; +} + +/** + * @brief Unregister a CAN CallBack. + * CAN callabck is redirected to the weak predefined callback + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for CAN module + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID Tx Mailbox 0 Complete callback ID + * @arg @ref HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID Tx Mailbox 1 Complete callback ID + * @arg @ref HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID Tx Mailbox 2 Complete callback ID + * @arg @ref HAL_CAN_TX_MAILBOX0_ABORT_CB_ID Tx Mailbox 0 Abort callback ID + * @arg @ref HAL_CAN_TX_MAILBOX1_ABORT_CB_ID Tx Mailbox 1 Abort callback ID + * @arg @ref HAL_CAN_TX_MAILBOX2_ABORT_CB_ID Tx Mailbox 2 Abort callback ID + * @arg @ref HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID Rx Fifo 0 message pending callback ID + * @arg @ref HAL_CAN_RX_FIFO0_FULL_CB_ID Rx Fifo 0 full callback ID + * @arg @ref HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID Rx Fifo 1 message pending callback ID + * @arg @ref HAL_CAN_RX_FIFO1_FULL_CB_ID Rx Fifo 1 full callback ID + * @arg @ref HAL_CAN_SLEEP_CB_ID Sleep callback ID + * @arg @ref HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID Wake Up from Rx message callback ID + * @arg @ref HAL_CAN_ERROR_CB_ID Error callback ID + * @arg @ref HAL_CAN_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_CAN_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_UnRegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (hcan->State == HAL_CAN_STATE_READY) + { + switch (CallbackID) + { + case HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID : + hcan->TxMailbox0CompleteCallback = HAL_CAN_TxMailbox0CompleteCallback; + break; + + case HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID : + hcan->TxMailbox1CompleteCallback = HAL_CAN_TxMailbox1CompleteCallback; + break; + + case HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID : + hcan->TxMailbox2CompleteCallback = HAL_CAN_TxMailbox2CompleteCallback; + break; + + case HAL_CAN_TX_MAILBOX0_ABORT_CB_ID : + hcan->TxMailbox0AbortCallback = HAL_CAN_TxMailbox0AbortCallback; + break; + + case HAL_CAN_TX_MAILBOX1_ABORT_CB_ID : + hcan->TxMailbox1AbortCallback = HAL_CAN_TxMailbox1AbortCallback; + break; + + case HAL_CAN_TX_MAILBOX2_ABORT_CB_ID : + hcan->TxMailbox2AbortCallback = HAL_CAN_TxMailbox2AbortCallback; + break; + + case HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID : + hcan->RxFifo0MsgPendingCallback = HAL_CAN_RxFifo0MsgPendingCallback; + break; + + case HAL_CAN_RX_FIFO0_FULL_CB_ID : + hcan->RxFifo0FullCallback = HAL_CAN_RxFifo0FullCallback; + break; + + case HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID : + hcan->RxFifo1MsgPendingCallback = HAL_CAN_RxFifo1MsgPendingCallback; + break; + + case HAL_CAN_RX_FIFO1_FULL_CB_ID : + hcan->RxFifo1FullCallback = HAL_CAN_RxFifo1FullCallback; + break; + + case HAL_CAN_SLEEP_CB_ID : + hcan->SleepCallback = HAL_CAN_SleepCallback; + break; + + case HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID : + hcan->WakeUpFromRxMsgCallback = HAL_CAN_WakeUpFromRxMsgCallback; + break; + + case HAL_CAN_ERROR_CB_ID : + hcan->ErrorCallback = HAL_CAN_ErrorCallback; + break; + + case HAL_CAN_MSPINIT_CB_ID : + hcan->MspInitCallback = HAL_CAN_MspInit; + break; + + case HAL_CAN_MSPDEINIT_CB_ID : + hcan->MspDeInitCallback = HAL_CAN_MspDeInit; + break; + + default : + /* Update the error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hcan->State == HAL_CAN_STATE_RESET) + { + switch (CallbackID) + { + case HAL_CAN_MSPINIT_CB_ID : + hcan->MspInitCallback = HAL_CAN_MspInit; + break; + + case HAL_CAN_MSPDEINIT_CB_ID : + hcan->MspDeInitCallback = HAL_CAN_MspDeInit; + break; + + default : + /* Update the error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + return status; +} +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup CAN_Exported_Functions_Group2 Configuration functions + * @brief Configuration functions. + * +@verbatim + ============================================================================== + ##### Configuration functions ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) HAL_CAN_ConfigFilter : Configure the CAN reception filters + +@endverbatim + * @{ + */ + +/** + * @brief Configures the CAN reception filter according to the specified + * parameters in the CAN_FilterInitStruct. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param sFilterConfig pointer to a CAN_FilterTypeDef structure that + * contains the filter configuration information. + * @retval None + */ +HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDef *sFilterConfig) +{ + uint32_t filternbrbitpos; + CAN_TypeDef *can_ip = hcan->Instance; + HAL_CAN_StateTypeDef state = hcan->State; + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check the parameters */ + assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterIdHigh)); + assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterIdLow)); + assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterMaskIdHigh)); + assert_param(IS_CAN_FILTER_ID_HALFWORD(sFilterConfig->FilterMaskIdLow)); + assert_param(IS_CAN_FILTER_MODE(sFilterConfig->FilterMode)); + assert_param(IS_CAN_FILTER_SCALE(sFilterConfig->FilterScale)); + assert_param(IS_CAN_FILTER_FIFO(sFilterConfig->FilterFIFOAssignment)); + assert_param(IS_CAN_FILTER_ACTIVATION(sFilterConfig->FilterActivation)); + + /* CAN is single instance with 14 dedicated filters banks */ + + /* Check the parameters */ + assert_param(IS_CAN_FILTER_BANK_SINGLE(sFilterConfig->FilterBank)); + + /* Initialisation mode for the filter */ + SET_BIT(can_ip->FMR, CAN_FMR_FINIT); + + /* Convert filter number into bit position */ + filternbrbitpos = (uint32_t)1 << (sFilterConfig->FilterBank & 0x1FU); + + /* Filter Deactivation */ + CLEAR_BIT(can_ip->FA1R, filternbrbitpos); + + /* Filter Scale */ + if (sFilterConfig->FilterScale == CAN_FILTERSCALE_16BIT) + { + /* 16-bit scale for the filter */ + CLEAR_BIT(can_ip->FS1R, filternbrbitpos); + + /* First 16-bit identifier and First 16-bit mask */ + /* Or First 16-bit identifier and Second 16-bit identifier */ + can_ip->sFilterRegister[sFilterConfig->FilterBank].FR1 = + ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow) << 16U) | + (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdLow); + + /* Second 16-bit identifier and Second 16-bit mask */ + /* Or Third 16-bit identifier and Fourth 16-bit identifier */ + can_ip->sFilterRegister[sFilterConfig->FilterBank].FR2 = + ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) | + (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh); + } + + if (sFilterConfig->FilterScale == CAN_FILTERSCALE_32BIT) + { + /* 32-bit scale for the filter */ + SET_BIT(can_ip->FS1R, filternbrbitpos); + + /* 32-bit identifier or First 32-bit identifier */ + can_ip->sFilterRegister[sFilterConfig->FilterBank].FR1 = + ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdHigh) << 16U) | + (0x0000FFFFU & (uint32_t)sFilterConfig->FilterIdLow); + + /* 32-bit mask or Second 32-bit identifier */ + can_ip->sFilterRegister[sFilterConfig->FilterBank].FR2 = + ((0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdHigh) << 16U) | + (0x0000FFFFU & (uint32_t)sFilterConfig->FilterMaskIdLow); + } + + /* Filter Mode */ + if (sFilterConfig->FilterMode == CAN_FILTERMODE_IDMASK) + { + /* Id/Mask mode for the filter*/ + CLEAR_BIT(can_ip->FM1R, filternbrbitpos); + } + else /* CAN_FilterInitStruct->CAN_FilterMode == CAN_FilterMode_IdList */ + { + /* Identifier list mode for the filter*/ + SET_BIT(can_ip->FM1R, filternbrbitpos); + } + + /* Filter FIFO assignment */ + if (sFilterConfig->FilterFIFOAssignment == CAN_FILTER_FIFO0) + { + /* FIFO 0 assignation for the filter */ + CLEAR_BIT(can_ip->FFA1R, filternbrbitpos); + } + else + { + /* FIFO 1 assignation for the filter */ + SET_BIT(can_ip->FFA1R, filternbrbitpos); + } + + /* Filter activation */ + if (sFilterConfig->FilterActivation == CAN_FILTER_ENABLE) + { + SET_BIT(can_ip->FA1R, filternbrbitpos); + } + + /* Leave the initialisation mode for the filter */ + CLEAR_BIT(can_ip->FMR, CAN_FMR_FINIT); + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + return HAL_ERROR; + } +} + +/** + * @} + */ + +/** @defgroup CAN_Exported_Functions_Group3 Control functions + * @brief Control functions + * +@verbatim + ============================================================================== + ##### Control functions ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) HAL_CAN_Start : Start the CAN module + (+) HAL_CAN_Stop : Stop the CAN module + (+) HAL_CAN_RequestSleep : Request sleep mode entry. + (+) HAL_CAN_WakeUp : Wake up from sleep mode. + (+) HAL_CAN_IsSleepActive : Check is sleep mode is active. + (+) HAL_CAN_AddTxMessage : Add a message to the Tx mailboxes + and activate the corresponding + transmission request + (+) HAL_CAN_AbortTxRequest : Abort transmission request + (+) HAL_CAN_GetTxMailboxesFreeLevel : Return Tx mailboxes free level + (+) HAL_CAN_IsTxMessagePending : Check if a transmission request is + pending on the selected Tx mailbox + (+) HAL_CAN_GetRxMessage : Get a CAN frame from the Rx FIFO + (+) HAL_CAN_GetRxFifoFillLevel : Return Rx FIFO fill level + +@endverbatim + * @{ + */ + +/** + * @brief Start the CAN module. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_Start(CAN_HandleTypeDef *hcan) +{ + uint32_t tickstart; + + if (hcan->State == HAL_CAN_STATE_READY) + { + /* Change CAN peripheral state */ + hcan->State = HAL_CAN_STATE_LISTENING; + + /* Request leave initialisation */ + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_INRQ); + + /* Get tick */ + tickstart = HAL_GetTick(); + + /* Wait the acknowledge */ + while ((hcan->Instance->MSR & CAN_MSR_INAK) != 0U) + { + /* Check for the Timeout */ + if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT; + + /* Change CAN state */ + hcan->State = HAL_CAN_STATE_ERROR; + + return HAL_ERROR; + } + } + + /* Reset the CAN ErrorCode */ + hcan->ErrorCode = HAL_CAN_ERROR_NONE; + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_READY; + + return HAL_ERROR; + } +} + +/** + * @brief Stop the CAN module and enable access to configuration registers. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_Stop(CAN_HandleTypeDef *hcan) +{ + uint32_t tickstart; + + if (hcan->State == HAL_CAN_STATE_LISTENING) + { + /* Request initialisation */ + SET_BIT(hcan->Instance->MCR, CAN_MCR_INRQ); + + /* Get tick */ + tickstart = HAL_GetTick(); + + /* Wait the acknowledge */ + while ((hcan->Instance->MSR & CAN_MSR_INAK) == 0U) + { + /* Check for the Timeout */ + if ((HAL_GetTick() - tickstart) > CAN_TIMEOUT_VALUE) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT; + + /* Change CAN state */ + hcan->State = HAL_CAN_STATE_ERROR; + + return HAL_ERROR; + } + } + + /* Exit from sleep mode */ + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP); + + /* Change CAN peripheral state */ + hcan->State = HAL_CAN_STATE_READY; + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_STARTED; + + return HAL_ERROR; + } +} + +/** + * @brief Request the sleep mode (low power) entry. + * When returning from this function, Sleep mode will be entered + * as soon as the current CAN activity (transmission or reception + * of a CAN frame) has been completed. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_CAN_RequestSleep(CAN_HandleTypeDef *hcan) +{ + HAL_CAN_StateTypeDef state = hcan->State; + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Request Sleep mode */ + SET_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP); + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + /* Return function status */ + return HAL_ERROR; + } +} + +/** + * @brief Wake up from sleep mode. + * When returning with HAL_OK status from this function, Sleep mode + * is exited. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan) +{ + __IO uint32_t count = 0; + uint32_t timeout = 1000000U; + HAL_CAN_StateTypeDef state = hcan->State; + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Wake up request */ + CLEAR_BIT(hcan->Instance->MCR, CAN_MCR_SLEEP); + + /* Wait sleep mode is exited */ + do + { + /* Increment counter */ + count++; + + /* Check if timeout is reached */ + if (count > timeout) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_TIMEOUT; + + return HAL_ERROR; + } + } + while ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U); + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + return HAL_ERROR; + } +} + +/** + * @brief Check is sleep mode is active. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval Status + * - 0 : Sleep mode is not active. + * - 1 : Sleep mode is active. + */ +uint32_t HAL_CAN_IsSleepActive(CAN_HandleTypeDef *hcan) +{ + uint32_t status = 0U; + HAL_CAN_StateTypeDef state = hcan->State; + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check Sleep mode */ + if ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U) + { + status = 1U; + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Add a message to the first free Tx mailbox and activate the + * corresponding transmission request. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param pHeader pointer to a CAN_TxHeaderTypeDef structure. + * @param aData array containing the payload of the Tx frame. + * @param pTxMailbox pointer to a variable where the function will return + * the TxMailbox used to store the Tx message. + * This parameter can be a value of @arg CAN_Tx_Mailboxes. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, CAN_TxHeaderTypeDef *pHeader, uint8_t aData[], uint32_t *pTxMailbox) +{ + uint32_t transmitmailbox; + HAL_CAN_StateTypeDef state = hcan->State; + uint32_t tsr = READ_REG(hcan->Instance->TSR); + + /* Check the parameters */ + assert_param(IS_CAN_IDTYPE(pHeader->IDE)); + assert_param(IS_CAN_RTR(pHeader->RTR)); + assert_param(IS_CAN_DLC(pHeader->DLC)); + if (pHeader->IDE == CAN_ID_STD) + { + assert_param(IS_CAN_STDID(pHeader->StdId)); + } + else + { + assert_param(IS_CAN_EXTID(pHeader->ExtId)); + } + assert_param(IS_FUNCTIONAL_STATE(pHeader->TransmitGlobalTime)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check that all the Tx mailboxes are not full */ + if (((tsr & CAN_TSR_TME0) != 0U) || + ((tsr & CAN_TSR_TME1) != 0U) || + ((tsr & CAN_TSR_TME2) != 0U)) + { + /* Select an empty transmit mailbox */ + transmitmailbox = (tsr & CAN_TSR_CODE) >> CAN_TSR_CODE_Pos; + + /* Check transmit mailbox value */ + if (transmitmailbox > 2U) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_INTERNAL; + + return HAL_ERROR; + } + + /* Store the Tx mailbox */ + *pTxMailbox = (uint32_t)1 << transmitmailbox; + + /* Set up the Id */ + if (pHeader->IDE == CAN_ID_STD) + { + hcan->Instance->sTxMailBox[transmitmailbox].TIR = ((pHeader->StdId << CAN_TI0R_STID_Pos) | + pHeader->RTR); + } + else + { + hcan->Instance->sTxMailBox[transmitmailbox].TIR = ((pHeader->ExtId << CAN_TI0R_EXID_Pos) | + pHeader->IDE | + pHeader->RTR); + } + + /* Set up the DLC */ + hcan->Instance->sTxMailBox[transmitmailbox].TDTR = (pHeader->DLC); + + /* Set up the Transmit Global Time mode */ + if (pHeader->TransmitGlobalTime == ENABLE) + { + SET_BIT(hcan->Instance->sTxMailBox[transmitmailbox].TDTR, CAN_TDT0R_TGT); + } + + /* Set up the data field */ + WRITE_REG(hcan->Instance->sTxMailBox[transmitmailbox].TDHR, + ((uint32_t)aData[7] << CAN_TDH0R_DATA7_Pos) | + ((uint32_t)aData[6] << CAN_TDH0R_DATA6_Pos) | + ((uint32_t)aData[5] << CAN_TDH0R_DATA5_Pos) | + ((uint32_t)aData[4] << CAN_TDH0R_DATA4_Pos)); + WRITE_REG(hcan->Instance->sTxMailBox[transmitmailbox].TDLR, + ((uint32_t)aData[3] << CAN_TDL0R_DATA3_Pos) | + ((uint32_t)aData[2] << CAN_TDL0R_DATA2_Pos) | + ((uint32_t)aData[1] << CAN_TDL0R_DATA1_Pos) | + ((uint32_t)aData[0] << CAN_TDL0R_DATA0_Pos)); + + /* Request transmission */ + SET_BIT(hcan->Instance->sTxMailBox[transmitmailbox].TIR, CAN_TI0R_TXRQ); + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_PARAM; + + return HAL_ERROR; + } + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + return HAL_ERROR; + } +} + +/** + * @brief Abort transmission requests + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param TxMailboxes List of the Tx Mailboxes to abort. + * This parameter can be any combination of @arg CAN_Tx_Mailboxes. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_AbortTxRequest(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes) +{ + HAL_CAN_StateTypeDef state = hcan->State; + + /* Check function parameters */ + assert_param(IS_CAN_TX_MAILBOX_LIST(TxMailboxes)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check Tx Mailbox 0 */ + if ((TxMailboxes & CAN_TX_MAILBOX0) != 0U) + { + /* Add cancellation request for Tx Mailbox 0 */ + SET_BIT(hcan->Instance->TSR, CAN_TSR_ABRQ0); + } + + /* Check Tx Mailbox 1 */ + if ((TxMailboxes & CAN_TX_MAILBOX1) != 0U) + { + /* Add cancellation request for Tx Mailbox 1 */ + SET_BIT(hcan->Instance->TSR, CAN_TSR_ABRQ1); + } + + /* Check Tx Mailbox 2 */ + if ((TxMailboxes & CAN_TX_MAILBOX2) != 0U) + { + /* Add cancellation request for Tx Mailbox 2 */ + SET_BIT(hcan->Instance->TSR, CAN_TSR_ABRQ2); + } + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + return HAL_ERROR; + } +} + +/** + * @brief Return Tx Mailboxes free level: number of free Tx Mailboxes. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval Number of free Tx Mailboxes. + */ +uint32_t HAL_CAN_GetTxMailboxesFreeLevel(CAN_HandleTypeDef *hcan) +{ + uint32_t freelevel = 0U; + HAL_CAN_StateTypeDef state = hcan->State; + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check Tx Mailbox 0 status */ + if ((hcan->Instance->TSR & CAN_TSR_TME0) != 0U) + { + freelevel++; + } + + /* Check Tx Mailbox 1 status */ + if ((hcan->Instance->TSR & CAN_TSR_TME1) != 0U) + { + freelevel++; + } + + /* Check Tx Mailbox 2 status */ + if ((hcan->Instance->TSR & CAN_TSR_TME2) != 0U) + { + freelevel++; + } + } + + /* Return Tx Mailboxes free level */ + return freelevel; +} + +/** + * @brief Check if a transmission request is pending on the selected Tx + * Mailboxes. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param TxMailboxes List of Tx Mailboxes to check. + * This parameter can be any combination of @arg CAN_Tx_Mailboxes. + * @retval Status + * - 0 : No pending transmission request on any selected Tx Mailboxes. + * - 1 : Pending transmission request on at least one of the selected + * Tx Mailbox. + */ +uint32_t HAL_CAN_IsTxMessagePending(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes) +{ + uint32_t status = 0U; + HAL_CAN_StateTypeDef state = hcan->State; + + /* Check function parameters */ + assert_param(IS_CAN_TX_MAILBOX_LIST(TxMailboxes)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check pending transmission request on the selected Tx Mailboxes */ + if ((hcan->Instance->TSR & (TxMailboxes << CAN_TSR_TME0_Pos)) != (TxMailboxes << CAN_TSR_TME0_Pos)) + { + status = 1U; + } + } + + /* Return status */ + return status; +} + +/** + * @brief Return timestamp of Tx message sent, if time triggered communication + mode is enabled. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param TxMailbox Tx Mailbox where the timestamp of message sent will be + * read. + * This parameter can be one value of @arg CAN_Tx_Mailboxes. + * @retval Timestamp of message sent from Tx Mailbox. + */ +uint32_t HAL_CAN_GetTxTimestamp(CAN_HandleTypeDef *hcan, uint32_t TxMailbox) +{ + uint32_t timestamp = 0U; + uint32_t transmitmailbox; + HAL_CAN_StateTypeDef state = hcan->State; + + /* Check function parameters */ + assert_param(IS_CAN_TX_MAILBOX(TxMailbox)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Select the Tx mailbox */ + /* Select the Tx mailbox */ + if (TxMailbox == CAN_TX_MAILBOX0) + { + transmitmailbox = 0U; + } + else if (TxMailbox == CAN_TX_MAILBOX1) + { + transmitmailbox = 1U; + } + else /* (TxMailbox == CAN_TX_MAILBOX2) */ + { + transmitmailbox = 2U; + } + + /* Get timestamp */ + timestamp = (hcan->Instance->sTxMailBox[transmitmailbox].TDTR & CAN_TDT0R_TIME) >> CAN_TDT0R_TIME_Pos; + } + + /* Return the timestamp */ + return timestamp; +} + +/** + * @brief Get an CAN frame from the Rx FIFO zone into the message RAM. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param RxFifo Fifo number of the received message to be read. + * This parameter can be a value of @arg CAN_receive_FIFO_number. + * @param pHeader pointer to a CAN_RxHeaderTypeDef structure where the header + * of the Rx frame will be stored. + * @param aData array where the payload of the Rx frame will be stored. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, CAN_RxHeaderTypeDef *pHeader, uint8_t aData[]) +{ + HAL_CAN_StateTypeDef state = hcan->State; + + assert_param(IS_CAN_RX_FIFO(RxFifo)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check the Rx FIFO */ + if (RxFifo == CAN_RX_FIFO0) /* Rx element is assigned to Rx FIFO 0 */ + { + /* Check that the Rx FIFO 0 is not empty */ + if ((hcan->Instance->RF0R & CAN_RF0R_FMP0) == 0U) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_PARAM; + + return HAL_ERROR; + } + } + else /* Rx element is assigned to Rx FIFO 1 */ + { + /* Check that the Rx FIFO 1 is not empty */ + if ((hcan->Instance->RF1R & CAN_RF1R_FMP1) == 0U) + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_PARAM; + + return HAL_ERROR; + } + } + + /* Get the header */ + pHeader->IDE = CAN_RI0R_IDE & hcan->Instance->sFIFOMailBox[RxFifo].RIR; + if (pHeader->IDE == CAN_ID_STD) + { + pHeader->StdId = (CAN_RI0R_STID & hcan->Instance->sFIFOMailBox[RxFifo].RIR) >> CAN_TI0R_STID_Pos; + } + else + { + pHeader->ExtId = ((CAN_RI0R_EXID | CAN_RI0R_STID) & hcan->Instance->sFIFOMailBox[RxFifo].RIR) >> CAN_RI0R_EXID_Pos; + } + pHeader->RTR = (CAN_RI0R_RTR & hcan->Instance->sFIFOMailBox[RxFifo].RIR); + pHeader->DLC = (CAN_RDT0R_DLC & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_DLC_Pos; + pHeader->FilterMatchIndex = (CAN_RDT0R_FMI & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_FMI_Pos; + pHeader->Timestamp = (CAN_RDT0R_TIME & hcan->Instance->sFIFOMailBox[RxFifo].RDTR) >> CAN_RDT0R_TIME_Pos; + + /* Get the data */ + aData[0] = (uint8_t)((CAN_RDL0R_DATA0 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R_DATA0_Pos); + aData[1] = (uint8_t)((CAN_RDL0R_DATA1 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R_DATA1_Pos); + aData[2] = (uint8_t)((CAN_RDL0R_DATA2 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R_DATA2_Pos); + aData[3] = (uint8_t)((CAN_RDL0R_DATA3 & hcan->Instance->sFIFOMailBox[RxFifo].RDLR) >> CAN_RDL0R_DATA3_Pos); + aData[4] = (uint8_t)((CAN_RDH0R_DATA4 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R_DATA4_Pos); + aData[5] = (uint8_t)((CAN_RDH0R_DATA5 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R_DATA5_Pos); + aData[6] = (uint8_t)((CAN_RDH0R_DATA6 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R_DATA6_Pos); + aData[7] = (uint8_t)((CAN_RDH0R_DATA7 & hcan->Instance->sFIFOMailBox[RxFifo].RDHR) >> CAN_RDH0R_DATA7_Pos); + + /* Release the FIFO */ + if (RxFifo == CAN_RX_FIFO0) /* Rx element is assigned to Rx FIFO 0 */ + { + /* Release RX FIFO 0 */ + SET_BIT(hcan->Instance->RF0R, CAN_RF0R_RFOM0); + } + else /* Rx element is assigned to Rx FIFO 1 */ + { + /* Release RX FIFO 1 */ + SET_BIT(hcan->Instance->RF1R, CAN_RF1R_RFOM1); + } + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + return HAL_ERROR; + } +} + +/** + * @brief Return Rx FIFO fill level. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param RxFifo Rx FIFO. + * This parameter can be a value of @arg CAN_receive_FIFO_number. + * @retval Number of messages available in Rx FIFO. + */ +uint32_t HAL_CAN_GetRxFifoFillLevel(CAN_HandleTypeDef *hcan, uint32_t RxFifo) +{ + uint32_t filllevel = 0U; + HAL_CAN_StateTypeDef state = hcan->State; + + /* Check function parameters */ + assert_param(IS_CAN_RX_FIFO(RxFifo)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + if (RxFifo == CAN_RX_FIFO0) + { + filllevel = hcan->Instance->RF0R & CAN_RF0R_FMP0; + } + else /* RxFifo == CAN_RX_FIFO1 */ + { + filllevel = hcan->Instance->RF1R & CAN_RF1R_FMP1; + } + } + + /* Return Rx FIFO fill level */ + return filllevel; +} + +/** + * @} + */ + +/** @defgroup CAN_Exported_Functions_Group4 Interrupts management + * @brief Interrupts management + * +@verbatim + ============================================================================== + ##### Interrupts management ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) HAL_CAN_ActivateNotification : Enable interrupts + (+) HAL_CAN_DeactivateNotification : Disable interrupts + (+) HAL_CAN_IRQHandler : Handles CAN interrupt request + +@endverbatim + * @{ + */ + +/** + * @brief Enable interrupts. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param ActiveITs indicates which interrupts will be enabled. + * This parameter can be any combination of @arg CAN_Interrupts. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_ActivateNotification(CAN_HandleTypeDef *hcan, uint32_t ActiveITs) +{ + HAL_CAN_StateTypeDef state = hcan->State; + + /* Check function parameters */ + assert_param(IS_CAN_IT(ActiveITs)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Enable the selected interrupts */ + __HAL_CAN_ENABLE_IT(hcan, ActiveITs); + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + return HAL_ERROR; + } +} + +/** + * @brief Disable interrupts. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @param InactiveITs indicates which interrupts will be disabled. + * This parameter can be any combination of @arg CAN_Interrupts. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_DeactivateNotification(CAN_HandleTypeDef *hcan, uint32_t InactiveITs) +{ + HAL_CAN_StateTypeDef state = hcan->State; + + /* Check function parameters */ + assert_param(IS_CAN_IT(InactiveITs)); + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Disable the selected interrupts */ + __HAL_CAN_DISABLE_IT(hcan, InactiveITs); + + /* Return function status */ + return HAL_OK; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + return HAL_ERROR; + } +} + +/** + * @brief Handles CAN interrupt request + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +void HAL_CAN_IRQHandler(CAN_HandleTypeDef *hcan) +{ + uint32_t errorcode = HAL_CAN_ERROR_NONE; + uint32_t interrupts = READ_REG(hcan->Instance->IER); + uint32_t msrflags = READ_REG(hcan->Instance->MSR); + uint32_t tsrflags = READ_REG(hcan->Instance->TSR); + uint32_t rf0rflags = READ_REG(hcan->Instance->RF0R); + uint32_t rf1rflags = READ_REG(hcan->Instance->RF1R); + uint32_t esrflags = READ_REG(hcan->Instance->ESR); + + /* Transmit Mailbox empty interrupt management *****************************/ + if ((interrupts & CAN_IT_TX_MAILBOX_EMPTY) != 0U) + { + /* Transmit Mailbox 0 management *****************************************/ + if ((tsrflags & CAN_TSR_RQCP0) != 0U) + { + /* Clear the Transmission Complete flag (and TXOK0,ALST0,TERR0 bits) */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_RQCP0); + + if ((tsrflags & CAN_TSR_TXOK0) != 0U) + { + /* Transmission Mailbox 0 complete callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->TxMailbox0CompleteCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_TxMailbox0CompleteCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + else + { + if ((tsrflags & CAN_TSR_ALST0) != 0U) + { + /* Update error code */ + errorcode |= HAL_CAN_ERROR_TX_ALST0; + } + else if ((tsrflags & CAN_TSR_TERR0) != 0U) + { + /* Update error code */ + errorcode |= HAL_CAN_ERROR_TX_TERR0; + } + else + { + /* Transmission Mailbox 0 abort callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->TxMailbox0AbortCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_TxMailbox0AbortCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + } + + /* Transmit Mailbox 1 management *****************************************/ + if ((tsrflags & CAN_TSR_RQCP1) != 0U) + { + /* Clear the Transmission Complete flag (and TXOK1,ALST1,TERR1 bits) */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_RQCP1); + + if ((tsrflags & CAN_TSR_TXOK1) != 0U) + { + /* Transmission Mailbox 1 complete callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->TxMailbox1CompleteCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_TxMailbox1CompleteCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + else + { + if ((tsrflags & CAN_TSR_ALST1) != 0U) + { + /* Update error code */ + errorcode |= HAL_CAN_ERROR_TX_ALST1; + } + else if ((tsrflags & CAN_TSR_TERR1) != 0U) + { + /* Update error code */ + errorcode |= HAL_CAN_ERROR_TX_TERR1; + } + else + { + /* Transmission Mailbox 1 abort callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->TxMailbox1AbortCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_TxMailbox1AbortCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + } + + /* Transmit Mailbox 2 management *****************************************/ + if ((tsrflags & CAN_TSR_RQCP2) != 0U) + { + /* Clear the Transmission Complete flag (and TXOK2,ALST2,TERR2 bits) */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_RQCP2); + + if ((tsrflags & CAN_TSR_TXOK2) != 0U) + { + /* Transmission Mailbox 2 complete callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->TxMailbox2CompleteCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_TxMailbox2CompleteCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + else + { + if ((tsrflags & CAN_TSR_ALST2) != 0U) + { + /* Update error code */ + errorcode |= HAL_CAN_ERROR_TX_ALST2; + } + else if ((tsrflags & CAN_TSR_TERR2) != 0U) + { + /* Update error code */ + errorcode |= HAL_CAN_ERROR_TX_TERR2; + } + else + { + /* Transmission Mailbox 2 abort callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->TxMailbox2AbortCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_TxMailbox2AbortCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + } + } + + /* Receive FIFO 0 overrun interrupt management *****************************/ + if ((interrupts & CAN_IT_RX_FIFO0_OVERRUN) != 0U) + { + if ((rf0rflags & CAN_RF0R_FOVR0) != 0U) + { + /* Set CAN error code to Rx Fifo 0 overrun error */ + errorcode |= HAL_CAN_ERROR_RX_FOV0; + + /* Clear FIFO0 Overrun Flag */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FOV0); + } + } + + /* Receive FIFO 0 full interrupt management ********************************/ + if ((interrupts & CAN_IT_RX_FIFO0_FULL) != 0U) + { + if ((rf0rflags & CAN_RF0R_FULL0) != 0U) + { + /* Clear FIFO 0 full Flag */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FF0); + + /* Receive FIFO 0 full Callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->RxFifo0FullCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_RxFifo0FullCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + + /* Receive FIFO 0 message pending interrupt management *********************/ + if ((interrupts & CAN_IT_RX_FIFO0_MSG_PENDING) != 0U) + { + /* Check if message is still pending */ + if ((hcan->Instance->RF0R & CAN_RF0R_FMP0) != 0U) + { + /* Receive FIFO 0 message pending Callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->RxFifo0MsgPendingCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_RxFifo0MsgPendingCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + + /* Receive FIFO 1 overrun interrupt management *****************************/ + if ((interrupts & CAN_IT_RX_FIFO1_OVERRUN) != 0U) + { + if ((rf1rflags & CAN_RF1R_FOVR1) != 0U) + { + /* Set CAN error code to Rx Fifo 1 overrun error */ + errorcode |= HAL_CAN_ERROR_RX_FOV1; + + /* Clear FIFO1 Overrun Flag */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FOV1); + } + } + + /* Receive FIFO 1 full interrupt management ********************************/ + if ((interrupts & CAN_IT_RX_FIFO1_FULL) != 0U) + { + if ((rf1rflags & CAN_RF1R_FULL1) != 0U) + { + /* Clear FIFO 1 full Flag */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_FF1); + + /* Receive FIFO 1 full Callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->RxFifo1FullCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_RxFifo1FullCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + + /* Receive FIFO 1 message pending interrupt management *********************/ + if ((interrupts & CAN_IT_RX_FIFO1_MSG_PENDING) != 0U) + { + /* Check if message is still pending */ + if ((hcan->Instance->RF1R & CAN_RF1R_FMP1) != 0U) + { + /* Receive FIFO 1 message pending Callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->RxFifo1MsgPendingCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_RxFifo1MsgPendingCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + + /* Sleep interrupt management *********************************************/ + if ((interrupts & CAN_IT_SLEEP_ACK) != 0U) + { + if ((msrflags & CAN_MSR_SLAKI) != 0U) + { + /* Clear Sleep interrupt Flag */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_SLAKI); + + /* Sleep Callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->SleepCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_SleepCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + + /* WakeUp interrupt management *********************************************/ + if ((interrupts & CAN_IT_WAKEUP) != 0U) + { + if ((msrflags & CAN_MSR_WKUI) != 0U) + { + /* Clear WakeUp Flag */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_WKU); + + /* WakeUp Callback */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->WakeUpFromRxMsgCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_WakeUpFromRxMsgCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } + } + + /* Error interrupts management *********************************************/ + if ((interrupts & CAN_IT_ERROR) != 0U) + { + if ((msrflags & CAN_MSR_ERRI) != 0U) + { + /* Check Error Warning Flag */ + if (((interrupts & CAN_IT_ERROR_WARNING) != 0U) && + ((esrflags & CAN_ESR_EWGF) != 0U)) + { + /* Set CAN error code to Error Warning */ + errorcode |= HAL_CAN_ERROR_EWG; + + /* No need for clear of Error Warning Flag as read-only */ + } + + /* Check Error Passive Flag */ + if (((interrupts & CAN_IT_ERROR_PASSIVE) != 0U) && + ((esrflags & CAN_ESR_EPVF) != 0U)) + { + /* Set CAN error code to Error Passive */ + errorcode |= HAL_CAN_ERROR_EPV; + + /* No need for clear of Error Passive Flag as read-only */ + } + + /* Check Bus-off Flag */ + if (((interrupts & CAN_IT_BUSOFF) != 0U) && + ((esrflags & CAN_ESR_BOFF) != 0U)) + { + /* Set CAN error code to Bus-Off */ + errorcode |= HAL_CAN_ERROR_BOF; + + /* No need for clear of Error Bus-Off as read-only */ + } + + /* Check Last Error Code Flag */ + if (((interrupts & CAN_IT_LAST_ERROR_CODE) != 0U) && + ((esrflags & CAN_ESR_LEC) != 0U)) + { + switch (esrflags & CAN_ESR_LEC) + { + case (CAN_ESR_LEC_0): + /* Set CAN error code to Stuff error */ + errorcode |= HAL_CAN_ERROR_STF; + break; + case (CAN_ESR_LEC_1): + /* Set CAN error code to Form error */ + errorcode |= HAL_CAN_ERROR_FOR; + break; + case (CAN_ESR_LEC_1 | CAN_ESR_LEC_0): + /* Set CAN error code to Acknowledgement error */ + errorcode |= HAL_CAN_ERROR_ACK; + break; + case (CAN_ESR_LEC_2): + /* Set CAN error code to Bit recessive error */ + errorcode |= HAL_CAN_ERROR_BR; + break; + case (CAN_ESR_LEC_2 | CAN_ESR_LEC_0): + /* Set CAN error code to Bit Dominant error */ + errorcode |= HAL_CAN_ERROR_BD; + break; + case (CAN_ESR_LEC_2 | CAN_ESR_LEC_1): + /* Set CAN error code to CRC error */ + errorcode |= HAL_CAN_ERROR_CRC; + break; + default: + break; + } + + /* Clear Last error code Flag */ + CLEAR_BIT(hcan->Instance->ESR, CAN_ESR_LEC); + } + } + + /* Clear ERRI Flag */ + __HAL_CAN_CLEAR_FLAG(hcan, CAN_FLAG_ERRI); + } + + /* Call the Error call Back in case of Errors */ + if (errorcode != HAL_CAN_ERROR_NONE) + { + /* Update error code in handle */ + hcan->ErrorCode |= errorcode; + + /* Call Error callback function */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + /* Call registered callback*/ + hcan->ErrorCallback(hcan); +#else + /* Call weak (surcharged) callback */ + HAL_CAN_ErrorCallback(hcan); +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ + } +} + +/** + * @} + */ + +/** @defgroup CAN_Exported_Functions_Group5 Callback functions + * @brief CAN Callback functions + * +@verbatim + ============================================================================== + ##### Callback functions ##### + ============================================================================== + [..] + This subsection provides the following callback functions: + (+) HAL_CAN_TxMailbox0CompleteCallback + (+) HAL_CAN_TxMailbox1CompleteCallback + (+) HAL_CAN_TxMailbox2CompleteCallback + (+) HAL_CAN_TxMailbox0AbortCallback + (+) HAL_CAN_TxMailbox1AbortCallback + (+) HAL_CAN_TxMailbox2AbortCallback + (+) HAL_CAN_RxFifo0MsgPendingCallback + (+) HAL_CAN_RxFifo0FullCallback + (+) HAL_CAN_RxFifo1MsgPendingCallback + (+) HAL_CAN_RxFifo1FullCallback + (+) HAL_CAN_SleepCallback + (+) HAL_CAN_WakeUpFromRxMsgCallback + (+) HAL_CAN_ErrorCallback + +@endverbatim + * @{ + */ + +/** + * @brief Transmission Mailbox 0 complete callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_TxMailbox0CompleteCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_TxMailbox0CompleteCallback could be implemented in the + user file + */ +} + +/** + * @brief Transmission Mailbox 1 complete callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_TxMailbox1CompleteCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_TxMailbox1CompleteCallback could be implemented in the + user file + */ +} + +/** + * @brief Transmission Mailbox 2 complete callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_TxMailbox2CompleteCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_TxMailbox2CompleteCallback could be implemented in the + user file + */ +} + +/** + * @brief Transmission Mailbox 0 Cancellation callback. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_TxMailbox0AbortCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_TxMailbox0AbortCallback could be implemented in the + user file + */ +} + +/** + * @brief Transmission Mailbox 1 Cancellation callback. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_TxMailbox1AbortCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_TxMailbox1AbortCallback could be implemented in the + user file + */ +} + +/** + * @brief Transmission Mailbox 2 Cancellation callback. + * @param hcan pointer to an CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_TxMailbox2AbortCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_TxMailbox2AbortCallback could be implemented in the + user file + */ +} + +/** + * @brief Rx FIFO 0 message pending callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_RxFifo0MsgPendingCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_RxFifo0MsgPendingCallback could be implemented in the + user file + */ +} + +/** + * @brief Rx FIFO 0 full callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_RxFifo0FullCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_RxFifo0FullCallback could be implemented in the user + file + */ +} + +/** + * @brief Rx FIFO 1 message pending callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_RxFifo1MsgPendingCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_RxFifo1MsgPendingCallback could be implemented in the + user file + */ +} + +/** + * @brief Rx FIFO 1 full callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_RxFifo1FullCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_RxFifo1FullCallback could be implemented in the user + file + */ +} + +/** + * @brief Sleep callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_SleepCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_SleepCallback could be implemented in the user file + */ +} + +/** + * @brief WakeUp from Rx message callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_WakeUpFromRxMsgCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_WakeUpFromRxMsgCallback could be implemented in the + user file + */ +} + +/** + * @brief Error CAN callback. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval None + */ +__weak void HAL_CAN_ErrorCallback(CAN_HandleTypeDef *hcan) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcan); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_CAN_ErrorCallback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup CAN_Exported_Functions_Group6 Peripheral State and Error functions + * @brief CAN Peripheral State functions + * +@verbatim + ============================================================================== + ##### Peripheral State and Error functions ##### + ============================================================================== + [..] + This subsection provides functions allowing to : + (+) HAL_CAN_GetState() : Return the CAN state. + (+) HAL_CAN_GetError() : Return the CAN error codes if any. + (+) HAL_CAN_ResetError(): Reset the CAN error codes if any. + +@endverbatim + * @{ + */ + +/** + * @brief Return the CAN state. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL state + */ +HAL_CAN_StateTypeDef HAL_CAN_GetState(CAN_HandleTypeDef *hcan) +{ + HAL_CAN_StateTypeDef state = hcan->State; + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Check sleep mode acknowledge flag */ + if ((hcan->Instance->MSR & CAN_MSR_SLAK) != 0U) + { + /* Sleep mode is active */ + state = HAL_CAN_STATE_SLEEP_ACTIVE; + } + /* Check sleep mode request flag */ + else if ((hcan->Instance->MCR & CAN_MCR_SLEEP) != 0U) + { + /* Sleep mode request is pending */ + state = HAL_CAN_STATE_SLEEP_PENDING; + } + else + { + /* Neither sleep mode request nor sleep mode acknowledge */ + } + } + + /* Return CAN state */ + return state; +} + +/** + * @brief Return the CAN error code. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval CAN Error Code + */ +uint32_t HAL_CAN_GetError(CAN_HandleTypeDef *hcan) +{ + /* Return CAN error code */ + return hcan->ErrorCode; +} + +/** + * @brief Reset the CAN error code. + * @param hcan pointer to a CAN_HandleTypeDef structure that contains + * the configuration information for the specified CAN. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CAN_ResetError(CAN_HandleTypeDef *hcan) +{ + HAL_StatusTypeDef status = HAL_OK; + HAL_CAN_StateTypeDef state = hcan->State; + + if ((state == HAL_CAN_STATE_READY) || + (state == HAL_CAN_STATE_LISTENING)) + { + /* Reset CAN error code */ + hcan->ErrorCode = 0U; + } + else + { + /* Update error code */ + hcan->ErrorCode |= HAL_CAN_ERROR_NOT_INITIALIZED; + + status = HAL_ERROR; + } + + /* Return the status */ + return status; +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_CAN_MODULE_ENABLED */ + +/** + * @} + */ + +#endif /* CAN */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cec.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cec.c new file mode 100644 index 0000000..5fe1f7e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cec.c @@ -0,0 +1,997 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_cec.c + * @author MCD Application Team + * @brief CEC HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the High Definition Multimedia Interface + * Consumer Electronics Control Peripheral (CEC). + * + Initialization and de-initialization function + * + IO operation function + * + Peripheral Control function + * + * + @verbatim + =============================================================================== + ##### How to use this driver ##### + =============================================================================== + [..] + The CEC HAL driver can be used as follow: + + (#) Declare a CEC_HandleTypeDef handle structure. + (#) Initialize the CEC low level resources by implementing the HAL_CEC_MspInit ()API: + (##) Enable the CEC interface clock. + (##) CEC pins configuration: + (+++) Enable the clock for the CEC GPIOs. + (+++) Configure these CEC pins as alternate function pull-up. + (##) NVIC configuration if you need to use interrupt process (HAL_CEC_Transmit_IT() + and HAL_CEC_Receive_IT() APIs): + (+++) Configure the CEC interrupt priority. + (+++) Enable the NVIC CEC IRQ handle. + (+++) The specific CEC interrupts (Transmission complete interrupt, + RXNE interrupt and Error Interrupts) will be managed using the macros + __HAL_CEC_ENABLE_IT() and __HAL_CEC_DISABLE_IT() inside the transmit + and receive process. + + (#) Program the Signal Free Time (SFT) and SFT option, Tolerance, reception stop in + in case of Bit Rising Error, Error-Bit generation conditions, device logical + address and Listen mode in the hcec Init structure. + + (#) Initialize the CEC registers by calling the HAL_CEC_Init() API. + + [..] + (@) This API (HAL_CEC_Init()) configures also the low level Hardware (GPIO, CLOCK, CORTEX...etc) + by calling the customed HAL_CEC_MspInit() API. + *** Callback registration *** + ============================================= + + The compilation define USE_HAL_CEC_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_CEC_RegisterCallback() or HAL_CEC_RegisterXXXCallback() + to register an interrupt callback. + + Function HAL_CEC_RegisterCallback() allows to register following callbacks: + (+) TxCpltCallback : Tx Transfer completed callback. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : CEC MspInit. + (+) MspDeInitCallback : CEC MspDeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + For specific callback HAL_CEC_RxCpltCallback use dedicated register callbacks + HAL_CEC_RegisterRxCpltCallback(). + + Use function HAL_CEC_UnRegisterCallback() to reset a callback to the default + weak function. + HAL_CEC_UnRegisterCallback() takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) TxCpltCallback : Tx Transfer completed callback. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : CEC MspInit. + (+) MspDeInitCallback : CEC MspDeInit. + + For callback HAL_CEC_RxCpltCallback use dedicated unregister callback : + HAL_CEC_UnRegisterRxCpltCallback(). + + By default, after the HAL_CEC_Init() and when the state is HAL_CEC_STATE_RESET + all callbacks are set to the corresponding weak functions : + examples HAL_CEC_TxCpltCallback() , HAL_CEC_RxCpltCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak function in the HAL_CEC_Init()/ HAL_CEC_DeInit() only when + these callbacks are null (not registered beforehand). + if not, MspInit or MspDeInit are not null, the HAL_CEC_Init() / HAL_CEC_DeInit() + keep and use the user MspInit/MspDeInit functions (registered beforehand) + + Callbacks can be registered/unregistered in HAL_CEC_STATE_READY state only. + Exception done MspInit/MspDeInit callbacks that can be registered/unregistered + in HAL_CEC_STATE_READY or HAL_CEC_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_CEC_RegisterCallback() before calling HAL_CEC_DeInit() + or HAL_CEC_Init() function. + + When the compilation define USE_HAL_CEC_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup CEC CEC + * @brief HAL CEC module driver + * @{ + */ +#ifdef HAL_CEC_MODULE_ENABLED +#if defined (CEC) + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup CEC_Private_Constants CEC Private Constants + * @{ + */ +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup CEC_Private_Functions CEC Private Functions + * @{ + */ +/** + * @} + */ + +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup CEC_Exported_Functions CEC Exported Functions + * @{ + */ + +/** @defgroup CEC_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim +=============================================================================== + ##### Initialization and Configuration functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to initialize the CEC + (+) The following parameters need to be configured: + (++) SignalFreeTime + (++) Tolerance + (++) BRERxStop (RX stopped or not upon Bit Rising Error) + (++) BREErrorBitGen (Error-Bit generation in case of Bit Rising Error) + (++) LBPEErrorBitGen (Error-Bit generation in case of Long Bit Period Error) + (++) BroadcastMsgNoErrorBitGen (Error-bit generation in case of broadcast message error) + (++) SignalFreeTimeOption (SFT Timer start definition) + (++) OwnAddress (CEC device address) + (++) ListenMode + +@endverbatim + * @{ + */ + +/** + * @brief Initializes the CEC mode according to the specified + * parameters in the CEC_InitTypeDef and creates the associated handle . + * @param hcec CEC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CEC_Init(CEC_HandleTypeDef *hcec) +{ + /* Check the CEC handle allocation */ + if ((hcec == NULL) || (hcec->Init.RxBuffer == NULL)) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_CEC_ALL_INSTANCE(hcec->Instance)); + assert_param(IS_CEC_SIGNALFREETIME(hcec->Init.SignalFreeTime)); + assert_param(IS_CEC_TOLERANCE(hcec->Init.Tolerance)); + assert_param(IS_CEC_BRERXSTOP(hcec->Init.BRERxStop)); + assert_param(IS_CEC_BREERRORBITGEN(hcec->Init.BREErrorBitGen)); + assert_param(IS_CEC_LBPEERRORBITGEN(hcec->Init.LBPEErrorBitGen)); + assert_param(IS_CEC_BROADCASTERROR_NO_ERRORBIT_GENERATION(hcec->Init.BroadcastMsgNoErrorBitGen)); + assert_param(IS_CEC_SFTOP(hcec->Init.SignalFreeTimeOption)); + assert_param(IS_CEC_LISTENING_MODE(hcec->Init.ListenMode)); + assert_param(IS_CEC_OWN_ADDRESS(hcec->Init.OwnAddress)); + +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) + if (hcec->gState == HAL_CEC_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hcec->Lock = HAL_UNLOCKED; + + hcec->TxCpltCallback = HAL_CEC_TxCpltCallback; /* Legacy weak TxCpltCallback */ + hcec->RxCpltCallback = HAL_CEC_RxCpltCallback; /* Legacy weak RxCpltCallback */ + hcec->ErrorCallback = HAL_CEC_ErrorCallback; /* Legacy weak ErrorCallback */ + + if (hcec->MspInitCallback == NULL) + { + hcec->MspInitCallback = HAL_CEC_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware */ + hcec->MspInitCallback(hcec); + } +#else + if (hcec->gState == HAL_CEC_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hcec->Lock = HAL_UNLOCKED; + /* Init the low level hardware : GPIO, CLOCK */ + HAL_CEC_MspInit(hcec); + } +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ + + hcec->gState = HAL_CEC_STATE_BUSY; + + /* Disable the Peripheral */ + __HAL_CEC_DISABLE(hcec); + + /* Write to CEC Control Register */ + hcec->Instance->CFGR = hcec->Init.SignalFreeTime | hcec->Init.Tolerance | hcec->Init.BRERxStop | \ + hcec->Init.BREErrorBitGen | hcec->Init.LBPEErrorBitGen | hcec->Init.BroadcastMsgNoErrorBitGen | \ + hcec->Init.SignalFreeTimeOption | ((uint32_t)(hcec->Init.OwnAddress) << 16U) | \ + hcec->Init.ListenMode; + + /* Enable the following CEC Transmission/Reception interrupts as + * well as the following CEC Transmission/Reception Errors interrupts + * Rx Byte Received IT + * End of Reception IT + * Rx overrun + * Rx bit rising error + * Rx short bit period error + * Rx long bit period error + * Rx missing acknowledge + * Tx Byte Request IT + * End of Transmission IT + * Tx Missing Acknowledge IT + * Tx-Error IT + * Tx-Buffer Underrun IT + * Tx arbitration lost */ + __HAL_CEC_ENABLE_IT(hcec, CEC_IT_RXBR | CEC_IT_RXEND | CEC_IER_RX_ALL_ERR | CEC_IT_TXBR | CEC_IT_TXEND | + CEC_IER_TX_ALL_ERR); + + /* Enable the CEC Peripheral */ + __HAL_CEC_ENABLE(hcec); + + hcec->ErrorCode = HAL_CEC_ERROR_NONE; + hcec->gState = HAL_CEC_STATE_READY; + hcec->RxState = HAL_CEC_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the CEC peripheral + * @param hcec CEC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CEC_DeInit(CEC_HandleTypeDef *hcec) +{ + /* Check the CEC handle allocation */ + if (hcec == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_CEC_ALL_INSTANCE(hcec->Instance)); + + hcec->gState = HAL_CEC_STATE_BUSY; + +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) + if (hcec->MspDeInitCallback == NULL) + { + hcec->MspDeInitCallback = HAL_CEC_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware */ + hcec->MspDeInitCallback(hcec); + +#else + /* DeInit the low level hardware */ + HAL_CEC_MspDeInit(hcec); +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ + + /* Disable the Peripheral */ + __HAL_CEC_DISABLE(hcec); + + /* Clear Flags */ + __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_TXEND | CEC_FLAG_TXBR | CEC_FLAG_RXBR | CEC_FLAG_RXEND | CEC_ISR_ALL_ERROR); + + /* Disable the following CEC Transmission/Reception interrupts as + * well as the following CEC Transmission/Reception Errors interrupts + * Rx Byte Received IT + * End of Reception IT + * Rx overrun + * Rx bit rising error + * Rx short bit period error + * Rx long bit period error + * Rx missing acknowledge + * Tx Byte Request IT + * End of Transmission IT + * Tx Missing Acknowledge IT + * Tx-Error IT + * Tx-Buffer Underrun IT + * Tx arbitration lost */ + __HAL_CEC_DISABLE_IT(hcec, CEC_IT_RXBR | CEC_IT_RXEND | CEC_IER_RX_ALL_ERR | CEC_IT_TXBR | CEC_IT_TXEND | + CEC_IER_TX_ALL_ERR); + + hcec->ErrorCode = HAL_CEC_ERROR_NONE; + hcec->gState = HAL_CEC_STATE_RESET; + hcec->RxState = HAL_CEC_STATE_RESET; + + /* Process Unlock */ + __HAL_UNLOCK(hcec); + + return HAL_OK; +} + +/** + * @brief Initializes the Own Address of the CEC device + * @param hcec CEC handle + * @param CEC_OwnAddress The CEC own address. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CEC_SetDeviceAddress(CEC_HandleTypeDef *hcec, uint16_t CEC_OwnAddress) +{ + /* Check the parameters */ + assert_param(IS_CEC_OWN_ADDRESS(CEC_OwnAddress)); + + if ((hcec->gState == HAL_CEC_STATE_READY) && (hcec->RxState == HAL_CEC_STATE_READY)) + { + /* Process Locked */ + __HAL_LOCK(hcec); + + hcec->gState = HAL_CEC_STATE_BUSY; + + /* Disable the Peripheral */ + __HAL_CEC_DISABLE(hcec); + + if (CEC_OwnAddress != CEC_OWN_ADDRESS_NONE) + { + hcec->Instance->CFGR |= ((uint32_t)CEC_OwnAddress << 16); + } + else + { + hcec->Instance->CFGR &= ~(CEC_CFGR_OAR); + } + + hcec->gState = HAL_CEC_STATE_READY; + hcec->ErrorCode = HAL_CEC_ERROR_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hcec); + + /* Enable the Peripheral */ + __HAL_CEC_ENABLE(hcec); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief CEC MSP Init + * @param hcec CEC handle + * @retval None + */ +__weak void HAL_CEC_MspInit(CEC_HandleTypeDef *hcec) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcec); + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_CEC_MspInit can be implemented in the user file + */ +} + +/** + * @brief CEC MSP DeInit + * @param hcec CEC handle + * @retval None + */ +__weak void HAL_CEC_MspDeInit(CEC_HandleTypeDef *hcec) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcec); + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_CEC_MspDeInit can be implemented in the user file + */ +} +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User CEC Callback + * To be used instead of the weak predefined callback + * @param hcec CEC handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_CEC_TX_CPLT_CB_ID Tx Complete callback ID + * @arg @ref HAL_CEC_ERROR_CB_ID Error callback ID + * @arg @ref HAL_CEC_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_CEC_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CEC_RegisterCallback(CEC_HandleTypeDef *hcec, HAL_CEC_CallbackIDTypeDef CallbackID, + pCEC_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hcec); + + if (hcec->gState == HAL_CEC_STATE_READY) + { + switch (CallbackID) + { + case HAL_CEC_TX_CPLT_CB_ID : + hcec->TxCpltCallback = pCallback; + break; + + case HAL_CEC_ERROR_CB_ID : + hcec->ErrorCallback = pCallback; + break; + + case HAL_CEC_MSPINIT_CB_ID : + hcec->MspInitCallback = pCallback; + break; + + case HAL_CEC_MSPDEINIT_CB_ID : + hcec->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hcec->gState == HAL_CEC_STATE_RESET) + { + switch (CallbackID) + { + case HAL_CEC_MSPINIT_CB_ID : + hcec->MspInitCallback = pCallback; + break; + + case HAL_CEC_MSPDEINIT_CB_ID : + hcec->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hcec); + + return status; +} + +/** + * @brief Unregister an CEC Callback + * CEC callabck is redirected to the weak predefined callback + * @param hcec uart handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_CEC_TX_CPLT_CB_ID Tx Complete callback ID + * @arg @ref HAL_CEC_ERROR_CB_ID Error callback ID + * @arg @ref HAL_CEC_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_CEC_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval status + */ +HAL_StatusTypeDef HAL_CEC_UnRegisterCallback(CEC_HandleTypeDef *hcec, HAL_CEC_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hcec); + + if (hcec->gState == HAL_CEC_STATE_READY) + { + switch (CallbackID) + { + case HAL_CEC_TX_CPLT_CB_ID : + hcec->TxCpltCallback = HAL_CEC_TxCpltCallback; /* Legacy weak TxCpltCallback */ + break; + + case HAL_CEC_ERROR_CB_ID : + hcec->ErrorCallback = HAL_CEC_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_CEC_MSPINIT_CB_ID : + hcec->MspInitCallback = HAL_CEC_MspInit; + break; + + case HAL_CEC_MSPDEINIT_CB_ID : + hcec->MspDeInitCallback = HAL_CEC_MspDeInit; + break; + + default : + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hcec->gState == HAL_CEC_STATE_RESET) + { + switch (CallbackID) + { + case HAL_CEC_MSPINIT_CB_ID : + hcec->MspInitCallback = HAL_CEC_MspInit; + break; + + case HAL_CEC_MSPDEINIT_CB_ID : + hcec->MspDeInitCallback = HAL_CEC_MspDeInit; + break; + + default : + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hcec); + + return status; +} + +/** + * @brief Register CEC RX complete Callback + * To be used instead of the weak HAL_CEC_RxCpltCallback() predefined callback + * @param hcec CEC handle + * @param pCallback pointer to the Rx transfer compelete Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CEC_RegisterRxCpltCallback(CEC_HandleTypeDef *hcec, pCEC_RxCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hcec); + + if (HAL_CEC_STATE_READY == hcec->RxState) + { + hcec->RxCpltCallback = pCallback; + } + else + { + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hcec); + return status; +} + +/** + * @brief UnRegister CEC RX complete Callback + * CEC RX complete Callback is redirected to the weak HAL_CEC_RxCpltCallback() predefined callback + * @param hcec CEC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CEC_UnRegisterRxCpltCallback(CEC_HandleTypeDef *hcec) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hcec); + + if (HAL_CEC_STATE_READY == hcec->RxState) + { + hcec->RxCpltCallback = HAL_CEC_RxCpltCallback; /* Legacy weak CEC RxCpltCallback */ + } + else + { + /* Update the error code */ + hcec->ErrorCode |= HAL_CEC_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hcec); + return status; +} +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup CEC_Exported_Functions_Group2 Input and Output operation functions + * @brief CEC Transmit/Receive functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + This subsection provides a set of functions allowing to manage the CEC data transfers. + + (#) The CEC handle must contain the initiator (TX side) and the destination (RX side) + logical addresses (4-bit long addresses, 0xF for broadcast messages destination) + + (#) The communication is performed using Interrupts. + These API's return the HAL status. + The end of the data processing will be indicated through the + dedicated CEC IRQ when using Interrupt mode. + The HAL_CEC_TxCpltCallback(), HAL_CEC_RxCpltCallback() user callbacks + will be executed respectively at the end of the transmit or Receive process + The HAL_CEC_ErrorCallback() user callback will be executed when a communication + error is detected + + (#) API's with Interrupt are : + (+) HAL_CEC_Transmit_IT() + (+) HAL_CEC_IRQHandler() + + (#) A set of User Callbacks are provided: + (+) HAL_CEC_TxCpltCallback() + (+) HAL_CEC_RxCpltCallback() + (+) HAL_CEC_ErrorCallback() + +@endverbatim + * @{ + */ + +/** + * @brief Send data in interrupt mode + * @param hcec CEC handle + * @param InitiatorAddress Initiator address + * @param DestinationAddress destination logical address + * @param pData pointer to input byte data buffer + * @param Size amount of data to be sent in bytes (without counting the header). + * 0 means only the header is sent (ping operation). + * Maximum TX size is 15 bytes (1 opcode and up to 14 operands). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CEC_Transmit_IT(CEC_HandleTypeDef *hcec, uint8_t InitiatorAddress, uint8_t DestinationAddress, + uint8_t *pData, uint32_t Size) +{ + /* if the peripheral isn't already busy and if there is no previous transmission + already pending due to arbitration lost */ + if (hcec->gState == HAL_CEC_STATE_READY) + { + if ((pData == NULL) && (Size > 0U)) + { + return HAL_ERROR; + } + + assert_param(IS_CEC_ADDRESS(DestinationAddress)); + assert_param(IS_CEC_ADDRESS(InitiatorAddress)); + assert_param(IS_CEC_MSGSIZE(Size)); + + /* Process Locked */ + __HAL_LOCK(hcec); + hcec->pTxBuffPtr = pData; + hcec->gState = HAL_CEC_STATE_BUSY_TX; + hcec->ErrorCode = HAL_CEC_ERROR_NONE; + + /* initialize the number of bytes to send, + * 0 means only one header is sent (ping operation) */ + hcec->TxXferCount = (uint16_t)Size; + + /* in case of no payload (Size = 0), sender is only pinging the system; + Set TX End of Message (TXEOM) bit, must be set before writing data to TXDR */ + if (Size == 0U) + { + __HAL_CEC_LAST_BYTE_TX_SET(hcec); + } + + /* send header block */ + hcec->Instance->TXDR = (uint32_t)(((uint32_t)InitiatorAddress << CEC_INITIATOR_LSB_POS) | DestinationAddress); + + /* Set TX Start of Message (TXSOM) bit */ + __HAL_CEC_FIRST_BYTE_TX_SET(hcec); + + /* Process Unlocked */ + __HAL_UNLOCK(hcec); + + return HAL_OK; + + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Get size of the received frame. + * @param hcec CEC handle + * @retval Frame size + */ +uint32_t HAL_CEC_GetLastReceivedFrameSize(CEC_HandleTypeDef *hcec) +{ + return hcec->RxXferSize; +} + +/** + * @brief Change Rx Buffer. + * @param hcec CEC handle + * @param Rxbuffer Rx Buffer + * @note This function can be called only inside the HAL_CEC_RxCpltCallback() + * @retval Frame size + */ +void HAL_CEC_ChangeRxBuffer(CEC_HandleTypeDef *hcec, uint8_t *Rxbuffer) +{ + hcec->Init.RxBuffer = Rxbuffer; +} + +/** + * @brief This function handles CEC interrupt requests. + * @param hcec CEC handle + * @retval None + */ +void HAL_CEC_IRQHandler(CEC_HandleTypeDef *hcec) +{ + + /* save interrupts register for further error or interrupts handling purposes */ + uint32_t reg; + reg = hcec->Instance->ISR; + + + /* ----------------------------Arbitration Lost Management----------------------------------*/ + /* CEC TX arbitration error interrupt occurred --------------------------------------*/ + if ((reg & CEC_FLAG_ARBLST) != 0U) + { + hcec->ErrorCode = HAL_CEC_ERROR_ARBLST; + __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_ARBLST); + } + + /* ----------------------------Rx Management----------------------------------*/ + /* CEC RX byte received interrupt ---------------------------------------------------*/ + if ((reg & CEC_FLAG_RXBR) != 0U) + { + /* reception is starting */ + hcec->RxState = HAL_CEC_STATE_BUSY_RX; + hcec->RxXferSize++; + /* read received byte */ + *hcec->Init.RxBuffer = (uint8_t) hcec->Instance->RXDR; + hcec->Init.RxBuffer++; + __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_RXBR); + } + + /* CEC RX end received interrupt ---------------------------------------------------*/ + if ((reg & CEC_FLAG_RXEND) != 0U) + { + /* clear IT */ + __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_RXEND); + + /* Rx process is completed, restore hcec->RxState to Ready */ + hcec->RxState = HAL_CEC_STATE_READY; + hcec->ErrorCode = HAL_CEC_ERROR_NONE; + hcec->Init.RxBuffer -= hcec->RxXferSize; +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1U) + hcec->RxCpltCallback(hcec, hcec->RxXferSize); +#else + HAL_CEC_RxCpltCallback(hcec, hcec->RxXferSize); +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ + hcec->RxXferSize = 0U; + } + + /* ----------------------------Tx Management----------------------------------*/ + /* CEC TX byte request interrupt ------------------------------------------------*/ + if ((reg & CEC_FLAG_TXBR) != 0U) + { + --hcec->TxXferCount; + if (hcec->TxXferCount == 0U) + { + /* if this is the last byte transmission, set TX End of Message (TXEOM) bit */ + __HAL_CEC_LAST_BYTE_TX_SET(hcec); + } + /* In all cases transmit the byte */ + hcec->Instance->TXDR = *hcec->pTxBuffPtr; + hcec->pTxBuffPtr++; + /* clear Tx-Byte request flag */ + __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_TXBR); + } + + /* CEC TX end interrupt ------------------------------------------------*/ + if ((reg & CEC_FLAG_TXEND) != 0U) + { + __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_TXEND); + + /* Tx process is ended, restore hcec->gState to Ready */ + hcec->gState = HAL_CEC_STATE_READY; + /* Call the Process Unlocked before calling the Tx call back API to give the possibility to + start again the Transmission under the Tx call back API */ + __HAL_UNLOCK(hcec); + hcec->ErrorCode = HAL_CEC_ERROR_NONE; +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1U) + hcec->TxCpltCallback(hcec); +#else + HAL_CEC_TxCpltCallback(hcec); +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ + } + + /* ----------------------------Rx/Tx Error Management----------------------------------*/ + if ((reg & (CEC_ISR_RXOVR | CEC_ISR_BRE | CEC_ISR_SBPE | CEC_ISR_LBPE | CEC_ISR_RXACKE | CEC_ISR_TXUDR | CEC_ISR_TXERR | + CEC_ISR_TXACKE)) != 0U) + { + hcec->ErrorCode = reg; + __HAL_CEC_CLEAR_FLAG(hcec, HAL_CEC_ERROR_RXOVR | HAL_CEC_ERROR_BRE | CEC_FLAG_LBPE | CEC_FLAG_SBPE | + HAL_CEC_ERROR_RXACKE | HAL_CEC_ERROR_TXUDR | HAL_CEC_ERROR_TXERR | HAL_CEC_ERROR_TXACKE); + + + if ((reg & (CEC_ISR_RXOVR | CEC_ISR_BRE | CEC_ISR_SBPE | CEC_ISR_LBPE | CEC_ISR_RXACKE)) != 0U) + { + hcec->Init.RxBuffer -= hcec->RxXferSize; + hcec->RxXferSize = 0U; + hcec->RxState = HAL_CEC_STATE_READY; + } + else if (((reg & CEC_ISR_ARBLST) == 0U) && ((reg & (CEC_ISR_TXUDR | CEC_ISR_TXERR | CEC_ISR_TXACKE)) != 0U)) + { + /* Set the CEC state ready to be able to start again the process */ + hcec->gState = HAL_CEC_STATE_READY; + } + else + { + /* Nothing todo*/ + } +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1U) + hcec->ErrorCallback(hcec); +#else + /* Error Call Back */ + HAL_CEC_ErrorCallback(hcec); +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ + } + else + { + /* Nothing todo*/ + } +} + +/** + * @brief Tx Transfer completed callback + * @param hcec CEC handle + * @retval None + */ +__weak void HAL_CEC_TxCpltCallback(CEC_HandleTypeDef *hcec) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcec); + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_CEC_TxCpltCallback can be implemented in the user file + */ +} + +/** + * @brief Rx Transfer completed callback + * @param hcec CEC handle + * @param RxFrameSize Size of frame + * @retval None + */ +__weak void HAL_CEC_RxCpltCallback(CEC_HandleTypeDef *hcec, uint32_t RxFrameSize) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcec); + UNUSED(RxFrameSize); + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_CEC_RxCpltCallback can be implemented in the user file + */ +} + +/** + * @brief CEC error callbacks + * @param hcec CEC handle + * @retval None + */ +__weak void HAL_CEC_ErrorCallback(CEC_HandleTypeDef *hcec) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcec); + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_CEC_ErrorCallback can be implemented in the user file + */ +} +/** + * @} + */ + +/** @defgroup CEC_Exported_Functions_Group3 Peripheral Control function + * @brief CEC control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control function ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the CEC. + (+) HAL_CEC_GetState() API can be helpful to check in run-time the state of the CEC peripheral. + (+) HAL_CEC_GetError() API can be helpful to check in run-time the error of the CEC peripheral. +@endverbatim + * @{ + */ +/** + * @brief return the CEC state + * @param hcec pointer to a CEC_HandleTypeDef structure that contains + * the configuration information for the specified CEC module. + * @retval HAL state + */ +HAL_CEC_StateTypeDef HAL_CEC_GetState(CEC_HandleTypeDef *hcec) +{ + uint32_t temp1, temp2; + temp1 = hcec->gState; + temp2 = hcec->RxState; + + return (HAL_CEC_StateTypeDef)(temp1 | temp2); +} + +/** + * @brief Return the CEC error code + * @param hcec pointer to a CEC_HandleTypeDef structure that contains + * the configuration information for the specified CEC. + * @retval CEC Error Code + */ +uint32_t HAL_CEC_GetError(CEC_HandleTypeDef *hcec) +{ + return hcec->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ +#endif /* CEC */ +#endif /* HAL_CEC_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_comp.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_comp.c new file mode 100644 index 0000000..0a6742b --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_comp.c @@ -0,0 +1,984 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_comp.c + * @author MCD Application Team + * @brief COMP HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the COMP peripheral: + * + Initialization/de-initialization functions + * + I/O operation functions + * + Peripheral Control functions + * + Peripheral State functions + * + @verbatim +================================================================================ + ##### COMP Peripheral features ##### +================================================================================ + + [..] + The STM32F0xx device family integrates up to 2 analog comparators COMP1 and COMP2: + (+) The non inverting input and inverting input can be set to GPIO pins. + + (+) The COMP output is available using HAL_COMP_GetOutputLevel() + and can be set on GPIO pins. + + (+) The COMP output can be redirected to embedded timers (TIM1, TIM2 and TIM3). + + (+) The comparators COMP1 and COMP2 can be combined in window mode. + + (+) The comparators have interrupt capability with wake-up + from Sleep and Stop modes (through the EXTI controller): + (++) COMP1 is internally connected to EXTI Line 21 + (++) COMP2 is internally connected to EXTI Line 22 + + (+) From the corresponding IRQ handler, the right interrupt source can be retrieved with the + macros __HAL_COMP_COMP1_EXTI_GET_FLAG() and __HAL_COMP_COMP2_EXTI_GET_FLAG(). + + + ##### How to use this driver ##### +================================================================================ + [..] + This driver provides functions to configure and program the Comparators of STM32F05x, STM32F07x and STM32F09x devices. + + To use the comparator, perform the following steps: + + (#) Fill in the HAL_COMP_MspInit() to + (++) Configure the comparator input in analog mode using HAL_GPIO_Init() + (++) Configure the comparator output in alternate function mode using HAL_GPIO_Init() to map the comparator + output to the GPIO pin + (++) If required enable the COMP interrupt by configuring and enabling EXTI line in Interrupt mode and + selecting the desired sensitivity level using HAL_GPIO_Init() function. After that enable the comparator + interrupt vector using HAL_NVIC_EnableIRQ() function. + + (#) Configure the comparator using HAL_COMP_Init() function: + (++) Select the inverting input (input minus) + (++) Select the non inverting input (input plus) + (++) Select the output polarity + (++) Select the output redirection + (++) Select the hysteresis level + (++) Select the power mode + (++) Select the event/interrupt mode + (++) Select the window mode + + -@@- HAL_COMP_Init() calls internally __HAL_RCC_SYSCFG_CLK_ENABLE() in order + to access the comparator(s) registers. + + (#) Enable the comparator using HAL_COMP_Start() function or HAL_COMP_Start_IT() function for interrupt mode. + + (#) Use HAL_COMP_TriggerCallback() and/or HAL_COMP_GetOutputLevel() functions + to manage comparator outputs (event/interrupt triggered and output level). + + (#) Disable the comparator using HAL_COMP_Stop() or HAL_COMP_Stop_IT() + function. + + (#) De-initialize the comparator using HAL_COMP_DeInit() function. + + (#) For safety purposes comparator(s) can be locked using HAL_COMP_Lock() function. + Only a MCU reset can reset that protection. + + *** Callback registration *** + ============================================= + [..] + + The compilation flag USE_HAL_COMP_REGISTER_CALLBACKS, when set to 1, + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_COMP_RegisterCallback() + to register an interrupt callback. + [..] + + Function HAL_COMP_RegisterCallback() allows to register following callbacks: + (+) OperationCpltCallback : callback for End of operation. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + [..] + + Use function HAL_COMP_UnRegisterCallback to reset a callback to the default + weak function. + [..] + + HAL_COMP_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) OperationCpltCallback : callback for End of operation. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + [..] + + By default, after the HAL_COMP_Init() and when the state is HAL_COMP_STATE_RESET + all callbacks are set to the corresponding weak functions: + examples HAL_COMP_OperationCpltCallback(), HAL_COMP_ErrorCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak functions in the HAL_COMP_Init()/ HAL_COMP_DeInit() only when + these callbacks are null (not registered beforehand). + [..] + + If MspInit or MspDeInit are not null, the HAL_COMP_Init()/ HAL_COMP_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state. + [..] + + Callbacks can be registered/unregistered in HAL_COMP_STATE_READY state only. + Exception done MspInit/MspDeInit functions that can be registered/unregistered + in HAL_COMP_STATE_READY or HAL_COMP_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + [..] + + Then, the user first registers the MspInit/MspDeInit user callbacks + using HAL_COMP_RegisterCallback() before calling HAL_COMP_DeInit() + or HAL_COMP_Init() function. + [..] + + When the compilation flag USE_HAL_COMP_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* + Additional Tables: + + Table 1. COMP Inputs for the STM32F05x, STM32F07x and STM32F09x devices + +--------------------------------------------------+ + | | | COMP1 | COMP2 | + |-----------------|----------------|---------------| + | | 1/4 VREFINT | OK | OK | + | | 1/2 VREFINT | OK | OK | + | | 3/4 VREFINT | OK | OK | + | Inverting Input | VREFINT | OK | OK | + | | DAC1 OUT (PA4) | OK | OK | + | | DAC2 OUT (PA5) | OK | OK | + | | IO1 | PA0 | PA2 | + |-----------------|----------------|-------|-------| + | Non Inverting | | PA1 | PA3 | + | Input | | | | + +--------------------------------------------------+ + + Table 2. COMP Outputs for the STM32F05x, STM32F07x and STM32F09x devices + +---------------+ + | COMP1 | COMP2 | + |-------|-------| + | PA0 | PA2 | + | PA6 | PA7 | + | PA11 | PA12 | + +---------------+ + + Table 3. COMP Outputs redirection to embedded timers for the STM32F05x, STM32F07x and STM32F09x devices + +---------------------------------+ + | COMP1 | COMP2 | + |----------------|----------------| + | TIM1 BKIN | TIM1 BKIN | + | | | + | TIM1 OCREFCLR | TIM1 OCREFCLR | + | | | + | TIM1 IC1 | TIM1 IC1 | + | | | + | TIM2 IC4 | TIM2 IC4 | + | | | + | TIM2 OCREFCLR | TIM2 OCREFCLR | + | | | + | TIM3 IC1 | TIM3 IC1 | + | | | + | TIM3 OCREFCLR | TIM3 OCREFCLR | + +---------------------------------+ + +*/ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +#ifdef HAL_COMP_MODULE_ENABLED + +#if defined (COMP1) || defined (COMP2) + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup COMP COMP + * @brief COMP HAL module driver + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ + +/** @defgroup COMP_Private_Constants COMP Private Constants + * @{ + */ + +/* Delay for COMP startup time. */ +/* Note: Delay required to reach propagation delay specification. */ +/* Literal set to maximum value (refer to device datasheet, */ +/* parameter "tSTART"). */ +/* Unit: us */ +#define COMP_DELAY_STARTUP_US (60U) /*!< Delay for COMP startup time */ + +/* CSR register reset value */ +#define COMP_CSR_RESET_VALUE (0x00000000U) +/* CSR register masks */ +#define COMP_CSR_RESET_PARAMETERS_MASK (0x00003FFFU) +#define COMP_CSR_UPDATE_PARAMETERS_MASK (0x00003FFEU) +/* CSR COMPx non inverting input mask */ +#define COMP_CSR_COMPxNONINSEL_MASK ((uint16_t)COMP_CSR_COMP1SW1) +/* CSR COMP2 shift */ +#define COMP_CSR_COMP1_SHIFT 0U +#define COMP_CSR_COMP2_SHIFT 16U +/** + * @} + */ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + +/** @defgroup COMP_Exported_Functions COMP Exported Functions + * @{ + */ + +/** @defgroup COMP_Exported_Functions_Group1 Initialization/de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and Configuration functions ##### + =============================================================================== + [..] This section provides functions to initialize and de-initialize comparators + +@endverbatim + * @{ + */ + +/** + * @brief Initializes the COMP according to the specified + * parameters in the COMP_InitTypeDef and create the associated handle. + * @note If the selected comparator is locked, initialization can't be performed. + * To unlock the configuration, perform a system reset. + * @param hcomp COMP handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_Init(COMP_HandleTypeDef *hcomp) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t regshift = COMP_CSR_COMP1_SHIFT; + + /* Check the COMP handle allocation and lock status */ + if((hcomp == NULL) || ((hcomp->State & COMP_STATE_BIT_LOCK) != RESET)) + { + status = HAL_ERROR; + } + else + { + /* Check the parameter */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + assert_param(IS_COMP_INVERTINGINPUT(hcomp->Init.InvertingInput)); + assert_param(IS_COMP_NONINVERTINGINPUT(hcomp->Init.NonInvertingInput)); + assert_param(IS_COMP_OUTPUT(hcomp->Init.Output)); + assert_param(IS_COMP_OUTPUTPOL(hcomp->Init.OutputPol)); + assert_param(IS_COMP_HYSTERESIS(hcomp->Init.Hysteresis)); + assert_param(IS_COMP_MODE(hcomp->Init.Mode)); + + if(hcomp->Init.NonInvertingInput == COMP_NONINVERTINGINPUT_DAC1SWITCHCLOSED) + { + assert_param(IS_COMP_DAC1SWITCH_INSTANCE(hcomp->Instance)); + } + + if(hcomp->Init.WindowMode != COMP_WINDOWMODE_DISABLE) + { + assert_param(IS_COMP_WINDOWMODE_INSTANCE(hcomp->Instance)); + } + + /* Init SYSCFG and the low level hardware to access comparators */ + __HAL_RCC_SYSCFG_CLK_ENABLE(); + +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) + /* Init the COMP Callback settings */ + hcomp->TriggerCallback = HAL_COMP_TriggerCallback; /* Legacy weak callback */ + + if (hcomp->MspInitCallback == NULL) + { + hcomp->MspInitCallback = HAL_COMP_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware */ + hcomp->MspInitCallback(hcomp); +#else + /* Init the low level hardware : SYSCFG to access comparators */ + HAL_COMP_MspInit(hcomp); +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ + + if(hcomp->State == HAL_COMP_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hcomp->Lock = HAL_UNLOCKED; + } + + /* Change COMP peripheral state */ + hcomp->State = HAL_COMP_STATE_BUSY; + + /* Set COMP parameters */ + /* Set COMPxINSEL bits according to hcomp->Init.InvertingInput value */ + /* Set COMPxOUTSEL bits according to hcomp->Init.Output value */ + /* Set COMPxPOL bit according to hcomp->Init.OutputPol value */ + /* Set COMPxHYST bits according to hcomp->Init.Hysteresis value */ + /* Set COMPxMODE bits according to hcomp->Init.Mode value */ + if(hcomp->Instance == COMP2) + { + regshift = COMP_CSR_COMP2_SHIFT; + } + MODIFY_REG(COMP->CSR, + (COMP_CSR_COMPxINSEL | COMP_CSR_COMPxNONINSEL_MASK | \ + COMP_CSR_COMPxOUTSEL | COMP_CSR_COMPxPOL | \ + COMP_CSR_COMPxHYST | COMP_CSR_COMPxMODE) << regshift, + (hcomp->Init.InvertingInput | \ + hcomp->Init.NonInvertingInput | \ + hcomp->Init.Output | \ + hcomp->Init.OutputPol | \ + hcomp->Init.Hysteresis | \ + hcomp->Init.Mode) << regshift); + + if(hcomp->Init.WindowMode != COMP_WINDOWMODE_DISABLE) + { + COMP->CSR |= COMP_CSR_WNDWEN; + } + + /* Initialize the COMP state*/ + hcomp->State = HAL_COMP_STATE_READY; + } + + return status; +} + +/** + * @brief DeInitializes the COMP peripheral + * @note Deinitialization can't be performed if the COMP configuration is locked. + * To unlock the configuration, perform a system reset. + * @param hcomp COMP handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_DeInit(COMP_HandleTypeDef *hcomp) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t regshift = COMP_CSR_COMP1_SHIFT; + + /* Check the COMP handle allocation and lock status */ + if((hcomp == NULL) || ((hcomp->State & COMP_STATE_BIT_LOCK) != RESET)) + { + status = HAL_ERROR; + } + else + { + /* Check the parameter */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + + /* Set COMP_CSR register to reset value for the corresponding COMP instance */ + if(hcomp->Instance == COMP2) + { + regshift = COMP_CSR_COMP2_SHIFT; + } + MODIFY_REG(COMP->CSR, + COMP_CSR_RESET_PARAMETERS_MASK << regshift, + COMP_CSR_RESET_VALUE << regshift); + +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) + if (hcomp->MspDeInitCallback == NULL) + { + hcomp->MspDeInitCallback = HAL_COMP_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware: SYSCFG, GPIO, CLOCK and NVIC */ + hcomp->MspDeInitCallback(hcomp); +#else + /* DeInit the low level hardware: SYSCFG, GPIO, CLOCK and NVIC */ + HAL_COMP_MspDeInit(hcomp); +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ + + hcomp->State = HAL_COMP_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(hcomp); + } + + return status; +} + +/** + * @brief Initializes the COMP MSP. + * @param hcomp COMP handle + * @retval None + */ +__weak void HAL_COMP_MspInit(COMP_HandleTypeDef *hcomp) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcomp); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_COMP_MspInit could be implenetd in the user file + */ +} + +/** + * @brief DeInitializes COMP MSP. + * @param hcomp COMP handle + * @retval None + */ +__weak void HAL_COMP_MspDeInit(COMP_HandleTypeDef *hcomp) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcomp); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_COMP_MspDeInit could be implenetd in the user file + */ +} + +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User COMP Callback + * To be used instead of the weak predefined callback + * @param hcomp Pointer to a COMP_HandleTypeDef structure that contains + * the configuration information for the specified COMP. + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_COMP_TRIGGER_CB_ID Trigger callback ID + * @arg @ref HAL_COMP_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_COMP_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_RegisterCallback(COMP_HandleTypeDef *hcomp, HAL_COMP_CallbackIDTypeDef CallbackID, pCOMP_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hcomp->ErrorCode |= HAL_COMP_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + if (HAL_COMP_STATE_READY == hcomp->State) + { + switch (CallbackID) + { + case HAL_COMP_TRIGGER_CB_ID : + hcomp->TriggerCallback = pCallback; + break; + + case HAL_COMP_MSPINIT_CB_ID : + hcomp->MspInitCallback = pCallback; + break; + + case HAL_COMP_MSPDEINIT_CB_ID : + hcomp->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hcomp->ErrorCode |= HAL_COMP_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_COMP_STATE_RESET == hcomp->State) + { + switch (CallbackID) + { + case HAL_COMP_MSPINIT_CB_ID : + hcomp->MspInitCallback = pCallback; + break; + + case HAL_COMP_MSPDEINIT_CB_ID : + hcomp->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hcomp->ErrorCode |= HAL_COMP_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hcomp->ErrorCode |= HAL_COMP_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + return status; +} + +/** + * @brief Unregister a COMP Callback + * COMP callback is redirected to the weak predefined callback + * @param hcomp Pointer to a COMP_HandleTypeDef structure that contains + * the configuration information for the specified COMP. + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_COMP_TRIGGER_CB_ID Trigger callback ID + * @arg @ref HAL_COMP_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_COMP_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_UnRegisterCallback(COMP_HandleTypeDef *hcomp, HAL_COMP_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (HAL_COMP_STATE_READY == hcomp->State) + { + switch (CallbackID) + { + case HAL_COMP_TRIGGER_CB_ID : + hcomp->TriggerCallback = HAL_COMP_TriggerCallback; /* Legacy weak callback */ + break; + + case HAL_COMP_MSPINIT_CB_ID : + hcomp->MspInitCallback = HAL_COMP_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_COMP_MSPDEINIT_CB_ID : + hcomp->MspDeInitCallback = HAL_COMP_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hcomp->ErrorCode |= HAL_COMP_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_COMP_STATE_RESET == hcomp->State) + { + switch (CallbackID) + { + case HAL_COMP_MSPINIT_CB_ID : + hcomp->MspInitCallback = HAL_COMP_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_COMP_MSPDEINIT_CB_ID : + hcomp->MspDeInitCallback = HAL_COMP_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hcomp->ErrorCode |= HAL_COMP_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hcomp->ErrorCode |= HAL_COMP_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + return status; +} + +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup COMP_Exported_Functions_Group2 I/O operation functions + * @brief Data transfers functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to manage the COMP data + transfers. + +@endverbatim + * @{ + */ + +/** + * @brief Start the comparator + * @param hcomp COMP handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_Start(COMP_HandleTypeDef *hcomp) +{ + uint32_t wait_loop_index = 0U; + HAL_StatusTypeDef status = HAL_OK; + uint32_t regshift = COMP_CSR_COMP1_SHIFT; + + /* Check the COMP handle allocation and lock status */ + if((hcomp == NULL) || ((hcomp->State & COMP_STATE_BIT_LOCK) != RESET)) + { + status = HAL_ERROR; + } + else + { + /* Check the parameter */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + + if(hcomp->State == HAL_COMP_STATE_READY) + { + /* Enable the selected comparator */ + if(hcomp->Instance == COMP2) + { + regshift = COMP_CSR_COMP2_SHIFT; + } + SET_BIT(COMP->CSR, COMP_CSR_COMPxEN << regshift); + + /* Set HAL COMP handle state */ + hcomp->State = HAL_COMP_STATE_BUSY; + + /* Delay for COMP startup time */ + wait_loop_index = (COMP_DELAY_STARTUP_US * (SystemCoreClock / 1000000U)); + while(wait_loop_index != 0U) + { + wait_loop_index--; + } + } + else + { + status = HAL_ERROR; + } + } + + return status; +} + +/** + * @brief Stop the comparator + * @param hcomp COMP handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_Stop(COMP_HandleTypeDef *hcomp) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t regshift = COMP_CSR_COMP1_SHIFT; + + /* Check the COMP handle allocation and lock status */ + if((hcomp == NULL) || ((hcomp->State & COMP_STATE_BIT_LOCK) != RESET)) + { + status = HAL_ERROR; + } + else + { + /* Check the parameter */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + + if(hcomp->State == HAL_COMP_STATE_BUSY) + { + /* Disable the selected comparator */ + if(hcomp->Instance == COMP2) + { + regshift = COMP_CSR_COMP2_SHIFT; + } + CLEAR_BIT(COMP->CSR, COMP_CSR_COMPxEN << regshift); + + hcomp->State = HAL_COMP_STATE_READY; + } + else + { + status = HAL_ERROR; + } + } + + return status; +} + +/** + * @brief Enables the interrupt and starts the comparator + * @param hcomp COMP handle + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_COMP_Start_IT(COMP_HandleTypeDef *hcomp) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t extiline = 0U; + + /* Check the parameter */ + assert_param(IS_COMP_TRIGGERMODE(hcomp->Init.TriggerMode)); + + status = HAL_COMP_Start(hcomp); + if(status == HAL_OK) + { + /* Check the Exti Line output configuration */ + extiline = COMP_GET_EXTI_LINE(hcomp->Instance); + /* Configure the rising edge */ + if((hcomp->Init.TriggerMode & COMP_TRIGGERMODE_IT_RISING) != RESET) + { + SET_BIT(EXTI->RTSR, extiline); + } + else + { + CLEAR_BIT(EXTI->RTSR, extiline); + } + /* Configure the falling edge */ + if((hcomp->Init.TriggerMode & COMP_TRIGGERMODE_IT_FALLING) != RESET) + { + SET_BIT(EXTI->FTSR, extiline); + } + else + { + CLEAR_BIT(EXTI->FTSR, extiline); + } + + /* Clear COMP EXTI pending bit */ + WRITE_REG(EXTI->PR, extiline); + + /* Enable Exti interrupt mode */ + SET_BIT(EXTI->IMR, extiline); + } + + return status; +} + +/** + * @brief Disable the interrupt and Stop the comparator + * @param hcomp COMP handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_Stop_IT(COMP_HandleTypeDef *hcomp) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Disable the Exti Line interrupt mode */ + CLEAR_BIT(EXTI->IMR, COMP_GET_EXTI_LINE(hcomp->Instance)); + + status = HAL_COMP_Stop(hcomp); + + return status; +} + +/** + * @brief Comparator IRQ Handler + * @param hcomp COMP handle + * @retval HAL status + */ +void HAL_COMP_IRQHandler(COMP_HandleTypeDef *hcomp) +{ + uint32_t extiline = COMP_GET_EXTI_LINE(hcomp->Instance); + + /* Check COMP Exti flag */ + if(READ_BIT(EXTI->PR, extiline) != RESET) + { + /* Clear COMP Exti pending bit */ + WRITE_REG(EXTI->PR, extiline); + + /* COMP trigger callback */ +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) + hcomp->TriggerCallback(hcomp); +#else + HAL_COMP_TriggerCallback(hcomp); +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ + } +} + +/** + * @} + */ + +/** @defgroup COMP_Exported_Functions_Group3 Peripheral Control functions + * @brief management functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the COMP data + transfers. + +@endverbatim + * @{ + */ + +/** + * @brief Lock the selected comparator configuration. + * @param hcomp COMP handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_COMP_Lock(COMP_HandleTypeDef *hcomp) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t regshift = COMP_CSR_COMP1_SHIFT; + + /* Check the COMP handle allocation and lock status */ + if((hcomp == NULL) || ((hcomp->State & COMP_STATE_BIT_LOCK) != RESET)) + { + status = HAL_ERROR; + } + else + { + /* Check the parameter */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + + /* Set lock flag */ + hcomp->State |= COMP_STATE_BIT_LOCK; + + /* Set the lock bit corresponding to selected comparator */ + if(hcomp->Instance == COMP2) + { + regshift = COMP_CSR_COMP2_SHIFT; + } + SET_BIT(COMP->CSR, COMP_CSR_COMPxLOCK << regshift); + } + + return status; +} + +/** + * @brief Return the output level (high or low) of the selected comparator. + * The output level depends on the selected polarity. + * If the polarity is not inverted: + * - Comparator output is low when the non-inverting input is at a lower + * voltage than the inverting input + * - Comparator output is high when the non-inverting input is at a higher + * voltage than the inverting input + * If the polarity is inverted: + * - Comparator output is high when the non-inverting input is at a lower + * voltage than the inverting input + * - Comparator output is low when the non-inverting input is at a higher + * voltage than the inverting input + * @param hcomp COMP handle + * @retval Returns the selected comparator output level: COMP_OUTPUTLEVEL_LOW or COMP_OUTPUTLEVEL_HIGH. + * + */ +uint32_t HAL_COMP_GetOutputLevel(COMP_HandleTypeDef *hcomp) +{ + uint32_t level=0; + uint32_t regshift = COMP_CSR_COMP1_SHIFT; + + /* Check the parameter */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + + if(hcomp->Instance == COMP2) + { + regshift = COMP_CSR_COMP2_SHIFT; + } + level = READ_BIT(COMP->CSR, COMP_CSR_COMPxOUT << regshift); + + if(level != 0U) + { + return(COMP_OUTPUTLEVEL_HIGH); + } + return(COMP_OUTPUTLEVEL_LOW); +} + +/** + * @brief Comparator trigger callback. + * @param hcomp COMP handle + * @retval None + */ +__weak void HAL_COMP_TriggerCallback(COMP_HandleTypeDef *hcomp) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcomp); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_COMP_TriggerCallback should be implemented in the user file + */ +} + + +/** + * @} + */ + +/** @defgroup COMP_Exported_Functions_Group4 Peripheral State functions + * @brief Peripheral State functions + * +@verbatim + =============================================================================== + ##### Peripheral State functions ##### + =============================================================================== + [..] + This subsection permit to get in run-time the status of the peripheral + and the data flow. + +@endverbatim + * @{ + */ + +/** + * @brief Return the COMP state + * @param hcomp COMP handle + * @retval HAL state + */ +uint32_t HAL_COMP_GetState(COMP_HandleTypeDef *hcomp) +{ + /* Check the COMP handle allocation */ + if(hcomp == NULL) + { + return HAL_COMP_STATE_RESET; + } + + /* Check the parameter */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + + return hcomp->State; +} + +/** + * @brief Return the COMP error code. + * @param hcomp COMP handle + * @retval COMP error code + */ +uint32_t HAL_COMP_GetError(COMP_HandleTypeDef *hcomp) +{ + /* Check the parameters */ + assert_param(IS_COMP_ALL_INSTANCE(hcomp->Instance)); + + return hcomp->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* COMP1 || COMP2 */ + +#endif /* HAL_COMP_MODULE_ENABLED */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cortex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cortex.c new file mode 100644 index 0000000..cbe3f5b --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_cortex.c @@ -0,0 +1,341 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_cortex.c + * @author MCD Application Team + * @brief CORTEX HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the CORTEX: + * + Initialization and de-initialization functions + * + Peripheral Control functions + * + * @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + + [..] + *** How to configure Interrupts using CORTEX HAL driver *** + =========================================================== + [..] + This section provides functions allowing to configure the NVIC interrupts (IRQ). + The Cortex-M0 exceptions are managed by CMSIS functions. + (#) Enable and Configure the priority of the selected IRQ Channels. + The priority can be 0..3. + + -@- Lower priority values gives higher priority. + -@- Priority Order: + (#@) Lowest priority. + (#@) Lowest hardware priority (IRQn position). + + (#) Configure the priority of the selected IRQ Channels using HAL_NVIC_SetPriority() + + (#) Enable the selected IRQ Channels using HAL_NVIC_EnableIRQ() + + -@- Negative value of IRQn_Type are not allowed. + + + [..] + *** How to configure Systick using CORTEX HAL driver *** + ======================================================== + [..] + Setup SysTick Timer for time base. + + (+) The HAL_SYSTICK_Config()function calls the SysTick_Config() function which + is a CMSIS function that: + (++) Configures the SysTick Reload register with value passed as function parameter. + (++) Configures the SysTick IRQ priority to the lowest value (0x03). + (++) Resets the SysTick Counter register. + (++) Configures the SysTick Counter clock source to be Core Clock Source (HCLK). + (++) Enables the SysTick Interrupt. + (++) Starts the SysTick Counter. + + (+) You can change the SysTick Clock source to be HCLK_Div8 by calling the macro + HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK_DIV8) just after the + HAL_SYSTICK_Config() function call. The HAL_SYSTICK_CLKSourceConfig() macro is defined + inside the stm32f0xx_hal_cortex.h file. + + (+) You can change the SysTick IRQ priority by calling the + HAL_NVIC_SetPriority(SysTick_IRQn,...) function just after the HAL_SYSTICK_Config() function + call. The HAL_NVIC_SetPriority() call the NVIC_SetPriority() function which is a CMSIS function. + + (+) To adjust the SysTick time base, use the following formula: + + Reload Value = SysTick Counter Clock (Hz) x Desired Time base (s) + (++) Reload Value is the parameter to be passed for HAL_SYSTICK_Config() function + (++) Reload Value should not exceed 0xFFFFFF + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup CORTEX CORTEX + * @brief CORTEX CORTEX HAL module driver + * @{ + */ + +#ifdef HAL_CORTEX_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup CORTEX_Exported_Functions CORTEX Exported Functions + * @{ + */ + + +/** @defgroup CORTEX_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + ============================================================================== + ##### Initialization and de-initialization functions ##### + ============================================================================== + [..] + This section provides the CORTEX HAL driver functions allowing to configure Interrupts + Systick functionalities + +@endverbatim + * @{ + */ + +/** + * @brief Sets the priority of an interrupt. + * @param IRQn External interrupt number . + * This parameter can be an enumerator of IRQn_Type enumeration + * (For the complete STM32 Devices IRQ Channels list, please refer to stm32f0xx.h file) + * @param PreemptPriority The preemption priority for the IRQn channel. + * This parameter can be a value between 0 and 3. + * A lower priority value indicates a higher priority + * @param SubPriority the subpriority level for the IRQ channel. + * with stm32f0xx devices, this parameter is a dummy value and it is ignored, because + * no subpriority supported in Cortex M0 based products. + * @retval None + */ +void HAL_NVIC_SetPriority(IRQn_Type IRQn, uint32_t PreemptPriority, uint32_t SubPriority) +{ + /* Check the parameters */ + assert_param(IS_NVIC_PREEMPTION_PRIORITY(PreemptPriority)); + NVIC_SetPriority(IRQn,PreemptPriority); +} + +/** + * @brief Enables a device specific interrupt in the NVIC interrupt controller. + * @note To configure interrupts priority correctly, the NVIC_PriorityGroupConfig() + * function should be called before. + * @param IRQn External interrupt number. + * This parameter can be an enumerator of IRQn_Type enumeration + * (For the complete STM32 Devices IRQ Channels list, please refer to the appropriate CMSIS device file (stm32f0xxxx.h)) + * @retval None + */ +void HAL_NVIC_EnableIRQ(IRQn_Type IRQn) +{ + /* Check the parameters */ + assert_param(IS_NVIC_DEVICE_IRQ(IRQn)); + + /* Enable interrupt */ + NVIC_EnableIRQ(IRQn); +} + +/** + * @brief Disables a device specific interrupt in the NVIC interrupt controller. + * @param IRQn External interrupt number. + * This parameter can be an enumerator of IRQn_Type enumeration + * (For the complete STM32 Devices IRQ Channels list, please refer to the appropriate CMSIS device file (stm32f0xxxx.h)) + * @retval None + */ +void HAL_NVIC_DisableIRQ(IRQn_Type IRQn) +{ + /* Check the parameters */ + assert_param(IS_NVIC_DEVICE_IRQ(IRQn)); + + /* Disable interrupt */ + NVIC_DisableIRQ(IRQn); +} + +/** + * @brief Initiates a system reset request to reset the MCU. + * @retval None + */ +void HAL_NVIC_SystemReset(void) +{ + /* System Reset */ + NVIC_SystemReset(); +} + +/** + * @brief Initializes the System Timer and its interrupt, and starts the System Tick Timer. + * Counter is in free running mode to generate periodic interrupts. + * @param TicksNumb Specifies the ticks Number of ticks between two interrupts. + * @retval status: - 0 Function succeeded. + * - 1 Function failed. + */ +uint32_t HAL_SYSTICK_Config(uint32_t TicksNumb) +{ + return SysTick_Config(TicksNumb); +} +/** + * @} + */ + +/** @defgroup CORTEX_Exported_Functions_Group2 Peripheral Control functions + * @brief Cortex control functions + * +@verbatim + ============================================================================== + ##### Peripheral Control functions ##### + ============================================================================== + [..] + This subsection provides a set of functions allowing to control the CORTEX + (NVIC, SYSTICK) functionalities. + + +@endverbatim + * @{ + */ + + +/** + * @brief Gets the priority of an interrupt. + * @param IRQn External interrupt number. + * This parameter can be an enumerator of IRQn_Type enumeration + * (For the complete STM32 Devices IRQ Channels list, please refer to the appropriate CMSIS device file (stm32f0xxxx.h)) + * @retval None + */ +uint32_t HAL_NVIC_GetPriority(IRQn_Type IRQn) +{ + /* Get priority for Cortex-M system or device specific interrupts */ + return NVIC_GetPriority(IRQn); +} + +/** + * @brief Sets Pending bit of an external interrupt. + * @param IRQn External interrupt number + * This parameter can be an enumerator of IRQn_Type enumeration + * (For the complete STM32 Devices IRQ Channels list, please refer to the appropriate CMSIS device file (stm32f0xxxx.h)) + * @retval None + */ +void HAL_NVIC_SetPendingIRQ(IRQn_Type IRQn) +{ + /* Check the parameters */ + assert_param(IS_NVIC_DEVICE_IRQ(IRQn)); + + /* Set interrupt pending */ + NVIC_SetPendingIRQ(IRQn); +} + +/** + * @brief Gets Pending Interrupt (reads the pending register in the NVIC + * and returns the pending bit for the specified interrupt). + * @param IRQn External interrupt number. + * This parameter can be an enumerator of IRQn_Type enumeration + * (For the complete STM32 Devices IRQ Channels list, please refer to the appropriate CMSIS device file (stm32f0xxxx.h)) + * @retval status: - 0 Interrupt status is not pending. + * - 1 Interrupt status is pending. + */ +uint32_t HAL_NVIC_GetPendingIRQ(IRQn_Type IRQn) +{ + /* Check the parameters */ + assert_param(IS_NVIC_DEVICE_IRQ(IRQn)); + + /* Return 1 if pending else 0 */ + return NVIC_GetPendingIRQ(IRQn); +} + +/** + * @brief Clears the pending bit of an external interrupt. + * @param IRQn External interrupt number. + * This parameter can be an enumerator of IRQn_Type enumeration + * (For the complete STM32 Devices IRQ Channels list, please refer to the appropriate CMSIS device file (stm32f0xxxx.h)) + * @retval None + */ +void HAL_NVIC_ClearPendingIRQ(IRQn_Type IRQn) +{ + /* Check the parameters */ + assert_param(IS_NVIC_DEVICE_IRQ(IRQn)); + + /* Clear pending interrupt */ + NVIC_ClearPendingIRQ(IRQn); +} + +/** + * @brief Configures the SysTick clock source. + * @param CLKSource specifies the SysTick clock source. + * This parameter can be one of the following values: + * @arg SYSTICK_CLKSOURCE_HCLK_DIV8: AHB clock divided by 8 selected as SysTick clock source. + * @arg SYSTICK_CLKSOURCE_HCLK: AHB clock selected as SysTick clock source. + * @retval None + */ +void HAL_SYSTICK_CLKSourceConfig(uint32_t CLKSource) +{ + /* Check the parameters */ + assert_param(IS_SYSTICK_CLK_SOURCE(CLKSource)); + if (CLKSource == SYSTICK_CLKSOURCE_HCLK) + { + SysTick->CTRL |= SYSTICK_CLKSOURCE_HCLK; + } + else + { + SysTick->CTRL &= ~SYSTICK_CLKSOURCE_HCLK; + } +} + +/** + * @brief This function handles SYSTICK interrupt request. + * @retval None + */ +void HAL_SYSTICK_IRQHandler(void) +{ + HAL_SYSTICK_Callback(); +} + +/** + * @brief SYSTICK callback. + * @retval None + */ +__weak void HAL_SYSTICK_Callback(void) +{ + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_SYSTICK_Callback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_CORTEX_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc.c new file mode 100644 index 0000000..b3f63f3 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc.c @@ -0,0 +1,520 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_crc.c + * @author MCD Application Team + * @brief CRC HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Cyclic Redundancy Check (CRC) peripheral: + * + Initialization and de-initialization functions + * + Peripheral Control functions + * + Peripheral State functions + * + @verbatim + =============================================================================== + ##### How to use this driver ##### + =============================================================================== + [..] + (+) Enable CRC AHB clock using __HAL_RCC_CRC_CLK_ENABLE(); + (+) Initialize CRC calculator + (++) specify generating polynomial (peripheral default or non-default one) + (++) specify initialization value (peripheral default or non-default one) + (++) specify input data format + (++) specify input or output data inversion mode if any + (+) Use HAL_CRC_Accumulate() function to compute the CRC value of the + input data buffer starting with the previously computed CRC as + initialization value + (+) Use HAL_CRC_Calculate() function to compute the CRC value of the + input data buffer starting with the defined initialization value + (default or non-default) to initiate CRC calculation + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup CRC CRC + * @brief CRC HAL module driver. + * @{ + */ + +#ifdef HAL_CRC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup CRC_Private_Functions CRC Private Functions + * @{ + */ +static uint32_t CRC_Handle_8(CRC_HandleTypeDef *hcrc, uint8_t pBuffer[], uint32_t BufferLength); +static uint32_t CRC_Handle_16(CRC_HandleTypeDef *hcrc, uint16_t pBuffer[], uint32_t BufferLength); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup CRC_Exported_Functions CRC Exported Functions + * @{ + */ + +/** @defgroup CRC_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions. + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Initialize the CRC according to the specified parameters + in the CRC_InitTypeDef and create the associated handle + (+) DeInitialize the CRC peripheral + (+) Initialize the CRC MSP (MCU Specific Package) + (+) DeInitialize the CRC MSP + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the CRC according to the specified + * parameters in the CRC_InitTypeDef and create the associated handle. + * @param hcrc CRC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CRC_Init(CRC_HandleTypeDef *hcrc) +{ + /* Check the CRC handle allocation */ + if (hcrc == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_CRC_ALL_INSTANCE(hcrc->Instance)); + + if (hcrc->State == HAL_CRC_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hcrc->Lock = HAL_UNLOCKED; + /* Init the low level hardware */ + HAL_CRC_MspInit(hcrc); + } + + hcrc->State = HAL_CRC_STATE_BUSY; + +#if defined(CRC_POL_POL) + /* check whether or not non-default generating polynomial has been + * picked up by user */ + assert_param(IS_DEFAULT_POLYNOMIAL(hcrc->Init.DefaultPolynomialUse)); + if (hcrc->Init.DefaultPolynomialUse == DEFAULT_POLYNOMIAL_ENABLE) + { + /* initialize peripheral with default generating polynomial */ + WRITE_REG(hcrc->Instance->POL, DEFAULT_CRC32_POLY); + MODIFY_REG(hcrc->Instance->CR, CRC_CR_POLYSIZE, CRC_POLYLENGTH_32B); + } + else + { + /* initialize CRC peripheral with generating polynomial defined by user */ + if (HAL_CRCEx_Polynomial_Set(hcrc, hcrc->Init.GeneratingPolynomial, hcrc->Init.CRCLength) != HAL_OK) + { + return HAL_ERROR; + } + } +#endif /* CRC_POL_POL */ + + /* check whether or not non-default CRC initial value has been + * picked up by user */ + assert_param(IS_DEFAULT_INIT_VALUE(hcrc->Init.DefaultInitValueUse)); + if (hcrc->Init.DefaultInitValueUse == DEFAULT_INIT_VALUE_ENABLE) + { + WRITE_REG(hcrc->Instance->INIT, DEFAULT_CRC_INITVALUE); + } + else + { + WRITE_REG(hcrc->Instance->INIT, hcrc->Init.InitValue); + } + + + /* set input data inversion mode */ + assert_param(IS_CRC_INPUTDATA_INVERSION_MODE(hcrc->Init.InputDataInversionMode)); + MODIFY_REG(hcrc->Instance->CR, CRC_CR_REV_IN, hcrc->Init.InputDataInversionMode); + + /* set output data inversion mode */ + assert_param(IS_CRC_OUTPUTDATA_INVERSION_MODE(hcrc->Init.OutputDataInversionMode)); + MODIFY_REG(hcrc->Instance->CR, CRC_CR_REV_OUT, hcrc->Init.OutputDataInversionMode); + + /* makes sure the input data format (bytes, halfwords or words stream) + * is properly specified by user */ + assert_param(IS_CRC_INPUTDATA_FORMAT(hcrc->InputDataFormat)); + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief DeInitialize the CRC peripheral. + * @param hcrc CRC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CRC_DeInit(CRC_HandleTypeDef *hcrc) +{ + /* Check the CRC handle allocation */ + if (hcrc == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_CRC_ALL_INSTANCE(hcrc->Instance)); + + /* Check the CRC peripheral state */ + if (hcrc->State == HAL_CRC_STATE_BUSY) + { + return HAL_BUSY; + } + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_BUSY; + + /* Reset CRC calculation unit */ + __HAL_CRC_DR_RESET(hcrc); + + /* Reset IDR register content */ + CLEAR_BIT(hcrc->Instance->IDR, CRC_IDR_IDR); + + /* DeInit the low level hardware */ + HAL_CRC_MspDeInit(hcrc); + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_RESET; + + /* Process unlocked */ + __HAL_UNLOCK(hcrc); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Initializes the CRC MSP. + * @param hcrc CRC handle + * @retval None + */ +__weak void HAL_CRC_MspInit(CRC_HandleTypeDef *hcrc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcrc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_CRC_MspInit can be implemented in the user file + */ +} + +/** + * @brief DeInitialize the CRC MSP. + * @param hcrc CRC handle + * @retval None + */ +__weak void HAL_CRC_MspDeInit(CRC_HandleTypeDef *hcrc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hcrc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_CRC_MspDeInit can be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup CRC_Exported_Functions_Group2 Peripheral Control functions + * @brief management functions. + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) compute the 7, 8, 16 or 32-bit CRC value of an 8, 16 or 32-bit data buffer + using combination of the previous CRC value and the new one. + + [..] or + + (+) compute the 7, 8, 16 or 32-bit CRC value of an 8, 16 or 32-bit data buffer + independently of the previous CRC value. + +@endverbatim + * @{ + */ + +/** + * @brief Compute the 7, 8, 16 or 32-bit CRC value of an 8, 16 or 32-bit data buffer + * starting with the previously computed CRC as initialization value. + * @param hcrc CRC handle + * @param pBuffer pointer to the input data buffer, exact input data format is + * provided by hcrc->InputDataFormat. + * @param BufferLength input data buffer length (number of bytes if pBuffer + * type is * uint8_t, number of half-words if pBuffer type is * uint16_t, + * number of words if pBuffer type is * uint32_t). + * @note By default, the API expects a uint32_t pointer as input buffer parameter. + * Input buffer pointers with other types simply need to be cast in uint32_t + * and the API will internally adjust its input data processing based on the + * handle field hcrc->InputDataFormat. + * @retval uint32_t CRC (returned value LSBs for CRC shorter than 32 bits) + */ +uint32_t HAL_CRC_Accumulate(CRC_HandleTypeDef *hcrc, uint32_t pBuffer[], uint32_t BufferLength) +{ + uint32_t index; /* CRC input data buffer index */ + uint32_t temp = 0U; /* CRC output (read from hcrc->Instance->DR register) */ + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_BUSY; + + switch (hcrc->InputDataFormat) + { + case CRC_INPUTDATA_FORMAT_WORDS: + /* Enter Data to the CRC calculator */ + for (index = 0U; index < BufferLength; index++) + { + hcrc->Instance->DR = pBuffer[index]; + } + temp = hcrc->Instance->DR; + break; + + case CRC_INPUTDATA_FORMAT_BYTES: + temp = CRC_Handle_8(hcrc, (uint8_t *)pBuffer, BufferLength); + break; + + case CRC_INPUTDATA_FORMAT_HALFWORDS: + temp = CRC_Handle_16(hcrc, (uint16_t *)(void *)pBuffer, BufferLength); /* Derogation MisraC2012 R.11.5 */ + break; + default: + break; + } + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_READY; + + /* Return the CRC computed value */ + return temp; +} + +/** + * @brief Compute the 7, 8, 16 or 32-bit CRC value of an 8, 16 or 32-bit data buffer + * starting with hcrc->Instance->INIT as initialization value. + * @param hcrc CRC handle + * @param pBuffer pointer to the input data buffer, exact input data format is + * provided by hcrc->InputDataFormat. + * @param BufferLength input data buffer length (number of bytes if pBuffer + * type is * uint8_t, number of half-words if pBuffer type is * uint16_t, + * number of words if pBuffer type is * uint32_t). + * @note By default, the API expects a uint32_t pointer as input buffer parameter. + * Input buffer pointers with other types simply need to be cast in uint32_t + * and the API will internally adjust its input data processing based on the + * handle field hcrc->InputDataFormat. + * @retval uint32_t CRC (returned value LSBs for CRC shorter than 32 bits) + */ +uint32_t HAL_CRC_Calculate(CRC_HandleTypeDef *hcrc, uint32_t pBuffer[], uint32_t BufferLength) +{ + uint32_t index; /* CRC input data buffer index */ + uint32_t temp = 0U; /* CRC output (read from hcrc->Instance->DR register) */ + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_BUSY; + + /* Reset CRC Calculation Unit (hcrc->Instance->INIT is + * written in hcrc->Instance->DR) */ + __HAL_CRC_DR_RESET(hcrc); + + switch (hcrc->InputDataFormat) + { + case CRC_INPUTDATA_FORMAT_WORDS: + /* Enter 32-bit input data to the CRC calculator */ + for (index = 0U; index < BufferLength; index++) + { + hcrc->Instance->DR = pBuffer[index]; + } + temp = hcrc->Instance->DR; + break; + + case CRC_INPUTDATA_FORMAT_BYTES: + /* Specific 8-bit input data handling */ + temp = CRC_Handle_8(hcrc, (uint8_t *)pBuffer, BufferLength); + break; + + case CRC_INPUTDATA_FORMAT_HALFWORDS: + /* Specific 16-bit input data handling */ + temp = CRC_Handle_16(hcrc, (uint16_t *)(void *)pBuffer, BufferLength); /* Derogation MisraC2012 R.11.5 */ + break; + + default: + break; + } + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_READY; + + /* Return the CRC computed value */ + return temp; +} + +/** + * @} + */ + +/** @defgroup CRC_Exported_Functions_Group3 Peripheral State functions + * @brief Peripheral State functions. + * +@verbatim + =============================================================================== + ##### Peripheral State functions ##### + =============================================================================== + [..] + This subsection permits to get in run-time the status of the peripheral. + +@endverbatim + * @{ + */ + +/** + * @brief Return the CRC handle state. + * @param hcrc CRC handle + * @retval HAL state + */ +HAL_CRC_StateTypeDef HAL_CRC_GetState(CRC_HandleTypeDef *hcrc) +{ + /* Return CRC handle state */ + return hcrc->State; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup CRC_Private_Functions + * @{ + */ + +/** + * @brief Enter 8-bit input data to the CRC calculator. + * Specific data handling to optimize processing time. + * @param hcrc CRC handle + * @param pBuffer pointer to the input data buffer + * @param BufferLength input data buffer length + * @retval uint32_t CRC (returned value LSBs for CRC shorter than 32 bits) + */ +static uint32_t CRC_Handle_8(CRC_HandleTypeDef *hcrc, uint8_t pBuffer[], uint32_t BufferLength) +{ + uint32_t i; /* input data buffer index */ + uint16_t data; + __IO uint16_t *pReg; + + /* Processing time optimization: 4 bytes are entered in a row with a single word write, + * last bytes must be carefully fed to the CRC calculator to ensure a correct type + * handling by the peripheral */ + for (i = 0U; i < (BufferLength / 4U); i++) + { + hcrc->Instance->DR = ((uint32_t)pBuffer[4U * i] << 24U) | \ + ((uint32_t)pBuffer[(4U * i) + 1U] << 16U) | \ + ((uint32_t)pBuffer[(4U * i) + 2U] << 8U) | \ + (uint32_t)pBuffer[(4U * i) + 3U]; + } + /* last bytes specific handling */ + if ((BufferLength % 4U) != 0U) + { + if ((BufferLength % 4U) == 1U) + { + *(__IO uint8_t *)(__IO void *)(&hcrc->Instance->DR) = pBuffer[4U * i]; /* Derogation MisraC2012 R.11.5 */ + } + if ((BufferLength % 4U) == 2U) + { + data = ((uint16_t)(pBuffer[4U * i]) << 8U) | (uint16_t)pBuffer[(4U * i) + 1U]; + pReg = (__IO uint16_t *)(__IO void *)(&hcrc->Instance->DR); /* Derogation MisraC2012 R.11.5 */ + *pReg = data; + } + if ((BufferLength % 4U) == 3U) + { + data = ((uint16_t)(pBuffer[4U * i]) << 8U) | (uint16_t)pBuffer[(4U * i) + 1U]; + pReg = (__IO uint16_t *)(__IO void *)(&hcrc->Instance->DR); /* Derogation MisraC2012 R.11.5 */ + *pReg = data; + + *(__IO uint8_t *)(__IO void *)(&hcrc->Instance->DR) = pBuffer[(4U * i) + 2U]; /* Derogation MisraC2012 R.11.5 */ + } + } + + /* Return the CRC computed value */ + return hcrc->Instance->DR; +} + +/** + * @brief Enter 16-bit input data to the CRC calculator. + * Specific data handling to optimize processing time. + * @param hcrc CRC handle + * @param pBuffer pointer to the input data buffer + * @param BufferLength input data buffer length + * @retval uint32_t CRC (returned value LSBs for CRC shorter than 32 bits) + */ +static uint32_t CRC_Handle_16(CRC_HandleTypeDef *hcrc, uint16_t pBuffer[], uint32_t BufferLength) +{ + uint32_t i; /* input data buffer index */ + __IO uint16_t *pReg; + + /* Processing time optimization: 2 HalfWords are entered in a row with a single word write, + * in case of odd length, last HalfWord must be carefully fed to the CRC calculator to ensure + * a correct type handling by the peripheral */ + for (i = 0U; i < (BufferLength / 2U); i++) + { + hcrc->Instance->DR = ((uint32_t)pBuffer[2U * i] << 16U) | (uint32_t)pBuffer[(2U * i) + 1U]; + } + if ((BufferLength % 2U) != 0U) + { + pReg = (__IO uint16_t *)(__IO void *)(&hcrc->Instance->DR); /* Derogation MisraC2012 R.11.5 */ + *pReg = pBuffer[2U * i]; + } + + /* Return the CRC computed value */ + return hcrc->Instance->DR; +} + +/** + * @} + */ + +#endif /* HAL_CRC_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc_ex.c new file mode 100644 index 0000000..ad8253f --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_crc_ex.c @@ -0,0 +1,227 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_crc_ex.c + * @author MCD Application Team + * @brief Extended CRC HAL module driver. + * This file provides firmware functions to manage the extended + * functionalities of the CRC peripheral. + * + @verbatim +================================================================================ + ##### How to use this driver ##### +================================================================================ + [..] + (+) Set user-defined generating polynomial through HAL_CRCEx_Polynomial_Set() + (+) Configure Input or Output data inversion + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup CRCEx CRCEx + * @brief CRC Extended HAL module driver + * @{ + */ + +#ifdef HAL_CRC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup CRCEx_Exported_Functions CRC Extended Exported Functions + * @{ + */ + +/** @defgroup CRCEx_Exported_Functions_Group1 Extended Initialization/de-initialization functions + * @brief Extended Initialization and Configuration functions. + * +@verbatim + =============================================================================== + ##### Extended configuration functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Configure the generating polynomial + (+) Configure the input data inversion + (+) Configure the output data inversion + +@endverbatim + * @{ + */ + + +#if defined(CRC_POL_POL) +/** + * @brief Initialize the CRC polynomial if different from default one. + * @param hcrc CRC handle + * @param Pol CRC generating polynomial (7, 8, 16 or 32-bit long). + * This parameter is written in normal representation, e.g. + * @arg for a polynomial of degree 7, X^7 + X^6 + X^5 + X^2 + 1 is written 0x65 + * @arg for a polynomial of degree 16, X^16 + X^12 + X^5 + 1 is written 0x1021 + * @param PolyLength CRC polynomial length. + * This parameter can be one of the following values: + * @arg @ref CRC_POLYLENGTH_7B 7-bit long CRC (generating polynomial of degree 7) + * @arg @ref CRC_POLYLENGTH_8B 8-bit long CRC (generating polynomial of degree 8) + * @arg @ref CRC_POLYLENGTH_16B 16-bit long CRC (generating polynomial of degree 16) + * @arg @ref CRC_POLYLENGTH_32B 32-bit long CRC (generating polynomial of degree 32) + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CRCEx_Polynomial_Set(CRC_HandleTypeDef *hcrc, uint32_t Pol, uint32_t PolyLength) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t msb = 31U; /* polynomial degree is 32 at most, so msb is initialized to max value */ + + /* Check the parameters */ + assert_param(IS_CRC_POL_LENGTH(PolyLength)); + + /* check polynomial definition vs polynomial size: + * polynomial length must be aligned with polynomial + * definition. HAL_ERROR is reported if Pol degree is + * larger than that indicated by PolyLength. + * Look for MSB position: msb will contain the degree of + * the second to the largest polynomial member. E.g., for + * X^7 + X^6 + X^5 + X^2 + 1, msb = 6. */ + while ((msb-- > 0U) && ((Pol & ((uint32_t)(0x1U) << (msb & 0x1FU))) == 0U)) + { + } + + switch (PolyLength) + { + case CRC_POLYLENGTH_7B: + if (msb >= HAL_CRC_LENGTH_7B) + { + status = HAL_ERROR; + } + break; + case CRC_POLYLENGTH_8B: + if (msb >= HAL_CRC_LENGTH_8B) + { + status = HAL_ERROR; + } + break; + case CRC_POLYLENGTH_16B: + if (msb >= HAL_CRC_LENGTH_16B) + { + status = HAL_ERROR; + } + break; + + case CRC_POLYLENGTH_32B: + /* no polynomial definition vs. polynomial length issue possible */ + break; + default: + status = HAL_ERROR; + break; + } + if (status == HAL_OK) + { + /* set generating polynomial */ + WRITE_REG(hcrc->Instance->POL, Pol); + + /* set generating polynomial size */ + MODIFY_REG(hcrc->Instance->CR, CRC_CR_POLYSIZE, PolyLength); + } + /* Return function status */ + return status; +} +#endif /* CRC_POL_POL */ + +/** + * @brief Set the Reverse Input data mode. + * @param hcrc CRC handle + * @param InputReverseMode Input Data inversion mode. + * This parameter can be one of the following values: + * @arg @ref CRC_INPUTDATA_INVERSION_NONE no change in bit order (default value) + * @arg @ref CRC_INPUTDATA_INVERSION_BYTE Byte-wise bit reversal + * @arg @ref CRC_INPUTDATA_INVERSION_HALFWORD HalfWord-wise bit reversal + * @arg @ref CRC_INPUTDATA_INVERSION_WORD Word-wise bit reversal + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CRCEx_Input_Data_Reverse(CRC_HandleTypeDef *hcrc, uint32_t InputReverseMode) +{ + /* Check the parameters */ + assert_param(IS_CRC_INPUTDATA_INVERSION_MODE(InputReverseMode)); + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_BUSY; + + /* set input data inversion mode */ + MODIFY_REG(hcrc->Instance->CR, CRC_CR_REV_IN, InputReverseMode); + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Set the Reverse Output data mode. + * @param hcrc CRC handle + * @param OutputReverseMode Output Data inversion mode. + * This parameter can be one of the following values: + * @arg @ref CRC_OUTPUTDATA_INVERSION_DISABLE no CRC inversion (default value) + * @arg @ref CRC_OUTPUTDATA_INVERSION_ENABLE bit-level inversion (e.g. for a 8-bit CRC: 0xB5 becomes 0xAD) + * @retval HAL status + */ +HAL_StatusTypeDef HAL_CRCEx_Output_Data_Reverse(CRC_HandleTypeDef *hcrc, uint32_t OutputReverseMode) +{ + /* Check the parameters */ + assert_param(IS_CRC_OUTPUTDATA_INVERSION_MODE(OutputReverseMode)); + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_BUSY; + + /* set output data inversion mode */ + MODIFY_REG(hcrc->Instance->CR, CRC_CR_REV_OUT, OutputReverseMode); + + /* Change CRC peripheral state */ + hcrc->State = HAL_CRC_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + + + + +/** + * @} + */ + + +/** + * @} + */ + + +#endif /* HAL_CRC_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac.c new file mode 100644 index 0000000..92ae933 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac.c @@ -0,0 +1,1090 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_dac.c + * @author MCD Application Team + * @brief DAC HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Digital to Analog Converter (DAC) peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral Control functions + * + Peripheral State and Errors functions + * + * + @verbatim + ============================================================================== + ##### DAC Peripheral features ##### + ============================================================================== + [..] + *** DAC Channels *** + ==================== + [..] + STM32F0 devices integrates no, one or two 12-bit Digital Analog Converters. + STM32F05x devices have one converter (channel1) + STM32F07x & STM32F09x devices have two converters (i.e. channel1 & channel2) + + When 2 converters are present (i.e. channel1 & channel2) they + can be used independently or simultaneously (dual mode): + (#) DAC channel1 with DAC_OUT1 (PA4) as output + (#) DAC channel2 with DAC_OUT2 (PA5) as output + + *** DAC Triggers *** + ==================== + [..] + Digital to Analog conversion can be non-triggered using DAC_TRIGGER_NONE + and DAC_OUT1/DAC_OUT2 is available once writing to DHRx register. + [..] + Digital to Analog conversion can be triggered by: + (#) External event: EXTI Line 9 (any GPIOx_PIN_9) using DAC_TRIGGER_EXT_IT9. + The used pin (GPIOx_PIN_9) must be configured in input mode. + + (#) Timers TRGO: TIM2, TIM3, TIM6, and TIM15 + (DAC_TRIGGER_T2_TRGO, DAC_TRIGGER_T3_TRGO...) + + (#) Software using DAC_TRIGGER_SOFTWARE + + *** DAC Buffer mode feature *** + =============================== + [..] + Each DAC channel integrates an output buffer that can be used to + reduce the output impedance, and to drive external loads directly + without having to add an external operational amplifier. + To enable, the output buffer use + sConfig.DAC_OutputBuffer = DAC_OUTPUTBUFFER_ENABLE; + [..] + (@) Refer to the device datasheet for more details about output + impedance value with and without output buffer. + + *** GPIO configurations guidelines *** + ===================== + [..] + When a DAC channel is used (ex channel1 on PA4) and the other is not + (ex channel1 on PA5 is configured in Analog and disabled). + Channel1 may disturb channel2 as coupling effect. + Note that there is no coupling on channel2 as soon as channel2 is turned on. + Coupling on adjacent channel could be avoided as follows: + when unused PA5 is configured as INPUT PULL-UP or DOWN. + PA5 is configured in ANALOG just before it is turned on. + + *** DAC wave generation feature *** + =================================== + [..] + Both DAC channels can be used to generate + (#) Noise wave + (#) Triangle wave + + *** DAC data format *** + ======================= + [..] + The DAC data format can be: + (#) 8-bit right alignment using DAC_ALIGN_8B_R + (#) 12-bit left alignment using DAC_ALIGN_12B_L + (#) 12-bit right alignment using DAC_ALIGN_12B_R + + *** DAC data value to voltage correspondance *** + ================================================ + [..] + The analog output voltage on each DAC channel pin is determined + by the following equation: + [..] + DAC_OUTx = VREF+ * DOR / 4095 + (+) with DOR is the Data Output Register + [..] + VEF+ is the input voltage reference (refer to the device datasheet) + [..] + e.g. To set DAC_OUT1 to 0.7V, use + (+) Assuming that VREF+ = 3.3V, DAC_OUT1 = (3.3 * 868) / 4095 = 0.7V + + *** DMA requests *** + ===================== + [..] + A DMA1 request can be generated when an external trigger (but not + a software trigger) occurs if DMA1 requests are enabled using + HAL_DAC_Start_DMA() + [..] + DMA1 requests are mapped as following: + (#) DAC channel1 : mapped on DMA1 channel3 which must be + already configured + (#) DAC channel2 : mapped on DMA1 channel4 which must be + already configured + + (@) For Dual mode and specific signal (Triangle and noise) generation please + refer to Extended Features Driver description + STM32F0 devices with one channel (one converting capability) does not + support Dual mode and specific signal (Triangle and noise) generation. + + ##### How to use this driver ##### + ============================================================================== + [..] + (+) DAC APB clock must be enabled to get write access to DAC + registers using HAL_DAC_Init() + (+) Configure DAC_OUTx (DAC_OUT1: PA4, DAC_OUT2: PA5) in analog mode. + (+) Configure the DAC channel using HAL_DAC_ConfigChannel() function. + (+) Enable the DAC channel using HAL_DAC_Start() or HAL_DAC_Start_DMA() functions. + + *** Polling mode IO operation *** + ================================= + [..] + (+) Start the DAC peripheral using HAL_DAC_Start() + (+) To read the DAC last data output value, use the HAL_DAC_GetValue() function. + (+) Stop the DAC peripheral using HAL_DAC_Stop() + + *** DMA mode IO operation *** + ============================== + [..] + (+) Start the DAC peripheral using HAL_DAC_Start_DMA(), at this stage the user specify the length + of data to be transferred at each end of conversion + (+) At the middle of data transfer HAL_DAC_ConvHalfCpltCallbackCh1() or HAL_DACEx_ConvHalfCpltCallbackCh2() + function is executed and user can add his own code by customization of function pointer + HAL_DAC_ConvHalfCpltCallbackCh1() or HAL_DACEx_ConvHalfCpltCallbackCh2() + (+) At The end of data transfer HAL_DAC_ConvCpltCallbackCh1() or HAL_DACEx_ConvHalfCpltCallbackCh2() + function is executed and user can add his own code by customization of function pointer + HAL_DAC_ConvCpltCallbackCh1() or HAL_DACEx_ConvHalfCpltCallbackCh2() + (+) In case of transfer Error, HAL_DAC_ErrorCallbackCh1() function is executed and user can + add his own code by customization of function pointer HAL_DAC_ErrorCallbackCh1 + (+) In case of DMA underrun, DAC interruption triggers and execute internal function HAL_DAC_IRQHandler. + HAL_DAC_DMAUnderrunCallbackCh1() or HAL_DACEx_DMAUnderrunCallbackCh2() + function is executed and user can add his own code by customization of function pointer + HAL_DAC_DMAUnderrunCallbackCh1() or HAL_DACEx_DMAUnderrunCallbackCh2() and + add his own code by customization of function pointer HAL_DAC_ErrorCallbackCh1() + (+) Stop the DAC peripheral using HAL_DAC_Stop_DMA() + + *** Callback registration *** + ============================================= + [..] + The compilation define USE_HAL_DAC_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + + Use Functions HAL_DAC_RegisterCallback() to register a user callback, + it allows to register following callbacks: + (+) ConvCpltCallbackCh1 : callback when a half transfer is completed on Ch1. + (+) ConvHalfCpltCallbackCh1 : callback when a transfer is completed on Ch1. + (+) ErrorCallbackCh1 : callback when an error occurs on Ch1. + (+) DMAUnderrunCallbackCh1 : callback when an error occurs on Ch1. + (+) ConvCpltCallbackCh2 : callback when a half transfer is completed on Ch2. + (+) ConvHalfCpltCallbackCh2 : callback when a transfer is completed on Ch2. + (+) ErrorCallbackCh2 : callback when an error occurs on Ch2. + (+) DMAUnderrunCallbackCh2 : callback when an error occurs on Ch2. + (+) MspInitCallback : DAC MspInit. + (+) MspDeInitCallback : DAC MspdeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + Use function HAL_DAC_UnRegisterCallback() to reset a callback to the default + weak (surcharged) function. It allows to reset following callbacks: + (+) ConvCpltCallbackCh1 : callback when a half transfer is completed on Ch1. + (+) ConvHalfCpltCallbackCh1 : callback when a transfer is completed on Ch1. + (+) ErrorCallbackCh1 : callback when an error occurs on Ch1. + (+) DMAUnderrunCallbackCh1 : callback when an error occurs on Ch1. + (+) ConvCpltCallbackCh2 : callback when a half transfer is completed on Ch2. + (+) ConvHalfCpltCallbackCh2 : callback when a transfer is completed on Ch2. + (+) ErrorCallbackCh2 : callback when an error occurs on Ch2. + (+) DMAUnderrunCallbackCh2 : callback when an error occurs on Ch2. + (+) MspInitCallback : DAC MspInit. + (+) MspDeInitCallback : DAC MspdeInit. + (+) All Callbacks + This function) takes as parameters the HAL peripheral handle and the Callback ID. + + By default, after the HAL_DAC_Init and if the state is HAL_DAC_STATE_RESET + all callbacks are reset to the corresponding legacy weak (surcharged) functions. + Exception done for MspInit and MspDeInit callbacks that are respectively + reset to the legacy weak (surcharged) functions in the HAL_DAC_Init + and HAL_DAC_DeInit only when these callbacks are null (not registered beforehand). + If not, MspInit or MspDeInit are not null, the HAL_DAC_Init and HAL_DAC_DeInit + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) + + Callbacks can be registered/unregistered in READY state only. + Exception done for MspInit/MspDeInit callbacks that can be registered/unregistered + in READY or RESET state, thus registered (user) MspInit/DeInit callbacks can be used + during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_DAC_RegisterCallback before calling HAL_DAC_DeInit + or HAL_DAC_Init function. + + When The compilation define USE_HAL_DAC_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registering feature is not available + and weak (surcharged) callbacks are used. + + *** DAC HAL driver macros list *** + ============================================= + [..] + Below the list of most used macros in DAC HAL driver. + + (+) __HAL_DAC_ENABLE : Enable the DAC peripheral + (+) __HAL_DAC_DISABLE : Disable the DAC peripheral + (+) __HAL_DAC_CLEAR_FLAG: Clear the DAC's pending flags + (+) __HAL_DAC_GET_FLAG: Get the selected DAC's flag status + + [..] + (@) You can refer to the DAC HAL driver header file for more useful macros + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#ifdef HAL_DAC_MODULE_ENABLED + +#if defined (DAC1) + +/** @defgroup DAC DAC + * @brief DAC driver modules + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/** @defgroup DAC_Private_Macros DAC Private Macros + * @{ + */ +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup DAC_Private_Functions DAC Private Functions + * @{ + */ +/** + * @} + */ + +/* Exported functions -------------------------------------------------------*/ + +/** @defgroup DAC_Exported_Functions DAC Exported Functions + * @{ + */ + +/** @defgroup DAC_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + ============================================================================== + ##### Initialization and de-initialization functions ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) Initialize and configure the DAC. + (+) De-initialize the DAC. + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the DAC peripheral according to the specified parameters + * in the DAC_InitStruct and initialize the associated handle. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_Init(DAC_HandleTypeDef* hdac) +{ + /* Check DAC handle */ + if(hdac == NULL) + { + return HAL_ERROR; + } + /* Check the parameters */ + assert_param(IS_DAC_ALL_INSTANCE(hdac->Instance)); + + if (hdac->State == HAL_DAC_STATE_RESET) + { +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) + /* Init the DAC Callback settings */ + hdac->ConvCpltCallbackCh1 = HAL_DAC_ConvCpltCallbackCh1; + hdac->ConvHalfCpltCallbackCh1 = HAL_DAC_ConvHalfCpltCallbackCh1; + hdac->ErrorCallbackCh1 = HAL_DAC_ErrorCallbackCh1; + hdac->DMAUnderrunCallbackCh1 = HAL_DAC_DMAUnderrunCallbackCh1; + + hdac->ConvCpltCallbackCh2 = HAL_DACEx_ConvCpltCallbackCh2; + hdac->ConvHalfCpltCallbackCh2 = HAL_DACEx_ConvHalfCpltCallbackCh2; + hdac->ErrorCallbackCh2 = HAL_DACEx_ErrorCallbackCh2; + hdac->DMAUnderrunCallbackCh2 = HAL_DACEx_DMAUnderrunCallbackCh2; + + if (hdac->MspInitCallback == NULL) + { + hdac->MspInitCallback = HAL_DAC_MspInit; + } +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + + /* Allocate lock resource and initialize it */ + hdac->Lock = HAL_UNLOCKED; + +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) + /* Init the low level hardware */ + hdac->MspInitCallback(hdac); +#else + /* Init the low level hardware */ + HAL_DAC_MspInit(hdac); +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + } + + /* Initialize the DAC state*/ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Set DAC error code to none */ + hdac->ErrorCode = HAL_DAC_ERROR_NONE; + + /* Initialize the DAC state*/ + hdac->State = HAL_DAC_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Deinitialize the DAC peripheral registers to their default reset values. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_DeInit(DAC_HandleTypeDef* hdac) +{ + /* Check DAC handle */ + if(hdac == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_DAC_ALL_INSTANCE(hdac->Instance)); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) + if(hdac->MspDeInitCallback == NULL) + { + hdac->MspDeInitCallback = HAL_DAC_MspDeInit; + } + /* DeInit the low level hardware */ + hdac->MspDeInitCallback(hdac); + +#else + /* DeInit the low level hardware */ + HAL_DAC_MspDeInit(hdac); +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + + /* Set DAC error code to none */ + hdac->ErrorCode = HAL_DAC_ERROR_NONE; + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Initialize the DAC MSP. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DAC_MspInit(DAC_HandleTypeDef* hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_DAC_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitialize the DAC MSP. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DAC_MspDeInit(DAC_HandleTypeDef* hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_DAC_MspDeInit could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup DAC_Exported_Functions_Group2 IO operation functions + * @brief IO operation functions + * +@verbatim + ============================================================================== + ##### IO operation functions ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) Start conversion. + (+) Stop conversion. + (+) Start conversion and enable DMA transfer. + (+) Stop conversion and disable DMA transfer. + (+) Set the specified data holding register value for DAC channel. + +@endverbatim + * @{ + */ + +/** + * @brief Enables DAC and starts conversion of channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval HAL status + */ +__weak HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + UNUSED(Channel); + + /* Note : This function is defined into this file for library reference. */ + /* Function content is located into file stm32f0xx_hal_dac_ex.c */ + + /* Return error status as not implemented here */ + return HAL_ERROR; +} + +/** + * @brief Disables DAC and stop conversion of channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_Stop(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Disable the Peripheral */ + __HAL_DAC_DISABLE(hdac, Channel); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Enables DAC and starts conversion of channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @param pData The destination peripheral Buffer address. + * @param Length The length of data to be transferred from memory to DAC peripheral + * @param Alignment Specifies the data alignment for DAC channel. + * This parameter can be one of the following values: + * @arg DAC_ALIGN_8B_R: 8bit right data alignment selected + * @arg DAC_ALIGN_12B_L: 12bit left data alignment selected + * @arg DAC_ALIGN_12B_R: 12bit right data alignment selected + * @retval HAL status + */ +__weak HAL_StatusTypeDef HAL_DAC_Start_DMA(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t* pData, uint32_t Length, uint32_t Alignment) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + UNUSED(Channel); + UNUSED(pData); + UNUSED(Length); + UNUSED(Alignment); + + /* Note : This function is defined into this file for library reference. */ + /* Function content is located into file stm32f0xx_hal_dac_ex.c */ + + /* Return error status as not implemented here */ + return HAL_ERROR; +} + +/** + * @brief Disables DAC and stop conversion of channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_Stop_DMA(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Disable the selected DAC channel DMA request */ + hdac->Instance->CR &= ~(DAC_CR_DMAEN1 << Channel); + + /* Disable the Peripheral */ + __HAL_DAC_DISABLE(hdac, Channel); + + /* Disable the DMA channel */ + /* Channel1 is used */ + if (Channel == DAC_CHANNEL_1) + { + /* Disable the DMA channel */ + status = HAL_DMA_Abort(hdac->DMA_Handle1); + + /* Disable the DAC DMA underrun interrupt */ + __HAL_DAC_DISABLE_IT(hdac, DAC_IT_DMAUDR1); + } + +#if defined(DAC_CHANNEL2_SUPPORT) + + else /* Channel2 is used */ + { + /* Disable the DMA channel */ + status = HAL_DMA_Abort(hdac->DMA_Handle2); + + /* Disable the DAC DMA underrun interrupt */ + __HAL_DAC_DISABLE_IT(hdac, DAC_IT_DMAUDR2); + } +#endif /* DAC_CHANNEL2_SUPPORT */ + + /* Check if DMA Channel effectively disabled */ + if (status != HAL_OK) + { + /* Update DAC state machine to error */ + hdac->State = HAL_DAC_STATE_ERROR; + } + else + { + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_READY; + } + + /* Return function status */ + return status; +} + +/** + * @brief Handles DAC interrupt request + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DAC_IRQHandler(DAC_HandleTypeDef* hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* Note : This function is defined into this file for library reference. */ + /* Function content is located into file stm32f0xx_hal_dac_ex.c */ +} + +/** + * @brief Set the specified data holding register value for DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @param Alignment Specifies the data alignment. + * This parameter can be one of the following values: + * @arg DAC_ALIGN_8B_R: 8bit right data alignment selected + * @arg DAC_ALIGN_12B_L: 12bit left data alignment selected + * @arg DAC_ALIGN_12B_R: 12bit right data alignment selected + * @param Data Data to be loaded in the selected data holding register. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_SetValue(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t Alignment, uint32_t Data) +{ + __IO uint32_t tmp = 0; + + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + assert_param(IS_DAC_ALIGN(Alignment)); + assert_param(IS_DAC_DATA(Data)); + + tmp = (uint32_t)hdac->Instance; + if(Channel == DAC_CHANNEL_1) + { + tmp += DAC_DHR12R1_ALIGNMENT(Alignment); + } + else + { + tmp += DAC_DHR12R2_ALIGNMENT(Alignment); + } + + /* Set the DAC channel1 selected data holding register */ + *(__IO uint32_t *) tmp = Data; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Conversion complete callback in non blocking mode for Channel1 + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DAC_ConvCpltCallbackCh1(DAC_HandleTypeDef* hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_DAC_ConvCpltCallbackCh1 could be implemented in the user file + */ +} + +/** + * @brief Conversion half DMA transfer callback in non-blocking mode for Channel1 + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DAC_ConvHalfCpltCallbackCh1(DAC_HandleTypeDef* hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_DAC_ConvHalfCpltCallbackCh1 could be implemented in the user file + */ +} + +/** + * @brief Error DAC callback for Channel1. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DAC_ErrorCallbackCh1(DAC_HandleTypeDef *hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_DAC_ErrorCallbackCh1 could be implemented in the user file + */ +} + +/** + * @brief DMA underrun DAC callback for channel1. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DAC_DMAUnderrunCallbackCh1(DAC_HandleTypeDef *hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_DAC_DMAUnderrunCallbackCh1 could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup DAC_Exported_Functions_Group3 Peripheral Control functions + * @brief Peripheral Control functions + * +@verbatim + ============================================================================== + ##### Peripheral Control functions ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) Configure channels. + (+) Get result of conversion. + +@endverbatim + * @{ + */ + +/** + * @brief Returns the last data output value of the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval The selected DAC channel data output value. + */ +__weak uint32_t HAL_DAC_GetValue(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + UNUSED(Channel); + + /* Note : This function is defined into this file for library reference. */ + /* Function content is located into file stm32f0xx_hal_dac_ex.c */ + + /* Return error status as not implemented here */ + return HAL_ERROR; +} + +/** + * @brief Configures the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param sConfig DAC configuration structure. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval HAL status + */ +__weak HAL_StatusTypeDef HAL_DAC_ConfigChannel(DAC_HandleTypeDef* hdac, DAC_ChannelConfTypeDef* sConfig, uint32_t Channel) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + UNUSED(sConfig); + UNUSED(Channel); + + /* Note : This function is defined into this file for library reference. */ + /* Function content is located into file stm32f0xx_hal_dac_ex.c */ + + /* Return error status as not implemented here */ + return HAL_ERROR; +} + +/** + * @} + */ + +/** @defgroup DAC_Exported_Functions_Group4 Peripheral State and Errors functions + * @brief Peripheral State and Errors functions + * +@verbatim + ============================================================================== + ##### Peripheral State and Errors functions ##### + ============================================================================== + [..] + This subsection provides functions allowing to + (+) Check the DAC state. + (+) Check the DAC Errors. + +@endverbatim + * @{ + */ + +/** + * @brief return the DAC handle state + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval HAL state + */ +HAL_DAC_StateTypeDef HAL_DAC_GetState(DAC_HandleTypeDef* hdac) +{ + /* Return DAC handle state */ + return hdac->State; +} + + +/** + * @brief Return the DAC error code + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval DAC Error Code + */ +uint32_t HAL_DAC_GetError(DAC_HandleTypeDef *hdac) +{ + return hdac->ErrorCode; +} + +/** + * @} + */ + + +/** + * @} + */ + +/** @addtogroup DAC_Exported_Functions + * @{ + */ + +/** @addtogroup DAC_Exported_Functions_Group1 + * @{ + */ +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User DAC Callback + * To be used instead of the weak (surcharged) predefined callback + * @param hdac DAC handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_DAC_ERROR_INVALID_CALLBACK DAC Error Callback ID + * @arg @ref HAL_DAC_CH1_COMPLETE_CB_ID DAC CH1 Complete Callback ID + * @arg @ref HAL_DAC_CH1_HALF_COMPLETE_CB_ID DAC CH1 Half Complete Callback ID + * @arg @ref HAL_DAC_CH1_ERROR_ID DAC CH1 Error Callback ID + * @arg @ref HAL_DAC_CH1_UNDERRUN_CB_ID DAC CH1 UnderRun Callback ID + * @arg @ref HAL_DAC_CH2_COMPLETE_CB_ID DAC CH2 Complete Callback ID + * @arg @ref HAL_DAC_CH2_HALF_COMPLETE_CB_ID DAC CH2 Half Complete Callback ID + * @arg @ref HAL_DAC_CH2_ERROR_ID DAC CH2 Error Callback ID + * @arg @ref HAL_DAC_CH2_UNDERRUN_CB_ID DAC CH2 UnderRun Callback ID + * @arg @ref HAL_DAC_MSPINIT_CB_ID DAC MSP Init Callback ID + * @arg @ref HAL_DAC_MSPDEINIT_CB_ID DAC MSP DeInit Callback ID + * + * @param pCallback pointer to the Callback function + * @retval status + */ +HAL_StatusTypeDef HAL_DAC_RegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID, + pDAC_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hdac->ErrorCode |= HAL_DAC_ERROR_INVALID_CALLBACK; + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hdac); + + if (hdac->State == HAL_DAC_STATE_READY) + { + switch (CallbackID) + { + case HAL_DAC_CH1_COMPLETE_CB_ID : + hdac->ConvCpltCallbackCh1 = pCallback; + break; + case HAL_DAC_CH1_HALF_COMPLETE_CB_ID : + hdac->ConvHalfCpltCallbackCh1 = pCallback; + break; + case HAL_DAC_CH1_ERROR_ID : + hdac->ErrorCallbackCh1 = pCallback; + break; + case HAL_DAC_CH1_UNDERRUN_CB_ID : + hdac->DMAUnderrunCallbackCh1 = pCallback; + break; + case HAL_DAC_CH2_COMPLETE_CB_ID : + hdac->ConvCpltCallbackCh2 = pCallback; + break; + case HAL_DAC_CH2_HALF_COMPLETE_CB_ID : + hdac->ConvHalfCpltCallbackCh2 = pCallback; + break; + case HAL_DAC_CH2_ERROR_ID : + hdac->ErrorCallbackCh2 = pCallback; + break; + case HAL_DAC_CH2_UNDERRUN_CB_ID : + hdac->DMAUnderrunCallbackCh2 = pCallback; + break; + case HAL_DAC_MSPINIT_CB_ID : + hdac->MspInitCallback = pCallback; + break; + case HAL_DAC_MSPDEINIT_CB_ID : + hdac->MspDeInitCallback = pCallback; + break; + default : + /* Update the error code */ + hdac->ErrorCode |= HAL_DAC_ERROR_INVALID_CALLBACK; + /* update return status */ + status = HAL_ERROR; + break; + } + } + else if (hdac->State == HAL_DAC_STATE_RESET) + { + switch (CallbackID) + { + case HAL_DAC_MSPINIT_CB_ID : + hdac->MspInitCallback = pCallback; + break; + case HAL_DAC_MSPDEINIT_CB_ID : + hdac->MspDeInitCallback = pCallback; + break; + default : + /* Update the error code */ + hdac->ErrorCode |= HAL_DAC_ERROR_INVALID_CALLBACK; + /* update return status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hdac->ErrorCode |= HAL_DAC_ERROR_INVALID_CALLBACK; + /* update return status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hdac); + return status; +} + +/** + * @brief Unregister a User DAC Callback + * DAC Callback is redirected to the weak (surcharged) predefined callback + * @param hdac DAC handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_DAC_CH1_COMPLETE_CB_ID DAC CH1 tranfer Complete Callback ID + * @arg @ref HAL_DAC_CH1_HALF_COMPLETE_CB_ID DAC CH1 Half Complete Callback ID + * @arg @ref HAL_DAC_CH1_ERROR_ID DAC CH1 Error Callback ID + * @arg @ref HAL_DAC_CH1_UNDERRUN_CB_ID DAC CH1 UnderRun Callback ID + * @arg @ref HAL_DAC_CH2_COMPLETE_CB_ID DAC CH2 Complete Callback ID + * @arg @ref HAL_DAC_CH2_HALF_COMPLETE_CB_ID DAC CH2 Half Complete Callback ID + * @arg @ref HAL_DAC_CH2_ERROR_ID DAC CH2 Error Callback ID + * @arg @ref HAL_DAC_CH2_UNDERRUN_CB_ID DAC CH2 UnderRun Callback ID + * @arg @ref HAL_DAC_MSPINIT_CB_ID DAC MSP Init Callback ID + * @arg @ref HAL_DAC_MSPDEINIT_CB_ID DAC MSP DeInit Callback ID + * @arg @ref HAL_DAC_ALL_CB_ID DAC All callbacks + * @retval status + */ +HAL_StatusTypeDef HAL_DAC_UnRegisterCallback(DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hdac); + + if (hdac->State == HAL_DAC_STATE_READY) + { + switch (CallbackID) + { + case HAL_DAC_CH1_COMPLETE_CB_ID : + hdac->ConvCpltCallbackCh1 = HAL_DAC_ConvCpltCallbackCh1; + break; + case HAL_DAC_CH1_HALF_COMPLETE_CB_ID : + hdac->ConvHalfCpltCallbackCh1 = HAL_DAC_ConvHalfCpltCallbackCh1; + break; + case HAL_DAC_CH1_ERROR_ID : + hdac->ErrorCallbackCh1 = HAL_DAC_ErrorCallbackCh1; + break; + case HAL_DAC_CH1_UNDERRUN_CB_ID : + hdac->DMAUnderrunCallbackCh1 = HAL_DAC_DMAUnderrunCallbackCh1; + break; + case HAL_DAC_CH2_COMPLETE_CB_ID : + hdac->ConvCpltCallbackCh2 = HAL_DACEx_ConvCpltCallbackCh2; + break; + case HAL_DAC_CH2_HALF_COMPLETE_CB_ID : + hdac->ConvHalfCpltCallbackCh2 = HAL_DACEx_ConvHalfCpltCallbackCh2; + break; + case HAL_DAC_CH2_ERROR_ID : + hdac->ErrorCallbackCh2 = HAL_DACEx_ErrorCallbackCh2; + break; + case HAL_DAC_CH2_UNDERRUN_CB_ID : + hdac->DMAUnderrunCallbackCh2 = HAL_DACEx_DMAUnderrunCallbackCh2; + break; + case HAL_DAC_MSPINIT_CB_ID : + hdac->MspInitCallback = HAL_DAC_MspInit; + break; + case HAL_DAC_MSPDEINIT_CB_ID : + hdac->MspDeInitCallback = HAL_DAC_MspDeInit; + break; + case HAL_DAC_ALL_CB_ID : + hdac->ConvCpltCallbackCh1 = HAL_DAC_ConvCpltCallbackCh1; + hdac->ConvHalfCpltCallbackCh1 = HAL_DAC_ConvHalfCpltCallbackCh1; + hdac->ErrorCallbackCh1 = HAL_DAC_ErrorCallbackCh1; + hdac->DMAUnderrunCallbackCh1 = HAL_DAC_DMAUnderrunCallbackCh1; + hdac->ConvCpltCallbackCh2 = HAL_DACEx_ConvCpltCallbackCh2; + hdac->ConvHalfCpltCallbackCh2 = HAL_DACEx_ConvHalfCpltCallbackCh2; + hdac->ErrorCallbackCh2 = HAL_DACEx_ErrorCallbackCh2; + hdac->DMAUnderrunCallbackCh2 = HAL_DACEx_DMAUnderrunCallbackCh2; + hdac->MspInitCallback = HAL_DAC_MspInit; + hdac->MspDeInitCallback = HAL_DAC_MspDeInit; + break; + default : + /* Update the error code */ + hdac->ErrorCode |= HAL_DAC_ERROR_INVALID_CALLBACK; + /* update return status */ + status = HAL_ERROR; + break; + } + } + else if (hdac->State == HAL_DAC_STATE_RESET) + { + switch (CallbackID) + { + case HAL_DAC_MSPINIT_CB_ID : + hdac->MspInitCallback = HAL_DAC_MspInit; + break; + case HAL_DAC_MSPDEINIT_CB_ID : + hdac->MspDeInitCallback = HAL_DAC_MspDeInit; + break; + default : + /* Update the error code */ + hdac->ErrorCode |= HAL_DAC_ERROR_INVALID_CALLBACK; + /* update return status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hdac->ErrorCode |= HAL_DAC_ERROR_INVALID_CALLBACK; + /* update return status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hdac); + return status; +} +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + +/** + * @} + */ + + +/** + * @} + */ + + +/** + * @} + */ +#endif /* DAC1 */ + +#endif /* HAL_DAC_MODULE_ENABLED */ + +/** + * @} + */ + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac_ex.c new file mode 100644 index 0000000..feac2b8 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dac_ex.c @@ -0,0 +1,1183 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_dac_ex.c + * @author MCD Application Team + * @brief DAC HAL module driver. + * This file provides firmware functions to manage the extended + * functionalities of the DAC peripheral. + * + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + (+) When Dual mode is enabled (i.e. DAC Channel1 and Channel2 are used simultaneously) : + Use HAL_DACEx_DualGetValue() to get digital data to be converted and use + HAL_DACEx_DualSetValue() to set digital value to converted simultaneously in Channel 1 and Channel 2. + (+) Use HAL_DACEx_TriangleWaveGenerate() to generate Triangle signal. + (+) Use HAL_DACEx_NoiseWaveGenerate() to generate Noise signal. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#ifdef HAL_DAC_MODULE_ENABLED + +/** @addtogroup DAC + * @{ + */ + +#if defined(STM32F051x8) || defined(STM32F058xx) || \ + defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** @addtogroup DAC_Private_Functions + * @{ + */ +static void DAC_DMAConvCpltCh1(DMA_HandleTypeDef *hdma); +static void DAC_DMAErrorCh1(DMA_HandleTypeDef *hdma); +static void DAC_DMAHalfConvCpltCh1(DMA_HandleTypeDef *hdma); +/** + * @} + */ + +#endif /* STM32F051x8 STM32F058xx */ + /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** @addtogroup DAC_Private_Functions + * @{ + */ + +/* DAC_DMAConvCpltCh2 / DAC_DMAErrorCh2 / DAC_DMAHalfConvCpltCh2 */ +/* are set by HAL_DAC_Start_DMA */ + +void DAC_DMAConvCpltCh2(DMA_HandleTypeDef *hdma); +void DAC_DMAErrorCh2(DMA_HandleTypeDef *hdma); +void DAC_DMAHalfConvCpltCh2(DMA_HandleTypeDef *hdma); +/** + * @} + */ + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +/** @addtogroup DAC_Exported_Functions + * @{ + */ + +/** @addtogroup DAC_Exported_Functions_Group3 + * @{ + */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** + * @brief Configures the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param sConfig DAC configuration structure. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_ConfigChannel(DAC_HandleTypeDef* hdac, DAC_ChannelConfTypeDef* sConfig, uint32_t Channel) +{ + uint32_t tmpreg1 = 0U, tmpreg2 = 0U; + + /* Check the DAC parameters */ + assert_param(IS_DAC_TRIGGER(sConfig->DAC_Trigger)); + assert_param(IS_DAC_OUTPUT_BUFFER_STATE(sConfig->DAC_OutputBuffer)); + assert_param(IS_DAC_TRIGGER(sConfig->DAC_Trigger)); + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Get the DAC CR value */ + tmpreg1 = hdac->Instance->CR; + /* Clear BOFFx, TENx, TSELx, WAVEx and MAMPx bits */ + tmpreg1 &= ~(((uint32_t)(DAC_CR_MAMP1 | DAC_CR_WAVE1 | DAC_CR_TSEL1 | DAC_CR_TEN1 | DAC_CR_BOFF1)) << Channel); + /* Configure for the selected DAC channel: buffer output, trigger */ + /* Set TSELx and TENx bits according to DAC_Trigger value */ + /* Set BOFFx bit according to DAC_OutputBuffer value */ + tmpreg2 = (sConfig->DAC_Trigger | sConfig->DAC_OutputBuffer); + /* Calculate CR register value depending on DAC_Channel */ + tmpreg1 |= tmpreg2 << Channel; + /* Write to DAC CR */ + hdac->Instance->CR = tmpreg1; + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined (STM32F051x8) || defined (STM32F058xx) + +/** + * @brief Configures the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param sConfig DAC configuration structure. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_ConfigChannel(DAC_HandleTypeDef* hdac, DAC_ChannelConfTypeDef* sConfig, uint32_t Channel) +{ + uint32_t tmpreg1 = 0U, tmpreg2 = 0U; + + /* Check the DAC parameters */ + assert_param(IS_DAC_TRIGGER(sConfig->DAC_Trigger)); + assert_param(IS_DAC_OUTPUT_BUFFER_STATE(sConfig->DAC_OutputBuffer)); + assert_param(IS_DAC_TRIGGER(sConfig->DAC_Trigger)); + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Get the DAC CR value */ + tmpreg1 = hdac->Instance->CR; + /* Clear BOFFx, TENx, TSELx, WAVEx and MAMPx bits */ + tmpreg1 &= ~(((uint32_t)(DAC_CR_TSEL1 | DAC_CR_TEN1 | DAC_CR_BOFF1)) << Channel); + /* Configure for the selected DAC channel: buffer output, trigger */ + /* Set TSELx and TENx bits according to DAC_Trigger value */ + /* Set BOFFx bit according to DAC_OutputBuffer value */ + tmpreg2 = (sConfig->DAC_Trigger | sConfig->DAC_OutputBuffer); + /* Calculate CR register value depending on DAC_Channel */ + tmpreg1 |= tmpreg2 << Channel; + /* Write to DAC CR */ + hdac->Instance->CR = tmpreg1; + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +#endif /* STM32F051x8 STM32F058xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) +/* DAC 1 has 2 channels 1 & 2 */ + +/** + * @brief Returns the last data output value of the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval The selected DAC channel data output value. + */ +uint32_t HAL_DAC_GetValue(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Returns the DAC channel data output register value */ + if(Channel == DAC_CHANNEL_1) + { + return hdac->Instance->DOR1; + } + else + { + return hdac->Instance->DOR2; + } +} + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined (STM32F051x8) || defined (STM32F058xx) + +/* DAC 1 has 1 channels */ + +/** + * @brief Returns the last data output value of the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @retval The selected DAC channel data output value. + */ +uint32_t HAL_DAC_GetValue(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Returns the DAC channel data output register value */ + return hdac->Instance->DOR1; +} + + + +#endif /* STM32F051x8 STM32F058xx */ + +/** + * @} + */ + +/** @addtogroup DAC_Exported_Functions_Group2 + * @{ + */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** + * @brief Enables DAC and starts conversion of channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Enable the Peripharal */ + __HAL_DAC_ENABLE(hdac, Channel); + + if(Channel == DAC_CHANNEL_1) + { + /* Check if software trigger enabled */ + if((hdac->Instance->CR & (DAC_CR_TEN1 | DAC_CR_TSEL1)) == (DAC_CR_TEN1 | DAC_CR_TSEL1)) + { + /* Enable the selected DAC software conversion */ + SET_BIT(hdac->Instance->SWTRIGR, DAC_SWTRIGR_SWTRIG1); + } + } + else + { + /* Check if software trigger enabled */ + if((hdac->Instance->CR & (DAC_CR_TEN2 | DAC_CR_TSEL2)) == (DAC_CR_TEN2 | DAC_CR_TSEL2)) + { + /* Enable the selected DAC software conversion*/ + SET_BIT(hdac->Instance->SWTRIGR, DAC_SWTRIGR_SWTRIG2); + } + } + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Enables DAC and starts conversion of channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @arg DAC_CHANNEL_2: DAC Channel2 selected + * @param pData The destination peripheral Buffer address. + * @param Length The length of data to be transferred from memory to DAC peripheral + * @param Alignment Specifies the data alignment for DAC channel. + * This parameter can be one of the following values: + * @arg DAC_ALIGN_8B_R: 8bit right data alignment selected + * @arg DAC_ALIGN_12B_L: 12bit left data alignment selected + * @arg DAC_ALIGN_12B_R: 12bit right data alignment selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_Start_DMA(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t* pData, uint32_t Length, uint32_t Alignment) +{ + uint32_t tmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + assert_param(IS_DAC_ALIGN(Alignment)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + if(Channel == DAC_CHANNEL_1) + { + /* Set the DMA transfer complete callback for channel1 */ + hdac->DMA_Handle1->XferCpltCallback = DAC_DMAConvCpltCh1; + + /* Set the DMA half transfer complete callback for channel1 */ + hdac->DMA_Handle1->XferHalfCpltCallback = DAC_DMAHalfConvCpltCh1; + + /* Set the DMA error callback for channel1 */ + hdac->DMA_Handle1->XferErrorCallback = DAC_DMAErrorCh1; + + /* Enable the selected DAC channel1 DMA request */ + SET_BIT(hdac->Instance->CR, DAC_CR_DMAEN1); + + /* Case of use of channel 1 */ + switch(Alignment) + { + case DAC_ALIGN_12B_R: + /* Get DHR12R1 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR12R1; + break; + case DAC_ALIGN_12B_L: + /* Get DHR12L1 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR12L1; + break; + case DAC_ALIGN_8B_R: + /* Get DHR8R1 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR8R1; + break; + default: + break; + } + } + else + { + /* Set the DMA transfer complete callback for channel2 */ + hdac->DMA_Handle2->XferCpltCallback = DAC_DMAConvCpltCh2; + + /* Set the DMA half transfer complete callback for channel2 */ + hdac->DMA_Handle2->XferHalfCpltCallback = DAC_DMAHalfConvCpltCh2; + + /* Set the DMA error callback for channel2 */ + hdac->DMA_Handle2->XferErrorCallback = DAC_DMAErrorCh2; + + /* Enable the selected DAC channel2 DMA request */ + SET_BIT(hdac->Instance->CR, DAC_CR_DMAEN2); + + /* Case of use of channel 2 */ + switch(Alignment) + { + case DAC_ALIGN_12B_R: + /* Get DHR12R2 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR12R2; + break; + case DAC_ALIGN_12B_L: + /* Get DHR12L2 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR12L2; + break; + case DAC_ALIGN_8B_R: + /* Get DHR8R2 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR8R2; + break; + default: + break; + } + } + + /* Enable the DMA channel */ + if(Channel == DAC_CHANNEL_1) + { + /* Enable the DAC DMA underrun interrupt */ + __HAL_DAC_ENABLE_IT(hdac, DAC_IT_DMAUDR1); + + /* Enable the DMA channel */ + HAL_DMA_Start_IT(hdac->DMA_Handle1, (uint32_t)pData, tmpreg, Length); + } + else + { + /* Enable the DAC DMA underrun interrupt */ + __HAL_DAC_ENABLE_IT(hdac, DAC_IT_DMAUDR2); + + /* Enable the DMA channel */ + HAL_DMA_Start_IT(hdac->DMA_Handle2, (uint32_t)pData, tmpreg, Length); + } + + /* Enable the Peripharal */ + __HAL_DAC_ENABLE(hdac, Channel); + + /* Process Unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + + + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined (STM32F051x8) || defined (STM32F058xx) + +HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef* hdac, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Enable the Peripharal */ + __HAL_DAC_ENABLE(hdac, Channel); + + if(Channel == DAC_CHANNEL_1) + { + /* Check if software trigger enabled */ + if((hdac->Instance->CR & (DAC_CR_TEN1 | DAC_CR_TSEL1)) == (DAC_CR_TEN1 | DAC_CR_TSEL1)) + { + /* Enable the selected DAC software conversion */ + SET_BIT(hdac->Instance->SWTRIGR, DAC_SWTRIGR_SWTRIG1); + } + } + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Enables DAC and starts conversion of channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * @arg DAC_CHANNEL_1: DAC Channel1 selected + * @param pData The destination peripheral Buffer address. + * @param Length The length of data to be transferred from memory to DAC peripheral + * @param Alignment Specifies the data alignment for DAC channel. + * This parameter can be one of the following values: + * @arg DAC_ALIGN_8B_R: 8bit right data alignment selected + * @arg DAC_ALIGN_12B_L: 12bit left data alignment selected + * @arg DAC_ALIGN_12B_R: 12bit right data alignment selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DAC_Start_DMA(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t* pData, uint32_t Length, uint32_t Alignment) +{ + uint32_t tmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + assert_param(IS_DAC_ALIGN(Alignment)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Set the DMA transfer complete callback for channel1 */ + hdac->DMA_Handle1->XferCpltCallback = DAC_DMAConvCpltCh1; + + /* Set the DMA half transfer complete callback for channel1 */ + hdac->DMA_Handle1->XferHalfCpltCallback = DAC_DMAHalfConvCpltCh1; + + /* Set the DMA error callback for channel1 */ + hdac->DMA_Handle1->XferErrorCallback = DAC_DMAErrorCh1; + + /* Enable the selected DAC channel1 DMA request */ + SET_BIT(hdac->Instance->CR, DAC_CR_DMAEN1); + + /* Case of use of channel 1 */ + switch(Alignment) + { + case DAC_ALIGN_12B_R: + /* Get DHR12R1 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR12R1; + break; + case DAC_ALIGN_12B_L: + /* Get DHR12L1 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR12L1; + break; + case DAC_ALIGN_8B_R: + /* Get DHR8R1 address */ + tmpreg = (uint32_t)&hdac->Instance->DHR8R1; + break; + default: + break; + } + + /* Enable the DMA channel */ + /* Enable the DAC DMA underrun interrupt */ + __HAL_DAC_ENABLE_IT(hdac, DAC_IT_DMAUDR1); + + /* Enable the DMA channel */ + HAL_DMA_Start_IT(hdac->DMA_Handle1, (uint32_t)pData, tmpreg, Length); + + /* Enable the DAC DMA underrun interrupt */ + __HAL_DAC_ENABLE_IT(hdac, DAC_IT_DMAUDR1); + + /* Enable the DMA channel */ + HAL_DMA_Start_IT(hdac->DMA_Handle1, (uint32_t)pData, tmpreg, Length); + + /* Enable the Peripharal */ + __HAL_DAC_ENABLE(hdac, Channel); + + /* Process Unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +#endif /* STM32F051x8 STM32F058xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) +/* DAC channel 2 is available on top of DAC channel 1 */ + +/** + * @brief Handles DAC interrupt request + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +void HAL_DAC_IRQHandler(DAC_HandleTypeDef* hdac) +{ + if(__HAL_DAC_GET_IT_SOURCE(hdac, DAC_IT_DMAUDR1)) + { + /* Check underrun channel 1 flag */ + if(__HAL_DAC_GET_FLAG(hdac, DAC_FLAG_DMAUDR1)) + { + /* Change DAC state to error state */ + hdac->State = HAL_DAC_STATE_ERROR; + + /* Set DAC error code to channel1 DMA underrun error */ + hdac->ErrorCode |= HAL_DAC_ERROR_DMAUNDERRUNCH1; + + /* Clear the underrun flag */ + __HAL_DAC_CLEAR_FLAG(hdac,DAC_FLAG_DMAUDR1); + + /* Disable the selected DAC channel1 DMA request */ + hdac->Instance->CR &= ~DAC_CR_DMAEN1; + + /* Error callback */ + HAL_DAC_DMAUnderrunCallbackCh1(hdac); + } + } + if(__HAL_DAC_GET_IT_SOURCE(hdac, DAC_IT_DMAUDR2)) + { + /* Check underrun channel 2 flag */ + if(__HAL_DAC_GET_FLAG(hdac, DAC_FLAG_DMAUDR2)) + { + /* Change DAC state to error state */ + hdac->State = HAL_DAC_STATE_ERROR; + + /* Set DAC error code to channel2 DMA underrun error */ + hdac->ErrorCode |= HAL_DAC_ERROR_DMAUNDERRUNCH2; + + /* Clear the underrun flag */ + __HAL_DAC_CLEAR_FLAG(hdac,DAC_FLAG_DMAUDR2); + + /* Disable the selected DAC channel1 DMA request */ + hdac->Instance->CR &= ~DAC_CR_DMAEN2; + + /* Error callback */ + HAL_DACEx_DMAUnderrunCallbackCh2(hdac); + } + } +} + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined (STM32F051x8) || defined (STM32F058xx) +/* DAC channel 2 is NOT available. Only DAC channel 1 is available */ + +/** + * @brief Handles DAC interrupt request + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +void HAL_DAC_IRQHandler(DAC_HandleTypeDef* hdac) +{ + if(__HAL_DAC_GET_IT_SOURCE(hdac, DAC_IT_DMAUDR1)) + { + /* Check Overrun flag */ + if(__HAL_DAC_GET_FLAG(hdac, DAC_FLAG_DMAUDR1)) + { + /* Change DAC state to error state */ + hdac->State = HAL_DAC_STATE_ERROR; + + /* Set DAC error code to chanel1 DMA underrun error */ + hdac->ErrorCode |= HAL_DAC_ERROR_DMAUNDERRUNCH1; + + /* Clear the underrun flag */ + __HAL_DAC_CLEAR_FLAG(hdac,DAC_FLAG_DMAUDR1); + + /* Disable the selected DAC channel1 DMA request */ + hdac->Instance->CR &= ~DAC_CR_DMAEN1; + + /* Error callback */ + HAL_DAC_DMAUnderrunCallbackCh1(hdac); + } + } +} + +#endif /* STM32F051x8 STM32F058xx */ + +/** + * @} + */ + +/** + * @} + */ + +#if defined(STM32F051x8) || defined(STM32F058xx) || \ + defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** @addtogroup DAC_Private_Functions + * @{ + */ + +/** + * @brief DMA conversion complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void DAC_DMAConvCpltCh1(DMA_HandleTypeDef *hdma) +{ + DAC_HandleTypeDef* hdac = ( DAC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + + HAL_DAC_ConvCpltCallbackCh1(hdac); + + hdac->State= HAL_DAC_STATE_READY; +} + +/** + * @brief DMA half transfer complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void DAC_DMAHalfConvCpltCh1(DMA_HandleTypeDef *hdma) +{ + DAC_HandleTypeDef* hdac = ( DAC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + /* Conversion complete callback */ + HAL_DAC_ConvHalfCpltCallbackCh1(hdac); +} + +/** + * @brief DMA error callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void DAC_DMAErrorCh1(DMA_HandleTypeDef *hdma) +{ + DAC_HandleTypeDef* hdac = ( DAC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + + /* Set DAC error code to DMA error */ + hdac->ErrorCode |= HAL_DAC_ERROR_DMA; + + HAL_DAC_ErrorCallbackCh1(hdac); + + hdac->State= HAL_DAC_STATE_READY; +} +/** + * @} + */ +#endif /* STM32F051x8 STM32F058xx */ + /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** @addtogroup DAC_Private_Functions + * @{ + */ + +/** + * @brief DMA conversion complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +void DAC_DMAConvCpltCh2(DMA_HandleTypeDef *hdma) +{ + DAC_HandleTypeDef* hdac = ( DAC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) + hdac->ConvCpltCallbackCh2(hdac); +#else + HAL_DACEx_ConvCpltCallbackCh2(hdac); +#endif + + hdac->State= HAL_DAC_STATE_READY; +} + +/** + * @brief DMA half transfer complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +void DAC_DMAHalfConvCpltCh2(DMA_HandleTypeDef *hdma) +{ + DAC_HandleTypeDef* hdac = ( DAC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + + /* Conversion complete callback */ +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) + hdac->ConvHalfCpltCallbackCh2(hdac); +#else + HAL_DACEx_ConvHalfCpltCallbackCh2(hdac); +#endif +} + +/** + * @brief DMA error callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +void DAC_DMAErrorCh2(DMA_HandleTypeDef *hdma) +{ + DAC_HandleTypeDef* hdac = ( DAC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent; + + /* Set DAC error code to DMA error */ + hdac->ErrorCode |= HAL_DAC_ERROR_DMA; + +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) + hdac->ErrorCallbackCh2(hdac); +#else + HAL_DACEx_ErrorCallbackCh2(hdac); +#endif + hdac->State= HAL_DAC_STATE_READY; +} + +/** + * @} + */ + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +/** + * @} + */ + +/** @defgroup DACEx DACEx + * @brief DACEx driver module + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/** @defgroup DACEx_Private_Macros DACEx Private Macros + * @{ + */ +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + +/** @defgroup DACEx_Exported_Functions DACEx Exported Functions + * @{ + */ + +/** @defgroup DACEx_Exported_Functions_Group1 Extended features functions + * @brief Extended features functions + * +@verbatim + ============================================================================== + ##### Extended features functions ##### + ============================================================================== + [..] This section provides functions allowing to: + (+) Start conversion. + (+) Stop conversion. + (+) Start conversion and enable DMA transfer. + (+) Stop conversion and disable DMA transfer. + (+) Get result of conversion. + (+) Get result of dual mode conversion. + +@endverbatim + * @{ + */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** + * @brief Returns the last data output value of the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval The selected DAC channel data output value. + */ +uint32_t HAL_DACEx_DualGetValue(DAC_HandleTypeDef* hdac) +{ + uint32_t tmp = 0U; + + tmp |= hdac->Instance->DOR1; + + /* DAC channel 2 is present in DAC 1 */ + tmp |= hdac->Instance->DOR2 << 16U; + + /* Returns the DAC channel data output register value */ + return tmp; +} + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined (STM32F051x8) || defined (STM32F058xx) + +/** + * @brief Returns the last data output value of the selected DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval The selected DAC channel data output value. + */ +uint32_t HAL_DACEx_DualGetValue(DAC_HandleTypeDef* hdac) +{ + uint32_t tmp = 0U; + + tmp |= hdac->Instance->DOR1; + + /* Returns the DAC channel data output register value */ + return tmp; +} + +#endif /* STM32F051x8 STM32F058xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** + * @brief Enables or disables the selected DAC channel wave generation. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * DAC_CHANNEL_1 / DAC_CHANNEL_2 + * @param Amplitude Select max triangle amplitude. + * This parameter can be one of the following values: + * @arg DAC_TRIANGLEAMPLITUDE_1: Select max triangle amplitude of 1 + * @arg DAC_TRIANGLEAMPLITUDE_3: Select max triangle amplitude of 3 + * @arg DAC_TRIANGLEAMPLITUDE_7: Select max triangle amplitude of 7 + * @arg DAC_TRIANGLEAMPLITUDE_15: Select max triangle amplitude of 15 + * @arg DAC_TRIANGLEAMPLITUDE_31: Select max triangle amplitude of 31 + * @arg DAC_TRIANGLEAMPLITUDE_63: Select max triangle amplitude of 63 + * @arg DAC_TRIANGLEAMPLITUDE_127: Select max triangle amplitude of 127 + * @arg DAC_TRIANGLEAMPLITUDE_255: Select max triangle amplitude of 255 + * @arg DAC_TRIANGLEAMPLITUDE_511: Select max triangle amplitude of 511 + * @arg DAC_TRIANGLEAMPLITUDE_1023: Select max triangle amplitude of 1023 + * @arg DAC_TRIANGLEAMPLITUDE_2047: Select max triangle amplitude of 2047 + * @arg DAC_TRIANGLEAMPLITUDE_4095: Select max triangle amplitude of 4095 + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DACEx_TriangleWaveGenerate(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t Amplitude) +{ + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + assert_param(IS_DAC_LFSR_UNMASK_TRIANGLE_AMPLITUDE(Amplitude)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Enable the selected wave generation for the selected DAC channel */ + MODIFY_REG(hdac->Instance->CR, ((DAC_CR_WAVE1)|(DAC_CR_MAMP1))<State = HAL_DAC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Enables or disables the selected DAC channel wave generation. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Channel The selected DAC channel. + * This parameter can be one of the following values: + * DAC_CHANNEL_1 / DAC_CHANNEL_2 + * @param Amplitude Unmask DAC channel LFSR for noise wave generation. + * This parameter can be one of the following values: + * @arg DAC_LFSRUNMASK_BIT0: Unmask DAC channel LFSR bit0 for noise wave generation + * @arg DAC_LFSRUNMASK_BITS1_0: Unmask DAC channel LFSR bit[1:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS2_0: Unmask DAC channel LFSR bit[2:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS3_0: Unmask DAC channel LFSR bit[3:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS4_0: Unmask DAC channel LFSR bit[4:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS5_0: Unmask DAC channel LFSR bit[5:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS6_0: Unmask DAC channel LFSR bit[6:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS7_0: Unmask DAC channel LFSR bit[7:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS8_0: Unmask DAC channel LFSR bit[8:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS9_0: Unmask DAC channel LFSR bit[9:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS10_0: Unmask DAC channel LFSR bit[10:0] for noise wave generation + * @arg DAC_LFSRUNMASK_BITS11_0: Unmask DAC channel LFSR bit[11:0] for noise wave generation + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DACEx_NoiseWaveGenerate(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t Amplitude) +{ + /* Check the parameters */ + assert_param(IS_DAC_CHANNEL(Channel)); + assert_param(IS_DAC_LFSR_UNMASK_TRIANGLE_AMPLITUDE(Amplitude)); + + /* Process locked */ + __HAL_LOCK(hdac); + + /* Change DAC state */ + hdac->State = HAL_DAC_STATE_BUSY; + + /* Enable the selected wave generation for the selected DAC channel */ + MODIFY_REG(hdac->Instance->CR, ((DAC_CR_WAVE1)|(DAC_CR_MAMP1))<State = HAL_DAC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(hdac); + + /* Return function status */ + return HAL_OK; +} + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +/** + * @} + */ + +/** + * @} + */ + +#if defined(STM32F051x8) || defined(STM32F058xx) || \ + defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** @addtogroup DACEx_Exported_Functions + * @{ + */ + +/** @addtogroup DACEx_Exported_Functions_Group1 + * @brief Extended features functions + * @{ + */ + +/** + * @brief Set the specified data holding register value for dual DAC channel. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @param Alignment Specifies the data alignment for dual channel DAC. + * This parameter can be one of the following values: + * DAC_ALIGN_8B_R: 8bit right data alignment selected + * DAC_ALIGN_12B_L: 12bit left data alignment selected + * DAC_ALIGN_12B_R: 12bit right data alignment selected + * @param Data1 Data for DAC Channel2 to be loaded in the selected data holding register. + * @param Data2 Data for DAC Channel1 to be loaded in the selected data holding register. + * @note In dual mode, a unique register access is required to write in both + * DAC channels at the same time. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DACEx_DualSetValue(DAC_HandleTypeDef* hdac, uint32_t Alignment, uint32_t Data1, uint32_t Data2) +{ + uint32_t data = 0U, tmp = 0U; + + /* Check the parameters */ + assert_param(IS_DAC_ALIGN(Alignment)); + assert_param(IS_DAC_DATA(Data1)); + assert_param(IS_DAC_DATA(Data2)); + + /* Calculate and set dual DAC data holding register value */ + if (Alignment == DAC_ALIGN_8B_R) + { + data = ((uint32_t)Data2 << 8U) | Data1; + } + else + { + data = ((uint32_t)Data2 << 16U) | Data1; + } + + tmp = (uint32_t)hdac->Instance; + tmp += DAC_DHR12RD_ALIGNMENT(Alignment); + + /* Set the dual DAC selected data holding register */ + *(__IO uint32_t *)tmp = data; + + /* Return function status */ + return HAL_OK; +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* STM32F051x8 STM32F058xx */ + /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/** @addtogroup DACEx_Exported_Functions + * @{ + */ + +/** @addtogroup DACEx_Exported_Functions_Group1 + * @brief Extended features functions + * @{ + */ + +/** + * @brief Conversion complete callback in non blocking mode for Channel2 + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DACEx_ConvCpltCallbackCh2(DAC_HandleTypeDef* hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_DAC_ConvCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Conversion half DMA transfer callback in non blocking mode for Channel2 + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DACEx_ConvHalfCpltCallbackCh2(DAC_HandleTypeDef* hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_DAC_ConvHalfCpltCallbackCh2 could be implemented in the user file + */ +} + +/** + * @brief Error DAC callback for Channel2. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DACEx_ErrorCallbackCh2(DAC_HandleTypeDef *hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_DAC_ErrorCallback could be implemented in the user file + */ +} + +/** + * @brief DMA underrun DAC callback for channel2. + * @param hdac pointer to a DAC_HandleTypeDef structure that contains + * the configuration information for the specified DAC. + * @retval None + */ +__weak void HAL_DACEx_DMAUnderrunCallbackCh2(DAC_HandleTypeDef *hdac) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hdac); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_DAC_DMAUnderrunCallbackCh2 could be implemented in the user file + */ +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* STM32F071xB STM32F072xB STM32F078xx */ + /* STM32F091xC STM32F098xx */ + +/** + * @} + */ + +#endif /* HAL_DAC_MODULE_ENABLED */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dma.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dma.c new file mode 100644 index 0000000..b7f91a4 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_dma.c @@ -0,0 +1,901 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_dma.c + * @author MCD Application Team + * @brief DMA HAL module driver. + * + * This file provides firmware functions to manage the following + * functionalities of the Direct Memory Access (DMA) peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral State and errors functions + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + (#) Enable and configure the peripheral to be connected to the DMA Channel + (except for internal SRAM / FLASH memories: no initialization is + necessary). Please refer to Reference manual for connection between peripherals + and DMA requests . + + (#) For a given Channel, program the required configuration through the following parameters: + Transfer Direction, Source and Destination data formats, + Circular or Normal mode, Channel Priority level, Source and Destination Increment mode, + using HAL_DMA_Init() function. + + (#) Use HAL_DMA_GetState() function to return the DMA state and HAL_DMA_GetError() in case of error + detection. + + (#) Use HAL_DMA_Abort() function to abort the current transfer + + -@- In Memory-to-Memory transfer mode, Circular mode is not allowed. + *** Polling mode IO operation *** + ================================= + [..] + (+) Use HAL_DMA_Start() to start DMA transfer after the configuration of Source + address and destination address and the Length of data to be transferred + (+) Use HAL_DMA_PollForTransfer() to poll for the end of current transfer, in this + case a fixed Timeout can be configured by User depending from his application. + + *** Interrupt mode IO operation *** + =================================== + [..] + (+) Configure the DMA interrupt priority using HAL_NVIC_SetPriority() + (+) Enable the DMA IRQ handler using HAL_NVIC_EnableIRQ() + (+) Use HAL_DMA_Start_IT() to start DMA transfer after the configuration of + Source address and destination address and the Length of data to be transferred. + In this case the DMA interrupt is configured + (+) Use HAL_DMA_Channel_IRQHandler() called under DMA_IRQHandler() Interrupt subroutine + (+) At the end of data transfer HAL_DMA_IRQHandler() function is executed and user can + add his own function by customization of function pointer XferCpltCallback and + XferErrorCallback (i.e a member of DMA handle structure). + + *** DMA HAL driver macros list *** + ============================================= + [..] + Below the list of most used macros in DMA HAL driver. + + [..] + (@) You can refer to the DMA HAL driver header file for more useful macros + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + + +/** @defgroup DMA DMA + * @brief DMA HAL module driver + * @{ + */ + +#ifdef HAL_DMA_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup DMA_Private_Functions DMA Private Functions + * @{ + */ +static void DMA_SetConfig(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength); +static void DMA_CalcBaseAndBitshift(DMA_HandleTypeDef *hdma); +/** + * @} + */ + +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup DMA_Exported_Functions DMA Exported Functions + * @{ + */ + +/** @defgroup DMA_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and de-initialization functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] + This section provides functions allowing to initialize the DMA Channel source + and destination addresses, incrementation and data sizes, transfer direction, + circular/normal mode selection, memory-to-memory mode selection and Channel priority value. + [..] + The HAL_DMA_Init() function follows the DMA configuration procedures as described in + reference manual. + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the DMA according to the specified + * parameters in the DMA_InitTypeDef and initialize the associated handle. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_Init(DMA_HandleTypeDef *hdma) +{ + uint32_t tmp = 0U; + + /* Check the DMA handle allocation */ + if(NULL == hdma) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_DMA_ALL_INSTANCE(hdma->Instance)); + assert_param(IS_DMA_DIRECTION(hdma->Init.Direction)); + assert_param(IS_DMA_PERIPHERAL_INC_STATE(hdma->Init.PeriphInc)); + assert_param(IS_DMA_MEMORY_INC_STATE(hdma->Init.MemInc)); + assert_param(IS_DMA_PERIPHERAL_DATA_SIZE(hdma->Init.PeriphDataAlignment)); + assert_param(IS_DMA_MEMORY_DATA_SIZE(hdma->Init.MemDataAlignment)); + assert_param(IS_DMA_MODE(hdma->Init.Mode)); + assert_param(IS_DMA_PRIORITY(hdma->Init.Priority)); + + /* Change DMA peripheral state */ + hdma->State = HAL_DMA_STATE_BUSY; + + /* Get the CR register value */ + tmp = hdma->Instance->CCR; + + /* Clear PL, MSIZE, PSIZE, MINC, PINC, CIRC, DIR bits */ + tmp &= ((uint32_t)~(DMA_CCR_PL | DMA_CCR_MSIZE | DMA_CCR_PSIZE | \ + DMA_CCR_MINC | DMA_CCR_PINC | DMA_CCR_CIRC | \ + DMA_CCR_DIR)); + + /* Prepare the DMA Channel configuration */ + tmp |= hdma->Init.Direction | + hdma->Init.PeriphInc | hdma->Init.MemInc | + hdma->Init.PeriphDataAlignment | hdma->Init.MemDataAlignment | + hdma->Init.Mode | hdma->Init.Priority; + + /* Write to DMA Channel CR register */ + hdma->Instance->CCR = tmp; + + /* Initialize DmaBaseAddress and ChannelIndex parameters used + by HAL_DMA_IRQHandler() and HAL_DMA_PollForTransfer() */ + DMA_CalcBaseAndBitshift(hdma); + + /* Initialise the error code */ + hdma->ErrorCode = HAL_DMA_ERROR_NONE; + + /* Initialize the DMA state*/ + hdma->State = HAL_DMA_STATE_READY; + + /* Allocate lock resource and initialize it */ + hdma->Lock = HAL_UNLOCKED; + + return HAL_OK; +} + +/** + * @brief DeInitialize the DMA peripheral + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_DeInit(DMA_HandleTypeDef *hdma) +{ + /* Check the DMA handle allocation */ + if(NULL == hdma) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_DMA_ALL_INSTANCE(hdma->Instance)); + + /* Disable the selected DMA Channelx */ + hdma->Instance->CCR &= ~DMA_CCR_EN; + + /* Reset DMA Channel control register */ + hdma->Instance->CCR = 0U; + + /* Reset DMA Channel Number of Data to Transfer register */ + hdma->Instance->CNDTR = 0U; + + /* Reset DMA Channel peripheral address register */ + hdma->Instance->CPAR = 0U; + + /* Reset DMA Channel memory address register */ + hdma->Instance->CMAR = 0U; + +/* Get DMA Base Address */ + DMA_CalcBaseAndBitshift(hdma); + + /* Clear all flags */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_GL1 << hdma->ChannelIndex; + + /* Clean callbacks */ + hdma->XferCpltCallback = NULL; + hdma->XferHalfCpltCallback = NULL; + hdma->XferErrorCallback = NULL; + hdma->XferAbortCallback = NULL; + + /* Reset the error code */ + hdma->ErrorCode = HAL_DMA_ERROR_NONE; + + /* Reset the DMA state */ + hdma->State = HAL_DMA_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(hdma); + + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup DMA_Exported_Functions_Group2 Input and Output operation functions + * @brief I/O operation functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Configure the source, destination address and data length and Start DMA transfer + (+) Configure the source, destination address and data length and + Start DMA transfer with interrupt + (+) Abort DMA transfer + (+) Poll for transfer complete + (+) Handle DMA interrupt request + +@endverbatim + * @{ + */ + +/** + * @brief Start the DMA Transfer. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @param SrcAddress The source memory Buffer address + * @param DstAddress The destination memory Buffer address + * @param DataLength The length of data to be transferred from source to destination + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_Start(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_DMA_BUFFER_SIZE(DataLength)); + + /* Process locked */ + __HAL_LOCK(hdma); + + if(HAL_DMA_STATE_READY == hdma->State) + { + /* Change DMA peripheral state */ + hdma->State = HAL_DMA_STATE_BUSY; + + hdma->ErrorCode = HAL_DMA_ERROR_NONE; + + /* Disable the peripheral */ + hdma->Instance->CCR &= ~DMA_CCR_EN; + + /* Configure the source, destination address and the data length */ + DMA_SetConfig(hdma, SrcAddress, DstAddress, DataLength); + + /* Enable the Peripheral */ + hdma->Instance->CCR |= DMA_CCR_EN; + } + else + { + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + /* Remain BUSY */ + status = HAL_BUSY; + } + + return status; +} + +/** + * @brief Start the DMA Transfer with interrupt enabled. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @param SrcAddress The source memory Buffer address + * @param DstAddress The destination memory Buffer address + * @param DataLength The length of data to be transferred from source to destination + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_Start_IT(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_DMA_BUFFER_SIZE(DataLength)); + + /* Process locked */ + __HAL_LOCK(hdma); + + if(HAL_DMA_STATE_READY == hdma->State) + { + /* Change DMA peripheral state */ + hdma->State = HAL_DMA_STATE_BUSY; + + hdma->ErrorCode = HAL_DMA_ERROR_NONE; + + /* Disable the peripheral */ + hdma->Instance->CCR &= ~DMA_CCR_EN; + + /* Configure the source, destination address and the data length */ + DMA_SetConfig(hdma, SrcAddress, DstAddress, DataLength); + + /* Enable the transfer complete, & transfer error interrupts */ + /* Half transfer interrupt is optional: enable it only if associated callback is available */ + if(NULL != hdma->XferHalfCpltCallback ) + { + hdma->Instance->CCR |= (DMA_IT_TC | DMA_IT_HT | DMA_IT_TE); + } + else + { + hdma->Instance->CCR |= (DMA_IT_TC | DMA_IT_TE); + hdma->Instance->CCR &= ~DMA_IT_HT; + } + + /* Enable the Peripheral */ + hdma->Instance->CCR |= DMA_CCR_EN; + } + else + { + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + /* Remain BUSY */ + status = HAL_BUSY; + } + + return status; +} + +/** + * @brief Abort the DMA Transfer. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_Abort(DMA_HandleTypeDef *hdma) +{ + if(hdma->State != HAL_DMA_STATE_BUSY) + { + /* no transfer ongoing */ + hdma->ErrorCode = HAL_DMA_ERROR_NO_XFER; + + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + return HAL_ERROR; + } + else + { + /* Disable DMA IT */ + hdma->Instance->CCR &= ~(DMA_IT_TC | DMA_IT_HT | DMA_IT_TE); + + /* Disable the channel */ + hdma->Instance->CCR &= ~DMA_CCR_EN; + + /* Clear all flags */ + hdma->DmaBaseAddress->IFCR = (DMA_FLAG_GL1 << hdma->ChannelIndex); + } + /* Change the DMA state*/ + hdma->State = HAL_DMA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + return HAL_OK; +} + +/** + * @brief Abort the DMA Transfer in Interrupt mode. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Stream. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_Abort_IT(DMA_HandleTypeDef *hdma) +{ + HAL_StatusTypeDef status = HAL_OK; + + if(HAL_DMA_STATE_BUSY != hdma->State) + { + /* no transfer ongoing */ + hdma->ErrorCode = HAL_DMA_ERROR_NO_XFER; + + status = HAL_ERROR; + } + else + { + + /* Disable DMA IT */ + hdma->Instance->CCR &= ~(DMA_IT_TC | DMA_IT_HT | DMA_IT_TE); + + /* Disable the channel */ + hdma->Instance->CCR &= ~DMA_CCR_EN; + + /* Clear all flags */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_GL1 << hdma->ChannelIndex; + + /* Change the DMA state */ + hdma->State = HAL_DMA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + /* Call User Abort callback */ + if(hdma->XferAbortCallback != NULL) + { + hdma->XferAbortCallback(hdma); + } + } + return status; +} + +/** + * @brief Polling for transfer complete. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @param CompleteLevel Specifies the DMA level complete. + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_PollForTransfer(DMA_HandleTypeDef *hdma, uint32_t CompleteLevel, uint32_t Timeout) +{ + uint32_t temp; + uint32_t tickstart = 0U; + + if(HAL_DMA_STATE_BUSY != hdma->State) + { + /* no transfer ongoing */ + hdma->ErrorCode = HAL_DMA_ERROR_NO_XFER; + __HAL_UNLOCK(hdma); + return HAL_ERROR; + } + + /* Polling mode not supported in circular mode */ + if (RESET != (hdma->Instance->CCR & DMA_CCR_CIRC)) + { + hdma->ErrorCode = HAL_DMA_ERROR_NOT_SUPPORTED; + return HAL_ERROR; + } + + /* Get the level transfer complete flag */ + if(HAL_DMA_FULL_TRANSFER == CompleteLevel) + { + /* Transfer Complete flag */ + temp = DMA_FLAG_TC1 << hdma->ChannelIndex; + } + else + { + /* Half Transfer Complete flag */ + temp = DMA_FLAG_HT1 << hdma->ChannelIndex; + } + + /* Get tick */ + tickstart = HAL_GetTick(); + + while(RESET == (hdma->DmaBaseAddress->ISR & temp)) + { + if(RESET != (hdma->DmaBaseAddress->ISR & (DMA_FLAG_TE1 << hdma->ChannelIndex))) + { + /* When a DMA transfer error occurs */ + /* A hardware clear of its EN bits is performed */ + /* Clear all flags */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_GL1 << hdma->ChannelIndex; + + /* Update error code */ + hdma->ErrorCode = HAL_DMA_ERROR_TE; + + /* Change the DMA state */ + hdma->State= HAL_DMA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + return HAL_ERROR; + } + /* Check for the Timeout */ + if(Timeout != HAL_MAX_DELAY) + { + if((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + /* Update error code */ + hdma->ErrorCode = HAL_DMA_ERROR_TIMEOUT; + + /* Change the DMA state */ + hdma->State = HAL_DMA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + return HAL_ERROR; + } + } + } + + if(HAL_DMA_FULL_TRANSFER == CompleteLevel) + { + /* Clear the transfer complete flag */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_TC1 << hdma->ChannelIndex; + + /* The selected Channelx EN bit is cleared (DMA is disabled and + all transfers are complete) */ + hdma->State = HAL_DMA_STATE_READY; + } + else + { + /* Clear the half transfer complete flag */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_HT1 << hdma->ChannelIndex; + } + + /* Process unlocked */ + __HAL_UNLOCK(hdma); + + return HAL_OK; +} + +/** + * @brief Handle DMA interrupt request. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @retval None + */ +void HAL_DMA_IRQHandler(DMA_HandleTypeDef *hdma) +{ + uint32_t flag_it = hdma->DmaBaseAddress->ISR; + uint32_t source_it = hdma->Instance->CCR; + + /* Half Transfer Complete Interrupt management ******************************/ + if ((RESET != (flag_it & (DMA_FLAG_HT1 << hdma->ChannelIndex))) && (RESET != (source_it & DMA_IT_HT))) + { + /* Disable the half transfer interrupt if the DMA mode is not CIRCULAR */ + if((hdma->Instance->CCR & DMA_CCR_CIRC) == 0U) + { + /* Disable the half transfer interrupt */ + hdma->Instance->CCR &= ~DMA_IT_HT; + } + + /* Clear the half transfer complete flag */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_HT1 << hdma->ChannelIndex; + + /* DMA peripheral state is not updated in Half Transfer */ + /* State is updated only in Transfer Complete case */ + + if(hdma->XferHalfCpltCallback != NULL) + { + /* Half transfer callback */ + hdma->XferHalfCpltCallback(hdma); + } + } + + /* Transfer Complete Interrupt management ***********************************/ + else if ((RESET != (flag_it & (DMA_FLAG_TC1 << hdma->ChannelIndex))) && (RESET != (source_it & DMA_IT_TC))) + { + if((hdma->Instance->CCR & DMA_CCR_CIRC) == 0U) + { + /* Disable the transfer complete & transfer error interrupts */ + /* if the DMA mode is not CIRCULAR */ + hdma->Instance->CCR &= ~(DMA_IT_TC | DMA_IT_TE); + + /* Change the DMA state */ + hdma->State = HAL_DMA_STATE_READY; + } + + /* Clear the transfer complete flag */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_TC1 << hdma->ChannelIndex; + + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + if(hdma->XferCpltCallback != NULL) + { + /* Transfer complete callback */ + hdma->XferCpltCallback(hdma); + } + } + + /* Transfer Error Interrupt management ***************************************/ + else if (( RESET != (flag_it & (DMA_FLAG_TE1 << hdma->ChannelIndex))) && (RESET != (source_it & DMA_IT_TE))) + { + /* When a DMA transfer error occurs */ + /* A hardware clear of its EN bits is performed */ + /* Then, disable all DMA interrupts */ + hdma->Instance->CCR &= ~(DMA_IT_TC | DMA_IT_HT | DMA_IT_TE); + + /* Clear all flags */ + hdma->DmaBaseAddress->IFCR = DMA_FLAG_GL1 << hdma->ChannelIndex; + + /* Update error code */ + hdma->ErrorCode = HAL_DMA_ERROR_TE; + + /* Change the DMA state */ + hdma->State = HAL_DMA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hdma); + + if(hdma->XferErrorCallback != NULL) + { + /* Transfer error callback */ + hdma->XferErrorCallback(hdma); + } + } +} + +/** + * @brief Register callbacks + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Stream. + * @param CallbackID User Callback identifer + * a HAL_DMA_CallbackIDTypeDef ENUM as parameter. + * @param pCallback pointer to private callback function which has pointer to + * a DMA_HandleTypeDef structure as parameter. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_RegisterCallback(DMA_HandleTypeDef *hdma, HAL_DMA_CallbackIDTypeDef CallbackID, void (* pCallback)( DMA_HandleTypeDef * _hdma)) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hdma); + + if(HAL_DMA_STATE_READY == hdma->State) + { + switch (CallbackID) + { + case HAL_DMA_XFER_CPLT_CB_ID: + hdma->XferCpltCallback = pCallback; + break; + + case HAL_DMA_XFER_HALFCPLT_CB_ID: + hdma->XferHalfCpltCallback = pCallback; + break; + + case HAL_DMA_XFER_ERROR_CB_ID: + hdma->XferErrorCallback = pCallback; + break; + + case HAL_DMA_XFER_ABORT_CB_ID: + hdma->XferAbortCallback = pCallback; + break; + + default: + status = HAL_ERROR; + break; + } + } + else + { + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hdma); + + return status; +} + +/** + * @brief UnRegister callbacks + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Stream. + * @param CallbackID User Callback identifer + * a HAL_DMA_CallbackIDTypeDef ENUM as parameter. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_DMA_UnRegisterCallback(DMA_HandleTypeDef *hdma, HAL_DMA_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hdma); + + if(HAL_DMA_STATE_READY == hdma->State) + { + switch (CallbackID) + { + case HAL_DMA_XFER_CPLT_CB_ID: + hdma->XferCpltCallback = NULL; + break; + + case HAL_DMA_XFER_HALFCPLT_CB_ID: + hdma->XferHalfCpltCallback = NULL; + break; + + case HAL_DMA_XFER_ERROR_CB_ID: + hdma->XferErrorCallback = NULL; + break; + + case HAL_DMA_XFER_ABORT_CB_ID: + hdma->XferAbortCallback = NULL; + break; + + case HAL_DMA_XFER_ALL_CB_ID: + hdma->XferCpltCallback = NULL; + hdma->XferHalfCpltCallback = NULL; + hdma->XferErrorCallback = NULL; + hdma->XferAbortCallback = NULL; + break; + + default: + status = HAL_ERROR; + break; + } + } + else + { + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hdma); + + return status; +} + +/** + * @} + */ + +/** @defgroup DMA_Exported_Functions_Group3 Peripheral State functions + * @brief Peripheral State functions + * +@verbatim + =============================================================================== + ##### State and Errors functions ##### + =============================================================================== + [..] + This subsection provides functions allowing to + (+) Check the DMA state + (+) Get error code + +@endverbatim + * @{ + */ + +/** + * @brief Returns the DMA state. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @retval HAL state + */ +HAL_DMA_StateTypeDef HAL_DMA_GetState(DMA_HandleTypeDef *hdma) +{ + return hdma->State; +} + +/** + * @brief Return the DMA error code + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @retval DMA Error Code + */ +uint32_t HAL_DMA_GetError(DMA_HandleTypeDef *hdma) +{ + return hdma->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup DMA_Private_Functions + * @{ + */ + +/** + * @brief Set the DMA Transfer parameters. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Channel. + * @param SrcAddress The source memory Buffer address + * @param DstAddress The destination memory Buffer address + * @param DataLength The length of data to be transferred from source to destination + * @retval HAL status + */ +static void DMA_SetConfig(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength) +{ + /* Clear all flags */ + hdma->DmaBaseAddress->IFCR = (DMA_FLAG_GL1 << hdma->ChannelIndex); + + /* Configure DMA Channel data length */ + hdma->Instance->CNDTR = DataLength; + + /* Memory to Peripheral */ + if((hdma->Init.Direction) == DMA_MEMORY_TO_PERIPH) + { + /* Configure DMA Channel destination address */ + hdma->Instance->CPAR = DstAddress; + + /* Configure DMA Channel source address */ + hdma->Instance->CMAR = SrcAddress; + } + /* Peripheral to Memory */ + else + { + /* Configure DMA Channel source address */ + hdma->Instance->CPAR = SrcAddress; + + /* Configure DMA Channel destination address */ + hdma->Instance->CMAR = DstAddress; + } +} + +/** + * @brief set the DMA base address and channel index depending on DMA instance + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA Stream. + * @retval None + */ +static void DMA_CalcBaseAndBitshift(DMA_HandleTypeDef *hdma) +{ +#if defined (DMA2) + /* calculation of the channel index */ + if ((uint32_t)(hdma->Instance) < (uint32_t)(DMA2_Channel1)) + { + /* DMA1 */ + hdma->ChannelIndex = (((uint32_t)hdma->Instance - (uint32_t)DMA1_Channel1) / ((uint32_t)DMA1_Channel2 - (uint32_t)DMA1_Channel1)) << 2U; + hdma->DmaBaseAddress = DMA1; + } + else + { + /* DMA2 */ + hdma->ChannelIndex = (((uint32_t)hdma->Instance - (uint32_t)DMA2_Channel1) / ((uint32_t)DMA2_Channel2 - (uint32_t)DMA2_Channel1)) << 2U; + hdma->DmaBaseAddress = DMA2; + } +#else + /* calculation of the channel index */ + /* DMA1 */ + hdma->ChannelIndex = (((uint32_t)hdma->Instance - (uint32_t)DMA1_Channel1) / ((uint32_t)DMA1_Channel2 - (uint32_t)DMA1_Channel1)) << 2U; + hdma->DmaBaseAddress = DMA1; +#endif +} + +/** + * @} + */ + +/** + * @} + */ +#endif /* HAL_DMA_MODULE_ENABLED */ + +/** + * @} + */ + + /** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_exti.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_exti.c new file mode 100644 index 0000000..91a5ee9 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_exti.c @@ -0,0 +1,549 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_exti.c + * @author MCD Application Team + * @brief EXTI HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Extended Interrupts and events controller (EXTI) peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + @verbatim + ============================================================================== + ##### EXTI Peripheral features ##### + ============================================================================== + [..] + (+) Each Exti line can be configured within this driver. + + (+) Exti line can be configured in 3 different modes + (++) Interrupt + (++) Event + (++) Both of them + + (+) Configurable Exti lines can be configured with 3 different triggers + (++) Rising + (++) Falling + (++) Both of them + + (+) When set in interrupt mode, configurable Exti lines have two different + interrupts pending registers which allow to distinguish which transition + occurs: + (++) Rising edge pending interrupt + (++) Falling + + (+) Exti lines 0 to 15 are linked to gpio pin number 0 to 15. Gpio port can + be selected through multiplexer. + + ##### How to use this driver ##### + ============================================================================== + [..] + + (#) Configure the EXTI line using HAL_EXTI_SetConfigLine(). + (++) Choose the interrupt line number by setting "Line" member from + EXTI_ConfigTypeDef structure. + (++) Configure the interrupt and/or event mode using "Mode" member from + EXTI_ConfigTypeDef structure. + (++) For configurable lines, configure rising and/or falling trigger + "Trigger" member from EXTI_ConfigTypeDef structure. + (++) For Exti lines linked to gpio, choose gpio port using "GPIOSel" + member from GPIO_InitTypeDef structure. + + (#) Get current Exti configuration of a dedicated line using + HAL_EXTI_GetConfigLine(). + (++) Provide exiting handle as parameter. + (++) Provide pointer on EXTI_ConfigTypeDef structure as second parameter. + + (#) Clear Exti configuration of a dedicated line using HAL_EXTI_GetConfigLine(). + (++) Provide exiting handle as parameter. + + (#) Register callback to treat Exti interrupts using HAL_EXTI_RegisterCallback(). + (++) Provide exiting handle as first parameter. + (++) Provide which callback will be registered using one value from + EXTI_CallbackIDTypeDef. + (++) Provide callback function pointer. + + (#) Get interrupt pending bit using HAL_EXTI_GetPending(). + + (#) Clear interrupt pending bit using HAL_EXTI_GetPending(). + + (#) Generate software interrupt using HAL_EXTI_GenerateSWI(). + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2019 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup EXTI + * @{ + */ +/** MISRA C:2012 deviation rule has been granted for following rule: + * Rule-18.1_b - Medium: Array `EXTICR' 1st subscript interval [0,7] may be out + * of bounds [0,3] in following API : + * HAL_EXTI_SetConfigLine + * HAL_EXTI_GetConfigLine + * HAL_EXTI_ClearConfigLine + */ + +#ifdef HAL_EXTI_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private defines -----------------------------------------------------------*/ +/** @defgroup EXTI_Private_Constants EXTI Private Constants + * @{ + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup EXTI_Exported_Functions + * @{ + */ + +/** @addtogroup EXTI_Exported_Functions_Group1 + * @brief Configuration functions + * +@verbatim + =============================================================================== + ##### Configuration functions ##### + =============================================================================== + +@endverbatim + * @{ + */ + +/** + * @brief Set configuration of a dedicated Exti line. + * @param hexti Exti handle. + * @param pExtiConfig Pointer on EXTI configuration to be set. + * @retval HAL Status. + */ +HAL_StatusTypeDef HAL_EXTI_SetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigTypeDef *pExtiConfig) +{ + uint32_t regval; + uint32_t linepos; + uint32_t maskline; + + /* Check null pointer */ + if ((hexti == NULL) || (pExtiConfig == NULL)) + { + return HAL_ERROR; + } + + /* Check parameters */ + assert_param(IS_EXTI_LINE(pExtiConfig->Line)); + assert_param(IS_EXTI_MODE(pExtiConfig->Mode)); + + /* Assign line number to handle */ + hexti->Line = pExtiConfig->Line; + + /* Compute line mask */ + linepos = (pExtiConfig->Line & EXTI_PIN_MASK); + maskline = (1uL << linepos); + + /* Configure triggers for configurable lines */ + if ((pExtiConfig->Line & EXTI_CONFIG) != 0x00u) + { + assert_param(IS_EXTI_TRIGGER(pExtiConfig->Trigger)); + + /* Configure rising trigger */ + /* Mask or set line */ + if ((pExtiConfig->Trigger & EXTI_TRIGGER_RISING) != 0x00u) + { + EXTI->RTSR |= maskline; + } + else + { + EXTI->RTSR &= ~maskline; + } + + /* Configure falling trigger */ + /* Mask or set line */ + if ((pExtiConfig->Trigger & EXTI_TRIGGER_FALLING) != 0x00u) + { + EXTI->FTSR |= maskline; + } + else + { + EXTI->FTSR &= ~maskline; + } + + + /* Configure gpio port selection in case of gpio exti line */ + if ((pExtiConfig->Line & EXTI_GPIO) == EXTI_GPIO) + { + assert_param(IS_EXTI_GPIO_PORT(pExtiConfig->GPIOSel)); + assert_param(IS_EXTI_GPIO_PIN(linepos)); + + regval = SYSCFG->EXTICR[linepos >> 2u]; + regval &= ~(SYSCFG_EXTICR1_EXTI0 << (SYSCFG_EXTICR1_EXTI1_Pos * (linepos & 0x03u))); + regval |= (pExtiConfig->GPIOSel << (SYSCFG_EXTICR1_EXTI1_Pos * (linepos & 0x03u))); + SYSCFG->EXTICR[linepos >> 2u] = regval; + } + } + + /* Configure interrupt mode : read current mode */ + /* Mask or set line */ + if ((pExtiConfig->Mode & EXTI_MODE_INTERRUPT) != 0x00u) + { + EXTI->IMR |= maskline; + } + else + { + EXTI->IMR &= ~maskline; + } + + /* Configure event mode : read current mode */ + /* Mask or set line */ + if ((pExtiConfig->Mode & EXTI_MODE_EVENT) != 0x00u) + { + EXTI->EMR |= maskline; + } + else + { + EXTI->EMR &= ~maskline; + } + + return HAL_OK; +} + +/** + * @brief Get configuration of a dedicated Exti line. + * @param hexti Exti handle. + * @param pExtiConfig Pointer on structure to store Exti configuration. + * @retval HAL Status. + */ +HAL_StatusTypeDef HAL_EXTI_GetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigTypeDef *pExtiConfig) +{ + uint32_t regval; + uint32_t linepos; + uint32_t maskline; + + /* Check null pointer */ + if ((hexti == NULL) || (pExtiConfig == NULL)) + { + return HAL_ERROR; + } + + /* Check the parameter */ + assert_param(IS_EXTI_LINE(hexti->Line)); + + /* Store handle line number to configuration structure */ + pExtiConfig->Line = hexti->Line; + + /* Compute line mask */ + linepos = (pExtiConfig->Line & EXTI_PIN_MASK); + maskline = (1uL << linepos); + + /* 1] Get core mode : interrupt */ + + /* Check if selected line is enable */ + if ((EXTI->IMR & maskline) != 0x00u) + { + pExtiConfig->Mode = EXTI_MODE_INTERRUPT; + } + else + { + pExtiConfig->Mode = EXTI_MODE_NONE; + } + + /* Get event mode */ + /* Check if selected line is enable */ + if ((EXTI->EMR & maskline) != 0x00u) + { + pExtiConfig->Mode |= EXTI_MODE_EVENT; + } + + /* Get default Trigger and GPIOSel configuration */ + pExtiConfig->Trigger = EXTI_TRIGGER_NONE; + pExtiConfig->GPIOSel = 0x00u; + + /* 2] Get trigger for configurable lines : rising */ + if ((pExtiConfig->Line & EXTI_CONFIG) != 0x00u) + { + /* Check if configuration of selected line is enable */ + if ((EXTI->RTSR & maskline) != 0x00u) + { + pExtiConfig->Trigger = EXTI_TRIGGER_RISING; + } + + /* Get falling configuration */ + /* Check if configuration of selected line is enable */ + if ((EXTI->FTSR & maskline) != 0x00u) + { + pExtiConfig->Trigger |= EXTI_TRIGGER_FALLING; + } + + /* Get Gpio port selection for gpio lines */ + if ((pExtiConfig->Line & EXTI_GPIO) == EXTI_GPIO) + { + assert_param(IS_EXTI_GPIO_PIN(linepos)); + + regval = SYSCFG->EXTICR[linepos >> 2u]; + pExtiConfig->GPIOSel = ((regval << (SYSCFG_EXTICR1_EXTI1_Pos * (3uL - (linepos & 0x03u)))) >> 24); + } + } + + return HAL_OK; +} + +/** + * @brief Clear whole configuration of a dedicated Exti line. + * @param hexti Exti handle. + * @retval HAL Status. + */ +HAL_StatusTypeDef HAL_EXTI_ClearConfigLine(EXTI_HandleTypeDef *hexti) +{ + uint32_t regval; + uint32_t linepos; + uint32_t maskline; + + /* Check null pointer */ + if (hexti == NULL) + { + return HAL_ERROR; + } + + /* Check the parameter */ + assert_param(IS_EXTI_LINE(hexti->Line)); + + /* compute line mask */ + linepos = (hexti->Line & EXTI_PIN_MASK); + maskline = (1uL << linepos); + + /* 1] Clear interrupt mode */ + EXTI->IMR = (EXTI->IMR & ~maskline); + + /* 2] Clear event mode */ + EXTI->EMR = (EXTI->EMR & ~maskline); + + /* 3] Clear triggers in case of configurable lines */ + if ((hexti->Line & EXTI_CONFIG) != 0x00u) + { + EXTI->RTSR = (EXTI->RTSR & ~maskline); + EXTI->FTSR = (EXTI->FTSR & ~maskline); + + /* Get Gpio port selection for gpio lines */ + if ((hexti->Line & EXTI_GPIO) == EXTI_GPIO) + { + assert_param(IS_EXTI_GPIO_PIN(linepos)); + + regval = SYSCFG->EXTICR[linepos >> 2u]; + regval &= ~(SYSCFG_EXTICR1_EXTI0 << (SYSCFG_EXTICR1_EXTI1_Pos * (linepos & 0x03u))); + SYSCFG->EXTICR[linepos >> 2u] = regval; + } + } + + return HAL_OK; +} + +/** + * @brief Register callback for a dedicated Exti line. + * @param hexti Exti handle. + * @param CallbackID User callback identifier. + * This parameter can be one of @arg @ref EXTI_CallbackIDTypeDef values. + * @param pPendingCbfn function pointer to be stored as callback. + * @retval HAL Status. + */ +HAL_StatusTypeDef HAL_EXTI_RegisterCallback(EXTI_HandleTypeDef *hexti, EXTI_CallbackIDTypeDef CallbackID, void (*pPendingCbfn)(void)) +{ + HAL_StatusTypeDef status = HAL_OK; + + switch (CallbackID) + { + case HAL_EXTI_COMMON_CB_ID: + hexti->PendingCallback = pPendingCbfn; + break; + + default: + status = HAL_ERROR; + break; + } + + return status; +} + +/** + * @brief Store line number as handle private field. + * @param hexti Exti handle. + * @param ExtiLine Exti line number. + * This parameter can be from 0 to @ref EXTI_LINE_NB. + * @retval HAL Status. + */ +HAL_StatusTypeDef HAL_EXTI_GetHandle(EXTI_HandleTypeDef *hexti, uint32_t ExtiLine) +{ + /* Check the parameters */ + assert_param(IS_EXTI_LINE(ExtiLine)); + + /* Check null pointer */ + if (hexti == NULL) + { + return HAL_ERROR; + } + else + { + /* Store line number as handle private field */ + hexti->Line = ExtiLine; + + return HAL_OK; + } +} + +/** + * @} + */ + +/** @addtogroup EXTI_Exported_Functions_Group2 + * @brief EXTI IO functions. + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + +@endverbatim + * @{ + */ + +/** + * @brief Handle EXTI interrupt request. + * @param hexti Exti handle. + * @retval none. + */ +void HAL_EXTI_IRQHandler(EXTI_HandleTypeDef *hexti) +{ + uint32_t regval; + uint32_t maskline; + + /* Compute line mask */ + maskline = (1uL << (hexti->Line & EXTI_PIN_MASK)); + + /* Get pending bit */ + regval = (EXTI->PR & maskline); + if (regval != 0x00u) + { + /* Clear pending bit */ + EXTI->PR = maskline; + + /* Call callback */ + if (hexti->PendingCallback != NULL) + { + hexti->PendingCallback(); + } + } +} + +/** + * @brief Get interrupt pending bit of a dedicated line. + * @param hexti Exti handle. + * @param Edge Specify which pending edge as to be checked. + * This parameter can be one of the following values: + * @arg @ref EXTI_TRIGGER_RISING_FALLING + * This parameter is kept for compatibility with other series. + * @retval 1 if interrupt is pending else 0. + */ +uint32_t HAL_EXTI_GetPending(EXTI_HandleTypeDef *hexti, uint32_t Edge) +{ + uint32_t regval; + uint32_t linepos; + uint32_t maskline; + + /* Check parameters */ + assert_param(IS_EXTI_LINE(hexti->Line)); + assert_param(IS_EXTI_CONFIG_LINE(hexti->Line)); + assert_param(IS_EXTI_PENDING_EDGE(Edge)); + + /* Compute line mask */ + linepos = (hexti->Line & EXTI_PIN_MASK); + maskline = (1uL << linepos); + + /* return 1 if bit is set else 0 */ + regval = ((EXTI->PR & maskline) >> linepos); + return regval; +} + +/** + * @brief Clear interrupt pending bit of a dedicated line. + * @param hexti Exti handle. + * @param Edge Specify which pending edge as to be clear. + * This parameter can be one of the following values: + * @arg @ref EXTI_TRIGGER_RISING_FALLING + * This parameter is kept for compatibility with other series. + * @retval None. + */ +void HAL_EXTI_ClearPending(EXTI_HandleTypeDef *hexti, uint32_t Edge) +{ + uint32_t maskline; + + /* Check parameters */ + assert_param(IS_EXTI_LINE(hexti->Line)); + assert_param(IS_EXTI_CONFIG_LINE(hexti->Line)); + assert_param(IS_EXTI_PENDING_EDGE(Edge)); + + /* Compute line mask */ + maskline = (1uL << (hexti->Line & EXTI_PIN_MASK)); + + /* Clear Pending bit */ + EXTI->PR = maskline; +} + +/** + * @brief Generate a software interrupt for a dedicated line. + * @param hexti Exti handle. + * @retval None. + */ +void HAL_EXTI_GenerateSWI(EXTI_HandleTypeDef *hexti) +{ + uint32_t maskline; + + /* Check parameters */ + assert_param(IS_EXTI_LINE(hexti->Line)); + assert_param(IS_EXTI_CONFIG_LINE(hexti->Line)); + + /* Compute line mask */ + maskline = (1uL << (hexti->Line & EXTI_PIN_MASK)); + + /* Generate Software interrupt */ + EXTI->SWIER = maskline; +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_EXTI_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash.c new file mode 100644 index 0000000..94ad6e9 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash.c @@ -0,0 +1,694 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_flash.c + * @author MCD Application Team + * @brief FLASH HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the internal FLASH memory: + * + Program operations functions + * + Memory Control functions + * + Peripheral State functions + * + @verbatim + ============================================================================== + ##### FLASH peripheral features ##### + ============================================================================== + [..] The Flash memory interface manages CPU AHB I-Code and D-Code accesses + to the Flash memory. It implements the erase and program Flash memory operations + and the read and write protection mechanisms. + + [..] The Flash memory interface accelerates code execution with a system of instruction + prefetch. + + [..] The FLASH main features are: + (+) Flash memory read operations + (+) Flash memory program/erase operations + (+) Read / write protections + (+) Prefetch on I-Code + (+) Option Bytes programming + + + ##### How to use this driver ##### + ============================================================================== + [..] + This driver provides functions and macros to configure and program the FLASH + memory of all STM32F0xx devices. + + (#) FLASH Memory I/O Programming functions: this group includes all needed + functions to erase and program the main memory: + (++) Lock and Unlock the FLASH interface + (++) Erase function: Erase page, erase all pages + (++) Program functions: half word, word and doubleword + (#) FLASH Option Bytes Programming functions: this group includes all needed + functions to manage the Option Bytes: + (++) Lock and Unlock the Option Bytes + (++) Set/Reset the write protection + (++) Set the Read protection Level + (++) Program the user Option Bytes + (++) Launch the Option Bytes loader + (++) Erase Option Bytes + (++) Program the data Option Bytes + (++) Get the Write protection. + (++) Get the user option bytes. + + (#) Interrupts and flags management functions : this group + includes all needed functions to: + (++) Handle FLASH interrupts + (++) Wait for last FLASH operation according to its status + (++) Get error flag status + + [..] In addition to these function, this driver includes a set of macros allowing + to handle the following operations: + + (+) Set/Get the latency + (+) Enable/Disable the prefetch buffer + (+) Enable/Disable the FLASH interrupts + (+) Monitor the FLASH flags status + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#ifdef HAL_FLASH_MODULE_ENABLED + +/** @defgroup FLASH FLASH + * @brief FLASH HAL module driver + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup FLASH_Private_Constants FLASH Private Constants + * @{ + */ +/** + * @} + */ + +/* Private macro ---------------------------- ---------------------------------*/ +/** @defgroup FLASH_Private_Macros FLASH Private Macros + * @{ + */ + +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/** @defgroup FLASH_Private_Variables FLASH Private Variables + * @{ + */ +/* Variables used for Erase pages under interruption*/ +FLASH_ProcessTypeDef pFlash; +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup FLASH_Private_Functions FLASH Private Functions + * @{ + */ +static void FLASH_Program_HalfWord(uint32_t Address, uint16_t Data); +static void FLASH_SetErrorCode(void); +extern void FLASH_PageErase(uint32_t PageAddress); +/** + * @} + */ + +/* Exported functions ---------------------------------------------------------*/ +/** @defgroup FLASH_Exported_Functions FLASH Exported Functions + * @{ + */ + +/** @defgroup FLASH_Exported_Functions_Group1 Programming operation functions + * @brief Programming operation functions + * +@verbatim +@endverbatim + * @{ + */ + +/** + * @brief Program halfword, word or double word at a specified address + * @note The function HAL_FLASH_Unlock() should be called before to unlock the FLASH interface + * The function HAL_FLASH_Lock() should be called after to lock the FLASH interface + * + * @note If an erase and a program operations are requested simultaneously, + * the erase operation is performed before the program one. + * + * @note FLASH should be previously erased before new programming (only exception to this + * is when 0x0000 is programmed) + * + * @param TypeProgram Indicate the way to program at a specified address. + * This parameter can be a value of @ref FLASH_Type_Program + * @param Address Specifie the address to be programmed. + * @param Data Specifie the data to be programmed + * + * @retval HAL_StatusTypeDef HAL Status + */ +HAL_StatusTypeDef HAL_FLASH_Program(uint32_t TypeProgram, uint32_t Address, uint64_t Data) +{ + HAL_StatusTypeDef status = HAL_ERROR; + uint8_t index = 0U; + uint8_t nbiterations = 0U; + + /* Process Locked */ + __HAL_LOCK(&pFlash); + + /* Check the parameters */ + assert_param(IS_FLASH_TYPEPROGRAM(TypeProgram)); + assert_param(IS_FLASH_PROGRAM_ADDRESS(Address)); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE); + + if(status == HAL_OK) + { + if(TypeProgram == FLASH_TYPEPROGRAM_HALFWORD) + { + /* Program halfword (16-bit) at a specified address. */ + nbiterations = 1U; + } + else if(TypeProgram == FLASH_TYPEPROGRAM_WORD) + { + /* Program word (32-bit = 2*16-bit) at a specified address. */ + nbiterations = 2U; + } + else + { + /* Program double word (64-bit = 4*16-bit) at a specified address. */ + nbiterations = 4U; + } + + for (index = 0U; index < nbiterations; index++) + { + FLASH_Program_HalfWord((Address + (2U*index)), (uint16_t)(Data >> (16U*index))); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE); + + /* If the program operation is completed, disable the PG Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_PG); + /* In case of error, stop programming procedure */ + if (status != HAL_OK) + { + break; + } + } + } + + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + + return status; +} + +/** + * @brief Program halfword, word or double word at a specified address with interrupt enabled. + * @note The function HAL_FLASH_Unlock() should be called before to unlock the FLASH interface + * The function HAL_FLASH_Lock() should be called after to lock the FLASH interface + * + * @note If an erase and a program operations are requested simultaneously, + * the erase operation is performed before the program one. + * + * @param TypeProgram Indicate the way to program at a specified address. + * This parameter can be a value of @ref FLASH_Type_Program + * @param Address Specifie the address to be programmed. + * @param Data Specifie the data to be programmed + * + * @retval HAL_StatusTypeDef HAL Status + */ +HAL_StatusTypeDef HAL_FLASH_Program_IT(uint32_t TypeProgram, uint32_t Address, uint64_t Data) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process Locked */ + __HAL_LOCK(&pFlash); + + /* Check the parameters */ + assert_param(IS_FLASH_TYPEPROGRAM(TypeProgram)); + assert_param(IS_FLASH_PROGRAM_ADDRESS(Address)); + + /* Enable End of FLASH Operation and Error source interrupts */ + __HAL_FLASH_ENABLE_IT(FLASH_IT_EOP | FLASH_IT_ERR); + + pFlash.Address = Address; + pFlash.Data = Data; + + if(TypeProgram == FLASH_TYPEPROGRAM_HALFWORD) + { + pFlash.ProcedureOnGoing = FLASH_PROC_PROGRAMHALFWORD; + /* Program halfword (16-bit) at a specified address. */ + pFlash.DataRemaining = 1U; + } + else if(TypeProgram == FLASH_TYPEPROGRAM_WORD) + { + pFlash.ProcedureOnGoing = FLASH_PROC_PROGRAMWORD; + /* Program word (32-bit : 2*16-bit) at a specified address. */ + pFlash.DataRemaining = 2U; + } + else + { + pFlash.ProcedureOnGoing = FLASH_PROC_PROGRAMDOUBLEWORD; + /* Program double word (64-bit : 4*16-bit) at a specified address. */ + pFlash.DataRemaining = 4U; + } + + /* Program halfword (16-bit) at a specified address. */ + FLASH_Program_HalfWord(Address, (uint16_t)Data); + + return status; +} + +/** + * @brief This function handles FLASH interrupt request. + * @retval None + */ +void HAL_FLASH_IRQHandler(void) +{ + uint32_t addresstmp = 0U; + + /* Check FLASH operation error flags */ + if(__HAL_FLASH_GET_FLAG(FLASH_FLAG_WRPERR) ||__HAL_FLASH_GET_FLAG(FLASH_FLAG_PGERR)) + { + /* Return the faulty address */ + addresstmp = pFlash.Address; + /* Reset address */ + pFlash.Address = 0xFFFFFFFFU; + + /* Save the Error code */ + FLASH_SetErrorCode(); + + /* FLASH error interrupt user callback */ + HAL_FLASH_OperationErrorCallback(addresstmp); + + /* Stop the procedure ongoing */ + pFlash.ProcedureOnGoing = FLASH_PROC_NONE; + } + + /* Check FLASH End of Operation flag */ + if(__HAL_FLASH_GET_FLAG(FLASH_FLAG_EOP)) + { + /* Clear FLASH End of Operation pending bit */ + __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_EOP); + + /* Process can continue only if no error detected */ + if(pFlash.ProcedureOnGoing != FLASH_PROC_NONE) + { + if(pFlash.ProcedureOnGoing == FLASH_PROC_PAGEERASE) + { + /* Nb of pages to erased can be decreased */ + pFlash.DataRemaining--; + + /* Check if there are still pages to erase */ + if(pFlash.DataRemaining != 0U) + { + addresstmp = pFlash.Address; + /*Indicate user which sector has been erased */ + HAL_FLASH_EndOfOperationCallback(addresstmp); + + /*Increment sector number*/ + addresstmp = pFlash.Address + FLASH_PAGE_SIZE; + pFlash.Address = addresstmp; + + /* If the erase operation is completed, disable the PER Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_PER); + + FLASH_PageErase(addresstmp); + } + else + { + /* No more pages to Erase, user callback can be called. */ + /* Reset Sector and stop Erase pages procedure */ + pFlash.Address = addresstmp = 0xFFFFFFFFU; + pFlash.ProcedureOnGoing = FLASH_PROC_NONE; + /* FLASH EOP interrupt user callback */ + HAL_FLASH_EndOfOperationCallback(addresstmp); + } + } + else if(pFlash.ProcedureOnGoing == FLASH_PROC_MASSERASE) + { + /* Operation is completed, disable the MER Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_MER); + + /* MassErase ended. Return the selected bank */ + /* FLASH EOP interrupt user callback */ + HAL_FLASH_EndOfOperationCallback(0); + + /* Stop Mass Erase procedure*/ + pFlash.ProcedureOnGoing = FLASH_PROC_NONE; + } + else + { + /* Nb of 16-bit data to program can be decreased */ + pFlash.DataRemaining--; + + /* Check if there are still 16-bit data to program */ + if(pFlash.DataRemaining != 0U) + { + /* Increment address to 16-bit */ + pFlash.Address += 2; + addresstmp = pFlash.Address; + + /* Shift to have next 16-bit data */ + pFlash.Data = (pFlash.Data >> 16U); + + /* Operation is completed, disable the PG Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_PG); + + /*Program halfword (16-bit) at a specified address.*/ + FLASH_Program_HalfWord(addresstmp, (uint16_t)pFlash.Data); + } + else + { + /* Program ended. Return the selected address */ + /* FLASH EOP interrupt user callback */ + if (pFlash.ProcedureOnGoing == FLASH_PROC_PROGRAMHALFWORD) + { + HAL_FLASH_EndOfOperationCallback(pFlash.Address); + } + else if (pFlash.ProcedureOnGoing == FLASH_PROC_PROGRAMWORD) + { + HAL_FLASH_EndOfOperationCallback(pFlash.Address - 2U); + } + else + { + HAL_FLASH_EndOfOperationCallback(pFlash.Address - 6U); + } + + /* Reset Address and stop Program procedure */ + pFlash.Address = 0xFFFFFFFFU; + pFlash.ProcedureOnGoing = FLASH_PROC_NONE; + } + } + } + } + + + if(pFlash.ProcedureOnGoing == FLASH_PROC_NONE) + { + /* Operation is completed, disable the PG, PER and MER Bits */ + CLEAR_BIT(FLASH->CR, (FLASH_CR_PG | FLASH_CR_PER | FLASH_CR_MER)); + + /* Disable End of FLASH Operation and Error source interrupts */ + __HAL_FLASH_DISABLE_IT(FLASH_IT_EOP | FLASH_IT_ERR); + + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + } +} + +/** + * @brief FLASH end of operation interrupt callback + * @param ReturnValue The value saved in this parameter depends on the ongoing procedure + * - Mass Erase: No return value expected + * - Pages Erase: Address of the page which has been erased + * (if 0xFFFFFFFF, it means that all the selected pages have been erased) + * - Program: Address which was selected for data program + * @retval none + */ +__weak void HAL_FLASH_EndOfOperationCallback(uint32_t ReturnValue) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(ReturnValue); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_FLASH_EndOfOperationCallback could be implemented in the user file + */ +} + +/** + * @brief FLASH operation error interrupt callback + * @param ReturnValue The value saved in this parameter depends on the ongoing procedure + * - Mass Erase: No return value expected + * - Pages Erase: Address of the page which returned an error + * - Program: Address which was selected for data program + * @retval none + */ +__weak void HAL_FLASH_OperationErrorCallback(uint32_t ReturnValue) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(ReturnValue); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_FLASH_OperationErrorCallback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup FLASH_Exported_Functions_Group2 Peripheral Control functions + * @brief management functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the FLASH + memory operations. + +@endverbatim + * @{ + */ + +/** + * @brief Unlock the FLASH control register access + * @retval HAL Status + */ +HAL_StatusTypeDef HAL_FLASH_Unlock(void) +{ + HAL_StatusTypeDef status = HAL_OK; + + if(READ_BIT(FLASH->CR, FLASH_CR_LOCK) != RESET) + { + /* Authorize the FLASH Registers access */ + WRITE_REG(FLASH->KEYR, FLASH_KEY1); + WRITE_REG(FLASH->KEYR, FLASH_KEY2); + + /* Verify Flash is unlocked */ + if(READ_BIT(FLASH->CR, FLASH_CR_LOCK) != RESET) + { + status = HAL_ERROR; + } + } + + return status; +} + +/** + * @brief Locks the FLASH control register access + * @retval HAL Status + */ +HAL_StatusTypeDef HAL_FLASH_Lock(void) +{ + /* Set the LOCK Bit to lock the FLASH Registers access */ + SET_BIT(FLASH->CR, FLASH_CR_LOCK); + + return HAL_OK; +} + +/** + * @brief Unlock the FLASH Option Control Registers access. + * @retval HAL Status + */ +HAL_StatusTypeDef HAL_FLASH_OB_Unlock(void) +{ + if (HAL_IS_BIT_CLR(FLASH->CR, FLASH_CR_OPTWRE)) + { + /* Authorizes the Option Byte register programming */ + WRITE_REG(FLASH->OPTKEYR, FLASH_OPTKEY1); + WRITE_REG(FLASH->OPTKEYR, FLASH_OPTKEY2); + } + else + { + return HAL_ERROR; + } + + return HAL_OK; +} + +/** + * @brief Lock the FLASH Option Control Registers access. + * @retval HAL Status + */ +HAL_StatusTypeDef HAL_FLASH_OB_Lock(void) +{ + /* Clear the OPTWRE Bit to lock the FLASH Option Byte Registers access */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTWRE); + + return HAL_OK; +} + +/** + * @brief Launch the option byte loading. + * @note This function will reset automatically the MCU. + * @retval HAL Status + */ +HAL_StatusTypeDef HAL_FLASH_OB_Launch(void) +{ + /* Set the OBL_Launch bit to launch the option byte loading */ + SET_BIT(FLASH->CR, FLASH_CR_OBL_LAUNCH); + + /* Wait for last operation to be completed */ + return(FLASH_WaitForLastOperation(FLASH_TIMEOUT_VALUE)); +} + +/** + * @} + */ + +/** @defgroup FLASH_Exported_Functions_Group3 Peripheral errors functions + * @brief Peripheral errors functions + * +@verbatim + =============================================================================== + ##### Peripheral Errors functions ##### + =============================================================================== + [..] + This subsection permit to get in run-time errors of the FLASH peripheral. + +@endverbatim + * @{ + */ + +/** + * @brief Get the specific FLASH error flag. + * @retval FLASH_ErrorCode The returned value can be: + * @ref FLASH_Error_Codes + */ +uint32_t HAL_FLASH_GetError(void) +{ + return pFlash.ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup FLASH_Private_Functions + * @{ + */ + +/** + * @brief Program a half-word (16-bit) at a specified address. + * @param Address specify the address to be programmed. + * @param Data specify the data to be programmed. + * @retval None + */ +static void FLASH_Program_HalfWord(uint32_t Address, uint16_t Data) +{ + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* Proceed to program the new data */ + SET_BIT(FLASH->CR, FLASH_CR_PG); + + /* Write data in the address */ + *(__IO uint16_t*)Address = Data; +} + +/** + * @brief Wait for a FLASH operation to complete. + * @param Timeout maximum flash operation timeout + * @retval HAL Status + */ +HAL_StatusTypeDef FLASH_WaitForLastOperation(uint32_t Timeout) +{ + /* Wait for the FLASH operation to complete by polling on BUSY flag to be reset. + Even if the FLASH operation fails, the BUSY flag will be reset and an error + flag will be set */ + + uint32_t tickstart = HAL_GetTick(); + + while(__HAL_FLASH_GET_FLAG(FLASH_FLAG_BSY)) + { + if (Timeout != HAL_MAX_DELAY) + { + if((Timeout == 0U) || ((HAL_GetTick()-tickstart) > Timeout)) + { + return HAL_TIMEOUT; + } + } + } + + /* Check FLASH End of Operation flag */ + if (__HAL_FLASH_GET_FLAG(FLASH_FLAG_EOP)) + { + /* Clear FLASH End of Operation pending bit */ + __HAL_FLASH_CLEAR_FLAG(FLASH_FLAG_EOP); + } + + if(__HAL_FLASH_GET_FLAG(FLASH_FLAG_WRPERR) || + __HAL_FLASH_GET_FLAG(FLASH_FLAG_PGERR)) + { + /*Save the error code*/ + FLASH_SetErrorCode(); + return HAL_ERROR; + } + + /* There is no error flag set */ + return HAL_OK; +} + + +/** + * @brief Set the specific FLASH error flag. + * @retval None + */ +static void FLASH_SetErrorCode(void) +{ + uint32_t flags = 0U; + + if(__HAL_FLASH_GET_FLAG(FLASH_FLAG_WRPERR)) + { + pFlash.ErrorCode |= HAL_FLASH_ERROR_WRP; + flags |= FLASH_FLAG_WRPERR; + } + if(__HAL_FLASH_GET_FLAG(FLASH_FLAG_PGERR)) + { + pFlash.ErrorCode |= HAL_FLASH_ERROR_PROG; + flags |= FLASH_FLAG_PGERR; + } + /* Clear FLASH error pending bits */ + __HAL_FLASH_CLEAR_FLAG(flags); +} +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_FLASH_MODULE_ENABLED */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash_ex.c new file mode 100644 index 0000000..8db75e8 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_flash_ex.c @@ -0,0 +1,984 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_flash_ex.c + * @author MCD Application Team + * @brief Extended FLASH HAL module driver. + * + * This file provides firmware functions to manage the following + * functionalities of the FLASH peripheral: + * + Extended Initialization/de-initialization functions + * + Extended I/O operation functions + * + Extended Peripheral Control functions + * + @verbatim + ============================================================================== + ##### Flash peripheral extended features ##### + ============================================================================== + + ##### How to use this driver ##### + ============================================================================== + [..] This driver provides functions to configure and program the FLASH memory + of all STM32F0xxx devices. It includes + + (++) Set/Reset the write protection + (++) Program the user Option Bytes + (++) Get the Read protection Level + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ +#ifdef HAL_FLASH_MODULE_ENABLED + +/** @addtogroup FLASH + * @{ + */ +/** @addtogroup FLASH_Private_Variables + * @{ + */ +/* Variables used for Erase pages under interruption*/ +extern FLASH_ProcessTypeDef pFlash; +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup FLASHEx FLASHEx + * @brief FLASH HAL Extension module driver + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup FLASHEx_Private_Constants FLASHEx Private Constants + * @{ + */ +#define FLASH_POSITION_IWDGSW_BIT 8U +#define FLASH_POSITION_OB_USERDATA0_BIT 16U +#define FLASH_POSITION_OB_USERDATA1_BIT 24U +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/** @defgroup FLASHEx_Private_Macros FLASHEx Private Macros + * @{ + */ +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup FLASHEx_Private_Functions FLASHEx Private Functions + * @{ + */ +/* Erase operations */ +static void FLASH_MassErase(void); +void FLASH_PageErase(uint32_t PageAddress); + +/* Option bytes control */ +static HAL_StatusTypeDef FLASH_OB_EnableWRP(uint32_t WriteProtectPage); +static HAL_StatusTypeDef FLASH_OB_DisableWRP(uint32_t WriteProtectPage); +static HAL_StatusTypeDef FLASH_OB_RDP_LevelConfig(uint8_t ReadProtectLevel); +static HAL_StatusTypeDef FLASH_OB_UserConfig(uint8_t UserConfig); +static HAL_StatusTypeDef FLASH_OB_ProgramData(uint32_t Address, uint8_t Data); +static uint32_t FLASH_OB_GetWRP(void); +static uint32_t FLASH_OB_GetRDP(void); +static uint8_t FLASH_OB_GetUser(void); + +/** + * @} + */ + +/* Exported functions ---------------------------------------------------------*/ +/** @defgroup FLASHEx_Exported_Functions FLASHEx Exported Functions + * @{ + */ + +/** @defgroup FLASHEx_Exported_Functions_Group1 FLASHEx Memory Erasing functions + * @brief FLASH Memory Erasing functions + * +@verbatim + ============================================================================== + ##### FLASH Erasing Programming functions ##### + ============================================================================== + + [..] The FLASH Memory Erasing functions, includes the following functions: + (+) HAL_FLASHEx_Erase: return only when erase has been done + (+) HAL_FLASHEx_Erase_IT: end of erase is done when HAL_FLASH_EndOfOperationCallback + is called with parameter 0xFFFFFFFF + + [..] Any operation of erase should follow these steps: + (#) Call the HAL_FLASH_Unlock() function to enable the flash control register and + program memory access. + (#) Call the desired function to erase page. + (#) Call the HAL_FLASH_Lock() to disable the flash program memory access + (recommended to protect the FLASH memory against possible unwanted operation). + +@endverbatim + * @{ + */ + + +/** + * @brief Perform a mass erase or erase the specified FLASH memory pages + * @note To correctly run this function, the @ref HAL_FLASH_Unlock() function + * must be called before. + * Call the @ref HAL_FLASH_Lock() to disable the flash memory access + * (recommended to protect the FLASH memory against possible unwanted operation) + * @param[in] pEraseInit pointer to an FLASH_EraseInitTypeDef structure that + * contains the configuration information for the erasing. + * + * @param[out] PageError pointer to variable that + * contains the configuration information on faulty page in case of error + * (0xFFFFFFFF means that all the pages have been correctly erased) + * + * @retval HAL_StatusTypeDef HAL Status + */ +HAL_StatusTypeDef HAL_FLASHEx_Erase(FLASH_EraseInitTypeDef *pEraseInit, uint32_t *PageError) +{ + HAL_StatusTypeDef status = HAL_ERROR; + uint32_t address = 0U; + + /* Process Locked */ + __HAL_LOCK(&pFlash); + + /* Check the parameters */ + assert_param(IS_FLASH_TYPEERASE(pEraseInit->TypeErase)); + + if (pEraseInit->TypeErase == FLASH_TYPEERASE_MASSERASE) + { + /* Mass Erase requested for Bank1 */ + /* Wait for last operation to be completed */ + if (FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE) == HAL_OK) + { + /*Mass erase to be done*/ + FLASH_MassErase(); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + /* If the erase operation is completed, disable the MER Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_MER); + } + } + else + { + /* Page Erase is requested */ + /* Check the parameters */ + assert_param(IS_FLASH_PROGRAM_ADDRESS(pEraseInit->PageAddress)); + assert_param(IS_FLASH_NB_PAGES(pEraseInit->PageAddress, pEraseInit->NbPages)); + + /* Page Erase requested on address located on bank1 */ + /* Wait for last operation to be completed */ + if (FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE) == HAL_OK) + { + /*Initialization of PageError variable*/ + *PageError = 0xFFFFFFFFU; + + /* Erase page by page to be done*/ + for(address = pEraseInit->PageAddress; + address < ((pEraseInit->NbPages * FLASH_PAGE_SIZE) + pEraseInit->PageAddress); + address += FLASH_PAGE_SIZE) + { + FLASH_PageErase(address); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + /* If the erase operation is completed, disable the PER Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_PER); + + if (status != HAL_OK) + { + /* In case of error, stop erase procedure and return the faulty address */ + *PageError = address; + break; + } + } + } + } + + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + + return status; +} + +/** + * @brief Perform a mass erase or erase the specified FLASH memory pages with interrupt enabled + * @note To correctly run this function, the @ref HAL_FLASH_Unlock() function + * must be called before. + * Call the @ref HAL_FLASH_Lock() to disable the flash memory access + * (recommended to protect the FLASH memory against possible unwanted operation) + * @param pEraseInit pointer to an FLASH_EraseInitTypeDef structure that + * contains the configuration information for the erasing. + * + * @retval HAL_StatusTypeDef HAL Status + */ +HAL_StatusTypeDef HAL_FLASHEx_Erase_IT(FLASH_EraseInitTypeDef *pEraseInit) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process Locked */ + __HAL_LOCK(&pFlash); + + /* If procedure already ongoing, reject the next one */ + if (pFlash.ProcedureOnGoing != FLASH_PROC_NONE) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_FLASH_TYPEERASE(pEraseInit->TypeErase)); + + /* Enable End of FLASH Operation and Error source interrupts */ + __HAL_FLASH_ENABLE_IT(FLASH_IT_EOP | FLASH_IT_ERR); + + if (pEraseInit->TypeErase == FLASH_TYPEERASE_MASSERASE) + { + /*Mass erase to be done*/ + pFlash.ProcedureOnGoing = FLASH_PROC_MASSERASE; + FLASH_MassErase(); + } + else + { + /* Erase by page to be done*/ + + /* Check the parameters */ + assert_param(IS_FLASH_PROGRAM_ADDRESS(pEraseInit->PageAddress)); + assert_param(IS_FLASH_NB_PAGES(pEraseInit->PageAddress, pEraseInit->NbPages)); + + pFlash.ProcedureOnGoing = FLASH_PROC_PAGEERASE; + pFlash.DataRemaining = pEraseInit->NbPages; + pFlash.Address = pEraseInit->PageAddress; + + /*Erase 1st page and wait for IT*/ + FLASH_PageErase(pEraseInit->PageAddress); + } + + return status; +} + +/** + * @} + */ + +/** @defgroup FLASHEx_Exported_Functions_Group2 Option Bytes Programming functions + * @brief Option Bytes Programming functions + * +@verbatim + ============================================================================== + ##### Option Bytes Programming functions ##### + ============================================================================== + [..] + This subsection provides a set of functions allowing to control the FLASH + option bytes operations. + +@endverbatim + * @{ + */ + +/** + * @brief Erases the FLASH option bytes. + * @note This functions erases all option bytes except the Read protection (RDP). + * The function @ref HAL_FLASH_Unlock() should be called before to unlock the FLASH interface + * The function @ref HAL_FLASH_OB_Unlock() should be called before to unlock the options bytes + * The function @ref HAL_FLASH_OB_Launch() should be called after to force the reload of the options bytes + * (system reset will occur) + * @retval HAL status + */ + +HAL_StatusTypeDef HAL_FLASHEx_OBErase(void) +{ + uint8_t rdptmp = OB_RDP_LEVEL_0; + HAL_StatusTypeDef status = HAL_ERROR; + + /* Get the actual read protection Option Byte value */ + rdptmp = FLASH_OB_GetRDP(); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + if(status == HAL_OK) + { + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* If the previous operation is completed, proceed to erase the option bytes */ + SET_BIT(FLASH->CR, FLASH_CR_OPTER); + SET_BIT(FLASH->CR, FLASH_CR_STRT); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + /* If the erase operation is completed, disable the OPTER Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTER); + + if(status == HAL_OK) + { + /* Restore the last read protection Option Byte value */ + status = FLASH_OB_RDP_LevelConfig(rdptmp); + } + } + + /* Return the erase status */ + return status; +} + +/** + * @brief Program option bytes + * @note The function @ref HAL_FLASH_Unlock() should be called before to unlock the FLASH interface + * The function @ref HAL_FLASH_OB_Unlock() should be called before to unlock the options bytes + * The function @ref HAL_FLASH_OB_Launch() should be called after to force the reload of the options bytes + * (system reset will occur) + * + * @param pOBInit pointer to an FLASH_OBInitStruct structure that + * contains the configuration information for the programming. + * + * @retval HAL_StatusTypeDef HAL Status + */ +HAL_StatusTypeDef HAL_FLASHEx_OBProgram(FLASH_OBProgramInitTypeDef *pOBInit) +{ + HAL_StatusTypeDef status = HAL_ERROR; + + /* Process Locked */ + __HAL_LOCK(&pFlash); + + /* Check the parameters */ + assert_param(IS_OPTIONBYTE(pOBInit->OptionType)); + + /* Write protection configuration */ + if((pOBInit->OptionType & OPTIONBYTE_WRP) == OPTIONBYTE_WRP) + { + assert_param(IS_WRPSTATE(pOBInit->WRPState)); + if (pOBInit->WRPState == OB_WRPSTATE_ENABLE) + { + /* Enable of Write protection on the selected page */ + status = FLASH_OB_EnableWRP(pOBInit->WRPPage); + } + else + { + /* Disable of Write protection on the selected page */ + status = FLASH_OB_DisableWRP(pOBInit->WRPPage); + } + if (status != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + return status; + } + } + + /* Read protection configuration */ + if((pOBInit->OptionType & OPTIONBYTE_RDP) == OPTIONBYTE_RDP) + { + status = FLASH_OB_RDP_LevelConfig(pOBInit->RDPLevel); + if (status != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + return status; + } + } + + /* USER configuration */ + if((pOBInit->OptionType & OPTIONBYTE_USER) == OPTIONBYTE_USER) + { + status = FLASH_OB_UserConfig(pOBInit->USERConfig); + if (status != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + return status; + } + } + + /* DATA configuration*/ + if((pOBInit->OptionType & OPTIONBYTE_DATA) == OPTIONBYTE_DATA) + { + status = FLASH_OB_ProgramData(pOBInit->DATAAddress, pOBInit->DATAData); + if (status != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + return status; + } + } + + /* Process Unlocked */ + __HAL_UNLOCK(&pFlash); + + return status; +} + +/** + * @brief Get the Option byte configuration + * @param pOBInit pointer to an FLASH_OBInitStruct structure that + * contains the configuration information for the programming. + * + * @retval None + */ +void HAL_FLASHEx_OBGetConfig(FLASH_OBProgramInitTypeDef *pOBInit) +{ + pOBInit->OptionType = OPTIONBYTE_WRP | OPTIONBYTE_RDP | OPTIONBYTE_USER; + + /*Get WRP*/ + pOBInit->WRPPage = FLASH_OB_GetWRP(); + + /*Get RDP Level*/ + pOBInit->RDPLevel = FLASH_OB_GetRDP(); + + /*Get USER*/ + pOBInit->USERConfig = FLASH_OB_GetUser(); +} + +/** + * @brief Get the Option byte user data + * @param DATAAdress Address of the option byte DATA + * This parameter can be one of the following values: + * @arg @ref OB_DATA_ADDRESS_DATA0 + * @arg @ref OB_DATA_ADDRESS_DATA1 + * @retval Value programmed in USER data + */ +uint32_t HAL_FLASHEx_OBGetUserData(uint32_t DATAAdress) +{ + uint32_t value = 0U; + + if (DATAAdress == OB_DATA_ADDRESS_DATA0) + { + /* Get value programmed in OB USER Data0 */ + value = READ_BIT(FLASH->OBR, FLASH_OBR_DATA0) >> FLASH_POSITION_OB_USERDATA0_BIT; + } + else + { + /* Get value programmed in OB USER Data1 */ + value = READ_BIT(FLASH->OBR, FLASH_OBR_DATA1) >> FLASH_POSITION_OB_USERDATA1_BIT; + } + + return value; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup FLASHEx_Private_Functions + * @{ + */ + +/** + * @brief Full erase of FLASH memory Bank + * + * @retval None + */ +static void FLASH_MassErase(void) +{ + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* Only bank1 will be erased*/ + SET_BIT(FLASH->CR, FLASH_CR_MER); + SET_BIT(FLASH->CR, FLASH_CR_STRT); +} + +/** + * @brief Enable the write protection of the desired pages + * @note An option byte erase is done automatically in this function. + * @note When the memory read protection level is selected (RDP level = 1), + * it is not possible to program or erase the flash page i if + * debug features are connected or boot code is executed in RAM, even if nWRPi = 1 + * + * @param WriteProtectPage specifies the page(s) to be write protected. + * The value of this parameter depend on device used within the same series + * @retval HAL status + */ +static HAL_StatusTypeDef FLASH_OB_EnableWRP(uint32_t WriteProtectPage) +{ + HAL_StatusTypeDef status = HAL_OK; + uint16_t WRP0_Data = 0xFFFFU; +#if defined(OB_WRP1_WRP1) + uint16_t WRP1_Data = 0xFFFFU; +#endif /* OB_WRP1_WRP1 */ +#if defined(OB_WRP2_WRP2) + uint16_t WRP2_Data = 0xFFFFU; +#endif /* OB_WRP2_WRP2 */ +#if defined(OB_WRP3_WRP3) + uint16_t WRP3_Data = 0xFFFFU; +#endif /* OB_WRP3_WRP3 */ + + /* Check the parameters */ + assert_param(IS_OB_WRP(WriteProtectPage)); + + /* Get current write protected pages and the new pages to be protected ******/ + WriteProtectPage = (uint32_t)(~((~FLASH_OB_GetWRP()) | WriteProtectPage)); + +#if defined(OB_WRP_PAGES0TO15MASK) + WRP0_Data = (uint16_t)(WriteProtectPage & OB_WRP_PAGES0TO15MASK); +#elif defined(OB_WRP_PAGES0TO31MASK) + WRP0_Data = (uint16_t)(WriteProtectPage & OB_WRP_PAGES0TO31MASK); +#endif /* OB_WRP_PAGES0TO31MASK */ + +#if defined(OB_WRP_PAGES16TO31MASK) + WRP1_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES16TO31MASK) >> 8U); +#elif defined(OB_WRP_PAGES32TO63MASK) + WRP1_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES32TO63MASK) >> 8U); +#endif /* OB_WRP_PAGES32TO63MASK */ + +#if defined(OB_WRP_PAGES32TO47MASK) + WRP2_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES32TO47MASK) >> 16U); +#endif /* OB_WRP_PAGES32TO47MASK */ + +#if defined(OB_WRP_PAGES48TO63MASK) + WRP3_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES48TO63MASK) >> 24U); +#elif defined(OB_WRP_PAGES48TO127MASK) + WRP3_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES48TO127MASK) >> 24U); +#endif /* OB_WRP_PAGES48TO63MASK */ + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + if(status == HAL_OK) + { + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* To be able to write again option byte, need to perform a option byte erase */ + status = HAL_FLASHEx_OBErase(); + if (status == HAL_OK) + { + /* Enable write protection */ + SET_BIT(FLASH->CR, FLASH_CR_OPTPG); + +#if defined(OB_WRP0_WRP0) + if(WRP0_Data != 0xFFU) + { + OB->WRP0 &= WRP0_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP0_WRP0 */ + +#if defined(OB_WRP1_WRP1) + if((status == HAL_OK) && (WRP1_Data != 0xFFU)) + { + OB->WRP1 &= WRP1_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP1_WRP1 */ + +#if defined(OB_WRP2_WRP2) + if((status == HAL_OK) && (WRP2_Data != 0xFFU)) + { + OB->WRP2 &= WRP2_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP2_WRP2 */ + +#if defined(OB_WRP3_WRP3) + if((status == HAL_OK) && (WRP3_Data != 0xFFU)) + { + OB->WRP3 &= WRP3_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP3_WRP3 */ + + /* if the program operation is completed, disable the OPTPG Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTPG); + } + } + + return status; +} + +/** + * @brief Disable the write protection of the desired pages + * @note An option byte erase is done automatically in this function. + * @note When the memory read protection level is selected (RDP level = 1), + * it is not possible to program or erase the flash page i if + * debug features are connected or boot code is executed in RAM, even if nWRPi = 1 + * + * @param WriteProtectPage specifies the page(s) to be write unprotected. + * The value of this parameter depend on device used within the same series + * @retval HAL status + */ +static HAL_StatusTypeDef FLASH_OB_DisableWRP(uint32_t WriteProtectPage) +{ + HAL_StatusTypeDef status = HAL_OK; + uint16_t WRP0_Data = 0xFFFFU; +#if defined(OB_WRP1_WRP1) + uint16_t WRP1_Data = 0xFFFFU; +#endif /* OB_WRP1_WRP1 */ +#if defined(OB_WRP2_WRP2) + uint16_t WRP2_Data = 0xFFFFU; +#endif /* OB_WRP2_WRP2 */ +#if defined(OB_WRP3_WRP3) + uint16_t WRP3_Data = 0xFFFFU; +#endif /* OB_WRP3_WRP3 */ + + /* Check the parameters */ + assert_param(IS_OB_WRP(WriteProtectPage)); + + /* Get current write protected pages and the new pages to be unprotected ******/ + WriteProtectPage = (FLASH_OB_GetWRP() | WriteProtectPage); + +#if defined(OB_WRP_PAGES0TO15MASK) + WRP0_Data = (uint16_t)(WriteProtectPage & OB_WRP_PAGES0TO15MASK); +#elif defined(OB_WRP_PAGES0TO31MASK) + WRP0_Data = (uint16_t)(WriteProtectPage & OB_WRP_PAGES0TO31MASK); +#endif /* OB_WRP_PAGES0TO31MASK */ + +#if defined(OB_WRP_PAGES16TO31MASK) + WRP1_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES16TO31MASK) >> 8U); +#elif defined(OB_WRP_PAGES32TO63MASK) + WRP1_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES32TO63MASK) >> 8U); +#endif /* OB_WRP_PAGES32TO63MASK */ + +#if defined(OB_WRP_PAGES32TO47MASK) + WRP2_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES32TO47MASK) >> 16U); +#endif /* OB_WRP_PAGES32TO47MASK */ + +#if defined(OB_WRP_PAGES48TO63MASK) + WRP3_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES48TO63MASK) >> 24U); +#elif defined(OB_WRP_PAGES48TO127MASK) + WRP3_Data = (uint16_t)((WriteProtectPage & OB_WRP_PAGES48TO127MASK) >> 24U); +#endif /* OB_WRP_PAGES48TO63MASK */ + + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + if(status == HAL_OK) + { + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* To be able to write again option byte, need to perform a option byte erase */ + status = HAL_FLASHEx_OBErase(); + if (status == HAL_OK) + { + SET_BIT(FLASH->CR, FLASH_CR_OPTPG); + +#if defined(OB_WRP0_WRP0) + if(WRP0_Data != 0xFFU) + { + OB->WRP0 &= WRP0_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP0_WRP0 */ + +#if defined(OB_WRP1_WRP1) + if((status == HAL_OK) && (WRP1_Data != 0xFFU)) + { + OB->WRP1 &= WRP1_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP1_WRP1 */ + +#if defined(OB_WRP2_WRP2) + if((status == HAL_OK) && (WRP2_Data != 0xFFU)) + { + OB->WRP2 &= WRP2_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP2_WRP2 */ + +#if defined(OB_WRP3_WRP3) + if((status == HAL_OK) && (WRP3_Data != 0xFFU)) + { + OB->WRP3 &= WRP3_Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + } +#endif /* OB_WRP3_WRP3 */ + + /* if the program operation is completed, disable the OPTPG Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTPG); + } + } + return status; +} + +/** + * @brief Set the read protection level. + * @param ReadProtectLevel specifies the read protection level. + * This parameter can be one of the following values: + * @arg @ref OB_RDP_LEVEL_0 No protection + * @arg @ref OB_RDP_LEVEL_1 Read protection of the memory + * @arg @ref OB_RDP_LEVEL_2 Full chip protection + * @note Warning: When enabling OB_RDP level 2 it's no more possible to go back to level 1 or 0 + * @retval HAL status + */ +static HAL_StatusTypeDef FLASH_OB_RDP_LevelConfig(uint8_t ReadProtectLevel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_OB_RDP_LEVEL(ReadProtectLevel)); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + if(status == HAL_OK) + { + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* If the previous operation is completed, proceed to erase the option bytes */ + SET_BIT(FLASH->CR, FLASH_CR_OPTER); + SET_BIT(FLASH->CR, FLASH_CR_STRT); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + /* If the erase operation is completed, disable the OPTER Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTER); + + if(status == HAL_OK) + { + /* Enable the Option Bytes Programming operation */ + SET_BIT(FLASH->CR, FLASH_CR_OPTPG); + + WRITE_REG(OB->RDP, ReadProtectLevel); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + /* if the program operation is completed, disable the OPTPG Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTPG); + } + } + + return status; +} + +/** + * @brief Program the FLASH User Option Byte. + * @note Programming of the OB should be performed only after an erase (otherwise PGERR occurs) + * @param UserConfig The FLASH User Option Bytes values: IWDG_SW(Bit0), RST_STOP(Bit1), RST_STDBY(Bit2), nBOOT1(Bit4), + * VDDA_Analog_Monitoring(Bit5) and SRAM_Parity_Enable(Bit6). + * For few devices, following option bytes are available: nBOOT0(Bit3) & BOOT_SEL(Bit7). + * @retval HAL status + */ +static HAL_StatusTypeDef FLASH_OB_UserConfig(uint8_t UserConfig) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_OB_IWDG_SOURCE((UserConfig&OB_IWDG_SW))); + assert_param(IS_OB_STOP_SOURCE((UserConfig&OB_STOP_NO_RST))); + assert_param(IS_OB_STDBY_SOURCE((UserConfig&OB_STDBY_NO_RST))); + assert_param(IS_OB_BOOT1((UserConfig&OB_BOOT1_SET))); + assert_param(IS_OB_VDDA_ANALOG((UserConfig&OB_VDDA_ANALOG_ON))); + assert_param(IS_OB_SRAM_PARITY((UserConfig&OB_SRAM_PARITY_RESET))); +#if defined(FLASH_OBR_BOOT_SEL) + assert_param(IS_OB_BOOT_SEL((UserConfig&OB_BOOT_SEL_SET))); + assert_param(IS_OB_BOOT0((UserConfig&OB_BOOT0_SET))); +#endif /* FLASH_OBR_BOOT_SEL */ + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + if(status == HAL_OK) + { + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* Enable the Option Bytes Programming operation */ + SET_BIT(FLASH->CR, FLASH_CR_OPTPG); + +#if defined(FLASH_OBR_BOOT_SEL) + OB->USER = UserConfig; +#else + OB->USER = (UserConfig | 0x88U); +#endif + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + /* if the program operation is completed, disable the OPTPG Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTPG); + } + + return status; +} + +/** + * @brief Programs a half word at a specified Option Byte Data address. + * @note The function @ref HAL_FLASH_Unlock() should be called before to unlock the FLASH interface + * The function @ref HAL_FLASH_OB_Unlock() should be called before to unlock the options bytes + * The function @ref HAL_FLASH_OB_Launch() should be called after to force the reload of the options bytes + * (system reset will occur) + * Programming of the OB should be performed only after an erase (otherwise PGERR occurs) + * @param Address specifies the address to be programmed. + * This parameter can be 0x1FFFF804 or 0x1FFFF806. + * @param Data specifies the data to be programmed. + * @retval HAL status + */ +static HAL_StatusTypeDef FLASH_OB_ProgramData(uint32_t Address, uint8_t Data) +{ + HAL_StatusTypeDef status = HAL_ERROR; + + /* Check the parameters */ + assert_param(IS_OB_DATA_ADDRESS(Address)); + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + if(status == HAL_OK) + { + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* Enables the Option Bytes Programming operation */ + SET_BIT(FLASH->CR, FLASH_CR_OPTPG); + *(__IO uint16_t*)Address = Data; + + /* Wait for last operation to be completed */ + status = FLASH_WaitForLastOperation((uint32_t)FLASH_TIMEOUT_VALUE); + + /* If the program operation is completed, disable the OPTPG Bit */ + CLEAR_BIT(FLASH->CR, FLASH_CR_OPTPG); + } + /* Return the Option Byte Data Program Status */ + return status; +} + +/** + * @brief Return the FLASH Write Protection Option Bytes value. + * @retval The FLASH Write Protection Option Bytes value + */ +static uint32_t FLASH_OB_GetWRP(void) +{ + /* Return the FLASH write protection Register value */ + return (uint32_t)(READ_REG(FLASH->WRPR)); +} + +/** + * @brief Returns the FLASH Read Protection level. + * @retval FLASH RDP level + * This parameter can be one of the following values: + * @arg @ref OB_RDP_LEVEL_0 No protection + * @arg @ref OB_RDP_LEVEL_1 Read protection of the memory + * @arg @ref OB_RDP_LEVEL_2 Full chip protection + */ +static uint32_t FLASH_OB_GetRDP(void) +{ + uint32_t tmp_reg; + + /* Read RDP level bits */ + tmp_reg = READ_BIT(FLASH->OBR, (FLASH_OBR_RDPRT1 | FLASH_OBR_RDPRT2)); + + if (tmp_reg == 0U) + { + return OB_RDP_LEVEL_0; + } + else if ((tmp_reg & FLASH_OBR_RDPRT2) == FLASH_OBR_RDPRT2) + { + return OB_RDP_LEVEL_2; + } + else + { + return OB_RDP_LEVEL_1; + } +} + +/** + * @brief Return the FLASH User Option Byte value. + * @retval The FLASH User Option Bytes values: IWDG_SW(Bit0), RST_STOP(Bit1), RST_STDBY(Bit2), nBOOT1(Bit4), + * VDDA_Analog_Monitoring(Bit5) and SRAM_Parity_Enable(Bit6). + * For few devices, following option bytes are available: nBOOT0(Bit3) & BOOT_SEL(Bit7). + */ +static uint8_t FLASH_OB_GetUser(void) +{ + /* Return the User Option Byte */ + return (uint8_t)((READ_REG(FLASH->OBR) & FLASH_OBR_USER) >> FLASH_POSITION_IWDGSW_BIT); +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup FLASH + * @{ + */ + +/** @addtogroup FLASH_Private_Functions + * @{ + */ + +/** + * @brief Erase the specified FLASH memory page + * @param PageAddress FLASH page to erase + * The value of this parameter depend on device used within the same series + * + * @retval None + */ +void FLASH_PageErase(uint32_t PageAddress) +{ + /* Clean the error context */ + pFlash.ErrorCode = HAL_FLASH_ERROR_NONE; + + /* Proceed to erase the page */ + SET_BIT(FLASH->CR, FLASH_CR_PER); + WRITE_REG(FLASH->AR, PageAddress); + SET_BIT(FLASH->CR, FLASH_CR_STRT); +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_FLASH_MODULE_ENABLED */ +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_gpio.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_gpio.c new file mode 100644 index 0000000..a030bef --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_gpio.c @@ -0,0 +1,540 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_gpio.c + * @author MCD Application Team + * @brief GPIO HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the General Purpose Input/Output (GPIO) peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + @verbatim + ============================================================================== + ##### GPIO Peripheral features ##### + ============================================================================== + [..] + (+) Each port bit of the general-purpose I/O (GPIO) ports can be individually + configured by software in several modes: + (++) Input mode + (++) Analog mode + (++) Output mode + (++) Alternate function mode + (++) External interrupt/event lines + + (+) During and just after reset, the alternate functions and external interrupt + lines are not active and the I/O ports are configured in input floating mode. + + (+) All GPIO pins have weak internal pull-up and pull-down resistors, which can be + activated or not. + + (+) In Output or Alternate mode, each IO can be configured on open-drain or push-pull + type and the IO speed can be selected depending on the VDD value. + + (+) The microcontroller IO pins are connected to onboard peripherals/modules through a + multiplexer that allows only one peripheral alternate function (AF) connected + to an IO pin at a time. In this way, there can be no conflict between peripherals + sharing the same IO pin. + + (+) All ports have external interrupt/event capability. To use external interrupt + lines, the port must be configured in input mode. All available GPIO pins are + connected to the 16 external interrupt/event lines from EXTI0 to EXTI15. + + (+) The external interrupt/event controller consists of up to 28 edge detectors + (16 lines are connected to GPIO) for generating event/interrupt requests (each + input line can be independently configured to select the type (interrupt or event) + and the corresponding trigger event (rising or falling or both). Each line can + also be masked independently. + + ##### How to use this driver ##### + ============================================================================== + [..] + (#) Enable the GPIO AHB clock using the following function : __HAL_RCC_GPIOx_CLK_ENABLE(). + + (#) Configure the GPIO pin(s) using HAL_GPIO_Init(). + (++) Configure the IO mode using "Mode" member from GPIO_InitTypeDef structure + (++) Activate Pull-up, Pull-down resistor using "Pull" member from GPIO_InitTypeDef + structure. + (++) In case of Output or alternate function mode selection: the speed is + configured through "Speed" member from GPIO_InitTypeDef structure. + (++) In alternate mode is selection, the alternate function connected to the IO + is configured through "Alternate" member from GPIO_InitTypeDef structure. + (++) Analog mode is required when a pin is to be used as ADC channel + or DAC output. + (++) In case of external interrupt/event selection the "Mode" member from + GPIO_InitTypeDef structure select the type (interrupt or event) and + the corresponding trigger event (rising or falling or both). + + (#) In case of external interrupt/event mode selection, configure NVIC IRQ priority + mapped to the EXTI line using HAL_NVIC_SetPriority() and enable it using + HAL_NVIC_EnableIRQ(). + + (#) HAL_GPIO_DeInit allows to set register values to their reset value. It's also + recommended to use it to unconfigure pin which was used as an external interrupt + or in event mode. That's the only way to reset corresponding bit in EXTI & SYSCFG + registers. + + (#) To get the level of a pin configured in input mode use HAL_GPIO_ReadPin(). + + (#) To set/reset the level of a pin configured in output mode use + HAL_GPIO_WritePin()/HAL_GPIO_TogglePin(). + + (#) To lock pin configuration until next reset use HAL_GPIO_LockPin(). + + (#) During and just after reset, the alternate functions are not + active and the GPIO pins are configured in input floating mode (except JTAG + pins). + + (#) The LSE oscillator pins OSC32_IN and OSC32_OUT can be used as general purpose + (PC14 and PC15, respectively) when the LSE oscillator is off. The LSE has + priority over the GPIO function. + + (#) The HSE oscillator pins OSC_IN/OSC_OUT can be used as + general purpose PF0 and PF1, respectively, when the HSE oscillator is off. + The HSE has priority over the GPIO function. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup GPIO GPIO + * @brief GPIO HAL module driver + * @{ + */ + +/** MISRA C:2012 deviation rule has been granted for following rules: + * Rule-18.1_d - Medium: Array pointer `GPIOx' is accessed with index [..,..] + * which may be out of array bounds [..,UNKNOWN] in following APIs: + * HAL_GPIO_Init + * HAL_GPIO_DeInit + */ + +#ifdef HAL_GPIO_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private defines -----------------------------------------------------------*/ +/** @addtogroup GPIO_Private_Constants GPIO Private Constants + * @{ + */ +#define GPIO_NUMBER 16U +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup GPIO_Exported_Functions GPIO Exported Functions + * @{ + */ + +/** @defgroup GPIO_Exported_Functions_Group1 Initialization/de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the GPIOx peripheral according to the specified parameters in the GPIO_Init. + * @param GPIOx where x can be (A..F) to select the GPIO peripheral for STM32F0 family + * @param GPIO_Init pointer to a GPIO_InitTypeDef structure that contains + * the configuration information for the specified GPIO peripheral. + * @retval None + */ +void HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_Init) +{ + uint32_t position = 0x00u; + uint32_t iocurrent; + uint32_t temp; + + /* Check the parameters */ + assert_param(IS_GPIO_ALL_INSTANCE(GPIOx)); + assert_param(IS_GPIO_PIN(GPIO_Init->Pin)); + assert_param(IS_GPIO_MODE(GPIO_Init->Mode)); + + /* Configure the port pins */ + while (((GPIO_Init->Pin) >> position) != 0x00u) + { + /* Get current io position */ + iocurrent = (GPIO_Init->Pin) & (1uL << position); + + if (iocurrent != 0x00u) + { + /*--------------------- GPIO Mode Configuration ------------------------*/ + /* In case of Output or Alternate function mode selection */ + if(((GPIO_Init->Mode & GPIO_MODE) == MODE_OUTPUT) || + ((GPIO_Init->Mode & GPIO_MODE) == MODE_AF)) + { + /* Check the Speed parameter */ + assert_param(IS_GPIO_SPEED(GPIO_Init->Speed)); + /* Configure the IO Speed */ + temp = GPIOx->OSPEEDR; + temp &= ~(GPIO_OSPEEDER_OSPEEDR0 << (position * 2u)); + temp |= (GPIO_Init->Speed << (position * 2u)); + GPIOx->OSPEEDR = temp; + + /* Configure the IO Output Type */ + temp = GPIOx->OTYPER; + temp &= ~(GPIO_OTYPER_OT_0 << position) ; + temp |= (((GPIO_Init->Mode & OUTPUT_TYPE) >> OUTPUT_TYPE_Pos) << position); + GPIOx->OTYPER = temp; + } + + if((GPIO_Init->Mode & GPIO_MODE) != MODE_ANALOG) + { + /* Check the Pull parameter */ + assert_param(IS_GPIO_PULL(GPIO_Init->Pull)); + + /* Activate the Pull-up or Pull down resistor for the current IO */ + temp = GPIOx->PUPDR; + temp &= ~(GPIO_PUPDR_PUPDR0 << (position * 2u)); + temp |= ((GPIO_Init->Pull) << (position * 2u)); + GPIOx->PUPDR = temp; + } + + /* In case of Alternate function mode selection */ + if((GPIO_Init->Mode & GPIO_MODE) == MODE_AF) + { + /* Check the Alternate function parameters */ + assert_param(IS_GPIO_AF_INSTANCE(GPIOx)); + assert_param(IS_GPIO_AF(GPIO_Init->Alternate)); + + /* Configure Alternate function mapped with the current IO */ + temp = GPIOx->AFR[position >> 3u]; + temp &= ~(0xFu << ((position & 0x07u) * 4u)); + temp |= ((GPIO_Init->Alternate) << ((position & 0x07u) * 4u)); + GPIOx->AFR[position >> 3u] = temp; + } + + /* Configure IO Direction mode (Input, Output, Alternate or Analog) */ + temp = GPIOx->MODER; + temp &= ~(GPIO_MODER_MODER0 << (position * 2u)); + temp |= ((GPIO_Init->Mode & GPIO_MODE) << (position * 2u)); + GPIOx->MODER = temp; + + /*--------------------- EXTI Mode Configuration ------------------------*/ + /* Configure the External Interrupt or event for the current IO */ + if((GPIO_Init->Mode & EXTI_MODE) != 0x00u) + { + /* Enable SYSCFG Clock */ + __HAL_RCC_SYSCFG_CLK_ENABLE(); + + temp = SYSCFG->EXTICR[position >> 2u]; + temp &= ~(0x0FuL << (4u * (position & 0x03u))); + temp |= (GPIO_GET_INDEX(GPIOx) << (4u * (position & 0x03u))); + SYSCFG->EXTICR[position >> 2u] = temp; + + /* Clear EXTI line configuration */ + temp = EXTI->IMR; + temp &= ~(iocurrent); + if((GPIO_Init->Mode & EXTI_IT) != 0x00u) + { + temp |= iocurrent; + } + EXTI->IMR = temp; + + temp = EXTI->EMR; + temp &= ~(iocurrent); + if((GPIO_Init->Mode & EXTI_EVT) != 0x00u) + { + temp |= iocurrent; + } + EXTI->EMR = temp; + + /* Clear Rising Falling edge configuration */ + temp = EXTI->RTSR; + temp &= ~(iocurrent); + if((GPIO_Init->Mode & TRIGGER_RISING) != 0x00u) + { + temp |= iocurrent; + } + EXTI->RTSR = temp; + + temp = EXTI->FTSR; + temp &= ~(iocurrent); + if((GPIO_Init->Mode & TRIGGER_FALLING) != 0x00u) + { + temp |= iocurrent; + } + EXTI->FTSR = temp; + } + } + + position++; + } +} + +/** + * @brief De-initialize the GPIOx peripheral registers to their default reset values. + * @param GPIOx where x can be (A..F) to select the GPIO peripheral for STM32F0 family + * @param GPIO_Pin specifies the port bit to be written. + * This parameter can be one of GPIO_PIN_x where x can be (0..15). + * @retval None + */ +void HAL_GPIO_DeInit(GPIO_TypeDef *GPIOx, uint32_t GPIO_Pin) +{ + uint32_t position = 0x00u; + uint32_t iocurrent; + uint32_t tmp; + + /* Check the parameters */ + assert_param(IS_GPIO_ALL_INSTANCE(GPIOx)); + assert_param(IS_GPIO_PIN(GPIO_Pin)); + + /* Configure the port pins */ + while ((GPIO_Pin >> position) != 0x00u) + { + /* Get current io position */ + iocurrent = (GPIO_Pin) & (1uL << position); + + if (iocurrent != 0x00u) + { + /*------------------------- EXTI Mode Configuration --------------------*/ + /* Clear the External Interrupt or Event for the current IO */ + + tmp = SYSCFG->EXTICR[position >> 2u]; + tmp &= (0x0FuL << (4u * (position & 0x03u))); + if (tmp == (GPIO_GET_INDEX(GPIOx) << (4u * (position & 0x03u)))) + { + /* Clear EXTI line configuration */ + EXTI->IMR &= ~((uint32_t)iocurrent); + EXTI->EMR &= ~((uint32_t)iocurrent); + + /* Clear Rising Falling edge configuration */ + EXTI->RTSR &= ~((uint32_t)iocurrent); + EXTI->FTSR &= ~((uint32_t)iocurrent); + + /* Configure the External Interrupt or event for the current IO */ + tmp = 0x0FuL << (4u * (position & 0x03u)); + SYSCFG->EXTICR[position >> 2u] &= ~tmp; + } + + /*------------------------- GPIO Mode Configuration --------------------*/ + /* Configure IO Direction in Input Floating Mode */ + GPIOx->MODER &= ~(GPIO_MODER_MODER0 << (position * 2u)); + + /* Configure the default Alternate Function in current IO */ + GPIOx->AFR[position >> 3u] &= ~(0xFu << ((uint32_t)(position & 0x07u) * 4u)) ; + + /* Deactivate the Pull-up and Pull-down resistor for the current IO */ + GPIOx->PUPDR &= ~(GPIO_PUPDR_PUPDR0 << (position * 2u)); + + /* Configure the default value IO Output Type */ + GPIOx->OTYPER &= ~(GPIO_OTYPER_OT_0 << position) ; + + /* Configure the default value for IO Speed */ + GPIOx->OSPEEDR &= ~(GPIO_OSPEEDER_OSPEEDR0 << (position * 2u)); + + } + + position++; + } +} + +/** + * @} + */ + +/** @defgroup GPIO_Exported_Functions_Group2 IO operation functions + * @brief GPIO Read, Write, Toggle, Lock and EXTI management functions. + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + +@endverbatim + * @{ + */ + +/** + * @brief Read the specified input port pin. + * @param GPIOx where x can be (A..F) to select the GPIO peripheral for STM32F0 family + * @param GPIO_Pin specifies the port bit to read. + * This parameter can be GPIO_PIN_x where x can be (0..15). + * @retval The input port pin value. + */ +GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin) +{ + GPIO_PinState bitstatus; + + /* Check the parameters */ + assert_param(IS_GPIO_PIN(GPIO_Pin)); + + if ((GPIOx->IDR & GPIO_Pin) != (uint32_t)GPIO_PIN_RESET) + { + bitstatus = GPIO_PIN_SET; + } + else + { + bitstatus = GPIO_PIN_RESET; + } + return bitstatus; + } + +/** + * @brief Set or clear the selected data port bit. + * @note This function uses GPIOx_BSRR and GPIOx_BRR registers to allow atomic read/modify + * accesses. In this way, there is no risk of an IRQ occurring between + * the read and the modify access. + * + * @param GPIOx where x can be (A..H) to select the GPIO peripheral for STM32F0 family + * @param GPIO_Pin specifies the port bit to be written. + * This parameter can be one of GPIO_PIN_x where x can be (0..15). + * @param PinState specifies the value to be written to the selected bit. + * This parameter can be one of the GPIO_PinState enum values: + * @arg GPIO_PIN_RESET: to clear the port pin + * @arg GPIO_PIN_SET: to set the port pin + * @retval None + */ +void HAL_GPIO_WritePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState) +{ + /* Check the parameters */ + assert_param(IS_GPIO_PIN(GPIO_Pin)); + assert_param(IS_GPIO_PIN_ACTION(PinState)); + + if (PinState != GPIO_PIN_RESET) + { + GPIOx->BSRR = (uint32_t)GPIO_Pin; + } + else + { + GPIOx->BRR = (uint32_t)GPIO_Pin; + } +} + +/** + * @brief Toggle the specified GPIO pin. + * @param GPIOx where x can be (A..F) to select the GPIO peripheral for STM32F0 family + * @param GPIO_Pin specifies the pin to be toggled. + * @retval None + */ +void HAL_GPIO_TogglePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin) +{ + uint32_t odr; + + /* Check the parameters */ + assert_param(IS_GPIO_PIN(GPIO_Pin)); + + /* get current Ouput Data Register value */ + odr = GPIOx->ODR; + + /* Set selected pins that were at low level, and reset ones that were high */ + GPIOx->BSRR = ((odr & GPIO_Pin) << GPIO_NUMBER) | (~odr & GPIO_Pin); +} + +/** +* @brief Locks GPIO Pins configuration registers. +* @note The locked registers are GPIOx_MODER, GPIOx_OTYPER, GPIOx_OSPEEDR, +* GPIOx_PUPDR, GPIOx_AFRL and GPIOx_AFRH. +* @note The configuration of the locked GPIO pins can no longer be modified +* until the next reset. + * @param GPIOx where x can be (A..F) to select the GPIO peripheral for STM32F0 family + * @param GPIO_Pin specifies the port bits to be locked. +* This parameter can be any combination of GPIO_Pin_x where x can be (0..15). +* @retval None +*/ +HAL_StatusTypeDef HAL_GPIO_LockPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin) +{ + __IO uint32_t tmp = GPIO_LCKR_LCKK; + + /* Check the parameters */ + assert_param(IS_GPIO_LOCK_INSTANCE(GPIOx)); + assert_param(IS_GPIO_PIN(GPIO_Pin)); + + /* Apply lock key write sequence */ + SET_BIT(tmp, GPIO_Pin); + /* Set LCKx bit(s): LCKK='1' + LCK[15-0] */ + GPIOx->LCKR = tmp; + /* Reset LCKx bit(s): LCKK='0' + LCK[15-0] */ + GPIOx->LCKR = GPIO_Pin; + /* Set LCKx bit(s): LCKK='1' + LCK[15-0] */ + GPIOx->LCKR = tmp; + /* Read LCKK register. This read is mandatory to complete key lock sequence */ + tmp = GPIOx->LCKR; + + /* read again in order to confirm lock is active */ + if((GPIOx->LCKR & GPIO_LCKR_LCKK) != 0x00u) + { + return HAL_OK; + } + else + { + return HAL_ERROR; + } +} + +/** + * @brief Handle EXTI interrupt request. + * @param GPIO_Pin Specifies the port pin connected to corresponding EXTI line. + * @retval None + */ +void HAL_GPIO_EXTI_IRQHandler(uint16_t GPIO_Pin) +{ + /* EXTI line interrupt detected */ + if(__HAL_GPIO_EXTI_GET_IT(GPIO_Pin) != 0x00u) + { + __HAL_GPIO_EXTI_CLEAR_IT(GPIO_Pin); + HAL_GPIO_EXTI_Callback(GPIO_Pin); + } +} + +/** + * @brief EXTI line detection callback. + * @param GPIO_Pin Specifies the port pin connected to corresponding EXTI line. + * @retval None + */ +__weak void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(GPIO_Pin); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_GPIO_EXTI_Callback could be implemented in the user file + */ +} + +/** + * @} + */ + + +/** + * @} + */ + +#endif /* HAL_GPIO_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c.c new file mode 100644 index 0000000..95dddec --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c.c @@ -0,0 +1,6794 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_i2c.c + * @author MCD Application Team + * @brief I2C HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Inter Integrated Circuit (I2C) peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral State and Errors functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The I2C HAL driver can be used as follows: + + (#) Declare a I2C_HandleTypeDef handle structure, for example: + I2C_HandleTypeDef hi2c; + + (#)Initialize the I2C low level resources by implementing the HAL_I2C_MspInit() API: + (##) Enable the I2Cx interface clock + (##) I2C pins configuration + (+++) Enable the clock for the I2C GPIOs + (+++) Configure I2C pins as alternate function open-drain + (##) NVIC configuration if you need to use interrupt process + (+++) Configure the I2Cx interrupt priority + (+++) Enable the NVIC I2C IRQ Channel + (##) DMA Configuration if you need to use DMA process + (+++) Declare a DMA_HandleTypeDef handle structure for + the transmit or receive channel + (+++) Enable the DMAx interface clock using + (+++) Configure the DMA handle parameters + (+++) Configure the DMA Tx or Rx channel + (+++) Associate the initialized DMA handle to the hi2c DMA Tx or Rx handle + (+++) Configure the priority and enable the NVIC for the transfer complete interrupt on + the DMA Tx or Rx channel + + (#) Configure the Communication Clock Timing, Own Address1, Master Addressing mode, Dual Addressing mode, + Own Address2, Own Address2 Mask, General call and Nostretch mode in the hi2c Init structure. + + (#) Initialize the I2C registers by calling the HAL_I2C_Init(), configures also the low level Hardware + (GPIO, CLOCK, NVIC...etc) by calling the customized HAL_I2C_MspInit(&hi2c) API. + + (#) To check if target device is ready for communication, use the function HAL_I2C_IsDeviceReady() + + (#) For I2C IO and IO MEM operations, three operation modes are available within this driver : + + *** Polling mode IO operation *** + ================================= + [..] + (+) Transmit in master mode an amount of data in blocking mode using HAL_I2C_Master_Transmit() + (+) Receive in master mode an amount of data in blocking mode using HAL_I2C_Master_Receive() + (+) Transmit in slave mode an amount of data in blocking mode using HAL_I2C_Slave_Transmit() + (+) Receive in slave mode an amount of data in blocking mode using HAL_I2C_Slave_Receive() + + *** Polling mode IO MEM operation *** + ===================================== + [..] + (+) Write an amount of data in blocking mode to a specific memory address using HAL_I2C_Mem_Write() + (+) Read an amount of data in blocking mode from a specific memory address using HAL_I2C_Mem_Read() + + + *** Interrupt mode IO operation *** + =================================== + [..] + (+) Transmit in master mode an amount of data in non-blocking mode using HAL_I2C_Master_Transmit_IT() + (+) At transmission end of transfer, HAL_I2C_MasterTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MasterTxCpltCallback() + (+) Receive in master mode an amount of data in non-blocking mode using HAL_I2C_Master_Receive_IT() + (+) At reception end of transfer, HAL_I2C_MasterRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MasterRxCpltCallback() + (+) Transmit in slave mode an amount of data in non-blocking mode using HAL_I2C_Slave_Transmit_IT() + (+) At transmission end of transfer, HAL_I2C_SlaveTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_SlaveTxCpltCallback() + (+) Receive in slave mode an amount of data in non-blocking mode using HAL_I2C_Slave_Receive_IT() + (+) At reception end of transfer, HAL_I2C_SlaveRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_SlaveRxCpltCallback() + (+) In case of transfer Error, HAL_I2C_ErrorCallback() function is executed and users can + add their own code by customization of function pointer HAL_I2C_ErrorCallback() + (+) Abort a master I2C process communication with Interrupt using HAL_I2C_Master_Abort_IT() + (+) End of abort process, HAL_I2C_AbortCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_AbortCpltCallback() + (+) Discard a slave I2C process communication using __HAL_I2C_GENERATE_NACK() macro. + This action will inform Master to generate a Stop condition to discard the communication. + + + *** Interrupt mode or DMA mode IO sequential operation *** + ========================================================== + [..] + (@) These interfaces allow to manage a sequential transfer with a repeated start condition + when a direction change during transfer + [..] + (+) A specific option field manage the different steps of a sequential transfer + (+) Option field values are defined through I2C_XFEROPTIONS and are listed below: + (++) I2C_FIRST_AND_LAST_FRAME: No sequential usage, functional is same as associated interfaces in + no sequential mode + (++) I2C_FIRST_FRAME: Sequential usage, this option allow to manage a sequence with start condition, address + and data to transfer without a final stop condition + (++) I2C_FIRST_AND_NEXT_FRAME: Sequential usage (Master only), this option allow to manage a sequence with + start condition, address and data to transfer without a final stop condition, + an then permit a call the same master sequential interface several times + (like HAL_I2C_Master_Seq_Transmit_IT() then HAL_I2C_Master_Seq_Transmit_IT() + or HAL_I2C_Master_Seq_Transmit_DMA() then HAL_I2C_Master_Seq_Transmit_DMA()) + (++) I2C_NEXT_FRAME: Sequential usage, this option allow to manage a sequence with a restart condition, address + and with new data to transfer if the direction change or manage only the new data to + transfer + if no direction change and without a final stop condition in both cases + (++) I2C_LAST_FRAME: Sequential usage, this option allow to manage a sequance with a restart condition, address + and with new data to transfer if the direction change or manage only the new data to + transfer + if no direction change and with a final stop condition in both cases + (++) I2C_LAST_FRAME_NO_STOP: Sequential usage (Master only), this option allow to manage a restart condition + after several call of the same master sequential interface several times + (link with option I2C_FIRST_AND_NEXT_FRAME). + Usage can, transfer several bytes one by one using + HAL_I2C_Master_Seq_Transmit_IT + or HAL_I2C_Master_Seq_Receive_IT + or HAL_I2C_Master_Seq_Transmit_DMA + or HAL_I2C_Master_Seq_Receive_DMA + with option I2C_FIRST_AND_NEXT_FRAME then I2C_NEXT_FRAME. + Then usage of this option I2C_LAST_FRAME_NO_STOP at the last Transmit or + Receive sequence permit to call the opposite interface Receive or Transmit + without stopping the communication and so generate a restart condition. + (++) I2C_OTHER_FRAME: Sequential usage (Master only), this option allow to manage a restart condition after + each call of the same master sequential + interface. + Usage can, transfer several bytes one by one with a restart with slave address between + each bytes using + HAL_I2C_Master_Seq_Transmit_IT + or HAL_I2C_Master_Seq_Receive_IT + or HAL_I2C_Master_Seq_Transmit_DMA + or HAL_I2C_Master_Seq_Receive_DMA + with option I2C_FIRST_FRAME then I2C_OTHER_FRAME. + Then usage of this option I2C_OTHER_AND_LAST_FRAME at the last frame to help automatic + generation of STOP condition. + + (+) Different sequential I2C interfaces are listed below: + (++) Sequential transmit in master I2C mode an amount of data in non-blocking mode using + HAL_I2C_Master_Seq_Transmit_IT() or using HAL_I2C_Master_Seq_Transmit_DMA() + (+++) At transmission end of current frame transfer, HAL_I2C_MasterTxCpltCallback() is executed and + users can add their own code by customization of function pointer HAL_I2C_MasterTxCpltCallback() + (++) Sequential receive in master I2C mode an amount of data in non-blocking mode using + HAL_I2C_Master_Seq_Receive_IT() or using HAL_I2C_Master_Seq_Receive_DMA() + (+++) At reception end of current frame transfer, HAL_I2C_MasterRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MasterRxCpltCallback() + (++) Abort a master IT or DMA I2C process communication with Interrupt using HAL_I2C_Master_Abort_IT() + (+++) End of abort process, HAL_I2C_AbortCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_AbortCpltCallback() + (++) Enable/disable the Address listen mode in slave I2C mode using HAL_I2C_EnableListen_IT() + HAL_I2C_DisableListen_IT() + (+++) When address slave I2C match, HAL_I2C_AddrCallback() is executed and users can + add their own code to check the Address Match Code and the transmission direction request by master + (Write/Read). + (+++) At Listen mode end HAL_I2C_ListenCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_ListenCpltCallback() + (++) Sequential transmit in slave I2C mode an amount of data in non-blocking mode using + HAL_I2C_Slave_Seq_Transmit_IT() or using HAL_I2C_Slave_Seq_Transmit_DMA() + (+++) At transmission end of current frame transfer, HAL_I2C_SlaveTxCpltCallback() is executed and + users can add their own code by customization of function pointer HAL_I2C_SlaveTxCpltCallback() + (++) Sequential receive in slave I2C mode an amount of data in non-blocking mode using + HAL_I2C_Slave_Seq_Receive_IT() or using HAL_I2C_Slave_Seq_Receive_DMA() + (+++) At reception end of current frame transfer, HAL_I2C_SlaveRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_SlaveRxCpltCallback() + (++) In case of transfer Error, HAL_I2C_ErrorCallback() function is executed and users can + add their own code by customization of function pointer HAL_I2C_ErrorCallback() + (++) Discard a slave I2C process communication using __HAL_I2C_GENERATE_NACK() macro. + This action will inform Master to generate a Stop condition to discard the communication. + + *** Interrupt mode IO MEM operation *** + ======================================= + [..] + (+) Write an amount of data in non-blocking mode with Interrupt to a specific memory address using + HAL_I2C_Mem_Write_IT() + (+) At Memory end of write transfer, HAL_I2C_MemTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MemTxCpltCallback() + (+) Read an amount of data in non-blocking mode with Interrupt from a specific memory address using + HAL_I2C_Mem_Read_IT() + (+) At Memory end of read transfer, HAL_I2C_MemRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MemRxCpltCallback() + (+) In case of transfer Error, HAL_I2C_ErrorCallback() function is executed and users can + add their own code by customization of function pointer HAL_I2C_ErrorCallback() + + *** DMA mode IO operation *** + ============================== + [..] + (+) Transmit in master mode an amount of data in non-blocking mode (DMA) using + HAL_I2C_Master_Transmit_DMA() + (+) At transmission end of transfer, HAL_I2C_MasterTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MasterTxCpltCallback() + (+) Receive in master mode an amount of data in non-blocking mode (DMA) using + HAL_I2C_Master_Receive_DMA() + (+) At reception end of transfer, HAL_I2C_MasterRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MasterRxCpltCallback() + (+) Transmit in slave mode an amount of data in non-blocking mode (DMA) using + HAL_I2C_Slave_Transmit_DMA() + (+) At transmission end of transfer, HAL_I2C_SlaveTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_SlaveTxCpltCallback() + (+) Receive in slave mode an amount of data in non-blocking mode (DMA) using + HAL_I2C_Slave_Receive_DMA() + (+) At reception end of transfer, HAL_I2C_SlaveRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_SlaveRxCpltCallback() + (+) In case of transfer Error, HAL_I2C_ErrorCallback() function is executed and users can + add their own code by customization of function pointer HAL_I2C_ErrorCallback() + (+) Abort a master I2C process communication with Interrupt using HAL_I2C_Master_Abort_IT() + (+) End of abort process, HAL_I2C_AbortCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_AbortCpltCallback() + (+) Discard a slave I2C process communication using __HAL_I2C_GENERATE_NACK() macro. + This action will inform Master to generate a Stop condition to discard the communication. + + *** DMA mode IO MEM operation *** + ================================= + [..] + (+) Write an amount of data in non-blocking mode with DMA to a specific memory address using + HAL_I2C_Mem_Write_DMA() + (+) At Memory end of write transfer, HAL_I2C_MemTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MemTxCpltCallback() + (+) Read an amount of data in non-blocking mode with DMA from a specific memory address using + HAL_I2C_Mem_Read_DMA() + (+) At Memory end of read transfer, HAL_I2C_MemRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_I2C_MemRxCpltCallback() + (+) In case of transfer Error, HAL_I2C_ErrorCallback() function is executed and users can + add their own code by customization of function pointer HAL_I2C_ErrorCallback() + + + *** I2C HAL driver macros list *** + ================================== + [..] + Below the list of most used macros in I2C HAL driver. + + (+) __HAL_I2C_ENABLE: Enable the I2C peripheral + (+) __HAL_I2C_DISABLE: Disable the I2C peripheral + (+) __HAL_I2C_GENERATE_NACK: Generate a Non-Acknowledge I2C peripheral in Slave mode + (+) __HAL_I2C_GET_FLAG: Check whether the specified I2C flag is set or not + (+) __HAL_I2C_CLEAR_FLAG: Clear the specified I2C pending flag + (+) __HAL_I2C_ENABLE_IT: Enable the specified I2C interrupt + (+) __HAL_I2C_DISABLE_IT: Disable the specified I2C interrupt + + *** Callback registration *** + ============================================= + [..] + The compilation flag USE_HAL_I2C_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_I2C_RegisterCallback() or HAL_I2C_RegisterAddrCallback() + to register an interrupt callback. + [..] + Function HAL_I2C_RegisterCallback() allows to register following callbacks: + (+) MasterTxCpltCallback : callback for Master transmission end of transfer. + (+) MasterRxCpltCallback : callback for Master reception end of transfer. + (+) SlaveTxCpltCallback : callback for Slave transmission end of transfer. + (+) SlaveRxCpltCallback : callback for Slave reception end of transfer. + (+) ListenCpltCallback : callback for end of listen mode. + (+) MemTxCpltCallback : callback for Memory transmission end of transfer. + (+) MemRxCpltCallback : callback for Memory reception end of transfer. + (+) ErrorCallback : callback for error detection. + (+) AbortCpltCallback : callback for abort completion process. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + [..] + For specific callback AddrCallback use dedicated register callbacks : HAL_I2C_RegisterAddrCallback(). + [..] + Use function HAL_I2C_UnRegisterCallback to reset a callback to the default + weak function. + HAL_I2C_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) MasterTxCpltCallback : callback for Master transmission end of transfer. + (+) MasterRxCpltCallback : callback for Master reception end of transfer. + (+) SlaveTxCpltCallback : callback for Slave transmission end of transfer. + (+) SlaveRxCpltCallback : callback for Slave reception end of transfer. + (+) ListenCpltCallback : callback for end of listen mode. + (+) MemTxCpltCallback : callback for Memory transmission end of transfer. + (+) MemRxCpltCallback : callback for Memory reception end of transfer. + (+) ErrorCallback : callback for error detection. + (+) AbortCpltCallback : callback for abort completion process. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + [..] + For callback AddrCallback use dedicated register callbacks : HAL_I2C_UnRegisterAddrCallback(). + [..] + By default, after the HAL_I2C_Init() and when the state is HAL_I2C_STATE_RESET + all callbacks are set to the corresponding weak functions: + examples HAL_I2C_MasterTxCpltCallback(), HAL_I2C_MasterRxCpltCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak functions in the HAL_I2C_Init()/ HAL_I2C_DeInit() only when + these callbacks are null (not registered beforehand). + If MspInit or MspDeInit are not null, the HAL_I2C_Init()/ HAL_I2C_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state. + [..] + Callbacks can be registered/unregistered in HAL_I2C_STATE_READY state only. + Exception done MspInit/MspDeInit functions that can be registered/unregistered + in HAL_I2C_STATE_READY or HAL_I2C_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + Then, the user first registers the MspInit/MspDeInit user callbacks + using HAL_I2C_RegisterCallback() before calling HAL_I2C_DeInit() + or HAL_I2C_Init() function. + [..] + When the compilation flag USE_HAL_I2C_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + + [..] + (@) You can refer to the I2C HAL driver header file for more useful macros + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup I2C I2C + * @brief I2C HAL module driver + * @{ + */ + +#ifdef HAL_I2C_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ + +/** @defgroup I2C_Private_Define I2C Private Define + * @{ + */ +#define TIMING_CLEAR_MASK (0xF0FFFFFFU) /*!< I2C TIMING clear register Mask */ +#define I2C_TIMEOUT_ADDR (10000U) /*!< 10 s */ +#define I2C_TIMEOUT_BUSY (25U) /*!< 25 ms */ +#define I2C_TIMEOUT_DIR (25U) /*!< 25 ms */ +#define I2C_TIMEOUT_RXNE (25U) /*!< 25 ms */ +#define I2C_TIMEOUT_STOPF (25U) /*!< 25 ms */ +#define I2C_TIMEOUT_TC (25U) /*!< 25 ms */ +#define I2C_TIMEOUT_TCR (25U) /*!< 25 ms */ +#define I2C_TIMEOUT_TXIS (25U) /*!< 25 ms */ +#define I2C_TIMEOUT_FLAG (25U) /*!< 25 ms */ + +#define MAX_NBYTE_SIZE 255U +#define SLAVE_ADDR_SHIFT 7U +#define SLAVE_ADDR_MSK 0x06U + +/* Private define for @ref PreviousState usage */ +#define I2C_STATE_MSK ((uint32_t)((uint32_t)((uint32_t)HAL_I2C_STATE_BUSY_TX | \ + (uint32_t)HAL_I2C_STATE_BUSY_RX) & \ + (uint32_t)(~((uint32_t)HAL_I2C_STATE_READY)))) +/*!< Mask State define, keep only RX and TX bits */ +#define I2C_STATE_NONE ((uint32_t)(HAL_I2C_MODE_NONE)) +/*!< Default Value */ +#define I2C_STATE_MASTER_BUSY_TX ((uint32_t)(((uint32_t)HAL_I2C_STATE_BUSY_TX & I2C_STATE_MSK) | \ + (uint32_t)HAL_I2C_MODE_MASTER)) +/*!< Master Busy TX, combinaison of State LSB and Mode enum */ +#define I2C_STATE_MASTER_BUSY_RX ((uint32_t)(((uint32_t)HAL_I2C_STATE_BUSY_RX & I2C_STATE_MSK) | \ + (uint32_t)HAL_I2C_MODE_MASTER)) +/*!< Master Busy RX, combinaison of State LSB and Mode enum */ +#define I2C_STATE_SLAVE_BUSY_TX ((uint32_t)(((uint32_t)HAL_I2C_STATE_BUSY_TX & I2C_STATE_MSK) | \ + (uint32_t)HAL_I2C_MODE_SLAVE)) +/*!< Slave Busy TX, combinaison of State LSB and Mode enum */ +#define I2C_STATE_SLAVE_BUSY_RX ((uint32_t)(((uint32_t)HAL_I2C_STATE_BUSY_RX & I2C_STATE_MSK) | \ + (uint32_t)HAL_I2C_MODE_SLAVE)) +/*!< Slave Busy RX, combinaison of State LSB and Mode enum */ +#define I2C_STATE_MEM_BUSY_TX ((uint32_t)(((uint32_t)HAL_I2C_STATE_BUSY_TX & I2C_STATE_MSK) | \ + (uint32_t)HAL_I2C_MODE_MEM)) +/*!< Memory Busy TX, combinaison of State LSB and Mode enum */ +#define I2C_STATE_MEM_BUSY_RX ((uint32_t)(((uint32_t)HAL_I2C_STATE_BUSY_RX & I2C_STATE_MSK) | \ + (uint32_t)HAL_I2C_MODE_MEM)) +/*!< Memory Busy RX, combinaison of State LSB and Mode enum */ + + +/* Private define to centralize the enable/disable of Interrupts */ +#define I2C_XFER_TX_IT (uint16_t)(0x0001U) /*!< Bit field can be combinated with + @ref I2C_XFER_LISTEN_IT */ +#define I2C_XFER_RX_IT (uint16_t)(0x0002U) /*!< Bit field can be combinated with + @ref I2C_XFER_LISTEN_IT */ +#define I2C_XFER_LISTEN_IT (uint16_t)(0x8000U) /*!< Bit field can be combinated with @ref I2C_XFER_TX_IT + and @ref I2C_XFER_RX_IT */ + +#define I2C_XFER_ERROR_IT (uint16_t)(0x0010U) /*!< Bit definition to manage addition of global Error + and NACK treatment */ +#define I2C_XFER_CPLT_IT (uint16_t)(0x0020U) /*!< Bit definition to manage only STOP evenement */ +#define I2C_XFER_RELOAD_IT (uint16_t)(0x0040U) /*!< Bit definition to manage only Reload of NBYTE */ + +/* Private define Sequential Transfer Options default/reset value */ +#define I2C_NO_OPTION_FRAME (0xFFFF0000U) +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ + +/** @defgroup I2C_Private_Functions I2C Private Functions + * @{ + */ +/* Private functions to handle DMA transfer */ +static void I2C_DMAMasterTransmitCplt(DMA_HandleTypeDef *hdma); +static void I2C_DMAMasterReceiveCplt(DMA_HandleTypeDef *hdma); +static void I2C_DMASlaveTransmitCplt(DMA_HandleTypeDef *hdma); +static void I2C_DMASlaveReceiveCplt(DMA_HandleTypeDef *hdma); +static void I2C_DMAError(DMA_HandleTypeDef *hdma); +static void I2C_DMAAbort(DMA_HandleTypeDef *hdma); + +/* Private functions to handle IT transfer */ +static void I2C_ITAddrCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags); +static void I2C_ITMasterSeqCplt(I2C_HandleTypeDef *hi2c); +static void I2C_ITSlaveSeqCplt(I2C_HandleTypeDef *hi2c); +static void I2C_ITMasterCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags); +static void I2C_ITSlaveCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags); +static void I2C_ITListenCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags); +static void I2C_ITError(I2C_HandleTypeDef *hi2c, uint32_t ErrorCode); + +/* Private functions to handle IT transfer */ +static HAL_StatusTypeDef I2C_RequestMemoryWrite(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, + uint16_t MemAddress, uint16_t MemAddSize, uint32_t Timeout, + uint32_t Tickstart); +static HAL_StatusTypeDef I2C_RequestMemoryRead(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, + uint16_t MemAddress, uint16_t MemAddSize, uint32_t Timeout, + uint32_t Tickstart); + +/* Private functions for I2C transfer IRQ handler */ +static HAL_StatusTypeDef I2C_Master_ISR_IT(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources); +static HAL_StatusTypeDef I2C_Slave_ISR_IT(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources); +static HAL_StatusTypeDef I2C_Master_ISR_DMA(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources); +static HAL_StatusTypeDef I2C_Slave_ISR_DMA(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources); + +/* Private functions to handle flags during polling transfer */ +static HAL_StatusTypeDef I2C_WaitOnFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Flag, FlagStatus Status, + uint32_t Timeout, uint32_t Tickstart); +static HAL_StatusTypeDef I2C_WaitOnTXISFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, + uint32_t Tickstart); +static HAL_StatusTypeDef I2C_WaitOnRXNEFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, + uint32_t Tickstart); +static HAL_StatusTypeDef I2C_WaitOnSTOPFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, + uint32_t Tickstart); +static HAL_StatusTypeDef I2C_IsAcknowledgeFailed(I2C_HandleTypeDef *hi2c, uint32_t Timeout, + uint32_t Tickstart); + +/* Private functions to centralize the enable/disable of Interrupts */ +static void I2C_Enable_IRQ(I2C_HandleTypeDef *hi2c, uint16_t InterruptRequest); +static void I2C_Disable_IRQ(I2C_HandleTypeDef *hi2c, uint16_t InterruptRequest); + +/* Private function to treat different error callback */ +static void I2C_TreatErrorCallback(I2C_HandleTypeDef *hi2c); + +/* Private function to flush TXDR register */ +static void I2C_Flush_TXDR(I2C_HandleTypeDef *hi2c); + +/* Private function to handle start, restart or stop a transfer */ +static void I2C_TransferConfig(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t Size, uint32_t Mode, + uint32_t Request); + +/* Private function to Convert Specific options */ +static void I2C_ConvertOtherXferOptions(I2C_HandleTypeDef *hi2c); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup I2C_Exported_Functions I2C Exported Functions + * @{ + */ + +/** @defgroup I2C_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This subsection provides a set of functions allowing to initialize and + deinitialize the I2Cx peripheral: + + (+) User must Implement HAL_I2C_MspInit() function in which he configures + all related peripherals resources (CLOCK, GPIO, DMA, IT and NVIC ). + + (+) Call the function HAL_I2C_Init() to configure the selected device with + the selected configuration: + (++) Clock Timing + (++) Own Address 1 + (++) Addressing mode (Master, Slave) + (++) Dual Addressing mode + (++) Own Address 2 + (++) Own Address 2 Mask + (++) General call mode + (++) Nostretch mode + + (+) Call the function HAL_I2C_DeInit() to restore the default configuration + of the selected I2Cx peripheral. + +@endverbatim + * @{ + */ + +/** + * @brief Initializes the I2C according to the specified parameters + * in the I2C_InitTypeDef and initialize the associated handle. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c) +{ + /* Check the I2C handle allocation */ + if (hi2c == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance)); + assert_param(IS_I2C_OWN_ADDRESS1(hi2c->Init.OwnAddress1)); + assert_param(IS_I2C_ADDRESSING_MODE(hi2c->Init.AddressingMode)); + assert_param(IS_I2C_DUAL_ADDRESS(hi2c->Init.DualAddressMode)); + assert_param(IS_I2C_OWN_ADDRESS2(hi2c->Init.OwnAddress2)); + assert_param(IS_I2C_OWN_ADDRESS2_MASK(hi2c->Init.OwnAddress2Masks)); + assert_param(IS_I2C_GENERAL_CALL(hi2c->Init.GeneralCallMode)); + assert_param(IS_I2C_NO_STRETCH(hi2c->Init.NoStretchMode)); + + if (hi2c->State == HAL_I2C_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hi2c->Lock = HAL_UNLOCKED; + +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + /* Init the I2C Callback settings */ + hi2c->MasterTxCpltCallback = HAL_I2C_MasterTxCpltCallback; /* Legacy weak MasterTxCpltCallback */ + hi2c->MasterRxCpltCallback = HAL_I2C_MasterRxCpltCallback; /* Legacy weak MasterRxCpltCallback */ + hi2c->SlaveTxCpltCallback = HAL_I2C_SlaveTxCpltCallback; /* Legacy weak SlaveTxCpltCallback */ + hi2c->SlaveRxCpltCallback = HAL_I2C_SlaveRxCpltCallback; /* Legacy weak SlaveRxCpltCallback */ + hi2c->ListenCpltCallback = HAL_I2C_ListenCpltCallback; /* Legacy weak ListenCpltCallback */ + hi2c->MemTxCpltCallback = HAL_I2C_MemTxCpltCallback; /* Legacy weak MemTxCpltCallback */ + hi2c->MemRxCpltCallback = HAL_I2C_MemRxCpltCallback; /* Legacy weak MemRxCpltCallback */ + hi2c->ErrorCallback = HAL_I2C_ErrorCallback; /* Legacy weak ErrorCallback */ + hi2c->AbortCpltCallback = HAL_I2C_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + hi2c->AddrCallback = HAL_I2C_AddrCallback; /* Legacy weak AddrCallback */ + + if (hi2c->MspInitCallback == NULL) + { + hi2c->MspInitCallback = HAL_I2C_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware : GPIO, CLOCK, CORTEX...etc */ + hi2c->MspInitCallback(hi2c); +#else + /* Init the low level hardware : GPIO, CLOCK, CORTEX...etc */ + HAL_I2C_MspInit(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + + hi2c->State = HAL_I2C_STATE_BUSY; + + /* Disable the selected I2C peripheral */ + __HAL_I2C_DISABLE(hi2c); + + /*---------------------------- I2Cx TIMINGR Configuration ------------------*/ + /* Configure I2Cx: Frequency range */ + hi2c->Instance->TIMINGR = hi2c->Init.Timing & TIMING_CLEAR_MASK; + + /*---------------------------- I2Cx OAR1 Configuration ---------------------*/ + /* Disable Own Address1 before set the Own Address1 configuration */ + hi2c->Instance->OAR1 &= ~I2C_OAR1_OA1EN; + + /* Configure I2Cx: Own Address1 and ack own address1 mode */ + if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_7BIT) + { + hi2c->Instance->OAR1 = (I2C_OAR1_OA1EN | hi2c->Init.OwnAddress1); + } + else /* I2C_ADDRESSINGMODE_10BIT */ + { + hi2c->Instance->OAR1 = (I2C_OAR1_OA1EN | I2C_OAR1_OA1MODE | hi2c->Init.OwnAddress1); + } + + /*---------------------------- I2Cx CR2 Configuration ----------------------*/ + /* Configure I2Cx: Addressing Master mode */ + if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_10BIT) + { + hi2c->Instance->CR2 = (I2C_CR2_ADD10); + } + /* Enable the AUTOEND by default, and enable NACK (should be disable only during Slave process */ + hi2c->Instance->CR2 |= (I2C_CR2_AUTOEND | I2C_CR2_NACK); + + /*---------------------------- I2Cx OAR2 Configuration ---------------------*/ + /* Disable Own Address2 before set the Own Address2 configuration */ + hi2c->Instance->OAR2 &= ~I2C_DUALADDRESS_ENABLE; + + /* Configure I2Cx: Dual mode and Own Address2 */ + hi2c->Instance->OAR2 = (hi2c->Init.DualAddressMode | hi2c->Init.OwnAddress2 | \ + (hi2c->Init.OwnAddress2Masks << 8)); + + /*---------------------------- I2Cx CR1 Configuration ----------------------*/ + /* Configure I2Cx: Generalcall and NoStretch mode */ + hi2c->Instance->CR1 = (hi2c->Init.GeneralCallMode | hi2c->Init.NoStretchMode); + + /* Enable the selected I2C peripheral */ + __HAL_I2C_ENABLE(hi2c); + + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_NONE; + hi2c->Mode = HAL_I2C_MODE_NONE; + + return HAL_OK; +} + +/** + * @brief DeInitialize the I2C peripheral. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_DeInit(I2C_HandleTypeDef *hi2c) +{ + /* Check the I2C handle allocation */ + if (hi2c == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance)); + + hi2c->State = HAL_I2C_STATE_BUSY; + + /* Disable the I2C Peripheral Clock */ + __HAL_I2C_DISABLE(hi2c); + +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + if (hi2c->MspDeInitCallback == NULL) + { + hi2c->MspDeInitCallback = HAL_I2C_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + hi2c->MspDeInitCallback(hi2c); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + HAL_I2C_MspDeInit(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + hi2c->State = HAL_I2C_STATE_RESET; + hi2c->PreviousState = I2C_STATE_NONE; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Release Lock */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; +} + +/** + * @brief Initialize the I2C MSP. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_MspInit(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitialize the I2C MSP. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_MspDeInit(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_MspDeInit could be implemented in the user file + */ +} + +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User I2C Callback + * To be used instead of the weak predefined callback + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_I2C_MASTER_TX_COMPLETE_CB_ID Master Tx Transfer completed callback ID + * @arg @ref HAL_I2C_MASTER_RX_COMPLETE_CB_ID Master Rx Transfer completed callback ID + * @arg @ref HAL_I2C_SLAVE_TX_COMPLETE_CB_ID Slave Tx Transfer completed callback ID + * @arg @ref HAL_I2C_SLAVE_RX_COMPLETE_CB_ID Slave Rx Transfer completed callback ID + * @arg @ref HAL_I2C_LISTEN_COMPLETE_CB_ID Listen Complete callback ID + * @arg @ref HAL_I2C_MEM_TX_COMPLETE_CB_ID Memory Tx Transfer callback ID + * @arg @ref HAL_I2C_MEM_RX_COMPLETE_CB_ID Memory Rx Transfer completed callback ID + * @arg @ref HAL_I2C_ERROR_CB_ID Error callback ID + * @arg @ref HAL_I2C_ABORT_CB_ID Abort callback ID + * @arg @ref HAL_I2C_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_I2C_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_RegisterCallback(I2C_HandleTypeDef *hi2c, HAL_I2C_CallbackIDTypeDef CallbackID, + pI2C_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hi2c); + + if (HAL_I2C_STATE_READY == hi2c->State) + { + switch (CallbackID) + { + case HAL_I2C_MASTER_TX_COMPLETE_CB_ID : + hi2c->MasterTxCpltCallback = pCallback; + break; + + case HAL_I2C_MASTER_RX_COMPLETE_CB_ID : + hi2c->MasterRxCpltCallback = pCallback; + break; + + case HAL_I2C_SLAVE_TX_COMPLETE_CB_ID : + hi2c->SlaveTxCpltCallback = pCallback; + break; + + case HAL_I2C_SLAVE_RX_COMPLETE_CB_ID : + hi2c->SlaveRxCpltCallback = pCallback; + break; + + case HAL_I2C_LISTEN_COMPLETE_CB_ID : + hi2c->ListenCpltCallback = pCallback; + break; + + case HAL_I2C_MEM_TX_COMPLETE_CB_ID : + hi2c->MemTxCpltCallback = pCallback; + break; + + case HAL_I2C_MEM_RX_COMPLETE_CB_ID : + hi2c->MemRxCpltCallback = pCallback; + break; + + case HAL_I2C_ERROR_CB_ID : + hi2c->ErrorCallback = pCallback; + break; + + case HAL_I2C_ABORT_CB_ID : + hi2c->AbortCpltCallback = pCallback; + break; + + case HAL_I2C_MSPINIT_CB_ID : + hi2c->MspInitCallback = pCallback; + break; + + case HAL_I2C_MSPDEINIT_CB_ID : + hi2c->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_I2C_STATE_RESET == hi2c->State) + { + switch (CallbackID) + { + case HAL_I2C_MSPINIT_CB_ID : + hi2c->MspInitCallback = pCallback; + break; + + case HAL_I2C_MSPDEINIT_CB_ID : + hi2c->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hi2c); + return status; +} + +/** + * @brief Unregister an I2C Callback + * I2C callback is redirected to the weak predefined callback + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * This parameter can be one of the following values: + * @arg @ref HAL_I2C_MASTER_TX_COMPLETE_CB_ID Master Tx Transfer completed callback ID + * @arg @ref HAL_I2C_MASTER_RX_COMPLETE_CB_ID Master Rx Transfer completed callback ID + * @arg @ref HAL_I2C_SLAVE_TX_COMPLETE_CB_ID Slave Tx Transfer completed callback ID + * @arg @ref HAL_I2C_SLAVE_RX_COMPLETE_CB_ID Slave Rx Transfer completed callback ID + * @arg @ref HAL_I2C_LISTEN_COMPLETE_CB_ID Listen Complete callback ID + * @arg @ref HAL_I2C_MEM_TX_COMPLETE_CB_ID Memory Tx Transfer callback ID + * @arg @ref HAL_I2C_MEM_RX_COMPLETE_CB_ID Memory Rx Transfer completed callback ID + * @arg @ref HAL_I2C_ERROR_CB_ID Error callback ID + * @arg @ref HAL_I2C_ABORT_CB_ID Abort callback ID + * @arg @ref HAL_I2C_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_I2C_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_UnRegisterCallback(I2C_HandleTypeDef *hi2c, HAL_I2C_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hi2c); + + if (HAL_I2C_STATE_READY == hi2c->State) + { + switch (CallbackID) + { + case HAL_I2C_MASTER_TX_COMPLETE_CB_ID : + hi2c->MasterTxCpltCallback = HAL_I2C_MasterTxCpltCallback; /* Legacy weak MasterTxCpltCallback */ + break; + + case HAL_I2C_MASTER_RX_COMPLETE_CB_ID : + hi2c->MasterRxCpltCallback = HAL_I2C_MasterRxCpltCallback; /* Legacy weak MasterRxCpltCallback */ + break; + + case HAL_I2C_SLAVE_TX_COMPLETE_CB_ID : + hi2c->SlaveTxCpltCallback = HAL_I2C_SlaveTxCpltCallback; /* Legacy weak SlaveTxCpltCallback */ + break; + + case HAL_I2C_SLAVE_RX_COMPLETE_CB_ID : + hi2c->SlaveRxCpltCallback = HAL_I2C_SlaveRxCpltCallback; /* Legacy weak SlaveRxCpltCallback */ + break; + + case HAL_I2C_LISTEN_COMPLETE_CB_ID : + hi2c->ListenCpltCallback = HAL_I2C_ListenCpltCallback; /* Legacy weak ListenCpltCallback */ + break; + + case HAL_I2C_MEM_TX_COMPLETE_CB_ID : + hi2c->MemTxCpltCallback = HAL_I2C_MemTxCpltCallback; /* Legacy weak MemTxCpltCallback */ + break; + + case HAL_I2C_MEM_RX_COMPLETE_CB_ID : + hi2c->MemRxCpltCallback = HAL_I2C_MemRxCpltCallback; /* Legacy weak MemRxCpltCallback */ + break; + + case HAL_I2C_ERROR_CB_ID : + hi2c->ErrorCallback = HAL_I2C_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_I2C_ABORT_CB_ID : + hi2c->AbortCpltCallback = HAL_I2C_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + break; + + case HAL_I2C_MSPINIT_CB_ID : + hi2c->MspInitCallback = HAL_I2C_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_I2C_MSPDEINIT_CB_ID : + hi2c->MspDeInitCallback = HAL_I2C_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_I2C_STATE_RESET == hi2c->State) + { + switch (CallbackID) + { + case HAL_I2C_MSPINIT_CB_ID : + hi2c->MspInitCallback = HAL_I2C_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_I2C_MSPDEINIT_CB_ID : + hi2c->MspDeInitCallback = HAL_I2C_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hi2c); + return status; +} + +/** + * @brief Register the Slave Address Match I2C Callback + * To be used instead of the weak HAL_I2C_AddrCallback() predefined callback + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pCallback pointer to the Address Match Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_RegisterAddrCallback(I2C_HandleTypeDef *hi2c, pI2C_AddrCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hi2c); + + if (HAL_I2C_STATE_READY == hi2c->State) + { + hi2c->AddrCallback = pCallback; + } + else + { + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hi2c); + return status; +} + +/** + * @brief UnRegister the Slave Address Match I2C Callback + * Info Ready I2C Callback is redirected to the weak HAL_I2C_AddrCallback() predefined callback + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_UnRegisterAddrCallback(I2C_HandleTypeDef *hi2c) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hi2c); + + if (HAL_I2C_STATE_READY == hi2c->State) + { + hi2c->AddrCallback = HAL_I2C_AddrCallback; /* Legacy weak AddrCallback */ + } + else + { + /* Update the error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hi2c); + return status; +} + +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup I2C_Exported_Functions_Group2 Input and Output operation functions + * @brief Data transfers functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to manage the I2C data + transfers. + + (#) There are two modes of transfer: + (++) Blocking mode : The communication is performed in the polling mode. + The status of all data processing is returned by the same function + after finishing transfer. + (++) No-Blocking mode : The communication is performed using Interrupts + or DMA. These functions return the status of the transfer startup. + The end of the data processing will be indicated through the + dedicated I2C IRQ when using Interrupt mode or the DMA IRQ when + using DMA mode. + + (#) Blocking mode functions are : + (++) HAL_I2C_Master_Transmit() + (++) HAL_I2C_Master_Receive() + (++) HAL_I2C_Slave_Transmit() + (++) HAL_I2C_Slave_Receive() + (++) HAL_I2C_Mem_Write() + (++) HAL_I2C_Mem_Read() + (++) HAL_I2C_IsDeviceReady() + + (#) No-Blocking mode functions with Interrupt are : + (++) HAL_I2C_Master_Transmit_IT() + (++) HAL_I2C_Master_Receive_IT() + (++) HAL_I2C_Slave_Transmit_IT() + (++) HAL_I2C_Slave_Receive_IT() + (++) HAL_I2C_Mem_Write_IT() + (++) HAL_I2C_Mem_Read_IT() + (++) HAL_I2C_Master_Seq_Transmit_IT() + (++) HAL_I2C_Master_Seq_Receive_IT() + (++) HAL_I2C_Slave_Seq_Transmit_IT() + (++) HAL_I2C_Slave_Seq_Receive_IT() + (++) HAL_I2C_EnableListen_IT() + (++) HAL_I2C_DisableListen_IT() + (++) HAL_I2C_Master_Abort_IT() + + (#) No-Blocking mode functions with DMA are : + (++) HAL_I2C_Master_Transmit_DMA() + (++) HAL_I2C_Master_Receive_DMA() + (++) HAL_I2C_Slave_Transmit_DMA() + (++) HAL_I2C_Slave_Receive_DMA() + (++) HAL_I2C_Mem_Write_DMA() + (++) HAL_I2C_Mem_Read_DMA() + (++) HAL_I2C_Master_Seq_Transmit_DMA() + (++) HAL_I2C_Master_Seq_Receive_DMA() + (++) HAL_I2C_Slave_Seq_Transmit_DMA() + (++) HAL_I2C_Slave_Seq_Receive_DMA() + + (#) A set of Transfer Complete Callbacks are provided in non Blocking mode: + (++) HAL_I2C_MasterTxCpltCallback() + (++) HAL_I2C_MasterRxCpltCallback() + (++) HAL_I2C_SlaveTxCpltCallback() + (++) HAL_I2C_SlaveRxCpltCallback() + (++) HAL_I2C_MemTxCpltCallback() + (++) HAL_I2C_MemRxCpltCallback() + (++) HAL_I2C_AddrCallback() + (++) HAL_I2C_ListenCpltCallback() + (++) HAL_I2C_ErrorCallback() + (++) HAL_I2C_AbortCpltCallback() + +@endverbatim + * @{ + */ + +/** + * @brief Transmits in master mode an amount of data in blocking mode. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Transmit(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t Timeout) +{ + uint32_t tickstart; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BUSY, SET, I2C_TIMEOUT_BUSY, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferISR = NULL; + + /* Send Slave Address */ + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, + I2C_GENERATE_START_WRITE); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_GENERATE_START_WRITE); + } + + while (hi2c->XferCount > 0U) + { + /* Wait until TXIS flag is set */ + if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + /* Write data to TXDR */ + hi2c->Instance->TXDR = *hi2c->pBuffPtr; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferCount--; + hi2c->XferSize--; + + if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U)) + { + /* Wait until TCR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_TCR, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, + I2C_NO_STARTSTOP); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_NO_STARTSTOP); + } + } + } + + /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */ + /* Wait until STOPF flag is set */ + if (I2C_WaitOnSTOPFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receives in master mode an amount of data in blocking mode. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Receive(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t Timeout) +{ + uint32_t tickstart; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BUSY, SET, I2C_TIMEOUT_BUSY, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferISR = NULL; + + /* Send Slave Address */ + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, + I2C_GENERATE_START_READ); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_GENERATE_START_READ); + } + + while (hi2c->XferCount > 0U) + { + /* Wait until RXNE flag is set */ + if (I2C_WaitOnRXNEFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferSize--; + hi2c->XferCount--; + + if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U)) + { + /* Wait until TCR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_TCR, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, + I2C_NO_STARTSTOP); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_NO_STARTSTOP); + } + } + } + + /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */ + /* Wait until STOPF flag is set */ + if (I2C_WaitOnSTOPFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Transmits in slave mode an amount of data in blocking mode. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Transmit(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t Timeout) +{ + uint32_t tickstart; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferISR = NULL; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Wait until ADDR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_ADDR, RESET, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + /* Clear ADDR flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + + /* If 10bit addressing mode is selected */ + if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_10BIT) + { + /* Wait until ADDR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_ADDR, RESET, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + /* Clear ADDR flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + } + + /* Wait until DIR flag is set Transmitter mode */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_DIR, RESET, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + while (hi2c->XferCount > 0U) + { + /* Wait until TXIS flag is set */ + if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + /* Write data to TXDR */ + hi2c->Instance->TXDR = *hi2c->pBuffPtr; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferCount--; + } + + /* Wait until STOP flag is set */ + if (I2C_WaitOnSTOPFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + + if (hi2c->ErrorCode == HAL_I2C_ERROR_AF) + { + /* Normal use case for Transmitter mode */ + /* A NACK is generated to confirm the end of transfer */ + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + } + else + { + return HAL_ERROR; + } + } + + /* Clear STOP flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Wait until BUSY flag is reset */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BUSY, SET, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive in slave mode an amount of data in blocking mode + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Receive(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t Timeout) +{ + uint32_t tickstart; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferISR = NULL; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Wait until ADDR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_ADDR, RESET, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + /* Clear ADDR flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + + /* Wait until DIR flag is reset Receiver mode */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_DIR, SET, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + while (hi2c->XferCount > 0U) + { + /* Wait until RXNE flag is set */ + if (I2C_WaitOnRXNEFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + + /* Store Last receive data if any */ + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_RXNE) == SET) + { + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferCount--; + } + + return HAL_ERROR; + } + + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferCount--; + } + + /* Wait until STOP flag is set */ + if (I2C_WaitOnSTOPFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + /* Clear STOP flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Wait until BUSY flag is reset */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BUSY, SET, Timeout, tickstart) != HAL_OK) + { + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + return HAL_ERROR; + } + + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Transmit in master mode an amount of data in non-blocking mode with Interrupt + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size) +{ + uint32_t xfermode; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_IT; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + /* Send Slave Address */ + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_GENERATE_START_WRITE); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive in master mode an amount of data in non-blocking mode with Interrupt + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size) +{ + uint32_t xfermode; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_IT; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + /* Send Slave Address */ + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_GENERATE_START_READ); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + + /* Enable ERR, TC, STOP, NACK, RXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RX_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Transmit in slave mode an amount of data in non-blocking mode with Interrupt + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Transmit_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size) +{ + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Slave_ISR_IT; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT | I2C_XFER_LISTEN_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive in slave mode an amount of data in non-blocking mode with Interrupt + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Receive_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size) +{ + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Slave_ISR_IT; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + + /* Enable ERR, TC, STOP, NACK, RXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RX_IT | I2C_XFER_LISTEN_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Transmit in master mode an amount of data in non-blocking mode with DMA + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size) +{ + uint32_t xfermode; + HAL_StatusTypeDef dmaxferstatus; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_DMA; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + if (hi2c->XferSize > 0U) + { + if (hi2c->hdmatx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmatx->XferCpltCallback = I2C_DMAMasterTransmitCplt; + + /* Set the DMA error callback */ + hi2c->hdmatx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmatx->XferHalfCpltCallback = NULL; + hi2c->hdmatx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmatx, (uint32_t)pData, (uint32_t)&hi2c->Instance->TXDR, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Send Slave Address */ + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_GENERATE_START_WRITE); + + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR and NACK interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_ERROR_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_TXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + else + { + /* Update Transfer ISR function pointer */ + hi2c->XferISR = I2C_Master_ISR_IT; + + /* Send Slave Address */ + /* Set NBYTES to write and generate START condition */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_GENERATE_START_WRITE); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT); + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive in master mode an amount of data in non-blocking mode with DMA + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size) +{ + uint32_t xfermode; + HAL_StatusTypeDef dmaxferstatus; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_DMA; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + if (hi2c->XferSize > 0U) + { + if (hi2c->hdmarx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmarx->XferCpltCallback = I2C_DMAMasterReceiveCplt; + + /* Set the DMA error callback */ + hi2c->hdmarx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmarx->XferHalfCpltCallback = NULL; + hi2c->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmarx, (uint32_t)&hi2c->Instance->RXDR, (uint32_t)pData, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Send Slave Address */ + /* Set NBYTES to read and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_GENERATE_START_READ); + + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR and NACK interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_ERROR_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_RXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + else + { + /* Update Transfer ISR function pointer */ + hi2c->XferISR = I2C_Master_ISR_IT; + + /* Send Slave Address */ + /* Set NBYTES to read and generate START condition */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_GENERATE_START_READ); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT); + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Transmit in slave mode an amount of data in non-blocking mode with DMA + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef dmaxferstatus; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Slave_ISR_DMA; + + if (hi2c->hdmatx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmatx->XferCpltCallback = I2C_DMASlaveTransmitCplt; + + /* Set the DMA error callback */ + hi2c->hdmatx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmatx->XferHalfCpltCallback = NULL; + hi2c->hdmatx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmatx, (uint32_t)pData, (uint32_t)&hi2c->Instance->TXDR, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR, STOP, NACK, ADDR interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_LISTEN_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_TXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive in slave mode an amount of data in non-blocking mode with DMA + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Receive_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef dmaxferstatus; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Slave_ISR_DMA; + + if (hi2c->hdmarx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmarx->XferCpltCallback = I2C_DMASlaveReceiveCplt; + + /* Set the DMA error callback */ + hi2c->hdmarx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmarx->XferHalfCpltCallback = NULL; + hi2c->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmarx, (uint32_t)&hi2c->Instance->RXDR, (uint32_t)pData, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR, STOP, NACK, ADDR interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_LISTEN_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_RXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} +/** + * @brief Write an amount of data in blocking mode to a specific memory address + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Mem_Write(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint32_t tickstart; + + /* Check the parameters */ + assert_param(IS_I2C_MEMADD_SIZE(MemAddSize)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BUSY, SET, I2C_TIMEOUT_BUSY, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MEM; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferISR = NULL; + + /* Send Slave Address and Memory Address */ + if (I2C_RequestMemoryWrite(hi2c, DevAddress, MemAddress, MemAddSize, Timeout, tickstart) != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + return HAL_ERROR; + } + + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, I2C_NO_STARTSTOP); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, I2C_NO_STARTSTOP); + } + + do + { + /* Wait until TXIS flag is set */ + if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Write data to TXDR */ + hi2c->Instance->TXDR = *hi2c->pBuffPtr; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferCount--; + hi2c->XferSize--; + + if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U)) + { + /* Wait until TCR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_TCR, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, + I2C_NO_STARTSTOP); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_NO_STARTSTOP); + } + } + + } while (hi2c->XferCount > 0U); + + /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */ + /* Wait until STOPF flag is reset */ + if (I2C_WaitOnSTOPFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Read an amount of data in blocking mode from a specific memory address + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Mem_Read(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint32_t tickstart; + + /* Check the parameters */ + assert_param(IS_I2C_MEMADD_SIZE(MemAddSize)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BUSY, SET, I2C_TIMEOUT_BUSY, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MEM; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferISR = NULL; + + /* Send Slave Address and Memory Address */ + if (I2C_RequestMemoryRead(hi2c, DevAddress, MemAddress, MemAddSize, Timeout, tickstart) != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + return HAL_ERROR; + } + + /* Send Slave Address */ + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, + I2C_GENERATE_START_READ); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_GENERATE_START_READ); + } + + do + { + /* Wait until RXNE flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_RXNE, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferSize--; + hi2c->XferCount--; + + if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U)) + { + /* Wait until TCR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_TCR, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t) hi2c->XferSize, I2C_RELOAD_MODE, + I2C_NO_STARTSTOP); + } + else + { + hi2c->XferSize = hi2c->XferCount; + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_NO_STARTSTOP); + } + } + } while (hi2c->XferCount > 0U); + + /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */ + /* Wait until STOPF flag is reset */ + if (I2C_WaitOnSTOPFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} +/** + * @brief Write an amount of data in non-blocking mode with Interrupt to a specific memory address + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Mem_Write_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size) +{ + uint32_t tickstart; + uint32_t xfermode; + + /* Check the parameters */ + assert_param(IS_I2C_MEMADD_SIZE(MemAddSize)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MEM; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_IT; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + /* Send Slave Address and Memory Address */ + if (I2C_RequestMemoryWrite(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) + != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + return HAL_ERROR; + } + + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_NO_STARTSTOP); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Read an amount of data in non-blocking mode with Interrupt from a specific memory address + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Mem_Read_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size) +{ + uint32_t tickstart; + uint32_t xfermode; + + /* Check the parameters */ + assert_param(IS_I2C_MEMADD_SIZE(MemAddSize)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MEM; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_IT; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + /* Send Slave Address and Memory Address */ + if (I2C_RequestMemoryRead(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + return HAL_ERROR; + } + + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_GENERATE_START_READ); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + + /* Enable ERR, TC, STOP, NACK, RXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RX_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} +/** + * @brief Write an amount of data in non-blocking mode with DMA to a specific memory address + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Mem_Write_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size) +{ + uint32_t tickstart; + uint32_t xfermode; + HAL_StatusTypeDef dmaxferstatus; + + /* Check the parameters */ + assert_param(IS_I2C_MEMADD_SIZE(MemAddSize)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MEM; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_DMA; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + /* Send Slave Address and Memory Address */ + if (I2C_RequestMemoryWrite(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) + != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + return HAL_ERROR; + } + + + if (hi2c->hdmatx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmatx->XferCpltCallback = I2C_DMAMasterTransmitCplt; + + /* Set the DMA error callback */ + hi2c->hdmatx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmatx->XferHalfCpltCallback = NULL; + hi2c->hdmatx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmatx, (uint32_t)pData, (uint32_t)&hi2c->Instance->TXDR, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Send Slave Address */ + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_NO_STARTSTOP); + + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR and NACK interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_ERROR_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_TXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Reads an amount of data in non-blocking mode with DMA from a specific memory address. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param pData Pointer to data buffer + * @param Size Amount of data to be read + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Mem_Read_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint16_t MemAddress, + uint16_t MemAddSize, uint8_t *pData, uint16_t Size) +{ + uint32_t tickstart; + uint32_t xfermode; + HAL_StatusTypeDef dmaxferstatus; + + /* Check the parameters */ + assert_param(IS_I2C_MEMADD_SIZE(MemAddSize)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MEM; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferISR = I2C_Master_ISR_DMA; + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = I2C_AUTOEND_MODE; + } + + /* Send Slave Address and Memory Address */ + if (I2C_RequestMemoryRead(hi2c, DevAddress, MemAddress, MemAddSize, I2C_TIMEOUT_FLAG, tickstart) != HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + return HAL_ERROR; + } + + if (hi2c->hdmarx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmarx->XferCpltCallback = I2C_DMAMasterReceiveCplt; + + /* Set the DMA error callback */ + hi2c->hdmarx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmarx->XferHalfCpltCallback = NULL; + hi2c->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmarx, (uint32_t)&hi2c->Instance->RXDR, (uint32_t)pData, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_GENERATE_START_READ); + + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR and NACK interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_ERROR_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_RXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Checks if target device is ready for communication. + * @note This function is used with Memory devices + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param Trials Number of trials + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint32_t Trials, + uint32_t Timeout) +{ + uint32_t tickstart; + + __IO uint32_t I2C_Trials = 0UL; + + FlagStatus tmp1; + FlagStatus tmp2; + + if (hi2c->State == HAL_I2C_STATE_READY) + { + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + do + { + /* Generate Start */ + hi2c->Instance->CR2 = I2C_GENERATE_START(hi2c->Init.AddressingMode, DevAddress); + + /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */ + /* Wait until STOPF flag is set or a NACK flag is set*/ + tickstart = HAL_GetTick(); + + tmp1 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF); + tmp2 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF); + + while ((tmp1 == RESET) && (tmp2 == RESET)) + { + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0U)) + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + + tmp1 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF); + tmp2 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF); + } + + /* Check if the NACKF flag has not been set */ + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF) == RESET) + { + /* Wait until STOPF flag is reset */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_STOPF, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Device is ready */ + hi2c->State = HAL_I2C_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + /* Wait until STOPF flag is reset */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_STOPF, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Clear STOP Flag, auto generated with autoend*/ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + } + + /* Check if the maximum allowed number of trials has been reached */ + if (I2C_Trials == Trials) + { + /* Generate Stop */ + hi2c->Instance->CR2 |= I2C_CR2_STOP; + + /* Wait until STOPF flag is reset */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_STOPF, RESET, Timeout, tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + } + + /* Increment Trials */ + I2C_Trials++; + } while (I2C_Trials < Trials); + + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Sequential transmit in master I2C mode an amount of data in non-blocking mode with Interrupt. + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Seq_Transmit_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions) +{ + uint32_t xfermode; + uint32_t xferrequest = I2C_GENERATE_START_WRITE; + + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Master_ISR_IT; + + /* If hi2c->XferCount > MAX_NBYTE_SIZE, use reload mode */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = hi2c->XferOptions; + } + + /* If transfer direction not change and there is no request to start another frame, + do not generate Restart Condition */ + /* Mean Previous state is same as current state */ + if ((hi2c->PreviousState == I2C_STATE_MASTER_BUSY_TX) && \ + (IS_I2C_TRANSFER_OTHER_OPTIONS_REQUEST(XferOptions) == 0)) + { + xferrequest = I2C_NO_STARTSTOP; + } + else + { + /* Convert OTHER_xxx XferOptions if any */ + I2C_ConvertOtherXferOptions(hi2c); + + /* Update xfermode accordingly if no reload is necessary */ + if (hi2c->XferCount <= MAX_NBYTE_SIZE) + { + xfermode = hi2c->XferOptions; + } + } + + /* Send Slave Address and set NBYTES to write */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, xferrequest); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Sequential transmit in master I2C mode an amount of data in non-blocking mode with DMA. + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Seq_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions) +{ + uint32_t xfermode; + uint32_t xferrequest = I2C_GENERATE_START_WRITE; + HAL_StatusTypeDef dmaxferstatus; + + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_TX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Master_ISR_DMA; + + /* If hi2c->XferCount > MAX_NBYTE_SIZE, use reload mode */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = hi2c->XferOptions; + } + + /* If transfer direction not change and there is no request to start another frame, + do not generate Restart Condition */ + /* Mean Previous state is same as current state */ + if ((hi2c->PreviousState == I2C_STATE_MASTER_BUSY_TX) && \ + (IS_I2C_TRANSFER_OTHER_OPTIONS_REQUEST(XferOptions) == 0)) + { + xferrequest = I2C_NO_STARTSTOP; + } + else + { + /* Convert OTHER_xxx XferOptions if any */ + I2C_ConvertOtherXferOptions(hi2c); + + /* Update xfermode accordingly if no reload is necessary */ + if (hi2c->XferCount <= MAX_NBYTE_SIZE) + { + xfermode = hi2c->XferOptions; + } + } + + if (hi2c->XferSize > 0U) + { + if (hi2c->hdmatx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmatx->XferCpltCallback = I2C_DMAMasterTransmitCplt; + + /* Set the DMA error callback */ + hi2c->hdmatx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmatx->XferHalfCpltCallback = NULL; + hi2c->hdmatx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmatx, (uint32_t)pData, (uint32_t)&hi2c->Instance->TXDR, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Send Slave Address and set NBYTES to write */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, xferrequest); + + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR and NACK interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_ERROR_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_TXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + else + { + /* Update Transfer ISR function pointer */ + hi2c->XferISR = I2C_Master_ISR_IT; + + /* Send Slave Address */ + /* Set NBYTES to write and generate START condition */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_GENERATE_START_WRITE); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT); + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Sequential receive in master I2C mode an amount of data in non-blocking mode with Interrupt + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Seq_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions) +{ + uint32_t xfermode; + uint32_t xferrequest = I2C_GENERATE_START_READ; + + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Master_ISR_IT; + + /* If hi2c->XferCount > MAX_NBYTE_SIZE, use reload mode */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = hi2c->XferOptions; + } + + /* If transfer direction not change and there is no request to start another frame, + do not generate Restart Condition */ + /* Mean Previous state is same as current state */ + if ((hi2c->PreviousState == I2C_STATE_MASTER_BUSY_RX) && \ + (IS_I2C_TRANSFER_OTHER_OPTIONS_REQUEST(XferOptions) == 0)) + { + xferrequest = I2C_NO_STARTSTOP; + } + else + { + /* Convert OTHER_xxx XferOptions if any */ + I2C_ConvertOtherXferOptions(hi2c); + + /* Update xfermode accordingly if no reload is necessary */ + if (hi2c->XferCount <= MAX_NBYTE_SIZE) + { + xfermode = hi2c->XferOptions; + } + } + + /* Send Slave Address and set NBYTES to read */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, xferrequest); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RX_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Sequential receive in master I2C mode an amount of data in non-blocking mode with DMA + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Seq_Receive_DMA(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions) +{ + uint32_t xfermode; + uint32_t xferrequest = I2C_GENERATE_START_READ; + HAL_StatusTypeDef dmaxferstatus; + + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY_RX; + hi2c->Mode = HAL_I2C_MODE_MASTER; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Master_ISR_DMA; + + /* If hi2c->XferCount > MAX_NBYTE_SIZE, use reload mode */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + xfermode = hi2c->XferOptions; + } + + /* If transfer direction not change and there is no request to start another frame, + do not generate Restart Condition */ + /* Mean Previous state is same as current state */ + if ((hi2c->PreviousState == I2C_STATE_MASTER_BUSY_RX) && \ + (IS_I2C_TRANSFER_OTHER_OPTIONS_REQUEST(XferOptions) == 0)) + { + xferrequest = I2C_NO_STARTSTOP; + } + else + { + /* Convert OTHER_xxx XferOptions if any */ + I2C_ConvertOtherXferOptions(hi2c); + + /* Update xfermode accordingly if no reload is necessary */ + if (hi2c->XferCount <= MAX_NBYTE_SIZE) + { + xfermode = hi2c->XferOptions; + } + } + + if (hi2c->XferSize > 0U) + { + if (hi2c->hdmarx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmarx->XferCpltCallback = I2C_DMAMasterReceiveCplt; + + /* Set the DMA error callback */ + hi2c->hdmarx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmarx->XferHalfCpltCallback = NULL; + hi2c->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmarx, (uint32_t)&hi2c->Instance->RXDR, (uint32_t)pData, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Send Slave Address and set NBYTES to read */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, xferrequest); + + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR and NACK interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_ERROR_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_RXDMAEN; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + else + { + /* Update Transfer ISR function pointer */ + hi2c->XferISR = I2C_Master_ISR_IT; + + /* Send Slave Address */ + /* Set NBYTES to read and generate START condition */ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE, + I2C_GENERATE_START_READ); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + /* possible to enable all of these */ + /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | + I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT); + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Sequential transmit in slave/device I2C mode an amount of data in non-blocking mode with Interrupt + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Transmit_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions) +{ + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) == (uint32_t)HAL_I2C_STATE_LISTEN) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Disable Interrupts, to prevent preemption during treatment in case of multicall */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_TX_IT); + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* I2C cannot manage full duplex exchange so disable previous IT enabled if any */ + /* and then toggle the HAL slave RX state to TX state */ + if (hi2c->State == HAL_I2C_STATE_BUSY_RX_LISTEN) + { + /* Disable associated Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT); + + /* Abort DMA Xfer if any */ + if ((hi2c->Instance->CR1 & I2C_CR1_RXDMAEN) == I2C_CR1_RXDMAEN) + { + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + + if (hi2c->hdmarx != NULL) + { + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmarx->XferAbortCallback = I2C_DMAAbort; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hi2c->hdmarx) != HAL_OK) + { + /* Call Directly XferAbortCallback function in case of error */ + hi2c->hdmarx->XferAbortCallback(hi2c->hdmarx); + } + } + } + } + + hi2c->State = HAL_I2C_STATE_BUSY_TX_LISTEN; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Slave_ISR_IT; + + if (I2C_GET_DIR(hi2c) == I2C_DIRECTION_RECEIVE) + { + /* Clear ADDR flag after prepare the transfer parameters */ + /* This action will generate an acknowledge to the Master */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* REnable ADDR interrupt */ + I2C_Enable_IRQ(hi2c, I2C_XFER_TX_IT | I2C_XFER_LISTEN_IT); + + return HAL_OK; + } + else + { + return HAL_ERROR; + } +} + +/** + * @brief Sequential transmit in slave/device I2C mode an amount of data in non-blocking mode with DMA + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Transmit_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions) +{ + HAL_StatusTypeDef dmaxferstatus; + + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) == (uint32_t)HAL_I2C_STATE_LISTEN) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Disable Interrupts, to prevent preemption during treatment in case of multicall */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_TX_IT); + + /* I2C cannot manage full duplex exchange so disable previous IT enabled if any */ + /* and then toggle the HAL slave RX state to TX state */ + if (hi2c->State == HAL_I2C_STATE_BUSY_RX_LISTEN) + { + /* Disable associated Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT); + + if ((hi2c->Instance->CR1 & I2C_CR1_RXDMAEN) == I2C_CR1_RXDMAEN) + { + /* Abort DMA Xfer if any */ + if (hi2c->hdmarx != NULL) + { + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmarx->XferAbortCallback = I2C_DMAAbort; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hi2c->hdmarx) != HAL_OK) + { + /* Call Directly XferAbortCallback function in case of error */ + hi2c->hdmarx->XferAbortCallback(hi2c->hdmarx); + } + } + } + } + else if (hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) + { + if ((hi2c->Instance->CR1 & I2C_CR1_TXDMAEN) == I2C_CR1_TXDMAEN) + { + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + + /* Abort DMA Xfer if any */ + if (hi2c->hdmatx != NULL) + { + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmatx->XferAbortCallback = I2C_DMAAbort; + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hi2c->hdmatx) != HAL_OK) + { + /* Call Directly XferAbortCallback function in case of error */ + hi2c->hdmatx->XferAbortCallback(hi2c->hdmatx); + } + } + } + } + else + { + /* Nothing to do */ + } + + hi2c->State = HAL_I2C_STATE_BUSY_TX_LISTEN; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Slave_ISR_DMA; + + if (hi2c->hdmatx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmatx->XferCpltCallback = I2C_DMASlaveTransmitCplt; + + /* Set the DMA error callback */ + hi2c->hdmatx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmatx->XferHalfCpltCallback = NULL; + hi2c->hdmatx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmatx, (uint32_t)pData, (uint32_t)&hi2c->Instance->TXDR, + hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Reset XferSize */ + hi2c->XferSize = 0; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (I2C_GET_DIR(hi2c) == I2C_DIRECTION_RECEIVE) + { + /* Clear ADDR flag after prepare the transfer parameters */ + /* This action will generate an acknowledge to the Master */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* Enable ERR, STOP, NACK, ADDR interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_LISTEN_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_TXDMAEN; + + return HAL_OK; + } + else + { + return HAL_ERROR; + } +} + +/** + * @brief Sequential receive in slave/device I2C mode an amount of data in non-blocking mode with Interrupt + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Receive_IT(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions) +{ + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) == (uint32_t)HAL_I2C_STATE_LISTEN) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Disable Interrupts, to prevent preemption during treatment in case of multicall */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT); + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* I2C cannot manage full duplex exchange so disable previous IT enabled if any */ + /* and then toggle the HAL slave TX state to RX state */ + if (hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) + { + /* Disable associated Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT); + + if ((hi2c->Instance->CR1 & I2C_CR1_TXDMAEN) == I2C_CR1_TXDMAEN) + { + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + + /* Abort DMA Xfer if any */ + if (hi2c->hdmatx != NULL) + { + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmatx->XferAbortCallback = I2C_DMAAbort; + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hi2c->hdmatx) != HAL_OK) + { + /* Call Directly XferAbortCallback function in case of error */ + hi2c->hdmatx->XferAbortCallback(hi2c->hdmatx); + } + } + } + } + + hi2c->State = HAL_I2C_STATE_BUSY_RX_LISTEN; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Slave_ISR_IT; + + if (I2C_GET_DIR(hi2c) == I2C_DIRECTION_TRANSMIT) + { + /* Clear ADDR flag after prepare the transfer parameters */ + /* This action will generate an acknowledge to the Master */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* REnable ADDR interrupt */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RX_IT | I2C_XFER_LISTEN_IT); + + return HAL_OK; + } + else + { + return HAL_ERROR; + } +} + +/** + * @brief Sequential receive in slave/device I2C mode an amount of data in non-blocking mode with DMA + * @note This interface allow to manage repeated start condition when a direction change during transfer + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref I2C_XFEROPTIONS + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Slave_Seq_Receive_DMA(I2C_HandleTypeDef *hi2c, uint8_t *pData, uint16_t Size, + uint32_t XferOptions) +{ + HAL_StatusTypeDef dmaxferstatus; + + /* Check the parameters */ + assert_param(IS_I2C_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) == (uint32_t)HAL_I2C_STATE_LISTEN) + { + if ((pData == NULL) || (Size == 0U)) + { + hi2c->ErrorCode = HAL_I2C_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Disable Interrupts, to prevent preemption during treatment in case of multicall */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT); + + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* I2C cannot manage full duplex exchange so disable previous IT enabled if any */ + /* and then toggle the HAL slave TX state to RX state */ + if (hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) + { + /* Disable associated Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT); + + if ((hi2c->Instance->CR1 & I2C_CR1_TXDMAEN) == I2C_CR1_TXDMAEN) + { + /* Abort DMA Xfer if any */ + if (hi2c->hdmatx != NULL) + { + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmatx->XferAbortCallback = I2C_DMAAbort; + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hi2c->hdmatx) != HAL_OK) + { + /* Call Directly XferAbortCallback function in case of error */ + hi2c->hdmatx->XferAbortCallback(hi2c->hdmatx); + } + } + } + } + else if (hi2c->State == HAL_I2C_STATE_BUSY_RX_LISTEN) + { + if ((hi2c->Instance->CR1 & I2C_CR1_RXDMAEN) == I2C_CR1_RXDMAEN) + { + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + + /* Abort DMA Xfer if any */ + if (hi2c->hdmarx != NULL) + { + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmarx->XferAbortCallback = I2C_DMAAbort; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hi2c->hdmarx) != HAL_OK) + { + /* Call Directly XferAbortCallback function in case of error */ + hi2c->hdmarx->XferAbortCallback(hi2c->hdmarx); + } + } + } + } + else + { + /* Nothing to do */ + } + + hi2c->State = HAL_I2C_STATE_BUSY_RX_LISTEN; + hi2c->Mode = HAL_I2C_MODE_SLAVE; + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + + /* Enable Address Acknowledge */ + hi2c->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hi2c->pBuffPtr = pData; + hi2c->XferCount = Size; + hi2c->XferSize = hi2c->XferCount; + hi2c->XferOptions = XferOptions; + hi2c->XferISR = I2C_Slave_ISR_DMA; + + if (hi2c->hdmarx != NULL) + { + /* Set the I2C DMA transfer complete callback */ + hi2c->hdmarx->XferCpltCallback = I2C_DMASlaveReceiveCplt; + + /* Set the DMA error callback */ + hi2c->hdmarx->XferErrorCallback = I2C_DMAError; + + /* Set the unused DMA callbacks to NULL */ + hi2c->hdmarx->XferHalfCpltCallback = NULL; + hi2c->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + dmaxferstatus = HAL_DMA_Start_IT(hi2c->hdmarx, (uint32_t)&hi2c->Instance->RXDR, + (uint32_t)pData, hi2c->XferSize); + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA_PARAM; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (dmaxferstatus == HAL_OK) + { + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Reset XferSize */ + hi2c->XferSize = 0; + } + else + { + /* Update I2C state */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Update I2C error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + + if (I2C_GET_DIR(hi2c) == I2C_DIRECTION_TRANSMIT) + { + /* Clear ADDR flag after prepare the transfer parameters */ + /* This action will generate an acknowledge to the Master */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + /* REnable ADDR interrupt */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RX_IT | I2C_XFER_LISTEN_IT); + + /* Enable DMA Request */ + hi2c->Instance->CR1 |= I2C_CR1_RXDMAEN; + + return HAL_OK; + } + else + { + return HAL_ERROR; + } +} + +/** + * @brief Enable the Address listen mode with Interrupt. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_EnableListen_IT(I2C_HandleTypeDef *hi2c) +{ + if (hi2c->State == HAL_I2C_STATE_READY) + { + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->XferISR = I2C_Slave_ISR_IT; + + /* Enable the Address Match interrupt */ + I2C_Enable_IRQ(hi2c, I2C_XFER_LISTEN_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Disable the Address listen mode with Interrupt. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_DisableListen_IT(I2C_HandleTypeDef *hi2c) +{ + /* Declaration of tmp to prevent undefined behavior of volatile usage */ + uint32_t tmp; + + /* Disable Address listen mode only if a transfer is not ongoing */ + if (hi2c->State == HAL_I2C_STATE_LISTEN) + { + tmp = (uint32_t)(hi2c->State) & I2C_STATE_MSK; + hi2c->PreviousState = tmp | (uint32_t)(hi2c->Mode); + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + hi2c->XferISR = NULL; + + /* Disable the Address Match interrupt */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Abort a master I2C IT or DMA process communication with Interrupt. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2C_Master_Abort_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress) +{ + if (hi2c->Mode == HAL_I2C_MODE_MASTER) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + /* Disable Interrupts and Store Previous state */ + if (hi2c->State == HAL_I2C_STATE_BUSY_TX) + { + I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT); + hi2c->PreviousState = I2C_STATE_MASTER_BUSY_TX; + } + else if (hi2c->State == HAL_I2C_STATE_BUSY_RX) + { + I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT); + hi2c->PreviousState = I2C_STATE_MASTER_BUSY_RX; + } + else + { + /* Do nothing */ + } + + /* Set State at HAL_I2C_STATE_ABORT */ + hi2c->State = HAL_I2C_STATE_ABORT; + + /* Set NBYTES to 1 to generate a dummy read on I2C peripheral */ + /* Set AUTOEND mode, this will generate a NACK then STOP condition to abort the current transfer */ + I2C_TransferConfig(hi2c, DevAddress, 1, I2C_AUTOEND_MODE, I2C_GENERATE_STOP); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Note : The I2C interrupts must be enabled after unlocking current process + to avoid the risk of I2C interrupt handle execution before current + process unlock */ + I2C_Enable_IRQ(hi2c, I2C_XFER_CPLT_IT); + + return HAL_OK; + } + else + { + /* Wrong usage of abort function */ + /* This function should be used only in case of abort monitored by master device */ + return HAL_ERROR; + } +} + +/** + * @} + */ + +/** @defgroup I2C_IRQ_Handler_and_Callbacks IRQ Handler and Callbacks + * @{ + */ + +/** + * @brief This function handles I2C event interrupt request. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c) +{ + /* Get current IT Flags and IT sources value */ + uint32_t itflags = READ_REG(hi2c->Instance->ISR); + uint32_t itsources = READ_REG(hi2c->Instance->CR1); + + /* I2C events treatment -------------------------------------*/ + if (hi2c->XferISR != NULL) + { + hi2c->XferISR(hi2c, itflags, itsources); + } +} + +/** + * @brief This function handles I2C error interrupt request. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c) +{ + uint32_t itflags = READ_REG(hi2c->Instance->ISR); + uint32_t itsources = READ_REG(hi2c->Instance->CR1); + uint32_t tmperror; + + /* I2C Bus error interrupt occurred ------------------------------------*/ + if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_BERR) != RESET) && \ + (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERRI) != RESET)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_BERR; + + /* Clear BERR flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_BERR); + } + + /* I2C Over-Run/Under-Run interrupt occurred ----------------------------------------*/ + if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_OVR) != RESET) && \ + (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERRI) != RESET)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_OVR; + + /* Clear OVR flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_OVR); + } + + /* I2C Arbitration Loss error interrupt occurred -------------------------------------*/ + if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_ARLO) != RESET) && \ + (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERRI) != RESET)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_ARLO; + + /* Clear ARLO flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ARLO); + } + + /* Store current volatile hi2c->ErrorCode, misra rule */ + tmperror = hi2c->ErrorCode; + + /* Call the Error Callback in case of Error detected */ + if ((tmperror & (HAL_I2C_ERROR_BERR | HAL_I2C_ERROR_OVR | HAL_I2C_ERROR_ARLO)) != HAL_I2C_ERROR_NONE) + { + I2C_ITError(hi2c, tmperror); + } +} + +/** + * @brief Master Tx Transfer completed callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_MasterTxCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_MasterTxCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Master Rx Transfer completed callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_MasterRxCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_MasterRxCpltCallback could be implemented in the user file + */ +} + +/** @brief Slave Tx Transfer completed callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_SlaveTxCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_SlaveTxCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Slave Rx Transfer completed callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_SlaveRxCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Slave Address Match callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param TransferDirection Master request Transfer Direction (Write/Read), value of @ref I2C_XFERDIRECTION + * @param AddrMatchCode Address Match Code + * @retval None + */ +__weak void HAL_I2C_AddrCallback(I2C_HandleTypeDef *hi2c, uint8_t TransferDirection, uint16_t AddrMatchCode) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + UNUSED(TransferDirection); + UNUSED(AddrMatchCode); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_AddrCallback() could be implemented in the user file + */ +} + +/** + * @brief Listen Complete callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_ListenCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_ListenCpltCallback() could be implemented in the user file + */ +} + +/** + * @brief Memory Tx Transfer completed callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_MemTxCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_MemTxCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Memory Rx Transfer completed callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_MemRxCpltCallback could be implemented in the user file + */ +} + +/** + * @brief I2C error callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_ErrorCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_ErrorCallback could be implemented in the user file + */ +} + +/** + * @brief I2C abort callback. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval None + */ +__weak void HAL_I2C_AbortCpltCallback(I2C_HandleTypeDef *hi2c) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2c); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_I2C_AbortCpltCallback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup I2C_Exported_Functions_Group3 Peripheral State, Mode and Error functions + * @brief Peripheral State, Mode and Error functions + * +@verbatim + =============================================================================== + ##### Peripheral State, Mode and Error functions ##### + =============================================================================== + [..] + This subsection permit to get in run-time the status of the peripheral + and the data flow. + +@endverbatim + * @{ + */ + +/** + * @brief Return the I2C handle state. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval HAL state + */ +HAL_I2C_StateTypeDef HAL_I2C_GetState(I2C_HandleTypeDef *hi2c) +{ + /* Return I2C handle state */ + return hi2c->State; +} + +/** + * @brief Returns the I2C Master, Slave, Memory or no mode. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for I2C module + * @retval HAL mode + */ +HAL_I2C_ModeTypeDef HAL_I2C_GetMode(I2C_HandleTypeDef *hi2c) +{ + return hi2c->Mode; +} + +/** + * @brief Return the I2C error code. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @retval I2C Error Code + */ +uint32_t HAL_I2C_GetError(I2C_HandleTypeDef *hi2c) +{ + return hi2c->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup I2C_Private_Functions + * @{ + */ + +/** + * @brief Interrupt Sub-Routine which handle the Interrupt Flags Master Mode with Interrupt. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param ITFlags Interrupt flags to handle. + * @param ITSources Interrupt sources enabled. + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_Master_ISR_IT(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources) +{ + uint16_t devaddress; + uint32_t tmpITFlags = ITFlags; + + /* Process Locked */ + __HAL_LOCK(hi2c); + + if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET)) + { + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Set corresponding Error Code */ + /* No need to generate STOP, it is automatically done */ + /* Error callback will be send during stop flag treatment */ + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + + /* Flush TX register */ + I2C_Flush_TXDR(hi2c); + } + else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_RXI) != RESET)) + { + /* Remove RXNE flag on temporary variable as read done */ + tmpITFlags &= ~I2C_FLAG_RXNE; + + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferSize--; + hi2c->XferCount--; + } + else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TXI) != RESET)) + { + /* Write data to TXDR */ + hi2c->Instance->TXDR = *hi2c->pBuffPtr; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferSize--; + hi2c->XferCount--; + } + else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TCR) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET)) + { + if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U)) + { + devaddress = (uint16_t)(hi2c->Instance->CR2 & I2C_CR2_SADD); + + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, I2C_NO_STARTSTOP); + } + else + { + hi2c->XferSize = hi2c->XferCount; + if (hi2c->XferOptions != I2C_NO_OPTION_FRAME) + { + I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize, + hi2c->XferOptions, I2C_NO_STARTSTOP); + } + else + { + I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize, + I2C_AUTOEND_MODE, I2C_NO_STARTSTOP); + } + } + } + else + { + /* Call TxCpltCallback() if no stop mode is set */ + if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE) + { + /* Call I2C Master Sequential complete process */ + I2C_ITMasterSeqCplt(hi2c); + } + else + { + /* Wrong size Status regarding TCR flag event */ + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE); + } + } + } + else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TC) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET)) + { + if (hi2c->XferCount == 0U) + { + if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE) + { + /* Generate a stop condition in case of no transfer option */ + if (hi2c->XferOptions == I2C_NO_OPTION_FRAME) + { + /* Generate Stop */ + hi2c->Instance->CR2 |= I2C_CR2_STOP; + } + else + { + /* Call I2C Master Sequential complete process */ + I2C_ITMasterSeqCplt(hi2c); + } + } + } + else + { + /* Wrong size Status regarding TC flag event */ + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE); + } + } + else + { + /* Nothing to do */ + } + + if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET)) + { + /* Call I2C Master complete process */ + I2C_ITMasterCplt(hi2c, tmpITFlags); + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; +} + +/** + * @brief Interrupt Sub-Routine which handle the Interrupt Flags Slave Mode with Interrupt. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param ITFlags Interrupt flags to handle. + * @param ITSources Interrupt sources enabled. + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_Slave_ISR_IT(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources) +{ + uint32_t tmpoptions = hi2c->XferOptions; + uint32_t tmpITFlags = ITFlags; + + /* Process locked */ + __HAL_LOCK(hi2c); + + /* Check if STOPF is set */ + if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET)) + { + /* Call I2C Slave complete process */ + I2C_ITSlaveCplt(hi2c, tmpITFlags); + } + + if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET)) + { + /* Check that I2C transfer finished */ + /* if yes, normal use case, a NACK is sent by the MASTER when Transfer is finished */ + /* Mean XferCount == 0*/ + /* So clear Flag NACKF only */ + if (hi2c->XferCount == 0U) + { + if ((hi2c->State == HAL_I2C_STATE_LISTEN) && (tmpoptions == I2C_FIRST_AND_LAST_FRAME)) + /* Same action must be done for (tmpoptions == I2C_LAST_FRAME) which removed for + Warning[Pa134]: left and right operands are identical */ + { + /* Call I2C Listen complete process */ + I2C_ITListenCplt(hi2c, tmpITFlags); + } + else if ((hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) && (tmpoptions != I2C_NO_OPTION_FRAME)) + { + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Flush TX register */ + I2C_Flush_TXDR(hi2c); + + /* Last Byte is Transmitted */ + /* Call I2C Slave Sequential complete process */ + I2C_ITSlaveSeqCplt(hi2c); + } + else + { + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + } + } + else + { + /* if no, error use case, a Non-Acknowledge of last Data is generated by the MASTER*/ + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Set ErrorCode corresponding to a Non-Acknowledge */ + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + + if ((tmpoptions == I2C_FIRST_FRAME) || (tmpoptions == I2C_NEXT_FRAME)) + { + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, hi2c->ErrorCode); + } + } + } + else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_RXI) != RESET)) + { + if (hi2c->XferCount > 0U) + { + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferSize--; + hi2c->XferCount--; + } + + if ((hi2c->XferCount == 0U) && \ + (tmpoptions != I2C_NO_OPTION_FRAME)) + { + /* Call I2C Slave Sequential complete process */ + I2C_ITSlaveSeqCplt(hi2c); + } + } + else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_ADDR) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_ADDRI) != RESET)) + { + I2C_ITAddrCplt(hi2c, tmpITFlags); + } + else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TXI) != RESET)) + { + /* Write data to TXDR only if XferCount not reach "0" */ + /* A TXIS flag can be set, during STOP treatment */ + /* Check if all Data have already been sent */ + /* If it is the case, this last write in TXDR is not sent, correspond to a dummy TXIS event */ + if (hi2c->XferCount > 0U) + { + /* Write data to TXDR */ + hi2c->Instance->TXDR = *hi2c->pBuffPtr; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + hi2c->XferCount--; + hi2c->XferSize--; + } + else + { + if ((tmpoptions == I2C_NEXT_FRAME) || (tmpoptions == I2C_FIRST_FRAME)) + { + /* Last Byte is Transmitted */ + /* Call I2C Slave Sequential complete process */ + I2C_ITSlaveSeqCplt(hi2c); + } + } + } + else + { + /* Nothing to do */ + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; +} + +/** + * @brief Interrupt Sub-Routine which handle the Interrupt Flags Master Mode with DMA. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param ITFlags Interrupt flags to handle. + * @param ITSources Interrupt sources enabled. + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_Master_ISR_DMA(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources) +{ + uint16_t devaddress; + uint32_t xfermode; + + /* Process Locked */ + __HAL_LOCK(hi2c); + + if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_AF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET)) + { + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Set corresponding Error Code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + + /* No need to generate STOP, it is automatically done */ + /* But enable STOP interrupt, to treat it */ + /* Error callback will be send during stop flag treatment */ + I2C_Enable_IRQ(hi2c, I2C_XFER_CPLT_IT); + + /* Flush TX register */ + I2C_Flush_TXDR(hi2c); + } + else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_TCR) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET)) + { + /* Disable TC interrupt */ + __HAL_I2C_DISABLE_IT(hi2c, I2C_IT_TCI); + + if (hi2c->XferCount != 0U) + { + /* Recover Slave address */ + devaddress = (uint16_t)(hi2c->Instance->CR2 & I2C_CR2_SADD); + + /* Prepare the new XferSize to transfer */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + xfermode = I2C_RELOAD_MODE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + if (hi2c->XferOptions != I2C_NO_OPTION_FRAME) + { + xfermode = hi2c->XferOptions; + } + else + { + xfermode = I2C_AUTOEND_MODE; + } + } + + /* Set the new XferSize in Nbytes register */ + I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize, xfermode, I2C_NO_STARTSTOP); + + /* Update XferCount value */ + hi2c->XferCount -= hi2c->XferSize; + + /* Enable DMA Request */ + if (hi2c->State == HAL_I2C_STATE_BUSY_RX) + { + hi2c->Instance->CR1 |= I2C_CR1_RXDMAEN; + } + else + { + hi2c->Instance->CR1 |= I2C_CR1_TXDMAEN; + } + } + else + { + /* Call TxCpltCallback() if no stop mode is set */ + if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE) + { + /* Call I2C Master Sequential complete process */ + I2C_ITMasterSeqCplt(hi2c); + } + else + { + /* Wrong size Status regarding TCR flag event */ + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE); + } + } + } + else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_TC) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET)) + { + if (hi2c->XferCount == 0U) + { + if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE) + { + /* Generate a stop condition in case of no transfer option */ + if (hi2c->XferOptions == I2C_NO_OPTION_FRAME) + { + /* Generate Stop */ + hi2c->Instance->CR2 |= I2C_CR2_STOP; + } + else + { + /* Call I2C Master Sequential complete process */ + I2C_ITMasterSeqCplt(hi2c); + } + } + } + else + { + /* Wrong size Status regarding TC flag event */ + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE); + } + } + else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_STOPF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET)) + { + /* Call I2C Master complete process */ + I2C_ITMasterCplt(hi2c, ITFlags); + } + else + { + /* Nothing to do */ + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; +} + +/** + * @brief Interrupt Sub-Routine which handle the Interrupt Flags Slave Mode with DMA. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param ITFlags Interrupt flags to handle. + * @param ITSources Interrupt sources enabled. + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_Slave_ISR_DMA(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags, + uint32_t ITSources) +{ + uint32_t tmpoptions = hi2c->XferOptions; + uint32_t treatdmanack = 0U; + HAL_I2C_StateTypeDef tmpstate; + + /* Process locked */ + __HAL_LOCK(hi2c); + + /* Check if STOPF is set */ + if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_STOPF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET)) + { + /* Call I2C Slave complete process */ + I2C_ITSlaveCplt(hi2c, ITFlags); + } + + if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_AF) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET)) + { + /* Check that I2C transfer finished */ + /* if yes, normal use case, a NACK is sent by the MASTER when Transfer is finished */ + /* Mean XferCount == 0 */ + /* So clear Flag NACKF only */ + if ((I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_TXDMAEN) != RESET) || + (I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_RXDMAEN) != RESET)) + { + /* Split check of hdmarx, for MISRA compliance */ + if (hi2c->hdmarx != NULL) + { + if (I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_RXDMAEN) != RESET) + { + if (__HAL_DMA_GET_COUNTER(hi2c->hdmarx) == 0U) + { + treatdmanack = 1U; + } + } + } + + /* Split check of hdmatx, for MISRA compliance */ + if (hi2c->hdmatx != NULL) + { + if (I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_TXDMAEN) != RESET) + { + if (__HAL_DMA_GET_COUNTER(hi2c->hdmatx) == 0U) + { + treatdmanack = 1U; + } + } + } + + if (treatdmanack == 1U) + { + if ((hi2c->State == HAL_I2C_STATE_LISTEN) && (tmpoptions == I2C_FIRST_AND_LAST_FRAME)) + /* Same action must be done for (tmpoptions == I2C_LAST_FRAME) which removed for + Warning[Pa134]: left and right operands are identical */ + { + /* Call I2C Listen complete process */ + I2C_ITListenCplt(hi2c, ITFlags); + } + else if ((hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) && (tmpoptions != I2C_NO_OPTION_FRAME)) + { + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Flush TX register */ + I2C_Flush_TXDR(hi2c); + + /* Last Byte is Transmitted */ + /* Call I2C Slave Sequential complete process */ + I2C_ITSlaveSeqCplt(hi2c); + } + else + { + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + } + } + else + { + /* if no, error use case, a Non-Acknowledge of last Data is generated by the MASTER*/ + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Set ErrorCode corresponding to a Non-Acknowledge */ + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + + /* Store current hi2c->State, solve MISRA2012-Rule-13.5 */ + tmpstate = hi2c->State; + + if ((tmpoptions == I2C_FIRST_FRAME) || (tmpoptions == I2C_NEXT_FRAME)) + { + if ((tmpstate == HAL_I2C_STATE_BUSY_TX) || (tmpstate == HAL_I2C_STATE_BUSY_TX_LISTEN)) + { + hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX; + } + else if ((tmpstate == HAL_I2C_STATE_BUSY_RX) || (tmpstate == HAL_I2C_STATE_BUSY_RX_LISTEN)) + { + hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX; + } + else + { + /* Do nothing */ + } + + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, hi2c->ErrorCode); + } + } + } + else + { + /* Only Clear NACK Flag, no DMA treatment is pending */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + } + } + else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_ADDR) != RESET) && \ + (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_ADDRI) != RESET)) + { + I2C_ITAddrCplt(hi2c, ITFlags); + } + else + { + /* Nothing to do */ + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; +} + +/** + * @brief Master sends target device address followed by internal memory address for write request. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param Timeout Timeout duration + * @param Tickstart Tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_RequestMemoryWrite(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, + uint16_t MemAddress, uint16_t MemAddSize, uint32_t Timeout, + uint32_t Tickstart) +{ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)MemAddSize, I2C_RELOAD_MODE, I2C_GENERATE_START_WRITE); + + /* Wait until TXIS flag is set */ + if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* If Memory address size is 8Bit */ + if (MemAddSize == I2C_MEMADD_SIZE_8BIT) + { + /* Send Memory Address */ + hi2c->Instance->TXDR = I2C_MEM_ADD_LSB(MemAddress); + } + /* If Memory address size is 16Bit */ + else + { + /* Send MSB of Memory Address */ + hi2c->Instance->TXDR = I2C_MEM_ADD_MSB(MemAddress); + + /* Wait until TXIS flag is set */ + if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Send LSB of Memory Address */ + hi2c->Instance->TXDR = I2C_MEM_ADD_LSB(MemAddress); + } + + /* Wait until TCR flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_TCR, RESET, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + return HAL_OK; +} + +/** + * @brief Master sends target device address followed by internal memory address for read request. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param MemAddress Internal memory address + * @param MemAddSize Size of internal memory address + * @param Timeout Timeout duration + * @param Tickstart Tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_RequestMemoryRead(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, + uint16_t MemAddress, uint16_t MemAddSize, uint32_t Timeout, + uint32_t Tickstart) +{ + I2C_TransferConfig(hi2c, DevAddress, (uint8_t)MemAddSize, I2C_SOFTEND_MODE, I2C_GENERATE_START_WRITE); + + /* Wait until TXIS flag is set */ + if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* If Memory address size is 8Bit */ + if (MemAddSize == I2C_MEMADD_SIZE_8BIT) + { + /* Send Memory Address */ + hi2c->Instance->TXDR = I2C_MEM_ADD_LSB(MemAddress); + } + /* If Memory address size is 16Bit */ + else + { + /* Send MSB of Memory Address */ + hi2c->Instance->TXDR = I2C_MEM_ADD_MSB(MemAddress); + + /* Wait until TXIS flag is set */ + if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Send LSB of Memory Address */ + hi2c->Instance->TXDR = I2C_MEM_ADD_LSB(MemAddress); + } + + /* Wait until TC flag is set */ + if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_TC, RESET, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + return HAL_OK; +} + +/** + * @brief I2C Address complete process callback. + * @param hi2c I2C handle. + * @param ITFlags Interrupt flags to handle. + * @retval None + */ +static void I2C_ITAddrCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags) +{ + uint8_t transferdirection; + uint16_t slaveaddrcode; + uint16_t ownadd1code; + uint16_t ownadd2code; + + /* Prevent unused argument(s) compilation warning */ + UNUSED(ITFlags); + + /* In case of Listen state, need to inform upper layer of address match code event */ + if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) == (uint32_t)HAL_I2C_STATE_LISTEN) + { + transferdirection = I2C_GET_DIR(hi2c); + slaveaddrcode = I2C_GET_ADDR_MATCH(hi2c); + ownadd1code = I2C_GET_OWN_ADDRESS1(hi2c); + ownadd2code = I2C_GET_OWN_ADDRESS2(hi2c); + + /* If 10bits addressing mode is selected */ + if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_10BIT) + { + if ((slaveaddrcode & SLAVE_ADDR_MSK) == ((ownadd1code >> SLAVE_ADDR_SHIFT) & SLAVE_ADDR_MSK)) + { + slaveaddrcode = ownadd1code; + hi2c->AddrEventCount++; + if (hi2c->AddrEventCount == 2U) + { + /* Reset Address Event counter */ + hi2c->AddrEventCount = 0U; + + /* Clear ADDR flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call Slave Addr callback */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->AddrCallback(hi2c, transferdirection, slaveaddrcode); +#else + HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + } + else + { + slaveaddrcode = ownadd2code; + + /* Disable ADDR Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call Slave Addr callback */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->AddrCallback(hi2c, transferdirection, slaveaddrcode); +#else + HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + } + /* else 7 bits addressing mode is selected */ + else + { + /* Disable ADDR Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call Slave Addr callback */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->AddrCallback(hi2c, transferdirection, slaveaddrcode); +#else + HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + } + /* Else clear address flag only */ + else + { + /* Clear ADDR flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + } +} + +/** + * @brief I2C Master sequential complete process. + * @param hi2c I2C handle. + * @retval None + */ +static void I2C_ITMasterSeqCplt(I2C_HandleTypeDef *hi2c) +{ + /* Reset I2C handle mode */ + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* No Generate Stop, to permit restart mode */ + /* The stop will be done at the end of transfer, when I2C_AUTOEND_MODE enable */ + if (hi2c->State == HAL_I2C_STATE_BUSY_TX) + { + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_MASTER_BUSY_TX; + hi2c->XferISR = NULL; + + /* Disable Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->MasterTxCpltCallback(hi2c); +#else + HAL_I2C_MasterTxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + /* hi2c->State == HAL_I2C_STATE_BUSY_RX */ + else + { + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_MASTER_BUSY_RX; + hi2c->XferISR = NULL; + + /* Disable Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->MasterRxCpltCallback(hi2c); +#else + HAL_I2C_MasterRxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } +} + +/** + * @brief I2C Slave sequential complete process. + * @param hi2c I2C handle. + * @retval None + */ +static void I2C_ITSlaveSeqCplt(I2C_HandleTypeDef *hi2c) +{ + uint32_t tmpcr1value = READ_REG(hi2c->Instance->CR1); + + /* Reset I2C handle mode */ + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* If a DMA is ongoing, Update handle size context */ + if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_TXDMAEN) != RESET) + { + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + } + else if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_RXDMAEN) != RESET) + { + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + } + else + { + /* Do nothing */ + } + + if (hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) + { + /* Remove HAL_I2C_STATE_SLAVE_BUSY_TX, keep only HAL_I2C_STATE_LISTEN */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX; + + /* Disable Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->SlaveTxCpltCallback(hi2c); +#else + HAL_I2C_SlaveTxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + + else if (hi2c->State == HAL_I2C_STATE_BUSY_RX_LISTEN) + { + /* Remove HAL_I2C_STATE_SLAVE_BUSY_RX, keep only HAL_I2C_STATE_LISTEN */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX; + + /* Disable Interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->SlaveRxCpltCallback(hi2c); +#else + HAL_I2C_SlaveRxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + else + { + /* Nothing to do */ + } +} + +/** + * @brief I2C Master complete process. + * @param hi2c I2C handle. + * @param ITFlags Interrupt flags to handle. + * @retval None + */ +static void I2C_ITMasterCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags) +{ + uint32_t tmperror; + uint32_t tmpITFlags = ITFlags; + __IO uint32_t tmpreg; + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Disable Interrupts and Store Previous state */ + if (hi2c->State == HAL_I2C_STATE_BUSY_TX) + { + I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT); + hi2c->PreviousState = I2C_STATE_MASTER_BUSY_TX; + } + else if (hi2c->State == HAL_I2C_STATE_BUSY_RX) + { + I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT); + hi2c->PreviousState = I2C_STATE_MASTER_BUSY_RX; + } + else + { + /* Do nothing */ + } + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + /* Reset handle parameters */ + hi2c->XferISR = NULL; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + + if (I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) + { + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Set acknowledge error code */ + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + } + + /* Fetch Last receive data if any */ + if ((hi2c->State == HAL_I2C_STATE_ABORT) && (I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET)) + { + /* Read data from RXDR */ + tmpreg = (uint8_t)hi2c->Instance->RXDR; + UNUSED(tmpreg); + } + + /* Flush TX register */ + I2C_Flush_TXDR(hi2c); + + /* Store current volatile hi2c->ErrorCode, misra rule */ + tmperror = hi2c->ErrorCode; + + /* Call the corresponding callback to inform upper layer of End of Transfer */ + if ((hi2c->State == HAL_I2C_STATE_ABORT) || (tmperror != HAL_I2C_ERROR_NONE)) + { + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, hi2c->ErrorCode); + } + /* hi2c->State == HAL_I2C_STATE_BUSY_TX */ + else if (hi2c->State == HAL_I2C_STATE_BUSY_TX) + { + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_NONE; + + if (hi2c->Mode == HAL_I2C_MODE_MEM) + { + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->MemTxCpltCallback(hi2c); +#else + HAL_I2C_MemTxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + else + { + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->MasterTxCpltCallback(hi2c); +#else + HAL_I2C_MasterTxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + } + /* hi2c->State == HAL_I2C_STATE_BUSY_RX */ + else if (hi2c->State == HAL_I2C_STATE_BUSY_RX) + { + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_NONE; + + if (hi2c->Mode == HAL_I2C_MODE_MEM) + { + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->MemRxCpltCallback(hi2c); +#else + HAL_I2C_MemRxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + else + { + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->MasterRxCpltCallback(hi2c); +#else + HAL_I2C_MasterRxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + } + else + { + /* Nothing to do */ + } +} + +/** + * @brief I2C Slave complete process. + * @param hi2c I2C handle. + * @param ITFlags Interrupt flags to handle. + * @retval None + */ +static void I2C_ITSlaveCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags) +{ + uint32_t tmpcr1value = READ_REG(hi2c->Instance->CR1); + uint32_t tmpITFlags = ITFlags; + HAL_I2C_StateTypeDef tmpstate = hi2c->State; + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Disable Interrupts and Store Previous state */ + if ((tmpstate == HAL_I2C_STATE_BUSY_TX) || (tmpstate == HAL_I2C_STATE_BUSY_TX_LISTEN)) + { + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_TX_IT); + hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX; + } + else if ((tmpstate == HAL_I2C_STATE_BUSY_RX) || (tmpstate == HAL_I2C_STATE_BUSY_RX_LISTEN)) + { + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT); + hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX; + } + else + { + /* Do nothing */ + } + + /* Disable Address Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + /* Flush TX register */ + I2C_Flush_TXDR(hi2c); + + /* If a DMA is ongoing, Update handle size context */ + if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_TXDMAEN) != RESET) + { + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + + if (hi2c->hdmatx != NULL) + { + hi2c->XferCount = (uint16_t)__HAL_DMA_GET_COUNTER(hi2c->hdmatx); + } + } + else if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_RXDMAEN) != RESET) + { + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + + if (hi2c->hdmarx != NULL) + { + hi2c->XferCount = (uint16_t)__HAL_DMA_GET_COUNTER(hi2c->hdmarx); + } + } + else + { + /* Do nothing */ + } + + /* Store Last receive data if any */ + if (I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) + { + /* Remove RXNE flag on temporary variable as read done */ + tmpITFlags &= ~I2C_FLAG_RXNE; + + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + if ((hi2c->XferSize > 0U)) + { + hi2c->XferSize--; + hi2c->XferCount--; + } + } + + /* All data are not transferred, so set error code accordingly */ + if (hi2c->XferCount != 0U) + { + /* Set ErrorCode corresponding to a Non-Acknowledge */ + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + } + + hi2c->Mode = HAL_I2C_MODE_NONE; + hi2c->XferISR = NULL; + + if (hi2c->ErrorCode != HAL_I2C_ERROR_NONE) + { + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, hi2c->ErrorCode); + + /* Call the Listen Complete callback, to inform upper layer of the end of Listen usecase */ + if (hi2c->State == HAL_I2C_STATE_LISTEN) + { + /* Call I2C Listen complete process */ + I2C_ITListenCplt(hi2c, tmpITFlags); + } + } + else if (hi2c->XferOptions != I2C_NO_OPTION_FRAME) + { + /* Call the Sequential Complete callback, to inform upper layer of the end of Transfer */ + I2C_ITSlaveSeqCplt(hi2c); + + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the Listen Complete callback, to inform upper layer of the end of Listen usecase */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->ListenCpltCallback(hi2c); +#else + HAL_I2C_ListenCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + /* Call the corresponding callback to inform upper layer of End of Transfer */ + else if (hi2c->State == HAL_I2C_STATE_BUSY_RX) + { + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->SlaveRxCpltCallback(hi2c); +#else + HAL_I2C_SlaveRxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + else + { + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->SlaveTxCpltCallback(hi2c); +#else + HAL_I2C_SlaveTxCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } +} + +/** + * @brief I2C Listen complete process. + * @param hi2c I2C handle. + * @param ITFlags Interrupt flags to handle. + * @retval None + */ +static void I2C_ITListenCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags) +{ + /* Reset handle parameters */ + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->PreviousState = I2C_STATE_NONE; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + hi2c->XferISR = NULL; + + /* Store Last receive data if any */ + if (I2C_CHECK_FLAG(ITFlags, I2C_FLAG_RXNE) != RESET) + { + /* Read data from RXDR */ + *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR; + + /* Increment Buffer pointer */ + hi2c->pBuffPtr++; + + if ((hi2c->XferSize > 0U)) + { + hi2c->XferSize--; + hi2c->XferCount--; + + /* Set ErrorCode corresponding to a Non-Acknowledge */ + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + } + } + + /* Disable all Interrupts*/ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT | I2C_XFER_TX_IT); + + /* Clear NACK Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the Listen Complete callback, to inform upper layer of the end of Listen usecase */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->ListenCpltCallback(hi2c); +#else + HAL_I2C_ListenCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ +} + +/** + * @brief I2C interrupts error process. + * @param hi2c I2C handle. + * @param ErrorCode Error code to handle. + * @retval None + */ +static void I2C_ITError(I2C_HandleTypeDef *hi2c, uint32_t ErrorCode) +{ + HAL_I2C_StateTypeDef tmpstate = hi2c->State; + uint32_t tmppreviousstate; + + /* Reset handle parameters */ + hi2c->Mode = HAL_I2C_MODE_NONE; + hi2c->XferOptions = I2C_NO_OPTION_FRAME; + hi2c->XferCount = 0U; + + /* Set new error code */ + hi2c->ErrorCode |= ErrorCode; + + /* Disable Interrupts */ + if ((tmpstate == HAL_I2C_STATE_LISTEN) || + (tmpstate == HAL_I2C_STATE_BUSY_TX_LISTEN) || + (tmpstate == HAL_I2C_STATE_BUSY_RX_LISTEN)) + { + /* Disable all interrupts, except interrupts related to LISTEN state */ + I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT | I2C_XFER_TX_IT); + + /* keep HAL_I2C_STATE_LISTEN if set */ + hi2c->State = HAL_I2C_STATE_LISTEN; + hi2c->XferISR = I2C_Slave_ISR_IT; + } + else + { + /* Disable all interrupts */ + I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT | I2C_XFER_TX_IT); + + /* If state is an abort treatment on going, don't change state */ + /* This change will be do later */ + if (hi2c->State != HAL_I2C_STATE_ABORT) + { + /* Set HAL_I2C_STATE_READY */ + hi2c->State = HAL_I2C_STATE_READY; + } + hi2c->XferISR = NULL; + } + + /* Abort DMA TX transfer if any */ + tmppreviousstate = hi2c->PreviousState; + if ((hi2c->hdmatx != NULL) && ((tmppreviousstate == I2C_STATE_MASTER_BUSY_TX) || \ + (tmppreviousstate == I2C_STATE_SLAVE_BUSY_TX))) + { + if ((hi2c->Instance->CR1 & I2C_CR1_TXDMAEN) == I2C_CR1_TXDMAEN) + { + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + } + + if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY) + { + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmatx->XferAbortCallback = I2C_DMAAbort; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hi2c->hdmatx) != HAL_OK) + { + /* Call Directly XferAbortCallback function in case of error */ + hi2c->hdmatx->XferAbortCallback(hi2c->hdmatx); + } + } + else + { + I2C_TreatErrorCallback(hi2c); + } + } + /* Abort DMA RX transfer if any */ + else if ((hi2c->hdmarx != NULL) && ((tmppreviousstate == I2C_STATE_MASTER_BUSY_RX) || \ + (tmppreviousstate == I2C_STATE_SLAVE_BUSY_RX))) + { + if ((hi2c->Instance->CR1 & I2C_CR1_RXDMAEN) == I2C_CR1_RXDMAEN) + { + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + } + + if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY) + { + /* Set the I2C DMA Abort callback : + will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */ + hi2c->hdmarx->XferAbortCallback = I2C_DMAAbort; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hi2c->hdmarx) != HAL_OK) + { + /* Call Directly hi2c->hdmarx->XferAbortCallback function in case of error */ + hi2c->hdmarx->XferAbortCallback(hi2c->hdmarx); + } + } + else + { + I2C_TreatErrorCallback(hi2c); + } + } + else + { + I2C_TreatErrorCallback(hi2c); + } +} + +/** + * @brief I2C Error callback treatment. + * @param hi2c I2C handle. + * @retval None + */ +static void I2C_TreatErrorCallback(I2C_HandleTypeDef *hi2c) +{ + if (hi2c->State == HAL_I2C_STATE_ABORT) + { + hi2c->State = HAL_I2C_STATE_READY; + hi2c->PreviousState = I2C_STATE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->AbortCpltCallback(hi2c); +#else + HAL_I2C_AbortCpltCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } + else + { + hi2c->PreviousState = I2C_STATE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1) + hi2c->ErrorCallback(hi2c); +#else + HAL_I2C_ErrorCallback(hi2c); +#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */ + } +} + +/** + * @brief I2C Tx data register flush process. + * @param hi2c I2C handle. + * @retval None + */ +static void I2C_Flush_TXDR(I2C_HandleTypeDef *hi2c) +{ + /* If a pending TXIS flag is set */ + /* Write a dummy data in TXDR to clear it */ + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXIS) != RESET) + { + hi2c->Instance->TXDR = 0x00U; + } + + /* Flush TX register if not empty */ + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXE) == RESET) + { + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_TXE); + } +} + +/** + * @brief DMA I2C master transmit process complete callback. + * @param hdma DMA handle + * @retval None + */ +static void I2C_DMAMasterTransmitCplt(DMA_HandleTypeDef *hdma) +{ + /* Derogation MISRAC2012-Rule-11.5 */ + I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); + + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + + /* If last transfer, enable STOP interrupt */ + if (hi2c->XferCount == 0U) + { + /* Enable STOP interrupt */ + I2C_Enable_IRQ(hi2c, I2C_XFER_CPLT_IT); + } + /* else prepare a new DMA transfer and enable TCReload interrupt */ + else + { + /* Update Buffer pointer */ + hi2c->pBuffPtr += hi2c->XferSize; + + /* Set the XferSize to transfer */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + } + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(hi2c->hdmatx, (uint32_t)hi2c->pBuffPtr, (uint32_t)&hi2c->Instance->TXDR, + hi2c->XferSize) != HAL_OK) + { + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, HAL_I2C_ERROR_DMA); + } + else + { + /* Enable TC interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RELOAD_IT); + } + } +} + +/** + * @brief DMA I2C slave transmit process complete callback. + * @param hdma DMA handle + * @retval None + */ +static void I2C_DMASlaveTransmitCplt(DMA_HandleTypeDef *hdma) +{ + /* Derogation MISRAC2012-Rule-11.5 */ + I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); + uint32_t tmpoptions = hi2c->XferOptions; + + if ((tmpoptions == I2C_NEXT_FRAME) || (tmpoptions == I2C_FIRST_FRAME)) + { + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN; + + /* Last Byte is Transmitted */ + /* Call I2C Slave Sequential complete process */ + I2C_ITSlaveSeqCplt(hi2c); + } + else + { + /* No specific action, Master fully manage the generation of STOP condition */ + /* Mean that this generation can arrive at any time, at the end or during DMA process */ + /* So STOP condition should be manage through Interrupt treatment */ + } +} + +/** + * @brief DMA I2C master receive process complete callback. + * @param hdma DMA handle + * @retval None + */ +static void I2C_DMAMasterReceiveCplt(DMA_HandleTypeDef *hdma) +{ + /* Derogation MISRAC2012-Rule-11.5 */ + I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); + + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + + /* If last transfer, enable STOP interrupt */ + if (hi2c->XferCount == 0U) + { + /* Enable STOP interrupt */ + I2C_Enable_IRQ(hi2c, I2C_XFER_CPLT_IT); + } + /* else prepare a new DMA transfer and enable TCReload interrupt */ + else + { + /* Update Buffer pointer */ + hi2c->pBuffPtr += hi2c->XferSize; + + /* Set the XferSize to transfer */ + if (hi2c->XferCount > MAX_NBYTE_SIZE) + { + hi2c->XferSize = MAX_NBYTE_SIZE; + } + else + { + hi2c->XferSize = hi2c->XferCount; + } + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(hi2c->hdmarx, (uint32_t)&hi2c->Instance->RXDR, (uint32_t)hi2c->pBuffPtr, + hi2c->XferSize) != HAL_OK) + { + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, HAL_I2C_ERROR_DMA); + } + else + { + /* Enable TC interrupts */ + I2C_Enable_IRQ(hi2c, I2C_XFER_RELOAD_IT); + } + } +} + +/** + * @brief DMA I2C slave receive process complete callback. + * @param hdma DMA handle + * @retval None + */ +static void I2C_DMASlaveReceiveCplt(DMA_HandleTypeDef *hdma) +{ + /* Derogation MISRAC2012-Rule-11.5 */ + I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); + uint32_t tmpoptions = hi2c->XferOptions; + + if ((__HAL_DMA_GET_COUNTER(hi2c->hdmarx) == 0U) && \ + (tmpoptions != I2C_NO_OPTION_FRAME)) + { + /* Disable DMA Request */ + hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN; + + /* Call I2C Slave Sequential complete process */ + I2C_ITSlaveSeqCplt(hi2c); + } + else + { + /* No specific action, Master fully manage the generation of STOP condition */ + /* Mean that this generation can arrive at any time, at the end or during DMA process */ + /* So STOP condition should be manage through Interrupt treatment */ + } +} + +/** + * @brief DMA I2C communication error callback. + * @param hdma DMA handle + * @retval None + */ +static void I2C_DMAError(DMA_HandleTypeDef *hdma) +{ + /* Derogation MISRAC2012-Rule-11.5 */ + I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); + + /* Disable Acknowledge */ + hi2c->Instance->CR2 |= I2C_CR2_NACK; + + /* Call the corresponding callback to inform upper layer of End of Transfer */ + I2C_ITError(hi2c, HAL_I2C_ERROR_DMA); +} + +/** + * @brief DMA I2C communication abort callback + * (To be called at end of DMA Abort procedure). + * @param hdma DMA handle. + * @retval None + */ +static void I2C_DMAAbort(DMA_HandleTypeDef *hdma) +{ + /* Derogation MISRAC2012-Rule-11.5 */ + I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); + + /* Reset AbortCpltCallback */ + if (hi2c->hdmatx != NULL) + { + hi2c->hdmatx->XferAbortCallback = NULL; + } + if (hi2c->hdmarx != NULL) + { + hi2c->hdmarx->XferAbortCallback = NULL; + } + + I2C_TreatErrorCallback(hi2c); +} + +/** + * @brief This function handles I2C Communication Timeout. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param Flag Specifies the I2C flag to check. + * @param Status The new Flag status (SET or RESET). + * @param Timeout Timeout duration + * @param Tickstart Tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_WaitOnFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Flag, FlagStatus Status, + uint32_t Timeout, uint32_t Tickstart) +{ + while (__HAL_I2C_GET_FLAG(hi2c, Flag) == Status) + { + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + return HAL_ERROR; + } + } + } + return HAL_OK; +} + +/** + * @brief This function handles I2C Communication Timeout for specific usage of TXIS flag. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param Timeout Timeout duration + * @param Tickstart Tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_WaitOnTXISFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, + uint32_t Tickstart) +{ + while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXIS) == RESET) + { + /* Check if a NACK is detected */ + if (I2C_IsAcknowledgeFailed(hi2c, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + } + return HAL_OK; +} + +/** + * @brief This function handles I2C Communication Timeout for specific usage of STOP flag. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param Timeout Timeout duration + * @param Tickstart Tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_WaitOnSTOPFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, + uint32_t Tickstart) +{ + while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET) + { + /* Check if a NACK is detected */ + if (I2C_IsAcknowledgeFailed(hi2c, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Check for the Timeout */ + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + return HAL_OK; +} + +/** + * @brief This function handles I2C Communication Timeout for specific usage of RXNE flag. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param Timeout Timeout duration + * @param Tickstart Tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_WaitOnRXNEFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout, + uint32_t Tickstart) +{ + while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_RXNE) == RESET) + { + /* Check if a NACK is detected */ + if (I2C_IsAcknowledgeFailed(hi2c, Timeout, Tickstart) != HAL_OK) + { + return HAL_ERROR; + } + + /* Check if a STOPF is detected */ + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == SET) + { + /* Check if an RXNE is pending */ + /* Store Last receive data if any */ + if ((__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_RXNE) == SET) && (hi2c->XferSize > 0U)) + { + /* Return HAL_OK */ + /* The Reading of data from RXDR will be done in caller function */ + return HAL_OK; + } + else + { + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + hi2c->ErrorCode = HAL_I2C_ERROR_NONE; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + + /* Check for the Timeout */ + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT; + hi2c->State = HAL_I2C_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + return HAL_OK; +} + +/** + * @brief This function handles Acknowledge failed detection during an I2C Communication. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param Timeout Timeout duration + * @param Tickstart Tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef I2C_IsAcknowledgeFailed(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart) +{ + if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF) == SET) + { + /* In case of Soft End condition, generate the STOP condition */ + if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE) + { + /* Generate Stop */ + hi2c->Instance->CR2 |= I2C_CR2_STOP; + } + /* Wait until STOP Flag is reset */ + /* AutoEnd should be initiate after AF */ + while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET) + { + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + } + } + + /* Clear NACKF Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF); + + /* Clear STOP Flag */ + __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF); + + /* Flush TX register */ + I2C_Flush_TXDR(hi2c); + + /* Clear Configuration Register 2 */ + I2C_RESET_CR2(hi2c); + + hi2c->ErrorCode |= HAL_I2C_ERROR_AF; + hi2c->State = HAL_I2C_STATE_READY; + hi2c->Mode = HAL_I2C_MODE_NONE; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_ERROR; + } + return HAL_OK; +} + +/** + * @brief Handles I2Cx communication when starting transfer or during transfer (TC or TCR flag are set). + * @param hi2c I2C handle. + * @param DevAddress Specifies the slave address to be programmed. + * @param Size Specifies the number of bytes to be programmed. + * This parameter must be a value between 0 and 255. + * @param Mode New state of the I2C START condition generation. + * This parameter can be one of the following values: + * @arg @ref I2C_RELOAD_MODE Enable Reload mode . + * @arg @ref I2C_AUTOEND_MODE Enable Automatic end mode. + * @arg @ref I2C_SOFTEND_MODE Enable Software end mode. + * @param Request New state of the I2C START condition generation. + * This parameter can be one of the following values: + * @arg @ref I2C_NO_STARTSTOP Don't Generate stop and start condition. + * @arg @ref I2C_GENERATE_STOP Generate stop condition (Size should be set to 0). + * @arg @ref I2C_GENERATE_START_READ Generate Restart for read request. + * @arg @ref I2C_GENERATE_START_WRITE Generate Restart for write request. + * @retval None + */ +static void I2C_TransferConfig(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t Size, uint32_t Mode, + uint32_t Request) +{ + /* Check the parameters */ + assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance)); + assert_param(IS_TRANSFER_MODE(Mode)); + assert_param(IS_TRANSFER_REQUEST(Request)); + + /* update CR2 register */ + MODIFY_REG(hi2c->Instance->CR2, + ((I2C_CR2_SADD | I2C_CR2_NBYTES | I2C_CR2_RELOAD | I2C_CR2_AUTOEND | \ + (I2C_CR2_RD_WRN & (uint32_t)(Request >> (31U - I2C_CR2_RD_WRN_Pos))) | \ + I2C_CR2_START | I2C_CR2_STOP)), \ + (uint32_t)(((uint32_t)DevAddress & I2C_CR2_SADD) | \ + (((uint32_t)Size << I2C_CR2_NBYTES_Pos) & I2C_CR2_NBYTES) | \ + (uint32_t)Mode | (uint32_t)Request)); +} + +/** + * @brief Manage the enabling of Interrupts. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param InterruptRequest Value of @ref I2C_Interrupt_configuration_definition. + * @retval None + */ +static void I2C_Enable_IRQ(I2C_HandleTypeDef *hi2c, uint16_t InterruptRequest) +{ + uint32_t tmpisr = 0U; + + if ((hi2c->XferISR == I2C_Master_ISR_DMA) || \ + (hi2c->XferISR == I2C_Slave_ISR_DMA)) + { + if ((InterruptRequest & I2C_XFER_LISTEN_IT) == I2C_XFER_LISTEN_IT) + { + /* Enable ERR, STOP, NACK and ADDR interrupts */ + tmpisr |= I2C_IT_ADDRI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI; + } + + if (InterruptRequest == I2C_XFER_ERROR_IT) + { + /* Enable ERR and NACK interrupts */ + tmpisr |= I2C_IT_ERRI | I2C_IT_NACKI; + } + + if (InterruptRequest == I2C_XFER_CPLT_IT) + { + /* Enable STOP interrupts */ + tmpisr |= (I2C_IT_STOPI | I2C_IT_TCI); + } + + if (InterruptRequest == I2C_XFER_RELOAD_IT) + { + /* Enable TC interrupts */ + tmpisr |= I2C_IT_TCI; + } + } + else + { + if ((InterruptRequest & I2C_XFER_LISTEN_IT) == I2C_XFER_LISTEN_IT) + { + /* Enable ERR, STOP, NACK, and ADDR interrupts */ + tmpisr |= I2C_IT_ADDRI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI; + } + + if ((InterruptRequest & I2C_XFER_TX_IT) == I2C_XFER_TX_IT) + { + /* Enable ERR, TC, STOP, NACK and RXI interrupts */ + tmpisr |= I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_TXI; + } + + if ((InterruptRequest & I2C_XFER_RX_IT) == I2C_XFER_RX_IT) + { + /* Enable ERR, TC, STOP, NACK and TXI interrupts */ + tmpisr |= I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_RXI; + } + + if (InterruptRequest == I2C_XFER_CPLT_IT) + { + /* Enable STOP interrupts */ + tmpisr |= I2C_IT_STOPI; + } + } + + /* Enable interrupts only at the end */ + /* to avoid the risk of I2C interrupt handle execution before */ + /* all interrupts requested done */ + __HAL_I2C_ENABLE_IT(hi2c, tmpisr); +} + +/** + * @brief Manage the disabling of Interrupts. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2C. + * @param InterruptRequest Value of @ref I2C_Interrupt_configuration_definition. + * @retval None + */ +static void I2C_Disable_IRQ(I2C_HandleTypeDef *hi2c, uint16_t InterruptRequest) +{ + uint32_t tmpisr = 0U; + + if ((InterruptRequest & I2C_XFER_TX_IT) == I2C_XFER_TX_IT) + { + /* Disable TC and TXI interrupts */ + tmpisr |= I2C_IT_TCI | I2C_IT_TXI; + + if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) != (uint32_t)HAL_I2C_STATE_LISTEN) + { + /* Disable NACK and STOP interrupts */ + tmpisr |= I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI; + } + } + + if ((InterruptRequest & I2C_XFER_RX_IT) == I2C_XFER_RX_IT) + { + /* Disable TC and RXI interrupts */ + tmpisr |= I2C_IT_TCI | I2C_IT_RXI; + + if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) != (uint32_t)HAL_I2C_STATE_LISTEN) + { + /* Disable NACK and STOP interrupts */ + tmpisr |= I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI; + } + } + + if ((InterruptRequest & I2C_XFER_LISTEN_IT) == I2C_XFER_LISTEN_IT) + { + /* Disable ADDR, NACK and STOP interrupts */ + tmpisr |= I2C_IT_ADDRI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI; + } + + if (InterruptRequest == I2C_XFER_ERROR_IT) + { + /* Enable ERR and NACK interrupts */ + tmpisr |= I2C_IT_ERRI | I2C_IT_NACKI; + } + + if (InterruptRequest == I2C_XFER_CPLT_IT) + { + /* Enable STOP interrupts */ + tmpisr |= I2C_IT_STOPI; + } + + if (InterruptRequest == I2C_XFER_RELOAD_IT) + { + /* Enable TC interrupts */ + tmpisr |= I2C_IT_TCI; + } + + /* Disable interrupts only at the end */ + /* to avoid a breaking situation like at "t" time */ + /* all disable interrupts request are not done */ + __HAL_I2C_DISABLE_IT(hi2c, tmpisr); +} + +/** + * @brief Convert I2Cx OTHER_xxx XferOptions to functional XferOptions. + * @param hi2c I2C handle. + * @retval None + */ +static void I2C_ConvertOtherXferOptions(I2C_HandleTypeDef *hi2c) +{ + /* if user set XferOptions to I2C_OTHER_FRAME */ + /* it request implicitly to generate a restart condition */ + /* set XferOptions to I2C_FIRST_FRAME */ + if (hi2c->XferOptions == I2C_OTHER_FRAME) + { + hi2c->XferOptions = I2C_FIRST_FRAME; + } + /* else if user set XferOptions to I2C_OTHER_AND_LAST_FRAME */ + /* it request implicitly to generate a restart condition */ + /* then generate a stop condition at the end of transfer */ + /* set XferOptions to I2C_FIRST_AND_LAST_FRAME */ + else if (hi2c->XferOptions == I2C_OTHER_AND_LAST_FRAME) + { + hi2c->XferOptions = I2C_FIRST_AND_LAST_FRAME; + } + else + { + /* Nothing to do */ + } +} + +/** + * @} + */ + +#endif /* HAL_I2C_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c_ex.c new file mode 100644 index 0000000..f6d8267 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2c_ex.c @@ -0,0 +1,365 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_i2c_ex.c + * @author MCD Application Team + * @brief I2C Extended HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of I2C Extended peripheral: + * + Filter Mode Functions + * + WakeUp Mode Functions + * + FastModePlus Functions + * + @verbatim + ============================================================================== + ##### I2C peripheral Extended features ##### + ============================================================================== + + [..] Comparing to other previous devices, the I2C interface for STM32F0xx + devices contains the following additional features + + (+) Possibility to disable or enable Analog Noise Filter + (+) Use of a configured Digital Noise Filter + (+) Disable or enable wakeup from Stop mode(s) + (+) Disable or enable Fast Mode Plus + + ##### How to use this driver ##### + ============================================================================== + [..] This driver provides functions to configure Noise Filter and Wake Up Feature + (#) Configure I2C Analog noise filter using the function HAL_I2CEx_ConfigAnalogFilter() + (#) Configure I2C Digital noise filter using the function HAL_I2CEx_ConfigDigitalFilter() + (#) Configure the enable or disable of I2C Wake Up Mode using the functions : + (++) HAL_I2CEx_EnableWakeUp() + (++) HAL_I2CEx_DisableWakeUp() + (#) Configure the enable or disable of fast mode plus driving capability using the functions : + (++) HAL_I2CEx_EnableFastModePlus() + (++) HAL_I2CEx_DisableFastModePlus() + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup I2CEx I2CEx + * @brief I2C Extended HAL module driver + * @{ + */ + +#ifdef HAL_I2C_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + +/** @defgroup I2CEx_Exported_Functions I2C Extended Exported Functions + * @{ + */ + +/** @defgroup I2CEx_Exported_Functions_Group1 Filter Mode Functions + * @brief Filter Mode Functions + * +@verbatim + =============================================================================== + ##### Filter Mode Functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Configure Noise Filters + +@endverbatim + * @{ + */ + +/** + * @brief Configure I2C Analog noise filter. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2Cx peripheral. + * @param AnalogFilter New state of the Analog filter. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2CEx_ConfigAnalogFilter(I2C_HandleTypeDef *hi2c, uint32_t AnalogFilter) +{ + /* Check the parameters */ + assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance)); + assert_param(IS_I2C_ANALOG_FILTER(AnalogFilter)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY; + + /* Disable the selected I2C peripheral */ + __HAL_I2C_DISABLE(hi2c); + + /* Reset I2Cx ANOFF bit */ + hi2c->Instance->CR1 &= ~(I2C_CR1_ANFOFF); + + /* Set analog filter bit*/ + hi2c->Instance->CR1 |= AnalogFilter; + + __HAL_I2C_ENABLE(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Configure I2C Digital noise filter. + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2Cx peripheral. + * @param DigitalFilter Coefficient of digital noise filter between Min_Data=0x00 and Max_Data=0x0F. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2CEx_ConfigDigitalFilter(I2C_HandleTypeDef *hi2c, uint32_t DigitalFilter) +{ + uint32_t tmpreg; + + /* Check the parameters */ + assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance)); + assert_param(IS_I2C_DIGITAL_FILTER(DigitalFilter)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY; + + /* Disable the selected I2C peripheral */ + __HAL_I2C_DISABLE(hi2c); + + /* Get the old register value */ + tmpreg = hi2c->Instance->CR1; + + /* Reset I2Cx DNF bits [11:8] */ + tmpreg &= ~(I2C_CR1_DNF); + + /* Set I2Cx DNF coefficient */ + tmpreg |= DigitalFilter << 8U; + + /* Store the new register value */ + hi2c->Instance->CR1 = tmpreg; + + __HAL_I2C_ENABLE(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} +/** + * @} + */ +#if defined(I2C_CR1_WUPEN) + +/** @defgroup I2CEx_Exported_Functions_Group2 WakeUp Mode Functions + * @brief WakeUp Mode Functions + * +@verbatim + =============================================================================== + ##### WakeUp Mode Functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Configure Wake Up Feature + +@endverbatim + * @{ + */ + +/** + * @brief Enable I2C wakeup from Stop mode(s). + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2Cx peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2CEx_EnableWakeUp(I2C_HandleTypeDef *hi2c) +{ + /* Check the parameters */ + assert_param(IS_I2C_WAKEUP_FROMSTOP_INSTANCE(hi2c->Instance)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY; + + /* Disable the selected I2C peripheral */ + __HAL_I2C_DISABLE(hi2c); + + /* Enable wakeup from stop mode */ + hi2c->Instance->CR1 |= I2C_CR1_WUPEN; + + __HAL_I2C_ENABLE(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Disable I2C wakeup from Stop mode(s). + * @param hi2c Pointer to a I2C_HandleTypeDef structure that contains + * the configuration information for the specified I2Cx peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2CEx_DisableWakeUp(I2C_HandleTypeDef *hi2c) +{ + /* Check the parameters */ + assert_param(IS_I2C_WAKEUP_FROMSTOP_INSTANCE(hi2c->Instance)); + + if (hi2c->State == HAL_I2C_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hi2c); + + hi2c->State = HAL_I2C_STATE_BUSY; + + /* Disable the selected I2C peripheral */ + __HAL_I2C_DISABLE(hi2c); + + /* Enable wakeup from stop mode */ + hi2c->Instance->CR1 &= ~(I2C_CR1_WUPEN); + + __HAL_I2C_ENABLE(hi2c); + + hi2c->State = HAL_I2C_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2c); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} +/** + * @} + */ +#endif /* I2C_CR1_WUPEN */ + +/** @defgroup I2CEx_Exported_Functions_Group3 Fast Mode Plus Functions + * @brief Fast Mode Plus Functions + * +@verbatim + =============================================================================== + ##### Fast Mode Plus Functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Configure Fast Mode Plus + +@endverbatim + * @{ + */ + +/** + * @brief Enable the I2C fast mode plus driving capability. + * @param ConfigFastModePlus Selects the pin. + * This parameter can be one of the @ref I2CEx_FastModePlus values + * @note For I2C1, fast mode plus driving capability can be enabled on all selected + * I2C1 pins using I2C_FASTMODEPLUS_I2C1 parameter or independently + * on each one of the following pins PB6, PB7, PB8 and PB9. + * @note For remaining I2C1 pins (PA14, PA15...) fast mode plus driving capability + * can be enabled only by using I2C_FASTMODEPLUS_I2C1 parameter. + * @note For all I2C2 pins fast mode plus driving capability can be enabled + * only by using I2C_FASTMODEPLUS_I2C2 parameter. + * @retval None + */ +void HAL_I2CEx_EnableFastModePlus(uint32_t ConfigFastModePlus) +{ + /* Check the parameter */ + assert_param(IS_I2C_FASTMODEPLUS(ConfigFastModePlus)); + + /* Enable SYSCFG clock */ + __HAL_RCC_SYSCFG_CLK_ENABLE(); + + /* Enable fast mode plus driving capability for selected pin */ + SET_BIT(SYSCFG->CFGR1, (uint32_t)ConfigFastModePlus); +} + +/** + * @brief Disable the I2C fast mode plus driving capability. + * @param ConfigFastModePlus Selects the pin. + * This parameter can be one of the @ref I2CEx_FastModePlus values + * @note For I2C1, fast mode plus driving capability can be disabled on all selected + * I2C1 pins using I2C_FASTMODEPLUS_I2C1 parameter or independently + * on each one of the following pins PB6, PB7, PB8 and PB9. + * @note For remaining I2C1 pins (PA14, PA15...) fast mode plus driving capability + * can be disabled only by using I2C_FASTMODEPLUS_I2C1 parameter. + * @note For all I2C2 pins fast mode plus driving capability can be disabled + * only by using I2C_FASTMODEPLUS_I2C2 parameter. + * @retval None + */ +void HAL_I2CEx_DisableFastModePlus(uint32_t ConfigFastModePlus) +{ + /* Check the parameter */ + assert_param(IS_I2C_FASTMODEPLUS(ConfigFastModePlus)); + + /* Enable SYSCFG clock */ + __HAL_RCC_SYSCFG_CLK_ENABLE(); + + /* Disable fast mode plus driving capability for selected pin */ + CLEAR_BIT(SYSCFG->CFGR1, (uint32_t)ConfigFastModePlus); +} +/** + * @} + */ +/** + * @} + */ + +#endif /* HAL_I2C_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2s.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2s.c new file mode 100644 index 0000000..fa82f08 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_i2s.c @@ -0,0 +1,1800 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_i2s.c + * @author MCD Application Team + * @brief I2S HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Integrated Interchip Sound (I2S) peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral State and Errors functions + @verbatim + =============================================================================== + ##### How to use this driver ##### + =============================================================================== + [..] + The I2S HAL driver can be used as follow: + + (#) Declare a I2S_HandleTypeDef handle structure. + (#) Initialize the I2S low level resources by implement the HAL_I2S_MspInit() API: + (##) Enable the SPIx interface clock. + (##) I2S pins configuration: + (+++) Enable the clock for the I2S GPIOs. + (+++) Configure these I2S pins as alternate function pull-up. + (##) NVIC configuration if you need to use interrupt process (HAL_I2S_Transmit_IT() + and HAL_I2S_Receive_IT() APIs). + (+++) Configure the I2Sx interrupt priority. + (+++) Enable the NVIC I2S IRQ handle. + (##) DMA Configuration if you need to use DMA process (HAL_I2S_Transmit_DMA() + and HAL_I2S_Receive_DMA() APIs: + (+++) Declare a DMA handle structure for the Tx/Rx Stream/Channel. + (+++) Enable the DMAx interface clock. + (+++) Configure the declared DMA handle structure with the required Tx/Rx parameters. + (+++) Configure the DMA Tx/Rx Stream/Channel. + (+++) Associate the initialized DMA handle to the I2S DMA Tx/Rx handle. + (+++) Configure the priority and enable the NVIC for the transfer complete interrupt on the + DMA Tx/Rx Stream/Channel. + + (#) Program the Mode, Standard, Data Format, MCLK Output, Audio frequency and Polarity + using HAL_I2S_Init() function. + + -@- The specific I2S interrupts (Transmission complete interrupt, + RXNE interrupt and Error Interrupts) will be managed using the macros + __HAL_I2S_ENABLE_IT() and __HAL_I2S_DISABLE_IT() inside the transmit and receive process. + -@- Make sure that either: + (+@) External clock source is configured after setting correctly + the define constant EXTERNAL_CLOCK_VALUE in the stm32f0xx_hal_conf.h file. + + (#) Three mode of operations are available within this driver : + + *** Polling mode IO operation *** + ================================= + [..] + (+) Send an amount of data in blocking mode using HAL_I2S_Transmit() + (+) Receive an amount of data in blocking mode using HAL_I2S_Receive() + + *** Interrupt mode IO operation *** + =================================== + [..] + (+) Send an amount of data in non blocking mode using HAL_I2S_Transmit_IT() + (+) At transmission end of half transfer HAL_I2S_TxHalfCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_TxHalfCpltCallback + (+) At transmission end of transfer HAL_I2S_TxCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_TxCpltCallback + (+) Receive an amount of data in non blocking mode using HAL_I2S_Receive_IT() + (+) At reception end of half transfer HAL_I2S_RxHalfCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_RxHalfCpltCallback + (+) At reception end of transfer HAL_I2S_RxCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_RxCpltCallback + (+) In case of transfer Error, HAL_I2S_ErrorCallback() function is executed and user can + add his own code by customization of function pointer HAL_I2S_ErrorCallback + + *** DMA mode IO operation *** + ============================== + [..] + (+) Send an amount of data in non blocking mode (DMA) using HAL_I2S_Transmit_DMA() + (+) At transmission end of half transfer HAL_I2S_TxHalfCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_TxHalfCpltCallback + (+) At transmission end of transfer HAL_I2S_TxCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_TxCpltCallback + (+) Receive an amount of data in non blocking mode (DMA) using HAL_I2S_Receive_DMA() + (+) At reception end of half transfer HAL_I2S_RxHalfCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_RxHalfCpltCallback + (+) At reception end of transfer HAL_I2S_RxCpltCallback is executed and user can + add his own code by customization of function pointer HAL_I2S_RxCpltCallback + (+) In case of transfer Error, HAL_I2S_ErrorCallback() function is executed and user can + add his own code by customization of function pointer HAL_I2S_ErrorCallback + (+) Pause the DMA Transfer using HAL_I2S_DMAPause() + (+) Resume the DMA Transfer using HAL_I2S_DMAResume() + (+) Stop the DMA Transfer using HAL_I2S_DMAStop() + + *** I2S HAL driver macros list *** + =================================== + [..] + Below the list of most used macros in I2S HAL driver. + + (+) __HAL_I2S_ENABLE: Enable the specified SPI peripheral (in I2S mode) + (+) __HAL_I2S_DISABLE: Disable the specified SPI peripheral (in I2S mode) + (+) __HAL_I2S_ENABLE_IT : Enable the specified I2S interrupts + (+) __HAL_I2S_DISABLE_IT : Disable the specified I2S interrupts + (+) __HAL_I2S_GET_FLAG: Check whether the specified I2S flag is set or not + + [..] + (@) You can refer to the I2S HAL driver header file for more useful macros + + *** I2S HAL driver macros list *** + =================================== + [..] + Callback registration: + + (#) The compilation flag USE_HAL_I2S_REGISTER_CALLBACKS when set to 1U + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_I2S_RegisterCallback() to register an interrupt callback. + + Function HAL_I2S_RegisterCallback() allows to register following callbacks: + (++) TxCpltCallback : I2S Tx Completed callback + (++) RxCpltCallback : I2S Rx Completed callback + (++) TxHalfCpltCallback : I2S Tx Half Completed callback + (++) RxHalfCpltCallback : I2S Rx Half Completed callback + (++) ErrorCallback : I2S Error callback + (++) MspInitCallback : I2S Msp Init callback + (++) MspDeInitCallback : I2S Msp DeInit callback + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + + (#) Use function HAL_I2S_UnRegisterCallback to reset a callback to the default + weak function. + HAL_I2S_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (++) TxCpltCallback : I2S Tx Completed callback + (++) RxCpltCallback : I2S Rx Completed callback + (++) TxHalfCpltCallback : I2S Tx Half Completed callback + (++) RxHalfCpltCallback : I2S Rx Half Completed callback + (++) ErrorCallback : I2S Error callback + (++) MspInitCallback : I2S Msp Init callback + (++) MspDeInitCallback : I2S Msp DeInit callback + + [..] + By default, after the HAL_I2S_Init() and when the state is HAL_I2S_STATE_RESET + all callbacks are set to the corresponding weak functions: + examples HAL_I2S_MasterTxCpltCallback(), HAL_I2S_MasterRxCpltCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak functions in the HAL_I2S_Init()/ HAL_I2S_DeInit() only when + these callbacks are null (not registered beforehand). + If MspInit or MspDeInit are not null, the HAL_I2S_Init()/ HAL_I2S_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state. + + [..] + Callbacks can be registered/unregistered in HAL_I2S_STATE_READY state only. + Exception done MspInit/MspDeInit functions that can be registered/unregistered + in HAL_I2S_STATE_READY or HAL_I2S_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + Then, the user first registers the MspInit/MspDeInit user callbacks + using HAL_I2S_RegisterCallback() before calling HAL_I2S_DeInit() + or HAL_I2S_Init() function. + + [..] + When the compilation define USE_HAL_I2S_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registering feature is not available + and weak (surcharged) callbacks are used. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +#ifdef HAL_I2S_MODULE_ENABLED + +#if defined(SPI_I2S_SUPPORT) +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup I2S I2S + * @brief I2S HAL module driver + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup I2S_Private_Functions I2S Private Functions + * @{ + */ +static void I2S_DMATxCplt(DMA_HandleTypeDef *hdma); +static void I2S_DMATxHalfCplt(DMA_HandleTypeDef *hdma); +static void I2S_DMARxCplt(DMA_HandleTypeDef *hdma); +static void I2S_DMARxHalfCplt(DMA_HandleTypeDef *hdma); +static void I2S_DMAError(DMA_HandleTypeDef *hdma); +static void I2S_Transmit_IT(I2S_HandleTypeDef *hi2s); +static void I2S_Receive_IT(I2S_HandleTypeDef *hi2s); +static HAL_StatusTypeDef I2S_WaitFlagStateUntilTimeout(I2S_HandleTypeDef *hi2s, uint32_t Flag, FlagStatus State, + uint32_t Timeout); +/** + * @} + */ + +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup I2S_Exported_Functions I2S Exported Functions + * @{ + */ + +/** @defgroup I2S_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This subsection provides a set of functions allowing to initialize and + de-initialize the I2Sx peripheral in simplex mode: + + (+) User must Implement HAL_I2S_MspInit() function in which he configures + all related peripherals resources (CLOCK, GPIO, DMA, IT and NVIC ). + + (+) Call the function HAL_I2S_Init() to configure the selected device with + the selected configuration: + (++) Mode + (++) Standard + (++) Data Format + (++) MCLK Output + (++) Audio frequency + (++) Polarity + + (+) Call the function HAL_I2S_DeInit() to restore the default configuration + of the selected I2Sx peripheral. + @endverbatim + * @{ + */ + +/** + * @brief Initializes the I2S according to the specified parameters + * in the I2S_InitTypeDef and create the associated handle. + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_Init(I2S_HandleTypeDef *hi2s) +{ + uint32_t i2sdiv; + uint32_t i2sodd; + uint32_t packetlength; + uint32_t tmp; + uint32_t i2sclk; + + /* Check the I2S handle allocation */ + if (hi2s == NULL) + { + return HAL_ERROR; + } + + /* Check the I2S parameters */ + assert_param(IS_I2S_ALL_INSTANCE(hi2s->Instance)); + assert_param(IS_I2S_MODE(hi2s->Init.Mode)); + assert_param(IS_I2S_STANDARD(hi2s->Init.Standard)); + assert_param(IS_I2S_DATA_FORMAT(hi2s->Init.DataFormat)); + assert_param(IS_I2S_MCLK_OUTPUT(hi2s->Init.MCLKOutput)); + assert_param(IS_I2S_AUDIO_FREQ(hi2s->Init.AudioFreq)); + assert_param(IS_I2S_CPOL(hi2s->Init.CPOL)); + + if (hi2s->State == HAL_I2S_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hi2s->Lock = HAL_UNLOCKED; + +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + /* Init the I2S Callback settings */ + hi2s->TxCpltCallback = HAL_I2S_TxCpltCallback; /* Legacy weak TxCpltCallback */ + hi2s->RxCpltCallback = HAL_I2S_RxCpltCallback; /* Legacy weak RxCpltCallback */ + hi2s->TxHalfCpltCallback = HAL_I2S_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + hi2s->RxHalfCpltCallback = HAL_I2S_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + hi2s->ErrorCallback = HAL_I2S_ErrorCallback; /* Legacy weak ErrorCallback */ + + if (hi2s->MspInitCallback == NULL) + { + hi2s->MspInitCallback = HAL_I2S_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware : GPIO, CLOCK, NVIC... */ + hi2s->MspInitCallback(hi2s); +#else + /* Init the low level hardware : GPIO, CLOCK, CORTEX...etc */ + HAL_I2S_MspInit(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ + } + + hi2s->State = HAL_I2S_STATE_BUSY; + + /*----------------------- SPIx I2SCFGR & I2SPR Configuration ----------------*/ + /* Clear I2SMOD, I2SE, I2SCFG, PCMSYNC, I2SSTD, CKPOL, DATLEN and CHLEN bits */ + CLEAR_BIT(hi2s->Instance->I2SCFGR, (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CKPOL | \ + SPI_I2SCFGR_I2SSTD | SPI_I2SCFGR_PCMSYNC | SPI_I2SCFGR_I2SCFG | \ + SPI_I2SCFGR_I2SE | SPI_I2SCFGR_I2SMOD)); + hi2s->Instance->I2SPR = 0x0002U; + + /*----------------------- I2SPR: I2SDIV and ODD Calculation -----------------*/ + /* If the requested audio frequency is not the default, compute the prescaler */ + if (hi2s->Init.AudioFreq != I2S_AUDIOFREQ_DEFAULT) + { + /* Check the frame length (For the Prescaler computing) ********************/ + if (hi2s->Init.DataFormat == I2S_DATAFORMAT_16B) + { + /* Packet length is 16 bits */ + packetlength = 16U; + } + else + { + /* Packet length is 32 bits */ + packetlength = 32U; + } + + /* I2S standard */ + if (hi2s->Init.Standard <= I2S_STANDARD_LSB) + { + /* In I2S standard packet length is multiplied by 2 */ + packetlength = packetlength * 2U; + } + + /* Get the source clock value: based on System Clock value */ + i2sclk = HAL_RCC_GetSysClockFreq(); + + /* Compute the Real divider depending on the MCLK output state, with a floating point */ + if (hi2s->Init.MCLKOutput == I2S_MCLKOUTPUT_ENABLE) + { + /* MCLK output is enabled */ + if (hi2s->Init.DataFormat != I2S_DATAFORMAT_16B) + { + tmp = (uint32_t)(((((i2sclk / (packetlength * 4U)) * 10U) / hi2s->Init.AudioFreq)) + 5U); + } + else + { + tmp = (uint32_t)(((((i2sclk / (packetlength * 8U)) * 10U) / hi2s->Init.AudioFreq)) + 5U); + } + } + else + { + /* MCLK output is disabled */ + tmp = (uint32_t)(((((i2sclk / packetlength) * 10U) / hi2s->Init.AudioFreq)) + 5U); + } + + /* Remove the flatting point */ + tmp = tmp / 10U; + + /* Check the parity of the divider */ + i2sodd = (uint32_t)(tmp & (uint32_t)1U); + + /* Compute the i2sdiv prescaler */ + i2sdiv = (uint32_t)((tmp - i2sodd) / 2U); + + /* Get the Mask for the Odd bit (SPI_I2SPR[8]) register */ + i2sodd = (uint32_t)(i2sodd << 8U); + } + else + { + /* Set the default values */ + i2sdiv = 2U; + i2sodd = 0U; + } + + /* Test if the divider is 1 or 0 or greater than 0xFF */ + if ((i2sdiv < 2U) || (i2sdiv > 0xFFU)) + { + /* Set the error code and execute error callback*/ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_PRESCALER); + return HAL_ERROR; + } + + /*----------------------- SPIx I2SCFGR & I2SPR Configuration ----------------*/ + + /* Write to SPIx I2SPR register the computed value */ + hi2s->Instance->I2SPR = (uint32_t)((uint32_t)i2sdiv | (uint32_t)(i2sodd | (uint32_t)hi2s->Init.MCLKOutput)); + + /* Clear I2SMOD, I2SE, I2SCFG, PCMSYNC, I2SSTD, CKPOL, DATLEN and CHLEN bits */ + /* And configure the I2S with the I2S_InitStruct values */ + MODIFY_REG(hi2s->Instance->I2SCFGR, (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN | \ + SPI_I2SCFGR_CKPOL | SPI_I2SCFGR_I2SSTD | \ + SPI_I2SCFGR_PCMSYNC | SPI_I2SCFGR_I2SCFG | \ + SPI_I2SCFGR_I2SE | SPI_I2SCFGR_I2SMOD), \ + (SPI_I2SCFGR_I2SMOD | hi2s->Init.Mode | \ + hi2s->Init.Standard | hi2s->Init.DataFormat | \ + hi2s->Init.CPOL)); + +#if defined(SPI_I2SCFGR_ASTRTEN) + if ((hi2s->Init.Standard == I2S_STANDARD_PCM_SHORT) || ((hi2s->Init.Standard == I2S_STANDARD_PCM_LONG))) + { + /* Write to SPIx I2SCFGR */ + SET_BIT(hi2s->Instance->I2SCFGR, SPI_I2SCFGR_ASTRTEN); + } +#endif /* SPI_I2SCFGR_ASTRTEN */ + + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->State = HAL_I2S_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the I2S peripheral + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_DeInit(I2S_HandleTypeDef *hi2s) +{ + /* Check the I2S handle allocation */ + if (hi2s == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_I2S_ALL_INSTANCE(hi2s->Instance)); + + hi2s->State = HAL_I2S_STATE_BUSY; + + /* Disable the I2S Peripheral Clock */ + __HAL_I2S_DISABLE(hi2s); + +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + if (hi2s->MspDeInitCallback == NULL) + { + hi2s->MspDeInitCallback = HAL_I2S_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware: GPIO, CLOCK, NVIC... */ + hi2s->MspDeInitCallback(hi2s); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC... */ + HAL_I2S_MspDeInit(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ + + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->State = HAL_I2S_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(hi2s); + + return HAL_OK; +} + +/** + * @brief I2S MSP Init + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +__weak void HAL_I2S_MspInit(I2S_HandleTypeDef *hi2s) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2s); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_I2S_MspInit could be implemented in the user file + */ +} + +/** + * @brief I2S MSP DeInit + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +__weak void HAL_I2S_MspDeInit(I2S_HandleTypeDef *hi2s) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2s); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_I2S_MspDeInit could be implemented in the user file + */ +} + +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) +/** + * @brief Register a User I2S Callback + * To be used instead of the weak predefined callback + * @param hi2s Pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for the specified I2S. + * @param CallbackID ID of the callback to be registered + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_RegisterCallback(I2S_HandleTypeDef *hi2s, HAL_I2S_CallbackIDTypeDef CallbackID, + pI2S_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hi2s->ErrorCode |= HAL_I2S_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hi2s); + + if (HAL_I2S_STATE_READY == hi2s->State) + { + switch (CallbackID) + { + case HAL_I2S_TX_COMPLETE_CB_ID : + hi2s->TxCpltCallback = pCallback; + break; + + case HAL_I2S_RX_COMPLETE_CB_ID : + hi2s->RxCpltCallback = pCallback; + break; + + case HAL_I2S_TX_HALF_COMPLETE_CB_ID : + hi2s->TxHalfCpltCallback = pCallback; + break; + + case HAL_I2S_RX_HALF_COMPLETE_CB_ID : + hi2s->RxHalfCpltCallback = pCallback; + break; + + case HAL_I2S_ERROR_CB_ID : + hi2s->ErrorCallback = pCallback; + break; + + case HAL_I2S_MSPINIT_CB_ID : + hi2s->MspInitCallback = pCallback; + break; + + case HAL_I2S_MSPDEINIT_CB_ID : + hi2s->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_I2S_STATE_RESET == hi2s->State) + { + switch (CallbackID) + { + case HAL_I2S_MSPINIT_CB_ID : + hi2s->MspInitCallback = pCallback; + break; + + case HAL_I2S_MSPDEINIT_CB_ID : + hi2s->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hi2s); + return status; +} + +/** + * @brief Unregister an I2S Callback + * I2S callback is redirected to the weak predefined callback + * @param hi2s Pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for the specified I2S. + * @param CallbackID ID of the callback to be unregistered + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_UnRegisterCallback(I2S_HandleTypeDef *hi2s, HAL_I2S_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hi2s); + + if (HAL_I2S_STATE_READY == hi2s->State) + { + switch (CallbackID) + { + case HAL_I2S_TX_COMPLETE_CB_ID : + hi2s->TxCpltCallback = HAL_I2S_TxCpltCallback; /* Legacy weak TxCpltCallback */ + break; + + case HAL_I2S_RX_COMPLETE_CB_ID : + hi2s->RxCpltCallback = HAL_I2S_RxCpltCallback; /* Legacy weak RxCpltCallback */ + break; + + case HAL_I2S_TX_HALF_COMPLETE_CB_ID : + hi2s->TxHalfCpltCallback = HAL_I2S_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + break; + + case HAL_I2S_RX_HALF_COMPLETE_CB_ID : + hi2s->RxHalfCpltCallback = HAL_I2S_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + break; + + case HAL_I2S_ERROR_CB_ID : + hi2s->ErrorCallback = HAL_I2S_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_I2S_MSPINIT_CB_ID : + hi2s->MspInitCallback = HAL_I2S_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_I2S_MSPDEINIT_CB_ID : + hi2s->MspDeInitCallback = HAL_I2S_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_I2S_STATE_RESET == hi2s->State) + { + switch (CallbackID) + { + case HAL_I2S_MSPINIT_CB_ID : + hi2s->MspInitCallback = HAL_I2S_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_I2S_MSPDEINIT_CB_ID : + hi2s->MspDeInitCallback = HAL_I2S_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hi2s); + return status; +} +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup I2S_Exported_Functions_Group2 IO operation functions + * @brief Data transfers functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to manage the I2S data + transfers. + + (#) There are two modes of transfer: + (++) Blocking mode : The communication is performed in the polling mode. + The status of all data processing is returned by the same function + after finishing transfer. + (++) No-Blocking mode : The communication is performed using Interrupts + or DMA. These functions return the status of the transfer startup. + The end of the data processing will be indicated through the + dedicated I2S IRQ when using Interrupt mode or the DMA IRQ when + using DMA mode. + + (#) Blocking mode functions are : + (++) HAL_I2S_Transmit() + (++) HAL_I2S_Receive() + + (#) No-Blocking mode functions with Interrupt are : + (++) HAL_I2S_Transmit_IT() + (++) HAL_I2S_Receive_IT() + + (#) No-Blocking mode functions with DMA are : + (++) HAL_I2S_Transmit_DMA() + (++) HAL_I2S_Receive_DMA() + + (#) A set of Transfer Complete Callbacks are provided in non Blocking mode: + (++) HAL_I2S_TxCpltCallback() + (++) HAL_I2S_RxCpltCallback() + (++) HAL_I2S_ErrorCallback() + +@endverbatim + * @{ + */ + +/** + * @brief Transmit an amount of data in blocking mode + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @param pData a 16-bit pointer to data buffer. + * @param Size number of data sample to be sent: + * @note When a 16-bit data frame or a 16-bit data frame extended is selected during the I2S + * configuration phase, the Size parameter means the number of 16-bit data length + * in the transaction and when a 24-bit data frame or a 32-bit data frame is selected + * the Size parameter means the number of 24-bit or 32-bit data length. + * @param Timeout Timeout duration + * @note The I2S is kept enabled at the end of transaction to avoid the clock de-synchronization + * between Master and Slave(example: audio streaming). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_Transmit(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint32_t tmpreg_cfgr; + + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State != HAL_I2S_STATE_READY) + { + __HAL_UNLOCK(hi2s); + return HAL_BUSY; + } + + /* Set state and reset error code */ + hi2s->State = HAL_I2S_STATE_BUSY_TX; + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->pTxBuffPtr = pData; + + tmpreg_cfgr = hi2s->Instance->I2SCFGR & (SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN); + + if ((tmpreg_cfgr == I2S_DATAFORMAT_24B) || (tmpreg_cfgr == I2S_DATAFORMAT_32B)) + { + hi2s->TxXferSize = (Size << 1U); + hi2s->TxXferCount = (Size << 1U); + } + else + { + hi2s->TxXferSize = Size; + hi2s->TxXferCount = Size; + } + + tmpreg_cfgr = hi2s->Instance->I2SCFGR; + + /* Check if the I2S is already enabled */ + if ((hi2s->Instance->I2SCFGR & SPI_I2SCFGR_I2SE) != SPI_I2SCFGR_I2SE) + { + /* Enable I2S peripheral */ + __HAL_I2S_ENABLE(hi2s); + } + + /* Wait until TXE flag is set */ + if (I2S_WaitFlagStateUntilTimeout(hi2s, I2S_FLAG_TXE, SET, Timeout) != HAL_OK) + { + /* Set the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_TIMEOUT); + hi2s->State = HAL_I2S_STATE_READY; + __HAL_UNLOCK(hi2s); + return HAL_ERROR; + } + + while (hi2s->TxXferCount > 0U) + { + hi2s->Instance->DR = (*hi2s->pTxBuffPtr); + hi2s->pTxBuffPtr++; + hi2s->TxXferCount--; + + /* Wait until TXE flag is set */ + if (I2S_WaitFlagStateUntilTimeout(hi2s, I2S_FLAG_TXE, SET, Timeout) != HAL_OK) + { + /* Set the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_TIMEOUT); + hi2s->State = HAL_I2S_STATE_READY; + __HAL_UNLOCK(hi2s); + return HAL_ERROR; + } + + /* Check if an underrun occurs */ + if (__HAL_I2S_GET_FLAG(hi2s, I2S_FLAG_UDR) == SET) + { + /* Clear underrun flag */ + __HAL_I2S_CLEAR_UDRFLAG(hi2s); + + /* Set the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_UDR); + } + } + + /* Check if Slave mode is selected */ + if (((tmpreg_cfgr & SPI_I2SCFGR_I2SCFG) == I2S_MODE_SLAVE_TX) + || ((tmpreg_cfgr & SPI_I2SCFGR_I2SCFG) == I2S_MODE_SLAVE_RX)) + { + /* Wait until Busy flag is reset */ + if (I2S_WaitFlagStateUntilTimeout(hi2s, I2S_FLAG_BSY, RESET, Timeout) != HAL_OK) + { + /* Set the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_TIMEOUT); + hi2s->State = HAL_I2S_STATE_READY; + __HAL_UNLOCK(hi2s); + return HAL_ERROR; + } + } + + hi2s->State = HAL_I2S_STATE_READY; + __HAL_UNLOCK(hi2s); + return HAL_OK; +} + +/** + * @brief Receive an amount of data in blocking mode + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @param pData a 16-bit pointer to data buffer. + * @param Size number of data sample to be sent: + * @note When a 16-bit data frame or a 16-bit data frame extended is selected during the I2S + * configuration phase, the Size parameter means the number of 16-bit data length + * in the transaction and when a 24-bit data frame or a 32-bit data frame is selected + * the Size parameter means the number of 24-bit or 32-bit data length. + * @param Timeout Timeout duration + * @note The I2S is kept enabled at the end of transaction to avoid the clock de-synchronization + * between Master and Slave(example: audio streaming). + * @note In I2S Master Receiver mode, just after enabling the peripheral the clock will be generate + * in continuous way and as the I2S is not disabled at the end of the I2S transaction. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_Receive(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint32_t tmpreg_cfgr; + + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State != HAL_I2S_STATE_READY) + { + __HAL_UNLOCK(hi2s); + return HAL_BUSY; + } + + /* Set state and reset error code */ + hi2s->State = HAL_I2S_STATE_BUSY_RX; + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->pRxBuffPtr = pData; + + tmpreg_cfgr = hi2s->Instance->I2SCFGR & (SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN); + + if ((tmpreg_cfgr == I2S_DATAFORMAT_24B) || (tmpreg_cfgr == I2S_DATAFORMAT_32B)) + { + hi2s->RxXferSize = (Size << 1U); + hi2s->RxXferCount = (Size << 1U); + } + else + { + hi2s->RxXferSize = Size; + hi2s->RxXferCount = Size; + } + + /* Check if the I2S is already enabled */ + if ((hi2s->Instance->I2SCFGR & SPI_I2SCFGR_I2SE) != SPI_I2SCFGR_I2SE) + { + /* Enable I2S peripheral */ + __HAL_I2S_ENABLE(hi2s); + } + + /* Check if Master Receiver mode is selected */ + if ((hi2s->Instance->I2SCFGR & SPI_I2SCFGR_I2SCFG) == I2S_MODE_MASTER_RX) + { + /* Clear the Overrun Flag by a read operation on the SPI_DR register followed by a read + access to the SPI_SR register. */ + __HAL_I2S_CLEAR_OVRFLAG(hi2s); + } + + /* Receive data */ + while (hi2s->RxXferCount > 0U) + { + /* Wait until RXNE flag is set */ + if (I2S_WaitFlagStateUntilTimeout(hi2s, I2S_FLAG_RXNE, SET, Timeout) != HAL_OK) + { + /* Set the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_TIMEOUT); + hi2s->State = HAL_I2S_STATE_READY; + __HAL_UNLOCK(hi2s); + return HAL_ERROR; + } + + (*hi2s->pRxBuffPtr) = (uint16_t)hi2s->Instance->DR; + hi2s->pRxBuffPtr++; + hi2s->RxXferCount--; + + /* Check if an overrun occurs */ + if (__HAL_I2S_GET_FLAG(hi2s, I2S_FLAG_OVR) == SET) + { + /* Clear overrun flag */ + __HAL_I2S_CLEAR_OVRFLAG(hi2s); + + /* Set the error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_OVR); + } + } + + hi2s->State = HAL_I2S_STATE_READY; + __HAL_UNLOCK(hi2s); + return HAL_OK; +} + +/** + * @brief Transmit an amount of data in non-blocking mode with Interrupt + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @param pData a 16-bit pointer to data buffer. + * @param Size number of data sample to be sent: + * @note When a 16-bit data frame or a 16-bit data frame extended is selected during the I2S + * configuration phase, the Size parameter means the number of 16-bit data length + * in the transaction and when a 24-bit data frame or a 32-bit data frame is selected + * the Size parameter means the number of 24-bit or 32-bit data length. + * @note The I2S is kept enabled at the end of transaction to avoid the clock de-synchronization + * between Master and Slave(example: audio streaming). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_Transmit_IT(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size) +{ + uint32_t tmpreg_cfgr; + + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State != HAL_I2S_STATE_READY) + { + __HAL_UNLOCK(hi2s); + return HAL_BUSY; + } + + /* Set state and reset error code */ + hi2s->State = HAL_I2S_STATE_BUSY_TX; + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->pTxBuffPtr = pData; + + tmpreg_cfgr = hi2s->Instance->I2SCFGR & (SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN); + + if ((tmpreg_cfgr == I2S_DATAFORMAT_24B) || (tmpreg_cfgr == I2S_DATAFORMAT_32B)) + { + hi2s->TxXferSize = (Size << 1U); + hi2s->TxXferCount = (Size << 1U); + } + else + { + hi2s->TxXferSize = Size; + hi2s->TxXferCount = Size; + } + + /* Enable TXE and ERR interrupt */ + __HAL_I2S_ENABLE_IT(hi2s, (I2S_IT_TXE | I2S_IT_ERR)); + + /* Check if the I2S is already enabled */ + if ((hi2s->Instance->I2SCFGR & SPI_I2SCFGR_I2SE) != SPI_I2SCFGR_I2SE) + { + /* Enable I2S peripheral */ + __HAL_I2S_ENABLE(hi2s); + } + + __HAL_UNLOCK(hi2s); + return HAL_OK; +} + +/** + * @brief Receive an amount of data in non-blocking mode with Interrupt + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @param pData a 16-bit pointer to the Receive data buffer. + * @param Size number of data sample to be sent: + * @note When a 16-bit data frame or a 16-bit data frame extended is selected during the I2S + * configuration phase, the Size parameter means the number of 16-bit data length + * in the transaction and when a 24-bit data frame or a 32-bit data frame is selected + * the Size parameter means the number of 24-bit or 32-bit data length. + * @note The I2S is kept enabled at the end of transaction to avoid the clock de-synchronization + * between Master and Slave(example: audio streaming). + * @note It is recommended to use DMA for the I2S receiver to avoid de-synchronization + * between Master and Slave otherwise the I2S interrupt should be optimized. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_Receive_IT(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size) +{ + uint32_t tmpreg_cfgr; + + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State != HAL_I2S_STATE_READY) + { + __HAL_UNLOCK(hi2s); + return HAL_BUSY; + } + + /* Set state and reset error code */ + hi2s->State = HAL_I2S_STATE_BUSY_RX; + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->pRxBuffPtr = pData; + + tmpreg_cfgr = hi2s->Instance->I2SCFGR & (SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN); + + if ((tmpreg_cfgr == I2S_DATAFORMAT_24B) || (tmpreg_cfgr == I2S_DATAFORMAT_32B)) + { + hi2s->RxXferSize = (Size << 1U); + hi2s->RxXferCount = (Size << 1U); + } + else + { + hi2s->RxXferSize = Size; + hi2s->RxXferCount = Size; + } + + /* Enable RXNE and ERR interrupt */ + __HAL_I2S_ENABLE_IT(hi2s, (I2S_IT_RXNE | I2S_IT_ERR)); + + /* Check if the I2S is already enabled */ + if ((hi2s->Instance->I2SCFGR & SPI_I2SCFGR_I2SE) != SPI_I2SCFGR_I2SE) + { + /* Enable I2S peripheral */ + __HAL_I2S_ENABLE(hi2s); + } + + __HAL_UNLOCK(hi2s); + return HAL_OK; +} + +/** + * @brief Transmit an amount of data in non-blocking mode with DMA + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @param pData a 16-bit pointer to the Transmit data buffer. + * @param Size number of data sample to be sent: + * @note When a 16-bit data frame or a 16-bit data frame extended is selected during the I2S + * configuration phase, the Size parameter means the number of 16-bit data length + * in the transaction and when a 24-bit data frame or a 32-bit data frame is selected + * the Size parameter means the number of 24-bit or 32-bit data length. + * @note The I2S is kept enabled at the end of transaction to avoid the clock de-synchronization + * between Master and Slave(example: audio streaming). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_Transmit_DMA(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size) +{ + uint32_t tmpreg_cfgr; + + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State != HAL_I2S_STATE_READY) + { + __HAL_UNLOCK(hi2s); + return HAL_BUSY; + } + + /* Set state and reset error code */ + hi2s->State = HAL_I2S_STATE_BUSY_TX; + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->pTxBuffPtr = pData; + + tmpreg_cfgr = hi2s->Instance->I2SCFGR & (SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN); + + if ((tmpreg_cfgr == I2S_DATAFORMAT_24B) || (tmpreg_cfgr == I2S_DATAFORMAT_32B)) + { + hi2s->TxXferSize = (Size << 1U); + hi2s->TxXferCount = (Size << 1U); + } + else + { + hi2s->TxXferSize = Size; + hi2s->TxXferCount = Size; + } + + /* Set the I2S Tx DMA Half transfer complete callback */ + hi2s->hdmatx->XferHalfCpltCallback = I2S_DMATxHalfCplt; + + /* Set the I2S Tx DMA transfer complete callback */ + hi2s->hdmatx->XferCpltCallback = I2S_DMATxCplt; + + /* Set the DMA error callback */ + hi2s->hdmatx->XferErrorCallback = I2S_DMAError; + + /* Enable the Tx DMA Stream/Channel */ + if (HAL_OK != HAL_DMA_Start_IT(hi2s->hdmatx, + (uint32_t)hi2s->pTxBuffPtr, + (uint32_t)&hi2s->Instance->DR, + hi2s->TxXferSize)) + { + /* Update SPI error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_DMA); + hi2s->State = HAL_I2S_STATE_READY; + + __HAL_UNLOCK(hi2s); + return HAL_ERROR; + } + + /* Check if the I2S is already enabled */ + if (HAL_IS_BIT_CLR(hi2s->Instance->I2SCFGR, SPI_I2SCFGR_I2SE)) + { + /* Enable I2S peripheral */ + __HAL_I2S_ENABLE(hi2s); + } + + /* Check if the I2S Tx request is already enabled */ + if (HAL_IS_BIT_CLR(hi2s->Instance->CR2, SPI_CR2_TXDMAEN)) + { + /* Enable Tx DMA Request */ + SET_BIT(hi2s->Instance->CR2, SPI_CR2_TXDMAEN); + } + + __HAL_UNLOCK(hi2s); + return HAL_OK; +} + +/** + * @brief Receive an amount of data in non-blocking mode with DMA + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @param pData a 16-bit pointer to the Receive data buffer. + * @param Size number of data sample to be sent: + * @note When a 16-bit data frame or a 16-bit data frame extended is selected during the I2S + * configuration phase, the Size parameter means the number of 16-bit data length + * in the transaction and when a 24-bit data frame or a 32-bit data frame is selected + * the Size parameter means the number of 24-bit or 32-bit data length. + * @note The I2S is kept enabled at the end of transaction to avoid the clock de-synchronization + * between Master and Slave(example: audio streaming). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_Receive_DMA(I2S_HandleTypeDef *hi2s, uint16_t *pData, uint16_t Size) +{ + uint32_t tmpreg_cfgr; + + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State != HAL_I2S_STATE_READY) + { + __HAL_UNLOCK(hi2s); + return HAL_BUSY; + } + + /* Set state and reset error code */ + hi2s->State = HAL_I2S_STATE_BUSY_RX; + hi2s->ErrorCode = HAL_I2S_ERROR_NONE; + hi2s->pRxBuffPtr = pData; + + tmpreg_cfgr = hi2s->Instance->I2SCFGR & (SPI_I2SCFGR_DATLEN | SPI_I2SCFGR_CHLEN); + + if ((tmpreg_cfgr == I2S_DATAFORMAT_24B) || (tmpreg_cfgr == I2S_DATAFORMAT_32B)) + { + hi2s->RxXferSize = (Size << 1U); + hi2s->RxXferCount = (Size << 1U); + } + else + { + hi2s->RxXferSize = Size; + hi2s->RxXferCount = Size; + } + + /* Set the I2S Rx DMA Half transfer complete callback */ + hi2s->hdmarx->XferHalfCpltCallback = I2S_DMARxHalfCplt; + + /* Set the I2S Rx DMA transfer complete callback */ + hi2s->hdmarx->XferCpltCallback = I2S_DMARxCplt; + + /* Set the DMA error callback */ + hi2s->hdmarx->XferErrorCallback = I2S_DMAError; + + /* Check if Master Receiver mode is selected */ + if ((hi2s->Instance->I2SCFGR & SPI_I2SCFGR_I2SCFG) == I2S_MODE_MASTER_RX) + { + /* Clear the Overrun Flag by a read operation to the SPI_DR register followed by a read + access to the SPI_SR register. */ + __HAL_I2S_CLEAR_OVRFLAG(hi2s); + } + + /* Enable the Rx DMA Stream/Channel */ + if (HAL_OK != HAL_DMA_Start_IT(hi2s->hdmarx, (uint32_t)&hi2s->Instance->DR, (uint32_t)hi2s->pRxBuffPtr, + hi2s->RxXferSize)) + { + /* Update SPI error code */ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_DMA); + hi2s->State = HAL_I2S_STATE_READY; + + __HAL_UNLOCK(hi2s); + return HAL_ERROR; + } + + /* Check if the I2S is already enabled */ + if (HAL_IS_BIT_CLR(hi2s->Instance->I2SCFGR, SPI_I2SCFGR_I2SE)) + { + /* Enable I2S peripheral */ + __HAL_I2S_ENABLE(hi2s); + } + + /* Check if the I2S Rx request is already enabled */ + if (HAL_IS_BIT_CLR(hi2s->Instance->CR2, SPI_CR2_RXDMAEN)) + { + /* Enable Rx DMA Request */ + SET_BIT(hi2s->Instance->CR2, SPI_CR2_RXDMAEN); + } + + __HAL_UNLOCK(hi2s); + return HAL_OK; +} + +/** + * @brief Pauses the audio DMA Stream/Channel playing from the Media. + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_DMAPause(I2S_HandleTypeDef *hi2s) +{ + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State == HAL_I2S_STATE_BUSY_TX) + { + /* Disable the I2S DMA Tx request */ + CLEAR_BIT(hi2s->Instance->CR2, SPI_CR2_TXDMAEN); + } + else if (hi2s->State == HAL_I2S_STATE_BUSY_RX) + { + /* Disable the I2S DMA Rx request */ + CLEAR_BIT(hi2s->Instance->CR2, SPI_CR2_RXDMAEN); + } + else + { + /* nothing to do */ + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2s); + + return HAL_OK; +} + +/** + * @brief Resumes the audio DMA Stream/Channel playing from the Media. + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_DMAResume(I2S_HandleTypeDef *hi2s) +{ + /* Process Locked */ + __HAL_LOCK(hi2s); + + if (hi2s->State == HAL_I2S_STATE_BUSY_TX) + { + /* Enable the I2S DMA Tx request */ + SET_BIT(hi2s->Instance->CR2, SPI_CR2_TXDMAEN); + } + else if (hi2s->State == HAL_I2S_STATE_BUSY_RX) + { + /* Enable the I2S DMA Rx request */ + SET_BIT(hi2s->Instance->CR2, SPI_CR2_RXDMAEN); + } + else + { + /* nothing to do */ + } + + /* If the I2S peripheral is still not enabled, enable it */ + if (HAL_IS_BIT_CLR(hi2s->Instance->I2SCFGR, SPI_I2SCFGR_I2SE)) + { + /* Enable I2S peripheral */ + __HAL_I2S_ENABLE(hi2s); + } + + /* Process Unlocked */ + __HAL_UNLOCK(hi2s); + + return HAL_OK; +} + +/** + * @brief Stops the audio DMA Stream/Channel playing from the Media. + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval HAL status + */ +HAL_StatusTypeDef HAL_I2S_DMAStop(I2S_HandleTypeDef *hi2s) +{ + HAL_StatusTypeDef errorcode = HAL_OK; + /* The Lock is not implemented on this API to allow the user application + to call the HAL SPI API under callbacks HAL_I2S_TxCpltCallback() or HAL_I2S_RxCpltCallback() + when calling HAL_DMA_Abort() API the DMA TX or RX Transfer complete interrupt is generated + and the correspond call back is executed HAL_I2S_TxCpltCallback() or HAL_I2S_RxCpltCallback() + */ + + /* Disable the I2S Tx/Rx DMA requests */ + CLEAR_BIT(hi2s->Instance->CR2, SPI_CR2_TXDMAEN); + CLEAR_BIT(hi2s->Instance->CR2, SPI_CR2_RXDMAEN); + + /* Abort the I2S DMA tx Stream/Channel */ + if (hi2s->hdmatx != NULL) + { + /* Disable the I2S DMA tx Stream/Channel */ + if (HAL_OK != HAL_DMA_Abort(hi2s->hdmatx)) + { + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_DMA); + errorcode = HAL_ERROR; + } + } + + /* Abort the I2S DMA rx Stream/Channel */ + if (hi2s->hdmarx != NULL) + { + /* Disable the I2S DMA rx Stream/Channel */ + if (HAL_OK != HAL_DMA_Abort(hi2s->hdmarx)) + { + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_DMA); + errorcode = HAL_ERROR; + } + } + + /* Disable I2S peripheral */ + __HAL_I2S_DISABLE(hi2s); + + hi2s->State = HAL_I2S_STATE_READY; + + return errorcode; +} + +/** + * @brief This function handles I2S interrupt request. + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +void HAL_I2S_IRQHandler(I2S_HandleTypeDef *hi2s) +{ + uint32_t itsource = hi2s->Instance->CR2; + uint32_t itflag = hi2s->Instance->SR; + + /* I2S in mode Receiver ------------------------------------------------*/ + if ((I2S_CHECK_FLAG(itflag, I2S_FLAG_OVR) == RESET) && + (I2S_CHECK_FLAG(itflag, I2S_FLAG_RXNE) != RESET) && (I2S_CHECK_IT_SOURCE(itsource, I2S_IT_RXNE) != RESET)) + { + I2S_Receive_IT(hi2s); + return; + } + + /* I2S in mode Tramitter -----------------------------------------------*/ + if ((I2S_CHECK_FLAG(itflag, I2S_FLAG_TXE) != RESET) && (I2S_CHECK_IT_SOURCE(itsource, I2S_IT_TXE) != RESET)) + { + I2S_Transmit_IT(hi2s); + return; + } + + /* I2S interrupt error -------------------------------------------------*/ + if (I2S_CHECK_IT_SOURCE(itsource, I2S_IT_ERR) != RESET) + { + /* I2S Overrun error interrupt occurred ---------------------------------*/ + if (I2S_CHECK_FLAG(itflag, I2S_FLAG_OVR) != RESET) + { + /* Disable RXNE and ERR interrupt */ + __HAL_I2S_DISABLE_IT(hi2s, (I2S_IT_RXNE | I2S_IT_ERR)); + + /* Set the error code and execute error callback*/ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_OVR); + } + + /* I2S Underrun error interrupt occurred --------------------------------*/ + if (I2S_CHECK_FLAG(itflag, I2S_FLAG_UDR) != RESET) + { + /* Disable TXE and ERR interrupt */ + __HAL_I2S_DISABLE_IT(hi2s, (I2S_IT_TXE | I2S_IT_ERR)); + + /* Set the error code and execute error callback*/ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_UDR); + } + + /* Set the I2S State ready */ + hi2s->State = HAL_I2S_STATE_READY; + + /* Call user error callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->ErrorCallback(hi2s); +#else + HAL_I2S_ErrorCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ + } +} + +/** + * @brief Tx Transfer Half completed callbacks + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +__weak void HAL_I2S_TxHalfCpltCallback(I2S_HandleTypeDef *hi2s) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2s); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_I2S_TxHalfCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Tx Transfer completed callbacks + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +__weak void HAL_I2S_TxCpltCallback(I2S_HandleTypeDef *hi2s) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2s); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_I2S_TxCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Rx Transfer half completed callbacks + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +__weak void HAL_I2S_RxHalfCpltCallback(I2S_HandleTypeDef *hi2s) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2s); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_I2S_RxHalfCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Rx Transfer completed callbacks + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +__weak void HAL_I2S_RxCpltCallback(I2S_HandleTypeDef *hi2s) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2s); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_I2S_RxCpltCallback could be implemented in the user file + */ +} + +/** + * @brief I2S error callbacks + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +__weak void HAL_I2S_ErrorCallback(I2S_HandleTypeDef *hi2s) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hi2s); + + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_I2S_ErrorCallback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup I2S_Exported_Functions_Group3 Peripheral State and Errors functions + * @brief Peripheral State functions + * +@verbatim + =============================================================================== + ##### Peripheral State and Errors functions ##### + =============================================================================== + [..] + This subsection permits to get in run-time the status of the peripheral + and the data flow. + +@endverbatim + * @{ + */ + +/** + * @brief Return the I2S state + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval HAL state + */ +HAL_I2S_StateTypeDef HAL_I2S_GetState(I2S_HandleTypeDef *hi2s) +{ + return hi2s->State; +} + +/** + * @brief Return the I2S error code + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval I2S Error Code + */ +uint32_t HAL_I2S_GetError(I2S_HandleTypeDef *hi2s) +{ + return hi2s->ErrorCode; +} +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup I2S_Private_Functions I2S Private Functions + * @{ + */ +/** + * @brief DMA I2S transmit process complete callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void I2S_DMATxCplt(DMA_HandleTypeDef *hdma) +{ + I2S_HandleTypeDef *hi2s = (I2S_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */ + + /* if DMA is configured in DMA_NORMAL Mode */ + if (hdma->Init.Mode == DMA_NORMAL) + { + /* Disable Tx DMA Request */ + CLEAR_BIT(hi2s->Instance->CR2, SPI_CR2_TXDMAEN); + + hi2s->TxXferCount = 0U; + hi2s->State = HAL_I2S_STATE_READY; + } + /* Call user Tx complete callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->TxCpltCallback(hi2s); +#else + HAL_I2S_TxCpltCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA I2S transmit process half complete callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void I2S_DMATxHalfCplt(DMA_HandleTypeDef *hdma) +{ + I2S_HandleTypeDef *hi2s = (I2S_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */ + + /* Call user Tx half complete callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->TxHalfCpltCallback(hi2s); +#else + HAL_I2S_TxHalfCpltCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA I2S receive process complete callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void I2S_DMARxCplt(DMA_HandleTypeDef *hdma) +{ + I2S_HandleTypeDef *hi2s = (I2S_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */ + + /* if DMA is configured in DMA_NORMAL Mode */ + if (hdma->Init.Mode == DMA_NORMAL) + { + /* Disable Rx DMA Request */ + CLEAR_BIT(hi2s->Instance->CR2, SPI_CR2_RXDMAEN); + hi2s->RxXferCount = 0U; + hi2s->State = HAL_I2S_STATE_READY; + } + /* Call user Rx complete callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->RxCpltCallback(hi2s); +#else + HAL_I2S_RxCpltCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA I2S receive process half complete callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void I2S_DMARxHalfCplt(DMA_HandleTypeDef *hdma) +{ + I2S_HandleTypeDef *hi2s = (I2S_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */ + + /* Call user Rx half complete callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->RxHalfCpltCallback(hi2s); +#else + HAL_I2S_RxHalfCpltCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA I2S communication error callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void I2S_DMAError(DMA_HandleTypeDef *hdma) +{ + I2S_HandleTypeDef *hi2s = (I2S_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; /* Derogation MISRAC2012-Rule-11.5 */ + + /* Disable Rx and Tx DMA Request */ + CLEAR_BIT(hi2s->Instance->CR2, (SPI_CR2_RXDMAEN | SPI_CR2_TXDMAEN)); + hi2s->TxXferCount = 0U; + hi2s->RxXferCount = 0U; + + hi2s->State = HAL_I2S_STATE_READY; + + /* Set the error code and execute error callback*/ + SET_BIT(hi2s->ErrorCode, HAL_I2S_ERROR_DMA); + /* Call user error callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->ErrorCallback(hi2s); +#else + HAL_I2S_ErrorCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ +} + +/** + * @brief Transmit an amount of data in non-blocking mode with Interrupt + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +static void I2S_Transmit_IT(I2S_HandleTypeDef *hi2s) +{ + /* Transmit data */ + hi2s->Instance->DR = (*hi2s->pTxBuffPtr); + hi2s->pTxBuffPtr++; + hi2s->TxXferCount--; + + if (hi2s->TxXferCount == 0U) + { + /* Disable TXE and ERR interrupt */ + __HAL_I2S_DISABLE_IT(hi2s, (I2S_IT_TXE | I2S_IT_ERR)); + + hi2s->State = HAL_I2S_STATE_READY; + /* Call user Tx complete callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->TxCpltCallback(hi2s); +#else + HAL_I2S_TxCpltCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ + } +} + +/** + * @brief Receive an amount of data in non-blocking mode with Interrupt + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @retval None + */ +static void I2S_Receive_IT(I2S_HandleTypeDef *hi2s) +{ + /* Receive data */ + (*hi2s->pRxBuffPtr) = (uint16_t)hi2s->Instance->DR; + hi2s->pRxBuffPtr++; + hi2s->RxXferCount--; + + if (hi2s->RxXferCount == 0U) + { + /* Disable RXNE and ERR interrupt */ + __HAL_I2S_DISABLE_IT(hi2s, (I2S_IT_RXNE | I2S_IT_ERR)); + + hi2s->State = HAL_I2S_STATE_READY; + /* Call user Rx complete callback */ +#if (USE_HAL_I2S_REGISTER_CALLBACKS == 1U) + hi2s->RxCpltCallback(hi2s); +#else + HAL_I2S_RxCpltCallback(hi2s); +#endif /* USE_HAL_I2S_REGISTER_CALLBACKS */ + } +} + +/** + * @brief This function handles I2S Communication Timeout. + * @param hi2s pointer to a I2S_HandleTypeDef structure that contains + * the configuration information for I2S module + * @param Flag Flag checked + * @param State Value of the flag expected + * @param Timeout Duration of the timeout + * @retval HAL status + */ +static HAL_StatusTypeDef I2S_WaitFlagStateUntilTimeout(I2S_HandleTypeDef *hi2s, uint32_t Flag, FlagStatus State, + uint32_t Timeout) +{ + uint32_t tickstart; + + /* Get tick */ + tickstart = HAL_GetTick(); + + /* Wait until flag is set to status*/ + while (((__HAL_I2S_GET_FLAG(hi2s, Flag)) ? SET : RESET) != State) + { + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - tickstart) >= Timeout) || (Timeout == 0U)) + { + /* Set the I2S State ready */ + hi2s->State = HAL_I2S_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hi2s); + + return HAL_TIMEOUT; + } + } + } + return HAL_OK; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* SPI_I2S_SUPPORT */ + +#endif /* HAL_I2S_MODULE_ENABLED */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_irda.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_irda.c new file mode 100644 index 0000000..3248379 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_irda.c @@ -0,0 +1,2998 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_irda.c + * @author MCD Application Team + * @brief IRDA HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the IrDA (Infrared Data Association) Peripheral + * (IRDA) + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral State and Errors functions + * + Peripheral Control functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The IRDA HAL driver can be used as follows: + + (#) Declare a IRDA_HandleTypeDef handle structure (eg. IRDA_HandleTypeDef hirda). + (#) Initialize the IRDA low level resources by implementing the HAL_IRDA_MspInit() API + in setting the associated USART or UART in IRDA mode: + (++) Enable the USARTx/UARTx interface clock. + (++) USARTx/UARTx pins configuration: + (+++) Enable the clock for the USARTx/UARTx GPIOs. + (+++) Configure these USARTx/UARTx pins (TX as alternate function pull-up, RX as alternate function Input). + (++) NVIC configuration if you need to use interrupt process (HAL_IRDA_Transmit_IT() + and HAL_IRDA_Receive_IT() APIs): + (+++) Configure the USARTx/UARTx interrupt priority. + (+++) Enable the NVIC USARTx/UARTx IRQ handle. + (+++) The specific IRDA interrupts (Transmission complete interrupt, + RXNE interrupt and Error Interrupts) will be managed using the macros + __HAL_IRDA_ENABLE_IT() and __HAL_IRDA_DISABLE_IT() inside the transmit and receive process. + + (++) DMA Configuration if you need to use DMA process (HAL_IRDA_Transmit_DMA() + and HAL_IRDA_Receive_DMA() APIs): + (+++) Declare a DMA handle structure for the Tx/Rx channel. + (+++) Enable the DMAx interface clock. + (+++) Configure the declared DMA handle structure with the required Tx/Rx parameters. + (+++) Configure the DMA Tx/Rx channel. + (+++) Associate the initialized DMA handle to the IRDA DMA Tx/Rx handle. + (+++) Configure the priority and enable the NVIC for the transfer + complete interrupt on the DMA Tx/Rx channel. + + (#) Program the Baud Rate, Word Length and Parity and Mode(Receiver/Transmitter), + the normal or low power mode and the clock prescaler in the hirda handle Init structure. + + (#) Initialize the IRDA registers by calling the HAL_IRDA_Init() API: + (++) This API configures also the low level Hardware GPIO, CLOCK, CORTEX...etc) + by calling the customized HAL_IRDA_MspInit() API. + + -@@- The specific IRDA interrupts (Transmission complete interrupt, + RXNE interrupt and Error Interrupts) will be managed using the macros + __HAL_IRDA_ENABLE_IT() and __HAL_IRDA_DISABLE_IT() inside the transmit and receive process. + + (#) Three operation modes are available within this driver : + + *** Polling mode IO operation *** + ================================= + [..] + (+) Send an amount of data in blocking mode using HAL_IRDA_Transmit() + (+) Receive an amount of data in blocking mode using HAL_IRDA_Receive() + + *** Interrupt mode IO operation *** + =================================== + [..] + (+) Send an amount of data in non-blocking mode using HAL_IRDA_Transmit_IT() + (+) At transmission end of transfer HAL_IRDA_TxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_IRDA_TxCpltCallback() + (+) Receive an amount of data in non-blocking mode using HAL_IRDA_Receive_IT() + (+) At reception end of transfer HAL_IRDA_RxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_IRDA_RxCpltCallback() + (+) In case of transfer Error, HAL_IRDA_ErrorCallback() function is executed and user can + add his own code by customization of function pointer HAL_IRDA_ErrorCallback() + + *** DMA mode IO operation *** + ============================== + [..] + (+) Send an amount of data in non-blocking mode (DMA) using HAL_IRDA_Transmit_DMA() + (+) At transmission half of transfer HAL_IRDA_TxHalfCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_IRDA_TxHalfCpltCallback() + (+) At transmission end of transfer HAL_IRDA_TxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_IRDA_TxCpltCallback() + (+) Receive an amount of data in non-blocking mode (DMA) using HAL_IRDA_Receive_DMA() + (+) At reception half of transfer HAL_IRDA_RxHalfCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_IRDA_RxHalfCpltCallback() + (+) At reception end of transfer HAL_IRDA_RxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_IRDA_RxCpltCallback() + (+) In case of transfer Error, HAL_IRDA_ErrorCallback() function is executed and user can + add his own code by customization of function pointer HAL_IRDA_ErrorCallback() + + *** IRDA HAL driver macros list *** + ==================================== + [..] + Below the list of most used macros in IRDA HAL driver. + + (+) __HAL_IRDA_ENABLE: Enable the IRDA peripheral + (+) __HAL_IRDA_DISABLE: Disable the IRDA peripheral + (+) __HAL_IRDA_GET_FLAG : Check whether the specified IRDA flag is set or not + (+) __HAL_IRDA_CLEAR_FLAG : Clear the specified IRDA pending flag + (+) __HAL_IRDA_ENABLE_IT: Enable the specified IRDA interrupt + (+) __HAL_IRDA_DISABLE_IT: Disable the specified IRDA interrupt + (+) __HAL_IRDA_GET_IT_SOURCE: Check whether or not the specified IRDA interrupt is enabled + + [..] + (@) You can refer to the IRDA HAL driver header file for more useful macros + + ##### Callback registration ##### + ================================== + + [..] + The compilation define USE_HAL_IRDA_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + + [..] + Use Function HAL_IRDA_RegisterCallback() to register a user callback. + Function HAL_IRDA_RegisterCallback() allows to register following callbacks: + (+) TxHalfCpltCallback : Tx Half Complete Callback. + (+) TxCpltCallback : Tx Complete Callback. + (+) RxHalfCpltCallback : Rx Half Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback. + (+) AbortReceiveCpltCallback : Abort Receive Complete Callback. + (+) MspInitCallback : IRDA MspInit. + (+) MspDeInitCallback : IRDA MspDeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + [..] + Use function HAL_IRDA_UnRegisterCallback() to reset a callback to the default + weak (surcharged) function. + HAL_IRDA_UnRegisterCallback() takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) TxHalfCpltCallback : Tx Half Complete Callback. + (+) TxCpltCallback : Tx Complete Callback. + (+) RxHalfCpltCallback : Rx Half Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback. + (+) AbortReceiveCpltCallback : Abort Receive Complete Callback. + (+) MspInitCallback : IRDA MspInit. + (+) MspDeInitCallback : IRDA MspDeInit. + + [..] + By default, after the HAL_IRDA_Init() and when the state is HAL_IRDA_STATE_RESET + all callbacks are set to the corresponding weak (surcharged) functions: + examples HAL_IRDA_TxCpltCallback(), HAL_IRDA_RxHalfCpltCallback(). + Exception done for MspInit and MspDeInit functions that are respectively + reset to the legacy weak (surcharged) functions in the HAL_IRDA_Init() + and HAL_IRDA_DeInit() only when these callbacks are null (not registered beforehand). + If not, MspInit or MspDeInit are not null, the HAL_IRDA_Init() and HAL_IRDA_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand). + + [..] + Callbacks can be registered/unregistered in HAL_IRDA_STATE_READY state only. + Exception done MspInit/MspDeInit that can be registered/unregistered + in HAL_IRDA_STATE_READY or HAL_IRDA_STATE_RESET state, thus registered (user) + MspInit/DeInit callbacks can be used during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_IRDA_RegisterCallback() before calling HAL_IRDA_DeInit() + or HAL_IRDA_Init() function. + + [..] + When The compilation define USE_HAL_IRDA_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available + and weak (surcharged) callbacks are used. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +#if defined(USART_IRDA_SUPPORT) +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup IRDA IRDA + * @brief HAL IRDA module driver + * @{ + */ + +#ifdef HAL_IRDA_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup IRDA_Private_Constants IRDA Private Constants + * @{ + */ +#define IRDA_TEACK_REACK_TIMEOUT 1000U /*!< IRDA TX or RX enable acknowledge time-out value */ + +#define IRDA_CR1_FIELDS ((uint32_t)(USART_CR1_M | USART_CR1_PCE \ + | USART_CR1_PS | USART_CR1_TE | USART_CR1_RE)) /*!< UART or USART CR1 fields of parameters set by IRDA_SetConfig API */ + +#define USART_BRR_MIN 0x10U /*!< USART BRR minimum authorized value */ + +#define USART_BRR_MAX 0x0000FFFFU /*!< USART BRR maximum authorized value */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup IRDA_Private_Macros IRDA Private Macros + * @{ + */ +/** @brief BRR division operation to set BRR register in 16-bit oversampling mode. + * @param __PCLK__ IRDA clock source. + * @param __BAUD__ Baud rate set by the user. + * @retval Division result + */ +#define IRDA_DIV_SAMPLING16(__PCLK__, __BAUD__) (((__PCLK__) + ((__BAUD__)/2U)) / (__BAUD__)) +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @addtogroup IRDA_Private_Functions + * @{ + */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) +void IRDA_InitCallbacksToDefault(IRDA_HandleTypeDef *hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ +static HAL_StatusTypeDef IRDA_SetConfig(IRDA_HandleTypeDef *hirda); +static HAL_StatusTypeDef IRDA_CheckIdleState(IRDA_HandleTypeDef *hirda); +static HAL_StatusTypeDef IRDA_WaitOnFlagUntilTimeout(IRDA_HandleTypeDef *hirda, uint32_t Flag, FlagStatus Status, + uint32_t Tickstart, uint32_t Timeout); +static void IRDA_EndTxTransfer(IRDA_HandleTypeDef *hirda); +static void IRDA_EndRxTransfer(IRDA_HandleTypeDef *hirda); +static void IRDA_DMATransmitCplt(DMA_HandleTypeDef *hdma); +static void IRDA_DMATransmitHalfCplt(DMA_HandleTypeDef *hdma); +static void IRDA_DMAReceiveCplt(DMA_HandleTypeDef *hdma); +static void IRDA_DMAReceiveHalfCplt(DMA_HandleTypeDef *hdma); +static void IRDA_DMAError(DMA_HandleTypeDef *hdma); +static void IRDA_DMAAbortOnError(DMA_HandleTypeDef *hdma); +static void IRDA_DMATxAbortCallback(DMA_HandleTypeDef *hdma); +static void IRDA_DMARxAbortCallback(DMA_HandleTypeDef *hdma); +static void IRDA_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma); +static void IRDA_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma); +static void IRDA_Transmit_IT(IRDA_HandleTypeDef *hirda); +static void IRDA_EndTransmit_IT(IRDA_HandleTypeDef *hirda); +static void IRDA_Receive_IT(IRDA_HandleTypeDef *hirda); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup IRDA_Exported_Functions IRDA Exported Functions + * @{ + */ + +/** @defgroup IRDA_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + ============================================================================== + ##### Initialization and Configuration functions ##### + ============================================================================== + [..] + This subsection provides a set of functions allowing to initialize the USARTx + in asynchronous IRDA mode. + (+) For the asynchronous mode only these parameters can be configured: + (++) Baud Rate + (++) Word Length + (++) Parity: If the parity is enabled, then the MSB bit of the data written + in the data register is transmitted but is changed by the parity bit. + (++) Power mode + (++) Prescaler setting + (++) Receiver/transmitter modes + + [..] + The HAL_IRDA_Init() API follows the USART asynchronous configuration procedures + (details for the procedures are available in reference manual). + +@endverbatim + + Depending on the frame length defined either by the M bit (8-bits or 9-bits) + or by the M1 and M0 bits (7-bit, 8-bit or 9-bit), the possible IRDA frame + formats are listed in the following table. + + Table 1. IRDA frame format. + +-----------------------------------------------------------------------+ + | M bit | PCE bit | IRDA frame | + |-------------------|-----------|---------------------------------------| + | 0 | 0 | | SB | 8-bit data | STB | | + |-------------------|-----------|---------------------------------------| + | 0 | 1 | | SB | 7-bit data | PB | STB | | + |-------------------|-----------|---------------------------------------| + | 1 | 0 | | SB | 9-bit data | STB | | + |-------------------|-----------|---------------------------------------| + | 1 | 1 | | SB | 8-bit data | PB | STB | | + +-----------------------------------------------------------------------+ + | M1 bit | M0 bit | PCE bit | IRDA frame | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 0 | | SB | 8 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 1 | | SB | 7 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 0 | | SB | 9 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 1 | | SB | 8 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 0 | | SB | 7 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 1 | | SB | 6 bit data | PB | STB | | + +-----------------------------------------------------------------------+ + + * @{ + */ + +/** + * @brief Initialize the IRDA mode according to the specified + * parameters in the IRDA_InitTypeDef and initialize the associated handle. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_Init(IRDA_HandleTypeDef *hirda) +{ + /* Check the IRDA handle allocation */ + if (hirda == NULL) + { + return HAL_ERROR; + } + + /* Check the USART/UART associated to the IRDA handle */ + assert_param(IS_IRDA_INSTANCE(hirda->Instance)); + + if (hirda->gState == HAL_IRDA_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hirda->Lock = HAL_UNLOCKED; + +#if USE_HAL_IRDA_REGISTER_CALLBACKS == 1 + IRDA_InitCallbacksToDefault(hirda); + + if (hirda->MspInitCallback == NULL) + { + hirda->MspInitCallback = HAL_IRDA_MspInit; + } + + /* Init the low level hardware */ + hirda->MspInitCallback(hirda); +#else + /* Init the low level hardware : GPIO, CLOCK */ + HAL_IRDA_MspInit(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + } + + hirda->gState = HAL_IRDA_STATE_BUSY; + + /* Disable the Peripheral to update the configuration registers */ + __HAL_IRDA_DISABLE(hirda); + + /* Set the IRDA Communication parameters */ + if (IRDA_SetConfig(hirda) == HAL_ERROR) + { + return HAL_ERROR; + } + + /* In IRDA mode, the following bits must be kept cleared: + - LINEN, STOP and CLKEN bits in the USART_CR2 register, + - SCEN and HDSEL bits in the USART_CR3 register.*/ + CLEAR_BIT(hirda->Instance->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN | USART_CR2_STOP)); + CLEAR_BIT(hirda->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); + + /* set the UART/USART in IRDA mode */ + hirda->Instance->CR3 |= USART_CR3_IREN; + + /* Enable the Peripheral */ + __HAL_IRDA_ENABLE(hirda); + + /* TEACK and/or REACK to check before moving hirda->gState and hirda->RxState to Ready */ + return (IRDA_CheckIdleState(hirda)); +} + +/** + * @brief DeInitialize the IRDA peripheral. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_DeInit(IRDA_HandleTypeDef *hirda) +{ + /* Check the IRDA handle allocation */ + if (hirda == NULL) + { + return HAL_ERROR; + } + + /* Check the USART/UART associated to the IRDA handle */ + assert_param(IS_IRDA_INSTANCE(hirda->Instance)); + + hirda->gState = HAL_IRDA_STATE_BUSY; + + /* DeInit the low level hardware */ +#if USE_HAL_IRDA_REGISTER_CALLBACKS == 1 + if (hirda->MspDeInitCallback == NULL) + { + hirda->MspDeInitCallback = HAL_IRDA_MspDeInit; + } + /* DeInit the low level hardware */ + hirda->MspDeInitCallback(hirda); +#else + HAL_IRDA_MspDeInit(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + /* Disable the Peripheral */ + __HAL_IRDA_DISABLE(hirda); + + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + hirda->gState = HAL_IRDA_STATE_RESET; + hirda->RxState = HAL_IRDA_STATE_RESET; + + /* Process Unlock */ + __HAL_UNLOCK(hirda); + + return HAL_OK; +} + +/** + * @brief Initialize the IRDA MSP. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_MspInit(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_IRDA_MspInit can be implemented in the user file + */ +} + +/** + * @brief DeInitialize the IRDA MSP. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_MspDeInit(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_IRDA_MspDeInit can be implemented in the user file + */ +} + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User IRDA Callback + * To be used instead of the weak predefined callback + * @param hirda irda handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_IRDA_TX_HALFCOMPLETE_CB_ID Tx Half Complete Callback ID + * @arg @ref HAL_IRDA_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_IRDA_RX_HALFCOMPLETE_CB_ID Rx Half Complete Callback ID + * @arg @ref HAL_IRDA_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_IRDA_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_IRDA_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_IRDA_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID + * @arg @ref HAL_IRDA_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID + * @arg @ref HAL_IRDA_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_IRDA_MSPDEINIT_CB_ID MspDeInit Callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_RegisterCallback(IRDA_HandleTypeDef *hirda, HAL_IRDA_CallbackIDTypeDef CallbackID, + pIRDA_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hirda->ErrorCode |= HAL_IRDA_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hirda); + + if (hirda->gState == HAL_IRDA_STATE_READY) + { + switch (CallbackID) + { + case HAL_IRDA_TX_HALFCOMPLETE_CB_ID : + hirda->TxHalfCpltCallback = pCallback; + break; + + case HAL_IRDA_TX_COMPLETE_CB_ID : + hirda->TxCpltCallback = pCallback; + break; + + case HAL_IRDA_RX_HALFCOMPLETE_CB_ID : + hirda->RxHalfCpltCallback = pCallback; + break; + + case HAL_IRDA_RX_COMPLETE_CB_ID : + hirda->RxCpltCallback = pCallback; + break; + + case HAL_IRDA_ERROR_CB_ID : + hirda->ErrorCallback = pCallback; + break; + + case HAL_IRDA_ABORT_COMPLETE_CB_ID : + hirda->AbortCpltCallback = pCallback; + break; + + case HAL_IRDA_ABORT_TRANSMIT_COMPLETE_CB_ID : + hirda->AbortTransmitCpltCallback = pCallback; + break; + + case HAL_IRDA_ABORT_RECEIVE_COMPLETE_CB_ID : + hirda->AbortReceiveCpltCallback = pCallback; + break; + + case HAL_IRDA_MSPINIT_CB_ID : + hirda->MspInitCallback = pCallback; + break; + + case HAL_IRDA_MSPDEINIT_CB_ID : + hirda->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hirda->ErrorCode |= HAL_IRDA_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hirda->gState == HAL_IRDA_STATE_RESET) + { + switch (CallbackID) + { + case HAL_IRDA_MSPINIT_CB_ID : + hirda->MspInitCallback = pCallback; + break; + + case HAL_IRDA_MSPDEINIT_CB_ID : + hirda->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hirda->ErrorCode |= HAL_IRDA_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hirda->ErrorCode |= HAL_IRDA_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hirda); + + return status; +} + +/** + * @brief Unregister an IRDA callback + * IRDA callback is redirected to the weak predefined callback + * @param hirda irda handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_IRDA_TX_HALFCOMPLETE_CB_ID Tx Half Complete Callback ID + * @arg @ref HAL_IRDA_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_IRDA_RX_HALFCOMPLETE_CB_ID Rx Half Complete Callback ID + * @arg @ref HAL_IRDA_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_IRDA_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_IRDA_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_IRDA_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID + * @arg @ref HAL_IRDA_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID + * @arg @ref HAL_IRDA_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_IRDA_MSPDEINIT_CB_ID MspDeInit Callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_UnRegisterCallback(IRDA_HandleTypeDef *hirda, HAL_IRDA_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hirda); + + if (HAL_IRDA_STATE_READY == hirda->gState) + { + switch (CallbackID) + { + case HAL_IRDA_TX_HALFCOMPLETE_CB_ID : + hirda->TxHalfCpltCallback = HAL_IRDA_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + break; + + case HAL_IRDA_TX_COMPLETE_CB_ID : + hirda->TxCpltCallback = HAL_IRDA_TxCpltCallback; /* Legacy weak TxCpltCallback */ + break; + + case HAL_IRDA_RX_HALFCOMPLETE_CB_ID : + hirda->RxHalfCpltCallback = HAL_IRDA_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + break; + + case HAL_IRDA_RX_COMPLETE_CB_ID : + hirda->RxCpltCallback = HAL_IRDA_RxCpltCallback; /* Legacy weak RxCpltCallback */ + break; + + case HAL_IRDA_ERROR_CB_ID : + hirda->ErrorCallback = HAL_IRDA_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_IRDA_ABORT_COMPLETE_CB_ID : + hirda->AbortCpltCallback = HAL_IRDA_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + break; + + case HAL_IRDA_ABORT_TRANSMIT_COMPLETE_CB_ID : + hirda->AbortTransmitCpltCallback = HAL_IRDA_AbortTransmitCpltCallback; /* Legacy weak + AbortTransmitCpltCallback */ + break; + + case HAL_IRDA_ABORT_RECEIVE_COMPLETE_CB_ID : + hirda->AbortReceiveCpltCallback = HAL_IRDA_AbortReceiveCpltCallback; /* Legacy weak + AbortReceiveCpltCallback */ + break; + + case HAL_IRDA_MSPINIT_CB_ID : + hirda->MspInitCallback = HAL_IRDA_MspInit; /* Legacy weak MspInitCallback */ + break; + + case HAL_IRDA_MSPDEINIT_CB_ID : + hirda->MspDeInitCallback = HAL_IRDA_MspDeInit; /* Legacy weak MspDeInitCallback */ + break; + + default : + /* Update the error code */ + hirda->ErrorCode |= HAL_IRDA_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_IRDA_STATE_RESET == hirda->gState) + { + switch (CallbackID) + { + case HAL_IRDA_MSPINIT_CB_ID : + hirda->MspInitCallback = HAL_IRDA_MspInit; + break; + + case HAL_IRDA_MSPDEINIT_CB_ID : + hirda->MspDeInitCallback = HAL_IRDA_MspDeInit; + break; + + default : + /* Update the error code */ + hirda->ErrorCode |= HAL_IRDA_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hirda->ErrorCode |= HAL_IRDA_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hirda); + + return status; +} +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup IRDA_Exported_Functions_Group2 IO operation functions + * @brief IRDA Transmit and Receive functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to manage the IRDA data transfers. + + [..] + IrDA is a half duplex communication protocol. If the Transmitter is busy, any data + on the IrDA receive line will be ignored by the IrDA decoder and if the Receiver + is busy, data on the TX from the USART to IrDA will not be encoded by IrDA. + While receiving data, transmission should be avoided as the data to be transmitted + could be corrupted. + + [..] + (#) There are two modes of transfer: + (++) Blocking mode: the communication is performed in polling mode. + The HAL status of all data processing is returned by the same function + after finishing transfer. + (++) Non-Blocking mode: the communication is performed using Interrupts + or DMA, these API's return the HAL status. + The end of the data processing will be indicated through the + dedicated IRDA IRQ when using Interrupt mode or the DMA IRQ when + using DMA mode. + The HAL_IRDA_TxCpltCallback(), HAL_IRDA_RxCpltCallback() user callbacks + will be executed respectively at the end of the Transmit or Receive process + The HAL_IRDA_ErrorCallback() user callback will be executed when a communication error is detected + + (#) Blocking mode APIs are : + (++) HAL_IRDA_Transmit() + (++) HAL_IRDA_Receive() + + (#) Non Blocking mode APIs with Interrupt are : + (++) HAL_IRDA_Transmit_IT() + (++) HAL_IRDA_Receive_IT() + (++) HAL_IRDA_IRQHandler() + + (#) Non Blocking mode functions with DMA are : + (++) HAL_IRDA_Transmit_DMA() + (++) HAL_IRDA_Receive_DMA() + (++) HAL_IRDA_DMAPause() + (++) HAL_IRDA_DMAResume() + (++) HAL_IRDA_DMAStop() + + (#) A set of Transfer Complete Callbacks are provided in Non Blocking mode: + (++) HAL_IRDA_TxHalfCpltCallback() + (++) HAL_IRDA_TxCpltCallback() + (++) HAL_IRDA_RxHalfCpltCallback() + (++) HAL_IRDA_RxCpltCallback() + (++) HAL_IRDA_ErrorCallback() + + (#) Non-Blocking mode transfers could be aborted using Abort API's : + (++) HAL_IRDA_Abort() + (++) HAL_IRDA_AbortTransmit() + (++) HAL_IRDA_AbortReceive() + (++) HAL_IRDA_Abort_IT() + (++) HAL_IRDA_AbortTransmit_IT() + (++) HAL_IRDA_AbortReceive_IT() + + (#) For Abort services based on interrupts (HAL_IRDA_Abortxxx_IT), a set of Abort Complete Callbacks are provided: + (++) HAL_IRDA_AbortCpltCallback() + (++) HAL_IRDA_AbortTransmitCpltCallback() + (++) HAL_IRDA_AbortReceiveCpltCallback() + + (#) In Non-Blocking mode transfers, possible errors are split into 2 categories. + Errors are handled as follows : + (++) Error is considered as Recoverable and non blocking : Transfer could go till end, but error severity is + to be evaluated by user : this concerns Frame Error, Parity Error or Noise Error + in Interrupt mode reception . + Received character is then retrieved and stored in Rx buffer, Error code is set to allow user + to identify error type, and HAL_IRDA_ErrorCallback() user callback is executed. + Transfer is kept ongoing on IRDA side. + If user wants to abort it, Abort services should be called by user. + (++) Error is considered as Blocking : Transfer could not be completed properly and is aborted. + This concerns Overrun Error In Interrupt mode reception and all errors in DMA mode. + Error code is set to allow user to identify error type, and + HAL_IRDA_ErrorCallback() user callback is executed. + +@endverbatim + * @{ + */ + +/** + * @brief Send an amount of data in blocking mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must reflect the number + * of u16 available through pData. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be sent. + * @param Timeout Specify timeout value. + * @retval HAL status + */ +/** + * @note When IRDA parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pData. + */ +HAL_StatusTypeDef HAL_IRDA_Transmit(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint8_t *pdata8bits; + uint16_t *pdata16bits; + uint32_t tickstart; + + /* Check that a Tx process is not already ongoing */ + if (hirda->gState == HAL_IRDA_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR will be + handled through a u16 cast. */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(hirda); + + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + hirda->gState = HAL_IRDA_STATE_BUSY_TX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + hirda->TxXferSize = Size; + hirda->TxXferCount = Size; + + /* In case of 9bits/No Parity transfer, pData needs to be handled as a uint16_t pointer */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + pdata8bits = NULL; + pdata16bits = (uint16_t *) pData; /* Derogation R.11.3 */ + } + else + { + pdata8bits = pData; + pdata16bits = NULL; + } + + while (hirda->TxXferCount > 0U) + { + hirda->TxXferCount--; + + if (IRDA_WaitOnFlagUntilTimeout(hirda, IRDA_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + if (pdata8bits == NULL) + { + hirda->Instance->TDR = (uint16_t)(*pdata16bits & 0x01FFU); + pdata16bits++; + } + else + { + hirda->Instance->TDR = (uint8_t)(*pdata8bits & 0xFFU); + pdata8bits++; + } + } + + if (IRDA_WaitOnFlagUntilTimeout(hirda, IRDA_FLAG_TC, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + + /* At end of Tx process, restore hirda->gState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in blocking mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must reflect the number + * of u16 available through pData. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @param Timeout Specify timeout value. + * @retval HAL status + */ +/** + * @note When IRDA parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier (16 bits) + * (as received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pData. + */ +HAL_StatusTypeDef HAL_IRDA_Receive(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint8_t *pdata8bits; + uint16_t *pdata16bits; + uint16_t uhMask; + uint32_t tickstart; + + /* Check that a Rx process is not already ongoing */ + if (hirda->RxState == HAL_IRDA_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be received from RDR will be + handled through a u16 cast. */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(hirda); + + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + hirda->RxState = HAL_IRDA_STATE_BUSY_RX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + hirda->RxXferSize = Size; + hirda->RxXferCount = Size; + + /* Computation of the mask to apply to RDR register + of the UART associated to the IRDA */ + IRDA_MASK_COMPUTATION(hirda); + uhMask = hirda->Mask; + + /* In case of 9bits/No Parity transfer, pRxData needs to be handled as a uint16_t pointer */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + pdata8bits = NULL; + pdata16bits = (uint16_t *) pData; /* Derogation R.11.3 */ + } + else + { + pdata8bits = pData; + pdata16bits = NULL; + } + + /* Check data remaining to be received */ + while (hirda->RxXferCount > 0U) + { + hirda->RxXferCount--; + + if (IRDA_WaitOnFlagUntilTimeout(hirda, IRDA_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + if (pdata8bits == NULL) + { + *pdata16bits = (uint16_t)(hirda->Instance->RDR & uhMask); + pdata16bits++; + } + else + { + *pdata8bits = (uint8_t)(hirda->Instance->RDR & (uint8_t)uhMask); + pdata8bits++; + } + } + + /* At end of Rx process, restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in interrupt mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must reflect the number + * of u16 available through pData. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be sent. + * @retval HAL status + */ +/** + * @note When IRDA parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pData. + */ +HAL_StatusTypeDef HAL_IRDA_Transmit_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size) +{ + /* Check that a Tx process is not already ongoing */ + if (hirda->gState == HAL_IRDA_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR will be + handled through a u16 cast. */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(hirda); + + hirda->pTxBuffPtr = pData; + hirda->TxXferSize = Size; + hirda->TxXferCount = Size; + + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + hirda->gState = HAL_IRDA_STATE_BUSY_TX; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + /* Enable the IRDA Transmit Data Register Empty Interrupt */ + SET_BIT(hirda->Instance->CR1, USART_CR1_TXEIE); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in interrupt mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must reflect the number + * of u16 available through pData. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +/** + * @note When IRDA parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier (16 bits) + * (as received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pData. + */ +HAL_StatusTypeDef HAL_IRDA_Receive_IT(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size) +{ + /* Check that a Rx process is not already ongoing */ + if (hirda->RxState == HAL_IRDA_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be received from RDR will be + handled through a u16 cast. */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(hirda); + + hirda->pRxBuffPtr = pData; + hirda->RxXferSize = Size; + hirda->RxXferCount = Size; + + /* Computation of the mask to apply to the RDR register + of the UART associated to the IRDA */ + IRDA_MASK_COMPUTATION(hirda); + + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + hirda->RxState = HAL_IRDA_STATE_BUSY_RX; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + /* Enable the IRDA Parity Error and Data Register not empty Interrupts */ + SET_BIT(hirda->Instance->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE); + + /* Enable the IRDA Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in DMA mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must reflect the number + * of u16 available through pData. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @param pData pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be sent. + * @retval HAL status + */ +/** + * @note When IRDA parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled by DMA from halfword frontier). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pData. + */ +HAL_StatusTypeDef HAL_IRDA_Transmit_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size) +{ + /* Check that a Tx process is not already ongoing */ + if (hirda->gState == HAL_IRDA_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data copy into TDR will be + handled by DMA from a u16 frontier. */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(hirda); + + hirda->pTxBuffPtr = pData; + hirda->TxXferSize = Size; + hirda->TxXferCount = Size; + + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + hirda->gState = HAL_IRDA_STATE_BUSY_TX; + + /* Set the IRDA DMA transfer complete callback */ + hirda->hdmatx->XferCpltCallback = IRDA_DMATransmitCplt; + + /* Set the IRDA DMA half transfer complete callback */ + hirda->hdmatx->XferHalfCpltCallback = IRDA_DMATransmitHalfCplt; + + /* Set the DMA error callback */ + hirda->hdmatx->XferErrorCallback = IRDA_DMAError; + + /* Set the DMA abort callback */ + hirda->hdmatx->XferAbortCallback = NULL; + + /* Enable the IRDA transmit DMA channel */ + if (HAL_DMA_Start_IT(hirda->hdmatx, (uint32_t)hirda->pTxBuffPtr, (uint32_t)&hirda->Instance->TDR, Size) == HAL_OK) + { + /* Clear the TC flag in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_TCF); + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + /* Enable the DMA transfer for transmit request by setting the DMAT bit + in the USART CR3 register */ + SET_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + + return HAL_OK; + } + else + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + /* Restore hirda->gState to ready */ + hirda->gState = HAL_IRDA_STATE_READY; + + return HAL_ERROR; + } + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in DMA mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must reflect the number + * of u16 available through pData. + * @note When the IRDA parity is enabled (PCE = 1), the received data contains + * the parity bit (MSB position). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +/** + * @note When IRDA parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier (16 bits) + * (as received data will be handled by DMA from halfword frontier). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pData. + */ +HAL_StatusTypeDef HAL_IRDA_Receive_DMA(IRDA_HandleTypeDef *hirda, uint8_t *pData, uint16_t Size) +{ + /* Check that a Rx process is not already ongoing */ + if (hirda->RxState == HAL_IRDA_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data copy from RDR will be + handled by DMA from a u16 frontier. */ + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(hirda); + + hirda->pRxBuffPtr = pData; + hirda->RxXferSize = Size; + + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + hirda->RxState = HAL_IRDA_STATE_BUSY_RX; + + /* Set the IRDA DMA transfer complete callback */ + hirda->hdmarx->XferCpltCallback = IRDA_DMAReceiveCplt; + + /* Set the IRDA DMA half transfer complete callback */ + hirda->hdmarx->XferHalfCpltCallback = IRDA_DMAReceiveHalfCplt; + + /* Set the DMA error callback */ + hirda->hdmarx->XferErrorCallback = IRDA_DMAError; + + /* Set the DMA abort callback */ + hirda->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(hirda->hdmarx, (uint32_t)&hirda->Instance->RDR, (uint32_t)hirda->pRxBuffPtr, Size) == HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + /* Enable the UART Parity Error Interrupt */ + SET_BIT(hirda->Instance->CR1, USART_CR1_PEIE); + + /* Enable the UART Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Enable the DMA transfer for the receiver request by setting the DMAR bit + in the USART CR3 register */ + SET_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + return HAL_OK; + } + else + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + /* Restore hirda->RxState to ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + + return HAL_ERROR; + } + } + else + { + return HAL_BUSY; + } +} + + +/** + * @brief Pause the DMA Transfer. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_DMAPause(IRDA_HandleTypeDef *hirda) +{ + /* Process Locked */ + __HAL_LOCK(hirda); + + if (hirda->gState == HAL_IRDA_STATE_BUSY_TX) + { + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + /* Disable the IRDA DMA Tx request */ + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + } + } + if (hirda->RxState == HAL_IRDA_STATE_BUSY_RX) + { + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hirda->Instance->CR1, USART_CR1_PEIE); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Disable the IRDA DMA Rx request */ + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + } + } + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + return HAL_OK; +} + +/** + * @brief Resume the DMA Transfer. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_DMAResume(IRDA_HandleTypeDef *hirda) +{ + /* Process Locked */ + __HAL_LOCK(hirda); + + if (hirda->gState == HAL_IRDA_STATE_BUSY_TX) + { + /* Enable the IRDA DMA Tx request */ + SET_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + } + if (hirda->RxState == HAL_IRDA_STATE_BUSY_RX) + { + /* Clear the Overrun flag before resuming the Rx transfer*/ + __HAL_IRDA_CLEAR_OREFLAG(hirda); + + /* Re-enable PE and ERR (Frame error, noise error, overrun error) interrupts */ + SET_BIT(hirda->Instance->CR1, USART_CR1_PEIE); + SET_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Enable the IRDA DMA Rx request */ + SET_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + } + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + return HAL_OK; +} + +/** + * @brief Stop the DMA Transfer. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_DMAStop(IRDA_HandleTypeDef *hirda) +{ + /* The Lock is not implemented on this API to allow the user application + to call the HAL IRDA API under callbacks HAL_IRDA_TxCpltCallback() / HAL_IRDA_RxCpltCallback() / + HAL_IRDA_TxHalfCpltCallback / HAL_IRDA_RxHalfCpltCallback: + indeed, when HAL_DMA_Abort() API is called, the DMA TX/RX Transfer or Half Transfer complete + interrupt is generated if the DMA transfer interruption occurs at the middle or at the end of + the stream and the corresponding call back is executed. */ + + /* Stop IRDA DMA Tx request if ongoing */ + if (hirda->gState == HAL_IRDA_STATE_BUSY_TX) + { + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + + /* Abort the IRDA DMA Tx channel */ + if (hirda->hdmatx != NULL) + { + if (HAL_DMA_Abort(hirda->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(hirda->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + + IRDA_EndTxTransfer(hirda); + } + } + + /* Stop IRDA DMA Rx request if ongoing */ + if (hirda->RxState == HAL_IRDA_STATE_BUSY_RX) + { + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + /* Abort the IRDA DMA Rx channel */ + if (hirda->hdmarx != NULL) + { + if (HAL_DMA_Abort(hirda->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(hirda->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + + IRDA_EndRxTransfer(hirda); + } + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing transfers (blocking mode). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable IRDA Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_Abort(IRDA_HandleTypeDef *hirda) +{ + /* Disable TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE)); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Disable the IRDA DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + + /* Abort the IRDA DMA Tx channel : use blocking DMA Abort API (no callback) */ + if (hirda->hdmatx != NULL) + { + /* Set the IRDA DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hirda->hdmatx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hirda->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(hirda->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Disable the IRDA DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + /* Abort the IRDA DMA Rx channel : use blocking DMA Abort API (no callback) */ + if (hirda->hdmarx != NULL) + { + /* Set the IRDA DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hirda->hdmarx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hirda->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(hirda->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Tx and Rx transfer counters */ + hirda->TxXferCount = 0U; + hirda->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->gState and hirda->RxState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + hirda->RxState = HAL_IRDA_STATE_READY; + + /* Reset Handle ErrorCode to No Error */ + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + + return HAL_OK; +} + +/** + * @brief Abort ongoing Transmit transfer (blocking mode). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable IRDA Interrupts (Tx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_AbortTransmit(IRDA_HandleTypeDef *hirda) +{ + /* Disable TXEIE and TCIE interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* Disable the IRDA DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + + /* Abort the IRDA DMA Tx channel : use blocking DMA Abort API (no callback) */ + if (hirda->hdmatx != NULL) + { + /* Set the IRDA DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hirda->hdmatx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hirda->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(hirda->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Tx transfer counter */ + hirda->TxXferCount = 0U; + + /* Restore hirda->gState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Abort ongoing Receive transfer (blocking mode). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable IRDA Interrupts (Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_AbortReceive(IRDA_HandleTypeDef *hirda) +{ + /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Disable the IRDA DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + /* Abort the IRDA DMA Rx channel : use blocking DMA Abort API (no callback) */ + if (hirda->hdmarx != NULL) + { + /* Set the IRDA DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hirda->hdmarx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hirda->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(hirda->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hirda->ErrorCode = HAL_IRDA_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Rx transfer counter */ + hirda->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Abort ongoing transfers (Interrupt mode). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable IRDA Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_Abort_IT(IRDA_HandleTypeDef *hirda) +{ + uint32_t abortcplt = 1U; + + /* Disable TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE)); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* If DMA Tx and/or DMA Rx Handles are associated to IRDA Handle, DMA Abort complete callbacks should be initialised + before any call to DMA Abort functions */ + /* DMA Tx Handle is valid */ + if (hirda->hdmatx != NULL) + { + /* Set DMA Abort Complete callback if IRDA DMA Tx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + hirda->hdmatx->XferAbortCallback = IRDA_DMATxAbortCallback; + } + else + { + hirda->hdmatx->XferAbortCallback = NULL; + } + } + /* DMA Rx Handle is valid */ + if (hirda->hdmarx != NULL) + { + /* Set DMA Abort Complete callback if IRDA DMA Rx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + hirda->hdmarx->XferAbortCallback = IRDA_DMARxAbortCallback; + } + else + { + hirda->hdmarx->XferAbortCallback = NULL; + } + } + + /* Disable the IRDA DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + /* Disable DMA Tx at UART level */ + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + + /* Abort the IRDA DMA Tx channel : use non blocking DMA Abort API (callback) */ + if (hirda->hdmatx != NULL) + { + /* IRDA Tx DMA Abort callback has already been initialised : + will lead to call HAL_IRDA_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hirda->hdmatx) != HAL_OK) + { + hirda->hdmatx->XferAbortCallback = NULL; + } + else + { + abortcplt = 0U; + } + } + } + + /* Disable the IRDA DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + /* Abort the IRDA DMA Rx channel : use non blocking DMA Abort API (callback) */ + if (hirda->hdmarx != NULL) + { + /* IRDA Rx DMA Abort callback has already been initialised : + will lead to call HAL_IRDA_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hirda->hdmarx) != HAL_OK) + { + hirda->hdmarx->XferAbortCallback = NULL; + abortcplt = 1U; + } + else + { + abortcplt = 0U; + } + } + } + + /* if no DMA abort complete callback execution is required => call user Abort Complete callback */ + if (abortcplt == 1U) + { + /* Reset Tx and Rx transfer counters */ + hirda->TxXferCount = 0U; + hirda->RxXferCount = 0U; + + /* Reset errorCode */ + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->gState and hirda->RxState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + hirda->RxState = HAL_IRDA_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + hirda->AbortCpltCallback(hirda); +#else + /* Call legacy weak Abort complete callback */ + HAL_IRDA_AbortCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing Transmit transfer (Interrupt mode). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable IRDA Interrupts (Tx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_AbortTransmit_IT(IRDA_HandleTypeDef *hirda) +{ + /* Disable TXEIE and TCIE interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* Disable the IRDA DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + + /* Abort the IRDA DMA Tx channel : use non blocking DMA Abort API (callback) */ + if (hirda->hdmatx != NULL) + { + /* Set the IRDA DMA Abort callback : + will lead to call HAL_IRDA_AbortCpltCallback() at end of DMA abort procedure */ + hirda->hdmatx->XferAbortCallback = IRDA_DMATxOnlyAbortCallback; + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hirda->hdmatx) != HAL_OK) + { + /* Call Directly hirda->hdmatx->XferAbortCallback function in case of error */ + hirda->hdmatx->XferAbortCallback(hirda->hdmatx); + } + } + else + { + /* Reset Tx transfer counter */ + hirda->TxXferCount = 0U; + + /* Restore hirda->gState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + hirda->AbortTransmitCpltCallback(hirda); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_IRDA_AbortTransmitCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + } + else + { + /* Reset Tx transfer counter */ + hirda->TxXferCount = 0U; + + /* Restore hirda->gState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + hirda->AbortTransmitCpltCallback(hirda); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_IRDA_AbortTransmitCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing Receive transfer (Interrupt mode). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable IRDA Interrupts (Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IRDA_AbortReceive_IT(IRDA_HandleTypeDef *hirda) +{ + /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Disable the IRDA DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + /* Abort the IRDA DMA Rx channel : use non blocking DMA Abort API (callback) */ + if (hirda->hdmarx != NULL) + { + /* Set the IRDA DMA Abort callback : + will lead to call HAL_IRDA_AbortCpltCallback() at end of DMA abort procedure */ + hirda->hdmarx->XferAbortCallback = IRDA_DMARxOnlyAbortCallback; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hirda->hdmarx) != HAL_OK) + { + /* Call Directly hirda->hdmarx->XferAbortCallback function in case of error */ + hirda->hdmarx->XferAbortCallback(hirda->hdmarx); + } + } + else + { + /* Reset Rx transfer counter */ + hirda->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + hirda->AbortReceiveCpltCallback(hirda); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_IRDA_AbortReceiveCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + } + else + { + /* Reset Rx transfer counter */ + hirda->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + hirda->AbortReceiveCpltCallback(hirda); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_IRDA_AbortReceiveCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + + return HAL_OK; +} + +/** + * @brief Handle IRDA interrupt request. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +void HAL_IRDA_IRQHandler(IRDA_HandleTypeDef *hirda) +{ + uint32_t isrflags = READ_REG(hirda->Instance->ISR); + uint32_t cr1its = READ_REG(hirda->Instance->CR1); + uint32_t cr3its; + uint32_t errorflags; + uint32_t errorcode; + + /* If no error occurs */ + errorflags = (isrflags & (uint32_t)(USART_ISR_PE | USART_ISR_FE | USART_ISR_ORE | USART_ISR_NE)); + if (errorflags == 0U) + { + /* IRDA in mode Receiver ---------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + IRDA_Receive_IT(hirda); + return; + } + } + + /* If some errors occur */ + cr3its = READ_REG(hirda->Instance->CR3); + if ((errorflags != 0U) + && (((cr3its & USART_CR3_EIE) != 0U) + || ((cr1its & (USART_CR1_RXNEIE | USART_CR1_PEIE)) != 0U))) + { + /* IRDA parity error interrupt occurred -------------------------------------*/ + if (((isrflags & USART_ISR_PE) != 0U) && ((cr1its & USART_CR1_PEIE) != 0U)) + { + __HAL_IRDA_CLEAR_IT(hirda, IRDA_CLEAR_PEF); + + hirda->ErrorCode |= HAL_IRDA_ERROR_PE; + } + + /* IRDA frame error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_FE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_IRDA_CLEAR_IT(hirda, IRDA_CLEAR_FEF); + + hirda->ErrorCode |= HAL_IRDA_ERROR_FE; + } + + /* IRDA noise error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_NE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_IRDA_CLEAR_IT(hirda, IRDA_CLEAR_NEF); + + hirda->ErrorCode |= HAL_IRDA_ERROR_NE; + } + + /* IRDA Over-Run interrupt occurred -----------------------------------------*/ + if (((isrflags & USART_ISR_ORE) != 0U) && + (((cr1its & USART_CR1_RXNEIE) != 0U) || ((cr3its & USART_CR3_EIE) != 0U))) + { + __HAL_IRDA_CLEAR_IT(hirda, IRDA_CLEAR_OREF); + + hirda->ErrorCode |= HAL_IRDA_ERROR_ORE; + } + + /* Call IRDA Error Call back function if need be --------------------------*/ + if (hirda->ErrorCode != HAL_IRDA_ERROR_NONE) + { + /* IRDA in mode Receiver ---------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + IRDA_Receive_IT(hirda); + } + + /* If Overrun error occurs, or if any error occurs in DMA mode reception, + consider error as blocking */ + errorcode = hirda->ErrorCode; + if ((HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) || + ((errorcode & HAL_IRDA_ERROR_ORE) != 0U)) + { + /* Blocking error : transfer is aborted + Set the IRDA state ready to be able to start again the process, + Disable Rx Interrupts, and disable Rx DMA request, if ongoing */ + IRDA_EndRxTransfer(hirda); + + /* Disable the IRDA DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + /* Abort the IRDA DMA Rx channel */ + if (hirda->hdmarx != NULL) + { + /* Set the IRDA DMA Abort callback : + will lead to call HAL_IRDA_ErrorCallback() at end of DMA abort procedure */ + hirda->hdmarx->XferAbortCallback = IRDA_DMAAbortOnError; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hirda->hdmarx) != HAL_OK) + { + /* Call Directly hirda->hdmarx->XferAbortCallback function in case of error */ + hirda->hdmarx->XferAbortCallback(hirda->hdmarx); + } + } + else + { +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hirda->ErrorCallback(hirda); +#else + /* Call legacy weak user error callback */ + HAL_IRDA_ErrorCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + } + else + { +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hirda->ErrorCallback(hirda); +#else + /* Call legacy weak user error callback */ + HAL_IRDA_ErrorCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + } + else + { + /* Non Blocking error : transfer could go on. + Error is notified to user through user error callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hirda->ErrorCallback(hirda); +#else + /* Call legacy weak user error callback */ + HAL_IRDA_ErrorCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + } + } + return; + + } /* End if some error occurs */ + + /* IRDA in mode Transmitter ------------------------------------------------*/ + if (((isrflags & USART_ISR_TXE) != 0U) && ((cr1its & USART_CR1_TXEIE) != 0U)) + { + IRDA_Transmit_IT(hirda); + return; + } + + /* IRDA in mode Transmitter (transmission end) -----------------------------*/ + if (((isrflags & USART_ISR_TC) != 0U) && ((cr1its & USART_CR1_TCIE) != 0U)) + { + IRDA_EndTransmit_IT(hirda); + return; + } + +} + +/** + * @brief Tx Transfer completed callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_TxCpltCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_TxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Tx Half Transfer completed callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified USART module. + * @retval None + */ +__weak void HAL_IRDA_TxHalfCpltCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_TxHalfCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Rx Transfer completed callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_RxCpltCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_RxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Rx Half Transfer complete callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_RxHalfCpltCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_RxHalfCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief IRDA error callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_ErrorCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_ErrorCallback can be implemented in the user file. + */ +} + +/** + * @brief IRDA Abort Complete callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_AbortCpltCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_AbortCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief IRDA Abort Complete callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_AbortTransmitCpltCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_AbortTransmitCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief IRDA Abort Receive Complete callback. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +__weak void HAL_IRDA_AbortReceiveCpltCallback(IRDA_HandleTypeDef *hirda) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hirda); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_IRDA_AbortReceiveCpltCallback can be implemented in the user file. + */ +} + +/** + * @} + */ + +/** @defgroup IRDA_Exported_Functions_Group4 Peripheral State and Error functions + * @brief IRDA State and Errors functions + * +@verbatim + ============================================================================== + ##### Peripheral State and Error functions ##### + ============================================================================== + [..] + This subsection provides a set of functions allowing to return the State of IrDA + communication process and also return Peripheral Errors occurred during communication process + (+) HAL_IRDA_GetState() API can be helpful to check in run-time the state + of the IRDA peripheral handle. + (+) HAL_IRDA_GetError() checks in run-time errors that could occur during + communication. + +@endverbatim + * @{ + */ + +/** + * @brief Return the IRDA handle state. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval HAL state + */ +HAL_IRDA_StateTypeDef HAL_IRDA_GetState(IRDA_HandleTypeDef *hirda) +{ + /* Return IRDA handle state */ + uint32_t temp1; + uint32_t temp2; + temp1 = (uint32_t)hirda->gState; + temp2 = (uint32_t)hirda->RxState; + + return (HAL_IRDA_StateTypeDef)(temp1 | temp2); +} + +/** + * @brief Return the IRDA handle error code. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval IRDA Error Code + */ +uint32_t HAL_IRDA_GetError(IRDA_HandleTypeDef *hirda) +{ + return hirda->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup IRDA_Private_Functions IRDA Private Functions + * @{ + */ + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) +/** + * @brief Initialize the callbacks to their default values. + * @param hirda IRDA handle. + * @retval none + */ +void IRDA_InitCallbacksToDefault(IRDA_HandleTypeDef *hirda) +{ + /* Init the IRDA Callback settings */ + hirda->TxHalfCpltCallback = HAL_IRDA_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + hirda->TxCpltCallback = HAL_IRDA_TxCpltCallback; /* Legacy weak TxCpltCallback */ + hirda->RxHalfCpltCallback = HAL_IRDA_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + hirda->RxCpltCallback = HAL_IRDA_RxCpltCallback; /* Legacy weak RxCpltCallback */ + hirda->ErrorCallback = HAL_IRDA_ErrorCallback; /* Legacy weak ErrorCallback */ + hirda->AbortCpltCallback = HAL_IRDA_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + hirda->AbortTransmitCpltCallback = HAL_IRDA_AbortTransmitCpltCallback; /* Legacy weak AbortTransmitCpltCallback */ + hirda->AbortReceiveCpltCallback = HAL_IRDA_AbortReceiveCpltCallback; /* Legacy weak AbortReceiveCpltCallback */ + +} +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + +/** + * @brief Configure the IRDA peripheral. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval HAL status + */ +static HAL_StatusTypeDef IRDA_SetConfig(IRDA_HandleTypeDef *hirda) +{ + uint32_t tmpreg; + IRDA_ClockSourceTypeDef clocksource; + HAL_StatusTypeDef ret = HAL_OK; + uint32_t pclk; + + /* Check the communication parameters */ + assert_param(IS_IRDA_BAUDRATE(hirda->Init.BaudRate)); + assert_param(IS_IRDA_WORD_LENGTH(hirda->Init.WordLength)); + assert_param(IS_IRDA_PARITY(hirda->Init.Parity)); + assert_param(IS_IRDA_TX_RX_MODE(hirda->Init.Mode)); + assert_param(IS_IRDA_PRESCALER(hirda->Init.Prescaler)); + assert_param(IS_IRDA_POWERMODE(hirda->Init.PowerMode)); + + /*-------------------------- USART CR1 Configuration -----------------------*/ + /* Configure the IRDA Word Length, Parity and transfer Mode: + Set the M bits according to hirda->Init.WordLength value + Set PCE and PS bits according to hirda->Init.Parity value + Set TE and RE bits according to hirda->Init.Mode value */ + tmpreg = (uint32_t)hirda->Init.WordLength | hirda->Init.Parity | hirda->Init.Mode ; + + MODIFY_REG(hirda->Instance->CR1, IRDA_CR1_FIELDS, tmpreg); + + /*-------------------------- USART CR3 Configuration -----------------------*/ + MODIFY_REG(hirda->Instance->CR3, USART_CR3_IRLP, hirda->Init.PowerMode); + + + /*-------------------------- USART GTPR Configuration ----------------------*/ + MODIFY_REG(hirda->Instance->GTPR, (uint16_t)USART_GTPR_PSC, (uint16_t)hirda->Init.Prescaler); + + /*-------------------------- USART BRR Configuration -----------------------*/ + IRDA_GETCLOCKSOURCE(hirda, clocksource); + tmpreg = 0U; + switch (clocksource) + { + case IRDA_CLOCKSOURCE_PCLK1: + pclk = HAL_RCC_GetPCLK1Freq(); + tmpreg = (uint16_t)(IRDA_DIV_SAMPLING16(pclk, hirda->Init.BaudRate)); + break; + case IRDA_CLOCKSOURCE_HSI: + tmpreg = (uint16_t)(IRDA_DIV_SAMPLING16(HSI_VALUE, hirda->Init.BaudRate)); + break; + case IRDA_CLOCKSOURCE_SYSCLK: + pclk = HAL_RCC_GetSysClockFreq(); + tmpreg = (uint16_t)(IRDA_DIV_SAMPLING16(pclk, hirda->Init.BaudRate)); + break; + case IRDA_CLOCKSOURCE_LSE: + tmpreg = (uint16_t)(IRDA_DIV_SAMPLING16((uint32_t)LSE_VALUE, hirda->Init.BaudRate)); + break; + default: + ret = HAL_ERROR; + break; + } + + /* USARTDIV must be greater than or equal to 0d16 */ + if ((tmpreg >= USART_BRR_MIN) && (tmpreg <= USART_BRR_MAX)) + { + hirda->Instance->BRR = tmpreg; + } + else + { + ret = HAL_ERROR; + } + + return ret; +} + +/** + * @brief Check the IRDA Idle State. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval HAL status + */ +static HAL_StatusTypeDef IRDA_CheckIdleState(IRDA_HandleTypeDef *hirda) +{ + uint32_t tickstart; + + /* Initialize the IRDA ErrorCode */ + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + /* Check if the Transmitter is enabled */ + if ((hirda->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE) + { + /* Wait until TEACK flag is set */ + if (IRDA_WaitOnFlagUntilTimeout(hirda, USART_ISR_TEACK, RESET, tickstart, IRDA_TEACK_REACK_TIMEOUT) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + /* Check if the Receiver is enabled */ + if ((hirda->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE) + { + /* Wait until REACK flag is set */ + if (IRDA_WaitOnFlagUntilTimeout(hirda, USART_ISR_REACK, RESET, tickstart, IRDA_TEACK_REACK_TIMEOUT) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + + /* Initialize the IRDA state*/ + hirda->gState = HAL_IRDA_STATE_READY; + hirda->RxState = HAL_IRDA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + + return HAL_OK; +} + +/** + * @brief Handle IRDA Communication Timeout. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @param Flag Specifies the IRDA flag to check. + * @param Status Flag status (SET or RESET) + * @param Tickstart Tick start value + * @param Timeout Timeout duration + * @retval HAL status + */ +static HAL_StatusTypeDef IRDA_WaitOnFlagUntilTimeout(IRDA_HandleTypeDef *hirda, uint32_t Flag, FlagStatus Status, + uint32_t Tickstart, uint32_t Timeout) +{ + /* Wait until flag is set */ + while ((__HAL_IRDA_GET_FLAG(hirda, Flag) ? SET : RESET) == Status) + { + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + /* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error) + interrupts for the interrupt process */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE)); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + hirda->gState = HAL_IRDA_STATE_READY; + hirda->RxState = HAL_IRDA_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hirda); + return HAL_TIMEOUT; + } + } + } + return HAL_OK; +} + + +/** + * @brief End ongoing Tx transfer on IRDA peripheral (following error detection or Transmit completion). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +static void IRDA_EndTxTransfer(IRDA_HandleTypeDef *hirda) +{ + /* Disable TXEIE and TCIE interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* At end of Tx process, restore hirda->gState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; +} + + +/** + * @brief End ongoing Rx transfer on UART peripheral (following error detection or Reception completion). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +static void IRDA_EndRxTransfer(IRDA_HandleTypeDef *hirda) +{ + /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* At end of Rx process, restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; +} + + +/** + * @brief DMA IRDA transmit process complete callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void IRDA_DMATransmitCplt(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + + /* DMA Normal mode */ + if (HAL_IS_BIT_CLR(hdma->Instance->CCR, DMA_CCR_CIRC)) + { + hirda->TxXferCount = 0U; + + /* Disable the DMA transfer for transmit request by resetting the DMAT bit + in the IRDA CR3 register */ + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAT); + + /* Enable the IRDA Transmit Complete Interrupt */ + SET_BIT(hirda->Instance->CR1, USART_CR1_TCIE); + } + /* DMA Circular mode */ + else + { +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Tx complete callback */ + hirda->TxCpltCallback(hirda); +#else + /* Call legacy weak Tx complete callback */ + HAL_IRDA_TxCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ + } + +} + +/** + * @brief DMA IRDA transmit process half complete callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void IRDA_DMATransmitHalfCplt(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Tx Half complete callback */ + hirda->TxHalfCpltCallback(hirda); +#else + /* Call legacy weak Tx complete callback */ + HAL_IRDA_TxHalfCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + +/** + * @brief DMA IRDA receive process complete callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void IRDA_DMAReceiveCplt(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + + /* DMA Normal mode */ + if (HAL_IS_BIT_CLR(hdma->Instance->CCR, DMA_CCR_CIRC)) + { + hirda->RxXferCount = 0U; + + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hirda->Instance->CR1, USART_CR1_PEIE); + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Disable the DMA transfer for the receiver request by resetting the DMAR bit + in the IRDA CR3 register */ + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_DMAR); + + /* At end of Rx process, restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + } + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Rx complete callback */ + hirda->RxCpltCallback(hirda); +#else + /* Call legacy weak Rx complete callback */ + HAL_IRDA_RxCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA IRDA receive process half complete callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void IRDA_DMAReceiveHalfCplt(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /*Call registered Rx Half complete callback*/ + hirda->RxHalfCpltCallback(hirda); +#else + /* Call legacy weak Rx Half complete callback */ + HAL_IRDA_RxHalfCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + +/** + * @brief DMA IRDA communication error callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void IRDA_DMAError(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + + /* Stop IRDA DMA Tx request if ongoing */ + if (hirda->gState == HAL_IRDA_STATE_BUSY_TX) + { + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAT)) + { + hirda->TxXferCount = 0U; + IRDA_EndTxTransfer(hirda); + } + } + + /* Stop IRDA DMA Rx request if ongoing */ + if (hirda->RxState == HAL_IRDA_STATE_BUSY_RX) + { + if (HAL_IS_BIT_SET(hirda->Instance->CR3, USART_CR3_DMAR)) + { + hirda->RxXferCount = 0U; + IRDA_EndRxTransfer(hirda); + } + } + + hirda->ErrorCode |= HAL_IRDA_ERROR_DMA; +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hirda->ErrorCallback(hirda); +#else + /* Call legacy weak user error callback */ + HAL_IRDA_ErrorCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + +/** + * @brief DMA IRDA communication abort callback, when initiated by HAL services on Error + * (To be called at end of DMA Abort procedure following error occurrence). + * @param hdma DMA handle. + * @retval None + */ +static void IRDA_DMAAbortOnError(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + hirda->RxXferCount = 0U; + hirda->TxXferCount = 0U; + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hirda->ErrorCallback(hirda); +#else + /* Call legacy weak user error callback */ + HAL_IRDA_ErrorCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + +/** + * @brief DMA IRDA Tx communication abort callback, when initiated by user + * (To be called at end of DMA Tx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Rx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void IRDA_DMATxAbortCallback(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + + hirda->hdmatx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (hirda->hdmarx != NULL) + { + if (hirda->hdmarx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + hirda->TxXferCount = 0U; + hirda->RxXferCount = 0U; + + /* Reset errorCode */ + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->gState and hirda->RxState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + hirda->RxState = HAL_IRDA_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + hirda->AbortCpltCallback(hirda); +#else + /* Call legacy weak Abort complete callback */ + HAL_IRDA_AbortCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + + +/** + * @brief DMA IRDA Rx communication abort callback, when initiated by user + * (To be called at end of DMA Rx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Tx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void IRDA_DMARxAbortCallback(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + + hirda->hdmarx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (hirda->hdmatx != NULL) + { + if (hirda->hdmatx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + hirda->TxXferCount = 0U; + hirda->RxXferCount = 0U; + + /* Reset errorCode */ + hirda->ErrorCode = HAL_IRDA_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->gState and hirda->RxState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + hirda->RxState = HAL_IRDA_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + hirda->AbortCpltCallback(hirda); +#else + /* Call legacy weak Abort complete callback */ + HAL_IRDA_AbortCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + + +/** + * @brief DMA IRDA Tx communication abort callback, when initiated by user by a call to + * HAL_IRDA_AbortTransmit_IT API (Abort only Tx transfer) + * (This callback is executed at end of DMA Tx Abort procedure following user abort request, + * and leads to user Tx Abort Complete callback execution). + * @param hdma DMA handle. + * @retval None + */ +static void IRDA_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)(hdma->Parent); + + hirda->TxXferCount = 0U; + + /* Restore hirda->gState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + hirda->AbortTransmitCpltCallback(hirda); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_IRDA_AbortTransmitCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + +/** + * @brief DMA IRDA Rx communication abort callback, when initiated by user by a call to + * HAL_IRDA_AbortReceive_IT API (Abort only Rx transfer) + * (This callback is executed at end of DMA Rx Abort procedure following user abort request, + * and leads to user Rx Abort Complete callback execution). + * @param hdma DMA handle. + * @retval None + */ +static void IRDA_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma) +{ + IRDA_HandleTypeDef *hirda = (IRDA_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + hirda->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_IRDA_CLEAR_FLAG(hirda, IRDA_CLEAR_OREF | IRDA_CLEAR_NEF | IRDA_CLEAR_PEF | IRDA_CLEAR_FEF); + + /* Restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + hirda->AbortReceiveCpltCallback(hirda); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_IRDA_AbortReceiveCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + +/** + * @brief Send an amount of data in interrupt mode. + * @note Function is called under interruption only, once + * interruptions have been enabled by HAL_IRDA_Transmit_IT(). + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +static void IRDA_Transmit_IT(IRDA_HandleTypeDef *hirda) +{ + uint16_t *tmp; + + /* Check that a Tx process is ongoing */ + if (hirda->gState == HAL_IRDA_STATE_BUSY_TX) + { + if (hirda->TxXferCount == 0U) + { + /* Disable the IRDA Transmit Data Register Empty Interrupt */ + CLEAR_BIT(hirda->Instance->CR1, USART_CR1_TXEIE); + + /* Enable the IRDA Transmit Complete Interrupt */ + SET_BIT(hirda->Instance->CR1, USART_CR1_TCIE); + } + else + { + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + tmp = (uint16_t *) hirda->pTxBuffPtr; /* Derogation R.11.3 */ + hirda->Instance->TDR = (uint16_t)(*tmp & 0x01FFU); + hirda->pTxBuffPtr += 2U; + } + else + { + hirda->Instance->TDR = (uint8_t)(*hirda->pTxBuffPtr & 0xFFU); + hirda->pTxBuffPtr++; + } + hirda->TxXferCount--; + } + } +} + +/** + * @brief Wrap up transmission in non-blocking mode. + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +static void IRDA_EndTransmit_IT(IRDA_HandleTypeDef *hirda) +{ + /* Disable the IRDA Transmit Complete Interrupt */ + CLEAR_BIT(hirda->Instance->CR1, USART_CR1_TCIE); + + /* Tx process is ended, restore hirda->gState to Ready */ + hirda->gState = HAL_IRDA_STATE_READY; + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Tx complete callback */ + hirda->TxCpltCallback(hirda); +#else + /* Call legacy weak Tx complete callback */ + HAL_IRDA_TxCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACK */ +} + +/** + * @brief Receive an amount of data in interrupt mode. + * @note Function is called under interruption only, once + * interruptions have been enabled by HAL_IRDA_Receive_IT() + * @param hirda Pointer to a IRDA_HandleTypeDef structure that contains + * the configuration information for the specified IRDA module. + * @retval None + */ +static void IRDA_Receive_IT(IRDA_HandleTypeDef *hirda) +{ + uint16_t *tmp; + uint16_t uhMask = hirda->Mask; + uint16_t uhdata; + + /* Check that a Rx process is ongoing */ + if (hirda->RxState == HAL_IRDA_STATE_BUSY_RX) + { + uhdata = (uint16_t) READ_REG(hirda->Instance->RDR); + if ((hirda->Init.WordLength == IRDA_WORDLENGTH_9B) && (hirda->Init.Parity == IRDA_PARITY_NONE)) + { + tmp = (uint16_t *) hirda->pRxBuffPtr; /* Derogation R.11.3 */ + *tmp = (uint16_t)(uhdata & uhMask); + hirda->pRxBuffPtr += 2U; + } + else + { + *hirda->pRxBuffPtr = (uint8_t)(uhdata & (uint8_t)uhMask); + hirda->pRxBuffPtr++; + } + + hirda->RxXferCount--; + if (hirda->RxXferCount == 0U) + { + /* Disable the IRDA Parity Error Interrupt and RXNE interrupt */ + CLEAR_BIT(hirda->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + + /* Disable the IRDA Error Interrupt: (Frame error, noise error, overrun error) */ + CLEAR_BIT(hirda->Instance->CR3, USART_CR3_EIE); + + /* Rx process is completed, restore hirda->RxState to Ready */ + hirda->RxState = HAL_IRDA_STATE_READY; + +#if (USE_HAL_IRDA_REGISTER_CALLBACKS == 1) + /* Call registered Rx complete callback */ + hirda->RxCpltCallback(hirda); +#else + /* Call legacy weak Rx complete callback */ + HAL_IRDA_RxCpltCallback(hirda); +#endif /* USE_HAL_IRDA_REGISTER_CALLBACKS */ + } + } + else + { + /* Clear RXNE interrupt flag */ + __HAL_IRDA_SEND_REQ(hirda, IRDA_RXDATA_FLUSH_REQUEST); + } +} + +/** + * @} + */ + +#endif /* HAL_IRDA_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ +#endif /* USART_IRDA_SUPPORT */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_iwdg.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_iwdg.c new file mode 100644 index 0000000..35700a4 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_iwdg.c @@ -0,0 +1,285 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_iwdg.c + * @author MCD Application Team + * @brief IWDG HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Independent Watchdog (IWDG) peripheral: + * + Initialization and Start functions + * + IO operation functions + * + @verbatim + ============================================================================== + ##### IWDG Generic features ##### + ============================================================================== + [..] + (+) The IWDG can be started by either software or hardware (configurable + through option byte). + + (+) The IWDG is clocked by the Low-Speed Internal clock (LSI) and thus stays + active even if the main clock fails. + + (+) Once the IWDG is started, the LSI is forced ON and both cannot be + disabled. The counter starts counting down from the reset value (0xFFF). + When it reaches the end of count value (0x000) a reset signal is + generated (IWDG reset). + + (+) Whenever the key value 0x0000 AAAA is written in the IWDG_KR register, + the IWDG_RLR value is reloaded into the counter and the watchdog reset + is prevented. + + (+) The IWDG is implemented in the VDD voltage domain that is still functional + in STOP and STANDBY mode (IWDG reset can wake up the CPU from STANDBY). + IWDGRST flag in RCC_CSR register can be used to inform when an IWDG + reset occurs. + + (+) Debug mode: When the microcontroller enters debug mode (core halted), + the IWDG counter either continues to work normally or stops, depending + on DBG_IWDG_STOP configuration bit in DBG module, accessible through + __HAL_DBGMCU_FREEZE_IWDG() and __HAL_DBGMCU_UNFREEZE_IWDG() macros. + + [..] Min-max timeout value @32KHz (LSI): ~125us / ~32.7s + The IWDG timeout may vary due to LSI clock frequency dispersion. + STM32F0xx devices provide the capability to measure the LSI clock + frequency (LSI clock is internally connected to TIM16 CH1 input capture). + The measured value can be used to have an IWDG timeout with an + acceptable accuracy. + + [..] Default timeout value (necessary for IWDG_SR status register update): + Constant LSI_VALUE is defined based on the nominal LSI clock frequency. + This frequency being subject to variations as mentioned above, the + default timeout value (defined through constant HAL_IWDG_DEFAULT_TIMEOUT + below) may become too short or too long. + In such cases, this default timeout value can be tuned by redefining + the constant LSI_VALUE at user-application level (based, for instance, + on the measured LSI clock frequency as explained above). + + ##### How to use this driver ##### + ============================================================================== + [..] + (#) Use IWDG using HAL_IWDG_Init() function to : + (++) Enable instance by writing Start keyword in IWDG_KEY register. LSI + clock is forced ON and IWDG counter starts counting down. + (++) Enable write access to configuration registers: + IWDG_PR, IWDG_RLR and IWDG_WINR. + (++) Configure the IWDG prescaler and counter reload value. This reload + value will be loaded in the IWDG counter each time the watchdog is + reloaded, then the IWDG will start counting down from this value. + (++) Depending on window parameter: + (+++) If Window Init parameter is same as Window register value, + nothing more is done but reload counter value in order to exit + function with exact time base. + (+++) Else modify Window register. This will automatically reload + watchdog counter. + (++) Wait for status flags to be reset. + + (#) Then the application program must refresh the IWDG counter at regular + intervals during normal operation to prevent an MCU reset, using + HAL_IWDG_Refresh() function. + + *** IWDG HAL driver macros list *** + ==================================== + [..] + Below the list of most used macros in IWDG HAL driver: + (+) __HAL_IWDG_START: Enable the IWDG peripheral + (+) __HAL_IWDG_RELOAD_COUNTER: Reloads IWDG counter with value defined in + the reload register + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#ifdef HAL_IWDG_MODULE_ENABLED +/** @addtogroup IWDG + * @brief IWDG HAL module driver. + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup IWDG_Private_Defines IWDG Private Defines + * @{ + */ +/* Status register needs up to 5 LSI clock periods divided by the clock + prescaler to be updated. The number of LSI clock periods is upper-rounded to + 6 for the timeout value calculation. + The timeout value is calculated using the highest prescaler (256) and + the LSI_VALUE constant. The value of this constant can be changed by the user + to take into account possible LSI clock period variations. + The timeout value is multiplied by 1000 to be converted in milliseconds. + LSI startup time is also considered here by adding LSI_STARTUP_TIMEOUT + converted in milliseconds. */ +#define HAL_IWDG_DEFAULT_TIMEOUT (((6UL * 256UL * 1000UL) / LSI_VALUE) + ((LSI_STARTUP_TIME / 1000UL) + 1UL)) +#define IWDG_KERNEL_UPDATE_FLAGS (IWDG_SR_WVU | IWDG_SR_RVU | IWDG_SR_PVU) +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup IWDG_Exported_Functions + * @{ + */ + +/** @addtogroup IWDG_Exported_Functions_Group1 + * @brief Initialization and Start functions. + * +@verbatim + =============================================================================== + ##### Initialization and Start functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Initialize the IWDG according to the specified parameters in the + IWDG_InitTypeDef of associated handle. + (+) Manage Window option. + (+) Once initialization is performed in HAL_IWDG_Init function, Watchdog + is reloaded in order to exit function with correct time base. + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the IWDG according to the specified parameters in the + * IWDG_InitTypeDef and start watchdog. Before exiting function, + * watchdog is refreshed in order to have correct time base. + * @param hiwdg pointer to a IWDG_HandleTypeDef structure that contains + * the configuration information for the specified IWDG module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IWDG_Init(IWDG_HandleTypeDef *hiwdg) +{ + uint32_t tickstart; + + /* Check the IWDG handle allocation */ + if (hiwdg == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_IWDG_ALL_INSTANCE(hiwdg->Instance)); + assert_param(IS_IWDG_PRESCALER(hiwdg->Init.Prescaler)); + assert_param(IS_IWDG_RELOAD(hiwdg->Init.Reload)); + assert_param(IS_IWDG_WINDOW(hiwdg->Init.Window)); + + /* Enable IWDG. LSI is turned on automatically */ + __HAL_IWDG_START(hiwdg); + + /* Enable write access to IWDG_PR, IWDG_RLR and IWDG_WINR registers by writing + 0x5555 in KR */ + IWDG_ENABLE_WRITE_ACCESS(hiwdg); + + /* Write to IWDG registers the Prescaler & Reload values to work with */ + hiwdg->Instance->PR = hiwdg->Init.Prescaler; + hiwdg->Instance->RLR = hiwdg->Init.Reload; + + /* Check pending flag, if previous update not done, return timeout */ + tickstart = HAL_GetTick(); + + /* Wait for register to be updated */ + while ((hiwdg->Instance->SR & IWDG_KERNEL_UPDATE_FLAGS) != 0x00u) + { + if ((HAL_GetTick() - tickstart) > HAL_IWDG_DEFAULT_TIMEOUT) + { + if ((hiwdg->Instance->SR & IWDG_KERNEL_UPDATE_FLAGS) != 0x00u) + { + return HAL_TIMEOUT; + } + } + } + + /* If window parameter is different than current value, modify window + register */ + if (hiwdg->Instance->WINR != hiwdg->Init.Window) + { + /* Write to IWDG WINR the IWDG_Window value to compare with. In any case, + even if window feature is disabled, Watchdog will be reloaded by writing + windows register */ + hiwdg->Instance->WINR = hiwdg->Init.Window; + } + else + { + /* Reload IWDG counter with value defined in the reload register */ + __HAL_IWDG_RELOAD_COUNTER(hiwdg); + } + + /* Return function status */ + return HAL_OK; +} + + +/** + * @} + */ + + +/** @addtogroup IWDG_Exported_Functions_Group2 + * @brief IO operation functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Refresh the IWDG. + +@endverbatim + * @{ + */ + +/** + * @brief Refresh the IWDG. + * @param hiwdg pointer to a IWDG_HandleTypeDef structure that contains + * the configuration information for the specified IWDG module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_IWDG_Refresh(IWDG_HandleTypeDef *hiwdg) +{ + /* Reload IWDG counter with value defined in the reload register */ + __HAL_IWDG_RELOAD_COUNTER(hiwdg); + + /* Return function status */ + return HAL_OK; +} + + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_IWDG_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_msp_template.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_msp_template.c new file mode 100644 index 0000000..9f661e9 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_msp_template.c @@ -0,0 +1,101 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_msp_template.c + * @author MCD Application Team + * @brief HAL MSP module. + * This file template is located in the HAL folder and should be copied + * to the user folder. + * + @verbatim + =============================================================================== + ##### How to use this driver ##### + =============================================================================== + [..] + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup HAL_MSP HAL MSP module driver + * @brief HAL MSP module. + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + +/** @defgroup HAL_MSP_Private_Functions HAL MSP Private Functions + * @{ + */ + +/** + * @brief Initializes the Global MSP. + * @retval None + */ +void HAL_MspInit(void) +{ + +} + +/** + * @brief DeInitializes the Global MSP. + * @retval None + */ +void HAL_MspDeInit(void) +{ + +} + +/** + * @brief Initializes the PPP MSP. + * @retval None + */ +void HAL_PPP_MspInit(void) +{ + +} + +/** + * @brief DeInitializes the PPP MSP. + * @retval None + */ +void HAL_PPP_MspDeInit(void) +{ + +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd.c new file mode 100644 index 0000000..917899f --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd.c @@ -0,0 +1,2184 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pcd.c + * @author MCD Application Team + * @brief PCD HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the USB Peripheral Controller: + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral Control functions + * + Peripheral State functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The PCD HAL driver can be used as follows: + + (#) Declare a PCD_HandleTypeDef handle structure, for example: + PCD_HandleTypeDef hpcd; + + (#) Fill parameters of Init structure in HCD handle + + (#) Call HAL_PCD_Init() API to initialize the PCD peripheral (Core, Device core, ...) + + (#) Initialize the PCD low level resources through the HAL_PCD_MspInit() API: + (##) Enable the PCD/USB Low Level interface clock using + (+++) __HAL_RCC_USB_CLK_ENABLE(); For USB Device only FS peripheral + + (##) Initialize the related GPIO clocks + (##) Configure PCD pin-out + (##) Configure PCD NVIC interrupt + + (#)Associate the Upper USB device stack to the HAL PCD Driver: + (##) hpcd.pData = pdev; + + (#)Enable PCD transmission and reception: + (##) HAL_PCD_Start(); + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup PCD PCD + * @brief PCD HAL module driver + * @{ + */ + +#ifdef HAL_PCD_MODULE_ENABLED + +#if defined (USB) + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @defgroup PCD_Private_Macros PCD Private Macros + * @{ + */ +#define PCD_MIN(a, b) (((a) < (b)) ? (a) : (b)) +#define PCD_MAX(a, b) (((a) > (b)) ? (a) : (b)) +/** + * @} + */ + +/* Private functions prototypes ----------------------------------------------*/ +/** @defgroup PCD_Private_Functions PCD Private Functions + * @{ + */ + +static HAL_StatusTypeDef PCD_EP_ISR_Handler(PCD_HandleTypeDef *hpcd); +static HAL_StatusTypeDef HAL_PCD_EP_DB_Transmit(PCD_HandleTypeDef *hpcd, PCD_EPTypeDef *ep, uint16_t wEPVal); +static uint16_t HAL_PCD_EP_DB_Receive(PCD_HandleTypeDef *hpcd, PCD_EPTypeDef *ep, uint16_t wEPVal); + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup PCD_Exported_Functions PCD Exported Functions + * @{ + */ + +/** @defgroup PCD_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This section provides functions allowing to: + +@endverbatim + * @{ + */ + +/** + * @brief Initializes the PCD according to the specified + * parameters in the PCD_InitTypeDef and initialize the associated handle. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_Init(PCD_HandleTypeDef *hpcd) +{ + uint8_t i; + + /* Check the PCD handle allocation */ + if (hpcd == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_PCD_ALL_INSTANCE(hpcd->Instance)); + + if (hpcd->State == HAL_PCD_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hpcd->Lock = HAL_UNLOCKED; + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->SOFCallback = HAL_PCD_SOFCallback; + hpcd->SetupStageCallback = HAL_PCD_SetupStageCallback; + hpcd->ResetCallback = HAL_PCD_ResetCallback; + hpcd->SuspendCallback = HAL_PCD_SuspendCallback; + hpcd->ResumeCallback = HAL_PCD_ResumeCallback; + hpcd->ConnectCallback = HAL_PCD_ConnectCallback; + hpcd->DisconnectCallback = HAL_PCD_DisconnectCallback; + hpcd->DataOutStageCallback = HAL_PCD_DataOutStageCallback; + hpcd->DataInStageCallback = HAL_PCD_DataInStageCallback; + hpcd->ISOOUTIncompleteCallback = HAL_PCD_ISOOUTIncompleteCallback; + hpcd->ISOINIncompleteCallback = HAL_PCD_ISOINIncompleteCallback; + hpcd->LPMCallback = HAL_PCDEx_LPM_Callback; + hpcd->BCDCallback = HAL_PCDEx_BCD_Callback; + + if (hpcd->MspInitCallback == NULL) + { + hpcd->MspInitCallback = HAL_PCD_MspInit; + } + + /* Init the low level hardware */ + hpcd->MspInitCallback(hpcd); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC... */ + HAL_PCD_MspInit(hpcd); +#endif /* (USE_HAL_PCD_REGISTER_CALLBACKS) */ + } + + hpcd->State = HAL_PCD_STATE_BUSY; + + /* Disable the Interrupts */ + __HAL_PCD_DISABLE(hpcd); + + /* Init endpoints structures */ + for (i = 0U; i < hpcd->Init.dev_endpoints; i++) + { + /* Init ep structure */ + hpcd->IN_ep[i].is_in = 1U; + hpcd->IN_ep[i].num = i; + hpcd->IN_ep[i].tx_fifo_num = i; + /* Control until ep is activated */ + hpcd->IN_ep[i].type = EP_TYPE_CTRL; + hpcd->IN_ep[i].maxpacket = 0U; + hpcd->IN_ep[i].xfer_buff = 0U; + hpcd->IN_ep[i].xfer_len = 0U; + } + + for (i = 0U; i < hpcd->Init.dev_endpoints; i++) + { + hpcd->OUT_ep[i].is_in = 0U; + hpcd->OUT_ep[i].num = i; + /* Control until ep is activated */ + hpcd->OUT_ep[i].type = EP_TYPE_CTRL; + hpcd->OUT_ep[i].maxpacket = 0U; + hpcd->OUT_ep[i].xfer_buff = 0U; + hpcd->OUT_ep[i].xfer_len = 0U; + } + + /* Init Device */ + (void)USB_DevInit(hpcd->Instance, hpcd->Init); + + hpcd->USB_Address = 0U; + hpcd->State = HAL_PCD_STATE_READY; + + /* Activate LPM */ + if (hpcd->Init.lpm_enable == 1U) + { + (void)HAL_PCDEx_ActivateLPM(hpcd); + } + + return HAL_OK; +} + +/** + * @brief DeInitializes the PCD peripheral. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_DeInit(PCD_HandleTypeDef *hpcd) +{ + /* Check the PCD handle allocation */ + if (hpcd == NULL) + { + return HAL_ERROR; + } + + hpcd->State = HAL_PCD_STATE_BUSY; + + /* Stop Device */ + if (USB_StopDevice(hpcd->Instance) != HAL_OK) + { + return HAL_ERROR; + } + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + if (hpcd->MspDeInitCallback == NULL) + { + hpcd->MspDeInitCallback = HAL_PCD_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware */ + hpcd->MspDeInitCallback(hpcd); +#else + /* DeInit the low level hardware: CLOCK, NVIC.*/ + HAL_PCD_MspDeInit(hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + + hpcd->State = HAL_PCD_STATE_RESET; + + return HAL_OK; +} + +/** + * @brief Initializes the PCD MSP. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_MspInit(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes PCD MSP. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_MspDeInit(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_MspDeInit could be implemented in the user file + */ +} + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) +/** + * @brief Register a User USB PCD Callback + * To be used instead of the weak predefined callback + * @param hpcd USB PCD handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_PCD_SOF_CB_ID USB PCD SOF callback ID + * @arg @ref HAL_PCD_SETUPSTAGE_CB_ID USB PCD Setup callback ID + * @arg @ref HAL_PCD_RESET_CB_ID USB PCD Reset callback ID + * @arg @ref HAL_PCD_SUSPEND_CB_ID USB PCD Suspend callback ID + * @arg @ref HAL_PCD_RESUME_CB_ID USB PCD Resume callback ID + * @arg @ref HAL_PCD_CONNECT_CB_ID USB PCD Connect callback ID + * @arg @ref HAL_PCD_DISCONNECT_CB_ID OTG PCD Disconnect callback ID + * @arg @ref HAL_PCD_MSPINIT_CB_ID MspDeInit callback ID + * @arg @ref HAL_PCD_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_RegisterCallback(PCD_HandleTypeDef *hpcd, + HAL_PCD_CallbackIDTypeDef CallbackID, + pPCD_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + switch (CallbackID) + { + case HAL_PCD_SOF_CB_ID : + hpcd->SOFCallback = pCallback; + break; + + case HAL_PCD_SETUPSTAGE_CB_ID : + hpcd->SetupStageCallback = pCallback; + break; + + case HAL_PCD_RESET_CB_ID : + hpcd->ResetCallback = pCallback; + break; + + case HAL_PCD_SUSPEND_CB_ID : + hpcd->SuspendCallback = pCallback; + break; + + case HAL_PCD_RESUME_CB_ID : + hpcd->ResumeCallback = pCallback; + break; + + case HAL_PCD_CONNECT_CB_ID : + hpcd->ConnectCallback = pCallback; + break; + + case HAL_PCD_DISCONNECT_CB_ID : + hpcd->DisconnectCallback = pCallback; + break; + + case HAL_PCD_MSPINIT_CB_ID : + hpcd->MspInitCallback = pCallback; + break; + + case HAL_PCD_MSPDEINIT_CB_ID : + hpcd->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hpcd->State == HAL_PCD_STATE_RESET) + { + switch (CallbackID) + { + case HAL_PCD_MSPINIT_CB_ID : + hpcd->MspInitCallback = pCallback; + break; + + case HAL_PCD_MSPDEINIT_CB_ID : + hpcd->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + return status; +} + +/** + * @brief Unregister an USB PCD Callback + * USB PCD callabck is redirected to the weak predefined callback + * @param hpcd USB PCD handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_PCD_SOF_CB_ID USB PCD SOF callback ID + * @arg @ref HAL_PCD_SETUPSTAGE_CB_ID USB PCD Setup callback ID + * @arg @ref HAL_PCD_RESET_CB_ID USB PCD Reset callback ID + * @arg @ref HAL_PCD_SUSPEND_CB_ID USB PCD Suspend callback ID + * @arg @ref HAL_PCD_RESUME_CB_ID USB PCD Resume callback ID + * @arg @ref HAL_PCD_CONNECT_CB_ID USB PCD Connect callback ID + * @arg @ref HAL_PCD_DISCONNECT_CB_ID OTG PCD Disconnect callback ID + * @arg @ref HAL_PCD_MSPINIT_CB_ID MspDeInit callback ID + * @arg @ref HAL_PCD_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_UnRegisterCallback(PCD_HandleTypeDef *hpcd, HAL_PCD_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hpcd); + + /* Setup Legacy weak Callbacks */ + if (hpcd->State == HAL_PCD_STATE_READY) + { + switch (CallbackID) + { + case HAL_PCD_SOF_CB_ID : + hpcd->SOFCallback = HAL_PCD_SOFCallback; + break; + + case HAL_PCD_SETUPSTAGE_CB_ID : + hpcd->SetupStageCallback = HAL_PCD_SetupStageCallback; + break; + + case HAL_PCD_RESET_CB_ID : + hpcd->ResetCallback = HAL_PCD_ResetCallback; + break; + + case HAL_PCD_SUSPEND_CB_ID : + hpcd->SuspendCallback = HAL_PCD_SuspendCallback; + break; + + case HAL_PCD_RESUME_CB_ID : + hpcd->ResumeCallback = HAL_PCD_ResumeCallback; + break; + + case HAL_PCD_CONNECT_CB_ID : + hpcd->ConnectCallback = HAL_PCD_ConnectCallback; + break; + + case HAL_PCD_DISCONNECT_CB_ID : + hpcd->DisconnectCallback = HAL_PCD_DisconnectCallback; + break; + + case HAL_PCD_MSPINIT_CB_ID : + hpcd->MspInitCallback = HAL_PCD_MspInit; + break; + + case HAL_PCD_MSPDEINIT_CB_ID : + hpcd->MspDeInitCallback = HAL_PCD_MspDeInit; + break; + + default : + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hpcd->State == HAL_PCD_STATE_RESET) + { + switch (CallbackID) + { + case HAL_PCD_MSPINIT_CB_ID : + hpcd->MspInitCallback = HAL_PCD_MspInit; + break; + + case HAL_PCD_MSPDEINIT_CB_ID : + hpcd->MspDeInitCallback = HAL_PCD_MspDeInit; + break; + + default : + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + return status; +} + +/** + * @brief Register USB PCD Data OUT Stage Callback + * To be used instead of the weak HAL_PCD_DataOutStageCallback() predefined callback + * @param hpcd PCD handle + * @param pCallback pointer to the USB PCD Data OUT Stage Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_RegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd, + pPCD_DataOutStageCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->DataOutStageCallback = pCallback; + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Unregister the USB PCD Data OUT Stage Callback + * USB PCD Data OUT Stage Callback is redirected to the weak HAL_PCD_DataOutStageCallback() predefined callback + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_UnRegisterDataOutStageCallback(PCD_HandleTypeDef *hpcd) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->DataOutStageCallback = HAL_PCD_DataOutStageCallback; /* Legacy weak DataOutStageCallback */ + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Register USB PCD Data IN Stage Callback + * To be used instead of the weak HAL_PCD_DataInStageCallback() predefined callback + * @param hpcd PCD handle + * @param pCallback pointer to the USB PCD Data IN Stage Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_RegisterDataInStageCallback(PCD_HandleTypeDef *hpcd, + pPCD_DataInStageCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->DataInStageCallback = pCallback; + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Unregister the USB PCD Data IN Stage Callback + * USB PCD Data OUT Stage Callback is redirected to the weak HAL_PCD_DataInStageCallback() predefined callback + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_UnRegisterDataInStageCallback(PCD_HandleTypeDef *hpcd) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->DataInStageCallback = HAL_PCD_DataInStageCallback; /* Legacy weak DataInStageCallback */ + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Register USB PCD Iso OUT incomplete Callback + * To be used instead of the weak HAL_PCD_ISOOUTIncompleteCallback() predefined callback + * @param hpcd PCD handle + * @param pCallback pointer to the USB PCD Iso OUT incomplete Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_RegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd, + pPCD_IsoOutIncpltCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->ISOOUTIncompleteCallback = pCallback; + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Unregister the USB PCD Iso OUT incomplete Callback + * USB PCD Iso OUT incomplete Callback is redirected + * to the weak HAL_PCD_ISOOUTIncompleteCallback() predefined callback + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_UnRegisterIsoOutIncpltCallback(PCD_HandleTypeDef *hpcd) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->ISOOUTIncompleteCallback = HAL_PCD_ISOOUTIncompleteCallback; /* Legacy weak ISOOUTIncompleteCallback */ + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Register USB PCD Iso IN incomplete Callback + * To be used instead of the weak HAL_PCD_ISOINIncompleteCallback() predefined callback + * @param hpcd PCD handle + * @param pCallback pointer to the USB PCD Iso IN incomplete Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_RegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd, + pPCD_IsoInIncpltCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->ISOINIncompleteCallback = pCallback; + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Unregister the USB PCD Iso IN incomplete Callback + * USB PCD Iso IN incomplete Callback is redirected + * to the weak HAL_PCD_ISOINIncompleteCallback() predefined callback + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_UnRegisterIsoInIncpltCallback(PCD_HandleTypeDef *hpcd) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->ISOINIncompleteCallback = HAL_PCD_ISOINIncompleteCallback; /* Legacy weak ISOINIncompleteCallback */ + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Register USB PCD BCD Callback + * To be used instead of the weak HAL_PCDEx_BCD_Callback() predefined callback + * @param hpcd PCD handle + * @param pCallback pointer to the USB PCD BCD Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_RegisterBcdCallback(PCD_HandleTypeDef *hpcd, pPCD_BcdCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->BCDCallback = pCallback; + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Unregister the USB PCD BCD Callback + * USB BCD Callback is redirected to the weak HAL_PCDEx_BCD_Callback() predefined callback + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_UnRegisterBcdCallback(PCD_HandleTypeDef *hpcd) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->BCDCallback = HAL_PCDEx_BCD_Callback; /* Legacy weak HAL_PCDEx_BCD_Callback */ + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Register USB PCD LPM Callback + * To be used instead of the weak HAL_PCDEx_LPM_Callback() predefined callback + * @param hpcd PCD handle + * @param pCallback pointer to the USB PCD LPM Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_RegisterLpmCallback(PCD_HandleTypeDef *hpcd, pPCD_LpmCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->LPMCallback = pCallback; + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} + +/** + * @brief Unregister the USB PCD LPM Callback + * USB LPM Callback is redirected to the weak HAL_PCDEx_LPM_Callback() predefined callback + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_UnRegisterLpmCallback(PCD_HandleTypeDef *hpcd) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hpcd); + + if (hpcd->State == HAL_PCD_STATE_READY) + { + hpcd->LPMCallback = HAL_PCDEx_LPM_Callback; /* Legacy weak HAL_PCDEx_LPM_Callback */ + } + else + { + /* Update the error code */ + hpcd->ErrorCode |= HAL_PCD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hpcd); + + return status; +} +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup PCD_Exported_Functions_Group2 Input and Output operation functions + * @brief Data transfers functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to manage the PCD data + transfers. + +@endverbatim + * @{ + */ + +/** + * @brief Start the USB device + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_Start(PCD_HandleTypeDef *hpcd) +{ + __HAL_LOCK(hpcd); + __HAL_PCD_ENABLE(hpcd); + (void)USB_DevConnect(hpcd->Instance); + __HAL_UNLOCK(hpcd); + + return HAL_OK; +} + +/** + * @brief Stop the USB device. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_Stop(PCD_HandleTypeDef *hpcd) +{ + __HAL_LOCK(hpcd); + __HAL_PCD_DISABLE(hpcd); + (void)USB_DevDisconnect(hpcd->Instance); + __HAL_UNLOCK(hpcd); + + return HAL_OK; +} + + +/** + * @brief This function handles PCD interrupt request. + * @param hpcd PCD handle + * @retval HAL status + */ +void HAL_PCD_IRQHandler(PCD_HandleTypeDef *hpcd) +{ + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_CTR)) + { + /* servicing of the endpoint correct transfer interrupt */ + /* clear of the CTR flag into the sub */ + (void)PCD_EP_ISR_Handler(hpcd); + } + + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_RESET)) + { + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_RESET); + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->ResetCallback(hpcd); +#else + HAL_PCD_ResetCallback(hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + + (void)HAL_PCD_SetAddress(hpcd, 0U); + } + + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_PMAOVR)) + { + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_PMAOVR); + } + + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_ERR)) + { + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_ERR); + } + + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_WKUP)) + { + hpcd->Instance->CNTR &= (uint16_t) ~(USB_CNTR_LPMODE); + hpcd->Instance->CNTR &= (uint16_t) ~(USB_CNTR_FSUSP); + + if (hpcd->LPM_State == LPM_L1) + { + hpcd->LPM_State = LPM_L0; +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->LPMCallback(hpcd, PCD_LPM_L0_ACTIVE); +#else + HAL_PCDEx_LPM_Callback(hpcd, PCD_LPM_L0_ACTIVE); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->ResumeCallback(hpcd); +#else + HAL_PCD_ResumeCallback(hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_WKUP); + } + + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_SUSP)) + { + /* Force low-power mode in the macrocell */ + hpcd->Instance->CNTR |= (uint16_t)USB_CNTR_FSUSP; + + /* clear of the ISTR bit must be done after setting of CNTR_FSUSP */ + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_SUSP); + + hpcd->Instance->CNTR |= (uint16_t)USB_CNTR_LPMODE; + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->SuspendCallback(hpcd); +#else + HAL_PCD_SuspendCallback(hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + + /* Handle LPM Interrupt */ + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_L1REQ)) + { + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_L1REQ); + if (hpcd->LPM_State == LPM_L0) + { + /* Force suspend and low-power mode before going to L1 state*/ + hpcd->Instance->CNTR |= (uint16_t)USB_CNTR_LPMODE; + hpcd->Instance->CNTR |= (uint16_t)USB_CNTR_FSUSP; + + hpcd->LPM_State = LPM_L1; + hpcd->BESL = ((uint32_t)hpcd->Instance->LPMCSR & USB_LPMCSR_BESL) >> 2; +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->LPMCallback(hpcd, PCD_LPM_L1_ACTIVE); +#else + HAL_PCDEx_LPM_Callback(hpcd, PCD_LPM_L1_ACTIVE); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + else + { +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->SuspendCallback(hpcd); +#else + HAL_PCD_SuspendCallback(hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + } + + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_SOF)) + { + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_SOF); + +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->SOFCallback(hpcd); +#else + HAL_PCD_SOFCallback(hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + + if (__HAL_PCD_GET_FLAG(hpcd, USB_ISTR_ESOF)) + { + /* clear ESOF flag in ISTR */ + __HAL_PCD_CLEAR_FLAG(hpcd, USB_ISTR_ESOF); + } +} + + +/** + * @brief Data OUT stage callback. + * @param hpcd PCD handle + * @param epnum endpoint number + * @retval None + */ +__weak void HAL_PCD_DataOutStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + UNUSED(epnum); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_DataOutStageCallback could be implemented in the user file + */ +} + +/** + * @brief Data IN stage callback + * @param hpcd PCD handle + * @param epnum endpoint number + * @retval None + */ +__weak void HAL_PCD_DataInStageCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + UNUSED(epnum); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_DataInStageCallback could be implemented in the user file + */ +} +/** + * @brief Setup stage callback + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_SetupStageCallback(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_SetupStageCallback could be implemented in the user file + */ +} + +/** + * @brief USB Start Of Frame callback. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_SOFCallback(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_SOFCallback could be implemented in the user file + */ +} + +/** + * @brief USB Reset callback. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_ResetCallback(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_ResetCallback could be implemented in the user file + */ +} + +/** + * @brief Suspend event callback. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_SuspendCallback(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_SuspendCallback could be implemented in the user file + */ +} + +/** + * @brief Resume event callback. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_ResumeCallback(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_ResumeCallback could be implemented in the user file + */ +} + +/** + * @brief Incomplete ISO OUT callback. + * @param hpcd PCD handle + * @param epnum endpoint number + * @retval None + */ +__weak void HAL_PCD_ISOOUTIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + UNUSED(epnum); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_ISOOUTIncompleteCallback could be implemented in the user file + */ +} + +/** + * @brief Incomplete ISO IN callback. + * @param hpcd PCD handle + * @param epnum endpoint number + * @retval None + */ +__weak void HAL_PCD_ISOINIncompleteCallback(PCD_HandleTypeDef *hpcd, uint8_t epnum) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + UNUSED(epnum); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_ISOINIncompleteCallback could be implemented in the user file + */ +} + +/** + * @brief Connection event callback. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_ConnectCallback(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_ConnectCallback could be implemented in the user file + */ +} + +/** + * @brief Disconnection event callback. + * @param hpcd PCD handle + * @retval None + */ +__weak void HAL_PCD_DisconnectCallback(PCD_HandleTypeDef *hpcd) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCD_DisconnectCallback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup PCD_Exported_Functions_Group3 Peripheral Control functions + * @brief management functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the PCD data + transfers. + +@endverbatim + * @{ + */ + +/** + * @brief Connect the USB device + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_DevConnect(PCD_HandleTypeDef *hpcd) +{ + __HAL_LOCK(hpcd); + (void)USB_DevConnect(hpcd->Instance); + __HAL_UNLOCK(hpcd); + + return HAL_OK; +} + +/** + * @brief Disconnect the USB device. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_DevDisconnect(PCD_HandleTypeDef *hpcd) +{ + __HAL_LOCK(hpcd); + (void)USB_DevDisconnect(hpcd->Instance); + __HAL_UNLOCK(hpcd); + + return HAL_OK; +} + +/** + * @brief Set the USB Device address. + * @param hpcd PCD handle + * @param address new device address + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_SetAddress(PCD_HandleTypeDef *hpcd, uint8_t address) +{ + __HAL_LOCK(hpcd); + hpcd->USB_Address = address; + (void)USB_SetDevAddress(hpcd->Instance, address); + __HAL_UNLOCK(hpcd); + + return HAL_OK; +} +/** + * @brief Open and configure an endpoint. + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @param ep_mps endpoint max packet size + * @param ep_type endpoint type + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_EP_Open(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, + uint16_t ep_mps, uint8_t ep_type) +{ + HAL_StatusTypeDef ret = HAL_OK; + PCD_EPTypeDef *ep; + + if ((ep_addr & 0x80U) == 0x80U) + { + ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK]; + ep->is_in = 1U; + } + else + { + ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK]; + ep->is_in = 0U; + } + + ep->num = ep_addr & EP_ADDR_MSK; + ep->maxpacket = ep_mps; + ep->type = ep_type; + + if (ep->is_in != 0U) + { + /* Assign a Tx FIFO */ + ep->tx_fifo_num = ep->num; + } + /* Set initial data PID. */ + if (ep_type == EP_TYPE_BULK) + { + ep->data_pid_start = 0U; + } + + __HAL_LOCK(hpcd); + (void)USB_ActivateEndpoint(hpcd->Instance, ep); + __HAL_UNLOCK(hpcd); + + return ret; +} + +/** + * @brief Deactivate an endpoint. + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_EP_Close(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) +{ + PCD_EPTypeDef *ep; + + if ((ep_addr & 0x80U) == 0x80U) + { + ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK]; + ep->is_in = 1U; + } + else + { + ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK]; + ep->is_in = 0U; + } + ep->num = ep_addr & EP_ADDR_MSK; + + __HAL_LOCK(hpcd); + (void)USB_DeactivateEndpoint(hpcd->Instance, ep); + __HAL_UNLOCK(hpcd); + return HAL_OK; +} + + +/** + * @brief Receive an amount of data. + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @param pBuf pointer to the reception buffer + * @param len amount of data to be received + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_EP_Receive(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len) +{ + PCD_EPTypeDef *ep; + + ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK]; + + /*setup and start the Xfer */ + ep->xfer_buff = pBuf; + ep->xfer_len = len; + ep->xfer_count = 0U; + ep->is_in = 0U; + ep->num = ep_addr & EP_ADDR_MSK; + + if ((ep_addr & EP_ADDR_MSK) == 0U) + { + (void)USB_EP0StartXfer(hpcd->Instance, ep); + } + else + { + (void)USB_EPStartXfer(hpcd->Instance, ep); + } + + return HAL_OK; +} + +/** + * @brief Get Received Data Size + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @retval Data Size + */ +uint32_t HAL_PCD_EP_GetRxCount(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) +{ + return hpcd->OUT_ep[ep_addr & EP_ADDR_MSK].xfer_count; +} +/** + * @brief Send an amount of data + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @param pBuf pointer to the transmission buffer + * @param len amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_EP_Transmit(PCD_HandleTypeDef *hpcd, uint8_t ep_addr, uint8_t *pBuf, uint32_t len) +{ + PCD_EPTypeDef *ep; + + ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK]; + + /*setup and start the Xfer */ + ep->xfer_buff = pBuf; + ep->xfer_len = len; + ep->xfer_fill_db = 1U; + ep->xfer_len_db = len; + ep->xfer_count = 0U; + ep->is_in = 1U; + ep->num = ep_addr & EP_ADDR_MSK; + + if ((ep_addr & EP_ADDR_MSK) == 0U) + { + (void)USB_EP0StartXfer(hpcd->Instance, ep); + } + else + { + (void)USB_EPStartXfer(hpcd->Instance, ep); + } + + return HAL_OK; +} + +/** + * @brief Set a STALL condition over an endpoint + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_EP_SetStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) +{ + PCD_EPTypeDef *ep; + + if (((uint32_t)ep_addr & EP_ADDR_MSK) > hpcd->Init.dev_endpoints) + { + return HAL_ERROR; + } + + if ((0x80U & ep_addr) == 0x80U) + { + ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK]; + ep->is_in = 1U; + } + else + { + ep = &hpcd->OUT_ep[ep_addr]; + ep->is_in = 0U; + } + + ep->is_stall = 1U; + ep->num = ep_addr & EP_ADDR_MSK; + + __HAL_LOCK(hpcd); + + (void)USB_EPSetStall(hpcd->Instance, ep); + + __HAL_UNLOCK(hpcd); + + return HAL_OK; +} + +/** + * @brief Clear a STALL condition over in an endpoint + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_EP_ClrStall(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) +{ + PCD_EPTypeDef *ep; + + if (((uint32_t)ep_addr & 0x0FU) > hpcd->Init.dev_endpoints) + { + return HAL_ERROR; + } + + if ((0x80U & ep_addr) == 0x80U) + { + ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK]; + ep->is_in = 1U; + } + else + { + ep = &hpcd->OUT_ep[ep_addr & EP_ADDR_MSK]; + ep->is_in = 0U; + } + + ep->is_stall = 0U; + ep->num = ep_addr & EP_ADDR_MSK; + + __HAL_LOCK(hpcd); + (void)USB_EPClearStall(hpcd->Instance, ep); + __HAL_UNLOCK(hpcd); + + return HAL_OK; +} + +/** + * @brief Flush an endpoint + * @param hpcd PCD handle + * @param ep_addr endpoint address + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_EP_Flush(PCD_HandleTypeDef *hpcd, uint8_t ep_addr) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + UNUSED(ep_addr); + + return HAL_OK; +} + +/** + * @brief Activate remote wakeup signalling + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_ActivateRemoteWakeup(PCD_HandleTypeDef *hpcd) +{ + return (USB_ActivateRemoteWakeup(hpcd->Instance)); +} + +/** + * @brief De-activate remote wakeup signalling. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCD_DeActivateRemoteWakeup(PCD_HandleTypeDef *hpcd) +{ + return (USB_DeActivateRemoteWakeup(hpcd->Instance)); +} + +/** + * @} + */ + +/** @defgroup PCD_Exported_Functions_Group4 Peripheral State functions + * @brief Peripheral State functions + * +@verbatim + =============================================================================== + ##### Peripheral State functions ##### + =============================================================================== + [..] + This subsection permits to get in run-time the status of the peripheral + and the data flow. + +@endverbatim + * @{ + */ + +/** + * @brief Return the PCD handle state. + * @param hpcd PCD handle + * @retval HAL state + */ +PCD_StateTypeDef HAL_PCD_GetState(PCD_HandleTypeDef *hpcd) +{ + return hpcd->State; +} + +/** + * @} + */ + +/** + * @} + */ + +/* Private functions ---------------------------------------------------------*/ +/** @addtogroup PCD_Private_Functions + * @{ + */ + + +/** + * @brief This function handles PCD Endpoint interrupt request. + * @param hpcd PCD handle + * @retval HAL status + */ +static HAL_StatusTypeDef PCD_EP_ISR_Handler(PCD_HandleTypeDef *hpcd) +{ + PCD_EPTypeDef *ep; + uint16_t count, wIstr, wEPVal, TxByteNbre; + uint8_t epindex; + + /* stay in loop while pending interrupts */ + while ((hpcd->Instance->ISTR & USB_ISTR_CTR) != 0U) + { + wIstr = hpcd->Instance->ISTR; + + /* extract highest priority endpoint number */ + epindex = (uint8_t)(wIstr & USB_ISTR_EP_ID); + + if (epindex == 0U) + { + /* Decode and service control endpoint interrupt */ + + /* DIR bit = origin of the interrupt */ + if ((wIstr & USB_ISTR_DIR) == 0U) + { + /* DIR = 0 */ + + /* DIR = 0 => IN int */ + /* DIR = 0 implies that (EP_CTR_TX = 1) always */ + PCD_CLEAR_TX_EP_CTR(hpcd->Instance, PCD_ENDP0); + ep = &hpcd->IN_ep[0]; + + ep->xfer_count = PCD_GET_EP_TX_CNT(hpcd->Instance, ep->num); + ep->xfer_buff += ep->xfer_count; + + /* TX COMPLETE */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->DataInStageCallback(hpcd, 0U); +#else + HAL_PCD_DataInStageCallback(hpcd, 0U); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + + if ((hpcd->USB_Address > 0U) && (ep->xfer_len == 0U)) + { + hpcd->Instance->DADDR = ((uint16_t)hpcd->USB_Address | USB_DADDR_EF); + hpcd->USB_Address = 0U; + } + } + else + { + /* DIR = 1 */ + + /* DIR = 1 & CTR_RX => SETUP or OUT int */ + /* DIR = 1 & (CTR_TX | CTR_RX) => 2 int pending */ + ep = &hpcd->OUT_ep[0]; + wEPVal = PCD_GET_ENDPOINT(hpcd->Instance, PCD_ENDP0); + + if ((wEPVal & USB_EP_SETUP) != 0U) + { + /* Get SETUP Packet */ + ep->xfer_count = PCD_GET_EP_RX_CNT(hpcd->Instance, ep->num); + + USB_ReadPMA(hpcd->Instance, (uint8_t *)hpcd->Setup, + ep->pmaadress, (uint16_t)ep->xfer_count); + + /* SETUP bit kept frozen while CTR_RX = 1 */ + PCD_CLEAR_RX_EP_CTR(hpcd->Instance, PCD_ENDP0); + + /* Process SETUP Packet*/ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->SetupStageCallback(hpcd); +#else + HAL_PCD_SetupStageCallback(hpcd); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + else if ((wEPVal & USB_EP_CTR_RX) != 0U) + { + PCD_CLEAR_RX_EP_CTR(hpcd->Instance, PCD_ENDP0); + + /* Get Control Data OUT Packet */ + ep->xfer_count = PCD_GET_EP_RX_CNT(hpcd->Instance, ep->num); + + if ((ep->xfer_count != 0U) && (ep->xfer_buff != 0U)) + { + USB_ReadPMA(hpcd->Instance, ep->xfer_buff, + ep->pmaadress, (uint16_t)ep->xfer_count); + + ep->xfer_buff += ep->xfer_count; + + /* Process Control Data OUT Packet */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->DataOutStageCallback(hpcd, 0U); +#else + HAL_PCD_DataOutStageCallback(hpcd, 0U); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + + if ((PCD_GET_ENDPOINT(hpcd->Instance, PCD_ENDP0) & USB_EP_SETUP) == 0U) + { + PCD_SET_EP_RX_CNT(hpcd->Instance, PCD_ENDP0, ep->maxpacket); + PCD_SET_EP_RX_STATUS(hpcd->Instance, PCD_ENDP0, USB_EP_RX_VALID); + } + } + } + } + else + { + /* Decode and service non control endpoints interrupt */ + /* process related endpoint register */ + wEPVal = PCD_GET_ENDPOINT(hpcd->Instance, epindex); + + if ((wEPVal & USB_EP_CTR_RX) != 0U) + { + /* clear int flag */ + PCD_CLEAR_RX_EP_CTR(hpcd->Instance, epindex); + ep = &hpcd->OUT_ep[epindex]; + + /* OUT Single Buffering */ + if (ep->doublebuffer == 0U) + { + count = (uint16_t)PCD_GET_EP_RX_CNT(hpcd->Instance, ep->num); + + if (count != 0U) + { + USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaadress, count); + } + } + else + { + /* manage double buffer bulk out */ + if (ep->type == EP_TYPE_BULK) + { + count = HAL_PCD_EP_DB_Receive(hpcd, ep, wEPVal); + } + else /* manage double buffer iso out */ + { + /* free EP OUT Buffer */ + PCD_FreeUserBuffer(hpcd->Instance, ep->num, 0U); + + if ((PCD_GET_ENDPOINT(hpcd->Instance, ep->num) & USB_EP_DTOG_RX) != 0U) + { + /* read from endpoint BUF0Addr buffer */ + count = (uint16_t)PCD_GET_EP_DBUF0_CNT(hpcd->Instance, ep->num); + + if (count != 0U) + { + USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr0, count); + } + } + else + { + /* read from endpoint BUF1Addr buffer */ + count = (uint16_t)PCD_GET_EP_DBUF1_CNT(hpcd->Instance, ep->num); + + if (count != 0U) + { + USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr1, count); + } + } + } + } + /* multi-packet on the NON control OUT endpoint */ + ep->xfer_count += count; + ep->xfer_buff += count; + + if ((ep->xfer_len == 0U) || (count < ep->maxpacket)) + { + /* RX COMPLETE */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->DataOutStageCallback(hpcd, ep->num); +#else + HAL_PCD_DataOutStageCallback(hpcd, ep->num); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + else + { + (void) USB_EPStartXfer(hpcd->Instance, ep); + } + } + + if ((wEPVal & USB_EP_CTR_TX) != 0U) + { + ep = &hpcd->IN_ep[epindex]; + + /* clear int flag */ + PCD_CLEAR_TX_EP_CTR(hpcd->Instance, epindex); + + if (ep->type != EP_TYPE_BULK) + { + ep->xfer_len = 0U; + + if ((wEPVal & USB_EP_DTOG_TX) != 0U) + { + PCD_SET_EP_DBUF0_CNT(hpcd->Instance, ep->num, ep->is_in, 0U); + } + else + { + PCD_SET_EP_DBUF1_CNT(hpcd->Instance, ep->num, ep->is_in, 0U); + } + + /* TX COMPLETE */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->DataInStageCallback(hpcd, ep->num); +#else + HAL_PCD_DataInStageCallback(hpcd, ep->num); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + else + /* Manage Bulk Single Buffer Transaction */ + if ((ep->type == EP_TYPE_BULK) && ((wEPVal & USB_EP_KIND) == 0U)) + { + /* multi-packet on the NON control IN endpoint */ + TxByteNbre = (uint16_t)PCD_GET_EP_TX_CNT(hpcd->Instance, ep->num); + + if (ep->xfer_len > TxByteNbre) + { + ep->xfer_len -= TxByteNbre; + } + else + { + ep->xfer_len = 0U; + } + + /* Zero Length Packet? */ + if (ep->xfer_len == 0U) + { + /* TX COMPLETE */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->DataInStageCallback(hpcd, ep->num); +#else + HAL_PCD_DataInStageCallback(hpcd, ep->num); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + else + { + /* Transfer is not yet Done */ + ep->xfer_buff += TxByteNbre; + ep->xfer_count += TxByteNbre; + (void)USB_EPStartXfer(hpcd->Instance, ep); + } + } + /* Double Buffer bulk IN (bulk transfer Len > Ep_Mps) */ + else + { + (void)HAL_PCD_EP_DB_Transmit(hpcd, ep, wEPVal); + } + } + } + } + + return HAL_OK; +} + + +/** + * @brief Manage double buffer bulk out transaction from ISR + * @param hpcd PCD handle + * @param ep current endpoint handle + * @param wEPVal Last snapshot of EPRx register value taken in ISR + * @retval HAL status + */ +static uint16_t HAL_PCD_EP_DB_Receive(PCD_HandleTypeDef *hpcd, + PCD_EPTypeDef *ep, uint16_t wEPVal) +{ + uint16_t count; + + /* Manage Buffer0 OUT */ + if ((wEPVal & USB_EP_DTOG_RX) != 0U) + { + /* Get count of received Data on buffer0 */ + count = (uint16_t)PCD_GET_EP_DBUF0_CNT(hpcd->Instance, ep->num); + + if (ep->xfer_len >= count) + { + ep->xfer_len -= count; + } + else + { + ep->xfer_len = 0U; + } + + if (ep->xfer_len == 0U) + { + /* set NAK to OUT endpoint since double buffer is enabled */ + PCD_SET_EP_RX_STATUS(hpcd->Instance, ep->num, USB_EP_RX_NAK); + } + + /* Check if Buffer1 is in blocked sate which requires to toggle */ + if ((wEPVal & USB_EP_DTOG_TX) != 0U) + { + PCD_FreeUserBuffer(hpcd->Instance, ep->num, 0U); + } + + if (count != 0U) + { + USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr0, count); + } + } + /* Manage Buffer 1 DTOG_RX=0 */ + else + { + /* Get count of received data */ + count = (uint16_t)PCD_GET_EP_DBUF1_CNT(hpcd->Instance, ep->num); + + if (ep->xfer_len >= count) + { + ep->xfer_len -= count; + } + else + { + ep->xfer_len = 0U; + } + + if (ep->xfer_len == 0U) + { + /* set NAK on the current endpoint */ + PCD_SET_EP_RX_STATUS(hpcd->Instance, ep->num, USB_EP_RX_NAK); + } + + /*Need to FreeUser Buffer*/ + if ((wEPVal & USB_EP_DTOG_TX) == 0U) + { + PCD_FreeUserBuffer(hpcd->Instance, ep->num, 0U); + } + + if (count != 0U) + { + USB_ReadPMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr1, count); + } + } + + return count; +} + + +/** + * @brief Manage double buffer bulk IN transaction from ISR + * @param hpcd PCD handle + * @param ep current endpoint handle + * @param wEPVal Last snapshot of EPRx register value taken in ISR + * @retval HAL status + */ +static HAL_StatusTypeDef HAL_PCD_EP_DB_Transmit(PCD_HandleTypeDef *hpcd, + PCD_EPTypeDef *ep, uint16_t wEPVal) +{ + uint32_t len; + uint16_t TxByteNbre; + + /* Data Buffer0 ACK received */ + if ((wEPVal & USB_EP_DTOG_TX) != 0U) + { + /* multi-packet on the NON control IN endpoint */ + TxByteNbre = (uint16_t)PCD_GET_EP_DBUF0_CNT(hpcd->Instance, ep->num); + + if (ep->xfer_len > TxByteNbre) + { + ep->xfer_len -= TxByteNbre; + } + else + { + ep->xfer_len = 0U; + } + /* Transfer is completed */ + if (ep->xfer_len == 0U) + { + PCD_SET_EP_DBUF0_CNT(hpcd->Instance, ep->num, ep->is_in, 0U); + PCD_SET_EP_DBUF1_CNT(hpcd->Instance, ep->num, ep->is_in, 0U); + + /* TX COMPLETE */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->DataInStageCallback(hpcd, ep->num); +#else + HAL_PCD_DataInStageCallback(hpcd, ep->num); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + + if ((wEPVal & USB_EP_DTOG_RX) != 0U) + { + PCD_FreeUserBuffer(hpcd->Instance, ep->num, 1U); + } + } + else /* Transfer is not yet Done */ + { + /* need to Free USB Buff */ + if ((wEPVal & USB_EP_DTOG_RX) != 0U) + { + PCD_FreeUserBuffer(hpcd->Instance, ep->num, 1U); + } + + /* Still there is data to Fill in the next Buffer */ + if (ep->xfer_fill_db == 1U) + { + ep->xfer_buff += TxByteNbre; + ep->xfer_count += TxByteNbre; + + /* Calculate the len of the new buffer to fill */ + if (ep->xfer_len_db >= ep->maxpacket) + { + len = ep->maxpacket; + ep->xfer_len_db -= len; + } + else if (ep->xfer_len_db == 0U) + { + len = TxByteNbre; + ep->xfer_fill_db = 0U; + } + else + { + ep->xfer_fill_db = 0U; + len = ep->xfer_len_db; + ep->xfer_len_db = 0U; + } + + /* Write remaining Data to Buffer */ + /* Set the Double buffer counter for pma buffer1 */ + PCD_SET_EP_DBUF0_CNT(hpcd->Instance, ep->num, ep->is_in, len); + + /* Copy user buffer to USB PMA */ + USB_WritePMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr0, (uint16_t)len); + } + } + } + else /* Data Buffer1 ACK received */ + { + /* multi-packet on the NON control IN endpoint */ + TxByteNbre = (uint16_t)PCD_GET_EP_DBUF1_CNT(hpcd->Instance, ep->num); + + if (ep->xfer_len >= TxByteNbre) + { + ep->xfer_len -= TxByteNbre; + } + else + { + ep->xfer_len = 0U; + } + + /* Transfer is completed */ + if (ep->xfer_len == 0U) + { + PCD_SET_EP_DBUF0_CNT(hpcd->Instance, ep->num, ep->is_in, 0U); + PCD_SET_EP_DBUF1_CNT(hpcd->Instance, ep->num, ep->is_in, 0U); + + /* TX COMPLETE */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->DataInStageCallback(hpcd, ep->num); +#else + HAL_PCD_DataInStageCallback(hpcd, ep->num); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + + /* need to Free USB Buff */ + if ((wEPVal & USB_EP_DTOG_RX) == 0U) + { + PCD_FreeUserBuffer(hpcd->Instance, ep->num, 1U); + } + } + else /* Transfer is not yet Done */ + { + /* need to Free USB Buff */ + if ((wEPVal & USB_EP_DTOG_RX) == 0U) + { + PCD_FreeUserBuffer(hpcd->Instance, ep->num, 1U); + } + + /* Still there is data to Fill in the next Buffer */ + if (ep->xfer_fill_db == 1U) + { + ep->xfer_buff += TxByteNbre; + ep->xfer_count += TxByteNbre; + + /* Calculate the len of the new buffer to fill */ + if (ep->xfer_len_db >= ep->maxpacket) + { + len = ep->maxpacket; + ep->xfer_len_db -= len; + } + else if (ep->xfer_len_db == 0U) + { + len = TxByteNbre; + ep->xfer_fill_db = 0U; + } + else + { + len = ep->xfer_len_db; + ep->xfer_len_db = 0U; + ep->xfer_fill_db = 0; + } + + /* Set the Double buffer counter for pmabuffer1 */ + PCD_SET_EP_DBUF1_CNT(hpcd->Instance, ep->num, ep->is_in, len); + + /* Copy the user buffer to USB PMA */ + USB_WritePMA(hpcd->Instance, ep->xfer_buff, ep->pmaaddr1, (uint16_t)len); + } + } + } + + /*enable endpoint IN*/ + PCD_SET_EP_TX_STATUS(hpcd->Instance, ep->num, USB_EP_TX_VALID); + + return HAL_OK; +} + + + +/** + * @} + */ +#endif /* defined (USB) */ +#endif /* HAL_PCD_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd_ex.c new file mode 100644 index 0000000..dbb8904 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pcd_ex.c @@ -0,0 +1,336 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pcd_ex.c + * @author MCD Application Team + * @brief PCD Extended HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the USB Peripheral Controller: + * + Extended features functions + * + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup PCDEx PCDEx + * @brief PCD Extended HAL module driver + * @{ + */ + +#ifdef HAL_PCD_MODULE_ENABLED + +#if defined (USB) +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup PCDEx_Exported_Functions PCDEx Exported Functions + * @{ + */ + +/** @defgroup PCDEx_Exported_Functions_Group1 Peripheral Control functions + * @brief PCDEx control functions + * +@verbatim + =============================================================================== + ##### Extended features functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Update FIFO configuration + +@endverbatim + * @{ + */ + +/** + * @brief Configure PMA for EP + * @param hpcd Device instance + * @param ep_addr endpoint address + * @param ep_kind endpoint Kind + * USB_SNG_BUF: Single Buffer used + * USB_DBL_BUF: Double Buffer used + * @param pmaadress: EP address in The PMA: In case of single buffer endpoint + * this parameter is 16-bit value providing the address + * in PMA allocated to endpoint. + * In case of double buffer endpoint this parameter + * is a 32-bit value providing the endpoint buffer 0 address + * in the LSB part of 32-bit value and endpoint buffer 1 address + * in the MSB part of 32-bit value. + * @retval HAL status + */ + +HAL_StatusTypeDef HAL_PCDEx_PMAConfig(PCD_HandleTypeDef *hpcd, uint16_t ep_addr, + uint16_t ep_kind, uint32_t pmaadress) +{ + PCD_EPTypeDef *ep; + + /* initialize ep structure*/ + if ((0x80U & ep_addr) == 0x80U) + { + ep = &hpcd->IN_ep[ep_addr & EP_ADDR_MSK]; + } + else + { + ep = &hpcd->OUT_ep[ep_addr]; + } + + /* Here we check if the endpoint is single or double Buffer*/ + if (ep_kind == PCD_SNG_BUF) + { + /* Single Buffer */ + ep->doublebuffer = 0U; + /* Configure the PMA */ + ep->pmaadress = (uint16_t)pmaadress; + } + else /* USB_DBL_BUF */ + { + /* Double Buffer Endpoint */ + ep->doublebuffer = 1U; + /* Configure the PMA */ + ep->pmaaddr0 = (uint16_t)(pmaadress & 0xFFFFU); + ep->pmaaddr1 = (uint16_t)((pmaadress & 0xFFFF0000U) >> 16); + } + + return HAL_OK; +} + +/** + * @brief Activate BatteryCharging feature. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCDEx_ActivateBCD(PCD_HandleTypeDef *hpcd) +{ + USB_TypeDef *USBx = hpcd->Instance; + hpcd->battery_charging_active = 1U; + + /* Enable BCD feature */ + USBx->BCDR |= USB_BCDR_BCDEN; + + /* Enable DCD : Data Contact Detect */ + USBx->BCDR &= ~(USB_BCDR_PDEN); + USBx->BCDR &= ~(USB_BCDR_SDEN); + USBx->BCDR |= USB_BCDR_DCDEN; + + return HAL_OK; +} + +/** + * @brief Deactivate BatteryCharging feature. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCDEx_DeActivateBCD(PCD_HandleTypeDef *hpcd) +{ + USB_TypeDef *USBx = hpcd->Instance; + hpcd->battery_charging_active = 0U; + + /* Disable BCD feature */ + USBx->BCDR &= ~(USB_BCDR_BCDEN); + + return HAL_OK; +} + +/** + * @brief Handle BatteryCharging Process. + * @param hpcd PCD handle + * @retval HAL status + */ +void HAL_PCDEx_BCD_VBUSDetect(PCD_HandleTypeDef *hpcd) +{ + USB_TypeDef *USBx = hpcd->Instance; + uint32_t tickstart = HAL_GetTick(); + + /* Wait Detect flag or a timeout is happen */ + while ((USBx->BCDR & USB_BCDR_DCDET) == 0U) + { + /* Check for the Timeout */ + if ((HAL_GetTick() - tickstart) > 1000U) + { +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->BCDCallback(hpcd, PCD_BCD_ERROR); +#else + HAL_PCDEx_BCD_Callback(hpcd, PCD_BCD_ERROR); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + + return; + } + } + + HAL_Delay(200U); + + /* Data Pin Contact ? Check Detect flag */ + if ((USBx->BCDR & USB_BCDR_DCDET) == USB_BCDR_DCDET) + { +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->BCDCallback(hpcd, PCD_BCD_CONTACT_DETECTION); +#else + HAL_PCDEx_BCD_Callback(hpcd, PCD_BCD_CONTACT_DETECTION); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + /* Primary detection: checks if connected to Standard Downstream Port + (without charging capability) */ + USBx->BCDR &= ~(USB_BCDR_DCDEN); + HAL_Delay(50U); + USBx->BCDR |= (USB_BCDR_PDEN); + HAL_Delay(50U); + + /* If Charger detect ? */ + if ((USBx->BCDR & USB_BCDR_PDET) == USB_BCDR_PDET) + { + /* Start secondary detection to check connection to Charging Downstream + Port or Dedicated Charging Port */ + USBx->BCDR &= ~(USB_BCDR_PDEN); + HAL_Delay(50U); + USBx->BCDR |= (USB_BCDR_SDEN); + HAL_Delay(50U); + + /* If CDP ? */ + if ((USBx->BCDR & USB_BCDR_SDET) == USB_BCDR_SDET) + { + /* Dedicated Downstream Port DCP */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->BCDCallback(hpcd, PCD_BCD_DEDICATED_CHARGING_PORT); +#else + HAL_PCDEx_BCD_Callback(hpcd, PCD_BCD_DEDICATED_CHARGING_PORT); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + else + { + /* Charging Downstream Port CDP */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->BCDCallback(hpcd, PCD_BCD_CHARGING_DOWNSTREAM_PORT); +#else + HAL_PCDEx_BCD_Callback(hpcd, PCD_BCD_CHARGING_DOWNSTREAM_PORT); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + } + else /* NO */ + { + /* Standard Downstream Port */ +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->BCDCallback(hpcd, PCD_BCD_STD_DOWNSTREAM_PORT); +#else + HAL_PCDEx_BCD_Callback(hpcd, PCD_BCD_STD_DOWNSTREAM_PORT); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ + } + + /* Battery Charging capability discovery finished Start Enumeration */ + (void)HAL_PCDEx_DeActivateBCD(hpcd); +#if (USE_HAL_PCD_REGISTER_CALLBACKS == 1U) + hpcd->BCDCallback(hpcd, PCD_BCD_DISCOVERY_COMPLETED); +#else + HAL_PCDEx_BCD_Callback(hpcd, PCD_BCD_DISCOVERY_COMPLETED); +#endif /* USE_HAL_PCD_REGISTER_CALLBACKS */ +} + + +/** + * @brief Activate LPM feature. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCDEx_ActivateLPM(PCD_HandleTypeDef *hpcd) +{ + + USB_TypeDef *USBx = hpcd->Instance; + hpcd->lpm_active = 1U; + hpcd->LPM_State = LPM_L0; + + USBx->LPMCSR |= USB_LPMCSR_LMPEN; + USBx->LPMCSR |= USB_LPMCSR_LPMACK; + + return HAL_OK; +} + +/** + * @brief Deactivate LPM feature. + * @param hpcd PCD handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_PCDEx_DeActivateLPM(PCD_HandleTypeDef *hpcd) +{ + USB_TypeDef *USBx = hpcd->Instance; + + hpcd->lpm_active = 0U; + + USBx->LPMCSR &= ~(USB_LPMCSR_LMPEN); + USBx->LPMCSR &= ~(USB_LPMCSR_LPMACK); + + return HAL_OK; +} + + + +/** + * @brief Send LPM message to user layer callback. + * @param hpcd PCD handle + * @param msg LPM message + * @retval HAL status + */ +__weak void HAL_PCDEx_LPM_Callback(PCD_HandleTypeDef *hpcd, PCD_LPM_MsgTypeDef msg) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + UNUSED(msg); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCDEx_LPM_Callback could be implemented in the user file + */ +} + +/** + * @brief Send BatteryCharging message to user layer callback. + * @param hpcd PCD handle + * @param msg LPM message + * @retval HAL status + */ +__weak void HAL_PCDEx_BCD_Callback(PCD_HandleTypeDef *hpcd, PCD_BCD_MsgTypeDef msg) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hpcd); + UNUSED(msg); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_PCDEx_BCD_Callback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** + * @} + */ +#endif /* defined (USB) */ +#endif /* HAL_PCD_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr.c new file mode 100644 index 0000000..558d869 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr.c @@ -0,0 +1,454 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pwr.c + * @author MCD Application Team + * @brief PWR HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Power Controller (PWR) peripheral: + * + Initialization/de-initialization function + * + Peripheral Control function + * + @verbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup PWR PWR + * @brief PWR HAL module driver + * @{ + */ + +#ifdef HAL_PWR_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + +/** @defgroup PWR_Exported_Functions PWR Exported Functions + * @{ + */ + +/** @defgroup PWR_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and de-initialization functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] + After reset, the backup domain (RTC registers, RTC backup data + registers) is protected against possible unwanted + write accesses. + To enable access to the RTC Domain and RTC registers, proceed as follows: + (+) Enable the Power Controller (PWR) APB1 interface clock using the + __HAL_RCC_PWR_CLK_ENABLE() macro. + (+) Enable access to RTC domain using the HAL_PWR_EnableBkUpAccess() function. + +@endverbatim + * @{ + */ + +/** + * @brief Deinitializes the PWR peripheral registers to their default reset values. + * @retval None + */ +void HAL_PWR_DeInit(void) +{ + __HAL_RCC_PWR_FORCE_RESET(); + __HAL_RCC_PWR_RELEASE_RESET(); +} + +/** + * @brief Enables access to the backup domain (RTC registers, RTC + * backup data registers when present). + * @note If the HSE divided by 32 is used as the RTC clock, the + * Backup Domain Access should be kept enabled. + * @retval None + */ +void HAL_PWR_EnableBkUpAccess(void) +{ + PWR->CR |= (uint32_t)PWR_CR_DBP; +} + +/** + * @brief Disables access to the backup domain (RTC registers, RTC + * backup data registers when present). + * @note If the HSE divided by 32 is used as the RTC clock, the + * Backup Domain Access should be kept enabled. + * @retval None + */ +void HAL_PWR_DisableBkUpAccess(void) +{ + PWR->CR &= ~((uint32_t)PWR_CR_DBP); +} + +/** + * @} + */ + +/** @defgroup PWR_Exported_Functions_Group2 Peripheral Control functions + * @brief Low Power modes configuration functions + * +@verbatim + + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + + *** WakeUp pin configuration *** + ================================ + [..] + (+) WakeUp pin is used to wakeup the system from Standby mode. This pin is + forced in input pull down configuration and is active on rising edges. + (+) There are two WakeUp pins, and up to eight Wakeup pins on STM32F07x & STM32F09x devices. + (++)WakeUp Pin 1 on PA.00. + (++)WakeUp Pin 2 on PC.13. + (++)WakeUp Pin 3 on PE.06.(STM32F07x/STM32F09x) + (++)WakeUp Pin 4 on PA.02.(STM32F07x/STM32F09x) + (++)WakeUp Pin 5 on PC.05.(STM32F07x/STM32F09x) + (++)WakeUp Pin 6 on PB.05.(STM32F07x/STM32F09x) + (++)WakeUp Pin 7 on PB.15.(STM32F07x/STM32F09x) + (++)WakeUp Pin 8 on PF.02.(STM32F07x/STM32F09x) + + *** Low Power modes configuration *** + ===================================== + [..] + The devices feature 3 low-power modes: + (+) Sleep mode: Cortex-M0 core stopped, peripherals kept running. + (+) Stop mode: all clocks are stopped, regulator running, regulator + in low power mode + (+) Standby mode: 1.2V domain powered off (mode not available on STM32F0x8 devices). + + *** Sleep mode *** + ================== + [..] + (+) Entry: + The Sleep mode is entered by using the HAL_PWR_EnterSLEEPMode(PWR_MAINREGULATOR_ON, PWR_SLEEPENTRY_WFx) + functions with + (++) PWR_SLEEPENTRY_WFI: enter SLEEP mode with WFI instruction + (++) PWR_SLEEPENTRY_WFE: enter SLEEP mode with WFE instruction + + (+) Exit: + (++) Any peripheral interrupt acknowledged by the nested vectored interrupt + controller (NVIC) can wake up the device from Sleep mode. + + *** Stop mode *** + ================= + [..] + In Stop mode, all clocks in the 1.8V domain are stopped, the PLL, the HSI, + and the HSE RC oscillators are disabled. Internal SRAM and register contents + are preserved. + The voltage regulator can be configured either in normal or low-power mode. + To minimize the consumption. + + (+) Entry: + The Stop mode is entered using the HAL_PWR_EnterSTOPMode(PWR_MAINREGULATOR_ON, PWR_STOPENTRY_WFI ) + function with: + (++) Main regulator ON. + (++) Low Power regulator ON. + (++) PWR_STOPENTRY_WFI: enter STOP mode with WFI instruction + (++) PWR_STOPENTRY_WFE: enter STOP mode with WFE instruction + (+) Exit: + (++) Any EXTI Line (Internal or External) configured in Interrupt/Event mode. + (++) Some specific communication peripherals (CEC, USART, I2C) interrupts, + when programmed in wakeup mode (the peripheral must be + programmed in wakeup mode and the corresponding interrupt vector + must be enabled in the NVIC) + + *** Standby mode *** + ==================== + [..] + The Standby mode allows to achieve the lowest power consumption. It is based + on the Cortex-M0 deep sleep mode, with the voltage regulator disabled. + The 1.8V domain is consequently powered off. The PLL, the HSI oscillator and + the HSE oscillator are also switched off. SRAM and register contents are lost + except for the RTC registers, RTC backup registers and Standby circuitry. + The voltage regulator is OFF. + + (+) Entry: + (++) The Standby mode is entered using the HAL_PWR_EnterSTANDBYMode() function. + (+) Exit: + (++) WKUP pin rising edge, RTC alarm (Alarm A), RTC wakeup, + tamper event, time-stamp event, external reset in NRST pin, IWDG reset. + + *** Auto-wakeup (AWU) from low-power mode *** + ============================================= + [..] + The MCU can be woken up from low-power mode by an RTC Alarm event, an RTC + Wakeup event, a tamper event, a time-stamp event, or a comparator event, + without depending on an external interrupt (Auto-wakeup mode). + + (+) RTC auto-wakeup (AWU) from the Stop and Standby modes + + (++) To wake up from the Stop mode with an RTC alarm event, it is necessary to + configure the RTC to generate the RTC alarm using the HAL_RTC_SetAlarm_IT() function. + + (++) To wake up from the Stop mode with an RTC Tamper or time stamp event, it + is necessary to configure the RTC to detect the tamper or time stamp event using the + HAL_RTC_SetTimeStamp_IT() or HAL_RTC_SetTamper_IT() functions. + + (++) To wake up from the Stop mode with an RTC WakeUp event, it is necessary to + configure the RTC to generate the RTC WakeUp event using the HAL_RTC_SetWakeUpTimer_IT() function. + + (+) Comparator auto-wakeup (AWU) from the Stop mode + + (++) To wake up from the Stop mode with a comparator wakeup event, it is necessary to: + (+++) Configure the EXTI Line associated with the comparator (example EXTI Line 22 for comparator 2) + to be sensitive to to the selected edges (falling, rising or falling + and rising) (Interrupt or Event modes) using the EXTI_Init() function. + (+++) Configure the comparator to generate the event. +@endverbatim + * @{ + */ + +/** + * @brief Enables the WakeUp PINx functionality. + * @param WakeUpPinx Specifies the Power Wake-Up pin to enable. + * This parameter can be value of : + * @ref PWREx_WakeUp_Pins + * @retval None + */ +void HAL_PWR_EnableWakeUpPin(uint32_t WakeUpPinx) +{ + /* Check the parameters */ + assert_param(IS_PWR_WAKEUP_PIN(WakeUpPinx)); + /* Enable the EWUPx pin */ + SET_BIT(PWR->CSR, WakeUpPinx); +} + +/** + * @brief Disables the WakeUp PINx functionality. + * @param WakeUpPinx Specifies the Power Wake-Up pin to disable. + * This parameter can be values of : + * @ref PWREx_WakeUp_Pins + * @retval None + */ +void HAL_PWR_DisableWakeUpPin(uint32_t WakeUpPinx) +{ + /* Check the parameters */ + assert_param(IS_PWR_WAKEUP_PIN(WakeUpPinx)); + /* Disable the EWUPx pin */ + CLEAR_BIT(PWR->CSR, WakeUpPinx); +} + +/** + * @brief Enters Sleep mode. + * @note In Sleep mode, all I/O pins keep the same state as in Run mode. + * @param Regulator Specifies the regulator state in SLEEP mode. + * On STM32F0 devices, this parameter is a dummy value and it is ignored + * as regulator can't be modified in this mode. Parameter is kept for platform + * compatibility. + * @param SLEEPEntry Specifies if SLEEP mode is entered with WFI or WFE instruction. + * When WFI entry is used, tick interrupt have to be disabled if not desired as + * the interrupt wake up source. + * This parameter can be one of the following values: + * @arg PWR_SLEEPENTRY_WFI: enter SLEEP mode with WFI instruction + * @arg PWR_SLEEPENTRY_WFE: enter SLEEP mode with WFE instruction + * @retval None + */ +void HAL_PWR_EnterSLEEPMode(uint32_t Regulator, uint8_t SLEEPEntry) +{ + /* Check the parameters */ + assert_param(IS_PWR_REGULATOR(Regulator)); + assert_param(IS_PWR_SLEEP_ENTRY(SLEEPEntry)); + + /* Clear SLEEPDEEP bit of Cortex System Control Register */ + SCB->SCR &= (uint32_t)~((uint32_t)SCB_SCR_SLEEPDEEP_Msk); + + /* Select SLEEP mode entry -------------------------------------------------*/ + if(SLEEPEntry == PWR_SLEEPENTRY_WFI) + { + /* Request Wait For Interrupt */ + __WFI(); + } + else + { + /* Request Wait For Event */ + __SEV(); + __WFE(); + __WFE(); + } +} + +/** + * @brief Enters STOP mode. + * @note In Stop mode, all I/O pins keep the same state as in Run mode. + * @note When exiting Stop mode by issuing an interrupt or a wakeup event, + * the HSI RC oscillator is selected as system clock. + * @note When the voltage regulator operates in low power mode, an additional + * startup delay is incurred when waking up from Stop mode. + * By keeping the internal regulator ON during Stop mode, the consumption + * is higher although the startup time is reduced. + * @param Regulator Specifies the regulator state in STOP mode. + * This parameter can be one of the following values: + * @arg PWR_MAINREGULATOR_ON: STOP mode with regulator ON + * @arg PWR_LOWPOWERREGULATOR_ON: STOP mode with low power regulator ON + * @param STOPEntry specifies if STOP mode in entered with WFI or WFE instruction. + * This parameter can be one of the following values: + * @arg PWR_STOPENTRY_WFI:Enter STOP mode with WFI instruction + * @arg PWR_STOPENTRY_WFE: Enter STOP mode with WFE instruction + * @retval None + */ +void HAL_PWR_EnterSTOPMode(uint32_t Regulator, uint8_t STOPEntry) +{ + uint32_t tmpreg = 0; + + /* Check the parameters */ + assert_param(IS_PWR_REGULATOR(Regulator)); + assert_param(IS_PWR_STOP_ENTRY(STOPEntry)); + + /* Select the regulator state in STOP mode ---------------------------------*/ + tmpreg = PWR->CR; + + /* Clear PDDS and LPDS bits */ + tmpreg &= (uint32_t)~(PWR_CR_PDDS | PWR_CR_LPDS); + + /* Set LPDS bit according to Regulator value */ + tmpreg |= Regulator; + + /* Store the new value */ + PWR->CR = tmpreg; + + /* Set SLEEPDEEP bit of Cortex System Control Register */ + SCB->SCR |= SCB_SCR_SLEEPDEEP_Msk; + + /* Select STOP mode entry --------------------------------------------------*/ + if(STOPEntry == PWR_STOPENTRY_WFI) + { + /* Request Wait For Interrupt */ + __WFI(); + } + else + { + /* Request Wait For Event */ + __SEV(); + __WFE(); + __WFE(); + } + + /* Reset SLEEPDEEP bit of Cortex System Control Register */ + SCB->SCR &= (uint32_t)~((uint32_t)SCB_SCR_SLEEPDEEP_Msk); +} + +/** + * @brief Enters STANDBY mode. + * @note In Standby mode, all I/O pins are high impedance except for: + * - Reset pad (still available) + * - RTC alternate function pins if configured for tamper, time-stamp, RTC + * Alarm out, or RTC clock calibration out. + * - WKUP pins if enabled. + * STM32F0x8 devices, the Stop mode is available, but it is + * aningless to distinguish between voltage regulator in Low power + * mode and voltage regulator in Run mode because the regulator + * not used and the core is supplied directly from an external source. + * Consequently, the Standby mode is not available on those devices. + * @retval None + */ +void HAL_PWR_EnterSTANDBYMode(void) +{ + /* Select STANDBY mode */ + PWR->CR |= (uint32_t)PWR_CR_PDDS; + + /* Set SLEEPDEEP bit of Cortex System Control Register */ + SCB->SCR |= SCB_SCR_SLEEPDEEP_Msk; + + /* This option is used to ensure that store operations are completed */ +#if defined ( __CC_ARM) + __force_stores(); +#endif + /* Request Wait For Interrupt */ + __WFI(); +} + +/** + * @brief Indicates Sleep-On-Exit when returning from Handler mode to Thread mode. + * @note Set SLEEPONEXIT bit of SCR register. When this bit is set, the processor + * re-enters SLEEP mode when an interruption handling is over. + * Setting this bit is useful when the processor is expected to run only on + * interruptions handling. + * @retval None + */ +void HAL_PWR_EnableSleepOnExit(void) +{ + /* Set SLEEPONEXIT bit of Cortex System Control Register */ + SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPONEXIT_Msk)); +} + + +/** + * @brief Disables Sleep-On-Exit feature when returning from Handler mode to Thread mode. + * @note Clears SLEEPONEXIT bit of SCR register. When this bit is set, the processor + * re-enters SLEEP mode when an interruption handling is over. + * @retval None + */ +void HAL_PWR_DisableSleepOnExit(void) +{ + /* Clear SLEEPONEXIT bit of Cortex System Control Register */ + CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SLEEPONEXIT_Msk)); +} + + + +/** + * @brief Enables CORTEX M4 SEVONPEND bit. + * @note Sets SEVONPEND bit of SCR register. When this bit is set, this causes + * WFE to wake up when an interrupt moves from inactive to pended. + * @retval None + */ +void HAL_PWR_EnableSEVOnPend(void) +{ + /* Set SEVONPEND bit of Cortex System Control Register */ + SET_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SEVONPEND_Msk)); +} + + +/** + * @brief Disables CORTEX M4 SEVONPEND bit. + * @note Clears SEVONPEND bit of SCR register. When this bit is set, this causes + * WFE to wake up when an interrupt moves from inactive to pended. + * @retval None + */ +void HAL_PWR_DisableSEVOnPend(void) +{ + /* Clear SEVONPEND bit of Cortex System Control Register */ + CLEAR_BIT(SCB->SCR, ((uint32_t)SCB_SCR_SEVONPEND_Msk)); +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_PWR_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr_ex.c new file mode 100644 index 0000000..c14370b --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_pwr_ex.c @@ -0,0 +1,274 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_pwr_ex.c + * @author MCD Application Team + * @brief Extended PWR HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Power Controller (PWR) peripheral: + * + Extended Initialization and de-initialization functions + * + Extended Peripheral Control functions + * + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup PWREx PWREx + * @brief PWREx HAL module driver + * @{ + */ + +#ifdef HAL_PWR_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup PWREx_Private_Constants PWREx Private Constants + * @{ + */ +#define PVD_MODE_IT (0x00010000U) +#define PVD_MODE_EVT (0x00020000U) +#define PVD_RISING_EDGE (0x00000001U) +#define PVD_FALLING_EDGE (0x00000002U) +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup PWREx_Exported_Functions PWREx Exported Functions + * @{ + */ + +/** @defgroup PWREx_Exported_Functions_Group1 Peripheral Extended Control Functions + * @brief Extended Peripheral Control functions + * +@verbatim + + =============================================================================== + ##### Peripheral extended control functions ##### + =============================================================================== + + *** PVD configuration *** + ========================= + [..] + (+) The PVD is used to monitor the VDD power supply by comparing it to a + threshold selected by the PVD Level (PLS[2:0] bits in the PWR_CR). + (+) A PVDO flag is available to indicate if VDD/VDDA is higher or lower + than the PVD threshold. This event is internally connected to the EXTI + line16 and can generate an interrupt if enabled. This is done through + HAL_PWR_ConfigPVD(), HAL_PWR_EnablePVD() functions. + (+) The PVD is stopped in Standby mode. + -@- PVD is not available on STM32F030x4/x6/x8 + + *** VDDIO2 Monitor Configuration *** + ==================================== + [..] + (+) VDDIO2 monitor is used to monitor the VDDIO2 power supply by comparing it + to VREFInt Voltage + (+) This monitor is internally connected to the EXTI line31 + and can generate an interrupt if enabled. This is done through + HAL_PWREx_EnableVddio2Monitor() function. + -@- VDDIO2 is available on STM32F07x/09x/04x + +@endverbatim + * @{ + */ + +#if defined (STM32F031x6) || defined (STM32F051x8) || \ + defined (STM32F071xB) || defined (STM32F091xC) || \ + defined (STM32F042x6) || defined (STM32F072xB) +/** + * @brief Configures the voltage threshold detected by the Power Voltage Detector(PVD). + * @param sConfigPVD pointer to an PWR_PVDTypeDef structure that contains the configuration + * information for the PVD. + * @note Refer to the electrical characteristics of your device datasheet for + * more details about the voltage threshold corresponding to each + * detection level. + * @retval None + */ +void HAL_PWR_ConfigPVD(PWR_PVDTypeDef *sConfigPVD) +{ + /* Check the parameters */ + assert_param(IS_PWR_PVD_LEVEL(sConfigPVD->PVDLevel)); + assert_param(IS_PWR_PVD_MODE(sConfigPVD->Mode)); + + /* Set PLS[7:5] bits according to PVDLevel value */ + MODIFY_REG(PWR->CR, PWR_CR_PLS, sConfigPVD->PVDLevel); + + /* Clear any previous config. Keep it clear if no event or IT mode is selected */ + __HAL_PWR_PVD_EXTI_DISABLE_EVENT(); + __HAL_PWR_PVD_EXTI_DISABLE_IT(); + __HAL_PWR_PVD_EXTI_DISABLE_RISING_EDGE();__HAL_PWR_PVD_EXTI_DISABLE_FALLING_EDGE(); + + /* Configure interrupt mode */ + if((sConfigPVD->Mode & PVD_MODE_IT) == PVD_MODE_IT) + { + __HAL_PWR_PVD_EXTI_ENABLE_IT(); + } + + /* Configure event mode */ + if((sConfigPVD->Mode & PVD_MODE_EVT) == PVD_MODE_EVT) + { + __HAL_PWR_PVD_EXTI_ENABLE_EVENT(); + } + + /* Configure the edge */ + if((sConfigPVD->Mode & PVD_RISING_EDGE) == PVD_RISING_EDGE) + { + __HAL_PWR_PVD_EXTI_ENABLE_RISING_EDGE(); + } + + if((sConfigPVD->Mode & PVD_FALLING_EDGE) == PVD_FALLING_EDGE) + { + __HAL_PWR_PVD_EXTI_ENABLE_FALLING_EDGE(); + } +} + +/** + * @brief Enables the Power Voltage Detector(PVD). + * @retval None + */ +void HAL_PWR_EnablePVD(void) +{ + PWR->CR |= (uint32_t)PWR_CR_PVDE; +} + +/** + * @brief Disables the Power Voltage Detector(PVD). + * @retval None + */ +void HAL_PWR_DisablePVD(void) +{ + PWR->CR &= ~((uint32_t)PWR_CR_PVDE); +} + +/** + * @brief This function handles the PWR PVD interrupt request. + * @note This API should be called under the PVD_IRQHandler() or PVD_VDDIO2_IRQHandler(). + * @retval None + */ +void HAL_PWR_PVD_IRQHandler(void) +{ + /* Check PWR exti flag */ + if(__HAL_PWR_PVD_EXTI_GET_FLAG() != RESET) + { + /* PWR PVD interrupt user callback */ + HAL_PWR_PVDCallback(); + + /* Clear PWR Exti pending bit */ + __HAL_PWR_PVD_EXTI_CLEAR_FLAG(); + } +} + +/** + * @brief PWR PVD interrupt callback + * @retval None + */ +__weak void HAL_PWR_PVDCallback(void) +{ + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_PWR_PVDCallback could be implemented in the user file + */ +} + +#endif /* defined (STM32F031x6) || defined (STM32F051x8) || */ + /* defined (STM32F071xB) || defined (STM32F091xC) || */ + /* defined (STM32F042x6) || defined (STM32F072xB) */ + +#if defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) +/** + * @brief Enable VDDIO2 monitor: enable Exti 31 and falling edge detection. + * @note If Exti 31 is enable correlty and VDDIO2 voltage goes below Vrefint, + an interrupt is generated Irq line 1. + NVIS has to be enable by user. + * @retval None + */ +void HAL_PWREx_EnableVddio2Monitor(void) +{ + __HAL_PWR_VDDIO2_EXTI_ENABLE_IT(); + __HAL_PWR_VDDIO2_EXTI_ENABLE_FALLING_EDGE(); +} + +/** + * @brief Disable the Vddio2 Monitor. + * @retval None + */ +void HAL_PWREx_DisableVddio2Monitor(void) +{ + __HAL_PWR_VDDIO2_EXTI_DISABLE_IT(); + __HAL_PWR_VDDIO2_EXTI_DISABLE_FALLING_EDGE(); + +} + +/** + * @brief This function handles the PWR Vddio2 monitor interrupt request. + * @note This API should be called under the VDDIO2_IRQHandler() PVD_VDDIO2_IRQHandler(). + * @retval None + */ +void HAL_PWREx_Vddio2Monitor_IRQHandler(void) +{ + /* Check PWR exti flag */ + if(__HAL_PWR_VDDIO2_EXTI_GET_FLAG() != RESET) + { + /* PWR Vddio2 monitor interrupt user callback */ + HAL_PWREx_Vddio2MonitorCallback(); + + /* Clear PWR Exti pending bit */ + __HAL_PWR_VDDIO2_EXTI_CLEAR_FLAG(); + } +} + +/** + * @brief PWR Vddio2 Monitor interrupt callback + * @retval None + */ +__weak void HAL_PWREx_Vddio2MonitorCallback(void) +{ + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_PWREx_Vddio2MonitorCallback could be implemented in the user file + */ +} + +#endif /* defined (STM32F042x6) || defined (STM32F048xx) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_PWR_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc.c new file mode 100644 index 0000000..e6ff64e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc.c @@ -0,0 +1,1365 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rcc.c + * @author MCD Application Team + * @brief RCC HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Reset and Clock Control (RCC) peripheral: + * + Initialization and de-initialization functions + * + Peripheral Control functions + * + @verbatim + ============================================================================== + ##### RCC specific features ##### + ============================================================================== + [..] + After reset the device is running from Internal High Speed oscillator + (HSI 8MHz) with Flash 0 wait state, Flash prefetch buffer is disabled, + and all peripherals are off except internal SRAM, Flash and JTAG. + (+) There is no prescaler on High speed (AHB) and Low speed (APB) buses; + all peripherals mapped on these buses are running at HSI speed. + (+) The clock for all peripherals is switched off, except the SRAM and FLASH. + (+) All GPIOs are in input floating state, except the JTAG pins which + are assigned to be used for debug purpose. + [..] Once the device started from reset, the user application has to: + (+) Configure the clock source to be used to drive the System clock + (if the application needs higher frequency/performance) + (+) Configure the System clock frequency and Flash settings + (+) Configure the AHB and APB buses prescalers + (+) Enable the clock for the peripheral(s) to be used + (+) Configure the clock source(s) for peripherals whose clocks are not + derived from the System clock (RTC, ADC, I2C, USART, TIM, USB FS, etc..) + + ##### RCC Limitations ##### + ============================================================================== + [..] + A delay between an RCC peripheral clock enable and the effective peripheral + enabling should be taken into account in order to manage the peripheral read/write + from/to registers. + (+) This delay depends on the peripheral mapping. + (++) AHB & APB peripherals, 1 dummy read is necessary + + [..] + Workarounds: + (#) For AHB & APB peripherals, a dummy read to the peripheral register has been + inserted in each __HAL_RCC_PPP_CLK_ENABLE() macro. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup RCC RCC +* @brief RCC HAL module driver + * @{ + */ + +#ifdef HAL_RCC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup RCC_Private_Constants RCC Private Constants + * @{ + */ +/** + * @} + */ +/* Private macro -------------------------------------------------------------*/ +/** @defgroup RCC_Private_Macros RCC Private Macros + * @{ + */ + +#define MCO1_CLK_ENABLE() __HAL_RCC_GPIOA_CLK_ENABLE() +#define MCO1_GPIO_PORT GPIOA +#define MCO1_PIN GPIO_PIN_8 + +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/** @defgroup RCC_Private_Variables RCC Private Variables + * @{ + */ +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions ---------------------------------------------------------*/ + +/** @defgroup RCC_Exported_Functions RCC Exported Functions + * @{ + */ + +/** @defgroup RCC_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * + @verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] + This section provides functions allowing to configure the internal/external oscillators + (HSE, HSI, HSI14, HSI48, LSE, LSI, PLL, CSS and MCO) and the System buses clocks (SYSCLK, + AHB and APB1). + + [..] Internal/external clock and PLL configuration + (#) HSI (high-speed internal), 8 MHz factory-trimmed RC used directly or through + the PLL as System clock source. + The HSI clock can be used also to clock the USART and I2C peripherals. + + (#) HSI14 (high-speed internal), 14 MHz factory-trimmed RC used directly to clock + the ADC peripheral. + + (#) LSI (low-speed internal), ~40 KHz low consumption RC used as IWDG and/or RTC + clock source. + + (#) HSE (high-speed external), 4 to 32 MHz crystal oscillator used directly or + through the PLL as System clock source. Can be used also as RTC clock source. + + (#) LSE (low-speed external), 32 KHz oscillator used as RTC clock source. + + (#) PLL (clocked by HSI, HSI48 or HSE), featuring different output clocks: + (++) The first output is used to generate the high speed system clock (up to 48 MHz) + (++) The second output is used to generate the clock for the USB FS (48 MHz) + (++) The third output may be used to generate the clock for the TIM, I2C and USART + peripherals (up to 48 MHz) + + (#) CSS (Clock security system), once enable using the macro __HAL_RCC_CSS_ENABLE() + and if a HSE clock failure occurs(HSE used directly or through PLL as System + clock source), the System clocks automatically switched to HSI and an interrupt + is generated if enabled. The interrupt is linked to the Cortex-M0 NMI + (Non-Maskable Interrupt) exception vector. + + (#) MCO (microcontroller clock output), used to output SYSCLK, HSI, HSE, LSI, LSE or PLL + clock (divided by 2) output on pin (such as PA8 pin). + + [..] System, AHB and APB buses clocks configuration + (#) Several clock sources can be used to drive the System clock (SYSCLK): HSI, + HSE and PLL. + The AHB clock (HCLK) is derived from System clock through configurable + prescaler and used to clock the CPU, memory and peripherals mapped + on AHB bus (DMA, GPIO...). APB1 (PCLK1) clock is derived + from AHB clock through configurable prescalers and used to clock + the peripherals mapped on these buses. You can use + "HAL_RCC_GetSysClockFreq()" function to retrieve the frequencies of these clocks. + + (#) All the peripheral clocks are derived from the System clock (SYSCLK) except: + (++) The FLASH program/erase clock which is always HSI 8MHz clock. + (++) The USB 48 MHz clock which is derived from the PLL VCO clock. + (++) The USART clock which can be derived as well from HSI 8MHz, LSI or LSE. + (++) The I2C clock which can be derived as well from HSI 8MHz clock. + (++) The ADC clock which is derived from PLL output. + (++) The RTC clock which is derived from the LSE, LSI or 1 MHz HSE_RTC + (HSE divided by a programmable prescaler). The System clock (SYSCLK) + frequency must be higher or equal to the RTC clock frequency. + (++) IWDG clock which is always the LSI clock. + + (#) For the STM32F0xx devices, the maximum frequency of the SYSCLK, HCLK and PCLK1 is 48 MHz, + Depending on the SYSCLK frequency, the flash latency should be adapted accordingly. + + (#) After reset, the System clock source is the HSI (8 MHz) with 0 WS and + prefetch is disabled. + @endverbatim + * @{ + */ + +/* + Additional consideration on the SYSCLK based on Latency settings: + +-----------------------------------------------+ + | Latency | SYSCLK clock frequency (MHz) | + |---------------|-------------------------------| + |0WS(1CPU cycle)| 0 < SYSCLK <= 24 | + |---------------|-------------------------------| + |1WS(2CPU cycle)| 24 < SYSCLK <= 48 | + +-----------------------------------------------+ + */ + +/** + * @brief Resets the RCC clock configuration to the default reset state. + * @note The default reset state of the clock configuration is given below: + * - HSI ON and used as system clock source + * - HSE and PLL OFF + * - AHB, APB1 prescaler set to 1. + * - CSS and MCO1 OFF + * - All interrupts disabled + * - All interrupt and reset flags cleared + * @note This function does not modify the configuration of the + * - Peripheral clocks + * - LSI, LSE and RTC clocks + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RCC_DeInit(void) +{ + uint32_t tickstart; + + /* Get Start Tick*/ + tickstart = HAL_GetTick(); + + /* Set HSION bit, HSITRIM[4:0] bits to the reset value*/ + SET_BIT(RCC->CR, RCC_CR_HSION | RCC_CR_HSITRIM_4); + + /* Wait till HSI is ready */ + while (READ_BIT(RCC->CR, RCC_CR_HSIRDY) == RESET) + { + if ((HAL_GetTick() - tickstart) > HSI_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + + /* Reset SW[1:0], HPRE[3:0], PPRE[2:0] and MCOSEL[2:0] bits */ + CLEAR_BIT(RCC->CFGR, RCC_CFGR_SW | RCC_CFGR_HPRE | RCC_CFGR_PPRE | RCC_CFGR_MCO); + + /* Wait till HSI as SYSCLK status is enabled */ + while (READ_BIT(RCC->CFGR, RCC_CFGR_SWS) != RESET) + { + if ((HAL_GetTick() - tickstart) > CLOCKSWITCH_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + + /* Update the SystemCoreClock global variable for HSI as system clock source */ + SystemCoreClock = HSI_VALUE; + + /* Adapt Systick interrupt period */ + if (HAL_InitTick(uwTickPrio) != HAL_OK) + { + return HAL_ERROR; + } + + /* Reset HSEON, CSSON, PLLON bits */ + CLEAR_BIT(RCC->CR, RCC_CR_PLLON | RCC_CR_CSSON | RCC_CR_HSEON); + + /* Reset HSEBYP bit */ + CLEAR_BIT(RCC->CR, RCC_CR_HSEBYP); + + /* Get start tick */ + tickstart = HAL_GetTick(); + + /* Wait till PLLRDY is cleared */ + while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) != RESET) + { + if((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + + /* Reset CFGR register */ + CLEAR_REG(RCC->CFGR); + + /* Reset CFGR2 register */ + CLEAR_REG(RCC->CFGR2); + + /* Reset CFGR3 register */ + CLEAR_REG(RCC->CFGR3); + + /* Disable all interrupts */ + CLEAR_REG(RCC->CIR); + + /* Clear all reset flags */ + __HAL_RCC_CLEAR_RESET_FLAGS(); + + return HAL_OK; +} + +/** + * @brief Initializes the RCC Oscillators according to the specified parameters in the + * RCC_OscInitTypeDef. + * @param RCC_OscInitStruct pointer to an RCC_OscInitTypeDef structure that + * contains the configuration information for the RCC Oscillators. + * @note The PLL is not disabled when used as system clock. + * @note Transitions LSE Bypass to LSE On and LSE On to LSE Bypass are not + * supported by this macro. User should request a transition to LSE Off + * first and then LSE On or LSE Bypass. + * @note Transition HSE Bypass to HSE On and HSE On to HSE Bypass are not + * supported by this macro. User should request a transition to HSE Off + * first and then HSE On or HSE Bypass. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RCC_OscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct) +{ + uint32_t tickstart; + uint32_t pll_config; + uint32_t pll_config2; + + /* Check Null pointer */ + if(RCC_OscInitStruct == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_RCC_OSCILLATORTYPE(RCC_OscInitStruct->OscillatorType)); + + /*------------------------------- HSE Configuration ------------------------*/ + if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE) + { + /* Check the parameters */ + assert_param(IS_RCC_HSE(RCC_OscInitStruct->HSEState)); + + /* When the HSE is used as system clock or clock source for PLL in these cases it is not allowed to be disabled */ + if((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSE) + || ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (__HAL_RCC_GET_PLL_OSCSOURCE() == RCC_PLLSOURCE_HSE))) + { + if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF)) + { + return HAL_ERROR; + } + } + else + { + /* Set the new HSE configuration ---------------------------------------*/ + __HAL_RCC_HSE_CONFIG(RCC_OscInitStruct->HSEState); + + + /* Check the HSE State */ + if(RCC_OscInitStruct->HSEState != RCC_HSE_OFF) + { + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSE is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET) + { + if((HAL_GetTick() - tickstart ) > HSE_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + else + { + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSE is disabled */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET) + { + if((HAL_GetTick() - tickstart ) > HSE_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + } + } + /*----------------------------- HSI Configuration --------------------------*/ + if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI) + { + /* Check the parameters */ + assert_param(IS_RCC_HSI(RCC_OscInitStruct->HSIState)); + assert_param(IS_RCC_CALIBRATION_VALUE(RCC_OscInitStruct->HSICalibrationValue)); + + /* Check if HSI is used as system clock or as PLL source when PLL is selected as system clock */ + if((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSI) + || ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (__HAL_RCC_GET_PLL_OSCSOURCE() == RCC_PLLSOURCE_HSI))) + { + /* When HSI is used as system clock it will not disabled */ + if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET) && (RCC_OscInitStruct->HSIState != RCC_HSI_ON)) + { + return HAL_ERROR; + } + /* Otherwise, just the calibration is allowed */ + else + { + /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/ + __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue); + } + } + else + { + /* Check the HSI State */ + if(RCC_OscInitStruct->HSIState != RCC_HSI_OFF) + { + /* Enable the Internal High Speed oscillator (HSI). */ + __HAL_RCC_HSI_ENABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSI is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET) + { + if((HAL_GetTick() - tickstart ) > HSI_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + + /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/ + __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue); + } + else + { + /* Disable the Internal High Speed oscillator (HSI). */ + __HAL_RCC_HSI_DISABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSI is disabled */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET) + { + if((HAL_GetTick() - tickstart ) > HSI_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + } + } + /*------------------------------ LSI Configuration -------------------------*/ + if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI) + { + /* Check the parameters */ + assert_param(IS_RCC_LSI(RCC_OscInitStruct->LSIState)); + + /* Check the LSI State */ + if(RCC_OscInitStruct->LSIState != RCC_LSI_OFF) + { + /* Enable the Internal Low Speed oscillator (LSI). */ + __HAL_RCC_LSI_ENABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till LSI is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == RESET) + { + if((HAL_GetTick() - tickstart ) > LSI_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + else + { + /* Disable the Internal Low Speed oscillator (LSI). */ + __HAL_RCC_LSI_DISABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till LSI is disabled */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) != RESET) + { + if((HAL_GetTick() - tickstart ) > LSI_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + } + /*------------------------------ LSE Configuration -------------------------*/ + if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE) + { + FlagStatus pwrclkchanged = RESET; + + /* Check the parameters */ + assert_param(IS_RCC_LSE(RCC_OscInitStruct->LSEState)); + + /* Update LSE configuration in Backup Domain control register */ + /* Requires to enable write access to Backup Domain of necessary */ + if(__HAL_RCC_PWR_IS_CLK_DISABLED()) + { + __HAL_RCC_PWR_CLK_ENABLE(); + pwrclkchanged = SET; + } + + if(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP)) + { + /* Enable write access to Backup domain */ + SET_BIT(PWR->CR, PWR_CR_DBP); + + /* Wait for Backup domain Write protection disable */ + tickstart = HAL_GetTick(); + + while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP)) + { + if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + + /* Set the new LSE configuration -----------------------------------------*/ + __HAL_RCC_LSE_CONFIG(RCC_OscInitStruct->LSEState); + /* Check the LSE State */ + if(RCC_OscInitStruct->LSEState != RCC_LSE_OFF) + { + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till LSE is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET) + { + if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + else + { + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till LSE is disabled */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != RESET) + { + if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + + /* Require to disable power clock if necessary */ + if(pwrclkchanged == SET) + { + __HAL_RCC_PWR_CLK_DISABLE(); + } + } + + /*----------------------------- HSI14 Configuration --------------------------*/ + if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI14) == RCC_OSCILLATORTYPE_HSI14) + { + /* Check the parameters */ + assert_param(IS_RCC_HSI14(RCC_OscInitStruct->HSI14State)); + assert_param(IS_RCC_CALIBRATION_VALUE(RCC_OscInitStruct->HSI14CalibrationValue)); + + /* Check the HSI14 State */ + if(RCC_OscInitStruct->HSI14State == RCC_HSI14_ON) + { + /* Disable ADC control of the Internal High Speed oscillator HSI14 */ + __HAL_RCC_HSI14ADC_DISABLE(); + + /* Enable the Internal High Speed oscillator (HSI). */ + __HAL_RCC_HSI14_ENABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSI is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI14RDY) == RESET) + { + if((HAL_GetTick() - tickstart) > HSI14_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + + /* Adjusts the Internal High Speed oscillator 14Mhz (HSI14) calibration value. */ + __HAL_RCC_HSI14_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSI14CalibrationValue); + } + else if(RCC_OscInitStruct->HSI14State == RCC_HSI14_ADC_CONTROL) + { + /* Enable ADC control of the Internal High Speed oscillator HSI14 */ + __HAL_RCC_HSI14ADC_ENABLE(); + + /* Adjusts the Internal High Speed oscillator 14Mhz (HSI14) calibration value. */ + __HAL_RCC_HSI14_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSI14CalibrationValue); + } + else + { + /* Disable ADC control of the Internal High Speed oscillator HSI14 */ + __HAL_RCC_HSI14ADC_DISABLE(); + + /* Disable the Internal High Speed oscillator (HSI). */ + __HAL_RCC_HSI14_DISABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSI is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI14RDY) != RESET) + { + if((HAL_GetTick() - tickstart) > HSI14_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + } + +#if defined(RCC_HSI48_SUPPORT) + /*----------------------------- HSI48 Configuration --------------------------*/ + if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI48) == RCC_OSCILLATORTYPE_HSI48) + { + /* Check the parameters */ + assert_param(IS_RCC_HSI48(RCC_OscInitStruct->HSI48State)); + + /* When the HSI48 is used as system clock it is not allowed to be disabled */ + if((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSI48) || + ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (__HAL_RCC_GET_PLL_OSCSOURCE() == RCC_PLLSOURCE_HSI48))) + { + if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) != RESET) && (RCC_OscInitStruct->HSI48State != RCC_HSI48_ON)) + { + return HAL_ERROR; + } + } + else + { + /* Check the HSI48 State */ + if(RCC_OscInitStruct->HSI48State != RCC_HSI48_OFF) + { + /* Enable the Internal High Speed oscillator (HSI48). */ + __HAL_RCC_HSI48_ENABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSI48 is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) == RESET) + { + if((HAL_GetTick() - tickstart) > HSI48_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + else + { + /* Disable the Internal High Speed oscillator (HSI48). */ + __HAL_RCC_HSI48_DISABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till HSI48 is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) != RESET) + { + if((HAL_GetTick() - tickstart) > HSI48_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + } + } +#endif /* RCC_HSI48_SUPPORT */ + + /*-------------------------------- PLL Configuration -----------------------*/ + /* Check the parameters */ + assert_param(IS_RCC_PLL(RCC_OscInitStruct->PLL.PLLState)); + if ((RCC_OscInitStruct->PLL.PLLState) != RCC_PLL_NONE) + { + /* Check if the PLL is used as system clock or not */ + if(__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_PLLCLK) + { + if((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_ON) + { + /* Check the parameters */ + assert_param(IS_RCC_PLLSOURCE(RCC_OscInitStruct->PLL.PLLSource)); + assert_param(IS_RCC_PLL_MUL(RCC_OscInitStruct->PLL.PLLMUL)); + assert_param(IS_RCC_PREDIV(RCC_OscInitStruct->PLL.PREDIV)); + + /* Disable the main PLL. */ + __HAL_RCC_PLL_DISABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till PLL is disabled */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != RESET) + { + if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + + /* Configure the main PLL clock source, predivider and multiplication factor. */ + __HAL_RCC_PLL_CONFIG(RCC_OscInitStruct->PLL.PLLSource, + RCC_OscInitStruct->PLL.PREDIV, + RCC_OscInitStruct->PLL.PLLMUL); + /* Enable the main PLL. */ + __HAL_RCC_PLL_ENABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till PLL is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == RESET) + { + if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + else + { + /* Disable the main PLL. */ + __HAL_RCC_PLL_DISABLE(); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till PLL is disabled */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != RESET) + { + if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + } + else + { + /* Check if there is a request to disable the PLL used as System clock source */ + if((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_OFF) + { + return HAL_ERROR; + } + else + { + /* Do not return HAL_ERROR if request repeats the current configuration */ + pll_config = RCC->CFGR; + pll_config2 = RCC->CFGR2; + if((READ_BIT(pll_config, RCC_CFGR_PLLSRC) != RCC_OscInitStruct->PLL.PLLSource) || + (READ_BIT(pll_config2, RCC_CFGR2_PREDIV) != RCC_OscInitStruct->PLL.PREDIV) || + (READ_BIT(pll_config, RCC_CFGR_PLLMUL) != RCC_OscInitStruct->PLL.PLLMUL)) + { + return HAL_ERROR; + } + } + } + } + + return HAL_OK; +} + +/** + * @brief Initializes the CPU, AHB and APB buses clocks according to the specified + * parameters in the RCC_ClkInitStruct. + * @param RCC_ClkInitStruct pointer to an RCC_OscInitTypeDef structure that + * contains the configuration information for the RCC peripheral. + * @param FLatency FLASH Latency + * The value of this parameter depend on device used within the same series + * @note The SystemCoreClock CMSIS variable is used to store System Clock Frequency + * and updated by @ref HAL_RCC_GetHCLKFreq() function called within this function + * + * @note The HSI is used (enabled by hardware) as system clock source after + * start-up from Reset, wake-up from STOP and STANDBY mode, or in case + * of failure of the HSE used directly or indirectly as system clock + * (if the Clock Security System CSS is enabled). + * + * @note A switch from one clock source to another occurs only if the target + * clock source is ready (clock stable after start-up delay or PLL locked). + * If a clock source which is not yet ready is selected, the switch will + * occur when the clock source will be ready. + * You can use @ref HAL_RCC_GetClockConfig() function to know which clock is + * currently used as system clock source. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RCC_ClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t FLatency) +{ + uint32_t tickstart; + + /* Check Null pointer */ + if(RCC_ClkInitStruct == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_RCC_CLOCKTYPE(RCC_ClkInitStruct->ClockType)); + assert_param(IS_FLASH_LATENCY(FLatency)); + + /* To correctly read data from FLASH memory, the number of wait states (LATENCY) + must be correctly programmed according to the frequency of the CPU clock + (HCLK) of the device. */ + + /* Increasing the number of wait states because of higher CPU frequency */ + if(FLatency > __HAL_FLASH_GET_LATENCY()) + { + /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */ + __HAL_FLASH_SET_LATENCY(FLatency); + + /* Check that the new number of wait states is taken into account to access the Flash + memory by reading the FLASH_ACR register */ + if(__HAL_FLASH_GET_LATENCY() != FLatency) + { + return HAL_ERROR; + } + } + + /*-------------------------- HCLK Configuration --------------------------*/ + if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_HCLK) == RCC_CLOCKTYPE_HCLK) + { + /* Set the highest APB divider in order to ensure that we do not go through + a non-spec phase whatever we decrease or increase HCLK. */ + if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1) + { + MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE, RCC_HCLK_DIV16); + } + + /* Set the new HCLK clock divider */ + assert_param(IS_RCC_HCLK(RCC_ClkInitStruct->AHBCLKDivider)); + MODIFY_REG(RCC->CFGR, RCC_CFGR_HPRE, RCC_ClkInitStruct->AHBCLKDivider); + } + + /*------------------------- SYSCLK Configuration ---------------------------*/ + if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_SYSCLK) == RCC_CLOCKTYPE_SYSCLK) + { + assert_param(IS_RCC_SYSCLKSOURCE(RCC_ClkInitStruct->SYSCLKSource)); + + /* HSE is selected as System Clock Source */ + if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSE) + { + /* Check the HSE ready flag */ + if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET) + { + return HAL_ERROR; + } + } + /* PLL is selected as System Clock Source */ + else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_PLLCLK) + { + /* Check the PLL ready flag */ + if(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == RESET) + { + return HAL_ERROR; + } + } +#if defined(RCC_CFGR_SWS_HSI48) + /* HSI48 is selected as System Clock Source */ + else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSI48) + { + /* Check the HSI48 ready flag */ + if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) == RESET) + { + return HAL_ERROR; + } + } +#endif /* RCC_CFGR_SWS_HSI48 */ + /* HSI is selected as System Clock Source */ + else + { + /* Check the HSI ready flag */ + if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET) + { + return HAL_ERROR; + } + } + __HAL_RCC_SYSCLK_CONFIG(RCC_ClkInitStruct->SYSCLKSource); + + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + while (__HAL_RCC_GET_SYSCLK_SOURCE() != (RCC_ClkInitStruct->SYSCLKSource << RCC_CFGR_SWS_Pos)) + { + if((HAL_GetTick() - tickstart ) > CLOCKSWITCH_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + + /* Decreasing the number of wait states because of lower CPU frequency */ + if(FLatency < __HAL_FLASH_GET_LATENCY()) + { + /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */ + __HAL_FLASH_SET_LATENCY(FLatency); + + /* Check that the new number of wait states is taken into account to access the Flash + memory by reading the FLASH_ACR register */ + if(__HAL_FLASH_GET_LATENCY() != FLatency) + { + return HAL_ERROR; + } + } + + /*-------------------------- PCLK1 Configuration ---------------------------*/ + if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1) + { + assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB1CLKDivider)); + MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE, RCC_ClkInitStruct->APB1CLKDivider); + } + + /* Update the SystemCoreClock global variable */ + SystemCoreClock = HAL_RCC_GetSysClockFreq() >> AHBPrescTable[(RCC->CFGR & RCC_CFGR_HPRE)>> RCC_CFGR_HPRE_BITNUMBER]; + + /* Configure the source of time base considering new system clocks settings*/ + HAL_InitTick (TICK_INT_PRIORITY); + + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup RCC_Exported_Functions_Group2 Peripheral Control functions + * @brief RCC clocks control functions + * + @verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the RCC Clocks + frequencies. + + @endverbatim + * @{ + */ + +#if defined(RCC_CFGR_MCOPRE) +/** + * @brief Selects the clock source to output on MCO pin. + * @note MCO pin should be configured in alternate function mode. + * @param RCC_MCOx specifies the output direction for the clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_MCO1 Clock source to output on MCO1 pin(PA8). + * @param RCC_MCOSource specifies the clock source to output. + * This parameter can be one of the following values: + * @arg @ref RCC_MCO1SOURCE_NOCLOCK No clock selected + * @arg @ref RCC_MCO1SOURCE_SYSCLK System Clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI HSI selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSE HSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSI LSI selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSE LSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI14 HSI14 selected as MCO clock + @if STM32F042x6 + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F048xx + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F071xB + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F072xB + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F078xx + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F091xC + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elseif STM32F098xx + * @arg @ref RCC_MCO1SOURCE_HSI48 HSI48 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elif STM32F030x6 + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elif STM32F030xC + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elif STM32F031x6 + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elif STM32F038xx + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elif STM32F070x6 + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @elif STM32F070xB + * @arg @ref RCC_MCO1SOURCE_PLLCLK PLLCLK selected as MCO clock + @endif + * @arg @ref RCC_MCO1SOURCE_PLLCLK_DIV2 PLLCLK Divided by 2 selected as MCO clock + * @param RCC_MCODiv specifies the MCO DIV. + * This parameter can be one of the following values: + * @arg @ref RCC_MCODIV_1 no division applied to MCO clock + * @arg @ref RCC_MCODIV_2 division by 2 applied to MCO clock + * @arg @ref RCC_MCODIV_4 division by 4 applied to MCO clock + * @arg @ref RCC_MCODIV_8 division by 8 applied to MCO clock + * @arg @ref RCC_MCODIV_16 division by 16 applied to MCO clock + * @arg @ref RCC_MCODIV_32 division by 32 applied to MCO clock + * @arg @ref RCC_MCODIV_64 division by 64 applied to MCO clock + * @arg @ref RCC_MCODIV_128 division by 128 applied to MCO clock + * @retval None + */ +#else +/** + * @brief Selects the clock source to output on MCO pin. + * @note MCO pin should be configured in alternate function mode. + * @param RCC_MCOx specifies the output direction for the clock source. + * This parameter can be one of the following values: + * @arg @ref RCC_MCO1 Clock source to output on MCO1 pin(PA8). + * @param RCC_MCOSource specifies the clock source to output. + * This parameter can be one of the following values: + * @arg @ref RCC_MCO1SOURCE_NOCLOCK No clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_SYSCLK System clock selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI HSI selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSE HSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSI LSI selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_LSE LSE selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_HSI14 HSI14 selected as MCO clock + * @arg @ref RCC_MCO1SOURCE_PLLCLK_DIV2 PLLCLK Divided by 2 selected as MCO clock + * @param RCC_MCODiv specifies the MCO DIV. + * This parameter can be one of the following values: + * @arg @ref RCC_MCODIV_1 no division applied to MCO clock + * @retval None + */ +#endif +void HAL_RCC_MCOConfig(uint32_t RCC_MCOx, uint32_t RCC_MCOSource, uint32_t RCC_MCODiv) +{ + GPIO_InitTypeDef gpio; + + /* Check the parameters */ + assert_param(IS_RCC_MCO(RCC_MCOx)); + assert_param(IS_RCC_MCODIV(RCC_MCODiv)); + assert_param(IS_RCC_MCO1SOURCE(RCC_MCOSource)); + + /* Configure the MCO1 pin in alternate function mode */ + gpio.Mode = GPIO_MODE_AF_PP; + gpio.Speed = GPIO_SPEED_FREQ_HIGH; + gpio.Pull = GPIO_NOPULL; + gpio.Pin = MCO1_PIN; + gpio.Alternate = GPIO_AF0_MCO; + + /* MCO1 Clock Enable */ + MCO1_CLK_ENABLE(); + + HAL_GPIO_Init(MCO1_GPIO_PORT, &gpio); + + /* Configure the MCO clock source */ + __HAL_RCC_MCO1_CONFIG(RCC_MCOSource, RCC_MCODiv); +} + +/** + * @brief Enables the Clock Security System. + * @note If a failure is detected on the HSE oscillator clock, this oscillator + * is automatically disabled and an interrupt is generated to inform the + * software about the failure (Clock Security System Interrupt, CSSI), + * allowing the MCU to perform rescue operations. The CSSI is linked to + * the Cortex-M0 NMI (Non-Maskable Interrupt) exception vector. + * @retval None + */ +void HAL_RCC_EnableCSS(void) +{ + SET_BIT(RCC->CR, RCC_CR_CSSON) ; +} + +/** + * @brief Disables the Clock Security System. + * @retval None + */ +void HAL_RCC_DisableCSS(void) +{ + CLEAR_BIT(RCC->CR, RCC_CR_CSSON) ; +} + +/** + * @brief Returns the SYSCLK frequency + * @note The system frequency computed by this function is not the real + * frequency in the chip. It is calculated based on the predefined + * constant and the selected clock source: + * @note If SYSCLK source is HSI, function returns values based on HSI_VALUE(*) + * @note If SYSCLK source is HSE, function returns a value based on HSE_VALUE + * divided by PREDIV factor(**) + * @note If SYSCLK source is PLL, function returns a value based on HSE_VALUE + * divided by PREDIV factor(**) or depending on STM32F0xxxx devices either a value based + * on HSI_VALUE divided by 2 or HSI_VALUE divided by PREDIV factor(*) multiplied by the + * PLL factor. + * @note (*) HSI_VALUE is a constant defined in stm32f0xx_hal_conf.h file (default value + * 8 MHz) but the real value may vary depending on the variations + * in voltage and temperature. + * @note (**) HSE_VALUE is a constant defined in stm32f0xx_hal_conf.h file (default value + * 8 MHz), user has to ensure that HSE_VALUE is same as the real + * frequency of the crystal used. Otherwise, this function may + * have wrong result. + * + * @note The result of this function could be not correct when using fractional + * value for HSE crystal. + * + * @note This function can be used by the user application to compute the + * baud-rate for the communication peripherals or configure other parameters. + * + * @note Each time SYSCLK changes, this function must be called to update the + * right SYSCLK value. Otherwise, any configuration based on this function will be incorrect. + * + * @retval SYSCLK frequency + */ +uint32_t HAL_RCC_GetSysClockFreq(void) +{ + const uint8_t aPLLMULFactorTable[16] = { 2U, 3U, 4U, 5U, 6U, 7U, 8U, 9U, + 10U, 11U, 12U, 13U, 14U, 15U, 16U, 16U}; + const uint8_t aPredivFactorTable[16] = { 1U, 2U, 3U, 4U, 5U, 6U, 7U, 8U, + 9U,10U, 11U, 12U, 13U, 14U, 15U, 16U}; + + uint32_t tmpreg = 0U, prediv = 0U, pllclk = 0U, pllmul = 0U; + uint32_t sysclockfreq = 0U; + + tmpreg = RCC->CFGR; + + /* Get SYSCLK source -------------------------------------------------------*/ + switch (tmpreg & RCC_CFGR_SWS) + { + case RCC_SYSCLKSOURCE_STATUS_HSE: /* HSE used as system clock */ + { + sysclockfreq = HSE_VALUE; + break; + } + case RCC_SYSCLKSOURCE_STATUS_PLLCLK: /* PLL used as system clock */ + { + pllmul = aPLLMULFactorTable[(uint32_t)(tmpreg & RCC_CFGR_PLLMUL) >> RCC_CFGR_PLLMUL_BITNUMBER]; + prediv = aPredivFactorTable[(uint32_t)(RCC->CFGR2 & RCC_CFGR2_PREDIV) >> RCC_CFGR2_PREDIV_BITNUMBER]; + if ((tmpreg & RCC_CFGR_PLLSRC) == RCC_PLLSOURCE_HSE) + { + /* HSE used as PLL clock source : PLLCLK = HSE/PREDIV * PLLMUL */ + pllclk = (uint32_t)((uint64_t) HSE_VALUE / (uint64_t) (prediv)) * ((uint64_t) pllmul); + } +#if defined(RCC_CFGR_PLLSRC_HSI48_PREDIV) + else if ((tmpreg & RCC_CFGR_PLLSRC) == RCC_PLLSOURCE_HSI48) + { + /* HSI48 used as PLL clock source : PLLCLK = HSI48/PREDIV * PLLMUL */ + pllclk = (uint32_t)((uint64_t) HSI48_VALUE / (uint64_t) (prediv)) * ((uint64_t) pllmul); + } +#endif /* RCC_CFGR_PLLSRC_HSI48_PREDIV */ + else + { +#if (defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6) || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC)) + /* HSI used as PLL clock source : PLLCLK = HSI/PREDIV * PLLMUL */ + pllclk = (uint32_t)((uint64_t) HSI_VALUE / (uint64_t) (prediv)) * ((uint64_t) pllmul); +#else + /* HSI used as PLL clock source : PLLCLK = HSI/2 * PLLMUL */ + pllclk = (uint32_t)((uint64_t) (HSI_VALUE >> 1U) * ((uint64_t) pllmul)); +#endif + } + sysclockfreq = pllclk; + break; + } +#if defined(RCC_CFGR_SWS_HSI48) + case RCC_SYSCLKSOURCE_STATUS_HSI48: /* HSI48 used as system clock source */ + { + sysclockfreq = HSI48_VALUE; + break; + } +#endif /* RCC_CFGR_SWS_HSI48 */ + case RCC_SYSCLKSOURCE_STATUS_HSI: /* HSI used as system clock source */ + default: /* HSI used as system clock */ + { + sysclockfreq = HSI_VALUE; + break; + } + } + return sysclockfreq; +} + +/** + * @brief Returns the HCLK frequency + * @note Each time HCLK changes, this function must be called to update the + * right HCLK value. Otherwise, any configuration based on this function will be incorrect. + * + * @note The SystemCoreClock CMSIS variable is used to store System Clock Frequency + * and updated within this function + * @retval HCLK frequency + */ +uint32_t HAL_RCC_GetHCLKFreq(void) +{ + return SystemCoreClock; +} + +/** + * @brief Returns the PCLK1 frequency + * @note Each time PCLK1 changes, this function must be called to update the + * right PCLK1 value. Otherwise, any configuration based on this function will be incorrect. + * @retval PCLK1 frequency + */ +uint32_t HAL_RCC_GetPCLK1Freq(void) +{ + /* Get HCLK source and Compute PCLK1 frequency ---------------------------*/ + return (HAL_RCC_GetHCLKFreq() >> APBPrescTable[(RCC->CFGR & RCC_CFGR_PPRE) >> RCC_CFGR_PPRE_BITNUMBER]); +} + +/** + * @brief Configures the RCC_OscInitStruct according to the internal + * RCC configuration registers. + * @param RCC_OscInitStruct pointer to an RCC_OscInitTypeDef structure that + * will be configured. + * @retval None + */ +void HAL_RCC_GetOscConfig(RCC_OscInitTypeDef *RCC_OscInitStruct) +{ + /* Check the parameters */ + assert_param(RCC_OscInitStruct != NULL); + + /* Set all possible values for the Oscillator type parameter ---------------*/ + RCC_OscInitStruct->OscillatorType = RCC_OSCILLATORTYPE_HSE | RCC_OSCILLATORTYPE_HSI \ + | RCC_OSCILLATORTYPE_LSE | RCC_OSCILLATORTYPE_LSI | RCC_OSCILLATORTYPE_HSI14; +#if defined(RCC_HSI48_SUPPORT) + RCC_OscInitStruct->OscillatorType |= RCC_OSCILLATORTYPE_HSI48; +#endif /* RCC_HSI48_SUPPORT */ + + + /* Get the HSE configuration -----------------------------------------------*/ + if((RCC->CR &RCC_CR_HSEBYP) == RCC_CR_HSEBYP) + { + RCC_OscInitStruct->HSEState = RCC_HSE_BYPASS; + } + else if((RCC->CR &RCC_CR_HSEON) == RCC_CR_HSEON) + { + RCC_OscInitStruct->HSEState = RCC_HSE_ON; + } + else + { + RCC_OscInitStruct->HSEState = RCC_HSE_OFF; + } + + /* Get the HSI configuration -----------------------------------------------*/ + if((RCC->CR &RCC_CR_HSION) == RCC_CR_HSION) + { + RCC_OscInitStruct->HSIState = RCC_HSI_ON; + } + else + { + RCC_OscInitStruct->HSIState = RCC_HSI_OFF; + } + + RCC_OscInitStruct->HSICalibrationValue = (uint32_t)((RCC->CR &RCC_CR_HSITRIM) >> RCC_CR_HSITRIM_BitNumber); + + /* Get the LSE configuration -----------------------------------------------*/ + if((RCC->BDCR &RCC_BDCR_LSEBYP) == RCC_BDCR_LSEBYP) + { + RCC_OscInitStruct->LSEState = RCC_LSE_BYPASS; + } + else if((RCC->BDCR &RCC_BDCR_LSEON) == RCC_BDCR_LSEON) + { + RCC_OscInitStruct->LSEState = RCC_LSE_ON; + } + else + { + RCC_OscInitStruct->LSEState = RCC_LSE_OFF; + } + + /* Get the LSI configuration -----------------------------------------------*/ + if((RCC->CSR &RCC_CSR_LSION) == RCC_CSR_LSION) + { + RCC_OscInitStruct->LSIState = RCC_LSI_ON; + } + else + { + RCC_OscInitStruct->LSIState = RCC_LSI_OFF; + } + + /* Get the HSI14 configuration -----------------------------------------------*/ + if((RCC->CR2 & RCC_CR2_HSI14ON) == RCC_CR2_HSI14ON) + { + RCC_OscInitStruct->HSI14State = RCC_HSI_ON; + } + else + { + RCC_OscInitStruct->HSI14State = RCC_HSI_OFF; + } + + RCC_OscInitStruct->HSI14CalibrationValue = (uint32_t)((RCC->CR2 & RCC_CR2_HSI14TRIM) >> RCC_HSI14TRIM_BIT_NUMBER); + +#if defined(RCC_HSI48_SUPPORT) + /* Get the HSI48 configuration if any-----------------------------------------*/ + RCC_OscInitStruct->HSI48State = __HAL_RCC_GET_HSI48_STATE(); +#endif /* RCC_HSI48_SUPPORT */ + + /* Get the PLL configuration -----------------------------------------------*/ + if((RCC->CR &RCC_CR_PLLON) == RCC_CR_PLLON) + { + RCC_OscInitStruct->PLL.PLLState = RCC_PLL_ON; + } + else + { + RCC_OscInitStruct->PLL.PLLState = RCC_PLL_OFF; + } + RCC_OscInitStruct->PLL.PLLSource = (uint32_t)(RCC->CFGR & RCC_CFGR_PLLSRC); + RCC_OscInitStruct->PLL.PLLMUL = (uint32_t)(RCC->CFGR & RCC_CFGR_PLLMUL); + RCC_OscInitStruct->PLL.PREDIV = (uint32_t)(RCC->CFGR2 & RCC_CFGR2_PREDIV); +} + +/** + * @brief Get the RCC_ClkInitStruct according to the internal + * RCC configuration registers. + * @param RCC_ClkInitStruct pointer to an RCC_ClkInitTypeDef structure that + * contains the current clock configuration. + * @param pFLatency Pointer on the Flash Latency. + * @retval None + */ +void HAL_RCC_GetClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t *pFLatency) +{ + /* Check the parameters */ + assert_param(RCC_ClkInitStruct != NULL); + assert_param(pFLatency != NULL); + + /* Set all possible values for the Clock type parameter --------------------*/ + RCC_ClkInitStruct->ClockType = RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_PCLK1; + + /* Get the SYSCLK configuration --------------------------------------------*/ + RCC_ClkInitStruct->SYSCLKSource = (uint32_t)(RCC->CFGR & RCC_CFGR_SW); + + /* Get the HCLK configuration ----------------------------------------------*/ + RCC_ClkInitStruct->AHBCLKDivider = (uint32_t)(RCC->CFGR & RCC_CFGR_HPRE); + + /* Get the APB1 configuration ----------------------------------------------*/ + RCC_ClkInitStruct->APB1CLKDivider = (uint32_t)(RCC->CFGR & RCC_CFGR_PPRE); + /* Get the Flash Wait State (Latency) configuration ------------------------*/ + *pFLatency = __HAL_FLASH_GET_LATENCY(); +} + +/** + * @brief This function handles the RCC CSS interrupt request. + * @note This API should be called under the NMI_Handler(). + * @retval None + */ +void HAL_RCC_NMI_IRQHandler(void) +{ + /* Check RCC CSSF flag */ + if(__HAL_RCC_GET_IT(RCC_IT_CSS)) + { + /* RCC Clock Security System interrupt user callback */ + HAL_RCC_CSSCallback(); + + /* Clear RCC CSS pending bit */ + __HAL_RCC_CLEAR_IT(RCC_IT_CSS); + } +} + +/** + * @brief RCC Clock Security System interrupt callback + * @retval none + */ +__weak void HAL_RCC_CSSCallback(void) +{ + /* NOTE : This function Should not be modified, when the callback is needed, + the HAL_RCC_CSSCallback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_RCC_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc_ex.c new file mode 100644 index 0000000..81790d8 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rcc_ex.c @@ -0,0 +1,964 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rcc_ex.c + * @author MCD Application Team + * @brief Extended RCC HAL module driver. + * This file provides firmware functions to manage the following + * functionalities RCC extension peripheral: + * + Extended Peripheral Control functions + * + Extended Clock Recovery System Control functions + * + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#ifdef HAL_RCC_MODULE_ENABLED + +/** @defgroup RCCEx RCCEx + * @brief RCC Extension HAL module driver. + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +#if defined(CRS) +/** @defgroup RCCEx_Private_Constants RCCEx Private Constants + * @{ + */ +/* Bit position in register */ +#define CRS_CFGR_FELIM_BITNUMBER 16 +#define CRS_CR_TRIM_BITNUMBER 8 +#define CRS_ISR_FECAP_BITNUMBER 16 +/** + * @} + */ +#endif /* CRS */ + +/* Private macro -------------------------------------------------------------*/ +/** @defgroup RCCEx_Private_Macros RCCEx Private Macros + * @{ + */ +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + +/** @defgroup RCCEx_Exported_Functions RCCEx Exported Functions + * @{ + */ + +/** @defgroup RCCEx_Exported_Functions_Group1 Extended Peripheral Control functions + * @brief Extended Peripheral Control functions + * +@verbatim + =============================================================================== + ##### Extended Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the RCC Clocks + frequencies. + [..] + (@) Important note: Care must be taken when HAL_RCCEx_PeriphCLKConfig() is used to + select the RTC clock source; in this case the Backup domain will be reset in + order to modify the RTC Clock source, as consequence RTC registers (including + the backup registers) are set to their reset values. + +@endverbatim + * @{ + */ + +/** + * @brief Initializes the RCC extended peripherals clocks according to the specified + * parameters in the RCC_PeriphCLKInitTypeDef. + * @param PeriphClkInit pointer to an RCC_PeriphCLKInitTypeDef structure that + * contains the configuration information for the Extended Peripherals clocks + * (USART, RTC, I2C, CEC and USB). + * + * @note Care must be taken when @ref HAL_RCCEx_PeriphCLKConfig() is used to select + * the RTC clock source; in this case the Backup domain will be reset in + * order to modify the RTC Clock source, as consequence RTC registers (including + * the backup registers) and RCC_BDCR register are set to their reset values. + * + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef *PeriphClkInit) +{ + uint32_t tickstart = 0U; + uint32_t temp_reg = 0U; + + /* Check the parameters */ + assert_param(IS_RCC_PERIPHCLOCK(PeriphClkInit->PeriphClockSelection)); + + /*---------------------------- RTC configuration -------------------------------*/ + if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_RTC) == (RCC_PERIPHCLK_RTC)) + { + /* check for RTC Parameters used to output RTCCLK */ + assert_param(IS_RCC_RTCCLKSOURCE(PeriphClkInit->RTCClockSelection)); + + FlagStatus pwrclkchanged = RESET; + + /* As soon as function is called to change RTC clock source, activation of the + power domain is done. */ + /* Requires to enable write access to Backup Domain of necessary */ + if(__HAL_RCC_PWR_IS_CLK_DISABLED()) + { + __HAL_RCC_PWR_CLK_ENABLE(); + pwrclkchanged = SET; + } + + if(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP)) + { + /* Enable write access to Backup domain */ + SET_BIT(PWR->CR, PWR_CR_DBP); + + /* Wait for Backup domain Write protection disable */ + tickstart = HAL_GetTick(); + + while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP)) + { + if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + + /* Reset the Backup domain only if the RTC Clock source selection is modified from reset value */ + temp_reg = (RCC->BDCR & RCC_BDCR_RTCSEL); + if((temp_reg != 0x00000000U) && (temp_reg != (PeriphClkInit->RTCClockSelection & RCC_BDCR_RTCSEL))) + { + /* Store the content of BDCR register before the reset of Backup Domain */ + temp_reg = (RCC->BDCR & ~(RCC_BDCR_RTCSEL)); + /* RTC Clock selection can be changed only if the Backup Domain is reset */ + __HAL_RCC_BACKUPRESET_FORCE(); + __HAL_RCC_BACKUPRESET_RELEASE(); + /* Restore the Content of BDCR register */ + RCC->BDCR = temp_reg; + + /* Wait for LSERDY if LSE was enabled */ + if (HAL_IS_BIT_SET(temp_reg, RCC_BDCR_LSEON)) + { + /* Get Start Tick */ + tickstart = HAL_GetTick(); + + /* Wait till LSE is ready */ + while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET) + { + if((HAL_GetTick() - tickstart) > RCC_LSE_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + } + __HAL_RCC_RTC_CONFIG(PeriphClkInit->RTCClockSelection); + + /* Require to disable power clock if necessary */ + if(pwrclkchanged == SET) + { + __HAL_RCC_PWR_CLK_DISABLE(); + } + } + + /*------------------------------- USART1 Configuration ------------------------*/ + if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART1) == RCC_PERIPHCLK_USART1) + { + /* Check the parameters */ + assert_param(IS_RCC_USART1CLKSOURCE(PeriphClkInit->Usart1ClockSelection)); + + /* Configure the USART1 clock source */ + __HAL_RCC_USART1_CONFIG(PeriphClkInit->Usart1ClockSelection); + } + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + /*----------------------------- USART2 Configuration --------------------------*/ + if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART2) == RCC_PERIPHCLK_USART2) + { + /* Check the parameters */ + assert_param(IS_RCC_USART2CLKSOURCE(PeriphClkInit->Usart2ClockSelection)); + + /* Configure the USART2 clock source */ + __HAL_RCC_USART2_CONFIG(PeriphClkInit->Usart2ClockSelection); + } +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + /*----------------------------- USART3 Configuration --------------------------*/ + if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART3) == RCC_PERIPHCLK_USART3) + { + /* Check the parameters */ + assert_param(IS_RCC_USART3CLKSOURCE(PeriphClkInit->Usart3ClockSelection)); + + /* Configure the USART3 clock source */ + __HAL_RCC_USART3_CONFIG(PeriphClkInit->Usart3ClockSelection); + } +#endif /* STM32F091xC || STM32F098xx */ + + /*------------------------------ I2C1 Configuration ------------------------*/ + if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C1) == RCC_PERIPHCLK_I2C1) + { + /* Check the parameters */ + assert_param(IS_RCC_I2C1CLKSOURCE(PeriphClkInit->I2c1ClockSelection)); + + /* Configure the I2C1 clock source */ + __HAL_RCC_I2C1_CONFIG(PeriphClkInit->I2c1ClockSelection); + } + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) || defined(STM32F070x6) + /*------------------------------ USB Configuration ------------------------*/ + if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USB) == RCC_PERIPHCLK_USB) + { + /* Check the parameters */ + assert_param(IS_RCC_USBCLKSOURCE(PeriphClkInit->UsbClockSelection)); + + /* Configure the USB clock source */ + __HAL_RCC_USB_CONFIG(PeriphClkInit->UsbClockSelection); + } +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || STM32F078xx || STM32F070xB || STM32F070x6 */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + /*------------------------------ CEC clock Configuration -------------------*/ + if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_CEC) == RCC_PERIPHCLK_CEC) + { + /* Check the parameters */ + assert_param(IS_RCC_CECCLKSOURCE(PeriphClkInit->CecClockSelection)); + + /* Configure the CEC clock source */ + __HAL_RCC_CEC_CONFIG(PeriphClkInit->CecClockSelection); + } +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + + return HAL_OK; +} + +/** + * @brief Get the RCC_ClkInitStruct according to the internal + * RCC configuration registers. + * @param PeriphClkInit pointer to an RCC_PeriphCLKInitTypeDef structure that + * returns the configuration information for the Extended Peripherals clocks + * (USART, RTC, I2C, CEC and USB). + * @retval None + */ +void HAL_RCCEx_GetPeriphCLKConfig(RCC_PeriphCLKInitTypeDef *PeriphClkInit) +{ + /* Set all possible values for the extended clock type parameter------------*/ + /* Common part first */ + PeriphClkInit->PeriphClockSelection = RCC_PERIPHCLK_USART1 | RCC_PERIPHCLK_I2C1 | RCC_PERIPHCLK_RTC; + /* Get the RTC configuration --------------------------------------------*/ + PeriphClkInit->RTCClockSelection = __HAL_RCC_GET_RTC_SOURCE(); + /* Get the USART1 clock configuration --------------------------------------------*/ + PeriphClkInit->Usart1ClockSelection = __HAL_RCC_GET_USART1_SOURCE(); + /* Get the I2C1 clock source -----------------------------------------------*/ + PeriphClkInit->I2c1ClockSelection = __HAL_RCC_GET_I2C1_SOURCE(); + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + PeriphClkInit->PeriphClockSelection |= RCC_PERIPHCLK_USART2; + /* Get the USART2 clock source ---------------------------------------------*/ + PeriphClkInit->Usart2ClockSelection = __HAL_RCC_GET_USART2_SOURCE(); +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F091xC) || defined(STM32F098xx) + PeriphClkInit->PeriphClockSelection |= RCC_PERIPHCLK_USART3; + /* Get the USART3 clock source ---------------------------------------------*/ + PeriphClkInit->Usart3ClockSelection = __HAL_RCC_GET_USART3_SOURCE(); +#endif /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) || defined(STM32F070x6) + PeriphClkInit->PeriphClockSelection |= RCC_PERIPHCLK_USB; + /* Get the USB clock source ---------------------------------------------*/ + PeriphClkInit->UsbClockSelection = __HAL_RCC_GET_USB_SOURCE(); +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || STM32F078xx || STM32F070xB || STM32F070x6 */ + +#if defined(STM32F042x6) || defined(STM32F048xx)\ + || defined(STM32F051x8) || defined(STM32F058xx)\ + || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\ + || defined(STM32F091xC) || defined(STM32F098xx) + PeriphClkInit->PeriphClockSelection |= RCC_PERIPHCLK_CEC; + /* Get the CEC clock source ------------------------------------------------*/ + PeriphClkInit->CecClockSelection = __HAL_RCC_GET_CEC_SOURCE(); +#endif /* STM32F042x6 || STM32F048xx || */ + /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +} + +/** + * @brief Returns the peripheral clock frequency + * @note Returns 0 if peripheral clock is unknown + * @param PeriphClk Peripheral clock identifier + * This parameter can be one of the following values: + * @arg @ref RCC_PERIPHCLK_RTC RTC peripheral clock + * @arg @ref RCC_PERIPHCLK_USART1 USART1 peripheral clock + * @arg @ref RCC_PERIPHCLK_I2C1 I2C1 peripheral clock + @if STM32F042x6 + * @arg @ref RCC_PERIPHCLK_USB USB peripheral clock + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F048xx + * @arg @ref RCC_PERIPHCLK_USB USB peripheral clock + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F051x8 + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F058xx + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F070x6 + * @arg @ref RCC_PERIPHCLK_USB USB peripheral clock + @endif + @if STM32F070xB + * @arg @ref RCC_PERIPHCLK_USB USB peripheral clock + @endif + @if STM32F071xB + * @arg @ref RCC_PERIPHCLK_USART2 USART2 peripheral clock + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F072xB + * @arg @ref RCC_PERIPHCLK_USART2 USART2 peripheral clock + * @arg @ref RCC_PERIPHCLK_USB USB peripheral clock + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F078xx + * @arg @ref RCC_PERIPHCLK_USART2 USART2 peripheral clock + * @arg @ref RCC_PERIPHCLK_USB USB peripheral clock + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F091xC + * @arg @ref RCC_PERIPHCLK_USART2 USART2 peripheral clock + * @arg @ref RCC_PERIPHCLK_USART3 USART2 peripheral clock + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + @if STM32F098xx + * @arg @ref RCC_PERIPHCLK_USART2 USART2 peripheral clock + * @arg @ref RCC_PERIPHCLK_USART3 USART2 peripheral clock + * @arg @ref RCC_PERIPHCLK_CEC CEC peripheral clock + @endif + * @retval Frequency in Hz (0: means that no available frequency for the peripheral) + */ +uint32_t HAL_RCCEx_GetPeriphCLKFreq(uint32_t PeriphClk) +{ + /* frequency == 0 : means that no available frequency for the peripheral */ + uint32_t frequency = 0U; + + uint32_t srcclk = 0U; +#if defined(USB) + uint32_t pllmull = 0U, pllsource = 0U, predivfactor = 0U; +#endif /* USB */ + + /* Check the parameters */ + assert_param(IS_RCC_PERIPHCLOCK(PeriphClk)); + + switch (PeriphClk) + { + case RCC_PERIPHCLK_RTC: + { + /* Get the current RTC source */ + srcclk = __HAL_RCC_GET_RTC_SOURCE(); + + /* Check if LSE is ready and if RTC clock selection is LSE */ + if ((srcclk == RCC_RTCCLKSOURCE_LSE) && (HAL_IS_BIT_SET(RCC->BDCR, RCC_BDCR_LSERDY))) + { + frequency = LSE_VALUE; + } + /* Check if LSI is ready and if RTC clock selection is LSI */ + else if ((srcclk == RCC_RTCCLKSOURCE_LSI) && (HAL_IS_BIT_SET(RCC->CSR, RCC_CSR_LSIRDY))) + { + frequency = LSI_VALUE; + } + /* Check if HSE is ready and if RTC clock selection is HSI_DIV32*/ + else if ((srcclk == RCC_RTCCLKSOURCE_HSE_DIV32) && (HAL_IS_BIT_SET(RCC->CR, RCC_CR_HSERDY))) + { + frequency = HSE_VALUE / 32U; + } + break; + } + case RCC_PERIPHCLK_USART1: + { + /* Get the current USART1 source */ + srcclk = __HAL_RCC_GET_USART1_SOURCE(); + + /* Check if USART1 clock selection is PCLK1 */ + if (srcclk == RCC_USART1CLKSOURCE_PCLK1) + { + frequency = HAL_RCC_GetPCLK1Freq(); + } + /* Check if HSI is ready and if USART1 clock selection is HSI */ + else if ((srcclk == RCC_USART1CLKSOURCE_HSI) && (HAL_IS_BIT_SET(RCC->CR, RCC_CR_HSIRDY))) + { + frequency = HSI_VALUE; + } + /* Check if USART1 clock selection is SYSCLK */ + else if (srcclk == RCC_USART1CLKSOURCE_SYSCLK) + { + frequency = HAL_RCC_GetSysClockFreq(); + } + /* Check if LSE is ready and if USART1 clock selection is LSE */ + else if ((srcclk == RCC_USART1CLKSOURCE_LSE) && (HAL_IS_BIT_SET(RCC->BDCR, RCC_BDCR_LSERDY))) + { + frequency = LSE_VALUE; + } + break; + } +#if defined(RCC_CFGR3_USART2SW) + case RCC_PERIPHCLK_USART2: + { + /* Get the current USART2 source */ + srcclk = __HAL_RCC_GET_USART2_SOURCE(); + + /* Check if USART2 clock selection is PCLK1 */ + if (srcclk == RCC_USART2CLKSOURCE_PCLK1) + { + frequency = HAL_RCC_GetPCLK1Freq(); + } + /* Check if HSI is ready and if USART2 clock selection is HSI */ + else if ((srcclk == RCC_USART2CLKSOURCE_HSI) && (HAL_IS_BIT_SET(RCC->CR, RCC_CR_HSIRDY))) + { + frequency = HSI_VALUE; + } + /* Check if USART2 clock selection is SYSCLK */ + else if (srcclk == RCC_USART2CLKSOURCE_SYSCLK) + { + frequency = HAL_RCC_GetSysClockFreq(); + } + /* Check if LSE is ready and if USART2 clock selection is LSE */ + else if ((srcclk == RCC_USART2CLKSOURCE_LSE) && (HAL_IS_BIT_SET(RCC->BDCR, RCC_BDCR_LSERDY))) + { + frequency = LSE_VALUE; + } + break; + } +#endif /* RCC_CFGR3_USART2SW */ +#if defined(RCC_CFGR3_USART3SW) + case RCC_PERIPHCLK_USART3: + { + /* Get the current USART3 source */ + srcclk = __HAL_RCC_GET_USART3_SOURCE(); + + /* Check if USART3 clock selection is PCLK1 */ + if (srcclk == RCC_USART3CLKSOURCE_PCLK1) + { + frequency = HAL_RCC_GetPCLK1Freq(); + } + /* Check if HSI is ready and if USART3 clock selection is HSI */ + else if ((srcclk == RCC_USART3CLKSOURCE_HSI) && (HAL_IS_BIT_SET(RCC->CR, RCC_CR_HSIRDY))) + { + frequency = HSI_VALUE; + } + /* Check if USART3 clock selection is SYSCLK */ + else if (srcclk == RCC_USART3CLKSOURCE_SYSCLK) + { + frequency = HAL_RCC_GetSysClockFreq(); + } + /* Check if LSE is ready and if USART3 clock selection is LSE */ + else if ((srcclk == RCC_USART3CLKSOURCE_LSE) && (HAL_IS_BIT_SET(RCC->BDCR, RCC_BDCR_LSERDY))) + { + frequency = LSE_VALUE; + } + break; + } +#endif /* RCC_CFGR3_USART3SW */ + case RCC_PERIPHCLK_I2C1: + { + /* Get the current I2C1 source */ + srcclk = __HAL_RCC_GET_I2C1_SOURCE(); + + /* Check if HSI is ready and if I2C1 clock selection is HSI */ + if ((srcclk == RCC_I2C1CLKSOURCE_HSI) && (HAL_IS_BIT_SET(RCC->CR, RCC_CR_HSIRDY))) + { + frequency = HSI_VALUE; + } + /* Check if I2C1 clock selection is SYSCLK */ + else if (srcclk == RCC_I2C1CLKSOURCE_SYSCLK) + { + frequency = HAL_RCC_GetSysClockFreq(); + } + break; + } +#if defined(USB) + case RCC_PERIPHCLK_USB: + { + /* Get the current USB source */ + srcclk = __HAL_RCC_GET_USB_SOURCE(); + + /* Check if PLL is ready and if USB clock selection is PLL */ + if ((srcclk == RCC_USBCLKSOURCE_PLL) && (HAL_IS_BIT_SET(RCC->CR, RCC_CR_PLLRDY))) + { + /* Get PLL clock source and multiplication factor ----------------------*/ + pllmull = RCC->CFGR & RCC_CFGR_PLLMUL; + pllsource = RCC->CFGR & RCC_CFGR_PLLSRC; + pllmull = (pllmull >> RCC_CFGR_PLLMUL_BITNUMBER) + 2U; + predivfactor = (RCC->CFGR2 & RCC_CFGR2_PREDIV) + 1U; + + if (pllsource == RCC_CFGR_PLLSRC_HSE_PREDIV) + { + /* HSE used as PLL clock source : frequency = HSE/PREDIV * PLLMUL */ + frequency = (HSE_VALUE/predivfactor) * pllmull; + } +#if defined(RCC_CR2_HSI48ON) + else if (pllsource == RCC_CFGR_PLLSRC_HSI48_PREDIV) + { + /* HSI48 used as PLL clock source : frequency = HSI48/PREDIV * PLLMUL */ + frequency = (HSI48_VALUE / predivfactor) * pllmull; + } +#endif /* RCC_CR2_HSI48ON */ + else + { +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F078xx) || defined(STM32F072xB) || defined(STM32F070xB) + /* HSI used as PLL clock source : frequency = HSI/PREDIV * PLLMUL */ + frequency = (HSI_VALUE / predivfactor) * pllmull; +#else + /* HSI used as PLL clock source : frequency = HSI/2U * PLLMUL */ + frequency = (HSI_VALUE >> 1U) * pllmull; +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || STM32F078xx || STM32F070xB */ + } + } +#if defined(RCC_CR2_HSI48ON) + /* Check if HSI48 is ready and if USB clock selection is HSI48 */ + else if ((srcclk == RCC_USBCLKSOURCE_HSI48) && (HAL_IS_BIT_SET(RCC->CR2, RCC_CR2_HSI48RDY))) + { + frequency = HSI48_VALUE; + } +#endif /* RCC_CR2_HSI48ON */ + break; + } +#endif /* USB */ +#if defined(CEC) + case RCC_PERIPHCLK_CEC: + { + /* Get the current CEC source */ + srcclk = __HAL_RCC_GET_CEC_SOURCE(); + + /* Check if HSI is ready and if CEC clock selection is HSI */ + if ((srcclk == RCC_CECCLKSOURCE_HSI) && (HAL_IS_BIT_SET(RCC->CR, RCC_CR_HSIRDY))) + { + frequency = HSI_VALUE; + } + /* Check if LSE is ready and if CEC clock selection is LSE */ + else if ((srcclk == RCC_CECCLKSOURCE_LSE) && (HAL_IS_BIT_SET(RCC->BDCR, RCC_BDCR_LSERDY))) + { + frequency = LSE_VALUE; + } + break; + } +#endif /* CEC */ + default: + { + break; + } + } + return(frequency); +} + +/** + * @} + */ + +#if defined(CRS) + +/** @defgroup RCCEx_Exported_Functions_Group3 Extended Clock Recovery System Control functions + * @brief Extended Clock Recovery System Control functions + * +@verbatim + =============================================================================== + ##### Extended Clock Recovery System Control functions ##### + =============================================================================== + [..] + For devices with Clock Recovery System feature (CRS), RCC Extension HAL driver can be used as follows: + + (#) In System clock config, HSI48 needs to be enabled + + (#) Enable CRS clock in IP MSP init which will use CRS functions + + (#) Call CRS functions as follows: + (##) Prepare synchronization configuration necessary for HSI48 calibration + (+++) Default values can be set for frequency Error Measurement (reload and error limit) + and also HSI48 oscillator smooth trimming. + (+++) Macro __HAL_RCC_CRS_RELOADVALUE_CALCULATE can be also used to calculate + directly reload value with target and synchronization frequencies values + (##) Call function HAL_RCCEx_CRSConfig which + (+++) Reset CRS registers to their default values. + (+++) Configure CRS registers with synchronization configuration + (+++) Enable automatic calibration and frequency error counter feature + Note: When using USB LPM (Link Power Management) and the device is in Sleep mode, the + periodic USB SOF will not be generated by the host. No SYNC signal will therefore be + provided to the CRS to calibrate the HSI48 on the run. To guarantee the required clock + precision after waking up from Sleep mode, the LSE or reference clock on the GPIOs + should be used as SYNC signal. + + (##) A polling function is provided to wait for complete synchronization + (+++) Call function HAL_RCCEx_CRSWaitSynchronization() + (+++) According to CRS status, user can decide to adjust again the calibration or continue + application if synchronization is OK + + (#) User can retrieve information related to synchronization in calling function + HAL_RCCEx_CRSGetSynchronizationInfo() + + (#) Regarding synchronization status and synchronization information, user can try a new calibration + in changing synchronization configuration and call again HAL_RCCEx_CRSConfig. + Note: When the SYNC event is detected during the downcounting phase (before reaching the zero value), + it means that the actual frequency is lower than the target (and so, that the TRIM value should be + incremented), while when it is detected during the upcounting phase it means that the actual frequency + is higher (and that the TRIM value should be decremented). + + (#) In interrupt mode, user can resort to the available macros (__HAL_RCC_CRS_XXX_IT). Interrupts will go + through CRS Handler (RCC_IRQn/RCC_IRQHandler) + (++) Call function HAL_RCCEx_CRSConfig() + (++) Enable RCC_IRQn (thanks to NVIC functions) + (++) Enable CRS interrupt (__HAL_RCC_CRS_ENABLE_IT) + (++) Implement CRS status management in the following user callbacks called from + HAL_RCCEx_CRS_IRQHandler(): + (+++) HAL_RCCEx_CRS_SyncOkCallback() + (+++) HAL_RCCEx_CRS_SyncWarnCallback() + (+++) HAL_RCCEx_CRS_ExpectedSyncCallback() + (+++) HAL_RCCEx_CRS_ErrorCallback() + + (#) To force a SYNC EVENT, user can use the function HAL_RCCEx_CRSSoftwareSynchronizationGenerate(). + This function can be called before calling HAL_RCCEx_CRSConfig (for instance in Systick handler) + +@endverbatim + * @{ + */ + +/** + * @brief Start automatic synchronization for polling mode + * @param pInit Pointer on RCC_CRSInitTypeDef structure + * @retval None + */ +void HAL_RCCEx_CRSConfig(RCC_CRSInitTypeDef *pInit) +{ + uint32_t value = 0U; + + /* Check the parameters */ + assert_param(IS_RCC_CRS_SYNC_DIV(pInit->Prescaler)); + assert_param(IS_RCC_CRS_SYNC_SOURCE(pInit->Source)); + assert_param(IS_RCC_CRS_SYNC_POLARITY(pInit->Polarity)); + assert_param(IS_RCC_CRS_RELOADVALUE(pInit->ReloadValue)); + assert_param(IS_RCC_CRS_ERRORLIMIT(pInit->ErrorLimitValue)); + assert_param(IS_RCC_CRS_HSI48CALIBRATION(pInit->HSI48CalibrationValue)); + + /* CONFIGURATION */ + + /* Before configuration, reset CRS registers to their default values*/ + __HAL_RCC_CRS_FORCE_RESET(); + __HAL_RCC_CRS_RELEASE_RESET(); + + /* Set the SYNCDIV[2:0] bits according to Prescaler value */ + /* Set the SYNCSRC[1:0] bits according to Source value */ + /* Set the SYNCSPOL bit according to Polarity value */ + value = (pInit->Prescaler | pInit->Source | pInit->Polarity); + /* Set the RELOAD[15:0] bits according to ReloadValue value */ + value |= pInit->ReloadValue; + /* Set the FELIM[7:0] bits according to ErrorLimitValue value */ + value |= (pInit->ErrorLimitValue << CRS_CFGR_FELIM_BITNUMBER); + WRITE_REG(CRS->CFGR, value); + + /* Adjust HSI48 oscillator smooth trimming */ + /* Set the TRIM[5:0] bits according to RCC_CRS_HSI48CalibrationValue value */ + MODIFY_REG(CRS->CR, CRS_CR_TRIM, (pInit->HSI48CalibrationValue << CRS_CR_TRIM_BITNUMBER)); + + /* START AUTOMATIC SYNCHRONIZATION*/ + + /* Enable Automatic trimming & Frequency error counter */ + SET_BIT(CRS->CR, CRS_CR_AUTOTRIMEN | CRS_CR_CEN); +} + +/** + * @brief Generate the software synchronization event + * @retval None + */ +void HAL_RCCEx_CRSSoftwareSynchronizationGenerate(void) +{ + SET_BIT(CRS->CR, CRS_CR_SWSYNC); +} + +/** + * @brief Return synchronization info + * @param pSynchroInfo Pointer on RCC_CRSSynchroInfoTypeDef structure + * @retval None + */ +void HAL_RCCEx_CRSGetSynchronizationInfo(RCC_CRSSynchroInfoTypeDef *pSynchroInfo) +{ + /* Check the parameter */ + assert_param(pSynchroInfo != NULL); + + /* Get the reload value */ + pSynchroInfo->ReloadValue = (uint32_t)(READ_BIT(CRS->CFGR, CRS_CFGR_RELOAD)); + + /* Get HSI48 oscillator smooth trimming */ + pSynchroInfo->HSI48CalibrationValue = (uint32_t)(READ_BIT(CRS->CR, CRS_CR_TRIM) >> CRS_CR_TRIM_BITNUMBER); + + /* Get Frequency error capture */ + pSynchroInfo->FreqErrorCapture = (uint32_t)(READ_BIT(CRS->ISR, CRS_ISR_FECAP) >> CRS_ISR_FECAP_BITNUMBER); + + /* Get Frequency error direction */ + pSynchroInfo->FreqErrorDirection = (uint32_t)(READ_BIT(CRS->ISR, CRS_ISR_FEDIR)); +} + +/** +* @brief Wait for CRS Synchronization status. +* @param Timeout Duration of the timeout +* @note Timeout is based on the maximum time to receive a SYNC event based on synchronization +* frequency. +* @note If Timeout set to HAL_MAX_DELAY, HAL_TIMEOUT will be never returned. +* @retval Combination of Synchronization status +* This parameter can be a combination of the following values: +* @arg @ref RCC_CRS_TIMEOUT +* @arg @ref RCC_CRS_SYNCOK +* @arg @ref RCC_CRS_SYNCWARN +* @arg @ref RCC_CRS_SYNCERR +* @arg @ref RCC_CRS_SYNCMISS +* @arg @ref RCC_CRS_TRIMOVF +*/ +uint32_t HAL_RCCEx_CRSWaitSynchronization(uint32_t Timeout) +{ + uint32_t crsstatus = RCC_CRS_NONE; + uint32_t tickstart = 0U; + + /* Get timeout */ + tickstart = HAL_GetTick(); + + /* Wait for CRS flag or timeout detection */ + do + { + if(Timeout != HAL_MAX_DELAY) + { + if((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + crsstatus = RCC_CRS_TIMEOUT; + } + } + /* Check CRS SYNCOK flag */ + if(__HAL_RCC_CRS_GET_FLAG(RCC_CRS_FLAG_SYNCOK)) + { + /* CRS SYNC event OK */ + crsstatus |= RCC_CRS_SYNCOK; + + /* Clear CRS SYNC event OK bit */ + __HAL_RCC_CRS_CLEAR_FLAG(RCC_CRS_FLAG_SYNCOK); + } + + /* Check CRS SYNCWARN flag */ + if(__HAL_RCC_CRS_GET_FLAG(RCC_CRS_FLAG_SYNCWARN)) + { + /* CRS SYNC warning */ + crsstatus |= RCC_CRS_SYNCWARN; + + /* Clear CRS SYNCWARN bit */ + __HAL_RCC_CRS_CLEAR_FLAG(RCC_CRS_FLAG_SYNCWARN); + } + + /* Check CRS TRIM overflow flag */ + if(__HAL_RCC_CRS_GET_FLAG(RCC_CRS_FLAG_TRIMOVF)) + { + /* CRS SYNC Error */ + crsstatus |= RCC_CRS_TRIMOVF; + + /* Clear CRS Error bit */ + __HAL_RCC_CRS_CLEAR_FLAG(RCC_CRS_FLAG_TRIMOVF); + } + + /* Check CRS Error flag */ + if(__HAL_RCC_CRS_GET_FLAG(RCC_CRS_FLAG_SYNCERR)) + { + /* CRS SYNC Error */ + crsstatus |= RCC_CRS_SYNCERR; + + /* Clear CRS Error bit */ + __HAL_RCC_CRS_CLEAR_FLAG(RCC_CRS_FLAG_SYNCERR); + } + + /* Check CRS SYNC Missed flag */ + if(__HAL_RCC_CRS_GET_FLAG(RCC_CRS_FLAG_SYNCMISS)) + { + /* CRS SYNC Missed */ + crsstatus |= RCC_CRS_SYNCMISS; + + /* Clear CRS SYNC Missed bit */ + __HAL_RCC_CRS_CLEAR_FLAG(RCC_CRS_FLAG_SYNCMISS); + } + + /* Check CRS Expected SYNC flag */ + if(__HAL_RCC_CRS_GET_FLAG(RCC_CRS_FLAG_ESYNC)) + { + /* frequency error counter reached a zero value */ + __HAL_RCC_CRS_CLEAR_FLAG(RCC_CRS_FLAG_ESYNC); + } + } while(RCC_CRS_NONE == crsstatus); + + return crsstatus; +} + +/** + * @brief Handle the Clock Recovery System interrupt request. + * @retval None + */ +void HAL_RCCEx_CRS_IRQHandler(void) +{ + uint32_t crserror = RCC_CRS_NONE; + /* Get current IT flags and IT sources values */ + uint32_t itflags = READ_REG(CRS->ISR); + uint32_t itsources = READ_REG(CRS->CR); + + /* Check CRS SYNCOK flag */ + if(((itflags & RCC_CRS_FLAG_SYNCOK) != RESET) && ((itsources & RCC_CRS_IT_SYNCOK) != RESET)) + { + /* Clear CRS SYNC event OK flag */ + WRITE_REG(CRS->ICR, CRS_ICR_SYNCOKC); + + /* user callback */ + HAL_RCCEx_CRS_SyncOkCallback(); + } + /* Check CRS SYNCWARN flag */ + else if(((itflags & RCC_CRS_FLAG_SYNCWARN) != RESET) && ((itsources & RCC_CRS_IT_SYNCWARN) != RESET)) + { + /* Clear CRS SYNCWARN flag */ + WRITE_REG(CRS->ICR, CRS_ICR_SYNCWARNC); + + /* user callback */ + HAL_RCCEx_CRS_SyncWarnCallback(); + } + /* Check CRS Expected SYNC flag */ + else if(((itflags & RCC_CRS_FLAG_ESYNC) != RESET) && ((itsources & RCC_CRS_IT_ESYNC) != RESET)) + { + /* frequency error counter reached a zero value */ + WRITE_REG(CRS->ICR, CRS_ICR_ESYNCC); + + /* user callback */ + HAL_RCCEx_CRS_ExpectedSyncCallback(); + } + /* Check CRS Error flags */ + else + { + if(((itflags & RCC_CRS_FLAG_ERR) != RESET) && ((itsources & RCC_CRS_IT_ERR) != RESET)) + { + if((itflags & RCC_CRS_FLAG_SYNCERR) != RESET) + { + crserror |= RCC_CRS_SYNCERR; + } + if((itflags & RCC_CRS_FLAG_SYNCMISS) != RESET) + { + crserror |= RCC_CRS_SYNCMISS; + } + if((itflags & RCC_CRS_FLAG_TRIMOVF) != RESET) + { + crserror |= RCC_CRS_TRIMOVF; + } + + /* Clear CRS Error flags */ + WRITE_REG(CRS->ICR, CRS_ICR_ERRC); + + /* user error callback */ + HAL_RCCEx_CRS_ErrorCallback(crserror); + } + } +} + +/** + * @brief RCCEx Clock Recovery System SYNCOK interrupt callback. + * @retval none + */ +__weak void HAL_RCCEx_CRS_SyncOkCallback(void) +{ + /* NOTE : This function should not be modified, when the callback is needed, + the @ref HAL_RCCEx_CRS_SyncOkCallback should be implemented in the user file + */ +} + +/** + * @brief RCCEx Clock Recovery System SYNCWARN interrupt callback. + * @retval none + */ +__weak void HAL_RCCEx_CRS_SyncWarnCallback(void) +{ + /* NOTE : This function should not be modified, when the callback is needed, + the @ref HAL_RCCEx_CRS_SyncWarnCallback should be implemented in the user file + */ +} + +/** + * @brief RCCEx Clock Recovery System Expected SYNC interrupt callback. + * @retval none + */ +__weak void HAL_RCCEx_CRS_ExpectedSyncCallback(void) +{ + /* NOTE : This function should not be modified, when the callback is needed, + the @ref HAL_RCCEx_CRS_ExpectedSyncCallback should be implemented in the user file + */ +} + +/** + * @brief RCCEx Clock Recovery System Error interrupt callback. + * @param Error Combination of Error status. + * This parameter can be a combination of the following values: + * @arg @ref RCC_CRS_SYNCERR + * @arg @ref RCC_CRS_SYNCMISS + * @arg @ref RCC_CRS_TRIMOVF + * @retval none + */ +__weak void HAL_RCCEx_CRS_ErrorCallback(uint32_t Error) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(Error); + + /* NOTE : This function should not be modified, when the callback is needed, + the @ref HAL_RCCEx_CRS_ErrorCallback should be implemented in the user file + */ +} + +/** + * @} + */ + +#endif /* CRS */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_RCC_MODULE_ENABLED */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc.c new file mode 100644 index 0000000..dc9560e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc.c @@ -0,0 +1,1733 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rtc.c + * @author MCD Application Team + * @brief RTC HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Real Time Clock (RTC) peripheral: + * + Initialization and de-initialization functions + * + RTC Time and Date functions + * + RTC Alarm functions + * + Peripheral Control functions + * + Peripheral State functions + * + @verbatim + ============================================================================== + ##### How to use RTC Driver ##### + =================================================================== + [..] + (+) Enable the RTC domain access (see description in the section above). + (+) Configure the RTC Prescaler (Asynchronous and Synchronous) and RTC hour + format using the HAL_RTC_Init() function. + + *** Time and Date configuration *** + =================================== + [..] + (+) To configure the RTC Calendar (Time and Date) use the HAL_RTC_SetTime() + and HAL_RTC_SetDate() functions. + (+) To read the RTC Calendar, use the HAL_RTC_GetTime() and HAL_RTC_GetDate() functions. + + *** Alarm configuration *** + =========================== + [..] + (+) To configure the RTC Alarm use the HAL_RTC_SetAlarm() function. + You can also configure the RTC Alarm with interrupt mode using the + HAL_RTC_SetAlarm_IT() function. + (+) To read the RTC Alarm, use the HAL_RTC_GetAlarm() function. + + ##### RTC and low power modes ##### + =================================================================== + [..] The MCU can be woken up from a low power mode by an RTC alternate + function. + [..] The RTC alternate functions are the RTC alarm (Alarm A), + RTC wake-up, RTC tamper event detection and RTC time stamp event detection. + These RTC alternate functions can wake up the system from the Stop and + Standby low power modes. + [..] The system can also wake up from low power modes without depending + on an external interrupt (Auto-wake-up mode), by using the RTC alarm + or the RTC wake-up events. + [..] The RTC provides a programmable time base for waking up from the + Stop or Standby mode at regular intervals. + Wake-up from STOP and STANDBY modes is possible only when the RTC clock source + is LSE or LSI. + + *** Callback registration *** + ============================================= + + The compilation define USE_RTC_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + Use Function HAL_RTC_RegisterCallback() to register an interrupt callback. + + Function HAL_RTC_RegisterCallback() allows to register following callbacks: + (+) AlarmAEventCallback : RTC Alarm A Event callback. + (+) TimeStampEventCallback : RTC TimeStamp Event callback. + (+) WakeUpTimerEventCallback : RTC WakeUpTimer Event callback. + (+) Tamper1EventCallback : RTC Tamper 1 Event callback. + (+) Tamper2EventCallback : RTC Tamper 2 Event callback. + (+) Tamper3EventCallback : RTC Tamper 3 Event callback. + (+) MspInitCallback : RTC MspInit callback. + (+) MspDeInitCallback : RTC MspDeInit callback. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + Use function HAL_RTC_UnRegisterCallback() to reset a callback to the default + weak function. + HAL_RTC_UnRegisterCallback() takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) AlarmAEventCallback : RTC Alarm A Event callback. + (+) TimeStampEventCallback : RTC TimeStamp Event callback. + (+) WakeUpTimerEventCallback : RTC WakeUpTimer Event callback. + (+) Tamper1EventCallback : RTC Tamper 1 Event callback. + (+) Tamper2EventCallback : RTC Tamper 2 Event callback. + (+) Tamper3EventCallback : RTC Tamper 3 Event callback. + (+) MspInitCallback : RTC MspInit callback. + (+) MspDeInitCallback : RTC MspDeInit callback. + + By default, after the HAL_RTC_Init() and when the state is HAL_RTC_STATE_RESET, + all callbacks are set to the corresponding weak functions : + examples AlarmAEventCallback(), WakeUpTimerEventCallback(). + Exception done for MspInit and MspDeInit callbacks that are reset to the legacy weak function + in the HAL_RTC_Init()/HAL_RTC_DeInit() only when these callbacks are null + (not registered beforehand). + If not, MspInit or MspDeInit are not null, HAL_RTC_Init()/HAL_RTC_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) + + Callbacks can be registered/unregistered in HAL_RTC_STATE_READY state only. + Exception done MspInit/MspDeInit that can be registered/unregistered + in HAL_RTC_STATE_READY or HAL_RTC_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_RTC_RegisterCallback() before calling HAL_RTC_DeInit() + or HAL_RTC_Init() function. + + When The compilation define USE_HAL_RTC_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + @endverbatim + + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup RTC + * @brief RTC HAL module driver + * @{ + */ + +#ifdef HAL_RTC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions ---------------------------------------------------------*/ + +/** @addtogroup RTC_Exported_Functions + * @{ + */ + +/** @addtogroup RTC_Exported_Functions_Group1 + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This section provides functions allowing to initialize and configure the + RTC Prescaler (Synchronous and Asynchronous), RTC Hour format, disable + RTC registers Write protection, enter and exit the RTC initialization mode, + RTC registers synchronization check and reference clock detection enable. + (#) The RTC Prescaler is programmed to generate the RTC 1Hz time base. + It is split into 2 programmable prescalers to minimize power consumption. + (++) A 7-bit asynchronous prescaler and a 15-bit synchronous prescaler. + (++) When both prescalers are used, it is recommended to configure the + asynchronous prescaler to a high value to minimize power consumption. + (#) All RTC registers are Write protected. Writing to the RTC registers + is enabled by writing a key into the Write Protection register, RTC_WPR. + (#) To configure the RTC Calendar, user application should enter + initialization mode. In this mode, the calendar counter is stopped + and its value can be updated. When the initialization sequence is + complete, the calendar restarts counting after 4 RTCCLK cycles. + (#) To read the calendar through the shadow registers after Calendar + initialization, calendar update or after wake-up from low power modes + the software must first clear the RSF flag. The software must then + wait until it is set again before reading the calendar, which means + that the calendar registers have been correctly copied into the + RTC_TR and RTC_DR shadow registers.The HAL_RTC_WaitForSynchro() function + implements the above software sequence (RSF clear and RSF check). + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the RTC according to the specified parameters + * in the RTC_InitTypeDef structure and initialize the associated handle. + * @param hrtc RTC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_Init(RTC_HandleTypeDef *hrtc) +{ + /* Check the RTC peripheral state */ + if (hrtc == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_RTC_ALL_INSTANCE(hrtc->Instance)); + assert_param(IS_RTC_HOUR_FORMAT(hrtc->Init.HourFormat)); + assert_param(IS_RTC_ASYNCH_PREDIV(hrtc->Init.AsynchPrediv)); + assert_param(IS_RTC_SYNCH_PREDIV(hrtc->Init.SynchPrediv)); + assert_param(IS_RTC_OUTPUT(hrtc->Init.OutPut)); + assert_param(IS_RTC_OUTPUT_POL(hrtc->Init.OutPutPolarity)); + assert_param(IS_RTC_OUTPUT_TYPE(hrtc->Init.OutPutType)); + +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + if (hrtc->State == HAL_RTC_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hrtc->Lock = HAL_UNLOCKED; + + hrtc->AlarmAEventCallback = HAL_RTC_AlarmAEventCallback; /* Legacy weak AlarmAEventCallback */ + hrtc->TimeStampEventCallback = HAL_RTCEx_TimeStampEventCallback; /* Legacy weak TimeStampEventCallback */ +#if defined(RTC_WAKEUP_SUPPORT) + hrtc->WakeUpTimerEventCallback = HAL_RTCEx_WakeUpTimerEventCallback; /* Legacy weak WakeUpTimerEventCallback */ +#endif /* RTC_WAKEUP_SUPPORT */ + hrtc->Tamper1EventCallback = HAL_RTCEx_Tamper1EventCallback; /* Legacy weak Tamper1EventCallback */ + hrtc->Tamper2EventCallback = HAL_RTCEx_Tamper2EventCallback; /* Legacy weak Tamper2EventCallback */ +#if defined(RTC_TAMPER3_SUPPORT) + hrtc->Tamper3EventCallback = HAL_RTCEx_Tamper3EventCallback; /* Legacy weak Tamper3EventCallback */ +#endif /* RTC_TAMPER3_SUPPORT */ + + if (hrtc->MspInitCallback == NULL) + { + hrtc->MspInitCallback = HAL_RTC_MspInit; + } + /* Init the low level hardware */ + hrtc->MspInitCallback(hrtc); + + if (hrtc->MspDeInitCallback == NULL) + { + hrtc->MspDeInitCallback = HAL_RTC_MspDeInit; + } + } +#else + if (hrtc->State == HAL_RTC_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hrtc->Lock = HAL_UNLOCKED; + + /* Initialize RTC MSP */ + HAL_RTC_MspInit(hrtc); + } +#endif /* (USE_HAL_RTC_REGISTER_CALLBACKS) */ + + /* Set RTC state */ + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set Initialization mode */ + if (RTC_EnterInitMode(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state */ + hrtc->State = HAL_RTC_STATE_ERROR; + + return HAL_ERROR; + } + else + { + /* Clear RTC_CR FMT, OSEL and POL Bits */ + hrtc->Instance->CR &= ((uint32_t)~(RTC_CR_FMT | RTC_CR_OSEL | RTC_CR_POL)); + /* Set RTC_CR register */ + hrtc->Instance->CR |= (uint32_t)(hrtc->Init.HourFormat | hrtc->Init.OutPut | hrtc->Init.OutPutPolarity); + + /* Configure the RTC PRER */ + hrtc->Instance->PRER = (uint32_t)(hrtc->Init.SynchPrediv); + hrtc->Instance->PRER |= (uint32_t)(hrtc->Init.AsynchPrediv << 16U); + + /* Exit Initialization mode */ + hrtc->Instance->ISR &= (uint32_t)~RTC_ISR_INIT; + + /* If CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */ + if ((hrtc->Instance->CR & RTC_CR_BYPSHAD) == RESET) + { + if (HAL_RTC_WaitForSynchro(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_ERROR; + + return HAL_ERROR; + } + } + + hrtc->Instance->TAFCR &= (uint32_t)~RTC_TAFCR_ALARMOUTTYPE; + hrtc->Instance->TAFCR |= (uint32_t)(hrtc->Init.OutPutType); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + return HAL_OK; + } +} + +/** + * @brief DeInitialize the RTC peripheral. + * @param hrtc RTC handle + * @note This function doesn't reset the RTC Backup Data registers. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_DeInit(RTC_HandleTypeDef *hrtc) +{ +#if defined (STM32F030xC) || defined (STM32F070xB) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) + uint32_t tickstart = 0; +#endif /* defined (STM32F030xC) || defined (STM32F070xB) ||\ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) ||*/ + + /* Check the parameters */ + assert_param(IS_RTC_ALL_INSTANCE(hrtc->Instance)); + + /* Set RTC state */ + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set Initialization mode */ + if (RTC_EnterInitMode(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state */ + hrtc->State = HAL_RTC_STATE_ERROR; + + return HAL_ERROR; + } + else + { + /* Reset TR, DR and CR registers */ + hrtc->Instance->TR = 0x00000000U; + hrtc->Instance->DR = 0x00002101U; + +#if defined (STM32F030xC) || defined (STM32F070xB) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) + /* Reset All CR bits except CR[2:0] */ + hrtc->Instance->CR &= 0x00000007U; + + tickstart = HAL_GetTick(); + + /* Wait till WUTWF flag is set and if Time out is reached exit */ + while (((hrtc->Instance->ISR) & RTC_ISR_WUTWF) == (uint32_t)RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state */ + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + return HAL_TIMEOUT; + } + } +#endif /* defined (STM32F030xC) || defined (STM32F070xB) ||\ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) ||*/ + + /* Reset all RTC CR register bits */ + hrtc->Instance->CR &= 0x00000000U; +#if defined (STM32F030xC) || defined (STM32F070xB) || \ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) + hrtc->Instance->WUTR = 0x0000FFFFU; +#endif /* defined (STM32F030xC) || defined (STM32F070xB) ||\ + defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) || \ + defined (STM32F091xC) || defined (STM32F098xx) ||*/ + hrtc->Instance->PRER = 0x007F00FFU; + hrtc->Instance->ALRMAR = 0x00000000U; + hrtc->Instance->SHIFTR = 0x00000000U; + hrtc->Instance->CALR = 0x00000000U; + hrtc->Instance->ALRMASSR = 0x00000000U; + + /* Reset ISR register and exit initialization mode */ + hrtc->Instance->ISR = 0x00000000U; + + /* Reset Tamper and alternate functions configuration register */ + hrtc->Instance->TAFCR = 0x00000000; + + /* If RTC_CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */ + if ((hrtc->Instance->CR & RTC_CR_BYPSHAD) == RESET) + { + if (HAL_RTC_WaitForSynchro(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_ERROR; + + return HAL_ERROR; + } + } + } + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + if (hrtc->MspDeInitCallback == NULL) + { + hrtc->MspDeInitCallback = HAL_RTC_MspDeInit; + } + + /* DeInit the low level hardware: CLOCK, NVIC.*/ + hrtc->MspDeInitCallback(hrtc); + +#else + /* De-Initialize RTC MSP */ + HAL_RTC_MspDeInit(hrtc); +#endif /* (USE_HAL_RTC_REGISTER_CALLBACKS) */ + + hrtc->State = HAL_RTC_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User RTC Callback + * To be used instead of the weak predefined callback + * @param hrtc RTC handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_RTC_ALARM_A_EVENT_CB_ID Alarm A Event Callback ID + * @arg @ref HAL_RTC_TIMESTAMP_EVENT_CB_ID TimeStamp Event Callback ID + * @arg @ref HAL_RTC_WAKEUPTIMER_EVENT_CB_ID WakeUp Timer Event Callback ID + * @arg @ref HAL_RTC_TAMPER1_EVENT_CB_ID Tamper 1 Callback ID + * @arg @ref HAL_RTC_TAMPER2_EVENT_CB_ID Tamper 2 Callback ID + * @arg @ref HAL_RTC_TAMPER3_EVENT_CB_ID Tamper 3 Callback ID + * @arg @ref HAL_RTC_MSPINIT_CB_ID Msp Init callback ID + * @arg @ref HAL_RTC_MSPDEINIT_CB_ID Msp DeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_RegisterCallback(RTC_HandleTypeDef *hrtc, HAL_RTC_CallbackIDTypeDef CallbackID, pRTC_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hrtc); + + if (HAL_RTC_STATE_READY == hrtc->State) + { + switch (CallbackID) + { + case HAL_RTC_ALARM_A_EVENT_CB_ID : + hrtc->AlarmAEventCallback = pCallback; + break; + + case HAL_RTC_TIMESTAMP_EVENT_CB_ID : + hrtc->TimeStampEventCallback = pCallback; + break; + +#if defined(RTC_WAKEUP_SUPPORT) + case HAL_RTC_WAKEUPTIMER_EVENT_CB_ID : + hrtc->WakeUpTimerEventCallback = pCallback; + break; +#endif /* RTC_WAKEUP_SUPPORT */ + case HAL_RTC_TAMPER1_EVENT_CB_ID : + hrtc->Tamper1EventCallback = pCallback; + break; + + case HAL_RTC_TAMPER2_EVENT_CB_ID : + hrtc->Tamper2EventCallback = pCallback; + break; + +#if defined(RTC_TAMPER3_SUPPORT) + case HAL_RTC_TAMPER3_EVENT_CB_ID : + hrtc->Tamper3EventCallback = pCallback; + break; +#endif /* RTC_TAMPER3_SUPPORT */ + case HAL_RTC_MSPINIT_CB_ID : + hrtc->MspInitCallback = pCallback; + break; + + case HAL_RTC_MSPDEINIT_CB_ID : + hrtc->MspDeInitCallback = pCallback; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_RTC_STATE_RESET == hrtc->State) + { + switch (CallbackID) + { + case HAL_RTC_MSPINIT_CB_ID : + hrtc->MspInitCallback = pCallback; + break; + + case HAL_RTC_MSPDEINIT_CB_ID : + hrtc->MspDeInitCallback = pCallback; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hrtc); + + return status; +} + +/** + * @brief Unregister an RTC Callback + * RTC callabck is redirected to the weak predefined callback + * @param hrtc RTC handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_RTC_ALARM_A_EVENT_CB_ID Alarm A Event Callback ID + * @arg @ref HAL_RTC_TIMESTAMP_EVENT_CB_ID TimeStamp Event Callback ID + * @arg @ref HAL_RTC_WAKEUPTIMER_EVENT_CB_ID WakeUp Timer Event Callback ID + * @arg @ref HAL_RTC_TAMPER1_EVENT_CB_ID Tamper 1 Callback ID + * @arg @ref HAL_RTC_TAMPER2_EVENT_CB_ID Tamper 2 Callback ID + * @arg @ref HAL_RTC_TAMPER3_EVENT_CB_ID Tamper 3 Callback ID + * @arg @ref HAL_RTC_MSPINIT_CB_ID Msp Init callback ID + * @arg @ref HAL_RTC_MSPDEINIT_CB_ID Msp DeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_UnRegisterCallback(RTC_HandleTypeDef *hrtc, HAL_RTC_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hrtc); + + if (HAL_RTC_STATE_READY == hrtc->State) + { + switch (CallbackID) + { + case HAL_RTC_ALARM_A_EVENT_CB_ID : + hrtc->AlarmAEventCallback = HAL_RTC_AlarmAEventCallback; /* Legacy weak AlarmAEventCallback */ + break; + + case HAL_RTC_TIMESTAMP_EVENT_CB_ID : + hrtc->TimeStampEventCallback = HAL_RTCEx_TimeStampEventCallback; /* Legacy weak TimeStampEventCallback */ + break; +#if defined(RTC_WAKEUP_SUPPORT) + case HAL_RTC_WAKEUPTIMER_EVENT_CB_ID : + hrtc->WakeUpTimerEventCallback = HAL_RTCEx_WakeUpTimerEventCallback; /* Legacy weak WakeUpTimerEventCallback */ + break; +#endif /* RTC_WAKEUP_SUPPORT */ + case HAL_RTC_TAMPER1_EVENT_CB_ID : + hrtc->Tamper1EventCallback = HAL_RTCEx_Tamper1EventCallback; /* Legacy weak Tamper1EventCallback */ + break; + + case HAL_RTC_TAMPER2_EVENT_CB_ID : + hrtc->Tamper2EventCallback = HAL_RTCEx_Tamper2EventCallback; /* Legacy weak Tamper2EventCallback */ + break; +#if defined( RTC_TAMPER3_SUPPORT) + case HAL_RTC_TAMPER3_EVENT_CB_ID : + hrtc->Tamper3EventCallback = HAL_RTCEx_Tamper3EventCallback; /* Legacy weak Tamper3EventCallback */ + break; +#endif /* RTC_TAMPER3_SUPPORT */ + case HAL_RTC_MSPINIT_CB_ID : + hrtc->MspInitCallback = HAL_RTC_MspInit; + break; + + case HAL_RTC_MSPDEINIT_CB_ID : + hrtc->MspDeInitCallback = HAL_RTC_MspDeInit; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_RTC_STATE_RESET == hrtc->State) + { + switch (CallbackID) + { + case HAL_RTC_MSPINIT_CB_ID : + hrtc->MspInitCallback = HAL_RTC_MspInit; + break; + + case HAL_RTC_MSPDEINIT_CB_ID : + hrtc->MspDeInitCallback = HAL_RTC_MspDeInit; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hrtc); + + return status; +} +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + +/** + * @brief Initialize the RTC MSP. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTC_MspInit(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTC_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitialize the RTC MSP. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTC_MspDeInit(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTC_MspDeInit could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @addtogroup RTC_Exported_Functions_Group2 + * @brief RTC Time and Date functions + * +@verbatim + =============================================================================== + ##### RTC Time and Date functions ##### + =============================================================================== + + [..] This section provides functions allowing to configure Time and Date features + +@endverbatim + * @{ + */ + +/** + * @brief Set RTC current time. + * @param hrtc RTC handle + * @param sTime Pointer to Time structure + * @note DayLightSaving and StoreOperation interfaces are deprecated. + * To manage Daylight Saving Time, please use HAL_RTC_DST_xxx functions. + * @param Format Specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN: Binary data format + * @arg RTC_FORMAT_BCD: BCD data format + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_SetTime(RTC_HandleTypeDef *hrtc, RTC_TimeTypeDef *sTime, uint32_t Format) +{ + uint32_t tmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + assert_param(IS_RTC_DAYLIGHT_SAVING(sTime->DayLightSaving)); + assert_param(IS_RTC_STORE_OPERATION(sTime->StoreOperation)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + if (Format == RTC_FORMAT_BIN) + { + if ((hrtc->Instance->CR & RTC_CR_FMT) != (uint32_t)RESET) + { + assert_param(IS_RTC_HOUR12(sTime->Hours)); + assert_param(IS_RTC_HOURFORMAT12(sTime->TimeFormat)); + } + else + { + sTime->TimeFormat = 0x00U; + assert_param(IS_RTC_HOUR24(sTime->Hours)); + } + assert_param(IS_RTC_MINUTES(sTime->Minutes)); + assert_param(IS_RTC_SECONDS(sTime->Seconds)); + + tmpreg = (uint32_t)(((uint32_t)RTC_ByteToBcd2(sTime->Hours) << 16U) | \ + ((uint32_t)RTC_ByteToBcd2(sTime->Minutes) << 8U) | \ + ((uint32_t)RTC_ByteToBcd2(sTime->Seconds)) | \ + (((uint32_t)sTime->TimeFormat) << 16U)); + } + else + { + if ((hrtc->Instance->CR & RTC_CR_FMT) != (uint32_t)RESET) + { + assert_param(IS_RTC_HOUR12(RTC_Bcd2ToByte(sTime->Hours))); + assert_param(IS_RTC_HOURFORMAT12(sTime->TimeFormat)); + } + else + { + sTime->TimeFormat = 0x00U; + assert_param(IS_RTC_HOUR24(RTC_Bcd2ToByte(sTime->Hours))); + } + assert_param(IS_RTC_MINUTES(RTC_Bcd2ToByte(sTime->Minutes))); + assert_param(IS_RTC_SECONDS(RTC_Bcd2ToByte(sTime->Seconds))); + tmpreg = (((uint32_t)(sTime->Hours) << 16U) | \ + ((uint32_t)(sTime->Minutes) << 8U) | \ + ((uint32_t)sTime->Seconds) | \ + ((uint32_t)(sTime->TimeFormat) << 16U)); + } + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set Initialization mode */ + if (RTC_EnterInitMode(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state */ + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + else + { + /* Set the RTC_TR register */ + hrtc->Instance->TR = (uint32_t)(tmpreg & RTC_TR_RESERVED_MASK); + + /* Clear the bits to be configured (Deprecated. Use HAL_RTC_DST_xxx functions instead) */ + hrtc->Instance->CR &= ((uint32_t)~RTC_CR_BKP); + + /* Configure the RTC_CR register (Deprecated. Use HAL_RTC_DST_xxx functions instead) */ + hrtc->Instance->CR |= (uint32_t)(sTime->DayLightSaving | sTime->StoreOperation); + + /* Exit Initialization mode */ + hrtc->Instance->ISR &= ((uint32_t)~RTC_ISR_INIT); + + /* If CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */ + if ((hrtc->Instance->CR & RTC_CR_BYPSHAD) == RESET) + { + if (HAL_RTC_WaitForSynchro(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + } + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + __HAL_UNLOCK(hrtc); + + return HAL_OK; + } +} + +/** + * @brief Get RTC current time. + * @param hrtc RTC handle + * @param sTime Pointer to Time structure with Hours, Minutes and Seconds fields returned + * with input format (BIN or BCD), also SubSeconds field returning the + * RTC_SSR register content and SecondFraction field the Synchronous pre-scaler + * factor to be used for second fraction ratio computation. + * @param Format Specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN: Binary data format + * @arg RTC_FORMAT_BCD: BCD data format + * @note You can use SubSeconds and SecondFraction (sTime structure fields returned) to convert SubSeconds + * value in second fraction ratio with time unit following generic formula: + * Second fraction ratio * time_unit= [(SecondFraction-SubSeconds)/(SecondFraction+1)] * time_unit + * This conversion can be performed only if no shift operation is pending (ie. SHFP=0) when PREDIV_S >= SS + * @note You must call HAL_RTC_GetDate() after HAL_RTC_GetTime() to unlock the values + * in the higher-order calendar shadow registers to ensure consistency between the time and date values. + * Reading RTC current time locks the values in calendar shadow registers until Current date is read + * to ensure consistency between the time and date values. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_GetTime(RTC_HandleTypeDef *hrtc, RTC_TimeTypeDef *sTime, uint32_t Format) +{ + uint32_t tmpreg = 0; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + + /* Get subseconds structure field from the corresponding register*/ + sTime->SubSeconds = (uint32_t)(hrtc->Instance->SSR); + + /* Get SecondFraction structure field from the corresponding register field*/ + sTime->SecondFraction = (uint32_t)(hrtc->Instance->PRER & RTC_PRER_PREDIV_S); + + /* Get the TR register */ + tmpreg = (uint32_t)(hrtc->Instance->TR & RTC_TR_RESERVED_MASK); + + /* Fill the structure fields with the read parameters */ + sTime->Hours = (uint8_t)((tmpreg & (RTC_TR_HT | RTC_TR_HU)) >> 16U); + sTime->Minutes = (uint8_t)((tmpreg & (RTC_TR_MNT | RTC_TR_MNU)) >> 8U); + sTime->Seconds = (uint8_t)(tmpreg & (RTC_TR_ST | RTC_TR_SU)); + sTime->TimeFormat = (uint8_t)((tmpreg & (RTC_TR_PM)) >> 16U); + + /* Check the input parameters format */ + if (Format == RTC_FORMAT_BIN) + { + /* Convert the time structure parameters to Binary format */ + sTime->Hours = (uint8_t)RTC_Bcd2ToByte(sTime->Hours); + sTime->Minutes = (uint8_t)RTC_Bcd2ToByte(sTime->Minutes); + sTime->Seconds = (uint8_t)RTC_Bcd2ToByte(sTime->Seconds); + } + + return HAL_OK; +} + +/** + * @brief Set RTC current date. + * @param hrtc RTC handle + * @param sDate Pointer to date structure + * @param Format specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN: Binary data format + * @arg RTC_FORMAT_BCD: BCD data format + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_SetDate(RTC_HandleTypeDef *hrtc, RTC_DateTypeDef *sDate, uint32_t Format) +{ + uint32_t datetmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + if ((Format == RTC_FORMAT_BIN) && ((sDate->Month & 0x10U) == 0x10U)) + { + sDate->Month = (uint8_t)((sDate->Month & (uint8_t)~(0x10U)) + (uint8_t)0x0AU); + } + + assert_param(IS_RTC_WEEKDAY(sDate->WeekDay)); + + if (Format == RTC_FORMAT_BIN) + { + assert_param(IS_RTC_YEAR(sDate->Year)); + assert_param(IS_RTC_MONTH(sDate->Month)); + assert_param(IS_RTC_DATE(sDate->Date)); + + datetmpreg = (((uint32_t)RTC_ByteToBcd2(sDate->Year) << 16U) | \ + ((uint32_t)RTC_ByteToBcd2(sDate->Month) << 8U) | \ + ((uint32_t)RTC_ByteToBcd2(sDate->Date)) | \ + ((uint32_t)sDate->WeekDay << 13U)); + } + else + { + assert_param(IS_RTC_YEAR(RTC_Bcd2ToByte(sDate->Year))); + assert_param(IS_RTC_MONTH(RTC_Bcd2ToByte(sDate->Month))); + assert_param(IS_RTC_DATE(RTC_Bcd2ToByte(sDate->Date))); + + datetmpreg = ((((uint32_t)sDate->Year) << 16U) | \ + (((uint32_t)sDate->Month) << 8U) | \ + ((uint32_t)sDate->Date) | \ + (((uint32_t)sDate->WeekDay) << 13U)); + } + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set Initialization mode */ + if (RTC_EnterInitMode(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state*/ + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + else + { + /* Set the RTC_DR register */ + hrtc->Instance->DR = (uint32_t)(datetmpreg & RTC_DR_RESERVED_MASK); + + /* Exit Initialization mode */ + hrtc->Instance->ISR &= ((uint32_t)~RTC_ISR_INIT); + + /* If CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */ + if ((hrtc->Instance->CR & RTC_CR_BYPSHAD) == RESET) + { + if (HAL_RTC_WaitForSynchro(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + } + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY ; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; + } +} + +/** + * @brief Get RTC current date. + * @param hrtc RTC handle + * @param sDate Pointer to Date structure + * @param Format Specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN : Binary data format + * @arg RTC_FORMAT_BCD : BCD data format + * @note You must call HAL_RTC_GetDate() after HAL_RTC_GetTime() to unlock the values + * in the higher-order calendar shadow registers to ensure consistency between the time and date values. + * Reading RTC current time locks the values in calendar shadow registers until Current date is read. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_GetDate(RTC_HandleTypeDef *hrtc, RTC_DateTypeDef *sDate, uint32_t Format) +{ + uint32_t datetmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + + /* Get the DR register */ + datetmpreg = (uint32_t)(hrtc->Instance->DR & RTC_DR_RESERVED_MASK); + + /* Fill the structure fields with the read parameters */ + sDate->Year = (uint8_t)((datetmpreg & (RTC_DR_YT | RTC_DR_YU)) >> 16U); + sDate->Month = (uint8_t)((datetmpreg & (RTC_DR_MT | RTC_DR_MU)) >> 8U); + sDate->Date = (uint8_t)(datetmpreg & (RTC_DR_DT | RTC_DR_DU)); + sDate->WeekDay = (uint8_t)((datetmpreg & (RTC_DR_WDU)) >> 13U); + + /* Check the input parameters format */ + if (Format == RTC_FORMAT_BIN) + { + /* Convert the date structure parameters to Binary format */ + sDate->Year = (uint8_t)RTC_Bcd2ToByte(sDate->Year); + sDate->Month = (uint8_t)RTC_Bcd2ToByte(sDate->Month); + sDate->Date = (uint8_t)RTC_Bcd2ToByte(sDate->Date); + } + return HAL_OK; +} + +/** + * @brief Daylight Saving Time, adda one hour to the calendar in one + * single operation without going through the initialization procedure. + * @param hrtc pointer to a RTC_HandleTypeDef structure that contains + * the configuration information for RTC. + * @retval None + */ +void HAL_RTC_DST_Add1Hour(RTC_HandleTypeDef *hrtc) +{ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + SET_BIT(hrtc->Instance->CR, RTC_CR_ADD1H); + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); +} + +/** + * @brief Daylight Saving Time, subtracts one hour from the calendar in one + * single operation without going through the initialization procedure. + * @param hrtc pointer to a RTC_HandleTypeDef structure that contains + * the configuration information for RTC. + * @retval None + */ +void HAL_RTC_DST_Sub1Hour(RTC_HandleTypeDef *hrtc) +{ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + SET_BIT(hrtc->Instance->CR, RTC_CR_SUB1H); + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); +} + +/** + * @brief Daylight Saving Time, sets the store operation bit. + * @note It can be used by the software in order to memorize the DST status. + * @param hrtc pointer to a RTC_HandleTypeDef structure that contains + * the configuration information for RTC. + * @retval None + */ +void HAL_RTC_DST_SetStoreOperation(RTC_HandleTypeDef *hrtc) +{ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + SET_BIT(hrtc->Instance->CR, RTC_CR_BKP); + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); +} + +/** + * @brief Daylight Saving Time, clears the store operation bit. + * @param hrtc pointer to a RTC_HandleTypeDef structure that contains + * the configuration information for RTC. + * @retval None + */ +void HAL_RTC_DST_ClearStoreOperation(RTC_HandleTypeDef *hrtc) +{ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + CLEAR_BIT(hrtc->Instance->CR, RTC_CR_BKP); + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); +} + +/** + * @brief Daylight Saving Time, reads the store operation bit. + * @param hrtc RTC handle + * @retval operation see RTC_StoreOperation_Definitions + */ +uint32_t HAL_RTC_DST_ReadStoreOperation(RTC_HandleTypeDef *hrtc) +{ + return READ_BIT(hrtc->Instance->CR, RTC_CR_BKP); +} + +/** + * @} + */ + +/** @addtogroup RTC_Exported_Functions_Group3 + * @brief RTC Alarm functions + * +@verbatim + =============================================================================== + ##### RTC Alarm functions ##### + =============================================================================== + + [..] This section provides functions allowing to configure Alarm feature + +@endverbatim + * @{ + */ +/** + * @brief Set the specified RTC Alarm. + * @param hrtc RTC handle + * @param sAlarm Pointer to Alarm structure + * @param Format Specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN: Binary data format + * @arg RTC_FORMAT_BCD: BCD data format + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_SetAlarm(RTC_HandleTypeDef *hrtc, RTC_AlarmTypeDef *sAlarm, uint32_t Format) +{ + uint32_t tickstart = 0U; + uint32_t tmpreg = 0U, subsecondtmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + assert_param(IS_RTC_ALARM(sAlarm->Alarm)); + assert_param(IS_RTC_ALARM_MASK(sAlarm->AlarmMask)); + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_SEL(sAlarm->AlarmDateWeekDaySel)); + assert_param(IS_RTC_ALARM_SUB_SECOND_VALUE(sAlarm->AlarmTime.SubSeconds)); + assert_param(IS_RTC_ALARM_SUB_SECOND_MASK(sAlarm->AlarmSubSecondMask)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + if (Format == RTC_FORMAT_BIN) + { + if ((hrtc->Instance->CR & RTC_CR_FMT) != (uint32_t)RESET) + { + assert_param(IS_RTC_HOUR12(sAlarm->AlarmTime.Hours)); + assert_param(IS_RTC_HOURFORMAT12(sAlarm->AlarmTime.TimeFormat)); + } + else + { + sAlarm->AlarmTime.TimeFormat = 0x00U; + assert_param(IS_RTC_HOUR24(sAlarm->AlarmTime.Hours)); + } + assert_param(IS_RTC_MINUTES(sAlarm->AlarmTime.Minutes)); + assert_param(IS_RTC_SECONDS(sAlarm->AlarmTime.Seconds)); + + if (sAlarm->AlarmDateWeekDaySel == RTC_ALARMDATEWEEKDAYSEL_DATE) + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_DATE(sAlarm->AlarmDateWeekDay)); + } + else + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_WEEKDAY(sAlarm->AlarmDateWeekDay)); + } + + tmpreg = (((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmTime.Hours) << 16U) | \ + ((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmTime.Minutes) << 8U) | \ + ((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmTime.Seconds)) | \ + ((uint32_t)(sAlarm->AlarmTime.TimeFormat) << 16U) | \ + ((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmDateWeekDay) << 24U) | \ + ((uint32_t)sAlarm->AlarmDateWeekDaySel) | \ + ((uint32_t)sAlarm->AlarmMask)); + } + else + { + if ((hrtc->Instance->CR & RTC_CR_FMT) != (uint32_t)RESET) + { + assert_param(IS_RTC_HOUR12(RTC_Bcd2ToByte(sAlarm->AlarmTime.Hours))); + assert_param(IS_RTC_HOURFORMAT12(sAlarm->AlarmTime.TimeFormat)); + } + else + { + sAlarm->AlarmTime.TimeFormat = 0x00U; + assert_param(IS_RTC_HOUR24(RTC_Bcd2ToByte(sAlarm->AlarmTime.Hours))); + } + + assert_param(IS_RTC_MINUTES(RTC_Bcd2ToByte(sAlarm->AlarmTime.Minutes))); + assert_param(IS_RTC_SECONDS(RTC_Bcd2ToByte(sAlarm->AlarmTime.Seconds))); + + if (sAlarm->AlarmDateWeekDaySel == RTC_ALARMDATEWEEKDAYSEL_DATE) + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_DATE(RTC_Bcd2ToByte(sAlarm->AlarmDateWeekDay))); + } + else + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_WEEKDAY(RTC_Bcd2ToByte(sAlarm->AlarmDateWeekDay))); + } + + tmpreg = (((uint32_t)(sAlarm->AlarmTime.Hours) << 16U) | \ + ((uint32_t)(sAlarm->AlarmTime.Minutes) << 8U) | \ + ((uint32_t) sAlarm->AlarmTime.Seconds) | \ + ((uint32_t)(sAlarm->AlarmTime.TimeFormat) << 16U) | \ + ((uint32_t)(sAlarm->AlarmDateWeekDay) << 24U) | \ + ((uint32_t)sAlarm->AlarmDateWeekDaySel) | \ + ((uint32_t)sAlarm->AlarmMask)); + } + + /* Configure the Alarm A Sub Second registers */ + subsecondtmpreg = (uint32_t)((uint32_t)(sAlarm->AlarmTime.SubSeconds) | (uint32_t)(sAlarm->AlarmSubSecondMask)); + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Disable the Alarm A interrupt */ + __HAL_RTC_ALARMA_DISABLE(hrtc); + + /* In case of interrupt mode is used, the interrupt source must disabled */ + __HAL_RTC_ALARM_DISABLE_IT(hrtc, RTC_IT_ALRA); + + tickstart = HAL_GetTick(); + /* Wait till RTC ALRAWF flag is set and if Time out is reached exit */ + while (__HAL_RTC_ALARM_GET_FLAG(hrtc, RTC_FLAG_ALRAWF) == RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + + hrtc->Instance->ALRMAR = (uint32_t)tmpreg; + /* Configure the Alarm A Sub Second register */ + hrtc->Instance->ALRMASSR = subsecondtmpreg; + /* Configure the Alarm state: Enable Alarm */ + __HAL_RTC_ALARMA_ENABLE(hrtc); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Set the specified RTC Alarm with Interrupt. + * @param hrtc RTC handle + * @param sAlarm Pointer to Alarm structure + * @param Format Specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN: Binary data format + * @arg RTC_FORMAT_BCD: BCD data format + * @note The Alarm register can only be written when the corresponding Alarm + * is disabled (Use the HAL_RTC_DeactivateAlarm()). + * @note The HAL_RTC_SetTime() must be called before enabling the Alarm feature. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_SetAlarm_IT(RTC_HandleTypeDef *hrtc, RTC_AlarmTypeDef *sAlarm, uint32_t Format) +{ + uint32_t tickstart = 0U; + uint32_t tmpreg = 0U, subsecondtmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + assert_param(IS_RTC_ALARM(sAlarm->Alarm)); + assert_param(IS_RTC_ALARM_MASK(sAlarm->AlarmMask)); + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_SEL(sAlarm->AlarmDateWeekDaySel)); + assert_param(IS_RTC_ALARM_SUB_SECOND_VALUE(sAlarm->AlarmTime.SubSeconds)); + assert_param(IS_RTC_ALARM_SUB_SECOND_MASK(sAlarm->AlarmSubSecondMask)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + if (Format == RTC_FORMAT_BIN) + { + if ((hrtc->Instance->CR & RTC_CR_FMT) != (uint32_t)RESET) + { + assert_param(IS_RTC_HOUR12(sAlarm->AlarmTime.Hours)); + assert_param(IS_RTC_HOURFORMAT12(sAlarm->AlarmTime.TimeFormat)); + } + else + { + sAlarm->AlarmTime.TimeFormat = 0x00U; + assert_param(IS_RTC_HOUR24(sAlarm->AlarmTime.Hours)); + } + assert_param(IS_RTC_MINUTES(sAlarm->AlarmTime.Minutes)); + assert_param(IS_RTC_SECONDS(sAlarm->AlarmTime.Seconds)); + + if (sAlarm->AlarmDateWeekDaySel == RTC_ALARMDATEWEEKDAYSEL_DATE) + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_DATE(sAlarm->AlarmDateWeekDay)); + } + else + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_WEEKDAY(sAlarm->AlarmDateWeekDay)); + } + tmpreg = (((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmTime.Hours) << 16U) | \ + ((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmTime.Minutes) << 8U) | \ + ((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmTime.Seconds)) | \ + ((uint32_t)(sAlarm->AlarmTime.TimeFormat) << 16U) | \ + ((uint32_t)RTC_ByteToBcd2(sAlarm->AlarmDateWeekDay) << 24U) | \ + ((uint32_t)sAlarm->AlarmDateWeekDaySel) | \ + ((uint32_t)sAlarm->AlarmMask)); + } + else + { + if ((hrtc->Instance->CR & RTC_CR_FMT) != (uint32_t)RESET) + { + assert_param(IS_RTC_HOUR12(RTC_Bcd2ToByte(sAlarm->AlarmTime.Hours))); + assert_param(IS_RTC_HOURFORMAT12(sAlarm->AlarmTime.TimeFormat)); + } + else + { + sAlarm->AlarmTime.TimeFormat = 0x00U; + assert_param(IS_RTC_HOUR24(RTC_Bcd2ToByte(sAlarm->AlarmTime.Hours))); + } + + assert_param(IS_RTC_MINUTES(RTC_Bcd2ToByte(sAlarm->AlarmTime.Minutes))); + assert_param(IS_RTC_SECONDS(RTC_Bcd2ToByte(sAlarm->AlarmTime.Seconds))); + + if (sAlarm->AlarmDateWeekDaySel == RTC_ALARMDATEWEEKDAYSEL_DATE) + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_DATE(RTC_Bcd2ToByte(sAlarm->AlarmDateWeekDay))); + } + else + { + assert_param(IS_RTC_ALARM_DATE_WEEKDAY_WEEKDAY(RTC_Bcd2ToByte(sAlarm->AlarmDateWeekDay))); + } + tmpreg = (((uint32_t)(sAlarm->AlarmTime.Hours) << 16U) | \ + ((uint32_t)(sAlarm->AlarmTime.Minutes) << 8U) | \ + ((uint32_t) sAlarm->AlarmTime.Seconds) | \ + ((uint32_t)(sAlarm->AlarmTime.TimeFormat) << 16U) | \ + ((uint32_t)(sAlarm->AlarmDateWeekDay) << 24U) | \ + ((uint32_t)sAlarm->AlarmDateWeekDaySel) | \ + ((uint32_t)sAlarm->AlarmMask)); + } + /* Configure the Alarm A Sub Second registers */ + subsecondtmpreg = (uint32_t)((uint32_t)(sAlarm->AlarmTime.SubSeconds) | (uint32_t)(sAlarm->AlarmSubSecondMask)); + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Disable the Alarm A interrupt */ + __HAL_RTC_ALARMA_DISABLE(hrtc); + + /* Clear flag alarm A */ + __HAL_RTC_ALARM_CLEAR_FLAG(hrtc, RTC_FLAG_ALRAF); + + tickstart = HAL_GetTick(); + + /* Wait till RTC ALRAWF flag is set and if Time out is reached exit */ + while (__HAL_RTC_ALARM_GET_FLAG(hrtc, RTC_FLAG_ALRAWF) == RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + + hrtc->Instance->ALRMAR = (uint32_t)tmpreg; + /* Configure the Alarm A Sub Second register */ + hrtc->Instance->ALRMASSR = subsecondtmpreg; + /* Configure the Alarm state: Enable Alarm */ + __HAL_RTC_ALARMA_ENABLE(hrtc); + /* Configure the Alarm interrupt */ + __HAL_RTC_ALARM_ENABLE_IT(hrtc, RTC_IT_ALRA); + + /* RTC Alarm Interrupt Configuration: EXTI configuration */ + __HAL_RTC_ALARM_EXTI_ENABLE_IT(); + + __HAL_RTC_ALARM_EXTI_ENABLE_RISING_EDGE(); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Deactivate the specified RTC Alarm. + * @param hrtc RTC handle + * @param Alarm Specifies the Alarm. + * This parameter can be one of the following values: + * @arg RTC_ALARM_A: AlarmA + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_DeactivateAlarm(RTC_HandleTypeDef *hrtc, uint32_t Alarm) +{ + uint32_t tickstart = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_ALARM(Alarm)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + __HAL_RTC_ALARMA_DISABLE(hrtc); + + /* In case of interrupt mode is used, the interrupt source must disabled */ + __HAL_RTC_ALARM_DISABLE_IT(hrtc, RTC_IT_ALRA); + + tickstart = HAL_GetTick(); + + /* Wait till RTC ALRxWF flag is set and if Time out is reached exit */ + while (__HAL_RTC_ALARM_GET_FLAG(hrtc, RTC_FLAG_ALRAWF) == RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Get the RTC Alarm value and masks. + * @param hrtc RTC handle + * @param sAlarm Pointer to Date structure + * @param Alarm Specifies the Alarm. + * This parameter can be one of the following values: + * @arg RTC_ALARM_A: AlarmA + * @param Format Specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN: Binary data format + * @arg RTC_FORMAT_BCD: BCD data format + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_GetAlarm(RTC_HandleTypeDef *hrtc, RTC_AlarmTypeDef *sAlarm, uint32_t Alarm, uint32_t Format) +{ + uint32_t tmpreg = 0U, subsecondtmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + assert_param(IS_RTC_ALARM(Alarm)); + + sAlarm->Alarm = RTC_ALARM_A; + + tmpreg = (uint32_t)(hrtc->Instance->ALRMAR); + subsecondtmpreg = (uint32_t)((hrtc->Instance->ALRMASSR) & RTC_ALRMASSR_SS); + + /* Fill the structure with the read parameters */ + sAlarm->AlarmTime.Hours = (uint32_t)((tmpreg & (RTC_ALRMAR_HT | RTC_ALRMAR_HU)) >> 16U); + sAlarm->AlarmTime.Minutes = (uint32_t)((tmpreg & (RTC_ALRMAR_MNT | RTC_ALRMAR_MNU)) >> 8U); + sAlarm->AlarmTime.Seconds = (uint32_t)(tmpreg & (RTC_ALRMAR_ST | RTC_ALRMAR_SU)); + sAlarm->AlarmTime.TimeFormat = (uint32_t)((tmpreg & RTC_ALRMAR_PM) >> 16U); + sAlarm->AlarmTime.SubSeconds = (uint32_t) subsecondtmpreg; + sAlarm->AlarmDateWeekDay = (uint32_t)((tmpreg & (RTC_ALRMAR_DT | RTC_ALRMAR_DU)) >> 24U); + sAlarm->AlarmDateWeekDaySel = (uint32_t)(tmpreg & RTC_ALRMAR_WDSEL); + sAlarm->AlarmMask = (uint32_t)(tmpreg & RTC_ALARMMASK_ALL); + + if (Format == RTC_FORMAT_BIN) + { + sAlarm->AlarmTime.Hours = RTC_Bcd2ToByte(sAlarm->AlarmTime.Hours); + sAlarm->AlarmTime.Minutes = RTC_Bcd2ToByte(sAlarm->AlarmTime.Minutes); + sAlarm->AlarmTime.Seconds = RTC_Bcd2ToByte(sAlarm->AlarmTime.Seconds); + sAlarm->AlarmDateWeekDay = RTC_Bcd2ToByte(sAlarm->AlarmDateWeekDay); + } + + return HAL_OK; +} + +/** + * @brief Handle Alarm interrupt request. + * @param hrtc RTC handle + * @retval None + */ +void HAL_RTC_AlarmIRQHandler(RTC_HandleTypeDef *hrtc) +{ + /* Get the AlarmA interrupt source enable status */ + if (__HAL_RTC_ALARM_GET_IT_SOURCE(hrtc, RTC_IT_ALRA) != RESET) + { + /* Get the pending status of the AlarmA Interrupt */ + if (__HAL_RTC_ALARM_GET_FLAG(hrtc, RTC_FLAG_ALRAF) != RESET) + { + /* AlarmA callback */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + hrtc->AlarmAEventCallback(hrtc); +#else + HAL_RTC_AlarmAEventCallback(hrtc); +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + + /* Clear the AlarmA interrupt pending bit */ + __HAL_RTC_ALARM_CLEAR_FLAG(hrtc, RTC_FLAG_ALRAF); + } + } + + /* Clear the EXTI's line Flag for RTC Alarm */ + __HAL_RTC_ALARM_EXTI_CLEAR_FLAG(); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; +} + +/** + * @brief Alarm A callback. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTC_AlarmAEventCallback(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTC_AlarmAEventCallback could be implemented in the user file + */ +} + +/** + * @brief Handle AlarmA Polling request. + * @param hrtc RTC handle + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_PollForAlarmAEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout) +{ + + uint32_t tickstart = HAL_GetTick(); + + while (__HAL_RTC_ALARM_GET_FLAG(hrtc, RTC_FLAG_ALRAF) == RESET) + { + if (Timeout != HAL_MAX_DELAY) + { + if ((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + hrtc->State = HAL_RTC_STATE_TIMEOUT; + return HAL_TIMEOUT; + } + } + } + + /* Clear the Alarm interrupt pending bit */ + __HAL_RTC_ALARM_CLEAR_FLAG(hrtc, RTC_FLAG_ALRAF); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + return HAL_OK; +} + +/** + * @} + */ + +/** @addtogroup RTC_Exported_Functions_Group4 + * @brief Peripheral Control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides functions allowing to + (+) Wait for RTC Time and Date Synchronization + +@endverbatim + * @{ + */ + +/** + * @brief Wait until the RTC Time and Date registers (RTC_TR and RTC_DR) are + * synchronized with RTC APB clock. + * @note The RTC Resynchronization mode is write protected, use the + * __HAL_RTC_WRITEPROTECTION_DISABLE() before calling this function. + * @note To read the calendar through the shadow registers after Calendar + * initialization, calendar update or after wakeup from low power modes + * the software must first clear the RSF flag. + * The software must then wait until it is set again before reading + * the calendar, which means that the calendar registers have been + * correctly copied into the RTC_TR and RTC_DR shadow registers. + * @param hrtc RTC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTC_WaitForSynchro(RTC_HandleTypeDef *hrtc) +{ + uint32_t tickstart = 0U; + + /* Clear RSF flag */ + hrtc->Instance->ISR &= (uint32_t)RTC_RSF_MASK; + + tickstart = HAL_GetTick(); + + /* Wait the registers to be synchronised */ + while ((hrtc->Instance->ISR & RTC_ISR_RSF) == (uint32_t)RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + + return HAL_OK; +} + +/** + * @} + */ + +/** @addtogroup RTC_Exported_Functions_Group5 + * @brief Peripheral State functions + * +@verbatim + =============================================================================== + ##### Peripheral State functions ##### + =============================================================================== + [..] + This subsection provides functions allowing to + (+) Get RTC state + +@endverbatim + * @{ + */ +/** + * @brief Return the RTC handle state. + * @param hrtc RTC handle + * @retval HAL state + */ +HAL_RTCStateTypeDef HAL_RTC_GetState(RTC_HandleTypeDef *hrtc) +{ + /* Return RTC handle state */ + return hrtc->State; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup RTC_Private_Functions + * @{ + */ +/** + * @brief Enter the RTC Initialization mode. + * @note The RTC Initialization mode is write protected, use the + * __HAL_RTC_WRITEPROTECTION_DISABLE() before calling this function. + * @param hrtc RTC handle + * @retval HAL status + */ +HAL_StatusTypeDef RTC_EnterInitMode(RTC_HandleTypeDef *hrtc) +{ + uint32_t tickstart = 0U; + + /* Check if the Initialization mode is set */ + if ((hrtc->Instance->ISR & RTC_ISR_INITF) == (uint32_t)RESET) + { + /* Set the Initialization mode */ + hrtc->Instance->ISR = (uint32_t)RTC_INIT_MASK; + + tickstart = HAL_GetTick(); + + /* Wait till RTC is in INIT state and if Time out is reached exit */ + while ((hrtc->Instance->ISR & RTC_ISR_INITF) == (uint32_t)RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + return HAL_TIMEOUT; + } + } + } + + return HAL_OK; +} + + +/** + * @brief Convert a 2 digit decimal to BCD format. + * @param Value Byte to be converted + * @retval Converted byte + */ +uint8_t RTC_ByteToBcd2(uint8_t Value) +{ + uint32_t bcdhigh = 0U; + + while (Value >= 10U) + { + bcdhigh++; + Value -= 10U; + } + + return ((uint8_t)(bcdhigh << 4U) | Value); +} + +/** + * @brief Convert from 2 digit BCD to Binary. + * @param Value BCD value to be converted + * @retval Converted word + */ +uint8_t RTC_Bcd2ToByte(uint8_t Value) +{ + uint32_t tmp = 0U; + tmp = ((uint8_t)(Value & (uint8_t)0xF0U) >> (uint8_t)0x4U) * 10U; + return (tmp + (Value & (uint8_t)0x0FU)); +} +/** + * @} + */ + +#endif /* HAL_RTC_MODULE_ENABLED */ + +/** + * @} + */ + + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc_ex.c new file mode 100644 index 0000000..59888c1 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_rtc_ex.c @@ -0,0 +1,1600 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_rtc_ex.c + * @author MCD Application Team + * @brief Extended RTC HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Real Time Clock (RTC) Extended peripheral: + * + RTC Time Stamp functions + * + RTC Tamper functions + * + RTC Wake-up functions + * + Extended Control functions + * + Extended RTC features functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + (+) Enable the RTC domain access. + (+) Configure the RTC Prescaler (Asynchronous and Synchronous) and RTC hour + format using the HAL_RTC_Init() function. + + *** RTC Wake-up configuration *** + ================================ + [..] + (+) To configure the RTC Wakeup Clock source and Counter use the HAL_RTCEx_SetWakeUpTimer() + function. You can also configure the RTC Wakeup timer with interrupt mode + using the HAL_RTCEx_SetWakeUpTimer_IT() function. + (+) To read the RTC WakeUp Counter register, use the HAL_RTCEx_GetWakeUpTimer() + function. + (@) Not available on F030x4/x6/x8 and F070x6 + + *** TimeStamp configuration *** + =============================== + [..] + (+) Configure the RTC_AF trigger and enable the RTC TimeStamp using the + HAL_RTCEx_SetTimeStamp() function. You can also configure the RTC TimeStamp with + interrupt mode using the HAL_RTCEx_SetTimeStamp_IT() function. + (+) To read the RTC TimeStamp Time and Date register, use the HAL_RTCEx_GetTimeStamp() + function. + + *** Tamper configuration *** + ============================ + [..] + (+) Enable the RTC Tamper and configure the Tamper filter count, trigger Edge + or Level according to the Tamper filter (if equal to 0 Edge else Level) + value, sampling frequency, precharge or discharge and Pull-UP using the + HAL_RTCEx_SetTamper() function. You can configure RTC Tamper in interrupt + mode using HAL_RTCEx_SetTamper_IT() function. + + *** Backup Data Registers configuration *** + =========================================== + [..] + (+) To write to the RTC Backup Data registers, use the HAL_RTCEx_BKUPWrite() + function. + (+) To read the RTC Backup Data registers, use the HAL_RTCEx_BKUPRead() + function. + (@) Not available on F030x6/x8/xC and F070x6/xB (F0xx Value Line devices) + + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + + + +/** @addtogroup RTCEx + * @brief RTC Extended HAL module driver + * @{ + */ + +#ifdef HAL_RTC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions ---------------------------------------------------------*/ + +/** @addtogroup RTCEx_Exported_Functions + * @{ + */ + + +/** @addtogroup RTCEx_Exported_Functions_Group1 + * @brief RTC TimeStamp and Tamper functions + * +@verbatim + =============================================================================== + ##### RTC TimeStamp and Tamper functions ##### + =============================================================================== + + [..] This section provides functions allowing to configure TimeStamp feature + +@endverbatim + * @{ + */ + +/** + * @brief Set TimeStamp. + * @note This API must be called before enabling the TimeStamp feature. + * @param hrtc RTC handle + * @param TimeStampEdge Specifies the pin edge on which the TimeStamp is + * activated. + * This parameter can be one of the following values: + * @arg RTC_TIMESTAMPEDGE_RISING: the Time stamp event occurs on the + * rising edge of the related pin. + * @arg RTC_TIMESTAMPEDGE_FALLING: the Time stamp event occurs on the + * falling edge of the related pin. + * @param RTC_TimeStampPin specifies the RTC TimeStamp Pin. + * This parameter can be one of the following values: + * @arg RTC_TIMESTAMPPIN_DEFAULT: PC13 is selected as RTC TimeStamp Pin. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetTimeStamp(RTC_HandleTypeDef *hrtc, uint32_t TimeStampEdge, uint32_t RTC_TimeStampPin) +{ + uint32_t tmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_TIMESTAMP_EDGE(TimeStampEdge)); + assert_param(IS_RTC_TIMESTAMP_PIN(RTC_TimeStampPin)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Get the RTC_CR register and clear the bits to be configured */ + tmpreg = (uint32_t)(hrtc->Instance->CR & (uint32_t)~(RTC_CR_TSEDGE | RTC_CR_TSE)); + + tmpreg |= TimeStampEdge; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Configure the Time Stamp TSEDGE and Enable bits */ + hrtc->Instance->CR = (uint32_t)tmpreg; + + __HAL_RTC_TIMESTAMP_ENABLE(hrtc); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Set TimeStamp with Interrupt. + * @param hrtc RTC handle + * @note This API must be called before enabling the TimeStamp feature. + * @param TimeStampEdge Specifies the pin edge on which the TimeStamp is + * activated. + * This parameter can be one of the following values: + * @arg RTC_TIMESTAMPEDGE_RISING: the Time stamp event occurs on the + * rising edge of the related pin. + * @arg RTC_TIMESTAMPEDGE_FALLING: the Time stamp event occurs on the + * falling edge of the related pin. + * @param RTC_TimeStampPin Specifies the RTC TimeStamp Pin. + * This parameter can be one of the following values: + * @arg RTC_TIMESTAMPPIN_DEFAULT: PC13 is selected as RTC TimeStamp Pin. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetTimeStamp_IT(RTC_HandleTypeDef *hrtc, uint32_t TimeStampEdge, uint32_t RTC_TimeStampPin) +{ + uint32_t tmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_TIMESTAMP_EDGE(TimeStampEdge)); + assert_param(IS_RTC_TIMESTAMP_PIN(RTC_TimeStampPin)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Get the RTC_CR register and clear the bits to be configured */ + tmpreg = (uint32_t)(hrtc->Instance->CR & (uint32_t)~(RTC_CR_TSEDGE | RTC_CR_TSE)); + + tmpreg |= TimeStampEdge; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Configure the Time Stamp TSEDGE and Enable bits */ + hrtc->Instance->CR = (uint32_t)tmpreg; + + __HAL_RTC_TIMESTAMP_ENABLE(hrtc); + + /* Enable IT timestamp */ + __HAL_RTC_TIMESTAMP_ENABLE_IT(hrtc, RTC_IT_TS); + + /* RTC timestamp Interrupt Configuration: EXTI configuration */ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_IT(); + + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_EDGE(); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Deactivate TimeStamp. + * @param hrtc RTC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_DeactivateTimeStamp(RTC_HandleTypeDef *hrtc) +{ + uint32_t tmpreg = 0U; + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* In case of interrupt mode is used, the interrupt source must disabled */ + __HAL_RTC_TIMESTAMP_DISABLE_IT(hrtc, RTC_IT_TS); + + /* Get the RTC_CR register and clear the bits to be configured */ + tmpreg = (uint32_t)(hrtc->Instance->CR & (uint32_t)~(RTC_CR_TSEDGE | RTC_CR_TSE)); + + /* Configure the Time Stamp TSEDGE and Enable bits */ + hrtc->Instance->CR = (uint32_t)tmpreg; + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Get the RTC TimeStamp value. + * @param hrtc RTC handle + + * @param sTimeStamp Pointer to Time structure + * @param sTimeStampDate Pointer to Date structure + * @param Format specifies the format of the entered parameters. + * This parameter can be one of the following values: + * @arg RTC_FORMAT_BIN: Binary data format + * @arg RTC_FORMAT_BCD: BCD data format + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_GetTimeStamp(RTC_HandleTypeDef *hrtc, RTC_TimeTypeDef *sTimeStamp, RTC_DateTypeDef *sTimeStampDate, uint32_t Format) +{ + uint32_t tmptime = 0U, tmpdate = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_FORMAT(Format)); + + /* Get the TimeStamp time and date registers values */ + tmptime = (uint32_t)(hrtc->Instance->TSTR & RTC_TR_RESERVED_MASK); + tmpdate = (uint32_t)(hrtc->Instance->TSDR & RTC_DR_RESERVED_MASK); + + /* Fill the Time structure fields with the read parameters */ + sTimeStamp->Hours = (uint8_t)((tmptime & (RTC_TR_HT | RTC_TR_HU)) >> 16U); + sTimeStamp->Minutes = (uint8_t)((tmptime & (RTC_TR_MNT | RTC_TR_MNU)) >> 8U); + sTimeStamp->Seconds = (uint8_t)(tmptime & (RTC_TR_ST | RTC_TR_SU)); + sTimeStamp->TimeFormat = (uint8_t)((tmptime & (RTC_TR_PM)) >> 16U); + sTimeStamp->SubSeconds = (uint32_t) hrtc->Instance->TSSSR; + + /* Fill the Date structure fields with the read parameters */ + sTimeStampDate->Year = 0; + sTimeStampDate->Month = (uint8_t)((tmpdate & (RTC_DR_MT | RTC_DR_MU)) >> 8U); + sTimeStampDate->Date = (uint8_t)(tmpdate & (RTC_DR_DT | RTC_DR_DU)); + sTimeStampDate->WeekDay = (uint8_t)((tmpdate & (RTC_DR_WDU)) >> 13U); + + /* Check the input parameters format */ + if (Format == RTC_FORMAT_BIN) + { + /* Convert the TimeStamp structure parameters to Binary format */ + sTimeStamp->Hours = (uint8_t)RTC_Bcd2ToByte(sTimeStamp->Hours); + sTimeStamp->Minutes = (uint8_t)RTC_Bcd2ToByte(sTimeStamp->Minutes); + sTimeStamp->Seconds = (uint8_t)RTC_Bcd2ToByte(sTimeStamp->Seconds); + + /* Convert the DateTimeStamp structure parameters to Binary format */ + sTimeStampDate->Month = (uint8_t)RTC_Bcd2ToByte(sTimeStampDate->Month); + sTimeStampDate->Date = (uint8_t)RTC_Bcd2ToByte(sTimeStampDate->Date); + sTimeStampDate->WeekDay = (uint8_t)RTC_Bcd2ToByte(sTimeStampDate->WeekDay); + } + + /* Clear the TIMESTAMP Flag */ + __HAL_RTC_TIMESTAMP_CLEAR_FLAG(hrtc, RTC_FLAG_TSF); + + return HAL_OK; +} + +/** + * @brief Set Tamper + * @note By calling this API we disable the tamper interrupt for all tampers. + * @param hrtc RTC handle + * @param sTamper Pointer to Tamper Structure. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetTamper(RTC_HandleTypeDef *hrtc, RTC_TamperTypeDef *sTamper) +{ + uint32_t tmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_TAMPER(sTamper->Tamper)); + assert_param(IS_RTC_TAMPER_TRIGGER(sTamper->Trigger)); + assert_param(IS_RTC_TAMPER_FILTER(sTamper->Filter)); + assert_param(IS_RTC_TAMPER_SAMPLING_FREQ(sTamper->SamplingFrequency)); + assert_param(IS_RTC_TAMPER_PRECHARGE_DURATION(sTamper->PrechargeDuration)); + assert_param(IS_RTC_TAMPER_PULLUP_STATE(sTamper->TamperPullUp)); + assert_param(IS_RTC_TAMPER_TIMESTAMPONTAMPER_DETECTION(sTamper->TimeStampOnTamperDetection)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + if (sTamper->Trigger != RTC_TAMPERTRIGGER_RISINGEDGE) + { + sTamper->Trigger = (uint32_t)(sTamper->Tamper << 1U); + } + + tmpreg = ((uint32_t)sTamper->Tamper | (uint32_t)sTamper->Trigger | (uint32_t)sTamper->Filter | \ + (uint32_t)sTamper->SamplingFrequency | (uint32_t)sTamper->PrechargeDuration | \ + (uint32_t)sTamper->TamperPullUp | sTamper->TimeStampOnTamperDetection); + + hrtc->Instance->TAFCR &= (uint32_t)~((uint32_t)sTamper->Tamper | (uint32_t)(sTamper->Tamper << 1U) | (uint32_t)RTC_TAFCR_TAMPTS | \ + (uint32_t)RTC_TAFCR_TAMPFREQ | (uint32_t)RTC_TAFCR_TAMPFLT | (uint32_t)RTC_TAFCR_TAMPPRCH | \ + (uint32_t)RTC_TAFCR_TAMPPUDIS | (uint32_t)RTC_TAFCR_TAMPIE); + + hrtc->Instance->TAFCR |= tmpreg; + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Sets Tamper with interrupt. + * @note By calling this API we force the tamper interrupt for all tampers. + * @param hrtc pointer to a RTC_HandleTypeDef structure that contains + * the configuration information for RTC. + * @param sTamper Pointer to RTC Tamper. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetTamper_IT(RTC_HandleTypeDef *hrtc, RTC_TamperTypeDef *sTamper) +{ + uint32_t tmpreg = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_TAMPER(sTamper->Tamper)); + assert_param(IS_RTC_TAMPER_TRIGGER(sTamper->Trigger)); + assert_param(IS_RTC_TAMPER_FILTER(sTamper->Filter)); + assert_param(IS_RTC_TAMPER_SAMPLING_FREQ(sTamper->SamplingFrequency)); + assert_param(IS_RTC_TAMPER_PRECHARGE_DURATION(sTamper->PrechargeDuration)); + assert_param(IS_RTC_TAMPER_PULLUP_STATE(sTamper->TamperPullUp)); + assert_param(IS_RTC_TAMPER_TIMESTAMPONTAMPER_DETECTION(sTamper->TimeStampOnTamperDetection)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Configure the tamper trigger */ + if (sTamper->Trigger != RTC_TAMPERTRIGGER_RISINGEDGE) + { + sTamper->Trigger = (uint32_t)(sTamper->Tamper << 1U); + } + + tmpreg = ((uint32_t)sTamper->Tamper | (uint32_t)sTamper->Trigger | (uint32_t)sTamper->Filter | \ + (uint32_t)sTamper->SamplingFrequency | (uint32_t)sTamper->PrechargeDuration | \ + (uint32_t)sTamper->TamperPullUp | sTamper->TimeStampOnTamperDetection); + + hrtc->Instance->TAFCR &= (uint32_t)~((uint32_t)sTamper->Tamper | (uint32_t)(sTamper->Tamper << 1U) | (uint32_t)RTC_TAFCR_TAMPTS | \ + (uint32_t)RTC_TAFCR_TAMPFREQ | (uint32_t)RTC_TAFCR_TAMPFLT | (uint32_t)RTC_TAFCR_TAMPPRCH | \ + (uint32_t)RTC_TAFCR_TAMPPUDIS); + + hrtc->Instance->TAFCR |= tmpreg; + + /* Configure the Tamper Interrupt in the RTC_TAFCR */ + hrtc->Instance->TAFCR |= (uint32_t)RTC_TAFCR_TAMPIE; + + /* RTC Tamper Interrupt Configuration: EXTI configuration */ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_IT(); + + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_RISING_EDGE(); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Deactivate Tamper. + * @param hrtc RTC handle + * @param Tamper Selected tamper pin. + * This parameter can be any combination of RTC_TAMPER_1, RTC_TAMPER_2 and RTC_TAMPER_3. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_DeactivateTamper(RTC_HandleTypeDef *hrtc, uint32_t Tamper) +{ + assert_param(IS_RTC_TAMPER(Tamper)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the selected Tamper pin */ + hrtc->Instance->TAFCR &= (uint32_t)~Tamper; + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Handle TimeStamp interrupt request. + * @param hrtc RTC handle + * @retval None + */ +void HAL_RTCEx_TamperTimeStampIRQHandler(RTC_HandleTypeDef *hrtc) +{ + /* Get the TimeStamp interrupt source enable status */ + if (__HAL_RTC_TIMESTAMP_GET_IT_SOURCE(hrtc, RTC_IT_TS) != RESET) + { + /* Get the pending status of the TIMESTAMP Interrupt */ + if (__HAL_RTC_TIMESTAMP_GET_FLAG(hrtc, RTC_FLAG_TSF) != RESET) + { + /* TIMESTAMP callback */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + hrtc->TimeStampEventCallback(hrtc); +#else + HAL_RTCEx_TimeStampEventCallback(hrtc); +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + + /* Clear the TIMESTAMP interrupt pending bit */ + __HAL_RTC_TIMESTAMP_CLEAR_FLAG(hrtc, RTC_FLAG_TSF); + } + } + + /* Get the Tamper interrupts source enable status */ + if (__HAL_RTC_TAMPER_GET_IT_SOURCE(hrtc, RTC_IT_TAMP)) + { + /* Get the pending status of the Tamper1 Interrupt */ + if (__HAL_RTC_TAMPER_GET_FLAG(hrtc, RTC_FLAG_TAMP1F) != RESET) + { + /* Tamper1 callback */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + hrtc->Tamper1EventCallback(hrtc); +#else + HAL_RTCEx_Tamper1EventCallback(hrtc); +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + + /* Clear the Tamper1 interrupt pending bit */ + __HAL_RTC_TAMPER_CLEAR_FLAG(hrtc, RTC_FLAG_TAMP1F); + } + } + + /* Get the Tamper interrupts source enable status */ + if (__HAL_RTC_TAMPER_GET_IT_SOURCE(hrtc, RTC_IT_TAMP)) + { + /* Get the pending status of the Tamper2 Interrupt */ + if (__HAL_RTC_TAMPER_GET_FLAG(hrtc, RTC_FLAG_TAMP2F) != RESET) + { + /* Tamper2 callback */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + hrtc->Tamper2EventCallback(hrtc); +#else + HAL_RTCEx_Tamper2EventCallback(hrtc); +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + + /* Clear the Tamper2 interrupt pending bit */ + __HAL_RTC_TAMPER_CLEAR_FLAG(hrtc, RTC_FLAG_TAMP2F); + } + } + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) + /* Get the Tamper interrupts source enable status */ + if (__HAL_RTC_TAMPER_GET_IT_SOURCE(hrtc, RTC_IT_TAMP)) + { + /* Get the pending status of the Tamper3 Interrupt */ + if (__HAL_RTC_TAMPER_GET_FLAG(hrtc, RTC_FLAG_TAMP3F) != RESET) + { + /* Tamper3 callback */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + hrtc->Tamper3EventCallback(hrtc); +#else + HAL_RTCEx_Tamper3EventCallback(hrtc); +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + + /* Clear the Tamper3 interrupt pending bit */ + __HAL_RTC_TAMPER_CLEAR_FLAG(hrtc, RTC_FLAG_TAMP3F); + } + } +#endif + + /* Clear the EXTI's Flag for RTC TimeStamp and Tamper */ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_CLEAR_FLAG(); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; +} + +/** + * @brief TimeStamp callback. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTCEx_TimeStampEventCallback(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTCEx_TimeStampEventCallback could be implemented in the user file + */ +} + +/** + * @brief Tamper 1 callback. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTCEx_Tamper1EventCallback(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTCEx_Tamper1EventCallback could be implemented in the user file + */ +} + +/** + * @brief Tamper 2 callback. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTCEx_Tamper2EventCallback(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTCEx_Tamper2EventCallback could be implemented in the user file + */ +} + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) +/** + * @brief Tamper 3 callback. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTCEx_Tamper3EventCallback(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTCEx_Tamper3EventCallback could be implemented in the user file + */ +} +#endif + +/** + * @brief Handle TimeStamp polling request. + * @param hrtc RTC handle + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_PollForTimeStampEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout) +{ + uint32_t tickstart = HAL_GetTick(); + + while (__HAL_RTC_TIMESTAMP_GET_FLAG(hrtc, RTC_FLAG_TSF) == RESET) + { + if (__HAL_RTC_TIMESTAMP_GET_FLAG(hrtc, RTC_FLAG_TSOVF) != RESET) + { + /* Clear the TIMESTAMP OverRun Flag */ + __HAL_RTC_TIMESTAMP_CLEAR_FLAG(hrtc, RTC_FLAG_TSOVF); + + /* Change TIMESTAMP state */ + hrtc->State = HAL_RTC_STATE_ERROR; + + return HAL_ERROR; + } + + if (Timeout != HAL_MAX_DELAY) + { + if ((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + hrtc->State = HAL_RTC_STATE_TIMEOUT; + return HAL_TIMEOUT; + } + } + } + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Handle Tamper 1 Polling. + * @param hrtc RTC handle + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_PollForTamper1Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout) +{ + uint32_t tickstart = HAL_GetTick(); + + /* Get the status of the Interrupt */ + while (__HAL_RTC_TAMPER_GET_FLAG(hrtc, RTC_FLAG_TAMP1F) == RESET) + { + if (Timeout != HAL_MAX_DELAY) + { + if ((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + hrtc->State = HAL_RTC_STATE_TIMEOUT; + return HAL_TIMEOUT; + } + } + } + + /* Clear the Tamper Flag */ + __HAL_RTC_TAMPER_CLEAR_FLAG(hrtc, RTC_FLAG_TAMP1F); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Handle Tamper 2 Polling. + * @param hrtc RTC handle + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_PollForTamper2Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout) +{ + uint32_t tickstart = HAL_GetTick(); + + /* Get the status of the Interrupt */ + while (__HAL_RTC_TAMPER_GET_FLAG(hrtc, RTC_FLAG_TAMP2F) == RESET) + { + if (Timeout != HAL_MAX_DELAY) + { + if ((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + hrtc->State = HAL_RTC_STATE_TIMEOUT; + return HAL_TIMEOUT; + } + } + } + + /* Clear the Tamper Flag */ + __HAL_RTC_TAMPER_CLEAR_FLAG(hrtc, RTC_FLAG_TAMP2F); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + return HAL_OK; +} + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) +/** + * @brief Handle Tamper 3 Polling. + * @param hrtc RTC handle + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_PollForTamper3Event(RTC_HandleTypeDef *hrtc, uint32_t Timeout) +{ + uint32_t tickstart = HAL_GetTick(); + + /* Get the status of the Interrupt */ + while (__HAL_RTC_TAMPER_GET_FLAG(hrtc, RTC_FLAG_TAMP3F) == RESET) + { + if (Timeout != HAL_MAX_DELAY) + { + if ((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + hrtc->State = HAL_RTC_STATE_TIMEOUT; + return HAL_TIMEOUT; + } + } + } + + /* Clear the Tamper Flag */ + __HAL_RTC_TAMPER_CLEAR_FLAG(hrtc, RTC_FLAG_TAMP3F); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + return HAL_OK; +} +#endif + +/** + * @} + */ + +#if defined(STM32F070xB) || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) +/** @addtogroup RTCEx_Exported_Functions_Group2 + * @brief RTC Wake-up functions + * +@verbatim + =============================================================================== + ##### RTC Wake-up functions ##### + =============================================================================== + + [..] This section provides functions allowing to configure Wake-up feature + +@endverbatim + * @{ + */ + +/** + * @brief Set wake up timer. + * @param hrtc RTC handle + * @param WakeUpCounter Wake up counter + * @param WakeUpClock Wake up clock + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetWakeUpTimer(RTC_HandleTypeDef *hrtc, uint32_t WakeUpCounter, uint32_t WakeUpClock) +{ + uint32_t tickstart = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_WAKEUP_CLOCK(WakeUpClock)); + assert_param(IS_RTC_WAKEUP_COUNTER(WakeUpCounter)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /*Check RTC WUTWF flag is reset only when wake up timer enabled*/ + if ((hrtc->Instance->CR & RTC_CR_WUTE) != RESET) + { + tickstart = HAL_GetTick(); + + /* Wait till RTC WUTWF flag is reset and if Time out is reached exit */ + while (__HAL_RTC_WAKEUPTIMER_GET_FLAG(hrtc, RTC_FLAG_WUTWF) == SET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + } + + __HAL_RTC_WAKEUPTIMER_DISABLE(hrtc); + + tickstart = HAL_GetTick(); + + /* Wait till RTC WUTWF flag is set and if Time out is reached exit */ + while (__HAL_RTC_WAKEUPTIMER_GET_FLAG(hrtc, RTC_FLAG_WUTWF) == RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + + /* Clear the Wakeup Timer clock source bits in CR register */ + hrtc->Instance->CR &= (uint32_t)~RTC_CR_WUCKSEL; + + /* Configure the clock source */ + hrtc->Instance->CR |= (uint32_t)WakeUpClock; + + /* Configure the Wakeup Timer counter */ + hrtc->Instance->WUTR = (uint32_t)WakeUpCounter; + + /* Enable the Wakeup Timer */ + __HAL_RTC_WAKEUPTIMER_ENABLE(hrtc); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Set wake up timer with interrupt. + * @param hrtc RTC handle + * @param WakeUpCounter Wake up counter + * @param WakeUpClock Wake up clock + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetWakeUpTimer_IT(RTC_HandleTypeDef *hrtc, uint32_t WakeUpCounter, uint32_t WakeUpClock) +{ + uint32_t tickstart = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_WAKEUP_CLOCK(WakeUpClock)); + assert_param(IS_RTC_WAKEUP_COUNTER(WakeUpCounter)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /*Check RTC WUTWF flag is reset only when wake up timer enabled*/ + if ((hrtc->Instance->CR & RTC_CR_WUTE) != RESET) + { + tickstart = HAL_GetTick(); + + /* Wait till RTC WUTWF flag is reset and if Time out is reached exit */ + while (__HAL_RTC_WAKEUPTIMER_GET_FLAG(hrtc, RTC_FLAG_WUTWF) == SET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + } + + /* Disable the Wake-Up timer */ + __HAL_RTC_WAKEUPTIMER_DISABLE(hrtc); + + /* Clear flag Wake-Up */ + __HAL_RTC_WAKEUPTIMER_CLEAR_FLAG(hrtc, RTC_FLAG_WUTF); + + tickstart = HAL_GetTick(); + + /* Wait till RTC WUTWF flag is set and if Time out is reached exit */ + while (__HAL_RTC_WAKEUPTIMER_GET_FLAG(hrtc, RTC_FLAG_WUTWF) == RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + + /* Configure the Wakeup Timer counter */ + hrtc->Instance->WUTR = (uint32_t)WakeUpCounter; + + /* Clear the Wakeup Timer clock source bits in CR register */ + hrtc->Instance->CR &= (uint32_t)~RTC_CR_WUCKSEL; + + /* Configure the clock source */ + hrtc->Instance->CR |= (uint32_t)WakeUpClock; + + /* RTC WakeUpTimer Interrupt Configuration: EXTI configuration */ + __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_IT(); + + __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE(); + + /* Configure the Interrupt in the RTC_CR register */ + __HAL_RTC_WAKEUPTIMER_ENABLE_IT(hrtc, RTC_IT_WUT); + + /* Enable the Wakeup Timer */ + __HAL_RTC_WAKEUPTIMER_ENABLE(hrtc); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Deactivate wake up timer counter. + * @param hrtc RTC handle + * @retval HAL status + */ +uint32_t HAL_RTCEx_DeactivateWakeUpTimer(RTC_HandleTypeDef *hrtc) +{ + uint32_t tickstart = 0U; + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Disable the Wakeup Timer */ + __HAL_RTC_WAKEUPTIMER_DISABLE(hrtc); + + /* In case of interrupt mode is used, the interrupt source must disabled */ + __HAL_RTC_WAKEUPTIMER_DISABLE_IT(hrtc, RTC_IT_WUT); + + tickstart = HAL_GetTick(); + /* Wait till RTC WUTWF flag is set and if Time out is reached exit */ + while (__HAL_RTC_WAKEUPTIMER_GET_FLAG(hrtc, RTC_FLAG_WUTWF) == RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Get wake up timer counter. + * @param hrtc RTC handle + * @retval Counter value + */ +uint32_t HAL_RTCEx_GetWakeUpTimer(RTC_HandleTypeDef *hrtc) +{ + /* Get the counter value */ + return ((uint32_t)(hrtc->Instance->WUTR & RTC_WUTR_WUT)); +} + +/** + * @brief Handle Wake Up Timer interrupt request. + * @param hrtc RTC handle + * @retval None + */ +void HAL_RTCEx_WakeUpTimerIRQHandler(RTC_HandleTypeDef *hrtc) +{ + /* Get the WAKEUPTIMER interrupt source enable status */ + if (__HAL_RTC_WAKEUPTIMER_GET_IT_SOURCE(hrtc, RTC_IT_WUT) != RESET) + { + /* Get the pending status of the WAKEUPTIMER Interrupt */ + if (__HAL_RTC_WAKEUPTIMER_GET_FLAG(hrtc, RTC_FLAG_WUTF) != RESET) + { + /* WAKEUPTIMER callback */ +#if (USE_HAL_RTC_REGISTER_CALLBACKS == 1) + hrtc->WakeUpTimerEventCallback(hrtc); +#else + HAL_RTCEx_WakeUpTimerEventCallback(hrtc); +#endif /* USE_HAL_RTC_REGISTER_CALLBACKS */ + + /* Clear the WAKEUPTIMER interrupt pending bit */ + __HAL_RTC_WAKEUPTIMER_CLEAR_FLAG(hrtc, RTC_FLAG_WUTF); + } + } + + /* Clear the EXTI's line Flag for RTC WakeUpTimer */ + __HAL_RTC_WAKEUPTIMER_EXTI_CLEAR_FLAG(); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; +} + +/** + * @brief Wake Up Timer callback. + * @param hrtc RTC handle + * @retval None + */ +__weak void HAL_RTCEx_WakeUpTimerEventCallback(RTC_HandleTypeDef *hrtc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hrtc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_RTCEx_WakeUpTimerEventCallback could be implemented in the user file + */ +} + + +/** + * @brief Handle Wake Up Timer Polling. + * @param hrtc RTC handle + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_PollForWakeUpTimerEvent(RTC_HandleTypeDef *hrtc, uint32_t Timeout) +{ + uint32_t tickstart = HAL_GetTick(); + + while (__HAL_RTC_WAKEUPTIMER_GET_FLAG(hrtc, RTC_FLAG_WUTF) == RESET) + { + if (Timeout != HAL_MAX_DELAY) + { + if ((Timeout == 0U) || ((HAL_GetTick() - tickstart) > Timeout)) + { + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + return HAL_TIMEOUT; + } + } + } + + /* Clear the WAKEUPTIMER Flag */ + __HAL_RTC_WAKEUPTIMER_CLEAR_FLAG(hrtc, RTC_FLAG_WUTF); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + return HAL_OK; +} + +/** + * @} + */ +#endif /* defined(STM32F070xB) || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) | defined(STM32F030xC) */ + +/** @addtogroup RTCEx_Exported_Functions_Group3 + * @brief Extended Peripheral Control functions + * +@verbatim + =============================================================================== + ##### Extended Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides functions allowing to + (+) Write a data in a specified RTC Backup data register + (+) Read a data in a specified RTC Backup data register + (+) Set the Coarse calibration parameters. + (+) Deactivate the Coarse calibration parameters + (+) Set the Smooth calibration parameters. + (+) Configure the Synchronization Shift Control Settings. + (+) Configure the Calibration Pinout (RTC_CALIB) Selection (1Hz or 512Hz). + (+) Deactivate the Calibration Pinout (RTC_CALIB) Selection (1Hz or 512Hz). + (+) Enable the RTC reference clock detection. + (+) Disable the RTC reference clock detection. + (+) Enable the Bypass Shadow feature. + (+) Disable the Bypass Shadow feature. + +@endverbatim + * @{ + */ + +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +/** + * @brief Write a data in a specified RTC Backup data register. + * @param hrtc RTC handle + * @param BackupRegister RTC Backup data Register number. + * This parameter can be: RTC_BKP_DRx where x can be from 0 to 4 to + * specify the register. + * @param Data Data to be written in the specified RTC Backup data register. + * @retval None + */ +void HAL_RTCEx_BKUPWrite(RTC_HandleTypeDef *hrtc, uint32_t BackupRegister, uint32_t Data) +{ + uint32_t tmp = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_BKP(BackupRegister)); + + tmp = (uint32_t) & (hrtc->Instance->BKP0R); + tmp += (BackupRegister * 4U); + + /* Write the specified register */ + *(__IO uint32_t *)tmp = (uint32_t)Data; +} + +/** + * @brief Reads data from the specified RTC Backup data Register. + * @param hrtc RTC handle + * @param BackupRegister RTC Backup data Register number. + * This parameter can be: RTC_BKP_DRx where x can be from 0 to 4 to + * specify the register. + * @retval Read value + */ +uint32_t HAL_RTCEx_BKUPRead(RTC_HandleTypeDef *hrtc, uint32_t BackupRegister) +{ + uint32_t tmp = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_BKP(BackupRegister)); + + tmp = (uint32_t) & (hrtc->Instance->BKP0R); + tmp += (BackupRegister * 4U); + + /* Read the specified register */ + return (*(__IO uint32_t *)tmp); +} +#endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) */ + +/** + * @brief Set the Smooth calibration parameters. + * @param hrtc RTC handle + * @param SmoothCalibPeriod Select the Smooth Calibration Period. + * This parameter can be can be one of the following values : + * @arg RTC_SMOOTHCALIB_PERIOD_32SEC: The smooth calibration period is 32s. + * @arg RTC_SMOOTHCALIB_PERIOD_16SEC: The smooth calibration period is 16s. + * @arg RTC_SMOOTHCALIB_PERIOD_8SEC: The smooth calibration period is 8s. + * @param SmoothCalibPlusPulses Select to Set or reset the CALP bit. + * This parameter can be one of the following values: + * @arg RTC_SMOOTHCALIB_PLUSPULSES_SET: Add one RTCCLK pulse every 2*11 pulses. + * @arg RTC_SMOOTHCALIB_PLUSPULSES_RESET: No RTCCLK pulses are added. + * @param SmoothCalibMinusPulsesValue Select the value of CALM[8:0] bits. + * This parameter can be one any value from 0 to 0x000001FF. + * @note To deactivate the smooth calibration, the field SmoothCalibPlusPulses + * must be equal to SMOOTHCALIB_PLUSPULSES_RESET and the field + * SmoothCalibMinusPulsesValue mut be equal to 0. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetSmoothCalib(RTC_HandleTypeDef *hrtc, uint32_t SmoothCalibPeriod, uint32_t SmoothCalibPlusPulses, uint32_t SmoothCalibMinusPulsesValue) +{ + uint32_t tickstart = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_SMOOTH_CALIB_PERIOD(SmoothCalibPeriod)); + assert_param(IS_RTC_SMOOTH_CALIB_PLUS(SmoothCalibPlusPulses)); + assert_param(IS_RTC_SMOOTH_CALIB_MINUS(SmoothCalibMinusPulsesValue)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* check if a calibration is pending*/ + if ((hrtc->Instance->ISR & RTC_ISR_RECALPF) != RESET) + { + tickstart = HAL_GetTick(); + + /* check if a calibration is pending*/ + while ((hrtc->Instance->ISR & RTC_ISR_RECALPF) != RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + } + + /* Configure the Smooth calibration settings */ + hrtc->Instance->CALR = (uint32_t)((uint32_t)SmoothCalibPeriod | (uint32_t)SmoothCalibPlusPulses | (uint32_t)SmoothCalibMinusPulsesValue); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Configure the Synchronization Shift Control Settings. + * @note When REFCKON is set, firmware must not write to Shift control register. + * @param hrtc RTC handle + * @param ShiftAdd1S Select to add or not 1 second to the time calendar. + * This parameter can be one of the following values : + * @arg RTC_SHIFTADD1S_SET: Add one second to the clock calendar. + * @arg RTC_SHIFTADD1S_RESET: No effect. + * @param ShiftSubFS Select the number of Second Fractions to substitute. + * This parameter can be one any value from 0 to 0x7FFF. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetSynchroShift(RTC_HandleTypeDef *hrtc, uint32_t ShiftAdd1S, uint32_t ShiftSubFS) +{ + uint32_t tickstart = 0U; + + /* Check the parameters */ + assert_param(IS_RTC_SHIFT_ADD1S(ShiftAdd1S)); + assert_param(IS_RTC_SHIFT_SUBFS(ShiftSubFS)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + tickstart = HAL_GetTick(); + + /* Wait until the shift is completed*/ + while ((hrtc->Instance->ISR & RTC_ISR_SHPF) != RESET) + { + if ((HAL_GetTick() - tickstart) > RTC_TIMEOUT_VALUE) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_TIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_TIMEOUT; + } + } + + /* Check if the reference clock detection is disabled */ + if ((hrtc->Instance->CR & RTC_CR_REFCKON) == RESET) + { + /* Configure the Shift settings */ + hrtc->Instance->SHIFTR = (uint32_t)(uint32_t)(ShiftSubFS) | (uint32_t)(ShiftAdd1S); + + /* If RTC_CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */ + if ((hrtc->Instance->CR & RTC_CR_BYPSHAD) == RESET) + { + if (HAL_RTC_WaitForSynchro(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + } + } + else + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Configure the Calibration Pinout (RTC_CALIB) Selection (1Hz or 512Hz). + * @param hrtc RTC handle + * @param CalibOutput Select the Calibration output Selection . + * This parameter can be one of the following values: + * @arg RTC_CALIBOUTPUT_512HZ: A signal has a regular waveform at 512Hz. + * @arg RTC_CALIBOUTPUT_1HZ: A signal has a regular waveform at 1Hz. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetCalibrationOutPut(RTC_HandleTypeDef *hrtc, uint32_t CalibOutput) +{ + /* Check the parameters */ + assert_param(IS_RTC_CALIB_OUTPUT(CalibOutput)); + + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Clear flags before config */ + hrtc->Instance->CR &= (uint32_t)~RTC_CR_COSEL; + + /* Configure the RTC_CR register */ + hrtc->Instance->CR |= (uint32_t)CalibOutput; + + __HAL_RTC_CALIBRATION_OUTPUT_ENABLE(hrtc); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Deactivate the Calibration Pinout (RTC_CALIB) Selection (1Hz or 512Hz). + * @param hrtc RTC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_DeactivateCalibrationOutPut(RTC_HandleTypeDef *hrtc) +{ + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + __HAL_RTC_CALIBRATION_OUTPUT_DISABLE(hrtc); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Enable the RTC reference clock detection. + * @param hrtc RTC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_SetRefClock(RTC_HandleTypeDef *hrtc) +{ + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set Initialization mode */ + if (RTC_EnterInitMode(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state*/ + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + else + { + __HAL_RTC_CLOCKREF_DETECTION_ENABLE(hrtc); + + /* Exit Initialization mode */ + hrtc->Instance->ISR &= (uint32_t)~RTC_ISR_INIT; + } + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Disable the RTC reference clock detection. + * @param hrtc RTC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_DeactivateRefClock(RTC_HandleTypeDef *hrtc) +{ + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set Initialization mode */ + if (RTC_EnterInitMode(hrtc) != HAL_OK) + { + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Set RTC state*/ + hrtc->State = HAL_RTC_STATE_ERROR; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_ERROR; + } + else + { + __HAL_RTC_CLOCKREF_DETECTION_DISABLE(hrtc); + + /* Exit Initialization mode */ + hrtc->Instance->ISR &= (uint32_t)~RTC_ISR_INIT; + } + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Enable the Bypass Shadow feature. + * @param hrtc RTC handle + * @note When the Bypass Shadow is enabled the calendar value are taken + * directly from the Calendar counter. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_EnableBypassShadow(RTC_HandleTypeDef *hrtc) +{ + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set the BYPSHAD bit */ + hrtc->Instance->CR |= (uint8_t)RTC_CR_BYPSHAD; + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @brief Disable the Bypass Shadow feature. + * @param hrtc RTC handle + * @note When the Bypass Shadow is enabled the calendar value are taken + * directly from the Calendar counter. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RTCEx_DisableBypassShadow(RTC_HandleTypeDef *hrtc) +{ + /* Process Locked */ + __HAL_LOCK(hrtc); + + hrtc->State = HAL_RTC_STATE_BUSY; + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Reset the BYPSHAD bit */ + hrtc->Instance->CR &= ((uint8_t)~RTC_CR_BYPSHAD); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); + + /* Change RTC state */ + hrtc->State = HAL_RTC_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hrtc); + + return HAL_OK; +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_RTC_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard.c new file mode 100644 index 0000000..33f9d57 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard.c @@ -0,0 +1,2933 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_smartcard.c + * @author MCD Application Team + * @brief SMARTCARD HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the SMARTCARD peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral Control functions + * + Peripheral State and Error functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The SMARTCARD HAL driver can be used as follows: + + (#) Declare a SMARTCARD_HandleTypeDef handle structure (eg. SMARTCARD_HandleTypeDef hsmartcard). + (#) Associate a USART to the SMARTCARD handle hsmartcard. + (#) Initialize the SMARTCARD low level resources by implementing the HAL_SMARTCARD_MspInit() API: + (++) Enable the USARTx interface clock. + (++) USART pins configuration: + (+++) Enable the clock for the USART GPIOs. + (+++) Configure the USART pins (TX as alternate function pull-up, RX as alternate function Input). + (++) NVIC configuration if you need to use interrupt process (HAL_SMARTCARD_Transmit_IT() + and HAL_SMARTCARD_Receive_IT() APIs): + (+++) Configure the USARTx interrupt priority. + (+++) Enable the NVIC USART IRQ handle. + (++) DMA Configuration if you need to use DMA process (HAL_SMARTCARD_Transmit_DMA() + and HAL_SMARTCARD_Receive_DMA() APIs): + (+++) Declare a DMA handle structure for the Tx/Rx channel. + (+++) Enable the DMAx interface clock. + (+++) Configure the declared DMA handle structure with the required Tx/Rx parameters. + (+++) Configure the DMA Tx/Rx channel. + (+++) Associate the initialized DMA handle to the SMARTCARD DMA Tx/Rx handle. + (+++) Configure the priority and enable the NVIC for the transfer complete + interrupt on the DMA Tx/Rx channel. + + (#) Program the Baud Rate, Parity, Mode(Receiver/Transmitter), clock enabling/disabling and accordingly, + the clock parameters (parity, phase, last bit), prescaler value, guard time and NACK on transmission + error enabling or disabling in the hsmartcard handle Init structure. + + (#) If required, program SMARTCARD advanced features (TX/RX pins swap, TimeOut, auto-retry counter,...) + in the hsmartcard handle AdvancedInit structure. + + (#) Initialize the SMARTCARD registers by calling the HAL_SMARTCARD_Init() API: + (++) This API configures also the low level Hardware GPIO, CLOCK, CORTEX...etc) + by calling the customized HAL_SMARTCARD_MspInit() API. + [..] + (@) The specific SMARTCARD interrupts (Transmission complete interrupt, + RXNE interrupt and Error Interrupts) will be managed using the macros + __HAL_SMARTCARD_ENABLE_IT() and __HAL_SMARTCARD_DISABLE_IT() inside the transmit and receive process. + + [..] + [..] Three operation modes are available within this driver : + + *** Polling mode IO operation *** + ================================= + [..] + (+) Send an amount of data in blocking mode using HAL_SMARTCARD_Transmit() + (+) Receive an amount of data in blocking mode using HAL_SMARTCARD_Receive() + + *** Interrupt mode IO operation *** + =================================== + [..] + (+) Send an amount of data in non-blocking mode using HAL_SMARTCARD_Transmit_IT() + (+) At transmission end of transfer HAL_SMARTCARD_TxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_SMARTCARD_TxCpltCallback() + (+) Receive an amount of data in non-blocking mode using HAL_SMARTCARD_Receive_IT() + (+) At reception end of transfer HAL_SMARTCARD_RxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_SMARTCARD_RxCpltCallback() + (+) In case of transfer Error, HAL_SMARTCARD_ErrorCallback() function is executed and user can + add his own code by customization of function pointer HAL_SMARTCARD_ErrorCallback() + + *** DMA mode IO operation *** + ============================== + [..] + (+) Send an amount of data in non-blocking mode (DMA) using HAL_SMARTCARD_Transmit_DMA() + (+) At transmission end of transfer HAL_SMARTCARD_TxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_SMARTCARD_TxCpltCallback() + (+) Receive an amount of data in non-blocking mode (DMA) using HAL_SMARTCARD_Receive_DMA() + (+) At reception end of transfer HAL_SMARTCARD_RxCpltCallback() is executed and user can + add his own code by customization of function pointer HAL_SMARTCARD_RxCpltCallback() + (+) In case of transfer Error, HAL_SMARTCARD_ErrorCallback() function is executed and user can + add his own code by customization of function pointer HAL_SMARTCARD_ErrorCallback() + + *** SMARTCARD HAL driver macros list *** + ======================================== + [..] + Below the list of most used macros in SMARTCARD HAL driver. + + (+) __HAL_SMARTCARD_GET_FLAG : Check whether or not the specified SMARTCARD flag is set + (+) __HAL_SMARTCARD_CLEAR_FLAG : Clear the specified SMARTCARD pending flag + (+) __HAL_SMARTCARD_ENABLE_IT: Enable the specified SMARTCARD interrupt + (+) __HAL_SMARTCARD_DISABLE_IT: Disable the specified SMARTCARD interrupt + (+) __HAL_SMARTCARD_GET_IT_SOURCE: Check whether or not the specified SMARTCARD interrupt is enabled + + [..] + (@) You can refer to the SMARTCARD HAL driver header file for more useful macros + + ##### Callback registration ##### + ================================== + + [..] + The compilation define USE_HAL_SMARTCARD_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + + [..] + Use Function HAL_SMARTCARD_RegisterCallback() to register a user callback. + Function HAL_SMARTCARD_RegisterCallback() allows to register following callbacks: + (+) TxCpltCallback : Tx Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback. + (+) AbortReceiveCpltCallback : Abort Receive Complete Callback. + (+) MspInitCallback : SMARTCARD MspInit. + (+) MspDeInitCallback : SMARTCARD MspDeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + [..] + Use function HAL_SMARTCARD_UnRegisterCallback() to reset a callback to the default + weak (surcharged) function. + HAL_SMARTCARD_UnRegisterCallback() takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) TxCpltCallback : Tx Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback. + (+) AbortReceiveCpltCallback : Abort Receive Complete Callback. + (+) MspInitCallback : SMARTCARD MspInit. + (+) MspDeInitCallback : SMARTCARD MspDeInit. + + [..] + By default, after the HAL_SMARTCARD_Init() and when the state is HAL_SMARTCARD_STATE_RESET + all callbacks are set to the corresponding weak (surcharged) functions: + examples HAL_SMARTCARD_TxCpltCallback(), HAL_SMARTCARD_RxCpltCallback(). + Exception done for MspInit and MspDeInit functions that are respectively + reset to the legacy weak (surcharged) functions in the HAL_SMARTCARD_Init() + and HAL_SMARTCARD_DeInit() only when these callbacks are null (not registered beforehand). + If not, MspInit or MspDeInit are not null, the HAL_SMARTCARD_Init() and HAL_SMARTCARD_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand). + + [..] + Callbacks can be registered/unregistered in HAL_SMARTCARD_STATE_READY state only. + Exception done MspInit/MspDeInit that can be registered/unregistered + in HAL_SMARTCARD_STATE_READY or HAL_SMARTCARD_STATE_RESET state, thus registered (user) + MspInit/DeInit callbacks can be used during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_SMARTCARD_RegisterCallback() before calling HAL_SMARTCARD_DeInit() + or HAL_SMARTCARD_Init() function. + + [..] + When The compilation define USE_HAL_SMARTCARD_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available + and weak (surcharged) callbacks are used. + + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup SMARTCARD SMARTCARD + * @brief HAL SMARTCARD module driver + * @{ + */ + +#ifdef HAL_SMARTCARD_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup SMARTCARD_Private_Constants SMARTCARD Private Constants + * @{ + */ +#define SMARTCARD_TEACK_REACK_TIMEOUT 1000U /*!< SMARTCARD TX or RX enable acknowledge time-out value */ + +#define USART_CR1_FIELDS ((uint32_t)(USART_CR1_M | USART_CR1_PCE | USART_CR1_PS | USART_CR1_TE | \ + USART_CR1_RE | USART_CR1_OVER8)) /*!< USART CR1 fields of parameters set by SMARTCARD_SetConfig API */ + +#define USART_CR2_CLK_FIELDS ((uint32_t)(USART_CR2_CLKEN | USART_CR2_CPOL | \ + USART_CR2_CPHA | USART_CR2_LBCL)) /*!< SMARTCARD clock-related USART CR2 fields of parameters */ + +#define USART_CR2_FIELDS ((uint32_t)(USART_CR2_RTOEN | USART_CR2_CLK_FIELDS | \ + USART_CR2_STOP)) /*!< USART CR2 fields of parameters set by SMARTCARD_SetConfig API */ + +#define USART_CR3_FIELDS ((uint32_t)(USART_CR3_ONEBIT | USART_CR3_NACK | \ + USART_CR3_SCARCNT)) /*!< USART CR3 fields of parameters set by SMARTCARD_SetConfig API */ + +#define USART_BRR_MIN 0x10U /*!< USART BRR minimum authorized value */ + +#define USART_BRR_MAX 0x0000FFFFU /*!< USART BRR maximum authorized value */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @addtogroup SMARTCARD_Private_Functions + * @{ + */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) +void SMARTCARD_InitCallbacksToDefault(SMARTCARD_HandleTypeDef *hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ +static HAL_StatusTypeDef SMARTCARD_SetConfig(SMARTCARD_HandleTypeDef *hsmartcard); +static void SMARTCARD_AdvFeatureConfig(SMARTCARD_HandleTypeDef *hsmartcard); +static HAL_StatusTypeDef SMARTCARD_CheckIdleState(SMARTCARD_HandleTypeDef *hsmartcard); +static HAL_StatusTypeDef SMARTCARD_WaitOnFlagUntilTimeout(SMARTCARD_HandleTypeDef *hsmartcard, uint32_t Flag, + FlagStatus Status, uint32_t Tickstart, uint32_t Timeout); +static void SMARTCARD_EndTxTransfer(SMARTCARD_HandleTypeDef *hsmartcard); +static void SMARTCARD_EndRxTransfer(SMARTCARD_HandleTypeDef *hsmartcard); +static void SMARTCARD_DMATransmitCplt(DMA_HandleTypeDef *hdma); +static void SMARTCARD_DMAReceiveCplt(DMA_HandleTypeDef *hdma); +static void SMARTCARD_DMAError(DMA_HandleTypeDef *hdma); +static void SMARTCARD_DMAAbortOnError(DMA_HandleTypeDef *hdma); +static void SMARTCARD_DMATxAbortCallback(DMA_HandleTypeDef *hdma); +static void SMARTCARD_DMARxAbortCallback(DMA_HandleTypeDef *hdma); +static void SMARTCARD_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma); +static void SMARTCARD_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma); +static void SMARTCARD_TxISR(SMARTCARD_HandleTypeDef *hsmartcard); +static void SMARTCARD_EndTransmit_IT(SMARTCARD_HandleTypeDef *hsmartcard); +static void SMARTCARD_RxISR(SMARTCARD_HandleTypeDef *hsmartcard); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup SMARTCARD_Exported_Functions SMARTCARD Exported Functions + * @{ + */ + +/** @defgroup SMARTCARD_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + ============================================================================== + ##### Initialization and Configuration functions ##### + ============================================================================== + [..] + This subsection provides a set of functions allowing to initialize the USARTx + associated to the SmartCard. + (+) These parameters can be configured: + (++) Baud Rate + (++) Parity: parity should be enabled, frame Length is fixed to 8 bits plus parity + (++) Receiver/transmitter modes + (++) Synchronous mode (and if enabled, phase, polarity and last bit parameters) + (++) Prescaler value + (++) Guard bit time + (++) NACK enabling or disabling on transmission error + + (+) The following advanced features can be configured as well: + (++) TX and/or RX pin level inversion + (++) data logical level inversion + (++) RX and TX pins swap + (++) RX overrun detection disabling + (++) DMA disabling on RX error + (++) MSB first on communication line + (++) Time out enabling (and if activated, timeout value) + (++) Block length + (++) Auto-retry counter + [..] + The HAL_SMARTCARD_Init() API follows the USART synchronous configuration procedures + (details for the procedures are available in reference manual). + +@endverbatim + + The USART frame format is given in the following table: + + Table 1. USART frame format. + +---------------------------------------------------------------+ + | M1M0 bits | PCE bit | USART frame | + |-----------------------|---------------------------------------| + | 01 | 1 | | SB | 8 bit data | PB | STB | | + +---------------------------------------------------------------+ + + + * @{ + */ + +/** + * @brief Initialize the SMARTCARD mode according to the specified + * parameters in the SMARTCARD_HandleTypeDef and initialize the associated handle. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Init(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Check the SMARTCARD handle allocation */ + if (hsmartcard == NULL) + { + return HAL_ERROR; + } + + /* Check the USART associated to the SMARTCARD handle */ + assert_param(IS_SMARTCARD_INSTANCE(hsmartcard->Instance)); + + if (hsmartcard->gState == HAL_SMARTCARD_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hsmartcard->Lock = HAL_UNLOCKED; + +#if USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1 + SMARTCARD_InitCallbacksToDefault(hsmartcard); + + if (hsmartcard->MspInitCallback == NULL) + { + hsmartcard->MspInitCallback = HAL_SMARTCARD_MspInit; + } + + /* Init the low level hardware */ + hsmartcard->MspInitCallback(hsmartcard); +#else + /* Init the low level hardware : GPIO, CLOCK */ + HAL_SMARTCARD_MspInit(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + } + + hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY; + + /* Disable the Peripheral to set smartcard mode */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* In SmartCard mode, the following bits must be kept cleared: + - LINEN in the USART_CR2 register, + - HDSEL and IREN bits in the USART_CR3 register.*/ + CLEAR_BIT(hsmartcard->Instance->CR2, USART_CR2_LINEN); + CLEAR_BIT(hsmartcard->Instance->CR3, (USART_CR3_HDSEL | USART_CR3_IREN)); + + /* set the USART in SMARTCARD mode */ + SET_BIT(hsmartcard->Instance->CR3, USART_CR3_SCEN); + + /* Set the SMARTCARD Communication parameters */ + if (SMARTCARD_SetConfig(hsmartcard) == HAL_ERROR) + { + return HAL_ERROR; + } + + /* Set the SMARTCARD transmission completion indication */ + SMARTCARD_TRANSMISSION_COMPLETION_SETTING(hsmartcard); + + if (hsmartcard->AdvancedInit.AdvFeatureInit != SMARTCARD_ADVFEATURE_NO_INIT) + { + SMARTCARD_AdvFeatureConfig(hsmartcard); + } + + /* Enable the Peripheral */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* TEACK and/or REACK to check before moving hsmartcard->gState and hsmartcard->RxState to Ready */ + return (SMARTCARD_CheckIdleState(hsmartcard)); +} + +/** + * @brief DeInitialize the SMARTCARD peripheral. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_DeInit(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Check the SMARTCARD handle allocation */ + if (hsmartcard == NULL) + { + return HAL_ERROR; + } + + /* Check the USART/UART associated to the SMARTCARD handle */ + assert_param(IS_SMARTCARD_INSTANCE(hsmartcard->Instance)); + + hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY; + + /* Disable the Peripheral */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + WRITE_REG(hsmartcard->Instance->CR1, 0x0U); + WRITE_REG(hsmartcard->Instance->CR2, 0x0U); + WRITE_REG(hsmartcard->Instance->CR3, 0x0U); + WRITE_REG(hsmartcard->Instance->RTOR, 0x0U); + WRITE_REG(hsmartcard->Instance->GTPR, 0x0U); + + /* DeInit the low level hardware */ +#if USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1 + if (hsmartcard->MspDeInitCallback == NULL) + { + hsmartcard->MspDeInitCallback = HAL_SMARTCARD_MspDeInit; + } + /* DeInit the low level hardware */ + hsmartcard->MspDeInitCallback(hsmartcard); +#else + HAL_SMARTCARD_MspDeInit(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + hsmartcard->gState = HAL_SMARTCARD_STATE_RESET; + hsmartcard->RxState = HAL_SMARTCARD_STATE_RESET; + + /* Process Unlock */ + __HAL_UNLOCK(hsmartcard); + + return HAL_OK; +} + +/** + * @brief Initialize the SMARTCARD MSP. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_MspInit(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_MspInit can be implemented in the user file + */ +} + +/** + * @brief DeInitialize the SMARTCARD MSP. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_MspDeInit(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_MspDeInit can be implemented in the user file + */ +} + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User SMARTCARD Callback + * To be used instead of the weak predefined callback + * @param hsmartcard smartcard handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_SMARTCARD_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_SMARTCARD_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_SMARTCARD_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_SMARTCARD_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID + * @arg @ref HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID + * @arg @ref HAL_SMARTCARD_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_SMARTCARD_MSPDEINIT_CB_ID MspDeInit Callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_RegisterCallback(SMARTCARD_HandleTypeDef *hsmartcard, + HAL_SMARTCARD_CallbackIDTypeDef CallbackID, + pSMARTCARD_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hsmartcard); + + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + switch (CallbackID) + { + + case HAL_SMARTCARD_TX_COMPLETE_CB_ID : + hsmartcard->TxCpltCallback = pCallback; + break; + + case HAL_SMARTCARD_RX_COMPLETE_CB_ID : + hsmartcard->RxCpltCallback = pCallback; + break; + + case HAL_SMARTCARD_ERROR_CB_ID : + hsmartcard->ErrorCallback = pCallback; + break; + + case HAL_SMARTCARD_ABORT_COMPLETE_CB_ID : + hsmartcard->AbortCpltCallback = pCallback; + break; + + case HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID : + hsmartcard->AbortTransmitCpltCallback = pCallback; + break; + + case HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID : + hsmartcard->AbortReceiveCpltCallback = pCallback; + break; + + + case HAL_SMARTCARD_MSPINIT_CB_ID : + hsmartcard->MspInitCallback = pCallback; + break; + + case HAL_SMARTCARD_MSPDEINIT_CB_ID : + hsmartcard->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (hsmartcard->gState == HAL_SMARTCARD_STATE_RESET) + { + switch (CallbackID) + { + case HAL_SMARTCARD_MSPINIT_CB_ID : + hsmartcard->MspInitCallback = pCallback; + break; + + case HAL_SMARTCARD_MSPDEINIT_CB_ID : + hsmartcard->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hsmartcard); + + return status; +} + +/** + * @brief Unregister an SMARTCARD callback + * SMARTCARD callback is redirected to the weak predefined callback + * @param hsmartcard smartcard handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_SMARTCARD_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_SMARTCARD_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_SMARTCARD_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_SMARTCARD_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID + * @arg @ref HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID + * @arg @ref HAL_SMARTCARD_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_SMARTCARD_MSPDEINIT_CB_ID MspDeInit Callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_UnRegisterCallback(SMARTCARD_HandleTypeDef *hsmartcard, + HAL_SMARTCARD_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hsmartcard); + + if (HAL_SMARTCARD_STATE_READY == hsmartcard->gState) + { + switch (CallbackID) + { + case HAL_SMARTCARD_TX_COMPLETE_CB_ID : + hsmartcard->TxCpltCallback = HAL_SMARTCARD_TxCpltCallback; /* Legacy weak TxCpltCallback */ + break; + + case HAL_SMARTCARD_RX_COMPLETE_CB_ID : + hsmartcard->RxCpltCallback = HAL_SMARTCARD_RxCpltCallback; /* Legacy weak RxCpltCallback */ + break; + + case HAL_SMARTCARD_ERROR_CB_ID : + hsmartcard->ErrorCallback = HAL_SMARTCARD_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_SMARTCARD_ABORT_COMPLETE_CB_ID : + hsmartcard->AbortCpltCallback = HAL_SMARTCARD_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + break; + + case HAL_SMARTCARD_ABORT_TRANSMIT_COMPLETE_CB_ID : + hsmartcard->AbortTransmitCpltCallback = HAL_SMARTCARD_AbortTransmitCpltCallback; /* Legacy weak + AbortTransmitCpltCallback*/ + break; + + case HAL_SMARTCARD_ABORT_RECEIVE_COMPLETE_CB_ID : + hsmartcard->AbortReceiveCpltCallback = HAL_SMARTCARD_AbortReceiveCpltCallback; /* Legacy weak + AbortReceiveCpltCallback */ + break; + + + case HAL_SMARTCARD_MSPINIT_CB_ID : + hsmartcard->MspInitCallback = HAL_SMARTCARD_MspInit; /* Legacy weak MspInitCallback */ + break; + + case HAL_SMARTCARD_MSPDEINIT_CB_ID : + hsmartcard->MspDeInitCallback = HAL_SMARTCARD_MspDeInit; /* Legacy weak MspDeInitCallback */ + break; + + default : + /* Update the error code */ + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_SMARTCARD_STATE_RESET == hsmartcard->gState) + { + switch (CallbackID) + { + case HAL_SMARTCARD_MSPINIT_CB_ID : + hsmartcard->MspInitCallback = HAL_SMARTCARD_MspInit; + break; + + case HAL_SMARTCARD_MSPDEINIT_CB_ID : + hsmartcard->MspDeInitCallback = HAL_SMARTCARD_MspDeInit; + break; + + default : + /* Update the error code */ + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hsmartcard); + + return status; +} +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup SMARTCARD_Exported_Functions_Group2 IO operation functions + * @brief SMARTCARD Transmit and Receive functions + * +@verbatim + ============================================================================== + ##### IO operation functions ##### + ============================================================================== + [..] + This subsection provides a set of functions allowing to manage the SMARTCARD data transfers. + + [..] + Smartcard is a single wire half duplex communication protocol. + The Smartcard interface is designed to support asynchronous protocol Smartcards as + defined in the ISO 7816-3 standard. The USART should be configured as: + (+) 8 bits plus parity: where M=1 and PCE=1 in the USART_CR1 register + (+) 1.5 stop bits when transmitting and receiving: where STOP=11 in the USART_CR2 register. + + [..] + (#) There are two modes of transfer: + (##) Blocking mode: The communication is performed in polling mode. + The HAL status of all data processing is returned by the same function + after finishing transfer. + (##) Non-Blocking mode: The communication is performed using Interrupts + or DMA, the relevant API's return the HAL status. + The end of the data processing will be indicated through the + dedicated SMARTCARD IRQ when using Interrupt mode or the DMA IRQ when + using DMA mode. + (##) The HAL_SMARTCARD_TxCpltCallback(), HAL_SMARTCARD_RxCpltCallback() user callbacks + will be executed respectively at the end of the Transmit or Receive process + The HAL_SMARTCARD_ErrorCallback() user callback will be executed when a communication + error is detected. + + (#) Blocking mode APIs are : + (##) HAL_SMARTCARD_Transmit() + (##) HAL_SMARTCARD_Receive() + + (#) Non Blocking mode APIs with Interrupt are : + (##) HAL_SMARTCARD_Transmit_IT() + (##) HAL_SMARTCARD_Receive_IT() + (##) HAL_SMARTCARD_IRQHandler() + + (#) Non Blocking mode functions with DMA are : + (##) HAL_SMARTCARD_Transmit_DMA() + (##) HAL_SMARTCARD_Receive_DMA() + + (#) A set of Transfer Complete Callbacks are provided in non Blocking mode: + (##) HAL_SMARTCARD_TxCpltCallback() + (##) HAL_SMARTCARD_RxCpltCallback() + (##) HAL_SMARTCARD_ErrorCallback() + + [..] + (#) Non-Blocking mode transfers could be aborted using Abort API's : + (##) HAL_SMARTCARD_Abort() + (##) HAL_SMARTCARD_AbortTransmit() + (##) HAL_SMARTCARD_AbortReceive() + (##) HAL_SMARTCARD_Abort_IT() + (##) HAL_SMARTCARD_AbortTransmit_IT() + (##) HAL_SMARTCARD_AbortReceive_IT() + + (#) For Abort services based on interrupts (HAL_SMARTCARD_Abortxxx_IT), + a set of Abort Complete Callbacks are provided: + (##) HAL_SMARTCARD_AbortCpltCallback() + (##) HAL_SMARTCARD_AbortTransmitCpltCallback() + (##) HAL_SMARTCARD_AbortReceiveCpltCallback() + + (#) In Non-Blocking mode transfers, possible errors are split into 2 categories. + Errors are handled as follows : + (##) Error is considered as Recoverable and non blocking : Transfer could go till end, but error severity is + to be evaluated by user : this concerns Frame Error, + Parity Error or Noise Error in Interrupt mode reception . + Received character is then retrieved and stored in Rx buffer, + Error code is set to allow user to identify error type, + and HAL_SMARTCARD_ErrorCallback() user callback is executed. Transfer is kept ongoing on SMARTCARD side. + If user wants to abort it, Abort services should be called by user. + (##) Error is considered as Blocking : Transfer could not be completed properly and is aborted. + This concerns Frame Error in Interrupt mode transmission, Overrun Error in Interrupt + mode reception and all errors in DMA mode. + Error code is set to allow user to identify error type, + and HAL_SMARTCARD_ErrorCallback() user callback is executed. + +@endverbatim + * @{ + */ + +/** + * @brief Send an amount of data in blocking mode. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param pData pointer to data buffer. + * @param Size amount of data to be sent. + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Transmit(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size, + uint32_t Timeout) +{ + uint32_t tickstart; + uint8_t *ptmpdata = pData; + + /* Check that a Tx process is not already ongoing */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + if ((ptmpdata == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY_TX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + /* Disable the Peripheral first to update mode for TX master */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* In case of TX only mode, if NACK is enabled, the USART must be able to monitor + the bidirectional line to detect a NACK signal in case of parity error. + Therefore, the receiver block must be enabled as well (RE bit must be set). */ + if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX) + && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE)) + { + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_RE); + } + /* Enable Tx */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TE); + + /* Enable the Peripheral */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* Perform a TX/RX FIFO Flush */ + __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard); + + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + hsmartcard->TxXferSize = Size; + hsmartcard->TxXferCount = Size; + + while (hsmartcard->TxXferCount > 0U) + { + hsmartcard->TxXferCount--; + if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, SMARTCARD_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + hsmartcard->Instance->TDR = (uint8_t)(*ptmpdata & 0xFFU); + ptmpdata++; + } + if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, SMARTCARD_TRANSMISSION_COMPLETION_FLAG(hsmartcard), RESET, + tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + + /* Disable the Peripheral first to update mode */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX) + && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE)) + { + /* In case of TX only mode, if NACK is enabled, receiver block has been enabled + for Transmit phase. Disable this receiver block. */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_RE); + } + if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX_RX) + || (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE)) + { + /* Perform a TX FIFO Flush at end of Tx phase, as all sent bytes are appearing in Rx Data register */ + __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard); + } + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* At end of Tx process, restore hsmartcard->gState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in blocking mode. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param pData pointer to data buffer. + * @param Size amount of data to be received. + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Receive(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size, + uint32_t Timeout) +{ + uint32_t tickstart; + uint8_t *ptmpdata = pData; + + /* Check that a Rx process is not already ongoing */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY) + { + if ((ptmpdata == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + hsmartcard->RxState = HAL_SMARTCARD_STATE_BUSY_RX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + hsmartcard->RxXferSize = Size; + hsmartcard->RxXferCount = Size; + + /* Check the remain data to be received */ + while (hsmartcard->RxXferCount > 0U) + { + hsmartcard->RxXferCount--; + + if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, SMARTCARD_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + *ptmpdata = (uint8_t)(hsmartcard->Instance->RDR & (uint8_t)0x00FF); + ptmpdata++; + } + + /* At end of Rx process, restore hsmartcard->RxState to Ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in interrupt mode. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param pData pointer to data buffer. + * @param Size amount of data to be sent. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Transmit_IT(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size) +{ + /* Check that a Tx process is not already ongoing */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY_TX; + + hsmartcard->pTxBuffPtr = pData; + hsmartcard->TxXferSize = Size; + hsmartcard->TxXferCount = Size; + hsmartcard->TxISR = NULL; + + /* Disable the Peripheral first to update mode for TX master */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* In case of TX only mode, if NACK is enabled, the USART must be able to monitor + the bidirectional line to detect a NACK signal in case of parity error. + Therefore, the receiver block must be enabled as well (RE bit must be set). */ + if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX) + && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE)) + { + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_RE); + } + /* Enable Tx */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TE); + + /* Enable the Peripheral */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* Perform a TX/RX FIFO Flush */ + __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard); + + /* Configure Tx interrupt processing */ + /* Set the Tx ISR function pointer */ + hsmartcard->TxISR = SMARTCARD_TxISR; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + /* Enable the SMARTCARD Error Interrupt: (Frame error) */ + SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* Enable the SMARTCARD Transmit Data Register Empty Interrupt */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TXEIE); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in interrupt mode. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param pData pointer to data buffer. + * @param Size amount of data to be received. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Receive_IT(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size) +{ + /* Check that a Rx process is not already ongoing */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + hsmartcard->RxState = HAL_SMARTCARD_STATE_BUSY_RX; + + hsmartcard->pRxBuffPtr = pData; + hsmartcard->RxXferSize = Size; + hsmartcard->RxXferCount = Size; + + /* Configure Rx interrupt processing */ + /* Set the Rx ISR function pointer */ + hsmartcard->RxISR = SMARTCARD_RxISR; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + /* Enable the SMARTCARD Parity Error and Data Register not empty Interrupts */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE); + + /* Enable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in DMA mode. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param pData pointer to data buffer. + * @param Size amount of data to be sent. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Transmit_DMA(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size) +{ + /* Check that a Tx process is not already ongoing */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY_TX; + + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + hsmartcard->pTxBuffPtr = pData; + hsmartcard->TxXferSize = Size; + hsmartcard->TxXferCount = Size; + + /* Disable the Peripheral first to update mode for TX master */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* In case of TX only mode, if NACK is enabled, the USART must be able to monitor + the bidirectional line to detect a NACK signal in case of parity error. + Therefore, the receiver block must be enabled as well (RE bit must be set). */ + if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX) + && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE)) + { + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_RE); + } + /* Enable Tx */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_TE); + + /* Enable the Peripheral */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* Perform a TX/RX FIFO Flush */ + __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard); + + /* Set the SMARTCARD DMA transfer complete callback */ + hsmartcard->hdmatx->XferCpltCallback = SMARTCARD_DMATransmitCplt; + + /* Set the SMARTCARD error callback */ + hsmartcard->hdmatx->XferErrorCallback = SMARTCARD_DMAError; + + /* Set the DMA abort callback */ + hsmartcard->hdmatx->XferAbortCallback = NULL; + + /* Enable the SMARTCARD transmit DMA channel */ + if (HAL_DMA_Start_IT(hsmartcard->hdmatx, (uint32_t)hsmartcard->pTxBuffPtr, (uint32_t)&hsmartcard->Instance->TDR, + Size) == HAL_OK) + { + /* Clear the TC flag in the ICR register */ + CLEAR_BIT(hsmartcard->Instance->ICR, USART_ICR_TCCF); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + /* Enable the UART Error Interrupt: (Frame error) */ + SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* Enable the DMA transfer for transmit request by setting the DMAT bit + in the SMARTCARD associated USART CR3 register */ + SET_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT); + + return HAL_OK; + } + else + { + /* Set error code to DMA */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + /* Restore hsmartcard->State to ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + return HAL_ERROR; + } + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in DMA mode. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param pData pointer to data buffer. + * @param Size amount of data to be received. + * @note The SMARTCARD-associated USART parity is enabled (PCE = 1), + * the received data contain the parity bit (MSB position). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Receive_DMA(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t *pData, uint16_t Size) +{ + /* Check that a Rx process is not already ongoing */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + hsmartcard->RxState = HAL_SMARTCARD_STATE_BUSY_RX; + + hsmartcard->pRxBuffPtr = pData; + hsmartcard->RxXferSize = Size; + + /* Set the SMARTCARD DMA transfer complete callback */ + hsmartcard->hdmarx->XferCpltCallback = SMARTCARD_DMAReceiveCplt; + + /* Set the SMARTCARD DMA error callback */ + hsmartcard->hdmarx->XferErrorCallback = SMARTCARD_DMAError; + + /* Set the DMA abort callback */ + hsmartcard->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(hsmartcard->hdmarx, (uint32_t)&hsmartcard->Instance->RDR, (uint32_t)hsmartcard->pRxBuffPtr, + Size) == HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + /* Enable the SMARTCARD Parity Error Interrupt */ + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE); + + /* Enable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* Enable the DMA transfer for the receiver request by setting the DMAR bit + in the SMARTCARD associated USART CR3 register */ + SET_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR); + + return HAL_OK; + } + else + { + /* Set error code to DMA */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + /* Restore hsmartcard->State to ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + return HAL_ERROR; + } + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Abort ongoing transfers (blocking mode). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SMARTCARD Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Abort(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable RTOIE, EOBIE, TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, + (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE | USART_CR1_RTOIE | + USART_CR1_EOBIE)); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* Disable the SMARTCARD DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT); + + /* Abort the SMARTCARD DMA Tx channel : use blocking DMA Abort API (no callback) */ + if (hsmartcard->hdmatx != NULL) + { + /* Set the SMARTCARD DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hsmartcard->hdmatx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hsmartcard->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(hsmartcard->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Disable the SMARTCARD DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR); + + /* Abort the SMARTCARD DMA Rx channel : use blocking DMA Abort API (no callback) */ + if (hsmartcard->hdmarx != NULL) + { + /* Set the SMARTCARD DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hsmartcard->hdmarx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hsmartcard->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(hsmartcard->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Tx and Rx transfer counters */ + hsmartcard->TxXferCount = 0U; + hsmartcard->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | + SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* Reset Handle ErrorCode to No Error */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + + return HAL_OK; +} + +/** + * @brief Abort ongoing Transmit transfer (blocking mode). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SMARTCARD Interrupts (Tx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable TXEIE and TCIE interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* Check if a receive process is ongoing or not. If not disable ERR IT */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY) + { + /* Disable the SMARTCARD Error Interrupt: (Frame error) */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + } + + /* Disable the SMARTCARD DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT); + + /* Abort the SMARTCARD DMA Tx channel : use blocking DMA Abort API (no callback) */ + if (hsmartcard->hdmatx != NULL) + { + /* Set the SMARTCARD DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hsmartcard->hdmatx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hsmartcard->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(hsmartcard->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Tx transfer counter */ + hsmartcard->TxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, SMARTCARD_CLEAR_FEF); + + /* Restore hsmartcard->gState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Abort ongoing Receive transfer (blocking mode). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SMARTCARD Interrupts (Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable RTOIE, EOBIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_RTOIE | USART_CR1_EOBIE)); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* Check if a Transmit process is ongoing or not. If not disable ERR IT */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + /* Disable the SMARTCARD Error Interrupt: (Frame error) */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + } + + /* Disable the SMARTCARD DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR); + + /* Abort the SMARTCARD DMA Rx channel : use blocking DMA Abort API (no callback) */ + if (hsmartcard->hdmarx != NULL) + { + /* Set the SMARTCARD DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + hsmartcard->hdmarx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(hsmartcard->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(hsmartcard->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Rx transfer counter */ + hsmartcard->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | + SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->RxState to Ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Abort ongoing transfers (Interrupt mode). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SMARTCARD Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_Abort_IT(SMARTCARD_HandleTypeDef *hsmartcard) +{ + uint32_t abortcplt = 1U; + + /* Disable RTOIE, EOBIE, TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, + (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE | USART_CR1_RTOIE | + USART_CR1_EOBIE)); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* If DMA Tx and/or DMA Rx Handles are associated to SMARTCARD Handle, + DMA Abort complete callbacks should be initialised before any call + to DMA Abort functions */ + /* DMA Tx Handle is valid */ + if (hsmartcard->hdmatx != NULL) + { + /* Set DMA Abort Complete callback if SMARTCARD DMA Tx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT)) + { + hsmartcard->hdmatx->XferAbortCallback = SMARTCARD_DMATxAbortCallback; + } + else + { + hsmartcard->hdmatx->XferAbortCallback = NULL; + } + } + /* DMA Rx Handle is valid */ + if (hsmartcard->hdmarx != NULL) + { + /* Set DMA Abort Complete callback if SMARTCARD DMA Rx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + { + hsmartcard->hdmarx->XferAbortCallback = SMARTCARD_DMARxAbortCallback; + } + else + { + hsmartcard->hdmarx->XferAbortCallback = NULL; + } + } + + /* Disable the SMARTCARD DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT)) + { + /* Disable DMA Tx at UART level */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT); + + /* Abort the SMARTCARD DMA Tx channel : use non blocking DMA Abort API (callback) */ + if (hsmartcard->hdmatx != NULL) + { + /* SMARTCARD Tx DMA Abort callback has already been initialised : + will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hsmartcard->hdmatx) != HAL_OK) + { + hsmartcard->hdmatx->XferAbortCallback = NULL; + } + else + { + abortcplt = 0U; + } + } + } + + /* Disable the SMARTCARD DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR); + + /* Abort the SMARTCARD DMA Rx channel : use non blocking DMA Abort API (callback) */ + if (hsmartcard->hdmarx != NULL) + { + /* SMARTCARD Rx DMA Abort callback has already been initialised : + will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hsmartcard->hdmarx) != HAL_OK) + { + hsmartcard->hdmarx->XferAbortCallback = NULL; + abortcplt = 1U; + } + else + { + abortcplt = 0U; + } + } + } + + /* if no DMA abort complete callback execution is required => call user Abort Complete callback */ + if (abortcplt == 1U) + { + /* Reset Tx and Rx transfer counters */ + hsmartcard->TxXferCount = 0U; + hsmartcard->RxXferCount = 0U; + + /* Clear ISR function pointers */ + hsmartcard->RxISR = NULL; + hsmartcard->TxISR = NULL; + + /* Reset errorCode */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | + SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + hsmartcard->AbortCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort complete callback */ + HAL_SMARTCARD_AbortCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing Transmit transfer (Interrupt mode). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SMARTCARD Interrupts (Tx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_AbortTransmit_IT(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable TXEIE and TCIE interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* Check if a receive process is ongoing or not. If not disable ERR IT */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY) + { + /* Disable the SMARTCARD Error Interrupt: (Frame error) */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + } + + /* Disable the SMARTCARD DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT); + + /* Abort the SMARTCARD DMA Tx channel : use non blocking DMA Abort API (callback) */ + if (hsmartcard->hdmatx != NULL) + { + /* Set the SMARTCARD DMA Abort callback : + will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */ + hsmartcard->hdmatx->XferAbortCallback = SMARTCARD_DMATxOnlyAbortCallback; + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hsmartcard->hdmatx) != HAL_OK) + { + /* Call Directly hsmartcard->hdmatx->XferAbortCallback function in case of error */ + hsmartcard->hdmatx->XferAbortCallback(hsmartcard->hdmatx); + } + } + else + { + /* Reset Tx transfer counter */ + hsmartcard->TxXferCount = 0U; + + /* Clear TxISR function pointers */ + hsmartcard->TxISR = NULL; + + /* Restore hsmartcard->gState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + hsmartcard->AbortTransmitCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_SMARTCARD_AbortTransmitCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + } + else + { + /* Reset Tx transfer counter */ + hsmartcard->TxXferCount = 0U; + + /* Clear TxISR function pointers */ + hsmartcard->TxISR = NULL; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, SMARTCARD_CLEAR_FEF); + + /* Restore hsmartcard->gState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + hsmartcard->AbortTransmitCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_SMARTCARD_AbortTransmitCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing Receive transfer (Interrupt mode). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SMARTCARD Interrupts (Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARD_AbortReceive_IT(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable RTOIE, EOBIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_RTOIE | USART_CR1_EOBIE)); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* Check if a Transmit process is ongoing or not. If not disable ERR IT */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + /* Disable the SMARTCARD Error Interrupt: (Frame error) */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + } + + /* Disable the SMARTCARD DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR); + + /* Abort the SMARTCARD DMA Rx channel : use non blocking DMA Abort API (callback) */ + if (hsmartcard->hdmarx != NULL) + { + /* Set the SMARTCARD DMA Abort callback : + will lead to call HAL_SMARTCARD_AbortCpltCallback() at end of DMA abort procedure */ + hsmartcard->hdmarx->XferAbortCallback = SMARTCARD_DMARxOnlyAbortCallback; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hsmartcard->hdmarx) != HAL_OK) + { + /* Call Directly hsmartcard->hdmarx->XferAbortCallback function in case of error */ + hsmartcard->hdmarx->XferAbortCallback(hsmartcard->hdmarx); + } + } + else + { + /* Reset Rx transfer counter */ + hsmartcard->RxXferCount = 0U; + + /* Clear RxISR function pointer */ + hsmartcard->RxISR = NULL; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | + SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->RxState to Ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + hsmartcard->AbortReceiveCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_SMARTCARD_AbortReceiveCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + } + else + { + /* Reset Rx transfer counter */ + hsmartcard->RxXferCount = 0U; + + /* Clear RxISR function pointer */ + hsmartcard->RxISR = NULL; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | + SMARTCARD_CLEAR_FEF | SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->RxState to Ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + hsmartcard->AbortReceiveCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_SMARTCARD_AbortReceiveCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + + return HAL_OK; +} + +/** + * @brief Handle SMARTCARD interrupt requests. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +void HAL_SMARTCARD_IRQHandler(SMARTCARD_HandleTypeDef *hsmartcard) +{ + uint32_t isrflags = READ_REG(hsmartcard->Instance->ISR); + uint32_t cr1its = READ_REG(hsmartcard->Instance->CR1); + uint32_t cr3its = READ_REG(hsmartcard->Instance->CR3); + uint32_t errorflags; + uint32_t errorcode; + + /* If no error occurs */ + errorflags = (isrflags & (uint32_t)(USART_ISR_PE | USART_ISR_FE | USART_ISR_ORE | USART_ISR_NE | USART_ISR_RTOF)); + if (errorflags == 0U) + { + /* SMARTCARD in mode Receiver ---------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) + && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + if (hsmartcard->RxISR != NULL) + { + hsmartcard->RxISR(hsmartcard); + } + return; + } + } + + /* If some errors occur */ + if ((errorflags != 0U) + && (((cr3its & USART_CR3_EIE) != 0U) + || ((cr1its & (USART_CR1_RXNEIE | USART_CR1_PEIE)) != 0U))) + { + /* SMARTCARD parity error interrupt occurred -------------------------------------*/ + if (((isrflags & USART_ISR_PE) != 0U) && ((cr1its & USART_CR1_PEIE) != 0U)) + { + __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_PEF); + + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_PE; + } + + /* SMARTCARD frame error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_FE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_FEF); + + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_FE; + } + + /* SMARTCARD noise error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_NE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_NEF); + + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_NE; + } + + /* SMARTCARD Over-Run interrupt occurred -----------------------------------------*/ + if (((isrflags & USART_ISR_ORE) != 0U) + && (((cr1its & USART_CR1_RXNEIE) != 0U) + || ((cr3its & USART_CR3_EIE) != 0U))) + { + __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_OREF); + + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_ORE; + } + + /* SMARTCARD receiver timeout interrupt occurred -----------------------------------------*/ + if (((isrflags & USART_ISR_RTOF) != 0U) && ((cr1its & USART_CR1_RTOIE) != 0U)) + { + __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_RTOF); + + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_RTO; + } + + /* Call SMARTCARD Error Call back function if need be --------------------------*/ + if (hsmartcard->ErrorCode != HAL_SMARTCARD_ERROR_NONE) + { + /* SMARTCARD in mode Receiver ---------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) + && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + if (hsmartcard->RxISR != NULL) + { + hsmartcard->RxISR(hsmartcard); + } + } + + /* If Error is to be considered as blocking : + - Receiver Timeout error in Reception + - Overrun error in Reception + - any error occurs in DMA mode reception + */ + errorcode = hsmartcard->ErrorCode; + if ((HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + || ((errorcode & (HAL_SMARTCARD_ERROR_RTO | HAL_SMARTCARD_ERROR_ORE)) != 0U)) + { + /* Blocking error : transfer is aborted + Set the SMARTCARD state ready to be able to start again the process, + Disable Rx Interrupts, and disable Rx DMA request, if ongoing */ + SMARTCARD_EndRxTransfer(hsmartcard); + + /* Disable the SMARTCARD DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR); + + /* Abort the SMARTCARD DMA Rx channel */ + if (hsmartcard->hdmarx != NULL) + { + /* Set the SMARTCARD DMA Abort callback : + will lead to call HAL_SMARTCARD_ErrorCallback() at end of DMA abort procedure */ + hsmartcard->hdmarx->XferAbortCallback = SMARTCARD_DMAAbortOnError; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(hsmartcard->hdmarx) != HAL_OK) + { + /* Call Directly hsmartcard->hdmarx->XferAbortCallback function in case of error */ + hsmartcard->hdmarx->XferAbortCallback(hsmartcard->hdmarx); + } + } + else + { +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hsmartcard->ErrorCallback(hsmartcard); +#else + /* Call legacy weak user error callback */ + HAL_SMARTCARD_ErrorCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + } + else + { +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hsmartcard->ErrorCallback(hsmartcard); +#else + /* Call legacy weak user error callback */ + HAL_SMARTCARD_ErrorCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + } + /* other error type to be considered as blocking : + - Frame error in Transmission + */ + else if ((hsmartcard->gState == HAL_SMARTCARD_STATE_BUSY_TX) + && ((errorcode & HAL_SMARTCARD_ERROR_FE) != 0U)) + { + /* Blocking error : transfer is aborted + Set the SMARTCARD state ready to be able to start again the process, + Disable Tx Interrupts, and disable Tx DMA request, if ongoing */ + SMARTCARD_EndTxTransfer(hsmartcard); + + /* Disable the SMARTCARD DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT); + + /* Abort the SMARTCARD DMA Tx channel */ + if (hsmartcard->hdmatx != NULL) + { + /* Set the SMARTCARD DMA Abort callback : + will lead to call HAL_SMARTCARD_ErrorCallback() at end of DMA abort procedure */ + hsmartcard->hdmatx->XferAbortCallback = SMARTCARD_DMAAbortOnError; + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(hsmartcard->hdmatx) != HAL_OK) + { + /* Call Directly hsmartcard->hdmatx->XferAbortCallback function in case of error */ + hsmartcard->hdmatx->XferAbortCallback(hsmartcard->hdmatx); + } + } + else + { +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hsmartcard->ErrorCallback(hsmartcard); +#else + /* Call legacy weak user error callback */ + HAL_SMARTCARD_ErrorCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + } + else + { +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hsmartcard->ErrorCallback(hsmartcard); +#else + /* Call legacy weak user error callback */ + HAL_SMARTCARD_ErrorCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + } + else + { + /* Non Blocking error : transfer could go on. + Error is notified to user through user error callback */ +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hsmartcard->ErrorCallback(hsmartcard); +#else + /* Call legacy weak user error callback */ + HAL_SMARTCARD_ErrorCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + } + } + return; + + } /* End if some error occurs */ + + /* SMARTCARD in mode Receiver, end of block interruption ------------------------*/ + if (((isrflags & USART_ISR_EOBF) != 0U) && ((cr1its & USART_CR1_EOBIE) != 0U)) + { + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + __HAL_UNLOCK(hsmartcard); +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Rx complete callback */ + hsmartcard->RxCpltCallback(hsmartcard); +#else + /* Call legacy weak Rx complete callback */ + HAL_SMARTCARD_RxCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + /* Clear EOBF interrupt after HAL_SMARTCARD_RxCpltCallback() call for the End of Block information + to be available during HAL_SMARTCARD_RxCpltCallback() processing */ + __HAL_SMARTCARD_CLEAR_IT(hsmartcard, SMARTCARD_CLEAR_EOBF); + return; + } + + /* SMARTCARD in mode Transmitter ------------------------------------------------*/ + if (((isrflags & USART_ISR_TXE) != 0U) + && ((cr1its & USART_CR1_TXEIE) != 0U)) + { + if (hsmartcard->TxISR != NULL) + { + hsmartcard->TxISR(hsmartcard); + } + return; + } + + /* SMARTCARD in mode Transmitter (transmission end) ------------------------*/ + if (__HAL_SMARTCARD_GET_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication) != RESET) + { + if (__HAL_SMARTCARD_GET_IT_SOURCE(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication) != RESET) + { + SMARTCARD_EndTransmit_IT(hsmartcard); + return; + } + } + +} + +/** + * @brief Tx Transfer completed callback. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_TxCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_TxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Rx Transfer completed callback. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_RxCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_RxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief SMARTCARD error callback. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_ErrorCallback(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_ErrorCallback can be implemented in the user file. + */ +} + +/** + * @brief SMARTCARD Abort Complete callback. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_AbortCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_AbortCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief SMARTCARD Abort Complete callback. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_AbortTransmitCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_AbortTransmitCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief SMARTCARD Abort Receive Complete callback. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +__weak void HAL_SMARTCARD_AbortReceiveCpltCallback(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmartcard); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMARTCARD_AbortReceiveCpltCallback can be implemented in the user file. + */ +} + +/** + * @} + */ + +/** @defgroup SMARTCARD_Exported_Functions_Group4 Peripheral State and Errors functions + * @brief SMARTCARD State and Errors functions + * +@verbatim + ============================================================================== + ##### Peripheral State and Errors functions ##### + ============================================================================== + [..] + This subsection provides a set of functions allowing to return the State of SmartCard + handle and also return Peripheral Errors occurred during communication process + (+) HAL_SMARTCARD_GetState() API can be helpful to check in run-time the state + of the SMARTCARD peripheral. + (+) HAL_SMARTCARD_GetError() checks in run-time errors that could occur during + communication. + +@endverbatim + * @{ + */ + +/** + * @brief Return the SMARTCARD handle state. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval SMARTCARD handle state + */ +HAL_SMARTCARD_StateTypeDef HAL_SMARTCARD_GetState(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Return SMARTCARD handle state */ + uint32_t temp1; + uint32_t temp2; + temp1 = (uint32_t)hsmartcard->gState; + temp2 = (uint32_t)hsmartcard->RxState; + + return (HAL_SMARTCARD_StateTypeDef)(temp1 | temp2); +} + +/** + * @brief Return the SMARTCARD handle error code. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval SMARTCARD handle Error Code + */ +uint32_t HAL_SMARTCARD_GetError(SMARTCARD_HandleTypeDef *hsmartcard) +{ + return hsmartcard->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup SMARTCARD_Private_Functions SMARTCARD Private Functions + * @{ + */ + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) +/** + * @brief Initialize the callbacks to their default values. + * @param hsmartcard SMARTCARD handle. + * @retval none + */ +void SMARTCARD_InitCallbacksToDefault(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Init the SMARTCARD Callback settings */ + hsmartcard->TxCpltCallback = HAL_SMARTCARD_TxCpltCallback; /* Legacy weak TxCpltCallback */ + hsmartcard->RxCpltCallback = HAL_SMARTCARD_RxCpltCallback; /* Legacy weak RxCpltCallback */ + hsmartcard->ErrorCallback = HAL_SMARTCARD_ErrorCallback; /* Legacy weak ErrorCallback */ + hsmartcard->AbortCpltCallback = HAL_SMARTCARD_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + hsmartcard->AbortTransmitCpltCallback = HAL_SMARTCARD_AbortTransmitCpltCallback; /* Legacy weak + AbortTransmitCpltCallback */ + hsmartcard->AbortReceiveCpltCallback = HAL_SMARTCARD_AbortReceiveCpltCallback; /* Legacy weak + AbortReceiveCpltCallback */ + +} +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACKS */ + +/** + * @brief Configure the SMARTCARD associated USART peripheral. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval HAL status + */ +static HAL_StatusTypeDef SMARTCARD_SetConfig(SMARTCARD_HandleTypeDef *hsmartcard) +{ + uint32_t tmpreg; + SMARTCARD_ClockSourceTypeDef clocksource; + HAL_StatusTypeDef ret = HAL_OK; + uint32_t pclk; + + /* Check the parameters */ + assert_param(IS_SMARTCARD_INSTANCE(hsmartcard->Instance)); + assert_param(IS_SMARTCARD_BAUDRATE(hsmartcard->Init.BaudRate)); + assert_param(IS_SMARTCARD_WORD_LENGTH(hsmartcard->Init.WordLength)); + assert_param(IS_SMARTCARD_STOPBITS(hsmartcard->Init.StopBits)); + assert_param(IS_SMARTCARD_PARITY(hsmartcard->Init.Parity)); + assert_param(IS_SMARTCARD_MODE(hsmartcard->Init.Mode)); + assert_param(IS_SMARTCARD_POLARITY(hsmartcard->Init.CLKPolarity)); + assert_param(IS_SMARTCARD_PHASE(hsmartcard->Init.CLKPhase)); + assert_param(IS_SMARTCARD_LASTBIT(hsmartcard->Init.CLKLastBit)); + assert_param(IS_SMARTCARD_ONE_BIT_SAMPLE(hsmartcard->Init.OneBitSampling)); + assert_param(IS_SMARTCARD_NACK(hsmartcard->Init.NACKEnable)); + assert_param(IS_SMARTCARD_TIMEOUT(hsmartcard->Init.TimeOutEnable)); + assert_param(IS_SMARTCARD_AUTORETRY_COUNT(hsmartcard->Init.AutoRetryCount)); + + /*-------------------------- USART CR1 Configuration -----------------------*/ + /* In SmartCard mode, M and PCE are forced to 1 (8 bits + parity). + * Oversampling is forced to 16 (OVER8 = 0). + * Configure the Parity and Mode: + * set PS bit according to hsmartcard->Init.Parity value + * set TE and RE bits according to hsmartcard->Init.Mode value */ + tmpreg = (((uint32_t)hsmartcard->Init.Parity) | ((uint32_t)hsmartcard->Init.Mode) | + ((uint32_t)hsmartcard->Init.WordLength)); + MODIFY_REG(hsmartcard->Instance->CR1, USART_CR1_FIELDS, tmpreg); + + /*-------------------------- USART CR2 Configuration -----------------------*/ + tmpreg = hsmartcard->Init.StopBits; + /* Synchronous mode is activated by default */ + tmpreg |= (uint32_t) USART_CR2_CLKEN | hsmartcard->Init.CLKPolarity; + tmpreg |= (uint32_t) hsmartcard->Init.CLKPhase | hsmartcard->Init.CLKLastBit; + tmpreg |= (uint32_t) hsmartcard->Init.TimeOutEnable; + MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_FIELDS, tmpreg); + + /*-------------------------- USART CR3 Configuration -----------------------*/ + /* Configure + * - one-bit sampling method versus three samples' majority rule + * according to hsmartcard->Init.OneBitSampling + * - NACK transmission in case of parity error according + * to hsmartcard->Init.NACKEnable + * - autoretry counter according to hsmartcard->Init.AutoRetryCount */ + + tmpreg = (uint32_t) hsmartcard->Init.OneBitSampling | hsmartcard->Init.NACKEnable; + tmpreg |= ((uint32_t)hsmartcard->Init.AutoRetryCount << USART_CR3_SCARCNT_Pos); + MODIFY_REG(hsmartcard->Instance->CR3, USART_CR3_FIELDS, tmpreg); + + + /*-------------------------- USART GTPR Configuration ----------------------*/ + tmpreg = (hsmartcard->Init.Prescaler | ((uint32_t)hsmartcard->Init.GuardTime << USART_GTPR_GT_Pos)); + MODIFY_REG(hsmartcard->Instance->GTPR, (uint16_t)(USART_GTPR_GT | USART_GTPR_PSC), (uint16_t)tmpreg); + + /*-------------------------- USART RTOR Configuration ----------------------*/ + tmpreg = ((uint32_t)hsmartcard->Init.BlockLength << USART_RTOR_BLEN_Pos); + if (hsmartcard->Init.TimeOutEnable == SMARTCARD_TIMEOUT_ENABLE) + { + assert_param(IS_SMARTCARD_TIMEOUT_VALUE(hsmartcard->Init.TimeOutValue)); + tmpreg |= (uint32_t) hsmartcard->Init.TimeOutValue; + } + MODIFY_REG(hsmartcard->Instance->RTOR, (USART_RTOR_RTO | USART_RTOR_BLEN), tmpreg); + + /*-------------------------- USART BRR Configuration -----------------------*/ + SMARTCARD_GETCLOCKSOURCE(hsmartcard, clocksource); + tmpreg = 0U; + switch (clocksource) + { + case SMARTCARD_CLOCKSOURCE_PCLK1: + pclk = HAL_RCC_GetPCLK1Freq(); + tmpreg = (uint16_t)((pclk + (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate); + break; + case SMARTCARD_CLOCKSOURCE_HSI: + tmpreg = (uint16_t)((HSI_VALUE + (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate); + break; + case SMARTCARD_CLOCKSOURCE_SYSCLK: + pclk = HAL_RCC_GetSysClockFreq(); + tmpreg = (uint16_t)((pclk + (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate); + break; + case SMARTCARD_CLOCKSOURCE_LSE: + tmpreg = (uint16_t)((LSE_VALUE + (hsmartcard->Init.BaudRate / 2U)) / hsmartcard->Init.BaudRate); + break; + default: + ret = HAL_ERROR; + break; + } + + /* USARTDIV must be greater than or equal to 0d16 */ + if ((tmpreg >= USART_BRR_MIN) && (tmpreg <= USART_BRR_MAX)) + { + hsmartcard->Instance->BRR = tmpreg; + } + else + { + ret = HAL_ERROR; + } + + + /* Clear ISR function pointers */ + hsmartcard->RxISR = NULL; + hsmartcard->TxISR = NULL; + + return ret; +} + + +/** + * @brief Configure the SMARTCARD associated USART peripheral advanced features. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +static void SMARTCARD_AdvFeatureConfig(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Check whether the set of advanced features to configure is properly set */ + assert_param(IS_SMARTCARD_ADVFEATURE_INIT(hsmartcard->AdvancedInit.AdvFeatureInit)); + + /* if required, configure TX pin active level inversion */ + if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_TXINVERT_INIT)) + { + assert_param(IS_SMARTCARD_ADVFEATURE_TXINV(hsmartcard->AdvancedInit.TxPinLevelInvert)); + MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_TXINV, hsmartcard->AdvancedInit.TxPinLevelInvert); + } + + /* if required, configure RX pin active level inversion */ + if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_RXINVERT_INIT)) + { + assert_param(IS_SMARTCARD_ADVFEATURE_RXINV(hsmartcard->AdvancedInit.RxPinLevelInvert)); + MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_RXINV, hsmartcard->AdvancedInit.RxPinLevelInvert); + } + + /* if required, configure data inversion */ + if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_DATAINVERT_INIT)) + { + assert_param(IS_SMARTCARD_ADVFEATURE_DATAINV(hsmartcard->AdvancedInit.DataInvert)); + MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_DATAINV, hsmartcard->AdvancedInit.DataInvert); + } + + /* if required, configure RX/TX pins swap */ + if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_SWAP_INIT)) + { + assert_param(IS_SMARTCARD_ADVFEATURE_SWAP(hsmartcard->AdvancedInit.Swap)); + MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_SWAP, hsmartcard->AdvancedInit.Swap); + } + + /* if required, configure RX overrun detection disabling */ + if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_RXOVERRUNDISABLE_INIT)) + { + assert_param(IS_SMARTCARD_OVERRUN(hsmartcard->AdvancedInit.OverrunDisable)); + MODIFY_REG(hsmartcard->Instance->CR3, USART_CR3_OVRDIS, hsmartcard->AdvancedInit.OverrunDisable); + } + + /* if required, configure DMA disabling on reception error */ + if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_DMADISABLEONERROR_INIT)) + { + assert_param(IS_SMARTCARD_ADVFEATURE_DMAONRXERROR(hsmartcard->AdvancedInit.DMADisableonRxError)); + MODIFY_REG(hsmartcard->Instance->CR3, USART_CR3_DDRE, hsmartcard->AdvancedInit.DMADisableonRxError); + } + + /* if required, configure MSB first on communication line */ + if (HAL_IS_BIT_SET(hsmartcard->AdvancedInit.AdvFeatureInit, SMARTCARD_ADVFEATURE_MSBFIRST_INIT)) + { + assert_param(IS_SMARTCARD_ADVFEATURE_MSBFIRST(hsmartcard->AdvancedInit.MSBFirst)); + MODIFY_REG(hsmartcard->Instance->CR2, USART_CR2_MSBFIRST, hsmartcard->AdvancedInit.MSBFirst); + } + +} + +/** + * @brief Check the SMARTCARD Idle State. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval HAL status + */ +static HAL_StatusTypeDef SMARTCARD_CheckIdleState(SMARTCARD_HandleTypeDef *hsmartcard) +{ + uint32_t tickstart; + + /* Initialize the SMARTCARD ErrorCode */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + /* Check if the Transmitter is enabled */ + if ((hsmartcard->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE) + { + /* Wait until TEACK flag is set */ + if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, USART_ISR_TEACK, RESET, tickstart, + SMARTCARD_TEACK_REACK_TIMEOUT) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + /* Check if the Receiver is enabled */ + if ((hsmartcard->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE) + { + /* Wait until REACK flag is set */ + if (SMARTCARD_WaitOnFlagUntilTimeout(hsmartcard, USART_ISR_REACK, RESET, tickstart, + SMARTCARD_TEACK_REACK_TIMEOUT) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + + /* Initialize the SMARTCARD states */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + return HAL_OK; +} + +/** + * @brief Handle SMARTCARD Communication Timeout. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param Flag Specifies the SMARTCARD flag to check. + * @param Status The new Flag status (SET or RESET). + * @param Tickstart Tick start value + * @param Timeout Timeout duration. + * @retval HAL status + */ +static HAL_StatusTypeDef SMARTCARD_WaitOnFlagUntilTimeout(SMARTCARD_HandleTypeDef *hsmartcard, uint32_t Flag, + FlagStatus Status, uint32_t Tickstart, uint32_t Timeout) +{ + /* Wait until flag is set */ + while ((__HAL_SMARTCARD_GET_FLAG(hsmartcard, Flag) ? SET : RESET) == Status) + { + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + /* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error) + interrupts for the interrupt process */ + CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE)); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + return HAL_TIMEOUT; + } + } + } + return HAL_OK; +} + + +/** + * @brief End ongoing Tx transfer on SMARTCARD peripheral (following error detection or Transmit completion). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +static void SMARTCARD_EndTxTransfer(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable TXEIE, TCIE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* At end of Tx process, restore hsmartcard->gState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; +} + + +/** + * @brief End ongoing Rx transfer on UART peripheral (following error detection or Reception completion). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +static void SMARTCARD_EndRxTransfer(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* At end of Rx process, restore hsmartcard->RxState to Ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; +} + + +/** + * @brief DMA SMARTCARD transmit process complete callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SMARTCARD_DMATransmitCplt(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + hsmartcard->TxXferCount = 0U; + + /* Disable the DMA transfer for transmit request by resetting the DMAT bit + in the SMARTCARD associated USART CR3 register */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAT); + + /* Enable the SMARTCARD Transmit Complete Interrupt */ + __HAL_SMARTCARD_ENABLE_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication); +} + +/** + * @brief DMA SMARTCARD receive process complete callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SMARTCARD_DMAReceiveCplt(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + hsmartcard->RxXferCount = 0U; + + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE); + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + + /* Disable the DMA transfer for the receiver request by resetting the DMAR bit + in the SMARTCARD associated USART CR3 register */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_DMAR); + + /* At end of Rx process, restore hsmartcard->RxState to Ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Rx complete callback */ + hsmartcard->RxCpltCallback(hsmartcard); +#else + /* Call legacy weak Rx complete callback */ + HAL_SMARTCARD_RxCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + +/** + * @brief DMA SMARTCARD communication error callback. + * @param hdma Pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SMARTCARD_DMAError(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + + /* Stop SMARTCARD DMA Tx request if ongoing */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_BUSY_TX) + { + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAT)) + { + hsmartcard->TxXferCount = 0U; + SMARTCARD_EndTxTransfer(hsmartcard); + } + } + + /* Stop SMARTCARD DMA Rx request if ongoing */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_BUSY_RX) + { + if (HAL_IS_BIT_SET(hsmartcard->Instance->CR3, USART_CR3_DMAR)) + { + hsmartcard->RxXferCount = 0U; + SMARTCARD_EndRxTransfer(hsmartcard); + } + } + + hsmartcard->ErrorCode |= HAL_SMARTCARD_ERROR_DMA; +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hsmartcard->ErrorCallback(hsmartcard); +#else + /* Call legacy weak user error callback */ + HAL_SMARTCARD_ErrorCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + +/** + * @brief DMA SMARTCARD communication abort callback, when initiated by HAL services on Error + * (To be called at end of DMA Abort procedure following error occurrence). + * @param hdma DMA handle. + * @retval None + */ +static void SMARTCARD_DMAAbortOnError(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + hsmartcard->RxXferCount = 0U; + hsmartcard->TxXferCount = 0U; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered user error callback */ + hsmartcard->ErrorCallback(hsmartcard); +#else + /* Call legacy weak user error callback */ + HAL_SMARTCARD_ErrorCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + +/** + * @brief DMA SMARTCARD Tx communication abort callback, when initiated by user + * (To be called at end of DMA Tx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Rx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void SMARTCARD_DMATxAbortCallback(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + + hsmartcard->hdmatx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (hsmartcard->hdmarx != NULL) + { + if (hsmartcard->hdmarx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + hsmartcard->TxXferCount = 0U; + hsmartcard->RxXferCount = 0U; + + /* Reset errorCode */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | + SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + hsmartcard->AbortCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort complete callback */ + HAL_SMARTCARD_AbortCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + + +/** + * @brief DMA SMARTCARD Rx communication abort callback, when initiated by user + * (To be called at end of DMA Rx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Tx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void SMARTCARD_DMARxAbortCallback(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + + hsmartcard->hdmarx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (hsmartcard->hdmatx != NULL) + { + if (hsmartcard->hdmatx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + hsmartcard->TxXferCount = 0U; + hsmartcard->RxXferCount = 0U; + + /* Reset errorCode */ + hsmartcard->ErrorCode = HAL_SMARTCARD_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | + SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->gState and hsmartcard->RxState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + hsmartcard->AbortCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort complete callback */ + HAL_SMARTCARD_AbortCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + + +/** + * @brief DMA SMARTCARD Tx communication abort callback, when initiated by user by a call to + * HAL_SMARTCARD_AbortTransmit_IT API (Abort only Tx transfer) + * (This callback is executed at end of DMA Tx Abort procedure following user abort request, + * and leads to user Tx Abort Complete callback execution). + * @param hdma DMA handle. + * @retval None + */ +static void SMARTCARD_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + + hsmartcard->TxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, SMARTCARD_CLEAR_FEF); + + /* Restore hsmartcard->gState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + hsmartcard->AbortTransmitCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_SMARTCARD_AbortTransmitCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + +/** + * @brief DMA SMARTCARD Rx communication abort callback, when initiated by user by a call to + * HAL_SMARTCARD_AbortReceive_IT API (Abort only Rx transfer) + * (This callback is executed at end of DMA Rx Abort procedure following user abort request, + * and leads to user Rx Abort Complete callback execution). + * @param hdma DMA handle. + * @retval None + */ +static void SMARTCARD_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma) +{ + SMARTCARD_HandleTypeDef *hsmartcard = (SMARTCARD_HandleTypeDef *)(hdma->Parent); + + hsmartcard->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_SMARTCARD_CLEAR_FLAG(hsmartcard, + SMARTCARD_CLEAR_OREF | SMARTCARD_CLEAR_NEF | SMARTCARD_CLEAR_PEF | SMARTCARD_CLEAR_FEF | + SMARTCARD_CLEAR_RTOF | SMARTCARD_CLEAR_EOBF); + + /* Restore hsmartcard->RxState to Ready */ + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + hsmartcard->AbortReceiveCpltCallback(hsmartcard); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_SMARTCARD_AbortReceiveCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + +/** + * @brief Send an amount of data in non-blocking mode. + * @note Function called under interruption only, once + * interruptions have been enabled by HAL_SMARTCARD_Transmit_IT(). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +static void SMARTCARD_TxISR(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Check that a Tx process is ongoing */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_BUSY_TX) + { + if (hsmartcard->TxXferCount == 0U) + { + /* Disable the SMARTCARD Transmit Data Register Empty Interrupt */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_TXEIE); + + /* Enable the SMARTCARD Transmit Complete Interrupt */ + __HAL_SMARTCARD_ENABLE_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication); + } + else + { + hsmartcard->Instance->TDR = (uint8_t)(*hsmartcard->pTxBuffPtr & 0xFFU); + hsmartcard->pTxBuffPtr++; + hsmartcard->TxXferCount--; + } + } +} + +/** + * @brief Wrap up transmission in non-blocking mode. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +static void SMARTCARD_EndTransmit_IT(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Disable the SMARTCARD Transmit Complete Interrupt */ + __HAL_SMARTCARD_DISABLE_IT(hsmartcard, hsmartcard->AdvancedInit.TxCompletionIndication); + + /* Check if a receive process is ongoing or not. If not disable ERR IT */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_READY) + { + /* Disable the SMARTCARD Error Interrupt: (Frame error) */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + } + + /* Disable the Peripheral first to update mode */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX) + && (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE)) + { + /* In case of TX only mode, if NACK is enabled, receiver block has been enabled + for Transmit phase. Disable this receiver block. */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_RE); + } + if ((hsmartcard->Init.Mode == SMARTCARD_MODE_TX_RX) + || (hsmartcard->Init.NACKEnable == SMARTCARD_NACK_ENABLE)) + { + /* Perform a TX FIFO Flush at end of Tx phase, as all sent bytes are appearing in Rx Data register */ + __HAL_SMARTCARD_FLUSH_DRREGISTER(hsmartcard); + } + SET_BIT(hsmartcard->Instance->CR1, USART_CR1_UE); + + /* Tx process is ended, restore hsmartcard->gState to Ready */ + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + /* Clear TxISR function pointer */ + hsmartcard->TxISR = NULL; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Tx complete callback */ + hsmartcard->TxCpltCallback(hsmartcard); +#else + /* Call legacy weak Tx complete callback */ + HAL_SMARTCARD_TxCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ +} + +/** + * @brief Receive an amount of data in non-blocking mode. + * @note Function called under interruption only, once + * interruptions have been enabled by HAL_SMARTCARD_Receive_IT(). + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval None + */ +static void SMARTCARD_RxISR(SMARTCARD_HandleTypeDef *hsmartcard) +{ + /* Check that a Rx process is ongoing */ + if (hsmartcard->RxState == HAL_SMARTCARD_STATE_BUSY_RX) + { + *hsmartcard->pRxBuffPtr = (uint8_t)(hsmartcard->Instance->RDR & (uint8_t)0xFF); + hsmartcard->pRxBuffPtr++; + + hsmartcard->RxXferCount--; + if (hsmartcard->RxXferCount == 0U) + { + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_RXNEIE); + + /* Check if a transmit process is ongoing or not. If not disable ERR IT */ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + /* Disable the SMARTCARD Error Interrupt: (Frame error, noise error, overrun error) */ + CLEAR_BIT(hsmartcard->Instance->CR3, USART_CR3_EIE); + } + + /* Disable the SMARTCARD Parity Error Interrupt */ + CLEAR_BIT(hsmartcard->Instance->CR1, USART_CR1_PEIE); + + hsmartcard->RxState = HAL_SMARTCARD_STATE_READY; + + /* Clear RxISR function pointer */ + hsmartcard->RxISR = NULL; + +#if (USE_HAL_SMARTCARD_REGISTER_CALLBACKS == 1) + /* Call registered Rx complete callback */ + hsmartcard->RxCpltCallback(hsmartcard); +#else + /* Call legacy weak Rx complete callback */ + HAL_SMARTCARD_RxCpltCallback(hsmartcard); +#endif /* USE_HAL_SMARTCARD_REGISTER_CALLBACK */ + } + } + else + { + /* Clear RXNE interrupt flag */ + __HAL_SMARTCARD_SEND_REQ(hsmartcard, SMARTCARD_RXDATA_FLUSH_REQUEST); + } +} + +/** + * @} + */ + +#endif /* HAL_SMARTCARD_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ +#endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) */ +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard_ex.c new file mode 100644 index 0000000..d87a221 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smartcard_ex.c @@ -0,0 +1,198 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_smartcard_ex.c + * @author MCD Application Team + * @brief SMARTCARD HAL module driver. + * This file provides extended firmware functions to manage the following + * functionalities of the SmartCard. + * + Initialization and de-initialization functions + * + Peripheral Control functions + * + @verbatim + ============================================================================= + ##### SMARTCARD peripheral extended features ##### + ============================================================================= + [..] + The Extended SMARTCARD HAL driver can be used as follows: + + (#) After having configured the SMARTCARD basic features with HAL_SMARTCARD_Init(), + then program SMARTCARD advanced features if required (TX/RX pins swap, TimeOut, + auto-retry counter,...) in the hsmartcard AdvancedInit structure. + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup SMARTCARDEx SMARTCARDEx + * @brief SMARTCARD Extended HAL module driver + * @{ + */ +#ifdef HAL_SMARTCARD_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ +/** @defgroup SMARTCARDEx_Exported_Functions SMARTCARD Extended Exported Functions + * @{ + */ + +/** @defgroup SMARTCARDEx_Exported_Functions_Group1 Extended Peripheral Control functions + * @brief Extended control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to initialize the SMARTCARD. + (+) HAL_SMARTCARDEx_BlockLength_Config() API allows to configure the Block Length on the fly + (+) HAL_SMARTCARDEx_TimeOut_Config() API allows to configure the receiver timeout value on the fly + (+) HAL_SMARTCARDEx_EnableReceiverTimeOut() API enables the receiver timeout feature + (+) HAL_SMARTCARDEx_DisableReceiverTimeOut() API disables the receiver timeout feature + +@endverbatim + * @{ + */ + +/** @brief Update on the fly the SMARTCARD block length in RTOR register. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param BlockLength SMARTCARD block length (8-bit long at most) + * @retval None + */ +void HAL_SMARTCARDEx_BlockLength_Config(SMARTCARD_HandleTypeDef *hsmartcard, uint8_t BlockLength) +{ + MODIFY_REG(hsmartcard->Instance->RTOR, USART_RTOR_BLEN, ((uint32_t)BlockLength << USART_RTOR_BLEN_Pos)); +} + +/** @brief Update on the fly the receiver timeout value in RTOR register. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @param TimeOutValue receiver timeout value in number of baud blocks. The timeout + * value must be less or equal to 0x0FFFFFFFF. + * @retval None + */ +void HAL_SMARTCARDEx_TimeOut_Config(SMARTCARD_HandleTypeDef *hsmartcard, uint32_t TimeOutValue) +{ + assert_param(IS_SMARTCARD_TIMEOUT_VALUE(hsmartcard->Init.TimeOutValue)); + MODIFY_REG(hsmartcard->Instance->RTOR, USART_RTOR_RTO, TimeOutValue); +} + +/** @brief Enable the SMARTCARD receiver timeout feature. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARDEx_EnableReceiverTimeOut(SMARTCARD_HandleTypeDef *hsmartcard) +{ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY; + + /* Set the USART RTOEN bit */ + SET_BIT(hsmartcard->Instance->CR2, USART_CR2_RTOEN); + + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** @brief Disable the SMARTCARD receiver timeout feature. + * @param hsmartcard Pointer to a SMARTCARD_HandleTypeDef structure that contains + * the configuration information for the specified SMARTCARD module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMARTCARDEx_DisableReceiverTimeOut(SMARTCARD_HandleTypeDef *hsmartcard) +{ + if (hsmartcard->gState == HAL_SMARTCARD_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hsmartcard); + + hsmartcard->gState = HAL_SMARTCARD_STATE_BUSY; + + /* Clear the USART RTOEN bit */ + CLEAR_BIT(hsmartcard->Instance->CR2, USART_CR2_RTOEN); + + hsmartcard->gState = HAL_SMARTCARD_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmartcard); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @} + */ + +/** @defgroup SMARTCARDEx_Exported_Functions_Group2 Extended Peripheral IO operation functions + * @brief SMARTCARD Transmit and Receive functions + * + * @{ + */ + +/** + * @} + */ + + +/** + * @} + */ + +/** @defgroup SMARTCARDEx_Private_Functions SMARTCARD Extended Private Functions + * @{ + */ + +/** + * @} + */ + +#endif /* HAL_SMARTCARD_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) */ +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smbus.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smbus.c new file mode 100644 index 0000000..f063886 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_smbus.c @@ -0,0 +1,2750 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_smbus.c + * @author MCD Application Team + * @brief SMBUS HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the System Management Bus (SMBus) peripheral, + * based on I2C principles of operation : + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral State and Errors functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The SMBUS HAL driver can be used as follows: + + (#) Declare a SMBUS_HandleTypeDef handle structure, for example: + SMBUS_HandleTypeDef hsmbus; + + (#)Initialize the SMBUS low level resources by implementing the HAL_SMBUS_MspInit() API: + (##) Enable the SMBUSx interface clock + (##) SMBUS pins configuration + (+++) Enable the clock for the SMBUS GPIOs + (+++) Configure SMBUS pins as alternate function open-drain + (##) NVIC configuration if you need to use interrupt process + (+++) Configure the SMBUSx interrupt priority + (+++) Enable the NVIC SMBUS IRQ Channel + + (#) Configure the Communication Clock Timing, Bus Timeout, Own Address1, Master Addressing mode, + Dual Addressing mode, Own Address2, Own Address2 Mask, General call, Nostretch mode, + Peripheral mode and Packet Error Check mode in the hsmbus Init structure. + + (#) Initialize the SMBUS registers by calling the HAL_SMBUS_Init() API: + (++) These API's configures also the low level Hardware GPIO, CLOCK, CORTEX...etc) + by calling the customized HAL_SMBUS_MspInit(&hsmbus) API. + + (#) To check if target device is ready for communication, use the function HAL_SMBUS_IsDeviceReady() + + (#) For SMBUS IO operations, only one mode of operations is available within this driver + + *** Interrupt mode IO operation *** + =================================== + [..] + (+) Transmit in master/host SMBUS mode an amount of data in non-blocking mode + using HAL_SMBUS_Master_Transmit_IT() + (++) At transmission end of transfer HAL_SMBUS_MasterTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_SMBUS_MasterTxCpltCallback() + (+) Receive in master/host SMBUS mode an amount of data in non-blocking mode + using HAL_SMBUS_Master_Receive_IT() + (++) At reception end of transfer HAL_SMBUS_MasterRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_SMBUS_MasterRxCpltCallback() + (+) Abort a master/host SMBUS process communication with Interrupt using HAL_SMBUS_Master_Abort_IT() + (++) The associated previous transfer callback is called at the end of abort process + (++) mean HAL_SMBUS_MasterTxCpltCallback() in case of previous state was master transmit + (++) mean HAL_SMBUS_MasterRxCpltCallback() in case of previous state was master receive + (+) Enable/disable the Address listen mode in slave/device or host/slave SMBUS mode + using HAL_SMBUS_EnableListen_IT() HAL_SMBUS_DisableListen_IT() + (++) When address slave/device SMBUS match, HAL_SMBUS_AddrCallback() is executed and users can + add their own code to check the Address Match Code and the transmission direction + request by master/host (Write/Read). + (++) At Listen mode end HAL_SMBUS_ListenCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_SMBUS_ListenCpltCallback() + (+) Transmit in slave/device SMBUS mode an amount of data in non-blocking mode + using HAL_SMBUS_Slave_Transmit_IT() + (++) At transmission end of transfer HAL_SMBUS_SlaveTxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_SMBUS_SlaveTxCpltCallback() + (+) Receive in slave/device SMBUS mode an amount of data in non-blocking mode + using HAL_SMBUS_Slave_Receive_IT() + (++) At reception end of transfer HAL_SMBUS_SlaveRxCpltCallback() is executed and users can + add their own code by customization of function pointer HAL_SMBUS_SlaveRxCpltCallback() + (+) Enable/Disable the SMBUS alert mode using + HAL_SMBUS_EnableAlert_IT() or HAL_SMBUS_DisableAlert_IT() + (++) When SMBUS Alert is generated HAL_SMBUS_ErrorCallback() is executed and users can + add their own code by customization of function pointer HAL_SMBUS_ErrorCallback() + to check the Alert Error Code using function HAL_SMBUS_GetError() + (+) Get HAL state machine or error values using HAL_SMBUS_GetState() or HAL_SMBUS_GetError() + (+) In case of transfer Error, HAL_SMBUS_ErrorCallback() function is executed and users can + add their own code by customization of function pointer HAL_SMBUS_ErrorCallback() + to check the Error Code using function HAL_SMBUS_GetError() + + *** SMBUS HAL driver macros list *** + ================================== + [..] + Below the list of most used macros in SMBUS HAL driver. + + (+) __HAL_SMBUS_ENABLE: Enable the SMBUS peripheral + (+) __HAL_SMBUS_DISABLE: Disable the SMBUS peripheral + (+) __HAL_SMBUS_GET_FLAG: Check whether the specified SMBUS flag is set or not + (+) __HAL_SMBUS_CLEAR_FLAG: Clear the specified SMBUS pending flag + (+) __HAL_SMBUS_ENABLE_IT: Enable the specified SMBUS interrupt + (+) __HAL_SMBUS_DISABLE_IT: Disable the specified SMBUS interrupt + + *** Callback registration *** + ============================================= + [..] + The compilation flag USE_HAL_SMBUS_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_SMBUS_RegisterCallback() or HAL_SMBUS_RegisterAddrCallback() + to register an interrupt callback. + [..] + Function HAL_SMBUS_RegisterCallback() allows to register following callbacks: + (+) MasterTxCpltCallback : callback for Master transmission end of transfer. + (+) MasterRxCpltCallback : callback for Master reception end of transfer. + (+) SlaveTxCpltCallback : callback for Slave transmission end of transfer. + (+) SlaveRxCpltCallback : callback for Slave reception end of transfer. + (+) ListenCpltCallback : callback for end of listen mode. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + [..] + For specific callback AddrCallback use dedicated register callbacks : HAL_SMBUS_RegisterAddrCallback. + [..] + Use function HAL_SMBUS_UnRegisterCallback to reset a callback to the default + weak function. + HAL_SMBUS_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) MasterTxCpltCallback : callback for Master transmission end of transfer. + (+) MasterRxCpltCallback : callback for Master reception end of transfer. + (+) SlaveTxCpltCallback : callback for Slave transmission end of transfer. + (+) SlaveRxCpltCallback : callback for Slave reception end of transfer. + (+) ListenCpltCallback : callback for end of listen mode. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + [..] + For callback AddrCallback use dedicated register callbacks : HAL_SMBUS_UnRegisterAddrCallback. + [..] + By default, after the HAL_SMBUS_Init() and when the state is HAL_I2C_STATE_RESET + all callbacks are set to the corresponding weak functions: + examples HAL_SMBUS_MasterTxCpltCallback(), HAL_SMBUS_MasterRxCpltCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak functions in the HAL_SMBUS_Init()/ HAL_SMBUS_DeInit() only when + these callbacks are null (not registered beforehand). + If MspInit or MspDeInit are not null, the HAL_SMBUS_Init()/ HAL_SMBUS_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state. + [..] + Callbacks can be registered/unregistered in HAL_I2C_STATE_READY state only. + Exception done MspInit/MspDeInit functions that can be registered/unregistered + in HAL_I2C_STATE_READY or HAL_I2C_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + Then, the user first registers the MspInit/MspDeInit user callbacks + using HAL_SMBUS_RegisterCallback() before calling HAL_SMBUS_DeInit() + or HAL_SMBUS_Init() function. + [..] + When the compilation flag USE_HAL_SMBUS_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + + [..] + (@) You can refer to the SMBUS HAL driver header file for more useful macros + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup SMBUS SMBUS + * @brief SMBUS HAL module driver + * @{ + */ + +#ifdef HAL_SMBUS_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup SMBUS_Private_Define SMBUS Private Constants + * @{ + */ +#define TIMING_CLEAR_MASK (0xF0FFFFFFUL) /*!< SMBUS TIMING clear register Mask */ +#define HAL_TIMEOUT_ADDR (10000U) /*!< 10 s */ +#define HAL_TIMEOUT_BUSY (25U) /*!< 25 ms */ +#define HAL_TIMEOUT_DIR (25U) /*!< 25 ms */ +#define HAL_TIMEOUT_RXNE (25U) /*!< 25 ms */ +#define HAL_TIMEOUT_STOPF (25U) /*!< 25 ms */ +#define HAL_TIMEOUT_TC (25U) /*!< 25 ms */ +#define HAL_TIMEOUT_TCR (25U) /*!< 25 ms */ +#define HAL_TIMEOUT_TXIS (25U) /*!< 25 ms */ +#define MAX_NBYTE_SIZE 255U +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @addtogroup SMBUS_Private_Functions SMBUS Private Functions + * @{ + */ +static HAL_StatusTypeDef SMBUS_WaitOnFlagUntilTimeout(SMBUS_HandleTypeDef *hsmbus, uint32_t Flag, + FlagStatus Status, uint32_t Timeout); + +static void SMBUS_Enable_IRQ(SMBUS_HandleTypeDef *hsmbus, uint32_t InterruptRequest); +static void SMBUS_Disable_IRQ(SMBUS_HandleTypeDef *hsmbus, uint32_t InterruptRequest); +static HAL_StatusTypeDef SMBUS_Master_ISR(SMBUS_HandleTypeDef *hsmbus, uint32_t StatusFlags); +static HAL_StatusTypeDef SMBUS_Slave_ISR(SMBUS_HandleTypeDef *hsmbus, uint32_t StatusFlags); + +static void SMBUS_ConvertOtherXferOptions(SMBUS_HandleTypeDef *hsmbus); + +static void SMBUS_ITErrorHandler(SMBUS_HandleTypeDef *hsmbus); + +static void SMBUS_TransferConfig(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, uint8_t Size, + uint32_t Mode, uint32_t Request); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup SMBUS_Exported_Functions SMBUS Exported Functions + * @{ + */ + +/** @defgroup SMBUS_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This subsection provides a set of functions allowing to initialize and + deinitialize the SMBUSx peripheral: + + (+) User must Implement HAL_SMBUS_MspInit() function in which he configures + all related peripherals resources (CLOCK, GPIO, IT and NVIC ). + + (+) Call the function HAL_SMBUS_Init() to configure the selected device with + the selected configuration: + (++) Clock Timing + (++) Bus Timeout + (++) Analog Filer mode + (++) Own Address 1 + (++) Addressing mode (Master, Slave) + (++) Dual Addressing mode + (++) Own Address 2 + (++) Own Address 2 Mask + (++) General call mode + (++) Nostretch mode + (++) Packet Error Check mode + (++) Peripheral mode + + + (+) Call the function HAL_SMBUS_DeInit() to restore the default configuration + of the selected SMBUSx peripheral. + + (+) Enable/Disable Analog/Digital filters with HAL_SMBUS_ConfigAnalogFilter() and + HAL_SMBUS_ConfigDigitalFilter(). + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the SMBUS according to the specified parameters + * in the SMBUS_InitTypeDef and initialize the associated handle. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_Init(SMBUS_HandleTypeDef *hsmbus) +{ + /* Check the SMBUS handle allocation */ + if (hsmbus == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_SMBUS_ALL_INSTANCE(hsmbus->Instance)); + assert_param(IS_SMBUS_ANALOG_FILTER(hsmbus->Init.AnalogFilter)); + assert_param(IS_SMBUS_OWN_ADDRESS1(hsmbus->Init.OwnAddress1)); + assert_param(IS_SMBUS_ADDRESSING_MODE(hsmbus->Init.AddressingMode)); + assert_param(IS_SMBUS_DUAL_ADDRESS(hsmbus->Init.DualAddressMode)); + assert_param(IS_SMBUS_OWN_ADDRESS2(hsmbus->Init.OwnAddress2)); + assert_param(IS_SMBUS_OWN_ADDRESS2_MASK(hsmbus->Init.OwnAddress2Masks)); + assert_param(IS_SMBUS_GENERAL_CALL(hsmbus->Init.GeneralCallMode)); + assert_param(IS_SMBUS_NO_STRETCH(hsmbus->Init.NoStretchMode)); + assert_param(IS_SMBUS_PEC(hsmbus->Init.PacketErrorCheckMode)); + assert_param(IS_SMBUS_PERIPHERAL_MODE(hsmbus->Init.PeripheralMode)); + + if (hsmbus->State == HAL_SMBUS_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hsmbus->Lock = HAL_UNLOCKED; + +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->MasterTxCpltCallback = HAL_SMBUS_MasterTxCpltCallback; /* Legacy weak MasterTxCpltCallback */ + hsmbus->MasterRxCpltCallback = HAL_SMBUS_MasterRxCpltCallback; /* Legacy weak MasterRxCpltCallback */ + hsmbus->SlaveTxCpltCallback = HAL_SMBUS_SlaveTxCpltCallback; /* Legacy weak SlaveTxCpltCallback */ + hsmbus->SlaveRxCpltCallback = HAL_SMBUS_SlaveRxCpltCallback; /* Legacy weak SlaveRxCpltCallback */ + hsmbus->ListenCpltCallback = HAL_SMBUS_ListenCpltCallback; /* Legacy weak ListenCpltCallback */ + hsmbus->ErrorCallback = HAL_SMBUS_ErrorCallback; /* Legacy weak ErrorCallback */ + hsmbus->AddrCallback = HAL_SMBUS_AddrCallback; /* Legacy weak AddrCallback */ + + if (hsmbus->MspInitCallback == NULL) + { + hsmbus->MspInitCallback = HAL_SMBUS_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware : GPIO, CLOCK, CORTEX...etc */ + hsmbus->MspInitCallback(hsmbus); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + HAL_SMBUS_MspInit(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + + hsmbus->State = HAL_SMBUS_STATE_BUSY; + + /* Disable the selected SMBUS peripheral */ + __HAL_SMBUS_DISABLE(hsmbus); + + /*---------------------------- SMBUSx TIMINGR Configuration ------------------------*/ + /* Configure SMBUSx: Frequency range */ + hsmbus->Instance->TIMINGR = hsmbus->Init.Timing & TIMING_CLEAR_MASK; + + /*---------------------------- SMBUSx TIMEOUTR Configuration ------------------------*/ + /* Configure SMBUSx: Bus Timeout */ + hsmbus->Instance->TIMEOUTR &= ~I2C_TIMEOUTR_TIMOUTEN; + hsmbus->Instance->TIMEOUTR &= ~I2C_TIMEOUTR_TEXTEN; + hsmbus->Instance->TIMEOUTR = hsmbus->Init.SMBusTimeout; + + /*---------------------------- SMBUSx OAR1 Configuration -----------------------*/ + /* Configure SMBUSx: Own Address1 and ack own address1 mode */ + hsmbus->Instance->OAR1 &= ~I2C_OAR1_OA1EN; + + if (hsmbus->Init.OwnAddress1 != 0UL) + { + if (hsmbus->Init.AddressingMode == SMBUS_ADDRESSINGMODE_7BIT) + { + hsmbus->Instance->OAR1 = (I2C_OAR1_OA1EN | hsmbus->Init.OwnAddress1); + } + else /* SMBUS_ADDRESSINGMODE_10BIT */ + { + hsmbus->Instance->OAR1 = (I2C_OAR1_OA1EN | I2C_OAR1_OA1MODE | hsmbus->Init.OwnAddress1); + } + } + + /*---------------------------- SMBUSx CR2 Configuration ------------------------*/ + /* Configure SMBUSx: Addressing Master mode */ + if (hsmbus->Init.AddressingMode == SMBUS_ADDRESSINGMODE_10BIT) + { + hsmbus->Instance->CR2 = (I2C_CR2_ADD10); + } + /* Enable the AUTOEND by default, and enable NACK (should be disable only during Slave process) */ + /* AUTOEND and NACK bit will be manage during Transfer process */ + hsmbus->Instance->CR2 |= (I2C_CR2_AUTOEND | I2C_CR2_NACK); + + /*---------------------------- SMBUSx OAR2 Configuration -----------------------*/ + /* Configure SMBUSx: Dual mode and Own Address2 */ + hsmbus->Instance->OAR2 = (hsmbus->Init.DualAddressMode | hsmbus->Init.OwnAddress2 | \ + (hsmbus->Init.OwnAddress2Masks << 8U)); + + /*---------------------------- SMBUSx CR1 Configuration ------------------------*/ + /* Configure SMBUSx: Generalcall and NoStretch mode */ + hsmbus->Instance->CR1 = (hsmbus->Init.GeneralCallMode | hsmbus->Init.NoStretchMode | \ + hsmbus->Init.PacketErrorCheckMode | hsmbus->Init.PeripheralMode | \ + hsmbus->Init.AnalogFilter); + + /* Enable Slave Byte Control only in case of Packet Error Check is enabled + and SMBUS Peripheral is set in Slave mode */ + if ((hsmbus->Init.PacketErrorCheckMode == SMBUS_PEC_ENABLE) && \ + ((hsmbus->Init.PeripheralMode == SMBUS_PERIPHERAL_MODE_SMBUS_SLAVE) || \ + (hsmbus->Init.PeripheralMode == SMBUS_PERIPHERAL_MODE_SMBUS_SLAVE_ARP))) + { + hsmbus->Instance->CR1 |= I2C_CR1_SBC; + } + + /* Enable the selected SMBUS peripheral */ + __HAL_SMBUS_ENABLE(hsmbus); + + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + hsmbus->PreviousState = HAL_SMBUS_STATE_READY; + hsmbus->State = HAL_SMBUS_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitialize the SMBUS peripheral. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_DeInit(SMBUS_HandleTypeDef *hsmbus) +{ + /* Check the SMBUS handle allocation */ + if (hsmbus == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_SMBUS_ALL_INSTANCE(hsmbus->Instance)); + + hsmbus->State = HAL_SMBUS_STATE_BUSY; + + /* Disable the SMBUS Peripheral Clock */ + __HAL_SMBUS_DISABLE(hsmbus); + +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + if (hsmbus->MspDeInitCallback == NULL) + { + hsmbus->MspDeInitCallback = HAL_SMBUS_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + hsmbus->MspDeInitCallback(hsmbus); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + HAL_SMBUS_MspDeInit(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + hsmbus->PreviousState = HAL_SMBUS_STATE_RESET; + hsmbus->State = HAL_SMBUS_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(hsmbus); + + return HAL_OK; +} + +/** + * @brief Initialize the SMBUS MSP. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_MspInit(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitialize the SMBUS MSP. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_MspDeInit(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief Configure Analog noise filter. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param AnalogFilter This parameter can be one of the following values: + * @arg @ref SMBUS_ANALOGFILTER_ENABLE + * @arg @ref SMBUS_ANALOGFILTER_DISABLE + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_ConfigAnalogFilter(SMBUS_HandleTypeDef *hsmbus, uint32_t AnalogFilter) +{ + /* Check the parameters */ + assert_param(IS_SMBUS_ALL_INSTANCE(hsmbus->Instance)); + assert_param(IS_SMBUS_ANALOG_FILTER(AnalogFilter)); + + if (hsmbus->State == HAL_SMBUS_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hsmbus); + + hsmbus->State = HAL_SMBUS_STATE_BUSY; + + /* Disable the selected SMBUS peripheral */ + __HAL_SMBUS_DISABLE(hsmbus); + + /* Reset ANOFF bit */ + hsmbus->Instance->CR1 &= ~(I2C_CR1_ANFOFF); + + /* Set analog filter bit*/ + hsmbus->Instance->CR1 |= AnalogFilter; + + __HAL_SMBUS_ENABLE(hsmbus); + + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Configure Digital noise filter. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param DigitalFilter Coefficient of digital noise filter between Min_Data=0x00 and Max_Data=0x0F. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_ConfigDigitalFilter(SMBUS_HandleTypeDef *hsmbus, uint32_t DigitalFilter) +{ + uint32_t tmpreg; + + /* Check the parameters */ + assert_param(IS_SMBUS_ALL_INSTANCE(hsmbus->Instance)); + assert_param(IS_SMBUS_DIGITAL_FILTER(DigitalFilter)); + + if (hsmbus->State == HAL_SMBUS_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hsmbus); + + hsmbus->State = HAL_SMBUS_STATE_BUSY; + + /* Disable the selected SMBUS peripheral */ + __HAL_SMBUS_DISABLE(hsmbus); + + /* Get the old register value */ + tmpreg = hsmbus->Instance->CR1; + + /* Reset I2C DNF bits [11:8] */ + tmpreg &= ~(I2C_CR1_DNF); + + /* Set I2Cx DNF coefficient */ + tmpreg |= DigitalFilter << I2C_CR1_DNF_Pos; + + /* Store the new register value */ + hsmbus->Instance->CR1 = tmpreg; + + __HAL_SMBUS_ENABLE(hsmbus); + + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User SMBUS Callback + * To be used instead of the weak predefined callback + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_SMBUS_MASTER_TX_COMPLETE_CB_ID Master Tx Transfer completed callback ID + * @arg @ref HAL_SMBUS_MASTER_RX_COMPLETE_CB_ID Master Rx Transfer completed callback ID + * @arg @ref HAL_SMBUS_SLAVE_TX_COMPLETE_CB_ID Slave Tx Transfer completed callback ID + * @arg @ref HAL_SMBUS_SLAVE_RX_COMPLETE_CB_ID Slave Rx Transfer completed callback ID + * @arg @ref HAL_SMBUS_LISTEN_COMPLETE_CB_ID Listen Complete callback ID + * @arg @ref HAL_SMBUS_ERROR_CB_ID Error callback ID + * @arg @ref HAL_SMBUS_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_SMBUS_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_RegisterCallback(SMBUS_HandleTypeDef *hsmbus, + HAL_SMBUS_CallbackIDTypeDef CallbackID, + pSMBUS_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(hsmbus); + + if (HAL_SMBUS_STATE_READY == hsmbus->State) + { + switch (CallbackID) + { + case HAL_SMBUS_MASTER_TX_COMPLETE_CB_ID : + hsmbus->MasterTxCpltCallback = pCallback; + break; + + case HAL_SMBUS_MASTER_RX_COMPLETE_CB_ID : + hsmbus->MasterRxCpltCallback = pCallback; + break; + + case HAL_SMBUS_SLAVE_TX_COMPLETE_CB_ID : + hsmbus->SlaveTxCpltCallback = pCallback; + break; + + case HAL_SMBUS_SLAVE_RX_COMPLETE_CB_ID : + hsmbus->SlaveRxCpltCallback = pCallback; + break; + + case HAL_SMBUS_LISTEN_COMPLETE_CB_ID : + hsmbus->ListenCpltCallback = pCallback; + break; + + case HAL_SMBUS_ERROR_CB_ID : + hsmbus->ErrorCallback = pCallback; + break; + + case HAL_SMBUS_MSPINIT_CB_ID : + hsmbus->MspInitCallback = pCallback; + break; + + case HAL_SMBUS_MSPDEINIT_CB_ID : + hsmbus->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_SMBUS_STATE_RESET == hsmbus->State) + { + switch (CallbackID) + { + case HAL_SMBUS_MSPINIT_CB_ID : + hsmbus->MspInitCallback = pCallback; + break; + + case HAL_SMBUS_MSPDEINIT_CB_ID : + hsmbus->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hsmbus); + return status; +} + +/** + * @brief Unregister an SMBUS Callback + * SMBUS callback is redirected to the weak predefined callback + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * This parameter can be one of the following values: + * @arg @ref HAL_SMBUS_MASTER_TX_COMPLETE_CB_ID Master Tx Transfer completed callback ID + * @arg @ref HAL_SMBUS_MASTER_RX_COMPLETE_CB_ID Master Rx Transfer completed callback ID + * @arg @ref HAL_SMBUS_SLAVE_TX_COMPLETE_CB_ID Slave Tx Transfer completed callback ID + * @arg @ref HAL_SMBUS_SLAVE_RX_COMPLETE_CB_ID Slave Rx Transfer completed callback ID + * @arg @ref HAL_SMBUS_LISTEN_COMPLETE_CB_ID Listen Complete callback ID + * @arg @ref HAL_SMBUS_ERROR_CB_ID Error callback ID + * @arg @ref HAL_SMBUS_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_SMBUS_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_UnRegisterCallback(SMBUS_HandleTypeDef *hsmbus, + HAL_SMBUS_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hsmbus); + + if (HAL_SMBUS_STATE_READY == hsmbus->State) + { + switch (CallbackID) + { + case HAL_SMBUS_MASTER_TX_COMPLETE_CB_ID : + hsmbus->MasterTxCpltCallback = HAL_SMBUS_MasterTxCpltCallback; /* Legacy weak MasterTxCpltCallback */ + break; + + case HAL_SMBUS_MASTER_RX_COMPLETE_CB_ID : + hsmbus->MasterRxCpltCallback = HAL_SMBUS_MasterRxCpltCallback; /* Legacy weak MasterRxCpltCallback */ + break; + + case HAL_SMBUS_SLAVE_TX_COMPLETE_CB_ID : + hsmbus->SlaveTxCpltCallback = HAL_SMBUS_SlaveTxCpltCallback; /* Legacy weak SlaveTxCpltCallback */ + break; + + case HAL_SMBUS_SLAVE_RX_COMPLETE_CB_ID : + hsmbus->SlaveRxCpltCallback = HAL_SMBUS_SlaveRxCpltCallback; /* Legacy weak SlaveRxCpltCallback */ + break; + + case HAL_SMBUS_LISTEN_COMPLETE_CB_ID : + hsmbus->ListenCpltCallback = HAL_SMBUS_ListenCpltCallback; /* Legacy weak ListenCpltCallback */ + break; + + case HAL_SMBUS_ERROR_CB_ID : + hsmbus->ErrorCallback = HAL_SMBUS_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_SMBUS_MSPINIT_CB_ID : + hsmbus->MspInitCallback = HAL_SMBUS_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_SMBUS_MSPDEINIT_CB_ID : + hsmbus->MspDeInitCallback = HAL_SMBUS_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_SMBUS_STATE_RESET == hsmbus->State) + { + switch (CallbackID) + { + case HAL_SMBUS_MSPINIT_CB_ID : + hsmbus->MspInitCallback = HAL_SMBUS_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_SMBUS_MSPDEINIT_CB_ID : + hsmbus->MspDeInitCallback = HAL_SMBUS_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hsmbus); + return status; +} + +/** + * @brief Register the Slave Address Match SMBUS Callback + * To be used instead of the weak HAL_SMBUS_AddrCallback() predefined callback + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param pCallback pointer to the Address Match Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_RegisterAddrCallback(SMBUS_HandleTypeDef *hsmbus, + pSMBUS_AddrCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hsmbus); + + if (HAL_SMBUS_STATE_READY == hsmbus->State) + { + hsmbus->AddrCallback = pCallback; + } + else + { + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hsmbus); + return status; +} + +/** + * @brief UnRegister the Slave Address Match SMBUS Callback + * Info Ready SMBUS Callback is redirected to the weak HAL_SMBUS_AddrCallback() predefined callback + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_UnRegisterAddrCallback(SMBUS_HandleTypeDef *hsmbus) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hsmbus); + + if (HAL_SMBUS_STATE_READY == hsmbus->State) + { + hsmbus->AddrCallback = HAL_SMBUS_AddrCallback; /* Legacy weak AddrCallback */ + } + else + { + /* Update the error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hsmbus); + return status; +} + +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup SMBUS_Exported_Functions_Group2 Input and Output operation functions + * @brief Data transfers functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to manage the SMBUS data + transfers. + + (#) Blocking mode function to check if device is ready for usage is : + (++) HAL_SMBUS_IsDeviceReady() + + (#) There is only one mode of transfer: + (++) Non-Blocking mode : The communication is performed using Interrupts. + These functions return the status of the transfer startup. + The end of the data processing will be indicated through the + dedicated SMBUS IRQ when using Interrupt mode. + + (#) Non-Blocking mode functions with Interrupt are : + (++) HAL_SMBUS_Master_Transmit_IT() + (++) HAL_SMBUS_Master_Receive_IT() + (++) HAL_SMBUS_Slave_Transmit_IT() + (++) HAL_SMBUS_Slave_Receive_IT() + (++) HAL_SMBUS_EnableListen_IT() or alias HAL_SMBUS_EnableListen_IT() + (++) HAL_SMBUS_DisableListen_IT() + (++) HAL_SMBUS_EnableAlert_IT() + (++) HAL_SMBUS_DisableAlert_IT() + + (#) A set of Transfer Complete Callbacks are provided in non-Blocking mode: + (++) HAL_SMBUS_MasterTxCpltCallback() + (++) HAL_SMBUS_MasterRxCpltCallback() + (++) HAL_SMBUS_SlaveTxCpltCallback() + (++) HAL_SMBUS_SlaveRxCpltCallback() + (++) HAL_SMBUS_AddrCallback() + (++) HAL_SMBUS_ListenCpltCallback() + (++) HAL_SMBUS_ErrorCallback() + +@endverbatim + * @{ + */ + +/** + * @brief Transmit in master/host SMBUS mode an amount of data in non-blocking mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref SMBUS_XferOptions_definition + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_Master_Transmit_IT(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, + uint8_t *pData, uint16_t Size, uint32_t XferOptions) +{ + uint32_t tmp; + + /* Check the parameters */ + assert_param(IS_SMBUS_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (hsmbus->State == HAL_SMBUS_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hsmbus); + + hsmbus->State = HAL_SMBUS_STATE_MASTER_BUSY_TX; + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + /* Prepare transfer parameters */ + hsmbus->pBuffPtr = pData; + hsmbus->XferCount = Size; + hsmbus->XferOptions = XferOptions; + + /* In case of Quick command, remove autoend mode */ + /* Manage the stop generation by software */ + if (hsmbus->pBuffPtr == NULL) + { + hsmbus->XferOptions &= ~SMBUS_AUTOEND_MODE; + } + + if (Size > MAX_NBYTE_SIZE) + { + hsmbus->XferSize = MAX_NBYTE_SIZE; + } + else + { + hsmbus->XferSize = Size; + } + + /* Send Slave Address */ + /* Set NBYTES to write and reload if size > MAX_NBYTE_SIZE and generate RESTART */ + if ((hsmbus->XferSize < hsmbus->XferCount) && (hsmbus->XferSize == MAX_NBYTE_SIZE)) + { + SMBUS_TransferConfig(hsmbus, DevAddress, (uint8_t)hsmbus->XferSize, + SMBUS_RELOAD_MODE | (hsmbus->XferOptions & SMBUS_SENDPEC_MODE), + SMBUS_GENERATE_START_WRITE); + } + else + { + /* If transfer direction not change, do not generate Restart Condition */ + /* Mean Previous state is same as current state */ + + /* Store current volatile XferOptions, misra rule */ + tmp = hsmbus->XferOptions; + + if ((hsmbus->PreviousState == HAL_SMBUS_STATE_MASTER_BUSY_TX) && \ + (IS_SMBUS_TRANSFER_OTHER_OPTIONS_REQUEST(tmp) == 0)) + { + SMBUS_TransferConfig(hsmbus, DevAddress, (uint8_t)hsmbus->XferSize, hsmbus->XferOptions, + SMBUS_NO_STARTSTOP); + } + /* Else transfer direction change, so generate Restart with new transfer direction */ + else + { + /* Convert OTHER_xxx XferOptions if any */ + SMBUS_ConvertOtherXferOptions(hsmbus); + + /* Handle Transfer */ + SMBUS_TransferConfig(hsmbus, DevAddress, (uint8_t)hsmbus->XferSize, + hsmbus->XferOptions, + SMBUS_GENERATE_START_WRITE); + } + + /* If PEC mode is enable, size to transmit manage by SW part should be Size-1 byte, corresponding to PEC byte */ + /* PEC byte is automatically sent by HW block, no need to manage it in Transmit process */ + if (SMBUS_GET_PEC_MODE(hsmbus) != 0UL) + { + hsmbus->XferSize--; + hsmbus->XferCount--; + } + } + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Note : The SMBUS interrupts must be enabled after unlocking current process + to avoid the risk of SMBUS interrupt handle execution before current + process unlock */ + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_TX); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive in master/host SMBUS mode an amount of data in non-blocking mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref SMBUS_XferOptions_definition + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_Master_Receive_IT(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, uint8_t *pData, + uint16_t Size, uint32_t XferOptions) +{ + uint32_t tmp; + + /* Check the parameters */ + assert_param(IS_SMBUS_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if (hsmbus->State == HAL_SMBUS_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hsmbus); + + hsmbus->State = HAL_SMBUS_STATE_MASTER_BUSY_RX; + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + + /* Prepare transfer parameters */ + hsmbus->pBuffPtr = pData; + hsmbus->XferCount = Size; + hsmbus->XferOptions = XferOptions; + + /* In case of Quick command, remove autoend mode */ + /* Manage the stop generation by software */ + if (hsmbus->pBuffPtr == NULL) + { + hsmbus->XferOptions &= ~SMBUS_AUTOEND_MODE; + } + + if (Size > MAX_NBYTE_SIZE) + { + hsmbus->XferSize = MAX_NBYTE_SIZE; + } + else + { + hsmbus->XferSize = Size; + } + + /* Send Slave Address */ + /* Set NBYTES to write and reload if size > MAX_NBYTE_SIZE and generate RESTART */ + if ((hsmbus->XferSize < hsmbus->XferCount) && (hsmbus->XferSize == MAX_NBYTE_SIZE)) + { + SMBUS_TransferConfig(hsmbus, DevAddress, (uint8_t)hsmbus->XferSize, + SMBUS_RELOAD_MODE | (hsmbus->XferOptions & SMBUS_SENDPEC_MODE), + SMBUS_GENERATE_START_READ); + } + else + { + /* If transfer direction not change, do not generate Restart Condition */ + /* Mean Previous state is same as current state */ + + /* Store current volatile XferOptions, Misra rule */ + tmp = hsmbus->XferOptions; + + if ((hsmbus->PreviousState == HAL_SMBUS_STATE_MASTER_BUSY_RX) && \ + (IS_SMBUS_TRANSFER_OTHER_OPTIONS_REQUEST(tmp) == 0)) + { + SMBUS_TransferConfig(hsmbus, DevAddress, (uint8_t)hsmbus->XferSize, hsmbus->XferOptions, + SMBUS_NO_STARTSTOP); + } + /* Else transfer direction change, so generate Restart with new transfer direction */ + else + { + /* Convert OTHER_xxx XferOptions if any */ + SMBUS_ConvertOtherXferOptions(hsmbus); + + /* Handle Transfer */ + SMBUS_TransferConfig(hsmbus, DevAddress, (uint8_t)hsmbus->XferSize, + hsmbus->XferOptions, + SMBUS_GENERATE_START_READ); + } + } + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Note : The SMBUS interrupts must be enabled after unlocking current process + to avoid the risk of SMBUS interrupt handle execution before current + process unlock */ + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_RX); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Abort a master/host SMBUS process communication with Interrupt. + * @note This abort can be called only if state is ready + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_Master_Abort_IT(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress) +{ + if (hsmbus->State == HAL_SMBUS_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(hsmbus); + + /* Keep the same state as previous */ + /* to perform as well the call of the corresponding end of transfer callback */ + if (hsmbus->PreviousState == HAL_SMBUS_STATE_MASTER_BUSY_TX) + { + hsmbus->State = HAL_SMBUS_STATE_MASTER_BUSY_TX; + } + else if (hsmbus->PreviousState == HAL_SMBUS_STATE_MASTER_BUSY_RX) + { + hsmbus->State = HAL_SMBUS_STATE_MASTER_BUSY_RX; + } + else + { + /* Wrong usage of abort function */ + /* This function should be used only in case of abort monitored by master device */ + return HAL_ERROR; + } + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + + /* Set NBYTES to 1 to generate a dummy read on SMBUS peripheral */ + /* Set AUTOEND mode, this will generate a NACK then STOP condition to abort the current transfer */ + SMBUS_TransferConfig(hsmbus, DevAddress, 1, SMBUS_AUTOEND_MODE, SMBUS_NO_STARTSTOP); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Note : The SMBUS interrupts must be enabled after unlocking current process + to avoid the risk of SMBUS interrupt handle execution before current + process unlock */ + if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_TX) + { + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_TX); + } + else if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_RX) + { + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_RX); + } + else + { + /* Nothing to do */ + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Transmit in slave/device SMBUS mode an amount of data in non-blocking mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref SMBUS_XferOptions_definition + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_Slave_Transmit_IT(SMBUS_HandleTypeDef *hsmbus, uint8_t *pData, uint16_t Size, + uint32_t XferOptions) +{ + /* Check the parameters */ + assert_param(IS_SMBUS_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if ((hsmbus->State & HAL_SMBUS_STATE_LISTEN) == HAL_SMBUS_STATE_LISTEN) + { + if ((pData == NULL) || (Size == 0UL)) + { + hsmbus->ErrorCode = HAL_SMBUS_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Disable Interrupts, to prevent preemption during treatment in case of multicall */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_ADDR | SMBUS_IT_TX); + + /* Process Locked */ + __HAL_LOCK(hsmbus); + + hsmbus->State = (HAL_SMBUS_STATE_SLAVE_BUSY_TX | HAL_SMBUS_STATE_LISTEN); + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + + /* Set SBC bit to manage Acknowledge at each bit */ + hsmbus->Instance->CR1 |= I2C_CR1_SBC; + + /* Enable Address Acknowledge */ + hsmbus->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hsmbus->pBuffPtr = pData; + hsmbus->XferCount = Size; + hsmbus->XferOptions = XferOptions; + + /* Convert OTHER_xxx XferOptions if any */ + SMBUS_ConvertOtherXferOptions(hsmbus); + + if (Size > MAX_NBYTE_SIZE) + { + hsmbus->XferSize = MAX_NBYTE_SIZE; + } + else + { + hsmbus->XferSize = Size; + } + + /* Set NBYTES to write and reload if size > MAX_NBYTE_SIZE and generate RESTART */ + if ((hsmbus->XferSize < hsmbus->XferCount) && (hsmbus->XferSize == MAX_NBYTE_SIZE)) + { + SMBUS_TransferConfig(hsmbus, 0, (uint8_t)hsmbus->XferSize, + SMBUS_RELOAD_MODE | (hsmbus->XferOptions & SMBUS_SENDPEC_MODE), + SMBUS_NO_STARTSTOP); + } + else + { + /* Set NBYTE to transmit */ + SMBUS_TransferConfig(hsmbus, 0, (uint8_t)hsmbus->XferSize, hsmbus->XferOptions, + SMBUS_NO_STARTSTOP); + + /* If PEC mode is enable, size to transmit should be Size-1 byte, corresponding to PEC byte */ + /* PEC byte is automatically sent by HW block, no need to manage it in Transmit process */ + if (SMBUS_GET_PEC_MODE(hsmbus) != 0UL) + { + hsmbus->XferSize--; + hsmbus->XferCount--; + } + } + + /* Clear ADDR flag after prepare the transfer parameters */ + /* This action will generate an acknowledge to the HOST */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_ADDR); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Note : The SMBUS interrupts must be enabled after unlocking current process + to avoid the risk of SMBUS interrupt handle execution before current + process unlock */ + /* REnable ADDR interrupt */ + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_TX | SMBUS_IT_ADDR); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive in slave/device SMBUS mode an amount of data in non-blocking mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param pData Pointer to data buffer + * @param Size Amount of data to be sent + * @param XferOptions Options of Transfer, value of @ref SMBUS_XferOptions_definition + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_Slave_Receive_IT(SMBUS_HandleTypeDef *hsmbus, uint8_t *pData, uint16_t Size, + uint32_t XferOptions) +{ + /* Check the parameters */ + assert_param(IS_SMBUS_TRANSFER_OPTIONS_REQUEST(XferOptions)); + + if ((hsmbus->State & HAL_SMBUS_STATE_LISTEN) == HAL_SMBUS_STATE_LISTEN) + { + if ((pData == NULL) || (Size == 0UL)) + { + hsmbus->ErrorCode = HAL_SMBUS_ERROR_INVALID_PARAM; + return HAL_ERROR; + } + + /* Disable Interrupts, to prevent preemption during treatment in case of multicall */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_ADDR | SMBUS_IT_RX); + + /* Process Locked */ + __HAL_LOCK(hsmbus); + + hsmbus->State = (HAL_SMBUS_STATE_SLAVE_BUSY_RX | HAL_SMBUS_STATE_LISTEN); + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + + /* Set SBC bit to manage Acknowledge at each bit */ + hsmbus->Instance->CR1 |= I2C_CR1_SBC; + + /* Enable Address Acknowledge */ + hsmbus->Instance->CR2 &= ~I2C_CR2_NACK; + + /* Prepare transfer parameters */ + hsmbus->pBuffPtr = pData; + hsmbus->XferSize = Size; + hsmbus->XferCount = Size; + hsmbus->XferOptions = XferOptions; + + /* Convert OTHER_xxx XferOptions if any */ + SMBUS_ConvertOtherXferOptions(hsmbus); + + /* Set NBYTE to receive */ + /* If XferSize equal "1", or XferSize equal "2" with PEC requested (mean 1 data byte + 1 PEC byte */ + /* no need to set RELOAD bit mode, a ACK will be automatically generated in that case */ + /* else need to set RELOAD bit mode to generate an automatic ACK at each byte Received */ + /* This RELOAD bit will be reset for last BYTE to be receive in SMBUS_Slave_ISR */ + if (((SMBUS_GET_PEC_MODE(hsmbus) != 0UL) && (hsmbus->XferSize == 2U)) || (hsmbus->XferSize == 1U)) + { + SMBUS_TransferConfig(hsmbus, 0, (uint8_t)hsmbus->XferSize, hsmbus->XferOptions, + SMBUS_NO_STARTSTOP); + } + else + { + SMBUS_TransferConfig(hsmbus, 0, 1, hsmbus->XferOptions | SMBUS_RELOAD_MODE, SMBUS_NO_STARTSTOP); + } + + /* Clear ADDR flag after prepare the transfer parameters */ + /* This action will generate an acknowledge to the HOST */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_ADDR); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Note : The SMBUS interrupts must be enabled after unlocking current process + to avoid the risk of SMBUS interrupt handle execution before current + process unlock */ + /* REnable ADDR interrupt */ + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_RX | SMBUS_IT_ADDR); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Enable the Address listen mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_EnableListen_IT(SMBUS_HandleTypeDef *hsmbus) +{ + hsmbus->State = HAL_SMBUS_STATE_LISTEN; + + /* Enable the Address Match interrupt */ + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_ADDR); + + return HAL_OK; +} + +/** + * @brief Disable the Address listen mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_DisableListen_IT(SMBUS_HandleTypeDef *hsmbus) +{ + /* Disable Address listen mode only if a transfer is not ongoing */ + if (hsmbus->State == HAL_SMBUS_STATE_LISTEN) + { + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Disable the Address Match interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_ADDR); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Enable the SMBUS alert mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUSx peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_EnableAlert_IT(SMBUS_HandleTypeDef *hsmbus) +{ + /* Enable SMBus alert */ + hsmbus->Instance->CR1 |= I2C_CR1_ALERTEN; + + /* Clear ALERT flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_ALERT); + + /* Enable Alert Interrupt */ + SMBUS_Enable_IRQ(hsmbus, SMBUS_IT_ALERT); + + return HAL_OK; +} +/** + * @brief Disable the SMBUS alert mode with Interrupt. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUSx peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_DisableAlert_IT(SMBUS_HandleTypeDef *hsmbus) +{ + /* Enable SMBus alert */ + hsmbus->Instance->CR1 &= ~I2C_CR1_ALERTEN; + + /* Disable Alert Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_ALERT); + + return HAL_OK; +} + +/** + * @brief Check if target device is ready for communication. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param DevAddress Target device address: The device 7 bits address value + * in datasheet must be shifted to the left before calling the interface + * @param Trials Number of trials + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SMBUS_IsDeviceReady(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, uint32_t Trials, + uint32_t Timeout) +{ + uint32_t tickstart; + + __IO uint32_t SMBUS_Trials = 0UL; + + FlagStatus tmp1; + FlagStatus tmp2; + + if (hsmbus->State == HAL_SMBUS_STATE_READY) + { + if (__HAL_SMBUS_GET_FLAG(hsmbus, SMBUS_FLAG_BUSY) != RESET) + { + return HAL_BUSY; + } + + /* Process Locked */ + __HAL_LOCK(hsmbus); + + hsmbus->State = HAL_SMBUS_STATE_BUSY; + hsmbus->ErrorCode = HAL_SMBUS_ERROR_NONE; + + do + { + /* Generate Start */ + hsmbus->Instance->CR2 = SMBUS_GENERATE_START(hsmbus->Init.AddressingMode, DevAddress); + + /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */ + /* Wait until STOPF flag is set or a NACK flag is set*/ + tickstart = HAL_GetTick(); + + tmp1 = __HAL_SMBUS_GET_FLAG(hsmbus, SMBUS_FLAG_STOPF); + tmp2 = __HAL_SMBUS_GET_FLAG(hsmbus, SMBUS_FLAG_AF); + + while ((tmp1 == RESET) && (tmp2 == RESET)) + { + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0UL)) + { + /* Device is ready */ + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Update SMBUS error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_HALTIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + return HAL_ERROR; + } + } + + tmp1 = __HAL_SMBUS_GET_FLAG(hsmbus, SMBUS_FLAG_STOPF); + tmp2 = __HAL_SMBUS_GET_FLAG(hsmbus, SMBUS_FLAG_AF); + } + + /* Check if the NACKF flag has not been set */ + if (__HAL_SMBUS_GET_FLAG(hsmbus, SMBUS_FLAG_AF) == RESET) + { + /* Wait until STOPF flag is reset */ + if (SMBUS_WaitOnFlagUntilTimeout(hsmbus, SMBUS_FLAG_STOPF, RESET, Timeout) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_STOPF); + + /* Device is ready */ + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + return HAL_OK; + } + else + { + /* Wait until STOPF flag is reset */ + if (SMBUS_WaitOnFlagUntilTimeout(hsmbus, SMBUS_FLAG_STOPF, RESET, Timeout) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear NACK Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_AF); + + /* Clear STOP Flag, auto generated with autoend*/ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_STOPF); + } + + /* Check if the maximum allowed number of trials has been reached */ + if (SMBUS_Trials == Trials) + { + /* Generate Stop */ + hsmbus->Instance->CR2 |= I2C_CR2_STOP; + + /* Wait until STOPF flag is reset */ + if (SMBUS_WaitOnFlagUntilTimeout(hsmbus, SMBUS_FLAG_STOPF, RESET, Timeout) != HAL_OK) + { + return HAL_ERROR; + } + + /* Clear STOP Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_STOPF); + } + + /* Increment Trials */ + SMBUS_Trials++; + } while (SMBUS_Trials < Trials); + + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Update SMBUS error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_HALTIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + return HAL_ERROR; + } + else + { + return HAL_BUSY; + } +} +/** + * @} + */ + +/** @defgroup SMBUS_IRQ_Handler_and_Callbacks IRQ Handler and Callbacks + * @{ + */ + +/** + * @brief Handle SMBUS event interrupt request. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +void HAL_SMBUS_EV_IRQHandler(SMBUS_HandleTypeDef *hsmbus) +{ + /* Use a local variable to store the current ISR flags */ + /* This action will avoid a wrong treatment due to ISR flags change during interrupt handler */ + uint32_t tmpisrvalue = READ_REG(hsmbus->Instance->ISR); + uint32_t tmpcr1value = READ_REG(hsmbus->Instance->CR1); + + /* SMBUS in mode Transmitter ---------------------------------------------------*/ + if ((SMBUS_CHECK_IT_SOURCE(tmpcr1value, (SMBUS_IT_TCI | SMBUS_IT_STOPI | + SMBUS_IT_NACKI | SMBUS_IT_TXI)) != RESET) && + ((SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_TXIS) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_TCR) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_TC) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_STOPF) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_AF) != RESET))) + { + /* Slave mode selected */ + if ((hsmbus->State & HAL_SMBUS_STATE_SLAVE_BUSY_TX) == HAL_SMBUS_STATE_SLAVE_BUSY_TX) + { + (void)SMBUS_Slave_ISR(hsmbus, tmpisrvalue); + } + /* Master mode selected */ + else if ((hsmbus->State & HAL_SMBUS_STATE_MASTER_BUSY_TX) == HAL_SMBUS_STATE_MASTER_BUSY_TX) + { + (void)SMBUS_Master_ISR(hsmbus, tmpisrvalue); + } + else + { + /* Nothing to do */ + } + } + + /* SMBUS in mode Receiver ----------------------------------------------------*/ + if ((SMBUS_CHECK_IT_SOURCE(tmpcr1value, (SMBUS_IT_TCI | SMBUS_IT_STOPI | + SMBUS_IT_NACKI | SMBUS_IT_RXI)) != RESET) && + ((SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_RXNE) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_TCR) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_TC) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_STOPF) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_AF) != RESET))) + { + /* Slave mode selected */ + if ((hsmbus->State & HAL_SMBUS_STATE_SLAVE_BUSY_RX) == HAL_SMBUS_STATE_SLAVE_BUSY_RX) + { + (void)SMBUS_Slave_ISR(hsmbus, tmpisrvalue); + } + /* Master mode selected */ + else if ((hsmbus->State & HAL_SMBUS_STATE_MASTER_BUSY_RX) == HAL_SMBUS_STATE_MASTER_BUSY_RX) + { + (void)SMBUS_Master_ISR(hsmbus, tmpisrvalue); + } + else + { + /* Nothing to do */ + } + } + + /* SMBUS in mode Listener Only --------------------------------------------------*/ + if (((SMBUS_CHECK_IT_SOURCE(tmpcr1value, SMBUS_IT_ADDRI) != RESET) || + (SMBUS_CHECK_IT_SOURCE(tmpcr1value, SMBUS_IT_STOPI) != RESET) || + (SMBUS_CHECK_IT_SOURCE(tmpcr1value, SMBUS_IT_NACKI) != RESET)) && + ((SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_ADDR) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_STOPF) != RESET) || + (SMBUS_CHECK_FLAG(tmpisrvalue, SMBUS_FLAG_AF) != RESET))) + { + if ((hsmbus->State & HAL_SMBUS_STATE_LISTEN) == HAL_SMBUS_STATE_LISTEN) + { + (void)SMBUS_Slave_ISR(hsmbus, tmpisrvalue); + } + } +} + +/** + * @brief Handle SMBUS error interrupt request. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +void HAL_SMBUS_ER_IRQHandler(SMBUS_HandleTypeDef *hsmbus) +{ + SMBUS_ITErrorHandler(hsmbus); +} + +/** + * @brief Master Tx Transfer completed callback. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_MasterTxCpltCallback(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_MasterTxCpltCallback() could be implemented in the user file + */ +} + +/** + * @brief Master Rx Transfer completed callback. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_MasterRxCpltCallback(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_MasterRxCpltCallback() could be implemented in the user file + */ +} + +/** @brief Slave Tx Transfer completed callback. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_SlaveTxCpltCallback(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_SlaveTxCpltCallback() could be implemented in the user file + */ +} + +/** + * @brief Slave Rx Transfer completed callback. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_SlaveRxCpltCallback(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_SlaveRxCpltCallback() could be implemented in the user file + */ +} + +/** + * @brief Slave Address Match callback. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param TransferDirection Master request Transfer Direction (Write/Read) + * @param AddrMatchCode Address Match Code + * @retval None + */ +__weak void HAL_SMBUS_AddrCallback(SMBUS_HandleTypeDef *hsmbus, uint8_t TransferDirection, + uint16_t AddrMatchCode) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + UNUSED(TransferDirection); + UNUSED(AddrMatchCode); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_AddrCallback() could be implemented in the user file + */ +} + +/** + * @brief Listen Complete callback. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_ListenCpltCallback(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_ListenCpltCallback() could be implemented in the user file + */ +} + +/** + * @brief SMBUS error callback. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval None + */ +__weak void HAL_SMBUS_ErrorCallback(SMBUS_HandleTypeDef *hsmbus) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hsmbus); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SMBUS_ErrorCallback() could be implemented in the user file + */ +} + +/** + * @} + */ + +/** @defgroup SMBUS_Exported_Functions_Group3 Peripheral State and Errors functions + * @brief Peripheral State and Errors functions + * +@verbatim + =============================================================================== + ##### Peripheral State and Errors functions ##### + =============================================================================== + [..] + This subsection permits to get in run-time the status of the peripheral + and the data flow. + +@endverbatim + * @{ + */ + +/** + * @brief Return the SMBUS handle state. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval HAL state + */ +uint32_t HAL_SMBUS_GetState(SMBUS_HandleTypeDef *hsmbus) +{ + /* Return SMBUS handle state */ + return hsmbus->State; +} + +/** + * @brief Return the SMBUS error code. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @retval SMBUS Error Code + */ +uint32_t HAL_SMBUS_GetError(SMBUS_HandleTypeDef *hsmbus) +{ + return hsmbus->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup SMBUS_Private_Functions SMBUS Private Functions + * @brief Data transfers Private functions + * @{ + */ + +/** + * @brief Interrupt Sub-Routine which handle the Interrupt Flags Master Mode. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param StatusFlags Value of Interrupt Flags. + * @retval HAL status + */ +static HAL_StatusTypeDef SMBUS_Master_ISR(SMBUS_HandleTypeDef *hsmbus, uint32_t StatusFlags) +{ + uint16_t DevAddress; + + /* Process Locked */ + __HAL_LOCK(hsmbus); + + if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_AF) != RESET) + { + /* Clear NACK Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_AF); + + /* Set corresponding Error Code */ + /* No need to generate STOP, it is automatically done */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_ACKF; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the Error callback to inform upper layer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->ErrorCallback(hsmbus); +#else + HAL_SMBUS_ErrorCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_STOPF) != RESET) + { + /* Check and treat errors if errors occurs during STOP process */ + SMBUS_ITErrorHandler(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ + if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_TX) + { + /* Disable Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_TX); + + /* Clear STOP Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_STOPF); + + /* Clear Configuration Register 2 */ + SMBUS_RESET_CR2(hsmbus); + + /* Flush remaining data in Fifo register in case of error occurs before TXEmpty */ + /* Disable the selected SMBUS peripheral */ + __HAL_SMBUS_DISABLE(hsmbus); + + hsmbus->PreviousState = HAL_SMBUS_STATE_READY; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Re-enable the selected SMBUS peripheral */ + __HAL_SMBUS_ENABLE(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->MasterTxCpltCallback(hsmbus); +#else + HAL_SMBUS_MasterTxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_RX) + { + /* Store Last receive data if any */ + if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_RXNE) != RESET) + { + /* Read data from RXDR */ + *hsmbus->pBuffPtr = (uint8_t)(hsmbus->Instance->RXDR); + + /* Increment Buffer pointer */ + hsmbus->pBuffPtr++; + + if ((hsmbus->XferSize > 0U)) + { + hsmbus->XferSize--; + hsmbus->XferCount--; + } + } + + /* Disable Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_RX); + + /* Clear STOP Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_STOPF); + + /* Clear Configuration Register 2 */ + SMBUS_RESET_CR2(hsmbus); + + hsmbus->PreviousState = HAL_SMBUS_STATE_READY; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->MasterRxCpltCallback(hsmbus); +#else + HAL_SMBUS_MasterRxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else + { + /* Nothing to do */ + } + } + else if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_RXNE) != RESET) + { + /* Read data from RXDR */ + *hsmbus->pBuffPtr = (uint8_t)(hsmbus->Instance->RXDR); + + /* Increment Buffer pointer */ + hsmbus->pBuffPtr++; + + /* Increment Size counter */ + hsmbus->XferSize--; + hsmbus->XferCount--; + } + else if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_TXIS) != RESET) + { + /* Write data to TXDR */ + hsmbus->Instance->TXDR = *hsmbus->pBuffPtr; + + /* Increment Buffer pointer */ + hsmbus->pBuffPtr++; + + /* Increment Size counter */ + hsmbus->XferSize--; + hsmbus->XferCount--; + } + else if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_TCR) != RESET) + { + if ((hsmbus->XferCount != 0U) && (hsmbus->XferSize == 0U)) + { + DevAddress = (uint16_t)(hsmbus->Instance->CR2 & I2C_CR2_SADD); + + if (hsmbus->XferCount > MAX_NBYTE_SIZE) + { + SMBUS_TransferConfig(hsmbus, DevAddress, MAX_NBYTE_SIZE, + (SMBUS_RELOAD_MODE | (hsmbus->XferOptions & SMBUS_SENDPEC_MODE)), + SMBUS_NO_STARTSTOP); + hsmbus->XferSize = MAX_NBYTE_SIZE; + } + else + { + hsmbus->XferSize = hsmbus->XferCount; + SMBUS_TransferConfig(hsmbus, DevAddress, (uint8_t)hsmbus->XferSize, hsmbus->XferOptions, + SMBUS_NO_STARTSTOP); + /* If PEC mode is enable, size to transmit should be Size-1 byte, corresponding to PEC byte */ + /* PEC byte is automatically sent by HW block, no need to manage it in Transmit process */ + if (SMBUS_GET_PEC_MODE(hsmbus) != 0UL) + { + hsmbus->XferSize--; + hsmbus->XferCount--; + } + } + } + else if ((hsmbus->XferCount == 0U) && (hsmbus->XferSize == 0U)) + { + /* Call TxCpltCallback() if no stop mode is set */ + if (SMBUS_GET_STOP_MODE(hsmbus) != SMBUS_AUTOEND_MODE) + { + /* Call the corresponding callback to inform upper layer of End of Transfer */ + if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_TX) + { + /* Disable Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_TX); + hsmbus->PreviousState = hsmbus->State; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->MasterTxCpltCallback(hsmbus); +#else + HAL_SMBUS_MasterTxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_RX) + { + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_RX); + hsmbus->PreviousState = hsmbus->State; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->MasterRxCpltCallback(hsmbus); +#else + HAL_SMBUS_MasterRxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else + { + /* Nothing to do */ + } + } + } + else + { + /* Nothing to do */ + } + } + else if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_TC) != RESET) + { + if (hsmbus->XferCount == 0U) + { + /* Specific use case for Quick command */ + if (hsmbus->pBuffPtr == NULL) + { + /* Generate a Stop command */ + hsmbus->Instance->CR2 |= I2C_CR2_STOP; + } + /* Call TxCpltCallback() if no stop mode is set */ + else if (SMBUS_GET_STOP_MODE(hsmbus) != SMBUS_AUTOEND_MODE) + { + /* No Generate Stop, to permit restart mode */ + /* The stop will be done at the end of transfer, when SMBUS_AUTOEND_MODE enable */ + + /* Call the corresponding callback to inform upper layer of End of Transfer */ + if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_TX) + { + /* Disable Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_TX); + hsmbus->PreviousState = hsmbus->State; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->MasterTxCpltCallback(hsmbus); +#else + HAL_SMBUS_MasterTxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else if (hsmbus->State == HAL_SMBUS_STATE_MASTER_BUSY_RX) + { + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_RX); + hsmbus->PreviousState = hsmbus->State; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->MasterRxCpltCallback(hsmbus); +#else + HAL_SMBUS_MasterRxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else + { + /* Nothing to do */ + } + } + else + { + /* Nothing to do */ + } + } + } + else + { + /* Nothing to do */ + } + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + return HAL_OK; +} +/** + * @brief Interrupt Sub-Routine which handle the Interrupt Flags Slave Mode. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param StatusFlags Value of Interrupt Flags. + * @retval HAL status + */ +static HAL_StatusTypeDef SMBUS_Slave_ISR(SMBUS_HandleTypeDef *hsmbus, uint32_t StatusFlags) +{ + uint8_t TransferDirection; + uint16_t SlaveAddrCode; + + /* Process Locked */ + __HAL_LOCK(hsmbus); + + if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_AF) != RESET) + { + /* Check that SMBUS transfer finished */ + /* if yes, normal usecase, a NACK is sent by the HOST when Transfer is finished */ + /* Mean XferCount == 0*/ + /* So clear Flag NACKF only */ + if (hsmbus->XferCount == 0U) + { + /* Clear NACK Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_AF); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + } + else + { + /* if no, error usecase, a Non-Acknowledge of last Data is generated by the HOST*/ + /* Clear NACK Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_AF); + + /* Set HAL State to "Idle" State, mean to LISTEN state */ + /* So reset Slave Busy state */ + hsmbus->PreviousState = hsmbus->State; + hsmbus->State &= ~((uint32_t)HAL_SMBUS_STATE_SLAVE_BUSY_TX); + hsmbus->State &= ~((uint32_t)HAL_SMBUS_STATE_SLAVE_BUSY_RX); + + /* Disable RX/TX Interrupts, keep only ADDR Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_RX | SMBUS_IT_TX); + + /* Set ErrorCode corresponding to a Non-Acknowledge */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_ACKF; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the Error callback to inform upper layer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->ErrorCallback(hsmbus); +#else + HAL_SMBUS_ErrorCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + } + else if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_ADDR) != RESET) + { + TransferDirection = (uint8_t)(SMBUS_GET_DIR(hsmbus)); + SlaveAddrCode = (uint16_t)(SMBUS_GET_ADDR_MATCH(hsmbus)); + + /* Disable ADDR interrupt to prevent multiple ADDRInterrupt*/ + /* Other ADDRInterrupt will be treat in next Listen usecase */ + __HAL_SMBUS_DISABLE_IT(hsmbus, SMBUS_IT_ADDRI); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call Slave Addr callback */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->AddrCallback(hsmbus, TransferDirection, SlaveAddrCode); +#else + HAL_SMBUS_AddrCallback(hsmbus, TransferDirection, SlaveAddrCode); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else if ((SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_RXNE) != RESET) || + (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_TCR) != RESET)) + { + if ((hsmbus->State & HAL_SMBUS_STATE_SLAVE_BUSY_RX) == HAL_SMBUS_STATE_SLAVE_BUSY_RX) + { + /* Read data from RXDR */ + *hsmbus->pBuffPtr = (uint8_t)(hsmbus->Instance->RXDR); + + /* Increment Buffer pointer */ + hsmbus->pBuffPtr++; + + hsmbus->XferSize--; + hsmbus->XferCount--; + + if (hsmbus->XferCount == 1U) + { + /* Receive last Byte, can be PEC byte in case of PEC BYTE enabled */ + /* or only the last Byte of Transfer */ + /* So reset the RELOAD bit mode */ + hsmbus->XferOptions &= ~SMBUS_RELOAD_MODE; + SMBUS_TransferConfig(hsmbus, 0, 1, hsmbus->XferOptions, SMBUS_NO_STARTSTOP); + } + else if (hsmbus->XferCount == 0U) + { + /* Last Byte is received, disable Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_RX); + + /* Remove HAL_SMBUS_STATE_SLAVE_BUSY_RX, keep only HAL_SMBUS_STATE_LISTEN */ + hsmbus->PreviousState = hsmbus->State; + hsmbus->State &= ~((uint32_t)HAL_SMBUS_STATE_SLAVE_BUSY_RX); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->SlaveRxCpltCallback(hsmbus); +#else + HAL_SMBUS_SlaveRxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + else + { + /* Set Reload for next Bytes */ + SMBUS_TransferConfig(hsmbus, 0, 1, + SMBUS_RELOAD_MODE | (hsmbus->XferOptions & SMBUS_SENDPEC_MODE), + SMBUS_NO_STARTSTOP); + + /* Ack last Byte Read */ + hsmbus->Instance->CR2 &= ~I2C_CR2_NACK; + } + } + else if ((hsmbus->State & HAL_SMBUS_STATE_SLAVE_BUSY_TX) == HAL_SMBUS_STATE_SLAVE_BUSY_TX) + { + if ((hsmbus->XferCount != 0U) && (hsmbus->XferSize == 0U)) + { + if (hsmbus->XferCount > MAX_NBYTE_SIZE) + { + SMBUS_TransferConfig(hsmbus, 0, MAX_NBYTE_SIZE, + (SMBUS_RELOAD_MODE | (hsmbus->XferOptions & SMBUS_SENDPEC_MODE)), + SMBUS_NO_STARTSTOP); + hsmbus->XferSize = MAX_NBYTE_SIZE; + } + else + { + hsmbus->XferSize = hsmbus->XferCount; + SMBUS_TransferConfig(hsmbus, 0, (uint8_t)hsmbus->XferSize, hsmbus->XferOptions, + SMBUS_NO_STARTSTOP); + /* If PEC mode is enable, size to transmit should be Size-1 byte, corresponding to PEC byte */ + /* PEC byte is automatically sent by HW block, no need to manage it in Transmit process */ + if (SMBUS_GET_PEC_MODE(hsmbus) != 0UL) + { + hsmbus->XferSize--; + hsmbus->XferCount--; + } + } + } + } + else + { + /* Nothing to do */ + } + } + else if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_TXIS) != RESET) + { + /* Write data to TXDR only if XferCount not reach "0" */ + /* A TXIS flag can be set, during STOP treatment */ + /* Check if all Data have already been sent */ + /* If it is the case, this last write in TXDR is not sent, correspond to a dummy TXIS event */ + if (hsmbus->XferCount > 0U) + { + /* Write data to TXDR */ + hsmbus->Instance->TXDR = *hsmbus->pBuffPtr; + + /* Increment Buffer pointer */ + hsmbus->pBuffPtr++; + + hsmbus->XferCount--; + hsmbus->XferSize--; + } + + if (hsmbus->XferCount == 0U) + { + /* Last Byte is Transmitted */ + /* Remove HAL_SMBUS_STATE_SLAVE_BUSY_TX, keep only HAL_SMBUS_STATE_LISTEN */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_TX); + hsmbus->PreviousState = hsmbus->State; + hsmbus->State &= ~((uint32_t)HAL_SMBUS_STATE_SLAVE_BUSY_TX); + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the corresponding callback to inform upper layer of End of Transfer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->SlaveTxCpltCallback(hsmbus); +#else + HAL_SMBUS_SlaveTxCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + } + else + { + /* Nothing to do */ + } + + /* Check if STOPF is set */ + if (SMBUS_CHECK_FLAG(StatusFlags, SMBUS_FLAG_STOPF) != RESET) + { + if ((hsmbus->State & HAL_SMBUS_STATE_LISTEN) == HAL_SMBUS_STATE_LISTEN) + { + /* Store Last receive data if any */ + if (__HAL_SMBUS_GET_FLAG(hsmbus, SMBUS_FLAG_RXNE) != RESET) + { + /* Read data from RXDR */ + *hsmbus->pBuffPtr = (uint8_t)(hsmbus->Instance->RXDR); + + /* Increment Buffer pointer */ + hsmbus->pBuffPtr++; + + if ((hsmbus->XferSize > 0U)) + { + hsmbus->XferSize--; + hsmbus->XferCount--; + } + } + + /* Disable RX and TX Interrupts */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_RX | SMBUS_IT_TX); + + /* Disable ADDR Interrupt */ + SMBUS_Disable_IRQ(hsmbus, SMBUS_IT_ADDR); + + /* Disable Address Acknowledge */ + hsmbus->Instance->CR2 |= I2C_CR2_NACK; + + /* Clear Configuration Register 2 */ + SMBUS_RESET_CR2(hsmbus); + + /* Clear STOP Flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_STOPF); + + /* Clear ADDR flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_ADDR); + + hsmbus->XferOptions = 0; + hsmbus->PreviousState = hsmbus->State; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + /* Call the Listen Complete callback, to inform upper layer of the end of Listen usecase */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->ListenCpltCallback(hsmbus); +#else + HAL_SMBUS_ListenCpltCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } + } + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + return HAL_OK; +} +/** + * @brief Manage the enabling of Interrupts. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param InterruptRequest Value of @ref SMBUS_Interrupt_configuration_definition. + * @retval HAL status + */ +static void SMBUS_Enable_IRQ(SMBUS_HandleTypeDef *hsmbus, uint32_t InterruptRequest) +{ + uint32_t tmpisr = 0UL; + + if ((InterruptRequest & SMBUS_IT_ALERT) == SMBUS_IT_ALERT) + { + /* Enable ERR interrupt */ + tmpisr |= SMBUS_IT_ERRI; + } + + if ((InterruptRequest & SMBUS_IT_ADDR) == SMBUS_IT_ADDR) + { + /* Enable ADDR, STOP interrupt */ + tmpisr |= SMBUS_IT_ADDRI | SMBUS_IT_STOPI | SMBUS_IT_NACKI | SMBUS_IT_ERRI; + } + + if ((InterruptRequest & SMBUS_IT_TX) == SMBUS_IT_TX) + { + /* Enable ERR, TC, STOP, NACK, RXI interrupt */ + tmpisr |= SMBUS_IT_ERRI | SMBUS_IT_TCI | SMBUS_IT_STOPI | SMBUS_IT_NACKI | SMBUS_IT_TXI; + } + + if ((InterruptRequest & SMBUS_IT_RX) == SMBUS_IT_RX) + { + /* Enable ERR, TC, STOP, NACK, TXI interrupt */ + tmpisr |= SMBUS_IT_ERRI | SMBUS_IT_TCI | SMBUS_IT_STOPI | SMBUS_IT_NACKI | SMBUS_IT_RXI; + } + + /* Enable interrupts only at the end */ + /* to avoid the risk of SMBUS interrupt handle execution before */ + /* all interrupts requested done */ + __HAL_SMBUS_ENABLE_IT(hsmbus, tmpisr); +} +/** + * @brief Manage the disabling of Interrupts. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param InterruptRequest Value of @ref SMBUS_Interrupt_configuration_definition. + * @retval HAL status + */ +static void SMBUS_Disable_IRQ(SMBUS_HandleTypeDef *hsmbus, uint32_t InterruptRequest) +{ + uint32_t tmpisr = 0UL; + uint32_t tmpstate = hsmbus->State; + + if ((tmpstate == HAL_SMBUS_STATE_READY) && ((InterruptRequest & SMBUS_IT_ALERT) == SMBUS_IT_ALERT)) + { + /* Disable ERR interrupt */ + tmpisr |= SMBUS_IT_ERRI; + } + + if ((InterruptRequest & SMBUS_IT_TX) == SMBUS_IT_TX) + { + /* Disable TC, STOP, NACK and TXI interrupt */ + tmpisr |= SMBUS_IT_TCI | SMBUS_IT_TXI; + + if ((SMBUS_GET_ALERT_ENABLED(hsmbus) == 0UL) + && ((tmpstate & HAL_SMBUS_STATE_LISTEN) != HAL_SMBUS_STATE_LISTEN)) + { + /* Disable ERR interrupt */ + tmpisr |= SMBUS_IT_ERRI; + } + + if ((tmpstate & HAL_SMBUS_STATE_LISTEN) != HAL_SMBUS_STATE_LISTEN) + { + /* Disable STOP and NACK interrupt */ + tmpisr |= SMBUS_IT_STOPI | SMBUS_IT_NACKI; + } + } + + if ((InterruptRequest & SMBUS_IT_RX) == SMBUS_IT_RX) + { + /* Disable TC, STOP, NACK and RXI interrupt */ + tmpisr |= SMBUS_IT_TCI | SMBUS_IT_RXI; + + if ((SMBUS_GET_ALERT_ENABLED(hsmbus) == 0UL) + && ((tmpstate & HAL_SMBUS_STATE_LISTEN) != HAL_SMBUS_STATE_LISTEN)) + { + /* Disable ERR interrupt */ + tmpisr |= SMBUS_IT_ERRI; + } + + if ((tmpstate & HAL_SMBUS_STATE_LISTEN) != HAL_SMBUS_STATE_LISTEN) + { + /* Disable STOP and NACK interrupt */ + tmpisr |= SMBUS_IT_STOPI | SMBUS_IT_NACKI; + } + } + + if ((InterruptRequest & SMBUS_IT_ADDR) == SMBUS_IT_ADDR) + { + /* Disable ADDR, STOP and NACK interrupt */ + tmpisr |= SMBUS_IT_ADDRI | SMBUS_IT_STOPI | SMBUS_IT_NACKI; + + if (SMBUS_GET_ALERT_ENABLED(hsmbus) == 0UL) + { + /* Disable ERR interrupt */ + tmpisr |= SMBUS_IT_ERRI; + } + } + + /* Disable interrupts only at the end */ + /* to avoid a breaking situation like at "t" time */ + /* all disable interrupts request are not done */ + __HAL_SMBUS_DISABLE_IT(hsmbus, tmpisr); +} + +/** + * @brief SMBUS interrupts error handler. + * @param hsmbus SMBUS handle. + * @retval None + */ +static void SMBUS_ITErrorHandler(SMBUS_HandleTypeDef *hsmbus) +{ + uint32_t itflags = READ_REG(hsmbus->Instance->ISR); + uint32_t itsources = READ_REG(hsmbus->Instance->CR1); + uint32_t tmpstate; + uint32_t tmperror; + + /* SMBUS Bus error interrupt occurred ------------------------------------*/ + if (((itflags & SMBUS_FLAG_BERR) == SMBUS_FLAG_BERR) && \ + ((itsources & SMBUS_IT_ERRI) == SMBUS_IT_ERRI)) + { + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_BERR; + + /* Clear BERR flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_BERR); + } + + /* SMBUS Over-Run/Under-Run interrupt occurred ----------------------------------------*/ + if (((itflags & SMBUS_FLAG_OVR) == SMBUS_FLAG_OVR) && \ + ((itsources & SMBUS_IT_ERRI) == SMBUS_IT_ERRI)) + { + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_OVR; + + /* Clear OVR flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_OVR); + } + + /* SMBUS Arbitration Loss error interrupt occurred ------------------------------------*/ + if (((itflags & SMBUS_FLAG_ARLO) == SMBUS_FLAG_ARLO) && \ + ((itsources & SMBUS_IT_ERRI) == SMBUS_IT_ERRI)) + { + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_ARLO; + + /* Clear ARLO flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_ARLO); + } + + /* SMBUS Timeout error interrupt occurred ---------------------------------------------*/ + if (((itflags & SMBUS_FLAG_TIMEOUT) == SMBUS_FLAG_TIMEOUT) && \ + ((itsources & SMBUS_IT_ERRI) == SMBUS_IT_ERRI)) + { + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_BUSTIMEOUT; + + /* Clear TIMEOUT flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_TIMEOUT); + } + + /* SMBUS Alert error interrupt occurred -----------------------------------------------*/ + if (((itflags & SMBUS_FLAG_ALERT) == SMBUS_FLAG_ALERT) && \ + ((itsources & SMBUS_IT_ERRI) == SMBUS_IT_ERRI)) + { + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_ALERT; + + /* Clear ALERT flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_ALERT); + } + + /* SMBUS Packet Error Check error interrupt occurred ----------------------------------*/ + if (((itflags & SMBUS_FLAG_PECERR) == SMBUS_FLAG_PECERR) && \ + ((itsources & SMBUS_IT_ERRI) == SMBUS_IT_ERRI)) + { + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_PECERR; + + /* Clear PEC error flag */ + __HAL_SMBUS_CLEAR_FLAG(hsmbus, SMBUS_FLAG_PECERR); + } + + /* Store current volatile hsmbus->State, misra rule */ + tmperror = hsmbus->ErrorCode; + + /* Call the Error Callback in case of Error detected */ + if ((tmperror != HAL_SMBUS_ERROR_NONE) && (tmperror != HAL_SMBUS_ERROR_ACKF)) + { + /* Do not Reset the HAL state in case of ALERT error */ + if ((tmperror & HAL_SMBUS_ERROR_ALERT) != HAL_SMBUS_ERROR_ALERT) + { + /* Store current volatile hsmbus->State, misra rule */ + tmpstate = hsmbus->State; + + if (((tmpstate & HAL_SMBUS_STATE_SLAVE_BUSY_TX) == HAL_SMBUS_STATE_SLAVE_BUSY_TX) + || ((tmpstate & HAL_SMBUS_STATE_SLAVE_BUSY_RX) == HAL_SMBUS_STATE_SLAVE_BUSY_RX)) + { + /* Reset only HAL_SMBUS_STATE_SLAVE_BUSY_XX */ + /* keep HAL_SMBUS_STATE_LISTEN if set */ + hsmbus->PreviousState = HAL_SMBUS_STATE_READY; + hsmbus->State = HAL_SMBUS_STATE_LISTEN; + } + } + + /* Call the Error callback to inform upper layer */ +#if (USE_HAL_SMBUS_REGISTER_CALLBACKS == 1) + hsmbus->ErrorCallback(hsmbus); +#else + HAL_SMBUS_ErrorCallback(hsmbus); +#endif /* USE_HAL_SMBUS_REGISTER_CALLBACKS */ + } +} + +/** + * @brief Handle SMBUS Communication Timeout. + * @param hsmbus Pointer to a SMBUS_HandleTypeDef structure that contains + * the configuration information for the specified SMBUS. + * @param Flag Specifies the SMBUS flag to check. + * @param Status The new Flag status (SET or RESET). + * @param Timeout Timeout duration + * @retval HAL status + */ +static HAL_StatusTypeDef SMBUS_WaitOnFlagUntilTimeout(SMBUS_HandleTypeDef *hsmbus, uint32_t Flag, + FlagStatus Status, uint32_t Timeout) +{ + uint32_t tickstart = HAL_GetTick(); + + /* Wait until flag is set */ + while ((FlagStatus)(__HAL_SMBUS_GET_FLAG(hsmbus, Flag)) == Status) + { + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0UL)) + { + hsmbus->PreviousState = hsmbus->State; + hsmbus->State = HAL_SMBUS_STATE_READY; + + /* Update SMBUS error code */ + hsmbus->ErrorCode |= HAL_SMBUS_ERROR_HALTIMEOUT; + + /* Process Unlocked */ + __HAL_UNLOCK(hsmbus); + + return HAL_ERROR; + } + } + } + + return HAL_OK; +} + +/** + * @brief Handle SMBUSx communication when starting transfer or during transfer (TC or TCR flag are set). + * @param hsmbus SMBUS handle. + * @param DevAddress specifies the slave address to be programmed. + * @param Size specifies the number of bytes to be programmed. + * This parameter must be a value between 0 and 255. + * @param Mode New state of the SMBUS START condition generation. + * This parameter can be one or a combination of the following values: + * @arg @ref SMBUS_RELOAD_MODE Enable Reload mode. + * @arg @ref SMBUS_AUTOEND_MODE Enable Automatic end mode. + * @arg @ref SMBUS_SOFTEND_MODE Enable Software end mode and Reload mode. + * @arg @ref SMBUS_SENDPEC_MODE Enable Packet Error Calculation mode. + * @param Request New state of the SMBUS START condition generation. + * This parameter can be one of the following values: + * @arg @ref SMBUS_NO_STARTSTOP Don't Generate stop and start condition. + * @arg @ref SMBUS_GENERATE_STOP Generate stop condition (Size should be set to 0). + * @arg @ref SMBUS_GENERATE_START_READ Generate Restart for read request. + * @arg @ref SMBUS_GENERATE_START_WRITE Generate Restart for write request. + * @retval None + */ +static void SMBUS_TransferConfig(SMBUS_HandleTypeDef *hsmbus, uint16_t DevAddress, uint8_t Size, + uint32_t Mode, uint32_t Request) +{ + /* Check the parameters */ + assert_param(IS_SMBUS_ALL_INSTANCE(hsmbus->Instance)); + assert_param(IS_SMBUS_TRANSFER_MODE(Mode)); + assert_param(IS_SMBUS_TRANSFER_REQUEST(Request)); + + /* update CR2 register */ + MODIFY_REG(hsmbus->Instance->CR2, + ((I2C_CR2_SADD | I2C_CR2_NBYTES | I2C_CR2_RELOAD | I2C_CR2_AUTOEND | \ + (I2C_CR2_RD_WRN & (uint32_t)(Request >> (31UL - I2C_CR2_RD_WRN_Pos))) | \ + I2C_CR2_START | I2C_CR2_STOP | I2C_CR2_PECBYTE)), \ + (uint32_t)(((uint32_t)DevAddress & I2C_CR2_SADD) | \ + (((uint32_t)Size << I2C_CR2_NBYTES_Pos) & I2C_CR2_NBYTES) | \ + (uint32_t)Mode | (uint32_t)Request)); +} + +/** + * @brief Convert SMBUSx OTHER_xxx XferOptions to functional XferOptions. + * @param hsmbus SMBUS handle. + * @retval None + */ +static void SMBUS_ConvertOtherXferOptions(SMBUS_HandleTypeDef *hsmbus) +{ + /* if user set XferOptions to SMBUS_OTHER_FRAME_NO_PEC */ + /* it request implicitly to generate a restart condition */ + /* set XferOptions to SMBUS_FIRST_FRAME */ + if (hsmbus->XferOptions == SMBUS_OTHER_FRAME_NO_PEC) + { + hsmbus->XferOptions = SMBUS_FIRST_FRAME; + } + /* else if user set XferOptions to SMBUS_OTHER_FRAME_WITH_PEC */ + /* it request implicitly to generate a restart condition */ + /* set XferOptions to SMBUS_FIRST_FRAME | SMBUS_SENDPEC_MODE */ + else if (hsmbus->XferOptions == SMBUS_OTHER_FRAME_WITH_PEC) + { + hsmbus->XferOptions = SMBUS_FIRST_FRAME | SMBUS_SENDPEC_MODE; + } + /* else if user set XferOptions to SMBUS_OTHER_AND_LAST_FRAME_NO_PEC */ + /* it request implicitly to generate a restart condition */ + /* then generate a stop condition at the end of transfer */ + /* set XferOptions to SMBUS_FIRST_AND_LAST_FRAME_NO_PEC */ + else if (hsmbus->XferOptions == SMBUS_OTHER_AND_LAST_FRAME_NO_PEC) + { + hsmbus->XferOptions = SMBUS_FIRST_AND_LAST_FRAME_NO_PEC; + } + /* else if user set XferOptions to SMBUS_OTHER_AND_LAST_FRAME_WITH_PEC */ + /* it request implicitly to generate a restart condition */ + /* then generate a stop condition at the end of transfer */ + /* set XferOptions to SMBUS_FIRST_AND_LAST_FRAME_WITH_PEC */ + else if (hsmbus->XferOptions == SMBUS_OTHER_AND_LAST_FRAME_WITH_PEC) + { + hsmbus->XferOptions = SMBUS_FIRST_AND_LAST_FRAME_WITH_PEC; + } + else + { + /* Nothing to do */ + } +} +/** + * @} + */ + +#endif /* HAL_SMBUS_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi.c new file mode 100644 index 0000000..a3cea6b --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi.c @@ -0,0 +1,4404 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_spi.c + * @author MCD Application Team + * @brief SPI HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Serial Peripheral Interface (SPI) peripheral: + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral Control functions + * + Peripheral State functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + The SPI HAL driver can be used as follows: + + (#) Declare a SPI_HandleTypeDef handle structure, for example: + SPI_HandleTypeDef hspi; + + (#)Initialize the SPI low level resources by implementing the HAL_SPI_MspInit() API: + (##) Enable the SPIx interface clock + (##) SPI pins configuration + (+++) Enable the clock for the SPI GPIOs + (+++) Configure these SPI pins as alternate function push-pull + (##) NVIC configuration if you need to use interrupt process + (+++) Configure the SPIx interrupt priority + (+++) Enable the NVIC SPI IRQ handle + (##) DMA Configuration if you need to use DMA process + (+++) Declare a DMA_HandleTypeDef handle structure for the transmit or receive Stream/Channel + (+++) Enable the DMAx clock + (+++) Configure the DMA handle parameters + (+++) Configure the DMA Tx or Rx Stream/Channel + (+++) Associate the initialized hdma_tx(or _rx) handle to the hspi DMA Tx or Rx handle + (+++) Configure the priority and enable the NVIC for the transfer complete interrupt on the DMA Tx or Rx Stream/Channel + + (#) Program the Mode, BidirectionalMode , Data size, Baudrate Prescaler, NSS + management, Clock polarity and phase, FirstBit and CRC configuration in the hspi Init structure. + + (#) Initialize the SPI registers by calling the HAL_SPI_Init() API: + (++) This API configures also the low level Hardware GPIO, CLOCK, CORTEX...etc) + by calling the customized HAL_SPI_MspInit() API. + [..] + Circular mode restriction: + (#) The DMA circular mode cannot be used when the SPI is configured in these modes: + (##) Master 2Lines RxOnly + (##) Master 1Line Rx + (#) The CRC feature is not managed when the DMA circular mode is enabled + (#) When the SPI DMA Pause/Stop features are used, we must use the following APIs + the HAL_SPI_DMAPause()/ HAL_SPI_DMAStop() only under the SPI callbacks + [..] + Master Receive mode restriction: + (#) In Master unidirectional receive-only mode (MSTR =1, BIDIMODE=0, RXONLY=1) or + bidirectional receive mode (MSTR=1, BIDIMODE=1, BIDIOE=0), to ensure that the SPI + does not initiate a new transfer the following procedure has to be respected: + (##) HAL_SPI_DeInit() + (##) HAL_SPI_Init() + [..] + Callback registration: + + (#) The compilation flag USE_HAL_SPI_REGISTER_CALLBACKS when set to 1U + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_SPI_RegisterCallback() to register an interrupt callback. + + Function HAL_SPI_RegisterCallback() allows to register following callbacks: + (++) TxCpltCallback : SPI Tx Completed callback + (++) RxCpltCallback : SPI Rx Completed callback + (++) TxRxCpltCallback : SPI TxRx Completed callback + (++) TxHalfCpltCallback : SPI Tx Half Completed callback + (++) RxHalfCpltCallback : SPI Rx Half Completed callback + (++) TxRxHalfCpltCallback : SPI TxRx Half Completed callback + (++) ErrorCallback : SPI Error callback + (++) AbortCpltCallback : SPI Abort callback + (++) MspInitCallback : SPI Msp Init callback + (++) MspDeInitCallback : SPI Msp DeInit callback + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + + (#) Use function HAL_SPI_UnRegisterCallback to reset a callback to the default + weak function. + HAL_SPI_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (++) TxCpltCallback : SPI Tx Completed callback + (++) RxCpltCallback : SPI Rx Completed callback + (++) TxRxCpltCallback : SPI TxRx Completed callback + (++) TxHalfCpltCallback : SPI Tx Half Completed callback + (++) RxHalfCpltCallback : SPI Rx Half Completed callback + (++) TxRxHalfCpltCallback : SPI TxRx Half Completed callback + (++) ErrorCallback : SPI Error callback + (++) AbortCpltCallback : SPI Abort callback + (++) MspInitCallback : SPI Msp Init callback + (++) MspDeInitCallback : SPI Msp DeInit callback + + [..] + By default, after the HAL_SPI_Init() and when the state is HAL_SPI_STATE_RESET + all callbacks are set to the corresponding weak functions: + examples HAL_SPI_MasterTxCpltCallback(), HAL_SPI_MasterRxCpltCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak functions in the HAL_SPI_Init()/ HAL_SPI_DeInit() only when + these callbacks are null (not registered beforehand). + If MspInit or MspDeInit are not null, the HAL_SPI_Init()/ HAL_SPI_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state. + + [..] + Callbacks can be registered/unregistered in HAL_SPI_STATE_READY state only. + Exception done MspInit/MspDeInit functions that can be registered/unregistered + in HAL_SPI_STATE_READY or HAL_SPI_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + Then, the user first registers the MspInit/MspDeInit user callbacks + using HAL_SPI_RegisterCallback() before calling HAL_SPI_DeInit() + or HAL_SPI_Init() function. + + [..] + When the compilation define USE_HAL_PPP_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registering feature is not available + and weak (surcharged) callbacks are used. + + [..] + Using the HAL it is not possible to reach all supported SPI frequency with the different SPI Modes, + the following table resume the max SPI frequency reached with data size 8bits/16bits, + according to frequency of the APBx Peripheral Clock (fPCLK) used by the SPI instance. + + @endverbatim + + Additional table : + + DataSize = SPI_DATASIZE_8BIT: + +----------------------------------------------------------------------------------------------+ + | | | 2Lines Fullduplex | 2Lines RxOnly | 1Line | + | Process | Transfer mode |---------------------|----------------------|----------------------| + | | | Master | Slave | Master | Slave | Master | Slave | + |==============================================================================================| + | T | Polling | Fpclk/4 | Fpclk/8 | NA | NA | NA | NA | + | X |----------------|----------|----------|-----------|----------|-----------|----------| + | / | Interrupt | Fpclk/4 | Fpclk/16 | NA | NA | NA | NA | + | R |----------------|----------|----------|-----------|----------|-----------|----------| + | X | DMA | Fpclk/2 | Fpclk/2 | NA | NA | NA | NA | + |=========|================|==========|==========|===========|==========|===========|==========| + | | Polling | Fpclk/4 | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 | + | |----------------|----------|----------|-----------|----------|-----------|----------| + | R | Interrupt | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 | Fpclk/4 | + | X |----------------|----------|----------|-----------|----------|-----------|----------| + | | DMA | Fpclk/4 | Fpclk/2 | Fpclk/2 | Fpclk/16 | Fpclk/2 | Fpclk/16 | + |=========|================|==========|==========|===========|==========|===========|==========| + | | Polling | Fpclk/8 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/8 | + | |----------------|----------|----------|-----------|----------|-----------|----------| + | T | Interrupt | Fpclk/2 | Fpclk/4 | NA | NA | Fpclk/16 | Fpclk/8 | + | X |----------------|----------|----------|-----------|----------|-----------|----------| + | | DMA | Fpclk/2 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/16 | + +----------------------------------------------------------------------------------------------+ + + DataSize = SPI_DATASIZE_16BIT: + +----------------------------------------------------------------------------------------------+ + | | | 2Lines Fullduplex | 2Lines RxOnly | 1Line | + | Process | Transfer mode |---------------------|----------------------|----------------------| + | | | Master | Slave | Master | Slave | Master | Slave | + |==============================================================================================| + | T | Polling | Fpclk/4 | Fpclk/8 | NA | NA | NA | NA | + | X |----------------|----------|----------|-----------|----------|-----------|----------| + | / | Interrupt | Fpclk/4 | Fpclk/16 | NA | NA | NA | NA | + | R |----------------|----------|----------|-----------|----------|-----------|----------| + | X | DMA | Fpclk/2 | Fpclk/2 | NA | NA | NA | NA | + |=========|================|==========|==========|===========|==========|===========|==========| + | | Polling | Fpclk/4 | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 | + | |----------------|----------|----------|-----------|----------|-----------|----------| + | R | Interrupt | Fpclk/8 | Fpclk/16 | Fpclk/8 | Fpclk/8 | Fpclk/8 | Fpclk/4 | + | X |----------------|----------|----------|-----------|----------|-----------|----------| + | | DMA | Fpclk/4 | Fpclk/2 | Fpclk/2 | Fpclk/16 | Fpclk/2 | Fpclk/16 | + |=========|================|==========|==========|===========|==========|===========|==========| + | | Polling | Fpclk/8 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/8 | + | |----------------|----------|----------|-----------|----------|-----------|----------| + | T | Interrupt | Fpclk/2 | Fpclk/4 | NA | NA | Fpclk/16 | Fpclk/8 | + | X |----------------|----------|----------|-----------|----------|-----------|----------| + | | DMA | Fpclk/2 | Fpclk/2 | NA | NA | Fpclk/8 | Fpclk/16 | + +----------------------------------------------------------------------------------------------+ + @note The max SPI frequency depend on SPI data size (4bits, 5bits,..., 8bits,...15bits, 16bits), + SPI mode(2 Lines fullduplex, 2 lines RxOnly, 1 line TX/RX) and Process mode (Polling, IT, DMA). + @note + (#) TX/RX processes are HAL_SPI_TransmitReceive(), HAL_SPI_TransmitReceive_IT() and HAL_SPI_TransmitReceive_DMA() + (#) RX processes are HAL_SPI_Receive(), HAL_SPI_Receive_IT() and HAL_SPI_Receive_DMA() + (#) TX processes are HAL_SPI_Transmit(), HAL_SPI_Transmit_IT() and HAL_SPI_Transmit_DMA() + + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup SPI SPI + * @brief SPI HAL module driver + * @{ + */ +#ifdef HAL_SPI_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private defines -----------------------------------------------------------*/ +/** @defgroup SPI_Private_Constants SPI Private Constants + * @{ + */ +#define SPI_DEFAULT_TIMEOUT 100U +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup SPI_Private_Functions SPI Private Functions + * @{ + */ +static void SPI_DMATransmitCplt(DMA_HandleTypeDef *hdma); +static void SPI_DMAReceiveCplt(DMA_HandleTypeDef *hdma); +static void SPI_DMATransmitReceiveCplt(DMA_HandleTypeDef *hdma); +static void SPI_DMAHalfTransmitCplt(DMA_HandleTypeDef *hdma); +static void SPI_DMAHalfReceiveCplt(DMA_HandleTypeDef *hdma); +static void SPI_DMAHalfTransmitReceiveCplt(DMA_HandleTypeDef *hdma); +static void SPI_DMAError(DMA_HandleTypeDef *hdma); +static void SPI_DMAAbortOnError(DMA_HandleTypeDef *hdma); +static void SPI_DMATxAbortCallback(DMA_HandleTypeDef *hdma); +static void SPI_DMARxAbortCallback(DMA_HandleTypeDef *hdma); +static HAL_StatusTypeDef SPI_WaitFlagStateUntilTimeout(SPI_HandleTypeDef *hspi, uint32_t Flag, FlagStatus State, + uint32_t Timeout, uint32_t Tickstart); +static HAL_StatusTypeDef SPI_WaitFifoStateUntilTimeout(SPI_HandleTypeDef *hspi, uint32_t Fifo, uint32_t State, + uint32_t Timeout, uint32_t Tickstart); +static void SPI_TxISR_8BIT(struct __SPI_HandleTypeDef *hspi); +static void SPI_TxISR_16BIT(struct __SPI_HandleTypeDef *hspi); +static void SPI_RxISR_8BIT(struct __SPI_HandleTypeDef *hspi); +static void SPI_RxISR_16BIT(struct __SPI_HandleTypeDef *hspi); +static void SPI_2linesRxISR_8BIT(struct __SPI_HandleTypeDef *hspi); +static void SPI_2linesTxISR_8BIT(struct __SPI_HandleTypeDef *hspi); +static void SPI_2linesTxISR_16BIT(struct __SPI_HandleTypeDef *hspi); +static void SPI_2linesRxISR_16BIT(struct __SPI_HandleTypeDef *hspi); +#if (USE_SPI_CRC != 0U) +static void SPI_RxISR_8BITCRC(struct __SPI_HandleTypeDef *hspi); +static void SPI_RxISR_16BITCRC(struct __SPI_HandleTypeDef *hspi); +static void SPI_2linesRxISR_8BITCRC(struct __SPI_HandleTypeDef *hspi); +static void SPI_2linesRxISR_16BITCRC(struct __SPI_HandleTypeDef *hspi); +#endif /* USE_SPI_CRC */ +static void SPI_AbortRx_ISR(SPI_HandleTypeDef *hspi); +static void SPI_AbortTx_ISR(SPI_HandleTypeDef *hspi); +static void SPI_CloseRxTx_ISR(SPI_HandleTypeDef *hspi); +static void SPI_CloseRx_ISR(SPI_HandleTypeDef *hspi); +static void SPI_CloseTx_ISR(SPI_HandleTypeDef *hspi); +static HAL_StatusTypeDef SPI_EndRxTransaction(SPI_HandleTypeDef *hspi, uint32_t Timeout, uint32_t Tickstart); +static HAL_StatusTypeDef SPI_EndRxTxTransaction(SPI_HandleTypeDef *hspi, uint32_t Timeout, uint32_t Tickstart); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup SPI_Exported_Functions SPI Exported Functions + * @{ + */ + +/** @defgroup SPI_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This subsection provides a set of functions allowing to initialize and + de-initialize the SPIx peripheral: + + (+) User must implement HAL_SPI_MspInit() function in which he configures + all related peripherals resources (CLOCK, GPIO, DMA, IT and NVIC ). + + (+) Call the function HAL_SPI_Init() to configure the selected device with + the selected configuration: + (++) Mode + (++) Direction + (++) Data Size + (++) Clock Polarity and Phase + (++) NSS Management + (++) BaudRate Prescaler + (++) FirstBit + (++) TIMode + (++) CRC Calculation + (++) CRC Polynomial if CRC enabled + (++) CRC Length, used only with Data8 and Data16 + (++) FIFO reception threshold + + (+) Call the function HAL_SPI_DeInit() to restore the default configuration + of the selected SPIx peripheral. + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the SPI according to the specified parameters + * in the SPI_InitTypeDef and initialize the associated handle. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Init(SPI_HandleTypeDef *hspi) +{ + uint32_t frxth; + + /* Check the SPI handle allocation */ + if (hspi == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_SPI_ALL_INSTANCE(hspi->Instance)); + assert_param(IS_SPI_MODE(hspi->Init.Mode)); + assert_param(IS_SPI_DIRECTION(hspi->Init.Direction)); + assert_param(IS_SPI_DATASIZE(hspi->Init.DataSize)); + assert_param(IS_SPI_NSS(hspi->Init.NSS)); + assert_param(IS_SPI_NSSP(hspi->Init.NSSPMode)); + assert_param(IS_SPI_BAUDRATE_PRESCALER(hspi->Init.BaudRatePrescaler)); + assert_param(IS_SPI_FIRST_BIT(hspi->Init.FirstBit)); + assert_param(IS_SPI_TIMODE(hspi->Init.TIMode)); + if (hspi->Init.TIMode == SPI_TIMODE_DISABLE) + { + assert_param(IS_SPI_CPOL(hspi->Init.CLKPolarity)); + assert_param(IS_SPI_CPHA(hspi->Init.CLKPhase)); + + if (hspi->Init.Mode == SPI_MODE_MASTER) + { + assert_param(IS_SPI_BAUDRATE_PRESCALER(hspi->Init.BaudRatePrescaler)); + } + else + { + /* Baudrate prescaler not use in Motoraola Slave mode. force to default value */ + hspi->Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2; + } + } + else + { + assert_param(IS_SPI_BAUDRATE_PRESCALER(hspi->Init.BaudRatePrescaler)); + + /* Force polarity and phase to TI protocaol requirements */ + hspi->Init.CLKPolarity = SPI_POLARITY_LOW; + hspi->Init.CLKPhase = SPI_PHASE_1EDGE; + } +#if (USE_SPI_CRC != 0U) + assert_param(IS_SPI_CRC_CALCULATION(hspi->Init.CRCCalculation)); + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + assert_param(IS_SPI_CRC_POLYNOMIAL(hspi->Init.CRCPolynomial)); + assert_param(IS_SPI_CRC_LENGTH(hspi->Init.CRCLength)); + } +#else + hspi->Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE; +#endif /* USE_SPI_CRC */ + + if (hspi->State == HAL_SPI_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + hspi->Lock = HAL_UNLOCKED; + +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + /* Init the SPI Callback settings */ + hspi->TxCpltCallback = HAL_SPI_TxCpltCallback; /* Legacy weak TxCpltCallback */ + hspi->RxCpltCallback = HAL_SPI_RxCpltCallback; /* Legacy weak RxCpltCallback */ + hspi->TxRxCpltCallback = HAL_SPI_TxRxCpltCallback; /* Legacy weak TxRxCpltCallback */ + hspi->TxHalfCpltCallback = HAL_SPI_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + hspi->RxHalfCpltCallback = HAL_SPI_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + hspi->TxRxHalfCpltCallback = HAL_SPI_TxRxHalfCpltCallback; /* Legacy weak TxRxHalfCpltCallback */ + hspi->ErrorCallback = HAL_SPI_ErrorCallback; /* Legacy weak ErrorCallback */ + hspi->AbortCpltCallback = HAL_SPI_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + + if (hspi->MspInitCallback == NULL) + { + hspi->MspInitCallback = HAL_SPI_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware : GPIO, CLOCK, NVIC... */ + hspi->MspInitCallback(hspi); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC... */ + HAL_SPI_MspInit(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + + hspi->State = HAL_SPI_STATE_BUSY; + + /* Disable the selected SPI peripheral */ + __HAL_SPI_DISABLE(hspi); + + /* Align by default the rs fifo threshold on the data size */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + frxth = SPI_RXFIFO_THRESHOLD_HF; + } + else + { + frxth = SPI_RXFIFO_THRESHOLD_QF; + } + + /* CRC calculation is valid only for 16Bit and 8 Bit */ + if ((hspi->Init.DataSize != SPI_DATASIZE_16BIT) && (hspi->Init.DataSize != SPI_DATASIZE_8BIT)) + { + /* CRC must be disabled */ + hspi->Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE; + } + + /*----------------------- SPIx CR1 & CR2 Configuration ---------------------*/ + /* Configure : SPI Mode, Communication Mode, Clock polarity and phase, NSS management, + Communication speed, First bit and CRC calculation state */ + WRITE_REG(hspi->Instance->CR1, ((hspi->Init.Mode & (SPI_CR1_MSTR | SPI_CR1_SSI)) | + (hspi->Init.Direction & (SPI_CR1_RXONLY | SPI_CR1_BIDIMODE)) | + (hspi->Init.CLKPolarity & SPI_CR1_CPOL) | + (hspi->Init.CLKPhase & SPI_CR1_CPHA) | + (hspi->Init.NSS & SPI_CR1_SSM) | + (hspi->Init.BaudRatePrescaler & SPI_CR1_BR_Msk) | + (hspi->Init.FirstBit & SPI_CR1_LSBFIRST) | + (hspi->Init.CRCCalculation & SPI_CR1_CRCEN))); +#if (USE_SPI_CRC != 0U) + /*---------------------------- SPIx CRCL Configuration -------------------*/ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* Align the CRC Length on the data size */ + if (hspi->Init.CRCLength == SPI_CRC_LENGTH_DATASIZE) + { + /* CRC Length aligned on the data size : value set by default */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + hspi->Init.CRCLength = SPI_CRC_LENGTH_16BIT; + } + else + { + hspi->Init.CRCLength = SPI_CRC_LENGTH_8BIT; + } + } + + /* Configure : CRC Length */ + if (hspi->Init.CRCLength == SPI_CRC_LENGTH_16BIT) + { + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCL); + } + } +#endif /* USE_SPI_CRC */ + + /* Configure : NSS management, TI Mode, NSS Pulse, Data size and Rx Fifo threshold */ + WRITE_REG(hspi->Instance->CR2, (((hspi->Init.NSS >> 16U) & SPI_CR2_SSOE) | + (hspi->Init.TIMode & SPI_CR2_FRF) | + (hspi->Init.NSSPMode & SPI_CR2_NSSP) | + (hspi->Init.DataSize & SPI_CR2_DS_Msk) | + (frxth & SPI_CR2_FRXTH))); + +#if (USE_SPI_CRC != 0U) + /*---------------------------- SPIx CRCPOLY Configuration ------------------*/ + /* Configure : CRC Polynomial */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + WRITE_REG(hspi->Instance->CRCPR, (hspi->Init.CRCPolynomial & SPI_CRCPR_CRCPOLY_Msk)); + } +#endif /* USE_SPI_CRC */ + +#if defined(SPI_I2SCFGR_I2SMOD) + /* Activate the SPI mode (Make sure that I2SMOD bit in I2SCFGR register is reset) */ + CLEAR_BIT(hspi->Instance->I2SCFGR, SPI_I2SCFGR_I2SMOD); +#endif /* SPI_I2SCFGR_I2SMOD */ + + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->State = HAL_SPI_STATE_READY; + + return HAL_OK; +} + +/** + * @brief De-Initialize the SPI peripheral. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_DeInit(SPI_HandleTypeDef *hspi) +{ + /* Check the SPI handle allocation */ + if (hspi == NULL) + { + return HAL_ERROR; + } + + /* Check SPI Instance parameter */ + assert_param(IS_SPI_ALL_INSTANCE(hspi->Instance)); + + hspi->State = HAL_SPI_STATE_BUSY; + + /* Disable the SPI Peripheral Clock */ + __HAL_SPI_DISABLE(hspi); + +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + if (hspi->MspDeInitCallback == NULL) + { + hspi->MspDeInitCallback = HAL_SPI_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware: GPIO, CLOCK, NVIC... */ + hspi->MspDeInitCallback(hspi); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC... */ + HAL_SPI_MspDeInit(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->State = HAL_SPI_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(hspi); + + return HAL_OK; +} + +/** + * @brief Initialize the SPI MSP. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_MspInit(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_MspInit should be implemented in the user file + */ +} + +/** + * @brief De-Initialize the SPI MSP. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_MspDeInit(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_MspDeInit should be implemented in the user file + */ +} + +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) +/** + * @brief Register a User SPI Callback + * To be used instead of the weak predefined callback + * @param hspi Pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for the specified SPI. + * @param CallbackID ID of the callback to be registered + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_RegisterCallback(SPI_HandleTypeDef *hspi, HAL_SPI_CallbackIDTypeDef CallbackID, + pSPI_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + hspi->ErrorCode |= HAL_SPI_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(hspi); + + if (HAL_SPI_STATE_READY == hspi->State) + { + switch (CallbackID) + { + case HAL_SPI_TX_COMPLETE_CB_ID : + hspi->TxCpltCallback = pCallback; + break; + + case HAL_SPI_RX_COMPLETE_CB_ID : + hspi->RxCpltCallback = pCallback; + break; + + case HAL_SPI_TX_RX_COMPLETE_CB_ID : + hspi->TxRxCpltCallback = pCallback; + break; + + case HAL_SPI_TX_HALF_COMPLETE_CB_ID : + hspi->TxHalfCpltCallback = pCallback; + break; + + case HAL_SPI_RX_HALF_COMPLETE_CB_ID : + hspi->RxHalfCpltCallback = pCallback; + break; + + case HAL_SPI_TX_RX_HALF_COMPLETE_CB_ID : + hspi->TxRxHalfCpltCallback = pCallback; + break; + + case HAL_SPI_ERROR_CB_ID : + hspi->ErrorCallback = pCallback; + break; + + case HAL_SPI_ABORT_CB_ID : + hspi->AbortCpltCallback = pCallback; + break; + + case HAL_SPI_MSPINIT_CB_ID : + hspi->MspInitCallback = pCallback; + break; + + case HAL_SPI_MSPDEINIT_CB_ID : + hspi->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_SPI_STATE_RESET == hspi->State) + { + switch (CallbackID) + { + case HAL_SPI_MSPINIT_CB_ID : + hspi->MspInitCallback = pCallback; + break; + + case HAL_SPI_MSPDEINIT_CB_ID : + hspi->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hspi); + return status; +} + +/** + * @brief Unregister an SPI Callback + * SPI callback is redirected to the weak predefined callback + * @param hspi Pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for the specified SPI. + * @param CallbackID ID of the callback to be unregistered + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_UnRegisterCallback(SPI_HandleTypeDef *hspi, HAL_SPI_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(hspi); + + if (HAL_SPI_STATE_READY == hspi->State) + { + switch (CallbackID) + { + case HAL_SPI_TX_COMPLETE_CB_ID : + hspi->TxCpltCallback = HAL_SPI_TxCpltCallback; /* Legacy weak TxCpltCallback */ + break; + + case HAL_SPI_RX_COMPLETE_CB_ID : + hspi->RxCpltCallback = HAL_SPI_RxCpltCallback; /* Legacy weak RxCpltCallback */ + break; + + case HAL_SPI_TX_RX_COMPLETE_CB_ID : + hspi->TxRxCpltCallback = HAL_SPI_TxRxCpltCallback; /* Legacy weak TxRxCpltCallback */ + break; + + case HAL_SPI_TX_HALF_COMPLETE_CB_ID : + hspi->TxHalfCpltCallback = HAL_SPI_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + break; + + case HAL_SPI_RX_HALF_COMPLETE_CB_ID : + hspi->RxHalfCpltCallback = HAL_SPI_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + break; + + case HAL_SPI_TX_RX_HALF_COMPLETE_CB_ID : + hspi->TxRxHalfCpltCallback = HAL_SPI_TxRxHalfCpltCallback; /* Legacy weak TxRxHalfCpltCallback */ + break; + + case HAL_SPI_ERROR_CB_ID : + hspi->ErrorCallback = HAL_SPI_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_SPI_ABORT_CB_ID : + hspi->AbortCpltCallback = HAL_SPI_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + break; + + case HAL_SPI_MSPINIT_CB_ID : + hspi->MspInitCallback = HAL_SPI_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_SPI_MSPDEINIT_CB_ID : + hspi->MspDeInitCallback = HAL_SPI_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_SPI_STATE_RESET == hspi->State) + { + switch (CallbackID) + { + case HAL_SPI_MSPINIT_CB_ID : + hspi->MspInitCallback = HAL_SPI_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_SPI_MSPDEINIT_CB_ID : + hspi->MspDeInitCallback = HAL_SPI_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_INVALID_CALLBACK); + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(hspi); + return status; +} +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup SPI_Exported_Functions_Group2 IO operation functions + * @brief Data transfers functions + * +@verbatim + ============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to manage the SPI + data transfers. + + [..] The SPI supports master and slave mode : + + (#) There are two modes of transfer: + (++) Blocking mode: The communication is performed in polling mode. + The HAL status of all data processing is returned by the same function + after finishing transfer. + (++) No-Blocking mode: The communication is performed using Interrupts + or DMA, These APIs return the HAL status. + The end of the data processing will be indicated through the + dedicated SPI IRQ when using Interrupt mode or the DMA IRQ when + using DMA mode. + The HAL_SPI_TxCpltCallback(), HAL_SPI_RxCpltCallback() and HAL_SPI_TxRxCpltCallback() user callbacks + will be executed respectively at the end of the transmit or Receive process + The HAL_SPI_ErrorCallback()user callback will be executed when a communication error is detected + + (#) APIs provided for these 2 transfer modes (Blocking mode or Non blocking mode using either Interrupt or DMA) + exist for 1Line (simplex) and 2Lines (full duplex) modes. + +@endverbatim + * @{ + */ + +/** + * @brief Transmit an amount of data in blocking mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pData pointer to data buffer + * @param Size amount of data to be sent + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Transmit(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint32_t tickstart; + HAL_StatusTypeDef errorcode = HAL_OK; + uint16_t initial_TxXferCount; + + /* Check Direction parameter */ + assert_param(IS_SPI_DIRECTION_2LINES_OR_1LINE(hspi->Init.Direction)); + + /* Process Locked */ + __HAL_LOCK(hspi); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + initial_TxXferCount = Size; + + if (hspi->State != HAL_SPI_STATE_READY) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Set the transaction information */ + hspi->State = HAL_SPI_STATE_BUSY_TX; + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pTxBuffPtr = (uint8_t *)pData; + hspi->TxXferSize = Size; + hspi->TxXferCount = Size; + + /*Init field not used in handle to zero */ + hspi->pRxBuffPtr = (uint8_t *)NULL; + hspi->RxXferSize = 0U; + hspi->RxXferCount = 0U; + hspi->TxISR = NULL; + hspi->RxISR = NULL; + + /* Configure communication direction : 1Line */ + if (hspi->Init.Direction == SPI_DIRECTION_1LINE) + { + /* Disable SPI Peripheral before set 1Line direction (BIDIOE bit) */ + __HAL_SPI_DISABLE(hspi); + SPI_1LINE_TX(hspi); + } + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } +#endif /* USE_SPI_CRC */ + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + + /* Transmit data in 16 Bit mode */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + if ((hspi->Init.Mode == SPI_MODE_SLAVE) || (initial_TxXferCount == 0x01U)) + { + hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint16_t); + hspi->TxXferCount--; + } + /* Transmit data in 16 Bit mode */ + while (hspi->TxXferCount > 0U) + { + /* Wait until TXE flag is set to send data */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE)) + { + hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint16_t); + hspi->TxXferCount--; + } + else + { + /* Timeout management */ + if ((((HAL_GetTick() - tickstart) >= Timeout) && (Timeout != HAL_MAX_DELAY)) || (Timeout == 0U)) + { + errorcode = HAL_TIMEOUT; + goto error; + } + } + } + } + /* Transmit data in 8 Bit mode */ + else + { + if ((hspi->Init.Mode == SPI_MODE_SLAVE) || (initial_TxXferCount == 0x01U)) + { + *((__IO uint8_t *)&hspi->Instance->DR) = (*hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint8_t); + hspi->TxXferCount--; + } + while (hspi->TxXferCount > 0U) + { + /* Wait until TXE flag is set to send data */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE)) + { + *((__IO uint8_t *)&hspi->Instance->DR) = (*hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint8_t); + hspi->TxXferCount--; + } + else + { + /* Timeout management */ + if ((((HAL_GetTick() - tickstart) >= Timeout) && (Timeout != HAL_MAX_DELAY)) || (Timeout == 0U)) + { + errorcode = HAL_TIMEOUT; + goto error; + } + } + } + } +#if (USE_SPI_CRC != 0U) + /* Enable CRC Transmission */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + } +#endif /* USE_SPI_CRC */ + + /* Check the end of the transaction */ + if (SPI_EndRxTxTransaction(hspi, Timeout, tickstart) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_FLAG; + } + + /* Clear overrun flag in 2 Lines communication mode because received is not read */ + if (hspi->Init.Direction == SPI_DIRECTION_2LINES) + { + __HAL_SPI_CLEAR_OVRFLAG(hspi); + } + + if (hspi->ErrorCode != HAL_SPI_ERROR_NONE) + { + errorcode = HAL_ERROR; + } + +error: + hspi->State = HAL_SPI_STATE_READY; + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Receive an amount of data in blocking mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pData pointer to data buffer + * @param Size amount of data to be received + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Receive(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ +#if (USE_SPI_CRC != 0U) + __IO uint32_t tmpreg = 0U; + __IO uint8_t * ptmpreg8; + __IO uint8_t tmpreg8 = 0; +#endif /* USE_SPI_CRC */ + uint32_t tickstart; + HAL_StatusTypeDef errorcode = HAL_OK; + + if ((hspi->Init.Mode == SPI_MODE_MASTER) && (hspi->Init.Direction == SPI_DIRECTION_2LINES)) + { + hspi->State = HAL_SPI_STATE_BUSY_RX; + /* Call transmit-receive function to send Dummy data on Tx line and generate clock on CLK line */ + return HAL_SPI_TransmitReceive(hspi, pData, pData, Size, Timeout); + } + + /* Process Locked */ + __HAL_LOCK(hspi); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + if (hspi->State != HAL_SPI_STATE_READY) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Set the transaction information */ + hspi->State = HAL_SPI_STATE_BUSY_RX; + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pRxBuffPtr = (uint8_t *)pData; + hspi->RxXferSize = Size; + hspi->RxXferCount = Size; + + /*Init field not used in handle to zero */ + hspi->pTxBuffPtr = (uint8_t *)NULL; + hspi->TxXferSize = 0U; + hspi->TxXferCount = 0U; + hspi->RxISR = NULL; + hspi->TxISR = NULL; + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + /* this is done to handle the CRCNEXT before the latest data */ + hspi->RxXferCount--; + } +#endif /* USE_SPI_CRC */ + + /* Set the Rx Fifo threshold */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + /* Set RX Fifo threshold according the reception data length: 16bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + else + { + /* Set RX Fifo threshold according the reception data length: 8bit */ + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + + /* Configure communication direction: 1Line */ + if (hspi->Init.Direction == SPI_DIRECTION_1LINE) + { + /* Disable SPI Peripheral before set 1Line direction (BIDIOE bit) */ + __HAL_SPI_DISABLE(hspi); + SPI_1LINE_RX(hspi); + } + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + + /* Receive data in 8 Bit mode */ + if (hspi->Init.DataSize <= SPI_DATASIZE_8BIT) + { + /* Transfer loop */ + while (hspi->RxXferCount > 0U) + { + /* Check the RXNE flag */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_RXNE)) + { + /* read the received data */ + (* (uint8_t *)hspi->pRxBuffPtr) = *(__IO uint8_t *)&hspi->Instance->DR; + hspi->pRxBuffPtr += sizeof(uint8_t); + hspi->RxXferCount--; + } + else + { + /* Timeout management */ + if ((((HAL_GetTick() - tickstart) >= Timeout) && (Timeout != HAL_MAX_DELAY)) || (Timeout == 0U)) + { + errorcode = HAL_TIMEOUT; + goto error; + } + } + } + } + else + { + /* Transfer loop */ + while (hspi->RxXferCount > 0U) + { + /* Check the RXNE flag */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_RXNE)) + { + *((uint16_t *)hspi->pRxBuffPtr) = (uint16_t)hspi->Instance->DR; + hspi->pRxBuffPtr += sizeof(uint16_t); + hspi->RxXferCount--; + } + else + { + /* Timeout management */ + if ((((HAL_GetTick() - tickstart) >= Timeout) && (Timeout != HAL_MAX_DELAY)) || (Timeout == 0U)) + { + errorcode = HAL_TIMEOUT; + goto error; + } + } + } + } + +#if (USE_SPI_CRC != 0U) + /* Handle the CRC Transmission */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* freeze the CRC before the latest data */ + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + + /* Read the latest data */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_RXNE, SET, Timeout, tickstart) != HAL_OK) + { + /* the latest data has not been received */ + errorcode = HAL_TIMEOUT; + goto error; + } + + /* Receive last data in 16 Bit mode */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + *((uint16_t *)hspi->pRxBuffPtr) = (uint16_t)hspi->Instance->DR; + } + /* Receive last data in 8 Bit mode */ + else + { + (*(uint8_t *)hspi->pRxBuffPtr) = *(__IO uint8_t *)&hspi->Instance->DR; + } + + /* Wait the CRC data */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_RXNE, SET, Timeout, tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + errorcode = HAL_TIMEOUT; + goto error; + } + + /* Read CRC to Flush DR and RXNE flag */ + if (hspi->Init.DataSize == SPI_DATASIZE_16BIT) + { + /* Read 16bit CRC */ + tmpreg = READ_REG(hspi->Instance->DR); + /* To avoid GCC warning */ + UNUSED(tmpreg); + } + else + { + /* Initialize the 8bit temporary pointer */ + ptmpreg8 = (__IO uint8_t *)&hspi->Instance->DR; + /* Read 8bit CRC */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + + if ((hspi->Init.DataSize == SPI_DATASIZE_8BIT) && (hspi->Init.CRCLength == SPI_CRC_LENGTH_16BIT)) + { + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_RXNE, SET, Timeout, tickstart) != HAL_OK) + { + /* Error on the CRC reception */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + errorcode = HAL_TIMEOUT; + goto error; + } + /* Read 8bit CRC again in case of 16bit CRC in 8bit Data mode */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + } + } + } +#endif /* USE_SPI_CRC */ + + /* Check the end of the transaction */ + if (SPI_EndRxTransaction(hspi, Timeout, tickstart) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_FLAG; + } + +#if (USE_SPI_CRC != 0U) + /* Check if CRC error occurred */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_CRCERR)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + __HAL_SPI_CLEAR_CRCERRFLAG(hspi); + } +#endif /* USE_SPI_CRC */ + + if (hspi->ErrorCode != HAL_SPI_ERROR_NONE) + { + errorcode = HAL_ERROR; + } + +error : + hspi->State = HAL_SPI_STATE_READY; + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Transmit and Receive an amount of data in blocking mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pTxData pointer to transmission data buffer + * @param pRxData pointer to reception data buffer + * @param Size amount of data to be sent and received + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_TransmitReceive(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size, + uint32_t Timeout) +{ + uint16_t initial_TxXferCount; + uint32_t tmp_mode; + HAL_SPI_StateTypeDef tmp_state; + uint32_t tickstart; +#if (USE_SPI_CRC != 0U) + __IO uint32_t tmpreg = 0U; + uint32_t spi_cr1; + uint32_t spi_cr2; + __IO uint8_t * ptmpreg8; + __IO uint8_t tmpreg8 = 0; +#endif /* USE_SPI_CRC */ + + /* Variable used to alternate Rx and Tx during transfer */ + uint32_t txallowed = 1U; + HAL_StatusTypeDef errorcode = HAL_OK; + + /* Check Direction parameter */ + assert_param(IS_SPI_DIRECTION_2LINES(hspi->Init.Direction)); + + /* Process Locked */ + __HAL_LOCK(hspi); + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + /* Init temporary variables */ + tmp_state = hspi->State; + tmp_mode = hspi->Init.Mode; + initial_TxXferCount = Size; +#if (USE_SPI_CRC != 0U) + spi_cr1 = READ_REG(hspi->Instance->CR1); + spi_cr2 = READ_REG(hspi->Instance->CR2); +#endif /* USE_SPI_CRC */ + + if (!((tmp_state == HAL_SPI_STATE_READY) || \ + ((tmp_mode == SPI_MODE_MASTER) && (hspi->Init.Direction == SPI_DIRECTION_2LINES) && (tmp_state == HAL_SPI_STATE_BUSY_RX)))) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pTxData == NULL) || (pRxData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Don't overwrite in case of HAL_SPI_STATE_BUSY_RX */ + if (hspi->State != HAL_SPI_STATE_BUSY_RX) + { + hspi->State = HAL_SPI_STATE_BUSY_TX_RX; + } + + /* Set the transaction information */ + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pRxBuffPtr = (uint8_t *)pRxData; + hspi->RxXferCount = Size; + hspi->RxXferSize = Size; + hspi->pTxBuffPtr = (uint8_t *)pTxData; + hspi->TxXferCount = Size; + hspi->TxXferSize = Size; + + /*Init field not used in handle to zero */ + hspi->RxISR = NULL; + hspi->TxISR = NULL; + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } +#endif /* USE_SPI_CRC */ + + /* Set the Rx Fifo threshold */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + /* Set fiforxthreshold according the reception data length: 16bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + else + { + /* Set fiforxthreshold according the reception data length: 8bit */ + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + + /* Transmit and Receive data in 16 Bit mode */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + if ((hspi->Init.Mode == SPI_MODE_SLAVE) || (initial_TxXferCount == 0x01U)) + { + hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint16_t); + hspi->TxXferCount--; + } + while ((hspi->TxXferCount > 0U) || (hspi->RxXferCount > 0U)) + { + /* Check TXE flag */ + if ((__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE)) && (hspi->TxXferCount > 0U) && (txallowed == 1U)) + { + hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint16_t); + hspi->TxXferCount--; + /* Next Data is a reception (Rx). Tx not allowed */ + txallowed = 0U; + +#if (USE_SPI_CRC != 0U) + /* Enable CRC Transmission */ + if ((hspi->TxXferCount == 0U) && (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE)) + { + /* Set NSS Soft to received correctly the CRC on slave mode with NSS pulse activated */ + if ((READ_BIT(spi_cr1, SPI_CR1_MSTR) == 0U) && (READ_BIT(spi_cr2, SPI_CR2_NSSP) == SPI_CR2_NSSP)) + { + SET_BIT(hspi->Instance->CR1, SPI_CR1_SSM); + } + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + } +#endif /* USE_SPI_CRC */ + } + + /* Check RXNE flag */ + if ((__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_RXNE)) && (hspi->RxXferCount > 0U)) + { + *((uint16_t *)hspi->pRxBuffPtr) = (uint16_t)hspi->Instance->DR; + hspi->pRxBuffPtr += sizeof(uint16_t); + hspi->RxXferCount--; + /* Next Data is a Transmission (Tx). Tx is allowed */ + txallowed = 1U; + } + if (((HAL_GetTick() - tickstart) >= Timeout) && (Timeout != HAL_MAX_DELAY)) + { + errorcode = HAL_TIMEOUT; + goto error; + } + } + } + /* Transmit and Receive data in 8 Bit mode */ + else + { + if ((hspi->Init.Mode == SPI_MODE_SLAVE) || (initial_TxXferCount == 0x01U)) + { + *((__IO uint8_t *)&hspi->Instance->DR) = (*hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint8_t); + hspi->TxXferCount--; + } + while ((hspi->TxXferCount > 0U) || (hspi->RxXferCount > 0U)) + { + /* Check TXE flag */ + if ((__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE)) && (hspi->TxXferCount > 0U) && (txallowed == 1U)) + { + *(__IO uint8_t *)&hspi->Instance->DR = (*hspi->pTxBuffPtr); + hspi->pTxBuffPtr++; + hspi->TxXferCount--; + /* Next Data is a reception (Rx). Tx not allowed */ + txallowed = 0U; + +#if (USE_SPI_CRC != 0U) + /* Enable CRC Transmission */ + if ((hspi->TxXferCount == 0U) && (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE)) + { + /* Set NSS Soft to received correctly the CRC on slave mode with NSS pulse activated */ + if ((READ_BIT(spi_cr1, SPI_CR1_MSTR) == 0U) && (READ_BIT(spi_cr2, SPI_CR2_NSSP) == SPI_CR2_NSSP)) + { + SET_BIT(hspi->Instance->CR1, SPI_CR1_SSM); + } + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + } +#endif /* USE_SPI_CRC */ + } + + /* Wait until RXNE flag is reset */ + if ((__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_RXNE)) && (hspi->RxXferCount > 0U)) + { + (*(uint8_t *)hspi->pRxBuffPtr) = *(__IO uint8_t *)&hspi->Instance->DR; + hspi->pRxBuffPtr++; + hspi->RxXferCount--; + /* Next Data is a Transmission (Tx). Tx is allowed */ + txallowed = 1U; + } + if ((((HAL_GetTick() - tickstart) >= Timeout) && ((Timeout != HAL_MAX_DELAY))) || (Timeout == 0U)) + { + errorcode = HAL_TIMEOUT; + goto error; + } + } + } + +#if (USE_SPI_CRC != 0U) + /* Read CRC from DR to close CRC calculation process */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* Wait until TXE flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_RXNE, SET, Timeout, tickstart) != HAL_OK) + { + /* Error on the CRC reception */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + errorcode = HAL_TIMEOUT; + goto error; + } + /* Read CRC */ + if (hspi->Init.DataSize == SPI_DATASIZE_16BIT) + { + /* Read 16bit CRC */ + tmpreg = READ_REG(hspi->Instance->DR); + /* To avoid GCC warning */ + UNUSED(tmpreg); + } + else + { + /* Initialize the 8bit temporary pointer */ + ptmpreg8 = (__IO uint8_t *)&hspi->Instance->DR; + /* Read 8bit CRC */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + + if (hspi->Init.CRCLength == SPI_CRC_LENGTH_16BIT) + { + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_RXNE, SET, Timeout, tickstart) != HAL_OK) + { + /* Error on the CRC reception */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + errorcode = HAL_TIMEOUT; + goto error; + } + /* Read 8bit CRC again in case of 16bit CRC in 8bit Data mode */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + } + } + } + + /* Check if CRC error occurred */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_CRCERR)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + /* Clear CRC Flag */ + __HAL_SPI_CLEAR_CRCERRFLAG(hspi); + + errorcode = HAL_ERROR; + } +#endif /* USE_SPI_CRC */ + + /* Check the end of the transaction */ + if (SPI_EndRxTxTransaction(hspi, Timeout, tickstart) != HAL_OK) + { + errorcode = HAL_ERROR; + hspi->ErrorCode = HAL_SPI_ERROR_FLAG; + } + +error : + hspi->State = HAL_SPI_STATE_READY; + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Transmit an amount of data in non-blocking mode with Interrupt. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pData pointer to data buffer + * @param Size amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Transmit_IT(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef errorcode = HAL_OK; + + /* Check Direction parameter */ + assert_param(IS_SPI_DIRECTION_2LINES_OR_1LINE(hspi->Init.Direction)); + + /* Process Locked */ + __HAL_LOCK(hspi); + + if ((pData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + if (hspi->State != HAL_SPI_STATE_READY) + { + errorcode = HAL_BUSY; + goto error; + } + + /* Set the transaction information */ + hspi->State = HAL_SPI_STATE_BUSY_TX; + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pTxBuffPtr = (uint8_t *)pData; + hspi->TxXferSize = Size; + hspi->TxXferCount = Size; + + /* Init field not used in handle to zero */ + hspi->pRxBuffPtr = (uint8_t *)NULL; + hspi->RxXferSize = 0U; + hspi->RxXferCount = 0U; + hspi->RxISR = NULL; + + /* Set the function for IT treatment */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + hspi->TxISR = SPI_TxISR_16BIT; + } + else + { + hspi->TxISR = SPI_TxISR_8BIT; + } + + /* Configure communication direction : 1Line */ + if (hspi->Init.Direction == SPI_DIRECTION_1LINE) + { + /* Disable SPI Peripheral before set 1Line direction (BIDIOE bit) */ + __HAL_SPI_DISABLE(hspi); + SPI_1LINE_TX(hspi); + } + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } +#endif /* USE_SPI_CRC */ + + /* Enable TXE and ERR interrupt */ + __HAL_SPI_ENABLE_IT(hspi, (SPI_IT_TXE | SPI_IT_ERR)); + + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + +error : + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Receive an amount of data in non-blocking mode with Interrupt. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pData pointer to data buffer + * @param Size amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Receive_IT(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef errorcode = HAL_OK; + + if ((hspi->Init.Direction == SPI_DIRECTION_2LINES) && (hspi->Init.Mode == SPI_MODE_MASTER)) + { + hspi->State = HAL_SPI_STATE_BUSY_RX; + /* Call transmit-receive function to send Dummy data on Tx line and generate clock on CLK line */ + return HAL_SPI_TransmitReceive_IT(hspi, pData, pData, Size); + } + + /* Process Locked */ + __HAL_LOCK(hspi); + + if (hspi->State != HAL_SPI_STATE_READY) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Set the transaction information */ + hspi->State = HAL_SPI_STATE_BUSY_RX; + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pRxBuffPtr = (uint8_t *)pData; + hspi->RxXferSize = Size; + hspi->RxXferCount = Size; + + /* Init field not used in handle to zero */ + hspi->pTxBuffPtr = (uint8_t *)NULL; + hspi->TxXferSize = 0U; + hspi->TxXferCount = 0U; + hspi->TxISR = NULL; + + /* Check the data size to adapt Rx threshold and the set the function for IT treatment */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + /* Set RX Fifo threshold according the reception data length: 16 bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + hspi->RxISR = SPI_RxISR_16BIT; + } + else + { + /* Set RX Fifo threshold according the reception data length: 8 bit */ + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + hspi->RxISR = SPI_RxISR_8BIT; + } + + /* Configure communication direction : 1Line */ + if (hspi->Init.Direction == SPI_DIRECTION_1LINE) + { + /* Disable SPI Peripheral before set 1Line direction (BIDIOE bit) */ + __HAL_SPI_DISABLE(hspi); + SPI_1LINE_RX(hspi); + } + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + hspi->CRCSize = 1U; + if ((hspi->Init.DataSize <= SPI_DATASIZE_8BIT) && (hspi->Init.CRCLength == SPI_CRC_LENGTH_16BIT)) + { + hspi->CRCSize = 2U; + } + SPI_RESET_CRC(hspi); + } + else + { + hspi->CRCSize = 0U; + } +#endif /* USE_SPI_CRC */ + + /* Enable TXE and ERR interrupt */ + __HAL_SPI_ENABLE_IT(hspi, (SPI_IT_RXNE | SPI_IT_ERR)); + + /* Note : The SPI must be enabled after unlocking current process + to avoid the risk of SPI interrupt handle execution before current + process unlock */ + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + +error : + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Transmit and Receive an amount of data in non-blocking mode with Interrupt. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pTxData pointer to transmission data buffer + * @param pRxData pointer to reception data buffer + * @param Size amount of data to be sent and received + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_TransmitReceive_IT(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, uint16_t Size) +{ + uint32_t tmp_mode; + HAL_SPI_StateTypeDef tmp_state; + HAL_StatusTypeDef errorcode = HAL_OK; + + /* Check Direction parameter */ + assert_param(IS_SPI_DIRECTION_2LINES(hspi->Init.Direction)); + + /* Process locked */ + __HAL_LOCK(hspi); + + /* Init temporary variables */ + tmp_state = hspi->State; + tmp_mode = hspi->Init.Mode; + + if (!((tmp_state == HAL_SPI_STATE_READY) || \ + ((tmp_mode == SPI_MODE_MASTER) && (hspi->Init.Direction == SPI_DIRECTION_2LINES) && (tmp_state == HAL_SPI_STATE_BUSY_RX)))) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pTxData == NULL) || (pRxData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Don't overwrite in case of HAL_SPI_STATE_BUSY_RX */ + if (hspi->State != HAL_SPI_STATE_BUSY_RX) + { + hspi->State = HAL_SPI_STATE_BUSY_TX_RX; + } + + /* Set the transaction information */ + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pTxBuffPtr = (uint8_t *)pTxData; + hspi->TxXferSize = Size; + hspi->TxXferCount = Size; + hspi->pRxBuffPtr = (uint8_t *)pRxData; + hspi->RxXferSize = Size; + hspi->RxXferCount = Size; + + /* Set the function for IT treatment */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + hspi->RxISR = SPI_2linesRxISR_16BIT; + hspi->TxISR = SPI_2linesTxISR_16BIT; + } + else + { + hspi->RxISR = SPI_2linesRxISR_8BIT; + hspi->TxISR = SPI_2linesTxISR_8BIT; + } + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + hspi->CRCSize = 1U; + if ((hspi->Init.DataSize <= SPI_DATASIZE_8BIT) && (hspi->Init.CRCLength == SPI_CRC_LENGTH_16BIT)) + { + hspi->CRCSize = 2U; + } + SPI_RESET_CRC(hspi); + } + else + { + hspi->CRCSize = 0U; + } +#endif /* USE_SPI_CRC */ + + /* Check if packing mode is enabled and if there is more than 2 data to receive */ + if ((hspi->Init.DataSize > SPI_DATASIZE_8BIT) || (Size >= 2U)) + { + /* Set RX Fifo threshold according the reception data length: 16 bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + else + { + /* Set RX Fifo threshold according the reception data length: 8 bit */ + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + + /* Enable TXE, RXNE and ERR interrupt */ + __HAL_SPI_ENABLE_IT(hspi, (SPI_IT_TXE | SPI_IT_RXNE | SPI_IT_ERR)); + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + +error : + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Transmit an amount of data in non-blocking mode with DMA. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pData pointer to data buffer + * @param Size amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Transmit_DMA(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef errorcode = HAL_OK; + + /* Check tx dma handle */ + assert_param(IS_SPI_DMA_HANDLE(hspi->hdmatx)); + + /* Check Direction parameter */ + assert_param(IS_SPI_DIRECTION_2LINES_OR_1LINE(hspi->Init.Direction)); + + /* Process Locked */ + __HAL_LOCK(hspi); + + if (hspi->State != HAL_SPI_STATE_READY) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Set the transaction information */ + hspi->State = HAL_SPI_STATE_BUSY_TX; + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pTxBuffPtr = (uint8_t *)pData; + hspi->TxXferSize = Size; + hspi->TxXferCount = Size; + + /* Init field not used in handle to zero */ + hspi->pRxBuffPtr = (uint8_t *)NULL; + hspi->TxISR = NULL; + hspi->RxISR = NULL; + hspi->RxXferSize = 0U; + hspi->RxXferCount = 0U; + + /* Configure communication direction : 1Line */ + if (hspi->Init.Direction == SPI_DIRECTION_1LINE) + { + /* Disable SPI Peripheral before set 1Line direction (BIDIOE bit) */ + __HAL_SPI_DISABLE(hspi); + SPI_1LINE_TX(hspi); + } + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } +#endif /* USE_SPI_CRC */ + + /* Set the SPI TxDMA Half transfer complete callback */ + hspi->hdmatx->XferHalfCpltCallback = SPI_DMAHalfTransmitCplt; + + /* Set the SPI TxDMA transfer complete callback */ + hspi->hdmatx->XferCpltCallback = SPI_DMATransmitCplt; + + /* Set the DMA error callback */ + hspi->hdmatx->XferErrorCallback = SPI_DMAError; + + /* Set the DMA AbortCpltCallback */ + hspi->hdmatx->XferAbortCallback = NULL; + + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_LDMATX); + /* Packing mode is enabled only if the DMA setting is HALWORD */ + if ((hspi->Init.DataSize <= SPI_DATASIZE_8BIT) && (hspi->hdmatx->Init.MemDataAlignment == DMA_MDATAALIGN_HALFWORD)) + { + /* Check the even/odd of the data size + crc if enabled */ + if ((hspi->TxXferCount & 0x1U) == 0U) + { + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_LDMATX); + hspi->TxXferCount = (hspi->TxXferCount >> 1U); + } + else + { + SET_BIT(hspi->Instance->CR2, SPI_CR2_LDMATX); + hspi->TxXferCount = (hspi->TxXferCount >> 1U) + 1U; + } + } + + /* Enable the Tx DMA Stream/Channel */ + if (HAL_OK != HAL_DMA_Start_IT(hspi->hdmatx, (uint32_t)hspi->pTxBuffPtr, (uint32_t)&hspi->Instance->DR, + hspi->TxXferCount)) + { + /* Update SPI error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_DMA); + errorcode = HAL_ERROR; + + hspi->State = HAL_SPI_STATE_READY; + goto error; + } + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + + /* Enable the SPI Error Interrupt Bit */ + __HAL_SPI_ENABLE_IT(hspi, (SPI_IT_ERR)); + + /* Enable Tx DMA Request */ + SET_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN); + +error : + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Receive an amount of data in non-blocking mode with DMA. + * @note In case of MASTER mode and SPI_DIRECTION_2LINES direction, hdmatx shall be defined. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pData pointer to data buffer + * @note When the CRC feature is enabled the pData Length must be Size + 1. + * @param Size amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Receive_DMA(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef errorcode = HAL_OK; + + /* Check rx dma handle */ + assert_param(IS_SPI_DMA_HANDLE(hspi->hdmarx)); + + if ((hspi->Init.Direction == SPI_DIRECTION_2LINES) && (hspi->Init.Mode == SPI_MODE_MASTER)) + { + hspi->State = HAL_SPI_STATE_BUSY_RX; + + /* Check tx dma handle */ + assert_param(IS_SPI_DMA_HANDLE(hspi->hdmatx)); + + /* Call transmit-receive function to send Dummy data on Tx line and generate clock on CLK line */ + return HAL_SPI_TransmitReceive_DMA(hspi, pData, pData, Size); + } + + /* Process Locked */ + __HAL_LOCK(hspi); + + if (hspi->State != HAL_SPI_STATE_READY) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Set the transaction information */ + hspi->State = HAL_SPI_STATE_BUSY_RX; + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pRxBuffPtr = (uint8_t *)pData; + hspi->RxXferSize = Size; + hspi->RxXferCount = Size; + + /*Init field not used in handle to zero */ + hspi->RxISR = NULL; + hspi->TxISR = NULL; + hspi->TxXferSize = 0U; + hspi->TxXferCount = 0U; + + /* Configure communication direction : 1Line */ + if (hspi->Init.Direction == SPI_DIRECTION_1LINE) + { + /* Disable SPI Peripheral before set 1Line direction (BIDIOE bit) */ + __HAL_SPI_DISABLE(hspi); + SPI_1LINE_RX(hspi); + } + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } +#endif /* USE_SPI_CRC */ + +#if defined (STM32F030x6) || defined (STM32F030x8) || defined (STM32F031x6)|| defined (STM32F038xx) || defined (STM32F051x8) || defined (STM32F058xx) + /* Packing mode management is enabled by the DMA settings */ + if ((hspi->Init.DataSize <= SPI_DATASIZE_8BIT) && (hspi->hdmarx->Init.MemDataAlignment == DMA_MDATAALIGN_HALFWORD)) + { + /* Restriction the DMA data received is not allowed in this mode */ + errorcode = HAL_ERROR; + goto error; + } +#endif /* STM32F030x6 || STM32F030x8 || STM32F031x6 || STM32F038xx || STM32F051x8 || STM32F058xx */ + + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_LDMARX); + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + /* Set RX Fifo threshold according the reception data length: 16bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + else + { + /* Set RX Fifo threshold according the reception data length: 8bit */ + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + + if (hspi->hdmarx->Init.MemDataAlignment == DMA_MDATAALIGN_HALFWORD) + { + /* Set RX Fifo threshold according the reception data length: 16bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + + if ((hspi->RxXferCount & 0x1U) == 0x0U) + { + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_LDMARX); + hspi->RxXferCount = hspi->RxXferCount >> 1U; + } + else + { + SET_BIT(hspi->Instance->CR2, SPI_CR2_LDMARX); + hspi->RxXferCount = (hspi->RxXferCount >> 1U) + 1U; + } + } + } + + /* Set the SPI RxDMA Half transfer complete callback */ + hspi->hdmarx->XferHalfCpltCallback = SPI_DMAHalfReceiveCplt; + + /* Set the SPI Rx DMA transfer complete callback */ + hspi->hdmarx->XferCpltCallback = SPI_DMAReceiveCplt; + + /* Set the DMA error callback */ + hspi->hdmarx->XferErrorCallback = SPI_DMAError; + + /* Set the DMA AbortCpltCallback */ + hspi->hdmarx->XferAbortCallback = NULL; + + /* Enable the Rx DMA Stream/Channel */ + if (HAL_OK != HAL_DMA_Start_IT(hspi->hdmarx, (uint32_t)&hspi->Instance->DR, (uint32_t)hspi->pRxBuffPtr, + hspi->RxXferCount)) + { + /* Update SPI error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_DMA); + errorcode = HAL_ERROR; + + hspi->State = HAL_SPI_STATE_READY; + goto error; + } + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + + /* Enable the SPI Error Interrupt Bit */ + __HAL_SPI_ENABLE_IT(hspi, (SPI_IT_ERR)); + + /* Enable Rx DMA Request */ + SET_BIT(hspi->Instance->CR2, SPI_CR2_RXDMAEN); + +error: + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Transmit and Receive an amount of data in non-blocking mode with DMA. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param pTxData pointer to transmission data buffer + * @param pRxData pointer to reception data buffer + * @note When the CRC feature is enabled the pRxData Length must be Size + 1 + * @param Size amount of data to be sent + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_TransmitReceive_DMA(SPI_HandleTypeDef *hspi, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size) +{ + uint32_t tmp_mode; + HAL_SPI_StateTypeDef tmp_state; + HAL_StatusTypeDef errorcode = HAL_OK; + + /* Check rx & tx dma handles */ + assert_param(IS_SPI_DMA_HANDLE(hspi->hdmarx)); + assert_param(IS_SPI_DMA_HANDLE(hspi->hdmatx)); + + /* Check Direction parameter */ + assert_param(IS_SPI_DIRECTION_2LINES(hspi->Init.Direction)); + + /* Process locked */ + __HAL_LOCK(hspi); + + /* Init temporary variables */ + tmp_state = hspi->State; + tmp_mode = hspi->Init.Mode; + + if (!((tmp_state == HAL_SPI_STATE_READY) || + ((tmp_mode == SPI_MODE_MASTER) && (hspi->Init.Direction == SPI_DIRECTION_2LINES) && (tmp_state == HAL_SPI_STATE_BUSY_RX)))) + { + errorcode = HAL_BUSY; + goto error; + } + + if ((pTxData == NULL) || (pRxData == NULL) || (Size == 0U)) + { + errorcode = HAL_ERROR; + goto error; + } + + /* Don't overwrite in case of HAL_SPI_STATE_BUSY_RX */ + if (hspi->State != HAL_SPI_STATE_BUSY_RX) + { + hspi->State = HAL_SPI_STATE_BUSY_TX_RX; + } + + /* Set the transaction information */ + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + hspi->pTxBuffPtr = (uint8_t *)pTxData; + hspi->TxXferSize = Size; + hspi->TxXferCount = Size; + hspi->pRxBuffPtr = (uint8_t *)pRxData; + hspi->RxXferSize = Size; + hspi->RxXferCount = Size; + + /* Init field not used in handle to zero */ + hspi->RxISR = NULL; + hspi->TxISR = NULL; + +#if (USE_SPI_CRC != 0U) + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } +#endif /* USE_SPI_CRC */ + +#if defined (STM32F030x6) || defined (STM32F030x8) || defined (STM32F031x6) || defined (STM32F038xx) || defined (STM32F051x8) || defined (STM32F058xx) + /* Packing mode management is enabled by the DMA settings */ + if ((hspi->Init.DataSize <= SPI_DATASIZE_8BIT) && (hspi->hdmarx->Init.MemDataAlignment == DMA_MDATAALIGN_HALFWORD)) + { + /* Restriction the DMA data received is not allowed in this mode */ + errorcode = HAL_ERROR; + goto error; + } +#endif /* STM32F030x6 || STM32F030x8 || STM32F031x6 || STM32F038xx || STM32F051x8 || STM32F058xx */ + + /* Reset the threshold bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_LDMATX | SPI_CR2_LDMARX); + + /* The packing mode management is enabled by the DMA settings according the spi data size */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + /* Set fiforxthreshold according the reception data length: 16bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + else + { + /* Set RX Fifo threshold according the reception data length: 8bit */ + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + + if (hspi->hdmatx->Init.MemDataAlignment == DMA_MDATAALIGN_HALFWORD) + { + if ((hspi->TxXferSize & 0x1U) == 0x0U) + { + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_LDMATX); + hspi->TxXferCount = hspi->TxXferCount >> 1U; + } + else + { + SET_BIT(hspi->Instance->CR2, SPI_CR2_LDMATX); + hspi->TxXferCount = (hspi->TxXferCount >> 1U) + 1U; + } + } + + if (hspi->hdmarx->Init.MemDataAlignment == DMA_MDATAALIGN_HALFWORD) + { + /* Set RX Fifo threshold according the reception data length: 16bit */ + CLEAR_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + + if ((hspi->RxXferCount & 0x1U) == 0x0U) + { + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_LDMARX); + hspi->RxXferCount = hspi->RxXferCount >> 1U; + } + else + { + SET_BIT(hspi->Instance->CR2, SPI_CR2_LDMARX); + hspi->RxXferCount = (hspi->RxXferCount >> 1U) + 1U; + } + } + } + + /* Check if we are in Rx only or in Rx/Tx Mode and configure the DMA transfer complete callback */ + if (hspi->State == HAL_SPI_STATE_BUSY_RX) + { + /* Set the SPI Rx DMA Half transfer complete callback */ + hspi->hdmarx->XferHalfCpltCallback = SPI_DMAHalfReceiveCplt; + hspi->hdmarx->XferCpltCallback = SPI_DMAReceiveCplt; + } + else + { + /* Set the SPI Tx/Rx DMA Half transfer complete callback */ + hspi->hdmarx->XferHalfCpltCallback = SPI_DMAHalfTransmitReceiveCplt; + hspi->hdmarx->XferCpltCallback = SPI_DMATransmitReceiveCplt; + } + + /* Set the DMA error callback */ + hspi->hdmarx->XferErrorCallback = SPI_DMAError; + + /* Set the DMA AbortCpltCallback */ + hspi->hdmarx->XferAbortCallback = NULL; + + /* Enable the Rx DMA Stream/Channel */ + if (HAL_OK != HAL_DMA_Start_IT(hspi->hdmarx, (uint32_t)&hspi->Instance->DR, (uint32_t)hspi->pRxBuffPtr, + hspi->RxXferCount)) + { + /* Update SPI error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_DMA); + errorcode = HAL_ERROR; + + hspi->State = HAL_SPI_STATE_READY; + goto error; + } + + /* Enable Rx DMA Request */ + SET_BIT(hspi->Instance->CR2, SPI_CR2_RXDMAEN); + + /* Set the SPI Tx DMA transfer complete callback as NULL because the communication closing + is performed in DMA reception complete callback */ + hspi->hdmatx->XferHalfCpltCallback = NULL; + hspi->hdmatx->XferCpltCallback = NULL; + hspi->hdmatx->XferErrorCallback = NULL; + hspi->hdmatx->XferAbortCallback = NULL; + + /* Enable the Tx DMA Stream/Channel */ + if (HAL_OK != HAL_DMA_Start_IT(hspi->hdmatx, (uint32_t)hspi->pTxBuffPtr, (uint32_t)&hspi->Instance->DR, + hspi->TxXferCount)) + { + /* Update SPI error code */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_DMA); + errorcode = HAL_ERROR; + + hspi->State = HAL_SPI_STATE_READY; + goto error; + } + + /* Check if the SPI is already enabled */ + if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE) + { + /* Enable SPI peripheral */ + __HAL_SPI_ENABLE(hspi); + } + /* Enable the SPI Error Interrupt Bit */ + __HAL_SPI_ENABLE_IT(hspi, (SPI_IT_ERR)); + + /* Enable Tx DMA Request */ + SET_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN); + +error : + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + return errorcode; +} + +/** + * @brief Abort ongoing transfer (blocking mode). + * @param hspi SPI handle. + * @note This procedure could be used for aborting any ongoing transfer (Tx and Rx), + * started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SPI Interrupts (depending of transfer direction) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Abort(SPI_HandleTypeDef *hspi) +{ + HAL_StatusTypeDef errorcode; + __IO uint32_t count; + __IO uint32_t resetcount; + + /* Initialized local variable */ + errorcode = HAL_OK; + resetcount = SPI_DEFAULT_TIMEOUT * (SystemCoreClock / 24U / 1000U); + count = resetcount; + + /* Clear ERRIE interrupt to avoid error interrupts generation during Abort procedure */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_ERRIE); + + /* Disable TXEIE, RXNEIE and ERRIE(mode fault event, overrun error, TI frame error) interrupts */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_TXEIE)) + { + hspi->TxISR = SPI_AbortTx_ISR; + /* Wait HAL_SPI_STATE_ABORT state */ + do + { + if (count == 0U) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + break; + } + count--; + } while (hspi->State != HAL_SPI_STATE_ABORT); + /* Reset Timeout Counter */ + count = resetcount; + } + + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXNEIE)) + { + hspi->RxISR = SPI_AbortRx_ISR; + /* Wait HAL_SPI_STATE_ABORT state */ + do + { + if (count == 0U) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + break; + } + count--; + } while (hspi->State != HAL_SPI_STATE_ABORT); + /* Reset Timeout Counter */ + count = resetcount; + } + + /* Disable the SPI DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_TXDMAEN)) + { + /* Abort the SPI DMA Tx Stream/Channel : use blocking DMA Abort API (no callback) */ + if (hspi->hdmatx != NULL) + { + /* Set the SPI DMA Abort callback : + will lead to call HAL_SPI_AbortCpltCallback() at end of DMA abort procedure */ + hspi->hdmatx->XferAbortCallback = NULL; + + /* Abort DMA Tx Handle linked to SPI Peripheral */ + if (HAL_DMA_Abort(hspi->hdmatx) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Disable Tx DMA Request */ + CLEAR_BIT(hspi->Instance->CR2, (SPI_CR2_TXDMAEN)); + + if (SPI_EndRxTxTransaction(hspi, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Disable SPI Peripheral */ + __HAL_SPI_DISABLE(hspi); + + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + } + } + + /* Disable the SPI DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXDMAEN)) + { + /* Abort the SPI DMA Rx Stream/Channel : use blocking DMA Abort API (no callback) */ + if (hspi->hdmarx != NULL) + { + /* Set the SPI DMA Abort callback : + will lead to call HAL_SPI_AbortCpltCallback() at end of DMA abort procedure */ + hspi->hdmarx->XferAbortCallback = NULL; + + /* Abort DMA Rx Handle linked to SPI Peripheral */ + if (HAL_DMA_Abort(hspi->hdmarx) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Disable peripheral */ + __HAL_SPI_DISABLE(hspi); + + /* Control the BSY flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_BSY, RESET, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Disable Rx DMA Request */ + CLEAR_BIT(hspi->Instance->CR2, (SPI_CR2_RXDMAEN)); + } + } + /* Reset Tx and Rx transfer counters */ + hspi->RxXferCount = 0U; + hspi->TxXferCount = 0U; + + /* Check error during Abort procedure */ + if (hspi->ErrorCode == HAL_SPI_ERROR_ABORT) + { + /* return HAL_Error in case of error during Abort procedure */ + errorcode = HAL_ERROR; + } + else + { + /* Reset errorCode */ + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + } + + /* Clear the Error flags in the SR register */ + __HAL_SPI_CLEAR_OVRFLAG(hspi); + __HAL_SPI_CLEAR_FREFLAG(hspi); + + /* Restore hspi->state to ready */ + hspi->State = HAL_SPI_STATE_READY; + + return errorcode; +} + +/** + * @brief Abort ongoing transfer (Interrupt mode). + * @param hspi SPI handle. + * @note This procedure could be used for aborting any ongoing transfer (Tx and Rx), + * started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable SPI Interrupts (depending of transfer direction) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_Abort_IT(SPI_HandleTypeDef *hspi) +{ + HAL_StatusTypeDef errorcode; + uint32_t abortcplt ; + __IO uint32_t count; + __IO uint32_t resetcount; + + /* Initialized local variable */ + errorcode = HAL_OK; + abortcplt = 1U; + resetcount = SPI_DEFAULT_TIMEOUT * (SystemCoreClock / 24U / 1000U); + count = resetcount; + + /* Clear ERRIE interrupt to avoid error interrupts generation during Abort procedure */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_ERRIE); + + /* Change Rx and Tx Irq Handler to Disable TXEIE, RXNEIE and ERRIE interrupts */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_TXEIE)) + { + hspi->TxISR = SPI_AbortTx_ISR; + /* Wait HAL_SPI_STATE_ABORT state */ + do + { + if (count == 0U) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + break; + } + count--; + } while (hspi->State != HAL_SPI_STATE_ABORT); + /* Reset Timeout Counter */ + count = resetcount; + } + + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXNEIE)) + { + hspi->RxISR = SPI_AbortRx_ISR; + /* Wait HAL_SPI_STATE_ABORT state */ + do + { + if (count == 0U) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + break; + } + count--; + } while (hspi->State != HAL_SPI_STATE_ABORT); + /* Reset Timeout Counter */ + count = resetcount; + } + + /* If DMA Tx and/or DMA Rx Handles are associated to SPI Handle, DMA Abort complete callbacks should be initialised + before any call to DMA Abort functions */ + /* DMA Tx Handle is valid */ + if (hspi->hdmatx != NULL) + { + /* Set DMA Abort Complete callback if UART DMA Tx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_TXDMAEN)) + { + hspi->hdmatx->XferAbortCallback = SPI_DMATxAbortCallback; + } + else + { + hspi->hdmatx->XferAbortCallback = NULL; + } + } + /* DMA Rx Handle is valid */ + if (hspi->hdmarx != NULL) + { + /* Set DMA Abort Complete callback if UART DMA Rx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXDMAEN)) + { + hspi->hdmarx->XferAbortCallback = SPI_DMARxAbortCallback; + } + else + { + hspi->hdmarx->XferAbortCallback = NULL; + } + } + + /* Disable the SPI DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_TXDMAEN)) + { + /* Abort the SPI DMA Tx Stream/Channel */ + if (hspi->hdmatx != NULL) + { + /* Abort DMA Tx Handle linked to SPI Peripheral */ + if (HAL_DMA_Abort_IT(hspi->hdmatx) != HAL_OK) + { + hspi->hdmatx->XferAbortCallback = NULL; + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + else + { + abortcplt = 0U; + } + } + } + /* Disable the SPI DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXDMAEN)) + { + /* Abort the SPI DMA Rx Stream/Channel */ + if (hspi->hdmarx != NULL) + { + /* Abort DMA Rx Handle linked to SPI Peripheral */ + if (HAL_DMA_Abort_IT(hspi->hdmarx) != HAL_OK) + { + hspi->hdmarx->XferAbortCallback = NULL; + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + else + { + abortcplt = 0U; + } + } + } + + if (abortcplt == 1U) + { + /* Reset Tx and Rx transfer counters */ + hspi->RxXferCount = 0U; + hspi->TxXferCount = 0U; + + /* Check error during Abort procedure */ + if (hspi->ErrorCode == HAL_SPI_ERROR_ABORT) + { + /* return HAL_Error in case of error during Abort procedure */ + errorcode = HAL_ERROR; + } + else + { + /* Reset errorCode */ + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + } + + /* Clear the Error flags in the SR register */ + __HAL_SPI_CLEAR_OVRFLAG(hspi); + __HAL_SPI_CLEAR_FREFLAG(hspi); + + /* Restore hspi->State to Ready */ + hspi->State = HAL_SPI_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->AbortCpltCallback(hspi); +#else + HAL_SPI_AbortCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + + return errorcode; +} + +/** + * @brief Pause the DMA Transfer. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for the specified SPI module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_DMAPause(SPI_HandleTypeDef *hspi) +{ + /* Process Locked */ + __HAL_LOCK(hspi); + + /* Disable the SPI DMA Tx & Rx requests */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN | SPI_CR2_RXDMAEN); + + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + + return HAL_OK; +} + +/** + * @brief Resume the DMA Transfer. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for the specified SPI module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_DMAResume(SPI_HandleTypeDef *hspi) +{ + /* Process Locked */ + __HAL_LOCK(hspi); + + /* Enable the SPI DMA Tx & Rx requests */ + SET_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN | SPI_CR2_RXDMAEN); + + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + + return HAL_OK; +} + +/** + * @brief Stop the DMA Transfer. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for the specified SPI module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPI_DMAStop(SPI_HandleTypeDef *hspi) +{ + HAL_StatusTypeDef errorcode = HAL_OK; + /* The Lock is not implemented on this API to allow the user application + to call the HAL SPI API under callbacks HAL_SPI_TxCpltCallback() or HAL_SPI_RxCpltCallback() or HAL_SPI_TxRxCpltCallback(): + when calling HAL_DMA_Abort() API the DMA TX/RX Transfer complete interrupt is generated + and the correspond call back is executed HAL_SPI_TxCpltCallback() or HAL_SPI_RxCpltCallback() or HAL_SPI_TxRxCpltCallback() + */ + + /* Abort the SPI DMA tx Stream/Channel */ + if (hspi->hdmatx != NULL) + { + if (HAL_OK != HAL_DMA_Abort(hspi->hdmatx)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_DMA); + errorcode = HAL_ERROR; + } + } + /* Abort the SPI DMA rx Stream/Channel */ + if (hspi->hdmarx != NULL) + { + if (HAL_OK != HAL_DMA_Abort(hspi->hdmarx)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_DMA); + errorcode = HAL_ERROR; + } + } + + /* Disable the SPI DMA Tx & Rx requests */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN | SPI_CR2_RXDMAEN); + hspi->State = HAL_SPI_STATE_READY; + return errorcode; +} + +/** + * @brief Handle SPI interrupt request. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for the specified SPI module. + * @retval None + */ +void HAL_SPI_IRQHandler(SPI_HandleTypeDef *hspi) +{ + uint32_t itsource = hspi->Instance->CR2; + uint32_t itflag = hspi->Instance->SR; + + /* SPI in mode Receiver ----------------------------------------------------*/ + if ((SPI_CHECK_FLAG(itflag, SPI_FLAG_OVR) == RESET) && + (SPI_CHECK_FLAG(itflag, SPI_FLAG_RXNE) != RESET) && (SPI_CHECK_IT_SOURCE(itsource, SPI_IT_RXNE) != RESET)) + { + hspi->RxISR(hspi); + return; + } + + /* SPI in mode Transmitter -------------------------------------------------*/ + if ((SPI_CHECK_FLAG(itflag, SPI_FLAG_TXE) != RESET) && (SPI_CHECK_IT_SOURCE(itsource, SPI_IT_TXE) != RESET)) + { + hspi->TxISR(hspi); + return; + } + + /* SPI in Error Treatment --------------------------------------------------*/ + if (((SPI_CHECK_FLAG(itflag, SPI_FLAG_MODF) != RESET) || (SPI_CHECK_FLAG(itflag, SPI_FLAG_OVR) != RESET) + || (SPI_CHECK_FLAG(itflag, SPI_FLAG_FRE) != RESET)) && (SPI_CHECK_IT_SOURCE(itsource, SPI_IT_ERR) != RESET)) + { + /* SPI Overrun error interrupt occurred ----------------------------------*/ + if (SPI_CHECK_FLAG(itflag, SPI_FLAG_OVR) != RESET) + { + if (hspi->State != HAL_SPI_STATE_BUSY_TX) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_OVR); + __HAL_SPI_CLEAR_OVRFLAG(hspi); + } + else + { + __HAL_SPI_CLEAR_OVRFLAG(hspi); + return; + } + } + + /* SPI Mode Fault error interrupt occurred -------------------------------*/ + if (SPI_CHECK_FLAG(itflag, SPI_FLAG_MODF) != RESET) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_MODF); + __HAL_SPI_CLEAR_MODFFLAG(hspi); + } + + /* SPI Frame error interrupt occurred ------------------------------------*/ + if (SPI_CHECK_FLAG(itflag, SPI_FLAG_FRE) != RESET) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FRE); + __HAL_SPI_CLEAR_FREFLAG(hspi); + } + + if (hspi->ErrorCode != HAL_SPI_ERROR_NONE) + { + /* Disable all interrupts */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_RXNE | SPI_IT_TXE | SPI_IT_ERR); + + hspi->State = HAL_SPI_STATE_READY; + /* Disable the SPI DMA requests if enabled */ + if ((HAL_IS_BIT_SET(itsource, SPI_CR2_TXDMAEN)) || (HAL_IS_BIT_SET(itsource, SPI_CR2_RXDMAEN))) + { + CLEAR_BIT(hspi->Instance->CR2, (SPI_CR2_TXDMAEN | SPI_CR2_RXDMAEN)); + + /* Abort the SPI DMA Rx channel */ + if (hspi->hdmarx != NULL) + { + /* Set the SPI DMA Abort callback : + will lead to call HAL_SPI_ErrorCallback() at end of DMA abort procedure */ + hspi->hdmarx->XferAbortCallback = SPI_DMAAbortOnError; + if (HAL_OK != HAL_DMA_Abort_IT(hspi->hdmarx)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + } + } + /* Abort the SPI DMA Tx channel */ + if (hspi->hdmatx != NULL) + { + /* Set the SPI DMA Abort callback : + will lead to call HAL_SPI_ErrorCallback() at end of DMA abort procedure */ + hspi->hdmatx->XferAbortCallback = SPI_DMAAbortOnError; + if (HAL_OK != HAL_DMA_Abort_IT(hspi->hdmatx)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + } + } + } + else + { + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + } + return; + } +} + +/** + * @brief Tx Transfer completed callback. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_TxCpltCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_TxCpltCallback should be implemented in the user file + */ +} + +/** + * @brief Rx Transfer completed callback. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_RxCpltCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_RxCpltCallback should be implemented in the user file + */ +} + +/** + * @brief Tx and Rx Transfer completed callback. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_TxRxCpltCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_TxRxCpltCallback should be implemented in the user file + */ +} + +/** + * @brief Tx Half Transfer completed callback. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_TxHalfCpltCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_TxHalfCpltCallback should be implemented in the user file + */ +} + +/** + * @brief Rx Half Transfer completed callback. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_RxHalfCpltCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_RxHalfCpltCallback() should be implemented in the user file + */ +} + +/** + * @brief Tx and Rx Half Transfer callback. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_TxRxHalfCpltCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_TxRxHalfCpltCallback() should be implemented in the user file + */ +} + +/** + * @brief SPI error callback. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +__weak void HAL_SPI_ErrorCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_ErrorCallback should be implemented in the user file + */ + /* NOTE : The ErrorCode parameter in the hspi handle is updated by the SPI processes + and user can use HAL_SPI_GetError() API to check the latest error occurred + */ +} + +/** + * @brief SPI Abort Complete callback. + * @param hspi SPI handle. + * @retval None + */ +__weak void HAL_SPI_AbortCpltCallback(SPI_HandleTypeDef *hspi) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hspi); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_SPI_AbortCpltCallback can be implemented in the user file. + */ +} + +/** + * @} + */ + +/** @defgroup SPI_Exported_Functions_Group3 Peripheral State and Errors functions + * @brief SPI control functions + * +@verbatim + =============================================================================== + ##### Peripheral State and Errors functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the SPI. + (+) HAL_SPI_GetState() API can be helpful to check in run-time the state of the SPI peripheral + (+) HAL_SPI_GetError() check in run-time Errors occurring during communication +@endverbatim + * @{ + */ + +/** + * @brief Return the SPI handle state. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval SPI state + */ +HAL_SPI_StateTypeDef HAL_SPI_GetState(SPI_HandleTypeDef *hspi) +{ + /* Return SPI handle state */ + return hspi->State; +} + +/** + * @brief Return the SPI error code. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval SPI error code in bitmap format + */ +uint32_t HAL_SPI_GetError(SPI_HandleTypeDef *hspi) +{ + /* Return SPI ErrorCode */ + return hspi->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup SPI_Private_Functions + * @brief Private functions + * @{ + */ + +/** + * @brief DMA SPI transmit process complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SPI_DMATransmitCplt(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + uint32_t tickstart; + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + /* DMA Normal Mode */ + if ((hdma->Instance->CCR & DMA_CCR_CIRC) != DMA_CCR_CIRC) + { + /* Disable ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_ERR); + + /* Disable Tx DMA Request */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN); + + /* Check the end of the transaction */ + if (SPI_EndRxTxTransaction(hspi, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + } + + /* Clear overrun flag in 2 Lines communication mode because received data is not read */ + if (hspi->Init.Direction == SPI_DIRECTION_2LINES) + { + __HAL_SPI_CLEAR_OVRFLAG(hspi); + } + + hspi->TxXferCount = 0U; + hspi->State = HAL_SPI_STATE_READY; + + if (hspi->ErrorCode != HAL_SPI_ERROR_NONE) + { + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + return; + } + } + /* Call user Tx complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->TxCpltCallback(hspi); +#else + HAL_SPI_TxCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI receive process complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SPI_DMAReceiveCplt(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + uint32_t tickstart; +#if (USE_SPI_CRC != 0U) + __IO uint32_t tmpreg = 0U; + __IO uint8_t * ptmpreg8; + __IO uint8_t tmpreg8 = 0; +#endif /* USE_SPI_CRC */ + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + /* DMA Normal Mode */ + if ((hdma->Instance->CCR & DMA_CCR_CIRC) != DMA_CCR_CIRC) + { + /* Disable ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_ERR); + +#if (USE_SPI_CRC != 0U) + /* CRC handling */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* Wait until RXNE flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_RXNE, SET, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + /* Error on the CRC reception */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + } + /* Read CRC */ + if (hspi->Init.DataSize > SPI_DATASIZE_8BIT) + { + /* Read 16bit CRC */ + tmpreg = READ_REG(hspi->Instance->DR); + /* To avoid GCC warning */ + UNUSED(tmpreg); + } + else + { + /* Initialize the 8bit temporary pointer */ + ptmpreg8 = (__IO uint8_t *)&hspi->Instance->DR; + /* Read 8bit CRC */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + + if (hspi->Init.CRCLength == SPI_CRC_LENGTH_16BIT) + { + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_RXNE, SET, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + /* Error on the CRC reception */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + } + /* Read 8bit CRC again in case of 16bit CRC in 8bit Data mode */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + } + } + } +#endif /* USE_SPI_CRC */ + + /* Check if we are in Master RX 2 line mode */ + if ((hspi->Init.Direction == SPI_DIRECTION_2LINES) && (hspi->Init.Mode == SPI_MODE_MASTER)) + { + /* Disable Rx/Tx DMA Request (done by default to handle the case master rx direction 2 lines) */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN | SPI_CR2_RXDMAEN); + } + else + { + /* Normal case */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_RXDMAEN); + } + + /* Check the end of the transaction */ + if (SPI_EndRxTransaction(hspi, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_FLAG; + } + + hspi->RxXferCount = 0U; + hspi->State = HAL_SPI_STATE_READY; + +#if (USE_SPI_CRC != 0U) + /* Check if CRC error occurred */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_CRCERR)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + __HAL_SPI_CLEAR_CRCERRFLAG(hspi); + } +#endif /* USE_SPI_CRC */ + + if (hspi->ErrorCode != HAL_SPI_ERROR_NONE) + { + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + return; + } + } + /* Call user Rx complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->RxCpltCallback(hspi); +#else + HAL_SPI_RxCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI transmit receive process complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SPI_DMATransmitReceiveCplt(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + uint32_t tickstart; +#if (USE_SPI_CRC != 0U) + __IO uint32_t tmpreg = 0U; + __IO uint8_t * ptmpreg8; + __IO uint8_t tmpreg8 = 0; +#endif /* USE_SPI_CRC */ + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + /* DMA Normal Mode */ + if ((hdma->Instance->CCR & DMA_CCR_CIRC) != DMA_CCR_CIRC) + { + /* Disable ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_ERR); + +#if (USE_SPI_CRC != 0U) + /* CRC handling */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + if ((hspi->Init.DataSize == SPI_DATASIZE_8BIT) && (hspi->Init.CRCLength == SPI_CRC_LENGTH_8BIT)) + { + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_QUARTER_FULL, SPI_DEFAULT_TIMEOUT, + tickstart) != HAL_OK) + { + /* Error on the CRC reception */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + } + /* Initialize the 8bit temporary pointer */ + ptmpreg8 = (__IO uint8_t *)&hspi->Instance->DR; + /* Read 8bit CRC */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + } + else + { + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_HALF_FULL, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + /* Error on the CRC reception */ + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + } + /* Read CRC to Flush DR and RXNE flag */ + tmpreg = READ_REG(hspi->Instance->DR); + /* To avoid GCC warning */ + UNUSED(tmpreg); + } + } +#endif /* USE_SPI_CRC */ + + /* Check the end of the transaction */ + if (SPI_EndRxTxTransaction(hspi, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + } + + /* Disable Rx/Tx DMA Request */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN | SPI_CR2_RXDMAEN); + + hspi->TxXferCount = 0U; + hspi->RxXferCount = 0U; + hspi->State = HAL_SPI_STATE_READY; + +#if (USE_SPI_CRC != 0U) + /* Check if CRC error occurred */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_CRCERR)) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + __HAL_SPI_CLEAR_CRCERRFLAG(hspi); + } +#endif /* USE_SPI_CRC */ + + if (hspi->ErrorCode != HAL_SPI_ERROR_NONE) + { + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + return; + } + } + /* Call user TxRx complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->TxRxCpltCallback(hspi); +#else + HAL_SPI_TxRxCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI half transmit process complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SPI_DMAHalfTransmitCplt(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + + /* Call user Tx half complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->TxHalfCpltCallback(hspi); +#else + HAL_SPI_TxHalfCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI half receive process complete callback + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SPI_DMAHalfReceiveCplt(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + + /* Call user Rx half complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->RxHalfCpltCallback(hspi); +#else + HAL_SPI_RxHalfCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI half transmit receive process complete callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SPI_DMAHalfTransmitReceiveCplt(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + + /* Call user TxRx half complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->TxRxHalfCpltCallback(hspi); +#else + HAL_SPI_TxRxHalfCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI communication error callback. + * @param hdma pointer to a DMA_HandleTypeDef structure that contains + * the configuration information for the specified DMA module. + * @retval None + */ +static void SPI_DMAError(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + + /* Stop the disable DMA transfer on SPI side */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN | SPI_CR2_RXDMAEN); + + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_DMA); + hspi->State = HAL_SPI_STATE_READY; + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI communication abort callback, when initiated by HAL services on Error + * (To be called at end of DMA Abort procedure following error occurrence). + * @param hdma DMA handle. + * @retval None + */ +static void SPI_DMAAbortOnError(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + hspi->RxXferCount = 0U; + hspi->TxXferCount = 0U; + + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI Tx communication abort callback, when initiated by user + * (To be called at end of DMA Tx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Rx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void SPI_DMATxAbortCallback(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + + hspi->hdmatx->XferAbortCallback = NULL; + + /* Disable Tx DMA Request */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_TXDMAEN); + + if (SPI_EndRxTxTransaction(hspi, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Disable SPI Peripheral */ + __HAL_SPI_DISABLE(hspi); + + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Check if an Abort process is still ongoing */ + if (hspi->hdmarx != NULL) + { + if (hspi->hdmarx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA Stream/Channel are aborted, call user Abort Complete callback */ + hspi->RxXferCount = 0U; + hspi->TxXferCount = 0U; + + /* Check no error during Abort procedure */ + if (hspi->ErrorCode != HAL_SPI_ERROR_ABORT) + { + /* Reset errorCode */ + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + } + + /* Clear the Error flags in the SR register */ + __HAL_SPI_CLEAR_OVRFLAG(hspi); + __HAL_SPI_CLEAR_FREFLAG(hspi); + + /* Restore hspi->State to Ready */ + hspi->State = HAL_SPI_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->AbortCpltCallback(hspi); +#else + HAL_SPI_AbortCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA SPI Rx communication abort callback, when initiated by user + * (To be called at end of DMA Rx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Tx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void SPI_DMARxAbortCallback(DMA_HandleTypeDef *hdma) +{ + SPI_HandleTypeDef *hspi = (SPI_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent); /* Derogation MISRAC2012-Rule-11.5 */ + + /* Disable SPI Peripheral */ + __HAL_SPI_DISABLE(hspi); + + hspi->hdmarx->XferAbortCallback = NULL; + + /* Disable Rx DMA Request */ + CLEAR_BIT(hspi->Instance->CR2, SPI_CR2_RXDMAEN); + + /* Control the BSY flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_BSY, RESET, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Check if an Abort process is still ongoing */ + if (hspi->hdmatx != NULL) + { + if (hspi->hdmatx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA Stream/Channel are aborted, call user Abort Complete callback */ + hspi->RxXferCount = 0U; + hspi->TxXferCount = 0U; + + /* Check no error during Abort procedure */ + if (hspi->ErrorCode != HAL_SPI_ERROR_ABORT) + { + /* Reset errorCode */ + hspi->ErrorCode = HAL_SPI_ERROR_NONE; + } + + /* Clear the Error flags in the SR register */ + __HAL_SPI_CLEAR_OVRFLAG(hspi); + __HAL_SPI_CLEAR_FREFLAG(hspi); + + /* Restore hspi->State to Ready */ + hspi->State = HAL_SPI_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->AbortCpltCallback(hspi); +#else + HAL_SPI_AbortCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ +} + +/** + * @brief Rx 8-bit handler for Transmit and Receive in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_2linesRxISR_8BIT(struct __SPI_HandleTypeDef *hspi) +{ + /* Receive data in packing mode */ + if (hspi->RxXferCount > 1U) + { + *((uint16_t *)hspi->pRxBuffPtr) = (uint16_t)(hspi->Instance->DR); + hspi->pRxBuffPtr += sizeof(uint16_t); + hspi->RxXferCount -= 2U; + if (hspi->RxXferCount == 1U) + { + /* Set RX Fifo threshold according the reception data length: 8bit */ + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + } + } + /* Receive data in 8 Bit mode */ + else + { + *hspi->pRxBuffPtr = *((__IO uint8_t *)&hspi->Instance->DR); + hspi->pRxBuffPtr++; + hspi->RxXferCount--; + } + + /* Check end of the reception */ + if (hspi->RxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SET_BIT(hspi->Instance->CR2, SPI_RXFIFO_THRESHOLD); + hspi->RxISR = SPI_2linesRxISR_8BITCRC; + return; + } +#endif /* USE_SPI_CRC */ + + /* Disable RXNE and ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_RXNE | SPI_IT_ERR)); + + if (hspi->TxXferCount == 0U) + { + SPI_CloseRxTx_ISR(hspi); + } + } +} + +#if (USE_SPI_CRC != 0U) +/** + * @brief Rx 8-bit handler for Transmit and Receive in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_2linesRxISR_8BITCRC(struct __SPI_HandleTypeDef *hspi) +{ + __IO uint8_t * ptmpreg8; + __IO uint8_t tmpreg8 = 0; + + /* Initialize the 8bit temporary pointer */ + ptmpreg8 = (__IO uint8_t *)&hspi->Instance->DR; + /* Read 8bit CRC to flush Data Register */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + + hspi->CRCSize--; + + /* Check end of the reception */ + if (hspi->CRCSize == 0U) + { + /* Disable RXNE and ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_RXNE | SPI_IT_ERR)); + + if (hspi->TxXferCount == 0U) + { + SPI_CloseRxTx_ISR(hspi); + } + } +} +#endif /* USE_SPI_CRC */ + +/** + * @brief Tx 8-bit handler for Transmit and Receive in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_2linesTxISR_8BIT(struct __SPI_HandleTypeDef *hspi) +{ + /* Transmit data in packing Bit mode */ + if (hspi->TxXferCount >= 2U) + { + hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint16_t); + hspi->TxXferCount -= 2U; + } + /* Transmit data in 8 Bit mode */ + else + { + *(__IO uint8_t *)&hspi->Instance->DR = (*hspi->pTxBuffPtr); + hspi->pTxBuffPtr++; + hspi->TxXferCount--; + } + + /* Check the end of the transmission */ + if (hspi->TxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* Set CRC Next Bit to send CRC */ + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + /* Disable TXE interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_TXE); + return; + } +#endif /* USE_SPI_CRC */ + + /* Disable TXE interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_TXE); + + if (hspi->RxXferCount == 0U) + { + SPI_CloseRxTx_ISR(hspi); + } + } +} + +/** + * @brief Rx 16-bit handler for Transmit and Receive in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_2linesRxISR_16BIT(struct __SPI_HandleTypeDef *hspi) +{ + /* Receive data in 16 Bit mode */ + *((uint16_t *)hspi->pRxBuffPtr) = (uint16_t)(hspi->Instance->DR); + hspi->pRxBuffPtr += sizeof(uint16_t); + hspi->RxXferCount--; + + if (hspi->RxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + hspi->RxISR = SPI_2linesRxISR_16BITCRC; + return; + } +#endif /* USE_SPI_CRC */ + + /* Disable RXNE interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_RXNE); + + if (hspi->TxXferCount == 0U) + { + SPI_CloseRxTx_ISR(hspi); + } + } +} + +#if (USE_SPI_CRC != 0U) +/** + * @brief Manage the CRC 16-bit receive for Transmit and Receive in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_2linesRxISR_16BITCRC(struct __SPI_HandleTypeDef *hspi) +{ + __IO uint32_t tmpreg = 0U; + + /* Read 16bit CRC to flush Data Register */ + tmpreg = READ_REG(hspi->Instance->DR); + /* To avoid GCC warning */ + UNUSED(tmpreg); + + /* Disable RXNE interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_RXNE); + + SPI_CloseRxTx_ISR(hspi); +} +#endif /* USE_SPI_CRC */ + +/** + * @brief Tx 16-bit handler for Transmit and Receive in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_2linesTxISR_16BIT(struct __SPI_HandleTypeDef *hspi) +{ + /* Transmit data in 16 Bit mode */ + hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint16_t); + hspi->TxXferCount--; + + /* Enable CRC Transmission */ + if (hspi->TxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* Set CRC Next Bit to send CRC */ + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + /* Disable TXE interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_TXE); + return; + } +#endif /* USE_SPI_CRC */ + + /* Disable TXE interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_TXE); + + if (hspi->RxXferCount == 0U) + { + SPI_CloseRxTx_ISR(hspi); + } + } +} + +#if (USE_SPI_CRC != 0U) +/** + * @brief Manage the CRC 8-bit receive in Interrupt context. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_RxISR_8BITCRC(struct __SPI_HandleTypeDef *hspi) +{ + __IO uint8_t * ptmpreg8; + __IO uint8_t tmpreg8 = 0; + + /* Initialize the 8bit temporary pointer */ + ptmpreg8 = (__IO uint8_t *)&hspi->Instance->DR; + /* Read 8bit CRC to flush Data Register */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + + hspi->CRCSize--; + + if (hspi->CRCSize == 0U) + { + SPI_CloseRx_ISR(hspi); + } +} +#endif /* USE_SPI_CRC */ + +/** + * @brief Manage the receive 8-bit in Interrupt context. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_RxISR_8BIT(struct __SPI_HandleTypeDef *hspi) +{ + *hspi->pRxBuffPtr = (*(__IO uint8_t *)&hspi->Instance->DR); + hspi->pRxBuffPtr++; + hspi->RxXferCount--; + +#if (USE_SPI_CRC != 0U) + /* Enable CRC Transmission */ + if ((hspi->RxXferCount == 1U) && (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE)) + { + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + } +#endif /* USE_SPI_CRC */ + + if (hspi->RxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + hspi->RxISR = SPI_RxISR_8BITCRC; + return; + } +#endif /* USE_SPI_CRC */ + SPI_CloseRx_ISR(hspi); + } +} + +#if (USE_SPI_CRC != 0U) +/** + * @brief Manage the CRC 16-bit receive in Interrupt context. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_RxISR_16BITCRC(struct __SPI_HandleTypeDef *hspi) +{ + __IO uint32_t tmpreg = 0U; + + /* Read 16bit CRC to flush Data Register */ + tmpreg = READ_REG(hspi->Instance->DR); + /* To avoid GCC warning */ + UNUSED(tmpreg); + + /* Disable RXNE and ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_RXNE | SPI_IT_ERR)); + + SPI_CloseRx_ISR(hspi); +} +#endif /* USE_SPI_CRC */ + +/** + * @brief Manage the 16-bit receive in Interrupt context. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_RxISR_16BIT(struct __SPI_HandleTypeDef *hspi) +{ + *((uint16_t *)hspi->pRxBuffPtr) = (uint16_t)(hspi->Instance->DR); + hspi->pRxBuffPtr += sizeof(uint16_t); + hspi->RxXferCount--; + +#if (USE_SPI_CRC != 0U) + /* Enable CRC Transmission */ + if ((hspi->RxXferCount == 1U) && (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE)) + { + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + } +#endif /* USE_SPI_CRC */ + + if (hspi->RxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + hspi->RxISR = SPI_RxISR_16BITCRC; + return; + } +#endif /* USE_SPI_CRC */ + SPI_CloseRx_ISR(hspi); + } +} + +/** + * @brief Handle the data 8-bit transmit in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_TxISR_8BIT(struct __SPI_HandleTypeDef *hspi) +{ + *(__IO uint8_t *)&hspi->Instance->DR = (*hspi->pTxBuffPtr); + hspi->pTxBuffPtr++; + hspi->TxXferCount--; + + if (hspi->TxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* Enable CRC Transmission */ + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + } +#endif /* USE_SPI_CRC */ + SPI_CloseTx_ISR(hspi); + } +} + +/** + * @brief Handle the data 16-bit transmit in Interrupt mode. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_TxISR_16BIT(struct __SPI_HandleTypeDef *hspi) +{ + /* Transmit data in 16 Bit mode */ + hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr); + hspi->pTxBuffPtr += sizeof(uint16_t); + hspi->TxXferCount--; + + if (hspi->TxXferCount == 0U) + { +#if (USE_SPI_CRC != 0U) + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + /* Enable CRC Transmission */ + SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT); + } +#endif /* USE_SPI_CRC */ + SPI_CloseTx_ISR(hspi); + } +} + +/** + * @brief Handle SPI Communication Timeout. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param Flag SPI flag to check + * @param State flag state to check + * @param Timeout Timeout duration + * @param Tickstart tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef SPI_WaitFlagStateUntilTimeout(SPI_HandleTypeDef *hspi, uint32_t Flag, FlagStatus State, + uint32_t Timeout, uint32_t Tickstart) +{ + __IO uint32_t count; + uint32_t tmp_timeout; + uint32_t tmp_tickstart; + + /* Adjust Timeout value in case of end of transfer */ + tmp_timeout = Timeout - (HAL_GetTick() - Tickstart); + tmp_tickstart = HAL_GetTick(); + + /* Calculate Timeout based on a software loop to avoid blocking issue if Systick is disabled */ + count = tmp_timeout * ((SystemCoreClock * 32U) >> 20U); + + while ((__HAL_SPI_GET_FLAG(hspi, Flag) ? SET : RESET) != State) + { + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - tmp_tickstart) >= tmp_timeout) || (tmp_timeout == 0U)) + { + /* Disable the SPI and reset the CRC: the CRC value should be cleared + on both master and slave sides in order to resynchronize the master + and slave for their respective CRC calculation */ + + /* Disable TXE, RXNE and ERR interrupts for the interrupt process */ + __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_TXE | SPI_IT_RXNE | SPI_IT_ERR)); + + if ((hspi->Init.Mode == SPI_MODE_MASTER) && ((hspi->Init.Direction == SPI_DIRECTION_1LINE) + || (hspi->Init.Direction == SPI_DIRECTION_2LINES_RXONLY))) + { + /* Disable SPI peripheral */ + __HAL_SPI_DISABLE(hspi); + } + + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } + + hspi->State = HAL_SPI_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + + return HAL_TIMEOUT; + } + /* If Systick is disabled or not incremented, deactivate timeout to go in disable loop procedure */ + if(count == 0U) + { + tmp_timeout = 0U; + } + count--; + } + } + + return HAL_OK; +} + +/** + * @brief Handle SPI FIFO Communication Timeout. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param Fifo Fifo to check + * @param State Fifo state to check + * @param Timeout Timeout duration + * @param Tickstart tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef SPI_WaitFifoStateUntilTimeout(SPI_HandleTypeDef *hspi, uint32_t Fifo, uint32_t State, + uint32_t Timeout, uint32_t Tickstart) +{ + __IO uint32_t count; + uint32_t tmp_timeout; + uint32_t tmp_tickstart; + __IO uint8_t * ptmpreg8; + __IO uint8_t tmpreg8 = 0; + + /* Adjust Timeout value in case of end of transfer */ + tmp_timeout = Timeout - (HAL_GetTick() - Tickstart); + tmp_tickstart = HAL_GetTick(); + + /* Initialize the 8bit temporary pointer */ + ptmpreg8 = (__IO uint8_t *)&hspi->Instance->DR; + + /* Calculate Timeout based on a software loop to avoid blocking issue if Systick is disabled */ + count = tmp_timeout * ((SystemCoreClock * 35U) >> 20U); + + while ((hspi->Instance->SR & Fifo) != State) + { + if ((Fifo == SPI_SR_FRLVL) && (State == SPI_FRLVL_EMPTY)) + { + /* Flush Data Register by a blank read */ + tmpreg8 = *ptmpreg8; + /* To avoid GCC warning */ + UNUSED(tmpreg8); + } + + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - tmp_tickstart) >= tmp_timeout) || (tmp_timeout == 0U)) + { + /* Disable the SPI and reset the CRC: the CRC value should be cleared + on both master and slave sides in order to resynchronize the master + and slave for their respective CRC calculation */ + + /* Disable TXE, RXNE and ERR interrupts for the interrupt process */ + __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_TXE | SPI_IT_RXNE | SPI_IT_ERR)); + + if ((hspi->Init.Mode == SPI_MODE_MASTER) && ((hspi->Init.Direction == SPI_DIRECTION_1LINE) + || (hspi->Init.Direction == SPI_DIRECTION_2LINES_RXONLY))) + { + /* Disable SPI peripheral */ + __HAL_SPI_DISABLE(hspi); + } + + /* Reset CRC Calculation */ + if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE) + { + SPI_RESET_CRC(hspi); + } + + hspi->State = HAL_SPI_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(hspi); + + return HAL_TIMEOUT; + } + /* If Systick is disabled or not incremented, deactivate timeout to go in disable loop procedure */ + if(count == 0U) + { + tmp_timeout = 0U; + } + count--; + } + } + + return HAL_OK; +} + +/** + * @brief Handle the check of the RX transaction complete. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @param Timeout Timeout duration + * @param Tickstart tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef SPI_EndRxTransaction(SPI_HandleTypeDef *hspi, uint32_t Timeout, uint32_t Tickstart) +{ + if ((hspi->Init.Mode == SPI_MODE_MASTER) && ((hspi->Init.Direction == SPI_DIRECTION_1LINE) + || (hspi->Init.Direction == SPI_DIRECTION_2LINES_RXONLY))) + { + /* Disable SPI peripheral */ + __HAL_SPI_DISABLE(hspi); + } + + /* Control the BSY flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_BSY, RESET, Timeout, Tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + return HAL_TIMEOUT; + } + + if ((hspi->Init.Mode == SPI_MODE_MASTER) && ((hspi->Init.Direction == SPI_DIRECTION_1LINE) + || (hspi->Init.Direction == SPI_DIRECTION_2LINES_RXONLY))) + { + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, Timeout, Tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + return HAL_TIMEOUT; + } + } + return HAL_OK; +} + +/** + * @brief Handle the check of the RXTX or TX transaction complete. + * @param hspi SPI handle + * @param Timeout Timeout duration + * @param Tickstart tick start value + * @retval HAL status + */ +static HAL_StatusTypeDef SPI_EndRxTxTransaction(SPI_HandleTypeDef *hspi, uint32_t Timeout, uint32_t Tickstart) +{ + /* Control if the TX fifo is empty */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FTLVL, SPI_FTLVL_EMPTY, Timeout, Tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + return HAL_TIMEOUT; + } + + /* Control the BSY flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_BSY, RESET, Timeout, Tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + return HAL_TIMEOUT; + } + + /* Control if the RX fifo is empty */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, Timeout, Tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + return HAL_TIMEOUT; + } + + return HAL_OK; +} + +/** + * @brief Handle the end of the RXTX transaction. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_CloseRxTx_ISR(SPI_HandleTypeDef *hspi) +{ + uint32_t tickstart; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + /* Disable ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, SPI_IT_ERR); + + /* Check the end of the transaction */ + if (SPI_EndRxTxTransaction(hspi, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + } + +#if (USE_SPI_CRC != 0U) + /* Check if CRC error occurred */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_CRCERR) != RESET) + { + hspi->State = HAL_SPI_STATE_READY; + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + __HAL_SPI_CLEAR_CRCERRFLAG(hspi); + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + else + { +#endif /* USE_SPI_CRC */ + if (hspi->ErrorCode == HAL_SPI_ERROR_NONE) + { + if (hspi->State == HAL_SPI_STATE_BUSY_RX) + { + hspi->State = HAL_SPI_STATE_READY; + /* Call user Rx complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->RxCpltCallback(hspi); +#else + HAL_SPI_RxCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + else + { + hspi->State = HAL_SPI_STATE_READY; + /* Call user TxRx complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->TxRxCpltCallback(hspi); +#else + HAL_SPI_TxRxCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + } + else + { + hspi->State = HAL_SPI_STATE_READY; + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } +#if (USE_SPI_CRC != 0U) + } +#endif /* USE_SPI_CRC */ +} + +/** + * @brief Handle the end of the RX transaction. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_CloseRx_ISR(SPI_HandleTypeDef *hspi) +{ + /* Disable RXNE and ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_RXNE | SPI_IT_ERR)); + + /* Check the end of the transaction */ + if (SPI_EndRxTransaction(hspi, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + } + hspi->State = HAL_SPI_STATE_READY; + +#if (USE_SPI_CRC != 0U) + /* Check if CRC error occurred */ + if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_CRCERR) != RESET) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_CRC); + __HAL_SPI_CLEAR_CRCERRFLAG(hspi); + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + else + { +#endif /* USE_SPI_CRC */ + if (hspi->ErrorCode == HAL_SPI_ERROR_NONE) + { + /* Call user Rx complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->RxCpltCallback(hspi); +#else + HAL_SPI_RxCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + else + { + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } +#if (USE_SPI_CRC != 0U) + } +#endif /* USE_SPI_CRC */ +} + +/** + * @brief Handle the end of the TX transaction. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_CloseTx_ISR(SPI_HandleTypeDef *hspi) +{ + uint32_t tickstart; + + /* Init tickstart for timeout management*/ + tickstart = HAL_GetTick(); + + /* Disable TXE and ERR interrupt */ + __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_TXE | SPI_IT_ERR)); + + /* Check the end of the transaction */ + if (SPI_EndRxTxTransaction(hspi, SPI_DEFAULT_TIMEOUT, tickstart) != HAL_OK) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG); + } + + /* Clear overrun flag in 2 Lines communication mode because received is not read */ + if (hspi->Init.Direction == SPI_DIRECTION_2LINES) + { + __HAL_SPI_CLEAR_OVRFLAG(hspi); + } + + hspi->State = HAL_SPI_STATE_READY; + if (hspi->ErrorCode != HAL_SPI_ERROR_NONE) + { + /* Call user error callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->ErrorCallback(hspi); +#else + HAL_SPI_ErrorCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } + else + { + /* Call user Rx complete callback */ +#if (USE_HAL_SPI_REGISTER_CALLBACKS == 1U) + hspi->TxCpltCallback(hspi); +#else + HAL_SPI_TxCpltCallback(hspi); +#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */ + } +} + +/** + * @brief Handle abort a Rx transaction. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_AbortRx_ISR(SPI_HandleTypeDef *hspi) +{ + __IO uint32_t count; + + /* Disable SPI Peripheral */ + __HAL_SPI_DISABLE(hspi); + + count = SPI_DEFAULT_TIMEOUT * (SystemCoreClock / 24U / 1000U); + + /* Disable RXNEIE interrupt */ + CLEAR_BIT(hspi->Instance->CR2, (SPI_CR2_RXNEIE)); + + /* Check RXNEIE is disabled */ + do + { + if (count == 0U) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + break; + } + count--; + } while (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXNEIE)); + + /* Control the BSY flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_BSY, RESET, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + hspi->State = HAL_SPI_STATE_ABORT; +} + +/** + * @brief Handle abort a Tx or Rx/Tx transaction. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for SPI module. + * @retval None + */ +static void SPI_AbortTx_ISR(SPI_HandleTypeDef *hspi) +{ + __IO uint32_t count; + + count = SPI_DEFAULT_TIMEOUT * (SystemCoreClock / 24U / 1000U); + + /* Disable TXEIE interrupt */ + CLEAR_BIT(hspi->Instance->CR2, (SPI_CR2_TXEIE)); + + /* Check TXEIE is disabled */ + do + { + if (count == 0U) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + break; + } + count--; + } while (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_TXEIE)); + + if (SPI_EndRxTxTransaction(hspi, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Disable SPI Peripheral */ + __HAL_SPI_DISABLE(hspi); + + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Check case of Full-Duplex Mode and disable directly RXNEIE interrupt */ + if (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXNEIE)) + { + /* Disable RXNEIE interrupt */ + CLEAR_BIT(hspi->Instance->CR2, (SPI_CR2_RXNEIE)); + + /* Check RXNEIE is disabled */ + do + { + if (count == 0U) + { + SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_ABORT); + break; + } + count--; + } while (HAL_IS_BIT_SET(hspi->Instance->CR2, SPI_CR2_RXNEIE)); + + /* Control the BSY flag */ + if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_BSY, RESET, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + + /* Empty the FRLVL fifo */ + if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, SPI_DEFAULT_TIMEOUT, HAL_GetTick()) != HAL_OK) + { + hspi->ErrorCode = HAL_SPI_ERROR_ABORT; + } + } + hspi->State = HAL_SPI_STATE_ABORT; +} + +/** + * @} + */ + +#endif /* HAL_SPI_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi_ex.c new file mode 100644 index 0000000..b746553 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_spi_ex.c @@ -0,0 +1,115 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_spi_ex.c + * @author MCD Application Team + * @brief Extended SPI HAL module driver. + * This file provides firmware functions to manage the following + * SPI peripheral extended functionalities : + * + IO operation functions + * + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup SPIEx SPIEx + * @brief SPI Extended HAL module driver + * @{ + */ +#ifdef HAL_SPI_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private defines -----------------------------------------------------------*/ +/** @defgroup SPIEx_Private_Constants SPIEx Private Constants + * @{ + */ +#define SPI_FIFO_SIZE 4UL +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup SPIEx_Exported_Functions SPIEx Exported Functions + * @{ + */ + +/** @defgroup SPIEx_Exported_Functions_Group1 IO operation functions + * @brief Data transfers functions + * +@verbatim + ============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] + This subsection provides a set of extended functions to manage the SPI + data transfers. + + (#) Rx data flush function: + (++) HAL_SPIEx_FlushRxFifo() + +@endverbatim + * @{ + */ + +/** + * @brief Flush the RX fifo. + * @param hspi pointer to a SPI_HandleTypeDef structure that contains + * the configuration information for the specified SPI module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_SPIEx_FlushRxFifo(SPI_HandleTypeDef *hspi) +{ + __IO uint32_t tmpreg; + uint8_t count = 0U; + while ((hspi->Instance->SR & SPI_FLAG_FRLVL) != SPI_FRLVL_EMPTY) + { + count++; + tmpreg = hspi->Instance->DR; + UNUSED(tmpreg); /* To avoid GCC warning */ + if (count == SPI_FIFO_SIZE) + { + return HAL_TIMEOUT; + } + } + return HAL_OK; +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_SPI_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim.c new file mode 100644 index 0000000..caf1702 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim.c @@ -0,0 +1,7635 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_tim.c + * @author MCD Application Team + * @brief TIM HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Timer (TIM) peripheral: + * + TIM Time Base Initialization + * + TIM Time Base Start + * + TIM Time Base Start Interruption + * + TIM Time Base Start DMA + * + TIM Output Compare/PWM Initialization + * + TIM Output Compare/PWM Channel Configuration + * + TIM Output Compare/PWM Start + * + TIM Output Compare/PWM Start Interruption + * + TIM Output Compare/PWM Start DMA + * + TIM Input Capture Initialization + * + TIM Input Capture Channel Configuration + * + TIM Input Capture Start + * + TIM Input Capture Start Interruption + * + TIM Input Capture Start DMA + * + TIM One Pulse Initialization + * + TIM One Pulse Channel Configuration + * + TIM One Pulse Start + * + TIM Encoder Interface Initialization + * + TIM Encoder Interface Start + * + TIM Encoder Interface Start Interruption + * + TIM Encoder Interface Start DMA + * + Commutation Event configuration with Interruption and DMA + * + TIM OCRef clear configuration + * + TIM External Clock configuration + @verbatim + ============================================================================== + ##### TIMER Generic features ##### + ============================================================================== + [..] The Timer features include: + (#) 16-bit up, down, up/down auto-reload counter. + (#) 16-bit programmable prescaler allowing dividing (also on the fly) the + counter clock frequency either by any factor between 1 and 65536. + (#) Up to 4 independent channels for: + (++) Input Capture + (++) Output Compare + (++) PWM generation (Edge and Center-aligned Mode) + (++) One-pulse mode output + (#) Synchronization circuit to control the timer with external signals and to interconnect + several timers together. + (#) Supports incremental encoder for positioning purposes + + ##### How to use this driver ##### + ============================================================================== + [..] + (#) Initialize the TIM low level resources by implementing the following functions + depending on the selected feature: + (++) Time Base : HAL_TIM_Base_MspInit() + (++) Input Capture : HAL_TIM_IC_MspInit() + (++) Output Compare : HAL_TIM_OC_MspInit() + (++) PWM generation : HAL_TIM_PWM_MspInit() + (++) One-pulse mode output : HAL_TIM_OnePulse_MspInit() + (++) Encoder mode output : HAL_TIM_Encoder_MspInit() + + (#) Initialize the TIM low level resources : + (##) Enable the TIM interface clock using __HAL_RCC_TIMx_CLK_ENABLE(); + (##) TIM pins configuration + (+++) Enable the clock for the TIM GPIOs using the following function: + __HAL_RCC_GPIOx_CLK_ENABLE(); + (+++) Configure these TIM pins in Alternate function mode using HAL_GPIO_Init(); + + (#) The external Clock can be configured, if needed (the default clock is the + internal clock from the APBx), using the following function: + HAL_TIM_ConfigClockSource, the clock configuration should be done before + any start function. + + (#) Configure the TIM in the desired functioning mode using one of the + Initialization function of this driver: + (++) HAL_TIM_Base_Init: to use the Timer to generate a simple time base + (++) HAL_TIM_OC_Init and HAL_TIM_OC_ConfigChannel: to use the Timer to generate an + Output Compare signal. + (++) HAL_TIM_PWM_Init and HAL_TIM_PWM_ConfigChannel: to use the Timer to generate a + PWM signal. + (++) HAL_TIM_IC_Init and HAL_TIM_IC_ConfigChannel: to use the Timer to measure an + external signal. + (++) HAL_TIM_OnePulse_Init and HAL_TIM_OnePulse_ConfigChannel: to use the Timer + in One Pulse Mode. + (++) HAL_TIM_Encoder_Init: to use the Timer Encoder Interface. + + (#) Activate the TIM peripheral using one of the start functions depending from the feature used: + (++) Time Base : HAL_TIM_Base_Start(), HAL_TIM_Base_Start_DMA(), HAL_TIM_Base_Start_IT() + (++) Input Capture : HAL_TIM_IC_Start(), HAL_TIM_IC_Start_DMA(), HAL_TIM_IC_Start_IT() + (++) Output Compare : HAL_TIM_OC_Start(), HAL_TIM_OC_Start_DMA(), HAL_TIM_OC_Start_IT() + (++) PWM generation : HAL_TIM_PWM_Start(), HAL_TIM_PWM_Start_DMA(), HAL_TIM_PWM_Start_IT() + (++) One-pulse mode output : HAL_TIM_OnePulse_Start(), HAL_TIM_OnePulse_Start_IT() + (++) Encoder mode output : HAL_TIM_Encoder_Start(), HAL_TIM_Encoder_Start_DMA(), HAL_TIM_Encoder_Start_IT(). + + (#) The DMA Burst is managed with the two following functions: + HAL_TIM_DMABurst_WriteStart() + HAL_TIM_DMABurst_ReadStart() + + *** Callback registration *** + ============================================= + + [..] + The compilation define USE_HAL_TIM_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + + [..] + Use Function HAL_TIM_RegisterCallback() to register a callback. + HAL_TIM_RegisterCallback() takes as parameters the HAL peripheral handle, + the Callback ID and a pointer to the user callback function. + + [..] + Use function HAL_TIM_UnRegisterCallback() to reset a callback to the default + weak function. + HAL_TIM_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + + [..] + These functions allow to register/unregister following callbacks: + (+) Base_MspInitCallback : TIM Base Msp Init Callback. + (+) Base_MspDeInitCallback : TIM Base Msp DeInit Callback. + (+) IC_MspInitCallback : TIM IC Msp Init Callback. + (+) IC_MspDeInitCallback : TIM IC Msp DeInit Callback. + (+) OC_MspInitCallback : TIM OC Msp Init Callback. + (+) OC_MspDeInitCallback : TIM OC Msp DeInit Callback. + (+) PWM_MspInitCallback : TIM PWM Msp Init Callback. + (+) PWM_MspDeInitCallback : TIM PWM Msp DeInit Callback. + (+) OnePulse_MspInitCallback : TIM One Pulse Msp Init Callback. + (+) OnePulse_MspDeInitCallback : TIM One Pulse Msp DeInit Callback. + (+) Encoder_MspInitCallback : TIM Encoder Msp Init Callback. + (+) Encoder_MspDeInitCallback : TIM Encoder Msp DeInit Callback. + (+) HallSensor_MspInitCallback : TIM Hall Sensor Msp Init Callback. + (+) HallSensor_MspDeInitCallback : TIM Hall Sensor Msp DeInit Callback. + (+) PeriodElapsedCallback : TIM Period Elapsed Callback. + (+) PeriodElapsedHalfCpltCallback : TIM Period Elapsed half complete Callback. + (+) TriggerCallback : TIM Trigger Callback. + (+) TriggerHalfCpltCallback : TIM Trigger half complete Callback. + (+) IC_CaptureCallback : TIM Input Capture Callback. + (+) IC_CaptureHalfCpltCallback : TIM Input Capture half complete Callback. + (+) OC_DelayElapsedCallback : TIM Output Compare Delay Elapsed Callback. + (+) PWM_PulseFinishedCallback : TIM PWM Pulse Finished Callback. + (+) PWM_PulseFinishedHalfCpltCallback : TIM PWM Pulse Finished half complete Callback. + (+) ErrorCallback : TIM Error Callback. + (+) CommutationCallback : TIM Commutation Callback. + (+) CommutationHalfCpltCallback : TIM Commutation half complete Callback. + (+) BreakCallback : TIM Break Callback. + + [..] +By default, after the Init and when the state is HAL_TIM_STATE_RESET +all interrupt callbacks are set to the corresponding weak functions: + examples HAL_TIM_TriggerCallback(), HAL_TIM_ErrorCallback(). + + [..] + Exception done for MspInit and MspDeInit functions that are reset to the legacy weak + functionalities in the Init / DeInit only when these callbacks are null + (not registered beforehand). If not, MspInit or MspDeInit are not null, the Init / DeInit + keep and use the user MspInit / MspDeInit callbacks(registered beforehand) + + [..] + Callbacks can be registered / unregistered in HAL_TIM_STATE_READY state only. + Exception done MspInit / MspDeInit that can be registered / unregistered + in HAL_TIM_STATE_READY or HAL_TIM_STATE_RESET state, + thus registered(user) MspInit / DeInit callbacks can be used during the Init / DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_TIM_RegisterCallback() before calling DeInit or Init function. + + [..] + When The compilation define USE_HAL_TIM_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup TIM TIM + * @brief TIM HAL module driver + * @{ + */ + +#ifdef HAL_TIM_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @addtogroup TIM_Private_Functions + * @{ + */ +static void TIM_OC1_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config); +static void TIM_OC3_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config); +static void TIM_OC4_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config); +static void TIM_TI1_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter); +static void TIM_TI2_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, + uint32_t TIM_ICFilter); +static void TIM_TI2_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter); +static void TIM_TI3_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, + uint32_t TIM_ICFilter); +static void TIM_TI4_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, + uint32_t TIM_ICFilter); +static void TIM_ITRx_SetConfig(TIM_TypeDef *TIMx, uint32_t InputTriggerSource); +static void TIM_DMAPeriodElapsedCplt(DMA_HandleTypeDef *hdma); +static void TIM_DMAPeriodElapsedHalfCplt(DMA_HandleTypeDef *hdma); +static void TIM_DMADelayPulseCplt(DMA_HandleTypeDef *hdma); +static void TIM_DMATriggerCplt(DMA_HandleTypeDef *hdma); +static void TIM_DMATriggerHalfCplt(DMA_HandleTypeDef *hdma); +static HAL_StatusTypeDef TIM_SlaveTimer_SetConfig(TIM_HandleTypeDef *htim, + TIM_SlaveConfigTypeDef *sSlaveConfig); +/** + * @} + */ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup TIM_Exported_Functions TIM Exported Functions + * @{ + */ + +/** @defgroup TIM_Exported_Functions_Group1 TIM Time Base functions + * @brief Time Base functions + * +@verbatim + ============================================================================== + ##### Time Base functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and configure the TIM base. + (+) De-initialize the TIM base. + (+) Start the Time Base. + (+) Stop the Time Base. + (+) Start the Time Base and enable interrupt. + (+) Stop the Time Base and disable interrupt. + (+) Start the Time Base and enable DMA transfer. + (+) Stop the Time Base and disable DMA transfer. + +@endverbatim + * @{ + */ +/** + * @brief Initializes the TIM Time base Unit according to the specified + * parameters in the TIM_HandleTypeDef and initialize the associated handle. + * @note Switching from Center Aligned counter mode to Edge counter mode (or reverse) + * requires a timer reset to avoid unexpected direction + * due to DIR bit readonly in center aligned mode. + * Ex: call @ref HAL_TIM_Base_DeInit() before HAL_TIM_Base_Init() + * @param htim TIM Base handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_Init(TIM_HandleTypeDef *htim) +{ + /* Check the TIM handle allocation */ + if (htim == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode)); + assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); + assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); + + if (htim->State == HAL_TIM_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htim->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + /* Reset interrupt callbacks to legacy weak callbacks */ + TIM_ResetCallback(htim); + + if (htim->Base_MspInitCallback == NULL) + { + htim->Base_MspInitCallback = HAL_TIM_Base_MspInit; + } + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + htim->Base_MspInitCallback(htim); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + HAL_TIM_Base_MspInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Set the Time Base configuration */ + TIM_Base_SetConfig(htim->Instance, &htim->Init); + + /* Initialize the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + + /* Initialize the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + + /* Initialize the TIM state*/ + htim->State = HAL_TIM_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the TIM Base peripheral + * @param htim TIM Base handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_DeInit(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Disable the TIM Peripheral Clock */ + __HAL_TIM_DISABLE(htim); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + if (htim->Base_MspDeInitCallback == NULL) + { + htim->Base_MspDeInitCallback = HAL_TIM_Base_MspDeInit; + } + /* DeInit the low level hardware */ + htim->Base_MspDeInitCallback(htim); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + HAL_TIM_Base_MspDeInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_RESET; + + /* Change the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + + /* Change TIM state */ + htim->State = HAL_TIM_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Initializes the TIM Base MSP. + * @param htim TIM Base handle + * @retval None + */ +__weak void HAL_TIM_Base_MspInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_Base_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes TIM Base MSP. + * @param htim TIM Base handle + * @retval None + */ +__weak void HAL_TIM_Base_MspDeInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_Base_MspDeInit could be implemented in the user file + */ +} + + +/** + * @brief Starts the TIM Base generation. + * @param htim TIM Base handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_Start(TIM_HandleTypeDef *htim) +{ + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + /* Check the TIM state */ + if (htim->State != HAL_TIM_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Base generation. + * @param htim TIM Base handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_Stop(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Base generation in interrupt mode. + * @param htim TIM Base handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_Start_IT(TIM_HandleTypeDef *htim) +{ + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + /* Check the TIM state */ + if (htim->State != HAL_TIM_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Enable the TIM Update interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_UPDATE); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Base generation in interrupt mode. + * @param htim TIM Base handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_Stop_IT(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + /* Disable the TIM Update interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_UPDATE); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Base generation in DMA mode. + * @param htim TIM Base handle + * @param pData The source Buffer address. + * @param Length The length of data to be transferred from memory to peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length) +{ + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_DMA_INSTANCE(htim->Instance)); + + /* Set the TIM state */ + if (htim->State == HAL_TIM_STATE_BUSY) + { + return HAL_BUSY; + } + else if (htim->State == HAL_TIM_STATE_READY) + { + if ((pData == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + htim->State = HAL_TIM_STATE_BUSY; + } + } + else + { + return HAL_ERROR; + } + + /* Set the DMA Period elapsed callbacks */ + htim->hdma[TIM_DMA_ID_UPDATE]->XferCpltCallback = TIM_DMAPeriodElapsedCplt; + htim->hdma[TIM_DMA_ID_UPDATE]->XferHalfCpltCallback = TIM_DMAPeriodElapsedHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_UPDATE]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_UPDATE], (uint32_t)pData, (uint32_t)&htim->Instance->ARR, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + + /* Enable the TIM Update DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_UPDATE); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Base generation in DMA mode. + * @param htim TIM Base handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Base_Stop_DMA(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_DMA_INSTANCE(htim->Instance)); + + /* Disable the TIM Update DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_UPDATE); + + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_UPDATE]); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group2 TIM Output Compare functions + * @brief TIM Output Compare functions + * +@verbatim + ============================================================================== + ##### TIM Output Compare functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and configure the TIM Output Compare. + (+) De-initialize the TIM Output Compare. + (+) Start the TIM Output Compare. + (+) Stop the TIM Output Compare. + (+) Start the TIM Output Compare and enable interrupt. + (+) Stop the TIM Output Compare and disable interrupt. + (+) Start the TIM Output Compare and enable DMA transfer. + (+) Stop the TIM Output Compare and disable DMA transfer. + +@endverbatim + * @{ + */ +/** + * @brief Initializes the TIM Output Compare according to the specified + * parameters in the TIM_HandleTypeDef and initializes the associated handle. + * @note Switching from Center Aligned counter mode to Edge counter mode (or reverse) + * requires a timer reset to avoid unexpected direction + * due to DIR bit readonly in center aligned mode. + * Ex: call @ref HAL_TIM_OC_DeInit() before HAL_TIM_OC_Init() + * @param htim TIM Output Compare handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_Init(TIM_HandleTypeDef *htim) +{ + /* Check the TIM handle allocation */ + if (htim == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode)); + assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); + assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); + + if (htim->State == HAL_TIM_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htim->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + /* Reset interrupt callbacks to legacy weak callbacks */ + TIM_ResetCallback(htim); + + if (htim->OC_MspInitCallback == NULL) + { + htim->OC_MspInitCallback = HAL_TIM_OC_MspInit; + } + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + htim->OC_MspInitCallback(htim); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_OC_MspInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Init the base time for the Output Compare */ + TIM_Base_SetConfig(htim->Instance, &htim->Init); + + /* Initialize the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + + /* Initialize the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + + /* Initialize the TIM state*/ + htim->State = HAL_TIM_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the TIM peripheral + * @param htim TIM Output Compare handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_DeInit(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Disable the TIM Peripheral Clock */ + __HAL_TIM_DISABLE(htim); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + if (htim->OC_MspDeInitCallback == NULL) + { + htim->OC_MspDeInitCallback = HAL_TIM_OC_MspDeInit; + } + /* DeInit the low level hardware */ + htim->OC_MspDeInitCallback(htim); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_OC_MspDeInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_RESET; + + /* Change the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + + /* Change TIM state */ + htim->State = HAL_TIM_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Initializes the TIM Output Compare MSP. + * @param htim TIM Output Compare handle + * @retval None + */ +__weak void HAL_TIM_OC_MspInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_OC_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes TIM Output Compare MSP. + * @param htim TIM Output Compare handle + * @retval None + */ +__weak void HAL_TIM_OC_MspDeInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_OC_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief Starts the TIM Output Compare signal generation. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_Start(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM channel state */ + if (TIM_CHANNEL_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the Output compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Output Compare signal generation. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Disable the Output compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Output Compare signal generation in interrupt mode. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM channel state */ + if (TIM_CHANNEL_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Enable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Enable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Enable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Enable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the Output compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM Output Compare signal generation in interrupt mode. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Disable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Output compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @brief Starts the TIM Output Compare signal generation in DMA mode. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @param pData The source Buffer address. + * @param Length The length of data to be transferred from memory to TIM peripheral + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Set the TIM channel state */ + if (TIM_CHANNEL_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_BUSY) + { + return HAL_BUSY; + } + else if (TIM_CHANNEL_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY) + { + if ((pData == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + + /* Enable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + + /* Enable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 3 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC4]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC4]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC4]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC4], (uint32_t)pData, (uint32_t)&htim->Instance->CCR4, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 4 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the Output compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM Output Compare signal generation in DMA mode. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC2); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC3); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC3]); + break; + } + + case TIM_CHANNEL_4: + { + /* Disable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC4); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC4]); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Output compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group3 TIM PWM functions + * @brief TIM PWM functions + * +@verbatim + ============================================================================== + ##### TIM PWM functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and configure the TIM PWM. + (+) De-initialize the TIM PWM. + (+) Start the TIM PWM. + (+) Stop the TIM PWM. + (+) Start the TIM PWM and enable interrupt. + (+) Stop the TIM PWM and disable interrupt. + (+) Start the TIM PWM and enable DMA transfer. + (+) Stop the TIM PWM and disable DMA transfer. + +@endverbatim + * @{ + */ +/** + * @brief Initializes the TIM PWM Time Base according to the specified + * parameters in the TIM_HandleTypeDef and initializes the associated handle. + * @note Switching from Center Aligned counter mode to Edge counter mode (or reverse) + * requires a timer reset to avoid unexpected direction + * due to DIR bit readonly in center aligned mode. + * Ex: call @ref HAL_TIM_PWM_DeInit() before HAL_TIM_PWM_Init() + * @param htim TIM PWM handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_Init(TIM_HandleTypeDef *htim) +{ + /* Check the TIM handle allocation */ + if (htim == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode)); + assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); + assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); + + if (htim->State == HAL_TIM_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htim->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + /* Reset interrupt callbacks to legacy weak callbacks */ + TIM_ResetCallback(htim); + + if (htim->PWM_MspInitCallback == NULL) + { + htim->PWM_MspInitCallback = HAL_TIM_PWM_MspInit; + } + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + htim->PWM_MspInitCallback(htim); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_PWM_MspInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Init the base time for the PWM */ + TIM_Base_SetConfig(htim->Instance, &htim->Init); + + /* Initialize the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + + /* Initialize the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + + /* Initialize the TIM state*/ + htim->State = HAL_TIM_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the TIM peripheral + * @param htim TIM PWM handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_DeInit(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Disable the TIM Peripheral Clock */ + __HAL_TIM_DISABLE(htim); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + if (htim->PWM_MspDeInitCallback == NULL) + { + htim->PWM_MspDeInitCallback = HAL_TIM_PWM_MspDeInit; + } + /* DeInit the low level hardware */ + htim->PWM_MspDeInitCallback(htim); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_PWM_MspDeInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_RESET; + + /* Change the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + + /* Change TIM state */ + htim->State = HAL_TIM_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Initializes the TIM PWM MSP. + * @param htim TIM PWM handle + * @retval None + */ +__weak void HAL_TIM_PWM_MspInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_PWM_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes TIM PWM MSP. + * @param htim TIM PWM handle + * @retval None + */ +__weak void HAL_TIM_PWM_MspDeInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_PWM_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief Starts the PWM signal generation. + * @param htim TIM handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_Start(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM channel state */ + if (TIM_CHANNEL_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the PWM signal generation. + * @param htim TIM PWM handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Disable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the PWM signal generation in interrupt mode. + * @param htim TIM PWM handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM channel state */ + if (TIM_CHANNEL_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Enable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Enable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Enable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Enable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the PWM signal generation in interrupt mode. + * @param htim TIM PWM handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Disable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @brief Starts the TIM PWM signal generation in DMA mode. + * @param htim TIM PWM handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @param pData The source Buffer address. + * @param Length The length of data to be transferred from memory to TIM peripheral + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Set the TIM channel state */ + if (TIM_CHANNEL_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_BUSY) + { + return HAL_BUSY; + } + else if (TIM_CHANNEL_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY) + { + if ((pData == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + + /* Enable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Output Capture/Compare 3 request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC4]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC4]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC4]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC4], (uint32_t)pData, (uint32_t)&htim->Instance->CCR4, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 4 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM PWM signal generation in DMA mode. + * @param htim TIM PWM handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC2); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC3); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC3]); + break; + } + + case TIM_CHANNEL_4: + { + /* Disable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC4); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC4]); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group4 TIM Input Capture functions + * @brief TIM Input Capture functions + * +@verbatim + ============================================================================== + ##### TIM Input Capture functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and configure the TIM Input Capture. + (+) De-initialize the TIM Input Capture. + (+) Start the TIM Input Capture. + (+) Stop the TIM Input Capture. + (+) Start the TIM Input Capture and enable interrupt. + (+) Stop the TIM Input Capture and disable interrupt. + (+) Start the TIM Input Capture and enable DMA transfer. + (+) Stop the TIM Input Capture and disable DMA transfer. + +@endverbatim + * @{ + */ +/** + * @brief Initializes the TIM Input Capture Time base according to the specified + * parameters in the TIM_HandleTypeDef and initializes the associated handle. + * @note Switching from Center Aligned counter mode to Edge counter mode (or reverse) + * requires a timer reset to avoid unexpected direction + * due to DIR bit readonly in center aligned mode. + * Ex: call @ref HAL_TIM_IC_DeInit() before HAL_TIM_IC_Init() + * @param htim TIM Input Capture handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_Init(TIM_HandleTypeDef *htim) +{ + /* Check the TIM handle allocation */ + if (htim == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode)); + assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); + assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); + + if (htim->State == HAL_TIM_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htim->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + /* Reset interrupt callbacks to legacy weak callbacks */ + TIM_ResetCallback(htim); + + if (htim->IC_MspInitCallback == NULL) + { + htim->IC_MspInitCallback = HAL_TIM_IC_MspInit; + } + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + htim->IC_MspInitCallback(htim); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_IC_MspInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Init the base time for the input capture */ + TIM_Base_SetConfig(htim->Instance, &htim->Init); + + /* Initialize the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + + /* Initialize the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY); + + /* Initialize the TIM state*/ + htim->State = HAL_TIM_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the TIM peripheral + * @param htim TIM Input Capture handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_DeInit(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Disable the TIM Peripheral Clock */ + __HAL_TIM_DISABLE(htim); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + if (htim->IC_MspDeInitCallback == NULL) + { + htim->IC_MspDeInitCallback = HAL_TIM_IC_MspDeInit; + } + /* DeInit the low level hardware */ + htim->IC_MspDeInitCallback(htim); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_IC_MspDeInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_RESET; + + /* Change the TIM channels state */ + TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_RESET); + + /* Change TIM state */ + htim->State = HAL_TIM_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Initializes the TIM Input Capture MSP. + * @param htim TIM Input Capture handle + * @retval None + */ +__weak void HAL_TIM_IC_MspInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_IC_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes TIM Input Capture MSP. + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_IC_MspDeInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_IC_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief Starts the TIM Input Capture measurement. + * @param htim TIM Input Capture handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_Start(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + uint32_t tmpsmcr; + HAL_TIM_ChannelStateTypeDef channel_state = TIM_CHANNEL_STATE_GET(htim, Channel); + HAL_TIM_ChannelStateTypeDef complementary_channel_state = TIM_CHANNEL_N_STATE_GET(htim, Channel); + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM channel state */ + if ((channel_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the Input Capture channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Input Capture measurement. + * @param htim TIM Input Capture handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Disable the Input Capture channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Input Capture measurement in interrupt mode. + * @param htim TIM Input Capture handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + HAL_TIM_ChannelStateTypeDef channel_state = TIM_CHANNEL_STATE_GET(htim, Channel); + HAL_TIM_ChannelStateTypeDef complementary_channel_state = TIM_CHANNEL_N_STATE_GET(htim, Channel); + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM channel state */ + if ((channel_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Enable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Enable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Enable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Enable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the Input Capture channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM Input Capture measurement in interrupt mode. + * @param htim TIM Input Capture handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Disable the TIM Capture/Compare 4 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Input Capture channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @brief Starts the TIM Input Capture measurement in DMA mode. + * @param htim TIM Input Capture handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @param pData The destination Buffer address. + * @param Length The length of data to be transferred from TIM peripheral to memory. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + HAL_TIM_ChannelStateTypeDef channel_state = TIM_CHANNEL_STATE_GET(htim, Channel); + HAL_TIM_ChannelStateTypeDef complementary_channel_state = TIM_CHANNEL_N_STATE_GET(htim, Channel); + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + assert_param(IS_TIM_DMA_CC_INSTANCE(htim->Instance)); + + /* Set the TIM channel state */ + if ((channel_state == HAL_TIM_CHANNEL_STATE_BUSY) + || (complementary_channel_state == HAL_TIM_CHANNEL_STATE_BUSY)) + { + return HAL_BUSY; + } + else if ((channel_state == HAL_TIM_CHANNEL_STATE_READY) + && (complementary_channel_state == HAL_TIM_CHANNEL_STATE_READY)) + { + if ((pData == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + + /* Enable the Input Capture channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)&htim->Instance->CCR1, (uint32_t)pData, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)&htim->Instance->CCR2, (uint32_t)pData, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)&htim->Instance->CCR3, (uint32_t)pData, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 3 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC3); + break; + } + + case TIM_CHANNEL_4: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC4]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC4]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC4]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC4], (uint32_t)&htim->Instance->CCR4, (uint32_t)pData, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 4 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC4); + break; + } + + default: + status = HAL_ERROR; + break; + } + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM Input Capture measurement in DMA mode. + * @param htim TIM Input Capture handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + assert_param(IS_TIM_DMA_CC_INSTANCE(htim->Instance)); + + /* Disable the Input Capture channel */ + TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC2); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC3); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC3]); + break; + } + + case TIM_CHANNEL_4: + { + /* Disable the TIM Capture/Compare 4 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC4); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC4]); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group5 TIM One Pulse functions + * @brief TIM One Pulse functions + * +@verbatim + ============================================================================== + ##### TIM One Pulse functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and configure the TIM One Pulse. + (+) De-initialize the TIM One Pulse. + (+) Start the TIM One Pulse. + (+) Stop the TIM One Pulse. + (+) Start the TIM One Pulse and enable interrupt. + (+) Stop the TIM One Pulse and disable interrupt. + (+) Start the TIM One Pulse and enable DMA transfer. + (+) Stop the TIM One Pulse and disable DMA transfer. + +@endverbatim + * @{ + */ +/** + * @brief Initializes the TIM One Pulse Time Base according to the specified + * parameters in the TIM_HandleTypeDef and initializes the associated handle. + * @note Switching from Center Aligned counter mode to Edge counter mode (or reverse) + * requires a timer reset to avoid unexpected direction + * due to DIR bit readonly in center aligned mode. + * Ex: call @ref HAL_TIM_OnePulse_DeInit() before HAL_TIM_OnePulse_Init() + * @note When the timer instance is initialized in One Pulse mode, timer + * channels 1 and channel 2 are reserved and cannot be used for other + * purpose. + * @param htim TIM One Pulse handle + * @param OnePulseMode Select the One pulse mode. + * This parameter can be one of the following values: + * @arg TIM_OPMODE_SINGLE: Only one pulse will be generated. + * @arg TIM_OPMODE_REPETITIVE: Repetitive pulses will be generated. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OnePulse_Init(TIM_HandleTypeDef *htim, uint32_t OnePulseMode) +{ + /* Check the TIM handle allocation */ + if (htim == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode)); + assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); + assert_param(IS_TIM_OPM_MODE(OnePulseMode)); + assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); + + if (htim->State == HAL_TIM_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htim->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + /* Reset interrupt callbacks to legacy weak callbacks */ + TIM_ResetCallback(htim); + + if (htim->OnePulse_MspInitCallback == NULL) + { + htim->OnePulse_MspInitCallback = HAL_TIM_OnePulse_MspInit; + } + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + htim->OnePulse_MspInitCallback(htim); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_OnePulse_MspInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Configure the Time base in the One Pulse Mode */ + TIM_Base_SetConfig(htim->Instance, &htim->Init); + + /* Reset the OPM Bit */ + htim->Instance->CR1 &= ~TIM_CR1_OPM; + + /* Configure the OPM Mode */ + htim->Instance->CR1 |= OnePulseMode; + + /* Initialize the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + + /* Initialize the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Initialize the TIM state*/ + htim->State = HAL_TIM_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the TIM One Pulse + * @param htim TIM One Pulse handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OnePulse_DeInit(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Disable the TIM Peripheral Clock */ + __HAL_TIM_DISABLE(htim); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + if (htim->OnePulse_MspDeInitCallback == NULL) + { + htim->OnePulse_MspDeInitCallback = HAL_TIM_OnePulse_MspDeInit; + } + /* DeInit the low level hardware */ + htim->OnePulse_MspDeInitCallback(htim); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + HAL_TIM_OnePulse_MspDeInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_RESET; + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET); + + /* Change TIM state */ + htim->State = HAL_TIM_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Initializes the TIM One Pulse MSP. + * @param htim TIM One Pulse handle + * @retval None + */ +__weak void HAL_TIM_OnePulse_MspInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_OnePulse_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes TIM One Pulse MSP. + * @param htim TIM One Pulse handle + * @retval None + */ +__weak void HAL_TIM_OnePulse_MspDeInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_OnePulse_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief Starts the TIM One Pulse signal generation. + * @note Though OutputChannel parameter is deprecated and ignored by the function + * it has been kept to avoid HAL_TIM API compatibility break. + * @note The pulse output channel is determined when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel See note above + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OnePulse_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Prevent unused argument(s) compilation warning */ + UNUSED(OutputChannel); + + /* Check the TIM channels state */ + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the Capture compare and the Input Capture channels + (in the OPM Mode the two possible channels that can be used are TIM_CHANNEL_1 and TIM_CHANNEL_2) + if TIM_CHANNEL_1 is used as output, the TIM_CHANNEL_2 will be used as input and + if TIM_CHANNEL_1 is used as input, the TIM_CHANNEL_2 will be used as output + whatever the combination, the TIM_CHANNEL_1 and TIM_CHANNEL_2 should be enabled together + + No need to enable the counter, it's enabled automatically by hardware + (the counter starts in response to a stimulus and generate a pulse */ + + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM One Pulse signal generation. + * @note Though OutputChannel parameter is deprecated and ignored by the function + * it has been kept to avoid HAL_TIM API compatibility break. + * @note The pulse output channel is determined when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel See note above + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OnePulse_Stop(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(OutputChannel); + + /* Disable the Capture compare and the Input Capture channels + (in the OPM Mode the two possible channels that can be used are TIM_CHANNEL_1 and TIM_CHANNEL_2) + if TIM_CHANNEL_1 is used as output, the TIM_CHANNEL_2 will be used as input and + if TIM_CHANNEL_1 is used as input, the TIM_CHANNEL_2 will be used as output + whatever the combination, the TIM_CHANNEL_1 and TIM_CHANNEL_2 should be disabled together */ + + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM One Pulse signal generation in interrupt mode. + * @note Though OutputChannel parameter is deprecated and ignored by the function + * it has been kept to avoid HAL_TIM API compatibility break. + * @note The pulse output channel is determined when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel See note above + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OnePulse_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Prevent unused argument(s) compilation warning */ + UNUSED(OutputChannel); + + /* Check the TIM channels state */ + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the Capture compare and the Input Capture channels + (in the OPM Mode the two possible channels that can be used are TIM_CHANNEL_1 and TIM_CHANNEL_2) + if TIM_CHANNEL_1 is used as output, the TIM_CHANNEL_2 will be used as input and + if TIM_CHANNEL_1 is used as input, the TIM_CHANNEL_2 will be used as output + whatever the combination, the TIM_CHANNEL_1 and TIM_CHANNEL_2 should be enabled together + + No need to enable the counter, it's enabled automatically by hardware + (the counter starts in response to a stimulus and generate a pulse */ + + /* Enable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + + /* Enable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Enable the main output */ + __HAL_TIM_MOE_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM One Pulse signal generation in interrupt mode. + * @note Though OutputChannel parameter is deprecated and ignored by the function + * it has been kept to avoid HAL_TIM API compatibility break. + * @note The pulse output channel is determined when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel See note above + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OnePulse_Stop_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(OutputChannel); + + /* Disable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + + /* Disable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + + /* Disable the Capture compare and the Input Capture channels + (in the OPM Mode the two possible channels that can be used are TIM_CHANNEL_1 and TIM_CHANNEL_2) + if TIM_CHANNEL_1 is used as output, the TIM_CHANNEL_2 will be used as input and + if TIM_CHANNEL_1 is used as input, the TIM_CHANNEL_2 will be used as output + whatever the combination, the TIM_CHANNEL_1 and TIM_CHANNEL_2 should be disabled together */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + + if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET) + { + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group6 TIM Encoder functions + * @brief TIM Encoder functions + * +@verbatim + ============================================================================== + ##### TIM Encoder functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and configure the TIM Encoder. + (+) De-initialize the TIM Encoder. + (+) Start the TIM Encoder. + (+) Stop the TIM Encoder. + (+) Start the TIM Encoder and enable interrupt. + (+) Stop the TIM Encoder and disable interrupt. + (+) Start the TIM Encoder and enable DMA transfer. + (+) Stop the TIM Encoder and disable DMA transfer. + +@endverbatim + * @{ + */ +/** + * @brief Initializes the TIM Encoder Interface and initialize the associated handle. + * @note Switching from Center Aligned counter mode to Edge counter mode (or reverse) + * requires a timer reset to avoid unexpected direction + * due to DIR bit readonly in center aligned mode. + * Ex: call @ref HAL_TIM_Encoder_DeInit() before HAL_TIM_Encoder_Init() + * @note Encoder mode and External clock mode 2 are not compatible and must not be selected together + * Ex: A call for @ref HAL_TIM_Encoder_Init will erase the settings of @ref HAL_TIM_ConfigClockSource + * using TIM_CLOCKSOURCE_ETRMODE2 and vice versa + * @note When the timer instance is initialized in Encoder mode, timer + * channels 1 and channel 2 are reserved and cannot be used for other + * purpose. + * @param htim TIM Encoder Interface handle + * @param sConfig TIM Encoder Interface configuration structure + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_Init(TIM_HandleTypeDef *htim, TIM_Encoder_InitTypeDef *sConfig) +{ + uint32_t tmpsmcr; + uint32_t tmpccmr1; + uint32_t tmpccer; + + /* Check the TIM handle allocation */ + if (htim == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(htim->Instance)); + assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode)); + assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); + assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); + assert_param(IS_TIM_ENCODER_MODE(sConfig->EncoderMode)); + assert_param(IS_TIM_IC_SELECTION(sConfig->IC1Selection)); + assert_param(IS_TIM_IC_SELECTION(sConfig->IC2Selection)); + assert_param(IS_TIM_ENCODERINPUT_POLARITY(sConfig->IC1Polarity)); + assert_param(IS_TIM_ENCODERINPUT_POLARITY(sConfig->IC2Polarity)); + assert_param(IS_TIM_IC_PRESCALER(sConfig->IC1Prescaler)); + assert_param(IS_TIM_IC_PRESCALER(sConfig->IC2Prescaler)); + assert_param(IS_TIM_IC_FILTER(sConfig->IC1Filter)); + assert_param(IS_TIM_IC_FILTER(sConfig->IC2Filter)); + + if (htim->State == HAL_TIM_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htim->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + /* Reset interrupt callbacks to legacy weak callbacks */ + TIM_ResetCallback(htim); + + if (htim->Encoder_MspInitCallback == NULL) + { + htim->Encoder_MspInitCallback = HAL_TIM_Encoder_MspInit; + } + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + htim->Encoder_MspInitCallback(htim); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */ + HAL_TIM_Encoder_MspInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Reset the SMS and ECE bits */ + htim->Instance->SMCR &= ~(TIM_SMCR_SMS | TIM_SMCR_ECE); + + /* Configure the Time base in the Encoder Mode */ + TIM_Base_SetConfig(htim->Instance, &htim->Init); + + /* Get the TIMx SMCR register value */ + tmpsmcr = htim->Instance->SMCR; + + /* Get the TIMx CCMR1 register value */ + tmpccmr1 = htim->Instance->CCMR1; + + /* Get the TIMx CCER register value */ + tmpccer = htim->Instance->CCER; + + /* Set the encoder Mode */ + tmpsmcr |= sConfig->EncoderMode; + + /* Select the Capture Compare 1 and the Capture Compare 2 as input */ + tmpccmr1 &= ~(TIM_CCMR1_CC1S | TIM_CCMR1_CC2S); + tmpccmr1 |= (sConfig->IC1Selection | (sConfig->IC2Selection << 8U)); + + /* Set the Capture Compare 1 and the Capture Compare 2 prescalers and filters */ + tmpccmr1 &= ~(TIM_CCMR1_IC1PSC | TIM_CCMR1_IC2PSC); + tmpccmr1 &= ~(TIM_CCMR1_IC1F | TIM_CCMR1_IC2F); + tmpccmr1 |= sConfig->IC1Prescaler | (sConfig->IC2Prescaler << 8U); + tmpccmr1 |= (sConfig->IC1Filter << 4U) | (sConfig->IC2Filter << 12U); + + /* Set the TI1 and the TI2 Polarities */ + tmpccer &= ~(TIM_CCER_CC1P | TIM_CCER_CC2P); + tmpccer &= ~(TIM_CCER_CC1NP | TIM_CCER_CC2NP); + tmpccer |= sConfig->IC1Polarity | (sConfig->IC2Polarity << 4U); + + /* Write to TIMx SMCR */ + htim->Instance->SMCR = tmpsmcr; + + /* Write to TIMx CCMR1 */ + htim->Instance->CCMR1 = tmpccmr1; + + /* Write to TIMx CCER */ + htim->Instance->CCER = tmpccer; + + /* Initialize the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Initialize the TIM state*/ + htim->State = HAL_TIM_STATE_READY; + + return HAL_OK; +} + + +/** + * @brief DeInitializes the TIM Encoder interface + * @param htim TIM Encoder Interface handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_DeInit(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Disable the TIM Peripheral Clock */ + __HAL_TIM_DISABLE(htim); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + if (htim->Encoder_MspDeInitCallback == NULL) + { + htim->Encoder_MspDeInitCallback = HAL_TIM_Encoder_MspDeInit; + } + /* DeInit the low level hardware */ + htim->Encoder_MspDeInitCallback(htim); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + HAL_TIM_Encoder_MspDeInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_RESET; + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET); + + /* Change TIM state */ + htim->State = HAL_TIM_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Initializes the TIM Encoder Interface MSP. + * @param htim TIM Encoder Interface handle + * @retval None + */ +__weak void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_Encoder_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes TIM Encoder Interface MSP. + * @param htim TIM Encoder Interface handle + * @retval None + */ +__weak void HAL_TIM_Encoder_MspDeInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_Encoder_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief Starts the TIM Encoder Interface. + * @param htim TIM Encoder Interface handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_ALL: TIM Channel 1 and TIM Channel 2 are selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_Start(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(htim->Instance)); + + /* Set the TIM channel(s) state */ + if (Channel == TIM_CHANNEL_1) + { + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else if (Channel == TIM_CHANNEL_2) + { + if ((channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + + /* Enable the encoder interface channels */ + switch (Channel) + { + case TIM_CHANNEL_1: + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + break; + } + + case TIM_CHANNEL_2: + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + break; + } + + default : + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + break; + } + } + /* Enable the Peripheral */ + __HAL_TIM_ENABLE(htim); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Encoder Interface. + * @param htim TIM Encoder Interface handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_ALL: TIM Channel 1 and TIM Channel 2 are selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(htim->Instance)); + + /* Disable the Input Capture channels 1 and 2 + (in the EncoderInterface the two possible channels that can be used are TIM_CHANNEL_1 and TIM_CHANNEL_2) */ + switch (Channel) + { + case TIM_CHANNEL_1: + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + break; + } + + case TIM_CHANNEL_2: + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + break; + } + + default : + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + break; + } + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel(s) state */ + if ((Channel == TIM_CHANNEL_1) || (Channel == TIM_CHANNEL_2)) + { + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Encoder Interface in interrupt mode. + * @param htim TIM Encoder Interface handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_ALL: TIM Channel 1 and TIM Channel 2 are selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(htim->Instance)); + + /* Set the TIM channel(s) state */ + if (Channel == TIM_CHANNEL_1) + { + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else if (Channel == TIM_CHANNEL_2) + { + if ((channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + + /* Enable the encoder interface channels */ + /* Enable the capture compare Interrupts 1 and/or 2 */ + switch (Channel) + { + case TIM_CHANNEL_1: + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + break; + } + + default : + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + break; + } + } + + /* Enable the Peripheral */ + __HAL_TIM_ENABLE(htim); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Encoder Interface in interrupt mode. + * @param htim TIM Encoder Interface handle + * @param Channel TIM Channels to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_ALL: TIM Channel 1 and TIM Channel 2 are selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(htim->Instance)); + + /* Disable the Input Capture channels 1 and 2 + (in the EncoderInterface the two possible channels that can be used are TIM_CHANNEL_1 and TIM_CHANNEL_2) */ + if (Channel == TIM_CHANNEL_1) + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + + /* Disable the capture compare Interrupts 1 */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + } + else if (Channel == TIM_CHANNEL_2) + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + + /* Disable the capture compare Interrupts 2 */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + } + else + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + + /* Disable the capture compare Interrupts 1 and 2 */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel(s) state */ + if ((Channel == TIM_CHANNEL_1) || (Channel == TIM_CHANNEL_2)) + { + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Encoder Interface in DMA mode. + * @param htim TIM Encoder Interface handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_ALL: TIM Channel 1 and TIM Channel 2 are selected + * @param pData1 The destination Buffer address for IC1. + * @param pData2 The destination Buffer address for IC2. + * @param Length The length of data to be transferred from TIM peripheral to memory. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData1, + uint32_t *pData2, uint16_t Length) +{ + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(htim->Instance)); + + /* Set the TIM channel(s) state */ + if (Channel == TIM_CHANNEL_1) + { + if ((channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY) + || (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY)) + { + return HAL_BUSY; + } + else if ((channel_1_state == HAL_TIM_CHANNEL_STATE_READY) + && (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_READY)) + { + if ((pData1 == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + } + else if (Channel == TIM_CHANNEL_2) + { + if ((channel_2_state == HAL_TIM_CHANNEL_STATE_BUSY) + || (complementary_channel_2_state == HAL_TIM_CHANNEL_STATE_BUSY)) + { + return HAL_BUSY; + } + else if ((channel_2_state == HAL_TIM_CHANNEL_STATE_READY) + && (complementary_channel_2_state == HAL_TIM_CHANNEL_STATE_READY)) + { + if ((pData2 == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + } + else + { + if ((channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY) + || (channel_2_state == HAL_TIM_CHANNEL_STATE_BUSY) + || (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY) + || (complementary_channel_2_state == HAL_TIM_CHANNEL_STATE_BUSY)) + { + return HAL_BUSY; + } + else if ((channel_1_state == HAL_TIM_CHANNEL_STATE_READY) + && (channel_2_state == HAL_TIM_CHANNEL_STATE_READY) + && (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_READY) + && (complementary_channel_2_state == HAL_TIM_CHANNEL_STATE_READY)) + { + if ((((pData1 == NULL) || (pData2 == NULL))) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + } + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)&htim->Instance->CCR1, (uint32_t)pData1, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Input Capture DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + + /* Enable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + + /* Enable the Peripheral */ + __HAL_TIM_ENABLE(htim); + + break; + } + + case TIM_CHANNEL_2: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError; + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)&htim->Instance->CCR2, (uint32_t)pData2, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Input Capture DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC2); + + /* Enable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + + /* Enable the Peripheral */ + __HAL_TIM_ENABLE(htim); + + break; + } + + default: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)&htim->Instance->CCR1, (uint32_t)pData1, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)&htim->Instance->CCR2, (uint32_t)pData2, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + + /* Enable the TIM Input Capture DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + /* Enable the TIM Input Capture DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC2); + + /* Enable the Capture compare channel */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_ENABLE); + + /* Enable the Peripheral */ + __HAL_TIM_ENABLE(htim); + + break; + } + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Encoder Interface in DMA mode. + * @param htim TIM Encoder Interface handle + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_ALL: TIM Channel 1 and TIM Channel 2 are selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_Encoder_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(htim->Instance)); + + /* Disable the Input Capture channels 1 and 2 + (in the EncoderInterface the two possible channels that can be used are TIM_CHANNEL_1 and TIM_CHANNEL_2) */ + if (Channel == TIM_CHANNEL_1) + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + + /* Disable the capture compare DMA Request 1 */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + } + else if (Channel == TIM_CHANNEL_2) + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + + /* Disable the capture compare DMA Request 2 */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC2); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + } + else + { + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_2, TIM_CCx_DISABLE); + + /* Disable the capture compare DMA Request 1 and 2 */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC2); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + } + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel(s) state */ + if ((Channel == TIM_CHANNEL_1) || (Channel == TIM_CHANNEL_2)) + { + TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @} + */ +/** @defgroup TIM_Exported_Functions_Group7 TIM IRQ handler management + * @brief TIM IRQ handler management + * +@verbatim + ============================================================================== + ##### IRQ handler management ##### + ============================================================================== + [..] + This section provides Timer IRQ handler function. + +@endverbatim + * @{ + */ +/** + * @brief This function handles TIM interrupts requests. + * @param htim TIM handle + * @retval None + */ +void HAL_TIM_IRQHandler(TIM_HandleTypeDef *htim) +{ + /* Capture compare 1 event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_CC1) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_CC1) != RESET) + { + { + __HAL_TIM_CLEAR_IT(htim, TIM_IT_CC1); + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + + /* Input capture event */ + if ((htim->Instance->CCMR1 & TIM_CCMR1_CC1S) != 0x00U) + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->IC_CaptureCallback(htim); +#else + HAL_TIM_IC_CaptureCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + /* Output compare event */ + else + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->OC_DelayElapsedCallback(htim); + htim->PWM_PulseFinishedCallback(htim); +#else + HAL_TIM_OC_DelayElapsedCallback(htim); + HAL_TIM_PWM_PulseFinishedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; + } + } + } + /* Capture compare 2 event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_CC2) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_CC2) != RESET) + { + __HAL_TIM_CLEAR_IT(htim, TIM_IT_CC2); + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + /* Input capture event */ + if ((htim->Instance->CCMR1 & TIM_CCMR1_CC2S) != 0x00U) + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->IC_CaptureCallback(htim); +#else + HAL_TIM_IC_CaptureCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + /* Output compare event */ + else + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->OC_DelayElapsedCallback(htim); + htim->PWM_PulseFinishedCallback(htim); +#else + HAL_TIM_OC_DelayElapsedCallback(htim); + HAL_TIM_PWM_PulseFinishedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; + } + } + /* Capture compare 3 event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_CC3) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_CC3) != RESET) + { + __HAL_TIM_CLEAR_IT(htim, TIM_IT_CC3); + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + /* Input capture event */ + if ((htim->Instance->CCMR2 & TIM_CCMR2_CC3S) != 0x00U) + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->IC_CaptureCallback(htim); +#else + HAL_TIM_IC_CaptureCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + /* Output compare event */ + else + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->OC_DelayElapsedCallback(htim); + htim->PWM_PulseFinishedCallback(htim); +#else + HAL_TIM_OC_DelayElapsedCallback(htim); + HAL_TIM_PWM_PulseFinishedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; + } + } + /* Capture compare 4 event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_CC4) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_CC4) != RESET) + { + __HAL_TIM_CLEAR_IT(htim, TIM_IT_CC4); + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; + /* Input capture event */ + if ((htim->Instance->CCMR2 & TIM_CCMR2_CC4S) != 0x00U) + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->IC_CaptureCallback(htim); +#else + HAL_TIM_IC_CaptureCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + /* Output compare event */ + else + { +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->OC_DelayElapsedCallback(htim); + htim->PWM_PulseFinishedCallback(htim); +#else + HAL_TIM_OC_DelayElapsedCallback(htim); + HAL_TIM_PWM_PulseFinishedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; + } + } + /* TIM Update event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_UPDATE) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_UPDATE) != RESET) + { + __HAL_TIM_CLEAR_IT(htim, TIM_IT_UPDATE); +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->PeriodElapsedCallback(htim); +#else + HAL_TIM_PeriodElapsedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + } + /* TIM Break input event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_BREAK) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_BREAK) != RESET) + { + __HAL_TIM_CLEAR_IT(htim, TIM_IT_BREAK); +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->BreakCallback(htim); +#else + HAL_TIMEx_BreakCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + } + /* TIM Trigger detection event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_TRIGGER) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_TRIGGER) != RESET) + { + __HAL_TIM_CLEAR_IT(htim, TIM_IT_TRIGGER); +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->TriggerCallback(htim); +#else + HAL_TIM_TriggerCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + } + /* TIM commutation event */ + if (__HAL_TIM_GET_FLAG(htim, TIM_FLAG_COM) != RESET) + { + if (__HAL_TIM_GET_IT_SOURCE(htim, TIM_IT_COM) != RESET) + { + __HAL_TIM_CLEAR_IT(htim, TIM_FLAG_COM); +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->CommutationCallback(htim); +#else + HAL_TIMEx_CommutCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + } +} + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group8 TIM Peripheral Control functions + * @brief TIM Peripheral Control functions + * +@verbatim + ============================================================================== + ##### Peripheral Control functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Configure The Input Output channels for OC, PWM, IC or One Pulse mode. + (+) Configure External Clock source. + (+) Configure Complementary channels, break features and dead time. + (+) Configure Master and the Slave synchronization. + (+) Configure the DMA Burst Mode. + +@endverbatim + * @{ + */ + +/** + * @brief Initializes the TIM Output Compare Channels according to the specified + * parameters in the TIM_OC_InitTypeDef. + * @param htim TIM Output Compare handle + * @param sConfig TIM Output Compare configuration structure + * @param Channel TIM Channels to configure + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OC_ConfigChannel(TIM_HandleTypeDef *htim, + TIM_OC_InitTypeDef *sConfig, + uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CHANNELS(Channel)); + assert_param(IS_TIM_OC_MODE(sConfig->OCMode)); + assert_param(IS_TIM_OC_POLARITY(sConfig->OCPolarity)); + + /* Process Locked */ + __HAL_LOCK(htim); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + + /* Configure the TIM Channel 1 in Output Compare */ + TIM_OC1_SetConfig(htim->Instance, sConfig); + break; + } + + case TIM_CHANNEL_2: + { + /* Check the parameters */ + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + + /* Configure the TIM Channel 2 in Output Compare */ + TIM_OC2_SetConfig(htim->Instance, sConfig); + break; + } + + case TIM_CHANNEL_3: + { + /* Check the parameters */ + assert_param(IS_TIM_CC3_INSTANCE(htim->Instance)); + + /* Configure the TIM Channel 3 in Output Compare */ + TIM_OC3_SetConfig(htim->Instance, sConfig); + break; + } + + case TIM_CHANNEL_4: + { + /* Check the parameters */ + assert_param(IS_TIM_CC4_INSTANCE(htim->Instance)); + + /* Configure the TIM Channel 4 in Output Compare */ + TIM_OC4_SetConfig(htim->Instance, sConfig); + break; + } + + default: + status = HAL_ERROR; + break; + } + + __HAL_UNLOCK(htim); + + return status; +} + +/** + * @brief Initializes the TIM Input Capture Channels according to the specified + * parameters in the TIM_IC_InitTypeDef. + * @param htim TIM IC handle + * @param sConfig TIM Input Capture configuration structure + * @param Channel TIM Channel to configure + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_IC_ConfigChannel(TIM_HandleTypeDef *htim, TIM_IC_InitTypeDef *sConfig, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + assert_param(IS_TIM_IC_POLARITY(sConfig->ICPolarity)); + assert_param(IS_TIM_IC_SELECTION(sConfig->ICSelection)); + assert_param(IS_TIM_IC_PRESCALER(sConfig->ICPrescaler)); + assert_param(IS_TIM_IC_FILTER(sConfig->ICFilter)); + + /* Process Locked */ + __HAL_LOCK(htim); + + if (Channel == TIM_CHANNEL_1) + { + /* TI1 Configuration */ + TIM_TI1_SetConfig(htim->Instance, + sConfig->ICPolarity, + sConfig->ICSelection, + sConfig->ICFilter); + + /* Reset the IC1PSC Bits */ + htim->Instance->CCMR1 &= ~TIM_CCMR1_IC1PSC; + + /* Set the IC1PSC value */ + htim->Instance->CCMR1 |= sConfig->ICPrescaler; + } + else if (Channel == TIM_CHANNEL_2) + { + /* TI2 Configuration */ + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + + TIM_TI2_SetConfig(htim->Instance, + sConfig->ICPolarity, + sConfig->ICSelection, + sConfig->ICFilter); + + /* Reset the IC2PSC Bits */ + htim->Instance->CCMR1 &= ~TIM_CCMR1_IC2PSC; + + /* Set the IC2PSC value */ + htim->Instance->CCMR1 |= (sConfig->ICPrescaler << 8U); + } + else if (Channel == TIM_CHANNEL_3) + { + /* TI3 Configuration */ + assert_param(IS_TIM_CC3_INSTANCE(htim->Instance)); + + TIM_TI3_SetConfig(htim->Instance, + sConfig->ICPolarity, + sConfig->ICSelection, + sConfig->ICFilter); + + /* Reset the IC3PSC Bits */ + htim->Instance->CCMR2 &= ~TIM_CCMR2_IC3PSC; + + /* Set the IC3PSC value */ + htim->Instance->CCMR2 |= sConfig->ICPrescaler; + } + else if (Channel == TIM_CHANNEL_4) + { + /* TI4 Configuration */ + assert_param(IS_TIM_CC4_INSTANCE(htim->Instance)); + + TIM_TI4_SetConfig(htim->Instance, + sConfig->ICPolarity, + sConfig->ICSelection, + sConfig->ICFilter); + + /* Reset the IC4PSC Bits */ + htim->Instance->CCMR2 &= ~TIM_CCMR2_IC4PSC; + + /* Set the IC4PSC value */ + htim->Instance->CCMR2 |= (sConfig->ICPrescaler << 8U); + } + else + { + status = HAL_ERROR; + } + + __HAL_UNLOCK(htim); + + return status; +} + +/** + * @brief Initializes the TIM PWM channels according to the specified + * parameters in the TIM_OC_InitTypeDef. + * @param htim TIM PWM handle + * @param sConfig TIM PWM configuration structure + * @param Channel TIM Channels to be configured + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_PWM_ConfigChannel(TIM_HandleTypeDef *htim, + TIM_OC_InitTypeDef *sConfig, + uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CHANNELS(Channel)); + assert_param(IS_TIM_PWM_MODE(sConfig->OCMode)); + assert_param(IS_TIM_OC_POLARITY(sConfig->OCPolarity)); + assert_param(IS_TIM_FAST_STATE(sConfig->OCFastMode)); + + /* Process Locked */ + __HAL_LOCK(htim); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + + /* Configure the Channel 1 in PWM mode */ + TIM_OC1_SetConfig(htim->Instance, sConfig); + + /* Set the Preload enable bit for channel1 */ + htim->Instance->CCMR1 |= TIM_CCMR1_OC1PE; + + /* Configure the Output Fast mode */ + htim->Instance->CCMR1 &= ~TIM_CCMR1_OC1FE; + htim->Instance->CCMR1 |= sConfig->OCFastMode; + break; + } + + case TIM_CHANNEL_2: + { + /* Check the parameters */ + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + + /* Configure the Channel 2 in PWM mode */ + TIM_OC2_SetConfig(htim->Instance, sConfig); + + /* Set the Preload enable bit for channel2 */ + htim->Instance->CCMR1 |= TIM_CCMR1_OC2PE; + + /* Configure the Output Fast mode */ + htim->Instance->CCMR1 &= ~TIM_CCMR1_OC2FE; + htim->Instance->CCMR1 |= sConfig->OCFastMode << 8U; + break; + } + + case TIM_CHANNEL_3: + { + /* Check the parameters */ + assert_param(IS_TIM_CC3_INSTANCE(htim->Instance)); + + /* Configure the Channel 3 in PWM mode */ + TIM_OC3_SetConfig(htim->Instance, sConfig); + + /* Set the Preload enable bit for channel3 */ + htim->Instance->CCMR2 |= TIM_CCMR2_OC3PE; + + /* Configure the Output Fast mode */ + htim->Instance->CCMR2 &= ~TIM_CCMR2_OC3FE; + htim->Instance->CCMR2 |= sConfig->OCFastMode; + break; + } + + case TIM_CHANNEL_4: + { + /* Check the parameters */ + assert_param(IS_TIM_CC4_INSTANCE(htim->Instance)); + + /* Configure the Channel 4 in PWM mode */ + TIM_OC4_SetConfig(htim->Instance, sConfig); + + /* Set the Preload enable bit for channel4 */ + htim->Instance->CCMR2 |= TIM_CCMR2_OC4PE; + + /* Configure the Output Fast mode */ + htim->Instance->CCMR2 &= ~TIM_CCMR2_OC4FE; + htim->Instance->CCMR2 |= sConfig->OCFastMode << 8U; + break; + } + + default: + status = HAL_ERROR; + break; + } + + __HAL_UNLOCK(htim); + + return status; +} + +/** + * @brief Initializes the TIM One Pulse Channels according to the specified + * parameters in the TIM_OnePulse_InitTypeDef. + * @param htim TIM One Pulse handle + * @param sConfig TIM One Pulse configuration structure + * @param OutputChannel TIM output channel to configure + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @param InputChannel TIM input Channel to configure + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @note To output a waveform with a minimum delay user can enable the fast + * mode by calling the @ref __HAL_TIM_ENABLE_OCxFAST macro. Then CCx + * output is forced in response to the edge detection on TIx input, + * without taking in account the comparison. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_OnePulse_ConfigChannel(TIM_HandleTypeDef *htim, TIM_OnePulse_InitTypeDef *sConfig, + uint32_t OutputChannel, uint32_t InputChannel) +{ + HAL_StatusTypeDef status = HAL_OK; + TIM_OC_InitTypeDef temp1; + + /* Check the parameters */ + assert_param(IS_TIM_OPM_CHANNELS(OutputChannel)); + assert_param(IS_TIM_OPM_CHANNELS(InputChannel)); + + if (OutputChannel != InputChannel) + { + /* Process Locked */ + __HAL_LOCK(htim); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Extract the Output compare configuration from sConfig structure */ + temp1.OCMode = sConfig->OCMode; + temp1.Pulse = sConfig->Pulse; + temp1.OCPolarity = sConfig->OCPolarity; + temp1.OCNPolarity = sConfig->OCNPolarity; + temp1.OCIdleState = sConfig->OCIdleState; + temp1.OCNIdleState = sConfig->OCNIdleState; + + switch (OutputChannel) + { + case TIM_CHANNEL_1: + { + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + + TIM_OC1_SetConfig(htim->Instance, &temp1); + break; + } + + case TIM_CHANNEL_2: + { + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + + TIM_OC2_SetConfig(htim->Instance, &temp1); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + switch (InputChannel) + { + case TIM_CHANNEL_1: + { + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + + TIM_TI1_SetConfig(htim->Instance, sConfig->ICPolarity, + sConfig->ICSelection, sConfig->ICFilter); + + /* Reset the IC1PSC Bits */ + htim->Instance->CCMR1 &= ~TIM_CCMR1_IC1PSC; + + /* Select the Trigger source */ + htim->Instance->SMCR &= ~TIM_SMCR_TS; + htim->Instance->SMCR |= TIM_TS_TI1FP1; + + /* Select the Slave Mode */ + htim->Instance->SMCR &= ~TIM_SMCR_SMS; + htim->Instance->SMCR |= TIM_SLAVEMODE_TRIGGER; + break; + } + + case TIM_CHANNEL_2: + { + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + + TIM_TI2_SetConfig(htim->Instance, sConfig->ICPolarity, + sConfig->ICSelection, sConfig->ICFilter); + + /* Reset the IC2PSC Bits */ + htim->Instance->CCMR1 &= ~TIM_CCMR1_IC2PSC; + + /* Select the Trigger source */ + htim->Instance->SMCR &= ~TIM_SMCR_TS; + htim->Instance->SMCR |= TIM_TS_TI2FP2; + + /* Select the Slave Mode */ + htim->Instance->SMCR &= ~TIM_SMCR_SMS; + htim->Instance->SMCR |= TIM_SLAVEMODE_TRIGGER; + break; + } + + default: + status = HAL_ERROR; + break; + } + } + + htim->State = HAL_TIM_STATE_READY; + + __HAL_UNLOCK(htim); + + return status; + } + else + { + return HAL_ERROR; + } +} + +/** + * @brief Configure the DMA Burst to transfer Data from the memory to the TIM peripheral + * @param htim TIM handle + * @param BurstBaseAddress TIM Base address from where the DMA will start the Data write + * This parameter can be one of the following values: + * @arg TIM_DMABASE_CR1 + * @arg TIM_DMABASE_CR2 + * @arg TIM_DMABASE_SMCR + * @arg TIM_DMABASE_DIER + * @arg TIM_DMABASE_SR + * @arg TIM_DMABASE_EGR + * @arg TIM_DMABASE_CCMR1 + * @arg TIM_DMABASE_CCMR2 + * @arg TIM_DMABASE_CCER + * @arg TIM_DMABASE_CNT + * @arg TIM_DMABASE_PSC + * @arg TIM_DMABASE_ARR + * @arg TIM_DMABASE_RCR + * @arg TIM_DMABASE_CCR1 + * @arg TIM_DMABASE_CCR2 + * @arg TIM_DMABASE_CCR3 + * @arg TIM_DMABASE_CCR4 + * @arg TIM_DMABASE_BDTR + * @param BurstRequestSrc TIM DMA Request sources + * This parameter can be one of the following values: + * @arg TIM_DMA_UPDATE: TIM update Interrupt source + * @arg TIM_DMA_CC1: TIM Capture Compare 1 DMA source + * @arg TIM_DMA_CC2: TIM Capture Compare 2 DMA source + * @arg TIM_DMA_CC3: TIM Capture Compare 3 DMA source + * @arg TIM_DMA_CC4: TIM Capture Compare 4 DMA source + * @arg TIM_DMA_COM: TIM Commutation DMA source + * @arg TIM_DMA_TRIGGER: TIM Trigger DMA source + * @param BurstBuffer The Buffer address. + * @param BurstLength DMA Burst length. This parameter can be one value + * between: TIM_DMABURSTLENGTH_1TRANSFER and TIM_DMABURSTLENGTH_18TRANSFERS. + * @note This function should be used only when BurstLength is equal to DMA data transfer length. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (status == HAL_OK) + { + status = HAL_TIM_DMABurst_MultiWriteStart(htim, BurstBaseAddress, BurstRequestSrc, BurstBuffer, BurstLength, + ((BurstLength) >> 8U) + 1U); + } + + + return status; +} + +/** + * @brief Configure the DMA Burst to transfer multiple Data from the memory to the TIM peripheral + * @param htim TIM handle + * @param BurstBaseAddress TIM Base address from where the DMA will start the Data write + * This parameter can be one of the following values: + * @arg TIM_DMABASE_CR1 + * @arg TIM_DMABASE_CR2 + * @arg TIM_DMABASE_SMCR + * @arg TIM_DMABASE_DIER + * @arg TIM_DMABASE_SR + * @arg TIM_DMABASE_EGR + * @arg TIM_DMABASE_CCMR1 + * @arg TIM_DMABASE_CCMR2 + * @arg TIM_DMABASE_CCER + * @arg TIM_DMABASE_CNT + * @arg TIM_DMABASE_PSC + * @arg TIM_DMABASE_ARR + * @arg TIM_DMABASE_RCR + * @arg TIM_DMABASE_CCR1 + * @arg TIM_DMABASE_CCR2 + * @arg TIM_DMABASE_CCR3 + * @arg TIM_DMABASE_CCR4 + * @arg TIM_DMABASE_BDTR + * @param BurstRequestSrc TIM DMA Request sources + * This parameter can be one of the following values: + * @arg TIM_DMA_UPDATE: TIM update Interrupt source + * @arg TIM_DMA_CC1: TIM Capture Compare 1 DMA source + * @arg TIM_DMA_CC2: TIM Capture Compare 2 DMA source + * @arg TIM_DMA_CC3: TIM Capture Compare 3 DMA source + * @arg TIM_DMA_CC4: TIM Capture Compare 4 DMA source + * @arg TIM_DMA_COM: TIM Commutation DMA source + * @arg TIM_DMA_TRIGGER: TIM Trigger DMA source + * @param BurstBuffer The Buffer address. + * @param BurstLength DMA Burst length. This parameter can be one value + * between: TIM_DMABURSTLENGTH_1TRANSFER and TIM_DMABURSTLENGTH_18TRANSFERS. + * @param DataLength Data length. This parameter can be one value + * between 1 and 0xFFFF. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_DMABurst_MultiWriteStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, + uint32_t BurstLength, uint32_t DataLength) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_DMABURST_INSTANCE(htim->Instance)); + assert_param(IS_TIM_DMA_BASE(BurstBaseAddress)); + assert_param(IS_TIM_DMA_SOURCE(BurstRequestSrc)); + assert_param(IS_TIM_DMA_LENGTH(BurstLength)); + assert_param(IS_TIM_DMA_DATA_LENGTH(DataLength)); + + if (htim->DMABurstState == HAL_DMA_BURST_STATE_BUSY) + { + return HAL_BUSY; + } + else if (htim->DMABurstState == HAL_DMA_BURST_STATE_READY) + { + if ((BurstBuffer == NULL) && (BurstLength > 0U)) + { + return HAL_ERROR; + } + else + { + htim->DMABurstState = HAL_DMA_BURST_STATE_BUSY; + } + } + else + { + /* nothing to do */ + } + + switch (BurstRequestSrc) + { + case TIM_DMA_UPDATE: + { + /* Set the DMA Period elapsed callbacks */ + htim->hdma[TIM_DMA_ID_UPDATE]->XferCpltCallback = TIM_DMAPeriodElapsedCplt; + htim->hdma[TIM_DMA_ID_UPDATE]->XferHalfCpltCallback = TIM_DMAPeriodElapsedHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_UPDATE]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_UPDATE], (uint32_t)BurstBuffer, + (uint32_t)&htim->Instance->DMAR, DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC1: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)BurstBuffer, + (uint32_t)&htim->Instance->DMAR, DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC2: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)BurstBuffer, + (uint32_t)&htim->Instance->DMAR, DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC3: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)BurstBuffer, + (uint32_t)&htim->Instance->DMAR, DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC4: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC4]->XferCpltCallback = TIM_DMADelayPulseCplt; + htim->hdma[TIM_DMA_ID_CC4]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC4]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC4], (uint32_t)BurstBuffer, + (uint32_t)&htim->Instance->DMAR, DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_COM: + { + /* Set the DMA commutation callbacks */ + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferCpltCallback = TIMEx_DMACommutationCplt; + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferHalfCpltCallback = TIMEx_DMACommutationHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_COMMUTATION], (uint32_t)BurstBuffer, + (uint32_t)&htim->Instance->DMAR, DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_TRIGGER: + { + /* Set the DMA trigger callbacks */ + htim->hdma[TIM_DMA_ID_TRIGGER]->XferCpltCallback = TIM_DMATriggerCplt; + htim->hdma[TIM_DMA_ID_TRIGGER]->XferHalfCpltCallback = TIM_DMATriggerHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_TRIGGER]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_TRIGGER], (uint32_t)BurstBuffer, + (uint32_t)&htim->Instance->DMAR, DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Configure the DMA Burst Mode */ + htim->Instance->DCR = (BurstBaseAddress | BurstLength); + /* Enable the TIM DMA Request */ + __HAL_TIM_ENABLE_DMA(htim, BurstRequestSrc); + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM DMA Burst mode + * @param htim TIM handle + * @param BurstRequestSrc TIM DMA Request sources to disable + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_DMABurst_WriteStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_DMA_SOURCE(BurstRequestSrc)); + + /* Abort the DMA transfer (at least disable the DMA channel) */ + switch (BurstRequestSrc) + { + case TIM_DMA_UPDATE: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_UPDATE]); + break; + } + case TIM_DMA_CC1: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + break; + } + case TIM_DMA_CC2: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + break; + } + case TIM_DMA_CC3: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC3]); + break; + } + case TIM_DMA_CC4: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC4]); + break; + } + case TIM_DMA_COM: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_COMMUTATION]); + break; + } + case TIM_DMA_TRIGGER: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_TRIGGER]); + break; + } + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the TIM Update DMA request */ + __HAL_TIM_DISABLE_DMA(htim, BurstRequestSrc); + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + } + + /* Return function status */ + return status; +} + +/** + * @brief Configure the DMA Burst to transfer Data from the TIM peripheral to the memory + * @param htim TIM handle + * @param BurstBaseAddress TIM Base address from where the DMA will start the Data read + * This parameter can be one of the following values: + * @arg TIM_DMABASE_CR1 + * @arg TIM_DMABASE_CR2 + * @arg TIM_DMABASE_SMCR + * @arg TIM_DMABASE_DIER + * @arg TIM_DMABASE_SR + * @arg TIM_DMABASE_EGR + * @arg TIM_DMABASE_CCMR1 + * @arg TIM_DMABASE_CCMR2 + * @arg TIM_DMABASE_CCER + * @arg TIM_DMABASE_CNT + * @arg TIM_DMABASE_PSC + * @arg TIM_DMABASE_ARR + * @arg TIM_DMABASE_RCR + * @arg TIM_DMABASE_CCR1 + * @arg TIM_DMABASE_CCR2 + * @arg TIM_DMABASE_CCR3 + * @arg TIM_DMABASE_CCR4 + * @arg TIM_DMABASE_BDTR + * @param BurstRequestSrc TIM DMA Request sources + * This parameter can be one of the following values: + * @arg TIM_DMA_UPDATE: TIM update Interrupt source + * @arg TIM_DMA_CC1: TIM Capture Compare 1 DMA source + * @arg TIM_DMA_CC2: TIM Capture Compare 2 DMA source + * @arg TIM_DMA_CC3: TIM Capture Compare 3 DMA source + * @arg TIM_DMA_CC4: TIM Capture Compare 4 DMA source + * @arg TIM_DMA_COM: TIM Commutation DMA source + * @arg TIM_DMA_TRIGGER: TIM Trigger DMA source + * @param BurstBuffer The Buffer address. + * @param BurstLength DMA Burst length. This parameter can be one value + * between: TIM_DMABURSTLENGTH_1TRANSFER and TIM_DMABURSTLENGTH_18TRANSFERS. + * @note This function should be used only when BurstLength is equal to DMA data transfer length. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, uint32_t BurstLength) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (status == HAL_OK) + { + status = HAL_TIM_DMABurst_MultiReadStart(htim, BurstBaseAddress, BurstRequestSrc, BurstBuffer, BurstLength, + ((BurstLength) >> 8U) + 1U); + } + + return status; +} + +/** + * @brief Configure the DMA Burst to transfer Data from the TIM peripheral to the memory + * @param htim TIM handle + * @param BurstBaseAddress TIM Base address from where the DMA will start the Data read + * This parameter can be one of the following values: + * @arg TIM_DMABASE_CR1 + * @arg TIM_DMABASE_CR2 + * @arg TIM_DMABASE_SMCR + * @arg TIM_DMABASE_DIER + * @arg TIM_DMABASE_SR + * @arg TIM_DMABASE_EGR + * @arg TIM_DMABASE_CCMR1 + * @arg TIM_DMABASE_CCMR2 + * @arg TIM_DMABASE_CCER + * @arg TIM_DMABASE_CNT + * @arg TIM_DMABASE_PSC + * @arg TIM_DMABASE_ARR + * @arg TIM_DMABASE_RCR + * @arg TIM_DMABASE_CCR1 + * @arg TIM_DMABASE_CCR2 + * @arg TIM_DMABASE_CCR3 + * @arg TIM_DMABASE_CCR4 + * @arg TIM_DMABASE_BDTR + * @param BurstRequestSrc TIM DMA Request sources + * This parameter can be one of the following values: + * @arg TIM_DMA_UPDATE: TIM update Interrupt source + * @arg TIM_DMA_CC1: TIM Capture Compare 1 DMA source + * @arg TIM_DMA_CC2: TIM Capture Compare 2 DMA source + * @arg TIM_DMA_CC3: TIM Capture Compare 3 DMA source + * @arg TIM_DMA_CC4: TIM Capture Compare 4 DMA source + * @arg TIM_DMA_COM: TIM Commutation DMA source + * @arg TIM_DMA_TRIGGER: TIM Trigger DMA source + * @param BurstBuffer The Buffer address. + * @param BurstLength DMA Burst length. This parameter can be one value + * between: TIM_DMABURSTLENGTH_1TRANSFER and TIM_DMABURSTLENGTH_18TRANSFERS. + * @param DataLength Data length. This parameter can be one value + * between 1 and 0xFFFF. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_DMABurst_MultiReadStart(TIM_HandleTypeDef *htim, uint32_t BurstBaseAddress, + uint32_t BurstRequestSrc, uint32_t *BurstBuffer, + uint32_t BurstLength, uint32_t DataLength) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_DMABURST_INSTANCE(htim->Instance)); + assert_param(IS_TIM_DMA_BASE(BurstBaseAddress)); + assert_param(IS_TIM_DMA_SOURCE(BurstRequestSrc)); + assert_param(IS_TIM_DMA_LENGTH(BurstLength)); + assert_param(IS_TIM_DMA_DATA_LENGTH(DataLength)); + + if (htim->DMABurstState == HAL_DMA_BURST_STATE_BUSY) + { + return HAL_BUSY; + } + else if (htim->DMABurstState == HAL_DMA_BURST_STATE_READY) + { + if ((BurstBuffer == NULL) && (BurstLength > 0U)) + { + return HAL_ERROR; + } + else + { + htim->DMABurstState = HAL_DMA_BURST_STATE_BUSY; + } + } + else + { + /* nothing to do */ + } + switch (BurstRequestSrc) + { + case TIM_DMA_UPDATE: + { + /* Set the DMA Period elapsed callbacks */ + htim->hdma[TIM_DMA_ID_UPDATE]->XferCpltCallback = TIM_DMAPeriodElapsedCplt; + htim->hdma[TIM_DMA_ID_UPDATE]->XferHalfCpltCallback = TIM_DMAPeriodElapsedHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_UPDATE]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_UPDATE], (uint32_t)&htim->Instance->DMAR, (uint32_t)BurstBuffer, + DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC1: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)&htim->Instance->DMAR, (uint32_t)BurstBuffer, + DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC2: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)&htim->Instance->DMAR, (uint32_t)BurstBuffer, + DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC3: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)&htim->Instance->DMAR, (uint32_t)BurstBuffer, + DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_CC4: + { + /* Set the DMA capture callbacks */ + htim->hdma[TIM_DMA_ID_CC4]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC4]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC4]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC4], (uint32_t)&htim->Instance->DMAR, (uint32_t)BurstBuffer, + DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_COM: + { + /* Set the DMA commutation callbacks */ + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferCpltCallback = TIMEx_DMACommutationCplt; + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferHalfCpltCallback = TIMEx_DMACommutationHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_COMMUTATION], (uint32_t)&htim->Instance->DMAR, (uint32_t)BurstBuffer, + DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + case TIM_DMA_TRIGGER: + { + /* Set the DMA trigger callbacks */ + htim->hdma[TIM_DMA_ID_TRIGGER]->XferCpltCallback = TIM_DMATriggerCplt; + htim->hdma[TIM_DMA_ID_TRIGGER]->XferHalfCpltCallback = TIM_DMATriggerHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_TRIGGER]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_TRIGGER], (uint32_t)&htim->Instance->DMAR, (uint32_t)BurstBuffer, + DataLength) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + break; + } + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Configure the DMA Burst Mode */ + htim->Instance->DCR = (BurstBaseAddress | BurstLength); + + /* Enable the TIM DMA Request */ + __HAL_TIM_ENABLE_DMA(htim, BurstRequestSrc); + } + + /* Return function status */ + return status; +} + +/** + * @brief Stop the DMA burst reading + * @param htim TIM handle + * @param BurstRequestSrc TIM DMA Request sources to disable. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_DMABurst_ReadStop(TIM_HandleTypeDef *htim, uint32_t BurstRequestSrc) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_DMA_SOURCE(BurstRequestSrc)); + + /* Abort the DMA transfer (at least disable the DMA channel) */ + switch (BurstRequestSrc) + { + case TIM_DMA_UPDATE: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_UPDATE]); + break; + } + case TIM_DMA_CC1: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + break; + } + case TIM_DMA_CC2: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + break; + } + case TIM_DMA_CC3: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC3]); + break; + } + case TIM_DMA_CC4: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC4]); + break; + } + case TIM_DMA_COM: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_COMMUTATION]); + break; + } + case TIM_DMA_TRIGGER: + { + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_TRIGGER]); + break; + } + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the TIM Update DMA request */ + __HAL_TIM_DISABLE_DMA(htim, BurstRequestSrc); + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + } + + /* Return function status */ + return status; +} + +/** + * @brief Generate a software event + * @param htim TIM handle + * @param EventSource specifies the event source. + * This parameter can be one of the following values: + * @arg TIM_EVENTSOURCE_UPDATE: Timer update Event source + * @arg TIM_EVENTSOURCE_CC1: Timer Capture Compare 1 Event source + * @arg TIM_EVENTSOURCE_CC2: Timer Capture Compare 2 Event source + * @arg TIM_EVENTSOURCE_CC3: Timer Capture Compare 3 Event source + * @arg TIM_EVENTSOURCE_CC4: Timer Capture Compare 4 Event source + * @arg TIM_EVENTSOURCE_COM: Timer COM event source + * @arg TIM_EVENTSOURCE_TRIGGER: Timer Trigger Event source + * @arg TIM_EVENTSOURCE_BREAK: Timer Break event source + * @note Basic timers can only generate an update event. + * @note TIM_EVENTSOURCE_COM is relevant only with advanced timer instances. + * @note TIM_EVENTSOURCE_BREAK are relevant only for timer instances + * supporting a break input. + * @retval HAL status + */ + +HAL_StatusTypeDef HAL_TIM_GenerateEvent(TIM_HandleTypeDef *htim, uint32_t EventSource) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + assert_param(IS_TIM_EVENT_SOURCE(EventSource)); + + /* Process Locked */ + __HAL_LOCK(htim); + + /* Change the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Set the event sources */ + htim->Instance->EGR = EventSource; + + /* Change the TIM state */ + htim->State = HAL_TIM_STATE_READY; + + __HAL_UNLOCK(htim); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Configures the OCRef clear feature + * @param htim TIM handle + * @param sClearInputConfig pointer to a TIM_ClearInputConfigTypeDef structure that + * contains the OCREF clear feature and parameters for the TIM peripheral. + * @param Channel specifies the TIM Channel + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 + * @arg TIM_CHANNEL_2: TIM Channel 2 + * @arg TIM_CHANNEL_3: TIM Channel 3 + * @arg TIM_CHANNEL_4: TIM Channel 4 + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_ConfigOCrefClear(TIM_HandleTypeDef *htim, + TIM_ClearInputConfigTypeDef *sClearInputConfig, + uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_OCXREF_CLEAR_INSTANCE(htim->Instance)); + assert_param(IS_TIM_CLEARINPUT_SOURCE(sClearInputConfig->ClearInputSource)); + + /* Process Locked */ + __HAL_LOCK(htim); + + htim->State = HAL_TIM_STATE_BUSY; + + switch (sClearInputConfig->ClearInputSource) + { + case TIM_CLEARINPUTSOURCE_NONE: + { + /* Clear the OCREF clear selection bit and the the ETR Bits */ + CLEAR_BIT(htim->Instance->SMCR, (TIM_SMCR_OCCS | TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP)); + break; + } + case TIM_CLEARINPUTSOURCE_OCREFCLR: + { + /* Clear the OCREF clear selection bit */ + CLEAR_BIT(htim->Instance->SMCR, TIM_SMCR_OCCS); + } + break; + + case TIM_CLEARINPUTSOURCE_ETR: + { + /* Check the parameters */ + assert_param(IS_TIM_CLEARINPUT_POLARITY(sClearInputConfig->ClearInputPolarity)); + assert_param(IS_TIM_CLEARINPUT_PRESCALER(sClearInputConfig->ClearInputPrescaler)); + assert_param(IS_TIM_CLEARINPUT_FILTER(sClearInputConfig->ClearInputFilter)); + + /* When OCRef clear feature is used with ETR source, ETR prescaler must be off */ + if (sClearInputConfig->ClearInputPrescaler != TIM_CLEARINPUTPRESCALER_DIV1) + { + htim->State = HAL_TIM_STATE_READY; + __HAL_UNLOCK(htim); + return HAL_ERROR; + } + + TIM_ETR_SetConfig(htim->Instance, + sClearInputConfig->ClearInputPrescaler, + sClearInputConfig->ClearInputPolarity, + sClearInputConfig->ClearInputFilter); + + /* Set the OCREF clear selection bit */ + SET_BIT(htim->Instance->SMCR, TIM_SMCR_OCCS); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + switch (Channel) + { + case TIM_CHANNEL_1: + { + if (sClearInputConfig->ClearInputState != (uint32_t)DISABLE) + { + /* Enable the OCREF clear feature for Channel 1 */ + SET_BIT(htim->Instance->CCMR1, TIM_CCMR1_OC1CE); + } + else + { + /* Disable the OCREF clear feature for Channel 1 */ + CLEAR_BIT(htim->Instance->CCMR1, TIM_CCMR1_OC1CE); + } + break; + } + case TIM_CHANNEL_2: + { + if (sClearInputConfig->ClearInputState != (uint32_t)DISABLE) + { + /* Enable the OCREF clear feature for Channel 2 */ + SET_BIT(htim->Instance->CCMR1, TIM_CCMR1_OC2CE); + } + else + { + /* Disable the OCREF clear feature for Channel 2 */ + CLEAR_BIT(htim->Instance->CCMR1, TIM_CCMR1_OC2CE); + } + break; + } + case TIM_CHANNEL_3: + { + if (sClearInputConfig->ClearInputState != (uint32_t)DISABLE) + { + /* Enable the OCREF clear feature for Channel 3 */ + SET_BIT(htim->Instance->CCMR2, TIM_CCMR2_OC3CE); + } + else + { + /* Disable the OCREF clear feature for Channel 3 */ + CLEAR_BIT(htim->Instance->CCMR2, TIM_CCMR2_OC3CE); + } + break; + } + case TIM_CHANNEL_4: + { + if (sClearInputConfig->ClearInputState != (uint32_t)DISABLE) + { + /* Enable the OCREF clear feature for Channel 4 */ + SET_BIT(htim->Instance->CCMR2, TIM_CCMR2_OC4CE); + } + else + { + /* Disable the OCREF clear feature for Channel 4 */ + CLEAR_BIT(htim->Instance->CCMR2, TIM_CCMR2_OC4CE); + } + break; + } + default: + break; + } + } + + htim->State = HAL_TIM_STATE_READY; + + __HAL_UNLOCK(htim); + + return status; +} + +/** + * @brief Configures the clock source to be used + * @param htim TIM handle + * @param sClockSourceConfig pointer to a TIM_ClockConfigTypeDef structure that + * contains the clock source information for the TIM peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_ConfigClockSource(TIM_HandleTypeDef *htim, TIM_ClockConfigTypeDef *sClockSourceConfig) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Process Locked */ + __HAL_LOCK(htim); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Check the parameters */ + assert_param(IS_TIM_CLOCKSOURCE(sClockSourceConfig->ClockSource)); + + /* Reset the SMS, TS, ECE, ETPS and ETRF bits */ + tmpsmcr = htim->Instance->SMCR; + tmpsmcr &= ~(TIM_SMCR_SMS | TIM_SMCR_TS); + tmpsmcr &= ~(TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP); + htim->Instance->SMCR = tmpsmcr; + + switch (sClockSourceConfig->ClockSource) + { + case TIM_CLOCKSOURCE_INTERNAL: + { + assert_param(IS_TIM_INSTANCE(htim->Instance)); + break; + } + + case TIM_CLOCKSOURCE_ETRMODE1: + { + /* Check whether or not the timer instance supports external trigger input mode 1 (ETRF)*/ + assert_param(IS_TIM_CLOCKSOURCE_ETRMODE1_INSTANCE(htim->Instance)); + + /* Check ETR input conditioning related parameters */ + assert_param(IS_TIM_CLOCKPRESCALER(sClockSourceConfig->ClockPrescaler)); + assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity)); + assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter)); + + /* Configure the ETR Clock source */ + TIM_ETR_SetConfig(htim->Instance, + sClockSourceConfig->ClockPrescaler, + sClockSourceConfig->ClockPolarity, + sClockSourceConfig->ClockFilter); + + /* Select the External clock mode1 and the ETRF trigger */ + tmpsmcr = htim->Instance->SMCR; + tmpsmcr |= (TIM_SLAVEMODE_EXTERNAL1 | TIM_CLOCKSOURCE_ETRMODE1); + /* Write to TIMx SMCR */ + htim->Instance->SMCR = tmpsmcr; + break; + } + + case TIM_CLOCKSOURCE_ETRMODE2: + { + /* Check whether or not the timer instance supports external trigger input mode 2 (ETRF)*/ + assert_param(IS_TIM_CLOCKSOURCE_ETRMODE2_INSTANCE(htim->Instance)); + + /* Check ETR input conditioning related parameters */ + assert_param(IS_TIM_CLOCKPRESCALER(sClockSourceConfig->ClockPrescaler)); + assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity)); + assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter)); + + /* Configure the ETR Clock source */ + TIM_ETR_SetConfig(htim->Instance, + sClockSourceConfig->ClockPrescaler, + sClockSourceConfig->ClockPolarity, + sClockSourceConfig->ClockFilter); + /* Enable the External clock mode2 */ + htim->Instance->SMCR |= TIM_SMCR_ECE; + break; + } + + case TIM_CLOCKSOURCE_TI1: + { + /* Check whether or not the timer instance supports external clock mode 1 */ + assert_param(IS_TIM_CLOCKSOURCE_TIX_INSTANCE(htim->Instance)); + + /* Check TI1 input conditioning related parameters */ + assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity)); + assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter)); + + TIM_TI1_ConfigInputStage(htim->Instance, + sClockSourceConfig->ClockPolarity, + sClockSourceConfig->ClockFilter); + TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1); + break; + } + + case TIM_CLOCKSOURCE_TI2: + { + /* Check whether or not the timer instance supports external clock mode 1 (ETRF)*/ + assert_param(IS_TIM_CLOCKSOURCE_TIX_INSTANCE(htim->Instance)); + + /* Check TI2 input conditioning related parameters */ + assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity)); + assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter)); + + TIM_TI2_ConfigInputStage(htim->Instance, + sClockSourceConfig->ClockPolarity, + sClockSourceConfig->ClockFilter); + TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI2); + break; + } + + case TIM_CLOCKSOURCE_TI1ED: + { + /* Check whether or not the timer instance supports external clock mode 1 */ + assert_param(IS_TIM_CLOCKSOURCE_TIX_INSTANCE(htim->Instance)); + + /* Check TI1 input conditioning related parameters */ + assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity)); + assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter)); + + TIM_TI1_ConfigInputStage(htim->Instance, + sClockSourceConfig->ClockPolarity, + sClockSourceConfig->ClockFilter); + TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1ED); + break; + } + + case TIM_CLOCKSOURCE_ITR0: + case TIM_CLOCKSOURCE_ITR1: + case TIM_CLOCKSOURCE_ITR2: + case TIM_CLOCKSOURCE_ITR3: + { + /* Check whether or not the timer instance supports internal trigger input */ + assert_param(IS_TIM_CLOCKSOURCE_ITRX_INSTANCE(htim->Instance)); + + TIM_ITRx_SetConfig(htim->Instance, sClockSourceConfig->ClockSource); + break; + } + + default: + status = HAL_ERROR; + break; + } + htim->State = HAL_TIM_STATE_READY; + + __HAL_UNLOCK(htim); + + return status; +} + +/** + * @brief Selects the signal connected to the TI1 input: direct from CH1_input + * or a XOR combination between CH1_input, CH2_input & CH3_input + * @param htim TIM handle. + * @param TI1_Selection Indicate whether or not channel 1 is connected to the + * output of a XOR gate. + * This parameter can be one of the following values: + * @arg TIM_TI1SELECTION_CH1: The TIMx_CH1 pin is connected to TI1 input + * @arg TIM_TI1SELECTION_XORCOMBINATION: The TIMx_CH1, CH2 and CH3 + * pins are connected to the TI1 input (XOR combination) + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_ConfigTI1Input(TIM_HandleTypeDef *htim, uint32_t TI1_Selection) +{ + uint32_t tmpcr2; + + /* Check the parameters */ + assert_param(IS_TIM_XOR_INSTANCE(htim->Instance)); + assert_param(IS_TIM_TI1SELECTION(TI1_Selection)); + + /* Get the TIMx CR2 register value */ + tmpcr2 = htim->Instance->CR2; + + /* Reset the TI1 selection */ + tmpcr2 &= ~TIM_CR2_TI1S; + + /* Set the TI1 selection */ + tmpcr2 |= TI1_Selection; + + /* Write to TIMxCR2 */ + htim->Instance->CR2 = tmpcr2; + + return HAL_OK; +} + +/** + * @brief Configures the TIM in Slave mode + * @param htim TIM handle. + * @param sSlaveConfig pointer to a TIM_SlaveConfigTypeDef structure that + * contains the selected trigger (internal trigger input, filtered + * timer input or external trigger input) and the Slave mode + * (Disable, Reset, Gated, Trigger, External clock mode 1). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro(TIM_HandleTypeDef *htim, TIM_SlaveConfigTypeDef *sSlaveConfig) +{ + /* Check the parameters */ + assert_param(IS_TIM_SLAVE_INSTANCE(htim->Instance)); + assert_param(IS_TIM_SLAVE_MODE(sSlaveConfig->SlaveMode)); + assert_param(IS_TIM_TRIGGER_SELECTION(sSlaveConfig->InputTrigger)); + + __HAL_LOCK(htim); + + htim->State = HAL_TIM_STATE_BUSY; + + if (TIM_SlaveTimer_SetConfig(htim, sSlaveConfig) != HAL_OK) + { + htim->State = HAL_TIM_STATE_READY; + __HAL_UNLOCK(htim); + return HAL_ERROR; + } + + /* Disable Trigger Interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_TRIGGER); + + /* Disable Trigger DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_TRIGGER); + + htim->State = HAL_TIM_STATE_READY; + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Configures the TIM in Slave mode in interrupt mode + * @param htim TIM handle. + * @param sSlaveConfig pointer to a TIM_SlaveConfigTypeDef structure that + * contains the selected trigger (internal trigger input, filtered + * timer input or external trigger input) and the Slave mode + * (Disable, Reset, Gated, Trigger, External clock mode 1). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIM_SlaveConfigSynchro_IT(TIM_HandleTypeDef *htim, + TIM_SlaveConfigTypeDef *sSlaveConfig) +{ + /* Check the parameters */ + assert_param(IS_TIM_SLAVE_INSTANCE(htim->Instance)); + assert_param(IS_TIM_SLAVE_MODE(sSlaveConfig->SlaveMode)); + assert_param(IS_TIM_TRIGGER_SELECTION(sSlaveConfig->InputTrigger)); + + __HAL_LOCK(htim); + + htim->State = HAL_TIM_STATE_BUSY; + + if (TIM_SlaveTimer_SetConfig(htim, sSlaveConfig) != HAL_OK) + { + htim->State = HAL_TIM_STATE_READY; + __HAL_UNLOCK(htim); + return HAL_ERROR; + } + + /* Enable Trigger Interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_TRIGGER); + + /* Disable Trigger DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_TRIGGER); + + htim->State = HAL_TIM_STATE_READY; + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Read the captured value from Capture Compare unit + * @param htim TIM handle. + * @param Channel TIM Channels to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @arg TIM_CHANNEL_4: TIM Channel 4 selected + * @retval Captured value + */ +uint32_t HAL_TIM_ReadCapturedValue(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + uint32_t tmpreg = 0U; + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + + /* Return the capture 1 value */ + tmpreg = htim->Instance->CCR1; + + break; + } + case TIM_CHANNEL_2: + { + /* Check the parameters */ + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + + /* Return the capture 2 value */ + tmpreg = htim->Instance->CCR2; + + break; + } + + case TIM_CHANNEL_3: + { + /* Check the parameters */ + assert_param(IS_TIM_CC3_INSTANCE(htim->Instance)); + + /* Return the capture 3 value */ + tmpreg = htim->Instance->CCR3; + + break; + } + + case TIM_CHANNEL_4: + { + /* Check the parameters */ + assert_param(IS_TIM_CC4_INSTANCE(htim->Instance)); + + /* Return the capture 4 value */ + tmpreg = htim->Instance->CCR4; + + break; + } + + default: + break; + } + + return tmpreg; +} + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group9 TIM Callbacks functions + * @brief TIM Callbacks functions + * +@verbatim + ============================================================================== + ##### TIM Callbacks functions ##### + ============================================================================== + [..] + This section provides TIM callback functions: + (+) TIM Period elapsed callback + (+) TIM Output Compare callback + (+) TIM Input capture callback + (+) TIM Trigger callback + (+) TIM Error callback + +@endverbatim + * @{ + */ + +/** + * @brief Period elapsed callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_PeriodElapsedCallback could be implemented in the user file + */ +} + +/** + * @brief Period elapsed half complete callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_PeriodElapsedHalfCpltCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_PeriodElapsedHalfCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Output Compare callback in non-blocking mode + * @param htim TIM OC handle + * @retval None + */ +__weak void HAL_TIM_OC_DelayElapsedCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_OC_DelayElapsedCallback could be implemented in the user file + */ +} + +/** + * @brief Input Capture callback in non-blocking mode + * @param htim TIM IC handle + * @retval None + */ +__weak void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_IC_CaptureCallback could be implemented in the user file + */ +} + +/** + * @brief Input Capture half complete callback in non-blocking mode + * @param htim TIM IC handle + * @retval None + */ +__weak void HAL_TIM_IC_CaptureHalfCpltCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_IC_CaptureHalfCpltCallback could be implemented in the user file + */ +} + +/** + * @brief PWM Pulse finished callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_PWM_PulseFinishedCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_PWM_PulseFinishedCallback could be implemented in the user file + */ +} + +/** + * @brief PWM Pulse finished half complete callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_PWM_PulseFinishedHalfCpltCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_PWM_PulseFinishedHalfCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Hall Trigger detection callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_TriggerCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_TriggerCallback could be implemented in the user file + */ +} + +/** + * @brief Hall Trigger detection half complete callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_TriggerHalfCpltCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_TriggerHalfCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Timer error callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIM_ErrorCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIM_ErrorCallback could be implemented in the user file + */ +} + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User TIM callback to be used instead of the weak predefined callback + * @param htim tim handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_TIM_BASE_MSPINIT_CB_ID Base MspInit Callback ID + * @arg @ref HAL_TIM_BASE_MSPDEINIT_CB_ID Base MspDeInit Callback ID + * @arg @ref HAL_TIM_IC_MSPINIT_CB_ID IC MspInit Callback ID + * @arg @ref HAL_TIM_IC_MSPDEINIT_CB_ID IC MspDeInit Callback ID + * @arg @ref HAL_TIM_OC_MSPINIT_CB_ID OC MspInit Callback ID + * @arg @ref HAL_TIM_OC_MSPDEINIT_CB_ID OC MspDeInit Callback ID + * @arg @ref HAL_TIM_PWM_MSPINIT_CB_ID PWM MspInit Callback ID + * @arg @ref HAL_TIM_PWM_MSPDEINIT_CB_ID PWM MspDeInit Callback ID + * @arg @ref HAL_TIM_ONE_PULSE_MSPINIT_CB_ID One Pulse MspInit Callback ID + * @arg @ref HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID One Pulse MspDeInit Callback ID + * @arg @ref HAL_TIM_ENCODER_MSPINIT_CB_ID Encoder MspInit Callback ID + * @arg @ref HAL_TIM_ENCODER_MSPDEINIT_CB_ID Encoder MspDeInit Callback ID + * @arg @ref HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID Hall Sensor MspInit Callback ID + * @arg @ref HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID Hall Sensor MspDeInit Callback ID + * @arg @ref HAL_TIM_PERIOD_ELAPSED_CB_ID Period Elapsed Callback ID + * @arg @ref HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID Period Elapsed half complete Callback ID + * @arg @ref HAL_TIM_TRIGGER_CB_ID Trigger Callback ID + * @arg @ref HAL_TIM_TRIGGER_HALF_CB_ID Trigger half complete Callback ID + * @arg @ref HAL_TIM_IC_CAPTURE_CB_ID Input Capture Callback ID + * @arg @ref HAL_TIM_IC_CAPTURE_HALF_CB_ID Input Capture half complete Callback ID + * @arg @ref HAL_TIM_OC_DELAY_ELAPSED_CB_ID Output Compare Delay Elapsed Callback ID + * @arg @ref HAL_TIM_PWM_PULSE_FINISHED_CB_ID PWM Pulse Finished Callback ID + * @arg @ref HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID PWM Pulse Finished half complete Callback ID + * @arg @ref HAL_TIM_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_TIM_COMMUTATION_CB_ID Commutation Callback ID + * @arg @ref HAL_TIM_COMMUTATION_HALF_CB_ID Commutation half complete Callback ID + * @arg @ref HAL_TIM_BREAK_CB_ID Break Callback ID + * @param pCallback pointer to the callback function + * @retval status + */ +HAL_StatusTypeDef HAL_TIM_RegisterCallback(TIM_HandleTypeDef *htim, HAL_TIM_CallbackIDTypeDef CallbackID, + pTIM_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(htim); + + if (htim->State == HAL_TIM_STATE_READY) + { + switch (CallbackID) + { + case HAL_TIM_BASE_MSPINIT_CB_ID : + htim->Base_MspInitCallback = pCallback; + break; + + case HAL_TIM_BASE_MSPDEINIT_CB_ID : + htim->Base_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_IC_MSPINIT_CB_ID : + htim->IC_MspInitCallback = pCallback; + break; + + case HAL_TIM_IC_MSPDEINIT_CB_ID : + htim->IC_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_OC_MSPINIT_CB_ID : + htim->OC_MspInitCallback = pCallback; + break; + + case HAL_TIM_OC_MSPDEINIT_CB_ID : + htim->OC_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_PWM_MSPINIT_CB_ID : + htim->PWM_MspInitCallback = pCallback; + break; + + case HAL_TIM_PWM_MSPDEINIT_CB_ID : + htim->PWM_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_ONE_PULSE_MSPINIT_CB_ID : + htim->OnePulse_MspInitCallback = pCallback; + break; + + case HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID : + htim->OnePulse_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_ENCODER_MSPINIT_CB_ID : + htim->Encoder_MspInitCallback = pCallback; + break; + + case HAL_TIM_ENCODER_MSPDEINIT_CB_ID : + htim->Encoder_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID : + htim->HallSensor_MspInitCallback = pCallback; + break; + + case HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID : + htim->HallSensor_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_PERIOD_ELAPSED_CB_ID : + htim->PeriodElapsedCallback = pCallback; + break; + + case HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID : + htim->PeriodElapsedHalfCpltCallback = pCallback; + break; + + case HAL_TIM_TRIGGER_CB_ID : + htim->TriggerCallback = pCallback; + break; + + case HAL_TIM_TRIGGER_HALF_CB_ID : + htim->TriggerHalfCpltCallback = pCallback; + break; + + case HAL_TIM_IC_CAPTURE_CB_ID : + htim->IC_CaptureCallback = pCallback; + break; + + case HAL_TIM_IC_CAPTURE_HALF_CB_ID : + htim->IC_CaptureHalfCpltCallback = pCallback; + break; + + case HAL_TIM_OC_DELAY_ELAPSED_CB_ID : + htim->OC_DelayElapsedCallback = pCallback; + break; + + case HAL_TIM_PWM_PULSE_FINISHED_CB_ID : + htim->PWM_PulseFinishedCallback = pCallback; + break; + + case HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID : + htim->PWM_PulseFinishedHalfCpltCallback = pCallback; + break; + + case HAL_TIM_ERROR_CB_ID : + htim->ErrorCallback = pCallback; + break; + + case HAL_TIM_COMMUTATION_CB_ID : + htim->CommutationCallback = pCallback; + break; + + case HAL_TIM_COMMUTATION_HALF_CB_ID : + htim->CommutationHalfCpltCallback = pCallback; + break; + + case HAL_TIM_BREAK_CB_ID : + htim->BreakCallback = pCallback; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (htim->State == HAL_TIM_STATE_RESET) + { + switch (CallbackID) + { + case HAL_TIM_BASE_MSPINIT_CB_ID : + htim->Base_MspInitCallback = pCallback; + break; + + case HAL_TIM_BASE_MSPDEINIT_CB_ID : + htim->Base_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_IC_MSPINIT_CB_ID : + htim->IC_MspInitCallback = pCallback; + break; + + case HAL_TIM_IC_MSPDEINIT_CB_ID : + htim->IC_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_OC_MSPINIT_CB_ID : + htim->OC_MspInitCallback = pCallback; + break; + + case HAL_TIM_OC_MSPDEINIT_CB_ID : + htim->OC_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_PWM_MSPINIT_CB_ID : + htim->PWM_MspInitCallback = pCallback; + break; + + case HAL_TIM_PWM_MSPDEINIT_CB_ID : + htim->PWM_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_ONE_PULSE_MSPINIT_CB_ID : + htim->OnePulse_MspInitCallback = pCallback; + break; + + case HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID : + htim->OnePulse_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_ENCODER_MSPINIT_CB_ID : + htim->Encoder_MspInitCallback = pCallback; + break; + + case HAL_TIM_ENCODER_MSPDEINIT_CB_ID : + htim->Encoder_MspDeInitCallback = pCallback; + break; + + case HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID : + htim->HallSensor_MspInitCallback = pCallback; + break; + + case HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID : + htim->HallSensor_MspDeInitCallback = pCallback; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return status; +} + +/** + * @brief Unregister a TIM callback + * TIM callback is redirected to the weak predefined callback + * @param htim tim handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_TIM_BASE_MSPINIT_CB_ID Base MspInit Callback ID + * @arg @ref HAL_TIM_BASE_MSPDEINIT_CB_ID Base MspDeInit Callback ID + * @arg @ref HAL_TIM_IC_MSPINIT_CB_ID IC MspInit Callback ID + * @arg @ref HAL_TIM_IC_MSPDEINIT_CB_ID IC MspDeInit Callback ID + * @arg @ref HAL_TIM_OC_MSPINIT_CB_ID OC MspInit Callback ID + * @arg @ref HAL_TIM_OC_MSPDEINIT_CB_ID OC MspDeInit Callback ID + * @arg @ref HAL_TIM_PWM_MSPINIT_CB_ID PWM MspInit Callback ID + * @arg @ref HAL_TIM_PWM_MSPDEINIT_CB_ID PWM MspDeInit Callback ID + * @arg @ref HAL_TIM_ONE_PULSE_MSPINIT_CB_ID One Pulse MspInit Callback ID + * @arg @ref HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID One Pulse MspDeInit Callback ID + * @arg @ref HAL_TIM_ENCODER_MSPINIT_CB_ID Encoder MspInit Callback ID + * @arg @ref HAL_TIM_ENCODER_MSPDEINIT_CB_ID Encoder MspDeInit Callback ID + * @arg @ref HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID Hall Sensor MspInit Callback ID + * @arg @ref HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID Hall Sensor MspDeInit Callback ID + * @arg @ref HAL_TIM_PERIOD_ELAPSED_CB_ID Period Elapsed Callback ID + * @arg @ref HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID Period Elapsed half complete Callback ID + * @arg @ref HAL_TIM_TRIGGER_CB_ID Trigger Callback ID + * @arg @ref HAL_TIM_TRIGGER_HALF_CB_ID Trigger half complete Callback ID + * @arg @ref HAL_TIM_IC_CAPTURE_CB_ID Input Capture Callback ID + * @arg @ref HAL_TIM_IC_CAPTURE_HALF_CB_ID Input Capture half complete Callback ID + * @arg @ref HAL_TIM_OC_DELAY_ELAPSED_CB_ID Output Compare Delay Elapsed Callback ID + * @arg @ref HAL_TIM_PWM_PULSE_FINISHED_CB_ID PWM Pulse Finished Callback ID + * @arg @ref HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID PWM Pulse Finished half complete Callback ID + * @arg @ref HAL_TIM_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_TIM_COMMUTATION_CB_ID Commutation Callback ID + * @arg @ref HAL_TIM_COMMUTATION_HALF_CB_ID Commutation half complete Callback ID + * @arg @ref HAL_TIM_BREAK_CB_ID Break Callback ID + * @retval status + */ +HAL_StatusTypeDef HAL_TIM_UnRegisterCallback(TIM_HandleTypeDef *htim, HAL_TIM_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(htim); + + if (htim->State == HAL_TIM_STATE_READY) + { + switch (CallbackID) + { + case HAL_TIM_BASE_MSPINIT_CB_ID : + /* Legacy weak Base MspInit Callback */ + htim->Base_MspInitCallback = HAL_TIM_Base_MspInit; + break; + + case HAL_TIM_BASE_MSPDEINIT_CB_ID : + /* Legacy weak Base Msp DeInit Callback */ + htim->Base_MspDeInitCallback = HAL_TIM_Base_MspDeInit; + break; + + case HAL_TIM_IC_MSPINIT_CB_ID : + /* Legacy weak IC Msp Init Callback */ + htim->IC_MspInitCallback = HAL_TIM_IC_MspInit; + break; + + case HAL_TIM_IC_MSPDEINIT_CB_ID : + /* Legacy weak IC Msp DeInit Callback */ + htim->IC_MspDeInitCallback = HAL_TIM_IC_MspDeInit; + break; + + case HAL_TIM_OC_MSPINIT_CB_ID : + /* Legacy weak OC Msp Init Callback */ + htim->OC_MspInitCallback = HAL_TIM_OC_MspInit; + break; + + case HAL_TIM_OC_MSPDEINIT_CB_ID : + /* Legacy weak OC Msp DeInit Callback */ + htim->OC_MspDeInitCallback = HAL_TIM_OC_MspDeInit; + break; + + case HAL_TIM_PWM_MSPINIT_CB_ID : + /* Legacy weak PWM Msp Init Callback */ + htim->PWM_MspInitCallback = HAL_TIM_PWM_MspInit; + break; + + case HAL_TIM_PWM_MSPDEINIT_CB_ID : + /* Legacy weak PWM Msp DeInit Callback */ + htim->PWM_MspDeInitCallback = HAL_TIM_PWM_MspDeInit; + break; + + case HAL_TIM_ONE_PULSE_MSPINIT_CB_ID : + /* Legacy weak One Pulse Msp Init Callback */ + htim->OnePulse_MspInitCallback = HAL_TIM_OnePulse_MspInit; + break; + + case HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID : + /* Legacy weak One Pulse Msp DeInit Callback */ + htim->OnePulse_MspDeInitCallback = HAL_TIM_OnePulse_MspDeInit; + break; + + case HAL_TIM_ENCODER_MSPINIT_CB_ID : + /* Legacy weak Encoder Msp Init Callback */ + htim->Encoder_MspInitCallback = HAL_TIM_Encoder_MspInit; + break; + + case HAL_TIM_ENCODER_MSPDEINIT_CB_ID : + /* Legacy weak Encoder Msp DeInit Callback */ + htim->Encoder_MspDeInitCallback = HAL_TIM_Encoder_MspDeInit; + break; + + case HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID : + /* Legacy weak Hall Sensor Msp Init Callback */ + htim->HallSensor_MspInitCallback = HAL_TIMEx_HallSensor_MspInit; + break; + + case HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID : + /* Legacy weak Hall Sensor Msp DeInit Callback */ + htim->HallSensor_MspDeInitCallback = HAL_TIMEx_HallSensor_MspDeInit; + break; + + case HAL_TIM_PERIOD_ELAPSED_CB_ID : + /* Legacy weak Period Elapsed Callback */ + htim->PeriodElapsedCallback = HAL_TIM_PeriodElapsedCallback; + break; + + case HAL_TIM_PERIOD_ELAPSED_HALF_CB_ID : + /* Legacy weak Period Elapsed half complete Callback */ + htim->PeriodElapsedHalfCpltCallback = HAL_TIM_PeriodElapsedHalfCpltCallback; + break; + + case HAL_TIM_TRIGGER_CB_ID : + /* Legacy weak Trigger Callback */ + htim->TriggerCallback = HAL_TIM_TriggerCallback; + break; + + case HAL_TIM_TRIGGER_HALF_CB_ID : + /* Legacy weak Trigger half complete Callback */ + htim->TriggerHalfCpltCallback = HAL_TIM_TriggerHalfCpltCallback; + break; + + case HAL_TIM_IC_CAPTURE_CB_ID : + /* Legacy weak IC Capture Callback */ + htim->IC_CaptureCallback = HAL_TIM_IC_CaptureCallback; + break; + + case HAL_TIM_IC_CAPTURE_HALF_CB_ID : + /* Legacy weak IC Capture half complete Callback */ + htim->IC_CaptureHalfCpltCallback = HAL_TIM_IC_CaptureHalfCpltCallback; + break; + + case HAL_TIM_OC_DELAY_ELAPSED_CB_ID : + /* Legacy weak OC Delay Elapsed Callback */ + htim->OC_DelayElapsedCallback = HAL_TIM_OC_DelayElapsedCallback; + break; + + case HAL_TIM_PWM_PULSE_FINISHED_CB_ID : + /* Legacy weak PWM Pulse Finished Callback */ + htim->PWM_PulseFinishedCallback = HAL_TIM_PWM_PulseFinishedCallback; + break; + + case HAL_TIM_PWM_PULSE_FINISHED_HALF_CB_ID : + /* Legacy weak PWM Pulse Finished half complete Callback */ + htim->PWM_PulseFinishedHalfCpltCallback = HAL_TIM_PWM_PulseFinishedHalfCpltCallback; + break; + + case HAL_TIM_ERROR_CB_ID : + /* Legacy weak Error Callback */ + htim->ErrorCallback = HAL_TIM_ErrorCallback; + break; + + case HAL_TIM_COMMUTATION_CB_ID : + /* Legacy weak Commutation Callback */ + htim->CommutationCallback = HAL_TIMEx_CommutCallback; + break; + + case HAL_TIM_COMMUTATION_HALF_CB_ID : + /* Legacy weak Commutation half complete Callback */ + htim->CommutationHalfCpltCallback = HAL_TIMEx_CommutHalfCpltCallback; + break; + + case HAL_TIM_BREAK_CB_ID : + /* Legacy weak Break Callback */ + htim->BreakCallback = HAL_TIMEx_BreakCallback; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (htim->State == HAL_TIM_STATE_RESET) + { + switch (CallbackID) + { + case HAL_TIM_BASE_MSPINIT_CB_ID : + /* Legacy weak Base MspInit Callback */ + htim->Base_MspInitCallback = HAL_TIM_Base_MspInit; + break; + + case HAL_TIM_BASE_MSPDEINIT_CB_ID : + /* Legacy weak Base Msp DeInit Callback */ + htim->Base_MspDeInitCallback = HAL_TIM_Base_MspDeInit; + break; + + case HAL_TIM_IC_MSPINIT_CB_ID : + /* Legacy weak IC Msp Init Callback */ + htim->IC_MspInitCallback = HAL_TIM_IC_MspInit; + break; + + case HAL_TIM_IC_MSPDEINIT_CB_ID : + /* Legacy weak IC Msp DeInit Callback */ + htim->IC_MspDeInitCallback = HAL_TIM_IC_MspDeInit; + break; + + case HAL_TIM_OC_MSPINIT_CB_ID : + /* Legacy weak OC Msp Init Callback */ + htim->OC_MspInitCallback = HAL_TIM_OC_MspInit; + break; + + case HAL_TIM_OC_MSPDEINIT_CB_ID : + /* Legacy weak OC Msp DeInit Callback */ + htim->OC_MspDeInitCallback = HAL_TIM_OC_MspDeInit; + break; + + case HAL_TIM_PWM_MSPINIT_CB_ID : + /* Legacy weak PWM Msp Init Callback */ + htim->PWM_MspInitCallback = HAL_TIM_PWM_MspInit; + break; + + case HAL_TIM_PWM_MSPDEINIT_CB_ID : + /* Legacy weak PWM Msp DeInit Callback */ + htim->PWM_MspDeInitCallback = HAL_TIM_PWM_MspDeInit; + break; + + case HAL_TIM_ONE_PULSE_MSPINIT_CB_ID : + /* Legacy weak One Pulse Msp Init Callback */ + htim->OnePulse_MspInitCallback = HAL_TIM_OnePulse_MspInit; + break; + + case HAL_TIM_ONE_PULSE_MSPDEINIT_CB_ID : + /* Legacy weak One Pulse Msp DeInit Callback */ + htim->OnePulse_MspDeInitCallback = HAL_TIM_OnePulse_MspDeInit; + break; + + case HAL_TIM_ENCODER_MSPINIT_CB_ID : + /* Legacy weak Encoder Msp Init Callback */ + htim->Encoder_MspInitCallback = HAL_TIM_Encoder_MspInit; + break; + + case HAL_TIM_ENCODER_MSPDEINIT_CB_ID : + /* Legacy weak Encoder Msp DeInit Callback */ + htim->Encoder_MspDeInitCallback = HAL_TIM_Encoder_MspDeInit; + break; + + case HAL_TIM_HALL_SENSOR_MSPINIT_CB_ID : + /* Legacy weak Hall Sensor Msp Init Callback */ + htim->HallSensor_MspInitCallback = HAL_TIMEx_HallSensor_MspInit; + break; + + case HAL_TIM_HALL_SENSOR_MSPDEINIT_CB_ID : + /* Legacy weak Hall Sensor Msp DeInit Callback */ + htim->HallSensor_MspDeInitCallback = HAL_TIMEx_HallSensor_MspDeInit; + break; + + default : + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return status; +} +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup TIM_Exported_Functions_Group10 TIM Peripheral State functions + * @brief TIM Peripheral State functions + * +@verbatim + ============================================================================== + ##### Peripheral State functions ##### + ============================================================================== + [..] + This subsection permits to get in run-time the status of the peripheral + and the data flow. + +@endverbatim + * @{ + */ + +/** + * @brief Return the TIM Base handle state. + * @param htim TIM Base handle + * @retval HAL state + */ +HAL_TIM_StateTypeDef HAL_TIM_Base_GetState(TIM_HandleTypeDef *htim) +{ + return htim->State; +} + +/** + * @brief Return the TIM OC handle state. + * @param htim TIM Output Compare handle + * @retval HAL state + */ +HAL_TIM_StateTypeDef HAL_TIM_OC_GetState(TIM_HandleTypeDef *htim) +{ + return htim->State; +} + +/** + * @brief Return the TIM PWM handle state. + * @param htim TIM handle + * @retval HAL state + */ +HAL_TIM_StateTypeDef HAL_TIM_PWM_GetState(TIM_HandleTypeDef *htim) +{ + return htim->State; +} + +/** + * @brief Return the TIM Input Capture handle state. + * @param htim TIM IC handle + * @retval HAL state + */ +HAL_TIM_StateTypeDef HAL_TIM_IC_GetState(TIM_HandleTypeDef *htim) +{ + return htim->State; +} + +/** + * @brief Return the TIM One Pulse Mode handle state. + * @param htim TIM OPM handle + * @retval HAL state + */ +HAL_TIM_StateTypeDef HAL_TIM_OnePulse_GetState(TIM_HandleTypeDef *htim) +{ + return htim->State; +} + +/** + * @brief Return the TIM Encoder Mode handle state. + * @param htim TIM Encoder Interface handle + * @retval HAL state + */ +HAL_TIM_StateTypeDef HAL_TIM_Encoder_GetState(TIM_HandleTypeDef *htim) +{ + return htim->State; +} + +/** + * @brief Return the TIM Encoder Mode handle state. + * @param htim TIM handle + * @retval Active channel + */ +HAL_TIM_ActiveChannel HAL_TIM_GetActiveChannel(TIM_HandleTypeDef *htim) +{ + return htim->Channel; +} + +/** + * @brief Return actual state of the TIM channel. + * @param htim TIM handle + * @param Channel TIM Channel + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 + * @arg TIM_CHANNEL_2: TIM Channel 2 + * @arg TIM_CHANNEL_3: TIM Channel 3 + * @arg TIM_CHANNEL_4: TIM Channel 4 + * @arg TIM_CHANNEL_5: TIM Channel 5 + * @arg TIM_CHANNEL_6: TIM Channel 6 + * @retval TIM Channel state + */ +HAL_TIM_ChannelStateTypeDef HAL_TIM_GetChannelState(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_TIM_ChannelStateTypeDef channel_state; + + /* Check the parameters */ + assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel)); + + channel_state = TIM_CHANNEL_STATE_GET(htim, Channel); + + return channel_state; +} + +/** + * @brief Return actual state of a DMA burst operation. + * @param htim TIM handle + * @retval DMA burst state + */ +HAL_TIM_DMABurstStateTypeDef HAL_TIM_DMABurstState(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_DMABURST_INSTANCE(htim->Instance)); + + return htim->DMABurstState; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup TIM_Private_Functions TIM Private Functions + * @{ + */ + +/** + * @brief TIM DMA error callback + * @param hdma pointer to DMA handle. + * @retval None + */ +void TIM_DMAError(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (hdma == htim->hdma[TIM_DMA_ID_CC1]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC2]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC3]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY); + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC4]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_4, HAL_TIM_CHANNEL_STATE_READY); + } + else + { + htim->State = HAL_TIM_STATE_READY; + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->ErrorCallback(htim); +#else + HAL_TIM_ErrorCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; +} + +/** + * @brief TIM DMA Delay Pulse complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +static void TIM_DMADelayPulseCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (hdma == htim->hdma[TIM_DMA_ID_CC1]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC2]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC3]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC4]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_4, HAL_TIM_CHANNEL_STATE_READY); + } + } + else + { + /* nothing to do */ + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->PWM_PulseFinishedCallback(htim); +#else + HAL_TIM_PWM_PulseFinishedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; +} + +/** + * @brief TIM DMA Delay Pulse half complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +void TIM_DMADelayPulseHalfCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (hdma == htim->hdma[TIM_DMA_ID_CC1]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC2]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC3]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC4]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; + } + else + { + /* nothing to do */ + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->PWM_PulseFinishedHalfCpltCallback(htim); +#else + HAL_TIM_PWM_PulseFinishedHalfCpltCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; +} + +/** + * @brief TIM DMA Capture complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +void TIM_DMACaptureCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (hdma == htim->hdma[TIM_DMA_ID_CC1]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC2]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC3]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC4]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_4, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_4, HAL_TIM_CHANNEL_STATE_READY); + } + } + else + { + /* nothing to do */ + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->IC_CaptureCallback(htim); +#else + HAL_TIM_IC_CaptureCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; +} + +/** + * @brief TIM DMA Capture half complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +void TIM_DMACaptureHalfCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (hdma == htim->hdma[TIM_DMA_ID_CC1]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC2]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC3]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC4]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; + } + else + { + /* nothing to do */ + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->IC_CaptureHalfCpltCallback(htim); +#else + HAL_TIM_IC_CaptureHalfCpltCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; +} + +/** + * @brief TIM DMA Period Elapse complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +static void TIM_DMAPeriodElapsedCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (htim->hdma[TIM_DMA_ID_UPDATE]->Init.Mode == DMA_NORMAL) + { + htim->State = HAL_TIM_STATE_READY; + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->PeriodElapsedCallback(htim); +#else + HAL_TIM_PeriodElapsedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +} + +/** + * @brief TIM DMA Period Elapse half complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +static void TIM_DMAPeriodElapsedHalfCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->PeriodElapsedHalfCpltCallback(htim); +#else + HAL_TIM_PeriodElapsedHalfCpltCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +} + +/** + * @brief TIM DMA Trigger callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +static void TIM_DMATriggerCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (htim->hdma[TIM_DMA_ID_TRIGGER]->Init.Mode == DMA_NORMAL) + { + htim->State = HAL_TIM_STATE_READY; + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->TriggerCallback(htim); +#else + HAL_TIM_TriggerCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +} + +/** + * @brief TIM DMA Trigger half complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +static void TIM_DMATriggerHalfCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->TriggerHalfCpltCallback(htim); +#else + HAL_TIM_TriggerHalfCpltCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +} + +/** + * @brief Time Base configuration + * @param TIMx TIM peripheral + * @param Structure TIM Base configuration structure + * @retval None + */ +void TIM_Base_SetConfig(TIM_TypeDef *TIMx, TIM_Base_InitTypeDef *Structure) +{ + uint32_t tmpcr1; + tmpcr1 = TIMx->CR1; + + /* Set TIM Time Base Unit parameters ---------------------------------------*/ + if (IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx)) + { + /* Select the Counter Mode */ + tmpcr1 &= ~(TIM_CR1_DIR | TIM_CR1_CMS); + tmpcr1 |= Structure->CounterMode; + } + + if (IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx)) + { + /* Set the clock division */ + tmpcr1 &= ~TIM_CR1_CKD; + tmpcr1 |= (uint32_t)Structure->ClockDivision; + } + + /* Set the auto-reload preload */ + MODIFY_REG(tmpcr1, TIM_CR1_ARPE, Structure->AutoReloadPreload); + + TIMx->CR1 = tmpcr1; + + /* Set the Autoreload value */ + TIMx->ARR = (uint32_t)Structure->Period ; + + /* Set the Prescaler value */ + TIMx->PSC = Structure->Prescaler; + + if (IS_TIM_REPETITION_COUNTER_INSTANCE(TIMx)) + { + /* Set the Repetition Counter value */ + TIMx->RCR = Structure->RepetitionCounter; + } + + /* Generate an update event to reload the Prescaler + and the repetition counter (only for advanced timer) value immediately */ + TIMx->EGR = TIM_EGR_UG; +} + +/** + * @brief Timer Output Compare 1 configuration + * @param TIMx to select the TIM peripheral + * @param OC_Config The output configuration structure + * @retval None + */ +static void TIM_OC1_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config) +{ + uint32_t tmpccmrx; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Disable the Channel 1: Reset the CC1E Bit */ + TIMx->CCER &= ~TIM_CCER_CC1E; + + /* Get the TIMx CCER register value */ + tmpccer = TIMx->CCER; + /* Get the TIMx CR2 register value */ + tmpcr2 = TIMx->CR2; + + /* Get the TIMx CCMR1 register value */ + tmpccmrx = TIMx->CCMR1; + + /* Reset the Output Compare Mode Bits */ + tmpccmrx &= ~TIM_CCMR1_OC1M; + tmpccmrx &= ~TIM_CCMR1_CC1S; + /* Select the Output Compare Mode */ + tmpccmrx |= OC_Config->OCMode; + + /* Reset the Output Polarity level */ + tmpccer &= ~TIM_CCER_CC1P; + /* Set the Output Compare Polarity */ + tmpccer |= OC_Config->OCPolarity; + + if (IS_TIM_CCXN_INSTANCE(TIMx, TIM_CHANNEL_1)) + { + /* Check parameters */ + assert_param(IS_TIM_OCN_POLARITY(OC_Config->OCNPolarity)); + + /* Reset the Output N Polarity level */ + tmpccer &= ~TIM_CCER_CC1NP; + /* Set the Output N Polarity */ + tmpccer |= OC_Config->OCNPolarity; + /* Reset the Output N State */ + tmpccer &= ~TIM_CCER_CC1NE; + } + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + /* Check parameters */ + assert_param(IS_TIM_OCNIDLE_STATE(OC_Config->OCNIdleState)); + assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState)); + + /* Reset the Output Compare and Output Compare N IDLE State */ + tmpcr2 &= ~TIM_CR2_OIS1; + tmpcr2 &= ~TIM_CR2_OIS1N; + /* Set the Output Idle state */ + tmpcr2 |= OC_Config->OCIdleState; + /* Set the Output N Idle state */ + tmpcr2 |= OC_Config->OCNIdleState; + } + + /* Write to TIMx CR2 */ + TIMx->CR2 = tmpcr2; + + /* Write to TIMx CCMR1 */ + TIMx->CCMR1 = tmpccmrx; + + /* Set the Capture Compare Register value */ + TIMx->CCR1 = OC_Config->Pulse; + + /* Write to TIMx CCER */ + TIMx->CCER = tmpccer; +} + +/** + * @brief Timer Output Compare 2 configuration + * @param TIMx to select the TIM peripheral + * @param OC_Config The output configuration structure + * @retval None + */ +void TIM_OC2_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config) +{ + uint32_t tmpccmrx; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Disable the Channel 2: Reset the CC2E Bit */ + TIMx->CCER &= ~TIM_CCER_CC2E; + + /* Get the TIMx CCER register value */ + tmpccer = TIMx->CCER; + /* Get the TIMx CR2 register value */ + tmpcr2 = TIMx->CR2; + + /* Get the TIMx CCMR1 register value */ + tmpccmrx = TIMx->CCMR1; + + /* Reset the Output Compare mode and Capture/Compare selection Bits */ + tmpccmrx &= ~TIM_CCMR1_OC2M; + tmpccmrx &= ~TIM_CCMR1_CC2S; + + /* Select the Output Compare Mode */ + tmpccmrx |= (OC_Config->OCMode << 8U); + + /* Reset the Output Polarity level */ + tmpccer &= ~TIM_CCER_CC2P; + /* Set the Output Compare Polarity */ + tmpccer |= (OC_Config->OCPolarity << 4U); + + if (IS_TIM_CCXN_INSTANCE(TIMx, TIM_CHANNEL_2)) + { + assert_param(IS_TIM_OCN_POLARITY(OC_Config->OCNPolarity)); + + /* Reset the Output N Polarity level */ + tmpccer &= ~TIM_CCER_CC2NP; + /* Set the Output N Polarity */ + tmpccer |= (OC_Config->OCNPolarity << 4U); + /* Reset the Output N State */ + tmpccer &= ~TIM_CCER_CC2NE; + + } + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + /* Check parameters */ + assert_param(IS_TIM_OCNIDLE_STATE(OC_Config->OCNIdleState)); + assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState)); + + /* Reset the Output Compare and Output Compare N IDLE State */ + tmpcr2 &= ~TIM_CR2_OIS2; + tmpcr2 &= ~TIM_CR2_OIS2N; + /* Set the Output Idle state */ + tmpcr2 |= (OC_Config->OCIdleState << 2U); + /* Set the Output N Idle state */ + tmpcr2 |= (OC_Config->OCNIdleState << 2U); + } + + /* Write to TIMx CR2 */ + TIMx->CR2 = tmpcr2; + + /* Write to TIMx CCMR1 */ + TIMx->CCMR1 = tmpccmrx; + + /* Set the Capture Compare Register value */ + TIMx->CCR2 = OC_Config->Pulse; + + /* Write to TIMx CCER */ + TIMx->CCER = tmpccer; +} + +/** + * @brief Timer Output Compare 3 configuration + * @param TIMx to select the TIM peripheral + * @param OC_Config The output configuration structure + * @retval None + */ +static void TIM_OC3_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config) +{ + uint32_t tmpccmrx; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Disable the Channel 3: Reset the CC2E Bit */ + TIMx->CCER &= ~TIM_CCER_CC3E; + + /* Get the TIMx CCER register value */ + tmpccer = TIMx->CCER; + /* Get the TIMx CR2 register value */ + tmpcr2 = TIMx->CR2; + + /* Get the TIMx CCMR2 register value */ + tmpccmrx = TIMx->CCMR2; + + /* Reset the Output Compare mode and Capture/Compare selection Bits */ + tmpccmrx &= ~TIM_CCMR2_OC3M; + tmpccmrx &= ~TIM_CCMR2_CC3S; + /* Select the Output Compare Mode */ + tmpccmrx |= OC_Config->OCMode; + + /* Reset the Output Polarity level */ + tmpccer &= ~TIM_CCER_CC3P; + /* Set the Output Compare Polarity */ + tmpccer |= (OC_Config->OCPolarity << 8U); + + if (IS_TIM_CCXN_INSTANCE(TIMx, TIM_CHANNEL_3)) + { + assert_param(IS_TIM_OCN_POLARITY(OC_Config->OCNPolarity)); + + /* Reset the Output N Polarity level */ + tmpccer &= ~TIM_CCER_CC3NP; + /* Set the Output N Polarity */ + tmpccer |= (OC_Config->OCNPolarity << 8U); + /* Reset the Output N State */ + tmpccer &= ~TIM_CCER_CC3NE; + } + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + /* Check parameters */ + assert_param(IS_TIM_OCNIDLE_STATE(OC_Config->OCNIdleState)); + assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState)); + + /* Reset the Output Compare and Output Compare N IDLE State */ + tmpcr2 &= ~TIM_CR2_OIS3; + tmpcr2 &= ~TIM_CR2_OIS3N; + /* Set the Output Idle state */ + tmpcr2 |= (OC_Config->OCIdleState << 4U); + /* Set the Output N Idle state */ + tmpcr2 |= (OC_Config->OCNIdleState << 4U); + } + + /* Write to TIMx CR2 */ + TIMx->CR2 = tmpcr2; + + /* Write to TIMx CCMR2 */ + TIMx->CCMR2 = tmpccmrx; + + /* Set the Capture Compare Register value */ + TIMx->CCR3 = OC_Config->Pulse; + + /* Write to TIMx CCER */ + TIMx->CCER = tmpccer; +} + +/** + * @brief Timer Output Compare 4 configuration + * @param TIMx to select the TIM peripheral + * @param OC_Config The output configuration structure + * @retval None + */ +static void TIM_OC4_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config) +{ + uint32_t tmpccmrx; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Disable the Channel 4: Reset the CC4E Bit */ + TIMx->CCER &= ~TIM_CCER_CC4E; + + /* Get the TIMx CCER register value */ + tmpccer = TIMx->CCER; + /* Get the TIMx CR2 register value */ + tmpcr2 = TIMx->CR2; + + /* Get the TIMx CCMR2 register value */ + tmpccmrx = TIMx->CCMR2; + + /* Reset the Output Compare mode and Capture/Compare selection Bits */ + tmpccmrx &= ~TIM_CCMR2_OC4M; + tmpccmrx &= ~TIM_CCMR2_CC4S; + + /* Select the Output Compare Mode */ + tmpccmrx |= (OC_Config->OCMode << 8U); + + /* Reset the Output Polarity level */ + tmpccer &= ~TIM_CCER_CC4P; + /* Set the Output Compare Polarity */ + tmpccer |= (OC_Config->OCPolarity << 12U); + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + /* Check parameters */ + assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState)); + + /* Reset the Output Compare IDLE State */ + tmpcr2 &= ~TIM_CR2_OIS4; + + /* Set the Output Idle state */ + tmpcr2 |= (OC_Config->OCIdleState << 6U); + } + + /* Write to TIMx CR2 */ + TIMx->CR2 = tmpcr2; + + /* Write to TIMx CCMR2 */ + TIMx->CCMR2 = tmpccmrx; + + /* Set the Capture Compare Register value */ + TIMx->CCR4 = OC_Config->Pulse; + + /* Write to TIMx CCER */ + TIMx->CCER = tmpccer; +} + +/** + * @brief Slave Timer configuration function + * @param htim TIM handle + * @param sSlaveConfig Slave timer configuration + * @retval None + */ +static HAL_StatusTypeDef TIM_SlaveTimer_SetConfig(TIM_HandleTypeDef *htim, + TIM_SlaveConfigTypeDef *sSlaveConfig) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + uint32_t tmpccmr1; + uint32_t tmpccer; + + /* Get the TIMx SMCR register value */ + tmpsmcr = htim->Instance->SMCR; + + /* Reset the Trigger Selection Bits */ + tmpsmcr &= ~TIM_SMCR_TS; + /* Set the Input Trigger source */ + tmpsmcr |= sSlaveConfig->InputTrigger; + + /* Reset the slave mode Bits */ + tmpsmcr &= ~TIM_SMCR_SMS; + /* Set the slave mode */ + tmpsmcr |= sSlaveConfig->SlaveMode; + + /* Write to TIMx SMCR */ + htim->Instance->SMCR = tmpsmcr; + + /* Configure the trigger prescaler, filter, and polarity */ + switch (sSlaveConfig->InputTrigger) + { + case TIM_TS_ETRF: + { + /* Check the parameters */ + assert_param(IS_TIM_CLOCKSOURCE_ETRMODE1_INSTANCE(htim->Instance)); + assert_param(IS_TIM_TRIGGERPRESCALER(sSlaveConfig->TriggerPrescaler)); + assert_param(IS_TIM_TRIGGERPOLARITY(sSlaveConfig->TriggerPolarity)); + assert_param(IS_TIM_TRIGGERFILTER(sSlaveConfig->TriggerFilter)); + /* Configure the ETR Trigger source */ + TIM_ETR_SetConfig(htim->Instance, + sSlaveConfig->TriggerPrescaler, + sSlaveConfig->TriggerPolarity, + sSlaveConfig->TriggerFilter); + break; + } + + case TIM_TS_TI1F_ED: + { + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + assert_param(IS_TIM_TRIGGERFILTER(sSlaveConfig->TriggerFilter)); + + if (sSlaveConfig->SlaveMode == TIM_SLAVEMODE_GATED) + { + return HAL_ERROR; + } + + /* Disable the Channel 1: Reset the CC1E Bit */ + tmpccer = htim->Instance->CCER; + htim->Instance->CCER &= ~TIM_CCER_CC1E; + tmpccmr1 = htim->Instance->CCMR1; + + /* Set the filter */ + tmpccmr1 &= ~TIM_CCMR1_IC1F; + tmpccmr1 |= ((sSlaveConfig->TriggerFilter) << 4U); + + /* Write to TIMx CCMR1 and CCER registers */ + htim->Instance->CCMR1 = tmpccmr1; + htim->Instance->CCER = tmpccer; + break; + } + + case TIM_TS_TI1FP1: + { + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(htim->Instance)); + assert_param(IS_TIM_TRIGGERPOLARITY(sSlaveConfig->TriggerPolarity)); + assert_param(IS_TIM_TRIGGERFILTER(sSlaveConfig->TriggerFilter)); + + /* Configure TI1 Filter and Polarity */ + TIM_TI1_ConfigInputStage(htim->Instance, + sSlaveConfig->TriggerPolarity, + sSlaveConfig->TriggerFilter); + break; + } + + case TIM_TS_TI2FP2: + { + /* Check the parameters */ + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + assert_param(IS_TIM_TRIGGERPOLARITY(sSlaveConfig->TriggerPolarity)); + assert_param(IS_TIM_TRIGGERFILTER(sSlaveConfig->TriggerFilter)); + + /* Configure TI2 Filter and Polarity */ + TIM_TI2_ConfigInputStage(htim->Instance, + sSlaveConfig->TriggerPolarity, + sSlaveConfig->TriggerFilter); + break; + } + + case TIM_TS_ITR0: + case TIM_TS_ITR1: + case TIM_TS_ITR2: + case TIM_TS_ITR3: + { + /* Check the parameter */ + assert_param(IS_TIM_CC2_INSTANCE(htim->Instance)); + break; + } + + default: + status = HAL_ERROR; + break; + } + + return status; +} + +/** + * @brief Configure the TI1 as Input. + * @param TIMx to select the TIM peripheral. + * @param TIM_ICPolarity The Input Polarity. + * This parameter can be one of the following values: + * @arg TIM_ICPOLARITY_RISING + * @arg TIM_ICPOLARITY_FALLING + * @arg TIM_ICPOLARITY_BOTHEDGE + * @param TIM_ICSelection specifies the input to be used. + * This parameter can be one of the following values: + * @arg TIM_ICSELECTION_DIRECTTI: TIM Input 1 is selected to be connected to IC1. + * @arg TIM_ICSELECTION_INDIRECTTI: TIM Input 1 is selected to be connected to IC2. + * @arg TIM_ICSELECTION_TRC: TIM Input 1 is selected to be connected to TRC. + * @param TIM_ICFilter Specifies the Input Capture Filter. + * This parameter must be a value between 0x00 and 0x0F. + * @retval None + * @note TIM_ICFilter and TIM_ICPolarity are not used in INDIRECT mode as TI2FP1 + * (on channel2 path) is used as the input signal. Therefore CCMR1 must be + * protected against un-initialized filter and polarity values. + */ +void TIM_TI1_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, + uint32_t TIM_ICFilter) +{ + uint32_t tmpccmr1; + uint32_t tmpccer; + + /* Disable the Channel 1: Reset the CC1E Bit */ + TIMx->CCER &= ~TIM_CCER_CC1E; + tmpccmr1 = TIMx->CCMR1; + tmpccer = TIMx->CCER; + + /* Select the Input */ + if (IS_TIM_CC2_INSTANCE(TIMx) != RESET) + { + tmpccmr1 &= ~TIM_CCMR1_CC1S; + tmpccmr1 |= TIM_ICSelection; + } + else + { + tmpccmr1 |= TIM_CCMR1_CC1S_0; + } + + /* Set the filter */ + tmpccmr1 &= ~TIM_CCMR1_IC1F; + tmpccmr1 |= ((TIM_ICFilter << 4U) & TIM_CCMR1_IC1F); + + /* Select the Polarity and set the CC1E Bit */ + tmpccer &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP); + tmpccer |= (TIM_ICPolarity & (TIM_CCER_CC1P | TIM_CCER_CC1NP)); + + /* Write to TIMx CCMR1 and CCER registers */ + TIMx->CCMR1 = tmpccmr1; + TIMx->CCER = tmpccer; +} + +/** + * @brief Configure the Polarity and Filter for TI1. + * @param TIMx to select the TIM peripheral. + * @param TIM_ICPolarity The Input Polarity. + * This parameter can be one of the following values: + * @arg TIM_ICPOLARITY_RISING + * @arg TIM_ICPOLARITY_FALLING + * @arg TIM_ICPOLARITY_BOTHEDGE + * @param TIM_ICFilter Specifies the Input Capture Filter. + * This parameter must be a value between 0x00 and 0x0F. + * @retval None + */ +static void TIM_TI1_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter) +{ + uint32_t tmpccmr1; + uint32_t tmpccer; + + /* Disable the Channel 1: Reset the CC1E Bit */ + tmpccer = TIMx->CCER; + TIMx->CCER &= ~TIM_CCER_CC1E; + tmpccmr1 = TIMx->CCMR1; + + /* Set the filter */ + tmpccmr1 &= ~TIM_CCMR1_IC1F; + tmpccmr1 |= (TIM_ICFilter << 4U); + + /* Select the Polarity and set the CC1E Bit */ + tmpccer &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP); + tmpccer |= TIM_ICPolarity; + + /* Write to TIMx CCMR1 and CCER registers */ + TIMx->CCMR1 = tmpccmr1; + TIMx->CCER = tmpccer; +} + +/** + * @brief Configure the TI2 as Input. + * @param TIMx to select the TIM peripheral + * @param TIM_ICPolarity The Input Polarity. + * This parameter can be one of the following values: + * @arg TIM_ICPOLARITY_RISING + * @arg TIM_ICPOLARITY_FALLING + * @arg TIM_ICPOLARITY_BOTHEDGE + * @param TIM_ICSelection specifies the input to be used. + * This parameter can be one of the following values: + * @arg TIM_ICSELECTION_DIRECTTI: TIM Input 2 is selected to be connected to IC2. + * @arg TIM_ICSELECTION_INDIRECTTI: TIM Input 2 is selected to be connected to IC1. + * @arg TIM_ICSELECTION_TRC: TIM Input 2 is selected to be connected to TRC. + * @param TIM_ICFilter Specifies the Input Capture Filter. + * This parameter must be a value between 0x00 and 0x0F. + * @retval None + * @note TIM_ICFilter and TIM_ICPolarity are not used in INDIRECT mode as TI1FP2 + * (on channel1 path) is used as the input signal. Therefore CCMR1 must be + * protected against un-initialized filter and polarity values. + */ +static void TIM_TI2_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, + uint32_t TIM_ICFilter) +{ + uint32_t tmpccmr1; + uint32_t tmpccer; + + /* Disable the Channel 2: Reset the CC2E Bit */ + TIMx->CCER &= ~TIM_CCER_CC2E; + tmpccmr1 = TIMx->CCMR1; + tmpccer = TIMx->CCER; + + /* Select the Input */ + tmpccmr1 &= ~TIM_CCMR1_CC2S; + tmpccmr1 |= (TIM_ICSelection << 8U); + + /* Set the filter */ + tmpccmr1 &= ~TIM_CCMR1_IC2F; + tmpccmr1 |= ((TIM_ICFilter << 12U) & TIM_CCMR1_IC2F); + + /* Select the Polarity and set the CC2E Bit */ + tmpccer &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP); + tmpccer |= ((TIM_ICPolarity << 4U) & (TIM_CCER_CC2P | TIM_CCER_CC2NP)); + + /* Write to TIMx CCMR1 and CCER registers */ + TIMx->CCMR1 = tmpccmr1 ; + TIMx->CCER = tmpccer; +} + +/** + * @brief Configure the Polarity and Filter for TI2. + * @param TIMx to select the TIM peripheral. + * @param TIM_ICPolarity The Input Polarity. + * This parameter can be one of the following values: + * @arg TIM_ICPOLARITY_RISING + * @arg TIM_ICPOLARITY_FALLING + * @arg TIM_ICPOLARITY_BOTHEDGE + * @param TIM_ICFilter Specifies the Input Capture Filter. + * This parameter must be a value between 0x00 and 0x0F. + * @retval None + */ +static void TIM_TI2_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter) +{ + uint32_t tmpccmr1; + uint32_t tmpccer; + + /* Disable the Channel 2: Reset the CC2E Bit */ + TIMx->CCER &= ~TIM_CCER_CC2E; + tmpccmr1 = TIMx->CCMR1; + tmpccer = TIMx->CCER; + + /* Set the filter */ + tmpccmr1 &= ~TIM_CCMR1_IC2F; + tmpccmr1 |= (TIM_ICFilter << 12U); + + /* Select the Polarity and set the CC2E Bit */ + tmpccer &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP); + tmpccer |= (TIM_ICPolarity << 4U); + + /* Write to TIMx CCMR1 and CCER registers */ + TIMx->CCMR1 = tmpccmr1 ; + TIMx->CCER = tmpccer; +} + +/** + * @brief Configure the TI3 as Input. + * @param TIMx to select the TIM peripheral + * @param TIM_ICPolarity The Input Polarity. + * This parameter can be one of the following values: + * @arg TIM_ICPOLARITY_RISING + * @arg TIM_ICPOLARITY_FALLING + * @arg TIM_ICPOLARITY_BOTHEDGE + * @param TIM_ICSelection specifies the input to be used. + * This parameter can be one of the following values: + * @arg TIM_ICSELECTION_DIRECTTI: TIM Input 3 is selected to be connected to IC3. + * @arg TIM_ICSELECTION_INDIRECTTI: TIM Input 3 is selected to be connected to IC4. + * @arg TIM_ICSELECTION_TRC: TIM Input 3 is selected to be connected to TRC. + * @param TIM_ICFilter Specifies the Input Capture Filter. + * This parameter must be a value between 0x00 and 0x0F. + * @retval None + * @note TIM_ICFilter and TIM_ICPolarity are not used in INDIRECT mode as TI3FP4 + * (on channel1 path) is used as the input signal. Therefore CCMR2 must be + * protected against un-initialized filter and polarity values. + */ +static void TIM_TI3_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, + uint32_t TIM_ICFilter) +{ + uint32_t tmpccmr2; + uint32_t tmpccer; + + /* Disable the Channel 3: Reset the CC3E Bit */ + TIMx->CCER &= ~TIM_CCER_CC3E; + tmpccmr2 = TIMx->CCMR2; + tmpccer = TIMx->CCER; + + /* Select the Input */ + tmpccmr2 &= ~TIM_CCMR2_CC3S; + tmpccmr2 |= TIM_ICSelection; + + /* Set the filter */ + tmpccmr2 &= ~TIM_CCMR2_IC3F; + tmpccmr2 |= ((TIM_ICFilter << 4U) & TIM_CCMR2_IC3F); + + /* Select the Polarity and set the CC3E Bit */ + tmpccer &= ~(TIM_CCER_CC3P | TIM_CCER_CC3NP); + tmpccer |= ((TIM_ICPolarity << 8U) & (TIM_CCER_CC3P | TIM_CCER_CC3NP)); + + /* Write to TIMx CCMR2 and CCER registers */ + TIMx->CCMR2 = tmpccmr2; + TIMx->CCER = tmpccer; +} + +/** + * @brief Configure the TI4 as Input. + * @param TIMx to select the TIM peripheral + * @param TIM_ICPolarity The Input Polarity. + * This parameter can be one of the following values: + * @arg TIM_ICPOLARITY_RISING + * @arg TIM_ICPOLARITY_FALLING + * @arg TIM_ICPOLARITY_BOTHEDGE + * @param TIM_ICSelection specifies the input to be used. + * This parameter can be one of the following values: + * @arg TIM_ICSELECTION_DIRECTTI: TIM Input 4 is selected to be connected to IC4. + * @arg TIM_ICSELECTION_INDIRECTTI: TIM Input 4 is selected to be connected to IC3. + * @arg TIM_ICSELECTION_TRC: TIM Input 4 is selected to be connected to TRC. + * @param TIM_ICFilter Specifies the Input Capture Filter. + * This parameter must be a value between 0x00 and 0x0F. + * @note TIM_ICFilter and TIM_ICPolarity are not used in INDIRECT mode as TI4FP3 + * (on channel1 path) is used as the input signal. Therefore CCMR2 must be + * protected against un-initialized filter and polarity values. + * @retval None + */ +static void TIM_TI4_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICSelection, + uint32_t TIM_ICFilter) +{ + uint32_t tmpccmr2; + uint32_t tmpccer; + + /* Disable the Channel 4: Reset the CC4E Bit */ + TIMx->CCER &= ~TIM_CCER_CC4E; + tmpccmr2 = TIMx->CCMR2; + tmpccer = TIMx->CCER; + + /* Select the Input */ + tmpccmr2 &= ~TIM_CCMR2_CC4S; + tmpccmr2 |= (TIM_ICSelection << 8U); + + /* Set the filter */ + tmpccmr2 &= ~TIM_CCMR2_IC4F; + tmpccmr2 |= ((TIM_ICFilter << 12U) & TIM_CCMR2_IC4F); + + /* Select the Polarity and set the CC4E Bit */ + tmpccer &= ~(TIM_CCER_CC4P | TIM_CCER_CC4NP); + tmpccer |= ((TIM_ICPolarity << 12U) & (TIM_CCER_CC4P | TIM_CCER_CC4NP)); + + /* Write to TIMx CCMR2 and CCER registers */ + TIMx->CCMR2 = tmpccmr2; + TIMx->CCER = tmpccer ; +} + +/** + * @brief Selects the Input Trigger source + * @param TIMx to select the TIM peripheral + * @param InputTriggerSource The Input Trigger source. + * This parameter can be one of the following values: + * @arg TIM_TS_ITR0: Internal Trigger 0 + * @arg TIM_TS_ITR1: Internal Trigger 1 + * @arg TIM_TS_ITR2: Internal Trigger 2 + * @arg TIM_TS_ITR3: Internal Trigger 3 + * @arg TIM_TS_TI1F_ED: TI1 Edge Detector + * @arg TIM_TS_TI1FP1: Filtered Timer Input 1 + * @arg TIM_TS_TI2FP2: Filtered Timer Input 2 + * @arg TIM_TS_ETRF: External Trigger input + * @retval None + */ +static void TIM_ITRx_SetConfig(TIM_TypeDef *TIMx, uint32_t InputTriggerSource) +{ + uint32_t tmpsmcr; + + /* Get the TIMx SMCR register value */ + tmpsmcr = TIMx->SMCR; + /* Reset the TS Bits */ + tmpsmcr &= ~TIM_SMCR_TS; + /* Set the Input Trigger source and the slave mode*/ + tmpsmcr |= (InputTriggerSource | TIM_SLAVEMODE_EXTERNAL1); + /* Write to TIMx SMCR */ + TIMx->SMCR = tmpsmcr; +} +/** + * @brief Configures the TIMx External Trigger (ETR). + * @param TIMx to select the TIM peripheral + * @param TIM_ExtTRGPrescaler The external Trigger Prescaler. + * This parameter can be one of the following values: + * @arg TIM_ETRPRESCALER_DIV1: ETRP Prescaler OFF. + * @arg TIM_ETRPRESCALER_DIV2: ETRP frequency divided by 2. + * @arg TIM_ETRPRESCALER_DIV4: ETRP frequency divided by 4. + * @arg TIM_ETRPRESCALER_DIV8: ETRP frequency divided by 8. + * @param TIM_ExtTRGPolarity The external Trigger Polarity. + * This parameter can be one of the following values: + * @arg TIM_ETRPOLARITY_INVERTED: active low or falling edge active. + * @arg TIM_ETRPOLARITY_NONINVERTED: active high or rising edge active. + * @param ExtTRGFilter External Trigger Filter. + * This parameter must be a value between 0x00 and 0x0F + * @retval None + */ +void TIM_ETR_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ExtTRGPrescaler, + uint32_t TIM_ExtTRGPolarity, uint32_t ExtTRGFilter) +{ + uint32_t tmpsmcr; + + tmpsmcr = TIMx->SMCR; + + /* Reset the ETR Bits */ + tmpsmcr &= ~(TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP); + + /* Set the Prescaler, the Filter value and the Polarity */ + tmpsmcr |= (uint32_t)(TIM_ExtTRGPrescaler | (TIM_ExtTRGPolarity | (ExtTRGFilter << 8U))); + + /* Write to TIMx SMCR */ + TIMx->SMCR = tmpsmcr; +} + +/** + * @brief Enables or disables the TIM Capture Compare Channel x. + * @param TIMx to select the TIM peripheral + * @param Channel specifies the TIM Channel + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 + * @arg TIM_CHANNEL_2: TIM Channel 2 + * @arg TIM_CHANNEL_3: TIM Channel 3 + * @arg TIM_CHANNEL_4: TIM Channel 4 + * @param ChannelState specifies the TIM Channel CCxE bit new state. + * This parameter can be: TIM_CCx_ENABLE or TIM_CCx_DISABLE. + * @retval None + */ +void TIM_CCxChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ChannelState) +{ + uint32_t tmp; + + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(TIMx)); + assert_param(IS_TIM_CHANNELS(Channel)); + + tmp = TIM_CCER_CC1E << (Channel & 0x1FU); /* 0x1FU = 31 bits max shift */ + + /* Reset the CCxE Bit */ + TIMx->CCER &= ~tmp; + + /* Set or reset the CCxE Bit */ + TIMx->CCER |= (uint32_t)(ChannelState << (Channel & 0x1FU)); /* 0x1FU = 31 bits max shift */ +} + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) +/** + * @brief Reset interrupt callbacks to the legacy weak callbacks. + * @param htim pointer to a TIM_HandleTypeDef structure that contains + * the configuration information for TIM module. + * @retval None + */ +void TIM_ResetCallback(TIM_HandleTypeDef *htim) +{ + /* Reset the TIM callback to the legacy weak callbacks */ + htim->PeriodElapsedCallback = HAL_TIM_PeriodElapsedCallback; + htim->PeriodElapsedHalfCpltCallback = HAL_TIM_PeriodElapsedHalfCpltCallback; + htim->TriggerCallback = HAL_TIM_TriggerCallback; + htim->TriggerHalfCpltCallback = HAL_TIM_TriggerHalfCpltCallback; + htim->IC_CaptureCallback = HAL_TIM_IC_CaptureCallback; + htim->IC_CaptureHalfCpltCallback = HAL_TIM_IC_CaptureHalfCpltCallback; + htim->OC_DelayElapsedCallback = HAL_TIM_OC_DelayElapsedCallback; + htim->PWM_PulseFinishedCallback = HAL_TIM_PWM_PulseFinishedCallback; + htim->PWM_PulseFinishedHalfCpltCallback = HAL_TIM_PWM_PulseFinishedHalfCpltCallback; + htim->ErrorCallback = HAL_TIM_ErrorCallback; + htim->CommutationCallback = HAL_TIMEx_CommutCallback; + htim->CommutationHalfCpltCallback = HAL_TIMEx_CommutHalfCpltCallback; + htim->BreakCallback = HAL_TIMEx_BreakCallback; +} +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + +/** + * @} + */ + +#endif /* HAL_TIM_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim_ex.c new file mode 100644 index 0000000..a7fdb9e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tim_ex.c @@ -0,0 +1,2390 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_tim_ex.c + * @author MCD Application Team + * @brief TIM HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Timer Extended peripheral: + * + Time Hall Sensor Interface Initialization + * + Time Hall Sensor Interface Start + * + Time Complementary signal break and dead time configuration + * + Time Master and Slave synchronization configuration + * + Time OCRef clear configuration + * + Timer remapping capabilities configuration + @verbatim + ============================================================================== + ##### TIMER Extended features ##### + ============================================================================== + [..] + The Timer Extended features include: + (#) Complementary outputs with programmable dead-time for : + (++) Output Compare + (++) PWM generation (Edge and Center-aligned Mode) + (++) One-pulse mode output + (#) Synchronization circuit to control the timer with external signals and to + interconnect several timers together. + (#) Break input to put the timer output signals in reset state or in a known state. + (#) Supports incremental (quadrature) encoder and hall-sensor circuitry for + positioning purposes + + ##### How to use this driver ##### + ============================================================================== + [..] + (#) Initialize the TIM low level resources by implementing the following functions + depending on the selected feature: + (++) Hall Sensor output : HAL_TIMEx_HallSensor_MspInit() + + (#) Initialize the TIM low level resources : + (##) Enable the TIM interface clock using __HAL_RCC_TIMx_CLK_ENABLE(); + (##) TIM pins configuration + (+++) Enable the clock for the TIM GPIOs using the following function: + __HAL_RCC_GPIOx_CLK_ENABLE(); + (+++) Configure these TIM pins in Alternate function mode using HAL_GPIO_Init(); + + (#) The external Clock can be configured, if needed (the default clock is the + internal clock from the APBx), using the following function: + HAL_TIM_ConfigClockSource, the clock configuration should be done before + any start function. + + (#) Configure the TIM in the desired functioning mode using one of the + initialization function of this driver: + (++) HAL_TIMEx_HallSensor_Init() and HAL_TIMEx_ConfigCommutEvent(): to use the + Timer Hall Sensor Interface and the commutation event with the corresponding + Interrupt and DMA request if needed (Note that One Timer is used to interface + with the Hall sensor Interface and another Timer should be used to use + the commutation event). + + (#) Activate the TIM peripheral using one of the start functions: + (++) Complementary Output Compare : HAL_TIMEx_OCN_Start(), HAL_TIMEx_OCN_Start_DMA(), + HAL_TIMEx_OCN_Start_IT() + (++) Complementary PWM generation : HAL_TIMEx_PWMN_Start(), HAL_TIMEx_PWMN_Start_DMA(), + HAL_TIMEx_PWMN_Start_IT() + (++) Complementary One-pulse mode output : HAL_TIMEx_OnePulseN_Start(), HAL_TIMEx_OnePulseN_Start_IT() + (++) Hall Sensor output : HAL_TIMEx_HallSensor_Start(), HAL_TIMEx_HallSensor_Start_DMA(), + HAL_TIMEx_HallSensor_Start_IT(). + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup TIMEx TIMEx + * @brief TIM Extended HAL module driver + * @{ + */ + +#ifdef HAL_TIM_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +static void TIM_DMADelayPulseNCplt(DMA_HandleTypeDef *hdma); +static void TIM_DMAErrorCCxN(DMA_HandleTypeDef *hdma); +static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ChannelNState); + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup TIMEx_Exported_Functions TIM Extended Exported Functions + * @{ + */ + +/** @defgroup TIMEx_Exported_Functions_Group1 Extended Timer Hall Sensor functions + * @brief Timer Hall Sensor functions + * +@verbatim + ============================================================================== + ##### Timer Hall Sensor functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and configure TIM HAL Sensor. + (+) De-initialize TIM HAL Sensor. + (+) Start the Hall Sensor Interface. + (+) Stop the Hall Sensor Interface. + (+) Start the Hall Sensor Interface and enable interrupts. + (+) Stop the Hall Sensor Interface and disable interrupts. + (+) Start the Hall Sensor Interface and enable DMA transfers. + (+) Stop the Hall Sensor Interface and disable DMA transfers. + +@endverbatim + * @{ + */ +/** + * @brief Initializes the TIM Hall Sensor Interface and initialize the associated handle. + * @note When the timer instance is initialized in Hall Sensor Interface mode, + * timer channels 1 and channel 2 are reserved and cannot be used for + * other purpose. + * @param htim TIM Hall Sensor Interface handle + * @param sConfig TIM Hall Sensor configuration structure + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Init(TIM_HandleTypeDef *htim, TIM_HallSensor_InitTypeDef *sConfig) +{ + TIM_OC_InitTypeDef OC_Config; + + /* Check the TIM handle allocation */ + if (htim == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); + assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode)); + assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision)); + assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload)); + assert_param(IS_TIM_IC_POLARITY(sConfig->IC1Polarity)); + assert_param(IS_TIM_IC_PRESCALER(sConfig->IC1Prescaler)); + assert_param(IS_TIM_IC_FILTER(sConfig->IC1Filter)); + + if (htim->State == HAL_TIM_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htim->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + /* Reset interrupt callbacks to legacy week callbacks */ + TIM_ResetCallback(htim); + + if (htim->HallSensor_MspInitCallback == NULL) + { + htim->HallSensor_MspInitCallback = HAL_TIMEx_HallSensor_MspInit; + } + /* Init the low level hardware : GPIO, CLOCK, NVIC */ + htim->HallSensor_MspInitCallback(htim); +#else + /* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */ + HAL_TIMEx_HallSensor_MspInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + } + + /* Set the TIM state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Configure the Time base in the Encoder Mode */ + TIM_Base_SetConfig(htim->Instance, &htim->Init); + + /* Configure the Channel 1 as Input Channel to interface with the three Outputs of the Hall sensor */ + TIM_TI1_SetConfig(htim->Instance, sConfig->IC1Polarity, TIM_ICSELECTION_TRC, sConfig->IC1Filter); + + /* Reset the IC1PSC Bits */ + htim->Instance->CCMR1 &= ~TIM_CCMR1_IC1PSC; + /* Set the IC1PSC value */ + htim->Instance->CCMR1 |= sConfig->IC1Prescaler; + + /* Enable the Hall sensor interface (XOR function of the three inputs) */ + htim->Instance->CR2 |= TIM_CR2_TI1S; + + /* Select the TIM_TS_TI1F_ED signal as Input trigger for the TIM */ + htim->Instance->SMCR &= ~TIM_SMCR_TS; + htim->Instance->SMCR |= TIM_TS_TI1F_ED; + + /* Use the TIM_TS_TI1F_ED signal to reset the TIM counter each edge detection */ + htim->Instance->SMCR &= ~TIM_SMCR_SMS; + htim->Instance->SMCR |= TIM_SLAVEMODE_RESET; + + /* Program channel 2 in PWM 2 mode with the desired Commutation_Delay*/ + OC_Config.OCFastMode = TIM_OCFAST_DISABLE; + OC_Config.OCIdleState = TIM_OCIDLESTATE_RESET; + OC_Config.OCMode = TIM_OCMODE_PWM2; + OC_Config.OCNIdleState = TIM_OCNIDLESTATE_RESET; + OC_Config.OCNPolarity = TIM_OCNPOLARITY_HIGH; + OC_Config.OCPolarity = TIM_OCPOLARITY_HIGH; + OC_Config.Pulse = sConfig->Commutation_Delay; + + TIM_OC2_SetConfig(htim->Instance, &OC_Config); + + /* Select OC2REF as trigger output on TRGO: write the MMS bits in the TIMx_CR2 + register to 101 */ + htim->Instance->CR2 &= ~TIM_CR2_MMS; + htim->Instance->CR2 |= TIM_TRGO_OC2REF; + + /* Initialize the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_READY; + + /* Initialize the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Initialize the TIM state*/ + htim->State = HAL_TIM_STATE_READY; + + return HAL_OK; +} + +/** + * @brief DeInitializes the TIM Hall Sensor interface + * @param htim TIM Hall Sensor Interface handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_DeInit(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(htim->Instance)); + + htim->State = HAL_TIM_STATE_BUSY; + + /* Disable the TIM Peripheral Clock */ + __HAL_TIM_DISABLE(htim); + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + if (htim->HallSensor_MspDeInitCallback == NULL) + { + htim->HallSensor_MspDeInitCallback = HAL_TIMEx_HallSensor_MspDeInit; + } + /* DeInit the low level hardware */ + htim->HallSensor_MspDeInitCallback(htim); +#else + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + HAL_TIMEx_HallSensor_MspDeInit(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + /* Change the DMA burst operation state */ + htim->DMABurstState = HAL_DMA_BURST_STATE_RESET; + + /* Change the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_RESET); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_RESET); + + /* Change TIM state */ + htim->State = HAL_TIM_STATE_RESET; + + /* Release Lock */ + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Initializes the TIM Hall Sensor MSP. + * @param htim TIM Hall Sensor Interface handle + * @retval None + */ +__weak void HAL_TIMEx_HallSensor_MspInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIMEx_HallSensor_MspInit could be implemented in the user file + */ +} + +/** + * @brief DeInitializes TIM Hall Sensor MSP. + * @param htim TIM Hall Sensor Interface handle + * @retval None + */ +__weak void HAL_TIMEx_HallSensor_MspDeInit(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIMEx_HallSensor_MspDeInit could be implemented in the user file + */ +} + +/** + * @brief Starts the TIM Hall Sensor Interface. + * @param htim TIM Hall Sensor Interface handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start(TIM_HandleTypeDef *htim) +{ + uint32_t tmpsmcr; + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); + + /* Check the TIM channels state */ + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the Input Capture channel 1 + (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, + TIM_CHANNEL_2 and TIM_CHANNEL_3) */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Hall sensor Interface. + * @param htim TIM Hall Sensor Interface handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); + + /* Disable the Input Capture channels 1, 2 and 3 + (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, + TIM_CHANNEL_2 and TIM_CHANNEL_3) */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Hall Sensor Interface in interrupt mode. + * @param htim TIM Hall Sensor Interface handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_IT(TIM_HandleTypeDef *htim) +{ + uint32_t tmpsmcr; + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); + + /* Check the TIM channels state */ + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the capture compare Interrupts 1 event */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + + /* Enable the Input Capture channel 1 + (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, + TIM_CHANNEL_2 and TIM_CHANNEL_3) */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Hall Sensor Interface in interrupt mode. + * @param htim TIM Hall Sensor Interface handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_IT(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); + + /* Disable the Input Capture channel 1 + (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, + TIM_CHANNEL_2 and TIM_CHANNEL_3) */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + + /* Disable the capture compare Interrupts event */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Hall Sensor Interface in DMA mode. + * @param htim TIM Hall Sensor Interface handle + * @param pData The destination Buffer address. + * @param Length The length of data to be transferred from TIM peripheral to memory. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Start_DMA(TIM_HandleTypeDef *htim, uint32_t *pData, uint16_t Length) +{ + uint32_t tmpsmcr; + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); + + /* Set the TIM channel state */ + if ((channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY) + || (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_BUSY)) + { + return HAL_BUSY; + } + else if ((channel_1_state == HAL_TIM_CHANNEL_STATE_READY) + && (complementary_channel_1_state == HAL_TIM_CHANNEL_STATE_READY)) + { + if ((pData == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + + /* Enable the Input Capture channel 1 + (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, + TIM_CHANNEL_2 and TIM_CHANNEL_3) */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_ENABLE); + + /* Set the DMA Input Capture 1 Callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMACaptureCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMACaptureHalfCplt; + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAError ; + + /* Enable the DMA channel for Capture 1*/ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)&htim->Instance->CCR1, (uint32_t)pData, Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the capture compare 1 Interrupt */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Hall Sensor Interface in DMA mode. + * @param htim TIM Hall Sensor Interface handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_HallSensor_Stop_DMA(TIM_HandleTypeDef *htim) +{ + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(htim->Instance)); + + /* Disable the Input Capture channel 1 + (in the Hall Sensor Interface the three possible channels that can be used are TIM_CHANNEL_1, + TIM_CHANNEL_2 and TIM_CHANNEL_3) */ + TIM_CCxChannelCmd(htim->Instance, TIM_CHANNEL_1, TIM_CCx_DISABLE); + + + /* Disable the capture compare Interrupts 1 event */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channel state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup TIMEx_Exported_Functions_Group2 Extended Timer Complementary Output Compare functions + * @brief Timer Complementary Output Compare functions + * +@verbatim + ============================================================================== + ##### Timer Complementary Output Compare functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Start the Complementary Output Compare/PWM. + (+) Stop the Complementary Output Compare/PWM. + (+) Start the Complementary Output Compare/PWM and enable interrupts. + (+) Stop the Complementary Output Compare/PWM and disable interrupts. + (+) Start the Complementary Output Compare/PWM and enable DMA transfers. + (+) Stop the Complementary Output Compare/PWM and disable DMA transfers. + +@endverbatim + * @{ + */ + +/** + * @brief Starts the TIM Output Compare signal generation on the complementary + * output. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Start(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM complementary channel state */ + if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the Capture compare channel N */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM Output Compare signal generation on the complementary + * output. + * @param htim TIM handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Disable the Capture compare channel N */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM Output Compare signal generation in interrupt mode + * on the complementary output. + * @param htim TIM OC handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM complementary channel state */ + if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Enable the TIM Output Compare interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Enable the TIM Output Compare interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Enable the TIM Output Compare interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC3); + break; + } + + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the TIM Break interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_BREAK); + + /* Enable the Capture compare channel N */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM Output Compare signal generation in interrupt mode + * on the complementary output. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpccer; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Output Compare interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Output Compare interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Output Compare interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC3); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Capture compare channel N */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); + + /* Disable the TIM Break interrupt (only if no more channel is active) */ + tmpccer = htim->Instance->CCER; + if ((tmpccer & (TIM_CCER_CC1NE | TIM_CCER_CC2NE | TIM_CCER_CC3NE)) == (uint32_t)RESET) + { + __HAL_TIM_DISABLE_IT(htim, TIM_IT_BREAK); + } + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @brief Starts the TIM Output Compare signal generation in DMA mode + * on the complementary output. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @param pData The source Buffer address. + * @param Length The length of data to be transferred from memory to TIM peripheral + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Set the TIM complementary channel state */ + if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_BUSY) + { + return HAL_BUSY; + } + else if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY) + { + if ((pData == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseNCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAErrorCCxN ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Output Compare DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseNCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAErrorCCxN ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Output Compare DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseNCplt; + htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAErrorCCxN ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Output Compare DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC3); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the Capture compare channel N */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM Output Compare signal generation in DMA mode + * on the complementary output. + * @param htim TIM Output Compare handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OCN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Output Compare DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Output Compare DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC2); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Output Compare DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC3); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC3]); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the Capture compare channel N */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @} + */ + +/** @defgroup TIMEx_Exported_Functions_Group3 Extended Timer Complementary PWM functions + * @brief Timer Complementary PWM functions + * +@verbatim + ============================================================================== + ##### Timer Complementary PWM functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Start the Complementary PWM. + (+) Stop the Complementary PWM. + (+) Start the Complementary PWM and enable interrupts. + (+) Stop the Complementary PWM and disable interrupts. + (+) Start the Complementary PWM and enable DMA transfers. + (+) Stop the Complementary PWM and disable DMA transfers. + (+) Start the Complementary Input Capture measurement. + (+) Stop the Complementary Input Capture. + (+) Start the Complementary Input Capture and enable interrupts. + (+) Stop the Complementary Input Capture and disable interrupts. + (+) Start the Complementary Input Capture and enable DMA transfers. + (+) Stop the Complementary Input Capture and disable DMA transfers. + (+) Start the Complementary One Pulse generation. + (+) Stop the Complementary One Pulse. + (+) Start the Complementary One Pulse and enable interrupts. + (+) Stop the Complementary One Pulse and disable interrupts. + +@endverbatim + * @{ + */ + +/** + * @brief Starts the PWM signal generation on the complementary output. + * @param htim TIM handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Start(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM complementary channel state */ + if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the complementary PWM output */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the PWM signal generation on the complementary output. + * @param htim TIM handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Disable the complementary PWM output */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the PWM signal generation in interrupt mode on the + * complementary output. + * @param htim TIM handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Check the TIM complementary channel state */ + if (TIM_CHANNEL_N_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY) + { + return HAL_ERROR; + } + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Enable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Enable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Enable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC3); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the TIM Break interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_BREAK); + + /* Enable the complementary PWM output */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the PWM signal generation in interrupt mode on the + * complementary output. + * @param htim TIM handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpccer; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC3); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the complementary PWM output */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); + + /* Disable the TIM Break interrupt (only if no more channel is active) */ + tmpccer = htim->Instance->CCER; + if ((tmpccer & (TIM_CCER_CC1NE | TIM_CCER_CC2NE | TIM_CCER_CC3NE)) == (uint32_t)RESET) + { + __HAL_TIM_DISABLE_IT(htim, TIM_IT_BREAK); + } + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @brief Starts the TIM PWM signal generation in DMA mode on the + * complementary output + * @param htim TIM handle + * @param Channel TIM Channel to be enabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @param pData The source Buffer address. + * @param Length The length of data to be transferred from memory to TIM peripheral + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Start_DMA(TIM_HandleTypeDef *htim, uint32_t Channel, uint32_t *pData, uint16_t Length) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + /* Set the TIM complementary channel state */ + if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_BUSY) + { + return HAL_BUSY; + } + else if (TIM_CHANNEL_N_STATE_GET(htim, Channel) == HAL_TIM_CHANNEL_STATE_READY) + { + if ((pData == NULL) && (Length > 0U)) + { + return HAL_ERROR; + } + else + { + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY); + } + } + else + { + return HAL_ERROR; + } + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC1]->XferCpltCallback = TIM_DMADelayPulseNCplt; + htim->hdma[TIM_DMA_ID_CC1]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC1]->XferErrorCallback = TIM_DMAErrorCCxN ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC1], (uint32_t)pData, (uint32_t)&htim->Instance->CCR1, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC1); + break; + } + + case TIM_CHANNEL_2: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC2]->XferCpltCallback = TIM_DMADelayPulseNCplt; + htim->hdma[TIM_DMA_ID_CC2]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC2]->XferErrorCallback = TIM_DMAErrorCCxN ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC2], (uint32_t)pData, (uint32_t)&htim->Instance->CCR2, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC2); + break; + } + + case TIM_CHANNEL_3: + { + /* Set the DMA compare callbacks */ + htim->hdma[TIM_DMA_ID_CC3]->XferCpltCallback = TIM_DMADelayPulseNCplt; + htim->hdma[TIM_DMA_ID_CC3]->XferHalfCpltCallback = TIM_DMADelayPulseHalfCplt; + + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_CC3]->XferErrorCallback = TIM_DMAErrorCCxN ; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(htim->hdma[TIM_DMA_ID_CC3], (uint32_t)pData, (uint32_t)&htim->Instance->CCR3, + Length) != HAL_OK) + { + /* Return error status */ + return HAL_ERROR; + } + /* Enable the TIM Capture/Compare 3 DMA request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_CC3); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Enable the complementary PWM output */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */ + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS; + if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr)) + { + __HAL_TIM_ENABLE(htim); + } + } + else + { + __HAL_TIM_ENABLE(htim); + } + } + + /* Return function status */ + return status; +} + +/** + * @brief Stops the TIM PWM signal generation in DMA mode on the complementary + * output + * @param htim TIM handle + * @param Channel TIM Channel to be disabled + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @arg TIM_CHANNEL_3: TIM Channel 3 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_PWMN_Stop_DMA(TIM_HandleTypeDef *htim, uint32_t Channel) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, Channel)); + + switch (Channel) + { + case TIM_CHANNEL_1: + { + /* Disable the TIM Capture/Compare 1 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC1); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC1]); + break; + } + + case TIM_CHANNEL_2: + { + /* Disable the TIM Capture/Compare 2 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC2); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC2]); + break; + } + + case TIM_CHANNEL_3: + { + /* Disable the TIM Capture/Compare 3 DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_CC3); + (void)HAL_DMA_Abort_IT(htim->hdma[TIM_DMA_ID_CC3]); + break; + } + + default: + status = HAL_ERROR; + break; + } + + if (status == HAL_OK) + { + /* Disable the complementary PWM output */ + TIM_CCxNChannelCmd(htim->Instance, Channel, TIM_CCxN_DISABLE); + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM complementary channel state */ + TIM_CHANNEL_N_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY); + } + + /* Return function status */ + return status; +} + +/** + * @} + */ + +/** @defgroup TIMEx_Exported_Functions_Group4 Extended Timer Complementary One Pulse functions + * @brief Timer Complementary One Pulse functions + * +@verbatim + ============================================================================== + ##### Timer Complementary One Pulse functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Start the Complementary One Pulse generation. + (+) Stop the Complementary One Pulse. + (+) Start the Complementary One Pulse and enable interrupts. + (+) Stop the Complementary One Pulse and disable interrupts. + +@endverbatim + * @{ + */ + +/** + * @brief Starts the TIM One Pulse signal generation on the complementary + * output. + * @note OutputChannel must match the pulse output channel chosen when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel pulse output channel to enable + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1; + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel)); + + /* Check the TIM channels state */ + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the complementary One Pulse output channel and the Input Capture channel */ + TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_ENABLE); + TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM One Pulse signal generation on the complementary + * output. + * @note OutputChannel must match the pulse output channel chosen when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel pulse output channel to disable + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel)); + + /* Disable the complementary One Pulse output channel and the Input Capture channel */ + TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_DISABLE); + TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_DISABLE); + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Starts the TIM One Pulse signal generation in interrupt mode on the + * complementary channel. + * @note OutputChannel must match the pulse output channel chosen when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel pulse output channel to enable + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Start_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1; + HAL_TIM_ChannelStateTypeDef channel_1_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef channel_2_state = TIM_CHANNEL_STATE_GET(htim, TIM_CHANNEL_2); + HAL_TIM_ChannelStateTypeDef complementary_channel_1_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_1); + HAL_TIM_ChannelStateTypeDef complementary_channel_2_state = TIM_CHANNEL_N_STATE_GET(htim, TIM_CHANNEL_2); + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel)); + + /* Check the TIM channels state */ + if ((channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (channel_2_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_1_state != HAL_TIM_CHANNEL_STATE_READY) + || (complementary_channel_2_state != HAL_TIM_CHANNEL_STATE_READY)) + { + return HAL_ERROR; + } + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_BUSY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_BUSY); + + /* Enable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC1); + + /* Enable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_CC2); + + /* Enable the complementary One Pulse output channel and the Input Capture channel */ + TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_ENABLE); + TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_ENABLE); + + /* Enable the Main Output */ + __HAL_TIM_MOE_ENABLE(htim); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stops the TIM One Pulse signal generation in interrupt mode on the + * complementary channel. + * @note OutputChannel must match the pulse output channel chosen when calling + * @ref HAL_TIM_OnePulse_ConfigChannel(). + * @param htim TIM One Pulse handle + * @param OutputChannel pulse output channel to disable + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 selected + * @arg TIM_CHANNEL_2: TIM Channel 2 selected + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_OnePulseN_Stop_IT(TIM_HandleTypeDef *htim, uint32_t OutputChannel) +{ + uint32_t input_channel = (OutputChannel == TIM_CHANNEL_1) ? TIM_CHANNEL_2 : TIM_CHANNEL_1; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, OutputChannel)); + + /* Disable the TIM Capture/Compare 1 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC1); + + /* Disable the TIM Capture/Compare 2 interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_CC2); + + /* Disable the complementary One Pulse output channel and the Input Capture channel */ + TIM_CCxNChannelCmd(htim->Instance, OutputChannel, TIM_CCxN_DISABLE); + TIM_CCxChannelCmd(htim->Instance, input_channel, TIM_CCx_DISABLE); + + /* Disable the Main Output */ + __HAL_TIM_MOE_DISABLE(htim); + + /* Disable the Peripheral */ + __HAL_TIM_DISABLE(htim); + + /* Set the TIM channels state */ + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + + /* Return function status */ + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup TIMEx_Exported_Functions_Group5 Extended Peripheral Control functions + * @brief Peripheral Control functions + * +@verbatim + ============================================================================== + ##### Peripheral Control functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Configure the commutation event in case of use of the Hall sensor interface. + (+) Configure Output channels for OC and PWM mode. + + (+) Configure Complementary channels, break features and dead time. + (+) Configure Master synchronization. + (+) Configure timer remapping capabilities. + +@endverbatim + * @{ + */ + +/** + * @brief Configure the TIM commutation event sequence. + * @note This function is mandatory to use the commutation event in order to + * update the configuration at each commutation detection on the TRGI input of the Timer, + * the typical use of this feature is with the use of another Timer(interface Timer) + * configured in Hall sensor interface, this interface Timer will generate the + * commutation at its TRGO output (connected to Timer used in this function) each time + * the TI1 of the Interface Timer detect a commutation at its input TI1. + * @param htim TIM handle + * @param InputTrigger the Internal trigger corresponding to the Timer Interfacing with the Hall sensor + * This parameter can be one of the following values: + * @arg TIM_TS_ITR0: Internal trigger 0 selected + * @arg TIM_TS_ITR1: Internal trigger 1 selected + * @arg TIM_TS_ITR2: Internal trigger 2 selected + * @arg TIM_TS_ITR3: Internal trigger 3 selected + * @arg TIM_TS_NONE: No trigger is needed + * @param CommutationSource the Commutation Event source + * This parameter can be one of the following values: + * @arg TIM_COMMUTATION_TRGI: Commutation source is the TRGI of the Interface Timer + * @arg TIM_COMMUTATION_SOFTWARE: Commutation source is set by software using the COMG bit + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent(TIM_HandleTypeDef *htim, uint32_t InputTrigger, + uint32_t CommutationSource) +{ + /* Check the parameters */ + assert_param(IS_TIM_COMMUTATION_EVENT_INSTANCE(htim->Instance)); + assert_param(IS_TIM_INTERNAL_TRIGGEREVENT_SELECTION(InputTrigger)); + + __HAL_LOCK(htim); + + if ((InputTrigger == TIM_TS_ITR0) || (InputTrigger == TIM_TS_ITR1) || + (InputTrigger == TIM_TS_ITR2) || (InputTrigger == TIM_TS_ITR3)) + { + /* Select the Input trigger */ + htim->Instance->SMCR &= ~TIM_SMCR_TS; + htim->Instance->SMCR |= InputTrigger; + } + + /* Select the Capture Compare preload feature */ + htim->Instance->CR2 |= TIM_CR2_CCPC; + /* Select the Commutation event source */ + htim->Instance->CR2 &= ~TIM_CR2_CCUS; + htim->Instance->CR2 |= CommutationSource; + + /* Disable Commutation Interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_COM); + + /* Disable Commutation DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_COM); + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Configure the TIM commutation event sequence with interrupt. + * @note This function is mandatory to use the commutation event in order to + * update the configuration at each commutation detection on the TRGI input of the Timer, + * the typical use of this feature is with the use of another Timer(interface Timer) + * configured in Hall sensor interface, this interface Timer will generate the + * commutation at its TRGO output (connected to Timer used in this function) each time + * the TI1 of the Interface Timer detect a commutation at its input TI1. + * @param htim TIM handle + * @param InputTrigger the Internal trigger corresponding to the Timer Interfacing with the Hall sensor + * This parameter can be one of the following values: + * @arg TIM_TS_ITR0: Internal trigger 0 selected + * @arg TIM_TS_ITR1: Internal trigger 1 selected + * @arg TIM_TS_ITR2: Internal trigger 2 selected + * @arg TIM_TS_ITR3: Internal trigger 3 selected + * @arg TIM_TS_NONE: No trigger is needed + * @param CommutationSource the Commutation Event source + * This parameter can be one of the following values: + * @arg TIM_COMMUTATION_TRGI: Commutation source is the TRGI of the Interface Timer + * @arg TIM_COMMUTATION_SOFTWARE: Commutation source is set by software using the COMG bit + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_IT(TIM_HandleTypeDef *htim, uint32_t InputTrigger, + uint32_t CommutationSource) +{ + /* Check the parameters */ + assert_param(IS_TIM_COMMUTATION_EVENT_INSTANCE(htim->Instance)); + assert_param(IS_TIM_INTERNAL_TRIGGEREVENT_SELECTION(InputTrigger)); + + __HAL_LOCK(htim); + + if ((InputTrigger == TIM_TS_ITR0) || (InputTrigger == TIM_TS_ITR1) || + (InputTrigger == TIM_TS_ITR2) || (InputTrigger == TIM_TS_ITR3)) + { + /* Select the Input trigger */ + htim->Instance->SMCR &= ~TIM_SMCR_TS; + htim->Instance->SMCR |= InputTrigger; + } + + /* Select the Capture Compare preload feature */ + htim->Instance->CR2 |= TIM_CR2_CCPC; + /* Select the Commutation event source */ + htim->Instance->CR2 &= ~TIM_CR2_CCUS; + htim->Instance->CR2 |= CommutationSource; + + /* Disable Commutation DMA request */ + __HAL_TIM_DISABLE_DMA(htim, TIM_DMA_COM); + + /* Enable the Commutation Interrupt */ + __HAL_TIM_ENABLE_IT(htim, TIM_IT_COM); + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Configure the TIM commutation event sequence with DMA. + * @note This function is mandatory to use the commutation event in order to + * update the configuration at each commutation detection on the TRGI input of the Timer, + * the typical use of this feature is with the use of another Timer(interface Timer) + * configured in Hall sensor interface, this interface Timer will generate the + * commutation at its TRGO output (connected to Timer used in this function) each time + * the TI1 of the Interface Timer detect a commutation at its input TI1. + * @note The user should configure the DMA in his own software, in This function only the COMDE bit is set + * @param htim TIM handle + * @param InputTrigger the Internal trigger corresponding to the Timer Interfacing with the Hall sensor + * This parameter can be one of the following values: + * @arg TIM_TS_ITR0: Internal trigger 0 selected + * @arg TIM_TS_ITR1: Internal trigger 1 selected + * @arg TIM_TS_ITR2: Internal trigger 2 selected + * @arg TIM_TS_ITR3: Internal trigger 3 selected + * @arg TIM_TS_NONE: No trigger is needed + * @param CommutationSource the Commutation Event source + * This parameter can be one of the following values: + * @arg TIM_COMMUTATION_TRGI: Commutation source is the TRGI of the Interface Timer + * @arg TIM_COMMUTATION_SOFTWARE: Commutation source is set by software using the COMG bit + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_ConfigCommutEvent_DMA(TIM_HandleTypeDef *htim, uint32_t InputTrigger, + uint32_t CommutationSource) +{ + /* Check the parameters */ + assert_param(IS_TIM_COMMUTATION_EVENT_INSTANCE(htim->Instance)); + assert_param(IS_TIM_INTERNAL_TRIGGEREVENT_SELECTION(InputTrigger)); + + __HAL_LOCK(htim); + + if ((InputTrigger == TIM_TS_ITR0) || (InputTrigger == TIM_TS_ITR1) || + (InputTrigger == TIM_TS_ITR2) || (InputTrigger == TIM_TS_ITR3)) + { + /* Select the Input trigger */ + htim->Instance->SMCR &= ~TIM_SMCR_TS; + htim->Instance->SMCR |= InputTrigger; + } + + /* Select the Capture Compare preload feature */ + htim->Instance->CR2 |= TIM_CR2_CCPC; + /* Select the Commutation event source */ + htim->Instance->CR2 &= ~TIM_CR2_CCUS; + htim->Instance->CR2 |= CommutationSource; + + /* Enable the Commutation DMA Request */ + /* Set the DMA Commutation Callback */ + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferCpltCallback = TIMEx_DMACommutationCplt; + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferHalfCpltCallback = TIMEx_DMACommutationHalfCplt; + /* Set the DMA error callback */ + htim->hdma[TIM_DMA_ID_COMMUTATION]->XferErrorCallback = TIM_DMAError; + + /* Disable Commutation Interrupt */ + __HAL_TIM_DISABLE_IT(htim, TIM_IT_COM); + + /* Enable the Commutation DMA Request */ + __HAL_TIM_ENABLE_DMA(htim, TIM_DMA_COM); + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Configures the TIM in master mode. + * @param htim TIM handle. + * @param sMasterConfig pointer to a TIM_MasterConfigTypeDef structure that + * contains the selected trigger output (TRGO) and the Master/Slave + * mode. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim, + TIM_MasterConfigTypeDef *sMasterConfig) +{ + uint32_t tmpcr2; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_MASTER_INSTANCE(htim->Instance)); + assert_param(IS_TIM_TRGO_SOURCE(sMasterConfig->MasterOutputTrigger)); + assert_param(IS_TIM_MSM_STATE(sMasterConfig->MasterSlaveMode)); + + /* Check input state */ + __HAL_LOCK(htim); + + /* Change the handler state */ + htim->State = HAL_TIM_STATE_BUSY; + + /* Get the TIMx CR2 register value */ + tmpcr2 = htim->Instance->CR2; + + /* Get the TIMx SMCR register value */ + tmpsmcr = htim->Instance->SMCR; + + /* Reset the MMS Bits */ + tmpcr2 &= ~TIM_CR2_MMS; + /* Select the TRGO source */ + tmpcr2 |= sMasterConfig->MasterOutputTrigger; + + /* Update TIMx CR2 */ + htim->Instance->CR2 = tmpcr2; + + if (IS_TIM_SLAVE_INSTANCE(htim->Instance)) + { + /* Reset the MSM Bit */ + tmpsmcr &= ~TIM_SMCR_MSM; + /* Set master mode */ + tmpsmcr |= sMasterConfig->MasterSlaveMode; + + /* Update TIMx SMCR */ + htim->Instance->SMCR = tmpsmcr; + } + + /* Change the htim state */ + htim->State = HAL_TIM_STATE_READY; + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Configures the Break feature, dead time, Lock level, OSSI/OSSR State + * and the AOE(automatic output enable). + * @param htim TIM handle + * @param sBreakDeadTimeConfig pointer to a TIM_ConfigBreakDeadConfigTypeDef structure that + * contains the BDTR Register configuration information for the TIM peripheral. + * @note Interrupts can be generated when an active level is detected on the + * break input, the break 2 input or the system break input. Break + * interrupt can be enabled by calling the @ref __HAL_TIM_ENABLE_IT macro. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_ConfigBreakDeadTime(TIM_HandleTypeDef *htim, + TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig) +{ + /* Keep this variable initialized to 0 as it is used to configure BDTR register */ + uint32_t tmpbdtr = 0U; + + /* Check the parameters */ + assert_param(IS_TIM_BREAK_INSTANCE(htim->Instance)); + assert_param(IS_TIM_OSSR_STATE(sBreakDeadTimeConfig->OffStateRunMode)); + assert_param(IS_TIM_OSSI_STATE(sBreakDeadTimeConfig->OffStateIDLEMode)); + assert_param(IS_TIM_LOCK_LEVEL(sBreakDeadTimeConfig->LockLevel)); + assert_param(IS_TIM_DEADTIME(sBreakDeadTimeConfig->DeadTime)); + assert_param(IS_TIM_BREAK_STATE(sBreakDeadTimeConfig->BreakState)); + assert_param(IS_TIM_BREAK_POLARITY(sBreakDeadTimeConfig->BreakPolarity)); + assert_param(IS_TIM_AUTOMATIC_OUTPUT_STATE(sBreakDeadTimeConfig->AutomaticOutput)); + + /* Check input state */ + __HAL_LOCK(htim); + + /* Set the Lock level, the Break enable Bit and the Polarity, the OSSR State, + the OSSI State, the dead time value and the Automatic Output Enable Bit */ + + /* Set the BDTR bits */ + MODIFY_REG(tmpbdtr, TIM_BDTR_DTG, sBreakDeadTimeConfig->DeadTime); + MODIFY_REG(tmpbdtr, TIM_BDTR_LOCK, sBreakDeadTimeConfig->LockLevel); + MODIFY_REG(tmpbdtr, TIM_BDTR_OSSI, sBreakDeadTimeConfig->OffStateIDLEMode); + MODIFY_REG(tmpbdtr, TIM_BDTR_OSSR, sBreakDeadTimeConfig->OffStateRunMode); + MODIFY_REG(tmpbdtr, TIM_BDTR_BKE, sBreakDeadTimeConfig->BreakState); + MODIFY_REG(tmpbdtr, TIM_BDTR_BKP, sBreakDeadTimeConfig->BreakPolarity); + MODIFY_REG(tmpbdtr, TIM_BDTR_AOE, sBreakDeadTimeConfig->AutomaticOutput); + + + /* Set TIMx_BDTR */ + htim->Instance->BDTR = tmpbdtr; + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @brief Configures the TIMx Remapping input capabilities. + * @param htim TIM handle. + * @param Remap specifies the TIM remapping source. + * For TIM14, the parameter can have the following values: + * @arg TIM_TIM14_GPIO: TIM14 TI1 is connected to GPIO + * @arg TIM_TIM14_RTC: TIM14 TI1 is connected to RTC_clock + * @arg TIM_TIM14_HSE: TIM14 TI1 is connected to HSE/32 + * @arg TIM_TIM14_MCO: TIM14 TI1 is connected to MCO + * + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TIMEx_RemapConfig(TIM_HandleTypeDef *htim, uint32_t Remap) +{ + __HAL_LOCK(htim); + + /* Check parameters */ + assert_param(IS_TIM_REMAP(htim->Instance, Remap)); + + /* Set the Timer remapping configuration */ + WRITE_REG(htim->Instance->OR, Remap); + + __HAL_UNLOCK(htim); + + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup TIMEx_Exported_Functions_Group6 Extended Callbacks functions + * @brief Extended Callbacks functions + * +@verbatim + ============================================================================== + ##### Extended Callbacks functions ##### + ============================================================================== + [..] + This section provides Extended TIM callback functions: + (+) Timer Commutation callback + (+) Timer Break callback + +@endverbatim + * @{ + */ + +/** + * @brief Hall commutation changed callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIMEx_CommutCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIMEx_CommutCallback could be implemented in the user file + */ +} +/** + * @brief Hall commutation changed half complete callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIMEx_CommutHalfCpltCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIMEx_CommutHalfCpltCallback could be implemented in the user file + */ +} + +/** + * @brief Hall Break detection callback in non-blocking mode + * @param htim TIM handle + * @retval None + */ +__weak void HAL_TIMEx_BreakCallback(TIM_HandleTypeDef *htim) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htim); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TIMEx_BreakCallback could be implemented in the user file + */ +} +/** + * @} + */ + +/** @defgroup TIMEx_Exported_Functions_Group7 Extended Peripheral State functions + * @brief Extended Peripheral State functions + * +@verbatim + ============================================================================== + ##### Extended Peripheral State functions ##### + ============================================================================== + [..] + This subsection permits to get in run-time the status of the peripheral + and the data flow. + +@endverbatim + * @{ + */ + +/** + * @brief Return the TIM Hall Sensor interface handle state. + * @param htim TIM Hall Sensor handle + * @retval HAL state + */ +HAL_TIM_StateTypeDef HAL_TIMEx_HallSensor_GetState(TIM_HandleTypeDef *htim) +{ + return htim->State; +} + +/** + * @brief Return actual state of the TIM complementary channel. + * @param htim TIM handle + * @param ChannelN TIM Complementary channel + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 + * @arg TIM_CHANNEL_2: TIM Channel 2 + * @arg TIM_CHANNEL_3: TIM Channel 3 + * @retval TIM Complementary channel state + */ +HAL_TIM_ChannelStateTypeDef HAL_TIMEx_GetChannelNState(TIM_HandleTypeDef *htim, uint32_t ChannelN) +{ + HAL_TIM_ChannelStateTypeDef channel_state; + + /* Check the parameters */ + assert_param(IS_TIM_CCXN_INSTANCE(htim->Instance, ChannelN)); + + channel_state = TIM_CHANNEL_N_STATE_GET(htim, ChannelN); + + return channel_state; +} +/** + * @} + */ + +/** + * @} + */ + +/* Private functions ---------------------------------------------------------*/ +/** @defgroup TIMEx_Private_Functions TIMEx Private Functions + * @{ + */ + +/** + * @brief TIM DMA Commutation callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +void TIMEx_DMACommutationCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + /* Change the htim state */ + htim->State = HAL_TIM_STATE_READY; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->CommutationCallback(htim); +#else + HAL_TIMEx_CommutCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +} + +/** + * @brief TIM DMA Commutation half complete callback. + * @param hdma pointer to DMA handle. + * @retval None + */ +void TIMEx_DMACommutationHalfCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + /* Change the htim state */ + htim->State = HAL_TIM_STATE_READY; + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->CommutationHalfCpltCallback(htim); +#else + HAL_TIMEx_CommutHalfCpltCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ +} + + +/** + * @brief TIM DMA Delay Pulse complete callback (complementary channel). + * @param hdma pointer to DMA handle. + * @retval None + */ +static void TIM_DMADelayPulseNCplt(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (hdma == htim->hdma[TIM_DMA_ID_CC1]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC2]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC3]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY); + } + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC4]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_4; + + if (hdma->Init.Mode == DMA_NORMAL) + { + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_4, HAL_TIM_CHANNEL_STATE_READY); + } + } + else + { + /* nothing to do */ + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->PWM_PulseFinishedCallback(htim); +#else + HAL_TIM_PWM_PulseFinishedCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; +} + +/** + * @brief TIM DMA error callback (complementary channel) + * @param hdma pointer to DMA handle. + * @retval None + */ +static void TIM_DMAErrorCCxN(DMA_HandleTypeDef *hdma) +{ + TIM_HandleTypeDef *htim = (TIM_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + if (hdma == htim->hdma[TIM_DMA_ID_CC1]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_1; + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY); + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC2]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_2; + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY); + } + else if (hdma == htim->hdma[TIM_DMA_ID_CC3]) + { + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_3; + TIM_CHANNEL_N_STATE_SET(htim, TIM_CHANNEL_3, HAL_TIM_CHANNEL_STATE_READY); + } + else + { + /* nothing to do */ + } + +#if (USE_HAL_TIM_REGISTER_CALLBACKS == 1) + htim->ErrorCallback(htim); +#else + HAL_TIM_ErrorCallback(htim); +#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */ + + htim->Channel = HAL_TIM_ACTIVE_CHANNEL_CLEARED; +} + +/** + * @brief Enables or disables the TIM Capture Compare Channel xN. + * @param TIMx to select the TIM peripheral + * @param Channel specifies the TIM Channel + * This parameter can be one of the following values: + * @arg TIM_CHANNEL_1: TIM Channel 1 + * @arg TIM_CHANNEL_2: TIM Channel 2 + * @arg TIM_CHANNEL_3: TIM Channel 3 + * @param ChannelNState specifies the TIM Channel CCxNE bit new state. + * This parameter can be: TIM_CCxN_ENABLE or TIM_CCxN_Disable. + * @retval None + */ +static void TIM_CCxNChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ChannelNState) +{ + uint32_t tmp; + + tmp = TIM_CCER_CC1NE << (Channel & 0x1FU); /* 0x1FU = 31 bits max shift */ + + /* Reset the CCxNE Bit */ + TIMx->CCER &= ~tmp; + + /* Set or reset the CCxNE Bit */ + TIMx->CCER |= (uint32_t)(ChannelNState << (Channel & 0x1FU)); /* 0x1FU = 31 bits max shift */ +} +/** + * @} + */ + +#endif /* HAL_TIM_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_alarm_template.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_alarm_template.c new file mode 100644 index 0000000..e809a38 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_alarm_template.c @@ -0,0 +1,318 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_timebase_rtc_alarm_template.c + * @brief HAL time base based on the hardware RTC_ALARM Template. + * + * This file override the native HAL time base functions (defined as weak) + * to use the RTC ALARM for time base generation: + * + Intializes the RTC peripheral to increment the seconds registers each 1ms + * + The alarm is configured to assert an interrupt when the RTC reaches 1ms + * + HAL_IncTick is called at each Alarm event and the time is reset to 00:00:00 + * + HSE (default), LSE or LSI can be selected as RTC clock source + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + This file must be copied to the application folder and modified as follows: + (#) Rename it to 'stm32f0xx_hal_timebase_rtc_alarm.c' + (#) Add this file and the RTC HAL drivers to your project and uncomment + HAL_RTC_MODULE_ENABLED define in stm32f0xx_hal_conf.h + + [..] + (@) HAL RTC alarm and HAL RTC wakeup drivers can’t be used with low power modes: + The wake up capability of the RTC may be intrusive in case of prior low power mode + configuration requiring different wake up sources. + Application/Example behavior is no more guaranteed + (@) The stm32f0xx_hal_timebase_tim use is recommended for the Applications/Examples + requiring low power modes + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup HAL_TimeBase_RTC_Alarm_Template HAL TimeBase RTC Alarm Template + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ + +/* Uncomment the line below to select the appropriate RTC Clock source for your application: + + RTC_CLOCK_SOURCE_HSE: can be selected for applications requiring timing precision. + + RTC_CLOCK_SOURCE_LSE: can be selected for applications with low constraint on timing + precision. + + RTC_CLOCK_SOURCE_LSI: can be selected for applications with low constraint on timing + precision. + */ +#define RTC_CLOCK_SOURCE_HSE +/* #define RTC_CLOCK_SOURCE_LSE */ +/* #define RTC_CLOCK_SOURCE_LSI */ + +#if defined(RTC_CLOCK_SOURCE_HSE) + #define RTC_ASYNCH_PREDIV 49U + #define RTC_SYNCH_PREDIV 4U +#elif defined(RTC_CLOCK_SOURCE_LSE) + #define RTC_ASYNCH_PREDIV 0U + #define RTC_SYNCH_PREDIV 31U +#else /* CLOCK_SOURCE_LSI */ + #define RTC_ASYNCH_PREDIV 0U + #define RTC_SYNCH_PREDIV 39U +#endif /* RTC_CLOCK_SOURCE_HSE */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +RTC_HandleTypeDef hRTC_Handle; +/* Private function prototypes -----------------------------------------------*/ +void RTC_IRQHandler(void); +/* Private functions ---------------------------------------------------------*/ + +/** + * @brief This function configures the RTC_ALARMA as a time base source. + * The time source is configured to have 1ms time base with a dedicated + * Tick interrupt priority. + * @note This function is called automatically at the beginning of program after + * reset by HAL_Init() or at any time when clock is configured, by HAL_RCC_ClockConfig(). + * @param TickPriority Tick interrupt priority. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_InitTick (uint32_t TickPriority) +{ + __IO uint32_t counter = 0U; + + RCC_OscInitTypeDef RCC_OscInitStruct; + RCC_PeriphCLKInitTypeDef PeriphClkInitStruct; + HAL_StatusTypeDef status; + +#ifdef RTC_CLOCK_SOURCE_LSE + /* Configue LSE as RTC clock soucre */ + RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSE; + RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; + RCC_OscInitStruct.LSEState = RCC_LSE_ON; + PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSE; +#elif defined (RTC_CLOCK_SOURCE_LSI) + /* Configue LSI as RTC clock soucre */ + RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSI; + RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; + RCC_OscInitStruct.LSIState = RCC_LSI_ON; + PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSI; +#elif defined (RTC_CLOCK_SOURCE_HSE) + /* Configue HSE as RTC clock soucre */ + RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; + RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; + RCC_OscInitStruct.HSEState = RCC_HSE_ON; + PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_HSE_DIV32; +#else +#error Please select the RTC Clock source +#endif /* RTC_CLOCK_SOURCE_LSE */ + + status = HAL_RCC_OscConfig(&RCC_OscInitStruct); + if (status == HAL_OK) + { + PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_RTC; + status = HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct); + } + if (status == HAL_OK) + { + /* Enable RTC Clock */ + __HAL_RCC_RTC_ENABLE(); + /* The time base should be 1ms + Time base = ((RTC_ASYNCH_PREDIV + 1) * (RTC_SYNCH_PREDIV + 1)) / RTC_CLOCK + HSE/32 as RTC clock and HSE 8MHz + Time base = ((49 + 1) * (4 + 1)) / 250kHz + = 1ms + LSE as RTC clock + Time base = ((31 + 1) * (0 + 1)) / 32.768KHz + = ~1ms + LSI as RTC clock + Time base = ((39 + 1) * (0 + 1)) / 40KHz + = 1ms + */ + hRTC_Handle.Instance = RTC; + hRTC_Handle.Init.HourFormat = RTC_HOURFORMAT_24; + hRTC_Handle.Init.AsynchPrediv = RTC_ASYNCH_PREDIV; + hRTC_Handle.Init.SynchPrediv = RTC_SYNCH_PREDIV; + hRTC_Handle.Init.OutPut = RTC_OUTPUT_DISABLE; + hRTC_Handle.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH; + hRTC_Handle.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN; + status = HAL_RTC_Init(&hRTC_Handle); + + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(&hRTC_Handle); + + /* Disable the Alarm A interrupt */ + __HAL_RTC_ALARMA_DISABLE(&hRTC_Handle); + + /* Clear flag alarm A */ + __HAL_RTC_ALARM_CLEAR_FLAG(&hRTC_Handle, RTC_FLAG_ALRAF); + + counter = 0U; + /* Wait till RTC ALRAWF flag is set and if Time out is reached exit */ + while (__HAL_RTC_ALARM_GET_FLAG(&hRTC_Handle, RTC_FLAG_ALRAWF) == RESET) + { + if (counter++ == (SystemCoreClock / 48U)) /* Timeout = ~ 1s */ + { + status = HAL_ERROR; + } + } + } + if (status == HAL_OK) + { + hRTC_Handle.Instance->ALRMAR = 0x01U; + + /* Configure the Alarm state: Enable Alarm */ + __HAL_RTC_ALARMA_ENABLE(&hRTC_Handle); + /* Configure the Alarm interrupt */ + __HAL_RTC_ALARM_ENABLE_IT(&hRTC_Handle, RTC_IT_ALRA); + + /* RTC Alarm Interrupt Configuration: EXTI configuration */ + __HAL_RTC_ALARM_EXTI_ENABLE_IT(); + __HAL_RTC_ALARM_EXTI_ENABLE_RISING_EDGE(); + + /* Check if the Initialization mode is set */ + if ((hRTC_Handle.Instance->ISR & RTC_ISR_INITF) == (uint32_t)RESET) + { + /* Set the Initialization mode */ + hRTC_Handle.Instance->ISR = (uint32_t)RTC_INIT_MASK; + counter = 0U; + while ((hRTC_Handle.Instance->ISR & RTC_ISR_INITF) == (uint32_t)RESET) + { + if (counter++ == (SystemCoreClock / 48U)) /* Timeout = ~ 1s */ + { + status = HAL_ERROR; + } + } + } + } + if (status == HAL_OK) + { + hRTC_Handle.Instance->DR = 0U; + hRTC_Handle.Instance->TR = 0U; + + hRTC_Handle.Instance->ISR &= (uint32_t)~RTC_ISR_INIT; + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(&hRTC_Handle); + + /* Enable the RTC Alarm Interrupt */ + HAL_NVIC_EnableIRQ(RTC_IRQn); + + /* Configure the SysTick IRQ priority */ + if (TickPriority < (1UL << __NVIC_PRIO_BITS)) + { + HAL_NVIC_SetPriority(RTC_IRQn, TickPriority, 0U); + uwTickPrio = TickPriority; + } + else + { + status = HAL_ERROR; + } + + } + return status; +} + +/** + * @brief Suspend Tick increment. + * @note Disable the tick increment by disabling RTC ALARM interrupt. + * @param None + * @retval None + */ +void HAL_SuspendTick(void) +{ + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(&hRTC_Handle); + /* Disable RTC ALARM update Interrupt */ + __HAL_RTC_ALARM_DISABLE_IT(&hRTC_Handle, RTC_IT_ALRA); + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(&hRTC_Handle); +} + +/** + * @brief Resume Tick increment. + * @note Enable the tick increment by Enabling RTC ALARM interrupt. + * @param None + * @retval None + */ +void HAL_ResumeTick(void) +{ + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(&hRTC_Handle); + /* Enable RTC ALARM Update interrupt */ + __HAL_RTC_ALARM_ENABLE_IT(&hRTC_Handle, RTC_IT_ALRA); + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(&hRTC_Handle); +} + +/** + * @brief ALARM A Event Callback in non blocking mode + * @note This function is called when RTC_ALARM interrupt took place, inside + * RTC_IRQHandler(). It makes a direct call to HAL_IncTick() to increment + * a global variable "uwTick" used as application time base. + * @param hrtc RTC handle + * @retval None + */ +void HAL_RTC_AlarmAEventCallback(RTC_HandleTypeDef *hrtc) +{ + __IO uint32_t counter = 0U; + + HAL_IncTick(); + + __HAL_RTC_WRITEPROTECTION_DISABLE(hrtc); + + /* Set the Initialization mode */ + hrtc->Instance->ISR = (uint32_t)RTC_INIT_MASK; + + while((hrtc->Instance->ISR & RTC_ISR_INITF) == (uint32_t)RESET) + { + if(counter++ == (SystemCoreClock /48U)) /* Timeout = ~ 1s */ + { + break; + } + } + + hrtc->Instance->DR = 0U; + hrtc->Instance->TR = 0U; + + hrtc->Instance->ISR &= (uint32_t)~RTC_ISR_INIT; + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(hrtc); +} + +/** + * @brief This function handles RTC ALARM interrupt request. + * @param None + * @retval None + */ +void RTC_IRQHandler(void) +{ + HAL_RTC_AlarmIRQHandler(&hRTC_Handle); +} + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_wakeup_template.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_wakeup_template.c new file mode 100644 index 0000000..9a151e5 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_rtc_wakeup_template.c @@ -0,0 +1,295 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_timebase_rtc_wakeup_template.c + * @brief HAL time base based on the hardware RTC_WAKEUP Template. + * + * This file overrides the native HAL time base functions (defined as weak) + * to use the RTC WAKEUP for the time base generation: + * + Intializes the RTC peripheral and configures the wakeup timer to be + * incremented each 1ms + * + The wakeup feature is configured to assert an interrupt each 1ms + * + HAL_IncTick is called inside the HAL_RTCEx_WakeUpTimerEventCallback + * + HSE (default), LSE or LSI can be selected as RTC clock source + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + This file must be copied to the application folder and modified as follows: + (#) Rename it to 'stm32f0xx_hal_timebase_rtc_wakeup.c' + (#) Add this file and the RTC HAL drivers to your project and uncomment + HAL_RTC_MODULE_ENABLED define in stm32f0xx_hal_conf.h + + [..] + (@) HAL RTC alarm and HAL RTC wakeup drivers can’t be used with low power modes: + The wake up capability of the RTC may be intrusive in case of prior low power mode + configuration requiring different wake up sources. + Application/Example behavior is no more guaranteed + (@) The stm32f0xx_hal_timebase_tim use is recommended for the Applications/Examples + requiring low power modes + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup HAL_TimeBase_RTC_WakeUp_Template HAL TimeBase RTC WakeUp Template + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ + +/* Uncomment the line below to select the appropriate RTC Clock source for your application: + + RTC_CLOCK_SOURCE_HSE: can be selected for applications requiring timing precision. + + RTC_CLOCK_SOURCE_LSE: can be selected for applications with low constraint on timing + precision. + + RTC_CLOCK_SOURCE_LSI: can be selected for applications with low constraint on timing + precision. + */ +#define RTC_CLOCK_SOURCE_HSE +/* #define RTC_CLOCK_SOURCE_LSE */ +/* #define RTC_CLOCK_SOURCE_LSI */ + +#if defined(RTC_CLOCK_SOURCE_HSE) + #define RTC_ASYNCH_PREDIV 49U + #define RTC_SYNCH_PREDIV 4U +#elif defined(RTC_CLOCK_SOURCE_LSE) + #define RTC_ASYNCH_PREDIV 0U + #define RTC_SYNCH_PREDIV 31U +#else /* CLOCK_SOURCE_LSI */ + #define RTC_ASYNCH_PREDIV 0U + #define RTC_SYNCH_PREDIV 39U +#endif /* RTC_CLOCK_SOURCE_HSE */ + +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +RTC_HandleTypeDef hRTC_Handle; + +/* Private function prototypes -----------------------------------------------*/ +void RTC_IRQHandler(void); + +/* Private functions ---------------------------------------------------------*/ + +/** + * @brief This function configures the RTC_WKUP as a time base source. + * The time source is configured to have 1ms time base with a dedicated + * Tick interrupt priority. + * Wakeup Time base = ((RTC_ASYNCH_PREDIV + 1) * (RTC_SYNCH_PREDIV + 1)) / RTC_CLOCK + = 1ms + * Wakeup Time = WakeupTimebase * WakeUpCounter (0 + 1) + = 1 ms + * @note This function is called automatically at the beginning of program after + * reset by HAL_Init() or at any time when clock is configured, by HAL_RCC_ClockConfig(). + * @param TickPriority Tick interrupt priority. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority) +{ + __IO uint32_t counter = 0U; + + RCC_OscInitTypeDef RCC_OscInitStruct; + RCC_PeriphCLKInitTypeDef PeriphClkInitStruct; + HAL_StatusTypeDef status; + +#ifdef RTC_CLOCK_SOURCE_LSE + /* Configue LSE as RTC clock soucre */ + RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSE; + RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; + RCC_OscInitStruct.LSEState = RCC_LSE_ON; + PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSE; +#elif defined (RTC_CLOCK_SOURCE_LSI) + /* Configue LSI as RTC clock soucre */ + RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_LSI; + RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; + RCC_OscInitStruct.LSIState = RCC_LSI_ON; + PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSI; +#elif defined (RTC_CLOCK_SOURCE_HSE) + /* Configue HSE as RTC clock soucre */ + RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; + RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; + RCC_OscInitStruct.HSEState = RCC_HSE_ON; + PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_HSE_DIV32; +#else +#error Please select the RTC Clock source +#endif /* RTC_CLOCK_SOURCE_LSE */ + + status = HAL_RCC_OscConfig(&RCC_OscInitStruct); + if (status == HAL_OK) + { + PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_RTC; + status = HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct); + } + if (status == HAL_OK) + { + /* Enable RTC Clock */ + __HAL_RCC_RTC_ENABLE(); + /* The time base should be 1ms + Time base = ((RTC_ASYNCH_PREDIV + 1) * (RTC_SYNCH_PREDIV + 1)) / RTC_CLOCK + HSE/32 as RTC clock and HSE 8MHz + Time base = ((49 + 1) * (4 + 1)) / 250kHz + = 1ms + LSE as RTC clock + Time base = ((31 + 1) * (0 + 1)) / 32.768Khz + = ~1ms + LSI as RTC clock + Time base = ((39 + 1) * (0 + 1)) / 40Khz + = 1ms + */ + hRTC_Handle.Instance = RTC; + hRTC_Handle.Init.HourFormat = RTC_HOURFORMAT_24; + hRTC_Handle.Init.AsynchPrediv = RTC_ASYNCH_PREDIV; + hRTC_Handle.Init.SynchPrediv = RTC_SYNCH_PREDIV; + hRTC_Handle.Init.OutPut = RTC_OUTPUT_DISABLE; + hRTC_Handle.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH; + hRTC_Handle.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN; + status = HAL_RTC_Init(&hRTC_Handle); + } + if (status == HAL_OK) + { + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(&hRTC_Handle); + + /* Disable the Wake-up Timer */ + __HAL_RTC_WAKEUPTIMER_DISABLE(&hRTC_Handle); + + /* In case of interrupt mode is used, the interrupt source must disabled */ + __HAL_RTC_WAKEUPTIMER_DISABLE_IT(&hRTC_Handle,RTC_IT_WUT); + + /* Wait till RTC WUTWF flag is set */ + while (__HAL_RTC_WAKEUPTIMER_GET_FLAG(&hRTC_Handle, RTC_FLAG_WUTWF) == RESET) + { + if (counter++ == (SystemCoreClock /48U)) + { + status = HAL_ERROR; + } + } + } + if (status == HAL_OK) + { + /* Clear PWR wake up Flag */ + __HAL_PWR_CLEAR_FLAG(PWR_FLAG_WU); + + /* Clear RTC Wake Up timer Flag */ + __HAL_RTC_WAKEUPTIMER_CLEAR_FLAG(&hRTC_Handle, RTC_FLAG_WUTF); + + /* Configure the Wake-up Timer counter */ + hRTC_Handle.Instance->WUTR = 0U; + + /* Clear the Wake-up Timer clock source bits in CR register */ + hRTC_Handle.Instance->CR &= (uint32_t)~RTC_CR_WUCKSEL; + + /* Configure the clock source */ + hRTC_Handle.Instance->CR |= (uint32_t)RTC_WAKEUPCLOCK_CK_SPRE_16BITS; + + /* RTC WakeUpTimer Interrupt Configuration: EXTI configuration */ + __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_IT(); + + __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_RISING_EDGE(); + + /* Configure the Interrupt in the RTC_CR register */ + __HAL_RTC_WAKEUPTIMER_ENABLE_IT(&hRTC_Handle, RTC_IT_WUT); + + /* Enable the Wake-up Timer */ + __HAL_RTC_WAKEUPTIMER_ENABLE(&hRTC_Handle); + + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(&hRTC_Handle); + + /* Enable the RTC global Interrupt */ + HAL_NVIC_EnableIRQ(RTC_IRQn); + + /* Configure the SysTick IRQ priority */ + if (TickPriority < (1UL << __NVIC_PRIO_BITS)) + { + HAL_NVIC_SetPriority(RTC_IRQn, TickPriority, 0U); + uwTickPrio = TickPriority; + } + else + { + status = HAL_ERROR; + } + } + return status; +} + +/** + * @brief Suspend Tick increment. + * @note Disable the tick increment by disabling RTC_WKUP interrupt. + * @param None + * @retval None + */ +void HAL_SuspendTick(void) +{ + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(&hRTC_Handle); + /* Disable WAKE UP TIMER Interrupt */ + __HAL_RTC_WAKEUPTIMER_DISABLE_IT(&hRTC_Handle, RTC_IT_WUT); + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(&hRTC_Handle); +} + +/** + * @brief Resume Tick increment. + * @note Enable the tick increment by Enabling RTC_WKUP interrupt. + * @param None + * @retval None + */ +void HAL_ResumeTick(void) +{ + /* Disable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_DISABLE(&hRTC_Handle); + /* Enable WAKE UP TIMER interrupt */ + __HAL_RTC_WAKEUPTIMER_ENABLE_IT(&hRTC_Handle, RTC_IT_WUT); + /* Enable the write protection for RTC registers */ + __HAL_RTC_WRITEPROTECTION_ENABLE(&hRTC_Handle); +} + +/** + * @brief Wake Up Timer Event Callback in non blocking mode + * @note This function is called when RTC_WKUP interrupt took place, inside + * RTC_IRQHandler(). It makes a direct call to HAL_IncTick() to increment + * a global variable "uwTick" used as application time base. + * @param hrtc RTC handle + * @retval None + */ +void HAL_RTCEx_WakeUpTimerEventCallback(RTC_HandleTypeDef *hrtc) +{ + HAL_IncTick(); +} + +/** + * @brief This function handles WAKE UP TIMER interrupt request. + * @param None + * @retval None + */ +void RTC_IRQHandler(void) +{ + HAL_RTCEx_WakeUpTimerIRQHandler(&hRTC_Handle); +} + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_tim_template.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_tim_template.c new file mode 100644 index 0000000..f655fa3 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_timebase_tim_template.c @@ -0,0 +1,179 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_timebase_tim_template.c + * @brief HAL time base based on the hardware TIM Template. + * + * This file override the native HAL time base functions (defined as weak) + * the TIM time base: + * + Intializes the TIM peripheral generate a Period elapsed Event each 1ms + * + HAL_IncTick is called inside HAL_TIM_PeriodElapsedCallback ie each 1ms + * + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup HAL_TimeBase_TIM + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +TIM_HandleTypeDef TimHandle; +/* Private function prototypes -----------------------------------------------*/ +void TIM6_DAC_IRQHandler(void); +/* Private functions ---------------------------------------------------------*/ + +/** + * @brief This function configures the TIM6 as a time base source. + * The time source is configured to have 1ms time base with a dedicated + * Tick interrupt priority. + * @note This function is called automatically at the beginning of program after + * reset by HAL_Init() or at any time when clock is configured, by HAL_RCC_ClockConfig(). + * @param TickPriority Tick interrupt priority. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_InitTick (uint32_t TickPriority) +{ + RCC_ClkInitTypeDef clkconfig; + uint32_t uwTimclock, uwAPB1Prescaler = 0U; + uint32_t uwPrescalerValue = 0U; + uint32_t pFLatency; + HAL_StatusTypeDef status; + + /* Enable TIM6 clock */ + __HAL_RCC_TIM6_CLK_ENABLE(); + + /* Get clock configuration */ + HAL_RCC_GetClockConfig(&clkconfig, &pFLatency); + + /* Get APB1 prescaler */ + uwAPB1Prescaler = clkconfig.APB1CLKDivider; + + /* Compute TIM6 clock */ + if (uwAPB1Prescaler == RCC_HCLK_DIV1) + { + uwTimclock = HAL_RCC_GetPCLK1Freq(); + } + else + { + uwTimclock = 2 * HAL_RCC_GetPCLK1Freq(); + } + + /* Compute the prescaler value to have TIM6 counter clock equal to 1MHz */ + uwPrescalerValue = (uint32_t) ((uwTimclock / 1000000U) - 1U); + + /* Initialize TIM6 */ + TimHandle.Instance = TIM6; + + /* Initialize TIMx peripheral as follow: + + Period = [(TIM6CLK/1000) - 1]. to have a (1/1000) s time base. + + Prescaler = (uwTimclock/1000000 - 1) to have a 1MHz counter clock. + + ClockDivision = 0 + + Counter direction = Up + */ + TimHandle.Init.Period = (1000000U / 1000U) - 1U; + TimHandle.Init.Prescaler = uwPrescalerValue; + TimHandle.Init.ClockDivision = 0U; + TimHandle.Init.CounterMode = TIM_COUNTERMODE_UP; + TimHandle.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE; + status = HAL_TIM_Base_Init(&TimHandle); + if (status == HAL_OK) + { + /* Start the TIM time Base generation in interrupt mode */ + status = HAL_TIM_Base_Start_IT(&TimHandle); + if (status == HAL_OK) + { + /* Enable the TIM6 global Interrupt */ + HAL_NVIC_EnableIRQ(TIM6_DAC_IRQn); + + if (TickPriority < (1UL << __NVIC_PRIO_BITS)) + { + /* Enable the TIM6 global Interrupt */ + HAL_NVIC_SetPriority(TIM6_DAC_IRQn, TickPriority, 0); + uwTickPrio = TickPriority; + } + else + { + status = HAL_ERROR; + } + } + } + /* Return function status */ + return status; +} + +/** + * @brief Suspend Tick increment. + * @note Disable the tick increment by disabling TIM6 update interrupt. + * @param None + * @retval None + */ +void HAL_SuspendTick(void) +{ + /* Disable TIM6 update Interrupt */ + __HAL_TIM_DISABLE_IT(&TimHandle, TIM_IT_UPDATE); +} + +/** + * @brief Resume Tick increment. + * @note Enable the tick increment by Enabling TIM6 update interrupt. + * @param None + * @retval None + */ +void HAL_ResumeTick(void) +{ + /* Enable TIM6 Update interrupt */ + __HAL_TIM_ENABLE_IT(&TimHandle, TIM_IT_UPDATE); +} + +/** + * @brief Period elapsed callback in non blocking mode + * @note This function is called when TIM6 interrupt took place, inside + * HAL_TIM_IRQHandler(). It makes a direct call to HAL_IncTick() to increment + * a global variable "uwTick" used as application time base. + * @param htim TIM handle + * @retval None + */ +void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim) +{ + HAL_IncTick(); +} + +/** + * @brief This function handles TIM interrupt request. + * @param None + * @retval None + */ +void TIM6_DAC_IRQHandler(void) +{ + HAL_TIM_IRQHandler(&TimHandle); +} + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tsc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tsc.c new file mode 100644 index 0000000..de2862b --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_tsc.c @@ -0,0 +1,1080 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_tsc.c + * @author MCD Application Team + * @brief This file provides firmware functions to manage the following + * functionalities of the Touch Sensing Controller (TSC) peripheral: + * + Initialization and De-initialization + * + Channel IOs, Shield IOs and Sampling IOs configuration + * + Start and Stop an acquisition + * + Read acquisition result + * + Interrupts and flags management + * + @verbatim +================================================================================ + ##### TSC specific features ##### +================================================================================ + [..] + (#) Proven and robust surface charge transfer acquisition principle + + (#) Supports up to 3 capacitive sensing channels per group + + (#) Capacitive sensing channels can be acquired in parallel offering a very good + response time + + (#) Spread spectrum feature to improve system robustness in noisy environments + + (#) Full hardware management of the charge transfer acquisition sequence + + (#) Programmable charge transfer frequency + + (#) Programmable sampling capacitor I/O pin + + (#) Programmable channel I/O pin + + (#) Programmable max count value to avoid long acquisition when a channel is faulty + + (#) Dedicated end of acquisition and max count error flags with interrupt capability + + (#) One sampling capacitor for up to 3 capacitive sensing channels to reduce the system + components + + (#) Compatible with proximity, touchkey, linear and rotary touch sensor implementation + + ##### How to use this driver ##### +================================================================================ + [..] + (#) Enable the TSC interface clock using __HAL_RCC_TSC_CLK_ENABLE() macro. + + (#) GPIO pins configuration + (++) Enable the clock for the TSC GPIOs using __HAL_RCC_GPIOx_CLK_ENABLE() macro. + (++) Configure the TSC pins used as sampling IOs in alternate function output Open-Drain mode, + and TSC pins used as channel/shield IOs in alternate function output Push-Pull mode + using HAL_GPIO_Init() function. + + (#) Interrupts configuration + (++) Configure the NVIC (if the interrupt model is used) using HAL_NVIC_SetPriority() + and HAL_NVIC_EnableIRQ() and function. + + (#) TSC configuration + (++) Configure all TSC parameters and used TSC IOs using HAL_TSC_Init() function. + + [..] TSC peripheral alternate functions are mapped on AF9. + + *** Acquisition sequence *** + =================================== + [..] + (+) Discharge all IOs using HAL_TSC_IODischarge() function. + (+) Wait a certain time allowing a good discharge of all capacitors. This delay depends + of the sampling capacitor and electrodes design. + (+) Select the channel IOs to be acquired using HAL_TSC_IOConfig() function. + (+) Launch the acquisition using either HAL_TSC_Start() or HAL_TSC_Start_IT() function. + If the synchronized mode is selected, the acquisition will start as soon as the signal + is received on the synchro pin. + (+) Wait the end of acquisition using either HAL_TSC_PollForAcquisition() or + HAL_TSC_GetState() function or using WFI instruction for example. + (+) Check the group acquisition status using HAL_TSC_GroupGetStatus() function. + (+) Read the acquisition value using HAL_TSC_GroupGetValue() function. + + *** Callback registration *** + ============================================= + + [..] + The compilation flag USE_HAL_TSC_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + Use Functions HAL_TSC_RegisterCallback() to register an interrupt callback. + + [..] + Function HAL_TSC_RegisterCallback() allows to register following callbacks: + (+) ConvCpltCallback : callback for conversion complete process. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + [..] + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + [..] + Use function HAL_TSC_UnRegisterCallback to reset a callback to the default + weak function. + HAL_TSC_UnRegisterCallback takes as parameters the HAL peripheral handle, + and the Callback ID. + [..] + This function allows to reset following callbacks: + (+) ConvCpltCallback : callback for conversion complete process. + (+) ErrorCallback : callback for error detection. + (+) MspInitCallback : callback for Msp Init. + (+) MspDeInitCallback : callback for Msp DeInit. + + [..] + By default, after the HAL_TSC_Init() and when the state is HAL_TSC_STATE_RESET + all callbacks are set to the corresponding weak functions: + examples HAL_TSC_ConvCpltCallback(), HAL_TSC_ErrorCallback(). + Exception done for MspInit and MspDeInit functions that are + reset to the legacy weak functions in the HAL_TSC_Init()/ HAL_TSC_DeInit() only when + these callbacks are null (not registered beforehand). + If MspInit or MspDeInit are not null, the HAL_TSC_Init()/ HAL_TSC_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand) whatever the state. + + [..] + Callbacks can be registered/unregistered in HAL_TSC_STATE_READY state only. + Exception done MspInit/MspDeInit functions that can be registered/unregistered + in HAL_TSC_STATE_READY or HAL_TSC_STATE_RESET state, + thus registered (user) MspInit/DeInit callbacks can be used during the Init/DeInit. + Then, the user first registers the MspInit/MspDeInit user callbacks + using HAL_TSC_RegisterCallback() before calling HAL_TSC_DeInit() + or HAL_TSC_Init() function. + + [..] + When the compilation flag USE_HAL_TSC_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available and all callbacks + are set to the corresponding weak functions. + + @endverbatim + ****************************************************************************** + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +#if defined(TSC) +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup TSC TSC + * @brief HAL TSC module driver + * @{ + */ + +#ifdef HAL_TSC_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +static uint32_t TSC_extract_groups(uint32_t iomask); + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup TSC_Exported_Functions TSC Exported Functions + * @{ + */ + +/** @defgroup TSC_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and de-initialization functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Initialize and configure the TSC. + (+) De-initialize the TSC. +@endverbatim + * @{ + */ + +/** + * @brief Initialize the TSC peripheral according to the specified parameters + * in the TSC_InitTypeDef structure and initialize the associated handle. + * @param htsc TSC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_Init(TSC_HandleTypeDef *htsc) +{ + /* Check TSC handle allocation */ + if (htsc == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + assert_param(IS_TSC_CTPH(htsc->Init.CTPulseHighLength)); + assert_param(IS_TSC_CTPL(htsc->Init.CTPulseLowLength)); + assert_param(IS_TSC_SS(htsc->Init.SpreadSpectrum)); + assert_param(IS_TSC_SSD(htsc->Init.SpreadSpectrumDeviation)); + assert_param(IS_TSC_SS_PRESC(htsc->Init.SpreadSpectrumPrescaler)); + assert_param(IS_TSC_PG_PRESC(htsc->Init.PulseGeneratorPrescaler)); + assert_param(IS_TSC_PG_PRESC_VS_CTPL(htsc->Init.PulseGeneratorPrescaler, htsc->Init.CTPulseLowLength)); + assert_param(IS_TSC_MCV(htsc->Init.MaxCountValue)); + assert_param(IS_TSC_IODEF(htsc->Init.IODefaultMode)); + assert_param(IS_TSC_SYNC_POL(htsc->Init.SynchroPinPolarity)); + assert_param(IS_TSC_ACQ_MODE(htsc->Init.AcquisitionMode)); + assert_param(IS_TSC_MCE_IT(htsc->Init.MaxCountInterrupt)); + assert_param(IS_TSC_GROUP(htsc->Init.ChannelIOs)); + assert_param(IS_TSC_GROUP(htsc->Init.ShieldIOs)); + assert_param(IS_TSC_GROUP(htsc->Init.SamplingIOs)); + + if (htsc->State == HAL_TSC_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + htsc->Lock = HAL_UNLOCKED; + +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) + /* Init the TSC Callback settings */ + htsc->ConvCpltCallback = HAL_TSC_ConvCpltCallback; /* Legacy weak ConvCpltCallback */ + htsc->ErrorCallback = HAL_TSC_ErrorCallback; /* Legacy weak ErrorCallback */ + + if (htsc->MspInitCallback == NULL) + { + htsc->MspInitCallback = HAL_TSC_MspInit; /* Legacy weak MspInit */ + } + + /* Init the low level hardware : GPIO, CLOCK, CORTEX...etc */ + htsc->MspInitCallback(htsc); +#else + /* Init the low level hardware : GPIO, CLOCK, CORTEX */ + HAL_TSC_MspInit(htsc); +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ + } + + /* Initialize the TSC state */ + htsc->State = HAL_TSC_STATE_BUSY; + + /*--------------------------------------------------------------------------*/ + /* Set TSC parameters */ + + /* Enable TSC */ + htsc->Instance->CR = TSC_CR_TSCE; + + /* Set all functions */ + htsc->Instance->CR |= (htsc->Init.CTPulseHighLength | + htsc->Init.CTPulseLowLength | + (htsc->Init.SpreadSpectrumDeviation << TSC_CR_SSD_Pos) | + htsc->Init.SpreadSpectrumPrescaler | + htsc->Init.PulseGeneratorPrescaler | + htsc->Init.MaxCountValue | + htsc->Init.SynchroPinPolarity | + htsc->Init.AcquisitionMode); + + /* Spread spectrum */ + if (htsc->Init.SpreadSpectrum == ENABLE) + { + htsc->Instance->CR |= TSC_CR_SSE; + } + + /* Disable Schmitt trigger hysteresis on all used TSC IOs */ + htsc->Instance->IOHCR = (~(htsc->Init.ChannelIOs | htsc->Init.ShieldIOs | htsc->Init.SamplingIOs)); + + /* Set channel and shield IOs */ + htsc->Instance->IOCCR = (htsc->Init.ChannelIOs | htsc->Init.ShieldIOs); + + /* Set sampling IOs */ + htsc->Instance->IOSCR = htsc->Init.SamplingIOs; + + /* Set the groups to be acquired */ + htsc->Instance->IOGCSR = TSC_extract_groups(htsc->Init.ChannelIOs); + + /* Disable interrupts */ + htsc->Instance->IER &= (~(TSC_IT_EOA | TSC_IT_MCE)); + + /* Clear flags */ + htsc->Instance->ICR = (TSC_FLAG_EOA | TSC_FLAG_MCE); + + /*--------------------------------------------------------------------------*/ + + /* Initialize the TSC state */ + htsc->State = HAL_TSC_STATE_READY; + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Deinitialize the TSC peripheral registers to their default reset values. + * @param htsc TSC handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_DeInit(TSC_HandleTypeDef *htsc) +{ + /* Check TSC handle allocation */ + if (htsc == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_BUSY; + +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) + if (htsc->MspDeInitCallback == NULL) + { + htsc->MspDeInitCallback = HAL_TSC_MspDeInit; /* Legacy weak MspDeInit */ + } + + /* DeInit the low level hardware: GPIO, CLOCK, NVIC */ + htsc->MspDeInitCallback(htsc); +#else + /* DeInit the low level hardware */ + HAL_TSC_MspDeInit(htsc); +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ + + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_RESET; + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Initialize the TSC MSP. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval None + */ +__weak void HAL_TSC_MspInit(TSC_HandleTypeDef *htsc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htsc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TSC_MspInit could be implemented in the user file. + */ +} + +/** + * @brief DeInitialize the TSC MSP. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval None + */ +__weak void HAL_TSC_MspDeInit(TSC_HandleTypeDef *htsc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htsc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TSC_MspDeInit could be implemented in the user file. + */ +} + +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User TSC Callback + * To be used instead of the weak predefined callback + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_TSC_CONV_COMPLETE_CB_ID Conversion completed callback ID + * @arg @ref HAL_TSC_ERROR_CB_ID Error callback ID + * @arg @ref HAL_TSC_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_TSC_MSPDEINIT_CB_ID MspDeInit callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_RegisterCallback(TSC_HandleTypeDef *htsc, HAL_TSC_CallbackIDTypeDef CallbackID, + pTSC_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + htsc->ErrorCode |= HAL_TSC_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(htsc); + + if (HAL_TSC_STATE_READY == htsc->State) + { + switch (CallbackID) + { + case HAL_TSC_CONV_COMPLETE_CB_ID : + htsc->ConvCpltCallback = pCallback; + break; + + case HAL_TSC_ERROR_CB_ID : + htsc->ErrorCallback = pCallback; + break; + + case HAL_TSC_MSPINIT_CB_ID : + htsc->MspInitCallback = pCallback; + break; + + case HAL_TSC_MSPDEINIT_CB_ID : + htsc->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + htsc->ErrorCode |= HAL_TSC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_TSC_STATE_RESET == htsc->State) + { + switch (CallbackID) + { + case HAL_TSC_MSPINIT_CB_ID : + htsc->MspInitCallback = pCallback; + break; + + case HAL_TSC_MSPDEINIT_CB_ID : + htsc->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + htsc->ErrorCode |= HAL_TSC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + htsc->ErrorCode |= HAL_TSC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(htsc); + return status; +} + +/** + * @brief Unregister an TSC Callback + * TSC callback is redirected to the weak predefined callback + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * This parameter can be one of the following values: + * @arg @ref HAL_TSC_CONV_COMPLETE_CB_ID Conversion completed callback ID + * @arg @ref HAL_TSC_ERROR_CB_ID Error callback ID + * @arg @ref HAL_TSC_MSPINIT_CB_ID MspInit callback ID + * @arg @ref HAL_TSC_MSPDEINIT_CB_ID MspDeInit callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_UnRegisterCallback(TSC_HandleTypeDef *htsc, HAL_TSC_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(htsc); + + if (HAL_TSC_STATE_READY == htsc->State) + { + switch (CallbackID) + { + case HAL_TSC_CONV_COMPLETE_CB_ID : + htsc->ConvCpltCallback = HAL_TSC_ConvCpltCallback; /* Legacy weak ConvCpltCallback */ + break; + + case HAL_TSC_ERROR_CB_ID : + htsc->ErrorCallback = HAL_TSC_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_TSC_MSPINIT_CB_ID : + htsc->MspInitCallback = HAL_TSC_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_TSC_MSPDEINIT_CB_ID : + htsc->MspDeInitCallback = HAL_TSC_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + htsc->ErrorCode |= HAL_TSC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_TSC_STATE_RESET == htsc->State) + { + switch (CallbackID) + { + case HAL_TSC_MSPINIT_CB_ID : + htsc->MspInitCallback = HAL_TSC_MspInit; /* Legacy weak MspInit */ + break; + + case HAL_TSC_MSPDEINIT_CB_ID : + htsc->MspDeInitCallback = HAL_TSC_MspDeInit; /* Legacy weak MspDeInit */ + break; + + default : + /* Update the error code */ + htsc->ErrorCode |= HAL_TSC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + htsc->ErrorCode |= HAL_TSC_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(htsc); + return status; +} + +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup TSC_Exported_Functions_Group2 Input and Output operation functions + * @brief Input and Output operation functions + * +@verbatim + =============================================================================== + ##### IO Operation functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Start acquisition in polling mode. + (+) Start acquisition in interrupt mode. + (+) Stop conversion in polling mode. + (+) Stop conversion in interrupt mode. + (+) Poll for acquisition completed. + (+) Get group acquisition status. + (+) Get group acquisition value. +@endverbatim + * @{ + */ + +/** + * @brief Start the acquisition. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_Start(TSC_HandleTypeDef *htsc) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + /* Process locked */ + __HAL_LOCK(htsc); + + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_BUSY; + + /* Clear interrupts */ + __HAL_TSC_DISABLE_IT(htsc, (TSC_IT_EOA | TSC_IT_MCE)); + + /* Clear flags */ + __HAL_TSC_CLEAR_FLAG(htsc, (TSC_FLAG_EOA | TSC_FLAG_MCE)); + + /* Set touch sensing IOs not acquired to the specified IODefaultMode */ + if (htsc->Init.IODefaultMode == TSC_IODEF_OUT_PP_LOW) + { + __HAL_TSC_SET_IODEF_OUTPPLOW(htsc); + } + else + { + __HAL_TSC_SET_IODEF_INFLOAT(htsc); + } + + /* Launch the acquisition */ + __HAL_TSC_START_ACQ(htsc); + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Start the acquisition in interrupt mode. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_TSC_Start_IT(TSC_HandleTypeDef *htsc) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + assert_param(IS_TSC_MCE_IT(htsc->Init.MaxCountInterrupt)); + + /* Process locked */ + __HAL_LOCK(htsc); + + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_BUSY; + + /* Enable end of acquisition interrupt */ + __HAL_TSC_ENABLE_IT(htsc, TSC_IT_EOA); + + /* Enable max count error interrupt (optional) */ + if (htsc->Init.MaxCountInterrupt == ENABLE) + { + __HAL_TSC_ENABLE_IT(htsc, TSC_IT_MCE); + } + else + { + __HAL_TSC_DISABLE_IT(htsc, TSC_IT_MCE); + } + + /* Clear flags */ + __HAL_TSC_CLEAR_FLAG(htsc, (TSC_FLAG_EOA | TSC_FLAG_MCE)); + + /* Set touch sensing IOs not acquired to the specified IODefaultMode */ + if (htsc->Init.IODefaultMode == TSC_IODEF_OUT_PP_LOW) + { + __HAL_TSC_SET_IODEF_OUTPPLOW(htsc); + } + else + { + __HAL_TSC_SET_IODEF_INFLOAT(htsc); + } + + /* Launch the acquisition */ + __HAL_TSC_START_ACQ(htsc); + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stop the acquisition previously launched in polling mode. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_Stop(TSC_HandleTypeDef *htsc) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + /* Process locked */ + __HAL_LOCK(htsc); + + /* Stop the acquisition */ + __HAL_TSC_STOP_ACQ(htsc); + + /* Set touch sensing IOs in low power mode (output push-pull) */ + __HAL_TSC_SET_IODEF_OUTPPLOW(htsc); + + /* Clear flags */ + __HAL_TSC_CLEAR_FLAG(htsc, (TSC_FLAG_EOA | TSC_FLAG_MCE)); + + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Stop the acquisition previously launched in interrupt mode. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_Stop_IT(TSC_HandleTypeDef *htsc) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + /* Process locked */ + __HAL_LOCK(htsc); + + /* Stop the acquisition */ + __HAL_TSC_STOP_ACQ(htsc); + + /* Set touch sensing IOs in low power mode (output push-pull) */ + __HAL_TSC_SET_IODEF_OUTPPLOW(htsc); + + /* Disable interrupts */ + __HAL_TSC_DISABLE_IT(htsc, (TSC_IT_EOA | TSC_IT_MCE)); + + /* Clear flags */ + __HAL_TSC_CLEAR_FLAG(htsc, (TSC_FLAG_EOA | TSC_FLAG_MCE)); + + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_READY; + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Start acquisition and wait until completion. + * @note There is no need of a timeout parameter as the max count error is already + * managed by the TSC peripheral. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval HAL state + */ +HAL_StatusTypeDef HAL_TSC_PollForAcquisition(TSC_HandleTypeDef *htsc) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + /* Process locked */ + __HAL_LOCK(htsc); + + /* Check end of acquisition */ + while (HAL_TSC_GetState(htsc) == HAL_TSC_STATE_BUSY) + { + /* The timeout (max count error) is managed by the TSC peripheral itself. */ + } + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + return HAL_OK; +} + +/** + * @brief Get the acquisition status for a group. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @param gx_index Index of the group + * @retval Group status + */ +TSC_GroupStatusTypeDef HAL_TSC_GroupGetStatus(TSC_HandleTypeDef *htsc, uint32_t gx_index) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + assert_param(IS_TSC_GROUP_INDEX(gx_index)); + + /* Return the group status */ + return (__HAL_TSC_GET_GROUP_STATUS(htsc, gx_index)); +} + +/** + * @brief Get the acquisition measure for a group. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @param gx_index Index of the group + * @retval Acquisition measure + */ +uint32_t HAL_TSC_GroupGetValue(TSC_HandleTypeDef *htsc, uint32_t gx_index) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + assert_param(IS_TSC_GROUP_INDEX(gx_index)); + + /* Return the group acquisition counter */ + return htsc->Instance->IOGXCR[gx_index]; +} + +/** + * @} + */ + +/** @defgroup TSC_Exported_Functions_Group3 Peripheral Control functions + * @brief Peripheral Control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] This section provides functions allowing to: + (+) Configure TSC IOs + (+) Discharge TSC IOs +@endverbatim + * @{ + */ + +/** + * @brief Configure TSC IOs. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @param config Pointer to the configuration structure. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_IOConfig(TSC_HandleTypeDef *htsc, TSC_IOConfigTypeDef *config) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + assert_param(IS_TSC_GROUP(config->ChannelIOs)); + assert_param(IS_TSC_GROUP(config->ShieldIOs)); + assert_param(IS_TSC_GROUP(config->SamplingIOs)); + + /* Process locked */ + __HAL_LOCK(htsc); + + /* Stop acquisition */ + __HAL_TSC_STOP_ACQ(htsc); + + /* Disable Schmitt trigger hysteresis on all used TSC IOs */ + htsc->Instance->IOHCR = (~(config->ChannelIOs | config->ShieldIOs | config->SamplingIOs)); + + /* Set channel and shield IOs */ + htsc->Instance->IOCCR = (config->ChannelIOs | config->ShieldIOs); + + /* Set sampling IOs */ + htsc->Instance->IOSCR = config->SamplingIOs; + + /* Set groups to be acquired */ + htsc->Instance->IOGCSR = TSC_extract_groups(config->ChannelIOs); + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Discharge TSC IOs. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @param choice This parameter can be set to ENABLE or DISABLE. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_TSC_IODischarge(TSC_HandleTypeDef *htsc, FunctionalState choice) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + /* Process locked */ + __HAL_LOCK(htsc); + + if (choice == ENABLE) + { + __HAL_TSC_SET_IODEF_OUTPPLOW(htsc); + } + else + { + __HAL_TSC_SET_IODEF_INFLOAT(htsc); + } + + /* Process unlocked */ + __HAL_UNLOCK(htsc); + + /* Return the group acquisition counter */ + return HAL_OK; +} + +/** + * @} + */ + +/** @defgroup TSC_Exported_Functions_Group4 Peripheral State and Errors functions + * @brief Peripheral State and Errors functions + * +@verbatim + =============================================================================== + ##### State and Errors functions ##### + =============================================================================== + [..] + This subsection provides functions allowing to + (+) Get TSC state. + +@endverbatim + * @{ + */ + +/** + * @brief Return the TSC handle state. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval HAL state + */ +HAL_TSC_StateTypeDef HAL_TSC_GetState(TSC_HandleTypeDef *htsc) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + if (htsc->State == HAL_TSC_STATE_BUSY) + { + /* Check end of acquisition flag */ + if (__HAL_TSC_GET_FLAG(htsc, TSC_FLAG_EOA) != RESET) + { + /* Check max count error flag */ + if (__HAL_TSC_GET_FLAG(htsc, TSC_FLAG_MCE) != RESET) + { + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_ERROR; + } + else + { + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_READY; + } + } + } + + /* Return TSC state */ + return htsc->State; +} + +/** + * @} + */ + +/** @defgroup TSC_IRQ_Handler_and_Callbacks IRQ Handler and Callbacks + * @{ + */ + +/** + * @brief Handle TSC interrupt request. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval None + */ +void HAL_TSC_IRQHandler(TSC_HandleTypeDef *htsc) +{ + /* Check the parameters */ + assert_param(IS_TSC_ALL_INSTANCE(htsc->Instance)); + + /* Check if the end of acquisition occurred */ + if (__HAL_TSC_GET_FLAG(htsc, TSC_FLAG_EOA) != RESET) + { + /* Clear EOA flag */ + __HAL_TSC_CLEAR_FLAG(htsc, TSC_FLAG_EOA); + } + + /* Check if max count error occurred */ + if (__HAL_TSC_GET_FLAG(htsc, TSC_FLAG_MCE) != RESET) + { + /* Clear MCE flag */ + __HAL_TSC_CLEAR_FLAG(htsc, TSC_FLAG_MCE); + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_ERROR; +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) + htsc->ErrorCallback(htsc); +#else + /* Conversion completed callback */ + HAL_TSC_ErrorCallback(htsc); +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ + } + else + { + /* Change TSC state */ + htsc->State = HAL_TSC_STATE_READY; +#if (USE_HAL_TSC_REGISTER_CALLBACKS == 1) + htsc->ConvCpltCallback(htsc); +#else + /* Conversion completed callback */ + HAL_TSC_ConvCpltCallback(htsc); +#endif /* USE_HAL_TSC_REGISTER_CALLBACKS */ + } +} + +/** + * @brief Acquisition completed callback in non-blocking mode. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval None + */ +__weak void HAL_TSC_ConvCpltCallback(TSC_HandleTypeDef *htsc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htsc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TSC_ConvCpltCallback could be implemented in the user file. + */ +} + +/** + * @brief Error callback in non-blocking mode. + * @param htsc Pointer to a TSC_HandleTypeDef structure that contains + * the configuration information for the specified TSC. + * @retval None + */ +__weak void HAL_TSC_ErrorCallback(TSC_HandleTypeDef *htsc) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(htsc); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_TSC_ErrorCallback could be implemented in the user file. + */ +} + +/** + * @} + */ + +/** + * @} + */ + +/* Private functions ---------------------------------------------------------*/ +/** @defgroup TSC_Private_Functions TSC Private Functions + * @{ + */ + +/** + * @brief Utility function used to set the acquired groups mask. + * @param iomask Channels IOs mask + * @retval Acquired groups mask + */ +static uint32_t TSC_extract_groups(uint32_t iomask) +{ + uint32_t groups = 0UL; + uint32_t idx; + + for (idx = 0UL; idx < (uint32_t)TSC_NB_OF_GROUPS; idx++) + { + if ((iomask & (0x0FUL << (idx * 4UL))) != 0UL) + { + groups |= (1UL << idx); + } + } + + return groups; +} + +/** + * @} + */ + +#endif /* HAL_TSC_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* TSC */ +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart.c new file mode 100644 index 0000000..3307e41 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart.c @@ -0,0 +1,4128 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_uart.c + * @author MCD Application Team + * @brief UART HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Universal Asynchronous Receiver Transmitter Peripheral (UART). + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral Control functions + * + * + @verbatim + =============================================================================== + ##### How to use this driver ##### + =============================================================================== + [..] + The UART HAL driver can be used as follows: + + (#) Declare a UART_HandleTypeDef handle structure (eg. UART_HandleTypeDef huart). + (#) Initialize the UART low level resources by implementing the HAL_UART_MspInit() API: + (++) Enable the USARTx interface clock. + (++) UART pins configuration: + (+++) Enable the clock for the UART GPIOs. + (+++) Configure these UART pins as alternate function pull-up. + (++) NVIC configuration if you need to use interrupt process (HAL_UART_Transmit_IT() + and HAL_UART_Receive_IT() APIs): + (+++) Configure the USARTx interrupt priority. + (+++) Enable the NVIC USART IRQ handle. + (++) UART interrupts handling: + -@@- The specific UART interrupts (Transmission complete interrupt, + RXNE interrupt, RX/TX FIFOs related interrupts and Error Interrupts) + are managed using the macros __HAL_UART_ENABLE_IT() and __HAL_UART_DISABLE_IT() + inside the transmit and receive processes. + (++) DMA Configuration if you need to use DMA process (HAL_UART_Transmit_DMA() + and HAL_UART_Receive_DMA() APIs): + (+++) Declare a DMA handle structure for the Tx/Rx channel. + (+++) Enable the DMAx interface clock. + (+++) Configure the declared DMA handle structure with the required Tx/Rx parameters. + (+++) Configure the DMA Tx/Rx channel. + (+++) Associate the initialized DMA handle to the UART DMA Tx/Rx handle. + (+++) Configure the priority and enable the NVIC for the transfer complete + interrupt on the DMA Tx/Rx channel. + + (#) Program the Baud Rate, Word Length, Stop Bit, Parity, Hardware + flow control and Mode (Receiver/Transmitter) in the huart handle Init structure. + + (#) If required, program UART advanced features (TX/RX pins swap, auto Baud rate detection,...) + in the huart handle AdvancedInit structure. + + (#) For the UART asynchronous mode, initialize the UART registers by calling + the HAL_UART_Init() API. + + (#) For the UART Half duplex mode, initialize the UART registers by calling + the HAL_HalfDuplex_Init() API. + + (#) For the UART LIN (Local Interconnection Network) mode, initialize the UART registers + by calling the HAL_LIN_Init() API. + + (#) For the UART Multiprocessor mode, initialize the UART registers + by calling the HAL_MultiProcessor_Init() API. + + (#) For the UART RS485 Driver Enabled mode, initialize the UART registers + by calling the HAL_RS485Ex_Init() API. + + [..] + (@) These API's (HAL_UART_Init(), HAL_HalfDuplex_Init(), HAL_LIN_Init(), HAL_MultiProcessor_Init(), + also configure the low level Hardware GPIO, CLOCK, CORTEX...etc) by + calling the customized HAL_UART_MspInit() API. + + ##### Callback registration ##### + ================================== + + [..] + The compilation define USE_HAL_UART_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + + [..] + Use Function HAL_UART_RegisterCallback() to register a user callback. + Function HAL_UART_RegisterCallback() allows to register following callbacks: + (+) TxHalfCpltCallback : Tx Half Complete Callback. + (+) TxCpltCallback : Tx Complete Callback. + (+) RxHalfCpltCallback : Rx Half Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback. + (+) AbortReceiveCpltCallback : Abort Receive Complete Callback. + (+) WakeupCallback : Wakeup Callback. + (+) MspInitCallback : UART MspInit. + (+) MspDeInitCallback : UART MspDeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + [..] + Use function HAL_UART_UnRegisterCallback() to reset a callback to the default + weak (surcharged) function. + HAL_UART_UnRegisterCallback() takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) TxHalfCpltCallback : Tx Half Complete Callback. + (+) TxCpltCallback : Tx Complete Callback. + (+) RxHalfCpltCallback : Rx Half Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) AbortTransmitCpltCallback : Abort Transmit Complete Callback. + (+) AbortReceiveCpltCallback : Abort Receive Complete Callback. + (+) WakeupCallback : Wakeup Callback. + (+) MspInitCallback : UART MspInit. + (+) MspDeInitCallback : UART MspDeInit. + + [..] + For specific callback RxEventCallback, use dedicated registration/reset functions: + respectively HAL_UART_RegisterRxEventCallback() , HAL_UART_UnRegisterRxEventCallback(). + + [..] + By default, after the HAL_UART_Init() and when the state is HAL_UART_STATE_RESET + all callbacks are set to the corresponding weak (surcharged) functions: + examples HAL_UART_TxCpltCallback(), HAL_UART_RxHalfCpltCallback(). + Exception done for MspInit and MspDeInit functions that are respectively + reset to the legacy weak (surcharged) functions in the HAL_UART_Init() + and HAL_UART_DeInit() only when these callbacks are null (not registered beforehand). + If not, MspInit or MspDeInit are not null, the HAL_UART_Init() and HAL_UART_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand). + + [..] + Callbacks can be registered/unregistered in HAL_UART_STATE_READY state only. + Exception done MspInit/MspDeInit that can be registered/unregistered + in HAL_UART_STATE_READY or HAL_UART_STATE_RESET state, thus registered (user) + MspInit/DeInit callbacks can be used during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_UART_RegisterCallback() before calling HAL_UART_DeInit() + or HAL_UART_Init() function. + + [..] + When The compilation define USE_HAL_UART_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available + and weak (surcharged) callbacks are used. + + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup UART UART + * @brief HAL UART module driver + * @{ + */ + +#ifdef HAL_UART_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup UART_Private_Constants UART Private Constants + * @{ + */ +#define USART_CR1_FIELDS ((uint32_t)(USART_CR1_M | USART_CR1_PCE | USART_CR1_PS | USART_CR1_TE | USART_CR1_RE | \ + USART_CR1_OVER8)) /*!< UART or USART CR1 fields of parameters set by UART_SetConfig API */ + +#define USART_CR3_FIELDS ((uint32_t)(USART_CR3_RTSE | USART_CR3_CTSE |\ + USART_CR3_ONEBIT)) /*!< UART or USART CR3 fields of parameters set by UART_SetConfig API */ + + +#define UART_BRR_MIN 0x10U /* UART BRR minimum authorized value */ +#define UART_BRR_MAX 0x0000FFFFU /* UART BRR maximum authorized value */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @addtogroup UART_Private_Functions + * @{ + */ +static void UART_EndTxTransfer(UART_HandleTypeDef *huart); +static void UART_EndRxTransfer(UART_HandleTypeDef *huart); +static void UART_DMATransmitCplt(DMA_HandleTypeDef *hdma); +static void UART_DMAReceiveCplt(DMA_HandleTypeDef *hdma); +static void UART_DMARxHalfCplt(DMA_HandleTypeDef *hdma); +static void UART_DMATxHalfCplt(DMA_HandleTypeDef *hdma); +static void UART_DMAError(DMA_HandleTypeDef *hdma); +static void UART_DMAAbortOnError(DMA_HandleTypeDef *hdma); +static void UART_DMATxAbortCallback(DMA_HandleTypeDef *hdma); +static void UART_DMARxAbortCallback(DMA_HandleTypeDef *hdma); +static void UART_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma); +static void UART_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma); +static void UART_TxISR_8BIT(UART_HandleTypeDef *huart); +static void UART_TxISR_16BIT(UART_HandleTypeDef *huart); +static void UART_EndTransmit_IT(UART_HandleTypeDef *huart); +static void UART_RxISR_8BIT(UART_HandleTypeDef *huart); +static void UART_RxISR_16BIT(UART_HandleTypeDef *huart); +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/* Exported Constants --------------------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup UART_Exported_Functions UART Exported Functions + * @{ + */ + +/** @defgroup UART_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim +=============================================================================== + ##### Initialization and Configuration functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to initialize the USARTx or the UARTy + in asynchronous mode. + (+) For the asynchronous mode the parameters below can be configured: + (++) Baud Rate + (++) Word Length + (++) Stop Bit + (++) Parity: If the parity is enabled, then the MSB bit of the data written + in the data register is transmitted but is changed by the parity bit. + (++) Hardware flow control + (++) Receiver/transmitter modes + (++) Over Sampling Method + (++) One-Bit Sampling Method + (+) For the asynchronous mode, the following advanced features can be configured as well: + (++) TX and/or RX pin level inversion + (++) data logical level inversion + (++) RX and TX pins swap + (++) RX overrun detection disabling + (++) DMA disabling on RX error + (++) MSB first on communication line + (++) auto Baud rate detection + [..] + The HAL_UART_Init(), HAL_HalfDuplex_Init(), HAL_LIN_Init()and HAL_MultiProcessor_Init()API + follow respectively the UART asynchronous, UART Half duplex, UART LIN mode + and UART multiprocessor mode configuration procedures (details for the procedures + are available in reference manual). + +@endverbatim + + Depending on the frame length defined by the M1 and M0 bits (7-bit, + 8-bit or 9-bit), the possible UART formats are listed in the + following table. + + Table 1. UART frame format. + +-----------------------------------------------------------------------+ + | M1 bit | M0 bit | PCE bit | UART frame | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 0 | | SB | 8 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 1 | | SB | 7 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 0 | | SB | 9 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 1 | | SB | 8 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 0 | | SB | 7 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 1 | | SB | 6 bit data | PB | STB | | + +-----------------------------------------------------------------------+ + + * @{ + */ + +/** + * @brief Initialize the UART mode according to the specified + * parameters in the UART_InitTypeDef and initialize the associated handle. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Init(UART_HandleTypeDef *huart) +{ + /* Check the UART handle allocation */ + if (huart == NULL) + { + return HAL_ERROR; + } + + if (huart->Init.HwFlowCtl != UART_HWCONTROL_NONE) + { + /* Check the parameters */ + assert_param(IS_UART_HWFLOW_INSTANCE(huart->Instance)); + } + else + { + /* Check the parameters */ + assert_param(IS_UART_INSTANCE(huart->Instance)); + } + + if (huart->gState == HAL_UART_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + huart->Lock = HAL_UNLOCKED; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + UART_InitCallbacksToDefault(huart); + + if (huart->MspInitCallback == NULL) + { + huart->MspInitCallback = HAL_UART_MspInit; + } + + /* Init the low level hardware */ + huart->MspInitCallback(huart); +#else + /* Init the low level hardware : GPIO, CLOCK */ + HAL_UART_MspInit(huart); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + + huart->gState = HAL_UART_STATE_BUSY; + + __HAL_UART_DISABLE(huart); + + /* Set the UART Communication parameters */ + if (UART_SetConfig(huart) == HAL_ERROR) + { + return HAL_ERROR; + } + + if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT) + { + UART_AdvFeatureConfig(huart); + } + + /* In asynchronous mode, the following bits must be kept cleared: + - LINEN (if LIN is supported) and CLKEN bits in the USART_CR2 register, + - SCEN (if Smartcard is supported), HDSEL and IREN (if IrDA is supported) bits in the USART_CR3 register.*/ +#if defined (USART_CR2_LINEN) + CLEAR_BIT(huart->Instance->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN)); +#else + CLEAR_BIT(huart->Instance->CR2, USART_CR2_CLKEN); +#endif /* USART_CR2_LINEN */ +#if defined (USART_CR3_SCEN) +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#endif /* USART_CR3_IREN */ +#else +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(huart->Instance->CR3, USART_CR3_HDSEL); +#endif /* USART_CR3_IREN*/ +#endif /* USART_CR3_SCEN */ + + __HAL_UART_ENABLE(huart); + + /* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */ + return (UART_CheckIdleState(huart)); +} + +/** + * @brief Initialize the half-duplex mode according to the specified + * parameters in the UART_InitTypeDef and creates the associated handle. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_HalfDuplex_Init(UART_HandleTypeDef *huart) +{ + /* Check the UART handle allocation */ + if (huart == NULL) + { + return HAL_ERROR; + } + + /* Check UART instance */ + assert_param(IS_UART_HALFDUPLEX_INSTANCE(huart->Instance)); + + if (huart->gState == HAL_UART_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + huart->Lock = HAL_UNLOCKED; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + UART_InitCallbacksToDefault(huart); + + if (huart->MspInitCallback == NULL) + { + huart->MspInitCallback = HAL_UART_MspInit; + } + + /* Init the low level hardware */ + huart->MspInitCallback(huart); +#else + /* Init the low level hardware : GPIO, CLOCK */ + HAL_UART_MspInit(huart); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + + huart->gState = HAL_UART_STATE_BUSY; + + __HAL_UART_DISABLE(huart); + + /* Set the UART Communication parameters */ + if (UART_SetConfig(huart) == HAL_ERROR) + { + return HAL_ERROR; + } + + if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT) + { + UART_AdvFeatureConfig(huart); + } + + /* In half-duplex mode, the following bits must be kept cleared: + - LINEN (if LIN is supported) and CLKEN bits in the USART_CR2 register, + - SCEN (if Smartcard is supported) and IREN (if IrDA is supported) bits in the USART_CR3 register.*/ +#if defined (USART_CR2_LINEN) + CLEAR_BIT(huart->Instance->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN)); +#else + CLEAR_BIT(huart->Instance->CR2, USART_CR2_CLKEN); +#endif /* USART_CR2_LINEN */ +#if defined (USART_CR3_SCEN) +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_IREN | USART_CR3_SCEN)); +#else + CLEAR_BIT(huart->Instance->CR3, USART_CR3_SCEN); +#endif /* USART_CR3_IREN */ +#else +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, USART_CR3_IREN); +#endif /* USART_CR3_IREN */ +#endif /* USART_CR3_SCEN */ + + /* Enable the Half-Duplex mode by setting the HDSEL bit in the CR3 register */ + SET_BIT(huart->Instance->CR3, USART_CR3_HDSEL); + + __HAL_UART_ENABLE(huart); + + /* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */ + return (UART_CheckIdleState(huart)); +} + + +#if defined(USART_CR2_LINEN) +/** + * @brief Initialize the LIN mode according to the specified + * parameters in the UART_InitTypeDef and creates the associated handle. + * @param huart UART handle. + * @param BreakDetectLength Specifies the LIN break detection length. + * This parameter can be one of the following values: + * @arg @ref UART_LINBREAKDETECTLENGTH_10B 10-bit break detection + * @arg @ref UART_LINBREAKDETECTLENGTH_11B 11-bit break detection + * @retval HAL status + */ +HAL_StatusTypeDef HAL_LIN_Init(UART_HandleTypeDef *huart, uint32_t BreakDetectLength) +{ + /* Check the UART handle allocation */ + if (huart == NULL) + { + return HAL_ERROR; + } + + /* Check the LIN UART instance */ + assert_param(IS_UART_LIN_INSTANCE(huart->Instance)); + /* Check the Break detection length parameter */ + assert_param(IS_UART_LIN_BREAK_DETECT_LENGTH(BreakDetectLength)); + + /* LIN mode limited to 16-bit oversampling only */ + if (huart->Init.OverSampling == UART_OVERSAMPLING_8) + { + return HAL_ERROR; + } + /* LIN mode limited to 8-bit data length */ + if (huart->Init.WordLength != UART_WORDLENGTH_8B) + { + return HAL_ERROR; + } + + if (huart->gState == HAL_UART_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + huart->Lock = HAL_UNLOCKED; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + UART_InitCallbacksToDefault(huart); + + if (huart->MspInitCallback == NULL) + { + huart->MspInitCallback = HAL_UART_MspInit; + } + + /* Init the low level hardware */ + huart->MspInitCallback(huart); +#else + /* Init the low level hardware : GPIO, CLOCK */ + HAL_UART_MspInit(huart); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + + huart->gState = HAL_UART_STATE_BUSY; + + __HAL_UART_DISABLE(huart); + + /* Set the UART Communication parameters */ + if (UART_SetConfig(huart) == HAL_ERROR) + { + return HAL_ERROR; + } + + if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT) + { + UART_AdvFeatureConfig(huart); + } + + /* In LIN mode, the following bits must be kept cleared: + - LINEN and CLKEN bits in the USART_CR2 register, + - SCEN(if Smartcard is supported) and IREN(if IrDA is supported) bits in the USART_CR3 register.*/ + CLEAR_BIT(huart->Instance->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN)); +#if defined (USART_CR3_SCEN) +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#endif /* USART_CR3_IREN */ +#else +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(huart->Instance->CR3, USART_CR3_HDSEL); +#endif /* USART_CR3_IREN*/ +#endif /* USART_CR3_SCEN */ + + /* Enable the LIN mode by setting the LINEN bit in the CR2 register */ + SET_BIT(huart->Instance->CR2, USART_CR2_LINEN); + + /* Set the USART LIN Break detection length. */ + MODIFY_REG(huart->Instance->CR2, USART_CR2_LBDL, BreakDetectLength); + + __HAL_UART_ENABLE(huart); + + /* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */ + return (UART_CheckIdleState(huart)); +} +#endif /* USART_CR2_LINEN */ + + +/** + * @brief Initialize the multiprocessor mode according to the specified + * parameters in the UART_InitTypeDef and initialize the associated handle. + * @param huart UART handle. + * @param Address UART node address (4-, 6-, 7- or 8-bit long). + * @param WakeUpMethod Specifies the UART wakeup method. + * This parameter can be one of the following values: + * @arg @ref UART_WAKEUPMETHOD_IDLELINE WakeUp by an idle line detection + * @arg @ref UART_WAKEUPMETHOD_ADDRESSMARK WakeUp by an address mark + * @note If the user resorts to idle line detection wake up, the Address parameter + * is useless and ignored by the initialization function. + * @note If the user resorts to address mark wake up, the address length detection + * is configured by default to 4 bits only. For the UART to be able to + * manage 6-, 7- or 8-bit long addresses detection, the API + * HAL_MultiProcessorEx_AddressLength_Set() must be called after + * HAL_MultiProcessor_Init(). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_MultiProcessor_Init(UART_HandleTypeDef *huart, uint8_t Address, uint32_t WakeUpMethod) +{ + /* Check the UART handle allocation */ + if (huart == NULL) + { + return HAL_ERROR; + } + + /* Check the wake up method parameter */ + assert_param(IS_UART_WAKEUPMETHOD(WakeUpMethod)); + + if (huart->gState == HAL_UART_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + huart->Lock = HAL_UNLOCKED; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + UART_InitCallbacksToDefault(huart); + + if (huart->MspInitCallback == NULL) + { + huart->MspInitCallback = HAL_UART_MspInit; + } + + /* Init the low level hardware */ + huart->MspInitCallback(huart); +#else + /* Init the low level hardware : GPIO, CLOCK */ + HAL_UART_MspInit(huart); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + + huart->gState = HAL_UART_STATE_BUSY; + + __HAL_UART_DISABLE(huart); + + /* Set the UART Communication parameters */ + if (UART_SetConfig(huart) == HAL_ERROR) + { + return HAL_ERROR; + } + + if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT) + { + UART_AdvFeatureConfig(huart); + } + + /* In multiprocessor mode, the following bits must be kept cleared: + - LINEN (if LIN is supported) and CLKEN bits in the USART_CR2 register, + - SCEN (if Smartcard is supported), HDSEL and IREN (if IrDA is supported) bits in the USART_CR3 register. */ +#if defined (USART_CR2_LINEN) + CLEAR_BIT(huart->Instance->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN)); +#else + CLEAR_BIT(huart->Instance->CR2, USART_CR2_CLKEN); +#endif /* USART_CR2_LINEN */ +#if defined (USART_CR3_SCEN) +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL)); +#endif /* USART_CR3_IREN */ +#else +#if defined (USART_CR3_IREN) + CLEAR_BIT(huart->Instance->CR3, (USART_CR3_HDSEL | USART_CR3_IREN)); +#else + CLEAR_BIT(huart->Instance->CR3, USART_CR3_HDSEL); +#endif /* USART_CR3_IREN */ +#endif /* USART_CR3_SCEN */ + + if (WakeUpMethod == UART_WAKEUPMETHOD_ADDRESSMARK) + { + /* If address mark wake up method is chosen, set the USART address node */ + MODIFY_REG(huart->Instance->CR2, USART_CR2_ADD, ((uint32_t)Address << UART_CR2_ADDRESS_LSB_POS)); + } + + /* Set the wake up method by setting the WAKE bit in the CR1 register */ + MODIFY_REG(huart->Instance->CR1, USART_CR1_WAKE, WakeUpMethod); + + __HAL_UART_ENABLE(huart); + + /* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */ + return (UART_CheckIdleState(huart)); +} + + +/** + * @brief DeInitialize the UART peripheral. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_DeInit(UART_HandleTypeDef *huart) +{ + /* Check the UART handle allocation */ + if (huart == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_UART_INSTANCE(huart->Instance)); + + huart->gState = HAL_UART_STATE_BUSY; + + __HAL_UART_DISABLE(huart); + + huart->Instance->CR1 = 0x0U; + huart->Instance->CR2 = 0x0U; + huart->Instance->CR3 = 0x0U; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + if (huart->MspDeInitCallback == NULL) + { + huart->MspDeInitCallback = HAL_UART_MspDeInit; + } + /* DeInit the low level hardware */ + huart->MspDeInitCallback(huart); +#else + /* DeInit the low level hardware */ + HAL_UART_MspDeInit(huart); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->gState = HAL_UART_STATE_RESET; + huart->RxState = HAL_UART_STATE_RESET; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + __HAL_UNLOCK(huart); + + return HAL_OK; +} + +/** + * @brief Initialize the UART MSP. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_MspInit(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_MspInit can be implemented in the user file + */ +} + +/** + * @brief DeInitialize the UART MSP. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_MspDeInit(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_MspDeInit can be implemented in the user file + */ +} + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User UART Callback + * To be used instead of the weak predefined callback + * @param huart uart handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_UART_TX_HALFCOMPLETE_CB_ID Tx Half Complete Callback ID + * @arg @ref HAL_UART_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_UART_RX_HALFCOMPLETE_CB_ID Rx Half Complete Callback ID + * @arg @ref HAL_UART_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_UART_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_UART_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_UART_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID + * @arg @ref HAL_UART_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID + * @arg @ref HAL_UART_WAKEUP_CB_ID Wakeup Callback ID + * @arg @ref HAL_UART_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_UART_MSPDEINIT_CB_ID MspDeInit Callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_RegisterCallback(UART_HandleTypeDef *huart, HAL_UART_CallbackIDTypeDef CallbackID, + pUART_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + __HAL_LOCK(huart); + + if (huart->gState == HAL_UART_STATE_READY) + { + switch (CallbackID) + { + case HAL_UART_TX_HALFCOMPLETE_CB_ID : + huart->TxHalfCpltCallback = pCallback; + break; + + case HAL_UART_TX_COMPLETE_CB_ID : + huart->TxCpltCallback = pCallback; + break; + + case HAL_UART_RX_HALFCOMPLETE_CB_ID : + huart->RxHalfCpltCallback = pCallback; + break; + + case HAL_UART_RX_COMPLETE_CB_ID : + huart->RxCpltCallback = pCallback; + break; + + case HAL_UART_ERROR_CB_ID : + huart->ErrorCallback = pCallback; + break; + + case HAL_UART_ABORT_COMPLETE_CB_ID : + huart->AbortCpltCallback = pCallback; + break; + + case HAL_UART_ABORT_TRANSMIT_COMPLETE_CB_ID : + huart->AbortTransmitCpltCallback = pCallback; + break; + + case HAL_UART_ABORT_RECEIVE_COMPLETE_CB_ID : + huart->AbortReceiveCpltCallback = pCallback; + break; + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + case HAL_UART_WAKEUP_CB_ID : + huart->WakeupCallback = pCallback; + break; + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + + case HAL_UART_MSPINIT_CB_ID : + huart->MspInitCallback = pCallback; + break; + + case HAL_UART_MSPDEINIT_CB_ID : + huart->MspDeInitCallback = pCallback; + break; + + default : + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + break; + } + } + else if (huart->gState == HAL_UART_STATE_RESET) + { + switch (CallbackID) + { + case HAL_UART_MSPINIT_CB_ID : + huart->MspInitCallback = pCallback; + break; + + case HAL_UART_MSPDEINIT_CB_ID : + huart->MspDeInitCallback = pCallback; + break; + + default : + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + break; + } + } + else + { + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + } + + __HAL_UNLOCK(huart); + + return status; +} + +/** + * @brief Unregister an UART Callback + * UART callaback is redirected to the weak predefined callback + * @param huart uart handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_UART_TX_HALFCOMPLETE_CB_ID Tx Half Complete Callback ID + * @arg @ref HAL_UART_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_UART_RX_HALFCOMPLETE_CB_ID Rx Half Complete Callback ID + * @arg @ref HAL_UART_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_UART_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_UART_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_UART_ABORT_TRANSMIT_COMPLETE_CB_ID Abort Transmit Complete Callback ID + * @arg @ref HAL_UART_ABORT_RECEIVE_COMPLETE_CB_ID Abort Receive Complete Callback ID + * @arg @ref HAL_UART_WAKEUP_CB_ID Wakeup Callback ID + * @arg @ref HAL_UART_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_UART_MSPDEINIT_CB_ID MspDeInit Callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_UnRegisterCallback(UART_HandleTypeDef *huart, HAL_UART_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + __HAL_LOCK(huart); + + if (HAL_UART_STATE_READY == huart->gState) + { + switch (CallbackID) + { + case HAL_UART_TX_HALFCOMPLETE_CB_ID : + huart->TxHalfCpltCallback = HAL_UART_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + break; + + case HAL_UART_TX_COMPLETE_CB_ID : + huart->TxCpltCallback = HAL_UART_TxCpltCallback; /* Legacy weak TxCpltCallback */ + break; + + case HAL_UART_RX_HALFCOMPLETE_CB_ID : + huart->RxHalfCpltCallback = HAL_UART_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + break; + + case HAL_UART_RX_COMPLETE_CB_ID : + huart->RxCpltCallback = HAL_UART_RxCpltCallback; /* Legacy weak RxCpltCallback */ + break; + + case HAL_UART_ERROR_CB_ID : + huart->ErrorCallback = HAL_UART_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_UART_ABORT_COMPLETE_CB_ID : + huart->AbortCpltCallback = HAL_UART_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + break; + + case HAL_UART_ABORT_TRANSMIT_COMPLETE_CB_ID : + huart->AbortTransmitCpltCallback = HAL_UART_AbortTransmitCpltCallback; /* Legacy weak + AbortTransmitCpltCallback */ + break; + + case HAL_UART_ABORT_RECEIVE_COMPLETE_CB_ID : + huart->AbortReceiveCpltCallback = HAL_UART_AbortReceiveCpltCallback; /* Legacy weak + AbortReceiveCpltCallback */ + break; + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + case HAL_UART_WAKEUP_CB_ID : + huart->WakeupCallback = HAL_UARTEx_WakeupCallback; /* Legacy weak WakeupCallback */ + break; + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + case HAL_UART_MSPINIT_CB_ID : + huart->MspInitCallback = HAL_UART_MspInit; /* Legacy weak MspInitCallback */ + break; + + case HAL_UART_MSPDEINIT_CB_ID : + huart->MspDeInitCallback = HAL_UART_MspDeInit; /* Legacy weak MspDeInitCallback */ + break; + + default : + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + break; + } + } + else if (HAL_UART_STATE_RESET == huart->gState) + { + switch (CallbackID) + { + case HAL_UART_MSPINIT_CB_ID : + huart->MspInitCallback = HAL_UART_MspInit; + break; + + case HAL_UART_MSPDEINIT_CB_ID : + huart->MspDeInitCallback = HAL_UART_MspDeInit; + break; + + default : + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + break; + } + } + else + { + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + } + + __HAL_UNLOCK(huart); + + return status; +} + +/** + * @brief Register a User UART Rx Event Callback + * To be used instead of the weak predefined callback + * @param huart Uart handle + * @param pCallback Pointer to the Rx Event Callback function + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_RegisterRxEventCallback(UART_HandleTypeDef *huart, pUART_RxEventCallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + + /* Process locked */ + __HAL_LOCK(huart); + + if (huart->gState == HAL_UART_STATE_READY) + { + huart->RxEventCallback = pCallback; + } + else + { + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(huart); + + return status; +} + +/** + * @brief UnRegister the UART Rx Event Callback + * UART Rx Event Callback is redirected to the weak HAL_UARTEx_RxEventCallback() predefined callback + * @param huart Uart handle + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_UnRegisterRxEventCallback(UART_HandleTypeDef *huart) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(huart); + + if (huart->gState == HAL_UART_STATE_READY) + { + huart->RxEventCallback = HAL_UARTEx_RxEventCallback; /* Legacy weak UART Rx Event Callback */ + } + else + { + huart->ErrorCode |= HAL_UART_ERROR_INVALID_CALLBACK; + + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(huart); + return status; +} + +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup UART_Exported_Functions_Group2 IO operation functions + * @brief UART Transmit/Receive functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + This subsection provides a set of functions allowing to manage the UART asynchronous + and Half duplex data transfers. + + (#) There are two mode of transfer: + (+) Blocking mode: The communication is performed in polling mode. + The HAL status of all data processing is returned by the same function + after finishing transfer. + (+) Non-Blocking mode: The communication is performed using Interrupts + or DMA, These API's return the HAL status. + The end of the data processing will be indicated through the + dedicated UART IRQ when using Interrupt mode or the DMA IRQ when + using DMA mode. + The HAL_UART_TxCpltCallback(), HAL_UART_RxCpltCallback() user callbacks + will be executed respectively at the end of the transmit or Receive process + The HAL_UART_ErrorCallback()user callback will be executed when a communication error is detected + + (#) Blocking mode API's are : + (+) HAL_UART_Transmit() + (+) HAL_UART_Receive() + + (#) Non-Blocking mode API's with Interrupt are : + (+) HAL_UART_Transmit_IT() + (+) HAL_UART_Receive_IT() + (+) HAL_UART_IRQHandler() + + (#) Non-Blocking mode API's with DMA are : + (+) HAL_UART_Transmit_DMA() + (+) HAL_UART_Receive_DMA() + (+) HAL_UART_DMAPause() + (+) HAL_UART_DMAResume() + (+) HAL_UART_DMAStop() + + (#) A set of Transfer Complete Callbacks are provided in Non_Blocking mode: + (+) HAL_UART_TxHalfCpltCallback() + (+) HAL_UART_TxCpltCallback() + (+) HAL_UART_RxHalfCpltCallback() + (+) HAL_UART_RxCpltCallback() + (+) HAL_UART_ErrorCallback() + + (#) Non-Blocking mode transfers could be aborted using Abort API's : + (+) HAL_UART_Abort() + (+) HAL_UART_AbortTransmit() + (+) HAL_UART_AbortReceive() + (+) HAL_UART_Abort_IT() + (+) HAL_UART_AbortTransmit_IT() + (+) HAL_UART_AbortReceive_IT() + + (#) For Abort services based on interrupts (HAL_UART_Abortxxx_IT), a set of Abort Complete Callbacks are provided: + (+) HAL_UART_AbortCpltCallback() + (+) HAL_UART_AbortTransmitCpltCallback() + (+) HAL_UART_AbortReceiveCpltCallback() + + (#) A Rx Event Reception Callback (Rx event notification) is available for Non_Blocking modes of enhanced + reception services: + (+) HAL_UARTEx_RxEventCallback() + + (#) In Non-Blocking mode transfers, possible errors are split into 2 categories. + Errors are handled as follows : + (+) Error is considered as Recoverable and non blocking : Transfer could go till end, but error severity is + to be evaluated by user : this concerns Frame Error, Parity Error or Noise Error + in Interrupt mode reception . + Received character is then retrieved and stored in Rx buffer, Error code is set to allow user + to identify error type, and HAL_UART_ErrorCallback() user callback is executed. + Transfer is kept ongoing on UART side. + If user wants to abort it, Abort services should be called by user. + (+) Error is considered as Blocking : Transfer could not be completed properly and is aborted. + This concerns Overrun Error In Interrupt mode reception and all errors in DMA mode. + Error code is set to allow user to identify error type, and HAL_UART_ErrorCallback() + user callback is executed. + + -@- In the Half duplex communication, it is forbidden to run the transmit + and receive process in parallel, the UART state HAL_UART_STATE_BUSY_TX_RX can't be useful. + +@endverbatim + * @{ + */ + +/** + * @brief Send an amount of data in blocking mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must indicate the number + * of u16 provided through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be sent. + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint8_t *pdata8bits; + uint16_t *pdata16bits; + uint32_t tickstart; + + /* Check that a Tx process is not already ongoing */ + if (huart->gState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR will be + handled through a u16 cast. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->gState = HAL_UART_STATE_BUSY_TX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + huart->TxXferSize = Size; + huart->TxXferCount = Size; + + /* In case of 9bits/No Parity transfer, pData needs to be handled as a uint16_t pointer */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + pdata8bits = NULL; + pdata16bits = (uint16_t *) pData; + } + else + { + pdata8bits = pData; + pdata16bits = NULL; + } + + __HAL_UNLOCK(huart); + + while (huart->TxXferCount > 0U) + { + if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + if (pdata8bits == NULL) + { + huart->Instance->TDR = (uint16_t)(*pdata16bits & 0x01FFU); + pdata16bits++; + } + else + { + huart->Instance->TDR = (uint8_t)(*pdata8bits & 0xFFU); + pdata8bits++; + } + huart->TxXferCount--; + } + + if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TC, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + + /* At end of Tx process, restore huart->gState to Ready */ + huart->gState = HAL_UART_STATE_READY; + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in blocking mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must indicate the number + * of u16 available through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier + * (16 bits) (as received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Receive(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint32_t Timeout) +{ + uint8_t *pdata8bits; + uint16_t *pdata16bits; + uint16_t uhMask; + uint32_t tickstart; + + /* Check that a Rx process is not already ongoing */ + if (huart->RxState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be received from RDR will be + handled through a u16 cast. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->RxState = HAL_UART_STATE_BUSY_RX; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + huart->RxXferSize = Size; + huart->RxXferCount = Size; + + /* Computation of UART mask to apply to RDR register */ + UART_MASK_COMPUTATION(huart); + uhMask = huart->Mask; + + /* In case of 9bits/No Parity transfer, pRxData needs to be handled as a uint16_t pointer */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + pdata8bits = NULL; + pdata16bits = (uint16_t *) pData; + } + else + { + pdata8bits = pData; + pdata16bits = NULL; + } + + __HAL_UNLOCK(huart); + + /* as long as data have to be received */ + while (huart->RxXferCount > 0U) + { + if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + if (pdata8bits == NULL) + { + *pdata16bits = (uint16_t)(huart->Instance->RDR & uhMask); + pdata16bits++; + } + else + { + *pdata8bits = (uint8_t)(huart->Instance->RDR & (uint8_t)uhMask); + pdata8bits++; + } + huart->RxXferCount--; + } + + /* At end of Rx process, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in interrupt mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must indicate the number + * of u16 provided through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be sent. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Transmit_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + /* Check that a Tx process is not already ongoing */ + if (huart->gState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR will be + handled through a u16 cast. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + huart->pTxBuffPtr = pData; + huart->TxXferSize = Size; + huart->TxXferCount = Size; + huart->TxISR = NULL; + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->gState = HAL_UART_STATE_BUSY_TX; + + /* Set the Tx ISR function pointer according to the data word length */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + huart->TxISR = UART_TxISR_16BIT; + } + else + { + huart->TxISR = UART_TxISR_8BIT; + } + + __HAL_UNLOCK(huart); + + /* Enable the Transmit Data Register Empty interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_TXEIE); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in interrupt mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must indicate the number + * of u16 available through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier + * (16 bits) (as received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Receive_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + /* Check that a Rx process is not already ongoing */ + if (huart->RxState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be received from RDR will be + handled through a u16 cast. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + /* Set Reception type to Standard reception */ + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Check that USART RTOEN bit is set */ + if (READ_BIT(huart->Instance->CR2, USART_CR2_RTOEN) != 0U) + { + /* Enable the UART Receiver Timeout Interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_RTOIE); + } + + return (UART_Start_Receive_IT(huart, pData, Size)); + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in DMA mode. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must indicate the number + * of u16 provided through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled by DMA from halfword frontier). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be sent. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Transmit_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + /* Check that a Tx process is not already ongoing */ + if (huart->gState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data copy into TDR will be + handled by DMA from a u16 frontier. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + huart->pTxBuffPtr = pData; + huart->TxXferSize = Size; + huart->TxXferCount = Size; + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->gState = HAL_UART_STATE_BUSY_TX; + + if (huart->hdmatx != NULL) + { + /* Set the UART DMA transfer complete callback */ + huart->hdmatx->XferCpltCallback = UART_DMATransmitCplt; + + /* Set the UART DMA Half transfer complete callback */ + huart->hdmatx->XferHalfCpltCallback = UART_DMATxHalfCplt; + + /* Set the DMA error callback */ + huart->hdmatx->XferErrorCallback = UART_DMAError; + + /* Set the DMA abort callback */ + huart->hdmatx->XferAbortCallback = NULL; + + /* Enable the UART transmit DMA channel */ + if (HAL_DMA_Start_IT(huart->hdmatx, (uint32_t)huart->pTxBuffPtr, (uint32_t)&huart->Instance->TDR, Size) != HAL_OK) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + __HAL_UNLOCK(huart); + + /* Restore huart->gState to ready */ + huart->gState = HAL_UART_STATE_READY; + + return HAL_ERROR; + } + } + /* Clear the TC flag in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_TCF); + + __HAL_UNLOCK(huart); + + /* Enable the DMA transfer for transmit request by setting the DMAT bit + in the UART CR3 register */ + ATOMIC_SET_BIT(huart->Instance->CR3, USART_CR3_DMAT); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in DMA mode. + * @note When the UART parity is enabled (PCE = 1), the received data contain + * the parity bit (MSB position). + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must indicate the number + * of u16 available through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier + * (16 bits) (as received data will be handled by DMA from halfword frontier). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Receive_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + /* Check that a Rx process is not already ongoing */ + if (huart->RxState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a u16 frontier, as data copy from RDR will be + handled by DMA from a u16 frontier. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + /* Set Reception type to Standard reception */ + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Check that USART RTOEN bit is set */ + if (READ_BIT(huart->Instance->CR2, USART_CR2_RTOEN) != 0U) + { + /* Enable the UART Receiver Timeout Interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_RTOIE); + } + + return (UART_Start_Receive_DMA(huart, pData, Size)); + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Pause the DMA Transfer. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_DMAPause(UART_HandleTypeDef *huart) +{ + const HAL_UART_StateTypeDef gstate = huart->gState; + const HAL_UART_StateTypeDef rxstate = huart->RxState; + + __HAL_LOCK(huart); + + if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) && + (gstate == HAL_UART_STATE_BUSY_TX)) + { + /* Disable the UART DMA Tx request */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAT); + } + if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) && + (rxstate == HAL_UART_STATE_BUSY_RX)) + { + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_PEIE); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Disable the UART DMA Rx request */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + } + + __HAL_UNLOCK(huart); + + return HAL_OK; +} + +/** + * @brief Resume the DMA Transfer. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_DMAResume(UART_HandleTypeDef *huart) +{ + __HAL_LOCK(huart); + + if (huart->gState == HAL_UART_STATE_BUSY_TX) + { + /* Enable the UART DMA Tx request */ + ATOMIC_SET_BIT(huart->Instance->CR3, USART_CR3_DMAT); + } + if (huart->RxState == HAL_UART_STATE_BUSY_RX) + { + /* Clear the Overrun flag before resuming the Rx transfer */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF); + + /* Re-enable PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_PEIE); + ATOMIC_SET_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Enable the UART DMA Rx request */ + ATOMIC_SET_BIT(huart->Instance->CR3, USART_CR3_DMAR); + } + + __HAL_UNLOCK(huart); + + return HAL_OK; +} + +/** + * @brief Stop the DMA Transfer. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_DMAStop(UART_HandleTypeDef *huart) +{ + /* The Lock is not implemented on this API to allow the user application + to call the HAL UART API under callbacks HAL_UART_TxCpltCallback() / HAL_UART_RxCpltCallback() / + HAL_UART_TxHalfCpltCallback / HAL_UART_RxHalfCpltCallback: + indeed, when HAL_DMA_Abort() API is called, the DMA TX/RX Transfer or Half Transfer complete + interrupt is generated if the DMA transfer interruption occurs at the middle or at the end of + the stream and the corresponding call back is executed. */ + + const HAL_UART_StateTypeDef gstate = huart->gState; + const HAL_UART_StateTypeDef rxstate = huart->RxState; + + /* Stop UART DMA Tx request if ongoing */ + if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) && + (gstate == HAL_UART_STATE_BUSY_TX)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAT); + + /* Abort the UART DMA Tx channel */ + if (huart->hdmatx != NULL) + { + if (HAL_DMA_Abort(huart->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(huart->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + + UART_EndTxTransfer(huart); + } + + /* Stop UART DMA Rx request if ongoing */ + if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) && + (rxstate == HAL_UART_STATE_BUSY_RX)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the UART DMA Rx channel */ + if (huart->hdmarx != NULL) + { + if (HAL_DMA_Abort(huart->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(huart->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + + UART_EndRxTransfer(huart); + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing transfers (blocking mode). + * @param huart UART handle. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable UART Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Abort(UART_HandleTypeDef *huart) +{ + /* Disable TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE)); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* If Reception till IDLE event was ongoing, disable IDLEIE interrupt */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_IDLEIE)); + } + + /* Disable the UART DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAT); + + /* Abort the UART DMA Tx channel : use blocking DMA Abort API (no callback) */ + if (huart->hdmatx != NULL) + { + /* Set the UART DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + huart->hdmatx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(huart->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(huart->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Disable the UART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the UART DMA Rx channel : use blocking DMA Abort API (no callback) */ + if (huart->hdmarx != NULL) + { + /* Set the UART DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + huart->hdmarx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(huart->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(huart->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Tx and Rx transfer counters */ + huart->TxXferCount = 0U; + huart->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + + /* Discard the received data */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + + /* Restore huart->gState and huart->RxState to Ready */ + huart->gState = HAL_UART_STATE_READY; + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + huart->ErrorCode = HAL_UART_ERROR_NONE; + + return HAL_OK; +} + +/** + * @brief Abort ongoing Transmit transfer (blocking mode). + * @param huart UART handle. + * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable UART Interrupts (Tx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_AbortTransmit(UART_HandleTypeDef *huart) +{ + /* Disable TXEIE and TCIE interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* Disable the UART DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAT); + + /* Abort the UART DMA Tx channel : use blocking DMA Abort API (no callback) */ + if (huart->hdmatx != NULL) + { + /* Set the UART DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + huart->hdmatx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(huart->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(huart->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Tx transfer counter */ + huart->TxXferCount = 0U; + + + /* Restore huart->gState to Ready */ + huart->gState = HAL_UART_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Abort ongoing Receive transfer (blocking mode). + * @param huart UART handle. + * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable UART Interrupts (Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_AbortReceive(UART_HandleTypeDef *huart) +{ + /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* If Reception till IDLE event was ongoing, disable IDLEIE interrupt */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_IDLEIE)); + } + + /* Disable the UART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the UART DMA Rx channel : use blocking DMA Abort API (no callback) */ + if (huart->hdmarx != NULL) + { + /* Set the UART DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + huart->hdmarx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(huart->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(huart->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Rx transfer counter */ + huart->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + /* Discard the received data */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + + /* Restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + return HAL_OK; +} + +/** + * @brief Abort ongoing transfers (Interrupt mode). + * @param huart UART handle. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable UART Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_Abort_IT(UART_HandleTypeDef *huart) +{ + uint32_t abortcplt = 1U; + + /* Disable interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE)); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* If Reception till IDLE event was ongoing, disable IDLEIE interrupt */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_IDLEIE)); + } + + /* If DMA Tx and/or DMA Rx Handles are associated to UART Handle, DMA Abort complete callbacks should be initialised + before any call to DMA Abort functions */ + /* DMA Tx Handle is valid */ + if (huart->hdmatx != NULL) + { + /* Set DMA Abort Complete callback if UART DMA Tx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) + { + huart->hdmatx->XferAbortCallback = UART_DMATxAbortCallback; + } + else + { + huart->hdmatx->XferAbortCallback = NULL; + } + } + /* DMA Rx Handle is valid */ + if (huart->hdmarx != NULL) + { + /* Set DMA Abort Complete callback if UART DMA Rx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) + { + huart->hdmarx->XferAbortCallback = UART_DMARxAbortCallback; + } + else + { + huart->hdmarx->XferAbortCallback = NULL; + } + } + + /* Disable the UART DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) + { + /* Disable DMA Tx at UART level */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAT); + + /* Abort the UART DMA Tx channel : use non blocking DMA Abort API (callback) */ + if (huart->hdmatx != NULL) + { + /* UART Tx DMA Abort callback has already been initialised : + will lead to call HAL_UART_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(huart->hdmatx) != HAL_OK) + { + huart->hdmatx->XferAbortCallback = NULL; + } + else + { + abortcplt = 0U; + } + } + } + + /* Disable the UART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the UART DMA Rx channel : use non blocking DMA Abort API (callback) */ + if (huart->hdmarx != NULL) + { + /* UART Rx DMA Abort callback has already been initialised : + will lead to call HAL_UART_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(huart->hdmarx) != HAL_OK) + { + huart->hdmarx->XferAbortCallback = NULL; + abortcplt = 1U; + } + else + { + abortcplt = 0U; + } + } + } + + /* if no DMA abort complete callback execution is required => call user Abort Complete callback */ + if (abortcplt == 1U) + { + /* Reset Tx and Rx transfer counters */ + huart->TxXferCount = 0U; + huart->RxXferCount = 0U; + + /* Clear ISR function pointers */ + huart->RxISR = NULL; + huart->TxISR = NULL; + + /* Reset errorCode */ + huart->ErrorCode = HAL_UART_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + + /* Discard the received data */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + + /* Restore huart->gState and huart->RxState to Ready */ + huart->gState = HAL_UART_STATE_READY; + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + huart->AbortCpltCallback(huart); +#else + /* Call legacy weak Abort complete callback */ + HAL_UART_AbortCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing Transmit transfer (Interrupt mode). + * @param huart UART handle. + * @note This procedure could be used for aborting any ongoing Tx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable UART Interrupts (Tx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_AbortTransmit_IT(UART_HandleTypeDef *huart) +{ + /* Disable interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* Disable the UART DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAT); + + /* Abort the UART DMA Tx channel : use non blocking DMA Abort API (callback) */ + if (huart->hdmatx != NULL) + { + /* Set the UART DMA Abort callback : + will lead to call HAL_UART_AbortCpltCallback() at end of DMA abort procedure */ + huart->hdmatx->XferAbortCallback = UART_DMATxOnlyAbortCallback; + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(huart->hdmatx) != HAL_OK) + { + /* Call Directly huart->hdmatx->XferAbortCallback function in case of error */ + huart->hdmatx->XferAbortCallback(huart->hdmatx); + } + } + else + { + /* Reset Tx transfer counter */ + huart->TxXferCount = 0U; + + /* Clear TxISR function pointers */ + huart->TxISR = NULL; + + /* Restore huart->gState to Ready */ + huart->gState = HAL_UART_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + huart->AbortTransmitCpltCallback(huart); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_UART_AbortTransmitCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + } + else + { + /* Reset Tx transfer counter */ + huart->TxXferCount = 0U; + + /* Clear TxISR function pointers */ + huart->TxISR = NULL; + + + /* Restore huart->gState to Ready */ + huart->gState = HAL_UART_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + huart->AbortTransmitCpltCallback(huart); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_UART_AbortTransmitCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + + return HAL_OK; +} + +/** + * @brief Abort ongoing Receive transfer (Interrupt mode). + * @param huart UART handle. + * @note This procedure could be used for aborting any ongoing Rx transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable UART Interrupts (Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_AbortReceive_IT(UART_HandleTypeDef *huart) +{ + /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* If Reception till IDLE event was ongoing, disable IDLEIE interrupt */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_IDLEIE)); + } + + /* Disable the UART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the UART DMA Rx channel : use non blocking DMA Abort API (callback) */ + if (huart->hdmarx != NULL) + { + /* Set the UART DMA Abort callback : + will lead to call HAL_UART_AbortCpltCallback() at end of DMA abort procedure */ + huart->hdmarx->XferAbortCallback = UART_DMARxOnlyAbortCallback; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(huart->hdmarx) != HAL_OK) + { + /* Call Directly huart->hdmarx->XferAbortCallback function in case of error */ + huart->hdmarx->XferAbortCallback(huart->hdmarx); + } + } + else + { + /* Reset Rx transfer counter */ + huart->RxXferCount = 0U; + + /* Clear RxISR function pointer */ + huart->pRxBuffPtr = NULL; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + /* Discard the received data */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + + /* Restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + huart->AbortReceiveCpltCallback(huart); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_UART_AbortReceiveCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + } + else + { + /* Reset Rx transfer counter */ + huart->RxXferCount = 0U; + + /* Clear RxISR function pointer */ + huart->pRxBuffPtr = NULL; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + /* Restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + huart->AbortReceiveCpltCallback(huart); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_UART_AbortReceiveCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + + return HAL_OK; +} + +/** + * @brief Handle UART interrupt request. + * @param huart UART handle. + * @retval None + */ +void HAL_UART_IRQHandler(UART_HandleTypeDef *huart) +{ + uint32_t isrflags = READ_REG(huart->Instance->ISR); + uint32_t cr1its = READ_REG(huart->Instance->CR1); + uint32_t cr3its = READ_REG(huart->Instance->CR3); + + uint32_t errorflags; + uint32_t errorcode; + + /* If no error occurs */ + errorflags = (isrflags & (uint32_t)(USART_ISR_PE | USART_ISR_FE | USART_ISR_ORE | USART_ISR_NE | USART_ISR_RTOF)); + if (errorflags == 0U) + { + /* UART in mode Receiver ---------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) + && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + if (huart->RxISR != NULL) + { + huart->RxISR(huart); + } + return; + } + } + + /* If some errors occur */ + if ((errorflags != 0U) + && (((cr3its & USART_CR3_EIE) != 0U) + || ((cr1its & (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_RTOIE)) != 0U))) + { + /* UART parity error interrupt occurred -------------------------------------*/ + if (((isrflags & USART_ISR_PE) != 0U) && ((cr1its & USART_CR1_PEIE) != 0U)) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_PEF); + + huart->ErrorCode |= HAL_UART_ERROR_PE; + } + + /* UART frame error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_FE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_FEF); + + huart->ErrorCode |= HAL_UART_ERROR_FE; + } + + /* UART noise error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_NE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_NEF); + + huart->ErrorCode |= HAL_UART_ERROR_NE; + } + + /* UART Over-Run interrupt occurred -----------------------------------------*/ + if (((isrflags & USART_ISR_ORE) != 0U) + && (((cr1its & USART_CR1_RXNEIE) != 0U) || + ((cr3its & USART_CR3_EIE) != 0U))) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF); + + huart->ErrorCode |= HAL_UART_ERROR_ORE; + } + + /* UART Receiver Timeout interrupt occurred ---------------------------------*/ + if (((isrflags & USART_ISR_RTOF) != 0U) && ((cr1its & USART_CR1_RTOIE) != 0U)) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_RTOF); + + huart->ErrorCode |= HAL_UART_ERROR_RTO; + } + + /* Call UART Error Call back function if need be ----------------------------*/ + if (huart->ErrorCode != HAL_UART_ERROR_NONE) + { + /* UART in mode Receiver --------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) + && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + if (huart->RxISR != NULL) + { + huart->RxISR(huart); + } + } + + /* If Error is to be considered as blocking : + - Receiver Timeout error in Reception + - Overrun error in Reception + - any error occurs in DMA mode reception + */ + errorcode = huart->ErrorCode; + if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) || + ((errorcode & (HAL_UART_ERROR_RTO | HAL_UART_ERROR_ORE)) != 0U)) + { + /* Blocking error : transfer is aborted + Set the UART state ready to be able to start again the process, + Disable Rx Interrupts, and disable Rx DMA request, if ongoing */ + UART_EndRxTransfer(huart); + + /* Disable the UART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the UART DMA Rx channel */ + if (huart->hdmarx != NULL) + { + /* Set the UART DMA Abort callback : + will lead to call HAL_UART_ErrorCallback() at end of DMA abort procedure */ + huart->hdmarx->XferAbortCallback = UART_DMAAbortOnError; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(huart->hdmarx) != HAL_OK) + { + /* Call Directly huart->hdmarx->XferAbortCallback function in case of error */ + huart->hdmarx->XferAbortCallback(huart->hdmarx); + } + } + else + { + /* Call user error callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered error callback*/ + huart->ErrorCallback(huart); +#else + /*Call legacy weak error callback*/ + HAL_UART_ErrorCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + + } + } + else + { + /* Call user error callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered error callback*/ + huart->ErrorCallback(huart); +#else + /*Call legacy weak error callback*/ + HAL_UART_ErrorCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + } + else + { + /* Non Blocking error : transfer could go on. + Error is notified to user through user error callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered error callback*/ + huart->ErrorCallback(huart); +#else + /*Call legacy weak error callback*/ + HAL_UART_ErrorCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + huart->ErrorCode = HAL_UART_ERROR_NONE; + } + } + return; + + } /* End if some error occurs */ + + /* Check current reception Mode : + If Reception till IDLE event has been selected : */ + if ((huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + && ((isrflags & USART_ISR_IDLE) != 0U) + && ((cr1its & USART_ISR_IDLE) != 0U)) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_IDLEF); + + /* Check if DMA mode is enabled in UART */ + if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) + { + /* DMA mode enabled */ + /* Check received length : If all expected data are received, do nothing, + (DMA cplt callback will be called). + Otherwise, if at least one data has already been received, IDLE event is to be notified to user */ + uint16_t nb_remaining_rx_data = (uint16_t) __HAL_DMA_GET_COUNTER(huart->hdmarx); + if ((nb_remaining_rx_data > 0U) + && (nb_remaining_rx_data < huart->RxXferSize)) + { + /* Reception is not complete */ + huart->RxXferCount = nb_remaining_rx_data; + + /* In Normal mode, end DMA xfer and HAL UART Rx process*/ + if (huart->hdmarx->Init.Mode != DMA_CIRCULAR) + { + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_PEIE); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Disable the DMA transfer for the receiver request by resetting the DMAR bit + in the UART CR3 register */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* At end of Rx process, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); + + /* Last bytes received, so no need as the abort is immediate */ + (void)HAL_DMA_Abort(huart->hdmarx); + } +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx Event callback*/ + huart->RxEventCallback(huart, (huart->RxXferSize - huart->RxXferCount)); +#else + /*Call legacy weak Rx Event callback*/ + HAL_UARTEx_RxEventCallback(huart, (huart->RxXferSize - huart->RxXferCount)); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + return; + } + else + { + /* DMA mode not enabled */ + /* Check received length : If all expected data are received, do nothing. + Otherwise, if at least one data has already been received, IDLE event is to be notified to user */ + uint16_t nb_rx_data = huart->RxXferSize - huart->RxXferCount; + if ((huart->RxXferCount > 0U) + && (nb_rx_data > 0U)) + { + /* Disable the UART Parity Error Interrupt and RXNE interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + + /* Disable the UART Error Interrupt: (Frame error, noise error, overrun error) */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Rx process is completed, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Clear RxISR function pointer */ + huart->RxISR = NULL; + + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx complete callback*/ + huart->RxEventCallback(huart, nb_rx_data); +#else + /*Call legacy weak Rx Event callback*/ + HAL_UARTEx_RxEventCallback(huart, nb_rx_data); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + return; + } + } +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + + /* UART wakeup from Stop mode interrupt occurred ---------------------------*/ + if (((isrflags & USART_ISR_WUF) != 0U) && ((cr3its & USART_CR3_WUFIE) != 0U)) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_WUF); + + /* UART Rx state is not reset as a reception process might be ongoing. + If UART handle state fields need to be reset to READY, this could be done in Wakeup callback */ + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Wakeup Callback */ + huart->WakeupCallback(huart); +#else + /* Call legacy weak Wakeup Callback */ + HAL_UARTEx_WakeupCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + return; + } +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + + /* UART in mode Transmitter ------------------------------------------------*/ + if (((isrflags & USART_ISR_TXE) != 0U) + && ((cr1its & USART_CR1_TXEIE) != 0U)) + { + if (huart->TxISR != NULL) + { + huart->TxISR(huart); + } + return; + } + + /* UART in mode Transmitter (transmission end) -----------------------------*/ + if (((isrflags & USART_ISR_TC) != 0U) && ((cr1its & USART_CR1_TCIE) != 0U)) + { + UART_EndTransmit_IT(huart); + return; + } + +} + +/** + * @brief Tx Transfer completed callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_TxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Tx Half Transfer completed callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_TxHalfCpltCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_UART_TxHalfCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Rx Transfer completed callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_RxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Rx Half Transfer completed callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_RxHalfCpltCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_UART_RxHalfCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief UART error callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_ErrorCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_ErrorCallback can be implemented in the user file. + */ +} + +/** + * @brief UART Abort Complete callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_AbortCpltCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_AbortCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief UART Abort Complete callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_AbortTransmitCpltCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_AbortTransmitCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief UART Abort Receive Complete callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UART_AbortReceiveCpltCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UART_AbortReceiveCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Reception Event Callback (Rx event notification called after use of advanced reception service). + * @param huart UART handle + * @param Size Number of data available in application reception buffer (indicates a position in + * reception buffer until which, data are available) + * @retval None + */ +__weak void HAL_UARTEx_RxEventCallback(UART_HandleTypeDef *huart, uint16_t Size) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + UNUSED(Size); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UARTEx_RxEventCallback can be implemented in the user file. + */ +} + +/** + * @} + */ + +/** @defgroup UART_Exported_Functions_Group3 Peripheral Control functions + * @brief UART control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to control the UART. + (+) HAL_UART_ReceiverTimeout_Config() API allows to configure the receiver timeout value on the fly + (+) HAL_UART_EnableReceiverTimeout() API enables the receiver timeout feature + (+) HAL_UART_DisableReceiverTimeout() API disables the receiver timeout feature + (+) HAL_MultiProcessor_EnableMuteMode() API enables mute mode + (+) HAL_MultiProcessor_DisableMuteMode() API disables mute mode + (+) HAL_MultiProcessor_EnterMuteMode() API enters mute mode + (+) UART_SetConfig() API configures the UART peripheral + (+) UART_AdvFeatureConfig() API optionally configures the UART advanced features + (+) UART_CheckIdleState() API ensures that TEACK and/or REACK are set after initialization + (+) HAL_HalfDuplex_EnableTransmitter() API disables receiver and enables transmitter + (+) HAL_HalfDuplex_EnableReceiver() API disables transmitter and enables receiver + (+) HAL_LIN_SendBreak() API transmits the break characters +@endverbatim + * @{ + */ + +/** + * @brief Update on the fly the receiver timeout value in RTOR register. + * @param huart Pointer to a UART_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @param TimeoutValue receiver timeout value in number of baud blocks. The timeout + * value must be less or equal to 0x0FFFFFFFF. + * @retval None + */ +void HAL_UART_ReceiverTimeout_Config(UART_HandleTypeDef *huart, uint32_t TimeoutValue) +{ + assert_param(IS_UART_RECEIVER_TIMEOUT_VALUE(TimeoutValue)); + MODIFY_REG(huart->Instance->RTOR, USART_RTOR_RTO, TimeoutValue); +} + +/** + * @brief Enable the UART receiver timeout feature. + * @param huart Pointer to a UART_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_EnableReceiverTimeout(UART_HandleTypeDef *huart) +{ + if (huart->gState == HAL_UART_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(huart); + + huart->gState = HAL_UART_STATE_BUSY; + + /* Set the USART RTOEN bit */ + SET_BIT(huart->Instance->CR2, USART_CR2_RTOEN); + + huart->gState = HAL_UART_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(huart); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Disable the UART receiver timeout feature. + * @param huart Pointer to a UART_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UART_DisableReceiverTimeout(UART_HandleTypeDef *huart) +{ + if (huart->gState == HAL_UART_STATE_READY) + { + /* Process Locked */ + __HAL_LOCK(huart); + + huart->gState = HAL_UART_STATE_BUSY; + + /* Clear the USART RTOEN bit */ + CLEAR_BIT(huart->Instance->CR2, USART_CR2_RTOEN); + + huart->gState = HAL_UART_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(huart); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Enable UART in mute mode (does not mean UART enters mute mode; + * to enter mute mode, HAL_MultiProcessor_EnterMuteMode() API must be called). + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_MultiProcessor_EnableMuteMode(UART_HandleTypeDef *huart) +{ + __HAL_LOCK(huart); + + huart->gState = HAL_UART_STATE_BUSY; + + /* Enable USART mute mode by setting the MME bit in the CR1 register */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_MME); + + huart->gState = HAL_UART_STATE_READY; + + return (UART_CheckIdleState(huart)); +} + +/** + * @brief Disable UART mute mode (does not mean the UART actually exits mute mode + * as it may not have been in mute mode at this very moment). + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_MultiProcessor_DisableMuteMode(UART_HandleTypeDef *huart) +{ + __HAL_LOCK(huart); + + huart->gState = HAL_UART_STATE_BUSY; + + /* Disable USART mute mode by clearing the MME bit in the CR1 register */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_MME); + + huart->gState = HAL_UART_STATE_READY; + + return (UART_CheckIdleState(huart)); +} + +/** + * @brief Enter UART mute mode (means UART actually enters mute mode). + * @note To exit from mute mode, HAL_MultiProcessor_DisableMuteMode() API must be called. + * @param huart UART handle. + * @retval None + */ +void HAL_MultiProcessor_EnterMuteMode(UART_HandleTypeDef *huart) +{ + __HAL_UART_SEND_REQ(huart, UART_MUTE_MODE_REQUEST); +} + +/** + * @brief Enable the UART transmitter and disable the UART receiver. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_HalfDuplex_EnableTransmitter(UART_HandleTypeDef *huart) +{ + __HAL_LOCK(huart); + huart->gState = HAL_UART_STATE_BUSY; + + /* Clear TE and RE bits */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_TE | USART_CR1_RE)); + + /* Enable the USART's transmit interface by setting the TE bit in the USART CR1 register */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_TE); + + huart->gState = HAL_UART_STATE_READY; + + __HAL_UNLOCK(huart); + + return HAL_OK; +} + +/** + * @brief Enable the UART receiver and disable the UART transmitter. + * @param huart UART handle. + * @retval HAL status. + */ +HAL_StatusTypeDef HAL_HalfDuplex_EnableReceiver(UART_HandleTypeDef *huart) +{ + __HAL_LOCK(huart); + huart->gState = HAL_UART_STATE_BUSY; + + /* Clear TE and RE bits */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_TE | USART_CR1_RE)); + + /* Enable the USART's receive interface by setting the RE bit in the USART CR1 register */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_RE); + + huart->gState = HAL_UART_STATE_READY; + + __HAL_UNLOCK(huart); + + return HAL_OK; +} + + +#if defined(USART_CR2_LINEN) +/** + * @brief Transmit break characters. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_LIN_SendBreak(UART_HandleTypeDef *huart) +{ + /* Check the parameters */ + assert_param(IS_UART_LIN_INSTANCE(huart->Instance)); + + __HAL_LOCK(huart); + + huart->gState = HAL_UART_STATE_BUSY; + + /* Send break characters */ + __HAL_UART_SEND_REQ(huart, UART_SENDBREAK_REQUEST); + + huart->gState = HAL_UART_STATE_READY; + + __HAL_UNLOCK(huart); + + return HAL_OK; +} +#endif /* USART_CR2_LINEN */ + +/** + * @} + */ + +/** @defgroup UART_Exported_Functions_Group4 Peripheral State and Error functions + * @brief UART Peripheral State functions + * +@verbatim + ============================================================================== + ##### Peripheral State and Error functions ##### + ============================================================================== + [..] + This subsection provides functions allowing to : + (+) Return the UART handle state. + (+) Return the UART handle error code + +@endverbatim + * @{ + */ + +/** + * @brief Return the UART handle state. + * @param huart Pointer to a UART_HandleTypeDef structure that contains + * the configuration information for the specified UART. + * @retval HAL state + */ +HAL_UART_StateTypeDef HAL_UART_GetState(UART_HandleTypeDef *huart) +{ + uint32_t temp1; + uint32_t temp2; + temp1 = huart->gState; + temp2 = huart->RxState; + + return (HAL_UART_StateTypeDef)(temp1 | temp2); +} + +/** + * @brief Return the UART handle error code. + * @param huart Pointer to a UART_HandleTypeDef structure that contains + * the configuration information for the specified UART. + * @retval UART Error Code + */ +uint32_t HAL_UART_GetError(UART_HandleTypeDef *huart) +{ + return huart->ErrorCode; +} +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup UART_Private_Functions UART Private Functions + * @{ + */ + +/** + * @brief Initialize the callbacks to their default values. + * @param huart UART handle. + * @retval none + */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) +void UART_InitCallbacksToDefault(UART_HandleTypeDef *huart) +{ + /* Init the UART Callback settings */ + huart->TxHalfCpltCallback = HAL_UART_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + huart->TxCpltCallback = HAL_UART_TxCpltCallback; /* Legacy weak TxCpltCallback */ + huart->RxHalfCpltCallback = HAL_UART_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + huart->RxCpltCallback = HAL_UART_RxCpltCallback; /* Legacy weak RxCpltCallback */ + huart->ErrorCallback = HAL_UART_ErrorCallback; /* Legacy weak ErrorCallback */ + huart->AbortCpltCallback = HAL_UART_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + huart->AbortTransmitCpltCallback = HAL_UART_AbortTransmitCpltCallback; /* Legacy weak AbortTransmitCpltCallback */ + huart->AbortReceiveCpltCallback = HAL_UART_AbortReceiveCpltCallback; /* Legacy weak AbortReceiveCpltCallback */ +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + huart->WakeupCallback = HAL_UARTEx_WakeupCallback; /* Legacy weak WakeupCallback */ +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + huart->RxEventCallback = HAL_UARTEx_RxEventCallback; /* Legacy weak RxEventCallback */ + +} +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + +/** + * @brief Configure the UART peripheral. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef UART_SetConfig(UART_HandleTypeDef *huart) +{ + uint32_t tmpreg; + uint16_t brrtemp; + UART_ClockSourceTypeDef clocksource; + uint32_t usartdiv; + HAL_StatusTypeDef ret = HAL_OK; + uint32_t pclk; + + /* Check the parameters */ + assert_param(IS_UART_BAUDRATE(huart->Init.BaudRate)); + assert_param(IS_UART_WORD_LENGTH(huart->Init.WordLength)); + assert_param(IS_UART_STOPBITS(huart->Init.StopBits)); + assert_param(IS_UART_ONE_BIT_SAMPLE(huart->Init.OneBitSampling)); + + assert_param(IS_UART_PARITY(huart->Init.Parity)); + assert_param(IS_UART_MODE(huart->Init.Mode)); + assert_param(IS_UART_HARDWARE_FLOW_CONTROL(huart->Init.HwFlowCtl)); + assert_param(IS_UART_OVERSAMPLING(huart->Init.OverSampling)); + + /*-------------------------- USART CR1 Configuration -----------------------*/ + /* Clear M, PCE, PS, TE, RE and OVER8 bits and configure + * the UART Word Length, Parity, Mode and oversampling: + * set the M bits according to huart->Init.WordLength value + * set PCE and PS bits according to huart->Init.Parity value + * set TE and RE bits according to huart->Init.Mode value + * set OVER8 bit according to huart->Init.OverSampling value */ + tmpreg = (uint32_t)huart->Init.WordLength | huart->Init.Parity | huart->Init.Mode | huart->Init.OverSampling ; + MODIFY_REG(huart->Instance->CR1, USART_CR1_FIELDS, tmpreg); + + /*-------------------------- USART CR2 Configuration -----------------------*/ + /* Configure the UART Stop Bits: Set STOP[13:12] bits according + * to huart->Init.StopBits value */ + MODIFY_REG(huart->Instance->CR2, USART_CR2_STOP, huart->Init.StopBits); + + /*-------------------------- USART CR3 Configuration -----------------------*/ + /* Configure + * - UART HardWare Flow Control: set CTSE and RTSE bits according + * to huart->Init.HwFlowCtl value + * - one-bit sampling method versus three samples' majority rule according + * to huart->Init.OneBitSampling (not applicable to LPUART) */ + tmpreg = (uint32_t)huart->Init.HwFlowCtl; + + tmpreg |= huart->Init.OneBitSampling; + MODIFY_REG(huart->Instance->CR3, USART_CR3_FIELDS, tmpreg); + + + /*-------------------------- USART BRR Configuration -----------------------*/ + UART_GETCLOCKSOURCE(huart, clocksource); + + if (huart->Init.OverSampling == UART_OVERSAMPLING_8) + { + switch (clocksource) + { + case UART_CLOCKSOURCE_PCLK1: + pclk = HAL_RCC_GetPCLK1Freq(); + break; + case UART_CLOCKSOURCE_HSI: + pclk = (uint32_t) HSI_VALUE; + break; + case UART_CLOCKSOURCE_SYSCLK: + pclk = HAL_RCC_GetSysClockFreq(); + break; + case UART_CLOCKSOURCE_LSE: + pclk = (uint32_t) LSE_VALUE; + break; + default: + pclk = 0U; + ret = HAL_ERROR; + break; + } + + /* USARTDIV must be greater than or equal to 0d16 */ + if (pclk != 0U) + { + usartdiv = (uint16_t)(UART_DIV_SAMPLING8(pclk, huart->Init.BaudRate)); + if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX)) + { + brrtemp = (uint16_t)(usartdiv & 0xFFF0U); + brrtemp |= (uint16_t)((usartdiv & (uint16_t)0x000FU) >> 1U); + huart->Instance->BRR = brrtemp; + } + else + { + ret = HAL_ERROR; + } + } + } + else + { + switch (clocksource) + { + case UART_CLOCKSOURCE_PCLK1: + pclk = HAL_RCC_GetPCLK1Freq(); + break; + case UART_CLOCKSOURCE_HSI: + pclk = (uint32_t) HSI_VALUE; + break; + case UART_CLOCKSOURCE_SYSCLK: + pclk = HAL_RCC_GetSysClockFreq(); + break; + case UART_CLOCKSOURCE_LSE: + pclk = (uint32_t) LSE_VALUE; + break; + default: + pclk = 0U; + ret = HAL_ERROR; + break; + } + + if (pclk != 0U) + { + /* USARTDIV must be greater than or equal to 0d16 */ + usartdiv = (uint16_t)(UART_DIV_SAMPLING16(pclk, huart->Init.BaudRate)); + if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX)) + { + huart->Instance->BRR = usartdiv; + } + else + { + ret = HAL_ERROR; + } + } + } + + + /* Clear ISR function pointers */ + huart->RxISR = NULL; + huart->TxISR = NULL; + + return ret; +} + +/** + * @brief Configure the UART peripheral advanced features. + * @param huart UART handle. + * @retval None + */ +void UART_AdvFeatureConfig(UART_HandleTypeDef *huart) +{ + /* Check whether the set of advanced features to configure is properly set */ + assert_param(IS_UART_ADVFEATURE_INIT(huart->AdvancedInit.AdvFeatureInit)); + + /* if required, configure TX pin active level inversion */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_TXINVERT_INIT)) + { + assert_param(IS_UART_ADVFEATURE_TXINV(huart->AdvancedInit.TxPinLevelInvert)); + MODIFY_REG(huart->Instance->CR2, USART_CR2_TXINV, huart->AdvancedInit.TxPinLevelInvert); + } + + /* if required, configure RX pin active level inversion */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_RXINVERT_INIT)) + { + assert_param(IS_UART_ADVFEATURE_RXINV(huart->AdvancedInit.RxPinLevelInvert)); + MODIFY_REG(huart->Instance->CR2, USART_CR2_RXINV, huart->AdvancedInit.RxPinLevelInvert); + } + + /* if required, configure data inversion */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_DATAINVERT_INIT)) + { + assert_param(IS_UART_ADVFEATURE_DATAINV(huart->AdvancedInit.DataInvert)); + MODIFY_REG(huart->Instance->CR2, USART_CR2_DATAINV, huart->AdvancedInit.DataInvert); + } + + /* if required, configure RX/TX pins swap */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_SWAP_INIT)) + { + assert_param(IS_UART_ADVFEATURE_SWAP(huart->AdvancedInit.Swap)); + MODIFY_REG(huart->Instance->CR2, USART_CR2_SWAP, huart->AdvancedInit.Swap); + } + + /* if required, configure RX overrun detection disabling */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_RXOVERRUNDISABLE_INIT)) + { + assert_param(IS_UART_OVERRUN(huart->AdvancedInit.OverrunDisable)); + MODIFY_REG(huart->Instance->CR3, USART_CR3_OVRDIS, huart->AdvancedInit.OverrunDisable); + } + + /* if required, configure DMA disabling on reception error */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_DMADISABLEONERROR_INIT)) + { + assert_param(IS_UART_ADVFEATURE_DMAONRXERROR(huart->AdvancedInit.DMADisableonRxError)); + MODIFY_REG(huart->Instance->CR3, USART_CR3_DDRE, huart->AdvancedInit.DMADisableonRxError); + } + + /* if required, configure auto Baud rate detection scheme */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_AUTOBAUDRATE_INIT)) + { + assert_param(IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(huart->Instance)); + assert_param(IS_UART_ADVFEATURE_AUTOBAUDRATE(huart->AdvancedInit.AutoBaudRateEnable)); + MODIFY_REG(huart->Instance->CR2, USART_CR2_ABREN, huart->AdvancedInit.AutoBaudRateEnable); + /* set auto Baudrate detection parameters if detection is enabled */ + if (huart->AdvancedInit.AutoBaudRateEnable == UART_ADVFEATURE_AUTOBAUDRATE_ENABLE) + { + assert_param(IS_UART_ADVFEATURE_AUTOBAUDRATEMODE(huart->AdvancedInit.AutoBaudRateMode)); + MODIFY_REG(huart->Instance->CR2, USART_CR2_ABRMODE, huart->AdvancedInit.AutoBaudRateMode); + } + } + + /* if required, configure MSB first on communication line */ + if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_MSBFIRST_INIT)) + { + assert_param(IS_UART_ADVFEATURE_MSBFIRST(huart->AdvancedInit.MSBFirst)); + MODIFY_REG(huart->Instance->CR2, USART_CR2_MSBFIRST, huart->AdvancedInit.MSBFirst); + } +} + +/** + * @brief Check the UART Idle State. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef UART_CheckIdleState(UART_HandleTypeDef *huart) +{ + uint32_t tickstart; + + /* Initialize the UART ErrorCode */ + huart->ErrorCode = HAL_UART_ERROR_NONE; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + /* Check if the Transmitter is enabled */ + if ((huart->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE) + { + /* Wait until TEACK flag is set */ + if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_TEACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + + /* Check if the Receiver is enabled */ + if ((huart->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE) + { + /* Wait until REACK flag is set */ + if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_REACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + + /* Initialize the UART State */ + huart->gState = HAL_UART_STATE_READY; + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + __HAL_UNLOCK(huart); + + return HAL_OK; +} + +/** + * @brief Handle UART Communication Timeout. + * @param huart UART handle. + * @param Flag Specifies the UART flag to check + * @param Status Flag status (SET or RESET) + * @param Tickstart Tick start value + * @param Timeout Timeout duration + * @retval HAL status + */ +HAL_StatusTypeDef UART_WaitOnFlagUntilTimeout(UART_HandleTypeDef *huart, uint32_t Flag, FlagStatus Status, + uint32_t Tickstart, uint32_t Timeout) +{ + /* Wait until flag is set */ + while ((__HAL_UART_GET_FLAG(huart, Flag) ? SET : RESET) == Status) + { + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + /* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error) + interrupts for the interrupt process */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE)); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + huart->gState = HAL_UART_STATE_READY; + huart->RxState = HAL_UART_STATE_READY; + + __HAL_UNLOCK(huart); + + return HAL_TIMEOUT; + } + + if (READ_BIT(huart->Instance->CR1, USART_CR1_RE) != 0U) + { + if (__HAL_UART_GET_FLAG(huart, UART_FLAG_RTOF) == SET) + { + /* Clear Receiver Timeout flag*/ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_RTOF); + + /* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error) + interrupts for the interrupt process */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE)); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + huart->gState = HAL_UART_STATE_READY; + huart->RxState = HAL_UART_STATE_READY; + huart->ErrorCode = HAL_UART_ERROR_RTO; + + /* Process Unlocked */ + __HAL_UNLOCK(huart); + + return HAL_TIMEOUT; + } + } + } + } + return HAL_OK; +} + +/** + * @brief Start Receive operation in interrupt mode. + * @note This function could be called by all HAL UART API providing reception in Interrupt mode. + * @note When calling this function, parameters validity is considered as already checked, + * i.e. Rx State, buffer address, ... + * UART Handle is assumed as Locked. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef UART_Start_Receive_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + huart->pRxBuffPtr = pData; + huart->RxXferSize = Size; + huart->RxXferCount = Size; + huart->RxISR = NULL; + + /* Computation of UART mask to apply to RDR register */ + UART_MASK_COMPUTATION(huart); + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->RxState = HAL_UART_STATE_BUSY_RX; + + /* Enable the UART Error Interrupt: (Frame error, noise error, overrun error) */ + ATOMIC_SET_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Set the Rx ISR function pointer according to the data word length */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + huart->RxISR = UART_RxISR_16BIT; + } + else + { + huart->RxISR = UART_RxISR_8BIT; + } + + __HAL_UNLOCK(huart); + + /* Enable the UART Parity Error interrupt and Data Register Not Empty interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE); + return HAL_OK; +} + +/** + * @brief Start Receive operation in DMA mode. + * @note This function could be called by all HAL UART API providing reception in DMA mode. + * @note When calling this function, parameters validity is considered as already checked, + * i.e. Rx State, buffer address, ... + * UART Handle is assumed as Locked. + * @param huart UART handle. + * @param pData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef UART_Start_Receive_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + huart->pRxBuffPtr = pData; + huart->RxXferSize = Size; + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->RxState = HAL_UART_STATE_BUSY_RX; + + if (huart->hdmarx != NULL) + { + /* Set the UART DMA transfer complete callback */ + huart->hdmarx->XferCpltCallback = UART_DMAReceiveCplt; + + /* Set the UART DMA Half transfer complete callback */ + huart->hdmarx->XferHalfCpltCallback = UART_DMARxHalfCplt; + + /* Set the DMA error callback */ + huart->hdmarx->XferErrorCallback = UART_DMAError; + + /* Set the DMA abort callback */ + huart->hdmarx->XferAbortCallback = NULL; + + /* Enable the DMA channel */ + if (HAL_DMA_Start_IT(huart->hdmarx, (uint32_t)&huart->Instance->RDR, (uint32_t)huart->pRxBuffPtr, Size) != HAL_OK) + { + /* Set error code to DMA */ + huart->ErrorCode = HAL_UART_ERROR_DMA; + + __HAL_UNLOCK(huart); + + /* Restore huart->RxState to ready */ + huart->RxState = HAL_UART_STATE_READY; + + return HAL_ERROR; + } + } + __HAL_UNLOCK(huart); + + /* Enable the UART Parity Error Interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_PEIE); + + /* Enable the UART Error Interrupt: (Frame error, noise error, overrun error) */ + ATOMIC_SET_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Enable the DMA transfer for the receiver request by setting the DMAR bit + in the UART CR3 register */ + ATOMIC_SET_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + return HAL_OK; +} + + +/** + * @brief End ongoing Tx transfer on UART peripheral (following error detection or Transmit completion). + * @param huart UART handle. + * @retval None + */ +static void UART_EndTxTransfer(UART_HandleTypeDef *huart) +{ + /* Disable TXEIE and TCIE interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_TXEIE | USART_CR1_TCIE)); + + /* At end of Tx process, restore huart->gState to Ready */ + huart->gState = HAL_UART_STATE_READY; +} + + +/** + * @brief End ongoing Rx transfer on UART peripheral (following error detection or Reception completion). + * @param huart UART handle. + * @retval None + */ +static void UART_EndRxTransfer(UART_HandleTypeDef *huart) +{ + /* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* In case of reception waiting for IDLE event, disable also the IDLE IE interrupt source */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); + } + + /* At end of Rx process, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Reset RxIsr function pointer */ + huart->RxISR = NULL; +} + + +/** + * @brief DMA UART transmit process complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMATransmitCplt(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + + /* DMA Normal mode */ + if (hdma->Init.Mode != DMA_CIRCULAR) + { + huart->TxXferCount = 0U; + + /* Disable the DMA transfer for transmit request by resetting the DMAT bit + in the UART CR3 register */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAT); + + /* Enable the UART Transmit Complete Interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_TCIE); + } + /* DMA Circular mode */ + else + { +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Tx complete callback*/ + huart->TxCpltCallback(huart); +#else + /*Call legacy weak Tx complete callback*/ + HAL_UART_TxCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } +} + +/** + * @brief DMA UART transmit process half complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMATxHalfCplt(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Tx Half complete callback*/ + huart->TxHalfCpltCallback(huart); +#else + /*Call legacy weak Tx Half complete callback*/ + HAL_UART_TxHalfCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA UART receive process complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMAReceiveCplt(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + + /* DMA Normal mode */ + if (hdma->Init.Mode != DMA_CIRCULAR) + { + huart->RxXferCount = 0U; + + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_PEIE); + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Disable the DMA transfer for the receiver request by resetting the DMAR bit + in the UART CR3 register */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR); + + /* At end of Rx process, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + + /* If Reception till IDLE event has been selected, Disable IDLE Interrupt */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); + } + } + + /* Check current reception Mode : + If Reception till IDLE event has been selected : use Rx Event callback */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx Event callback*/ + huart->RxEventCallback(huart, huart->RxXferSize); +#else + /*Call legacy weak Rx Event callback*/ + HAL_UARTEx_RxEventCallback(huart, huart->RxXferSize); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + else + { + /* In other cases : use Rx Complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx complete callback*/ + huart->RxCpltCallback(huart); +#else + /*Call legacy weak Rx complete callback*/ + HAL_UART_RxCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } +} + +/** + * @brief DMA UART receive process half complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMARxHalfCplt(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + + /* Check current reception Mode : + If Reception till IDLE event has been selected : use Rx Event callback */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx Event callback*/ + huart->RxEventCallback(huart, huart->RxXferSize / 2U); +#else + /*Call legacy weak Rx Event callback*/ + HAL_UARTEx_RxEventCallback(huart, huart->RxXferSize / 2U); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + else + { + /* In other cases : use Rx Half Complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx Half complete callback*/ + huart->RxHalfCpltCallback(huart); +#else + /*Call legacy weak Rx Half complete callback*/ + HAL_UART_RxHalfCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } +} + +/** + * @brief DMA UART communication error callback. + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMAError(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + + const HAL_UART_StateTypeDef gstate = huart->gState; + const HAL_UART_StateTypeDef rxstate = huart->RxState; + + /* Stop UART DMA Tx request if ongoing */ + if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAT)) && + (gstate == HAL_UART_STATE_BUSY_TX)) + { + huart->TxXferCount = 0U; + UART_EndTxTransfer(huart); + } + + /* Stop UART DMA Rx request if ongoing */ + if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) && + (rxstate == HAL_UART_STATE_BUSY_RX)) + { + huart->RxXferCount = 0U; + UART_EndRxTransfer(huart); + } + + huart->ErrorCode |= HAL_UART_ERROR_DMA; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered error callback*/ + huart->ErrorCallback(huart); +#else + /*Call legacy weak error callback*/ + HAL_UART_ErrorCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA UART communication abort callback, when initiated by HAL services on Error + * (To be called at end of DMA Abort procedure following error occurrence). + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMAAbortOnError(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + huart->RxXferCount = 0U; + huart->TxXferCount = 0U; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered error callback*/ + huart->ErrorCallback(huart); +#else + /*Call legacy weak error callback*/ + HAL_UART_ErrorCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA UART Tx communication abort callback, when initiated by user + * (To be called at end of DMA Tx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Rx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMATxAbortCallback(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + + huart->hdmatx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (huart->hdmarx != NULL) + { + if (huart->hdmarx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + huart->TxXferCount = 0U; + huart->RxXferCount = 0U; + + /* Reset errorCode */ + huart->ErrorCode = HAL_UART_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + + /* Restore huart->gState and huart->RxState to Ready */ + huart->gState = HAL_UART_STATE_READY; + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Call user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + huart->AbortCpltCallback(huart); +#else + /* Call legacy weak Abort complete callback */ + HAL_UART_AbortCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + + +/** + * @brief DMA UART Rx communication abort callback, when initiated by user + * (To be called at end of DMA Rx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Tx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMARxAbortCallback(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + + huart->hdmarx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (huart->hdmatx != NULL) + { + if (huart->hdmatx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + huart->TxXferCount = 0U; + huart->RxXferCount = 0U; + + /* Reset errorCode */ + huart->ErrorCode = HAL_UART_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + /* Discard the received data */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + + /* Restore huart->gState and huart->RxState to Ready */ + huart->gState = HAL_UART_STATE_READY; + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Call user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort complete callback */ + huart->AbortCpltCallback(huart); +#else + /* Call legacy weak Abort complete callback */ + HAL_UART_AbortCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + + +/** + * @brief DMA UART Tx communication abort callback, when initiated by user by a call to + * HAL_UART_AbortTransmit_IT API (Abort only Tx transfer) + * (This callback is executed at end of DMA Tx Abort procedure following user abort request, + * and leads to user Tx Abort Complete callback execution). + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMATxOnlyAbortCallback(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent); + + huart->TxXferCount = 0U; + + + /* Restore huart->gState to Ready */ + huart->gState = HAL_UART_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Transmit Complete Callback */ + huart->AbortTransmitCpltCallback(huart); +#else + /* Call legacy weak Abort Transmit Complete Callback */ + HAL_UART_AbortTransmitCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA UART Rx communication abort callback, when initiated by user by a call to + * HAL_UART_AbortReceive_IT API (Abort only Rx transfer) + * (This callback is executed at end of DMA Rx Abort procedure following user abort request, + * and leads to user Rx Abort Complete callback execution). + * @param hdma DMA handle. + * @retval None + */ +static void UART_DMARxOnlyAbortCallback(DMA_HandleTypeDef *hdma) +{ + UART_HandleTypeDef *huart = (UART_HandleTypeDef *)((DMA_HandleTypeDef *)hdma)->Parent; + + huart->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF | UART_CLEAR_NEF | UART_CLEAR_PEF | UART_CLEAR_FEF); + + /* Discard the received data */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + + /* Restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Call user Abort complete callback */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Receive Complete Callback */ + huart->AbortReceiveCpltCallback(huart); +#else + /* Call legacy weak Abort Receive Complete Callback */ + HAL_UART_AbortReceiveCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + +/** + * @brief TX interrupt handler for 7 or 8 bits data word length . + * @note Function is called under interruption only, once + * interruptions have been enabled by HAL_UART_Transmit_IT(). + * @param huart UART handle. + * @retval None + */ +static void UART_TxISR_8BIT(UART_HandleTypeDef *huart) +{ + /* Check that a Tx process is ongoing */ + if (huart->gState == HAL_UART_STATE_BUSY_TX) + { + if (huart->TxXferCount == 0U) + { + /* Disable the UART Transmit Data Register Empty Interrupt */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_TXEIE); + + /* Enable the UART Transmit Complete Interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_TCIE); + } + else + { + huart->Instance->TDR = (uint8_t)(*huart->pTxBuffPtr & (uint8_t)0xFF); + huart->pTxBuffPtr++; + huart->TxXferCount--; + } + } +} + +/** + * @brief TX interrupt handler for 9 bits data word length. + * @note Function is called under interruption only, once + * interruptions have been enabled by HAL_UART_Transmit_IT(). + * @param huart UART handle. + * @retval None + */ +static void UART_TxISR_16BIT(UART_HandleTypeDef *huart) +{ + uint16_t *tmp; + + /* Check that a Tx process is ongoing */ + if (huart->gState == HAL_UART_STATE_BUSY_TX) + { + if (huart->TxXferCount == 0U) + { + /* Disable the UART Transmit Data Register Empty Interrupt */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_TXEIE); + + /* Enable the UART Transmit Complete Interrupt */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_TCIE); + } + else + { + tmp = (uint16_t *) huart->pTxBuffPtr; + huart->Instance->TDR = (((uint32_t)(*tmp)) & 0x01FFUL); + huart->pTxBuffPtr += 2U; + huart->TxXferCount--; + } + } +} + + +/** + * @brief Wrap up transmission in non-blocking mode. + * @param huart pointer to a UART_HandleTypeDef structure that contains + * the configuration information for the specified UART module. + * @retval None + */ +static void UART_EndTransmit_IT(UART_HandleTypeDef *huart) +{ + /* Disable the UART Transmit Complete Interrupt */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_TCIE); + + /* Tx process is ended, restore huart->gState to Ready */ + huart->gState = HAL_UART_STATE_READY; + + /* Cleat TxISR function pointer */ + huart->TxISR = NULL; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Tx complete callback*/ + huart->TxCpltCallback(huart); +#else + /*Call legacy weak Tx complete callback*/ + HAL_UART_TxCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ +} + +/** + * @brief RX interrupt handler for 7 or 8 bits data word length . + * @param huart UART handle. + * @retval None + */ +static void UART_RxISR_8BIT(UART_HandleTypeDef *huart) +{ + uint16_t uhMask = huart->Mask; + uint16_t uhdata; + + /* Check that a Rx process is ongoing */ + if (huart->RxState == HAL_UART_STATE_BUSY_RX) + { + uhdata = (uint16_t) READ_REG(huart->Instance->RDR); + *huart->pRxBuffPtr = (uint8_t)(uhdata & (uint8_t)uhMask); + huart->pRxBuffPtr++; + huart->RxXferCount--; + + if (huart->RxXferCount == 0U) + { + /* Disable the UART Parity Error Interrupt and RXNE interrupts */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + + /* Disable the UART Error Interrupt: (Frame error, noise error, overrun error) */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Rx process is completed, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + + /* Clear RxISR function pointer */ + huart->RxISR = NULL; + + /* Check current reception Mode : + If Reception till IDLE event has been selected : */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + /* Set reception type to Standard */ + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Disable IDLE interrupt */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); + + if (__HAL_UART_GET_FLAG(huart, UART_FLAG_IDLE) == SET) + { + /* Clear IDLE Flag */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_IDLEF); + } +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx Event callback*/ + huart->RxEventCallback(huart, huart->RxXferSize); +#else + /*Call legacy weak Rx Event callback*/ + HAL_UARTEx_RxEventCallback(huart, huart->RxXferSize); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + else + { + /* Standard reception API called */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx complete callback*/ + huart->RxCpltCallback(huart); +#else + /*Call legacy weak Rx complete callback*/ + HAL_UART_RxCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + } + } + else + { + /* Clear RXNE interrupt flag */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + } +} + +/** + * @brief RX interrupt handler for 9 bits data word length . + * @note Function is called under interruption only, once + * interruptions have been enabled by HAL_UART_Receive_IT() + * @param huart UART handle. + * @retval None + */ +static void UART_RxISR_16BIT(UART_HandleTypeDef *huart) +{ + uint16_t *tmp; + uint16_t uhMask = huart->Mask; + uint16_t uhdata; + + /* Check that a Rx process is ongoing */ + if (huart->RxState == HAL_UART_STATE_BUSY_RX) + { + uhdata = (uint16_t) READ_REG(huart->Instance->RDR); + tmp = (uint16_t *) huart->pRxBuffPtr ; + *tmp = (uint16_t)(uhdata & uhMask); + huart->pRxBuffPtr += 2U; + huart->RxXferCount--; + + if (huart->RxXferCount == 0U) + { + /* Disable the UART Parity Error Interrupt and RXNE interrupt*/ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + + /* Disable the UART Error Interrupt: (Frame error, noise error, overrun error) */ + ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE); + + /* Rx process is completed, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + + /* Clear RxISR function pointer */ + huart->RxISR = NULL; + + /* Check current reception Mode : + If Reception till IDLE event has been selected : */ + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + /* Set reception type to Standard */ + huart->ReceptionType = HAL_UART_RECEPTION_STANDARD; + + /* Disable IDLE interrupt */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); + + if (__HAL_UART_GET_FLAG(huart, UART_FLAG_IDLE) == SET) + { + /* Clear IDLE Flag */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_IDLEF); + } +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx Event callback*/ + huart->RxEventCallback(huart, huart->RxXferSize); +#else + /*Call legacy weak Rx Event callback*/ + HAL_UARTEx_RxEventCallback(huart, huart->RxXferSize); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + else + { + /* Standard reception API called */ +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + /*Call registered Rx complete callback*/ + huart->RxCpltCallback(huart); +#else + /*Call legacy weak Rx complete callback*/ + HAL_UART_RxCpltCallback(huart); +#endif /* USE_HAL_UART_REGISTER_CALLBACKS */ + } + } + } + else + { + /* Clear RXNE interrupt flag */ + __HAL_UART_SEND_REQ(huart, UART_RXDATA_FLUSH_REQUEST); + } +} + + +/** + * @} + */ + +#endif /* HAL_UART_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart_ex.c new file mode 100644 index 0000000..808487a --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_uart_ex.c @@ -0,0 +1,816 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_uart_ex.c + * @author MCD Application Team + * @brief Extended UART HAL module driver. + * This file provides firmware functions to manage the following extended + * functionalities of the Universal Asynchronous Receiver Transmitter Peripheral (UART). + * + Initialization and de-initialization functions + * + Peripheral Control functions + * + * + @verbatim + ============================================================================== + ##### UART peripheral extended features ##### + ============================================================================== + + (#) Declare a UART_HandleTypeDef handle structure. + + (#) For the UART RS485 Driver Enable mode, initialize the UART registers + by calling the HAL_RS485Ex_Init() API. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup UARTEx UARTEx + * @brief UART Extended HAL module driver + * @{ + */ + +#ifdef HAL_UART_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ + +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup UARTEx_Private_Functions UARTEx Private Functions + * @{ + */ +#if defined(USART_CR1_UESM) +static void UARTEx_Wakeup_AddressConfig(UART_HandleTypeDef *huart, UART_WakeUpTypeDef WakeUpSelection); +#endif /* USART_CR1_UESM */ +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup UARTEx_Exported_Functions UARTEx Exported Functions + * @{ + */ + +/** @defgroup UARTEx_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Extended Initialization and Configuration Functions + * +@verbatim +=============================================================================== + ##### Initialization and Configuration functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to initialize the USARTx or the UARTy + in asynchronous mode. + (+) For the asynchronous mode the parameters below can be configured: + (++) Baud Rate + (++) Word Length + (++) Stop Bit + (++) Parity: If the parity is enabled, then the MSB bit of the data written + in the data register is transmitted but is changed by the parity bit. + (++) Hardware flow control + (++) Receiver/transmitter modes + (++) Over Sampling Method + (++) One-Bit Sampling Method + (+) For the asynchronous mode, the following advanced features can be configured as well: + (++) TX and/or RX pin level inversion + (++) data logical level inversion + (++) RX and TX pins swap + (++) RX overrun detection disabling + (++) DMA disabling on RX error + (++) MSB first on communication line + (++) auto Baud rate detection + [..] + The HAL_RS485Ex_Init() API follows the UART RS485 mode configuration + procedures (details for the procedures are available in reference manual). + +@endverbatim + + Depending on the frame length defined by the M1 and M0 bits (7-bit, + 8-bit or 9-bit), the possible UART formats are listed in the + following table. + + Table 1. UART frame format. + +-----------------------------------------------------------------------+ + | M1 bit | M0 bit | PCE bit | UART frame | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 0 | | SB | 8 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 1 | | SB | 7 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 0 | | SB | 9 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 1 | | SB | 8 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 0 | | SB | 7 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 1 | | SB | 6 bit data | PB | STB | | + +-----------------------------------------------------------------------+ + + * @{ + */ + +/** + * @brief Initialize the RS485 Driver enable feature according to the specified + * parameters in the UART_InitTypeDef and creates the associated handle. + * @param huart UART handle. + * @param Polarity Select the driver enable polarity. + * This parameter can be one of the following values: + * @arg @ref UART_DE_POLARITY_HIGH DE signal is active high + * @arg @ref UART_DE_POLARITY_LOW DE signal is active low + * @param AssertionTime Driver Enable assertion time: + * 5-bit value defining the time between the activation of the DE (Driver Enable) + * signal and the beginning of the start bit. It is expressed in sample time + * units (1/8 or 1/16 bit time, depending on the oversampling rate) + * @param DeassertionTime Driver Enable deassertion time: + * 5-bit value defining the time between the end of the last stop bit, in a + * transmitted message, and the de-activation of the DE (Driver Enable) signal. + * It is expressed in sample time units (1/8 or 1/16 bit time, depending on the + * oversampling rate). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_RS485Ex_Init(UART_HandleTypeDef *huart, uint32_t Polarity, uint32_t AssertionTime, + uint32_t DeassertionTime) +{ + uint32_t temp; + + /* Check the UART handle allocation */ + if (huart == NULL) + { + return HAL_ERROR; + } + /* Check the Driver Enable UART instance */ + assert_param(IS_UART_DRIVER_ENABLE_INSTANCE(huart->Instance)); + + /* Check the Driver Enable polarity */ + assert_param(IS_UART_DE_POLARITY(Polarity)); + + /* Check the Driver Enable assertion time */ + assert_param(IS_UART_ASSERTIONTIME(AssertionTime)); + + /* Check the Driver Enable deassertion time */ + assert_param(IS_UART_DEASSERTIONTIME(DeassertionTime)); + + if (huart->gState == HAL_UART_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + huart->Lock = HAL_UNLOCKED; + +#if (USE_HAL_UART_REGISTER_CALLBACKS == 1) + UART_InitCallbacksToDefault(huart); + + if (huart->MspInitCallback == NULL) + { + huart->MspInitCallback = HAL_UART_MspInit; + } + + /* Init the low level hardware */ + huart->MspInitCallback(huart); +#else + /* Init the low level hardware : GPIO, CLOCK, CORTEX */ + HAL_UART_MspInit(huart); +#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */ + } + + huart->gState = HAL_UART_STATE_BUSY; + + /* Disable the Peripheral */ + __HAL_UART_DISABLE(huart); + + /* Set the UART Communication parameters */ + if (UART_SetConfig(huart) == HAL_ERROR) + { + return HAL_ERROR; + } + + if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT) + { + UART_AdvFeatureConfig(huart); + } + + /* Enable the Driver Enable mode by setting the DEM bit in the CR3 register */ + SET_BIT(huart->Instance->CR3, USART_CR3_DEM); + + /* Set the Driver Enable polarity */ + MODIFY_REG(huart->Instance->CR3, USART_CR3_DEP, Polarity); + + /* Set the Driver Enable assertion and deassertion times */ + temp = (AssertionTime << UART_CR1_DEAT_ADDRESS_LSB_POS); + temp |= (DeassertionTime << UART_CR1_DEDT_ADDRESS_LSB_POS); + MODIFY_REG(huart->Instance->CR1, (USART_CR1_DEDT | USART_CR1_DEAT), temp); + + /* Enable the Peripheral */ + __HAL_UART_ENABLE(huart); + + /* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */ + return (UART_CheckIdleState(huart)); +} + +/** + * @} + */ + +/** @defgroup UARTEx_Exported_Functions_Group2 IO operation functions + * @brief Extended functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + This subsection provides a set of Wakeup and FIFO mode related callback functions. + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) + (#) Wakeup from Stop mode Callback: + (+) HAL_UARTEx_WakeupCallback() + +#endif +#endif +@endverbatim + * @{ + */ + +#if defined(USART_CR1_UESM) +#if defined(USART_CR3_WUFIE) +/** + * @brief UART wakeup from Stop mode callback. + * @param huart UART handle. + * @retval None + */ +__weak void HAL_UARTEx_WakeupCallback(UART_HandleTypeDef *huart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(huart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_UARTEx_WakeupCallback can be implemented in the user file. + */ +} + +#endif /* USART_CR3_WUFIE */ +#endif /* USART_CR1_UESM */ + +/** + * @} + */ + +/** @defgroup UARTEx_Exported_Functions_Group3 Peripheral Control functions + * @brief Extended Peripheral Control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] This section provides the following functions: + (+) HAL_MultiProcessorEx_AddressLength_Set() API optionally sets the UART node address + detection length to more than 4 bits for multiprocessor address mark wake up. +#if defined(USART_CR1_UESM) + (+) HAL_UARTEx_StopModeWakeUpSourceConfig() API defines the wake-up from stop mode + trigger: address match, Start Bit detection or RXNE bit status. + (+) HAL_UARTEx_EnableStopMode() API enables the UART to wake up the MCU from stop mode + (+) HAL_UARTEx_DisableStopMode() API disables the above functionality +#endif + + [..] This subsection also provides a set of additional functions providing enhanced reception + services to user. (For example, these functions allow application to handle use cases + where number of data to be received is unknown). + + (#) Compared to standard reception services which only consider number of received + data elements as reception completion criteria, these functions also consider additional events + as triggers for updating reception status to caller : + (+) Detection of inactivity period (RX line has not been active for a given period). + (++) RX inactivity detected by IDLE event, i.e. RX line has been in idle state (normally high state) + for 1 frame time, after last received byte. + (++) RX inactivity detected by RTO, i.e. line has been in idle state + for a programmable time, after last received byte. + (+) Detection that a specific character has been received. + + (#) There are two mode of transfer: + (+) Blocking mode: The reception is performed in polling mode, until either expected number of data is received, + or till IDLE event occurs. Reception is handled only during function execution. + When function exits, no data reception could occur. HAL status and number of actually received data elements, + are returned by function after finishing transfer. + (+) Non-Blocking mode: The reception is performed using Interrupts or DMA. + These API's return the HAL status. + The end of the data processing will be indicated through the + dedicated UART IRQ when using Interrupt mode or the DMA IRQ when using DMA mode. + The HAL_UARTEx_RxEventCallback() user callback will be executed during Receive process + The HAL_UART_ErrorCallback()user callback will be executed when a reception error is detected. + + (#) Blocking mode API: + (+) HAL_UARTEx_ReceiveToIdle() + + (#) Non-Blocking mode API with Interrupt: + (+) HAL_UARTEx_ReceiveToIdle_IT() + + (#) Non-Blocking mode API with DMA: + (+) HAL_UARTEx_ReceiveToIdle_DMA() + +@endverbatim + * @{ + */ + +/** + * @brief By default in multiprocessor mode, when the wake up method is set + * to address mark, the UART handles only 4-bit long addresses detection; + * this API allows to enable longer addresses detection (6-, 7- or 8-bit + * long). + * @note Addresses detection lengths are: 6-bit address detection in 7-bit data mode, + * 7-bit address detection in 8-bit data mode, 8-bit address detection in 9-bit data mode. + * @param huart UART handle. + * @param AddressLength This parameter can be one of the following values: + * @arg @ref UART_ADDRESS_DETECT_4B 4-bit long address + * @arg @ref UART_ADDRESS_DETECT_7B 6-, 7- or 8-bit long address + * @retval HAL status + */ +HAL_StatusTypeDef HAL_MultiProcessorEx_AddressLength_Set(UART_HandleTypeDef *huart, uint32_t AddressLength) +{ + /* Check the UART handle allocation */ + if (huart == NULL) + { + return HAL_ERROR; + } + + /* Check the address length parameter */ + assert_param(IS_UART_ADDRESSLENGTH_DETECT(AddressLength)); + + huart->gState = HAL_UART_STATE_BUSY; + + /* Disable the Peripheral */ + __HAL_UART_DISABLE(huart); + + /* Set the address length */ + MODIFY_REG(huart->Instance->CR2, USART_CR2_ADDM7, AddressLength); + + /* Enable the Peripheral */ + __HAL_UART_ENABLE(huart); + + /* TEACK and/or REACK to check before moving huart->gState to Ready */ + return (UART_CheckIdleState(huart)); +} + +#if defined(USART_CR1_UESM) +/** + * @brief Set Wakeup from Stop mode interrupt flag selection. + * @note It is the application responsibility to enable the interrupt used as + * usart_wkup interrupt source before entering low-power mode. + * @param huart UART handle. + * @param WakeUpSelection Address match, Start Bit detection or RXNE/RXFNE bit status. + * This parameter can be one of the following values: + * @arg @ref UART_WAKEUP_ON_ADDRESS + * @arg @ref UART_WAKEUP_ON_STARTBIT + * @arg @ref UART_WAKEUP_ON_READDATA_NONEMPTY + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UARTEx_StopModeWakeUpSourceConfig(UART_HandleTypeDef *huart, UART_WakeUpTypeDef WakeUpSelection) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t tickstart; + + /* check the wake-up from stop mode UART instance */ + assert_param(IS_UART_WAKEUP_FROMSTOP_INSTANCE(huart->Instance)); + /* check the wake-up selection parameter */ + assert_param(IS_UART_WAKEUP_SELECTION(WakeUpSelection.WakeUpEvent)); + + /* Process Locked */ + __HAL_LOCK(huart); + + huart->gState = HAL_UART_STATE_BUSY; + + /* Disable the Peripheral */ + __HAL_UART_DISABLE(huart); + +#if defined(USART_CR3_WUS) + /* Set the wake-up selection scheme */ + MODIFY_REG(huart->Instance->CR3, USART_CR3_WUS, WakeUpSelection.WakeUpEvent); +#endif /* USART_CR3_WUS */ + + if (WakeUpSelection.WakeUpEvent == UART_WAKEUP_ON_ADDRESS) + { + UARTEx_Wakeup_AddressConfig(huart, WakeUpSelection); + } + + /* Enable the Peripheral */ + __HAL_UART_ENABLE(huart); + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + /* Wait until REACK flag is set */ + if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_REACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK) + { + status = HAL_TIMEOUT; + } + else + { + /* Initialize the UART State */ + huart->gState = HAL_UART_STATE_READY; + } + + /* Process Unlocked */ + __HAL_UNLOCK(huart); + + return status; +} + +/** + * @brief Enable UART Stop Mode. + * @note The UART is able to wake up the MCU from Stop 1 mode as long as UART clock is HSI or LSE. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UARTEx_EnableStopMode(UART_HandleTypeDef *huart) +{ + /* Process Locked */ + __HAL_LOCK(huart); + + /* Set UESM bit */ + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_UESM); + + /* Process Unlocked */ + __HAL_UNLOCK(huart); + + return HAL_OK; +} + +/** + * @brief Disable UART Stop Mode. + * @param huart UART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UARTEx_DisableStopMode(UART_HandleTypeDef *huart) +{ + /* Process Locked */ + __HAL_LOCK(huart); + + /* Clear UESM bit */ + ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_UESM); + + /* Process Unlocked */ + __HAL_UNLOCK(huart); + + return HAL_OK; +} + +#endif /* USART_CR1_UESM */ +/** + * @brief Receive an amount of data in blocking mode till either the expected number of data + * is received or an IDLE event occurs. + * @note HAL_OK is returned if reception is completed (expected number of data has been received) + * or if reception is stopped after IDLE event (less than the expected number of data has been received) + * In this case, RxLen output parameter indicates number of data available in reception buffer. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of uint16_t. In this case, Size must indicate the number + * of uint16_t available through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier + * (16 bits) (as received data will be handled using uint16_t pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper + * alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (uint8_t or uint16_t data elements). + * @param Size Amount of data elements (uint8_t or uint16_t) to be received. + * @param RxLen Number of data elements finally received + * (could be lower than Size, in case reception ends on IDLE event) + * @param Timeout Timeout duration expressed in ms (covers the whole reception sequence). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UARTEx_ReceiveToIdle(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size, uint16_t *RxLen, + uint32_t Timeout) +{ + uint8_t *pdata8bits; + uint16_t *pdata16bits; + uint16_t uhMask; + uint32_t tickstart; + + /* Check that a Rx process is not already ongoing */ + if (huart->RxState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a uint16_t frontier, as data to be received from RDR will be + handled through a uint16_t cast. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + huart->ErrorCode = HAL_UART_ERROR_NONE; + huart->RxState = HAL_UART_STATE_BUSY_RX; + huart->ReceptionType = HAL_UART_RECEPTION_TOIDLE; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + huart->RxXferSize = Size; + huart->RxXferCount = Size; + + /* Computation of UART mask to apply to RDR register */ + UART_MASK_COMPUTATION(huart); + uhMask = huart->Mask; + + /* In case of 9bits/No Parity transfer, pRxData needs to be handled as a uint16_t pointer */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + pdata8bits = NULL; + pdata16bits = (uint16_t *) pData; + } + else + { + pdata8bits = pData; + pdata16bits = NULL; + } + + __HAL_UNLOCK(huart); + + /* Initialize output number of received elements */ + *RxLen = 0U; + + /* as long as data have to be received */ + while (huart->RxXferCount > 0U) + { + /* Check if IDLE flag is set */ + if (__HAL_UART_GET_FLAG(huart, UART_FLAG_IDLE)) + { + /* Clear IDLE flag in ISR */ + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_IDLEF); + + /* If Set, but no data ever received, clear flag without exiting loop */ + /* If Set, and data has already been received, this means Idle Event is valid : End reception */ + if (*RxLen > 0U) + { + huart->RxState = HAL_UART_STATE_READY; + + return HAL_OK; + } + } + + /* Check if RXNE flag is set */ + if (__HAL_UART_GET_FLAG(huart, UART_FLAG_RXNE)) + { + if (pdata8bits == NULL) + { + *pdata16bits = (uint16_t)(huart->Instance->RDR & uhMask); + pdata16bits++; + } + else + { + *pdata8bits = (uint8_t)(huart->Instance->RDR & (uint8_t)uhMask); + pdata8bits++; + } + /* Increment number of received elements */ + *RxLen += 1U; + huart->RxXferCount--; + } + + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0U)) + { + huart->RxState = HAL_UART_STATE_READY; + + return HAL_TIMEOUT; + } + } + } + + /* Set number of received elements in output parameter : RxLen */ + *RxLen = huart->RxXferSize - huart->RxXferCount; + /* At end of Rx process, restore huart->RxState to Ready */ + huart->RxState = HAL_UART_STATE_READY; + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in interrupt mode till either the expected number of data + * is received or an IDLE event occurs. + * @note Reception is initiated by this function call. Further progress of reception is achieved thanks + * to UART interrupts raised by RXNE and IDLE events. Callback is called at end of reception indicating + * number of received data elements. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of uint16_t. In this case, Size must indicate the number + * of uint16_t available through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier + * (16 bits) (as received data will be handled using uint16_t pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (uint8_t or uint16_t data elements). + * @param Size Amount of data elements (uint8_t or uint16_t) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UARTEx_ReceiveToIdle_IT(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef status; + + /* Check that a Rx process is not already ongoing */ + if (huart->RxState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a uint16_t frontier, as data to be received from RDR will be + handled through a uint16_t cast. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + /* Set Reception type to reception till IDLE Event*/ + huart->ReceptionType = HAL_UART_RECEPTION_TOIDLE; + + status = UART_Start_Receive_IT(huart, pData, Size); + + /* Check Rx process has been successfully started */ + if (status == HAL_OK) + { + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_IDLEF); + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); + } + else + { + /* In case of errors already pending when reception is started, + Interrupts may have already been raised and lead to reception abortion. + (Overrun error for instance). + In such case Reception Type has been reset to HAL_UART_RECEPTION_STANDARD. */ + status = HAL_ERROR; + } + } + + return status; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in DMA mode till either the expected number + * of data is received or an IDLE event occurs. + * @note Reception is initiated by this function call. Further progress of reception is achieved thanks + * to DMA services, transferring automatically received data elements in user reception buffer and + * calling registered callbacks at half/end of reception. UART IDLE events are also used to consider + * reception phase as ended. In all cases, callback execution will indicate number of received data elements. + * @note When the UART parity is enabled (PCE = 1), the received data contain + * the parity bit (MSB position). + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of uint16_t. In this case, Size must indicate the number + * of uint16_t available through pData. + * @note When UART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier + * (16 bits) (as received data will be handled by DMA from halfword frontier). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pData. + * @param huart UART handle. + * @param pData Pointer to data buffer (uint8_t or uint16_t data elements). + * @param Size Amount of data elements (uint8_t or uint16_t) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_UARTEx_ReceiveToIdle_DMA(UART_HandleTypeDef *huart, uint8_t *pData, uint16_t Size) +{ + HAL_StatusTypeDef status; + + /* Check that a Rx process is not already ongoing */ + if (huart->RxState == HAL_UART_STATE_READY) + { + if ((pData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pData buffer provided as input parameter + should be aligned on a uint16_t frontier, as data copy from RDR will be + handled by DMA from a uint16_t frontier. */ + if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE)) + { + if ((((uint32_t)pData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + __HAL_LOCK(huart); + + /* Set Reception type to reception till IDLE Event*/ + huart->ReceptionType = HAL_UART_RECEPTION_TOIDLE; + + status = UART_Start_Receive_DMA(huart, pData, Size); + + /* Check Rx process has been successfully started */ + if (status == HAL_OK) + { + if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE) + { + __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_IDLEF); + ATOMIC_SET_BIT(huart->Instance->CR1, USART_CR1_IDLEIE); + } + else + { + /* In case of errors already pending when reception is started, + Interrupts may have already been raised and lead to reception abortion. + (Overrun error for instance). + In such case Reception Type has been reset to HAL_UART_RECEPTION_STANDARD. */ + status = HAL_ERROR; + } + } + + return status; + } + else + { + return HAL_BUSY; + } +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup UARTEx_Private_Functions + * @{ + */ +#if defined(USART_CR1_UESM) + +/** + * @brief Initialize the UART wake-up from stop mode parameters when triggered by address detection. + * @param huart UART handle. + * @param WakeUpSelection UART wake up from stop mode parameters. + * @retval None + */ +static void UARTEx_Wakeup_AddressConfig(UART_HandleTypeDef *huart, UART_WakeUpTypeDef WakeUpSelection) +{ + assert_param(IS_UART_ADDRESSLENGTH_DETECT(WakeUpSelection.AddressLength)); + + /* Set the USART address length */ + MODIFY_REG(huart->Instance->CR2, USART_CR2_ADDM7, WakeUpSelection.AddressLength); + + /* Set the USART address node */ + MODIFY_REG(huart->Instance->CR2, USART_CR2_ADD, ((uint32_t)WakeUpSelection.Address << UART_CR2_ADDRESS_LSB_POS)); +} +#endif /* USART_CR1_UESM */ + +/** + * @} + */ + +#endif /* HAL_UART_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart.c new file mode 100644 index 0000000..420101e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart.c @@ -0,0 +1,3265 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_usart.c + * @author MCD Application Team + * @brief USART HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Universal Synchronous/Asynchronous Receiver Transmitter + * Peripheral (USART). + * + Initialization and de-initialization functions + * + IO operation functions + * + Peripheral Control functions + * + Peripheral State and Error functions + * + @verbatim + =============================================================================== + ##### How to use this driver ##### + =============================================================================== + [..] + The USART HAL driver can be used as follows: + + (#) Declare a USART_HandleTypeDef handle structure (eg. USART_HandleTypeDef husart). + (#) Initialize the USART low level resources by implementing the HAL_USART_MspInit() API: + (++) Enable the USARTx interface clock. + (++) USART pins configuration: + (+++) Enable the clock for the USART GPIOs. + (+++) Configure these USART pins as alternate function pull-up. + (++) NVIC configuration if you need to use interrupt process (HAL_USART_Transmit_IT(), + HAL_USART_Receive_IT() and HAL_USART_TransmitReceive_IT() APIs): + (+++) Configure the USARTx interrupt priority. + (+++) Enable the NVIC USART IRQ handle. + (++) USART interrupts handling: + -@@- The specific USART interrupts (Transmission complete interrupt, + RXNE interrupt and Error Interrupts) will be managed using the macros + __HAL_USART_ENABLE_IT() and __HAL_USART_DISABLE_IT() inside the transmit and receive process. + (++) DMA Configuration if you need to use DMA process (HAL_USART_Transmit_DMA() + HAL_USART_Receive_DMA() and HAL_USART_TransmitReceive_DMA() APIs): + (+++) Declare a DMA handle structure for the Tx/Rx channel. + (+++) Enable the DMAx interface clock. + (+++) Configure the declared DMA handle structure with the required Tx/Rx parameters. + (+++) Configure the DMA Tx/Rx channel. + (+++) Associate the initialized DMA handle to the USART DMA Tx/Rx handle. + (+++) Configure the priority and enable the NVIC for the transfer + complete interrupt on the DMA Tx/Rx channel. + + (#) Program the Baud Rate, Word Length, Stop Bit, Parity, and Mode + (Receiver/Transmitter) in the husart handle Init structure. + + (#) Initialize the USART registers by calling the HAL_USART_Init() API: + (++) This API configures also the low level Hardware GPIO, CLOCK, CORTEX...etc) + by calling the customized HAL_USART_MspInit(&husart) API. + + [..] + (@) To configure and enable/disable the USART to wake up the MCU from stop mode, resort to UART API's + HAL_UARTEx_StopModeWakeUpSourceConfig(), HAL_UARTEx_EnableStopMode() and + HAL_UARTEx_DisableStopMode() in casting the USART handle to UART type UART_HandleTypeDef. + + ##### Callback registration ##### + ================================== + + [..] + The compilation define USE_HAL_USART_REGISTER_CALLBACKS when set to 1 + allows the user to configure dynamically the driver callbacks. + + [..] + Use Function HAL_USART_RegisterCallback() to register a user callback. + Function HAL_USART_RegisterCallback() allows to register following callbacks: + (+) TxHalfCpltCallback : Tx Half Complete Callback. + (+) TxCpltCallback : Tx Complete Callback. + (+) RxHalfCpltCallback : Rx Half Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) TxRxCpltCallback : Tx Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) MspInitCallback : USART MspInit. + (+) MspDeInitCallback : USART MspDeInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + [..] + Use function HAL_USART_UnRegisterCallback() to reset a callback to the default + weak (surcharged) function. + HAL_USART_UnRegisterCallback() takes as parameters the HAL peripheral handle, + and the Callback ID. + This function allows to reset following callbacks: + (+) TxHalfCpltCallback : Tx Half Complete Callback. + (+) TxCpltCallback : Tx Complete Callback. + (+) RxHalfCpltCallback : Rx Half Complete Callback. + (+) RxCpltCallback : Rx Complete Callback. + (+) TxRxCpltCallback : Tx Rx Complete Callback. + (+) ErrorCallback : Error Callback. + (+) AbortCpltCallback : Abort Complete Callback. + (+) MspInitCallback : USART MspInit. + (+) MspDeInitCallback : USART MspDeInit. + + [..] + By default, after the HAL_USART_Init() and when the state is HAL_USART_STATE_RESET + all callbacks are set to the corresponding weak (surcharged) functions: + examples HAL_USART_TxCpltCallback(), HAL_USART_RxHalfCpltCallback(). + Exception done for MspInit and MspDeInit functions that are respectively + reset to the legacy weak (surcharged) functions in the HAL_USART_Init() + and HAL_USART_DeInit() only when these callbacks are null (not registered beforehand). + If not, MspInit or MspDeInit are not null, the HAL_USART_Init() and HAL_USART_DeInit() + keep and use the user MspInit/MspDeInit callbacks (registered beforehand). + + [..] + Callbacks can be registered/unregistered in HAL_USART_STATE_READY state only. + Exception done MspInit/MspDeInit that can be registered/unregistered + in HAL_USART_STATE_READY or HAL_USART_STATE_RESET state, thus registered (user) + MspInit/DeInit callbacks can be used during the Init/DeInit. + In that case first register the MspInit/MspDeInit user callbacks + using HAL_USART_RegisterCallback() before calling HAL_USART_DeInit() + or HAL_USART_Init() function. + + [..] + When The compilation define USE_HAL_USART_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registration feature is not available + and weak (surcharged) callbacks are used. + + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup USART USART + * @brief HAL USART Synchronous module driver + * @{ + */ + +#ifdef HAL_USART_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/** @defgroup USART_Private_Constants USART Private Constants + * @{ + */ +#define USART_DUMMY_DATA ((uint16_t) 0xFFFF) /*!< USART transmitted dummy data */ +#define USART_TEACK_REACK_TIMEOUT 1000U /*!< USART TX or RX enable acknowledge time-out value */ +#define USART_CR1_FIELDS ((uint32_t)(USART_CR1_M | USART_CR1_PCE | USART_CR1_PS | \ + USART_CR1_TE | USART_CR1_RE | USART_CR1_OVER8)) /*!< USART CR1 fields of parameters set by USART_SetConfig API */ +#define USART_CR2_FIELDS ((uint32_t)(USART_CR2_CPHA | USART_CR2_CPOL | \ + USART_CR2_CLKEN | USART_CR2_LBCL | USART_CR2_STOP)) /*!< USART CR2 fields of parameters set by USART_SetConfig API */ + +#define USART_BRR_MIN 0x10U /* USART BRR minimum authorized value */ +#define USART_BRR_MAX 0xFFFFU /* USART BRR maximum authorized value */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/** @addtogroup USART_Private_Functions + * @{ + */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) +void USART_InitCallbacksToDefault(USART_HandleTypeDef *husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ +static void USART_EndTransfer(USART_HandleTypeDef *husart); +static void USART_DMATransmitCplt(DMA_HandleTypeDef *hdma); +static void USART_DMAReceiveCplt(DMA_HandleTypeDef *hdma); +static void USART_DMATxHalfCplt(DMA_HandleTypeDef *hdma); +static void USART_DMARxHalfCplt(DMA_HandleTypeDef *hdma); +static void USART_DMAError(DMA_HandleTypeDef *hdma); +static void USART_DMAAbortOnError(DMA_HandleTypeDef *hdma); +static void USART_DMATxAbortCallback(DMA_HandleTypeDef *hdma); +static void USART_DMARxAbortCallback(DMA_HandleTypeDef *hdma); +static HAL_StatusTypeDef USART_WaitOnFlagUntilTimeout(USART_HandleTypeDef *husart, uint32_t Flag, FlagStatus Status, + uint32_t Tickstart, uint32_t Timeout); +static HAL_StatusTypeDef USART_SetConfig(USART_HandleTypeDef *husart); +static HAL_StatusTypeDef USART_CheckIdleState(USART_HandleTypeDef *husart); +static void USART_TxISR_8BIT(USART_HandleTypeDef *husart); +static void USART_TxISR_16BIT(USART_HandleTypeDef *husart); +static void USART_EndTransmit_IT(USART_HandleTypeDef *husart); +static void USART_RxISR_8BIT(USART_HandleTypeDef *husart); +static void USART_RxISR_16BIT(USART_HandleTypeDef *husart); + + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup USART_Exported_Functions USART Exported Functions + * @{ + */ + +/** @defgroup USART_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * +@verbatim + =============================================================================== + ##### Initialization and Configuration functions ##### + =============================================================================== + [..] + This subsection provides a set of functions allowing to initialize the USART + in asynchronous and in synchronous modes. + (+) For the asynchronous mode only these parameters can be configured: + (++) Baud Rate + (++) Word Length + (++) Stop Bit + (++) Parity: If the parity is enabled, then the MSB bit of the data written + in the data register is transmitted but is changed by the parity bit. + (++) USART polarity + (++) USART phase + (++) USART LastBit + (++) Receiver/transmitter modes + + [..] + The HAL_USART_Init() function follows the USART synchronous configuration + procedure (details for the procedure are available in reference manual). + +@endverbatim + + Depending on the frame length either defined by the M1 and M0 bits (7-bit, + 8-bit or 9-bit) or by the M bit (8-bits or 9-bits), the possible USART formats + are listed in the following table. + + Table 1. USART frame format. + +-----------------------------------------------------------------------+ + | M bit | PCE bit | USART frame | + |-------------------|-----------|---------------------------------------| + | 0 | 0 | | SB | 8-bit data | STB | | + |-------------------|-----------|---------------------------------------| + | 0 | 1 | | SB | 7-bit data | PB | STB | | + |-------------------|-----------|---------------------------------------| + | 1 | 0 | | SB | 9-bit data | STB | | + |-------------------|-----------|---------------------------------------| + | 1 | 1 | | SB | 8-bit data | PB | STB | | + +-----------------------------------------------------------------------+ + +-----------------------------------------------------------------------+ + | M1 bit | M0 bit | PCE bit | USART frame | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 0 | | SB | 8 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 0 | 1 | | SB | 7 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 0 | | SB | 9 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 0 | 1 | 1 | | SB | 8 bit data | PB | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 0 | | SB | 7 bit data | STB | | + |---------|---------|-----------|---------------------------------------| + | 1 | 0 | 1 | | SB | 6 bit data | PB | STB | | + +-----------------------------------------------------------------------+ + + * @{ + */ + +/** + * @brief Initialize the USART mode according to the specified + * parameters in the USART_InitTypeDef and initialize the associated handle. + * @param husart USART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Init(USART_HandleTypeDef *husart) +{ + /* Check the USART handle allocation */ + if (husart == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_USART_INSTANCE(husart->Instance)); + + if (husart->State == HAL_USART_STATE_RESET) + { + /* Allocate lock resource and initialize it */ + husart->Lock = HAL_UNLOCKED; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + USART_InitCallbacksToDefault(husart); + + if (husart->MspInitCallback == NULL) + { + husart->MspInitCallback = HAL_USART_MspInit; + } + + /* Init the low level hardware */ + husart->MspInitCallback(husart); +#else + /* Init the low level hardware : GPIO, CLOCK */ + HAL_USART_MspInit(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + + husart->State = HAL_USART_STATE_BUSY; + + /* Disable the Peripheral */ + __HAL_USART_DISABLE(husart); + + /* Set the Usart Communication parameters */ + if (USART_SetConfig(husart) == HAL_ERROR) + { + return HAL_ERROR; + } + + /* In Synchronous mode, the following bits must be kept cleared: + - LINEN bit (if LIN is supported) in the USART_CR2 register + - SCEN (if Smartcard is supported), HDSEL and IREN (if IrDA is supported) bits in the USART_CR3 register. + */ +#if defined (USART_CR2_LINEN) + husart->Instance->CR2 &= ~USART_CR2_LINEN; +#endif /* USART_CR2_LINEN */ +#if defined (USART_CR3_SCEN) +#if defined (USART_CR3_IREN) + husart->Instance->CR3 &= ~(USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN); +#else + husart->Instance->CR3 &= ~(USART_CR3_SCEN | USART_CR3_HDSEL); +#endif /* USART_CR3_IREN */ +#else +#if defined (USART_CR3_IREN) + husart->Instance->CR3 &= ~(USART_CR3_HDSEL | USART_CR3_IREN); +#else + husart->Instance->CR3 &= ~(USART_CR3_HDSEL); +#endif /* USART_CR3_IREN */ +#endif /* USART_CR3_SCEN */ + + /* Enable the Peripheral */ + __HAL_USART_ENABLE(husart); + + /* TEACK and/or REACK to check before moving husart->State to Ready */ + return (USART_CheckIdleState(husart)); +} + +/** + * @brief DeInitialize the USART peripheral. + * @param husart USART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_DeInit(USART_HandleTypeDef *husart) +{ + /* Check the USART handle allocation */ + if (husart == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_USART_INSTANCE(husart->Instance)); + + husart->State = HAL_USART_STATE_BUSY; + + husart->Instance->CR1 = 0x0U; + husart->Instance->CR2 = 0x0U; + husart->Instance->CR3 = 0x0U; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + if (husart->MspDeInitCallback == NULL) + { + husart->MspDeInitCallback = HAL_USART_MspDeInit; + } + /* DeInit the low level hardware */ + husart->MspDeInitCallback(husart); +#else + /* DeInit the low level hardware */ + HAL_USART_MspDeInit(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_RESET; + + /* Process Unlock */ + __HAL_UNLOCK(husart); + + return HAL_OK; +} + +/** + * @brief Initialize the USART MSP. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_MspInit(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_USART_MspInit can be implemented in the user file + */ +} + +/** + * @brief DeInitialize the USART MSP. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_MspDeInit(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_USART_MspDeInit can be implemented in the user file + */ +} + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User USART Callback + * To be used instead of the weak predefined callback + * @param husart usart handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_USART_TX_HALFCOMPLETE_CB_ID Tx Half Complete Callback ID + * @arg @ref HAL_USART_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_USART_RX_HALFCOMPLETE_CB_ID Rx Half Complete Callback ID + * @arg @ref HAL_USART_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_USART_TX_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_USART_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_USART_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_USART_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_USART_MSPDEINIT_CB_ID MspDeInit Callback ID + * @param pCallback pointer to the Callback function + * @retval HAL status ++ */ +HAL_StatusTypeDef HAL_USART_RegisterCallback(USART_HandleTypeDef *husart, HAL_USART_CallbackIDTypeDef CallbackID, + pUSART_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + /* Update the error code */ + husart->ErrorCode |= HAL_USART_ERROR_INVALID_CALLBACK; + + return HAL_ERROR; + } + /* Process locked */ + __HAL_LOCK(husart); + + if (husart->State == HAL_USART_STATE_READY) + { + switch (CallbackID) + { + case HAL_USART_TX_HALFCOMPLETE_CB_ID : + husart->TxHalfCpltCallback = pCallback; + break; + + case HAL_USART_TX_COMPLETE_CB_ID : + husart->TxCpltCallback = pCallback; + break; + + case HAL_USART_RX_HALFCOMPLETE_CB_ID : + husart->RxHalfCpltCallback = pCallback; + break; + + case HAL_USART_RX_COMPLETE_CB_ID : + husart->RxCpltCallback = pCallback; + break; + + case HAL_USART_TX_RX_COMPLETE_CB_ID : + husart->TxRxCpltCallback = pCallback; + break; + + case HAL_USART_ERROR_CB_ID : + husart->ErrorCallback = pCallback; + break; + + case HAL_USART_ABORT_COMPLETE_CB_ID : + husart->AbortCpltCallback = pCallback; + break; + + + case HAL_USART_MSPINIT_CB_ID : + husart->MspInitCallback = pCallback; + break; + + case HAL_USART_MSPDEINIT_CB_ID : + husart->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + husart->ErrorCode |= HAL_USART_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (husart->State == HAL_USART_STATE_RESET) + { + switch (CallbackID) + { + case HAL_USART_MSPINIT_CB_ID : + husart->MspInitCallback = pCallback; + break; + + case HAL_USART_MSPDEINIT_CB_ID : + husart->MspDeInitCallback = pCallback; + break; + + default : + /* Update the error code */ + husart->ErrorCode |= HAL_USART_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + husart->ErrorCode |= HAL_USART_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(husart); + + return status; +} + +/** + * @brief Unregister an USART Callback + * USART callaback is redirected to the weak predefined callback + * @param husart usart handle + * @param CallbackID ID of the callback to be unregistered + * This parameter can be one of the following values: + * @arg @ref HAL_USART_TX_HALFCOMPLETE_CB_ID Tx Half Complete Callback ID + * @arg @ref HAL_USART_TX_COMPLETE_CB_ID Tx Complete Callback ID + * @arg @ref HAL_USART_RX_HALFCOMPLETE_CB_ID Rx Half Complete Callback ID + * @arg @ref HAL_USART_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_USART_TX_RX_COMPLETE_CB_ID Rx Complete Callback ID + * @arg @ref HAL_USART_ERROR_CB_ID Error Callback ID + * @arg @ref HAL_USART_ABORT_COMPLETE_CB_ID Abort Complete Callback ID + * @arg @ref HAL_USART_MSPINIT_CB_ID MspInit Callback ID + * @arg @ref HAL_USART_MSPDEINIT_CB_ID MspDeInit Callback ID + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_UnRegisterCallback(USART_HandleTypeDef *husart, HAL_USART_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + /* Process locked */ + __HAL_LOCK(husart); + + if (HAL_USART_STATE_READY == husart->State) + { + switch (CallbackID) + { + case HAL_USART_TX_HALFCOMPLETE_CB_ID : + husart->TxHalfCpltCallback = HAL_USART_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + break; + + case HAL_USART_TX_COMPLETE_CB_ID : + husart->TxCpltCallback = HAL_USART_TxCpltCallback; /* Legacy weak TxCpltCallback */ + break; + + case HAL_USART_RX_HALFCOMPLETE_CB_ID : + husart->RxHalfCpltCallback = HAL_USART_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + break; + + case HAL_USART_RX_COMPLETE_CB_ID : + husart->RxCpltCallback = HAL_USART_RxCpltCallback; /* Legacy weak RxCpltCallback */ + break; + + case HAL_USART_TX_RX_COMPLETE_CB_ID : + husart->TxRxCpltCallback = HAL_USART_TxRxCpltCallback; /* Legacy weak TxRxCpltCallback */ + break; + + case HAL_USART_ERROR_CB_ID : + husart->ErrorCallback = HAL_USART_ErrorCallback; /* Legacy weak ErrorCallback */ + break; + + case HAL_USART_ABORT_COMPLETE_CB_ID : + husart->AbortCpltCallback = HAL_USART_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ + break; + + + case HAL_USART_MSPINIT_CB_ID : + husart->MspInitCallback = HAL_USART_MspInit; /* Legacy weak MspInitCallback */ + break; + + case HAL_USART_MSPDEINIT_CB_ID : + husart->MspDeInitCallback = HAL_USART_MspDeInit; /* Legacy weak MspDeInitCallback */ + break; + + default : + /* Update the error code */ + husart->ErrorCode |= HAL_USART_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else if (HAL_USART_STATE_RESET == husart->State) + { + switch (CallbackID) + { + case HAL_USART_MSPINIT_CB_ID : + husart->MspInitCallback = HAL_USART_MspInit; + break; + + case HAL_USART_MSPDEINIT_CB_ID : + husart->MspDeInitCallback = HAL_USART_MspDeInit; + break; + + default : + /* Update the error code */ + husart->ErrorCode |= HAL_USART_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + break; + } + } + else + { + /* Update the error code */ + husart->ErrorCode |= HAL_USART_ERROR_INVALID_CALLBACK; + + /* Return error status */ + status = HAL_ERROR; + } + + /* Release Lock */ + __HAL_UNLOCK(husart); + + return status; +} +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + + +/** + * @} + */ + +/** @defgroup USART_Exported_Functions_Group2 IO operation functions + * @brief USART Transmit and Receive functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + [..] This subsection provides a set of functions allowing to manage the USART synchronous + data transfers. + + [..] The USART supports master mode only: it cannot receive or send data related to an input + clock (SCLK is always an output). + + [..] + + (#) There are two modes of transfer: + (++) Blocking mode: The communication is performed in polling mode. + The HAL status of all data processing is returned by the same function + after finishing transfer. + (++) No-Blocking mode: The communication is performed using Interrupts + or DMA, These API's return the HAL status. + The end of the data processing will be indicated through the + dedicated USART IRQ when using Interrupt mode or the DMA IRQ when + using DMA mode. + The HAL_USART_TxCpltCallback(), HAL_USART_RxCpltCallback() and HAL_USART_TxRxCpltCallback() user callbacks + will be executed respectively at the end of the transmit or Receive process + The HAL_USART_ErrorCallback()user callback will be executed when a communication error is detected + + (#) Blocking mode API's are : + (++) HAL_USART_Transmit() in simplex mode + (++) HAL_USART_Receive() in full duplex receive only + (++) HAL_USART_TransmitReceive() in full duplex mode + + (#) Non-Blocking mode API's with Interrupt are : + (++) HAL_USART_Transmit_IT() in simplex mode + (++) HAL_USART_Receive_IT() in full duplex receive only + (++) HAL_USART_TransmitReceive_IT() in full duplex mode + (++) HAL_USART_IRQHandler() + + (#) No-Blocking mode API's with DMA are : + (++) HAL_USART_Transmit_DMA() in simplex mode + (++) HAL_USART_Receive_DMA() in full duplex receive only + (++) HAL_USART_TransmitReceive_DMA() in full duplex mode + (++) HAL_USART_DMAPause() + (++) HAL_USART_DMAResume() + (++) HAL_USART_DMAStop() + + (#) A set of Transfer Complete Callbacks are provided in Non_Blocking mode: + (++) HAL_USART_TxCpltCallback() + (++) HAL_USART_RxCpltCallback() + (++) HAL_USART_TxHalfCpltCallback() + (++) HAL_USART_RxHalfCpltCallback() + (++) HAL_USART_ErrorCallback() + (++) HAL_USART_TxRxCpltCallback() + + (#) Non-Blocking mode transfers could be aborted using Abort API's : + (++) HAL_USART_Abort() + (++) HAL_USART_Abort_IT() + + (#) For Abort services based on interrupts (HAL_USART_Abort_IT), a Abort Complete Callbacks is provided: + (++) HAL_USART_AbortCpltCallback() + + (#) In Non-Blocking mode transfers, possible errors are split into 2 categories. + Errors are handled as follows : + (++) Error is considered as Recoverable and non blocking : Transfer could go till end, but error severity is + to be evaluated by user : this concerns Frame Error, + Parity Error or Noise Error in Interrupt mode reception . + Received character is then retrieved and stored in Rx buffer, Error code is set to allow user to identify + error type, and HAL_USART_ErrorCallback() user callback is executed. + Transfer is kept ongoing on USART side. + If user wants to abort it, Abort services should be called by user. + (++) Error is considered as Blocking : Transfer could not be completed properly and is aborted. + This concerns Overrun Error In Interrupt mode reception and all errors in DMA mode. + Error code is set to allow user to identify error type, + and HAL_USART_ErrorCallback() user callback is executed. + +@endverbatim + * @{ + */ + +/** + * @brief Simplex send an amount of data in blocking mode. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must indicate the number + * of u16 provided through pTxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pTxData. + * @param husart USART handle. + * @param pTxData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be sent. + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Transmit(USART_HandleTypeDef *husart, uint8_t *pTxData, uint16_t Size, uint32_t Timeout) +{ + uint8_t *ptxdata8bits; + uint16_t *ptxdata16bits; + uint32_t tickstart; + + if (husart->State == HAL_USART_STATE_READY) + { + if ((pTxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pTxData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR will be + handled through a u16 cast. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if ((((uint32_t)pTxData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_TX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + husart->TxXferSize = Size; + husart->TxXferCount = Size; + + /* In case of 9bits/No Parity transfer, pTxData needs to be handled as a uint16_t pointer */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + ptxdata8bits = NULL; + ptxdata16bits = (uint16_t *) pTxData; + } + else + { + ptxdata8bits = pTxData; + ptxdata16bits = NULL; + } + + /* Check the remaining data to be sent */ + while (husart->TxXferCount > 0U) + { + if (USART_WaitOnFlagUntilTimeout(husart, USART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + if (ptxdata8bits == NULL) + { + husart->Instance->TDR = (uint16_t)(*ptxdata16bits & 0x01FFU); + ptxdata16bits++; + } + else + { + husart->Instance->TDR = (uint8_t)(*ptxdata8bits & 0xFFU); + ptxdata8bits++; + } + + husart->TxXferCount--; + } + + if (USART_WaitOnFlagUntilTimeout(husart, USART_FLAG_TC, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + + /* Clear Transmission Complete Flag */ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_TCF); + + /* Clear overrun flag and discard the received data */ + __HAL_USART_CLEAR_OREFLAG(husart); + __HAL_USART_SEND_REQ(husart, USART_RXDATA_FLUSH_REQUEST); +#if defined(USART_RQR_TXFRQ) + __HAL_USART_SEND_REQ(husart, USART_TXDATA_FLUSH_REQUEST); +#endif /* USART_RQR_TXFRQ */ + + /* At end of Tx process, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in blocking mode. + * @note To receive synchronous data, dummy data are simultaneously transmitted. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must indicate the number + * of u16 available through pRxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier (16 bits) + * (as received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pRxData. + * @param husart USART handle. + * @param pRxData Pointer to data buffer (u8 or u16 data elements). + * @param Size Amount of data elements (u8 or u16) to be received. + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Receive(USART_HandleTypeDef *husart, uint8_t *pRxData, uint16_t Size, uint32_t Timeout) +{ + uint8_t *prxdata8bits; + uint16_t *prxdata16bits; + uint16_t uhMask; + uint32_t tickstart; + + if (husart->State == HAL_USART_STATE_READY) + { + if ((pRxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pRxData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be received from RDR will be + handled through a u16 cast. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if ((((uint32_t)pRxData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_RX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + husart->RxXferSize = Size; + husart->RxXferCount = Size; + + /* Computation of USART mask to apply to RDR register */ + USART_MASK_COMPUTATION(husart); + uhMask = husart->Mask; + + /* In case of 9bits/No Parity transfer, pRxData needs to be handled as a uint16_t pointer */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + prxdata8bits = NULL; + prxdata16bits = (uint16_t *) pRxData; + } + else + { + prxdata8bits = pRxData; + prxdata16bits = NULL; + } + + /* as long as data have to be received */ + while (husart->RxXferCount > 0U) + { + { + /* Wait until TXE flag is set to send dummy byte in order to generate the + * clock for the slave to send data. + * Whatever the frame length (7, 8 or 9-bit long), the same dummy value + * can be written for all the cases. */ + if (USART_WaitOnFlagUntilTimeout(husart, USART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + husart->Instance->TDR = (USART_DUMMY_DATA & (uint16_t)0x0FF); + } + + /* Wait for RXNE Flag */ + if (USART_WaitOnFlagUntilTimeout(husart, USART_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + + if (prxdata8bits == NULL) + { + *prxdata16bits = (uint16_t)(husart->Instance->RDR & uhMask); + prxdata16bits++; + } + else + { + *prxdata8bits = (uint8_t)(husart->Instance->RDR & (uint8_t)(uhMask & 0xFFU)); + prxdata8bits++; + } + + husart->RxXferCount--; + + } + + + /* At end of Rx process, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Full-Duplex Send and Receive an amount of data in blocking mode. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data and the received data are handled as sets of u16. In this case, Size must indicate the number + * of u16 available through pTxData and through pRxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffers containing data to be sent/received, should be aligned on a half word frontier (16 bits) + * (as sent/received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pTxData and pRxData. + * @param husart USART handle. + * @param pTxData pointer to TX data buffer (u8 or u16 data elements). + * @param pRxData pointer to RX data buffer (u8 or u16 data elements). + * @param Size amount of data elements (u8 or u16) to be sent (same amount to be received). + * @param Timeout Timeout duration. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_TransmitReceive(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size, uint32_t Timeout) +{ + uint8_t *prxdata8bits; + uint16_t *prxdata16bits; + uint8_t *ptxdata8bits; + uint16_t *ptxdata16bits; + uint16_t uhMask; + uint16_t rxdatacount; + uint32_t tickstart; + + if (husart->State == HAL_USART_STATE_READY) + { + if ((pTxData == NULL) || (pRxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pTxData and pRxData buffers provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR/retrieved from RDR will be + handled through a u16 cast. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if (((((uint32_t)pTxData) & 1U) != 0U) || ((((uint32_t)pRxData) & 1U) != 0U)) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_RX; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + husart->RxXferSize = Size; + husart->TxXferSize = Size; + husart->TxXferCount = Size; + husart->RxXferCount = Size; + + /* Computation of USART mask to apply to RDR register */ + USART_MASK_COMPUTATION(husart); + uhMask = husart->Mask; + + /* In case of 9bits/No Parity transfer, pRxData needs to be handled as a uint16_t pointer */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + prxdata8bits = NULL; + ptxdata8bits = NULL; + ptxdata16bits = (uint16_t *) pTxData; + prxdata16bits = (uint16_t *) pRxData; + } + else + { + prxdata8bits = pRxData; + ptxdata8bits = pTxData; + ptxdata16bits = NULL; + prxdata16bits = NULL; + } + + if (husart->TxXferCount == 0x01U) + { + /* Wait until TXE flag is set to send data */ + if (USART_WaitOnFlagUntilTimeout(husart, USART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + if (ptxdata8bits == NULL) + { + husart->Instance->TDR = (uint16_t)(*ptxdata16bits & uhMask); + ptxdata16bits++; + } + else + { + husart->Instance->TDR = (uint8_t)(*ptxdata8bits & (uint8_t)(uhMask & 0xFFU)); + ptxdata8bits++; + } + + husart->TxXferCount--; + } + + /* Check the remain data to be sent */ + /* rxdatacount is a temporary variable for MISRAC2012-Rule-13.5 */ + rxdatacount = husart->RxXferCount; + while ((husart->TxXferCount > 0U) || (rxdatacount > 0U)) + { + if (husart->TxXferCount > 0U) + { + /* Wait until TXE flag is set to send data */ + if (USART_WaitOnFlagUntilTimeout(husart, USART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + if (ptxdata8bits == NULL) + { + husart->Instance->TDR = (uint16_t)(*ptxdata16bits & uhMask); + ptxdata16bits++; + } + else + { + husart->Instance->TDR = (uint8_t)(*ptxdata8bits & (uint8_t)(uhMask & 0xFFU)); + ptxdata8bits++; + } + + husart->TxXferCount--; + } + + if (husart->RxXferCount > 0U) + { + /* Wait for RXNE Flag */ + if (USART_WaitOnFlagUntilTimeout(husart, USART_FLAG_RXNE, RESET, tickstart, Timeout) != HAL_OK) + { + return HAL_TIMEOUT; + } + + if (prxdata8bits == NULL) + { + *prxdata16bits = (uint16_t)(husart->Instance->RDR & uhMask); + prxdata16bits++; + } + else + { + *prxdata8bits = (uint8_t)(husart->Instance->RDR & (uint8_t)(uhMask & 0xFFU)); + prxdata8bits++; + } + + husart->RxXferCount--; + } + rxdatacount = husart->RxXferCount; + } + + /* At end of TxRx process, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in interrupt mode. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must indicate the number + * of u16 provided through pTxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pTxData. + * @param husart USART handle. + * @param pTxData pointer to data buffer (u8 or u16 data elements). + * @param Size amount of data elements (u8 or u16) to be sent. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Transmit_IT(USART_HandleTypeDef *husart, uint8_t *pTxData, uint16_t Size) +{ + if (husart->State == HAL_USART_STATE_READY) + { + if ((pTxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pTxData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR will be + handled through a u16 cast. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if ((((uint32_t)pTxData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->pTxBuffPtr = pTxData; + husart->TxXferSize = Size; + husart->TxXferCount = Size; + husart->TxISR = NULL; + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_TX; + + /* The USART Error Interrupts: (Frame error, noise error, overrun error) + are not managed by the USART Transmit Process to avoid the overrun interrupt + when the usart mode is configured for transmit and receive "USART_MODE_TX_RX" + to benefit for the frame error and noise interrupts the usart mode should be + configured only for transmit "USART_MODE_TX" */ + + { + /* Set the Tx ISR function pointer according to the data word length */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + husart->TxISR = USART_TxISR_16BIT; + } + else + { + husart->TxISR = USART_TxISR_8BIT; + } + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Enable the USART Transmit Data Register Empty Interrupt */ + __HAL_USART_ENABLE_IT(husart, USART_IT_TXE); + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in interrupt mode. + * @note To receive synchronous data, dummy data are simultaneously transmitted. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must indicate the number + * of u16 available through pRxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on a half word frontier (16 bits) + * (as received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pRxData. + * @param husart USART handle. + * @param pRxData pointer to data buffer (u8 or u16 data elements). + * @param Size amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Receive_IT(USART_HandleTypeDef *husart, uint8_t *pRxData, uint16_t Size) +{ + + if (husart->State == HAL_USART_STATE_READY) + { + if ((pRxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pRxData buffer provided as input parameter + should be aligned on a u16 frontier, as data to be received from RDR will be + handled through a u16 cast. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if ((((uint32_t)pRxData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->pRxBuffPtr = pRxData; + husart->RxXferSize = Size; + husart->RxXferCount = Size; + husart->RxISR = NULL; + + USART_MASK_COMPUTATION(husart); + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_RX; + + /* Enable the USART Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(husart->Instance->CR3, USART_CR3_EIE); + + { + /* Set the Rx ISR function pointer according to the data word length */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + husart->RxISR = USART_RxISR_16BIT; + } + else + { + husart->RxISR = USART_RxISR_8BIT; + } + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Enable the USART Parity Error and Data Register not empty Interrupts */ + SET_BIT(husart->Instance->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE); + } + + { + /* Send dummy data in order to generate the clock for the Slave to send the next data. + */ + { + husart->Instance->TDR = (USART_DUMMY_DATA & (uint16_t)0x00FF); + } + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Full-Duplex Send and Receive an amount of data in interrupt mode. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data and the received data are handled as sets of u16. In this case, Size must indicate the number + * of u16 available through pTxData and through pRxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffers containing data to be sent/received, should be aligned on a half word frontier (16 bits) + * (as sent/received data will be handled using u16 pointer cast). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required to ensure proper alignment for pTxData and pRxData. + * @param husart USART handle. + * @param pTxData pointer to TX data buffer (u8 or u16 data elements). + * @param pRxData pointer to RX data buffer (u8 or u16 data elements). + * @param Size amount of data elements (u8 or u16) to be sent (same amount to be received). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_TransmitReceive_IT(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size) +{ + + if (husart->State == HAL_USART_STATE_READY) + { + if ((pTxData == NULL) || (pRxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pTxData and pRxData buffers provided as input parameter + should be aligned on a u16 frontier, as data to be filled into TDR/retrieved from RDR will be + handled through a u16 cast. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if (((((uint32_t)pTxData) & 1U) != 0U) || ((((uint32_t)pRxData) & 1U) != 0U)) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->pRxBuffPtr = pRxData; + husart->RxXferSize = Size; + husart->RxXferCount = Size; + husart->pTxBuffPtr = pTxData; + husart->TxXferSize = Size; + husart->TxXferCount = Size; + + /* Computation of USART mask to apply to RDR register */ + USART_MASK_COMPUTATION(husart); + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_TX_RX; + + { + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + husart->TxISR = USART_TxISR_16BIT; + husart->RxISR = USART_RxISR_16BIT; + } + else + { + husart->TxISR = USART_TxISR_8BIT; + husart->RxISR = USART_RxISR_8BIT; + } + + /* Process Locked */ + __HAL_UNLOCK(husart); + + /* Enable the USART Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Enable the USART Parity Error and USART Data Register not empty Interrupts */ + SET_BIT(husart->Instance->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE); + + /* Enable the USART Transmit Data Register Empty Interrupt */ + SET_BIT(husart->Instance->CR1, USART_CR1_TXEIE); + } + + return HAL_OK; + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Send an amount of data in DMA mode. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data is handled as a set of u16. In this case, Size must indicate the number + * of u16 provided through pTxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer containing data to be sent, should be aligned on a half word frontier (16 bits) + * (as sent data will be handled by DMA from halfword frontier). Depending on compilation chain, + * use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pTxData. + * @param husart USART handle. + * @param pTxData pointer to data buffer (u8 or u16 data elements). + * @param Size amount of data elements (u8 or u16) to be sent. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Transmit_DMA(USART_HandleTypeDef *husart, uint8_t *pTxData, uint16_t Size) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t *tmp; + + if (husart->State == HAL_USART_STATE_READY) + { + if ((pTxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pTxData buffer provided as input parameter + should be aligned on a u16 frontier, as data copy into TDR will be + handled by DMA from a u16 frontier. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if ((((uint32_t)pTxData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->pTxBuffPtr = pTxData; + husart->TxXferSize = Size; + husart->TxXferCount = Size; + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_TX; + + if (husart->hdmatx != NULL) + { + /* Set the USART DMA transfer complete callback */ + husart->hdmatx->XferCpltCallback = USART_DMATransmitCplt; + + /* Set the USART DMA Half transfer complete callback */ + husart->hdmatx->XferHalfCpltCallback = USART_DMATxHalfCplt; + + /* Set the DMA error callback */ + husart->hdmatx->XferErrorCallback = USART_DMAError; + + /* Enable the USART transmit DMA channel */ + tmp = (uint32_t *)&pTxData; + status = HAL_DMA_Start_IT(husart->hdmatx, *(uint32_t *)tmp, (uint32_t)&husart->Instance->TDR, Size); + } + + if (status == HAL_OK) + { + /* Clear the TC flag in the ICR register */ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_TCF); + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Enable the DMA transfer for transmit request by setting the DMAT bit + in the USART CR3 register */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAT); + + return HAL_OK; + } + else + { + /* Set error code to DMA */ + husart->ErrorCode = HAL_USART_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Restore husart->State to ready */ + husart->State = HAL_USART_STATE_READY; + + return HAL_ERROR; + } + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Receive an amount of data in DMA mode. + * @note When the USART parity is enabled (PCE = 1), the received data contain + * the parity bit (MSB position). + * @note The USART DMA transmit channel must be configured in order to generate the clock for the slave. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the received data is handled as a set of u16. In this case, Size must indicate the number + * of u16 available through pRxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffer for storing data to be received, should be aligned on + * a half word frontier (16 bits) (as received data will be handled by DMA from halfword frontier). + * Depending on compilation chain, use of specific alignment compilation directives or pragmas + * might be required to ensure proper alignment for pRxData. + * @param husart USART handle. + * @param pRxData pointer to data buffer (u8 or u16 data elements). + * @param Size amount of data elements (u8 or u16) to be received. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Receive_DMA(USART_HandleTypeDef *husart, uint8_t *pRxData, uint16_t Size) +{ + HAL_StatusTypeDef status = HAL_OK; + uint32_t *tmp = (uint32_t *)&pRxData; + + /* Check that a Rx process is not already ongoing */ + if (husart->State == HAL_USART_STATE_READY) + { + if ((pRxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pRxData buffer provided as input parameter + should be aligned on a u16 frontier, as data copy from RDR will be + handled by DMA from a u16 frontier. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if ((((uint32_t)pRxData) & 1U) != 0U) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->pRxBuffPtr = pRxData; + husart->RxXferSize = Size; + husart->pTxBuffPtr = pRxData; + husart->TxXferSize = Size; + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_RX; + + if (husart->hdmarx != NULL) + { + /* Set the USART DMA Rx transfer complete callback */ + husart->hdmarx->XferCpltCallback = USART_DMAReceiveCplt; + + /* Set the USART DMA Half transfer complete callback */ + husart->hdmarx->XferHalfCpltCallback = USART_DMARxHalfCplt; + + /* Set the USART DMA Rx transfer error callback */ + husart->hdmarx->XferErrorCallback = USART_DMAError; + + /* Enable the USART receive DMA channel */ + status = HAL_DMA_Start_IT(husart->hdmarx, (uint32_t)&husart->Instance->RDR, *(uint32_t *)tmp, Size); + } + + { + /* Enable the USART transmit DMA channel: the transmit channel is used in order + to generate in the non-blocking mode the clock to the slave device, + this mode isn't a simplex receive mode but a full-duplex receive mode */ + + /* Set the USART DMA Tx Complete and Error callback to Null */ + if (husart->hdmatx != NULL) + { + husart->hdmatx->XferErrorCallback = NULL; + husart->hdmatx->XferHalfCpltCallback = NULL; + husart->hdmatx->XferCpltCallback = NULL; + status = HAL_DMA_Start_IT(husart->hdmatx, *(uint32_t *)tmp, (uint32_t)&husart->Instance->TDR, Size); + } + } + + if (status == HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Enable the USART Parity Error Interrupt */ + SET_BIT(husart->Instance->CR1, USART_CR1_PEIE); + + /* Enable the USART Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Enable the DMA transfer for the receiver request by setting the DMAR bit + in the USART CR3 register */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAR); + + /* Enable the DMA transfer for transmit request by setting the DMAT bit + in the USART CR3 register */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAT); + + return HAL_OK; + } + else + { + if (husart->hdmarx != NULL) + { + status = HAL_DMA_Abort(husart->hdmarx); + } + + /* No need to check on error code */ + UNUSED(status); + + /* Set error code to DMA */ + husart->ErrorCode = HAL_USART_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Restore husart->State to ready */ + husart->State = HAL_USART_STATE_READY; + + return HAL_ERROR; + } + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Full-Duplex Transmit Receive an amount of data in non-blocking mode. + * @note When the USART parity is enabled (PCE = 1) the data received contain the parity bit. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * the sent data and the received data are handled as sets of u16. In this case, Size must indicate the number + * of u16 available through pTxData and through pRxData. + * @note When USART parity is not enabled (PCE = 0), and Word Length is configured to 9 bits (M1-M0 = 01), + * address of user data buffers containing data to be sent/received, should be aligned on a half word frontier + * (16 bits) (as sent/received data will be handled by DMA from halfword frontier). Depending on compilation + * chain, use of specific alignment compilation directives or pragmas might be required + * to ensure proper alignment for pTxData and pRxData. + * @param husart USART handle. + * @param pTxData pointer to TX data buffer (u8 or u16 data elements). + * @param pRxData pointer to RX data buffer (u8 or u16 data elements). + * @param Size amount of data elements (u8 or u16) to be received/sent. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_TransmitReceive_DMA(USART_HandleTypeDef *husart, uint8_t *pTxData, uint8_t *pRxData, + uint16_t Size) +{ + HAL_StatusTypeDef status; + uint32_t *tmp; + + if (husart->State == HAL_USART_STATE_READY) + { + if ((pTxData == NULL) || (pRxData == NULL) || (Size == 0U)) + { + return HAL_ERROR; + } + + /* In case of 9bits/No Parity transfer, pTxData and pRxData buffers provided as input parameter + should be aligned on a u16 frontier, as data copy to/from TDR/RDR will be + handled by DMA from a u16 frontier. */ + if ((husart->Init.WordLength == USART_WORDLENGTH_9B) && (husart->Init.Parity == USART_PARITY_NONE)) + { + if (((((uint32_t)pTxData) & 1U) != 0U) || ((((uint32_t)pRxData) & 1U) != 0U)) + { + return HAL_ERROR; + } + } + + /* Process Locked */ + __HAL_LOCK(husart); + + husart->pRxBuffPtr = pRxData; + husart->RxXferSize = Size; + husart->pTxBuffPtr = pTxData; + husart->TxXferSize = Size; + + husart->ErrorCode = HAL_USART_ERROR_NONE; + husart->State = HAL_USART_STATE_BUSY_TX_RX; + + if ((husart->hdmarx != NULL) && (husart->hdmatx != NULL)) + { + /* Set the USART DMA Rx transfer complete callback */ + husart->hdmarx->XferCpltCallback = USART_DMAReceiveCplt; + + /* Set the USART DMA Half transfer complete callback */ + husart->hdmarx->XferHalfCpltCallback = USART_DMARxHalfCplt; + + /* Set the USART DMA Tx transfer complete callback */ + husart->hdmatx->XferCpltCallback = USART_DMATransmitCplt; + + /* Set the USART DMA Half transfer complete callback */ + husart->hdmatx->XferHalfCpltCallback = USART_DMATxHalfCplt; + + /* Set the USART DMA Tx transfer error callback */ + husart->hdmatx->XferErrorCallback = USART_DMAError; + + /* Set the USART DMA Rx transfer error callback */ + husart->hdmarx->XferErrorCallback = USART_DMAError; + + /* Enable the USART receive DMA channel */ + tmp = (uint32_t *)&pRxData; + status = HAL_DMA_Start_IT(husart->hdmarx, (uint32_t)&husart->Instance->RDR, *(uint32_t *)tmp, Size); + + /* Enable the USART transmit DMA channel */ + if (status == HAL_OK) + { + tmp = (uint32_t *)&pTxData; + status = HAL_DMA_Start_IT(husart->hdmatx, *(uint32_t *)tmp, (uint32_t)&husart->Instance->TDR, Size); + } + } + else + { + status = HAL_ERROR; + } + + if (status == HAL_OK) + { + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Enable the USART Parity Error Interrupt */ + SET_BIT(husart->Instance->CR1, USART_CR1_PEIE); + + /* Enable the USART Error Interrupt: (Frame error, noise error, overrun error) */ + SET_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Clear the TC flag in the ICR register */ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_TCF); + + /* Enable the DMA transfer for the receiver request by setting the DMAR bit + in the USART CR3 register */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAR); + + /* Enable the DMA transfer for transmit request by setting the DMAT bit + in the USART CR3 register */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAT); + + return HAL_OK; + } + else + { + if (husart->hdmarx != NULL) + { + status = HAL_DMA_Abort(husart->hdmarx); + } + + /* No need to check on error code */ + UNUSED(status); + + /* Set error code to DMA */ + husart->ErrorCode = HAL_USART_ERROR_DMA; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + /* Restore husart->State to ready */ + husart->State = HAL_USART_STATE_READY; + + return HAL_ERROR; + } + } + else + { + return HAL_BUSY; + } +} + +/** + * @brief Pause the DMA Transfer. + * @param husart USART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_DMAPause(USART_HandleTypeDef *husart) +{ + const HAL_USART_StateTypeDef state = husart->State; + + /* Process Locked */ + __HAL_LOCK(husart); + + if ((HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAT)) && + (state == HAL_USART_STATE_BUSY_TX)) + { + /* Disable the USART DMA Tx request */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAT); + } + else if ((state == HAL_USART_STATE_BUSY_RX) || + (state == HAL_USART_STATE_BUSY_TX_RX)) + { + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAT)) + { + /* Disable the USART DMA Tx request */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAT); + } + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAR)) + { + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(husart->Instance->CR1, USART_CR1_PEIE); + CLEAR_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Disable the USART DMA Rx request */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAR); + } + } + else + { + /* Nothing to do */ + } + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + return HAL_OK; +} + +/** + * @brief Resume the DMA Transfer. + * @param husart USART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_DMAResume(USART_HandleTypeDef *husart) +{ + const HAL_USART_StateTypeDef state = husart->State; + + /* Process Locked */ + __HAL_LOCK(husart); + + if (state == HAL_USART_STATE_BUSY_TX) + { + /* Enable the USART DMA Tx request */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAT); + } + else if ((state == HAL_USART_STATE_BUSY_RX) || + (state == HAL_USART_STATE_BUSY_TX_RX)) + { + /* Clear the Overrun flag before resuming the Rx transfer*/ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_OREF); + + /* Re-enable PE and ERR (Frame error, noise error, overrun error) interrupts */ + SET_BIT(husart->Instance->CR1, USART_CR1_PEIE); + SET_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Enable the USART DMA Rx request before the DMA Tx request */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAR); + + /* Enable the USART DMA Tx request */ + SET_BIT(husart->Instance->CR3, USART_CR3_DMAT); + } + else + { + /* Nothing to do */ + } + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + return HAL_OK; +} + +/** + * @brief Stop the DMA Transfer. + * @param husart USART handle. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_DMAStop(USART_HandleTypeDef *husart) +{ + /* The Lock is not implemented on this API to allow the user application + to call the HAL USART API under callbacks HAL_USART_TxCpltCallback() / HAL_USART_RxCpltCallback() / + HAL_USART_TxHalfCpltCallback / HAL_USART_RxHalfCpltCallback: + indeed, when HAL_DMA_Abort() API is called, the DMA TX/RX Transfer or Half Transfer complete + interrupt is generated if the DMA transfer interruption occurs at the middle or at the end of + the stream and the corresponding call back is executed. */ + + /* Disable the USART Tx/Rx DMA requests */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAT); + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the USART DMA tx channel */ + if (husart->hdmatx != NULL) + { + if (HAL_DMA_Abort(husart->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(husart->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + husart->ErrorCode = HAL_USART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + /* Abort the USART DMA rx channel */ + if (husart->hdmarx != NULL) + { + if (HAL_DMA_Abort(husart->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(husart->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + husart->ErrorCode = HAL_USART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + + USART_EndTransfer(husart); + husart->State = HAL_USART_STATE_READY; + + return HAL_OK; +} + +/** + * @brief Abort ongoing transfers (blocking mode). + * @param husart USART handle. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable USART Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort (in case of transfer in DMA mode) + * - Set handle State to READY + * @note This procedure is executed in blocking mode : when exiting function, Abort is considered as completed. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Abort(USART_HandleTypeDef *husart) +{ + CLEAR_BIT(husart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE)); + CLEAR_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Disable the USART DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAT)) + { + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAT); + + /* Abort the USART DMA Tx channel : use blocking DMA Abort API (no callback) */ + if (husart->hdmatx != NULL) + { + /* Set the USART DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + husart->hdmatx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(husart->hdmatx) != HAL_OK) + { + if (HAL_DMA_GetError(husart->hdmatx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + husart->ErrorCode = HAL_USART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Disable the USART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the USART DMA Rx channel : use blocking DMA Abort API (no callback) */ + if (husart->hdmarx != NULL) + { + /* Set the USART DMA Abort callback to Null. + No call back execution at end of DMA abort procedure */ + husart->hdmarx->XferAbortCallback = NULL; + + if (HAL_DMA_Abort(husart->hdmarx) != HAL_OK) + { + if (HAL_DMA_GetError(husart->hdmarx) == HAL_DMA_ERROR_TIMEOUT) + { + /* Set error code to DMA */ + husart->ErrorCode = HAL_USART_ERROR_DMA; + + return HAL_TIMEOUT; + } + } + } + } + + /* Reset Tx and Rx transfer counters */ + husart->TxXferCount = 0U; + husart->RxXferCount = 0U; + + /* Clear the Error flags in the ICR register */ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_OREF | USART_CLEAR_NEF | USART_CLEAR_PEF | USART_CLEAR_FEF); + + + /* Discard the received data */ + __HAL_USART_SEND_REQ(husart, USART_RXDATA_FLUSH_REQUEST); + + /* Restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + + /* Reset Handle ErrorCode to No Error */ + husart->ErrorCode = HAL_USART_ERROR_NONE; + + return HAL_OK; +} + +/** + * @brief Abort ongoing transfers (Interrupt mode). + * @param husart USART handle. + * @note This procedure could be used for aborting any ongoing transfer started in Interrupt or DMA mode. + * This procedure performs following operations : + * - Disable USART Interrupts (Tx and Rx) + * - Disable the DMA transfer in the peripheral register (if enabled) + * - Abort DMA transfer by calling HAL_DMA_Abort_IT (in case of transfer in DMA mode) + * - Set handle State to READY + * - At abort completion, call user abort complete callback + * @note This procedure is executed in Interrupt mode, meaning that abort procedure could be + * considered as completed only when user abort complete callback is executed (not when exiting function). + * @retval HAL status + */ +HAL_StatusTypeDef HAL_USART_Abort_IT(USART_HandleTypeDef *husart) +{ + uint32_t abortcplt = 1U; + + CLEAR_BIT(husart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE)); + CLEAR_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* If DMA Tx and/or DMA Rx Handles are associated to USART Handle, DMA Abort complete callbacks should be initialised + before any call to DMA Abort functions */ + /* DMA Tx Handle is valid */ + if (husart->hdmatx != NULL) + { + /* Set DMA Abort Complete callback if USART DMA Tx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAT)) + { + husart->hdmatx->XferAbortCallback = USART_DMATxAbortCallback; + } + else + { + husart->hdmatx->XferAbortCallback = NULL; + } + } + /* DMA Rx Handle is valid */ + if (husart->hdmarx != NULL) + { + /* Set DMA Abort Complete callback if USART DMA Rx request if enabled. + Otherwise, set it to NULL */ + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAR)) + { + husart->hdmarx->XferAbortCallback = USART_DMARxAbortCallback; + } + else + { + husart->hdmarx->XferAbortCallback = NULL; + } + } + + /* Disable the USART DMA Tx request if enabled */ + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAT)) + { + /* Disable DMA Tx at USART level */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAT); + + /* Abort the USART DMA Tx channel : use non blocking DMA Abort API (callback) */ + if (husart->hdmatx != NULL) + { + /* USART Tx DMA Abort callback has already been initialised : + will lead to call HAL_USART_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA TX */ + if (HAL_DMA_Abort_IT(husart->hdmatx) != HAL_OK) + { + husart->hdmatx->XferAbortCallback = NULL; + } + else + { + abortcplt = 0U; + } + } + } + + /* Disable the USART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAR); + + /* Abort the USART DMA Rx channel : use non blocking DMA Abort API (callback) */ + if (husart->hdmarx != NULL) + { + /* USART Rx DMA Abort callback has already been initialised : + will lead to call HAL_USART_AbortCpltCallback() at end of DMA abort procedure */ + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(husart->hdmarx) != HAL_OK) + { + husart->hdmarx->XferAbortCallback = NULL; + abortcplt = 1U; + } + else + { + abortcplt = 0U; + } + } + } + + /* if no DMA abort complete callback execution is required => call user Abort Complete callback */ + if (abortcplt == 1U) + { + /* Reset Tx and Rx transfer counters */ + husart->TxXferCount = 0U; + husart->RxXferCount = 0U; + + /* Reset errorCode */ + husart->ErrorCode = HAL_USART_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_OREF | USART_CLEAR_NEF | USART_CLEAR_PEF | USART_CLEAR_FEF); + + + /* Discard the received data */ + __HAL_USART_SEND_REQ(husart, USART_RXDATA_FLUSH_REQUEST); + + /* Restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + + /* As no DMA to be aborted, call directly user Abort complete callback */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Complete Callback */ + husart->AbortCpltCallback(husart); +#else + /* Call legacy weak Abort Complete Callback */ + HAL_USART_AbortCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + + return HAL_OK; +} + +/** + * @brief Handle USART interrupt request. + * @param husart USART handle. + * @retval None + */ +void HAL_USART_IRQHandler(USART_HandleTypeDef *husart) +{ + uint32_t isrflags = READ_REG(husart->Instance->ISR); + uint32_t cr1its = READ_REG(husart->Instance->CR1); + uint32_t cr3its = READ_REG(husart->Instance->CR3); + + uint32_t errorflags; + uint32_t errorcode; + + /* If no error occurs */ + errorflags = (isrflags & (uint32_t)(USART_ISR_PE | USART_ISR_FE | USART_ISR_ORE | USART_ISR_NE | USART_ISR_RTOF)); + if (errorflags == 0U) + { + /* USART in mode Receiver ---------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) + && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + if (husart->RxISR != NULL) + { + husart->RxISR(husart); + } + return; + } + } + + /* If some errors occur */ + if ((errorflags != 0U) + && (((cr3its & USART_CR3_EIE) != 0U) + || ((cr1its & (USART_CR1_RXNEIE | USART_CR1_PEIE)) != 0U))) + { + /* USART parity error interrupt occurred -------------------------------------*/ + if (((isrflags & USART_ISR_PE) != 0U) && ((cr1its & USART_CR1_PEIE) != 0U)) + { + __HAL_USART_CLEAR_IT(husart, USART_CLEAR_PEF); + + husart->ErrorCode |= HAL_USART_ERROR_PE; + } + + /* USART frame error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_FE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_USART_CLEAR_IT(husart, USART_CLEAR_FEF); + + husart->ErrorCode |= HAL_USART_ERROR_FE; + } + + /* USART noise error interrupt occurred --------------------------------------*/ + if (((isrflags & USART_ISR_NE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U)) + { + __HAL_USART_CLEAR_IT(husart, USART_CLEAR_NEF); + + husart->ErrorCode |= HAL_USART_ERROR_NE; + } + + /* USART Over-Run interrupt occurred -----------------------------------------*/ + if (((isrflags & USART_ISR_ORE) != 0U) + && (((cr1its & USART_CR1_RXNEIE) != 0U) || + ((cr3its & USART_CR3_EIE) != 0U))) + { + __HAL_USART_CLEAR_IT(husart, USART_CLEAR_OREF); + + husart->ErrorCode |= HAL_USART_ERROR_ORE; + } + + /* USART Receiver Timeout interrupt occurred ---------------------------------*/ + if (((isrflags & USART_ISR_RTOF) != 0U) && ((cr1its & USART_CR1_RTOIE) != 0U)) + { + __HAL_USART_CLEAR_IT(husart, USART_CLEAR_RTOF); + + husart->ErrorCode |= HAL_USART_ERROR_RTO; + } + + + /* Call USART Error Call back function if need be --------------------------*/ + if (husart->ErrorCode != HAL_USART_ERROR_NONE) + { + /* USART in mode Receiver ---------------------------------------------------*/ + if (((isrflags & USART_ISR_RXNE) != 0U) + && ((cr1its & USART_CR1_RXNEIE) != 0U)) + { + if (husart->RxISR != NULL) + { + husart->RxISR(husart); + } + } + + /* If Overrun error occurs, or if any error occurs in DMA mode reception, + consider error as blocking */ + errorcode = husart->ErrorCode & HAL_USART_ERROR_ORE; + if ((HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAR)) || + (errorcode != 0U)) + { + /* Blocking error : transfer is aborted + Set the USART state ready to be able to start again the process, + Disable Interrupts, and disable DMA requests, if ongoing */ + USART_EndTransfer(husart); + + /* Disable the USART DMA Rx request if enabled */ + if (HAL_IS_BIT_SET(husart->Instance->CR3, USART_CR3_DMAR)) + { + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAR | USART_CR3_DMAR); + + /* Abort the USART DMA Tx channel */ + if (husart->hdmatx != NULL) + { + /* Set the USART Tx DMA Abort callback to NULL : no callback + executed at end of DMA abort procedure */ + husart->hdmatx->XferAbortCallback = NULL; + + /* Abort DMA TX */ + (void)HAL_DMA_Abort_IT(husart->hdmatx); + } + + /* Abort the USART DMA Rx channel */ + if (husart->hdmarx != NULL) + { + /* Set the USART Rx DMA Abort callback : + will lead to call HAL_USART_ErrorCallback() at end of DMA abort procedure */ + husart->hdmarx->XferAbortCallback = USART_DMAAbortOnError; + + /* Abort DMA RX */ + if (HAL_DMA_Abort_IT(husart->hdmarx) != HAL_OK) + { + /* Call Directly husart->hdmarx->XferAbortCallback function in case of error */ + husart->hdmarx->XferAbortCallback(husart->hdmarx); + } + } + else + { + /* Call user error callback */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Error Callback */ + husart->ErrorCallback(husart); +#else + /* Call legacy weak Error Callback */ + HAL_USART_ErrorCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + } + else + { + /* Call user error callback */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Error Callback */ + husart->ErrorCallback(husart); +#else + /* Call legacy weak Error Callback */ + HAL_USART_ErrorCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + } + else + { + /* Non Blocking error : transfer could go on. + Error is notified to user through user error callback */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Error Callback */ + husart->ErrorCallback(husart); +#else + /* Call legacy weak Error Callback */ + HAL_USART_ErrorCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + husart->ErrorCode = HAL_USART_ERROR_NONE; + } + } + return; + + } /* End if some error occurs */ + + + /* USART in mode Transmitter ------------------------------------------------*/ + if (((isrflags & USART_ISR_TXE) != 0U) + && ((cr1its & USART_CR1_TXEIE) != 0U)) + { + if (husart->TxISR != NULL) + { + husart->TxISR(husart); + } + return; + } + + /* USART in mode Transmitter (transmission end) -----------------------------*/ + if (((isrflags & USART_ISR_TC) != 0U) && ((cr1its & USART_CR1_TCIE) != 0U)) + { + USART_EndTransmit_IT(husart); + return; + } + +} + +/** + * @brief Tx Transfer completed callback. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_TxCpltCallback(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_USART_TxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Tx Half Transfer completed callback. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_TxHalfCpltCallback(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_USART_TxHalfCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Rx Transfer completed callback. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_RxCpltCallback(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_USART_RxCpltCallback can be implemented in the user file. + */ +} + +/** + * @brief Rx Half Transfer completed callback. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_RxHalfCpltCallback(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_USART_RxHalfCpltCallback can be implemented in the user file + */ +} + +/** + * @brief Tx/Rx Transfers completed callback for the non-blocking process. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_TxRxCpltCallback(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_USART_TxRxCpltCallback can be implemented in the user file + */ +} + +/** + * @brief USART error callback. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_ErrorCallback(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_USART_ErrorCallback can be implemented in the user file. + */ +} + +/** + * @brief USART Abort Complete callback. + * @param husart USART handle. + * @retval None + */ +__weak void HAL_USART_AbortCpltCallback(USART_HandleTypeDef *husart) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(husart); + + /* NOTE : This function should not be modified, when the callback is needed, + the HAL_USART_AbortCpltCallback can be implemented in the user file. + */ +} + +/** + * @} + */ + +/** @defgroup USART_Exported_Functions_Group4 Peripheral State and Error functions + * @brief USART Peripheral State and Error functions + * +@verbatim + ============================================================================== + ##### Peripheral State and Error functions ##### + ============================================================================== + [..] + This subsection provides functions allowing to : + (+) Return the USART handle state + (+) Return the USART handle error code + +@endverbatim + * @{ + */ + + +/** + * @brief Return the USART handle state. + * @param husart pointer to a USART_HandleTypeDef structure that contains + * the configuration information for the specified USART. + * @retval USART handle state + */ +HAL_USART_StateTypeDef HAL_USART_GetState(USART_HandleTypeDef *husart) +{ + return husart->State; +} + +/** + * @brief Return the USART error code. + * @param husart pointer to a USART_HandleTypeDef structure that contains + * the configuration information for the specified USART. + * @retval USART handle Error Code + */ +uint32_t HAL_USART_GetError(USART_HandleTypeDef *husart) +{ + return husart->ErrorCode; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup USART_Private_Functions USART Private Functions + * @{ + */ + +/** + * @brief Initialize the callbacks to their default values. + * @param husart USART handle. + * @retval none + */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) +void USART_InitCallbacksToDefault(USART_HandleTypeDef *husart) +{ + /* Init the USART Callback settings */ + husart->TxHalfCpltCallback = HAL_USART_TxHalfCpltCallback; /* Legacy weak TxHalfCpltCallback */ + husart->TxCpltCallback = HAL_USART_TxCpltCallback; /* Legacy weak TxCpltCallback */ + husart->RxHalfCpltCallback = HAL_USART_RxHalfCpltCallback; /* Legacy weak RxHalfCpltCallback */ + husart->RxCpltCallback = HAL_USART_RxCpltCallback; /* Legacy weak RxCpltCallback */ + husart->TxRxCpltCallback = HAL_USART_TxRxCpltCallback; /* Legacy weak TxRxCpltCallback */ + husart->ErrorCallback = HAL_USART_ErrorCallback; /* Legacy weak ErrorCallback */ + husart->AbortCpltCallback = HAL_USART_AbortCpltCallback; /* Legacy weak AbortCpltCallback */ +} +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + +/** + * @brief End ongoing transfer on USART peripheral (following error detection or Transfer completion). + * @param husart USART handle. + * @retval None + */ +static void USART_EndTransfer(USART_HandleTypeDef *husart) +{ + /* Disable TXEIE, TCIE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(husart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE | USART_CR1_TCIE)); + CLEAR_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* At end of process, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; +} + +/** + * @brief DMA USART transmit process complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMATransmitCplt(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + + /* DMA Normal mode */ + if (HAL_IS_BIT_CLR(hdma->Instance->CCR, DMA_CCR_CIRC)) + { + husart->TxXferCount = 0U; + + if (husart->State == HAL_USART_STATE_BUSY_TX) + { + /* Disable the DMA transfer for transmit request by resetting the DMAT bit + in the USART CR3 register */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAT); + + /* Enable the USART Transmit Complete Interrupt */ + __HAL_USART_ENABLE_IT(husart, USART_IT_TC); + } + } + /* DMA Circular mode */ + else + { + if (husart->State == HAL_USART_STATE_BUSY_TX) + { +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Complete Callback */ + husart->TxCpltCallback(husart); +#else + /* Call legacy weak Tx Complete Callback */ + HAL_USART_TxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + } +} + +/** + * @brief DMA USART transmit process half complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMATxHalfCplt(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Half Complete Callback */ + husart->TxHalfCpltCallback(husart); +#else + /* Call legacy weak Tx Half Complete Callback */ + HAL_USART_TxHalfCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA USART receive process complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMAReceiveCplt(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + + /* DMA Normal mode */ + if (HAL_IS_BIT_CLR(hdma->Instance->CCR, DMA_CCR_CIRC)) + { + husart->RxXferCount = 0U; + + /* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */ + CLEAR_BIT(husart->Instance->CR1, USART_CR1_PEIE); + CLEAR_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Disable the DMA RX transfer for the receiver request by resetting the DMAR bit + in USART CR3 register */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAR); + /* similarly, disable the DMA TX transfer that was started to provide the + clock to the slave device */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_DMAT); + + if (husart->State == HAL_USART_STATE_BUSY_RX) + { +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Rx Complete Callback */ + husart->RxCpltCallback(husart); +#else + /* Call legacy weak Rx Complete Callback */ + HAL_USART_RxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + /* The USART state is HAL_USART_STATE_BUSY_TX_RX */ + else + { +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Rx Complete Callback */ + husart->TxRxCpltCallback(husart); +#else + /* Call legacy weak Tx Rx Complete Callback */ + HAL_USART_TxRxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + husart->State = HAL_USART_STATE_READY; + } + /* DMA circular mode */ + else + { + if (husart->State == HAL_USART_STATE_BUSY_RX) + { +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Rx Complete Callback */ + husart->RxCpltCallback(husart); +#else + /* Call legacy weak Rx Complete Callback */ + HAL_USART_RxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + /* The USART state is HAL_USART_STATE_BUSY_TX_RX */ + else + { +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Rx Complete Callback */ + husart->TxRxCpltCallback(husart); +#else + /* Call legacy weak Tx Rx Complete Callback */ + HAL_USART_TxRxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + } +} + +/** + * @brief DMA USART receive process half complete callback. + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMARxHalfCplt(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Rx Half Complete Callback */ + husart->RxHalfCpltCallback(husart); +#else + /* Call legacy weak Rx Half Complete Callback */ + HAL_USART_RxHalfCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA USART communication error callback. + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMAError(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + + husart->RxXferCount = 0U; + husart->TxXferCount = 0U; + USART_EndTransfer(husart); + + husart->ErrorCode |= HAL_USART_ERROR_DMA; + husart->State = HAL_USART_STATE_READY; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Error Callback */ + husart->ErrorCallback(husart); +#else + /* Call legacy weak Error Callback */ + HAL_USART_ErrorCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA USART communication abort callback, when initiated by HAL services on Error + * (To be called at end of DMA Abort procedure following error occurrence). + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMAAbortOnError(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + husart->RxXferCount = 0U; + husart->TxXferCount = 0U; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Error Callback */ + husart->ErrorCallback(husart); +#else + /* Call legacy weak Error Callback */ + HAL_USART_ErrorCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ +} + +/** + * @brief DMA USART Tx communication abort callback, when initiated by user + * (To be called at end of DMA Tx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Rx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMATxAbortCallback(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + + husart->hdmatx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (husart->hdmarx != NULL) + { + if (husart->hdmarx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + husart->TxXferCount = 0U; + husart->RxXferCount = 0U; + + /* Reset errorCode */ + husart->ErrorCode = HAL_USART_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_OREF | USART_CLEAR_NEF | USART_CLEAR_PEF | USART_CLEAR_FEF); + + /* Restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Complete Callback */ + husart->AbortCpltCallback(husart); +#else + /* Call legacy weak Abort Complete Callback */ + HAL_USART_AbortCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + +} + + +/** + * @brief DMA USART Rx communication abort callback, when initiated by user + * (To be called at end of DMA Rx Abort procedure following user abort request). + * @note When this callback is executed, User Abort complete call back is called only if no + * Abort still ongoing for Tx DMA Handle. + * @param hdma DMA handle. + * @retval None + */ +static void USART_DMARxAbortCallback(DMA_HandleTypeDef *hdma) +{ + USART_HandleTypeDef *husart = (USART_HandleTypeDef *)(hdma->Parent); + + husart->hdmarx->XferAbortCallback = NULL; + + /* Check if an Abort process is still ongoing */ + if (husart->hdmatx != NULL) + { + if (husart->hdmatx->XferAbortCallback != NULL) + { + return; + } + } + + /* No Abort process still ongoing : All DMA channels are aborted, call user Abort Complete callback */ + husart->TxXferCount = 0U; + husart->RxXferCount = 0U; + + /* Reset errorCode */ + husart->ErrorCode = HAL_USART_ERROR_NONE; + + /* Clear the Error flags in the ICR register */ + __HAL_USART_CLEAR_FLAG(husart, USART_CLEAR_OREF | USART_CLEAR_NEF | USART_CLEAR_PEF | USART_CLEAR_FEF); + + /* Restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + + /* Call user Abort complete callback */ +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Abort Complete Callback */ + husart->AbortCpltCallback(husart); +#else + /* Call legacy weak Abort Complete Callback */ + HAL_USART_AbortCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ +} + + +/** + * @brief Handle USART Communication Timeout. + * @param husart USART handle. + * @param Flag Specifies the USART flag to check. + * @param Status the Flag status (SET or RESET). + * @param Tickstart Tick start value + * @param Timeout timeout duration. + * @retval HAL status + */ +static HAL_StatusTypeDef USART_WaitOnFlagUntilTimeout(USART_HandleTypeDef *husart, uint32_t Flag, FlagStatus Status, + uint32_t Tickstart, uint32_t Timeout) +{ + /* Wait until flag is set */ + while ((__HAL_USART_GET_FLAG(husart, Flag) ? SET : RESET) == Status) + { + /* Check for the Timeout */ + if (Timeout != HAL_MAX_DELAY) + { + if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U)) + { + husart->State = HAL_USART_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + return HAL_TIMEOUT; + } + } + } + return HAL_OK; +} + +/** + * @brief Configure the USART peripheral. + * @param husart USART handle. + * @retval HAL status + */ +static HAL_StatusTypeDef USART_SetConfig(USART_HandleTypeDef *husart) +{ + uint32_t tmpreg; + USART_ClockSourceTypeDef clocksource; + HAL_StatusTypeDef ret = HAL_OK; + uint16_t brrtemp; + uint32_t usartdiv = 0x00000000; + uint32_t pclk; + + /* Check the parameters */ + assert_param(IS_USART_POLARITY(husart->Init.CLKPolarity)); + assert_param(IS_USART_PHASE(husart->Init.CLKPhase)); + assert_param(IS_USART_LASTBIT(husart->Init.CLKLastBit)); + assert_param(IS_USART_BAUDRATE(husart->Init.BaudRate)); + assert_param(IS_USART_WORD_LENGTH(husart->Init.WordLength)); + assert_param(IS_USART_STOPBITS(husart->Init.StopBits)); + assert_param(IS_USART_PARITY(husart->Init.Parity)); + assert_param(IS_USART_MODE(husart->Init.Mode)); + + /*-------------------------- USART CR1 Configuration -----------------------*/ + /* Clear M, PCE, PS, TE and RE bits and configure + * the USART Word Length, Parity and Mode: + * set the M bits according to husart->Init.WordLength value + * set PCE and PS bits according to husart->Init.Parity value + * set TE and RE bits according to husart->Init.Mode value + * force OVER8 to 1 to allow to reach the maximum speed (Fclock/8) */ + tmpreg = (uint32_t)husart->Init.WordLength | husart->Init.Parity | husart->Init.Mode | USART_CR1_OVER8; + MODIFY_REG(husart->Instance->CR1, USART_CR1_FIELDS, tmpreg); + + /*---------------------------- USART CR2 Configuration ---------------------*/ + /* Clear and configure the USART Clock, CPOL, CPHA, LBCL and STOP bits: + * set CPOL bit according to husart->Init.CLKPolarity value + * set CPHA bit according to husart->Init.CLKPhase value + * set LBCL bit according to husart->Init.CLKLastBit value (used in SPI master mode only) + * set STOP[13:12] bits according to husart->Init.StopBits value */ + tmpreg = (uint32_t)(USART_CLOCK_ENABLE); + tmpreg |= (uint32_t)husart->Init.CLKLastBit; + tmpreg |= ((uint32_t)husart->Init.CLKPolarity | (uint32_t)husart->Init.CLKPhase); + tmpreg |= (uint32_t)husart->Init.StopBits; + MODIFY_REG(husart->Instance->CR2, USART_CR2_FIELDS, tmpreg); + + + /*-------------------------- USART BRR Configuration -----------------------*/ + /* BRR is filled-up according to OVER8 bit setting which is forced to 1 */ + USART_GETCLOCKSOURCE(husart, clocksource); + + switch (clocksource) + { + case USART_CLOCKSOURCE_PCLK1: + pclk = HAL_RCC_GetPCLK1Freq(); + usartdiv = (uint32_t)(USART_DIV_SAMPLING8(pclk, husart->Init.BaudRate)); + break; + case USART_CLOCKSOURCE_HSI: + usartdiv = (uint32_t)(USART_DIV_SAMPLING8(HSI_VALUE, husart->Init.BaudRate)); + break; + case USART_CLOCKSOURCE_SYSCLK: + pclk = HAL_RCC_GetSysClockFreq(); + usartdiv = (uint32_t)(USART_DIV_SAMPLING8(pclk, husart->Init.BaudRate)); + break; + case USART_CLOCKSOURCE_LSE: + usartdiv = (uint32_t)(USART_DIV_SAMPLING8(LSE_VALUE, husart->Init.BaudRate)); + break; + default: + ret = HAL_ERROR; + break; + } + + /* USARTDIV must be greater than or equal to 0d16 and smaller than or equal to ffff */ + if ((usartdiv >= USART_BRR_MIN) && (usartdiv <= USART_BRR_MAX)) + { + brrtemp = (uint16_t)(usartdiv & 0xFFF0U); + brrtemp |= (uint16_t)((usartdiv & (uint16_t)0x000FU) >> 1U); + husart->Instance->BRR = brrtemp; + } + else + { + ret = HAL_ERROR; + } + + + /* Clear ISR function pointers */ + husart->RxISR = NULL; + husart->TxISR = NULL; + + return ret; +} + +/** + * @brief Check the USART Idle State. + * @param husart USART handle. + * @retval HAL status + */ +static HAL_StatusTypeDef USART_CheckIdleState(USART_HandleTypeDef *husart) +{ + uint32_t tickstart; + + /* Initialize the USART ErrorCode */ + husart->ErrorCode = HAL_USART_ERROR_NONE; + + /* Init tickstart for timeout management */ + tickstart = HAL_GetTick(); + + /* Check if the Transmitter is enabled */ + if ((husart->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE) + { + /* Wait until TEACK flag is set */ + if (USART_WaitOnFlagUntilTimeout(husart, USART_ISR_TEACK, RESET, tickstart, USART_TEACK_REACK_TIMEOUT) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + /* Check if the Receiver is enabled */ + if ((husart->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE) + { + /* Wait until REACK flag is set */ + if (USART_WaitOnFlagUntilTimeout(husart, USART_ISR_REACK, RESET, tickstart, USART_TEACK_REACK_TIMEOUT) != HAL_OK) + { + /* Timeout occurred */ + return HAL_TIMEOUT; + } + } + + /* Initialize the USART state*/ + husart->State = HAL_USART_STATE_READY; + + /* Process Unlocked */ + __HAL_UNLOCK(husart); + + return HAL_OK; +} + +/** + * @brief Simplex send an amount of data in non-blocking mode. + * @note Function called under interruption only, once + * interruptions have been enabled by HAL_USART_Transmit_IT(). + * @note The USART errors are not managed to avoid the overrun error. + * @note ISR function executed when data word length is less than 9 bits long. + * @param husart USART handle. + * @retval None + */ +static void USART_TxISR_8BIT(USART_HandleTypeDef *husart) +{ + const HAL_USART_StateTypeDef state = husart->State; + + /* Check that a Tx process is ongoing */ + if ((state == HAL_USART_STATE_BUSY_TX) || + (state == HAL_USART_STATE_BUSY_TX_RX)) + { + if (husart->TxXferCount == 0U) + { + /* Disable the USART Transmit data register empty interrupt */ + __HAL_USART_DISABLE_IT(husart, USART_IT_TXE); + + /* Enable the USART Transmit Complete Interrupt */ + __HAL_USART_ENABLE_IT(husart, USART_IT_TC); + } + else + { + husart->Instance->TDR = (uint8_t)(*husart->pTxBuffPtr & (uint8_t)0xFF); + husart->pTxBuffPtr++; + husart->TxXferCount--; + } + } +} + +/** + * @brief Simplex send an amount of data in non-blocking mode. + * @note Function called under interruption only, once + * interruptions have been enabled by HAL_USART_Transmit_IT(). + * @note The USART errors are not managed to avoid the overrun error. + * @note ISR function executed when data word length is 9 bits long. + * @param husart USART handle. + * @retval None + */ +static void USART_TxISR_16BIT(USART_HandleTypeDef *husart) +{ + const HAL_USART_StateTypeDef state = husart->State; + uint16_t *tmp; + + if ((state == HAL_USART_STATE_BUSY_TX) || + (state == HAL_USART_STATE_BUSY_TX_RX)) + { + if (husart->TxXferCount == 0U) + { + /* Disable the USART Transmit data register empty interrupt */ + __HAL_USART_DISABLE_IT(husart, USART_IT_TXE); + + /* Enable the USART Transmit Complete Interrupt */ + __HAL_USART_ENABLE_IT(husart, USART_IT_TC); + } + else + { + tmp = (uint16_t *) husart->pTxBuffPtr; + husart->Instance->TDR = (uint16_t)(*tmp & 0x01FFU); + husart->pTxBuffPtr += 2U; + husart->TxXferCount--; + } + } +} + + +/** + * @brief Wraps up transmission in non-blocking mode. + * @param husart Pointer to a USART_HandleTypeDef structure that contains + * the configuration information for the specified USART module. + * @retval None + */ +static void USART_EndTransmit_IT(USART_HandleTypeDef *husart) +{ + /* Disable the USART Transmit Complete Interrupt */ + __HAL_USART_DISABLE_IT(husart, USART_IT_TC); + + /* Disable the USART Error Interrupt: (Frame error, noise error, overrun error) */ + __HAL_USART_DISABLE_IT(husart, USART_IT_ERR); + + /* Clear TxISR function pointer */ + husart->TxISR = NULL; + + if (husart->State == HAL_USART_STATE_BUSY_TX) + { + /* Clear overrun flag and discard the received data */ + __HAL_USART_CLEAR_OREFLAG(husart); + __HAL_USART_SEND_REQ(husart, USART_RXDATA_FLUSH_REQUEST); + + /* Tx process is completed, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Complete Callback */ + husart->TxCpltCallback(husart); +#else + /* Call legacy weak Tx Complete Callback */ + HAL_USART_TxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + else if (husart->RxXferCount == 0U) + { + /* TxRx process is completed, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Rx Complete Callback */ + husart->TxRxCpltCallback(husart); +#else + /* Call legacy weak Tx Rx Complete Callback */ + HAL_USART_TxRxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + else + { + /* Nothing to do */ + } +} + + +/** + * @brief Simplex receive an amount of data in non-blocking mode. + * @note Function called under interruption only, once + * interruptions have been enabled by HAL_USART_Receive_IT(). + * @note ISR function executed when data word length is less than 9 bits long. + * @param husart USART handle + * @retval None + */ +static void USART_RxISR_8BIT(USART_HandleTypeDef *husart) +{ + const HAL_USART_StateTypeDef state = husart->State; + uint16_t txdatacount; + uint16_t uhMask = husart->Mask; + + if ((state == HAL_USART_STATE_BUSY_RX) || + (state == HAL_USART_STATE_BUSY_TX_RX)) + { + *husart->pRxBuffPtr = (uint8_t)(husart->Instance->RDR & (uint8_t)uhMask); + husart->pRxBuffPtr++; + husart->RxXferCount--; + + if (husart->RxXferCount == 0U) + { + /* Disable the USART Parity Error Interrupt and RXNE interrupt*/ + CLEAR_BIT(husart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + + /* Disable the USART Error Interrupt: (Frame error, noise error, overrun error) */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Clear RxISR function pointer */ + husart->RxISR = NULL; + + /* txdatacount is a temporary variable for MISRAC2012-Rule-13.5 */ + txdatacount = husart->TxXferCount; + + if (state == HAL_USART_STATE_BUSY_RX) + { + + /* Rx process is completed, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Rx Complete Callback */ + husart->RxCpltCallback(husart); +#else + /* Call legacy weak Rx Complete Callback */ + HAL_USART_RxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + else if ((READ_BIT(husart->Instance->CR1, USART_CR1_TCIE) != USART_CR1_TCIE) && + (txdatacount == 0U)) + { + /* TxRx process is completed, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Rx Complete Callback */ + husart->TxRxCpltCallback(husart); +#else + /* Call legacy weak Tx Rx Complete Callback */ + HAL_USART_TxRxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + else + { + /* Nothing to do */ + } + } + else if (state == HAL_USART_STATE_BUSY_RX) + { + /* Send dummy byte in order to generate the clock for the Slave to Send the next data */ + husart->Instance->TDR = (USART_DUMMY_DATA & (uint16_t)0x00FF); + } + else + { + /* Nothing to do */ + } + } +} + +/** + * @brief Simplex receive an amount of data in non-blocking mode. + * @note Function called under interruption only, once + * interruptions have been enabled by HAL_USART_Receive_IT(). + * @note ISR function executed when data word length is 9 bits long. + * @param husart USART handle + * @retval None + */ +static void USART_RxISR_16BIT(USART_HandleTypeDef *husart) +{ + const HAL_USART_StateTypeDef state = husart->State; + uint16_t txdatacount; + uint16_t *tmp; + uint16_t uhMask = husart->Mask; + + if ((state == HAL_USART_STATE_BUSY_RX) || + (state == HAL_USART_STATE_BUSY_TX_RX)) + { + tmp = (uint16_t *) husart->pRxBuffPtr; + *tmp = (uint16_t)(husart->Instance->RDR & uhMask); + husart->pRxBuffPtr += 2U; + husart->RxXferCount--; + + if (husart->RxXferCount == 0U) + { + /* Disable the USART Parity Error Interrupt and RXNE interrupt*/ + CLEAR_BIT(husart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE)); + + /* Disable the USART Error Interrupt: (Frame error, noise error, overrun error) */ + CLEAR_BIT(husart->Instance->CR3, USART_CR3_EIE); + + /* Clear RxISR function pointer */ + husart->RxISR = NULL; + + /* txdatacount is a temporary variable for MISRAC2012-Rule-13.5 */ + txdatacount = husart->TxXferCount; + + if (state == HAL_USART_STATE_BUSY_RX) + { + + /* Rx process is completed, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Rx Complete Callback */ + husart->RxCpltCallback(husart); +#else + /* Call legacy weak Rx Complete Callback */ + HAL_USART_RxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + else if ((READ_BIT(husart->Instance->CR1, USART_CR1_TCIE) != USART_CR1_TCIE) && + (txdatacount == 0U)) + { + /* TxRx process is completed, restore husart->State to Ready */ + husart->State = HAL_USART_STATE_READY; + +#if (USE_HAL_USART_REGISTER_CALLBACKS == 1) + /* Call registered Tx Rx Complete Callback */ + husart->TxRxCpltCallback(husart); +#else + /* Call legacy weak Tx Rx Complete Callback */ + HAL_USART_TxRxCpltCallback(husart); +#endif /* USE_HAL_USART_REGISTER_CALLBACKS */ + } + else + { + /* Nothing to do */ + } + } + else if (state == HAL_USART_STATE_BUSY_RX) + { + /* Send dummy byte in order to generate the clock for the Slave to Send the next data */ + husart->Instance->TDR = (USART_DUMMY_DATA & (uint16_t)0x00FF); + } + else + { + /* Nothing to do */ + } + } +} + + +/** + * @} + */ + +#endif /* HAL_USART_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart_ex.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart_ex.c new file mode 100644 index 0000000..547bbc9 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_usart_ex.c @@ -0,0 +1,138 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_usart_ex.c + * @author MCD Application Team + * @brief Extended USART HAL module driver. + * This file provides firmware functions to manage the following extended + * functionalities of the Universal Synchronous Receiver Transmitter Peripheral (USART). + * + Peripheral Control functions + * + * + @verbatim + ============================================================================== + ##### USART peripheral extended features ##### + ============================================================================== + + (#) FIFO mode enabling/disabling and RX/TX FIFO threshold programming. + + -@- When USART operates in FIFO mode, FIFO mode must be enabled prior + starting RX/TX transfers. Also RX/TX FIFO thresholds must be + configured prior starting RX/TX transfers. + + (#) Slave mode enabling/disabling and NSS pin configuration. + + -@- When USART operates in Slave mode, Slave mode must be enabled prior + starting RX/TX transfers. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup USARTEx USARTEx + * @brief USART Extended HAL module driver + * @{ + */ + +#ifdef HAL_USART_MODULE_ENABLED + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup USARTEx_Exported_Functions USARTEx Exported Functions + * @{ + */ + +/** @defgroup USARTEx_Exported_Functions_Group1 IO operation functions + * @brief Extended USART Transmit/Receive functions + * +@verbatim + =============================================================================== + ##### IO operation functions ##### + =============================================================================== + This subsection provides a set of FIFO mode related callback functions. + + (#) TX/RX Fifos Callbacks: + (+) HAL_USARTEx_RxFifoFullCallback() + (+) HAL_USARTEx_TxFifoEmptyCallback() + +@endverbatim + * @{ + */ + + +/** + * @} + */ + +/** @defgroup USARTEx_Exported_Functions_Group2 Peripheral Control functions + * @brief Extended Peripheral Control functions + * +@verbatim + =============================================================================== + ##### Peripheral Control functions ##### + =============================================================================== + [..] This section provides the following functions: + (+) HAL_USARTEx_EnableSPISlaveMode() API enables the SPI slave mode + (+) HAL_USARTEx_DisableSPISlaveMode() API disables the SPI slave mode + (+) HAL_USARTEx_ConfigNSS API configures the Slave Select input pin (NSS) + (+) HAL_USARTEx_EnableFifoMode() API enables the FIFO mode + (+) HAL_USARTEx_DisableFifoMode() API disables the FIFO mode + (+) HAL_USARTEx_SetTxFifoThreshold() API sets the TX FIFO threshold + (+) HAL_USARTEx_SetRxFifoThreshold() API sets the RX FIFO threshold + + +@endverbatim + * @{ + */ + + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup USARTEx_Private_Functions + * @{ + */ + +/** + * @} + */ + +#endif /* HAL_USART_MODULE_ENABLED */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_wwdg.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_wwdg.c new file mode 100644 index 0000000..e9e64d0 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_hal_wwdg.c @@ -0,0 +1,422 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_wwdg.c + * @author MCD Application Team + * @brief WWDG HAL module driver. + * This file provides firmware functions to manage the following + * functionalities of the Window Watchdog (WWDG) peripheral: + * + Initialization and Configuration functions + * + IO operation functions + @verbatim + ============================================================================== + ##### WWDG Specific features ##### + ============================================================================== + [..] + Once enabled the WWDG generates a system reset on expiry of a programmed + time period, unless the program refreshes the counter (T[6;0] downcounter) + before reaching 0x3F value (i.e. a reset is generated when the counter + value rolls down from 0x40 to 0x3F). + + (+) An MCU reset is also generated if the counter value is refreshed + before the counter has reached the refresh window value. This + implies that the counter must be refreshed in a limited window. + (+) Once enabled the WWDG cannot be disabled except by a system reset. + (+) If required by application, an Early Wakeup Interrupt can be triggered + in order to be warned before WWDG expiration. The Early Wakeup Interrupt + (EWI) can be used if specific safety operations or data logging must + be performed before the actual reset is generated. When the downcounter + reaches 0x40, interrupt occurs. This mechanism requires WWDG interrupt + line to be enabled in NVIC. Once enabled, EWI interrupt cannot be + disabled except by a system reset. + (+) WWDGRST flag in RCC CSR register can be used to inform when a WWDG + reset occurs. + (+) The WWDG counter input clock is derived from the APB clock divided + by a programmable prescaler. + (+) WWDG clock (Hz) = PCLK1 / (4096 * Prescaler) + (+) WWDG timeout (mS) = 1000 * (T[5;0] + 1) / WWDG clock (Hz) + where T[5;0] are the lowest 6 bits of Counter. + (+) WWDG Counter refresh is allowed between the following limits : + (++) min time (mS) = 1000 * (Counter - Window) / WWDG clock + (++) max time (mS) = 1000 * (Counter - 0x40) / WWDG clock + (+) Typical values: + (++) Counter min (T[5;0] = 0x00) at 48MHz (PCLK1) with zero prescaler: + max timeout before reset: approximately 85.3µs + (++) Counter max (T[5;0] = 0x3F) at 48MHz (PCLK1) with prescaler + dividing by 8: + max timeout before reset: approximately 43.7ms + + ##### How to use this driver ##### + ============================================================================== + + *** Common driver usage *** + =========================== + + [..] + (+) Enable WWDG APB1 clock using __HAL_RCC_WWDG_CLK_ENABLE(). + (+) Configure the WWDG prescaler, refresh window value, counter value and early + interrupt status using HAL_WWDG_Init() function. This will automatically + enable WWDG and start its downcounter. Time reference can be taken from + function exit. Care must be taken to provide a counter value + greater than 0x40 to prevent generation of immediate reset. + (+) If the Early Wakeup Interrupt (EWI) feature is enabled, an interrupt is + generated when the counter reaches 0x40. When HAL_WWDG_IRQHandler is + triggered by the interrupt service routine, flag will be automatically + cleared and HAL_WWDG_WakeupCallback user callback will be executed. User + can add his own code by customization of callback HAL_WWDG_WakeupCallback. + (+) Then the application program must refresh the WWDG counter at regular + intervals during normal operation to prevent an MCU reset, using + HAL_WWDG_Refresh() function. This operation must occur only when + the counter is lower than the refresh window value already programmed. + + *** Callback registration *** + ============================= + + [..] + The compilation define USE_HAL_WWDG_REGISTER_CALLBACKS when set to 1 allows + the user to configure dynamically the driver callbacks. Use Functions + HAL_WWDG_RegisterCallback() to register a user callback. + + (+) Function HAL_WWDG_RegisterCallback() allows to register following + callbacks: + (++) EwiCallback : callback for Early WakeUp Interrupt. + (++) MspInitCallback : WWDG MspInit. + This function takes as parameters the HAL peripheral handle, the Callback ID + and a pointer to the user callback function. + + (+) Use function HAL_WWDG_UnRegisterCallback() to reset a callback to + the default weak (surcharged) function. HAL_WWDG_UnRegisterCallback() + takes as parameters the HAL peripheral handle and the Callback ID. + This function allows to reset following callbacks: + (++) EwiCallback : callback for Early WakeUp Interrupt. + (++) MspInitCallback : WWDG MspInit. + + [..] + When calling HAL_WWDG_Init function, callbacks are reset to the + corresponding legacy weak (surcharged) functions: + HAL_WWDG_EarlyWakeupCallback() and HAL_WWDG_MspInit() only if they have + not been registered before. + + [..] + When compilation define USE_HAL_WWDG_REGISTER_CALLBACKS is set to 0 or + not defined, the callback registering feature is not available + and weak (surcharged) callbacks are used. + + *** WWDG HAL driver macros list *** + =================================== + [..] + Below the list of available macros in WWDG HAL driver. + (+) __HAL_WWDG_ENABLE: Enable the WWDG peripheral + (+) __HAL_WWDG_GET_FLAG: Get the selected WWDG's flag status + (+) __HAL_WWDG_CLEAR_FLAG: Clear the WWDG's pending flags + (+) __HAL_WWDG_ENABLE_IT: Enable the WWDG early wakeup interrupt + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#ifdef HAL_WWDG_MODULE_ENABLED +/** @defgroup WWDG WWDG + * @brief WWDG HAL module driver. + * @{ + */ + +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup WWDG_Exported_Functions WWDG Exported Functions + * @{ + */ + +/** @defgroup WWDG_Exported_Functions_Group1 Initialization and Configuration functions + * @brief Initialization and Configuration functions. + * +@verbatim + ============================================================================== + ##### Initialization and Configuration functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Initialize and start the WWDG according to the specified parameters + in the WWDG_InitTypeDef of associated handle. + (+) Initialize the WWDG MSP. + +@endverbatim + * @{ + */ + +/** + * @brief Initialize the WWDG according to the specified. + * parameters in the WWDG_InitTypeDef of associated handle. + * @param hwwdg pointer to a WWDG_HandleTypeDef structure that contains + * the configuration information for the specified WWDG module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_WWDG_Init(WWDG_HandleTypeDef *hwwdg) +{ + /* Check the WWDG handle allocation */ + if (hwwdg == NULL) + { + return HAL_ERROR; + } + + /* Check the parameters */ + assert_param(IS_WWDG_ALL_INSTANCE(hwwdg->Instance)); + assert_param(IS_WWDG_PRESCALER(hwwdg->Init.Prescaler)); + assert_param(IS_WWDG_WINDOW(hwwdg->Init.Window)); + assert_param(IS_WWDG_COUNTER(hwwdg->Init.Counter)); + assert_param(IS_WWDG_EWI_MODE(hwwdg->Init.EWIMode)); + +#if (USE_HAL_WWDG_REGISTER_CALLBACKS == 1) + /* Reset Callback pointers */ + if (hwwdg->EwiCallback == NULL) + { + hwwdg->EwiCallback = HAL_WWDG_EarlyWakeupCallback; + } + + if (hwwdg->MspInitCallback == NULL) + { + hwwdg->MspInitCallback = HAL_WWDG_MspInit; + } + + /* Init the low level hardware */ + hwwdg->MspInitCallback(hwwdg); +#else + /* Init the low level hardware */ + HAL_WWDG_MspInit(hwwdg); +#endif /* USE_HAL_WWDG_REGISTER_CALLBACKS */ + + /* Set WWDG Counter */ + WRITE_REG(hwwdg->Instance->CR, (WWDG_CR_WDGA | hwwdg->Init.Counter)); + + /* Set WWDG Prescaler and Window */ + WRITE_REG(hwwdg->Instance->CFR, (hwwdg->Init.EWIMode | hwwdg->Init.Prescaler | hwwdg->Init.Window)); + + /* Return function status */ + return HAL_OK; +} + + +/** + * @brief Initialize the WWDG MSP. + * @param hwwdg pointer to a WWDG_HandleTypeDef structure that contains + * the configuration information for the specified WWDG module. + * @note When rewriting this function in user file, mechanism may be added + * to avoid multiple initialize when HAL_WWDG_Init function is called + * again to change parameters. + * @retval None + */ +__weak void HAL_WWDG_MspInit(WWDG_HandleTypeDef *hwwdg) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hwwdg); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_WWDG_MspInit could be implemented in the user file + */ +} + + +#if (USE_HAL_WWDG_REGISTER_CALLBACKS == 1) +/** + * @brief Register a User WWDG Callback + * To be used instead of the weak (surcharged) predefined callback + * @param hwwdg WWDG handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_WWDG_EWI_CB_ID Early WakeUp Interrupt Callback ID + * @arg @ref HAL_WWDG_MSPINIT_CB_ID MspInit callback ID + * @param pCallback pointer to the Callback function + * @retval status + */ +HAL_StatusTypeDef HAL_WWDG_RegisterCallback(WWDG_HandleTypeDef *hwwdg, HAL_WWDG_CallbackIDTypeDef CallbackID, + pWWDG_CallbackTypeDef pCallback) +{ + HAL_StatusTypeDef status = HAL_OK; + + if (pCallback == NULL) + { + status = HAL_ERROR; + } + else + { + switch (CallbackID) + { + case HAL_WWDG_EWI_CB_ID: + hwwdg->EwiCallback = pCallback; + break; + + case HAL_WWDG_MSPINIT_CB_ID: + hwwdg->MspInitCallback = pCallback; + break; + + default: + status = HAL_ERROR; + break; + } + } + + return status; +} + + +/** + * @brief Unregister a WWDG Callback + * WWDG Callback is redirected to the weak (surcharged) predefined callback + * @param hwwdg WWDG handle + * @param CallbackID ID of the callback to be registered + * This parameter can be one of the following values: + * @arg @ref HAL_WWDG_EWI_CB_ID Early WakeUp Interrupt Callback ID + * @arg @ref HAL_WWDG_MSPINIT_CB_ID MspInit callback ID + * @retval status + */ +HAL_StatusTypeDef HAL_WWDG_UnRegisterCallback(WWDG_HandleTypeDef *hwwdg, HAL_WWDG_CallbackIDTypeDef CallbackID) +{ + HAL_StatusTypeDef status = HAL_OK; + + switch (CallbackID) + { + case HAL_WWDG_EWI_CB_ID: + hwwdg->EwiCallback = HAL_WWDG_EarlyWakeupCallback; + break; + + case HAL_WWDG_MSPINIT_CB_ID: + hwwdg->MspInitCallback = HAL_WWDG_MspInit; + break; + + default: + status = HAL_ERROR; + break; + } + + return status; +} +#endif /* USE_HAL_WWDG_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup WWDG_Exported_Functions_Group2 IO operation functions + * @brief IO operation functions + * +@verbatim + ============================================================================== + ##### IO operation functions ##### + ============================================================================== + [..] + This section provides functions allowing to: + (+) Refresh the WWDG. + (+) Handle WWDG interrupt request and associated function callback. + +@endverbatim + * @{ + */ + +/** + * @brief Refresh the WWDG. + * @param hwwdg pointer to a WWDG_HandleTypeDef structure that contains + * the configuration information for the specified WWDG module. + * @retval HAL status + */ +HAL_StatusTypeDef HAL_WWDG_Refresh(WWDG_HandleTypeDef *hwwdg) +{ + /* Write to WWDG CR the WWDG Counter value to refresh with */ + WRITE_REG(hwwdg->Instance->CR, (hwwdg->Init.Counter)); + + /* Return function status */ + return HAL_OK; +} + +/** + * @brief Handle WWDG interrupt request. + * @note The Early Wakeup Interrupt (EWI) can be used if specific safety operations + * or data logging must be performed before the actual reset is generated. + * The EWI interrupt is enabled by calling HAL_WWDG_Init function with + * EWIMode set to WWDG_EWI_ENABLE. + * When the downcounter reaches the value 0x40, and EWI interrupt is + * generated and the corresponding Interrupt Service Routine (ISR) can + * be used to trigger specific actions (such as communications or data + * logging), before resetting the device. + * @param hwwdg pointer to a WWDG_HandleTypeDef structure that contains + * the configuration information for the specified WWDG module. + * @retval None + */ +void HAL_WWDG_IRQHandler(WWDG_HandleTypeDef *hwwdg) +{ + /* Check if Early Wakeup Interrupt is enable */ + if (__HAL_WWDG_GET_IT_SOURCE(hwwdg, WWDG_IT_EWI) != RESET) + { + /* Check if WWDG Early Wakeup Interrupt occurred */ + if (__HAL_WWDG_GET_FLAG(hwwdg, WWDG_FLAG_EWIF) != RESET) + { + /* Clear the WWDG Early Wakeup flag */ + __HAL_WWDG_CLEAR_FLAG(hwwdg, WWDG_FLAG_EWIF); + +#if (USE_HAL_WWDG_REGISTER_CALLBACKS == 1) + /* Early Wakeup registered callback */ + hwwdg->EwiCallback(hwwdg); +#else + /* Early Wakeup callback */ + HAL_WWDG_EarlyWakeupCallback(hwwdg); +#endif /* USE_HAL_WWDG_REGISTER_CALLBACKS */ + } + } +} + + +/** + * @brief WWDG Early Wakeup callback. + * @param hwwdg pointer to a WWDG_HandleTypeDef structure that contains + * the configuration information for the specified WWDG module. + * @retval None + */ +__weak void HAL_WWDG_EarlyWakeupCallback(WWDG_HandleTypeDef *hwwdg) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(hwwdg); + + /* NOTE: This function should not be modified, when the callback is needed, + the HAL_WWDG_EarlyWakeupCallback could be implemented in the user file + */ +} + +/** + * @} + */ + +/** + * @} + */ + +#endif /* HAL_WWDG_MODULE_ENABLED */ +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_adc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_adc.c new file mode 100644 index 0000000..7d92cc7 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_adc.c @@ -0,0 +1,562 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_adc.c + * @author MCD Application Team + * @brief ADC LL module driver + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_adc.h" +#include "stm32f0xx_ll_bus.h" + +#ifdef USE_FULL_ASSERT + #include "stm32_assert.h" +#else + #define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (ADC1) + +/** @addtogroup ADC_LL ADC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @addtogroup ADC_LL_Private_Constants + * @{ + */ + +/* Definitions of ADC hardware constraints delays */ +/* Note: Only ADC IP HW delays are defined in ADC LL driver driver, */ +/* not timeout values: */ +/* Timeout values for ADC operations are dependent to device clock */ +/* configuration (system clock versus ADC clock), */ +/* and therefore must be defined in user application. */ +/* Refer to @ref ADC_LL_EC_HW_DELAYS for description of ADC timeout */ +/* values definition. */ +/* Note: ADC timeout values are defined here in CPU cycles to be independent */ +/* of device clock setting. */ +/* In user application, ADC timeout values should be defined with */ +/* temporal values, in function of device clock settings. */ +/* Highest ratio CPU clock frequency vs ADC clock frequency: */ +/* - ADC clock from synchronous clock with AHB prescaler 512, */ +/* APB prescaler 16, ADC prescaler 4. */ +/* - ADC clock from asynchronous clock (HSI) with prescaler 1, */ +/* with highest ratio CPU clock frequency vs HSI clock frequency: */ +/* CPU clock frequency max 48MHz, HSI frequency 14MHz: ratio 4. */ +/* Unit: CPU cycles. */ +#define ADC_CLOCK_RATIO_VS_CPU_HIGHEST ((uint32_t) 512U * 16U * 4U) +#define ADC_TIMEOUT_DISABLE_CPU_CYCLES (ADC_CLOCK_RATIO_VS_CPU_HIGHEST * 1U) +#define ADC_TIMEOUT_STOP_CONVERSION_CPU_CYCLES (ADC_CLOCK_RATIO_VS_CPU_HIGHEST * 1U) + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ + +/** @addtogroup ADC_LL_Private_Macros + * @{ + */ + +/* Check of parameters for configuration of ADC hierarchical scope: */ +/* common to several ADC instances. */ +/* Check of parameters for configuration of ADC hierarchical scope: */ +/* ADC instance. */ +#define IS_LL_ADC_CLOCK(__CLOCK__) \ + ( ((__CLOCK__) == LL_ADC_CLOCK_SYNC_PCLK_DIV4) \ + || ((__CLOCK__) == LL_ADC_CLOCK_SYNC_PCLK_DIV2) \ + || ((__CLOCK__) == LL_ADC_CLOCK_ASYNC) \ + ) + +#define IS_LL_ADC_RESOLUTION(__RESOLUTION__) \ + ( ((__RESOLUTION__) == LL_ADC_RESOLUTION_12B) \ + || ((__RESOLUTION__) == LL_ADC_RESOLUTION_10B) \ + || ((__RESOLUTION__) == LL_ADC_RESOLUTION_8B) \ + || ((__RESOLUTION__) == LL_ADC_RESOLUTION_6B) \ + ) + +#define IS_LL_ADC_DATA_ALIGN(__DATA_ALIGN__) \ + ( ((__DATA_ALIGN__) == LL_ADC_DATA_ALIGN_RIGHT) \ + || ((__DATA_ALIGN__) == LL_ADC_DATA_ALIGN_LEFT) \ + ) + +#define IS_LL_ADC_LOW_POWER(__LOW_POWER__) \ + ( ((__LOW_POWER__) == LL_ADC_LP_MODE_NONE) \ + || ((__LOW_POWER__) == LL_ADC_LP_AUTOWAIT) \ + || ((__LOW_POWER__) == LL_ADC_LP_AUTOPOWEROFF) \ + || ((__LOW_POWER__) == LL_ADC_LP_AUTOWAIT_AUTOPOWEROFF) \ + ) + +/* Check of parameters for configuration of ADC hierarchical scope: */ +/* ADC group regular */ +#define IS_LL_ADC_REG_TRIG_SOURCE(__REG_TRIG_SOURCE__) \ + ( ((__REG_TRIG_SOURCE__) == LL_ADC_REG_TRIG_SOFTWARE) \ + || ((__REG_TRIG_SOURCE__) == LL_ADC_REG_TRIG_EXT_TIM1_TRGO) \ + || ((__REG_TRIG_SOURCE__) == LL_ADC_REG_TRIG_EXT_TIM1_CH4) \ + || ((__REG_TRIG_SOURCE__) == LL_ADC_REG_TRIG_EXT_TIM2_TRGO) \ + || ((__REG_TRIG_SOURCE__) == LL_ADC_REG_TRIG_EXT_TIM3_TRGO) \ + || ((__REG_TRIG_SOURCE__) == LL_ADC_REG_TRIG_EXT_TIM15_TRGO) \ + ) + +#define IS_LL_ADC_REG_CONTINUOUS_MODE(__REG_CONTINUOUS_MODE__) \ + ( ((__REG_CONTINUOUS_MODE__) == LL_ADC_REG_CONV_SINGLE) \ + || ((__REG_CONTINUOUS_MODE__) == LL_ADC_REG_CONV_CONTINUOUS) \ + ) + +#define IS_LL_ADC_REG_DMA_TRANSFER(__REG_DMA_TRANSFER__) \ + ( ((__REG_DMA_TRANSFER__) == LL_ADC_REG_DMA_TRANSFER_NONE) \ + || ((__REG_DMA_TRANSFER__) == LL_ADC_REG_DMA_TRANSFER_LIMITED) \ + || ((__REG_DMA_TRANSFER__) == LL_ADC_REG_DMA_TRANSFER_UNLIMITED) \ + ) + +#define IS_LL_ADC_REG_OVR_DATA_BEHAVIOR(__REG_OVR_DATA_BEHAVIOR__) \ + ( ((__REG_OVR_DATA_BEHAVIOR__) == LL_ADC_REG_OVR_DATA_PRESERVED) \ + || ((__REG_OVR_DATA_BEHAVIOR__) == LL_ADC_REG_OVR_DATA_OVERWRITTEN) \ + ) + +#define IS_LL_ADC_REG_SEQ_SCAN_DISCONT_MODE(__REG_SEQ_DISCONT_MODE__) \ + ( ((__REG_SEQ_DISCONT_MODE__) == LL_ADC_REG_SEQ_DISCONT_DISABLE) \ + || ((__REG_SEQ_DISCONT_MODE__) == LL_ADC_REG_SEQ_DISCONT_1RANK) \ + ) + +/** + * @} + */ + + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup ADC_LL_Exported_Functions + * @{ + */ + +/** @addtogroup ADC_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize registers of all ADC instances belonging to + * the same ADC common instance to their default reset values. + * @note This function is performing a hard reset, using high level + * clock source RCC ADC reset. + * @param ADCxy_COMMON ADC common instance + * (can be set directly from CMSIS definition or by using helper macro @ref __LL_ADC_COMMON_INSTANCE() ) + * @retval An ErrorStatus enumeration value: + * - SUCCESS: ADC common registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_ADC_CommonDeInit(ADC_Common_TypeDef *ADCxy_COMMON) +{ + /* Check the parameters */ + assert_param(IS_ADC_COMMON_INSTANCE(ADCxy_COMMON)); + + /* Force reset of ADC clock (core clock) */ + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_ADC1); + + /* Release reset of ADC clock (core clock) */ + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_ADC1); + + return SUCCESS; +} + + +/** + * @brief De-initialize registers of the selected ADC instance + * to their default reset values. + * @note To reset all ADC instances quickly (perform a hard reset), + * use function @ref LL_ADC_CommonDeInit(). + * @note If this functions returns error status, it means that ADC instance + * is in an unknown state. + * In this case, perform a hard reset using high level + * clock source RCC ADC reset. + * Refer to function @ref LL_ADC_CommonDeInit(). + * @param ADCx ADC instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: ADC registers are de-initialized + * - ERROR: ADC registers are not de-initialized + */ +ErrorStatus LL_ADC_DeInit(ADC_TypeDef *ADCx) +{ + ErrorStatus status = SUCCESS; + + __IO uint32_t timeout_cpu_cycles = 0U; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(ADCx)); + + /* Disable ADC instance if not already disabled. */ + if(LL_ADC_IsEnabled(ADCx) == 1U) + { + /* Set ADC group regular trigger source to SW start to ensure to not */ + /* have an external trigger event occurring during the conversion stop */ + /* ADC disable process. */ + LL_ADC_REG_SetTriggerSource(ADCx, LL_ADC_REG_TRIG_SOFTWARE); + + /* Stop potential ADC conversion on going on ADC group regular. */ + if(LL_ADC_REG_IsConversionOngoing(ADCx) != 0U) + { + if(LL_ADC_REG_IsStopConversionOngoing(ADCx) == 0U) + { + LL_ADC_REG_StopConversion(ADCx); + } + } + + /* Wait for ADC conversions are effectively stopped */ + timeout_cpu_cycles = ADC_TIMEOUT_STOP_CONVERSION_CPU_CYCLES; + while (LL_ADC_REG_IsStopConversionOngoing(ADCx) == 1U) + { + if(timeout_cpu_cycles-- == 0U) + { + /* Time-out error */ + status = ERROR; + } + } + + /* Disable the ADC instance */ + LL_ADC_Disable(ADCx); + + /* Wait for ADC instance is effectively disabled */ + timeout_cpu_cycles = ADC_TIMEOUT_DISABLE_CPU_CYCLES; + while (LL_ADC_IsDisableOngoing(ADCx) == 1U) + { + if(timeout_cpu_cycles-- == 0U) + { + /* Time-out error */ + status = ERROR; + } + } + } + + /* Check whether ADC state is compliant with expected state */ + if(READ_BIT(ADCx->CR, + ( ADC_CR_ADSTP | ADC_CR_ADSTART + | ADC_CR_ADDIS | ADC_CR_ADEN ) + ) + == 0U) + { + /* ========== Reset ADC registers ========== */ + /* Reset register IER */ + CLEAR_BIT(ADCx->IER, + ( LL_ADC_IT_ADRDY + | LL_ADC_IT_EOC + | LL_ADC_IT_EOS + | LL_ADC_IT_OVR + | LL_ADC_IT_EOSMP + | LL_ADC_IT_AWD1 ) + ); + + /* Reset register ISR */ + SET_BIT(ADCx->ISR, + ( LL_ADC_FLAG_ADRDY + | LL_ADC_FLAG_EOC + | LL_ADC_FLAG_EOS + | LL_ADC_FLAG_OVR + | LL_ADC_FLAG_EOSMP + | LL_ADC_FLAG_AWD1 ) + ); + + /* Reset register CR */ + /* Bits ADC_CR_ADCAL, ADC_CR_ADSTP, ADC_CR_ADSTART are in access mode */ + /* "read-set": no direct reset applicable. */ + /* No action on register CR */ + + /* Reset register CFGR1 */ + CLEAR_BIT(ADCx->CFGR1, + ( ADC_CFGR1_AWDCH | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL | ADC_CFGR1_DISCEN + | ADC_CFGR1_AUTOFF | ADC_CFGR1_WAIT | ADC_CFGR1_CONT | ADC_CFGR1_OVRMOD + | ADC_CFGR1_EXTEN | ADC_CFGR1_EXTSEL | ADC_CFGR1_ALIGN | ADC_CFGR1_RES + | ADC_CFGR1_SCANDIR | ADC_CFGR1_DMACFG | ADC_CFGR1_DMAEN ) + ); + + /* Reset register CFGR2 */ + /* Note: Update of ADC clock mode is conditioned to ADC state disabled: */ + /* already done above. */ + CLEAR_BIT(ADCx->CFGR2, ADC_CFGR2_CKMODE); + + /* Reset register SMPR */ + CLEAR_BIT(ADCx->SMPR, ADC_SMPR_SMP); + + /* Reset register TR */ + MODIFY_REG(ADCx->TR, ADC_TR_HT | ADC_TR_LT, ADC_TR_HT); + + /* Reset register CHSELR */ +#if defined(ADC_CCR_VBATEN) + CLEAR_BIT(ADCx->CHSELR, + ( ADC_CHSELR_CHSEL18 | ADC_CHSELR_CHSEL17 | ADC_CHSELR_CHSEL16 + | ADC_CHSELR_CHSEL15 | ADC_CHSELR_CHSEL14 | ADC_CHSELR_CHSEL13 | ADC_CHSELR_CHSEL12 + | ADC_CHSELR_CHSEL11 | ADC_CHSELR_CHSEL10 | ADC_CHSELR_CHSEL9 | ADC_CHSELR_CHSEL8 + | ADC_CHSELR_CHSEL7 | ADC_CHSELR_CHSEL6 | ADC_CHSELR_CHSEL5 | ADC_CHSELR_CHSEL4 + | ADC_CHSELR_CHSEL3 | ADC_CHSELR_CHSEL2 | ADC_CHSELR_CHSEL1 | ADC_CHSELR_CHSEL0 ) + ); +#else + CLEAR_BIT(ADCx->CHSELR, + ( ADC_CHSELR_CHSEL17 | ADC_CHSELR_CHSEL16 + | ADC_CHSELR_CHSEL15 | ADC_CHSELR_CHSEL14 | ADC_CHSELR_CHSEL13 | ADC_CHSELR_CHSEL12 + | ADC_CHSELR_CHSEL11 | ADC_CHSELR_CHSEL10 | ADC_CHSELR_CHSEL9 | ADC_CHSELR_CHSEL8 + | ADC_CHSELR_CHSEL7 | ADC_CHSELR_CHSEL6 | ADC_CHSELR_CHSEL5 | ADC_CHSELR_CHSEL4 + | ADC_CHSELR_CHSEL3 | ADC_CHSELR_CHSEL2 | ADC_CHSELR_CHSEL1 | ADC_CHSELR_CHSEL0 ) + ); +#endif + + /* Reset register DR */ + /* bits in access mode read only, no direct reset applicable */ + + } + else + { + /* ADC instance is in an unknown state */ + /* Need to performing a hard reset of ADC instance, using high level */ + /* clock source RCC ADC reset. */ + /* Caution: On this STM32 serie, if several ADC instances are available */ + /* on the selected device, RCC ADC reset will reset */ + /* all ADC instances belonging to the common ADC instance. */ + status = ERROR; + } + + return status; +} + +/** + * @brief Initialize some features of ADC instance. + * @note These parameters have an impact on ADC scope: ADC instance. + * Refer to corresponding unitary functions into + * @ref ADC_LL_EF_Configuration_ADC_Instance . + * @note The setting of these parameters by function @ref LL_ADC_Init() + * is conditioned to ADC state: + * ADC instance must be disabled. + * This condition is applied to all ADC features, for efficiency + * and compatibility over all STM32 families. However, the different + * features can be set under different ADC state conditions + * (setting possible with ADC enabled without conversion on going, + * ADC enabled with conversion on going, ...) + * Each feature can be updated afterwards with a unitary function + * and potentially with ADC in a different state than disabled, + * refer to description of each function for setting + * conditioned to ADC state. + * @note After using this function, some other features must be configured + * using LL unitary functions. + * The minimum configuration remaining to be done is: + * - Set ADC group regular sequencer: + * map channel on rank corresponding to channel number. + * Refer to function @ref LL_ADC_REG_SetSequencerChannels(); + * - Set ADC channel sampling time + * Refer to function LL_ADC_SetChannelSamplingTime(); + * @param ADCx ADC instance + * @param ADC_InitStruct Pointer to a @ref LL_ADC_REG_InitTypeDef structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: ADC registers are initialized + * - ERROR: ADC registers are not initialized + */ +ErrorStatus LL_ADC_Init(ADC_TypeDef *ADCx, LL_ADC_InitTypeDef *ADC_InitStruct) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(ADCx)); + + assert_param(IS_LL_ADC_CLOCK(ADC_InitStruct->Clock)); + assert_param(IS_LL_ADC_RESOLUTION(ADC_InitStruct->Resolution)); + assert_param(IS_LL_ADC_DATA_ALIGN(ADC_InitStruct->DataAlignment)); + assert_param(IS_LL_ADC_LOW_POWER(ADC_InitStruct->LowPowerMode)); + + /* Note: Hardware constraint (refer to description of this function): */ + /* ADC instance must be disabled. */ + if(LL_ADC_IsEnabled(ADCx) == 0U) + { + /* Configuration of ADC hierarchical scope: */ + /* - ADC instance */ + /* - Set ADC data resolution */ + /* - Set ADC conversion data alignment */ + /* - Set ADC low power mode */ + MODIFY_REG(ADCx->CFGR1, + ADC_CFGR1_RES + | ADC_CFGR1_ALIGN + | ADC_CFGR1_WAIT + | ADC_CFGR1_AUTOFF + , + ADC_InitStruct->Resolution + | ADC_InitStruct->DataAlignment + | ADC_InitStruct->LowPowerMode + ); + + MODIFY_REG(ADCx->CFGR2, + ADC_CFGR2_CKMODE + , + ADC_InitStruct->Clock + ); + } + else + { + /* Initialization error: ADC instance is not disabled. */ + status = ERROR; + } + return status; +} + +/** + * @brief Set each @ref LL_ADC_InitTypeDef field to default value. + * @param ADC_InitStruct Pointer to a @ref LL_ADC_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ +void LL_ADC_StructInit(LL_ADC_InitTypeDef *ADC_InitStruct) +{ + /* Set ADC_InitStruct fields to default values */ + /* Set fields of ADC instance */ + ADC_InitStruct->Clock = LL_ADC_CLOCK_SYNC_PCLK_DIV2; + ADC_InitStruct->Resolution = LL_ADC_RESOLUTION_12B; + ADC_InitStruct->DataAlignment = LL_ADC_DATA_ALIGN_RIGHT; + ADC_InitStruct->LowPowerMode = LL_ADC_LP_MODE_NONE; + +} + +/** + * @brief Initialize some features of ADC group regular. + * @note These parameters have an impact on ADC scope: ADC group regular. + * Refer to corresponding unitary functions into + * @ref ADC_LL_EF_Configuration_ADC_Group_Regular + * (functions with prefix "REG"). + * @note The setting of these parameters by function @ref LL_ADC_Init() + * is conditioned to ADC state: + * ADC instance must be disabled. + * This condition is applied to all ADC features, for efficiency + * and compatibility over all STM32 families. However, the different + * features can be set under different ADC state conditions + * (setting possible with ADC enabled without conversion on going, + * ADC enabled with conversion on going, ...) + * Each feature can be updated afterwards with a unitary function + * and potentially with ADC in a different state than disabled, + * refer to description of each function for setting + * conditioned to ADC state. + * @note After using this function, other features must be configured + * using LL unitary functions. + * The minimum configuration remaining to be done is: + * - Set ADC group regular sequencer: + * map channel on rank corresponding to channel number. + * Refer to function @ref LL_ADC_REG_SetSequencerChannels(); + * - Set ADC channel sampling time + * Refer to function LL_ADC_SetChannelSamplingTime(); + * @param ADCx ADC instance + * @param ADC_REG_InitStruct Pointer to a @ref LL_ADC_REG_InitTypeDef structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: ADC registers are initialized + * - ERROR: ADC registers are not initialized + */ +ErrorStatus LL_ADC_REG_Init(ADC_TypeDef *ADCx, LL_ADC_REG_InitTypeDef *ADC_REG_InitStruct) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_ADC_ALL_INSTANCE(ADCx)); + assert_param(IS_LL_ADC_REG_TRIG_SOURCE(ADC_REG_InitStruct->TriggerSource)); + assert_param(IS_LL_ADC_REG_SEQ_SCAN_DISCONT_MODE(ADC_REG_InitStruct->SequencerDiscont)); + assert_param(IS_LL_ADC_REG_CONTINUOUS_MODE(ADC_REG_InitStruct->ContinuousMode)); + assert_param(IS_LL_ADC_REG_DMA_TRANSFER(ADC_REG_InitStruct->DMATransfer)); + assert_param(IS_LL_ADC_REG_OVR_DATA_BEHAVIOR(ADC_REG_InitStruct->Overrun)); + + /* ADC group regular continuous mode and discontinuous mode */ + /* can not be enabled simultenaeously */ + assert_param((ADC_REG_InitStruct->ContinuousMode == LL_ADC_REG_CONV_SINGLE) + || (ADC_REG_InitStruct->SequencerDiscont == LL_ADC_REG_SEQ_DISCONT_DISABLE)); + + /* Note: Hardware constraint (refer to description of this function): */ + /* ADC instance must be disabled. */ + if(LL_ADC_IsEnabled(ADCx) == 0U) + { + /* Configuration of ADC hierarchical scope: */ + /* - ADC group regular */ + /* - Set ADC group regular trigger source */ + /* - Set ADC group regular sequencer discontinuous mode */ + /* - Set ADC group regular continuous mode */ + /* - Set ADC group regular conversion data transfer: no transfer or */ + /* transfer by DMA, and DMA requests mode */ + /* - Set ADC group regular overrun behavior */ + /* Note: On this STM32 serie, ADC trigger edge is set to value 0x0 by */ + /* setting of trigger source to SW start. */ + MODIFY_REG(ADCx->CFGR1, + ADC_CFGR1_EXTSEL + | ADC_CFGR1_EXTEN + | ADC_CFGR1_DISCEN + | ADC_CFGR1_CONT + | ADC_CFGR1_DMAEN + | ADC_CFGR1_DMACFG + | ADC_CFGR1_OVRMOD + , + ADC_REG_InitStruct->TriggerSource + | ADC_REG_InitStruct->SequencerDiscont + | ADC_REG_InitStruct->ContinuousMode + | ADC_REG_InitStruct->DMATransfer + | ADC_REG_InitStruct->Overrun + ); + + } + else + { + /* Initialization error: ADC instance is not disabled. */ + status = ERROR; + } + return status; +} + +/** + * @brief Set each @ref LL_ADC_REG_InitTypeDef field to default value. + * @param ADC_REG_InitStruct Pointer to a @ref LL_ADC_REG_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ +void LL_ADC_REG_StructInit(LL_ADC_REG_InitTypeDef *ADC_REG_InitStruct) +{ + /* Set ADC_REG_InitStruct fields to default values */ + /* Set fields of ADC group regular */ + /* Note: On this STM32 serie, ADC trigger edge is set to value 0x0 by */ + /* setting of trigger source to SW start. */ + ADC_REG_InitStruct->TriggerSource = LL_ADC_REG_TRIG_SOFTWARE; + ADC_REG_InitStruct->SequencerDiscont = LL_ADC_REG_SEQ_DISCONT_DISABLE; + ADC_REG_InitStruct->ContinuousMode = LL_ADC_REG_CONV_SINGLE; + ADC_REG_InitStruct->DMATransfer = LL_ADC_REG_DMA_TRANSFER_NONE; + ADC_REG_InitStruct->Overrun = LL_ADC_REG_OVR_DATA_OVERWRITTEN; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* ADC1 */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_comp.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_comp.c new file mode 100644 index 0000000..a108f40 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_comp.c @@ -0,0 +1,316 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_comp.c + * @author MCD Application Team + * @brief COMP LL module driver + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_comp.h" + +#ifdef USE_FULL_ASSERT + #include "stm32_assert.h" +#else + #define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (COMP1) || defined (COMP2) + +/** @addtogroup COMP_LL COMP + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ + +/** @addtogroup COMP_LL_Private_Macros + * @{ + */ + +/* Check of parameters for configuration of COMP hierarchical scope: */ +/* COMP instance. */ + +#define IS_LL_COMP_POWER_MODE(__POWER_MODE__) \ + ( ((__POWER_MODE__) == LL_COMP_POWERMODE_HIGHSPEED) \ + || ((__POWER_MODE__) == LL_COMP_POWERMODE_MEDIUMSPEED) \ + || ((__POWER_MODE__) == LL_COMP_POWERMODE_LOWPOWER) \ + || ((__POWER_MODE__) == LL_COMP_POWERMODE_ULTRALOWPOWER) \ + ) + +/* Note: On this STM32 serie, comparator input plus parameters are */ +/* the different depending on COMP instances. */ +#define IS_LL_COMP_INPUT_PLUS(__COMP_INSTANCE__, __INPUT_PLUS__) \ + (((__COMP_INSTANCE__) == COMP1) \ + ? ( \ + ((__INPUT_PLUS__) == LL_COMP_INPUT_PLUS_IO1) \ + || ((__INPUT_PLUS__) == LL_COMP_INPUT_PLUS_DAC1_CH1) \ + ) \ + : \ + ( \ + ((__INPUT_PLUS__) == LL_COMP_INPUT_PLUS_IO1) \ + ) \ + ) + +/* Note: On this STM32 serie, comparator input minus parameters are */ +/* the same on all COMP instances. */ +/* However, comparator instance kept as macro parameter for */ +/* compatibility with other STM32 families. */ +#define IS_LL_COMP_INPUT_MINUS(__COMP_INSTANCE__, __INPUT_MINUS__) \ + ( ((__INPUT_MINUS__) == LL_COMP_INPUT_MINUS_1_4VREFINT) \ + || ((__INPUT_MINUS__) == LL_COMP_INPUT_MINUS_1_2VREFINT) \ + || ((__INPUT_MINUS__) == LL_COMP_INPUT_MINUS_3_4VREFINT) \ + || ((__INPUT_MINUS__) == LL_COMP_INPUT_MINUS_VREFINT) \ + || ((__INPUT_MINUS__) == LL_COMP_INPUT_MINUS_DAC1_CH1) \ + || ((__INPUT_MINUS__) == LL_COMP_INPUT_MINUS_DAC1_CH2) \ + || ((__INPUT_MINUS__) == LL_COMP_INPUT_MINUS_IO1) \ + ) + +#define IS_LL_COMP_INPUT_HYSTERESIS(__INPUT_HYSTERESIS__) \ + ( ((__INPUT_HYSTERESIS__) == LL_COMP_HYSTERESIS_NONE) \ + || ((__INPUT_HYSTERESIS__) == LL_COMP_HYSTERESIS_LOW) \ + || ((__INPUT_HYSTERESIS__) == LL_COMP_HYSTERESIS_MEDIUM) \ + || ((__INPUT_HYSTERESIS__) == LL_COMP_HYSTERESIS_HIGH) \ + ) + +#define IS_LL_COMP_OUTPUT_SELECTION(__OUTPUT_SELECTION__) \ + ( ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_NONE) \ + || ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_TIM1_BKIN) \ + || ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_TIM1_IC1) \ + || ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_TIM1_OCCLR) \ + || ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_TIM2_IC4) \ + || ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_TIM2_OCCLR) \ + || ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_TIM3_IC1) \ + || ((__OUTPUT_SELECTION__) == LL_COMP_OUTPUT_TIM3_OCCLR) \ + ) + +#define IS_LL_COMP_OUTPUT_POLARITY(__POLARITY__) \ + ( ((__POLARITY__) == LL_COMP_OUTPUTPOL_NONINVERTED) \ + || ((__POLARITY__) == LL_COMP_OUTPUTPOL_INVERTED) \ + ) + +/** + * @} + */ + + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup COMP_LL_Exported_Functions + * @{ + */ + +/** @addtogroup COMP_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize registers of the selected COMP instance + * to their default reset values. + * @note If comparator is locked, de-initialization by software is + * not possible. + * The only way to unlock the comparator is a device hardware reset. + * @param COMPx COMP instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: COMP registers are de-initialized + * - ERROR: COMP registers are not de-initialized + */ +ErrorStatus LL_COMP_DeInit(COMP_TypeDef *COMPx) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_COMP_ALL_INSTANCE(COMPx)); + + /* Note: Hardware constraint (refer to description of this function): */ + /* COMP instance must not be locked. */ + if(LL_COMP_IsLocked(COMPx) == 0U) + { + /* Note: Connection switch is applicable only to COMP instance COMP1, */ + /* therefore is COMP2 is selected the equivalent bit is */ + /* kept unmodified. */ + if(COMPx == COMP1) + { + CLEAR_BIT(COMP->CSR, + ( COMP_CSR_COMP1MODE + | COMP_CSR_COMP1INSEL + | COMP_CSR_COMP1SW1 + | COMP_CSR_COMP1OUTSEL + | COMP_CSR_COMP1HYST + | COMP_CSR_COMP1POL + | COMP_CSR_COMP1EN + ) << __COMP_BITOFFSET_INSTANCE(COMPx) + ); + } + else + { + CLEAR_BIT(COMP->CSR, + ( COMP_CSR_COMP1MODE + | COMP_CSR_COMP1INSEL + | COMP_CSR_COMP1OUTSEL + | COMP_CSR_COMP1HYST + | COMP_CSR_COMP1POL + | COMP_CSR_COMP1EN + ) << __COMP_BITOFFSET_INSTANCE(COMPx) + ); + } + + } + else + { + /* Comparator instance is locked: de-initialization by software is */ + /* not possible. */ + /* The only way to unlock the comparator is a device hardware reset. */ + status = ERROR; + } + + return status; +} + +/** + * @brief Initialize some features of COMP instance. + * @note This function configures features of the selected COMP instance. + * Some features are also available at scope COMP common instance + * (common to several COMP instances). + * Refer to functions having argument "COMPxy_COMMON" as parameter. + * @param COMPx COMP instance + * @param COMP_InitStruct Pointer to a @ref LL_COMP_InitTypeDef structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: COMP registers are initialized + * - ERROR: COMP registers are not initialized + */ +ErrorStatus LL_COMP_Init(COMP_TypeDef *COMPx, LL_COMP_InitTypeDef *COMP_InitStruct) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_COMP_ALL_INSTANCE(COMPx)); + assert_param(IS_LL_COMP_POWER_MODE(COMP_InitStruct->PowerMode)); + assert_param(IS_LL_COMP_INPUT_PLUS(COMPx, COMP_InitStruct->InputPlus)); + assert_param(IS_LL_COMP_INPUT_MINUS(COMPx, COMP_InitStruct->InputMinus)); + assert_param(IS_LL_COMP_INPUT_HYSTERESIS(COMP_InitStruct->InputHysteresis)); + assert_param(IS_LL_COMP_OUTPUT_SELECTION(COMP_InitStruct->OutputSelection)); + assert_param(IS_LL_COMP_OUTPUT_POLARITY(COMP_InitStruct->OutputPolarity)); + + /* Note: Hardware constraint (refer to description of this function) */ + /* COMP instance must not be locked. */ + if(LL_COMP_IsLocked(COMPx) == 0U) + { + /* Configuration of comparator instance : */ + /* - PowerMode */ + /* - InputPlus */ + /* - InputMinus */ + /* - InputHysteresis */ + /* - OutputSelection */ + /* - OutputPolarity */ + /* Note: Connection switch is applicable only to COMP instance COMP1, */ + /* therefore is COMP2 is selected the equivalent bit is */ + /* kept unmodified. */ + if(COMPx == COMP1) + { + MODIFY_REG(COMP->CSR, + ( COMP_CSR_COMP1MODE + | COMP_CSR_COMP1INSEL + | COMP_CSR_COMP1SW1 + | COMP_CSR_COMP1OUTSEL + | COMP_CSR_COMP1HYST + | COMP_CSR_COMP1POL + ) << __COMP_BITOFFSET_INSTANCE(COMPx) + , + ( COMP_InitStruct->PowerMode + | COMP_InitStruct->InputPlus + | COMP_InitStruct->InputMinus + | COMP_InitStruct->InputHysteresis + | COMP_InitStruct->OutputSelection + | COMP_InitStruct->OutputPolarity + ) << __COMP_BITOFFSET_INSTANCE(COMPx) + ); + } + else + { + MODIFY_REG(COMP->CSR, + ( COMP_CSR_COMP1MODE + | COMP_CSR_COMP1INSEL + | COMP_CSR_COMP1OUTSEL + | COMP_CSR_COMP1HYST + | COMP_CSR_COMP1POL + ) << __COMP_BITOFFSET_INSTANCE(COMPx) + , + ( COMP_InitStruct->PowerMode + | COMP_InitStruct->InputPlus + | COMP_InitStruct->InputMinus + | COMP_InitStruct->InputHysteresis + | COMP_InitStruct->OutputSelection + | COMP_InitStruct->OutputPolarity + ) << __COMP_BITOFFSET_INSTANCE(COMPx) + ); + } + + } + else + { + /* Initialization error: COMP instance is locked. */ + status = ERROR; + } + + return status; +} + +/** + * @brief Set each @ref LL_COMP_InitTypeDef field to default value. + * @param COMP_InitStruct pointer to a @ref LL_COMP_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ +void LL_COMP_StructInit(LL_COMP_InitTypeDef *COMP_InitStruct) +{ + /* Set COMP_InitStruct fields to default values */ + COMP_InitStruct->PowerMode = LL_COMP_POWERMODE_ULTRALOWPOWER; + COMP_InitStruct->InputPlus = LL_COMP_INPUT_PLUS_IO1; + COMP_InitStruct->InputMinus = LL_COMP_INPUT_MINUS_VREFINT; + COMP_InitStruct->InputHysteresis = LL_COMP_HYSTERESIS_NONE; + COMP_InitStruct->OutputSelection = LL_COMP_OUTPUT_NONE; + COMP_InitStruct->OutputPolarity = LL_COMP_OUTPUTPOL_NONINVERTED; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* COMP1 || COMP2 */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crc.c new file mode 100644 index 0000000..8e1bd97 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crc.c @@ -0,0 +1,122 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_crc.c + * @author MCD Application Team + * @brief CRC LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_crc.h" +#include "stm32f0xx_ll_bus.h" + +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (CRC) + +/** @addtogroup CRC_LL + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup CRC_LL_Exported_Functions + * @{ + */ + +/** @addtogroup CRC_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize CRC registers (Registers restored to their default values). + * @param CRCx CRC Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: CRC registers are de-initialized + * - ERROR: CRC registers are not de-initialized + */ +ErrorStatus LL_CRC_DeInit(CRC_TypeDef *CRCx) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_CRC_ALL_INSTANCE(CRCx)); + + if (CRCx == CRC) + { +#if defined(CRC_POL_POL) + /* Set programmable polynomial size in CR register to reset value (32 bits)*/ + LL_CRC_SetPolynomialSize(CRCx, LL_CRC_POLYLENGTH_32B); + + /* Set programmable polynomial in POL register to reset value */ + LL_CRC_SetPolynomialCoef(CRCx, LL_CRC_DEFAULT_CRC32_POLY); +#endif /* CRC_POL_POL */ + + /* Set INIT register to reset value */ + LL_CRC_SetInitialData(CRCx, LL_CRC_DEFAULT_CRC_INITVALUE); + + /* Set Reversibility options on I/O data values in CR register to reset value */ + LL_CRC_SetInputDataReverseMode(CRCx, LL_CRC_INDATA_REVERSE_NONE); + LL_CRC_SetOutputDataReverseMode(CRCx, LL_CRC_OUTDATA_REVERSE_NONE); + + /* Reset the CRC calculation unit */ + LL_CRC_ResetCRCCalculationUnit(CRCx); + + /* Reset IDR register */ + LL_CRC_Write_IDR(CRCx, 0x00U); + } + else + { + status = ERROR; + } + + return (status); +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined (CRC) */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crs.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crs.c new file mode 100644 index 0000000..ac186e9 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_crs.c @@ -0,0 +1,87 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_crs.h + * @author MCD Application Team + * @brief CRS LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_crs.h" +#include "stm32f0xx_ll_bus.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(CRS) + +/** @defgroup CRS_LL CRS + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup CRS_LL_Exported_Functions + * @{ + */ + +/** @addtogroup CRS_LL_EF_Init + * @{ + */ + +/** + * @brief De-Initializes CRS peripheral registers to their default reset values. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: CRS registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_CRS_DeInit(void) +{ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_CRS); + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_CRS); + + return SUCCESS; +} + + + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(CRS) */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dac.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dac.c new file mode 100644 index 0000000..c99828c --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dac.c @@ -0,0 +1,276 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_dac.c + * @author MCD Application Team + * @brief DAC LL module driver + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_dac.h" +#include "stm32f0xx_ll_bus.h" + +#ifdef USE_FULL_ASSERT + #include "stm32_assert.h" +#else + #define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (DAC1) + +/** @addtogroup DAC_LL DAC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ + +/** @addtogroup DAC_LL_Private_Macros + * @{ + */ + +#if defined(DAC_CHANNEL2_SUPPORT) +#define IS_LL_DAC_CHANNEL(__DACX__, __DAC_CHANNEL__) \ + ( \ + ((__DAC_CHANNEL__) == LL_DAC_CHANNEL_1) \ + || ((__DAC_CHANNEL__) == LL_DAC_CHANNEL_2) \ + ) +#else +#define IS_LL_DAC_CHANNEL(__DACX__, __DAC_CHANNEL__) \ + ( \ + ((__DAC_CHANNEL__) == LL_DAC_CHANNEL_1) \ + ) +#endif /* DAC_CHANNEL2_SUPPORT */ + +#define IS_LL_DAC_TRIGGER_SOURCE(__TRIGGER_SOURCE__) \ + ( ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_SOFTWARE) \ + || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM2_TRGO) \ + || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM3_TRGO) \ + || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM4_TRGO) \ + || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM6_TRGO) \ + || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM7_TRGO) \ + || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_TIM15_TRGO) \ + || ((__TRIGGER_SOURCE__) == LL_DAC_TRIG_EXT_EXTI_LINE9) \ + ) + +#if defined(DAC_CR_WAVE1) +#define IS_LL_DAC_WAVE_AUTO_GENER_MODE(__WAVE_AUTO_GENERATION_MODE__) \ + ( ((__WAVE_AUTO_GENERATION_MODE__) == LL_DAC_WAVE_AUTO_GENERATION_NONE) \ + || ((__WAVE_AUTO_GENERATION_MODE__) == LL_DAC_WAVE_AUTO_GENERATION_NOISE) \ + || ((__WAVE_AUTO_GENERATION_MODE__) == LL_DAC_WAVE_AUTO_GENERATION_TRIANGLE) \ + ) + +#define IS_LL_DAC_WAVE_AUTO_GENER_CONFIG(__WAVE_AUTO_GENERATION_CONFIG__) \ + ( ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BIT0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS1_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS2_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS3_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS4_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS5_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS6_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS7_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS8_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS9_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS10_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_NOISE_LFSR_UNMASK_BITS11_0) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_1) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_3) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_7) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_15) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_31) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_63) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_127) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_255) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_511) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_1023) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_2047) \ + || ((__WAVE_AUTO_GENERATION_CONFIG__) == LL_DAC_TRIANGLE_AMPLITUDE_4095) \ + ) +#endif + +#define IS_LL_DAC_OUTPUT_BUFFER(__OUTPUT_BUFFER__) \ + ( ((__OUTPUT_BUFFER__) == LL_DAC_OUTPUT_BUFFER_ENABLE) \ + || ((__OUTPUT_BUFFER__) == LL_DAC_OUTPUT_BUFFER_DISABLE) \ + ) + +/** + * @} + */ + + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup DAC_LL_Exported_Functions + * @{ + */ + +/** @addtogroup DAC_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize registers of the selected DAC instance + * to their default reset values. + * @param DACx DAC instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: DAC registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_DAC_DeInit(DAC_TypeDef *DACx) +{ + /* Check the parameters */ + assert_param(IS_DAC_ALL_INSTANCE(DACx)); + + /* Force reset of DAC clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_DAC1); + + /* Release reset of DAC clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_DAC1); + + return SUCCESS; +} + +/** + * @brief Initialize some features of DAC instance. + * @note The setting of these parameters by function @ref LL_DAC_Init() + * is conditioned to DAC state: + * DAC instance must be disabled. + * @param DACx DAC instance + * @param DAC_Channel This parameter can be one of the following values: + * @arg @ref LL_DAC_CHANNEL_1 + * @arg @ref LL_DAC_CHANNEL_2 (1) + * + * (1) On this STM32 serie, parameter not available on all devices. + * Refer to device datasheet for channels availability. + * @param DAC_InitStruct Pointer to a @ref LL_DAC_InitTypeDef structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: DAC registers are initialized + * - ERROR: DAC registers are not initialized + */ +ErrorStatus LL_DAC_Init(DAC_TypeDef *DACx, uint32_t DAC_Channel, LL_DAC_InitTypeDef *DAC_InitStruct) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_DAC_ALL_INSTANCE(DACx)); + assert_param(IS_LL_DAC_CHANNEL(DACx, DAC_Channel)); + assert_param(IS_LL_DAC_TRIGGER_SOURCE(DAC_InitStruct->TriggerSource)); + assert_param(IS_LL_DAC_OUTPUT_BUFFER(DAC_InitStruct->OutputBuffer)); +#if defined(DAC_CR_WAVE1) + assert_param(IS_LL_DAC_WAVE_AUTO_GENER_MODE(DAC_InitStruct->WaveAutoGeneration)); + if (DAC_InitStruct->WaveAutoGeneration != LL_DAC_WAVE_AUTO_GENERATION_NONE) + { + assert_param(IS_LL_DAC_WAVE_AUTO_GENER_CONFIG(DAC_InitStruct->WaveAutoGenerationConfig)); + } +#endif + + /* Note: Hardware constraint (refer to description of this function) */ + /* DAC instance must be disabled. */ + if(LL_DAC_IsEnabled(DACx, DAC_Channel) == 0U) + { + /* Configuration of DAC channel: */ + /* - TriggerSource */ +#if defined(DAC_CR_WAVE1) + /* - WaveAutoGeneration */ +#endif + /* - OutputBuffer */ +#if defined(DAC_CR_WAVE1) + if (DAC_InitStruct->WaveAutoGeneration != LL_DAC_WAVE_AUTO_GENERATION_NONE) + { + MODIFY_REG(DACx->CR, + ( DAC_CR_TSEL1 + | DAC_CR_WAVE1 + | DAC_CR_MAMP1 + | DAC_CR_BOFF1 + ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + , + ( DAC_InitStruct->TriggerSource + | DAC_InitStruct->WaveAutoGeneration + | DAC_InitStruct->WaveAutoGenerationConfig + | DAC_InitStruct->OutputBuffer + ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + ); + } + else + { + MODIFY_REG(DACx->CR, + ( DAC_CR_TSEL1 + | DAC_CR_WAVE1 + | DAC_CR_BOFF1 + ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + , + ( DAC_InitStruct->TriggerSource + | LL_DAC_WAVE_AUTO_GENERATION_NONE + | DAC_InitStruct->OutputBuffer + ) << (DAC_Channel & DAC_CR_CHX_BITOFFSET_MASK) + ); + } +#endif + } + else + { + /* Initialization error: DAC instance is not disabled. */ + status = ERROR; + } + return status; +} + +/** + * @brief Set each @ref LL_DAC_InitTypeDef field to default value. + * @param DAC_InitStruct pointer to a @ref LL_DAC_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ +void LL_DAC_StructInit(LL_DAC_InitTypeDef *DAC_InitStruct) +{ + /* Set DAC_InitStruct fields to default values */ + DAC_InitStruct->TriggerSource = LL_DAC_TRIG_SOFTWARE; +#if defined(DAC_CR_WAVE1) + DAC_InitStruct->WaveAutoGeneration = LL_DAC_WAVE_AUTO_GENERATION_NONE; + /* Note: Parameter discarded if wave auto generation is disabled, */ + /* set anyway to its default value. */ + DAC_InitStruct->WaveAutoGenerationConfig = LL_DAC_NOISE_LFSR_UNMASK_BIT0; +#endif + DAC_InitStruct->OutputBuffer = LL_DAC_OUTPUT_BUFFER_ENABLE; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* DAC1 */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dma.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dma.c new file mode 100644 index 0000000..502d9a0 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_dma.c @@ -0,0 +1,397 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_dma.c + * @author MCD Application Team + * @brief DMA LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_dma.h" +#include "stm32f0xx_ll_bus.h" +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (DMA1) || defined (DMA2) + +/** @defgroup DMA_LL DMA + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup DMA_LL_Private_Macros + * @{ + */ +#define IS_LL_DMA_DIRECTION(__VALUE__) (((__VALUE__) == LL_DMA_DIRECTION_PERIPH_TO_MEMORY) || \ + ((__VALUE__) == LL_DMA_DIRECTION_MEMORY_TO_PERIPH) || \ + ((__VALUE__) == LL_DMA_DIRECTION_MEMORY_TO_MEMORY)) + +#define IS_LL_DMA_MODE(__VALUE__) (((__VALUE__) == LL_DMA_MODE_NORMAL) || \ + ((__VALUE__) == LL_DMA_MODE_CIRCULAR)) + +#define IS_LL_DMA_PERIPHINCMODE(__VALUE__) (((__VALUE__) == LL_DMA_PERIPH_INCREMENT) || \ + ((__VALUE__) == LL_DMA_PERIPH_NOINCREMENT)) + +#define IS_LL_DMA_MEMORYINCMODE(__VALUE__) (((__VALUE__) == LL_DMA_MEMORY_INCREMENT) || \ + ((__VALUE__) == LL_DMA_MEMORY_NOINCREMENT)) + +#define IS_LL_DMA_PERIPHDATASIZE(__VALUE__) (((__VALUE__) == LL_DMA_PDATAALIGN_BYTE) || \ + ((__VALUE__) == LL_DMA_PDATAALIGN_HALFWORD) || \ + ((__VALUE__) == LL_DMA_PDATAALIGN_WORD)) + +#define IS_LL_DMA_MEMORYDATASIZE(__VALUE__) (((__VALUE__) == LL_DMA_MDATAALIGN_BYTE) || \ + ((__VALUE__) == LL_DMA_MDATAALIGN_HALFWORD) || \ + ((__VALUE__) == LL_DMA_MDATAALIGN_WORD)) + +#define IS_LL_DMA_NBDATA(__VALUE__) ((__VALUE__) <= 0x0000FFFFU) + +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) +#define IS_LL_DMA_PERIPHREQUEST(__VALUE__) (((__VALUE__) == LL_DMA_REQUEST_0) || \ + ((__VALUE__) == LL_DMA_REQUEST_1) || \ + ((__VALUE__) == LL_DMA_REQUEST_2) || \ + ((__VALUE__) == LL_DMA_REQUEST_3) || \ + ((__VALUE__) == LL_DMA_REQUEST_4) || \ + ((__VALUE__) == LL_DMA_REQUEST_5) || \ + ((__VALUE__) == LL_DMA_REQUEST_6) || \ + ((__VALUE__) == LL_DMA_REQUEST_7) || \ + ((__VALUE__) == LL_DMA_REQUEST_8) || \ + ((__VALUE__) == LL_DMA_REQUEST_9) || \ + ((__VALUE__) == LL_DMA_REQUEST_10) || \ + ((__VALUE__) == LL_DMA_REQUEST_11) || \ + ((__VALUE__) == LL_DMA_REQUEST_12) || \ + ((__VALUE__) == LL_DMA_REQUEST_13) || \ + ((__VALUE__) == LL_DMA_REQUEST_14) || \ + ((__VALUE__) == LL_DMA_REQUEST_15)) +#endif + +#define IS_LL_DMA_PRIORITY(__VALUE__) (((__VALUE__) == LL_DMA_PRIORITY_LOW) || \ + ((__VALUE__) == LL_DMA_PRIORITY_MEDIUM) || \ + ((__VALUE__) == LL_DMA_PRIORITY_HIGH) || \ + ((__VALUE__) == LL_DMA_PRIORITY_VERYHIGH)) + +#if defined (DMA2) +#if defined (DMA2_Channel6) && defined (DMA2_Channel7) +#define IS_LL_DMA_ALL_CHANNEL_INSTANCE(INSTANCE, CHANNEL) ((((INSTANCE) == DMA1) && \ + (((CHANNEL) == LL_DMA_CHANNEL_1) || \ + ((CHANNEL) == LL_DMA_CHANNEL_2) || \ + ((CHANNEL) == LL_DMA_CHANNEL_3) || \ + ((CHANNEL) == LL_DMA_CHANNEL_4) || \ + ((CHANNEL) == LL_DMA_CHANNEL_5) || \ + ((CHANNEL) == LL_DMA_CHANNEL_6) || \ + ((CHANNEL) == LL_DMA_CHANNEL_7))) || \ + (((INSTANCE) == DMA2) && \ + (((CHANNEL) == LL_DMA_CHANNEL_1) || \ + ((CHANNEL) == LL_DMA_CHANNEL_2) || \ + ((CHANNEL) == LL_DMA_CHANNEL_3) || \ + ((CHANNEL) == LL_DMA_CHANNEL_4) || \ + ((CHANNEL) == LL_DMA_CHANNEL_5) || \ + ((CHANNEL) == LL_DMA_CHANNEL_6) || \ + ((CHANNEL) == LL_DMA_CHANNEL_7)))) +#else +#define IS_LL_DMA_ALL_CHANNEL_INSTANCE(INSTANCE, CHANNEL) ((((INSTANCE) == DMA1) && \ + (((CHANNEL) == LL_DMA_CHANNEL_1) || \ + ((CHANNEL) == LL_DMA_CHANNEL_2) || \ + ((CHANNEL) == LL_DMA_CHANNEL_3) || \ + ((CHANNEL) == LL_DMA_CHANNEL_4) || \ + ((CHANNEL) == LL_DMA_CHANNEL_5) || \ + ((CHANNEL) == LL_DMA_CHANNEL_6) || \ + ((CHANNEL) == LL_DMA_CHANNEL_7))) || \ + (((INSTANCE) == DMA2) && \ + (((CHANNEL) == LL_DMA_CHANNEL_1) || \ + ((CHANNEL) == LL_DMA_CHANNEL_2) || \ + ((CHANNEL) == LL_DMA_CHANNEL_3) || \ + ((CHANNEL) == LL_DMA_CHANNEL_4) || \ + ((CHANNEL) == LL_DMA_CHANNEL_5)))) +#endif +#else +#if defined(DMA1_Channel6) && defined(DMA1_Channel7) +#define IS_LL_DMA_ALL_CHANNEL_INSTANCE(INSTANCE, CHANNEL) ((((INSTANCE) == DMA1) && \ + (((CHANNEL) == LL_DMA_CHANNEL_1)|| \ + ((CHANNEL) == LL_DMA_CHANNEL_2) || \ + ((CHANNEL) == LL_DMA_CHANNEL_3) || \ + ((CHANNEL) == LL_DMA_CHANNEL_4) || \ + ((CHANNEL) == LL_DMA_CHANNEL_5) || \ + ((CHANNEL) == LL_DMA_CHANNEL_6) || \ + ((CHANNEL) == LL_DMA_CHANNEL_7)))) +#elif defined (DMA1_Channel6) +#define IS_LL_DMA_ALL_CHANNEL_INSTANCE(INSTANCE, CHANNEL) ((((INSTANCE) == DMA1) && \ + (((CHANNEL) == LL_DMA_CHANNEL_1)|| \ + ((CHANNEL) == LL_DMA_CHANNEL_2) || \ + ((CHANNEL) == LL_DMA_CHANNEL_3) || \ + ((CHANNEL) == LL_DMA_CHANNEL_4) || \ + ((CHANNEL) == LL_DMA_CHANNEL_5) || \ + ((CHANNEL) == LL_DMA_CHANNEL_6)))) +#else +#define IS_LL_DMA_ALL_CHANNEL_INSTANCE(INSTANCE, CHANNEL) ((((INSTANCE) == DMA1) && \ + (((CHANNEL) == LL_DMA_CHANNEL_1)|| \ + ((CHANNEL) == LL_DMA_CHANNEL_2) || \ + ((CHANNEL) == LL_DMA_CHANNEL_3) || \ + ((CHANNEL) == LL_DMA_CHANNEL_4) || \ + ((CHANNEL) == LL_DMA_CHANNEL_5)))) +#endif /* DMA1_Channel6 && DMA1_Channel7 */ +#endif +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup DMA_LL_Exported_Functions + * @{ + */ + +/** @addtogroup DMA_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize the DMA registers to their default reset values. + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 (*) + * @arg @ref LL_DMA_CHANNEL_7 (*) + * + * (*) value not defined in all devices + * @retval An ErrorStatus enumeration value: + * - SUCCESS: DMA registers are de-initialized + * - ERROR: DMA registers are not de-initialized + */ +uint32_t LL_DMA_DeInit(DMA_TypeDef *DMAx, uint32_t Channel) +{ + DMA_Channel_TypeDef *tmp = (DMA_Channel_TypeDef *)DMA1_Channel1; + ErrorStatus status = SUCCESS; + + /* Check the DMA Instance DMAx and Channel parameters*/ + assert_param(IS_LL_DMA_ALL_CHANNEL_INSTANCE(DMAx, Channel)); + + tmp = (DMA_Channel_TypeDef *)(__LL_DMA_GET_CHANNEL_INSTANCE(DMAx, Channel)); + + /* Disable the selected DMAx_Channely */ + CLEAR_BIT(tmp->CCR, DMA_CCR_EN); + + /* Reset DMAx_Channely control register */ + LL_DMA_WriteReg(tmp, CCR, 0U); + + /* Reset DMAx_Channely remaining bytes register */ + LL_DMA_WriteReg(tmp, CNDTR, 0U); + + /* Reset DMAx_Channely peripheral address register */ + LL_DMA_WriteReg(tmp, CPAR, 0U); + + /* Reset DMAx_Channely memory address register */ + LL_DMA_WriteReg(tmp, CMAR, 0U); + +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) + /* Reset Request register field for DMAx Channel */ + LL_DMA_SetPeriphRequest(DMAx, Channel, LL_DMA_REQUEST_0); +#endif + + if (Channel == LL_DMA_CHANNEL_1) + { + /* Reset interrupt pending bits for DMAx Channel1 */ + LL_DMA_ClearFlag_GI1(DMAx); + } + else if (Channel == LL_DMA_CHANNEL_2) + { + /* Reset interrupt pending bits for DMAx Channel2 */ + LL_DMA_ClearFlag_GI2(DMAx); + } + else if (Channel == LL_DMA_CHANNEL_3) + { + /* Reset interrupt pending bits for DMAx Channel3 */ + LL_DMA_ClearFlag_GI3(DMAx); + } + else if (Channel == LL_DMA_CHANNEL_4) + { + /* Reset interrupt pending bits for DMAx Channel4 */ + LL_DMA_ClearFlag_GI4(DMAx); + } + else if (Channel == LL_DMA_CHANNEL_5) + { + /* Reset interrupt pending bits for DMAx Channel5 */ + LL_DMA_ClearFlag_GI5(DMAx); + } + +#if defined(DMA1_Channel6) + else if (Channel == LL_DMA_CHANNEL_6) + { + /* Reset interrupt pending bits for DMAx Channel6 */ + LL_DMA_ClearFlag_GI6(DMAx); + } +#endif +#if defined(DMA1_Channel7) + else if (Channel == LL_DMA_CHANNEL_7) + { + /* Reset interrupt pending bits for DMAx Channel7 */ + LL_DMA_ClearFlag_GI7(DMAx); + } +#endif + else + { + status = ERROR; + } + + return status; +} + +/** + * @brief Initialize the DMA registers according to the specified parameters in DMA_InitStruct. + * @note To convert DMAx_Channely Instance to DMAx Instance and Channely, use helper macros : + * @arg @ref __LL_DMA_GET_INSTANCE + * @arg @ref __LL_DMA_GET_CHANNEL + * @param DMAx DMAx Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_DMA_CHANNEL_1 + * @arg @ref LL_DMA_CHANNEL_2 + * @arg @ref LL_DMA_CHANNEL_3 + * @arg @ref LL_DMA_CHANNEL_4 + * @arg @ref LL_DMA_CHANNEL_5 + * @arg @ref LL_DMA_CHANNEL_6 (*) + * @arg @ref LL_DMA_CHANNEL_7 (*) + * + * (*) value not defined in all devices + * @param DMA_InitStruct pointer to a @ref LL_DMA_InitTypeDef structure. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: DMA registers are initialized + * - ERROR: Not applicable + */ +uint32_t LL_DMA_Init(DMA_TypeDef *DMAx, uint32_t Channel, LL_DMA_InitTypeDef *DMA_InitStruct) +{ + /* Check the DMA Instance DMAx and Channel parameters*/ + assert_param(IS_LL_DMA_ALL_CHANNEL_INSTANCE(DMAx, Channel)); + + /* Check the DMA parameters from DMA_InitStruct */ + assert_param(IS_LL_DMA_DIRECTION(DMA_InitStruct->Direction)); + assert_param(IS_LL_DMA_MODE(DMA_InitStruct->Mode)); + assert_param(IS_LL_DMA_PERIPHINCMODE(DMA_InitStruct->PeriphOrM2MSrcIncMode)); + assert_param(IS_LL_DMA_MEMORYINCMODE(DMA_InitStruct->MemoryOrM2MDstIncMode)); + assert_param(IS_LL_DMA_PERIPHDATASIZE(DMA_InitStruct->PeriphOrM2MSrcDataSize)); + assert_param(IS_LL_DMA_MEMORYDATASIZE(DMA_InitStruct->MemoryOrM2MDstDataSize)); + assert_param(IS_LL_DMA_NBDATA(DMA_InitStruct->NbData)); +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) + assert_param(IS_LL_DMA_PERIPHREQUEST(DMA_InitStruct->PeriphRequest)); +#endif + assert_param(IS_LL_DMA_PRIORITY(DMA_InitStruct->Priority)); + + /*---------------------------- DMAx CCR Configuration ------------------------ + * Configure DMAx_Channely: data transfer direction, data transfer mode, + * peripheral and memory increment mode, + * data size alignment and priority level with parameters : + * - Direction: DMA_CCR_DIR and DMA_CCR_MEM2MEM bits + * - Mode: DMA_CCR_CIRC bit + * - PeriphOrM2MSrcIncMode: DMA_CCR_PINC bit + * - MemoryOrM2MDstIncMode: DMA_CCR_MINC bit + * - PeriphOrM2MSrcDataSize: DMA_CCR_PSIZE[1:0] bits + * - MemoryOrM2MDstDataSize: DMA_CCR_MSIZE[1:0] bits + * - Priority: DMA_CCR_PL[1:0] bits + */ + LL_DMA_ConfigTransfer(DMAx, Channel, DMA_InitStruct->Direction | \ + DMA_InitStruct->Mode | \ + DMA_InitStruct->PeriphOrM2MSrcIncMode | \ + DMA_InitStruct->MemoryOrM2MDstIncMode | \ + DMA_InitStruct->PeriphOrM2MSrcDataSize | \ + DMA_InitStruct->MemoryOrM2MDstDataSize | \ + DMA_InitStruct->Priority); + + /*-------------------------- DMAx CMAR Configuration ------------------------- + * Configure the memory or destination base address with parameter : + * - MemoryOrM2MDstAddress: DMA_CMAR_MA[31:0] bits + */ + LL_DMA_SetMemoryAddress(DMAx, Channel, DMA_InitStruct->MemoryOrM2MDstAddress); + + /*-------------------------- DMAx CPAR Configuration ------------------------- + * Configure the peripheral or source base address with parameter : + * - PeriphOrM2MSrcAddress: DMA_CPAR_PA[31:0] bits + */ + LL_DMA_SetPeriphAddress(DMAx, Channel, DMA_InitStruct->PeriphOrM2MSrcAddress); + + /*--------------------------- DMAx CNDTR Configuration ----------------------- + * Configure the peripheral base address with parameter : + * - NbData: DMA_CNDTR_NDT[15:0] bits + */ + LL_DMA_SetDataLength(DMAx, Channel, DMA_InitStruct->NbData); + +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) + /*--------------------------- DMAx CSELR Configuration ----------------------- + * Configure the DMA request for DMA instance on Channel x with parameter : + * - PeriphRequest: DMA_CSELR[31:0] bits + */ + LL_DMA_SetPeriphRequest(DMAx, Channel, DMA_InitStruct->PeriphRequest); +#endif + + return SUCCESS; +} + +/** + * @brief Set each @ref LL_DMA_InitTypeDef field to default value. + * @param DMA_InitStruct Pointer to a @ref LL_DMA_InitTypeDef structure. + * @retval None + */ +void LL_DMA_StructInit(LL_DMA_InitTypeDef *DMA_InitStruct) +{ + /* Set DMA_InitStruct fields to default values */ + DMA_InitStruct->PeriphOrM2MSrcAddress = 0x00000000U; + DMA_InitStruct->MemoryOrM2MDstAddress = 0x00000000U; + DMA_InitStruct->Direction = LL_DMA_DIRECTION_PERIPH_TO_MEMORY; + DMA_InitStruct->Mode = LL_DMA_MODE_NORMAL; + DMA_InitStruct->PeriphOrM2MSrcIncMode = LL_DMA_PERIPH_NOINCREMENT; + DMA_InitStruct->MemoryOrM2MDstIncMode = LL_DMA_MEMORY_NOINCREMENT; + DMA_InitStruct->PeriphOrM2MSrcDataSize = LL_DMA_PDATAALIGN_BYTE; + DMA_InitStruct->MemoryOrM2MDstDataSize = LL_DMA_MDATAALIGN_BYTE; + DMA_InitStruct->NbData = 0x00000000U; +#if (defined(DMA1_CSELR_DEFAULT)||defined(DMA2_CSELR_DEFAULT)) + DMA_InitStruct->PeriphRequest = LL_DMA_REQUEST_0; +#endif + DMA_InitStruct->Priority = LL_DMA_PRIORITY_LOW; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* DMA1 || DMA2 */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_exti.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_exti.c new file mode 100644 index 0000000..2832037 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_exti.c @@ -0,0 +1,223 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_exti.c + * @author MCD Application Team + * @brief EXTI LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_exti.h" +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (EXTI) + +/** @defgroup EXTI_LL EXTI + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup EXTI_LL_Private_Macros + * @{ + */ + +#define IS_LL_EXTI_LINE_0_31(__VALUE__) (((__VALUE__) & ~LL_EXTI_LINE_ALL_0_31) == 0x00000000U) + +#define IS_LL_EXTI_MODE(__VALUE__) (((__VALUE__) == LL_EXTI_MODE_IT) \ + || ((__VALUE__) == LL_EXTI_MODE_EVENT) \ + || ((__VALUE__) == LL_EXTI_MODE_IT_EVENT)) + + +#define IS_LL_EXTI_TRIGGER(__VALUE__) (((__VALUE__) == LL_EXTI_TRIGGER_NONE) \ + || ((__VALUE__) == LL_EXTI_TRIGGER_RISING) \ + || ((__VALUE__) == LL_EXTI_TRIGGER_FALLING) \ + || ((__VALUE__) == LL_EXTI_TRIGGER_RISING_FALLING)) + +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup EXTI_LL_Exported_Functions + * @{ + */ + +/** @addtogroup EXTI_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize the EXTI registers to their default reset values. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: EXTI registers are de-initialized + * - ERROR: not applicable + */ +uint32_t LL_EXTI_DeInit(void) +{ + /* Interrupt mask register set to default reset values */ +#if defined(STM32F030x6) || defined(STM32F031x6) ||defined(STM32F038xx) + LL_EXTI_WriteReg(IMR, 0x0FF40000U); +#elif defined(STM32F070x6) || defined(STM32F042x6) || defined(STM32F048xx) + LL_EXTI_WriteReg(IMR, 0x7FF40000U); +#elif defined(STM32F030x8) || defined(STM32F051x8) || defined(STM32F058xx) + LL_EXTI_WriteReg(IMR, 0x0F940000U); +#else + LL_EXTI_WriteReg(IMR, 0x7F840000U); +#endif + /* Event mask register set to default reset values */ + LL_EXTI_WriteReg(EMR, 0x00000000U); + /* Rising Trigger selection register set to default reset values */ + LL_EXTI_WriteReg(RTSR, 0x00000000U); + /* Falling Trigger selection register set to default reset values */ + LL_EXTI_WriteReg(FTSR, 0x00000000U); + /* Software interrupt event register set to default reset values */ + LL_EXTI_WriteReg(SWIER, 0x00000000U); + /* Pending register clear */ + LL_EXTI_WriteReg(PR, 0x007BFFFFU); + + return SUCCESS; +} + +/** + * @brief Initialize the EXTI registers according to the specified parameters in EXTI_InitStruct. + * @param EXTI_InitStruct pointer to a @ref LL_EXTI_InitTypeDef structure. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: EXTI registers are initialized + * - ERROR: not applicable + */ +uint32_t LL_EXTI_Init(LL_EXTI_InitTypeDef *EXTI_InitStruct) +{ + ErrorStatus status = SUCCESS; + /* Check the parameters */ + assert_param(IS_LL_EXTI_LINE_0_31(EXTI_InitStruct->Line_0_31)); + assert_param(IS_FUNCTIONAL_STATE(EXTI_InitStruct->LineCommand)); + assert_param(IS_LL_EXTI_MODE(EXTI_InitStruct->Mode)); + + /* ENABLE LineCommand */ + if (EXTI_InitStruct->LineCommand != DISABLE) + { + assert_param(IS_LL_EXTI_TRIGGER(EXTI_InitStruct->Trigger)); + + /* Configure EXTI Lines in range from 0 to 31 */ + if (EXTI_InitStruct->Line_0_31 != LL_EXTI_LINE_NONE) + { + switch (EXTI_InitStruct->Mode) + { + case LL_EXTI_MODE_IT: + /* First Disable Event on provided Lines */ + LL_EXTI_DisableEvent_0_31(EXTI_InitStruct->Line_0_31); + /* Then Enable IT on provided Lines */ + LL_EXTI_EnableIT_0_31(EXTI_InitStruct->Line_0_31); + break; + case LL_EXTI_MODE_EVENT: + /* First Disable IT on provided Lines */ + LL_EXTI_DisableIT_0_31(EXTI_InitStruct->Line_0_31); + /* Then Enable Event on provided Lines */ + LL_EXTI_EnableEvent_0_31(EXTI_InitStruct->Line_0_31); + break; + case LL_EXTI_MODE_IT_EVENT: + /* Directly Enable IT & Event on provided Lines */ + LL_EXTI_EnableIT_0_31(EXTI_InitStruct->Line_0_31); + LL_EXTI_EnableEvent_0_31(EXTI_InitStruct->Line_0_31); + break; + default: + status = ERROR; + break; + } + if (EXTI_InitStruct->Trigger != LL_EXTI_TRIGGER_NONE) + { + switch (EXTI_InitStruct->Trigger) + { + case LL_EXTI_TRIGGER_RISING: + /* First Disable Falling Trigger on provided Lines */ + LL_EXTI_DisableFallingTrig_0_31(EXTI_InitStruct->Line_0_31); + /* Then Enable Rising Trigger on provided Lines */ + LL_EXTI_EnableRisingTrig_0_31(EXTI_InitStruct->Line_0_31); + break; + case LL_EXTI_TRIGGER_FALLING: + /* First Disable Rising Trigger on provided Lines */ + LL_EXTI_DisableRisingTrig_0_31(EXTI_InitStruct->Line_0_31); + /* Then Enable Falling Trigger on provided Lines */ + LL_EXTI_EnableFallingTrig_0_31(EXTI_InitStruct->Line_0_31); + break; + case LL_EXTI_TRIGGER_RISING_FALLING: + LL_EXTI_EnableRisingTrig_0_31(EXTI_InitStruct->Line_0_31); + LL_EXTI_EnableFallingTrig_0_31(EXTI_InitStruct->Line_0_31); + break; + default: + status = ERROR; + break; + } + } + } + } + /* DISABLE LineCommand */ + else + { + /* De-configure EXTI Lines in range from 0 to 31 */ + LL_EXTI_DisableIT_0_31(EXTI_InitStruct->Line_0_31); + LL_EXTI_DisableEvent_0_31(EXTI_InitStruct->Line_0_31); + } + return status; +} + +/** + * @brief Set each @ref LL_EXTI_InitTypeDef field to default value. + * @param EXTI_InitStruct Pointer to a @ref LL_EXTI_InitTypeDef structure. + * @retval None + */ +void LL_EXTI_StructInit(LL_EXTI_InitTypeDef *EXTI_InitStruct) +{ + EXTI_InitStruct->Line_0_31 = LL_EXTI_LINE_NONE; + EXTI_InitStruct->LineCommand = DISABLE; + EXTI_InitStruct->Mode = LL_EXTI_MODE_IT; + EXTI_InitStruct->Trigger = LL_EXTI_TRIGGER_FALLING; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined (EXTI) */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_gpio.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_gpio.c new file mode 100644 index 0000000..f5c4cc9 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_gpio.c @@ -0,0 +1,277 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_gpio.c + * @author MCD Application Team + * @brief GPIO LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_gpio.h" +#include "stm32f0xx_ll_bus.h" +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (GPIOA) || defined (GPIOB) || defined (GPIOC) || defined (GPIOD) || defined (GPIOE) || defined (GPIOF) + +/** @addtogroup GPIO_LL + * @{ + */ +/** MISRA C:2012 deviation rule has been granted for following rules: + * Rule-12.2 - Medium: RHS argument is in interval [0,INF] which is out of + * range of the shift operator in following API : + * LL_GPIO_Init + * LL_GPIO_DeInit + * LL_GPIO_SetPinMode + * LL_GPIO_GetPinMode + * LL_GPIO_SetPinSpeed + * LL_GPIO_GetPinSpeed + * LL_GPIO_SetPinPull + * LL_GPIO_GetPinPull + * LL_GPIO_GetAFPin_0_7 + * LL_GPIO_SetAFPin_0_7 + * LL_GPIO_SetAFPin_8_15 + * LL_GPIO_GetAFPin_8_15 + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup GPIO_LL_Private_Macros + * @{ + */ +#define IS_LL_GPIO_PIN(__VALUE__) (((0x00u) < (__VALUE__)) && ((__VALUE__) <= (LL_GPIO_PIN_ALL))) + +#define IS_LL_GPIO_MODE(__VALUE__) (((__VALUE__) == LL_GPIO_MODE_INPUT) ||\ + ((__VALUE__) == LL_GPIO_MODE_OUTPUT) ||\ + ((__VALUE__) == LL_GPIO_MODE_ALTERNATE) ||\ + ((__VALUE__) == LL_GPIO_MODE_ANALOG)) + +#define IS_LL_GPIO_OUTPUT_TYPE(__VALUE__) (((__VALUE__) == LL_GPIO_OUTPUT_PUSHPULL) ||\ + ((__VALUE__) == LL_GPIO_OUTPUT_OPENDRAIN)) + +#define IS_LL_GPIO_SPEED(__VALUE__) (((__VALUE__) == LL_GPIO_SPEED_FREQ_LOW) ||\ + ((__VALUE__) == LL_GPIO_SPEED_FREQ_MEDIUM) ||\ + ((__VALUE__) == LL_GPIO_SPEED_FREQ_HIGH)) + +#define IS_LL_GPIO_PULL(__VALUE__) (((__VALUE__) == LL_GPIO_PULL_NO) ||\ + ((__VALUE__) == LL_GPIO_PULL_UP) ||\ + ((__VALUE__) == LL_GPIO_PULL_DOWN)) + +#define IS_LL_GPIO_ALTERNATE(__VALUE__) (((__VALUE__) == LL_GPIO_AF_0 ) ||\ + ((__VALUE__) == LL_GPIO_AF_1 ) ||\ + ((__VALUE__) == LL_GPIO_AF_2 ) ||\ + ((__VALUE__) == LL_GPIO_AF_3 ) ||\ + ((__VALUE__) == LL_GPIO_AF_4 ) ||\ + ((__VALUE__) == LL_GPIO_AF_5 ) ||\ + ((__VALUE__) == LL_GPIO_AF_6 ) ||\ + ((__VALUE__) == LL_GPIO_AF_7 )) +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup GPIO_LL_Exported_Functions + * @{ + */ + +/** @addtogroup GPIO_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize GPIO registers (Registers restored to their default values). + * @param GPIOx GPIO Port + * @retval An ErrorStatus enumeration value: + * - SUCCESS: GPIO registers are de-initialized + * - ERROR: Wrong GPIO Port + */ +ErrorStatus LL_GPIO_DeInit(GPIO_TypeDef *GPIOx) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_GPIO_ALL_INSTANCE(GPIOx)); + + /* Force and Release reset on clock of GPIOx Port */ + if (GPIOx == GPIOA) + { + LL_AHB1_GRP1_ForceReset(LL_AHB1_GRP1_PERIPH_GPIOA); + LL_AHB1_GRP1_ReleaseReset(LL_AHB1_GRP1_PERIPH_GPIOA); + } + else if (GPIOx == GPIOB) + { + LL_AHB1_GRP1_ForceReset(LL_AHB1_GRP1_PERIPH_GPIOB); + LL_AHB1_GRP1_ReleaseReset(LL_AHB1_GRP1_PERIPH_GPIOB); + } + else if (GPIOx == GPIOC) + { + LL_AHB1_GRP1_ForceReset(LL_AHB1_GRP1_PERIPH_GPIOC); + LL_AHB1_GRP1_ReleaseReset(LL_AHB1_GRP1_PERIPH_GPIOC); + } +#if defined(GPIOD) + else if (GPIOx == GPIOD) + { + LL_AHB1_GRP1_ForceReset(LL_AHB1_GRP1_PERIPH_GPIOD); + LL_AHB1_GRP1_ReleaseReset(LL_AHB1_GRP1_PERIPH_GPIOD); + } +#endif /* GPIOD */ +#if defined(GPIOE) + else if (GPIOx == GPIOE) + { + LL_AHB1_GRP1_ForceReset(LL_AHB1_GRP1_PERIPH_GPIOE); + LL_AHB1_GRP1_ReleaseReset(LL_AHB1_GRP1_PERIPH_GPIOE); + } +#endif /* GPIOE */ +#if defined(GPIOF) + else if (GPIOx == GPIOF) + { + LL_AHB1_GRP1_ForceReset(LL_AHB1_GRP1_PERIPH_GPIOF); + LL_AHB1_GRP1_ReleaseReset(LL_AHB1_GRP1_PERIPH_GPIOF); + } +#endif /* GPIOF */ + else + { + status = ERROR; + } + + return (status); +} + +/** + * @brief Initialize GPIO registers according to the specified parameters in GPIO_InitStruct. + * @param GPIOx GPIO Port + * @param GPIO_InitStruct pointer to a @ref LL_GPIO_InitTypeDef structure + * that contains the configuration information for the specified GPIO peripheral. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: GPIO registers are initialized according to GPIO_InitStruct content + * - ERROR: Not applicable + */ +ErrorStatus LL_GPIO_Init(GPIO_TypeDef *GPIOx, LL_GPIO_InitTypeDef *GPIO_InitStruct) +{ + uint32_t pinpos; + uint32_t currentpin; + + /* Check the parameters */ + assert_param(IS_GPIO_ALL_INSTANCE(GPIOx)); + assert_param(IS_LL_GPIO_PIN(GPIO_InitStruct->Pin)); + assert_param(IS_LL_GPIO_MODE(GPIO_InitStruct->Mode)); + assert_param(IS_LL_GPIO_PULL(GPIO_InitStruct->Pull)); + + /* ------------------------- Configure the port pins ---------------- */ + /* Initialize pinpos on first pin set */ + pinpos = 0; + + /* Configure the port pins */ + while (((GPIO_InitStruct->Pin) >> pinpos) != 0x00u) + { + /* Get current io position */ + currentpin = (GPIO_InitStruct->Pin) & (0x00000001uL << pinpos); + + if (currentpin != 0x00u) + { + if ((GPIO_InitStruct->Mode == LL_GPIO_MODE_OUTPUT) || (GPIO_InitStruct->Mode == LL_GPIO_MODE_ALTERNATE)) + { + /* Check Speed mode parameters */ + assert_param(IS_LL_GPIO_SPEED(GPIO_InitStruct->Speed)); + + /* Speed mode configuration */ + LL_GPIO_SetPinSpeed(GPIOx, currentpin, GPIO_InitStruct->Speed); + + /* Check Output mode parameters */ + assert_param(IS_LL_GPIO_OUTPUT_TYPE(GPIO_InitStruct->OutputType)); + + /* Output mode configuration*/ + LL_GPIO_SetPinOutputType(GPIOx, GPIO_InitStruct->Pin, GPIO_InitStruct->OutputType); + } + + /* Pull-up Pull down resistor configuration*/ + LL_GPIO_SetPinPull(GPIOx, currentpin, GPIO_InitStruct->Pull); + + if (GPIO_InitStruct->Mode == LL_GPIO_MODE_ALTERNATE) + { + /* Check Alternate parameter */ + assert_param(IS_LL_GPIO_ALTERNATE(GPIO_InitStruct->Alternate)); + + /* Speed mode configuration */ + if (currentpin < LL_GPIO_PIN_8) + { + LL_GPIO_SetAFPin_0_7(GPIOx, currentpin, GPIO_InitStruct->Alternate); + } + else + { + LL_GPIO_SetAFPin_8_15(GPIOx, currentpin, GPIO_InitStruct->Alternate); + } + } + + /* Pin Mode configuration */ + LL_GPIO_SetPinMode(GPIOx, currentpin, GPIO_InitStruct->Mode); + } + pinpos++; + } + + return (SUCCESS); +} + +/** + * @brief Set each @ref LL_GPIO_InitTypeDef field to default value. + * @param GPIO_InitStruct pointer to a @ref LL_GPIO_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ + +void LL_GPIO_StructInit(LL_GPIO_InitTypeDef *GPIO_InitStruct) +{ + /* Reset GPIO init structure parameters values */ + GPIO_InitStruct->Pin = LL_GPIO_PIN_ALL; + GPIO_InitStruct->Mode = LL_GPIO_MODE_ANALOG; + GPIO_InitStruct->Speed = LL_GPIO_SPEED_FREQ_LOW; + GPIO_InitStruct->OutputType = LL_GPIO_OUTPUT_PUSHPULL; + GPIO_InitStruct->Pull = LL_GPIO_PULL_NO; + GPIO_InitStruct->Alternate = LL_GPIO_AF_0; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined (GPIOA) || defined (GPIOB) || defined (GPIOC) || defined (GPIOD) || defined (GPIOE) || defined (GPIOF) */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_i2c.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_i2c.c new file mode 100644 index 0000000..a79d30a --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_i2c.c @@ -0,0 +1,229 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_i2c.c + * @author MCD Application Team + * @brief I2C LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_i2c.h" +#include "stm32f0xx_ll_bus.h" +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (I2C1) || defined (I2C2) + +/** @defgroup I2C_LL I2C + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup I2C_LL_Private_Macros + * @{ + */ + +#define IS_LL_I2C_PERIPHERAL_MODE(__VALUE__) (((__VALUE__) == LL_I2C_MODE_I2C) || \ + ((__VALUE__) == LL_I2C_MODE_SMBUS_HOST) || \ + ((__VALUE__) == LL_I2C_MODE_SMBUS_DEVICE) || \ + ((__VALUE__) == LL_I2C_MODE_SMBUS_DEVICE_ARP)) + +#define IS_LL_I2C_ANALOG_FILTER(__VALUE__) (((__VALUE__) == LL_I2C_ANALOGFILTER_ENABLE) || \ + ((__VALUE__) == LL_I2C_ANALOGFILTER_DISABLE)) + +#define IS_LL_I2C_DIGITAL_FILTER(__VALUE__) ((__VALUE__) <= 0x0000000FU) + +#define IS_LL_I2C_OWN_ADDRESS1(__VALUE__) ((__VALUE__) <= 0x000003FFU) + +#define IS_LL_I2C_TYPE_ACKNOWLEDGE(__VALUE__) (((__VALUE__) == LL_I2C_ACK) || \ + ((__VALUE__) == LL_I2C_NACK)) + +#define IS_LL_I2C_OWN_ADDRSIZE(__VALUE__) (((__VALUE__) == LL_I2C_OWNADDRESS1_7BIT) || \ + ((__VALUE__) == LL_I2C_OWNADDRESS1_10BIT)) +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup I2C_LL_Exported_Functions + * @{ + */ + +/** @addtogroup I2C_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize the I2C registers to their default reset values. + * @param I2Cx I2C Instance. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: I2C registers are de-initialized + * - ERROR: I2C registers are not de-initialized + */ +ErrorStatus LL_I2C_DeInit(I2C_TypeDef *I2Cx) +{ + ErrorStatus status = SUCCESS; + + /* Check the I2C Instance I2Cx */ + assert_param(IS_I2C_ALL_INSTANCE(I2Cx)); + + if (I2Cx == I2C1) + { + /* Force reset of I2C clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_I2C1); + + /* Release reset of I2C clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_I2C1); + } +#if defined(I2C2) + else if (I2Cx == I2C2) + { + /* Force reset of I2C clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_I2C2); + + /* Release reset of I2C clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_I2C2); + + } +#endif /* I2C2 */ + else + { + status = ERROR; + } + + return status; +} + +/** + * @brief Initialize the I2C registers according to the specified parameters in I2C_InitStruct. + * @param I2Cx I2C Instance. + * @param I2C_InitStruct pointer to a @ref LL_I2C_InitTypeDef structure. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: I2C registers are initialized + * - ERROR: Not applicable + */ +ErrorStatus LL_I2C_Init(I2C_TypeDef *I2Cx, LL_I2C_InitTypeDef *I2C_InitStruct) +{ + /* Check the I2C Instance I2Cx */ + assert_param(IS_I2C_ALL_INSTANCE(I2Cx)); + + /* Check the I2C parameters from I2C_InitStruct */ + assert_param(IS_LL_I2C_PERIPHERAL_MODE(I2C_InitStruct->PeripheralMode)); + assert_param(IS_LL_I2C_ANALOG_FILTER(I2C_InitStruct->AnalogFilter)); + assert_param(IS_LL_I2C_DIGITAL_FILTER(I2C_InitStruct->DigitalFilter)); + assert_param(IS_LL_I2C_OWN_ADDRESS1(I2C_InitStruct->OwnAddress1)); + assert_param(IS_LL_I2C_TYPE_ACKNOWLEDGE(I2C_InitStruct->TypeAcknowledge)); + assert_param(IS_LL_I2C_OWN_ADDRSIZE(I2C_InitStruct->OwnAddrSize)); + + /* Disable the selected I2Cx Peripheral */ + LL_I2C_Disable(I2Cx); + + /*---------------------------- I2Cx CR1 Configuration ------------------------ + * Configure the analog and digital noise filters with parameters : + * - AnalogFilter: I2C_CR1_ANFOFF bit + * - DigitalFilter: I2C_CR1_DNF[3:0] bits + */ + LL_I2C_ConfigFilters(I2Cx, I2C_InitStruct->AnalogFilter, I2C_InitStruct->DigitalFilter); + + /*---------------------------- I2Cx TIMINGR Configuration -------------------- + * Configure the SDA setup, hold time and the SCL high, low period with parameter : + * - Timing: I2C_TIMINGR_PRESC[3:0], I2C_TIMINGR_SCLDEL[3:0], I2C_TIMINGR_SDADEL[3:0], + * I2C_TIMINGR_SCLH[7:0] and I2C_TIMINGR_SCLL[7:0] bits + */ + LL_I2C_SetTiming(I2Cx, I2C_InitStruct->Timing); + + /* Enable the selected I2Cx Peripheral */ + LL_I2C_Enable(I2Cx); + + /*---------------------------- I2Cx OAR1 Configuration ----------------------- + * Disable, Configure and Enable I2Cx device own address 1 with parameters : + * - OwnAddress1: I2C_OAR1_OA1[9:0] bits + * - OwnAddrSize: I2C_OAR1_OA1MODE bit + */ + LL_I2C_DisableOwnAddress1(I2Cx); + LL_I2C_SetOwnAddress1(I2Cx, I2C_InitStruct->OwnAddress1, I2C_InitStruct->OwnAddrSize); + + /* OwnAdress1 == 0 is reserved for General Call address */ + if (I2C_InitStruct->OwnAddress1 != 0U) + { + LL_I2C_EnableOwnAddress1(I2Cx); + } + + /*---------------------------- I2Cx MODE Configuration ----------------------- + * Configure I2Cx peripheral mode with parameter : + * - PeripheralMode: I2C_CR1_SMBDEN and I2C_CR1_SMBHEN bits + */ + LL_I2C_SetMode(I2Cx, I2C_InitStruct->PeripheralMode); + + /*---------------------------- I2Cx CR2 Configuration ------------------------ + * Configure the ACKnowledge or Non ACKnowledge condition + * after the address receive match code or next received byte with parameter : + * - TypeAcknowledge: I2C_CR2_NACK bit + */ + LL_I2C_AcknowledgeNextData(I2Cx, I2C_InitStruct->TypeAcknowledge); + + return SUCCESS; +} + +/** + * @brief Set each @ref LL_I2C_InitTypeDef field to default value. + * @param I2C_InitStruct Pointer to a @ref LL_I2C_InitTypeDef structure. + * @retval None + */ +void LL_I2C_StructInit(LL_I2C_InitTypeDef *I2C_InitStruct) +{ + /* Set I2C_InitStruct fields to default values */ + I2C_InitStruct->PeripheralMode = LL_I2C_MODE_I2C; + I2C_InitStruct->Timing = 0U; + I2C_InitStruct->AnalogFilter = LL_I2C_ANALOGFILTER_ENABLE; + I2C_InitStruct->DigitalFilter = 0U; + I2C_InitStruct->OwnAddress1 = 0U; + I2C_InitStruct->TypeAcknowledge = LL_I2C_NACK; + I2C_InitStruct->OwnAddrSize = LL_I2C_OWNADDRESS1_7BIT; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* I2C1 || I2C2 */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_pwr.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_pwr.c new file mode 100644 index 0000000..2ffb50d --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_pwr.c @@ -0,0 +1,86 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_pwr.c + * @author MCD Application Team + * @brief PWR LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_pwr.h" +#include "stm32f0xx_ll_bus.h" + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(PWR) + +/** @defgroup PWR_LL PWR + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup PWR_LL_Exported_Functions + * @{ + */ + +/** @addtogroup PWR_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize the PWR registers to their default reset values. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: PWR registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_PWR_DeInit(void) +{ + /* Force reset of PWR clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_PWR); + + /* Release reset of PWR clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_PWR); + + return SUCCESS; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* defined(PWR) */ +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rcc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rcc.c new file mode 100644 index 0000000..83fe3e5 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rcc.c @@ -0,0 +1,609 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_rcc.c + * @author MCD Application Team + * @brief RCC LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_rcc.h" +#ifdef USE_FULL_ASSERT + #include "stm32_assert.h" +#else + #define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(RCC) + +/** @defgroup RCC_LL RCC + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup RCC_LL_Private_Macros + * @{ + */ +#if defined(RCC_CFGR3_USART2SW) && defined(RCC_CFGR3_USART3SW) +#define IS_LL_RCC_USART_CLKSOURCE(__VALUE__) (((__VALUE__) == LL_RCC_USART1_CLKSOURCE) \ + || ((__VALUE__) == LL_RCC_USART2_CLKSOURCE) \ + || ((__VALUE__) == LL_RCC_USART3_CLKSOURCE)) +#elif defined(RCC_CFGR3_USART2SW) && !defined(RCC_CFGR3_USART3SW) +#define IS_LL_RCC_USART_CLKSOURCE(__VALUE__) (((__VALUE__) == LL_RCC_USART1_CLKSOURCE) \ + || ((__VALUE__) == LL_RCC_USART2_CLKSOURCE)) +#elif defined(RCC_CFGR3_USART3SW) && !defined(RCC_CFGR3_USART2SW) +#define IS_LL_RCC_USART_CLKSOURCE(__VALUE__) (((__VALUE__) == LL_RCC_USART1_CLKSOURCE) \ + || ((__VALUE__) == LL_RCC_USART3_CLKSOURCE)) +#else +#define IS_LL_RCC_USART_CLKSOURCE(__VALUE__) (((__VALUE__) == LL_RCC_USART1_CLKSOURCE)) +#endif /* RCC_CFGR3_USART2SW && RCC_CFGR3_USART3SW */ + +#define IS_LL_RCC_I2C_CLKSOURCE(__VALUE__) ((__VALUE__) == LL_RCC_I2C1_CLKSOURCE) + +#if defined(USB) +#define IS_LL_RCC_USB_CLKSOURCE(__VALUE__) (((__VALUE__) == LL_RCC_USB_CLKSOURCE)) +#endif /* USB */ + +#if defined(CEC) +#define IS_LL_RCC_CEC_CLKSOURCE(__VALUE__) (((__VALUE__) == LL_RCC_CEC_CLKSOURCE)) +#endif /* CEC */ + +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup RCC_LL_Private_Functions RCC Private functions + * @{ + */ +uint32_t RCC_GetSystemClockFreq(void); +uint32_t RCC_GetHCLKClockFreq(uint32_t SYSCLK_Frequency); +uint32_t RCC_GetPCLK1ClockFreq(uint32_t HCLK_Frequency); +uint32_t RCC_PLL_GetFreqDomain_SYS(void); +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup RCC_LL_Exported_Functions + * @{ + */ + +/** @addtogroup RCC_LL_EF_Init + * @{ + */ + +/** + * @brief Reset the RCC clock configuration to the default reset state. + * @note The default reset state of the clock configuration is given below: + * - HSI ON and used as system clock source + * - HSE and PLL OFF + * - AHB and APB1 prescaler set to 1. + * - CSS, MCO OFF + * - All interrupts disabled + * @note This function doesn't modify the configuration of the + * - Peripheral clocks + * - LSI, LSE and RTC clocks + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RCC registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_RCC_DeInit(void) +{ + __IO uint32_t vl_mask; + + /* Set HSION bit */ + LL_RCC_HSI_Enable(); + + /* Wait for HSI READY bit */ + while(LL_RCC_HSI_IsReady() != 1U) + {} + + /* Set HSITRIM bits to the reset value*/ + LL_RCC_HSI_SetCalibTrimming(0x10U); + + /* Reset SW, HPRE, PPRE and MCOSEL bits */ + vl_mask = 0xFFFFFFFFU; + CLEAR_BIT(vl_mask, (RCC_CFGR_SW | RCC_CFGR_HPRE | RCC_CFGR_PPRE | RCC_CFGR_MCOSEL)); + + /* Write new value in CFGR register */ + LL_RCC_WriteReg(CFGR, vl_mask); + + /* Wait till system clock source is ready */ + while(LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_HSI) + {} + + /* Read CR register */ + vl_mask = LL_RCC_ReadReg(CR); + + /* Reset HSEON, CSSON, PLLON bits */ + CLEAR_BIT(vl_mask, (RCC_CR_PLLON | RCC_CR_CSSON | RCC_CR_HSEON)); + + /* Write new value in CR register */ + LL_RCC_WriteReg(CR, vl_mask); + + /* Wait for PLL READY bit to be reset */ + while(LL_RCC_PLL_IsReady() != 0U) + {} + + /* Reset HSEBYP bit */ + LL_RCC_HSE_DisableBypass(); + + /* Reset CFGR register */ + LL_RCC_WriteReg(CFGR, 0x00000000U); + +#if defined(RCC_HSI48_SUPPORT) + /* Reset CR2 register */ + LL_RCC_WriteReg(CR2, 0x00000000U); + + /* Disable HSI48 */ + LL_RCC_HSI48_Disable(); + +#endif /*RCC_HSI48_SUPPORT*/ + /* Set HSI14TRIM/HSI14ON/HSI14DIS bits to the reset value*/ + LL_RCC_HSI14_SetCalibTrimming(0x10U); + LL_RCC_HSI14_Disable(); + LL_RCC_HSI14_EnableADCControl(); + + /* Reset CFGR2 register */ + LL_RCC_WriteReg(CFGR2, 0x00000000U); + + /* Reset CFGR3 register */ + LL_RCC_WriteReg(CFGR3, 0x00000000U); + + /* Clear pending flags */ +#if defined(RCC_HSI48_SUPPORT) + vl_mask = (LL_RCC_CIR_LSIRDYC | LL_RCC_CIR_LSERDYC | LL_RCC_CIR_HSIRDYC | LL_RCC_CIR_HSERDYC |\ + LL_RCC_CIR_PLLRDYC | LL_RCC_CIR_HSI14RDYC | LL_RCC_CIR_HSI48RDYC | LL_RCC_CIR_CSSC); +#else + vl_mask = (LL_RCC_CIR_LSIRDYC | LL_RCC_CIR_LSERDYC | LL_RCC_CIR_HSIRDYC | LL_RCC_CIR_HSERDYC |\ + LL_RCC_CIR_PLLRDYC | LL_RCC_CIR_HSI14RDYC | LL_RCC_CIR_CSSC); +#endif /* RCC_HSI48_SUPPORT */ + + /* Write new value in CIR register */ + LL_RCC_WriteReg(CIR, vl_mask); + + /* Disable all interrupts */ + LL_RCC_WriteReg(CIR, 0x00000000U); + + /* Clear reset flags */ + LL_RCC_ClearResetFlags(); + + return SUCCESS; +} + +/** + * @} + */ + +/** @addtogroup RCC_LL_EF_Get_Freq + * @brief Return the frequencies of different on chip clocks; System, AHB and APB1 buses clocks + * and different peripheral clocks available on the device. + * @note If SYSCLK source is HSI, function returns values based on HSI_VALUE(**) + * @note If SYSCLK source is HSE, function returns values based on HSE_VALUE(***) + * @note If SYSCLK source is PLL, function returns values based on + * HSI_VALUE(**) or HSE_VALUE(***) multiplied/divided by the PLL factors. + * @note (**) HSI_VALUE is a defined constant but the real value may vary + * depending on the variations in voltage and temperature. + * @note (***) HSE_VALUE is a defined constant, user has to ensure that + * HSE_VALUE is same as the real frequency of the crystal used. + * Otherwise, this function may have wrong result. + * @note The result of this function could be incorrect when using fractional + * value for HSE crystal. + * @note This function can be used by the user application to compute the + * baud-rate for the communication peripherals or configure other parameters. + * @{ + */ + +/** + * @brief Return the frequencies of different on chip clocks; System, AHB and APB1 buses clocks + * @note Each time SYSCLK, HCLK and/or PCLK1 clock changes, this function + * must be called to update structure fields. Otherwise, any + * configuration based on this function will be incorrect. + * @param RCC_Clocks pointer to a @ref LL_RCC_ClocksTypeDef structure which will hold the clocks frequencies + * @retval None + */ +void LL_RCC_GetSystemClocksFreq(LL_RCC_ClocksTypeDef *RCC_Clocks) +{ + /* Get SYSCLK frequency */ + RCC_Clocks->SYSCLK_Frequency = RCC_GetSystemClockFreq(); + + /* HCLK clock frequency */ + RCC_Clocks->HCLK_Frequency = RCC_GetHCLKClockFreq(RCC_Clocks->SYSCLK_Frequency); + + /* PCLK1 clock frequency */ + RCC_Clocks->PCLK1_Frequency = RCC_GetPCLK1ClockFreq(RCC_Clocks->HCLK_Frequency); +} + +/** + * @brief Return USARTx clock frequency + * @param USARTxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_USART1_CLKSOURCE + * @arg @ref LL_RCC_USART2_CLKSOURCE (*) + * @arg @ref LL_RCC_USART3_CLKSOURCE (*) + * + * (*) value not defined in all devices. + * @retval USART clock frequency (in Hz) + * @arg @ref LL_RCC_PERIPH_FREQUENCY_NO indicates that oscillator (HSI or LSE) is not ready + */ +uint32_t LL_RCC_GetUSARTClockFreq(uint32_t USARTxSource) +{ + uint32_t usart_frequency = LL_RCC_PERIPH_FREQUENCY_NO; + + /* Check parameter */ + assert_param(IS_LL_RCC_USART_CLKSOURCE(USARTxSource)); +#if defined(RCC_CFGR3_USART1SW) + if (USARTxSource == LL_RCC_USART1_CLKSOURCE) + { + /* USART1CLK clock frequency */ + switch (LL_RCC_GetUSARTClockSource(USARTxSource)) + { + case LL_RCC_USART1_CLKSOURCE_SYSCLK: /* USART1 Clock is System Clock */ + usart_frequency = RCC_GetSystemClockFreq(); + break; + + case LL_RCC_USART1_CLKSOURCE_HSI: /* USART1 Clock is HSI Osc. */ + if (LL_RCC_HSI_IsReady()) + { + usart_frequency = HSI_VALUE; + } + break; + + case LL_RCC_USART1_CLKSOURCE_LSE: /* USART1 Clock is LSE Osc. */ + if (LL_RCC_LSE_IsReady()) + { + usart_frequency = LSE_VALUE; + } + break; + + case LL_RCC_USART1_CLKSOURCE_PCLK1: /* USART1 Clock is PCLK1 */ + default: + usart_frequency = RCC_GetPCLK1ClockFreq(RCC_GetHCLKClockFreq(RCC_GetSystemClockFreq())); + break; + } + } +#endif /* RCC_CFGR3_USART1SW */ + +#if defined(RCC_CFGR3_USART2SW) + if (USARTxSource == LL_RCC_USART2_CLKSOURCE) + { + /* USART2CLK clock frequency */ + switch (LL_RCC_GetUSARTClockSource(USARTxSource)) + { + case LL_RCC_USART2_CLKSOURCE_SYSCLK: /* USART2 Clock is System Clock */ + usart_frequency = RCC_GetSystemClockFreq(); + break; + + case LL_RCC_USART2_CLKSOURCE_HSI: /* USART2 Clock is HSI Osc. */ + if (LL_RCC_HSI_IsReady()) + { + usart_frequency = HSI_VALUE; + } + break; + + case LL_RCC_USART2_CLKSOURCE_LSE: /* USART2 Clock is LSE Osc. */ + if (LL_RCC_LSE_IsReady()) + { + usart_frequency = LSE_VALUE; + } + break; + + case LL_RCC_USART2_CLKSOURCE_PCLK1: /* USART2 Clock is PCLK1 */ + default: + usart_frequency = RCC_GetPCLK1ClockFreq(RCC_GetHCLKClockFreq(RCC_GetSystemClockFreq())); + break; + } + } +#endif /* RCC_CFGR3_USART2SW */ + +#if defined(RCC_CFGR3_USART3SW) + if (USARTxSource == LL_RCC_USART3_CLKSOURCE) + { + /* USART3CLK clock frequency */ + switch (LL_RCC_GetUSARTClockSource(USARTxSource)) + { + case LL_RCC_USART3_CLKSOURCE_SYSCLK: /* USART3 Clock is System Clock */ + usart_frequency = RCC_GetSystemClockFreq(); + break; + + case LL_RCC_USART3_CLKSOURCE_HSI: /* USART3 Clock is HSI Osc. */ + if (LL_RCC_HSI_IsReady()) + { + usart_frequency = HSI_VALUE; + } + break; + + case LL_RCC_USART3_CLKSOURCE_LSE: /* USART3 Clock is LSE Osc. */ + if (LL_RCC_LSE_IsReady()) + { + usart_frequency = LSE_VALUE; + } + break; + + case LL_RCC_USART3_CLKSOURCE_PCLK1: /* USART3 Clock is PCLK1 */ + default: + usart_frequency = RCC_GetPCLK1ClockFreq(RCC_GetHCLKClockFreq(RCC_GetSystemClockFreq())); + break; + } + } + +#endif /* RCC_CFGR3_USART3SW */ + return usart_frequency; +} + +/** + * @brief Return I2Cx clock frequency + * @param I2CxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_I2C1_CLKSOURCE + * @retval I2C clock frequency (in Hz) + * @arg @ref LL_RCC_PERIPH_FREQUENCY_NO indicates that HSI oscillator is not ready + */ +uint32_t LL_RCC_GetI2CClockFreq(uint32_t I2CxSource) +{ + uint32_t i2c_frequency = LL_RCC_PERIPH_FREQUENCY_NO; + + /* Check parameter */ + assert_param(IS_LL_RCC_I2C_CLKSOURCE(I2CxSource)); + + /* I2C1 CLK clock frequency */ + if (I2CxSource == LL_RCC_I2C1_CLKSOURCE) + { + switch (LL_RCC_GetI2CClockSource(I2CxSource)) + { + case LL_RCC_I2C1_CLKSOURCE_SYSCLK: /* I2C1 Clock is System Clock */ + i2c_frequency = RCC_GetSystemClockFreq(); + break; + + case LL_RCC_I2C1_CLKSOURCE_HSI: /* I2C1 Clock is HSI Osc. */ + default: + if (LL_RCC_HSI_IsReady()) + { + i2c_frequency = HSI_VALUE; + } + break; + } + } + + return i2c_frequency; +} + +#if defined(USB) +/** + * @brief Return USBx clock frequency + * @param USBxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_USB_CLKSOURCE + * @retval USB clock frequency (in Hz) + * @arg @ref LL_RCC_PERIPH_FREQUENCY_NO indicates that oscillator (HSI48) or PLL is not ready + * @arg @ref LL_RCC_PERIPH_FREQUENCY_NA indicates that no clock source selected + */ +uint32_t LL_RCC_GetUSBClockFreq(uint32_t USBxSource) +{ + uint32_t usb_frequency = LL_RCC_PERIPH_FREQUENCY_NO; + + /* Check parameter */ + assert_param(IS_LL_RCC_USB_CLKSOURCE(USBxSource)); + + /* USBCLK clock frequency */ + switch (LL_RCC_GetUSBClockSource(USBxSource)) + { + case LL_RCC_USB_CLKSOURCE_PLL: /* PLL clock used as USB clock source */ + if (LL_RCC_PLL_IsReady()) + { + usb_frequency = RCC_PLL_GetFreqDomain_SYS(); + } + break; + +#if defined(RCC_CFGR3_USBSW_HSI48) + case LL_RCC_USB_CLKSOURCE_HSI48: /* HSI48 clock used as USB clock source */ + default: + if (LL_RCC_HSI48_IsReady()) + { + usb_frequency = HSI48_VALUE; + } + break; +#else + case LL_RCC_USB_CLKSOURCE_NONE: /* No clock used as USB clock source */ + default: + usb_frequency = LL_RCC_PERIPH_FREQUENCY_NA; + break; +#endif /* RCC_CFGR3_USBSW_HSI48 */ + } + + return usb_frequency; +} +#endif /* USB */ + +#if defined(CEC) +/** + * @brief Return CECx clock frequency + * @param CECxSource This parameter can be one of the following values: + * @arg @ref LL_RCC_CEC_CLKSOURCE + * @retval CEC clock frequency (in Hz) + * @arg @ref LL_RCC_PERIPH_FREQUENCY_NO indicates that oscillators (HSI or LSE) are not ready + */ +uint32_t LL_RCC_GetCECClockFreq(uint32_t CECxSource) +{ + uint32_t cec_frequency = LL_RCC_PERIPH_FREQUENCY_NO; + + /* Check parameter */ + assert_param(IS_LL_RCC_CEC_CLKSOURCE(CECxSource)); + + /* CECCLK clock frequency */ + switch (LL_RCC_GetCECClockSource(CECxSource)) + { + case LL_RCC_CEC_CLKSOURCE_HSI_DIV244: /* HSI / 244 clock used as CEC clock source */ + if (LL_RCC_HSI_IsReady()) + { + cec_frequency = HSI_VALUE / 244U; + } + break; + + case LL_RCC_CEC_CLKSOURCE_LSE: /* LSE clock used as CEC clock source */ + default: + if (LL_RCC_LSE_IsReady()) + { + cec_frequency = LSE_VALUE; + } + break; + } + + return cec_frequency; +} +#endif /* CEC */ + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup RCC_LL_Private_Functions + * @{ + */ + +/** + * @brief Return SYSTEM clock frequency + * @retval SYSTEM clock frequency (in Hz) + */ +uint32_t RCC_GetSystemClockFreq(void) +{ + uint32_t frequency = 0U; + + /* Get SYSCLK source -------------------------------------------------------*/ + switch (LL_RCC_GetSysClkSource()) + { + case LL_RCC_SYS_CLKSOURCE_STATUS_HSI: /* HSI used as system clock source */ + frequency = HSI_VALUE; + break; + + case LL_RCC_SYS_CLKSOURCE_STATUS_HSE: /* HSE used as system clock source */ + frequency = HSE_VALUE; + break; + + case LL_RCC_SYS_CLKSOURCE_STATUS_PLL: /* PLL used as system clock source */ + frequency = RCC_PLL_GetFreqDomain_SYS(); + break; + +#if defined(RCC_HSI48_SUPPORT) + case LL_RCC_SYS_CLKSOURCE_STATUS_HSI48:/* HSI48 used as system clock source */ + frequency = HSI48_VALUE; + break; +#endif /* RCC_HSI48_SUPPORT */ + + default: + frequency = HSI_VALUE; + break; + } + + return frequency; +} + +/** + * @brief Return HCLK clock frequency + * @param SYSCLK_Frequency SYSCLK clock frequency + * @retval HCLK clock frequency (in Hz) + */ +uint32_t RCC_GetHCLKClockFreq(uint32_t SYSCLK_Frequency) +{ + /* HCLK clock frequency */ + return __LL_RCC_CALC_HCLK_FREQ(SYSCLK_Frequency, LL_RCC_GetAHBPrescaler()); +} + +/** + * @brief Return PCLK1 clock frequency + * @param HCLK_Frequency HCLK clock frequency + * @retval PCLK1 clock frequency (in Hz) + */ +uint32_t RCC_GetPCLK1ClockFreq(uint32_t HCLK_Frequency) +{ + /* PCLK1 clock frequency */ + return __LL_RCC_CALC_PCLK1_FREQ(HCLK_Frequency, LL_RCC_GetAPB1Prescaler()); +} +/** + * @brief Return PLL clock frequency used for system domain + * @retval PLL clock frequency (in Hz) + */ +uint32_t RCC_PLL_GetFreqDomain_SYS(void) +{ + uint32_t pllinputfreq = 0U, pllsource = 0U; + + /* PLL_VCO = (HSE_VALUE or HSI_VALUE / PLL divider) * PLL Multiplicator */ + + /* Get PLL source */ + pllsource = LL_RCC_PLL_GetMainSource(); + + switch (pllsource) + { +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + case LL_RCC_PLLSOURCE_HSI: /* HSI used as PLL clock source */ + pllinputfreq = HSI_VALUE; +#else + case LL_RCC_PLLSOURCE_HSI_DIV_2: /* HSI used as PLL clock source */ + pllinputfreq = HSI_VALUE / 2U; +#endif /* RCC_PLLSRC_PREDIV1_SUPPORT */ + break; + +#if defined(RCC_HSI48_SUPPORT) + case LL_RCC_PLLSOURCE_HSI48: /* HSI48 used as PLL clock source */ + pllinputfreq = HSI48_VALUE; + break; +#endif /* RCC_HSI48_SUPPORT */ + + case LL_RCC_PLLSOURCE_HSE: /* HSE used as PLL clock source */ + pllinputfreq = HSE_VALUE; + break; + + default: +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + pllinputfreq = HSI_VALUE; +#else + pllinputfreq = HSI_VALUE / 2U; +#endif /* RCC_PLLSRC_PREDIV1_SUPPORT */ + break; + } +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + return __LL_RCC_CALC_PLLCLK_FREQ(pllinputfreq, LL_RCC_PLL_GetMultiplicator(), LL_RCC_PLL_GetPrediv()); +#else + return __LL_RCC_CALC_PLLCLK_FREQ((pllinputfreq / (LL_RCC_PLL_GetPrediv() + 1U)), LL_RCC_PLL_GetMultiplicator()); +#endif /* RCC_PLLSRC_PREDIV1_SUPPORT */ +} +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(RCC) */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rtc.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rtc.c new file mode 100644 index 0000000..5a7655e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_rtc.c @@ -0,0 +1,714 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_rtc.c + * @author MCD Application Team + * @brief RTC LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_rtc.h" +#include "stm32f0xx_ll_cortex.h" +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined(RTC) + +/** @addtogroup RTC_LL + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @addtogroup RTC_LL_Private_Constants + * @{ + */ +/* Default values used for prescaler */ +#define RTC_ASYNCH_PRESC_DEFAULT 0x0000007FU +#define RTC_SYNCH_PRESC_DEFAULT 0x000000FFU + +/* Values used for timeout */ +#define RTC_INITMODE_TIMEOUT 1000U /* 1s when tick set to 1ms */ +#define RTC_SYNCHRO_TIMEOUT 1000U /* 1s when tick set to 1ms */ +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup RTC_LL_Private_Macros + * @{ + */ + +#define IS_LL_RTC_HOURFORMAT(__VALUE__) (((__VALUE__) == LL_RTC_HOURFORMAT_24HOUR) \ + || ((__VALUE__) == LL_RTC_HOURFORMAT_AMPM)) + +#define IS_LL_RTC_ASYNCH_PREDIV(__VALUE__) ((__VALUE__) <= 0x7FU) + +#define IS_LL_RTC_SYNCH_PREDIV(__VALUE__) ((__VALUE__) <= 0x7FFFU) + +#define IS_LL_RTC_FORMAT(__VALUE__) (((__VALUE__) == LL_RTC_FORMAT_BIN) \ + || ((__VALUE__) == LL_RTC_FORMAT_BCD)) + +#define IS_LL_RTC_TIME_FORMAT(__VALUE__) (((__VALUE__) == LL_RTC_TIME_FORMAT_AM_OR_24) \ + || ((__VALUE__) == LL_RTC_TIME_FORMAT_PM)) + +#define IS_LL_RTC_HOUR12(__HOUR__) (((__HOUR__) > 0U) && ((__HOUR__) <= 12U)) +#define IS_LL_RTC_HOUR24(__HOUR__) ((__HOUR__) <= 23U) +#define IS_LL_RTC_MINUTES(__MINUTES__) ((__MINUTES__) <= 59U) +#define IS_LL_RTC_SECONDS(__SECONDS__) ((__SECONDS__) <= 59U) + +#define IS_LL_RTC_WEEKDAY(__VALUE__) (((__VALUE__) == LL_RTC_WEEKDAY_MONDAY) \ + || ((__VALUE__) == LL_RTC_WEEKDAY_TUESDAY) \ + || ((__VALUE__) == LL_RTC_WEEKDAY_WEDNESDAY) \ + || ((__VALUE__) == LL_RTC_WEEKDAY_THURSDAY) \ + || ((__VALUE__) == LL_RTC_WEEKDAY_FRIDAY) \ + || ((__VALUE__) == LL_RTC_WEEKDAY_SATURDAY) \ + || ((__VALUE__) == LL_RTC_WEEKDAY_SUNDAY)) + +#define IS_LL_RTC_DAY(__DAY__) (((__DAY__) >= 1U) && ((__DAY__) <= 31U)) + +#define IS_LL_RTC_MONTH(__MONTH__) (((__MONTH__) >= 1U) && ((__MONTH__) <= 12U)) + +#define IS_LL_RTC_YEAR(__YEAR__) ((__YEAR__) <= 99U) + +#define IS_LL_RTC_ALMA_MASK(__VALUE__) (((__VALUE__) == LL_RTC_ALMA_MASK_NONE) \ + || ((__VALUE__) == LL_RTC_ALMA_MASK_DATEWEEKDAY) \ + || ((__VALUE__) == LL_RTC_ALMA_MASK_HOURS) \ + || ((__VALUE__) == LL_RTC_ALMA_MASK_MINUTES) \ + || ((__VALUE__) == LL_RTC_ALMA_MASK_SECONDS) \ + || ((__VALUE__) == LL_RTC_ALMA_MASK_ALL)) + + +#define IS_LL_RTC_ALMA_DATE_WEEKDAY_SEL(__SEL__) (((__SEL__) == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE) || \ + ((__SEL__) == LL_RTC_ALMA_DATEWEEKDAYSEL_WEEKDAY)) + + +/** + * @} + */ +/* Private function prototypes -----------------------------------------------*/ +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup RTC_LL_Exported_Functions + * @{ + */ + +/** @addtogroup RTC_LL_EF_Init + * @{ + */ + +/** + * @brief De-Initializes the RTC registers to their default reset values. + * @note This function doesn't reset the RTC Clock source and RTC Backup Data + * registers. + * @param RTCx RTC Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RTC registers are de-initialized + * - ERROR: RTC registers are not de-initialized + */ +ErrorStatus LL_RTC_DeInit(RTC_TypeDef *RTCx) +{ + ErrorStatus status = ERROR; + + /* Check the parameter */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + + /* Disable the write protection for RTC registers */ + LL_RTC_DisableWriteProtection(RTCx); + + /* Set Initialization mode */ + if (LL_RTC_EnterInitMode(RTCx) != ERROR) + { + /* Reset TR, DR and CR registers */ + LL_RTC_WriteReg(RTCx, TR, 0x00000000U); +#if defined(RTC_WAKEUP_SUPPORT) + LL_RTC_WriteReg(RTCx, WUTR, RTC_WUTR_WUT); +#endif /* RTC_WAKEUP_SUPPORT */ + LL_RTC_WriteReg(RTCx, DR, (RTC_DR_WDU_0 | RTC_DR_MU_0 | RTC_DR_DU_0)); + /* Reset All CR bits except CR[2:0] */ +#if defined(RTC_WAKEUP_SUPPORT) + LL_RTC_WriteReg(RTCx, CR, (LL_RTC_ReadReg(RTCx, CR) & RTC_CR_WUCKSEL)); +#else + LL_RTC_WriteReg(RTCx, CR, 0x00000000U); +#endif /* RTC_WAKEUP_SUPPORT */ + LL_RTC_WriteReg(RTCx, PRER, (RTC_PRER_PREDIV_A | RTC_SYNCH_PRESC_DEFAULT)); + LL_RTC_WriteReg(RTCx, ALRMAR, 0x00000000U); + LL_RTC_WriteReg(RTCx, SHIFTR, 0x00000000U); + LL_RTC_WriteReg(RTCx, CALR, 0x00000000U); + LL_RTC_WriteReg(RTCx, ALRMASSR, 0x00000000U); + + /* Reset ISR register and exit initialization mode */ + LL_RTC_WriteReg(RTCx, ISR, 0x00000000U); + + /* Reset Tamper and alternate functions configuration register */ + LL_RTC_WriteReg(RTCx, TAFCR, 0x00000000U); + + /* Wait till the RTC RSF flag is set */ + status = LL_RTC_WaitForSynchro(RTCx); + } + + /* Enable the write protection for RTC registers */ + LL_RTC_EnableWriteProtection(RTCx); + + return status; +} + +/** + * @brief Initializes the RTC registers according to the specified parameters + * in RTC_InitStruct. + * @param RTCx RTC Instance + * @param RTC_InitStruct pointer to a @ref LL_RTC_InitTypeDef structure that contains + * the configuration information for the RTC peripheral. + * @note The RTC Prescaler register is write protected and can be written in + * initialization mode only. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RTC registers are initialized + * - ERROR: RTC registers are not initialized + */ +ErrorStatus LL_RTC_Init(RTC_TypeDef *RTCx, LL_RTC_InitTypeDef *RTC_InitStruct) +{ + ErrorStatus status = ERROR; + + /* Check the parameters */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + assert_param(IS_LL_RTC_HOURFORMAT(RTC_InitStruct->HourFormat)); + assert_param(IS_LL_RTC_ASYNCH_PREDIV(RTC_InitStruct->AsynchPrescaler)); + assert_param(IS_LL_RTC_SYNCH_PREDIV(RTC_InitStruct->SynchPrescaler)); + + /* Disable the write protection for RTC registers */ + LL_RTC_DisableWriteProtection(RTCx); + + /* Set Initialization mode */ + if (LL_RTC_EnterInitMode(RTCx) != ERROR) + { + /* Set Hour Format */ + LL_RTC_SetHourFormat(RTCx, RTC_InitStruct->HourFormat); + + /* Configure Synchronous and Asynchronous prescaler factor */ + LL_RTC_SetSynchPrescaler(RTCx, RTC_InitStruct->SynchPrescaler); + LL_RTC_SetAsynchPrescaler(RTCx, RTC_InitStruct->AsynchPrescaler); + + /* Exit Initialization mode */ + LL_RTC_DisableInitMode(RTCx); + + status = SUCCESS; + } + /* Enable the write protection for RTC registers */ + LL_RTC_EnableWriteProtection(RTCx); + + return status; +} + +/** + * @brief Set each @ref LL_RTC_InitTypeDef field to default value. + * @param RTC_InitStruct pointer to a @ref LL_RTC_InitTypeDef structure which will be initialized. + * @retval None + */ +void LL_RTC_StructInit(LL_RTC_InitTypeDef *RTC_InitStruct) +{ + /* Set RTC_InitStruct fields to default values */ + RTC_InitStruct->HourFormat = LL_RTC_HOURFORMAT_24HOUR; + RTC_InitStruct->AsynchPrescaler = RTC_ASYNCH_PRESC_DEFAULT; + RTC_InitStruct->SynchPrescaler = RTC_SYNCH_PRESC_DEFAULT; +} + +/** + * @brief Set the RTC current time. + * @param RTCx RTC Instance + * @param RTC_Format This parameter can be one of the following values: + * @arg @ref LL_RTC_FORMAT_BIN + * @arg @ref LL_RTC_FORMAT_BCD + * @param RTC_TimeStruct pointer to a RTC_TimeTypeDef structure that contains + * the time configuration information for the RTC. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RTC Time register is configured + * - ERROR: RTC Time register is not configured + */ +ErrorStatus LL_RTC_TIME_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_TimeTypeDef *RTC_TimeStruct) +{ + ErrorStatus status = ERROR; + + /* Check the parameters */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + assert_param(IS_LL_RTC_FORMAT(RTC_Format)); + + if (RTC_Format == LL_RTC_FORMAT_BIN) + { + if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR) + { + assert_param(IS_LL_RTC_HOUR12(RTC_TimeStruct->Hours)); + assert_param(IS_LL_RTC_TIME_FORMAT(RTC_TimeStruct->TimeFormat)); + } + else + { + RTC_TimeStruct->TimeFormat = 0x00U; + assert_param(IS_LL_RTC_HOUR24(RTC_TimeStruct->Hours)); + } + assert_param(IS_LL_RTC_MINUTES(RTC_TimeStruct->Minutes)); + assert_param(IS_LL_RTC_SECONDS(RTC_TimeStruct->Seconds)); + } + else + { + if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR) + { + assert_param(IS_LL_RTC_HOUR12(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Hours))); + assert_param(IS_LL_RTC_TIME_FORMAT(RTC_TimeStruct->TimeFormat)); + } + else + { + RTC_TimeStruct->TimeFormat = 0x00U; + assert_param(IS_LL_RTC_HOUR24(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Hours))); + } + assert_param(IS_LL_RTC_MINUTES(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Minutes))); + assert_param(IS_LL_RTC_SECONDS(__LL_RTC_CONVERT_BCD2BIN(RTC_TimeStruct->Seconds))); + } + + /* Disable the write protection for RTC registers */ + LL_RTC_DisableWriteProtection(RTCx); + + /* Set Initialization mode */ + if (LL_RTC_EnterInitMode(RTCx) != ERROR) + { + /* Check the input parameters format */ + if (RTC_Format != LL_RTC_FORMAT_BIN) + { + LL_RTC_TIME_Config(RTCx, RTC_TimeStruct->TimeFormat, RTC_TimeStruct->Hours, + RTC_TimeStruct->Minutes, RTC_TimeStruct->Seconds); + } + else + { + LL_RTC_TIME_Config(RTCx, RTC_TimeStruct->TimeFormat, __LL_RTC_CONVERT_BIN2BCD(RTC_TimeStruct->Hours), + __LL_RTC_CONVERT_BIN2BCD(RTC_TimeStruct->Minutes), + __LL_RTC_CONVERT_BIN2BCD(RTC_TimeStruct->Seconds)); + } + + /* Exit Initialization mode */ + LL_RTC_DisableInitMode(RTCx); + + /* If RTC_CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */ + if (LL_RTC_IsShadowRegBypassEnabled(RTCx) == 0U) + { + status = LL_RTC_WaitForSynchro(RTCx); + } + else + { + status = SUCCESS; + } + } + /* Enable the write protection for RTC registers */ + LL_RTC_EnableWriteProtection(RTCx); + + return status; +} + +/** + * @brief Set each @ref LL_RTC_TimeTypeDef field to default value (Time = 00h:00min:00sec). + * @param RTC_TimeStruct pointer to a @ref LL_RTC_TimeTypeDef structure which will be initialized. + * @retval None + */ +void LL_RTC_TIME_StructInit(LL_RTC_TimeTypeDef *RTC_TimeStruct) +{ + /* Time = 00h:00min:00sec */ + RTC_TimeStruct->TimeFormat = LL_RTC_TIME_FORMAT_AM_OR_24; + RTC_TimeStruct->Hours = 0U; + RTC_TimeStruct->Minutes = 0U; + RTC_TimeStruct->Seconds = 0U; +} + +/** + * @brief Set the RTC current date. + * @param RTCx RTC Instance + * @param RTC_Format This parameter can be one of the following values: + * @arg @ref LL_RTC_FORMAT_BIN + * @arg @ref LL_RTC_FORMAT_BCD + * @param RTC_DateStruct pointer to a RTC_DateTypeDef structure that contains + * the date configuration information for the RTC. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RTC Day register is configured + * - ERROR: RTC Day register is not configured + */ +ErrorStatus LL_RTC_DATE_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_DateTypeDef *RTC_DateStruct) +{ + ErrorStatus status = ERROR; + + /* Check the parameters */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + assert_param(IS_LL_RTC_FORMAT(RTC_Format)); + + if ((RTC_Format == LL_RTC_FORMAT_BIN) && ((RTC_DateStruct->Month & 0x10U) == 0x10U)) + { + RTC_DateStruct->Month = (RTC_DateStruct->Month & (uint32_t)~(0x10U)) + 0x0AU; + } + if (RTC_Format == LL_RTC_FORMAT_BIN) + { + assert_param(IS_LL_RTC_YEAR(RTC_DateStruct->Year)); + assert_param(IS_LL_RTC_MONTH(RTC_DateStruct->Month)); + assert_param(IS_LL_RTC_DAY(RTC_DateStruct->Day)); + } + else + { + assert_param(IS_LL_RTC_YEAR(__LL_RTC_CONVERT_BCD2BIN(RTC_DateStruct->Year))); + assert_param(IS_LL_RTC_MONTH(__LL_RTC_CONVERT_BCD2BIN(RTC_DateStruct->Month))); + assert_param(IS_LL_RTC_DAY(__LL_RTC_CONVERT_BCD2BIN(RTC_DateStruct->Day))); + } + assert_param(IS_LL_RTC_WEEKDAY(RTC_DateStruct->WeekDay)); + + /* Disable the write protection for RTC registers */ + LL_RTC_DisableWriteProtection(RTCx); + + /* Set Initialization mode */ + if (LL_RTC_EnterInitMode(RTCx) != ERROR) + { + /* Check the input parameters format */ + if (RTC_Format != LL_RTC_FORMAT_BIN) + { + LL_RTC_DATE_Config(RTCx, RTC_DateStruct->WeekDay, RTC_DateStruct->Day, RTC_DateStruct->Month, RTC_DateStruct->Year); + } + else + { + LL_RTC_DATE_Config(RTCx, RTC_DateStruct->WeekDay, __LL_RTC_CONVERT_BIN2BCD(RTC_DateStruct->Day), + __LL_RTC_CONVERT_BIN2BCD(RTC_DateStruct->Month), __LL_RTC_CONVERT_BIN2BCD(RTC_DateStruct->Year)); + } + + /* Exit Initialization mode */ + LL_RTC_DisableInitMode(RTCx); + + /* If RTC_CR_BYPSHAD bit = 0, wait for synchro else this check is not needed */ + if (LL_RTC_IsShadowRegBypassEnabled(RTCx) == 0U) + { + status = LL_RTC_WaitForSynchro(RTCx); + } + else + { + status = SUCCESS; + } + } + /* Enable the write protection for RTC registers */ + LL_RTC_EnableWriteProtection(RTCx); + + return status; +} + +/** + * @brief Set each @ref LL_RTC_DateTypeDef field to default value (date = Monday, January 01 xx00) + * @param RTC_DateStruct pointer to a @ref LL_RTC_DateTypeDef structure which will be initialized. + * @retval None + */ +void LL_RTC_DATE_StructInit(LL_RTC_DateTypeDef *RTC_DateStruct) +{ + /* Monday, January 01 xx00 */ + RTC_DateStruct->WeekDay = LL_RTC_WEEKDAY_MONDAY; + RTC_DateStruct->Day = 1U; + RTC_DateStruct->Month = LL_RTC_MONTH_JANUARY; + RTC_DateStruct->Year = 0U; +} + +/** + * @brief Set the RTC Alarm A. + * @note The Alarm register can only be written when the corresponding Alarm + * is disabled (Use @ref LL_RTC_ALMA_Disable function). + * @param RTCx RTC Instance + * @param RTC_Format This parameter can be one of the following values: + * @arg @ref LL_RTC_FORMAT_BIN + * @arg @ref LL_RTC_FORMAT_BCD + * @param RTC_AlarmStruct pointer to a @ref LL_RTC_AlarmTypeDef structure that + * contains the alarm configuration parameters. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: ALARMA registers are configured + * - ERROR: ALARMA registers are not configured + */ +ErrorStatus LL_RTC_ALMA_Init(RTC_TypeDef *RTCx, uint32_t RTC_Format, LL_RTC_AlarmTypeDef *RTC_AlarmStruct) +{ + /* Check the parameters */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + assert_param(IS_LL_RTC_FORMAT(RTC_Format)); + assert_param(IS_LL_RTC_ALMA_MASK(RTC_AlarmStruct->AlarmMask)); + assert_param(IS_LL_RTC_ALMA_DATE_WEEKDAY_SEL(RTC_AlarmStruct->AlarmDateWeekDaySel)); + + if (RTC_Format == LL_RTC_FORMAT_BIN) + { + if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR) + { + assert_param(IS_LL_RTC_HOUR12(RTC_AlarmStruct->AlarmTime.Hours)); + assert_param(IS_LL_RTC_TIME_FORMAT(RTC_AlarmStruct->AlarmTime.TimeFormat)); + } + else + { + RTC_AlarmStruct->AlarmTime.TimeFormat = 0x00U; + assert_param(IS_LL_RTC_HOUR24(RTC_AlarmStruct->AlarmTime.Hours)); + } + assert_param(IS_LL_RTC_MINUTES(RTC_AlarmStruct->AlarmTime.Minutes)); + assert_param(IS_LL_RTC_SECONDS(RTC_AlarmStruct->AlarmTime.Seconds)); + + if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE) + { + assert_param(IS_LL_RTC_DAY(RTC_AlarmStruct->AlarmDateWeekDay)); + } + else + { + assert_param(IS_LL_RTC_WEEKDAY(RTC_AlarmStruct->AlarmDateWeekDay)); + } + } + else + { + if (LL_RTC_GetHourFormat(RTCx) != LL_RTC_HOURFORMAT_24HOUR) + { + assert_param(IS_LL_RTC_HOUR12(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Hours))); + assert_param(IS_LL_RTC_TIME_FORMAT(RTC_AlarmStruct->AlarmTime.TimeFormat)); + } + else + { + RTC_AlarmStruct->AlarmTime.TimeFormat = 0x00U; + assert_param(IS_LL_RTC_HOUR24(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Hours))); + } + + assert_param(IS_LL_RTC_MINUTES(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Minutes))); + assert_param(IS_LL_RTC_SECONDS(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmTime.Seconds))); + + if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE) + { + assert_param(IS_LL_RTC_DAY(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmDateWeekDay))); + } + else + { + assert_param(IS_LL_RTC_WEEKDAY(__LL_RTC_CONVERT_BCD2BIN(RTC_AlarmStruct->AlarmDateWeekDay))); + } + } + + /* Disable the write protection for RTC registers */ + LL_RTC_DisableWriteProtection(RTCx); + + /* Select weekday selection */ + if (RTC_AlarmStruct->AlarmDateWeekDaySel == LL_RTC_ALMA_DATEWEEKDAYSEL_DATE) + { + /* Set the date for ALARM */ + LL_RTC_ALMA_DisableWeekday(RTCx); + if (RTC_Format != LL_RTC_FORMAT_BIN) + { + LL_RTC_ALMA_SetDay(RTCx, RTC_AlarmStruct->AlarmDateWeekDay); + } + else + { + LL_RTC_ALMA_SetDay(RTCx, __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmDateWeekDay)); + } + } + else + { + /* Set the week day for ALARM */ + LL_RTC_ALMA_EnableWeekday(RTCx); + LL_RTC_ALMA_SetWeekDay(RTCx, RTC_AlarmStruct->AlarmDateWeekDay); + } + + /* Configure the Alarm register */ + if (RTC_Format != LL_RTC_FORMAT_BIN) + { + LL_RTC_ALMA_ConfigTime(RTCx, RTC_AlarmStruct->AlarmTime.TimeFormat, RTC_AlarmStruct->AlarmTime.Hours, + RTC_AlarmStruct->AlarmTime.Minutes, RTC_AlarmStruct->AlarmTime.Seconds); + } + else + { + LL_RTC_ALMA_ConfigTime(RTCx, RTC_AlarmStruct->AlarmTime.TimeFormat, + __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Hours), + __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Minutes), + __LL_RTC_CONVERT_BIN2BCD(RTC_AlarmStruct->AlarmTime.Seconds)); + } + /* Set ALARM mask */ + LL_RTC_ALMA_SetMask(RTCx, RTC_AlarmStruct->AlarmMask); + + /* Enable the write protection for RTC registers */ + LL_RTC_EnableWriteProtection(RTCx); + + return SUCCESS; +} + +/** + * @brief Set each @ref LL_RTC_AlarmTypeDef of ALARMA field to default value (Time = 00h:00mn:00sec / + * Day = 1st day of the month/Mask = all fields are masked). + * @param RTC_AlarmStruct pointer to a @ref LL_RTC_AlarmTypeDef structure which will be initialized. + * @retval None + */ +void LL_RTC_ALMA_StructInit(LL_RTC_AlarmTypeDef *RTC_AlarmStruct) +{ + /* Alarm Time Settings : Time = 00h:00mn:00sec */ + RTC_AlarmStruct->AlarmTime.TimeFormat = LL_RTC_ALMA_TIME_FORMAT_AM; + RTC_AlarmStruct->AlarmTime.Hours = 0U; + RTC_AlarmStruct->AlarmTime.Minutes = 0U; + RTC_AlarmStruct->AlarmTime.Seconds = 0U; + + /* Alarm Day Settings : Day = 1st day of the month */ + RTC_AlarmStruct->AlarmDateWeekDaySel = LL_RTC_ALMA_DATEWEEKDAYSEL_DATE; + RTC_AlarmStruct->AlarmDateWeekDay = 1U; + + /* Alarm Masks Settings : Mask = all fields are not masked */ + RTC_AlarmStruct->AlarmMask = LL_RTC_ALMA_MASK_NONE; +} + +/** + * @brief Enters the RTC Initialization mode. + * @note The RTC Initialization mode is write protected, use the + * @ref LL_RTC_DisableWriteProtection before calling this function. + * @param RTCx RTC Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RTC is in Init mode + * - ERROR: RTC is not in Init mode + */ +ErrorStatus LL_RTC_EnterInitMode(RTC_TypeDef *RTCx) +{ + __IO uint32_t timeout = RTC_INITMODE_TIMEOUT; + ErrorStatus status = SUCCESS; + uint32_t tmp = 0U; + + /* Check the parameter */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + + /* Check if the Initialization mode is set */ + if (LL_RTC_IsActiveFlag_INIT(RTCx) == 0U) + { + /* Set the Initialization mode */ + LL_RTC_EnableInitMode(RTCx); + + /* Wait till RTC is in INIT state and if Time out is reached exit */ + tmp = LL_RTC_IsActiveFlag_INIT(RTCx); + while ((timeout != 0U) && (tmp != 1U)) + { + if (LL_SYSTICK_IsActiveCounterFlag() == 1U) + { + timeout --; + } + tmp = LL_RTC_IsActiveFlag_INIT(RTCx); + if (timeout == 0U) + { + status = ERROR; + } + } + } + return status; +} + +/** + * @brief Exit the RTC Initialization mode. + * @note When the initialization sequence is complete, the calendar restarts + * counting after 4 RTCCLK cycles. + * @note The RTC Initialization mode is write protected, use the + * @ref LL_RTC_DisableWriteProtection before calling this function. + * @param RTCx RTC Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RTC exited from in Init mode + * - ERROR: Not applicable + */ +ErrorStatus LL_RTC_ExitInitMode(RTC_TypeDef *RTCx) +{ + /* Check the parameter */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + + /* Disable initialization mode */ + LL_RTC_DisableInitMode(RTCx); + + return SUCCESS; +} + +/** + * @brief Waits until the RTC Time and Day registers (RTC_TR and RTC_DR) are + * synchronized with RTC APB clock. + * @note The RTC Resynchronization mode is write protected, use the + * @ref LL_RTC_DisableWriteProtection before calling this function. + * @note To read the calendar through the shadow registers after Calendar + * initialization, calendar update or after wakeup from low power modes + * the software must first clear the RSF flag. + * The software must then wait until it is set again before reading + * the calendar, which means that the calendar registers have been + * correctly copied into the RTC_TR and RTC_DR shadow registers. + * @param RTCx RTC Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: RTC registers are synchronised + * - ERROR: RTC registers are not synchronised + */ +ErrorStatus LL_RTC_WaitForSynchro(RTC_TypeDef *RTCx) +{ + __IO uint32_t timeout = RTC_SYNCHRO_TIMEOUT; + ErrorStatus status = SUCCESS; + uint32_t tmp = 0U; + + /* Check the parameter */ + assert_param(IS_RTC_ALL_INSTANCE(RTCx)); + + /* Clear RSF flag */ + LL_RTC_ClearFlag_RS(RTCx); + + /* Wait the registers to be synchronised */ + tmp = LL_RTC_IsActiveFlag_RS(RTCx); + while ((timeout != 0U) && (tmp != 0U)) + { + if (LL_SYSTICK_IsActiveCounterFlag() == 1U) + { + timeout--; + } + tmp = LL_RTC_IsActiveFlag_RS(RTCx); + if (timeout == 0U) + { + status = ERROR; + } + } + + if (status != ERROR) + { + timeout = RTC_SYNCHRO_TIMEOUT; + tmp = LL_RTC_IsActiveFlag_RS(RTCx); + while ((timeout != 0U) && (tmp != 1U)) + { + if (LL_SYSTICK_IsActiveCounterFlag() == 1U) + { + timeout--; + } + tmp = LL_RTC_IsActiveFlag_RS(RTCx); + if (timeout == 0U) + { + status = ERROR; + } + } + } + + return (status); +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* defined(RTC) */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_spi.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_spi.c new file mode 100644 index 0000000..f9b1eea --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_spi.c @@ -0,0 +1,537 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_spi.c + * @author MCD Application Team + * @brief SPI LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_spi.h" +#include "stm32f0xx_ll_bus.h" +#include "stm32f0xx_ll_rcc.h" + +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (SPI1) || defined (SPI2) + +/** @addtogroup SPI_LL + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup SPI_LL_Private_Constants SPI Private Constants + * @{ + */ +/* SPI registers Masks */ +#define SPI_CR1_CLEAR_MASK (SPI_CR1_CPHA | SPI_CR1_CPOL | SPI_CR1_MSTR | \ + SPI_CR1_BR | SPI_CR1_LSBFIRST | SPI_CR1_SSI | \ + SPI_CR1_SSM | SPI_CR1_RXONLY | SPI_CR1_CRCL | \ + SPI_CR1_CRCNEXT | SPI_CR1_CRCEN | SPI_CR1_BIDIOE | \ + SPI_CR1_BIDIMODE) +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup SPI_LL_Private_Macros SPI Private Macros + * @{ + */ +#define IS_LL_SPI_TRANSFER_DIRECTION(__VALUE__) (((__VALUE__) == LL_SPI_FULL_DUPLEX) \ + || ((__VALUE__) == LL_SPI_SIMPLEX_RX) \ + || ((__VALUE__) == LL_SPI_HALF_DUPLEX_RX) \ + || ((__VALUE__) == LL_SPI_HALF_DUPLEX_TX)) + +#define IS_LL_SPI_MODE(__VALUE__) (((__VALUE__) == LL_SPI_MODE_MASTER) \ + || ((__VALUE__) == LL_SPI_MODE_SLAVE)) + +#define IS_LL_SPI_DATAWIDTH(__VALUE__) (((__VALUE__) == LL_SPI_DATAWIDTH_4BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_5BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_6BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_7BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_8BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_9BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_10BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_11BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_12BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_13BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_14BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_15BIT) \ + || ((__VALUE__) == LL_SPI_DATAWIDTH_16BIT)) + +#define IS_LL_SPI_POLARITY(__VALUE__) (((__VALUE__) == LL_SPI_POLARITY_LOW) \ + || ((__VALUE__) == LL_SPI_POLARITY_HIGH)) + +#define IS_LL_SPI_PHASE(__VALUE__) (((__VALUE__) == LL_SPI_PHASE_1EDGE) \ + || ((__VALUE__) == LL_SPI_PHASE_2EDGE)) + +#define IS_LL_SPI_NSS(__VALUE__) (((__VALUE__) == LL_SPI_NSS_SOFT) \ + || ((__VALUE__) == LL_SPI_NSS_HARD_INPUT) \ + || ((__VALUE__) == LL_SPI_NSS_HARD_OUTPUT)) + +#define IS_LL_SPI_BAUDRATE(__VALUE__) (((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV2) \ + || ((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV4) \ + || ((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV8) \ + || ((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV16) \ + || ((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV32) \ + || ((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV64) \ + || ((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV128) \ + || ((__VALUE__) == LL_SPI_BAUDRATEPRESCALER_DIV256)) + +#define IS_LL_SPI_BITORDER(__VALUE__) (((__VALUE__) == LL_SPI_LSB_FIRST) \ + || ((__VALUE__) == LL_SPI_MSB_FIRST)) + +#define IS_LL_SPI_CRCCALCULATION(__VALUE__) (((__VALUE__) == LL_SPI_CRCCALCULATION_ENABLE) \ + || ((__VALUE__) == LL_SPI_CRCCALCULATION_DISABLE)) + +#define IS_LL_SPI_CRC_POLYNOMIAL(__VALUE__) ((__VALUE__) >= 0x1U) + +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup SPI_LL_Exported_Functions + * @{ + */ + +/** @addtogroup SPI_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize the SPI registers to their default reset values. + * @param SPIx SPI Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: SPI registers are de-initialized + * - ERROR: SPI registers are not de-initialized + */ +ErrorStatus LL_SPI_DeInit(SPI_TypeDef *SPIx) +{ + ErrorStatus status = ERROR; + + /* Check the parameters */ + assert_param(IS_SPI_ALL_INSTANCE(SPIx)); + +#if defined(SPI1) + if (SPIx == SPI1) + { + /* Force reset of SPI clock */ + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_SPI1); + + /* Release reset of SPI clock */ + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_SPI1); + + status = SUCCESS; + } +#endif /* SPI1 */ +#if defined(SPI2) + if (SPIx == SPI2) + { + /* Force reset of SPI clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_SPI2); + + /* Release reset of SPI clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_SPI2); + + status = SUCCESS; + } +#endif /* SPI2 */ + + return status; +} + +/** + * @brief Initialize the SPI registers according to the specified parameters in SPI_InitStruct. + * @note As some bits in SPI configuration registers can only be written when the SPI is disabled (SPI_CR1_SPE bit =0), + * SPI peripheral should be in disabled state prior calling this function. Otherwise, ERROR result will be returned. + * @param SPIx SPI Instance + * @param SPI_InitStruct pointer to a @ref LL_SPI_InitTypeDef structure + * @retval An ErrorStatus enumeration value. (Return always SUCCESS) + */ +ErrorStatus LL_SPI_Init(SPI_TypeDef *SPIx, LL_SPI_InitTypeDef *SPI_InitStruct) +{ + ErrorStatus status = ERROR; + + /* Check the SPI Instance SPIx*/ + assert_param(IS_SPI_ALL_INSTANCE(SPIx)); + + /* Check the SPI parameters from SPI_InitStruct*/ + assert_param(IS_LL_SPI_TRANSFER_DIRECTION(SPI_InitStruct->TransferDirection)); + assert_param(IS_LL_SPI_MODE(SPI_InitStruct->Mode)); + assert_param(IS_LL_SPI_DATAWIDTH(SPI_InitStruct->DataWidth)); + assert_param(IS_LL_SPI_POLARITY(SPI_InitStruct->ClockPolarity)); + assert_param(IS_LL_SPI_PHASE(SPI_InitStruct->ClockPhase)); + assert_param(IS_LL_SPI_NSS(SPI_InitStruct->NSS)); + assert_param(IS_LL_SPI_BAUDRATE(SPI_InitStruct->BaudRate)); + assert_param(IS_LL_SPI_BITORDER(SPI_InitStruct->BitOrder)); + assert_param(IS_LL_SPI_CRCCALCULATION(SPI_InitStruct->CRCCalculation)); + + if (LL_SPI_IsEnabled(SPIx) == 0x00000000U) + { + /*---------------------------- SPIx CR1 Configuration ------------------------ + * Configure SPIx CR1 with parameters: + * - TransferDirection: SPI_CR1_BIDIMODE, SPI_CR1_BIDIOE and SPI_CR1_RXONLY bits + * - Master/Slave Mode: SPI_CR1_MSTR bit + * - ClockPolarity: SPI_CR1_CPOL bit + * - ClockPhase: SPI_CR1_CPHA bit + * - NSS management: SPI_CR1_SSM bit + * - BaudRate prescaler: SPI_CR1_BR[2:0] bits + * - BitOrder: SPI_CR1_LSBFIRST bit + * - CRCCalculation: SPI_CR1_CRCEN bit + */ + MODIFY_REG(SPIx->CR1, + SPI_CR1_CLEAR_MASK, + SPI_InitStruct->TransferDirection | SPI_InitStruct->Mode | + SPI_InitStruct->ClockPolarity | SPI_InitStruct->ClockPhase | + SPI_InitStruct->NSS | SPI_InitStruct->BaudRate | + SPI_InitStruct->BitOrder | SPI_InitStruct->CRCCalculation); + + /*---------------------------- SPIx CR2 Configuration ------------------------ + * Configure SPIx CR2 with parameters: + * - DataWidth: DS[3:0] bits + * - NSS management: SSOE bit + */ + MODIFY_REG(SPIx->CR2, + SPI_CR2_DS | SPI_CR2_SSOE, + SPI_InitStruct->DataWidth | (SPI_InitStruct->NSS >> 16U)); + + /* Set Rx FIFO to Quarter (1 Byte) in case of 8 Bits mode. No DataPacking by default */ + if (SPI_InitStruct->DataWidth < LL_SPI_DATAWIDTH_9BIT) + { + LL_SPI_SetRxFIFOThreshold(SPIx, LL_SPI_RX_FIFO_TH_QUARTER); + } + + /*---------------------------- SPIx CRCPR Configuration ---------------------- + * Configure SPIx CRCPR with parameters: + * - CRCPoly: CRCPOLY[15:0] bits + */ + if (SPI_InitStruct->CRCCalculation == LL_SPI_CRCCALCULATION_ENABLE) + { + assert_param(IS_LL_SPI_CRC_POLYNOMIAL(SPI_InitStruct->CRCPoly)); + LL_SPI_SetCRCPolynomial(SPIx, SPI_InitStruct->CRCPoly); + } + status = SUCCESS; + } + +#if defined (SPI_I2S_SUPPORT) + /* Activate the SPI mode (Reset I2SMOD bit in I2SCFGR register) */ + CLEAR_BIT(SPIx->I2SCFGR, SPI_I2SCFGR_I2SMOD); +#endif /* SPI_I2S_SUPPORT */ + return status; +} + +/** + * @brief Set each @ref LL_SPI_InitTypeDef field to default value. + * @param SPI_InitStruct pointer to a @ref LL_SPI_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ +void LL_SPI_StructInit(LL_SPI_InitTypeDef *SPI_InitStruct) +{ + /* Set SPI_InitStruct fields to default values */ + SPI_InitStruct->TransferDirection = LL_SPI_FULL_DUPLEX; + SPI_InitStruct->Mode = LL_SPI_MODE_SLAVE; + SPI_InitStruct->DataWidth = LL_SPI_DATAWIDTH_8BIT; + SPI_InitStruct->ClockPolarity = LL_SPI_POLARITY_LOW; + SPI_InitStruct->ClockPhase = LL_SPI_PHASE_1EDGE; + SPI_InitStruct->NSS = LL_SPI_NSS_HARD_INPUT; + SPI_InitStruct->BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV2; + SPI_InitStruct->BitOrder = LL_SPI_MSB_FIRST; + SPI_InitStruct->CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE; + SPI_InitStruct->CRCPoly = 7U; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#if defined(SPI_I2S_SUPPORT) +/** @addtogroup I2S_LL + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup I2S_LL_Private_Constants I2S Private Constants + * @{ + */ +/* I2S registers Masks */ +#define I2S_I2SCFGR_CLEAR_MASK (SPI_I2SCFGR_CHLEN | SPI_I2SCFGR_DATLEN | \ + SPI_I2SCFGR_CKPOL | SPI_I2SCFGR_I2SSTD | \ + SPI_I2SCFGR_I2SCFG | SPI_I2SCFGR_I2SMOD ) + +#define I2S_I2SPR_CLEAR_MASK 0x0002U +/** + * @} + */ +/* Private macros ------------------------------------------------------------*/ +/** @defgroup I2S_LL_Private_Macros I2S Private Macros + * @{ + */ + +#define IS_LL_I2S_DATAFORMAT(__VALUE__) (((__VALUE__) == LL_I2S_DATAFORMAT_16B) \ + || ((__VALUE__) == LL_I2S_DATAFORMAT_16B_EXTENDED) \ + || ((__VALUE__) == LL_I2S_DATAFORMAT_24B) \ + || ((__VALUE__) == LL_I2S_DATAFORMAT_32B)) + +#define IS_LL_I2S_CPOL(__VALUE__) (((__VALUE__) == LL_I2S_POLARITY_LOW) \ + || ((__VALUE__) == LL_I2S_POLARITY_HIGH)) + +#define IS_LL_I2S_STANDARD(__VALUE__) (((__VALUE__) == LL_I2S_STANDARD_PHILIPS) \ + || ((__VALUE__) == LL_I2S_STANDARD_MSB) \ + || ((__VALUE__) == LL_I2S_STANDARD_LSB) \ + || ((__VALUE__) == LL_I2S_STANDARD_PCM_SHORT) \ + || ((__VALUE__) == LL_I2S_STANDARD_PCM_LONG)) + +#define IS_LL_I2S_MODE(__VALUE__) (((__VALUE__) == LL_I2S_MODE_SLAVE_TX) \ + || ((__VALUE__) == LL_I2S_MODE_SLAVE_RX) \ + || ((__VALUE__) == LL_I2S_MODE_MASTER_TX) \ + || ((__VALUE__) == LL_I2S_MODE_MASTER_RX)) + +#define IS_LL_I2S_MCLK_OUTPUT(__VALUE__) (((__VALUE__) == LL_I2S_MCLK_OUTPUT_ENABLE) \ + || ((__VALUE__) == LL_I2S_MCLK_OUTPUT_DISABLE)) + +#define IS_LL_I2S_AUDIO_FREQ(__VALUE__) ((((__VALUE__) >= LL_I2S_AUDIOFREQ_8K) \ + && ((__VALUE__) <= LL_I2S_AUDIOFREQ_192K)) \ + || ((__VALUE__) == LL_I2S_AUDIOFREQ_DEFAULT)) + +#define IS_LL_I2S_PRESCALER_LINEAR(__VALUE__) ((__VALUE__) >= 0x2U) + +#define IS_LL_I2S_PRESCALER_PARITY(__VALUE__) (((__VALUE__) == LL_I2S_PRESCALER_PARITY_EVEN) \ + || ((__VALUE__) == LL_I2S_PRESCALER_PARITY_ODD)) +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup I2S_LL_Exported_Functions + * @{ + */ + +/** @addtogroup I2S_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize the SPI/I2S registers to their default reset values. + * @param SPIx SPI Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: SPI registers are de-initialized + * - ERROR: SPI registers are not de-initialized + */ +ErrorStatus LL_I2S_DeInit(SPI_TypeDef *SPIx) +{ + return LL_SPI_DeInit(SPIx); +} + +/** + * @brief Initializes the SPI/I2S registers according to the specified parameters in I2S_InitStruct. + * @note As some bits in SPI configuration registers can only be written when the SPI is disabled (SPI_CR1_SPE bit =0), + * SPI peripheral should be in disabled state prior calling this function. Otherwise, ERROR result will be returned. + * @param SPIx SPI Instance + * @param I2S_InitStruct pointer to a @ref LL_I2S_InitTypeDef structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: SPI registers are Initialized + * - ERROR: SPI registers are not Initialized + */ +ErrorStatus LL_I2S_Init(SPI_TypeDef *SPIx, LL_I2S_InitTypeDef *I2S_InitStruct) +{ + uint32_t i2sdiv = 2U; + uint32_t i2sodd = 0U; + uint32_t packetlength = 1U; + uint32_t tmp; + LL_RCC_ClocksTypeDef rcc_clocks; + uint32_t sourceclock; + ErrorStatus status = ERROR; + + /* Check the I2S parameters */ + assert_param(IS_I2S_ALL_INSTANCE(SPIx)); + assert_param(IS_LL_I2S_MODE(I2S_InitStruct->Mode)); + assert_param(IS_LL_I2S_STANDARD(I2S_InitStruct->Standard)); + assert_param(IS_LL_I2S_DATAFORMAT(I2S_InitStruct->DataFormat)); + assert_param(IS_LL_I2S_MCLK_OUTPUT(I2S_InitStruct->MCLKOutput)); + assert_param(IS_LL_I2S_AUDIO_FREQ(I2S_InitStruct->AudioFreq)); + assert_param(IS_LL_I2S_CPOL(I2S_InitStruct->ClockPolarity)); + + if (LL_I2S_IsEnabled(SPIx) == 0x00000000U) + { + /*---------------------------- SPIx I2SCFGR Configuration -------------------- + * Configure SPIx I2SCFGR with parameters: + * - Mode: SPI_I2SCFGR_I2SCFG[1:0] bit + * - Standard: SPI_I2SCFGR_I2SSTD[1:0] and SPI_I2SCFGR_PCMSYNC bits + * - DataFormat: SPI_I2SCFGR_CHLEN and SPI_I2SCFGR_DATLEN bits + * - ClockPolarity: SPI_I2SCFGR_CKPOL bit + */ + + /* Write to SPIx I2SCFGR */ + MODIFY_REG(SPIx->I2SCFGR, + I2S_I2SCFGR_CLEAR_MASK, + I2S_InitStruct->Mode | I2S_InitStruct->Standard | + I2S_InitStruct->DataFormat | I2S_InitStruct->ClockPolarity | + SPI_I2SCFGR_I2SMOD); + + /*---------------------------- SPIx I2SPR Configuration ---------------------- + * Configure SPIx I2SPR with parameters: + * - MCLKOutput: SPI_I2SPR_MCKOE bit + * - AudioFreq: SPI_I2SPR_I2SDIV[7:0] and SPI_I2SPR_ODD bits + */ + + /* If the requested audio frequency is not the default, compute the prescaler (i2sodd, i2sdiv) + * else, default values are used: i2sodd = 0U, i2sdiv = 2U. + */ + if (I2S_InitStruct->AudioFreq != LL_I2S_AUDIOFREQ_DEFAULT) + { + /* Check the frame length (For the Prescaler computing) + * Default value: LL_I2S_DATAFORMAT_16B (packetlength = 1U). + */ + if (I2S_InitStruct->DataFormat != LL_I2S_DATAFORMAT_16B) + { + /* Packet length is 32 bits */ + packetlength = 2U; + } + + /* I2S Clock source is System clock: Get System Clock frequency */ + LL_RCC_GetSystemClocksFreq(&rcc_clocks); + + /* Get the source clock value: based on System Clock value */ + sourceclock = rcc_clocks.SYSCLK_Frequency; + + /* Compute the Real divider depending on the MCLK output state with a floating point */ + if (I2S_InitStruct->MCLKOutput == LL_I2S_MCLK_OUTPUT_ENABLE) + { + /* MCLK output is enabled */ + tmp = (((((sourceclock / 256U) * 10U) / I2S_InitStruct->AudioFreq)) + 5U); + } + else + { + /* MCLK output is disabled */ + tmp = (((((sourceclock / (32U * packetlength)) * 10U) / I2S_InitStruct->AudioFreq)) + 5U); + } + + /* Remove the floating point */ + tmp = tmp / 10U; + + /* Check the parity of the divider */ + i2sodd = (tmp & (uint16_t)0x0001U); + + /* Compute the i2sdiv prescaler */ + i2sdiv = ((tmp - i2sodd) / 2U); + + /* Get the Mask for the Odd bit (SPI_I2SPR[8]) register */ + i2sodd = (i2sodd << 8U); + } + + /* Test if the divider is 1 or 0 or greater than 0xFF */ + if ((i2sdiv < 2U) || (i2sdiv > 0xFFU)) + { + /* Set the default values */ + i2sdiv = 2U; + i2sodd = 0U; + } + + /* Write to SPIx I2SPR register the computed value */ + WRITE_REG(SPIx->I2SPR, i2sdiv | i2sodd | I2S_InitStruct->MCLKOutput); + + status = SUCCESS; + } + return status; +} + +/** + * @brief Set each @ref LL_I2S_InitTypeDef field to default value. + * @param I2S_InitStruct pointer to a @ref LL_I2S_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ +void LL_I2S_StructInit(LL_I2S_InitTypeDef *I2S_InitStruct) +{ + /*--------------- Reset I2S init structure parameters values -----------------*/ + I2S_InitStruct->Mode = LL_I2S_MODE_SLAVE_TX; + I2S_InitStruct->Standard = LL_I2S_STANDARD_PHILIPS; + I2S_InitStruct->DataFormat = LL_I2S_DATAFORMAT_16B; + I2S_InitStruct->MCLKOutput = LL_I2S_MCLK_OUTPUT_DISABLE; + I2S_InitStruct->AudioFreq = LL_I2S_AUDIOFREQ_DEFAULT; + I2S_InitStruct->ClockPolarity = LL_I2S_POLARITY_LOW; +} + +/** + * @brief Set linear and parity prescaler. + * @note To calculate value of PrescalerLinear(I2SDIV[7:0] bits) and PrescalerParity(ODD bit)\n + * Check Audio frequency table and formulas inside Reference Manual (SPI/I2S). + * @param SPIx SPI Instance + * @param PrescalerLinear value Min_Data=0x02 and Max_Data=0xFF. + * @param PrescalerParity This parameter can be one of the following values: + * @arg @ref LL_I2S_PRESCALER_PARITY_EVEN + * @arg @ref LL_I2S_PRESCALER_PARITY_ODD + * @retval None + */ +void LL_I2S_ConfigPrescaler(SPI_TypeDef *SPIx, uint32_t PrescalerLinear, uint32_t PrescalerParity) +{ + /* Check the I2S parameters */ + assert_param(IS_I2S_ALL_INSTANCE(SPIx)); + assert_param(IS_LL_I2S_PRESCALER_LINEAR(PrescalerLinear)); + assert_param(IS_LL_I2S_PRESCALER_PARITY(PrescalerParity)); + + /* Write to SPIx I2SPR */ + MODIFY_REG(SPIx->I2SPR, SPI_I2SPR_I2SDIV | SPI_I2SPR_ODD, PrescalerLinear | (PrescalerParity << 8U)); +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ +#endif /* SPI_I2S_SUPPORT */ + +#endif /* defined (SPI1) || defined (SPI2) */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_tim.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_tim.c new file mode 100644 index 0000000..554b4a2 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_tim.c @@ -0,0 +1,1170 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_tim.c + * @author MCD Application Team + * @brief TIM LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_tim.h" +#include "stm32f0xx_ll_bus.h" + +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (TIM1) || defined (TIM2) || defined (TIM3) || defined (TIM14) || defined (TIM15) || defined (TIM16) || defined (TIM17) || defined (TIM6) || defined (TIM7) + +/** @addtogroup TIM_LL + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup TIM_LL_Private_Macros + * @{ + */ +#define IS_LL_TIM_COUNTERMODE(__VALUE__) (((__VALUE__) == LL_TIM_COUNTERMODE_UP) \ + || ((__VALUE__) == LL_TIM_COUNTERMODE_DOWN) \ + || ((__VALUE__) == LL_TIM_COUNTERMODE_CENTER_UP) \ + || ((__VALUE__) == LL_TIM_COUNTERMODE_CENTER_DOWN) \ + || ((__VALUE__) == LL_TIM_COUNTERMODE_CENTER_UP_DOWN)) + +#define IS_LL_TIM_CLOCKDIVISION(__VALUE__) (((__VALUE__) == LL_TIM_CLOCKDIVISION_DIV1) \ + || ((__VALUE__) == LL_TIM_CLOCKDIVISION_DIV2) \ + || ((__VALUE__) == LL_TIM_CLOCKDIVISION_DIV4)) + +#define IS_LL_TIM_OCMODE(__VALUE__) (((__VALUE__) == LL_TIM_OCMODE_FROZEN) \ + || ((__VALUE__) == LL_TIM_OCMODE_ACTIVE) \ + || ((__VALUE__) == LL_TIM_OCMODE_INACTIVE) \ + || ((__VALUE__) == LL_TIM_OCMODE_TOGGLE) \ + || ((__VALUE__) == LL_TIM_OCMODE_FORCED_INACTIVE) \ + || ((__VALUE__) == LL_TIM_OCMODE_FORCED_ACTIVE) \ + || ((__VALUE__) == LL_TIM_OCMODE_PWM1) \ + || ((__VALUE__) == LL_TIM_OCMODE_PWM2)) + +#define IS_LL_TIM_OCSTATE(__VALUE__) (((__VALUE__) == LL_TIM_OCSTATE_DISABLE) \ + || ((__VALUE__) == LL_TIM_OCSTATE_ENABLE)) + +#define IS_LL_TIM_OCPOLARITY(__VALUE__) (((__VALUE__) == LL_TIM_OCPOLARITY_HIGH) \ + || ((__VALUE__) == LL_TIM_OCPOLARITY_LOW)) + +#define IS_LL_TIM_OCIDLESTATE(__VALUE__) (((__VALUE__) == LL_TIM_OCIDLESTATE_LOW) \ + || ((__VALUE__) == LL_TIM_OCIDLESTATE_HIGH)) + +#define IS_LL_TIM_ACTIVEINPUT(__VALUE__) (((__VALUE__) == LL_TIM_ACTIVEINPUT_DIRECTTI) \ + || ((__VALUE__) == LL_TIM_ACTIVEINPUT_INDIRECTTI) \ + || ((__VALUE__) == LL_TIM_ACTIVEINPUT_TRC)) + +#define IS_LL_TIM_ICPSC(__VALUE__) (((__VALUE__) == LL_TIM_ICPSC_DIV1) \ + || ((__VALUE__) == LL_TIM_ICPSC_DIV2) \ + || ((__VALUE__) == LL_TIM_ICPSC_DIV4) \ + || ((__VALUE__) == LL_TIM_ICPSC_DIV8)) + +#define IS_LL_TIM_IC_FILTER(__VALUE__) (((__VALUE__) == LL_TIM_IC_FILTER_FDIV1) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV1_N2) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV1_N4) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV1_N8) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV2_N6) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV2_N8) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV4_N6) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV4_N8) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV8_N6) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV8_N8) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV16_N5) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV16_N6) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV16_N8) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV32_N5) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV32_N6) \ + || ((__VALUE__) == LL_TIM_IC_FILTER_FDIV32_N8)) + +#define IS_LL_TIM_IC_POLARITY(__VALUE__) (((__VALUE__) == LL_TIM_IC_POLARITY_RISING) \ + || ((__VALUE__) == LL_TIM_IC_POLARITY_FALLING) \ + || ((__VALUE__) == LL_TIM_IC_POLARITY_BOTHEDGE)) + +#define IS_LL_TIM_ENCODERMODE(__VALUE__) (((__VALUE__) == LL_TIM_ENCODERMODE_X2_TI1) \ + || ((__VALUE__) == LL_TIM_ENCODERMODE_X2_TI2) \ + || ((__VALUE__) == LL_TIM_ENCODERMODE_X4_TI12)) + +#define IS_LL_TIM_IC_POLARITY_ENCODER(__VALUE__) (((__VALUE__) == LL_TIM_IC_POLARITY_RISING) \ + || ((__VALUE__) == LL_TIM_IC_POLARITY_FALLING)) + +#define IS_LL_TIM_OSSR_STATE(__VALUE__) (((__VALUE__) == LL_TIM_OSSR_DISABLE) \ + || ((__VALUE__) == LL_TIM_OSSR_ENABLE)) + +#define IS_LL_TIM_OSSI_STATE(__VALUE__) (((__VALUE__) == LL_TIM_OSSI_DISABLE) \ + || ((__VALUE__) == LL_TIM_OSSI_ENABLE)) + +#define IS_LL_TIM_LOCK_LEVEL(__VALUE__) (((__VALUE__) == LL_TIM_LOCKLEVEL_OFF) \ + || ((__VALUE__) == LL_TIM_LOCKLEVEL_1) \ + || ((__VALUE__) == LL_TIM_LOCKLEVEL_2) \ + || ((__VALUE__) == LL_TIM_LOCKLEVEL_3)) + +#define IS_LL_TIM_BREAK_STATE(__VALUE__) (((__VALUE__) == LL_TIM_BREAK_DISABLE) \ + || ((__VALUE__) == LL_TIM_BREAK_ENABLE)) + +#define IS_LL_TIM_BREAK_POLARITY(__VALUE__) (((__VALUE__) == LL_TIM_BREAK_POLARITY_LOW) \ + || ((__VALUE__) == LL_TIM_BREAK_POLARITY_HIGH)) + +#define IS_LL_TIM_AUTOMATIC_OUTPUT_STATE(__VALUE__) (((__VALUE__) == LL_TIM_AUTOMATICOUTPUT_DISABLE) \ + || ((__VALUE__) == LL_TIM_AUTOMATICOUTPUT_ENABLE)) +/** + * @} + */ + + +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup TIM_LL_Private_Functions TIM Private Functions + * @{ + */ +static ErrorStatus OC1Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct); +static ErrorStatus OC2Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct); +static ErrorStatus OC3Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct); +static ErrorStatus OC4Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct); +static ErrorStatus IC1Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct); +static ErrorStatus IC2Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct); +static ErrorStatus IC3Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct); +static ErrorStatus IC4Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup TIM_LL_Exported_Functions + * @{ + */ + +/** @addtogroup TIM_LL_EF_Init + * @{ + */ + +/** + * @brief Set TIMx registers to their reset values. + * @param TIMx Timer instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: invalid TIMx instance + */ +ErrorStatus LL_TIM_DeInit(TIM_TypeDef *TIMx) +{ + ErrorStatus result = SUCCESS; + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(TIMx)); + + if (TIMx == TIM1) + { + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_TIM1); + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_TIM1); + } +#if defined (TIM2) + else if (TIMx == TIM2) + { + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_TIM2); + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_TIM2); + } +#endif /* TIM2 */ +#if defined(TIM3) + else if (TIMx == TIM3) + { + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_TIM3); + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_TIM3); + } +#endif /* TIM3 */ +#if defined(TIM5) + else if (TIMx == TIM5) + { + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_TIM5); + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_TIM5); + } +#endif /* TIM5 */ +#if defined (TIM6) + else if (TIMx == TIM6) + { + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_TIM6); + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_TIM6); + } +#endif /* TIM6 */ +#if defined (TIM7) + else if (TIMx == TIM7) + { + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_TIM7); + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_TIM7); + } +#endif /* TIM7 */ +#if defined(TIM8) + else if (TIMx == TIM8) + { + LL_APB2_GRP1_ForceReset(LL_APB2_GRP1_PERIPH_TIM8); + LL_APB2_GRP1_ReleaseReset(LL_APB2_GRP1_PERIPH_TIM8); + } +#endif /* TIM8 */ +#if defined (TIM14) + else if (TIMx == TIM14) + { + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_TIM14); + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_TIM14); + } +#endif /* TIM14 */ +#if defined (TIM15) + else if (TIMx == TIM15) + { + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_TIM15); + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_TIM15); + } +#endif /* TIM15 */ +#if defined (TIM16) + else if (TIMx == TIM16) + { + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_TIM16); + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_TIM16); + } +#endif /* TIM16 */ +#if defined(TIM17) + else if (TIMx == TIM17) + { + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_TIM17); + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_TIM17); + } +#endif /* TIM17 */ + else + { + result = ERROR; + } + + return result; +} + +/** + * @brief Set the fields of the time base unit configuration data structure + * to their default values. + * @param TIM_InitStruct pointer to a @ref LL_TIM_InitTypeDef structure (time base unit configuration data structure) + * @retval None + */ +void LL_TIM_StructInit(LL_TIM_InitTypeDef *TIM_InitStruct) +{ + /* Set the default configuration */ + TIM_InitStruct->Prescaler = (uint16_t)0x0000; + TIM_InitStruct->CounterMode = LL_TIM_COUNTERMODE_UP; + TIM_InitStruct->Autoreload = 0xFFFFFFFFU; + TIM_InitStruct->ClockDivision = LL_TIM_CLOCKDIVISION_DIV1; + TIM_InitStruct->RepetitionCounter = 0x00000000U; +} + +/** + * @brief Configure the TIMx time base unit. + * @param TIMx Timer Instance + * @param TIM_InitStruct pointer to a @ref LL_TIM_InitTypeDef structure + * (TIMx time base unit configuration data structure) + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_TIM_Init(TIM_TypeDef *TIMx, LL_TIM_InitTypeDef *TIM_InitStruct) +{ + uint32_t tmpcr1; + + /* Check the parameters */ + assert_param(IS_TIM_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_COUNTERMODE(TIM_InitStruct->CounterMode)); + assert_param(IS_LL_TIM_CLOCKDIVISION(TIM_InitStruct->ClockDivision)); + + tmpcr1 = LL_TIM_ReadReg(TIMx, CR1); + + if (IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx)) + { + /* Select the Counter Mode */ + MODIFY_REG(tmpcr1, (TIM_CR1_DIR | TIM_CR1_CMS), TIM_InitStruct->CounterMode); + } + + if (IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx)) + { + /* Set the clock division */ + MODIFY_REG(tmpcr1, TIM_CR1_CKD, TIM_InitStruct->ClockDivision); + } + + /* Write to TIMx CR1 */ + LL_TIM_WriteReg(TIMx, CR1, tmpcr1); + + /* Set the Autoreload value */ + LL_TIM_SetAutoReload(TIMx, TIM_InitStruct->Autoreload); + + /* Set the Prescaler value */ + LL_TIM_SetPrescaler(TIMx, TIM_InitStruct->Prescaler); + + if (IS_TIM_REPETITION_COUNTER_INSTANCE(TIMx)) + { + /* Set the Repetition Counter value */ + LL_TIM_SetRepetitionCounter(TIMx, TIM_InitStruct->RepetitionCounter); + } + + /* Generate an update event to reload the Prescaler + and the repetition counter value (if applicable) immediately */ + LL_TIM_GenerateEvent_UPDATE(TIMx); + + return SUCCESS; +} + +/** + * @brief Set the fields of the TIMx output channel configuration data + * structure to their default values. + * @param TIM_OC_InitStruct pointer to a @ref LL_TIM_OC_InitTypeDef structure + * (the output channel configuration data structure) + * @retval None + */ +void LL_TIM_OC_StructInit(LL_TIM_OC_InitTypeDef *TIM_OC_InitStruct) +{ + /* Set the default configuration */ + TIM_OC_InitStruct->OCMode = LL_TIM_OCMODE_FROZEN; + TIM_OC_InitStruct->OCState = LL_TIM_OCSTATE_DISABLE; + TIM_OC_InitStruct->OCNState = LL_TIM_OCSTATE_DISABLE; + TIM_OC_InitStruct->CompareValue = 0x00000000U; + TIM_OC_InitStruct->OCPolarity = LL_TIM_OCPOLARITY_HIGH; + TIM_OC_InitStruct->OCNPolarity = LL_TIM_OCPOLARITY_HIGH; + TIM_OC_InitStruct->OCIdleState = LL_TIM_OCIDLESTATE_LOW; + TIM_OC_InitStruct->OCNIdleState = LL_TIM_OCIDLESTATE_LOW; +} + +/** + * @brief Configure the TIMx output channel. + * @param TIMx Timer Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param TIM_OC_InitStruct pointer to a @ref LL_TIM_OC_InitTypeDef structure (TIMx output channel configuration + * data structure) + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx output channel is initialized + * - ERROR: TIMx output channel is not initialized + */ +ErrorStatus LL_TIM_OC_Init(TIM_TypeDef *TIMx, uint32_t Channel, LL_TIM_OC_InitTypeDef *TIM_OC_InitStruct) +{ + ErrorStatus result = ERROR; + + switch (Channel) + { + case LL_TIM_CHANNEL_CH1: + result = OC1Config(TIMx, TIM_OC_InitStruct); + break; + case LL_TIM_CHANNEL_CH2: + result = OC2Config(TIMx, TIM_OC_InitStruct); + break; + case LL_TIM_CHANNEL_CH3: + result = OC3Config(TIMx, TIM_OC_InitStruct); + break; + case LL_TIM_CHANNEL_CH4: + result = OC4Config(TIMx, TIM_OC_InitStruct); + break; + default: + break; + } + + return result; +} + +/** + * @brief Set the fields of the TIMx input channel configuration data + * structure to their default values. + * @param TIM_ICInitStruct pointer to a @ref LL_TIM_IC_InitTypeDef structure (the input channel configuration + * data structure) + * @retval None + */ +void LL_TIM_IC_StructInit(LL_TIM_IC_InitTypeDef *TIM_ICInitStruct) +{ + /* Set the default configuration */ + TIM_ICInitStruct->ICPolarity = LL_TIM_IC_POLARITY_RISING; + TIM_ICInitStruct->ICActiveInput = LL_TIM_ACTIVEINPUT_DIRECTTI; + TIM_ICInitStruct->ICPrescaler = LL_TIM_ICPSC_DIV1; + TIM_ICInitStruct->ICFilter = LL_TIM_IC_FILTER_FDIV1; +} + +/** + * @brief Configure the TIMx input channel. + * @param TIMx Timer Instance + * @param Channel This parameter can be one of the following values: + * @arg @ref LL_TIM_CHANNEL_CH1 + * @arg @ref LL_TIM_CHANNEL_CH2 + * @arg @ref LL_TIM_CHANNEL_CH3 + * @arg @ref LL_TIM_CHANNEL_CH4 + * @param TIM_IC_InitStruct pointer to a @ref LL_TIM_IC_InitTypeDef structure (TIMx input channel configuration data + * structure) + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx output channel is initialized + * - ERROR: TIMx output channel is not initialized + */ +ErrorStatus LL_TIM_IC_Init(TIM_TypeDef *TIMx, uint32_t Channel, LL_TIM_IC_InitTypeDef *TIM_IC_InitStruct) +{ + ErrorStatus result = ERROR; + + switch (Channel) + { + case LL_TIM_CHANNEL_CH1: + result = IC1Config(TIMx, TIM_IC_InitStruct); + break; + case LL_TIM_CHANNEL_CH2: + result = IC2Config(TIMx, TIM_IC_InitStruct); + break; + case LL_TIM_CHANNEL_CH3: + result = IC3Config(TIMx, TIM_IC_InitStruct); + break; + case LL_TIM_CHANNEL_CH4: + result = IC4Config(TIMx, TIM_IC_InitStruct); + break; + default: + break; + } + + return result; +} + +/** + * @brief Fills each TIM_EncoderInitStruct field with its default value + * @param TIM_EncoderInitStruct pointer to a @ref LL_TIM_ENCODER_InitTypeDef structure (encoder interface + * configuration data structure) + * @retval None + */ +void LL_TIM_ENCODER_StructInit(LL_TIM_ENCODER_InitTypeDef *TIM_EncoderInitStruct) +{ + /* Set the default configuration */ + TIM_EncoderInitStruct->EncoderMode = LL_TIM_ENCODERMODE_X2_TI1; + TIM_EncoderInitStruct->IC1Polarity = LL_TIM_IC_POLARITY_RISING; + TIM_EncoderInitStruct->IC1ActiveInput = LL_TIM_ACTIVEINPUT_DIRECTTI; + TIM_EncoderInitStruct->IC1Prescaler = LL_TIM_ICPSC_DIV1; + TIM_EncoderInitStruct->IC1Filter = LL_TIM_IC_FILTER_FDIV1; + TIM_EncoderInitStruct->IC2Polarity = LL_TIM_IC_POLARITY_RISING; + TIM_EncoderInitStruct->IC2ActiveInput = LL_TIM_ACTIVEINPUT_DIRECTTI; + TIM_EncoderInitStruct->IC2Prescaler = LL_TIM_ICPSC_DIV1; + TIM_EncoderInitStruct->IC2Filter = LL_TIM_IC_FILTER_FDIV1; +} + +/** + * @brief Configure the encoder interface of the timer instance. + * @param TIMx Timer Instance + * @param TIM_EncoderInitStruct pointer to a @ref LL_TIM_ENCODER_InitTypeDef structure (TIMx encoder interface + * configuration data structure) + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_TIM_ENCODER_Init(TIM_TypeDef *TIMx, LL_TIM_ENCODER_InitTypeDef *TIM_EncoderInitStruct) +{ + uint32_t tmpccmr1; + uint32_t tmpccer; + + /* Check the parameters */ + assert_param(IS_TIM_ENCODER_INTERFACE_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_ENCODERMODE(TIM_EncoderInitStruct->EncoderMode)); + assert_param(IS_LL_TIM_IC_POLARITY_ENCODER(TIM_EncoderInitStruct->IC1Polarity)); + assert_param(IS_LL_TIM_ACTIVEINPUT(TIM_EncoderInitStruct->IC1ActiveInput)); + assert_param(IS_LL_TIM_ICPSC(TIM_EncoderInitStruct->IC1Prescaler)); + assert_param(IS_LL_TIM_IC_FILTER(TIM_EncoderInitStruct->IC1Filter)); + assert_param(IS_LL_TIM_IC_POLARITY_ENCODER(TIM_EncoderInitStruct->IC2Polarity)); + assert_param(IS_LL_TIM_ACTIVEINPUT(TIM_EncoderInitStruct->IC2ActiveInput)); + assert_param(IS_LL_TIM_ICPSC(TIM_EncoderInitStruct->IC2Prescaler)); + assert_param(IS_LL_TIM_IC_FILTER(TIM_EncoderInitStruct->IC2Filter)); + + /* Disable the CC1 and CC2: Reset the CC1E and CC2E Bits */ + TIMx->CCER &= (uint32_t)~(TIM_CCER_CC1E | TIM_CCER_CC2E); + + /* Get the TIMx CCMR1 register value */ + tmpccmr1 = LL_TIM_ReadReg(TIMx, CCMR1); + + /* Get the TIMx CCER register value */ + tmpccer = LL_TIM_ReadReg(TIMx, CCER); + + /* Configure TI1 */ + tmpccmr1 &= (uint32_t)~(TIM_CCMR1_CC1S | TIM_CCMR1_IC1F | TIM_CCMR1_IC1PSC); + tmpccmr1 |= (uint32_t)(TIM_EncoderInitStruct->IC1ActiveInput >> 16U); + tmpccmr1 |= (uint32_t)(TIM_EncoderInitStruct->IC1Filter >> 16U); + tmpccmr1 |= (uint32_t)(TIM_EncoderInitStruct->IC1Prescaler >> 16U); + + /* Configure TI2 */ + tmpccmr1 &= (uint32_t)~(TIM_CCMR1_CC2S | TIM_CCMR1_IC2F | TIM_CCMR1_IC2PSC); + tmpccmr1 |= (uint32_t)(TIM_EncoderInitStruct->IC2ActiveInput >> 8U); + tmpccmr1 |= (uint32_t)(TIM_EncoderInitStruct->IC2Filter >> 8U); + tmpccmr1 |= (uint32_t)(TIM_EncoderInitStruct->IC2Prescaler >> 8U); + + /* Set TI1 and TI2 polarity and enable TI1 and TI2 */ + tmpccer &= (uint32_t)~(TIM_CCER_CC1P | TIM_CCER_CC1NP | TIM_CCER_CC2P | TIM_CCER_CC2NP); + tmpccer |= (uint32_t)(TIM_EncoderInitStruct->IC1Polarity); + tmpccer |= (uint32_t)(TIM_EncoderInitStruct->IC2Polarity << 4U); + tmpccer |= (uint32_t)(TIM_CCER_CC1E | TIM_CCER_CC2E); + + /* Set encoder mode */ + LL_TIM_SetEncoderMode(TIMx, TIM_EncoderInitStruct->EncoderMode); + + /* Write to TIMx CCMR1 */ + LL_TIM_WriteReg(TIMx, CCMR1, tmpccmr1); + + /* Write to TIMx CCER */ + LL_TIM_WriteReg(TIMx, CCER, tmpccer); + + return SUCCESS; +} + +/** + * @brief Set the fields of the TIMx Hall sensor interface configuration data + * structure to their default values. + * @param TIM_HallSensorInitStruct pointer to a @ref LL_TIM_HALLSENSOR_InitTypeDef structure (HALL sensor interface + * configuration data structure) + * @retval None + */ +void LL_TIM_HALLSENSOR_StructInit(LL_TIM_HALLSENSOR_InitTypeDef *TIM_HallSensorInitStruct) +{ + /* Set the default configuration */ + TIM_HallSensorInitStruct->IC1Polarity = LL_TIM_IC_POLARITY_RISING; + TIM_HallSensorInitStruct->IC1Prescaler = LL_TIM_ICPSC_DIV1; + TIM_HallSensorInitStruct->IC1Filter = LL_TIM_IC_FILTER_FDIV1; + TIM_HallSensorInitStruct->CommutationDelay = 0U; +} + +/** + * @brief Configure the Hall sensor interface of the timer instance. + * @note TIMx CH1, CH2 and CH3 inputs connected through a XOR + * to the TI1 input channel + * @note TIMx slave mode controller is configured in reset mode. + Selected internal trigger is TI1F_ED. + * @note Channel 1 is configured as input, IC1 is mapped on TRC. + * @note Captured value stored in TIMx_CCR1 correspond to the time elapsed + * between 2 changes on the inputs. It gives information about motor speed. + * @note Channel 2 is configured in output PWM 2 mode. + * @note Compare value stored in TIMx_CCR2 corresponds to the commutation delay. + * @note OC2REF is selected as trigger output on TRGO. + * @note LL_TIM_IC_POLARITY_BOTHEDGE must not be used for TI1 when it is used + * when TIMx operates in Hall sensor interface mode. + * @param TIMx Timer Instance + * @param TIM_HallSensorInitStruct pointer to a @ref LL_TIM_HALLSENSOR_InitTypeDef structure (TIMx HALL sensor + * interface configuration data structure) + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +ErrorStatus LL_TIM_HALLSENSOR_Init(TIM_TypeDef *TIMx, LL_TIM_HALLSENSOR_InitTypeDef *TIM_HallSensorInitStruct) +{ + uint32_t tmpcr2; + uint32_t tmpccmr1; + uint32_t tmpccer; + uint32_t tmpsmcr; + + /* Check the parameters */ + assert_param(IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_IC_POLARITY_ENCODER(TIM_HallSensorInitStruct->IC1Polarity)); + assert_param(IS_LL_TIM_ICPSC(TIM_HallSensorInitStruct->IC1Prescaler)); + assert_param(IS_LL_TIM_IC_FILTER(TIM_HallSensorInitStruct->IC1Filter)); + + /* Disable the CC1 and CC2: Reset the CC1E and CC2E Bits */ + TIMx->CCER &= (uint32_t)~(TIM_CCER_CC1E | TIM_CCER_CC2E); + + /* Get the TIMx CR2 register value */ + tmpcr2 = LL_TIM_ReadReg(TIMx, CR2); + + /* Get the TIMx CCMR1 register value */ + tmpccmr1 = LL_TIM_ReadReg(TIMx, CCMR1); + + /* Get the TIMx CCER register value */ + tmpccer = LL_TIM_ReadReg(TIMx, CCER); + + /* Get the TIMx SMCR register value */ + tmpsmcr = LL_TIM_ReadReg(TIMx, SMCR); + + /* Connect TIMx_CH1, CH2 and CH3 pins to the TI1 input */ + tmpcr2 |= TIM_CR2_TI1S; + + /* OC2REF signal is used as trigger output (TRGO) */ + tmpcr2 |= LL_TIM_TRGO_OC2REF; + + /* Configure the slave mode controller */ + tmpsmcr &= (uint32_t)~(TIM_SMCR_TS | TIM_SMCR_SMS); + tmpsmcr |= LL_TIM_TS_TI1F_ED; + tmpsmcr |= LL_TIM_SLAVEMODE_RESET; + + /* Configure input channel 1 */ + tmpccmr1 &= (uint32_t)~(TIM_CCMR1_CC1S | TIM_CCMR1_IC1F | TIM_CCMR1_IC1PSC); + tmpccmr1 |= (uint32_t)(LL_TIM_ACTIVEINPUT_TRC >> 16U); + tmpccmr1 |= (uint32_t)(TIM_HallSensorInitStruct->IC1Filter >> 16U); + tmpccmr1 |= (uint32_t)(TIM_HallSensorInitStruct->IC1Prescaler >> 16U); + + /* Configure input channel 2 */ + tmpccmr1 &= (uint32_t)~(TIM_CCMR1_OC2M | TIM_CCMR1_OC2FE | TIM_CCMR1_OC2PE | TIM_CCMR1_OC2CE); + tmpccmr1 |= (uint32_t)(LL_TIM_OCMODE_PWM2 << 8U); + + /* Set Channel 1 polarity and enable Channel 1 and Channel2 */ + tmpccer &= (uint32_t)~(TIM_CCER_CC1P | TIM_CCER_CC1NP | TIM_CCER_CC2P | TIM_CCER_CC2NP); + tmpccer |= (uint32_t)(TIM_HallSensorInitStruct->IC1Polarity); + tmpccer |= (uint32_t)(TIM_CCER_CC1E | TIM_CCER_CC2E); + + /* Write to TIMx CR2 */ + LL_TIM_WriteReg(TIMx, CR2, tmpcr2); + + /* Write to TIMx SMCR */ + LL_TIM_WriteReg(TIMx, SMCR, tmpsmcr); + + /* Write to TIMx CCMR1 */ + LL_TIM_WriteReg(TIMx, CCMR1, tmpccmr1); + + /* Write to TIMx CCER */ + LL_TIM_WriteReg(TIMx, CCER, tmpccer); + + /* Write to TIMx CCR2 */ + LL_TIM_OC_SetCompareCH2(TIMx, TIM_HallSensorInitStruct->CommutationDelay); + + return SUCCESS; +} + +/** + * @brief Set the fields of the Break and Dead Time configuration data structure + * to their default values. + * @param TIM_BDTRInitStruct pointer to a @ref LL_TIM_BDTR_InitTypeDef structure (Break and Dead Time configuration + * data structure) + * @retval None + */ +void LL_TIM_BDTR_StructInit(LL_TIM_BDTR_InitTypeDef *TIM_BDTRInitStruct) +{ + /* Set the default configuration */ + TIM_BDTRInitStruct->OSSRState = LL_TIM_OSSR_DISABLE; + TIM_BDTRInitStruct->OSSIState = LL_TIM_OSSI_DISABLE; + TIM_BDTRInitStruct->LockLevel = LL_TIM_LOCKLEVEL_OFF; + TIM_BDTRInitStruct->DeadTime = (uint8_t)0x00; + TIM_BDTRInitStruct->BreakState = LL_TIM_BREAK_DISABLE; + TIM_BDTRInitStruct->BreakPolarity = LL_TIM_BREAK_POLARITY_LOW; + TIM_BDTRInitStruct->AutomaticOutput = LL_TIM_AUTOMATICOUTPUT_DISABLE; +} + +/** + * @brief Configure the Break and Dead Time feature of the timer instance. + * @note As the bits AOE, BKP, BKE, OSSR, OSSI and DTG[7:0] can be write-locked + * depending on the LOCK configuration, it can be necessary to configure all of + * them during the first write access to the TIMx_BDTR register. + * @note Macro IS_TIM_BREAK_INSTANCE(TIMx) can be used to check whether or not + * a timer instance provides a break input. + * @param TIMx Timer Instance + * @param TIM_BDTRInitStruct pointer to a @ref LL_TIM_BDTR_InitTypeDef structure (Break and Dead Time configuration + * data structure) + * @retval An ErrorStatus enumeration value: + * - SUCCESS: Break and Dead Time is initialized + * - ERROR: not applicable + */ +ErrorStatus LL_TIM_BDTR_Init(TIM_TypeDef *TIMx, LL_TIM_BDTR_InitTypeDef *TIM_BDTRInitStruct) +{ + uint32_t tmpbdtr = 0; + + /* Check the parameters */ + assert_param(IS_TIM_BREAK_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_OSSR_STATE(TIM_BDTRInitStruct->OSSRState)); + assert_param(IS_LL_TIM_OSSI_STATE(TIM_BDTRInitStruct->OSSIState)); + assert_param(IS_LL_TIM_LOCK_LEVEL(TIM_BDTRInitStruct->LockLevel)); + assert_param(IS_LL_TIM_BREAK_STATE(TIM_BDTRInitStruct->BreakState)); + assert_param(IS_LL_TIM_BREAK_POLARITY(TIM_BDTRInitStruct->BreakPolarity)); + assert_param(IS_LL_TIM_AUTOMATIC_OUTPUT_STATE(TIM_BDTRInitStruct->AutomaticOutput)); + + /* Set the Lock level, the Break enable Bit and the Polarity, the OSSR State, + the OSSI State, the dead time value and the Automatic Output Enable Bit */ + + /* Set the BDTR bits */ + MODIFY_REG(tmpbdtr, TIM_BDTR_DTG, TIM_BDTRInitStruct->DeadTime); + MODIFY_REG(tmpbdtr, TIM_BDTR_LOCK, TIM_BDTRInitStruct->LockLevel); + MODIFY_REG(tmpbdtr, TIM_BDTR_OSSI, TIM_BDTRInitStruct->OSSIState); + MODIFY_REG(tmpbdtr, TIM_BDTR_OSSR, TIM_BDTRInitStruct->OSSRState); + MODIFY_REG(tmpbdtr, TIM_BDTR_BKE, TIM_BDTRInitStruct->BreakState); + MODIFY_REG(tmpbdtr, TIM_BDTR_BKP, TIM_BDTRInitStruct->BreakPolarity); + MODIFY_REG(tmpbdtr, TIM_BDTR_AOE, TIM_BDTRInitStruct->AutomaticOutput); + MODIFY_REG(tmpbdtr, TIM_BDTR_MOE, TIM_BDTRInitStruct->AutomaticOutput); + + /* Set TIMx_BDTR */ + LL_TIM_WriteReg(TIMx, BDTR, tmpbdtr); + + return SUCCESS; +} +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup TIM_LL_Private_Functions TIM Private Functions + * @brief Private functions + * @{ + */ +/** + * @brief Configure the TIMx output channel 1. + * @param TIMx Timer Instance + * @param TIM_OCInitStruct pointer to the the TIMx output channel 1 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus OC1Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct) +{ + uint32_t tmpccmr1; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_OCMODE(TIM_OCInitStruct->OCMode)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCState)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCPolarity)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCNState)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCNPolarity)); + + /* Disable the Channel 1: Reset the CC1E Bit */ + CLEAR_BIT(TIMx->CCER, TIM_CCER_CC1E); + + /* Get the TIMx CCER register value */ + tmpccer = LL_TIM_ReadReg(TIMx, CCER); + + /* Get the TIMx CR2 register value */ + tmpcr2 = LL_TIM_ReadReg(TIMx, CR2); + + /* Get the TIMx CCMR1 register value */ + tmpccmr1 = LL_TIM_ReadReg(TIMx, CCMR1); + + /* Reset Capture/Compare selection Bits */ + CLEAR_BIT(tmpccmr1, TIM_CCMR1_CC1S); + + /* Set the Output Compare Mode */ + MODIFY_REG(tmpccmr1, TIM_CCMR1_OC1M, TIM_OCInitStruct->OCMode); + + /* Set the Output Compare Polarity */ + MODIFY_REG(tmpccer, TIM_CCER_CC1P, TIM_OCInitStruct->OCPolarity); + + /* Set the Output State */ + MODIFY_REG(tmpccer, TIM_CCER_CC1E, TIM_OCInitStruct->OCState); + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCNIdleState)); + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCIdleState)); + + /* Set the complementary output Polarity */ + MODIFY_REG(tmpccer, TIM_CCER_CC1NP, TIM_OCInitStruct->OCNPolarity << 2U); + + /* Set the complementary output State */ + MODIFY_REG(tmpccer, TIM_CCER_CC1NE, TIM_OCInitStruct->OCNState << 2U); + + /* Set the Output Idle state */ + MODIFY_REG(tmpcr2, TIM_CR2_OIS1, TIM_OCInitStruct->OCIdleState); + + /* Set the complementary output Idle state */ + MODIFY_REG(tmpcr2, TIM_CR2_OIS1N, TIM_OCInitStruct->OCNIdleState << 1U); + } + + /* Write to TIMx CR2 */ + LL_TIM_WriteReg(TIMx, CR2, tmpcr2); + + /* Write to TIMx CCMR1 */ + LL_TIM_WriteReg(TIMx, CCMR1, tmpccmr1); + + /* Set the Capture Compare Register value */ + LL_TIM_OC_SetCompareCH1(TIMx, TIM_OCInitStruct->CompareValue); + + /* Write to TIMx CCER */ + LL_TIM_WriteReg(TIMx, CCER, tmpccer); + + return SUCCESS; +} + +/** + * @brief Configure the TIMx output channel 2. + * @param TIMx Timer Instance + * @param TIM_OCInitStruct pointer to the the TIMx output channel 2 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus OC2Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct) +{ + uint32_t tmpccmr1; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Check the parameters */ + assert_param(IS_TIM_CC2_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_OCMODE(TIM_OCInitStruct->OCMode)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCState)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCPolarity)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCNState)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCNPolarity)); + + /* Disable the Channel 2: Reset the CC2E Bit */ + CLEAR_BIT(TIMx->CCER, TIM_CCER_CC2E); + + /* Get the TIMx CCER register value */ + tmpccer = LL_TIM_ReadReg(TIMx, CCER); + + /* Get the TIMx CR2 register value */ + tmpcr2 = LL_TIM_ReadReg(TIMx, CR2); + + /* Get the TIMx CCMR1 register value */ + tmpccmr1 = LL_TIM_ReadReg(TIMx, CCMR1); + + /* Reset Capture/Compare selection Bits */ + CLEAR_BIT(tmpccmr1, TIM_CCMR1_CC2S); + + /* Select the Output Compare Mode */ + MODIFY_REG(tmpccmr1, TIM_CCMR1_OC2M, TIM_OCInitStruct->OCMode << 8U); + + /* Set the Output Compare Polarity */ + MODIFY_REG(tmpccer, TIM_CCER_CC2P, TIM_OCInitStruct->OCPolarity << 4U); + + /* Set the Output State */ + MODIFY_REG(tmpccer, TIM_CCER_CC2E, TIM_OCInitStruct->OCState << 4U); + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCNIdleState)); + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCIdleState)); + + /* Set the complementary output Polarity */ + MODIFY_REG(tmpccer, TIM_CCER_CC2NP, TIM_OCInitStruct->OCNPolarity << 6U); + + /* Set the complementary output State */ + MODIFY_REG(tmpccer, TIM_CCER_CC2NE, TIM_OCInitStruct->OCNState << 6U); + + /* Set the Output Idle state */ + MODIFY_REG(tmpcr2, TIM_CR2_OIS2, TIM_OCInitStruct->OCIdleState << 2U); + + /* Set the complementary output Idle state */ + MODIFY_REG(tmpcr2, TIM_CR2_OIS2N, TIM_OCInitStruct->OCNIdleState << 3U); + } + + /* Write to TIMx CR2 */ + LL_TIM_WriteReg(TIMx, CR2, tmpcr2); + + /* Write to TIMx CCMR1 */ + LL_TIM_WriteReg(TIMx, CCMR1, tmpccmr1); + + /* Set the Capture Compare Register value */ + LL_TIM_OC_SetCompareCH2(TIMx, TIM_OCInitStruct->CompareValue); + + /* Write to TIMx CCER */ + LL_TIM_WriteReg(TIMx, CCER, tmpccer); + + return SUCCESS; +} + +/** + * @brief Configure the TIMx output channel 3. + * @param TIMx Timer Instance + * @param TIM_OCInitStruct pointer to the the TIMx output channel 3 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus OC3Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct) +{ + uint32_t tmpccmr2; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Check the parameters */ + assert_param(IS_TIM_CC3_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_OCMODE(TIM_OCInitStruct->OCMode)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCState)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCPolarity)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCNState)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCNPolarity)); + + /* Disable the Channel 3: Reset the CC3E Bit */ + CLEAR_BIT(TIMx->CCER, TIM_CCER_CC3E); + + /* Get the TIMx CCER register value */ + tmpccer = LL_TIM_ReadReg(TIMx, CCER); + + /* Get the TIMx CR2 register value */ + tmpcr2 = LL_TIM_ReadReg(TIMx, CR2); + + /* Get the TIMx CCMR2 register value */ + tmpccmr2 = LL_TIM_ReadReg(TIMx, CCMR2); + + /* Reset Capture/Compare selection Bits */ + CLEAR_BIT(tmpccmr2, TIM_CCMR2_CC3S); + + /* Select the Output Compare Mode */ + MODIFY_REG(tmpccmr2, TIM_CCMR2_OC3M, TIM_OCInitStruct->OCMode); + + /* Set the Output Compare Polarity */ + MODIFY_REG(tmpccer, TIM_CCER_CC3P, TIM_OCInitStruct->OCPolarity << 8U); + + /* Set the Output State */ + MODIFY_REG(tmpccer, TIM_CCER_CC3E, TIM_OCInitStruct->OCState << 8U); + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCNIdleState)); + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCIdleState)); + + /* Set the complementary output Polarity */ + MODIFY_REG(tmpccer, TIM_CCER_CC3NP, TIM_OCInitStruct->OCNPolarity << 10U); + + /* Set the complementary output State */ + MODIFY_REG(tmpccer, TIM_CCER_CC3NE, TIM_OCInitStruct->OCNState << 10U); + + /* Set the Output Idle state */ + MODIFY_REG(tmpcr2, TIM_CR2_OIS3, TIM_OCInitStruct->OCIdleState << 4U); + + /* Set the complementary output Idle state */ + MODIFY_REG(tmpcr2, TIM_CR2_OIS3N, TIM_OCInitStruct->OCNIdleState << 5U); + } + + /* Write to TIMx CR2 */ + LL_TIM_WriteReg(TIMx, CR2, tmpcr2); + + /* Write to TIMx CCMR2 */ + LL_TIM_WriteReg(TIMx, CCMR2, tmpccmr2); + + /* Set the Capture Compare Register value */ + LL_TIM_OC_SetCompareCH3(TIMx, TIM_OCInitStruct->CompareValue); + + /* Write to TIMx CCER */ + LL_TIM_WriteReg(TIMx, CCER, tmpccer); + + return SUCCESS; +} + +/** + * @brief Configure the TIMx output channel 4. + * @param TIMx Timer Instance + * @param TIM_OCInitStruct pointer to the the TIMx output channel 4 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus OC4Config(TIM_TypeDef *TIMx, LL_TIM_OC_InitTypeDef *TIM_OCInitStruct) +{ + uint32_t tmpccmr2; + uint32_t tmpccer; + uint32_t tmpcr2; + + /* Check the parameters */ + assert_param(IS_TIM_CC4_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_OCMODE(TIM_OCInitStruct->OCMode)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCState)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCPolarity)); + assert_param(IS_LL_TIM_OCPOLARITY(TIM_OCInitStruct->OCNPolarity)); + assert_param(IS_LL_TIM_OCSTATE(TIM_OCInitStruct->OCNState)); + + /* Disable the Channel 4: Reset the CC4E Bit */ + CLEAR_BIT(TIMx->CCER, TIM_CCER_CC4E); + + /* Get the TIMx CCER register value */ + tmpccer = LL_TIM_ReadReg(TIMx, CCER); + + /* Get the TIMx CR2 register value */ + tmpcr2 = LL_TIM_ReadReg(TIMx, CR2); + + /* Get the TIMx CCMR2 register value */ + tmpccmr2 = LL_TIM_ReadReg(TIMx, CCMR2); + + /* Reset Capture/Compare selection Bits */ + CLEAR_BIT(tmpccmr2, TIM_CCMR2_CC4S); + + /* Select the Output Compare Mode */ + MODIFY_REG(tmpccmr2, TIM_CCMR2_OC4M, TIM_OCInitStruct->OCMode << 8U); + + /* Set the Output Compare Polarity */ + MODIFY_REG(tmpccer, TIM_CCER_CC4P, TIM_OCInitStruct->OCPolarity << 12U); + + /* Set the Output State */ + MODIFY_REG(tmpccer, TIM_CCER_CC4E, TIM_OCInitStruct->OCState << 12U); + + if (IS_TIM_BREAK_INSTANCE(TIMx)) + { + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCNIdleState)); + assert_param(IS_LL_TIM_OCIDLESTATE(TIM_OCInitStruct->OCIdleState)); + + /* Set the Output Idle state */ + MODIFY_REG(tmpcr2, TIM_CR2_OIS4, TIM_OCInitStruct->OCIdleState << 6U); + } + + /* Write to TIMx CR2 */ + LL_TIM_WriteReg(TIMx, CR2, tmpcr2); + + /* Write to TIMx CCMR2 */ + LL_TIM_WriteReg(TIMx, CCMR2, tmpccmr2); + + /* Set the Capture Compare Register value */ + LL_TIM_OC_SetCompareCH4(TIMx, TIM_OCInitStruct->CompareValue); + + /* Write to TIMx CCER */ + LL_TIM_WriteReg(TIMx, CCER, tmpccer); + + return SUCCESS; +} + + +/** + * @brief Configure the TIMx input channel 1. + * @param TIMx Timer Instance + * @param TIM_ICInitStruct pointer to the the TIMx input channel 1 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus IC1Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct) +{ + /* Check the parameters */ + assert_param(IS_TIM_CC1_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_IC_POLARITY(TIM_ICInitStruct->ICPolarity)); + assert_param(IS_LL_TIM_ACTIVEINPUT(TIM_ICInitStruct->ICActiveInput)); + assert_param(IS_LL_TIM_ICPSC(TIM_ICInitStruct->ICPrescaler)); + assert_param(IS_LL_TIM_IC_FILTER(TIM_ICInitStruct->ICFilter)); + + /* Disable the Channel 1: Reset the CC1E Bit */ + TIMx->CCER &= (uint32_t)~TIM_CCER_CC1E; + + /* Select the Input and set the filter and the prescaler value */ + MODIFY_REG(TIMx->CCMR1, + (TIM_CCMR1_CC1S | TIM_CCMR1_IC1F | TIM_CCMR1_IC1PSC), + (TIM_ICInitStruct->ICActiveInput | TIM_ICInitStruct->ICFilter | TIM_ICInitStruct->ICPrescaler) >> 16U); + + /* Select the Polarity and set the CC1E Bit */ + MODIFY_REG(TIMx->CCER, + (TIM_CCER_CC1P | TIM_CCER_CC1NP), + (TIM_ICInitStruct->ICPolarity | TIM_CCER_CC1E)); + + return SUCCESS; +} + +/** + * @brief Configure the TIMx input channel 2. + * @param TIMx Timer Instance + * @param TIM_ICInitStruct pointer to the the TIMx input channel 2 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus IC2Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct) +{ + /* Check the parameters */ + assert_param(IS_TIM_CC2_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_IC_POLARITY(TIM_ICInitStruct->ICPolarity)); + assert_param(IS_LL_TIM_ACTIVEINPUT(TIM_ICInitStruct->ICActiveInput)); + assert_param(IS_LL_TIM_ICPSC(TIM_ICInitStruct->ICPrescaler)); + assert_param(IS_LL_TIM_IC_FILTER(TIM_ICInitStruct->ICFilter)); + + /* Disable the Channel 2: Reset the CC2E Bit */ + TIMx->CCER &= (uint32_t)~TIM_CCER_CC2E; + + /* Select the Input and set the filter and the prescaler value */ + MODIFY_REG(TIMx->CCMR1, + (TIM_CCMR1_CC2S | TIM_CCMR1_IC2F | TIM_CCMR1_IC2PSC), + (TIM_ICInitStruct->ICActiveInput | TIM_ICInitStruct->ICFilter | TIM_ICInitStruct->ICPrescaler) >> 8U); + + /* Select the Polarity and set the CC2E Bit */ + MODIFY_REG(TIMx->CCER, + (TIM_CCER_CC2P | TIM_CCER_CC2NP), + ((TIM_ICInitStruct->ICPolarity << 4U) | TIM_CCER_CC2E)); + + return SUCCESS; +} + +/** + * @brief Configure the TIMx input channel 3. + * @param TIMx Timer Instance + * @param TIM_ICInitStruct pointer to the the TIMx input channel 3 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus IC3Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct) +{ + /* Check the parameters */ + assert_param(IS_TIM_CC3_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_IC_POLARITY(TIM_ICInitStruct->ICPolarity)); + assert_param(IS_LL_TIM_ACTIVEINPUT(TIM_ICInitStruct->ICActiveInput)); + assert_param(IS_LL_TIM_ICPSC(TIM_ICInitStruct->ICPrescaler)); + assert_param(IS_LL_TIM_IC_FILTER(TIM_ICInitStruct->ICFilter)); + + /* Disable the Channel 3: Reset the CC3E Bit */ + TIMx->CCER &= (uint32_t)~TIM_CCER_CC3E; + + /* Select the Input and set the filter and the prescaler value */ + MODIFY_REG(TIMx->CCMR2, + (TIM_CCMR2_CC3S | TIM_CCMR2_IC3F | TIM_CCMR2_IC3PSC), + (TIM_ICInitStruct->ICActiveInput | TIM_ICInitStruct->ICFilter | TIM_ICInitStruct->ICPrescaler) >> 16U); + + /* Select the Polarity and set the CC3E Bit */ + MODIFY_REG(TIMx->CCER, + (TIM_CCER_CC3P | TIM_CCER_CC3NP), + ((TIM_ICInitStruct->ICPolarity << 8U) | TIM_CCER_CC3E)); + + return SUCCESS; +} + +/** + * @brief Configure the TIMx input channel 4. + * @param TIMx Timer Instance + * @param TIM_ICInitStruct pointer to the the TIMx input channel 4 configuration data structure + * @retval An ErrorStatus enumeration value: + * - SUCCESS: TIMx registers are de-initialized + * - ERROR: not applicable + */ +static ErrorStatus IC4Config(TIM_TypeDef *TIMx, LL_TIM_IC_InitTypeDef *TIM_ICInitStruct) +{ + /* Check the parameters */ + assert_param(IS_TIM_CC4_INSTANCE(TIMx)); + assert_param(IS_LL_TIM_IC_POLARITY(TIM_ICInitStruct->ICPolarity)); + assert_param(IS_LL_TIM_ACTIVEINPUT(TIM_ICInitStruct->ICActiveInput)); + assert_param(IS_LL_TIM_ICPSC(TIM_ICInitStruct->ICPrescaler)); + assert_param(IS_LL_TIM_IC_FILTER(TIM_ICInitStruct->ICFilter)); + + /* Disable the Channel 4: Reset the CC4E Bit */ + TIMx->CCER &= (uint32_t)~TIM_CCER_CC4E; + + /* Select the Input and set the filter and the prescaler value */ + MODIFY_REG(TIMx->CCMR2, + (TIM_CCMR2_CC4S | TIM_CCMR2_IC4F | TIM_CCMR2_IC4PSC), + (TIM_ICInitStruct->ICActiveInput | TIM_ICInitStruct->ICFilter | TIM_ICInitStruct->ICPrescaler) >> 8U); + + /* Select the Polarity and set the CC2E Bit */ + MODIFY_REG(TIMx->CCER, + (TIM_CCER_CC4P | TIM_CCER_CC4NP), + ((TIM_ICInitStruct->ICPolarity << 12U) | TIM_CCER_CC4E)); + + return SUCCESS; +} + + +/** + * @} + */ + +/** + * @} + */ + +#endif /* TIM1 || TIM2 || TIM3 || TIM14 || TIM15 || TIM16 || TIM17 || TIM6 || TIM7 */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usart.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usart.c new file mode 100644 index 0000000..afb331e --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usart.c @@ -0,0 +1,504 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_usart.c + * @author MCD Application Team + * @brief USART LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ +#if defined(USE_FULL_LL_DRIVER) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_usart.h" +#include "stm32f0xx_ll_rcc.h" +#include "stm32f0xx_ll_bus.h" +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +#if defined (USART1) || defined (USART2) || defined (USART3) || defined (UART4) || defined (UART5) || defined (USART6) || defined (USART7) || defined (USART8) + +/** @addtogroup USART_LL + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup USART_LL_Private_Macros + * @{ + */ + +/* __BAUDRATE__ The maximum Baud Rate is derived from the maximum clock available + * divided by the smallest oversampling used on the USART (i.e. 8) */ +#define IS_LL_USART_BAUDRATE(__BAUDRATE__) ((__BAUDRATE__) <= 6000000U) + +/* __VALUE__ In case of oversampling by 16 and 8, BRR content must be greater than or equal to 16d. */ +#define IS_LL_USART_BRR_MIN(__VALUE__) ((__VALUE__) >= 16U) + +#define IS_LL_USART_DIRECTION(__VALUE__) (((__VALUE__) == LL_USART_DIRECTION_NONE) \ + || ((__VALUE__) == LL_USART_DIRECTION_RX) \ + || ((__VALUE__) == LL_USART_DIRECTION_TX) \ + || ((__VALUE__) == LL_USART_DIRECTION_TX_RX)) + +#define IS_LL_USART_PARITY(__VALUE__) (((__VALUE__) == LL_USART_PARITY_NONE) \ + || ((__VALUE__) == LL_USART_PARITY_EVEN) \ + || ((__VALUE__) == LL_USART_PARITY_ODD)) + +#if defined(USART_7BITS_SUPPORT) +#define IS_LL_USART_DATAWIDTH(__VALUE__) (((__VALUE__) == LL_USART_DATAWIDTH_7B) \ + || ((__VALUE__) == LL_USART_DATAWIDTH_8B) \ + || ((__VALUE__) == LL_USART_DATAWIDTH_9B)) +#else +#define IS_LL_USART_DATAWIDTH(__VALUE__) (((__VALUE__) == LL_USART_DATAWIDTH_8B) \ + || ((__VALUE__) == LL_USART_DATAWIDTH_9B)) +#endif /* USART_7BITS_SUPPORT */ + +#define IS_LL_USART_OVERSAMPLING(__VALUE__) (((__VALUE__) == LL_USART_OVERSAMPLING_16) \ + || ((__VALUE__) == LL_USART_OVERSAMPLING_8)) + +#define IS_LL_USART_LASTBITCLKOUTPUT(__VALUE__) (((__VALUE__) == LL_USART_LASTCLKPULSE_NO_OUTPUT) \ + || ((__VALUE__) == LL_USART_LASTCLKPULSE_OUTPUT)) + +#define IS_LL_USART_CLOCKPHASE(__VALUE__) (((__VALUE__) == LL_USART_PHASE_1EDGE) \ + || ((__VALUE__) == LL_USART_PHASE_2EDGE)) + +#define IS_LL_USART_CLOCKPOLARITY(__VALUE__) (((__VALUE__) == LL_USART_POLARITY_LOW) \ + || ((__VALUE__) == LL_USART_POLARITY_HIGH)) + +#define IS_LL_USART_CLOCKOUTPUT(__VALUE__) (((__VALUE__) == LL_USART_CLOCK_DISABLE) \ + || ((__VALUE__) == LL_USART_CLOCK_ENABLE)) + +#if defined(USART_SMARTCARD_SUPPORT) +#define IS_LL_USART_STOPBITS(__VALUE__) (((__VALUE__) == LL_USART_STOPBITS_0_5) \ + || ((__VALUE__) == LL_USART_STOPBITS_1) \ + || ((__VALUE__) == LL_USART_STOPBITS_1_5) \ + || ((__VALUE__) == LL_USART_STOPBITS_2)) +#else +#define IS_LL_USART_STOPBITS(__VALUE__) (((__VALUE__) == LL_USART_STOPBITS_1) \ + || ((__VALUE__) == LL_USART_STOPBITS_2)) +#endif + +#define IS_LL_USART_HWCONTROL(__VALUE__) (((__VALUE__) == LL_USART_HWCONTROL_NONE) \ + || ((__VALUE__) == LL_USART_HWCONTROL_RTS) \ + || ((__VALUE__) == LL_USART_HWCONTROL_CTS) \ + || ((__VALUE__) == LL_USART_HWCONTROL_RTS_CTS)) + +/** + * @} + */ + +/* Private function prototypes -----------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup USART_LL_Exported_Functions + * @{ + */ + +/** @addtogroup USART_LL_EF_Init + * @{ + */ + +/** + * @brief De-initialize USART registers (Registers restored to their default values). + * @param USARTx USART Instance + * @retval An ErrorStatus enumeration value: + * - SUCCESS: USART registers are de-initialized + * - ERROR: USART registers are not de-initialized + */ +ErrorStatus LL_USART_DeInit(USART_TypeDef *USARTx) +{ + ErrorStatus status = SUCCESS; + + /* Check the parameters */ + assert_param(IS_UART_INSTANCE(USARTx)); + + if (USARTx == USART1) + { + /* Force reset of USART clock */ + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_USART1); + + /* Release reset of USART clock */ + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_USART1); + } +#if defined(USART2) + else if (USARTx == USART2) + { + /* Force reset of USART clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_USART2); + + /* Release reset of USART clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_USART2); + } +#endif /* USART2 */ +#if defined(USART3) + else if (USARTx == USART3) + { + /* Force reset of USART clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_USART3); + + /* Release reset of USART clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_USART3); + } +#endif /* USART3 */ +#if defined(USART4) + else if (USARTx == USART4) + { + /* Force reset of USART clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_USART4); + + /* Release reset of USART clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_USART4); + } +#endif /* USART4 */ +#if defined(USART5) + else if (USARTx == USART5) + { + /* Force reset of USART clock */ + LL_APB1_GRP1_ForceReset(LL_APB1_GRP1_PERIPH_USART5); + + /* Release reset of USART clock */ + LL_APB1_GRP1_ReleaseReset(LL_APB1_GRP1_PERIPH_USART5); + } +#endif /* USART5 */ +#if defined(USART6) + else if (USARTx == USART6) + { + /* Force reset of USART clock */ + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_USART6); + + /* Release reset of USART clock */ + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_USART6); + } +#endif /* USART6 */ +#if defined(USART7) + else if (USARTx == USART7) + { + /* Force reset of USART clock */ + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_USART7); + + /* Release reset of USART clock */ + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_USART7); + } +#endif /* USART7 */ +#if defined(USART8) + else if (USARTx == USART8) + { + /* Force reset of USART clock */ + LL_APB1_GRP2_ForceReset(LL_APB1_GRP2_PERIPH_USART8); + + /* Release reset of USART clock */ + LL_APB1_GRP2_ReleaseReset(LL_APB1_GRP2_PERIPH_USART8); + } +#endif /* USART8 */ + else + { + status = ERROR; + } + + return (status); +} + +/** + * @brief Initialize USART registers according to the specified + * parameters in USART_InitStruct. + * @note As some bits in USART configuration registers can only be written when + * the USART is disabled (USART_CR1_UE bit =0), USART Peripheral should be in disabled state prior calling + * this function. Otherwise, ERROR result will be returned. + * @note Baud rate value stored in USART_InitStruct BaudRate field, should be valid (different from 0). + * @param USARTx USART Instance + * @param USART_InitStruct pointer to a LL_USART_InitTypeDef structure + * that contains the configuration information for the specified USART peripheral. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: USART registers are initialized according to USART_InitStruct content + * - ERROR: Problem occurred during USART Registers initialization + */ +ErrorStatus LL_USART_Init(USART_TypeDef *USARTx, LL_USART_InitTypeDef *USART_InitStruct) +{ + ErrorStatus status = ERROR; + uint32_t periphclk = LL_RCC_PERIPH_FREQUENCY_NO; +#if defined(USART2)||defined(USART3)||defined(USART4) + LL_RCC_ClocksTypeDef RCC_Clocks; +#endif /* USART2 ||USART3 || USART4 */ + + /* Check the parameters */ + assert_param(IS_UART_INSTANCE(USARTx)); + assert_param(IS_LL_USART_BAUDRATE(USART_InitStruct->BaudRate)); + assert_param(IS_LL_USART_DATAWIDTH(USART_InitStruct->DataWidth)); + assert_param(IS_LL_USART_STOPBITS(USART_InitStruct->StopBits)); + assert_param(IS_LL_USART_PARITY(USART_InitStruct->Parity)); + assert_param(IS_LL_USART_DIRECTION(USART_InitStruct->TransferDirection)); + assert_param(IS_LL_USART_HWCONTROL(USART_InitStruct->HardwareFlowControl)); + assert_param(IS_LL_USART_OVERSAMPLING(USART_InitStruct->OverSampling)); + + /* USART needs to be in disabled state, in order to be able to configure some bits in + CRx registers */ + if (LL_USART_IsEnabled(USARTx) == 0U) + { + /*---------------------------- USART CR1 Configuration --------------------- + * Configure USARTx CR1 (USART Word Length, Parity, Mode and Oversampling bits) with parameters: + * - DataWidth: USART_CR1_M bits according to USART_InitStruct->DataWidth value + * - Parity: USART_CR1_PCE, USART_CR1_PS bits according to USART_InitStruct->Parity value + * - TransferDirection: USART_CR1_TE, USART_CR1_RE bits according to USART_InitStruct->TransferDirection value + * - Oversampling: USART_CR1_OVER8 bit according to USART_InitStruct->OverSampling value. + */ + MODIFY_REG(USARTx->CR1, + (USART_CR1_M | USART_CR1_PCE | USART_CR1_PS | + USART_CR1_TE | USART_CR1_RE | USART_CR1_OVER8), + (USART_InitStruct->DataWidth | USART_InitStruct->Parity | + USART_InitStruct->TransferDirection | USART_InitStruct->OverSampling)); + + /*---------------------------- USART CR2 Configuration --------------------- + * Configure USARTx CR2 (Stop bits) with parameters: + * - Stop Bits: USART_CR2_STOP bits according to USART_InitStruct->StopBits value. + * - CLKEN, CPOL, CPHA and LBCL bits are to be configured using LL_USART_ClockInit(). + */ + LL_USART_SetStopBitsLength(USARTx, USART_InitStruct->StopBits); + + /*---------------------------- USART CR3 Configuration --------------------- + * Configure USARTx CR3 (Hardware Flow Control) with parameters: + * - HardwareFlowControl: USART_CR3_RTSE, USART_CR3_CTSE bits according to + * USART_InitStruct->HardwareFlowControl value. + */ + LL_USART_SetHWFlowCtrl(USARTx, USART_InitStruct->HardwareFlowControl); + + /*---------------------------- USART BRR Configuration --------------------- + * Retrieve Clock frequency used for USART Peripheral + */ + if (USARTx == USART1) + { + periphclk = LL_RCC_GetUSARTClockFreq(LL_RCC_USART1_CLKSOURCE); + } +#if defined(USART2) + else if (USARTx == USART2) + { +#if defined(RCC_CFGR3_USART2SW) + periphclk = LL_RCC_GetUSARTClockFreq(LL_RCC_USART2_CLKSOURCE); +#else + /* USART2 clock is PCLK */ + LL_RCC_GetSystemClocksFreq(&RCC_Clocks); + periphclk = RCC_Clocks.PCLK1_Frequency; +#endif + } +#endif /* USART2 */ +#if defined(USART3) + else if (USARTx == USART3) + { +#if defined(RCC_CFGR3_USART3SW) + periphclk = LL_RCC_GetUSARTClockFreq(LL_RCC_USART3_CLKSOURCE); +#else + /* USART3 clock is PCLK */ + LL_RCC_GetSystemClocksFreq(&RCC_Clocks); + periphclk = RCC_Clocks.PCLK1_Frequency; +#endif + } +#endif /* USART3 */ +#if defined(USART4) + else if (USARTx == USART4) + { + /* USART4 clock is PCLK1 */ + LL_RCC_GetSystemClocksFreq(&RCC_Clocks); + periphclk = RCC_Clocks.PCLK1_Frequency; + } +#endif /* USART4 */ +#if defined(USART5) + else if (USARTx == USART5) + { + /* USART5 clock is PCLK1 */ + LL_RCC_GetSystemClocksFreq(&RCC_Clocks); + periphclk = RCC_Clocks.PCLK1_Frequency; + } +#endif /* USART5 */ +#if defined(USART6) + else if (USARTx == USART6) + { + /* USART6 clock is PCLK1 */ + LL_RCC_GetSystemClocksFreq(&RCC_Clocks); + periphclk = RCC_Clocks.PCLK1_Frequency; + } +#endif /* USART6 */ +#if defined(USART7) + else if (USARTx == USART7) + { + /* USART7 clock is PCLK */ + LL_RCC_GetSystemClocksFreq(&RCC_Clocks); + periphclk = RCC_Clocks.PCLK1_Frequency; + } +#endif /* USART7 */ +#if defined(USART8) + else if (USARTx == USART8) + { + /* USART8 clock is PCLK */ + LL_RCC_GetSystemClocksFreq(&RCC_Clocks); + periphclk = RCC_Clocks.PCLK1_Frequency; + } +#endif /* USART8 */ + else + { + /* Nothing to do, as error code is already assigned to ERROR value */ + } + + /* Configure the USART Baud Rate : + - valid baud rate value (different from 0) is required + - Peripheral clock as returned by RCC service, should be valid (different from 0). + */ + if ((periphclk != LL_RCC_PERIPH_FREQUENCY_NO) + && (USART_InitStruct->BaudRate != 0U)) + { + status = SUCCESS; + LL_USART_SetBaudRate(USARTx, + periphclk, + USART_InitStruct->OverSampling, + USART_InitStruct->BaudRate); + + /* Check BRR is greater than or equal to 16d */ + assert_param(IS_LL_USART_BRR_MIN(USARTx->BRR)); + } + } + /* Endif (=> USART not in Disabled state => return ERROR) */ + + return (status); +} + +/** + * @brief Set each @ref LL_USART_InitTypeDef field to default value. + * @param USART_InitStruct pointer to a @ref LL_USART_InitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ + +void LL_USART_StructInit(LL_USART_InitTypeDef *USART_InitStruct) +{ + /* Set USART_InitStruct fields to default values */ + USART_InitStruct->BaudRate = 9600U; + USART_InitStruct->DataWidth = LL_USART_DATAWIDTH_8B; + USART_InitStruct->StopBits = LL_USART_STOPBITS_1; + USART_InitStruct->Parity = LL_USART_PARITY_NONE ; + USART_InitStruct->TransferDirection = LL_USART_DIRECTION_TX_RX; + USART_InitStruct->HardwareFlowControl = LL_USART_HWCONTROL_NONE; + USART_InitStruct->OverSampling = LL_USART_OVERSAMPLING_16; +} + +/** + * @brief Initialize USART Clock related settings according to the + * specified parameters in the USART_ClockInitStruct. + * @note As some bits in USART configuration registers can only be written when + * the USART is disabled (USART_CR1_UE bit =0), USART Peripheral should be in disabled state prior calling + * this function. Otherwise, ERROR result will be returned. + * @param USARTx USART Instance + * @param USART_ClockInitStruct pointer to a @ref LL_USART_ClockInitTypeDef structure + * that contains the Clock configuration information for the specified USART peripheral. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: USART registers related to Clock settings are initialized according + * to USART_ClockInitStruct content + * - ERROR: Problem occurred during USART Registers initialization + */ +ErrorStatus LL_USART_ClockInit(USART_TypeDef *USARTx, LL_USART_ClockInitTypeDef *USART_ClockInitStruct) +{ + ErrorStatus status = SUCCESS; + + /* Check USART Instance and Clock signal output parameters */ + assert_param(IS_UART_INSTANCE(USARTx)); + assert_param(IS_LL_USART_CLOCKOUTPUT(USART_ClockInitStruct->ClockOutput)); + + /* USART needs to be in disabled state, in order to be able to configure some bits in + CRx registers */ + if (LL_USART_IsEnabled(USARTx) == 0U) + { + /* If USART Clock signal is disabled */ + if (USART_ClockInitStruct->ClockOutput == LL_USART_CLOCK_DISABLE) + { + /* Deactivate Clock signal delivery : + * - Disable Clock Output: USART_CR2_CLKEN cleared + */ + LL_USART_DisableSCLKOutput(USARTx); + } + else + { + /* Ensure USART instance is USART capable */ + assert_param(IS_USART_INSTANCE(USARTx)); + + /* Check clock related parameters */ + assert_param(IS_LL_USART_CLOCKPOLARITY(USART_ClockInitStruct->ClockPolarity)); + assert_param(IS_LL_USART_CLOCKPHASE(USART_ClockInitStruct->ClockPhase)); + assert_param(IS_LL_USART_LASTBITCLKOUTPUT(USART_ClockInitStruct->LastBitClockPulse)); + + /*---------------------------- USART CR2 Configuration ----------------------- + * Configure USARTx CR2 (Clock signal related bits) with parameters: + * - Enable Clock Output: USART_CR2_CLKEN set + * - Clock Polarity: USART_CR2_CPOL bit according to USART_ClockInitStruct->ClockPolarity value + * - Clock Phase: USART_CR2_CPHA bit according to USART_ClockInitStruct->ClockPhase value + * - Last Bit Clock Pulse Output: USART_CR2_LBCL bit according to USART_ClockInitStruct->LastBitClockPulse value. + */ + MODIFY_REG(USARTx->CR2, + USART_CR2_CLKEN | USART_CR2_CPHA | USART_CR2_CPOL | USART_CR2_LBCL, + USART_CR2_CLKEN | USART_ClockInitStruct->ClockPolarity | + USART_ClockInitStruct->ClockPhase | USART_ClockInitStruct->LastBitClockPulse); + } + } + /* Else (USART not in Disabled state => return ERROR */ + else + { + status = ERROR; + } + + return (status); +} + +/** + * @brief Set each field of a @ref LL_USART_ClockInitTypeDef type structure to default value. + * @param USART_ClockInitStruct pointer to a @ref LL_USART_ClockInitTypeDef structure + * whose fields will be set to default values. + * @retval None + */ +void LL_USART_ClockStructInit(LL_USART_ClockInitTypeDef *USART_ClockInitStruct) +{ + /* Set LL_USART_ClockInitStruct fields with default values */ + USART_ClockInitStruct->ClockOutput = LL_USART_CLOCK_DISABLE; + USART_ClockInitStruct->ClockPolarity = LL_USART_POLARITY_LOW; /* Not relevant when ClockOutput = + LL_USART_CLOCK_DISABLE */ + USART_ClockInitStruct->ClockPhase = LL_USART_PHASE_1EDGE; /* Not relevant when ClockOutput = + LL_USART_CLOCK_DISABLE */ + USART_ClockInitStruct->LastBitClockPulse = LL_USART_LASTCLKPULSE_NO_OUTPUT; /* Not relevant when ClockOutput = + LL_USART_CLOCK_DISABLE */ +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* USART1 || USART2 || USART3 || UART4 || UART5 || USART6 || USART7 || USART8 */ + +/** + * @} + */ + +#endif /* USE_FULL_LL_DRIVER */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usb.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usb.c new file mode 100644 index 0000000..d08f257 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_usb.c @@ -0,0 +1,810 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_usb.c + * @author MCD Application Team + * @brief USB Low Layer HAL module driver. + * + * This file provides firmware functions to manage the following + * functionalities of the USB Peripheral Controller: + * + Initialization/de-initialization functions + * + I/O operation functions + * + Peripheral Control functions + * + Peripheral State functions + * + @verbatim + ============================================================================== + ##### How to use this driver ##### + ============================================================================== + [..] + (#) Fill parameters of Init structure in USB_OTG_CfgTypeDef structure. + + (#) Call USB_CoreInit() API to initialize the USB Core peripheral. + + (#) The upper HAL HCD/PCD driver will call the right routines for its internal processes. + + @endverbatim + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" + +/** @addtogroup STM32F0xx_LL_USB_DRIVER + * @{ + */ + +#if defined (HAL_PCD_MODULE_ENABLED) || defined (HAL_HCD_MODULE_ENABLED) +#if defined (USB) +/* Private typedef -----------------------------------------------------------*/ +/* Private define ------------------------------------------------------------*/ +/* Private macro -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private function prototypes -----------------------------------------------*/ +/* Private functions ---------------------------------------------------------*/ + + +/** + * @brief Initializes the USB Core + * @param USBx USB Instance + * @param cfg pointer to a USB_CfgTypeDef structure that contains + * the configuration information for the specified USBx peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef USB_CoreInit(USB_TypeDef *USBx, USB_CfgTypeDef cfg) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(USBx); + UNUSED(cfg); + + /* NOTE : - This function is not required by USB Device FS peripheral, it is used + only by USB OTG FS peripheral. + - This function is added to ensure compatibility across platforms. + */ + + return HAL_OK; +} + +/** + * @brief USB_EnableGlobalInt + * Enables the controller's Global Int in the AHB Config reg + * @param USBx Selected device + * @retval HAL status + */ +HAL_StatusTypeDef USB_EnableGlobalInt(USB_TypeDef *USBx) +{ + uint32_t winterruptmask; + + /* Clear pending interrupts */ + USBx->ISTR = 0U; + + /* Set winterruptmask variable */ + winterruptmask = USB_CNTR_CTRM | USB_CNTR_WKUPM | + USB_CNTR_SUSPM | USB_CNTR_ERRM | + USB_CNTR_SOFM | USB_CNTR_ESOFM | + USB_CNTR_RESETM | USB_CNTR_L1REQM; + + /* Set interrupt mask */ + USBx->CNTR = (uint16_t)winterruptmask; + + return HAL_OK; +} + +/** + * @brief USB_DisableGlobalInt + * Disable the controller's Global Int in the AHB Config reg + * @param USBx Selected device + * @retval HAL status + */ +HAL_StatusTypeDef USB_DisableGlobalInt(USB_TypeDef *USBx) +{ + uint32_t winterruptmask; + + /* Set winterruptmask variable */ + winterruptmask = USB_CNTR_CTRM | USB_CNTR_WKUPM | + USB_CNTR_SUSPM | USB_CNTR_ERRM | + USB_CNTR_SOFM | USB_CNTR_ESOFM | + USB_CNTR_RESETM | USB_CNTR_L1REQM; + + /* Clear interrupt mask */ + USBx->CNTR &= (uint16_t)(~winterruptmask); + + return HAL_OK; +} + +/** + * @brief USB_SetCurrentMode Set functional mode + * @param USBx Selected device + * @param mode current core mode + * This parameter can be one of the these values: + * @arg USB_DEVICE_MODE Peripheral mode + * @retval HAL status + */ +HAL_StatusTypeDef USB_SetCurrentMode(USB_TypeDef *USBx, USB_ModeTypeDef mode) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(USBx); + UNUSED(mode); + + /* NOTE : - This function is not required by USB Device FS peripheral, it is used + only by USB OTG FS peripheral. + - This function is added to ensure compatibility across platforms. + */ + return HAL_OK; +} + +/** + * @brief USB_DevInit Initializes the USB controller registers + * for device mode + * @param USBx Selected device + * @param cfg pointer to a USB_CfgTypeDef structure that contains + * the configuration information for the specified USBx peripheral. + * @retval HAL status + */ +HAL_StatusTypeDef USB_DevInit(USB_TypeDef *USBx, USB_CfgTypeDef cfg) +{ + /* Prevent unused argument(s) compilation warning */ + UNUSED(cfg); + + /* Init Device */ + /* CNTR_FRES = 1 */ + USBx->CNTR = (uint16_t)USB_CNTR_FRES; + + /* CNTR_FRES = 0 */ + USBx->CNTR = 0U; + + /* Clear pending interrupts */ + USBx->ISTR = 0U; + + /*Set Btable Address*/ + USBx->BTABLE = BTABLE_ADDRESS; + + return HAL_OK; +} + +#if defined (HAL_PCD_MODULE_ENABLED) +/** + * @brief Activate and configure an endpoint + * @param USBx Selected device + * @param ep pointer to endpoint structure + * @retval HAL status + */ +HAL_StatusTypeDef USB_ActivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep) +{ + HAL_StatusTypeDef ret = HAL_OK; + uint16_t wEpRegVal; + + wEpRegVal = PCD_GET_ENDPOINT(USBx, ep->num) & USB_EP_T_MASK; + + /* initialize Endpoint */ + switch (ep->type) + { + case EP_TYPE_CTRL: + wEpRegVal |= USB_EP_CONTROL; + break; + + case EP_TYPE_BULK: + wEpRegVal |= USB_EP_BULK; + break; + + case EP_TYPE_INTR: + wEpRegVal |= USB_EP_INTERRUPT; + break; + + case EP_TYPE_ISOC: + wEpRegVal |= USB_EP_ISOCHRONOUS; + break; + + default: + ret = HAL_ERROR; + break; + } + + PCD_SET_ENDPOINT(USBx, ep->num, (wEpRegVal | USB_EP_CTR_RX | USB_EP_CTR_TX)); + + PCD_SET_EP_ADDRESS(USBx, ep->num, ep->num); + + if (ep->doublebuffer == 0U) + { + if (ep->is_in != 0U) + { + /*Set the endpoint Transmit buffer address */ + PCD_SET_EP_TX_ADDRESS(USBx, ep->num, ep->pmaadress); + PCD_CLEAR_TX_DTOG(USBx, ep->num); + + if (ep->type != EP_TYPE_ISOC) + { + /* Configure NAK status for the Endpoint */ + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_NAK); + } + else + { + /* Configure TX Endpoint to disabled state */ + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_DIS); + } + } + else + { + /* Set the endpoint Receive buffer address */ + PCD_SET_EP_RX_ADDRESS(USBx, ep->num, ep->pmaadress); + + /* Set the endpoint Receive buffer counter */ + PCD_SET_EP_RX_CNT(USBx, ep->num, ep->maxpacket); + PCD_CLEAR_RX_DTOG(USBx, ep->num); + + /* Configure VALID status for the Endpoint */ + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_VALID); + } + } + /* Double Buffer */ + else + { + if (ep->type == EP_TYPE_BULK) + { + /* Set bulk endpoint as double buffered */ + PCD_SET_BULK_EP_DBUF(USBx, ep->num); + } + else + { + /* Set the ISOC endpoint in double buffer mode */ + PCD_CLEAR_EP_KIND(USBx, ep->num); + } + + /* Set buffer address for double buffered mode */ + PCD_SET_EP_DBUF_ADDR(USBx, ep->num, ep->pmaaddr0, ep->pmaaddr1); + + if (ep->is_in == 0U) + { + /* Clear the data toggle bits for the endpoint IN/OUT */ + PCD_CLEAR_RX_DTOG(USBx, ep->num); + PCD_CLEAR_TX_DTOG(USBx, ep->num); + + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_VALID); + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_DIS); + } + else + { + /* Clear the data toggle bits for the endpoint IN/OUT */ + PCD_CLEAR_RX_DTOG(USBx, ep->num); + PCD_CLEAR_TX_DTOG(USBx, ep->num); + + if (ep->type != EP_TYPE_ISOC) + { + /* Configure NAK status for the Endpoint */ + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_NAK); + } + else + { + /* Configure TX Endpoint to disabled state */ + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_DIS); + } + + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_DIS); + } + } + + return ret; +} + +/** + * @brief De-activate and de-initialize an endpoint + * @param USBx Selected device + * @param ep pointer to endpoint structure + * @retval HAL status + */ +HAL_StatusTypeDef USB_DeactivateEndpoint(USB_TypeDef *USBx, USB_EPTypeDef *ep) +{ + if (ep->doublebuffer == 0U) + { + if (ep->is_in != 0U) + { + PCD_CLEAR_TX_DTOG(USBx, ep->num); + + /* Configure DISABLE status for the Endpoint*/ + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_DIS); + } + else + { + PCD_CLEAR_RX_DTOG(USBx, ep->num); + + /* Configure DISABLE status for the Endpoint*/ + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_DIS); + } + } + /*Double Buffer*/ + else + { + if (ep->is_in == 0U) + { + /* Clear the data toggle bits for the endpoint IN/OUT*/ + PCD_CLEAR_RX_DTOG(USBx, ep->num); + PCD_CLEAR_TX_DTOG(USBx, ep->num); + + /* Reset value of the data toggle bits for the endpoint out*/ + PCD_TX_DTOG(USBx, ep->num); + + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_DIS); + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_DIS); + } + else + { + /* Clear the data toggle bits for the endpoint IN/OUT*/ + PCD_CLEAR_RX_DTOG(USBx, ep->num); + PCD_CLEAR_TX_DTOG(USBx, ep->num); + PCD_RX_DTOG(USBx, ep->num); + + /* Configure DISABLE status for the Endpoint*/ + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_DIS); + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_DIS); + } + } + + return HAL_OK; +} + +/** + * @brief USB_EPStartXfer setup and starts a transfer over an EP + * @param USBx Selected device + * @param ep pointer to endpoint structure + * @retval HAL status + */ +HAL_StatusTypeDef USB_EPStartXfer(USB_TypeDef *USBx, USB_EPTypeDef *ep) +{ + uint32_t len; + uint16_t pmabuffer; + uint16_t wEPVal; + + /* IN endpoint */ + if (ep->is_in == 1U) + { + /*Multi packet transfer*/ + if (ep->xfer_len > ep->maxpacket) + { + len = ep->maxpacket; + } + else + { + len = ep->xfer_len; + } + + /* configure and validate Tx endpoint */ + if (ep->doublebuffer == 0U) + { + USB_WritePMA(USBx, ep->xfer_buff, ep->pmaadress, (uint16_t)len); + PCD_SET_EP_TX_CNT(USBx, ep->num, len); + } + else + { + /* double buffer bulk management */ + if (ep->type == EP_TYPE_BULK) + { + if (ep->xfer_len_db > ep->maxpacket) + { + /* enable double buffer */ + PCD_SET_BULK_EP_DBUF(USBx, ep->num); + + /* each Time to write in PMA xfer_len_db will */ + ep->xfer_len_db -= len; + + /* Fill the two first buffer in the Buffer0 & Buffer1 */ + if ((PCD_GET_ENDPOINT(USBx, ep->num) & USB_EP_DTOG_TX) != 0U) + { + /* Set the Double buffer counter for pmabuffer1 */ + PCD_SET_EP_DBUF1_CNT(USBx, ep->num, ep->is_in, len); + pmabuffer = ep->pmaaddr1; + + /* Write the user buffer to USB PMA */ + USB_WritePMA(USBx, ep->xfer_buff, pmabuffer, (uint16_t)len); + ep->xfer_buff += len; + + if (ep->xfer_len_db > ep->maxpacket) + { + ep->xfer_len_db -= len; + } + else + { + len = ep->xfer_len_db; + ep->xfer_len_db = 0U; + } + + /* Set the Double buffer counter for pmabuffer0 */ + PCD_SET_EP_DBUF0_CNT(USBx, ep->num, ep->is_in, len); + pmabuffer = ep->pmaaddr0; + + /* Write the user buffer to USB PMA */ + USB_WritePMA(USBx, ep->xfer_buff, pmabuffer, (uint16_t)len); + } + else + { + /* Set the Double buffer counter for pmabuffer0 */ + PCD_SET_EP_DBUF0_CNT(USBx, ep->num, ep->is_in, len); + pmabuffer = ep->pmaaddr0; + + /* Write the user buffer to USB PMA */ + USB_WritePMA(USBx, ep->xfer_buff, pmabuffer, (uint16_t)len); + ep->xfer_buff += len; + + if (ep->xfer_len_db > ep->maxpacket) + { + ep->xfer_len_db -= len; + } + else + { + len = ep->xfer_len_db; + ep->xfer_len_db = 0U; + } + + /* Set the Double buffer counter for pmabuffer1 */ + PCD_SET_EP_DBUF1_CNT(USBx, ep->num, ep->is_in, len); + pmabuffer = ep->pmaaddr1; + + /* Write the user buffer to USB PMA */ + USB_WritePMA(USBx, ep->xfer_buff, pmabuffer, (uint16_t)len); + } + } + /* auto Switch to single buffer mode when transfer xfer_len_db; + + /* disable double buffer mode for Bulk endpoint */ + PCD_CLEAR_BULK_EP_DBUF(USBx, ep->num); + + /* Set Tx count with nbre of byte to be transmitted */ + PCD_SET_EP_TX_CNT(USBx, ep->num, len); + pmabuffer = ep->pmaaddr0; + + /* Write the user buffer to USB PMA */ + USB_WritePMA(USBx, ep->xfer_buff, pmabuffer, (uint16_t)len); + } + } + else /* manage isochronous double buffer IN mode */ + { + /* each Time to write in PMA xfer_len_db will */ + ep->xfer_len_db -= len; + + /* Fill the data buffer */ + if ((PCD_GET_ENDPOINT(USBx, ep->num) & USB_EP_DTOG_TX) != 0U) + { + /* Set the Double buffer counter for pmabuffer1 */ + PCD_SET_EP_DBUF1_CNT(USBx, ep->num, ep->is_in, len); + pmabuffer = ep->pmaaddr1; + + /* Write the user buffer to USB PMA */ + USB_WritePMA(USBx, ep->xfer_buff, pmabuffer, (uint16_t)len); + } + else + { + /* Set the Double buffer counter for pmabuffer0 */ + PCD_SET_EP_DBUF0_CNT(USBx, ep->num, ep->is_in, len); + pmabuffer = ep->pmaaddr0; + + /* Write the user buffer to USB PMA */ + USB_WritePMA(USBx, ep->xfer_buff, pmabuffer, (uint16_t)len); + } + } + } + + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_VALID); + } + else /* OUT endpoint */ + { + if (ep->doublebuffer == 0U) + { + /* Multi packet transfer */ + if (ep->xfer_len > ep->maxpacket) + { + len = ep->maxpacket; + ep->xfer_len -= len; + } + else + { + len = ep->xfer_len; + ep->xfer_len = 0U; + } + /* configure and validate Rx endpoint */ + PCD_SET_EP_RX_CNT(USBx, ep->num, len); + } + else + { + /* First Transfer Coming From HAL_PCD_EP_Receive & From ISR */ + /* Set the Double buffer counter */ + if (ep->type == EP_TYPE_BULK) + { + PCD_SET_EP_DBUF_CNT(USBx, ep->num, ep->is_in, ep->maxpacket); + + /* Coming from ISR */ + if (ep->xfer_count != 0U) + { + /* update last value to check if there is blocking state */ + wEPVal = PCD_GET_ENDPOINT(USBx, ep->num); + + /*Blocking State */ + if ((((wEPVal & USB_EP_DTOG_RX) != 0U) && ((wEPVal & USB_EP_DTOG_TX) != 0U)) || + (((wEPVal & USB_EP_DTOG_RX) == 0U) && ((wEPVal & USB_EP_DTOG_TX) == 0U))) + { + PCD_FreeUserBuffer(USBx, ep->num, 0U); + } + } + } + /* iso out double */ + else if (ep->type == EP_TYPE_ISOC) + { + /* Multi packet transfer */ + if (ep->xfer_len > ep->maxpacket) + { + len = ep->maxpacket; + ep->xfer_len -= len; + } + else + { + len = ep->xfer_len; + ep->xfer_len = 0U; + } + PCD_SET_EP_DBUF_CNT(USBx, ep->num, ep->is_in, len); + } + else + { + return HAL_ERROR; + } + } + + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_VALID); + } + + return HAL_OK; +} + + +/** + * @brief USB_EPSetStall set a stall condition over an EP + * @param USBx Selected device + * @param ep pointer to endpoint structure + * @retval HAL status + */ +HAL_StatusTypeDef USB_EPSetStall(USB_TypeDef *USBx, USB_EPTypeDef *ep) +{ + if (ep->is_in != 0U) + { + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_STALL); + } + else + { + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_STALL); + } + + return HAL_OK; +} + +/** + * @brief USB_EPClearStall Clear a stall condition over an EP + * @param USBx Selected device + * @param ep pointer to endpoint structure + * @retval HAL status + */ +HAL_StatusTypeDef USB_EPClearStall(USB_TypeDef *USBx, USB_EPTypeDef *ep) +{ + if (ep->doublebuffer == 0U) + { + if (ep->is_in != 0U) + { + PCD_CLEAR_TX_DTOG(USBx, ep->num); + + if (ep->type != EP_TYPE_ISOC) + { + /* Configure NAK status for the Endpoint */ + PCD_SET_EP_TX_STATUS(USBx, ep->num, USB_EP_TX_NAK); + } + } + else + { + PCD_CLEAR_RX_DTOG(USBx, ep->num); + + /* Configure VALID status for the Endpoint */ + PCD_SET_EP_RX_STATUS(USBx, ep->num, USB_EP_RX_VALID); + } + } + + return HAL_OK; +} +#endif /* defined (HAL_PCD_MODULE_ENABLED) */ + +/** + * @brief USB_StopDevice Stop the usb device mode + * @param USBx Selected device + * @retval HAL status + */ +HAL_StatusTypeDef USB_StopDevice(USB_TypeDef *USBx) +{ + /* disable all interrupts and force USB reset */ + USBx->CNTR = (uint16_t)USB_CNTR_FRES; + + /* clear interrupt status register */ + USBx->ISTR = 0U; + + /* switch-off device */ + USBx->CNTR = (uint16_t)(USB_CNTR_FRES | USB_CNTR_PDWN); + + return HAL_OK; +} + +/** + * @brief USB_SetDevAddress Stop the usb device mode + * @param USBx Selected device + * @param address new device address to be assigned + * This parameter can be a value from 0 to 255 + * @retval HAL status + */ +HAL_StatusTypeDef USB_SetDevAddress(USB_TypeDef *USBx, uint8_t address) +{ + if (address == 0U) + { + /* set device address and enable function */ + USBx->DADDR = (uint16_t)USB_DADDR_EF; + } + + return HAL_OK; +} + +/** + * @brief USB_DevConnect Connect the USB device by enabling the pull-up/pull-down + * @param USBx Selected device + * @retval HAL status + */ +HAL_StatusTypeDef USB_DevConnect(USB_TypeDef *USBx) +{ + /* Enabling DP Pull-UP bit to Connect internal PU resistor on USB DP line */ + USBx->BCDR |= (uint16_t)USB_BCDR_DPPU; + + return HAL_OK; +} + +/** + * @brief USB_DevDisconnect Disconnect the USB device by disabling the pull-up/pull-down + * @param USBx Selected device + * @retval HAL status + */ +HAL_StatusTypeDef USB_DevDisconnect(USB_TypeDef *USBx) +{ + /* Disable DP Pull-Up bit to disconnect the Internal PU resistor on USB DP line */ + USBx->BCDR &= (uint16_t)(~(USB_BCDR_DPPU)); + + return HAL_OK; +} + +/** + * @brief USB_ReadInterrupts return the global USB interrupt status + * @param USBx Selected device + * @retval HAL status + */ +uint32_t USB_ReadInterrupts(USB_TypeDef *USBx) +{ + uint32_t tmpreg; + + tmpreg = USBx->ISTR; + return tmpreg; +} + +/** + * @brief USB_ActivateRemoteWakeup : active remote wakeup signalling + * @param USBx Selected device + * @retval HAL status + */ +HAL_StatusTypeDef USB_ActivateRemoteWakeup(USB_TypeDef *USBx) +{ + USBx->CNTR |= (uint16_t)USB_CNTR_RESUME; + + return HAL_OK; +} + +/** + * @brief USB_DeActivateRemoteWakeup de-active remote wakeup signalling + * @param USBx Selected device + * @retval HAL status + */ +HAL_StatusTypeDef USB_DeActivateRemoteWakeup(USB_TypeDef *USBx) +{ + USBx->CNTR &= (uint16_t)(~USB_CNTR_RESUME); + + return HAL_OK; +} + +/** + * @brief Copy a buffer from user memory area to packet memory area (PMA) + * @param USBx USB peripheral instance register address. + * @param pbUsrBuf pointer to user memory area. + * @param wPMABufAddr address into PMA. + * @param wNBytes no. of bytes to be copied. + * @retval None + */ +void USB_WritePMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf, uint16_t wPMABufAddr, uint16_t wNBytes) +{ + uint32_t n = ((uint32_t)wNBytes + 1U) >> 1; + uint32_t BaseAddr = (uint32_t)USBx; + uint32_t i, temp1, temp2; + __IO uint16_t *pdwVal; + uint8_t *pBuf = pbUsrBuf; + + pdwVal = (__IO uint16_t *)(BaseAddr + 0x400U + ((uint32_t)wPMABufAddr * PMA_ACCESS)); + + for (i = n; i != 0U; i--) + { + temp1 = *pBuf; + pBuf++; + temp2 = temp1 | ((uint16_t)((uint16_t) *pBuf << 8)); + *pdwVal = (uint16_t)temp2; + pdwVal++; + +#if PMA_ACCESS > 1U + pdwVal++; +#endif + + pBuf++; + } +} + +/** + * @brief Copy data from packet memory area (PMA) to user memory buffer + * @param USBx USB peripheral instance register address. + * @param pbUsrBuf pointer to user memory area. + * @param wPMABufAddr address into PMA. + * @param wNBytes no. of bytes to be copied. + * @retval None + */ +void USB_ReadPMA(USB_TypeDef *USBx, uint8_t *pbUsrBuf, uint16_t wPMABufAddr, uint16_t wNBytes) +{ + uint32_t n = (uint32_t)wNBytes >> 1; + uint32_t BaseAddr = (uint32_t)USBx; + uint32_t i, temp; + __IO uint16_t *pdwVal; + uint8_t *pBuf = pbUsrBuf; + + pdwVal = (__IO uint16_t *)(BaseAddr + 0x400U + ((uint32_t)wPMABufAddr * PMA_ACCESS)); + + for (i = n; i != 0U; i--) + { + temp = *(__IO uint16_t *)pdwVal; + pdwVal++; + *pBuf = (uint8_t)((temp >> 0) & 0xFFU); + pBuf++; + *pBuf = (uint8_t)((temp >> 8) & 0xFFU); + pBuf++; + +#if PMA_ACCESS > 1U + pdwVal++; +#endif + } + + if ((wNBytes % 2U) != 0U) + { + temp = *pdwVal; + *pBuf = (uint8_t)((temp >> 0) & 0xFFU); + } +} + + +/** + * @} + */ + +/** + * @} + */ +#endif /* defined (USB) */ +#endif /* defined (HAL_PCD_MODULE_ENABLED) || defined (HAL_HCD_MODULE_ENABLED) */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_utils.c b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_utils.c new file mode 100644 index 0000000..f3a7836 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Src/stm32f0xx_ll_utils.c @@ -0,0 +1,622 @@ +/** + ****************************************************************************** + * @file stm32f0xx_ll_utils.c + * @author MCD Application Team + * @brief UTILS LL module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_ll_rcc.h" +#include "stm32f0xx_ll_utils.h" +#include "stm32f0xx_ll_system.h" +#ifdef USE_FULL_ASSERT +#include "stm32_assert.h" +#else +#define assert_param(expr) ((void)0U) +#endif + +/** @addtogroup STM32F0xx_LL_Driver + * @{ + */ + +/** @addtogroup UTILS_LL + * @{ + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @addtogroup UTILS_LL_Private_Constants + * @{ + */ + +/* Defines used for PLL range */ +#define UTILS_PLL_OUTPUT_MIN 16000000U /*!< Frequency min for PLL output, in Hz */ +#define UTILS_PLL_OUTPUT_MAX 48000000U /*!< Frequency max for PLL output, in Hz */ + +/* Defines used for HSE range */ +#define UTILS_HSE_FREQUENCY_MIN 4000000U /*!< Frequency min for HSE frequency, in Hz */ +#define UTILS_HSE_FREQUENCY_MAX 32000000U /*!< Frequency max for HSE frequency, in Hz */ + +/* Defines used for FLASH latency according to SYSCLK Frequency */ +#define UTILS_LATENCY1_FREQ 24000000U /*!< SYSCLK frequency to set FLASH latency 1 */ +/** + * @} + */ +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup UTILS_LL_Private_Macros + * @{ + */ +#define IS_LL_UTILS_SYSCLK_DIV(__VALUE__) (((__VALUE__) == LL_RCC_SYSCLK_DIV_1) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_2) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_4) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_8) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_16) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_64) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_128) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_256) \ + || ((__VALUE__) == LL_RCC_SYSCLK_DIV_512)) + +#define IS_LL_UTILS_APB1_DIV(__VALUE__) (((__VALUE__) == LL_RCC_APB1_DIV_1) \ + || ((__VALUE__) == LL_RCC_APB1_DIV_2) \ + || ((__VALUE__) == LL_RCC_APB1_DIV_4) \ + || ((__VALUE__) == LL_RCC_APB1_DIV_8) \ + || ((__VALUE__) == LL_RCC_APB1_DIV_16)) + +#define IS_LL_UTILS_PLLMUL_VALUE(__VALUE__) (((__VALUE__) == LL_RCC_PLL_MUL_2) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_3) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_4) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_5) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_6) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_7) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_8) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_9) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_10) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_11) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_12) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_13) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_14) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_15) \ + || ((__VALUE__) == LL_RCC_PLL_MUL_16)) + +#define IS_LL_UTILS_PREDIV_VALUE(__VALUE__) (((__VALUE__) == LL_RCC_PREDIV_DIV_1) || ((__VALUE__) == LL_RCC_PREDIV_DIV_2) || \ + ((__VALUE__) == LL_RCC_PREDIV_DIV_3) || ((__VALUE__) == LL_RCC_PREDIV_DIV_4) || \ + ((__VALUE__) == LL_RCC_PREDIV_DIV_5) || ((__VALUE__) == LL_RCC_PREDIV_DIV_6) || \ + ((__VALUE__) == LL_RCC_PREDIV_DIV_7) || ((__VALUE__) == LL_RCC_PREDIV_DIV_8) || \ + ((__VALUE__) == LL_RCC_PREDIV_DIV_9) || ((__VALUE__) == LL_RCC_PREDIV_DIV_10) || \ + ((__VALUE__) == LL_RCC_PREDIV_DIV_11) || ((__VALUE__) == LL_RCC_PREDIV_DIV_12) || \ + ((__VALUE__) == LL_RCC_PREDIV_DIV_13) || ((__VALUE__) == LL_RCC_PREDIV_DIV_14) || \ + ((__VALUE__) == LL_RCC_PREDIV_DIV_15) || ((__VALUE__) == LL_RCC_PREDIV_DIV_16)) + +#define IS_LL_UTILS_PLL_FREQUENCY(__VALUE__) ((UTILS_PLL_OUTPUT_MIN <= (__VALUE__)) && ((__VALUE__) <= UTILS_PLL_OUTPUT_MAX)) + + +#define IS_LL_UTILS_HSE_BYPASS(__STATE__) (((__STATE__) == LL_UTILS_HSEBYPASS_ON) \ + || ((__STATE__) == LL_UTILS_HSEBYPASS_OFF)) + +#define IS_LL_UTILS_HSE_FREQUENCY(__FREQUENCY__) (((__FREQUENCY__) >= UTILS_HSE_FREQUENCY_MIN) && ((__FREQUENCY__) <= UTILS_HSE_FREQUENCY_MAX)) +/** + * @} + */ +/* Private function prototypes -----------------------------------------------*/ +/** @defgroup UTILS_LL_Private_Functions UTILS Private functions + * @{ + */ +static uint32_t UTILS_GetPLLOutputFrequency(uint32_t PLL_InputFrequency, + LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct); +static ErrorStatus UTILS_EnablePLLAndSwitchSystem(uint32_t SYSCLK_Frequency, LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct); +static ErrorStatus UTILS_PLL_IsBusy(void); +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup UTILS_LL_Exported_Functions + * @{ + */ + +/** @addtogroup UTILS_LL_EF_DELAY + * @{ + */ + +/** + * @brief This function configures the Cortex-M SysTick source to have 1ms time base. + * @note When a RTOS is used, it is recommended to avoid changing the Systick + * configuration by calling this function, for a delay use rather osDelay RTOS service. + * @param HCLKFrequency HCLK frequency in Hz + * @note HCLK frequency can be calculated thanks to RCC helper macro or function @ref LL_RCC_GetSystemClocksFreq + * @retval None + */ +void LL_Init1msTick(uint32_t HCLKFrequency) +{ + /* Use frequency provided in argument */ + LL_InitTick(HCLKFrequency, 1000U); +} + +/** + * @brief This function provides accurate delay (in milliseconds) based + * on SysTick counter flag + * @note When a RTOS is used, it is recommended to avoid using blocking delay + * and use rather osDelay service. + * @note To respect 1ms timebase, user should call @ref LL_Init1msTick function which + * will configure Systick to 1ms + * @param Delay specifies the delay time length, in milliseconds. + * @retval None + */ +void LL_mDelay(uint32_t Delay) +{ + __IO uint32_t tmp = SysTick->CTRL; /* Clear the COUNTFLAG first */ + /* Add this code to indicate that local variable is not used */ + ((void)tmp); + + /* Add a period to guaranty minimum wait */ + if (Delay < LL_MAX_DELAY) + { + Delay++; + } + + while (Delay) + { + if ((SysTick->CTRL & SysTick_CTRL_COUNTFLAG_Msk) != 0U) + { + Delay--; + } + } +} + +/** + * @} + */ + +/** @addtogroup UTILS_EF_SYSTEM + * @brief System Configuration functions + * + @verbatim + =============================================================================== + ##### System Configuration functions ##### + =============================================================================== + [..] + System, AHB and APB buses clocks configuration + + (+) The maximum frequency of the SYSCLK, HCLK, PCLK1 and PCLK2 is 48000000 Hz. + @endverbatim + @internal + Depending on the SYSCLK frequency, the flash latency should be adapted accordingly: + (++) +-----------------------------------------------+ + (++) | Latency | SYSCLK clock frequency (MHz) | + (++) |---------------|-------------------------------| + (++) |0WS(1CPU cycle)| 0 < SYSCLK <= 24 | + (++) |---------------|-------------------------------| + (++) |1WS(2CPU cycle)| 24 < SYSCLK <= 48 | + (++) +-----------------------------------------------+ + @endinternal + * @{ + */ + +/** + * @brief This function sets directly SystemCoreClock CMSIS variable. + * @note Variable can be calculated also through SystemCoreClockUpdate function. + * @param HCLKFrequency HCLK frequency in Hz (can be calculated thanks to RCC helper macro) + * @retval None + */ +void LL_SetSystemCoreClock(uint32_t HCLKFrequency) +{ + /* HCLK clock frequency */ + SystemCoreClock = HCLKFrequency; +} + +/** + * @brief Update number of Flash wait states in line with new frequency and current + voltage range. + * @param Frequency SYSCLK frequency + * @retval An ErrorStatus enumeration value: + * - SUCCESS: Latency has been modified + * - ERROR: Latency cannot be modified + */ +#if defined(FLASH_ACR_LATENCY) +ErrorStatus LL_SetFlashLatency(uint32_t Frequency) +{ + uint32_t timeout; + uint32_t getlatency; + uint32_t latency; + ErrorStatus status = SUCCESS; + + /* Frequency cannot be equal to 0 */ + if (Frequency == 0U) + { + status = ERROR; + } + else + { + if (Frequency > UTILS_LATENCY1_FREQ) + { + /* 24 < SYSCLK <= 48 => 1WS (2 CPU cycles) */ + latency = LL_FLASH_LATENCY_1; + } + else + { + /* else SYSCLK < 24MHz default LL_FLASH_LATENCY_0 0WS */ + latency = LL_FLASH_LATENCY_0; + } + if (status != ERROR) + { + LL_FLASH_SetLatency(latency); + + /* Check that the new number of wait states is taken into account to access the Flash + memory by reading the FLASH_ACR register */ + timeout = 2; + do + { + /* Wait for Flash latency to be updated */ + getlatency = LL_FLASH_GetLatency(); + timeout--; + } while ((getlatency != latency) && (timeout > 0)); + + if(getlatency != latency) + { + status = ERROR; + } + else + { + status = SUCCESS; + } + } + } + + return status; +} +#endif /* FLASH_ACR_LATENCY */ + +/** + * @brief This function configures system clock with HSI as clock source of the PLL + * @note The application need to ensure that PLL is disabled. + * @note Function is based on the following formula: + * - PLL output frequency = ((HSI frequency / PREDIV) * PLLMUL) + * - PREDIV: Set to 2 for few devices + * - PLLMUL: The application software must set correctly the PLL multiplication factor to + * be in the range 16-48MHz + * @note FLASH latency can be modified through this function. + * @param UTILS_PLLInitStruct pointer to a @ref LL_UTILS_PLLInitTypeDef structure that contains + * the configuration information for the PLL. + * @param UTILS_ClkInitStruct pointer to a @ref LL_UTILS_ClkInitTypeDef structure that contains + * the configuration information for the BUS prescalers. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: Max frequency configuration done + * - ERROR: Max frequency configuration not done + */ +ErrorStatus LL_PLL_ConfigSystemClock_HSI(LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, + LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct) +{ + ErrorStatus status = SUCCESS; + uint32_t pllfreq = 0U; + + /* Check if one of the PLL is enabled */ + if (UTILS_PLL_IsBusy() == SUCCESS) + { +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + /* Check PREDIV value */ + assert_param(IS_LL_UTILS_PREDIV_VALUE(UTILS_PLLInitStruct->PLLDiv)); +#else + /* Force PREDIV value to 2 */ + UTILS_PLLInitStruct->Prediv = LL_RCC_PREDIV_DIV_2; +#endif /*RCC_PLLSRC_PREDIV1_SUPPORT*/ + /* Calculate the new PLL output frequency */ + pllfreq = UTILS_GetPLLOutputFrequency(HSI_VALUE, UTILS_PLLInitStruct); + + /* Enable HSI if not enabled */ + if (LL_RCC_HSI_IsReady() != 1U) + { + LL_RCC_HSI_Enable(); + while (LL_RCC_HSI_IsReady() != 1U) + { + /* Wait for HSI ready */ + } + } + + /* Configure PLL */ +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSI, UTILS_PLLInitStruct->PLLMul, UTILS_PLLInitStruct->PLLDiv); +#else + LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSI_DIV_2, UTILS_PLLInitStruct->PLLMul); +#endif /*RCC_PLLSRC_PREDIV1_SUPPORT*/ + + /* Enable PLL and switch system clock to PLL */ + status = UTILS_EnablePLLAndSwitchSystem(pllfreq, UTILS_ClkInitStruct); + } + else + { + /* Current PLL configuration cannot be modified */ + status = ERROR; + } + + return status; +} + +#if defined(RCC_CFGR_SW_HSI48) +/** + * @brief This function configures system clock with HSI48 as clock source of the PLL + * @note The application need to ensure that PLL is disabled. + * @note Function is based on the following formula: + * - PLL output frequency = ((HSI48 frequency / PREDIV) * PLLMUL) + * - PLLMUL: The application software must set correctly the PLL multiplication factor to + * be in the range 16-48MHz + * @param UTILS_PLLInitStruct pointer to a @ref LL_UTILS_PLLInitTypeDef structure that contains + * the configuration information for the PLL. + * @param UTILS_ClkInitStruct pointer to a @ref LL_UTILS_ClkInitTypeDef structure that contains + * the configuration information for the BUS prescalers. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: Max frequency configuration done + * - ERROR: Max frequency configuration not done + */ +ErrorStatus LL_PLL_ConfigSystemClock_HSI48(LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, + LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct) +{ + ErrorStatus status = SUCCESS; + uint32_t pllfreq = 0U; + + /* Check if one of the PLL is enabled */ + if (UTILS_PLL_IsBusy() == SUCCESS) + { + /* Check PREDIV value */ + assert_param(IS_LL_UTILS_PREDIV_VALUE(UTILS_PLLInitStruct->PLLDiv)); + + /* Calculate the new PLL output frequency */ + pllfreq = UTILS_GetPLLOutputFrequency(HSI48_VALUE, UTILS_PLLInitStruct); + + /* Enable HSI48 if not enabled */ + if (LL_RCC_HSI48_IsReady() != 1U) + { + LL_RCC_HSI48_Enable(); + while (LL_RCC_HSI48_IsReady() != 1U) + { + /* Wait for HSI48 ready */ + } + } + + /* Configure PLL */ + LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSI48, UTILS_PLLInitStruct->PLLMul, UTILS_PLLInitStruct->PLLDiv); + + /* Enable PLL and switch system clock to PLL */ + status = UTILS_EnablePLLAndSwitchSystem(pllfreq, UTILS_ClkInitStruct); + } + else + { + /* Current PLL configuration cannot be modified */ + status = ERROR; + } + + return status; +} + +#endif /*RCC_CFGR_SW_HSI48*/ +/** + * @brief This function configures system clock with HSE as clock source of the PLL + * @note The application need to ensure that PLL is disabled. + * @note Function is based on the following formula: + * - PLL output frequency = ((HSE frequency / PREDIV) * PLLMUL) + * - PLLMUL: The application software must set correctly the PLL multiplication factor to + * be in the range 16-48MHz + * @note FLASH latency can be modified through this function. + * @param HSEFrequency Value between Min_Data = 4000000 and Max_Data = 32000000 + * @param HSEBypass This parameter can be one of the following values: + * @arg @ref LL_UTILS_HSEBYPASS_ON + * @arg @ref LL_UTILS_HSEBYPASS_OFF + * @param UTILS_PLLInitStruct pointer to a @ref LL_UTILS_PLLInitTypeDef structure that contains + * the configuration information for the PLL. + * @param UTILS_ClkInitStruct pointer to a @ref LL_UTILS_ClkInitTypeDef structure that contains + * the configuration information for the BUS prescalers. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: Max frequency configuration done + * - ERROR: Max frequency configuration not done + */ +ErrorStatus LL_PLL_ConfigSystemClock_HSE(uint32_t HSEFrequency, uint32_t HSEBypass, + LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct, LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct) +{ + ErrorStatus status = SUCCESS; + uint32_t pllfreq = 0U; + + /* Check the parameters */ + assert_param(IS_LL_UTILS_HSE_FREQUENCY(HSEFrequency)); + assert_param(IS_LL_UTILS_HSE_BYPASS(HSEBypass)); + + /* Check if one of the PLL is enabled */ + if (UTILS_PLL_IsBusy() == SUCCESS) + { + /* Check PREDIV value */ +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + assert_param(IS_LL_UTILS_PREDIV_VALUE(UTILS_PLLInitStruct->PLLDiv)); +#else + assert_param(IS_LL_UTILS_PREDIV_VALUE(UTILS_PLLInitStruct->Prediv)); +#endif /*RCC_PLLSRC_PREDIV1_SUPPORT*/ + + /* Calculate the new PLL output frequency */ + pllfreq = UTILS_GetPLLOutputFrequency(HSEFrequency, UTILS_PLLInitStruct); + + /* Enable HSE if not enabled */ + if (LL_RCC_HSE_IsReady() != 1U) + { + /* Check if need to enable HSE bypass feature or not */ + if (HSEBypass == LL_UTILS_HSEBYPASS_ON) + { + LL_RCC_HSE_EnableBypass(); + } + else + { + LL_RCC_HSE_DisableBypass(); + } + + /* Enable HSE */ + LL_RCC_HSE_Enable(); + while (LL_RCC_HSE_IsReady() != 1U) + { + /* Wait for HSE ready */ + } + } + + /* Configure PLL */ +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + LL_RCC_PLL_ConfigDomain_SYS(LL_RCC_PLLSOURCE_HSE, UTILS_PLLInitStruct->PLLMul, UTILS_PLLInitStruct->PLLDiv); +#else + LL_RCC_PLL_ConfigDomain_SYS((RCC_CFGR_PLLSRC_HSE_PREDIV | UTILS_PLLInitStruct->Prediv), UTILS_PLLInitStruct->PLLMul); +#endif /*RCC_PLLSRC_PREDIV1_SUPPORT*/ + + /* Enable PLL and switch system clock to PLL */ + status = UTILS_EnablePLLAndSwitchSystem(pllfreq, UTILS_ClkInitStruct); + } + else + { + /* Current PLL configuration cannot be modified */ + status = ERROR; + } + + return status; +} + +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup UTILS_LL_Private_Functions + * @{ + */ +/** + * @brief Function to check that PLL can be modified + * @param PLL_InputFrequency PLL input frequency (in Hz) + * @param UTILS_PLLInitStruct pointer to a @ref LL_UTILS_PLLInitTypeDef structure that contains + * the configuration information for the PLL. + * @retval PLL output frequency (in Hz) + */ +static uint32_t UTILS_GetPLLOutputFrequency(uint32_t PLL_InputFrequency, LL_UTILS_PLLInitTypeDef *UTILS_PLLInitStruct) +{ + uint32_t pllfreq = 0U; + + /* Check the parameters */ + assert_param(IS_LL_UTILS_PLLMUL_VALUE(UTILS_PLLInitStruct->PLLMul)); + + /* Check different PLL parameters according to RM */ + /* The application software must set correctly the PLL multiplication factor to + be in the range 16-48MHz */ +#if defined(RCC_PLLSRC_PREDIV1_SUPPORT) + pllfreq = __LL_RCC_CALC_PLLCLK_FREQ(PLL_InputFrequency, UTILS_PLLInitStruct->PLLMul, UTILS_PLLInitStruct->PLLDiv); +#else + pllfreq = __LL_RCC_CALC_PLLCLK_FREQ(PLL_InputFrequency / (UTILS_PLLInitStruct->Prediv + 1U), UTILS_PLLInitStruct->PLLMul); +#endif /*RCC_PLLSRC_PREDIV1_SUPPORT*/ + assert_param(IS_LL_UTILS_PLL_FREQUENCY(pllfreq)); + + return pllfreq; +} + +/** + * @brief Function to check that PLL can be modified + * @retval An ErrorStatus enumeration value: + * - SUCCESS: PLL modification can be done + * - ERROR: PLL is busy + */ +static ErrorStatus UTILS_PLL_IsBusy(void) +{ + ErrorStatus status = SUCCESS; + + /* Check if PLL is busy*/ + if (LL_RCC_PLL_IsReady() != 0U) + { + /* PLL configuration cannot be modified */ + status = ERROR; + } + + return status; +} + +/** + * @brief Function to enable PLL and switch system clock to PLL + * @param SYSCLK_Frequency SYSCLK frequency + * @param UTILS_ClkInitStruct pointer to a @ref LL_UTILS_ClkInitTypeDef structure that contains + * the configuration information for the BUS prescalers. + * @retval An ErrorStatus enumeration value: + * - SUCCESS: No problem to switch system to PLL + * - ERROR: Problem to switch system to PLL + */ +static ErrorStatus UTILS_EnablePLLAndSwitchSystem(uint32_t SYSCLK_Frequency, LL_UTILS_ClkInitTypeDef *UTILS_ClkInitStruct) +{ + ErrorStatus status = SUCCESS; + uint32_t sysclk_frequency_current = 0U; + + assert_param(IS_LL_UTILS_SYSCLK_DIV(UTILS_ClkInitStruct->AHBCLKDivider)); + assert_param(IS_LL_UTILS_APB1_DIV(UTILS_ClkInitStruct->APB1CLKDivider)); + + /* Calculate current SYSCLK frequency */ + sysclk_frequency_current = (SystemCoreClock << AHBPrescTable[LL_RCC_GetAHBPrescaler() >> RCC_POSITION_HPRE]); + + /* Increasing the number of wait states because of higher CPU frequency */ + if (sysclk_frequency_current < SYSCLK_Frequency) + { + /* Set FLASH latency to highest latency */ + status = LL_SetFlashLatency(SYSCLK_Frequency); + } + + /* Update system clock configuration */ + if (status == SUCCESS) + { + /* Enable PLL */ + LL_RCC_PLL_Enable(); + while (LL_RCC_PLL_IsReady() != 1U) + { + /* Wait for PLL ready */ + } + + /* Sysclk activation on the main PLL */ + LL_RCC_SetAHBPrescaler(UTILS_ClkInitStruct->AHBCLKDivider); + LL_RCC_SetSysClkSource(LL_RCC_SYS_CLKSOURCE_PLL); + while (LL_RCC_GetSysClkSource() != LL_RCC_SYS_CLKSOURCE_STATUS_PLL) + { + /* Wait for system clock switch to PLL */ + } + + /* Set APB1 & APB2 prescaler*/ + LL_RCC_SetAPB1Prescaler(UTILS_ClkInitStruct->APB1CLKDivider); + } + + /* Decreasing the number of wait states because of lower CPU frequency */ + if (sysclk_frequency_current > SYSCLK_Frequency) + { + /* Set FLASH latency to lowest latency */ + status = LL_SetFlashLatency(SYSCLK_Frequency); + } + + /* Update SystemCoreClock variable */ + if (status == SUCCESS) + { + LL_SetSystemCoreClock(__LL_RCC_CALC_HCLK_FREQ(SYSCLK_Frequency, UTILS_ClkInitStruct->AHBCLKDivider)); + } + + return status; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/inc/stm32f0xx_hal_conf.h b/Chapter04/bare/platform/inc/stm32f0xx_hal_conf.h new file mode 100644 index 0000000..d8b49fc --- /dev/null +++ b/Chapter04/bare/platform/inc/stm32f0xx_hal_conf.h @@ -0,0 +1,322 @@ +/* USER CODE BEGIN Header */ +/** + ****************************************************************************** + * @file stm32f0xx_hal_conf.h + * @brief HAL configuration file. + ****************************************************************************** + * @attention + * + * Copyright (c) 2016 STMicroelectronics. + * All rights reserved. + * + * This software is licensed under terms that can be found in the LICENSE file + * in the root directory of this software component. + * If no LICENSE file comes with this software, it is provided AS-IS. + * + ****************************************************************************** + */ +/* USER CODE END Header */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_CONF_H +#define __STM32F0xx_HAL_CONF_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/* ########################## Module Selection ############################## */ +/** + * @brief This is the list of modules to be used in the HAL driver + */ +#define HAL_MODULE_ENABLED + #define HAL_ADC_MODULE_ENABLED +/*#define HAL_CRYP_MODULE_ENABLED */ +/*#define HAL_CAN_MODULE_ENABLED */ +/*#define HAL_CEC_MODULE_ENABLED */ +/*#define HAL_COMP_MODULE_ENABLED */ +#define HAL_CRC_MODULE_ENABLED +/*#define HAL_CRYP_MODULE_ENABLED */ +/*#define HAL_TSC_MODULE_ENABLED */ +#define HAL_DAC_MODULE_ENABLED +/*#define HAL_I2S_MODULE_ENABLED */ +#define HAL_IWDG_MODULE_ENABLED +/*#define HAL_LCD_MODULE_ENABLED */ +/*#define HAL_LPTIM_MODULE_ENABLED */ +/*#define HAL_RNG_MODULE_ENABLED */ +/*#define HAL_RTC_MODULE_ENABLED */ +/*#define HAL_SPI_MODULE_ENABLED */ +#define HAL_TIM_MODULE_ENABLED +#define HAL_UART_MODULE_ENABLED +/*#define HAL_USART_MODULE_ENABLED */ +/*#define HAL_IRDA_MODULE_ENABLED */ +/*#define HAL_SMARTCARD_MODULE_ENABLED */ +/*#define HAL_SMBUS_MODULE_ENABLED */ +#define HAL_WWDG_MODULE_ENABLED +/*#define HAL_PCD_MODULE_ENABLED */ +#define HAL_CORTEX_MODULE_ENABLED +#define HAL_DMA_MODULE_ENABLED +#define HAL_FLASH_MODULE_ENABLED +#define HAL_GPIO_MODULE_ENABLED +#define HAL_EXTI_MODULE_ENABLED +#define HAL_PWR_MODULE_ENABLED +#define HAL_RCC_MODULE_ENABLED +#define HAL_I2C_MODULE_ENABLED + +/* ########################## HSE/HSI Values adaptation ##################### */ +/** + * @brief Adjust the value of External High Speed oscillator (HSE) used in your application. + * This value is used by the RCC HAL module to compute the system frequency + * (when HSE is used as system clock source, directly or through the PLL). + */ +#if !defined (HSE_VALUE) + #define HSE_VALUE ((uint32_t)8000000) /*!< Value of the External oscillator in Hz */ +#endif /* HSE_VALUE */ + +/** + * @brief In the following line adjust the External High Speed oscillator (HSE) Startup + * Timeout value + */ +#if !defined (HSE_STARTUP_TIMEOUT) + #define HSE_STARTUP_TIMEOUT ((uint32_t)100) /*!< Time out for HSE start up, in ms */ +#endif /* HSE_STARTUP_TIMEOUT */ + +/** + * @brief Internal High Speed oscillator (HSI) value. + * This value is used by the RCC HAL module to compute the system frequency + * (when HSI is used as system clock source, directly or through the PLL). + */ +#if !defined (HSI_VALUE) + #define HSI_VALUE ((uint32_t)8000000) /*!< Value of the Internal oscillator in Hz*/ +#endif /* HSI_VALUE */ + +/** + * @brief In the following line adjust the Internal High Speed oscillator (HSI) Startup + * Timeout value + */ +#if !defined (HSI_STARTUP_TIMEOUT) + #define HSI_STARTUP_TIMEOUT ((uint32_t)5000) /*!< Time out for HSI start up */ +#endif /* HSI_STARTUP_TIMEOUT */ + +/** + * @brief Internal High Speed oscillator for ADC (HSI14) value. + */ +#if !defined (HSI14_VALUE) +#define HSI14_VALUE ((uint32_t)14000000) /*!< Value of the Internal High Speed oscillator for ADC in Hz. + The real value may vary depending on the variations + in voltage and temperature. */ +#endif /* HSI14_VALUE */ + +/** + * @brief Internal High Speed oscillator for USB (HSI48) value. + */ +#if !defined (HSI48_VALUE) + #define HSI48_VALUE ((uint32_t)48000000) /*!< Value of the Internal High Speed oscillator for USB in Hz. + The real value may vary depending on the variations + in voltage and temperature. */ +#endif /* HSI48_VALUE */ + +/** + * @brief Internal Low Speed oscillator (LSI) value. + */ +#if !defined (LSI_VALUE) + #define LSI_VALUE ((uint32_t)40000) +#endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz + The real value may vary depending on the variations + in voltage and temperature. */ +/** + * @brief External Low Speed oscillator (LSI) value. + */ +#if !defined (LSE_VALUE) + #define LSE_VALUE ((uint32_t)32768) /*!< Value of the External Low Speed oscillator in Hz */ +#endif /* LSE_VALUE */ + +/** + * @brief Time out for LSE start up value in ms. + */ +#if !defined (LSE_STARTUP_TIMEOUT) + #define LSE_STARTUP_TIMEOUT ((uint32_t)5000) /*!< Time out for LSE start up, in ms */ +#endif /* LSE_STARTUP_TIMEOUT */ + +/* Tip: To avoid modifying this file each time you need to use different HSE, + === you can define the HSE value in your toolchain compiler preprocessor. */ + +/* ########################### System Configuration ######################### */ +/** + * @brief This is the HAL system configuration section + */ +#define VDD_VALUE ((uint32_t)3300) /*!< Value of VDD in mv */ +#define TICK_INT_PRIORITY ((uint32_t)3) /*!< tick interrupt priority (lowest by default) */ + /* Warning: Must be set to higher priority for HAL_Delay() */ + /* and HAL_GetTick() usage under interrupt context */ +#define USE_RTOS 0 +#define PREFETCH_ENABLE 1 +#define INSTRUCTION_CACHE_ENABLE 0 +#define DATA_CACHE_ENABLE 0 +#define USE_SPI_CRC 0U + +#define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */ +#define USE_HAL_CAN_REGISTER_CALLBACKS 0U /* CAN register callback disabled */ +#define USE_HAL_COMP_REGISTER_CALLBACKS 0U /* COMP register callback disabled */ +#define USE_HAL_CEC_REGISTER_CALLBACKS 0U /* CEC register callback disabled */ +#define USE_HAL_DAC_REGISTER_CALLBACKS 0U /* DAC register callback disabled */ +#define USE_HAL_I2C_REGISTER_CALLBACKS 0U /* I2C register callback disabled */ +#define USE_HAL_SMBUS_REGISTER_CALLBACKS 0U /* SMBUS register callback disabled */ +#define USE_HAL_UART_REGISTER_CALLBACKS 1U /* UART register callback disabled */ +#define USE_HAL_USART_REGISTER_CALLBACKS 0U /* USART register callback disabled */ +#define USE_HAL_IRDA_REGISTER_CALLBACKS 0U /* IRDA register callback disabled */ +#define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U /* SMARTCARD register callback disabled */ +#define USE_HAL_WWDG_REGISTER_CALLBACKS 0U /* WWDG register callback disabled */ +#define USE_HAL_RTC_REGISTER_CALLBACKS 0U /* RTC register callback disabled */ +#define USE_HAL_SPI_REGISTER_CALLBACKS 0U /* SPI register callback disabled */ +#define USE_HAL_I2S_REGISTER_CALLBACKS 0U /* I2S register callback disabled */ +#define USE_HAL_TIM_REGISTER_CALLBACKS 0U /* TIM register callback disabled */ +#define USE_HAL_TSC_REGISTER_CALLBACKS 0U /* TSC register callback disabled */ +#define USE_HAL_PCD_REGISTER_CALLBACKS 0U /* PCD register callback disabled */ + +/* ########################## Assert Selection ############################## */ +/** + * @brief Uncomment the line below to expanse the "assert_param" macro in the + * HAL drivers code + */ + #define USE_FULL_ASSERT 0U + +/* Includes ------------------------------------------------------------------*/ +/** + * @brief Include module's header file + */ + +#ifdef HAL_RCC_MODULE_ENABLED + #include "stm32f0xx_hal_rcc.h" +#endif /* HAL_RCC_MODULE_ENABLED */ + +#ifdef HAL_GPIO_MODULE_ENABLED + #include "stm32f0xx_hal_gpio.h" +#endif /* HAL_GPIO_MODULE_ENABLED */ + +#ifdef HAL_EXTI_MODULE_ENABLED + #include "stm32f0xx_hal_exti.h" +#endif /* HAL_EXTI_MODULE_ENABLED */ + +#ifdef HAL_DMA_MODULE_ENABLED + #include "stm32f0xx_hal_dma.h" +#endif /* HAL_DMA_MODULE_ENABLED */ + +#ifdef HAL_CORTEX_MODULE_ENABLED + #include "stm32f0xx_hal_cortex.h" +#endif /* HAL_CORTEX_MODULE_ENABLED */ + +#ifdef HAL_ADC_MODULE_ENABLED + #include "stm32f0xx_hal_adc.h" +#endif /* HAL_ADC_MODULE_ENABLED */ + +#ifdef HAL_CAN_MODULE_ENABLED + #include "stm32f0xx_hal_can.h" +#endif /* HAL_CAN_MODULE_ENABLED */ + +#ifdef HAL_CEC_MODULE_ENABLED + #include "stm32f0xx_hal_cec.h" +#endif /* HAL_CEC_MODULE_ENABLED */ + +#ifdef HAL_COMP_MODULE_ENABLED + #include "stm32f0xx_hal_comp.h" +#endif /* HAL_COMP_MODULE_ENABLED */ + +#ifdef HAL_CRC_MODULE_ENABLED + #include "stm32f0xx_hal_crc.h" +#endif /* HAL_CRC_MODULE_ENABLED */ + +#ifdef HAL_DAC_MODULE_ENABLED + #include "stm32f0xx_hal_dac.h" +#endif /* HAL_DAC_MODULE_ENABLED */ + +#ifdef HAL_FLASH_MODULE_ENABLED + #include "stm32f0xx_hal_flash.h" +#endif /* HAL_FLASH_MODULE_ENABLED */ + +#ifdef HAL_I2C_MODULE_ENABLED + #include "stm32f0xx_hal_i2c.h" +#endif /* HAL_I2C_MODULE_ENABLED */ + +#ifdef HAL_I2S_MODULE_ENABLED + #include "stm32f0xx_hal_i2s.h" +#endif /* HAL_I2S_MODULE_ENABLED */ + +#ifdef HAL_IRDA_MODULE_ENABLED + #include "stm32f0xx_hal_irda.h" +#endif /* HAL_IRDA_MODULE_ENABLED */ + +#ifdef HAL_IWDG_MODULE_ENABLED + #include "stm32f0xx_hal_iwdg.h" +#endif /* HAL_IWDG_MODULE_ENABLED */ + +#ifdef HAL_PCD_MODULE_ENABLED + #include "stm32f0xx_hal_pcd.h" +#endif /* HAL_PCD_MODULE_ENABLED */ + +#ifdef HAL_PWR_MODULE_ENABLED + #include "stm32f0xx_hal_pwr.h" +#endif /* HAL_PWR_MODULE_ENABLED */ + +#ifdef HAL_RTC_MODULE_ENABLED + #include "stm32f0xx_hal_rtc.h" +#endif /* HAL_RTC_MODULE_ENABLED */ + +#ifdef HAL_SMARTCARD_MODULE_ENABLED + #include "stm32f0xx_hal_smartcard.h" +#endif /* HAL_SMARTCARD_MODULE_ENABLED */ + +#ifdef HAL_SMBUS_MODULE_ENABLED + #include "stm32f0xx_hal_smbus.h" +#endif /* HAL_SMBUS_MODULE_ENABLED */ + +#ifdef HAL_SPI_MODULE_ENABLED + #include "stm32f0xx_hal_spi.h" +#endif /* HAL_SPI_MODULE_ENABLED */ + +#ifdef HAL_TIM_MODULE_ENABLED + #include "stm32f0xx_hal_tim.h" +#endif /* HAL_TIM_MODULE_ENABLED */ + +#ifdef HAL_TSC_MODULE_ENABLED + #include "stm32f0xx_hal_tsc.h" +#endif /* HAL_TSC_MODULE_ENABLED */ + +#ifdef HAL_UART_MODULE_ENABLED + #include "stm32f0xx_hal_uart.h" +#endif /* HAL_UART_MODULE_ENABLED */ + +#ifdef HAL_USART_MODULE_ENABLED + #include "stm32f0xx_hal_usart.h" +#endif /* HAL_USART_MODULE_ENABLED */ + +#ifdef HAL_WWDG_MODULE_ENABLED + #include "stm32f0xx_hal_wwdg.h" +#endif /* HAL_WWDG_MODULE_ENABLED */ + +/* Exported macro ------------------------------------------------------------*/ +#ifdef USE_FULL_ASSERT +/** + * @brief The assert_param macro is used for function's parameters check. + * @param expr If expr is false, it calls assert_failed function + * which reports the name of the source file and the source + * line number of the call that failed. + * If expr is true, it returns no value. + * @retval None + */ + #define assert_param(expr) ((expr) ? (void)0U : assert_failed(__FILE__, __LINE__)) +/* Exported functions ------------------------------------------------------- */ + void assert_failed(const char* file, uint32_t line); +#else + #define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_CONF_H */ + diff --git a/Chapter04/bare/platform/inc/stm32f0xx_it.h b/Chapter04/bare/platform/inc/stm32f0xx_it.h new file mode 100644 index 0000000..1cb9f8b --- /dev/null +++ b/Chapter04/bare/platform/inc/stm32f0xx_it.h @@ -0,0 +1,74 @@ +/* USER CODE BEGIN Header */ +/** + ****************************************************************************** + * @file stm32f0xx_it.h + * @brief This file contains the headers of the interrupt handlers. + ****************************************************************************** + * @attention + * + * Copyright (c) 2022 STMicroelectronics. + * All rights reserved. + * + * This software is licensed under terms that can be found in the LICENSE file + * in the root directory of this software component. + * If no LICENSE file comes with this software, it is provided AS-IS. + * + ****************************************************************************** + */ +/* USER CODE END Header */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_IT_H +#define __STM32F0xx_IT_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Private includes ----------------------------------------------------------*/ +/* USER CODE BEGIN Includes */ +#include +/* USER CODE END Includes */ + +/* Exported types ------------------------------------------------------------*/ +/* USER CODE BEGIN ET */ + +/* USER CODE END ET */ + +/* Exported constants --------------------------------------------------------*/ +/* USER CODE BEGIN EC */ + +/* USER CODE END EC */ + +/* Exported macro ------------------------------------------------------------*/ +/* USER CODE BEGIN EM */ + +/* USER CODE END EM */ + +/* Exported functions prototypes ---------------------------------------------*/ +void NMI_Handler(void); +void HardFault_Handler(void); +void SVC_Handler(void); +void PendSV_Handler(void); +void SysTick_Handler(void); +void EXTI4_15_IRQHandler(void); +void DMA1_Channel1_IRQHandler(void); +void TIM16_IRQHandler(void); +void TIM17_IRQHandler(void); +/* USER CODE BEGIN EFP */ + +void tim1_set_irq_handler(void (*handler)(void)); +void tim2_set_irq_handler(void (*handler)(void)); +void tim16_set_irq_handler(void (*handler)(void)); +void tim17_set_irq_handler(void (*handler)(void)); +void tim6_set_irq_handler(void (*handler)(void)); +void sw_set_irq_handler(void (*handler)(void), size_t sw_num); +void efuse_set_irq_handler(void (*handler)(void)); + +/* USER CODE END EFP */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_IT_H */ diff --git a/Chapter04/bare/platform/src/stm32f0xx_hal_msp.c b/Chapter04/bare/platform/src/stm32f0xx_hal_msp.c new file mode 100644 index 0000000..0aacc85 --- /dev/null +++ b/Chapter04/bare/platform/src/stm32f0xx_hal_msp.c @@ -0,0 +1,89 @@ +/* USER CODE BEGIN Header */ +/** + ****************************************************************************** + * @file stm32f0xx_hal_msp.c + * @brief This file provides code for the MSP Initialization + * and de-Initialization codes. + ****************************************************************************** + * @attention + * + * Copyright (c) 2022 STMicroelectronics. + * All rights reserved. + * + * This software is licensed under terms that can be found in the LICENSE file + * in the root directory of this software component. + * If no LICENSE file comes with this software, it is provided AS-IS. + * + ****************************************************************************** + */ +/* USER CODE END Header */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal.h" +/* USER CODE BEGIN Includes */ + +/* USER CODE END Includes */ + +/* Private typedef -----------------------------------------------------------*/ +/* USER CODE BEGIN TD */ + +/* USER CODE END TD */ + +/* Private define ------------------------------------------------------------*/ +/* USER CODE BEGIN Define */ + +/* USER CODE END Define */ + +/* Private macro -------------------------------------------------------------*/ +/* USER CODE BEGIN Macro */ + +/* USER CODE END Macro */ + +/* Private variables ---------------------------------------------------------*/ +/* USER CODE BEGIN PV */ + +/* USER CODE END PV */ + +/* Private function prototypes -----------------------------------------------*/ +/* USER CODE BEGIN PFP */ + +/* USER CODE END PFP */ + +/* External functions --------------------------------------------------------*/ +/* USER CODE BEGIN ExternalFunctions */ + +/* USER CODE END ExternalFunctions */ + +/* USER CODE BEGIN 0 */ + +/* USER CODE END 0 */ +/** + * Initializes the Global MSP. + */ +void HAL_MspInit(void) +{ + /* USER CODE BEGIN MspInit 0 */ + + /* USER CODE END MspInit 0 */ + + __HAL_RCC_SYSCFG_CLK_ENABLE(); + __HAL_RCC_PWR_CLK_ENABLE(); + + /* System interrupt init*/ + + /* USER CODE BEGIN MspInit 1 */ + + /* USER CODE END MspInit 1 */ +} + +/* USER CODE BEGIN 1 */ +void assert_failed(const char *file, uint32_t line) +{ + while(1) + { + // printf("assert_failed \r\n"); + } +} +/* USER CODE END 1 */ + + diff --git a/Chapter04/bare/platform/src/stm32f0xx_it.c b/Chapter04/bare/platform/src/stm32f0xx_it.c new file mode 100644 index 0000000..112f19c --- /dev/null +++ b/Chapter04/bare/platform/src/stm32f0xx_it.c @@ -0,0 +1,133 @@ +/* USER CODE BEGIN Header */ +/** + ****************************************************************************** + * @file stm32f0xx_it.c + * @brief Interrupt Service Routines. + ****************************************************************************** + * @attention + * + * Copyright (c) 2022 STMicroelectronics. + * All rights reserved. + * + * This software is licensed under terms that can be found in the LICENSE file + * in the root directory of this software component. + * If no LICENSE file comes with this software, it is provided AS-IS. + * + ****************************************************************************** + */ +/* USER CODE END Header */ + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_it.h" +#include "stm32f0xx_hal.h" +/* Private includes ----------------------------------------------------------*/ +/* USER CODE BEGIN Includes */ +/* USER CODE END Includes */ + +/* Private typedef -----------------------------------------------------------*/ +/* USER CODE BEGIN TD */ + +/* USER CODE END TD */ + +/* Private define ------------------------------------------------------------*/ +/* USER CODE BEGIN PD */ + +/* USER CODE END PD */ + +/* Private macro -------------------------------------------------------------*/ +/* USER CODE BEGIN PM */ + +/* USER CODE END PM */ + +/* Private variables ---------------------------------------------------------*/ +/* USER CODE BEGIN PV */ + +/* USER CODE END PV */ + +/* Private function prototypes -----------------------------------------------*/ +/* USER CODE BEGIN PFP */ + +/* USER CODE END PFP */ + +/* Private user code ---------------------------------------------------------*/ +/* USER CODE BEGIN 0 */ +/* USER CODE END 0 */ + +/* External variables --------------------------------------------------------*/ +/* USER CODE BEGIN EV */ + +/* USER CODE END EV */ + +/******************************************************************************/ +/* Cortex-M0 Processor Interruption and Exception Handlers */ +/******************************************************************************/ +/** + * @brief This function handles Non maskable interrupt. + */ +void NMI_Handler(void) +{ + /* USER CODE BEGIN NonMaskableInt_IRQn 0 */ + + /* USER CODE END NonMaskableInt_IRQn 0 */ + /* USER CODE BEGIN NonMaskableInt_IRQn 1 */ + while(1) + { + } + /* USER CODE END NonMaskableInt_IRQn 1 */ +} + +/** + * @brief This function handles Hard fault interrupt. + */ +void HardFault_Handler(void) +{ + /* USER CODE BEGIN HardFault_IRQn 0 */ + + /* USER CODE END HardFault_IRQn 0 */ + while(1) + { + /* USER CODE BEGIN W1_HardFault_IRQn 0 */ + /* USER CODE END W1_HardFault_IRQn 0 */ + } +} + +/** + * @brief This function handles System service call via SWI instruction. + */ +void SVC_Handler(void) +{ + /* USER CODE BEGIN SVC_IRQn 0 */ + + /* USER CODE END SVC_IRQn 0 */ + /* USER CODE BEGIN SVC_IRQn 1 */ + + /* USER CODE END SVC_IRQn 1 */ +} + +/** + * @brief This function handles Pendable request for system service. + */ +void PendSV_Handler(void) +{ + /* USER CODE BEGIN PendSV_IRQn 0 */ + + /* USER CODE END PendSV_IRQn 0 */ + /* USER CODE BEGIN PendSV_IRQn 1 */ + + /* USER CODE END PendSV_IRQn 1 */ +} + +/** + * @brief This function handles System tick timer. + */ +void SysTick_Handler(void) +{ + /* USER CODE BEGIN SysTick_IRQn 0 */ + + /* USER CODE END SysTick_IRQn 0 */ + HAL_IncTick(); + /* USER CODE BEGIN SysTick_IRQn 1 */ + + /* USER CODE END SysTick_IRQn 1 */ +} + diff --git a/Chapter04/bare/platform/src/system_stm32f0xx.c b/Chapter04/bare/platform/src/system_stm32f0xx.c new file mode 100644 index 0000000..3755770 --- /dev/null +++ b/Chapter04/bare/platform/src/system_stm32f0xx.c @@ -0,0 +1,305 @@ +/** + ****************************************************************************** + * @file system_stm32f0xx.c + * @author MCD Application Team + * @brief CMSIS Cortex-M0 Device Peripheral Access Layer System Source File. + * + * 1. This file provides two functions and one global variable to be called from + * user application: + * - SystemInit(): This function is called at startup just after reset and + * before branch to main program. This call is made inside + * the "startup_stm32f0xx.s" file. + * + * - SystemCoreClock variable: Contains the core clock (HCLK), it can be used + * by the user application to setup the SysTick + * timer or configure other parameters. + * + * - SystemCoreClockUpdate(): Updates the variable SystemCoreClock and must + * be called whenever the core clock is changed + * during program execution. + * + * + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/** @addtogroup CMSIS + * @{ + */ + +/** @addtogroup stm32f0xx_system + * @{ + */ + +/** @addtogroup STM32F0xx_System_Private_Includes + * @{ + */ + +#include "stm32f0xx.h" + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_TypesDefinitions + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Defines + * @{ + */ +#if !defined (HSE_VALUE) + #define HSE_VALUE ((uint32_t)8000000) /*!< Default value of the External oscillator in Hz. + This value can be provided and adapted by the user application. */ +#endif /* HSE_VALUE */ + +#if !defined (HSI_VALUE) + #define HSI_VALUE ((uint32_t)8000000) /*!< Default value of the Internal oscillator in Hz. + This value can be provided and adapted by the user application. */ +#endif /* HSI_VALUE */ + +#if !defined (HSI48_VALUE) +#define HSI48_VALUE ((uint32_t)48000000) /*!< Default value of the HSI48 Internal oscillator in Hz. + This value can be provided and adapted by the user application. */ +#endif /* HSI48_VALUE */ +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Macros + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Variables + * @{ + */ + /* This variable is updated in three ways: + 1) by calling CMSIS function SystemCoreClockUpdate() + 2) by calling HAL API function HAL_RCC_GetHCLKFreq() + 3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency + Note: If you use this function to configure the system clock; then there + is no need to call the 2 first functions listed above, since SystemCoreClock + variable is updated automatically. + */ +uint32_t SystemCoreClock = 8000000; + +const uint8_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}; +const uint8_t APBPrescTable[8] = {0, 0, 0, 0, 1, 2, 3, 4}; + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_FunctionPrototypes + * @{ + */ + +/** + * @} + */ + +/** @addtogroup STM32F0xx_System_Private_Functions + * @{ + */ + +/** + * @brief Setup the microcontroller system + * @param None + * @retval None + */ +void SystemInit(void) +{ + /* NOTE :SystemInit(): This function is called at startup just after reset and + before branch to main program. This call is made inside + the "startup_stm32f0xx.s" file. + User can setups the default system clock (System clock source, PLL Multiplier + and Divider factors, AHB/APBx prescalers and Flash settings). + */ + + /* Reset the RCC clock configuration to the default reset state ------------*/ + /* Set HSION bit */ + RCC->CR |= (uint32_t)0x00000001U; + +#if defined (STM32F051x8) || defined (STM32F058x8) + /* Reset SW[1:0], HPRE[3:0], PPRE[2:0], ADCPRE and MCOSEL[2:0] bits */ + RCC->CFGR &= (uint32_t)0xF8FFB80CU; +#else + /* Reset SW[1:0], HPRE[3:0], PPRE[2:0], ADCPRE, MCOSEL[2:0], MCOPRE[2:0] and PLLNODIV bits */ + RCC->CFGR &= (uint32_t)0x08FFB80CU; +#endif /* STM32F051x8 or STM32F058x8 */ + + /* Reset HSEON, CSSON and PLLON bits */ + RCC->CR &= (uint32_t)0xFEF6FFFFU; + + /* Reset HSEBYP bit */ + RCC->CR &= (uint32_t)0xFFFBFFFFU; + + /* Reset PLLSRC, PLLXTPRE and PLLMUL[3:0] bits */ + RCC->CFGR &= (uint32_t)0xFFC0FFFFU; + + /* Reset PREDIV[3:0] bits */ + RCC->CFGR2 &= (uint32_t)0xFFFFFFF0U; + +#if defined (STM32F072xB) || defined (STM32F078xx) + /* Reset USART2SW[1:0], USART1SW[1:0], I2C1SW, CECSW, USBSW and ADCSW bits */ + RCC->CFGR3 &= (uint32_t)0xFFFCFE2CU; +#elif defined (STM32F071xB) + /* Reset USART2SW[1:0], USART1SW[1:0], I2C1SW, CECSW and ADCSW bits */ + RCC->CFGR3 &= (uint32_t)0xFFFFCEACU; +#elif defined (STM32F091xC) || defined (STM32F098xx) + /* Reset USART3SW[1:0], USART2SW[1:0], USART1SW[1:0], I2C1SW, CECSW and ADCSW bits */ + RCC->CFGR3 &= (uint32_t)0xFFF0FEACU; +#elif defined (STM32F030x6) || defined (STM32F030x8) || defined (STM32F031x6) || defined (STM32F038xx) || defined (STM32F030xC) + /* Reset USART1SW[1:0], I2C1SW and ADCSW bits */ + RCC->CFGR3 &= (uint32_t)0xFFFFFEECU; +#elif defined (STM32F051x8) || defined (STM32F058xx) + /* Reset USART1SW[1:0], I2C1SW, CECSW and ADCSW bits */ + RCC->CFGR3 &= (uint32_t)0xFFFFFEACU; +#elif defined (STM32F042x6) || defined (STM32F048xx) + /* Reset USART1SW[1:0], I2C1SW, CECSW, USBSW and ADCSW bits */ + RCC->CFGR3 &= (uint32_t)0xFFFFFE2CU; +#elif defined (STM32F070x6) || defined (STM32F070xB) + /* Reset USART1SW[1:0], I2C1SW, USBSW and ADCSW bits */ + RCC->CFGR3 &= (uint32_t)0xFFFFFE6CU; + /* Set default USB clock to PLLCLK, since there is no HSI48 */ + RCC->CFGR3 |= (uint32_t)0x00000080U; +#else + #warning "No target selected" +#endif + + /* Reset HSI14 bit */ + RCC->CR2 &= (uint32_t)0xFFFFFFFEU; + + /* Disable all interrupts */ + RCC->CIR = 0x00000000U; + +} + +/** + * @brief Update SystemCoreClock variable according to Clock Register Values. + * The SystemCoreClock variable contains the core clock (HCLK), it can + * be used by the user application to setup the SysTick timer or configure + * other parameters. + * + * @note Each time the core clock (HCLK) changes, this function must be called + * to update SystemCoreClock variable value. Otherwise, any configuration + * based on this variable will be incorrect. + * + * @note - The system frequency computed by this function is not the real + * frequency in the chip. It is calculated based on the predefined + * constant and the selected clock source: + * + * - If SYSCLK source is HSI, SystemCoreClock will contain the HSI_VALUE(*) + * + * - If SYSCLK source is HSE, SystemCoreClock will contain the HSE_VALUE(**) + * + * - If SYSCLK source is PLL, SystemCoreClock will contain the HSE_VALUE(**) + * or HSI_VALUE(*) multiplied/divided by the PLL factors. + * + * (*) HSI_VALUE is a constant defined in stm32f0xx_hal_conf.h file (default value + * 8 MHz) but the real value may vary depending on the variations + * in voltage and temperature. + * + * (**) HSE_VALUE is a constant defined in stm32f0xx_hal_conf.h file (its value + * depends on the application requirements), user has to ensure that HSE_VALUE + * is same as the real frequency of the crystal used. Otherwise, this function + * may have wrong result. + * + * - The result of this function could be not correct when using fractional + * value for HSE crystal. + * + * @param None + * @retval None + */ +void SystemCoreClockUpdate(void) +{ + uint32_t tmp = 0, pllmull = 0, pllsource = 0, predivfactor = 0; + + /* Get SYSCLK source -------------------------------------------------------*/ + tmp = RCC->CFGR & RCC_CFGR_SWS; + + switch (tmp) + { + case RCC_CFGR_SWS_HSI: /* HSI used as system clock */ + SystemCoreClock = HSI_VALUE; + break; + case RCC_CFGR_SWS_HSE: /* HSE used as system clock */ + SystemCoreClock = HSE_VALUE; + break; + case RCC_CFGR_SWS_PLL: /* PLL used as system clock */ + /* Get PLL clock source and multiplication factor ----------------------*/ + pllmull = RCC->CFGR & RCC_CFGR_PLLMUL; + pllsource = RCC->CFGR & RCC_CFGR_PLLSRC; + pllmull = ( pllmull >> 18) + 2; + predivfactor = (RCC->CFGR2 & RCC_CFGR2_PREDIV) + 1; + + if (pllsource == RCC_CFGR_PLLSRC_HSE_PREDIV) + { + /* HSE used as PLL clock source : SystemCoreClock = HSE/PREDIV * PLLMUL */ + SystemCoreClock = (HSE_VALUE/predivfactor) * pllmull; + } +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) + else if (pllsource == RCC_CFGR_PLLSRC_HSI48_PREDIV) + { + /* HSI48 used as PLL clock source : SystemCoreClock = HSI48/PREDIV * PLLMUL */ + SystemCoreClock = (HSI48_VALUE/predivfactor) * pllmull; + } +#endif /* STM32F042x6 || STM32F048xx || STM32F072xB || STM32F078xx || STM32F091xC || STM32F098xx */ + else + { +#if defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6) \ + || defined(STM32F078xx) || defined(STM32F071xB) || defined(STM32F072xB) \ + || defined(STM32F070xB) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) + /* HSI used as PLL clock source : SystemCoreClock = HSI/PREDIV * PLLMUL */ + SystemCoreClock = (HSI_VALUE/predivfactor) * pllmull; +#else + /* HSI used as PLL clock source : SystemCoreClock = HSI/2 * PLLMUL */ + SystemCoreClock = (HSI_VALUE >> 1) * pllmull; +#endif /* STM32F042x6 || STM32F048xx || STM32F070x6 || + STM32F071xB || STM32F072xB || STM32F078xx || STM32F070xB || + STM32F091xC || STM32F098xx || STM32F030xC */ + } + break; + default: /* HSI used as system clock */ + SystemCoreClock = HSI_VALUE; + break; + } + /* Compute HCLK clock frequency ----------------*/ + /* Get HCLK prescaler */ + tmp = AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> 4)]; + /* HCLK clock frequency */ + SystemCoreClock >>= tmp; +} + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/startup_stm32f072xb.s b/Chapter04/bare/platform/startup_stm32f072xb.s new file mode 100644 index 0000000..9d431a9 --- /dev/null +++ b/Chapter04/bare/platform/startup_stm32f072xb.s @@ -0,0 +1,294 @@ +/** + ****************************************************************************** + * @file startup_stm32f072xb.s + * @author MCD Application Team + * @brief STM32F072x8/STM32F072xB devices vector table for GCC toolchain. + * This module performs: + * - Set the initial SP + * - Set the initial PC == Reset_Handler, + * - Set the vector table entries with the exceptions ISR address + * - Branches to main in the C library (which eventually + * calls main()). + * After Reset the Cortex-M0 processor is in Thread mode, + * priority is Privileged, and the Stack is set to Main. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + + .syntax unified + .cpu cortex-m0 + .fpu softvfp + .thumb + +.global g_pfnVectors +.global Default_Handler + +/* start address for the initialization values of the .data section. +defined in linker script */ +.word _sidata +/* start address for the .data section. defined in linker script */ +.word _sdata +/* end address for the .data section. defined in linker script */ +.word _edata +/* start address for the .bss section. defined in linker script */ +.word _sbss +/* end address for the .bss section. defined in linker script */ +.word _ebss + + .section .text.Reset_Handler + .weak Reset_Handler + .type Reset_Handler, %function +Reset_Handler: + ldr r0, =_estack + mov sp, r0 /* set stack pointer */ + +/* Copy the data segment initializers from flash to SRAM */ + ldr r0, =_sdata + ldr r1, =_edata + ldr r2, =_sidata + movs r3, #0 + b LoopCopyDataInit + +CopyDataInit: + ldr r4, [r2, r3] + str r4, [r0, r3] + adds r3, r3, #4 + +LoopCopyDataInit: + adds r4, r0, r3 + cmp r4, r1 + bcc CopyDataInit + +/* Zero fill the bss segment. */ + ldr r2, =_sbss + ldr r4, =_ebss + movs r3, #0 + b LoopFillZerobss + +FillZerobss: + str r3, [r2] + adds r2, r2, #4 + +LoopFillZerobss: + cmp r2, r4 + bcc FillZerobss + +/* Call the clock system intitialization function.*/ + bl SystemInit +/* Call static constructors */ + bl __libc_init_array +/* Call the application's entry point.*/ + bl main + +LoopForever: + b LoopForever + + +.size Reset_Handler, .-Reset_Handler + +/** + * @brief This is the code that gets called when the processor receives an + * unexpected interrupt. This simply enters an infinite loop, preserving + * the system state for examination by a debugger. + * + * @param None + * @retval : None +*/ + .section .text.Default_Handler,"ax",%progbits +Default_Handler: +Infinite_Loop: + b Infinite_Loop + .size Default_Handler, .-Default_Handler +/****************************************************************************** +* +* The minimal vector table for a Cortex M0. Note that the proper constructs +* must be placed on this to ensure that it ends up at physical address +* 0x0000.0000. +* +******************************************************************************/ + .section .isr_vector,"a",%progbits + .type g_pfnVectors, %object + .size g_pfnVectors, .-g_pfnVectors + + +g_pfnVectors: + .word _estack + .word Reset_Handler + .word NMI_Handler + .word HardFault_Handler + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word 0 + .word SVC_Handler + .word 0 + .word 0 + .word PendSV_Handler + .word SysTick_Handler + .word WWDG_IRQHandler /* Window WatchDog */ + .word PVD_VDDIO2_IRQHandler /* PVD and VDDIO2 through EXTI Line detect */ + .word RTC_IRQHandler /* RTC through the EXTI line */ + .word FLASH_IRQHandler /* FLASH */ + .word RCC_CRS_IRQHandler /* RCC and CRS */ + .word EXTI0_1_IRQHandler /* EXTI Line 0 and 1 */ + .word EXTI2_3_IRQHandler /* EXTI Line 2 and 3 */ + .word EXTI4_15_IRQHandler /* EXTI Line 4 to 15 */ + .word TSC_IRQHandler /* TSC */ + .word DMA1_Channel1_IRQHandler /* DMA1 Channel 1 */ + .word DMA1_Channel2_3_IRQHandler /* DMA1 Channel 2 and Channel 3 */ + .word DMA1_Channel4_5_6_7_IRQHandler /* DMA1 Channel 4, Channel 5, Channel 6 and Channel 7*/ + .word ADC1_COMP_IRQHandler /* ADC1, COMP1 and COMP2 */ + .word TIM1_BRK_UP_TRG_COM_IRQHandler /* TIM1 Break, Update, Trigger and Commutation */ + .word TIM1_CC_IRQHandler /* TIM1 Capture Compare */ + .word TIM2_IRQHandler /* TIM2 */ + .word TIM3_IRQHandler /* TIM3 */ + .word TIM6_DAC_IRQHandler /* TIM6 and DAC */ + .word TIM7_IRQHandler /* TIM7 */ + .word TIM14_IRQHandler /* TIM14 */ + .word TIM15_IRQHandler /* TIM15 */ + .word TIM16_IRQHandler /* TIM16 */ + .word TIM17_IRQHandler /* TIM17 */ + .word I2C1_IRQHandler /* I2C1 */ + .word I2C2_IRQHandler /* I2C2 */ + .word SPI1_IRQHandler /* SPI1 */ + .word SPI2_IRQHandler /* SPI2 */ + .word USART1_IRQHandler /* USART1 */ + .word USART2_IRQHandler /* USART2 */ + .word USART3_4_IRQHandler /* USART3 and USART4 */ + .word CEC_CAN_IRQHandler /* CEC and CAN */ + .word USB_IRQHandler /* USB */ + +/******************************************************************************* +* +* Provide weak aliases for each Exception handler to the Default_Handler. +* As they are weak aliases, any function with the same name will override +* this definition. +* +*******************************************************************************/ + + .weak NMI_Handler + .thumb_set NMI_Handler,Default_Handler + + .weak HardFault_Handler + .thumb_set HardFault_Handler,Default_Handler + + .weak SVC_Handler + .thumb_set SVC_Handler,Default_Handler + + .weak PendSV_Handler + .thumb_set PendSV_Handler,Default_Handler + + .weak SysTick_Handler + .thumb_set SysTick_Handler,Default_Handler + + .weak WWDG_IRQHandler + .thumb_set WWDG_IRQHandler,Default_Handler + + .weak PVD_VDDIO2_IRQHandler + .thumb_set PVD_VDDIO2_IRQHandler,Default_Handler + + .weak RTC_IRQHandler + .thumb_set RTC_IRQHandler,Default_Handler + + .weak FLASH_IRQHandler + .thumb_set FLASH_IRQHandler,Default_Handler + + .weak RCC_CRS_IRQHandler + .thumb_set RCC_CRS_IRQHandler,Default_Handler + + .weak EXTI0_1_IRQHandler + .thumb_set EXTI0_1_IRQHandler,Default_Handler + + .weak EXTI2_3_IRQHandler + .thumb_set EXTI2_3_IRQHandler,Default_Handler + + .weak EXTI4_15_IRQHandler + .thumb_set EXTI4_15_IRQHandler,Default_Handler + + .weak TSC_IRQHandler + .thumb_set TSC_IRQHandler,Default_Handler + + .weak DMA1_Channel1_IRQHandler + .thumb_set DMA1_Channel1_IRQHandler,Default_Handler + + .weak DMA1_Channel2_3_IRQHandler + .thumb_set DMA1_Channel2_3_IRQHandler,Default_Handler + + .weak DMA1_Channel4_5_6_7_IRQHandler + .thumb_set DMA1_Channel4_5_6_7_IRQHandler,Default_Handler + + .weak ADC1_COMP_IRQHandler + .thumb_set ADC1_COMP_IRQHandler,Default_Handler + + .weak TIM1_BRK_UP_TRG_COM_IRQHandler + .thumb_set TIM1_BRK_UP_TRG_COM_IRQHandler,Default_Handler + + .weak TIM1_CC_IRQHandler + .thumb_set TIM1_CC_IRQHandler,Default_Handler + + .weak TIM2_IRQHandler + .thumb_set TIM2_IRQHandler,Default_Handler + + .weak TIM3_IRQHandler + .thumb_set TIM3_IRQHandler,Default_Handler + + .weak TIM6_DAC_IRQHandler + .thumb_set TIM6_DAC_IRQHandler,Default_Handler + + .weak TIM7_IRQHandler + .thumb_set TIM7_IRQHandler,Default_Handler + + .weak TIM14_IRQHandler + .thumb_set TIM14_IRQHandler,Default_Handler + + .weak TIM15_IRQHandler + .thumb_set TIM15_IRQHandler,Default_Handler + + .weak TIM16_IRQHandler + .thumb_set TIM16_IRQHandler,Default_Handler + + .weak TIM17_IRQHandler + .thumb_set TIM17_IRQHandler,Default_Handler + + .weak I2C1_IRQHandler + .thumb_set I2C1_IRQHandler,Default_Handler + + .weak I2C2_IRQHandler + .thumb_set I2C2_IRQHandler,Default_Handler + + .weak SPI1_IRQHandler + .thumb_set SPI1_IRQHandler,Default_Handler + + .weak SPI2_IRQHandler + .thumb_set SPI2_IRQHandler,Default_Handler + + .weak USART1_IRQHandler + .thumb_set USART1_IRQHandler,Default_Handler + + .weak USART2_IRQHandler + .thumb_set USART2_IRQHandler,Default_Handler + + .weak USART3_4_IRQHandler + .thumb_set USART3_4_IRQHandler,Default_Handler + + .weak CEC_CAN_IRQHandler + .thumb_set CEC_CAN_IRQHandler,Default_Handler + + .weak USB_IRQHandler + .thumb_set USB_IRQHandler,Default_Handler + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/renode_scripts/stm32f072.resc b/Chapter04/bare/renode_scripts/stm32f072.resc new file mode 100644 index 0000000..8f46c0c --- /dev/null +++ b/Chapter04/bare/renode_scripts/stm32f072.resc @@ -0,0 +1,17 @@ +using sysbus + +mach create +machine LoadPlatformDescription @platforms/cpus/stm32f072.repl + +$bin?=$ORIGIN/../build/bare.elf + +showAnalyzer usart2 + +macro reset +""" + sysbus LoadELF $bin +""" + +runMacro $reset + +start \ No newline at end of file diff --git a/Chapter04/bare/renode_scripts/stm32f072_debug.resc b/Chapter04/bare/renode_scripts/stm32f072_debug.resc new file mode 100644 index 0000000..94aefd0 --- /dev/null +++ b/Chapter04/bare/renode_scripts/stm32f072_debug.resc @@ -0,0 +1,17 @@ +using sysbus + +mach create +machine LoadPlatformDescription @platforms/cpus/stm32f072.repl + +$bin?=$ORIGIN/../build/bare.elf + +showAnalyzer usart2 + +macro reset +""" + sysbus LoadELF $bin +""" + +runMacro $reset + +machine StartGdbServer 3333
    B>V*opJaHP;du196rRQKe1?4tzs&G0 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

    j#jcNQ> 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%0A|4t|vmsL}z8DLo$jmN6gYk7GZ=bBK-!Gp$*; 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

    Pbyb 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 z zVnI}g{9*(CBaZ#U_ZLr69Cjt=#9wc>Vafl`q>VC^u2XOH%TQY4rDkkz zCet6%yz0$%y6tTh=|2O0i0*ka{!i1r>lDau5yfn=o4yFm(vym!x8PNT-9)fA(@}ft zTml-JNPK*VElq`ryA>pPChg~ogDov>&IZ*lHj^I~+vcOCGaZ~fj7r8M#VHGY zlJp}*sl87Y=ZPC{ype9Hsql&OatLW%75BM>0eycAAuUG|osdcb?rCPLuBG@Nz)y-u zIe@%zi~s7P0dW97sSNKSZBcIgv$@&~iAH7t{CwitvjOTNHi}nbyup_pa;qUp6o=|i zTR0jGWY@$x1A$WpSvjGTP3JP()(`bf`SOqQ$!u7DJ@1rMkYRMx8Pa9^*BFGgbzB zusifJ?thnq4qI?M$63b4xP5hy7rEhsL;QS6jb?C}w9i&jN8FGZvysa(Vq(1y?3D?%Q;_PK) z_?TZ*Z&IQ-e=rqk+CYAs5l{?J#p;t~%9xBCvdUV6TwJF3wz?xuTxsao9dKMo%p+d@88>YOah*#p+SI-bzBK(G*P`X2Xs5n#rc#w3hiI5Lb z2vkyTcC4n>(KMNMr>_qs;CmK71UZ`KIE7mAKc-?<5x4`yYYE0wkf)^?%TZJ4NZpTZ z4|npOk*)Q$(NJ4+V|`V;mi6Z@e}r|Glo#Q-9YYY19ftA!MsBUD3n>c=-*1hBjQL07 zfOZ%a{mD2XfZN5t$gNO2o+huek4J~M$*SeiD(bZG6Y}pwKw+{e|4S6)noao!QBY(Q z#cs|i_&y&c#S*CcJdiI`WLvDEU!>@^a6`XX(d{U#Vo7oA_aO?(SdQN+I;xXbIeD21 zpO8mox9>Z$mkKTc9p@cH#vb zk(887^B1g0*@KWInQF~@n0t;zFu`n!4sW|{K@oVBN3qZG6+)H=$b|v{=S@OZC@0DR zoOcMhRymRVaNaFsWgs$U!hS`_Q?*kEeptxUv|ES9{)`*6TL*tx$dHnTopEturis7S zL9?`|a}X_E>K#N&qtkU14w=xa(MhzlYjRR89h;q0OVfysi;nhGioz6|ZITuV+7_E; zskzmrSz2!6NGy3U&bu8nEfB^{BVY!EtId+SH6UCo$WjK`&0v>>C-1 zb>-r8uGr|<@Bo^b5Qg-v;cAMJJ zP+!{=u2xfnBFse4#^&W>GBMQAwF|2VRH(_^fxMOQqfnW2`YfU|zdwP0>yx31p zvgDo~nDGiYTf>3(G9y3kIE0bu-wjG{bedp?ardpN# zO8lSH&*M`EO8$DNco7}x9}RgH=sM%5$jTp$U=MNKcpN$_1_U2#j;3K zTT3(E<4_C2_FnJ$gqAbO{5z@!2S)MDoMw>`vF@urc`l~>*vZ`vuMb)2V%GQpEC1}1 z`>ElfnCm00Sc;q?TE(FCh=|I2{qln*Xy{Nu6@wM@w|;r62|978pxcPS3i|mZ`Dqh0 z(u!fq6#7Pn2fMJ1AJ*Kvc15Tp;;T#}Xx&>$@+-7VLN-%^w7o_LhnjmRpb90l*`^Xy zc_3LHG#WJ?LZilx-hue)>`#$DFzP5N4t1g2n+Q# zc8u(@t#aWU`D>$wB|xh(G^}}zN!%eTAD$y$_gA1%*jSHsZ)Ij3PPGV*&Bt{Pw3}xf zw3&80o@}TyAJ7h{mOz{cq=kEW*TU5|Ry8+9uyWZ#-J^f0FUg2#mtv97-KxM7k51^>!~xv#Sa-_y$RYXPt4Y$96w83w_$^oIkrHh; z7U07es1!u&qP5|sa7%p^aw6N8Bsb9brGUpU=4nD>h!)%eCDhqrNHLiKr(3~ab%q<` z_y=gfFgcVGyKY?|Sh{&-;C-akq?k!CBE|Zpd1SzSE=C#jv_Oq+3N{P>ZdHQxdzF4X zOFH6Z2!pCW z)gwAQp^KZZpt`0S7`4S6e9(DX-0d?i;`&%VLHsz9!n1v~?kRS6{wN3rsTvk}aLmFJ|XHbTB+ z-3Nqx8IGMDBhgOmPB7X#KmxJ&_BUC#xi%c#f(M0Yp?mrUJ4SJc9nMauZ>n#@2m$fG zVX-uTMXiH$4~}*A#k`DfVm(cVOC;)lBo1Z>pd+x>x(a%tWi?f50|&Cl-=#_n4ti*6 zrULQ5mYeewPk1l(8I=)Dd`-UZ?-{~Taw8+XJ$seqa`jVdx?jIOzz&_-m4VZcw$Snft zX~je4pr=KzD~5*V+KmN)+%>MpT7R{?l<@)u6XnWY1r+-m{@xMnh>ZiFrk_p|!j(!x z)M=l(boBizQla-qLAJ~+6^Vi&71tpZ_*8TzSqpYg zzG?xGb~B`55A%_Kg)KZeYL!^jDpL@qk)u{HXn!Yb|1ZnVE~^wSL!qShU@FZ$+)(&) ztnd-8N4gg2oMh2Gj_PDuEf<6B552w)y#_i|2QYP|HtnKf_Y^8E0Mfoq(guh7sfuA; z(6jHJBMsHT+#W2?@es$+D+hY$=~JJxqo(Q8maK;yH;dhB0uUP>-q|tGjRy%kMCOl>+REE~@@jdqX+HFzp+`uB$bqVSPQ-LFZ%mQj^#(meq#P1!kB^&>ra^L9*sZRpd?Q6Z z=?O4JOrr9(Ir7iG6V%zL;JX&ZZ&GPOX%>}_%#m;SmMA_-^yTr&De8f!e0z@koIj^) zaA+^->yjBKAC>ISrOL1RmzyAN@o`F!ismP&^7F~ddpbHtocukGB~hxDXr6GbP&YH zoNm=A_lRdF(ZnJ&o;sLSOlrL(v4<#h46eA%-1P{0%42LV-gY>8#3?YBHnFlElAylh zr*}E&+YwshxWT6;5^APM4_9x)(?9*d)n3Q^v=0lJpYhRzL-EnFVoj*AzTr%)CjF;3 zfbie%^C$VgiG%*+BfjczLt7|%Mo|zGyb1K^=={ECh`|!fPw?j6qj-6vnqFVV$~-7~ z>`+uA=C@jTWe&rQq6(}!1^3lsrTA8*G);pr~)=Z!TyUEC>9Day4 z+FDm%(}r0hPE-j5Df*|K48an^5G*weKlbtCCR$PVil~5upZGXZJXodmHcDN=gxW9? zs{lXs`l@7>!{@(|&d6rGg{#9M%*N7!jis2H|H`Kx@fK4C;Gtn_ePcBq0@EAj^zOKN z9&8@l3VFLo%+u(PF`u;}<62JYdYii=us)Ex8x?+(W=^@Rb1=7@R_WMMc&+);a6Q)=WRLZ>Y$o7ZWE+>7Q8rZ^gBhZK+i* zQ#obYCO8<^1h$Md(~$Ad5=-$ZPN)J*Rt)q~F7^-oMaJ@6#yy;BZr{ zw=atG!O(fqFWy^$^dW^ko3gjrqcM-!&ynU<%!50Ap1PsPnsf2kjNmwTa?eLL$V>eTBdVI~r{j1b z32v(DB7GJ4Uk$gK*-=|BGQTL~_5KV^(QmBXFXT=B%)CGO(z0A%C;FC)tRcLIFp8o3 zp!6+I$}*oSDrYKANB@~n%Ib|Eq4GdiEV{c)WUiC)8>z{82mMosJm?llP7?Xscp`C3 zcIMSmJ_wmNCQTu8kz+HvRMm`=M(AmoCpx~f$Eyz%d(D|M_z0DpdlFUols^`MNr9n zz%Q?wmz?)->I`JoCXvkS%sidBljP!Ks!SZEd=uo}cGL{ys@#sRtIEb*N%G^6`Ini< zRGFGUCgs)xN%CIEd}VHCR;YjuhNlt{f(PCCvO?;xcqG^Vt+^m!tH3N&V5;jS$-d<& zS(}D5XIj>#UVXP9Yg4zrOV`m3^>*7fSLwiqxBC|)=RH3!N5%Q36(`*#sW|B_)>g zsFaR4??#-632~DDVihOdEmd*ST_9eZl+MeN<@Jd3hiN*_#b`%#I_XZwNq4FKyV6i; z9dVwRV&Wu!9VgxCIO#54oT_ZSohpyeo`L3$Dw0?@HF;Ofk(V5e`jOsuk^mBGKWF z?%s()yTGX0SDPxIhV~y``0u8@NAF^f-pNPFSE2V4#~c~Gxwkt4R`=-bv^N#=ZyqJD zNJj--^lz@W)83@_*j)Ju=>4PPjyWQwoICu(w|CayK&*2wS3K2*az_)l$g4JT%{=)4 zl5*?u|Mw-ukt-@GZ_bm?ASoYQGPyL_Ey|+#)Ugb?Y#jhCmD>$8Svy8|nsy^iWT0!$ z&di*jq1un^%q8>fGEJjMJz}S3^*d?uHAH{y2~$OX!;GVU6VYEAH&QBz8|TZ5GLrN5 zFP$pVxeI2R=EX8QGiAa5Ved`g>nzIs@tJdSlC(+NEM3x)hST;?(liN4nxrX7p=p*j zG-*PTE|kC_%SjuWjVx`70+qEOLQ4V5A|L`TprRrw7qJvXWznLjD2O0<*)9so(yLzi zf1jCW-sR++kfiA6-v8(KwkO}2XP$ZHnP=8_-uIn}kW*#o?@W{Xk?14y)42LKV$WrJ z{5BmuUMJT*eN0$SZw2_QZoJX%$MrM-gFTM|gwIals#R35z6mA_TQ;I^{AtiC!(eN#WS?>H$eH_GnD1Sl&9i;eY!jd zRkn<{>EgCDva1@g%LM_!cY^i@WLRXm7j(r%Fn`-TM{GWMb)CaX2{~E%?izpM(hi7&nE7=1{@@>fe-omtu z^+t@ySl?z_#*?9+*Wt}gGut$&=oC-^EBXd`8lh*L8U2l_qOC}dkkRHOmC=s&q40j` zr%Cd%6kpb3m?4ix8Jer3hqC5CR88Eo(KD>424<&kz-Oj{R;S|l4uOhL(jFlJ{jVW|p zGL#LPRE#$+o7V&uEM%kkYSeQX) z%#%Mwvb&4@(UTp29(DJclrexAK|ik^QS6zPZe*4;r5m}@_24^NH`Rq-I!|7>z?XIN z@-a*@{=(L}O?T-=v6C#_sD8{;x{+&kRNZI-weT4EUFi0uk_Z(M6?Q08)7udmF*9Mz z3>;GqOma+p(aj6HC{%{JTXz|Dx^Zdk*QAupbm)lHH2RKIP3NfN8tiYyB3@WoK6H${ zbdfLX!4(tKDRTLKv`$gAQKi?IF84#5$4{J~Hjzv8Xtbg7dNEzz25p`#ouD?6o+4(9 zqr9Tq25Yvx^W|3;`AY9DlW%z!w|95-2i4QhJ~eZpt|Ndsj_dVPJb4hM&z0fx7B@e# zM$b1!@#E=;D7|8({8Y?wT0Xs00r|_p{u{6#!MOvD*A}tChbVnurTlaZi)VIAd>FqH z|HevreavEdqeD%-AUR%YMM%EuRnd5CYFhfIljMUjOXx|l>K=4v_4m}^@9KqGvppSy zLkjyF?JmStls~cV8^+D+5z#Uf>gmU`480J7J$h7&qfWi0i)r*C9#)?CS%)b7%gOT3 zE*&U`tix+sheJ~9a7cc%4zEo{heuY)FZdSY1*@iVd{B;j=;F{HmAlM_Qg6XM=$O6)$(1V8|{uhVdX^Wf3B97#3Fl5YmvW6%J_1HypCj?icC#X#9I~e zPOZk|Wqhqtep{(g-n4mAws^Zz{*Y}kNeSPmlE2iJz}91vDUQEZ$v?6kCMn@7)$%9J{<#?44r7u;>-EmY8>Nb>5Almh7}T6w!xu(q6%qMk^%Kf4`j|KMPTB#@N!gYUO7ZFE-I>j->~W9u-}U zppNJ?cC@y))1a)y9KnVcDKGd+@2is!I>cB*{C!G{8U!6;Fw(olyhdWq_LaR?C+|M~ zIMN0m77uI>>HJVOYH$)HK^x#~Pk&8ocmFmbk-IH~w+Teqlk4SUuE;7kG!ClB0E#@@ z5t-a7a!da}UkCQQ!YvaA~t5)ga)tdiljs z0vx)r0MbtjP%5&jZI(Kbbo*X|{F@eysrz=PwIXWO!CIXIOq2NNmF79*Z0{Q+rzm^q zRC&V^m02b5qqHP}q%8?NA}oPN@ZEtDXiPa;cN4PAX>lwXk;V5n$~UzVWbv?^QIfDV zr5LduM9bODP4bE?s~E#_M?ztL5*o37e2lp(y|G!oo~0VB`@Iyq>CVg2P1iM>rk1O2 z!&~${c#D3&re&A9BX8LS6Q{`*=c_g}U!_i>#eUxgt?a9@rJvm(Z(pj~yjugi^}`7I z9UaQJ8E4EJK8}V={Q;Chn;|s_bV=hRU2Gsn1fD;W9_Yw7%I6~{Z1oqIACD_x>Oqh& zx*1BsE%irZFb=$iJ+K15|`m5StKi1 zn9`74cHI_vMXpOVJi_I1CxB&zh?-@l4}dAEVwvgs=13v-2OJEsmLOx-O!XvRs|~`K zY7aQoZlUO*-VWUgMA==Z%ZJ^nYpc?-9L#e_M%4YItU7zzWUX5EQj2`ct&pxa(4cL}wPyxIaJtvKla8g< zM_9CvZ`~FC%Pd;@;aPHTks21lU;DEMhKus_z_1xMPLroO`whp$t_9mdsKKB!PY(*6 zIDef6ht7QMw_Y4>8Q}#*HB9VsdK~?B%Lv}h!?&`Ku*-6_X;E#MB!S+BVVnR1I3||K zDe-X&Q!dCWy}wQVyhsf+;d!!$n&N!Q(-E8vNPk^3g3mR|izwd$=Gri9{3UvHN;7e`jv8l+y2uJWjvEolYi zFf@^J_CQ6-5z)?rBRkPmJ|x3bJ``7aQ%Js1tlHuzE1Ti%rh=$OrV%Y{N*_fl$_Iuz z%7;DhQ9j^{u5n+u#>d8|9_*B}tdB;UHdItpHR0eUn}l!KHq_yJo*=d;s&5n**deu5 z>(^i(CQU!zrt8hoYjBK7bH!S5o*jVQe6S;s_@qr~!k3vFYRenNCu~}C6}}p+F0ZM@ zj#%n6Rl2nj0{2n^pVFu^9q~=9cRoH{g;#tMKd%_TUvQ22{m;j6ycEqI_zNG>DHh-6 zzNpg2A8Wt6|DT+pwlHZUo$^E%<&_RTlncZOGw>P50=T_6w`*1nPJ@XFh=hcb61+Gn z%BRneN%h&M$i%uyLd4mGq*xsNX?t;As_m&j#1u&!Q=LR2Bp8C>NOTf}m}b1hJl%MN zm|>i@>?E5+%*l%dF9o>y24E)(up={&1@o++5{aDx36xJ5G!rM8rbS2+iR=33MM<* z9YD$wd6iAp>JqWsCOU-RNVL`N03`(E3Y*MAK&+e(qvfMM(z)MN+9O1@P2D`>v>BU_ z%Qc#0ylY9AiC1HLNU>8KUL>(jdxfYahc~_~u@HrGGD@t@CXjdiEQC{4swW2?O3qd_ zR2Qibr)n=1b>kc*iRwiYImywiX+mt6qiWN}G}NX|X{xSoE>w~{Q?kK$n(+v+g`H6P zbnPUD7VQ+`48uujo@qSUGsqicZ!CGv(jFbssy#%m*n`2R zU@HMN^ld)Y6^9+N6S2z_`3VB$t9jS4&$*LHrK(v_$qKKy`?~J zzV)>B_tT!KgS&d#`nm@Z+R@bt?{I%Vwoo2ixnjk#{A~57xVR8IKjgIc53j_Q=|iEB z92}CDlhX-*Q(xy0os5^0gV|^Q@X$&+ssk@l^@Jd72n}g) z<0bP3o<2!7w+~WwbcTBRIzlTu`v%%WQ$1@5AP!dSFK)}r!93$AOo-DB zv<2Hcl?BOZcDyvyW^XJsV(Dg%IJ)wwY z;?JpZeLZgZ!#*E(()qh?BDLV8$CjY3mUVe(H8o*hnbYnM>T`3oOGrymZeDIastCS8 zuMF+LOLo?$=yiGK;ONmpbX+T09Bi>+V~skhkoT}&i31}2IhFKDJ2fbBSewH*y_l&t z;sCyiwN(}CoOJ7GNVLA5P8^JYk6=SbQ!woVoqlcCNl%hZALqn3Xuf4#Qn>w|Fuzy4 z;No8{ZgTiz#5*5e&3?MUz`cgJ$mPcu|9oX)toG{TAQS~>Jiw10nJ*oV9-l8A9%sDj zlp?Rd%!w~N*g|{^6@2-DUYyQY8K&Q_Fq&JJM+&#!BMv*ly^wIG!!JD8McUz)IQBK$ zmP|o@ye_{- z{KPhqNcI$qoi2Z&SmE;Li6gd&!GDan&*eW>>~Q%Pi87aeDQ;3M>mvRf@u*#d@E%yapV5ii?S0`ZR(-*ovGiA!AmrDCJYKZj=W)kkh-YYf3civ(3&o8tf0j7Y<)1AUy8Mg9Q+5-8yaI8h%bzROy8LtL zqiX9)_RJRtsj&G<#@*yaF8>ly>GIDKK9~PE@gox%nC!_GUjY(J8Gb3K-!}rym4dV{ zHy$AQhaCQe@H@mK(FrA-T$rTTbOicplMlb6!Z8!usLB2|B6UgWb}9 zNjN8r4n9Q((kbAcH2g^41>hqDeJbO0LLBlmo6wJ2S@tg^T#Q>x_7}3hg#Fco3vlDX z{!Q#Zo&DPh5x0hbff zd71pc4;W{WeE9Pi*D-EkH2Pi2{_7a;VtknKFyl*%e`lPEx%~5Z>(P$`fj4H6yjpSBBmc_hu=-~6+(QS5N|QONVr&tw;8Fykw1x1)ff0b z$NqO1js0$7yF9^2=kZbe62@W1rx;&gT!4O$_zDzBq1^OQ1KasJPv4in;#_uxv&=(Q^9L5tEdl)ZbJj^&1eHHPiGuAU+ z&iE+fKN(j}*Zd8PU5pnq{*7@O?utq7V#adD?=U{j_&dh;8I#eWQ@pDgf5rF;V|%g= zKZo&MM(Tqo-X)CJGrrFFH^w?Fm=WKZjNf2U3HHGIhUdDJc=r=RI&)9%Ip6Fj;oJD;){JR-nXRJV9PW1B_?`3?0aX!Wj3cr@|r;K?x;E(8M zGd{`qBIAs79iGK_7UK}(7a0G8XmFtgq#F=2h8cmhR=Q4j}_e^ z2;SAB5@^>;v?7;Qc(I5Z+=jQ9@XD3mj(O`qe=eum+J^HxcjRsz=o{|OEeMwP(9WyD z?zaAI>uQF!hXMsbBIM;cVvf0J+zugwn`qzQ;EwWh>l<2!1BHc!!GPLHI82CsG>iy4 zw-r%@;Wfj{>bgShr*`KBH-|^Cn0p84K$KuZLGju(BgLD~DF_9ZgWyupY%vMhB|9lB zcuIRsZUP{S$x1?x8!b#>$it4NAdH*<^} zWo3H2)&Tnd7SFx^AdzZtzwl+{tyG2(8s#cem1RASOEeSLN2j`7?)cG*w^?{gn6Cg3; zX#)|(aFZYz<7pFNGN|b7avV=*5uXC0xgsVzsa^xjytIqs^U(ng{qi#c~a{dPl0le zq+=gl3w6ktTnkkK>|&=ZjHle4Ss1$xOt71tz{D3bsbCPZx!_m|1lxo8D+&wSLk0LG z0;gkFZERXgla$HD#W%US)km1cS=~X9jblw_aKkey(99MJM+afz7r^l%qoSzpup|mS ze>7bc?TRS$2=dikO(1{Szi4vVTvHcyZkelQwg2)-t!qAeluz)ZP0b;;g?{{MKua}_ zZ4J?Z!_~vR?L%ES_O@m0_j~X`O$UUxc6ZR0#(^PGz6STKYML!1oyqR2FmD%$*u*I^ zSZRN&56NUZaV6zQ3&gXl5Y zxUcVc^m9hK$EK?gzZm7xe~kO?Fh1OdN95}Uozge*%HXD-xgbVeE%@uya|C{RFTq^K zSqp-3Q`l|rP+W7FuyA?*K)`t91-y~vl_CKno6_11zDkp*BP^Wn(Q)#{!?2qp$P3TM zS>Stq9DHRyAr3ecHqLPSJ%fVjh#)VVuLO1Kwg`N;aXm0W&w}q2;{lp<_l5D%Go~Tf z#$1N)ct;!x%S+Vn(}(koKwh#T0z1G5kzxgY>G;7+>UXwD7f4q(`25PH|Cn^?>@BCf zE5Vlp7Ltc$F-xA650-Z`_zqCQd>MJQ@GCd-72+95vtcq}K&yP2Zx8qqBiJP_OuuW> zZ2hpz8CAbKz;}dYQ}WUDyZIPAmm>zg3}3i@uYm8#2>Q{pW~cq`#rmAFAC_68>UR)) z0h1`uq#JI(SHQP70$;d(Lw+G1jlg$nn0_S-Z2hvqZ|X~U`K|@uixK37>zBDuh$|!T zh3j`8_zp(k>krd!XpyZSmQ|zbcQN?(M35J*Um}b=p89td`0j}yuOdvpM6A8f1Ru2z zEK5h#&kw#AX&~YYV$>C`AH6Knz+nW2FWi0&;G>iK%w_njeuL}!Js7ywm_Ua-dT-rX zPv0%F?Ysnh(dt1=u@HXrZRRqf!}AeX8M&Vf&&Q+St6XNJ+4+46B&UAy=h*sXA}pGI zY2Zt=#aZ?nr62fqN8k(B?+)<25`k|&Xvq%xo&mexMH9933-5RLg6|HDN#-*4y9fm1 zrm#W`{FFy?8TYv$IQdGz_o4}OgdrI^>&Uv&&J*G+@KN1L$B&{U;kOMxyp~{HBcHPE zOx+vt#pAabKPTTF@SzH-dQUutZ*3Ugcfm*TseMqk4PUstgARE#M>2fj^4@mHqiSgQ z@Vbjjza!wI{874;el))L3vE8iUo^fn2Ol+K!xx^9Oz@>4oYGAggKri1zRP@6UyZ!* z{2l?HvEOtDAG$kNeg!I!;iGzKZ0OJWZ zp6*!=KGHp!ej^S(>dT_>?RD^(ah1{~+0J_UCGZ)$WRD^5Uho}6M9MGK>uBlrUxoe; z;lzio)#95Aw--Ni?FHW>9^~n8(&HD+;m4qeD$3DVrl!~w)Njy{fTE&Z#p)k_ILX;Zmv$dDPv?% zBeDKIJSSA`S@hwf!m+~gPQ#u3CNJ>ebK9JK)(p4_2ACcLwY=W3N0s^y=|1N>Jq96i`z3io-3h zrX9F&8`(4MaC*(2)k~fgnW?{%H(Z`^O~xZ}-oxwmH0{1T{hIVuN%6}4={@^*ugaJ* zKV`nieE;e6d*A+k+UIgc`tVwoIPR|ChG5xT%F#9HU1|O0r)T{2>APR`R6p>lya93c zB=43tT$6rzy4)u+-&1iv{P4pI(otn}9gdNcT?N2S4Y}Ny(2xMrN2Eo``zr^oiG8N6>D|Q+HnM zyCmjP?`58=WO-`P^W4#CeVd|9}&bs)qiX&2>IHZ}BycDCrRs^Dp980b4Y)IKyw>?X?!%aAF~mk$jO|Nn32 zi^`F%n3%ZXUfNL=-*VzXzKHSo2Df3!6ahZvkN0)=^=|dkAMEk+nmGBPSb4cOHqv7R z+BrvwHNv}^L{b7MKZNDF`kS!*QPLrJFI3)2>Abg5=WnB+DuNq1Jwja2|=nCV1+=2))U3pUo2tVt?Xi)w%XcqhJsZ zDN=lrro&1n5U^>BPku-VYPmst*PQYW@`M~97#{3ULi)o~Odir6?h@Kp~#a_g(3GcppFW52yA4&W*rNMj7!n>s_7=$vgj0D#&&Wk+`L2=#%bA3K<57A>+ z;dhK8PKhPzPVG+3@O~mSHVq!1cYvZySKKSr-&7^|O3zYAo#NenJ|(C~yFIZrDy=y0 zyXUPmTolJ}A~-f*|2Rgy34)N=xhnOz(_=i|mu2j+Nc?;xK8w_dO~>CU$erSe&G1c` z!%2Pmd`cm9q2elrYc^b7Z+z@hL_CJFO#dMA50WAyJ)ieB$n|>9SN8D5QUVg9kv)Vx zbO9waJ9e)3JXkZ;doCF@Re6-CTqW$kQ4B2X4y^!XfRvQ<*CSPZp_+r5g5P-xX;rk|l9Ms8C03xXC$MDn2trQy#=}Yk5t4IxobThp7DH3%x z>LSuN73ow%+5_+HieyD>hIgZzvS-ZjjW~i@&tEBt;XM z^;!Jj)M3~?0S>KO^FcW2Cq=W711H6KUd3rfn7ZsZjR!%XpA?N0CtWc%+Howykj9if zDH;f_SI$%IbQ&nmuT=B~gsIDs%gTeG&<{DQq*zosE|j ziK#p$s`7wCT_!GMuQ~_{{m5-%lG{WiH-gn=;z8JMXPUb&FfmmKefdUpO?iwQHghOMmDL@B!i?o4uVcUa+^fRZN!or!PZ5qU{ajw5OLN)kmv{2vm7GMa)>w!!PXT6 z7fR3}!m6kcp=v4@Op8N=Rc$36`B#=VR|SLqh1H=pzdzq!ke9!FA!G)F^c0=~^7Bs2 zUvc8HB28^-uB-qxU$H0;e|t~F6<9b~QLBQgD%V(SYoLT&Gci(t zqBS%(R@PKk2bqT^WfU}sGuQe$aazQXztBlgvo#k5^8#kUq_(2M=;1HQE6yt{C{U4` zvFBG+bFiXeL$IPAI~i;aV)p=@Lk_A&P*Z(%Gwsar5dmRa68Nzt0TQ9aSty+LrUWF+ zBDl6CaD`YK6X?W|4@6>3FeuwD%jT?jd1J-eU~yB>FgwX4BF||6#oWAhL)~isvQhN% z;=%~rE zo@jRyiV5X_UAgeX+Z*2aA+SLm3Frk&HK{61EI7p2OCuqr;ObJ#5n>JKeW4nx?zq?z=*}-5#IZRxT zIg-6=iGReuXpw)HkaL);8YMcDRb6hY;rdi)4WVUg_ zXoKJ>3D(uD_vhpnln6NlKi;iZgk=TGi$NL&2~~zjndj$?Ebr78l;4369N|VGR_>fE z%-IRnT{@le&HnrX^pEFqGVoI>pnQT;0i__naCu?Lvf@IJKgmgeY$vgzpkUduW>R28TB_SobwD_(AgL^kFX zHp4h=`WZWh&bBh`RW_CL&KADf4qyW~4ZYV6wTz%`Uy&Kv-usosEE^cJU+W;djengZ zBvKJv?+CYa_^5)oN$Fi}m4mbXp`32Eg1J1x!arw)M=q6HtnhIb%IB>JTooOa`F1Oe z4dX0;FIa&QO6LwM&@#-}h4V#iOSVgRW&e^L%9^;^!k6vfNageuJJ{0Zql)R9lmX0k zRA&LFwziPpv*^%~={TiC9#mkxMSraU8uCJ@9h}5$_=L$z$ zXH9ttfm<;B0NG&}&#Q7%#oBUZVc~hrc*vN4G9GA$8PT7O7Xr9n{HxpqwIgZrE{BBa z@OQFmNw9(jE&PQ12N6)2Y|8%-1*K+F{z(*68AY+XbBey(Ls_u|sxc4bPbso3*3d6h zbX&NgU!>@E5>~aOG%ocZ2`X4l->N!lkXI#nnTj8kM-{i{n|KJMG9orXBg(E6%{S3yLxHCxvRImd$=QnTNm@ig_`l`^)K2V1OIWwB#lRi zC1SF>-j#h)jDg?YY2)ROeQ4ip~UC0xa7sU_nmxV0#Hw>G&_X~NF_Ugz#67pp2*Rg*i zq`$^Nv$R<2AX>WAIEa=;r|2XcGND(UlW1wT-buA|tanl^ zO&fGtbj-I>6sFiKoDCTL`%gp97IdQGgUIU zTji1pX(lE>RHtIVL490yXD?7?#{`td_64dE(tQBEOMxvd)O#m%A21IS+PbEiCc10H zz2jQUYXkbD0eyd1r|)-)Kx?YQ7=S0Zs7cg_Yirh5fzZ`UpA?|N(6qU{8GSMb(aDfq z?GBEUg2DCm_;><$dNk?9N!s0m{h{_uoYWZ_!jlSgGv%1lH&s9nW&8Qj@v; zSxXQ`u}(qObR1$1OS!dMJpy7@7=v~zR0?W&LgEfi(~$kf4HeChz)9hAF`V5an!HW8tSKeZxj(k+q&BS0u{YH%Ziiz6LglWnc`r=7>JGS)25xDK!8>l8?X9gpv z>~Ashep)6Wn<+usUPFET^_>(^#iECeu=iMkN)P(vA)`^n+SMCbol9foPmMZC zibEYM7OP|V!!uR-qgeS{qf0|$OS6%DicH1hSij)6o)UX6-Rr&`suQ7=` zX6cXO-$v29maeg} zqQ0&HtCo#4JbKeTG2VsV7%bRbsrYu|?|A!>@ytNYyGr)w_axq$mtuj?-K&u1daipA zE}rX-*&jJ1|L^LOv?av?;6nTssr*QZz8j10RhX#c1=j}GRIRUStf@drEcC?4RWyIe z<2j6Zl2BJp3vT`*8tgEo7|no_E)lK30BxyA&WfF`; zv3_YD7x0*iSq42RP_vu74Z?elszLg@3OrNQId|XlL>Y_5S%)yG3byy;QLRuM2kjT*NAEXN8=i&Ec8I>5RO{U6dTE{;ah*Gj zg0M>o%GH{h(v)pz8}@oenI1zE+(w+zVyz3$M=A5VFy_qKiRI$u>o?TmNmmI0)(m3Q z+Z{)FUrRaAMagabODcc(Gw%CZ7V)u_8>LNG_?uD<^aPIXL~zTQO}83U0mTyh==lb{ zPo9k*l?^OPuZ*aY!D4*Wl0k`>g#zb7ecneDSRse2$8&f(7qMJHb=_)U_KvOmgP99k zX_xec>J9-nKWoc3Rw*Sa>o=^ft)k~T%Z>O3Jh>X5aLkJahv=T8)WofBsM=gn)quMO ztMa+jv0|(>F-F~Z)wn}YJFB6Mxh<==bMF!yDWBWWN7Xj-Et9qWkhNqn-TnxPcdXXd zaA>}NsXsHE1w6e}R8b`i1hMjlbCS%1mETFzY=nHpa{GmR9Uil z@5{9t)>H*I;vpe==+5rG)*&2di*uA}*4H#+hJf@xuvlurqSiq=`i9%OL*a}^u%4#l zMHBVk5{ESTF%Vd5U3s0s<<%8x6DP9AKcvbG4t-i*PZi>SEI*eip6*`cF)AaO$eKLi z?d->~vV((Nox7CfGW8>Da<5$JXOGV969364TU3>x9jB8RPaH)C6*@lc#UsWoRgLu+ zhT#1W+a{T!;FK%x$1Zl8PxV}u7g@N|N6#kOx`xJY7>?kwi!B5)ANNrois?vg zWqxKSmgjhi;~16wo%Hmn+c{9v?bB0^m<^eo+0EmQob7KW0f%h?1rta*TTd_bI1M?T z|BAJLM*evF!m;CWMwwv+WmMA#P-4T_I$1oqHl)Z_-uPK15*AT=d9>*vAz9o>$&!bJIX(x<6MUIy1W*3suOWYzYQ&uI=qO#_vC9 z;n7OeA;y(>00s>Pqf2=sM&4&jL2qbuk8H`$`{Z|B?5@OGX>n4mqOqzYtn2eWym?^h zs=L{-5<)IVLOPq*$I2guNBxLIIVRQ~pE5B`hvc%bTU}B5L9Bc_EW#KmiPBr+2pgc_uh`E|VfhHp`4YulicztdUMh)-R#?}kUYXx9t+DrQux{1b@btHuE)y-%*`A#e0zh1nrq)B&wQAn?5)Q;`2_w8k9T5^P^~DHabro z&8jAA!bxH$Q3lV!S6;UoSErz-JjV9o?+#C=I05F;CRWx%7SujIw3kXAezeAMok!hB zs5?b^xOyv|{^au*?;EiBJ$Kdx9L(DJ2{R!UOdmJxsRMM- z=Fg|(f9YhvC%w#&Uu+nD<>ALow4xp^Vg)4p+QW(B!78n{QSS0a)TYr`1$Z_*RAsXS zA-_jH8#dq#TpbT_Ru|{3F2=3-A3f?3Zy^-`9vU{))K%gkFugfWANQ%}!RE28khght z0c}_x@mX}Qc^dtB=Cf90Tnj9%-8)-%4e~k+-HQLvN;ngTMh>Xw(r#6M+^znV{>*dG;D_kW3D-Hr%gEiTWG{nCSP?YD5q}n5 z?gqtP|G`@L57ai*01(baz_qOEL8Ep?g7DbqH= zp@=51W#o)Q#$%&%W($ZK-%$=vFR!iN6x3fbY{APr_3MK;-@d95{p4>V1Z}QqM#%4$ z*Wgvj`t`M^VXZex>=(!4QDQK3-mJ#Rz4(if(|wPmpM6>HUmVq=F!!ga_D;Jr=P_G4 z)4dhnGQq{qSXM2w?z#ARs!_-x@?*Qh`dD7-h>00>d)7e8(#u%GgCgbD0=$3ZYdB{) zZo`u38*91So6dub(dXe%iA+Pl& zYl?nj?Li@L@TO$_*^`*jJKWRU+K=b#HHhh1Br^ER^^`v8Srn6DK3iAbczi|w8=;id zdqG3x-u6)N9DKK3CglV1zN|yuF+?76izF|Jd@Yhle2<@UwUm!S=JhdS$eitQsYzav zc_fm|W%wNYWhs9OnQx3G^K7?F@{-InIXdf|%kVk+a*uo#GJoMqB6H$Bj;%OGL=~OW zppkN)flu3qnznUya#4F0C2Gany0FUJ5o~WA>CS6&Ute~pVL zn>FI7Ub_l{P=O=34Z)MqUrAf!rl@qZeb5mMbd4yps4A#r{=h4*O7LaM7LgpJ& zQ!>i2fx&C4MwBCfT%L?_R8?}tcpsVy2X+h2pgsq;=|w)zqS%ae{W?4`V_lbaP0v`@ zpAtKN5&|mCBUYN^icx8jE8hFf1T;!VnqNkmNC|0Dc$!L+ zT>1u(){W)G`o%TE+eX^X$K=#(j!fHu~aRQDFrh6PqS+-H#T||w{-wkq$A&L zW2!{@V#kv-EVP|+NXqOEHz;m^d%w;}wG6A|vHaZ!b1BoZn4aq@2verU!7GY}T_99bunWIEERpB&bq#i zu1>raY|=?&snxCRLwIAB$KmN>p>nBSv>l2B2U4<^4Co``6EbvU&KVICa#_)FHH7jU79{tqEn|&G|y>rVM^@u2su@T{?0VH zABjFPKaHz@BaU6L$8Xco<8^Y~)5nDM^j3h+>c$)Geq2uj;;m7jTuE0$L83)mZ4;Al zSA{AsQhtPN&P0I)rY%f)L@Pf)UA?=QvZu>0Liydt{yUYY9(9!RM6{H@c!pN~1}MLK zhO&H^@>JZfPnQRw{9%7&<#o$ny{o{~-xzDuwQL?6tuW#yP#Dx>jmi%Zt^713QGOPt z+>#g}FRB*ZHADUudAWN*T1FG5Zz5$n%1@XYRbAa|G69)9A!sD3x^J1O=OW5P^x>IZ z$V&D=l6)Jozqc?gW4#e0GS;`*mhoih=XH2<(@b2;>o<^uNk>N&F(N-i! z$Y^tt%4kRXPU49(TiLs@emswQq_xHf5J9&;-5I6P$aJu?=j z#3w{hNX;%!PnO??Lcb1-Pa$=a<4}kuWp0ItVp(TXio-gm!$S%^F@0gmfhmy`qOSA5 zlI6=#=s%82%&0S+h6rCv!F?-D_&Tws!_z|CK-2A((nr?^T1UaF%w4$e4B1se&F#)h zk$<0yS?}U;ra?wVF>o5H5XMY{n&(R?^3r*}tc#8xXBs^4a~kA}A1e)2wX0I)KBVy` z(x|mmF^gFQ>{|j`3yvDsuu!jcK;XNs;Ad&Xiw9QV%bgKvH8` zFJe;4fEUb^_aUioX1P{;^hjl|*A>iC#cyhyD*s3;K4@opsl#5IQ7cS%q=3ai3_U^B ztSn_h+9y=?vK$JCGzJwGW&T*v>zM{&VfH78BFM#TdZ*jvr zfh%XrgY$h^H|35gnd`8T9M<+nOQs6^pR?uTko?}*lA{+e^<1MQtAbrMM?M3|FP`A4 zuTiYA-6*ZhkE|Vru1HC#KJvyn^1cjT))RSSCdKBllH#^uB}M)*lOlWh(&P`2 z)cyHmCdKx$l2R?gkt_0#m6S4If0}$8NgXIqNkv|sk5n)jJ;QoxV3wMC=;1a``IY47 z(&YWe`m!!rHZy#%vOAJU)l^BQVHJa>y<)8=zI?~l?MzG+PSITXDiZt4Sc!4bm_pYj zL)oB7#ds5=;<?9l`)%%C&o z$)6(G-NpXs$&Npdx_eE^7{H96pI474_DoARGE17$ja=z^@Ext2>cTIbCof#!%er~_ z7$zBiVQbx{yL6-2NtSL@KV~Z3$Td5vZZv^fc#Qlmbo)|Cgo=m?I~1zv?FfySnJ{Js zjwy%Zsg!PB*hQf-)ZMzvu%q6f(P&aiW;%4lY8rhJ+(rKU$}#+NjcNOqcti&EqFdP@BjldNkTldA*n}Z-X|^mQGNcNKX+n#!+6; zZG$!2-ud#Yi+rVbm&v!hi`%=q`h)7}XP=t6P}dQ_9LM$gDV{ut(&x(Xd5fDLS)=D0 zqxkW3M3i2!QhqAtI4z%Es(}3EVE+x+j|i7|Z15pUA6O|r9mC?8-4Y+huf)HxQeGdk znBM46Q!hx4ms$~$?|M}<9tSCu{^=z7V9XMFQmncMomu@oHTb)Fq1J3q2X-bW>~FNY z5c~Z~{gHc1-!N`ok6`caP)|ReW$?GwUAo0lr*5_pZ=o0Qu=2#uIz;JTPL_Xm=|DMT z9bVHq9FkgxL-M0_z$W1n*Wr;>@(aGjc)<#reZy!}+GJk+QMt=(D0Q=UxN80_ykWTZ zbZNy!>ArHjjE;}bPA#vjEHT+pnTjNpZ8)GTh+8|dqx!1`Em8XWa`^`(4c~Aby|mj` z%Xf`#bk2sh^#qg?rT@8FUJ{G!HLXSdCMn~~74kZgaVj!3NfB>V$UC(flb7+eO8IT2 zMtKu9WS)dA-ma8CWLr#9!Z)hqFSRAG_1I)o_-mE?Bimt;624L`-%}FmHZ)a^R|!%2 zQnlP2NA;j?L-_=vUB5sdXU3G>it+UuqoWb2d3eKwtI58u?ij31vO*NS|IS zZ`TUemQzyH6X{lMw?plxqY%P-HBtKHT6wP(Kbl>}67ZQC`49_;ZrHH|{Io_sX*8&% zEObT80#U=VKqT00?H+akT0Faf*DOV>OLG*4^vmh4ECQ zHaCy%6-FoW<~n(0JiX>xS65pO)go0TU8TZ|LyR!aUA6Mf z3%=6(>g0nCG1d@&pAw@6L5CQO^lmXY?P6id*}k&(>g3(WA4l5Y!{UMMA)Oz}Mhy;w zCTIhk?dh*+?Z#ReyW2u|4@Q(dxn4fzimY-&+%erS8aE zcEQAHvc>tT4b4}nlW4Kuw?QlWYHaCeH^|$Usy6S|z;698f__JbGH%8h^M;S3Aya<< zrBH&T27xZ=&H=o)p$I&GCOy!RZ3FlNk@Fd$08dp61I zvQ^=S<=EW1^o=uJ+W*kb@NaawfKlnvFfB@dut|PCXDRh(^l=XN&X1`YtZq$EgX?kI z;jrjq=+ny%Zfz2#yfCB3hFZw{ZTwE+s>idH z5bk$W*|#Ysy#0&tjoE`Zu!+Z#fp$ey(+T^iChHbwCreR6M6!Z~DGk|W*KLtkl!90g#MBP8isg z&J$eKfNhBe6~JrJlQQLdxsx?zGS(j!ro59|_N}0N+O3y1=~!xgghl)K)?MMh%%Y_q zo+bAdsbL}f%{+TxxF}B#44Yx&Gwc{+mgG3l=>Pc*uiRT(ww!~ip5_q4lgCyj*^sHSXY5W-smL>#E$ zVX)me%y>B4)6%P7saC!9!jw>4>Fe$C=HkdITZ7c=(N!Kbvn8#d9EK)R&K{^pIU?G5 zaAYUC%7 zIeHC_Flnw>E6%e6u$vEd1QMULDNXn?b3<);qxghPYp%jqqt)d#wb&6$oQsj0ZmopC zy_CSGH0rD*d=u-Pk55EiXZ8w@bY|r%n2@}gO1F$YDkWW3SOyewfjD6XKKWPxw-<+4&#J-6F);y=kZ@9h zHy&rr>+@z(efEhnv2KzOaW)|-7RQ9!UYu-WdnynyMH0tUCy@vVhF~}nodhAK880zU zHy$Bo7^f{e$tDqV@?t?bN{K<%yzvP*AsioJ$XVo=nTeBg(h)dIIi}&zoCE~vvvlSp z2<=EC8urpg1ToKq=ObfS}Eeu5y#mF$2EJ;Pe$QDX4i=5O(fEZHfhalB9z($9TB&>ZjulyZNeJZ>LlB1tGWs% zJJ}sT$`W~%P1foXvD_v)gy5vM)$RZ#1mp^v%tAn{oDZYrqdwBfgH_riM72%bJma(( zn~=*jnq<6dNtlUOV|z%kQyg9-u}*u1s3nItzAUj2g>y1Wtj;Eocl|7cQ&p-b2OeO~ zRy9-?sSu}XFBNs;93_eBMH4y6(X44gY?z~J)5bK^rcG(8u5T_>k~~wg!FZbS;Pg{= zLg~}BlNegGQ;0JRC#89&@np{+FV29a=HrPa&so}|Lt3?m=$JU=C+Sq%l@kedkb{y5 zkpufR_!Mj9a|%LE{l(s7STo;Zmq1#Ez9B4GQl}mdC}X`Y>FUu>*!y*JM9E#f>!X z-?#fuFYH)W)KPE-9W$l~IXPI+8R}~7_UGjE_64!603HW+_hCa!Jf9rKBRp)xgFWnqY3=W){Z$8d^|ax`I)rv~wZc2x-;a%A23M|Fu`EAZ{V6Uk#4Zsz?ft_m zvAz0GXe0;c-sR+U!rz1wsObc~oE*$l`-g{C(y<8d9LVM9n4n}xLC(_KXB$?I;R zr2zevD1GRp-`2zZUTz-*?C1>j^mT+*cJ>Xlho*{}UWoIdj(=N;4LhbB@JwviWY3qj|j^Rekgxp}$y zs1rMiS}H?3@b;YwLpZi~X|d&o2~k^**ugmQV#CH7b$%glZoLwxM*4FqwH)oRc8zg* zF@DGCXXlgy3I57cV$A%_ZChY^Aer?jpOrA|QX5poe!(oPd6X94-qH2{MZeEFF#~@^-&RuLWiPy1$tn< zbU1o=zI1q;@v0MyyaGKqUwG(+_!t`a@&mnea$}f&*I@LvE{_y$zeil@2=_w5JcnO+ za5v-dOL$(hlSFP4#9@~|QGD0spC)c|`KOCLF8>VCmDSz-&@sPb! zke{ExB(~opuC`4il0C&@waZ_KE#@q1AUsbzVw)KLW5fk6|FNRnhov3A@M; ze~!4?pF5^T1@!apLnXf3~FnQ5csypP?EfT(?`Hp1?7xQncd-BKjNfAVL+n4q z{wLW_r@WJ1zhVE&jIT2N&xA<-AB?mC3-M1Q1U;Gke)b30U(C3MaWmsy#s?XnVSJep zU8Itq%D9wq1>?D7UsEn~>~gq}=qC$tDIwPWO!?eTejFS00O2w&AL#uu`GFrW&f@&# zF|K3W!f48YP8g?n*D>D3_%NfgC&FK1|KAy>QvN{CVyt2uWc&={&5Yk;RQ5r<57|GT z>;Qi@<0{4=j4v=QK)+0U1&q5GuV8$N@dd{7kU`@A1LI#APma^{2F9BizsmUE zj8oCKQ2b`bPR8>YA7uPF_AlfU%76T*keOk25~c_%34s`cR6$mhnQyYZ>oh ze1nnZH^fi#EW%pG4#wLVzsu-DUrT&*7*AmAVZ4a(FymD8y~Ll+SkHJlx_S6tV3T#dY#Gm4aUb9(`V}Ne8$TdZ)W@(V;06FlGDfdG~AlR~Tnu%p(78#@87uFjf)$JjQz&-(Z}NzMjIbW&9~)9>zkVpUwCr9peN!xfw7vgk#P%S7vm+2-(q~6@mGv5Fuui@ z=-2X>FcveO#MsQZg|UrsknwiLFEQTB_%P!;j2|$5$e6T1r(48W%2>hJ%s9e$KI5f~ zpJjZI@et$VjL$Lt52JUXPA`Emo$+MGD#kj-GZ}X?UdnhC-y%+z zF_kgESjM=T@f60>8P8$d$#?GK%z z9)#k1l<_IXR~UB`=afVAb!Ds{ z2e;upE4&n@H;mpo(4Wg`wYK4e(H*&42l|Hla|?pyJ+wD$u)D2)+q#;e?V&(HkO+Bs zj+oJws@oC2a5HUc92_a!-q_xV&6oS~f&sP7aaer4GbJMI+*U*phSv-)tLqB2pW2-l zR3e-STFkuzbXrTWp`du}nvvqo=M;p3%Rz8yXZF8@?2?@n7CfcBrg6*g#-XNN*a?;> zPTBV6nTT*&IfVvCa42X;`I^4Kn$8FjdIq}&v1r=Uj}`oZ+--=qb%%=9x^;LMm>Sj(zq^zt_>|5%(wr|hx9@rAH zG;@_BTN#V@E^=CSdepKT)f%~Yj!t#E zN>l3NsncP~>(e;xDo$d?Q^zBU;VMru##86RWKdsYm*aRkiwFWDJy&Zdg~rocu{`Q- zCtE2v?xbpjifdb70ySC1oOE5#vBUbh304G$jLFpkC1BE3z>0lT z4#LzefYVDxMNz$8NfdhiXu2xP6;bFBo6S(ZsO1rY`EdP|sBVzWl2Sa#(R8f$dw*pTe=gAC@ClMs<_?#v( zVz8tsaF;4%92_Z<9xqbRblk#@`}&$kKf|Q^VY&+Oi%~B9$GC3~^S&d10Ov*GnbJUZof=alCumGFdE+;@a3UQ z%w_oYarqkhcTpeXO`(El_%00NJD7x53nS=6dC3+PuT+8$ zkCX(KZUmOnRb3=CPB-ZS>FNfbU%B)jBQHBl-j(2kib@`qpe%V-K3E<-$2dR<^JU~& zc4odpDAjD3fQHX1U*_8bzQhQ2q4y1(`MuU}>xU)BsQTRjz9TFfY*xDA`rW(;&(Mg0 zuW0(c0=_3B=ts|oo%-F2f;9HahD<68`i0x?Aov2DCV@#eT)$Vqw>JV`xc!DQg?Kaq z-`+6&N|xCAVF@&=?A_~M&JwA?>6wwG)jTr zI4_6Wso#C)+WoE{VWu90_qz{*?+zar_%ia4j3t|b&f2YIkee=3)ctUqI7IK*jdo-L z;WuI1;C6I(B5(=n75M5wH{$}eD;jI3;AgHOWQ^L`3j9bc{o?Uki=UJ44)773_$WJu zFI?U|4tX^9F?`|jo_ENj>Sg$r!|hD>74VVXlrE(ojqhCtAH|Qx7juOzkD9093(v<) z@TDP~(oGnHFB^O#C9br7aJS%%k!pe#Yh_-J|IjaPUzd6^*aV!MD`G7jBnk@R|CT?cfWy zOAGi8q5@EPP`!?pZu)11@FSe~3LSiN;r8NZt}^gF;AmK;y;0dX`QE=l2zrOcT!xPj zeEo)g;7;7~7!T0!oseHrnCG{z{KAr=6@_`rmlyf{ny&xiVM=jvvEN@_N|9;FCE}yEs~{ic6SYBX6is5)1O00b;`iaVufBK2ff+aK-sag`vn_7l zj2mk9$bFZKDaWo#o4S9>Ua@rRVR>Lxe8S$O19IDx1M;k-17d#C-YNJyW$%mwVkCaA z$XtI|_+zTY-uMHa&wWb79hj0P4@@~$WOg2&abwEJHR9@dImaH1i#z=5x!bno%wMtX z!w>%XVIug&g4lftxA^vn++z;UxMAD2DI=GQU7IOX+_*apn+NTkal@BDjW7C%_}N?? zFZL$ijR(_CE%)t<-Mb^><)_7su?KuNBq{Dzad1X_Me+^tXC*_wWazUhBYy9_PkZ3= z?41hV)V()8EpM1{peAGYwka`F5>pR*ZWPC+9Q#C^_i)p;inGN0l=(IB@yfk_+eK%^ z=hbAy7lg6*xR}{zW zo+}pYDxY25Td{m5`F52rhWqllZ$H?-CLIN(Yfg-u^d0rG{M`1B?W38aKJAVg8C^IY zckDGMY?p{9nT7ewi`v`Uc&UoEnZspds1eF5R)K^nJ?cwjwE#h8!&*V8#eAI6f??dX z_N(i^Pc>ZcL9d+W@x(&j|FgZ@_E;vQ>tAU5pINr2-uOdYUbS+&RLDtoqoV14lF>sEl=Hf zvG0}NCC!Ebzp1>H*sxW3FC(wLKatw5Xb7||y!EkSs!{~rEn86*fzqN`DuxGeDv6?= z);~0mubmJuG=TF}D9JA(k6UPSy`*?VdjLM#Vk_wgIojE=h4)2$ig??)w^xwN)4=`` z5zMg-daGrcT(k_e_A8zmc(!N{9!iLmXT`ND1~drx zbzco#-DAk)wy#j_lO)Hg9V=ErtdAfHokm^hH zPKiwgdSf$UQ@ydV$Nqopy$O7rRnOg;3f!O+!gSQZm`ow9rX1Nrq-4 zGieJ1hb)seG#gpk6j>@rK|~f=WP3qS5ah)L5jSM13dklX2;v5>8=$y?^aYjQ_uS=K zCeKWhQ2qG+KmYkOJr$JgEivT8=Nb zdtT~M?sLEu|1DdoSf`6%9`~6>BAM4r`bX3JS@`4TJc^0x&{R||X zC{XQI)R;gS0Z)UI<`TF$v#C)ocEu+6h#xf`)Yt&mbQ&N9p>F{3)BbLD#b?ev4JaZI z4&jaeEEM-!Degblf#MD;#U1D3jGu@w7~Wx!Q!rAAV+3INksQuCv^Xf)cN$Qn4}Aj| zzj^qA4K1Xnod%R5rBCCRf-fYBg|zE5pcHABrsG(_s}Dqi(Woz{A=cyb`F$nD{>mJL zjYervjXeCt>;2X1OUorT9I3AZma1ReGD;40AeWHU7&cWm3$I{(qd`XBCKX0j28Fn2 zCvs9d2{Kv*?13@}+9MtHp@xR2qS0RCc%f;eA9u@7_{s#WLJW=!Z?|Jm6)FTB6*jc> zl^0hOmz9)=z!BUK6pTdc+B>6lZ8+Y%Es6vAGKR{l0bb#@h6tU_KZr-%Ib|QtDMN@l zr%Yk-X`WQJA#7)rZ9c|nWhor-02ieR+DG%tu(?t^&{5YEtq4aou@y}$ime6^#F3`X zmReuwG<=|<%z-*UVMA1^QIx!I$Vw+?@uAR+4QV^6hQs36&XG2vp$k?fqS3p zLcVng`_6YCc~r`!IWC%$S%E(&&*w++emd=YiSF<*o*_07)HR1{b=ekWs@Px6_>w4@ z8yO}_MHH|1@TCe9t&4^`8yavTKk6GCWPEuv+8#iHmE=to?#cH}`PQuQ?P2_Ig_c+g zjc-pr<5>o?ys3Q12!`tdRE6N)W5EoefE5~8Al~k8iS5%f%mrpW&p75dA2vJ6&U@ESxqOuHaL}_Jlb$PkJ z!e0(y7jp1M!9rHCn(rbL9cRUlnm*3Pyx1g|p-n$-hLF(~roGg}s<dLE649&)MEr3X2&w&}P5Ng0>s~YKxCk5?o{PH*`2yLfjzqZZOipn*WeaHyYk5 zJ>vZT%kXzjm75Iz879gtMgWx+Et&aN!%rE;ngE|RJRMT!Glr*OnBd`k`kd))XmhY+x`!fwzLTgd@F}g$_}2|QbX0h}kiZ`jGDHA)5O=8w z9BPaPB5f_9I;WcTCpLeCwdRyp;CV7SGeBDmTm(ZV0&e zp$MOlMkKfE9!zbEh%nce@u}NiIde*5MYq@$g`SdqHX!asA?ktGb=3|G(^T5PaPQz` zUkn2wz4co3wB!r}op)C=Z<#Y;Vz8L&OxJo6ZrtnTNz(3oJf8+?_|8j z*FLGk-pBZH(kTN!%J}ipEkom;*iF(cgTKajKybqi-FUfI%Wt&c3@w^0NJE#91!-t> zf)rul3B6jZNJG0;E7s7l&5AWNZI`m>iD98AOwnngBun77m^eetttQUUa+?xj@Plzq zvEU>_AiFF`L&Z}qNJGO93NaY_s+5XJB832}enEgo!c^LwzFMT6LLfDEt`<3v#vd#3 zNBbCPpD2w3R-i-M5)OrF42qFx6Z*Bea!0WoZMMkKQ#o+q7PJ9amqJdWLfjl`4FWMR zO#6+IVW`_2h@ehZUi2#6K(B@3xM;Ms4V$VlZlq2xUhy3qAC2|q;g!JH1g2t9%>>Y; z4+rZ>jy`XOkwD($c&v|l{J1%6YcQ}m-g|efdnb8glA^OU&>U)P4c3dHK`BNesACKA zFqjza?%j!5YRc4PZeKw@{3z53h?)#T#Bq|l2gT&JB84&NLNuYEe@!uXr0=vv#_;W0ci%J{o*Zfyv`xx0UWVN#r&WXawAFyqB=hJ#z+9FOf{ z{7N`O;o7`>U*CxDLxkJSYCb&umj^gdBsx=;@gShY~Su3IIQT) zEAB*$ZvxZ$gEQ@$71KM3Y0E)1?Hihnre6V5?7~M3aX69jpOLezgPbE{jQ@I@+4CrH2+S%r_^5lb=N9 z-(EK|Jb`1el7zRj4PSNfGcn}HixOsd`PfshB6SW}^A{K2M->lA4z-6dx12<*Adq^r zvzoiz{1ZB8;9x-off4joH@`^-ojO?1ZA4%M{Zb15oDSL^MmHsizU^Zpy|^M2i!Qx8 z+bJjF%(Z5;;hhwIA5D{x%>*N9uZfY-wtfmILNRH!WQ=Ma^6>pyqn3kc)Y3gL?5xhd zRQ|M9M{u#IV}w%b81DE;)jXQYU(&j?cZ6C3;mrrJ&_GM~_)gO*A5P=H(P|hBq$;Ch zl2)6<9FaAg98Py{*>4ECX#yovX?2UdY<{9m^3Ovk%jYrR+S_zDVA%F!uMJcAI?#CV=6z0j!JQ~DcTrp4R(a;kP~E2qW|U5e=hcx4a%qA{#>@b^)NVR|URcEbjrzoIkWcNS?iO)@ct zP|RQI#Rt{qqL)GI4x)Ec+{xT$h#VyMUSkz9k@;wX?i4ea69lqgfTC?3aPB-h0$l0pO`MLZ0&5ux>*$g%o(JJ_0;z{uB8~r zq*P`74iP{6$5LiEu2n1!S-O#I`lZCZ(9llHcQg{gkh74M8z=*^Li`oskM{c0c^FC? zSd`Asij=`*e8QALis*>~>qLF=K@zM?`HRIqto1pjE3meq272$f8a$ep(@hsK=ZFyk z20u-KEm#Y}NFXKizkR*5P#`*y5@&5SwvMdK4R=BUwO8`^{0>VoYUH5i%Crj8M! zNr#v=@Cw;|kUJZojUJY@nX$Jqc8cc?)KSe5HDog89}4o<((s3I>@;Z#DPOXC_oVPc5Mx4-eG&cpN0k&IzH>hg5}A2JFS#&O#|9-^ChJaq_LEHzTb@jbBJj)5O~+H#38FE6PH*RJ(xf2>kYGcnni z+J9l?-l5U5JcuduQ@PwAk0u;1(s>E=vH-h!eA{gxQ(G(*BxbmiZ@ZS*& zc?}YhWp=Sh6b!Mr60yKh^4TOU$m7ygG61(5zzy#sjQ=}q5tpJyjzy``8DRz~Y6OG! zw<+!aZOPed#tE3V%TWiZVwZ;k+C5vVwe}ywLsE}R)>h^so8+-_rP`%d~v;6tnc5EVd*9? z`l-TeI+G{6NhfM9!-*)|=ApHTo`H#(8%71N*~Mf6o{xK|4n=pQx!#}GkLfwp#j&)? zzJ6ML8nialG<60$w7zc4c6z=ggDF?hygP%;bAg|d4o+iCD|{XW%<0&~4#akVqo zA53QnbKO4A?4_d5kGVATacl8EdcXE@-OMHd5QJ8GxFir2Icm z(}#veAWzEtEjPc-q^5>USARAkGBSHC6IF;I?}|q8rsl197VMie@n{IOu(1ixg+Zgy z#9Ura;rE(cP#bF9oh^BbhkwmRZWGo`lfhyZO{qGibp5FZI}Z$9Wi^{j5MntMlhM2; zm47!r=s|?4keGXXN{7@HlFh<)by>~Zsr=cv07)dVnw!)3UtC9uH=03r1+w3?+=SfB zY934DZ@X3qI*Rl~PWcq&fYrR4#=qds?Hw82L;BiyI;5lE{e^V?RreYl#LnI!2MIAR zr1LL%*7SGxj9cmZtvQY8#IFtz(~9`f$@mulr zE*fwMI+|8&2(*NnPr_`{H{$~^_x&z+iu+r5aFjphst-0t0?`vo{TSd)p+!gI_dSjD zmt%Z_oqLaC^F}>wgvQJ~FtYDZ+Q9geuJ(|xbe+GB;}zKvp6JS8rX#Vo*!@xCIORq*)*;@RGb{k$?9!qiq2*H&O?{%e<5;w_^D zz@lL|)KZT{VA_Z7)9b-{*_QE7xn%-%wmPmw59`(FTNIr!BV(Ij=^otOy=Pp_!_ZLt zyN2LAJVG}n)}`&L6co@1Q~DynBSrvPUkgWcFpN#D5x_#W;D->8y0uSRLqj-dgeaI6 z#FX-wl2TEo`4{BDCbav&7pKtoLE65#sWy^_J@)=W{8vK%l_DzWOj9UYSS@OWf;%uEIe!&}nf*~;d&txzX={z* zZS7zO>d7BFcx?+s;PbP}5VlITwKkuGx!we!Urt6N*r4gWQM8el<9{^%_A!#&hhgl$ zNU$wqW+N#&l3|Xf%zHPf&!g{lrLmQw!IwUrh(?@T=6aY`$iniFjj#^MrjC@9X~VO2 zQkFJjO^!3~%_Z1>x}JHz%=lIA#S$ZTtliJ}b#8CLA6*&Q!;?di?oq6>(@|H~8kVh&=6XlC zYfVb_s5+M`oauP8`^QWuD=&qG%EP^}=ovVSx`Fd=qh@`U`)G7Aaqa))J;T;40Dydy-GNj@?1DIv*i}rSp_eJ~q{ph2N zPehRinD=8Y{?1{Zf`?LV!e~#BRhW}mtisj{`lQ0hS_fSGf_a{T>(fLE=$OR|bF`PR zm18u7&0=nT894tnEuC!Ef!9FIEC@s$p7hlSSN3Q<-K6Oia-@Aw5sVE?3A2bSD0n{T z=9kX*6g-+f3!aTB$UjKj0-3ne_~I~?7tgd`2fjBSHVeKYwVibp$+$Cxe;PdhIvbuM zQ4{c_)Os+5-wmFx&+}#na2EYlks|`|pf6W;09lp3Qrr*B!w0Sn&89jB!}M~GYfWnQ z=27XNk-d39el5)2+$X>A>L%4uqXT`W%|$$L)Op`RPr=XU=L(qz44L$mB4pB6y8E8_ zD3lhNcS0s4K_>ZU37Pb@Qplt)pOZ|A=Y<}A6=eP(L(0rTJ;Jgnp7bSU(pS3s_6(pb zGFPQ)ndC2J(wCG;UrsVb-g?)=Z-vae7ogZ}p}maAp1K@N8KS4c*jOs2$bkwqwfnX_OnnlG7w5;I4;^}95FDR{rMI5WGyf1)`y ztZN;XJpe?*VE1;GDQintHYVRYV!L8v<1s7Vojn@aJBg!y^S+dh zyqG-!5^79aM*0T&u`5{1$xvJyx_c+EV^+1p3t5i%5~Z#eibTh{`v#^;%nTz+Ut>Cd z9@<~KRW;%<`g+ESk?BL{x4%;{RS$EU6-* za$r7x2~qjPis`w@tWlOPpf+vPW@{gC>8jp9m9>3hhpsm=*kUy8IbQFA#iIVm@vc~4 z=4t9h${ssatKZJxe}?!gj!Y*0>RF3F0P$Bi3Zb5>rK{MtPwI{&5^t*&A7)I^DqHjBid8f#j7 z2x-KpJ(J>-9cqGWnmt`|CMb*{zxl%Wmy4E#u0T>vh<Uwh(#HPr)PTAZ_xMGWtN2P3+33+$5EG#H!5W zaFEq6T9o5WpYNcM=v|(&n12Ndy^uRIg~TAoq7Ze;>BOWW@ZV| zw>#U*-#r4o-nBE7K}JS0C>bIVlFFds`HGkCTj41<|L7UYPz}G5L9X;u}j*U18 zdUzRs0fK%}m^3P4BFHSU`|KL}Cx z`ICxL_A*3?5@CrIxs!8~X z?A{7rVzD!iqpV&tv&YaQ7*(@J6nd$l8<{0b=tf^FW#c$6tuoJP+a9?an_k__iuyi>r zt5ULf;TDDZ*kJb_O^$qnLL*V$yp_-qvuSjWRCMR4;u;_A#w1=`T0U?j-?zq7aDVkI zb#hMMgX@$~8U7+g8zZTp?TYhvWGDDfzStBdP}(S+NE|^aI0CYq_frS1%JB?J%nlbAP2g z3OB_||UFyE%F4~BPnJ2Z@!D{|;JpZFj2a2K6;Z>=_ zelB&`&kwG{t8>xe+ne~OJ!`SSDjdLpa>PR>hdfknGaFL93(ZwaH!2b;{$0bd?JY2r zbf`G8nkxd>jE=)+CkE>4t8{ckq^8((uF8gE!h%??Cp(J&MWe-Pei7jRBe>xV*Zb#o zYb}3M>qf5!NL$ZBIac$VT7E$)q8DyL{N~8x&N_ZI@i-BYnj?!h>iBI^jk)vqd_Dh) zP$LlDHYZ#Bsh)pV*3oyY2=rrVRIst4n&yBQLgx(3J1BYMNS}4S3S|lKPdtst!EtQV@>>4 zsbF(}L{Uv7%b!^erJJsMkFV8O&67?1i$?fFc1gzI<01ZlVvyLd$rwBx;!kP~nkfnc zj!__NToeceyIp<)|B1G7h5T+aza*Wuxwf=42cVi$R+3pN&NxH}@?Iqa!+*5OJ z3%}pO#%SX26>LN!Xkmkv-p=M#++E^5-Lv7X7Jk>!N0Bx-SUk2f78UWKXoT=)EP)adMQOnH_}6?r&R-kSKIh!r!lbTrWlZZl7UcBsoG6X-N!8TVi;C z84M5L+<{=IO*vh6?SnTQOp9aEh%A0(2mhT^f-D{vGZG0~lSIdSkSJz1hWW(>Ml#05 zj+ny!#MCi=9KzVuTp!`D6^H_B-bvvVX_*e=u)dx@tDM)G% zkSUFqwsC@|>RD(b;sv#1L9y19BNFey4t^Ddjk@#^j z)h=zd^-iKH+&YHK2Xy()TS@5J$^L$9n2~KmGkCs~zMH7p`ulN9m%{f5 zBJBQ!|CYjWyhx+klCfTa6x|8)EgEBpvs-Zy8Hg+s@+AwW5a#26tE4qpTZxut1hid z({eD+em*CwE?+QLt8RFui@#x4NZ2yDJ_oU-Inboo|I2Lo=TrG@$J(-ivLy;sF1AI_ z$&_!co2w}oWBwt>`{#8Vz8vMx+VzqqO{UgCEIOiw?gIYHEL!v4Y5ekX(JaL8%rhH? z^NVG}unjiO;wM?_4NJ$a3)e!3#-P7gHVXap1``^GetK^S(AYTKHKisLMKiI->af(? zT~pYbhqJN>xyShGk*s>qNdmqH%{T!x;OJN`_NJ%hc+V}axvz)+pjT5+qyKGjqSi&v%7|Vk+LI}>rrl$HQd>x#qRXZmA?y+$%LYi@~L?^Mz`+1zo`_pP} zi1F7eL|L3>W!=2pP?FHd)S|_8=@V#0@jz2Y@h}@ciU(YYH6DrA_yg%n9_r`Ij6MY{7Y+D6S}K>tN@aKFz__M%=?B@#mO$c{zFr528fsn%LQ<2X6Dh zjX>-y6BEYC%+BUO2m6qTiv)3Mv>^~`#*J9)OtjoIv|t2PUtN28Z zh}=W?A5=-t|GdA)#;D_<4)>5c;?*pA&&__e=l}MLe2CYKU*r1?dLmnv(pV8M%Hc;w zq4#_FYIf`*9Q9a@Z#N#oT^3pnrnzkX{Nv`k)A3%le79za$9%aa)sA8;%|vA4-DjM5WLT9I_eP6%ZXy16-kKs8lfpNtO&*yXeSXb)DFfL=}(h)rimir#cLVG$eV(w zxzp$4m0=vd;LGS^X&zqSSqaZ&;$s0GrJWBi`6kcd^O^j}A{^e)K>)Tw`};E)J5o~6 z=SsrU$Ex{^K=uM~4lS=bjIj^MPsV&2SC+xpYVDXmf5H3=u+CW|)Lc_3K&}UXtbY`J z;8IKiE^s?qd>~qRnZhG~2?QfrNWlX7q>p1H4%hE3K_V9|fhxFyZwb^tmVC-GBz>`T zPzb-q;~4uAPWqKDVMK@Lo#_Lmc^yKoUsSWGdXYQ*_>9nUX`2c=S|Te=WTT?1GEp+P z4^pe`NJ6bQQH{$9QDY)xKn!v1D8@FLh(_4zIMZpWx(Oyb-tIxl5_*$~mg*8RU?MF{ z@P1pZ-9s<|y3Rx^CP3D&g3xm2G}`V{#|1YPozu~RiA$^4*p z6fPoXR5?@0ahh~UpKj?OJUUGNOewWjd_qtkeUO+Kec+x3j{w^VP(k0}QM%$4QT2&X zr^`>qc4}|pKd2p2@{pz{zhPoX<#9xOfXAqg0U7%Y={P=P0~}-0v2r=-HLe|uO_Ylg zJXs?wx@#lLg2KBObE-JeOm0vgFtqs1^~fpOL5$mX`c5h9D=qIUIh7tO6NsWBOyo=q zbPxK9iiSs`xK04efP*8r2ovj)lUTaL1w6PrUwCe(oeZ=)Zm4^7l-!s&M19kB2 z8|a2}a�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%0DXn9%_kTfeKS6axu-=rQ^<*w!MQr15 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¥hmMN?4!62>81bziywMHY^J>#Z1hC1k&tn2_4u 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

    p*WQ&riBw?tgLjQs?LO%v;-P$#)8Z+=+ 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 =>HTpq?P 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�$aBDvquPavZIEGREY60yG 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 z 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[hu_C7=sW)WOF5nUnHUPPTZ@_|UK3EHXc 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 z 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

    sR{%Q0kMuEgWq5b$R}MOppQ+eQ zMpy5kn>_{HRtFvBFT>9pk3P^D`=JXkDcxSs?L~r?!ER9ds+F zpu5UJmp297oenxvuaP~y_B#MNV`tNkAh$OjkAUvLQ99jBe<&H<{%c_ugs1eSG%$9d z5fPOu^L!R`-*XgHQwLDp;-tIqgF?_gA@dkIf}l$n{PK_DlOp2)G<2sF6=HwB{e+6k zODc*B%E}9ZLHx&~|6-M>w6ruBEG{Z7FIM=oXI&U+sKqCh7FUUw*)Ht=`)}nHC{`d> zw2Ef2;j4+d1Na^M;{4i_{R{Tj_HF9ByvqO7hW%&k-(Tf>(ic2Xeemlw)xjqhM=!5B z;m2b2aX(#iLg@+5r=>ob=&PtLJ^rmX{`pql*=vsP$(Z+KMQx%_yFUxR^iq1i^X#6i z^b)c9)u%-8;MXf^3lxR?c28F6@nZE~pZd#h-+Jq<3-z9PQY=MIdvH9`-8rC+*2wQZ zVjteT?JMyp2hoE&bb0cq!kTQd6vk{*VJIFi4Pj+d&o%5d%$b|TRh_868Z2vaOY1sWKnWT$2 z>-tCQ$GYgds5K+_$ZvP&aGWo?F3GQHYZ;91?$F;u!O_t&JakUHdvt`zP3$!MJtD>N z3H%?94vM5r$iT zq76q6WxNjbv9MFWq7@l9D@5&E?oZUe1HN^VO;aYX4k zsD(=QV`e4}$`B^M~IW7vgzDcwE(DzCA6Bk;_$&R1W65J-Ads4?+>Z)?fd9S= z7y64qexgEVq@Dnn<{w3P<$ZqY$%HrtlxeBk19Ay@!f$QrLNpQ7Mo_e<-SCSG#P#$- z`N1bHSOTCPYOZSWlVX!b=<_z#D%57|a%bPo#y1-;RmzvfHtNa2UqwDbZH1zz!2J(>7R9Yx3|9~wtFR3TrgHl^51zPt1*{#p-3M5_E_p=K%685saN zW?OpjN)eZ03;tRUad)U9k?m{3?U7h4m|Yw13I;>L!h%p)HfUloTEQTXP{Gf8x@8mYj>pHYTVss{97Fc1g;!g1Z99F9t)o7vhv%!+Aii3K5E9Nz@oIm!O3W;T z>&sP_kM-@U7LIrz5Nm?E(0;RQ&iaL0tLtN>Z81aaL=%ewrvVgkd;O-ys$kIse7LkY z33Zsl6cxIS($d;o8*PYqh1N#G?KtZuRv&Jt-O}7z;|^qewS2dcIbaPGOX?BX+8$|A z-wL-z>Y{D9lN$-Ssi~b64!2ad#iDdoH^gpa7NdP*JG-3kmg#T`xb?1Y`)-S<(!kWf z;pEhCLqjaw))r}Px6#qYC`cP3nEs7mJyrn)7RUK3g;8+87lk+@K;CF(y_WYui*?i!Z5T!GQrG7sp~PVVJfsSKV+w9$c{^ zxJSri7_G4m8eC~F@QS^qQbILpvHhgRv}dGy9>t4di4Y4cfki&_>hkkJ0}TK_JVYemJ{9@3>BhY zJdee|O;Uh)7fS)AFjQPtTwYXK4D|Ud0%%)AMPXr4QCVRDhSnv;Wo0Gh1!WL%AsG^J zAr2)aLhhA>pvVAIT2fL3+j=kQ6E1lK$KEgcS(5H~8lYprx} z=0Bv%|yA?3cy*>k(qC^{Mazg1o)`snIv^SW_enMnL2Sk zu5HP7@n-frZC}>JRTl2Dy_2QWCv0y^n?ohj=P3f{<*3R6uiDx|e#OE=N5lp3onS6AZXs{EOTIwUcS`8vA&3c$2JJ9;>EC3qK+MP6%Ws8}kps zAk}QlKM8{@qcC=LPQmy3C@L01)#d^H9)-5q8vI2HZ!|OQB79%Kt7(7rbd?^v)}V)i9*cXN={ZgY{nF~{j;j7a znxN?)>>e2FiFe>gDAl9M?^8XVR5jM4?}mB)BV#&DEEd)HI06?Q500)4QZJaC^sPh? zN7s}F#}e476b}{$bGzs}0yKw(tAg!ALjxf8&gCFF>PeBQJaN(8*Ex(M2LmI0*wTb4 z3^j9s*)qEmk|NWsu?|z)^ByLcjiE75O1kZ~8MVNxJccu`FB7snNG@auI6ow0g>oVv zzZ(^3GH}E^O4}oDvKW+8WUY zVA>x!i3)K;v?&5a{~&F{M24YmbGRLKGJDa?R)4pH;?!8IsTrG3F~XxxFK$vD7)ivt zb8%B!d~|Gh5Y?* z>zX1pYG_b|kqGM8yj%<>5}n;UFlk7cn#>){TLnJ~bvmM^!w|7Ya_4}WYh+RwgATG% z3Tl2rV&tZAh<@v)>UMBoQP_8nyBmaj4HaEea|=8MhY~`*3FnsDD4e@{`-QyNPfoJr z?p~PjGC12Jo8cUZ?-KGFIHPSU=L&HM;7S5`TE$z9xItRw$ly><3uX9IY2x-hXAums%A=@^1b`PAV+Zk$M{DOC* zx!V~%MUKB}@rjQbL(7t6=}F2*?6!s13cLZ`!H!syazvH~D*q|vAd3I?_$a1An%Y~N z8?Y>YCMpU0+<)biXOj81R}T%2;+sNEB3s0|FZtwo81my(e>=RsaHpF|lLxH)vrq1$ ziiadeTiRNu6srid9xbBsZomA12^v0BP(@$`ebFy(HbKV^6?7{RSV2FRB0ph*wzQ#} zqI{B@2}?2EIKB~AAa?I)p`3^>RSlzce@l_~(liO#Ofk~-8XZbB_fkL=N@%l9#i;T? zKt5nJYCMESjh+32$<^7HD!*&gQCuAASfN-Q%k7O+<-@7+S))r!YqT-kw($@a>Tm2E z*Ib;&?!sl*f?~?zXYIxv>Sam95k~`j`1q{Mr5#Ow?Vj==S0-*iEY*nNAPX zR5tiBgul)u_Ex_X6NBzr1)f6pbr0Z;`?^!sM-I;aSyhs@q*~d^#`_8tA1P6HW70i> zj!HqSK2{fLinK6~4f=SI~_{oJJU+)Ky{Uuq*=t*$9`*+%sA*?^N-_ACWT6aV@hrV(CV*>G3Yfx6sNPjYKfy zTunm_H5y+9n1>&Z2@$LDqqKoV=`%!?GMJ2?G-Z$?W}?73QD1O~1S@8LwJe8Kxuod| ztZS%&-aC$Mj^$=|(gC{JYJ`BnPkneZR&B6SP}97rsv$z_Ic0`@3s$VA#~l5lkx?3R zRGP50Es?F&krs>^tjy<9#|lwzLQEKVMcqEgowd-$49lAB*t-}fi)SC|sD^ePGFkHv zd8<~^@JC2|Tv#7v-%#-6V6K-0G}x@r&^#%J;TUG#a8HI=Sox_m#YV_qS??&PFTv5* zITEAUmC^n|Vu;DNzsmYeb&=R+EDoZE?j0EF9L0r(xJM(}6m3Tj0rKClNE$$*=0SRf z#<~XLUc!TzPt)NhWA(ohmvjWt5Lk0v1--Gd+G=&c1=-{8Qbh)rel#^xhWLl&<}}5s z?!`W%GQ=d;JQI^ZqOV{+ietnP~I<~8Vry*^TRbqCSULssO0Szp4 ze9Did#ch$+W;8=^exICZqnesg)xko=!2N)520`mHPZNTz6A9)P0riZcA#>1b(QAsJ zp}DTAAeg(xwXF5J<)w@lEEq3W_9`IhZ}|I1a1uH$1Dk$4O$b*k4N}MPEwJ5=fggI> zdWkVNcS;kkTp2X}dy<%#Y)tLHvU2y%L~$;}tPbYxS+y#-5)r~RMmh^n>J*F@TF$jr zu$~zNgI(U2VnqO_gLDr3J7S^FkU_G{EEbamLoBXAEbxWxOp+Glo^;g=!0kqG!@jAJ ze}^qRDQe|dlq!=ErjepnFlc`}YyWRc&TcCgE=Q)M`d})}J=9S6Gpz6tE=Rf)>6B#F zy^i8!YAqLm?GL@a0=))1RRb_}p*HoRBKKq}%>dlKN!*5pcTy3+Cj z4Nx75?npyTD7P2WbKJ#ow93I=T74RDHqx~4*oCb?VAm^=_%Sy)&iDiYi^6`vd}e!gFBISZs1GFQ>?RY%Zt`jqb@Ud22v^*+uRW)@kj6W>v>o*XIJ* zd0^?PtJ$dpA(rED9nI@g<+r^-4-8FSy$Cn4j=rBJ-0z8gM8&npUh0H%1%I#B9>nya9y&KA%6u|8-pY zC?E0FL>k(|u``N77~qYgMMvZJ9fJ&&V0?m|dyiuCMh$IQ#>_l0y6;d_E9B$8mT0gj zKU5qlsVFSPF2C}MvI^vvANXkVlUAlZjQNfj?V1Ue;1C}9w8IZ#V{P@(+IEZ*aq&(t zMB<-u5`;<&L8#Oa{LshCO*EtKWl;eRKk~6qEUeOe8^x|*Tpg&1S%4pVeN{Be;q!CE zvt<)@-s*4&Q&n0}Rf?hcuYGEXx0n(Di-v8{#u_XF)2?#bFRs>u&9beKAMxu1+SHVE zEqc(bM&HVG){Km6f~9j{cjulFo`<2K__r;=xws%~SglLDRmsbv5vKMWlyuvK2psc-U`znrmy@B36jJ2|;WrkFb=|V#7Z#7dD~Y2SJZQ-vepO#`>!E zT&RXDi1yMgEoc59(qkp{1LIwm(itg;cgr+TR4t% z+!2o_09tc9SF7FJox%0N+;dUjM``4Q=iJgFdhb-ci=Yx_1PyXLn1{{Xz}WLYmaR6dI*Ab&i8 zGgnEDeS9JHdCb|EG`8X)6W(||bpt-GCzrh*W)yO;JYplPBeJQ({vOgAp0$v&v>6MZ z8D`#6i2X-_mUGK649j>6F_U}!nJwp{nTC5V%p))HFKki8T(6E}LlWFn)J4Y0-wJDBjx(t;m^63Z8p zvBZ_>nO92rAb4J%G6m1YK9`#0B%TM8@hrk8n7@?ryWsiqR6Ngd^CTznTp}k%y|)P8 zftLB?kHPZ?febPy?6;l1CZ(iv8Z=q#vl2riqiucty`0p(6?3%WUHzD4?um7Gj`YNO zdPBEbfbYlWhH9p(7{Y4N81M#!Epb$odp%o z`~C8Y*@3)=(`Uf5E(Q4qiJPYrcLHC0OqGc%v_AyCw;VMCzACko>#CA*M~eI?c>ZN3 zJXNAj!jn?#{uFsPc)mOy`UmH`72&?aoeJgxfVPsXprTD)w3okf(F$)El%6dt_ zw<0xbV?z7S$=cYj-{xg)?9p!-T5O`f$F{kO2R;JcH!qO)v)MUH=0Qs)y`?Cb^p@`b z{A?6Ths?Vm6Otg4{Ff-1^tMdNq_Ndehbc4p?>1*-nY z&Rjaz&eL{}ovPJu&5?hC_^XebO8j**7Jm@puTCnIa$?n7dC`JE-o9m137s`>rg2^( zvollYC5fpr^q1z!YasMn$1maR--?5*?e^PL^w>_WYx)#VO>cPwtZKZ~uE%vZ0F6Dj z0%65nH3f4lWR;D~z^DpYUSvLuXf8s6<;=~_{FYXJn5uerGOeB`KMv*hp78Hfo@&$y z$`jI3{=M_H@*jfod*>_5dz7c-ercXO0Og+yCRbjU{Hi^LCjX{nO-PK?$r2-N28ls6 z)`a*F(uz+@2E`{k^X558;-YfV9rNY0h|4FJFUe{{_f2HZL;4AmqiSp0O(ejRvqCFj z)wpGm?u#fB(T8VtA}ij*8S+)|{z~?etR}-oWHoi!mholj^*Zd_G`&qDMN2>itR5QS zZiJGF2)C+?RhNz4g*}GvuY2fxL&%L!OQ@)K^ChW%Yq5o4A$X+@zIx z$f?YuaFEsa&(F?GpPfV@)w?`vf&3yA`ccmG6jFm6heFgTb1Os`%Q{;!9o9Ju4pQi` zdD)pa9FiX6eeJ|KS&gRB5Z<{Ij9bm@33m%IfTrP=(nse9nn%G_=6;Mj z<93!%eY*=X<(tQ%*Sm6>GRVkC29}``VM-ZPJYUF^`<4dsEG%(R*cP*4R9~a2`VeSk>O=-5|qR4WK7RkFH z>YJ-(AZkkMB^9L%c;O;>4@7-F&o$$tTPl0LuJCA;{3ge#^iMY9gL0;)I_$X_HN%7@ z1xya2>4~W#_wpin$Fe})wI{n~e!N0CMn&>TSY5&w0r^*{(6KY zj9@$+A4(?Zn@7tZLD0`vPZ@Z3zb7UoUIo&*E(w|I}sv|#qjJzi+koQ=@l%m)?mMAV8mMC&h zDT?eBSR(I-sCz?Gieh_NqEv}+#ERTgiBbkkERl~w)D4A7RPyQhWC@eCb4+&)%v94( zTHMAQA5GFL&Occq?>!-qcS+GAZ)0UwB+0U=;!Mpd8cln~T6cVT#5Uj*rV^**SovEB z`}0)7IB86x>y)8rP^V(L!YFxeJ63);7|8oo@si17Hnq*N;)C(w?R&HZGqT1pgG!Tl z+;OAmQ3uRp(D_T{cOiCfX>f9}(~qOBUNf?W(IZIk>=A`tWa&m`S)z2Kw`IEVov53t z!uKte7cCFu-BdP(Nv5CJTDN&F-6(X1r5ojsMM^h%TRf?5)Pc%APJS7>-C3R_BO=3& z#-oEh@p01=M$f>}<#4P@>EeY`6l&rFoqG&9@(l`&MrGzMgN~R@qwh#ncaAEqkwhmZ z@jPkyjpO9L6@k3_DrTrt^7K8lPLpb*Qm=KHyaw7lx^{-zBu~+|qYb6k^ULH%pv{jf zXQ)lGRm7}mq}SxO!JO^j@$&8!fyz&=lYj89>>lV(#MJ8Nkm|Wm)scffj%)iVRvtv< zPuAh{7B@YjM(Z0B=&?E?Dlc0v-;;8p=1-d{z`qRS{{!-a!o?m3e2B`gu9yFn!t9yc zV(+0>>|b6luTNP?J33U?3!KxXR)qMwwu+|XK-9`tPL=nitfG}-RXym)>hGyR-#-Yo z7W;Z|8ZN;^t6hcI`z!TF?j1v87`z@79i#D`39M!4i4dI8qe>iA>K*-zqm6i&dE&JW zQTgZ7AlO5Gx z)o6*zpNHiy6gPas_4c{lRwZ9Ey3rBs+SW5rPE`J;N?wwR=(W`&euv59u4;K5@i+sK zI!qRSsFt^DH4dN0r)%UFl^Wr;t%qfcS8L?A*%pV%;d2rBjJ5=h9y^@m_)A3on(c6y z96nJiUsoI&H?`GFR|!%1Lap4JM){y|Q+Ni!uCJ4qr(tslp+31$UX)HbYHRz%T4AD)-))qar_(mq#>R#)R7;kXbe8fMhX`Su zI~wHgPRyeQkhUSvc!qlDIhiY0wxJDJB2ly3LgALWp~F$}*_o}Wm49fE?_asn1gAch zZaj9X;Hm|61gEy6v%8xbWz$}Q&Cddr_cY4;9Biy6{vO3fHG&Q{XzAT-UKC(+PGH^Z zjq;Nxok-f?!{Xr`dVHp$5ykbI&_3D)aE>n#?Hs^d8NYYMu@6S9d%Q_L?C#P`J53|)q%DVNSav?KgKS}wo@xztRH z%KNv-Ti2XS^%;Gf!?p86DhI2f336~Vh8+%zK7=}b-IH78PuD1QyZeW`$50h+8OGrQ zrhMlvBXreRZ!b2?=(eE&JfBV9O;pX;nHtAK6@pmA!ZTFKXH12LuA!%nq3D0qCZN0$Pz?vAtMH{GghtJ1U_%=3Uus{5g= zx_Iv4T6NtE9r6!ug_JF)*5?qmv%g%Psxjy-(2YVbuC1rWp*N)6*2dwEah_0A&BPw3!%=T{jAL&ezLf=s zJ=R;7X4QpG67XGU#tEPSN5^tOW_nt7=7j~7_jbwem#Buu8z;M|DGgDa4&tsr`s<1l zwJv5>M)f+;o{ZZy?H>D;+CuVFT{hDQVV3|QhojsKcAFQ|9xnEE4C*b_sglo2siLZEd*e z!$RR}x=oGvo+pMQike%+g|<&aq^S<)Flqd|ZM;4lJ&LPK+NPifQ*R`@2?e>^^2CBFoIe$j)! zpqldgpToMkiuw!uO%G|I&qyRu?r(bj&))CmJ$TLj_Q%|X_7ikD{({(M^YLlNa=iO-x#rPP+z^wJBWBM&b+$iUh=9IVW?{g-Stiwu!hO0nA|n;o zm)cI;4Qo595inB{#VjY15VH-!P|R^6gqUlbL_E(pgqUw$ZQdC+iij7i6cnS(6hzIR zJ{vce;$sVWG`%d!#SJ;j;CZxq!7aIqXTwY1nRCo+p=Zq zsTFP{q1M`{y2XU3v=KTWhO};!5bJG39c*=~?X*?h0F#~O_8?^my}?FnbqN`^kq#!f zKds8`p_l+&ZKIh9kTu7{Xd&cBx`QdA9k_YT#%`T|=KL*)Wt~PDXFV}9;i9&K6g%DF zgousWDMSOk_|w@pb$HL#yX-KQToEh;jOk;912zMI}9j@1SeM z6k^R9Ox%q2cMb&CtQj1N;rIY7`(gAtLhF!YSgON;J2)#}d2Xkj3$z<XMc3y6I}$_SuoJSO*l@yH5gi00x}akxZtEDqC5?%qqMq(G=yALa!{MF-ZMW`TWjAso#__JP?F1)@ zd8o9YaCHdxU4drm=+o(<>rYW}-#s+E!+t|ZBuP*IuKu2QaN@;p`9p^vt+4xQ6794i z)g4?jbU3Ne6Hj1vV8#ha*~@DpWfaRM!8OgWWAkYL&UjLj2iHVhpNU&;&v)WZJb%DV zs197?*b&ott+4<_A?o>@oQ`==-<7N5Kss>oOMVDB03Vyz#CKsgo%PLmV}ZG)dLk1Y z))I>wEH-V9s(T3eu}b-7Ovr7rgh@pn6k5dLIwz~w$hyw~MENu2I-7mH(E?gH^^I}3o{ zapKc1_X*+xmwSb1ak)kQ@2#-#7F+mKxl$@Xt-y%0IU3!=xy3j5>=oB9CG4jVHO>`EAFB>)` z2>j6uk0ppx)pH0g$6%1%#RNfL&Te(48~p3oy_x;Du{+Lg+5$lQM%g{i?)MQqNr(?J zypi#D5`>(uvHMYm&oacWDLdZB*zvrG@TUo}k09pLO#JU9H?HFOD#0Qlo+b#nzhw9Z zLluAE3rG&&MusXraPMIEK8DvZyo2F489vGI1%_`joaNJe^B6`Ljxc;b!h2hf- z-(q+?$|vc!n&Ae9F^17F^1_JuX2WC44+{5Glt7iPZIw^hI<%Z#_$P-KVx_SB1rVVVE7k?r=@9p z3&Wcj-p!EOCki(UWtU((!(N8ez7hUDhTmuS9K%esm*k(ra2><*7+%HjQHIYke2rlt z>L?0d&+sCK*E0MR!_LH8UB;udenVH-@>q;;d>eWjp1C3fQfD;!!W}yF?^KaPZ|D|;R1||DcqF| zf5`Ax47(R-|8p6>#?Y6k@s}{Xp5aRj|HiNpbu00IC&SM%e2C$)McO~a@KT01G5j0D zJkF}$Cl#N|mucM8K= zhOG>@G3;k}3BxZie3ao28UBpn9~jOFYW}MjmNGn*VLQWZ47(VPFuaZ7oeV$A@S6<( z#PAJ$MAy;?_>A?!$%qZgyBCJ`m?pX*$kI4JdI(5 zVI#wLGTh5>AHypc-oo$!hL13OlHm&s11nfA!-WiU7_MVj#qe~7XE8jN;ckW(GQ5i6 z9SlFk@E(TWX80V#Uod=`;hz}>aIk(i{TXvuVr{U!}}OM!0=Iq z-)H!1hO_dt9<2;N!0<7KvrpFk)eJ9Y_zJ_+)!ILc;mHiwGu+6qmEnGdw=jH=;WG?> z!SFSPzBQVE2E!VL9SlbqzK7v83~y!lG{fI9%*faLmNU#}xPf64!w!a5GW_jvBg-#$DvmdG!Rg?G{ktg(TvMBm2f=#F?!VT=$31&)vt zCyKi%DF@#>N*E`( zeK;iooEawH*f=iT>)bxJtuuPwo}TvN$%4UX z-Q6nQkp{X9A{K8sJyF=Sxum}*6pIiSr*7sBIf_c1BHz~7zhg&eV0c^H(#(~DY&1-r zyU_U|!S0=Oo*88po!hViLHTCaNMB6n9K6$g$&`yk6loQ>OgHxQ_HkanSyRCg=^~M_QEQ7PYA*Y#+ zijL$&s>0ZRI%;Tmy%K*3jRTlhcYjT;e06IXSS_Kz|qF)EV#W>W}r} z2ZTVGk=WsIZ5XhgHbK&ILNOr<$8#7I5%5y!2NL4m z^%=Eib}~Yl>6B$};YG0NlwH>qw+J(xvTCOf0!*iDasX$NAmj|nA~jxzTNXL&VUJhWW}6GQrcd^~Dpt&@aou z)gKdrsCun@5`1VPUfI545_}T=YNU}9D*6}o{o13AlXm^`Rj2b`-sg06H)p*5K3QKG zj5_GYOZgp*>OAY(vBB=qe%wIYkz`v9K4|FyyUu|gIt)7pA99U~a2>{ssYStG0=dX{j9em*m9##ErR?g${DKNB@-3BFKHnUma5(Z3k(Gj(N`XPAkZE|y zl(Z^GUh^d2w4P7-^tvF8ap@_>FGaoSKj!@-9y%<0B&8bwo`f5I>+rr8Kl2!V9Y8ph zybo?#_b`unZ2-c&li%ZTP+0RAKQF&r=sO*Lv{sUgUnK+>-X!Z<(A5~B4nHs5kEcnu z42Gb%na9ZT#-k5(PZ}b?$>_=hSVuCR4mz*>a*oe#QXaB4Zf}8||c_+W$&%wH@A#(W9TKfVAe$ia4AH$957=h_=l@}>*#f)4) zdT6aBsNVD+Bdfr}Zyo3|KtlX5tz_}D;=%kHKz9QP=Ev}}?8kJ!!Wu;~J6q|?bmdsH zn3KdVe+Oe{d}~nBjeeL$oK(Md&^h-lOr~GMGOUZ4NB|l-uYT8p?(ro0ecPko*+E;s z)l=w~09_9J&12+x?RRZZh^q_{prP~Xm$O`m2b0iUivUjhy$CvEzcrwzyh1;3`W^(` z^T3-2Y}Dh`@5k9fTyBT}4V_oNo)tnINJ2+@1f2Tiz$iw)0?<#UUoq(RC*kMS?>^8? zC;w$&PWw|y_|aYmr+zdyz6f+wJ}_-NseVs_?s;m3_%U|z>i1bhvc(Vq8al82LNnkOC~E4A&6>H10IaS!N%r~}Po?CxCL=`OD|p`mKWBWclC`(9N;gS#l@n2fEQDbYA`Hhat--1$y&(4c?vl zHH_HxZV-M(KX1L;4!Vy8K){dTcQM@NoxBc?YaUFd_|f}$_&MqR4!WC?s#@2(k;12?>izo6IY_E_t4dY zj_^cB(VmQ7i-RBakqn)e-(Ckl%7%un4DU|;_JfY%M{-I2WOO$;=qUVTbay)Fs2CeM zuU)i_p=T<%9n=U1pPo~^usoQ zN$H*h9qsd?cpNtc-NE8z-Ik0KU?ojKYs8 z+XO+EF!+)G#<<8h01e$KMTNyhLHh|6mzPu&7nGG31cUgGNB_m*Noi?mFj!nvR$i>| zXV1DY(ol;}@GPzpJxtpr#Mw71uK>l9Vts~a5*xmns5^k)tM|-bdGAu+{uA~``a1f) zTIGLg!~V1O-%#a$^40r%!2{Kax~l49o)p2{cluV;R~LlSPP%*9jpD+rzdt2%{Xab` z>xQb?&-tD|tLlcTw4Vg`wq|{7naKO?Q?K49f{D5%wXgqn4iwRLN|7@hTjC@9{O%+6 z9mdhV!`a%cvmnO3KkZG%CbQdi_wY)d4vkqhAP$;RcLHm zdrdX4xF#JW%E6x|60!mv*op?_6{)GS$mrdsLLb+nP)CT+&FY{X8>BOS@g*@fpI8Jf z?X5M@+FEt{I%tg72oBB~>cy$qqrqZD%ZP!Y!R>BLVsw}hXdSAnjUK_0g3^NGLR?W# zF~!*@k@i@1%O>2Njt@Pz#_(~ajv;&1!mF*hww=C4K7@zoi_IXu*n|)g&P?%Yf3r!< zEQIT;O_z`L-KG|fcpwmKf?C3Uvuw_ahg+-bW2J2|L+nHoivp(s6mfg~rpBsZ(FAm^nnZm8YT+*;!fWPG)Jw~;wu4HQf25!u=v zX;R~Z4p%( zm>M{o92#zDh=tqQBCYK zU#c`064b|(*r%%a@^KJ=J}bh|9gP>N9%xZnn-m+TTu8;jK#<_O>IK1Hm@++2x!VZ%obc9Qs1Wtyc`OEQ zk^;=TSPC$Oq2jXQ@}kmWpwDL!K-(fJ3JZ&h$_fjLO3O=%%gRd13(6qkLNX-cLL5ra zE!-;!L6HHbw4|g6xc4X=#Rjj^vVAQhXxmrkCb#!B%3_ucjM=Yspxws5&f$|R39fheTRI#nA#PN9*IMb|%zsFy zn=Efm50C$UTmH#Ye27AzkaD$SRke<)$<#Xo1IPj2vFO3bQ8g#Y)QbLbC0Pk@2S`>EjHw{cNYj6# zs?ZU;AKD)7=shdjqII!wdvjy7I$6#76PG{2I&;bk@Z5%O2ha|~_BlnVN#)zuwU{ev_C)j!xh zFxC^tc*g8hRXrnpJ|BG_%=0@L(_vzIP>{3Arjc5a~ z%z>Olg}5Qw6ak`tkhX0i!%(+5+>Sb#y=Z!_zuQ4^YAn{&j9sZ1;Zdg-H;E36B;wt< zxT!2YIyO9rY9@>>eOsi4#QslifO+q$PjI_N*hZ4=b6i|f{+H6xXsyq;o4;YOa z51~}Z49?Xd9K^0upu?<7(ZS*!SURG` zCH>F~?VX~TeA?^cY8$JY8(T12*-Fi$f0-}EpY2bGVL&y1xB^ zBC)snrI-RWT8)&*_NB-T)PE`9K8#sGXbjVYTd;&0J9H@~65ysU_^ZaSDv5uPIt&v-DYom@ z1w*BqRt3)|ttLn&#t@46OS4SCZ7zBlv_hbIHwBx7|6G-W^uAVF^E%>r2%V}}_s)X+ zzT~;bkq2}JLSOJcWpDfuDU;Naaq%*2CQ(E z6TqB73a=}_t#K{IKqn=a^*dGk@JFOfb6m?Tj##>pYOMnw_wF;dd$%;8X2WAN2Li{+Y;GY z9cjU+!ODCtb*vEeCd7n+SJdr;+*u24%&@H4j=hUo z#1NBjf0gx{>LRhtSR6zR-8(SUIf@JYaF0Z^DcX)60_4A8ku-or&4cs|jdcygy@Urb zpQgi2#_E41E~yBjA+YAU3VLH@wbkkz3$n-GrHTwLy=ZEt4Dk=k&1s5N-HUxjWr#_x z$z%TB1g_N^8R_rcqb!%JSE}iK{rVs~bZl1zPea-wtHkUuy+pWn0vcH8_>><@i`yct z&1i<;{60C+Mm05~s)L1!f%^gB41(5Yo+boaClbsp0_qt>L*}5>qSq8bLvvkKK`?iX zYgy}c%S#zASTJ6$>{US0-|+X3;3RNdhBf_onh>s78l;ZnTVT5#13&b%^%7%l?vy56 zxiV<{_aref*_hgYW##UjiQ-&{Ssl#XvuagvB_f1td~_C|)F~J*w47_LU_CPk2D`j3 z#fkt92k9L6cf>*;6@z4%Su7?ChFDyKSm2A?nItX9J?W|$fZL7WhW%h8{|;MtQq;<^ zC{-pSOe00DV9@?{*8bm?oZVI~T#igh^}$q{d#IuCXISAQT#j@p(kaQTdmY8e)LJeA z+aG#;1$qs3ss>={LT&0rMefN|ngO_dlei5H@1!Dzc|lVPOj*&I5MG{!4cLAMY{$SC zhfl?O{v8>XPD`SP3$N{*I@xVHRdZQRMB(-Ttxa_Gk51n(9KdB4n+bS68lXB9-I0cx zP;M`#=eUdGXqAJ#wE8sQY^Z7Y^n@d1OK$J#_Gt%R9c(8CPudI$XCQjD?q2G48hm`e zPqm{Ue1CAbT7>Tv+gT`lcg(VTsp#|5PC~z^!e0!p+;aodn*`9uaj3pC?T_4w`34@_ zPpiMr!T$xl{S?&|!Fp4Qwv)Ahm0~YIVcJWyC^{Ml?5Aba1udGK5LeSeYUYB>8^yV5 z01zJ@?&}=v!9v1zk@*9}w(=uBd8ItbR3Ez2&?_WD%5}pHt#$uCmc{xSiV{<`mXmn3*$y)>R%Pw-4uuf}tH>*0%x;_`c&I3zV zUCmA<2(cWG>u6q|D!=UwdI+H$5_6AFn2@GIa#`4|uBdz?RX*hjFoh&hc}tr7v+p={ zPb}!JM)sSKn~TexY;MkK}yVz(&gs@D|$P-Mx6A$jww+pmZ+ZaR0I0d8+~>BBfL#0m9GHlEsa40 zbK}Gr4wNcUd))}}X@}d9oqNUW$vs3R6f;6p&OOJC5Vtzrs!{G0&rQII#i%?rA1j;G zc~N3FVdzR=af^BD6|~A@Y%kt)IC{k?Fqby5vL2$Kz7szMumC@rh8rs9L zGm1hO;Ekh2N8|S$gAA2me1e^Ok7Dyi4Q*M*%seos1;!w+I(ZS~RGc8n5n=}a(0;-7I6;OjRg z2$dRwANqK?iDuNjEGod^M?Mycg;knwqu3RUt8+6k3-DvFuZm_le1492wrs-ATOAHz zs!9v0N-;G5wNEYa7E=OX(XcJrSc64i+Eq^b#npPSS+*7OBYvGgo0^iYMGu{)%a6L ze~J(lbfzg3S#p)~T@}PcIXb9_kHPDlSBr;c&piPORRGP+6^7__Ul$R4N^8(wb+{VX z+>&W<>Z!pb8jy4fw~Bg}&yfb$18{Cx?yiE>yF#mX6|UYj!2-Jw^GV`Qyu9(>6;kBo zNzFywe7CZ@w6Q{^6X=bpJoL~H+7uRh=ruL*N5no~h66}P!`(PVws0KjxFa4<0JP?I zu2#FbJA>V^xmm>7eOV=2pZ&gFb|u%fwAX*Fc-cm2m^ys$a|Hr zwz00m7Pe;k!oI46O-~X>O6fnj`rk-uE89{hyG-TeX`A4Iq$aR=teFOnhbG3%W-w`Z zM>;%J*3i5qroUj=hRr+8O)=c>8)-#7`9Dd#wnp3G^V6~@wn{cPHJpjL-bq3~KNXE) zgQoK))ka>0zi2t#VGU1KaST+<{V=i6~GYUCa902SP64-|@imv;R^sPwAN>mTUdwZc3InzZp zZmd?y_Vy2>-Gs`6-SODDWg>H(lwVB`;oWj;B`YDBxwGR5^C9?u~A5K##U}EMKmegL#R!O6wY!>&+E5Z3MY3XFM zR@`7{XF(wJBF0biBc$#qr9xFbb=6g>Yj6P_wjC*et{b$^Py8$4g0m6;VT z5GYraBf{{YH(yp5S(V;W{NI>`7wHpOD8N+KO9H+XsaYEn+J8>gMtqS?l=HGS_UN|^ zEjH2LW7}NC1K$eon-|FY+3Xx8^PnY@-cpoIdQ10zel`lFL*`wO2}zJi{!5fhdRwMs z(pxZ@Op52F0eLNCet(XZxdioyjwiione>+Kzhe#xtwZMVsYWLGYnk+>Wzt(RnJRC+ z8IZR@=G}8q>^9S0M&wsh4#uGq1y0EtZ^On?HAP15^sL00cFyI(Mq6<^sq(~HSi&}@ z5;Bx3e*+===glCaISNHr|5VJMPL;2M`LAcf+>zrZWsa6eWQNk@-@yEV`7_YmQA8$Z zPF3C&Y4W}EQT{S!z+5$7Is;A49PQTc(&QE3{p^B_tlr+yhB%HuFfCy}5VZrH+eL=1 zEqz&-d~c2KiVu&(op^s%qJ4LNPtO2K5?At7im<&CtJ)&-*>uVZqadNiv~j4XzZbiL zjhs2mwYIZ+6gy^F`aF@X-c&8x4Mk$Zojv{Ig?5HfrLQhsJ_GG_Tr*qVkEq;y?Ek%}I8sGL<=|}jETZy(r4w_LU85|X zOASlHW$Pet>0EE1%Gy5KXX=ePVgXw2?99x$3sn7)ow;ejLj0J>lP}Jk_WZlqaO6{CnqX2x`Bi%gP5w>EnvfW&lO;yl3=)HCtO@ZUq!pi*42n;7=FM}G#6{(z zJLb!05tmOcUy{{^?wiP*hx8LBN7dH0n@E5sXN6Y6s&UIA-4{_Nq7TpPL{_|qGvuq_ z{gvz`SxttG$ZG1cE#u45>vh<mUXsdI;?XR9Hh`=^RhE?L<%>5X5#_cSj`gRv&$~TWiuXp7%Wss4P z3@k$>!jv+oc)pM+_bmTOw^a6gUE$Fx`Av>f>7Q)I2jxspb=Y$=YK93*3YZ*3(-Tug?&U@Dj%9(oYfpB~ z{CI_OjEqo6hOoJJ;^6Mnl*kP1b=EzFy za=LlSq(7M`RY!jK7vP9`dZ_9M!J5e`Ph3{J`FIpbRyQypnlT1IcwQlqN zA9-H_9%ohVf6h!M32oXY=@y_3(=?PcBq5VMO-nmTCdstf$Ruqkks+B(n$T>`(gi^( zYehtm#RUXKK@styA}$vdDd(Qi9lbJLLc%OTp|Mz6_ z`_6mb^Pcy-XFuQfo#W7rLZ_R$QTbS=bfdc!33a0ZRL;rrYtZepRdEU;3hZPwIMNqA zV2p$@GO!IfY)_?h^};R+_0gf8g9baw4JwT$W#+Adj#y2j??}~fjvB6su^ueq#pLC; zPL@}!_2fTLJx875=kM`#N~n#>y^dA#dT8_LhB;~zKS$q=Hk4n_t&*RBHb1MGqc-uL zB4*DbzY^O9Yqle+gngG8o5x@k&7{o~d4~{^s6|O$) z@=G|@VKpJv`<48O_2?8PuSZ4qWOR58&ocBv2=?evHI5qf?m?!}i+EUh;%6PA=8v1@ z9~?SR3R#C2v<^q4*5Qaez78+UM~Cljk)QIc!wXi}8W={S+$QttkIEfpL#`X!46Ewj z&D#rW2d7cgT<6Ej==k{TEPs7{m605ksCZJ@hU3bDcrZ?ORR2|{C2IcDFMp+^;Tx{E zFYWeP`G%nzZAq_fJqP7P&2MYv<;h51s0rztr;NMmm)=BocxIml(Na*BYq>aj-oVHF5@J?lX4 zZ<4ob1)Kd86}3dVR$KK@yC_gqX zOkzDgiv;4ribw+R+W9iOgSOr%-s4Y149X*i< zb;?@IQEYgT`AbjDeJ%0M)4ku*!Xy>eAp3KrH1-J6&OH)F$ypP)4dAZ zJvKhthdr+_WkS!z4!jtG8AxK6t zieijg4ics8mXN$E-^|9C)R9owpM=IOAMar5YChH}U(8n(*7;tFRdr9w*Hzasnx>ko zrs3Us4&JTbujxLhX5`%mVd5;=ZGY8<#;epwbX)J+pqAZ}T=U^BdHdcaYm|74- zjAn=;#)z3B1|*31@D6!nfy(@t6dO~Q(OJez`yW~f{<)49FfCr{rbW%ScgRl`o=)u< zeVoIs^TVnHtEmY}a2uu_Hj6%tHhtq0JLR*5O5Modcw`Dq;f`@^K48@Eyj4W5o$Bw$ z3p2WJXok#Rr0yrKHoTb{#e7HQeXnA|+rRMNUNC_ZQn)V}k0_!VCG_H4>pdZQgl0~0 z_OlcvL}Vz)$!ss!c;ha4RgptAJi_IECl|{KaW%_ZH4dhPish}+lOu)LA8;bdT7ryS zGu4xPtu_cVsy%L3yPJYXNBVRv5F772M}Ehty0$7U%fUQHWL({kXVn#p=4;iB&v(mL zoC+yh&aBUIY-vq2DfRy}TfY7-dB+)!V!*aUh04Wi(epCppNr;e$_%VO1!`(~ciF6ZI~}s*D^2O0{aOb26hTH7`cwEfw)qHan>o z6RSLJWJ_8>Idn~=oYhg0azwP!U`tM7m5<06m5-#<+#HoJRj9f+&B{jic5_KWBU6tS zGo(+T6{Q1R9i_wS_$VE4CDwQ}R^wArmp<4pmzy7rhPvwN0wJ9JW0CMJTUQId=Lutr zqP7lkvE|boXl=wkOq%{4i>^0E58~*O&blUXk>!Eie6S;sxX_}6@MUIKv%f>U+oE*_ z@YQI8KiG^NvD9g{G_?`}b18vOY1EmT_$Jo98lSGhsSdz&i$2_eYsT+?-ifoZ^d5U|>`z~ap-v;aEWc~`zCFoA)0hafKTqDj{f=@Zt;NFeHL6-+{ zB1}@QSh(=ah3-@w9;VNcS?aM)l1X-wgh;Un={U<5r_8uhPfevDIGfdS)FEJ|B#s4k zA`uoE1cM{ZP7q>|;Uwn8hC_%Y#;qkg-69cl#yUYM%1lDi+^Gw3@+v;Akjv?2SsqTr zSq0DK>IMheuUH5#eMZj8g+kwC5e<7}BY-%`@b{%-w`|Qpx2uRwH>(#4g6u_*99&U# z0`?8nw?cRgT3MP9YYfN2g^L!ZL3GX%rRLg71-TvoS^reJ!RCboE=W5~-5^B?jM zQbdeoAqVs6mTpehG;FE26ji8jDOABH=u4sg8RS!zrumDtgF^TWI;!PTN&1y86~u?? zNjE~27a`<^B{fT`m$*|mrv+DN+f+EonpkNO8=0@lBI)2>#9Hkn5@~})YFt5t8jGL< zVhZad39-o{G{RPAT24#VEil<;rw1uZW-C45|xV(-O^2`rU}utQkACdStw0A zvQ$~$S*9epPACB5*@gp0EAlOrK1bgYL$|&a;#~$O#d)sbC|E+yFgugUah`T)pC0WX zItE0(bRBC%-6Ensx}j*Ibc1~uJPLLbP(>f`u&y|tl5Y{}e0?j#9>bgD4;c;}^RU5B zej_B1>f@-ofs8RD1!U~K+OaupBOK$}v1$eBHDNe#7=5{_!BaKLqWd<9EGWD`LsG*j z#DR@`14FB8zMqt0f{c0j9`8A2eWm4nCGVnR!xW*g5DPVvgFQpu!orc!Ft!W8V?NAQ zC+NB36duiCgB|RRuRM3tn+o*y+i=g=810)nad5bIbZ7#;eS@PXoMTs5*bjFIN3+t2c!h-+fsRd0ZldEl@G{kK6v8GE zFE#<`#wWQ5G+aE?O;dclt%zOjd$7elW^hHL2)eI7Iy~AJ-PAui9*Hgx!4U}Z!bro> zk;#b-$dHo0NLe997;nRHIM+biEz+;-MsB1y+B>zIFhRoeus=af;2IBwjzZl-)FN#auz8INbPRpRaWEvu=HygQC!B zrfz}OlrQa%)|xNvpJF&gJ?`8BqaMDr8_hglUZ5MNEB*vMuW^xn12(sCN#S(6M6b=? z4GFJVA~EuIi=WusQY;YPa<~_YJ00#cagD>hNbGaC7mITp?j@qm;Z7Ip9PSLU$mY&K z`ksLaU`l1lOr+;-hubCgS|$=1t_qRwaF>bSTPB5nvAEmeK3VK`xK9!59qzT_4^|c- z{ORJ$4);p2-{C$@Y;w5EM4H20EPiGc0mwU9eA3}QMT|MzYek*IeY#lYaIX}&Ga&T&sk5m=KOf8GlHKvYCVcL{DX; z;m}5?aB!<|Kot&HMd2_s+sJa18`D4KhJP{9aprLuVJ63e10cRjZtPzEeZrM7bnq!U z@Gbe5Iu2c0N$AB)lHCP_YY;!XHxjPH6ouW}2*KaR?sEy(U?|M) zVRr9j_l4{}#O~_|A@7rncQE}+?7pAf-z8il#FOm)EhFv6Mtbk1^dTL}{uov(gncd{ z`k6vpL0DnY?Mkp}$`(KiWk86h6PDEg_E|J_8d z7UEwB@m9ifgzJQOjZu|bxT(J+`c}q|GrrDf*zabx%VUgmz8;0EVw__90pl+j*PvY_ zz7ocRj8`%Kfbo}%7bR={UorlPaWm>H$!TZ2h4CK7|7Ki(ev0@y8T%RE!}tK>j~J;R zB>qgaL4>)C8yPQPyq57%#%CDcU@SrZPvM&wFJZia@$-x?F$%O@#J_>DnX!-YcE+zU zdeD{;|4PO)7>5}zWqg8h0opp^U&YwQ_&&ym82`bzX|d*SXB=d_jPWhTMVR4|+;xn8 z#;-Cy%J?kfUl=nm^QCYfWc&%^uNfm5+J7(O8;sNjQMk()Z(@9r@h!#{EPfH+xr|?A ze3)?++IsT$F}88@H}B>F9ke_?D#A3^lbF)l}+K<-0~FEZAl zO(pt8jQ29W#JC!L4*B1}_(R6xlQsQ(#>W|-V_bqhmBQsSp2s-J_$kI$88H-4{65AD z8LwshHlsvaMRLzzY+&qQ+{HM^csb*j86Rc*3F9vrUtvu1YWeFKD;UpY>}1@<*vmM< zcst`~8SiEM4&&>LZ!#WZOkbnpEoZD@tYhqCJiz!K#w!><%=iG~5ynRupJx0!qdP~( zw~%oa<7UPHV+-TCjE5MnV7!L$HpU~2k1#&L_&lR$Eyv5alrfiaBV#S&R>pG}_cHEh zyqNJ?#yc55&v+l>_ZXjH{1xL%jDKYGe|G@Yr;{x=hRQ}g6p2m0v;}*spjPGKMGVWu%hVcf*I~X5eJi_=W z(RmZA;!lT7oM*D>liO(e3db|K>KGip3b<5aT{X?<6*|z7$0JMit$&B zZ!o$FwfuC(dd63{81XKEDi>!mZe`5yY5GZwcvnF2J;e9}#$Pk;E7ATJ zGv36QEI>ya`CY;)o^K$IUy~bc%Bzf`2n$F>=FYPdq6k|WPWJQy2aG$c^%kj>%<$M$ z??}%uwwEfhXn1r!9JLeZ-7dQu8##|c+`(ZbHlo*EMG>vlVr4cwfOnGc0+rredH48O z5y#cji_AJy%V0Ee)=+VHr`kQ(78O>RHS@?gooNzo zFR5s1JW#Q7Z%H&x@(mxr z(V2bz#?joy{x|`KCk7|5G&wwm_3&|(hTZ#Au%6vhyLy5b9PH~XOB4)7i$qkIKr z-F2K$i!igPt5*IXz-;O!2e4-eLe8NsQm-}Ny2xSYRTov*dDTS~(#k}tN3+RAZhLg- zw^tW!GUitol>jTR=hzV2L)$Zcj;-(<#-ukFs$Hu}K=)0jE8ABm zpvRG~CKkEA(tpx$uQS+^aI~k#pa1k>relOT=f~-ZhQ|=pO+S7z-`%3Nqi&cQiA)aS z0NL(1Z^__$ls<^-8S10GtaB%YzY+7po@h_+ppbN=xu?!}F-Ih)ogg#hGS^C(B~O$t ztcwb_s4FQduEqnrlVrAw9+wGhY@8*sldvi&Fu@cO%jzOix)x}!#S%EH>$5KX43Ort zbd}+kr0(=T`|xpGg$i8q!n z&x2=~hH-8B#oDh71*J2NyjZ@&;LEcaz_@)s=dU5+UOboih~a6A_re%Hdfq}dG%h2^ zX|^!r_rM~=YcSdTB9ND1qyHLwh+0(Rw+cThr}XPG;sw(6d+>SHo&IOUyDmmv+G3O! zu#h|~L7DQ*bg;Zt;QI(g%$Fh0v>)@`hvyFQ>}=*6^QGc>L|PoX{1Jlf>0O5B42FJK zQcS2{F8GeJY*I0ieyi~Opo!C9=Zn>^4}6cu(eGbl^ebLt>4zoFg!*j(Uv8XuW9`=m zzH8&~#p?G4_#TSGca?P7?`t`heg!k=N9**@#gP}Q-)GkfadjNNSpCY7*azeAofD(q z8{jkY7fYB4?U#i0=EHI1#p-u8_-0f7o&(?K_=em#oF%)@X@Jv#%1uC?FN_if(pF5ZFt(`{T=uAdNf&S*?B$u zNHqOo>-lBi^P&wjE<1x8y&i4rTjPz1+48B--PuS$q7|Gy^l_xH>Z)6LJ-!U9OgYS&el8Q2~b@|Gw%B#zYE31mV zUi{(G|M4iKqN2j+6<3vApTB+T}kJ z1?kVqAG$tz?9G21OKtet7FWXt|5dfFCmvb3DA=?`ey=ZE6ukPR@KUJwd~O@xOTRmI z?AXPmrw2a_6UA%yB`tgZm)130@}+a@7A;F}s9d(Qt|IBsiDJz`|B8l@y2@qbI_O`A z`}dvr+5=;a^wy%zg(NxG>1e61DDsYdiSf1%MWgyb7fw-4v@nDH^djLNUsbfKyu!yT zIkXQME+aJ6R=3!K|0oXAzEoASbutqs+0ky}+kkF#fsS=hU3NUG(7PXW%adGqu~o|d z?`@4$GrInHw*Gh1*3@#Lb{uo7wae3myl`>mB9S6eWQr@rotl*DNli{oNli^XA$39O z!j!aBbSd^x5b5|%$jFP)!xdK#9Y66J*M+$8FWrBc=kla0+*i7;kqt}t1s5!Rw}0U- z_5X4BbG_vg3upIv$J?s2e&=UKl8$9;9Gq;L>ZLDc3McRh*#4gJC?9)VUQ{1yABpbo z)?doN(cL~idVVxAIYI13N;MXvvT%Als9^Z}KbaoNHoB5xKGo(gxN|c9Q=EBklB`OL zS!2dFVlw?<9ab1Z2FF6!e84})NjQ6O#3z)7w4D(S;2L7bh=uKSr)o;gRA_CVKK|_$`O~gyfTmntU?;d)z6>r+8$RV%w9v6#mI; zrt>AQNM4F=iTWi`&h>+ql2U|T>E%A_IO?sNLm`ZsANMSCZJ zl))|jt7{ql>##fOaZ4Oh>>x3uF>di+T^3^(`A*^|g{i3JyWI*)HZU(NoFPESbmK;o zD1GLYhC3bYP zHWo2CFg4t3zc)=sN7Wl8T%Ug(3aHw^+@N7EQGauD*dGc7IyxY77d;W{-OCeyTrge)*_VYCVGRE1lDt=>Xk zNtKY3aO1T{MJO$)tN>{WBosa(<-Mo)KxMzap!`1g;FuipF;iz}Va|TA9@O#pcY1v# zXlXCtXyB$;KzTRE0!oRmtg@`Cw4w~;3pomqtthHXN=i#BONvV?s>;hME6b~jD-p%T zWJsiiB$Ss6c}Nn05(7#_d3h;l?^QHP4QOR0)n(Ncl_k~XQ$k*%d?+<4Dl=1jRajuD zEJOcLT3K9OUhb>#l_Rn%C1j&gp{Ur+ci1AwSn++9PkduuWiiasrXR3E=wvI?USm-? z?QG!>S{`fwyP>bOd`%;0+t=mAxA*nRVx|oYv)^DNJB@#%%_m+K++_1NbvRx|+^qC& zF!RA){*X_%nBJTpG5#Mn{p07#t)~AhGv$+J04|EQ!hE~w$A+lIJxs_)6+D} z%$f5UZA-RGY+?Vb<;$8l>cU-?cf5T1oaJq5bG&T&5+wlRCe>KrR$E)hubXt}$aL%k zFCSEKr~vRF=~@#ZAEpqfq}=S7O|7kIGTNP?A(ViBGx;IN)-=Z{)QbOc6|;)K86aLu zFr|V#C5;gwHHEg+{lxNcChr$A6l@IpJKI`G78b4-3+`c3Iv=V6|!16Q4Zj|UC0f}iR_2-E+K2Y?NdhB`-MDHJ9Xgi3%Oalb!hB|xkbBm z@E3*jD{0t?7$=k(@i*FNrWQ>$qNz*JMl?0rs-v*UgkCLnqN!c0ooedXW~Z8(w(Gd) zC{?8>OwnbLv`EmlTQpP69Tv^hawkV(%7byvvC*_Z5W8(eQ^j}Lh^B_;s%S9p<(!IY zCMG~szhb~)NSt@)uTgo&1mwn^HL3*CJYW@mcnwF;LJ7?SPQrk;B@_(N{1da#CX8!y z_1mL*rrDxrPUWD5TF?jJ!3s(eRpRDgYXF475qh^21%`&r{!X;X>_rQLgAp6Ync;A2 zTeu^DIU@~vaa!rn#8@$iJ*6%mpx2Z33f}_Yd;}riKttEs)((%6(J>+a z3g?c7Ae{UA2Zg-UO-{1p{(hM8DmX)d?Ql*+_X&ADoWW3S-gs3nK!Sv3n{)8LhFw&v~NyA?;@cs$JMlN zcrKcL1wuQNHSl?vkk68{tpf=j9~~F+cW~BjYwyh4*E2K~rM$yeh&_A8Mv=!%6Y}aL znzHSJXJqIC-Otd%np^POmd<`gKX|}@^>~lB_Cn7R=i#1|k63*RKY@u2=nVFbbt&)2 zLzkL=NI8P)zdJgK#g*31j<#mJCPLdfTYKy46LHR_M+m#?Mn@*`VWVb|?PB9sUGf4< z`LT1p6$W8H&|0-LZ+P z`F^teg`rD(N3g{o+IAcZ4Yu@5?6Iu!-W2&;Lk&}aR%L8l^BN{`hOGI1ihRRejYgq1 z*vWC~aH>U^R*<`mCt*~|yYaA!9%t!`ZoK%d!H*W<9erb6TT46EKRc*o(b!mDQIdFbT#7YDXR88Fp~t!p;*Q6FE#U1KMsZ;|DNMDGoP<8w0I@j$j>fBFB{^x6t^dn8z^2Gl>>IEx38hsk6h7 zVmbp(6NA6%3~S@~duhNhJ(Lo=aiiB)(Y4-tA!#)&W)h4@v3_Yhc;G%4qYQfHphh>v zUBbOrl_358ts76>-tjVoK~*?1T&yQU(@T%74Cn#`J3pZ8jejC3QTef?{;w-J%7SX` zd_7V?@3m9eS&qhba-8k;}X;j4`vm#d2|FYgaR#nN<;B%^*oVe|($sT1tUqUi(>lI9#WM%ae-z|OirJ7x`L;d7{ChG;TEOq+NGojxd?4baAzmbF=_ zcLEKJV$?yjT|S;2nD zm1m_NFmM*xi`;VWh1eG3MpXXu@^tyoUe5I3^|=Q~$5592p)f%R@8;-n@hB z*L&9?K{zT%7Xiwh;sYh7bAuVIZw|p=m-i)^3BaZ$JwyK!sn8qQAY0~^ibTPXitCXI zd^S9ntOa{azG?xGb~B{m4YY~>30uVEs99oBtBis$iySqBLHj#c`~R`*jF_cx4GJZ- z2Qz6N!wrT1g%y5>>yfTSIwx6lzpXkMt(Jqq@`qkuhh8H+ssot0QXB1}Vvi|QS^%Vd zhop^;4^tJxx}ebt%-GNxA!213Vj%Y4Aa)9Ju{Bn-?|-7e(q2wbpN1UQ?~|=02-hn%SG#b%YB@`U>&^w%C>3LV ztfgU$TZ{jgUOCqWX155S_Y6^EXL>`EzTKY7b1V-2PZ;edsi6p-S0!mXnGdjHUU+U- zd^8a_Opj4B+BG{7uA>L3nHiZki@jL{v46$#Mlo$M+#+kIE=FcZ^to7|4IvwW~4STj>vOi&~P}hl$Vm^eU=oohKBC( zE%`~0{F;N^5m}G{K zDe8f!`D=>&7k6%CbnGDM>yQ~IAC>HXNtIu9uQh@=#m6Z@Dw?0B$}f7>_V@Ho*!lZy zOQKXQ(LCX*17cYb7kwT5Q{c2(`6`I9wb6@UPMSE&Mp8BEkdq+3U~}7wbHDg=d=F6r z#f(T)$vxjmP=_R#460M^7th#v6iuu^7Rb!YOP~_&V_}{yInNlP<*tk z*x+voHlK~vq<@VKAlwhQ+)3_l;$TJjh^s!(-02UWRqDe8?*MvqbbkM45PjvCpWw~C zNAdDTJ-q~tm3dI~*rBvR$j4pnL2qf1ugq6oT~dL!{Hm%et5IJ5!$mJYX=OV7Snmka zTQlBr>?|aIZ1Y33;ZResp%b%29CYLLQS?vQ8GPjigRjD1_=$@jH_?iEtcYqz_^FE{ z#e-E^Z==)|A5gn`Vin+LvA!yqRq**wq_e#X@AB$!2vb{8Tw8&u`EOk65pNk~03I5K zf-UuU2u$y((;MjOd9d-=R>)7dbp~~{#(fq&VmyuhB=eaoGL8k7o}v9c2Pb$PhNj}* zGb7H!p2ne8X7_YGerKh zAXY4oa4Z#NhWz|I*o59b@Wv?g?_h1;)>PY>hxhA!1^8D&|4NY*45ld*S#rJdUGK$0 zIR>amk3rWZuK^dWp2q|zQ313xM;PMQV_hWhNv%O=?R+(`q{Y+V%rm`lG@#fi+W zK0_Md9e}-+dHaeB_W26-l@#ooW`TW3d4lwltl0GL^C|YKxaOi^zEjzK+E~7dY5az% zV)&sSv?(cz;n&#rNA?XB+3aHC zL@E6ftN*RIwz4dBy2Dgqi_~79-f{uOF+W#wtRT9vbk+XSbr0-3oq}q zwT5wqaG(S2=H?F@Fp=h@02UX^TXZ9W@oy$M1;HxrK%gRb)y)kj{7|LFXkb0qy9 zhWY+Qg4Z%;H>0yz_8>yK z){5*gyoWG}q5G(Gtxd`vs~e5>_d_dkrs5dmp9`gI|KK?KO{hE)!NHJ~B6FjZ-$?c3 zA92qh@`zI;IZ5OT@kHWS^2`rP`4D8@lr)3P6)uOG-ZqRtC&mJ3{FuvQ>{ApV8-a)J~ z_k|-p6Mf;nexI^69l$9v-|v!do#4rTFxe3qy)9vnES_2Hk!?`?Ge$<%I_i>_FYx4l zEJfvjk+Rsx;@V5uDsD2A&7yAkK}h~nN-Ei`1E(fhMGypifW0o0uI#aT+D9={#iQ+m zhG2Z~fK>#Q%x}BpH48oY-%p)`%*G^?A7pO6&fIBo@iA2yNq63OaZ)<3^vD|!=a15KoLOi`bUNuy z$4Pgo?mN>^X>D};##a%H1eaeJuo#Ivw5%a|&X(Pa5sL~?lX915DPQuGeaB>cz8 z@-+zm&0K`rN?bzW=!rz8FGaou;YXItL33LbNi3Y2ylYbAWlK>1(&r#tbziywB^Hi; z>*W-A4P^f!BR#vnf3i7>O&5%wa1exsp`P6$UALC5Y%IQaME6Cg*wxg(Z0ccycKN3lg3gTdLol}W0qrIEOOMHYDFVZ zBs|{JH+Z1LDln?{HKxj^p#4Xd{%_MhM(?s1y*($$*P!?e-?UrxwUhL+}4sx$GS&<=o-FeS2q*jzoJ8a>Y|^D0eh*i@a(h z3m3|7BPq9@_w3Il55(0!jJMNz+S{)uOCeL>>GJ2k7{O_Q%9`s+@fDf%1d9Q{#5e_h;2sU+4el9yz7 z@~>DmQ=|(P&o#|iGAA>6ah#MYLw|LVydIH$cXbvQ{|@ZUZS~(qLyy6lfa$cxPHBbm#PVY!QPGQX>pAE&0?nN0R{o<<{?HO-`55IXyI))^AB6Hxc;hRtYkuv)5~KVk zWlzhDoEbr;!NAc)ENIvcH~_mECHH5!tQ1mStSo`gtAR z+%!g;Ml3o86u`RC2_8nMIFaBERnV$4;v}>)T_vD3*87@s)nTPGlJPHR{{qT~U%+!T(6jGzhb28*tpwLfqXQz;wW;8o^9%sZo2kx*m1i!$Y3PsFHq-7MoEBO@C)4wVTr#zEEd`Am7mNuK;m zPn%^N-0^c94pp=ROXYQl<7LFrY}slI?~X>Deb;R5rKe7#L(@%m*HU@w$)5b5 zaf;k)CvSbaXUcMBiC1e~O6yvtY)gsD&V_#*&lE_RLA41)}^F z@_EGYokB+p#yrxflH3Rw#)@eLP@M5CZfqlP^$PjmYES;nMKem~GHghWsr%C6l`-$>nUQhn7%d!%u zY-XEfM@ORLyANs$re`0(3Mwt)@xYCeM+2}JgDyEq{t(d~s_-U`cJ^u1&1-u0I7S3x zym~~TmzlbeS+bOFbhk=(zSDJ6P52cj$xGIF@^7h}!6dWKY^~d3hi())-PDcB$1J&eJkFQfgZB*`ctdiG5 zn@2ayQJeTV`gXLT{CaMc`~Nl5@r8Q%6{Uthgl&W8VT;%5<@eYY z^OW$#fP6|@0$Y#GM}OWNua@nh#BA~5$tWkbg1wvlWI?(%@Lfxx=6(shZtd;JDcUpr{+@!NUtH#e1=BoxtZ(Mh0q6NNwn-%q;N~! z(Pc?2=XE64ywWT`ux_0ZoW@wX^B7jaRS#+lPJKsDBto6C(O*K$FFiH)wa5o-V$3f7 zJ|#wVf;KVe>78O;z}_X9=X*B(xkcW6+Nq=sJ}e&JqvvNT89|&F3hjfvfb(5r!JZ+k zmGOOV6z{=^jgPm=haG`cYN#JnfdLd4qX087-K)UeW86VAA@&1p z^6EUL)8NRyIC`-nq#NnM>KUp*zzc2iGt&gvbYlUepBA80WL0}jb>ivv^>+D|7LB3% z9-aHjOon-!TJ^D3dx2RJAHC8zhi)UI6Lc#!e(Nmx(e)~^O5pLdB!Q$Y2|OxHfk*MO zq7rDBa=Pw@4-QVSERIDZviS8K@@1_ASv)3X6eUtcF~%(iiBfh;NM4n1W@Ak1NGR-2 zLgSW?cQAD|AM2Da=BoB~u-%)wr ztC;ZiFZ{O`OyEow?n}lail{~jy*PY(Plz6&nNytoEJXf#j-+N&GJ@_gDIh6d8_o~NFnwIoQSfPAY<1|^(0@b4Z@6SkK5Jmrr^<$K3xmM z#yiiE-*Kw0txC&sFwYSgSNG#tb;Y9jT6N>|-SQQuLdupi>vJ4iS`$r5{Xfl?ufI#) zafYK9uq{!ca`9U9yiED$qWPLK1M3etnXeaZ{Bl@6>C{V`bSAZqW6@Ebx-0yrS+wTZ zdGgwF)h)!nnP+tjmlo@eVJB>yCC|3E8@7R6H@1aPok4%G?iBic?DlE5`QmW*0bWp4 z-NZq=!`5zhAHchL_*NF(%R%$5SBvV!APMwdbmIi*z%j7Q$V^Si$-KC@=Kfy!qjJ^J z#HPvWYASq`rlUCVhWv!tHyAN) zjQ((it9wMhQmtC+oXluS&5IFvOGSK@%}(mY#41l4*^*XJ4qX!|XLVGh91*QF*pic2 zyv$D~>-CUB;$ke074CxbSMd?6SN9nLSK1v5%i8UUL)%cXu zr4RPY<>p7Dp{}~RKnO<;StNYR*42XVdBWJDsI5a>Z22??S{tzslcvANqU+7kgE$PO zv#v>8WO-mWAM6MuF0?2ie3{wR?C%iowrHIJd^OtO4>n^*EO7yPZkk#Nfqp??c}c*G z^i8aLH9lR%tvb-tE&6Z=t{K1onb%=nG+y9udPobsN8%f}bAHqFfAW+$q+;5}Yvu`a zPh+IoW zk%&2CouCwDCLw9=)P*=r79Uv1<#e+w52x&`g6DE|vj_*KE`*mpcW327p>MK?Cd7#d zAWky;ed##)S98$qDx%ZP>V<+Jdl4iDS5%#VbFB5P5MF~;mL|j+!?AGTqJ?P?owG!# zxwcY4t_MKYKb3B<@g;!^(oR!1NLF6D@>stV5hGd1!F;-AU+)9OE;*oMF_cJNzIb#CGOPCX~7lRHWf~? zCRSR+M&_%sNIJL|u~s{YMA~4H8dngZ#vJrg!5p6mmH~LwhZ*YxJ$szO<2h`ygZ=T9=Wcpi zf!=@{?im}Sy;CO+4)=}@O~AKrum{emu`z6=Jh7>|y3|*o{#8_zVF!r9$k@~-Y@I$C zJy3|#@d^w3;SS+YSUP8~un?orv8l;TbYur!s2Yw!*d*e`Mj+kzEEj=>i-)?o+s01! zJ=o?RBiy1<1l`vk9UkqAZt5Q$k3<)U;0OeHVWi>c$mGNZWJpQ0B2tJCcHf5KaJGTA zTclsvjoe6aw0CMZVS<$VDvC=Ad^qC@JToVsb`;%ohD!VX(eXXj9YP{Y`Udw6_C>wZ zkB=)Foqw|Y&I5b3(@a#vTR1wO+~|vrVMSoh8A-(})$28TjH(cf`GlOdcA%q)`NZP#qT(VSO2EGI?)vCH zyg{e@;Eyd@jI+O|3sKvLSl&3bqHB9loo2`zRByr=lHS64El1y&JHObS7>0M?biKN! zK;1Sw-8?-KRcg2&ryk%7*XW#cBQoCa)yAB|5ZGv+?D$z4E18!RPPZ$@?G|@{|3Z`B z9pmp2A9cvvAo^_XB=P#Oo$RJb1m+W>+2O`l{e01B#%_VunlGH=0C$Sv6xtuHF<;sr z%{*WAK(|1*>u_7jctLmLL`RGa&5QKA#|naxwiHgcOMJ%W?}mhOn_IZt;$)j!;!JY4 z!@WqnY^jLUFBbpda4!-6>TsuvPdVHf;;_S=DfT$rOGU`$cH>N7r+yx>!RDWV^q&AX zOsx*r$V7U729sKDm$=n3vB+>$i@gr_3X$({SBl?TSp@!4aks;rEp|KHIbyxTy-xhW z%5sD+5?^+>PZIkb?tHPy;jR>E4tJ^e89Hd=%5Y_iPdeN=V$9)QC+ZyTBC*WjK1uwB z3NBw6u6%K;!(AcHbGS>yDGv8)@wA@6DhU~w$$i}6K2<~~1D$`U^}U6`-A^2E&!_Zi}S za8nR!BQjARy10DNzFL_skC+4+R}OTui3j=hV`ccipb>*lM#@g8DIO+7S$mZ6hlHrR zNf1EvR7N_Op4^Ub&_RU*s&JS-s&H_ta6lCfSViF%W9q_klpCW#<%WMT(J?$FJzdK< zp0z@Jm)xs__&y;HYgO?Zbnq!U@GyO{?`8KCyAQGZGIrlc2zhrf-o^C$+5HW6f1eO?f5iAK z;|q*$5kmhHkhg>)ZX}24uCd!_3)l}!Gy+a-i`LR>*uW6|#?_huo!L5M}E z9}`0F|6+WTaXIM$y0RN^8@qQg?qR%w(MbQD?EVhp6O7L@{*`e7r3Z5J83T+Hj2~dU zh4Jf*KW03}xZ17d6fkaK3^QK9cpc-189&eX4aOskhW)-ycGx1sHwjUQ4f>bK?HA&! zgjiHE=$DYYp6!joZqN@Ay;g|J2r*Vy^nA<$2=N>t?D85TRd8~vat++d z?vFFR&S=>0X12>?jC2Mdg|A|qV*CN)FB#XMoh7~!#)FJkG5&z@my8!7A;kYH#y>G` zPSNys##<3`2{7_Vh~l<^tHHyBGW zo}lnejF&Lp!1#H_ml(xD&A)+>##PVp8&3W{#w!_bVSI}*9}7Fg zH_G@V;|BCCM8AdcFO2OgHT`pp%h7fc-yy~q8SBvZ5d9*?dl_G1T#dem{BL0VA!9Mx zYNDUd_&DQpj7!kBk$*npd5n{cpJIHK(S?HwiQmU~A>*}--)5AjXudNT8yGtncQFn! zUe5Ss#zz@{!uU(ZR~Xa0TK;;*3dS=TI~jK|_A*W|-p=@0#(NpR!}vPmn~cX8)7R*D z%Nc7J>liy34=}!m@e0NdGd{q0gz-_vry2jw=+4pcEo5B9xS27)*ur=&;~~Z?7_VWx zjqwQMBaBZlKF{b`%keTUWz1#V$XLs`mGK!*~PZ9gGh!9$|cx@kflmVO)@}_2^*y5aVNv3!x+F zS;u%OHG@pQ&bjN2GH7!Nbv#`qB9Q;ff2e1p+dsO6_K)-!f9PBOli@p{Hj zGX9wHWybU(EpH8D5#tudR>p3|4>Ep+@!O1#GyanC_l)b#(DFAi_A*W|9%B3u<0lxu zz=-!1l)cYn+{&2Y)AW-V@jip%dx-G|jK5~wSEBtdX1s|}jpI;9zANCriRUNfLcBok zbwd1+Q50dNtH|6PcS00l+r`PAUf_UnhqdS;wbB|Mo9Z3u8O9b^MHUT@_lKi)0=<7` zcVn~ZQSHVm@+1Tw999uT^a`;kqE%(AA%_R>1{GfS(py3A9v>^>SbKVLcIdvM-Q%NE zV?`xl|1j z;Q&do>t>u=M@eZ^?7Lb9_w4Zvjqi$@nmKZijfSOr2f4^6*gZ^ps8M0jr43I )yw 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⁢A6KpR)?kD?w-W9Ief+n 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 z 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

    Y0n453+eyFsoq^zs>!_)yP#EKPItQqNz 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%0A(b(S1tU|1 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

    O`B<(B0wpH{+VE(9p2o4{h~y zcj&ihbfRG~E)X2Xo5rr5J@_13ovo<01gTOO?t%7)l0!%LFcO7x7~6Z4XIu~&YVYU{ zbPbJkKwV4>Iw*W-YdPW7s^dkTB8K#SEOT29#l&{TMx`sNOXO$UR zrIsVf>m)9*R61w=`;A&c!DFc=V}b|q-Y;*53Ldp+j?n;@zR4-T2yE3@ianMp8z#KI zZ`rEB#3q(19FYxjgK9MKh^0!0@%UKsl9*UUDwYP7rJx>UvL%7TPO2EFu$IIVs01qH zqzix!9oBwNF!yadCYSY!!AHt>lY^zgSTfzH@-f!dYDhilue6svrWyk{MhBsV|;v4dk$ss(~u3ReWN}GrPoA{!Oq6 zR`G^s<^*e?jmP9_pkm<6W)dNme6}mW%5w@mflQykI2!}GKp;?19I%TU=nMq&yV`># zIO`uzbIsd-Y$4VpjkF|%X1Ji&cH(MI}U(?);1p{T8O zu)S{x+w*#BNBTO4yK&2Tn{yi-$V?bLRmP@45uZFo zrplSFIWk=yBVAbU7H&~hn3umC8wKXdOc%X27MPc(i_AEzHVaIYg~aO;;gzl=?KB;; z_t>7VVBSrhY2HmwG5+F|N&gsTdS7JshgVS%{q?}!?ymxL7s48kVQhniUC3MEkZ7|o zj16J_zUtO{6bycbzi@u>5Ih!s(>;;-m50TPO|xpRM0mX6{=N~TzrVrXEe11NT;b`s z5*hPk4E|0<0cbLmYvUKLKiUV?8i8N9KPpKt8p^ft+mASG)`Ir2`69&o=`ervUTPS5 zXFLXv6KuT6Z7@}c1%@Y^+Ya!9lldF~fmeNE1^zPdN9C0Mwi)rVOt-+F5BA1m#Jf0* z-^1{i0#C#bON%ByGabzDY4|%p5%Xj4Gxf**cHn(aBt4t?%l;mKzvKvdc@K;cmH9l5 z_c(@pSSpSx->=~B2=k`E(d2vDC&XIvz>ncCT)y=AD1Q;;dpJzKSN)cJSgMXH-#hS! z|K?-F8?L|f8SF35B@HW!0-QK>@C2m=(_%46fA6POvFwslyhb; zJHYP77H_e;ML-awOO#eX6p&Ie&in`wP*Md61*E$>&o{pB>+{_I`+J}N_sw<9S+m#v z&8ofjo|!%ST=P%+7ES*Dmwz?_&gXxTH|HPrEfSJ$pn&_`KZL3M|7hP90ryK7JN|6{ zseR|p6UM7QAc6kD{WE_00`B)$S^sQ*aQ_-N{wLRe33KZ!|5W}>p0L#O|L8}PgaP|c zKN3RuAN^P$;Kp?OqxIkR{WH!xmi&K=x z1YECwi~Cpn{%PMH0e9wq!TmGNu>$V*zw7>Ne?s}sIO|*$ZaDsc1o{VOEgb*dj|c(R zUEuxB7vc5Czx?>;_#7+X+=Xl5pY4x4J%RD(_;=lz+y5=&5AIJ&T>A&^f`HTcQ~9^L zbHef8+>@yj6#No!n*{y{VgG%~@4PrB?7}7TUt5yU*?zC7`R&K=VemKZw_iJi{qMLu zqyJvB_Z#;c^9Q%;AGm?W|BlOVxBuY&DQ|>;QxWQa%M)$^{)PLeyfuH5_d8wx$P<

    j*h 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

    2vsq@8F9w<9`RjRajaFI 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 z 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

    g52AVnuJ`H+lh5m*|;M~ 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°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 @hoDg4c)zy zcw?4hKU%C)cd8ccg(A`M?!Lj961%{tr>`+f{utW7ciF$2_HlZb#p#`Xl>8&~et7wt zqc^v9Z-Uk1^mf{tiuu=$l2>Ho0bTKLuD8?Pr1#VUc{}v}(aPm-N-5_C|Bc%_cXTAy zbC4fARflpzld#CEIq7OP7auQW06>jrhQ#b&f=x2{#ci@da+%m?H)T-tKV8A|AgqTJ#Mb(-#zc> zUq$rSCXAFyV(nsi;nMViOV`X5>4Kx@o90z=T~5Z)2~w&I{iVh7Iz;-d<5zL<@4!yc zcKdBAdc01qYx=afn%?qAx2o|DyB^ow05ta83IvsO)f6nUh_yB`8>1=|d6Dy7By%}3 zEN}6;oNsC6$Em7!XH((P@*`0G&|ChM%2SOxOL-z%%3r)hEB`(ye`txae4O%>-OnB^ z?}73U`w}a!pZwZ`C8qqQ<<82CjAWUSIgiXx9kBS!AflC?_H0Vex||O#N{|*+iaxwV z{uF8X#M)K45p>@~&e6y}VMia`k#0-rO|3O%scb0R^ybbb`APy2qJ2)}abo_0j|h?aWpQ?dzS4 zua|z1EicPSFSrjqb zk&z7?hsuOGhyw(PE0WlZumJ4a%IgGhbr2kW%63Y@jJxPY};xK?~caY zZC9%H(nF`wq1h(;*fROSq?GM*>6gm%Kt<&K6uXbREIq`qh^?}q=3mmG(A!E$UV1Qet1oK z!S$P5Ge7Z>a*9l(jsjsz@5PCDh@qs@F5fCy(PQL8h~ecoDTWD*r(>guBKqbr@+XMs z7lm^sMNI_RPb@jPY|ot(njk7zA)iJJ-z;*)V8)T=k>pCi7%Q$8Kyk*mxbc<1l`G^u z$EO$ESUjg>F2hE0+_OJhG8N$eSs@>QLgcrO=69G zMrmb^+_7n=o2N_$6Gf%!$oH?5cjl%SeBVE3RBRqADtaM_? zQL(+OsMHhTNENx~ib@%9Y?XWfQN6cBMU{AZK2gTx4o~T>fthL=rp0Z{@zEr`lKit( z@~*d}7hF=hJif8AE0RRTR7s|06^*7nW34;BJYpMiMy4{S{8;&0ME2*oBIB$vnXYq& zl0lt{R3oG8x$Ri_eqVaQugg{?Pubiy%Z-i1#`hl77R=6_!3-)*;&I1~l1Ck|ID;-( zEq{P$4^{Y*N1J*Yb@iH^JB}W~7|$M2=;fAfWR_J*H@aJ+8{gTwsVe-^)$+o%=><1c z&S8?&Gh6F+v`aS%oo(qxyDFOhHf9NN>C6{U?*eYk-pfB=?SA} z;OKHVR;Bdgg4QE-$}+oV;{> zdcob*^VBJE{vKYZq}r(5>sTYNgEkLro~Jg6bM%d9L;3a88hHz}dAw$x+9X;<%uOM` zlG_Gzwj;;OPpwa{`NS6aymv$I(BN29t$vQGo(okSdFbP~UO&akgQ)r07JS~~=10p?L|J+u2 zL)r#BjkHp%st27|{XI4Ku^Db&&I(W8#H2#( zooiJg_WPCmiS_6d2CuJ*uF2T&7}hfQTkApn#8IW*HE6!S#`}+$dE&JWQS;|hla->6NhyJMCWj5q`7n-YOE&f<9zr(gTLJ6M>$scP=VC%6X$&SB-EZ# zs6fc;lmq=ole|qU*c_y&s3y|SpZy$aH|+x+U#p3l2b<()t?q zhsERj^!Q9ABiyZ_2XMA$EZjYWxiY@*iQ#PmvE{*5d7mq=N)5GxDlmWouW$sWdlk5A zY<#p2dtPD4gqDjPcrgUY+w#sfd1b!RX>epZfnKc0Dyc=WdPX$}c&1H$WR?JjZY+TG zqlB=Ej6Ie*iFEr)yZoybjjsDXo%@vOmU-M-;Q&x&y#2sc5+A)%KZkC6M_>NXfqrydy=i)K z)iAtEkHNe2`!!t$)rh?7AWXbUb~#_Qq5djW5?%KDHh9WDl~MDa9rCtK>X~1pl{=7ceVcYNkcaH+IQei#Abx zMjz*J?R=jq!D?uN65NJihr^=xp-$iO@NW6@BBgHc;CSy8s={64*nGe|-}!5ZTszg@ zj~8Zi+t3V|Kg~KoTy1zWHHPty%KIM0gtvd;zq4=xr;Bh~GTy6*syksHGhz*K4zLs@ zL@ZUXE~mY4%e(i;D~esJVF{Ppojgn{B-AW_%{Z8nDwe-S4~`UKf53?tYY8%T%~UJ- zT5S;KRD0a1b{7SYjr8fKKy3N&8Sc`a8_Nh_(-j~<>@Z@yjvk< z%enPAj4kbfCZ+zLX3IalRo-!us~E5?@j&I_wdf-<qL7pW7o6? z?OSRK$y0UNOe2K11c*2u=4PvcJ?%$jF=a+U9uaVp=NS#x7dK3Ach#aUK1&D)J7NsUY`T3nYt ziB^;jG_2%ed99z;^*CfufJ+PY(b_5dV+LQ>s%-qo&>=19WX`LZ_ zHQEpiH)BUEaSmE;8d?cKrzzo68c~Knd=u+E9-pq_R-mU0cQ1ayHRty~M{?{Hbr<-P z9#R6|;=ZWjqkFTz-T&3I-{SXNi{D$^oR#)dO03EQOz#P~R-Cj1pK`3ly%&dR9uvli zFll*W;lh&_db4mwmOe*jS-O3aOop2zM5ay1#<5m7WrmKPp&&Tp)ppb&V2&h?1x_Ln z78-)#SmY!KvDi3?`Do)1Vu`u6WoO$YVqUsIP>OQWkTh@BLY!2Jk1OOcbhA7kC*rJu z=P~MLF%H972rqp`&dP;C->f1U_Q*y6vD)|tvawsX=Ahd(M5mkM7Yc&h#gH6cQFRpd z4b`_o_zbOVkq~Q*W8uQZ3l~B3x+O}@^_2?p(g9@s6X*t;7ZP|N?L>8hWaVcokB!R^ zF_MKGETCJu*`#UMQjZR`D_RCs@Co`dsDBdqlr7Tye(j(T0Yk@QxlEFNrOO2I;qjy! zAK?lST z)=d&(t4(NxtxmR`wyN7;vQyk1q%4uQ*<`IQ5ra0-A!LCNwQdh31mrrK%tAn{KORO4 zpgiUvA41xJ6X9&??j@%$*@aX#YLam_kuVc3Y&%G?Qyor3v0XcHP#fKNv$iZML*|@< z9BZ)&K(yOWz9dR>Mhgo@pF~OUM~zX9hXW(hlv@tsO*1 zhbWM(W9?P9h^UWlD4H1EU>}Bb1$znTK_5tGU2)hW-y+o6`c{a2#+&318HbK}*zl9z z2nnR;aa7$v#+XR~8GFBWoU&*O9OK%tW(DarVH`NTy<9!PQ#Hz>(_6(VD12b4q>59B znJs(+L#yjZKPg3vhjIBn-x+0nrR9AkZ>1x{6rrdH6E%~A-9x^jqLI-kwhO>A-_R&F zy2QHU6qe?&!4CGuSDt(6O$B=UZMb`EjP^~PI5^xhIy3>_zQJxdr^d#x0nEhK>gv)! zq57$)D8ud#MZIHFTd{5WWNfAg2jdkL^}`(*?VqI6@QRAi109>1+)BrF;AN`e7=%qC zUTgx=g->!3XxKm0MQ!%j=z-WcRzr(N5o)?WHayxF+uA=m-WyvW!XuF3gMEf$Ba;)G zkryT9f!-o?F5ZC6aHN4YS#Q5G8M%?zSkKg6!X$|fRQO8@1320WJaeal1lc0 z(eZuu9YP{E`Ua;5`(i%V`EJFdN1mdf`?Oi@w9?b-D;k|=9`wb=F#MlS&QVc{w~4ZX zWdvVQ8w}SrIXE0kXk%Yd*!2mx<&N87-%00>vx(G&;~Bf6x?HvRQS8HUpNi8K4qfOd zcd4yDy2^|F#Q|jbba_{OY#MLMDL?pQD;9Gy^=u(JtQ9Rzr`WMGtj-tYji|TcR7YP? zy_TbItQ}sQPIR|BaEe}CQ>bpclWv{oh{tERAEz7OOV-$YGNO09->2=EdQaEXLN=aE z{UPg;!tM6NxpA@r_=hZhuQ}7x#BvPd!0Dl>RuN56G_eMcu2Xig;93vhz4&YMH3E~EqyHLCX zZVE!rcn-?AQ>EI1cBlgr!2|KgIhiasyvs zJci`M?PuK1xQB5cufU-mM0>%*I1mimyZ({rkTDeT@)>$I!n(?yW+6i4cn*hJGQr zx3RrZ2o3#^0R3bkE+(vC`Uczo6GX2T;xmMJli(>rr00)}^nj6Dl{?_6?EV1bpBRn( zZe+WBpOMbQqwrOXQ;ZKWKFPQi^&0V&Fdk&Qg7G27CmGK}0*U{ZjDKM~B~#Pe8E<0z z6yyIgE}&=mL<~V0`x)QPcsJt@8J}RxL3>Bx@))-;p2K(z;{%LOFuurGf;x!8H!)tw zcs=7M8J}Ym=+6-UX2xd5KE~S^zs#79x{CN$GM>aZ%y<#w!;A}1cM<;@#x}-xFn*iy zAB$gxQy4>xEsSR}9%8(d@hZlf8SiDhpYdVF zry0}NbG(ep81opnFxE1j%6JCje#Qfg=QCcz_+iFRGTzDf9mXdZf64e9|G@YPYnt&e*|tIpfWY-)8(V<1ZOsWb_ni`Pq#1j9rYAj2AFo$9OB_ql~{}%r4gQ z)-o0|Zewg^>|(r{@gt1iV0@7ANygtZZa7KH-^$p-IKg;`@m-9!Fn*d5>-VZ&Jel!S z#-#yGU(Ja1eZ}`}#)lYx%{X16{m*B-ff3yu;Xz$>FX3h$FThU}V+N?$+8uU66l2@L z$?hKDfVsnbY_XbhjE+t9jC2oU3#ek7hUM+yn3F*7Upd{_YBC-=qjN}@#Y z`yC-&Q?$JZv~P+yqQTzjz5PwY6MJgQqWYAOxIlU>76A?nlv9AI#;MYl!C3EUL;mP) zwYje&fW3ohebA z?Dh_j2yl9ke4{fs*|IO#IGWekpCG{S#NY&G6NkqzT|HhrfM9#4Rj}^8Q+v9@=N#`BCkCR{JsnLR{0N#nbyw0W; zoI)F%E^Wz+$PdhM)) zv#B|+jdo=Y<%Md4Re2qu)2i~?J3^7Fybw-Y!}HWU*prvnf#XtQ6O(y)C}Tr|J+2vX zN7>+nnCB!M(kGC^9?=u1!rH|rl{|B5 zZ0FxRt6&vxd}hw`33SLfvL{dpaA)&8YhFu&ZNhnE`aF7{=-x!5(Lh<$scy74T3%h% zT~*ax2~RpGKGKAKLW;cj)KovU3A#?!;~eGOwmKUaL(K9tt$EpOFZ8zZaB9Y^Agb!B zNIUlC&$QJD30TKBTMrINvqyWL;m#>7qYgE$^a@ zAqFR~b@|rq`Lb zVnoKGqvTS#+_O@ylE+F~q``V|T}iRO8Y^k5Wv<7w2qf$(yh`MzVR}(uMnW%x@|clyWNzbB3l%M}Uvu8rf{0=}^X^148C>iJ2yX?@;Y z=C&CGb5DME!a-rpW&GmhWkZite#=6Z!pdkv`Wwp6^V^TWW~F<%^NOz-s(qT3eMxDy!`#ULakxM&eU< z`p3k(Hcs9a@MVLAK3l&+2&BBA zzj*tNfiDkqb0yR7dY=&27$%_Mi`Or2tq|W%z;_7(IPLcg_>BFEz@JRNSHbsG0(tTI z`}jH`u1vreuV3GKA?``Qw=+(^JQ&63=Ldf>{mQ_1c>;Oy`rQq_RLWmA=Au8DK;FhU z{b){mIr!-Lz;tU;{T>G2Q`8Xg1u^Q1*YC4PWIOv27`}M>i2&+nG6r9U&#E`Ltap{; z-D%?qUUN%zn6n(*USZpLBm9!t`A+cpPzRdJ$csRKNSdx5yS}#XCzs@Qo$li`TDyJaK*hjyV0cOxX3V4}Qje@%3&! z_-;?PBR1(h2$H!c-)CmD48v)%nsj#Z{T_UWjHknI0QZjSP7Ixgas|FN&`rCLjr-mB zLlb0OcVD32^P%!=(m>TZ)rn5N--D0n#7D^?UUJ9Fd(k0}`cj53US8gXwmd3chOZL$ z&Ug#KM|xAd6kjsFEe<{kpNy~B!AFm$;fqg47x-4epWo6yh(LykCRw9t0#l{~Ua`UuCDa%)xgo z?!EXk*WKXzjK{d_XOZ&8$+z!Xj6tZN@CB2rix7PD7^~}(H(|(Q96-b87_SG)i$_li zlvR~im-#EJ%6vY*k1qX-wT_C43ZJj6w7dddxXxN|eyF(tpQ%|=rO3DB67k{>D6e!% zCrX1jO|*(_Uma__2Y;`8QLMl4v#T4#wPNGuhfiqvSnZa_!?|MPrk{%s$PE|gKA-t= z=1a9{4|~@C>dZ6he!BAZHF(i+Lo6!aUEUDR{&d5Y4a*;v?@K%Jx6yFjLo4%+|Ng48 zgPyhBXP#g8_m%S6{S99~wk6oz5Y8pe=N`H7*t3J;ec{~nN5f*e!pJ(U)vg}NC6Uz1LUNt4T zNyu}L&RHxnMW)R3WO}pGveL6MvNE%>vX07HkhL&#Q5G5vXFrE@d^2R^$LZlosE3X} z54`5O4L8AMGZ&{{l6I;0GS5}AcGqqNfl4obx->L;q*|J(KYL%XixgY0A}8-1M0KVhek*C`sfGST>L_u@(Zurn&E1p zbnRgz4vs~z)l2rhuu}>C2JIbQ)P^tgp7$U&qEx4$XP00`;6vZY8 zM`Xy1W$9jTMaElz(tE0M(A|=Zfb!X|=u7aM?w!s!LAe$v^m_N7K#UY*KfE(?;aZ>> zkImSWu}uBjf!||6^m>mXTDr_wtyreWce!H8&sgS>85z`WP?C{Kj1A5cH{5Uo-BS18 zBhK>?Ua9Z%3DKh>`f@@lLAa+{NL|hNrA(4ymnP`15in?kxSiLfoq1gv-H#}iGYtzh zk3{l_YiT^EE+2j|mV=~D<;G7I{w~HJ*r*9r7tvPWPm0q>pAYI={Hn`@kfMWp(RTx5 zhxXIIR1bqhz@i6;Q>W|N0nMa;IT|PFTsWj?Hz9Cqd?nT}>Vuu3XwyUimX@}SiytWME}9`+6(o??8ouJ<)Cd}!!Y-9qDY zL?IVOalSAuzefjrLM~E^opsIOT35;U2daf!7A2z~Tch+K;dBeRoGH<|XklFw>h$p$-}?2wgF>!kvZgwCaNM|%t1MypGaC^{C{h=s2Oax@Dq#o( zs?xv_-$sNy7T@kNJy}rFU@BSoHBp>}-P%Zhs(+z78FIaG;J~&>5 ze5}+tS(vjQtOs>G!QH+<3F^diI2yPq7Es>Cv4Bz%D61^1Dy=93`CN_yWIKxLl9JNW z$`XHRMOArOWo3DlzY&Mw%$+$O(Y9o}#25CD+Psk1i?VTu}K5lzk+8i#MK2Hfi z4@XrNxYgDc@+%e{Ix-zQh|7Ca94Y`jNV?WU$onV+9#XD$tg6;gHJN&6Xb2_Xdlo+g zIjZIagF^p^wJKUijTZid{2LKam~6`5iGp0SDgPh}ij1Pz)j0(}Oh=l`vc@^R1Kr~y&68;n%mj%|q47>ymhHBuOxod96~%tUR|r|< zBNqw;obMB|S~*b;;Ji)9&B}@Fhx21X*7(||OxU}GJXt$+;O`1~igxSJ*hg`jcI)8J z3K>+=u!Aj5wlwiKI%t*_O%9@^OV~lQG&)sB;gAWvTAV~nyH+RF(y`4+wKQ$lanTW+ zN>P|%hfUHVLECB5EH!u8G)v3f9El|l#yP`5(*i;4au6*Q-|8S*8lI`5!3dReDyEs3 z08#yl0f*>t-krTx2tTBQ#RPc(Don+C2T{ zqaG8s=rK+?Xpt7Q0azwLNur0iIouioVQ_@ri$sB;Zga2`buxR=sZE2u4vv$f(bhJ+ z@rltLb$W5i<@{LP@yJs`wBL~k3yY_r0Fok z92axAl5fE6vJ-3 zI>(~!dE(TfXFx=U~W>9oOyf z`Y@DUW=$Nh=Fc8^DOEfabGSW%Im|htRSa5>c2V;wuY8vY8a!N3#b5<}#w$N)g3cT+ z=x$=Lf_^Sde%u6YkD!|}hraFOqrKQ_4{ss&?rW!#h;KNJpe=t*lXuZH3E4~u()OAh z9c$~SfGU*GW}8b;%{}SzUZYXVVKi##9vn%m&ZQah2Syzw#i5QBiq)~)@rkPWZif7+ z(WSj3+!BmzKa7P2Te>Iq*;ctAQ~r-p!xErX85`HU#w6~LHQ&vYFM6v{Db$8Bv#!jn z!>Jm$*t8J`nYiY+!Wd}8n-Zh>y z?>cW9Ch2Ga!7C2oH`RJ1l^&?6Z0v9RNW9fA#iXFSR-sm1_jT{V9rtzTtdAU$|Glat zZAq~fxDJ2oReGdE-Hi$N5IQRUXj8N?)Eept*C8j?dD7%I>c9B84`WsjT7op;<}0Vh z4qb}b3^;`f{;DyoP2lgN4#VtFO6-;`zCgu}jlOe9t64FVU_^@fOS444Z7zBlv^t=A zH~t;MyI++c{obfoEe#?c-Rp8m+M*Q85IR-S-eG_7K;qKlC=`Ui1tfgUWVtoc2Ved2Up_)Xz;g&%KJg@MSad)#{p3mu+$Y zTR0+5kE0H52X;`m=7o<(F7v!F`po(k)5VpoJDRb&RYia~gEX~}=2c%R%*x}`GShth zNLk6x`bSmz@FUVv9M_T&P#WH}e51JOieJKSr$sgziD1ZCNJ9;!^+q7QJ4^4?72=Qb z1{S4n&{WP~GCpa}AVhgusBha*+Z>{`oJu3U9jjHT2}i$ZVv@!jH70CBduVrEs2!sQD=jW{ ztPo8m#H@i=*zJST*#K?Ku&m8ay-RSSbPk}7YVPDAlQrE?uyF$oe}u%>d`)5Y4fr+GeTLFRKj=^GjBM%W1xE?+JjvUCI?4IAST~lmQ6bv zL(!dB7(@--KQ!7siNoe_#zD9>+=(6n;(x_rX$Fg$2k9G~>KTf~Gro%XG#xIPsQ;BX zK*5KGz?$pw_eU!m>eTiRWRJf|l^7hz(Aq`?;_sH5^Asz(7kP}zh$gWn-}m;9;mEg% ziNXGZ%5wR7m74CiZuPN4r*@<76yz<6O4JV1PmG&qkwJxyk9e`HxF^)nhGq!PACePo zRBIca99XCfv>y@85NLhoQ6jK)LcaV`kbbOq$Q-m<^rB*DZfmUd`|^ui%UUm4Udnhr z|4fy#m!D#P#XC5GU8`|WQ|jq7AzZ06M4iUhA$BhYe&}iICC2>xIZe1>gU|RMOkiTN zF}457%Duy5W%-Dv(3gL3<3`^GBnU^$=psP5_FAQIEea*o2Xkp2#|?!)!wSF2&yjwLbWXD9e#hfvYAqLo?GL@a0=-7M zRRb{hLv89s#U59vv;au^CP^C|AErkP^Ma-pn6siaA>w5kF%bJbh@FC5Y}XX)`&SfL z+GL0>et2!?+}UpPshZ1jA_;e-(_2+NgOjNnh6A|lVhe%H2hynyMR%mRK9Jv!={fG= zI9g?2Kdn9uIU8ykK0V|J*`D8D*qL(RLSH8dc-R(DGLNVWb@x)Y(~#r&eTJO`;d$QS zY8RdtY-fq^e0YJ~OGTfbULN#{TKpbipI`6JpnLr2EAPg91CQ-f>hE*#e?o6RO?5@E z-jt^8WWB1JW-mZt+Do)6J{kyIPRpoE+ci58uBC<4oTWK8iv4N;5E~yK=pO0ALc(5= z^CP6T<`$26lc!ehU0bqlO`UmNF8Eak>|mn z(P(lh&!x#bZ7HY?jqZspd271-vWwjnSvO4vt64Nwb%u3)A{}oYSi0(JcCLt!%9)r> z<_#J0JMlpe6Dfzp+~Y$gq^Xcx7Iv#EYF^2ZkHiI-BPLOEbEf>W=QwqSDfq5M@take zP?|-}{h9I=&uYa-iM~8hImL4zYF^8fpYi7Pj*cB9eO)pW>6GBJ&d-8gM8+npSKGwuGBc$86Gn#s?7IyFK1C@7Hi3pS<5wA8PIlMo%jZV1PG+ z79EY>_Y5&mj`0cJ+c+0P0m19>N`KZGW(MBUp;f79(5^-pXFF?`%*vWt|$e1BeVHh6s z@NyH)sK<+_hJ>GZI8rRE(tI1G&Of8Jo5U=@b)@%xPS$OS@GmD4-Fh_CFgA5201Mel9zuNA zYkb-o8X_SpM8T{eb}aXEEEQ!&enCELLT?}V;uQKXu(oe+s_o3joA7}`{FKm7DUyQD zG=(BdZdAS-eV8am2NmftbY1cqaMA2}T!0c4KudFlA%5N0MFJnu8g$kksRp*RL>ioY zvM+%K6g!36NIlCZNCUhBu)i{Y+Fv*wD4Z@SoStQYX{00D5d*uCA$Cxf>LF{s(j68+|Y^IEB1RMHZRrIpWBQ zQjhGbDzemK;zTL^ldJ#rgtoFRwaH~Fr%c-f_a-!fEu$y}8TZXjnJpk`ct<`wQrXf4*h)`q^g$sy^3*tpZR4xh>L~dCwC~k;YTvvSmZlSy=0h z5&Ga%G>Q$n&RbOVbb)hm4v0uSmUF@e|s_ZANg9(ufQ}c?J#M6kJsOdYuCv> z6WJgy_hz)JYOddoV?z?`RMkb=Ddc}G>}qC5ZN2b+RmdB>>Doo_SbI>&k9+-jfAFMc z4UG?WbcOMrUEP|qL}Z1r4`B>L_hIQ-l8_ay9S-&NK`OE)i)`Gctc30BA3?tfk%xLh zxKvR1tEGG(*_XH9I|a-AZkA*vmajx(iR-NW*Gl;qc;1vS1<$!2mzZQFo`<6GEW!7l zzm)PB@O*75p69uFl9hO7%E?Km+t2+K9{FSN{Jt-Z)Cv7pTvHMoWEGczATI zeS3c&XSHWZsusMvAFIs0!Je+s-e7NEk8?=T$4Z%qNgk1y`&xgG7niOB&cax{Vb8Q0g%=YK$%$>v+A5-~p-SNl4 z_x9ta!B^#WbXiq4?nscI0?$89ho{Qa7(6Mr9!ik+fahy7{8=@H^l3Adh#K{gvuBAX zs|H1t+!DOso&f`nJj_A`rn+9{^DIfsS|8T_safm$wP{w?`d)2H)6s_edu^Sobl^kZ zy|a9IFQw$DI1gEIk|{yONv34)S5iL_TH6>O6!PoQKE^H{B@jU(s7b0TAZqE{naP$M4b1`M77&Q zdl^w)O+BEi=P7VP)oG5>T zNUoeUje@2spVm}&|5VJMPn2(h`LCzL+)?6UGDlA&{6$IfT`=E2dm55Esz_|+)Z|^0 zBrltd`j<8h=BoQTf?BBGdOb;A1KuyBr)Bl^jWvaEtbpkW`{B?q(6vpZ>DJPdg~j)_ z(9Y1vXvpdA%?fwy>hJ9xKuzLCevKmR=)zlV;eR2SiozI3s55OI?(Ofxu3!^SDsye< z>KVh1S&n^{$W|uRiuOQ|;7C_*|3tA}U{vi}n=F3->2J>XSCc+M?$QXkeaFc+A@{R$ zj*Z;h+Z_X~N678eHx=`59Vf3!Lj|4tFD|!J-z4|=4Ebru{r!1!j!7x!4*$LDJ8O6- z)V-T4o@zt6qlsGNRU4U~A|FChZkzw_mlQ{?sH7Z9kuM-AA6+oHG}$f6+?mv|gk8E0 zz%7~E4K!KX#6W%sMI zdvRt~JBDw_7x2+jZmVRG{ottK~X=2eapa9kmkMb}=k2tf!ZK|NHNRN`xjx?3f-k!0@cIlZk zd4=DX_c%t#@d!g>b+k~{7>J6ATNo})TA0V3!W@8ww0`C6Y=3e}6oJ&}^6Yf^H3;;h zocIJ%lN^UYG$?ZmL@p@aTAzXR<{4<r&@|mr^62tF>nPaD+>d!@$Sx9UYf#G}*ceWAA9l-FL;SFFkb{ z9+<4M&u7TnPVnXZFn1bJO{uo%QIY26%#oi*RF5p1MpRR3FKSduffvt__aUmUJm7mB+ zIYlN?M}e@p_u!5^#8BK}mv5D<;PLWl#PFA66vHUy)1l#L5j}Fe{1GDh`SK}~q85Ve z8cS9#+fyfn7KrlZ%9jztBl)fv%skRmNp1v;vLadm6lZ*k8`%h4Jy$-w$d`9Z!IYf2 z3>(f7b$>EvD!{*)D-VG4pQq*=JA)d2l{>s;j)l(8dlUv{FY_c&F3O zOD6r%qEc<-C+5lfvV3_@7ET!ztH+9p>xLB-*{6((^ySNx48c<^<_n+YJ?+I zWS=T3rND5eJb=-RU!ISaF zE4v|yR!kLV>Q>Qd+AG$2;L9_%0cT_?bIRt+-y*Ur6nc&&8>uBz$wsDyy7QeZn`*-ME|8Zj_T}ALF@;Lv&ulH*ESGE) zI?a-e%Euff8=2Z*(bkY#eh#aV3pE`%7~{CMpW@AfsQPI&K5uc;BWd)0V-h{yj)==0 zoTT~FrV8+{0QpZqen`03=Rr02UrL?0%4ZXlQS!zLu zziX>#G7e0w`u%D0!GvY>rdTx(Iz(MXn!C`DQ1$N|3T z=va5H>uCrls(!OZUY>~LwXZ|^j*`dcYvql^<4h##C|SHwD?g*fIC>sms*_(+V$`(b zMBby&#hZ2VJFJVNTyU zlSJj9d1K8qg59)MUY&%^iBvm~V5&Mf>X#}9*_>5QIiRh2a;^NB3WU6lJJ5&M$vd@x zO*Ir1wM4r9+4WG{=_v5XR!vkrwNBn^g^#6|sTh2uQGS~l#8&K744!F}PZSWsH+T7e!1JR-tC0(Q*jQcseTt3h1RZS9)4SQcLTt|SRsXqJ-hJ{(Bn>_+9@(MiXDS(uxbG6u zH+BQg^Mo6_2C!Df=I#)76Nu`kHps_afmLd#A5?(>6nL&9Fqu{0&hW@^FV4KelnFf- zTd*+%$*cZIi@Z8l$<#lzGm2a+2+2lruy{r^FnFa!es&TAhiuG%dRmwXbm?`nmD~)r=*fTszMp6CkGv&vZsl+OVN0O2l zlC;F|kgymY!gmLXp;6^z*^LjbAFwr!MI+Mq^=1z3UHhQ~y+?-F-Ci!C2h^_VlZtSQbe=AxL0bOqV|*5%bVZk1OR zxJ1J%T<&*ru&fYOvfPCuAc`qi?m|5|Qi$^bM?)+noN;QVdXulkhQpL%k2uBdq~M{U zUR?`B^<8JnN8F-ot(QbE6U~eA2l?8|0mZ@8_>c$`m?%n9d3DALKV43buPRjOQTv&B~ zxBOn2>S!XY?1fN2$AXh$M%y>m*4DST3t>CqTegkO_?{<-BZ^wu#KpExQ~iduIEP8Qf53Lv zhod**+LDgib>br11E=}mL?CgY?b41fGdDKXw2AlIZXNabYP6xIu?Z()i3`wk)6_}` z%%ucArBV0TlVMISZpT>&&*PN=m&eadftS87XI_fX zhD>t9dD#dc78w7cG@P8RDag2x+{v&gMG$1o1n0)NmB-->QEe0=VBAVmg;;DXDJe5k zQo%ZVwi0tmg@PO(fV6)S8E}vxfd|}9Rt6+1H%)mg%Rt0P7IH9;jAS@PyWx1f3}kYC z21LQ<=ot|IRPrfJ)%1nhLLrKbJE~}gB>74*1ks_Yl0k^F0)$*SyK44|+1}*SQyb@M z-ITkXwPS_txR&WEZ6_T(fLK?!9m#2>?X-3-IaJvWIv}RAZYLpD*$!)=tJ7?&E$V8h z>~yyW2}{naZD%bmIo8;Y4koypd5zmcF@bZf?aWNzShomDD?)knBOmIuMTiF5b<6Ct zW^YC+*J>wYT}RAJxJKJTf}P>8B8v6eDnt_*yvfz6rO2Gqkz>ua16em54}U63Eo8t; z%DJk9>MRxFOl_sCZkwk#QMqU*BN;lhn-Cl4snWD56QyZ$rYh@ON);#1amzt?ma*W* zJT^k;v$c^3I<--V_Zdox^BiMYKAWsTwkDG0Ty4=lUD`tK7#tO)=~#P|5fSy0fuaeK z0cSG!6l^1)ioV^)vf}PXHX_t{+9<>h<4ybrj77&hXz0mrh!|3R999PK2%8j;vd`C+ z(^IQq8PS%7b4jjIV-aGkOx57=Dy7k#t3)OQ-jyz?;S^$`nhj92dXDz`wkE9 z3XRaGi3P(5wzDrZINTdr)i*rS6Ph6!hrlEN1r3IV#zt2nGm2J}_2gru@g9_h`wg_t zdis>k$d1&8y2rN>#z=Khd13MLBHVKYnyHgcr;4sRRi%5^@W>9^gpkON-u|8ay`g~n zvbTcaqfb(e`zl&(wGz}5$RD0=F7$@NSPhs~=23BqREtuCrH4R%3v|~q);}1Es^&m` zqy7e*zreQa5hoNo-5sQzxUR7?sLNJ!A&P!u#KF6Cq(djh(w*w)kIu4!!h#~?`p&Y> zy3kJSoKt@A$I&e27VF7ObXY4|+*Yx1Q=__XkPoI_gz(e_{f?+YgMGN|0AIF-rj-*tBYgp_$Y~6FO*PlO$(AA|l* zi{2|LUEwQ)*I`c(ZykOIy&OF>QNWx*yza7llpp=1qL1||D(!^38em6D%8&L(OU;k= zPcl|@DzjJJ#;Tp_0A7J6o}U2Fi(3{S;P}az2 z1)a}lo^(%%nCG%D5Z~96PDPUL$r3lZ?AhXMmpxCM=(5ihzqE@y(z8_D>9QAyPM5t{ zWV-D0#dDOo{G@vpiG42nV$trhFB5ZI_T$A5OkiNT=OpnlmwmbT5bPA>PW<~(zQ-K? z*^tG-4nA)krtE?k;&DQhg#(Pw5K`Si0CG=YY-WE~IFvyZ4yeLm*rme3uEGITIAA4( z$5gMH`6&A=w!)f3;TS= zMT9s7J(qAXCTDD~COjF_5Vmh1T#R8j+dJ8QF5BrF@pZy7+x-%@GM+i1fV4sLDO;X{@(17*)A|`&(=``n!eo@+2eOlSlk28OIr) zW_*cpG1@hvD`woycopN*j4v@>gai`(FBt#CczTj{Z)Lod@gBziWt@S!N#Q#f`xrmK z_#or=7++-cqranYIgHhe7clN)Jiz!Ot*FZ(#f)<7x>5&f5!M1#&pbDDcrS;KV`xh9GN1IRf zJ&dn1)}pN^_lp?sWqgfs5!!t6zk%@?#zOQZ zhZ4Uc#tRwuF+Rj7aj6l}oyyq2*v7b(v7hmB#;-CSVEiHDON?(YrUo?sWsK#Fr!jUg zZe{Fd9A&(d@pFv#GCsoi7UMgNhZ)lr>v+o;s~Bq;I~XSzKft(`@neh+GVW(Q!1z-bU_7c!pCSkKtZcn;$p#=VT!Fy79%pYaLCXBl5+^ey3d88aAj7^@lAFrLA9 zHskq>yBIHK+{btq;};q4WBd-|i;TZue2wvsjJ_N#-y+5(jHfV`Fg7rr!`RC>z&OTu z1>^0EpJBX*@oS7vFuu(ATgE>yzQZ`$Kg#$dW6CMozn1Y*#@{n0F4z89jHfWJVqDMI#&{*;?Tn8x z{($ipjBhh~@-_c7#yZAM#xceZGG5R4Nyg_HUuR4!(EJuN7BH@6+`!n$crD{+86RSN zit#1J-!U#dRr6oP*v&Y~xQFqhjCU}8i4pJgRl9f^;~9+UMcRD6V_!5)XHNpJl;Lj zHHc%O3T!vL@*WI19cWLM(~bj}hrw?5pkmvj*GWYIt*c@sHMkvniLmiWABwzfBwWC8 zb#>zw&7B3?Mux}31;xRdK|235IM5y5zP@p6M<}N_NDhUCj*#x9+8zouP9(vmGm1yg zyP&(JZLBP)uMUX_rQgpYz^?6O6kvSqcu8}AsOQXq!r&Hl;;$osMLaY@%z~}O8JA!T7se*NF8{gX1c){-8j?!4cps=1E6{fz4u3-p< zTF(dy~K1e5t zQSs2_3+w-)0PF5!RDO1jZVy^!y04hr#Ts12)LUb2NMgHvK^N{%ip zInY@=rNyn598-8Gcs!+NQt)1^Y!_@-!DHswq?*T>^4>(Z3o^wXPf3mtUf(Wh7i?k^ zPsxtTh6_6Jh^M4S@Q7$vh)X;TOB614X^5wxVFuKo9&J(Jut!x6R9IW$X_Q|T@~BII z4js|1O*8u)JdQ5!6@&Md@fHhPhwqd~cV+D~+h4^XBA=((_*yJ%9Zn+Ibda;m8ggJRG0D^P>7|psFzCv`jT)1JsOGCOhI`Ru zcctnTG2El@R}+VvqLP2mkglV#Ip&B?k1_w@LrK>ta@w!EV-119sFVKr&3PxC8qq(B zb9F`=#)o>w`f<5yXT+`*d?(Tic3lI#bW(2)zKk4&s_X|n4jr(fNJ{ggi zdYnv`b3F58rkpS7H4@$&*A^EPuE0CB1v1OyNre;69L^M330PL{wX~YZ;Ao5!5p=ZoVGO!4 zkD)u+5r+KM&BXf}L*(!af?vABeE@WbTCBi7mbX<|gsQ}uCSD*tW1tHtlm0RB()(y9 zzZ*c81`^_jWg&~7l@8|jY0%wF5%XjCS^8tTYP?H`re`aEnQkBGQlseQ_h9Ul?^aZG zBOjIlW6JkM&>dplBw{T2KD`jS<}^6zBIWxX=$?uq-`6AL`$oW)Z#fuJUeJG}{+<9` zwET_K-|s-T58=&Y(h(`&g^PuF%n$($9ldLI>Th+nEnhz9V#(JEx`R>pMaoyWM2M@S z&_&AkAm|>BLbo|Wz6+rglfQ+ak0syLpt~{(zexG!V68cx^0ysyUyQ;pFG9XKOR;Gl zbW}gE>>5+PT+khyVKX%O5h-7C5!wx#%*wY&{cQmq-AHF1!_R6rxUAn-hP~9r6U4^& zzc4$?!QaYlJuib_EIp@I2oXRVXdc5aG9AnDzWxqF1T=J!>39lsbtN{Tp?efgPWjSC zZ29myAf|i)(52e!tavBM2fDE+bdmDi0XmC`!}uYXo$}o=YPY)q_!<30w!5DL-KWtf zna8AeHyn(a{F>n4$X?4Fj-YD=-IWeP!(%(>9L=5h@kJS^dA)A0o8GT~40rc6P15Om*QIx2^TUu1f3zSP#=EC(H$ zMOS+7aL`eCGyEdu`yA+ue0V({lkQ>A(S9pR2VSekqM64NOXl$(4}2#r=!$CHy>s%{>_sM zx_dpwX4hHD8zDRE^b>{U4a{7z@zQIcDr7MFqpB7L`_(ttc(5 zs4NWx3Ip`$U%c`tFE0-SN=u82E0z1XGcK-gYQSe}7FQ{9ExzQ~al7*JQ94l?#3s=$ zRzDD4`!N3B`I^rya+~e+j^IP(NoIFizJG1`y-0yyS`0(M2 zNi#nDV~8o$35X)m&}=a_wg@t!Y5qdG$mZc&Z4_=B_bdV*bjW!)>vD++m~h|VCx zV?t6Zso-*Wz(lBmG@zJA4Q--n>;95HG%*0i2AJxVT zpU*pycoKZ^1$^QvMKwB~s3@=|vQ6_9HFza%OeCV@i%syv`6_5qVk5CiT!3GncUNM@ z9MCo;W_Tp^8I)@3M?B&pg*4-UIY78yn=1())8;vZ2er8ppq?l2OYMfV=ixWQdMo}D z#Ptc+Cy?nj{CmW8O#t;^b}ulKMW9VYOx`f!S3RltC0~SSCGQ8=3{VgGXX771NTL_D z5x?r8X-PHyrRXq$VI;yAv@3qCCjllY+6Xwt?IsXn-%g!BqKDbBR)Fp$om z0|K40&4!T_n++crO&E!{EOj*<^}%2uyCKva2owd13yUhU!6X=@7a!zNRJgKe#mdrB z?b_Z^R|{8MLJksT;g12yaRr9EE1Hy7ecf7%jLbF_M#L6{I-rB@EeGxR5M5=DZ*{3X zA?_5cwWF=Bv7tfTZ4MgaHHw>EhWl_P^;n=((XxYTgIq4*u@NSr&lGEo9D%aJ@8an8EU!C-r9ueP22Jnp}BH?c&DJ+ck zSCTFV*LRXGAL~m=9XZkgE-VS!SleXjoaL)&t6di?Zx0$`r!%p@HS?6!S^C9rYX3m#J;_Ya82f<1;dH5RYv6o8*%U`@t_mnB^8 z-RrqRZpIgr-+BDI)OzSSHO-;1#UDM9lqo^nw@kYZg4+W^rm7dbwM~s{Ty?3iXoZj& zK~ggcN|351Zu^jP*dfUkgqfq?-b=hC(F$f)96bsPIcV9AoeZXxHfvvzgR z;QDnTGc9Jh6Uz`seS2*UH61u7RWU;-xGD)8@hwBh`S^C3-D3qM3C3fEUl_#Q;2YM` zzZ&A`agJP~nm{lP*45WGwFiXfq+pO#v!Pwc<;Do5je@2!*xa}wkY7|>DdZUJ*ovqe zN{TDW;WQ2>6g+au{XpSFMW22k{7(4bx*77ZQs*RL%07_p*74MA2^1BhmA!zYft_N3 z%lkPNxD*$aR+Ltjl$XN!LXHB?b`&d$i%Uu>iVI81E6YkND#|JgD-gxSq)4QNIFywM zxkr)%B?d0#Wo0FB`=D~8)WEH@ctt6uqs1%A#)Z5@`A}+9R92=GRhE{PSCpb}D5)r1 zQC3z|UQ~w2u8`o33WcKLRNs}hbA%Q@Wcx%{=2bR9oI3r89YQBtsrDM%mDA1|zSj0& z1vnMG&-S&HpmkrH8(rVmD~(w?FlxWS;p|rajSin^S#XoX-;&`-8F7n}yTQr_XZb@u z-D-Jrenj~HhvgqVS8lWXByItufhmLDs|nE{`&Jfq~!r!7xQF;i#GXSFU_ zFOh})bG9!_;;IXux4om~(-&-SOPV8P(^n_~7&EEH0!FQEA-`$4Lq>MTiR$uU6^9A{ z58|#R5%O^gflA8Fj@8sUnkLik3=E(I{I^99MvkUAN}*QtPpOzy1nvOQT7q#E z2B|4@r0$2dhdX&M$o9sy!J3Yi=EmA+E$dHR{s`+VDKEowD+V!eb|}X4Te-P*U5(PP z@VsIyq|DzN3#7xi>JP>W2HYH@{Zi#_M`0C9ies+_QBcNm z{8rIXoxIA)D^&QHG%CA2U%?uuN{H}$6-Lwl>IF7E^RB}P1tS*sEIHyR6dHNgcCP6k zqNSJqp`L;9-cTowFj6C$g6(R=qtDW#Z-#m0DJ>o*7K@`jpJ&pl6OyBz1ewTlp`Pts zBVx*v@DgOQHFIL>B+FrRJ2qoYUb9KIDeP67Rt(uHgE*i0Dj_QaWJ7^~_2WXWP*#)! zSnm{arLrRXVg0<2Re{!V6ZU=~Pt#T%_`5=$uI)NB&XruP?K=3YLe?m5IMEk3eVX{! zI@~NN);Sz4SsERVmPBXhC>%T?SF_X6l5T_3)snHr>1s*Zs^g+7NtK{b#YWpnvxM6w z+szVlv+ZU{xrHOK_(3^mJKQuwICeT5EfL@6aI_>mM@541w zy%~J~UQnPUQ6+9_+)xjP{vp~6iULE!=9&()$?Qe9SoQZfC{7CoH?&}zE9Q$d=*6v{ z1Eb+kPcCj13yqDB4568+!H~YazK-HCU-4ijkUKsa>ZK7sPAl46U$Z{adsnDy2YF+0 zV&jIIrpC1!>g&|hpae4!w6S@)m`sGbdUjwPf(kXMJCL^weiZ5qBu$4Q;)s~L2GsHe zlR_DE2$K>}^Ai&DK<$R)w{5KL00)i=d-ZY8fRJyaq1({X3Xh@Tu#kU+b#p@_th@U9 zg}l^DR?_6IKB)03SljD2!8#h+DdhFAHny+HT^8sa4!oaSd$xyq#|J_ z=zfNJ7_Z=+k?wv*FXrP{y(;5lve2_cc~K_i6L#OiZ#5zVx`Q3FF6EfK$f)|eltZZg z+d^YlSlQ6g)`C@3wa{*#QLn7>EK>ir+To!wd~B#mWUHwDx<_7sDL+o2x5MkpVS1P} zdcdkbdgNYecqrz^*7mk3qg4c2j#g21k5_)w1g$wzP(@$`eZ?zpGeIYg6m$y_SV6y> zAirROwzgxKqI{yOsdZ$y2geO!<8{xDRw{}3e$_Clem6nhPs=2vGsQ^jYiu~&(nkSR zD52Fh6{D($eR98%sQCyIHFxz7MHgppqI|}PqqsQ4u|lypmOV02Ro_jNFBn-`+Zvl| z+SeaJL;cNNqdRP^d@xD=#)x4t(4vG#G_6sIJ7m>&ljPgp6=)RJG+na!8zpEA9 z9{eJ7TZWkz?a0#80S`eB%OtUG0U(7AT|64nvB`1h|z8 z{;D%v6U9G31BS_=6x-_RKvDU|Wq}Jxs!1^uV?>JeOY_o!`&^7N=zW74-4t#V-t$!n z(tBmScuRK7%Mb=t!JffFJsFx@dK_gy7a-{QL8Wi}2=kVHQh#Q1{g*2_N`q?cd>K+e zdsC_G9FN9!Y=q8*rFCvJy)@2^y3U3xqx_!cwUh$ay!LY{efSXxan5U*#WBk_ikqIu z%>%9U+Ky%-m~t+s*9~emz8pyV+G%e#eZN3?1C7#`cPeMF7#}ldkRxWHz`0Ogc!Ufq zWqfh2bBv2d$7s$`Wx_VJ)^Dk;Z^f*^Dts<+tPtx=h)EN#Mz;@2X9J`$)3O#j^)ANI z(zzXNR8t2}nXKi8yk$#i`XeNEPONKW-=e@Nf!s(E&f!&v_iF~s8AU*x)tYwLrX@Tw6lbl<>m*BCC}!<`R}8yY(> zLO}fQSR_p#QR^VR!{glpp-93*SWna8VzK&Pi3=qH=m@N}uEM@xMMJGR`GWNEH>nbX z3o16WP=WYA%g%X}g^bU6@uG5TeOn8 z1Gyz|`hlV$bJY%a#R} zB0;!vM;8Igox+J?%evAE);o=0(94GstOVd7k*0-k*}HoxZMJ7IBR|MpP`G09JNX;YLzJnapb5K4AOswrT?d8XOC417o$*8doY#c z5!4X)KUv^oT#s}u(mBbj`yAEDv|26#+aGd$6LJl8sSaT3N^ROjMIKS8Gy`yZgt!fl z3{n-tx}a$Vrfg_Uh)AA>4cPuS*p7oQj;adv{xb?Jov%a>S67kuTXXxC zcf=idd7y(BJZm#3o<`Km_3%>n)8OOzU80=?;d#ShYZac~+ty;?xod_!O2wETYiStc zuE8&+SMIfe_!a^5nG|a5Ogk#+?C$Bj$Kv4sfYE+}8j4_ZaDvtoCIEW3aDx2;3d>%i zRngHz;7WRpn%=6($>BPBk?K$P-y+Ue6M)dj$o8(GUc5-yCj8$=YOC(>$ZO@vruoo= zhCU$?A_we(LDzk$w?Io(&w1qaks&z1bx{NC@ybuw0jMjQlK+=z`OuOG15uND8CaK^azo1NUS|R zZ9A7-oSxzEZj#r5Yslib8yG@hD|RZP}KI*DE6Lf7|-+l{GD&|4m(d+}F? zrB9p+b!ioo@{~G@fV2;jKBcBLjvGB{BB5rA^m6rfy#3QJTCTGw{StBe8N*#-_%hPJhP+-6TAuZ=;-|Z+c*}LVSa+0 zdk3(2qmDK}V`UyLdhAfrAmme?*2X|dK~ZT@*^1(F?DDHzQLzH$<@+Am{G^5HsKI(i zkao=k%5V~peBR-QXoKzR8XGz=OT?uyfg+0j2TlTqhM3)!`6kO?ly(a!k#C?NP6IODO~J z(y+a;xehOZX^%SXK3DI9&1+jB@9^pj+PER=yXYbFHu{rHXRXM%7FfClc6IF@<#iaE zihsw7I2RXMji~q1Zc*~`XojhM5#Vtv0KH#p?=ZnIH+3ceFR~Rsg!r!4__Q=MwAWi9 z@+JkbV|jvODK9nr^KzjR+IMh+dC%k-+D)1RZORRsx$_Gzm^SEf7Tlik-qO zqmku{BmwpSoL`ZA|_P#S_TK9idPd(3ab^TpG>#L2JZ$cUi@pAXweV#DC>WGN-mfBSAMZZu$nxWl>;V;7 zd@*sNl>D*9|8`Ve*_t}Vr79;+TLt^0s=(%v9|w=eC#TG25Hq|ZAD*jdYS|pr-$QK0 z=AD)eLEOb#--dSbCsDk%GWB-w__52DZ-;QHL66{pfMcOIke=Y24W=Czk@PAdv8@%b-MekU9P{@ya{ds@z zq-G6`4|a5g@t(aAAw5e(Rv7yb#xQgrmYyXES>f8@P+uRUB5N|fF#U;8!uIu#px=bZ zLp`D3`4z%nE#(8rzP$b3DOm1zvm`6Ad?gx7T<`6_R?5e~^QMF;c+T~>#3U>6JQR&* z3BEV|rIgQr=WA2(JkQOOti&@@PEI=A2Jf%%$RC5}_kC%kPUvqNj#yV&=TvC4)Mtf< zN5|T?_xEvDdzPeX!Mpph%G?|5=^E_~_VyJiUDE}Y!vA59eD^qC-ouHm$mq&+XJpaT z;*4yiqMtG{($*o5ynKc)?-NNX2TaN$Ba5mprK_mPP&x~F<+b4ar=(=kSsQL3w2L4d z^hNNxOnS1yb#(5bU&W*KgN9(Ff5I+;iswUKc}t661?A@0fY32EL32s>t#OAlEkd_VeOxqwZ31QW@WAK)uuEZZMeVJ*11Xt zJ}}-p%a`|3N{)*2kQFDH5>%XIO7?yw1(nhf=jRb8VnUqcpQ+*`(?S&|nF7(`q;y{4 zlQ$sF@1^QEGtrLdbdpKONv34)U8$(FjyM-3nmEZ{$4Mp~Cz+zfsmj)0eezDkdCyE# zyG^v05#`m?g9*q)ffKSO+Oe@zEs>EuIV*gYU2?gy(N^3pYCQ2SENm-NMKYWye}hP_ zoHdPt=BO0i{Zlc2K2g32=D(f}b4Q7b$s9eA@E0Y?cfoxB>}g2us3NhMQR;M4n5*tf7ogb8(Qmz;B(DMQ7t+(R`ufJ2LO9vL^o0FzXc*|)Cen0k>B++4ds}E{ zXk;|xboXY3J9hQ=_70#XaU;J*5q5Opt+w#LkW58k3?$TGyc`2kC3}GLT=x2@=eJ7?3`mG zH}`hOKFC5$U6gGP(G-;Vf;t|27Rh zwv+3YJ|Uu|w>*4SGu~#m<9Zl?&YpXL8pU081*w+f8rv}qvnmvM;r}j@IR_b*Gc()& zs1|;NntFFOEuSSn3*q;i_|FucTGUCxlcOd4WwW*LABXUJW-HA{2v6Dl>MZ#%gnu>= zU3gvd*X%AfDZCj7IIf5McghK3H42=L^h&_=Fm-ZDpzMU;x@!!tXR74MNW`6hUOGdnYDgJC1G zHgwyX@nq@ub=bLSMw=!U9Rmtr?eHiMBUGG7aGNSos^o@Y#I#_xt4-? zt64qaVId~aG~H72=<-18DA>x}k9lXvE)r^NcadNIbv{PDOXG}#l#FcPI8-J~83$F* zm;G|@0$<*xC&w8Fcl;a&*^;MmcpY&x*}4j2?`X)~cg3qOJ#`u$n5?qT zXUN-5@a6q5cN$SmskZ1*k>=*ik)KCYk1U%;R8wj%YE(*r7tfLRA*!$BxmJ91Pi3#y z6(6s%-;_9&|It=_P|x&IhrKqVR+#Wg0gHp^dV;FTy*5YQwa}M$!zr$npU6l#MJ7^5 zfv~yv;C?{FP~2gcZ=OI9x1 zQzwNMi1Oyjml4Aw`K}nuJknH2ZUl_7B3c0yXMBqr*$7-cS3bPRmv>9Sl$^N?8_p4R ze==t(z`vO*4}kNZr{)|xgQ?}3#93wR>Ur{ca6WjdtGve0#ttL2Qb$&Jr_;_$CjHT( zQf=fX=E?iAe0fh6P8k)e$BK&Uh7}drr;Lj9<;#>0A*%a}ri_a9WkscGgdS%c$xXkeC_2I=KC*7#_VUUB|uro8_|U*6><=t8_g-YVjY%SX?muwU|&617E z#~dXandZinjRsKJC&+I=w$D{YDTpYrW1+^O-q3^@31ej77;-q?O6lr_Qxxh#16{if zIm!(xjdt?qE`*F&O{4Ef)o_j)uF-H87V#qT^4llKy-R#~53ZP|OwsfA$TG#0M&(}H zLU}!;Ik0k?(nQbE_aY7D*TIGI4oLIks%c6S?JZ(f9QhSnH(0YBS|smT;;Xv5TE5|3 z+B47}4yw1G!)oM0O-ByKIIiudc=I5tep-#sTioQ;6qeBuu6V7f!Q;;#Xf>wv43rqyeVNR?dVWLFK|wlS`gyz+A5li z<65hJf0}$SVHv$CR?UM>ta=AQ^f;0?$3NH8J36KiC-_=Th`qm(Kd~Mj$K>^p=o||T zhVd?gzqRhyHI5qf&VKX#HTFMZ<%!>Qh^jxHF8|6NhyJMCr8eYxC%UWVE;J-m{X2(3+nVX@VrAhpimK~suo)d6 zpPgA#S66A0qY^bCCUa#SjwlV{#W?9v{i;q&RQi|BCn9<6>yW;q*Wu$CUErF(PYP;>gBIl4@b%23k~wmibM0p_PTh55LGWX$UR9^4w^UC zOe5G$Yvt8R*qlhU0|}<8lcRpAa*)kg<&*>3swdaVkEuY&>$n4bc%8gc3)oacQBg~z z>z`c@wVh5Qk8IUM)l=)_y;k^GdYOvBM;hg~nL%vDPQ~DvM){PHpox;uA2kW&8j%EY zg5LI>A%AK!pfpUE!{cYj*E9#@attL-R^8vukbmJ&?eT}Yd%e6QnM%}_j>)aUBws%%k2*lwhCuTf8lmU-mo9BbACM{0vfGiu zE<066mnpHF*OplIMw9%=(xoOijj?p+F{py89@G(>`i`!i9_o}en?pEs#Q&17>b_?A zpo5Lo#owpcs7}zq20gu-%`3#_JYV&no8{dnpG4B&!{U)0dVZ#o(TE#9A$?;v;5<*b zv1WtbFl>*Ly)}c zkF?0EbCpc}Lp!6$#e$G*BnOLUL<56YTI6RZF>uJn3`joBK#9nrc3a{^lkJY@9 zF@^q#Y1Hy@3{zM2i4OT{o~p3!eJOU;U67}%u4^<+HCIi;JM|pAQ}3_o+^uHhox7pp zOxfw&YD42yY9u=C{Whp&_as(*Y@@vM6jkTl64iP@|Czf{Ubf&XbLxv;P3%czjGIo^P2I#K5UrLeM1v?zL30&s9LZyHH7(& z%KL6bgx$aJ-?V%bcbsrvGSZ_Q)o{YT?8KVl>|!p8iAYzF?QdOPedAVnRe?)1yu#&v zCkM+4Q6DfWm{>`n?E8tT=xKvds# zwtU1by4ET!%RxQ+WmMUZq}91Ik5;SIFL%l}+yW_GPA$(7bZJjCDfRy_UB2}``I%E) z#ej8*3YCLx(MP4qKNlRWD$}w4knMk~p!%yp`J7uWtbKKRIAoH+aF4*dbLO1S{_|wtCM;)w#bu4wj>pVL)S#Y*&P)LM~-$H9Lb3-@_rd1 z^8Tc%TSD@+a#a^6Y1wpdw-m=zGWBQ?L;4s}Q997oQ9A67kJ15KY>9^>B|b4Zbr11E=}mL?CgY?b41fGdDKXw2AlIZXNabYP6xIu?Z()i3`wk)6_}`^b3OSD});9 zn^^B6e7Xvwx_r|sdSL?9l;8gx)x}#hUf^$fND6%(_}ehKzv=n6ytxgjm~`-(Ifuc0 zYuitWRObWTy($-rQ)lCIj>Ry0aXIPnjdQ^%N2H{jmf}sueVqDknhc+PJ58e7Nr)ud zAr043;pQ5;&W3{EZdlt=i-3Mf6f>NTT-V;30z zqBPvnt0~C1kle|zC`Axt%>?Jhxs}HWaiTT~5ioA0sX{C^mXws4DXCzcJzI&nq(VWC z4?x;Ki3~XSlE4FQCo2Pzm7AtKmSrGfBnvs1M@BN7qTO))ZU%~Zeg;IrF?$&h|5WlR zP1W>;+Cm|Uj5|J6&yXZvNroUgAxg=B8e4#nD`!{DUNPI7e0pl*T&+D3>sv|{C(m)qL3oz2;HpM8Lg=%#kqA1q zQHb{$N{aIwV_80%tU$t6>?@mW6Xk zu2EybCHG~j29H-MjqY3}G9mD;bV&`T5EIpGfTGoNw4art)5F|+N8s$z-jcH3;`h-- zWXd5wAB#0({apir{QRNeAdU>ctG{BMKb2sBtY&`I5Pcz9Q6gkC}x3?tai zzR=)sZ)jED@JLT+hG-lDlK>Pn7#bQIU5U&nDlVdhmR2P*O7B4Tt{Z^ovI_Y$p=&Dmyx_1qa?66G;iR|d@-`U?A3b?P0D;PfdB-OYt zztvVNK|O)|;pyf=ZzzmafN5nO6{kqGC`DL$2;{dwcP(T6gQ2Ku4&*nwJ_Wbz5#NG4 z-T5PJa_YpzkDWnXwweo3^cy2S8K%88zlzJONbG={sTEpp=3G%m6pDcp8XgxxDX1p0#(y*I+&CoXdF zTPfB#>7ySIBqR;gTw9NeA&IZ_%j8$lVjBxnT{%F$qsRMci zx>%Rp7A639FK%x;o=dcTp6mGjmeAwad1&8?#yYP6$VOs>GE>-;2WuGbj z$7P=-zV5Qm7Pq_XY2pf(JzWgA?0(VWvS)}2hutfD5%T#&mcu_C>3<62l z$6R)gxXM2xW#2J z7IdzkdD1=QVxG&sNPJ&URuxG)W^FgR>?et{UG{u&qRT#C{L-!>(9be)r^{X>I$icM zk?FE86wgs+^ONogh5M{{rI^jFim~Up!8TGI)UT8A7V&U`*}_ zjLq!t3J2L#IG_rLDWnPqy9x(X;eeGCeio)L%tzTVB2;$xliVH*QA-Ku=wgTue#E0> zUns1k{(tI@hw6WF5~`H zveyXlbwVuo823xaUdQ@IAvErL$bF3vml0wtt=#i$|GUY3l@R|)h=sg^gwV^IjH>*@ zuF4|^`@jx{KEqgu zK7riNV|9H#)lZ?iJIja{Z}m%_M^@pQ&|#%9KI822#lWxR&* zcE|g|UROf$<#1Ud92&F~%zxZ)f}r<2{UDV|;?~Wyaq!{( zQ9W7AcrxRujH?+pGro^8#JH338pazKKg0MS<9@~ijNfDYHRFstEk_&UM;V`FOo5Cf zXD#EUjK610T(14I7*Anb#kiiajqysx+Zi8Y`~l-H7~f{}$8%@FwvplSa6xgfW{^%` z4GwgNx36y;+Y!ns4w6G*p(CVw(YObpM#qUHShTxjdawB0E>8NgqQ_ei_6!oohaXOesL&RLGd|dGG|MIcjYef z3!c%_*tT_i(^&g%oU%$TPICKTN(4BohJ1q)xNx(#X6vYGqi zC@E_d`PSzC9XpB!Mz)45$y~X|O2aa`%ekOPuziruGNXc`OB&upi2edy6sVvK4+RGX zg7|=GR29CRquYbJG@)eB9m-U)#2Q==)mvk33LeeL=~&l{>vC&$mNe(I=d{-6)U0eO zF3#DqvZ<&jryZuo`uh5!oW{*LIN7;$IXP{(*CjMMmXiZ54)k}sSM43eh0|tgQI0M?InZJ} z<;Sh498;Vqcs%84Qt)1^x)*F$!DHs(q`Ju2^xj0bi#Ej`PuY$TUf+0W7jh)X<8O%yJ6X^5xkVFuLL9&J(Jut!x6R9IW$X_Q|T@~BII4js|b zO*8u)JdQ5!6@&Md@fHhPhwqd~cV+D~+h4^XBA=((_*yJ%9mbLCLDqsA_u`&cdU+c;Lb0n96Hj9Ziy=}l7{m$O zuEYgi~N`y(VHEzLVWs;{E7?e)- z!dNZ`SA|RpqT0a9816-r-Bo_Ah~XZEzs{kel7G;+u%od#=CH6p4M_jt<5Aa8blUIp zF^P*hjs~Mn`sb|yopc;V|0oU&8f_RK>KW_Dt+kyI+j8&$OfT4V4fN9C**W;|YfRLv z!}PK%)YaWDB;NE0U#-~)Bob4Plj(AfXP(TI^Ci8n5?-IEEiNcrfwz1MWR}O13OAgl zoGG#ru#_oK%Y?*QyzooU4DB^b0^@xi_NZ5L>U{=vwbIM{ZU)`WBp^Q~UQ5qRSBUo_(elG82TXSv z=u)HT?+_R}^|BA|MT~q{l8Y(d9iThJyh+4Z^4*O09qTv^PP$0>4ubBfDDu(!Xs3K% zTx`o%2!^rrNAC}!m4itA9R%IJIOGdw3-MSKx_uGyl`gU6E1E*SI?x@A!Y@+393C+NNygoL zzf zs4ZUs{9@^O4(L)1Goax&Nj}hxMWKt-^9`Uo6ou}3xH;v!8q7@ljH+VE7ui1F0J=}3 z?=p{(?@~AzGx=3spm`WNlhtr`(N)9YO5^G98-dx;+=<6NfcyYm2iybrryx|Xw&NdL z7ObZig5<(R<=KmWqN8+e!M~I4YS0zJjp%4BW$4yL&^-t`3Qu%YYz$o_zsDT>h~Cge z@_XCCkK{3QD84TF{subJZcw$0MVES+O_wqS-9iT)l`q3DG9Al7mkEDLFS_=abakM+ zm+8=TT6B}r3p%4eN{@+m3Czy?_?v?+!$B9RmxRmh^kU0`#V;})b3kX(fvz(q-Ez?7 zqTo_`X|iDCi{#g_*XD<=DJI>3gAPq_OuEY)ba_+I-Rht-?FQ*HQh)b>&gj{UBgh_^ zjt4>aFceSeEtw+T3-{USr93ctp*fKk|K_;?bWb@ds%ZnLZE@0_iw5UfDxmxrIzrHe zjr$*N!zVVz0yK2AC^3TLDe?7m!SJbpKv8LB*^1J_iptVJpfEs>{>4k7^78UPptPi- z6kd4FopEt}Qv*IRw75#N5Vj5F331}_l`6;;ZK6f2ejvQ|Vf?@IHTfT6>AZ%729bZ# zvx^%)vZnOMB0uo6oD*M3N`Cg-?XuzUJAXf1q<#|{auyAy`6s#F;i5_|O>7v<`rUK# zW(p}A3RT#{i~rmA#2U}{$W0s+fy#5e_rCcp`IMXgVAh|X`^9e$A3l6B?eo<7O^|WV zn~ef{j@cI~@Ae`ijacc=?G=X2WB`QTg_Y)%ZmQ zPx^LOEhmtAumlk5G+$11b_(HI0@S6!r;4%nVXs`^@g#!Z|F=5E5+6PPI353wrQ<@x zgYtaXiwfS;bBd4`&hpPhPn#r@JW1ZGm=x1Qj^iyILAjMN_jgJiRA{uscQ)PmW?AiXGiPOL1#W%W+E=M;IhDCq4 z9VhRk(bCpzsHWdOa7UfL^JB!)k8?rQ<@Ac`({Sme^WM^MoQBv+r*o2FC7ic*5A3K# zv??U}X5$bH;v|Nr#VEN@bip9bmZzO8stj}2|OdFrCVpQEA4oo3Mi zOUeQLj>OqQ`=s|#ktls$Z(fFPrgt-L=ks2im_hdWFm6(&jKmY+B)u~e=L3D-iNp*= z^8UnCWX}Y3QX)bnc;I>W^28#zCV5jSRN~xu-rew#2!5blh4XoL0p}#HPR#H~m2OC< z<|hf_B5~7A)N@>@TrLU_VzL6?i{=ngsew5FP|qd!rHq#LJel%t%pe6dSdJ9`UggMYYfEOH|Z8O3_B3*=^nm1$eB4#F|GhJrB(!OpOt%1S zn5LnmAt{;cXA5$Rurn$e2uK+M#JO&DK;!E65@ui!8D|HU$M9E{OO<6sQWw zCMd`vC_XpDhoXY?fy)1T?($nEGwGyMKfcd@K5fqLo_p>&=bpRoTeNzdZ2`jg$uKAD zFb;O<5CxjTfBM#;=-UW`k4*eWqzD`#K6^DKH>b=vmQk90z5Y3?Q+@?L@sj?!5M@P2VG4Y8pg+M*p z)TH(BRF~J3S5@HYdWtFTMDh2An!5Y&raBIXZVll;ri`KTYJpd1p#Z&U#AWhz9~GO;9e)FT>_aabHhUTc{=&(!^FYu_(71 zKoIw~^>s9QDrew*HC0KdeH5m$!furAp01WayFXEAi{ICaJ77X>zV?5Z)l~Y^DDmQ6tbF##f693yed}{-*Yz2S?jNAu>&8knvLe z38RgJrY_VG==79%E9w}ZfE(Kj1){Q|wg#w4ppZ=nRs7NN>Ds9LLHQ~8;8`2;F=A&W zQIt`T?vZkQTRq+i)QKNbV&Enzz73GyR zb=6h1wbgaywGikpZTry1Ej$j|&{d2Dqw<`YP-%sHm@=Wc)1Q zL$MK}j70I)RaMnsNRK-XYRl`ZtGzYeY6v@zgEz82vWnGw=bPvRD}K`SNp8#wOoB9R z`e`$SjJ7cCMJ86oU0L{I(?c1+YUoQ$U&9E}_D#jf?R}ZBm|+8L_RB43yYa8E_#{h$ zD=q$p4hKqzYlYq|MmkvYAJXYM!&{|Cg8zRQ{>fA2dc!}>M7hZbpt7PRGv93ZDZ^M3 z;B$s&lGORU;b|CV_Qd&uw5763VrKuM>8mucm4(|(?_}w8yXkFcbD(6piz0v?j;Ji~ zDXq=;Hw`>=RCwIn&L0pmL;!dYcc}^E4^apdQdR93Rjs9J()G^pFmk{T40o(P|kMkKf6F3cHQ#?q=2+$l>to8Jcjt+x3aYhHx5x)$csirW( z+Xu!N2C?JYvB?RO8Db6tvu0)|B!g!g;~Yh8&VcA(CWgj48QG@WWYi6>x)APxzJT#M z54n&b;Jljgdf`Mqfb(X?*9#|-AI{qtZ}4ah1Pe!O(bzz;Kif^^H!xWDp5>6XEN z$GA^$!_C2XQB=!swcrdb+AK&zmw*LnXmpYkVc`kAI;==TyG|?C(6P&kH8ky(vgqkk zp(sqzXQCua;5M5$L(MHF&d_qJ5@PU!aZa<~BtszkEl5Mf4_J_fhNlZL7@?|^ibx`b z0IR4Vz~eg(JOk^19Hv4)}Co3;{Eh`qbP#hl$b#`Gl zDn@tI>BZ}!!{hNtxEQaOMJ6W4Mo`W8(4`Ohn@Ns7nS+r)@#J`9hLf%>h9Tkv z$pgb;)=`nd7)bnA&hPOwCCWj-q1$k^N z78xsE+W>5Ae6YBDxnsOiwoxoG-z zFva#|#1Pw08Go6aT|ML+9b^2ra5ir0?k%1g7@mw!+TrZqz>fGR(pcdbzc7P_Y^TCA zJp3Wq&QJ^EWNLSsy`7Qso%kyjpUipCBuh`6KVr5mYP}#apgq_jYf=u$B0Y6%R=cbO(E86)Om&9^I_rPAC724(dBlP(fe>ebvdY*FmQb6m%;Q7(u_9 z!Ee_=yMySa2%qF;!h%c~*BfFVba+QMa0lfmzyX%e!TU?lA|F&giRQa}-k zNwdwysNn$@-={U|IDkeS1F@0h>YSU&pVaCIE*5o+P)Z%cofxTxhco$$T9@vgK!-25 z=>QgrbqtK}Fs<_OEdCp?#Itsiupf`d(WUG1M<3W;Ddyd9J%qh&Z0hRh#!O`oHIL2}jtpm^GXs-!7Ye$) z_>0hK)g$TjK=nE|&WWhQxy0V+mts=TUaOGivakC9zEod#*80f8`QNKbl9ptv0BJ2{ zwTKVrsJk)Y?ng(ZJk%Cy^>_Mv0!>JXLPrKak@_#?st==A4?27_;pVBP#tvPInFM(K z3;v=pY)s}$vBRviJ%8DxkxL#H^|08`uRiS#N2eUj5MuKl8jAO5h6G{?1M z1muQ8mTn}Qeu<0o-L&dPBM}TaOKGSfv|bBHd**N@2rI>ZN*h>|R*FT+U@|^s${^{hyEzm{} z%eu_i+ZZQ{=XTUl?Y(NqWXwO5tX)IHAI5Riuq~i`y`Ez|#fc=K8KI;~$zd#nnK!&0 zp%+$O=DOH0{ww1f<@9%OY#$g8(d^1ZY=jtM^6js@t*_M|+Kh!k)X>r4(SZp(@`tx2 z0-b?g^bjEbZG)s8Bw`+9XmoOLIFd-XAMG zf8!!DcnG7ji!#LD4Yx{DtmvNY&?-Yra!np{M&o#DZ+tu!-6JelESIh6d*eora>&@O z^_+mTMOF!!VWLF1eg+y?==ih~%ZjJ^d%DmJ!TBR{qK)e8LRAL~RRQ;7!f6Dp&pbm2 zWgWk#xDu#m1r3>lR*T*g1npg|jpd%=GTXA&TZWe~o~L}ePS~rQq`&QqjpL?pJdl-s zJaq_LEHzTb@jbBJhJhb?+H#4pxOi3*u36*J{(F*`m~2e#zp!$6XS}KyVoE*5d)BV? ztU-kEw2#aJlse_p6^3)Y5o~Akg{zP$sXmxZ z^8{)r{AH!^AudO<6v>oStfQ9Vq-!l3f$0yuz6rfX21Eled!g3#q99MmRFVO>JxJU} z$97T?!@Qub1!k>ib%;csnhn_g0Bk407Z*}RhW-^9mTpm^pDMhjbM|C6=|s(CI1zc$qO|%nY;CA%`1FJ&WOs42 zv^VX*rJi15@RZ4*Vh*B9W%p9H)8OOypG-3f%<;O#)y*7#Fr5|5aqB#@mx?|==F-r| zZN%S$?DJdpP|}`Fy6anw?bGV-tKk2H-oD;?o1G!;WGrAMY|`x(T^1S$oKMTBdEJtn z5SP+IsyokpE!!mq0Fkk=?E@o2SV-8$+&@Na8*X&)i}^9S`jDN5DB}oG1a_g2?OoPu zVdI9U9sIJy5Guf>NdxS4@@vch)D+Fi|4TG|XlMlTS((4( zV#xbLA-wf>GoCd17EL@FLM?1;!i!+gP$)H**E0CsCKuF(TKD9ZyvfD?%SLV!Hb9fX zVirxQI<0hl$%UN4X5YNMa2)Wbr>cjudalg6>jezZtm+xtTRQlEvS493ki^(&s13rzi)k;oU6$WoJ=% zG`@%Qwed`nj)M1>v-vlit91}N`y@F?h&>_C) zbnkQcno%nM0Aylm^dOiW$4<7OM2XsKN3bth+?MPdWp5?-U=2`A3lTY&cJNye>?W&Q zG|Ex-(hMA1hRRb0GqOo*B8u%M3_TOfZqQ#*Myov9_Uv7YBg&40xul7O^$-O{=l$p` zAMNm_IgTqFVjv+#inO?T16Kd!f~z@?dAkD>nRhs7z#-^pTCv5~5okXJvq|4d48WZC zIh+~JZ{s0E{)nU5-`?vBom}a~0B;&CIvT$pXr#9q;}h)MdlZ{DnrXW-X6AvBeTT{x z#vgZd2RxPQyj9-n`idIt@~f+_tw(t$QU zZ*g!Cp7CoX@qi<4l#*B<@f@NTM_rRWUH4j5W@$Vagi}8Tgm{^y#t5Q-zBTVUw z01p`fXnif%tAk-|YK;IEvIRecc-X0Zx>{O-ej`N5j3B0zN0gMBD$T#77&f8Z2c86l zehAX;O>K?6#n=h&EybS-`csLhpfgRO$dYS??^+Kg%F#hZd^BF>ycYau_B&SGG?uq!2E8^_0zLGDHWgI~^pcwRBVu>e;=f<{jG?W(Dy?*YNP5-MRvP$Q>3CD_~z zj5+^Kcv?{syB@aC_-2leC&NxZfOa3wx}xi)~U zl3ktcr(mu(Md(*%qY-S-bY3UgNO=G%VO>P-!!Y(=q}Y~`-s*|{M4EY%A@zBTl@+w> zYRH5ywVrxnr7`AG>tR|U3(G?`!a5|II?R)i#_+70l%>sBljF>NV+Hmfxw?1NVi=bD z9%9P(I^ErP?w;HW(1GFSI2U(|VlG$5u^|a=D(WovSn|IZZZWc>x}Lee#`xvVJc*Gz z*6w5cYNxy8kB*#zk;$FC197agiykf!gHC! zrY1Rw=l*0oD{->(mz+Ndp0CZu^9(yrauUycJ~Qg{>b$$w!Jh}uAG>nNoUq?ET&XUS z4o^NA22B?Gg81n8L~wg7s*>8VI!7u#7{e^{P$)bwJ`@^?dWEe+$OFv%DF=V&FjvU~ znKohcG`m$;GP78PtrzsO3L|UnckpxOxk|3d5-Ff#mMAQ#y@aijMnl*v;^Y^D^Ix*E z$!0xx@zBhIK*$H@Wu9~t#GC0FLbs43?SqP7EH-UsLBaEWC%k7E zmdM1N!54?A+&Hs(HTd3e*c|wZ)K0FeNX8u*{Bz*>m$~p1iJF2ZrPlo!{7&$EZJxWp zSI$tbC`b6b{_%6hfSu{yJ0Q(XGz6l{vguZ0DhhU8bS z6dR8XnKl>kz+vEX7rIJ*Hor*7+;7OFuM8oRzOtQn%}1fM$h-|QAqg_cKVQhCuN6Wj zeR-0}qB5%Fx z;x|L)oeNOxHq%~4Y8A|rQpLHram=c>X+TX6@d^2AzL+%%>T zGMdSM10m-xoI^&l6pF#vY|Nj@+HzEKeN4q#QAxnInttS|u*YD_yuhhkCe3f6LR z6xWu4@C0_uD(MSZq4*NDXc&rw#s-FB(-mfh5v8v+n?DQfuUh=?rhS6mRS9~#4&!e? z@28d=8ogC(cL=PWptsfDl+C|=7{4GF1$5cJx!zWLliri__~)VbkC!hwB)MEQ`0wA| z1vtJlxJMN{QHQFACTW%zb!6Fmem|me{o()jqGCxE5taS(`HP6kXO5Veo6H(z*#c@< z;x=1*fXi0(2CA%W6WevYk;C%Pv=_SF3-Uz$QRqHmftjbx9y?X5-_7BFg7{01oK5@{ za~8iJ;xA1qlyYL@0)AGWtK{4jvk9HIaISIA=Y{Ufg-K#64E>D-{4xmr?#g_X{d;h= zwb_2_iXPj^Wlf)vP}3V8E~6UnG3#;J4M1bBS^=NnE}DWI1KDUIb1|wymS^sV5zQq? zu%ZQp?(a(F$Ed2eCsXM{{skz%_o#oR@>HYFP@a&6@}F2FmA@Lw?_DG;pP)P?_wN?+ z2cY~@p5)5QlHa(eLg(L%f*FaCnJO`|=8zavW6g*UA&vNS=TdwM-Ph+NiHpcZw=Uu@ zA})8V$}b3_`^MZ0k$z0)sFs#q9SQJMS)qrpV%)Ms_CI$PWp>zoD$DfHOFLibgNB~ys1&i~2dzl1{HIy$GILsuFs zaV`bpRy}*7x`h}(({M}ZBl82zqhKp@4CBs-nI%Nu?o2m-_i*%j*Q6zqMF|6bYze;`qV6iO&G^Wc z%A8)RSSpfV=Qxr6$!2^|&g4{wIX5F_n6RXP$w4$dAyMRBTf%Q$;VQZOSli4`qEHnh zE!2`BOzvU40tg8ey=MLv(F!f)Pe8(750Qj%jHe@`$pk&Pls^YSKQEm%Dq@Rtc6`-{ZP+SIBu@3={I?MH=h=j*q|u2kQ--2Jor-jYQS#h;IKRf@D*07a ze(IRbZnJ{ONMvl=9%;ecf@#d4(j=bhxKZ?|1D0UWMMv-_A$D(#C$-r0<0z}w+=4Om z2;yq?h(a$hbR)Cm3*G2zg=~Ch>L#l2bC2L>t#XxIS38SI(obxu+d`Xe6gtrt5ULf;TDDF$nd}(O^$qn zLL*V`;uX*lvuSjWRCMR4;u?<+U=lAOEx&UlKXXbZv53Ey4ZA9wztl*bH zn@88rQJdr``hK*b^m=6lzY*Fz-!MmQlC2^Zq>)~!ZG$=6k(K<;)vks+Ht^S-Yr?~^ zcu1^%j*6ZORUJj>_F7wli#$gj*;LpwS|*9)Apxm1Ms+qQ~k;}Y(M zKOE2R%UDY*#iDwUk(KAEL66ICi`>f`L*o+y;+|Zi3NiOrsw38;lNh}2XZ;hAopG#X zsI%5FS>mWt?~m#8*VzAvnJ2Z@!5aR20{^2;2a2K6;Z>=_J}!0G#}BN-s|TaQcTeP> zbFIM!tDp}D$`KEl9P&`P&1^{Zel%Ad1E@%-`1g-Qwsp`g!NQ^9$Qmy7VKX`opPlS$ zZm!eO5s{i^Gr1}ojtL85VVvwJ{)$G6HT>Mi|66dw8Ls!w?dC@Qrq+$FXqUF0gL16l zH;w$9Ohhl(hWH&MkK3B~6~yCYMCu?}yxzobk!l<~k1sXzuM0JN!L0{ni#MA2_mwRU zlEYX1{8?!UTs?L$$?+FI|FyEiL2|ggg})^@bo2$A(^Y~s{Gx^L&7yqJ(dU~(uq#{n zg<05~NTmZ2rlM0M{!-x}m$k?V1nR2CTKQ*1Af$ELfj-s7Z%k5H=wSgo52JIf?(& zWI%D4D~E?p;;%^#NaYkpoN2nhoy7mDLIu+gb;l-tRyO6Rt-UjAg_%NrzlmR%P1{^M zI@*0uEm>BQSt`LeLrLLQL~#u;pY9Kp~IE% zh3=lrhS%Hqr`N2}!KsfW8;_kLxM)Ew!Kv*S2#2XrmTdOp!VCA$Tn%@3@cS%mj3)kW z!A3NK7B*<jAgxJh6T;0#ARFffd{GW9(e z!9Eza;qgxXkS(x?4Yh+JFaQN!W(iE+B5;3vY;*{BUSY_DmP9lShyPwGK^9Ml8Ht3gNn+A`kSb=^1^ERfMlvSEj+ny!#58ICIE1ll zxTcr?u0#}A`@R&j=pIobi>|FVO(jE9zp;Q*!dzW`F3Q%7qfR0 zRTs9HMlf&@i8v^Tu#Fe~N0pA_Nf6a2jD-bK^b5?lL5#7=ZpB3~VR-@+x(_ei@Uv6+ z1?z08VJ%iQAVruTNUB-!iZKwSRIGS~9OVdzi~hzVN=u+|{iRrvmudqstJ-5$wfiY} zWMoKYXSU&wr}78ws!OZV{2I)&k0;grKvrG0;9#w~;r4$1x?Le*%h~lgfGy1tBgOuo zX3Kj&z;8LumJO6GQ8J3Kzxkj{`JHtKYsx%KBow;uUAN(Hr}L-ndP$Scrq%&0I;zIt z0{+u1+VIE+`6bn&eox$DXV&oT<+6s~3LEG1Q&RNM`fMj-|w+HEERD7G&b4c&?`9XF}?;Rt3mX3fFDGAOaLu0dWd=M?5sj}TY1BK z1N=wTqQyvzli6mxC*rgpj{s7mVT%(r6MA|@bRW?$Oq*5a9`lnLHS!dFFWs78xu1|@ z0o9&`^@ncQmO1)IA{PKz|7iNarG*3> z;C77oK(vZ;g~!^(5R7Oc1xx6YK8}?*T&1@diCnfAs^IAPVyJ%{`Bddd`f}-@5MGT( zaa_zvzskjo=uj-_gR$y$2)TYy!=m~{&g>I%0?VXrYV2r1JHt+yiy zwcbRvE+a&PiI4%&;kTn0+h`(MVXNa!r>W|RFxd%q4^o!UCz@!fE+Ks;(!vDqHaFTm z1QVc}OtfMGWb;ZG&5Qg9mQG6Qp5=lQ<%=MF(nqhv zG1j+Sx+JRRN)hCobO@0zVzx-tE1DcX#o~|9Gi^v&L z&P;NAP&%Z~fOHTZ{U>j(lo}SF5Hv&|Bql;1xPQSVz%~L@(6_sku6WQAQhEiitPCC2_~gV! zdZq)LsCGucYyxs|`A0vF;v&$_^5K5!`sjx$M-gZ$8reBI6xkRZ9ScY1vA_se&=VXx z@gB$cdL)Inye?dZKE?Ym8D27w77Is(#mJ4gMg}Lh5lj(hZ%uhcsTVI=foArI)BT|v zj}x)pJvz3-{6a`1#!zf3HWcw#pLJU|dhikQ*`FPeP9r*DPub|)QeY?&$5g=_l8v%a zqCtcS3=4S5x?r`giP+9aQUiO+0=90S;Re=v9lsT?4rCLmA5Sv&hh(1WC`XnLBpeT? zYa8g9T=jY`9&%adMS4$F_cuqTuscrp!5`PJ=vSv_G7(pUnBI7iqHl9RyeX(IpWcX< z96e>tl8^i_ZgsIb(ZlY+%Xv+0{-#YG0$oO$)cRLc?PBsks%ME%b`=Bj+Ei1FQGuWTrTczAI5Wtv#Ew#BF2B&Pat4{fB zgTUdHAGlF_s-N^n?W}&%KTA8st;z( zv%4K^%;N6^2WD|Ihm-xr6oJ^yV^7-L^VvN%cMiMW=3cJfdUCyd(Zaj-?b05imU}g#MJBnRpbFZd$-}vP@j%6Ec z?&WNO&3z2}p%|gcAbF1C*hMyXCF`)ck6?${+y(40x<*3%@*IWiQk%Pk_1WCZ*x@$! z8uq+d1Q4Hf>~fpCf_2;6hqJ?M?v>)zP*eUY_9;qy^~-atW$iZiQbu<_=wF`WX!b+x z0L*igvhM;C36*g-^7lP}`sar1+q46a+;q2x{*n7)?EobACllNg7Iz{1E$YDMPwy4t z?>s*SMFg7|t5fddmAg&3JC&R2fq59LFCa# z6nvZ@%Jkoqn-n5{dZL@4EnKz=2Pnd!ODMv@Ey4kcaDb$@1H;e_ijQzFRBrf}6CRy+ zhxi>QQ4T4zr(fG5- zeWJ2AGO5PzWx%7*eS%<(!mly??;w0VV_znST@bGjgr09GD9Quexyo)QDfk}>{z*Y? zziX9U9#b$|#j8%iNd=!!@Mj9H%8+s^6x^fW1qwc);Lj916A>gm|69SoD0o7a#CI!r zoq~5N_`eFyL)oS9y$VJZ{HTKWDflA=UsBMGcACN!DY!ww4=H$wf{!Zrl7eq4Sb;i< z!nY}SmV%cn_@4^CrXWKp3r-ElI_>_Y4P`45N z3I)3q{G@{4Q}7=OZbaQj^xX=^6#RsO?Nu`tMTkO$8lpi9bidD;4~mg6}BUfx3N6g*wQ zAq9sOoKWyQ1#eLB76tEA@aqabqTnwS{H=n2RPb#D=N&EeTczMJ3LdB6i3)B}@B<1) z6r57H{Q*fVxk1F^h1%IvJyb`HLkAk03@G%AFA1nQv6g*qOZz%Xf1%IpH zn+j%@%5X~*JW|1v72K}irxmT72K%cNecEWc!q-iq2S#L zzM$Z13cju2Ve2H{S` z-%&8DT!vq);EM|WQo(l={IplnU8&%m3Z76Q@ofr*6hwE2IZ#(UNN~LxPr#3@!%WsX z<7V4&whmV&P7DkJZr5L!Q(hLekIydx3;c5kny z0G%Vz?)K@a`pK$_&{lCnu_b^(JTgYiLfsWLZLQNaTX$7NLbW8%s*%2l61?knlV9kh zaG>YZ$;}hNJ-CyVFjjKRbE@~<5a1La`G%(PJm-+Fb+o88nk2x^@z^+~NA;tE2)1oX z1RK~kdFnvmLwkmLt5OAnxx(Rf+Y!d!PR~Y!BHbs&D>^q<$A-KiKXI|@rr#>0sI&_5 zQ#)cic6f)!PK_9v+0srK4O8$o^g1t7?wxe=8D$fh&#;C;Ic92ndr0OPeACOylz&(w zJ<09U?+1?;74^1t;1ONlRAom|u&CQ#e#y_=dgHA`nLoNetzU396mzsTR{t1Ig9pIlee-Qy3|75VXC+*Ac?j|~4@TFmf;h{Qh@2eB8_!TKv~9;+jSW$lG&>W zR!%2>*$r8wvl|6ZC%?@IK7@Jwb=yVolxaMpq^e|mf2x~VpQNXg_Y;(t?`N7tf!L%| z7Lu}2MT2;xQ#KNK*y6BO7JGlsxPWiN@48o*S9x04rfOOJAl|O3H4z~QMum@HCL|8NTq?2S;jm_kvvXf5w z*+Rd+@+Wk+CF~q)UctbY%5$uC4F;wK=aA-e=&PbP6bgmBl_86^p>Sw$up%7w*3`l; z)Z^bAY@@zITBJB!D@$yWewI;`Ln^V1ZU#0>&+ydkc-2fVbj^zJPRNWPqS~rUf%neD z3p3ZJz$f7^h8acP%70S#uQ$+4t$P`I_Gbd|!qC`ltEz17X$k8MtZfP5<;~ zI}rMt{9b~C!s?&)OXODvebeDb>qW`d4?{#6$7x2i;X9Sp76V!+whHO{_;Gv$K)Dimnao6FEuj@>ejn>eq|H zuJyyzU`qXlK(}AI$q_m*_iT2wI zx+389FO`0u_b_&eCIZxSiTYKol6w&}siwOKA6EVLgHGG848*DQ%Py2_u!;N<)Av=- zU8sowwcJGgCRQ`{KoYu8f__yniq@|j^r`e~2Hp8d_$BK1IOx*Je;&+V|7Q|@6$$!1 z4!R|vqw;~N*_8Ud0=ieIAyPkWmqh&@KqR|05um0^v|p|l^)nem{WP6XZ>YRJT#Y^B z+7q<;ljFmh5ALop?YtIrsqFkc(0Nb?>YwJ97>{3VWb8&w1gPl}Fc8Tx@Po`fz@zuqyq=RlKc{VoH-s$cWCS?_w_r|p+m z@3w>P^DfQJw9DB*Y2M`f#1y$9mHRyCD1IcD4+xW@nIe_&{& z9e|onkLhu^eckAB9*?)GuDZUeytb~&<0<#hPyWU7Nli_S$5T~VR}FyQ2j_jv-`;{_ zdRn&2NWBv22 zWW~$Z7Ce)c@sz`pfBK0{4=%rU1v|R5WpnPrryPaXoZi#)-16M~41DeJ(RbhBAMqWz za;o5sr%yb5z&F^!R=@Z5Ki&&uJTO1I$+0S{@RO{k;BQZ}V&}_&g7X^}zvOr&(0G31 zqMyRFR}-c4D{p+86|D$eyJD#6*ULTmF<(!?U!Q*Qx7jVP|CX`$-h1z3w0}|BJA=<@ zkV*y(AF^{H@B2|U%8&HJE3PvpX`m|RbIK#$+QG`fN;RKDH=yCC!%;opWGCV;5`4xP zSuu7e^I*gs>DR{+`q3ELrpRROaEWZ~e89<%a5(5Z?Ekkm#+(`b{&_b3pNpq5yCbU_Y-1b=v0yy3gH5cci5M#6u52SHw?XD!90ZXqwd$m zh`QzP&Q5Gp8H5k%%+Kb|(E%XNfFrsMACXb~89I|_!WZB#brr&&#m5$W(61Z+oy?EF zP}p9_rhoB(%-h5+lj>HwK}6nd;7H^tvzR)$hN^mwSq>5?vE=H5wPts5=f+H)x!C1& z)?^+9*Gb~L4u83`O@1%VJW4q8G7krIIVUm~3y%+HddZ!c5BJdmlbzX>xj4h&%5vVG zk?95LM;E)YmI|U3_}Q)Aod?O3*5VsNigv_{5kZp@W%CS`SZkc};m$1)jC1 znBuw=e{ZO%yASWJ<1p#g5RNm;7%Hz8cm=y!dg)~I0Xz~;g?ex*6hhRgPzsAr^IWJ6 zVLKUW^D)kbO5unHxF}6fCzxM`&6VQlw6}$7f+0<8MH7p1s{sUYZ(CnSqo;BP-d9tV zgxW`8Dl6

    F()j3AFnYg|_&8y|^AG)aGk%+0xb1Y!9S;rF$hP#ddyzuaQQ-Z&@W1Z zq6QAPjr!W#L%v|p-_vWN104a7w);2x+m!_=)3kI8b~x-x#kK(dsdP*54*+WmEby>B zZZg4ttf0|lE9UJiI1lK=4J>r$1pNqLdY&!Af0`SB2tGfAH=k*DKxn&%@f@)n+teOt zwB`JAZ$0CSLu3>rYlsRGUL4^|6eiRZ3ih?M;FNO6Gd#@rvQVho2eVcbix=UiJ*!uH z_AtI&p(WNrgD2n_&o`JAPp^dxf3V3%1s!*_3T6letkA$BZ!JO|j?`)<2qPHWvJbbmNu)sLf>~CrhdYI$rP>4*^8DzXvf5K?vps5RW1Ufxs-ikWL zC*Z~=LxHHQsI38N5-4O7LKT0se7ZI&e^7o3K6vtme2myxNfc!iqr2CqQ0uWrnaKKdXn+8gb&3=h%yqzTUS+8Q(J|a zyt1~uzPj35s~3X4y&B)HPzZ|HEKgt%7d-D0GJ zHUA-Lq~NJbUA>w7{>8izNM+n zCoIeyuWAPw^AFkq?a&MQqjrLUsu%ylw?OS=n!Kre5_EW%tXdapqDBk<8UGt0keN)( z-wA_MGco@l46=;CnAJH2-|L{L7z{<52lU4U+GMNoX9>K?T;tCccvFOtElI|?4v3(H zRq~CjBN};;lIMx=DQQGg2+4X?To?ufpC@j4H=kRjl_n(=z!L_UD? zX2#bGCz2n|+Zb=~bWiHA_b`6EbjrXFGk$_}%h0$I^F-;E!GFiNPjJI!#CUB~%Wt*d z3@zF$NJE!^1!-t>k`!U#3B5Y3NJG0$E7s7l%ZfEL?Uu6WSyZ7YOwnheBun5nn>a(w zEhf&;a;p+z@Plzqv*08{Ap0#yL&XnRkcNh*3o#g>s+5XIB832}s35?@Mk?*jSS8X< zA&?q7R*4));{aOE!VzAv_DAD@BhaDk2nK>QQp9+%4gK08xi?de2|MH%ry96m2igEE zQXnT$A#M+J`hkdz(9TU{80t3rdQm4UFM3HU7Pe3v9}0DLVM{7Tchu>{%cH~N@kqEB zFPlXsCdWol&G^uz5Bi%)jy|7*kwEd}cw~rr{J2eNi{G~?(R+7fUnBSVwJ5nQZ1HWrJF6|ZdoHa0$3Tt3|* zzLQa$>Dj#%p}7z)Xkc#Pl{|+HpWlhjz|I)31Xm_An!cIKajD%jE3p zA?N5AL+gp!1Jvkl*H@DE|gkIVDT@bZD0up&(!u;I@RelAr!BstI> z#7yigVg-TJqnkC{>Exf$L45}bDhQ0AuR8hlI_UI)f^H=OBj{H%`0YAqH_hpj}oJiG-HoTL;@1bcDvYB8c?KLqP?}}1D5sFE(&BmzV0Tu)}o5`Ql>Ig0tb&OC-9mAa%sfLF$`HNbY?w&x0FSzLd7K(KYjPEe5^6@PG z8?A=HK&lcSleF3-_K*z^XYn_k^{5mY1DJ~!W|rYZjbOPCTc$uiE~vzlcapFl56jUi zjQr6D?VqA~H`?!FYa5%oI=V4a*+b2vbA=O{D3O)WPk+rS`_W@Jghznioc&S$<-=xVE#e9jjY)1Tbfi zq1KPz*SMBqux`6$T>C{4Km1`CX^v|Zi$j)fB%6MT8w$ENU$p9FP7x6B9}B>fwc`a(0j-A$D!iF z0lJ*FP>c{T_-XTP#)=JA3Yxq68r%J}mQ$Gp4J@^@p@ zU}QdnTno0nG>{RZ0$HAt0>TK%ETSQtbN9UUGWn7{*ocy=Pt8R$h10rKBANZLUn=0S!=CkKZkiG=$xpC-el zV)efqZ(4ZJ5Eye^<=GN`&iYpn-*sPdl-!c&fjr3(XLm zKO!gEsLn1_b+Awsa6cxTM$r1qGlWpq@q3CZfqGWZkU40z=uJV;-qqSz?kO&_Eo;4H zcnRZq%BSmuy~;`Y+s@cHZWPCxTj|GBhp@#`BV`=l1KVvF_@SpQml%tSXEouPH6HE1 zCy9y4#?<}`D~ET+tBN6})Kk1??OM+oL!b`pGX`BY@+ zUy)(y&LsM&!fQHbPj-_|)Le!WQMkoLYZHU9iS!Ml0@&azb263#slr_qA-77yv}Z#pip>^M@qy9c^U zk^N@mCgf(;@JJSa+i`@Tqe!2hET5tru!eWD_?MkU;nDaW($~f_NjeJNU(V*=aIV%t z?Cg`|AR*?tZ2nc(>gd4WxRpL?nG&U9iRuZzCP0VyqLatZ;cG^z`~#4QrO|_6b{sp| zf)XWauN}d@WN}-vbCkW6+=DehF)c*o+%xP5c9YdD8s#W^X$FohL**&?7}=yX5yf^B zhOXsfH|Vb@qg5Vld-kry5oO20T++nCdWeEJD^B+*l;c0maa`dL0|_xwq{Y=6u=*z# zT+MmR+Z~w5yu(2Q4narLiY>m5K>I0}P5M@10Oq{U;mmM;8;>ONM;y)m_FiA;#zU|XQ27o$WxYUA;e_-CyIIKid}yfvEO zCl0mTL^JA%Eb77GIfoL8g;knwqu7;Ci`z3X3-ElRuZU(He1492cK2b|tqg}SjWy+s zH5i)z+98&Bt0)1mXc!E1G-DB%c9hdzaj_n(mu(rp(J2$CuQTad^oU-KzDdy;GcvXb zmVx2j1AE5RJPZxRzi$XG#vP7hVqMyf|ybsQBrEEH2;!f*o1Z;coG!)AxOJ7wKet@V<)_~6n`q{PbH#) z&NPK0ORg2ZYdx4KM+X)0(Ri8jTJWRU^Mn8uB7o#(3q$m>uZsviEj8$EJXj4(Zpkz_ z{&-Ik4M;kLTT4C5mq-Kb0oYYrJXKygimC*9Nlp9_vAb$<=jenljJsqjrjd?2B9S;iPw_yh*v&oQ z+2|?Wg#tf8BPaZJ)l|~=fZ$yTl`tcyk<*?MZ0-ieod3aG_*xGP3`)lD5yFC#g9k0F zEPY}33SsFR6kptUOH<>`Q6_lSf$^JRX`EGm}Be@RoFVy0*P* zOGutxI2D_Bx;jI64%pv=dh&%NURwjb@Oim5fUS~Uo$aS!t~W*KS7xITY|wOGC)&tM z@E0woeT*dcVHo=_q%(0fiVk>gio}LPc%luBC;d;hE6{!#&b*zF`aJs9OB!3LArrpT zdg_Ul#+Xa3r)q^PEDzZT>yT{fFkkvLhG*TREN#Y`9B1wuE3p5_)xE10!?4`<$ntxg z?ru704mZ8=#Lsaq?iR&du8w0v65LeOS?;mqe=*!*WJh&9bAOHT%bj@=BX_Lb$N1Gw zcgY_eIRzt=J9`J>SZ5C)q+>NJh+`kZ1iJ2{+_5^NAl@_@iAJFnIkR!t^aUoAjmE~% zZbIdea3r*=mbo`@es8v`WS?^umiz21$w@38VI!7u#7{e^{P$)bwJ`@^?dWEe+$OFv%DF=V&FjvU~nKohc+PhU) zGP78P(V5=^2qSClckpxOxk|3d5-Ff#mMAQ#y@aijMnl*v;^Y^D^Ix*E$!0xxA<@i& zK*%@jWu9~t#GC1+Lbs43?SqP7EH-UsLBaEWC%k7EmdM1N!54?A z+&CF~HTd3e*c|wZ)K0FeNX8u*{Bz*>m$~p1iJF2ZrPlo!{7&$EZJxWpSI$tbC`b6< zL0^snAF?WaWjMbx4b{_%6hfSu{yJ0Q(XGz6l{vguZ0DhhU8bS6dR8XnKl>k zz-i%g7rIJ*Hor*7+;7OFuM8oRzOtQn%}1fM$h-|QAqg_cKVQhCuN6WjeR-0}qB5%Fx;x|L)oeNOx zHq%~4Y8A|rQpLHram=cTGMdSM10m-x zoI^&l6pF#vY|Nj@+HzEKeN4q#QAxnInttS|u*YD_yuhhkCe3f6LR6xWu4@C0_u zD(MSZq4*NDXc&rw#s-FB(-mfh5v8v+n?DQfuUh=?rhS6mRS9~#4&!e?@28d=8ogC( zcL=PWptsfDl+C|=7{4GF1$5cJx!zWLliri__~)VbkC!hwB)MEQ`0wA|1*0R8!9A+r zi8@p@G)c3(s3Xhf^ZOB%>kt3G7ZppYh^XwJ&tF7TK6Av(++@}$%N9_>61Umf16;PM zH&A75o7k@FjU1MTroGVZUXUm1k3#nm3(P!i_SmUf{caBb6U1M7 zp_CIF7x1(4TqWnOm`&)sg>#K_J}-1fvcsr=PYe(xe-`2^)Dxqr8iKLF*Q@+4PY zmi)#&6*~WB6wFAB%v6byHHXBY8f!*;2x-KpJD1{9=)OKDNnAuOx^)qM5plU=RenJb z-8bf5i1cGRN42!{>PUd6$_hP%72}pAvM(Y`L9cqa`_wJ{msJsf=(9hPd4L&awexb%()pc!-ORTOb(*y35g>2+7f>23RlVH$J%Co5{0T5X`z-3VR8@S z#Xm@>=r!}Vh*oGRe*zNzdWa;9V>}%hO(y8UrTjSv`g!TBQ4teCW{D-I%GZt33?oMmE&yrHH9^HXr+ZY3gS~%x0*7EB@-p;$ZMAK zy9-<;kCo3VN}0zHrOJjOirlk`B73>=`TY=ek9Ss4%3g*jQ6em{BKK^fgaPCE{85Oy zszQiLK0Ti-VG4Fm%C3Q)YT8MQ+nD2{NqWKgr}_Mzqg*BDR4z$utjvleSvD1%saZv% zY0g;7j;|WA4O@kY#Hl`<{}#gjJex3;G&<2`%1|_@Q<1JPN}ih!=ht{#CBLf5PaU(_ zZB`H&iHvRABQ2O)FpU{hn#5BbH;Nv0z!D6)=m`EK#O|%}q!ycg9A)*ITQG(mL0ruq zQRpRxZe*5xp&Nazkd5z5-9#0B?h*W~Rj!ijYG*M?`iU)dTWHgbLgyN~QT|vWbfd3j zDRrX`RN;~Qzo6R}>yl(dWY~#FU}PvVt$V`g8Cbd;mQ^WPyl{&`b7Xj6k0wXHL7|Z- zckv47h}kqcM=H8=RB?^R2QZ13ke1&$lApWURdQeb9Cb>bz6aJRr8Xk8#$~Gwe>k4s zm$8;sibeGxBP-8SgC6(u7P*%>hQ=oZ#C5(#6=LqMR7b2wCoy>4&-y1KJL6c(P-m@U zvcyrP-XGKFud)9TGf!%*gEjp51pY^x4irPB!>dwij9?v)OD~QL*h}1!{xUPxcBGou}9xpfXuM0JN!L0{niyNBx z_mwRUlEW*_{8?!U+!S^&$#Juv|61AMAUV9?=WhuP9eu&(bd_KYm$dM`S(Fbt`h0T; z_Wc%qVHWlhQt3d1snshIf2nYg%T_oDfvV-57XDcg2x*;mpnF^S%~HX3ABm!hLzX|Y z97;FcB%W9aVV89)|B4Ylm0f0Ia9_{i0pU z=a_x#$!xf;oqu}G8XcUvL{x1TxmT>A;G)5^1V;nkKM)R68!FlC$Nd!UpSc=-+0O5? zurXTXuwWzFEDIYn%yu@f5}Pwz8$RE`?>OdY(gx>%$9Bl!l!!(EPiR8>z#zaGj(A{T z7*kv7doY4+D{RBN9sD6%U=bUNga`~kftOhV)3*rRA0HbX!WC5*;h^PG4(#JV^fuhr z$uBGxI>kn&lIW!rA>Bw1rJhy|3_jb%zc7P=MK{HO^pgyPib~Z%L!D&0z1qd!k*v|v z-XT+8m`R(*t`*)O6~@~In9p%WmAWPL86F*{PqyLpZhrMz5m~|TKw1(*(v}$RX9mOl zI3^$%YE#bCUHjnm0@LD{;~|UhJDLApDnS-ch#84QtVm+ge2^+;kM-~iN{nPoh#fJ7 z{fTMP{Ba0l*YJZN|6PeFu=Z^vX3_n@T3K{$onI=sV$|F(hs^zQJ52u`F@Wyh0~6=- ze(TN{>RwVM(Qj^#K`Fa4v*Dp$e)F-S%-c0EOFxVtx71L?bvvUs8;Ayjvl^gu=4$6rb+*r+eiolQ$H)gTazYKR1*gG+(|QV9OWW`0GfNc@Bt z>ygH2nsVv7LNmfINVxzry~i z*sKeGSLrz3CsA$5SXdxMcfx$A#2At6R$K%VmM1`=`@Lf~eD4%~!8)62SaDVDP7!7S zl4@4GVhltn6)RpL$1(!qI=}IV(h_J~aw!(xrP@Hus`i*w?S2X#85xqLfNgm8RQ{k{ zb!ko)xN>HKNCUectqsdWI0j;fKifd4d$Hhk%W{E}+X zEF^BEGaH7Aa@jC!g^lz1Db{+!(y{BuEe@hFh?dJnA&Q6Tsd0#UrQ6u&+dr-5|3ovf z$Lg@u+x^qnN{6GZ;IPN|8kDRC(MbY+5Y0FNG~no1=DD-83f=3<8-6{&e^f0Rn#4Gn zP0g=Goc81SO=@dwaiZ2mPojukC)$%~v!>l+eo|XVo}$a98zC&}6LKt|n!&LC(Cy(e zNB@Z20WE6lLU$yq;i@pdt|qz4Mk95VSN4sQs63-*OIkrWG)<(O*-(*kgf!z|iB4*j z_wfXk_hmIaI>cYA5oK|Pm38xWQbkIQsYOfZ(x=dh;(?});$b#?6c4ykYdo5$@ln}z zH%9p9Tx&4q3HoqZAri@H?Ppkr&hX>?SPSVGz$~@Mr6ZAT9rQ|;aHt71w)nv)Uuv8h z4fZuP`Ga`0$3)>UTVDqb^n`FnQCAQ9nCa8*?`*|IOcMW56EAN^58&OB-ljHors;v} zd~hWY`-q7N;%H`HyRV0R*u?evacs237ih-=EFd)V-dx<6Eh*@81>xyq<$Ok< zU;#J>men1GyF=wCV;+sG%3*AkcFdo@V15o*7cLTNuC5iJ$OS;wKbk&pfgu40xE&)t z5Ut`|;jwlx1S48V!4mqUk7Fec*Xk`sF)CXORd5V_G1Nbfe5!IJeYtc{2(QMYXfEcY zU*%#(bSR?q!C3V=gj~Ofo0M*HFmT_)|$vxMOSB{WN;6p*4vSUT5qCS zml2}DM96>`7u!*cZ8Qon&!B#3t#)V{`Q3 z%-)bwg~T}lDb`^k$l19R{*;xv=mU$B%R~;9Ny^yC(n(3(vs`eZd=aEi`skH7#`>0v z+_X6#xoJzj$m?6H1SiK~r64>-JMikF`h?P_$xkBam!FJ%KvR;;)3u{?5jpWzBNZP< zCOJMR9nxn&ItY(mmN!>Q4U10*8ln#p6QK{>#o!WP8v!cl+g(amyg{ix5$X*2$=D9< zP5g(oLrUJM>B(<|7*cs06(8Uc*D)Yt?~;xaayGy*CLJr5kzV84!PrE#D8Z8rP>Hdr zjVvDu@6O{?aWXc&L4Cl`;&-seN-^rjV1I|_w5p-X>Y<7c(6eCzQC5c8pNZJOu&1nS zWHf{;1F+OLJc`RMvGzEL3R~H$aqylM@^1 z$qsC&+8F_}3CP7oApJO&i$FWehx=*XURj7*HLM^aQ&4u;Fnzjz-e!>b0;V&SN;7`YMG$l&BQf+^zcttqc4_2P9a(99lj zx=VE9aU#~cN5^)UUkHiB7>Z5Bh9Vy86L0HA4?aRZ`x7M6X+$UNDI1+z3JgW!m{6EQ zvQailG>9;PVF6EB7p&Gb5!)F_YG6-Uz;*=Oa3`Drx8l{|Y(n+pdB*;b%u^lZ$nt@N zqvCXhgE%uTuKMV&URS=(i}c1p^5)1CcFGy&$vevRtJyP|$gqZ3yiU=#IUwE_R2NZi z#H)^;vSvD$PNji9j2m98PV}~W@QPkjo4;w36>q%fh@!JIiq{Qrk~K1ibO?_{J<^P6 zKUl2mA1mykzL4?b%EN1=qKF{ z>A+ulFW4!t5``Ck;70AKe$pScv-(N@EbU~?_;UU~^1cKatjJ_ zs0hCJdLt?*LIq#@|2{L%{Ep2g-IVIb_w)a?o9}O)dFGjCo|)gAzu$~N?aP;Tqgv<7 z5A@3QB7{F#e9PrNTAb%{pCs11+(qJOm%Bv#!Y%@k zcbvH0vAs_%`W%J;slrbXz>~qJig|8P7-&y+^2{gE_bmga=DKcuj)ajk}%(s zBfji%FB79KcfP1_xfhAQ+eIGfSs}jdau^_}vDLVD+-puZHb|=_9LWpp?nEoNg>lvvWP<;0=-cPs` zdJ>YJj6Y=h^Mv64DZ5{0{1xNx8UI8GzBkytpWW!f*!DWwwh!gA=QJTMCB$T%vD-Ju zjbnN4AuJZ+Swf`e7mRN)D*J(6MDYOEGj3tr#&{{?#~5#8ROv>zr`Y{-#&;NJqKuN< ze8w>22;)Z>Z(_Wg@malovV=P+K)_#ce7Gv34a0Hd+f-DC$8*6$Fa zP#XGI$-P#HZxUj4$Ive%_d2#W3b&!}5ul$c#KnYVOkZL9f05{wLVSe~uSmR1i1bkX zK&YN0;5@dQDyMLNg59q(8vEVIcKIG7oy|vbsQx1yV|ApjJGqs!YI&hBL3Bkjf~xlw=#Z<(T6&a_>X2hg>gIM zMT}1|&P1I^{7V>H7(c}LAmcw6*P_lO{wQM~jQMCQNX{VR(~PSzB|-F?7~f=!qHZMm7Z{I1TSD$VjK5>7K^sE!^BM18e1-9N z)WPI`E#vnYi_k_9{cOf37++>Qa*6iOXFQ8>l=0Jye`KV#ndAi+&tu%ncpsz0K}y7T z3S%8(E8`Z%KE_KJzsmSHLEGv38`599Y3|H$|Th`f$=?zU5ulQA7;Fo z@p{HjF@BBl3C15XzQFiDjDKaEldJVwz<3g>oX2v$gcE)bTU5tAfuVcKK@ixZ0 z8J}W&p7Cdle`3r$QR_9EaUtW0jB6Qd7~2@PG45d8&G-SvYZ>oespZRjjUmQ!81G^H zGh^^%&G!k$uQNW$_yXgrjBhi_0v)cLv6*p%@nXiS89&Wx@TodX@)u@zOJO~bnV_Jor_FP1so z*z|c&yD^(P3c~TQYAQ9xCKmJ34WO=gz{d!-Hc( zg~51eJMF$2@9!MyT^||UmdFjpiBMGJ2kdjib*tazGZQB;;AKsF%G;`%08x2$FE^=W&uzNf0Vn)S8mouzEP>I<&(i_)h z2KRJIGL;`ujRT;%L*^{tk=)$2h9(?{8`@dilpD*9hI2!!8-u~z&8r&&f!rAGBH?g2 zkQ>>Qi@lp;8_ROvA8T7*v%Xe4%i(Nj%x$3!qQkl2>QF^)Yxs{=QB%Gp}A|q}SANWLTo3voGF{d3!8PIH&C$C5Dq{9-~}c zf^uQVbc&GMR=K7`QSfw%)P&&On0hblRlz6C#t9E2=hVAX-7eh}dpgBCNqK$TrCr)d zOghCqr5G;#BqN>TpCrRo)sT#I>Y5ZX?6Qzf-NOQ?u07O(z+n%m6sWMa#?vUhD&!&O zzYd*L)lD<=9Wo9r=aqnWlkJuO+k)xjxq0AG#?pD-)2gQJ=UeLn+394aoq-6D&hwl6 zz#>>W&#UWLTZBpH`E=zB!ld&&QW(ns>Es1Jf7ECl>hs5859#?+VeQhBPL??}wzH3( zopkcg75d#he@b^(#!j>5RRUbOJk4s?5@1_!8hJjA?kGAu@pwE?9Cv6N?}`^C0_B~> zoyG8@qwHf1)O|>c6(85?CpJY_%6gRJoLN>k18+S~@HFjs$wV*ozH)J_$AloN+Nzj@ z9+*g1X0DusoY9lS!-wfv{|EM1+-X|BRg)*ptLcKY#hemiYk z(KmvveMaiW2D(Q3aK3E2>jfHo`O*zx9sS+3$#pKi_!nUf2Q4VL^4j5aD)~#e z>D>WyncGGX%su(hx+;Y=m+?!M*8qLfkr(x*mRE%cjBJXF)`MzIqz=DizSq*^D}f=R zDdZ)m<6`hVkp^GX2PUN1Tt@d~`_Z~fn_&V@#`hWU`HiQ8?Q4VL z@zT1YQ{KF}SVIE~$-`8UCC^F+%kzWp;}kJpMxJG7=KB`b6;j#R%3tQ2jrE4vC^P0V z^4`RaQ@_PnM=<(fDsWQ$^1!#BWs^)JFIhi7jMiWxb?_zY*9*QUQs{SIl71yiZT$)$ zkMe?k$@Z%SUoPn8noPf5@a;8BK*N`;-+u5tn1b(01aR8#-etCan3|kazbC-=ate9L z_Pc#K%6$sHWc@0T*nKJZ;z|1L2cOB`BJgMMFWG)sm~Xx;g}h|__JS{+^7l*d-JU{T zFiF3?EAa9@_~`k-lgx!Ur`y} z={BBVHn-SV$5jr-%WXSj%6`&xTn0Wr>OgZDdCBSc9MxZ8y zr^)s167YS-XQbJ7xdhvW$^0!qZX_anXFi^65v z1$wS}@xv0ob=`5HZD*?9NHkUJoAGnEwG2d=#GeDA|TDS>Aq! zJnADEzGQiMFqDx;#nAAfSi0gZ0w1N1;wApc_|`f2Nbkw`q7FWKj16CMI?e*$V)#?M zv!>u1Cwa(l;-m6v2pV1FZ?4*2mfREn! zBK@!wKPlgjFR|re>3dSX*BpGL`(*lMU24mtx@{sI8I|lb&{LHl&e0O<_%YL>gZ=8IOe-vM`P(k6#)B%Lx8#440 zZpOICIDm%F8qgO93I|W|`vWBvrIjT`ap9*4;ByzYo8+zJB2y;zaK!GwTZK#3?JES{}Ko zy6VT`l-!rfPS`&q^Qoa;S$E*Ae;n}D&8{mu9$n@-u~+WBU|zQ66F%mS-o}vT5;w>j z_bfg$lvO6L7JDzqdG+a4iyK2?d0ySpI`0i6=X9~}$ayu79sR)3S66$Udi3ZSk%n~{ z*Q*%rcN$B3o7LyPJLYRVUqYj#%+C@ve_v zqmoP)&T5@Fw}buqu;|xW(iJETR`4_sZJdV7grge7E7svJipqp9VbzeI%!7e?qTPIt z(2i!*HM6G6l}|ko-hEzqtj9xNz5ah|V@$Qt_0O~M4=fu~ZHA}efEQIoSJ%lxo;Npp zj+h~4$Qhm)-mHu)Ush(;jI6AzBeG^@&6+Vg3(btP2Sqv_4jFk#dU#Umq2td5ueol) zO=!XR#lA~2F7d1G+MXlKu+Lmn|O>)s7Vhe3eupc*Ja&-1@tAQRW^jB;`JdRBh zo>Yf^ZlNgSacrOQx2e)3}J z9sDo|RB1{&@|y%^+PemH!U+qxW$GftAAq4co@SAPNXiwx zFyXAdebT#6WXjA1KCibd^B6c!*Z1mHQ5R&M0Fw01%{&I^^X|%Apxj5SMVMjb@MY!z zPgEhZGPhE7B%I z%Ee8gB5gbipnW&uPF*xY(7sjx2Zg}2uqldq=sH~_Yh{NY8rP$OY+!n8iZosMN z_{+81#O*{cp-v6i|v`sP?CeNvC4?=}7SUK5c}w3>Uv28h zkq!i6P4K+icb3grzffyUL%b{&H_T2liNF!}wgD7#Tf>H?YJc$rdZ?@<1$T(T6bIc# ziMF=XMH<7&k=BJnZP>&m-Vkc6+tkup>kedmb^LB4bHG|CmeM1qRzLISX*GFPF zZ5kQ5p}CC}4n=EX@dzD4jcC`ih|%7$?VZkh%XD<)yeZ-O9P3zEJq^qa8a5dXH8#dW zu~@jZ%_c{hB4BL{ZwxoG1*y=~MU^;whDr}{4t`YaVO|k+;a`EyW|ZhuMdI~-fn_t= z1jXJp#Z!n6{qgw<{ za@^nFFXSRR?jD&G%u}bpkNcM|_wN?+XeMi_g9pdH3%S@5mN&i=6Bco|U;da;9ZzVpKM+I>dk#kfH^lDCR0e~^ z#pS`G;ilTBvaRC_;X(0)vr9$qJM4-fgQdU}84B7`2jZybusIs&)P!=dfWFM4}jfV+E#c96FY;uwnKVumPNg-fR0>M$ope$xChTYm~(-8yK@+>ma+0 z|1pP8sw}w9;cw}1u#C7->0M{#gR}f0pKh|eIX{y8KVkW&&Xt=j|1>k@Q&s>jijKm3 ztL4Xrac01$EzcCW^BK$2GR)MO^Pk$5Y?tK1{yE#1HE}%)pSQhJ<De=<%8;Ck^daud`}rO6xY zlcd8tWYvmz4K-T$3Hf&-pfK5#|0N1?&8GZ=C@3^b1WLvDE zU#RG|a6`XH(d{U#Vo7ma>OmBgu^hiubW|g+a`J;J{G>c8yFGVd)>9=!c)p5T)Bfs- zH$5V+MGs}dh&*Xa7W8myYTB#&254HQZ=kDxtUG}*wRy8u^|Uh8h@8F~<{7DZ=?Jkz z9O@21q2&1}Bu8BtGLy$aUA-N{V#^FowRXcUyM}$00yLD)6 zkhxB~b@1N_8B)@)H8D;YHSyOwXqFZY4x*(?#6h$)I$cNMkO{q-oJ32zW+&CsvBgQX zG>z)G=qOaBC`_@zCTWqNZM12YnwxBzrR8Rh#F7W&yvIS)0zqtd5G@to>mXVhzE4Gi z@h<07LNhS|qIwhq4m0AsJA0|hJ0>7E=;KmcH2$DD16psU(F%_w+%^>sNo zPL0Q#Tku{h#){PG#c8AcBSVRyy2AB|5f|Hzp=FG=~}^_08d0H8d#3NCb6kejWxBLmge)Fb6?}n#}FbUkN`7 zbvlx!!w_>)%pLt|>VjEe4B8AzDX8TMi7}w2A^EKvYT6)yqrz+XI50uTH&D?vw?yGF zFgPUSJ8*8Qi@>?7r%%X>yyPTH?&^UVFNZT0-U#PNVyBSTz!`~E=dJX25Bkp~YFBTf zd#pc!ZI*|J`x3)>E2}{58|lm|8n09LsW{H}@9M?pU;ezJ4M_3L5L$b1q21FG`gs!C zbWlyZw@*jYuR|zaghmSSp_h;^k+Y?hoP)zc{szwK_0hJxogMvS3CcTs57@D7Xb^eK zG$F6Zpds59cy{%lquUv3VZ4Ihh)gw0i$+B)pV_muDHhM9eAI4Rc(o%rpgY)MYf=u& z5=YfPq#VHGzcn$6NtNcd)|N)R0zvyc+nenxr#zF)zqMv?U=$x3Y8Dw4Yrg4`=U~W> zt@Q2i`jne4W=$Qi>dzi|DOEfab0ivToibX*p!JA~sxNuvM@`Vs!GbCVE9h^%@@5ls z{9r*h6N44>&J6hl6Eqq_H%0lRHWQYUy0G0L-nQ=A7NwGiFISDAHE(CgZ_qRe*-Q!2 z_8J`=YU!bXDwNP>n@UjCKA(KRXw-BNjhZ_822!hYX(krxSsf+Cp^g=b)v?^kiK==e zQ@&tyiMB?XLb3G+u~1)A$H+F@Dj%33e{IyT1ZY);hBdD-i92M~BQxY1-bz#o)sZ%i zQ-@PE!i0j{j*TdB%$<(89f!%$7TNlu8$W(a@mq$Ut8J`lX^LXrvz3}h?-EajcbPW> zQ+~9V;T3!E7opRtN7Ctmnw5I{BSsQ$^-D3u=&n`ZiNz;cf!T*U?(0rjA2}rddsRu= zlIp$N6LG&nrAJEC-I%@)qoYz3Z;022o5QV<8sx+>PljAa{g)!{! zLziMA1CAGiziJGtQ~3L-!!R+F61!%NKTx(|rT;wAYC_B;7?EQB(kwV|n~Postu?6L zP0R;wY{jYH+AW8lmT6UP=4-J_QoG;&+`fGnJx9-uH@+c zEzO;;#E;%drDymkRJNnTv@b2qbEB@Kes0Qn?#1MV&$^MXR@aoeY@@x{N)vf{9CdJ8 zv5~zsFMK?5ndgPkXV$lvE-r80(1^9N3Ifa-WT>S~ulgzjrgqm8=~W2k15e6Ie%3#y z(uY4HBh7Iw83Co?u;m-YO;_?jG)hZ$G!ns(vw)Txl-9J0O7FANswjQ8KzRd;(t5Va z8BE4cnls1|Gg082s4qH5hLy0tTHwR_Udnt0)iu;W?;YD5$McqT&?dCY)Cd8CpN7yz ztp8x8ptfa0bz_)ThRTijDAvBx6OMk-$S93Ds!Z6rXn1o?IEqn&Rrp-$SRoorhzSF) zh}#FHvkuyrVOfivdY9l->Fh-v)!4>ECTqGOf8`1q{s@VeEE*#08}Og(&r4s>I-2jOG?95dUkrIZv@Ze38efjA&A8@;z_Q5YF-&8R_fUtt^+P z*SzU|?OH!ObZS@nPeb0KsKo6sJ;b1b(Hn}Pv8BGc$e*{$wXF45%S##0Uo>8!>{Udu zzvb;4!Or10fh+xVnh>s38lq0)0f^m-fggI>dWkVFZ%PxcSm8JRyHl8$Y)tLHvU1n< zp^`jAQ{d0ry>g|01rmg_gLDy~+$kClTF%v0u_oVl7E-h4XWuAxr~yD?c(}J?pc@MbTSfLWNNv?E9(k2K z$y6V@)6gR%LgYeRJnlO9^+wpZ>S>R>COHHLxH@HkJzjZ(9e|pmDdm5erVlNRz&@q$ zzk20oZEkAFO!eoAL?^~|oEs9;9*^TN!CP^}(YI;h(Tda|#ua%k3>uG5F6EUB`88V# zYD1%YYD<2~C%@%lcSY7glfh~h4VgizjW`tas~rK_%Hr;3PzCUi2d%aji#2R%rn z91?SnPnwXXLULKyt*)qgD^ot56kv*&MAau}$Ul3IQ-{-n?`jmk38e|8SyVkbL%!uX zR`F4yFH2QU@f_f^`5E#n-rTOiq1~jfOJ<6ERIjYWVp|MF8s#4G;slylgvwLPv5HB3GD++r3T@pdK56cH1g-KI z+lzM`jvjFe%%x3C##81D0O>tU`h=S1I6mf40|_-!q{Y=wV)aiixZ3lWU+`ce^NSuD za40^SR;&v(MHhjXLkyH+ ze1bRk9>>cYwe<2cX68ZBeTU*YA)oL>BmUyTKuMsqGFXPU{3xp7Cm5Aqd&!b){Km6f~BK>SI6!Vo`<2K z_(N92c{osOSglLDRmsn%5vKMIVuoWVI zLJ&KaM>&?V5+gr94>qB<5By0A{Q#`d^$pc+d3dirP=G%{`csUgpfgRO$dW6S?@B)= z%F#hZdJJ8cygFPod!7^^r~+tdt}w)}`?^Tr(^`YJ>Ok=>&rOD`r) zl+u54^}n0aR<@;1cA3g4(>B2aDNSI@Se1s1hbN}Y7BFdeM?O4V-q^A!uD^xYf|qw% zn&UVEINXYQ@+T?0Hb>gv^HO;PuS&KwH=c>P-bq5gJQa@;gQoK))kf~cUo`&ibrCE) z;lK6%g?1*dM$xC9>l1zbaU8{l#*==j-U@VoH)n5gNPQk_Wd-dz51DYsYb@)~h?C1+ z4>JlmL>{&g)?s<6BO_zN@GMHo(#u$5BO?2jAl^UnMR$~A7&h+!QYQC!v!mFknA~%a z4e}E2f~b1T_3AiYNP?RlbusT`^1ljhHL|0+USxk&$ZNgxHATO%cCV1vd$aTZ7GNzEZ$m3FzoFsF9Dw)Oj z9`zSeejhSlnM&r_ZkgmHnTzGbq|>qX+2tPjW5|5QH;>E-`)$QG>niJ<22GXv9GnV1 z8td)r;jH#7pRE<|?87W`cf6}(q&wc-6HvCMBQ!6^`!eL0AoG=(**T#if#-@!L$`b6+M&K~+vX}A z_-OgkxxW0L&B|4A?ziHky9^a4-DP?2nuUkb5$ER-Ct^aJbGv#X#{;TN-ca*qEg`*`B*?}4IZ3uth$Z2Tqctj=_PF3EO zGvvib;`y654dJT!(gkR8;b^yhKSN##*)PnWm($ZT+L*x32c{+L1EH?JW2=~_YfDcK zCf{2VI}^hr2`Al~Gt{=Lue-Y+PZC%1)rzsL1FPC1`-Lnj3Zr15#q7l?kU*{TSt3My)j$NN7KG6JA2N2RevnYK6Z{>rtKa(RjdCsTfUCyuRd<7 z=sz~?==US~t5ZfwC9!&ryl}oR|I#H>MLKitbkn?8F3ZlGnXULsXW!F6O<>SrToQ5YUQto@_UX{mQPZi zvio;)=PBWFTpWKNbDGp3OlRAWs@4-u{OMCVa@mSx{OJ4ISl zDZ1@Q`2y1N#ifgLV(7k!?77H4VM?EYy7wWg`0U%+6#bdw8CF z4YKcEwm7HRh!Hu>owj8>IeNVgZ*H32rin$zfC5-EIKtfs6(ZqZtJ`fcXw=!Isv@#Dnm3bTvvifC5F3ZlEl|mua zyL``l`E@AtqulfqQiB|aLewd9D?}8_I-9Z`)_D&cq|o=~F3bM-5vdfSs`J(P@)uC( z+b7P>X)=|DNS;fz!Y&f3Z+CvSeCHVSdRL?w z2N@aJz;UQdm@*D}Jb#`oFFn?mf6+;4#=#9g$3d>Fsp3#YJG?+%jW~XfI2vtR4dLC< zguCrZ*Is()G}u4UWS?IkZ$8eK|9svwqMFidsiPvxEnFx+kErfnIgO~Mv|h@nlmRbT zD8GiN?#g$~_~@3(p05iYrLy0YIF8TETZbr>8VMzg#gJ^o<>XCb8p}cL0 zFaO$;T{Az)k#dSmq>ch%OYg$TfQTX3W|wc3toTv#NyPBxVTxe{qYW$NdD{8k|)n#s<|deRvEkQX!$H8zkG_TyiQ_` zZANKjj+~*LPB%}P^rebQ)sZ(GEx(rI%l}@{lu@yHtf=_eu%aUOlu?nre2e9Mi0T`G zDWhV0Sy8Dc!jUR+PZgCi;Lu|EIHLM^P(_t`dOlUg~@Kw4D~WF~>)f^h)wi z7t3#);LE?Hcwus5WmhDrim8%J%_meL@&>;z|Cc3;Cr{bbHp@v2B!;){))t(XGmaTln#ALd8zqlAU`Yl& z@>uzOM7yWVKY6t2r%_k0^KypKBN*b@BMQCH(v8frSm{Q0OLXHqQ8!hEUwW*(aH%i< zrt&FFl741u-R8PZRo z=ovV=9FA2f{di#)h1x`a$8N)pa)XCPld|)cKu64`(RZY(J4Y4Q$WR9+@sjfLyT{2( zm;3VXt(>M#sq^>XI!&sL%DvVl@)~IK`08nDlR8J=jW(2DFE5d|K${;|O;ejxtB5&i zM zPcKP;zZ@rB{RHg$u@$Z3HAHOKA*wE4D?gmU;+Y+m(BhN$mH2zs%Ih*#&>I@6D+SIh zsTCplu2(;^uoY|7cTbh~W~`)@U-h`FZkL{uAbxDYo14AJ(>*e(5Igo-Rf4Uk{%E~@ za14Xd{i1y|v3&?@6a4LTpMHXqqTqewsQ^G0@}OK9JbjM0*u0 z2d7a~{d^r>F2~1YXM}2ND@<}!qQ=EUscgexWkD=-lO5Gx)d-2IuY~0PC~5d6>)lKH zb4b2nbfZnJUYIr$&BOt8wTu{!t^p zuG9#{HXo8L_SMRV*cOK<;R9j$oVEnE5<8Ua_^+`172DwuCA=M$e^nBiHpFVvRYFwV zSts|*pmNZ(AvBF(zpj&4%)rZr^mHJ>^yuWOzw~gB%lXJD0_v(8>*ar_K*;N~1O2pK z-l`RB3{g~66Y1yAeh#&pb{|i!)kM`z4e|~v{A6~SO2A7E^1Ccxa>Gs~;O2;Y!f4P) zN$5+N1fnJ-fk?31%MtlgTL7hDx)QECUB03vAeSdG;zZLuak_kyL&ee$_0H+?!YnFL zo7*PV3KJvw_Ii0m7QMFG)P#daQWqs%q>_w7r3}V-bG`iiiTTt3(rX1YKA|3WZuXle z#?S^VmZ;h7Na2>cp<665J=dC9^_@ofkrgXUaOyMZ#$)XY3a(mEM{sI8I=Z^3Q8w)* z#Qe-xb#art*CEDg;xATWR3qpRgO=Vc=C|03B>QaNnunU?7f(8ow84kM!`t+DOC=+M zgF2yoq!VzqXDHIqkGU_t?@Zvm7P020X8Euyuu2UjLInm;;6;wWbgu%p4-F4?V-G6~ zfzWcX121~)huD{zN_>MpcG^U)WyYazs2e!pA2}BnE#ToMVS_!gvQpzYwq>5rpSq>&k z*{iMc@_Z{BlTt@QVSf^uvV0uI)K$F_lfTPX53Kt=6Z_G9Wu<;}UA<{~a@DZ9U5}~T z_4_jIyVVH0eK$eJcp&)_NhQfAd}+T^V#t7qP=f&KKu2>P8HO1Nof z%o{t72bt;vD1{s(H3)Q0;~-;f2uB3&Ka(D)$T!FrQ$}pn7w8|S6*1Kyh#1unMT{OZ zMGTlE;va96A1hFqpOj)VbQw%DUfR#lPVi53ynqSuQZp^8uG%C&wd!Q5&*)~L80VbtksZrLnfTBX$O>KpDFLshtG7@G;0=R0o+k*mjgdhh~_ZW|gQ z^M$Nk#MOc~O%oXJsJ!n~On93Y{woSbaHa{jCBt2csJavO;U?A)XBSIRLd1Lp%d-6i zYkqa6yu8q*8kS_a-O0r?K}yZ?mJEYwQpNI?=)sXf?Dsd4U@bw$E|_X%UaJkllxhz< z)o!QYiGgnY6o@r%Zjtx9Ro7OfX*QVW0hv7Lwnzvm1t3k!~0^!^Vr{na+B{(XngCHV>*X=qb{TLQjC* z0qwS41a2Sa2}0FO>~=aF^>+I>-nGNGuV`L&TX&sWR3|z~pm(AfCqM&^j^+I9tQpI) zTZ*bK?UX+(RSivYn(U?~GoU+~l&1Z{l_qLk%&d&+b)r2Pw`cTGa+M#DNh&`uqw4qF@|806EKabpY2LO4Cp9v)Xh~iANwlJLpsAyD*bN`0 z1Fp$69!%Ewgsh5N67mm8bB;Xl@J^U?L?I9h?(dODSznFDHq_LFV=){tVv+DM+lD55 z&=bcVMJ=u30^6rC++2^1m^A(UHeK(I9>FOnZ8Z(zeA@%t`Cv;Rah^?y;nU0wjiFX? zu1#wTLCuRY(Q;x)E97}QU#UZ0dMHayf zxnkC=Q)hXza4x4llV*X>K9wfZO%h^;O_+!Cr*L8o9b-d5aQ3b3s6oJNNgOksL?X;G z1j8}gNf2U=aT4=f;}GIVb8E|Ck|T>Mju7Gm zeJh0D&`M?tvD7$b&6+c7HbgHwQmMJTTtTi6K-NEzZm{7cfd|q~Qa4Ce-aO^8aseVn zvXF!MbW1lUYnl)R3y{gH7C;qjueSi|pF%z*vo(K_c2J0bq2m+v1(NhDULc51h!VQN zlUj(7tBr zb(4fxYZK~Wt5a>Kt?D|M>@>FrDNE#aHd(7n#E?yN2*J^C)ou?Z1mqf<%tAn{Jsw62 zpgd+HAHv!pM4e6DeB_x&ZbB;SHOV*|NSFy1u^pt?=?*8NSg)NzG}4VXYt8HuWX@^G zu_l{9&gP@wPerMPZm=l1NR?2Xr9zycos`wBM=MEGE@E^`H*K1R6OfNqrD@}0l%`FK zRaxI$q9l2aC;;P`#)0z~`4&pQN8b`dyS^3Ty@r$Ge4lX?97#@`*+`F%CzBj!X@~ad z&<>)b^Awn;W9?G6h^U)xD4GP_U=IeLf~^Gfp!fP%R~$#lw+MB%z7=Ad@h18G#-U^0 zZurS>fCSR>IH+zQW5}d{jJ-oUPMf_3j$!RsvWWB=F%BU{OVtxRRt1%W*tu3LhQhn% zOR6|=NaY&7fuYrPsGpN!FpV+%HvfA{x{FJ@gYTuo#}r}JDopB(_I338SFIWtjAN?+ zED81xVv|d(QI26551Z>?Uwq}cmEKaIH{Z5*3=PqqsUy3$cMkTCz_+`v1J1FbA#DCK zvbM6aI8dPel$DiW=Z95YLt|^PW%_7hd=*Z^TeYeO?ih|~ZJC7dM5fwH1tK>&wZfoJM;(-xv@ zPf>~9H8{M@zC%dlMR(uMzV3wIc}`s6;GridzsuozSWwdX5BBg=-t0Jy1zb$vtr{7LGf0Iq5cAW9p9@j;xsR$)LlJtc* z?cAU~6<0faw3ikZ6$X&s_t1xWx{F zUbGZ$w@2LI@b^MOp2ICXUNP6U&%RN^->~bF|zU*?(6W6)i^ToL? zceZ$+%e_FU?Gc}_O)TbnD#eh?y+{OI z?qcz}okid;7k9YaIila?UM31%?iJz~gtFMX}4hM7&Cw%h!C5UwqN!&J_bL zcY!#?=K*AL|4@637(3m8vl>?dpx;!?th5Fcea6$d0!JV=PL`Y7WQgn0J<&Tfi` z{OM?TLRUDXL4^aVa2Q&uaB!<|Kot&HLE-0OSi^FZ8$CtkhJO*!(RD2$T*&b(7vg?$ zFA?G)LLA_#;x}~gDLU{m^2cuLRR2-<*^KiDkHaXI@I;JL*-iQ9IT<5Bc8AzM%q8`&=3W2E!_NDkG9gky|PGX9Kl zX@>R>GVW%)obgGp9gEsP&xe30=UjB8Ox5`UDjkMUy0w;AW4?j*hy zj3LHvGCt1u662eU^XKVsS1~@%_)EsF`PzR6;~R{gY)!v}@jAxeF}}^%gb6s(>wS!O zGCs_>1a%jQNjBheVkJj`rFdl`vllb;9{*JK* zZ3xlNXS{>)6~^PyhLHcYjNfN0LLE)?vl*XYe3|h`v{B@r&v+K&DC4IY|H$aUA%w&q zU_6g;FXMfTPovH!z5|SlPSEaUjQNa}j2jp)V!VOzHpVYAeuwcz#=kLU`nCMIjJb^Y zj6ud4#$m>B#yyNzGv3em2;&bJUuN_z)$z?@T)>#i*udD#xRG%y;}wh_WxRp$i;Pb) zKEwD^##b4ST&Ckcit%{HLdGcLM#lFs4l;g}@#BoQFy6`d9OF+Jf5G?$KZaSdZF z<0i&I#xch8882b{IOCm+-(}0%=@u!RnpbO~}WBe}T^NfFFe1~yPf#yGsaT()g z#zDqw89&Q-7vqDBKV*EFap5X0w}7#h@eIZ;#vP2GVf;4Z%Z#rx{)2H|p_ZG&Sil%( z+{Jhm<4ufTX1tg2O~yH=Xn8@#8pbGNC*u&~`x#}C4mX$aSjL|-zQQQ+<|^gKwTz!& z{2F6jQ2Vzq_AsKmgYT?({DDE$L*y>QpF+%L620024i6P_tR0;=2XtrQ*5Sdip~7H1w4HWvjrVsB^{$VMZcF3_<3uPba)fkFK6fF^ z)-hs;cl2zk?c1H$vZJ9qu8%%R3ZwUoM1Wnrr4(R$tSdG?+&el@Tpr)7b}V)Tu$Tvi zNmx7@ENiGAFWbB$n248Cd`^wb&XkZ{v5WlTr*}nKw~TEZjqS!BtweFM+uK?qz?mWP zjgRBF&hAkCU~YX+iU8Y3`bIEUx_t=q@WX|@l<1u*SjX0}Egg|_c6YaxOco60>grNq z!i{u{L_85aeJI$xv9zx{5D$|Sr*7u#LP|=#V&Br#w{2UXe|Ss6(#(~2Y&6WryU2wB z!S3y}6B-p0UCywcA^Hk+L7-wXI1umekK=Qx5moedj`YTLSwgv>6PT%7iE11!)g3bD z43FgIwly^2u-(wk;-=hKZZw=5THP27=5Aiy7zpIXa2E-O!-3q$rd;d`9otxz`~Fzl z`kM8%+F1@~Lt}0WZ9W~&4OfRMa$Cb^ROCim!?B9oFbQKI29%_GMbwU zEB5zws_B3A9wfc}gX72&9i4sgek=}P`NO$3;3!F)Z1Z^K>XMZU1E*88+&0WLC5?io zQ`9B|@5cOoVXq24Y4%QdNI3`Jo$7X}r`Xde_DRa?qcrWOfW)Np7^D=#PX)L#L(YF4I;jerX68F&99qsR z0q-W;EdjO#)5&x5z^D1Vr&WF1&$reEveU^-I|C6Qo#!|Cfkm)%o>$kAxd@Za^XbYN ziYJZdk-}I8NGC7&`J=|{P@g{zdq~fp3Tv01bh6B;v7LSN?4*-_uF&u9`BS>PGIp9Z zuM*(Ofi?@b1#u})vkrpdH;??@3=#Nd->#`DHQfu{9@YeMNPtzGFndpVCT`tZYnGi(P zeHD|?sUJmV#h}2%ukxyL5_$^xI(Gua|D>sqG~XA%crIn9 z8e(YU{&s%xpq+Ns=o`V_LnC!#16`wiH~_cZ^`;NLyy=Fpj{a`ig*z8toQ;Z51IC%E z8!RNI{e-W^yjdhNXCEQw%Y~k!)=eDu4)#0#YBRs1l7w=O1&c2Jzj&Vhs03e9D18M}pSy&%2`eABrQvHU&x8LXhJ|iz#zh10+Q1xdn!37~zTR%(* zPO2ZRBjlP$fhOK${q6wY-V}Vv`mI~0->opLM&6aUaoR6qxvgIS%#-EsLh!w8gaM7b zWc}U%-xVqNlJ(nz#O_PM7f;e}9p=AH{+haxZfPN%i|B_+}enKqGI0e&8EQ!I!MxStCNck%I3U(46|UjoS4y9sx_g z%J&>C!*H6c2HC}z0m8WPboe28!cpCc^WKl=4Sa2&`|+b7 z^j!7ghgTP@YYh}Bf{V(t7eC^oYJD?)PQHEzU#5eP>P{!$P2i*OB#(;CWb!`akVpK6 zFInER4tW%h;X|=>#rq=oD18(!J$94vz3SkbH3i?_9eh;2jJ#yK%)VHl>#O5MQ#>hO zF8E$%J~W*cUvhdgF0t)L=`ryx$Gy|evmJa39DK=kSqMI37reS)$xBX0F8EA3&~#49 zw+4K9D7a*28Y>w6lI3+@YRf~@G%4SC4n9o@DZKT zVfqo|PEN-Y;M)ho6CYJulco2Hy>@yj4-6j-iM;rk>oeec-0`5AI)LgHC*J@noExZs z@@4o4!8c^+S)arwJH`Ptd^8tXgNzduk?QCeA2R9;cy_ZRu;(toi$R905z z_m>n`k{7PCW?m3(tivaZmQ*S7EV+t^IC1$(6y%9k(IVE}GgQA1zqh`gQ78Nt-r=hg zd%Yi*dF@YSit?u_B3D+o|5y|TU&=kIH&J-MC?|)7jI;#Ysb6$Sht7M7mGwQOG{H5w|X59r#{dJG|D4vYEKwX~0@4(W> ze2-T9eyIGe&pOL@$7|ooxL)}6-JT~ZSyHmT6yKkoe)u;B4ji~3118gXm?6_1n43)M zI&2@-yz7JQsO-{(lW<)VR;()Kwi2Bs!9*|+?dG$O_I4p$bBnsf`P8H0-RG6ZdOY+^@&C6r#{3~&|2!N2z_M`>;z4;n;6)|U z)pfFv=grNYgVub8oZ*?_&C1B~Wo2f~$jZt(B5P*WtQoUuZ0YQSk&cH$MqZL0o|Jm% z_zS>muKldOBtmA?!*|bom(UmdbTYGcDW`+;z-q>H|C2`v8URj;#XySBbVMO!|#jwNByt7ev z{0}7d*&7R~eTM#vXxRUB1iQOxu8)J#PW#%;!?q#nuB9i2GaK>kr6!$88R4GQrs`1}w*`Bmv1_y7o^=Q8|FTurxhMe*~BF#bX-cO9GF<_&gvCUKcmx6<}2 zdVdI5&Mi|HEB*!#RrNHB8DgN^(#tl^n%yV84~a~fxxhCkb0HiTsJo+lUhm8WxRu_~ zV{reB$Xt+lROX3_a$M#yK%aLTXbT$PJC=E}B4jRT_MUq}8z?g}%i-DTJwJ27q6`ms z|9Wy}3wUODXJ?)OpCuU*qAzTN0C>;vURZ!T+!OU5F}g*Vvw;gUtMRuma{<1{(j6jd zk9^{Maou&-(JgfuJ>q;n;p6%~kMIe7zmV`*rV~ETbV4ew2urn`x@z&a0Y7O^SWu6> zT9G#5ueuiFZxV^mg4;JO%Z#Ico zi4JLHqw)&Z)>~|JZ*!r~YH_IDQs@+U@Qw}8{>O=KI#AwXh_fOh6r5Q)Be-mll;3l>~z-a2vLH3Ae>-q8o5dJidV4 z9LHCuI)&_22d`L5T^oIkeGreNPg(u=logRscgK*m?c?=~_Atc7AJJ;IyY!p-Uf;?{6|B!=_1k&zpk z+gRaHv?dmh(6QWzc0G$2?H$|R>Abg0haJMLdwsHZEUcae<^~PBs)iaHS%))dq)|3 zx9P>MG1IV(=XL_8VsUcZpD)iQ2PW2D+u@{0nMLN17tQIM^1 zdXR8Zid@K)cuhREp{@>}R>%GQ{X#B^$D<*bHJGPPvLE*^U+&*63FRdslM-&&3A(0l6P+BVF9!UgB3@Bx# zrNy9qK+z~Qpp^tGODfCCgO#OYLSCqRC^af7D^mg$B_(C$C8)`Z%Zn;YO9N$rQbhJa z3E3$AC@N0#U1pP$toR|@C$%vzw;9s3=|}7kI@!v!SK3rgJ6rfF+k*|@H1uBE*D`{( zeNA3!dtak0X4$}){aOdvZTycpd{Sk>bq;?^hl6FrjY{u2D<7QY5BYSH<<0q#f@odmZnHes+#quE`Nk|mXx2va|^m0AUh1>`HkFE(-2Y?7M|Z42O0B^#sTfn z3;L6BLIBr`f03J@b}CKYV4ox%-XW`2#A~S0!cWM*69I+Eru;8akZU&OA4EZsQ53s6 zr{H@$loU&#YV$z;fFj#s4gEqzw}l(}MT%}mVHHb?<5CZzpp51Ct)inEd6knNRN*J( zQQ7Ue3v-JqA;R-j+?w`RPjBh5Z7q5z=&`uRp-KD8pif#;(_Y;-KodB916}=N-3g3N zb&sa7SM_)@)!3H4Tju$mdFcqTMAYDm4IFGdFuK}LJz#Ru2ONIvWmD!K8^UW;34e({ zuaiD*Kyw&e>2Dhx><4r5Y!8y7t_+#UBbTmT%oAV$I?{{xtuXPS<~K0AW_Lm|WR^9~ zVeT0g!347@G~UU`vfZ|zD7-4-*bDn|AuIgkLVUa97Ic_ z({&UMnb51rNwlj?oG!qjbsz)*4Kqk(+vzMy8V*+wx+fr2mX&gZ7 zQnb#8&xzGI;8=8Mn_`g|jTA9nY(T%3UzOEk!X`b&Da8OG)`T_y3j-)g^bj{jn!_OU z4bU5+C@|D*4z;09W-mGctgp+#acVr?+=5qPF}kBpFHTJD9~nw?<>5rO#OT=Y0IHb~ zy7aMdEyZKL7s5y&Z)_ydO+9{W0ktU{TA%E_E77ryyfKxqp*hqTsc#O~s-ZzKMk1(V z^Ybv680zTShFJqD)MRdd{z~{!sMC=&9fp{bV(#cylMT!YW6;i4N;yeL+?N>6TUiBa-$-X((RiJ@PsMS*e^)PR zFMnRq2Bi3A2(3N1(C%po{X7Y6I;f`I+oz-H*C7<|P$PwS4_3&R$l20L&cR_Je*ANAnvhpy(2#8lJiGeO(d`ViFkZoL%DLMaJ->;+YLUvG z_e`-wCFP@b+rn!J$pPKL4qKCQSQZef{vqW69{;V0QA~q0x3#u3;*|l~irPL8Ksn`^ zWd5x+g9D@Z&{4CPuevQ4=(Du%L>;3i?~Gyx9aDKUmPs#9#%zGedsC1dYbfO;J9n&4k68E^OV17qYvy zMX4m>%UL66&D$CB8#GNqHdBJMy+#LzT6!p;3MI7JrV>=O&nF)+8Z{k6qo$6&fz;|; znkm0;)KO9#>R6#z9m}1ZsH#UYn1GP4e+YJ>>|xg85TYVn6kc{|p4Xyrp+bc0tt)x6sY zK$;`7+QyoerYL4ATd8^UF7ae|mw9Pt?JE@D9{feX%|t z&|RyL=DM%D4|m+xow7c1NdEV#lC&koQXnlsELZ7~5_LBw+{5Uo6vZ3j_2K4lYorD_ zvCNYp*HQnai2E>R^`I$46K?)eYV6RZn8<(=(BQ8c!|D|Ne(Eqx45h@bS>q3sZCL3) zkF=T)GYLkdn7=ej1l;DLmqDuos&`YgL3nql5~SZ{^| z0bPJl-tSfR#vg0n_6hBoE%o27zIh=cb(J zUQAy2d>r{|bxoSGHwJhSW@b?h%`sq&_h7{Z&@sjU{UiR-GgJD{fT78{g_YF;U*LH zH;J=2{AdWQxvrv~czIoo+I55M@pq{bgR?!FTc|+%ujS@E#ft7l9-}g%Nv+BEygfrW zZg6CzuV=TiT%KN~ru(&P{p`@GUFkm!d5fYFx5M-hUE7CB@(@jdKX3QSmHrh-5RNy}MSyarXgp{+S6jilrx6Tx`A~+H0Bl*( z(f_YVh2Gc(*)qLUOco5OxCW`f$G_9bTCgYOs}=xhH$ocrtsnVU*di%MtrCl;$`ph& za?}b2?LW)f|I4zo%PNISQ7EZCm`d{`ZYcZ}R`@VKNBSw!Imx1X9FLQ!wOkCgKlHjA zdJS}_24L!k+SH4RJ*iM>0g!e-NgEvAPLCMo1x+n5WkqX3B+E2nAoekc9fMqKl9lNG zR}@&<+lelIcx~s@*>3Zxn#*z`37_@R+C*pHX!?fX04}@OLLl>TAJw7gjx^Q=@_H~m z$6XvptL*Qg)u(=ELrue{CmkW9c|8SfX$LOww~>ISYyrV(L|ve}m%5#X9M7wnb`pf= z4-QvUc>ZWRgTiy$OuLtgK0oHt(8sODUktC@a|7v30yy58q<1toW4?jM_G$I^Iru-J zw{Kp{&C1YrvKFwCUf_+YE(;9=E~91C`BBYIgsW*GHG6*cjbeuy03?QodpicYv5>G; zWIuz{R^8%}SILu1^`ScrJwhTxF2u#-uCr-xgpI47_Q-3JLvVnrQwG@Ml{eS{s41FK z{+DU`(9#I(Qwsm9SAN#!riRQ^f38S$Vw{JyBZaa(9>;lyx8k^_Z_~u16{$mvEAm_z zG#;N^$}1W2Yqk{BhDP_)mi&}Ye#^z~imZbsgVih=t2)lQzUaf72bQk7nw=^lq;fo= zlX+dHd?-2SK_caln0tKEgftbB%ffDTMb%rG^68`iQ^X{yJ~>1F*>jvaKNoygqxelI zO(@Nx>d_hUEzhxvj}m=Zs&b0wKvcamLw?1Z+ch|}oAhJk0q)nTs1(Cx}z_Re}uaUPvsv$Onw^u2^9vqKWPZ^@0}jPU(~5PWrby$Nm`(b2asc7I*W=Cbeg}s;%11r5;l{R5{EXrN z26*FW(b4!lW{81Oj8E|9-s5_k@y6;e2C*%{JXvAM!7$^ypRtC%PmS06> zc_qrrGah>RNh{M9!hA=Z-kR~3Vt*j{tiun{#$yeUx;BgwaT1R|K+!+vWC)ZRhCrEN zc;3UyO*EsPETR$;e&pduv9L<>ZIrsAaka}QW&wVj?5mPl0iXXyI-?u#)~ybQFx6#6 z)nyo(|H`A5cuOb)uxJ>IG}U4enBFL-cg59uuvxYh@)obopbgC_*P;i^YV@a=&zg~O zO|W$I@9Nk+!t*dR6o1HyI1h(|4Xbr&w<`JhG{V%r2=K5KfY#SyZ6+ATrp^RlAzR5q zh)2A}r=_kg7PdmhEe~(P2MX{fNPmiv z6m+I36j^em@?Gi2L^(RBNROfGl2?a|X3vuX;Qbi{(9&FCh+p@0k-(?525r@cs(~#n zl?JDtno0wTox-i8p5=?A0p0=FQJ%N6s9gKgmi?|IUD7uSjVw z>gKzZ-KmWgD4W1-B#B>hlYAuXu5xVSIvVQ224=x=(vR#O6GH;wO>zD8!WO)|)6yKrF~;Fm)RR9+;k7x^2A`M8BY0J^rMdA;%=JzZ`sJy3lo&Lf zH>oyqFaDzCbdQnrdl=UH7uuP;8bu#cu21y!$8oM48c+JAdMnWV1)9B;BK3L97M(P< z;vp06cs+F;KKv(_y&h&1a)>-^Bdo*nQb$I{gyC6Ke>l=HIyNG*Zwcc4BVTk!Ifh~L z4j^T6k2gEI1I;wtbC3=467Pbjdd&6eI9^DCn;vyB?_~173T`#Bqq<&Xe^tn9z4J9i zzp-|&kk@;&^Z(?Toii}Dy{%&i>+BJP#4hJKLwFBi6kYd0=~OXsy++D=vV8duc&8BgfLkOvN#t)+iNsOr*;h&VAY@*b zF@?-U9+#TrB$@kD$;6)0*}stT`;hs{R5H(Y%OoesTr4Lh9eX&4>~fF%F=RgDn@8q^ z{kGD_sg!k2gQiM-&d}hsTwnKNhBcjkR(a<5HLIbc#2 z8Cg_&DO*KNhO$}MD?bg%e@RFrn>FEBN4p4uP>G{f4Z)K&P(?c;rm1+eeb5jLc8}Uc zP|1A2D=$g%<^CXX3NmZsP=1iPxjJ*l$;HQ1Y54l|8p!?pv?<6{xgA|sm5saOB?&4IObeHJ8 zD+!g-5$COl6EPu9^3PCl(p{#ClkWV{;-qw5;FDJ%&L1V~I5W_W=ycMZj+5>Zy|*Nz z(mLW?7;oYve;p^?={V^wTAZqE{mmzDLY#NZK(*US?=qrzntCt_ohWcz)@U}PU@Po6apt+-pOe~z5yh{?~d9zUeQl=nWbziywO)MP!)@up!63Bio zH6^R7Yq&m)%>+zO*bPEWPuotBqFYN(7AD`D!h6DlLt!V~n>Em~x4W~m2Q`Ts`Spsi zr46gvBJH_EDhk73q0Y3Szq7jwZv~rpl38j^TgNconB~}KifnbKTG0+D5*lpl>>e$$ z3yi9LwTbc>Xn*zWe>d$T^e&Fj+c!}%(Pqm@k(L^oss*TJ`k`Ev$H_ZRf zONt{`R8kHl$>)%i&ny^Un(P*3?hNW!23)rGgO+0-knX$XUZ=_`F+R!E0w1f zb)51VG#Jw&w9)0jf($xgc=IZ9eoDY|8rd=6>3ZBa&6Glp*>Z6@+hm=aY}(_#_eB#HNsX$Z;q{gEF^5M6s;1EzMz_Q{f0unhzDqT+*11J@<8(_c$K*u z&z)hrNT{*h*=h1`^D*jO8e<$}WMl)!p)z68IH-F5GEMGZ;LH8^aWTfh9Y4oGuEfdW zP({0Xw!92+yoNaHZCefC-O;eS?~2u4`q8PsXS~U7oh@%T#+UnS&J?1W)NIkCBFm+x z%UcoEgUhB6)uh&o8kI8OIqC9lM0HoLYsN?SRQ7yb(Hxciro^fIk2d3jdZwp3?70~= z!-ORTOb(*!38^agYP!57)0cb2@vfPl$VfRwCQ?U%u%&n4WJ1JH)MA%!m8{Sl`8Z;D z`vZz$2+z~u{%8?BI7j{j5&dHMq)AZ|L3WKLCztKXlR^_jxpU<&5yOLdt{BX7q^XkJ z2pD5Uv;rv3_!c*^5x97+Jh0H0dtLsdlDP~U$q{vbyksiCznv=|f#knVE_vb%rj~1* zWRHKqQ#QHHvci4g!JT8;f+<;} zm_emUJRZ1F@@N1SVbEC%x(OstQ ze8=min(+M#&Ik*;*3ySWqUMgyqqW8}A?+kcfu zDTpYr!{NHV&hV%i31ej77;-pPrF8YeE(%rQp0+W=j&g%aqe*Ewna~llY4jbb8qQI} zH8jwMNxX=>y#E-vf3Yw3zExAyDSG}MS*HoLQMuQYDKCdMkF1`eHqmqR{b)n^^-`w1 z5!(E;Vv5>CTSd%@A-^WJ4d!h77Royo`zmf*BVYF}?da(q2&vW2el>ETrXzqcj_dVP ztUQQ{pRd8^EpC1!jn+5D@ndyFR9v)Hek^W@mQOELKt8sQ#|mfwQMklogAY-0?^^lE zI2Ooc)QXUN*Q=t5*xojka>vww{7=qT;vf<@xbQUh@W|?H>`s4Ap38ZIHJew}iC8hsA@t_4AoZMjg)ng!XmqfYUt#b!|PEE93k2Fy4a^YaZJqA94j& zsiA&Q1qM*yxsJeeuL8FY4EA?o&nrAKq32=;UJN+|v7g#3FV0aqb@%Owq8BSdx{)5N zo>2_~UfC?aJWhZ^Hx@wpX#q+_R<+$yCz@{eG|G3iXbjzV>)cmnGUjn>g~L;o@y-Bd zNPP54;~cu}=pUk6vF84hy8|WAm~y=C#s|j=*cQj6 z5n255Ci$9Hf-D}9GKvzZq8Ou=gNagheY3nM*UH9-)R9owpM*v&A0J@qDz0sjzt2?_ z*8N_JU3C}a>ZU`CP#;epwwA%06pqAYc zU-8*3@}}ceop)4AoP zt9(9c#8!KO@o`KMQwxHK(F{?<7%@}CfC(bLaGShxxyt;A6q`qv{utw>{SWN~|4hdV z7#A;f(_+mv+vN*+D&CIn!HyBMY1;;|i-4)9IhjOWKho8OH(zukUymaAT;g8h+Kg9B z!+3B}nb@wF@ER}tk6k{5<3hMo80=6)H7>Bv4Y8h8_OcWuM5HRnPMg1c&5NhVi}GEn zVJ((BkO1ZfqH30tIS8f+70b!gPdN&)(ce&*wFDX4U#cZ}tu_dgsy*mbyOn~6`#N=T z7Hj^rLq6zMU0apr*I=H5GOF%Jvg+I!M{CtJUul)EyA@KloLrwH*wTJtq}2b@YZsF?-bPK;7HqMZzOfW)g#r_VeRqra$t$SA?y9>43dIPw1lxGH2 zdq3uMI2z#AQM_b_k6zJFj9GW>T2wnmJD|6tKPEs=j1gjLT4F+W+J=IP!)@|MC921W zOq1Pb99C&MgaZkw({QDUx(PGAqK1#?7)I?TbIiV_PK`X(*vs@LSnem{U>)~o9p=V# zY;!%Wefr&K)$C@cg%c|7>X6r$MpxPDZSE?hY>2AzxFITO1?AAkkaBj9L&_1+PJ<&k z6RUhsMyPx+q2lFE`D&@Ei{q?p`l-&M2{op!DPn9sfmW0b^jVY+y9c9mz%{YP{gE0U zn^=BhSbibzcp9(M$EW=C@sRLRsaA7u7@}>)yqaUk@DLtaW`}D2Nt|Q*)K_n+#YRk;{!yE*cSo)p#CjLv(^cFGjFjPS z$A555`u)%QKX)n~-{Ss3#fN{^{&xSNXTL>mxn_U$W6nzZ8KshJk7+$27l{?K@CnBv z+;QH7jC zH|aSz2`3YtbJPt^>YbYeFMT%7yd1JV)Ajp~l z$#rwfrwMVaz7@i6XvN7wEHaLyq!~%c5S=|sskyjJLBIzf>o1`jY+6X*fwbe)4U(0U zqCA$(M#M-Kaxj-}>E?J%!&Z8;k;!?pp$a}dpAGd_kWX>4<}c6=3Q=h2sE)HG>9=yW zAU;$}x)GuzA0b!Is+hHEmN)Ul_vEj#Jj$9!dzvl{T4$ zfLOHlq_dW)wF8Iw+0^Z`PMNh0sjSr`^POt?DRL5iK^a3YG0+9^am-FOq% zBo`xdPDGA1*aUKJngf3-N}K5h3zBnH3DsFD#L3!8S=}^GNuqMmOt*B?qG>{GnWswA z)(n)UZ5gVpZ!cDoJkyqg@f730nTC7|rBBtj#L%j5h4_%+q&QDAj^(q+8DeKVIXr17VTz8mL){{xPP(CJ!gPcE7kmnK5>Q3o@%0zT1Clap%gC&Y};|QDKUZmxl?O;qJB`e_mc+e+b(I zV0o{n9~)d^y>SFfa@bf0d*Un4o%DtRz4g}HHZVZ@r4Ehtw&O!N_;z-;!8tN8fQ?^< z)~;H$vT(WjS6W((T_5r~21eFmyY%7kXdce4%ggJ6yBUX?(kXa(c^I$`j0~@(V><8> zRc{!=h7m6||7gXhxCqo+(9^1hKIYVF1lrRT?(OdkukGp|>*!JzBRA3-ZXel6I6;~VOACsY7ve-K@Jya?+COyd3YF@; z{e!#hJA_1LbawCQ?hN~#$GYYBAAN#??qf%^(@IW9sh?(VtgE z-=b4(pc`vf7pD^=>?WL?SGl3Oa-)-Oo#BY8)7ym;4e<49cnbN@G1%qTW{i1oYuXypCl_C&b7VhsG4bmq$|dR^hm#A=5-PP}nc^cZ_bl;YmpesNy4I~3au*01=bJ0lQ!JjdO$`2H#8oc$v0}T+ zjV~Eo?&HO;>?}k0dEyqA`#3S;auZdB=(`x!jAzsLOr4sB^jJ zi3KkAapHL@n0%#rR*36d?v-MP%e_F%b-A;|PxZzTNmldrb9vh^tvA9DH67js?ih2j~?Y`#+QOf&)p*o(1^8HA^t~-y=ksf0*$xLbMU@v6~V^{&b)_p(`BfnhFP0;gUHV+$tPU zg#(sTcs$lp`bmy*&ty0J3y6+~0h)X9-~my^;}_yVa^n!F?-OQ3(7~tZz#o!74vmT< zec`6|mN1zRySvXLT!bfOcGDgqp5yQw%I>vx9tq4Mm(5kdD7uH?hK zq2I5`4Sa`j4#|hRfKjCn?j7vj&A6ZOO2%6lA7p%z@t2H$W1Nn%Px5mas~LwFKgD=G z<2{T|GahDK=+$zTGp=I{F`mhI8RKUeZ)d!h@gSqI(>-Jd6u$2eqL3N-*U7zBh;I>M zJ;~6|CHFeEHwvqv?-QV(AjElurA%LH``OWdi4b;qgHhEBxKr3}Coz7G z@l8f!zw6j8k1{55y2=?x7$0YRk#SL+j<<+$jPWAI#~EK_JR1olJ*mGV{0rlW3EJJr zcs=7CjQ__t9d($(wJ>%uew6V(#vd_0&zOe(pTY$g*D#*Rcq!u}jL$Q^#aM*4io$PT zJeTnb#@iWRWfT~{5kHOd2!7}uf=B>qOmZpQN%-({RJOY<#d3^IO;@e#%s7~f`0#gjbA|1{&Xj4v~Gq-y^& z7~f*_q-py3j8`%Kp7CAA2DE7;|1`$0F+RkYnXdf{882YGp7CAAT(tcpr=RgD#?_cA zA^P=Oq0$RU? zjEfnMXI#lx!+08FCu0xeFyjS`pJ)6M;~k9OV0@VImyEw-{1f9ljMJBB{T4AE$GC!V z9pg5}4>5)r_b^_E}N7%|)t9<)^t60YXw3iye9OpN7QJLV3Fd~C%y z+|~}o z94HDAp`gGK(m9dcfiN8-#1I-jX<*ydk?x^WPA&-PBUB>7=)ETqVDGLH3b3iKtFeA` z&#IB)qR@7=^RXj<#oRYY!a|Kjr5kETOShj<6b_Y9d`^wb4wsN!zL)$$Cw0^{?HJiQ z+&qT8UWwvlx3|YcfK!6x8ydy2pPj+l{y=S4lmNX$-9wmmHHQ@<*v>sFSliB#9c^`I zj&-&aPZSL1>gdSdg)r6ibR0z}+<4MJ(Wb2>-JOM@YLepA&75LKNvT!rI~uxo?=I{a z+!3}kbLAZy4O9Cra(E2PT|?&-v4DnDX99rYbF=MoPE z0xcUFa5!&p&&q~CbD*(05L{hfR2100y1uY5(2Tpf>gwvkK;5uU9g!}itS#Ku-W?k0F0vh6LnG~$PZvJ_vK?4&upL+laxOf;gQlq+Mc-7ofG%qR zm^_xk=C*3UlsyU_OW_+Ayc3HD`MXr`2{U}0?wqIZPj$N43j&8ds#2iB+8R%x^s10Yo&P#? zM58#x%y-B*x|~-6-cPn$0&EM$lINzvqm0E;-(zaf?fR{Cf$Uf^)6PHyh^78UR#*g! zrM|ij<3*TQ>ZdDb5GI!TNMS4k#F7_W|EPOA+WN;~kE;Huuy*N*CCi)|+u28TCzkwk zg?@kaPwDQ;*eSNWN`Nbur`YUT0&ELTAX{=@xbmMg7Hp|&m~beVuLhz2^f9Pw_&LS*2qqdiLrg3E_=SX4+HRwJ z2pbX&)r|CY40q#H+*a2sK=>-B6T;ehI%#X}06r@l7QtFPG^!!5kXg9(Rhn0hM11lz znJUvg^JIpcFKIOh3-Xmk`30-6w75WKc|6G=VXNj0krjveNrAzxkO{a+le8vBUNa>y z#_JZ3UXP?_Te^zzi&J;{pSiy_f)C3bQTcj6r|6BmHMoBdKXVy*tspqnEQf>Em&HqK@SRRF2ffokJgZ4k$1B#u)ZrJ&R}~}Qh2V=N9WR6Lu_*CI zruR;t5N|mYHn)-XyBS5LC5pUAzC+;i8zGMLewxdH5s`s47N?<1kbRMSD4WBuwYd!6 zaqi&a;u(0k*f2T#c0yjNgMKIYuskGI;fHB)RTg0?af*o-NY}T)=T~?7pNW^&Af57l z3ceJukUUHyS@NuOu)J5mcQr-Kmyu`LkNNgt4I-MIt$bs?r@@yT#V&6{uv5R6P}hxq zm?oT1zc;{lh-H(C6Y2L#Cf36^4NksD{R&{*$D-)>K!kqp`EC7{Lm=e^{UYs`ya?-f zpqpzV{R+T$sbK;dzDWHJfbV-z_%1;Jr~S^$w)M*c|3vy-0lt@_$cxP1;l)B+9EC4Z zKT7O@D14y^{SJW71UZj58F-ILs`MVu_w?~mz6rtbtrT72=d{jR$ zO*^4}J>YwZ`XRm`MqQEm)fZwtll=$`U!?u62Opi}XD-8MwHsX450wZ}YdjtDBxufZ zu&&Iu^D^*FWamck`OyZN%ZQFl#{ky(Z!}Cm!xx#3loQc^th5;o-{T-T^=lcl^}{m4 zg!*-YFWDAn#XC+v@C`)ai`4HW@Vya*?{d(b`aL;hx4VA$8T&=HyFUfr&FGWNWzzd` z5X?RKoi(Oq7(SELXGZYt1K(N3)8PlTg`>F>@0~5go#3OgW%`8_-0#AVx+-(selFT^ zIH){R^G2enS>KMIldlR27l1~5#AEoV?R4@DgO9=!A0^xHManzNA&nGU|ixOdw5Wd|RXOCv8*zdwM_=r?Z?zPR)8aS{q7r31_M6Utk@-9DJnvMEbQl_^2(Lh;P`zXZn50=SaI;3_hY$I+jl&?+Wl8fI*3m%JoF?wp?nb zx7fiqANOAT%+&+FyBrnJ)NRTeCtnsCl5?n_@MZW2!8c&&pSuB1M#cd&eCClJAJFIb zukicv(L~9r;)1gB62HH|PnZ6WrIgarQop~rxV*Gn(LX%>oa*`-d@5*3l_JNIOT?$Y zpuBvPPLu|*RWyrr_YTw^!0(-Jh`_mbdav`;_-hu`EUA&lZ+>#2Sn*`>rf;m@_EV9U z`@(0kUQ6&j>G7wW7FV;b^1*qZ$rOuwQ?hEr<+s<&d(yLHOX#aLy_J8OmyVGrXUJl&svE!|(j# za6*mu27gUorBtq>8nKwD1FH!HG7ld6!>#7~j8=5Xu6a6LMt!Psc@KEy0*{Bj{Qdvd#+bOH>z`-i z|FvvPEhB2fVK17Uj*jDnJZom!43QubWP&Hbn;4hqON>uUNK8zemN-2zDIqx#U6yk+ zMml~FGIApH@I=)^$4{-kxn9LhaQ5hVzVqYudoS=@BG=E}18qoA*~wgYFNzBprHL+daHtq@BK3${WImc6-|f!+fZ8Nq$vxV_$f0tNu<2 zj@HJ({?o%9!$ZVw(n`1;m4wsc`;ScvWg1=MzKHkuhIV0s5FS3PAq$kgp8md_e)@-< zQC<)yJ{Kp~#5;OO-EtUt-2=_o8z|)<+U9iFsoUNXNbL~xd(gYF1?dnrSk+v2fwF_P zmPzlzYT;h!qK%8H{pK#>pYuyWXDB-LHKlh7B?8! zsH+kGy`mcbp@_RJk9{i#U2jNUJhkDY5T$pEK!&(w>f*~E<)KTMVsSfZ&Lhx5S82OeN4p9j-M01L{T!8kI#ELXv8r$ z{&?_rYCn>LTR42)cw&q%jGsNvd)Dj~;7p6J1G!IerV-~J;*2lGuQq;moX3~o-5;ld zess1kVGiBJXX5`fEh#hxdfbfC*9(6o7QNeF%ABhV^7N6G0Xo^<*bzYM>* zD!?@F%?J=b+as0jDHEtq^@+2^Raad_xABT}wx94`eV;>kpT18ge2nRYPcWU3ij_y4 zO)a&$p2q**;wLeT?MI48X$v2$^MnT#ea1r`!$}Y0fBYaPx$gV^OSeFiVvLjfhQ3|Y`79Vcn@spyFAfRrWY^|D1AV(%i zEVWeyTdG4Le|Al{9gigbqJqM*YzPU3X!VOc3JX>ju3BAOtf|c{Rh6I?Di-D74{eFK z3Xe0Z>Xlb@RjtKF_cj-vcq|UJzfH?2jTF&HAMHSm@879|AO$E`V@p$2T}@4hd5qT( zPDbkQ!k+HK{$j<;1l6gyC3BECQN-{Uo(SxPMQMiK?W@VAvD2+{< zYwGH&BO|S;4z^$;qR@t5ea*JbO;zqd##hJhHZljSf?`oUs<*dPZ&F`M9rkFq?)6#h&DE+lFgIw}*EU#R9||@% zS2wlT^t*&PaQlY77RO0YiHPvBSEcM`rIbpy*fX-15(b2IAd=?_Gh)SFK z*t-DXyHhWA`k}o|=%V)8Il`Z8WbLN_d|_aKk@Z>U#hvfn@3}y3n=QWg{fB;_uVATp^aXLR}4GXJQ5@nZj&kn@HArDa8{N=Ae{SNTwCR8&@`6qXkkmzEWyUszdIu&Sh_u(YrQkzF7m8o2r0OKXqSm0J$TgZDXI&@@uaJ!HPR2(V*JV?6MM97CI1S%;vJ62Qc zXqrsB)6;_z@I#9qf*ehAltQieA5$@_2;2dpwFDz7$TQN61gR->r0!YU!=1e6WOH3@ zDA=;Op{_Do%ldPdKf*do$}i!$0|OY49ftAzPHwB*5L6Zxo>z>6jQL07fOZ&D{mD2X zfZN5t$Zb$NnkH|tPlOJCBdeB&Dyh@LPssO(fWl-`{!SF+noao!QBY(Q#cs|i_&yIM z#S*CcJdi)8$hKHRKUdLh;fDTkMYp4{iY3Ld--9S9V>y1S=%`L!<>Un_{DeFzyFGVd z)>|07KLM#zSyW>?bavl-MQCFOd=jWh~U2TH`Qw$T&oW;pR>#2#k6D)!W zW>e_tDK61=+f#6j@G1{sZ}W?UEccTO1p>}%gj}VZC5-sgEIjNS8o1Iik(?%T^9p|eQg(G2{HKYI6o zo>u5NU;zfS4b64U^xTQ3&kY#Y2K4K``U$f^KQWbn*4%(T0836NNmPmJ>o!$`(A`Hb z1EavuusPU*HkrNX1i0=F2geDa(5B6J%Nfs#H0Z^NxjjPz;f@@f$QK?S8SFzd6U30d zxw?wtG2egTNg!urDBMXSe(VCatva|d(tB^XZ8v#iVq(jtV0~Tfrs^v7Xs{AbB4}fC zbMP=R(AKdVa}ZRh$=v?jW$>d=Cn0G%3^7N<+}5L}E|?X@pv}#cf?A%Ccm~uoB)@4( zWeX&5RQN~(XLJbp78<%un;YTL*FPZS-{9O3-ACg%+rM`g zwgU9$6l_6?Z-CIMBMa@ElF(a8Xu}aT?d+Y3rr&^2ycUlX;sZe;Um)k^CUW)<3i&%Y z*KcfW$=TD^GZLn}!*`@@y9fG_$4nFQ;y8L_+X2sxo-=hnLp_XF@Y}J`X1LL*sO3+4 zraQ{wr<4!deG9KrMFw;S`@p)C4`gYo;vZ7>q5AI(4`WhgQ%lq4dc3Z43K|J}`)lQt zr;zz~R`&M|;{#RAA{)h;Z+YaIc;v^S4|aHcuu=!JMh{r=XOG-Z4G+a!*Vv4yGd z3|fyyQE`V?e#Qh19x13|u!6qgl{c86qelw5ofxd3UyGApF+m%fF-)06Un~Q5VEazI zd*89UkxC-Ics7F8yc;LKNz)``GbKpdYq)=4a~B0vp@cTuWP&OV_~b#OQNs~5YG~{3 zi>}W8c=?1;M@ez0V})XMEO%t0Dt-_zpEJ5NHq|u*n>QZ8Lfs8*L%VIOd@Mo!)~I0# z(5eg!YF=X!cgTt#B*?eCtI#N{uWR8rbvV@`j4Q~kSRhm@iB!s4u~w+gc|mKSMx4SA zT!ddXey+Z;a&to?<~^IJd-P^{;=I}3I86CntoZifKg7kIwoHE&wjpR|&AYg~%C zMR%(LPb}Qg%H09n@mP1#_Q)am->XT|mQ+g|OK`tbrAJD%-I%_w#z3VYv>{Ymy{WpX zt`a$s?TM4?X#7&ZV;Hj*(Ga8wH-8Crb{JBOXTXVe@K>GT`Y8T>8Ze9xrNpjT<1Z}T zvdn)LX*Dip5{yVOe`yvRxX;BXgVq|<=%!$c@SdSckbYmE?TCnFf8r$JP+Gm;OxzY5}I5+A%cLsT3 zI{@UXH8iCm+wd-I4U0TIh6cDzIE=xX7hZ^5=6PX^ne{EEi_11`smEGbIRWMj;?(=T zUiF0zOzmzbVrvl0=e~~T+W)fiD#qtpG6G7&2bOP8KwXiqgf!BU9X*NQk#jjMHz=)_ z1L@m_eEjGe7HVH%QF<3ZtyurTNgn&{*wr=^YR6U} z!`*!(5R-3j%MDvr|EDLiTXc@vsnD-2&}oTg04_mO{Ll`h3xU3REfdaE}J$}f%v=S<~+sv@W(wy zWkeHQlSjQ>12{f%XsEkuOj#~RuX)q`+O>Xm=+rLrpNPCgQ3=^$x`=W0I5Mcv@hLAB zDR)#iZALc)=a0yVK5EluGs0%5R)X}5;vsX;YSCMYp?-7i z`T~DWo@-g_ua=iGp1)wUT-mFDVt>cmJ%pX`aaLUH=`-krtLT^ZfY?)drCJKgBT#i)WJMXDvE!ZRSRSST$>mUth7YzL? zY!Q*8R*6NeG6f-q9JPW$`!BKf|FZ1tuu9<~6iR9jCeu8E8w&q7EBpc1BVCJhPO|7O zM|Co-mW#pmhhFzUuf8_b0Zd-0O}nVrBMOxk0BH}BwEn?fs$!TIG_Am-4Xp_gDbt97 z*dIdd2;^dOvvB9XqQKIgTy$~ewVjh^yUnLsF3X7|e91>^6Ybr@u^Wa1xa?vJfy_sI z)P`a>QeRb=(}n3d9^yE9Wq%i~KJ_>|YI=Nn+!3-dr)zmj%z>BtTS&l@wt%83M7>-O zFLgf+Ii5en+er|f*B!1#;rXNOEE1kurrV=bjQKH_hB5AX{6ESuzvC@gdbZz=`38PA zi)p;i!T$-P{Wvug!Fp4iwv+YhcbvTdg=sI*sQBnX;6hqPO>NZdM7WF=Qqxk?t`ldd z2Y~S4;I6j5PAnws6lp(3YAbH^$WP1TO!J`!4P8PaL;&JKA=g>M*TKdWPkH3!ks&z1 zWl;m{^U7=O0Mr#tD*vlAeQ0R}_DO~R)hoYbb5loVnm<=0Ix%C8i7KQ}wuVAD_VOki z+4Vm(@n}Wr5aWtG0E31?6H9qDPTp-xL2GDqk8a5?_~f@;?5@b#XfjyMqOq!@tn2eW zym?^hs+-x#B0?%h!#bH)#mnzU20cQg91?SnkDHLDL2_Bxt*)qeCtf}k5nz&-M8)S5 z>Vc^ETY~&=Z=j=pV2t#2$&8YZ zO7?#z%5QlWn;>rSQA&`C<|m2rYre%@ZS6x&{w`-pBR+Li0x_+Ki@s+632To-XbC>vQbPrJh#Y`lsiYDfw z@ziWqF{zCtiM>RjZ6C$w&0UwERUTt|@i&K~ORRvow28@h%AAEjdJl6Yel*8%rAIwT zs3%2QT>U&&|MY^ZJ&*Yn4<<5i^Uwo_;-hKBnqWg+{VAAD`k%-E!h4^`8|VEF4)>G~ zd#bAITY{mJR~F&{ZxlT`I=>$pVqpoMPw?j6BY1hEie7%k%seQ1?69&%$j3a5b^ew4 zg~f#>tBOkTmS6d*vQ;QAKlaeePg=U9AV3Wm_R{^y&=S zvMK6Xbe~y`{sQw^Gcv9TmbRX~ZDT_`4?~aQ-?t*p!M31-YF*l`N^UMaVQOClc*qJs z>ub#|CK#Sgoe97~wvvYsKkyo#%{4X6)mDhyaY5`@9_Cm|i;eu;9N2{3KJZ5<^uJ(j z+_+(VOAg+vFICdfFcz@OLK)G zem&Mj0-w?vw5&f`4Qy%AG&tb|e-sTUb_%zQMwZW$26zYHjIx|P1_N&WNI%JnO#hxj#aPnw#V!VRw~b8{6Sv z2lgs18bvB$M#8Ko=fzD>zq36(G-Xo#c!T)f;3 ziaq~>x$tFv7#N&Fep5x(JkoyDk>$l6*}W>V*ka;DDg7r_|Nf}9vMqJI%T!L8wh0bK zHGwT7F9sP8jZc{^V8ZZ@e0Zv?e)G1F{uW{fUf$WfDTHIJtDDeH{w#{u_PQ4Myiit$ zS0y)Zsy_vDy%U6fX)+!q23_a%s*k)B|Izuo*G2S~h1UBQ+8OzF1%0BsG2Gn~!qI~0 zJn0whtw8rThxUe-H0H5ZR?x5WBNOg;J#`&AadP3aS6)vw3OPi6U{6>d$V(me3Dwr) zS)=|8rEPd*NTl6Zg!hkpjc1hMF)ZaUQYQC#(;8{p0Jvu$8|3-k*^R22>(z0*kOVhX zb&+yB`F|R2^<+nFy-54IkXLw9HATO%cAt>fc++zKk+lwaza%7*&6;qsr(Fa=sKjx*hTzE>sG`j;(^Nd# zK4=IAyGQLJsAN9im6s&>a(|FG1(~&RC_l*DT%Eb&WlR z%EsMs@{5r9m#N59nL2??%B=_Dh!d%V1Yorq7o5=2iu)}J6XLvM2CCgwdY2K!)6|1e=tP0z zvPPTnVyT)UBX?rfz$tdg<;q5{;?>h-mHO^z1^Li zJ*Y|C$gfw7Ep1rU7HQ8VQc)NN3w5Rq{hi%icq`b%lgv_U+B$~u#w^D^Q)H_<)rxjN zkMp_|GQ})p?7hF-o9z_4e0%3`Uj&o_jVtE)g$zF+M9~` zcc#gUQcywX{+sLVv^VKJGF{#by?;C}{R1iG+~L1}duR3ch15bY@|gwWOOxHA%$-3U%Ye()e$W!R-9VGIb9k3&HB_K2OD)$b-v=w`u6{I=OD?<04vm%fn|i z<4txuu7?5W?70^RD(R{#NVbUUZDI<^19})A1gBDH!f>j zX2egF83|L!3~I5)rH6=CdKyzGJ=tkDBu7b$Dn+-|3<*BLi8&K#cf!GvM4>=BnXi(->h$xnI zwxv0&b1EF9(4#Z6)2^NtO(AMJ|Bxzw4Tb(^Npe<$X*5LSTne6B&Fl#e3-JI=k6TI~ zT^?v21+Ox9e?+#fBX2j|G2AfjI^pEN0IBFL_>C1Q9m z&lQ7tjx<%08v$dih*ki_8Q4%Zf_X2uG^OJy}%BfCCxw5kz%$k%}t% z^nA38$?6@^LjyC_)Ju!onB${KdL{Yi8S!m`v9>L&=~)MXZrg_S`gIUhDVezFeF!ampsQSys3& zJh*dATQDVS6f>waiN^ysN*)csA`CiffqVkd?kn|A9Bu4r)Xi&3)*wa%13Y^~q0=qh z$SfI3H@eHzo$q+vR1>~`fjoDSFZcSgNlX%ZW^3JMx^$z^DVAM4-nVLsIz`XlBkMGwHY)d;GUesa=8@G?)Fyh4 zz8`HUzh26eH$t1AR!mWwXsd`>G33|8w!xfj-$HrEVqe8=Yvk+Rr5!!p10l8g*{?<} z)N}+e#&NxVij@aZ@$)tKyv5Crq|y4uIDV{-h>DBW%8$h@(emk~3dqOt8CU@gAPSdw zZ15o}?p-TC8OP$8-4Y+cuf)H)R$djil-}r2LoY~9lv)vz?|M}<5!=95{P6^NU)(ZU zDOSycPOMskAbxC!97vn%=^PqXhz*&oCd7WfQh(&$+CPGa*F&OpINUpcwG2HGf<1av zjiW}rwVP@5A|7U*c&$TJ{P{%rCzlSCLe}9Gt;0d7bvP)Gtivluqr-u9cy}D%ik%#+ zswy|JD;-9K{<7R@J5KVTN-);3DcS13>SIL3B|-TsB@Lfky?<#>1?5{tH`>!*n`R2i ziHa-N%k$%ryygu^-%-l=>3Vr3$v7E_I!Y1OSIRGGHI81!3zhO4N{wLi_M@`J=d0xR z*%n7B;iW41jJ5=J3OkzYxT#wHhV5{a5`I=K|EeT3Y-z5FRS8jXX^q^MK;@ueOK=Lo zzF#9RPQbf_R6CGh>h%KZKUEHLxhe+{(6qc;BR{JGA+KW&bZ@P^Nh??%q^PLj(Dl!* zhuTeh!ACYic+0w0-f4xO$S#u!xNn2Jp9M^8*vSO^eS>_=Xi!f{=#H8MqDCZvNU+-j zb@J!707}DDCH%EczN#f4mnSgdc+=f>l6;#(HOC(6xs&9%iBzJtw~TKU#z%7PMtN}} zy_MR~P#=V9(Tb8TQW3`CLiNl>`P!0P>aXan0ebwP0d*klnI+BWqB10UEIU%TrS6w9 zBxc{5;w!GNm!Dd?)C8v?5jER^w9KUxTy=Pk;OO96+d4X^4>jEz#JuRM_;tO!&mqR@ zkvo(a)n_@xpksE6c?DaIq@C_tb8~~d?YJeR4ZZ^&+^rv{R5I#tDl4?FYX_X}8K`UP z!PFMtw}#bgu%p4h;5pVv8y~;h^VY2j1g21hMyR zk{9PFox1z>MA3^CA>Bw1R?nyg0iWG0zdTNWLpK&c`e^}5MOL-lQYV^juWXj@YS9>J z@7B4m%w){t)(XekD&w62%#ip-m4+pB+tEKnw_?rfjq;jhDzQr7k+dX%q%8?NBrJi4 z@R@)TXiPa?cjJS@BW#Ofj)yFM@MQU#R)Q=Zkur)BsiGL8mV=2>_Gpv5DA&ryh}4l# z*q?+(Egv6X>MDNNEPtP?Dy;i861(dDaG9>UuE8(WT=mr4svntK_3JRLW9k9AbqprX zkgd))V`z9ujYO;cdJJmW9q|dVD%({61*8t2@Z=s zgbr`b;cfDTJf&_&_h82en!;^^*ek%)@0?5`uOI2^!uu_{Z>WdN=Mwi4*Jiv(8ph*^ z%KLW3gqL;U?^`~E6K1$C8SGF*HJq@Inz5cp_OcWuM5HRnPCI=3n(v(=FUohRh80)t zcLJCNh^kpm<{+3RR4gY`Kg%e@c78))))HiFa;X;Hwb~#|s`j8$?N$mN?(5XGK&*LY zhkVejy0$9KqQN`|WmMgdWYxJdj@GJcE^U>syA@KloLrwH*wTJ3q}2b@Yh2e*f>L;;%qk@1G`r2;-ET%t^(aDbQQ9@P`j=7d|O9({!eui zV@`*o-EJMlt91CZ72V62b=R&%wPTP3dONyt0(9UQSf-{WCS<4O7gYSFP5!7vbu^J_ zvb&n!s5BkIk*?I&xY9(uiX5Ug@NSJxFWj=RAQb7T6$ zxt`WO{RXsZt+Ug@2^Cj&$m>g^t88^rR~PEBaTJxujciFPD2J|zl(Rc3QjUmr8XU=) zSmlEos=TPiE7n{lv`O~S`)TN>~|PY8PyZEh0h*go~un`*HUlcs;vrt96&>u?H6OXUV} zw(WuKe6S^uILoFqksYA<)sNbDoed^i8aH zAwFHjt-#P5?sohK*QDS7y#JHN;_)pmM%fYH^ZbXNDj2!t+N67l(`Pk0ALv|Nxk#*- zh0i$_ku7lW?3}u}_`E3~l9EnH@+RWsF?}}8Y@dBPO}v{VM1oC7!I4xrxrUCjp&&R9 z*>+SSV45V3=}saMk_^FcBs&R0%rH)3o@pFH%rdvO>=c_s%&AKSr6?^9N%JNq;Z$FI zU?JzwO?nPa*~x_G9Cb4T2gxSEOP{+lFG=W|45Hzz96Aqpf$=X)!3oTogKjg4PB#ma z1VPpeNUob(K23;Y^{o(oLn}@eVv%tqCCx}mhUn~BO3lS(3IaX=S$_%LVB<>y52PKZ zZjh{;6y>pOHX=r{kb}8&OE<@B8je<;jcSxP8>(QNz1dKI1^E;wYyJZ5pb&+Ij!)HR zOVV%UY(acDMU8GyWAhPm^{k3nt7dr3E}H3rDRV!H)we=?$Z%4ery0lcS>(i# zm{ff{@#Ofhc4(hA?I1cvS%oP&)(&-xh&t(pq6yOt_G0iU*hxSYeV31Q#VMkEi%_TQ zTOoEEZ<60*96IJ+!%u#FB#`Q3zq)~p0h0nU_8Ho7V)7a|2DKw|F6lL795}_WMAhJt z3aBK+p0y$a3hzyo)Ntb5z%_gWL#yj(KP$ykHy-wP`%f+ITv^gt^dUNgOcC<(F#9vy z-PYsJ%j@e8Vaot4_4V{)vrDW!j$nBXo9tkJeC4^5-d3PD;CkBz259fpp|Rd}d^88& z&h9oiM+OG43Cz&iRjXDOE?56bON+4sL|(_h$XaZjJ{%s+!>M?Ad0lWfAWFt@tb#fqDyiTGhP4a3_6`nBR{;d%D8C{hi^pUHyX{ z;pw8T4bhmgpO&h99^RWdVQQW>{_WaCdJws)7A^b*@jqEqBB>;7&S!oK2)w9QN26 z(q*cl07bqo;!|a{o{(w|pF-=$M+pc`w47pD`W?IxU}SGl3Oa-)-Ooeqhr)7yp94e%vv zcnbN@G1%qTW{i2DYuXA+^MKx@nwP5^>C!8nEXM{CQM_D3_$7go2xk8aiFww3XN?!}3X zGi?%fc6;;ijdl=>q@{4XJ>pu2zZVj69B$$9ikS|##M$g`+bSWoGsKH7_e}AS%RNhc z)#XkRSGnA&;v+71nmEnno-Jw|ZZFOncI)R8c@FOxvz#8fO2~29cJ>qk= ziAAbsl^Afj=ZYeid!=~O&LZ%ai922HEYag~XN!E7d#QNK&T@p$7vFZd7l^Z5?p(3a zT_<<1l3F86%#o?S&?pJn2IT<$`#*X1q|D_!nP@dwIW zzEVAYahuB>5PdH9aoy_{^g{2kH5=gq_W@PGOSAub`T6-pktA0l@hrW$}qmiQha%I3q2j}fA-zsGJ8 zO#Th*c7=n^DjZOS!{ek12e%3bRN;W-6n-WiWmt}KV|1w8@Gl@bhO5Pd>8#&kq0W-` zWD4a`V)u4- zx3YVH-RCiWh7jSeV*gv2eh0h1$?kjE{TSo(jDKYOJL4SWA?cY(2tECTNJoG%kLiVk z;45V}?F~o#>lkYpHxh!ck=-rq#*oUkFCJ->-2-fQ9EfG?doJ-+3bCKC!lr+d+$Zue z?3m1Yn%uC%uNmKARQ3nGfYJxt$hd=XH{*WBD;aNLe30=;#$Pi2jd41q2Xb>6s~LwF zKgD=G<2{T|GahDK=+$zTGp=I{F`mhI8RKUeZ)d!h@gSqI-#ui9bwYfH5QW{)zfSI; z5Z@xiWR#(wOYSPRH!6jp?<4wpAW_6Vw{COkoAH_(jG)GJ0^pA@LV7p2c`6;{%NHSk1SBv4*jUaR*~J z?wTzn>&tTlkcn;&G zjCV8M%XpCS$BeHrzRCE1jMEqE`2CDa8S@!WWZc4dDq{!ZFyki~FJruh@e7Q1Gd{-n zBgW?#f5rG$#u)*v*KEdP7#A~^GHzmQVQgjWWZcVmDdSa)H!$A9cn{-~jL$N@$oMD5 zc#NT_z9ciIGcI9V%UH?S!nm9948}3Wk1<}sc+WB|U*>8IGM>qJFXNvXi=YeX^Et+E zFh0)s9OEAt-({4`b+|IdO^ic~=P_Q!_(jIAF+RZf7sjMKEpIVn0pohcM#hgbUd#9Z zIy99Byj|?lO0nv(8uZvY~;I_P(}WY?YO7)9_wFZ`eto7vG$2Y)aj)-I#42 zhTySY6+wrdPZs$!`-~aq&@Q~Xh4;+#meD&02l6@AwsxE`x+j0A?m(FS5n>2cZ5rEF7%1O*W^Y?aAFC1(M(;<70DE_p zP=NNqlXkCaDQ(`}5)N%wyCFLQSj>HcBrMceRJx&dv~>F!Md45x#pl$>?0N~=<$K95 zbW%rM(~gm?!_8yZ|CK0Cc6-ZA1UMx~zM)YZ1=<;`?GMy;MG4S5)IEgh*WLll?GNVf zLa?2CRIs+4BRksa&K&D(DV``8%+=AM!c^DO5f!0u<4FTWo3@s8cNT`KNs3c9b1ot! zrB<=;Xz1R(yRc_)N7&NLm3M43O!2$O`Gtbry|l|36%$>~utp-f^L0U>V$$Ci>gfsL z)2bm=^!5zx3hAOgRHeNjZ+@&3j=lA0@!o9d24Clqs=WFD>qhYXBnIu>I0i;W9#Zb_4;6WpsD)g z@<3x#b#r;38i&^HDH8SF?SViOPMir34F>|SVo!IwUQwWzFzNL=9Ca3MYwr&AV7&oL zD$eBwM@iyjo9Y$NB`W{}$5OQ1HVl}OM!{n#YU6_I1Km~d3A1-xCFLA^f2!N1o??%s z*heU@kLk2)0f~vF8blStwSr{CQY|86xSAl65lb5sMTT7#Vri3D0JXtKTM#(xQI!G} z*4B6mrB{VK>ipNCBbvY|X1+tl(dE1n@P4x05@1^}mOM8V9%U?+`W{pBZP#zD3uMQV znRW&uKrHn)vce)*EcMlO952GeQa@cegD|nwM+##ZAeOw~`bVAF(bhi>dsOvLg|$mh zELrB%*v>wxJF(=SEA;!Te@b^(#!j*2RRUbOJjG_$5@1^}hCC0k4b(swhtkrDbL61K zu1?H6g)uEgO`%YzaAnAmv`|N=BwV(tt)Qb6exau7t<4)~tPv9{z9826L>Z4wH0rVv zU{Y(1Rq)F9I8QSeC?4;HpeK#w9{=T70uf6_3qrLJMZ zQDVLtpZ?Q_r>>Fd6kkEW^IX(HHN>>ikKbizrCmF^hp?~FP|ZkR$8a|e*KKvZJ%rDG zIw7pBr;~R04&ZaQVG-Pb=S(#W77|N7!dGeDRub{a(`2el_so+Sa=xSmDB<;q%A)*& zRall>AhSH4WYDnXbB4%@!@QdWz z6C>Zf;EN?4bA5WP*hFn~icIgXz}ISw>(DRKekWjEr^N`Hgzq!pJIh4o;QKV4q=Ew-fT5;m1GRmsCjJ&sT~}Tz0#V|P)bBp zT!s(H(_y%*pNEdH)_58}LeQM`=&@C{oiX)3VLF}%pFaT%d>PS^>3DCQ5H}hopy7*5 z$Mr$q%?DiQ|)Y31qeI5Yc&FH(#W#oMv1anV*>1SyfhRcy+#m4YO%DdemkN6E=q`c=H@<<=USB871elLTM(ns-9wVR0VEeBuHBz$rEZFy9_ zjJ(Knq=PR5{uJ+wN%)q7Zyhq6_+~ozBGcP*fo(rZkBOJcm@~b@4!+qAzDT>A1wLb! zxemU_bX*KRlMcLsV8t8BcQg3tojFPeJu4XfBKaP>(3Y1y3E#^OzNM4!z31S=lIVo- zrhmeY*R&gn;E%N5a_|wI(qYCC^7G58L^@We;W)oaz|lm~_n!x~ku0P0Fc zL-L5DqM9~<+7_yR=6d!@JZn$^<;(C9f^Wdk2fl#MfQ$oZ_^i2zm4*5JEByY#;_{MJ z#RX;MC4PT_pDz6$%R{B5rG9^Laba1JqJMb$Io0(w_zcpLDn*VZmx!64S6;qi1vz4? zXcp`49jHBk-#gzBf%ES4UA?5{xSFLki)v)f`X@1f$;o^&ukOP2>wYS7=DiSijkru+ zDy~Ljl;$B^C@%F}Eo%Lb>#{sG;?nY( zLd7++CZWc6jkr2kDK7KZEUWRQODES@a4GITG5?MG25RFFT<2_@oZ90$vaaI;`-10vAEien znl7BZJAN7q`!9BcO52Ny3Q9{ldB%%2!oy|4QO)v-b@-2>HSWu1HH$&!!Q4Z*)qG#l z+A4%=#!;6;pQ=FK175knOcG+#*gbNpKck;M?&wbo(A0?rb#-$v$lJ9 z!$>=QZ^VIx_WmDvUjiOyRrP=GEJ}#HVb!!n5%T z&z5n4Z0&CbiSlW`!gJCU9-QZ78T*M>&(OA7=qkjGDCTk8&NbaN*2Bf@$Xpo87Y}d5HKyJ z0?rovJB@;or`PMg{VX7e%X5MOF!05HN8sPmluU%qT#~ZPeP&ALVwWdH#E~LP?TCw= zDPW5H_7l8DeisqEPJS;U_!;?KMDP~*y@()XHt?b9P5c(&FZE`*Ikwj*7rUHNO#G;N zlw=!;`wjTV(VJ2~>W)g^PSdwj`x2xom9usNL9AQ29A z_>+)T=!RA`39nFHgF!~$CKY0gRQicK1#9bQuM5}Li?{1R zqrJxQa?eOV?i`=+mkL^i7#bPgYR8ODj41@_(Arw9hrg_-yr{IeSOo6C#WA6dXl+|3 zUY^HM+RafMUzIUbUiI*bwAOdfx$Xma#GQ%t<4i1skZ{EmpXRApVrC$0=VEO>#>rSI z9PvOPr3tD>^UJWgQaspR+ZZj6L^ZJ$O)QG61`xy@jh)Rk{*r0+iD}xFg^4Qu^SYNiGj)OJ=Sl-bhty@_?B;lM?#`BC~Dwvk!!H2DH@DK zLhT(UI@}xvX;Wxps7YCnGEIG(V27ijg+-OwpS&0t#8BZ5W$F)u28e2Ik3RE$k86^`VlSHXl;w2ZpNMWM2(MV@~Jx+W_ z{X;{HFOEjrf=Hy|ys5(7`Ti;Y%9Z}zj4x4WiM7!9cjq&nWiZQ|%7=_lq&7&^1}@bV z%n%A#p@BtSK0+RWbLtA8C@5(#nJE0SDBgW24_}xY-{lMh$zq5(76$0p_Dh3NXci(u&f`lJZiZ&rl+OHbqnw z7nhV&6c?40SC*AlRFqW~RY1g9WJtt?IFyw!zK0WnA_Gi$Sy>5iXA2y~2DsAVs?w_R zisGuWNyg6+J`@`v%1D$zWoc=7MJd{al8U0Lva&#VpbWw;;NXqIgsfsU--RYR&Way5 zeVmPXkx4K^n|{&^A)_r!dx?ovaaR_;)bvmWup0U@)7LP9w0&)!v%Rkn7Bg(1&3>f? zZ8!c^79Xc1xZ2`x=y0HfxL)X8Z={1Y{~?`jFuYZI#QFc1;qRO(HyZvkOq83A04gh5 zGV?8lpE8U!0X}PZI;76$3{S%_$rI=E(w53D@tOU0(^qL?D+_m+-cITC1=HKm=0M4G zH$?#bB~e-6Q(Bwx`wcvFRCrv!&mR^tL;!dYcc}^Ek5UK}QdR93Rjs9J()G^J5OTox z4SF!LRLu^VTF^f!Bntud08TZ*qzLj8u6u%16koWWZDUYan7Llo4l?GSv;*3qPxWW*1Orts{*`Zn+D@9h zrF`Oac#o`F8Lg#83;!7ZJ0XynOw2zBgH$sy|0E2ujKG-HIR)S2qNo@QMVklo*#d2{ z)%bG+-ej)v=L)gID|%XT#7JkK)$CBlOqduf zYH{iV4=)c-to2iWnw)e9#E&a>%Kek0*oqbNm-_R1=zs*8!{U5@$H>SKh~wvm5FPRJ z@Dw!;>K*7FV@dBi^zbxe)TF3W4aE2Wwt7vUT}d-3%-&2Jx@?tET;_cd6C#VWBhpOmZ5P8=?T&;gTKOfP;kTb z&v?aE%WtsY3@sWhNJE#f1!-t>q7-4_3B8)FNJG08E7s7l)rvJVZIiO-xmlqoOwnng zBun5nnm9wvO(xFJa_AiFF`L&XnUkcNgI5n?djRVfvdL<#{`{el1w zMya$rZG}iXg+OZ10a^TLc(DxsaBNtNR%jfs6dl^;NH{{{PK-Vq(XUn8ZRH5FS&o>> zFhGbjqYc0^0&)@+;-+v*2#CR9+GUCiL*3?J2kKM_F5>8i$+^ov8@(kMe6k8 zMc1M6(O7RDUW|)POpXnsnhByy9|_fw9DU{pBZ0ih@mL@A_;EAUrciK0y!WnH_crpz z#6)LHuqoWo5~>qJgA$BHP{$VJVK6b;-MbBQ5R|FO-2Q@m_)(}65j7cxh~p%84~eM@ zMG9lkgF$&Yc20VNL6Z||(_00$)sM+opJ1>bj9&p~I8u|B@9!J&f0VGj1F^ozp%|{R9vd5sjpgN6 z13Nh0lUFoVFTR~9&h+mZK<(wvE9yjyZv@l212gTL71KM2Y4ZU!?b|*ZO}`GN*oTc6 zVlOS@FOajfotz_MjQ;`7nhk9oc{{s@CS#O#IMdj@ZFB@_tZoDZY;Z;ef0 zQl+J%y|oG34(Kjz^FagQe0rk?{f1`>7c;_1r-EF(3jo(MjdqOKtVSXff4kp9{vR# zv@L>eituqZ6P9**ait_Sb@y&-qnwD-x0=zqcRl=GnkFHe2}aUh6CZo%?Hq^xqEQfS)IKp{D)c{!NsDE5lX3JxZ@*L{a6ZrUhC4<9&QdsHXOi0 zgU#LJ+f1vRoyvc&)i4-HRYu1otu~20Wc6dI{4IACDutRbR#t?WWjIkIOv}h!SPBwr zMwH9Duqw2SnndxV4?q5`z`q>)v$c)2t<7zi_iU%;(Y?&&ap$<{=I@II-5&f!=o!@` zGwFfq)pHzoQOAynz0ohl6r;UXfhQJ#Xa(qDe5t-}()!54`9G^ll9m*EY>&n_t&dPT zpzg->eFzyaxYh?;fQMEJ}w0Map0@K4HorMf600b)vrL00~yA{KWzv z*7qFK686W*bHoS%gP+FWMy&r}rJ%00v!*FTD?=5UeH+%kX2u-- zqVWkDb5!fF^=+ZewV^hQ8jQ?mQ^yF=s6$K}c!ljg$es1jMi0wc&Dh%*JH>MVbyQP_ z8ZsHv4F&nDX!yf8PE0n2m2bd*j6W})1T@2xR0%nZMKSY+=Q{Ml$_rc<8^(WYe50Jc z0>?o2c$8*WCI*LzAtvAc#v3~uLeY&_W<(9$KQz)kftMQboJY7N+<_hfRv>VG-j3h|>MFy^|7`lA)~wc_Ruvd7=Khz#ByX=$Yl@ejkT z(iH2%=eo4Y5aX=L58VBucrS5$e6WAFuw0&8^QQ0h>;1|hW1H_k9%+lL5;ep06XDuv zXkek^Gj1$Wo*Zg#MKc8FkI0EOs-+cG9V}D|+>Z&T5wt$@EFqM2LjJrGpnf7~$Q-m< z^p+rKYHg?~^5?C#Eo;4PcnRbAi>4}ty^2WsJMO`8+|G_y&SoA@9l{n%jg)bGA8fZ` z;D?^JTw=`2OKQSZtNhv@tCZ7BOg5(WUs$+oj)P>GT`Up>LoBX9EO3B$Hc1QexO9~a!0mc) z!+rYW{|;NkrKpi(QL1!Cm_dpf!Jz%EO8b9Xa`qaza0N0Y)d$HmkE4ddUsehq;&LQQ zkxWU&y5CZqbggA0F#Vy|{m^T;TQmU43$?Bn1$kVik_^D@5#ly7ww;O?<^^>vkhG%J zA>w&zHemaGu$=^7T(lMI`*&nmx*v*us_>f5FosaAM|$Q2}gr zF`0np6JDxA(H&{33*_}eHwK3P9OlL83-8RSUrJ~P|xis`~Yw#DnU;Es^%q9Wk zbs3`XOk?}am~WWPI+hClFX-)iL|24)(mc{m7yyWUz0<}4f{q3P7t%87!Zt}xh|6gq z)wj@hJ=-A$0I{*Lf$rfxEF^4Yz8@pD)t_eLV|y|Wk?D#? z@nGXEct+}5H1TK%wXm@X&xJvw(ZpO{_3(R4E~pK)?#`CH*~{;)=pDu2hdRM1hRFLcVMC<=x);2 z#?v7k1@AAX@o%_S>L7OZ4mn7O`B@tOs&{37ch9($zTYw>O2rb@6MnUTm{!D(PAmTm za9XMS6Oi$x(T`wu96QN^5+!Pn9l^e2aa*!;KYQERgVEjiT8PNGr`ZwgW~*B?%Khw@ z({OAtDo@GB$R-W(D7K3*^wu-GNq_Y-TIJEUXYW}Y{p?tnOPZLBC(IcDq<~-&XT$sqb(?tUgK}XYy^}*(F(-zDoeJefyb3fp6d)(i~ z1qr6 zOV$KR17%gk<=Ev{SyfSm{PJTLZGMuLY0*9Zulu#_J(tI1mu4qc!6pC4Z=i+@uG%Mlr zYs9my6MJ}NIE1MwFRCfW(EN8UvBXx$opzp!^g(32#ZYi9JH|2GZ*$vA#7%nRHTIdiPeA5(N?CVj?^-jWW_R5Z12ipsMPCu8$YYfBW*EQi`rPyXD&Yjd~*J}*>+u~o9QrD+T1 zdJ}|xF&T|ugQoKa(MDc|zi9mJVsw6X~VNNc?_j{Vsf1MZYsw9BX8S|3Jk+C-bc*% z9=ERzmnxHc9+H8d@6K!!#aynAV?z?$RMc6uU$4V<){5kOau{VRv3HxoOJf+!yWb9`B3x^#_El#l_mbPq_HIhj|MgPO%B2 z-4a$|PG+$RTPx_33L|Unck%P*cnhve6)B)&7B9@vUcy$6(GWI^x%s8w{MXbpvROM` zn>4c^5Vd#$RwG>5qjhwvqEE zTQzU8vo|IY-dH7x6`RW{BcCd({ zTv3h)!h^nC*+FDg`trCRoP!TsE}4x2Ol7^y>spzTy8nWH6QzCbE}7tHr9n1$w+B9fRnm6c0U z`FRUa{xW94Tr^)Y10`mTcI&lNehGL#zc3@azki}BhT8>nOE?Hb{ZRK-mLY3PS2iZ! z+haRpW8*O^-km+#v1_oeZwMtxRq{20u%jER+RXQS8fAqEkWgdVJkmGVk6po9PP*b+ z-`zWb9kWXMe3m1=L@nA2MWSQfeS=fQW`+@^uOW^91lnJd`JbkJoZh8zdV3G!Z$R&- z7abbCRcm($tRAPg)!vlNzkL|LC<6s_@qf79R(q4)lXLjzp!biLEIK5)Ts8O~+}_zZ zzSFZ?6+BUgs)oif%Zoa4^<4fCqH^OA|M#L|Nfi;5{d4*Ah{~syPR~tdjk0(iH7uhx zTl;}aQ}qU_tgRCRy52}<3(>Ua_5=PaJ%OPTKwQ(@?D%;Q%;=y#T9sqEj5o4U>R zTUYehPA+SDPh3rJczBI!yxpwFWj6qgy=n!5g1cx6(hX#diOj&L3R#}{9z!%2A;EIz z<@mlMl^>(3-kwZ_^ZDnY{GOx!oyt>(8p@xyKq`MNl;5*JSUyg9O72(Y^M|4Q z(|%{=Wy!DEU99u3Cwp3Aq$Em=)LA43)mYQwLr5b&Z5b4w9N&%U4sj8==(Yv?dBo+; z6vh<<(XhIKaiEY>*%4pQg`^K*RH9Ok4DRh@ra$o~flee3A->}FkQu=u$Y zj9c~WiRu<&08PU!p^wZDG>?L<%!3$r#>^}s`gUjf_rzLQ)x2 zJYVwhy-U3X=YD90GE~E_WRNQ@nGBJ&Lz((9hcbf4*Ig?Wz=G=^!VZxFECI`{k-fZG{2_?CH;`16vX>!Bln6_#$em1-FyLqw ze*&VeDHfufr{|p#CVTs&>>B8)rtP%2jX6G=q!*ljk;U&l%3E-L$)fni%B)D7vZ>%q z%_Iv9D0D67|u>@oBR zM%C;Qg&0dKGtlO_>RD>zw2GKLgY-&l8_d}bFXwly^j6=wj=%0+)jKpe z8WpRbBckU*RYxxRIJWJlSb1R8zgUOkEp~cDjn+4&(PMRlRbRB8pY1tX@~2G|;EyZl zu>zV45jOU?;Dc3vb3OlrN3mDr2KzXA!T#0t{A$lC+R-7pUf`U@r6R=NwpBC@S9@3g z={Wv?C!bb|MfD&fE6-Dd9@paL`WCzT#wP^C)w@O&V(zb$huphHCNX&3&$=dJ+efjM zAtyp`M~^6RRH=6jDjaRZ!_1Rf>tNM?IiCO7rUS)L>F~1DVIP+|?BfU4;pKzT;X5br z&w5v3gHWY%eiiXJ36VNT7O&UxTcsKY&*MvV{OdxEU}W<_+2V~l{yk-j zgXHkl5dVp^1g;)CnB@3ti2qL6;UGDDp`O1jI5c-g>Sn40tA44T?@6V6(A*iEMX;+I z_{FK%oJgeu5vHP(EB;d9AeXhs2?Xk@A2je!i$F;083+1ABfmu|*c2pDR1?YaXO=_h zrfbCGYc*E=WF!BI5k8S!k}>#Xm_Mi(BsOd^20sk*C$$Dm6oo;@C=fO-3WS2)E<2I` z!el^km@S7#Pvoyk4oKw$Mx1WCzn{qerb0z#9_r2w{G2q(QJXua*9y~xytaW~oJQMR zo12@0P|YbT$t)FT93q5qZfoMN9bG^TAZX!U9>GR5 zf)+Mt>FsQA>2QwkH1E2%oB5p|I-0b>!Q!!Pa(pJD5ytzW&_3J)aGGm0+&zT3GWFdP z!#)_c?#UMZs4cLF4Yh+JFaQN!Yza)?B5>E}*hnAlyuy$PEthg&W5|B6{bVb@I8W#_ zIK0zAFQo|SMtUgqv}$1Rax4G*GzJ#k6a&&vG7u^%ReKC|oOHXtjlU~dqwBs+roJ$f zHjiB^Jisc9w*xSXb? z!q`<`*TG*Y5Czu0FU2gnOABPtwe_Z{+kf}a^Qb<8kgMdtFyswN4 z8~TVDy+tFhByq7jEKL6^g`c6 z7LMa_64jQB^$MiuPMEKh7(<+0ii=>v77CE#Yb#uL)ye##H8$0-gsa+}TuduCYL>Tb z3`7YP%UdP~M*`x0!10*U5@_6-DOU2O+CU^#d(5hK7X^f(6^Yt?lxb@A8j3JF^#*XIDXGzXd#`+u1&-~2GY^;larP_{&Y%Eh+m zgEHmYYYx_w3o-wY<9l<>y01m~Gj_eCNt3B{0E>>Op}Tg6v-lQkyUhF(HQg>$wr|+pxgoJHZ~4-O{ob*(M;^NIxO{e*A({V z;jAp0m)*u!k7U(@P7?4vXvPVk0Y}Gjp)V~p$9Gmy^}Rj(M`fa+iI0=n)RYG(PW$l| zBK@_+iCPyuDbq&ic)uOh} z@x@ZBU+LvHlsl_zG*Yi5R(V>_mb8L$Xqrelv!Np82x-Q_5}m{<@8fYQ?@O(|KE_`y z7iDppm38xWeQ`n~Q;QbYrB9$0#RE+p#lvj)C?0Sn)_5dd0 zNCYp87$}^k>ukn(o+z#;YHep{nLbUSmImCzB=H|J@$z!?FdjkasBL6tnjW~#2R8z- zGfYebCo?;ng6-_1CaxodQ=|34a1(CCVyC0!rlA#MXcrj0D+n{vnOOI799_jHLr)p* z9{dGW((^wD@hBGc7SxFz(jf(Baepi1;g4~@-T%SY)r9&U^R92&ETnE=paV4Yqxj+p zXvSBtV;A7)#tMA9@i^$=;l+r0E}J{|xVi2$ypJj0p~>``FVUpfQFss7L}aAk`Bl@2 zx7kcbEdu&DQOvO-2{BhAG)1}`IM$h`XcF|5CM(H zvGhz%`juodqGPO-K2SQ>AmrKw)eEW?xYLeL4=7RwaShp z)LIkOu$U0lCPD_pkkyW2Y`uwSfUS-*ou;ZMz+}hUJxEzXpJ1Y;x`YgxNDGrWjMdmZ z1QVcZO|)VHWZiNYEr9$;Z#IRbgRy!OyLrKu1)C7d28q(nMq;MJg-r)3cA~`z5gVkF zu_pR(r>#pbMdBQf6l*pSrRqi$xBVNy^ws(n(3(zC>`Md=a5f`sk22 z#yXdX+_W(ZxoK0D$m^R+1t-^Gg&^Fb9e5s5eM0F|_Jr9=93O9$c60SaVDslDP8g8Jx##KhU z^(+et?^?)@PRqob#8d0k2MjHK2YZARO&rGI+x(}L_LY?N6@Qo>921Dut1&S%G1xui zU%h&GB#P?+u&g&Uf{QJ&&NzvsI9#ZMyYPkQR@#|ByWO^TkB-tkspGr1_uzmWeESBw z;hY>D#f2~9>#M3t0)^sFd3h;rdsy8&I=LR#q))`AR^tV{)vNpAj^OE2dP{HhYV4(?IV4$_5CAby|Fng zJPa1}^u~6)!!f=VNm1Ni(YqSQazB8{@PdJ~SZ}|u7`YMGSkL5Ef(harC@(554B#az z&?JvI-5a|8SP|=8BV*glFN8#5^bPJD?2GxWkHf7QIrs<#?az%!rxBfA|LT$1r9fY7 z6l48aBpYR;c!LNN7#8raZiUraCkD6291ZMW9kw0!Hr#Qy>09yYAU2`8@UUZ7ROYGX zB4qh++_7-Fu7MufRqyZO0hcuar1#FUuDaMx?1~e9@W-_)`VH&pOvIHSrZ--q=-e0< zFB7Uur`O{>NdM|O$wz(|x4BrI=vueq#k|_aQ0)dQ-gpTTMQ3|IUNXR`)z~c3p?9p` zFU>gPPOYwgtnhQx7czdF+1;)U;^uf;+ii2tW3QPiBKGsyk8SP+>{~W>2K%hd zy^vjKbNkpfn>&+5EN(aR#_8u}Yc2i@5&s2n!_?xT3?JhATbR^zyVw^@6SIY`Dt4yL zy_g+ubCx&Ap0on|lrWo|y%}Zz=n@&0WAY+uS8A*XFKZ zZ=eCzzlE-BcE8P?!!ESBSFuxU?lr8?=3dJFK^a&57P<=9LpFCY`7s zZ0=n4QJcGvt+Tna*gte&z=f_nMlW&e-$K{1>}zmP5UL}5C=Z<~f6*OTK9`q$7Eu3u z(CupN03`RvcHpC_t)X?oCb6u2{tk@3o$3m*g4AmDS{_5c8{W??15;r z?-E4beO$pO38F6eyK<8t@~7w83EILTP9hwj2#4XO2nV+a2Pnb;R#N!+80siK!j0ae zaKpcd@aWE#5?rL@tYqvFaxY`-dj#>2tB|kppc8n&?~^}nU4Ku77Z*hU?uq$ z5#L-DUp%3!<3;J^s%301K|Ix?@%NJZc*ed-5EDwz5`^6UQScoF4<~uR7b&h1ep1036ue)-XBB*3!R2nrr%=HY z6pSi(x`LN0_-O^dsNgph+^3+n)BR+J6Bzq8L1Z$Gr}F3uGWHFEm?YBpbI4t%?2XK* z@p}kg!`OKQ(E}Iw0@MFa!mnrS%LFme_aZ^qH{Q_zcHE%9HX;IRsBSMXc~pH^@V>N=udreLdr zA6M|Z3jR~U^{D%ZzD>bF1d{x2aXdB4? zN(FzYU=iwU!k?z#lM245-~zNghA9C`os$ zg7pfvD|oVkg9@In;MWvLkb?N;0X$DQt-nH#uVJC z;3W!Pso<>&KA_+}1)osxM+*K_rfC-&OD_1%IpH&SL3*mV#F+DEe_IBablnAE(9-<#4RQ4AvUs zCfjkg23I6bboT%b=r7DAuMzX5(b37C;qL9Yu4;{m!&3bAm=!^L#jI{z3_T* z8*V>&a^pl~H|}61jFsHHwh{rh1j#o#h37c?f(;|N4gC%QwvP{vV_H-{B8XsHcZy)$ zTPIKM4xhfeucI_kFqo^icg+C8gqrA?h-j?s#L?oGjb(#~g8JgMBP8khT?>6+B08{SmbkiAS6PeGjcEJYM$c#YQWMnuxG!(`0rg4$= zc8(83WnMzQpcj@YU$Gi`nmef95gyOY?PzSqW4gheCC#~!+_q3|aBWj@aqi}|O@Tme z1YhA$C=|#IZ_35J&ykJgxgU#kY^dE(C!G~=Ha6w9(&f^j+)z!hGPgZ+Qe|#idni(w z8^XhJC~8fEJ-NBYigm}!PjKuM<)knl*CKZwc4>K>!q=Hfms6sy2jG)3ER4x!< zO^s)fdqv2DPJbCXu0EV);#+teT*?auA0*ig2BrmPlIFU=Bah9byw9jEH_Nxw1-xgH zm}UYZz)Z?-e1S!mDOhB4DTb!VV-x)=I+xp-t`S`bn9RVKhwr;5yq5rUR4(yA%}-hsbNoj}RI zsL$9DZcf-`Tq8QG|MI@7t(!W_eF7NVIrgx@ri=cm4F_FxjmF?OE*cuIpB(O;7{qJ0 zUA8SgI5yJdqEE~?)_<6{R&Oa{Dd~stg?y1~3D4q3a9Ryx zZZE4XUQ<+swZWx4+vQ3J4tFqTv1|_}I2p2mTru`>*Bt3Z3tlt)J?N6_i8MB*Un%~1 z#FzY|zweHt!}5wF-4O63UGrOq?`QE(|1>{ZBU-4DfV5UZ5hMBr{3AO0cb%3CNIyDm zfZ@FHQ)t!&j5XFRaM1n;{nMXKadaEOfWqpZriR}BH0H_2Lz$kl0~ z7QcA9lV?bGBj}vu#>eAb&^_rOH=gcMFJmuT6xN^d_WKgnhB_Sh#naLH@oydIE`?n+ zZ}R><=<+NG{kbQOZa%X51Z=H;n(jkD=x_2nXC5{qYa)x^R`9dtzt4dVqDB7m1Hw$= z-xe(wkbYkTonL&(KU$WNZi?*~h4`!a#p`$9O2#gBpo`b94v~G>fi4=Sp9gc{T0dR)laBHE zZxQG&bl?}S-wmLfN&b5SbYFDfR~)C`4Xbdl0d(u|kLvwI_WKIxUZmzv{Sw*lG9*Hq zCIZxS@%DQWbo4Ty{%Ja+eo=XS9p;Z4w5Nq1E*P@qgYzm(JFf;^qIg^hIzQ@E{nM=D z?R*dBuRo)S05x5FJUWg?J3|$V`f0kS;I`(|YsO6dFrA-JzuQ5Vu9*R9e$(^=-KYay zyneakXlESgt^m%eU;2buKcfg3`o-7Ji$M1|ugOsBcP>!+n|$xvEqQ24oz$nt(LDgV zGqk7057A>P3kVjKA7kuk&{5v^;~xc~ay5W|*v4S|(x6BYT$G>P_(ybU__rDVtaOzY zI_gVly2d!V0nkx+;z!v=)5Y@}weTZ)O&8DaGZucNkETPmwCQ&{=qP?9mx^5?y8A42 zbCb|LZlR<6rTN9j<2le}!Jp)!iA_lN2I%fnbZ9yay7>6sex7MRijS7N65rPJ_=<%t z(?S<-m-|4c?SiJ*;1?f{$3ds#fu=Jd-HV{3{t(5Nh6*11qx6gCm$ujBho&SUo!>%- zDl;KnrG>5_30<3oPS+cxU%dSWKu36rhweu>#bXq755w?8N7YuM_!eDe#+TAS)6s~? zjeq*r2)ZXM1y$DpRJT~^e5i0fPZ?DGG#x?EjcWY;H_CmM+O6qmDq<&|p}~pkH6zFR z{ejZTvZ~Ueipny-zsOHN`4>w?<>lpme<>EyDh2-3IcJ5M>Ty(2vqU|WXRE8SZW3PJ zQUUTwnVf=gN>&$=7S6nyFt52=xm+^ehbDnG13Vy2hD{p-JxW@GQvumQy zvBJY&C_n1ORPWO}2FjQ7Yu@w-=x`AKD zRIyeI0e_Lnrkyz!(-~wQOhUxE^l^`_F2-zAk1|JkMNx7;?B+{dE;?WQ|E-NNy-2@* zosIw7uyGOOAV0tFMkUkRdko`e%=gVhYoE$fU8(LgPntI^B`q~AE$y(hIcalK)6>x4 zS^H?DxH00)EKSsvc2QH{8!u!p7$NPUaE|h5W^GrK;uV35rc(E*wyHj3Z z$M1LZV2Y&)l$C{MF*q8*?Lir*q3-a4>!5jQkhnt#wKW^W-KOKXxm8j<0L;n#&9QD= zEs9G)#6gCxe(_42M0E8GZL5WF5x#3woSBqCyXdMr5vZ#_qCZcTMG zVCHM$mqK+cnLzS{1wS}XCM$6-cYl|qaPNX8_&OscQ+)uYWO=<=KydfYOz&at^vsmZ zMR5F@;lt~7hw=9?_Zj$1S(0*upsNt@Fn3dmBsnwX7$RB>>eQ6hluUO{N`?E>Ot&BY zQ@7wM{t?^UPSOW3QzF23Qv&oE79Xq{I15|Yw(YoGaAEiUMWzW z_$z)x_)AnSb~$AV@mq_(7@#BMMv0J}_ez1HA)@i4x|y?f0u%sD1}qE*3_5&JlsG$y zfaGncKvdGVP5Xk;sf4B<$D&YOup<Ra&%;?0JLSQ+hwpQ!mFDoi9DlIM+ zfje+FOsFGT+t!J<<#B*^a}-CoWek;9J-i~V^&NDY`v4wsCt>|K2@4@4Trs89Ih=cK zj7~$?PQ#KIgVZ<=D}^H-@KTzfb~V2Yn=8eG?X`{3@<>z@ThYX#$Z7yV+|k(CT;ng9 zh7XpPI#35GOi8ibC~fVn_2H&aywLhkumgADL>q%m^_yDT>+FHFuas{$vI#`+;{0)Ys39D|o83sr&Xx|PaImd55)IQ+-VnP%v6vW`+}>mTHcW?G!i{hF8h9iW zrP83Nfy2$J!KS8YFcJy1cbMpKa~Pyep^c#?WkJd`^=*P34)juC&c;8gmvAZ$waS}- z*5*-o!1lPk1^=+%=T191&AgGuwFZ|c$a^-3lIU<$g3)}!68wV*J~tYb+g73je#XsSQ#=$GxfpN4hRNEBs1p!`nw;CUbNF=A&WQI!24-7Vz= zH~Ry{s1r|DV&EnzztgHmMvjvV~16*lwRcTduMR8TxB;)4@ABv3-Wh6?V zvb40k0y7mAB^5){zE$5V0f$ai1Yt1!{0eoZZ!O7m?$?J0aRABWae88KV=we0({o+bV!}g z8J>n=k|)mRr7e|R;xqg0rmxb(Ru=9sy`9qO3#PZB&4H5XZi)bUIHIz^r?fWX_ZxWV zsPMSKo@GX8}wjgshS-!wV;1eNEQO@ z0i0@rNfG2HT=(6mDzwDzr>2KJde8GnxFH(sXl)MHI@PSdu=yjbHK)7;&y&&R0NP?0 z*B|(%+Qy);Fmt`E9c0WuX$Q1JFX+$O2?nZO{43uCwVgD1OZmj<@E%#UGFnTG7XC5* zcS0aDnV5eN2B~IZ{z({Q8G$jYa|*u4MNu&riZ&1Evjy5@tMTUuyvbbS&lPx6gpn;t z#$FdhP{JztM%EFHyhzClMEHa>BDr06V-8Y8gt@+kPu>2?X)rnVtwRq5Jr?^oHST&E z^hs-LyJ`l9X`*LvxOZr>FNVRB-iRxDJaT+TXQ9=+P{vG{7%XaW3IvZK4^OQ1QxBM& zxQJ=YkE?LX{gb2EjTQ5k`ty3|zyzAZ;(UL{$jA_g<7b5s9r5$<6g6_`9q1lo9+!7~ z0Nb|oMTD4zGdm$3o@R`56t#JKp$=wZXuRV|Gu7y_fOhq*DfdjPc{8TZYCxo+n7R4E_q^LBS0-DC1>S zEx*BnGqh;5APrr@7NnukiBg1xC-iEzA`R_YtXMs?%gsuN!4Jkc#e$Ozf$Xv%4HZ9ZK^hu9FO9+U;VcKYl3`5=KU2&=RT>LxU2GL{P^TeeE3nQ6A?8ThKS=NcMpll21N>E z(8X9nLCKGCjM^j)(Qogp?EnWQ3a1G0t^?z5p`vSPZG*?~$SC9Q!MUkE4Ck)?LB`K@ zlanmDs~={(2+l}oBb?*0os3@rXE;)mm+$Wz@qd)Cy#ukn$)Ol-gB}|jjE&{xR|7jZ z-ji1}RWH7sD9-fn8bIyk&nxOgjBfOJU+keF+sW|k9XegMGt|Pk znc8t@Z)fCmJN}BrEOlcVS{8?;EY2S{+ZMIv5FgMU?2t7nhh(9l`k$N+qxf%)O<)?N zrK7#I30n{7I%@Mx0O90Y$oyMtM}{YGcv6z^Hn#2?E`BGg|kqhu=%nBxEzeNZM;+WVE%P0*X*fnk^Zl z>W962pVp}P02(!S4-Px4vp0qRP^%-jSky5>DRm5Ye59%$OX1IJUE12i&B4fq16XLV zxqEz@X_d26`R}zF1_P^nM2~iZ%O8DU%cz)l!!;Q8wz0OgxeYUw?bJNFm$^Ld9JdFPbQcS{J@|{zGpa{s z(gW3%4Nkm>9_N|?VsG?IF)3)TRY-H$*L@gYs;`^0KC*EB&#IE7CD{tV9Q<1;;=?)W zZcMm`XeK<`7;Ol(gxbTkNQoSmho3SXR6A_vJmv2LtA z9r8ScPF1vbdr_j?W61+D1EDYYfUr0I7HrUa-_1F7e=31 zeqy?~qNTG5t6P->FlXQq`-R=&v<6IVuP0_!A?Wj{mT~RvB7XS8JTn~Ek`a&_4q3X9 zZ2HA7@VC(-8;wLTJwIof0Q<`D4h!wDTB%Qgeij*(GvyMiTa`g zBv`5P7fW(jk#kH}U~NMU^xkphb2Klfn=a(d5hDZ)ej0-tv0{Ujg1XkunkKQtQ=!?n zVYO;z%+W6zpP(^EwGLa~7TR1JYQw0($b2?+j1Y}F#I%7|*zSYeSr2XWu&mXLy^XO` zJO@xmHFc;VlQI8LkiUwCKaAthWMf$Q2K>kP^WsTBGfYX9ki%FMGjCYZ)C(&wa9wN| z|E=+ja{3A!1Ks0Mnq8R~943aCeES=3>}&`{H)3HBHFW>bNcRLDJH#6s;g)a*dI*sJ zjzQ7{5-|_bH!|5X6pJU^kNGqiE)lE$<#@oukA}dQ>niGxR@B#un>@%Kf9E1Hco3we zl@|B@VYpSAVnz2{msS~KoHhA@yMGi<4vvox_U{&!%ag0r^u2z)UpZuK^ZmyoZIM-? zW|)2=TssX7EOdOvjb+7?L+!0-hT!}WInhS7w4$nmg-U_@G2t|V)@Pn2gtAV^pH~9Z zPXrB_gI0^)5(G`H4K+pnyw$d4t+x#?VLX4)RHd+25lMf?JvfeA)bUW*%;Tv;*kY-X zGLG+q?N$u@(9@PnjCpxUO}J{6U;AT~a+-8VV=UO9J-zQxU_w zpsodyReG<5p{C)}Q031MXb82iu?f$GL8H;cTwe9?drU5<4Ylshmb}@^@3WEHgmu$ou$V>Q>^ChpAvd$?$5Z(`uBC#GB7LD#K1DfT)$gV9FS~PlM@Dy( zzBZl?=_q)AIgNkAy;29Uvv*ERKG5EX*ZMEUbqpFgn9X=M(9? z49#&|R`FnUr+00X=!wCHI3zORviGK^2KbMFak-l(JP%9xo4M)n;_>KT91 z)fV=btO=9`%BqUXvCFTrs-g<{<;O1C{3Mm>2x7h?O1ozKWw>UDKWp)W*l46NT;G9F zA|CSb2T1%+tOS8FO%N#81V44DJ4kh-X_TcHPQw2vbvDR8x+j`R`m}iMNyz0E>o^aC03NfoVrM?G+d6!Ft)2@z1zr z0(G`Hu0;>))##fQoiQV0n_%f4+SR>#T+PGKQ2cv_;51nOAs%yUpVs>NNXQ6LFfE8F<#8pYyj1fq$b(I2_kll7q5lSH z+lI!Pjy&vy4;120G5sk)RM45GP-Mw`;hXQrL^(RBh>yn0oL7$@&7Q{v!2THoklbux zh+g(}5y5Aq1|2mAtAWYQNrU5#bJBpMQ@DKUS^knVz#f1d6?r?03U>wycNQ1!oMwTY zhEGJdZR7MbihXkn{oF6^5^*vurUND2KDtN);*txQWDV>6YNr)h$HjwUd9 zteydnN2kZkWRNhtB^{orXlmUQm8Ta@#^#;YmMGpn4z;76{JDeI=5PmmUZ@CTt7L0S z(-zG2CJ6mvG8(}KP3H}wjl2wh(Q?|?MdUsVWB-M8#;-=vfy)iC!J#Ogr99u1 zocV4l#{MI3+l~qh!!q7S%=jL+uWbjKX}ISh8Tk3`%r;TXV&sms2N=KB?JM}RD?NL7a(hSjDAw7-2zO4@LcS&sYy=ax!;K=?y2_u59dDw&sUT2Jk8FNoWwJWPmen8f?&Q1 z7k>^sf9%a5bHaXGado^%I;%mQVxK)aGCmO*80=R`?OK^G74I3uEOTG9w|l%V+SeZt zwvHkXFyAL!{N2O61rMj#gwbvZt1u_CScR<>^ht%0wf4LC`E$Gl*QJUS&@qb_=4dZr zE5~REo5kGxQgHrjY8u(B9j`)~SrCX?Jk_cZuI$k|x>(UCnf6Qn}>fEJpVcyo+42b z@TAmw$iwdf&sXR8vV%no<%)7d5FYg9$_^r{(wE2m;2eB#7t2Ngrm|kzG*k{^Y!~=(S_s;hg{AzBlkh$NGNnaizlfKg2ch5zkw8*>z zG9d{v$v;cTq_1T{CVlyxWKujY@bW7m^GE4YW)|uZ8Bh9>GU+SLeOo#TtwrYY6fKkd zrA+#gGU>}nrpR0GdHF4ndDlD?J8?=K*;AK;Dd;U2DR=hiVv}4y`U*8Z)lB(ou1Yt)vR<)V$`83K3 z6Ck0+w0Wd&uphgEwVZUtwZ6M|0y}1v^!Y4De2H4L7m7s3y88yFip>loN?$`7{|U6e zCi6c{`#8Nzzm2n}7Q-eo+Pr=;Hryy{+~py(j1J z&q41WFIjX*a=B{oKe)ZKaeSv|w<>s|4pj|}W0n_n zji@}nlg{6S_{)z>CjP2fi{B6NmpcljoLDoDpR>?guyyWXHqKc*$ConSA*RC6 z-x- z8WWj;Q5CX0^F4-WE<%Fk&dc$AM=C!?RlPl#3g`3BL-{>N{X3PX8g-iTgfx^tZ-G?) zS}4C~fv|j>@|4`K%;yh7`KSHP%FB{pv%6U5Ur+Y5#7Ie$7^$;J463oF#fOkaeA+T7 zJ~_S{(;ea>a?x!I`16R%oh!1kBj~;{-+ZJW(>bcXzC%X>JXKa`C#)E^ERuZ@VIn$s zW+t-WJ(j`W0Pp*Ava(w=8#5N3LK=+59a6it~ty}A?lI- zaUuU7DDU&$a>S~3|TYlkxV<&g0jWHgz! z8pYnxn7!?qslDXTX=G@+$?nMHHy-IN_-WoOL?tzwvnaCMqDA};hF+e-gK{RPI?TBlF~fu<1xya2=@IX_`CeVb zZ(HUqxbhg=%ul>f6(cRwk|9j)y?E^q5{f&_{4JstJ)A!U34c3862>u}j*U18dgO5a zGYI;1VbZ9Gi6FDYl2hgFHFx6bsIE#cmVF`a0oL@ZFmR}QC zW1Ci5m?L|1r`4^dOa`4qi8}JSCH$UjZ@~|Wl8RF1F+{1dVTdAkQc+|tZx(+DqV5eO z6{YNDh!Q2j5-V~i6D15dn#G@hsB4OaDCg;Ur-aGgJ}J8fda7wVEpB6uk0$8_=U-&; zdyn!KoL{mizOgbZ5~pk`I8(EVM$??JmK|R;VjHpw6NyuH1pfns{Uw<&l{7lhWy(-A zs8cahVU#?#9Ko;idkcPBnw2~bx?m~) zA;j(}_a_!R^Ek@tH6wcrJ%Uj+dqklZ8M={KvV?B*wM;g?({&TQroBt~IV-#cH&i4s z$;=a5>Nek|8->m=bff&SNa#jiixcWb9jKfm`F+ss_DYA0hzvUs3lI0jrgTpjJp)UZ z!?G$Rix+NDsEZAC@7CnVHz+g`<;zM?iTF=k+94-0NrV8-KHS|~k&4maXdtC6rs=v9Of5M~KD{_N<9KB%w>Uw^)XBF+} z5M3{DPUBJ$;&0n3nubfgtN(Nyf54MZE5)LEkdc+=sX;$D47C=!`o<> g~a6=LqM zl!x5AMkXtB2*`@=I*5T!Y(cwEM@XvZzVS`m9hy&$_hfEH6sN7~YqmdJ);D$3? zADr7QHT*5D8(sN6Yvow=?`!z^DTrRA5%D`n9(UC8tBA)*h}1!{c)gb2D%Ci69$%{C zUl(cwBbyJ(7H`z??1B*$Mv{CCO@2g%_J_55wYp}8|sH&Z28 z^-J}9Pb%eu=FZ?Of?eIfFHXhgL@FJKFqNZR@s|n*xvWJ_AW&ERpn-o{1VUQRIM62= z`7KhxrXY!;nn;#Evm8n{T>u_mtFh`Q8~Im^@QLh_jKL?v{6WPav0;-j_+gkosWoV# zC=5DAfv|B=AQbF&*@^rYCIgDYY&kr7B7aqKKq@CN;&jvf{Y3sZ6)H0GPsz%d zf;J$Fqh>dS!p&tvhpW|deC;XKuQ%~eu3DvoQy)t<9@|B5(SllnQ`^zq+e?kIZZE;+ zSKjJ-n)w43HbxVFk6phJ7$>-IFc+QCnaU8)^qdU;qld*b*ah}j=aCoPKUP=+tjr36JY1P2sG$T)qnbq}7zugw>c6$}rg zB{3vziQ#@`Fx-!G2ZEtC<#gS(4_**3EsjYeviKG4{57crSv)RgBoeVAiH`XoQOs_L z@QVtJWQ>a)F@^n!sbl^)gt4o>u7kf)APTH~Uy50DmlnvPYwJx@$rZ!!E;$D8lKX4A zc8d{t*KU|Ni+5SK+E9O$Dv2(0zYR*+T`AR{?&P-|Bg(v81GDtQ2y%}OMO?QtdWVmt zAX9w+rI3Q81_7DUcw!kB$Pq&IpGgl?b{ClH}RoiLvzF@`w16c@pSEfgTf*H*ahs+0Le zYiz1v30Ji{xtLaP)GTk=7>E)ombXj}js(R0fa5WxCD6DvQ>^4mwSh>g_Lx=eE(#tS z?vtf}t-I|M{)k<5X;qq*gL(FGN8Jx()y4A;)~f4X>f*246%w{guFnB%X$~|g_Wv?l zzWHH(>#??Mplpc(m5XiB2W85)*Bq=V7h?V)$M@!%bzh6}XY6`OlO|K^02UolLw5oH zWfrY||5ScinP?W`cjlQ5!?{JWVb}~CXYno8dc)GO>%z4VqA}<%l8r)tK)D0bZEPIw zno<*rqM6ujby(`{t|{!z!&zB0FT0Je9?7Z)oh0CU(2Ns61CEa6LSI^Hj_<6Z>U(?m zkIF`x;Kc|?szq&`9Wr< zB|3>!-pAuq-j`Z^eT=_aF3RFGE9>U%`r?E}rWP%(OP@e1iU*oHiig?oQ9R&Etno;^ z#z&=PKHSd_Hx7+PI%{h~kqBP;Fi<#6*V&BoJW*Ux)Y{I@GJTptEe*JbN#Z|d;^pP& zVLV&XQQOGQG(B*e4{iivXPB4>PG)vC1>4z2OtmC+l_}p4-exd7*8&nJNLM`?le5ACf|?A^qMco zq}Wk-8`wl-;EgD}E<;bwP!POxYdUHX(8q~ljulCWxf-D<(ya)*#;ct~JYPE)TcAHp z-Weu}h!?J66eFJpQFEuw#Vf2hRKX9Yk41TS31=BR4;LSJ@ptiDc*(bMmds`HBa3jj z8yf-GQtcnez%AL5f5{%kIw(Xy<53(lIq6rD$%qccl0FzKTZ52m7gR5(THsDQK0Ulx+NRu& zmdFYd*`VkuO_U7ohtw)Nl2B_+RKsFIRGSDH5JOixim~-3q5-x#&UBipo&b{_Z}%W& z34MZzmg*8RXd*34@D_EA-9s<|y4FN1CP3CLhtUGak3OVBNIDp+H?f-+Y+0}gv22hi z?QA4wI$YRvkYXoVoDi`=IvH!C4|m$S^im|w@kp^|6G6_F!{JX^sg*vkAh}rNP?@BR zog|%<)a^?IC(0KQ`lOEziDRsDiO5YGvyhuMWr@7Lxm0j+9aad!E!u%c4%H`=K1F^K zL6`hw?8BOpWPU_D3Kx(ws+=k0I8{2NPq%as9vz`ThLqYXJ|U=&K1fWAK5+knSAeYq zsGtvcm9BUcQhg%SY4Ve?ZQ7go4{3*#yj|0i-!L(x@;D+sz++U$fQ-FEI*w0Y2gjIn zEL%)^jcW&E6J??VPgVf7mt^z88B5*3ZS}v($QnAP120ka#UX42@nZ9jHhhYUKz+g9 zHtMX+!Ic9Dw6i*ZM8J{84`J8kFM<34P7{=jJ@V{{wg1ZfVH1`Ah)aH17>CQmr+AG+owmFissLpz*1ghXa^_3Z5FiU-`s zx)lr@euBc@V@I^pPEKbae_(n!&=nuVGygQQjfzpCL6iw>3k32TVYSAQp1yce0|)YJ zJ)eEs?u75Y-E{sSn@DXqlCjOwWvV`iB43;Ec{pv`puQ7V+k3R(AeVv=@*5wISH*YY z?Kt}z^7^1T#d^FD9oCK(CsJ(KSgXzy|I^lP7JY|adKXy zCK_4qrrT#YqU!W@<3s~|y&9iJK6DOs2ecWdJh(OOj~jQ=SjfJl@Vb2oZoe1?zd5g$ zM)lh~;mbs^%bg-#KbXsIdJw=f0ftvPGVS)+F=wD(_3L9B6b)xFz>U_EFYS-knJ?|1 zZk%e@Wxv2Ehp#H2U!Ym%D**K46vaQHr!^Ppcb>~Fd{TJbKC#>7?}vnRms|M!;*U-g zNZkza6OVhQ_>RXtOWfgcA1OZOaUUf{J?^8$R*ySVtns*KiyW7GHq!UMFab=dESZJ$ z{Ltg}iEA7aiP^qVvC-oWieo(PV)3+NV(=d;_IcbN5X~O5U_lgxS8O;(CuePqca5^F+YoUM_y+Q~{)?K-}nY7m7_D_d=2B zaUUoCn=+fP*?981+T&g!T0HJ!#9WX2c=1yc7&zOvQalDE7OLY}DBs_4`DY>SyA#}> zN^oD7;J!4$J>qgNg*=x!@Ok|p%^l2$U~tZOD&t1NY9Y=btkOq)&xq-L^=CwdxPtj; zuMwi(P6+yEnSL+Rzs>XmOn;K;KPQCTmze%Hrl&wbk~4!4dQoxo;Q)z;2vOD_Wqh0v zZ3BfPIwg#-p52~ssADP|P=&+LQiX$Cg#)T^z;X(Y$Jx~^N4bw;H~fP{$3pl*R6PcGC`V6#jH}?;u3DF?OHN_%X&?2*Ljq#vd`h$cV#Zob=6i(sMr1PZ44- zA?EK)I=@bC9Q{N2?JE-EX+p&R8^*U7k0JS>2N~BhZe=uj?`8M3jCV3V!1yHN3ykkF z&OjL_`FV^{#$m>fG2X=ZEykxA4>BI-*K$@eu4S|s&t|-e@#BnNWc)VcgN(*b-y%Dp za8W(?p%5ARSINCbh;I;L!N<_gC-+*mHwvSn?-8KmxbX`KOPRjh@&5wRD}?wmA>NvJ zo)C66+fecoXB782^`X2I?qei7}ubUBmO4F9>xn9-(frwPvXS4oH5M!4aUb9pJjZL zadxH-cO~Ob8DC`VoUQ%OVtj+qm!;_!FW|-XFPhb_RnKHgK>oMQ;e@NQeR5)LX77y?qj^4QR1*B;yZ~k z#@Nibm9dBMBF3*WKF0V{#^)IS$T%yY<*#5YWjvX&m2oR$2jei~?Tnvgyqoa>#@89& zVm!#0xkSfX!dS@|VQgg_WBdr?UdE3z-pBYL<714!Wc)j$f2oddCgWnpQy8O+^^B)8 z?qS@^cm?Avj1MwC%J?MX3yi7DI9|p%j5&;}8P_qM%J@OXvlw?Vp2xV4@lM7sGTzJh zJ;rAkf6e#`86WcQRhVcn#wnjQ24<$oLrJj~M@laYmljqnYt) z#vd@wJW=~c7%yOal`(Cl_RnTKk#P;7@uH#k#T3C_CJsDIz|k4gb!`i1B9#i zxdDEn025vX_D;CNq5xYgjvyqrbfm8`>2(G%V%!#oYvY*Uat4 z#?k}YjoIT72;SYNBIwlf!=gaVCU?iJ?RZ-XuXgEepSKMS7I3WX9XKa+XTi3ifziQ& zLMz-yJG@%G9fRA~*N*In=M-8*2nJmt-4oQE2-7)A3|2*_72e!X+Hht=v89hjNeH7? zpb=o#_7Vy(T0L4+-xKdVtv6_GRy!KI0@%#`LnO>IMT8kd$or(XH*ZXYcN6O_FHO*@Orat)pWmta#I@gM|$nOM1FOR+OZ;bu(uhQc|iF z`_}rN9Xmq3LtEpvW}dubqhZS4LoNsjcK6XvX;e&fIm4OwB$5JbHc0Y3JY^Kuc`}$a$0a#8;wRoIklT|us?Lm z#?qXRw6v~|tgq6}GB|7MavEt9>S#`MUAR1_IeJ=oPE&KVr93B!1Ljbr>UuhIa++~E zOni7GCkKVAx2FSXYLB;f^jM=kh26HJdwA6G>Ba|Ljt^E490%5R+)D}YpowQ!p*K}6 zN0+i37<($k%xljaQ|c)AREpiW;9Xb_DA=xoPngx?bm!cBZ>l>rfMTCY6-ZEC7j36T zkeI1diKJqX=bfF}5L2ll2{Js*5$Q3N_9%%Arz}jRePRLB9v^N&;IM~P3RGA}<7t#$ z74oq2Ux!X;4yT#W%jhP{)jeh)!K^twL(KC!K zhK6IK{hcE{IOn#_^HL8!nCXJB_TDbqY&!=Zij9bHH69n$kXOiT+@?m%OGF}V))8{H zoa>t}7s!Q@)}4f3L<$Rn6 z)+O+r0X-ng<0vStM%W~L0j#;W^Ua99lFNY+L2EEM#?vKlPXgZ=D48R$ zwYf|XOkaEK{PdA{S=cbS{I)^fY#04)@IggUfgh&BRat~d#TFAUP+dnM@A#I$#7k?B zZg~OlWx}82VH(MnXQzYZ1;KYcMa-9xXWNv;2GCSM(#(ayhCNV3CUEYLXw|==; zYcTp@+HgYs%E9+G%O({k(k}?3)o>cze2Myvf$#Ao`rV(PU)2&vzm*V3c|pHK`_bHe z4n@e#^Y^}G zLR_ANFHyf5B=$fOJ}W`L49q1P{es}1$bJjJcS#a?iTd3NzNwVIH^BGBB=QOq^t*LA zJ}3Ym)elV5PN?6#;Cr5WA-*QE-!&nuV;Ux);Y+k1&BfBmeC9HIcDuo4eQhb;GdG?t zdD!5`Qw}aEbL_kVd=uIEdhi9%R+`I*PPFqkvA%z+VFDVy#B^*v1^q{n!)W-P0LfiW zZyIv+!}7s|`h5|6vm9}DyyNr(-(V8HME!Dy^?L_~)#$e$1h;+*Mx1sx06$~D#CA6T zzE7tbX^vek0LjQE--mW<8HUqj_1Ou0kAm+Uzna&^IZsqgP;)~@fbd8JKcQuf{(%zA0^xHCCaIpE7hfuwX` zxqd>vy1kA(ERRpf*X80P-6zuT92Xz8WfSpT@KG`YJE?)$nvERx`g2I>KBLv@|p?~9MJQo=U z(D0cDdVJYlFmO^J5GpP&sVEMXm6rqp!2n(QFP2bBOG^WR;^LBGO*v!6dC|HUKK-+$ zN|9^JCF13`Dz8*ZCrX3ZC|bnYZx2=rQ67Ba3c7?^w z@{^+r#kHfczU;eVFFti(fw*CJ_|pqgZfMTVc)CS&#C~-8F|p>zkLPDD*b-j3P%QJ` zaPX~v988O)f6{+_G!lr(7`gLeVi{p@QN||@%*ohu#NDrbC*yj*!p@jD{zKM{i*JgZ z7~2tfZvKJ=q)Bu3pP%~K?}Rvb@Zfo5Icn1|q!q8-n=0nL2{q?Pc-O4xVPB{oHVwaMVKi#ajGDQ5^ThubNUI^I#$%-e$hRXhS#c znUdAzHdR$P{{g>TzOgUG$1_~qoPvJwF_f}8C-jBB=9c)?MGg33! zLEj|h594FHUF}10J~+ChpsJ;*KfbF?e~Sc1Thq|Mneon%VPZFFB`ilJ;k2awpG^y8 z8eQYQdiSLcZ^x7&JW{c$EKvG-2l}@K=nu9rc~+eAjTE^$&DCq_mcz*F8EnBuKA8`q zZT<>=J3#Xp-X!NYixx4f1B%LG&fu$PKSb4rE!_9O4Oa6@?;|EeqR( zyd&_iBHFZAO!s5Yb+JYJV)u||h3~2+io&w6rR{Hp1>P<07%i(*Wc^X3wd_yXv_FLd zVk=$>SO;cYP5Ajm6n~+cx2>M~b_}{+khnBzql+O*%S6F^?=pq%1X88{lr))o#9Z8* zmo_KW@1KQ}1N|d&h~)RrOj`&dxs~4&B5h7uBizRViInQ!k#@Y|I412xruqGG3UVw7 z({~?Ge2|oOlK-5vIrE8;Zit`)&rVwdmH~aQrIIH?R6^Y0I^sxMiodD;JE5)$ z@C#CkC}%3Z<@mb-zjbic@-e0Z}C@M+4xH&gxE}>@8Wxa zx&ruHfFD9rgzxBE{8blq303$>aheH?ThjPBO*Kk_3WB=mLF{Dwq-b@*v^rs0DGb$1 zFyOC!QI`WP2w36mCOnkiZUoT1iIwi{@VL<;PIHOqa*6121?zGLqnweViGX63qRoWD zt%(=6COmFUaES%1s&H%6vI0wE@eU021BJm**-{9xELu|{k5F(`sA5%dv8J}PRz*O? zVfSEB4*npOh!uEDsHjt3(W+{jjqV*TJW1FbY9pA|Elm{BXg}@LjPJy$ktOLAtf{rR zsx}t0n8$bx;{>6BZtQ(N5-3)@Oi&H8hcY-a#4PBuA`zoUpd?rtEG{fmfm^YIO|;dD zG;OdVjrhEGvxQG;bqd)l2CtUJSSx*Neh80*?{owBP8X3-9*%qDog)%Ez; zU+e0~kq!i6P0;Z;cec%0@o;mb#wu;G46~a|B7$xMDCX9h4fX2+MdRq<(&8lCVG2`J z=ru}Hb7QQwE}9r=EE;abjy+aQxGuJ-vAN0{$oT5`y+-DMRZuLcM|5**v_X9x-5jm1 zZNbUn$jA*1t*mgkDbixq(t+cMc0G$2**@CW;l8&`hrP`0dwphkOH|bc<^~P>zlQ7T ztZ++9w7JzG*Vfm9wJy3bTE`ZoLKACJ;_&$~Rc&h0e5wMj2K)ne?vVp|pz{*=%tByk zk~Y6_cFV!{nSShulSK@;a`AJIk|!IT1}Feug~0Hfb1qD|$iLTjvD`FAJoLSXAJOqH zfFI2}EW!^8%b6C=^rqK1tnC3IXQ_4bNL}qZPdy5TDukS4k%>`AEUK0`QAW;XiWRY1 zHpF813f&6y_6j-AvYNukq{7^>mAh92#sbTh1$GNLpUIl);tA|tA>;yESnk*g#1UeLV>C@aK*O*As6D?d8SVklr$KfDEwjz=g&7((@%~0^uSLpQ_UX)TUF6W zT}wdtj<+l_O+$;2E6pv8HVmF}tG>1&kRK{67jgt{ycDVkMTKRhAdP~ALPwD@w}>D@sO%JYV@xYE)Eqri99ii%ZLj(JvI01uIHQLZzV+M0T-+Y*Z!`6}R~= zamWc)ywveYZp_OZhAGd`8=n?UGp7KkN9iCZ4+RImbI$K7HQt zwzWA_Hr+!Bz<5bD7P!^c7V=v*9Xc`{yY|ZiDh?F@9wc3BBILsq0+p1T9lNP@HBF}7 z>Fq@c_`b~#L9V7bNugH!kE@tf1l|D2T7pp(rS7MWhc|h@kS(>GTH1?ip;Q|nwUG?CYVVpheA(JDH)F2 znZ{~@SGk2fz%LWBJU}iK2sl3>WQB5~9KdL$lS~9i3t$Ztr&1{73bZVOH|%50lBebi7J8gc(E8iTGOYe6?zU>gaK`R zOKl51cjD=@2IJZs{SvKy!mQU%OeLVT)T0l;vJFZSRpPqZhA0R<{q%}03JeXK!>wqO z*^5p}>*;iHoNQSQjd*t$&x$nY#mTb0!-Mh8T%24N9~m9$M>7+~kiI2aMe&&LsqiF_ zJ31Wiq7grK%i0tTuTS*e6>r}`-k6x!&=9Vxt!{``sYin%Jc*!<&CA8Z#9({p4$MJN zp(b+&@>al)LY<1F=`h5c5OaI4nz~?C7=tzeQwnN%LgE=v(~$h;4Utwz;HdEF1J1G# z@(na}4UJ9k=pPsq@?AJL#cJW))!ifH1%7gpC3khhjF-XL65R;raD1nb`{Ar@S(m#a z&@~YFFi|_V$Gb**()25=I(6o9gS1o z;k(TC9fJeNW2Omtc?vzUZG~rN@7cPap&rIB_^ng#EV5qYz+bh5$lJ6fUqF=dQKxU= zm7c_a-gU?KtxI`dmUk-uA!R?R|F-xDCRG|*n;S84uhtiwa}bnMZXxq;iwyLS;Db-i zBAdkOZ}{Zdc;v?^2Tpi>08uBiCJ$KoXP?|l4G+a!+tkuLX|#$#>(L}CzvP!!o1o!C z1yu}o(3kx3W)pPmP(e2ngB|oMDf06sXj2P@Dat3gnXr`BiES?NMtkRuCMt>eg4hUJ z{Z5MfI!%+1&6FT*uaSYl#%>CzLJ4iQ$plp%NR`U=4^`~IU?{dYr2Y(TIO6|y0Mxf?x1?NLi5^s-7F}LV#Rp5!mF#IgN!pU?-R9$Qzg(q9O0?aWzK>#{60~Zp>S#l>xi*5FSn5lWYiaxv zMFNgj=A5Iy($0#xvmLH~6d0a9tAr01X(%hf-o!uMUJtH>?PpLt2fCnFJ$J z%wL)X2kvt*%AmCdHM$9I5dO1N3DWN&`>`tbzLy~ks;thwV8Qm}rN>nUbOA#7xlh>} zf9(D3$Mt89)PK8@qb#WA&Q~A>^xiMk;bYL)jttR$#5B*1rkBRKN$0s2kQY9$N50xa zQyQ|3Y{wR=$kStKfZL2y3+#E}zQuHLS;K}ptd*4$V9p?gSHj=Zb1kJn zXC>G5&#Ls{k4Tx~b1jQ_-|~&(rYrHaiY8jJqbCtOa;~K11}cDJC4ThHKmmUAZ3yKJ zEJ`0Us+_@O{De7!95E9G?uq)~Au_C({nY{=*7uU;E2y4F4UFEgy|tCQw4F8|UaFoD z@bFU;-iY-dtQ1r=Zdg|rrIn#FBfbf1UsDr~anbMyJ#$o=u(77-=18;&PYrhA^QdEo zs4*eNJ$Ti6eNZ}M(8fHLH9D#H2u_yH?P#OwTKSR5o^Hrnv78=%gv84rHMQ&;3Y-|o zO=JO2KV{W~5{4|yyy4ssv#|24G}T7P7wvo0)0g4c-ac$~U~7$$o_-RD$+tIU&4%iz zwGqpVXra4%2iiw)z$4BTscooj#RviMzh$%3fkn-ObPbGl^u`kz-^P5J4mXjg|CKnj zB!G^vp785 z)4f|+E?2L4)BTz?0e0xrt_YlhyhTy5oG{(QxN003ROtAWAB&V*qs@)zhT!}WInhTo zG@_}4g^EG@G0_Zx)@Pn30$V2<$SnftCyIy6L90b?D2BSm>UF_DZoX$(>#w$#GF~7! zR<7(7q}bo`_Y7mlcpQ#4^>msLo>Us5PUAs{-G&E0jI{LBIr4UQGs&Q*4>u4x2=T`oFlJ<_#E=Ol~nc2y_SYIztOf9Uls=+)n@ zI)KS5wP_a>dqSbo0wC=Hk~T2ZM^y~-f~FOiw4pU25@i}O5c_?I9fe$M78dXNR}@&< zypD77Y58G@@RqhnKpah8*7?(wrm+-ydDB zCgFS4aTW^Soim(KD#rYnOT!p<9sXkU>zx~z+9ZJ9=0lC0>DhiW<{PH7j>WmQ;N2e{rYr@vjBx@FVUp<=t1BTT1K7Sq}hpZ6)mJ@&Ca?}oTVNB;zL8*+xxq) zkg!c;{TQjOywxYKlqZ5zU3D`%Swu+X zSX?Lbx-|K{#Gr?WltW_f@d*>sG)Nu`d({<{Z>7nn5&}#Tlc>BUUH;j3tU5Osd{?3P zjVnzk&7$(rborKVk>aC7Uy`hxq8^CKchlvU{W+ZjgS$yzkIW?bsAPXRLw>`*%mnd@ zPf~(ZG(XFbUrAlo-QF?m=I?e*iBh#h^Moq`#IzzV`bzv~z;U(mRS*+vV*tUtG;x}X zq-xY2FG1Ypa=VIixA<#v4^aulOeCu0p6Mls+uUx|DR+x!#?iz)G@e?HT}-MINn#gK z=!j@>i@EC-w8~>_FWz-Iy2VK_mo_mOPnk0Wr1vn3@S{17YklfLLOm(c;_59}{nHDs z&OGMleVEAnf{z|J6dz41#=`Zrbz3l-^q+|Vg#SLDKgItY9D*qy^;JddTEo_9MIk)k zjiE43*&d1aIy=hL<<0=;de3%!8uG4n;8`ANMuY28s$o#i5dl!cx5DS6)$8 zf%5WWAHDpfm1zxQzQdxoW&$PHU`amh@KEdrgl5UEWpnbeN{5c;qxn`vuOj~;nm>~W?gA; zT`3;T|Hr46c#A0muxQv)TVI7mV0!nQUP@Q%!DiW3$Xoq7gEllIU5oBFtI@YHpFJbv znP6$}-POK(nCD^WQT%&$#JSjPb4aaAdsWHHqbE%5ivSPX0cd@#rPTz(v#C1)SjblL z5aJQP@o9|3TB3G{ym3LCSRUnAN{fyByj<9X-aZH

    Z8ZCYQmt~D3$)rVH%Pa*v& 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¥@`nmYQ~O zU{Tmsj`RD4d;<;Lrp+w~7#xZU`3{`h>KozQ*V`xL`F?VeCHM8hj2FY%R<{+-k;q;l zuY|L)ZGFy)V9!wSL*(1NE7CL8AHk`=!^60pK4(QGeEUYaatg=m)pIP0bAtPJq4f&p z6mCI^KMSU{M`qeHEvB~+)8->;+A}a6O}`DM*qe(KVt=KOzar=6R&ovv3;Ex0uHV?w zp0l^Je=I_Ihwt1vcSnbi$LuHMB?&ZT+kwFD{Np5Uu!=mOSVikeb zqeWES?w6l5QLB#>RS{TGU+~M%nyBMPin^T$tf=2ekY6!TTiP&8nMB`~;h}CE@rRAR z-Md?;B;t!q!>H=*1bHVdlaS36BW?xrKvk0&>HA9 zGHfAKdnRb@&DA&7Y;JDBN@Xi`kN(BJ1b>!40gH5(D7pjqi=K5#?Z{L{pr*0GClG4H zsfV-HxD+e@?pB3*bv@R-4^KSSowPl2aQ^3NlC&iSjaIVoZ<$JulxVxL;9iG;N?~|I zxS?)SU29_vaw5x@AlK3OrI5!k=IudqH7&RWOR2NNkYXYMZo5Lb>I~P%2oKVLVPY)B zwyG)^D%-Lmcs6M@K{7FhP^@2?R|MSWVw6E|2h`}MaEtKoQ6)(4k@TyVL+^7Lvc7+& z!a1?@ILZLRQGhTOyj$5Df2=dTC-i4F*MGW_qw6rXiHha;NBb_R4$ntpJ335fvC=v> znqC^`#$4ylpdfsfjC{3*rZi+5-G%cbk*CMe0JjwHpBusH$%Piivd?VTP^S;(@p_gnl6Ty@-kER-G zHogK#`@&Y@UmpHZ-oT>tp_s}UEXK#p8RUprC~z*+7ak$QN;q7-lEWLhnE47{*Hi@<+7QC&R8gq<`Mn-AQQEB4V zx72N~scXTk!76+%b*va0OpFN=uSRzWN@qQ^G1IcmcIsV>W2JK!+Nh>>o-$d>4Y@0p z)AUD3d_}jRkwZhlmBAb@31|i>tKxDP4rApFcO{q?E5DMa+6ehO>lyX*ML2eKj)ZA- zWwdXQ7-I45O}Sx9LtS_)UJRmz?(HAy9L1$}xJ#jNQ)4?u2$27lMbZQkwGPrVG}hH0 z@e&@!dYXuc0$4rGtNNtGB}{IF>=6^Q?}+?=O)qkF#3 zs0=Z&HF?C}8^zUfBO`si`<3N#^jm6rUb{BP4xQQ+!IP11g6&RB{4mni zuNZT3CN<&mOL8D4FPO7`#fso^BnVg8=psP5Q#f8^IoDXx zdZrN#cKKL>l>i)t(b@lxNQFKy1=%vaRK$yhR9uNv;G@#%WG%=&`KlR!+jZcE^UX*8 z5w`H;s8wQ7t4u+dLXKL|p#2wF`+rz=c3Y)zDGDXE2a{>;p@za=V};-6dZcTS&Pit7 z>!?nq)p8No;n3@Q&}*<$bpVrBYSS(%a!;Ys48ZMv;x;rqKvfLuf~FOiw4pUIygUsX zu>DW49Rpt+z7*;CM-*5(Gl+g%d2Q$9*>2ORmdkP?311A*yNRy8(Wx7TBe?8hGXc+s z1Js6MIMP%b%IU@O91n3Ey>hUZ-ahp^J8GIfJ?4nnlGB^lKIO=H!FFQsxXqww8lv;` z@KX2F;NyEG(N2Q!z3Ona2;U!VXOZyTJkuVfV$84iN3O?6cf!1GYKs8+2n98Ern%X6 ztT*u7eoEtgj{bKT?VC-jNeS9c)(flz`vnx1y+n%|vd~1}B6^LQ)}qPD;|h9_nx2+^ zo!Fx$0FmM0U7dqHc#*JEr2hn|t-R4EFOw&l=0gt}dWA%cY_JQ5UH6b)2P;)R;geT- zV{n8kVn#UNm!GjCP**f5|F6>Wp`{VXCuROuzx<+2O&ytO{#-(IVw@LqBZaaf9LC*t zH{n{Jf2V~|}zF%JGO!<~51(2i~Yh5Xv#J_V}2IX&NM#h283k%C{2b6P^f@ND`Gd z%#eTf9jER}1>F@WeiKR)O0%eZXoh^tw@A@ZqA!Y7PEij;KrR6Kdrj z;pwf7K}2)=iBlb3szx1fdx)<(+>YYhEB+cgKvY68BSe*4+WPMB5TA3pRj1r5o|)h$ z7NGIe(X3+9;Pn#w$cL`Q6*ritUO{hpjP1oc4o9z81#@W=E9)T%g1%{^@6`(NkJdP@ z_Nj@4nkmxD)f@2kPrq=r*D=51!$Rh*KALbSI$Bn&uWoK^It{By|L%<-{CE5O3I6}U z#eec4Uu|7edv*BK;t(cysnA8mfp%CuKwy(3J!W`dwn}^<{~+vuS;G%ezbb-iGckxh@iQ- z;t;(a>mq?qXbsxeAFT#9w^$mSbW$u0NIJz^K_km&NCWHv*i)Xfw=i#SC~t33-rflo z*o&0MNk8%Orhjipkypet7Y*~>%I?+13YATuH>UE?LqBL!RN|r6)WjbN`(`csw{UWj2Gj@g4c_M0wNZZDIZO!VYZS*}N%?J8tV*(N6v%M$q;~9RDtVRo;lL zlAAX*orbmEII*9bj7G6R*Ll6_BQM8a^qjHYpIZAb;%v*9+DwW*oUmt8_7QzF<}pV< z(%gz^@Wk&^*WrV5a@p_0j6x2U@7oOPec9BJkT79-)E9CaDu0^x z(L2`e7V^{n^xQxBQZfg}2HHELc+cL5n7(BqGm3o(qZqmmN#C-B%xKL}q_-DZkuwS3 zKmI}}WqbRE(QiWK!R|F+Ps`t&~3k&zC0Sd8V5uIf-Y6oS1aFWj(#zC!Ye(p9E6LoUq?c z93QT-&S}tCsn3iKjf}SK>g(mK_AN`%ig)#4mANO}-8s?|?&%FFTZd5wMEb{l^6g^+ zx%VZygwa*xPGPak;uN+<(N8LjtaaEYFPs_3{mcxN114o&VKMEcY!x#Z%4QM2ybPTG zG9!s>){5)@>>>yceZjgelfF#r>Urd~whtPD;l6RZ2r8cU`sJm`f!rS^O@n7c0`bgB z&()bbfiFI$O2;+Jp9bF>j+q8umD{m(RoS>ZL4F=Q|1uq(DpTX|q};kULEa9YFU?HP ztS+RB;;BSbBY>WKnbjz&^pxPgXC@wS;9w>yFxB5zE~WI_^TQh0`vNl%NF zOnM5&l1b_OXh2>CnLkd^GBePQ=ycMPmPt=Z{+m-!X&o|`BpR6%u4U4bmPt>sWU8|D zPC(uSnYYhEwcAR28BtzMJ)kS@DRM&QcpEmBswFaVCuK%YtEDp{)2W7VWuvXQxB?a< z?#OV|Hl`9XlqmlIAs5Y_MnO}RPg|<1Z!+djCd${q{P)vg?kI6_nWHBX>7g0&Z7@GH zXBwJ2sz`k1)Z|?{LtZck^)GcA%vJYw1hY`T_3{jPDR@7fmYUhyJK7W(w40$mc+~fI z?i8uIwe)3T@x3*&H!?gDar*l+qwV|pdV2a%lem#zuL#>a@m5=;Kb=HHVH70PnKlpg z^z~v_u#uC(TS?qhdX=v#*6F%qiSD6lKd&Ozjp3FoAw^P zOFVi9j*+iH@5kr8KYDX-_dZzNqqo!ERLuY57estx6iCT5XWZDfA3ycbFN?6LoPNpa+gO3LA6`81O9$wd=O zlii{$m_;2+)Me`+{F1ocK$Ep|beCy2QbZcM_N?^uS!t^M$Vy){%P!OQh@G0%@2AMu zA^wWvCKG@4w8bBW_$y)xrINUQmOL*lkb7|PWI|`oo^F~mWLA3O>=-FkhW^ehc_oB? ze@O-x|5lvdZ1>-$p~rS|-O?v`T6!xWU^U~db~~j z@*d?WyI-6w?}PG>2V*O*YySHEMW*~FWKPJ8#CVx8V;Y&E24LRIAWthjEvb~Atn|;O z#7K)OMK{lpPa`e2F3ren!|+X{&qn?UQ=;nY+f5?ClZ!$t`Kr<1JUtdsCZZ3|>`Yd? zhg0Qi;QhU_hi+feA|*;7+UO>!Ix(V)z&5c!~ZYlXI@JFIg$9Hh`Av$N8#Jtmey)O5a* zCVvZs{{4iM%x2SQ2=7`7=B;M+golNgK+|+f>7&a7t)pNob06lN5xYpJvE4c8@||Nb z>RmoX8DwN+1ItjEFsTfxp3kStgNp*W=bt!58Qk%+400t+CPNkNy1DWS$aontnrvG| zv3E4$?z^UHFFkb{>Yr$`Tjt8o9v8^{SO=`B-qR4Xd=E++i>i!ke5H+dwVv14* zJa?YF1ERi}>ss;AJ(ay)S2SN`zbSDl|6{HApq}Za4ts4ztuW!00u~3+^@LTGdug7$ zd2t~3s+F#lAFohOkrC=B5H|O2+;|5GMeTO^R>=y_mybcho9~l^5zMC}L$L(iKVSYF zf_|MhX;RcekX>WR$z^-;q|gFU?gIHdB;23xlHgrYlVr#}dVL!xBaANkx&p0vYmNh`KX0sVKIW zB}&x@N2FR}36lx>=o%;5r>RY>w}_cj$glXe!J6&h z5_$WwK;^Af@>T!x?*6`LSiSumQX>~?I5h7db}MG zl^3s-A4xbt^QTP};E!X;@dh*-B3$foz=x>3Ypwiv0<&jwi@k?lv43f;ye45e?dVWL zFK|whS`p&!+A5lagH0>{c#^z3VFkS@R?UM>tp1)F^nHU+Yk{u^XU!5uTkR&q-e1X| zSPzY1@_JZwj7A2cc$dN7TKDN1M~!+%pZWe8`ya9L#P2#p<)2TMe{$(SDP$d9&^jEF zT8BgO$U3}mG&+2Lo&0=YIW}0eRpWzlq(f(i{;1q#HspE-x~t|+G$d60I|d^=n_(#J z;53TLE2^;>9Uq^aT3uUtNAuj;f!<*%#dZxlCt!}Z>| z-Lzi5VRWN&&8MxLsQklvd0`@w*R}!aJ4zn6)X1xe$EirvQL=coMt)JNar8XCS}VV; z)TnOTepI%2tycbkZE=(wzELNCsx5(|$BrgD{!%A@&vrOU4qvI4e^nfsx3twxRS8k~ ze7!s{gUUhkmg;FlyQV>2G6S0vsdga2RFAUNU#cABa#lIzfwt!Eg!j14$;N$VOZDj(e-zi!2kXP3zse4e>+9K$+6m|9_!YP z^1LJ}QQO-mwh9x4yu49fl0@5Fo12@ep<1k>q>GftI7A5J+}tEzJ|UMnK-z{t^BEeU zXQwY;-iAIPL!xE3g~Ba6R7aN~v7FbMSovy`{KWF*COVC=bmuXkqN^U%5uN&u&hBpN zlr@{fIPfC<*+AtT&GK#s8>@@IL$Ohvpo0y1dN-RFh|QUSs=qeNTTeWJw84kP!@KqT zOeLcccS=J0#xB5_zG!1-Ki10lxhsO*1fuHEP4YokWR)7~2UTPMMaC$=icHTcaz}J{ zs0U|WVakM_iyhb)g5*_wVzay?N9oizxHpDgtO)5wda!y%H86N#v;5Ko1`ger0qLh1 zC>2@NE=!$Qx_z%jzO7kf=)PO$zA}?Bk6SBT%BhUE2bdx8(JPH}=&^ffgdRoJJ*Ub~ zuTY6q43DHGF(hq?;bCDhJdE!S6hmXmiMpE*oZW9*9E(O|@he;9%UTJtxF=;K5~(7I zG0Q=`lwIE@FV3~H(UUr23i}h&nC0VrOkL$?+U1M6s=~VWrPx(>QLe7KuF*8rTr~~v z&~xw(y}zboznYPE?1zanWQTLB4UJc+k?64Z+n|=+o>=**E%K(7s?NJLuxmezp!eud z!c9M8cKA3dGPMU#3OPt>5a^u7ox3H(W=uOA7JU$Hde!6G<*)LUy4`)l-D7A9w+-X)0aL$o7L)h-vEE*6n9+Sh z6L>zIw2!DZV`pjv^BtA*04ta5bOEtX0<$fm{%L*|y%UL`OqPU9XEY_1Fg*YE@B*I$48>eQfH~Cs^cucDH zuv6_0iXIv4(X~KS-F&*d->tf~DlN;wJcndV-H&9|1+$LUs#VW-$XDG8DO*mi&k<~C zPc$j@e>Ypc{sH;LRjy*dwnT->#(aLwvke8RLZo#|l&+Zt`FVr2wcGx&Wp5|;f90R)!91Ed3gWf{jDfHr| zcIq5@L)vX^9PSwB1x3|O>~}gG?RLjF_U7SRS#a2IJ#}eTT^J<6zYES(-avb&nH5T)rb?jxhWt~62aVpe6;s1yCkxZTq3w;!o5q(C)f zGo28236SS-BX@({=E3xb3w#}edP}uxt+Uc2Gb&%~me-fXR@v&LUW~8ugpn<21?A8+ zk#crNMaq$0le5p*;#R*n6-P?6Vag9tpnrBEKM=MGPx;jdS z-SJU6;EJ#DkXPg5ljh#nE9YAujkay6si|vg!%ZKS7rv(3(v0tU!Z@O6bE`Pl4r!{} z)PQrCwEu@~e|)|L4^9LUXWKq)_%d@#Q+2EOknPuAhp$HKs~eke zB9=G{JvU9Qgt~_ppVFwi;_*$ae+fQar7(zSm)dQOWup-J#fwb=EvM4_H#<3wmn@;C6|g-bMOhrQat-{ape3)+ys-5Es~Q@ zO7X392X1FI zP9mOd974=7k2ddA+lz?PmJ3QzdIFN>PfEtEocO3h&ZmcYIk*XDF#_kS2iyR=AQ?gW zZk&b5LO*1XAI`=`1hL43hf;A$wx*!R#pF*9OOgda<}7e-Tu^Zg?&{HxLIjOpNs16l zjUzdER&okhXU$P+E-P1%9RQH^PoM`JT1emnw-eO^l9iLH0#?k0U?dAUm`jiJuu}Ws zD80ET-uZK(3O+rb3-wn~NJ)yOFVqf-5iXgjj2PG{9CT z*-l&4buiha;_M zdfRvVoYUrPLn<4zmvL?&W+q;v?I6WYaX2AjqjuuTJ$mpbRi%_5b52H%HQOHK+%zBI zRFpQ;171ijP$g7nsSu}XCuMc(LdA*7MH@ZRL%a49V#`8Rnzm-3G;PaJWqo^z;^aFf z4}_-~2QCieM<{)|ek6hp{V2o-3?<3@pmF5QAt!DZr0U~KB*z)rp+h>ggZwcN3Z-hP z-Rcp7dgy_~MCbwMF9a0qB%q4EE5N$qIz)a%tTXka5W7t<@$WYdEqTDuQ`jIer206d z9>61NQb5Muqa7!wRKYQ<9g7!`UL(dK#AvCi!DE$BNr=5`MFte!mnKh0nu{yP$E)}O zhE~6${gf1)9p>Y^gQu7D6qoiCeSoeCQy%&GSfCm0>+BEa=MN5raZCVS@AVJifJ?k@ z9K$O)9IS&g@m1hX+Mz(Z-Ud3OQ93VmWdA_dQ2z)*d-^)z#66BU_+@16>ea=eJoTrn ztOTb%x28MbfYkP-=yCXA2;~;p@9UKF=kYi*G@}f9YT9}VP z#e1+Bt}@Uj>+V%1BR3Ko=^EQf7$?!8vcjUg5U#WW&EzSk14P%ZQpw&oG`!n>LQLdF zPv73Yo=DJjuUo;;(Wj`|eesBPTIuNy<_}FX4|*a|O#7#kb5xYPHc?ivj1bJ<48v_6 z?Hh>1v~e)MQGe^rUs_vk&q>5ie+Ov?u4U{%NuqMqT!>=d==nsPj&A6{0J%dQ@zH_H zTna+S^1Y=UwUNEpA*aF+jw4viZOs#z=(v_x+)A-!YooeXkPo0l9sc>n3RnDcaTquVd75AI@s z8?7h*bU0dP{^{@;#;J7jtDEGt7wPC1Xx8}`1p0A{;A_KR;h+)~UG*SXxu;(V7oMeKIDXNfkKd$y=_x#x(W%bhCxE_a%E2_264r6GOy zzztI>OQs_|pLDr>V!M;xS0)y?+$G{E+oU4RS13N^avvw!T<+t=e3yHf_@$jih`&r1qSNJGCQ4lHl_KDBFBCtcg2=x#--+TX zm%CVOb-7oG`7ZY&@q|7oLUBm*Wr{0Z?ksVd%bhEhxZDfG^LCL(`j(69UG5@ry31W4 z7P{QWipME)`IqKfA}({emx@-GdxfBRgZZWT=8Gqd1DNJJL0sc<=ZTNOO;Kv`FCFE3 z)DfNqT^#HX^7^}!eNaOjB1Bnuknv$c)SY+OO=nP0cr&9b9?GDK2UPJe)Kc-_R`Gx; z9ZG9F-TA-P81g|>d@k^jj; z93;g0l+pW6a^q^7y9kSg%2$&6TXF;6Vw_L>;Vxv{$hd=XH{(IZs~K-*yq}TE9r1ad z@g2sQC==wL%UH)a!uSbBD(6J^J;o;)-({qFLg9Ig>lnj~XE9#E_$kKQ81G^{#AxjF zJ+cD|$A1u_P#FJjk$bHW-yy^c4dZ_vx!1A1QMio%0RewpzkLB=8T&7{!*3;j3|PNL zh)o605h6XWF;c}LcPgVP7yriY*BOodu4B7A!btbqQTz(VF~-LjpJiN%_KN6=822+? z%=j4NvyA5;fkgis#=kJ0JVX1pFka7iJLCT_&P1J~`0b3nj2~vaoAJkt&oHK=AES8L zj8%+hF<#F2Fyk|fZ!i|2ZK3!Z7|&z8it#qamly@cDMY`9v5B#V@g~OaG6v8F5&c5O zRg43S=QBReI1_CW(JyA)%=j_J2N?g4aV^>`qHkgBW4wUzZN^!cX%gLX#%jjzFh0!q zE5A>%cSFEYN(*o?M{_TTbo+j4v|QpbaPga~QwQ z_!8q1wB;0j72}T>3(-fA|Cx-BGCs#RXR!{?Wjup%l=1V7e`KV-k@$re&t|-w@m@xG zyrx^lSkKtXxP!5e@j}LLF+R-rGsb5bUu8@QYW^!2%NS2$Y-ilT*u^-)coXB78NbeW zKjZ6+Z!x~hn7UNUEoH1^tYK_t9B2G6<3YwxG2YF1i1A^@Uo!qLqd!Z_OJ-cmcrs%h zV>9Ci84oZXWW1E|2F62-4>3N@_&j4^8Ovpy%b3kr#kijF6vopT_b~2bJeTou#+w;$ zW4wd$2aL}!{)X`-#y>L#vbBCo7?&}wWGrT^XZ#>z4`V;$DC0*NZ(#f)v2`A7G3y?q$4`@hZkIGTzO2i1A^@A2a@*ab~X8 zqm}WKjE^uTuhii+jOR1{kufn(hi5XbWL(R*k+GHWBE}mSA7K0`<8K(>VD#l{{;7<$ zj2(=lj2~gVlJRqlPcpvDm|CFuEoCfVT*tVHv4in4#xF76%lIhcvy87WE?=ejuVw6F z9AP}b_({ea8NbSick!zIJc;oX#W_c$GEphho8%M4I_p-!iTo% zUc%Kp4?rAIfK{CW>!jBaQGg=^M?1TKyUY{TSPRrLVmLb1HP|_T`~itgIjIJ!HMT@)sd!a_$(*RpFjB6W`uMYy4MYemu6S!eZ}i32*x#~Vq% zT1A9?yGkj-Si@Lxb6=$U)c(Toc6Cs%LyAQ_I84mKEk$J;8pg}E?So)f5^Y$1RmT)eS@04ZSfU42<-RV1>}! zt%qnk_o`@}JI8i(HlDS=r@bUzG}x=VyI>dM)HTuV3E@b~Dbb=$TTA>b$^ zww~#lVe%L2>3-^JbD8c)c6R%QX51)Sy|=hIyDht=F1vb7Q&Ca&_BBnRP<9)h8tdxn zLfMVmvT^uv+t#w|54W{%tl3zro#k+DXv*G9CoI=x*R8Lv$ZoAWwIaKvwXUrqyAHRf zp*}VBb!BI_;_8#g$Y^#pY}Vh`1VpB@+c!ysqs^4lI$?3Fai&s3?W{qBsnke{ zVCM!RO``@<4|TLPkmDXz4ODTDss^f;@bcCTPpK>gTY_h=t(VeN2lIl=cFJz&+@ z-$N(rX5%}iQBmE1*_&zAx(oDG~IG83?{C@^Ofat0pKCB6KjpxF{QwcqD``u!TsN$FRDe+lYI|1r;> z^3dTmMNGOYJako{+Yp0a2mG8`UH~_}Z#O^l*aQ#rOktP6L2=E`gn9YBfPks+dky-= z;#Ua)hBwJ-@;mn+*kN9}%cn^9BP?^Uy`{4rUZ-Ha|m$Woj!9h5asB-_7o&`ylwG z8BbtR3jP7Hd?K)%t;!-yAXp*uc z3Fe>S*95nEX1b^FuA$u!nJ}Q0zf6~hcMmBs?D8s@In!H#cML{9Ec?aPZv*HKGj9?f zPrr3|x8SUohR&2U&&|T=!?-|e;{jdxf*M6^n?m2{;pONd;@6n}biwqIa(0TRSo+ZS6G3d5>^vhUg z>sJVRD$DfGTmEuDcTo&}Uj4ofx~Y^uY}FUH#o$MK3!LTe>!3rCR`mnRta0^w0CZ-* z6|psT@#^;lRI(N#;Gd!M+V2g}(amw@XXvbUgUfnL3HCvoKoFZpYMY$txVF@`GnUum zrsKu2b^`c>@F`vwf5q5Bv-ociSq+wE=;VMaf1yITmlF9ZxX+b;Xz zWq4EQllwFeLus;_bav7`1-i3Mpd)M-o*m7dXg?d}3Ur&{Z~BE)Ja5N8yvDbFUpS!m z?NEDf(m>5RwTVu;CqYO4L`TUXT5@~&J#)b3M`I~N=jE635t|v0uBDGv}VR89Yoo}ZXT~1uOb_X5l9#6l12OYIh z@#rpa(3$?6>_ohs<=}eI8T;i;!tV>9yAKh`&V`fE^?brkFPcnCzhm+2$3OEs8+2cD zR4kZM{U~pobSqH^Dyg9G&(INqE^7RHufv4LIDm%Eny2q6FBn=C42DW7N>`T@mRFPp zgM~r*>A!f#QC3zK43-p!ib|CK88gqVYpTa5XBJl}axA{&`6y)K7oc>aG>B8hCb90W zXv2N@mwJcDUGR8n(@pE=KP7V0ezh*MG4m%g{Eyd+Z;Y;6+_<wCsOZ@Hu%Srb$I6gDEGVXzI!eS)iz0x)0iA0#oh1QHwN$dhA%3p^uv{)yf9L1 zFQVX1ukLVJcTrbKXK^vFq0n(!_;Ea{r+%>xe~}>*zPD8KWik!sxseXD`@I95kZZ+J z=UzY+JO6!txya{BB!2&2+81k7^!vNn_rEOrQhR}N{H`CBvAcVvkY~?MpCx8sAL z41ZEWQXnZYX+}~~(lJRhlagnoB%vX9jy*`l_k%}{M-N|YJ(T>#pfx`-RQ23*FOWNC z&J_<-CpX~l1MuTIITHmB{~z&dh4)k+tKDD7Nb#O4q)y%ScG(a7Yo_U0x1+0ncMUE+P##y>9^o)Pjel4iARl5H4&#u7*TjHwgKHRH62iU183SL~ zzbG2uqklBs_KWrS3w7M>-c&yGmyBDf)cCf+5e%$x%e+9Am=B}^~prl9z#cJqXXg` zam_W?&?EH)K5XLgu9bZRHbknHM53?eA9>M)Q`*x- z5*SooRz!yviC^yyh07a(yl6fPNfcq7e#BqvmyRb0rBLj_rbiPbvA$kg-Ch?C2eaxU zT^O_kiwZ;KS)d7rX~~-cLWOHWtJjp2YTvf@+8X%cx@eFn2Y=2*o~tq7S>2?9>S`M- zGJ3YDFeb7n)KLm_!!&5e2Duhte}P5N(%xFzSYNMhp$3f!8o?bLL%ldXcr;j|XxXEG zXmF?7CptRJ9`vDEjnN}m`v1uL68N~QYX5s@GD&FCHkodrv|*a2B~6o%J!z9dC&?rk znvG1-mJ%JZOxnVm#GNDa9QSfsSx(TPNO-#>a7Z1iVnC zPm-dZ2T zd*}|K^#Oke?z{*$`kU&vw6@pTBWYhL-^NdS)j_eS9)YbLffn&?VSAt<7{c4U$jHu? z4yCZatu_=6(v!UqyGgN_*fBZOV|5#*qX)Wm374<_h618CsL-I{21S2UQ`jF01=>4I za<^RyF28%LPRaC5N5mtRy|$@m0toD~yJa`sEMG?}87W@gN@~b=Dv%WIuxLk#hW7eMQA+6VFs)fRhwZKBA<6 zQe0G8QCeA2UJCMAN(9KJh;_xqB_$Qbg(c;cWu+ArWtD{$5OEF}5@{h0Wo3--1!B4+P*d?y1lOu7Bg(1&3>hYY&ZT@7N2NYaJ9wX(BV)SagETs-pB`Q`9nTkYj~^t zaQOe1;U7I$t~2~+m?<|H5mZsM6y_TZKV=we27J-*jFLNFGCU2##Lt{BOIs?tI1Bq% zOkbsmtuEYRdPmErubSS5HiyclZ&Ly=!V!%HoYLBi-(}FDqoU)cYJR_vAtJzoxJykK zKR_{1Nma9BG_{tdNw+(LgD3$%F~Wn9rD={*s73fkg=8VX9wAywFe#!u!}ZvWnnFwJ zer9^ullL4C1slTtj@IU2ZM2s4d7D4tT1(1H@Z5$W2gnw~xczjjBeL7|Z7jEmgfQ3baO(b7uKLh~!!5pw#)!o}7j#@bLF44wu9|^iTId)U?j4-$ zi(qk0A4wD=9(hk0ebcGdMbc)%#9(o_m!V8s7(t@M&pH2hdB%6(6pUU7z^aou2ua|{ z#ym%^7PyiOf{tcVXugw>Y~m)PHh5KraqsPgj92;yLxBMLImXus6y*Tujf}4sD6${u zEsR(B+9q|}I~hMgqB8P>jGriR85{TYZIrl-{tDxM!3{U1;sr%5zrjK?v}m*t4PAm3 zqM^}AQiO#k^lG*e4eeU2R71yBE7j1nP0FID9)+SXMW;!UEJ53B(hN1Xm^4GntxAZ& z55_swLX!+Z?6MFI6+dJl8XA6Bh`|h1qYuDZIZ6^$;-+9r z0EB^IIe5M zGvmjQJ`|`UIr=jT%mi{K$0L0-;>YbUTLS(~PVe23?w#a~rG(BFe^aobB~T}(1|^t@ zppDJV!DIsOz3;@@8x?9Yw=Z`M{3zB*NScg8fgO^&2gQ<|3JPP;r8h!B$&Yc&+9VCh zZ||(_00$)s=c#djJL7Mmp=)VvgU9g5DC6$|-BKR}y1RdX@$=k-k|lTd!;BXK4Fxs> z9gpl{{0gAKP)*JnU*CxDBSh`p5$T&8jNsPSu`#?(p0lP3)PeDyoWiMk;f@yKY~Su3 zxF*V%Q`m_VUk9djhi2M0E2g&))8<2J+BY;CO}_)CIKGM$;+q`Ce@SR-JE3@io&OPN z&8D`FoL$|6lM%{0e6`iRb94lGtZ0m1lt5FqZSd?JJX7{Fb)xK7;qSD5MlLzyuh_Uz z*AhkFw&DCCvu{yr?#_tz-JT=Xr5us9_NxEod>GY#dt?I3AT1s3tytR?E5_#C-vZ^Q zkomXQjto!WYcLsvx3TK)y7-xx^5bT2GroLuqgMru9?+j#v>u z>e0rkZgcZb>!|)iMHK;zs4u(ubvo+Qp`vc307lerCGfB6sBIw(Q{w2`Ha60WtKIMn zTJO#_Dv9{MP&2B2H-Xx=V6#88=@1qgXzm{0XnszvW(sMxiFyp=8QnJdAax^8t*-VJm3OZ3 zokdzrlT3^u6zi9Ii$L|c7-i7zfEe8rb~5)Fq6Epajc&0?gnYEmd1CZMGb}?GRE2wo z3JZ2bFFlqrAPW%2g7*k}`u4w6O z!tPcj0jwD$h>f%lIIpD?$gEU#{VO7U_`?!rIImSKj#$2tZ2CF(x!Y)yjbq33uAu_B~`HL+%?8rsUS5R$J z4UFD#rE54RtD7#{%n~yMOnw^uo3Ueqor1d7&YGqG?d4Qx_HEd$ni+G9i^eBt&QYb~ z*0%+=)&|-zYcL9*O&udfqmD6c;uW;}pmf$l8$B&+HB)b694(zY&_*?Ns40`N+>pCw zHBEmQ$CqY}LFHTITkFel20@r%%Bq+g#==;6!(I7$W964zR~yEEXSh*MUjc%5=fget z;(lUam>6R5?eDy?vmp@PjEzCG(EWoW-4l4!40q`VTY?=JAwd2+Mvx{15$hm*Ba=OY z5of@ISWlDjVzK%kj*I$z=m?CpuEPFsMSZQfnt<%_4=xgei~n0%sX+YGz*U}NNB2CJ zRvBWVYx0P@e-uxPjgJrX?-7>Ek-OC7-mt-^5SiLFz7vtRC@NtyPCo@)KaC73bbQi{ zZN+VY_EvO5Kz~Xo`lyyxGjZo`B_KT`!jL&=x9BYqpsBT? zrqGv@Z`;;-+wc;`^A%223VRij^mp6?*zatg$_77ys>{1ac8d7luQi0DgXOp!E?#Nfk0NkztH{5GI{_n7b zBS(!Ai&~`%!VGfMhz9L%QriF9va{DHg)2}fsXd6Nxg#_b{)STc2-hQ7i)2nJ*8P_1 zq+2ap0Mj3O-37gdyF~{Ozf$XVQ3Q7sD#-xc9w2Ub8=k5d)&+Gd5VxV#F`PU#8?gNe z*iM2kt`ds${W}UQU4TPBRe4P`ezu$8M9XEMNWx7XI#ty(Ffnt(s0cQ@m`uR)VGp&T z7>+d673K6}c}@*+EWNU?pLU-HtsON@pB}TsY|H7->zHxmJYNSfc*0~*JPXlza(F5G zY4CCVDbY*fC+L-IlCR)r~H_tIgsTlLeIVU-@37ouqL5!X04B}R-H>kP&jK=#a z`oCbbpCE=J*l$XZb}}}w9OqrzL^zrVTtM5X>1{GN5iX~VRByWX8g_=507S;dc61N- zVIyHX^FD>tR(-+6FXhMS=0gq|`WZ)zY_JQ5ZSPQC11nWM>Ec&7W2gw1M~$%8%|CBO zpspw`|F6^Xp`j6i$7TMuo8M%HrjATEe>Nd9G1iBfkwV@T4&!aJ8}XsZ_i5qL5Ncs# z6P^u&hQqPByqdu8Fu9;L)VfEv_ux?rm7OQAV)hVUx3m%+2Fm#p8Y&=0o zF<4>b)fX4RE zi5j)nPGDcR;FjXt&)$yi!K$E`79vXS>2?CU!HSDcxu3l-jm8$E@sxawV$$FwvE4+W zXHnVp+SSi!mq**4y=OuC+3_%!G%*=Zn3Ilf)A#iBeF&{_T;&oI2{BWo&DHC%`zJSC z&2`MLy0DOWtBWQaA{;F%*87`-O{ZWr>HE$I%zcl`o#6ff9)9Bwx#|K<9scmiB}JIv zO`%6e=l2s$EGonN1Sj_%#^H@RI@7MP)ibQMnHA zGnd+Kq7`)~i*?}etV;>S#wxA1QR)h(#8rq`1^BtsS0u9%KEFmf+d6UTR>nh|n)1S$ za!k#C?-E#zw-C(7xpxY!TY+qR5_IABDe{k2esj)u9ZH38Vj7W@$7 zLAUm4t*;LSj2OAoqL@-1Qc}uGHUHck*o00W_#6uTH-ffpYOLwV!Aba{Jp3u9KP5;C z2GbOaEV)MbuJK`^90OFON7H4=tH+O4&m9qpMFh#s7Kg&iu`Uw$q|~6J=5RGIxkc09 zgcE#GG$82|Zw-wsUmy)|2H=c}oLz-^yNdF573b}mW`SKud5rWEFK7C96^Y=LQO!le ze7mx{q_K+1r-j$1a)gI|(5AT55nhHS{z%xjD~7N&=I_PDpv6MNku`e7QK>4T`z`gSGHAJ{TAw8NX8q3r*rm z)WZ~(KXYMs3t=;pq!K0ckFEZ_QEg>fYOT#wR-UE__D3~=$s>OTJPu4xnaLn#d`mt& zS<%$GB`m*Q*oMP9tu0}^aT;hxJNb(!UR#45@cCs$5Jx3jTbfS6T5pWlFUAWa*r4mY zR`ijV;V(M>XnSAA`HK&<6-FOUn6oMKYC0P8=sOQ-Zl%J&rS@1h;{FQ4%>6K}kcH(D zn_(T1LmlS(rN;EEjg+OsSd-(-dwns^A9>pFeKU5!-$%;$UbnXm&wCR-7umqicQ0rY z)m-k5<3JK{s_HClE%{#xT+HmKt!Lib8NbqeWSOHlhcJPm`v`ZfOvoIq9f{y&c!?(Cwd`Lop=|%a82U}9Jlq=zpHacQ)tuj* z?8)8lj>B@loh6~f^5tkO@ocj9QqF$_o>wQt;knplQSp-3l4{Xaa>B=;o9!FkF z`=B8h8<;YSpx}9*n_rUR$$c<+7Cajgh-a2JS7z=szWA8Ri|2Je2fo)IH4DBXx1;MS zvTxpdDeElumL< zndC}#-<%4PMdtEEEtCAEOmaz?gxuwL#WR9MQd5eR;L{n2YY~5N4r% z>$N0)33xx3o|f6)KhYE!Hk+XV5b6iJx3e_aTDmf^_}(7b6&V|kSn2M}(T?2%eSL$d zNve^r5dk~8v8&Cz&m~h)m_QKfOq)mg2KsR-Sj$OOT8NF3+cLc2N(A#QnD&{{p zieH$93cC0|TyLwrN$<%y{7caLsU-`KNGVqx{s*^r=E!iQXOF6Qq779YP1GVUnz8&8 zejk!@-O>N|l48jfk(7fe{5d4$(@Uq9CbLCZJeN9_QJbxOpe3tz15MWUi5Yw-sm{_?0osU+6S<>#h*a`!EZ zCv?ud*`_&zXL%FnMMkhJKa|RkQB!Zvro4Il%TRvr zvHwoxsYRWpJP{4$KR#b7|2ZhXcfPQ^LwU;XSLX5iq5KoR=*r8QU$duJm*0fUX_=82 zD>IU2kr`qD=FAKt8tG|Eqx58XuS<=R7Ey|Bp3k2{T5esDkr~49jd|xG|ClaO_4OS( z5#XtcLOW5tBxj)NnZN5<7KLdZl0wu^$cE4Z1GyG zb1D#0=#hC@-p?KtO(7bQ{wbaR77BfTRcdClZZw#4Ed}#dy?UaCg_uCobW7+X%LA>W z;3)F|=A99FiTsbY;)8l7mpaU~ z8L`5IRemfEqU#BZD);I_e)BRu~j*LVT^uQwiECl^JFK$xALXcTw2~}k~eo|9x1#vm6GORf}>i%@jRDl1mm_H28Z^!2xJAfk=cw2dmVU3+yXN>V_eT z@VKJLUY-noA4J_*6jzk8mmx~j2urF6k0(kPa5RHI3{jsg7NVjr&qvFc%%Mp+G|)>; zL$tY#H9lIT7o4BZ;CCMD$vwYhp|i6x8}dW+ z2>WY1VJd5Mrpuh6WYC~urot$DZakWQ-sj2vU1>(_l*PAMW@I=rwtbJZU|QxBR#0gX zPYv8Cc{BiX7eSu%uf>-|4!E zCVbyge(nlS?zI(hOfvJ#mb%Te=|-{B4Be=FEEKwtYjI57XaJRU4F4W<`$}b$f`|e; z5eW|WMW*yf7$XDAki)VoC94;1QK*XycJI-_QEpIaB*~kz3_4;pjlLrl!#QfW#z(uc zi08=5dynD!R(f*pSvO0aqUZ0Sb&9Et$i4Pu{0eCE@cLP56Fo;ih&Gg8FD~O>fHps` znx!_;b`djYkYBNFgEiaX<@~mlo~m1``Rnf0y@LazVX^x;B1SIMbYx?UV>^C|od;I+ zd^J9Av4=;}Xn$i`c<{OM2y_~S}^?0{xNgpEBe_+V9cZ{VLwQ0!H3 zgS{iXVE^g{es#iXI?*A9Uf`U}r6R=Nc2qPO7fx6G`2>DX!W!Bs7R`f9tk{E~@B_n8 zYq6^j_s$X=Z8w_`^L(ZH#Cl{Blh=c+Ya%i8I#*@GF=0V$jFTP3 zU(so?s$cv0Zv;1d!}YIYB^M z^+*H%jEIE1o^hm4HS!y!f=zxBMJVqJHf%fwj|cgqT7xD^!a&p{5Y>?cBEfE#oy4Cv8BiK#%i+LD{8h;Txg5iY&JKZ9 z{o^G5cNHr%^H{fT;^!t)iQ3vRy;Yblv5|{8+=$iwo}f}L^6VSkrCPldjL*%jRw01u~w$sJrTUu$f_T0;RkGyMQW%Y6p;Za zGDZPLWO9qhU87?oeYo=qQzrCW3c{{VTOJTe-05do~dZlp= zIeSOO$;qnkJ(+)QjYzCucqlE2A!$nt4>E({L40>07-~~a*IoPI9)Hu~STrJwU(wEA zlS+`q9VsJ`NEJzpS`K2R?Aj2&FxSXNN9u?v>`zRimX9Ntx~k82@KH(qiL$SVjA8h=ipuPd`;ILF(dEV0~2TPF6&Vn8n03#(Pf^uK`py2vFbCO{KmDS z&f7IGYd?%|N}YHG6=u=>j6UIGsmRnGKq=%PsX;*IG+wL41#(1C<7d(X4f$sNLR7&< zdx7!sj095)0>Nm8NH9jsBp4uu;0w0!tMWwVJ5sEtE+aFPOZOj|3I2tY3ouPCbl1h-<^VX^1|wCUAPY~{bq7wYy7jP*{UDcmxK%LjD* z&RIs}n#ult9GH=PLlbyDm%N)owc=!I1oIt{_dOyIPXEGxbKW?f<4}FcSg#<8QG)pp zhcU(3t+)s#EM0&sZ(CmVRonQ51vb^Ng{%6VY%D88)huV(7y`vqEN7XV90`c~0mmas zOOSDErr61sYJ(70?J=v`T@*bs+$U=RtG@YE{(xO|X;oU5gL(GzsJb7@s*C3yu2rjF z>f*246%w|Lug@WDX-+gL_5U(kzWE`3)A6=qplpc>m5o!=gR(#yNEk{Y4Tt4i0xssRc#RP3*BEmUg>q3TN~1tt>d~F8RSyP9 zp!c8~Cx8wd1Iu)8a#EJ}oWiO*d-zYwL`UOHliAgj7g3rH;+;nNYfBULE_zi)j5^Vu zOqnh19@9yEA$f`+o9={gN`Q!CLDdcRYKQI*7rVNK<&kR9T4#A9NmZ}(@@vbZt88>q zuf$e)+Q^o)f^z7ZNIA2kBISr^roob&*edVm4wd&ORb3O|ua=9tIL*qsd%LDMrje;f za}4QYXhrEjS4ZhEJ3dMWu-F=pI5j>tdBOete39|dXsENcHV_Kor4NIIZ`nGV@jXu% zR}{6jvvW+Jra(&r?qQPjkD7FOIeHM!mUPrMva?MO+~$KDf!J9lC4?_CJDdFN>?0|)>;1td+=#`_M9)oAD<&R2!lyLit#y18>t2peSIKV&{<&Ege-SF~_dm0JT8f4W z>T@1a0N>%hA!Ly|;s5aaXwJLVoOg;RcxeiIAcR zIz+0Kz}Q@kQs8+SVQjv3n!M9Y5(Q3Q%_v3Q1SHL!oPyUm@lgd|M2>|ycnN12JQoSa zTs(r40x$VC&XN=+9T`N!-Pnl0mTLc^G~ALcLy&VB(aEtqg%QY{3(mpCl}F*eQ0ZjM zr)j0BjIGc}O3K`nRItvPFVtLFAwaeVfULiY9JsWQfD7D?6AmORCrx;)SpdOE7IH9` zoa9(5X}C&n0m^s&0;qyl!xljO)?D?rTk z^Q-2so9|9OF*UeY+NRu2mc$B^*r38ynj{(B2dV4qL?W#>NezpMP-PNiL`+@nB*r$F zga+8^1QRt?-3XJNX!jsxiM-JyOLd9pH;EP|cq_QZ?je|fTx*gQ6AOOZJzBFCCd0--I7 z;7>)Vl^ocRTr5hc%u>cqmMCR)`x3#4%0-BrvZX4Y^U}n{(~Bkl81D7@*5_GR3Ar# z13X4`3dq=JNaV!SY9M10S+tgRVxP! zEq;glDJgn8%*S{7PA%;#DeEi#5Iq$p2>JO~pqUux9`xns508X#O#rs{21jtgCH5O9 zu_cF#b#N!X@Z3%(6zJ63Q1|F4-IqGPXQ*dna2&pU1KmI;M@Mn-%lL+M>q?69#Gmr= zQr!BG-#a?F0oSEZM5glbAYOicKk(2<{{+2)m!FT3=ji0b270Cghp2`kU^W4{xcs9F zpW-6YP~l(~_1ARA1~x$pMi6ONe`IK+FS4P3WUMzbhXseh!UyvVMTRHF*CQ*6`^rl5 zF{bzcCc{ex(qg^+!eWFYt&yI|?F3__xv0FbIIjpVS|LpQgwy?@8;%#L-aRt5({v#w zGNW%`*FayyXMNVKVC3)<^lG z)`@|kNK^y+@`Lg_Z}pY6fje#?w$d#@yYM7q7fKP8spdiy`Jm&XExNX$3xne>alJ=Z zSwUez5%POiSyx?T7f#0sKltPN75!rKbS5&cAr>!EbZ!ocHwD$@(;M)Tqc6Ws@{tbX zRu?OZA$B`n&Z}(<)NZoUjW--ob%y%!q5-~Mjm#n+ddK>G(u^~E09ZFZ7I-|3gNz?% zcHHH_-7F8`8;$U8=Cj4GU~ixo)4v4v=KH@>I86dDA7DSX;rJ?F{Swfpy5*A%f`WG# zfTQJ9Kk1K_S^cDcl19Z#LT>Szyd+`s3GvaStDg_hjTaQZ=Fsm13(j1e*>M-EwD`Nh z;eg2!qii?(ng!=<4!hEZr?9hZcq;3&;d5D&4WGwKZTNh4v<**V|3K%We^@qPzqR1$ zNZ!<533UZm$@8}4EuYj{^V)`K-SjICXz>}k`azzf+GHvAaYYQv9Z={9^Nd)CY% z#9zyd*JhDN`c|`RY2 z{&`WpCoKM1(8aHG$-~sZ- z!%0aU!(ARg>N8u9A+E}Z&7%=!uu4QQ1IglUaep&$=7-> zG4(u`=qEC^k092lwElMzj^}OeCRoDQ(*z;^w+g)x8JK-A``!2yUlYTDY8yf5PH6$AXOm3(-b^O!T(b5O$D|6sC}UDk0?lQ+!0=>;G}|& zDflY|SD@XZaK#GlQSd?qA5-vG3Z9JwQuyB}_%{VlOp^3A1+P``HU*3g6ArDrGnJolmDv< zGK^OUU$0=3f_)0!sNnY$^q?)G@JkdtUcn&+&r|RT1?Qk`qVUTUY*p}+3jRpJ|5b1U z+Aa#;rr>~rA6M{Q1?OV6N#Ry2=vVN&3O=mhFBSZ|g6WurQoKtQ{F#EkQ?NH(`k$fT zTMD|ol77B|S1b66g6}HWjJAsSe^|k9DR@A^WecT$k%FI4@LC1mRWKKAHt`uz@JR*N zW13I&YZd&vf^BFUiT+gu7oklje6ND9C|HZOoakpO_)P_0Rd6}lbn?Ga!N(OWL|;Ml z(-nMF!50;rzfAh)DtMZL6AFG&!9OcVeI)TKQt&JVFH`V71vwrhqHxD6Sg&Bag4+}v zQ1E;OZ&&bP1%IaCuM~V;!Bn5*zed4w1y4}0L&0qd_9!^6;Ef7?MZs?>_<(|MD)^3q z?<<(LLdq>uuu8#N1v?a+Qt+b+?o;qH3f`mOegz*^@OcIQsh~Sc%1cpjnSv)O7*McT z!4E6ASHXP>UZUXj3hr0%AqAgM@FfL3E0tUY7buvmV6}oZ3ZA6ksS2K<;BE!aQSdSa zZ&vVY3f`gMj}?4D!QUwOs)B!2(336oTdv?r1=lKAqF}v(A6BqW!9fKl6#RsO*DH9F zg10I79R(j!@FfNRsNi1|d`H1KtE7G_6g*DB;}zVf;1&fxq+mqBT?$^J;FSvAq~JXY z?pN?(1%ImG?-iVrEA?ns@Y4!DqF~Be>0hhhc?$kn!Nff2pQ+$l1veshp$$;nSP8_J+%v&z!9656eeC9C76KDkALOQAQCa8zxJd2O_;E4;F^Eio1F( z5sbjYW5g`nR$SiLFjc(sweFGP}tyd{S?)ecR;biO?S0PD&JOaPvY( zL^#DyzTqi6RN3cm7|CvkqP=`R4>ldeD)d;v4n*6&OGNA5KDn(sc;=qIj?yS{hQ@f~5qO)m`-oz>tGr9QuYPj@^!yQ8rg zkIMRYl{9CEvfBdL{`F18#o1feHx(6Shu{hZ0)e9J;FfIMe;nFep8e5K$EMm%brP)r z+SrucN|!7LvI8~#%Ix;Q$(7k{?SW8bb^s5kp*l4U^kiqZQw{M#`aT^ht=wW9U^+n{F+wlRF-@&)y-l|(q~eR z9m+e4HL;mVxsJ+46?5V-lXC9hL2Zhek27f?qA<|=LA@e3X3#1r9@LZ`Zb49S533Z2 zxMr$nQF=wp!_I#hTQp8)n>NeLx9~W;oEHoZJKK%ev(9r};b&OiXVe~>^?O#`mYIPw ztiR3*JHz^Fd;N8W_0!B5M3_l^qzFc4AkIui1*-m0?{v8JPsKf~`X}NZR{aw(&FrJP zGmG|D#{OXS&%)#I>Yrd><}xK=CfRJwGFz68mjLI4tWz1w$<*-VrG0ec+VVbAz$4jSsVVIST*Dt0;5iM6` z40_RYy2z(>G3ZhFi-|&ZQOUn(5Z4iGjyZ;tqso8z;L$d2oXy5{tnn^*bkRSx{oNJ9 z!4(_|sGl6}ofyCatX;O#Cis%051hIO`^0xT_=0JI`5Q3D>yC8y3^1Mvr>9n*ZefY3 zNAYyN(6xkT@S{0x%3%Muwz!~h9d^c+@=TX26(rmWoWU{^u$;&+Q)D~|4lk#zFY=nl z0cZNV(IxlSXf8^>Qv6F0F8N2huXcpP_C(ZhmpQ^!BV1DyeqEqh^}K-iSqR!makZP+ zTm*#T>Yw&=@_QK`GvW6q=o^h+6$EJBB&*Sl!+2V##m^b;q8WyJ0^zK7(XyQBScVLE zD2iNXxZfe%7c>)#eop&+92wmfg`YFr(+KyaDB;dm`K!IAsO&|NyUQ64doL46v;OHQ zSa!BXXMak;K~^2e;`br&OSjO|QgKKaIF?Nqma#=ygb7%ymJ3L~421Ium;9sU`W*Z! z5iSiuh#!`J41PvB6u(A<`z#4oKh3WRxNxg*FJh0OLkH4+fJVNlaHZIDNR48bKY^Jw zy&JK&p!LIYUrhbl5bmJjP2ywe*N8oZMhc*QI-FC#%Mk9-DEfWJp51b*S}c$ zJ-q^Lkq!i?!#VXkEsL@HqlD{p=;vE$>Q{*HvFulfa2G`3=d|DV5N;;rFBO^bwJ7{@ z9Qu6^;ZUSS{lM~SO#L23xEHA-Qa^1Mr+!~UC2P}x0ChO0{r-V)^lF^`>2OB7p~^ar z5VHpDY2o({+}3jNg)-C5SXPgjj&CBIkJ>i%)2yB8c%mBZt_}pK!#UG2x&i%1i5XCb z`yohH{q7hw^;-i!N;>^>)}tRGTq@}Lr}<6O58(!NAV3|?sbBROjJ*{l+$TY^>Q^{s zw!1#~Y5kn-ZY9Ef$zw9qa`%9w-Q@eiZplN3)L9L+ZQ))-xGC*v@!J8nrMY8U&qBFE zxK_}0zmNv^R{X>Ez480XUU_bZ+IyV_YSyVuw1)dR!V#UqQF16O;ZA-p?lt+*SW1U; z@=N=e$&ZSc4p#xURc;2tk=`Vi|8S(l{d}Lsb4a}Y5kVO3FkvNYQsn_y0Do1 z8qYKNq05OG?lem{(mj@bQz0ZIQ;HwujWt~PWjOCc1x5XIID!Z_s_8qf!IVcM zfI6HxOD`%b7&+coR9acKuC%bCvdrfz^wCfL#pXtNdAZM5T2fS6D(I)pIVaFmkI&5v zuAJo)FfAuJ2@fQlbo2Gl$@M=RPvnUl%&*TH0ad!>mMn3 zBzWY2k5vy>bUlRpWm-5OnaaQ5oR9Nua~7~4`BNJ3_aV?!-JJ1vxgV%r`t2XeaQ1;K zrjf$Wn(d4S6$$?z`V)-*u(Zh1jPmSw%ss*78Q+0bF#XtjmiKvf;%D5vFwxpU$hJZA z7#IzW^|G}6u*z>>qk+*n+#e~>9}#L^mm+RY`4(u~dIopa;sa(uxWXia!}vV@5w@2o z#55enMG3F5A%TNy7+(_t-)4=0uk3%v8bFc1CIGC|;V;y&w|z7IxLo9wV8{6v41Q<{ zKQKSpoO-ysB$0dE?p1jB%zbL&0^v+N77p${NGUrkQx5nSx-1cH^)EnvN(6Quk@82pvL)c`mV1H-i| z3d4a&(UNfV+3H6mns{<^+DHO@f@DOrkVt%u-4~cM0+ANtA0$zPjnav~#?K2Egpx1L zV3SjOajdh~`8xvPurI4V(&O_L`HBmRDzXqJ9Hymj@+c}?U$kz0X_=&kI_hdc#gowp zA`tai7ZKNC;Ipntcm?Vjj9}z8Lt$)Wgb>#$&@0mjJ2^}bk4O6G!D%BvTSt3cu)bcr zM2#@oYaH)zjP&CM;R#=<2&)K#Bg5P6l+lSXMW7GPYPBA|vcmGh(qcT_&nnONXaaMJ)Ha7SZjbB(WL8r@%B8YQ%! z;^1j>sh8s3*4|nl#GB|2q4fcO2kyNHH~O3Ex3sp`*&}IRDc{CVd(}a)s2+i>9f20{ zjbVGBAsE8@yvWGTmJX$`zpXYD4$`x|5W7jSnAkBn)MIrUrlUu?bqSX*|AqphHmJ~` z;TA=IQ&ZR<3I*CbOmeU}h@ee@&4DImK`J!$ZGs&>+$tv*f%)H_+om}8)hxe5iea&`Btv< z?O}Y0B1@_z44$@TJi}m?GqnaX0-;(zRdn1zDVQM^s6qpaJbDQJXnZrO=&_=b29vSk zFAL+{<(3Be=Myag{b78iXt2OIToS~ykFFMm*e7ku!P2l*JOvj$Ni`w?`Hl;hv(D=J2t zc%~8qoTPyA5hVqb;-b=u(#n$ZQjpJ5B0x4ptSc@qDXAzfEGe%nE3K#~t1PU5h;zu0 zNDFZ&D`R{wCjun~l=8B&63{*-Xp|bzN{iQ(t}Cx7URO5B__@M|QX@nenNn0)T8dc| zTJn;L!gXb3Mdd|h5cUZU-YEVkDpvDdV3HkH{G{m<-Iy1e0cL2^i_I7^*}}A!m{gT^ zW#LOr4`l$Wp)WIi4I@a~*XBgG_Z7loh7GjYue6Zu#=pwq6D+;%ECkpiL~98q zMU-c_9=lOfXi44AOb>hVp5vilL)hQZ+8nHn*0Mft^G953NqGsL+c4w+*-8J`Nq;Bdb=1YpK)1KgRz-1QaHd z@=u~5*G$U)5(Py@P|W6>qVIK4QVfQo&ja~mf^4$Y^m7H>WUlGw3A!o5D3&B+p9>-= zW0icP=!i~U)N$`*`~->0$PY4pqQqrv+}XEL;xhUxjQa&Q+?I-06t(;Y z3(e4?(LywI30jDTMkh%T7M{?n*-A9DYq3%d9b2tbL(?`Xi=KNFioz6~CP}gcZL>); z)ZAjy3@x`RAqGDf=Tr+#G6b>9LNrwTkcDVy_+cRiGgOsR5gAAkz^Y#az=JI+?@nJK z@=g(u8#`Bs5=ip^+W(*>2HGp4dB9Q(Xq!X95X}@ZUu?v83B38f6RQSPsL9;E+%@o{SSKNAG7bfHNbVjKiw!C$j6s** z2n8iS#xZM?G$g;hv$g{qlqj63#vSgAzlDabrL_$n!y}`NzXxF0s^G01y6n*Q4^M}m7MXk9zBieU-j#!s+M3&mC{+IJ%RR8Uf2`q!ObhNi( zZC9)qoA-YUl%GQ8-(EX1Jb}-_WDwrQs=w>vXJX2a+r7>B^5KnM6*PLps=vDUK5BSK za_m_%|ET9`VSRV1Tdn$?B>_$s8ffEx|ISLQNNYIzpA6Qg)mHs zqi@^TNH4B;!&7LzJKLxv;`>6)sQTRmekU!Hkj(@mX|IWq(bj&7C}J^bws?%H?)UKh zTBGJeXw=+2FdSW-eTn>Wt&ZSgQOAg-)G=^pqN*NDlSpuL<5&Atu0RWoCb zanbk$%{i)c-1@e_*4jWDW(`K+v#DdmXw)&LO}v73AC%5|XrrfPt!C;>1>uSUJ?+iEU z=_^3+_I$VppWIIj3==~vzWtpyb~XgUo3Sy77P^0MqYUauBfjScN363{=r3JaQS~rD;0=; z8o0_+?C757(keqtbWI*{_mARvvGMVN{yoBSIdYep+#5Fd6e3f*#&;s}7DXj&#_6Yk z>!*=Hg^o|Uv8}i*(B6t}2Mv$ z?H0Wy0yMQY)D-%1@@?B%ZyR31c)r4^N@1@;lKzf+U>r9k<58fQr&GtUrBV}R8s7)o z?U?vsq%F4?b8_OEaP?}R_TLl5#AIXY|Am!%hek_tASTb3vuDj3-)bZX&zZ;~K)F*m zRcxT^jc9$dhz7fSGQmgyu6pPm{CA{6UjKn?nO!PkMMEmCKq~NA=4`SS!5#T38Gze0 z;D)=c$NwF+aO9{_Vo|GfL6|{~8quKrO-lQJTXyyurEmobCAA0fG!ce zI);;{W&^fA0ozIN#Z^L)zJEu7r5kYQrz)?B#?N*$oM^cW6iK+rL#L{G1}0{17!|>0 z7n2EiKJ1}36vL6Gx}uzZEYGPSj-^-j_0#UtptYl>>C*hJ;C>3LVc}}thBi(89x|vPj`ePuTe04t=Jqoh@2lwlg3*407>Z!ODM8vvA7!034-nyKB5(n1qo%jX;6%8bHd4Lm z-fP$yVge8u8{5%6+=q>X?accWQd{)}7r&Grr<)HsXy|7gF|xrf9Jakhc@3;o^`whm z;f$doTpl&TUN`@|8G*W@xct9P%ZG+W2p*UD+irf78JapW-Tc{v$i!G5XGRKnS2&FK z&2Ge#F5jnxM?pr{=JIL+zr*B$)==vn-I6zW`1fqVZNj=~F<7jkDOIPG zt}l3S^1#qlHnZ^rA(c}Rnaryb`H!7Z4ABu&Vcx_&40ybSDhyYvUOu z9|iAkB=hgOSL!Hs_EAcZ5c6y@|CVQEe|OKgHGIEiNtCK3nkW2f0bRmHU!Xn<*R)#s zXAqsW(T8Yunz$idlSGZ$YY9Vj=Ia*RQk?tQ+tEE(6%^APMaezgPGC1!anULFvlph( z*kUxEl8;eL8k{7yn<(@&D!X30`Wfx=Xxp>*EJ!~)9_ErJ7S=-&#L;bh%FF2c5L)B7 z$|WWeVx~x&tJh=qPj0xH>zH44VIlKY7fm=sI9gV$_csTdPQhx@_ni@#`yQ7&!Tkd~ z{>C42)diY5{Na;JiZH>OLXVEl?9_y4r%i zl7gbrqOx_xF{H{BTT1ed}X+~g+FcagV=DWF<9S$St1_m z@D-8xXRHD6Ih6`fRIUU3%%!%QXhq%0VjVa<>rz6ou}bT0l)AzxaTg+10ee(yTlf6DP;gQ4MV}^I&1>diE=tCF7|`B!TJ*;=5Z&2Zk6&c$COZVXJ?mgpb9fqdjKQ;vC-~pjAu`g{`B{!F5n9>&!4j2(= ze=XFZqhW4pO#n8s1wX`i(5-!1>+3@SBS!ADD5jK$l$7#P%|AB>Hlfo8K8Hg8ji7Ct z8f!Xoa1y>K4}Xg3PYIHO!8FApORf>VYkXKJ#{d=S(R5kz>hYu1b4P??5kYdZ#i8(W ztcwIbDK+S*Ib01)ZqYP2;RIh44M;l0TSFtu7f1t~0XU-~XIEj~uA;nM#d*7?Szs4Z z9wYt4%bEUNMIv}*RCCcV->&Q~X{@61Y2mf09O0oKv?(rigqNX-KN9xsiXm)``Fn9Q zXz>*Cac3kl3ecX@ohMFncl$Q@a?U`7pP-o&erJ@Ikh@#(E`dr|5!A#fUoH-JgJQ1# zU@d%&4+cg^#_truLX$m*Ei8ZL!tNHrW+q7`O6VV3{d=R@%Cyv4o2jfkO%v>oY66o- z{tS2=n4U6|LCpA;e0Z{=sdYOENw0MUkY5z?5M40-rE_!(w#0T^2FLbjDODU z&HaljHFJ1!sH1xn`|Lr)bgg8Wqd12!fuZ{dcdbmw9IYLR;B|P3CgZu)UofF;|G*gf zO{hHF8^KF<%v;U*-N~NZ{q8s{_uE+#N-STF#u85_doShuN8ovNLL8opT{bldC7uVP z@hriIlE3BraqxUK9?#S5JP9S98GL%u>7{LNg^T|jJfHHUkvU<%?YIJ4WS!NZ(Ndo| zIx;>H+A+|tvf8yWRVv;yfK}$caBuf`U%0QoNZ2||&%Ap-<>K!i<;lH2(I$+ZqqYi* zW)`ck^&)&+VPvg?E`I(TPwwZFL=NbbIfX^Fm#|gTWC)u@-275-{##Nq*{mHeznMi4 z1o_CeER(KGid2?mvPUDM@sl0e% z_jBNT{ZX^vD{?!!t|A+ECh#wU=ig?-Q)Frko|IenCGgw8^VK=tOh4Xle_50WKRn3g z%JieCk}JV|?;JR|i)Eq$Q(Z6fxK<`+ZW@*TshOJwq-$R0ratLPlVV2)`b?XPbl{`h zee*oIze>p#G7lOu$(0~vk}KK$?G#i>i_BXf6Otg4{4<11axD`w$>obClhXMK55E#J zf0`;~W}qEmnUqd)NtxtIcHf)|l11k7L@ks2rA%^3ndFKlQp-jgI1WQ{#!fuu;>PLdZxW{{w_vFmDzG zO;kQkww4e(SX)ehGL#m!6i{-#^h588(}t0TAj3ySKA6*;=|XvH0E|*%cWZ zk67vM%+ZeB1ATpis7b1kuMq(|y0NRxyw4?5QJ6pw>P(wQ`Ud)ODp<=&Rb1=4dna&W zR`tX4Se9^!Rdye97K<_6O9vQt= zZ+8T&?$Fz6Zz|?LIEr7Gh6=j)KU{CCy-DxMIs8k|`>7=hk4Pz39sUQmcjm}&q-T$+ zc%lte9Zl3CFPgFZ6n-C)a^2DY_mX1C6_J#KDf~Gk<2mnO4CSv;3ImQkCneV`?) zb^}e;_K6+3-AHBW=-RWq-nr?b{mAkzookk9qeBpl#}8Ban-G8bG4aG-HEZz)A^!5H zLa8Ly%;o2%dvfyxFEXgJ*dY=S4}WF!Xol@+%E@reRivBG0@JBAE-3VcB!Dyg!u6 zk5N-^&!)V2{L4^&@3H?*<*7xTraTc12k`_^lZl2GdLt1WKk&zj~ z@Qr!rA^(^zQT6p5IuYQhib6Y4y(DL$9E%7O(T8VdCJWwUY5WcFzAGyuvqiIEnJqo0 zWn7tZzYZri^=MN|krGe6robA%%Y5WsjPwoMX zkY}O{jn&aY8Dk(SCU#|1X_CquuqyK~5VHCO^Rv9kDNz&>qsvp%`FEhuv)MCKNKA4p z3eljum8_taB<5Qs|L+S>Dec6-^-;k^U*2{}u{;e^qK`vu-q)b1en)R=s+n zhJ~0w({xMdBg+G=qu?m>0Op+$vq*^M`D`zL?`VvASIz%Pf4*C3*)&QyT^u$Vs# z&Tq%(96N)l<(kG>WbDQz{AqB0@pxN#jbV+QT4`a9%+Xy|TrHUlL=z?2$j>j~cVv2U zA1RD0N}0zHrRs(uitxCi$X=cdejh~LSrk{4vX>!B)Cfze2#+U97;rR$KMYZyEf%7p zFV9EIn9QL`IW*8qO+&P~jWs@6q!*l@&)|0+>&ZR8WTCUOG8>X;#Z+*nZWW!TxneB` zzG}ucXcZv|w816jo4a5l;==D0wsha~O2~QvNu^?k)Gl7CZAa%H}mKa||PbQMGzRu@@S; zky$c?Zsb}fJKyQLi6(sCQhx3VPwur9aZEDv%$B;%v*|{$(+u6Hd@K~Yk!x{G-Dm)n zbqxO=bo)wWl!Ax?I}r&E_eG}kNEjmn%aFseD>L>jmW+BW&8?g^YHpvY7;$2 zKZrJzUoS4>Uw}40ubQPc(RL9tXOLg9ZG$!2;pP0cm7c0wtNH8h)xCoQqhYc8IU+_b z)O2KHjAJ`~ik$~m^?WrxZ?T6*(rABUT6pY^u&N6;@Q)>|lKkmV1^DA?eC&W`Lxhbz zF8E+ocW>aIN>J=oaD%-gykP(827YzIYC6#&hF;*D%%vj4-*!|q85f*Z{rLobPr@47 zDHhFxOsv?0pzs63P;0TP5BJUz9Bnt75c7Pc`owx<5|h`1tZO1NG>W|p^{w@QtZ~$+ zcMa(8uW|knD^F^#gH`?YME)0>4wOQr!^={K{aos>pC4L>mk&pWA8zDd^sL4KtB@Zb zlp`H7JLE^@HnSnuyU<-VccUSp>fbdS+1?C8NkpZQRbB4KVRU?acCx>&4p*znbl~#b42Bv8rGD`ELX_e8cs@x!qX9-_p9#9p|%Fj#d4khM%8^IQyM5)LO)?LdO5 z9%YNaR5=KHz5&0?lV=gr4nPy*h+GAcLc2H-!S{U81AQ;8@OUPpo>q ziC?^WwT@0>EZKPsiRhvSwM3`Bqr114I%Ub`ATGS{{>oEzM>D_2!p7+0?+|Q6Cum`V zp5D&pWny!>r~2(?e(Q0oNE>`uJhoHL&qOkU-4gTwobDP8b`N5$Ou2g^6WxqeKia|% z*dmM6P(LUl15jj)0*uJy7LmI~$42^a=M|<*=(!YvgCR&>^~J6Hq8y>q!0@gpdMQOR zxMZc&)2e~N%dPy&(->HEQw&HyN{CWX!5%}MXu93i#^05!F?8Q4bDuKZNTFRTJZ>qB zcLrbv$49R;&LL;-$T&G!^}Q$a&#e)O6$}rhB{3u;62pVcV0aMU9SDZnl+$(BKDfu< zv^W-x$l_PD^Vg&jWN}BzNF-845~G%bSShveA(`VhZ~c)2QX+2&S&;^Bw$^ zTv1`|hhEI8yEIo;UE64yYOa`ucgZ<;mpot7wMWdzyY|4u8NADS)P}~Z)JSxh=WS5S zZcD8COeeo_t*G;M4b0jPBb-tv-b001bU&j{_*g13wFgiNIY?>{kU5Q4YjJ@b5!CpZ z^gu(tnZFQKu+d&%d^{t;)Pg`TnjsR55i#57g4CT`Ohh~C* zA>{&0lS|z+tGaIszaf7uwP*Bkj%u9`h!QNOCMdzJn08n!dH`*D^%Gn9FY|@Ey#r&t zlV}RJjN$SDUB7dd5xHivzaIx?WZ%#Pp3f!krckXonHs@-N928v2!zwW@ZX#_j^{X3 zUozG!h+>prKEz>6ads;%f(c6(Aj{j9SAEqseqn)4HEiLkekU8t3Q;x7SvH11F%`>M zCMQP%;(oyKh|&^d+?pwN@}=4!#8rFDs&*Gej|}(8TEMDrK9xUUS6y0_mgQic{XDAf zhqCJ8xrb}j>X*9s>vn~NE#vER2wR#HO-lX0%$9F{h~IR)tr#dv;{_5Nx6vNF*vIFJ3A9m9ErvSZi^ z8)xuStnG$nVAq9fAw*};Uno0;e!O)~okM?-#EpZ)T~lg7QFIe~tca!E?wZ2cJbWt) z4toq&k7U(@K@#Xa=*9`41INHJ-J6`0dqei(=yS~IMZZyHRVN=rh|B!jQ-lv zM7@h%l@X&(^e0nhOS{K(QeQ}(V#uaDA)FE*;#g31gT30J`@_Yqu3>qkTC~<#-bhl_ zE4}>M^5`lXozyF_Rh~AoC9R+wx+YT2?5IdNBARKiBqz4Y`?*8q{Yh2VMEI-aqApIe zvhLolDUNAm>d_oS`WRYKI?&ZoI?Rrb(g7^C#v@LRk4;{1e?MPjd^8&BtgQ`%LU`%J zAmLlK&Srei6UG%qt?ld_)2AuW(tvxIB>kf%U0#kJ#Iq$GwT?k#N$UvUtI>LYun9L}u`|(g)6|NIN00C+jd*h%-^99?FJdH3mUpr0SX(ovRr>|y|B5wkc=1xw*E1meLf-fS+!W_JW zvkab#gkvrq!AXIad>dy;3X_fuqTz0AL|{v`e^DB4$(A9=xs2%KSf0WNWX=WW;Nr@o za9^l&GUn5?(p1J)Xe1?NZb~XxXU!LCuB;Fs+XFz>UqudFT1dbJZpR4+l9iJtJk~6L zU?dAUm`hG_td%rerMCdZJAVOG!Kdd7p#JgXQ<^Hn7fOU;6lprD;{s0ll`LQs4%Lzz zjFlB2=KA?n^ViLHC!d%aTr6!K*--1*&NRmbyiJ6WUG!atlBnt`=nZ{k0w5h-~{hbO;b zVo3FIL^!}>RHuN9eTGC%OsxhoCXr=}Nw0B@Fg8&pYVc$gRKnBd8(0Pu-kr`@B`?4m z+f&ub0Yi)5;eJYr&JOeOoxW2``%23Cia$h8g$Y7_J{D*u2D%4*`T4^mVO$e{?Y+Sf zTyTl~#z}0+;bI-!i7!02(+LGS^)}Q!I!gDYj_(=j85tahZ{I*S(8LV=Vcoit zqCD}Zyu1{*KIHd~PHw<;=@XHud_0JkpWhEWG}1poui)k9W8^tHIkADB>A)eXp$M2w zKrSx-=)$MCh%{6<*hSqn-LXMmAr_1v)~^1@&`4ioL;uKFZ)6S&4ugje_8E!{PmHfe zUX+xV_vT|z@d0dxrwpXYdi#aR2uETgJ(JrB#z=Hgd0}y05uUU{nD{BD3q&^@FOt1` zWNfGDLQLdF-@vYczKGBEu3N##;it%Ne~?w8MtXXE`6IK;gTBZprv0q<14EIhHumKQ<+tAIOKSsn+(c}pTY`4sS;j7uBq~?Ug(&tx$7Ne|bwd{h z$X()!kFK(U!h#}X`L43Ay2vh^kQ09J#}zF4<>u*3WL!fmUZv>V92D;gstc$$;5A2I zex2ka9mdTrRuseRcD$Zf+Zd?bWThMLIHLLt_2X3oe8C!-O-A&N_4}k9XE?&uO^^XA zX)I*?IJ4s}2kvHN2;XRgce6FN_!aCRdNTb>U~j(vCxz2Q0CNKNq7BEF`RbR9e$_3X zZ4eZ^#Q+?wr}{~Mw9e`${gX5*UK4VQm*pi18&HUkW?lV!fNs2^c)LTtfCXnR&g{60 zooMlQgTrGcON_ML>~;&z*&KF_4Nqa`+3-}h(}vGwAsarARoU?Q%xA;XnA?V@vscmK z=wCY0cQ0_5QdrW9^nBWeyVzE1cvm@FY{N_0&rOrEbXOt!j151Ag>3k-Y>^FL$(}c} z2=Ujl>uvZF)@#F$V+A(6l>O7pav}dGHvAa&X&Zhl>$c%5S*Z`8f1gkX^F%4ApA@GN$U4bNrEZTMpLl3C=DzSZnn8(z## zwc!P9i48xRJwchPe(A2|>{1)Pg0E3p@C{`95VI)L{DwqAVOx@L__eJMSr+?w}z5W(95WPzFUjKoJi^EfEj6 zhzBU*0aj9cOz)}{AA#fDc7emckmwi`mlDK8Nyzarb|2w*4C#jiG32$;5l+wnA0&S~ zp5#VCDSncIDFkuL`C@`um_90emBQC3d>z5#Fq2XENeXXK_-P7`D!5m{Pb=6)^0nSe zOg+yf`iYF~BZze>t^b{bF9Rt^I5X9kv7YQOgZzxC=i10K8b@})&g}}tdO$(hQlZ9p(l60X&hb)seG)>YhZHg#mD~QM zcQO25hBHw1D0~OQK8EjScrU{rF?^0;Hrg`^m&b4|!}Azk!|)M?&oO+RVKM3$3g5u+ zB8Jy9`~t&Q7z*@Ph<**jCWgHXZ)5lkh5^(?M8AmPsSI~AyqMwR3}>KjBKjo^TN!?U z;R6i+&Tt*-E~1Yz>}Plh!#5eu#)y;XmNN`9{5r!&82*gmUl`8ANR+}|&G07-Uu4)b zPy6p;_&P&hw#Hw|@CJr2GklX_GwLeh{~m^4X80h(B@48Fh~Z@nZ({f+!vfUV#Ak@% z6Aag2s89Ht82*J}6m=uvKgaM`)am5j$M9u_HK@x8|2~HQ&hQn6C!$U#|LYn4kYN$p z3c{bu@G*wZGn~6b`xh`ghv68*PceLrA+?djFU0VChSxB>kD)wC)1At&j$s?atql7a zUdr&R3?E_m6NW!$_*;gvf|~ydhUE-TW7xrPE5mMvqYQ6j_*sVk&hUPQe_;3q!?zh` zE!A?%7*;W?Vc5ZNg5moa?q~Q>hW9c&$nX({&ocZQLw~N8HeDt{(|8v4FAY5kf-%Kk>N6ir!XvGSjX@^40{<4FdSoe8N*u`-p=qYhF@d&FvAxZ z{+i+M7{0-9#>ra0r3~N2@KlED8E$6yZiaD&yBS`^@Op-~GrX7KL57bo{1L-nGMrJM z^=M=GVTO+~oOz1&uVHvG!`B$5uhjlI3{PRWj^PG|Z457GcniY^82*^yFBrbg(6>tS z&th21u#@2!!wVT+$MBO3pJMnMhFOK0-%^H!4A(PkVc5y=YKEU-cpt;Z82+5$s|=T) zs`;;D*v)X1;XZ~RW_T;ZFEYfMysAG>V|WI`c_EEIo*~xk72N|2f57lXhP#Wk{{;+h zV2JLH@S(1{kKk$^4i!&D8x~MV_n^V+szy1S_{>5Vr+Q4d$4OKj&&-u zaagk68FwORPnFY+^OA?aZtqUTwntBXib9$z#q?-wJN5!$L<##>?)4O zDoCDFC37$%cvtQrzt|Z)jcr@UH;uLL#Sx{1agy7oIwHVXVe*Yl;I_)%aQ#qTeP4nA zJ4gFRF;lp67*o+Bh1(Hq+in%CYuotNuEz8B_I4zQwCn0Ugo!lKEef%C^o-%+mQ7{- zy`flyxHxq)SNBm=>J|Cc=KdW!LIWdPaI(3ICoCoM)q=jFBG3Y7ThSY96T*g$``Yqr~wH#j1uoaE`ek_VHel3CnV$uoI} zf~S&sCI#=se0AY=6+CHzO)7VsChtsjJ0FwuR5G$hd7VM+d`)ap$=C_mAkBJuv>{T- z=pG(atJvw7N)3^Kfwd~sLorFEUScLxn;vOS;IK!O4OCb=+SACsD&!Go03F&>t4%ZY z9XyUK=@o+`PIoKx^b_3_`4mfhN>#F5!l%`8*(sP}3HBD*6ie)pG(~pOKu9Vjk^%NoTG!tzs*U{LVv@54O zm;dlSq^tWlt@Z0<{a!HXq(5E;?`+2|7VHkF8z1Z$>&I=Zo$jqC_^zWDthxqz)mJk>oMBvig$JQ3rV+w2Wre-7m+^e7&%Wa@GX*y<#CdhXRs1nQ(RcI8f#?7%N(C? z7Em}Nc(KSy!^EP%m{G_KyktvS1S79G5-_#rQ$D@UMq^TXO7WMb-t>=o|EPx!%M=Oe zuJzEZ1zl4Dex1NMwY(f|T6Z^(d8M%Co&2tWgTk7}_<8xg3XfFyy$*d7@vDLW!<%G9 z{n(giggX4Zbl0ay_cZ97b}_QN@yJ60JeEMNm+tqVyU8$d=;yWHl}PAl0)Ae)=Ro)A z1a$j3eT~;X%6SRo?(x!L4Q32+HjfE{X=-P1@%l`CN4uBqJ>WObAORQ8Liz$?`b1zl zTjfQVKtzpPKzf3p3#vE$W8^ON@LLbMERYaCOaoc`tavcLDCj;$g84E0n&4LNO!pGj z8afP-@dLEdjp^26?O|2|yZjc+obheI8iUaf(|$?y+XA{n%$vj~(=Up(g$5$v$IyB8 z`xxjROQ7F99{qYT=Wp~|37(V|^yjtT80hj?CIKVYYrl_y?wSO2Uj6ceLOhUw?oy9_ zuY%6#hiS;9`u!Dj&%@t5$@F_}sSsBhB0xju)o**Q5C;;_ZSv@szs%OJ2=vM9R|&ey z6Y%re?*Qmh$$txw7+*-hkMO(9nGsD5rk+4%_;zfFDJj{=DVrG0@Ed-aLliB>g~#|JGyZ zy!til()$Jsp`rT#5KjFnN9=kx2tT8rx87Y3x=#lTH`^|Ifik?w_r*P$hoLk{O*%X2 zUIN|u#?#@q9q*3nPV}CSdy0jP5ek+GP+U+9feOuSL>jo zUZSD%#-jsti{Vdl(G(}88vxzMn2z$H;pdHS+C_GJ=Q!w4J-OmL%Rxu^&G7T;w*YiT zzeQ8ftpr`Z)bT(QmXu$|#Wp`QIZ5dT9CW06GW{-b&`}+gjP51}ooUZ0or$+IAKVQ( z!c%&z#9uOg_k!*K0umkN!(?>lf5?t6s!WUSIK2DuXP)ap_a&ck*=3Q^#z|Lm4ZgOa zjKU90t{#G*8)m0?|BV>%7zd!Cv&ZQrp~9h4gQ3#Ovel(U6_sVdU{R1B{fjk@^78Uv zu(Skk3V+Uw3nEQ*`1H);Dn-74#>$t=nYwdK6=MAp5-^_dU1 zFT$`P zpsNHEw12oA=cHsUL=Eu_IQ0+L;`m7AyqBEzX({UPlskdj+C8wN2HX|mgEk@-!`JbT z;s70x5Yt!;=Op|>Y*lV>jp1WLxa;9QOS8bVvVe;GP(K^yP4ScR zR*N6v_Kx}KDl{PdrRg%@_pidGXa4r|`RX1*lT z|K9ZZ__rh=k4>NNlT;6rs#G@z#QVezH{3w4)C%~-`_c$j>URaJ8BdTB4>b7I4|YAO zDFBHE*@2?cEJZX3kf&eqs~!>*#Ge#x%8effio{}*w9}WUf|F4+euYp9uvWj~*Lt$? z2KnSm8spV?NzA9$hC3p$STMIP-W?2vg2hFlid@jdVl>4~9-*Q&q19_j%QUvVqqYWE zToVlv<>1e_2)P;^oYhUrD^go;koO>`sfj>boExcs|_W5`~0@M>?Z>!7bRb<~r3c)o56;_EgD;jh~$EMD#J+gu3O z7j7;e>l-&M9Pt1b)&!M`{bt#m^$WMvG{nl=V}{s?CKk8|+%|wB?r7N9TpcW#gb$aO zCZG;e7+hzr^h{ z5ouB16t+d`8{2UwFA{QNO9v|)j@Got8tJNDh~2;}#~_9erlX6wO%B(${kBI` zX<%yLaB^a}sVNq2Z;!Nf*yzUQMvyi|Hbt7)f|P0MqKX|p+)G2jqp=tjay{e!D?nGP zpnRx8qV*B1m-sVJ&a_XO@D<|YX#M>>5fUAyS;a#9(U=h;pTg>t&RzOCiy(UZr9p_FeW(WnW(!e2)E`L7`--t3kSy0ko zJX!c9G2FG>Qcr(DRU^=kkjqqs1;(-3NKI3FQ20)c#mF=*?Lw|JuQ1vuXewjPjV-}d zq2fv*$Kb}^Foh^7t|$j;94KTHLgl}|XriJ|KTv)*d~kgS`B<@Yk}zc-NcUX zG3vzgSPa}G1(^4;6kv)&r4^->CFP|+pU)zIwneNiE-oplC@v}~uPiIAsKBVE0wOLT zLn1E3p{z{EeUcCq8DPrG%1VH{P~j*xz?BxSE?r$-QM|frT*!-*55-1_vJxd!Sz3xU zXVl~+6-BGd%0lI#G6=g&f;X~1vWnAum)mHM6+dA6BsS(1HbIIu{g53(M_ZZpDjUmj zXA56#d$0kVhQ7x3wTz%`Uz4BM-q$IMSvD|czutj%8~-B?pF~M;gTvp_;cy9Yqtd(1 zN(X2DLpt4Ld2@Pr{Qu4JPn;?@TmC5~$|tP=oE06J`8Las4dYCJPg$M`Qs>i_r)8L_ z6X!G9mTVVqX8)}1%bK{#!kxBvqICM4?QLmuxMcbYMF2e!_Mcy)!U?9PoXM9*i7SbAn8*=pR#(l>m2uL^Z*< z3i4xV`fgMeI%4+|+ru5bXJmV0eJtG3+T2)^sAhfE<&Ut=obm!Zx1!4dw8JpIU(3xk z4Pj+r;d{wA$e6Dg2ed;k=y%2m23#-xNp6PPi8OhgeLOn6MOLkh)lj2_KOz502xKN3 z^EbjE)oje)34<)7Fm`oL!T0$nDi%Z4<^g@7LfdQ&{vw69nH&7Y3U7P9o5LIl)OxZPfDYb+xHdBu&Ia$-&gT!+Fw1#Ljw*!4?a9&K+lmA)K9MItnMGA zNsa!&o`Lb+cqfjDQ9YW%?W)J4&nKgAIC%~vD-|Xdiz7V*Wzrl7BBh=*na(4Zp6y*D zBFz^V-Hu%^m<~|Gf6Or1oscw{X^nH3I>SPkU^a%vJ87A=+h!DnS7i+6-CiMNWsqFR z5O986$kob;d;sTdLatFxBtM*Y3RxA5j+?Oe2zi=z>c9^PdAfG%&^V`Wy>{#1FAEt~ z+;BoFZca4v>m4{tiv|bM(xuUXv@|+Hi*WFSUd>LVrCo~?Yw6hP#9Eq0wJf^gQ7H;j zY_w6DC2*T;oTcVw8)s>`g@suBV4SlZIL#2qP6yIb@!bxjrQv&&7>rOkrQ({15n$D) z2yjUYr`@?rRoXEEsj*|J%7HWvpmh$KfS@%Y8V4MY4sCOLV>^u$F<6 zQKuKTC=QGc$9wW|OH+Jod}I*SOc-7I_DC(sF`rdnB#=Ko8tC{AB8#tQPW|F*dw`X zKutCO%GZDUObIIt+}pT@cELcWfQuB9~!kHMi~A>V>?b6q2x zd;0o?yx31pvgDpVnDGiY+asIc9F6Z5@;W#h+pF_e1bc^q?>_V7%5r^WP6V%mIIO?!7vN7Ju? zDYmO3hWG|Y$e)q3wT+y(d0qY*&gu=(j{MzS1LJW@JA9?pwPSb)Y0NkwuS}yM+g5n? z44kLi8Jgbmiz@u0M7ZY~_0%$c)j|y)M}(Fo!7`1M58G`E&#!v}x`Q3HCgrG1t5^M9 z%0U$WZSgTogS2$CwPH?JO%vN^ek-Rui_E{RW@vB>Uw>&585L{4?vv+X$d41f?eO}t zjUFaV9I)z-KDnPN9+KP`ZO5eM6k-*D)*~va?()kIo1o#t1yuxA(3kx3W)pPca6z{a zffe-2Y4UR>XtW*OlqvL$jtuqSNH<)6*0Uo@IT7Cz8b)j1Oq2J}Gzr;EG1B%L8yary zqkt-u&}N&8QPqKfJZLm(K8!}qUHyZJ)!Cmee`wTETpa3Hp;#Tu?Tu8`L+SDvqf4}{ zu{qqn;V>5JZ|)l1VO!9z#I2u`0od30|ByCBt6fhTm z%T#=%MBR-E_Xs*FMX`oheWWGQ)>wm-$n~Yk_0)eU;y#R7J!lTogj=wT8as3;CKKS6 zBlxSvusVT%kU9*LLn*dv*9Jr78&?F+C#@z)CdLqo`Af4zz-=yi8MHc}dN)NIg@2dI zL3%HvUo8$H9aCzHQp`i>RKY7rQZEQP^3PhToKposR zoX~B}3!jKo=6PZCne{8Ciz`|-Heq$Ek^trm($qrQI~>KQ)C@r$lNCZR9l{C~)qwy7hwBMBWdacACr41}fpOmST!DM{WltGG^i2~NdemY>^2hivAm5dsE34dG2#vB63~ZR^JBrURQ@4wsD8|4JOtA4Ef7&2<&^#VYD*)KLUvkH1P4 z865cE(n=ZPZp^ek?0)jkL9*8G`digI0@PR|HM1_0>he{8g@Htv_2{%6P$|iArU!B9i`wzkd{`BjX~V)Z=MF zxMFFLI*xCH?KTYj(9_mSjQROfnsE8@pz+_Ez{F%@YX6m$dv*?&=0nWNVE*0}D}u`r zAzWdivjC+|(L}N3Tw?|6oklR&^ASt7ZUhH-a0^vmX6t*us;dR*prfG8rL-6t#ju``cOje_C?(Sh;X1G9}dqQ)%v@ zhQeQBg^zMM(xphJB(v^w6em+_xd?23==DwLHQ1#ZfT;_$sTUQwCsSz#;C4T8!=3O{ z#4s;tYJn*$S`)&{)35>C?}P0)_~PiGc<(WlZb8Atv-3Re3z*{bf=+DNQB4(yI9P1 z|KyFZQq>bad7U=|2e>w2fPH@X2|EBaMN{(sB26D!8i9OD=709f+ihxU$V~O;5~3sH zypS0&l%25{?lij%AC`QZCLS%J4mK{~c`#@!mYmBgY4UEH3u;57dtys|G9bUu&&Pqu=BvuRadi92|_F<;yRi)q|5JlgC0gGhs50D4@^i?A-OEG*CP8(%1y}4qUzxc`G)U!MMsgoJW)PHIS^HEWyml2 z^XM!P($~c^K{_hlU&@qU_b)R+-0TzNASLFfnexklWqn=UqfYuh$CM})OH@yIY5;xe zjlMMfDc&ZP%GZGOmc}50xpCr52TGNweQt#KqQmXT&VAy~i9JLW6f;6p&OO(S5TA6q zRioS|o|}Xd3sHG$K2|oV_oBoe!q9c7;uiDPCuo(&*j~KlaP)~&VJ>ZAWj#be(6_<# z{XBgOLUSA+@u`7?8Y$A^>MdCP(+jTlJm%+on8^IRj|Loyj;0ms!p)6MXJIz!+ui`e zf3MG<=Kl{|_$D9r)kc~+!m%?;LKxspphZXH_kDv5m0^5>oqLa9^F}RgSH{ddFuLzh zQYYkNzG!2xq%c$(DqCG#j$MA0t1DI`zdY%q%}-jHjxgpsVzg@}ScVf?f*3 zG}d)sl!(hYf*}(BV<$nV%n*di4Z%-*yxc@H>RuMB!QrPq7K(*cns1}n6-}t44>1ey zwAWWfvl2f4jd(^kV%Mz>hcMOUMb+gPn*Y+LmUv4k0kCM;-q>7=MPS-dPJ6}Gdazlx z74lZUPN0n~3D=?r&1&=~na-M#aZRvv4eaUKJIeDgG!*}yB{(0K292n7X}2l`1vJ9c zz6kK36@b>)+B-}zj7^;pz(Tg-hY%0>jZbS`U3t76v~qW78sfS)u6MsbPD-}Dj zG#2i`L7>GGNXH%V_%J|Qe%DI1o4YHxE||Xy1%8Z1PIz{em(Y8c;#~rjFe7M?6Tt#( z?gqx5|G`}NiXaRON+Iu2!rI5Xk675M)P;RZ2}?~9M@s3RT>bAPw3ThCQ(UHU^0ZBG zFrf)-9;;H|@!;f`*$k3~ccjA;6-}+1WBTibt=PQN+7iRvrja((lmC^#YfEDXe12BZ zh^>;XElp=(t~W{O=cl4kY|wPxq}s@9@Qao+(b|`_|02n@jMPR_^x=d(nzE0gqdt#0 z87A0kAGuHU1$iAf*`;P+AT@@IHWxb6Ma-Tmt ziW}m{JsZg&FZIuls$#BJ$FU&^ZYt^`>lE_88g4bRqq<&Xe^toq{qr+FpP>02gphOrM}3|;pj>06eTGh8zi$BppXnTZb||4S%k`}#-F zZbIe3o_K6mg~(nj<+m~e1qc08usrByNls$-?CX+@$P=iGWW)Mx<-3ry?r5NYq}*+WPi{n-#jKza3I|!jIN+| z3QJ@br?54OeoA3vtwTO}>5M?ZCo)tDn3#EmCA62aRl;Z}o5lU|YHe%_(qN&O|#lmZ~W-a%bk4yW**YaABjZxLs6vVl8agHl`9XlrDb- zA(zjYMn+SGPg}}+fxA^fE9Ot7%in|fFQ>!Yk>ipwM@uBKLmBc-Fh4kV8k#$bNOI;> zIS;Di7Z`P`f@P& z-WJ~-9~q51@&26Qjy?Uoy#pvoT*+4}!j3MiYK!b=GAS#JfrJ{<=AqvHKI{rMa%M5t zx~`rv?3m?tc#gkpUfg-VyuHOEMVmrgA(pR4;e+=zEHveBudyn3w9=!v{$lpWn z#}^zOy}7kJ3Rd^%?X)*#^Zz(TUXg_Yy6|6IZ>POU@9`P()6o0LMGKBfF6RdSo!dKS zXfWQrmkXY%L%E?znB`S9wrZxl4^g@Kxc_@maiofh%AuL^8ARp7$4|~pc8#)dHZ?56 zE?WnI%j9|kRo1q#?WW$CCFY@N&&|%BJx|pix!K3hw)3>rAgIdYyR+mUApY7DrV{^= zX^TGu@z*94N;$E5w!COwpkV)!sf5m$Gu=2ZmbuyKa}vZ<8T#w9<#iDH-4hpc_HV;k z$9DT|Dtc@u*EM~br>3_&0#-HNX4m7o8-T{1TY<3Ru9|{b7P8t#W?@u?EHAPjLNpg3 z!SZJ3W`9>JKSEW#JDFC_k)MI``%e02Do-`)B;^TdDSydat^CKK{Jy!$@*d?WxnG_m z4?y|HgNc>bCBJ%avB|$_Ig=72Jy~L8Od~N=2h5uogtX!l&7%0^X5Tz3L0nWWx?`?< z266fP(#1LL=)Q^UIY>WYa#USihlvDua#m;~Y&OYRp!*`qMD*dAoydy!NS6FPcz-i@ zaZZb2BXU~0ZOiy_^m-k3Zkpbvk)kCa1J(?UayLTBL;|*{jJA4Sf{1oxsfhOWjCt#& zA7;tRvI7MVqKBM{GSpW`4Q2I#D4V#I;oPK^dC;lMBXE$_FQ1#6ojEgsLaKLp_B{DD zDD>03)D%*K9EU>GDRV1C7|S}FvmMqs8xB(F(K)%@{$5&NchW9k}!(#bbKh0p!<)NKZT(GUO8n{)I^Y7 zV#&#Qd+Mmr1X004`2r-|zse=SJEO{#fH9V*7C?5!x47O);L3&az=?r^8w;o8%z4;w z_LTj}oGAnUYN31toc}yE=i~`YHPGKf74ob5fw-(vk(<#>%cp z5@l1xnVMBJn)Zyf?)dVEZNMo^B~ICK^4Add$Ek#I(wIcoDMQhqPDQH1D0yx>PJSX7 zD0s1Saq^f=ZL^&CV0>iTUTwjwoC(aJ(j*>t+$eg~0rMDi?(y=65WBBDm|Se?an#jo zR?Y}|1j9UgM4=a0x{+BHE8XaAiEex+>!zyk{m09TmIexLs+htgsVBD9ZH`Mf3Y}%? zM)_lb(v990Ce@8PP`M|_Z$P)tRwl@Z$gpGa#=+kBgy{*RXW-~^I98=}@xmzzwef+j zy@nk528BkWvh$ZfN6e3evcl4_$; zuWgCE4%$4jW}4b0PSJOw4W-xfOXRK4=IN?wYLjRcF(-xeN^Tp>*$$p4?^+h9`utk? zTmSN&f&Sr`TKybSJr}Av^3ca|Z9m1zgQ$9TEk18?(<5rMzA=d&t0SW7igohBw39V| z+EfAlI07Flpm`ACVvhqpMAf&}$q%M6dnUKod*~JWSJufJ(w5VX4%PJn=S-;;A^xtd zqM10@wCc6fS0VQPO8&%pXdHvrL!xsm zzH=CB8T_qvzb+q7+;h@wy9F&LG;iV(d z;k)bQrvl5d!Kyus56Te_ogDh3a+leV>YZq=n!8YuQ1R~^jBjg(p|peJD5|avV>3EF zK07m9TZ^Mrb#&D4gqX~gZ8)MVh=p;oqxw~imZ6JMhHtpuIk(%YX#P0}s+*u<(LOjkyq>hlqZ)@c3T8$&;@x@yCHKj(leajKq;`g=k zdu)p%?RiFEn1 z%b|9Uj_-8rlGY_sR6W)p|J@3o%q~+g_)w$#4l_t@*r^!&uu(o{G-#qI^e2o0VLeeG z6zq1*8S+`10mWgu93DJFzM?rGm6I6J+aQRlzn&rg!lBwz5B2#C@}f-2QCm7D*9wz` z{APo^GLyEsHa9ngp<1G>q_dRAI7A5J+|eX|b8-PSfV2&P#xvAI&&yuEyd7=8Vu_mF z77DlQR1Mu?iRrwy^s3)B$qy}GZh})EOE(@nRdCgUI)YQ%(bdyKjk0EQ2nSwd|2$B2 zceA|L!NzLh?^bM7Bj{j*mfp?gC1P`KVC|oq<>%jZGHHVki$`|o@tKN7W0wZq0O$IK z8@mQDSH|z%@v$zP4E|V)e9#qG#fI8J6&Qd5qZeQWrgs&%b9iK^7iV5!$b^=Q9oQIx z=&k)wtGqH_>C`{CJAq!T$YQBkv3f=|FnFm|er6H_hi=S(^rMKdiVV9gbrR|J&8U1+ zvqsl_hfaM;bSs8#t#E~z z6FXuG`xDcI`Qs?YuIdvV^5p_mVBMQu?4o;ofiAkP-ZYh5H4N|6WAIMBzov7q8j*MI zg^3r-PUlt|>aS8I(P{6uK`FZ{z3QVIP+;NHBWLBp4ux;LA75 zkE~RQ?}@P)x(uZ#m(D-5Bm7@lF2E$Y)J%)2`!>r@t~!P4Gx|7(Yv%`54pu`GTsrHCd?M@0FAMDko zK&-vvYzR)Ru>sCnFa%z1JV@rFWNwNQj+42wX zmbahk$_8vp6sSDxl0G6+{<-i-O*s$q54qWYC|vv1n0&&mmp18CY8}R+Lp*d>@E>N; zs<+RP*OaMd!Mp9xZWt~u(hb8F*m$u#%UN$YI(D5n7D6=!eMP!a=);}n)Hw8owAvTBk?am48&BM2{;IP+v>(;Eg(MbZn8_hTYG~no1&dbis$j!c>sOp|> z`J*z`(0JoyH#OxUiqj$7Lq@-@I8p0jW@S{b6Ya@_UDNKhU#Tr5Pt|2JjSzMT5OSoE zo53FQV%o!nzRp3trCQb2x!LiIs+W7@P34JIwi>CIldC+bXG>Z^IW$eAoZV27a)h+w z;D}Cgl@Cgf$_F#5Zj8%U%2ipMWM$L5-B_H|$kd{Fy7Wo3qIjUGqj=a2AH@T%QuK;nEG(~d7QH#UXa#CvUAM+9Gu)`c6Ja3YpCkG@AiGb{wg zQUagS2)c(5-^BV)#HXux73e9$eGYy>HRbm|)4o!Q`U?C#4{4y!M|>V{?(cd2Pu_>- zJ#fvsKkTR4lIl__xm27w7oTk`r8wh~$YUFE`%7A$m^t&bnf^@NVWsbknIEukjY)T- zgvhWFS-8^`H_Fg8GZX}OblQ#@1k9F1F~f-@#7u)Q6tkQNA!ZvV5zjFWA?BJ_n|GFt zBI0?=1;r>k4N>!F&cqFz_>e*#OD_xZar?~@cpj@>X5-?Unefv0;Vhad^vhzx;XG^v z5XT$;P!>+c))e%*gz)ro;!HsxXEr!DF04ETXN2lkA%X^1I!lP9#xZl|?3uH`I(M#8 zb6JG~c>w^j{>k)$g9-`w!0lb?1<}gSQXVVjLolL+6fB@udO1boaD3i;Wa(A&p$a}X zpAYpS3$XY^Sa2dYJ5Vw+AUp z==C;Qt4qkRjdU=5lQ0z<3kNIxG%1BWsAj^Np) zy(MM6#qXx;!4zWEDoo0Z^>+;fSFIWxis5JgEa?pl;ZRGgF^*#y4u|RB9DL=ujdmr_ zPPd(1!^3n&>ge8`-9rPT@a^sIf^&R$7>B)#u3NpjB(zffl$V#{q=!{K!{h64MEY2K zVihjITeYeW?sj~#N;luFT7}-`@c7s|x|#zUr*_7{Yz%U7;72DuzeS*(MFXAGMANw% zwANTSgiyQt;yZ_WD1-Ki?tdxl1K*l!4l)adQs-QODzy6$o- z96ItCh20mfYNr*Sp5UsXX{JGMd>BLh>7*QGC9h4C6)YnJSGB@$tz-Q=;|XmXT-B(* z@8++oEw|_NVJF@}+KHi-(A*O8{dsx zamo+=ICjO{%siQi`V8Cl#!VC(H#Mre1o_bEb-2MXxT;q3(J$6%E>0)9)@`^kucjeV zv%!hC?ruc!+1ZDi4Di)zd^!oyGtw8-c1*EXYpNg%R#IQcdZci>eIB=8lz|=#I{f&> z3Rn0FaR@D$dD6rm-hP$c)cMCaKs@hq<7<3=GSRO3^;HcDgZmfYM(xRu_DAi^kM_?n zPNkDy-5Re^q@&+)t9($o=Zmj;^ouy$!Y75>?GvXv{Qcng1GE&@37ndduE zTTo}3PIxr^UU)dE1ohAzDM&5;vXQ^X9R9h`#la3fe|Vdc z4{C^m1d$gWWcUa{l%2QOP3KOKKOI{^&=n4OP=y0j;n3Am;ow%`0981^N(ztR-CE|O z+_;xrx#3?#cyx+s-ob}~l9Ce?;y!ZY0;KN}M3>iv2c5zLK1BYwFzHQ#aQ~elijwf* zWOF(%!Doz1rhmI#%uB=>*F4fqDbV~Ic9Mz0O*-pX(X!~G0D!tf4;_cNq?M|@sj_!h$% zK8-J67-2Zd@IwqKpHuj6GJJ~R+YG6kkpD`C>lwxvp2zT7h97141%}^Zc#xs7(>KWu z$Q=Jc5ShZ@ze?_PLVTSd7BLL|B66>1dn0oh{5}CZuH3$aU^(NL+y0*?JUXmjB8bVa z=LsS{zh_7Vhum2V&tUj(4FAB;*zZQR%cBhGPCE);$#9(E4;cQO;ZoFBL|4pkFT*Ps z{(#}n8NLq@B>G=4{1d~|Gc-QR@Fs?LG5lYKGf?Izdf7r3iMNmehtGWhP@1LWB3h*0n|Z6 zzlhSd8{*2*Y7|z28l)_!j@FxskWY{xL`|o1-IzwN!#$U?t28J&)e3M}_>PF)K9)@3L z_#ne23$%ZT;bjbOV)!P*0@T&SXNchw4A)?YPxzY{{)J%_btBcPS@MVTI zsKW{WK8F9!@D+w9qAn-@>lyx#VG-I0!k^3VF^11GoV!H(7ce}B;TXeDF?@|7wT;9t z#PEEE*D$<~p*%^`oyxF|VH?A(4Eq^g%J8cUA7S_thCgTcTZXfOn*R!h_%OrA8NR?Uu#Dw0oX;?i;aY~( z49{SAHp5*E_b|MG;WZ5JVE6@wcQgDR!{-?Og5fI+|Hv?qr}aCL;WCD&Ff3tM$M8K2 zdl?Qe9AkJH!&?~M&hRdVUt{<%!xtF-n&IylzQJ(D$y&dq4By4@REFyrZf5vyhH-|w z8D7QkdWN?%yqDoYhL14(5yM|HoKc|lXk++chL19wd5ZS0VR$ja*BGX+)c!dPPhq%@ z;Rc3n3@>MR3&RH({+Qt}7{1QXw@UNRVpz+tli?V{3mIO=@RJOmV)z?|S%sS4Qig>L z*E4Kk*var}hM!@0AH&BO{+!{f440p(`LAQx&2W_AK87D=cq_v%GQ|43sy|O-cm~6H zA&oztA=c*=-2)7N!0<(eyNk8|1q^Rsi0+Q?p{}}*;A$QRAdD!)tWKeIy6dPY#Ib>6 zUEP4&%^T)e3)M7YY{w`#W6w@ z6*)q>rd@jwsA!xhVtcloyZMZs+Oh3t^~LlpAD%#ZITZo+Y%ik#L<##>?)4ODoCDFC36TPcvtQrzt|Z)jcr@UH;uLL#c`yB zagy67I3mDVVe*Yl;AYC+aQ#qTeFE+EeR(kIFs7hK3b!NJw%saN*S7JkU5)4M?d>Q{ zAZO=j|7Z;M>giEoB29E-LM$FVW4O3wQ(1p+C>9|uPTkB!YZR4wMZUGUf5(o{z{u9P zrI{=7*l3uDcA*PHg55jm&@ajzI(uO%Uld}hbBwaj?$PZr>z%F^CcLP|tx3IMbAj$? zUS3B-Gj5R$?=ET1YtM^D^1^GHii`8MtZ52`^4js%7>Pted5xR%aNu$Krt-Y^w|8u) z*-)#U6>v5*<+akO%8|TCb+|IGEpldMUbHRJUYQrcjcF)PP5s?@d2P7vBtANpmj{~- z^mn^vxgB|fBVx))p3W@#ch>5lXob1Dw$_e@LtSQ7j9Rr@%&Q!Pa zF-cD)BYTwh=4)b;O2$sehVwb`NF}3tcu=ikr(-HLL;?oZYETbpkxIS9OsFc zt(MD9K`4_-3HBCQ1WTpFx^8?$m{dxroiqrLN{OTZc4{EdG)f?~P)Aw2_x1+#6H=tbr=q&lCg?g@#W}{2wK^LZLrn5Ct$FEWFZ8zZ zaO=gSAgcPROo9(h#;c@SodlnNzZx*)g-ZTGeYuXt=A>OY-MRdS_aR-~$7!uwC+qiu zNhkgB@^@!DcCTPpK;8IY&saZhUhQ;mIl(s^yb#L;F{vXqSaU%J6`7ae6xVUdBBTBP8uc_1;&g* zX5b}T(&86+&5?kqJ)iRF^)(uk(o>4RH1(!`%=RQUZK`X=I61p$UP$!hXD_aNAQUb<^iqAXAkpPbwBEV#HuY&Fx2kC9-048JD0)jQKYji57>)J28}(9n7Hi{=V(AOYPbkA7LpZ2gKrPkEXCy!kH(y2}&r^Xm6m(4~_9 z{tCJ;B;dEgqu*zdXvos4d|;Y2sebo@&g{1$w#F`A{cb`bixL4phR$ohS3yU&#hJ&@ zS@j0z^@dXHgEpQZHm_7SIm^*CWwxC$y`D54w}LK+y3IU>pEn){)(UZ}Ap$gX-gum| z4(&&YO=#%83zSp8PY>Jrt$-gzo&LP};BL^(0^U4^-z5D&hyT`N=)C$B?GoZei^`72 z2Y_?xw_wDscZ2XV`g!Z!C7}Csz-DOV?gh%clkb5&nunnze)N#ePPzv`cfRp-_-)6# zqq-C8&quxjT`TaWUC6@w7W`ou-+Hdur}ynpeQ)AG)jHLQPPzl2BRtVjbcmMRUVabn zv-we9%FucF9Ri)8JRp8wzS6pc41ENnxm*t?N@X6?c4m#>38ai)0ia@s*{uEy{ z#YyQJKz9w(Q9d;MyzzY+bSA!Y9CWC5T=9M0K}Y$`@bl{Tl0&~mQ_zWv@R5tu@jw%n zlwbbEc6`y~B&A#Lpd;Or>9@r}M|D&(x?u;MY0t?{#M_w*r2ZN<0MP4%f^3+j9P@-mo|D?YA#TgGgY$j@*4Q3!i_P7(6_ zIoY#ChRBc^z6^h6T4o?KJu@RSGxM0t8JROPW@VxRr@G!eq~y`ykqsG(-Ph=AfO z9R!oeBKt+S@igHNb8z^DWOqH6!UyAyJVwk=x7~_g%@3--V}82o3`qa|B3%aj{!?(9 znSW#YeD#`s5?-YLnDpZS1OE3C_I&L~UqoK%1==HhKK?BX$YayzW81lIRH;t(i}#5e z=!FJLKJmUZg47YgyMolX5}qKX6yeQ-{f&aAHzk^0eux#JrD#ilBF0psIDCo96M#_J z_yb!CK*Ldo1h`melzd4iX%96e=EiHo9g$cpm|GX`4hBQP;-XMRE@)ygnyw~~P|=#u z>NTZh8r$AcTLUbvcLs@a@TXXWT#e4k>L%qCsjauj=-sA5f5xIvM<39Q(4ZY3q)Wo_ zl_V7b;!eS$9c{IZb#?02XwVq1QQVm^)Q8i4$AYDbmJtI(gWKGg;js}$&_`l5Mvq`w zQF&2mF|O98nBvTaNJp$Dx)FCiPbC3U#JD~g&KtL z7itt1ul6@;E`;kVHJ6X|othSocz_FQf;z%}vuw`#h1+TxV&&~IL+nHo3tZrB8$c0v zG;D0H4wg*9hs#S7P=_fDt|8ZYG52U&Yh5GmFZT$oi-bFHMn$Y4+*G%@wXN12$oOjc zE`G+V7K$bGh-~SIw5aa_+amRi?YK)93AwSQgB1=(YuaOtbj2>jZeSK;+sAiyJKrtS z(S_P3hwEE<+aszpFg0*E@i5%f6brYvN7_1UbYpWPNSh*?B28>T$~1LR#SS0eQ6GWE zRaEXVbA<}@cYv-+UirWSUy`Ay>f;ye(;|F@_`q3z15boRhbdFB5PvlOg9te@hI?me zSvR&lDC8`)h*s0oSnbOBMWNL~&X18%kgPE(NVxStE?`WoCf2^Ot`1*J#)1O_LN281 zw_(=ee03}JL~z-%;9emYFB)8PlUr^Nu^dsalRbhc~tTs~9)E*SRlVdS5O-s9wE6pp6 zHVT@`SaV}ba8;@jMm-H%S5Jy(|To;!tTtX=O=yDbVM$2%v2dtBZ?EN-BzrO3EwC zN-HX`##;dq7my(l7vfM>CgeUz2#O3a89z3Z%WaOOXx(@mB)r-#S?-z@*csdBUBpJJkX(h9&?(UF;Nv;5dF&II_B z<(VLLK5cnghM78XKBH~PcJXHR&)UAMiK{H!X?rJ1r_b5mmNth=rms*0(8E!c1zxqa zh5V+4hmMTL$#$l0|Uqb-?!+&$Wb*X$kdAd zF(p|Ea0f_K6O5}MKbEHNMpdCBc0aK_+|heRwl~(t!X2&6jWvmC)@NP*2P+JM@BnXPjWb_2Qr8W~iM=lh@hDqr+Qd)yh~6 zHCp%+@~?zIX0kDVBMef_#{8Wy$TA9JSLYObpO2zqF;s0H&=)GS&DP*AQh1xW!C$QK zwg@X*l8pU6h@gaJ`Bv6Zjl4?9%T)NJG%C4$U%||oiiq%i6|biK)pIvd)i{s*K^B z+AD;t43Y~O0?v;Mxmr1q58%8_$TiA|eFmPTi25e}ZvtJ#UPv}zMjB~aFrx^m-=|Ea4zT1JcG<=T|gAppH zR9q7=0<8KJ0WMeJv^#gHN;^g%HFhjjIgrKyv}Qq51GK(F1w&Y^RYT#)}Q; z*XHRRb$U$Ltj9QIz_mA{4ZyTFauOBdrpA^C5dDL+-wqjuy3OGZ)XD5cxB2wh$9F!-3J^cuziVSBj5~j|`%k38PEj9;qcc<`W5w1oFp6+IZ9psIvgpDoXrpEe~NUa(glwc%+I<_Dmg9+Tvz5}xcl&Q(w!Gaa=qfloc zYB~%Ndn9)asL2KDedsZRo9N;A*3OepqG#WJ@Mx*Ag{=vlR>`#|JH0mfW4t1{l*>4BQHUi<4IVsG_JF)8S-RY-H)*FAtY?(0rjA2~SxYgI|wl42=fF8-FO z_(+Mm8x!skbX1CB4YB%2OQfx_1}Ty2OOxxV|5C(#7_)lN9Ht4kU>P-b=u%83!0klv zSB+tH0{CtI_h}{ovK*R&Z5HYiF1!559kbpzTmye-uMw|$?}iQ^EiqEsz@qedm`WK;#wSe~q==a) za8A@09VWp_*q!tQ6F?Zme#K z&{|G~VIRe6Rcg%9FB%=AF-MgNTNjONsfk1}YOpe&OC2jjg9$Nd;MM5%LGG-BHfC7X zYRBHiI8i*eqmF9o;31PW-B7S%ISqe=#8+YsjqDo=o)XOWl7MEAk}4^Okr-y)aJIc! zSoxVW#YV^%t#_2um*K!Y@v&}vEkD*jNDMLg_7~Z(u|5*pgoQ!W(0v0#U1PX}3}@dr zwlsF2hXDC+SR_p#QS%_ZL*v~8aWCN^%%|ya$yoib#KHPOGz8XMS5aTAqOL|AD?s-6 zt5lJ}LH#YQlp+3Rxj9X-qIs4xcU$-vE4jtPS z!PAkp$SN^AOdk=hnS=%wIzHjYvf|cATPvC&IDbS=v{5assOn&$QsAB>oI%j~%u|G5 z>qLV2B|!aH(U3W4wdi$4(9~LAT@=h;2LV^M{&Y2F7Qb` zo+gAVmIkTg_%_&X!@v(cZN0>ppFgDumoE<*|Gf!JOg5(WUs<_l=WuC0#HE$igZdc>pn+uGPRbA!1jk;--KR+U8(_?x=@>XQIUHxm1Y2L_Y*hV zum)EiI&G&&$41>{0`O_{hliuEAa`By1DePa?KexBBGO@?EC-(4B@pArT@E>|!z3 zy^%MxwzTXNWU5o5DDK{ZEi>ik+)ul_9_6 z&!e+kNM9Gv1nH=Fe<@Rb-M`EPakEd5gOr$`X38%Imi2XYk2>l59CQ0rEKxn-sR8t< zH~MPyr+AxGDqjQATN;B1=EjLL9Vk_z_PG(_iw?IVJNJn{C-x9kP|OHXIhVGsI}qZN zPPb~5`^0mTaAF}UPaVw4CiPyF*h3h)##G#5-ueWs@)+BTw;YZ>aVpHEO{}bkD5#Cq z`21GTj%=Fa_=rypB-BWe7FTb<>YrY4wdXNE=fgzi=Y2HbP;@k{SQl^RBi}<;^XBeno;+%SPc$8^|4SatkQfN#ja>V9b<@D zfTz8_Dw>t>`ESHCx)Hl>bvT5nE-$Js$I$$jKDESKN(q2P!}iAJS}X$7j&j;7uGWLi zvaOJ}`gH=Kgo2~jErl7rE6eM*WOW{hoPbP_bkErxcFy8txLOADJY;3 zruIdE2dx0KzSiDhf?;gxi~tt06+eV{$ZvdF>+0GgR)~U0L2M}xvy}2u!@nROHlf`I zL61WJ3DW3>hU$)d?1T@k#7{B(lpreTOj9Vb!An6ot1@$bSBMqdO!F9p>T`2HlG;+eTtGtBXyAe3v<0mLO(whjbekQlfFRnt1sfwa=O<=^gax0|3#8*8L6$F(1#QDXv#iT zj`}>-$_m106Xdej!;C@>mPc)bbyPNW*xv|R!?P$UOPjIAM@9B6#n^uo zi0-PuFf8kB#7yqjU$@tqxA!&ql;L`dH(mzv}xo`(|gEWx*r|0CrO!Sj`=c%JL#NlxOqSWb>Q-HM%E;ge5;=aYdf zGAHb}4aZljq;ncHQS5VuhepTRxA*sPQu~(8(u#NYW0tu$*3&iG8|&>0DO<rGSZ;j#*llbCes%%`1`*HBS<(O&kRjHj=SCx!A(&VSW^H0;^sS-5_PfD%((&Sy> z`O1v!oG|WMe@W$tFg)nZmlH--rMEQycV^%P2kPaZ08?2n3;33$=WH0({!A8z3=33X)Glm_r+z!tXx#~^TqCHR~HqzDGKT&LF7*+b}Gv$w={m172 zt7-4iyVRq1;28OP=>7PDqoX&sc1OYL9=)CRrfmKn$H*(PP(T;{i|g&QH|ae-Lw*{1 zKe=eZQOV`p;JW8$l=mSjHy`(ZFDi~yQBgTGQ$B;J zeE9guxyi0k7S5)IW!PowAaI#nZ=lNBHn!c=8?(ebH0`ad%{%WKQe9champighDANR?n6f%?lLlUow@@8FQu^=fyHNJAF=qm?}em zeYU&~Lce?BV$S|;IJektzfDDt?c}%0+j~mCqn9pI^E-rybolkv#|LCrpm2tLre408h>eZG_DxISX`OM45;_ zJhKy7@gB*NzX$Jc<}S`@F>FLmOSf$qUyfd{!_H09+cZ+N1Z2RPp;7KeD49sWHkHv< z&r1-|jw}_?-kvdUz4XH@d0BR#;6e0|Q&EQc>ZqZtJ`iOSw=$fYv@#Dmm3agXvijw7 zbF(vNCQwNAF3+APzXpYVnwOeFYLMelh&p9%g$QF=XLGj0I%mT{3Oza}H~VA9BvOca zq_57C{{w}-ee$fFW>aYh?_3JTt!DOwyM-7)({M}aqw@pJqhKp@KgOMLJ4>kQ`F+{) zt>e(^U7n&0GBT2ZWvE1$QU(>z7qaF4;{yd3zbi!<-0-sua%D~>LuKvAe0eQo{01_b zY+DUu?`YiJcBN`BJ#-oxm~65;=gXT<2o(Gze;T5uG+Sa(WVrOYtOOz@Rj#!aQO**UJe24<>hCoOJcj*lkk73XIc z%X>}=6kJ-ez}r~a6-lCOsyI`#ibm6(vDO`590Xn3Xeu8C06Y^6kY34c zgE`y56XjjY0#%=1D}U=>-ZRiY98;^GL#pRORYxBBIIiudSa}dt&#uMiEpB>5jn+3N z(PMQ)R9&%7UYK^W=1-d{z#qriV+Ax1B3$foz=x>%);jsYG-l7_7JCo9V*koIc|+QA z+R>r9Uf`T5wIamdwN*3|2bWg8cAC65Z3V3qtLi~VR;@u0eg7cTTIlP=(Xj-F+w3aD z-e0Lda_<}($Kdsl=p2jh9L8D(e{0>ZOB_||o&DzfYwUl-%oDG5h^jxHE`R6Jfnvxy zyrgwFD76j;<>7UB=}2_=?t1yDz;bM`Y7gUs^8ZKPm%!IuRQu1|n~gT5NxA|h+@_(V zX&SOGO$)tEZjwv0k((}*$TiDN8=8$QZHgcj5P=5*vbcbPD7fK{xICUfMMOj&C@xRY z2R>9lP*4;esQkZY=FD%)z3EK=KfcfZLi7F2nKNh3oY`l7zZs-MXNUf%++{Z8dN;bO z)*dt@RQi#<@f32k98?HAl?bfaGC8HaiQ?6}22jxWFZ@0>Kry+TfW~6VPGCox=uO}I&BT@4d z@qE3!O{+0~8J}yAUr}lVBe+0e9=3R)L4KQUF;59!49OpBOW^3S`Ka*cko*nXVV)8` z-6;Q}B(!diG$gBpsC%+e9!jTj(7HW1hhR4}$t%+Faw63ZB$(<^zWPg*gIvxkrwC}P zzSkt*uL2>jlMeK6&GJ^QU`vpqqLxV4Kf4}k_r%n&<1J~$h)5r9mS3>KC$h_I0CRc*VfjSAXJN2lys5u7>5{PoZDOE z?@uhG4v=0$p!p1q(DQTFu8p7%SSiu6+mXU8bw`JD)$?*X)9RjYkyox=Yl71lOLrc_ zD!A%F9l@#Z=;`aDPTBOA5c8|lx;tCt-3~EU7k{S`qdGx{81(dRF;C;%jGVJmH~pnm ze&(bTNgI4vJibrQ&r~wPJsNreXZyy&JwsS4w11K;? z0ajpoR)M?6#z*^c<`t$)=(*T|7eiiw*el!R6$MJC!IAxO^kPL;N-c`jGpa$r)9vyT zGXywvV*#WeC4^OE?6uU1r`y*%nN4+&H=8J_~@0!IrP{! zIzf+O(>G6-A6%yrs{|fNOA<&%B!RC8OW-T`?m!7Nrkts}@xf92w#Bh%L>9lcQ~q8n zK^FIfXOy-nw4Z zdAA03?S~Q0Xiztp!YrnrF>m-dDl)YPPzpInY7pq0#!a(0K#mAJekMK8knfO>$Bo!( zFEBn%Dq?Cu5HXq|iWnniiWra};!AhR>x)$8ds1wsE~81tOXnZj3H~n~FJMNz)J==J zdv?l?Zdgz48GW3?t@8t_1gohDN^m=-9S(~=fHr;8BfI1;Hz;-c2FLrR&=l?*$KeB} zeiy7F^46(=0lYAy`-T?C{CUO!;%dj6sWHrVRNnV0CcOO%{~bjW<3L5nlOn27f_;~U zHN`o=QWUeuR*;v|QMBp$-SYBcmulF;<$fn0%L;KdD_AuSri6+WtkRPsg*YE@BF0*R zj8ik!PQF$fgjv-dcdFe@!DA!+x)z8{x1TBRbE~ecO3QLE&tVx?_aj+#`J(w+b<>mG z@_DyH%9gY1a|B!36HQ9}TV~4_-zIN6*;NeKmZ(tqcuRU-ru<9sd`+2+^@qHi7mGK2 zIVvA@>!nRPn_5S(=qOL!6~1K_t$Y3L^6E;}EqGu1vpa^1N_5At3pQRU&v3RIj)7e_ zj)hR2!9a=b6b5iVIdu*LrP^)1INUwW3yP|nIOudZ+U@RXyqkw_Wg+39_0+3H^S(-avb&n9QcBY+xSogpy3$0wi&>RXqfYcE z({@XH(0-)8kUZ6p&2&O|OMr;uVeSU|%!BCwa&|lrPn>vCvU2Xud>xi zJ(F1F86#WL3d*5tBIWFkij*Uwod!p8603YzdQ?7~UUy?mK3k>g;tVUB?(N31ghr+w z%`>D=pcSP9T^*&v?)WGja3$7w)T{9c8B6XRkjt!(MkCwn>qC(UZu+oD_?B&ZE57H6 z;)tU5PH}k8qk(Z*o71t(&ObJ26t)Jh1jm-gD+XaLxYa$J`6{Q%a+@y}HV2wK#b(KH*pmnje=x zE(_x(n3R06aN#Kn{TaCIQQsf4B-Oq_Ce2L}BHbor;jUKPF5}NQF@u8O?oHcKkAOLn zI2JgGL|AADh9lES5Mq&W67$i2he1gN5`+59>7zN9ip=@!qfms^HV}B~brl@~Ozw{3Y5!AxaG$)p3a={mPdJ z;zPBh2O%np5pv_=y2Z7N{TZibhL>yGRJqBTSZx!Vn6Jhr>EHpxTI(hfX`@YQT26#I zo1ggpy5vDqdx!B(f(PFvM2FxjbY4^o!MTWqpcmxw`|=n#T?ez&?kln{{XZ88f1 zvEg_atrX=k2l)`v4j~$C>aN9SEZ&J!HffS^Hj^+DE^IqUvC|w*M6pdfaitzT_%k+T zRv>duMUJ)F1ah`5gFh9ec6z{u$c(RVYcmql&DkKz@YMXX-~{=+=)yyv=Y@oM#zF(PDB&*_lR;w`+&? z>Cq0NV<1$TrDN?=kBF$B9w?d^J>dL>R0VqosG{#pWnFQ*AwMG2+4@n4ea4&Q4;hD! zdD!ri-v|k$`Z%f{AY;s=fQ)^PcAT2I3662?Shbw=nlKI_CM#79o~lz8-M?9^gu(~1 zB{iHvOmE@`7+U@2`za|pJIu%T1AP8=NW9UYp0Z~tHqoKs_CIQV5^ zb8T&TX_5LM?;>65YP4Y&|*!-fI4BclV8bPL{w4H$WjO-*j5YdY`} z)o={LCJ`?V|LDf2xCk^{GSp4owRPv?C_?QYhz*bS$2Jd)j`zhDi0}wx1Yn=x*vRC> zM&w0lZGXiE3@YA$&2W{0Hd)_*G8ws%*jVq>9>N5PF0CplD=Nj6R^XXE<#d4P=95*j z4~&lQv!4(WxzRtkf3QCmaNX-xJUagr1>KjbYNwT+zQBgjIp#rsYz))>x#S!bC9h4C z6)YnJHnhWV?URGUvA8x4YzVtP{kGhmll7f+{wSMB-ME&qJF3f7YYB>d*z<`v9o^84 z0dluG;-kB=xTLrgS-!uryCJq8Z^$V>_~Qr`bNlj4Av&xTEpDaQz9X#e732e`H{&+P zz=j4bM?Y96yEvT~W_RNDy!z%){Wd4vy2laKXLta&8sH1o*jzHAZ+sx2?U>{U*EB&E z*3ekU`bpt-`#f&Hs04qN#qSsET;Z$5E9lA0FGalg`g822i2&vV;t7`0t`L8>vs}ghU6=bf@jjRP1kvMiuMrh4_j-})a<33S zQ8Q9)v25Q-;yRbRTy&*^LmVbVS$Kf)Awtxh*Vs*GP>_EsqbnTBpb7_6 z;V{%v;ow%`fGQlYhQecdw~6H_H|}0nZuplF9fRTuLQIrYJOLr@AvZ2V`W7LEye>NU z6dm{-^2g;#ek7E_r!y`j#3|=12=g#wWcONj7qVNu;dm0JF6`b$2zNWXdl=7Q?4bCJ zo-1sufU-dJLdFo|1ml&ARKAJt>x_>vzRpPXgZzsaw=hN-&t<%Z@%@Z< zFn)vaFr%^4*U1hj6#qep!eHoMCii9`zDkIV3`4(=+*{b*C{%`iNPvEd5Em1oQYiXb z+y65}$3XS-gjfK3f)MF>fsrZjHX8bebsp*>D!FUtnXBq#OaRKTYh3{e3N@_!46o+7t@k%y=Q=b&Pi~KFcUDJ|X^%j4h1)jJGm= zjWHE%5Am;HJehHr@gl}Y7#E-|BK}p3?TnW(-p}|C#?5G}h`)nzknv*1R~Z*!hDm&D z8H0>pWqgS7myCa9%*M=Y*v~k`ILY`P#+w;$ zWBe@RR~R2;e3J2ZjDKW&nQ_61TEEqdCo!JPxP@^i_VX0R(-^Z$HT_sd?9nT}`x(E__!Q&*GVOl> z;|+`$?g$^+s(T1)dHjzsq8O_=#nuV06QUSL2Tu0%0{5CHtgRNS<-_RMRPRX7FphC5 zwrSX+9*#K)^bVENjRTWMA@1O?65FR2J4G?Ajbb@8x)<;M;6){Ui1D8Bv0{#^rx&+g z?l0amJ~}m4Tow%u(|M)Qq295*+rpFkV)Y`-4rR`Aq|H z0t`E?w;_u2m8A!5(R_3`ubFuPz&9f5RG-5HdfZQ zqjIpnG#Vl)PTkB^eUy|Y#lE|BaNoYtq4C`@OEXvIvC*&q?IIVK3U&|E!CzE5bn(Ix zz9`1h`6Lye{S$km)-zo%OmwjoHz)N6%_X`M`T1SVt++`xxWBwLKa$@O$`5XADJ#q0 zwXvnNG(Uo;a3~Zi%@6O)$DzlO9aZ`7jC5_Q-`1d=)o?bqM~8l6HP9hrel<`D zu(O$xkW4;1li<$tIX1g<7=2=R6OBeoE27Q_qkYk`fr^@{%2*#f>9Y4oGsX!?^5Sz* zU2EeEovi8{<-}Tp4a^~Cc$(h4Vx|{HTlu*8Vnz_veAOhNm(HZCtg1~wk0W1A81hTY z-=eWxSGYCdP)-jn-|{h}Yxp>){pv*HUI^)?f4uG89l={Gc*~@5YNT&+5Vx;(yI(cI zcO3l?)iczuzS6<>OOqnlgxOwCtfzNSNV*L?wcfnjBGNLClG$>pZ-rbbkCC)JgPq^{ zvf`3j?1>#KbA7%{kZ>mON|Bp_g++lmqmb!%$dR<^MP5fsU~<2Y`SiXT%}ME3fqyCL zN&hj=@AvRwn<6gXH6FfA;G=)$XXJH*;M8&&ZrW!zKl9iEf_WytLvT=7^D};4d5^;* z8F^1Z-+1!s5P^|RanasTgNfAP=jFRNNj|#qhtg(#CN6I}mcn2U8zx{Pz9+zUsqu91 zdF{6s8Ql>_o|o@y;QM$SzDqcNjaN5H-p`B!XjC}h;j6$N%p}rmeufXr)K(bs`{Y7> zC%c#LEXd0?MBu~VgGhnp6M^MyRTg0a(P82R((f_w1=N%NW8z)yk@ph#vcN*}unc6$ zv(mxxQZj}307c9{BhRuQ^U#<9!u2;fZb->~;!^ji;klveuZ z)h`o!5wEapcw6y$^-ICtLNhV&FOhyN;CncZes_8FTZuJ)qhAqZCep6}eEB9)po!P3 zUkmuIj>G4*-{auBKMvo!J^I}eu=T?-WJ3ME0KO;SZ+?mNyLz<{R~ROs;q&T8dja>x z;oE@#&is8Ge8zqy;7??~=fHPq9C=>*O|D6<{5=T1JL1S&=h2VW;89dn{lGG7Lj5iU zpLx%U#2UMJ_1lX|)`$)Fq_9$@a(j6ccpD- zEUza_#}N1eXxq%s$n&P-icLb?Vwix2&zp{-&FDYMZAQcQEs&i0jg8s*t%F~pa&QQI znYK79-WmFV5C2;~6R%glzk%rmi_1>OWuQ6rd+r>&-3`Fc=;v*BUjpC9Q*D7J-h&{S zXY&2P0WHIDnyeyt_@Y{=LE&@u#%JWdJz}F6!=@+u_ybJ%Zjc@(-9@6jY zP$lPV=2SumG=nvj65n{hOZjW&Uk+YKGK`w zCH_QwPdoT1d?LPA9DFoNG<@E4WV}mYWU1ptmza<*0KQ9^kIJEu=S}Y?!DrHYw1W@L zjw`)iaPU!iGxEIpea)dCy2ONhkASa0>U5wBOUU=ig?4(;l_ccLy2$1u-4p3o;NYV+ zDiPln2cPNB$xbBOSq^rA&)BbM7I|+6-@OP(<)vg6zQC1sI?!ZV`W=I3KmM6t4fsCq zs8}$i`cd9E`F?j5zOJEy!au`D2tKOD>X&yTCOpOgG)qU?6OszxvxH&b@y0P z22pcgQ_ruz{`v(JiMBzCoWo=gDeQaGz9o3WH+fOPq#v&Sr?$Vc zx2KxdOz7Aw{5TxdOTXBHzsP_Y-&LylF_{MQ+E}-F%e}i>2-gau&aG5c%>4KI<*`0r z8p-?r(!N-eqTgF)-~Y7iOYH;7@#}t6zP`ToLY{YY&LWYH_f6A%>HdtAjMR*@jP#6* zjH5CZWGqb2%s|6UZM^xBif@LD0?2Xd;ft?_ihq@f99V;Y!6g@5EV~vg5%&idhVb`( z(6~-6K*7WRNBk<`4b{h>`%4%p-f)G~3B1BC`>Fpo(?PjIzZstp%QU(c8Q+5S?d=&i zH@fHL{9K%RgLCjp8(f7jTq;6$FdNxb#6Zf}(yc`0E#2@fXp# z+qq;v7+2+tgi+ge3sB2LtM>-w3Egt0N`FO~O!fN~XSK1Qwn05jlr2nY2V}Pmt zcM$bF?MPceUTKBeBW(%(Ta_x8r7iKvG}Zn>M{1K(#QEZe8|aBt!E7IwPMAGpZq?5}*qPXzVjMEn`ZvZ0Y;GYzyQvhn3 z@QA?vQ#G~<&SSxP`c7>wRKwe|47Xy$$SxISi9(bZrTD~Ta(vpp(wHqrc zH8s-JP!B4ud7z%db+=^&(u%&TlduM|?knz>=yW|Tf$piCBLM!R>&n$G77RaN)-t=A;_gniPlFW+Z!A4%&uvK>WjSy_2`by-PyRZV3@b#-M; zNj0LlfDDPWkc7%gArDC+P+~x-s;n#r?OlpSsR6B`thS=Is=BPUa!SYxl@FyxMP+45 zX-!2%Rdoeg^787E+RDn(s?thC_8tk@DE=raPV-%AlRZ|v%=U?I%*$nl z;0_S4C74n{ek{${jhaG7>V9H-xRdvD83{Kd;re(j>n~jX2Z2olrZTCNHs%M~BzQsx{Gi>a_4r z$iEQ*g~_J;ohZmPoAM8$pvWkS-JDbKLq1B1B~bNwAiqnIZLx-ap`zQu4gDfTx1+F% zCB<=x4^dFYa{N}&QJuWX$@i%633*g@`@V#wG?ftH`!XI)|EpJYXu{!FZxGCwM|zHr zpmB12_twD?TErL}=^L8rk741=yk4kAJo>CL`aYA_JhGAzVu_gVfhIE+J&-8%OYzL@ zeW??B@kWc8gNGhG(g0Fhk{>ifJY$K-7R@ zz=bQEcW19wdB+6g#=h061kyZ!_AqEIf%bc79&juMw5^eFgl3AEFE(Rbo3G!n({sXB zJ;$j8Ez*iU0PEl=NmPkj!fhcC21n@qI}{iiHV3=VCbJja@H5!w;5a23ZEMGyg_zyZ zpcgkH4o!^3`U-I4QfzW+d<4x*5JUP%sDa`!pG;sTP%t$S>!%SvPI%cF3U2dyABgqr zBX2AvY;Oy;gqzwz4Qgsoj+qGB*unx#CU9r_KCG)zp(b+&3fIApLY;=B=`h6XiMeM; zEypn{j6nz2C?T1gm%C=5!)~1wQze3@5jakK=~% zf^~JE4o>tIluS3O=Xf0F2M+AT_cnoolI=+GMMn9vMlkrz=%J9)b@wa58r1#UfZ{hWHZ$S4>&YRYyyeaGGb^nlZ1l4~} zY!b^LZC#!1E!a+{qhsy!yOmR(LFV66KRPmrFS|60>=2v2>XYYU%8%2z?eO~Ij6PJQQ=dBZ8&RS)x@8T8|D<_gTMup9vZ~Qc%TU1%28tKVpJTA1UZAVz7dK zF-3mb1nr1mm@n*4!LM@ez0V})XMEVnmNb>B&oKR3E`bcS1l zk!?q?&|quN#6H_9?@E`yHELJ_v?^ocn%9`b9kT8_>GCCiEgFTb;VzC-htu03-h$kX zgY$3|myWp`7hcgp(fUUZ^ezmoyU{xiuD-Fpy|n`?m7UZ*`d9f<{CWNqEYe+}_zvN3 zvh7GRBT%#dYkx~d;;nHh76sj{3Tdv#y7%HKnfAyb`CqF^(v}pffqD41Mx{qewB1;6 z4`HBE5^at)h1x=$;d~7T%V9g*!ZKS=yc`cG5Ppb6ck4Q;!Udtlhw0xtu z>F3?U?x0OJnu%b_SwvF}Du7}g{?X1Ty~jmcjFdO9D19!bat4d>33CQHVipRV3-u*O z$gm3bS6gz}k&BzJpt`0S7`@|I)@VUq4;`49r)CJ4{4@u5V8;eK1r6=nx3+|6FQ?jw z@4#+Va>6k#nwX?HN1X}V*b&-QAL_uY!76+%b*vE0Cd7=1SJ>@?(%A@Y%(SfCPQ6QT zymanG8`aXqQzmP

    W+=n*Iohug03g>{}XGA1Ls$fMr|EEsME$SCVfz7e1lC$t$w0Kav0fcBK=$~XREfdi z{cY`3ApUN-IZv^pdy&tmjA-I(@;(2+7_JAKm>3*5s4Q2Ycd6-l^X33MbZXZHPDS3L zs6_2B1H`y-1{qZ7_^2P-in~Ld?dXQ!{2@8fN42%1se^?oK>HEV41xA%9wP!#7{bm2)1Wr1}r9R20(}ZxP z(hzkTUx(N|nD}9&t+yBp3T8Fo+O+}We=v@T$;QPnxa6#!FB5bYmp#a zN1}@W=fkUSfE({Kcm3XVK(&R%4<7k&vu(nwOp1HNw_VQ-m2;y zoJ`&@9KdB4TL@%6luB(Vh9fNvr3C|6p5q~oqgM_L(C*Wav!kZz)At=AI|>Ghx{?lD z6zC!WkJtjr<`8v}9$xBx8ghKkrP)akzULjT4&nQQ?JN_%+ZWiQRE+ttmWDCzR{WhY zuS;$Mrw>w4V`qBba2M7acy6E6c%Os61*82GH59>qQ;N2ewSkplZ$M$$OLQncnh0D< z+o;(cnw<#O&_-%bcFv9B95n%mjgRl`8R^GH!XA+C3z#PRQIS)Uh56P0j`M~;E-Q_$PPeV(X8@6N6UwnMqr;+_+R|;Hk+F|GSmFI zBGHL)UapK3%I;_s_mkabk)u5Y!M-q(=naQ8`9*ry+Mx{eIQy__Z=^#qtDCQ)~Dy8M&xICbA8_^v_mn^Brjnnm4%>GEaYv5JopeQCUMih3aG zUQ3ss_viPGjvXX@T{7e3qmupk4Ea_68WY4VK28Zz(fl++elc~;Ku_<4lYhXmwola( z%@cn0K%aV|uSkE2rx~^K4UcBaT42Y9qE^T6E zJtRRC;~zf974(8Nt#MrMQxgd_Q>4w+o3Z<+H(c#?%uoBUkog%OO*j-EEh{z#Tf;49 zU^VIAy#a*(Zl6EJ{~x%#O+M&r2(@$tqo0T$}s%I$J;Pi^s5PzGSrFcNNUz$P%g zQBLoQtNmcJZ7bw0ew{(v+v4s;kC@%)k20UNBI8E*TFIDU{am_`;e7CauwXsU8X7C$RdHA6pv?;6b z@M~_8kA!`xdKg<{!9E=FSvHM)+!u?D0XhqMiqzZOJ%P=Ef^$&eCu!z{-#Jy~^xUIl zmqR722pZyapb#&2gJQ4$U@d%I00su9kawxbB2&Hdj%-8nk$po&mRwAnD5Za5^}iX{ zR<@ag!1wWensq%6IRH8mk} zZZ5<7N2wk7b{V_iuOnshkUysbS9Ftm5wbzP+rOkkRdc;Nju(>Prm8No)|3BLaI2Xe zwe=$B%R*k~&(;+E#@gLNe$by&_(xx6?#R?|SI-#s*~19wTO)GE@E*b>hVG-%wua=@g_8(Ca? zDO<%&hO$}AFRy~+Kc{Dq%{p;wn_UD!(3fQEGU>~;t`A3EYx|%f7$2Ori=dKuk6*rb zVQS%bGUgz&DTQR_>^aV9rPhL%B!gdbWJ%0PRX5);Kfq4L`Lq6 zTyyU`)ex@P^eS!-HJ;cD8?%k6A{kASzeOaM9zBPGrYfJdl=m`rtASR+A4`)jK=^Ow zBHU5p5(-C8ByvjA<*N{Wc<~%GcT|zY!l}u7Z@RpAG3sB|9E7Xx>j-9{e(U$?^1YD# z^X#nLfq}`E*ofT>4T8`()U!uq>DJPhi^ccO*#6k~M9fL|=ZcOtI$oY8&6@^K#P-ogY+CMmew}MSPnJl%jr*9H(%yK_`w8&FWsuk^nBGK`l{=w-o zyTGX0*OVcD4DCO#B0So)@va_;coxV>{nM`FDPx#FodlslTZMP4;y8y3oYkd%)c z^M5ZXj$Bbmd1ayeIg;|eV`r8oyG2>Ph&q-rm#qV!WpKNJCTq{+Uej)5ifnZ4c{w?Y zvQ_($mvihQyG&ahf@(azl__6D^w%6WTlCk@Ir>)+{WWnTrINUHk-RWFweXTvvqie# z=((nOrOeAoJ33BEm7%}7NM4IbzjgddF8-Z3$Jp+_O+$~@$#qMg;%VtEk5sD}@3h-- zJq$o+&%HoUNmpG#rbXOp6SFX@LXj6a-$62$BE#|*<>h=!D?d(6y*rzVj+UQ*@`q0N zXDUxE>I~(HXeod3Vy*lKq5Pr6%JLrNDZ8IJTHXug9|^=)Uf2As2g^+PP05{+8EJ_! zBYh5;p$1^y%pjtbo{lU^PhQSPGUKF0m7?1h%bz1HpIN;!H-h1t$T=GMCrpWIZ0s_L zfJ`n5okY!{c$Vt1h%ymyU#{M-!<(CCv}t0| zF`xj}k52F~LdA&;>{JDYWtd17S8Us-= zaVx{6Nh|Y!Q<;b0Agf=xI4>t-VH}0j=<>{L`4uSi)BNNVQj;8qLNq9ID?}8_Iy-Y5 z);SXnQs{d}=jD9hsCWv|i1fK^`9DzT-%rfUZ8eRC@UEp`-fC7)cvy%DG)=dZKDs>6 zItpH89>lyeW)}(7JfEK{CnRM~+J^{7JzaqMFrg z@uMQkEnO-Uau=#rn29ZIF-L3BM)Rpp*tDsNwvT6o=h*UFDKQcjVH)KMU8>3z714Kb8;+2va$ zE4oa6A2Iy(O^RUx^Xb@Vyol~wCVz^E{<~<_q^N};yT+1}%l7O^p#`GC0yaNh=3 z4Bi!0ZUl_6JgoqVGrq<3HUd{Hm-il@T6kmetdhA58_Ax!KT|Rl;NLEn4?*%@W|y2e zgQ?}3Az5YYmKE|bNPgmES9wifjeSOGWscmj{Z2P8nGD8@O0|(6S|RVuO)dOh$*fVa zd90|oZdg%~d)BDPUa2ePJ&5YA(pjTods$Jb8sSJ4xo3+?8E|Z+d7jvHY8s}^ZLIOpBE6FQi(Q@4sv(_XRG17Du8 z4LKuInNxX;{2e0u(`=D()|gD!IYY^yK}E8WQTE(=jQmg_weYEmm5Ea}yUlWABeC&4 z2ek#Wa;LF^N{e_raHHhW0L)|1#mCAYAlgG!fyB`!pGMuhX624!L@>syM-+Ogr5l-L zrP7U_R_V@nrf#YUzvNhX;p)`Fo2q9qN%EPkbvxRn8->oYbffaIROv=f%M? z5UFG^n&CJsTCplu2)4faF}%6A5M{Xr>vu$ zV%0q8#Hu|A;vXD=TFZU?I8v5ytkZ5n?Ds46NABIDQ<%KIBDyDI!(-UX;BT!5b&aD& zy?fAne~tGavGT-w9ir|}r^-LNbf6Tn4o_X7o}P~m-`XNSmbw-%SVe;P zpd9JY*`YrwcbN^j-i_|6wFeCeRsZgh*q&AxN;^1>qVAd?UPi~qXQu}n8gQ(tPLBFJ zEoMq(8;&arVq=`_sQ#)>OVs^$Q2ts;!#7-ST-vQ$qSOdRcFoHcFEq$+vn}Q+;fo>pV{Hi> zJvN{0_;X19hV3v<37>A1e^C-zw?`V1RYKG~*(eXCQ#oke9-Kq48=B-5>3BJjY6lWb z^(bHcrOH7rXO&X~v{m10lJ8f6kk?5E`nP6zt5&cjNKsKsr0btu54C$@YS{6Xw62k& z?%`(n1uJ|ayUZrw%CP(<3rK9(*#!I`EFU%+v``WT<0gTqo+JO7P5-qzODcn+bbSov6^E%V& zo^O#?u3c+_(-=#49>XfQ>OmdBsqg6N>!VKD^p_CxtJJzXTjkvjF;*9UrxK$&L5CRh z^lmXvASS#b_-q>UhE+Txm zO+MfXtWrb$pb8A2z!(Ksf$3QV?j9Q-?Z=r{m@=W~Vh3Ifc?DvxY?oIQD4hmJ_Q%nS z6t)E+=756K!S)b-6^jxQkm~bv6;GzCK)fC ze`qK8zjVBS8Szp#E$Z&sDL=YlJ+)`_aSpf652zBXrY0!C?U;5rEcyW2^i7ZKlE2)b z)a@G_@0&tXxN{tb519I0u!_iArv?V_!i?@4S|Ic183%}~9dD+_FyB#m->aDL_AmT* z6iti+6&+8Cs749)9UImZ=KxDl%pzMsUQS2Rrt5dh%ZpvAVGEc0oqQ}S#MP`|)i{_E zDps&cPmUDge87nqYY8$=%~U)2T5S+!ReRj2b~go&jr8kUAU558ro7Lsy0$7U%fUQ{ zWnA5lWYy)1=4;hWPj<`a-3lpN&aTf9Y-vw4DfMreEnj?_yzOLHF<@JwLgnKv>3Ny* zFU9jUWj59y@^W4*-t^_DeAKO%HtB3?9l@fbJat$2mRYp!^|#BbD^<7PeeKWg7%nQ& z9m6izc%?kU*={%ncHKA@LUjfMCAw1>zpO|Rh2 zMf&SX6ZI};RYr|E(VtA)E$u=3k@`aNR6{n?3E?dPB94c-8|*U=raxTn>mJdsRIAoH zFDI5>_e`I>sVct8RwwmLVwGo%Y)LC9hpvf~vpXtMj)-;|9LY(n@?q&w`EYvOjWPLb zm8y#~tZcfs8_No+pYUirPEH1-4I1sI3X-FlqWbZMr@jJ&bEhy6T(7`L+j6^TCNg z;yjxY!IzoaTY{b99X72igs(;$gW(pOh$YTN&rMS+p>8L_r!?x`bbJ%*KOUd1lHXqZ z^NT3{f@{|Af986P6b%*la~@Iv-{HQX;-cr2|HF5mdCyw&o++M^O79Nk<@|&as%%fU zPRZ5cO=rxD0Yx7&pPB<#v#OF^JvS?vPs08y;e|)a#D~q zf5t-Gw26-@5p z$5lk9hvOFtg4{)r99~{?6wV9Pk3s|tts+y1)yA=K;i83^5S_PJskx?FL4GQLtbZas z;Lt(>AEce69+0epEakCo2_il>l2;xJvqz54?ixG0;;=0APi~Sj=W`>t*+f=#9npkZUo0zZ0Ch6b- z#9Hen5^1ANYFbW&I-8&aV(RK939;EGG{IJ<*iKv3Eil=sZVytH$Xjf(R+orDo9GaN zdw;jOJ(LiT>uoX%0kPqD7_AiLF$eh&(heaSZR)PYXDr@{R5odnaW<1M6E18!NU_r# zPDHUyJB4VW2Y<$<%nD@AsmQTbn?TOCW$>q>)J_lBkX)`xsLoO$PS;M#>dqBP5|xVx zJ<>y$rU|iqg(^)uR-!cRT&c?Xt_mf|cT^D=&oB<$2gr|5`b_;u4Bh%sh_@L|it{Yv zC|XR;C_B^0@pkRdK0Vq&bPR+_vvjO|>Jbt3(*s2lqX(S7kg8x00af(9sjMq*J>*A( zI$J*qvCnvu{2}AeF%KJl@*5$6R3Asx17wVu6p*pc(T-CyH^DKk9jlg;UK7S4#AKza z!Bch0qWd?Cl~DLVwxotri0MuI07I+ad_N^cZ-@E#zQCCk{pFSYWpAUa!W3b{1}xA_ z4)zQMHf$IfjpCR9Z0`+?;($x+H%?(o4hQStOnl|Jhu%=2x88<(#>VKp)QN+`y`w`D z@a-S$fpcnX3>FD+7ks;Vk*>cfVSpONP3szXojxo1n#`2(*77HayxN+dMEj z-WOXS!Xpq7fO&>vBa;&wkridt8Dbl zmIM8p;u<)xA*{di=C7o0jLBW@YZ@O1o=oE)>nDZV?en<(q6qvo7QbHvT;Z$53+TnnFGalg`cv$t zNdV>p;%6>5zRKrc3i?#PzOq44a1R6AXgT?({n0Y>Py44Er@BeVuWp9dBy2t*JeqX= z1%Q6spm>Kzzf&A;;giDc_K6yYzaJ7Futj2&?H6}A+)^wM*SXva#d$7wrs#LM7l{^^ z`)E<&axWIgxZGLdZy3axAC?Wo|2W*)NZ;4shAEXLbC8}ZU2dOV?5wm@{ z;u@DbPwaHL3&n9R_j2*yc9BQ=)`}Zl?lQ64UG8JVe^Tc1FWYy#c(2R7TAj*e z`>zu;RyDtD-!kzd;{ay+P88R>+(qItxG4zL@f?)zNr!(Pba9A-&x@~9_CXDCA0f)Z zw;8`nh`RH??EX7rE2AqM%Ag7dRN*kpQsLlM;eaX}ko59lYPX5yC^zn7S8n*15FG>J z3PMbhR6GG8zDaIegmjp2rH2kaMF&1W{tqKMj{hJ;p)m9>lY6reUnQ)x=@*iF z3)>ro%kUo(pr0bd#e`K%Uu*k+hUgfrex4976g)u)Jzrp?ibL)!#?u%-%=jXsu^+Vy z#Q!};y4#N2HH=e?-)H<4<7%{5#8<|6knwWH?=$|2@q8qZ_@#W=wDPR6?#f5`YaV-ET?3YX8giSb;?DdgVB*uvP)cq`-A7*o*(5&sItlNpB@FJgRzaRJ&S;$Ows&UhK){fz%$ z+>ADh_&XQ}882phm2nYfnZ&o2G06B;#)lYx$@o{sY|K6>+*OP}VSI|QFI)Sc!}t=T zFGthg&3FUjGmNh?wxX>f`DZbHk?{e>RZF#hDdT$>Z(@9vu@G%F$r)vQlyM`b_e8&m z@vn>>Xd8+CX~tz}%gKF+@fpT?wBbZQpYaQf&oUm5ww(O0WBdVQ3Hk`4pUwC%;}eXF zS84x3#vg&F2-rb zcQRhW_)PR4IDKF;`S#%CG-#F(0|^*f$% z4dZ&oa>ho+vl#mshZrXr-@|w_<86$eW&8@`gN#oy{*LjFj4v}TI8p1jn(-vYlNq-# z?qqx$V~lY><9iveW4w*=ZpOom4>A6b@i&YM3bh`cjPGOo9^=CG+P|LhBE~;3rWI-b zT*mc`n;Ew;b~0Ydcr)Yuj6Y`lHRDT+z71M_7GncrH{&GZyBM!!{3zpNjK62hD%SE= zGZr&$VQgdUX1t2=6O8vTKFs(l#^)HX6$90U_8Y5KE_)ZKgWoDc-1bR!gv~E zcB!Tx%ZPn?#dkmB_ZgpJ++U{sFJQcZ5yKtfLtCZh2emv8Kp0VsRh?q%l-CJSjN=0* zdwPL;%@fvFi`5!pbZn}3q-PjMIThP9Y*P=%oCJE0%IU_T$)gZ=a9D}$(<`2$nAS(J zCK}y~_kZxRl0L|I&-hp|$JNt|n=khl?-?JR8Y?b~28Zd)(&$j{*xqg7$$hc>vM3Qs zN*p1bORjwgQ!_;j(Wa`3iowB(vqNXcqWZEAPZ+(eiU0@pR#Jeerm6DQ!C2qvLnYB& z>Wp4T0E>BKoPQ+!U1%vp@2%mMO?p4J!c+pGI9{7k`l$q zZXe``0A~crH#&_AD*J;?qxnq(aRLla3{GHyaCi)>&*Q~=5p2(X6|85^)b5_}xd;2Z zDiQ^Qx%&E4m{1E{oDhw5oHkb0wxe>ezcd;mDNfzYZGDuKCdIzHb#ULl(xLI)F-tR7 z-m%fJ2<;*lmkM?d)7f8CICSa4D!wSj>iHy(AHp0erM?Pn*5H=P^2b5gp1QqomvKa^Yc4#>q%^4GCvvKTAE-~|MiQ+O%b=!oz6F89 z&Z`utuy(5FPr1_6?(j}*Yl41`H$RKWF*dZ+o;KMp&u`lrIqtNy8wcJ@)- znM3=lL%*^5=a4bK`lkfgxlBn&CYzmE=F0Lpwz+c{cVc7{jYdn$qmKBZebKU>+WyMk zo@)5fP4AIr3=xuJ#iydW#>N>lSyeg8DYb?fm^;kyH2rwROfL+x@^S0Mj3BDzs!2dE zok>^uRGWYvN4}aUGeMT5AmaBIRboE}xa<%37pxN$BU)``ZukkL*5c-y->f)`fs zf=T1lNZ;fjE?(_+y=8(gIQk)}XQ*F&pMx)#CPlCbbG)8dPw$|Rxp+*iH*d9ww9KPq zwp{94Ay>*{ByGxI-?zT3xTF?4V#mr{pDz<6oCds7^2H(|j_`LRe4t)2=;k($Q-xmV5epr4?Xuo^G_XPaS4`S5MtKTiFg}A~n0S%v5 zzoI-L?v2B@9RZyA`yBX;{Yt=3WtskY%irI?cWE4XUi~g!lU(`x8TjsqBd@@t-^Iu@ z6lqmIu)La3zYl=#3F?UWXYAtDZyJ@X!!Q92pVxj5f{$*CGe5&;wHsX4^U-lN8Bd42 zm+|bh^H8O2XDq8HOvicP3!rT?KO@?kj+-_Kaf@LB8a{72Hf=`#QEoFDzHfo#)bG%k zt=~HMQPSz3w;WszzD&@~&&ZphANYn06VUK^^~*R%h?nBa2a}iJ?^3OxL0$)2^reDay z^Dg|u_PzC+Jfz>(q4wUSfzs8Ce@?!SAF|U+$su0i^UAved?lchJQ_0Dqv~n+yy;j9zLoGN{m^wLPLCwhQDDg>;>Qsu zeyNmBlm>CSXcJq$G1hc1{$<@M3bP)`Y`Jyo;-87ag}=Nk_ebgSk>*2}t?JB50bY9O zsN*|xUwt&|?y;r}qUOG)o?n0c^$Ya-z$7z8&Sf@;6!yJoUlP3GYrLq0&=2>1@3^d@>)|($G`DVx{fE=eDzW92m_*a?8fi?ISTynw1 zvTMN-aer`O2!9_0O}9_Ue}DUi>SfUVL5vh{xMErB=gR^)%%D0RINZ8gNi#)?rxb z3*@xVMN!A3d>FLdy+ixz@ujjNTwoKTQG5sgJvA`iO;Vy!oQUvy9A{t!!4k5_c}g^b zqJAy-i}@#Rr)K^WUAj^hzrg9JJOb@$Fvjh zApJ+B9Rp1Dzk{gfX-C=$@=7bz9%)PP->Ou(ENzKTQX5RFQoEcY&KEb_Ku|P z2x&BeXNA-;5S@^+i|FPTz{6VnlcLj*R^lOFkxn-xl8)CPom>tQ#f6tNaWc7_SN3r7=2yQ-CJ}6^fS$L!%>m+?27&aVF45WA#Rl zKxIi)Nktj1+@_S`EQe56w7z3I?t;dLZn(_5gj2{~jqr-JH+IoimpbVQJv?8m1@Ofh zBH=IAC@dcBZ`ND{*H>#UAM3j{9XZkgDXaooIM`7iiH7OwT|~Q$MNICU8t!#I zTc)FnwoM7wxA#Uusx~k;XgCQm*wPXWMk1lkE}I-~4TH5Mv?J8Q7NkPc*rCMXV>}u= z(0q$3Iabop*8CCZYW$TCHA1utf?W|h2*N%&!dHxso%Q$d#7KNtN)^lTkLHDlLN1Kr zK3dxAjqVKynW;9{>RZBFT_wMyv{uL^Q8Eg$HA)o;w;{--Oo`S#2oYX$dQsUWYhBk@_H2betopgdr5DN&`oH zbea1x`0kVGiGq>_Q;EW_isJ6%wkG-)P%Q%e5ps=cupl_v5UOv91cdLzXp~IT77?<@ zJi=%b;HinWhT8%gO3P}5oP--MeklT`22~(UfrMg0q=I*rOji%+AC%t@A6&;lK33|S zEX+9o)`L2p;I2Sv8QR2iIU2Yr7Es>7v4B!mT2Wn5Q(jd8@_8Hu$aWO9Wo6~%)nz5+ zRW+3r)zy_XCDn-H0x~4hLJ}$~aUroJ0wo5Ns>;f8(B7qJlp4?~%4#cWtE$UtE2o6K zQ29`5R8&@`l-5*KR8?1?B`>cosjaLmttzcVWbcuXjpC1@;xyl-HrZpv%WR+c#=P8S zNYbWP+97nZm1*B=Q#tKy;j3&9Hh|O6SKGdp5wz{=3*y`RT4gcI2FC2yImm9~U+?gV zmjyRC{4E`hlo2;7y&J83aF##h(@mB)=ZDAt!|>QBw&KzAxj^^uKydhbA0; z^(FyEEbe)q=NJhZC)amx9UP&F|KLd9&{Tg6i)ZE)Lp9<_OQU%jeV@te1X;-lu|&-G zRFfHN9!Qk>dCv*+%<{3KWDi18WQH}*>D${gE>e8y7QrkI*c6)Yq-5A`TTlnQYN9y5 z_HrR>0^~x0fb)Yw)+#5;0i3rAxluWh{cwIt$httslnHy6kf&&;4*VS%1OSF4j~Y1ihYS~|8nsg|Z4 zIxf1hQ7H;jY_~~TBxpNqnx*DWn`UXbizBh*!8m6+Xj&kM-43Fq;@ccVOT)8NG?<}s zPQ^466Ci3pG2qe_&bzZ$tGr_Za%10WRRU=qKzkXqmO%SHG!Hly1KQR|I6^Z;%om$6 zuFcnP+UYrAtDfUjf);5-AAsd>lq9OeE#bBh2!kW^9v%t|4V!~qXp`BCZuuGPb8wsz zjkdMp1w+j4XwZvW5r-zmVtoa;btyJEH9mr7CWs+@B-B9hm~SR96DXLPi1pKmA1A%+ z3?gY?Ojpo{*TeX&RE>xxKy%5;!WnAB}U^g?tGOU0ZtxJVr*x zgnSLoosD5Q4-5)2)c6 zD2CHp$H#HYc)_|lPzNV^3reON)pIW!!0OpIHi|rEnvhqd z(3EXAJo|>u)%{F^D*JW#JENb`OUd}FHfH#Uq4?V}Qa)(+EqtD(H=uhr=S}NU-jrqZ zx_?MHg6h8~Hi>1Bwyw_h7Hosl@v-(9-pVP@AoK63A03&*r(K#wc8E=1^~rNF<;Mx# zc6fbxMjx}r4_NmnpS*+`9*Q~K5y8^uEYT_ktw)Eb`>bES&jbw~DX3zwfdP zpBr5|I>W8O$hIR`Xt1?sVxMi5ccshU8Z|5dT9vVJ&1+2J4q5k|bor9M7LCHza2Lm^ z!|Cl1Z$a+H;d!`@OUK-eORv;f{%8kOOQ7C~p?8jH?akFU*0;BIV5PE?x<~&iUy47^ zpMpiYD-_=${7tqUNoE9U_JHlL$w<64F2$mtyH$aw&|}?u@x)`@S=%FrJccp52dzO`a0^sYXNMuh zOa|Oq1b@{TZjIv~paH|oP)h8kO@Y#??dt;PkybNeCc%gl>z8JWfcspGGH7=|jc!V| z3;#K)1nKt`{c1-D`RJbWB+cb$7BdEpaUW}(2jP+xL{469&&wIzogxw!cXs%xr&(L0W2jTYqf(7~B`YKDNxPjhewc5JXy z(9phpYfFgsa;lB^4(wJXCmiFViAkDs)S0l29id(Ip$^O%titC~#|qJGLd=+Wh21_V zosH1OOv~Es)Vl=7OXps+Q7v6OWwMqV3fHZr>5q{3cC0zfzNLZnfdVfJct$9z5=t14 zV&x5I-kXh;UrJMLgnY_+Mm>E74%{Cf?ZxNwlY=895Q}ermCf6mLeU-A7(@#_Ff`gT ziOb1wCVsdr+=USW;(ysK%%C8DGJAnhuvp)c;BxxF0}AV6AnP3`DCN z>(w~}WRJf|l^7i0-_}kA;_sH5^AtO}7x|3Jh$g-!-}4WQ;fk<{iNS$`%5nvImzth8 zZw|0Sr*>W7ROBs+O4JTBK#Ut_kU@oxkNUB#xI5I@j&2CfACeP&R9icmI#{Rzv>y@8 z5NLnqF(R;aLV<#EkbbOq$Q-m=^pav|X>ZzE5-8Z<+SdAu<)w@lD4DKN_9~&+U-l19 z;Iw00?2~*tO$b*i4N<4@b%@=Ai62JVdW*53U{({ZT^lg|2jiHSY)t*XvU1<>SVaM% zDGC%ET(>T;774Ls&gIz95u@Zn|8+wNR8L7}mc_3TnmWo8d zkcw-O3VdQYm#hW5CttMyNV^fza6a|KKf@ND9JNX;YLzJnN#v*%4BFqu+W*tCv(GAp zt5GPaJ(x{%4>uJ4JS+Sr*CSnvbWXD90Y`N*t(J?y_J>|yhh8H+ssot4Qk!;Bv3m-Y z7657Yku==#PE`!+f~FOiwV^d3yfTd#i2W|aPC+h?1&a0mGYTx7Wa^g0bF*mg+S&*snmvIIMUKkS}=g+IUeFTdgZ_X?LG}TJ8GIf zecutXqhO$@E9t;Rfi4p8h%KOO4pA5B;ic}UA;f#orn8y5uHs`ZNVKcBXx-U0846xqVXOeGdK>jP_I1Pz3u;DcVlvHPspO z0L4cWflFx{HM>Kz6X6=#NX^O4xlx>>CIGSV@x47G{n$v@BXWL()YjeNlUK=;O!J`! z4Ff_VL_WktqptfTZ-kZV9`(soH#bR}v`uceP}*>thLWa9 znms9Lp=p*jG-*PTE|lmc%S{`aty$WX52dnHL}Zaog-;X(7sL%jMPw<6$o7GvARvOG zvWS9$^aK6)KWFC5yXD?A3FuFM{|n9Y&dix}&YW4_nR#cTMmXS?pRprQS2Q92uhaCQ zr4h&{Wd5dKUT;%VM`oHomk^y8=LO41p==9>aYxy8xR&JyH1TK&b+B;>&xAq4;n-YW zj+3|8T+kXC-J@Ib^8xui7r9GVJ52_wSu|F4jCFk`fSm`HuDY3>NDxvv7SYMPGG6}3 z8}$f6IVR>FA2u;fgXFTXTU}A{R=j-76JY{LqT<>F`4`{O>ds5hU5es2t~8-Ei;DXb z(B;_X-pz+jRRx#P&^%DEYhpsmj z*P5qpL90B*_Tn9fqg$+kxwMIu^^gRShky7iSI`D)n&Y^_r(Pt~n<6c)UW?T~z2Iuk zV}8|#iOd^)^unR&Xj-whvZ1d26wD_5z#BpMZ}<7*{6EA6Zt{L#bxnP1W%%Tx0=(dj zp+`sO_Y>n;P=fap?A&_*n>VUyyE10x;iJb6MYTdcoRnbu0ocZ6xzOsE8>u*k<9VGtW`*;rTGinl~uxDhHK@jrJG;8Q6kC@3`q zzwq&L6V0f5S*!+!Cwwdv3#&BWMybmmQ|B6D7T`&5s7huzLVk^OHf_PKTOAK^)|ck5 zFU70*?|f>Bx0o^ji-s+A4b@l#rXA(9S6rrJKg>1zS zF@EefA&s@QEj3n*>~T?SDfhFK(qh9uI}0|U-3K9$LjMEOrcE2yw`O4{d_fNW6w;p} zBn5+Miba-Op+Z-LFj0;HD$-;8b;+y6k7mz35eiiV&CL~u==E3^34Baz(7JxQ8ra;T zX>h^`p(q-Vbc(lvMwZWz2G|3zrz~r4e$L*4oV|rPd&gN|FH#;O{lv?g{=Ef?ygaJ8 zXqfL-cCR*8LFqVpV=50l^n*5q#U6T1P5hCtZDf69kxm~ZmvHCbGPZ!Wm897+_=}XCQ_C*V~q}r;I)O=e-voiQ-;^Dly{LbdB7iR!ZqFGo`r0X=lSP0 zscNoQ$FU&^ZmQ}cWhI4Q47Yl-qqbfIZx-@$f2#J;JJxO&^3(oc_Md&p>HVX9t?h$Y zXRkv{-!hRthZg|(uL|mErOQDqQ?ioVA36=XhBe;!D1lLG; zTVf#lkbeS}hukd5Ni1KC#uC>b2QQZLUhup!ZUUYQd@eP~Njwin<5`4nB7ZC8BjEY+ zL_AM-^CTznOq1i2PPb(T%Y5=l@cdaIh0F>2?Zk1`D(jpEjh6cK!GYnCmR&vFoYlT% z$y)J_9?UX#g*)4ayTV=F1~TUUr9 zueE*95DfK<*+o$Cywfi)N(yBEIB^O*H^dRoj9|9T+;M#IF;x)P#DMGcbxnJc>Z-NJXNN~;7Pf4XPmqVJYSv}Os~Wp>@TVkQHcP0@}*azsM1rM|Bjh> zz)^eYsK8X$O9H-S@#&ieb$D|6rXKw?JAG4^eoE0|2Yb3~o2zu-1KfkN1KH0eWh$A6 zEt&Kbr)1JoqW{}TsFV(wUx7?Wf=mieQ!?pkv64wop=dHGogWRz%OUfp$y#O_+7XdX z>7*wulb#a&HzdQ$A#+K*kxAiNCOv7H^b}2|DqHUagmR=U?V4)xz@IKj$p?u_rtSAhI&%1 zXeSg254Csoj1}4iM%BIziSp;r{!?@R-L&`UUF^|2Fhjluy&s+T{^-rU-TPp5kKRsu zQ!)SH40%BcD(HfLbG@DRCcQ^z$}d9ipDmpCzLawA@ZY<=(+Bz^9s9ZBsWy~5ny5uy zHDkF+@=he>vq$~sCB=~|Dk+DPCl`$`O?Hd2U>0>OgDzW#;Frkl2AZs$BfCty zkt|ZtwPyr_vr<+2kr7-p%P!MahoBmddy?hr5P#{>6N$fK%Hj`0{H0NaQb}AtOP-w? z$UeAuBB3*9Pc_YHG9ws2J4#BGp}#vzUIwA}EJ@?y-;5KD?f%;|^w>_WTlzRpOK$}P ztY*B~ZpZa70G&Pe0+oup>I#xA&-J!v3f`(v?L<%sqJTjMzm&HP0Uk%6E>!sCW4!Wss4P4J<=t!h|xYdOjbN2Nwmh&pB?A zGPvVs8RSZwNQNrfHFM>qknsv+)Z4Zi#NN?}yYHH;z4WWoK<{{yePyov?9qYjUt~=| z)P!b>E{ZHSZ=U=LMBTk&3Zf>oUQ|)afM?Bk8+q>^CJ&<$tsp zAJj8F)nU)gs2L_KDPVFCT~An5xtHh38x{w$FJI}J`SA+n6d9q80%3FS#9eHVP}pjh zZum%sTp;gS63D(fZ$i#oh7D&=-5<}H3h?h2$Opjr&51e3 z&R}Y}#&K2|yKbR;9Gst9Z)K!Z>S8rt6%cWYC~uvcf2Pt~*M8CKSkip*Sse$|km1dZa%xv~$0< zU`qNJW>9Goj|Xm)JQ{#`3_53#d<0?-l!ju9oqQT~^O}-Agb~3Y&mK|id6sTumNcas zJuTLq?|9u*6Mk@!JbP&%`Jf>To%Z_ef1P|ik`nm)+weoD)*Wf%gdn61IJHMo9H?EUbLb7 zdTz1&9JG0|Vv5>CTSZKtM1IA#4d!h7m&luz1uAY_BVY9|@9gav46D`80X1@=rXv$$ z9M|?!tUQQ{r`O=~7B@YTM(Z2n=&?E?DlS+nKN5GW=1-d{z#qrlV+Ax5B3$foz=x=~ zZLR!x9J6O~i@k?lv4453yfSV%?dVWLFK|wjS`p&!+A5le!%Qpwbb`D+ZUwCrtL8x` zR;@u0eNR8sTHx!#k+Ot?&2|%F@2}J!xwj3B;^pVKq+J$Uer1ql3IsD^2j>8I2|4CStq{`SdI-=EtUA79O=;6 zp+72jnGLz#hVH7N9SsRp|F-_f&ITAtJ2;J^;?hcNM#slzCs$Ti<5*Rl9QAihjOWTW z98wm(_`ebeOe zl`44!@i-ZYnkI`^tK{`sjp_6FdbRwHQlqkE`?PHFTDANU+hUp=zEvZCt}TJ1$EK4V zf31?Wf!&htNn~FojmX_+tDj_PKuayT9s2ntGshmQzD>ujs6RP)|wdiJAoR^(2A3V7E(7l26+VC=FBPaNkMt zWz7M(9K(p-4nb7>{UrG}j@2^xST}BxXD3pL+TJ?8RTwYil}+-(MB3)s&`@6q)uI(8 zU8Fq5Awn4EhI;wRvDwrC(l!KopP>ik3JP$^`MUE)OWOZc2cKo`b)5RHc)X(gS_3r#_Hm4QEXHv=wO4M-pvN5 zzh?wb53G5!LEd=Wv7`+?EFRje-_KMs>e@AQ08aM}*0uLyu8f~MA|vg%kno|+@;+B& zl^W^?Rb&7~#wfswOwTHE+u+bZ7tXxGD-(Jyc3@-3VX*x~qr5On>D1G|H;P`YNSf5F zSUsZ}7`)ghzch}4LpNqX`cXnyMaB+GooKp!ze&EWS!3wFTjxGyx|Kq=R=B8A8E+3T zP2!_h8t2es=fE&MiZyqfEI++MB~~#!l9t4fj7SU*3ya}le0QK28dHwf-GtzXe%s=h zG$M;%)+}GqN|41pDI<|c6-kU*4q~P3nihFMwv~;Z)DctIpO{81AMa!8Dn8RHU&>Y$ z*1hS)uDXk|b=7r^rm5zt*YGy|4&J8s*R<_dZ{%(JVd6B|=Gqoo0v0+B{4fWvpRN_9OYQ)ae2;O&8-ghV>?EXdg)|}xXpz_C) z@>HV)`;HCk6=xrFQN$uuK}N7CXU!EmNtY3~4 z;(Wm22x|#%oSLat^0nIVm{9E@r`l~4J<{K$Yk^pE!>RIax9ZxeG%W}79FkFWKay1! z%$lxM*F4`QUv(>_Y&o$$N3f;+qDiU$r`huL56J6RxrzbX5)~>FyQHUO$~W_-Ysys2 zKV$@7&s%eISU%>~OPh2ewT@uX0e*E?_)oKF#k;4;OG;F?;NA9TcMRv`>yBYNY@8-f zakd+dfn6Jpg;1SAcfRfvx^Ztgbq?JH+HGwdZX4qXMb%C0cRC#HcH0>C=HXjeaM*7> zb!b){7$m{J1Kl_QI&cguQ-g^K8NsviD{k$OKP^!mjW&!fxJ8XuE5_pWX^-}-2@WlL36O-l=I`mnt4 zE!&m`e9sfc5k-y7;w(F)zGm|VoWrF3KWzK!!_n(-ZAoj@M)4s#0H^ujL?Cgd?bCuU zGq==NHjDqV{aS1A)o5*HT|G|35@(?2rdKPWZYRR0H0u6zd=u+mf=^c|3?pTHUvnD% zf@;F=f2Mqm6pa=5dmhq2pO5%QB@chB^X>lQ?hI4P$Jr-+(^jE4&q?AL!6%4J+n#Qn zl1s&^IrxNQDW3hf6motYZi0!+6iG=ZB>59@38cP1W^TZ~K_=eqh5J}-j}+YDirZ!A z${C7+J2`Df6(R;DQOtCDl1Gy9Fcis74A_! z6O(Y`CO)c=^XXw;7H+~>jKKNoVHPgINkWjm8)spX&<|TdPZ+mA0pY z3GV-0?+#E*;9X^VGZT1LFM-htP#%NGhZ^k=qSp4^KIfD<+mOl)+RHdM5;GI8&UTPu zCpnxDu}M3HsHX>i;+o`QWX_4mu?E|NoSWw(oQhH-Jzzm{fhwUoONBUDJ1MK17b;Fv zE?Vf39$K}Z5L*_i(zG=VrD?ELyzAM1G;?_fc zM6A>GqY%4IF!Ap-4lTLQ&{J4HF{Ju9pdP?u(4>Hjy+=DvOkM-WkajFyKza=uhY%wr zss@i%D2wi0E7G9wzEnvKC$8*X!w)dD`c3y!Qgn8BAKx81wYaOOq^s})bXA!0$j!wB z%}7ssZzwmne;|xw0|dgER3};7;11K)c@h+6M>eywu_SeH{b6 z!wBu_X@_%ka1aN-46j|ix~L#W{V6Ri#;Fgvor9xmaa{UHWGojK;^pRc!`(8_JwmtO z<>q4KIXF79magf*CaS&&n2kU#4*zJwr?`mJm*3k)-8KAr=_|y%0mRzd9qAkBimdG( z80w776m|XJ5rTdCBK;%7$0ILri&b$h1{LqYX1K~go2;{2nT*^>Y@}m!Ct-|47nJ4~ z<`m#cE6_}waymeC?JAY*eFHy0Cy!^ZZWcl8bw(7`U?2uDo2*(jD=2qtMOmtjJ zEN-RPvb9d#E64{>uf=VSq1K7HM|)c{|x zMy8SxokQIrZO2KDa7`0rVL6S3te+Hax6kADixSY6Tl9Xh!WF+v97a!OesSXUcmK$4 zdJ(`ofq2g4#+Uj0OGLlw*Vi^EAKb+NH(F2r>2S2p{L|qH#;I--@~d0owHFqk5FgDt z|3W}NZc)71qhF1~EqqeA-9B-mBis)T58Es;()Np+9d0RRimP4jByo<*oh){{+_OZB z%RO6ExZHC@$mLEEewRB{yo`aJ`K2O#cfbu(DoX~Do=>{mKC#_N?<*AxT<&7=q-|1> z>dO~bx!gyK7MJ@NG2i80CZ4vl2=P~nYhCVzqSNI*PUN}V#o`}!mMi%`ak-BcpLDs8 z5$!JbGEwYuuM`27d!hJ+dLz{qOZ6QmE_b<$#8#Jkm6-2xFA|UGgCZ1zRA0Kd%;nAy zr?}kNVu{PWKs;|3d8BW-xW?r!6sNk}d19f{RUDf^&?I7EoDa3A9Xgs403 zu$#`HpzsDpS3HzK6%VN5VW_3z!L8x}RXiZ+<-_aU8s?+ixRYJE5uQ)}7!(&1;zdcx z2?=p0xp5iNJ%niP?xm_&$E&KDA9;Ej>p%h{dHZneYlIJ~;B zdlMntjqGk`+{1VdV-v|W`YyEfJDdDZ6yhKu=BG@0ZY4Lawz-Y4NT_@zIlm=0@GZvq z#2@Z_Mx)OTcJF39$an?g4UBg)Qn@2O&ojQmI1^=p{IeNr7>5}@!ARwt=)TYRIODsF zR8J^8hjATanDGq8OBt_X{2JqJjE5MFoxV?YK;ifyAqs`@znR=?h4?NZ7Br0i+2mfw z_D10{{s#p7PY~iHpIb`-yyag_04#%CFqqP-%zLdN}!7cf4|_$=dxkU*mU4dY)KPfXDMO^nwt-o*I7 zj5AT^D1IwrH{*vHZ)f}|<1>sw^kWn+lW`5>8H|@OKEU`4;~R{HXj>@$M#i%lFK7H3 z>i}5u$~Y5k645VaY-Icxh!=?=n8X_$$W0F{a`Tl;T~?_zT7t7&}vS_#VbL7=1zQ ze;(tNj4v_1&Dempiuiw!@mq}dF)p5`!wVQc%6JXq+l<+0tBKD5<714+;}xI$uVMTf zV-wm&^8YI1e6;1{KEU`AV-?zP^8XOyHyK}MT!OZo!Y^lhgfSm|1o@xN_z>fBjB^(2 z@NCA@7)Kbt!1yOd>Kln)0pppBmoVPRD38%}s~Bq;n;Ca7_As8ucr)VzjK5%fmhn}_ z&iEGNyNoGIwcHZM3dSnNR>m>L4>KNQ zyo&L5#zTw`Fh0%r4@Q56mY2l1nDIo$8pa034>BHLJji$v8SiEMIpc2_-(d9RYW^vV)r@V7Ba9zmyo~YljE^(E!kCh$`7LG4V_e6$ znX!%WV#Y5q-pTk7Q2Jd{2qWfA`i1VdDcm%y{R}U>?hA@4)Ssd-HY<4U7)v6^1MO=-kq9Z^z)SO?4x?BbkL^^2pD3#B@!& zb|O;eC{ctrZP|2EdFdH-h4rOjedC8Gl3rRxgnhe8D8lH5(V~W)NaxAD`Qh#Apk7A= zi@1M?n1!1POE+#9E8V`QFcK~!c}|tgfsEi?zK_DfCw0~}?-<=W(y|{%lah~<+&;|_ z5l*S3(C`>;sqCuUFp#;SJ4%GU;htg45cUmX3VJAS7ozRltD?2<9Np1gcgFs%*5X*v zV6Vh`bLtLD?nJfD!DH{~|j)tDyy9;`Uc0?@AT$#s4 z!$h>pJFh^nyN?b4qtc;^7pC$>9;VPosQBz1-W9f<>6&5k7wd6@Qdgz9Om{dlvvp$w zZj`OuThx%*lG#*~S$TYYVPWR>KS<(W;*H7(_tHMl(u^{Kw6BQvuZSD!?NM=~>Ev)-N# z*DSZAY;ZzMJ;~H%B@-r_Okr_bCDW80iawdbGcI};=Be{`spv5?Y+SwLJb7=b+vS*~ zPo^Myl-GAc+U1(qOr~H*Wy9s1cuc0Cdw5W*V&~&zT8JnNtks}S(qc005;LLJbh;&h z<4&s>sJM2rr%-%V%xM<@9oy5YO)>W!Jf@fRiovw=-HJW+OgB{?Wn?lneo{@cUBjo; zbJ;lvWhPUDy;T;`CR1Zwx4$CJWNN6LHHa{o8c7lC+(4u$)IjQ?rdtC!?zC#4iaV_u zsAAgrN3~}%8OSY;j{V+hpo7QsYM^3ZXEP;XGWqOGf;-Qr*z8VW^oik3I2A@|mZSE~6_@1K+tlE3K)Ym%rj%h?xZou1Kd!)UiM@YIA zJWyr!xQO`V88TJQ^DUHV@+e8mGgtwxD$L7YjkU2wGTrA(h8NBTP7~>Im{=5eXB094 z4?#(bUlcT30w?$Tf={on(K{*qit#T_J?TH@`6>?`mMNmrUFxA*13LO=euiHgJe*pN z!A;N1T*ZfSFm)|o8m<+!cpl>vO6%b%}lPp>rsy0F$VP3j(CrL*) z|4`b@&&cwoV;&6lkRbxbqI(W>7n(o^o!5T7$mpgh{JeCxgYJt_=niuJnxNBA^8RQX zK%>Gw4_!UhU`CK;^D}gqrncfx*j-8bZgwx-2f;7ZcmiJl9asuXp9oB6tFj0ah$bT! zNWVXVE~K9HA0v0EhhK6s*2zFZ{4fn<@w3vw{1$`mQzV#whM#3Wrn?1e4XuU-Xz}0_3F16YYQ8RfPaS0t6vxB9*Uyh ztsedIG3Rge%K=Zy3;O4^-#XA`vP=Ra*Q;L_=q`yu=hg2G(A^t_?mUlv-wWCLVHz@~ ze)og!IfR>EEd9Q`6!pyz0S%p3zv2v(=_qttJ^H-?I%B_l(8sc0+%h4~kHXJuzY9S( znez7>=)M+(-wKa@7b4S8q*eXEG;2)#J_kCp--_58yLk1ZIoKv5;Gd!M+V4@&(amw@ zXXvbUgUfnOG4?^5KoFb9!+3VqBW#zx6Y6z531DqxTIMLPPg4 zcsTWo8?xKo5W3pU{09hEo3&#T{)4*eERK=&HxvZPK2 zy0Do1($2Bdi>@RlUA}{kbdROqMh6|WQL*SwbI_Uooa{uro#kK*bjE%;6Yx6#y1NjO z@{P)2EV=7GVW$^OrbTxYp8fb|e%nF!4M)X-Db~#4kYUL}?Hwi_K!)ZG#)`!oQSTM0U!f$@SN*pYx>1PWsi1V}6z( zAKiG`j3vz}alrFWODt$kfBUhN+XpwuyPMPhuAZrmqDbk^L_iM z;5}dIMJ0rOxC1oGOb8Bw>kPMd7nYY7v={NL2_2w?pNXj2RKHjUFJ!{FZ!Fb2GMNYO zwvjfo2fzPcZH$>I`u!7a{6ChBshvQ1e%Fsm*x9*K z$TMdLXQ5Y0kO{s7e_~u>ATd5MAu%y=M&iuGq=e)|G~m?Mn;$9pe(=ZwAEzF^=z1vm zi;Zv~701fCXPqlsXU-M(Rwh;B@BQ%Ox;Ybt5C0$eD~0z|FDu=j#z^s=E2fpgGwpUJ z@E@8M-D03Td%r7=3t&AI2SPk8PW-!17Q{RI0o^2+s6Bh>)+&*57`2K@e&xX{eMC4R1Yj6Vhs z(mx~qC}6<khqc_=q1S~J`_ht z0}wnbq)wIm2`Q_{-~6zzQP8xeM3>7yVnyCkG)M6w#?+EHLW#-~fxLqF2euS}UPB!c z;9{Xo6iPZt`xR4SPQ1FZwI&=6Wz|Jg8btPRv%wnqJ3Lh ztE=FPE1p539Q+9ud9KDFWp%v@s;S;!kj5Up^iVGTcJTa+D{jSwXd!O+^8!qn7=M-{KErMDaYg_3HOP%zX0iG|@LijQbLio!xii=14 z+ccMl>+3XEi1mG%7LIg)3u}T#!hW)B&iYk0S8WWJwuB9_)0AxKW_xSRX7xQ_bIpdj7Tl+cjNG!hl@+dRs%i<>(KWjeyNOwh>>BOsa6Vh6qf50- z3D-CEw$!NFz|`==sfU&I_2J5vmYU{P+qdZ~n-n{IbVp+YdY__t zFVw94?}4sXUWHJDLu(vZ^Poc?>{B9qdHAqdfBQ~^M2D$Tu>k+*y$>Q}QW$s7(sFKi zS4hZYwRl!lU$@>>^79K;3pqDTMnSfQsUqR#138a`UmCrA_P}&P>7W}Ckaz_ zgLJ=^Q@K4

    4413>E`7NrBIQu@v|e78I8imlu^5!~0AY0dHHx>Oy>>T~?T1R9aqA zTvk?6o?iwLXOSV17UED+g3E^`c~D~DQ(96|1iz0cKS~Y!iVIg4uP!YsTwO9M2O zQlms!nNm<*TwGdKjF!BpEPr)LNkM5r350!Af;Wmkii*>G=iA;MD}KxliEhjbY=TMJ z^b>Xroor>=i)>#`J6rf-JAe(~H1s8QsAU9g`>L$y_P$J6%(8(o`{fRAxACuVghb1N zD;?pM4oAv}tCilhRz5h(AM)uME12`c6aL>;c=TNPtQ9`VO!>SOfs3M}Fkfedv0Q6B z)YcaA`<6d+WPhA4E$>n?R0ISNcddz#_fZT~Qf_vvrq-CQ5EIq(v01xDRiXn7j}RB0XDff3 zx$!?o`P(9_Vo5R%`XGWbmgQSTM|JWlCqJs<$D~o&?fW)n%v3^z?`Axj{#Vc0G^w#k zHU5r!XY?EwLF44Aw)H*zG)d9Z-`P9b6~W|~*+!^FJo;=g`VN!lG*TwR#9}es15C!v zX&^c37boNS&82f!`_Q=4!7yWF4?^N(qV=A`)b`n8!@IEIW&Er_qD^5lYQm7MJdCqy zFA%akL@pEvI6p1qYUM;Zfb%*bk5^7)Kb&6?vLe(pYU181)6SZ5%#uo!IsE=p7dIO|&0XRQcz4TS!S zd^>kVx<-2=IH`4L2sesnt*C%+&u~Xp{#dPgjz;mJ(7s*xt|pX~zXd7&ESOdwnQ7OQ zn0|$rHXKpYuD+>g`W-OEmQ$n<-_Z#9D{?kAlM}b5%Rj)mep6FxmYU_Hyu+7P?YjpD zkjLyN_}0!6M+@=TXFKMCTdd)hA9*1+cY%LiR0LCby?@`CMt>eCeSci^LCuP zm8MC^W{Q!v*T}$NV>d-qv4l3;M2sr#3dlo7qlP1B)X?73A6=b;@$wO)j^g4_$BM=3 zSZ;5kDt;U>cL=VsD8H=14==SH39PNN`vDT{oyhNd)R8`*_p{*b3f z(*U;_r)yjD!b_0LJTHtfvwp;MaoOfA^;q31C%~LRoLWfps~zw#wR`Pyat(s{nvSxP z>-v{f`tV1@P4c~#jDXVczU3Rqrk{6tx``Iq=uHH#oH_KWp|oBBq-9XruSH9YlsB*_ zeHNy229xnIa|StLCJLMr_4!B0uwo8ZOLAC|i<+abUgNg_U1PQ*DHN!FonLeF+ZS6(8=vSMno0{lpNHZ-0{;w``~h zZ^gnOTIlZHf%XwxM27S4>o(W5VuS$sZ&@VuAW`!mT?3;Xy%8_rVa%uLc(GXhuf*Z{ zA#?=RTvvW~xU9BH9VbBc_`6hz!D0QI8>vA2!*X+;Vnz2HpHUfNqHFS?zk3kZfejD$ zbnjP|%hIdV^t^U$h#fk$D?%qCZ&6gjcARb^Jbs)ve4*oGek?2QsA+CQHw5QT$%#H{ zb0eBMSg06&KO;ZmLF+S*lLuR;CX`hKub(R#G6$^|y`c!|8#k=a4`t=LmbKorf|T(> z`D5kEUil>bEq~82PBz9RK9f(UiQ!76@ziO27i@Rp#SbHGy~LQ6HK7TYFAtgU{ZULz zHm3exS-G=sus921aza`ASF8vvM}lzuh%N$@JNaXUmh*TkTGte!!7d+*vl4*Q8QOdQ z6{*lCb|71(mWo)>kc!KY3VcF2m8=E1Cto!KaJw4Za2ECOzrq%t9JNX;YLzJnlgLpk z8nnNjwf~o8XQx#Pm!eQodoYpa9%?B34OaMlu1C5S>6~QN-Hz&HS}hlW9S*&|554-^ zRR=I}r8e!NBKH(3%>dl)CT_UTovIk-1x+h3VMA+TczGH&VEYrW9R*(;{}bu@R}@$} zw1$3Md2Q#!*>2ORmdkP?3D*Z`ZK9)RWb%gL2rj$WOu+Mj0JWhQj?`BdWOZYDj)ypo zUOCiFt53boj+$Pd9(KfR%IeN(opj`!P%ANb)MijP1<^Trc&Yno@bUdI-cEw>z3Ol^ z3E!V=XQA-jFw-8TV$6@ZG>mcAth$c{}DC_}zX|<9&|)PZ;gTsiBC7 zON`TY!V7@fk2>x>K+(~Q!1=U{n%bnv$>UO5NDZb2uNHgM3qWLOXjglG7ZwtBir~+X z+KSKlL^XC$x6XU#087Y));V|wayAB_R{D3ANEujuJF5#IlXgD03 z%gb@{7MlxNL!*0iOMX5ezvm)%32UdxU^R=zs*bU)&jhgZz|vJWvl9tID#s!^nODZk zA9+~dP0rfHB|7Iv#ED&C5hk9i_YAW2kQn;`$_vr-R&L2PWo=g+&)!HG*9?d0e$L;z7~A~PvdIkpWx}OjUhyH`-zhsUaCeNaC?Za zJKT=q+%4XW9v~{9m=U5%?&)q1@p-3Pb;{l1nQ?w%0UA%u$0{Zpyk24-`OsCS;#%|6 zEoha;*j~KjaCD1RFqby5vL2G4HdfO&@U$bF<~XkKsTT?Lrbvsc*JAZgFSy$Cm|yi_ zBJ)Ncy>KWxnpUi>Y^bY01+z&%@J0~++kO5x{||9lo4nswT~ps$89uqF055oB=+V*n z{ls_{l;HgYJNF*I=8bCFu8f&^_~@}iQLT^<`I_oNMR^6q1tqHsOR>wZe0AAsl$W3R zX!Da+rnM6D9bwuv6Dq+eEAnwi7{rEKHrCa);w=#uYlI3&{Lh^P1to@{pwtlj!pF-^ zG^6fiu^Jqn@Uc)VtkQfNr7nL=9bbr9fG547Dw*X7`8Cqnv<16vbv(pbUz)$Z6tCvL z^Qk4?V#)w48n)CmRAUjCc9hdzakU<7mTiUnoL^_qmd#PuqWjHi^yit*nvro$u(bE? zYu`W2^Dy)({v%6p7B2i5QtQ%gRkE|`4O53A!hKc*T3>5vHPP^H>P!F@vK2qX__5!F zG}hL()L1dH$3?NF+|N=zrnuVS41v&UrNPmiu6bz;* z7FlwI3SAMxL^%eiNRRQ?C9f7gnmzYKC{z(NH&+~@*JE8I@G-4H>-y*s9cO{PNO_F(6EAQ2_ZBGf@~GybVZK}0 zz1mm>rQ_(0sXX-1584zKd+0Sa@kheGUDk)CvC2*y=2DS-SDyJe=rxmA_N12Qpj7Cu$Iw|X$#Ap zys+Dpu*pf{L@E7atA9sSTiKRc=`xj*r)`2mQB7d;$ejd_`^KltW)L&JBOe|st8d&E z)?Y8|z~-IC&0*Y2TGNbn@|RJ9w%4^Hym+#=V|3k+QTIYjjuyuPwy>qd?Q1GQ5VRyo;2{ z1O8wWZg(U1EM$W`&p)?GRdc;Mjtxn0Q&kr!D=GY9xYe5-we=!+vyhkjQ?-xYv39$V zpY{i{|LjXn?;q`JZ6CxsdmUo>mWlL1>_ZsA(0xGqmc^wHRt-dOo4a-<;)BLt3Z-m! z&k*`esNCNf3GXQr!8KCemKexB;VaUSUz~rEC>78Oml6zq}Zn|C*3UHfzQ$ zZFUiahrSeBmq}l`bzL~}TH6N=!BEebT?7@+JN@#aq(JtM6Q{s)LmctU2xjZd9mf|R zQw4D)?x(@`+8I;et8zQKt|}XM$H^~%=U=D7Q)Oxlo|Id6#>tz&^W~Yr^h(^f{-P=o zl?b3GUwS2qDm}&d@0f`P9Hf_y3QTpqB;Z>XpT22OhbO0R>d{ZL(>HbLrxY!Au&2wm zxk?8s z%|f-?N?&ZFyqbDI*OF7@xb(3WY%En%WaLgvH}||#4dI$iTXEZ|@x)r#plwVgWFTJt z9zxEaJ%xg%DxbEL_wseCfmX~PkC(53`R}H}+)?6UGDlA&f&~fkZ7@GHX9}7-sz_|+ z)Z|^1AkUqH`j;{V=BoQTf?25FdL=<#1l~`jrlfawkJLx{?PjP49<{ygJ4K3aEq&>j zd~c5IjSLM(oc{jw!Pb2}U0uDXN!-YLp7 z=(2SPeu>;}pvl@fvdgp^$s!e9dqyxgD^;~08No%f>@sb22&(b8Ct1D@@s}Pwk@zd7 zEdDUWUm8^?mBjV4Boe})hjA#nci1d%C^0!dv2gfF-H<(64 zc;`~^-fCt~cvy%RXnNgJ`sngN^C;NL+=KVdh+QO9^ZcQpeCH^PdY4a91{oRIz%o=O zOelk@=kq~%a8V%poZ}`bgFAkfL9WD!WT>KDGgn>;8LvP_y=|*O>>Z7``>x5_OTRh| z^o}>#SLVvk9v#U3Mb;EVO=!00qR4Xd=E<)>)ZHtlAZkMEMHQtCc-B053q*Z8+co2( zdn$Xru5iA}epBL9{zsefK|Rw`9roOenqk6{0wxF1^@LTGdwHI`VR0b)@|CWcAFohO zkrC=B5H|Nt+_?q`g{^k^R>=y_mk&e2-`*z)!+4*L3`7%j_k8&T1pPW^!lbB)AiKtr zlgswRNudd%>;>|9NVq%KCBZwR%8h_AmZud!amKf}-bUcU1@f*Xf$XdECgjXz*l_mL z{qdZs0RMi0d;px^oS1X$45pTA9A}lW>lVt#!TGsWuJRhg8oQ0s${gu~d!25cGUKcOf#k0pxhh9!#J6N(~x1=8f55Or(8greA9mMB#t9H}DrM52@d z2h-#O5cR1-B`W&#e6);7?;F)a12fgsM~mB-#rf$pdFwHO?DLA|c{?k+A&FK@ z6=&*J(P`Q<)_UN}Z*09zVJdS=DJDXX!>}NmIJf(_-EEj@L~!;RhGVvzG?4uPK|rB$Lll`iFR}36sjY=?fVTm z$_*-w_6lY#hK`s`qwh%7aE=T!x z&fcEEuv+~bP$L&=Ix;cFacw`v%7dtQdJR5ranmDdw7xNp9;+jw;)1pEBXP%S{qv9ZNXaY&RkH{!0Ckd)vS$US1E2wvkBR zAl5SYTk9TOoMP7WB(&&o_MW8RQ%;c`Dd37ltR|wMXkdjsdYFckF3Ls)6wCc zb@B^=<=9}=Qi%`Bkq(_5`lE7}*^ujP=&l;t(U4H}Z|jfjY=EJ(gVQJ~F0I67bbNev za%FXOxk-*n)R-90m2EhrEQp11vZMN|IxSK0>q_|>#SPzZy?1Wct(R{Y-ROLBZR;s0 zCn|owUY-|^`liX_D^>Ce;&Cz(HBA<;R>|wN8q??T^=kPYrAB4T_G#JTwQBhz zw#76#e5*$OTw4N1k4+~#{#qk{$99+|hp*PkHx-A5EiKiPRYFueUn>tJP&sJWQaOca zS8k9OCSY?S)ea<>>QScpOO=CM&MK!o&{jRTL0+XIA+IML>Ej#aby~stN)kmak*@pF9Pt?gfm_cmAPQ>7mI{A>%pq`S@6Ez9s>q!E6 z!ETqFB%ih!P#UJn;l7jP%bEjnIffCv9fGL%`$_U|9IIvWv2NTX&rYNgwY_zGt1w>3 zE1TqniL}kNp`pGKszobGx=4A9LxeES4fXPsW3#CPq-_ZFK0_n)%;56nE$9Q%BwBV` zDBMzabZHXPdCl<^uhz>?EMIP-(-=#49(^jh>OmdRsqbj-?4(ZF^p{}sY@p(n26?-K zjn&29qS&ZT(7^^hy_?O8I5#7BdSK0)4f4k0jwNmIVe!yz{eGsBQP-}a18}-;u&%uq zb7lP85gBR6g@X@mmiM_LtJF|Gs3HR>GDZPbWO`PS+XjaQx^U(dUYXEyu>%`J4ukC{ z8s&vqN~fOwy;1aHMbe~Z#p)T=z~IG3`K56T9J(O|A+`%Us~%^E}Z z-8%Ov)2$S`wZb)&%6NN#X%Zj3(m016I|qj8QLMS+Wcle8DzS>;k+dX+WJF?kSXc}X zh-v z{=_tD`FI~wSMixv`BJv3u!t*fqUG)*;Ey@t2xcknj7zou=!dLwV!4-==! zHs@9w8n03#(Prbi4dju2Q$NXQ*=&P2sj796n&`ch+L^UO(F1jSVxpZ>R^)rxN!ORU>w$M)1C) z^1ee6VfQb>x8@8F0hK?Vl&2ac*q3QouQ>adiy{`O3NnICIcu)iAuq^tsfHz7?sqaV ztq@hSti?khim6!EV*PTY5a$C9M_5aE5 zmZ(sf*d;wJQ@)uuT~nrF{vjjydfu9w!}2k=UfQG+sdWU44)CkH!hf1YE8aa#UQ(jE z1@E>$yJI*fUv~`KVdFG;inHBt4D8x)EQIO|y7P6X(2aY^sdMNq&~9tvaN8J9D5`E^ zztiDpx7)_BHxJ*+g2R66sYA2sz#s|!9q7gh(1BxMnHo$?$OxX5UvX=P{Ar2mXuN5% zyPDDhO4DK7&qIG*X`(4LoRv-Yc6DJ)BU6v&8Pdnliqe6uj?!Uwe3TBjVrx9$)%cjixp#HT z`PN6HEnBLpYFb)w(}(4SZ`rmq;Cr4hjwotu7H8QZ^);I};2b9H|6$u-AC6v!YfD?blj^uSRPt>*{eLmN)}FH@#X3fp;l^PifTs z==dhqzXYGI!YMFP#`iU+;V-Br{QhUkS4PoTfxqV=4fOel&*91aJN{iR2JBm7;@w`jW7YOZ z!M&`wQHHLWp(wa#({@xLVo(yrOs6M#BpDAwk?iykVwQ0d@oeJ|Vvc#Vd8gQ3M4Y-@ zP>Oud}_i zy5w1DdpellPT%$J0L28}Rkk-XfoJs+7_9*1F^GJq(GDSMZQt#4PMNa}sobEwjB_I~ zGx6$d2Pt-v!wC_av{Q(BdhjQ%NiIg_oQNE2usz7Rc|O9aC^gap79kg?5~{OQh?BLG zvbuSp;zZ@5g&yglRr?9CWuYofThmaQwxy}EzP(s+^3BKr;VH&}`vLh8N}sA9iJ(nC z3h@C$NisiZ9658y8D?iZIZo3K9n!8H3O_*C zgDH>PTujQ0^tAVea&!9!!Z;cLOM1NnIMfnrjH6hF!(lo&2VVv5q+JQL)2*+4aFEVO z9p2y9G0;1V(5{|#I7bHuaoEf7+SRLz3Ubt+($Zp_^pM**IJy=`q>n_#a&ZY>Zf-Z+ zEd$*nbn{(qE=HS!qa$nSY7T6i>WhHc2;}0xk2ZXMi%5O>y=~M*!>^at8uJDaYj1a? zZ=fr(wtHZxGcr@u^@B$U_UViCj|?A=yeKG$6z5_f@g8i3>kG8WI=hw0$c@BCI!1RA z#z=HQX?|f&0j{wE&BQ6ELqpfDQpw&oFtpo#LQLdFSI^#_u1Lsrms{Sz^ix#nzCcww zt@Lz;atEfE2VIdtyy{OS=cp)oZKAAT86lM02*Wjw^z=od+BlS3=la~+a(lk_cKY*& z*yPoQs~FqDx?DBnquAGZJ`1Pg8r1jU>R6AqlDz!90%SQp8n2G*#jZH(+wq2cbJOy8 zCOWPq7B^9B*;=RW668at*Ww1pP;NDSgHAPq9<0+`oK6g_n{i`a)yA5tO-_I7?nYFf zzHZ!PfUi~~Q^|gIRt zg+(XCN3+hq5YUgC6L0qDSL1LCpA>GlPn_ro_k+X3HcO1O{o-baTZ)y6uaCjMZo1=D1M>dLbb(GeaDH*UG5^W)#Y9#=DXaB#AEtpQZY#N zrHjj4?hJ8?%bhKjxZDfG^LCL(`j(4pT<$_~s>_`x7P{O=iAO1O`IqWjA})5hmx^YW zdxfC)2J=hx%@>aw2QbxlthmzU&JiDjo1#!152AdJIKnfai-R3PUVoRe4{C@*geVL5 zF+MD&nlZ(wxALm5=@fGQq_S}GpgDjrb91C~>Kyxy&0KFW=I)|DIK`Q(p5 zaWNrYl$4y15O@FZY4sTiPUeE4Yc5i3g#n{CBl|Bn?z0M~86NNZPh`A`E@2%vVC=AB`W^%6;;=6=cyfFS} zlY1T88->dF9}w_AL5On+Q7M%Fay$G+^2b2+8-$qjdX5n3d5w`O47pPnPh$LU#@88* z{jO%aJjh6Q*-`v*#!<$H8J}fbigt?V3K{n^UcmS;b0 zVDtsG|9Om8GQPz4He&12jV3+=jE^xMzd-w6 z!}vGGCbW%2|5e8MXv4{Ufbk{9Dzx3?{~^Y2GQP~X1Z_BlU(WalV?O!@@;{yNA;#wz z=PcIY*^H+#jxc_K@lTA@ClbE`#xof&VZ4)39;4}2G1f9RGwxvQVLXrVX2u5?f5G@H z;Oxh0Ghj8%-SjAM)+ zW<1Dv731xUhZrAVe46nejQ$KQFNtw6$jBgIL1|s>ln8& zet!F#>*M6XS|*95aR=kKV|$KFFm86RX!TB*aU7|&t+6Jvai4o_!X z$+(tr6Js;u`Ha^x-plxN#@{f$!RX7?{8JdK8QT~~7(c>z8RO>}A7^}pF(ps)TgsTn zxQ=l%V;keej9+5Blkp+OXBq#&re!|>o}M}K=Cj&91c{je>cdw3%0WmH7ix2uFAjBXe$YUqh{p4^)s-mVVi zbwsd;`-g~GxT&yokKsnjuF4GqnH##JMCcpt8OF?D-yo)*hw^qI+RnWyTKmq?9qn~z?C)wV zjuj2|>g-f;YU=5xgm9$kq`|_?TT6Pn3c@wS#i^UQo{y5UL6Prh=-Iuypm%6T#L~=_ zd2BRHK)by23Ix0R=&&y;9lCg73SZ=5>U@NX&)(r(Ve6T$6efSM9=9cRRho-)hch!< zH#Xq**vh>{4Vf*OO*NU7$JZAYW^O;ezMvqp1y6M~H8lm9b=xv=&~eMw(##LHv~H@} zRIQz5aBi&6Y^2kaYcgxrSC(fs*PL9Q+0U%meGn;YENo05=GZQxJ z?dfpMZac~bC&bi~OkGwoVY0~-7PnP0P1&L7lPNsoqIY3_I&YVX9y7zn)jQ6U_oljC zj!F7t3bIFeegC6fu8GZL3U*XBT+WHdWD2^62em48K2D~Eh{C{H1?nU%Ceto46KYMT zTM{_#w2Fa>YbSdO#aG3gb^*|_J+0albKk*ZdRea+OgrDL*i+ARQ{_=cCR5`l)g;?B zd`dl+or6$jGBwy+Wf5&MHP&_0E8SSUS7~%gh0CBy=5cD36rG7C!)I6Mj1L;)j7c$2yuZq-)iL~|@K-MknFU4vq_JFUT|>;FoE}{M)5nmm;p3Fnt7DCO z!K97;@v?VY3wEtwmr3ntf9FUKZd`41Z#BWU8(m=4-rJ?V%)vKHBcgHx-uBuf?HxTr z(hcB&Dzmpm#3#>?sdAogp-huUNm>TN%5PO+UjAyVi7k@pK3_7ta1L;qNRPwBqQE<& zkO_DQN?P=yAX+Gzfst+Sh-d8~(rd8V)fa8O+HGhtqS&mdqj{9b^*(fCzBfZCT-b z9o_OnX)`|~%bSjQFxW$e2pEg*Ina@9%+EY}?ROe7y2%g$W6^yRbYF}@caZbf1ht~% zJ!u>ce)~LhIaq@kL7L6a$i+0Zr2~b1E=k|R?xp)6_@x?8;Ju&&OM&SVf$3~j7GVO> zWaI+r_Ymkp>Pi1Ga+iAe{SkC2AR&I32D12B>0o|;2i>PgF#ilc%g#)9Io29l4H3}L zS^3L!FM=*Pid|ks1ZR5Rz}kb+ZzcFqTIruxzc{Q#9A@4Kw&Z&C`#aViHWC5 zWK8{Nt>HO@n_n#b&R;6Tg@y=d=)C&P%MjwOD0Evr`aKRhW50aR$FkoGpgTVbKd=3I zmrbtx-37X@Md7!?qaV%1qo}I-foay5`W*nB*=I#;ja|I@orX%*LBwA*{-ekyG<5gC%cBv$N!m(+_m`-})K3Uj5zx(F+!posN&e z&#B*&d+c^MgfOF@x7~dXbYBeE42|6V@G{R7dhR~W!%&*6CY_yh=Y#G{6X*!rg=a1T zibdR+C|96sgv;~`DR|zFe=`(?{?mFu@7JOB-lTz=b!roxbmtzh(@V)ATB7svyAX8w z@F#vWmNIl+ez${;;u9SeFGE*`XQ$kI57^~^=ws16?x3UivFKiK(9tN-(0SAG2I$fd zPWqv%i%FOK5#0_E9hF1F&zs)ML1)rC+d+qB$Cch|9CTFP3_q`aUj&`e4_#tRy4yjQ zC3QN`g~gZncaF`E+NfA`ISxA0pOc-ucBuxPv0u&v{OUn> z7YYF72bIHEa+5z{>xU-OqB{!De*81POwfJ9QL$i3^`pFT(*5jWd|g8Yg@1;Q5Ojma zfA-aQ;V}-Np<7j4m|q^Ue+9+mC98|`%gReap?u}7|6+}!w6ru7DlRH20^oPr%(H6h zYw@X>#Z`(di!XVOU88~mlunce(TrAM-ED&#?!v#r-bH;sVsotH*M0n?ow3!|7ZRn6(vyVC_1F8u6@AAt< zK3_ce{r_!e%v;g#pJwO(vFuE3$h-LY)s*2%AVT{E2aifyDU4gv7+e z8HqC!lM<2>(YQOuBc$T{!6VC~hcBugTK;0tnqLzhD(9YYZs5GQgZ_{DE}~ZAe*EJ) zIuivD|4;bkf?eR>L;b9De=#HJ4#5pQBO6CM=rfSqVSK~1uYD-Ocl4IzRkt+tNA|Vp z&p+U3YZ@9jJ<>TcOynkUzzgm6Ch(t|7Rn|1@h8P6Ug(!6#;d7Y+xWU6FqA!mEjSG& z<#e&Z!Ch3sJHeVe9|JEl_1)|XD!0H49-(<>=({!42SU%{UdPGkM#44TKoks zcbhkvkIC)iqO8%6+PW8jenD<1@8+qqoIejj(>c{50G?!Ky`tf4Y6H@LNW{zdxq;d7 z^8$YVuLLed^IvxsJOchdi1@kjbNwHVpF1yp?xOhW__=XD|9Nrb8AynqADFRFJ^VlN z-UL3*s_GxVcP5jhZQ3T&EtC?cX((w(%1rh&Ep(DhlA+niByEA{m}Sz2W*M@yDT0*6 zf`|gLxWEgFf}$__s)!p36a_^bEr4dJdxJRZnzO!Nf;p+IRcRFw~A@iD$oqLZ95>M1=OC*T4& z0S6%@TrtI`c?OP{83@}cIGc}g4o(V3JP=4}f+Avm88%n?g*)q;M(`DGv_v=bab{iM)5wnLug|p+=V+Z;?3cf#vSdQ4fa6V zSIW2X(_Rfw%+({Zvn$dj&K-6}nxZkh)r*AeZtGGChdb(H@hCmv3$fc2i^<(nBYoCy z!*ujux6a}672sGzlm%`k3sR=5j5xQ_~G zKK@hXftf>8!cPG@n-bv(`{VWo{Kq;AT`*zZNa5LtL)7w|Jy8ntQiQ^sSwkG-?5VZpRVSJsaw7@vt5UFp81(@f=c$`er7Gu0v zf5K=Jps9|xM%w}1_?NLwnqI5YbvO<$#ntt{MOdb_35r%Z1{n zsRjKbLb4EG58zf4Oo<>*aovBTs?ZXYKyD!p!r$c91cDuN}}1J)u8nCm5)D@h^M_)OOS4W#!}0;dQcV zb-bP$E&ONvZ-hW*GBJNA3{uU+{DUyaG6G{(=M?;ahoWLI6m1^R7YVe9fLC=K zci~>acy)kW$PjRTi18ZXL_UD?R>n68Cz2n|I~cDGbWG{6cQbyfbjrXFF@BnK%h0&P zZ>x06;4d&97Tj=qDqdC8@|!F;LyKk$($FPpK^hvJE=5>)La$aU($KEWiZyg>w_*)V zJESan{!u6jQ*@gs$r8BjCeBcEhlw+^+^K{Z{9v53EjY;#$Q}#QQ1Pu6q@m&4gcyuc zRZ1l!kwSpgpdi2lE-LNLSu4^`A&?q-){0C>;{aM8!IlX|Ye_T?Sd9*CYb+Y0(IUo- z&FI$_$lZH#T-YkdITgUgTG0kzE*&|E3UN!cEds>QDDCY-hM{hAxC?c%@}d`mhWafO zr^e%L?bx-55gv7V@xtQpL^9D|h!>m^lT+iPsAj_G(#IkVBu5{|z(}BQY9cW}J$~FC zvm+AT=Jei|=-or!m`>h+m zj;P5nMC_2FV})b< z$}}3XodwVS;qzoWLoJM#)#5Kogxh>18WpjqW6n#uEa`Agd*4*sqUPb90qwz#S(9>1 z=H6@n!TBhP|E|O&rb61fI@>WLDCU#R`@n^hW1e_Cv8#S;bP}h=Bnj_eo4@4Y=V8c? z+rG{4@*$3XMd}`~_Rk)EkSZRM9PNl*N9 zugS4w`yd4rp=e$n_MVMV?R`FeNNd!31dUpIheqAiIhf8L)9MH=7IlnJN*%-Pj8yGI z>HKM}OGjt4H5}V^1Pcwd_D<|Et#VNY|Fu@bU?5dVj!Rl?5_`znhcfuf-WpU2bx}-! z3p2}bqDHV>P%TrS2bc2UX)j6Gg9o(4y8x&ML`@*}+0ZU#+CO1y8|&L!J1|?>NzJ2o zjVH~U?@hx*-Iapw0RGOk9+^uIRIeYK=hTS3(J#fspuJY1R$caW@59$z>LUy1f3GS@ zT9T~=q&d)aB0ij>?#85h1Ra%NygA+!X^V75>yZ-qo;1Fd`Y%D%htVqttznvQ3sg{J zhc3lT0=$3(f6*A$x%daD!!R?HV7qy9AXM4CA#grvHA6BnhEU93>SY4e=AxHDD+Ho< z6YOT*b43o4dyl+WFFNLV2%V~U|44A-Zui_{$pbP2p)Yukus8m&v{dbx$@SkZ=g2aA zBD7zR|Fma`%J2$Qwv*#@M<>m5qw1x8uIoH^E_vZ}F4EQLno^f-ayPCNM4BE?9o$ab z-fheapMX?W^TOye%TG)fSG9GwV1=ui0OkzR)SBv>8rM<`WKycK{z(x({F(E(RBLob7n#0?%YJ-)6hW75dmI$rq zRB84dSh1QLbM%WQCTYx3tHU;SM0VCkIxuQ5GM`NyBSfnK#^@uNPK+ z#&xk_{FlZz%IOPm;4S)iA5P{^4vi8+Ouqe&UQ3IaDJbhXrtQNQPsgh<-q-ba2i4DGfxsiStk-G zECcE(K||)C)uNXLK}&m6T`*8sVq4aF#qbiw3k0XDg}s6#{Z;SK1a48rBSCYIrw(C@ zrAEp)z5%woFz`c9TP`sc7S3wI_3H!Lf4_@~$;QVQgyP073ekED;j{=3$?Bn1-Tp6n)_sJRR$qHvp!)+YLf zCg*M#6~JZ}lL>e}?4vpq-I11tP~jk^=TsNR(kcfAY4vH?+ECN*=}}9_j>5s>t~m!T z4s;QN$4v&M^AKGuyO*+^1|QGw(#ibe1yD?F-FbD*F7iyUxq%@E5&b z`yAukCIKv48fg#ZPRuu`vHhIZu~hJXLT^7!bVab|*{OAhxw1@$jqoNxJ%worXci5uyO> z;&I#ClsCf0wNH5XwaySKz%{M`4tV*8%>dLC&C35XG<|4j1oBy#zvAV$nbg#f>FUoW zL`KH?STkbCd*X4tcXlfdqsoYU7zt`=YgTCtY&8ugjh}|WHfI`=ihP$J%Ugb5_6A_>X5oZvRT-! zE~|Ytoj>6SFpDHsdrJoYv*&p6ekSOyLH3)Gn~Qnf!CUb%VWq6IS{`%akY;OH@zz z)dPCO7oAZ35x!=W%HIR&ER6vKv*Xwq7L+Ja2kZ#;8H?MJod?+~?jEcbifJJt=h6mv z3xa*r>K2XiAbVy8j;%!HDT5i=q{)e5`v^l%rLtS}*C3-+9&LN}y2UZbPJy|kiG}qL z1xEX|anzRu@t@{6uJ?$6gcvE(;_59}{gVr><~-)7JebJ*w1);9f{vyY8^f*9mNPM% z^fhMy=Do+`P4j*okHPV8dm17wUE%l{Wg!gkrqQCK@%xTOhAJ>V!Op#hv3a9`wk%_2 z9vInoC~IW=5l=@nP_{8t9;&D*t;8YAz=6-Pgw~<6`CMasR@4QQOiveG%Y6BLJjVP0T&HOI)&RnJTSG$^vy7_ix_ex`hDreAZQ#t6NAG9egchE~};*W@Z zzG?(ZW8r>WAX++&blj6jBmp`LdyBAF=h0QzdZE?JN8tFtm`4bnfozX7% z{H!X9t&;6+EoWk`H$~`YXQL5p&~)A;+Q_T%7cHlKj3m#28T&7!)498X&LD0}3=PNe zBo!J@`tP_75#oLhxqSoRx;89(6lci_oyaxX?Q@OOEab%19_kvrDzVf;g0f6*U2S$U&VBVD~otg}ZE(zA}`C9w}- z5?%K(?pc?Xm#iO4;I(+^%)|@YKVd@I!J%=qn^1YQKM_B-iupHl{?$xh(IM|FEDzaP zl9O0I@5T~ODf_SD{F~r;L)t7nS9)w}l9PBIcH>!wLzn-<`D5Vu;%q$6vGXJ+@yz8j zqfRex`>Q^ItMD$!48+5zfqlK*&e8WuElp8PAa;t)+cX5sVK_n^{os zyw}U$x5!uYQ06>%Hl-2Ie1DNl+!=gvn97gCr5^&{TNccNuSjioT}3kPN#h>_&%exv zr%2QkJSnyAP2+ch=Zg#dd11Wg{=CQ$VR+D&CohbwN?&Q-Z!E+I_pm$^U@GesKF_-J zylqM8pOv?5NPaEJ+cqG-vZdJM(12-k5f7ZRJ-EbI^z%gpLgryZCViy|ne>(E{rn;n zN{h@pAQO@xll*gqO!`_QWYSl_O(w7El(M zC!}kck++M0Yu@;szjVXkTrSo4y$mL7skzm2n}2-)zakq2bmhOf z-d1~)-ct+t$D#KRRxLj!xm-2)Z{FT{W21?_{i@)JI#e|@u327GVi{58kVCjR<)i$4tU*SHF$oLIM*U!3DBI=E&wp$nJHH_o{{ z-=Dt3C8omAUs}wsh0q61$W__D6L%z=?YFMzv7KDj^l6To-th1l)p(~_kIQZV8hh0W zgavoe6l595Iun_VQ5CX0^FM@WE=PhDEY9~oAeA4ds@|SV#Y^}np!|Wi{415G8g+*9 zgfx`Dbg5MSLs0&}Qek_~iR<&T@&1$VIm=|0 zXSwW)2our4Gc%C|@9}K@NAUhier{fyX2bH@`b^7s^5l9Qc5dq4rj{ZlAOqHqO{i{! zkckBB6dA21$0ed&*&?C?{gcjm>9K5nncr9RAbQAiQHJ{JsG*EL5M>j)GAcJoWgfID z^DrD_^~;y$`!g50C?tB9XXo%QLZKfO%uOLN$gwCyoie*ZgfXnM!*8+9*>I3T-(8aL z|KI{Qg{VjRyBz*MQ0QwXX63c&N`pD)QZR1SvnQ%shygSWw}d`2KhQi1wlWW4+?g=5 zgs7e`@blM?L$7!J9A%J^kqk=4>)V){ZRW z*FeT^A*02#RT6tg6ZW=iuJ)2cr?KIgCc9%9zxjAy(GLsfA!=5$xr-vpEnm*>fT;U7 z%tO?y)^iml40z#keiuZ2zQ{J?BU>tSzOHnINPeB;MEbkU_@JE0sSa~)M$9l_Ndc3C zXnNwJ$i29n-@e9Iblu6enIET66(cRwk|9j){dngM5=y(w{4JstU%?-Rgufmm2@@Dk zC&t_a-M@nW2!ei5JZn_MM37lx$*J=8>`|c!qN0`jIY_v_#3n(HBXyBfm4G&uqZUAR z##vlvC2-|Re%}ecq8m5P%30-M&Dl}*XL62#AsrC*M4ci?7V5rpwc9s>bOz# zr~~FO=+f2vF^D}-8AvU5?s1gWYj)l^dIU)|dqkm^8@iEMa)oa6wMI6+Gj$VH_`%iu z;bAtD8->m`bff&STPEMB-pp&>EcyI+$d-=NS)l)rEdbi`~Log)?9IjXoOlD(M3bEM@r zj^_v0`HJqTnWs+f>3d|IQfebouX7E*7TP?#X`b4+r|6r}hSKZVHT)yc=Et@3)W&TU zF>em(mD)C#vmHHw-?`3L`{~X6CGYzF;h|()tbUG(o(okS1?c10wx434KcB|` zVAFwOsC0N<>Trll9S-p$>+t;1=OT zN8PO}9V(8j_L?v@qvP<|8R3QoTG@EYinyu7^=BtC7Goh#vwu&=k^x<+Y^hZ0iT1_DawPaE>P#?H$HknfmTaO!nfD!$;cqgSNmTHq;J^zyK5&y#OOHeT%?7$?>rP z+6EhfCbW;pSKZ=M_ zQNcb#9XH*+(!pPotkHGfBU7Ie-H4%GD?EKEjCU?zF2|u)>gUjB|JVe5vd!N(gMVm) zh^%0EBrS;{8Ic$sW(LE` ziX1G4Cdk3<7TO99(_``P?{yXw-aG%W}79OACJAIYjK7ay%vH$T_IU$QGCY&p9=N3f+i z(4^S^(`@;txANOgv1J2gOBARA?2)uR_U7TNEI8~pzWOAqK6H|R??W?A01Y@gmO1{+ zjC}uv!P>j~`1dPBL*tB-+0;~qC{Bm*o+JIW#fe%MJu4%6ooG*{&6;+<`AKadd5SKZ zZiKK)fRN)+)eQFQ58WQF^z@9%E!Cp7&i5xWYG3H*H&wc;Y&23Yq*i%G&z7`;a%h@J zIkTZ6!QMe#sWNAWNl zK8goisWl#RYW$YWW%mv86~>{_Sa*GWBo@O<9|j6%*}7YCo+pkgirPEbg{DtSq^$|} zFiHG7O}xAuJ&LDGy6T(R1*QjX^TCZk?0gdw!^zC^KwaJpo5o;biD3<9tm&{(@@O^FPPpT`1hwD&*mhalhUF-FMT- zuJl+TU&~HeisKn;@$JPUk}INkIJw9RDLoR(75s}#@1@bqD6}rWr216QlaL$Dgg?70A&3W z=>r!M67YcAN#X<1D$Euh8kX_-ZCU|$ug*dW97@B{wd^Bo+asn z(m^3Y8jqs3jFWz4%NWt2$k7L56&n$9)6&|dHA}sjr)5P~O50T0(Gpo@BAXOlwTY6! z1CUx{M-pn2iE3I&h*}dN17cWeM=`d=L^Q!xr!>>h#%(Df!-F#)pS1Q;!Z{OCtIM5F_+rw9DD7+}W;$HdbdX}F zTbvNFO*$ECp$~87=B#og&S^-oRue(awiWQFtkg~)SZrJ=a;QvF#?FvVO6ty4f)nM7 z7=6-5m&7sFy-MV!?YYQJJ90%{-&rm=c@`9d@J#K%TY>5mN}nx1iJ(V*GWJ$YNiyH2 z9mPw@8CTA9a=cwSq))GO5FVYJP_~rXFFqk?fIdh}fDS1TGliw&Yr1Cf>KENZXV?f3}S2|A1+6>3IbgWrPdQE5tW0Mu4 z1W(lpi|*aRa-s0P98MJ{p6uPMK456^JKAHS81!PSy(e&X`9N94KQ(JHq`eb6d1aH%olnlZh!&{&9%3Vnb zdX>qk$u0B*2R2BJB*1JEa&fUo502R)&`5B&hlcIyDj-_q+&G4Sdj}IEV*`mTgJa|U ziG?gW3N`_lXe2Q@Ik5@JQCeBmUxGfvn=l(*Dv(y|9~4$2H{zSBg|n~BT&)~3${-VjU-%+9Vm&~j(8hx#~E)cULC$BR1cnD?1{@f z)*3_+h&qmf(-jTkOt`qpqo-nHaAOE*kAvb3iM`kfXPg&r4eFPhXEKpt4Y7EAqI-K( zydkJAn%;t!8v`W`bncu=2YnbfxLBR&PIuy!y!z%y{WdG!c(V~jX=D(u7vQ97VxDQy zKRy_crks0cR#!?EI8FT{`snksfX$7Q_v)90 zw$&@2We^y=;sZBoQ1z4ksG-$Q`e$gTcnH-iUY3_AEHEKFs&@4Y0DAFC;vdo4>L2NM zvBk|ioY~zTcD}{m3l0k{Zszf_Kbj&CyM^q>HuoY%Z`kV}$BWXRw7D0vt8MNjY})2t z%HC>oXS1y~cMdzr;?6<*4x_UNQwmG^5ufka+#Yrn-1?W}sbr_y+~q9G<_@y&nkHsB zp5xhNHuqat)aG8tmfGAWvmcmAhVZM{2W;+>Sls3=XB%zqAbZWs0z&=+HuqcD`)%%Z zEMaq>%qnf}RV>5iK8YO?BT#9P98Vd$)aE{g)!W>w*&FgA2oWI1lgIA2x%1g&Hg^%* zW^=D(OKtA;>>;xVAbzFnpv}FJ)!E#~vDYba)i1|$0{g1Xy_Q{Ib8ld$+T1G`-Swb< zIi3^6qtm9ln0*co3eti9e&p|uX;0y1>;{MX-46Gp#hnk`E#l$xr#JlgyRZ(kngkm# z03ukAVLzZ}4P)OT2*-C6e3T&aI5sBZwYSK)!uLJl5;I7E2dX8s_-RSrDp1Rn5V@<;djcLd@7qk=CJ z#N$hp4m4QzQheZELJ)2mV~{(a;Cc)hl{-jqErvM?-=OfV3V)Vz(^5W#pH?ubP`J4DIMBX7-q+mqB2?gJ);7tmCMZqT(d_%z#P~M17v4UF_j4ODa zg4Zbc0R{h4!LKTKNWpZ9KkWAvf_OUU>jcq3)%Y)v8=2}$1j|kQ#pFIs*&FkSn*IRc zw=i}oK`fjI{E4RjrwL!f*k=i1H^H+6*Q@*lNCk}C*$SSn;D0FiCk3_rZd7*pu7dO~ z9)+(~a7w{P75uq^Yf%ppU8#cm6}&>hM-}|Jf)}Jq`u|q&FAAQ9vPFD46ue2nI~Dw2 z1s9?nBDyXG2Nis$g7+x+eFdLU(2u%;!WAgES;6xZr1qBlA6D=g1z%RM6zx0tH!Dc} z0dilb;D0LkqJj){4Eb+TutmWE1#eaG%L@8X=MeoW1y50MM8QiGd|bhWsFR3(je_k8 zzFWa>D)Bn3}VaI1nl6nv|K z2?h5m_&x=%Q}8wg?@{oOf)6YBeFcA|;KCxQN2h}CSMa+EE;?EI*DH95g1=WVy;%C^ zDR{DiTNK=;V5fqYD|m~7-&F7^1^-*YmlgDsNdDOhHYnJm;G}{VDR`}dA64*41%Inx z_D0EXt%4gB+^S%kf;|derQjzNyjQ_T6#Th@zf*AiDU$yd1^X17Q1F0)?^p063VudG ztl^7%ajJr+E0`0K_|*zxjbG4xQ^7|S{H20>OQrvX3f`b#Is+bcAL1%Yeh|5J{#f)C+}NCfPK3w zD8N+HR9Wj#qW_HHV0@>z?bi~(ARZkjX7P^F%I2o&%AMzyCgN2j&#INa)e*d__mN-x z^!{k)SyS65WBYNxDPgSS=9Q2LaAuf%B-Wz?G-}I5LwojwhR4rJ7@FDAPZVWS!+S8pd(Tc-qccBTCj6dODI$j!&fvCiG&KGI|^`j za%_8L!8>DJ+v>M9NM{wC%`FA(bU|~ZAW|2uF6fM$QC-l{8HrUFMDX|;idD-{UqL}9 zUQS6&OcoTtTEjzqh*NK(w{Ivuh;jnM)Hc&`F4c$&1MAvUzffcj^_Sv9Rq)Yf1{L`|3N5%#Fcp$KUvA(f$d)WtINn=6MF9!FOW z1p_msDGGB*YE^X_p>4@N&-!;BJy!IG;_-N>D(=W?@&0)4U`NkT=5B*n5@;xzZu)&6y#;MW%$ss%f z+cRTV3{I2`fLrhIfH*HS$-+$-G>T3yD%Vd+^5cn)9gS;cetaomF$QY=u{ zmu?K!VCil(&-2g%7sJ)WxhyXY^OFoiPsTC9j#VblLg_{8PILWz$|IH=#2N*KDaZdb zOJMzdvx5%9Ust+e;7L47SP6j7Ja&@Q5Y?OhxxM z&|R%PEp$%%U5SM0a^dHsdlq!hyU<;$@`3jHHnQH6+5xClxYR*+6V`Gj5oi6=bSGKD zkY9F|eB;|mw+H-kG!n2HbYRJ9@P7^dQ$D5tZ`E=E>9-Yh0r4gOXt^65{N4__Y>*H? zOh*~~jCd%1Nzi?e1goFs*8;crR&<$In{czUk-mzq2Xt93c6klVtnuBAwF<2trWaG{ zHx0VOiZ`j4O1~u5D4K~t{WP6Zzb}LC5f}X)aOig_=EbyrnBGjO-*uoX&_V&VT&MlM z47#gb=$!gB2N?UN3*Gx2`em&(^(zLw&M(gNT?4vjUHCcm`y1%4bfI(VcX>Wz_qovZ zJM?Q_XX=OP%#`}=1l{E>{G9qd3%a@Fzj7qTf4cCibm;di=$3Rw7L_0x1ly`l2@fpYBC)}El%pR`BBT8_S5VcK~E z=!iA_cjkj1gD!x&P5(4MXFLvXX6z%H2vE~G8cF+}HWZH$It?8Wn%0U-|Kk=hJlBRR=8?f-B zY^dp~@NLy^7<3dr;z#atXHzq8Qkc9rB3Z)-kCyVSH_@htqZKzAPkQo2z-OeOb`_nPrV z)oRckhi@)$Uyceh8o%(6{sW2O7>)r`G^GK%`ar=s3{LtRaXQ8L4lTkv5Zn#Ss4hFmz4*r1^(>|FO0M_;`p4wm1BpZ>4H5V z6F(otlXfq5vUaxhtI4MO@c-}^m$M~}zQ%&b`AKj1_@hhLzVYfm-uQBz=clKwU69V7 zy%&E8L;pREo{br;w9ep-59An)!qtoWHH4u9R# z`08)u?q`yi#^*bx3{`CGKW67A-t^;Sl!xet*G$#aO0{Dq25*q{$3vB+6&0bfYBd!@ z*MZ@u1B;U6Wm|zlQq4FqDu&!-CJdDmJ$he%PY+|ZIZTpu?{{MGd zW7>;;|3q7V&#*PsDsSND6*G?~Gk*RO|6-QGGI)k3!<(6w>B~&d%*f2lT#&gib5TZC zCaQaDPll8{7CZ_adU#y*kn*XgpnqrKBfRXqOMUN3JLtX4^FFF69>ITEo24y8Cd9wF z9msf7OFD=c7HCF)pEA^*+%!^~B_BmnPP#~&)9dsxe!;LT5 z=b*;8ADo7g4Y&w1`w(b8NKW(K7jX>?^-6apqoXna?_P3N-|(J#h!(!6jOaEWmYs{> zXH8>9n)$!SqJ&kqNy2#+o=E$lINp7hx>XX$bwq;;&TunjJdW!Ez6Uq`I`H4in(!AK z?RDb3j?IgFNDNUIK99d%Hh{l~vz@2R3hGc4Vl(fo0j6YbxoTpqi+$Yt088iT%X~}H zSHp23zI@)_u=Hi=%e?PQU$#7b+3NI$^kr!tUxxRhwDjZP`_5&)j1@$ez6O66c+=C5 z1I$Rz^DS5fN)D2j-XRz)5;me` ziC-iBo{s7$*RwaKr9c+trlaS{ zbq<$r9>*f0G$?A|aDQaDr6nGY#UhjoiahP1*H$bFBhpAt-68~v@3PF5P9B=v3 zT6KJPfblG`AXwiLt+VC-V5o-iWpOeM5;so82`@?TjK|3|Z864+^(Txr z0h;P~YqTv;5-P1`d=hSKcoT@S(yB_Jrhr0bAynZzgVR-m@(1Pj!Us>8kdF~ND~X~U z1nGV$C%iKdDn-qBo)QB$Nde{^N(wNgq4KKo>axmmpwCw#fHpr2Uw5GhKvZ}PEVv6yLg%8C> zh%yo-R9#+PSyhhuysRo%gYj5pr~<++U{aaR_;%JfhMup0Vm)7LP9w0(V{yS=X!7Bg(1&3>H)Z8!e)79Y1HxWVFY z=y0TjxKZfcXrzNR{~?`jGQ3rKIQ;*^@OMv@n+^XtCdx;R04gh5GV`s5pE8U!0X}AU zx}?s>4Nt=`vnS3cq%DM3}&5@Gn^ArK}b3|oqMYW5*}E=&v-M|)#T*g2De z=!jn$PgmoY{@uOf48zBX-Pnp_Oekdf%uYxe&oo9mirSoR(7{X$je62DO}ELY176i} z-2Hn6x)fpI3B6jaNJG0eE7s7l-HJ6d z?U1tQxl5raOwnzkBun77n>a(w9VX7ua;Fkv@Pl#Aw%{Z~AbTuGL&djRkcNhD6Jjt< zRVkH_L<#{`gMt7L)~K{QXRSy(g+OZTSu1iNjRR;+Wi|fO`V)-h+m zj;P5nMC_2l3(`_F}wp9y;>cGZuKPU0||B;g%w^OrpQJPi49 zySW)&K0MN|NZkY0{@KG1QpH1(qa88Ka?T=F5J){bSnZu&{(c=ae59a)zzF)hm*1>| zP9G`gP9iXZelCrFN(b$Tp_?*`zE}w9#}#;Z3a)=o2jxVZkkpJezm~@DrfCwgnP4RC zH93}SAEbaH6q9C~jZy7=K7L4R)OrMsT6>2^-PJjm&L7k22rd?Nj8IA)!|jYz?L+DO zX{}2~XS6jO+jayC4Yl@8>@lr!Q3n6DR>NQ*RY{IZT5S@0$l8Z8_{-iJR0?%b%!Ugy z%W$Gbn30ita5*8KGLwWocrZ-7gMfNK)C3Gy9x&P>O?xhEZDW0VYX{~lJE?i}uJNRK z^Sx=9s=HFq9l+nY)+2N2f$CLe^JE;cH~OWR8no9c@MN;Ddmp}3Uw78}$in&Gt4flV zWNQKQ@qe9&59g@6G3_2fM0?HLj%?$fQ(d{gWbo_`}lXIIdMJ zj#;{qZ2CD@!aHcGjYc9Eau(B2gEAo7fd57KPy5P>@t@KL7Nyl&kusQ!Pnj}E5j|00 zov05UA;HR(zgU>Vx}0me0&5#;p!bfeZ{vmey>t<2z8E23@Y5XLj&&QX6g0GV*R@1w zMW;%$@4%YX+?bKGxKb%+@Quc+Mzxw8@4=wVsA z8G9RJw|MSG9o5pMhD^r%L(zuyH2h&4=iZv5$~P1^IZ)^%0nI2SRZ0%yam>8oy#T$i z@-wcB4dcHwzEMtJfMa*>M7$5z222i(5<^VB{gpR&H$~#xu{?+xTAcU8!)|y_Aleq~ zLJtA*Uo}WtKqBTr2F9lPh7(T0!^x zZIM;tW|%=D+%y9XEOdOri^avWBAxAMhT!}@InhS7wWF$oh01~Z0pT=))@Pn1gtAT~ zP*?`kQ-X%fL90bC3xbyRrn+FDu*9~k^@`yoj28$_R||UuN&2hap$Xh3jYpB@9#0*@ z7E6tkaeM=8cVXa%p0-?KEG(SWgzMJ_wEun=6O)ap{TEj5A4!%MLQHX>aQ}u4f%S+G zo^z2|fKn$oU1~Tt8NmkT5e#;DcbX9aTvyRM{I7_Gyu1X-GQU`)3Wiu*i&)@T=zNkE znqS}v{y6$vlnVzFA8!;rjiW6?SA4mHaaV)KJV31ayhOG@X4WAyhgzP9BEbf|f z;Nn0RF?if$P&yCM#j<-T+iCFe{4U*$0`t6Nadj}y?@ebZ^W47B?4_d5kGVATaqI9G zz2Bo*%d+fiq;;&Fm~T*H`#JUZRq%g8Z$C|RMX=tKChcS_U^#ZgcBl&(nE!HGM$PGv zayBb z)AcyX8}q16KQb2LG(L zpnoj6pY*lybV*0S`?Hz+OWt)lh@HJl4iaL1l*vEmTQ}I-H({m6#b##m5uNze1A4?4 zoqqihzGjrl-vj9^jR6F+EL z7LD>Cdu9fXtwiN1gBjVR$%$h72t!Z9vRm}mAfr_tZF}~*#WBcEfw`oKh4l~xah{*f zR0r{&<~XkRh=GI{DbnKVEm-}N3$Ero=BGTE$o#a21{{KprWG5*t@;w zWc(3NM>J5jF;pI^s41<)F2CxUsv6{%A9!f}@+HGF=7cy@GS@2w1nFm;u|x=IYqf8`NNyycVtSTu}9TN|(lO#8}d$GBJz*2}hx zf5a;jsJqQ|EqYY1Mt@Y%88b4r36|dBeZBi9)I1Cg#lK|;F2v=7<6>Rfu1Zl6jWDGz z0z7C0p!Ky_mkx%psWk#v$QJw%;vuj0X>V+dMT`(dGlG~>zOAHGmTUe+g|G?jJ_tAz z`W{F-wl&vv6=FMhs2G1r=}#G=g3dIBB1>)%z8eCVC`Shs@zHph^BVD^*>gvLQV~FM zvxOmg+1Et`pO6}K)g7${CO0&RlX{=D?40>%U2R-zIHl^hbdPzd)rOQ(^JdlHExKxbiZvDnSs8`u&kJQoFil15JWom*K(-@Sr&8C1fIphivyimGH&H%Tf|LjTn2f5X*Qrln4{naax3G{GTP z6PP?o=D_2@nK3gNqzrFKhbO99+IPg|8HTg4d8fTCj(1)oov0^&;^MV4+6AAVRYkE? zvc0Y4Ow9GB2>tAAG=dG9&YMIVc{To`<+P8HtGS|bjLKc?CY=m`8Hg%+>%^03_kg~KH zYife|Zz;w8BVWh4RTze4zk!(X173dzo;WA>Vk859mv>o*DCTl?92=70rlQWWPbUAX z;1(l0s_U8m3yfdq&5;sVeA`w%A4bsyuN zb!mCY`mw~|AhaT9CSDBx2@}c=4vnMTgvz7+3B2^j{F^!dYNoH~karfAhwLoLNi3gt zV~K;A{;N3uCV1YEHVe;{9-ErvB%X)ec$VP+=Kpa17JjqEsbNS4u(@W$2 zDi8lLc>chbP3DCCcHug2k#tsry2U;Z2SF!eyN3ow%OGYNytP`){nOP7B`N+7;lb$@|`E{hVv=1tR@u6um3ksh1dinbn z`HCLOoCnXQG~$`>FOrEngD(zK`Ej`PL*RSMf_d;2sqL<-NX9*B{A1wxm-+A%iJF2Z zrPjS^{7&$EaiKpijQ8uG7davf5Bl=tg^^Y1E6w|jh4{dwfq5vvRMsneo^|PY+mg~h zD{mVPB@^Y6yln&WD_e?94h@(#7x7r;;|G`cihjPRK*&67$fU0{A(Or`y`Nu%LTQnC z2V_DLWRicbkV#)_giQJhxXGk=UgqQ1LFV_fq|98@BP@^NNncVXePw!Y&jQLK^MrIQ zll-Mj`jRr~%T1=pTd({0t&n-=ViddWw3iY2RhI*L=A8nk;Qe$? zcHZFNWJ?0a^>s@)1VrO-?=F@tYfDcaCf_>~dlTam2`k>4m+aa%G%zrXlB6p6Iziag zi&bsre>#)0!X!wjF>M_i7#hT`U@a$0ac%7FpTv$?C4C9Y7hj?l?S~@q@!o-<=~6Sp zh|<@T$)AGuA6)kDroBV&a);i&1^kcD`|;(+MsL;H9RsU7^tRfYvia8+@GG)WKv({o z>ut3+={>cOe;j)MVAb+tlFL7*!$5Gyg+~=5i!h!Qy=X15){Ms_N~@RJ??L0?HqF%fC{2s!?Ys zPe?=gOP5OJKLq6uEESe_C{M}#!V-QTlz%+nuDmSyb^A+o{!Po9kr?Tz5+h?Ci6J^* z&cq<35uc81ich}(<}8=Eh+K60QvNjJ^69m?c`!ruC`DK1z(SztA&qW#PtD}Z8`aqOT?8>OzB$av4 zs?5W1kkv0=n(xnC7esx&$Ts66TPkzDu5^V+ex2h)`n%2epq$C64s&is%rId| z0h5Dhdg7wUy||p;zQ$K{-O09@AE!_iBQ4aDAx!T5c!3TQO1sSbEus})!5@W$zaAqA z6Bth?#@qzmzk>e=f__mvYgEKUkXd5Msq*&hQK1Q<8P*-`dqa;6OY>y`XraDHWW&Z!faYOWcaMZ#`f z#h(P{XHT)^*A&*+qm>rs$V=|Ey494)keet`M}Bw}zbnsI^xfdBqLg_IQL1bhqR2g~ zD6*F?m){FfcZX&brR-&h5+%YCD{{{!N*FMi%O8fQ50(m1?$h&b36nQ6CA$WCs%eB4 zw=u^@lk|e~PjmU*Z}Anqt8BTmu`(+Xw`?jnQ?rUj)10xE9bYwK8@37)iBoYL{|$uw zc{X7xX>_8?l%Z%)r(&+cD0yx@j(<4dEBa-5Zt9rLZnM0^XkvWVerdt%ylKp!(j=bh zxKZ?|1LiR3($)Mih&@mlNG*2mag^0-cHTI81W7e}M4^`(x{+COg>Lk$o*!K2E4rs~Qr#JJLyzBdihmvuz`Z*?gE>v|CppRqQeu|X`R{PV< zINoBXN7QJ2V+K7|M_BC@Tlht3CrbXbsRI0Q-9A=83n0SA9v6JD+OKZm?@3ea6}iFQ zK`+?9xP{-4ww`u$h^`knXL6|s@waUi&BWEEwZA`=-;=h1R*FUSAR{Z!Q-dD&%og}p zdIoS^Ex}}`S%sMU3FRU8p0OzmUJtXL$;3z!YZ>aS^^h!aRH^q2>GRjv|A?6IbvVS2ti$t1qr(GR`Nw?gvB3(rBhXgc};Fb#z3e+_)+mjtdK7VVvwJ{)$G6)&3&P|66dw z8Ll_a?bbT}veu1mNSC&rhjOg;*LD0|>4;ve8Sy(x9(UC9>xsu1h}2QCc&VP>Ce=84 z9-nF8UleMDV>^$^7JqEu-%_?XN)Dfk@Ta6DaP`>HB*$MO{8!2jN6Fz+jrugt*aL@FJKFg2qE;x82ra#@R(L1{8<+a(M7`{-Wf7R8C<;XM@0M|8_e6s|ppH zd#F!u;}>UAj@sEZvsRcXYbk z+uu)(vTiTI=I6fJyIT1@7B)r`f0tk*8bJ#iwDfj1xNbe)e~xeSE3N#~C!I*z;9&9i z9yvY}(TMg+&#$1{D?n_`d0o(jY8-LIiSj2|fK@k{$0;3mT1g38hxF?Fl0i@r5xB8au{si+s>~n6gmx!?sd^iDU!=2E2W-R4Gf-d=bxCtz@nRCK>ATc zl!^-W8S1#{_LUC)nq-Zx`yQG4l;}nb?OF{etk5Q`n!Fy5^5#7`xgJckvgBM1i$$dNGUc>LOWmZM|tKxndaJBgf!9 za(_+Fela5N*$)%v@*e9}8|tr8CDCKv77f~f|9U{pgS7(HeZ z43I+bdjsW@oj^fSN zpT)1(Xj2VKxT@VLz_fy^W`%3UL6lOl!ZmVmBp~hwoJc4wfyS+wVkKXy4aBT!k6YF5 zq2P(p0a*&z=G)Ka_uEyMR;6hq_e4Y1dEQT zp}Tg{0@pgW7g=iL>+y2ak;gXod> zT>^w0kE&*{Uw`QKaHXebRBovjwROHfkx~0XKfkHcU1g(@dLgySGkUh96_i8MM9P^B z6)8tZGY*#Mq*nP5cc^?QqxQxGf3Z@O#Ti!C&D)KoDUD1mnxjjfLMw^~nmUSy+3-<3 z;7YCWm{a4oWG=gJkgqTfjmEm`>m#ukUivUlILp@Eit{{iTv62C$u2Z~S|V*txQ9vN z-)Z9I<>*m7UeZ5oGcDIB(**i>JR|Ka<8^h5S+=#`_L(5G= zE55Y#0KPyq>-nE!@j8^eBk>WT14;k?#_MWiUrgOG zzLuS`6vs5y;@gV{C|5-B+DlpiTeRrZMczz2I4R$VS>`ieiAlGk7|Spb*?1}nFUZid zG86>wf0~YZ1oU&FSZGBOVv$B@iYzOFvBla+#7ne;v8DRc?4?t>- z9Z9H7CaP&AA!<#842a>W9mUud6VU`)ooYHwRky-qr`bJ7Swe3$(NbMPhE1e}3Emp6 zvwH|8K-ZgS#RSNP6JWFu@}nQ=5RneX8cpoZrDrbPfmk+4ly)`~GaW8!I!Lk8El!Bo zCY_A6(1$m3b5=PL=QN~PtBD|I+Y0zoR%)jYEIO_fIaDSoV`oSwC3WX2!HM!kj6Uh3 zOX3*oUL|tV_FUwq9l0W}?<^ObJPV3Jc&2vXtvU4xrO%e1M9?EY8GEayB$;p1j^d@{ zj4Nk4Io>WE(x+EC2#?NAC|gSH7oQL`Kp!L~K_9qd!6(2j0#wj<`;@MDHBo&c)H(8# zu|3+G_z!D`lsuy8$#0YxQh6K`AK;PHF(6}~D;=k0ZH8l9I@YWty(YASvB?Tif~RVQ zMfYxDxlnjt4yTHfvFXj~1BMpAqdhK)!7s+#dje;d50q65l)jZ71rvyp5=_EO4)qQP zN=in@;ot)T&^a%CUl$W6M@FwhrCkv$6`Ui#C$c+dm`lfafOcC)=Ww5k3gr}=O zGkfgmqR=g;h^X%y8{cDoAtX{{U}*2qKq4^X6}OFJM<1)O{gDyrG~(1BC>cA7v=~Sv zG0dNDDpJ;R+DBN#Fi4=J9Y$=Q92!Zu+B;AZwH^01+>Z0!R=hfhO{g9`$k-E?`K&dF zVi0v43#aQE#QAV>tw&GA#^A;fk{^f08xni5E6zAO-Wt?zJGiZ8t4o-gqknub zAZ5X#brcOWl|E$pF#wmRD%SQX^ zl}|JX3|{ns8?~tVNq^MR>L>j(w39X9%gfN)Q9tQM^{##aKrdcQd=)LO{*iv~wz!#x zGrQZvF0uG~!6C=uW*#ql)f9o)Eo8s2xfijAZ0;=fS(|$?`+&{8gk5NJFJ%KZcQ$LX zxpUY?i#rGL`v*(_QwmG^5ue9wZV$W8G!e`3RI)akyPRd)+(Gs|)5M@Zp1sHBehX{0 zx!18}HuuTwM`n^C{3>>%&3zK>i`d+&nRuqtpwD9u$V(ywCdZS{-feULKk~i=yw0NP zf9BrYG_+}(q@@&W<82#C8q$!PJxvSEa+6$|jU-*Dk!zNlHZ)tav?+p=tso+cEG{6M zf*ZIiiYQnR5CK7P`4A9X0ap~HAE5pJ&diy2%e`q*s*m6Ef1li(cg~zS=ggUXd1rD& zqszTWq`TZJ#lvP~C#V&WAsCK!J6>m}E@{{gcD!%1%FB9)`xmSr(TyFFlUGC$> ze!~nf-IpuA1V|)X@ykH|{sf?TGN8+K#sNs~_j}x94)=2SJH)}~m4g}hKf4MuoCIqy z2qIXGDF8s<5+NQW2*)D~A18=B?gt~n&tgayjguRHb~xlc6%J5^LtUf7!L7mps&Ig1 z6b@axwaiDkF?>{R_~#RTp`N$!L1`rimqXl7c${qh5W!b~JjigVU-QXjxSnB@;aLo?V)$W(cQCx0;eLk6 z6o2G{ZxX~cLf&l6lJ#9tXw0V6lHj|5L;_;H4>Ff{hNp6&7jhIB_Bg)3t?&hRmY&oNwv zdXVS}817+sDZ|GYKF9E!WKI7ohJR;x3d$DoX<>K+!#f%NFT>erhlsA7VK2k?F}#Q2 zj~G6~Favc3h09{Nmf=|puVnZL!)F-2%CG?KJB6=jcs|2x7~a9~WrhNE4AHM)*ub!d z;jIk6!7zY2hv<)CcoM?_h8Hk=g5hk`NkqSdVKc+`Gkk#IzZkB=E$&3$!my9wg$&Se>m!fST|7#dN&M+UB?h*b>hL19Qp5c77edM3R z@I4I27=D7`pBbX*SM(uMG)U62n@Ctqiv^>|=Nl!>=%WgyByaKF9D+ z3{!)e|0;$h3{Pg*&TuQkE{3BFZ)NythF@g(U52kPe4XJzhH1;R++v0m467NoGn`=f zK8E`kewg7s4EHm9gyAn3{*$49xt2GF;Sz?YFbp$nWOxR{y$ts;yqw`p4EHm9nBfx) zUtkzm!EzZcV3@^lEyF5?r!ssO!<`IwGd!2!l?-oZcn8C;GW;IHXBhs9;mZvF#xRhj z^;^nt1;Y~=7BZ}5cm~5BhW!l37+%cqCWf~$yp!SA7(UGK1%|(8_!ow+Gn|dKl=A;F zh9@vQiQ#&Nn;E{FVT|D}hLc?_>+ zcnia)82*7_TAt>&jA0(b^$eRBb}+nx;inkh%kWW#&oTTX!<8p#{_7ZaF&t&Mm*IyP z-pugx46&ZC^2NyvPi2@M()i;TV!dC{J;3lWhQDFBt3dmo%kVme$pU!Pk@piU<8c9G zh&)UVO;JXN$GZkQ2XG`*o{htD_dv{vp#4}*Hx6GO z(r(PYj)C!>0VSYYPpyhPnvKQeYjity6k+?5J{o!3$Z#G@?d-x`n!ED0jSP(s=M_XN z2j~>kXn)u6_6?D-9kHx}C?WFm9U&)8@OC5MX=6kcZ7u8EwWnyXrR~g6RNo=u38)WW zM1bAfiz&c(-FRVRU#$DI{`}|`b@ZEq1ts-$6D3=A7Q~{ZB+sdqIpPt# z%XX7r^wjQ1>(=p2V{LnI*ePM0#j?`2PA-B4CtZ=3)FqkW^8e;gRb zg!f3^b_CnDO9kuPHomnpa@L-n_M$|=V6*OS6(-z3_c26cEvF6_G;J#G>j_1}#Kozb zxdf1+Qm4qbHumk<5$Ye=8nZNWB_JCOQ{FCgUP!QefQ}TSyrMH377i%e>>Ax3)forx zbY(GRB2k6gn0hMB#k`|gS?%?WxSh6gS7BpTTUJXrt8z_4K|$7*H4ULqRvX?T;cz&V z71^AHgOuAgm1MoIt$joFh8pcGg|ogPtC>z~4rhg{D$BB3!>5&HwX}xY%Cf?^i4End zp|2||s}Ss)!9-p!5QXHq_WfkuzN8IX!U_3I()3owMlfBSa%fgKulY*!!tt!YhOx_}c?@W5YuCu>~PWsIn6P0xsKC0fYkaSgfpxSK85y`1X$#l8U zcZ^&tkCi^mm13#7x*#vV9E)_v$xI(Db!N->F~?&$LCi80fslp8U$U95$f>s(tUZFbpHSy#mziMmNy<% zNPs5{5nv*^jDQfIHl7YTul?>u!nDWX=cSv64E4u2bk}e`FkWwf?kVE{G%8%=p`*PE zV~DeP4BZKiFyvR2s_*>v()EL1xRXXMAtK znuXC1(~JrAy90Cwm^Z1INWV{Ft)iX?_%U=|{r(8LN8{-CfJeV?V1CT#hiT4)`aKM~ zEF%=q$o1OqkD$9U4xLxOvx7oB5Qpw+kACZy+4|*z-sBf=`nG`X`8fQ%`sFVd;<7k& zUj6O?-FNfKj*4}vJt`p*BLj-8(yzzJxbTx%Gp`m*WD5rjDJ8k{4 z;g?9iAm~zUc9z^p`hjjN4xLxOn?d(P9J;H4OLyRhN9=kRMby&ITklSQ?vrSf%wytv z0TAY${FY2;9)`{&^;sUeAn2|!o(?~V;X4mChp(QE&BmakytM>B3X+E3cKom{zNOVY`V-zdJxj@gun;KM~zM4myfoBDzN%bX1HDoi`rOfX>)&&J=X7g6?MclYW$6 z4L@&uuQ}hg-#iB$sykPFZ*b62zBK&2`h5~~Mn7x=NJw`N=(45O4^3S{y5At<8h$3< zlfAui-*V8A?uqnUc%jXY>as+1xehwhu994@U1~r_c(QZu6#N=McONnU(NVrmBscYP zTR&8-7TvLU_v2@tEYRKMGcLPqQ`$J`esLxCMNvlK2PRh!LC_7eQ$%mTxX3sF4c$pa z1x2Mn`w1156_*#~mzEU=gZT=r|6?_!q@*MmEGono4+{UD+2@8EYVj$Z#T7f3Exv@j z@8ilVK=GtqjIE+stiOA>?mqkud~KnaR~x7eK9N~3PdFI3uxiQAMeecBzH?dj_Jgng z>)`68->CBa;*@1aCClgU#ec%lZ~rk@Rr#KH_?Wav{d)OePo~KI?UM(-EgyU5GV+}| zjNc0LJA@J9;K76Erb2yf&m=k10cc?;ultC7c=5KcH=`U!5AH)vFcX7=@w%f0g{86H z(#}GjxuFBa@R-1=-1)_NppdYWzByInb21Z#)v*rqH9!X%J=d(K&IJLLef{_O<#9f2 zLzVLXcUxnYjGlj^t$%3Qn(83r?}L6dRe7S2XV1%+D`sJj?=0Uee@aqHASF3vR!U0B zQ7N-i=FCb>LF3@;_mGlDf=9MT4_{n8w0!DUm

    vOsm(>0k}r_;5XuG!prov!6{P3P9_bgidrKDU0Sdm-Huxph3< zE9suet>@`pO7~Q5T~GH~y61B1d%73XJ(*kQ)4iJR+1z@c?&Wk(=hppnucv!HxBh28 z{-fM=Ap7{=<*o7UU%1%?0Ei`yRKx%`|kRZosZvg*O}~m-Cb|8^Z8rux|5ynyX#N39)8PRhqCo@ zcRkA1({H)!Qnudiu20!|{4IB#%GT?z-1RD3&%bilt!%yDUB9yZ@GEy6%l6CN^(@;@ zzjD{LY`@)I-?IJqD|emC_UqmCF5Az){(th`1H7tg>jFJH1p-n+L_mai1cVR)Qz(Iu zeFz~yAc2@7Rgb9<2}wvoS9%e|28s;<8}^0`m7ImBpn|9u6+sXcD*xD}7$_ex~Hy$w{hxxqF=P{orO3r0IZ}j=h=aG_gn$IhJUh{dTti&d#F17b4>>aQ5 z+njLEVLJxK9`;hghY4@pZSQH=OQyvgP3V~9_!9xQ1)9%%X77R6TV4zaH7hF}|KihW z?aYcl?L8BF&F`N^m`~4f{Ea&X^fIG=vG-W)J$>#@G=I-={Ew@SrkSnYu=ix_MYs1I zYc2|R{E@yWYG# zZJKpPVDCC`&n@QdlO6x1^}V;79TwSV3ih%YYws~Vx7aZN_Ov%{yWc!{t9=GxZ+m^o zBj%`^?3fp4RKF=tnT7MptTPLH-I1*4&8Ufvzq3C271KA^@q5A>zG}8_=lDNeKip=H z{?t_uXr}LgxzlH#x!5az%R6MA zb7g_{mtJ&zXIA`dpV8PmXWn|$3|)|`{ilW({%js^kYkHcIVT5Pjdjqszw_r=8=Yq|q_V0>XcJ~CX?{E2R*y|t6xzzK(HT|@| z*Z$#XPpgbL?e}f|Ce~Bz?ydbl{ETbj2jW@0BmN-DLYd+hqAt`a{vq0eHi@5zwxZ4A zFQPB#llYD3EBY+{BgO(_B7P*s3S%bzB*qeBDt;x#8e=a0CFTNiB7P?33Uem@Cgu`z zDt;&C8gnlGCu{*WA$}-q1vaDoQL-h=rr0lqt-{Zya#9zit>X)x51+&tJYPEA;Q91P+`;p$;}5n6pTr?-FFGD!d-6$K!uF=)6Sha6#3^jA zI$mLW_DS5r_O9a>UJpKrV|cyjc!t-LPvRP0Z#ur=_2`p0hu5o)cX&PfB<|t$uHzrx z4}1~_@qVG>A>L1X5*P7)qvIpqk9-m*@qVS_CEm|`5;yUFr{gEy4}B6x@qVe}Dc(E=9gp#Oq9iWk^G3&Kd>$!@ z)A+p7@fx3JO5!#??{xge=b@4~j?YUS&+&PxB(CH0R>yaI9xI9S_`KHf9-rq*;yym_ zb^OQvfRZ?n{RJHlvOl3DE@Xd0$A|2XD2Wr0k~ot6B^^() zKcytDWPeM?m+X%zi8I+>)A1(zb4ub)_V;xB$^M{{IF$WG9gngY$%@jAz|O5%2ocXj;E@vxFOp5tX5&vQJjB(CRpTgUetk1L7uIbPTCKF9M);(m_z zb^O1*c}n~Z{SW=<-~+QGzvv(QjqP*5 zSGcri%|ohc?(g4Sb2X^(6_<-0X)Z ze6lbhWQKz)JePlS!gu2xeBsw4YZ9_Nw$B7#D+5>hU7@P>USpHFz}ciYE;@6q>~ ztqC9Oaqx#1|JapK^t6LR^ttwvgzJ|$c*I@5eUlJ3*1;vVO#L~b{1OMBNS^L8<9@S! zKKLpn8ylD_wmEpkup>>(lA9ge;_Xi7nxBqx@QcsJoo^m!cdg}9!k3wS%Y|m~K?l!R z@y5mG@^ucb5p?nrv)>gCzVSgsj5({#HI~l`U+2iEI5X{i2k$T!o94!)4({>N(}T>% z;vM{BK1^U9y>93*_~g~fSh(%rVt z4PWWy>x;}S101|$G`z@ZF4n$IMx&4t~@BKTnteZ`d&ve7PNmpEmmt&sXwR z5AJ`~yx=JZ*LiK{3+B^q2j2;Q9^(e)*yubHZ1g@aAsw$uI{my7T^z%)Z3x72N2hYxbH;U$r?Lh+$vN+;84_-UKVA zg)jL?#6fe)1P4#L`qbxU=!j-nuX(?i?{2VjOz=tH9B|V7?n^s{ zhj03yKYuenaXa|bD=+_HZWw!|74ySaZP3ry%y%#y2a)|0AuksY3b>+*T!7nE5Dd|p6B6XcFqqz^SV1* zd0GdJv@ja@&S9Un_AG1V;AhP*I^Xk0=QIn`fiJx(x2ylq@3PoF#okJ~ZnV$Wq)Ik?=RdpdiTjdSq1oLyZ!pJydnm=}EY#6KcD<5L~H zZeC=h=l4X9g^|H`zu@vqJa6=J@Vn;ox_LHrNw6?A`0`^O?(W&!+QIYwv#W=vYXb+@ z`}(I#J&zx^IV-^EI<$`V6dbTIJNWvK#>IHDx7j&e`24d*$9m>IVPkyo{coDq)AP+r zn_CBt9Dc?%!2$6s-Vrq*yb*JWIThRybB#F{{1LVQn-Cll zwgQ_GJQB79n-W|Swg#IMd=j<@n-rW9whEgSyb`tyn-<&>who&Y{1R&cYeH~LtQD*o z!85Uzu%-mp#9G6e6MPeE5o=Q8oU~T0HOqN+tYxfe!9B6ovE~K;#9n|sL2yv)71%Qb z55-=BJw^0bP1Rup-gguGlZfmc?o+WvF>}A-~1UJQAhdod5Q|yJ<69q@bUWq+Z z@Ko%j*i!{p#a@d&SMXKr#n_VtXT@HPJzMZr?B&?g1$V_>k3C=TSDXbn69k9FS%EV{ z@K~HBI8y|d#aV+hNAOvkML3fLr^Q)?GfVJVoMkxE1h>Umhci#`TbzYB69vb`S&1`K z@LZgwI8z1J#aW9pSMXh&#W<4%=fzo#Gh6UpoaH#v1^2~Sk27EJU-$y>2?Pg*uK=Gx z@L>27@F@frhOYsiL-1kvBJfEBCx)*ApGELu_%iTm1UH7S1D{9mWB5Ywi3CT6uLPe- z@MQQ>@Tmk>hOY&mOYmj*V(`fXXNIo^pH1*)_;T>+1b2q72cJ*yXZV8f2?d9SuLz$} z@M!pw@F@kChOY^qQ}Ai{qVP!tr-rWzpH=W`%abFAkqvaBleO@Yx0LhA$7FUT|;t`tbP$|3)l;m_TrF#0rQR z1P@0nftW&Yal{&kIRqa^EP|LsaB{>dh*<E8iI`GwdBmECIR&3bEQ**^aC$3NrI=Oldc?AbX$7}Otc#de@O#9_*ktdE#q@PGdNisS+K`OT6K z;PN(0UV!V<`2lXvX2}z9d#fa0!2PL`yaD%D=MQ*1sw9uV?O@Osnv4PK8v$#d{})%gxy&pyd}@Oszz58e-ak_X}a zLgzzxKk-Rkg!dbrAL0GTCwUUyuXMhI_cNd5O?bc4`4ip`eUeAv{Zi*sct79**NhosZ*q zQb}Hp<4v8P<9Jj_o{r;Hov-6~R!QED<6WJ<<9Jv}9*^T?ozLTVT1j4y<87Va<9J+2 zo{!^oo$up#UP<1M<9(g~V?01f9+2?@oeyL@K}lYa@dlkAWIRGio{;ehoiAiOLrLC{ z@eZ9oWIRMk9+B}9olj&uMM++f@fMw5WIRSmo{{kyoo{43M@in1@gALjWIRYo9+L4Q zosVQZNl9Lk@g|+0WIReqo|5q@ov&m(OG)06@h+XeWIRks9+UAhozG-EO-Wvp@iv{` zWIRquo|Ex9o$q8kPf6aB@jjjZWIRww9+dGyoeyO^QAu8u@kX5=WjsD9JN(zDDPpIiI5>@67og zoqy(hkdiz!=Zkbcn)69Y^3t4d()nr5M=8lubG}OFtGC$sEG2ns&UfkjHRr>Wijw9LzU#wIbW*t>6}khl2_+^tIn@;K2}Mdo%6Li z-_H45C3$zw_v-vR=Yy5x;W=Nd^YNTdR+5+Je6!Bab3R&0p1!f2uh#i`&Sxvh+jG8K z=kGZmt|X7o`Es4l=X|=7ygujKb$*}o@k;XioUhmUe$MAB$@_D@U+4cnX#Q5eBa8_E z3wU+M>i7}#ujm4zGEc>y>&FWS_~Fw2eSdfO0j{Xr{;&ROV-COy;`%P{|M&@qFVJr6 z{ryiKw=oJ}2Y1if-2b7Y4u4?7T_5(}^qq}q088lp^3nd6eChBBZaxy2;QG|z6>ORv zn$TyD!!Nk5ar=b#-?cFlU=1hk=$f!|yTdp5y>st`NagSjZh3BC!r|u~{=rj;BNLiF zZeudQB2ssaOSt7;hmVjuc4ESe)ebM=yRRw}wk~)03B{Y{B}|?}`~>DH-1^6ogxOOZ zzQWZ5Z%8gNvcVcVKF5_;}(_zz1C z>`0jVvWIjD~(PPxV6RzxIV|2hyy50Jpgexy}_!BGN`y*j%gEM8)F3avT3@zsP*@U5B6XL|iAc>M0xZ z1XgodMi(>sCWo(a!=y+vq{PNZf!*XR>TV87b@&@^t%)+f>S|-Ez;a%HF4p|6fy3uW z-`U&DJml~?iVyWQ-OAy2ocCLQGxIJRvjx_Z5<0*mrgO`cRGBNZ~Ir8tJXNYlMN};&5UA) zf3hQcmN`A%#^ixTU7mBT8PwR}qjcy!&-~9G;-fGxW!Nk8&C4Ei_$eI*EHuw8w=sWU zRgb>D$n0-Ae3gSkmzX;nO}BCcz^-21xzv391Bbtop1#cNw9etNEZ@D{JTlSYvy@!E z!n`2H;kEq!@eSs)zuB5ok2(^v)OLB!*{v$%9Z91>2{6-*q1uE z%IwnG;lJE))otcm`|X?vurSx>tIZGZb@(u?a_%rw3LRd|uFvi?yF@ztm@Ze{ZI=9C z=Ujl5xeu-}FMQhJ%WS%0t=YHS;msWVWS!}Yb@($|$J}c^{)2?J_fB9RASq*!RpmpV>K0V2O|3_rAIF zMu$%{w8d^SroY20%Afmz+3-7C(~TVIA4fhkQ*X0#robA{9lOU2Omz50_iy{yj67oJ zSb;r05wp*Hb+yAkieCGP`St*Zht#9d0W#xn0*V;K{ zV3}*uzBMoE;P9EAeD*u@-fa%ADeC<1&D*Ya_)QnhIb#0aG|$Re1M8gk#SiA5ryagi z>fmE$=S+w9wD^%9&BH(2zoQ5_@UBgcn;ll$IdNd2aV0;Q@AY>0P|v(e`n-?q96GSk zRZ%C*Wz!sf)c%|QW3E2W;Yr>2<4N=U=N!J&gCl=4!!jJ+REH-|ne&g?zas@X{GcX( zm=jjmIelQM!;1biUyE?~R6o7(mwEf^4zKF3n_ZsIy$-+XdDHOR|C`Mj0M^>>h~YVK ztHZa7xii3XV-JUSbuu~7vuV4-znXkJ&@=Wbhlh2`+91!=leWeSm~8H_U{9l)9bVQK zzXW?)b#eGv&F*dBSyN?Uv=;Z_+u;p8Ycd_aR_Td`p4Q*l90_2z_pT4|oHNJaZ_ORn z$TKs{;c+$kxsfMtgTv=axTmpadtZmw)o$=Po`-hYzcT?GjR%jO;|cKEoDE>Tdsa8` z?ETT!v;p&d)@b1KZ?e-+%&%roSEn-c;oIKF3dPxDxZ54LGvb5HhG zhZnYgUZ|(dWez{=q0TKlV-7Osgs|fCcee1fne6bzqNap-vVOBUD!`79o_DS%bg9E1 zOMm%X&#-eH9@*$CTY3W5IefC9fb%@@kq)mc>%sFpKR@U2%Z3bX<+;S;@XQV#Zsqy% zOgo>>Flt! zo{(~fm$qqRThI2B_V2g=$LE!d3p|bH+MFL?)!yS5cy$bR)=dlhBKQ8FPi#>7o+MFw3<`A@Q;ma+$th49aH8w{J z*m>mP&YpAHI{dkb3%Yn-Ty1l@fTa&;8{s(;=J4sBekQ{6$c+xKZqv}No*x@I{JK#G zyLz@PvN>bG+Hagn`q;m0O)4<=apzp(`D=#5yHo2g@su35f9DuDXfO5Z=9w_b=A;3O zPkFnW=g1*j;|ff^^vdp@-^V$;yspQ)d+yjBul2Sw7WeSHI?U$00jnR^=2FkpS8dHK zF#Fw)Ug~+VPd|$z2kidS{!yOAPdNO&Yj#C>KJVc0_@3}adv@IJ@cE|v80|@F5~q26 z+vml2hRt*MeNTnPdJg_%bM}DscU>Rr37X*W{d!*7)3a%>&G7^F|87-J&#B=K{|`Uo zn(zSeEZz}5Aj(3S!V5%Qs8jfXXbajTJVCS-Z5F;D`hq?QZxDS&pM^h&vA~!Jj}T*p zF%v!^#u8&Hyh4mM#$5P?mt~8f;GZiLgc3r0^7BtFT$&E5epx)52SXt;6PpzlgPfH6c7ktQD*o;WJ__ zVND6I5o--=PWX*ji&&GwbHrN3niaky)-u+#@E)<&vF3&Uh`j)Ng76@*S76T&J|y-M z>?y*F#9o6vNBEK0i?AmNPZE0-_AKE`VlTs2gEL3?nK+AZCJ9dyXBEyY;cMb7!Nvk+&Z@HlZ+;>;92 zC(crwsho$k&RU$gqG!ihj5Aqyo;a&bWWqCruLhq@_@?mX;L{236uusOKH;Cj7lcnJJXH9K z@EL`V3SSaFrSMYWYr^Lgeky!X_@u&9g|7;qRrsp#W#Q8@Pr&kZ;qwZA6}~WhV&SpE zSBB3ld{+3<@TrB@3SS#OxA0rxi^C_^JXiA7EuWpV49I!GmxoU;yjS@8@cD)RidX8e%r#+ai`jOeefs#CnMNgnx@z z5HX?fa1kpaW)wayVoAi5!plXhiI`LPxrjv(lL}84u_|I#;p-xnMNBKaUBtSGd4<1= zSoko-#KPl6tc;jh_`Hav5mPe{$BMNPa|^#0u{dIK;rSv~N6apKU&Qi=>4o=;SRXOJ z@PB~?022@%Ft7q(2EqphmHF?s{m#pd|_Z2z%+z646Fl~ zhwz7ig#Z%~9x<>IU?##R29^R$MR>))T7bC-zZh5yFd5+)1FHdMBYb0EIly#;cMPlt zn2+#}fdv5*5*{+JB49?sM+TMzOi6gjz?y(L2|pQF6fh~_DFdqlW+i-OU|GPlgtrW= z3z(Pimw|-=6B8aYurgp~!e<7S224$O&A{4#xe31+SR61p;W-1V17;_DXJC22^n~{e ztPhx<@SlMN0uvM-G_XQohQfyimIzEyc+tQbfjJ648dxMSN#RKYs|02#d}&~rz%+$7 z4XhKGr|_qNg#r^59yPF1V5Y*S29^p;Re06FT7kI=zZzI9Fj?VQ1FHpQD|~BUxxjRV zcMYr;n6L1!fdvB-79KXRVqnI?#|D-ROj&r@z?y+M3qKoJG%#u5X#=YUW-WYeVA;U5 zg|`i?8<@B7w}FKN6BiyguySDL!siB-4oqEm-N4#`xeLD=SUfO!;dukA2WBsPZ(#Yr z^o92gtRI-a@V}7@Ku$n-;K&sqXCQoVxB7Ab>Qjk*-UO93t$hio=9Jv_eWQ1pqTn%zI z!Z$}Q2RR+#og>$SoR9F&kqbgjNO?U>S4S=jIW6I>BiDtTm+;q-3qwv!chTqkm#!k2XkxNBRRe1Ht zwIb&#{CebKk&_jkJ#w|k*)pHp%H<-bE4+K;dXe)L{ylQR$O#J%AGu=WjD?SnTrzUX z%wxB5&B!?mKOebhWjhwge_mK-nPMmr5R<0a5bK&zN zmyVpe@cNN!N6uaI`zaT1<>Z;?k6b-+_QLl^E+094;r%1mkDR~o|M~OFq66UPwH|=W zdqs2s$o*4&S|7me*(^E%Zm-r0AooxG+06ah%>C8+0UnRdq9fq((s}|O&nnRs@OW!| z0doH|A5}a*RXkr>Z@}|eCAtHiZ>>LId#Dl}0&@RkFItbl_EaUh1hzM=Phfkj5}g9u ztJW*9Jy(ftf$d%E7kE8XiH?ESi`FyndaB~}RmJN~>l={!r}bFH>$8g2tJXX4dae@P z1Fv_jf8hO~N^}ssUuZo9?mztSs^a~riuWt6m*D-ZN^}#v-)a2>?}t^q zKl*sT)OrfuPko}R;QdzXD|kQliOz!eYpu87{oE(I3*PUw{({c~pXf07ywG|KK2Ln2 z%i!}y>ofQ~@`+A^&nvCh;PcEUx(z<>w0?unL!an4_`KA54n9wPqU+%ER_i?g#96(=t$UK(s~m1r+lI-VSh{OOV}UtiOz)mHLW*cf6gbm6ZZGC{)GKOpXgB7 zU(|XO_9uO!OJRRg>r>bt^@&b}{Z*}3VSm;qx)t_!wSI;DVV~$&*k9Iq7WSuoqHAG) zTkBicANPsQh5dD{cVU0tC%PB*_qG0o;{l)OU^rgTdKiu;e4>ltcth)BI3DqdPKM(Z zt(W0=#wWTNj(4r+lKT;do2yYd9YBiOz=OHLbVdc+Mxf8;vK3B^@&c0<5jKK;ds_3x*d*peH{P#I3D(ij)&uA zt>@u*+9$dmj<>bGhvRXd=zKU{*Lok0=Y694;do!`e;5z&i4KVI0<8yPJi#ZrAjTWC zJ_xyg!Xtc)Pxu(G(0U=pGkl^OV!T7^hZqm>iH?Zz60IjyH=@@`(t`=&l&=)%q*OgO%v87%$d(EXI?S=&~4Z*7_{u{t1s( zqSIo$TI;nK&sL(_V!T`Hw-^ssqT^z`T$TpC@q8t^ zFUI?|{)_VgN_1eHFVK20&L=3*g>k+?>%)-yr+kDGofzjUv|fz!8A^0xobS;3G0ul5 z(UEb!MC-{opQ1!p#`zYlFXMcS5}g_6YqZ{s^Epa%XPocR`ZLZ4Dbb;EzDVoQIG?0M zm&W-ftxw~8loFj9=c}|{jq_PbbZeaN()u;dhbhsqalTCJ**Kr3MAydoHmz^te4G-U z8|Uk^-i`BlN_20W@6-A>&Ic;d!EwG&>)|+`s6-dX`9`ge<9wtNogC*YwO)?%nM!nX zobS~7InIYF(a~|fRO{(DpQ=Px$N5&Ruj72I;{2@Qe67~oaXwdx?vC@lT7Sp+U?n;{ z&KGMv9_N!4=a&`do3%cV^U+FldYrG;dOgl(E79$7zFX_}I3KP=$H)0{t>@!>x)NO< z=i9ZukMr?Lbbg$#*LpwB=PS|ualT*c|CkS;Lj#++p+rZ>dnE8Hr9?-`d?~G`WImM=T_y9aw7!!0SW0x3%-7O- zOXhPa(Ooj%OY1M052i$i$$T-b$7DX45?v0N_3*kSJZk@<})hMjWXX+>qnUnsYFN0d`Yb*Wj>`6T`BV|wZ4@3 zm`Ze}%-7U#5?w0uO|?Fi`KU^Cs?1l_dR6AL zD$%Vn-&N~ZnGdT($I5(Jt!HIEtrA@;^KG@hmHD_zbgs2&N_4W!SJrx2<})kN%`)Fv>t~q{twcx5d}*zxWj?hM zT`lviwZ4}5*h+M^%-7a>Tjp~s(cLoNTkCI`53WRq%Y1RI$7Mdb5?wCy&9y$4`RGb? zy3AMCdR^wTE79#T-`&yg+I)B=I$q|>YdtUX>6PeunQyQ4z0Ai~qVr|GzSjFPpI?dY zm-+r$|I2y+B|2c%3urws>j{+Tf?02%^}(!1P@)rNy@J*Yvz|eTZkY8BT0hKs2qijV z)=OwTG3zOm=!#iyq4mYA$55g(X1#{i8?&B6iSC&79$J6QdJrW#WY&vlJu>S_l<1OK zZ=&_dtVdCzQ)a!2)+@7~MTu^i^)6b!%z79lI_6EbUPkMgSx=)x*UWkwt#4*MjuM?S z>vgo=ne{wMbkD5!(fViB11Zr#vtCH+p;=F)L>J9^Bdw2SJ(3cgH0zbLUYhkxN_5k# zchdT4$h1Cr$ooidO5A3&U!(u2WLH@5?wg!4YfX;^@vJz z;;dKHdU4h>D$$Lz-cjqvSr4g1N6valttV$ar4n5^>n*ju9JznW$tcm8vtCo{%~{W> zM0d`5Ppv;^J*W~LI_pKX9-Z~1N_6S0H`V%d)}t!Xsk2^H>(yD$szkTWdRMJqXFaSE z9Xsn~9X-3Pr&XeBXT7b~x3eBsiO!w%x?1nfdR`^Ech>uA{X6S{mFVDEFRb%o=i@L4ae_4uqOSE9>jy}8!svmRZEPM`JaTCdM~b|t!f z*1K!{KI`F?==fPLul4-M{Zmd|iLRgZ_FCW1dVD21f7a`3y+7;umFWIi?{DejjPJO>_c-FaFz|in_|6P`?<2lj1K+QV@8H1qMB=+T_VsOMeUB`@ zR}$a-f$wL=cZA@3DDhn)_&#-f=Lo*H65maN?{~&`nBaRZ@m(kQ-N(={K!*S=0rUXi z^n;gg(D$%`9}kW@cu;-)9ZpHn`W|PlE#u9y7Se;1h!r3|=p|xwn(H4jftV zT)|ZZ-xQot@IJxa1pg8oO5}mSWdt7)oI>yd!R-S-4;(x2O zFm4z>j3dSqG3*(34f}?j z!`@-{uz#!rtOu+MtPiXctQV{stRJi+tS781tS_uHtT(JXtUs(ntVgU%tWT^{tXHgC ztY55StY@ritZ%Gytaq$?7yU>7Zl=$h>3S92ucGIw==myouZrHUqH?OJyecZ!N9Fsd z9v{``qk4T*zmMACqxSfyT|R1`kJ{;@_WG#ZK5D;@`r)Jg_^4k#>YtDL>7)MosNX*7 zzmLYjN8{n6aq-dk_-LGbG+sU$Hy@3kkH*nQ*n!gn>qovo zk)0uLf!v28`$G-}c^u?|kWWHRN|C)PvRg&=tH_QO*|Q?MR%G9b>|Bw(E3$h<_OECi zC|VDS)`g<=p=g~bS}%&$jiU9VXdNk9Pm0!+qV=U{ohe#xiq@T?^`~eZDq4?<)}^BL zsc4-lTCa-Mt)lg>XdNqB&x+QyqV=t4ohw@Jiq<{t|MRSW@fp`~AJ5@=>pglO<)A#2 zi}Fzq>O;M#AMHSU&@QwO?L>RgZnPi$K!4CL^bh?+f6;IBALD@Wz_?(1FisdRj2p%e z=$+ndxl-ZzG3IEci27b zAL{_?0qX+m1M39q1?vXu2kQvy3F`{$3+oK)4eJi;59<)?5$h7`6YCV~73&u37wZ`7 z8S5JB8|xhF9qXQ!|2*sg?)EDU71=59it}Fxx@PZ?25ZOdZJ2WN)s2EDo@#vM?(3U; zx%Gl(mvnio`MW>%ZBZKfX4o^+vRfv%{NlV%_fBrzf78h}o!2jDd-Z~I+I=;0Rr}e$ zo_}GxvUTn^9_ZL%?sXeFUfCq#;w2Y7+&SW<&Jl}WzrXAEJukfEh(_YH%HnHDfqf*XzY2}M)W8~eL!yCVy^{)qh$^PwV`%zg329CZXKYz?!GZ&1_YH`oF&)m)$z#8^?2RjyaasdD*x5yH6b`aL<3Yu&R00g!yYX zOf2rSqUeD;CSN`C_^?S=b?sFAd(U5sTQ+@r@;#5NF4-91ExjwWW7)PHUzGi;+uA9M zyJeTZ_gce>_rHI>;{AKPmC3t z{dn${9pBAeaM6jmW3T&T?q7fXW&MlKxQ_dH4$tE~ypM8F9?C`es0a0-Ueu3vpgm|8 z+J|ydexv^w2aE^C1>=Kp!gyiaFn$qwtrfxW>BnBJBPi)?qUB}2UrhS7g!%yCs;37 zH&{PdM_5l-S6E+IXIO7ocUXT|hggqTmsp=zr&zC8w^+Ye$5_u;*I3_J=UDGp_gMd* zeKGmZ#1B9D{r<00PA%%Z>DSx`I-h*8^tKbHZV&q9zHXI2wM+Q&-yeRQ^<#ANZAWi8 z*5`+j%O3symG9dh?$CMVx33Rr_{~1=wO_5i_UA(vJYD?7;s#%T_T^1i9gH8h|G@m| zWA@+o)1G~^J{`69s)`#yHdJ2RVJ zwDXbDjc*@0nEY0H@h97Nb*R{u(xT}bHzz;x+Sqr7Y#sW-w_6T1U7_y&JleOz+_(AZ zn8mM5c{}Fi^UpoB>F)DazxdAK;V(>F74&=)_m*e--!o_9xYh%ndG@ZLr;B5EKDqLT z)lY)+dc?z&h1YPL4(&!+d3y%V}--?Y|ucMs}t*JpF0?o9e|;2m>w#@v4ECl#y5 zPgr@|(x%Vfy8fe2Rt4>7uw;Fr zU(BC;!TR|@kLJ$r*EVu~|B@5)8b7>!-juiQnb-7#8S_%#8a?moM-%3i&*(C5K+jh5 z=6u>{-iGM`^Jx05fAJaDaUaj&dAx`BQ4Y#OxhNm?pgz=#`q2)w2kk=p&`z`$?MD02 z5A+B9LjTZDtH0E5^dIAZ@xZuXd@xQJFN_<;595gO#JFO7G0qroj6233^MLulykLGX zPna*v8|Dx5i2204Vtz5tm~YHG<{x$ddw^ZQK42%X7uXH#2X+K|f?dJBU}vy5*d6Q- zb_jcfUBW(Lr?6MpE$kO|410!M!@gnXuy@!!>>uj@>jCQm>jUcq>jmou>j&!y>j~=$ z>kI1)>kaD;>ksP?>k;b`>l5n~>lN!3>lf=7>ly1B>l^DF>mBPJ>z|?kqf_7uK|>qt zZ8)jXsm3dsv}^WQ^L{Pf49linrKI(*Z5Fm|(r#7zwim8*ck1v^$B2s`?%XBffvy)` za%Z;|J(gbjdsIox!PpVKUhaKy+zowy>Nl$Yri9j>$^p9)J15N^^iFd7Ay*H5F6Gp) z0jcxTwv0G6vgc(*8Fy#CopmBRd{olt{4op0-ZSpG@o!$S=gKd=N3QyJ&hgx1dEe!K zTJThirL#{M_#k+nlG>EckS|PKe{%2&Q){nne)+{#&hH5=FVL@ z_o2C4=kA?*c8(|GPj^!!zG!smQM@Atd*ODZe!nr*YM zn0<`OZ!l~5%*Hbp&p0)`c>3OH1E+168a(x?$`>j^DzeMhPB~Q8vCLa~d&%3Ae=Y7* zJbY5g)hmh~npidAy~0lmzRN$BcRcssIY+Mg(!1x%H?MeZ{5|6qjLjdDG&+3LiR`zt z?#?XA=y}vvmLs2JbA&5K`&efiL))i0*L5d8d>XXkDl@J#U2JD59U3PdVkz~UGHtTzU8{+Yn$EEVomG2JKRM(?HyxouUx(I zw&!o%zpCM?-Ybi4x%cJ+H?_Yh_r}L=IJsijiuKo@T0VBUZ&{aRw_X=~-Rz|&mP}jn z+v0_bTP(hRQNKkWEu6lv-NJ1PrY(qE@WuS~^Yi9M&Ob5l&3S9*&73!8o;k0}yjJrX z&!at%{xqhayU?{UbZ;#^b7Ed3J->eb7xN?O{cQ`{QCS}??6>ItMJ=fO-xg0>a$?Es zrNP(TdR>=gzGY*VpIW~D`e7?hu6XQ*+#B29bl|3YZ!Wr}_sWK=_OE*W)|IzauBP4T zj;K33+|~N-7HgW_(|m2qb?w%7y*KW@)cf-unDgM84OI_)@o?iudp}n2`0Y>Zd@}gy z0ng0cxaHa4=Tl!;{oNQhDlRB@_v#VV+dZ``Kc}+5 z-P0YBJGH1d-`z7NrmH)vw6wUNo65?mnCu?cGe5RhUf~t4q<-Uv6jctLnme9~>0VJ< zSUEkXyuh23mYI_2?bTyYW_n4%^zqim@$_MQdU@&91$mVfc-(Hh^|#9v;Pq0$UavR0 zulKYDd-J?Kqx$xZi;C+_Pk1wuFOTl+|MqD55a=2}e;bCYK~wsh{CLzsS zt|oS~bQAxHGTx-pcwIFnqoMzKRaIM5r!0={*M=x49l${ zx-TLBU+ha64fDXF%8Y_()?Vfc-9b1)FRC$^c8uCu(<_>)Y*EL}=%^T~w0#|SW1@OetzGN5 zOPe57+pCVd(Y?J>VxwK5iFMqMjj`{i)^WdgPy7C;I_}ee*bn5^@c<2q{Xj__575Ba z56r6L0Su1)#F9FmzyR4#zzM2t^f5^G6Km^u0s|G@%N6=)9rrO%xc__|_c2hozom}* z)OQ^y0=K;eNybv$4X6rMO%#}oEI;fYgqJYf$Mo@hvio(v@|xr~Cm zqB3j6U52~o)_E7!7GC|XyLUeVL)f5=-{G@~Hj+T`Y)(UTa_WoPsx26p8cJ!y^a z-DmWuHOvp3(WBOAKY2!v+JnC7jGnc}e(M=MYfr&Wzi0hVmh!^FN-xIqqxv4eFn(U& z1J>vrsqYDE(Ed~36V_M-(&;Bl^|W@{L)5&!N9>WgpuR`!0qNrRNJWtyOn3`160x=2 zu}&UOt#`1840rC(iJDG-0$qdXZ`zuw`|GZ=^HZn@SAz!d(+!u`J18+L+3R(87+jF+ zc1OEoqN4kBpenrHtdunCMs!ra=)V1W_O`EPW(`WB$D^%BtPhtbXJn>~9D$2{`_ee1 zTDOu14bhL`XXmM&QGN6inJHtFy;)<@QPI?rilPZ61^Moxl1lwRdRE4ul);1L8M#$a zG^?Pr&`TfPJ*{W?LUC!ygz8tyD$Dr-MNdgd(hhg8C~_QQVyu_55;KM*XL*y-v%N_p zGqRFLd()!0hkR==-O3y}IP3Dk>3?@4`|=cPIJm>^UREWjoC~ENy=jSALn+|1Yta|z zYDUUvZ_?1@q~TUI`cB5k>=A=fMhxM~sULKUKhWXh{G`X68=jbvG}PNW(<=}AUq%s8 z{sUk=oHaB%ZJ;~$wCjnzd)D%FBHoFO;RbN&=@}yjr=%v=taNa4VpeuWvUg}=>fli$ zGX_BkZ>hHDRg2B3J z$>>GmxXG~FLABqq%(tladzKa7So=N8n4hivp5sv-sP_RHfQAifZ7`QW;}Bi%0~n6+ z^*(`7Sz7NC7@UpuK4Fc~r}aK!4OQcY^>xM?vEKBEznzH#II6bm)cqN?T}Q9)s_h0k zyScU-=;Nog-LSf5(Dr&-qpTivs_l-|ks)-an&Xz^e*ym5>}nTiDcS$g{^uG-e~cDJ zV93QG7lgDh!i-QF+<+dgKq7%+wB#$^ByVQ+;KAfQc-_UtE~Ay#o1RDqVNAq~ZZo^O zXSh3dbkB4dt@*Nj)$bYi%&sn@jV>%=MpvpMIWs8{u33ch7G1Sk;8$N)dh>j*H=D25 z^(tC0wObwUxAS^aM~)bRKW@v1!(T3=qt{C=CKc=*l$?~B>2?KN?Db-3Mr68-Zt^1y zS_M55=S@o);qDGIGAijaok7-x*qA=O>C#lXMEf)@Ma+qs(WlV1XK^+38MV-r*<1@`$Fqb;JjgX+Zx&%ovYk;9^spu8$1C11AVh|R}X?c_DK=7kM}BT z#Pk@*u;1!;x%%MW=69#IDOl}yU$^1!CgN_Z-GlW!_}d@N(;9u7=cC5`d-VOg&Zkjft0~C{5n+5%7kG9KrNnfWn^7X{gE@O*ThxG#8K{PyrrL~g8a7TT8!Fyey3HlRYCO^YTF5>TCaR)NVJWu(64tNIX9|z zZ=aEwGQ^vhH8L$FskWW=nZ z)H;e=kI6?WfcM3pj8W9=+FJ56->K1tQyA4aZxRkI`r|Tw#|1Jb=gJ?rLbK*v`4d;j zWUMRBc8=HQ1)wXsK?-`qq;{qGU(~G|;eS=PaisrM-O_Zsu0m-j z4Mnzd$u5$vUG7}d%^c-i)2$rMmFV(laK`yvvkRn)R6uNQCy-$OsB1%5w515zY&v z#&EkMyV5b6`YQcYdjRHm>GPEXbc)T;R>kDK9T7D39nGPgjd7awDQ<47Pr*?TKsM(om9kEP`<;~V-o zaCmxF#I&5^sRfw3+;TF7vQnC3zUDGk1R-P_OE>e1XW8e>Aj|gS>2F#Q)w3FQQiJ}s zC`iIUs+E9b7;idf3o}q^zF3{N^p71W{|N6S{!hawq2)iJppt;=5m^}{2_py{Lqn2- z;jWlkTxowa#^CdWq|%bg^3r0ymhS5RVt_G=LjDT>_d8hyH>S#QmUwtOXcvN0Z&!jE1 zp7s)PF0Y`XBD0eAn{-%WLAfrd|8GIY3xG*5W>!J=cvY5`jV#2A)>|%n*y<}NeoL^i zRa%txH!VubDJrSGIZGNCyQDc*DSpk-Z*g<<=bD|0-`>F3Cv8d3NJ&e~9R4>WRFsxe zG07Q~`3;S)r5U;ayD4Sm_Omi1)!&TY-q83turF;215>iNPWwG;M>x%p$NQW0_zG8O zI~<}149_tG0xq0;WneHQJ;(^L$ zlgCs~+nv>ZDP;|+?<#1y?dxu#pV-%}cR%tg`Ty3IWRIl9UK~R|kG1+^7_@g&iZmIy zOYczckmM1`87WCL6CDDAi~;apqS%L#d~aGJ05^9p9CqYVoc=&&_CUIC9fkvIx$lO< zaQa(TvHknIqkCs}bzg&4omMjnrb-FFl%y`7x#VRapKEzHQQ5A*DV7DfT-RBByw>jd z8J$IEXhY;wdGjVm)nz??HeeeN`GOEF{*C=OrT(9@9BUQ2h%D^7g8p1-^~EsGqs^8) z$&v{c&P`iyoj7+J+)5k>$4tAXaM>y+mX}VaIlTZ5ZU*JUH7?wqW|?te@|o=)2`=t4 zB0H7%2yys_FoU4_SQKYAnRXAV#kCJRb9IJsEe3&#_{Zjr8eshw6yyY+blkbpL5n~n zLLq0jws-^vb`|}}p+C9wCy)MMf29$foKrc`ni&G)>zo;y5djMPf%>SwnXsOG-y%^E zhoaVbrK{CK4f5XeDk$dYkds3{bg&`>3VwzrUY=||g|XydEa9R0>ndE>OeE2a7!vd+QO8VSorI=!z}aBcmZNPARj z7Kcn4ZiwvK8R3u1AkzQP6uuknzQi3-^AUQc1XERK3FTfw-iU-EiIoF}EE|{crT*FN zGQOh^6LTuOkTp~mm7qWZ-%c1qvxg*mFDEJo?a+nAr8$*d5s3~?8Ih7j9sAN@!w zJ!0V?`K41yUQzSGlZ2<)@6}b*uf~W(Iz{|o&!|FgpTS8{_z&apyJ2-EIU{4lNYF9< z(4TouiRiO1K$=X|)ZUUEfrVvx#W@ufMTIl1k&Cc-Mff=(!Ob7+-gb3+Xl}_=yv{p? zc(C7Tm+30C@%=y|f{abh7)i$vef$?b(it^kByDvxLOto)Zd{WK$j^L$3p_f>?ub~r z^r7_(h6CB6pRET{M-CYn<&NlHEv@y7zGV%bJ8DLpHC{AgG&zAq6@^75MU@3--cNa> zS}*0I-N(PE*a;N)k*95^7$YL;9m39?-EyC@l&1|b#u(?nHOhID%X&soHQn41GrM+m zccu;%N{8@j)QlMYv7de||14gkaak6mJ5VrXYEJS0MlWJ@v(Ks*b-hNtSVg@kDzWCN z{_z(RwjQrBuXX`c+TBzdiJ~h0H^!pIjB1OeRV9XS1~aN(qt-vjt^Z$}&OAMx7m-n7 zKd7(eHJ+vhKgA9Hhu4w4itL%>q6__&lk8g69&qkcyI!JpmE>3lz?m8qJzm48>;kB? zS5aCiDdT8~5iTgZK)oBSyiv1EDTa!Di;A5}<>nWZ7v%qM7;LnjZENv5AM2lX=eg>y zQ5PNzMs6avsPfDQhF_>QE>0m-=G(#8L&+UU9TXi=NbnrHIDV(HyAau@V*i60;nO>Q zZ>C2ScFQ{Bm%F*MP{4am0WoJ$bvN6+w9jcOC*Vi}rwgutAN)S0y8@0nA7fkr8yY)a zD*622+XT7>(%%;$$^EFM4k%A*Ny;MnYp{C$4?{{?S9$Z|y}UlnAJlTKjO zj03Fa5C~j{G-``<`*B>j1&P$K7GZb0rdR<$L3#PaoRWM>BusFH?WW$wuMaS8GP=n2 zVLJ_lE`#3aM8$c%GyJd}x@frK-w!ZW)qI0rxTV$?<^>veIWN$`Q-AqS0zT9&qQ~nk z{FgxELFZ{4WU~EL>xA8znKe2y-s>$yPRh;!L%Hbg6Ij0ot zkJTEHqv2kAB<~G2HdTAPT4mLrrl!u|w(bum=7Dajz0KBF5ne5@ySci7@kY&8|E5xY zld#8kh0Wr8W``_c%hz}T=DA~8pi`J@K#KrOszrVY>#y{^CN3^#lP9m_)kDv z>p67#y4viN)`2VjR72ybz)pFkWi!#%S!WH^BO7Jnb@j=%>?GCA60{SEHL=tA5ROncpRAMa`>z!S$ry zXFqc;bp2BM4Hv{@Qi)}`S69E_y4U}+bto6Q_Mdjm)rvMxyBuvMLuy`fO~(~$s@KU+ zg)U@yWb9q1{5}-AE~VkJhu9iD>Vm6){uI)m3G@dT$87;tAYny{NUpA}`EC2zA^&DWu!HH=psbdIDdZp$IuE5O!fkA;)0YO2=n*oE8Q?nAim&Ha?fH#8< zcsl&vl8e#3C_W+P-rGdp7zBX{A@g*_b{=8}yNsOy=_&5m9??Ccd-aX!O)S5-zJ2NSh#OC{_H;7Td63cL-yi<;5XYPZYyxaM7}n{k8>9Hf4xXOm9CevjT6*gI-q zZwk%73b0bVJuv~4G|Ws%8$?N9Xn-L6vGT!^wsjfn1MLaQ9#Ly9x2EqYtH($-4@2`W>Y!zuStLa&9xKmaM^kxD3X8l1omruC zokJ%2iSwxgVs*^L`BZ6;Uy=Vtcw16r4V# z4~1c&e_`b31%{>5FG;}XrZf%4;=ps$tz~X!$BB?cpRv?kp_kzPP4wA{?6B9n!k%>* zw+6Pbuh@*W%`W54z_7?;0Zqb7rcTbvDWg1l3cVT7(G^}sJcLSe-Aj#tjzQsN_>~}q z)GB-oadimW>#`bKSX55uCN;SvufRK{k1MRdVZ0m?9Jw{Ho+7taFA^V7EdG`Cv!1WFGK|*A0Aq3E;K;igS~DO$t65pC z<7JIit=+K3tRT?1iAw&dVF<=7qjb8T3DSk6(qerfAiQi)PGycO%&Ny8AKD1Yi)J_` zXqBk~jT_Gij@%w{7G(|zBKx7qjkG8Cv~o#I6?SfraVM3#uF+YPYt44;ZN=|937ZsT z+)rixbT(yLlUhfam@O4#JV9k1ZX6b#80DgM1&c_e8~7<8JdsQlKLrK)8q*IX!VRYd zjJ4h?IG|&L@Zn|l{U+hVi|n78g%8iSe+sp$Ei1}*#@y=1xxvPgX2Fr4p3}*y^Q5j5 zKLuHJ;-`?njpxv!^sDm`s*`G>I&r^^RVRLGXVrYE+|Yy;tzVt(8%UkFZ`X;R>^kvNZFO34nkLrA)DJ{Fp!DS@#lyxwJ z+Ju*b!e?X>vDAXd@Hr&BY>Z>Myx2g+&B5kLxv(;4Fs({T8yH_xCD%1O3q$i;6uCw9 z75+g3<3}p|tFtNG&*JJVoK7NFSad_2c z3@^*Fe}9%Mj5m2(7H$8ct+0I|Fa=0XahRr+<`)$bD_H7j!le$*$*UyBET6;8Tpg^R ztX(t@zc-~kC%KhVbd`PXodM;l|G(E2zge-ma`GHwA9ZDA+taPd*-=_G#lccmZLHmNErjse_c<0>WyJ*vKzC_zcFvq2aNi4%{zpJoKs7KEbnq$ z3*&ie(4J0b)*vg$@oNyAvg!@O6+Jqm!u&>O9DP88b~Nh{c1NSy8icL$NDJc-HRzR# zn}nyyrs1lIrBK`|=n1=p6hI@~vf5+Y18@|gG8a+YS>Tw2<=b5wW}G^oyxz`dSO*4~ zrh)6QCZXOsuslBxGnTXsj$GK~4C~;7pXwlp50s$T7S7FE?ddbL(%4dC3C z#&cBF#>i@jk9|@(cwNkS*7S?TS@T~T;zR4qhB_Q<#zL4Vr9j{y9X-}BxC%Sm(%8^0 zIP%s@sv$o$E9D+ZrG5tCl%AK9UqCg)WI6V2b<2C6@eb8+;vcG^g5v3d(%LF|^*mz_ zRdldhy(H8*~<8wYIwDKwHj(7s=NuvVAa?K$ec-wTXPdw(aPA; zJ~;C39`%;YHY_FASo^1!38h+1;nypCuCFR<0L$7KZ&Ouw#8_3;4$s#%G2xS^+OB~>O_Pz_CX5dty;brj zZHyN#431nJ+p^|i#K~XMkd{! z8FT|q#hF%y>ACNG<1Tk_{q@aAlOnU@F!)FkJ3J{MSH*^mUSd9T~ z-qzSf)z0hfuDjYZ@1woFhK85xUmEQS!`m%&+b}F`thV8&cJ|?WdfP0oX-QjS!9~H5 zYx>kPBxgR^cH5d&Ya8AU)op`)w6xlWpIX(~HaJinE-*Gx+a8Xq#SqD0D+{b&=O>;p zc?NzihhJ98US9ND6b2O(=ggGH$!=)T*q6d0+EE(`O@ofqa_6vdRg~orh*x7SeHR!@ zItE8>?t7MPs(pU{zD;$u#+tp1cE&1d&D;IXvNg5O=>McOn6J;;8SAMvAIG0%Yii3P zhM&QF)jc+Z*_O07p6D1H|5$(HhrrHx#YJUaEBje$c`n#GI+2f4jsHiP2Uq+j{Ylq*!6%7V#dl*_Oa8T31P==aRa&-^clc!WH0uEQ07 z++!T8)&}&D+wiU3hOLI(hONfmx8d9WrVXzRFzyfTOa!aUL{fuOKkVtSMdj6ojb?p3 z9am{N)GaLk@g)Tl(rBRU4@GvvUGcXh5*eMuXO|@o8Wbnpu{t%wb$Y2hhUL}>QeqtA zX#H&+TCVtmiN+UJX{6!$pO<#uK;vg=8@{K<9_zDcoGbq8fyUwn)V<81)W83-j7O4; z+fc@3)T#fnh#!)S2kmD3_hmde$avmrMq=jZ|7t9L9Avz~WAR^>@JzDtp*<4xtH=JE z>G&zx_=?BjzbxU=!NxCE32E7xgU+-OuK3Rf8}k~%4$`s{&*HV!LyQ#-iJXYlK^?|A z>SX`jV|C4joZz`j8B{b(1)`v zVcRg{uw4Spavg){=mYG{%oYFpFyjQjm3iiGJvQ7}5CV%Dopt)IaC#-*4>wkXfaaQ( zmYPUStId>bld3T|c#sBXL#pxp#gRAwK|?@10}s7ZSm(}}bOy9BXlHjSrO$?a(6uoL z&dX>J|3j*AL+8%&I(#hq@R)49Zk?chujA~<$;-o`EaxQ^^J#GWb7{tAzhd+e|D08f zbqM+uLnnRpV!m}zF;@ro|0T_Mtjon{4GD|OC)x3t)s2)K`=4C;=jwp6l$>J1%J}Ep z0^-5A`tKZJY^(ON)f=3H*30w{UT)?0GJdvR9$!{onoqy;ib5tjx%dMSLrzk$H;gn^ zL|APqDw$SGySO2347(_9o-~aL_;#f6&}jwuwT%lv`_K_?BLADKn^RlcUP?E9vx_Fz zeUd%)YY>!na1)+J&iSb zheB!mQE099@elSc{;n+JyGU!nR_CQSOSf&Ly>zR2(^$Dy7(U*P!N=SDn(;HOh$Rc=F}2NsM>+Hnhr~Xb^vUwsGGj)|#*00%!HpAlMuobX?9EVfgqhWb6mj zC|WaU2L7>Uy0Dyh8`cH(pV1E5$S*hc*IKdOFUUVWql&SEP{p(jp}p~C z(;+OqTmRd}8q0fBYZ|3+`P}J5utKdZi)dF)57pVQh<0{xWc^FOAF!f;TS=Gcw`Tr7 zmo_w8vy>JQB0Kz0 zKyd{HQ9%?HMFkb5R75O`Wfw#!iVK^7tOCmaduGnvCilIh6@P#Kpa1(b{oXU@%$YN1 z=FZHWJ9kFD$ya70Agb9zPP5x6dbqz!-34Ox^`{tjx=mMJrD-|1=YZj9`$S%yJ?&_{ zy878R<7Kx&(wEWgnZTF!gC^zvKjzEVK4N@*rK=jSFL6VqV_Ec3x$@1NqjhBf^AAf> zU&~p2OUQW8ZI^OsG_xk~=m0;uOZ<;{wETnZ#^pt_ThLeL*&V~VxvFE>1|QEgPI9&z zj)7epwuO+LL3gg|6uR@6&Qr9taJX$RPbkW6VxN<6wA*cau{ICi%A$MOXI*tDRUH^4 zA-n_KH~~6v3@ihw3Gqu(&(1CXQHSwRk?d&nJlS1MaUSLA9qgS(|GV-;y^A?3BS)R+ zVD{QA?LPaG`a)vLA)DC=VU+*{4%Kou*lAvv{o!n1TfbUTEnDj)sp0tY=R1w7i@i;@ zI;rO)n>=o0OIE=+bWLQO-BFQo6lmwck)6mUA22kN55$*W6*gWdmiOW~FPq)lRrwK} zOg)-5q>o?~sUd*$nLFgB^jynRZAEzRcWQSJ5m! zYKOH}CO?VAri%6W-bjAx*&=sV4B|7` z99qiCr^N;x*L1FQu`o6vzu4;$d&0_3TGe-=*i%_usBGcOFxuspc3NJZPhX_M%JGr# z`AVcng{6p8?-dCzu_Hw)Dn_IRuShr?Bx0=mTuQ6aD;k~56e%&Bsex!sUeWN8Zj@-0 z+KFD#P69{77O#j@pph-jmEQ?&_lk%EXRyC>ltRy= zPYl~5M~zbS_(oC~9g(9>Q~^38M~zku@}$XKkt0W|4EeG$gd<0eS|v)UWV<6rj#@Fw z%E;9_BFBzeJMzj($=y36N1sF;iBWr+`^5&dE@*9{en&_rdWAX%`uYa?LnH0j7H(L5 z6iC7R`5!e{XrspOh3WkEPgn8Z^%0=V0sia5UqAi^@P~HSzYsgurt!X`=gF|W_9@y1f~}<@}B1HhgYLUtHqT#s8;IaaSv%{l7I*?-9la@xuQ{oWwO9-d!a8 zf8)!w!v7DxJX`qB_bGu74B@}Ry!H$Km&|J@xzW5%7XBZa*U)&Uc@35K`BJW!hJ@w_ z|KohQQuzPCmmwt2mvQ=b%5Ax~`T)iZ(E}Sm>Z^^4?77G7ZEGfHVk?>zE zuVBrmf~|1ot1tBWJ1i3hOkPz{90G%+0)8**M zIf^306q~3-M0Ez;RA(SXNi+jYi6m!$5YtSOgr}Q?5Xt7HtvkgIBH_R?K{-l|LDu{U ziHSnsqe^2IUChkDNq7suoFy+%eP<_vMJ5O_CsC-2xfCYEF^C}Mnf$yIA?7Oyx?Div zbg?i|5Ts3m=Gxh%Q-oNgE`0*Tn6C!H{@{x_30*Z2G!2FfODNIuGxr(3|d1kl} z`7;c%uV98CIUx$^LWrUq#9WnJo?MpfPgt8&J6rjt*d43_OYFc6ELUm=spvtZTILR< zpjCFzhS?NQZU?A{n7Vcc39-fw*Z^N0Z)^7rZUz}k!Rzc`WiAC)*ntiuQ-xUX zW=JInuC#+$2?DDY!fAP^k5r$k6(K~89l9;~q~xv0gj){=G6qRbHyhK7>bV134=>nTA#Y)&gKsWkMbTYUv=}y8~tnw1E zPE(h71~u8Fzt<#G%6+Ch@%l+2X&I0g&@pJ{fSkQs5o?oHgBVi8g4tx(uu0$~&?0#U zkCwv@A@-~hb7Ao50fQP&A@;833piT-j&>A@5f?$bg%Kr!rz+^ynHeS$- z^tAT|v$OjLLf9q<%X=_OJxuG3MzJIZ8|&dr9Ld~4D->zfdtdwDAnlhvysxhVAIgK< z)zc1gbZ`*ICk(GCD=Wy$lK&MK7h>0^?9Rc_H8?J1B)m5phl^)tcY|&j=pLbS%d@jF z^E5a*vWAZ7!XoOvFqDlTT@1b3uoVX)_2u@qjUOWpAnKm(aNj^zcun`fP-l3msO^WM zAe__}?jIRmg#yVBcjabdla7DGaX8ON`K_~C`i*GhINUM1gD^tQ^NMrxv+{7RC1j#! zpLP*nvr^{$^nsyW_7!5HNVUIk`D`r~x=?t}46-tLCi}=jwCYY`vNi71v_pq^iwZYUSzh zd?>}5qI}#eRe09L_HOFJ+U?CrV(P6KC+b#itghVT3~$ES@;H@t16(xF*Nu~ou&YJ* zh)bh$s5^MX&vRz`Wa2PdG5co-H|-NUTztPq$7pn{M#pJ%yhbNz^c0Prs?muWoutvz zGxiGI@e^%69N-s88b8V6Zx_U$rtzm){QZ(YUE@!; z_+!$4$r?Y|;zK$9rD*&Vn~y=bUj#IMz~*Bp?iZ;VKh@^rk;X4(X#5#AKbQD3HU3PS z4+r?gER8?Q;v+ivvo-!~i;w8w&(ZjEEdGAUpR4ibT72cdV>JFT79Yy-Z=S}VXY-~1 z=4<@h<1e=O z+a-UA#$RIb2PJ>0#$Rgjua)&PUE`-){6Xp8V>SM<7Jp3gmudWE7C!~^!G3X^#y`&D z?_Ws#42_>*@y8Ysf4RnAZt>}f-7hjVex}7&^>c;BUt#f;f3h@wmc>6T^=E7RY@09r zm!t7>EdGA!pOqSarOl5g`*SsZuEifiyX_Zw8b8nGOaJ6+{Ct})?Jv;y1r}e`ze0^) zX!B+JUZnAhY`$#Yi#2|+&6n+aiN-In`6-mYQjK3~^Mk}M)A(gJe;x5xY5Y|dKSris zuJOw?{%VcC+T#0U{?=&xHR3hYYx8G_D)EGit`>K?=o)doi{2nEcF`Nfpo0#ezh4U) zRSP{cCVA1nPj}Hi@fN0a=|}fhz;~Q@hH1K=1HN?eYo@9F2w)ccdrZ^)7Vu?=FEUN{ zcffb7IFIS=Qhtf(Wt#54fN#0jY|>JGnOJMam-0(#8d(1Jqdo_Gxx&ZvVad-He?mJ; zKe}H7zD#j9(^S6$zC7^_rVmT|bHx8JP4{oWw?g!q^3tAs(ZKY6Y0pZL$28r~0biC_ z!n8p72Qc0VnDHeaN=&{?FDPE8d2sxwz65;b;?GP|`3HP!#1k(5YH<(KB1rtH;ue#J z-hgj`__9eO!vWt6@kx`G`r^eIOpnR*j}hG_U*;!8Y&H3?DF7p?m{$InE%KP&F8R|$ z(2T#1XzY4{_5N`egzTM(h7d;>bUGy%I@1l2z z*Kl8%zksheA7kui%u7PnmE=)cZ=sxZ_Qu8ccQq~ zMQ;`zF8U;q;iB8cOQ;9tFW{>eH@oPMh;A3%Cl{OB^qN5dUmHf;_AlV;6b^M_32bvc58`=|iqH2eA$~!)P6%8| zyqB;NeGL@&*5SP1x8iBmYc?3EvZ9jOhyq|188;n7)DV6(J5VO(%i)-VyTtBK3-yu9C#6wK~ zmhe#_-e($Ji}3vxuc`@=UKZi+@Me+et%Q%DJ~4d`;p0Nw!1T8XpA_O@rk@~u80E)w zY&_`4@OGOJ`tt~%z>80&n+b7q_Axz77-NXbnEnjmzl8W6)3*|$HF%imCkXw9c#G-x z3IB=r{^(yQy+wo{;J##fJt4-MTbOPmdS=qVRt(PNjMax|Ok;@hryM z86RSNiZK=AI*OOhxSH_{#>*KGGCsvf<5P;4k8vyEM#gg(uVlQ5@dZXqT}t^?jCG7% zjMp*V#u$t7G3lSfxRSAt@m$73j8ms6`2~!Pj2AQB#rQAAHF(}6{Y{KLjOQ`F%Qy|s zbtJcpv4Zhd#)FK%XMBq>fbluSyNvNM#^)G21B$!(<_{SJ;W_*Eh;XK8^lJNn?-1#c}G{*ZF4>Kk&Q2b2B?TjOgUuFCoqYv{0WM3ZR znT(e+-oc2qo>FclV+~_7!P#tRrf$9OyA0mg%jzhnF-qkoA? zFOhKp<66dQ#(Kt68OIneVEiQGHH-%s?_oT|_$*`WQcjm~24gzoYR2`9CorDExSR2G z#E=!1#B@*mPyzLdK|*R?9AUhW@fyaj zGk%-#hm7|yKFjzQ##b2MW}JGgvTrftaf~Y&*D-Eo{0L*1aS!7s8LwpgI^*q(2N(}B zKE(JZ#;KXgj%LPBG2Y9VxI*zO8P8?>8)ICS;-@jLU|hqviLsgSBF1YN?_zwE@ehn| zF#58U{uIV4#x}+g#*Z_8n(-@)k1)Q-n3ALPEoRJNT*uhJ*v5Dn;|+{=Fy6=bG~-K* z%T_A=YZyBihZ)BhKgD=0<98VG-K1<6k7qoAF_5Ri=P}~DN-1|2_@ejvbKVu;%akFm#f`-xs`h`R{!VdX(WwC7I|CK%!`jDKhRC!>6>249Z9flwjk zvl+`6s~KrtgY=!k*v&Y^coyR&jGtw^j*$+>r1(E(yo(VF+hsV-t4MnpUuXP)G0~^^ za~NsvgXEuN{1fA=jPEhV`<2`bM)~}Vcq^DLVXS0qWE44A&6H!EdN?d{aGVxCs{!sb zudv=QN3Ny|4UTs7xA);_lN>t?pKbPqodLA3fRn}{q61L3uTQG&RBQi44y_l&>cG%W zd=HP0_tn9kJB9{xIIZ@Mj-l|LoE<|0qk}p5p^82_!!Oj^F}QP6?Z~chdVYuka&sLq z$1g$bM9kX4B8Y_wd-qnaKWSe>NnTl~ibA5t+=-Yc$|OR&x|`}x+ST8(ZDVPufFkNK z)n`YDaQaS})aZuMg8H6t=ZU?!p>6WaONWt`aQ_e~3pM2zZ``oAc-!v$aHvGrZk}xh z-KD1!Gju{{ZS%>aTSi*;;gmmJ94q9)q0YYC9J2nT3K?PV&_Hij#fE|O4c#6Q`i6Uk z>1(P%tmYh&(RS>S(b{*6p4?u0#=frB!bs8J?#@mbr@D^LB@cz0P8iH@*izKfl^3ek zZ5tlx!g4_=Ub;bwpIqOwYgbv2Jf|RaBT~9}PdUJR;4(1t2PlxHfJsplxVU1=5PgkXs4mVDwnB4ZH zo25q4CsS7(shLcb@>Ih$jC4$FbVZ08m7^Gk_HN&aEt|b(EGSx(ntyLLPGnqOQUCpE$16DKX z!L@Vy4tX{Wjx!h+Mu*Ce3zVCEj0?r4jN`(vF@i^6Zei*8P;9{95ty6rHVQjD(5^bp zgeVBR*0_UQB<--E$C6=MG(EF&e*-q`K@)$*# zmQ5fLi=bVjaNpWHUZ04{;SPW}0-R^4S)|+wN+r?Vvp3uo!W|HqNwp&~SJr^YY-Oji zVqCIRo{^)Ov#I6_t<<bpcyzT!P9biJtw&Bwv5jMz&vaxm zCTc>MA2H*}VPW3*aM{zAMF`Iq>qmPq9Wa8^kvm35!o%t5tsCn@wJjBU3hL8a(wnN& zD^}Iz=cjL5RhO5S-h!*z>gwve^xCcIn_H?|wiKtI)zZ4Da#NKeOF(X{OK)tgt*=h6 zUSCm~-qc*(Qkq^}vAz~leU1n7|4h0q`0&p&;hZ*nA~)InP9jYjKn1BW_25fIdKQ#z z!El?$2d~&tvJ1M}d*xI_`iQ9b7^WfH!|feC!oZ6t5nE|~V=Lm4rWgTZrf-gMjDhu8 zSoIqd8yBB2Woly5wCTwyfz%l@XU(27_n3L}7c5L$6kNPyY5K9tj>}k{xgsk&XJu|) zenDYTaY<>}s`AxqL}h+XZW-3q&NI?{SiFg4OgOtaCV&f68e!mFt(Y!9Z^y;teotXu z5mS=#y*kAx#9s_u@Xx$Hq{)?nZ}Ldgy#6K20pxEr{f~Fh=FbctCkL4^QwSJIAHCm} z2D5BLIr4>>STuc!4yNN$x9|33Fdg}bm@eLv(ppXP7g6pwNCZu(DEZw0nRSzpyAU#C zlaPxy#CBUOqMsLFPI><%MMa9-gTJ2h;ln1x80PAlJ2jt2FMn(s-j-6E`^*!T|~K;Ah&-K`fj?% zT^{Bwpr@O45czPFM?|^%AxAH5_!m*`VaPekBcj|hki(h*^A}O>ZOAzs7*XyxpBOWh z0VB!X1i8ty8#iV6@Kulfi=^)n$Zfa9BBooo+$RPnA@?=NU5hN6zewp;t$@Bsl-mz- z;Fn3r73TZow-^(qyUr)*8w~Ro$-bCVkuKIin7>GJ=Y7oQtOgPNcQxc3)gYqWeUO`s zpI2ky>S5D3U?lq%oDI22l*jvH@XI9peEWHji?n0($3SSvd!aji)u9K0A+2qGMSUX)=-dL~niNTDp%xuF6c*!PDjDHG9kH_MHm3`#kjNa+xiD@p(siMDojl zQ~a)P4@|iq!QtjLB{#dxFGd{qugN>kktdS71PfyyiKQ#`Gv&SneKh_yf7`K8oy^0V zNcpV-6*c``W~R#pz7ujmgquH8-*!#kMUbOvPx@v<$kb=$gY|tLa#8)la=HE9ezE+_ za_2!V$-^&Mnthk=w(X;RwIbPfE#%%|-IQlDzgB%_-se#m8%cnFrkrlyVaVO*Vc(mG z;4F`u_S*K*kTH^dw?i)7OcZFQtJ`-Na+iC^>Gloo^UF0Xrl_fp)`>XnE5t%;vwUYp zv9AhphfQTbQ=e{M`bYiZQV%)ZzMCPp-$RbpqdV;zJkz#sP89pbAa{|6KHa{Ak4>)r zwL$JC4}Ci|`x4HgT>#YmL2G{^mG1(`9i}H{{y|j!bo<`F$S<0hM_|h7{;Rtf?Ib0} zKU2lfFW#yQf} z^RXXtRRy-7sgKrGIqi!%Xxm3?>Lb}V6LPH{e$nmQ`M~7r!R?USZ<}ZN?-!bVXa2^v zkG`#nWZ$JMXR0*wtJ`-qBpEsEf-cDRQnqzU#@BQLXst{!Nukc4vs9oBIKblH0 zf1iJqzWP`98|@xLatZj`h(D*?J&>bt>bKV7&y>^k9dhVf=aAF&iPvm>6%M%)TszZE zfE?LP>8_6=H`gIo>5$Xy%YYm`u9Cj0D01r{cN^*f$yGb#mg3rJ-#c&E`Jg;T@{4%W zPPZY7++4_Ipuj2J<|uOO-m>*=i6XbnA$M{Vxj~2AsZr!Ea>#W!8}{SRVY2K`gO(OG z4YSTcm*RTNK_8-PM?&-ssz%?U@PlgZQIgQ2wv}%LS}s+C(Cq{u-kI z{v9GT{bnM9T;=KT<9?Dc%hf~#xysk!S7$i~At%#vq(edL=s$#w5juWjbdB(Jgw7wu z$6wGHM%QE~!X3q^B*;#LJIqqy6o7C?HdHt%K)55@Dmh65&tb2>k?O<%E*=Z2n*o3%* z_=JRnDG5^(662E+&_^Xn6Yzi zLpd)AxB>7l@{9TZ#=KwyZmbdM?ncYiOb1WWL5#TbQ>ct$WyTCI5v*;QNCazWCK91# zEECDldYOr2XkpGoGIDLqL_%^E&O}0Ty-!3TtnM;>NbfYfe8?i?!wE#lhZBfMA5I`6 zeK>)P^x*_D%7+sODIZQCq2}GplCXkU%n?OeTYXTYNstJUYmnINW4w^uy zG_MTRETWKozix@-MI}OBoIpf+aRM3X#R+7j7blQWUYtNkd2s?E<;4kvlouUBxNV#8 zr`{;SbMCRXII=MZ6!E!c1{P6PRkT)zLct|9;f`Q1FPNX3SF!{{^iYUaJQ5=>cU4~5 zs={Iw+R|E8iO@VLA_+b^fC9@fVN+HoS=Ch=EHS#ar7)*sNywu-TTg1Dghu;^dv?%C zANYvU5@>2|uBxr639*dH8pZ+E1KlBz!9pp^0lfqLJKQ0IBSRd3C!xwp(~e+KZgFm5 ze!h&{iZe*7TSJvin?se2IEZ0e2!|i295Sm0td_=_Ryr+Y0>)d|NLNstf_%4AnwlGHYU`@?L~E)mT5;xTXk$fP&DO@|Dt9E4tI~HnnIl%g zFi%GHw$|zfd5%SM^@iG(*6L;y<4-ezW?aWK`$PM2EZc@noMjb<;9_vvfi6T4diZb7PX7?Qq&_U*&P1Fnc{0nFGS6#-iQN4l3LB;RR1`MlGZrrj$zm_lU$t>RF&6Bx%(3>YS_LetK zj#=j81&38GlmS(fkm=*SImmRoH-|EPzBh|9eWN#vGJU@{OJ@4--aMJpS@@rQ1~NDN`hn7&sH?FHCoBdE5pg6A?nD`6^Cf>1Me9#IV4mWYS~n&LKtL1aj2@gvaThFEfzx|a!o^vFtW@` zIBgg*rJ?%ThF~_;9AgADKH-xA1^Fe#2pUBYx^@c6I4gH=Nw@mJ_&wm@`$^(hxpRuJ zWH&_jsdOr~1@rPTjy;2u0ZpkO@# z(xSqWlA_Yw5+rdpITCpx4Mj!57&9n>^yN0!a)R=GWrnxEKP^3G`M`Ahm5yMy^FQO@ zcoo5C9em4%i3;K>X?KlP4$k_Aa=O}Lb9rd|FIjx=Qu(sQpJbtY#frdH(NUSNvv}+n zX90ZGVtSO$*DR*xnCOLbgYqT&MX&7Nu(@oB>t49gW_y*>H*L0M%|ylYeaZlyN@Zh# zOXY20{MZVIjT~OFO&I%S8ZrVHq+MAejJqiYZc=V`tftn{G@0#AZ!c=VuPu2fax~2z zm0HT*CsURQxFdMA1fw#_qlWpsO--RAcaPZ&clMq%T530hDq0)sYb(84*5A4Ki0iB= z&w_a}9upDlaE$LS#@5P>71G1lIou@3nSV10ScfOqS4Q81GX6Dw7@ZPYOY)*&+X;5L6i%VmId$eauH$u@uTa55XUo!M0j6{2Uo> zD>uW>mEm?0R<)!wF7P1t((HfL+ukVi zP1>oFm`A9rY+K*cPcOcD`a63^yTW+sYi_e5M@DgR@*OXpLGTa1n3TyVu~gu@)WLy% zoT$1gNV671(so`!9D`XL938~hsNrB?Fr$M${Y7_}zdYDFFwhHO{gt0goYFVqc($o? zXZw(d@x>1B#FwigCMK5VnD7?V9)!dg3D(>cOUGLQW;8oQ#kXl&Q4?6Dp%IaKi7-lo zM4>`}{DLsbB#C+e@;YIxk|c^BpaOaepL?;}xkQ|4JBZ6|G`FA&hm3R?(jq zMupUdmnnE5V5Yyp5oTGj(Gh6bQtJq`EIL6Y;m`@Y>Yag>bq&r?%f?1$sAXxBN{ilH zNJHU@&32GdiLfnpm}TZxJIu0j8z*AvgL6)CgeipxY;y!!CVs>bXjyowOa`-xTvA~r z!~sy%Ed~18_j1{twpf-O2cR@|EtZv#o)=EQ-zNOg8eDn~n1=yveM@Z%&F*22ZzIOF z>FTq1HIG-X=B0`d)>4l?0AJsuCeck?SKCmHfS!K(XdV@YhRqeNXp@;WJkmbW)9H{n zJ``$b#JB&Lk)uIxSGcoxcre_V(T}woBcnt8Xl5!fq;ILNqIAr!>G33xF*+RXq7gq% zkKI~bu}Np29&X=7Y)t=dZm6iM-Ox~7B_9n6@FapZHZubc6NBxYyD-yBm73fg%v=s0 z#X135Q*lUGOS!#QP7t#woI!`;N&}TXVPK|Bg(3URn=4zPfs;~8a)j{)8oGwYCNTO3 z28Hn+$gMTCAW!e^5yrWGBFU4dcf*aBfNZJW0&+OKM;M<5S=+KcV|lP^Aox)V?c5pe z8tn~-I@*VZdcs2)%gYhkGu)ApySGMOdr5pOc=}GXUcrpq&B*bWp|omZrCmp)^hQ!z zKcS^veMe&H51|yBMIeXRf>0R0C$h1b$blhY`~~FtO--#Cd)j+P!&G+I-Liex-~h^) z!-R2Z3_Y@)3}$EV8LFSDl69ZIo^rp}P_H%czg$qn#}<1pCo&8=_k#PDsooLYtB^jl zF6Bd6MNy$DJRi1D!F@jw0A_2#z{o)s2u1Y!M2wi)+AQn z>NC#3Bmb~7e!5hEts|wVcf|6)`-}^y;h~gkn_94xI!dxqK=O?yQT}be@hLNE#Y9o1 zfED$xe&fq#)V&i$-9`dd)bGU@-!!8(wP2VM#a=9f>%?*JEhA`eny4mXA68S*>UU#| zAJH@k`AjNO{u&t=Z0x3pGL}$oi>9c2f2?u9w5Wapi|X5Z`n}D$AkKKeG)HQ2m}A9a zb1YiVRQa#sj3-T7nwo3tD_YROMD9QCMHw%4w>2vPBqIk=vZrx@}mb;Lr^I(M1FP8u6#bp^m<>va!AiZd-N~x z#rT)_vGiPi`{fs7h=JIXYDXqB0yWnzc3KkIZ!21GjUts}6tvxVNm`A8N^WRlXhU^Fb#rYcN@58Pxmic!ms}phm~VXRD`>(k zSVWy2h7{ukS~jl-Uv`G;J@`QyFpQ5S)vjJ0%q!l!Ja{HqH7;dRj6^YiX};FwJ{O}5 zdZQ~xH@TaIf48hb_)b9Pk+!t?kn51OYq59janu1-fiM=lUD|^Ggt>L_69c4P72Dr_&4I8X^;e{w=o)^ZLSzThfxTIlo9abci5@60CCfYiR$u$V(Zlf}X z>R$f_^2qo4B%f=^2{}7IymEs9@)r|hKX{_M6HT-*f}TY1$eD$cM^w4c_f4nZ4`V6u z5&Y4!2RusqUdoceWPHSuL5Y|X1YK2_U~1%E2CMS9 z%&}r@G-Hf=@TzrlP&;d2jrmyCXy@Lg*ejnq(MHv^@*|Tq-H^F_89n|81Dm^TtYvOq za78df7lBMa6;(tHLm|w(wQjU-px+zjZ6l25tm~jKo(HkBeKSD!!D0@y(A~WQ?IX+SNwlW6p|%wx1f>7AB~k|wISOk&L$`_xigBJA2!Q zhkLsBNzY}dl|^*DW=)U@mD}aPwJ2Lum5?2$n*>*l3q~kxe9(`jASYKhH=-K?`4Exl zqZ%5~)WJiA2z!{q%m8{n^9Tj7cdCOK1qgan%8)zgZP6Q2pssPl`rKefw(GUln-)tt zFPOWxRQfBIQh(duGu++N-!l@Pd_K(>u3VadDvuvP?G8NnVWh2IF=k{$b>XsQL6eWS zl;d1XKBoR(dbzW2urLG3WCb(!Engm7h75I^8KS7Ud-E-Fl@+b)2%^C+7spr`z+U?8 zz5g4zP{$mgSdJ_gk)k0NpGGdQPvVgjEyT5QRSKZ(DroD)bJYKaFSHW1YAo(5vm#8Q zM6GDB{_AZ0|5|Z&TD5R7DkZfC(Ja@bVeog^;1BseQg@LmNmkwMxSh;a%Ozm*Vb_mg zSAVonCs?XRJB6nb&wO1SHP zqr%cjAN1p!*CwMEyDcYME{jAKz8*{OCOUdXChr)I;PQ*D1Ue7KQX7ilNL^K4MmMJC zc!=ZZm4n^%_Nmv|QPbno{f?MT8Qoc}la8DfY$XMUYz6s8kaU(BUaEc?dVDX%*;&Am zx(=!dCj{GMzVKZ?)gGl{%&+Fx*JGqR?zwJqV}7+Gyc+Rith^2L4M#HG=jb2W^F1;m ze=#vJawvlLRWZs>)(b5CIY7$MgTO`f8a2?Q#3|qkdXbtMNWDtzmJa~op`o4a{atvG zutTIijNF!A>oYDhjx(DNHE8G-24bW`T`08IF}H(2LzF-0Gd``y;0RZEMi}!OU$i4o zR}@wMcWC<1vIyc)mA~mXzHUoXM`kvEu0&L3_Gy`E3x&Grot!BDDNQ_Di8|D{5>JOi zL!ro8UWhS%U~55ZXxi@W$*;s3x4Fb!iM3mk!{m3Ex|eNzDi$jbEL&AG8!aJ<8dll- zY@G2+J?aFBa!kxU-fzY<8zh&9-R6q&x8sZlwFpsC66M##8-MrB4-N0en_2^YR=##s zKh$PXeowsdwr`%4qfB4qRZnpri1PR1jqm!?I|l~$k-aXR9_1)?e>cIn)xXq?;#Tib zgJd#~Cm7$0UE1B=G3=D@cGfhKlfOzJrWNs{U6vjPj=L-WhCuyp3?iC4Oq}Qll6TaY zJ3!D;Ze|=ub?z3lmzW1bl*2GHT-Myv+yUY%PFi-#-GVk+wj#+eF&mAi3bLxn20cie zP9d_WuQ9K>1-<1leJ|c~5Zz)W+@)Mh&Xev80k`9?9e*^(@fn|dkdRM`^m6qYy!}%z zTCtvXvQUTzlVM}d&6xI8j|m&-KJz_(i5iQBEsEP1bRQ$(rQM-v#B!! zc#$pjA;z!#Ca1Bcrls17kvT4koyt9&N^zm7KQjY9q16XL&7j{vv}x1E^{pBBdMPgp z|K-zv1;`2p(-ez5xmB;ndj9w1 zN%2xochNB4ZR{T9ti0lJ@}{dadDsVQ@(VS2B~AK~vG14k;f-%aCr&`j--~kG6%G#q znlsw7oMkWwhg{6U&}_Vn30IO)e$Ql(avx`9JscmF=k&E>}5q+AcWY=>l6v_9S%NJw9i) zf{5`Qel znv7I~uJdZyM_!Kq(fND5Keg6hc(1OY-843ZdwN5AifGdr`tw>9NFP|(Pg9OpSQsT( zZ&uK+vkb2Ied;>w)ku{6KFl=8q4Gm}!un9&gLyojHIcEj7;AJ`q+XMc^+&NyyG!sG zmhu5|W{mk$o9LSv&~zMtalU^>lf2E<+i@&N0!_ENNLfMr%RtK~J8J7i>Mg>!(jQPE zYQ@^^!uWzeHS-l;Qd<9LUu*jy-m}*trf;c88^k(<5e(f24Byh2w86@OaCbMXA~HcN zNqs^{W4n8X&~L)z{?2e{cZo<{Z5TgEh|N6UkD~H`TP2aC@~>VhaWYZrWrlGVbbdA_ ziq6?SmzhM8&Ud_Y;`pP~KN`jZ(D_0%ou|2V5=lDe8soE0XDp?b_>A8|=fklnTDnG3UzhoNng``K)>1bVn6LK;=NM72r!7tfDh+Q)N2JKWGSsdiL5?Q0lzHZ+tQ_HuF~rN1$^< z4C)UGH&YevIKB9oDs@JT@dfC;X37!hm8I=%t1QM{F~(P+^YtUqDGN1%PAaWCVvKJ? z=L=I)(<*WW?klPh6=2YnFRcPqm9Ap^Kc9*VIx7b^Fx~4#vA(5oX`2QWKPhcfkGh(k zwy8^9rKn^Fd%A3&%Y4j;H7=MQoB4ENx=iyOD^0qJk!jLZg8%!8xG5cJ-iS1j64E68 zT$v_aEs$x_RnRL<%IAf##+69(p(K^&T(l!9pLC_tq^kt~^+~vC9ceC%Gt(r#N|UZs znsnurrmS1<#TwTk&2LY`ZMTKiGNO8#_rYG+M3H0C_O@VQshlDsIw5WFB)jJF%|=Uc z+o|!yyRbpqnKF@qIOESq>FVmmoy3j2^F+PWCljbD&>4Z$nbr?< z^>kxZu$fL0YprST9KniN?uVy~CGtwPqH+(eq4utxz4>;9k$2yQ1mjUy|M?mJZPsgc z7ixCLPBC7E-G^p=ICgVy_aS&)v)k!!s^&kNVqB7f8+7)6x!q2Glij0JjjzG(hv&@v zP-;1M`2W7Y)A0FD$3DLCWE;vIjc1jYZDe+$aR;*Ur>a>7tKbEAMxRv z*O2@b^P?sInIlgA9VCB+XQEUS*H1If3B+bzupnBZQ>Pzkp641%Qsbt3$zi zo~lsgMe47R&6y~$^l3{{f1!+*TUWS?DQmiM1B@SA^uK95wW#Bar$Ed2^OBYEUx4vr z$e`C_d6-Hd7!iYbD!k`vwTz)9f%1=`Y4pMO{7jo`3bW|)zq|_nSf5N3e6NMpIc_Cv537jiB-r_ z_fU%QDs=yN$=tLCQ;kS#=&(KGOH=RbuyWHJZJMd56i@*x2ZnhVA=5;Ln`K2S3wUI- zHAQB$t8+wemmWwlE=-Nhyc;9r$rwXpb+k~{7>KHg+Ze7*%9y*I#vBAeUcV@LNoqo( zhe2|5c}l?eAq;vveR2lLha87NG$?Z$L?M=Uwx&9~a|#GD=-%l|Qa?Y%%OGkxUkVt1 zgh4+&HYu&%Y&3*EmxAY3bM}OXg?NCb$1Q1(st+`ef~Cwoco5P5Td3*x978|#s%|YGtWJ4l4)?q&uI{q5G@T^wX0_sS0IfSkw%^Et3j+C z4ZHiU$@)t@It}!WciD|Ij4#iR&3r852$G8GHt(d!b2DceHzKJ!mmfh=QN8Dxlyu

    `FU&Nq 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 literal 0 HcmV?d00001 diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/Compiler/EventRecorderConf.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/Compiler/EventRecorderConf.h new file mode 100644 index 0000000..5958233 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/Compiler/EventRecorderConf.h @@ -0,0 +1,44 @@ +/*------------------------------------------------------------------------------ + * MDK - Component ::Event Recorder + * Copyright (c) 2016 ARM Germany GmbH. All rights reserved. + *------------------------------------------------------------------------------ + * Name: EventRecorderConf.h + * Purpose: Event Recorder Configuration + * Rev.: V1.0.0 + *----------------------------------------------------------------------------*/ + +//-------- <<< Use Configuration Wizard in Context Menu >>> -------------------- + +// Event Recorder + +// Number of Records +// <8=>8 <16=>16 <32=>32 <64=>64 <128=>128 <256=>256 <512=>512 <1024=>1024 +// <2048=>2048 <4096=>4096 <8192=>8192 <16384=>16384 <32768=>32768 +// <65536=>65536 <131072=>131072 <262144=>262144 <524288=>524288 +// <1048576=>1048576 +// Configure size of Event Record Buffer (each record is 16 bytes) +// Must be 2^n (min=8, max=1048576) +#define EVENT_RECORD_COUNT 64U + +// Time Stamp Source +// <0=> DWT Cycle Counter <1=> SysTick +// <3=> User Timer (Normal Reset) <4=> User Timer (Power-On Reset) +// Selects source for 32-bit time stamp +#define EVENT_TIMESTAMP_SOURCE 1 + +// SysTick Configuration +// Configure values when Time Stamp Source is set to SysTick + +// SysTick Input Clock Frequency [Hz] <1-1000000000> +// Defines SysTick input clock (typical identical with processor clock) +#define SYSTICK_CLOCK 100000000U + +// SysTick Interrupt Period [us] <1-1000000000> +// Defines time period of the SysTick timer interrupt +#define SYSTICK_PERIOD_US 1000U + +// + +// + +//------------- <<< end of configuration section >>> --------------------------- diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM0/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM0/RTE_Components.h new file mode 100644 index 0000000..182fb76 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM0/RTE_Components.h @@ -0,0 +1,24 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_cifar10' + * Target: 'ARMCM0' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM0.h" + +#define RTE_Compiler_EventRecorder + #define RTE_Compiler_EventRecorder_DAP +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_EVR /* Compiler I/O: STDOUT EVR */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM3/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM3/RTE_Components.h new file mode 100644 index 0000000..2aa5627 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM3/RTE_Components.h @@ -0,0 +1,22 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_cifar10' + * Target: 'ARMCM3' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM3.h" + +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM4_FP/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM4_FP/RTE_Components.h new file mode 100644 index 0000000..bdf6fb9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM4_FP/RTE_Components.h @@ -0,0 +1,22 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_cifar10' + * Target: 'ARMCM4_FP' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM4_FP.h" + +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM7_SP/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM7_SP/RTE_Components.h new file mode 100644 index 0000000..9d43970 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/RTE/_ARMCM7_SP/RTE_Components.h @@ -0,0 +1,22 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_cifar10' + * Target: 'ARMCM7_SP' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM7_SP.h" + +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10.cpp b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10.cpp new file mode 100644 index 0000000..ee1083b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10.cpp @@ -0,0 +1,196 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2018 Arm Limited. All rights reserved. +* +* +* Project: CMSIS NN Library +* Title: arm_nnexamples_cifar10.cpp +* +* Description: Convolutional Neural Network Example +* +* Target Processor: Cortex-M4/Cortex-M7 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of Arm LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup CNNExample Convolutional Neural Network Example + * + * \par Description: + * \par + * Demonstrates a convolutional neural network (CNN) example with the use of convolution, + * ReLU activation, pooling and fully-connected functions. + * + * \par Model definition: + * \par + * The CNN used in this example is based on CIFAR-10 example from Caffe [1]. + * The neural network consists + * of 3 convolution layers interspersed by ReLU activation and max pooling layers, followed by a + * fully-connected layer at the end. The input to the network is a 32x32 pixel color image, which will + * be classified into one of the 10 output classes. + * This example model implementation needs 32.3 KB to store weights, 40 KB for activations and + * 3.1 KB for storing the \c im2col data. + * + * \image html CIFAR10_CNN.gif "Neural Network model definition" + * + * \par Variables Description: + * \par + * \li \c conv1_wt, \c conv2_wt, \c conv3_wt are convolution layer weight matrices + * \li \c conv1_bias, \c conv2_bias, \c conv3_bias are convolution layer bias arrays + * \li \c ip1_wt, ip1_bias point to fully-connected layer weights and biases + * \li \c input_data points to the input image data + * \li \c output_data points to the classification output + * \li \c col_buffer is a buffer to store the \c im2col output + * \li \c scratch_buffer is used to store the activation data (intermediate layer outputs) + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_convolve_HWC_q7_RGB() + * - arm_convolve_HWC_q7_fast() + * - arm_relu_q7() + * - arm_maxpool_q7_HWC() + * - arm_avepool_q7_HWC() + * - arm_fully_connected_q7_opt() + * - arm_fully_connected_q7() + * + * Refer + * \link arm_nnexamples_cifar10.cpp \endlink + * + * \par [1] https://github.com/BVLC/caffe + */ + +#include +#include +#include "arm_math.h" +#include "arm_nnexamples_cifar10_parameter.h" +#include "arm_nnexamples_cifar10_weights.h" + +#include "arm_nnfunctions.h" +#include "arm_nnexamples_cifar10_inputs.h" + +#ifdef _RTE_ +#include "RTE_Components.h" +#ifdef RTE_Compiler_EventRecorder +#include "EventRecorder.h" +#endif +#endif + +// include the input and weights + +static q7_t conv1_wt[CONV1_IM_CH * CONV1_KER_DIM * CONV1_KER_DIM * CONV1_OUT_CH] = CONV1_WT; +static q7_t conv1_bias[CONV1_OUT_CH] = CONV1_BIAS; + +static q7_t conv2_wt[CONV2_IM_CH * CONV2_KER_DIM * CONV2_KER_DIM * CONV2_OUT_CH] = CONV2_WT; +static q7_t conv2_bias[CONV2_OUT_CH] = CONV2_BIAS; + +static q7_t conv3_wt[CONV3_IM_CH * CONV3_KER_DIM * CONV3_KER_DIM * CONV3_OUT_CH] = CONV3_WT; +static q7_t conv3_bias[CONV3_OUT_CH] = CONV3_BIAS; + +static q7_t ip1_wt[IP1_DIM * IP1_OUT] = IP1_WT; +static q7_t ip1_bias[IP1_OUT] = IP1_BIAS; + +/* Here the image_data should be the raw uint8 type RGB image in [RGB, RGB, RGB ... RGB] format */ +uint8_t image_data[CONV1_IM_CH * CONV1_IM_DIM * CONV1_IM_DIM] = IMG_DATA; +q7_t output_data[IP1_OUT]; + +//vector buffer: max(im2col buffer,average pool buffer, fully connected buffer) +q7_t col_buffer[2 * 5 * 5 * 32 * 2]; + +q7_t scratch_buffer[32 * 32 * 10 * 4]; + +int main() +{ + #ifdef RTE_Compiler_EventRecorder + EventRecorderInitialize (EventRecordAll, 1); // initialize and start Event Recorder + #endif + + printf("start execution\n"); + /* start the execution */ + + q7_t *img_buffer1 = scratch_buffer; + q7_t *img_buffer2 = img_buffer1 + 32 * 32 * 32; + + /* input pre-processing */ + int mean_data[3] = INPUT_MEAN_SHIFT; + unsigned int scale_data[3] = INPUT_RIGHT_SHIFT; + for (int i=0;i<32*32*3; i+=3) { + img_buffer2[i] = (q7_t)__SSAT( ((((int)image_data[i] - mean_data[0])<<7) + (0x1<<(scale_data[0]-1))) + >> scale_data[0], 8); + img_buffer2[i+1] = (q7_t)__SSAT( ((((int)image_data[i+1] - mean_data[1])<<7) + (0x1<<(scale_data[1]-1))) + >> scale_data[1], 8); + img_buffer2[i+2] = (q7_t)__SSAT( ((((int)image_data[i+2] - mean_data[2])<<7) + (0x1<<(scale_data[2]-1))) + >> scale_data[2], 8); + } + + // conv1 img_buffer2 -> img_buffer1 + arm_convolve_HWC_q7_RGB(img_buffer2, CONV1_IM_DIM, CONV1_IM_CH, conv1_wt, CONV1_OUT_CH, CONV1_KER_DIM, CONV1_PADDING, + CONV1_STRIDE, conv1_bias, CONV1_BIAS_LSHIFT, CONV1_OUT_RSHIFT, img_buffer1, CONV1_OUT_DIM, + (q15_t *) col_buffer, NULL); + + arm_relu_q7(img_buffer1, CONV1_OUT_DIM * CONV1_OUT_DIM * CONV1_OUT_CH); + + // pool1 img_buffer1 -> img_buffer2 + arm_maxpool_q7_HWC(img_buffer1, CONV1_OUT_DIM, CONV1_OUT_CH, POOL1_KER_DIM, + POOL1_PADDING, POOL1_STRIDE, POOL1_OUT_DIM, NULL, img_buffer2); + + // conv2 img_buffer2 -> img_buffer1 + arm_convolve_HWC_q7_fast(img_buffer2, CONV2_IM_DIM, CONV2_IM_CH, conv2_wt, CONV2_OUT_CH, CONV2_KER_DIM, + CONV2_PADDING, CONV2_STRIDE, conv2_bias, CONV2_BIAS_LSHIFT, CONV2_OUT_RSHIFT, img_buffer1, + CONV2_OUT_DIM, (q15_t *) col_buffer, NULL); + + arm_relu_q7(img_buffer1, CONV2_OUT_DIM * CONV2_OUT_DIM * CONV2_OUT_CH); + + // pool2 img_buffer1 -> img_buffer2 + arm_maxpool_q7_HWC(img_buffer1, CONV2_OUT_DIM, CONV2_OUT_CH, POOL2_KER_DIM, + POOL2_PADDING, POOL2_STRIDE, POOL2_OUT_DIM, col_buffer, img_buffer2); + +// conv3 img_buffer2 -> img_buffer1 + arm_convolve_HWC_q7_fast(img_buffer2, CONV3_IM_DIM, CONV3_IM_CH, conv3_wt, CONV3_OUT_CH, CONV3_KER_DIM, + CONV3_PADDING, CONV3_STRIDE, conv3_bias, CONV3_BIAS_LSHIFT, CONV3_OUT_RSHIFT, img_buffer1, + CONV3_OUT_DIM, (q15_t *) col_buffer, NULL); + + arm_relu_q7(img_buffer1, CONV3_OUT_DIM * CONV3_OUT_DIM * CONV3_OUT_CH); + + // pool3 img_buffer-> img_buffer2 + arm_maxpool_q7_HWC(img_buffer1, CONV3_OUT_DIM, CONV3_OUT_CH, POOL3_KER_DIM, + POOL3_PADDING, POOL3_STRIDE, POOL3_OUT_DIM, col_buffer, img_buffer2); + + arm_fully_connected_q7_opt(img_buffer2, ip1_wt, IP1_DIM, IP1_OUT, IP1_BIAS_LSHIFT, IP1_OUT_RSHIFT, ip1_bias, + output_data, (q15_t *) img_buffer1); + + arm_softmax_q7(output_data, 10, output_data); + + for (int i = 0; i < 10; i++) + { + printf("%d: %d\n", i, output_data[i]); + } + + return 0; +} diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_inputs.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_inputs.h new file mode 100644 index 0000000..4ff8dc2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_inputs.h @@ -0,0 +1,6 @@ +/* Here are two different test images */ + +//#define IMG_DATA {158,112,49,159,111,47,165,116,51,166,118,53,160,112,46,156,109,41,162,115,47,159,113,45,158,111,44,159,113,41,161,116,41,160,111,52,161,111,49,166,117,41,169,117,45,170,119,44,167,117,40,162,113,38,160,111,39,160,112,43,156,109,44,149,107,45,150,107,45,148,106,43,149,107,44,143,101,39,140,98,43,141,97,41,143,97,38,137,95,36,126,91,36,116,85,33,152,112,51,151,110,40,159,114,45,166,116,56,162,112,49,160,113,43,164,117,47,162,114,45,163,116,46,156,110,38,155,111,41,159,110,54,163,113,52,170,119,41,171,117,40,171,115,33,169,115,30,160,111,33,154,112,41,151,115,50,145,110,53,139,104,55,140,102,52,141,100,48,149,105,50,147,102,46,145,102,45,142,97,38,143,98,34,136,95,31,125,91,32,119,88,34,151,110,47,151,109,33,158,111,36,167,111,48,160,106,42,163,115,44,165,117,45,165,117,45,163,115,43,162,115,43,158,114,48,157,109,57,161,111,51,166,115,38,167,114,37,169,113,35,170,116,39,159,114,47,145,111,54,121,96,49,110,90,52,98,78,50,101,77,47,114,85,50,120,86,48,134,96,55,143,103,51,140,99,39,142,99,35,139,98,34,130,95,34,120,89,33,155,107,40,155,110,32,160,109,31,174,112,44,167,110,43,167,117,46,169,120,48,169,119,48,165,115,44,165,117,45,167,123,57,191,146,95,177,130,75,157,111,41,162,115,47,164,114,54,158,112,58,149,111,67,104,80,47,103,87,65,98,90,76,92,90,84,80,75,66,74,63,50,86,70,52,83,62,39,113,85,45,132,98,46,140,102,43,140,101,39,136,99,39,127,94,36,155,107,41,156,114,48,161,115,49,170,114,47,169,114,43,163,113,40,169,120,47,166,116,44,164,113,41,164,116,42,173,128,59,246,214,164,195,156,107,151,114,56,146,111,60,142,108,71,111,80,50,78,53,31,85,69,56,113,103,98,112,110,111,106,114,118,97,102,105,93,94,93,74,72,67,84,78,70,85,73,47,105,83,45,128,96,48,138,101,46,133,94,36,129,93,36,148,109,54,133,104,64,130,100,57,147,112,53,161,115,44,165,113,39,167,116,41,167,115,41,163,111,37,165,116,39,163,118,42,180,138,85,157,122,78,128,102,58,97,75,43,66,50,31,69,58,43,66,56,45,89,83,76,118,113,110,122,121,120,119,122,122,114,116,116,94,96,96,99,100,97,91,91,86,58,58,47,67,58,37,108,84,49,140,105,58,138,98,44,134,95,40,127,100,57,109,95,80,47,37,17,88,74,28,153,117,48,170,118,43,168,115,40,170,118,43,169,117,42,166,116,37,164,120,39,147,107,52,129,98,59,127,108,75,100,87,70,68,67,57,78,83,72,72,75,64,83,84,74,132,130,121,146,142,132,124,118,108,105,99,90,107,102,94,115,111,103,85,83,77,63,71,69,46,47,39,79,61,36,132,98,58,141,99,48,134,93,39,131,115,90,99,96,92,42,43,38,70,64,41,143,111,56,167,117,42,165,114,36,168,116,39,171,119,49,161,113,51,140,109,51,120,94,49,130,110,77,144,131,107,116,106,93,88,87,79,91,95,88,85,88,82,77,77,69,124,118,107,163,153,140,136,124,112,102,93,81,106,98,88,100,93,84,85,81,74,54,60,58,49,53,49,57,47,32,107,83,50,138,103,51,136,97,39,170,161,144,103,105,105,54,58,59,124,121,113,153,124,82,161,113,43,163,117,41,166,122,50,165,121,66,174,135,95,113,89,59,125,105,78,157,141,121,156,143,128,121,111,101,86,80,74,82,81,77,84,85,82,80,78,73,81,71,61,138,125,112,146,135,123,113,103,93,87,79,70,83,77,69,86,82,76,71,73,67,56,57,53,40,35,27,74,59,35,133,106,59,137,103,45,180,176,163,134,139,143,94,100,105,154,154,149,174,149,112,158,116,51,156,116,47,153,118,60,207,180,146,237,214,198,207,180,166,156,131,119,174,153,145,148,131,125,125,110,107,93,85,79,86,84,79,74,74,71,59,57,53,76,68,58,137,125,112,143,133,122,133,124,114,106,98,89,86,81,74,87,85,78,84,85,78,75,76,71,50,49,43,40,30,15,95,75,44,132,103,57,183,183,175,108,116,122,142,151,158,165,169,168,177,156,122,155,112,50,159,118,51,122,89,47,213,197,179,237,224,226,220,191,188,164,135,131,183,159,155,156,137,132,125,108,104,120,111,104,78,76,69,80,80,77,45,44,40,91,85,77,175,165,154,157,147,137,155,147,138,107,100,92,87,83,77,103,102,96,88,88,79,78,79,73,59,59,59,41,36,33,59,46,31,104,81,46,188,191,189,100,108,116,135,144,153,170,175,178,187,167,136,166,120,59,173,123,55,134,93,44,117,95,80,194,182,188,199,171,164,170,142,133,185,161,151,189,171,159,134,119,106,117,107,95,102,98,89,84,84,79,38,38,34,125,121,113,210,201,192,160,152,142,146,139,130,93,89,82,83,80,75,94,93,88,104,104,94,85,87,81,73,75,78,55,53,55,62,55,48,76,56,26,189,194,194,90,96,105,127,134,144,175,180,185,174,156,133,166,123,68,178,123,53,159,109,47,97,68,44,168,154,152,168,144,126,137,114,94,186,166,148,216,202,183,160,149,129,123,113,98,120,114,105,115,114,109,50,50,47,150,147,140,194,187,178,155,149,140,123,118,111,91,88,83,84,83,79,84,84,80,95,95,85,86,87,81,84,87,89,73,73,73,79,74,64,73,55,24,189,192,193,93,95,103,152,154,163,185,188,192,119,110,98,136,106,66,173,124,58,167,116,50,103,72,39,147,132,120,145,125,103,167,149,127,189,174,155,226,216,200,180,172,157,141,131,117,126,117,107,117,114,109,71,71,68,154,152,147,186,181,174,149,144,136,114,110,104,87,85,80,80,80,76,72,73,70,80,80,72,99,100,94,100,101,99,90,88,81,97,89,69,94,73,34,194,196,196,108,107,112,168,167,172,186,186,188,105,109,109,99,89,67,156,119,62,167,122,55,100,74,34,115,106,88,138,123,103,198,185,169,190,180,169,172,165,159,145,140,140,154,143,134,146,136,125,103,100,95,71,71,70,152,152,149,179,175,170,137,133,127,130,128,122,110,109,105,85,86,83,91,93,91,95,96,90,109,110,104,115,116,111,100,96,80,97,85,53,117,95,47,197,197,197,132,129,136,172,167,174,184,178,181,130,137,142,78,83,77,140,120,88,155,125,77,115,94,52,130,120,93,143,131,116,230,221,211,242,236,230,145,138,137,135,130,130,131,121,112,121,112,101,108,104,95,95,88,75,144,134,118,168,159,146,152,147,138,112,108,101,87,85,80,71,72,68,87,88,87,105,104,99,112,109,99,120,110,93,103,86,54,121,96,48,136,104,48,203,203,204,146,146,160,168,164,178,191,182,188,168,170,172,78,86,90,126,125,126,138,126,113,138,121,82,96,80,37,154,143,133,173,163,155,162,152,141,140,132,117,113,106,88,113,106,90,101,101,92,105,101,87,112,90,58,171,143,104,156,138,109,148,141,126,135,130,118,109,105,97,78,76,72,79,79,77,94,93,94,101,91,82,107,83,55,125,88,45,151,108,55,144,104,46,214,215,215,163,166,180,164,167,184,183,184,194,176,182,186,94,102,105,96,96,102,156,149,145,148,137,111,106,93,61,129,116,105,118,105,95,114,102,89,116,105,89,102,91,73,115,110,98,86,91,88,101,103,95,144,128,102,118,96,64,68,56,32,128,120,105,133,126,115,75,69,61,60,56,51,58,56,53,71,70,65,102,93,78,116,94,64,143,112,68,150,116,64,140,110,54,212,211,205,178,184,192,167,175,189,173,181,193,176,184,188,124,131,133,86,88,96,141,139,143,153,148,141,135,128,111,104,90,80,77,64,55,134,121,108,124,111,96,129,117,100,147,143,133,85,92,93,92,96,93,150,139,120,132,117,93,117,109,92,107,99,86,75,68,58,64,59,52,44,41,39,65,62,60,86,69,40,133,105,59,155,119,62,160,120,54,154,115,45,151,111,46,199,192,180,187,189,187,171,176,181,174,179,185,177,182,184,144,149,152,86,90,99,119,121,132,122,124,130,137,136,135,144,134,126,70,59,51,129,118,108,108,97,86,145,134,123,184,176,168,116,118,118,73,75,73,131,119,103,137,124,105,134,129,118,89,86,78,51,49,44,52,51,50,47,49,52,90,90,93,121,91,60,163,118,68,171,121,64,164,113,52,158,111,50,149,107,46,165,156,146,195,193,187,179,178,175,177,173,172,181,181,180,152,157,160,99,103,111,131,135,146,171,175,185,103,105,111,93,90,87,80,77,73,93,90,86,122,118,116,178,173,173,191,182,177,150,148,148,100,100,101,89,78,66,87,77,63,60,61,57,46,52,54,38,46,51,24,33,41,46,57,69,60,71,83,108,100,75,144,125,82,144,123,76,128,109,61,127,113,69,120,105,63,117,120,124,195,200,200,177,178,176,178,169,168,181,179,179,138,144,147,83,87,91,150,153,159,245,247,250,219,222,225,133,140,144,134,141,147,149,156,164,176,182,192,190,196,208,194,192,197,168,172,181,125,133,143,110,109,109,61,62,62,35,49,58,34,54,68,49,70,87,58,81,102,61,85,110,58,84,111,69,99,122,72,101,119,78,104,120,69,96,112,59,92,112,55,90,115,79,105,133,175,197,213,174,183,192,176,172,177,177,177,182,140,146,150,109,112,113,211,211,209,253,252,247,252,253,252,208,224,232,124,143,157,114,132,149,124,141,162,116,133,156,122,133,152,104,124,148,68,93,119,68,87,104,60,82,101,52,84,111,50,84,110,51,85,115,56,93,125,56,94,131,51,91,130,43,96,135,51,104,141,59,108,142,48,97,132,43,97,137,42,95,132,41,89,135,96,137,168,144,168,188,168,174,188,178,182,192,165,170,174,165,166,164,246,245,237,253,251,241,227,231,228,110,136,153,60,88,111,53,80,105,49,76,105,49,75,107,48,72,101,45,79,115,42,81,120,46,81,113,42,82,116,38,86,125,46,90,125,46,89,126,43,87,128,42,89,132,46,93,139,46,94,137,50,96,137,55,96,135,53,94,134,51,95,139,45,90,133,29,91,141,29,87,130,59,102,134,131,153,176,166,179,191,132,136,137,194,189,181,254,250,242,241,245,245,141,159,175,61,94,127,50,84,118,50,84,119,51,85,121,49,83,120,50,84,116,47,86,117,42,84,117,39,82,115,34,79,113,35,83,120,39,86,125,38,85,125,42,89,130,45,92,134,56,103,145,62,103,142,59,101,142,56,102,146,50,99,144,46,94,140,51,103,149,48,111,162,30,94,140,34,85,124,73,106,136,128,148,167,128,136,143,215,213,209,255,253,249,187,198,205,66,93,118,54,91,128,50,88,125,52,90,127,52,90,127,46,83,121,45,82,115,43,82,113,41,81,112,36,80,113,39,83,117,40,86,123,40,89,131,43,92,134,46,95,138,59,108,150,62,110,152,64,109,147,59,108,149,54,108,154,50,105,152,70,123,167,83,137,182,52,114,165,35,99,147,31,86,130,41,83,122,66,95,126,128,145,164,224,229,234,240,245,247,124,143,153,58,92,114,49,87,123,56,94,131,54,92,129,44,82,119,44,82,119,47,83,119,46,84,119,43,83,119,43,86,123,44,88,127,44,90,131,45,97,141,54,106,150,58,110,154,54,105,150,46,97,141,43,95,140,36,91,138,51,108,158,73,130,178,85,138,182,76,125,169,50,110,162,35,98,149,29,89,138,35,86,133,44,83,126,78,106,138,202,219,233,211,228,234,97,126,140,65,104,126,54,94,129,48,87,124,58,97,133,48,87,123,40,80,116,45,82,119,47,84,122,48,87,126,47,89,130,46,89,132,51,97,140,39,92,138,39,93,139,48,102,148,47,101,147,39,93,139,28,85,133,40,101,153,67,129,182,67,126,176,46,98,142,51,96,139,50,108,161,35,97,147,32,92,143,33,88,141,41,88,138,46,84,125,104,133,159,170,197,211,64,100,119,54,97,121,52,94,128,53,95,130,61,103,139,58,100,135,54,96,131,45,83,120,42,79,118,41,80,120,46,88,130,49,92,135,46,92,136,42,95,139,40,93,138,39,92,136,37,90,135,40,93,138,44,102,151,63,125,178,47,110,164,31,90,140,15,60,103,51,93,136,68,124,177,42,100,148,31,88,137,38,91,146,37,87,139,43,89,132,42,79,113,71,107,133,49,89,114,31,77,105,27,71,105,38,82,117,49,93,128,56,100,135,58,102,137,53,92,128,56,94,131,60,99,137,57,99,139,53,97,138,50,95,137,45,94,136,39,88,131,33,83,125,42,91,133,62,112,154,79,132,179,73,131,181,56,116,168,38,97,146,13,64,108,40,85,127,61,116,168,49,102,148,35,85,132,43,91,143,39,90,139,42,92,134,44,88,125,40,81,112,42,85,115,27,72,104,23,67,102,30,74,109,27,71,106,29,73,108,36,80,115,47,86,120,56,95,128,62,101,135,66,109,144,75,119,156,69,113,152,49,95,134,43,88,127,43,88,127,60,105,144,85,130,170,109,156,197,93,145,190,60,115,164,26,82,130,29,82,126,20,64,107,54,107,160,56,105,149,45,89,132,43,86,134,40,89,134,40,92,132,40,87,123,38,81,115,36,79,114,26,69,105,22,66,101,29,73,108,25,69,104,29,73,108,19,63,98,18,58,89,32,70,100,47,87,118,61,104,137,74,119,152,66,111,145,53,96,131,52,95,130,45,87,123,67,109,145,89,131,167,105,146,182,89,135,175,48,99,145,24,77,124,34,84,129,21,67,110} + + +#define IMG_DATA {235,235,235,231,231,231,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,232,233,233,233,233,233,233,233,233,233,233,233,233,233,233,233,233,232,233,233,231,233,232,231,233,231,233,233,230,233,232,232,232,234,232,231,234,232,232,232,233,233,230,232,233,231,233,233,233,232,232,232,232,232,232,232,232,232,233,233,233,233,233,233,232,232,232,238,238,238,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,236,236,236,236,236,236,236,236,236,236,236,236,236,236,236,236,236,236,237,234,233,236,234,233,236,236,234,234,236,234,234,235,237,234,234,238,235,236,237,236,236,235,236,236,234,236,236,236,235,235,235,235,235,235,235,235,235,236,236,236,236,236,236,235,235,235,237,237,237,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,235,235,235,235,234,234,236,233,231,236,234,231,235,235,234,234,235,236,227,230,233,231,235,238,231,233,235,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,235,235,235,235,235,235,234,234,234,238,238,238,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,234,235,235,235,235,235,234,233,233,230,232,232,231,228,230,232,223,226,231,186,192,197,209,216,219,207,210,213,228,228,230,236,235,235,234,234,234,234,234,234,234,234,234,234,234,234,235,235,235,235,235,235,235,235,235,237,237,237,234,234,234,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,235,234,234,234,234,234,234,235,235,235,235,235,235,234,234,234,234,234,234,235,235,235,235,235,235,236,238,236,233,237,237,219,225,230,203,210,219,163,172,179,195,205,208,214,218,221,230,229,232,237,235,237,235,235,235,235,235,235,235,235,235,235,236,236,236,236,236,236,236,236,236,236,236,239,239,238,236,235,235,236,235,235,236,235,235,236,235,235,236,235,235,235,236,235,235,235,235,234,234,234,235,235,235,237,236,236,237,236,236,234,235,236,232,233,234,235,237,237,229,231,232,208,216,218,194,205,210,185,198,207,174,188,200,165,179,189,184,196,202,207,215,220,226,228,232,236,235,237,236,236,235,236,236,235,236,236,235,236,236,236,237,237,237,237,237,237,237,237,237,228,229,229,228,227,228,232,230,231,231,228,230,234,232,233,237,236,236,237,237,235,236,237,235,237,235,236,237,235,236,239,236,237,239,237,238,225,229,230,224,228,229,233,237,238,221,226,228,183,197,204,161,180,190,159,180,191,154,176,190,144,163,177,143,159,171,156,169,177,198,206,211,233,238,239,236,237,234,235,236,233,235,235,235,235,236,236,236,238,237,237,237,237,239,237,238,212,220,222,224,230,233,230,234,238,227,232,234,229,234,234,234,237,236,237,238,235,238,237,236,239,237,238,239,237,238,239,236,237,240,238,239,201,204,203,219,222,221,233,236,235,214,218,218,193,204,210,185,201,210,184,201,211,173,191,203,165,182,196,159,174,187,162,176,185,186,199,204,229,239,240,234,239,238,233,238,237,233,238,238,234,239,238,236,239,238,237,239,238,238,238,238,216,234,241,221,236,243,225,238,246,225,239,243,227,240,240,231,238,237,236,237,235,238,236,235,238,236,237,238,236,237,237,237,237,239,239,239,197,198,196,220,221,218,233,234,231,230,231,229,209,213,217,209,216,222,219,228,235,208,218,227,209,221,234,210,224,235,217,233,240,218,235,241,225,240,243,228,238,240,228,239,240,230,240,240,230,240,239,235,240,239,237,240,239,238,238,238,118,140,149,119,138,148,124,142,153,136,155,161,172,188,191,225,234,233,235,236,233,237,234,232,236,233,234,235,235,235,235,237,236,233,237,235,214,216,214,226,228,226,232,234,232,236,237,236,228,230,232,227,230,235,231,236,241,225,232,239,225,237,247,217,233,243,201,219,226,185,204,211,172,189,195,167,179,186,167,180,185,186,199,201,223,235,235,235,241,239,236,240,239,238,240,239,109,130,141,103,121,133,108,125,137,111,127,137,146,159,165,222,229,231,227,228,225,229,226,224,236,232,233,234,234,234,231,236,234,230,237,235,229,234,235,231,235,236,232,237,238,230,235,236,231,236,238,231,237,240,229,237,241,223,232,238,191,206,213,164,184,191,146,165,172,137,156,163,134,149,159,128,140,153,121,133,143,149,162,166,216,228,229,234,241,239,235,240,238,237,240,239,195,212,224,188,202,215,199,211,224,200,211,223,209,217,227,223,227,231,213,213,211,211,209,206,216,213,214,220,222,222,219,226,225,210,221,219,209,219,223,211,221,225,216,225,230,220,229,233,225,234,237,226,236,239,225,237,241,218,231,237,183,204,208,175,198,203,181,200,207,178,194,202,186,197,211,170,178,196,142,151,164,185,195,202,219,230,233,231,240,238,234,241,239,236,240,239,193,207,222,191,202,217,202,211,224,214,217,234,223,225,241,214,219,227,203,208,208,171,174,174,177,180,183,207,213,214,174,184,188,98,112,121,93,114,126,101,121,132,111,129,139,122,138,147,137,152,161,153,167,174,202,216,220,223,236,237,218,232,235,220,233,238,223,234,240,217,226,233,221,228,237,212,219,229,196,203,212,222,230,237,219,227,234,221,230,233,232,239,242,235,241,242,113,130,152,111,125,147,113,125,141,125,131,151,138,145,165,170,182,193,191,201,205,190,199,204,208,219,226,216,230,234,158,172,183,54,71,92,45,70,91,49,73,91,53,73,90,66,84,98,102,114,129,159,168,179,221,227,233,234,239,241,233,237,241,227,231,237,223,228,233,207,211,217,202,208,212,211,218,220,212,219,223,199,206,214,179,186,196,188,197,205,211,221,227,221,231,234,61,81,108,69,86,114,63,79,100,68,85,102,123,141,155,139,155,164,151,157,164,195,200,207,214,228,234,206,223,228,163,180,190,103,121,138,95,112,131,101,117,135,138,151,168,181,192,207,207,212,223,221,222,232,219,219,227,205,203,212,183,186,195,158,166,174,147,154,163,131,138,147,125,133,140,130,139,144,136,146,152,133,142,151,128,137,147,138,153,160,182,197,203,197,212,216,40,53,77,58,70,94,85,98,116,127,144,153,132,151,156,96,107,110,119,115,118,163,158,161,173,180,182,184,194,197,182,194,198,181,193,200,183,194,202,198,209,217,218,228,236,200,210,217,174,181,186,159,165,172,145,150,159,132,136,149,116,125,138,98,111,123,94,106,118,99,111,123,105,118,128,107,121,130,122,135,145,138,151,161,150,164,174,157,174,184,188,206,213,185,203,208,13,15,35,26,29,47,134,140,151,206,216,220,138,150,150,118,123,123,141,133,134,172,162,162,181,181,180,207,209,211,220,224,225,228,234,233,224,234,232,230,241,240,226,238,238,176,189,190,144,159,163,138,154,162,142,158,170,145,163,177,154,171,187,149,165,182,149,165,182,154,171,187,157,174,189,160,177,191,173,190,204,187,204,217,190,207,218,178,196,208,165,183,193,157,175,183,5,5,24,58,62,79,200,207,217,225,232,239,197,205,212,199,207,211,212,212,218,226,224,229,229,230,237,233,236,246,232,238,245,230,238,239,209,221,220,223,238,239,221,238,241,210,228,234,198,217,228,180,200,214,193,216,230,188,213,229,189,212,231,194,214,234,192,212,232,184,204,224,172,193,212,171,191,209,161,181,197,144,165,179,136,156,169,131,146,161,128,143,158,138,154,165,39,45,71,145,155,179,190,204,222,186,196,216,184,197,217,192,211,229,194,211,230,194,208,227,194,206,227,191,203,228,192,207,228,190,207,221,177,193,207,180,198,215,154,176,193,147,169,188,145,161,184,156,171,195,146,163,186,113,133,156,114,137,161,132,157,180,126,150,173,111,135,158,92,115,138,91,112,135,93,114,133,94,116,131,105,125,140,121,133,151,129,141,158,129,142,156,122,135,161,162,179,207,143,160,194,137,154,189,131,152,187,128,152,190,127,150,192,130,150,193,131,150,192,128,147,190,127,147,189,129,149,189,129,149,188,124,145,186,104,126,163,100,122,154,102,120,154,118,134,170,112,128,163,94,109,145,94,112,148,94,117,153,87,112,144,83,103,136,80,97,130,83,103,134,93,111,139,101,117,141,108,121,144,115,125,146,121,133,148,130,144,156,73,87,109,76,90,113,77,90,122,80,93,127,84,98,134,87,102,142,87,102,147,90,105,150,94,111,152,102,119,160,107,124,165,113,131,172,115,137,181,118,136,186,118,132,180,120,133,175,115,136,172,110,133,168,106,127,163,100,119,155,95,109,148,85,101,139,79,97,132,80,92,127,80,94,129,77,100,133,80,100,129,82,98,122,92,104,126,113,119,138,125,135,146,136,149,156,13,25,41,3,11,25,9,16,35,18,26,48,18,26,52,21,25,56,20,25,58,22,30,61,26,36,62,34,43,70,42,51,77,48,59,87,52,69,106,60,75,121,66,77,126,70,79,126,71,87,127,72,88,126,67,81,120,60,72,112,55,67,106,53,68,104,53,69,103,57,69,102,57,71,105,57,78,110,72,89,115,87,100,119,104,113,128,120,124,136,130,136,141,137,146,149,36,46,55,11,16,20,8,13,19,32,44,53,36,45,58,22,25,41,8,11,30,3,8,24,1,4,17,0,2,15,0,2,15,0,4,20,6,13,42,5,18,56,1,19,60,3,23,62,13,29,71,24,38,81,21,33,77,21,31,76,21,38,78,22,44,79,30,50,83,39,58,90,57,70,101,85,90,118,113,115,138,123,123,138,116,115,125,122,123,128,134,139,137,153,160,158,35,41,45,26,27,26,13,19,18,27,41,41,71,81,84,70,70,76,49,50,57,27,31,37,15,15,21,5,5,11,2,2,7,0,0,7,17,17,35,57,64,91,31,50,78,10,36,62,4,30,60,4,30,62,7,30,63,14,35,69,25,43,74,41,55,83,62,71,99,86,97,123,122,124,146,144,131,149,132,120,135,114,105,114,117,111,116,132,134,133,146,152,146,172,179,175,16,15,17,13,10,9,4,10,8,3,12,11,45,44,46,65,52,57,54,43,47,36,33,35,18,18,20,4,4,7,2,2,4,0,1,3,7,8,15,118,117,134,161,158,179,131,128,148,112,112,131,105,105,125,105,103,124,109,105,127,118,107,126,138,115,133,154,126,144,151,126,141,127,106,116,105,86,91,106,94,97,120,116,116,129,130,129,142,147,144,164,172,165,184,194,190,40,40,35,12,10,7,0,3,3,0,4,4,12,6,7,30,12,17,32,12,17,21,10,12,7,6,7,2,1,3,2,1,2,3,2,3,0,0,2,68,58,64,182,128,146,205,130,148,196,127,144,194,123,141,195,119,137,187,113,129,172,110,122,150,96,106,123,75,83,103,66,69,95,71,70,104,93,88,122,118,113,129,132,126,132,141,135,152,162,158,171,182,176,185,197,194,69,77,64,26,29,21,1,1,1,1,1,2,4,1,0,12,2,5,18,3,9,12,2,5,4,1,2,2,0,0,2,0,0,4,0,1,1,1,1,32,12,11,153,45,59,203,47,68,195,46,67,191,48,69,179,50,67,155,49,59,119,42,49,91,38,42,81,48,46,94,77,71,117,110,102,125,126,116,125,128,120,129,135,128,144,153,147,162,176,171,173,187,183,184,198,196,83,94,82,47,52,43,1,1,1,2,1,2,2,0,0,5,1,2,7,1,5,4,0,2,1,0,0,1,0,0,1,0,0,3,0,0,1,2,0,27,3,2,142,25,38,205,32,54,198,25,46,169,25,43,121,25,36,85,29,34,74,41,39,85,66,56,102,92,82,121,113,105,128,124,115,122,126,115,121,127,118,132,139,131,147,157,150,165,179,174,176,191,187,186,201,199,92,102,93,54,60,50,6,7,3,3,2,1,2,2,0,1,3,1,1,3,3,1,2,2,1,1,1,1,0,0,1,0,0,1,1,1,0,3,2,15,1,0,102,19,28,157,31,47,117,17,23,74,13,12,56,27,22,74,58,55,99,90,81,115,115,99,122,126,111,124,124,112,123,123,113,125,130,119,128,135,126,136,145,137,148,159,151,162,176,171,177,192,188,188,202,201,87,99,89,43,51,37,19,23,11,11,12,4,8,10,2,5,11,4,2,10,4,2,7,2,3,4,1,3,4,1,3,4,1,2,3,2,0,6,6,4,5,2,42,13,13,71,21,24,53,27,25,57,50,41,80,77,62,113,98,82,132,113,101,134,126,113,123,126,112,116,125,111,120,128,115,131,138,126,139,148,137,143,154,145,156,168,161,169,184,179,182,197,193,188,202,201,82,96,82,46,57,36,36,44,22,31,35,17,27,30,15,22,28,15,17,26,13,16,23,12,18,21,12,19,21,13,20,22,14,19,23,15,19,27,20,23,31,21,37,40,27,64,55,45,87,70,67,104,88,81,116,102,85,128,112,88,139,121,105,131,122,110,117,122,107,115,127,112,123,133,119,131,139,127,139,149,138,148,160,151,159,172,164,174,189,183,185,200,196,187,202,200,85,101,83,62,75,48,58,67,38,55,61,37,51,56,35,47,53,33,46,53,34,48,55,38,49,55,40,51,56,41,53,58,44,55,62,46,59,67,45,68,71,48,81,84,59,104,96,74,116,103,83,127,109,92,133,116,97,127,121,97,127,127,107,118,124,106,114,125,108,122,131,117,129,136,123,136,145,133,141,152,141,149,162,153,158,171,163,168,183,178,180,195,191,186,200,199} diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_parameter.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_parameter.h new file mode 100644 index 0000000..423d069 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_parameter.h @@ -0,0 +1,43 @@ +#define CONV1_IM_DIM 32 +#define CONV1_IM_CH 3 +#define CONV1_KER_DIM 5 +#define CONV1_PADDING 2 +#define CONV1_STRIDE 1 +#define CONV1_OUT_CH 32 +#define CONV1_OUT_DIM 32 + +#define POOL1_KER_DIM 3 +#define POOL1_STRIDE 2 +#define POOL1_PADDING 0 +#define POOL1_OUT_DIM 16 + +#define CONV2_IM_DIM 16 +#define CONV2_IM_CH 32 +#define CONV2_KER_DIM 5 +#define CONV2_PADDING 2 +#define CONV2_STRIDE 1 +#define CONV2_OUT_CH 16 +#define CONV2_OUT_DIM 16 + +#define POOL2_KER_DIM 3 +#define POOL2_STRIDE 2 +#define POOL2_PADDING 0 +#define POOL2_OUT_DIM 8 + +#define CONV3_IM_DIM 8 +#define CONV3_IM_CH 16 +#define CONV3_KER_DIM 5 +#define CONV3_PADDING 2 +#define CONV3_STRIDE 1 +#define CONV3_OUT_CH 32 +#define CONV3_OUT_DIM 8 + +#define POOL3_KER_DIM 3 +#define POOL3_STRIDE 2 +#define POOL3_PADDING 0 +#define POOL3_OUT_DIM 4 + +#define IP1_DIM 4*4*32 +#define IP1_IM_DIM 4 +#define IP1_IM_CH 32 +#define IP1_OUT 10 diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_weights.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_weights.h new file mode 100644 index 0000000..2c3cedd --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/arm_nnexamples_cifar10_weights.h @@ -0,0 +1,26 @@ +#define CONV1_WT {-9,-1,2,6,-4,6,4,-11,8,-9,-11,10,-12,5,15,11,-1,-1,33,-25,-18,47,-35,-23,25,-27,-5,0,-4,9,2,-5,0,34,-25,-21,55,-40,-33,34,-32,-16,5,-7,2,-21,16,14,-4,5,3,14,-10,-7,3,-10,-2,-8,5,8,-29,23,12,-25,15,8,-15,4,7,-16,5,8,-13,17,12,2,-4,-1,-1,-10,9,6,-4,21,11,0,12,-10,-9,-4,13,10,12,19,11,27,0,-5,11,-21,-26,-28,-7,3,-15,16,14,26,-22,-25,-8,-29,-24,-23,0,6,-13,13,25,0,-21,-18,-3,-21,-19,-13,11,14,4,13,18,-4,6,16,-1,-10,-14,-7,12,9,5,13,8,-4,9,10,-9,-4,7,-3,7,7,-12,7,3,0,-1,-7,2,-8,-5,9,-3,6,-4,7,-10,-25,7,-7,-7,10,2,14,-4,2,17,-9,5,-3,7,-10,-25,4,-10,-8,0,0,16,-7,11,25,-14,13,4,7,-12,-23,5,-16,-17,8,0,11,2,13,21,-11,9,-3,2,-9,-9,-3,-14,-11,1,-1,6,-6,6,14,-1,16,11,7,3,-14,21,6,-6,17,13,4,1,7,-3,-6,2,2,27,13,-5,18,0,-7,-6,-4,2,-24,-11,0,-18,-8,6,24,8,-14,11,-6,-8,-8,0,12,-22,-2,13,-15,-3,7,29,6,-16,10,-6,-4,-12,-7,11,-26,-14,3,-10,-8,0,16,5,-8,-5,-5,3,-15,-2,23,-17,-5,17,1,1,12,10,3,-5,-7,-18,-7,-3,-4,2,3,6,4,4,2,-7,17,20,12,-23,-27,-15,-3,3,6,5,15,6,-2,2,-5,22,22,11,-26,-30,-19,-6,-5,3,10,12,6,2,1,-3,20,14,4,-15,-26,-18,0,-9,1,14,8,6,1,-7,-9,8,11,6,-10,-13,-11,-4,-4,8,2,5,17,-9,0,11,-9,-11,21,6,13,39,-7,1,30,2,12,36,-11,-1,28,-2,-25,-6,6,-16,-6,-9,-34,-24,3,-17,-15,2,-20,-11,0,-13,-11,25,13,6,0,-15,-20,16,7,-11,7,-3,-10,-5,-2,-6,14,22,12,-16,-5,-12,7,23,7,-10,5,-2,-10,-1,-9,7,21,8,-19,-2,-13,2,21,3,-15,9,-2,-4,-2,-2,-12,2,13,-19,1,6,0,16,-1,5,8,-28,11,-2,-4,-10,-1,21,-30,-4,22,-8,14,9,11,14,-21,20,-9,-23,0,-4,19,-28,-9,31,-30,-1,12,3,14,-11,30,3,-24,3,-8,6,-22,-9,31,-29,2,26,-5,11,8,24,2,-36,24,3,-9,-6,-17,4,-8,-8,12,1,-1,5,3,-12,15,-6,-2,-1,0,15,-11,-18,6,-18,-10,6,3,6,-3,3,-12,13,-14,-1,43,-23,-3,52,-16,-11,28,-8,4,-6,5,-11,16,-6,-20,32,-28,-24,38,-31,-22,20,-16,5,-13,7,-2,5,3,-6,17,-10,-8,22,-13,-5,13,0,11,-16,14,-3,-14,6,3,-4,4,4,-2,2,-3,-9,5,2,1,-2,-10,-6,-3,-17,-2,1,-19,2,1,-14,8,11,14,3,7,1,-13,-13,2,-1,-3,-9,0,-5,-18,4,0,18,3,9,15,-10,-8,10,-12,-18,5,-3,-16,-10,0,-14,5,4,14,14,-1,10,16,-6,-2,14,-1,-12,8,2,-18,-13,-1,17,-2,2,24,-4,-3,17,8,-1,12,9,-6,-3,-2,-9,3,-2,-13,-1,-5,-17,-5,-7,-16,-7,-8,-14,-9,3,-9,-1,0,-13,-7,4,-9,-7,3,-6,-8,-2,-4,-7,5,-7,-4,1,-8,-11,10,6,-3,14,12,-1,6,10,-2,0,-12,-16,-3,-9,-19,0,1,-12,9,12,-2,1,10,-1,10,4,-8,6,3,-11,11,14,1,12,19,8,3,16,9,-7,-1,4,-11,-1,3,1,12,8,7,15,13,-5,-2,4,-7,-5,1,-8,-3,2,1,10,9,-1,8,9,-11,-9,-2,0,-1,6,-14,-13,-6,1,3,10,3,4,11,-1,-5,5,7,4,10,-14,-17,-10,-12,-13,-6,-11,-14,-6,1,-6,1,2,-1,1,-5,-7,-3,-2,-4,1,-11,-13,-9,-12,-16,-12,-2,-1,-2,-9,-5,-4,-7,-3,3,-1,-3,8,9,-2,1,8,11,13,5,14,17,1,10,17,-1,3,18,0,-6,0,-1,0,3,4,13,16,-1,8,14,-4,2,14,-16,-20,-14,-3,-3,0,13,21,25,5,11,14,-5,-2,9,1,-5,2,-6,-9,-14,-7,-4,-8,-10,-9,-13,-10,-12,-12,7,-1,-2,-5,2,-14,-5,3,-6,1,9,3,-8,3,-1,-9,2,0,-12,-4,-21,6,17,8,17,28,22,-5,6,2,-15,-8,-7,8,21,-3,2,20,-5,-1,16,-8,7,17,3,0,6,1,11,26,0,-22,-4,-33,-36,-16,-40,-2,14,1,2,10,5,1,17,-10,-16,3,-22,-22,-1,-14,-9,10,6,-7,7,7,10,-8,5,-3,-4,-1,-7,-7,-7,1,0,-2,-7,11,9,5,-2,2,12,14,16,12,7,2,0,-9,-23,-14,-8,-23,-1,-11,-14,-7,-9,-7,14,11,7,44,35,19,34,38,12,1,3,9,-6,-4,8,-32,-28,-19,-41,-45,-37,-14,-17,-17,-7,4,-3,-5,8,8,3,16,21,8,14,24,-3,-5,6,-11,-15,-18,-8,-12,-12,-6,-14,-8,9,-6,1,16,3,11,3,3,-8,-5,0,-6,-13,-13,-13,-6,-15,-15,6,-5,-4,9,16,5,1,14,5,-4,7,-1,-12,-11,-18,0,-6,-12,5,14,0,-1,13,2,2,18,6,-9,-4,-16,0,-3,-17,4,12,0,-1,13,2,0,16,6,-6,1,-9,-5,-8,-19,18,-1,-4,16,-2,-6,18,-1,-4,9,-4,1,-12,-13,-4,9,-3,-9,6,-4,-14,15,5,-2,-5,-5,-1,-20,-9,-3,16,2,-5,12,3,-7,15,7,1,-12,-7,-2,-15,-2,2,18,7,-1,10,2,-5,-1,-8,-8,-18,-15,-7,-2,7,9,-15,-15,-17,-7,-6,-7,-12,-12,-6,-17,-12,-6,9,14,12,13,7,6,3,-3,2,-6,-7,1,-7,-4,3,-11,-12,-6,12,11,6,-4,-3,-2,-15,-12,-4,-7,-4,3,-9,-9,-4,15,17,12,-3,1,2,-18,-13,-6,4,5,10,6,1,5,9,14,8,-6,1,3,-21,-15,-7,-2,-1,5,4,-1,2,4,17,14,-4,4,9,-24,-20,-11,-7,-7,3,-2,-6,1,5,9,-10,6,9,-12,12,11,-7,4,1,-15,11,9,-6,25,15,5,21,13,5,23,14,7,13,2,-3,17,10,6,-1,-10,-2,-20,-21,-14,-11,-11,-2,-11,-12,-3,-16,-15,-3,-4,-14,6,-16,-19,-1,-3,-2,13,-1,-3,12,-6,-10,8,0,-5,10,-11,-10,4,-4,-1,8,-11,-5,3,-6,-1,8,-8,-15,0,-3,0,9,4,11,14,-3,3,4,-15,-9,-6,-12,-14,-1,-18,-8,-1,-26,-12,-8,-28,-12,-9,-30,-13,-8,10,-1,-6,15,17,5,11,22,8,15,24,8,17,25,12,10,-5,-9,4,4,-5,1,10,1,2,4,-8,6,7,-7,5,-10,-6,-1,-5,-3,3,8,10,1,4,-2,-1,0,-8,2,-8,3,0,-6,9,1,-2,-8,6,1,-3,1,-10,6,5,-6,7,-8,-12,0,11,17,-4,-7,-1,-12,1,-2,9,11,2,17,-35,-32,-21,38,52,20,-27,-17,-30,4,2,17,18,10,19,-44,-34,-34,43,59,28,-25,-17,-31,6,0,16,10,4,18,-31,-27,-22,27,31,16,-10,-9,-16,3,-6,6,-2,-11,15,10,0,14,-2,-8,-8,0,-7,-7,13,0,11,2,-7,3,10,4,3,0,-2,-14,-1,-1,-16,-1,3,-6,8,-4,3,12,4,2,4,1,-17,7,10,-8,0,10,-2,-3,-15,0,10,4,8,-10,-13,-24,-7,-2,-16,0,8,-3,-6,-6,7,7,11,13,2,9,-6,-4,11,-15,2,22,0,2,-4,-2,-10,-12,-5,24,15,25,-1,-4,-2,-11,-1,-3,7,11,5,-16,-17,-23,-29,-35,-30,53,45,54,-11,-9,-12,-3,5,4,44,39,36,-45,-51,-51,-19,-28,-16,25,24,28,-15,0,-12,7,1,2,44,42,40,-36,-41,-41,5,0,3,-1,18,5,-17,-15,-15,7,8,14,11,3,4,1,-11,-8,10,-1,-2,-5,-10,-3,6,6,10,5,9,9,-6,3,0,-14,-21,-16,-40,-39,-26,0,4,16,15,20,24,-14,-7,-5,3,-5,1,-13,-12,0,-16,-11,6,4,7,20,-11,-9,-1,11,-4,7,14,7,22,-14,-14,5,-7,-6,12,-4,-9,4,18,-6,5,14,-4,12,-2,-11,6,3,-5,11,4,-10,1,2,-1,-14,4,-6,-23,26,11,-15,12,-7,-33,6,-10,-15,13,6,-20,14,0,-25,2,-14,-34,1,-4,-11,3,9,23,1,6,-5,-6,-2,-8,-7,6,17,-5,18,42,-19,10,42,-3,-1,-2,-2,1,8,4,11,29,-18,-12,7,-16,-7,2,1,-1,9,-9,-9,15,-7,-5,18,-1,-4,6,1,2,-6,-10,7,-2,1,4,-2,-2,-4,6,5,-7,4,3,-7,-2,-11,17,0,-15,-18,-24,40,25,30,-9,-20,-18,1,4,1,-32,-12,-22,54,43,41,0,-19,-9,-29,-29,-25,5,16,20,20,6,8,29,5,16,-60,-74,-65,37,39,43,-5,-2,-2,21,-7,9,-21,-38,-19,6,22,14,2,25,17,-22,4,-11,3,6,-15,-5,2,-13,-2,12,-8,0,13,5,-4,1,5,-8,19,4,-5,28,29,-18,18,19,-20,1,-2,-9,-2,-10,-30,1,8,-57,-26,-3,-47,-28,-10,4,1,3,15,4,-1,-4,-8,4,12,-3,10,48,16,25,38,1,-1,15,-7,-4,23,-2,2,31,-7,-15,23,-17,-19,6,-20,-21,-2,-1,4,4,-4,3,9,0,8,10,-6,-3,17,-2,-11,14,-2,-20,-12,-8,18,-15,-9,20,-4,-1,23,7,6,20,-2,-3,-5,-12,-3,26,-27,-15,17,-22,-10,19,-10,-3,16,-10,-3,0,-7,-1,19,-16,-6,16,-12,-5,16,-7,-5,6,-6,-4,-9,-5,-4,8,-6,-2,9,1,-1,4,7,0,-6,9,5,-13,12,6,4,8,15,10,-22,-12,-15,-34,-20,-19,-14,-2,-3,9,0,7,13,18,21,3,21,22,-31,-11,-6,-24,-5,0,8,-10,-1,-12,-20,-13,8,13,13,16,28,24,5,21,22,3,-11,-5,1,-15,-11,18,6,0,3,1,-8,-1,2,6,-1,-5,-8,8,-5,-8,22,7,-6,6,-4,-13,-4,-12,-6,-12,-9,-10,-9,-9,-11,-6,-6,-9,-6,-7,-10,-6,-9,-10,-11,-8,-8,-9,-7,-7,-5,-3,-4,-5,-4,-4,-6,-5,-3,1,4,4,-1,3,3,1,4,4,-2,1,2,-2,1,5,-3,3,6,-5,1,4,-5,1,3,-4,0,3,-3,2,6,-9,-2,2,-6,1,3,-5,1,1,-5,0,2,-5,1,4,0,-4,-1,20,6,2,20,-2,-17,7,-1,-15,-10,4,-3,-12,-1,16,-1,-4,6,23,1,-7,22,0,-13,10,2,-2,-32,-10,14,-25,-13,11,16,3,6,25,0,-13,19,-1,-10,-27,-2,11,-41,-18,8,-1,0,11,17,-3,-12,26,0,-13,-6,10,10,-22,-1,16,-16,0,17,-3,-3,7,3,-11,-8,-19,14,-3,-12,13,2,-5,1,9,4,-1,-4,10,0,2,-20,18,2,-15,11,14,0,-6,11,20,-11,-17,17,-12,-13,-27,23,10,-18,15,25,4,-14,5,30,-16,-29,26,-13,-21,-33,21,14,-20,13,32,4,-19,2,32,-19,-29,22,-11,-18,-24,19,8,-11,12,22,5,-16,-3,25,-11,-16,7,-7,-11,-6,-3,-14,8,11,2,4,5,-2,9,-1,-1,17,-4,2,-10,-1,-9,-9,3,-4,-26,-13,-19,11,11,14,16,4,12,-11,2,-1,-19,-1,-5,-32,-12,-17,19,23,23,8,0,4,-16,-4,-5,-17,1,-3,-13,4,0,17,19,15,1,-8,-7,-16,-5,-5,-2,14,11,-3,10,6,10,7,3,-2,-11,-13} + +#define CONV1_BIAS {-49,-18,-7,-20,-12,-15,7,2,-10,-84,-72,-65,-53,-6,-87,-63,-64,-28,-28,-4,-3,-10,-52,-15,-5,-7,-31,-44,-102,-19,-5,-65} + +#define CONV2_WT {-3,-9,-16,-14,8,-17,-10,-9,-20,37,-11,-5,-21,9,-22,-10,-11,18,4,12,8,22,11,6,-14,-6,14,15,8,-15,-6,-10,-23,-32,-11,-11,34,29,-5,-14,-13,14,-31,-17,-12,8,-19,-9,11,12,-8,31,35,24,-35,7,16,-16,-6,20,3,0,9,-28,-36,-21,-12,-35,-6,-2,-10,23,10,-2,8,7,-16,26,-13,-15,-11,17,-3,16,15,-2,-23,-9,-23,-13,6,-21,7,-4,-40,-38,-24,-20,-3,-47,19,26,-3,4,21,-4,-4,9,1,24,14,-17,-26,-1,-12,38,19,13,-7,-18,49,1,1,-11,8,-7,-26,-8,-30,14,-28,-49,11,-15,-16,-8,39,1,6,-16,-23,35,4,-8,-7,-15,-15,33,14,8,-9,-2,42,27,4,15,0,-25,-13,-22,14,-10,-44,-35,-10,3,-16,14,-10,15,8,14,6,26,0,10,19,23,15,5,-8,12,-23,7,-18,14,8,19,-4,-9,4,-5,18,-31,-44,-35,9,7,-23,7,13,0,-15,-17,-2,25,-6,13,9,24,-12,26,16,35,-34,-14,19,10,-8,8,-8,16,14,-17,5,-21,4,-17,-20,6,7,43,26,-4,-2,-10,-1,30,-17,-9,-16,6,9,24,15,-21,-41,16,-4,34,11,-8,-6,-4,-39,-19,-3,-39,-21,-9,-5,-1,8,27,10,-21,-7,-3,-5,-10,-11,-11,-36,5,-14,12,6,25,-21,0,2,43,12,-13,3,-14,-36,-11,-10,-35,-37,-49,-7,-13,4,24,22,-16,-4,-16,-17,-18,-8,-13,-22,7,-30,34,6,23,-15,-22,26,3,-7,-5,-3,-20,-8,-22,21,-44,-34,3,-18,11,-27,15,15,4,25,12,-5,33,-4,-3,-5,26,-4,-8,-17,-1,-43,7,-17,13,2,-23,-23,-13,-21,-9,26,-46,-47,-5,-5,8,-34,2,28,-4,33,-23,-24,41,-15,-9,-15,5,-12,-17,6,-21,-20,-22,-6,8,-8,-22,-26,8,-1,-17,25,-28,6,-6,-35,15,-21,48,30,-5,24,-12,-48,70,-13,-12,-1,11,13,3,17,-4,-25,-9,-33,1,13,-18,-16,-15,4,-24,37,-26,11,-39,-17,8,-4,22,23,-7,21,-1,-31,44,-7,2,-37,-5,13,-16,1,2,-37,-20,-3,3,5,-14,-5,-32,-26,-2,10,16,20,-51,-9,12,4,13,9,-24,-19,13,-15,50,9,6,-16,-27,19,23,14,35,-12,-30,39,-18,2,2,-10,8,-17,29,9,-15,-12,14,-19,23,-7,-28,8,6,3,-15,-12,-26,20,-3,13,35,23,-25,-59,-32,10,36,-40,12,8,-8,15,-22,-20,1,-2,-54,-32,-14,-16,10,-30,-54,-3,0,-2,-10,-22,-10,5,-15,-5,26,23,-40,-60,-6,-12,9,-28,-21,4,-29,11,4,-28,8,4,-26,-17,-25,-44,30,-4,-24,18,4,13,-5,-23,15,22,-7,3,33,48,-28,-22,-20,-22,-3,-58,-2,32,5,22,2,-10,-20,-5,-23,15,-36,-28,42,-1,-41,12,1,18,6,-35,-4,14,1,-27,44,35,-36,-21,3,-21,-11,-50,-7,14,7,21,34,-24,1,-2,-12,3,-27,-8,54,1,-10,16,-24,-13,-27,-35,-10,7,-12,-5,21,-19,6,12,4,9,-42,-6,-16,7,-20,4,35,-9,63,-7,7,35,16,-10,49,13,-26,55,-28,17,-35,16,-40,17,4,19,32,-2,-20,-51,-21,5,38,-8,26,-2,-17,25,-6,0,21,-11,-20,8,-1,0,27,8,-38,14,-28,11,-44,3,-32,-19,-8,-25,15,-9,-16,-47,1,7,-10,-8,7,-4,1,20,-9,-34,16,-9,-26,22,-3,-15,49,11,5,21,-27,28,-31,15,54,10,-16,-21,-1,8,-2,-10,19,3,-1,-24,4,15,10,24,17,7,-13,-25,-27,26,-12,-3,9,-2,-5,34,-12,15,-23,-16,26,-2,-10,-1,-11,6,23,-21,15,6,20,-19,17,-2,-20,11,34,-8,16,-19,-3,38,-2,9,28,-9,11,21,-8,-22,-48,-15,-15,-13,-7,24,-7,-3,35,-9,18,-8,13,-1,27,-21,6,-10,36,41,32,11,12,-3,22,-10,13,-2,-16,7,-16,25,31,14,-11,6,7,6,7,-5,35,-22,3,37,18,54,-9,2,-17,-5,-6,2,-7,-1,2,21,8,5,14,8,-48,-18,-3,-3,7,-17,-11,7,23,-6,-21,-25,22,-26,21,-19,13,77,7,-29,-2,-12,1,23,-18,-4,-18,34,-1,2,19,53,6,3,9,5,4,-7,36,5,-6,-11,-18,-5,49,-15,9,15,-5,17,2,-14,12,8,42,59,-40,39,-9,7,-13,-3,-22,47,-9,-7,8,32,2,-27,0,-33,14,-10,-27,0,39,-15,23,-3,0,10,22,-7,-23,5,17,1,17,26,26,37,15,3,18,21,-20,3,-4,23,29,-7,-21,-32,34,-6,-2,42,22,-7,34,11,2,30,34,-4,-14,-7,10,14,4,6,-9,-9,37,-39,0,2,-14,21,-45,-5,28,-2,-6,8,0,16,37,-8,3,-25,30,57,15,-16,-28,-8,-17,4,-2,-45,1,-8,10,-18,1,19,-17,-11,-39,3,-27,-6,14,-19,-14,12,16,-25,-24,-41,-26,-11,57,20,-12,16,-3,-17,-1,-9,-3,-1,-5,-38,43,4,16,1,-14,38,-3,17,-5,-2,16,-16,17,26,-2,4,-17,-16,0,-10,47,25,9,22,13,-15,-16,14,13,-1,-17,-5,32,-13,5,5,-33,4,-34,9,12,10,18,-1,-27,-21,-1,1,7,11,-21,-13,4,6,12,46,24,-25,-4,-1,9,-25,18,-1,43,12,17,-15,0,-11,-22,-2,-3,-4,17,-30,3,-22,7,-12,22,34,-48,-22,-8,2,2,-6,18,-14,15,-5,16,-2,1,14,-22,-14,4,-42,-19,-30,11,16,10,-28,10,22,-7,5,-30,-14,46,29,-53,1,-37,29,2,-74,12,13,20,0,21,-40,-2,20,-10,-60,-16,-38,-4,-24,-13,0,-6,-12,-14,-1,-16,5,-20,-42,4,30,-110,-3,-6,5,-6,-85,-1,6,8,-12,-2,-49,1,-14,24,-17,11,-50,21,18,25,38,-22,-3,-16,-1,-15,24,-19,3,-16,39,-52,3,-24,3,27,-64,37,18,26,8,-4,-43,2,2,-14,-70,-15,-58,-6,-23,2,2,-8,-2,-4,15,-18,3,-27,-20,-21,3,-115,3,-33,31,14,-50,28,-13,20,8,-55,-51,34,19,-16,-42,17,-62,-9,-24,11,5,5,22,1,12,34,16,-19,-19,23,18,-103,-13,-34,29,12,-57,-2,3,17,0,-17,-25,8,9,-22,-36,-20,-34,15,-9,12,32,31,-18,17,-3,-23,-8,-8,-1,31,15,-37,-3,-29,24,1,-34,24,28,-7,11,21,-18,-21,18,-54,-68,-35,-63,-1,-19,-1,-16,8,-19,0,-19,-18,-2,-17,-39,16,3,-68,-21,-75,-17,-3,-80,-12,24,-46,4,-7,-45,-6,5,-26,4,-1,-44,39,20,18,4,-8,-2,12,-5,-16,12,-5,-17,15,6,-17,1,-75,-25,3,-51,12,46,24,19,-3,-31,1,23,-11,-58,-23,-88,8,-5,-24,-6,18,8,7,1,-27,21,-2,-32,11,-18,-88,2,-74,-6,-15,-52,-7,24,6,11,-36,-48,19,19,41,-13,3,-67,6,20,-13,31,33,5,-7,-4,4,20,11,-2,23,17,-43,-6,-49,-12,-15,24,19,34,42,8,-9,-27,-5,20,39,12,-17,-18,20,6,3,31,-11,-5,-26,26,16,-7,-5,-2,23,29,47,11,28,13,8,35,21,-7,21,3,50,1,-23,2,3,-10,-8,-36,-9,-25,-4,28,-23,-25,-17,-11,-1,2,-11,-2,-7,32,-5,1,-16,4,8,-12,-12,-5,3,1,-4,-19,-6,-28,5,17,-1,-2,19,9,32,17,-17,-18,13,-17,10,8,-5,1,-23,8,27,34,-42,-25,-8,-4,16,10,18,23,9,29,-5,3,6,-46,-26,-50,-37,-13,6,-27,6,1,-8,15,0,-7,5,-10,-18,4,-9,28,-14,-30,6,36,19,1,6,15,-35,-17,10,26,21,-1,15,6,-25,39,4,4,10,22,-26,23,-1,-1,13,16,9,-9,-2,21,7,2,22,56,25,28,36,19,4,26,9,-7,3,15,-6,-21,5,-14,28,-4,-44,8,-16,16,8,14,-18,25,-21,-5,13,-12,5,-2,4,-5,-13,27,-11,13,-13,-10,11,4,20,50,-10,11,12,1,42,-7,-5,-12,14,4,-4,3,-28,24,-14,14,0,-14,9,-1,-22,2,13,15,-17,21,3,-16,9,31,43,-36,12,8,-4,15,40,-6,29,12,14,-4,-5,-2,-37,38,-14,-5,-1,-23,-5,12,-21,-8,35,15,-4,21,-13,20,22,12,-22,-26,-13,-7,7,-26,17,-26,-11,3,-15,8,17,0,-15,-5,-16,4,-31,-3,-68,0,-22,-38,16,-3,2,21,-26,-45,10,15,-3,-25,-25,30,20,-20,15,22,-13,-5,10,-6,20,4,5,1,-12,-13,-12,-4,-2,19,-37,-17,0,17,11,15,-3,3,29,-7,-22,19,9,-11,5,19,24,-17,-51,23,-31,-19,22,4,-17,14,-30,-22,-20,-15,14,22,-23,5,-17,25,11,11,-2,-17,-6,3,4,32,14,3,13,19,12,-33,0,31,-13,0,3,-20,-30,0,16,11,-19,-33,-18,6,8,25,-2,13,-1,5,-18,-18,10,27,44,-11,22,2,-22,26,11,4,38,22,-9,11,-7,-31,-16,14,46,-2,-38,-24,-19,-3,30,24,59,-15,-20,-2,-29,43,2,0,-31,-21,-50,-27,-21,2,16,-5,-4,25,-12,-5,-15,-10,-10,-14,6,13,-55,-18,13,17,8,-43,31,-28,0,0,5,-37,-8,25,-25,-22,-61,-10,-14,25,18,38,-17,9,12,9,24,-21,-15,0,1,4,-15,-9,-18,34,-21,-8,14,-15,16,-18,25,-1,15,-15,-16,-14,5,18,-37,24,23,-17,-20,9,-22,-15,33,2,13,18,-7,-32,-2,-15,-14,3,-26,-3,1,10,-8,-24,12,37,-28,-12,52,-19,11,-6,-2,18,2,-6,14,0,-11,-4,-27,-10,18,7,33,10,-13,3,-22,7,-13,35,32,-5,-29,-18,-18,54,-16,-13,66,11,26,-9,4,14,-40,1,36,-16,14,-20,-58,-20,9,-17,26,2,-25,-10,-16,-16,14,24,74,-26,-11,-9,-27,99,13,-24,-29,-1,2,-4,-18,8,-11,21,-2,-3,6,-13,-6,18,-13,-14,-1,25,-49,0,12,-10,1,0,23,-19,-5,-17,-7,20,-13,-10,1,43,-12,-5,0,36,9,44,24,-1,29,10,30,-6,-3,-12,33,9,-14,9,30,17,-38,-12,23,-29,22,-33,5,12,-1,-27,17,-9,-9,5,-5,2,12,-5,14,9,-32,10,33,15,36,-2,23,-5,-19,-8,-18,-3,24,-14,7,25,3,-15,33,27,6,-32,13,13,7,-14,-2,-25,-40,4,7,-5,-17,-11,-30,27,17,21,18,-18,-12,4,-20,-4,10,-40,0,0,-53,-10,26,58,-13,-42,5,34,23,20,-3,-58,-98,-17,25,-17,1,-30,-74,-5,19,4,-19,-48,12,15,-22,-17,1,23,-43,-13,-32,-7,10,74,-7,-53,15,22,12,10,8,-87,-83,-1,9,-23,2,-40,-21,5,-12,19,-31,-12,-7,24,-20,-42,-23,-13,-65,-21,2,-10,-22,1,-34,-24,9,34,-10,-9,24,-70,-60,25,14,-7,7,-21,14,0,12,-25,7,-16,1,25,20,4,-18,-24,-51,-30,2,-14,6,6,-12,5,15,-9,-12,-26,31,-2,2,-7,-23,14,-30,25,-10,16,56,-6,2,9,10,-5,24,7,-16,20,41,18,-5,-8,9,1,10,-15,7,0,13,-32,-8,-23,-37,-7,-19,-7,-9,-3,-30,4,32,14,-12,-17,10,-2,2,11,-35,-4,7,2,-37,-5,4,30,-14,-52,25,41,1,11,-41,-48,-70,6,1,-31,-24,-35,-22,-22,0,8,-20,-24,22,25,23,-6,-15,33,-45,-11,-17,-1,7,27,10,-60,26,25,0,27,-34,-63,-63,4,-10,-17,-34,-35,6,-5,-14,20,7,-20,6,37,9,-25,-16,28,-32,-28,-15,-5,3,4,-48,-30,12,8,3,8,-24,-58,-65,1,-4,-9,-36,-8,3,2,67,-35,32,-13,10,36,38,6,-28,50,-25,-44,-9,-12,0,-11,-35,28,18,-7,-13,7,28,18,-13,6,6,7,0,-26,7,59,18,-2,22,6,-2,-80,33,6,-11,4,-5,-9,33,-2,-16,-20,-19,16,12,1,-36,-6,22,45,-3,-28,32,17,-7,-55,6,1,-5,12,-11,-15,21,-37,23,-14,-5,-4,2,-8,8,4,36,37,-53,-16,3,1,-11,-1,48,13,25,-22,23,0,-23,-49,17,-22,16,4,-8,1,4,-14,-23,4,16,-26,18,-21,12,1,7,-6,24,-6,30,-44,-25,-50,-11,-35,22,-37,-21,-6,8,-8,16,14,13,-9,-9,23,-50,-20,-55,7,1,-50,16,19,12,3,-16,-36,5,18,-4,7,15,1,17,1,17,-33,-16,-11,16,1,-16,20,3,-12,-23,11,-2,-17,33,13,3,-15,18,15,48,-6,-12,-27,10,-35,33,6,-7,5,10,14,-26,3,-15,23,-10,-27,-2,22,20,20,6,21,46,-44,8,-10,-14,38,-26,-34,22,-35,-14,-6,-33,-18,19,35,-1,42,14,46,-19,-1,22,10,-25,-37,16,-21,-2,23,-18,33,39,-9,58,-29,23,61,50,-24,11,-25,14,30,-47,-37,-6,-3,-19,18,9,2,10,-5,-20,5,-20,-18,17,-15,3,-3,0,27,23,25,13,1,34,8,40,-19,-15,-11,26,-15,-24,-15,-6,-54,-33,-41,-3,-36,-2,-25,-30,0,-3,-7,-1,-16,5,-7,17,-3,-49,-5,-65,14,-8,-49,14,25,-14,-4,-2,-52,-2,-4,-37,-22,14,-6,11,-21,14,-8,-21,6,3,-25,-1,-12,26,-5,12,-22,-9,5,-45,5,-7,-46,19,26,14,-17,-9,-48,3,-51,33,25,-8,52,-32,21,2,5,0,5,-4,-8,-7,-17,-14,-13,-14,29,28,-25,39,8,-16,30,11,-11,-23,6,8,18,5,-17,22,25,3,47,18,30,18,-8,-12,-6,-28,1,8,-22,-7,-22,6,33,9,22,48,-17,30,74,9,-20,-38,5,3,46,-2,-14,-24,-25,-7,8,-2,-13,31,-22,-33,-3,-12,-3,-32,-10,9,-17,6,38,8,28,-7,26,8,-10,-9,-28,-43,21,28,-4,-22,18,-26,-58,-29,-35,-7,-36,-4,-21,-17,-12,-2,12,25,-10,-1,-8,11,19,-46,17,-60,10,-29,-67,-33,16,-20,19,-14,-56,-6,28,-43,-18,11,-19,7,-20,-3,-16,-33,0,-9,22,36,-4,25,-2,11,27,-24,27,-43,-14,-27,-31,-3,11,-8,8,-16,-47,-2,-26,-17,-4,-22,-9,-17,16,-3,2,5,-15,-19,3,-24,-34,-21,-30,-28,25,-17,-35,-14,2,11,-3,22,7,-8,15,-38,-22,14,-7,-12,-8,-12,6,15,38,14,26,-5,-16,-15,14,-2,-39,-12,-25,-10,13,-48,12,-17,-1,3,22,-18,5,5,12,-34,0,-2,0,-21,-33,15,-6,-29,-6,14,2,-7,-13,-6,0,5,-17,-6,4,1,11,-11,20,-28,25,7,-36,3,5,-4,14,2,-27,-9,35,-16,-52,-24,-25,-16,-42,-20,-5,6,-10,-14,15,-2,-12,-3,0,-7,7,-31,-3,-47,13,-18,-51,-3,31,-15,13,-13,-49,1,38,-20,-20,-22,-22,14,-36,-2,-5,-6,5,-40,25,16,-9,1,6,1,18,-33,22,-29,-8,-19,-38,6,18,-4,11,-9,-57,13,-5,10,26,10,-5,-48,-13,-11,26,23,-34,-16,7,-2,-28,-22,17,13,-16,36,-10,13,-2,-22,48,29,10,-24,-25,-31,-26,-7,-11,6,11,35,28,-15,-1,19,48,17,-9,-21,31,3,-40,-19,11,11,-4,9,20,-21,-8,-5,23,16,6,4,-16,-22,-4,-2,-14,-30,-46,24,11,-23,-29,11,36,7,4,-9,-4,13,-29,-14,6,8,24,27,1,-9,17,10,-12,25,9,-3,-4,6,-26,16,15,-3,-41,-15,-11,-21,-32,-5,-2,19,1,-6,3,16,-16,-13,-4,9,6,-17,-3,-40,-4,10,-25,-27,37,-9,8,13,-53,3,18,-22,-9,-42,-26,-11,-28,21,-16,6,2,-26,14,5,-14,-18,-8,-6,7,-35,18,-21,-15,13,-30,-3,23,2,4,-3,-56,26,-29,-17,-2,13,10,-55,-25,-44,-63,21,9,5,24,-32,-46,-23,-24,-24,-7,-41,2,-26,8,-23,6,17,-8,17,7,15,14,30,-9,-27,-15,43,31,7,-7,-30,-1,3,1,-14,-6,-12,-28,-26,5,4,1,20,25,-41,5,-5,-21,2,-12,8,7,-21,38,10,-1,-17,-6,47,22,-2,16,-27,14,-36,10,-13,-6,10,-2,-27,24,42,-9,20,2,-23,14,7,-16,31,-11,0,15,4,46,26,19,-10,-15,21,-21,-7,17,-32,1,8,-1,-29,2,-14,-30,-10,28,25,-10,8,-24,-34,5,3,-15,11,-25,11,10,9,-13,-1,1,-9,5,10,13,26,58,-14,23,-13,-13,-13,-26,-26,-6,-30,24,-12,-1,23,-29,4,7,-12,23,14,-20,41,5,27,-12,15,-10,6,0,-2,16,-24,-21,3,-21,9,-14,-38,9,-11,-3,-3,-12,0,23,0,-4,4,20,15,18,15,-26,21,3,-10,-8,40,19,-23,-1,10,21,7,4,-18,6,-2,-27,-32,-19,-9,-16,8,2,-32,16,34,20,5,17,10,14,-18,-40,15,-5,-15,45,-11,25,3,26,27,41,21,6,-22,23,-32,0,31,-22,2,15,-16,1,-30,-6,23,13,-2,28,18,17,19,-15,8,4,-9,64,48,64,-10,-16,13,-5,-7,-12,-10,-6,5,-9,20,-32,-32,15,-25,26,-15,-18,14,-13,-26,24,-5,25,4,-14,18,3,9,26,17,38,19,-25,38,-17,-23,-2,0,-15,-18,-2,-20,-14,-6,-11,-27,20,-11,-6,11,-41,-21,-4,-8,25,-2,-17,-42,-13,-1,-15,7,5,19,8,13,39,40,-10,17,-33,2,-10,-10,0,1,22,-16,31,52,1,-7,-9,41,2,19,5,-23,-8,-19,17,5,15,36,55,9,2,-4,12,25,14,-3,-14,14,-16,-8,1,48,4,7,7,18,12,4,19,23,-51,17,18,15,-25,30,9,-10,44,-14,60,-2,5,3,22,43,16,9,-13,15,32,20,-24,11,3,-2,-27,8,6,-18,20,-4,-23,-1,27,47,3,20,6,-15,53,50,75,-9,15,-14,0,31,2,10,-13,23,15,18,-22,-19,4,9,8,18,-14,9,-1,-28,-3,-19,-13,20,23,32,2,-7,-12,20,10,32,-10,48,-8,-6,6,18,-34,17,22,16,23,-17,-20,12,7,18,-12,9,-45,-11,-30,2,13,2,22,10,0,-29,-31,28,-7,-13,-25,9,9,53,13,17,-38,17,-26,-17,-26,23,27,-9,14,12,-23,-28,-3,24,-9,-20,-11,0,2,17,-2,-13,7,31,25,-9,-42,-37,-27,7,14,17,-27,28,-27,-13,-2,7,-2,-20,3,-19,-3,-17,6,-62,-44,-8,-40,14,-12,-3,-9,-20,-1,-36,58,-3,-29,-17,-33,4,-25,23,-36,37,-1,18,10,18,-3,-7,-22,-11,-27,-50,15,-60,-10,25,-37,17,8,4,2,-29,-9,-10,57,13,-21,-12,-40,17,-13,11,-49,2,-9,-1,6,-6,-6,8,6,14,-33,-28,-14,-61,9,11,-18,18,36,-25,-1,-28,-32,-28,-10,42,-13,36,-8,26,-14,33,-62,-24,-12,-22,8,3,-22,13,11,19,-55,15,-30,-75,-11,7,43,-17,34,16,-10,-21,14,8,-8,10,-14,-12,-24,60,-1,5,11,-7,-4,17,16,46,30,0,-15,49,32,-9,-27,5,-21,17,-9,19,-23,28,-5,35,-5,-1,24,-27,-53,10,-21,41,13,8,-16,-3,-22,31,9,25,34,-10,-8,36,15,12,-9,-29,-20,9,-33,14,-31,-9,0,-19,-8,-9,30,15,-16,-10,-34,21,-51,19,-48,22,-1,23,20,5,24,-6,12,29,2,-24,4,-50,-26,0,-9,34,-15,1,-2,-12,-45,-15,26,20,24,-6,-44,34,-4,14,-71,28,17,10,17,6,2,6,24,12,5,-12,-25,-39,-4,21,-1,10,19,-11,-4,-7,-21,-6,-15,25,26,34,32,57,3,17,-54,6,11,13,4,-10,-12,24,19,-5,-5,39,-37,-59,4,35,-10,-21,34,-11,-7,-48,45,17,-17,27,10,-19,-17,-10,-19,-11,-1,-37,21,-24,-15,6,4,32,-14,-6,-14,4,-18,10,27,5,-18,14,22,6,-13,-12,-41,-1,-27,18,33,-25,10,10,-1,3,-16,-24,12,-3,-7,-7,-6,11,-27,-22,-8,-4,-3,-8,-5,13,-10,18,-9,-2,-20,11,-11,19,-6,20,54,-10,13,32,1,-21,-10,-8,17,-26,-4,-12,35,7,-14,-23,-10,11,-13,1,-8,-15,12,-3,-7,-3,-3,24,21,14,9,-21,12,2,37,-31,-3,3,4,2,-7,-20,23,-16,49,2,-9,-8,-16,3,-26,14,-14,-21,-18,-17,-17,26,8,14,0,-4,30,-8,22,13,-2,-24,-16,-6,3,10,-9,-23,-3,-23,27,3,-19,-6,-41,-9,-4,-13,-17,-25,-40,-45,-16,-1,17,6,-22,15,-25,37,12,-3,-5,25,-11,-1,23,0,42,-8,0,4,-1,43,-6,46,16,-21,-1,-7,17,8,21,39,-5,0,0,20,-42,10,-26,13,20,-19,-13,22,9,20,6,3,13,-1,-14,-20,-7,10,-13,19,9,-18,2,-5,-27,-3,-15,14,1,10,-20,37,-31,18,-3,6,58,7,-12,19,6,-2,-26,27,18,1,-7,-21,6,32,-5,-13,-8,4,-15,-1,-32,8,27,-41,11,-9,-18,32,-11,-37,6,-8,9,36,11,-30,4,-1,-4,-3,-21,-13,-6,-7,-20,-17,3,-13,2,-11,-18,-16,2,32,-4,-38,-2,-11,-1,-5,-8,-24,14,0,-9,21,-9,-13,-8,8,5,11,-50,-21,-19,-19,-25,-36,-11,-16,-1,-19,5,-40,-8,3,-9,-51,-8,-24,8,-26,-13,3,-13,36,-14,18,-5,36,-52,1,45,15,0,-30,32,-21,24,13,-2,10,12,-52,19,-40,6,-51,-46,44,-47,-19,33,23,-37,7,-11,34,30,11,-17,19,-35,11,6,31,-14,-23,17,-21,10,16,12,-16,-28,-24,17,-32,-11,-30,-12,22,-28,-16,17,28,-17,7,3,-11,108,32,1,18,3,-6,-43,30,-1,7,0,-10,-22,33,6,2,-24,-7,-10,-44,-18,37,21,-26,4,12,7,7,-31,-17,-3,17,34,27,-17,-21,3,-2,-35,1,4,13,11,7,-49,-11,5,13,12,-17,-30,-34,8,22,19,-31,6,12,-10,-29,14,3,-6,15,22,33,-15,-14,0,14,-15,-6,-12,15,-39,36,-52,-35,0,-13,47,-38,3,-26,-29,47,28,4,0,8,-24,-17,9,9,-3,17,-28,10,-29,-11,-49,13,24,22,-16,-10,33,-11,0,-8,-28,-17,16,-51,18,-45,-18,-7,-34,16,-30,-25,47,-26,-27,-2,-10,24,18,41,-12,-38,-27,10,-20,33,-1,-23,29,-22,-6,-1,5,-9,-24,-25,0,-44,-20,29,42,1,-18,-29,28,-12,-9,-11,-6,-17,49,45,2,-23,25,-18,-41,-2,14,0,0,-12,-31,21,11,-11,-42,-26,-36,-36,-3,46,15,-8,-8,-24,18,-26,-5,-20,-5,-27,23,27,-17,-21,16,-20,-25,-26,28,-3,13,-9,-37,-10,8,6,-11,-10,-41,5,15,36,38,-21,18,-3,-21,-22,19,48,4,0,-4,7,-9,17,25,4,-27,-18,28,12,-22,49,-30,-19,15,6,7,-25,13,0,0,1,18,6,35,-10,-40,8,26,42,-21,-8,-18,50,-23,1,-37,35,14,6,-29,13,22,-30,8,-13,-5,-8,2,-9,-9,-14,-23,36,-4,25,-36,-15,21,-34,-30,-11,-28,7,9,78,-15,-22,-7,3,-9,-1,-6,-8,16,-15,3,-7,51,4,0,-13,-34,-35,5,32,24,-7,-21,-16,6,-9,-5,-22,-4,4,6,42,-9,-30,29,-39,-9,-7,14,-23,-42,-6,-20,-15,25,-5,-19,-19,-33,-21,-32,8,0,8,-13,-10,5,-25,26,-51,19,8,-5,-12,-14,-25,26,-33,-12,-33,24,-35,-29,8,-22,-34,-9,0,-16,-22,-25,1,33,0,34,16,4,-10,-2,1,32,33,23,-16,14,32,0,25,42,18,0,-14,32,4,-10,33,-14,-15,12,-14,25,10,30,-6,35,11,36,27,17,4,-8,3,40,44,14,-3,-8,36,-16,-3,-2,-11,11,36,-5,2,7,-39,-27,-28,8,-26,-14,4,-8,-22,-26,-6,-21,15,-2,0,-5,49,-2,31,10,-50,-4,-2,24,9,2,6,-11,12,-12,-16,22,-35,-16,-26,22,-20,-20,25,13,-5,25,-20,-45,-25,13,17,-15,33,-11,20,7,-59,5,-17,17,6,-11,1,-8,2,-25,-10,26,-27,-7,-14,-5,-10,-15,-11,-2,-41,8,-13,-55,-38,28,44,-23,12,-28,-8,13,-14,-27,6,-19,3,-14,-9,-18,28,-26,-16,23,-24,-31,-9,-10,-6,-16,-26,4,-45,10,-12,-38,-31,19,4,-26,-1,-9,5,-8,16,-4,37,20,21,10,-7,-14,27,-27,-32,37,-30,0,23,-24,-16,2,15,9,16,1,-17,-16,-4,4,26,-29,13,23,32,16,-5,-10,27,-5,-17,-12,-2,22,16,-3,21,30,1,0,-18,4,-5,-23,-13,8,-22,-15,-35,8,-25,5,8,7,27,-28,9,22,-16,-34,25,3,11,7,0,30,25,7,1,27,2,-17,6,1,10,-12,-20,18,-40,12,-21,-37,-20,12,8,1,21,-20,-12,-1,-47,-59,-23,-6,32,-2,-11,15,4,-15,0,-16,-11,4,6,-9,11,-7,-5,4,-95,10,4,-77,-6,4,16,-8,-15,-50,-28,1,-6,-61,-17,-40,8,-13,-14,-18,12,-2,-4,-28,-13,-16,-6,-12,-6,4,-28,0,-91,4,18,-65,-13,6,-8,-5,-2,-43,-10,0,-2,-20,28,6,11,-11,3,-13,-10,-8,1,-5,-2,11,69,-13,-1,10,6,9,-23,10,8,-23,13,4,-1,-1,17,9,29,8,38,5,-20,2,-18,-32,-12,6,-7,6,3,-31,-27,1,-14,10,-46,3,-6,-6,34,6,-2,2,3,-16,6,7,13,11,30,-1,-5,7,2,32,20,-10,-15,14,-11,28,-30,0,23,-9,-2,11,1,11,-1,16,24,0,-22,14,-7,-18,-8,13,4,47,8,1,-11,-14,-29,-21,34,2,-28,7,-37,40,2,6,58,-9,8,-31,11,26,-37,-2,-24,-7,7,-31,31,-13,-10,7,-21,-19,-17,-14,2,-24,-44,-28,0,-17,-32,0,11,33,-2,-32,24,-13,-2,-16,9,5,-8,-7,-55,-12,18,-10,33,-13,-24,13,0,-21,-11,21,39,10,16,10,1,28,-11,-6,0,0,2,-16,-26,20,60,-18,13,23,8,-11,3,-2,-4,48,29,-9,-12,14,6,36,-17,-11,2,-3,-1,-11,-26,-7,18,-23,-7,9,-21,11,-28,36,16,-3,7,-13,-1,-19,-20,-9,36,34,-18,-21,-7,-5,-4,28,14,-17,24,-9,21,13,-6,19,34,23,19,8,-44,9,23,8,-4,6,33,9,52,8,13,14,35,26,-31,-25,0,19,-8,33,-19,-13,-7,-9,13,23,50,26,42,11,14,46,8,18,37,0,-6,9,65,42,10,31,-24,-10,49,-7,25,1,46,10,1,-11,-9,-7,13,-35,-30,2,39,9,27,25,18,21,5,-18,-10,35,-27,-15,60,39,17,6,11,-36,34,-43,24,4,1,18,2,-16,15,33,15,40,16,33,23,37,18,28,7,7,5,8,-21,37,20,2,22,19,62,0,40,-22,1,15,-3,-14,-14,11,3,36,-18,-8,7,-57,9,36,-11,-22,-17,-16,38,-19,-10,5,-32,16,-1,3,-13,-53,36,-19,-5,0,8,54,-13,-34,-38,8,-34,-7,40,-30,-36,-19,-23,7,13,10,-2,-27,25,4,5,-34,17,-4,-14,5,-13,-4,44,-9,-22,4,26,15,-20,-23,-30,10,-22,11,-11,-23,-10,-13,3,50,41,-1,8,-1,-4,28,19,0,21,-14,10,44,-6,12,33,26,-34,-13,36,36,9,-2,-3,-4,3,-27,-27,-19,9,-30,-41,-9,29,-5,-7,10,-5,6,15,-32,18,-14,-2,-3,16,-13,1,5,-29,9,28,-24,2,14,-26,1,16,-62,6,-15,-5,7,-56,24,40,25,16,2,-20,-25,4,-7,1,-8,4,-16,17,-20,44,1,64,-35,2,-3,5,0,-26,-9,-12,1,-2,18,-15,8,9,-24,15,11,10,-27,3,14,-9,8,-25,-16,4,6,-4,23,-19,-11,-6,11,-18,-6,16,36,-15,-10,-3,11,-3,5,1,-2,3,-9,32,18,21,-6,11,-6,0,17,-27,30,-21,5,-11,-7,2,-3,11,-22,-2,27,-13,28,37,-17,-20,-10,2,9,0,-17,17,-4,3,-25,1,-13,3,-8,4,20,-53,16,17,-7,1,-9,17,-33,7,23,-9,10,-18,11,5,-10,-2,2,0,15,13,11,5,0,-22,-23,-17,-9,-8,-1,-10,-11,-32,-8,25,-4,10,-23,-5,-9,-5,27,-6,28,7,-2,-40,-8,-10,9,-1,-4,6,44,20,-10,-20,-4,7,9,39,30,-17,-16,-15,-11,27,-17,0,27,-17,-11,-22,7,10,21,14,-1,10,10,7,34,-15,-11,-5,0,-10,2,-26,8,14,-16,3,1,25,11,-25,-9,16,5,-20,31,16,9,29,1,14,-5,-46,25,-33,-2,-18,-1,-6,1,-18,-13,32,3,-9,3,51,-18,4,-8,1,-5,-46,-13,-8,21,-9,-2,30,-1,-44,-22,-5,-40,-19,8,-16,-3,6,-10,29,-1,2,-31,15,-2,-25,-26,6,-31,-11,6,-14,-1,-37,-4,25,-10,-9,-27,11,-18,-21,15,6,45,4,-6,-38,-12,-16,7,-19,-15,31,-22,-12,13,-30,-10,-28,-6,-12,5,-36,-45,-12,6,28,-42,-8,-11,11,3,-24,5,19,99,29,-22,-13,-8,2,-6,-24,-3,15,17,-9,-2,-2,-12,15,16,19,-7,-15,-14,-18,11,21,-31,-10,12,-6,17,28,4,-14,34,4,-8,5,-3,-5,-12,-11,-13,-25,5,-9,16,-7,-2,17,2,21,14,27,-12,38,-40,17,-16,-1,12,9,-4,57,21,-6,-30,-5,27,-6,1,3,11,-24,-33,22,-33,-2,20,-10,-2,46,5,2,33,22,-1,-43,-21,-20,-11,7,-12,9,-1,-19,45,26,-1,5,11,-15,-6,-9,22,-10,-15,52,34,12,16,-7,-47,-34,-6,-10,4,-4,-22,-60,14,-5,-27,10,-31,6,-7,-28,32,26,127,55,-12,-9,-17,-13,30,-35,-13,70,47,9,-1,0,-22,-48,-9,18,-11,-14,-51,-14,19,9,-36,2,-2,8,6,-55,-1,-2,110,17,-28,-30,-14,-6,-8,-13,-1,16,11,25,23,9,-15,4,4,24,2,22,-22,5,10,29,-1,-7,-8,17,14,-16,2,-4,20,-7,9,-9,5,-5,-13,-11,-22,-11,-20,-6,6,-19,-19,-48,10,34,4,11,13,35,-34,16,4,-15,22,-23,-26,65,5,-6,24,-19,7,-26,17,-18,33,-8,-26,18,13,-16,-6,1,-29,-49,0,12,8,-22,-26,-5,2,-8,-28,4,-2,-2,-19,1,6,0,25,25,-8,-33,-3,-18,-2,-29,-35,72,53,47,-17,-8,-35,-68,-8,-15,-31,-21,-32,-38,3,-14,-12,4,-29,-28,4,-56,24,7,95,19,-36,-57,3,-27,8,-8,-20,68,-4,59,-25,-19,-22,-16,-26,-24,-20,13,-13,-14,1,-4,9,-33,-27,-26,8,-94,-29,-30,23,11,-7,-45,5,-27,-2,-13,6,26,-16,12,-9,-20,-6,37,-60,20,6,7,9,-39,-16,-4,2,9,-21,-5,-12,-52,-31,-37,-18,2,20,-31,0,-22,-15,-23,-50,33,25,41,0,-32,-33,-93,-11,1,-33,0,-34,-12,3,6,2,14,-21,-42,-41,9,-1,33,21,19,22,-24,11,-8,3,10,-33,-7,34,35,4,17,-13,-58,-16,-23,9,0,-30,4,17,15,5,-27,-20,-4,0,-7,-24,37,18,-12,7,-63,9,6,-1,-46,-41,-5,35,-3,14,2,-5,14,-11,-4,21,28,26,12,-2,4,17,-38,-23,-12,-11,19,-18,-1,-9,-11,-23,2,0,3,-35,1,-33,-2,-9,15,-46,15,2,48,12,6,5,19,32,19,-11,-19,25,4,-21,-14,9,17,-27,-5,-11,24,-4,4,-16,11,2,24,-4,24,-3,3,-9,3,25,61,12,33,42,-13,8,-14,-6,-7,10,11,9,-20,-9,-18,-4,-8,-8,54,23,12,-8,-16,-23,-6,-32,31,4,-30,-38,-11,-38,3,-21,-16,6,24,0,0,20,2,-17,-13,-52,0,2,2,-14,-19,-6,-29,0,-13,-5,-16,29,16,-11,-10,-9,-16,-40,-11,-16,17,0,-7,19,-15,1,17,14,-23,-35,-4,-56,-6,9,60,-18,-26,-32,-27,-14,10,-4,-6,2,1,-4,-31,19,-7,-2,-6,7,28,57,19,16,-7,22,31,11,-15,21,-21,3,9,28,76,-40,8,-44,-22,-37,21,0,26,-20,-22,1,-17,53,-15,6,-19,29,21,31,15,2,6,4,-21,8,-7,-25,-19,6,-3,21,16,-18,3,-13,-21,-27,-24,19,43,4,-13,3,-20,23,-5,21,-14,8,-2,16,-12,-19,-11,0,-24,18,-18,-23,-7,-5,-14,20,25,-20,1,21,1,1,-15,7,2,20,-15,-36,31,-13,-29,-14,21,-40,-10,-34,12,-16,-23,7,-26,7,-1,-24,0,-43,2,17,33,-7,-10,11,6,7,18,10,-26,-17,9,-31,16,-19,-47,-31,11,-26,-2,-8,13,-25,-17,-8,-8,19,-24,-35,-16,-8,-10,1,16,-27,-17,-4,14,1,24,0,-21,-46,-11,-30,-29,5,-31,-7,37,10,33,11,-3,-10,10,-27,34,4,-17,1,-23,-12,-22,-4,55,-14,-12,23,-14,-18,-16,-2,-2,-51,3,-29,-29,30,-14,-12,-16,0,29,-3,-2,-8,-16,-6,29,5,5,-17,-19,-19,-7,-8,31,-14,-13,40,-21,-19,-33,4,20,-18,11,-18,30,18,-18,12,-13,0,9,8,-14,-29,-25,-14,-15,35,-16,-31,-23,-18,-2,14,12,-9,-18,31,-18,-4,10,0,21,24,-16,-38,16,-45,-30,-49,-19,-16,-35,-36,16,-2,-3,-3,-28,-23,3,-27,-7,-9,-11,-15,14,6,54,-2,15,39,3,7,-30,-17,-15,-40,24,-23,-28,-44,-28,-18,-20,-34,17,-21,-3,-16,-28,-29,-4,-26,6,-6,-40,-18,12,-29,24,-5,15,47,33,0,-31,-53,-33,-53,31,-17,-28,-26,-9,9,0,-17,4,-21,18,-46,21,-22,-2,0,11,8,-29,-17,21,-30,37,-5,20,56,54,-2,-19,-14,-10,-45,5,-2,-29,-32,-19,16,23,-22,-35,-29,-1,-6,31,-5,-3,2,-6,-11,-24,-32,39,-11,25,29,43,46,4,-6,23,12,24,-34,39,15,9,15,-6,0,14,2,-13,-23,-10,6,31,5,1,-7,-5,-28,-6,-22,-23,4,-6,42,28,5,13,-12,-30,-4,-18,-29,53,-36,-2,-34,0,-24,-31,-36,27,-8,11,-17,-17,-18,23,-17,-36,-21,-23,-12,26,-5,-7,21,18,28,-11,7,-48,-23,-21,-28,51,-15,-12,-36,3,-24,-5,-28,27,5,-3,-6,-3,-20,9,-9,-6,-13,-32,-23,-7,-24,24,3,37,34,-17,4,-47,-24,-24,-34,28,-28,9,-38,17,-12,10,-26,9,6,-24,-27,16,-33,7,14,9,-2,12,-13,-15,-34,24,42,24,40,-18,9,-37,2,-21,-11,31,-14,9,-34,-8,-16,22,-36,7,3,-17,-4,12,-8,-10,-8,-7,-9,10,8,10,-5,14,21,40,28,-1,1,-28,18,-10,1,-5,14,40,-5,7,-14,27,-37,11,6,-2,-5,-14,-2,8,-3,-23,4,-12,-6,13,-41,13,28,0,-19,-6,-18,-33,-19,-24,-27,71,-11,23,-43,16,-9,-28,-54,33,-17,26,-11,-10,-21,0,1,-14,-20,8,-14,-20,-36,50,49,0,31,-1,3,-22,20,6,-21,26,-24,18,-49,11,-13,-4,-53,-6,-5,13,-21,19,-7,-15,-2,-25,-21,-19,-17,-21,-26,62,26,-10,40,-32,-6,-49,23,-22,-34,16,-15,25,-35,21,-7,11,-24,-3,-10,-4,-26,61,-16,-8,-19,-18,13,13,-13,-24,-35,59,21,40,53,-25,-5,-54,0,-4,-7,-14,-31,39,-18,-3,-13,18,3,23,12,-16,-9,31,12,22,-25,6,2,4,10,-11,-32,50,53,54,42,-49,-7,-39,26,-12,-2,6,-8,49,-14,-6,-8,20,-1,28,31,-9,11,2,5,55,-4,20,11,1,-1,-50,-24,71,3,36,4,-55,-6,-9,-7,-24,11,23,0,25,24,-16,-67,2,-27,-2,3,-58,21,-33,6,28,-47,-26,-2,-13,-21,-20,-22,-8,3,-19,-20,31,-32,-13,16,4,-9,10,28,-43,19,21,-47,-33,-40,-14,12,-27,10,2,-8,-6,-35,54,8,-21,-8,5,28,-6,61,44,-16,-46,18,9,27,10,-3,11,-28,-6,-32,-9,-66,-13,-25,-21,2,-28,-10,14,4,18,-11,32,14,-35,5,23,2,-5,-12,-13,-21,-1,21,-38,-26,-2,-10,20,-24,8,-1,-10,-63,3,19,-10,-19,-13,-17,42,10,10,-25,7,-37,0,40,57,-16,-18,-24,-5,-28,40,9,-26,-8,-10,-19,27,-3,12,13,-38,-42,20,9,24,-30,-13,15,-24,6,36,-20,-5,-24,-5,-25,-7,1,-31,-2,17,-25,20,4,10,-22,-23,26,-15,-23,15,7,5,-12,28,-29,-13,-33,10,-13,-17,30,16,21,-83,-4,11,-1,-12,-6,10,6,-34,12,50,-17,0,12,-17,-10,-11,-35,58,7,22,42,-42,-43,-3,9,21,15,27,-42,-2,5,25,-1,2,-5,-1,24,32,70,60,10,-26,28,6,37,-6,-10,-13,-2,22,-8,5,26,-38,-34,-12,-15,-38,66,70,-32,-19,2,83,5,-26,-21,2,16,15,6,30,2,9,26,60,-9,2,-10,7,41,-20,-21,12,13,9,52,12,-9,-21,-24,-9,-3,-5,23,11,-22,3,1,92,1,-8,-25,28,-11,31,5,49,-16,-4,-22,-1,36,-17,0,-13,13,37,30,29,-11,7,-29,-20,11,1,8,-41,-11,-15,-14,-16,-17,-7,-11,-25,0,-25,4,4,12,-5,30,13,-20,-21,21,-23,-21,34,-15,20,-64,2,19,-12,20,17,13,-77,-17,-27,-13,-5,22,-20,-32,-42,11,-18,-17,-2,3,6,-13,-21,-7,48,-8,6,23,-44,16,-15,-19,-5,1,10,-22,-14,-15,-1,-1,18,-18,15,1,11,0,11,-21,15,18,2,25,24,-46,40,-2,33,54,-2,25,-71,22,-38,-34,15,-18,60,-16,-9,-30,58,-16,8,-14,53,8,-20,56,88,-30,-3,11,94,7,-6,-34,24,22,-21,15,-19,10,-18,4,-23,-4,-9,-38,31,-15,-16,-1,-2,-2,11,-9,27,22,-27,23,82,-40,18,-8,73,-22,-34,-16,-1,44,-20,-6,-24,-4,39,7,14,-17,-6,-9,-11,41,-13,12,-68,-26,-1,-1,0,-21,-41,14,-14,-11,-39,-8,-3,-6,-6,14,-24,-5,-17,-11,-24,9,22,-10,16,-1,8,30,-15,7,22,21,-55,-12,-34,-9,15,-2,-27,-49,-24,24,-9,-25,14,-7,24,-8,2,15,30,11,-11,21,-29,12,-21,21,-11,22,13,2,-6,-5,-23,-1,-19,-13,37,-33,-30,-27,-21,7,18,7,32,-10,-21,-24,4,10,4,20,19,-2,-53,49,-30,-10,-14,14,-12,-28,17,-10,13,-32,-44,-1,26,-6,35,22,0,-3,-1,10,28,23,-37,-31,43,-3,14,20,16,17,-18,16,-6,0,-22,-36,5,9,22,18,-6,6,-15,-1,-27,6,6,24,-4,-13,-27,-13,17,1,-28,-28,19,-16,-9,-22,-16,10,13,-2,-8,-15,-29,30,-27,21,-9,16,-46,5,-20,0,-18,-13,8,-3,6,-3,12,-3,-1,-33,12,2,-9,27,7,-16,-19,-27,10,-17,14,14,-10,-28,-63,20,-24,10,-13,-20,1,-10,32,21,-2,-43,-22,15,15,-18,6,4,35,-7,-27,30,-3,4,-30,11,-11,3,-13,59,-26,-24,-6,6,-22,18,-1,-5,-9,-32,35,30,18,-35,-18,21,-10,7,21,8,8,-8,16,19,-26,-43,-9,-8,-19,29,7,13,-34,-22,15,6,16,-30,20,16,-30,-36,-17,41,16,-20,-14,6,-17,6,27,21,-23,-10,34,15,26,5,18,9,-18,11,17,-9,-40,9,-17,-3,20,6,2,34,-13,4,4,-5,22,5,13,10,-35,0,-4,13,18,-21,31,-36,14,-5,-6,6,12,5,-4,-19,-25,34,-36,17,-19,29,-42,-14,-16,-2,-1,-6,9,4,-8,-2,-13,10,-16,25,-4,-10,10,2,10,21,-13,-5,-1,15,28,23,-21,-6,-36,-13,11,19,-20,10,-13,-36,-12,26,19,14,22,-11,60,-3,26,-7,7,17,32,-12,-30,-26,32,-11,39,-3,42,1,-18,22,1,-6,-28,-6,-3,2,-25,-2,1,5,5,1,12,-1,21,14,-30,1,-15,34,2,-7,-6,-46,-24,16,3,-3,4,16,-38,37,1,35,2,-35,26,-7,-24,-38,19,25,-8,-13,5,7,34,14,-17,4,-31,49,-27,16,-6,3,0,21,24,9,21,5,-16,-1,-13,2,11,9,-14,-3,6,-37,19,10,2,1,-11,10,25,-8,8,11,-29,35,-9,4,-3,12,10,15,35,1,2,3,-3,11,20,-18,-18,19,-48,4,21,-22,11,4,-4,3,1,18,-32,-13,-4,6,-21,1,7,-42,-9,-18,9,-32,-16,-42,-26,20,-28,-18,-31,-18,9,14,-16,25,-19,-16,-42,-3,-28,36,11,28,14,-17,-5,0,4,23,20,-12,-1,-19,-10,-32,12,-13,-22,34,40,22,-5,-16,-12,-12,-8,2,-22,0,15,-11,10,44,-12,22,-20,-1,12,-9,-14,3,1,0,39,-46,-19,-7,8,-22,-39,32,26,29,-43,11,1,-33,6,-18,-9,-22,27,33,-11,-21,-24,34,-17,-8,57,5,0,9,-7,24,-13,-14,-4,4,21,-53,-14,17,-29,8,-39,0,-3,10,-37,5,5,-9,11,-13,-3,2,-24,34,-22,-23,-11,-17,-5,42,1,16,19,21,8,6,21,-39,-12,-17,-30,13,38,18,-8,0,-24,11,-21,-34,24,-22,23,-13,-1,27,28,-12,12,38,-14,-9,9,-48,6,-4,14,-4,-26,-20,-4,-16,5,-60,-16,-17,39,-2,14,-6,29,-7,-21,-18,13,33,-10,7,-11,-7,6,0,7,-16,40,14,7,40,17,4,8,-8,-21,-42,26,5,-2,1,3,-9,-1,-53,50,-2,38,23,8,85,-15,1,-16,2,-5,12,-49,14,-8,11,35,18,-13,42,37,-5,-23,1,21,1,16,45,-39,-32,2,-1,39,-14,60,81,-47,-17,-39,15,39,-2,38,10,-16,31,-31,22,-1,33,-21,19,55,-10,-6,13,-2,3,-19,20,2,-3,-21,38,42,19,-15,7,31,-21,-20,-1,-21,-9,38,-13,-9,42,-7,-25,16,-9,21,1,9,-35,-17,-4,-7,13,18,1,18,-6,-14,45,-9,-6,-33,-2,26,-12,63,27,6,4,-41,12,6,-27,20,9,-32,-7,6,-35,-56,-10,50,1,24,-34,22,5,32,-18,-24,-10,43,-9,-6,4,-16,-2,-15,-12,-59,-5,18,-23,-15,-26,-12,43,23,50,-1,11,-52,-13,7,-65,-5,-22,-60,-7,6,-10,-55,-46,20,-11,-6,16,-12,18,-32,-39,-85,-19,-18,21,-27,-7,-14,-5,2,26,-38,49,7,7,-16,-17,-44,-48,3,90,-21,-17,-24,-45,35,-14,20,12,-45,-7,-65,-11,-33,-16,11,44,-17,14,-29,7,9,13,-16,12,30,-15,-11,17,9,-7,40,19,-11,-3,-16,-22,50,28,-31,-20,-8,-30,-11,-16,6,5,20,-8,-10,19,10,-11,23,-25,13,-20,-4,-40,-7,-2,8,14,23,-21,33,21,37,16,-17,-4,-38,-2,-3,-30,38,11,14,0,-25,-13,-7,-28,-4,19,-11,45,5,-47,-43,-14,12,6,0,-45,21,30,25,10,-6,18,-1,-5,46,4,-17,3,29,-30,-1,9,3,-12,-24,-24,-12,86,45,27,-36,-5,-34,-16,-22,-50,-44,-46,-17,15,-15,12,-37,-6,-1,7,14,26,-14,21,-11,-43,-75,-41,-32,16,-1,-17,27,55,10,22,-26,13,3,-14,-36,15,-50,-29,-3,20,-20,29,-52,-7,9,15,-10,-50,-43,60,-8,-22,2,-33,24,68,-14,44,-5,16,-17,17,20,-2,39,-2,8,65,-7,5,31,-3,-12,-8,-13,21,-2,30,-30,-6,-14,-25,-9,-11,38,12,37,-8,-26,45,-37,-24,-12,-29,18,-7,-18,-34,29,23,20,5,44,-5,20,13,52,47,-34,-18,-24,0,13,-34,36,17,37,28,0,-32,0,-16,2,-14,8,-7,-8,-13,4,19,28,-22,-2,-16,-20,-20,-31,5,-25,-11,-29,7,11,-17,23,-21,-16,6,4,-4,-21,12,6,-22,10,-39,8,-5,-13,-24,6,8,8,-1,-12,25,10,-33,6,25,-49,-20,-13,39,11,-10,20,18,-10,10,-18,-1,3,17,12,-26,1,-13,31,12,-33,-7,-27,35,-7,1,-24,-13,2,-21,9,17,-37,-20,18,6,-5,-34,-14,10,-31,3,26,11,11,46,-4,-4,16,-13,28,23,-18,-3,-14,42,3,28,0,-2,10,-44,-1,-19,-19,-22,18,-6,31,-18,-30,6,-6,0,30,3,-23,-3,19,-7,11,-3,3,-22,-17,27,-17,7,-3,12,-11,-14,-11,18,16,34,-23,-19,-22,-16,13,0,-42,-14,-17,17,-3,-9,-25,1,-29,-10,-7,-14,3,-37,-22,-4,-10,0,5,-30,11,-11,-41,-11,-35,-6,-13,-17,-26,-4,-38,-31,10,-44,-33,-13,-8,-7,-22,6,8,-6,-17,15,10,6,11,14,7,24,7,-24,0,11,-27,15,-7,23,-19,23,3,24,5,-30,13,-13,-31,-15,9,-4,11,23,4,-6,-20,-14,35,-23,-9,-14,-5,84,-5,5,-32,-11,-17,13,-17,-37,-27,-16,8,-17,55,-32,26,-57,-48,-18,3,-8,21,52,8,16,-31,-20,15,-26,-6,-18,19,77,18,41,-36,-18,22,4,-4,-5,12,-20,-17,-1,61,-24,-4,-30,-40,-11,0,-12,21,58,15,12,21,-7,12,-25,46,10,28,36,30,68,-17,-13,57,8,35,23,46,2,-54,-7,5,-27,-44,-9,-14,-8,32,-15,14,8,-16,-8,7,-8,12,-15,-30,4,-25,-16,-12,-8,9,-4,-4,-11,-8,-4,-17,-14,-25,-12,16,-1,-11,-26,21,-6,-6,-10,-13,-16,15,-2,1,31,11,3,-27,5,-5,4,3,-8,28,-10,-17,-13,-35,14,-26,-36,-27,-5,-26,-16,10,-8,-25,10,21,-7,15,-12,-18,-8,4,-12,19,-7,-40,-3,-22,32,6,-2,29,0,-10,22,-14,-38,-38,-49,-5,-43,-3,5,13,-24,-26,19,-2,-9,0,33,11,-16,38,-58,-1,-30,-23,-3,7,84,-2,4,-21,-3,12,17,18,-9,-2,-24,-30,9,41,-23,-35,-11,-17,11,-30,15,34,33,12,-14,12,-28,6,22,43,-26,24,45,26,24,-47,-5,33,30,24,-22,-1,-5,-22,6,21,-21,-5,-33,-1,-30,-9,5,33,22,9,19,-1,-9,6,17,16,-16,-24,-11,-31,-11,11,-13,-10,-5,-18,-6,-4,-10,-39,-1,12,17,5,18,12,-6,-8,-13,-10,6,13,10,-28,30,37,-14,17,-15,-11,12,-15,-9,3,-16,-9,-22,-17,9,5,-23,-37,0,-9,-9,-14,-28,-3,13,20,-11,-17,-8,5,-7,32,7,21,8,20,-11,-20,-10,-16,-7,28,26,2,-8,30,-9,13,-22,-25,-31,-21,4,-27,21,10,21,-15,1,-1,-19,13,-27,49,-21,-21,-11,-2,11,-1,33,2,-9,-18,18,-9,-6,19,-18,5,-11,-29,3,-21,17,-29,42,8,19,-13,30,-3,-19,20,-28,14,-31,-14,13,-12,-4,17,31,17,5,-31,26,39,12,-5,-37,-5,6,16,-5,-17,-8,-13,34,-4,-7,-30,35,4,-21,2,15,5,16,2,16,17,-2,-12,-9,-31,1,11,-10,4,2,3,-9,10,7,-30,-4,-6,14,-13,-12,-5,-2,1,1,-5,20,19,27,-4,12,5,-1,2,10,-12,23,-18,1,-8,17,19,-28,7,32,13,4,6,8,-33,-27,-14,9,6,6,5,-8,-16,28,8,16,-6,11,13,6,-8,-2,-11,1,-14,1,27,28,10,-18,12,28,6,-6,9,-20,-2,-4,1,10,-1,9,-4,-1,-6,-18,19,-10,16,31,-24,2,-20,10,-2,-18,-10,-9,16,6,12,6,2,-8,-2,-11,11,16,13,22,8,-8,-31,18,-6,23,-17,-21,20,-20,-11,16,-21,2,-34,-3,25,-2,0,-24,-33,-13,-13,0,-25,1,4,-8,13,-4,11,-2,0,-4,-21,-3,19,41,-16,-35,-1,-24,20,-5,-14,-13,-18,-10,-33,-19,-14,-21,-14,-14,-17,-22,-3,24,-4,-5,-24,-3,-23,2,-7,11,19,3,-6,19,-9,8,-2,-18,-12,0,-1,2,2,3,-20,-17,14,2,2,6,-9,-20,19,2,-16,14,-19,8,9,30,10,-17,12,13,13,8,-1,-11,6,-20,-1,22,-25,15,-10,-2,-6,-15,19,1,31,-1,-13,-7,12,-23,-18,-15,-6,14,16,3,30,-31,-6,1,16,-10,5,-9,11,-20,-11,12,7,-5,-18,-15,3,-8,11,-13,30,-5,4,-5,2,3,-19,15,-23,18,5,-6,18,-31,-26,-13,19,-10,12,-15,6,-31,-6,13,5,-29,10,-23,-20,8,6,-18,-6,7,28,-4,-3,-20,-21,-21,-14,15,48,-4,-8,-33,-16,6,10,-12,18,19,-7,0,25,-3,9,-6,-23,3,-21,5,-1,2,4,16,-20,-5,16,23,9,10,-10,-13,-48,7,12,-18,-3,14,-12,3,5,20,2,-11,-6,16,27,-12,8,-3,-20,-9,1,10,9,17,18,0,25,-4,6,13,-50,9,-11,17,16,-57,-7,14,23,10,16,-10,1,-9,-30,32,7,5,12,-9,-20,-22,3,-8,39,-3,12,19,27,-11,-14,10,-15,19,-20,-14,8,-39,-13,0,-7,3,32,4,-34,-21,-3,23,5,12,8,-22,1,-10,-2,-23,31,-13,-19,11,7,18,-45,3,-15,7,-31,-35,-17,-43,-51,-18,22,-4,21,22,-7,-32,-28,8,3,-15,2,-17,-9,-8,-16,-24,-3,23,11,-3,4,7,-38,-3,-30,22,19,-9,-24,37,-48,-5,-1,-11,-5,16,5,29,-8,1,40,14,-35,-9,-25,2,12,-18,1,-7,-3,-23,-2,9,3,2,-65,-5,-16,16,2,-47,1,3,19,-11,-19,23,-24,7,30,8,-5,-34,-15,-15,-30,-31,-5,-10,-1,-28,48,-17,11,-15,5,14,-61,-14,-23,4,-9,22,27,-7,19,0,12,-6,-30,-7,16,12,0,-24,-4,1,-22,-17,-30,-15,16,-45,63,-5,36,0,-23,11,-32,-13,32,-6,-2,8,62,-11,-8,1,9,0,-18,-7,-37,-1,26,-3,-27,4,-7,9,-34,-2,11,-36,20,8,24,-5,-54,-4,-22,0,-4,17,-10,-24,32,-21,-4,-5,22,13,0,-16,-2,33,28,-10,-8,12,8,7,-23,5,-2,-9,3,16,30,17,-25,-11,-28,25,16,-13,-19,22,-44,-28,3,-19,14,33,24,19,40,-6,3,14,-16,3,-43,32,14,10,-15,-12,18,-8,3,16,-9,12,-32,-4,6,5,38,29,19,-10,14,0,-30,19,-12,-6,68,36,-31,-11,2,-12,-25,-13,20,8,-24,-51,-18,-22,8,-22,-30,69,-25,-5,-44,-1,98,76,58,-26,8,0,4,-1,-10,-16,59,14,-9,-40,5,-10,-27,12,4,-15,2,-32,-2,11,30,18,-32,24,-47,-38,6,-11,38,1,32,-32,24,3,-5,13,-16,10,-8,-19,13,-26,-37,2,-36,5,-31,4,2,-28,14,38,32,7,-44,-13,-31,-15,30,8,-6,-56,-15,-32,14,6,-22,43,-23,9,-29,36,17,-9,-46,5,-10,13,-27,18,-37,-28,-12,23,25,9,-21,-28,-14,-3,52,7,-2,-36,-29,-30,26,1,7,27,7,13,38,16,-9,2,17,29,-34,18,-6,22,-23,9,14,28,-15,24,9,-5,-12,-26,-18,7,16,19,0,12,3,5,5,5,-16,-7,23,36,-35,18,27,15,-22,-10,-10,-14,-31,-9,-22,-6,-17,-25,-6,35,-6,-21,-40,15,45,3,-7,3,-28,17,11,-8,-7,-7,-25,20,15,-12,23,18,-31,-31,-7,-29,1,-7,2,-8,-15,21,7,10,-28,-31,-12,23,9,-44,-30,-8,-17,16,-27,30,1,13,-18,39,3,-14,12,5,-41,-11,-10,-5,1,3,4,36,2,20,3,12,-25,-6,46,-9,-25,7,-30,2,13,12,-22,24,-9,21,-27,62,-9,7,-16,-1,-7,26,6,9,-21,1,8,52,1,14,-16,21,-22,-12,61,50,-11,-30,-34,-5,34,16,-18,-3,3,12,-40,-22,-12,-48,17,-40,-19,-1,31,-4,-8,-7,-17,-2,-24,-5,-29,-9,-42,5,29,-25,-32,13,0,4,20,-8,-3,-32,12,18,-34,3,-12,-20,3,15,-1,27,-9,17,-1,-9,21,5,-27,-29,-6,-41,-50,-28,25,3,-23,-55,-4,1,53,-2,24,-21,-21,4,-81,4,-54,-16,10,38,16,11,-11,28,-32,-10,15,-5,-32,0,-3,-46,-29,-40,53,2,-41,-68,-44,-9,47,4,53,-37,-33,19,-51,10,-31,-24,0,36,53,22,-1,7,7,-14,39,-12,-21,5,-13,-38,-14,-23,15,29,-37,-43,-18,-14,48,2,43,-18,-13,4,-2,9,3,-9,25,34,63,20,-3,4,-1,-10,6,-9,-14,1,-24,-15,0,-7,58,30,3,-28,-16,-11,33,8,30,18,20,19,18,13,34,6,-12,-46,-4,22,22,21,5,55,23,-3,4,16,8,13,0,32,4,-37,0,34,-9,8,9,-11,-4,-7,20,17,2,-20,-6,-24,-16,-8,-38,19,2,14,6,6,7,34,-9,-27,1,-13,10,-11,24,-6,-29,-12,-13,10,-5,-12,34,-3,-22,24,-30,15,-26,12,9,65,-34,13,-13,16,0,-10,6,18,-7,-4,-18,1,-7,-25,90,16,-50,-67,-61,6,13,3,16,-13,-19,31,-49,16,-21,-7,-9,62,18,20,-11,29,-8,-9,21,-19,-13,16,-18,1,-38,-18,56,-7,-58,-22,-63,-10,8,-2,45,-31,-51,13,-29,19,-14,-23,-9,24,34,39,-15,9,19,-61,41,-15,-32,-15,6,26,-25,-41,5,-8,2,-45,-43,-6,38,5,47,-29,-28,2,41,5,31,-6,0,-27,14,-12,14,-5,29,34,1,-13,4,-5,-3,-8,0,20,42,-3,34,34,12,1,13,-10,-17,5,33,7,46,-30,-8,-20,2,-8,2,-26,8,5,-2,5,25,26,-9,-29,-5,-2,-1,9,5,-33,-3,4,-13,17,-1,-4,4,11,-2,-2,-6,8,-18,-12,10,23,-29,38,-23,-4,-13,9,6,7,-11,-8,-18,-14,0,-6,47,-14,-40,16,-40,7,-30,-3,20,12,8,5,-36,14,-31,-22,-26,20,-23,46,-19,-18,-14,-21,4,24,-8,17,-49,-19,-46,-24,75,-15,-58,-37,-43,-13,-10,-15,38,8,-21,12,-15,31,-36,-19,-21,26,-8,29,-3,13,22,0,72,-3,-14,-26,6,4,-17,-43,70,25,-37,-25,-17,-3,15,-6,39,-4,-28,-15,-5,-21,16,-13,-29,-23,22,17,2,21,2,2,-10,15,9,-21,21,-9,-22,17,19,21,11,-11,-7,6,5,9,-12,-15,10,0,9,-45,-12,-17,-20,-26,16,12,13,19,-1,13,13,17,-3,-40,5,2,10,9,-9,-15,-7,14,-17,17,-27,4,18,14,13,-26,-2,12,-18,7,-5,2,2,5,0,-8,-6,-28,-12,47,-5,-20,-15,-13,-3,-2,-9,-30,-37,4,-30,14,-6,-19,17,-7,51,-24,-22,-38,-18,-17,-38,-15,-24,15,-4,-12,-2,-3,-2,24,10,7,-36,-28,-29,-4,29,-6,-59,-26,-31,-1,-25,-11,12,1,20,-20,-16,22,1,-1,5,3,-50,31,12,3,8,0,-22,11,33,-17,-26,16,-22,-32,29,2,-31,-14,-29,14,-18,-5,27,-12,12,-2,-2,-24,-15,15,-39,-28,46,12,10,-18,1,58,-30,21,16,-12,13,-19,-28,6,26,-5,-3,25,10,19,-9,4,-12,-13,9,-3,11,-19,-3,6,-42,-20,17,16,-10,-7,-13,19,-15,3,1,-20,-5,-25,27,29,-15,-17,4,-10,3,22,0,2,-3,24,-4,-21,-6,-16,0,22,-6,9,16,16,5,-31,-3,-12,2,3,-2,22,-13,-31,34,9,2,-13,7,33,10,10,-13,-13,-5,12,53,-36,-3,-20,17,-16,-40,-36,0,0,-8,-9,-4,15,-2,-14,40,33,-13,-27,33,17,36,-25,-4,52,-7,-8,9,-9,4,27,10,-32,8,11,-3,-4,-6,-14,-39,4,3,12,40,19,-22,-26,36,6,-25,0,17,13,50,-9,5,41,-8,1,-5,9,3,14,33,5,-9,-10,4,-15,47,-49,-21,-15,-26,-15,33,-7,-10,-6,-32,13,-11,5,-1,-2,-62,22,-20,-31,-13,7,-14,-5,-24,5,37,23,-12,-27,22,10,34,-60,-12,7,-27,-14,16,18,-25,16,-19,-5,1,-3,-10,-5,-15,-23,-16,-27,-31,0,-9,-10,-4,-10,16,21,-3,0,11,15,-1,13,-25,-15,-14,12,-20,13,-80,13,1,20,-2,-16,6,1,-8,-24,-25,-5,-16,4,23,-8,9,31,21,-10,27,25,0,37,9,23,-32,31,19,13,-19,-30,-50,-6,41,39,-33,-16,37,-10,3,-16,3,1,-55,-26,-9,-4,16,46,-4,-36,9,33,45,8,62,2,40,-3,41,21,6,-25,49,8,38,-47,24,13,26,19,27,3,-19,20,-26,19,-22,11,4,-5,-1,13,-42,-11,17,9,-11,-25,-25,0,-10,-10,28,-24,41,-14,-35,9,-10,26,-16,-11,-21,25,15,8,23,6,16,-7,-38,4,14,23,-32,-14,-8,-10,-13,-40,-17,4,-5,-39,20,-2,-5,17,-30,-28,2,1,-12,-14,-13,7,-11,-14,4,7,-2,-17,5,-23,8,15,-50,-9,10,10,-44,11,-36,0,-23,-7,-5,-28,-57,-1,-10,7,-10,-36,-3,-37,-54,9,-54,-23,-33,10,2,-20,5,14,-1,-22,-26,21,6,4,-34,21,-28,-17,6,-19,-24,-47,-81,-28,-6,37,-35,-46,47,-13,-61,-35,-16,-26,-68,-27,-27,7,24,37,-32,-20,44,24,43,26,7,-2,30,5,8,16,-9,-15,21,-33,5,-14,-16,31,31,6,-11,-7,-16,-5,-56,12,30,36,-20,-3,-4,29,-6,-19,24,1,3,-4,13,34,7,19,-12,-14,56,-17,0,31,37,37,-10,24,3,7,12,20,54,-14,16,-4,1,-9,-5,26,3,30,-5,-19,15,22,22,-10,7,-14,-7,3,-7,30,-6,10,43,36,-29,12,-6,-5,-10,27,35,13,-11,-4,21,-15,-2,9,-43,10,-12,18,-4,26,1,3,-27,16,-29,-13,-39,19,16,19,-9,-16,10,0,4,36,-79,1,13,12,-12,-7,28,30,11,-39,-35,33,16,35,-9,36,-15,1,4,-6,-41,-22,-55,-34,14,29,-50,-58,50,26,-23,-13,-28,-32,-31,-34,-50,5,18,26,7,-28,-10,60,43,55,-8,9,25,8,-29,9,-25,-12,-9,-7,-6,9,-44,31,17,40,-13,-24,-35,-5,-21,-14,5,6,-8,5,-15,9,3,-29,-12,0,-5,-3,14,-15,-5,5,-25,2,4,-11,-19,16,22,-1,3,16,-10,-13,17,-13,27,-8,20,17,-21,-18,-25,10,-4,26,-1,-7,-4,17,16,-16,-2,-20,-21,-2,-17,11,-5,26,-2,-25,-39,-11,-19,-2,-11,0,0,6,-16,23,22,-10,12,18,-31,6,7,17,-15,2,-3,7,9,10,-45,22,-33,11,1,12,-48,-51,-1,2,-9,6,-41,-30,-24,5,-30,13,17,3,25,-22,-45,46,27,-9,-40,19,-24,4,13,6,-14,-6,-47,-9,15,-5,-43,-63,34,16,-14,-15,-12,-39,-34,-39,-49,12,12,23,-12,-1,-18,25,39,18,-24,30,-3,41,-1,5,-3,-24,-7,5,3,2,-49,13,-19,31,-15,-1,-26,-21,-19,-16,-36,-4,42,15,-21,-9,-2,-11,3,-15,2,31,11,-11,-15,5,-2,-22,45,18,-28,6,7,1,22,15,-23,-27,36,-6,15,4,-19,14,15,5,-14,4,-4,6,1,-23,5,11,2,-25,-13,-8,25,0,21,7,-10,26,-28,1,-1,-11,-30,20,17,-4,31,17,-19,0,55,-11,22,21,-1,-19,12,21,-10,27,-1,-1,8,4,4,12,-11,-21,-7,16,-52,-14,-4,-2,14,-1,-13,-14,15,12,-35,-12,16,-16,28,-1,-6,27,3,2,-9,-4,20,-16,12,14,-1,25,-6,-23,9,-23,-46,-42,29,9,-7,15,2,-20,-17,-13,-27,-11,0,20,9,8,38,5,11,-12,-5,16,18,0,33,-3,-4,12,46,2,25,-3,-29,18,-31,-9,36,0,-16,-3,-17,-3,4,-3,20,18,-15,-6,21,14,26,14,-20,-18,13,-35,7,-14,-4,46,-61,7,-16,-3,-26,-28,-10,-6,-26,26,29,24,8,-10,-35,-20,9,30,7,-7,10,-19,35,7,-22,-20,-20,-53,25,-6,1,20,-61,-32,-3,-12,6,-23,-45,-9,-66,26,55,44,12,-13,-1,-16,-13,-20,48,-25,33,26,21,9,-29,-18,-16,-28,12,-7,-1,-2,-49,3,8,1,20,-4,-37,12,-9,41,64,2,-17,5,12,-7,-24,26,57,-29,1,47,2,22,-28,-20,4,-7,9,16,-7,18,-19,11,-9,23,-1,-19,-40,25,8,6,17,-15,-48,16,12,-1,-32,1,18,-8,-25,1,-19,-29,-58,6,11,16,4,24,1,20,-22,49,-8,2,-22,-16,-6,18,-18,17,-9,-30,-49,5,10,14,-39,-16,-13,-12,15,22,40,15,-10,10,19,-8,5,-10,-29,20,-63,23,-1,-27,-10,-11,6,-15,22,-8,-1,3,30,6,-10,-14,2,31,-1,-1,10,-50,23,-31,-5,-23,-4,-46,3,-3,-18,-13,-57,-5,-12,6,9,-10,-32,13,-43,15,17,-15,-20,-11,-41,-11,-34,-15,13,-13,-33,-16,17,-23,-22,-21,-16,-55,-10,-1,-26,4,-40,-9,4,9,16,-32,-35,-3,-31,18,-5,-1,-48,15,-15,-9,-22,-4,-5,-13,-9,27,-9,-20,-27,-35,-7,-37,-4,4,-32,1,-29,7,-5,13,19,-22,-29,17,19,-16,-33,-23,-47,16,7,-1,-18,-17,0,-3,1,20,-18,-20,-24,-6,4,13,12,13,-12,26,-42,26,-9,-7,-11,-2,-2,31,18,8,-29,-23,-28,15,25,2,-14,-19,-5,10,-62,88,23,23,-16,67,4,26,26,-13,-4,21,0,8,-7,-34,-15,14,39,-28,88,-9,38,3,-4,-1,42,-17,36,17,-22,11,-46,3,3,-4,-17,30,-5,17,-8,15,5,17,-10,-5,-13,6,16,19,-4,-1,22,-3,4,-23,-49,-4,23,3,17,-13,-15,-7,-13,-23,3,-40,-33,4,-24,-30,5,15,18,-12,-21,-2,-5,-2,-17,9,-36,-5,-61,11,10,-68,-30,20,20,9,20,-12,-16,-5,-1,0,5,-28,-29,-41,-28,-28,20,-11,20,4,-30,-2,-17,-8,-9,26,-15,10,-14,-27,36,6,-19,7,-13,12,-2,-28,-2,0,3,9,18,-4,-11,-14,-27,-3,20,-4,27,55,-52,33,-15,30,-30,37,-15,29,10,-1,41,40,14,-9,-18,4,1,-19,31,27,-3,42,-9,17,-29,70,-8,35,-25,4,-14,6,7,26,-19,-29,-15,-26,6,1,38,1,-21,1,8,18,14,2,35,7,-2,31,-39,11,-9,15,-12,55,-6,53,-2,4,-28,-14,6,22,-22,2,-3,-1,-20,4,47,23,-64,-34,4,13,44,10,31,-6,5,11,-6,-18,-30,-23,-5,20,-12,12,4,22,3,9,10,27,-8,-21,-26,22,13,-13,12,11,-19,-28,7,25,7,18,14,-13,-25,-9,19,-10,12,-27,-12,-32,-16,-23,16,-7,27,11,-7,-16,1,-16,-22,20,-6,5,-61,10,32,6,16,13,-24,6,-3,-18,10,-10,2,-12,26,11,-17,-25,-29,-26,3,-6,20,21,-3,10,25,32,-23,-2,-13,26,14,22,3,24,7,-12,-29,-3,-10,19,31,33,-13,-21,-20,-24,-33,20,-3,21,-4,-5,29,35,25,3,-3,-23,19,-16,-5,1,19,5,-4,31,31,29,14,23,3,-12,-15,14,5,32,-21,16,-5,50,10,30,-3,-33,-17,-11,10,7,-3,-18,1,4,10,-6,29,29,-4,5,16,11,35,17,20,-9,15,2,0,5,-27,2,-1,40,4,29,14,-6,-21,-7,12,15,3,-12,-8,6,17,-19,1,-3,-15,20,11,3,28,26,6,16,-34,1,1,-5,8,3,-14,-35,5,0,29,0,0,-7,-16,13,-2,-14,-14,9,16,-9,-25,-18,11,8,-14,-25,-5,6,22,-13,-14,-7,-25,-21,43,-5,-38,-20,-13,-4,13,10,37,6,11,-10,8,7,-9,-11,3,-2,-10,17,2,1,-14,-26,42,-11,-6,9,11} + +#define CONV2_BIAS {55,50,34,43,-37,35,-21,10,35,-53,-76,7,14,-1,92,20} + +#define CONV3_WT {15,10,3,1,-20,-11,5,-18,-9,-1,-4,-11,-5,-19,-26,-15,13,5,1,7,6,16,1,-20,3,35,0,-2,8,12,-41,-5,-20,4,6,3,-3,0,-28,-13,6,16,-4,-4,1,8,17,2,-4,-10,-9,-11,3,-2,-4,-9,-21,-10,-18,2,-6,-18,27,5,2,5,-5,-3,-4,-2,-16,17,1,-17,-13,-12,-1,-18,10,6,7,-4,-1,7,1,-4,7,-8,0,4,12,-4,-5,-13,8,-17,0,-22,-2,5,12,20,3,-6,4,10,16,4,-3,-7,0,-15,-17,-1,14,25,2,3,-15,-11,1,-4,-2,-14,-2,5,12,-2,5,-13,8,-1,-4,0,-6,12,-3,-22,-20,7,3,11,8,6,6,2,10,7,-5,-6,-6,18,-2,-23,2,1,-12,-9,-3,-2,0,-3,-9,4,-16,-3,-7,-23,-10,-8,-1,-26,-3,9,30,-16,-11,-13,-9,-11,-14,5,5,-9,-16,1,10,-5,-18,-14,31,-6,-1,1,5,-7,1,2,-17,3,8,1,2,-3,-4,3,-6,7,23,-10,-6,-3,-9,-9,-38,14,-3,9,-10,-3,17,13,-6,12,22,8,8,-6,9,9,-6,13,-1,-11,12,-2,-4,-3,-2,17,2,-8,-15,-2,-9,-10,-9,-19,2,-11,6,-5,-5,8,28,2,-23,12,-19,-12,-33,2,-8,-17,-3,-15,-1,23,-18,9,23,2,-9,18,-17,-29,17,9,21,6,13,3,13,32,-4,0,-7,10,-2,-2,-10,-5,-4,-5,8,-1,-1,-9,-20,11,1,4,-10,1,-1,-6,-24,-1,-6,-2,11,6,7,-9,2,8,-6,-8,-19,11,6,-10,5,-5,0,-14,18,-11,13,5,3,-7,0,6,-21,4,2,12,-14,3,-14,0,-10,-6,10,0,-21,17,3,19,-19,-2,13,21,-10,-11,-5,-18,-10,6,25,1,-19,0,2,-11,-36,-13,11,-24,4,-16,-3,-28,0,1,-9,-6,-3,-1,6,-11,-19,3,5,-6,-7,16,-22,-19,-11,-20,6,-2,-1,-12,24,3,-27,-2,-15,-18,-2,-3,5,-12,-8,-4,-23,1,5,19,-30,12,-5,-4,-1,10,-1,13,2,-4,-12,6,-3,2,13,5,-18,-3,2,1,4,20,13,8,22,-6,-3,8,-12,-10,-28,12,-12,-5,5,-12,-6,13,1,-17,-32,-11,20,-14,-9,-6,-11,-1,-8,-2,-13,-10,-1,31,-12,21,-32,-2,-14,-1,0,11,-1,-1,-13,16,-10,-8,-10,20,-2,1,3,-7,-17,-1,-12,-4,-14,-16,-20,-1,-2,-4,-3,11,16,6,-12,-11,3,0,2,-1,-2,-18,-21,-4,5,-9,12,16,7,21,9,13,-4,2,4,0,-21,-17,-3,2,-10,-24,-10,7,3,-15,3,-11,1,1,5,-8,0,-7,3,0,-3,2,0,31,-5,7,0,6,-13,-7,11,-15,-1,-13,2,13,-2,8,25,-6,-1,-16,-3,7,3,-21,10,0,-14,13,17,7,0,-7,14,10,-1,-6,-8,-14,-6,-16,4,-26,-11,-5,-1,-14,15,10,26,-1,-27,-22,6,23,-16,-14,-1,-12,-26,-21,-3,-5,1,-9,-13,-9,-9,-12,0,-6,-3,-6,-9,-2,-10,-3,-13,5,-4,4,-2,1,-3,1,-3,-13,6,-5,3,-18,-11,-6,-19,-2,-13,12,4,-10,23,-8,-23,15,10,-3,18,4,-5,2,5,10,1,-16,15,-14,2,33,-5,-4,5,-11,-19,-4,6,5,16,-14,20,12,6,-14,-24,-29,-11,1,16,-6,11,-8,-25,7,-9,-6,7,20,-19,-3,-7,-19,2,-8,15,-7,-5,2,-11,-11,-6,-4,4,-7,-1,-4,15,-2,-3,-2,7,-9,-16,-6,-4,-19,5,-6,6,12,14,-2,-3,-1,17,3,-11,-5,25,4,15,-7,8,7,1,-19,9,-32,19,17,6,4,8,2,-5,29,28,-9,14,14,-13,-3,5,-9,-20,-17,4,-12,0,-4,-2,14,9,5,9,-28,-15,8,-8,11,-16,-34,8,-3,-2,4,8,-20,-1,-11,-19,-14,-1,-14,-5,-3,25,-16,12,13,14,22,6,-4,1,-12,3,-15,3,-14,-12,-5,23,4,-13,3,-22,19,8,-3,-29,9,-12,-21,-12,-18,-15,-9,8,-6,1,-5,-21,7,-2,1,3,-9,-16,27,-11,-19,8,0,0,-1,-2,-9,-28,-25,-24,2,-7,-5,-20,1,-27,-15,2,8,-13,-1,-1,3,-21,-6,-10,9,4,15,-15,12,-12,-10,-6,-15,2,0,5,0,-2,-18,4,-8,-3,4,1,-9,-1,16,-8,20,11,7,12,-4,-34,11,-21,-6,-9,-12,-18,-39,7,14,-14,-1,-11,4,4,-5,-21,2,-7,9,-5,-9,20,31,17,-18,-14,-1,-6,1,-6,-14,-21,-11,-6,3,8,-4,5,26,2,-18,0,19,0,4,3,-8,2,-10,-6,13,7,-3,3,16,-7,-11,9,-11,19,-9,-6,-5,2,-1,-1,-8,-10,13,7,-9,-12,-2,0,24,10,-7,13,13,14,19,-6,0,-19,-14,10,-21,15,-1,-11,-3,21,0,1,23,-37,1,3,-9,0,13,10,13,31,-29,-3,-1,9,-2,-8,-11,-11,-6,-5,-17,15,-20,0,11,7,12,6,13,0,-12,-8,-13,-2,-3,-5,-1,-10,-6,4,6,0,8,-8,-7,10,-5,-6,-2,-23,-4,-4,-13,3,16,-1,16,5,-3,-12,9,-5,-2,11,-16,13,15,7,-12,0,-4,-18,-9,-7,4,-25,-6,-6,6,-19,-5,13,9,-1,-5,3,4,-7,16,5,-8,-6,3,5,1,-6,4,14,-4,14,2,2,-10,13,23,7,3,5,11,3,-13,-4,9,12,-6,-7,-2,-11,-3,0,-6,2,-2,23,8,-4,-13,-1,-7,4,-9,4,9,-8,-3,-8,5,-12,-14,-15,-13,-1,3,14,1,-9,4,-2,-8,-2,18,-5,-5,10,-4,-2,-8,12,30,-10,17,1,-10,-1,-15,-17,17,6,-3,-4,0,1,-13,0,2,-14,3,-4,-18,6,-12,9,12,-12,3,13,5,-6,-4,-7,2,-17,11,-7,3,-7,-2,12,0,-9,21,1,9,24,13,11,-2,-18,2,-3,-1,-14,-13,-14,2,-1,0,-2,19,-8,-3,-9,6,-20,-9,-5,-5,-4,-9,-17,-4,-4,3,-3,14,11,3,1,6,-20,12,-9,-16,-12,1,4,-6,-7,6,3,-5,0,-14,-2,20,-12,-2,-29,-15,-10,6,14,-17,1,-23,4,-2,-5,0,3,5,4,12,-20,1,6,-2,-1,1,-7,2,-2,-23,0,0,3,8,0,1,-20,17,-16,-7,-12,-2,5,1,-6,-15,6,-8,3,5,-14,-11,-2,3,-1,7,-2,13,-13,4,6,21,-18,-1,9,-7,-12,2,-12,-9,-6,1,10,5,-12,-5,5,-1,-18,-15,-13,19,1,10,-21,1,-8,8,-2,-5,-13,-8,9,0,-17,-11,-9,0,6,13,-4,10,0,-19,0,15,-15,-3,15,-7,-9,-8,-3,-5,2,5,-8,17,-5,1,-11,3,-10,10,8,4,11,-1,4,-12,-10,-11,9,-1,2,-6,-3,16,2,14,-15,2,0,0,8,-3,-20,-16,13,-1,-14,2,8,4,13,5,2,14,7,-26,11,2,-1,-13,-5,2,-9,1,-9,-3,-6,-2,19,-2,-26,0,8,-19,14,2,-8,2,-13,-16,-1,2,-12,-8,32,9,-23,-3,15,19,-22,2,25,-4,-1,-16,10,8,-18,4,23,8,4,8,-9,-12,-7,2,21,-4,3,-13,-13,-10,-12,-2,-13,-20,11,5,-8,8,-2,14,13,-5,8,-2,-10,-16,-4,-2,7,-7,12,-13,-5,10,11,18,10,6,12,-9,-12,17,15,3,13,7,-26,-13,16,-8,18,-9,1,8,-7,-3,4,6,11,-19,10,6,-4,-10,13,5,-16,-2,32,-2,-11,-2,-4,15,-30,-5,13,17,-14,9,-4,10,-30,-14,16,-17,0,-11,-8,-37,-5,9,-36,-6,-8,11,3,18,-11,-6,-1,-8,5,-10,0,-9,-7,4,-20,-7,-1,16,-5,-8,-3,-10,-7,-5,9,-2,-15,-11,2,8,-9,-18,16,7,-13,-1,0,10,-12,-12,13,21,-20,7,8,-17,-6,-9,15,9,11,-7,-17,-4,-11,-34,-5,0,-19,9,-15,-28,-10,0,-13,13,19,-7,-10,-10,-4,-8,4,-7,-15,18,18,10,-27,-9,-14,3,7,20,-5,1,-10,10,-3,-16,-1,2,14,-18,-2,-3,-2,5,8,12,-7,7,-9,14,1,-12,2,7,-12,4,-6,-7,-21,-3,15,0,-14,-9,-11,-11,3,-7,0,-4,-22,-15,2,-8,-25,11,15,6,8,2,4,-7,5,-2,-4,-13,-13,-17,-3,9,-9,-5,3,-5,-4,-1,-9,-7,3,-29,-1,0,-9,6,9,6,-13,-2,-5,10,0,4,-9,-3,12,-17,-3,-5,2,-3,13,2,-5,-6,-2,7,-8,9,5,5,-2,-15,-6,0,-9,-21,9,13,-13,-19,2,4,-2,-9,2,-12,4,-21,15,2,-12,0,-2,-17,-1,11,-7,2,27,-16,16,0,22,-18,-2,-8,-19,-16,-6,23,-12,-20,5,-24,-15,-3,-8,7,-1,-6,-1,-28,-6,0,11,-20,-1,-14,8,-8,-3,11,-4,-8,2,-15,-8,7,3,8,18,-20,-6,-17,3,-25,-6,-11,-15,-7,-12,20,3,0,-9,-31,20,-11,-16,-14,5,-5,-19,-10,-20,-11,-10,17,4,-18,-4,-5,-12,-6,-13,-11,-4,-8,1,-28,7,7,-7,16,1,-7,2,3,1,19,25,-10,12,-13,16,2,11,7,1,-2,5,8,-9,-7,0,3,27,-2,-11,-3,2,8,23,4,-7,-7,-3,-5,6,1,3,-1,12,8,3,-15,-2,0,-7,1,8,9,18,26,10,13,1,-7,17,2,-13,-2,17,-19,-7,-7,0,-4,6,-3,-5,-9,-12,-13,7,-11,-2,-11,5,-1,15,-12,-24,7,-13,0,-1,24,4,-21,-4,27,16,-9,-2,5,-7,-11,-19,-6,-7,33,2,6,9,-15,15,11,-16,-3,-26,13,-7,5,-15,-12,13,-9,-7,-1,3,-10,8,18,-2,-14,0,0,-5,-2,15,6,-4,15,-18,23,-2,-9,20,8,-21,-16,0,-8,11,-28,11,-8,2,-2,-11,6,-18,-11,-1,4,-16,-7,2,11,-15,-26,11,3,-20,-1,-14,14,-6,-8,-4,-16,3,6,13,-4,9,9,3,-14,-13,-11,13,5,0,-4,9,4,-13,10,-1,-19,-1,-5,-6,-12,-14,-23,-1,-19,-2,2,19,38,-8,-18,11,-2,-7,-12,14,-7,-18,-1,6,3,4,-12,-5,-20,3,8,4,4,-22,-5,-20,-2,10,-1,-3,-7,3,-2,9,-23,3,13,20,-3,19,-18,-29,-12,-4,-6,7,-2,-18,-8,2,-13,4,3,10,0,-1,15,5,-8,-5,2,14,18,4,-1,5,4,13,2,-1,-11,-2,20,16,12,3,-5,-16,1,10,3,9,13,3,-14,18,8,7,-1,8,-3,-22,7,-28,-7,8,19,-19,-12,2,3,-9,-1,13,2,9,-9,-4,-18,-19,0,-6,-1,0,-14,5,16,-14,-23,-14,-29,-12,-2,17,-11,-1,28,21,6,1,-2,5,1,-10,6,17,8,-2,-16,-11,0,-6,-1,-2,-18,6,1,0,-5,-3,5,-3,1,9,-16,-12,-13,-13,-7,-11,-11,4,26,5,-5,-4,1,-6,2,13,2,-21,-9,-12,-7,-24,-26,5,28,-8,-15,10,-23,-7,8,20,35,-4,-12,-19,-16,-21,-16,-4,-7,-16,10,9,9,-24,0,-4,8,-1,-5,1,15,8,-26,-23,0,2,1,-17,3,7,16,-14,1,-9,-7,-10,-22,8,-4,-6,-18,-14,-7,-19,3,-10,4,13,-4,-2,-2,-10,-24,-1,-18,3,-16,-7,2,-2,7,-12,1,-3,-32,-6,2,1,-31,-6,-24,-2,15,-13,-6,11,-6,9,2,26,14,1,9,-17,-22,-11,-16,5,-6,4,3,15,32,0,17,2,0,3,32,5,-8,-16,13,-1,-13,7,0,-8,-12,-18,-2,-22,-11,8,-11,-5,-17,-2,7,-9,-22,-4,-10,-6,-8,-4,1,8,4,25,-6,13,-3,-8,1,-10,-25,-5,-5,-10,-13,-2,19,-11,-7,10,9,-13,-19,-4,4,1,-6,5,1,-8,-7,8,4,-11,2,3,14,-3,-15,-18,14,-6,-4,24,-11,-4,1,-13,-8,-7,13,2,2,30,1,-18,32,-18,-15,24,6,5,-2,-24,2,-21,-1,8,-23,-3,21,-5,-5,-8,-9,7,-9,-13,-12,-17,-13,-2,5,21,6,5,10,-12,-16,-1,29,21,3,-7,-31,4,-25,-6,18,-8,10,-7,-2,-14,-19,3,26,33,10,0,-10,5,-11,-20,-4,-9,-14,10,-16,-12,6,21,3,10,-14,-20,4,-29,12,-8,9,1,29,-13,-4,9,-12,-20,-10,-1,-6,18,7,-16,-1,-25,14,-10,1,-22,6,8,-10,-27,-13,-8,-11,2,-1,1,13,-15,-1,15,-5,8,3,-8,3,-3,7,6,2,-3,-18,17,-15,-9,-21,0,0,18,-16,-22,-9,-9,-9,9,-16,-12,-17,25,-11,-15,-9,11,-21,21,-14,-9,7,-12,-24,-7,-5,-2,0,11,27,-12,0,25,17,2,8,23,-6,13,0,-10,8,-12,3,-25,10,12,2,-29,5,-6,-18,16,6,-9,2,-1,17,-9,-1,0,14,-2,-1,-2,-10,0,-16,-19,-15,6,18,-12,19,5,-10,43,-1,4,6,-8,-6,18,-11,6,-12,6,5,17,-34,-17,-3,-6,-17,-4,4,-1,3,12,5,41,10,-16,-16,-15,8,-6,-8,-27,6,-14,-14,-11,-13,-10,22,11,2,4,-5,-7,-2,-11,-10,-19,0,14,-8,-10,-1,-1,-7,10,6,-20,-11,-8,13,-2,-17,2,-11,-8,4,1,5,-10,-18,3,-9,-1,-10,-13,-4,15,2,11,8,-11,4,0,-17,19,0,3,-18,16,-10,1,-14,-5,-3,-10,7,-11,0,-9,5,-4,-1,16,4,-2,-24,6,9,-18,-22,-5,-9,1,-9,-3,-14,-7,-3,-16,18,37,-7,1,0,-3,-4,-1,2,12,-7,-3,-11,4,1,11,-9,-1,16,5,24,10,6,-5,1,-1,6,-10,-11,-7,-1,6,3,12,-1,2,5,-17,-1,6,13,8,-4,-11,-24,0,-2,0,1,16,10,17,6,-6,-4,8,-1,16,-8,-10,-6,-5,-9,14,1,-22,-13,6,1,-11,-18,1,4,10,-1,0,-1,-25,-4,-6,-8,-2,5,-2,20,9,1,-18,22,-9,-8,11,-25,1,5,5,-12,7,5,-15,15,-4,15,1,3,0,-17,1,-21,-11,-4,4,6,-4,4,-2,-12,-18,-3,-9,3,-10,-23,-8,-14,-1,-14,14,-7,4,-7,-4,4,-19,-14,-13,-9,-2,0,1,-2,-11,-5,8,1,15,-6,-2,-1,-13,-12,-9,18,-2,-8,-1,0,8,12,-4,-8,-23,-8,0,6,-4,-8,-4,32,-28,-3,1,-9,6,-24,-8,-11,12,22,7,1,6,-4,1,11,3,-6,-6,-22,14,1,14,-3,1,6,-11,-1,-8,-9,-1,0,-2,-14,-13,-7,9,-4,9,-15,12,13,-22,6,-1,-21,-2,-25,9,-7,-13,-11,16,9,4,20,12,-8,-25,12,0,-6,-12,14,6,1,9,-4,1,4,-3,-2,-21,-7,13,-1,-13,3,5,-1,-11,2,-16,-15,-6,-35,3,-11,0,11,47,-1,-13,3,7,-15,-2,-1,-9,-25,6,-12,-10,-15,-6,6,19,-1,-4,-15,7,-13,0,-4,2,1,4,15,-24,-23,18,22,-3,0,8,-1,5,-19,22,1,15,8,12,10,-1,-5,-5,14,-31,18,-8,10,-19,-17,1,2,-3,23,-6,-8,7,-3,-3,-2,1,-14,-16,12,-3,-14,0,0,-7,27,-6,-15,-8,13,-1,-23,47,-19,-15,13,3,-5,4,-4,-2,3,9,-34,-2,1,7,-22,20,-14,0,-2,26,-5,-17,-4,-5,-5,-7,10,-16,-28,13,-7,8,-13,-12,11,0,1,-14,-13,4,20,-9,2,3,-14,-5,-4,-10,1,-5,32,-26,12,-13,-9,-23,6,-1,-10,5,-2,-4,3,-25,-5,-2,-6,-5,17,23,0,-6,22,-9,29,-8,7,-14,-5,-9,1,-8,-13,28,1,6,-5,6,-1,-6,-20,15,-4,-2,-5,-25,-6,-19,-14,31,-10,-17,4,-6,-7,12,-2,-8,-7,-5,-7,-12,-13,-9,5,1,4,-4,-13,17,6,2,-1,3,3,-23,12,-8,19,-5,-7,-9,17,-8,-4,-2,3,-1,-13,-30,25,-17,-25,9,1,-1,2,-31,6,-5,-21,-15,2,1,-11,4,20,-10,-17,5,-3,-2,6,3,12,0,-11,13,12,0,-9,-1,-13,11,0,-2,-17,5,0,-15,8,5,-6,-5,-3,4,7,13,15,5,-10,0,-14,-10,-7,-9,-9,7,-4,-15,-11,12,-7,-2,13,-28,-7,-14,-2,-8,16,-9,-3,-8,16,-4,14,1,-12,1,-10,1,-7,-16,-7,0,7,-25,13,5,-17,-10,-2,-11,27,3,11,-2,-2,2,10,4,-11,-9,-6,3,-18,22,15,-4,-2,-9,-7,-2,1,-5,-15,-3,11,-20,2,6,-2,4,-6,4,1,-2,13,-9,2,-5,-13,6,1,0,-3,16,12,-13,0,10,-18,6,-12,-14,0,6,18,30,-3,-19,-16,0,21,-15,-1,-4,-4,8,-10,18,5,-2,-20,-6,-8,8,-8,21,0,-16,-19,6,17,-4,-22,24,-13,4,-8,4,-27,14,8,5,-11,0,-10,4,1,21,16,1,0,6,-23,-5,-10,-25,-17,16,-12,15,-11,9,-2,29,13,3,21,2,-34,-1,-11,1,-14,13,-1,-19,-7,-3,-9,-14,-14,-5,17,22,-24,17,12,-12,-23,0,-3,-8,-3,-3,5,-9,-24,-16,7,-19,5,-7,5,-2,-11,-8,1,-10,17,18,4,6,-6,7,9,-12,20,-10,-18,6,-2,4,0,-15,-2,0,15,6,-8,-20,6,-4,-3,-7,-5,-10,0,-4,-19,-10,-22,4,-2,20,7,-4,-15,-2,-7,-1,6,8,1,-15,-8,-17,-9,-9,-1,4,-3,7,-9,8,-7,-11,2,-9,-4,-5,-17,4,15,-2,24,21,10,-1,-2,-13,9,7,-4,-24,-25,-17,6,12,21,6,13,-18,8,1,-6,-9,8,-26,-14,-9,-28,6,22,19,4,-6,13,-17,5,-11,12,-7,-21,-2,-21,-5,-7,21,-3,-17,-11,-13,1,-15,2,-6,-22,-1,-8,-7,-1,8,-6,14,-3,-17,-2,-10,18,9,-6,-15,-15,3,-5,-17,1,3,-10,10,-7,-4,27,-1,-1,22,16,4,4,9,-13,-3,3,7,-6,-13,-43,0,3,21,-10,-3,-2,13,2,-11,-12,2,-11,-19,-12,-5,-10,-18,15,11,-6,-10,-7,-4,-17,8,14,-4,-4,-16,-10,-26,-19,-11,-9,-8,15,11,-11,-5,-19,-4,9,4,8,10,8,14,-10,4,16,2,17,13,-13,-2,2,18,12,1,6,3,10,18,4,-14,8,-2,13,5,-3,-9,-20,37,-16,-19,18,2,-15,-21,5,-1,-9,3,-12,-11,-2,16,-2,1,-12,-6,-3,-3,-27,-10,-16,16,22,-13,22,16,-17,-8,-23,-1,7,-15,9,-6,5,-22,-6,15,3,-7,-1,26,9,-3,-6,-5,8,4,8,-11,-5,2,-14,7,7,15,-6,19,14,9,-5,8,9,0,2,11,-4,15,-8,-4,4,-4,-4,-8,-5,-5,-4,-20,-9,-5,-40,-40,-20,-3,60,-16,-24,-3,-25,-23,-20,-4,4,-10,-5,-1,2,-17,-18,-19,35,25,-32,4,20,-6,-25,-25,-10,2,-2,2,2,1,8,-25,-1,12,-6,-15,11,-7,-18,-5,11,10,-10,19,-8,7,-13,-6,-13,-1,-8,1,0,-23,1,5,5,3,8,6,-6,1,-7,15,-7,-8,1,-1,-2,-9,-2,-6,0,-25,-4,-7,-13,-3,-4,-13,68,-31,-6,-7,-27,-10,7,-18,12,-1,12,-11,16,-12,20,-7,-4,-9,7,14,-14,-10,3,-10,-9,4,15,-22,3,-2,-1,-25,-26,0,8,-12,-19,-15,1,7,12,3,-21,9,-3,3,6,-16,-11,-1,-8,0,-4,-2,1,-2,9,1,-2,-8,6,-12,-12,-4,-7,0,6,-10,7,-6,5,2,6,15,-6,-2,-7,-8,-7,-26,5,-23,2,11,-25,-15,5,-26,8,-8,-10,5,3,4,22,-7,-30,0,16,10,-16,5,-7,-13,-8,-8,-2,-7,17,9,14,2,-28,6,-2,0,16,8,9,5,-10,3,-7,1,9,-2,14,28,-11,-2,-6,7,19,6,-7,8,-2,14,9,-14,5,-6,-8,22,-12,5,1,-4,6,14,4,3,1,18,10,-6,-8,-24,-5,-2,-4,-5,-15,-4,-5,-1,-7,-14,-11,15,7,2,-2,-7,2,-3,13,3,-12,-11,-1,10,-9,-28,2,12,-18,-3,-12,0,-4,-17,-6,-5,14,2,-16,-1,-19,-7,2,-16,-8,6,-4,14,-8,-7,-15,-6,5,36,-8,1,-20,11,5,1,-2,9,-1,-5,6,-21,-1,-7,9,16,-5,13,1,1,-14,-17,9,23,-10,14,-6,-4,-13,-9,-16,-21,-13,15,-21,-3,-19,3,25,8,-14,9,1,-9,-12,3,8,-3,-8,23,-5,-13,-16,-11,-6,-14,-15,-10,12,-13,-3,-10,19,-9,-18,-11,-9,-8,-7,-9,-12,-3,-10,-2,-22,-6,4,3,-10,3,-4,-1,-23,6,-2,-7,14,-6,14,10,-17,-13,-13,-13,-7,-11,-4,-6,-5,8,-12,26,-22,0,-9,9,-10,-27,-13,-4,3,0,11,-11,-1,25,0,24,-2,-5,-19,27,13,-15,-11,1,38,5,-3,8,-8,5,-14,2,-19,-6,0,-8,39,-10,-13,11,2,19,-11,26,-18,-12,0,4,-20,-4,-10,-16,-10,-17,9,-6,-3,-7,-1,-4,-19,0,-1,15,4,9,8,5,-2,-2,-12,-3,-9,-14,-4,-4,0,-9,-3,4,-7,-20,-5,12,5,-13,10,-3,8,2,24,-8,-10,-6,6,-20,11,-15,-9,21,1,-27,27,-1,-12,-17,10,-1,-10,-4,16,-7,9,2,22,-3,1,18,10,24,4,-1,-8,1,15,-7,-9,-13,-4,1,10,-8,-8,-3,12,3,-9,1,-3,-11,13,0,15,2,3,-6,0,2,-1,11,22,13,-13,-25,21,-1,-7,13,3,-9,7,-15,5,-29,-4,-37,-7,-18,-2,11,-2,17,15,-13,10,-18,4,-18,-8,-6,11,-1,-2,-17,2,10,-6,-21,2,-11,1,17,-4,-12,-12,-4,5,16,-9,18,4,1,8,6,-7,-6,-7,6,7,4,-1,-1,2,1,6,20,10,-26,2,-5,-3,29,-4,12,7,11,5,17,7,0,-9,-13,2,0,-11,-10,-16,-15,-1,9,-5,13,3,16,1,13,-1,-1,8,10,4,-12,-13,6,5,9,-11,-14,8,-3,12,9,2,-12,8,3,-2,-9,-12,-11,-2,-9,18,-22,11,-10,5,1,4,-10,-20,8,-1,-13,1,-10,-4,-7,-6,-12,4,-5,-12,12,-13,-25,21,-10,-15,9,-5,20,-2,14,-19,-9,7,-12,-2,-10,-5,-39,13,2,-2,-16,7,-15,-11,-6,-4,3,0,-15,-7,-7,-10,-11,-18,-5,-9,-21,-12,2,5,-9,6,11,-8,-9,5,-11,3,-4,-10,0,6,-21,5,8,19,4,-18,27,-25,-6,15,-4,-17,-23,-14,-7,-4,-10,13,-15,4,6,-5,1,-18,-8,-7,2,-10,-1,6,10,-1,-6,-22,3,2,5,-16,-11,-4,0,1,-10,-3,23,-14,-6,7,-30,3,20,-15,3,16,-22,5,-16,-7,-8,7,9,3,-20,-8,-14,4,4,-4,-15,22,-1,-11,-5,6,-5,4,9,12,12,7,-13,22,0,5,-3,17,11,6,-14,-5,0,-3,-12,-13,1,3,24,18,8,-19,13,-8,2,1,-20,-11,-1,26,26,-16,6,1,5,-8,-7,-2,1,17,-17,-33,8,16,-30,16,89,-24,13,8,-16,-3,8,16,14,15,-24,-14,3,-16,-9,4,-6,9,-1,9,1,-13,3,-4,-5,20,-9,5,16,-9,-10,0,-1,16,5,5,-5,-19,-8,-4,-8,11,7,14,39,-9,14,-13,-14,-5,12,-1,13,-5,2,-16,6,-10,-14,23,-17,1,3,-2,-18,-13,-8,-20,18,-2,-19,16,-1,5,-12,0,0,24,-19,-26,11,0,-12,8,-3,-13,-9,0,8,-13,3,10,15,-3,12,2,-3,-2,19,3,-9,15,2,4,-4,-3,2,4,-11,4,-2,1,-5,-5,7,-6,-1,4,-1,-2,-8,-10,-14,-6,1,-8,11,-10,-9,-17,1,-3,-16,-8,0,15,4,-13,4,6,-23,8,3,9,-19,-6,-6,1,-9,1,-11,11,4,-7,-3,-3,-6,6,-14,18,-6,-1,0,-3,-4,4,4,-6,-12,8,6,-17,0,-8,-5,-3,-2,-15,-6,-8,8,4,-4,-20,6,-5,5,0,0,-15,-6,-1,-10,-7,-12,-10,15,-7,-23,-36,-5,-9,19,19,-5,-14,-13,-11,21,-15,-21,-21,-16,6,5,0,-10,2,11,16,-4,-16,-11,-1,6,-5,-10,-2,-15,-11,18,2,5,1,-3,5,-1,-6,2,9,0,-17,7,-16,6,-16,-15,6,20,2,-2,-17,-2,12,-9,1,11,-28,-4,4,-11,7,-8,-4,-2,1,-2,-7,1,11,4,0,-4,1,-14,-3,13,4,-9,-23,17,-10,-5,-23,1,4,-8,3,2,0,-2,9,16,1,20,-12,8,-11,-2,1,-3,6,-8,-8,12,-13,4,-5,5,4,3,-10,7,-4,-2,10,12,10,-4,0,34,-7,17,7,15,0,-9,16,0,-8,-12,-2,-6,-7,-7,23,-8,-25,-19,15,-33,-5,3,6,4,-9,1,-11,-5,-6,-2,11,-8,-4,-31,11,0,-16,-1,30,-7,-10,-9,-22,-15,-9,1,-2,-5,30,-23,13,1,2,15,5,-1,4,-17,-11,2,7,-9,10,-2,2,-5,-9,-11,-17,-2,-1,-2,14,-2,-7,-6,-4,-12,3,16,-1,-1,2,-1,-17,9,-24,4,-12,-22,1,-5,-28,-29,18,-12,9,-11,7,-25,3,-1,-28,-3,-13,-7,-12,1,-22,-11,-7,-15,1,-24,13,-9,-19,13,20,-18,-13,1,-22,-9,-22,-4,-32,-22,45,-9,14,-6,-3,-5,31,-4,-13,-12,-24,-1,-6,9,0,-11,-9,-1,7,-2,-3,-5,15,-1,-8,-13,-16,-3,0,-3,-6,-5,-6,-8,-8,-13,-9,31,-8,11,-8,-16,5,-11,-4,7,28,23,13,16,26,-22,11,6,-13,-1,-5,6,-8,-2,-15,-7,-8,16,10,-4,4,-24,3,15,-23,7,-9,22,-5,7,0,18,-24,-12,12,-4,7,-4,4,1,-23,3,-12,-5,-6,0,-1,31,-16,10,0,7,11,19,-18,-4,0,10,-4,-19,-2,-18,6,7,16,3,-9,-5,10,3,0,-10,18,2,8,-10,-13,-15,-6,-2,1,8,6,0,-2,-3,-10,23,6,-5,-2,-1,2,23,0,2,-15,-9,-3,-5,10,-20,4,-4,-21,5,-17,34,17,-10,-2,-5,2,-6,6,-3,2,-9,-9,1,-14,-7,-21,-7,-9,-6,4,-15,-6,10,-10,10,7,11,-26,-12,-10,9,-24,4,-20,10,7,7,13,24,8,-3,17,-14,11,-2,1,-19,9,-16,-8,-6,-9,-10,-8,-4,-1,-8,-2,8,-3,12,26,2,7,-5,-11,-3,-12,-6,-2,-14,9,-4,-1,4,-1,1,-2,0,-3,11,-9,-28,6,-10,-1,-20,3,-6,0,10,-9,-23,-20,-11,2,-11,-12,-5,-11,-26,3,17,-30,-2,-3,9,13,-23,-8,4,-9,-8,-11,-1,2,-12,0,16,-12,0,1,-12,-15,-13,-13,-28,14,9,-19,-16,0,-5,-12,2,-7,-1,-7,5,13,27,7,9,20,-27,-22,-7,-7,-23,-17,1,-2,9,5,-6,9,30,29,-10,19,-20,11,-19,-9,-4,-20,-17,27,-5,20,4,4,-5,13,-17,19,-30,-3,-23,-2,13,1,-6,3,-15,-29,5,-13,-18,30,21,34,-15,0,-12,40,12,1,-13,-11,-4,-20,-8,0,-8,-11,2,-8,-4,-10,10,-2,-6,-14,3,-9,0,-5,-4,0,-20,-29,-12,6,0,-1,10,-4,-10,-16,22,-14,3,3,-4,19,11,0,-13,34,-14,1,-4,-7,-15,-18,-8,4,-7,12,18,19,2,5,-6,11,0,-5,-13,-14,-6,-1,-4,-6,-7,-9,3,1,-4,23,-6,21,6,-1,2,10,-1,7,-9,3,6,-3,-10,13,29,-1,10,-12,8,13,-15,2,1,15,1,-3,-8,-12,-20,-15,-19,-11,8,-9,-9,19,-6,3,-4,-21,-13,8,-12,-5,-9,-6,-7,-7,15,17,-13,10,-4,-8,-22,-8,10,8,-7,13,20,16,11,2,1,-10,5,-5,-13,-14,-5,-9,-3,-5,-15,8,7,5,12,11,6,-5,-3,0,10,4,-14,6,3,3,-7,8,-7,-9,-19,-13,-13,-4,-4,-7,-4,1,-11,-8,3,22,11,-4,-3,26,-29,-18,3,-7,2,14,5,2,4,9,6,-6,3,3,4,-14,27,21,-13,4,2,6,10,-3,22,9,-5,-16,18,-1,-18,-17,22,4,-14,5,20,10,-10,-1,27,-10,-18,7,5,-7,8,2,-3,6,-7,-5,-3,10,3,-10,-13,12,5,-3,-1,3,7,6,-7,-11,-9,0,4,-8,-16,-2,5,-15,-30,-2,0,-14,2,2,-16,-23,5,3,-3,-8,-27,-13,-11,-11,-8,-6,-14,-31,6,-12,11,0,24,13,-2,-2,-7,-23,-23,9,3,-16,-20,-11,-31,-9,22,0,8,-5,6,-19,-14,-2,7,-4,-13,-8,-15,-7,-12,-17,28,-8,-8,-4,-8,-10,-15,-11,-3,4,20,-18,-4,-11,1,-9,-11,-31,0,-11,11,28,8,-5,-5,1,15,7,4,-2,21,19,-18,-22,8,9,-2,14,11,-1,5,-7,7,1,-2,-10,24,-12,-3,-19,11,21,-1,15,27,-7,-20,1,-15,-6,-13,-10,-2,-13,18,1,-5,-7,2,-5,0,-17,8,9,-8,12,1,-8,-5,-13,8,-2,2,3,-6,2,4,-12,-12,-1,7,7,-2,5,9,3,14,-9,-12,4,-12,-16,1,10,-3,10,-21,-9,-8,5,6,2,1,-10,2,2,-2,12,-20,2,6,-7,0,14,-7,-4,13,-13,2,-10,5,14,-1,-6,8,-12,-22,-11,-12,-15,-5,-17,-14,-8,18,9,-21,1,-9,-3,-13,-17,-3,-12,4,-17,5,5,19,-12,2,1,-1,-2,-7,3,-16,4,3,-8,-4,21,1,6,16,-28,7,0,-18,17,-17,-2,-2,0,-10,5,17,-16,-9,16,-9,-1,-3,-5,-4,5,3,19,5,16,11,-10,17,-8,8,-5,5,-4,-1,-14,12,-20,27,2,-6,0,-20,0,15,5,-4,-28,-18,1,10,2,-5,-12,9,-13,-3,-12,-15,9,25,-16,4,-3,-4,-12,-3,-23,-2,-12,3,-2,16,8,-7,0,-5,8,14,-7,13,-21,-2,-22,5,-5,0,-11,-15,-7,14,-30,25,6,1,25,4,-15,3,-7,-9,-5,15,-12,10,-1,6,-9,9,-2,17,7,4,-24,2,11,-11,-23,4,4,-8,-14,-13,35,-7,-15,-12,-6,3,-23,7,13,-4,-3,15,-1,-9,-7,-3,19,-12,-13,4,-9,-1,-18,5,-20,6,-1,4,3,-4,0,0,-27,-16,6,-3,-4,-7,0,2,-19,16,-1,-2,5,-5,-7,13,-15,7,10,-28,16,1,17,9,-4,-6,4,-7,-6,11,-18,-18,-13,13,10,-16,23,-11,4,2,11,-24,-8,5,-16,15,3,-22,2,-9,-10,-18,-16,-24,0,0,17,7,-12,8,-6,8,14,-7,15,14,-18,12,-19,-5,-4,4,-9,15,-15,4,14,-7,17,1,-4,11,15,8,-11,9,-12,-8,13,1,-13,9,8,3,3,-3,-25,-21,5,3,13,16,4,3,-16,28,-11,-11,5,2,-37,-13,-2,-1,42,-16,28,6,-11,-7,-1,-5,-2,-10,-15,21,2,6,-4,-4,-7,-25,-20,-41,9,-18,-9,22,7,-10,0,-2,15,-18,-8,39,-8,19,-25,17,-4,-5,-6,5,6,-12,9,-2,-28,-11,-17,11,8,-2,-13,0,-15,0,-13,7,-6,10,4,9,7,0,-7,6,-20,1,-18,2,9,2,-20,-3,-12,-16,14,-12,-16,-6,21,-7,-11,26,-16,16,-1,-10,0,-24,-7,-11,-17,-27,-6,3,-21,-15,-21,-4,-22,-34,-1,-27,-17,-13,2,0,3,-8,-11,8,7,11,8,9,-5,3,-26,13,-3,9,28,-13,8,15,-15,0,-14,-19,0,5,11,15,-3,8,-13,-9,-5,-7,-11,-11,6,-7,3,2,-4,5,-18,13,7,17,1,-16,-4,-4,5,-18,-27,16,19,9,9,9,7,2,0,9,4,-29,-15,4,-11,-14,8,1,9,-24,-2,-6,-33,-34,11,-8,6,-1,3,22,-11,-13,28,0,11,-19,16,4,1,5,-25,-8,14,14,2,-9,6,6,-2,4,-9,2,-6,5,27,6,-3,4,1,-8,14,-8,-3,-17,-10,-13,-4,-6,-14,-11,8,-20,-4,-5,29,-13,33,-3,-26,-3,-8,-14,-10,-24,12,-19,-8,1,12,1,26,16,2,-21,19,4,0,6,-7,-5,-2,2,3,5,7,-10,-23,8,-23,-3,-12,-3,5,-6,3,6,-4,16,5,1,-20,-13,-15,-27,14,-3,-1,-6,-4,1,25,21,-5,-2,-6,-3,0,19,8,0,17,4,-26,-13,-9,-11,8,-2,-7,-12,-2,-15,9,6,15,-4,23,5,-10,18,-6,2,-10,-7,-1,3,-9,-5,2,9,4,-3,-24,-9,-17,14,13,23,-15,5,3,-8,-5,-2,-1,-10,-25,-17,-18,14,-21,-17,7,-3,-6,9,-6,-9,2,-5,-4,-13,-13,-11,-3,-6,-9,-3,1,18,2,0,4,-3,-15,-12,3,-6,1,6,6,4,-19,16,-2,-4,26,7,-20,26,-20,-13,36,-4,-9,8,5,-9,13,9,38,-5,-1,17,-21,9,-6,0,-4,7,-21,9,-5,-9,-7,-6,31,-6,2,16,-2,-1,-15,-29,4,18,8,-8,2,10,0,-15,5,-18,-12,-7,-24,-11,-24,0,-13,2,10,8,7,-2,-6,2,11,13,-1,0,-11,-11,-8,-8,-17,-12,-17,40,-2,-16,-20,-3,16,-21,-16,-12,-3,11,-11,-20,-8,1,-5,-8,-25,-27,11,8,-20,-4,-17,8,19,-14,-1,9,-5,7,-13,-5,7,-8,2,-9,-10,-19,18,-1,31,-16,-5,-8,11,16,6,-22,-2,15,-14,-10,5,-7,-7,-13,-2,-5,-3,12,-11,15,17,-19,9,9,12,-27,7,-3,-15,-20,-18,-12,-7,-12,-18,-29,-21,-4,-21,-9,-13,-3,26,-12,-6,0,3,34,4,-4,-4,-12,-9,-8,2,-34,1,-14,-26,13,1,15,18,9,17,25,-23,-8,-17,-5,3,3,9,-11,-18,1,6,2,2,-1,2,3,-13,0,7,9,14,8,-4,8,5,-10,-5,-4,-1,9,9,19,5,18,9,14,17,0,3,19,-10,-7,-16,-22,-15,-2,-8,8,10,-16,-10,2,-16,-23,-10,-28,6,0,-18,-15,5,3,4,12,1,4,2,4,-13,-14,0,-7,-1,3,-15,-13,2,-11,-9,-7,1,5,-3,0,-12,15,-2,-10,14,-3,-21,-2,17,-3,-13,1,-22,2,4,14,1,-1,25,-10,-20,1,35,3,-11,2,-2,2,-4,-17,-18,-6,32,-11,-9,-13,-13,-2,24,2,-7,-1,5,15,-1,-10,-15,-18,-17,-16,19,-16,7,19,-11,-13,7,9,1,7,-2,1,6,17,-14,-9,15,-13,5,20,2,-6,-1,-7,-9,-28,-13,0,-2,10,-17,1,4,-12,15,16,-16,13,-6,-9,4,-4,4,6,-7,-3,-3,0,3,-19,-1,19,-7,16,4,0,-4,15,1,-16,3,9,13,-3,-11,-19,0,1,-15,18,-15,-9,0,3,-22,8,13,-24,-4,-10,-8,10,25,-2,9,-11,3,22,9,-9,-1,16,9,7,-7,1,-7,11,-17,-14,-14,-12,-15,-2,-1,-19,0,-17,7,-9,-23,29,4,-9,0,4,-15,-29,0,10,-17,-2,9,-12,3,-12,-9,7,34,-1,24,30,-20,-1,17,2,-18,9,-11,-14,2,11,9,8,12,6,-3,0,-28,-5,-16,-13,-3,1,-19,-5,15,-8,-4,-20,-8,7,19,11,-5,11,5,9,-7,-16,-21,11,-20,-11,-9,-29,-2,12,-8,-17,6,0,-1,-9,3,-23,-8,-19,-17,-16,4,10,7,22,-13,-26,-3,-13,-16,-11,-6,-19,16,-4,2,5,3,10,8,3,0,-2,-20,-14,4,3,-21,-6,11,5,-13,8,3,-9,-9,17,-3,-1,-5,-22,-3,-10,-3,1,-1,-8,-3,0,3,7,2,-1,20,-6,-14,11,-14,3,6,-8,-5,-7,-10,4,-14,-10,-4,-4,-18,16,-7,3,7,-8,-2,-2,-23,7,-14,-12,11,1,-6,-6,1,11,13,5,-4,6,-4,-8,-8,12,-9,1,4,-20,-21,2,15,-6,23,9,2,7,-5,-6,14,17,8,1,-10,-9,-22,3,13,-3,9,-3,-7,10,-4,-1,8,-7,-32,29,-13,-20,2,0,-4,-2,4,-15,16,9,19,6,-9,-17,4,36,-11,4,17,29,-10,-24,-4,24,6,19,4,-19,11,-4,0,-20,-17,-10,-14,3,-17,-5,-1,6,-5,22,-11,8,-5,-4,-18,-13,-12,-4,18,-13,-14,-9,-6,15,1,7,-8,25,-10,-10,1,5,7,-3,-2,-24,-2,-6,8,7,16,0,-11,5,12,-18,-33,-34,1,-13,-11,3,19,6,-4,-13,11,-5,-6,12,-5,-13,-5,-9,13,4,8,24,-8,-17,-15,1,-13,-17,-6,-19,9,-12,-3,-13,-1,4,-24,6,4,-5,1,2,-2,-34,4,-18,-3,-14,-7,-14,7,-19,-6,-3,-6,-2,12,8,-15,-14,3,-1,1,-2,-3,12,12,-6,-25,-20,-4,-4,10,-7,-21,-20,-2,-14,21,14,-3,-29,5,-11,-18,-18,5,4,-4,13,-19,-20,-18,48,-5,3,9,-11,23,0,-23,-14,-22,3,-30,4,-24,-21,-16,1,1,11,2,-4,10,5,-21,-25,18,14,-27,-3,-11,-4,-20,10,-10,19,4,-5,17,4,-2,22,11,0,-5,-4,-9,-8,-4,22,1,29,0,23,18,-2,-7,0,-11,-8,-12,1,7,-6,8,3,-15,19,-7,-11,-19,-11,-6,-23,-14,7,-15,-5,-23,-7,-22,-2,-4,12,12,-9,-14,-5,-12,-5,-9,15,-18,-8,-16,-9,-20,-15,-18,-7,5,-11,-3,-7,9,-1,8,-2,-18,-4,-16,4,11,-8,-11,-10,9,-12,-12,14,-5,5,-1,-1,8,-6,4,-13,-13,9,-2,6,15,-7,-5,3,4,-1,-6,-7,0,5,1,6,3,16,-8,27,-12,8,1,-6,0,-10,-8,10,1,2,-11,-2,2,-9,-3,6,1,15,2,-16,-15,-1,-7,7,-14,8,-6,-11,-15,-8,-12,-6,-5,4,3,-13,7,-8,21,7,-4,4,6,15,16,-14,3,1,16,-10,-10,2,-7,7,10,7,14,-3,13,4,8,-7,18,9,13,12,-2,-5,-7,-5,-2,-9,-12,8,11,-14,0,-15,6,4,-2,11,-2,-5,-3,-4,-27,-4,14,-8,5,-20,9,6,-7,-1,-1,22,-1,-11,13,-10,-23,-1,1,-11,7,-21,10,8,-11,-8,-12,24,2,-18,-10,-12,0,-9,-13,1,-21,-16,-14,4,-4,-17,-10,-7,-9,-7,-6,7,6,-3,-8,0,-5,-7,0,9,12,1,-4,8,-7,-2,-5,21,0,3,-6,15,-6,-14,-6,5,-3,17,-10,13,1,-5,11,14,5,-13,17,1,11,8,4,9,-1,-10,-7,17,-3,-19,11,6,4,-7,31,-7,-13,4,1,5,12,-10,-27,2,18,-25,0,-13,-12,-6,10,-10,-8,10,-8,17,-5,-21,-11,-13,0,-1,5,-5,20,-1,12,-8,-13,0,1,0,14,-14,9,0,1,-18,-2,6,-3,-13,7,18,-8,7,28,3,18,15,-1,-12,9,-10,8,3,12,-10,-7,-3,-12,2,-12,13,-12,5,-6,8,-10,-12,4,-18,-2,-7,3,3,-19,7,-17,-12,-23,10,-20,-19,18,23,8,-31,-15,19,-12,-27,2,-6,-22,-23,-16,-6,13,-12,-7,34,11,-25,15,15,-2,-6,5,-11,-11,-13,-9,-19,13,-1,12,12,6,-27,-3,-12,-15,-7,24,6,8,0,-11,-21,8,-6,-13,-9,-7,-16,-13,12,-14,3,-17,3,9,-13,9,-2,2,-9,-17,-6,0,-5,-16,9,-3,14,-4,9,3,-20,-7,17,-6,-22,13,-2,-6,-9,-8,21,-10,-10,-3,16,-10,-13,2,2,8,-11,-7,0,-11,-14,-2,13,-3,-7,2,14,-22,-15,4,1,5,3,6,2,-7,-10,-4,-5,-16,-16,11,-6,-5,-10,-24,1,-14,8,9,-23,9,-10,-12,-7,0,3,-8,2,13,10,-12,4,-19,-1,18,-8,9,-5,-5,-1,2,5,25,9,17,8,-11,15,-4,0,3,0,13,-1,-1,-12,-16,-11,-10,17,-2,5,11,0,12,-11,-10,-4,12,0,11,5,-1,-11,9,9,-15,1,-11,1,5,0,-15,0,14,2,4,-1,-7,-7,29,8,-15,10,0,-14,3,8,-7,12,-3,-24,3,10,0,-21,-21,-13,-17,-33,-30,22,18,-6,-7,13,-29,-33,-11,3,-6,-17,-13,-12,-18,-29,-23,33,13,-4,-16,31,17,-12,8,31,15,-9,-3,12,-17,-21,-19,4,-10,6,3,-3,20,16,10,-4,5,5,14,4,-9,6,-14,-10,-5,4,5,-29,-7,-3,-2,-17,-20,1,-13,9,-9,24,0,-7,15,1,-5,23,-1,-12,17,9,-19,-7,-1,-4,-18,-27,-7,2,9,-5,-8,2,-1,-5,18,1,-23,-1,-9,-5,-10,5,-7,5,-15,3,-20,-15,5,-14,26,-7,-9,-8,-11,-12,-15,-1,-2,9,-8,12,-11,-17,6,-12,-8,-12,5,12,7,-16,-6,-6,7,-6,6,12,22,-3,0,-17,-10,8,-9,18,2,6,7,4,-8,-15,16,-5,-2,15,14,-9,3,13,-5,2,15,-7,-10,5,-4,-8,-6,-2,-5,-7,2,19,12,5,-7,-6,3,10,-11,3,15,-16,7,-2,-1,-14,-1,-4,17,10,4,-20,-2,2,-13,-15,-11,-33,-9,-12,-13,-7,7,13,-14,-13,16,3,-9,-3,12,-3,-6,-10,6,-7,9,13,11,2,2,4,-11,-8,-16,-10,3,-8,18,-18,0,-4,14,0,-5,6,1,2,-16,-16,9,-11,-10,8,1,-3,-1,18,5,-23,8,8,2,1,-19,-4,1,9,-6,16,-4,6,-4,5,-7,0,-6,2,14,10,-2,-8,12,1,-30,14,12,-7,-11,-7,-8,-7,8,4,-23,-15,1,-10,1,-8,3,8,2,-13,8,17,7,-7,1,4,-9,1,-16,-23,-10,0,5,17,-2,-7,13,9,7,-2,-7,-3,15,4,-23,-16,-7,-6,-16,-15,14,0,-6,0,5,-11,12,-9,-2,-4,-5,-11,-3,-7,-12,0,-12,2,-12,4,15,-7,25,0,11,7,8,12,23,15,-18,2,-4,5,-16,9,-3,-13,0,-7,-14,-19,16,19,7,5,7,-3,-2,-5,4,10,-3,-3,-15,9,-8,-7,5,-4,-2,-3,8,5,-4,0,-9,-4,18,11,-2,6,5,-11,1,-8,33,2,-12,1,-5,4,-7,24,19,-14,15,-17,-1,-7,4,-15,-8,-6,-4,-16,12,1,17,5,-2,-19,0,-4,-15,-13,-1,4,-9,-8,-7,-14,26,9,-2,6,-5,-16,-1,4,-23,-15,-22,-12,-13,-2,-8,4,-13,15,4,2,-11,-5,11,16,-10,-8,-13,-12,4,-7,-21,1,-8,10,17,-2,-9,24,11,13,-4,-8,1,4,-2,11,6,-4,6,-11,-7,-10,15,6,-11,-17,-6,1,11,-12,-3,-5,-15,12,12,-18,-8,-10,-3,-25,-16,-4,-19,2,-13,3,-8,-19,-5,12,9,-13,-8,-4,-1,-8,-2,1,-14,-2,-7,2,-14,-7,-19,16,-9,0,5,-13,-4,6,7,5,-6,3,-1,0,1,-14,-7,-1,-6,-3,20,3,6,10,-7,3,-7,11,8,3,-14,4,8,-4,6,-8,-4,-14,18,5,-2,-13,-3,-5,-13,-3,-10,-2,-5,12,-9,2,2,-10,10,-27,-2,12,-20,-6,-9,3,-9,-16,3,15,4,12,-3,-12,-5,-19,-20,-4,-2,-9,-19,-1,-27,-14,-10,2,-6,27,11,-20,3,-24,-1,2,-5,-1,-16,8,-15,-13,4,-5,2,-7,14,8,8,-25,-10,-8,2,-13,-14,3,5,9,-7,25,2,-19,-3,-9,-3,-27,-12,-18,-6,-16,-18,-1,-7,-3,-7,8,6,-12,7,-15,-1,-29,-7,-10,-7,-2,-4,6,-23,-10,9,27,13,-12,-8,-6,7,-27,-37,-8,15,-1,-10,15,-19,-6,-5,5,10,-14,-1,-4,13,-10,-30,-19,39,-12,-16,8,-19,11,-5,9,5,12,8,9,0,-15,-13,15,3,-2,-7,10,15,-4,-7,2,-3,14,-1,-9,-5,4,-6,-18,-14,3,6,-7,-5,-8,2,-10,1,19,-5,-31,-17,5,-3,3,4,19,10,-8,18,-1,23,10,8,20,-11,-12,-13,18,-11,-10,10,11,17,1,5,2,-9,7,-12,7,-19,2,2,26,-13,4,35,-1,15,-2,-20,4,-25,-4,-4,8,-18,-5,-29,-16,16,-23,8,1,16,-15,-2,24,-1,-1,-2,8,-24,-3,-11,-8,-11,-12,-5,3,0,-19,-11,8,1,-22,-21,4,-18,2,-7,-20,-24,-32,21,18,3,8,2,-17,3,5,-25,-2,-11,-13,8,-19,-5,-28,4,24,-3,-1,-19,-7,-10,-14,-9,9,-10,-6,-28,-16,-10,-8,1,3,1,3,-2,5,10,2,-8,-16,-16,-6,-10,-2,17,-5,14,-19,10,17,-6,-6,-14,8,16,15,-9,-16,5,-1,-4,-9,-3,8,0,5,-2,-3,-10,-10,1,10,-14,-8,-18,-1,-12,-15,-2,20,9,-6,0,-2,-1,3,-18,-12,-11,-18,-1,-27,9,1,-17,3,-6,13,4,-10,-12,-10,-10,0,6,2,-18,-6,1,0,-13,-7,7,4,5,-2,2,15,-8,27,5,-12,-14,3,5,4,-14,-14,10,-20,4,8,2,31,-10,8,-5,-3,-1,-12,-6,-17,-1,-9,8,14,-1,3,-4,4,-1,16,-5,-5,-4,10,-15,-14,10,11,15,12,1,-3,1,-21,9,15,0,-22,14,-5,2,-1,23,-17,8,18,-7,-12,7,-1,-8,6,6,12,14,-9,5,-5,13,12,6,-8,12,3,-8,27,1,-10,15,-5,2,-4,-11,-20,-21,1,-19,7,-3,-6,8,5,14,10,-9,-15,-6,-6,-3,-22,-18,14,-6,-16,8,4,29,-12,-14,-12,-20,0,3,5,-28,-12,18,-9,-14,1,-8,-15,-11,-34,-11,-23,-9,-12,-13,13,-17,-9,26,-6,-13,1,-9,12,-3,-16,-21,-16,10,-11,5,14,-13,-15,9,-2,-18,-21,-10,4,-21,-6,6,8,13,20,20,2,8,14,-8,0,13,9,0,7,1,-21,10,3,10,-17,2,-10,9,-12,-10,32,18,-10,11,-2,9,-7,-11,10,-3,5,-4,-14,16,-14,3,-12,17,1,-3,6,-3,-8,-29,5,0,3,-7,-4,11,-13,-18,-12,19,6,-4,7,-17,-15,-15,5,26,13,-2,-2,-1,0,16,5,5,-8,4,4,-6,-1,11,-3,-11,-2,8,-10,-9,-1,1,-11,-2,-6,-7,3,-14,-7,3,19,4,14,7,-18,-11,-5,-12,10,-8,-8,1,16,0,23,-26,12,13,-23,21,-10,-13,-13,2,3,6,3,1,-16,-20,20,-12,-5,4,4,-1,-6,10,-11,16,5,-2,-10,-1,15,-23,-7,4,-13,-2,18,-22,-19,-5,-9,6,-10,4,-20,-1,38,-5,-5,7,-24,-4,15,-20,-13,19,1,21,2,4,8,6,1,-10,-13,18,4,18,15,-1,-12,-7,-5,-12,7,-7,-1,1,10,-10,-8,5,3,14,-9,-7,-3,-11,1,-7,-11,3,-19,8,-1,-6,0,-10,7,-4,-4,-13,-3,3,-3,3,3,-7,-18,1,-8,-15,-1,-4,-3,-12,4,-5,-10,0,-3,-8,-5,0,4,11,-12,20,-5,9,-18,-31,6,-15,12,6,-21,6,-11,-9,33,9,5,18,6,-15,23,9,-28,-1,23,12,-6,-10,10,-15,19,22,-16,-2,-21,2,5,29,-32,11,0,9,-2,-2,4,-14,-1,7,-9,6,-24,15,16,-1,-24,0,-2,-5,-3,-2,34,8,3,8,2,-6,-2,-1,12,-33,8,16,11,-6,-2,-8,2,-13,13,2,2,8,-5,-3,-15,-34,-8,1,-6,-17,-5,-29,-13,-9,48,8,-12,-4,4,-7,3,-10,-13,18,-14,-9,-5,-13,-11,-2,-6,-2,-1,-13,-18,-7,-14,2,-30,9,-18,6,7,7,-6,-4,-2,-1,-1,0,8,-2,-17,-10,-7,-2,2,11,1,4,12,10,2,-6,7,-12,-5,-2,3,-20,4,8,-1,10,6,0,-12,-10,10,-17,12,4,13,-25,-13,-11,-1,17,-17,-10,13,-11,-3,0,-22,-6,-14,-13,-17,0,-6,2,14,20,4,-19,-8,-16,-2,-8,-28,-20,5,-10,-7,12,27,9,-8,-4,0,0,15,7,1,-13,-20,-21,1,-7,-4,-8,18,15,-10,-11,17,10,8,-4,6,10,-6,-3,-2,-19,2,-17,6,5,8,2,7,13,4,-14,-1,10,1,-6,0,-10,26,-18,1,6,-18,-8,-10,4,-18,-5,9,0,-8,-5,4,1,-3,17,-10,15,-15,-8,-1,-1,9,1,-16,-4,-18,10,-4,-32,-3,-4,-1,5,9,14,-5,-3,-10,1,-3,-10,-14,3,-1,2,-5,-11,-7,-5,-7,-4,-1,-3,-10,15,7,8,7,7,1,-12,19,-7,-5,10,13,9,13,-21,-6,-6,-15,-1,1,20,-21,-9,-18,1,9,-5,1,4,0,15,-5,-12,7,4,5,0,3,9,-15,-10,2,3,6,8,14,-15,3,-6,-17,-11,-15,24,-5,-11,-15,-14,-1,1,1,-1,-2,-23,-18,-4,-5,-5,-23,17,1,10,-20,-23,-7,-7,-18,-23,-1,0,-3,10,-3,10,-6,28,2,-8,7,-6,6,0,33,0,1,-12,-4,-5,-8,8,-6,18,-3,9,-10,14,-23,6,-2,11,6,7,-2,6,8,-2,-17,-11,-11,12,27,-13,-9,8,12,6,-4,-12,4,2,-14,-4,-5,0,-18,3,17,-15,-1,10,24,18,9,-1,17,6,-1,-6,-13,8,-26,14,27,-11,-2,-1,-3,-21,-2,-1,7,6,-20,-5,-20,-14,-14,-7,11,-9,-4,-30,20,-5,-7,-18,14,1,-3,21,-19,3,16,7,8,-25,-15,-22,4,-8,10,-17,-15,7,0,-8,8,-3,-12,-7,0,-5,-7,-11,17,3,14,-7,-13,-4,23,-12,-2,-13,-11,16,-8,-12,-2,12,10,12,-7,-18,-1,-13,20,-23,-5,-35,-9,12,-3,-23,-1,-6,0,7,1,13,-11,3,11,1,13,-12,-24,9,-12,2,11,-27,3,-7,0,3,-10,9,12,4,-13,7,-2,-12,15,1,5,-18,3,13,-7,-2,-17,-7,-9,19,-2,-1,-13,11,-18,-16,12,-12,5,11,-9,2,-4,-12,14,15,-9,-4,-10,13,-8,-14,12,-7,28,1,-14,-11,-7,0,9,3,-22,-9,1,12,-8,-26,-6,-22,8,19,-10,-4,12,9,-1,-13,1,6,-1,-5,-2,-8,13,-16,1,3,2,16,-2,2,-9,17,4,-7,-8,5,11,-8,-3,-12,-13,-4,29,4,1,-32,0,-19,3,-7,-15,2,-1,-12,-1,-8,2,-19,-6,22,15,-10,1,13,-13,-12,-2,16,3,-16,-4,-4,13,-14,-3,-2,9,4,-5,-6,-13,-6,-5,-8,-6,-22,0,1,-5,-14,-9,-3,16,3,5,-10,2,-4,0,-6,-1,-17,2,9,11,-15,-15,-8,-5,-16,-2,0,-1,23,15,-23,7,8,-1,-28,20,-11,-2,-25,15,-17,-6,6,19,-6,-13,-8,5,-19,-1,-28,0,-11,-6,2,15,-2,-15,10,28,10,0,5,4,-6,1,4,7,11,34,-27,-12,2,-11,-15,-2,3,2,-15,-9,-27,11,19,-2,1,6,-3,-26,-12,1,5,-18,-4,-7,1,-15,-14,9,6,-10,4,-7,-13,-12,-26,-6,14,2,6,-3,-10,-21,-19,-6,9,-6,-1,-26,-17,-17,12,-14,9,0,-5,-7,-15,8,7,-9,8,-7,30,-9,5,-15,-2,6,15,-3,12,2,7,4,6,10,11,7,29,-1,-6,-17,0,-11,3,-13,7,-9,1,-25,-10,21,23,2,-4,12,2,-11,-4,-1,-1,-15,-12,1,3,-11,-11,13,-1,-6,17,2,-4,-7,-8,-22,0,-12,-7,-9,-23,1,-14,6,32,12,11,-31,2,-24,13,-17,-25,-18,-4,-7,-21,3,1,-22,31,-12,-5,-21,22,-11,-10,18,4,7,3,7,6,9,-10,-2,-19,-22,-11,-10,13,2,-5,8,1,6,6,-8,3,-10,-3,-9,-9,-8,-11,-11,-2,1,4,-7,-8,-3,11,-1,15,-6,-4,11,0,0,6,0,3,1,-1,-12,-15,-7,-10,-4,7,3,-9,11,9,-9,9,4,7,-6,12,-1,-5,-16,-7,-1,-12,2,24,-4,11,11,1,-6,-2,-3,0,15,17,-19,21,-2,11,11,-9,16,-10,-10,2,-4,4,0,3,4,-6,-2,-6,5,4,9,-13,8,2,-7,9,-18,9,-7,-1,-2,1,-2,9,1,15,9,-4,11,6,6,-3,-10,5,6,-10,-21,-24,-6,-3,1,15,0,-6,2,-2,6,-5,-14,6,-9,-7,-17,-14,-2,-5,3,-21,3,-2,-10,-1,-15,-14,-5,0,-4,-13,-8,-5,-13,6,-7,-9,8,-15,14,-20,1,4,-20,-9,-18,21,17,1,6,-2,-8,-2,9,-22,8,-8,-14,-22,4,-15,-17,41,6,-24,4,-16,-6,-14,-3,-17,-21,-11,-9,27,17,0,-21,27,-12,-39,-4,-19,-6,-27,10,2,-7,-11,5,6,2,-1,-11,-9,6,-8,3,-5,-11,-11,14,0,-14,7,-14,-11,8,-8,3,-12,1,-6,4,8,-13,-13,11,-14,9,-1,-14,4,-10,-2,-19,-5,8,10,-8,15,-11,2,6,-17,13,-7,7,-14,-12,-11,-15,6,8,-2,-3,-9,9,8,7,-13,10,-5,25,4,1,-8,34,0,-9,-6,4,-23,-2,-27,-22,-4,-3,-22,-6,17,1,-6,-23,-13,4,-13,3,-17,2,-17,-5,11,-8,0,-9,-4,-5,-14,-2,-20,8,-21,8,6,1,-9,3,-18,-12,1,4,-9,-11,2,-23,-20,24,6,2,8,-4,1,-11,5,-7,-18,-8,-1,-4,10,-7,-25,-6,15,5,16,5,21,3,-10,1,-21,33,-3,5,10,25,-6,-10,9,22,-4,-5,-1,-13,10,20,6,-16,10,17,-2,2,-2,12,-15,-15,4,0,-9,-1,3,19,20,-8,-5,15,-6,17,-16,8,-2,-14,11,4,-6,3,-5,-1,13,-4,14,9,-10,3,-8,-5,-4,-7,2,13,-15,6,-3,-10,5,2,0,9,0,-13,4,5,-4,-20,8,10,9,-12,-15,-6,-12,-15,-13,-10,6,-1,4,-1,-1,-13,1,-1,-4,-14,5,2,4,23,2,-8,16,4,9,-9,-11,-9,2,8,-7,-6,-2,12,15,26,-2,-7,-1,-1,-10,10,-9,17,5,6,-10,-6,-6,15,20,30,20,-20,-3,8,-4,-11,-11,-5,-8,11,-4,-8,3,-5,1,11,-9,-5,-8,-7,12,-3,-5,-3,9,-11,-18,-3,-10,0,-13,15,-7,-16,-18,-20,-6,-2,13,-4,-3,-14,-20,15,-19,1,-20,-1,-13,-5,6,-11,-19,-23,15,18,-11,0,33,-3,-7,6,7,8,-5,7,-19,0,-12,-18,-2,-5,-8,0,9,2,-8,-7,5,-19,-15,-6,7,-3,19,-1,-14,-18,1,-7,-3,9,-2,-15,-10,-27,6,-5,19,22,23,8,-12,-9,-8,-4,-16,-10,-6,21,-6,-14,4,-8,4,28,1,2,-13,-11,-21,-16,-16,-22,-21,-6,-18,-19,-4,-1,-12,-5,-14,-11,18,7,-27,-16,0,-9,-2,-5,20,-10,-13,-7,2,-2,-17,8,-7,-12,-17,-6,-3,-5,-5,-10,7,-12,-14,-21,22,-29,28,28,0,0,-5,-6,-15,1,19,-4,-5,-21,7,-13,6,0,8,12,10,-4,-14,-8,-14,-16,-10,23,0,-11,1,-31,-9,-8,-1,-3,-4,-25,-12,7,-12,-15,-16,-12,19,-10,-15,-24,20,-2,-8,-21,-15,-4,6,-22,-18,-2,-10,9,16,16,-20,5,40,6,3,17,19,-12,5,-1,-7,-30,-35,5,-10,-7,-2,-1,1,-1,-28,14,19,-14,3,28,2,-14,-23,0,14,-9,-14,18,-8,-8,-18,-16,0,-5,12,8,-8,8,-8,0,33,3,-5,-14,-8,-32,-14,0,-13,-14,3,1,4,-2,-7,16,11,3,-2,-6,5,7,27,-8,-16,-17,-4,-3,12,-5,12,4,-20,5,8,6,0,-18,6,24,15,7,-2,-11,-13,1,2,13,-27,3,40,1,-14,-10,-19,-3,19,30,1,4,17,1,-12,3,2,-1,14,-6,4,-11,-9,0,-17,10,-8,19,10,3,2,-5,-7,4,1,11,0,-9,18,15,-6,15,-6,14,8,13,2,13,11,5,2,4,-5,-2,4,7,-2,-5,10,6,12,4,-8,-16,-10,-6,-3,15,-6,0,-16,-5,3,5,16,2,-10,21,-4,-2,14,-4,10,8,-8,0,-5,-19,9,11,-4,-4,3,16,-8,-6,18,-1,6,-5,0,11,-5,-4,-9,-5,2,10,-8,5,-18,-14,13,-5,24,0,2,5,-9,-1,-23,-7,-3,-12,-10,-10,4,8,12,12,7,-14,11,-20,-10,1,8,-11,1,19,4,-17,1,2,-11,-3,-11,-19,-12,-34,2,-1,-15,-9,-12,8,-2,0,-14,6,2,-6,-22,-24,15,-6,1,-2,-26,-2,-12,-8,20,-9,12,-4,-16,1,-13,-8,4,-5,4,17,-14,1,-7,-20,14,16,7,5,-17,8,14,2,-12,0,-2,-13,-14,0,-3,-4,1,18,12,-5,4,8,4,-4,22,0,-3,3,1,-8,3,-7,0,-5,8,-2,-12,-2,-14,-14,-6,-7,18,-1,-9,-1,-25,-13,-13,14,5,-6,-19,11,-4,-10,25,12,14,-7,2,18,-11,8,0,4,6,1,-11,8,0,1,0,18,-8,18,-11,-3,-2,-4,-9,12,-3,15,2,-2,5,1,-19,4,-15,-11,-14,5,-2,-6,-7,9,9,2,0,-5,1,-8,0,10,5,-5,19,-8,-7,10,-11,-8,6,15,5,-8,-19,8,-5,12,0,2,-4,-6,-6,6,-1,-8,-5,1,-8,-1,-4,4,36,-18,0,6,7,-9,-4,20,2,1,-13,14,4,0,1,-8,24,-4,5,5,-10,-23,4,17,-11,-1,0,1,-6,0,9,-6,-11,-15,-8,-9,2,13,-4,-8,-10,19,9,-13,10,1,-18,-12,5,10,-10,4,3,-6,-20,-8,-5,-2,-5,-5,12,8,5,-1,-5,5,-16,-1,-9,5,-13,-15,-8,-5,-16,-8,-19,-7,-12,-11,-5,20,3,2,14,-9,-2,-13,-10,-22,-9,-3,1,-8,3,14,-20,5,-9,-1,-27,-13,-10,-1,-21,12,-6,-9,1,-5,1,2,2,4,-15,1,-12,-9,-14,-2,-16,20,-21,-1,-6,21,-2,-11,20,7,-7,10,-9,7,4,17,10,1,5,9,4,3,15,-18,-13,-5,6,-1,-3,-1,-8,3,-13,-1,1,8,-13,3,-9,-13,-12,4,-22,5,28,17,22,0,-28,-22,-25,19,5,4,4,8,-20,9,-25,-12,-5,10,-1,-18,-38,-11,-13,17,-3,0,-5,28,-4,23,-9,13,8,11,-4,1,-32,-14,-21,8,-12,6,-8,40,-13,-8,-15,-17,-2,-3,-8,-3,-15,4,-10,14,-13,7,-17,-19,-19,-14,-16,-5,21,26,8,-11,1,-1,-9,-6,-20,-7,-22,-16,10,11,13,-15,-8,29,1,-22,2,-2,-21,-3,-18,0,1,-4,4,1,7,-2,-9,-28,5,-12,-28,-10,11,0,5,-16,1,-1,-7,-10,1,10,2,15,2,4,0,-12,-4,15,-17,4,-21,7,-10,11,12,-19,0,-8,-21,18,-15,6,-15,2,2,-2,6,8,-2,-5,19,-12,-8,-2,-9,-4,-8,-11,-10,-4,7,3,20,11,11,10,21,-6,-6,-10,-4,-5,-9,-3,-23,-10,2,4,-6,-7,5,1,-5,5,-9,-14,-2,-5,-21,3,5,-27,40,-10,17,5,-12,-23,-7,4,-24,-9,3,15,5,9,12,19,24,-6,16,6,13,5,0,-4,-6,-34,-19,6,-3,-7,-19,-11,15,10,13,1,17,-15,10,1,0,-6,-9,1,-10,-1,10,-19,-5,34,20,-20,51,-4,9,8,-4,-19,-32,-9,-10,-13,10,-6,-16,15,-12,-17,24,21,-13,9,-7,-20,-22,8,-2,-29,-9,6,9,-10,-1,-14,2,6,-27,-9,-20,-3,31,2,33,6,-7,-17,-1,3,3,11,8,16,-15,1,-16,8,-10,-3,1,1,3,-3,1,-6,1,5,-6,8,-16,-4,2,17,-7,16,-11,-2,-11,-6,-13,0,-14,-12,-16,-12,9,-7,-14,-10,-5,13,-11,10,10,-11,-11,7,-12,-11,-18,-21,-1,-7,3,-4,-35,1,-10,9,14,12,-2,-15,-9,-9,-2,-20,-7,-8,11,14,-17,9,10,4,-17,5,-13,10,-12,-2,-13,-8,0,-1,-28,8,-6,-13,-8,-1,3,3,9,13,-5,-6,-9,11,-2,12,-9,0,25,3,-12,14,-5,8,-14,-6,-7,-17,-11,-24,0,9,-5,-10,5,-5,-27,32,1,-2,-7,2,9,-12,-1,-11,6,1,40,-8,-8,-7,-16,-6,-13,-5,-1,-25,5,1,14,-21,3,-17,52,-17,-5,13,-19,-10,-17,-10,-5,-19,-8,-3,15,-3,-18,-9,-6,-24,17,8,-2,-6,-38,-9,-8,-5,11,-18,14,-7,-33,-25,20,8,5,23,5,0,-3,8,-10,18,4,4,-1,4,5,-12,7,2,2,15,4,3,-8,12,-5,-7,-11,-4,11,-8,-7,14,4,-4,-6,-7,11,-19,-21,13,-1,3,16,10,-3,-13,-7,4,-9,-5,13,9,-16,12,-7,-7,-13,-22,-9,-9,4,-27,-16,-11,-4,-2,-31,-29,-6,-8,-15,-10,-10,-2,5,-7,0,-20,-24,-13,1,5,2,-23,-9,-1,9,8,-3,14,0,-3,2,-7,23,-11,1,-2,17,-5,-2,16,10,-9,-12,13,-11,-17,-12,-16,5,9,4,-14,-17,-4,5,-7,-2,12,-3,13,3,0,-9,-2,-5,22,-3,-21,-7,5,6,-1,-16,5,-19,-5,-7,-2,20,-12,2,1,-7,6,1,-22,7,17,4,-18,0,5,10,-16,2,-15,1,-14,1,30,2,0,5,12,-2,-6,-6,15,9,-7,1,-3,15,-8,1,4,10,10,-6,2,0,-10,-8,7,1,-32,-13,-13,4,-16,-8,-4,1,-12,-12,-15,-13,4,-6,1,-1,-21,-9,-14,-15,-2,11,-20,5,-3,-3,-13,-1,-7,-8,-13,-6,8,4,1,7,3,-15,16,16,6,0,16,-9,-17,5,7,5,8,-5,-3,-6,-13,-11,13,7,-2,12,3,1,11,-1,9,-13,9,2,8,20,0,3,-2,3,13,-2,10,-15,3,-12,2,4,-25,-14,-1,14,-7,-5,9,-6,-9,-10,1,23,21,-9,-4,-13,-11,-3,-2,-4,-12,4,-5,-4,-2,-1,-13,11,-18,-19,4,-23,-7,-4,21,8,-13,-4,9,13,1,-4,-3,0,-16,6,-4,-19,7,7,0,0,-12,-10,-6,-7,-7,-2,-13,3,-1,3,-2,-15,5,10,0,10,8,9,-6,5,5,1,13,-11,8,-1,14,-3,-6,-1,-3,-4,0,-1,0,-4,-4,-3,6,11,-9,18,14,-24,-16,13,2,-12,-1,14,-12,8,9,-2,-4,12,-7,7,32,-3,-24,-18,-5,-9,-29,6,4,0,-14,-5,-22,24,21,32,6,-13,-4,-11,3,-18,8,1,-2,2,-5,23,-4,-7,27,-15,-17,-23,2,-22,-5,-13,30,12,-5,4,0,6,11,-7,-14,-13,2,-11,-19,-2,-9,5,19,-5,-7,-8,-2,-13,-11,-6,-8,4,-5,10,-2,15,-12,10,-9,-11,-4,-9,-3,4,-23,-9,4,3,-11,-21,-7,16,4,-4,11,-8,-13,8,-2,4,-14,28,-17,-14,3,-13,-10,0,32,10,1,2,-13,-6,-11,11,17,13,-12,-8,-9,23,25,23,-9,20,-10,17,4,-2,0,-22,-5,12,-9,5,-8,4,10,15,-12,13,-15,-5,5,21,-5,-10,-2,18,6,2,0,14,-3,10,-15,-9,-1,-11,-6,0,13,8,1,-15,23,-11,-2,-17,-16,18,27,5,0,-16,13,2,-5,-14,-18,-25,11,-23,6,13,-19,-16,7,-25,-15,19,-5,13,-8,15,21,-1,-23,-7,7,5,-7,-11,1,-11,-22,6,-3,-1,10,-7,-8,-12,-5,2,8,-7,-9,0,2,10,-11,-7,26,7,17,-1,-26,1,2,7,4,15,7,0,-6,9,9,-14,-3,-11,-11,-19,-8,24,16,-4,0,-6,11,-8,-17,-13,-14,-4,-3,-23,-9,-33,0,-12,1,-3,0,7,-3,2,-25,-12,6,17,2,-6,-5,1,23,-20,0,-10,-11,5,-24,-8,3,-29,4,-20,1,-2,-1,2,8,-12,3,-1,5,-14,-11,-14,8,-12,16,-5,-15,14,-10,20,2,-12,7,-12,-14,-12,-14,7,-8,6,6,-1,-4,8,-6,-7,-10,-3,10,-15,10,-4,26,-24,-4,-10,-22,-18,9,-10,3,-24,2,-13,5,-1,-4,-5,8,11,-3,-2,-8,14,-5,0,-6,-5,9,-23,1,-15,4,-16,-12,-7,2,10,-16,7,-9,-5,-13,-10,6,0,9,2,9,-4,4,-20,16,4,-11,19,-12,2,-1,-2,25,2,9,11,10,22,-20,-16,2,-3,-9,-6,-5,4,16,-7,4,8} + +#define CONV3_BIAS {18,36,-46,-45,64,8,13,-19,28,1,14,-57,23,20,-2,32,48,-11,85,73,-7,52,125,33,125,13,92,-72,89,-1,11,70} + +#define IP1_WT {38,-13,5,-20,15,-4,-3,13,36,-19,10,14,-18,-17,-11,15,25,-18,-16,-9,-9,-8,-4,21,-11,10,4,6,7,9,-14,-9,17,-6,1,8,18,5,14,12,0,2,9,-8,-3,15,-7,2,-18,-6,-26,20,-6,9,10,-2,12,11,-10,-7,18,-12,-12,41,18,6,11,-3,-1,2,11,24,1,22,9,6,4,33,-18,-12,-26,-22,7,3,-2,-8,-3,-8,19,-16,28,-18,1,2,16,-26,-30,-18,-12,-30,9,9,-7,13,7,12,-11,16,-2,-1,14,-10,15,11,4,-15,-5,-12,7,22,-15,-12,-7,1,22,1,-12,29,3,1,-3,-12,-5,-7,-1,22,20,-6,-20,25,3,5,1,2,-17,-2,-2,4,4,0,15,-19,6,-7,-20,11,-18,-26,14,1,0,-9,4,-8,11,-16,-1,15,-16,-7,17,-13,-10,1,2,8,14,-2,-16,32,-10,-10,12,-16,9,-11,-10,-15,3,9,-30,58,4,-20,6,-10,-6,11,0,-1,13,14,-14,0,-3,-12,-4,22,2,2,14,1,10,1,-12,-8,17,-12,-1,-10,-9,-9,-2,11,-28,-25,-6,-5,4,10,-3,11,6,16,13,-3,-6,5,35,-12,-1,5,26,-3,-29,2,-4,-6,-15,-6,-11,8,-8,-12,1,-13,-2,7,12,-16,7,-5,11,20,-6,-2,42,21,36,-4,-12,1,-4,25,6,0,-12,5,28,-5,1,5,-15,1,-2,1,-5,-4,-10,41,-14,9,-11,-23,0,33,0,-9,13,-9,-3,6,1,4,1,3,-9,4,2,-16,-2,21,-32,-9,6,-12,-2,3,-7,29,-8,-27,10,-3,-3,10,-20,-3,12,0,-4,-4,-11,7,-6,8,2,-11,6,7,-6,-13,-2,-4,17,-11,5,0,11,1,4,-6,-17,-9,-25,7,4,4,21,17,14,-5,4,-12,-17,5,46,-7,17,-10,22,0,-9,-13,-13,12,-4,1,-4,-17,-2,-7,-14,-14,-14,7,9,-11,-2,3,6,15,4,6,3,8,20,10,16,-4,-20,-10,25,7,-4,5,3,1,-2,-2,8,2,9,-2,-6,2,-5,-11,4,1,24,-10,-11,11,-17,-4,-5,-14,11,2,2,0,10,13,-31,9,-14,13,19,21,-29,-10,4,9,-33,3,9,0,-13,-16,-1,-3,-4,20,3,-2,12,-6,-38,-16,-17,-8,10,12,18,-10,-8,16,25,8,-4,-1,4,-12,-6,-8,-2,11,-10,2,-16,-11,40,-17,11,5,4,-21,-1,25,33,-5,12,-7,1,6,2,-4,5,-17,17,12,-18,3,6,-8,-9,33,-5,10,-22,-3,16,-3,-22,29,45,-5,-5,-19,11,13,-10,-12,-15,8,1,16,14,-3,-4,7,-9,-5,-6,1,2,5,-15,-32,-11,-9,8,-8,9,3,-18,-4,23,12,4,-14,36,3,-4,41,14,-3,-2,2,-3,12,4,-4,8,-15,-2,7,8,8,3,2,4,11,-1,10,-26,12,-7,11,-16,-1,28,-25,19,8,-5,-8,-3,-8,-4,16,-8,-14,-9,3,16,8,8,8,4,-12,3,-6,-12,3,22,-7,-21,-11,-14,-4,-1,7,-10,-3,6,13,-14,61,-10,-14,-15,-3,13,5,-30,-20,-15,-25,5,10,-9,12,8,-1,-7,5,-17,-1,-13,0,11,-6,60,5,0,-20,6,21,-22,6,-12,-9,1,-3,1,-19,-21,-7,-4,7,-15,-6,-9,11,-5,-5,12,-12,6,8,15,2,-6,-23,-23,0,-4,6,-8,-9,-21,31,-5,3,-5,1,5,-1,-7,-6,30,-14,-3,11,11,5,-4,0,15,-7,-8,-3,-4,2,-15,-4,-20,-7,13,-10,-15,-19,-25,-16,76,-15,17,26,2,7,-16,-17,-14,-1,-9,21,-4,-5,2,42,-6,2,-8,-6,6,6,-5,3,-10,-2,6,14,-12,0,4,22,26,-5,-12,-1,-4,28,19,2,11,-22,27,-20,-6,15,-9,1,-10,-9,4,-6,-5,4,0,2,5,-11,-9,-11,-6,16,22,-4,-3,2,1,-7,11,6,6,8,-13,-9,-16,7,1,7,-16,-15,-2,-3,11,3,-12,6,-17,-15,18,-5,11,8,-10,-8,22,5,-6,-4,-17,-10,-2,12,-16,2,-7,-5,12,4,-18,1,9,-14,-5,1,-4,13,-6,-2,11,-8,4,1,-8,-8,0,1,6,-4,23,4,-3,-7,1,20,-11,-8,1,-14,3,12,10,-6,-5,44,11,5,-2,-3,24,3,6,2,1,0,-13,7,2,13,-9,7,9,2,-14,2,27,-14,1,-10,3,1,23,-10,6,4,-5,12,11,-7,-3,-7,1,-11,-9,12,-21,7,-10,-9,-14,17,-2,-2,-4,2,24,-8,-12,-4,4,14,5,21,12,-7,0,-3,3,-12,0,2,5,-5,11,-4,6,-2,33,-10,-2,15,-6,-10,12,-10,5,6,7,-2,11,3,1,16,2,-11,-6,11,-10,-5,-3,6,-7,-27,5,1,-1,-2,-2,3,-18,0,4,-10,4,1,-3,-10,5,-7,13,-16,-15,22,2,8,-2,16,23,-11,19,-3,-12,-11,9,-11,-24,8,-17,-5,-3,-22,6,2,8,12,-17,10,4,-1,-6,0,-17,5,5,-1,-22,1,1,3,31,-7,6,-3,5,6,8,-4,-1,-11,11,-12,-10,31,-8,-2,-10,-9,28,2,-10,-8,-19,6,7,4,-16,17,-5,9,-17,-11,-3,13,15,-14,-5,10,-19,0,-2,7,-6,1,2,13,3,4,-14,-1,-14,-7,-11,46,18,2,6,-10,-18,55,14,-4,-1,3,7,-12,23,19,8,0,-12,9,-4,-11,-10,-21,7,9,4,-16,-2,-6,18,-14,-15,-9,-11,-10,-8,3,4,-21,3,-9,9,13,0,19,8,-12,-8,-30,1,6,6,9,-23,-1,3,-25,39,-27,11,-19,8,-12,7,17,0,10,-7,-5,-2,19,-3,-12,-20,9,4,18,4,4,10,-6,10,-20,1,6,-3,6,4,5,-7,-3,-6,-8,5,16,14,12,-20,2,-6,9,-14,-2,-26,2,12,12,-15,-16,14,6,3,-8,-5,-1,-4,0,-12,1,6,6,1,8,-4,-9,-13,-5,-16,42,-11,7,-8,-21,-2,-5,-13,-15,-11,-7,5,-11,15,32,-3,-10,6,-10,11,-8,10,19,-17,-28,-1,-14,-8,-12,-5,2,-12,3,31,5,-19,33,3,10,-9,-1,4,-15,1,12,0,-8,-20,2,2,-13,1,-5,11,0,-17,1,-8,5,4,3,15,27,4,-2,5,-36,2,-2,-16,0,12,-5,-3,6,31,-12,-14,0,-8,-1,-14,8,29,-8,-2,5,-3,1,-12,-4,10,12,-4,-8,19,-1,-15,-1,9,14,2,-16,-2,15,3,10,-11,-5,-2,2,9,2,-12,4,11,0,3,2,-10,-11,15,1,0,-23,3,-3,-23,0,-6,-12,-1,11,-12,-13,2,-4,-5,-3,17,0,0,0,9,-3,4,5,-9,-11,4,-5,7,-9,-1,-9,11,-7,-16,-3,-9,-7,-11,8,-2,-6,3,11,3,-4,-7,-14,1,12,-12,-1,-9,15,19,8,5,2,26,7,-19,-7,-17,-4,-7,-1,33,-15,1,-8,1,-4,-6,-5,-3,-14,10,-1,-2,12,6,8,-7,26,-6,-12,6,0,31,-9,19,-11,-2,14,-6,16,-1,1,5,6,-4,-13,4,11,-6,2,7,-6,-15,2,-3,7,-3,-13,2,-5,-6,6,4,-4,11,-2,32,-3,12,0,20,-1,-8,-1,-10,5,18,-37,-13,-5,16,-3,11,6,10,-3,-2,9,1,-17,1,-13,4,4,5,-6,2,1,11,-18,-7,-11,11,-2,-9,-3,7,0,-16,6,3,3,9,-9,1,26,-9,3,-6,-12,3,1,17,1,-5,4,2,3,-22,6,-18,-18,-17,-15,27,6,9,5,9,12,-9,-2,-13,-3,-12,10,0,-3,-8,-3,8,7,16,1,-9,38,14,-9,-8,0,-8,6,-11,-19,-3,-9,-18,13,5,-5,13,-4,-2,-8,-15,5,42,-14,-4,0,0,-3,12,-2,-5,5,18,-39,13,-6,12,7,13,6,8,0,7,2,-49,23,-15,-11,23,3,1,11,-1,-3,7,-1,-26,24,7,-2,-11,3,15,2,14,3,-5,21,-19,-17,4,-4,-16,-18,9,-11,25,1,5,-7,7,-2,-15,0,-5,6,10,-2,5,7,-12,-8,-4,10,16,0,-32,7,-7,-26,-24,20,-5,4,-6,2,-5,-4,-3,6,13,-17,10,14,-3,-11,-9,15,4,1,-11,-8,-10,0,20,18,19,-5,22,-11,23,-2,-8,5,9,11,2,-11,31,-14,0,-14,1,11,-6,28,30,-7,-7,9,14,-6,8,1,-5,22,17,-19,-18,-13,5,18,3,11,-1,3,3,-7,4,-11,-3,-9,-30,20,-18,14,8,11,-1,23,-13,5,-11,0,-8,-4,-5,-9,10,2,2,0,17,14,-21,25,-18,-2,-8,0,1,0,-1,-29,17,-4,-18,18,-10,7,9,3,-3,0,-5,23,18,8,9,9,17,-14,4,10,-10,3,-13,-4,-3,6,-9,21,-25,2,6,-2,-26,23,-9,1,20,8,9,-12,-2,3,-6,-2,-10,-6,5,-3,23,-7,14,-7,-14,3,-7,-4,-16,-6,13,-3,-5,-5,30,-6,7,7,6,5,-23,12,8,-18,-14,-6,23,-14,-5,4,-1,19,18,1,-6,6,-14,-2,9,21,5,5,-1,2,2,-8,4,-5,2,-8,-14,-1,-3,15,13,6,-10,0,3,1,5,-12,12,-6,10,-7,16,3,22,10,-6,25,-19,-2,-11,-15,8,-14,6,-9,10,-3,8,5,-2,-13,-10,-4,-5,0,-1,-5,-1,-16,-3,3,6,4,22,9,17,-2,-6,-16,25,1,4,4,23,-10,0,-2,-26,10,2,25,22,-1,0,1,-16,-5,-7,-10,-22,-14,10,-7,15,31,15,-17,-7,36,12,-22,-3,-7,10,8,-2,2,7,-4,8,2,-11,6,17,-15,2,-22,-33,-19,19,-23,-8,1,9,-10,10,2,4,5,-6,17,6,0,11,-8,-10,-18,-6,-2,21,3,-11,-1,4,6,2,17,15,-13,-1,7,27,-11,-1,-2,2,-9,2,5,3,2,-3,-3,3,18,12,-1,11,-7,24,-7,-5,-9,16,3,6,-5,8,7,1,-12,-2,15,9,-18,1,-1,-12,0,-5,5,9,-17,31,-4,-8,-10,-12,9,-2,9,4,-18,12,-11,-6,5,0,3,16,2,1,10,-16,-4,9,-6,-3,-2,9,-10,-16,12,5,9,-6,31,11,-2,-16,-12,10,3,1,-9,-8,10,4,-7,-6,-15,6,-10,4,17,-24,17,2,-33,9,-23,-1,-1,32,-5,16,-8,3,12,21,-1,-24,-1,-24,27,-3,-8,18,-1,-10,-7,45,-39,-18,2,-4,-6,5,5,-19,34,15,36,11,8,-7,-14,-11,0,0,-11,2,6,-18,-25,-17,1,-3,-15,-31,37,-9,-14,10,-24,1,-16,1,13,-21,-11,-5,15,5,6,27,4,27,24,-5,-19,37,-19,-18,-10,-17,-17,-16,-1,18,14,11,12,6,35,-17,35,-14,-12,-5,7,1,-8,-9,10,-8,-14,1,23,1,-24,-7,-4,-20,49,18,15,8,-12,-30,10,0,-7,-8,10,-3,-2,6,-25,-22,-10,-10,0,1,9,-18,-7,6,-11,11,-6,7,-12,1,-16,-15,-10,22,-5,86,-12,16,-41,-11,-1,-1,12,26,11,-7,12,-20,42,6,8,16,6,-27,4,2,-24,-20,7,43,-15,-5,-2,-8,3,-15,12,-16,-4,5,-5,1,2,9,3,-17,19,4,-11,-1,8,0,-13,6,-10,15,12,-28,-14,55,-4,13,16,-42,-5,46,-10,-8,-3,-14,-13,-15,0,26,-7,-8,25,34,-12,-34,22,-10,-9,-17,-5,11,-11,-14,-6,-6,-9,0,14,7,-14,-19,7,-8,37,-13,-7,-7,17,-16,19,23,-14,-13,-7,-18,9,18,-20,-25,1,-22,-26,14,-28,16,-17,-6,4,6,-26,-6,-5,-6,-17,-5,-5,19,13,22,-16,-14,4,-8,-15,3,2,8,7,-3,-6,-2,17,9,5,1,-12,-14,0,-14,-9,11,15,39,-5,-25,2,-18,-5,4,-1,23,18,-9,-7,2,22,-10,10,-13,37,14,-11,-9,-6,-5,14,-6,-9,-8,0,-8,6,28,-7,7,25,-13,-6,25,-3,7,-11,-14,-8,-7,-14,15,10,6,11,33,-2,-23,-16,10,14,-3,8,-10,0,-14,17,7,2,24,-6,-9,23,-1,-19,-7,14,-14,-4,-2,6,2,5,6,-1,-11,9,5,-7,9,-7,-6,14,-14,-6,3,9,0,-1,-4,2,14,-22,-11,18,8,-36,2,-1,9,-14,-4,2,-8,4,-1,5,-8,29,-16,10,-1,1,-8,35,1,10,4,-17,-13,15,-4,0,0,22,-31,4,18,-7,0,-2,-11,-15,29,10,3,7,3,5,-16,26,-6,33,-8,8,2,-7,9,12,11,10,11,10,2,-4,-17,9,-16,-29,-7,-1,-19,29,-11,0,3,-3,1,26,23,-3,7,-4,19,-5,-29,20,21,7,-4,3,-23,-5,-11,3,1,-27,-5,20,-12,22,-5,7,14,-6,-15,-16,5,-19,-7,11,-2,-16,-7,-12,-12,-21,-9,3,-9,1,-14,11,-11,-9,6,-27,-13,-7,-6,4,49,-7,4,9,-13,-12,56,4,11,14,-15,12,19,-4,-25,11,-17,-22,15,4,-6,-8,2,-5,0,-11,1,-23,-6,3,21,-12,-1,-7,-22,-23,-1,19,1,-7,-10,-20,5,-8,5,-21,-1,-2,13,-6,-11,5,-9,-9,-13,18,-3,2,5,-12,-6,30,-13,-4,-18,20,0,8,-8,8,4,0,-7,6,5,6,29,9,42,-2,-12,7,14,-10,-13,1,-1,-17,8,-19,4,-17,-13,-20,8,25,-1,-17,19,10,5,10,-6,3,-12,14,30,-6,-11,-8,-4,-17,-12,-9,-12,41,-16,-21,-2,-15,22,2,9,2,-5,5,2,22,-8,-13,-19,56,-16,6,33,-4,35,-3,10,-15,13,-11,-5,11,0,1,-5,3,-6,21,-12,-6,-16,7,15,-6,-5,-15,1,-8,1,-3,-17,-29,-2,1,-12,9,-8,-8,-8,30,10,18,17,-34,10,5,2,17,-14,-6,-3,0,-22,6,20,-32,-5,-21,-16,8,-8,1,-2,16,-3,-6,-20,-13,5,3,10,13,-9,-13,11,0,4,5,-10,-9,5,-19,10,-4,-11,-3,-12,-4,-11,-7,-21,-30,-10,6,14,8,-2,-1,16,1,19,-15,-14,4,-1,-4,4,-7,12,-13,-12,29,-1,3,0,2,4,-11,-3,-3,-22,4,-6,3,6,9,-25,16,-4,-14,36,3,5,2,-15,-4,1,-11,13,-4,-3,-4,0,-4,-3,44,14,-2,-7,-7,13,-1,-6,-9,2,0,28,-13,-8,-6,1,-5,-6,-9,6,6,10,-3,6,-2,12,-15,5,0,0,17,-2,-18,4,6,2,3,-7,-2,-10,-19,-4,-7,-3,-4,3,9,-17,10,-4,-10,-12,-2,-10,7,-22,-7,-7,1,7,-2,6,-8,-8,7,18,9,-5,3,-6,-4,-10,4,-14,-11,-7,9,13,1,-5,-15,27,7,-4,-13,0,-9,11,8,11,0,-1,0,-4,9,5,9,-15,5,-10,27,-8,6,11,15,-11,13,-25,-15,-16,-9,9,-4,14,-7,-6,-2,-2,3,2,-21,-8,-1,-22,-5,-27,-6,4,9,7,13,0,-7,-2,-8,-12,5,6,-5,-8,-7,-2,-5,8,7,-16,1,16,1,4,0,-6,11,7,-14,-6,15,-4,17,-5,-1,5,24,5,5,-14,11,-8,-6,-18,-3,-14,-13,3,-4,-10,8,-7,19,-2,4,6,36,22,8,18,-20,-8,10,-7,1,-12,8,-5,4,-8,7,-2,-3,-7,-6,-16,0,-9,11,10,3,-1,-9,-6,0,-3,-8,-11,2,-13,19,-1,-22,4,0,-6,0,-10,-12,12,7,-12,-5,-17,3,-12,-4,12,-5,27,19,-11,10,-6,13,7,1,-1,27,-8,12,7,6,-2,-6,6,-7,-16,24,-10,-2,-12,-11,13,-10,-5,-19,-27,-14,-11,1,-1,-15,-2,18,-19,-10,3,3,-3,19,9,-11,-8,-5,24,-3,2,20,-18,-24,-5,11,4,14,14,2,-9,8,0,-9,-12,-2,12,-2,17,-19,-17,4,16,17,-10,5,-5,14,15,5,20,-10,3,-8,24,-16,-4,-1,4,-20,-10,-20,-5,-2,5,2,5,6,-22,-18,3,-8,-7,5,5,-3,12,0,18,-8,12,-2,13,-4,2,3,-4,11,-15,-13,-14,11,0,-4,-10,-10,-22,17,25,20,-4,-10,-5,34,-2,29,3,4,-12,-8,-11,9,-10,13,-16,-5,3,-2,6,8,-4,-5,-10,1,-2,-6,15,3,14,-7,-5,6,-5,-2,13,7,-9,-13,-10,14,-7,-4,6,-2,8,-15,29,15,-14,15,-8,48,-2,-13,-3,-8,-6,-20,12,-3,6,-9,-16,-4,-8,-8,31,-6,11,-3,0,-10,-10,-6,17,6,-12,1,18,-10,1,9,2,3,2,-27,17,-5,-8,-6,-7,-2,6,-15,-12,-12,13,-12,-10,1,-6,10,13,7,0,-13,8,-18,0,25,7,-7,4,-8,-5,1,9,-3,-2,-12,-3,-4,-22,-7,4,6,18,1,1,-11,-7,7,5,-3,15,-6,5,10,-22,11,-9,-16,10,-6,6,2,21,-2,-1,2,12,-10,-2,-4,5,3,20,3,10,-9,-7,-4,-10,12,-14,-6,2,1,-8,7,5,0,-9,-4,46,-14,4,12,-13,3,2,0,8,4,31,-13,6,-7,1,-14,-2,8,4,-12,9,-13,-7,5,4,1,10,-7,-14,-6,-7,10,15,1,-4,-4,11,-2,-3,-13,15,-4,-11,-8,4,2,7,10,-1,-7,37,-15,-3,-7,-16,2,13,11,-3,-23,3,-19,-5,-2,-21,9,-8,1,0,8,10,-4,0,-4,-17,11,6,9,-22,12,-11,11,-1,14,10,22,2,1,6,-11,-7,-4,-4,5,-5,-13,9,-9,-5,-7,-9,-17,1,9,-2,3,0,7,-1,16,-5,14,-4,3,-6,-12,8,16,1,7,-14,1,0,-4,9,-14,1,1,7,13,-3,11,7,9,5,-12,5,-8,0,-2,18,-15,-9,-5,-13,12,-7,-5,2,13,-11,3,2,19,21,-16,-8,12,13,7,4,2,-18,-4,-5,-6,-16,-12,-16,0,4,9,4,-10,9,0,-7,10,-8,6,-5,6,-20,-14,-6,-5,3,-23,-10,-4,18,3,-10,6,-7,15,-8,7,0,-22,3,-21,-2,5,-11,33,2,-6,6,-13,-7,14,1,10,0,13,-20,-16,-15,21,-16,16,5,40,5,1,15,-10,8,17,2,-21,-24,3,-9,5,3,-4,-6,-7,-13,-4,0,2,-23,28,-4,0,6,0,3,11,1,-13,-6,-8,16,-3,36,2,8,6,-12,20,6,8,9,-7,-5,6,3,-1,16,-14,-10,-1,40,-16,-5,12,26,-1,5,-3,23,21,-14,-5,0,2,-3,15,6,-13,5,-14,-4,-1,-16,-13,-16,20,-1,23,0,-38,-2,-10,17,16,-9,-24,-9,7,17,9,-8,-10,11,0,-26,6,-5,-5,-8,-17,1,1,10,0,-11,-16,-18,-10,5,11,14,7,-22,5,-1,-1,-9,1,-5,18,-17,17,-15,-6,-7,31,-4,-4,-1,4,6,-2,-4,-11,1,-15,-3,-5,11,1,1,-16,-6,-1,7,4,-5,18,0,-9,2,17,-14,-15,-8,-25,-7,-9,13,14,5,12,-4,31,-6,2,-1,0,7,3,-18,18,-5,-7,14,-13,-11,-6,-10,-6,2,-16,-14,26,9,-3,28,-9,9,7,-2,-2,-15,-1,3,9,-6,-24,-2,2,-7,-1,3,3,21,-3,3,-7,-10,18,-1,-7,14,1,22,-10,-18,-5,26,7,-6,-6,-8,-6,-2,7,2,-18,10,9,9,3,-2,5,-11,16,27,-5,-5,-16,-12,-14,-3,7,2,-16,-17,-1,-10,7,0,-8,22,-9,7,-5,-1,5,4,13,-6,8,7,-10,-2,-5,-8,4,-1,-2,7,-16,0,-2,-12,3,-10,-3,-2,1,-8,-1,-13,5,5,9,16,-4,14,6,12,4,7,29,14,3,-4,-6,-3,22,-23,-5,15,-28,5,2,8,-12,5,-18,8,5,-3,-18,-8,4,-17,18,5,-6,-8,-12,0,-5,-2,-10,1,6,-17,6,10,-8,-6,17,2,-5,5,11,1,-5,-4,-26,-3,14,-10,-4,3,-11,-11,-16,-3,-1,-5,2,9,2,24,17,8,4,-4,38,16,14,6,-6,-11,-2,14,-10,11,-11,12,4,-8,-8,-26,-13,13,-8,-14,21,1,-8,10,11,22,-17,7,-4,-7,-10,0,-11,18,9,5,0,10,-17,0,-2,2,15,1,-2,-7,-2,2,17,-6,-14,-13,7,11,3,1,14,0,10,8,-11,20,-19,0,-4,16,8,-13,3,4,-1,4,0,29,-12,-24,26,4,11,-14,-12,-10,15,15,-5,1,6,-3,-8,3,-13,-15,7,-6,1,-3,-11,2,-18,14,-1,-17,-2,12,12,-6,12,-23,-13,9,-18,4,0,5,-3,-14,20,7,-6,-6,-11,10,-7,-6,6,-24,4,-18,26,-23,-2,18,-14,-13,-3,-10,28,-4,30,-22,9,-13,-17,11,-19,-9,-12,14,2,-6,25,27,0,1,-7,-17,-6,-16,4,1,13,-12,-6,-6,-11,2,-12,-22,17,-5,-15,-7,-4,5,15,35,0,-3,10,-14,13,-16,4,7,-5,12,-1,11,-2,-23,-9,-3,10,-8,-3,-5,9,12,-3,-12,-4,6,3,-26,-7,5,-24,-11,-3,-9,23,-9,-32,-16,3,30,0,16,7,5,-1,0,-15,-7,40,-20,-6,-9,-2,-13,-7,-2,-2,-4,0,-22,-4,12,-14,5,-1,-3,-6,-8,2,41,32,-10,-6,3,-10,-15,-16,10,-12,-7,-12,-5,-13,51,4,-9,5,-16,15,2,1,-10,40,-14,9,36,1,-16,-7,-3,6,5,25,23,-15,-6,-14,-11,-4,-2,-9,3,-2,17,-5,-4,0,10,17,18,-1,1,-17,3,8,-6,6,15,-1,2,-14,5,-10,7,-5,11,-1,0,-10,3,13,1,-10,16,7,-8,-6,-6,-13,-3,9,20,4,2,-13,-9,-22,-8,-2,-16,12,5,-16,7,-15,9,6,1,5,2,8,9,-7,15,-2,7,35,-11,0,-2,1,1,-9,17,-7,7,-7,-20,-8,11,-2,6,9,0,10,-4,-11,29,7,0,-2,-10,-15,-3,-1,-4,4,-15,-27,1,12,22,-10,-3,20,-17,19,7,-3,5,37,-4,9,18,-3,-7,-12,-3,15,2,0,16,-11,-12,7,8,10,-2,-15,20,-14,2,13,-1,6,4,13,17,15,6,8,-6,9,-7,6,16,4,-2,-3,-7,14,-14,2,-3,-10,-7,-14,4,8,-3,10,0,12,-4,4,5,-5,-10,17,42,-9,2,5,2,5,3,-3,-14,12,2,6,4,-41,-6,2,-3,9,3,0,-7,-8,7,1,-3,11,-3,0,-11,4,2,-3,23,-11,-3,-8,10,-21,26,12,-9,16,-8,16,2,-8,13,-13,-8,-16,-18,18,-19,8,-3,2,-6,-21,8,1,-13,-17,-14,-7,6,18,-21,-36,16,8,20,-13,-8,-16,8,-9,2,-3,2,-5,-5,-7,-3,-12,-4,0,3,-7,-5,-9,12,17,-16,-6,-18,-19,7,25,-12,-17,9,1,-14,-3,-14,6,4,-17,-5,-1,-13,-7,-4,15,-6,5,1,-5,1,-4,-2,1,3,9,-28,-9,-28,-10,28,-3,-12,-6,24,6,-5,-7,-6,1,5,1,38,-34,-3,-14,-15,14,-4,37,2,-8,-21,-21,-6,-13,1,6,-46,-12,-8,-5,5,10,3,-15,28,-10,4,-4,-12,2,1,5,-13,10,19,-12,2,7,-8,-3,0,-13,-33,-5,10,0,13,-2,-2,1,-21,-6,6,-19,-3,14,-21,9,7,6,23,-1,-23,-13,8,-2,16,1,0,-4,11,7,5,-6,-11,-10,0,1,20,6,12,-2,-1,-5,20,-14,5,44,4,1,-7,-7,10,1,-12,22,6,1,10,-6,-9,4,3,3,0,5,-1,0,0,13,-10,-1,-14,13,0,8,11,-14,-15,19,-11,-4,-3,-15,2,4,-9,37,11,-28,-4,-6,-4,-2,-17,-3,-2,-5,-28,19,15,-8,-30,-1,-13,4,6,-3,8,-9,18,6,-2,-24,-14,-13,-16,3,12,34,8,9,0,-3,-9,18,-13,0,-8,-11,19,-1,15,-6,37,7,-12,-1,11,-2,-12,3,-3,-29,2,-10,0,-7,36,-18,-10,-4,-9,0,3,-1,12,-8,-6,-14,13,18,24,12,-1,-4,40,3,-10,10,4,-3,21,14,13,-2,11,12,-5,-11,-6,11,-2,18,7,4,-3,-3,-2,10,6,6,6,-11,9,-14,-14,6,17,11,0,0,1,-1,8,-3,1,-3,5,0,14,-3,4,12,3,-4,-1,-19,-9,-6,3,-1,-1,-7,8,7,10,-14,10,-19,-7,3,10,-8,-2,-1,2,-7,-8,-7,2,26,2,17,-3,5,0,6,4,32,-3,-4,-3,-13,-11,-7,-10,12,4,11,33,0,-12,-10,11,5,16,-7,9,-4,-4,-16,-8,-8,14,2,9,-6,-5,-11,-6,14,-13,-6,-5,-8,-7,-3,-11,28,9,8,6,5,10,-11,-8,3,-23,-16,1,12,-14,0,-2,18,3,-10,5,25,9,-20,0,15,-3,1,4,1,-10,-7,-7,16,23,-7,21,0,-14,2,3,6,-14,-3,-15,-5,-15,-4,-8,14,5,4,-19,4,-6,-18,-8,15,-2,8,-4,3,-6,-5,-11,14,16,-10,-12,-3,-10,6,-1,-6,-9,12,-4,-9,-8,-1,-4,30,-4,24,-11,16,-2,7,6,27,5,-10,-2,0,17,-8,-14,-7,-10,3,27,29,-19,-11,-5,2,-10,-1,-14,2,-2,0,-9,1,-2,23,-23,15,-8,-12,21,4,14,-6,-1,-11,-1,10,-5,11,16,-3,9,35,-7,2,1,6,-4,-11,-7,-14,-3,-8,18,9,12,7,-12,34,-1,-27,9,11,7,-9,-8,9,6,-9,-4,7,-4,-10,10,10,-11,6,-7,4,-11,-6,0,-4,-1,10,-2,15,-13,13,-31,24,1,-13,-19,8,-2,-5,7,-4,10,-4,-10,-10,-10,-8,-1,-10,-8,-3,1,-9,-3,1,1,-11,-2,6,-10,34,-5,12,-15,34,-1,-20} + +#define IP1_BIAS {30,-121,-51,77,40,20,46,-35,28,-33} + +#define CONV1_BIAS_LSHIFT 6 +#define CONV1_OUT_RSHIFT 9 +#define CONV2_BIAS_LSHIFT 4 +#define CONV2_OUT_RSHIFT 9 +#define CONV3_BIAS_LSHIFT 1 +#define CONV3_OUT_RSHIFT 7 +#define IP1_BIAS_LSHIFT 1 +#define IP1_OUT_RSHIFT 8 +#define INPUT_MEAN_SHIFT {125,123,114} +#define INPUT_RIGHT_SHIFT {8,8,8} diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/readme.txt b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/readme.txt new file mode 100644 index 0000000..75b6e01 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/cifar10/readme.txt @@ -0,0 +1,4 @@ +CMSIS NN Lib example arm_nnexample_cifar10 for + Cortex-M4 and Cortex-M7. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/Compiler/EventRecorderConf.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/Compiler/EventRecorderConf.h new file mode 100644 index 0000000..5958233 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/Compiler/EventRecorderConf.h @@ -0,0 +1,44 @@ +/*------------------------------------------------------------------------------ + * MDK - Component ::Event Recorder + * Copyright (c) 2016 ARM Germany GmbH. All rights reserved. + *------------------------------------------------------------------------------ + * Name: EventRecorderConf.h + * Purpose: Event Recorder Configuration + * Rev.: V1.0.0 + *----------------------------------------------------------------------------*/ + +//-------- <<< Use Configuration Wizard in Context Menu >>> -------------------- + +// Event Recorder + +// Number of Records +// <8=>8 <16=>16 <32=>32 <64=>64 <128=>128 <256=>256 <512=>512 <1024=>1024 +// <2048=>2048 <4096=>4096 <8192=>8192 <16384=>16384 <32768=>32768 +// <65536=>65536 <131072=>131072 <262144=>262144 <524288=>524288 +// <1048576=>1048576 +// Configure size of Event Record Buffer (each record is 16 bytes) +// Must be 2^n (min=8, max=1048576) +#define EVENT_RECORD_COUNT 64U + +// Time Stamp Source +// <0=> DWT Cycle Counter <1=> SysTick +// <3=> User Timer (Normal Reset) <4=> User Timer (Power-On Reset) +// Selects source for 32-bit time stamp +#define EVENT_TIMESTAMP_SOURCE 1 + +// SysTick Configuration +// Configure values when Time Stamp Source is set to SysTick + +// SysTick Input Clock Frequency [Hz] <1-1000000000> +// Defines SysTick input clock (typical identical with processor clock) +#define SYSTICK_CLOCK 100000000U + +// SysTick Interrupt Period [us] <1-1000000000> +// Defines time period of the SysTick timer interrupt +#define SYSTICK_PERIOD_US 1000U + +// + +// + +//------------- <<< end of configuration section >>> --------------------------- diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM0/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM0/RTE_Components.h new file mode 100644 index 0000000..73f80ad --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM0/RTE_Components.h @@ -0,0 +1,24 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_gru' + * Target: 'ARMCM0' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM0.h" + +#define RTE_Compiler_EventRecorder + #define RTE_Compiler_EventRecorder_DAP +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_EVR /* Compiler I/O: STDOUT EVR */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM3/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM3/RTE_Components.h new file mode 100644 index 0000000..1f91822 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM3/RTE_Components.h @@ -0,0 +1,22 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_gru' + * Target: 'ARMCM3' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM3.h" + +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM4_FP/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM4_FP/RTE_Components.h new file mode 100644 index 0000000..3df85a0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM4_FP/RTE_Components.h @@ -0,0 +1,22 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_gru' + * Target: 'ARMCM4_FP' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM4_FP.h" + +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM7_SP/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM7_SP/RTE_Components.h new file mode 100644 index 0000000..04bee02 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/RTE/_ARMCM7_SP/RTE_Components.h @@ -0,0 +1,22 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_gru' + * Target: 'ARMCM7_SP' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM7_SP.h" + +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru.cpp b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru.cpp new file mode 100644 index 0000000..efb3257 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru.cpp @@ -0,0 +1,221 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2018 Arm Limited. All rights reserved. +* +* +* Project: CMSIS NN Library +* Title: arm_nnexamples_gru.cpp +* +* Description: Gated Recurrent Unit Example +* +* Target Processor: Cortex-M4/Cortex-M7 +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of Arm LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +/** + * @ingroup groupExamples + */ + +/** + * @defgroup GRUExample Gated Recurrent Unit Example + * + * \par Description: + * \par + * Demonstrates a gated recurrent unit (GRU) example with the use of fully-connected, + * Tanh/Sigmoid activation functions. + * + * \par Model definition: + * \par + * GRU is a type of recurrent neural network (RNN). It contains two sigmoid gates and one hidden + * state. + * \par + * The computation can be summarized as: + *

    z[t] = sigmoid( W_z ⋅ {h[t-1],x[t]} )
    + * r[t] = sigmoid( W_r ⋅ {h[t-1],x[t]} ) 
    + * n[t] = tanh( W_n ⋅ [r[t] × {h[t-1], x[t]} ) 
    + * h[t] = (1 - z[t]) × h[t-1] + z[t] × n[t] 
    + * \image html GRU.gif "Gate Recurrent Unit Diagram" + * + * \par Variables Description: + * \par + * \li \c update_gate_weights, \c reset_gate_weights, \c hidden_state_weights are weights corresponding to update gate (W_z), reset gate (W_r), and hidden state (W_n). + * \li \c update_gate_bias, \c reset_gate_bias, \c hidden_state_bias are layer bias arrays + * \li \c test_input1, \c test_input2, \c test_history are the inputs and initial history + * + * \par + * The buffer is allocated as: + * \par + * | reset | input | history | update | hidden_state | + * \par + * In this way, the concatination is automatically done since (reset, input) and (input, history) + * are physically concatinated in memory. + * \par + * The ordering of the weight matrix should be adjusted accordingly. + * + * + * + * \par CMSIS DSP Software Library Functions Used: + * \par + * - arm_fully_connected_mat_q7_vec_q15_opt() + * - arm_nn_activations_direct_q15() + * - arm_mult_q15() + * - arm_offset_q15() + * - arm_sub_q15() + * - arm_copy_q15() + * + * Refer + * \link arm_nnexamples_gru.cpp \endlink + * + */ + +#include +#include +#include +#include "arm_nnexamples_gru_test_data.h" +#include "arm_math.h" +#include "arm_nnfunctions.h" + +#ifdef _RTE_ +#include "RTE_Components.h" +#ifdef RTE_Compiler_EventRecorder +#include "EventRecorder.h" +#endif +#endif + +#define DIM_HISTORY 32 +#define DIM_INPUT 32 +#define DIM_VEC 64 + +#define USE_X4 + +#ifndef USE_X4 +static q7_t update_gate_weights[DIM_VEC * DIM_HISTORY] = UPDATE_GATE_WEIGHT_X2; +static q7_t reset_gate_weights[DIM_VEC * DIM_HISTORY] = RESET_GATE_WEIGHT_X2; +static q7_t hidden_state_weights[DIM_VEC * DIM_HISTORY] = HIDDEN_STATE_WEIGHT_X2; +#else +static q7_t update_gate_weights[DIM_VEC * DIM_HISTORY] = UPDATE_GATE_WEIGHT_X4; +static q7_t reset_gate_weights[DIM_VEC * DIM_HISTORY] = RESET_GATE_WEIGHT_X4; +static q7_t hidden_state_weights[DIM_VEC * DIM_HISTORY] = HIDDEN_STATE_WEIGHT_X4; +#endif + +static q7_t update_gate_bias[DIM_HISTORY] = UPDATE_GATE_BIAS; +static q7_t reset_gate_bias[DIM_HISTORY] = RESET_GATE_BIAS; +static q7_t hidden_state_bias[DIM_HISTORY] = HIDDEN_STATE_BIAS; + +static q15_t test_input1[DIM_INPUT] = INPUT_DATA1; +static q15_t test_input2[DIM_INPUT] = INPUT_DATA2; +static q15_t test_history[DIM_HISTORY] = HISTORY_DATA; + +q15_t scratch_buffer[DIM_HISTORY * 4 + DIM_INPUT]; + +void gru_example(q15_t * scratch_input, uint16_t input_size, uint16_t history_size, + q7_t * weights_update, q7_t * weights_reset, q7_t * weights_hidden_state, + q7_t * bias_update, q7_t * bias_reset, q7_t * bias_hidden_state) +{ + q15_t *reset = scratch_input; + q15_t *input = scratch_input + history_size; + q15_t *history = scratch_input + history_size + input_size; + q15_t *update = scratch_input + 2 * history_size + input_size; + q15_t *hidden_state = scratch_input + 3 * history_size + input_size; + + // reset gate calculation + // the range of the output can be adjusted with bias_shift and output_shift +#ifndef USE_X4 + arm_fully_connected_mat_q7_vec_q15(input, weights_reset, input_size + history_size, history_size, 0, 15, bias_reset, + reset, NULL); +#else + arm_fully_connected_mat_q7_vec_q15_opt(input, weights_reset, input_size + history_size, history_size, 0, 15, + bias_reset, reset, NULL); +#endif + // sigmoid function, the size of the integer bit-width should be consistent with out_shift + arm_nn_activations_direct_q15(reset, history_size, 0, ARM_SIGMOID); + arm_mult_q15(history, reset, reset, history_size); + + // update gate calculation + // the range of the output can be adjusted with bias_shift and output_shift +#ifndef USE_X4 + arm_fully_connected_mat_q7_vec_q15(input, weights_update, input_size + history_size, history_size, 0, 15, + bias_update, update, NULL); +#else + arm_fully_connected_mat_q7_vec_q15_opt(input, weights_update, input_size + history_size, history_size, 0, 15, + bias_update, update, NULL); +#endif + + // sigmoid function, the size of the integer bit-width should be consistent with out_shift + arm_nn_activations_direct_q15(update, history_size, 0, ARM_SIGMOID); + + // hidden state calculation +#ifndef USE_X4 + arm_fully_connected_mat_q7_vec_q15(reset, weights_hidden_state, input_size + history_size, history_size, 0, 15, + bias_hidden_state, hidden_state, NULL); +#else + arm_fully_connected_mat_q7_vec_q15_opt(reset, weights_hidden_state, input_size + history_size, history_size, 0, 15, + bias_hidden_state, hidden_state, NULL); +#endif + + // tanh function, the size of the integer bit-width should be consistent with out_shift + arm_nn_activations_direct_q15(hidden_state, history_size, 0, ARM_TANH); + arm_mult_q15(update, hidden_state, hidden_state, history_size); + + // we calculate z - 1 here + // so final addition becomes substraction + arm_offset_q15(update, 0x8000, update, history_size); + // multiply history + arm_mult_q15(history, update, update, history_size); + // calculate history_out + arm_sub_q15(hidden_state, update, history, history_size); + + return; +} + +int main() +{ + #ifdef RTE_Compiler_EventRecorder + EventRecorderInitialize (EventRecordAll, 1); // initialize and start Event Recorder + #endif + + printf("Start GRU execution\n"); + int input_size = DIM_INPUT; + int history_size = DIM_HISTORY; + + // copy over the input data + arm_copy_q15(test_input1, scratch_buffer + history_size, input_size); + arm_copy_q15(test_history, scratch_buffer + history_size + input_size, history_size); + + gru_example(scratch_buffer, input_size, history_size, + update_gate_weights, reset_gate_weights, hidden_state_weights, + update_gate_bias, reset_gate_bias, hidden_state_bias); + printf("Complete first iteration on GRU\n"); + + arm_copy_q15(test_input2, scratch_buffer + history_size, input_size); + gru_example(scratch_buffer, input_size, history_size, + update_gate_weights, reset_gate_weights, hidden_state_weights, + update_gate_bias, reset_gate_bias, hidden_state_bias); + printf("Complete second iteration on GRU\n"); + + return 0; +} diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru_test_data.h b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru_test_data.h new file mode 100644 index 0000000..e0ccbe1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/arm_nnexamples_gru_test_data.h @@ -0,0 +1,23 @@ +#define UPDATE_GATE_WEIGHT_X2 {-62,83,-58,-89,-80,1,-93,31,101,95,121,-83,71,18,-98,-5,44,-100,-16,-73,25,62,34,-22,-16,42,9,-125,60,-78,15,-76,-76,-63,71,-25,78,-66,38,-118,-71,-120,-80,28,33,51,82,-105,26,-47,38,86,-114,44,90,-98,105,-123,24,95,-12,11,49,-35,78,104,104,17,-116,-40,-83,4,88,-110,-111,-98,18,-89,120,-84,66,-69,-8,-22,-91,-29,-41,110,55,-124,-67,103,-40,-100,1,-25,-68,-62,-89,-75,-20,-78,101,-92,-51,-97,-54,59,-78,41,34,-102,-9,-53,56,103,-55,13,81,-75,-20,-37,29,36,110,84,-80,-127,-68,-33,-70,-16,-42,-9,-104,107,-81,-16,42,-74,-63,-4,-128,-109,-105,55,-51,-68,-88,19,-39,116,-7,66,52,-29,63,-94,71,-2,-127,31,-103,120,124,41,-13,-23,127,59,-22,54,-2,32,-87,-109,85,-31,-5,-59,-122,-97,-14,-88,-19,43,-30,115,42,14,10,121,28,-63,83,-85,101,40,23,-39,74,-99,73,50,-20,123,-88,-13,-126,-25,70,-11,16,-28,121,-29,20,-69,104,117,-40,-1,-97,-12,31,32,15,-32,77,31,16,40,107,-52,-52,-89,-17,124,-95,54,48,-40,37,24,-46,42,119,5,-118,-45,-10,106,83,57,-74,-10,-56,85,37,-25,83,-31,-54,111,-78,-96,-114,-65,-100,28,-31,-111,33,66,74,-43,112,119,-80,-26,74,-81,-123,55,-126,32,-66,110,-86,-118,-21,15,16,26,13,-109,41,-16,88,81,-82,-55,-89,109,-52,118,-39,57,-16,86,-68,-10,-19,110,-50,-17,-84,103,-3,94,-8,50,15,-44,-87,6,18,8,61,66,-108,-67,-6,107,-68,25,25,25,-82,71,62,121,-31,-4,17,-6,-60,-17,116,-67,45,117,-90,12,-68,20,121,-65,-43,74,-104,-42,-69,35,4,-17,5,95,-82,18,65,43,-57,89,1,-8,37,-51,10,67,4,-50,-18,81,-120,44,98,16,-98,25,127,88,-111,-49,114,111,-17,-74,40,-18,35,19,31,48,-23,53,102,41,89,-27,87,-54,-121,-113,97,125,125,-108,58,-17,8,70,-67,-55,59,42,-85,78,27,16,66,67,54,-74,33,-19,72,77,126,-122,-7,-109,58,78,-88,15,2,16,37,-34,-114,-88,-53,88,115,19,7,-67,93,80,-48,-11,-61,31,38,29,-59,-70,0,25,106,-7,-44,53,62,19,-64,109,70,-103,-114,97,57,112,24,-66,-127,29,29,-31,-87,-125,54,-98,101,-39,56,-88,-63,-113,-73,-91,80,112,-27,-75,-42,-5,79,60,-55,23,-61,66,51,39,-91,96,-60,-64,-1,75,55,-108,73,38,75,-113,-9,-92,-92,-3,-30,93,-27,-100,-55,125,52,72,110,12,84,-83,65,-79,92,11,87,-106,35,-38,-24,-79,15,-11,-109,-22,95,82,-1,-2,-113,116,-64,93,-62,-11,101,35,-91,51,-6,21,29,25,-16,68,-103,-111,-23,-123,-80,24,-17,-7,53,23,114,-13,-105,-88,120,13,-25,-40,29,-38,-43,3,2,-121,-110,54,-43,30,66,28,60,-81,-6,-8,126,-80,64,-42,126,75,-69,-116,-41,81,94,31,-116,5,-46,5,-21,-105,78,-20,-34,54,46,-124,120,-83,44,-17,-52,-23,-110,34,-35,31,61,88,-108,-38,31,117,-26,38,-57,65,9,0,59,124,14,-39,-95,-91,107,-34,85,-83,-31,-68,-78,-86,21,-118,56,60,-3,-116,33,53,-94,85,77,91,-94,100,-89,97,88,111,36,74,-110,7,-74,91,-112,21,32,-59,98,36,10,-41,44,-114,-88,92,111,72,43,58,42,-125,-11,96,126,25,96,-105,-128,-70,85,-82,-17,103,23,-37,76,58,108,16,-116,-44,22,89,0,6,-108,27,-34,88,-125,22,-45,-116,28,-29,-70,-3,-81,-80,42,119,105,-40,-109,105,64,5,72,-32,-95,90,60,6,-29,40,-19,57,89,-50,34,-123,-32,-18,20,9,-19,-81,-45,-120,-120,20,2,18,70,75,100,64,126,-9,63,-82,114,-62,106,-11,104,-9,-13,88,-40,101,73,108,52,33,116,-54,-114,-47,85,2,-117,-80,100,-20,98,-75,-83,-24,-125,-91,-97,95,-46,15,-94,-21,53,-27,-18,65,87,112,38,-115,-27,37,-84,1,103,85,-50,36,-49,-119,68,20,119,-113,43,-67,105,44,4,-48,16,-42,83,-39,106,31,-34,-76,-51,68,82,-111,-116,-104,-118,109,-29,-6,-91,81,-102,-76,-82,64,121,27,-98,-24,-88,36,115,59,-84,-121,4,29,45,73,110,-56,-12,109,-88,85,-30,87,18,118,23,21,106,40,115,78,-72,-103,11,83,44,117,-63,98,30,115,123,-39,25,15,84,52,46,77,64,-104,125,-13,34,125,65,6,57,-128,-2,115,7,-65,-73,82,72,-109,99,43,-94,-106,-39,-4,-127,58,123,-128,29,-80,4,51,109,-50,-38,25,-13,-52,-106,87,76,44,78,101,16,-102,-20,104,23,107,-88,18,-85,119,-21,-53,-84,-7,-8,-114,23,-54,74,80,77,-40,19,-75,-41,60,77,82,-96,-121,-43,114,-124,-1,-75,32,34,-117,21,64,-87,-100,-29,-36,-45,-46,-111,4,-44,-94,-117,100,-25,-27,105,95,15,88,25,-38,-88,122,62,-62,-28,95,-86,125,-83,-9,-100,101,-124,22,21,-91,50,-100,-27,-92,115,86,85,33,-112,-43,61,114,62,-31,-84,-7,5,-26,-10,-21,-89,60,-96,48,-34,88,-80,-91,92,12,118,-2,-38,83,-50,-109,-111,-26,-109,-78,-7,84,60,-95,15,-71,112,126,71,36,39,-42,-85,-126,-68,105,-18,-127,48,-41,57,-93,13,-25,-71,66,-43,-23,122,4,-70,123,115,124,-61,-32,18,-18,49,123,-101,37,-50,-111,-73,124,-18,54,-64,93,-69,16,112,21,-56,56,127,113,-48,-57,-4,85,-84,53,44,28,-126,-59,-11,94,58,-64,112,82,127,58,50,5,-6,-102,90,-18,-86,104,17,108,-64,-22,73,-102,-17,-31,-11,-105,-40,-49,84,-82,104,57,30,112,-119,-92,78,-92,35,90,-45,-13,-75,-125,-19,-83,-75,29,15,-33,127,-14,29,-80,61,41,67,-14,-18,101,101,108,-24,-61,-90,-59,-48,-114,1,-14,106,52,109,-45,-100,74,-33,-68,-94,-68,-22,-99,31,-86,85,-27,-70,69,127,92,125,-95,117,-87,-8,-71,18,94,-90,103,-31,-1,-50,-60,-2,96,31,-1,-98,75,104,-6,-38,-24,127,94,-48,97,-96,4,-108,106,76,-31,-7,-41,58,-13,-72,-81,-116,-24,-45,46,-20,114,97,-14,125,11,22,26,27,-2,-88,-28,-76,119,50,52,66,65,120,-42,-43,-59,-56,-28,-42,-87,-18,-47,-85,74,119,97,-6,-127,-86,30,18,-43,48,-73,22,-5,34,122,9,115,-32,-63,-13,61,119,18,-113,-12,80,26,-39,-76,-101,-104,-6,48,38,-82,-52,-91,-38,112,110,115,76,69,100,-116,109,3,-35,16,94,24,110,86,25,-5,84,2,62,57,-121,-28,-108,29,127,-25,89,16,-86,15,-68,97,-115,-73,-110,-13,41,16,-47,-74,75,-71,-52,-20,-29,3,-34,68,-2,-29,63,-5,95,-79,26,-42,-91,-109,-19,107,-102,62,111,-35,80,36,55,-65,26,76,-86,26,-88,-116,110,84,-62,-13,120,-31,-47,-32,84,-98,58,74,18,-22,5,-83,-3,11,53,114,32,-118,16,-91,-74,-67,-68,78,-34,102,88,-80,-5,63,-35,22,-87,-97,-30,-76,94,116,44,-109,-122,38,112,-103,99,-119,49,35,107,108,47,54,11,-50,-73,37,-56,71,-125,108,-47,15,-115,-65,-90,-13,-27,-16,-94,72,-101,-74,-58,27,121,-91,110,-101,45,-54,105,-8,-88,-66,-71,-128,-35,-53,-50,-51,-85,113,96,16,-72,-80,-54,78,47,75,-82,-115,-53,40,-39,54,-43,23,-35,43,81,125,-8,51,49,-91,122,123,-102,-65,-78,19,14,51,-68,60,43,-36,105,44,-100,36,89,-40,123,31,105,26,-128,63,-49,-115,48,96,-91,-73,99,37,2,3,-52,-103,-11,10,31,-106,-119,-67,118,-71,-67,-52,-12,43,-21,99,-64,-88,64,100,-62,-11,-32,23,-90,68,-102,116,-21,-78,1,108,-2,116,-122,114,53,-33,102,65,33,73,92,-79,-51,-50,-65,49,76,119,-51,15,-21,95,-109,80,17,7,115,115,-117,-77,-39,-115,-19,-83,-35,-122,56,94,1,-13,83,8,-84,72,-88,87,77,-82,-125,-18,75,10,-106,51,-59,120,-85,22,-45,-68,-44,-38,64,38,-75,-69,122,88,53,18,41,-108,48,38,-127,34,-85,36,-116,-96,56,105,38,76,92,-41,99,-101,-100,112,74,57,60,85,-14,95,0,-73,-46,12,-93,-14,-78,-1,-2,-10,34,111,115,-91,16,-79,76,-108,-8,-84,33,111,-98,2,-6,8,0,-77,1,52,18,-5,-77,-46,-80,-20,-61,-30,-81,-73,-7,49,-107,-25,-97,-125,69,-89,31,-124,-108,76,96,58,88,24,49,79,11,-43,-60,100,108,62,21,-72,-111,81,46,-108,-107,29,90,-13,55,-23,-63,-10,-128,-124,86,88,3,-39,-39,98,-57,-24,-97,-124,85,-84,-78,4,11,59,-73,120,66,21,-73,20,-95,91,-53,76,98,-29,49,-76,-74,-67,-80,-29,-106,111,60,32,-127,-87,104,30,95,-21,93,-23,-97,26,-46,63,12,-28,123,12,30,102,-115,36,74,-54,-54,-103,-57,-95,-72,-60,24,-14,-41,27,9,19,-74,-12,-65,-7,17,122,-85,123,16,-127,22,75,-85,-28,-50,125,-102,-28,24,120,-53,-128,-108,-65,-37,60,-53,-10,28,-38,-11,71,-45,21,-77,-108,-115,-24,103,-29,121,-23,11,-102,-115,-108,-78,-55,84,-17,-58,-8,-118,-119,-56,1,-109,42,-94,51,54,6,-30,56,12,23,-10,121,-113,-74,9,12,0,-93,67,51,-110,44,-69,-40,-72,49,-16,-31,-16,9,-43,7,90,96,-63,-24,-74,-26,35,-16,109,-101,38,87,-13,11,-18,-54,33,37,106,84,79,80,23,-76,-80,-45,-106,56,3,-103,-92,86,-81,68,90,-126,-125,102,-83,-36,83,97,-39,-44,-14,-14,79,-9,-31,119,114,29,-27,-29,55,-72,-3,54,49,-40,22,-37,54,68,71,66,-66,-23,49,69,-73,83,-14,-70,9,117,-63,111,65,66,92,58,-56,15,20,52,-72,-4,34,-94,119,-95} + +#define UPDATE_GATE_WEIGHT_X4 {-62,78,83,104,-68,28,-33,-63,-58,104,-89,17,-70,83,-16,-85,-80,-116,1,-40,-42,101,-9,40,-93,-83,31,4,-104,23,107,-39,101,88,95,-110,-81,74,-16,-99,121,-111,-83,-98,42,73,-74,50,71,18,18,-89,-63,-20,-4,123,-98,120,-5,-84,-128,-88,-109,-13,44,66,-100,-69,-105,-126,55,-25,-16,-8,-73,-22,-51,70,-68,-11,25,-91,62,-29,-88,16,19,-28,34,-41,-22,110,-39,121,116,-29,-16,55,42,-124,-7,20,66,-69,9,-67,-125,103,52,104,-29,117,60,-40,-78,-100,63,-40,-94,-1,15,1,-76,-25,71,-97,-2,-12,-76,-68,-63,-62,-127,31,31,32,71,-89,-25,-75,-103,15,120,-32,78,-20,-66,-78,124,77,41,31,38,101,-118,-92,-13,16,-23,40,-71,-51,-120,-97,127,107,59,-52,-80,-54,28,59,-22,-52,54,-89,33,-78,51,41,-2,-17,32,124,82,34,-105,-102,-87,-95,-109,54,26,-9,-47,-53,85,48,-31,-40,38,56,86,103,-5,37,-59,24,-114,-55,44,13,-122,-46,-97,42,90,81,-98,-75,-14,119,-88,5,105,-20,-123,-37,-19,-118,43,-45,24,29,95,36,-30,-10,115,106,-12,110,11,84,42,83,14,57,49,-80,-35,-127,10,-74,121,-10,-56,-8,85,50,-120,37,44,-34,37,15,-25,-44,98,-114,16,-88,83,-87,-31,6,-98,-53,25,88,-54,18,111,8,127,115,88,19,-78,61,-96,66,-111,7,-49,-67,-114,-108,-65,-67,114,93,111,80,-100,-6,28,107,-17,-48,-74,-11,-31,-68,-111,25,40,-61,-18,31,33,25,66,25,35,38,19,29,74,-82,-43,71,31,-59,48,-70,112,62,119,121,-23,0,53,25,-80,-31,-26,-4,102,106,41,-7,74,17,-81,-6,89,-44,-27,53,-123,-60,55,-17,87,62,-54,19,-126,116,32,-67,-121,-64,-113,109,-66,45,110,117,97,70,125,-103,-86,-90,-118,12,125,-114,-108,97,-21,-68,15,20,58,57,-17,112,16,121,26,-65,8,24,70,-66,13,-43,-109,74,-67,-127,-55,29,41,-104,-16,-42,59,29,42,-31,88,-69,81,35,-85,-87,78,-125,-82,4,-55,-17,27,54,16,-98,-89,5,109,95,66,101,67,-39,-52,-82,118,18,54,56,-74,-88,-39,65,57,43,33,-63,-19,-113,-16,-57,86,89,72,-73,77,-91,-68,1,-10,-8,126,80,-122,112,-19,37,110,-51,-7,-27,-109,-75,-50,10,-17,67,58,-42,78,-5,-84,4,103,-50,-88,79,15,60,-3,-18,94,81,2,-55,16,23,-61,-16,66,68,-52,44,-23,-114,51,-103,39,-111,-110,-88,34,92,-91,-23,96,-123,-35,111,31,72,-60,-80,-64,24,61,43,88,58,-1,-17,75,-7,-108,42,-38,-125,55,53,-108,23,31,-11,117,96,73,114,38,-13,-26,126,38,25,75,-105,-113,-88,-57,96,65,-105,-9,120,-92,13,9,-128,0,-70,-92,-25,-3,-40,59,85,124,-82,-30,29,93,-38,14,-17,-39,103,-27,-43,-100,3,-95,23,-91,-37,-55,2,125,-121,107,76,-34,58,52,-110,72,54,85,108,-83,16,110,-43,12,30,-31,-116,-68,-44,84,66,-83,28,-78,22,-86,89,65,60,-79,-81,21,0,-118,6,92,-6,11,-8,56,-108,60,27,87,126,-106,-80,-3,-34,-116,88,35,64,-38,-42,33,-125,53,22,-24,126,-79,75,-94,-45,85,-116,15,-69,-11,-116,77,28,91,-29,-109,-41,-22,81,-94,-70,100,-3,95,94,82,31,-89,-81,97,-80,-1,-116,-2,5,88,42,111,119,-113,-46,116,5,36,105,74,-40,-64,-21,93,-105,-110,-109,7,105,-62,78,-11,-20,-74,64,91,5,101,-34,35,54,-112,72,21,-32,-91,46,51,-124,32,-95,-59,90,-6,120,21,-83,98,60,36,6,29,44,25,-17,10,-29,-41,40,-19,-18,57,65,110,4,-56,51,89,87,-50,112,-12,109,109,-50,34,38,-123,-115,-88,-38,85,25,-32,-27,-18,37,-30,-13,87,-52,20,-84,9,1,18,-106,118,87,-19,103,-81,85,23,76,21,44,-45,-50,-120,36,106,78,40,101,-120,-49,20,-119,115,16,78,-102,2,68,18,20,-72,-20,-103,104,70,119,75,-113,11,23,83,107,100,43,64,-67,44,-88,117,18,126,105,-9,44,-63,-85,98,119,63,4,-82,-48,30,-21,115,-53,114,16,-62,-42,123,-84,-39,-7,106,83,-11,-39,25,-8,15,-114,104,106,-9,31,84,23,52,-54,-13,-34,88,-76,46,74,77,80,-40,-51,101,68,64,77,-104,-40,73,82,108,-111,125,19,-13,-75,52,-116,33,-104,34,-41,125,60,116,-118,-54,109,65,77,6,82,-114,-29,-47,-6,57,-96,-128,-121,85,-91,2,81,-2,-43,115,114,-117,-102,-80,-76,7,-124,-65,-1,100,-82,-20,64,-73,-75,82,32,98,121,-75,27,72,34,-109,-117,-83,-98,-24,-24,99,21,43,64,-125,-88,-91,36,-94,-87,-106,-100,-97,115,95,59,-39,-29,-4,-36,-46,-84,15,-121,-127,-45,58,-46,-94,4,-21,29,123,-111,-128,4,53,45,-27,73,29,-44,-80,-94,-117,-109,100,-78,-84,-18,53,101,-25,-7,-27,84,44,101,28,108,105,60,95,-95,-126,-24,-59,-61,15,15,88,-71,-11,-90,94,-59,25,112,-38,126,58,-48,-64,-114,-88,71,122,36,112,1,82,-14,62,39,-62,-42,127,106,58,52,-28,-85,95,-126,50,109,5,-45,-86,-68,125,105,-6,-100,-102,74,-83,-18,-9,-127,90,-33,-18,-68,-100,48,101,-41,-86,-94,104,-68,-124,57,22,-93,17,-22,108,-99,21,13,-91,-25,-64,31,-22,-86,50,-71,-100,66,73,85,-102,-27,-27,-43,-92,-23,-17,-70,-31,69,115,122,86,4,-11,127,-105,92,85,-70,33,123,-40,125,-49,-95,-112,115,-43,124,84,117,-82,-87,61,-61,114,-32,104,-8,57,-71,62,18,-31,-18,30,18,112,94,-84,49,-7,123,-119,-90,-92,103,5,-101,-26,37,78,-31,-92,-1,-10,-50,-21,-111,35,-50,90,-60,-89,-73,60,124,-45,-2,-13,96,-96,-18,48,54,-75,31,-125,-1,-34,-64,88,93,-19,-98,-83,75,-80,-69,-91,16,-75,104,29,-6,92,112,12,21,15,-38,-33,-24,118,-56,-2,56,127,127,-14,94,-38,127,83,113,29,-48,-80,97,-50,-48,-109,-57,61,-96,41,4,-111,-4,-26,85,67,-108,-14,106,76,-113,-31,-12,-2,-30,-29,-76,-7,80,-41,26,63,94,-5,116,58,-39,-13,-76,95,44,-79,-109,-72,-101,-81,-104,26,-122,-42,38,-116,-6,-24,48,-91,112,-109,-103,-45,38,46,-82,-19,99,107,-119,-20,-52,114,-91,-102,49,62,35,97,-38,-14,112,111,107,-35,108,125,110,11,115,80,47,36,54,22,76,26,69,55,11,-65,-50,27,100,-2,-116,26,-73,76,37,-88,109,-28,3,-86,-56,26,71,-76,-35,119,16,-88,-125,-116,108,50,94,52,24,110,-47,84,15,66,110,65,86,-62,-115,-13,-65,120,25,-42,-5,120,-90,-31,-13,-43,84,-59,2,-47,-27,-32,-16,-56,62,-28,57,84,-94,-98,72,-42,-121,-87,-28,58,-101,74,-74,-18,-108,-47,29,18,-58,-22,27,-85,127,74,-25,5,121,-83,-91,119,89,97,16,-3,110,11,-101,-6,-86,-127,15,53,45,114,-54,-86,-68,30,97,32,105,-118,-8,18,-115,-43,-73,16,-88,-91,-66,48,-110,-73,-13,-74,-71,-67,-128,22,41,-5,16,-68,-35,78,-53,34,-47,122,-74,-34,-50,102,-51,9,75,115,-71,88,-85,-80,113,-32,-52,-63,-20,-5,96,63,16,-13,-29,61,3,-35,-72,22,-80,119,-34,18,68,-87,-54,-97,78,47,-12,75,43,-88,115,87,-91,-82,-21,-115,99,77,16,-82,-79,-53,-64,40,-88,-125,76,-18,-108,-39,64,54,100,75,-8,10,-84,-43,-62,23,-11,-106,33,51,111,-35,-32,43,23,-59,-98,120,2,81,-90,125,68,-85,-6,22,8,-8,-102,51,116,-45,0,-68,-77,49,-21,-91,-78,-44,1,-38,52,122,1,123,108,64,18,38,-5,-102,-2,-65,116,-75,-77,-69,-46,-78,-122,19,114,122,-80,88,-20,14,53,51,-33,53,-61,18,-30,-68,102,60,65,41,-81,-108,-73,43,33,-36,73,48,-7,38,49,105,92,44,-79,-127,-107,34,-25,-100,-51,36,-50,-85,-97,36,-125,89,-65,-40,49,-116,69,-96,-89,123,76,31,119,56,31,105,-124,105,-51,26,15,38,-108,76,76,-128,-21,63,95,92,96,-41,58,-49,-109,-115,80,99,88,-101,24,48,17,96,7,-100,49,112,79,-91,115,-73,115,74,11,57,-43,99,-117,37,-77,60,-60,85,100,2,-39,3,-115,-14,108,95,62,-52,-19,-103,-83,0,21,-73,-72,-11,-35,10,-122,-46,-111,12,81,31,56,-106,94,-93,46,-14,-108,-119,1,-67,-13,-78,-107,-1,29,118,83,-71,8,-2,90,-10,-13,-67,-84,-52,72,34,55,111,-23,-63,-54,-10,-103,-118,3,-119,-103,-128,-57,-124,-95,-56,-92,1,86,86,-72,88,-60,-109,-81,42,68,3,24,-39,-14,-94,90,51,-126,-39,-41,98,27,54,-125,6,102,-57,9,-24,19,-30,-83,56,-36,-97,-74,-124,-12,12,83,23,97,85,-65,-84,-7,-10,-39,121,-44,-78,17,4,122,-113,-14,-74,-14,11,-85,59,123,9,79,12,-9,-73,16,120,-127,0,-31,-93,119,66,22,21,75,67,114,51,29,-73,-85,20,-28,-110,-27,44,-29,-95,-50,91,125,-69,55,-40,-72,-53,-102,76,-28,-72,-3,49,54,98,24,-29,120,-16,49,-31,-40,49,-53,-76,-128,-16,22,9,-37,-74,-108,-67,-65,-43,54,7,68,-80,-37,-29,60,90,71,96,66,-106,-53,111,-10,-63,-66,-24,-23,60,28,32,-38,-74,49,-26,69,-127,-11,-87,71,35,-73,-16,83,104,-45,30,21,109,-14,-101,-70,95,-77,-21,-108,38,9,87,117,93,-115,-23,-24,-13,-63,11,111,-97,103,26,-29,-18,65,-54,66,-46,121,63,-23,33,92,37,58,12,11,-28,-102,106,-56,84,15,123,-115,12,-108,79,20,80,52,30,-78,102,-55,23,-72,-76,-4,-115,84,36,-17,-80,34,-45,-94,74,-58,-54,-8,-106,119,56,-95} + +#define RESET_GATE_WEIGHT_X2 {65,-28,-36,70,67,55,86,-53,23,25,-19,59,67,43,-92,48,94,-113,60,-58,24,76,-15,-19,15,36,-74,115,-59,3,34,-43,21,-125,-45,127,92,-5,-65,-103,-83,51,42,109,-51,-39,-97,-64,-4,57,79,-42,88,-4,-108,83,-4,20,86,82,-87,95,12,-69,28,30,-97,-13,-33,-48,75,119,18,31,-83,-59,-114,-21,127,34,-27,-26,-47,86,-83,-49,8,29,-48,-31,-94,-59,-49,-36,0,28,-64,113,65,-8,47,-55,-49,112,-40,-39,-100,-42,32,82,27,-78,-105,3,19,88,15,-121,-120,7,-9,-107,-23,104,114,66,113,-102,-90,24,80,-34,106,48,-91,-11,22,-96,-82,75,26,-42,59,-45,23,78,79,-76,6,20,63,-118,-125,-42,111,-80,-79,-59,-121,-79,83,49,-95,-49,81,15,-11,-54,-45,64,-30,-49,81,-57,71,91,113,-46,-63,-4,-96,-95,-27,5,-52,35,67,112,58,-62,48,112,106,80,-19,103,4,-32,-118,-74,12,13,-126,-20,-5,115,-74,-30,123,-74,-66,11,-99,-16,-102,-100,-81,-20,-24,92,-79,-31,44,-24,-85,-123,5,-52,-111,73,29,28,-19,18,23,-112,-32,-52,-38,99,-59,-52,-31,87,124,28,-42,-39,81,-87,-24,16,47,20,36,1,-70,121,124,13,1,30,112,87,-86,11,36,-18,74,-104,-100,-14,0,-24,28,-53,53,66,-63,-109,-10,-50,-15,63,34,82,-59,85,-44,105,-10,-27,99,5,-105,-69,-75,2,-47,-66,71,-30,73,-11,-45,93,47,-37,-34,-8,90,-106,103,112,65,-100,-25,-13,38,74,54,27,-81,-8,19,49,94,118,-121,-116,120,-71,-87,36,-65,-112,8,-59,-106,-40,-16,68,87,-109,53,12,-7,9,6,67,78,8,-42,-123,79,-93,-102,-40,12,-66,-109,47,15,-8,-5,51,-62,111,8,-66,-82,-102,120,68,-67,9,-73,-69,-79,56,-36,-10,-69,-99,-2,-11,-66,76,37,4,92,1,-89,74,85,-124,-25,40,106,-102,42,-19,-30,0,-70,82,84,106,-84,48,16,37,33,-114,38,-29,-117,51,101,26,56,127,-81,-76,38,-124,103,-25,54,-21,-112,40,102,3,63,36,-54,16,-18,114,39,5,105,83,117,-92,-5,-14,-102,-87,-48,-77,-19,-82,-55,119,-95,-43,97,126,-48,-50,-97,-25,-102,-53,47,111,66,-82,-16,-38,76,-15,23,20,88,-19,125,-90,107,-31,102,107,30,-111,71,38,26,43,-85,82,29,-99,126,-109,21,-42,-107,-115,-123,30,-46,39,4,-19,-44,-69,86,41,4,33,57,-110,95,-22,123,71,1,119,77,90,105,81,-68,74,-38,-109,6,-82,-20,-115,-104,38,27,-44,82,-107,99,-41,-28,-55,100,10,-42,7,91,56,-91,113,-91,70,-66,-48,-18,109,-27,42,-89,-20,-63,-41,77,-13,73,10,-74,-51,88,28,50,-5,7,92,18,-98,-41,-14,8,-16,99,30,-109,7,52,110,-120,-17,33,53,1,106,-99,-14,-93,-46,-60,7,-54,100,91,93,89,-84,118,58,-84,38,57,-24,-25,22,-52,119,-85,-75,-79,60,-97,1,-13,54,-43,98,-92,65,37,-110,64,21,-18,-111,-9,86,90,42,-71,-29,86,-10,-15,-20,106,-45,-22,44,105,55,-61,-89,-119,31,93,-97,-35,9,-113,86,-113,22,-68,-29,-36,-123,98,79,34,-29,71,44,49,56,93,4,63,-3,45,12,54,-96,27,-55,-72,84,69,27,-28,-111,-57,-41,92,-106,-90,55,105,-60,94,34,94,-1,112,-86,-55,-58,68,-65,37,110,-107,-62,66,61,-69,-52,27,-61,70,-56,-116,-101,-103,127,-98,-79,25,-117,40,33,111,10,-3,-65,1,84,-41,5,-93,-85,-96,78,54,43,70,77,-53,-71,-38,48,103,-88,115,94,20,-5,-125,-7,-61,30,-25,-57,-42,-100,63,-114,40,-53,123,50,-7,121,75,67,75,3,-38,-101,-44,-46,54,38,-22,4,18,102,-126,44,86,-10,-1,118,98,102,-125,74,32,18,74,73,72,64,47,105,-72,5,73,98,9,39,18,10,-68,81,-128,-89,27,-51,51,16,119,-71,-53,51,-84,107,-116,7,73,106,20,52,-85,-74,-103,-18,29,-13,73,106,-92,107,-115,5,65,83,-79,-7,98,-42,-33,82,-64,75,-32,100,-67,-122,84,43,-111,114,-99,46,12,99,43,50,-24,-88,-60,111,68,64,54,-105,-120,119,68,5,51,63,89,-57,-75,-25,-35,-28,42,-64,101,-103,-35,-99,-96,-18,-64,-94,-46,89,-65,-38,-1,-97,127,-67,84,-18,86,115,60,-78,-109,-61,-93,-67,-87,-80,124,26,-9,111,115,-88,-71,-86,-71,-65,-15,108,-25,111,9,86,-115,-55,-23,57,27,103,108,-28,65,86,68,114,62,126,-4,33,-34,-123,87,-76,-104,-126,26,-13,44,108,105,12,-35,-58,3,-5,-32,91,49,89,88,37,38,119,-125,-48,37,53,85,-73,67,116,-116,-127,103,127,-115,92,-35,-83,-45,25,-96,-13,-90,41,-27,105,119,85,27,-3,-64,93,17,-53,104,-70,-43,65,45,-90,61,-31,-49,-99,84,46,93,-37,84,-79,13,-59,-76,62,19,-11,-96,-104,-3,-8,-78,92,98,50,-7,-39,-82,37,-126,127,-113,67,94,115,-9,-33,-57,26,-67,9,28,-8,81,-98,-10,84,34,111,-95,127,75,38,-7,-2,-71,-62,-72,99,-74,25,123,114,51,-28,103,-110,43,113,7,58,75,-95,-52,19,-112,101,26,65,-115,-91,85,-5,-45,110,-103,-34,-69,50,-15,-19,-110,-44,-7,-112,-93,29,50,-84,-55,-41,11,19,-31,-47,-62,-12,-105,-47,68,-124,-47,-113,-55,30,25,55,-14,85,-66,-5,-105,62,-27,-89,-124,-84,112,34,52,25,104,32,-30,84,-46,-38,60,-2,-107,-95,-86,-25,117,60,-121,32,84,8,-88,-1,91,-46,-76,81,44,79,105,-105,82,20,59,-115,96,21,-113,19,92,122,76,36,-112,78,16,38,73,69,54,97,41,-49,78,-71,-69,95,-85,117,10,-98,25,72,126,47,-17,4,-44,-32,-16,-12,105,76,4,-82,-91,-21,-117,30,-67,46,-8,-125,84,-51,94,0,-60,127,99,43,60,16,55,-16,-121,-61,-115,38,25,17,35,23,68,9,-107,-44,118,119,43,99,-95,40,42,-70,54,19,92,-36,82,-35,122,-96,54,-29,-50,100,-79,-71,-99,-60,-2,-100,41,97,-93,-58,-123,126,-102,81,-5,83,110,-50,58,-86,41,-126,43,-49,98,-59,94,-91,115,16,-3,-58,-30,-109,110,-114,124,22,-88,-79,-29,-100,54,-33,23,-1,-77,52,-126,114,70,-50,90,82,-13,-25,-125,16,48,101,-93,19,-103,67,-1,-32,28,-72,-26,73,45,-22,83,-68,-61,89,57,-37,90,16,-38,-124,47,-5,-113,81,71,-30,-46,-18,-52,-104,-40,49,-101,106,38,6,125,-70,25,-88,-50,-77,-12,53,110,-84,23,-109,-53,112,2,88,101,-55,-10,-72,123,-35,42,-15,98,-85,48,-100,-54,123,52,-105,7,-28,86,-125,85,12,86,-34,103,-8,-65,-24,88,-43,57,-16,114,-98,101,81,34,-83,-8,3,-27,5,110,-24,-80,9,85,-108,96,-93,-34,76,-107,71,84,-98,-10,-94,71,71,-38,-96,-112,100,127,52,-32,-127,102,61,-119,-46,-119,125,109,-23,-80,-11,-68,84,-53,35,-115,105,-88,72,110,109,17,-121,80,-87,-72,-123,-31,13,71,63,-126,107,115,-100,27,39,10,75,-128,58,103,-104,126,-59,31,89,-67,97,-96,-69,87,19,99,49,111,9,91,-98,-4,-118,103,-63,-92,-74,106,-53,52,122,12,24,123,-126,-105,104,38,107,118,10,74,-38,14,-11,76,-112,-112,30,-47,95,112,65,-94,120,21,85,33,52,55,-54,-57,-77,-16,52,88,-81,-77,52,0,90,-126,66,88,-81,83,50,81,-28,-56,-36,-8,50,4,115,58,-30,-53,-78,-114,-16,-100,33,-80,-6,96,108,4,-27,-90,8,48,-118,-112,22,-56,114,-66,4,-11,-48,118,61,104,118,-27,13,52,2,74,112,-127,48,27,59,-37,-58,18,85,-5,-41,-91,-32,-56,-5,-40,-117,-89,-48,-8,-32,43,-75,-118,-109,-92,-122,67,88,107,79,-90,30,-65,-102,-100,-112,-104,57,-33,-103,69,-26,15,-12,106,-17,50,-20,33,51,14,98,-118,-82,63,-65,-40,-89,-8,-75,-16,-1,-13,118,76,34,-100,83,-10,72,26,-13,50,92,69,12,-33,-66,76,62,-47,-10,-31,60,-52,52,74,77,30,59,-98,-78,-124,107,38,-121,97,-39,-12,-1,63,-112,71,-65,9,-66,-31,50,39,77,56,-81,-125,-109,-36,-62,-74,12,31,-128,64,62,86,-9,26,69,-45,-35,46,39,95,78,-22,81,-5,-22,90,-47,-36,58,65,88,-89,37,81,115,-3,-108,52,7,-32,80,-96,-24,-22,104,-95,-3,117,59,105,66,-113,28,55,-75,46,45,-118,79,-3,-113,119,-114,-3,-64,56,34,118,67,32,25,-8,1,-64,91,112,31,-88,91,-53,115,33,-3,14,-43,82,-42,-57,-128,-124,127,-69,-112,98,-40,-9,-35,29,-87,-74,27,120,77,-70,93,39,95,118,-39,82,83,-26,60,106,-116,43,8,-114,66,28,5,-95,111,-11,68,24,44,65,-93,26,50,13,100,-33,-93,99,6,0,77,98,5,-10,84,77,46,4,-13,-31,-83,84,-78,-97,-58,76,-71,-6,2,27,-73,81,100,-126,-7,117,-10,-6,118,52,-4,25,56,43,-26,-43,-64,23,-44,-108,-53,45,-117,91,-88,-45,-87,63,120,82,70,73,-108,89,-12,35,-81,-98,-124,-114,-126,86,21,-35,-32,-105,122,111,98,77,38,-18,-7,-48,69,22,74,-127,-62,-47,-20,-8,9,-48,-2,-53,-58,-37,51,27,-91,57,69,-27,-91,76,-127,78,76,-108,-1,13,-71,-41,38,46,60,-5,-73,-98,123,106,35,-38,-102,2,125,25,-63,-110,9,25,-106,-21,-113,-111,97,-33,33,83,55,123,72,-11,-78,-85,35,56,-110,-18,118,9,85,-100,-65,126,24,-18,50,-32,98,40,114,59,-60,-6,-72,-68,16,21,-10,-6,113,-23,-24,-27,-116,-126,119,6,-78,118,15,-53,7,113,3,83,52,44,-44,-53,-85,78,-108,-83,-128,63,-10,-122,-92,24,28,21,-87} + +#define RESET_GATE_WEIGHT_X4 {65,28,-28,30,-90,106,24,80,-36,-97,70,-13,80,-19,-34,103,67,-33,55,-48,106,4,48,-32,86,75,-53,119,-91,-118,-11,-74,23,18,25,31,22,12,-96,13,-19,-83,59,-59,-82,-126,75,-20,67,-114,43,-21,26,-5,-42,115,-92,127,48,34,59,-74,-45,-30,94,-27,-113,-26,23,123,78,-74,60,-47,-58,86,79,-66,-76,11,24,-83,76,-49,6,-99,20,-16,-15,8,-19,29,63,-102,-118,-100,15,-48,36,-31,-125,-81,-42,-20,-74,-94,115,-59,111,-24,-80,92,-59,-49,3,-36,-79,-79,-59,-31,34,0,-43,28,-121,44,-79,-24,21,-64,-125,113,83,-85,49,-123,-45,65,127,-8,-95,5,-49,-52,92,47,-5,-55,81,-111,15,73,-65,-49,-103,112,-11,29,-54,28,-83,-40,51,-39,-45,-19,64,18,42,-100,109,-42,-30,23,-49,-112,-51,32,-39,82,81,-32,-57,-52,-97,27,-64,-78,71,-38,91,99,-4,-105,57,3,113,-59,-46,-52,79,19,-42,88,-63,-31,-4,87,88,15,-4,-121,-96,124,-95,28,-108,-120,83,7,-27,-42,5,-39,-4,-9,20,-107,-52,81,35,-87,86,-23,82,104,67,-24,112,16,-87,114,95,66,58,47,-62,20,12,113,-69,-102,48,36,112,1,-70,54,121,27,-2,-102,-11,-87,124,-81,13,-8,-66,-48,76,-77,1,19,30,49,37,-19,4,-82,112,94,87,118,92,-55,1,119,-86,-121,11,-116,-89,-95,74,-43,36,120,-18,-71,85,97,-124,126,74,-87,-104,36,-25,-48,40,-50,-100,-65,-14,-112,106,-97,-102,-25,0,8,-24,-59,42,-102,-19,-53,28,-106,-53,-40,-30,47,0,111,53,-16,66,68,-70,66,82,-82,-63,87,-109,-109,84,-16,106,-38,-10,53,-50,12,-84,76,48,-15,-15,-7,63,9,16,23,37,20,34,6,82,67,33,88,-114,-19,-59,78,85,8,38,125,-29,-90,-44,-42,105,-123,-117,107,51,-31,-10,79,-27,-93,101,102,26,107,99,-102,5,-40,56,30,127,-111,-105,12,-69,-66,-81,71,-76,38,-75,-109,2,47,38,26,-124,43,-47,15,-66,-8,103,-85,-25,82,71,-5,-30,51,54,29,-21,-99,73,-62,-11,111,-112,126,40,-109,-45,8,93,-66,102,21,3,-42,47,-82,-37,-102,63,-107,36,-115,-34,120,-8,68,-54,-123,16,30,90,-67,-106,9,-18,-46,114,39,103,-73,112,-69,39,4,5,-19,65,-79,-100,56,105,-44,83,-69,-25,-36,-13,-10,117,86,-92,41,38,-69,74,-99,-5,4,-14,33,57,-41,-110,-14,-15,68,-20,-65,95,8,-22,-16,106,37,-45,110,123,99,71,30,-22,-107,44,-62,1,-109,119,7,105,66,55,61,77,52,90,110,-61,-69,-89,-52,105,-120,81,-17,-119,27,31,-61,-68,33,74,53,93,70,-97,-56,-38,1,-109,106,-35,-116,9,-101,6,-99,-82,-14,-113,-103,86,127,-20,-93,-115,-46,-113,-98,22,-79,-104,-60,38,7,-68,25,-29,-117,27,-54,-44,100,-36,40,-123,33,82,91,-107,93,98,111,79,10,99,89,-41,-84,34,-3,-29,-65,-28,118,-55,58,71,1,44,84,100,-84,10,38,49,-41,56,5,-42,57,7,-24,93,-93,4,-85,91,-25,56,22,63,-96,-3,78,-91,-52,113,119,45,54,12,43,-91,-85,70,-75,54,70,-96,77,-66,-79,-48,60,27,-53,-55,-71,-18,-97,109,1,-72,-38,84,48,-27,-13,42,54,69,103,27,-88,-89,-43,-20,98,-28,115,-111,94,-63,-92,-41,65,-57,20,-41,-5,77,37,-13,-110,92,-125,-106,-7,73,64,10,21,-90,-61,55,30,-74,-18,-51,-111,105,-25,-60,-57,88,-9,28,86,94,-42,34,-100,50,90,-5,42,94,63,-1,-114,7,-71,92,-29,112,40,-86,-53,18,86,-98,-10,-55,123,-58,50,-7,-103,121,-18,-46,-35,89,-58,75,29,67,-13,-65,3,-38,-5,75,73,3,106,-1,-32,-97,91,-38,-92,-101,107,127,49,-67,89,-44,-115,-46,5,84,88,-18,37,54,65,38,83,86,38,115,119,-22,-79,4,-7,60,-125,-78,-48,18,98,102,-42,-109,37,-61,53,-126,-33,44,82,-93,85,-67,-73,86,-64,-10,75,-87,67,-80,116,-1,-32,118,100,124,-116,26,-127,98,-67,102,-122,-9,103,111,127,-125,84,74,43,115,-115,-88,92,32,-111,18,114,-71,-35,-86,-83,74,-99,73,46,-71,-45,-65,25,72,12,64,99,-15,-96,108,-13,47,43,105,50,-25,-90,111,41,-72,-24,5,-88,9,-27,86,105,73,-60,98,111,-115,119,-55,85,9,68,39,64,-23,27,57,-3,18,54,10,-105,27,-64,103,93,-68,-120,81,119,108,17,-28,-53,-128,68,-89,5,65,104,86,-70,27,51,-51,63,68,-43,114,65,51,89,16,-57,62,45,126,-90,119,-75,-71,-25,-4,61,33,-31,-53,-35,51,-28,-34,-49,-123,-99,-84,42,107,-64,87,84,-76,46,-116,101,7,-103,-104,93,-126,-37,73,-35,106,-99,26,84,-13,-79,20,-96,52,-18,44,13,108,-59,-85,-64,-74,-94,105,-76,12,62,19,-115,-11,-91,117,-67,60,46,-96,85,-104,-5,-121,-8,32,-125,-3,-45,-8,110,84,84,8,-51,-78,-103,92,-34,-88,94,-1,0,98,-69,50,50,91,-60,-46,127,-7,-15,-39,-19,-76,99,81,43,-82,-110,37,-44,44,60,79,16,-126,-7,127,-112,105,55,-105,-16,-113,-93,67,29,82,-121,20,-61,94,50,115,-84,59,-115,-115,38,-9,-55,-33,-41,96,25,21,17,-57,11,26,19,-113,35,19,23,-67,-31,9,-47,92,68,122,9,28,-62,-8,-12,76,-107,36,-44,81,-105,-98,-47,-112,118,78,119,-10,68,84,-124,16,43,38,99,34,-47,111,-113,73,-95,69,40,-95,-55,127,30,54,42,97,-70,75,25,38,55,41,54,-49,19,-7,-14,-2,85,78,92,-71,-36,-71,-66,-62,-5,-69,82,95,-35,-72,-105,99,62,-85,122,117,-96,-74,-27,25,-89,10,54,-98,-29,123,-124,114,-84,25,-50,72,100,51,112,-28,34,126,-79,47,-71,103,52,-110,25,-17,-99,4,-60,43,104,113,32,-44,-2,-32,-100,7,-30,58,84,-16,41,-12,97,75,-46,-95,-38,105,-93,76,-58,-52,60,19,-2,4,-123,-82,126,-112,-107,101,-95,-91,-102,-21,81,26,-86,65,-25,-117,-5,30,83,110,-38,-50,-124,57,-31,-16,13,58,47,-86,-5,114,71,-98,63,41,-113,-126,81,101,-126,81,107,43,71,-49,-30,34,115,-83,-100,98,-46,-59,-18,-8,27,3,39,94,-52,-91,-104,-27,10,5,75,115,-40,16,49,110,-128,-24,58,-3,-101,-58,106,-80,103,9,-104,-30,38,-109,6,85,126,-108,-59,110,125,-114,-70,96,31,-93,89,124,25,22,-88,-34,-67,76,97,-88,-50,-79,-77,-107,-96,71,-69,-29,-12,-100,53,84,87,-98,19,54,110,-33,-84,-10,99,-94,49,23,23,-1,-109,71,111,71,9,-77,-53,52,112,-38,91,-96,-98,-126,2,114,88,-112,-4,100,-118,70,101,-50,-55,127,103,52,-63,90,-10,82,-72,-32,-92,-127,-74,-13,123,-25,-35,102,106,61,-53,-125,42,16,-15,-119,52,-46,122,48,98,101,-85,-119,12,125,24,-93,48,19,-100,109,123,-23,-126,-103,-54,67,123,-80,-105,-11,104,-1,52,-32,-105,-68,38,84,107,28,7,-72,-28,-53,118,35,10,-26,86,73,-125,-115,74,105,-38,45,85,-22,12,-88,14,72,-11,83,86,-68,-34,110,76,109,-112,-61,103,89,-8,17,-112,-121,30,57,-65,-37,-24,80,-47,-87,95,90,88,16,-43,-72,112,-123,65,-94,52,120,2,-16,26,-1,69,21,74,85,112,-13,-45,118,-35,33,-127,52,48,76,46,34,39,55,27,-54,59,-100,95,83,78,-57,-37,-77,-58,-10,-22,72,81,-16,18,52,85,26,-5,-13,-22,88,-5,-81,-41,50,90,92,-47,-77,-91,52,-32,69,-36,12,58,0,-56,90,-5,-33,65,-66,88,-126,-40,66,-117,76,-89,62,37,88,-89,-81,-48,-47,81,-10,115,83,-8,50,-32,-31,-3,60,-108,81,43,-28,-75,-52,52,52,7,-56,-118,-36,-109,74,-32,77,80,-8,-92,50,-122,30,-96,59,-24,4,67,115,88,-98,-22,-78,104,58,107,-30,79,-124,-95,107,-3,-53,-90,-78,30,38,117,-121,59,-114,-65,-16,-102,97,105,-39,66,-100,-100,33,-112,-12,-113,-1,28,-80,-104,-6,57,63,55,-112,-75,96,-33,108,-103,71,46,-65,45,4,69,-27,-26,9,-118,-66,79,-90,15,8,-12,-31,-3,50,-113,48,106,-118,-17,39,119,77,-114,-112,50,22,-20,56,-3,-81,-64,-56,33,114,51,-125,56,-109,34,-66,14,4,98,-36,118,-62,67,-11,-118,-48,-82,-74,32,12,25,118,63,61,-65,31,-8,-128,1,104,-40,118,-89,64,-64,62,91,-27,-8,13,-75,86,112,-9,31,-88,-10,91,84,111,123,98,72,-53,77,115,46,77,-11,38,-78,33,4,-3,-13,-18,-85,-7,35,14,-31,-43,-83,-48,56,69,-110,82,84,-42,-78,22,-18,74,118,-57,-97,-128,-58,-127,9,-62,85,-124,76,127,-71,-47,-100,-20,-65,-69,-6,-112,2,-8,126,9,24,98,27,-40,-73,-48,-18,-2,50,-9,81,-35,100,-53,-32,-58,98,29,-126,-87,-7,-37,40,51,114,-74,117,27,-10,27,59,-91,-60,120,-6,77,118,57,-6,69,-72,-70,52,93,-4,-27,-68,-91,16,39,25,95,56,76,21,-127,-10,118,43,-39,-26,78,-6,76,113,82,-43,83,-64,-108,-23,-1,-24,-26,23,60,-44,13,-27,-71,-116,106,-108,-116,-53,-41,-126,38,119,43,45,8,-117,46,6,60,-78,-114,91,66,-88,-5,118,-73,15,28,-45,5,-87,-98,-53,123,7,-95,63,111,120,106,113,35,3,-11,82,68,70,-38,83,-102,52,24,73,44,-108,2,44,125,-44,65,89,-93,-12,25,-53,-63,-85,26,35,50,-81,-110,78,9,-108,13,-98,100,-124,25,-83,-106,-128,-33,-114,-93,-126,-21,63,-113,-10,99,86,6,21,-111,-122,97,-92,0,-35,77,-32,-33,24,33,28,98,-105,5,122,83,21,55,-87} + +#define HIDDEN_STATE_WEIGHT_X2 {-3,-33,59,21,117,70,0,44,108,108,-47,-80,-118,34,88,-91,-123,-108,8,51,26,82,-80,107,-100,-69,97,-90,17,19,63,111,-40,-125,110,24,58,-69,26,-31,-65,-37,-47,-41,-109,106,-100,108,-99,108,116,104,86,-50,-45,10,-53,112,34,96,-10,-39,-32,-25,69,102,-2,-4,-25,121,-1,-28,-48,-100,0,-128,60,-73,42,-32,118,-88,-113,-112,-113,70,-98,118,95,77,-52,123,-99,72,26,-102,-32,120,113,22,6,-68,84,-33,103,66,111,60,-76,33,10,25,-43,93,41,-79,110,13,67,107,-113,90,58,64,-125,79,-85,-18,76,80,-59,11,-18,-74,15,-102,99,-19,117,99,65,-50,-108,-121,-9,-104,33,94,-95,110,-48,-97,76,36,1,-58,86,-115,45,-88,38,51,123,-23,-20,-43,-37,15,91,-85,-88,6,-96,58,78,13,23,1,-43,62,-70,-108,44,30,74,90,79,-80,-20,71,-21,0,60,19,-59,-52,44,-14,77,92,-69,121,-123,-27,119,-84,79,87,24,85,118,1,-51,-96,60,102,-6,15,96,120,-109,6,35,11,-119,-109,-18,16,-112,91,-126,71,-29,121,-21,-120,37,57,-117,-39,93,56,-73,-104,77,-107,-52,111,-61,-4,44,-119,67,72,-66,36,-127,-113,-124,123,21,98,84,86,76,23,78,7,-127,-4,1,-46,-107,59,-21,53,-65,-99,-15,-98,53,-31,7,64,7,105,51,-75,50,-52,48,101,-126,-120,5,34,3,81,-39,70,41,112,25,30,79,-6,107,-11,-97,92,-84,67,49,107,60,101,-37,27,-91,-61,-96,120,-113,87,-46,68,64,102,-86,-60,13,-71,56,-105,90,-9,-35,27,103,120,39,23,-39,-1,-85,-95,-6,119,-41,-2,-69,102,102,-119,-3,-11,-125,-111,40,-115,-41,-117,-44,-7,83,123,-21,23,99,-107,43,100,-99,-3,89,3,-113,103,47,-94,-69,-38,-28,-37,49,-117,-49,-126,17,-98,37,92,55,-116,-70,-50,77,120,47,124,78,114,67,-48,6,-42,-115,85,116,-114,-46,-50,-13,70,-101,110,-55,20,-51,125,-19,-9,-15,46,30,-27,-123,114,-50,-30,-72,76,-83,71,47,-45,74,102,44,108,-26,108,-113,-43,110,-91,37,-69,76,-33,106,-76,-96,20,-117,63,-33,-5,11,-121,-51,63,-56,59,-16,-33,114,74,124,73,99,-50,51,-71,118,106,30,-92,26,-40,119,-121,2,-45,9,0,-5,-2,-89,88,-11,-85,-60,19,81,-96,75,82,-40,124,89,-36,-117,-100,-2,-34,112,101,39,-101,-106,60,59,-126,-32,96,68,-53,87,20,54,-24,46,-95,65,-112,22,60,122,-22,-106,-124,97,-37,-86,95,-110,-8,44,58,-12,-120,-45,-86,-32,-86,-94,-14,15,29,-8,-114,71,70,-93,-69,100,-123,-18,-47,-12,127,104,-102,93,-11,-73,121,87,-79,-92,46,92,-108,-107,79,121,-71,-89,16,-11,-52,72,-114,-32,-60,-9,-57,-4,10,-81,-22,68,74,76,-68,-127,96,-84,69,-3,-26,-106,-3,-87,-65,105,109,122,-103,31,-108,-86,-5,-39,85,88,67,-82,0,-25,93,61,-62,5,-54,-114,-51,-9,-114,20,49,-26,38,19,39,-103,33,-120,37,-97,32,-89,119,111,-124,-99,78,-49,-128,76,-18,-12,-109,96,90,-73,-104,59,-59,-92,123,55,54,-120,-80,-48,-16,-95,96,36,118,-119,-58,93,45,-43,-75,64,38,-2,-72,-111,22,-89,-75,-120,-42,45,108,59,-105,40,27,32,-66,121,-22,-71,-9,118,124,60,-96,47,4,14,-27,64,70,47,-91,-70,1,-44,94,-46,53,4,23,-124,-92,-95,83,-49,-81,40,-80,48,0,39,1,-113,32,40,-21,-1,-110,102,1,-74,-51,40,108,-35,-36,89,84,123,-48,-115,-115,83,-61,114,-127,-61,114,100,-82,-45,60,87,60,19,86,97,-68,40,-66,75,86,-32,-128,88,-57,-27,77,3,-27,43,-39,-62,66,5,-82,45,-104,-78,34,57,96,89,-90,66,-10,37,-110,-30,82,-58,13,94,12,115,35,117,0,80,61,-7,107,-104,-21,21,-70,-93,-94,-51,-61,39,-62,64,-82,-109,76,84,58,-47,-100,52,46,-51,88,91,8,-47,108,-80,25,-58,111,-59,-83,-75,92,98,110,54,106,65,-47,-120,-5,90,-123,101,-61,-85,-93,109,88,0,8,59,86,56,126,17,-26,58,-101,-25,35,0,-123,-3,-56,112,-128,8,17,-52,88,31,-3,105,-56,68,-1,-94,96,-19,10,-22,-88,-10,119,-44,19,42,75,-86,18,-107,89,-82,-120,76,40,84,-122,29,33,-47,17,-50,-13,23,-66,-46,85,-29,-110,42,-68,8,99,-93,-29,101,16,52,-13,127,0,86,-117,-92,-70,-32,-27,127,-123,1,34,-13,92,114,-11,29,-103,-121,-54,20,73,16,74,108,16,-61,89,50,-30,-14,116,44,-31,16,96,24,-51,7,39,-87,-69,-61,-98,61,-46,113,85,-95,103,67,99,-66,-45,-42,-70,96,104,5,-111,69,-25,99,-118,23,109,11,4,-41,-94,73,100,96,6,90,-75,-25,79,-13,-43,-6,-12,51,12,40,124,-56,81,-8,59,-60,-26,-54,33,122,85,53,-99,125,19,-26,94,41,-5,46,-48,-70,-10,41,102,-1,-98,-9,15,29,46,-66,-118,-53,45,119,-127,94,53,-58,90,124,5,-110,-98,-80,-77,77,29,19,105,-121,92,9,-124,50,-119,59,40,67,104,-12,13,103,101,47,-51,34,-66,-101,-117,112,-5,118,-48,-60,-114,38,-71,2,51,114,80,115,-5,116,20,16,-47,-19,30,24,-68,7,-30,-3,-64,-7,-34,-12,44,34,-91,-97,116,112,-99,108,-75,17,26,-14,-61,80,22,-7,34,47,-93,45,106,121,78,43,-97,39,-99,-68,-72,-7,64,-49,-82,-127,78,-64,48,18,15,126,-125,-111,-69,-111,10,-46,111,-75,123,-44,-67,-31,-96,-67,-53,-53,-106,67,-101,23,62,30,9,-114,-12,-57,-38,-78,95,-10,-3,110,88,123,-26,78,-125,114,53,10,-57,26,38,-51,73,92,-124,79,15,75,-62,109,-113,-67,1,35,52,-36,55,7,111,-43,109,101,88,122,-21,-32,-87,59,16,-122,-109,-118,17,-22,-39,53,-105,77,90,-24,-65,43,-27,113,30,-117,-30,106,37,55,59,54,-70,99,99,-73,120,97,-39,-88,-54,101,51,-76,70,-121,-68,23,-73,-31,75,-8,-63,-123,-93,96,-81,99,-95,28,-36,55,-104,32,-64,41,-97,95,-89,126,-26,-25,126,2,-26,-54,110,-86,110,74,-3,-110,56,-60,-49,117,-82,-55,-103,-112,70,-85,85,-63,82,7,75,-61,90,32,35,-115,72,73,-121,63,-84,-52,-29,-59,-4,29,64,119,127,58,-117,48,126,120,-115,-15,-10,27,27,-81,117,-5,121,-72,113,31,-13,10,27,-106,-51,81,-96,-22,19,-78,6,71,-34,123,118,75,-23,-72,-97,111,-121,0,80,28,52,95,59,-116,72,80,-75,-62,88,23,-102,13,6,113,-85,98,45,-96,-32,94,-7,12,-9,86,18,59,-15,75,13,-70,50,-93,52,67,53,-31,19,45,-111,36,39,-91,-77,104,71,7,-44,-76,3,-62,121,43,37,-7,-96,-6,57,-104,30,-126,-94,118,-44,91,29,124,-86,-13,55,41,-41,91,-112,-25,103,81,-70,-112,113,-25,-73,-82,16,67,-5,104,56,66,-115,-90,-126,106,80,-78,-51,-15,-68,-3,102,-10,-123,-10,-71,-111,86,48,-45,101,81,-114,-94,77,-127,-96,-100,86,109,-33,15,-34,60,88,-86,-63,-103,-46,101,-127,-88,90,-37,82,-125,-28,-6,61,-104,77,0,-52,59,-9,-82,59,-78,79,80,-77,-125,-95,16,26,-55,-16,15,-76,-9,56,110,85,-102,-23,-12,-6,-97,-34,32,-79,-95,71,126,127,30,-112,-115,75,-8,125,103,-118,65,-43,107,46,96,-41,-87,-64,-18,126,82,10,81,45,95,61,9,28,-113,-71,47,117,26,-81,73,49,-55,-126,-33,62,-84,-87,-56,-71,97,49,-124,-76,-9,97,119,-23,127,-29,20,-66,-80,-122,40,-2,116,126,-120,-48,124,57,-107,104,80,-13,81,118,33,88,119,-110,33,-35,-75,-6,89,-41,99,46,127,-36,54,-55,50,24,51,49,-71,37,-117,114,6,110,88,84,-30,-45,-50,113,-12,-57,59,-18,49,99,-124,46,-48,88,-82,-121,-97,15,-73,-128,-121,46,30,-93,-109,-15,-86,-2,75,1,-32,-27,-86,-13,-38,48,10,-36,-107,-27,-48,88,-7,-88,98,-83,61,-81,20,-123,18,-41,-127,-55,-66,24,-107,73,30,-42,-74,124,-43,-125,102,98,6,32,24,-123,32,113,105,-81,117,-41,-54,-113,-126,-28,31,-56,-64,-6,-103,-36,-2,-59,34,-40,-64,-39,-64,-74,-105,50,-86,-66,-14,-71,35,-116,-20,15,-119,-12,90,-117,-29,13,-8,-75,57,67,124,-38,66,113,-80,113,105,45,-74,-80,108,-24,-3,36,62,-8,109,-40,-101,106,12,-47,-113,-118,-12,-3,-86,-52,-93,-24,-62,-119,-93,67,39,4,-18,-103,24,1,71,93,95,-113,-7,34,-10,-77,-74,96,86,52,-2,-45,-71,-48,124,-97,1,23,-59,-117,-74,58,-31,-115,114,-14,-115,77,82,100,67,117,-16,-64,105,-19,59,124,124,-116,-33,22,-115,30,102,91,98,-124,38,12,-38,-23,-106,52,75,-45,74,-6,-29,31,117,20,99,66,27,-92,127,-67,-53,68,-66,-26,35,114,-84,-74,-94,-14,-43,-106,-32,-67,-27,28,29,-32,-101,-60,-55,-6,-101,-42,61,111,107,-87,-67,102,-36,119,-81,-54,52,-114,5,-26,115,-7,44,-30,-21,-67,33,-92,29,-30,3,7,-101,-83,-115,29,68,49,-70,-40,-116,63,-49,115,97,123,119,22,-13,47,-4,-14,-94,94,-122,56,58,57,-127,-60,-46,29,94,-105,49,-72,94,20,-8,104,35,-90,19,-26,24,-7,109,10,-9,80,-105,0,126,94,105,63,85,43,-63,-2,-32,39,-119,-12,-108,33,-67,127,-66,-23,-123,8,41,-21,-30,117,20,-85,-39,-87,2,96,-12,-128,83,67,-53,-101,3,-3,-22,-16,51,125,-125,-76,25,42,101,101,35,-36,103,85,-71,-24,6,26,105,60,112,-91,69,13,21,10,-93,22,-111,0,-38,4,-34,45,-86,121,-42,-54,7} + +#define HIDDEN_STATE_WEIGHT_X4 {-3,69,-33,102,76,60,80,19,59,-2,21,-4,-59,-59,11,-52,117,-25,70,121,-18,44,-74,-14,0,-1,44,-28,15,77,-102,92,108,-48,108,-100,99,-69,-19,121,-47,0,-80,-128,117,-123,99,-27,-118,60,34,-73,65,119,-50,-84,88,42,-91,-32,-108,79,-121,87,-123,118,-108,-88,-9,24,-104,85,8,-113,51,-112,33,118,94,1,26,-113,82,70,-95,-51,110,-96,-80,-98,107,118,-48,60,-97,102,-100,95,-69,77,76,-6,36,15,97,-52,-90,123,1,96,-58,120,17,-99,19,72,86,-109,-115,6,63,26,111,-102,45,35,-88,11,-40,-32,-125,120,38,-119,51,-109,110,113,24,22,123,-18,-23,16,58,6,-69,-68,-20,-112,-43,91,26,84,-31,-33,-37,-126,15,71,-65,103,-37,66,91,-29,-85,121,-47,111,-41,60,-88,-21,6,-120,-109,-76,106,33,-96,37,58,57,-100,10,108,25,78,-117,13,-39,-99,-43,108,93,23,93,1,56,116,41,104,-79,-43,-73,62,-104,86,110,-50,13,-70,77,-108,-107,-45,67,10,107,44,-52,30,111,-53,-113,112,90,74,-61,90,-4,34,58,96,64,79,44,-80,-119,-10,-125,-39,79,-20,67,71,72,-32,-85,-25,-18,-21,-66,0,36,-127,-96,-113,120,49,76,-117,-33,-124,-113,123,87,-49,106,-126,-76,21,-46,98,68,17,-96,-98,20,84,64,86,102,37,-117,92,63,76,-86,23,-60,55,-33,-116,-5,78,13,7,-71,-70,11,-50,-121,-127,56,-4,-105,77,-51,120,63,1,90,-46,-9,47,-56,124,59,-107,-35,59,27,78,-16,114,-33,-21,103,53,120,67,114,-48,74,-65,39,-99,23,6,124,-42,73,-15,-39,-98,-1,-115,99,85,-50,53,-85,-31,-95,116,51,-114,-71,7,-6,64,119,-46,118,-50,106,7,-41,105,-2,-13,30,70,-92,51,-69,-75,102,-101,26,110,-40,50,102,-52,-119,-55,119,20,-121,48,-3,101,-11,-51,2,125,-45,-126,-125,-120,-111,-19,9,-9,0,5,40,34,-115,-15,-5,46,-2,3,-41,81,-117,30,-89,-27,88,-39,-44,70,-7,-123,-11,114,-85,41,83,112,123,-50,-60,-30,19,25,-21,30,23,-72,81,76,-96,79,99,-6,-107,-83,75,71,82,107,43,-11,100,47,-40,-45,124,-97,-99,92,-3,74,89,102,-36,-84,89,67,3,44,-117,108,-100,49,-113,107,103,-26,-2,108,-34,60,47,101,-94,-113,112,-43,101,-37,-69,27,-38,110,39,-91,-101,-91,-28,-61,-37,37,-106,-69,60,59,121,-126,-71,-97,47,32,4,-32,-89,96,16,-89,14,119,-27,68,-11,-53,-52,111,64,-124,70,87,72,20,-114,-99,47,78,-91,54,-32,-24,-60,-49,-70,-128,1,46,-9,-95,-57,76,-44,-18,94,65,-4,-112,10,-12,-46,-109,53,22,-81,60,-22,96,4,90,23,122,68,-22,74,-73,-124,-104,-92,-106,76,-124,-68,59,-95,-59,83,97,-127,-37,96,-92,-49,123,-81,-86,-84,95,69,55,40,54,-80,-110,-3,-8,-26,-120,48,-80,0,44,-106,58,-3,-48,39,-16,1,-12,-87,-120,-65,-95,-113,96,32,-45,105,-86,109,36,40,118,-21,-32,122,-86,-103,-119,-1,-58,-110,-94,31,-14,-108,93,102,45,1,15,-86,29,-5,-43,-74,-75,-51,-8,-39,-114,85,64,40,38,108,71,88,70,67,-2,-35,-72,-36,-93,-82,-69,0,-111,89,22,84,100,-25,-123,93,-89,123,-75,-48,-18,61,-47,-62,-120,-115,-42,-115,-12,5,127,-54,45,83,108,-61,104,-114,-102,-51,59,114,-105,-127,93,-9,-11,-114,40,-61,27,114,-73,20,121,49,32,100,-66,-82,87,-26,-79,38,121,-45,-22,60,-92,19,46,39,-71,87,-9,60,92,-103,-108,33,118,19,124,86,-107,-120,79,37,60,97,-96,-68,40,-51,-66,88,-10,-61,119,89,75,91,86,8,-44,50,19,-30,-32,-47,-128,108,42,-14,75,116,88,-80,-57,25,-86,44,18,-31,-27,-58,77,111,-107,16,89,96,3,-59,-27,-83,-82,24,-120,-51,43,-75,-39,92,76,7,40,39,-62,98,66,110,84,-87,-122,-69,5,54,-82,106,29,-61,33,-98,45,65,-104,-47,-47,61,17,-46,-78,-120,34,-5,-50,113,-13,85,57,90,96,-123,23,-95,-66,103,89,101,-90,-61,-46,67,85,99,66,-85,-10,-93,-29,-66,-110,-45,37,109,-110,88,42,-42,-68,-70,-30,0,82,8,8,96,99,104,-58,59,13,86,-93,5,-29,-111,94,56,12,126,101,69,16,-25,115,17,35,-26,52,99,-13,-118,117,58,0,-101,127,23,0,109,80,-25,61,35,86,11,-117,4,-7,0,107,-123,-92,-41,-70,-94,-104,-3,-21,-56,-32,73,-27,100,21,112,-70,-128,127,96,-123,6,-93,8,-94,17,1,90,34,-75,-51,-52,-61,88,-13,-25,92,79,39,31,-62,-3,114,-13,-11,-43,64,105,-82,-56,29,-6,-103,-12,-109,68,76,-1,-121,51,-54,12,84,-94,58,96,20,40,73,124,-47,-19,-100,10,16,-56,74,81,52,-22,46,-88,108,-8,16,59,-60,-101,-26,-117,-127,-36,78,55,-54,112,33,-5,-64,7,48,111,122,118,85,-48,18,-43,15,109,53,-60,-99,-114,126,101,-125,88,125,38,19,-71,-111,122,-69,-21,-26,2,94,51,-111,-32,10,-87,41,114,-5,80,-46,59,111,16,46,115,-48,-5,-75,-122,123,-109,-70,116,-10,20,-44,-118,-67,17,41,16,102,-47,-31,-22,-96,-39,-1,-19,-98,30,-67,53,-53,-105,-9,24,15,-68,-53,77,-106,90,29,7,46,-30,67,-24,-101,-65,-66,-3,-118,-64,23,43,62,-27,-53,-7,45,-34,30,113,9,30,119,-12,-127,44,-114,-117,-12,-30,94,34,53,-91,-57,106,-38,37,-58,-97,90,116,-78,55,95,59,124,112,5,-99,-10,54,-3,-70,-110,108,-98,-75,110,99,88,99,-80,17,-77,26,123,-73,-26,120,77,-14,29,-61,78,97,-125,-39,19,80,105,22,114,-88,53,-54,-121,-7,92,34,10,101,-57,51,9,47,-124,-93,26,-76,38,70,50,45,-119,106,-51,-121,73,-68,59,121,40,78,92,23,-124,-73,67,43,104,-97,79,-31,15,75,-12,39,13,-99,75,-8,-62,-63,103,-68,101,-72,109,-123,-113,-93,47,-7,-51,64,-67,96,1,-81,34,-49,-66,-82,35,99,52,-95,28,27,-36,27,-93,-15,52,-68,55,-81,-104,117,67,-3,53,102,32,-5,-64,121,-31,-10,19,-123,41,-72,-97,113,45,-10,-111,-71,95,31,-89,-13,36,-111,39,86,126,10,-26,27,-91,48,-77,-45,-25,-106,126,-51,104,101,71,81,2,81,-26,-96,7,-114,-44,-94,-54,-22,110,19,-76,77,3,-127,-86,-78,110,6,-62,-96,121,-100,74,71,-3,-34,43,86,37,109,-110,123,56,118,-7,-33,-96,15,-60,75,-49,-23,-6,-34,57,60,117,-72,-82,-97,-104,88,30,-86,-55,111,-103,-121,-126,-63,-94,-103,-112,0,70,80,118,-46,-44,101,-85,28,85,52,91,-127,29,-88,-63,95,82,59,124,90,-86,-37,7,-116,75,72,-13,82,55,-125,-61,80,90,-75,41,-28,-41,-6,32,-62,35,88,91,61,-112,-104,-115,23,72,-102,-25,77,103,0,73,13,-121,6,81,-52,-70,59,63,113,-84,-85,-112,-9,113,-82,-52,98,-29,45,-25,59,-73,-78,-59,-96,-4,-32,-82,79,16,80,29,94,64,-7,67,-77,-5,-125,119,12,127,-9,104,-95,56,16,58,86,-117,18,66,26,-115,-55,48,59,126,-15,-90,-16,-126,15,120,75,-115,13,106,-76,80,-9,-15,-70,-10,50,-78,56,-51,110,85,-29,-102,20,15,-56,-73,-64,-23,-66,-12,-80,-128,-6,-121,-103,-6,-122,-97,40,46,-36,30,-2,-34,-2,32,116,-93,-59,-109,34,-79,126,-95,-120,-15,-40,-86,-64,71,-48,126,124,-2,-39,75,-64,127,57,30,-107,1,-74,-32,-105,-112,104,-115,80,-27,50,-86,-86,75,-13,-8,81,-13,-66,-38,-14,125,118,103,33,48,-71,10,35,-118,88,65,119,-36,-116,-107,-20,-43,-110,107,33,-27,15,-48,-119,46,-35,96,-75,88,-12,-7,90,-41,-6,-87,89,-88,-117,98,-29,-64,-41,-18,99,-83,13,61,-8,126,46,82,127,-81,-75,20,57,10,-36,81,54,-123,67,18,124,45,-55,95,50,-41,-38,-127,66,61,24,9,51,-55,113,-66,-80,28,49,-113,-71,24,113,-107,105,-71,37,47,-117,73,45,30,-74,117,114,26,6,-42,-80,-74,108,-81,110,73,88,124,-24,-43,-3,49,84,-55,-30,-125,36,102,62,-126,-45,-33,-50,98,-8,6,109,62,113,-84,-12,32,-40,24,-101,-87,-57,-56,59,-123,106,32,12,-71,-18,97,49,113,-47,105,-113,49,99,-124,-124,-81,-118,117,-12,-76,46,-9,-48,-41,-3,-54,-86,97,88,119,-82,-113,-52,-126,-93,-23,-121,127,-97,-28,-24,31,-62,-119,52,-93,75,7,33,-101,-67,67,-45,39,74,-83,127,-115,-66,4,-6,-18,-29,29,-23,68,-123,-103,31,24,117,49,8,-70,41,1,20,71,99,-40,-21,-116,-30,93,66,95,27,63,117,-49,20,-113,-92,-7,127,115,-85,97,-39,34,-67,-10,-53,123,-87,119,2,-77,68,-74,-66,22,96,-13,-12,96,-26,86,35,47,-128,-4,83,52,114,-2,-84,-14,67,-94,-53,-45,-74,-71,-94,94,-101,-122,3,-48,-14,124,-43,56,-3,58,-22,-97,-106,1,-32,57,-16,-127,51,23,-67,-59,-27,-60,125,-46,-125,-117,28,-74,29,29,-76,94,25,58,-32,-31,-101,-105,42,49,101,-115,-60,114,-55,-72,101,94,35,-14,-6,-115,-101,20,-36,-8,103,77,-42,82,61,104,85,35,-71,100,111,67,107,-90,-24,19,6,117,-87,-16,-67,-26,26,24,105,-64,102,105,-36,-7,60,109,112,-19,119,59,-81,10,-91,-9,69,124,-54,124,52,80,13,-105,21,-116,-114,-33,5,0,10,126,-93,22,-26,-115,115,94,22,105,-111,30,-7,102,44,63,0,85,-38,91,-30,98,-21,43,4,-63,-34,-124,-67,38,33,-2,45,-32,-86,12,-92,-38,29,39,121,-119,-42,-23,-30,-106,3,-12,-54,-108,7} + +#define UPDATE_GATE_BIAS {-85,78,113,70,33,38,8,114,70,-35,-67,65,31,-24,-70,-124,-89,104,124,-122,111,61,-87,75,-61,-98,83,-69,-63,45,-11,103} + +#define RESET_GATE_BIAS {-77,67,-93,-3,98,59,-121,33,49,50,41,91,-115,-33,71,47,-70,45,89,-115,72,106,-22,100,97,-100,-95,108,-33,3,14,30} + +#define HIDDEN_STATE_BIAS {-85,78,113,70,33,38,8,114,70,-35,-67,65,31,-24,-70,-124,-89,104,124,-122,111,61,-87,75,-61,-98,83,-69,-63,45,-11,103} + +#define INPUT_DATA1 {-367,-338,0,-89,453,-413,-343,-16,42,418,201,274,-352,477,-290,-92,266,-49,342,453,-398,247,-153,328,217,342,85,69,-38,351,73,128} + +#define INPUT_DATA2 {280,41,-322,61,315,350,504,-227,-221,-483,352,252,455,-236,344,364,-378,229,-187,-498,295,357,-511,58,-349,-458,-420,-66,-400,-379,477,-60} + +#define HISTORY_DATA {-38,53,105,-79,-463,51,-343,-226,-435,-282,218,441,-299,-215,-109,335,340,-471,-109,273,33,-245,-469,170,-26,-59,192,-119,76,-6,236,-145} diff --git a/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/readme.txt b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/readme.txt new file mode 100644 index 0000000..99cf676 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Examples/ARM/arm_nn_examples/gru/readme.txt @@ -0,0 +1,4 @@ +CMSIS NN Lib example arm_nnexample_gru0 for + Cortex-M4 and Cortex-M7. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/NN/Include/arm_nn_tables.h b/Chapter04/bare/platform/CMSIS/NN/Include/arm_nn_tables.h new file mode 100644 index 0000000..9357424 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Include/arm_nn_tables.h @@ -0,0 +1,59 @@ +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nn_tables.h + * Description: Extern declaration for NN tables + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef _ARM_NN_TABLES_H +#define _ARM_NN_TABLES_H + +#include "arm_math.h" + +/** +* @brief tables for various activation functions +* +*/ + +extern const q15_t sigmoidTable_q15[256]; +extern const q7_t sigmoidTable_q7[256]; + +extern const q7_t tanhTable_q7[256]; +extern const q15_t tanhTable_q15[256]; + + /** + * @brief 2-way tables for various activation functions + * + * 2-way table, H table for value larger than 1/4 + * L table for value smaller than 1/4, H table for remaining + * We have this only for the q15_t version. It does not make + * sense to have it for q7_t type + */ +extern const q15_t sigmoidHTable_q15[192]; +extern const q15_t sigmoidLTable_q15[128]; + +extern const q15_t sigmoidLTable_q15[128]; +extern const q15_t sigmoidHTable_q15[192]; + +#endif /* ARM_NN_TABLES_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Include/arm_nnfunctions.h b/Chapter04/bare/platform/CMSIS/NN/Include/arm_nnfunctions.h new file mode 100644 index 0000000..96c59c2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Include/arm_nnfunctions.h @@ -0,0 +1,1010 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nnfunctions.h + * Description: Public header file for CMSIS NN Library + * + * $Date: 13. July 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ + +/** + \mainpage CMSIS NN Software Library + * + * Introduction + * ------------ + * + * This user manual describes the CMSIS NN software library, + * a collection of efficient neural network kernels developed to maximize the + * performance and minimize the memory footprint of neural networks on Cortex-M processor cores. + * + * The library is divided into a number of functions each covering a specific category: + * - Neural Network Convolution Functions + * - Neural Network Activation Functions + * - Fully-connected Layer Functions + * - Neural Network Pooling Functions + * - Softmax Functions + * - Neural Network Support Functions + * + * The library has separate functions for operating on different weight and activation data + * types including 8-bit integers (q7_t) and 16-bit integers (q15_t). The descrition of the + * kernels are included in the function description. The implementation details are also + * described in this paper [1]. + * + * Block Diagram + * -------- + * \image html CMSIS-NN-OVERVIEW.PNG + * + * Examples + * -------- + * + * The library ships with a number of examples which demonstrate how to use the library functions. + * + * Pre-processor Macros + * ------------ + * + * Each library project have differant pre-processor macros. + * + * - ARM_MATH_DSP: + * + * Define macro ARM_MATH_DSP, If the silicon supports DSP instructions. + * + * - ARM_MATH_BIG_ENDIAN: + * + * Define macro ARM_MATH_BIG_ENDIAN to build the library for big endian targets. By default library builds for little endian targets. + * + * - ARM_NN_TRUNCATE: + * + * Define macro ARM_NN_TRUNCATE to use floor instead of round-to-the-nearest-int for the computation. + * + * Copyright Notice + * ------------ + * + * Copyright (C) 2010-2018 Arm Limited. All rights reserved. + * + * [1] CMSIS-NN: Efficient Neural Network Kernels for Arm Cortex-M CPUs https://arxiv.org/abs/1801.06601 + */ + +/** + * @defgroup groupNN Neural Network Functions + * These functions perform basic operations for neural network layers. + */ + +#ifndef _ARM_NNFUNCTIONS_H +#define _ARM_NNFUNCTIONS_H + +#include "arm_nnsupportfunctions.h" +#include "arm_nn_tables.h" + +#define USE_INTRINSIC + +//#define ARM_NN_TRUNCATE /* This config the rounding model to floor or round to the nearest int */ + +#ifdef __cplusplus +extern "C" +{ +#endif + +/** + * @defgroup NNConv Neural Network Convolution Functions + * + * Perform convolution layer + * + * The convolution is implemented in 2 steps: im2col and GEMM + * + * im2col is a process of converting each patch of image data into + * a column. After im2col, the convolution is computed as matrix-matrix + * multiplication. + * + * To reduce the memory footprint, the im2col is performed partially. + * Each iteration, only a few column (i.e., patches) are generated and + * computed with GEMM kernels similar to CMSIS-DSP arm_mat_mult functions. + * + */ + + /** + * @brief Basic Q7 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_convolve_HWC_q7_basic(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Basic Q7 convolution function (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns ARM_MATH_SUCCESS + */ + + arm_status arm_convolve_HWC_q7_basic_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Basic Q15 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_convolve_HWC_q15_basic(const q15_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Fast Q7 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 4 + * ch_im_out is multiple of 2 + */ + + arm_status arm_convolve_HWC_q7_fast(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Fast Q7 convolution function (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 4 + * ch_im_out is multiple of 2 + */ + + arm_status arm_convolve_HWC_q7_fast_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Fast Q7 version of 1x1 convolution (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function implement convolution with 1x1 kernel size (i.e., dim_kernel_x=1 + * and dim_kernel_y=1). It can be used for + * second half of MobileNets after depthwise separable convolution. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 4 + * ch_im_out is multiple of 2 + */ + arm_status arm_convolve_1x1_HWC_q7_fast_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Q7 version of convolution for RGB image + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This kernel is written exclusively for convolution with ch_im_in + * equals 3. This applies on the first layer of CNNs which has input + * image with RGB format. + */ + + arm_status arm_convolve_HWC_q7_RGB(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Fast Q15 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 2 + * ch_im_out is multiple of 2 + */ + + arm_status arm_convolve_HWC_q15_fast(const q15_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Fast Q15 convolution function (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * + * Buffer size: + * + * bufferA size: 2*ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * Input dimension constraints: + * + * ch_im_in is multiple of 2 + * + * ch_im_out is multipe of 2 + * + */ + + arm_status + arm_convolve_HWC_q15_fast_nonsquare(const q15_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Q7 depthwise separable convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 2 + * ch_im_out is multiple of 2 + */ + + arm_status arm_depthwise_separable_conv_HWC_q7(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB); + + /** + * @brief Q7 depthwise separable convolution function (non-square shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding sizes x + * @param[in] padding_y padding sizes y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 2 + * ch_im_out is multiple of 2 + */ + arm_status arm_depthwise_separable_conv_HWC_q7_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB); + + +/** + * @defgroup FC Fully-connected Layer Functions + * + * Perform fully-connected layer + * + * Fully-connected layer is basically a matrix-vector multiplication + * with bias. The matrix is the weights and the input/output vectors + * are the activation values. Supported {weight, activation} precisions + * include {8-bit, 8-bit}, {16-bit, 16-bit}, and {8-bit, 16-bit}. + * + * Here we have two types of kernel functions. The basic function + * implements the function using regular GEMV approach. The opt functions + * operates with weights in interleaved formats. + * + */ + + /** + * @brief Q7 basic fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_fully_connected_q7(const q7_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q7_t * pOut, + q15_t * vec_buffer); + + /** + * @brief Q7 opt fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_fully_connected_q7_opt(const q7_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q7_t * pOut, + q15_t * vec_buffer); + + /** + * @brief Q15 basic fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_fully_connected_q15(const q15_t * pV, + const q15_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q15_t * bias, + q15_t * pOut, + q15_t * vec_buffer); + + /** + * @brief Q15 opt fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_fully_connected_q15_opt(const q15_t * pV, + const q15_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q15_t * bias, + q15_t * pOut, + q15_t * vec_buffer); + + /** + * @brief Mixed Q15-Q7 fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_fully_connected_mat_q7_vec_q15(const q15_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q15_t * pOut, + q15_t * vec_buffer); + + /** + * @brief Mixed Q15-Q7 opt fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + */ + + arm_status arm_fully_connected_mat_q7_vec_q15_opt(const q15_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q15_t * pOut, + q15_t * vec_buffer); + +/** + * @brief Matrix-Multiplication Kernels for Convolution + * + * These functions are used within convolution layer functions for + * matrix multiplication. + * + * The implementation is similar to CMSIS-DSP arm_mat_mult functions + * with one Q7 and one Q15 operands. The Q15 operand is the im2col + * output which is always with 2 columns. + * + */ + + /** + * @brief Matrix-multiplication function for convolution + * @param[in] pA pointer to operand A + * @param[in] pInBuffer pointer to operand B, always conssists of 2 vectors + * @param[in] ch_im_out numRow of A + * @param[in] numCol_A numCol of A + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias the bias + * @param[in,out] pOut pointer to output + * @return The function returns the incremented output pointer + */ + + q7_t *arm_nn_mat_mult_kernel_q7_q15(const q7_t * pA, + const q15_t * pInBuffer, + const uint16_t ch_im_out, + const uint16_t numCol_A, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q7_t * pOut); + + /** + * @brief Matrix-multiplication function for convolution with reordered columns + * @param[in] pA pointer to operand A + * @param[in] pInBuffer pointer to operand B, always conssists of 2 vectors + * @param[in] ch_im_out numRow of A + * @param[in] numCol_A numCol of A + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias the bias + * @param[in,out] pOut pointer to output + * @return The function returns the incremented output pointer + */ + + q7_t *arm_nn_mat_mult_kernel_q7_q15_reordered(const q7_t * pA, + const q15_t * pInBuffer, + const uint16_t ch_im_out, + const uint16_t numCol_A, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q7_t * pOut); + +#ifdef __cplusplus +} +#endif + +/* + * Other functions + * These layers are typically not timing critical + * Basic implementation is supported here + */ + +#ifdef __cplusplus +extern "C" +{ +#endif + +/** + * @defgroup Acti Neural Network Activation Functions + * + * Perform activation layers, including ReLU (Rectified Linear Unit), + * sigmoid and tanh + * + */ + + /** + * @brief Q7 RELU function + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @return none. + */ + + void arm_relu_q7(q7_t * data, uint16_t size); + + /** + * @brief Q15 RELU function + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @return none. + */ + + void arm_relu_q15(q15_t * data, uint16_t size); + + /** + * @brief Q7 neural network activation function using direct table look-up + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @param[in] int_width bit-width of the integer part, assume to be smaller than 3 + * @param[in] type type of activation functions + * @return none. + */ + + void arm_nn_activations_direct_q7(q7_t * data, uint16_t size, uint16_t int_width, + arm_nn_activation_type type); + + /** + * @brief Q15 neural network activation function using direct table look-up + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @param[in] int_width bit-width of the integer part, assume to be smaller than 3 + * @param[in] type type of activation functions + * @return none. + */ + + void arm_nn_activations_direct_q15(q15_t * data, uint16_t size, uint16_t int_width, + arm_nn_activation_type type); + +/** + * @defgroup Pooling Neural Network Pooling Functions + * + * Perform pooling functions, including max pooling and average pooling + * + */ + + /** + * @brief Q7 max pooling function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] Im_out pointer to output tensor + * @return none. + * + */ + + void arm_maxpool_q7_HWC(q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const uint16_t dim_im_out, + q7_t * bufferA, + q7_t * Im_out); + + /** + * @brief Q7 average pooling function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] Im_out pointer to output tensor + * @return none. + * + */ + + void arm_avepool_q7_HWC(q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const uint16_t dim_im_out, + q7_t * bufferA, + q7_t * Im_out); + +/** + * @defgroup Softmax Softmax Functions + * + * EXP(2) based softmax function + * + */ + + /** + * @brief Q7 softmax function + * @param[in] vec_in pointer to input vector + * @param[in] dim_vec input vector dimention + * @param[out] p_out pointer to output vector + * @return none. + * + */ + + void arm_softmax_q7(const q7_t * vec_in, const uint16_t dim_vec, q7_t * p_out); + + /** + * @brief Q15 softmax function + * @param[in] vec_in pointer to input vector + * @param[in] dim_vec input vector dimention + * @param[out] p_out pointer to output vector + * @return none. + * + */ + + void arm_softmax_q15(const q15_t * vec_in, const uint16_t dim_vec, q15_t * p_out); + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/Chapter04/bare/platform/CMSIS/NN/Include/arm_nnsupportfunctions.h b/Chapter04/bare/platform/CMSIS/NN/Include/arm_nnsupportfunctions.h new file mode 100644 index 0000000..05a239d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Include/arm_nnsupportfunctions.h @@ -0,0 +1,202 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nnsupportfunctions.h + * Description: Public header file of support functions for CMSIS NN Library + * + * $Date: 13. July 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ + +#ifndef _ARM_NNSUPPORTFUNCTIONS_H_ +#define _ARM_NNSUPPORTFUNCTIONS_H_ + +#include "arm_math.h" +#include "arm_common_tables.h" +//#include + +#ifdef __cplusplus +extern "C" +{ +#endif + +/** + * @brief Union for SIMD access of Q31/Q15/Q7 types + */ +union arm_nnword +{ + q31_t word; + /**< Q31 type */ + q15_t half_words[2]; + /**< Q15 type */ + q7_t bytes[4]; + /**< Q7 type */ +}; + +/** + * @brief Struct for specifying activation function types + * + */ +typedef enum +{ + ARM_SIGMOID = 0, + /**< Sigmoid activation function */ + ARM_TANH = 1, + /**< Tanh activation function */ +} arm_nn_activation_type; + +/** + * @defgroup nndata_convert Neural Network Data Conversion Functions + * + * Perform data type conversion in-between neural network operations + * + */ + +/** + * @brief Converts the elements of the Q7 vector to Q15 vector without left-shift + * @param[in] *pSrc points to the Q7 input vector + * @param[out] *pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + */ + +void arm_q7_to_q15_no_shift(const q7_t * pSrc, q15_t * pDst, uint32_t blockSize); + +/** + * @brief Converts the elements of the Q7 vector to reordered Q15 vector without left-shift + * @param[in] *pSrc points to the Q7 input vector + * @param[out] *pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + */ + +void arm_q7_to_q15_reordered_no_shift(const q7_t * pSrc, q15_t * pDst, uint32_t blockSize); + +#if defined (ARM_MATH_DSP) + +/** + * @brief read and expand one Q7 word into two Q15 words + */ + +__STATIC_FORCEINLINE void *read_and_pad(void *source, q31_t * out1, q31_t * out2) +{ + q31_t inA = *__SIMD32(source)++; + q31_t inAbuf1 = __SXTB16(__ROR(inA, 8)); + q31_t inAbuf2 = __SXTB16(inA); + +#ifndef ARM_MATH_BIG_ENDIAN + *out2 = __PKHTB(inAbuf1, inAbuf2, 16); + *out1 = __PKHBT(inAbuf2, inAbuf1, 16); +#else + *out1 = __PKHTB(inAbuf1, inAbuf2, 16); + *out2 = __PKHBT(inAbuf2, inAbuf1, 16); +#endif + + return source; +} + +/** + * @brief read and expand one Q7 word into two Q15 words with reordering + */ + +__STATIC_FORCEINLINE void *read_and_pad_reordered(void *source, q31_t * out1, q31_t * out2) +{ + q31_t inA = *__SIMD32(source)++; +#ifndef ARM_MATH_BIG_ENDIAN + *out2 = __SXTB16(__ROR(inA, 8)); + *out1 = __SXTB16(inA); +#else + *out1 = __SXTB16(__ROR(inA, 8)); + *out2 = __SXTB16(inA); +#endif + + return source; +} +#endif + +/** + * @defgroup NNBasicMath Basic Math Functions for Neural Network Computation + * + * Basic Math Functions for Neural Network Computation + * + */ + +/** + * @brief Q7 vector multiplication with variable output shifts + * @param[in] *pSrcA pointer to the first input vector + * @param[in] *pSrcB pointer to the second input vector + * @param[out] *pDst pointer to the output vector + * @param[in] out_shift amount of right-shift for output + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +void arm_nn_mult_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + const uint16_t out_shift, + uint32_t blockSize); + +/** + * @brief Q7 vector multiplication with variable output shifts + * @param[in] *pSrcA pointer to the first input vector + * @param[in] *pSrcB pointer to the second input vector + * @param[out] *pDst pointer to the output vector + * @param[in] out_shift amount of right-shift for output + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x80 0x7F] will be saturated. + */ + +void arm_nn_mult_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + const uint16_t out_shift, + uint32_t blockSize); + +/** + * @brief defition to adding rouding offset + */ +#ifndef ARM_NN_TRUNCATE + #define NN_ROUND(out_shift) ( 0x1 << (out_shift - 1) ) +#else + #define NN_ROUND(out_shift) 0 +#endif + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM0/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM0/RTE_Components.h new file mode 100644 index 0000000..bf1d6d1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM0/RTE_Components.h @@ -0,0 +1,20 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_cifar10' + * Target: 'ARMCM0' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM0.h" + + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM3/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM3/RTE_Components.h new file mode 100644 index 0000000..6993e2a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM3/RTE_Components.h @@ -0,0 +1,26 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_nn_test' + * Target: 'ARMCM3' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM3.h" + +#define RTE_Compiler_IO_STDERR /* Compiler I/O: STDERR */ + #define RTE_Compiler_IO_STDERR_ITM /* Compiler I/O: STDERR ITM */ +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ +#define RTE_Compiler_IO_TTY /* Compiler I/O: TTY */ + #define RTE_Compiler_IO_TTY_ITM /* Compiler I/O: TTY ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM4_FP/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM4_FP/RTE_Components.h new file mode 100644 index 0000000..374579e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM4_FP/RTE_Components.h @@ -0,0 +1,26 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_nn_test' + * Target: 'ARMCM4_FP' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM4_FP.h" + +#define RTE_Compiler_IO_STDERR /* Compiler I/O: STDERR */ + #define RTE_Compiler_IO_STDERR_ITM /* Compiler I/O: STDERR ITM */ +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ +#define RTE_Compiler_IO_TTY /* Compiler I/O: TTY */ + #define RTE_Compiler_IO_TTY_ITM /* Compiler I/O: TTY ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM7_SP/RTE_Components.h b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM7_SP/RTE_Components.h new file mode 100644 index 0000000..40dfc78 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/RTE/_ARMCM7_SP/RTE_Components.h @@ -0,0 +1,26 @@ + +/* + * Auto generated Run-Time-Environment Component Configuration File + * *** Do not modify ! *** + * + * Project: 'arm_nnexamples_nn_test' + * Target: 'ARMCM7_SP' + */ + +#ifndef RTE_COMPONENTS_H +#define RTE_COMPONENTS_H + + +/* + * Define the Device Header File: + */ +#define CMSIS_device_header "ARMCM7_SP.h" + +#define RTE_Compiler_IO_STDERR /* Compiler I/O: STDERR */ + #define RTE_Compiler_IO_STDERR_ITM /* Compiler I/O: STDERR ITM */ +#define RTE_Compiler_IO_STDOUT /* Compiler I/O: STDOUT */ + #define RTE_Compiler_IO_STDOUT_ITM /* Compiler I/O: STDOUT ITM */ +#define RTE_Compiler_IO_TTY /* Compiler I/O: TTY */ + #define RTE_Compiler_IO_TTY_ITM /* Compiler I/O: TTY ITM */ + +#endif /* RTE_COMPONENTS_H */ diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref.c new file mode 100644 index 0000000..4aa6077 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref.c @@ -0,0 +1,71 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_convolve_HWC_q15_ref(const q15_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimention + const uint16_t ch_im_in, // number of input image channels + const q15_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel, // filter kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const q15_t * bias, // bias + const uint16_t bias_shift, const uint16_t out_shift, q15_t * Im_out, // output image + const uint16_t dim_im_out, // output image dimension + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ) +{ + int i, j, k, l, m, n; + int conv_out; + int in_row, in_col; + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out; j++) + { + for (k = 0; k < dim_im_out; k++) + { +#ifndef ARM_NN_TRUNCATE + conv_out = (bias[i] << bias_shift) + (0x1 << (out_shift - 1)); +#else + conv_out = bias[i] << bias_shift; +#endif + for (m = 0; m < dim_kernel; m++) + { + for (n = 0; n < dim_kernel; n++) + { + in_row = stride * j + m - padding; + in_col = stride * k + n - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += Im_in[(in_row * dim_im_in + in_col) * ch_im_in + l] * + wt[i * ch_im_in * dim_kernel * dim_kernel + (m * dim_kernel + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out + k) * ch_im_out] = (q15_t) __SSAT((conv_out >> out_shift), 16); + } + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref_nonsquare.c new file mode 100644 index 0000000..69efcb2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q15_ref_nonsquare.c @@ -0,0 +1,83 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void +arm_convolve_HWC_q15_nonsquare_ref(const q15_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB) + +{ + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out_y; j++) + { + for (k = 0; k < dim_im_out_x; k++) + { +#ifndef ARM_NN_TRUNCATE + conv_out = (bias[i] << bias_shift) + (0x1 << (out_shift - 1)); +#else + conv_out = bias[i] << bias_shift; +#endif + for (m = 0; m < dim_kernel_y; m++) + { + for (n = 0; n < dim_kernel_x; n++) + { + in_row = stride_y * j + m - padding_y; + in_col = stride_x * k + n - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + + l] * wt[i * ch_im_in * dim_kernel_x * dim_kernel_y + (m * dim_kernel_x + + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out_x + k) * ch_im_out] = (q15_t) __SSAT((conv_out >> out_shift), 16); + } + } + } +} + + diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref.c new file mode 100644 index 0000000..aaf25ba --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref.c @@ -0,0 +1,72 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_convolve_HWC_q7_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimention + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel, // filter kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const q7_t * bias, // bias + const uint16_t bias_shift, const uint16_t out_shift, q7_t * Im_out, // output image + const uint16_t dim_im_out, // output image dimension + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ) +{ + int i, j, k, l, m, n; + int conv_out; + int in_row, in_col; + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out; j++) + { + for (k = 0; k < dim_im_out; k++) + { +#ifndef ARM_NN_TRUNCATE + conv_out = ((q31_t) (bias[i]) << bias_shift) + (0x1 << (out_shift - 1)); +#else + conv_out = bias[i] << bias_shift; +#endif + for (m = 0; m < dim_kernel; m++) + { + for (n = 0; n < dim_kernel; n++) + { + // if-for implementation + in_row = stride * j + m - padding; + in_col = stride * k + n - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += Im_in[(in_row * dim_im_in + in_col) * ch_im_in + l] * + wt[i * ch_im_in * dim_kernel * dim_kernel + (m * dim_kernel + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref_nonsquare.c new file mode 100644 index 0000000..e731d07 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_convolve_HWC_q7_ref_nonsquare.c @@ -0,0 +1,78 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_convolve_HWC_q7_ref_nonsquare(const q7_t * Im_in, // input image + const uint16_t dim_im_in_x, // input image dimention x + const uint16_t dim_im_in_y, // input image dimention y + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel_x, // filter kernel size x + const uint16_t dim_kernel_y, // filter kernel size y + const uint16_t padding_x, // padding sizes x + const uint16_t padding_y, // padding sizes y + const uint16_t stride_x, // stride x + const uint16_t stride_y, // stride y + const q7_t * bias, // bias + const uint16_t bias_shift, const uint16_t out_shift, q7_t * Im_out, // output image + const uint16_t dim_im_out_x, // output image dimension x + const uint16_t dim_im_out_y, // output image dimension y + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ) +{ + int i, j, k, l, m, n; + int conv_out; + int in_row, in_col; + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out_y; j++) + { + for (k = 0; k < dim_im_out_x; k++) + { +#ifndef ARM_NN_TRUNCATE + conv_out = ((q31_t) (bias[i]) << bias_shift) + (0x1 << (out_shift - 1)); +#else + conv_out = bias[i] << bias_shift; +#endif + for (m = 0; m < dim_kernel_y; m++) + { + for (n = 0; n < dim_kernel_x; n++) + { + // if-for implementation + in_row = stride_y * j + m - padding_y; + in_col = stride_x * k + n - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + l] * + wt[i * ch_im_in * dim_kernel_y * dim_kernel_x + (m * dim_kernel_x + n) * ch_im_in + + l]; + } + } + } + } + Im_out[i + (j * dim_im_out_x + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref.c new file mode 100644 index 0000000..970effc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref.c @@ -0,0 +1,70 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_depthwise_separable_conv_HWC_q7_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimention + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel, // filter kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const q7_t * bias, // bias + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + q7_t * Im_out, // output image + const uint16_t dim_im_out, // output image dimension + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ) +{ + int i_out_y, i_out_x, i_ch_out; + int i_ker_y, i_ker_x; + for (i_out_y = 0; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + for (i_ch_out = 0; i_ch_out < ch_im_out; i_ch_out++) + { + // for each output +#ifndef ARM_NN_TRUNCATE + int conv_out = (bias[i_ch_out] << bias_shift) + (0x1 << (out_shift - 1)); +#else + int conv_out = bias[i_ch_out] << bias_shift; +#endif + for (i_ker_y = 0; i_ker_y < dim_kernel; i_ker_y++) + { + for (i_ker_x = 0; i_ker_x < dim_kernel; i_ker_x++) + { + int in_row = stride * i_out_y + i_ker_y - padding; + int in_col = stride * i_out_x + i_ker_x - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + conv_out += Im_in[(in_row * dim_im_in + in_col) * ch_im_in + i_ch_out] * + wt[(i_ker_y * dim_kernel + i_ker_x) * ch_im_out + i_ch_out]; + } + } + } + Im_out[(i_out_y * dim_im_out + i_out_x) * ch_im_out + i_ch_out] = + (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref_nonsquare.c new file mode 100644 index 0000000..8fa4147 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_depthwise_separable_conv_HWC_q7_ref_nonsquare.c @@ -0,0 +1,75 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_depthwise_separable_conv_HWC_q7_ref_nonsquare(const q7_t * Im_in, // input image + const uint16_t dim_im_in_x, // input image dimention x + const uint16_t dim_im_in_y, // input image dimention y + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel_x, // filter kernel size x + const uint16_t dim_kernel_y, // filter kernel size y + const uint16_t padding_x, // padding sizes x + const uint16_t padding_y, // padding sizes y + const uint16_t stride_x, // stride x + const uint16_t stride_y, // stride y + const q7_t * bias, // bias + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + q7_t * Im_out, // output image + const uint16_t dim_im_out_x, // output image dimension x + const uint16_t dim_im_out_y, // output image dimension y + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ) +{ + int i_out_y, i_out_x, i_ch_out; + int i_ker_y, i_ker_x; + for (i_out_y = 0; i_out_y < dim_im_out_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + for (i_ch_out = 0; i_ch_out < ch_im_out; i_ch_out++) + { + // for each output +#ifndef ARM_NN_TRUNCATE + int conv_out = (bias[i_ch_out] << bias_shift) + (0x1 << (out_shift - 1)); +#else + int conv_out = bias[i_ch_out] << bias_shift; +#endif + for (i_ker_y = 0; i_ker_y < dim_kernel_y; i_ker_y++) + { + for (i_ker_x = 0; i_ker_x < dim_kernel_x; i_ker_x++) + { + int in_row = stride_y * i_out_y + i_ker_y - padding_y; + int in_col = stride_x * i_out_x + i_ker_x - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + conv_out += Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + i_ch_out] * + wt[(i_ker_y * dim_kernel_x + i_ker_x) * ch_im_out + i_ch_out]; + } + } + } + Im_out[(i_out_y * dim_im_out_x + i_out_x) * ch_im_out + i_ch_out] = + (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_opt_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_opt_ref.c new file mode 100644 index 0000000..6fe5e2b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_opt_ref.c @@ -0,0 +1,120 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_fully_connected_mat_q7_vec_q15_opt_ref(const q15_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer) +{ + + uint16_t rowCnt = num_of_rows >> 2; + const q7_t *pB = pM; + const q15_t *pA; + q15_t *pO = pOut; + const q7_t *pBias = bias; + + while (rowCnt) + { + pA = pV; +#ifndef ARM_NN_TRUNCATE + q31_t sum = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum2 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum3 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum4 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); +#else + q31_t sum = *pBias++ << bias_shift; + q31_t sum2 = *pBias++ << bias_shift; + q31_t sum3 = *pBias++ << bias_shift; + q31_t sum4 = *pBias++ << bias_shift; +#endif + + uint16_t colCnt = dim_vec >> 1; + + while (colCnt) + { + q15_t inA1 = *pA++; + q15_t inA2 = *pA++; + + q7_t inB1 = *pB++; + q7_t inB3 = *pB++; + q7_t inB2 = *pB++; + q7_t inB4 = *pB++; + + sum += inA1 * inB1 + inA2 * inB2; + sum2 += inA1 * inB3 + inA2 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum3 += inA1 * inB1 + inA2 * inB2; + sum4 += inA1 * inB3 + inA2 * inB4; + + colCnt--; + } + colCnt = dim_vec & 0x1; + while (colCnt) + { + q15_t inA = *pA++; + q7_t inB = *pB++; + sum += inA * inB; + inB = *pB++; + sum2 += inA * inB; + inB = *pB++; + sum3 += inA * inB; + inB = *pB++; + sum4 += inA * inB; + + colCnt--; + } + *pO++ = (q15_t) __SSAT((sum >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum2 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum3 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum4 >> out_shift), 16); + + rowCnt--; + } + + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + pA = pV; +#ifndef ARM_NN_TRUNCATE + int ip_out = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); +#else + int ip_out = *pBias++ << bias_shift; +#endif + for (int j = 0; j < dim_vec; j++) + { + q15_t inA = *pA++; + q7_t inB = *pB++; + ip_out += inA * inB; + } + *pO++ = (q15_t) __SSAT((ip_out >> out_shift), 16); + + rowCnt--; + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_ref.c new file mode 100644 index 0000000..6a4d385 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_mat_q7_vec_q15_ref.c @@ -0,0 +1,43 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_fully_connected_mat_q7_vec_q15_ref(const q15_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer) +{ + for (int i = 0; i < num_of_rows; i++) + { +#ifndef ARM_NN_TRUNCATE + int ip_out = (bias[i] << bias_shift) + (0x1 << (out_shift - 1)); +#else + int ip_out = bias[i] << bias_shift; +#endif + for (int j = 0; j < dim_vec; j++) + { + ip_out += pV[j] * pM[i * dim_vec + j]; + } + pOut[i] = (q15_t) __SSAT((ip_out >> out_shift), 16); + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_opt_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_opt_ref.c new file mode 100644 index 0000000..475c757 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_opt_ref.c @@ -0,0 +1,119 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_fully_connected_q15_opt_ref(const q15_t * pV, // pointer to vector + const q15_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q15_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer) +{ + + uint16_t rowCnt = num_of_rows >> 2; + const q15_t *pB = pM; + const q15_t *pA; + q15_t *pO = pOut; + const q15_t *pBias = bias; + + while (rowCnt) + { + pA = pV; +#ifndef ARM_NN_TRUNCATE + q31_t sum = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum2 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum3 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum4 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); +#else + q31_t sum = *pBias++ << bias_shift; + q31_t sum2 = *pBias++ << bias_shift; + q31_t sum3 = *pBias++ << bias_shift; + q31_t sum4 = *pBias++ << bias_shift; +#endif + + uint16_t colCnt = dim_vec >> 1; + + while (colCnt) + { + q15_t inA1 = *pA++; + q15_t inA2 = *pA++; + + q15_t inB1 = *pB++; + q15_t inB2 = *pB++; + sum += inA1 * inB1 + inA2 * inB2; + + inB1 = *pB++; + inB2 = *pB++; + sum2 += inA1 * inB1 + inA2 * inB2; + + inB1 = *pB++; + inB2 = *pB++; + sum3 += inA1 * inB1 + inA2 * inB2; + + inB1 = *pB++; + inB2 = *pB++; + sum4 += inA1 * inB1 + inA2 * inB2; + + colCnt--; + } + colCnt = dim_vec & 0x1; + while (colCnt) + { + q15_t inA = *pA++; + q15_t inB = *pB++; + sum += inA * inB; + inB = *pB++; + sum2 += inA * inB; + inB = *pB++; + sum3 += inA * inB; + inB = *pB++; + sum4 += inA * inB; + colCnt--; + } + *pO++ = (q15_t) __SSAT((sum >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum2 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum3 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum4 >> out_shift), 16); + + rowCnt--; + } + + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + pA = pV; +#ifndef ARM_NN_TRUNCATE + int ip_out = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); +#else + int ip_out = *pBias++ << bias_shift; +#endif + for (int j = 0; j < dim_vec; j++) + { + q15_t inA = *pA++; + q15_t inB = *pB++; + ip_out += inA * inB; + } + *pO++ = (q15_t) __SSAT((ip_out >> out_shift), 16); + + rowCnt--; + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_ref.c new file mode 100644 index 0000000..3fd0bc0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q15_ref.c @@ -0,0 +1,43 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_fully_connected_q15_ref(const q15_t * pV, // pointer to vector + const q15_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q15_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer) +{ + for (int i = 0; i < num_of_rows; i++) + { +#ifndef ARM_NN_TRUNCATE + int ip_out = (bias[i] << bias_shift) + (0x1 << (out_shift - 1)); +#else + int ip_out = bias[i] << bias_shift; +#endif + for (int j = 0; j < dim_vec; j++) + { + ip_out += pV[j] * pM[i * dim_vec + j]; + } + pOut[i] = (q15_t) __SSAT((ip_out >> out_shift), 16); + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_opt_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_opt_ref.c new file mode 100644 index 0000000..cee8faa --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_opt_ref.c @@ -0,0 +1,138 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_fully_connected_q7_opt_ref(const q7_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q7_t * pOut, // output operand + q15_t * vec_buffer) +{ + + uint16_t rowCnt = num_of_rows >> 2; + const q7_t *pB = pM; + const q7_t *pA; + q7_t *pO = pOut; + const q7_t *pBias = bias; + + while (rowCnt) + { + pA = pV; +#ifndef ARM_NN_TRUNCATE + q31_t sum = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum2 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum3 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); + q31_t sum4 = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); +#else + q31_t sum = *pBias++ << bias_shift; + q31_t sum2 = *pBias++ << bias_shift; + q31_t sum3 = *pBias++ << bias_shift; + q31_t sum4 = *pBias++ << bias_shift; +#endif + + uint16_t colCnt = dim_vec >> 2; + + while (colCnt) + { + q7_t inA1 = *pA++; + q7_t inA3 = *pA++; + q7_t inA2 = *pA++; + q7_t inA4 = *pA++; + + q7_t inB1 = *pB++; + q7_t inB3 = *pB++; + q7_t inB2 = *pB++; + q7_t inB4 = *pB++; + + sum += inA1 * inB1 + inA2 * inB2; + sum2 += inA1 * inB3 + inA2 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum3 += inA1 * inB1 + inA2 * inB2; + sum4 += inA1 * inB3 + inA2 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum += inA3 * inB1 + inA4 * inB2; + sum2 += inA3 * inB3 + inA4 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum3 += inA3 * inB1 + inA4 * inB2; + sum4 += inA3 * inB3 + inA4 * inB4; + + colCnt--; + } + colCnt = dim_vec & 0x3; + while (colCnt) + { + q7_t inA = *pA++; + q7_t inB = *pB++; + sum += inA * inB; + inB = *pB++; + sum2 += inA * inB; + inB = *pB++; + sum3 += inA * inB; + inB = *pB++; + sum4 += inA * inB; + + colCnt--; + } + *pO++ = (q7_t) __SSAT((sum >> out_shift), 8); + *pO++ = (q7_t) __SSAT((sum2 >> out_shift), 8); + *pO++ = (q7_t) __SSAT((sum3 >> out_shift), 8); + *pO++ = (q7_t) __SSAT((sum4 >> out_shift), 8); + + rowCnt--; + } + + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + pA = pV; +#ifndef ARM_NN_TRUNCATE + int ip_out = (*pBias++ << bias_shift) + (0x1 << (out_shift - 1)); +#else + int ip_out = *pBias++ << bias_shift; +#endif + for (int j = 0; j < dim_vec; j++) + { + q7_t inA = *pA++; + q7_t inB = *pB++; + ip_out += inA * inB; + } + *pO++ = (q7_t) __SSAT((ip_out >> out_shift), 8); + + rowCnt--; + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_ref.c new file mode 100644 index 0000000..78c891c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_fully_connected_q7_ref.c @@ -0,0 +1,43 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_fully_connected_q7_ref(const q7_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q7_t * pOut, // output operand + q15_t * vec_buffer) +{ + for (int i = 0; i < num_of_rows; i++) + { +#ifndef ARM_NN_TRUNCATE + int ip_out = (bias[i] << bias_shift) + (0x1 << (out_shift - 1)); +#else + int ip_out = bias[i] << bias_shift; +#endif + for (int j = 0; j < dim_vec; j++) + { + ip_out += pV[j] * pM[i * dim_vec + j]; + } + pOut[i] = (q7_t) __SSAT((ip_out >> out_shift), 8); + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_nn_mult_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_nn_mult_ref.c new file mode 100644 index 0000000..e78850f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_nn_mult_ref.c @@ -0,0 +1,58 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +void arm_nn_mult_q7_ref(q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + const uint16_t out_shift, + uint32_t blockSize) { + uint16_t i; + +for (i = 0; i < blockSize; i++) + { + q31_t product = pSrcA[i] * pSrcB[i]; +#ifndef ARM_NN_TRUNCATE + pDst[i] = (q7_t)__SSAT((product + (0x1 << (out_shift - 1)))>>out_shift, 8); +#else + pDst[i] = (q7_t)__SSAT(product >> out_shift, 8); +#endif + } +} + +void arm_nn_mult_q15_ref(q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + const uint16_t out_shift, + uint32_t blockSize) { + uint16_t i; + +for (i = 0; i < blockSize; i++) + { + q31_t product = pSrcA[i] * pSrcB[i]; +#ifndef ARM_NN_TRUNCATE + pDst[i] = (q15_t)__SSAT((product + (0x1 << (out_shift - 1)))>>out_shift, 16); +#else + pDst[i] = (q15_t)__SSAT(product >> out_shift, 16); +#endif + + + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_pool_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_pool_ref.c new file mode 100644 index 0000000..b75a0a2 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_pool_ref.c @@ -0,0 +1,96 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ref_functions.h" + +void arm_avepool_q7_HWC_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimension + const uint16_t ch_im_in, // number of input image channels + const uint16_t dim_kernel, // window kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const uint16_t dim_im_out, // output image dimension + q7_t * bufferA, // a buffer for local storage + q7_t * Im_out) +{ + int16_t i_ch_in, i_x, i_y; + int16_t k_x, k_y; + + for (i_ch_in = 0; i_ch_in < ch_im_in; i_ch_in++) + { + for (i_y = 0; i_y < dim_im_out; i_y++) + { + for (i_x = 0; i_x < dim_im_out; i_x++) + { + int sum = 0; + int count = 0; + for (k_y = i_y * stride - padding; k_y < i_y * stride - padding + dim_kernel; k_y++) + { + for (k_x = i_x * stride - padding; k_x < i_x * stride - padding + dim_kernel; k_x++) + { + if (k_y >= 0 && k_x >= 0 && k_y < dim_im_in && k_x < dim_im_in) + { + sum += Im_in[i_ch_in + ch_im_in * (k_x + k_y * dim_im_in)]; + count++; + } + } + } + Im_out[i_ch_in + ch_im_in * (i_x + i_y * dim_im_out)] = sum / count; + } + } + } +} + +void arm_maxpool_q7_HWC_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimension + const uint16_t ch_im_in, // number of input image channels + const uint16_t dim_kernel, // window kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const uint16_t dim_im_out, // output image dimension + q7_t * bufferA, // a buffer for local storage + q7_t * Im_out) +{ + int16_t i_ch_in, i_x, i_y; + int16_t k_x, k_y; + + for (i_ch_in = 0; i_ch_in < ch_im_in; i_ch_in++) + { + for (i_y = 0; i_y < dim_im_out; i_y++) + { + for (i_x = 0; i_x < dim_im_out; i_x++) + { + int max = -129; + for (k_y = i_y * stride - padding; k_y < i_y * stride - padding + dim_kernel; k_y++) + { + for (k_x = i_x * stride - padding; k_x < i_x * stride - padding + dim_kernel; k_x++) + { + if (k_y >= 0 && k_x >= 0 && k_y < dim_im_in && k_x < dim_im_in) + { + if (Im_in[i_ch_in + ch_im_in * (k_x + k_y * dim_im_in)] > max) + { + max = Im_in[i_ch_in + ch_im_in * (k_x + k_y * dim_im_in)]; + } + } + } + } + Im_out[i_ch_in + ch_im_in * (i_x + i_y * dim_im_out)] = max; + } + } + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_relu_ref.c b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_relu_ref.c new file mode 100644 index 0000000..9397ef1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/arm_relu_ref.c @@ -0,0 +1,42 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +void arm_relu_q7_ref(q7_t * data, uint16_t size) +{ + uint16_t i; + + for (i = 0; i < size; i++) + { + if (data[i] < 0) + data[i] = 0; + } +} + +void arm_relu_q15_ref(q15_t * data, uint16_t size) +{ + uint16_t i; + + for (i = 0; i < size; i++) + { + if (data[i] < 0) + data[i] = 0; + } +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/fully_connected_testing_weights.h b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/fully_connected_testing_weights.h new file mode 100644 index 0000000..31cdcb0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/fully_connected_testing_weights.h @@ -0,0 +1,7 @@ +#define IP2_WEIGHT {18,-12,-120,-75,60,-92,62,106,43,43,-108,-80,78,76,94,13,-125,63,54,-121,-61,26,60,-125,-79,112,-45,-97,-59,-100,28,35,-15,26,-41,-65,-99,106,115,109,-20,-75,83,-106,51,-55,25,-126,15,-46,-73,62,-89,-15,-37,-79,-12,43,-30,120,46,116,113,11,-57,-81,113,-53,4,117,18,-31,101,65,125,60,76,91,-53,-63,-74,73,-47,-51,-87,-27,-126,-12,107,103,79,113,-41,93,124,122,-72,67,93,-103,-97,-61,62,-17,10,30,124,-119,-17,31,-60,4,88,-76,18,25,-109,-47,19,33,102,71,66,-42,-111,8,-4,-44,78,40,-19,107,-118,11,-105,-116,48,0,-73,-101,-55,-20,-81,71,-121,60,107,110,103,-28,88,-85,34,-90,12,-105,-21,-10,-115,118,-84,97,86,-67,-80,-43,-107,115,108,-49,-59,22,19,122,-76,82,-16,93,67,-100,-57,-41,-43,99,-1,-69,-79,54,-46,24,-59,-1,77,-94,111,-20,-35,108,54,3,107,-59,17,-112,106,-108,95,37,63,60,9,-65,-63,7,-118,-69,-48,111,120,40,44,63,-67,108,26,-37,127,96,-54,-1,21,88,-24,-112,-115,-27,-9,59,-89,22,109,45,47,-42,68,-72,94,55,-121,-23,-2,83,105,-18,104,-34,29,-80,58,-104,-6,-20,53,-86,-5,115,94,39,100,70,-70,-69,-121,-106,-43,94,83,120,121,-93,-97,90,0,-26,-87,6,-26,1,94,67,-26,-71,-21,64,53,35,-46,-102,-58,-103,-7,-34,15,-19,117,-27,59,20,111,-31,-31,43,-36,-19,49,94,-17,119,32,118,110,-19,121,24,30,-74,-12,-38,52,21,-38,98,-58,63,-115,-84,29,22,-93,63,-127,-113,56,25,-2,43,88,107,29,14,116,88,-24,115,-22,-14,-65,116,-119,-95,88,57,-64,18,-127,8,-123,-51,-80,75,-8,-98,2,-109,19,76,40,3,117,121,-4,61,92,-56,21,94,47,-32,24,-50,-38,-26,111,-61,118,-111,94,-14,-74,51,-38,-116,111,62,-39,-121,97,109,-45,-122,-37,-62,108,-74,73,34,59,-21,-20,37,-2,-102,45,121,-41,-116,80,-2,110,-52,-39,62,-12,-127,52,99,13,124,-15,-89,89,85,67,-119,110,-38,-13,-14,-53,-97,119,-121,16,14,-53,-65,-118,26,-4,19,111,-44,22,-57,81,110,-26,-70,45,55,-55,108,-122,-78,-34,24,-69,90,-48,-76,-80,-123,-49,10,113,89,58,119,68,-26,109,-35,-90,88,-90,-66,-24,78,-122,-84,82,76,93,106,123,-52,2,-19,-125,38,36,105,31,3,-99,-27,74,54,-29,8,40,30,-111,21,-118,87,95,58,-29,-117,84,-83,114,-75,96,64,94,-23,-44,46,-77,-82,62,104,74,26,-91,7,63,81,14,-27,33,41,31,-9,64,-19,60,-79,21,-120,49,26,63,-8,105,-116,-58,65,87,-38,-27,109,-97,-50,63,83,-70,111,32,-70,104,22,-123,74,-61,98,60,58,-13,-80,-37,-62,76,-82,-26,76,109,25,81,78,-104,96,-29,-9,-6,-46,-120,54,-33,-30,-108,41,22,110,-54,78,52,14,-40,-70,59,-101,-38,61,-122,77,46,116,-3,-21,-124,-23,41,80,83,29,-71,-43,9,101,77,35,-119,2,93,-30,22,-62,97,-12,29,40,41,36,106,-87,21,93,-41,-112,60,-100,81,91,-89,-10,79,-69,-7,-113,111,-47,51,-23,14,16,-56,98,26,-50,121,127,-104,39,-38,44,-22,-73,-69,125,61,15,-78,-119,-47,-15,-44,-90,-72,29,61,92,109,-10,25,-16,-49,-31,-109,121,5,-2,-125,10,53,80,-13,46,38,1,73,116,66,75,-18,-50,99,-44,-126,-60,-126,-26,-57,-121,-35,105,57,77,112,44,56,83,66,-94,106,60,-119,-124,-25,57,104,106,122,-52,-51,-38,68,47,64,-50,25,-64,-72,-127,73,124,-51,-96,116,53,75,-18,97,97,-96,-12,-16,46,29,105,-118,11,53,-31,-127,-98,-126,2,-115,-116,12,-47,-70,-106,-41,73,-115,-55,-96,126,-124,-41,-48,-43,-6,18,-107,-106,-59,86,-5,85,89,-17,91,-71,103,-116,-122,-80,99,-26,-87,-14,-4,-110,52,-44,-124,-47,15,104,-52,-16,18,62,92,-92,-81,101,94,38,45,-77,-103,-124,74,67,70,-113,25,25,-53,-125,124,33,-84,-119,118,105,-70,-101,-108,-48,111,118,-91,-49,38,102,105,24,56,-95,-119,-45,-96,88,33,126,-101,74,-30,17,-35,24,-23,123,47,-41,-82,91,-3,60,15,-4,46,38,49,-8,-35,82,28,110,8,-58,-108,-124,60,125,-5,49,31,69,-73,94,-25,75,107,75,-1,53,-32,66,20,121,-75,-39,-13,-84,120,15,8,-33,-46,-30,-121,-119,-17,73,-102,-36,103,-20,11,-62,-80,-111,69,-84,-37,38,82,-87,8,69,-110,80,66,-41,122,102,125,-90,72,109,-120,-25,-56,-43,-44,-93,48,63,-59,-30,106,85,-83,-68,44,112,-75,-61,-127,-4,21,-124,-79,-111,-65,68,0,-111,62,-14,41,27,53,68,69,102,-55,122,99,-5,-74,74,2,96,71,107,49,88,19,55,10,84,-124,2,10,-47,-66,-1,-61,-70,3,-101,37,113,120,33,3,18,3,52,-86,38,91,-88,-48,-115,104,-20,49,-25,26,-108,-82,86,80,-125,-86,-73,-109,-72,-49,108,56,-8,-103,-10,-115,-99,97,-120,15,-94,-52,90,-1,-39,-1,-2,89,-103,-69,-82,-63,-32,59,101,-23,-83,-67,-112,-23,-12,-47,-105,-85,-117,-9,-80,-34,-38,108,-77,89,112,-63,28,-69,70,-99,47,59,82,16,-89,47,-78,-21,-101,23,115,-98,-89,23,83,-113,-26,6,-15,101,-72,95,15,-116,46,107,117,67,-98,45,21,-30,10,108,120,99,-30,-91,-96,100,53,-62,-126,54,103,96,-20,-57,14,-128,123,-104,-7,-62,-49,-94,105,108,-104,52,5,-91,114,62,102,-103,10,84,1,30,-102,-17,-112,91,-115,14,1,54,-110,4,99,-10,-35,78,84,78,-66,120,-110,-29,-92,105,-96,118,64,81,48,-127,-32,-9,51,69,-31,40,-84,111,4,-123,-43,54,55,100,-61,19,33,-65,-50,-27,42,120,-66,-126,-17,36,107,2,53,80,95,-94,17,64,50,-25,29,9,-67,-101,-24,82,97,-53,-58,-119,-40,-10,8,-99,60,-29,79,-79,-43,-127,-73,26,-60,-26,114,-82,-19,-111,49,3,-54,100,67,45,72,-84,-50,-17,123,54,-94,-86,80,-9,-87,-51,-57,-32,-92,123,40,-93,-44,-61,-24,-128,-85,-52,-56,-52,51,32,-23,-108,-32,8,-69,9,-2,84,-36,24,126,-80,-73,3,42,20,30,-46,-29,25,89,-30,48,115,37,57,-47,-95,-100,-77,-38,-8,26,-37,-23,-31,124,65,67,-87,35,19,-80,107,-71,120,106,21,-28,69,24,-110,103,-43,-68,94,95,-105,28,-16,-49,-6,88,121,-36,-83,28,-101,102,-28,40,-7,-108,28,97,11,-98,117,80,2,-92,-62,-43,-67,113,74,59,18,-72,-124,-126,-52,102,-128,-14,125,-116,-40,21,82,13,-2,59,-111,-110,-125,-44,-94,109,111,49,-71,40,-52,1,2,-73,-62,-40,-30,-93,-43,25,-103,-94,-110,126,-112,78,32,24,-95,-121,101,25,95,66,-63,5,72,-61,-83,-66,-88,-57,118,113,-110,92,-44,-3,15,24,-14,-114,14,33,-76,-75,80,76,-110,122,-56,101,12,66,-89,21,-76,42,86,-49,77,65,97,127,-20,43,0,-117,115,9,-83,-27,119,15,-122,4,21,-47,72,-113,-68,-98,-124,-89,125,-90,-83,35,-74,79,101,-65,127,60,-118,104,73,44,-41,-111,79,54,-70,-52,-97,10,18,-17,91,-46,-72,3,-35,-23,44,84,-11,-17,-11,-45,-38,67,75,-100,3,54,-16,-22,66,-98,-79,41,-110,-49,-76,-6,-33,-109,30,6,-18,84,63,50,-119,64,-127,-79,101,-91,59,-87,-51,0,-18,-23,-102,-99,120,-28,123,-86,59,-81,-22,-13,43,107,-13,-92,78,95,-10,26,-108,36,-57,-44,-118,-93,-62,-77,-33,-6,-50,-122,-103,-20,57,24,3,-25,-95,-91,-47,74,14,20,16,23,52,78,-15,-17,69,13,-98,126,84,115,74,-125,23,62,110,34,124,-38,111,6,106,-24,82,53,-102,-53,-36,7,60,1,19,80,-26,-111,58,83,-76,-19,112,121,41,-45,69,112,-95,98,-126,68,-37,-109,-55,-70,77,-97,35,-61,12,-58,54,-36,93,-48,4,10,104,102,37,70,4,10,-18,33,26,0,60,69,-49,26,66,-114,-22,-72,-96,124,16,-6,-92,-52,83,103,96,77,-99,4,80,10,-119,-108,-117,122,39,-13,-72,-7,77,-91,58,111,3,29,52,93,116,-123,-16,44,-60,107,60,-57,83,15,42,33,-93,-16,60,-97,53,86,5,-76,120,-42,-88,-35,18,12,110,-4,-62,84,2,-46,-14,-99,27,96,96,-69,15,102,79,-84,-24,-7,-64,-49,107,-51,17,108,-3,-41,-104,122,-123,-2,-58,-69,-36,-69,-33,81,-78,12,0,11,-63,125,97,58,-43,-63,-49,48,73,-78,-87,-88,-94,94,97,56,-31,-27,-113,125,-128,-25,-65,5,67,71,-26,7,40,-115,-55,-119,74,-34,-111,-42,-77,-15,-80,41,71,-121,-62,54,-95,-76,122,-115,101,-80,36,82,-55,-25,11,11,105,39,-98,-80,-77,-45,-58,93,-118,64,126,124,-46,1,26,113,37,107,108,-117,-127,123,-17,-120,-64,-35,-99,10,81,2,55,-110,-122,-120,-3,-24,-11,109,126,72,60,-18,92,-79,32,84,2,103,-7,-22,-7,-2,-108,-40,-55,45,47,14,-77,-60,50,43,-98,67,-52,51,101,107,105,45,-24,52,93,46,-61,-45,-36,-63,-33,-33,50,-81,-30,38,-124,73,-106,-90,54,-116,-86,-77,76,-63,-5,121,-22,-79,-73,-87,29,69,68,5,87,-85,-36,43,124,0,-62,104,72,-98,-63,-90,76,88,52,12,107,63,119,-54,102,-30,80,-63,-50,51,-5,79,110,-101,-11,32,80,-90,-22,-28,78,42,-76,89,-22,74,111,9,-78,28,-76,-17,20,-113,44,99,-82,31,-94,40,42,-75,-10,57,27,41,-29,42,-104,127,-70,-119,115,-77,54,114,-5,89,-63,9,-51,-68,-117,99,13,-23,103,-30,-117,76,78,112,-118,-16,-87,41,-23,72,67,-4,-69,30,-16,-18,-97,-111,-93,-68,-104,-112,55,-92,123,52,-14,-78,3,69,61,-35,-108,68,88,87,-114,-81,-126,26,-94,-111,80,10,47,43,98,28,-115,-122,103,-88,20,-58,79,33,103,-48,118,102,6,86,35,52,126,123,-62,62,-37,-126,-52,65,84,28,127,49,120,-67,-80,-8,96,-60,-25,100,-47,-14,103,-79,-29,-11,75,-77,-29,-56,1,-88,75,39,-36,-12,-71,-77,34,-98,-35,-103,-89,-41,-106,-86,-56,-36,-119,113,-17,-1,118,48,-59,101,-9,-51,-117,4,-71,31,23,6,80,3,40,-52,18,103,-127,50,75,-102,-56,0,47,-16,29,-15,-38,-32,-10,97,60,-4,-77,-105,-38,115,32,-14,5,-57,34,-22,-125,107,-32,99,115,64,-114,-90,118,-101,-25,125,33,-98,105,-88,85,-121,-66,-62,-46,-108,49,-19,-15,86,-83,49,50,42,-25,-128,-3,-89,-107,99,-116,-101,-45,-44,5,-53,57,-96,107,-77,-119,127,-76,99,-94,45,59,-6,-1,6,108,-71,-46,-35,-3,-26,4,104,-106,23,-51,52,104,-67,-74,-38,-125,-107,-9,-24,-93,75,-123,80,-68,28,-98,-119,-69,15,91,105,-17,46,-110,4,76,39,106,18,23,-55,69,-77,7,105,-16,-19,53,38,-95,100,46,73,23,44,86,19,64,87,-28,76,-1,81,-59,-123,-39,70,127,-120,81,89,110,-27,-54,-92,36,70,-45,-3,-12,-72,88,-109,96,123,-80,26,101,87,-113,-100,-45,0,29,122,111,-86,-67,-104,-87,-6,-109,-49,94,110,-85,113,93,-49,-110,-48,67,-85,34,-60,50,89,-34,-1,-46,12,3,-74,-25,0,-23,-48,-100,-98,54,-126,101,95,68,127,-118,-22,9,-106,84,95,-124,-31,-90,-39,18,23,10,7,45,35,52,6,-102,37,40,-31,-9,-33,69,-95,119,-36,6,-124,-3,-100,75,-91,126,106,77,126,112,-72,-60,53,-127,90,-112,45,115,69,32,61,69,-82,56,80,-40,-115,50,-124,34,-13,109,35,-21,-19,-82,90,65,-93,10,-121,106,39,114,-81,10,-43,-58,91,-26,-88,125,-36,93,-19,70,40,121,-26,-124,-28,-28,-70,18,-94,-120,109,10,100,-19,96,-78,-26,62,127,60,91,-6,-52,-64,-52,34,-47,47,-85,-49,-2,-44,91,56,-100,90,-62,124,-113,-67,-127,-15,-67,-39,10,53,87,38,41,3,-58,83,14,36,109,13,57,32,-37,-97,-18,-4,3,5,-33,-31,-7,46,73,-1,-120,-117,33,-82,91,76,84,-35,-128,100,41,117,-102,126,71,-50,18,41,16,-109,117,-86,102,-36,56,-66,-77,-92,-67,-70,-66,75,49,98,53,-36,50,103,62,61,-15,61,11,-19,-51,126,79,14,76,32,-120,35,-21,106,93,66,-74,4,13,19,-18,68,-90,-91,55,93,27,68,70,-64,-97,13,-32,-112,65,-116,91,3,37,13,-77,21,-17,83,53,-56,69,-86,55,-107,-116,106,-49,2,-5,-59,63,124,16,30,-81,-27,-61,-60,65,92,103,72,39,-88,113,112,-31,-52,55,-46,53,-58,-50,50,51,57,-71,-112,-99,42,76,-33,58,2,115,-111,15,27,-49,114,74,-63,5,123,-108,-73,-56,8,-26,-122,-35,88,40,18,51,52,20,65,-35,-24,-41,-7,67,65,-47,20,8,-118,51,107,36,17,96,-108,-69,-40,-72,-61,-67,-17,-109,61,-26,59,-83,-31,10,-25,-62,-47,-113,65,46,25,13,86,-61,-14,113,-52,64,-100,0,110,34,-64,-35,-88,121,-84,81,46,33,-19,22,-23,106,49,40,4,-76,-89,53,110,86,-50,-71,-67,28,14,49,-123,-66,-18,66,-100,-83,111,101,54,18,-70,63,9,-48,-70,-115,-22,21,-71,-14,-74,65,-71,-2,-77,53,-62,-35,-127,-100,33,24,-5,-87,65,82,52,0,87,-37,20,104,-62,-52,31,11,29,-45,-58,-54,107,126,-119,-113,-47,-9,-72,-77,43,102,-116,-4,-79,-120,-90,79,-117,39,1,53,-91,127,123,41,-70,-104,38,31,-53,-85,-18,-127,45,18,13,-59,-5,-75,-110,1,24,-60,28,-110,58,-9,0,43,-104,92,-125,106,-91,-16,-75,-1,113,-115,-83,-95,66,-25,63,-120,-96,-26,101,51,83,27,47,-75,60,83,63,-58,-26,42,-88,-22,111,116,-72,-5,-65,-44,-78,-70,12,-109,95,-71,-27,125,9,-6,-72,104,-39,70,98,-38,48,117,67,-66,-117,-125,-89,49,-72,-71,127,-67,8,8,36,-76,-71,-105,-127,70,-100,-78,115,-84,32,38,78,26,85,43,62,-79,56,-78,113,-2,-12,-37,4,49,-17,123,-87,51,36,-90,-62,-27,11,47,73,-1,-37,18,75,18,19,-109,30,44,-96,91,-21,-115,-88,85,108,-17,-18,52,111,32,-88,108,66,-9,113,13,-117,-44,-49,15,-37,27,28,-57,-15,125,106,43,60,98,-21,-119,36,42,52,6,65,52,23,-39,60,-46,-61,100,50,116,111,8,-128,87,29,-27,-42,93,122,125,50,-82,45,95,-86,6,-10,21,-23,87,21,61,-14,-102,27,-64,43,8,3,-118,-97,-82,-66,-119,-82,56,-13,90,-109,-36,-116,-21,-42,64,-38,-55,-77,-14,-97,93,126,-10,77,39,-78,64,-39,46,-17,27,114,114,-88,80,-86,-88,-20,-121,-7,97,-20,100,82,-3,81,-108,-10,-40,53,-54,59,-103,31,-58,96,85,87,-76,118,-60,24,-41,78,84,38,-56,121,39,-101,55,6,103,40,-39,117,44,-26,-67,14,-33,-71,36,-38,-88,73,-5,28,-41,-21,-31,33,-53,82,93,54,-28,-63,31,-17,94,-48,-128,115,-62,-89,36,-28,-4,-48,75,-104,25,113,-76,-52,103,24,-96,-24,-44,107,-17,124,-95,-75,122,-64,122,51,74,121,106,-45,41,-77,-91,97,-17,87,111,106,-25,-38,-109,-87,-91,42,-71,-97,-111,-69,18,77,66,46,96,10,24,-89,16,-25,10,-1,-114,26,123,68,46,75,-115,44,-125,-121,-60,112,48,-110,-50,-10,-55,-10,75,4,-79,53,-84,99,98,-36,56,52,-66,67,-126,-77,29,-31,-88,-35,26,62,79,-79,-10,-114,-52,110,-21,-22,124,47,-114,-18,-101,-105,-44,-50,-114,-12,-104,-77,-38,-128,60,-81,-110,30,101,13,107,-57,-69,-40,14,-97,-50,-54,92,-60,59,127,-128,-95,95,-8,0,-119,83,24,-96,-106,-84,96,-29,14,-80,82,-120,-28,-116,-55,-78,-31,95,112,-82,68,92,-121,74,75,-62,24,-5,97,6,42,-123,-99,82,-82,-70,56,16,118,-84,66,111,80,-82,-15,-104,69,-12,-76,-23,-69,-55,-46,-48,22,79,16,-51,34,-115,64,23,-106,-77,71,-8,107,46,-22,34,-14,60,-80,117,-8,89,-108,123,25,-58,15,-25,64,-114,-19,69,50,95,-7,-95,120,98,106,-41,-31,-120,-127,88,71,53,41,-50,-68,-80,40,55,96,26,-8,-6,54,96,106,98,-60,-71,90,60,-17,48,24,17,-36,10,95,74,126,-123,51,79,118,115,69,-106,-78,65,121,77,96,78,-70,-49,91,27,-91,-51,62,53,-68,5,-96,-108,12,-45,79,-19,-80,-61,-30,-40,127,-117,77,83,22,116,19,-70,70,-95,95,-77,-120,59,24,-41,79,-100,95,-112,-22,89,-99,77,94,60,84,-5,112,55,-33,-92,63,88,-89,-88,-23,123,-20,-6,115,22,29,125,-46,65,-118,77,-50,94,-31,24,111,-107,63,19,-71,22,-69,-102,-26,-26,22,85,111,126,-55,46,90,-13,34,77,-5,61,43,-29,-60,13,114,107,19,-64,-107,108,-101,-63,103,51,32,-26,79,-115,-91,22,-120,-58,33,-83,-114,95,-48,-126,84,-112,-38,-38,54,-52,-113,46,111,-38,-111,-69,55,26,-43,-88,-81,94,-96,120,102,54,80,-68,-10,11,53,-68,102,32,-50,-60,50,20,124,-27,-57,15,87,-92,57,-50,51,49,-70,-124,32,-76,-51,-3,-38,22,-9,-18,102,-78,49,27,-96,-47,-9,89,-81,-39,37,-82,-70,-88,-104,46,95,31,-17,10,-62,-66,68,26,118,-104,-50,-50,-17,-108,24,-120,-88,22,-31,59,-7,-5,-15,75,101,-102,-17,106,57,12,93,-99,-105,24,51,-14,-7,107,-111,46,98,75,-8,-101,121,42,5,4,89,-110,-42,21,-14,-110,-46,49,-67,-64,-20,-85,72,41,-89,95,79,89,-97,43,48,14,121,109,-53,-50,35,-35,-103,12,-97,-111,-17,2,-89,28,-126,-36,-96,-98,71,-98,-9,74,-59,112,81,-89,-123,31,115,28,110,-20,-109,101,-107,-98,122,-101,15,47,27,-63,-19,85,-113,99,-67,109,-45,55,5,18,-97,31,117,-3,104,-8,11,24,-63,34,-86,42,-65,55,16,103,51,-82,-121,73,-61,104,76,-115,-92,30,86,-30,-110,-51,-115,-43,-108,-13,114,-89,-104,-51,-26,-112,-83,-29,79,8,112,-30,-47,94,71,-21,89,-38,7,-57,-70,105,62,-116,76,-12,95,-94,114,9,55,7,-46,-95,-105,96,61,24,88,25,-126,42,31,69,20,-93,-86,126,-79,97,39,87,-74,-104,-71,66,-83,87,-81,108,75,8,1,-121,120,-10,-1,-29,-47,-20,38,-73,67,7,52,-89,100,-57,92,9,-38,-58,-71,-112,-57,108,-121,-17,-127,-59,40,0,-69,-45,-98,115,-67,49,55,-76,-97,57,-94,-67,-60,97,-25,-13,-77,91,-54,118,36,-122,14,63,29,-66,-41,-87,2,9,-83,14,-42,34,25,-36,54,19,93,95,69,77,115,115,-67,-20,90,110,70,-83,-68,65,28,122,-51,102,-112,123,-55,-6,-88,42,76,-8,-96,127,117,-121,-97,36,62,120,90,-58,-89,79,56,-114,-1,62,69,-44,-96,-49,-18,102,6,-43,-9,-26,34,-127,83,-97,-74,-48,0,118,52,-66,42,-74,126,-89,-107,-37,-72,-114,64,-109,51,-2,34,-104,47,-122,-20,65,-48,24,81,2,-29,122,44,-11,61,27,11,114,75,21,18,22,39,114,-46,-109,124,-41,59,-99,-28,55,53,24,77,-63,51,118,122,101,-48,11,71,91,18,37,-41,-86,65,-69,-48,15,-101,-2,-43,122,20,-102,-58,-97,-88,25,3,47,22,-91,51,37,-14,70,118,-2,-47,25,49,111,45,83,15,-70,-96,8,23,112,-8,-79,-89,49,68,-35,118,101,-1,39,11,-51,98,-5,-67,-64,52,-41,-128,-128,30,-128,74,113,-85,-25,30,-22,2,127,-20,13,-85,-92,-32,-4,-21,31,-105,3,-47,22,35,5,29,-82,126,62,83,-28,-4,-94,93,-93,-120,44,16,19,-67,-70,5,-31,-100,85,80,30,123,-89,-9,52,2,87,79,105,45,82,-93,-46,99,-110,87,-13,-4,-52,19,7,17,54,-92,-118,-127,-24,71,-79,55,-102,0,30,-71,-42,-6,-112,-78,-55,85,29,-32,-103,-54,72,27,-76,-95,30,-7,-6,67,112,76,-79,84,-56,7,-84,85,33,-86,-39,-77,-27,103,100,99,-43,105,68,12,85,44,-92,76,-109,31,20,27,-28,-39,78,30,94,46,-28,-79,76,-103,-26,25,52,-21,-79,9,26,-26,-84,-17,-102,15,-120,70,-100,89,55,-3,-125,-80,-65,-27,89,-41,74,-8,-63,77,99,-9,-9,89,87,74,-101,-44,-16,112,100,102,9,-47,-40,-41,15,-53,-88,59,-44,93,-8,-51,26,76,-54,21,102,94,23,-81,9,110,-125,-76,59,-45,22,-78,72,19,98,127,21,-113,12,62,-80,-27,-21,58,-38,7,-112,-109,-111,-123,32,73,-29,-65,8,23,20,-58,106,-101,-30,20,-93,-36,-38,48,31,57,-26,-76,-93,93,-33,-99,12,25,-68,64,-90,120,-86,82,-102,103,-11,56,-96,104,3,101,83,-82,8,36,-38,-72,98,-94,112,-112,-83,-60,-123,125,86,96,64,17,89,113,34,2,68,51,-85,109,-92,102,50,64,-57,-64,114,66,-37,-120,-32,-102,96,-38,-90,-114,-81,46,-15,108,72,19,118,-98,64,33,-58,-93,-13,70,-93,41,67,93,-61,99,-53,88,-79,-64,-85,48,-67,56,-54,-46,58,2,-14,58,-127,-72,73,34,-12,-50,-50,31,48,-75,33,-89,-7,-93,-76,-95,-96,-52,85,122,35,-14,73,-30,-107,-112,127,-22,74,85,-127,44,13,-78,-85,-63,-86,-121,-58,126,-117,71,113,59,-95,117,41,48,-73,2,-89,34,18,-3,90,112,15,-26,-5,69,46,-24,99,-6,35,38,-33,-55,52,104,53,77,-114,-37,43,-36,-70,114,36,88,-43,-81,53,-99,75,108,-70,92,99,-6,102,-80,-128,-112,119,-107,-22,36,27,123,105,-80,76,-103,83,127,20,-7,14,-52,76,-23,-128,123,63,-65,-111,-53,25,100,-6,40,40,34,-42,-25,-44,-40,8,-36,-46,84,41,-123,106,117,-89,69,-53,-33,-58,-41,90,-114,-68,26,-80,-124,8,-77,92,-49,103,-48,-27,-77,-50,-96,-113,-6,55,-5,-60,106,112,-6,-111,-89,-127,-38,-33,99,83,-88,113,-2,-23,-73,-7,-88,-49,76,69,-42,35,46,58,-96,67,29,84,117,52,-97,93,-113,64,123,-90,-104,109,-41,-26,-50,-48,85,-52,41,104,-20,38,45,25,-105,37,85,15,-92,79,-23,81,-125,-40,-49,18,1,-124,-34,-125,59,-97,65,68,93,64,38,-5,-31,-59,-74,43,-104,-62,-100,95,14,-85,-60,-56,-37,37,116,27,41,106,63,124,64,75,109,72,47,44,-128,-119,60,28,105,58,20,-104,-35,-98,63,118,-61,-11,-28,32,-97,92,57,114,99,47,-80,92,39,-115,-55,-35,-57,-79,4,-113,28,43,124,-31,-119,-83,56,101,-114,-53,116,-102,-126,-73,-124,-97,46,83,-17,49,-17,-13,96,23,3,-60,-93,-73,23,4,-35,-119,-71,5,-118,30,-51,71,112,121,-95,97,23,-37,47,55,102,-6,17,107,-16,-70,124,-81,28,-5,71,77,-70,43,20,71,44,-72,-125,88,123,32,40,-27,98,62,-6,35,47,49,-74,20,-56,-112,82,-50,22,113,82,-11,102,-67,114,-6,-41,123,41,-73,-102,-65,-97,-39,-41,70,-25,-21,96,58,74,119,-125,-112,-101,-57,87,116,-29,-25,-79,24,8,-83,17,76,-28,40,25,80,-59,-77,61,-50,41,69,-21,38,-56,61,26,114,32,49,50,-47,5,-53,29,-43,41,-5,-80,38,-112,49,49,-26,-34,-54,-95,50,103,16,95,28,-31,-126,-31,-2,-48,74,122,-83,-73,-22,-122,89,52,-12,13,18,117,-80,52,-36,88,-57,-37,32,-107,33,-55,15,78,80,23,-30,-44,126,125,124,12,125,73,-3,-8,37,-15,8,29,70,73,92,19,63,-5,24,-123,60,53,-14,-27,-92,20,-12,-38,49,-43,9,-118,111,39,110,50,-16,98,-85,21,23,30,-9,93,-96,77,52,-107,-58,-19,-72,69,21,-127,-43,-43,19,-39,121,-103,-125,58,-105,2,90,92,-49,-74,-95,-52,119,81,38,-13,-63,11,112,-2,125,-34,-82,81,13,65,-43,-88,-74,5,17,-112,-41,26,60,-71,58,-93,-92,-75,-65,-24,-49,119,55,-118,-4,125,34,7,97,20,60,-3,105,-44,-111,-96,-73,53,-79,-83,-53,59,33,-20,-3,-89,117,59,98,-104,-43,-48,19,100,60,-125,76,58,-125,94,78,-40,23,-49,46,85,45,-108,-126,-108,-19,-101,-27,-68,-111,-16,-62,-4,123,18,98,-82,110,-81,-41,-120,76,-41,-76,123,21,-55,58,-24,-86,-125,-94,-37,-127,-77,31,108,-2,30,-24,123,116,10,-16,104,-111,-68,80,-113,62,-64,64,-78,-81,127,101,125,-15,-54,87,-48,-108,86,-119,-55,52,122,-118,47,-121,59,-84,-45,54,-97,-72,94,-38,114,-105,8,-53,-61,69,-113,-27,-30,75,-37,13,-51,24,-49,-122,12,97,111,29,68,-111,-35,21,50,-9,-105,-94,90,43,52,-80,0,-100,61,100,-68,-89,103,-52,-105,29,-128,109,-32,52,-88,77,59,6,38,69,-31,-110,-85,102,112,93,-64,-79,-51,-117,70,11,-51,100,102,-120,-48,79,123,-86,-32,5,5,-108,116,111,-34,-47,-90,79,-17,40,-59,-85,95,-69,-9,42,12,-77,54,-75,-3,68,-128,-88,-32,118,-126,19,20,56,118,-84,-30,-87,87,99,-19,-125,-62,-31,123,-19,-56,-83,21,87,1,-38,-96,73,-30,20,22,95,35,45,87,-61,48,10,80,125,122,24,33,27,37,85,-30,-54,-99,-7,-75,68,-63,-28,-22,14,-84,82,-89,-17,-82,-63,123,-76,77,107,89,-46,49,-69,-88,96,48,5,73,122,33,-16,67,-67,-92,-33,87,-68,113,-23,-45,93,69,-128,-8,-39,87,-91,-104,-76,13,71,-17,-20,-128,111,80,-43,55,34,110,85,-128,-111,48,-109,102,-52,-93,-26,-25,-88,90,81,123,88,-119,-54,63,-96,3,-13,-40,-48,-41,-79,-10,86,69,-62,65,105,-116,49,-107,-98,-38,23,-76,120,86,-74,-69,119,19,-58,-13,100,23,-121,-4,-85,-85,-41,93,117,-52,-75,89,119,55,-13,31,98,-51,110,18,-17,4,73,90,106,99,86,74,-80,45,-18,102,74,-83,-119,124,75,-72,-18,-27,93,-9,-77,-65,-33,86,-76,-94,-11,29,63,-69,-106,-115,107,81,9,-117,44,77,-4,-36,-109,-78,-40,-94,-79,15,-59,40,42,117,44,-44,-51,71,124,-65,73,-46,59,-61,59,45,-56,-95,-96,16,10,-28,-94,120,67,-92,86,-86,-43,-7,-95,112,-37,74,55,-21,-75,-112,97,-20,73,52,-53,-59,-120,71,-40,58,91,85,77,49,-15,-82,-86,-39,-67,-122,-91,-118,-30,-36,-7,50,-89,93,30,17,-99,-104,107,-76,8,-37,-14,101,-15,83,92,101,-82,-46,-91,45,-74,-122,-70,-93,-41,-50,-38,120,-17,-106,-118,98,80,-49,-70,-52,13,-29,39,-119,55,62,-43,-82,-40,-89,-59,112,-120,40,8,9,-81,-62,-6,84,-63,80,-2,-82,-17,-47,100,-64,100,5,13,-128,-81,-122,100,87,29,-100,-49,6,53,-103,52,86,4,-41,17,-126,63,16,79,-89,92,-123,120,34,-102,77,90,-65,-62,101,-36,63,-19,-125,113,-18,-120,-85,-50,55,-34,-69,101,-108,-46,106,-31,12,37,21,-53,-64,122,121,-73,109,-74,-74,-110,-122,54,6,31,114,-20,-63,-25,111,69,119,80,-24,-25,87,-11,-113,-76,-103,111,10,2,94,-22,124,-117,90,52,-85,92,15,-76,-24,-74,102,-57,-47,86,-77,67,-110,95,64,-118,-84,-113,-1,-123,5,5,-108,-28,-33,47,20,-126,58,-45,34,-128,57,-44,-23,-124,123,-13,-125,-87,-75,-60,-124,125,-127,-105,-77,63,-103,122,-3,-106,-99,51,4,65,-115,105,-115,98,-36,32,110,-24,-33,84,76,10,29,22,-85,45,-126,-108,30,-56,-121,47,-121,-114,82,-34,-21,-107,-46,60,-78,29,2,-87,109,-68,-25,-84,80,106,-62,-64,-73,-72,42,29,-46,10,-43,76,-12,-121,-5,39,86,73,74,-32,-115,-99,112,-10,-68,-38,-18,103,22,-122,-119,-52,-76,-124,13,127,47,1,-29,26,-108,-17,-86,52,-28,-81,-35,-1,-99,68,94,12,97,-24,-98,70,63,-96,-58,-37,105,-48,-62,107,-113,12,121,42,105,-7,112,86,-18,116,117,82,123,-54,2,-110,76,-118,54,57,82,68,92,22,76,-109,96,-71,-88,56,81,108,-8,76,-98,-104,-80,-116,77,-44,16,1,-103,-127,32,-25,-109,-127,-6,83,123,33,56,38,8,4,89,40,-116,77,-109,28,12,-88,89,-65,-27,-87,22,-37,62,23,68,15,30,-43,-49,-42,-32,-74,-11,104,-24,-78,-20,50,-9,96,-73,90,116,-68,-43,47,2,-84,-115,2,-39,3,-17,-21,-114,-104,38,114,-68,23,-97,-96,-25,68,-39,93,80,-117,-27,-96,-21,23,-50,-109,44,75,38,-8,-16,-99,-110,-29,34,-128,117,-4,53,-77,-110,-35,77,100,-117,-4,-101,-40,108,-86,65,-44,15,-63,-83,80,-50,34,-61,113,18,-29,-31,25,-128,-4,-105,89,120,3,-107,-29,31,-38,26,102,-7,-6,-34,-44,-2,25,-23,-30,108,25,124,100,-48,-46,-60,-71,62,-118,-89,58,-73,96,-128,73,-87,-99,63,-24,124,-86,38,34,-51,27,-71,53,117,99,-7,121,-9,-35,-108,-64,-105,99,-42,-6,72,-22,-19,36,107,-109,90,-27,32,-112,76,106,-81,-63,-57,-29,-11,-24,-118,77,-80,111,-52,48,-37,123,67,-124,-64,-101,34,100,-62,-37,113,-68,122,43,112,-86,-110,64,-33,-17,29,38,-90,107,40,-58,91,23,64,58,-101,94,-22,78,-36,48,-8,-49,28,15,-90,36,103,45,127,-89,-84,-56,-27,103,45,-112,121,104,-13,118,24,-84,-66,122,121,12,-78,-2,22,-59,92,7,116,92,-115,62,-3,-126,-24,113,122,-71,0,-68,-105,59,-62,18,110,-24,13,48,50,8,19,64,-127,74,-46,-86,-99,14,-115,-18,-124,-42,51,-27,-26,-119,-99,97,82,-47,47,117,78,-59,-109,-13,-61,-49,12,-86,-91,47,-64,-71,-79,67,-33,56,6,-33,-29,-76,-16,95,94,-76,-72,45,27,-117,-99,27,-37,47,-58,69,-90,100,107,23,-44,-76,-50,-9,113,20,44,121,-125,100,43,81,45,-66,104,-65,-31,-54,-81,-13,20,-54,-23,-35,37,44,78,61,-102,-106,46,-79,-52,-59,57,-18,28,81,-110,-94,44,83,-43,-51,19,-78,7,80,99,59,-61,100,21,96,100,-55,-108,-90,-41,94,-37,53,14,48,116,-4,111,-9,-32,88,-61,-15,79,36,-55,67,-35,38,13,-82,-61,-61,-70,14,34,30,-99,4,-29,41,-94,14,-58,45,90,-24,-63,54,3,110,113,-18,36,-5,39,82,121,-101,-81,107,-57,-4,-51,114,-77,105,-82,-15,83,-53,44,14,51,-58,-44,106,-79,-21,-106,-47,114,-91,-76,-55,81,-128,94,118,90,2,116,-69,103,14,-62,-35,-32,127,117,77,87,-115,-16,-3,-104,-67,-39,-91,61,-5,-34,-62,102,-123,89,-38,111,-2,92,-29,-2,-66,124,107,98,-74,-93,-58,-65,-103,-38,-23,88,82,99,76,67,56,-62,-121,-17,-80,-77,-4,-45,77,-85,-75,116,7,0,76,71,-104,-70,98,-66,26,44,27,63,-44,-97,-13,37,-7,8,-125,11,100,47,77,112,73,67,68,-96,23,-35,48,-56,-11,29,-78,116,-72,123,39,-21,10,-21,47,18,40,-7,-8,1,-50,18,35,-103,-99,-49,7,-10,84,34,-11,-62,-105,38,-55,-101,-46,-103,-3,44,-90,-78,-71,-103,70,-60,-93,59,48,3,60,11,-112,-44,88,102,52,-77,-90,46,101,47,32,-19,-78,8,-36,-66,60,-71,39,-100,103,127,-95,109,11,87,-71,-106,-118,72,73,119,37,-41,68,-41,38,-84,110,-63,77,112,72,-90,63,125,76,46,95,101,95,8,18,77,2,2,114,99,-88,65,13,48,11,28,99,32,101,-94,84,19,-48,4,5,-26,105,-14,-36,68,-20,-43,8,28,-98,97,-89,-47,102,-67,-41,49,20,50,-118,-121,-74,82,-68,81,102,7,99,-89,85,2,71,9,-104,124,81,-110,17,73,-32,81,-15,7,119,116,-26,-12,39,-43,96,-68,3,-88,-93,-56,-36,66,77,102,-80,1,-44,-81,63,83,-80,29,56,-124,-60,80,96,126,-74,53,-16,-117,6,52,-57,45,20,2,-33,34,27,-16,21,127,76,-105,56,68,6,-26,-21,35,-108,46,10,-58,80,-100,-77,63,-10,111,71,-22,-3,95,104,-90,-38,-11,-104,-31,111,-113,26,-4,-2,-30,-2,58,100,-112,49,-76,101,-40,-106,-45,-126,39,-24,5,-97,-90,-84,-113,-77,-18,41,63,-25,42,16,-85,90,-4,-80,-2,-117,21,-75,-35,28,-118,-20,45,83,88,122,30,-78,-127,54,-13,96,34,9,103,-88,92,120,-59,-87,48,86,116,-36,-38,-65,103,104,-70,-1,90,66,-35,71,-54,-7,-107,-3,-78,-49,-105,-87,82,22,29,-3,-13,23,108,87,-65,-39,78,37,-13,-19,59,6,83,118,85,3,58,5,-113,-23,-47,58,83,25,-85,-80,87,86,84,-75,-111,106,-89,-17,71,32,-81,106,-30,-125,-50,95,-74,-14,-86,-78,102,53,-66,89,95,-35,39,-83,32,-86,-56,103,71,110,-79,-97,-107,-24,29,-19,84,103,87,48,-13,-14,-40,17,-64,-74,21,74,-29,2,53,-84,4,-113,50,66,92,26,5,34,9,-126,109,67,19,116,85,-87,-53,12,-99,87,63,100,-80,-62,85,-99,60,-6,-80,-59,17,-56,-111,-7,-114,21,-13,-110,-115,112,70,-70,-40,-47,64,87,74,59,52,-96,-79,-61,12,32,-119,57,80,27,89,16,-95,-78,23,90,-14,-42,-117,-49,40,-2,-122,-94,-47,101,-47,43,-94,22,96,7,-7,30,78,-110,-19,-66,-86,4,-83,118,-105,83,46,-104,75,88,20,-82,-106,-80,-71,52,121,117,-39,77,3,105,-112,49,54,15,33,61,-48,6,-76,2,-101,-54,8,-50,-36,-105,-55,126,2,76,10,95,44,-85,-53,3,-75,-42,-102,6,-70,-9,88,91,33,84,-18,-28,21,33,-65,-97,-87,73,103,-96,-67,93,39,-58,-49,92,-48,-75,54,61,123,-29,-68,16,-84,-90,14,-84,-100,-37,82,57,-61,84,63,101,9,-97,-124,-31,102,98,-57,-77,26,-110,-16,102,119,80,-38,-54,-35,-45,-115,-114,123,-35,-99,111,-52,10,-99,-112,-16,99,30,-50,109,-66,70,48,-62,-45,37,-25,125,22,19,54,61,116,-52,108,70,120,9,-56,71,-8,-64,-5,-99,-7,65,-60,23,13,79,-63,-79,96,22,89,61,-41,-51,51,88,-61,-12,45,15,-71,-9,51,29,-105,-82,33,13,-29,-73,43,123,33,-86,-90,41,106,10,-124,52,11,114,82,-60,30,-47,-118,-6,117,-33,-5,1,-57,0,-60,27,-17,21,46,-83,-121,98,-59,92,4,-21,-109,-88,75,-40,80,97,-32,9,127,-2,-15,109,17,-55,-53,-94,65,79,64,-29,-24,-123,-121,-109,-99,-43,10,-111,-79,-124,68,-55,-83,-85,103,112,-122,-101,29,0,97,-61,-67,95,10,-86,53,-42,-119,12,-42,-24,20,3,123,87,74,-12,-102,105,-6,85,10,116,24,40,96,-5,-7,19,43,-104,121,32,7,-6,16,91,-70,80,39,62,44,29,-114,68,51,50,-51,17,-120,27,-52,-43,109,49,0,-13,74,26,83,-44,-108,96,99,5,-33,-69,-35,-80,47,-13,-117,-65,-78,110,61,-75,107,88,-100,-55,-64,-73,-29,65,26,-86,77,-54,127,-56,-77,61,65,10,-18,-57,28,2,-63,125,-116,88,12,-112,106,78,-36,4,-98,63,-57,83,-32,40,-19,-72,36,-59,3,10,-114,26,-1,-87,32,-36,13,8,-112,124,-50,-1,-28,-47,63,10,-28,69,-42,-101,15,-89,19,59,-76,115,14,68,-83,68,-2,-19,19,-93,31,61,29,116,121,-80,-84,115,69,75,-22,68,-51,-27,-106,105,-109,-48,-65,54,123,100,-13,-110,-79,103,-28,10,124,91,114,95,13,39,-34,-101,-128,-121,-18,-35,-102,101,-127,74,-107,-100,-19,-84,-56,-33,109,-48,29,-65,-86,-26,-111,-119,113,-35,-95,-24,125,-85,-105,9,-76,2,11,90,22,48,44,-2,76,-11,72,91,-93,79,-28,92,-39,-23,50,-34,91,56,-101,-86,3,-113,53,46,52,-108,25,57,117,-108,-59,105,-127,-108,65,-92,15,-71,-23,114,108,120,-36,77,-23,54,-100,-65,112,118,69,-118,-78,-43,-56,94,-47,30,-49,-111,-17,-109,-105,-41,-25,-80,-38,111,40,11,112,-95,-68,-13,-103,-46,-91,108,32,52,-76,-30,39,-52,-57,-15,-63,-48,-23,-57,27,29,117,-74,-112,20,109,24,4,25,-64,125,-1,-63,-29,-25,-89,83,-3,28,-63,30,47,1,-1,-29,22,24,43,-18,69,19,90,-37,27,-51,69,98,-13,-96,72,61,44,-103,72,74,92,83,98,94,92,79,-26,115,60,-73,-73,-98,34,-90,58,51,-77,-51,67,-124,-50,28,-54,-43,-111,35,-97,-50,22,83,98,29,13,-44,56,65,66,-31,-111,79,124,-28,-72,118,-88,116,-125,-66,-120,78,-79,-42,90,-115,-123,-19,-98,-86,68,40,-91,125,65,91,-111,114,90,5,-68,-52,97,59,64,102,107,1,25,-64,64,-21,29,115,15,-8,74,10,-104,-99,35,-94,20,43,-22,-44,23,-106,104,54,72,49,-12,40,33,-12,-108,-85,-48,-123,-111,-105,-107,-116,54,-25,-17,46,26,32,-31,42,-21,30,20,94,-33,35,-30,33,15,28,40,98,83,-102,-88,11,-8,95,-73,-109,81,77,-44,115,-36,86,43,-16,-98,-72,-33,6,-18,-27,-116,-113,14,-91,-17,28,-64,-1,-58,119,-16,109,-8,-17,108,-58,43,-54,-80,-75,117,-58,-72,-51,4,-33,20,123,-97,-15,41,93,24,-86,-87,-123,-40,2,-111,57,60,11,-45,83,-43,-62,-125,-97,-51,-12,94,-74,-37,-123,-31,2,18,8,37,-1,-105,40,43,40,-63,77,-53,86,-95,-96,120,107,-67,18,38,-70,111,14,-109,98,-72,60,7,-121,-10,-128,36,101,20,126,-72,-29,-11,95,27,-74,-51,-115,18,-101,16,-59,-43,68,38,106,-110,38,-122,-46,-61,77,-110,-23,62,-33,32,-96,38,53,84,-80,34,-115,91,-19,106,35,7,18,-51,88,109,-114,-121,51,-76,-43,-87,-46,15,-55,83,74,-38,-3,43,82,-5,85,-100,-55,127,117,-75,90,92,106,-41,-39,-120,-41,35,5,83,126,62,-105,-33,117,-81,69,110,43,-122,43,100,45,-46,-104,-2,21,75,27,90,-82,80,110,24,-40,113,64,-79,110,97,-121,-14,-128,-60,-30,-91,7,-89,36,85,57,-17,15,11,91,-98,64,38,-96,67,-71,0,44,-8,119,123,38,-122,45,7,-6,-92,-111,-67,27,-95,-126,86,40,46,30,90,-123,105,127,81,-70,4,-123,86,21,-125,-12,-25,-119,42,22,46,78,50,-123,-112,-83,-19,86,-33,-109,104,-28,111,69,-48,61,53,-80,-102,56,105,88,74,6,-49,123,88,60,9,122,-32,94,-60,-80,73,-27,-9,113,34,-66,-93,-117,-35,51,36,45,-95,88,95,4,-22,98,-38,102,119,-40,-115,82,-80,88,77,-97,-49,99,10,-71,-3,-82,-124,-27,25,74,-9,21,-33,77,-43,44,-15,112,100,85,-124,90,-10,83,59,64,-108,-89,-1,77,-14,-74,84,-128,-11,41,74,80,95,-69,3,-86,-111,-26,-34,-54,-37,81,112,-40,-44,32,-83,-55,-62,52,-33,127,106,-69,17,-70,48,-34,0,-92,44,-110,22,113,-51,30,73,30,86,89,-90,-95,69,30,125,54,4,6,3,-80,-76,16,53,-67,-27,-42,-105,-98,-32,-66,-93,126,107,45,-110,19,125,54,121,102,52,-121,119,103,49,-32,90,-115,60,54,-77,-94,59,-119,42,-42,-6,106,-5,-90,-6,-74,-32,-81,113,-103,-69,-126,119,-90,7,24,52,115,-52,-96,59,74,-113,32,69,5,127,-38,-91,126,-126,74,-90,94,50,-39,-117,-22,-102,-106,-98,109,52,122,12,-111,123,-100,-87,35,-54,14,-89,126,-119,88,-107,62,-88,56,95,9,-95,-106,-25,69,84,-67,35,-42,-76,-61,-99,-88,-82,-24,-20,-26,75,109,74,27,-100,-55,-77,72,-6,52,76,96,-100,67,53,5,111,48,-16,38,89,3,-1,-115,59,-19,-16,-34,-61,-94,-115,-16,90,-110,116,65,-121,-117,104,109,-107,-26,-72,123,108,-49,55,36,-100,91,59,-93,-7,40,77,-91,84,80,102,-108,-113,-104,-22,-64,-90,-57,-37,-63,78,33,-95,-78,102,20,-105,94,24,59,-81,-39,120,54,-40,-56,-45,9,-107,-104,74,72,29,-45,91,-18,-106,11,91,-51,62,-87,-109,70,126,-49,-117,119,-89,-117,79,-124,-95,-93,21,108,122,39,18,48,3,-107,30,-99,-19,103,-91,83,-110,41,107,-78,99,-23,58,-99,39,50,-47,89,126,-119,58,123,31,7,23,43,-17,64,65,93,7,-26,-107,50,-11,-63,-24,-39,2,-55,-119,68,6,119,-90,-16,-92,93,111,-79,-89,78,-4,95,-7,-65,32,-100,35,-20,76,114,-126,-69,-13,-127,-43,-11,62,-107,77,10,114,-76,94,85,-97,99,50,-76,-57,-72,-117,86,9,28,124,14,-108,26,19,37,83,38,-125,21,-56,-42,51,-69,-3,-108,51,70,15,33,-125,-36,-122,-34,126,29,25,103,9,66,-126,54,-54,105,-9,-124,59,-105,78,76,3,101,-94,-67,-71,90,-7,62,-77,94,26,49,-14,-112,55,67,92,-26,97,80,-36,-13,106,33,-111,-110,51,-12,118,21,-75,-25,14,75,2,-109,123,-11,98,77,109,-47,6,22,-38,124,-100,61,27,-124,89,-54,-108,-28,123,-99,-24,-77,115,70,105,-32,49,-83,-99,-29,87,-11,79,26,77,-83,-22,-38,-13,-56,-82,10,-66,4,-69,-26,-19,-7,91,-58,35,101,-31,80,-5,-37,53,-73,-126,90,-76,20,-51,-1,55,51,-93,96,-39,-81,-64,-111,65,-47,46,-87,-65,-89,100,-36,-5,-9,-2,81,-37,-97,98,-25,117,-75,79,-81,-118,112,76,-105,120,34,-116,23,-125,-13,77,-73,87,-115,-108,-44,19,-96,-103,89,-56,-60,52,-3,-105,-59,37,-43,124,76,-2,25,57,92,-57,113,-20,22,79,32,122,48,115,-85,-6,-35,-103,9,13,93,-26,-123,-98,109,7,29,4,92,-54,-89,52,-92,74,8,55,13,97,-49,87,-26,-28,-11,14,72,-29,112,-82,12,4,50,-24,63,-112,84,74,122,23,57,-58,-125,20,-85,104,-32,125,126,-86,50,-83,14,-82,107,-124,26,101,-55,-118,-72,-100,-105,102,-111,-76,123,47,103,10,-14,-109,56,-70,104,27,-18,-33,30,41,-56,122,-117,-56,-76,-45,49,41,-34,-45,-35,100,77,-36,-24,0,102,88,123,11,116,47,-1,-9,-3,78,127,-108,33,64,27,-115,30,110,-105,-92,-15,56,21,20,-70,15,47,127,9,-21,122,83,105,117,21,10,-5,31,-91,-126,63,-7,-128,-20,46,106,22,3,-102,96,110,-106,71,-93,-52,112,121,-117,-74,-49,-7,118,121,78,76,-94,93,108,52,-67,-10,-103,54,62,109,5,81,-90,-100,24,109,22,30,-48,-36,-61,-36,119,120,-47,-92,112,-125,-41,-7,-11,-106,50,-23,32,84,-125,79,-36,-6,68,41,-97,-102,-51,-72,114,-105,126,-127,-13,53,-112,-71,38,44,-98,0,93,123,-60,-19,69,108,-68,-106,-68,-53,-55,-21,-37,118,-117,-121,52,-52,88,-36,63,-82,-72,-77,-25,68,115,112,62,-124,-71,122,-68,30,42,110,98,-42,27,22,-112,22,-56,-64,74,72,-92,32,-119,-50,-69,-64,-106,-59,83,9,125,20,49,-65,-128,-33,102,-28,46,97,28,74,-47,-59,-32,-113,-96,33,-54,20,-18,7,107,-61,51,6,104,23,15,-128,123,-92,-12,-75,0,-37,-89,-17,-14,-106,126,-5,-25,57,39,-66,102,82,32,28,97,-78,33,93,125,53,4,-74,-102,121,-51,-126,84,57,34,127,22,97,4,-24,88,-23,-65,-63,89,85,119,-99,97,6,94,-107,-69,18,107,-79,-25,-71,68,14,-16,-75,-21,30,-20,106,98,71,38,105,48,-41,110,-45,-70,68,8,-42,-82,110,29,-32,71,60,-77,-53,-20,6,-94,-90,88,107,28,74,58,-95,-19,26,-63,-73,88,4,21,125,82,-71,16,85,107,-67,-48,119,-17,27,-63,49,102,-78,-20,31,98,125,64,56,-100,23,-82,-89,-65,10,49,-105,-38,18,48,-50,-114,-23,87,71,-84,-28,-101,-65,34,-112,-18,38,-80,-120,-95,90,-79,-27,92,28,8,63,49,30,3,-85,-111,-114,52,-111,-53,42,-118,22,119,35,65,21,-8,3,72,-89,-111,-121,-29,45,-125,53,-122,-24,49,-64,-80,-107,-23,125,-84,-91,-115,102,26,124,-9,-72,67,-57,29,-34,57,15,-2,-14,16,-84,5,-95,115,-97,15,-58,39,2,-24,80,-37,55,-62,-43,24,38,11,-110,-76,54,-58,-109,112,24,-65,6,-127,-94,78,107,-67,21,-23,16,-29,62,48,-53,46,41,-123,-39,51,-82,114,83,14,93,41,-59,69,-23,-17,50,-113,-41,-117,40,-95,2,4,45,23,75,-110,-90,74,-18,77,9,113,97,66,-102,-76,-16,78,2,49,-105,71,-105,94,-43,74,-86,-89,71,126,117,-51,-72,73,-27,-100,116,17,-60,-83,-55,42,-45,-37,91,-100,-75,-51,-11,90,41,102,-99,-108,-8,28,114,-24,-41,127,36,-23,118,-44,8,-41,48,-62,-127,-89,124,3,89,-1,19,38,-64,-128,123,121,14,-99,-79,-19,23,88,-53,-80,-35,119,38,51,84,-104,-50,-103,10,-41,-39,-88,-118,-37,-55,46,-41,123,1,-94,-50,-24,119,-86,-110,93,59,51,-56,71,-48,0,-110,4,-4,-56,-99,-99,-31,29,-21,-65,-23,116,1,93,3,25,-29,95,-1,-109,33,77,21,-116,78,40,-124,14,-114,-50,35,116,-19,-52,112,26,-110,47,-120,72,-36,19,-97,-53,-28,-64,71,4,104,101,-2,44,-26,-102,-4,-18,8,30,-35,6,39,-93,-39,44,-3,-92,16,-87,-38,51,-87,-82,79,17,-20,28,-18,-118,-21,-19,-18,127,-48,19,-43,36,93,42,-46,-34,-70,-121,-51,-128,83,20,-19,120,37,-8,118,58,30,-95,63,-108,-55,-1,-80,78,1,34,37,71,-16,8,20,-55,8,-15,122,107,-125,-21,111,38,75,87,12,-20,-77,115,26,-102,-86,94,-85,-97,-109,29,95,-48,-22,-117,-104,-28,-94,91,-65,51,-79,-51,-90,97,112,3,59,73,16,-119,-88,-21,52,4,-66,-107,85,-114,71,87,-68,116,11,-3,-123,-22,81,-77,-72,108,19,118,-18,-54,21,-35,24,1,76,9,72,-58,-31,-1,-124,-19,121,-47,71,118,-83,-12,54,40,-125,45,23,-121,-46,81,-16,-73,-127,56,-117,-112,-99,-128,-81,51,52,10,27,97,67,112,67,-1,-97,-94,-42,27,91,-28,-9,-82,-112,50,12,108,3,-42,86,22,115,-72,74,3,-17,28,38,79,-29,113,32,-27,-61,-87,-99,119,-53,112,-82,-17,100,-111,80,112,-106,72,94,-124,12,-29,-88,95,54,-107,-123,64,-3,124,-83,-63,120,-91,-46,-117,123,-21,-108,-65,-26,-63,-115,-54,126,81,27,80,-6,-56,71,-91,-22,46,23,-39,26,42,61,74,46,0,-56,28,28,-75,66,-20,45,-72,-86,36,-73,-41,14,115,97,102,20,55,46,-120,-26,-18,-24,-46,99,47,-2,10,-57,24,10,90,43,123,10,-90,112,99,-16,54,-3,107,-72,-84,-125,30,112,127,76,-107,114,-120,49,-117,-9,-109,116,-103,52,-108,-37,-68,-2,-107,24,-110,6,-53,-6,44,13,66,-92,29,34,-57,-41,-49,45,47,99,-15,-11,-104,127,-110,3,68,24,-97,-97,49,89,-9,-1,-53,-6,-18,-36,-18,-108,-97,-118,-104,21,-11,-55,-16,59,-72,-118,-23,87,-79,-118,-49,31,116,-62,40,88,-7,-18,-91,-36,54,28,103,44,-16,-121,-2,-122,17,38,44,91,-70,52,110,29,-53,-88,-102,-101,-91,85,115,-50,33,-24,-66,-43,-14,126,-30,81,34,88,51,-85,-37,123,64,-74,25,-82,-17,124,40,-74,63,14,-41,52,-65,-118,78,24,-15,-91,-115,-89,121,93,-28,49,-28,14,-37,-49,-100,93,-7,98,-99,86,23,-111,114,58,-26,5,22,-20,-51,-29,21,-67,57,39,5,-79,-87,94,26,-36,77,-69,127,114,31,-69,62,-44,127,-26,-84,-119,34,70,-108,53,-125,7,-12,-76,121,-125,-85,-19,-43,-121,34,-59,-4,-54,12,-89,67,-38,15,100,-44,-92,34,-7,38,-19,110,-45,6,-45,17,121,-71,36,-46,-32,53,117,82,36,101,-47,7,-108,-71,-25,117,-112,104,93,115,-116,-90,55,8,-4,109,-83,104,-54,64,14,60,89,6,-70,109,115,27,26,-74,77,48,1,-26,-21,82,-50,-39,-87,-115,-26,-41,11,17,46,-84,102,65,-5,67,24,19,-43,-105,-11,77,-44,-30,20,-11,44,-71,-84,2,98,95,-9,40,-111,-95,112,-96,85,-102,-53,113,-73,68,12,84,75,72,-59,63,-35,-81,-58,0,-67,-13,5,-14,-37,-45,72,-90,89,49,12,120,34,-37,123,-104,113,-75,25,-100,-113,58,-99,11,-58,41,64,-93,43,53,-90,-75,92,122,-39,-26,14,-108,-81,18,-125,33,41,10,53,-74,-77,69,89,65,72,-12,13,40,105,44,-20,-109,-37,-64,-47,36,-98,-62,-38,-56,-112,-53,-96,60,29,58,-84,104,36,-103,37,-93,38,19,107,-120,24,-122,38,35,-8,-4,-65,7,9,-61,-33,48,0,-99,10,-61,104,108,-83,122,14,23,89,104,107,-100,31,-111,-45,-5,16,-6,84,-15,-105,-27,-28,-31,-86,-119,35,-106,-19,-45,-5,38,113,-14,70,-100,118,39,102,59,44,90,-47,59,-28,-94,-85,75,1,-124,-45,-90,36,86,-45,-16,19,122,-57,-111,11,-53,19,-36,-32,79,123,114,-124,-116,67,-110,-3,47,-19,-21,-33,63,-121,14,50,30,-11,-94,-10,-41,65,7,18,13,-3,106,73,116,2,-7,31,-6,113,-15,117,-121,60,68,117,-101,-57,-15,-27,114,36,-27,-34,29,-100,79,19,12,-27,-14,-4,-120,116,-83,124,2,110,-37,67,99,-43,-103,-64,-31,-30,-100,-25,-94,-16,-62,-80,12,-128,-64,-3,0,95,102,-61,-42,51,93,-74,18,70,98,-60,-67,-2,-89,52,-35,0,-80,-70,39,16,-115,69,-115,127,39,65,-4,-67,-43,22,127,-83,59,99,91,-33,115,-86,4,-5,107,-68,-40,-56,20,37,94,31,-62,-100,-85,83,14,-65,-7,106,61,-70,-77,87,104,-59,-23,-108,125,-119,-39,-102,-126,96,6,72,61,-127,88,-57,111,-62,65,68,-32,-78,5,-65,61,46,97,125,-47,16,81,-20,-77,66,44,116,-80,-18,14,-77,-88,60,111,1,93,-64,-55,97,53,26,80,-23,20,-52,73,55,42,-13,-85,-17,-11,-54,-31,-109,-102,64,-87,104,-105,-121,86,67,32,44,72,-84,-67,-62,-54,28,-61,-46,-124,-100,-120,-49,53,-102,-113,-19,-54,-114,-115,127,27,-21,-27,-44,-86,-126,108,110,-120,85,67,-58,-91,-128,-68,10,-64,-65,-33,67,-32,41,-17,45,-121,-78,-114,74,117,26,56,-125,69,-117,43,52,-38,-19,-42,-4,110,95,-89,35,82,-83,54,-37,-39,-24,103,37,-65,-5,120,4,64,-88,69,54,-23,104,-100,-73,-80,-126,77,-18,-15,27,45,1,-40,51,108,-74,-69,121,-45,27,110,-74,43,60,68,-79,-7,-111,-1,-63,-59,0,-90,96,-12,103,58,39,-18,88,-62,-26,-19,-111,51,73,-82,50,-84,-126,-23,-110,11,4,-11,49,-54,-69,-50,-27,65,20,-19,-27,75,-46,-98,-42,-74,53,-23,10,-59,-99,106,-87,-83,-4,-2,95,-12,85,58,-12,-9,88,-2,86,35,-81,5,-120,-87,-9,-40,78,-9,76,-32,-101,80,-98,97,24,-56,25,109,74,99,15,-78,-15,98,-17,-102,-79,69,74,123,94,59,104,-85,-80,-123,-19,84,-124,44,-87,95,-64,-120,105,-27,-71,-92,116,-110,-26,-101,-123,87,11,62,-79,-79,-91,98,9,-36,-112,-113,94,87,-29,108,38,47,116,-110,-6,-11,-118,-67,93,-31,-36,46,-53,117,-24,82,-76,121,7,108,-107,84,-39,-82,75,-31,51,78,-92,-69,61,26,-67,-127,-49,-37,-67,17,78,-47,-31,68,77,116,105,-74,45,42,-59,-109,-89,-10,-26,64,-28,109,114,80,-71,-64,56,-75,16,-50,-20,96,-23,-39,42,-84,46,94,61,-100,-43,-63,35,54,110,37,48,54,9,32,-40,17,-100,33,-33,-103,-90,-86,5,21,45,-75,89,45,-78,-18,-55,-97,23,-15,-5,-108,-41,-102,-9,10,42,-36,-28,-17,-84,-53,-76,117,104,80,-112,-10,87,51,32,96,-87,-15,47,-44,-16,44,-55,-34,-122,-65,89,-59,61,93,-70,-10,-124,-64,-65,-118,64,-88,-100,-68,26,-44,51,-51,-112,53,-38,43,48,-60,-55,-101,116,-42,-89,-59,-47,-41,37,-122,61,109,-97,-94,-99,85,-128,11,120,-32,-71,59,-84,50,-26,-111,118,-10,-74,-105,85,-63,75,-73,96,-122,108,12,-2,122,2,22,-128,-8,15,-50,20,14,-58,-99,-91,62,66,32,19,112,-38,-9,-101,-40,50,68,58,-117,51,94,-18,112,19,88,-47,73,-109,81,67,-49,121,-67,-113,52,-116,-38,-53,18,83,124,34,-116,66,74,-47,-96,-64,76,-125,74,97,36,-53,-30,118,14,-23,97,-10,-87,-54,-103,-22,-122,-6,80,-82,-44,-59,-56,65,-66,-65,-73,-84,82,-66,127,-63,24,-26,38,105,-109,110,62,-17,-51,15,-123,-96,-122,-111,114,-52,122,120,-49,-51,-19,28,-11,-22,-55,77,54,99,-121,30,36,19,-84,-53,59,-118,-127,-18,81,-94,-75,101,106,94,5,35,87,-114,84,-93,112,-55,34,84,82,-100,102,114,38,-66,41,89,-73,-107,-67,16,-119,61,22,119,7,-103,-84,34,-116,20,67,-57,61,-38,-94,-96,-51,-44,54,10,-62,15,108,-68,-123,25,-122,67,-41,1,-77,67,-4,3,-120,8,106,86,-26,71,10,-19,121,52,29,84,52,-27,73,81,9,35,-73,-15,-62,100,-19,93,5,-30,31,-71,-43,-63,10,3,-103,-41,10,-16,94,101,-8,-11,44,105,-113,87,21,-75,30,-79,-44,55,-113,-105,36,42,-100,-128,93,-122,-99,-72,-86,90,-9,-106,29,-58,33,85,45,-49,-115,38,-114,-76,115,-13,43,77,-82,23,-3,117,93,101,-1,-89,-71,-113,123,5,3,-64,36,69,-124,97,65,-109,-62,106,33,81,-46,-40,-33,28,-89,-67,117,29,-110,98,-36,102,47,91,55,-67,-34,57,31,-124,13,99,108,-9,105,99,40,-95,-64,114,-108,-60,-4,-28,-1,-126,-1,121,-80,103,-4,-104,-78,-92,20,120,113,-19,-46,-13,11,-105,110,19,-82,76,-85,89,-103,107,-35,-14,-56,-92,-95,83,10,123,-73,113,-82,-53,-128,-6,44,-64,126,44,-63,67,-25,45,-69,48,-76,47,6,89,115,-17,-100,-92,-106,33,-79,-60,44,74,106,-90,-120,-107,-59,89,33,96,66,70,-104,102,-35,-4,14,101,99,-3,-120,105,122,35,48,-125,7,101,-95,86,-39,-8,90,-112,127,-77,13,-36,27,-83,48,-10,-40,102,97,50,-48,-111,110,45,-72,-4,-86,33,-13,126,95,67,-1,-4,-66,-91,119,67,-32,35,-124,-36,31,25,118,21,-2,-24,126,49,-102,74,100,-127,-15,89,84,-83,-17,-25,-54,35,-123,28,-98,52,-27,75,-45,-116,85,-112,-43,104,51,36,-84,82,-122,35,98,-20,-17,-62,-99,92,92,-26,85,108,-70,-118,-78,-85,-56,-2,-60,-115,54,-77,-8,-28,-57,-81,-16,-57,-92,40,89,-58,-19,-125,-31,-90,44,-117,-88,46,-12,96,-93,112,-67,50,-41,0,81,-26,-128,117,-53,65,-85,54,105,-124,-84,-5,-16,13,101,92,-51,-115,98,109,40,-23,43,-41,-28,-45,-10,18,5,-125,48,-116,111,-54,19,20,33,82,30,-123,55,120,3,79,-32,-55,70,90,-33,60,121,1,-28,77,-64,22,-95,37,-40,83,33,-107,-72,-96,-47,59,-76,117,-34,-13,-81,-38,117,36,-106,93,33,-86,-118,81,-71,-49,-126,-74,-61,66,73,-91,80,-98,-56,-31,60,4,36,-104,24,-53,-106,44,-120,5,90,79,83,-88,34,71,-32,-78,-50,-39,-42,-21,98,60,86,79,6,43,-27,32,-6,57,-54,-98,71,23,-60,22,-126,-86,64,-28,-128,-40,63,53,-31,-124,-98,13,-98,-81,-52,107,-46,71,34,-9,108,-50,9,16,64,93,-6,11,125,2,45,18,15,-15,116,111,109,-47,-107,-17,127,-19,125,-95,97,-79,41,56,44,46,-8,-12,86,36,-56,-92,4,-111,127,76,95,77,75,87,67,91,5,-35,89,43,-80,47,-84,11,0,-33,-44,-73,-104,46,-48,-28,-38,49,105,-30,-95,102,-112,-62,-1,72,-54,-56,49,85,47,41,114,42,-67,-97,9,7,113,-85,-22,58,90,25,118,-111,-62,-47,-81,-5,42,65,-111,89,-126,-46,-22,45,118,25,-29,74,-62,-77,124,-1,123,123,-46,-74,-24,-115,-5,-111,-82,24,-1,109,-70,-13,-1,37,121,-66,-119,-36,19,-61,-62,-6,82,-103,48,94,-24,15,-106,90,13,124,-94,16,83,-38,98,-30,-101,52,105,-13,3,-98,58,111,-61,-16,-32,-47,5,41,28,-126,86,5,22,77,-34,-55,64,100,-104,44,59,121,70,-7,110,-12,-19,68,-124,30,-97,105,17,14,-100,-48,56,26,108,-78,-56,-3,81,58,-14,-73,-83,51,-51,-116,-20,114,55,49,106,-64,-75,24,57,18,-113,74,-86,-14,109,-124,-21,-121,-78,46,-104,62,-39,34,-47,-110,77,-107,-23,43,-82,32,-111,-75,1,33,78,60,56,-6,120,-90,-92,-35,77,11,-42,-81,-123,64,-78,-43,118,52,-62,-96,53,8,70,-64,41,6,80,-20,-104,-124,-101,90,-24,-17,-11,99,105,88,122,-114,67,-122,69,7,56,23,67,61,74,-65,0,-50,-29,21,-76,84,85,-42,-60,103,-102,107,-24,-110,61,-102,102,-27,-81,-110,4,-79,-9,0,58,-38,62,94,-99,-44,64,76,8,-74,-118,-96,102,-40,112,-81,83,-72,97,-9,-102,-126,101,62,-44,-122,-107,25,-35,107,-100,-124,-65,1,109,-102,0,-96,37,-84,26,-67,91,46,83,-23,16,57,-70,75,-14,-123,-72,-102,38,79,-78,25,-121,-112,58,-9,-128,-70,30,-40,-51,122,27,-92,-8,119,-115,-125,71,-40,115,54,104,71,65,120,-95,14,-96,-69,-89,13,-56,2,26,71,-70,87,126,11,-6,94,-31,110,43,97,-22,-83,-93,-79,34,-116,-102,44,43,-54,-65,81,89,51,76,42,-28,18,115,-33,108,-17,88,61,101,-42,27,39,-20,120,-2,-83,26,-100,67,-13,27,-60,-120,-15,-7,59,-39,-53,107,-54,-44,-123,-110,104,-119,122,-90,102,-51,1,-85,30,-75,82,-94,6,39,-92,3,60,-2,2,43,-71,-110,-55,-102,116,116,-128,-85,70,48,93,-83,-127,82,-35,119,109,-107,48,-23,-8,-127,95,81,88,-109,-45,73,46,89,-107,15,-11,-108,-67,66,108,59,-80,25,-64,108,-29,53,72,75,23,-29,-9,7,-30,103,-6,29,-63,57,54,74,-115,-3,116,-54,68,-31,-13,-115,85,120,-69,-79,-44,75,117,-28,-67,121,-46,56,-83,114,-86,11,7,121,119,-49,7,87,-117,-105,21,50,9,65,-122,-13,16,127,100,121,-43,56,45,59,18,-70,-17,43,-40,-19,123,-22,56,35,-16,55,67,-23,-60,12,101,48,68,25,118,103,-85,-7,42,-52,-32,-11,-44,31,71,-72,-15,114,75,112,-37,8,-32,69,-21,-30,-78,106,9,-109,-15,37,-106,65,127,47,115,24,-119,-103,-20,-8,95,90,-7,113,37,-103,-113,87,-79,92,-11,31,-49,-21,-64,89,62,91,-109,65,-2,62,-48,-55,-25,86,29,-81,0,-23,-5,-4,58,65,123,-121,-108,119,-104,117,-68,52,118,75,-19,-64,-126,72,73,-121,-91,42,-104,0,-1,-103,-104,16,-109,-50,-29,-32,109,-9,-19,-105,-103,-50,77,-123,-23,-99,-95,58,-14,-90,-21,-38,24,-74,94,-121,-98,110,95,4,-48,122,-69,21,23,57,-50,76,-112,32,48,-38,116,-62,-54,-57,-39,-32,121,60,-67,-41,-107,31,29,65,122,90,107,-128,126,101,115,76,-109,-59,-58,-52,56,-114,-115,102,19,55,-53,-83,-61,-103,-26,-63,123,113,14,-83,-59,59,-104,3,7,-1,-39,-51,61,25,36,-84,-30,65,69,-66,-75,66,29,9,-128,99,-70,-18,1,-68,-22,-96,41,14,-54,11,-5,62,-115,-87,-40,57,-53,-117,70,-12,32,-123,31,-44,-63,16,-43,-34,126,-82,-115,68,-121,98,-68,4,-80,5,35,35,-53,17,70,34,14,125,-122,80,80,50,113,-39,52,-34,7,89,-87,-118,-25,-94,58,118,-69,-112,55,17,116,53,33,-84,22,-49,55,48,48,-102,78,76,-55,112,101,-75,-55,63,32,98,19,79,95,-13,67,113,15,-22,-123,51,34,114,-10,88,-62,59,88,23,53,109,-42,24,-21,61,25,-34,24,50,24,6,-95,-102,-85,65,127,62,-59,41,55,-67,-99,11,78,61,-108,64,58,-54,21,-119,76,-9,64,23,-48,-82,54,6,52,103,59,123,-35,55,24,35,-68,-56,-39,-74,32,17,-29,-7,37,62,-103,-58,19,-37,-123,28,-53,30,101,46,88,-127,14,72,27,-124,8,94,-56,-90,-97,-80,-17,90,-32,-12,107,92,-110,0,54,-36,-69,37,-95,-74,98,-57,-72,-38,79,-8,-31,77,122,-62,-118,68,-6,90,109,-1,121,114,91,-51,-58,73,13,-110,40,59,-25,-121,-65,31,-87,25,35,-72,-22,52,-60,15,-117,-37,26,-15,-32,99,94,-94,-53,117,-7,-108,10,-82,-55,-58,-28,-6,122,103,121,31,-68,11,-26,60,-66,-97,81,117,65,90,73,-11,102,-56,104,12,-75,20,-116,76,-116,-115,32,74,-46,94,105,53,74,-8,-21,45,-2,-65,108,-5,39,94,62,20,-61,36,-97,10,8,54,-117,61,40,-123,24,-16,63,24,-4,11,28,61,-104,127,-46,-90,114,72,-70,-105,-7,60,-51,-35,-5,71,-113,102,-66,-83,111,52,-128,6,100,114,84,-77,-52,50,-94,-33,56,55,-114,44,91,63,113,-5,127,66,-73,55,68,13,-76,10,-95,94,93,-124,28,-82,-117,37,31,-27,-36,-72,-31,-66,69,56,-8,-123,-102,76,-113,40,18,95,47,76,-90,73,-84,-46,-75,55,25,7,-95,38,-34,72,18,-84,-104,62,-92,-5,-77,-67,85,16,122,63,-31,64,97,-23,-55,-63,11,-90,-105,-80,57,5,-60,10,34,56,-39,-102,-104,-87,-85,23,-96,121,75,32,10,7,61,45,19,-110,106,58,-50,67,49,76,19,81,19,-65,-25,16,-79,80,96,125,107,93,-119,-43,13,15,-76,-127,-29,38,-29,-95,-43,-92,-120,-126,22,-39,-34,-81,-91,43,113,-13,-7,105,94,126,100,-79,77,7,25,-99,113,115,-125,26,2,-5,106,-89,76,-106,-70,-92,-71,-104,48,-16,88,-21,123,82,-58,109,7,-47,-62,-62,121,-75,122,-100,-103,51,86,95,101,-99,115,27,-8,-97,-109,50,-68,-15,64,126,76,-94,-94,87,-13,-45,11,62,-27,35,126,-56,-115,12,39,54,108,-127,-17,-76,-95,61,-98,-10,-14,-65,-52,87,9,45,-66,-110,114,-65,-54,-7,-115,-126,86,32,-21,24,97,-117,-50,-52,49,-106,-116,53,-39,15,112,99,90,111,34,24,-70,16,80,-85,-29,113,-90,-21,69,120,-111,47,73,110,-36,108,21,-117,-72,-63,-15,84,-65,13,-40,-96,57,-15,44,126,-114,51,1,105,40,-20,77,76,44,34,-115,-28,-114,22,-108,-96,110,-128,42,69,87,-68,-96,-57,89,66,-86,-32,43,-14,41,-114,16,106,-27,-22,23,23,16,-57,72,-53,116,9,59,44,20,46,29,77,-42,-17,-119,-66,1,-75,-88,33,-94,107,78,-28,-125,-96,-27,-71,-43,-52,-74,-126,-86,-77,33,37,22,-105,124,-5,80,-124,65,29,14,-23,2,13,102,-11,-86,0,24,76,-18,63,-66,111,5,-15,76,-125,126,-82,-92,43,-3,-59,-126,-99,-46,37,-76,10,-127,-80,21,98,24,-62,-99,62,-51,85,70,43,-112,-97,111,-111,120,-54,-56,-52,-93,-30,53,-107,53,53,21,-104,-97,-30,89,25,-54,-62,54,88,-83,74,109,120,85,15,48,76,76,-74,50,-36,-52,-99,-112,121,54,18,-75,-40,30,-64,-72,110,28,-7,45,-91,-65,115,-67,-20,22,107,14,103,-71,-102,92,-33,33,-72,-4,92,100,110,-70,91,-27,-52,-63,116,64,-124,50,-37,-48,-93,-23,51,56,-77,87,55,61,-37,-23,-96,19,-73,79,119,3,-34,31,65,86,-127,-120,21,-39,-117,-78,-18,109,89,-33,-42,49,5,-28,65,40,52,-99,-27,114,-28,42,36,38,-46,-36,-88,-8,-94,45,116,-120,48,-109,78,-22,-20,50,74,11,-11,-16,-73,-127,45,109,24,28,-113,102,-33,109,111,-70,-40,33,-112,81,19,40,6,9,65,-25,-38,45,122,-57,-69,-65,-28,37,86,42,-113,119,11,60,-114,4,69,125,93,-60,-52,-58,-72,76,-8,93,77,69,107,-42,-84,-28,100,38,41,-119,-115,-114,-80,-111,95,-113,-122,37,-10,-118,-21,-6,-45,87,-30,88,44,54,101,95,-29,122,124,-101,-72,92,28,-74,6,-29,83,-48,67,43,-92,94,-69,-99,20,124,22,13,-76,-104,-46,-74,-83,-61,48,-81,-115,93,7,-85,-125,-81,-37,81,-28,-85,-14,-79,10,74,86,91,65,127,-66,87,-30,24,126,45,114,-32,-7,-25,-9,-45,-113,28,-53,-106,19,53,85,65,91,-67,-107,-106,-103,-31,49,27,59,-52,113,119,90,125,126,-13,90,7,58,-93,78,-124,-59,80,-59,34,105,-49,-100,-119,-126,-86,73,-54,22,-71,88,112,36,60,-9,88,-96,-113,-70,-83,-105,126,36,-9,118,-33,58,-47,-17,29,-86,98,13,-103,-106,79,69,-102,37,-104,-35,97,53,-99,38,72,100,-88,121,112,116,26,-32,-105,-98,97,82,-125,64,81,-81,12,68,-86,-56,-80,5,123,21,48,-122,-99,50,10,-98,94,-30,51,-86,-97,-24,-95,109,-11,61,-1,-24,-103,-125,-28,-101,73,-111,-32,-41,75,117,96,-9,36,68,-34,121,-122,-83,-42,84,41,-116,-101,-29,-51,-104,-32,65,-37,-49,-117,-22,106,110,-20,73,-5,-105,59,-96,-79,-47,-115,-115,-103,83,5,-104,-126,97,94,39,107,1,-105,-91,-103,-70,-92,121,82,89,-85,-103,-5,122,-43,-10,94,-59,-116,-12,72,-73,54,17,-43,71,127,-7,-125,-31,-57,126,56,-96,-37,36,112,-80,-42,26,-118,81,124,59,96,-36,-31,8,-49,-80,83,62,-52,38,-106,122,-112,93,32,-47,-67,56,41,-120,110,43,-44,-31,119,-64,98,54,76,64,-28,122,95,-7,63,-41,-48,-95,76,71,-94,125,-82,-91,59,65,125,20,109,-42,23,78,3,-91,-29,-19,-84,37,-21,59,-80,-84,-50,-77,-46,-42,75,6,-14,-46,-102,-81,-94,-102,-68,91,-26,-85,-61,-43,-128,-84,-55,87,-45,-67,90,-24,91,-20,117,81,-2,124,65,-113,124,54,-116,-106,41,106,-12,55,6,-93,7,31,-44,54,-50,-16,-119,-17,-23,14,88,22,-41,-9,-3,52,78,-33,-61,-16,114,-101,-57,46,-113,-76,112,121,-82,2,-3,-50,117,-74,104,67,64,-45,84,-36,125,30,11,-16,40,-69,83,-80,115,-127,-72,-41,103,-16,71,-33,-38,22,-39,-81,54,72,-73,20,-105,65,61,97,57,-122,23,106,-111,-87,-72,-97,115,89,113,57,38,-67,-25,-29,-93,116,-123,113,-68,-111,92,46,-25,27,-44,-11,79,101,-30,12,-89,-29,82,68,22,-17,-52,71,105,52,85,-112,-72,34,-109,17,86,-55,42,-90,22,67,119,43,-80,-14,51,40,-73,85,-51,102,95,28,-44,82,-28,-74,127,-104,31,58,-27,92,-125,-125,80,47,-47,24,-24,37,-71,123,91,49,102,67,-42,-111,97,41,48,-111,-45,81,-31,72,-64,38,-118,70,-114,-102,42,7,-87,-41,-9,-54,118,-48,121,-105,19,-28,-109,-84,-108,110,-55,-107,122,-74,99,69,100,85,-105,83,-66,-78,-8,-51,-88,-102,40,-5,-9,-110,3,-36,-20,120,-121,-97,-53,-37,-80,-46,-101,85,-61,-46,-22,117,-80,-120,64,-3,120,-46,-117,-121,-122,-53,-9,15,127,-29,11,-32,9,11,-87,86,15,57,-59,100,-90,64,-47,121,-34,-43,52,91,-116,-35,122,117,122,-90,115,-128,112,29,66,-73,39,95,-107,44,124,-31,18,-104,102,59,78,-14,-47,-30,41,-21,26,18,122,-19,43,-66,59,28,105,45,-3,98,-77,60,100,81,-22,8,3,80,105,-87,62,116,-21,83,31,-95,112,-114,-126,-58,8,121,-65,46,-112,-94,79,-128,112,24,99,-114,83,28,-104,89,-18,-121,-10,16,-73,-18,-97,69,-94,-81,-18,108,-86,53,-87,-17,-30,99,-23,54,1,-111,11,-52,-63,112,-55,-125,60,56,70,4,-103,114,89,114,-80,53,-50,49,90,-97,-54,-89,126,-17,110,-99,-30,-9,-71,95,74,63,92,-38,26,111,61,37,53,-76,27,110,-96,101,63,21,-99,121,68,-10,-124,-17,32,-83,-19,-92,-72,-26,-78,108,105,-80,115,60,-10,52,-74,-46,-77,-70,123,109,-77,-48,57,-54,-30,-37,22,-90,66,-41,112,-125,-1,89,120,-93,68,-103,-97,1,7,94,116,-108,39,-102,-7,-113,79,-90,56,-76,-8,38,27,123,-40,-111,87,-47,105,114,77,-9,-69,54,-109,34,-25,85,-65,-16,106,-94,-75,-103,87,12,-123,101,-41,-3,-1,-7,48,-46,56,-1,92,-18,-4,120,-46,110,96,81,21,92,-37,-54,36,121,-18,86,-55,118,101,87,55,49,79,-96,-28,19,56,71,-27,-127,110,104,107,30,65,-128,-107,110,-20,-57,112,-103,-41,88,12,113,117,-5,46,33,-20,-115,-113,-106,-19,101,-120,5,-125,-89,-107,-33,-116,-69,107,-85,-101,-39,44,31,-69,108,-124,-2,67,15,37,32,41,0,-20,78,59,79,-8,-80,-50,-82,-115,-6,12,1,-30,-85,-90,7,-61,96,-81,99,97,51,123,-107,-68,-102,127,-82,58,23,11,42,62,-82,-51,-59,-40,73,76,0,66,-42,103,-104,59,25,-48,-25,-99,55,-9,43,123,82,-108,53,-32,-20,-4,-36,39,23,-48,100,-1,-114,20,-108,74,114,-12,83,111,-77,89,-14,-37,74,6,126,-52,29,109,62,110,-108,38,-32,55,36,-92,-16,88,60,-84,0,-3,96,-50,36,3,-111,92,-3,-13,-23,19,-122,-32,-35,43,-48,52,5,62,78,27,-86,-59,-114,-19,60,-111,-75,0,-120,122,125,77,-128,-124,11,-112,29,74,18,15,43,82,58,63,-69,-26,-90,63,125,25,122,39,48,-64,-103,-107,41,-105,-122,84,46,-95,-57,39,36,76,-3,19,-21,-57,-56,-47,34,-30,-41,-128,-47,-10,66,118,37,119,48,76,97,95,-119,-71,17,66,-128,47,96,15,83,-48,117,-22,-43,-68,-44,-128,102,17,-16,62,-34,85,79,80,-11,-2,123,-123,-68,-36,126,98,-5,99,-56,71,76,23,45,69,38,28,-9,-96,-80,-107,-9,-87,1,53,69,-10,-69,-74,-107,-38,83,-7,-46,105,-117,-30,49,-126,-29,-55,35,56,-18,-4,95,119,-9,-114,9,29,-32,-19,-55,-123,72,-30,-17,-56,-117,121,-92,-18,-11,67,-71,33,28,-9,92,48,-100,-7,-120,-18,-37,16,-105,-18,106,98,124,45,-45,46,90,-39,-120,-67,120,125,88,-12,125,-42,114,-84,-8,-63,-17,-109,41,80,-57,19,82,9,-87,-4,-58,-52,-60,-76,20,41,43,126,-19,-110,-26,32,-107,126,8,-74,29,108,59,28,71,-39,-12,100,-82,89,118,97,-96,-77,-41,31,4,-119,-38,85,-23,7,116,53,-115,-35,117,-67,-122,75,109,18,50,115,99,97,-72,-94,-48,-22,-122,-21,-22,81,47,108,51,-68,-115,109,7,91,-56,11,-6,12,-15,-62,2,26,-100,52,111,5,60,-52,82,110,93,-116,-31,-62,-2,83,113,10,20,-82,-58,-78,0,52,-108,-67,121,20,-18,79,90,79,94,35,88,68,92,20,46,67,79,-21,-23,27,68,-50,-9,-16,-113,-76,30,-35,-86,-10,17,-102,-88,-89,-112,-99,-67,-123,-108,84,110,-9,-92,-57,73,31,-107,98,60,111,-82,-127,88,45,64,116,-125,29,-115,-33,-81,-127,-121,109,112,126,126,-76,37,56,39,-45,-35,-53,69,-74,94,58,62,35,-120,-17,9,29,-92,-66,-110,-71,-96,-52,-25,-55,-98,23,102,115,-84,-115,3,29,83,61,27,-40,38,-8,-102,95,-83,-115,96,-2,-90,74,0,-13,-39,98,-119,117,-78,-87,36,98,-30,-96,-110,-122,-105,0,-113,-23,-115,86,31,-86,21,-91,54,15,-29,112,120,-128,18,-35,-67,15,77,33,115,-18,74,-51,126,99,-6,46,37,-13,-33,-47,92,-88,-108,-43,-25,-74,59,-67,-89,9,8,92,-126,-82,22,88,-51,-48,41,-111,-55,103,-36,-41,29,-11,-6,30,67,25,-109,-47,-43,-120,-15,-40,-69,-120,19,-113,-61,78,-21,-121,-127,125,30,-20,95,16,122,10,111,-37,107,-77,43,-97,-98,106,-121,-86,-94,-104,-39,86,10,-44,99,-14,37,-52,113,-37,-49,-44,10,-61,-55,2,-107,36,78,52,115,76,83,54,125,86,20,97,36,55,18,-114,-49,83,-48,-23,-90,83,69,-73,57,-128,-85,-16,-11,49,84,-15,9,83,4,-60,100,126,-41,-81,80,-16,114,-2,-92,60,28,77,118,102,45,86,50,79,29,1,81,126,53,15,79,-110,-113,-87,-55,-95,-46,75,-29,-56,88,-90,-17,-4,-24,-57,4,-101,-38,-86,54,-80,26,70,-97,-112,-53,-57,-58,-97,-38,2,-30,30,-53,60,102,-113,-78,9,39,-9,28,-37,69,-11,98,-78,11,-9,-38,54,-27,65,-86,101,-82,102,-36,-66,-55,-123,-1,107,94,41,-103,-47,-21,26,-40,-57,43,127,127,121,124,-126,-104,105,-121,-39,9,-107,121,125,-67,-79,64,-77,88,-47,-96,-78,27,-19,41,-57,36,39,-54,101,46,-27,-48,-95,-60,27,77,-26,-23,-52,122,-101,101,-96,44,-48,-7,-109,23,53,65,17,-119,52,-15,110,-49,-124,-17,62,-122,-91,95,-56,-100,-81,77,-10,30,-124,34,79,-9,117,85,-70,3,-64,24,-29,-78,-106,97,46,-16,35,54,-44,117,52,-29,54,68,-120,-11,111,81,0,-123,-4,-42,5,-69,34,51,-113,-116,-108,-91,34,126,-56,126,74,-20,-98,20,75,87,-63,-123,-85,6,-70,8,72,-60,-25,-78,19,62,-32,13,6,-48,-83,20,-20,70,-30,-114,48,-107,-60,99,-10,101,-50,7,116,-33,15,-73,41,27,-82,-117,-56,-25,10,9,85,108,44,20,-69,92,28,-61,116,-55,1,-25,31,75,-68,-21,21,-3,22,41,-111,-22,25,25,12,-32,-10,84,41,-3,-11,96,-83,85,-33,-59,74,107,-80,-40,-102,123,-28,18,-93,115,-66,117,-128,-88,-10,-99,101,58,-3,-51,-47,40,4,-36,50,28,-57,-126,-91,100,44,-47,36,-124,117,-46,-47,109,-65,112,-43,51,-48,-116,51,-113,-106,71,115,-123,-111,-82,-18,-126,10,94,98,-39,-50,-60,-58,-14,43,-124,18,25,98,-99,86,77,35,-85,-58,-127,10,-23,79,60,119,28,3,-11,-44,7,-70,108,115,-122,58,66,-96,55,76,-2,-1,15,98,-121,84,-120,94,121,-80,-58,84,110,92,107,-125,-61,75,-4,-94,-52,-7,3,84,96,12,-48,-16,-25,-36,6,-91,70,-80,-22,91,61,-82,-77,83,111,-47,22,-82,65,28,119,63,-71,94,-53,-74,-119,57,-103,-81,12,-26,-73,-113,124,100,-91,-102,-90,24,113,11,3,-18,-4,-50,-73,72,-2,-16,121,94,-70,106,-62,-105,-50,4,-46,-34,-52,-31,-15,-89,62,-11,-78,43,-36,-104,-118,-68,87,-106,-2,-86,112,-51,3,-24,120,-78,-20,14,44,-58,103,-70,-15,10,93,9,15,-66,-75,74,-106,-117,-65,-8,16,-10,-31,107,-114,125,-44,-84,-75,26,-97,2,12,-27,-117,80,45,-115,-29,8,97,-74,108,75,-60,17,-119,1,-14,10,-14,-18,81,-81,11,8,29,-110,122,122,-24,-35,-120,113,-78,86,27,-31,87,-89,76,9,-114,-29,-75,-43,-12,-70,-118,-94,-1,70,62,-56,34,-32,-99,-126,-15,97,-38,-86,88,-37,20,94,119,103,64,41,-44,-66,-78,33,22,-67,120,-109,84,-106,-62,-34,12,104,36,-88,21,-35,52,-78,74,37,6,121,70,-78,-109,26,8,-18,42,102,-104,22,25,87,120,-8,125,-90,-82,127,-100,1,6,102,-72,78,-42,-100,-59,-87,-125,-13,-86,34,43,-12,-109,-61,13,36,87,-108,29,33,24,-124,-36,-114,34,-88,114,-41,21,-115,-71,-3,-108,36,-31,19,57,-95,97,-114,46,-121,-102,114,77,76,82,79,11,124,-82,-124,-50,31,92,113,-100,-102,27,-88,122,4,-87,7,102,118,30,-98,-84,72,-73,24,-112,-97,-125,-29,58,-101,52,48,82,111,78,71,88,-40,-58,-28,11,-94,125,-6,12,-18,50,-62,78,-18,-62,102,29,127,80,-31,-126,7,114,-25,-100,-116,120,-75,69,25,26,124,-23,-68,-15,-79,-5,-14,108,4,11,-69,-41,75,59,-72,113,26,-66,48,-4,103,57,71,-94,-2,14,-28,-36,22,-8,-25,39,-51,25,99,91,70,63,11,-124,69,46,-34,-21,99,-70,-110,-90,32,116,34,-74,82,43,-104,-56,31,-117,-43,67,12,-72,115,-84,-62,-9,21,-30,105,82,94,86,12,40,-47,-39,40,-114,-67,-89,-72,-64,-62,-124,-105,32,95,-124,-41,-14,48,26,8,-116,-57,24,-45,-45,-75,-40,-111,-118,107,116,66,-97,-57,-79,-96,-85,-55,49,-55,-32,-87,-76,-12,42,-85,85,-16,75,-41,-112,49,-29,-28,-124,-10,-60,62,-2,-112,15,-36,-33,81,-95,117,120,51,99,-64,30,11,106,-21,-42,43,-59,51,117,12,45,3,-116,110,88,104,60,67,102,-74,108,80,-58,-108,28,38,-108,16,63,100,-24,-36,-1,70,97,7,32,118,-112,-122,-31,-36,106,10,115,-89,35,58,-15,-5,63,19,-123,-99,-11,-94,108,-18,-13,70,-12,-1,126,-15,-9,-25,113,111,66,-59,81,-88,-114,97,-121,-76,16,8,72,62,3,-107,106,-43,92,-91,63,60,-90,-61,96,-9,93,-24,-17,-22,38,-24,29,-27,-36,-25,117,99,-10,76,66,-77,-71,33,-87,100,48,-13,-122,-49,56,-104,72,72,-84,103,72,115,-10,45,19,-22,52,-97,-77,-107,50,-81,-93,-79,102,-71,46,73,6,-21,-52,5,-96,32,112,15,-44,-4,110,5,-26,-85,89,-87,35,73,-17,59,-95,-5,-123,94,127,-83,9,-122,-64,-58,-72,-111,33,-91,-82,56,63,1,6,-67,-106,-55,26,-12,-105,-32,115,-38,-95,118,117,67,-17,95,99,120,-75,2,28,-113,-105,117,-15,111,22,-46,116,25,-91,40,44,84,37,-4,-66,-125,15,69,-14,49,-12,-11,87,-68,20,91,110,117,125,-65,-34,-36,84,-29,-87,-27,60,-66,-118,-125,49,69,81,54,7,-119,53,-23,-60,-9,22,-116,-125,-58} + +#define IP4_WEIGHT {18,-44,-120,40,104,61,29,-56,-12,78,-75,-19,-34,92,-80,21,60,107,62,11,58,94,-6,-32,-92,-118,106,-105,-104,47,-20,24,43,-116,-108,0,53,-50,-5,-26,43,48,-80,-73,-86,-38,115,111,78,-101,94,-20,94,-61,100,-111,76,-55,13,-81,39,118,70,94,-125,71,54,60,-70,-14,-121,51,63,-121,-121,107,-69,-74,-106,-38,-61,110,60,-28,-43,-116,83,62,26,103,-125,88,94,111,120,-39,-79,-85,-45,-90,121,-121,-97,109,112,34,-97,12,-93,97,90,-45,-59,-105,28,-10,0,-122,-87,-62,-100,-21,35,-115,-26,-37,6,108,-15,118,-41,97,-26,-74,94,34,26,-84,-65,86,1,73,67,59,-99,-67,115,-43,-26,-21,-21,37,106,-80,109,-107,-71,-20,64,-2,-20,115,83,-49,53,-102,-46,121,-75,108,-106,-59,35,45,-102,-41,51,22,25,122,-58,-116,-7,-2,-55,19,-126,-76,-103,80,-34,110,15,82,-73,93,15,-52,117,62,-46,-16,62,67,-19,-39,-27,-12,-89,-100,-37,-41,59,-127,111,99,-15,-57,-79,-43,20,52,-31,13,-12,99,-30,-69,-31,124,-36,-89,43,-1,120,-79,43,-15,-19,89,46,54,113,24,49,85,-17,-119,116,-46,11,-59,94,67,119,110,-57,-1,113,-94,32,-38,110,-14,-81,77,-53,111,118,-13,-19,-53,4,-20,18,108,121,-97,30,-121,117,-35,-31,54,24,119,-74,16,101,3,125,-59,-12,14,52,-65,65,107,60,17,-38,-53,21,-118,76,-112,-53,-108,-38,26,-58,19,91,106,-63,95,98,-4,63,111,-74,37,-47,60,-115,-44,29,-57,73,63,-51,9,-84,22,22,81,-87,-65,-126,7,-93,110,-127,-70,-27,-63,-12,-118,63,-26,-113,45,107,-69,79,111,56,55,-2,108,103,-48,113,120,25,-55,43,-122,-41,40,124,63,88,-78,29,24,93,44,122,-67,107,-34,14,-69,-72,108,93,-37,116,90,-24,-76,67,26,-103,127,88,-48,115,-80,-97,96,62,-1,-22,-123,-65,10,-61,-54,-17,21,-14,-49,116,113,10,88,124,-112,-119,89,88,119,30,-24,-119,-115,-95,58,57,68,-17,-27,-60,59,-64,-26,-127,-35,31,-9,4,-89,18,109,8,-90,88,22,18,45,-123,88,-80,-66,-76,109,25,47,-51,-90,75,-24,-109,-42,19,-72,-8,78,2,-84,-47,68,33,94,-98,-122,-109,82,102,55,66,-23,19,76,40,106,71,-121,-42,-2,76,93,3,123,-111,83,117,-52,8,105,121,2,-4,-18,-4,-19,-125,80,36,29,25,123,-72,-41,38,83,105,-71,-64,47,-127,-82,31,-43,-99,101,73,91,-51,60,3,9,-27,77,124,-3,-96,15,74,35,-29,2,116,-4,75,38,54,-119,8,93,53,46,-18,49,40,-30,-111,-62,97,-8,-96,82,30,22,21,97,97,-35,-12,28,-118,-12,95,40,-16,110,29,-58,87,29,58,41,46,8,105,-108,-29,36,84,-87,-118,-124,53,125,-117,106,-83,21,11,60,-31,-5,114,93,96,-112,-127,49,-126,69,-75,-41,64,60,-98,31,2,-73,94,-100,-44,91,-115,94,12,75,-23,81,46,-89,-116,-25,-47,107,-77,-10,62,-69,-70,75,-41,53,-82,79,104,-7,-106,-1,73,-32,74,-113,-91,-47,-115,66,-96,121,26,111,7,51,-55,20,126,-75,63,-23,14,16,-124,-39,-48,-84,81,14,-27,-56,-41,-13,-43,120,33,98,31,-50,-6,15,-107,-33,41,26,-9,121,18,8,-106,-46,64,127,60,39,-59,-30,-5,-119,-19,-104,-79,-38,86,-121,85,-17,21,44,49,-73,89,73,91,-36,-120,-22,26,-69,-17,-102,-71,103,63,125,105,15,103,-20,-122,-62,-8,61,-116,-78,-116,11,-80,-80,-58,-119,87,-15,99,-111,-87,-84,65,-47,-38,-44,-26,69,-14,-37,-27,-90,-97,29,-4,38,52,-87,109,-72,-50,61,-110,82,-44,8,63,92,-70,-10,-124,69,15,80,83,109,111,25,-47,-110,104,66,32,-16,104,-31,-52,-41,18,102,-70,-49,22,-109,-16,122,62,125,-123,121,-61,-2,92,-90,-81,109,74,5,98,-125,-92,72,101,-120,60,10,-13,80,94,-25,45,-43,58,53,-80,-13,38,-56,-77,-44,-37,46,76,1,-103,-93,74,63,-62,38,-82,73,-124,48,67,-59,-26,116,109,75,70,-30,25,85,76,66,25,-18,-113,106,25,-83,81,-50,-104,-44,-53,-68,124,112,78,99,96,-126,-125,44,33,-75,-29,-60,-6,-26,-84,-61,118,-4,-9,-126,-46,-57,-119,-127,105,21,-120,-121,-33,105,-70,-124,-108,-111,54,-35,-30,57,-101,-79,-48,-65,-108,77,22,44,111,68,-91,-111,41,112,110,56,118,0,-49,62,-54,83,52,-94,38,-14,105,27,78,66,14,106,102,41,24,53,-40,60,59,-124,56,68,-119,102,-70,-119,-101,-25,-95,69,-45,-55,-38,57,-122,106,-96,122,33,-5,61,104,77,122,88,99,126,-74,46,-52,-3,-38,-101,74,-30,96,116,-51,-21,68,74,2,17,71,-124,47,-35,107,-23,64,24,49,41,-50,-23,88,19,-30,10,-96,3,-14,100,-116,55,-91,84,100,-54,125,67,-40,-124,53,10,-126,45,21,-84,13,2,-62,-47,54,72,82,-50,-2,-66,103,-61,-20,-17,59,54,-110,-1,96,-70,-57,123,-111,-94,-125,3,14,37,123,-86,-44,-9,109,-101,-128,113,-104,80,-94,-87,111,120,-7,3,-49,-51,49,-32,40,33,-62,18,-94,-57,-71,-92,-52,3,105,-86,-104,123,1,-93,-73,52,108,38,52,40,2,-44,-62,91,5,-48,114,-61,-40,-128,-93,-88,-91,-115,62,-24,-30,-85,-43,104,102,49,10,-52,25,-52,-94,-20,-103,-25,84,-56,-103,51,-110,26,1,-82,-102,32,126,-108,78,-108,30,86,-17,-23,-112,-32,32,80,-112,-86,-115,8,24,9,-121,-125,91,-73,14,-69,-95,-2,101,-109,1,-49,-110,84,25,24,66,-72,54,108,4,-36,95,126,-63,56,99,-103,-35,-80,5,3,-61,-8,-10,-10,78,-73,72,42,-83,-115,84,97,-66,20,-66,-46,-57,-99,78,-120,120,30,-88,-29,118,15,-110,-52,-92,25,113,-30,92,-94,-29,90,105,89,-110,48,-44,-1,-96,-1,64,115,-3,57,24,-39,118,-2,81,37,15,-47,-14,89,48,-69,-32,-95,-114,-77,33,-103,-127,-82,-9,-100,14,-38,-76,-63,51,59,-31,-8,-75,-37,76,-32,69,101,40,26,80,-23,-110,-23,-84,-67,4,-31,122,65,101,-83,111,-112,-123,124,-56,67,12,-23,-43,-47,55,-87,66,19,21,-12,54,-105,100,35,-89,-80,-76,-85,-61,-9,33,107,42,120,-49,-117,19,-80,-65,-71,86,106,77,-34,-50,108,42,21,65,69,127,-38,-27,-77,120,-28,97,24,-20,89,-66,-63,-17,-110,43,-43,-117,112,-126,28,36,103,0,-68,115,-69,107,-99,53,94,9,-105,-27,70,2,47,80,95,-83,28,119,59,95,16,17,-16,15,-6,4,82,-94,-89,64,-49,-122,88,21,47,50,-21,29,121,-47,-83,-113,-78,-25,-101,9,-36,72,28,-68,23,-67,-98,-24,-101,-98,-28,-89,115,-101,-89,82,102,-124,40,125,23,97,-113,-58,-7,-90,28,35,83,-53,-26,-119,-108,-83,97,-74,6,-40,101,8,11,79,117,-65,-15,-10,-72,-99,-98,101,80,127,95,60,-116,79,2,60,-62,104,15,-29,46,-79,-92,-118,-43,73,107,-43,67,-73,-67,44,74,-111,117,-127,-98,26,113,-41,59,79,45,-60,-30,114,18,54,-124,-52,21,-26,10,-82,-72,-70,-126,-97,108,-19,-52,10,120,-111,102,18,99,49,-128,-17,91,83,-72,-19,-3,45,-104,14,-46,-76,3,112,-41,47,122,-77,-35,121,44,-45,-123,-60,-58,43,-23,41,84,69,-2,50,-69,-98,-11,112,-11,98,-36,67,-33,51,-17,-95,-45,-126,-69,-52,81,101,-38,68,75,-109,-78,107,0,45,67,-37,-100,-55,12,105,11,-24,3,-70,-16,-97,-63,52,97,46,54,77,-22,35,125,93,58,-61,66,-61,-79,-58,-43,-45,-49,-63,-98,12,41,54,-63,-36,48,-33,-110,-36,-76,-48,73,-33,-87,-81,-49,93,-6,4,-78,50,-88,-30,-33,10,30,102,-94,38,97,73,-109,104,6,37,94,-124,56,-106,-18,70,63,10,-31,-90,-113,-116,84,4,50,-18,-27,54,125,-86,-119,33,-127,0,-128,-77,-65,-63,64,26,-79,60,-25,76,5,-5,101,69,59,26,67,121,-26,-79,-91,-49,-87,66,71,-22,7,-73,-51,-114,-18,-72,40,-87,-55,69,0,-22,-23,-96,-115,29,-119,68,-102,124,120,-6,74,5,-111,-85,-99,16,-28,-92,-34,87,-42,-36,123,-52,59,103,-77,43,-80,0,-86,83,-81,96,-15,124,41,-62,-22,77,43,4,71,104,-62,-98,-13,-99,107,80,-121,72,54,-63,-13,10,78,-108,-95,-90,122,88,-92,-119,95,-117,-76,76,-115,52,-10,122,-108,-13,101,12,36,63,26,39,36,-72,-80,107,82,119,-57,-7,-118,-91,-55,-54,11,-30,-44,77,-93,58,-25,102,11,80,-62,111,-33,29,105,-63,-98,51,-77,3,-6,52,39,-50,-80,-5,-50,93,-103,-123,-77,79,-58,-101,-122,116,-20,-16,-45,110,93,-11,57,44,3,107,-118,32,126,-90,24,-60,-25,60,64,80,124,-22,-95,-57,-47,15,-46,-28,26,42,-91,83,74,42,1,78,113,-76,14,33,16,-16,37,89,108,74,20,-93,23,60,107,-22,-117,111,52,-97,-15,86,-127,9,-17,28,78,53,-17,5,123,-78,-120,-76,69,-76,-98,-42,-64,-17,-99,-113,13,120,126,-88,-35,20,10,44,84,-35,74,12,81,99,55,31,115,18,-125,110,2,-82,-110,-94,23,-4,110,84,-122,40,-3,-75,62,-62,34,2,-120,42,-24,-10,124,-46,111,-99,-11,57,126,41,-38,-14,6,27,109,27,72,-29,106,96,82,-69,60,42,92,127,-24,96,53,15,-18,-104,-79,-70,-102,102,-36,-84,32,-119,2,-77,-53,79,7,-24,84,115,103,54,60,-7,19,-49,-7,114,-7,89,1,-64,80,107,-22,-5,-2,-63,-26,-51,-108,9,-111,17,-40,-51,58,108,-55,-68,-117,-51,13,4,-17,-33,-110,-95,99,-117,-23,-71,46,69,4,119,103,31,-117,6,76,-36,106,-124,-30,23,76,80,39,6,18,-3,78,3,-118,-52,23,-100,69,-91,112,40,-16,18,-55,75,-77,126,-87,103,-23,50,7,106,-16,126,41,-127,72,75,105,77,-19,112,67,-102,-69,0,53,-72,-95,53,-4,-56,30,47,38,-60,100,-127,-16,-16,-97,-15,46,90,23,45,-18,29,-111,-38,73,-112,44,115,-93,-32,-104,97,86,69,64,61,-68,-10,-112,60,19,32,87,69,55,-4,123,-105,-28,-82,-1,80,-92,-77,52,-38,76,56,81,-40,-14,115,3,-14,-59,-115,-39,-124,-78,32,69,5,-123,50,70,34,61,-57,-108,-22,127,-13,81,35,-35,34,68,-125,-120,109,89,-21,88,107,-114,99,110,-19,-54,90,87,-32,-81,115,-27,-82,-92,65,-126,64,-94,-90,36,-93,-45,-121,26,-114,-111,118,70,10,-3,106,80,-101,47,125,-12,39,88,-81,10,-25,43,33,-72,114,-109,10,98,-98,-115,-88,96,-43,-80,91,28,105,-122,85,123,-58,26,-26,103,-121,20,-62,101,-88,-113,-36,-88,-66,-58,-46,87,125,-100,93,79,-108,103,-19,-45,-19,29,40,33,49,-48,-15,0,70,122,121,118,86,6,49,111,-26,-67,-28,102,-83,86,50,-86,-124,-104,-28,35,42,126,-128,-87,-70,-109,-94,52,-25,123,-3,-6,18,-49,-120,-62,-89,-37,99,94,109,-85,100,62,-107,-126,-116,110,10,113,-19,-52,-101,84,-44,93,96,-110,-26,65,-45,28,5,-49,-78,-48,62,127,-53,120,-96,67,127,34,91,49,57,-67,107,-85,60,-60,-6,-80,-77,96,127,50,-52,-34,-52,-8,-119,-60,-76,89,-64,-1,34,-25,99,-47,45,-46,-47,3,-85,100,-94,-14,59,12,47,-74,-49,103,-6,-29,6,-25,-2,-23,91,-79,-1,-11,108,0,-44,-48,56,75,-71,-29,-35,-100,-100,54,-62,-77,-46,-56,-3,-98,90,-126,124,1,-26,75,104,101,-113,68,-127,-88,4,39,-106,95,-67,127,-15,-36,23,-71,52,-118,-67,9,10,-12,-51,-77,104,-22,-39,-106,53,34,-67,-35,-38,84,87,-124,41,-98,-74,-103,-125,95,38,-31,3,-89,-107,-106,-24,-90,-58,18,14,-41,-9,-86,-93,-39,83,23,36,-56,75,-119,80,10,109,45,57,-36,-123,113,-68,7,13,35,32,-17,28,118,-119,52,-37,-102,-18,-1,-98,48,-69,6,-97,37,-4,-59,15,40,3,101,91,-31,5,-9,105,-9,-33,-31,-71,46,-99,-71,70,-77,-38,-7,-112,73,42,-2,98,53,48,-1,76,-117,58,-62,117,-127,-66,-120,-33,33,2,-35,67,-100,-117,-82,115,76,15,33,-125,-5,49,91,-111,84,27,24,-89,-87,-72,-35,-49,100,74,65,-71,52,-67,-128,114,41,-63,82,127,0,8,117,5,126,-108,87,8,20,-76,-102,123,71,-73,-37,36,104,-71,-50,-56,41,-26,-62,-105,31,70,18,8,16,-122,-52,-127,11,-100,-109,-35,-86,40,29,-78,-58,-84,117,88,102,18,-45,115,-54,32,-36,51,-66,20,107,38,-119,26,56,52,-77,65,126,78,-113,85,-92,-35,-70,-41,-47,43,-72,-79,-67,-24,-66,-7,-9,62,-77,56,75,67,98,-47,43,-78,-116,-2,49,65,53,20,102,113,-4,-12,-36,8,103,51,-79,-37,-90,49,50,-118,62,107,-120,4,79,-17,61,36,61,96,-117,123,1,51,-15,17,11,-108,39,-87,53,36,-19,-69,126,-72,-91,-90,123,-27,-51,-40,79,-61,127,-62,41,11,14,-67,32,-109,-70,47,38,-1,76,-17,-120,61,-104,73,31,-37,35,-26,106,-83,-53,18,-18,18,-21,59,93,-31,-85,75,-127,19,66,10,4,-62,45,-109,13,44,-74,-25,13,-47,18,30,-59,-96,19,-113,68,46,-5,91,-110,-115,-18,65,-90,25,-75,-21,1,-88,-91,13,93,-61,24,85,28,-17,55,86,27,-14,-60,108,-110,-18,68,113,-64,64,58,52,0,32,70,-52,-97,-100,-9,111,43,-88,13,0,-112,34,-104,108,-125,-9,-32,110,65,-64,92,66,106,113,-116,-35,3,121,-91,13,-75,-44,91,-88,37,-84,-16,-117,-1,-49,13,81,21,33,113,15,-83,27,-77,46,-17,-19,-115,-37,-95,28,83,22,-56,106,66,-57,63,125,53,-23,69,49,-25,-15,-120,106,-86,40,-107,-76,-96,43,101,98,55,4,-116,-89,-26,60,51,-21,106,53,2,86,83,-119,47,42,-49,110,-5,-50,27,36,-75,52,-59,-71,124,28,60,6,63,52,63,-67,16,14,83,65,-58,23,30,49,-27,-66,-26,-39,-88,-46,-81,-123,-61,-18,42,60,-22,-61,-60,66,92,-83,111,100,-72,116,65,-100,103,111,116,50,-5,111,72,101,-88,18,-65,8,-78,87,39,54,113,-70,-44,-128,-70,29,112,63,-52,-48,12,-27,95,93,-31,9,55,-70,-109,-42,-71,122,-46,-115,-58,21,-27,125,9,-82,53,-22,-50,-71,125,50,-6,45,50,-14,-72,95,51,-74,104,-86,57,65,-39,6,-10,-76,-23,103,127,17,-95,10,21,-52,87,24,-128,-36,95,95,21,-96,-14,-44,-8,74,-119,-123,61,-24,-102,107,0,126,83,51,27,-17,43,-95,24,79,-106,115,-64,124,8,-75,-96,118,-84,69,3,122,-97,122,96,-106,14,65,-118,-64,-82,51,-29,-78,-80,121,-66,74,-82,106,82,77,-28,78,-119,121,56,-45,-120,96,-116,-70,-13,41,-109,-91,-55,-49,-31,27,90,-77,-36,97,-78,91,95,-91,-116,-17,-42,111,112,-51,68,53,-21,87,64,106,-82,62,92,-68,-38,-25,-77,-109,-121,5,75,-108,-55,-38,-14,-87,74,-96,-62,12,-97,-91,126,-71,24,-45,97,-19,93,42,-10,-97,-5,79,6,-80,77,-111,-78,18,42,-61,-99,-40,39,-69,64,77,-123,-30,82,127,-39,66,-17,96,-82,-117,56,83,46,46,27,10,-70,77,16,22,114,24,-88,16,118,116,66,-70,114,-89,80,-25,-84,19,111,70,-86,10,-20,-114,80,-95,-15,-77,-88,-1,-121,26,-82,95,-104,-120,-7,123,-20,46,69,59,-76,-41,97,68,100,75,-12,24,-23,79,82,-115,81,-125,-69,-100,-46,-112,-3,44,-108,-121,-55,95,-48,-22,-10,-60,53,48,22,89,16,77,-40,112,-54,-110,79,-99,-51,94,59,-50,31,-55,34,60,64,-5,-103,-10,-58,-10,-115,84,23,112,96,75,87,-79,-106,55,71,-92,85,4,-76,53,-77,-33,-8,63,118,-84,24,98,107,88,-22,-88,-60,99,-41,-36,46,-89,34,-23,78,56,38,-66,-14,123,-80,-6,84,52,-56,67,60,-20,117,115,121,-126,-101,29,-8,22,-108,125,39,-77,55,-31,89,29,123,-46,6,-88,40,26,25,65,15,77,103,-35,-39,62,-58,-118,-25,-50,117,79,-26,-10,64,94,-19,24,44,-79,-67,-114,-114,-31,69,111,14,-52,-71,-21,50,-107,-7,19,-33,110,36,-22,95,63,-95,-71,-38,124,73,-114,120,22,106,-102,-88,47,-5,-18,98,-69,-41,-26,28,-101,-21,-44,-31,-26,-127,85,-41,-105,-31,-50,-120,22,88,111,33,-114,82,-104,71,126,41,46,-53,-12,93,-77,53,-55,-50,90,54,-38,-63,60,-68,-13,40,77,-28,-128,31,-81,-80,34,55,-5,-17,-110,-48,101,96,61,-8,-29,94,30,-128,13,26,43,-6,-60,115,107,-89,-69,54,13,106,107,-62,-57,36,-40,96,114,98,19,-28,14,-48,-50,-60,-64,90,108,-4,-97,75,-54,-71,-107,60,-101,-104,92,-17,-63,25,-60,48,103,113,59,24,51,32,-101,79,42,71,-83,89,65,-26,121,-115,5,-21,-68,-38,28,-91,4,-120,-110,7,122,-70,102,22,89,-58,-42,-57,-51,105,-112,33,21,-114,-110,62,123,76,-6,-83,-14,95,-46,-116,-55,-12,-88,-48,49,84,-64,95,42,114,-8,-126,-67,-112,-20,-94,76,9,-96,-38,-85,54,41,55,127,-46,-121,-38,72,-52,-89,7,117,-95,-97,-113,95,111,89,-105,36,61,120,46,79,-38,-97,96,62,24,90,-111,43,55,14,88,-58,-126,79,-69,48,26,121,25,-89,42,56,-43,109,-81,-50,31,-114,20,62,-88,-53,94,35,69,-1,-93,69,-96,-35,102,12,-86,-44,-79,-49,120,-103,54,-97,126,-96,97,-18,80,-111,-10,2,39,102,-74,-43,-68,-17,11,-89,87,6,-104,-9,53,28,102,-36,-71,-26,-83,-127,-68,-126,32,-96,66,34,87,83,-50,-98,50,-98,-81,-97,75,-48,-60,71,20,-9,108,-74,8,0,124,74,-57,112,1,118,120,-66,-27,-59,15,81,-121,52,-10,42,87,-89,57,31,-1,-74,-47,-89,-92,-123,-50,115,-29,126,-20,-107,51,28,-70,-20,38,-37,67,-114,49,110,-124,-109,-73,-72,7,64,32,101,-51,-98,52,-109,100,-2,-76,-107,-3,122,-89,51,-57,34,-38,-101,-9,47,92,-104,-38,-122,22,15,-18,27,9,47,-58,-20,102,-63,49,85,-71,65,-57,24,-78,-19,27,-113,-112,-48,108,81,-96,99,-9,109,-121,2,-127,122,-47,-67,89,-45,-17,-29,-59,44,-81,55,37,18,40,-11,-69,27,-39,5,-82,-97,0,61,-45,11,-70,31,-104,-3,-98,114,-67,21,-88,117,46,104,115,75,49,18,95,-8,-17,24,55,22,-97,114,31,11,10,-63,-76,39,57,-46,-62,34,68,42,-94,-109,-60,-41,-66,-86,26,-65,-67,124,97,59,118,55,-50,103,-25,-99,-77,55,-104,16,-50,51,-13,-28,91,53,-17,-82,24,73,-54,24,36,-63,-108,-121,-120,-61,118,77,-122,51,-88,104,-31,-115,14,118,29,101,22,76,59,-92,63,122,-66,-48,-7,30,-15,-30,-41,11,2,91,-5,86,75,-110,-87,71,9,18,101,-51,-17,-43,-83,37,-42,-86,-102,-115,106,-108,14,-41,34,65,57,-13,93,-89,25,-69,54,15,12,114,-99,-104,-36,-48,19,-101,-105,-51,51,-112,93,-2,69,122,24,-26,-14,-83,95,-43,77,20,-7,-29,-111,8,115,-102,-67,-97,107,79,46,112,115,-58,-20,-88,98,-30,90,25,75,-47,110,3,-8,94,70,47,22,-103,51,72,58,-12,7,-50,-91,-54,37,27,-38,-50,-112,31,-14,-76,118,30,-109,48,-123,33,70,-95,-2,-7,-111,-75,32,-89,-47,-6,49,112,73,-7,-65,-76,25,67,111,76,-29,-93,8,-95,45,-79,15,-56,23,-96,-58,85,83,84,-70,7,20,-52,106,122,-96,-84,23,33,-101,35,20,73,8,85,112,-86,-30,-14,-93,-30,-8,-39,-89,-27,-36,-107,48,127,-79,-77,49,103,-38,-112,31,-22,68,100,118,-43,57,74,-76,-127,-35,99,101,105,-26,85,-93,44,-1,68,11,85,93,13,-99,-85,39,12,-51,44,-33,-78,12,-63,98,-92,-67,-109,25,-86,64,-58,-5,76,-64,31,-68,-121,-90,126,52,20,-128,-28,120,-117,82,113,-41,27,-128,-39,-86,71,-102,59,30,78,74,94,103,-95,56,41,-128,30,113,46,-11,117,-96,48,-85,-28,30,76,104,-73,101,-89,-25,-79,-22,-103,3,2,83,34,2,-26,-20,52,-82,18,36,90,127,25,13,-21,8,-3,-38,112,-85,-79,-32,26,-72,15,-94,-5,-92,9,-4,-26,98,-26,112,69,-21,-84,-105,-102,-112,46,-60,99,31,-17,3,15,-83,-24,-123,-6,-47,-120,35,-100,125,35,96,-33,22,70,5,89,86,38,64,-55,29,55,126,-125,17,52,113,53,-82,-3,62,-80,89,104,34,77,83,-65,-4,89,2,-114,51,43,-28,-27,-94,-41,68,-37,-85,-36,93,74,-120,-63,109,-70,102,36,-93,-8,44,77,-92,114,50,88,16,99,-67,-9,64,-43,-64,53,19,-9,-70,89,-57,-81,114,-99,5,87,-100,-101,66,75,-120,-70,-31,74,85,-44,-37,108,-32,92,80,-16,123,100,-102,99,-38,102,30,112,-89,102,96,-6,-90,-80,-9,9,2,-40,-114,-128,46,119,52,-47,87,-41,-81,-112,-15,-107,79,15,45,-88,108,-22,19,27,105,-53,82,59,72,36,118,123,-93,-44,99,-8,-98,105,33,76,-46,93,-110,-51,64,-80,-58,-103,87,26,-4,-54,-93,83,70,20,-13,76,-52,21,-13,127,-93,-7,19,102,17,23,41,14,93,76,7,94,54,-81,67,-52,-61,-23,-92,9,-127,-125,99,-128,88,63,-118,110,-24,-76,-53,123,-79,-65,71,59,55,22,-64,-111,48,25,-79,-45,-102,-78,-85,-53,-67,100,0,72,-71,98,56,-6,-46,40,30,19,-42,127,-54,40,58,34,-6,21,-78,12,2,-42,58,-44,-112,-113,-55,62,-14,-25,-127,-40,85,-80,-72,8,29,-27,73,-36,-32,-21,34,-46,84,75,-123,72,-41,-92,41,-12,41,109,106,47,123,20,-73,-38,117,44,69,-119,-102,49,-97,9,-89,-128,-53,60,-65,-43,-39,-118,-33,28,-41,58,-41,111,-25,110,-58,105,90,20,70,39,-21,50,-114,-104,26,-98,96,-16,74,-85,-68,-35,-80,63,58,98,119,21,-124,118,-77,-11,-125,23,-101,-9,8,-61,92,-28,-112,30,-57,93,-49,32,-48,92,87,-96,-29,52,103,-97,-27,57,116,77,-25,-107,-77,114,-96,47,-79,-58,8,-72,-50,99,-113,-80,24,-19,-83,69,-6,92,-5,-115,17,21,-28,-43,55,39,-60,-55,76,-127,40,-43,106,-35,-6,-79,25,19,-59,121,112,-57,-111,4,80,-39,-77,-103,-89,-113,-38,43,61,-125,41,-105,-127,28,-33,124,-50,58,69,2,99,-31,-88,-83,-21,90,-56,-49,83,-119,113,56,38,92,61,-74,-2,101,-73,-53,26,-95,32,119,-23,-114,-7,116,114,-52,49,81,-88,-102,76,-73,50,38,5,-63,-49,-126,69,-124,-47,-13,-53,11,-42,-97,46,83,29,112,41,125,35,46,58,-17,-43,-2,-5,-34,-96,49,29,-13,-80,-82,-112,13,67,-17,84,96,38,81,49,65,117,23,-97,-60,49,-43,-34,-74,52,3,93,-93,-26,-88,-54,5,-113,-73,123,4,-95,17,103,-41,64,23,-90,-35,50,-112,16,26,-104,-119,-41,5,95,60,-31,58,109,-71,-26,-118,28,-71,-126,-93,-50,30,85,71,-31,-92,-48,-65,-48,-51,-52,112,-2,-75,74,-24,41,121,-20,97,122,-49,-73,55,104,-95,38,23,-83,119,-22,-118,45,-37,-105,55,-122,-4,52,34,25,47,37,102,89,125,-12,7,85,-6,-92,107,13,97,117,60,15,17,79,-16,18,20,-80,-3,-23,-70,-125,-81,52,105,88,-111,81,124,-40,28,-36,-44,-57,-96,-49,-5,1,77,-37,-73,-107,-79,18,71,-124,-70,32,53,33,-83,-34,43,59,71,-55,-53,78,33,-125,20,-97,44,15,59,80,-20,65,-72,93,88,23,-3,-44,117,68,-125,64,123,-30,-89,126,59,38,32,-31,-27,125,98,12,-43,-5,40,-59,98,124,-104,125,-48,-74,62,-104,35,73,19,-8,60,43,-6,-62,47,-3,100,37,-125,-100,49,14,20,-15,76,29,-125,95,-74,-85,-56,8,58,70,94,-60,-112,-37,-50,73,78,19,23,-56,82,37,22,92,-40,63,-49,116,113,41,-11,-5,46,-123,45,27,82,106,102,24,85,60,-108,63,-67,53,-126,124,114,-14,-108,64,-6,-27,-19,-101,102,-68,93,-45,-4,69,-109,-27,112,-111,-64,93,-36,-128,-78,-16,-79,-4,-117,-8,-40,87,-79,-62,-51,123,70,-39,-94,-91,15,18,11,-82,100,-104,-59,13,42,98,-51,110,102,-76,40,71,117,-81,-120,-120,79,-17,44,-128,-51,-41,-48,76,123,-20,-44,111,71,-41,-86,123,5,80,124,55,73,-76,-32,21,5,-43,-65,34,-46,-55,-108,-24,111,110,59,-128,59,58,116,-86,-34,85,-61,-111,45,-125,-47,-37,79,48,-56,102,-96,-94,-90,-127,-17,-109,-95,-52,16,-77,40,108,-85,-93,10,-25,-94,31,-59,-2,95,-26,-28,-88,120,30,-69,123,42,90,67,123,86,-24,-9,116,12,81,-92,88,-86,10,-77,104,-75,-119,-43,63,-95,-16,54,-111,-3,-54,-7,-96,112,-68,68,-113,-88,3,-37,-40,55,80,-128,62,-32,-13,74,-48,-21,-64,118,-78,19,-41,-75,-10,97,64,-126,-81,20,-79,-112,86,-20,127,56,125,-84,69,73,65,-53,101,118,-15,-30,-62,52,105,-59,-54,-87,-48,99,-116,-120,-107,-40,87,87,-108,-19,49,71,-98,58,86,-125,-55,-31,-38,91,-76,77,-119,-62,52,123,23,85,120,49,122,-19,47,-83,86,-15,-69,-86,-118,-56,-121,21,-74,-82,119,-39,59,87,-45,-38,19,-67,-13,-91,-84,1,54,-96,-58,-122,100,-118,-97,73,94,20,23,-30,-4,-7,-72,-30,-38,22,-121,-36,-85,50,114,95,8,45,-85,-89,93,30,-105,35,-53,87,-41,93,117,17,-61,-61,-113,10,-52,-99,89,107,69,48,-27,80,-75,-104,119,-76,-30,125,-37,24,55,8,31,-14,75,122,13,33,-13,-37,98,101,-51,27,-49,85,-51,-15,18,92,24,37,-122,-30,110,83,-17,101,12,-54,111,-7,4,-82,90,-91,97,-99,29,-75,73,-46,106,45,68,68,-35,-28,99,-74,74,-70,-111,-63,21,-22,86,-122,-80,-93,50,14,-105,82,45,-41,102,-38,-9,-84,-94,-89,-18,-50,74,120,90,-17,52,-63,-83,-17,124,-118,43,-82,-80,123,-119,-106,75,98,0,-76,61,107,-72,80,-27,-70,-100,77,100,89,-18,-49,93,-52,-68,-46,103,-69,-9,13,-65,39,-89,49,-52,-88,-77,-29,-33,-119,-105,96,-128,5,86,55,-94,-43,29,48,109,73,-76,62,-11,-82,-32,122,-88,-16,29,-40,-69,-59,52,33,77,67,63,-89,-106,112,59,-67,38,-33,-115,-120,81,8,6,-92,69,87,107,40,9,9,-31,-68,-117,-81,-110,113,44,-62,-85,-23,77,-6,84,-126,80,-45,105,75,-62,-8,-63,58,-2,34,-48,38,107,-16,-82,-128,-47,-44,-113,-99,121,-29,-17,57,100,-23,12,-110,42,34,-64,-124,5,-13,105,-128,112,-4,100,123,13,-125,-7,117,86,53,-128,-87,-122,-60,-18,-77,117,-35,-81,-75,100,-124,116,-110,82,77,87,125,-100,-105,123,100,2,-4,29,-127,-49,-77,-54,-117,-110,-101,6,63,-103,122,76,-40,54,-86,53,-103,52,-3,-118,108,57,65,86,-106,-41,51,82,-44,92,-63,4,-99,17,4,68,15,22,-83,-126,65,16,105,76,80,96,34,63,-115,79,-115,-109,-50,-71,-61,-89,98,-123,32,-88,113,81,-29,92,-36,120,110,56,18,108,-31,34,-24,77,84,-8,25,-98,-4,-102,-33,90,76,76,-128,-104,-105,-65,10,101,22,-80,89,77,3,-62,29,-36,-85,-116,120,-44,-107,63,45,-125,-108,16,-29,-103,-38,-19,-126,113,30,1,31,-127,26,-18,-56,-85,47,32,102,-109,-6,-120,-121,-50,-121,-25,-7,-127,-34,55,-114,-69,-34,-6,-44,123,25,-34,82,101,-21,83,-2,33,-23,-108,-107,106,60,56,-30,8,25,-46,-46,-31,-78,38,108,4,124,12,29,21,-87,89,100,-116,-46,37,2,-53,109,40,-48,77,-60,-64,-68,121,-84,-109,-71,12,-118,122,-25,-73,80,28,62,-88,-89,109,106,-74,-64,89,58,-27,96,-74,-62,-110,-73,-65,-73,-87,-128,-122,-72,6,29,22,73,62,-99,54,42,31,-46,-37,-87,23,63,114,10,-63,76,68,-24,30,-86,-20,-43,-25,-12,15,124,-43,38,111,-121,119,39,-49,34,-32,27,69,-5,80,86,-42,-51,-74,-71,-24,73,87,-32,-11,53,-24,99,-25,74,-11,-115,104,117,-78,-7,-113,-99,-103,-10,-20,121,-9,-35,-76,112,111,-68,50,-9,96,-108,10,-38,94,103,-73,-64,116,99,2,-18,-22,22,90,-105,-68,-42,124,-122,90,-52,-43,-6,2,-22,-117,-119,52,-76,47,72,-84,-19,-85,-124,15,127,-115,36,-39,-109,92,13,-76,47,2,107,3,90,-24,1,102,26,-17,-27,-114,-112,-74,-29,-57,-108,-21,32,-104,76,-47,-17,-77,52,38,106,-68,-63,86,-86,67,-28,114,-81,23,-57,-110,-81,64,-1,-97,-29,-25,-24,95,-35,-118,-99,-96,-11,68,-118,-84,68,-1,12,-39,77,80,111,-113,94,-123,97,93,-80,-117,-52,5,-24,-108,70,-27,48,-21,123,5,-98,-28,63,-96,-37,23,67,-33,-96,-50,-124,47,-58,-109,-64,20,-37,44,-101,34,95,-62,-76,-57,39,-51,10,100,94,-37,-72,-4,-21,114,-21,113,45,122,-117,-77,47,-82,40,-68,27,43,-99,105,18,-15,-7,112,27,-110,47,83,-8,44,-50,-86,-37,64,-58,-53,1,14,18,-33,69,29,100,51,35,-44,-99,-17,-90,38,107,-58,-103,106,-49,-90,23,40,-76,-79,7,-106,84,107,-44,-58,-50,-21,-10,-47,34,91,-9,64,20,114,-11,-76,-105,23,113,58,44,-91,-62,-55,38,-101,121,-22,100,81,-55,94,-46,94,-125,78,43,-128,-101,118,-103,-36,81,-8,-66,90,-3,116,-90,48,45,-49,104,2,44,-69,-78,28,-65,-90,-54,103,-71,-62,70,15,-31,36,-81,14,-103,-35,-60,103,-13,127,-54,-32,-93,117,48,45,20,-89,-23,127,59,77,3,-84,-35,-27,44,87,60,-16,-112,-56,37,103,78,-115,11,-3,-44,45,61,121,-106,-104,88,-39,52,-112,-102,104,46,-67,102,-91,-77,-13,-79,24,-59,61,-90,-34,101,118,-52,-84,57,-5,46,-62,47,-66,-18,121,81,102,32,89,-78,122,28,12,-110,-123,-19,-38,8,-78,-94,22,83,111,-36,92,60,-2,44,-59,-43,-2,-66,-29,-71,92,-51,116,-78,-2,39,124,103,7,19,92,7,-66,-100,107,127,-115,80,-3,59,98,-95,-93,11,62,99,-126,-61,-74,109,-58,87,-24,100,122,96,-65,-71,-38,-118,113,21,-71,100,-103,-106,-23,72,0,-55,-105,-90,88,73,99,37,-68,-108,59,-41,82,119,76,-41,-62,94,110,53,67,68,-62,38,18,-37,-24,14,56,-41,-121,-84,13,48,50,-4,-17,110,-77,77,48,116,8,111,-80,-63,-4,112,19,-9,-127,88,-45,72,-85,63,64,-32,74,-61,77,-90,-75,125,-46,-15,-99,36,116,76,0,95,-86,79,14,-55,7,46,76,101,-115,67,-124,38,71,95,-70,18,-18,-35,-42,13,-104,8,98,77,51,-82,-26,-61,-66,2,44,114,-27,-61,-119,-70,26,2,27,99,-99,14,82,30,63,-88,-97,13,97,34,-47,-99,-44,65,-13,48,47,4,78,41,37,11,8,99,117,-29,-59,-94,-7,28,-125,32,-109,14,-61,45,11,101,47,84,-13,-58,-49,90,100,-94,77,19,12,-24,-91,54,112,-48,67,5,-86,-63,47,3,73,4,68,-26,-64,110,-79,-18,-96,105,-35,-36,-71,113,67,36,23,-14,48,68,-33,-5,6,82,-56,-20,29,8,56,39,-33,121,-11,-43,-78,28,-29,-101,116,-98,-76,-81,-72,97,-16,107,123,-89,-47,-84,-67,-77,-107,105,29,49,102,-113,-41,-18,-24,-112,-19,54,49,41,50,-25,84,15,87,61,20,63,-118,42,103,33,48,-48,-121,16,82,90,-13,6,-40,2,-74,-85,-68,-4,-14,-76,17,-101,81,-80,7,-117,-64,-54,21,-50,102,-2,99,21,-74,8,74,-36,-89,-75,2,28,-29,-105,53,126,85,-35,71,-118,2,-55,-84,2,9,-20,124,83,4,76,50,95,-104,45,81,88,-113,10,66,44,-110,122,73,-78,92,-85,5,3,17,30,-32,-127,26,-53,34,-75,81,54,7,96,9,-42,109,6,-15,-13,119,34,-126,-102,67,-70,116,9,-12,-88,19,-9,85,91,-26,103,39,92,116,88,-87,33,-43,120,-68,-87,-53,84,-99,-28,96,-59,3,48,12,-18,87,21,-88,86,-56,-36,63,33,-80,-97,-93,116,-36,-38,100,-65,-62,-87,66,-65,102,104,85,73,60,-96,77,103,-80,-70,-99,103,-6,-67,1,-1,-81,66,-80,93,17,-58,-44,90,63,-35,-59,39,-56,-49,83,71,29,-7,-111,92,-114,-75,-80,-54,56,-107,-7,-48,21,54,-124,-3,80,-49,-13,61,-115,-29,-60,-78,96,-105,-110,123,112,-68,126,-87,53,22,70,16,-40,-90,-74,82,-16,29,-70,-84,-47,14,-117,-3,52,23,64,-84,74,-37,6,-13,-57,108,87,-100,59,82,45,87,2,-39,52,57,-79,84,20,-65,-33,78,-96,-61,-61,63,34,37,-16,-19,12,101,-119,-97,27,-13,21,59,32,9,57,-124,127,6,-105,118,80,-31,89,98,76,83,56,85,27,102,16,-57,68,3,-26,5,-95,-77,23,-110,6,58,-21,-113,-78,26,90,-16,35,-23,46,58,-14,102,-117,80,-108,-47,10,83,-42,119,-49,-38,-58,25,-100,-80,40,-54,-122,-45,80,-85,-77,87,-2,-35,-94,-115,63,86,111,-75,-47,-114,-47,-35,-10,84,71,-111,101,123,43,-99,-22,106,95,-17,-94,111,96,10,-3,-89,104,71,22,-52,7,-99,-90,32,-11,106,-7,-112,78,99,-38,-81,-104,-30,30,-16,-110,30,-31,-125,-113,95,-19,-50,-86,-66,111,-50,26,-74,-66,109,4,70,-4,-14,-30,-78,-83,48,-105,-45,-2,-86,-2,102,118,-62,83,37,58,53,-112,89,46,-25,75,22,100,-66,49,95,-104,125,88,19,-76,-35,-40,-83,20,54,-106,116,101,39,-106,32,-82,61,-80,-52,-45,-86,39,103,-71,108,121,120,-126,-56,-24,71,52,70,117,9,5,110,-39,-56,-97,-79,77,71,-90,-97,3,-8,-64,-102,-99,-6,59,-100,115,112,-5,105,-7,85,-76,-65,14,118,65,10,23,24,68,69,68,-78,-60,116,13,40,-83,-118,-2,-43,79,96,-79,-7,-19,-56,-93,-47,-63,-5,96,19,19,94,31,30,22,43,61,121,61,-49,116,-17,89,-104,-41,32,29,-111,121,-109,-51,7,88,16,-80,-105,115,-25,51,-6,-61,91,-84,-41,69,-80,-12,-70,15,39,75,-38,68,40,45,80,-71,62,-22,111,-51,11,-9,44,29,-114,-27,112,105,-68,51,29,-105,68,-106,-95,-109,-13,-82,51,13,-51,-48,-103,54,-91,33,50,-29,17,-65,-46,123,108,-73,-120,123,-52,100,32,-110,-76,43,27,33,-43,-13,52,-79,-30,-86,109,41,0,103,39,10,-57,-90,49,106,-13,-28,-52,124,-15,10,74,52,83,91,-63,95,-23,-124,26,11,-44,114,-48,13,-57,114,-108,-60,99,39,27,-101,117,82,96,30,5,-34,29,-128,-74,-47,-33,-6,-35,-121,-112,-35,109,-118,-69,117,-80,-18,20,-102,24,-33,47,1,-117,101,4,74,-64,-5,-13,-57,-65,-127,25,-107,125,0,-78,27,61,-100,-1,-84,-29,-60,110,-17,-75,-19,-63,-56,-25,21,107,-83,-100,-33,-89,-48,-3,46,88,-121,-55,109,83,29,28,98,-64,92,-29,-65,-63,-26,47,-59,-73,4,65,-86,30,-111,1,-21,26,-88,77,-119,-1,-35,22,-109,-86,75,-54,113,-29,-95,24,-40,127,97,-77,-24,43,-85,69,80,-56,-32,61,125,-18,-105,19,9,65,-2,-18,9,90,2,27,127,10,-15,-57,-76,-37,11,-51,109,28,-55,-63,90,69,48,-13,17,2,-53,125,22,98,44,-96,-94,-116,79,12,-2,72,-11,44,65,88,64,-112,76,61,72,-103,-29,106,-123,-36,91,72,79,92,-24,78,-121,4,-93,74,-28,83,-109,-98,-43,-57,92,98,-23,92,-99,63,10,83,-39,94,50,79,-111,-32,-124,-19,-34,-26,56,60,-79,40,68,-72,91,115,-101,-73,-55,36,-85,3,-86,-73,-113,34,-83,-59,103,10,3,-98,53,-90,112,-114,-101,-1,46,58,-108,-77,-122,26,29,-87,52,51,25,-51,0,32,-61,13,57,67,-108,-50,97,-36,-67,8,117,-124,-59,28,95,-112,-86,-50,105,-54,-108,-111,10,124,53,-1,-127,-43,65,35,-42,-28,12,63,-92,-97,-71,22,-119,-47,-42,10,15,-50,-23,83,-24,-28,3,-42,114,98,120,13,20,69,123,-101,108,29,-36,-44,87,15,77,56,74,-89,-23,65,-12,19,54,66,-31,-16,79,-8,-43,111,-46,-48,-111,109,124,-17,-87,69,15,61,-28,108,118,43,-55,53,74,-102,-72,-58,-88,-54,83,-80,-38,56,116,-80,-66,117,-3,105,82,74,-125,-75,-120,-58,43,88,-5,6,78,-72,-42,4,85,-49,-55,88,-79,-51,90,-33,-100,123,127,60,-115,20,-19,-97,117,9,90,-32,-123,123,-98,-15,-75,122,92,94,-86,41,40,24,106,-60,-39,73,68,93,-91,-86,-41,-80,-120,-27,125,-87,91,-40,-41,-9,5,34,65,-123,-111,2,35,113,83,-66,114,-111,5,60,126,-93,-105,-35,90,57,-68,11,62,-117,-33,51,-52,-45,59,-43,117,36,69,-95,97,83,64,-62,-81,45,110,88,102,-125,1,-51,43,95,43,-22,107,-97,25,-12,-122,4,100,98,-64,94,-21,-37,45,-38,-104,119,64,-74,29,-123,-46,102,-2,-40,115,-31,-8,18,21,-115,27,-80,15,2,74,8,75,82,90,88,10,37,-99,-105,-82,77,110,-49,-104,-1,35,40,80,-97,24,99,-94,43,43,-63,-40,10,64,-3,20,40,-22,77,113,-71,-79,-82,-44,-53,-106,-95,110,-124,-121,25,23,86,104,-96,97,-27,-14,74,54,120,49,-67,-128,-9,-30,-33,72,107,-12,18,-60,21,-91,77,40,38,-12,111,7,-43,36,-15,33,-70,-108,14,-89,44,85,112,-85,-109,-123,-72,57,100,15,-124,-48,98,-111,60,-17,85,11,90,-105,7,-116,-10,91,-10,64,59,-107,-121,54,-128,-98,83,38,64,-25,36,46,20,-96,-108,-71,-1,-17,101,26,126,67,-89,0,77,32,-72,42,-11,44,-14,119,84,-31,-29,-21,95,-8,-74,123,-128,30,27,94,-51,38,-11,45,74,20,-74,-33,-115,-122,41,7,80,35,18,33,16,-6,95,-111,3,-30,-101,15,-59,-92,-69,-67,-86,28,-43,98,38,27,-111,-126,-34,40,68,83,106,-95,-26,86,-54,-102,-110,11,-122,40,-37,30,112,-88,38,-8,-46,46,81,90,-40,95,-61,-109,-110,-123,-44,127,-83,-73,77,81,-23,105,32,81,-55,77,62,115,32,-70,-62,-123,-33,-44,-33,-36,-96,4,52,86,127,86,38,-16,84,21,106,-12,17,43,53,-98,-80,-125,-69,-25,-70,-72,34,6,91,-119,48,22,0,-33,-115,-18,-19,42,-34,46,-92,-27,106,-113,7,78,44,-123,22,-116,35,14,18,50,-110,-112,113,-91,-51,28,109,-83,-51,86,73,-17,88,-64,-114,-19,30,-33,30,-1,-121,-109,86,-58,51,104,89,119,-76,-28,-90,-95,-100,30,-77,-23,-14,-99,55,69,-55,125,72,58,-112,39,67,54,-6,6,76,50,92,89,97,4,52,3,96,-47,-26,126,80,-80,-100,16,53,-119,-36,123,106,-76,67,53,5,58,-13,31,33,-67,111,-42,-16,7,-111,43,51,-27,48,-105,38,23,-110,-17,-12,-98,89,-66,-1,64,118,93,-75,-32,3,-93,-115,65,21,7,-25,126,59,45,-16,-26,14,50,2,107,-19,-110,-34,-107,75,-11,-109,19,-61,54,-115,-63,123,-39,98,125,-94,121,-16,-24,-11,2,77,102,90,-121,116,-55,109,68,6,52,-110,119,65,-119,-47,6,22,103,-121,-32,104,119,-38,-16,-100,49,-117,90,109,-90,124,-92,61,-115,-107,54,-72,93,27,-79,89,60,-26,-77,123,111,-124,-89,-54,-94,108,-119,55,78,-108,95,123,59,-49,42,36,-4,-28,-7,-99,-42,-100,106,59,-65,-24,-100,115,-6,91,-5,-93,32,-77,35,70,-90,-7,-74,77,-20,105,114,49,-6,40,-32,-91,76,-32,-126,-83,-81,84,-103,102,-69,-99,-127,87,113,80,-69,-108,-13,-29,-43,-11,-126,-113,-90,-22,-11,79,-107,77,119,-104,7,-64,62,26,77,-83,24,-90,115,-37,10,-22,-76,-13,52,-57,-52,-63,114,-38,94,-56,-96,78,74,-95,85,-82,99,-66,59,33,-113,-78,-97,10,50,4,32,102,5,-105,-76,-69,-72,-19,69,20,127,94,-57,-26,-117,-7,-38,24,126,-81,86,91,28,35,-91,59,-126,-39,9,-58,124,101,74,120,94,-40,14,-31,26,-5,-90,54,50,-56,-108,80,19,-37,-39,-45,-22,-107,37,53,38,-126,-117,9,-102,-104,83,-73,-125,90,-106,74,109,29,21,-76,-42,-51,-98,72,52,-45,-56,20,51,-1,122,91,-111,-106,-69,55,-108,-93,12,-18,123,11,-3,51,51,96,-100,91,35,62,70,-39,33,-64,-87,-51,-54,-87,15,-81,-125,-111,14,-109,126,126,-36,65,-34,46,-89,70,-119,-49,-122,-47,126,-87,88,-117,62,-89,29,-65,103,100,-107,119,-88,-117,25,-89,9,-36,56,79,9,-95,66,-5,54,-2,95,-124,-95,-93,-126,-9,-54,81,-106,21,69,122,105,-37,-124,98,-25,108,84,39,-9,-97,59,-25,-67,18,-42,3,-105,117,76,79,35,48,-76,-107,78,-75,3,-81,-61,30,-88,-19,101,-118,-67,76,-99,-99,-82,103,-94,112,-71,-105,-24,-91,-26,-110,90,120,62,-116,-20,83,75,41,-7,34,-77,23,109,107,94,-125,74,-78,26,-13,27,99,49,77,-73,100,-115,-36,0,88,123,-65,87,77,-108,-24,93,-23,-60,-63,-44,0,-96,88,-19,89,108,119,19,102,-103,123,69,85,-68,-99,89,11,-60,47,-106,97,-53,94,-56,116,52,-1,-68,6,-55,-107,-3,-9,-59,78,-21,-69,118,107,-105,-3,37,127,-37,18,-117,-79,-43,-108,76,64,-121,-25,-52,68,124,33,-2,27,52,-71,88,14,25,-115,92,110,-36,-16,-82,-21,57,30,-57,-105,63,-75,-72,30,113,-92,22,56,-77,-20,68,98,-20,-15,79,21,-25,106,115,71,32,20,48,15,112,38,-124,48,122,-70,115,47,62,105,-71,-41,-85,127,-35,-21,122,110,30,-70,-6,9,-103,122,-68,-45,42,68,9,83,93,117,110,8,-42,-82,13,105,-26,21,98,-42,27,110,-123,10,109,31,22,29,22,71,-98,-5,7,-91,-112,-32,-56,60,29,-126,92,-7,-64,-77,72,-20,4,63,-54,-128,74,-53,-92,6,-89,-20,-92,106,32,-94,-50,88,52,46,74,22,-119,-90,-69,107,8,3,13,96,-64,28,-59,58,55,-102,97,110,-106,74,83,-95,-49,-106,-26,-93,9,-19,20,-63,87,71,-28,-52,125,26,49,-73,-11,112,72,-117,-65,88,-33,21,14,121,-29,-74,-128,4,102,125,112,-49,12,118,-28,82,97,16,-82,-7,4,121,46,-71,28,85,50,78,63,-94,74,107,-59,-48,-24,76,-112,93,-47,-67,-32,119,84,108,122,-67,-113,-17,33,-63,74,52,23,-10,-96,27,-54,49,57,-103,-125,62,20,102,7,-20,-58,54,20,109,-18,-78,107,31,-85,5,-32,-90,-61,98,6,64,104,81,125,-100,51,125,104,56,126,24,50,22,23,-100,-128,-82,-86,109,-83,30,15,23,123,-89,14,-48,107,-61,-92,-65,-75,49,-82,-36,-124,-36,-12,10,0,-105,26,119,-55,-47,-37,-38,-17,48,101,120,-118,-92,-89,18,-14,-50,-72,112,-105,-41,-106,-114,-5,87,-100,-125,102,-7,126,-23,-25,71,-111,-11,123,50,57,-84,-66,-101,-76,-106,47,-23,39,-28,102,-65,103,32,-14,-125,82,34,28,-18,10,84,-109,79,32,-112,97,38,56,-36,104,68,-78,-80,93,-95,-70,-6,27,41,33,-120,125,90,-18,-97,30,-51,53,-79,-74,92,-33,-102,41,-72,4,-27,-102,28,-56,114,-117,126,121,8,-126,49,122,-105,-56,-127,-51,63,84,30,-76,-13,49,-112,57,3,127,-111,-45,53,41,-71,34,-85,22,-114,-34,38,97,52,-45,44,4,-111,-35,-98,-24,-53,42,74,22,-89,-19,-119,112,-21,-118,-86,119,71,-52,-88,26,52,35,126,21,-51,-110,4,-120,-107,65,117,-8,-72,47,-66,72,85,3,73,-89,-100,-36,-114,-97,87,72,-27,-111,116,19,71,-53,-68,-121,17,45,-83,-28,116,71,-3,-29,-60,-125,-55,-64,11,4,-123,53,42,-24,-37,104,-22,-2,-77,-122,-45,49,91,101,81,44,-72,-64,-100,-107,-51,-26,108,-4,118,-80,-75,-23,-11,-102,19,-18,-18,125,90,-91,102,8,-54,-35,-35,-84,41,-115,-99,30,21,6,24,102,-108,124,28,39,1,-39,9,26,-8,-9,114,-93,76,44,72,-72,-24,-57,127,-3,-58,16,-1,67,-41,29,36,-92,-31,-87,-124,-34,-23,15,-44,-38,-19,-87,-47,57,118,-2,8,51,121,-82,71,-14,-41,-84,-62,79,118,-20,-12,16,48,5,-127,17,-83,28,54,-95,-89,-97,3,-18,40,-21,45,115,124,15,89,-118,-125,-19,23,-58,-1,2,38,-18,-121,-48,81,39,19,-24,-64,127,-46,19,-16,80,-128,55,121,-43,-73,93,56,-37,123,-62,14,36,-127,42,-117,-43,-99,38,-19,-46,-112,-70,-128,24,-79,11,23,-34,-99,-121,-81,-110,88,54,-80,-51,51,83,10,-76,-53,-58,-35,-128,52,20,27,-109,119,24,51,-19,97,37,112,112,38,-65,84,120,67,-8,67,6,-104,-94,-103,118,-1,30,-94,-127,-50,78,10,58,-97,-95,-42,107,-41,21,-88,63,27,-55,-28,-67,-39,-23,-118,-108,91,-1,-9,16,-37,62,46,-80,-82,1,50,-29,-55,48,-41,78,-112,34,12,-53,123,41,-94,37,108,-16,-42,46,1,-123,-50,71,3,8,86,-39,-24,-82,-86,20,22,8,-72,51,119,114,-110,-55,115,-15,74,83,93,93,51,122,3,-125,28,14,59,41,-56,107,-17,-21,38,-59,71,-23,0,111,79,75,113,69,-48,-17,-110,38,-29,87,32,50,4,-41,-56,12,-27,-77,-87,-113,-4,-117,-99,-20,-61,115,-99,40,-99,2,29,26,119,-86,112,-95,-31,4,-21,-102,-53,94,-82,45,-65,75,116,-85,-17,-109,-111,23,-23,-110,1,-97,100,29,80,-90,93,-18,25,95,112,-22,72,74,3,77,-29,-48,-106,-117,94,9,95,97,-109,-104,-124,-94,-29,113,-1,66,33,-28,12,91,-88,-102,77,-16,-116,-65,95,-79,-107,-76,21,78,78,51,54,-51,-123,2,40,-105,14,-90,64,112,124,49,-124,71,-114,97,-3,3,-83,-105,-50,59,-63,94,35,73,120,-43,116,16,-91,-46,-18,123,-97,-26,84,-119,72,-117,-108,-21,-118,-84,75,34,-59,-108,-104,-26,-11,70,63,53,-81,-65,21,-63,-55,-108,-35,-125,-58,-115,-16,126,-72,7,0,-76,-13,-54,59,81,-118,-12,-67,121,5,27,-23,-6,-79,-125,-14,-19,-45,80,87,-56,-118,-85,-37,-43,72,71,-49,-22,116,-121,-90,-59,49,-91,31,46,-62,34,89,-4,12,23,40,26,-7,-54,120,-89,-37,-39,88,42,-18,12,34,67,123,61,-91,46,54,-38,-104,100,-75,74,-36,0,28,15,113,-44,25,-56,103,28,-16,-92,-100,-7,58,28,44,-75,-121,34,-113,38,-99,66,-2,45,17,-19,11,-45,41,-20,-122,-72,38,110,-58,6,64,-86,44,-73,-70,-45,-93,121,53,36,91,-41,52,17,43,-71,-90,14,110,97,-53,36,-75,-32,122,115,29,102,-88,-46,92,53,-39,20,-102,46,-91,117,-26,36,-108,55,-101,-120,85,82,14,101,-81,-26,115,-24,33,-47,18,-108,33,-18,-50,-46,-24,7,-125,-71,41,99,-66,-2,-14,-25,10,-112,-74,47,-43,10,126,117,53,104,-77,-57,-30,10,34,93,69,-116,65,24,81,90,88,115,89,-90,72,43,51,10,-37,55,-12,-4,40,123,-85,-90,123,8,13,109,105,112,64,-16,25,-83,44,-54,-109,99,-74,54,-82,104,-20,64,-37,-3,-17,-72,40,14,-64,89,36,107,124,-84,-74,60,-47,6,-98,-125,63,112,-41,-70,-62,115,-56,30,14,127,52,109,-38,27,-112,76,-65,114,78,26,-53,77,60,-107,-118,-120,24,-74,-96,48,29,49,-15,-9,-115,1,58,-21,104,-117,-91,-109,-89,-26,-84,82,36,116,121,52,-28,-50,-103,-87,-93,-103,93,-108,49,-39,37,-115,38,-37,-28,-2,-37,-26,19,11,-120,-68,14,-107,-49,-41,107,17,24,24,-100,6,-7,46,-122,102,35,-110,93,-53,98,-84,38,65,-8,-6,-99,13,23,-5,-4,24,7,44,86,66,-111,67,-65,19,9,-92,114,34,-26,-43,-61,-11,48,29,58,-57,5,-105,-33,77,0,-41,22,45,-51,-44,-99,20,-61,-49,-20,47,-29,-30,10,-11,104,99,21,-11,57,44,108,-84,122,-15,-67,-104,39,-71,-83,2,14,127,5,3,-87,98,23,-9,104,-110,-79,68,94,95,89,40,107,24,26,-97,77,-111,-100,112,-111,-97,-36,49,-69,-95,31,-96,-45,89,127,-1,31,85,-5,-53,-6,-9,114,-53,-69,-102,16,113,84,-6,62,-73,-15,-18,-44,68,-105,-36,127,12,-27,-28,-42,-86,93,-121,-19,67,51,-31,51,-119,-74,86,-111,32,73,35,18,-19,98,44,-82,-84,-84,-106,70,-45,-60,72,50,-67,-126,-5,-67,113,-89,-62,-23,28,11,38,-2,-14,52,-54,-110,-61,4,70,-35,118,-80,-46,-11,-100,-54,-100,0,39,-70,-124,49,-120,-69,102,39,44,-115,-49,-50,-102,65,59,16,90,69,53,-27,-113,20,-47,-115,-28,39,-19,-19,-114,75,59,127,-94,65,-54,-27,-115,-46,-85,-4,1,-43,127,-98,-21,-74,75,-67,-124,22,27,-42,-27,53,-45,127,36,59,-44,-23,-126,-59,-90,-83,86,99,-86,10,108,-99,-45,91,19,115,110,106,85,-83,-16,-33,122,-86,-120,-87,67,-4,-57,4,11,107,-58,-2,-128,-12,-111,-5,-53,-68,-91,95,-68,85,19,-40,-32,20,10,58,-65,-9,-36,-56,79,37,-64,-12,-33,88,123,94,-124,-62,67,-2,41,35,114,31,-116,-100,-32,86,-17,-81,67,-85,-3,14,45,5,-78,-87,-110,83,47,-65,-121,-120,-114,-9,-19,-7,-33,61,74,-40,26,-9,-21,106,63,-70,117,78,56,76,-121,-77,50,104,-125,-32,-117,80,14,87,30,-59,69,-101,43,-98,-11,-23,-10,125,52,97,-19,-56,-94,-108,-41,-119,-38,24,-42,25,65,-39,18,-126,-4,109,95,99,7,-102,13,96,110,74,-89,15,-3,6,73,61,35,-78,-83,98,106,72,116,-127,82,-15,54,-17,2,88,31,111,-37,-102,-24,69,-7,-57,-6,-62,-39,-79,103,74,113,65,117,-32,37,123,-5,59,-15,68,-121,-78,-65,94,120,104,60,5,117,61,4,-85,-88,-123,68,-65,-101,46,64,-80,69,-19,-57,97,-27,-47,54,84,104,44,-15,125,114,16,-23,-124,-100,-87,36,81,-34,-77,-73,95,-126,-120,-27,-20,29,66,-80,-64,77,105,-100,44,19,-80,-18,-27,27,-92,79,116,12,-18,-15,-71,45,116,-27,14,-4,-88,1,-110,51,-101,-14,-77,-120,60,-40,-26,108,-123,116,111,124,93,-74,87,121,62,-83,1,2,-64,-69,11,-45,-79,110,-55,67,53,27,-79,-74,98,-37,97,99,26,110,-91,43,9,-43,80,-64,20,60,-36,-79,-113,-103,-23,-31,-52,68,-112,-7,94,-30,73,-25,42,-111,87,-63,108,-100,55,-94,-13,-1,-29,-59,38,-16,-85,-80,-11,0,47,96,-110,-62,-17,12,-54,-90,116,-12,-6,-128,-31,-3,-102,103,-11,39,-67,-64,-109,0,64,58,-118,-18,93,95,-87,88,-31,102,104,-62,-36,-61,-105,-26,46,-53,93,-24,-10,-54,121,-22,29,117,-70,82,-124,-103,52,-122,84,-76,-64,7,-118,-6,52,-82,73,121,-65,108,64,80,-27,-44,81,-107,-88,-39,-68,-59,9,65,-73,84,-100,-82,26,-56,35,-66,-15,75,-44,51,-51,-65,-62,-84,-19,-31,51,78,-112,-73,100,82,93,-92,53,61,43,-66,5,-63,31,-69,-38,26,48,127,-30,24,-71,-67,-60,-49,-101,-26,-43,105,10,-127,-55,-37,116,38,-63,-109,3,-67,-42,78,-59,110,-103,-17,10,17,-89,-47,-47,62,-41,-51,-16,-31,-41,77,-122,15,94,-96,-8,68,37,116,61,-123,101,-122,-11,105,109,45,-94,-111,44,-52,-113,-74,-97,42,-99,114,105,122,87,-59,85,-89,11,120,21,-51,30,-109,-128,-10,120,-49,-75,-19,-79,-26,-32,-28,59,28,-44,-22,-113,64,-71,109,-84,-11,55,-55,-105,114,50,-71,-111,77,36,99,-100,80,-26,-64,118,54,42,-121,-128,56,-10,16,-105,30,93,19,-99,-75,-74,-50,85,36,-122,-84,-72,-20,-63,-23,-73,-53,-86,-118,-9,96,75,-39,96,59,90,-127,-106,42,-122,46,12,-18,29,-94,33,-84,108,94,-2,81,-58,-75,85,61,122,-43,22,101,45,94,-115,-100,2,-63,-128,106,-49,5,38,35,-8,110,-50,35,-114,-114,115,54,15,37,20,87,-76,84,-13,48,14,9,-99,-93,43,-55,-82,54,-58,32,-91,112,77,34,23,-40,62,-100,32,84,-3,-100,93,17,66,33,19,82,117,102,101,-33,112,-90,-9,114,-1,-66,-71,-103,-38,-86,-101,38,-89,41,-113,5,-40,45,68,89,123,-107,3,21,50,-75,58,-73,5,-67,-64,89,-117,-78,94,16,36,61,-124,45,51,-18,-18,-119,69,22,97,-55,112,23,88,119,65,-103,-62,-97,19,-15,-47,7,-109,-84,106,-5,73,-41,81,34,33,20,-46,-108,-109,-102,67,-116,81,67,-40,-9,-49,42,-67,-57,-33,-38,-89,10,121,-36,-113,61,28,-94,-67,-28,52,-84,-38,-96,117,-44,-110,-17,-116,-53,-53,-51,29,54,98,-76,18,104,124,10,-36,15,47,117,83,80,34,-62,102,108,91,-112,-116,87,74,-68,55,25,-34,-10,66,51,-47,-123,-67,-122,57,32,-96,-87,76,67,31,1,13,96,-64,-15,-125,-41,-124,-77,99,47,74,-16,36,67,108,3,105,-44,97,44,-53,-4,-9,-120,99,-55,-30,-122,14,8,40,86,-64,-34,118,-65,-23,106,-95,-26,114,89,97,71,-108,-59,-10,10,-60,61,-87,-19,-4,-28,-32,-126,-124,-123,109,120,-107,-1,35,-1,-36,55,-47,3,-17,121,31,103,118,79,127,-55,125,-80,25,-4,21,-32,-19,70,-95,-104,-2,-92,126,90,97,60,41,-78,-24,20,49,-33,-79,121,56,120,-102,-19,100,1,44,77,-8,113,74,-46,-127,-28,46,-64,-12,-13,-15,-105,84,22,86,37,-56,11,89,110,-83,-95,36,-40,-92,19,-17,76,-54,83,4,-107,127,-82,-25,-85,35,33,-111,-72,76,89,-123,107,-98,-96,95,59,75,-103,28,-35,52,-47,77,-76,87,-14,-27,-92,-45,117,67,-13,5,-56,75,-95,-116,-34,91,-81,-35,83,85,123,-43,-38,89,36,-80,10,-112,-73,104,117,43,-106,47,113,51,-53,-84,93,-84,-86,0,-82,36,-128,82,33,11,-118,-33,-6,-122,-64,98,81,-44,-49,-104,44,35,126,-20,-71,-73,-126,46,44,-17,67,-99,-74,-48,66,-38,-63,-62,-25,92,-61,-28,73,49,45,92,48,85,-91,105,-98,-95,-69,-26,-76,108,80,-30,-56,102,47,-70,89,-78,-31,-112,4,-1,6,-118,115,-85,60,-62,36,72,-17,-56,-92,-60,-104,-54,-53,49,-100,-2,-106,-115,24,-56,-106,85,33,54,-60,-8,44,47,5,114,-79,-77,44,-28,-120,41,90,42,74,-57,-90,-16,79,-67,-88,9,106,-81,-120,-57,83,-97,34,7,-107,-92,89,89,71,113,-78,-22,-59,40,33,-58,-32,-85,-50,58,96,-19,70,-31,-39,90,-21,118,66,-125,-104,-90,-42,25,98,-111,102,44,-4,-88,60,-62,79,-81,-35,-117,14,46,86,-47,6,-5,101,-12,-3,-93,43,42,32,-111,99,96,-120,112,-27,65,-6,89,105,-67,35,-41,57,-126,-98,-22,122,50,48,0,-54,-46,71,45,-125,81,101,-128,23,118,22,-29,7,-26,-95,117,-60,25,-126,74,86,-53,-8,-85,-86,-62,-28,124,-39,65,90,54,64,-77,-128,-1,-112,105,-77,-84,-40,123,53,-46,127,-124,13,-5,63,123,-31,-74,-36,-16,-83,101,-124,-24,13,-5,27,13,48,92,-98,-115,-98,-111,-10,-51,102,98,-81,-82,107,-1,-40,-115,97,109,-52,24,-46,109,50,40,-111,43,71,-70,-9,-1,-48,-23,110,-41,34,-13,108,37,45,-28,-4,-10,-50,121,16,-119,-72,-45,-86,18,9,-66,64,-36,33,5,126,48,93,19,11,-62,-13,-125,95,-116,-6,-61,125,-6,67,111,-4,19,2,82,18,48,-1,-54,-66,20,45,-103,15,94,-91,33,-15,-24,119,82,116,15,67,30,111,-106,90,80,124,-104,71,66,120,59,13,-20,-94,-124,65,108,-95,-80,16,-101,-38,-24,14,25,-69,108,83,90,98,-17,-96,-64,-89,-29,-30,-11,52,105,13,53,2,75,-101,99,105,88,-56,72,26,23,-13,122,-98,67,71,-29,87,7,3,-114,58,-122,-70,-9,126,-30,111,69,-16,56,11,103,94,29,-61,7,-32,23,-6,-6,-31,-63,-47,67,41,74,110,57,97,74,5,61,28,-65,43,54,-22,-115,-126,0,5,-29,-83,-3,-79,-54,86,-50,22,21,-93,116,34,68,77,-76,-55,85,-116,-31,44,-115,-34,84,64,-42,-102,-13,43,85,100,-60,44,-102,-54,120,81,-79,-104,103,59,107,-65,-69,89,-44,121,-24,-7,61,51,75,42,-28,70,-110,110,-102,76,117,-28,-67,-12,102,68,-81,18,121,-33,56,-19,-27,-124,-110,115,-46,108,-83,30,4,105,-9,-17,114,61,11,-97,-79,17,0,88,-86,101,7,14,58,-48,62,-42,121,39,-49,-100,-38,56,94,27,119,-20,7,26,-99,-78,64,120,87,-83,-105,108,-44,-56,76,-2,-117,26,21,-3,8,58,-118,-100,50,-13,65,81,-74,-14,-96,67,9,27,-122,-73,102,51,112,-60,-13,-15,127,-83,-40,-51,-81,-120,16,-7,100,-116,83,114,97,59,121,-53,56,-20,-72,55,-9,-39,-43,107,45,49,-102,-64,101,-54,59,-123,-70,106,-126,-75,62,-44,18,-110,-17,24,-44,18,-107,104,43,122,-19,57,-122,-113,25,-119,-40,-90,123,74,-35,-14,-100,102,-22,1,35,-86,107,109,-124,-51,56,-85,-16,-124,-65,-121,109,30,55,82,-23,-21,1,-78,-102,-75,67,-94,-60,46,0,62,37,6,12,-92,48,-104,-96,-39,-84,39,101,3,68,34,26,-110,91,60,25,2,103,-47,-67,77,46,-2,118,43,-85,-107,83,43,16,-71,-7,-55,-52,-23,-23,-82,57,-110,42,-102,-32,32,-70,-75,-14,116,-11,-128,31,-111,75,1,-123,116,-44,-85,71,33,-72,60,38,70,-72,93,114,78,-102,56,79,48,-15,-83,75,-6,-78,-90,-121,-127,112,-35,8,120,25,-92,-112,82,-37,119,-32,-35,58,11,-128,109,69,48,-30,77,-9,-42,-70,-107,-21,-23,-78,-81,30,64,-51,-8,106,95,-109,-123,-40,-78,122,-127,9,81,-15,-43,27,52,-8,88,37,-45,65,118,-92,-62,119,-109,-106,73,127,-96,-115,8,71,46,47,-107,24,53,-125,70,-40,89,115,15,-119,-64,115,-11,-103,41,54,-108,-20,6,104,-67,-8,95,102,-7,55,15,73,-123,-110,90,19,113,-53,-22,13,51,40,37,-83,-113,-103,34,59,-10,-121,-103,-61,87,-26,114,-25,88,-65,-79,-63,-11,113,-62,31,88,25,92,123,31,14,59,-87,23,35,-49,-83,-64,59,53,-72,-42,52,-21,-59,89,-104,109,-22,24,-60,62,3,-109,-1,-21,15,25,-37,91,7,65,-39,61,-117,-34,26,-2,-51,-48,25,24,-15,24,99,62,61,-55,36,50,-32,6,94,-25,-84,29,65,-95,-94,-85,117,86,-30,-81,69,-102,-53,65,-7,0,-66,-5,66,127,-108,-59,-82,-23,-75,-4,29,62,10,41,-55,58,9,123,99,55,-58,-99,-6,65,-128,-121,-70,-67,-28,11,122,-108,-18,-104,-68,78,103,-108,31,119,1,117,-22,61,121,64,-68,-68,-96,118,14,58,11,21,60,52,41,75,-54,-54,-26,-119,-66,-19,11,-126,62,76,-97,64,117,-64,-5,72,-115,-9,81,23,65,73,-87,-91,57,-48,90,54,-11,-121,-40,42,-53,-82,73,6,102,-104,-117,-1,-12,52,-56,59,12,0,70,-103,32,103,104,123,-75,-104,-123,-109,-44,-35,20,24,76,16,31,-50,-63,55,-116,35,-116,-29,16,109,-34,-68,-115,-39,74,-32,-43,-9,126,-56,32,-74,-46,-19,-82,-103,68,32,94,-29,53,-105,-115,-50,-121,17,105,-7,74,77,98,-23,4,37,-8,-103,45,-123,-68,-99,-80,62,-21,-58,-2,-95,5,-14,35,19,-65,-123,-5,58,35,-90,-53,-37,108,28,39,-21,17,24,34,-53,94,101,20,-38,70,-74,14,30,62,46,-61,94,125,-98,80,88,36,14,10,-121,-122,110,80,-127,-97,72,8,95,50,-48,-39,27,54,8,61,4,113,122,52,-124,-117,94,40,-69,-34,23,89,-56,-123,-97,-16,21,7,57,-87,-90,24,-80,63,-50,-118,-112,-94,-17,24,-32,11,76,-25,32,58,90,-4,-12,28,48,118,116,-112,107,61,-110,127,-38,-69,-62,55,92,-104,0,-46,-54,17,-39,53,54,-90,-69,72,-57,116,-32,33,-36,114,37,-70,121,-84,-67,-49,-95,-105,98,60,60,22,-41,55,-74,-7,-57,-51,-107,48,29,-102,-72,-35,79,71,31,48,65,78,-38,-5,-8,-113,122,76,107,112,-31,102,122,-83,90,-55,-128,101,77,-66,-62,111,126,-75,115,63,-118,52,-6,6,101,-55,76,32,68,-128,90,100,-109,98,-58,79,109,114,121,-77,-59,19,-52,95,-1,84,114,-52,56,-13,91,50,-114,67,-51,-94,-115,113,-58,-33,56,-92,-114,-126,80,-125,-29,-82,55,-120,44,22,-85,126,113,-92,91,-39,113,-81,-90,43,69,-59,63,-34,-5,-91,-21,-3,120,-126,127,43,-73,-13,-111,-99,73,37,66,113,55,-7,47,-46,110,-76,68,105,-76,126,-36,10,21,-80,13,94,10,100,108,-127,-117,21,-95,-79,93,7,-72,98,-15,-62,94,77,-124,25,-63,24,84,-99,28,-99,-117,115,-65,62,-40,85,-82,113,37,-125,13,-51,-96,70,31,26,-36,-5,57,43,44,-97,-27,2,-72,106,-15,-112,126,111,-31,-89,69,-106,-114,-111,1,-54,-66,76,56,-70,51,120,105,-56,-8,-92,-102,-104,40,-52,77,-30,-123,-71,76,48,-20,-93,76,53,-113,-16,18,-21,44,-107,-115,53,40,88,95,123,34,53,-28,21,47,82,-90,109,-114,-104,-108,-30,76,-58,73,7,22,-97,-96,89,-84,-47,-75,-62,110,25,42,-62,-46,-62,55,121,-128,-54,69,54,25,-75,-95,-100,87,88,-96,74,7,122,38,-103,-68,-83,-57,109,-34,51,18,95,89,120,-86,15,72,86,-84,101,66,85,-32,48,-104,-99,-92,27,43,76,41,-74,62,115,-5,-8,-14,76,-114,50,-77,-97,85,50,16,-36,-27,-99,-67,-109,16,-68,106,-52,-22,-112,122,-15,-31,126,23,121,16,18,63,64,64,76,23,54,-57,-75,97,-94,-55,87,72,-40,116,-64,-23,-94,-63,-13,-53,30,9,-72,11,-45,-105,62,59,110,20,-7,-90,11,-80,-27,44,28,46,45,57,35,-60,-56,29,-91,-42,115,5,126,10,-115,77,-65,-17,-67,34,12,-39,54,-119,-20,1,107,56,39,-102,108,-66,22,-75,14,-104,-127,-85,-76,-88,103,-94,-102,-87,-17,23,-95,33,-71,107,92,-96,61,75,-10,78,-33,-125,-72,121,-98,32,-14,-28,33,-96,-4,10,-65,61,87,-27,92,-43,110,7,-52,45,9,-71,100,-52,-70,19,45,106,-110,-74,91,-86,-52,-110,-66,58,114,-126,-27,-77,-63,-50,-65,49,-7,33,116,22,-124,67,-54,76,-115,37,64,-105,50,19,-126,19,32,124,-37,80,-93,81,86,-65,-21,-5,-48,-124,-23,-25,24,-79,-117,65,51,14,-77,16,97,80,-50,29,56,-23,87,96,-52,107,-106,2,55,102,-37,125,49,93,-116,13,61,-11,-23,-119,53,13,15,-86,-96,24,-73,-43,-39,15,112,0,19,76,79,-76,99,-29,111,-18,119,-66,-34,-127,90,38,34,63,3,111,31,-29,24,5,65,-95,-70,-15,86,-43,16,76,-127,-120,6,-39,83,97,-31,-99,126,21,-29,-117,-48,53,-57,38,56,-78,67,109,-92,72,-96,-88,36,-18,43,89,94,100,-37,121,112,-33,-69,49,20,112,-80,26,26,-42,-99,5,124,116,-42,-32,-118,-28,22,40,-76,-105,81,97,59,65,13,52,-104,-98,124,82,96,-99,-46,114,-83,-125,-36,81,8,-27,-74,-28,-61,64,-31,-81,-49,42,48,38,-115,12,-80,-86,62,36,-81,-46,93,68,83,-56,-52,-36,7,-8,-125,-80,38,123,122,-88,-85,-94,-81,5,-106,21,-112,45,-37,-120,-28,48,93,-99,-47,116,81,48,-85,-122,32,50,-67,-109,-14,-22,10,10,56,94,-120,78,-79,-20,74,-98,41,-30,110,50,86,11,65,51,43,-97,-31,74,91,-11,127,-86,-44,-24,119,-16,-66,-127,-30,-95,-64,-11,54,-73,87,45,24,109,98,61,76,109,126,28,114,-1,64,-103,122,24,45,-113,-32,-24,-28,-125,95,102,-7,109,-9,-28,-7,73,-41,-33,-25,111,-45,-101,63,-111,-48,-70,-113,33,-53,-32,-95,75,71,-40,28,-112,-106,-41,76,117,-94,81,19,40,85,96,125,36,-91,19,53,6,65,-9,-82,68,59,9,91,-25,-107,-34,65,-122,20,65,-67,-38,-106,121,125,-83,109,45,-103,-57,49,-42,-42,41,78,122,-31,-69,27,84,23,-116,3,-65,59,37,113,-101,-91,-51,-19,-28,-52,86,119,-29,-29,-104,-84,42,90,119,126,-32,37,-37,59,-113,125,11,-13,65,-21,-49,-80,60,90,4,58,-117,-84,106,-77,-114,7,69,-93,-22,-50,110,-46,125,78,-60,-59,-20,-42,-5,6,93,-124,-52,80,73,75,-105,-14,-58,-59,76,105,59,-46,-79,-81,-72,34,-8,-49,-96,-102,-47,-94,93,-100,69,-126,-115,-102,-103,91,77,-119,107,-86,-115,-68,83,-26,-42,73,-28,22,5,-85,-126,-43,-84,-54,100,-71,-104,-61,97,-128,38,88,-119,36,94,-84,107,87,41,112,-115,60,39,-55,1,-45,-114,-9,-111,-96,-105,-67,-103,-24,-80,88,95,-113,-91,90,-70,91,-113,-70,37,-105,-92,-20,82,81,-122,-83,-10,126,121,117,89,-2,-118,36,-6,118,-85,124,-5,-113,-21,-9,-45,-33,-103,65,122,124,87,58,88,-17,-43,54,94,-106,-30,-47,44,29,-10,-116,-59,41,54,-86,95,13,-116,106,72,55,101,98,-29,-103,-12,-12,-73,6,122,-106,-101,69,54,-93,-43,31,124,79,-72,-102,17,7,71,-44,92,37,127,54,28,-104,-7,-50,-74,-35,-125,-16,-119,28,-23,82,122,63,122,-38,-17,-44,14,-28,117,92,-90,26,88,-74,-41,-104,115,111,112,37,22,127,-9,31,-128,61,29,53,-3,58,78,92,66,-76,39,110,52,-27,-33,-125,-73,27,95,-96,-61,-125,114,47,-107,101,124,21,-16,80,-101,-47,44,63,-31,-99,-57,24,-113,37,18,121,102,-10,46,-24,-76,-71,-104,68,59,-124,112,123,-82,49,78,-17,-47,-83,121,91,2,102,-14,32,-30,-19,-3,67,117,-111,41,-92,26,-26,-50,-42,-74,97,-21,-72,18,-78,104,41,64,-111,122,108,43,-80,67,48,-45,-45,-19,105,-66,115,84,81,125,72,59,60,105,52,-36,-31,30,-64,28,-10,45,-74,11,38,40,70,-3,-46,-77,-70,-16,-118,-69,-114,98,-77,60,123,83,-102,115,7,100,109,-22,-48,-80,42,-127,-87,81,-77,8,57,-72,-41,103,-54,3,-54,105,-37,-41,-9,-16,118,80,-30,-87,22,71,-48,-38,-105,62,-90,-21,-41,-33,121,22,19,116,66,83,112,-39,-28,54,-84,31,-125,112,89,-81,-109,72,-108,-95,-1,-114,120,-73,110,-105,-107,-126,-93,8,-103,20,-55,65,122,-58,68,121,-97,61,-74,57,69,-65,1,-112,94,97,99,-122,100,46,7,-94,116,23,85,-111,83,79,-108,112,-102,106,-105,-87,-66,-128,39,24,-7,-72,-78,115,-51,99,-113,83,-90,-97,-8,89,-88,-114,79,28,56,113,-102,38,-5,-104,-76,-18,38,57,40,-67,-9,89,-8,-121,27,-25,-110,-93,-36,-10,123,-73,-111,-29,3,116,-20,16,-40,-18,87,-123,120,-68,-97,-97,-47,-94,114,113,-121,-111,-53,69,105,-81,77,92,-37,-25,-46,-18,-9,-86,54,46,-80,27,-101,108,-69,53,-109,-44,85,79,-46,-87,34,-30,85,-11,-61,101,-22,-17,-25,99,-65,-30,117,-89,-120,-23,-16,1,-94,12,-80,-29,64,54,106,-111,-75,82,-3,22,-46,11,-103,-63,12,68,120,-17,-117,-52,87,112,-123,-52,-121,105,-53,-55,101,60,-3,71,-122,52,-9,-125,-41,56,-1,85,15,-72,-29,70,-7,-103,-46,-112,127,34,11,4,48,114,56,-109,-32,86,11,89,-1,-80,-18,17,9,-55,-87,114,92,53,-4,42,86,22,57,-50,120,90,110,-90,15,67,-59,49,-46,-97,96,119,100,-80,64,-54,81,126,92,43,-90,-14,-47,-89,21,-17,-37,51,121,-73,-43,110,-54,-30,121,40,-34,85,52,-99,36,-9,-18,-51,91,-71,86,102,-116,95,-55,95,-35,74,118,101,-114,55,-108,-48,-60,-22,20,87,20,49,74,117,-76,-43,41,79,114,-28,83,-68,43,-128,-19,-96,-12,19,111,-44,126,102,-110,56,-77,-27,-14,17,-26,62,-107,71,89,-127,-37,-16,32,-34,126,110,74,107,126,85,8,80,29,104,6,30,-52,79,-74,-11,108,65,29,-107,62,-2,59,-123,71,-128,109,110,110,123,28,-68,-39,-20,-108,112,-32,-36,-12,98,-82,-57,38,-103,55,126,100,-5,89,-41,36,12,-16,99,118,71,-96,88,-92,113,88,-56,97,76,-77,117,60,46,0,23,-41,69,4,-5,-84,33,-3,45,31,38,-119,-20,96,-113,36,28,-38,-96,-23,-115,-50,-106,3,-9,85,-80,7,-19,-111,-120,-3,-107,116,-87,-115,101,92,5,-13,-9,53,1,-35,-125,-23,-107,-122,53,117,-10,-122,-89,19,-33,-32,69,-67,-69,75,-116,-35,107,-48,-74,109,-38,50,-69,43,-85,52,-107,18,83,115,-101,5,44,78,-7,99,105,-72,-39,62,31,27,-46,97,-117,-94,-69,-86,-124,-114,-30,-48,-126,-122,108,-59,-2,-19,49,-22,-29,-21,67,60,37,-75,-55,-22,56,47,15,-111,32,0,35,81,-18,108,41,-120,-20,125,-4,51,119,-115,0,122,78,77,95,-68,-9,109,59,-128,-8,11,-114,7,29,-56,79,-124,-80,-112,9,91,-32,11,-50,29,-115,18,-19,-6,-123,-15,-82,74,-6,15,-55,12,72,-62,12,43,-30,58,-30,2,-56,-100,1,82,-85,63,-17,26,-117,52,-90,-69,-61,-90,121,111,-18,60,7,-26,96,63,-92,5,-11,-52,-81,125,97,122,67,82,33,93,99,25,51,39,-71,110,28,-116,123,48,-68,-103,-9,-31,48,-2,-107,-64,-102,-107,92,-62,-100,83,127,41,58,-122,-7,113,-18,20,-82,-105,23,84,-120,10,-37,-82,11,46,62,-57,16,-58,-18,0,42,-95,-82,39,-105,-78,106,52,-51,36,-40,-3,98,-108,45,121,-59,76,73,19,124,-67,-45,20,76,-21,66,-56,46,-18,-39,90,0,-57,-42,-47,90,79,-120,79,103,34,59,-41,-67,94,125,88,-104,-30,25,-128,120,35,88,68,-48,-47,-99,66,-12,92,-42,46,-25,-10,55,118,125,20,114,67,-9,37,123,48,-84,79,-63,-23,43,119,82,76,-8,-21,-17,27,-108,97,-32,-119,-109,68,80,-9,53,95,-20,-71,41,-50,-57,-16,-4,17,39,-128,19,-113,9,30,-36,66,23,47,82,-76,-87,-35,-48,96,-4,-86,100,15,-58,-10,-1,83,-52,17,-102,37,-89,-33,-2,-23,60,122,-88,-13,-112,-47,-92,-52,28,-101,-99,92,-123,-108,77,101,102,44,-67,-88,-108,-43,118,-96,45,-48,84,-25,-9,59,86,-7,79,23,110,-74,-92,-67,50,-109,29,53,-57,-89,31,8,1,65,126,-119,73,9,-107,92,81,17,53,52,98,-126,111,22,15,-15,-110,-49,60,-82,-82,88,79,110,-113,-124,-127,-51,45,41,-87,-17,-95,-122,88,-48,64,-111,-55,62,-46,-91,116,-55,29,-36,75,95,-56,-100,-125,103,-115,-41,-29,-56,88,-81,-33,29,-127,-6,-90,77,-4,30,-81,-11,-121,30,-17,-10,-24,-124,109,67,126,-109,-57,34,-101,-9,112,25,126,-47,4,79,-38,117,-76,-43,56,-15,-86,85,-80,3,37,-120,39,-40,54,-70,26,-64,-45,-69,-53,19,70,24,-112,-78,-35,-120,69,-113,-97,-29,-53,-106,-74,-61,58,-21,-57,97,-97,-16,94,78,62,-121,-58,46,-38,35,35,-127,-17,30,2,54,30,117,-120,125,9,-20,-30,-44,-53,52,29,95,-66,122,60,-29,-113,68,-92,16,-110,10,102,54,-78,-120,-71,111,-52,107,9,-11,-9,81,-96,-37,-25,-77,39,111,28,0,-55,43,23,-98,-37,-123,-11,-42,-98,-97,102,106,69,-4,98,5,115,-121,-115,-94,-78,-69,-9,51,-84,-86,3,-104,11,34,-38,-113,29,-39,61,10,54,-116,65,-91,83,86,27,-44,-27,-108,-86,34,-40,99,-8,37,101,126,102,126,38,-14,-102,-52,-82,-56,-36,74,95,113,-115,-49,-66,-20,-123,20,-83,-37,96,-44,-55,-98,-1,75,-2,10,74,-55,107,87,41,-123,-90,-61,0,2,94,-63,-103,-85,-13,-107,98,78,-47,6,26,8,-39,36,-119,52,-21,-70,-40,72,117,115,-87,83,-57,-60,127,-78,-78,76,36,54,43,-25,127,19,98,125,-96,20,121,62,-126,13,-30,86,-110,97,124,-32,-104,6,-122,36,0,18,105,-48,-39,20,-105,55,-113,-114,-121,-83,9,-20,-23,-49,86,-48,-107,70,125,-114,-115,83,31,-23,121,-30,-67,48,-86,-90,-91,69,-79,-107,-77,99,21,83,54,-73,64,-60,88,-10,15,57,112,-85,-47,101,-78,7,-29,-128,120,-16,-96,-50,27,116,-128,-11,-35,84,-19,-33,-57,-73,18,49,-67,-15,41,15,36,41,15,9,33,4,39,27,101,-117,77,83,115,-60,-54,-82,46,-56,-18,100,-51,-41,-27,-25,-95,9,74,126,126,-81,-48,10,-60,85,99,80,27,108,-6,-16,77,44,46,114,-26,20,-69,15,28,-121,107,-59,125,-125,92,98,-61,84,-114,-87,-44,-13,116,-120,1,121,-84,-86,26,43,-55,94,-25,-80,-75,34,-97,-12,31,-58,-68,110,2,-109,-27,13,75,84,-21,92,12,-61,-117,36,21,107,22,-61,80,87,-115,29,-3,-125,41,75,45,-108,-29,33,-111,-4,25,-52,8,24,-74,-36,-22,-94,25,-7,97,-124,108,-114,12,3,-10,96,75,34,17,114,-32,84,84,12,-60,-88,-119,-41,41,-48,-11,-25,1,21,10,-71,-3,-16,96,-36,-14,-115,-14,-3,-83,6,-33,70,-18,-108,-81,-31,85,-91,-59,-80,81,36,11,19,74,-22,-80,61,8,57,-110,97,107,91,-40,-82,29,-95,122,-114,-102,-77,-28,111,122,46,-35,-102,123,83,18,-47,-24,-121,-120,114,-93,22,-66,65,113,77,86,82,115,-82,117,28,-78,76,27,79,-128,119,-10,-71,-31,11,-89,-82,-88,63,-99,94,87,124,76,-124,101,-53,-3,-119,9,-50,-29,92,58,-74,-51,57,-114,31,-75,113,-47,-103,4,12,-43,-100,-70,27,40,-81,-36,-26,-12,-102,-118,-88,50,-73,-57,124,-94,122,70,-87,28,-113,-126,100,-1,4,62,7,-91,-91,44,-90,-56,102,-32,30,100,-102,-47,24,34,118,-99,-98,36,113,117,3,-126,-84,97,-73,-124,11,-46,-18,-15,72,-38,24,-47,-4,-65,-73,-86,-112,-37,-125,109,-50,112,72,88,-97,20,-29,-43,-2,-48,121,94,58,103,52,51,-16,-116,94,119,-101,64,48,51,-70,-106,-62,41,82,-66,78,-113,106,71,-105,-44,111,-78,71,115,-50,-111,-46,33,88,-67,-58,-123,4,-82,-34,22,-40,120,-28,-18,-52,10,-15,-109,11,-106,125,-126,-31,94,-89,84,-94,-62,-6,98,62,-50,-78,-34,12,104,50,-39,-11,-60,43,12,-18,36,-62,-58,-36,43,-118,-88,78,-35,-62,-14,-104,-124,-68,21,-18,52,102,18,87,98,-2,-78,29,37,80,25,-106,-99,-86,74,127,6,-31,86,112,35,3,121,-126,-78,114,77,-51,-85,-24,70,7,-109,-25,-58,120,10,-20,26,-100,-18,120,-127,-78,-23,14,8,-116,42,-75,79,44,119,103,102,69,22,26,60,-58,28,-70,-104,25,25,124,3,-15,-44,93,87,-23,-8,-15,-11,10,7,9,120,-68,125,-79,-70,15,115,-75,-90,-5,127,108,108,-66,-122,74,-82,-14,-100,4,58,-106,-96,-65,1,11,102,-41,66,-117,55,-8,6,-69,-72,75,76,16,78,59,-2,-10,-42,-72,-1,-31,-100,113,26,-66,48,-4,103,57,71,-94,-2,14,-28,-36,22,-8,-25,39,-51,25,99,91,70,63,11,-124,69,46,-34,-21,99,-70,-110,-90,32,116,34,-74,82,43,-104,-56,31,-117,-43,67,12,-72,115,-84,-62,-9,21,-30,105,82,94,86,12,40,-47,-39,40,-114,-67,-89,-72,-64,-62,-124,-105,32,95,-124,-41,-14,48,26,8,-116,-57,24,-45,-45,-75,-40,-111,-118,107,116,66,-97,-57,-79,-96,-85,-55,49,-55,-32,-87,-76,-12,42,-85,85,-16,75,-41,-112,49,-29,-28,-124,-10,-60,62,-2,-112,15,-36,-33,81,-95,117,120,51,99,-64,30,11,106,-21,-42,43,-59,51,117,12,45,3,-116,110,88,104,60,67,102,-74,108,80,-58,-108,28,38,-108,16,63,100,-24,-36,-1,70,97,7,32,118,-112,-122,-31,-36,106,10,115,-89,35,58,-15,-5,63,19,-123,-99,-11,-94,108,-18,-13,70,-12,-1,126,-15,-9,-25,113,111,66,-59,81,-88,-114,97,-121,-76,16,8,72,62,3,-107,106,-43,92,-91,63,60,-90,-61,96,-9,93,-24,-17,-22,38,-24,29,-27,-36,-25,117,99,-10,76,66,-77,-71,33,-87,100,48,-13,-122,-49,56,-104,72,72,-84,103,72,115,-10,45,19,-22,52,-97,-77,-107,50,-81,-93,-79,102,-71,46,73,6,-21,-52,5,-96,32,112,15,-44,-4,110,5,-26,-85,89,-87,35,73,-17,59,-95,-5,-123,94,127,-83,9,-122,-64,-58,-72,-111,33,-91,-82,56,63,1,6,-67,-106,-55,26,-12,-105,-32,115,-38,-95,118,117,67,-17,95,99,120,-75,2,28,-113,-105,117,-15,111,22,-46,116,25,-91,40,44,84,37,-4,-66,-125,15,69,-14,49,-12,-11,87,-68,20,91,110,117,125,-65,-34,-36,84,-29,-87,-27,60,-66,-118,-125,49,69,81,54,7,-119,53,-23,-60,-9,22,-116,-125,-58} + +#define IP4_q7_q15_WEIGHT {18,-44,-12,78,104,61,-34,92,-120,40,-75,-19,29,-56,-80,21,60,107,-92,-118,58,94,-104,47,62,11,106,-105,-6,-32,-20,24,43,-116,43,48,53,-50,-86,-38,-108,0,-80,-73,-5,-26,115,111,78,-101,76,-55,94,-61,39,118,94,-20,13,-81,100,-111,70,94,-125,71,63,-121,-70,-14,-69,-74,54,60,-121,107,-121,51,-106,-38,-61,110,26,103,-43,-116,94,111,60,-28,-125,88,83,62,120,-39,-79,-85,112,34,121,-121,-93,97,-45,-90,-97,12,-97,109,90,-45,-59,-105,-100,-21,0,-122,-26,-37,28,-10,35,-115,-87,-62,6,108,-15,118,26,-84,-26,-74,1,73,-41,97,-65,86,94,34,67,59,-99,-67,106,-80,-26,-21,-71,-20,115,-43,109,-107,-21,37,64,-2,-20,115,-75,108,53,-102,35,45,83,-49,-106,-59,-46,121,-102,-41,51,22,-55,19,-58,-116,-103,80,25,122,-126,-76,-7,-2,-34,110,15,82,-46,-16,15,-52,-19,-39,-73,93,62,67,117,62,-27,-12,-89,-100,-15,-57,59,-127,20,52,-37,-41,-79,-43,111,99,-31,13,-12,99,43,-1,-31,124,43,-15,-30,-69,120,-79,-36,-89,-19,89,46,54,116,-46,49,85,94,67,113,24,11,-59,-17,-119,119,110,-57,-1,-81,77,32,-38,118,-13,113,-94,-53,111,110,-14,-19,-53,4,-20,117,-35,121,-97,24,119,18,108,-31,54,30,-121,-74,16,101,3,65,107,-12,14,-38,-53,125,-59,60,17,52,-65,21,-118,76,-112,91,106,-38,26,98,-4,-53,-108,-63,95,-58,19,63,111,-74,37,73,63,-115,-44,-84,22,-47,60,-51,9,29,-57,22,81,-87,-65,-27,-63,-93,110,63,-26,-126,7,-12,-118,-127,-70,-113,45,107,-69,103,-48,56,55,25,-55,79,111,113,120,-2,108,43,-122,-41,40,93,44,88,-78,107,-34,124,63,122,-67,29,24,14,-69,-72,108,67,26,116,90,88,-48,93,-37,-103,127,-24,-76,115,-80,-97,96,-61,-54,-22,-123,-14,-49,62,-1,-17,21,-65,10,116,113,10,88,30,-24,-119,89,-95,58,124,-112,-119,-115,88,119,57,68,-17,-27,31,-9,-64,-26,18,109,-60,59,4,-89,-127,-35,8,-90,88,22,-76,109,-123,88,-51,-90,18,45,25,47,-80,-66,75,-24,-109,-42,-47,68,-8,78,-98,-122,19,-72,33,94,2,-84,-109,82,102,55,71,-121,19,76,76,93,66,-23,-42,-2,40,106,3,123,-111,83,8,105,117,-52,121,2,-4,-18,-4,-19,-125,80,38,83,25,123,-64,47,36,29,105,-71,-72,-41,-127,-82,31,-43,3,9,73,91,124,-3,-99,101,-27,77,-51,60,-96,15,74,35,54,-119,116,-4,53,46,-29,2,8,93,75,38,-18,49,40,-30,30,22,97,-8,97,-35,-111,-62,21,97,-96,82,-12,28,-118,-12,87,29,-16,110,46,8,95,40,58,41,29,-58,105,-108,-29,36,-117,106,-118,-124,11,60,84,-87,-83,21,53,125,-31,-5,114,93,-75,-41,-127,49,-98,31,96,-112,64,60,-126,69,2,-73,94,-100,-23,81,-115,94,-116,-25,-44,91,46,-89,12,75,-47,107,-77,-10,-82,79,-70,75,-106,-1,62,-69,104,-7,-41,53,73,-32,74,-113,26,111,-115,66,-55,20,-91,-47,7,51,-96,121,126,-75,63,-23,81,14,-124,-39,-41,-13,14,16,-27,-56,-48,-84,-43,120,33,98,41,26,-6,15,18,8,31,-50,-9,121,-107,-33,-106,-46,64,127,-19,-104,-59,-30,86,-121,60,39,-79,-38,-5,-119,85,-17,21,44,-120,-22,89,73,-17,-102,49,-73,26,-69,91,-36,-71,103,63,125,-8,61,103,-20,-116,11,105,15,-116,-78,-122,-62,-80,-80,-58,-119,65,-47,99,-111,-26,69,87,-15,-38,-44,-87,-84,-14,-37,-27,-90,109,-72,-4,38,-110,82,-97,29,-50,61,52,-87,-44,8,63,92,83,109,-124,69,-47,-110,-70,-10,111,25,15,80,104,66,32,-16,-70,-49,-52,-41,-16,122,104,-31,22,-109,18,102,62,125,-123,121,74,5,92,-90,-92,72,-61,-2,98,-125,-81,109,101,-120,60,10,58,53,94,-25,38,-56,-13,80,-80,-13,45,-43,-77,-44,-37,46,-62,38,-103,-93,-124,48,76,1,-82,73,74,63,67,-59,-26,116,76,66,70,-30,-113,106,109,75,25,-18,25,85,25,-83,81,-50,78,99,-53,-68,-125,44,-104,-44,96,-126,124,112,33,-75,-29,-60,-9,-126,-84,-61,-119,-127,-6,-26,-46,-57,118,-4,105,21,-120,-121,54,-35,-70,-124,-101,-79,-33,105,-30,57,-108,-111,-48,-65,-108,77,41,112,111,68,118,0,22,44,110,56,-91,-111,-49,62,-54,83,78,66,38,-14,102,41,52,-94,14,106,105,27,24,53,-40,60,-70,-119,56,68,-95,69,59,-124,-101,-25,-119,102,-45,-55,-38,57,61,104,-96,122,88,99,-122,106,77,122,33,-5,126,-74,46,-52,116,-51,-101,74,74,2,-3,-38,-21,68,-30,96,17,71,-124,47,-23,64,-35,107,24,49,41,-50,-23,88,19,-30,55,-91,3,-14,-54,125,10,-96,84,100,100,-116,67,-40,-124,53,2,-62,45,21,72,82,10,-126,-47,54,-84,13,-50,-2,-66,103,-1,96,-17,59,123,-111,-61,-20,-70,-57,54,-110,-94,-125,3,14,-101,-128,-86,-44,80,-94,37,123,113,-104,-9,109,-87,111,120,-7,33,-62,-51,49,-57,-71,3,-49,18,-94,-32,40,-92,-52,3,105,52,108,123,1,40,2,-86,-104,38,52,-93,-73,-44,-62,91,5,-88,-91,-61,-40,-24,-30,-48,114,-115,62,-128,-93,-85,-43,104,102,-20,-103,-52,25,-56,-103,49,10,-25,84,-52,-94,51,-110,26,1,-108,30,32,126,-23,-112,-82,-102,86,-17,-108,78,-32,32,80,-112,-125,91,8,24,-69,-95,-86,-115,-73,14,9,-121,-2,101,-109,1,-72,54,84,25,-36,95,-49,-110,108,4,24,66,126,-63,56,99,-8,-10,-80,5,-73,72,-103,-35,-10,78,3,-61,42,-83,-115,84,-99,78,20,-66,30,-88,97,-66,-120,120,-46,-57,-29,118,15,-110,-94,-29,25,113,89,-110,-52,-92,90,105,-30,92,48,-44,-1,-96,-39,118,115,-3,37,15,-1,64,-2,81,57,24,-47,-14,89,48,-103,-127,-95,-114,-100,14,-69,-32,-82,-9,-77,33,-38,-76,-63,51,-32,69,-8,-75,26,80,59,-31,101,40,-37,76,-23,-110,-23,-84,-83,111,-31,122,124,-56,-67,4,-112,-123,65,101,67,12,-23,-43,-12,54,-87,66,35,-89,-47,55,-105,100,19,21,-80,-76,-85,-61,-117,19,107,42,-71,86,-9,33,-80,-65,120,-49,106,77,-34,-50,-38,-27,21,65,-28,97,108,42,-77,120,69,127,24,-20,89,-66,112,-126,-110,43,103,0,-63,-17,28,36,-43,-117,-68,115,-69,107,70,2,94,9,95,-83,-99,53,47,80,-105,-27,28,119,59,95,82,-94,-16,15,-49,-122,16,17,-89,64,-6,4,88,21,47,50,-78,-25,121,-47,-36,72,-21,29,-101,9,-83,-113,28,-68,23,-67,115,-101,-101,-98,102,-124,-98,-24,-89,82,-28,-89,40,125,23,97,83,-53,-7,-90,-108,-83,-113,-58,-26,-119,28,35,97,-74,6,-40,-15,-10,11,79,-98,101,101,8,-72,-99,117,-65,80,127,95,60,15,-29,2,60,-92,-118,-116,79,46,-79,-62,104,-43,73,107,-43,117,-127,-67,44,113,-41,67,-73,-98,26,74,-111,59,79,45,-60,21,-26,18,54,-72,-70,-30,114,10,-82,-124,-52,-126,-97,108,-19,120,-111,-52,10,102,18,99,49,-128,-17,91,83,-46,-76,-3,45,-41,47,-72,-19,3,112,-104,14,122,-77,-35,121,-23,41,-123,-60,-2,50,44,-45,84,69,-58,43,-69,-98,-11,112,-17,-95,-36,67,-69,-52,-11,98,-45,-126,-33,51,81,101,-38,68,67,-37,-78,107,12,105,75,-109,-100,-55,0,45,11,-24,3,-70,54,77,-63,52,125,93,-16,-97,-22,35,97,46,58,-61,66,-61,-98,12,-43,-45,-63,-36,-79,-58,41,54,-49,-63,48,-33,-110,-36,-49,93,73,-33,-78,50,-76,-48,-6,4,-87,-81,-88,-30,-33,10,-109,104,-94,38,94,-124,30,102,6,37,97,73,56,-106,-18,70,84,4,-31,-90,-27,54,63,10,50,-18,-113,-116,125,-86,-119,33,64,26,-128,-77,-25,76,-127,0,-79,60,-65,-63,5,-5,101,69,-91,-49,67,121,71,-22,59,26,-87,66,-26,-79,7,-73,-51,-114,0,-22,40,-87,-115,29,-18,-72,-23,-96,-55,69,-119,68,-102,124,-99,16,74,5,-34,87,120,-6,-28,-92,-111,-85,-42,-36,123,-52,-86,83,-77,43,-15,124,59,103,-81,96,-80,0,41,-62,-22,77,-13,-99,71,104,-121,72,43,4,107,80,-62,-98,54,-63,-13,10,-92,-119,-95,-90,-76,76,78,-108,95,-117,122,88,-115,52,-10,122,26,39,101,12,-80,107,-108,-13,36,-72,36,63,82,119,-57,-7,-44,77,-55,-54,-25,102,-118,-91,-93,58,11,-30,11,80,-62,111,-77,3,105,-63,39,-50,-33,29,-6,52,-98,51,-80,-5,-50,93,-122,116,-77,79,-45,110,-103,-123,-20,-16,-58,-101,93,-11,57,44,24,-60,-118,32,64,80,3,107,-25,60,126,-90,124,-22,-95,-57,-91,83,-46,-28,1,78,-47,15,74,42,26,42,113,-76,14,33,20,-93,37,89,107,-22,16,-16,23,60,108,74,-117,111,52,-97,78,53,-127,9,123,-78,-15,86,-17,5,-17,28,-120,-76,69,-76,13,120,-64,-17,-35,20,-98,-42,126,-88,-99,-113,10,44,84,-35,115,18,81,99,2,-82,74,12,-125,110,55,31,-110,-94,23,-4,62,-62,-122,40,-120,42,110,84,34,2,-3,-75,-24,-10,124,-46,-38,-14,-11,57,109,27,111,-99,6,27,126,41,72,-29,106,96,-24,96,60,42,-18,-104,82,-69,53,15,92,127,-79,-70,-102,102,-53,79,32,-119,84,115,-36,-84,7,-24,2,-77,103,54,60,-7,1,-64,-7,114,-22,-5,19,-49,80,107,-7,89,-2,-63,-26,-51,-111,17,-108,9,-40,-51,58,108,-55,-68,-117,-51,99,-117,-17,-33,46,69,13,4,-23,-71,-110,-95,4,119,103,31,-30,23,76,-36,39,6,-117,6,76,80,106,-124,18,-3,78,3,112,40,23,-100,-55,75,-118,-52,-16,18,69,-91,-77,126,-87,103,41,-127,7,106,105,77,-23,50,72,75,-16,126,-19,112,67,-102,-4,-56,53,-72,38,-60,-69,0,30,47,-95,53,100,-127,-16,-16,-18,29,46,90,73,-112,-97,-15,-111,-38,23,45,44,115,-93,-32,-68,-10,86,69,19,32,-104,97,-112,60,64,61,87,69,55,-4,-92,-77,-28,-82,76,56,123,-105,52,-38,-1,80,81,-40,-14,115,-78,32,-59,-115,-123,50,3,-14,69,5,-39,-124,70,34,61,-57,-35,34,127,-13,-120,109,-108,-22,68,-125,81,35,89,-21,88,107,87,-32,110,-19,-27,-82,-114,99,-81,115,-54,90,-92,65,-126,64,26,-114,36,-93,70,10,-94,-90,-111,118,-45,-121,-3,106,80,-101,10,-25,-12,39,-72,114,47,125,43,33,88,-81,-109,10,98,-98,28,105,96,-43,123,-58,-115,-88,-122,85,-80,91,26,-26,103,-121,-88,-66,101,-88,87,125,20,-62,-58,-46,-113,-36,-100,93,79,-108,33,49,-45,-19,0,70,103,-19,-48,-15,29,40,122,121,118,86,102,-83,111,-26,-86,-124,6,49,86,50,-67,-28,-104,-28,35,42,52,-25,-87,-70,-6,18,126,-128,123,-3,-109,-94,-49,-120,-62,-89,62,-107,94,109,110,10,-37,99,-126,-116,-85,100,113,-19,-52,-101,65,-45,93,96,-49,-78,84,-44,28,5,-110,-26,-48,62,127,-53,49,57,67,127,-85,60,120,-96,-67,107,34,91,-60,-6,-80,-77,-8,-119,50,-52,89,-64,96,127,-60,-76,-34,-52,-1,34,-25,99,100,-94,-46,-47,12,47,-47,45,-14,59,3,-85,-74,-49,103,-6,-79,-1,-25,-2,0,-44,-29,6,-11,108,-23,91,-48,56,75,-71,-77,-46,-100,-100,-98,90,-29,-35,-56,-3,54,-62,-126,124,1,-26,-88,4,101,-113,95,-67,75,104,39,-106,68,-127,127,-15,-36,23,-12,-51,-118,-67,-22,-39,-71,52,-77,104,9,10,-106,53,34,-67,-98,-74,84,87,95,38,-35,-38,-103,-125,-124,41,-31,3,-89,-107,-41,-9,-90,-58,-39,83,-106,-24,-86,-93,18,14,23,36,-56,75,-36,-123,10,109,7,13,-119,80,113,-68,45,57,35,32,-17,28,-1,-98,52,-37,6,-97,118,-119,48,-69,-102,-18,37,-4,-59,15,101,91,40,3,-31,5,-9,105,-9,-33,-31,-71,-7,-112,-71,70,-2,98,46,-99,73,42,-77,-38,53,48,-1,76,-120,-33,-62,117,-35,67,-117,58,33,2,-127,-66,-100,-117,-82,115,91,-111,33,-125,24,-89,76,15,84,27,-5,49,-87,-72,-35,-49,-128,114,65,-71,82,127,100,74,41,-63,52,-67,0,8,117,5,-102,123,87,8,-37,36,126,-108,71,-73,20,-76,104,-71,-50,-56,18,8,-62,-105,-52,-127,41,-26,16,-122,31,70,11,-100,-109,-35,117,88,29,-78,-45,115,-86,40,102,18,-58,-84,-54,32,-36,51,56,52,107,38,126,78,-66,20,-77,65,-119,26,-113,85,-92,-35,-67,-24,-47,43,-9,62,-70,-41,-66,-7,-72,-79,-77,56,75,67,49,65,43,-78,102,113,98,-47,53,20,-116,-2,-4,-12,-36,8,50,-118,-79,-37,-120,4,103,51,62,107,-90,49,79,-17,61,36,-15,17,-117,123,39,-87,61,96,11,-108,1,51,53,36,-19,-69,-51,-40,-91,-90,127,-62,126,-72,79,-61,123,-27,41,11,14,-67,76,-17,-70,47,-104,73,32,-109,-120,61,38,-1,31,-37,35,-26,-21,59,-53,18,-85,75,106,-83,93,-31,-18,18,-127,19,66,10,-74,-25,45,-109,18,30,4,-62,13,-47,13,44,-59,-96,19,-113,-18,65,-5,91,-75,-21,68,46,-90,25,-110,-115,1,-88,-91,13,55,86,24,85,-60,108,93,-61,27,-14,28,-17,-110,-18,68,113,70,-52,58,52,-9,111,-64,64,-97,-100,0,32,43,-88,13,0,-32,110,-104,108,92,66,-112,34,65,-64,-125,-9,106,113,-116,-35,91,-88,-91,13,-16,-117,3,121,37,-84,-75,-44,-1,-49,13,81,-77,46,113,15,-115,-37,21,33,-17,-19,-83,27,-95,28,83,22,53,-23,66,-57,-25,-15,-56,106,69,49,63,125,-120,106,-86,40,55,4,-96,43,-26,60,-107,-76,-116,-89,101,98,51,-21,106,53,-49,110,83,-119,27,36,2,86,-5,-50,47,42,-75,52,-59,-71,63,-67,60,6,83,65,124,28,16,14,63,52,-58,23,30,49,-81,-123,-26,-39,42,60,-27,-66,-61,-18,-88,-46,-22,-61,-60,66,65,-100,111,100,116,50,92,-83,103,111,-72,116,-5,111,72,101,39,54,-65,8,-44,-128,-88,18,113,-70,-78,87,-70,29,112,63,-31,9,12,-27,-109,-42,-52,-48,55,-70,95,93,-71,122,-46,-115,53,-22,-27,125,125,50,-58,21,-50,-71,9,-82,-6,45,50,-14,51,-74,-72,95,104,-86,57,65,-39,6,-10,-76,21,-52,127,17,-128,-36,-23,103,87,24,-95,10,95,95,21,-96,61,-24,-8,74,0,126,-14,-44,-102,107,-119,-123,83,51,27,-17,-64,124,24,79,-96,118,43,-95,8,-75,-106,115,-84,69,3,122,-118,-64,96,-106,-29,-78,-97,122,-82,51,14,65,-80,121,-66,74,-119,121,82,77,-120,96,-82,106,56,-45,-28,78,-116,-70,-13,41,90,-77,-55,-49,-78,91,-109,-91,-36,97,-31,27,95,-91,-116,-17,-21,87,112,-51,-82,62,-42,111,64,106,68,53,92,-68,-38,-25,-55,-38,-121,5,74,-96,-77,-109,-14,-87,75,-108,-62,12,-97,-91,93,42,24,-45,-5,79,126,-71,-10,-97,97,-19,6,-80,77,-111,39,-69,42,-61,-123,-30,-78,18,64,77,-99,-40,82,127,-39,66,46,46,-82,-117,-70,77,-17,96,27,10,56,83,16,22,114,24,114,-89,118,116,-84,19,-88,16,80,-25,66,-70,111,70,-86,10,-88,-1,80,-95,-82,95,-20,-114,-121,26,-15,-77,-104,-120,-7,123,97,68,69,59,-12,24,-20,46,100,75,-76,-41,-23,79,82,-115,-3,44,-69,-100,-55,95,81,-125,-108,-121,-46,-112,-48,-22,-10,-60,-40,112,22,89,79,-99,53,48,-54,-110,16,77,-51,94,59,-50,-103,-10,34,60,-115,84,31,-55,-58,-10,64,-5,23,112,96,75,85,4,-106,55,-77,-33,87,-79,-76,53,71,-92,-8,63,118,-84,-60,99,107,88,46,-89,24,98,-41,-36,-22,-88,34,-23,78,56,84,52,-14,123,60,-20,38,-66,-56,67,-80,-6,117,115,121,-126,39,-77,-8,22,89,29,-101,29,55,-31,-108,125,123,-46,6,-88,103,-35,25,65,-58,-118,40,26,-39,62,15,77,-25,-50,117,79,44,-79,64,94,-114,-31,-26,-10,-67,-114,-19,24,69,111,14,-52,-33,110,50,-107,95,63,-71,-21,36,-22,-7,19,-95,-71,-38,124,-88,47,120,22,98,-69,73,-114,-5,-18,106,-102,-41,-26,28,-101,-41,-105,-31,-26,-120,22,-21,-44,-31,-50,-127,85,88,111,33,-114,-53,-12,71,126,53,-55,82,-104,93,-77,41,46,-50,90,54,-38,-28,-128,-68,-13,-80,34,-63,60,31,-81,40,77,55,-5,-17,-110,94,30,96,61,26,43,-48,101,-128,13,-8,-29,-6,-60,115,107,-62,-57,54,13,96,114,-89,-69,36,-40,106,107,98,19,-28,14,-4,-97,-60,-64,-71,-107,-48,-50,75,-54,90,108,60,-101,-104,92,25,-60,-17,-63,48,103,113,59,24,51,32,-101,-26,121,71,-83,-21,-68,79,42,-115,5,89,65,-38,28,-91,4,22,89,7,122,-57,-51,-120,-110,-58,-42,-70,102,105,-112,33,21,-83,-14,62,123,-116,-55,-114,-110,95,-46,76,-6,-12,-88,-48,49,-126,-67,95,42,-94,76,84,-64,-112,-20,114,-8,9,-96,-38,-85,-38,72,55,127,7,117,54,41,-52,-89,-46,-121,-95,-97,-113,95,46,79,-105,36,96,62,111,89,-38,-97,61,120,24,90,-111,43,-69,48,88,-58,25,-89,55,14,26,121,-126,79,42,56,-43,109,-88,-53,31,-114,69,-1,-81,-50,94,35,20,62,-93,69,-96,-35,120,-103,-86,-44,126,-96,102,12,54,-97,-79,-49,97,-18,80,-111,-68,-17,39,102,87,6,-10,2,11,-89,-74,-43,-104,-9,53,28,-68,-126,-71,-26,66,34,102,-36,32,-96,-83,-127,87,83,-50,-98,-60,71,-81,-97,108,-74,50,-98,20,-9,75,-48,8,0,124,74,-27,-59,1,118,-121,52,-57,112,15,81,120,-66,-10,42,87,-89,-92,-123,-1,-74,-29,126,57,31,-50,115,-47,-89,-20,-107,51,28,49,110,38,-37,-73,-72,-70,-20,-124,-109,67,-114,7,64,32,101,-76,-107,52,-109,-89,51,-51,-98,-3,122,100,-2,-57,34,-38,-101,22,15,92,-104,9,47,-9,47,-18,27,-38,-122,-58,-20,102,-63,-78,-19,-71,65,-112,-48,49,85,27,-113,-57,24,108,81,-96,99,-47,-67,-121,2,-17,-29,-9,109,89,-45,-127,122,-59,44,-81,55,-39,5,40,-11,0,61,37,18,-82,-97,-69,27,-45,11,-70,31,-88,117,-98,114,115,75,-104,-3,46,104,-67,21,49,18,95,-8,31,11,55,22,-76,39,-17,24,10,-63,-97,114,57,-46,-62,34,-66,-86,-94,-109,-67,124,68,42,26,-65,-60,-41,97,59,118,55,-104,16,-25,-99,-13,-28,-50,103,-50,51,-77,55,91,53,-17,-82,-108,-121,-54,24,118,77,24,73,-120,-61,36,-63,-122,51,-88,104,22,76,14,118,63,122,-31,-115,59,-92,29,101,-66,-48,-7,30,-5,86,-41,11,-87,71,-15,-30,75,-110,2,91,9,18,101,-51,-102,-115,-83,37,14,-41,-17,-43,106,-108,-42,-86,34,65,57,-13,12,114,25,-69,-36,-48,93,-89,-99,-104,54,15,19,-101,-105,-51,24,-26,93,-2,95,-43,51,-112,-14,-83,69,122,77,20,-7,-29,107,79,115,-102,115,-58,-111,8,46,112,-67,-97,-20,-88,98,-30,75,-47,90,25,110,3,-8,94,70,47,22,-103,-91,-54,58,-12,-38,-50,51,72,37,27,7,-50,-112,31,-14,-76,70,-95,-109,48,-111,-75,118,30,-2,-7,-123,33,32,-89,-47,-6,25,67,73,-7,-29,-93,49,112,111,76,-65,-76,8,-95,45,-79,83,84,23,-96,20,-52,15,-56,-70,7,-58,85,106,122,-96,-84,8,85,-101,35,-30,-14,23,33,112,-86,20,73,-93,-30,-8,-39,-79,-77,-36,-107,-38,-112,-89,-27,49,103,48,127,31,-22,68,100,-35,99,57,74,-26,85,118,-43,101,105,-76,-127,-93,44,-1,68,39,12,93,13,-33,-78,11,85,-51,44,-99,-85,12,-63,98,-92,-5,76,25,-86,-68,-121,-67,-109,-64,31,64,-58,-90,126,52,20,-41,27,120,-117,-86,71,-128,-28,-128,-39,82,113,-102,59,30,78,-128,30,103,-95,-11,117,74,94,113,46,56,41,-96,48,-85,-28,-25,-79,104,-73,3,2,30,76,-22,-103,101,-89,83,34,2,-26,127,25,-82,18,8,-3,-20,52,13,-21,36,90,-38,112,-85,-79,-92,9,-72,15,98,-26,-32,26,-4,-26,-94,-5,112,69,-21,-84,31,-17,-112,46,-83,-24,-105,-102,3,15,-60,99,-123,-6,-47,-120,22,70,125,35,86,38,35,-100,5,89,96,-33,64,-55,29,55,-82,-3,17,52,89,104,126,-125,62,-80,113,53,34,77,83,-65,-28,-27,2,-114,68,-37,-4,89,-94,-41,51,43,-85,-36,93,74,-93,-8,109,-70,-92,114,-120,-63,44,77,102,36,50,88,16,99,19,-9,64,-43,-57,-81,-67,-9,-70,89,-64,53,114,-99,5,87,-31,74,66,75,-37,108,-100,-101,85,-44,-120,-70,-32,92,80,-16,30,112,-102,99,96,-6,123,100,-89,102,-38,102,-90,-80,-9,9,52,-47,-114,-128,-81,-112,2,-40,87,-41,46,119,-15,-107,79,15,105,-53,108,-22,72,36,45,-88,82,59,19,27,118,123,-93,-44,-46,93,-98,105,64,-80,99,-8,-110,-51,33,76,-58,-103,87,26,-13,76,-93,83,-13,127,-4,-54,-52,21,70,20,-93,-7,19,102,7,94,41,14,67,-52,17,23,54,-81,93,76,-61,-23,-92,9,-118,110,99,-128,-53,123,-127,-125,-24,-76,88,63,-79,-65,71,59,-79,-45,-64,-111,-85,-53,55,22,-102,-78,48,25,-67,100,0,72,30,19,56,-6,-54,40,-71,98,-42,127,-46,40,58,34,-6,21,-112,-113,2,-42,-14,-25,-78,12,-55,62,58,-44,-127,-40,85,-80,29,-27,-72,8,73,-36,-32,-21,34,-46,84,75,41,109,-41,-92,123,20,-123,72,106,47,41,-12,-73,-38,117,44,-89,-128,-102,49,-65,-43,69,-119,-53,60,-97,9,-39,-118,-33,28,-58,105,-41,111,70,39,-41,58,90,20,-25,110,-21,50,-114,-104,-68,-35,96,-16,58,98,26,-98,-80,63,74,-85,119,21,-124,118,8,-61,-125,23,-112,30,-77,-11,92,-28,-101,-9,-57,93,-49,32,103,-97,87,-96,116,77,-48,92,-27,57,-29,52,-25,-107,-77,114,-50,99,-79,-58,24,-19,-96,47,-113,-80,8,-72,-83,69,-6,92,55,39,17,21,76,-127,-5,-115,-60,-55,-28,-43,40,-43,106,-35,112,-57,25,19,80,-39,-6,-79,-111,4,-59,121,-77,-103,-89,-113,-127,28,61,-125,-50,58,-38,43,-33,124,41,-105,69,2,99,-31,83,-119,-21,90,38,92,-88,-83,113,56,-56,-49,61,-74,-2,101,-23,-114,26,-95,114,-52,-73,-53,-7,116,32,119,49,81,-88,-102,-49,-126,50,38,-47,-13,76,-73,69,-124,5,-63,-53,11,-42,-97,35,46,29,112,-43,-2,46,83,58,-17,41,125,-5,-34,-96,49,67,-17,-80,-82,38,81,29,-13,84,96,-112,13,49,65,117,23,52,3,49,-43,-26,-88,-97,-60,93,-93,-34,-74,-54,5,-113,-73,64,23,-95,17,50,-112,123,4,-90,-35,103,-41,16,26,-104,-119,109,-71,95,60,28,-71,-41,5,-26,-118,-31,58,-126,-93,-50,30,-48,-51,-31,-92,-2,-75,85,71,-52,112,-48,-65,74,-24,41,121,104,-95,122,-49,-83,119,-20,97,38,23,-73,55,-22,-118,45,-37,25,47,-122,-4,89,125,-105,55,37,102,52,34,-12,7,85,-6,15,17,13,97,18,20,-92,107,79,-16,117,60,-80,-3,-23,-70,81,124,52,105,-36,-44,-125,-81,-40,28,88,-111,-57,-96,-49,-5,18,71,-37,-73,32,53,1,77,-124,-70,-107,-79,33,-83,-34,43,-125,20,-55,-53,15,59,59,71,-97,44,78,33,80,-20,65,-72,68,-125,23,-3,-30,-89,93,88,64,123,-44,117,126,59,38,32,-5,40,125,98,124,-104,-31,-27,-59,98,12,-43,125,-48,-74,62,43,-6,73,19,-3,100,-104,35,-62,47,-8,60,37,-125,-100,49,95,-74,-15,76,8,58,14,20,-85,-56,29,-125,70,94,-60,-112,-56,82,73,78,92,-40,-37,-50,37,22,19,23,63,-49,116,113,27,82,-5,46,24,85,41,-11,106,102,-123,45,60,-108,63,-67,124,114,53,-126,-14,-108,64,-6,-27,-19,-101,102,-27,112,-45,-4,93,-36,-68,93,-111,-64,69,-109,-128,-78,-16,-79,-62,-51,-8,-40,-39,-94,-4,-117,123,70,87,-79,-91,15,18,11,98,-51,-104,-59,-76,40,-82,100,110,102,13,42,71,117,-81,-120,-41,-48,-17,44,-20,-44,-120,79,76,123,-128,-51,111,71,-41,-86,-76,-32,80,124,-43,-65,123,5,21,5,55,73,34,-46,-55,-108,58,116,110,59,85,-61,-24,111,-86,-34,-128,59,-111,45,-125,-47,-94,-90,48,-56,-109,-95,-37,79,-127,-17,102,-96,-52,16,-77,40,31,-59,-93,10,-26,-28,108,-85,-2,95,-25,-94,-88,120,30,-69,-24,-9,90,67,81,-92,123,42,116,12,123,86,88,-86,10,-77,-16,54,-119,-43,-54,-7,104,-75,-111,-3,63,-95,-96,112,-68,68,80,-128,3,-37,-13,74,-113,-88,62,-32,-40,55,-48,-21,-64,118,64,-126,-41,-75,-79,-112,-78,19,-81,20,-10,97,86,-20,127,56,101,118,69,73,-62,52,125,-84,-15,-30,65,-53,105,-59,-54,-87,87,87,-116,-120,49,71,-48,99,-108,-19,-107,-40,-98,58,86,-125,-119,-62,-38,91,23,85,-55,-31,52,123,-76,77,120,49,122,-19,-118,-56,86,-15,-74,-82,47,-83,-121,21,-69,-86,119,-39,59,87,-84,1,19,-67,-58,-122,-45,-38,54,-96,-13,-91,100,-118,-97,73,-72,-30,23,-30,-121,-36,94,20,-38,22,-4,-7,-85,50,114,95,-105,35,-85,-89,-41,93,8,45,-53,87,93,30,117,17,-61,-61,69,48,-52,-99,-75,-104,-113,10,-27,80,89,107,119,-76,-30,125,75,122,55,8,-13,-37,-37,24,13,33,31,-14,98,101,-51,27,24,37,-51,-15,110,83,-49,85,-122,-30,18,92,-17,101,12,-54,97,-99,4,-82,73,-46,111,-7,29,-75,90,-91,106,45,68,68,-111,-63,99,-74,86,-122,-35,-28,21,-22,74,-70,-80,-93,50,14,-9,-84,45,-41,-18,-50,-105,82,-94,-89,102,-38,74,120,90,-17,43,-82,-83,-17,-119,-106,52,-63,-80,123,124,-118,75,98,0,-76,-100,77,-72,80,-18,-49,61,107,100,89,-27,-70,93,-52,-68,-46,-89,49,-9,13,-77,-29,103,-69,-52,-88,-65,39,-33,-119,-105,96,29,48,86,55,-76,62,-128,5,109,73,-94,-43,-11,-82,-32,122,52,33,29,-40,63,-89,-88,-16,77,67,-69,-59,-106,112,59,-67,6,-92,-115,-120,107,40,38,-33,69,87,81,8,9,9,-31,-68,-110,113,-117,-81,44,-62,-85,-23,77,-6,84,-126,-63,58,105,75,-48,38,80,-45,-2,34,-62,-8,107,-16,-82,-128,-17,57,-113,-99,12,-110,-47,-44,100,-23,121,-29,42,34,-64,-124,100,123,105,-128,-7,117,5,-13,13,-125,112,-4,86,53,-128,-87,-81,-75,-18,-77,116,-110,-122,-60,100,-124,117,-35,82,77,87,125,29,-127,123,100,-54,-117,-100,-105,-49,-77,2,-4,-110,-101,6,63,53,-103,76,-40,-118,108,-103,122,52,-3,54,-86,57,65,86,-106,4,-99,82,-44,68,15,-41,51,17,4,92,-63,22,-83,-126,65,63,-115,76,80,-109,-50,16,105,79,-115,96,34,-71,-61,-89,98,92,-36,-88,113,56,18,-123,32,120,110,81,-29,108,-31,34,-24,-102,-33,-8,25,76,-128,77,84,90,76,-98,-4,-104,-105,-65,10,-62,29,-80,89,-116,120,101,22,-36,-85,77,3,-44,-107,63,45,-19,-126,16,-29,1,31,-125,-108,113,30,-103,-38,-127,26,-18,-56,-120,-121,32,102,-25,-7,-85,47,-50,-121,-109,-6,-127,-34,55,-114,-34,82,-6,-44,83,-2,-69,-34,101,-21,123,25,33,-23,-108,-107,-46,-46,56,-30,38,108,106,60,-31,-78,8,25,4,124,12,29,37,2,89,100,40,-48,21,-87,-53,109,-116,-46,77,-60,-64,-68,122,-25,-109,-71,28,62,121,-84,-73,80,12,-118,-88,-89,109,106,-74,-62,89,58,-65,-73,-74,-64,-110,-73,-27,96,-87,-128,-122,-72,54,42,22,73,-37,-87,6,29,31,-46,62,-99,23,63,114,10,-20,-43,68,-24,15,124,-63,76,-25,-12,30,-86,-43,38,111,-121,69,-5,-49,34,-42,-51,119,39,80,86,-32,27,-74,-71,-24,73,-25,74,-11,53,104,117,87,-32,-11,-115,-24,99,-78,-7,-113,-99,-76,112,-20,121,50,-9,-103,-10,111,-68,-9,-35,96,-108,10,-38,2,-18,-73,-64,90,-105,94,103,-22,22,116,99,-68,-42,124,-122,-117,-119,-43,-6,47,72,90,-52,52,-76,2,-22,-84,-19,-85,-124,92,13,-115,36,2,107,15,127,-76,47,-39,-109,3,90,-24,1,-74,-29,-17,-27,-21,32,102,26,-57,-108,-114,-112,-104,76,-47,-17,86,-86,38,106,114,-81,-77,52,67,-28,-68,-63,23,-57,-110,-81,95,-35,-97,-29,-96,-11,64,-1,-118,-99,-25,-24,68,-118,-84,68,-113,94,-39,77,93,-80,-1,12,-123,97,80,111,-117,-52,5,-24,5,-98,-27,48,-96,-37,-108,70,-28,63,-21,123,23,67,-33,-96,47,-58,-50,-124,-109,-64,20,-37,44,-101,34,95,100,94,-57,39,-4,-21,-62,-76,-37,-72,-51,10,114,-21,113,45,-68,27,-77,47,105,18,122,-117,43,-99,-82,40,-15,-7,112,27,-86,-37,83,-8,-53,1,-110,47,64,-58,44,-50,14,18,-33,69,-17,-90,51,35,-58,-103,29,100,38,107,-44,-99,106,-49,-90,23,107,-44,-79,7,-21,-10,40,-76,-58,-50,-106,84,-47,34,91,-9,23,113,114,-11,-91,-62,64,20,58,44,-76,-105,-55,38,-101,121,94,-125,81,-55,-128,-101,-22,100,78,43,94,-46,118,-103,-36,81,48,45,90,-3,2,44,-8,-66,-49,104,116,-90,-69,-78,28,-65,15,-31,103,-71,14,-103,-90,-54,36,-81,-62,70,-35,-60,103,-13,45,20,-32,-93,127,59,127,-54,-89,-23,117,48,77,3,-84,-35,-56,37,87,60,-115,11,-27,44,103,78,-16,-112,-3,-44,45,61,-112,-102,-104,88,-67,102,121,-106,104,46,-39,52,-91,-77,-13,-79,118,-52,61,-90,-5,46,24,-59,-84,57,-34,101,-62,47,-66,-18,122,28,102,32,-123,-19,121,81,12,-110,89,-78,-38,8,-78,-94,-2,44,111,-36,-2,-66,22,83,-59,-43,92,60,-29,-71,92,-51,7,19,-2,39,-66,-100,116,-78,92,7,124,103,107,127,-115,80,62,99,98,-95,-74,109,-3,59,-126,-61,-93,11,-58,87,-24,100,113,21,-65,-71,-103,-106,122,96,-71,100,-38,-118,-23,72,0,-55,-68,-108,88,73,82,119,-105,-90,59,-41,99,37,76,-41,-62,94,18,-37,67,68,56,-41,110,53,-24,14,-62,38,-121,-84,13,48,48,116,-17,110,-80,-63,50,-4,8,111,-77,77,-4,112,19,-9,64,-32,-45,72,77,-90,-127,88,74,-61,-85,63,-75,125,-46,-15,-86,79,116,76,7,46,-99,36,14,-55,0,95,76,101,-115,67,-18,-35,71,95,-104,8,-124,38,-42,13,-70,18,98,77,51,-82,-27,-61,-66,2,26,2,-26,-61,-119,-70,44,114,27,99,-99,14,97,34,63,-88,-44,65,82,30,-47,-99,-97,13,-13,48,47,4,117,-29,37,11,-7,28,78,41,-59,-94,8,99,-125,32,-109,14,-13,-58,11,101,100,-94,-61,45,-49,90,47,84,77,19,12,-24,-86,-63,112,-48,73,4,-91,54,47,3,67,5,68,-26,-64,110,-71,113,-96,105,23,-14,-79,-18,67,36,-35,-36,48,68,-33,-5,56,39,-56,-20,-11,-43,6,82,-33,121,29,8,-78,28,-29,-101,-76,-81,116,-98,-72,97,-16,107,123,-89,-47,-84,102,-113,-107,105,-24,-112,-67,-77,-41,-18,29,49,-19,54,49,41,20,63,84,15,103,33,50,-25,-118,42,87,61,48,-48,-121,16,-74,-85,-13,6,-14,-76,82,90,-68,-4,-40,2,17,-101,81,-80,102,-2,-64,-54,-74,8,7,-117,99,21,21,-50,74,-36,-89,-75,85,-35,-29,-105,2,-55,2,28,71,-118,53,126,-84,2,9,-20,-104,45,4,76,-113,10,124,83,81,88,50,95,66,44,-110,122,17,30,92,-85,26,-53,73,-78,-32,-127,5,3,34,-75,81,54,-15,-13,9,-42,-126,-102,7,96,119,34,109,6,67,-70,116,9,-26,103,19,-9,116,88,-12,-88,39,92,85,91,-87,33,-43,120,96,-59,-53,84,12,-18,-68,-87,3,48,-99,-28,87,21,-88,86,-93,116,63,33,100,-65,-56,-36,-36,-38,-80,-97,-62,-87,66,-65,77,103,85,73,-99,103,102,104,-80,-70,60,-96,-6,-67,1,-1,-44,90,-80,93,-59,39,-81,66,63,-35,17,-58,-56,-49,83,71,-80,-54,-111,92,-7,-48,29,-7,56,-107,-114,-75,21,54,-124,-3,-60,-78,-13,61,-110,123,80,-49,96,-105,-115,-29,112,-68,126,-87,-74,82,70,16,-70,-84,53,22,-16,29,-40,-90,-47,14,-117,-3,6,-13,64,-84,87,-100,52,23,-57,108,74,-37,59,82,45,87,20,-65,52,57,-96,-61,2,-39,-33,78,-79,84,-61,63,34,37,27,-13,12,101,32,9,-16,-19,21,59,-119,-97,57,-124,127,6,76,83,80,-31,27,102,-105,118,56,85,89,98,16,-57,68,3,6,58,-95,-77,-78,26,-26,5,-21,-113,23,-110,90,-16,35,-23,-108,-47,-14,102,-42,119,46,58,10,83,-117,80,-49,-38,-58,25,80,-85,40,-54,-2,-35,-100,-80,-77,87,-122,-45,-94,-115,63,86,-10,84,-47,-114,101,123,111,-75,71,-111,-47,-35,43,-99,-22,106,-3,-89,-94,111,22,-52,95,-17,104,71,96,10,7,-99,-90,32,-38,-81,-7,-112,30,-16,-11,106,-104,-30,78,99,-110,30,-31,-125,111,-50,-19,-50,-66,109,-113,95,26,-74,-86,-66,4,70,-4,-14,-2,-86,-83,48,118,-62,-30,-78,-2,102,-105,-45,83,37,58,53,100,-66,46,-25,-104,125,-112,89,49,95,75,22,88,19,-76,-35,101,39,20,54,-82,61,-40,-83,-106,32,-106,116,-80,-52,-45,-86,-126,-56,-71,108,52,70,39,103,-24,71,121,120,117,9,5,110,-97,-79,-39,-56,77,71,-90,-97,3,-8,-64,-102,-5,105,59,-100,-76,-65,-99,-6,-7,85,115,112,14,118,65,10,-60,116,68,69,-83,-118,23,24,13,40,68,-78,-2,-43,79,96,-63,-5,-19,-56,19,94,-79,-7,96,19,-93,-47,31,30,22,43,89,-104,61,-49,29,-111,61,121,-41,32,116,-17,121,-109,-51,7,51,-6,-80,-105,-84,-41,88,16,-61,91,115,-25,69,-80,-12,-70,45,80,75,-38,-22,111,15,39,-71,62,68,40,-51,11,-9,44,51,29,-27,112,-106,-95,29,-114,-105,68,105,-68,-109,-13,-82,51,33,50,-48,-103,-65,-46,13,-51,-29,17,54,-91,123,108,-73,-120,43,27,100,32,-13,52,123,-52,33,-43,-110,-76,-79,-30,-86,109,-90,49,103,39,-28,-52,41,0,106,-13,10,-57,124,-15,10,74,-124,26,91,-63,114,-48,52,83,11,-44,95,-23,13,-57,114,-108,82,96,39,27,-34,29,-60,99,30,5,-101,117,-128,-74,-47,-33,-118,-69,-121,-112,-18,20,-6,-35,117,-80,-35,109,-102,24,-33,47,-5,-13,101,4,-127,25,1,-117,-57,-65,74,-64,-107,125,0,-78,-60,110,-100,-1,-19,-63,27,61,-17,-75,-84,-29,-56,-25,21,107,46,88,-33,-89,109,83,-83,-100,-121,-55,-48,-3,29,28,98,-64,-59,-73,-65,-63,-86,30,92,-29,4,65,-26,47,-111,1,-21,26,-109,-86,-119,-1,113,-29,-88,77,75,-54,-35,22,-95,24,-40,127,80,-56,-24,43,125,-18,97,-77,-32,61,-85,69,-105,19,9,65,127,10,9,90,-76,-37,-2,-18,-15,-57,2,27,11,-51,109,28,17,2,90,69,22,98,-55,-63,-53,125,48,-13,44,-96,-94,-116,65,88,-2,72,76,61,79,12,64,-112,-11,44,72,-103,-29,106,-24,78,91,72,-93,74,-123,-36,-121,4,79,92,-28,83,-109,-98,-99,63,92,98,-39,94,-43,-57,10,83,-23,92,50,79,-111,-32,-79,40,-34,-26,91,115,-124,-19,68,-72,56,60,-101,-73,-55,36,-83,-59,-86,-73,3,-98,-85,3,103,10,-113,34,53,-90,112,-114,-122,26,46,58,52,51,-101,-1,29,-87,-108,-77,25,-51,0,32,97,-36,57,67,117,-124,-61,13,-67,8,-108,-50,-59,28,95,-112,10,124,105,-54,-127,-43,-86,-50,53,-1,-108,-111,65,35,-42,-28,-119,-47,-92,-97,15,-50,12,63,-42,10,-71,22,-23,83,-24,-28,20,69,114,98,108,29,3,-42,123,-101,120,13,-36,-44,87,15,74,-89,77,56,-23,65,-12,19,54,66,-31,-16,-111,109,-43,111,-87,69,79,-8,124,-17,-46,-48,15,61,-28,108,-72,-58,-55,53,83,-80,118,43,-88,-54,74,-102,-38,56,116,-80,-125,-75,-3,105,43,88,-66,117,-120,-58,82,74,-5,6,78,-72,-79,-51,85,-49,-100,123,-42,4,90,-33,-55,88,127,60,-115,20,-123,123,117,9,-75,122,-19,-97,-98,-15,90,-32,92,94,-86,41,68,93,106,-60,-41,-80,40,24,-91,-86,-39,73,-120,-27,125,-87,65,-123,-41,-9,35,113,91,-40,-111,2,5,34,83,-66,114,-111,90,57,126,-93,62,-117,5,60,-68,11,-105,-35,-33,51,-52,-45,97,83,117,36,-81,45,59,-43,64,-62,69,-95,110,88,102,-125,107,-97,43,95,-122,4,1,-51,25,-12,43,-22,100,98,-64,94,64,-74,45,-38,-46,102,-21,-37,29,-123,-104,119,-2,-40,115,-31,15,2,21,-115,75,82,-8,18,74,8,27,-80,90,88,10,37,-104,-1,-82,77,80,-97,-99,-105,35,40,110,-49,24,99,-94,43,20,40,-40,10,113,-71,43,-63,-22,77,64,-3,-79,-82,-44,-53,23,86,110,-124,97,-27,-106,-95,104,-96,-121,25,-14,74,54,120,72,107,-128,-9,-60,21,49,-67,-12,18,-30,-33,-91,77,40,38,33,-70,7,-43,-89,44,-12,111,-108,14,36,-15,85,112,-85,-109,-48,98,57,100,-17,85,-123,-72,-111,60,15,-124,11,90,-105,7,-107,-121,91,-10,-98,83,-116,-10,54,-128,64,59,38,64,-25,36,-17,101,-96,-108,67,-89,46,20,26,126,-71,-1,0,77,32,-72,-31,-29,44,-14,-8,-74,42,-11,-21,95,119,84,123,-128,30,27,20,-74,38,-11,-122,41,94,-51,-33,-115,45,74,7,80,35,18,-30,-101,-6,95,-92,-69,33,16,15,-59,-111,3,-67,-86,28,-43,40,68,27,-111,-95,-26,98,38,83,106,-126,-34,86,-54,-102,-110,-88,38,40,-37,46,81,11,-122,-8,-46,30,112,90,-40,95,-61,-73,77,-123,-44,105,32,-109,-110,81,-23,127,-83,81,-55,77,62,-44,-33,-70,-62,4,52,115,32,-36,-96,-123,-33,86,127,86,38,43,53,21,106,-125,-69,-16,84,-98,-80,-12,17,-25,-70,-72,34,-33,-115,-119,48,42,-34,6,91,-18,-19,22,0,46,-92,-27,106,-116,35,78,44,50,-110,-113,7,14,18,-123,22,-112,113,-91,-51,-17,88,-83,-51,-19,30,28,109,-64,-114,86,73,-33,30,-1,-121,-58,51,-109,86,104,89,119,-76,-28,-90,-95,-100,69,-55,-23,-14,58,-112,30,-77,125,72,-99,55,39,67,54,-6,4,52,50,92,-47,-26,6,76,3,96,89,97,126,80,-80,-100,-76,67,-119,-36,58,-13,16,53,53,5,123,106,31,33,-67,111,-27,48,7,-111,23,-110,-42,-16,-105,38,43,51,-17,-12,-98,89,-32,3,64,118,65,21,-66,-1,-93,-115,93,-75,7,-25,126,59,107,-19,-26,14,-107,75,45,-16,-110,-34,50,2,-11,-109,19,-61,125,-94,-63,123,-24,-11,54,-115,121,-16,-39,98,2,77,102,90,52,-110,-55,109,-119,-47,-121,116,119,65,68,6,6,22,103,-121,49,-117,119,-38,-90,124,-32,104,90,109,-16,-100,-92,61,-115,-107,60,-26,93,27,111,-124,54,-72,-77,123,-79,89,-89,-54,-94,108,59,-49,78,-108,-4,-28,-119,55,42,36,95,123,-7,-99,-42,-100,-6,91,-65,-24,32,-77,106,59,-5,-93,-100,115,35,70,-90,-7,-6,40,-20,105,76,-32,-74,77,-32,-91,114,49,-126,-83,-81,84,113,80,-69,-99,-13,-29,-103,102,-69,-108,-127,87,-43,-11,-126,-113,119,-104,-11,79,62,26,-90,-22,7,-64,-107,77,77,-83,24,-90,52,-57,10,-22,114,-38,115,-37,-52,-63,-76,-13,94,-56,-96,78,59,33,85,-82,-97,10,74,-95,-113,-78,99,-66,50,4,32,102,69,20,-76,-69,-57,-26,5,-105,127,94,-72,-19,-117,-7,-38,24,-91,59,86,91,9,-58,126,-81,-126,-39,28,35,124,101,74,120,-90,54,14,-31,-108,80,94,-40,50,-56,26,-5,19,-37,-39,-45,-117,9,37,53,83,-73,-22,-107,-102,-104,38,-126,-125,90,-106,74,-98,72,21,-76,-56,20,109,29,52,-45,-42,-51,51,-1,122,91,12,-18,-69,55,-3,51,-111,-106,123,11,-108,-93,51,96,-100,91,-87,-51,70,-39,15,-81,35,62,-54,-87,33,-64,-125,-111,14,-109,-89,70,-36,65,-122,-47,126,126,-119,-49,-34,46,126,-87,88,-117,-107,119,29,-65,25,-89,62,-89,-88,-117,103,100,9,-36,56,79,95,-124,66,-5,-126,-9,9,-95,-95,-93,54,-2,-54,81,-106,21,-25,108,105,-37,-9,-97,69,122,84,39,-124,98,59,-25,-67,18,35,48,-105,117,78,-75,-42,3,-76,-107,76,79,3,-81,-61,30,-99,-99,101,-118,-94,112,-88,-19,-82,103,-67,76,-71,-105,-24,-91,-20,83,90,120,-7,34,-26,-110,75,41,62,-116,-77,23,109,107,74,-78,94,-125,26,-13,27,99,49,77,-73,100,87,77,0,88,93,-23,-115,-36,-108,-24,123,-65,-60,-63,-44,0,19,102,-19,89,69,85,-96,88,-103,123,108,119,-68,-99,89,11,-56,116,-106,97,-68,6,-60,47,52,-1,-53,94,-55,-107,-3,-9,-105,-3,-21,-69,-37,18,-59,78,37,127,118,107,-117,-79,-43,-108,124,33,-121,-25,52,-71,76,64,-2,27,-52,68,88,14,25,-115,57,30,-36,-16,63,-75,92,110,-57,-105,-82,-21,-72,30,113,-92,-20,-15,-77,-20,-25,106,22,56,79,21,68,98,115,71,32,20,122,-70,112,38,62,105,48,15,115,47,-124,48,-71,-41,-85,127,-6,9,122,110,-68,-45,-35,-21,-103,122,30,-70,42,68,9,83,13,105,110,8,98,-42,93,117,-26,21,-42,-82,27,110,-123,10,-98,-5,22,29,-112,-32,109,31,7,-91,22,71,-56,60,29,-126,4,63,-64,-77,74,-53,92,-7,-54,-128,72,-20,-92,6,-89,-20,52,46,32,-94,-119,-90,-92,106,74,22,-50,88,-69,107,8,3,55,-102,-64,28,-106,74,13,96,97,110,-59,58,83,-95,-49,-106,87,71,9,-19,125,26,-26,-93,-28,-52,20,-63,49,-73,-11,112,14,121,-65,88,-128,4,72,-117,-29,-74,-33,21,102,125,112,-49,-82,-7,-28,82,46,-71,12,118,4,121,97,16,28,85,50,78,-24,76,74,107,-47,-67,63,-94,-112,93,-59,-48,-32,119,84,108,74,52,-113,-17,-96,27,122,-67,23,-10,33,-63,-54,49,57,-103,-58,54,20,102,-18,-78,-125,62,20,109,7,-20,107,31,-85,5,104,81,-61,98,51,125,-32,-90,125,-100,6,64,104,56,126,24,-86,109,23,-100,15,23,50,22,-83,30,-128,-82,123,-89,14,-48,-82,-36,-92,-65,-12,10,107,-61,-124,-36,-75,49,0,-105,26,119,101,120,-37,-38,-89,18,-55,-47,-118,-92,-17,48,-14,-50,-72,112,-100,-125,-106,-114,126,-23,-105,-41,102,-7,-5,87,-25,71,-111,-11,-76,-106,57,-84,39,-28,123,50,47,-23,-66,-101,102,-65,103,32,10,84,82,34,32,-112,-14,-125,-109,79,28,-18,97,38,56,-36,-70,-6,-78,-80,33,-120,104,68,27,41,93,-95,125,90,-18,-97,-33,-102,53,-79,4,-27,30,-51,41,-72,-74,92,-102,28,-56,114,122,-105,121,8,-51,63,-117,126,-56,-127,-126,49,84,30,-76,-13,-45,53,57,3,34,-85,49,-112,41,-71,127,-111,22,-114,-34,38,-45,44,97,52,4,-111,-35,-98,-24,-53,42,74,-118,-86,-19,-119,-52,-88,22,-89,119,71,112,-21,26,52,35,126,65,117,-110,4,47,-66,21,-51,-8,-72,-120,-107,72,85,3,73,72,-27,-36,-114,19,71,-89,-100,-111,116,-97,87,-53,-68,-121,17,-29,-60,-28,116,-64,11,45,-83,-125,-55,71,-3,4,-123,53,42,-122,-45,104,-22,101,81,-24,-37,49,91,-2,-77,44,-72,-64,-100,-80,-75,-26,108,-102,19,-107,-51,-23,-11,-4,118,-18,-18,125,90,-84,41,8,-54,30,21,-91,102,-115,-99,-35,-35,6,24,102,-108,26,-8,39,1,-93,76,124,28,-9,114,-39,9,44,72,-72,-24,67,-41,-3,-58,-92,-31,-57,127,29,36,16,-1,-87,-124,-34,-23,57,118,-38,-19,51,121,15,-44,-2,8,-87,-47,-82,71,-14,-41,16,48,79,118,17,-83,-84,-62,5,-127,-20,-12,28,54,-95,-89,115,124,-18,40,-118,-125,-97,3,15,89,-21,45,-19,23,-58,-1,39,19,-18,-121,127,-46,2,38,-24,-64,-48,81,19,-16,80,-128,-37,123,-43,-73,36,-127,55,121,-62,14,93,56,42,-117,-43,-99,24,-79,-46,-112,-34,-99,38,-19,11,23,-70,-128,-121,-81,-110,88,-76,-53,-51,51,-128,52,54,-80,-58,-35,83,10,20,27,-109,119,112,38,-19,97,120,67,24,51,-65,84,37,112,-8,67,6,-104,-127,-50,118,-1,58,-97,-94,-103,78,10,30,-94,-95,-42,107,-41,-67,-39,63,27,-108,91,21,-88,-23,-118,-55,-28,-1,-9,16,-37,-29,-55,-80,-82,78,-112,62,46,48,-41,1,50,34,12,-53,123,46,1,37,108,71,3,41,-94,-123,-50,-16,-42,8,86,-39,-24,51,119,20,22,-55,115,-82,-86,114,-110,8,-72,-15,74,83,93,14,59,122,3,107,-17,93,51,41,-56,-125,28,-21,38,-59,71,69,-48,111,79,38,-29,-23,0,-17,-110,75,113,87,32,50,4,-113,-4,12,-27,-20,-61,-41,-56,-117,-99,-77,-87,115,-99,40,-99,-95,-31,26,119,-102,-53,2,29,4,-21,-86,112,94,-82,45,-65,23,-23,-85,-17,-97,100,75,116,-110,1,-109,-111,29,80,-90,93,74,3,95,112,-48,-106,-18,25,77,-29,-22,72,-117,94,9,95,113,-1,-104,-124,-28,12,97,-109,66,33,-94,-29,91,-88,-102,77,-76,21,-65,95,51,54,-16,-116,78,78,-79,-107,-51,-123,2,40,49,-124,-90,64,97,-3,-105,14,71,-114,112,124,3,-83,-105,-50,94,35,59,-63,73,120,-43,116,16,-91,-46,-18,-117,-108,-26,84,-84,75,123,-97,-21,-118,-119,72,34,-59,-108,-104,-65,21,70,63,-108,-35,-26,-11,-63,-55,53,-81,-125,-58,-115,-16,-54,59,7,0,-12,-67,126,-72,81,-118,-76,-13,121,5,27,-23,80,87,-125,-14,-85,-37,-6,-79,-56,-118,-19,-45,-43,72,71,-49,-91,31,-121,-90,34,89,-22,116,46,-62,-59,49,-4,12,23,40,-39,88,-54,120,12,34,26,-7,42,-18,-89,-37,67,123,61,-91,74,-36,-38,-104,15,113,46,54,0,28,100,-75,-44,25,-56,103,28,44,-92,-100,34,-113,28,-16,-75,-121,-7,58,38,-99,66,-2,-20,-122,-19,11,110,-58,45,17,-72,38,-45,41,6,64,-86,44,36,91,-45,-93,17,43,-73,-70,-41,52,121,53,-71,-90,14,110,115,29,36,-75,-46,92,97,-53,102,-88,-32,122,53,-39,20,-102,55,-101,117,-26,82,14,46,-91,-120,85,36,-108,101,-81,-26,115,-18,-50,-47,18,7,-125,-24,33,-46,-24,-108,33,-71,41,99,-66,47,-43,-25,10,117,53,-2,-14,10,126,-112,-74,104,-77,-57,-30,24,81,93,69,115,89,10,34,90,88,-116,65,-90,72,43,51,123,-85,55,-12,8,13,10,-37,-90,123,-4,40,109,105,112,64,99,-74,-83,44,104,-20,-16,25,54,-82,-54,-109,64,-37,-3,-17,107,124,14,-64,60,-47,-72,40,-84,-74,89,36,6,-98,-125,63,30,14,-70,-62,109,-38,112,-41,127,52,115,-56,27,-112,76,-65,-107,-118,26,-53,-74,-96,114,78,-120,24,77,60,48,29,49,-15,-117,-91,1,58,-26,-84,-9,-115,-109,-89,-21,104,82,36,116,121,-103,93,-50,-103,-39,37,52,-28,-108,49,-87,-93,-115,38,-37,-28,-68,14,-26,19,-41,107,-2,-37,-107,-49,11,-120,17,24,24,-100,-110,93,46,-122,-84,38,6,-7,-53,98,102,35,65,-8,-6,-99,44,86,-5,-4,67,-65,13,23,66,-111,24,7,19,9,-92,114,29,58,-43,-61,-105,-33,34,-26,-57,5,-11,48,77,0,-41,22,-49,-20,-44,-99,-30,10,45,-51,47,-29,20,-61,-11,104,99,21,-15,-67,44,108,-71,-83,-11,57,-104,39,-84,122,2,14,127,5,-110,-79,98,23,95,89,3,-87,68,94,-9,104,40,107,24,26,-97,-36,-111,-100,-95,31,-97,77,49,-69,112,-111,-96,-45,89,127,-9,114,85,-5,-102,16,-1,31,-53,-69,-53,-6,113,84,-6,62,-18,-44,-73,-15,68,-105,-36,127,12,-27,-28,-42,-31,51,-121,-19,86,-111,-86,93,-119,-74,67,51,32,73,35,18,-106,70,44,-82,72,50,-19,98,-45,-60,-84,-84,-67,-126,-5,-67,38,-2,-62,-23,-54,-110,113,-89,-14,52,28,11,-61,4,70,-35,-100,0,-46,-11,-124,49,118,-80,39,-70,-100,-54,-120,-69,102,39,59,16,-49,-50,53,-27,44,-115,90,69,-102,65,-113,20,-47,-115,59,127,-19,-19,-54,-27,-28,39,-94,65,-114,75,-115,-46,-85,-4,75,-67,127,-98,27,-42,1,-43,-124,22,-21,-74,-27,53,-45,127,-90,-83,-44,-23,-86,10,36,59,86,99,-126,-59,108,-99,-45,91,-16,-33,110,106,-120,-87,19,115,122,-86,85,-83,67,-4,-57,4,-111,-5,-58,-2,-91,95,11,107,-53,-68,-128,-12,-68,85,19,-40,-36,-56,10,58,-64,-12,-32,20,79,37,-65,-9,-33,88,123,94,114,31,67,-2,-32,86,-124,-62,-116,-100,41,35,-17,-81,67,-85,-110,83,45,5,-121,-120,-3,14,47,-65,-78,-87,-114,-9,-19,-7,-21,106,74,-40,117,78,-33,61,63,-70,26,-9,56,76,-121,-77,14,87,-125,-32,69,-101,50,104,30,-59,-117,80,43,-98,-11,-23,-94,-108,52,97,-38,24,-10,125,-41,-119,-19,-56,-42,25,65,-39,7,-102,-4,109,110,74,18,-126,13,96,95,99,-89,15,-3,6,106,72,35,-78,82,-15,73,61,116,-127,-83,98,54,-17,2,88,-7,-57,-37,-102,-39,-79,31,111,-6,-62,-24,69,103,74,113,65,-15,68,37,123,-65,94,117,-32,-121,-78,-5,59,120,104,60,5,68,-65,4,-85,64,-80,117,61,-101,46,-88,-123,69,-19,-57,97,-15,125,54,84,-23,-124,-27,-47,114,16,104,44,-100,-87,36,81,-27,-20,-73,95,-80,-64,-34,-77,29,66,-126,-120,77,105,-100,44,79,116,-18,-27,-15,-71,19,-80,12,-18,27,-92,45,116,-27,14,-14,-77,1,-110,-40,-26,-4,-88,-120,60,51,-101,108,-123,116,111,-83,1,-74,87,-69,11,124,93,2,-64,121,62,-45,-79,110,-55,-37,97,27,-79,110,-91,67,53,99,26,-74,98,43,9,-43,80,-103,-23,60,-36,68,-112,-64,20,-31,-52,-79,-113,-7,94,-30,73,-100,55,-111,87,-1,-29,-25,42,-94,-13,-63,108,-59,38,-16,-85,-62,-17,0,47,-90,116,-80,-11,12,-54,96,-110,-12,-6,-128,-31,-64,-109,103,-11,58,-118,-3,-102,0,64,39,-67,-18,93,95,-87,102,104,88,-31,-62,-36,-61,-105,-26,46,-53,93,117,-70,-54,121,-103,52,-24,-10,82,-124,-22,29,-122,84,-76,-64,121,-65,-6,52,80,-27,7,-118,108,64,-82,73,-44,81,-107,-88,84,-100,-59,9,-56,35,-39,-68,-82,26,65,-73,-66,-15,75,-44,-31,51,-65,-62,-73,100,51,-51,78,-112,-84,-19,82,93,-92,53,-69,-38,-66,5,127,-30,61,43,26,48,-63,31,24,-71,-67,-60,-127,-55,-26,-43,38,-63,-49,-101,-37,116,105,10,-109,3,-67,-42,17,-89,110,-103,62,-41,78,-59,-47,-47,-17,10,-51,-16,-31,-41,68,37,15,94,-123,101,77,-122,116,61,-96,-8,-122,-11,105,109,-74,-97,-111,44,114,105,45,-94,42,-99,-52,-113,122,87,-59,85,-109,-128,120,21,-49,-75,-89,11,-10,120,-51,30,-19,-79,-26,-32,64,-71,28,-44,-11,55,-28,59,109,-84,-22,-113,-55,-105,114,50,80,-26,77,36,54,42,-71,-111,-64,118,99,-100,-121,-128,56,-10,-75,-74,30,93,36,-122,16,-105,-50,85,19,-99,-84,-72,-20,-63,96,75,-53,-86,59,90,-23,-73,-39,96,-118,-9,-127,-106,42,-122,-84,108,-18,29,81,-58,46,12,94,-2,-94,33,-75,85,61,122,-100,2,101,45,106,-49,-43,22,-63,-128,94,-115,5,38,35,-8,54,15,35,-114,87,-76,110,-50,37,20,-114,115,84,-13,48,14,54,-58,-93,43,112,77,9,-99,32,-91,-55,-82,34,23,-40,62,17,66,84,-3,82,117,-100,32,33,19,-100,93,102,101,-33,112,-103,-38,114,-1,38,-89,-90,-9,-86,-101,-66,-71,41,-113,5,-40,21,50,89,123,-73,5,45,68,-75,58,-107,3,-67,-64,89,-117,45,51,16,36,-119,69,-78,94,-18,-18,61,-124,22,97,-55,112,-97,19,119,65,7,-109,23,88,-15,-47,-103,-62,-84,106,-5,73,-108,-109,34,33,-116,81,-41,81,-102,67,20,-46,67,-40,-9,-49,10,121,-57,-33,61,28,42,-67,-36,-113,-38,-89,-94,-67,-28,52,-17,-116,-96,117,-51,29,-84,-38,-53,-53,-44,-110,54,98,-76,18,117,83,10,-36,-62,102,104,124,80,34,15,47,108,91,-112,-116,-10,66,-68,55,-123,-67,87,74,51,-47,25,-34,-122,57,32,-96,96,-64,67,31,-41,-124,-87,76,-15,-125,1,13,-77,99,47,74,-44,97,67,108,-4,-9,-16,36,44,-53,3,105,-120,99,-55,-30,-34,118,8,40,106,-95,-122,14,-65,-23,86,-64,-26,114,89,97,-59,-10,71,-108,10,-60,61,-87,-19,-4,-28,-32,-1,35,-123,109,55,-47,-126,-124,-1,-36,120,-107,3,-17,121,31,-80,25,79,127,-32,-19,103,118,-4,21,-55,125,70,-95,-104,-2,-78,-24,90,97,-33,-79,-92,126,20,49,60,41,121,56,120,-102,113,74,1,44,-28,46,-19,100,-46,-127,77,-8,-64,-12,-13,-15,11,89,22,86,-95,36,-105,84,110,-83,37,-56,-40,-92,19,-17,-82,-25,83,4,33,-111,76,-54,-85,35,-107,127,-72,76,89,-123,-103,28,-96,95,-47,77,107,-98,-35,52,59,75,-76,87,-14,-27,-56,75,117,67,-34,91,-92,-45,-95,-116,-13,5,-81,-35,83,85,10,-112,-38,89,117,43,123,-43,-73,104,36,-80,-106,47,113,51,-82,36,93,-84,33,11,-53,-84,-128,82,-86,0,-118,-33,-6,-122,44,35,81,-44,-71,-73,-64,98,126,-20,-49,-104,-126,46,44,-17,-63,-62,-74,-48,-61,-28,67,-99,-25,92,66,-38,73,49,45,92,-69,-26,-91,105,80,-30,48,85,-76,108,-98,-95,-56,102,47,-70,6,-118,-31,-112,60,-62,89,-78,115,-85,4,-1,36,72,-17,-56,-100,-2,-104,-54,24,-56,-92,-60,-106,-115,-53,49,-106,85,33,54,-79,-77,44,47,-120,41,-60,-8,44,-28,5,114,90,42,74,-57,106,-81,79,-67,83,-97,-90,-16,-120,-57,-88,9,34,7,-107,-92,-59,40,71,113,-32,-85,89,89,33,-58,-78,-22,-50,58,96,-19,66,-125,-39,90,-42,25,70,-31,-104,-90,-21,118,98,-111,102,44,-35,-117,60,-62,86,-47,-4,-88,14,46,79,-81,6,-5,101,-12,99,96,43,42,-27,65,-3,-93,-120,112,32,-111,-6,89,105,-67,122,50,57,-126,-54,-46,35,-41,48,0,-98,-22,71,45,-125,81,7,-26,23,118,-60,25,101,-128,-95,117,22,-29,-126,74,86,-53,-39,65,-86,-62,64,-77,-8,-85,90,54,-28,124,-128,-1,-112,105,127,-124,-40,123,63,123,-77,-84,13,-5,53,-46,-31,-74,-36,-16,27,13,-124,-24,-98,-115,-83,101,48,92,13,-5,-98,-111,-10,-51,-40,-115,-81,-82,-52,24,102,98,97,109,107,-1,-46,109,50,40,-48,-23,71,-70,34,-13,-111,43,110,-41,-9,-1,108,37,45,-28,-72,-45,-50,121,9,-66,-4,-10,-86,18,16,-119,64,-36,33,5,-13,-125,93,19,-6,-61,126,48,95,-116,11,-62,125,-6,67,111,-1,-54,2,82,45,-103,-4,19,-66,20,18,48,15,94,-91,33,119,82,-15,-24,116,15,67,30,111,-106,90,80,13,-20,71,66,65,108,124,-104,-94,-124,120,59,-95,-80,16,-101,83,90,14,25,-96,-64,-38,-24,98,-17,-69,108,-89,-29,-30,-11,-101,99,13,53,-56,72,52,105,105,88,2,75,26,23,-13,122,3,-114,71,-29,-70,-9,-98,67,58,-122,87,7,126,-30,111,69,-61,7,11,103,-6,-6,-16,56,-32,23,94,29,-31,-63,-47,67,5,61,110,57,43,54,41,74,28,-65,97,74,-22,-115,-126,0,86,-50,-83,-3,-93,116,5,-29,22,21,-79,-54,34,68,77,-76,-34,84,-116,-31,-102,-13,-55,85,64,-42,44,-115,43,85,100,-60,-104,103,-54,120,-65,-69,44,-102,59,107,81,-79,89,-44,121,-24,70,-110,51,75,76,117,-7,61,110,-102,42,-28,-28,-67,-12,102,-19,-27,18,121,115,-46,68,-81,-124,-110,-33,56,108,-83,30,4,-97,-79,-17,114,88,-86,105,-9,17,0,61,11,101,7,14,58,-100,-38,-42,121,27,119,-48,62,56,94,39,-49,-20,7,26,-99,108,-44,120,87,-2,-117,-78,64,-56,76,-83,-105,26,21,-3,8,81,-74,-100,50,67,9,58,-118,-14,-96,-13,65,27,-122,-73,102,-83,-40,-60,-13,-120,16,51,112,-51,-81,-15,127,-7,100,-116,83,-20,-72,59,121,-39,-43,114,97,55,-9,-53,56,107,45,49,-102,106,-126,-54,59,-44,18,-64,101,-75,62,-123,-70,-110,-17,24,-44,57,-122,104,43,-119,-40,18,-107,-113,25,122,-19,-90,123,74,-35,-86,107,102,-22,-51,56,-14,-100,109,-124,1,35,-85,-16,-124,-65,-21,1,30,55,-75,67,-121,109,-78,-102,82,-23,-94,-60,46,0,-104,-96,6,12,39,101,62,37,-39,-84,-92,48,3,68,34,26,-47,-67,60,25,-2,118,-110,91,77,46,2,103,43,-85,-107,83,-23,-23,-71,-7,-110,42,43,16,-82,57,-55,-52,-102,-32,32,-70,-111,75,116,-11,116,-44,-75,-14,1,-123,-128,31,-85,71,33,-72,78,-102,70,-72,48,-15,60,38,56,79,93,114,-83,75,-6,-78,120,25,-127,112,82,-37,-90,-121,-92,-112,-35,8,119,-32,-35,58,77,-9,109,69,-107,-21,11,-128,-42,-70,48,-30,-23,-78,-81,30,-123,-40,-8,106,-127,9,64,-51,-78,122,95,-109,81,-15,-43,27,118,-92,88,37,-109,-106,52,-8,-62,119,-45,65,73,127,-96,-115,53,-125,46,47,89,115,8,71,70,-40,-107,24,15,-119,-64,115,41,54,-11,-103,-108,-20,6,104,-67,-8,95,102,90,19,15,73,-22,13,-7,55,113,-53,-123,-110,51,40,37,-83,-103,-61,34,59,114,-25,-113,-103,87,-26,-10,-121,88,-65,-79,-63,92,123,-62,31,59,-87,-11,113,31,14,88,25,23,35,-49,-83,-21,-59,53,-72,109,-22,-64,59,89,-104,-42,52,24,-60,62,3,91,7,-21,15,61,-117,-109,-1,65,-39,25,-37,-34,26,-2,-51,62,61,24,-15,50,-32,-48,25,-55,36,24,99,6,94,-25,-84,86,-30,-95,-94,-102,-53,29,65,-81,69,-85,117,65,-7,0,-66,-23,-75,127,-108,62,10,-5,66,-4,29,-59,-82,41,-55,58,9,65,-128,55,-58,-67,-28,123,99,-121,-70,-99,-6,11,122,-108,-18,119,1,78,103,61,121,-104,-68,117,-22,-108,31,64,-68,-68,-96,52,41,58,11,-54,-26,118,14,75,-54,21,60,-119,-66,-19,11,-64,-5,76,-97,-9,81,-126,62,72,-115,64,117,23,65,73,-87,-121,-40,-48,90,-82,73,-91,57,42,-53,54,-11,6,102,-104,-117,0,70,52,-56,103,104,-1,-12,-103,32,59,12,123,-75,-104,-123,16,31,-35,20,55,-116,-109,-44,-50,-63,24,76,35,-116,-29,16,-32,-43,-68,-115,-56,32,109,-34,-9,126,-39,74,-74,-46,-19,-82,-105,-115,32,94,17,105,-103,68,-50,-121,-29,53,-7,74,77,98,-123,-68,37,-8,62,-21,-23,4,-99,-80,-103,45,-58,-2,-95,5,58,35,19,-65,-37,108,-14,35,-90,-53,-123,-5,28,39,-21,17,-38,70,-53,94,30,62,24,34,-74,14,101,20,46,-61,94,125,-121,-122,88,36,-127,-97,-98,80,110,80,14,10,72,8,95,50,4,113,27,54,-124,-117,-48,-39,122,52,8,61,94,40,-69,-34,21,7,-56,-123,-90,24,23,89,57,-87,-97,-16,-80,63,-50,-118,76,-25,-17,24,90,-4,-112,-94,32,58,-32,11,-12,28,48,118,-38,-69,107,61,92,-104,116,-112,-62,55,-110,127,0,-46,-54,17,-57,116,54,-90,-36,114,-39,53,-32,33,-69,72,37,-70,121,-84,60,22,-95,-105,-74,-7,-67,-49,-41,55,98,60,-57,-51,-107,48,31,48,-72,-35,-38,-5,29,-102,65,78,79,71,-8,-113,122,76,90,-55,-31,102,77,-66,107,112,-128,101,122,-83,-62,111,126,-75,101,-55,-118,52,68,-128,115,63,76,32,-6,6,90,100,-109,98,-59,19,109,114,-1,84,-58,79,-52,95,121,-77,114,-52,56,-13,-114,67,91,50,-51,-94,-115,113,-58,-33,56,-92,55,-120,80,-125,-85,126,-114,-126,44,22,-29,-82,113,-92,91,-39,63,-34,-90,43,-21,-3,113,-81,-5,-91,69,-59,120,-126,127,43,66,113,-111,-99,47,-46,-73,-13,55,-7,73,37,110,-76,68,105,13,94,-36,10,108,-127,-76,126,10,100,21,-80,-117,21,-95,-79,94,77,-72,98,-63,24,93,7,-124,25,-15,-62,84,-99,28,-99,-82,113,-65,62,13,-51,-117,115,37,-125,-40,85,-96,70,31,26,-27,2,57,43,-15,-112,-36,-5,-72,106,44,-97,126,111,-31,-89,-66,76,-114,-111,51,120,69,-106,56,-70,1,-54,105,-56,-8,-92,-123,-71,40,-52,-20,-93,-102,-104,76,48,77,-30,76,53,-113,-16,40,88,44,-107,34,53,18,-21,95,123,-115,53,-28,21,47,82,76,-58,-114,-104,22,-97,-90,109,73,7,-108,-30,-96,89,-84,-47,-46,-62,110,25,-128,-54,-75,-62,55,121,42,-62,69,54,25,-75,7,122,87,88,-68,-83,-95,-100,38,-103,-96,74,-57,109,-34,51,72,86,89,120,66,85,18,95,-84,101,-86,15,-32,48,-104,-99,62,115,43,76,-14,76,-92,27,-5,-8,41,-74,-114,50,-77,-97,-67,-109,16,-36,106,-52,85,50,16,-68,-27,-99,-22,-112,122,-15,63,64,23,121,23,54,-31,126,64,76,16,18,-57,-75,97,-94,-23,-94,72,-40,-53,30,-55,87,-63,-13,116,-64,9,-72,11,-45,-90,11,59,110,44,28,-105,62,-80,-27,20,-7,46,45,57,35,5,126,29,-91,77,-65,-60,-56,10,-115,-42,115,-17,-67,34,12,56,39,-119,-20,-66,22,-39,54,-102,108,1,107,-75,14,-104,-127,-87,-17,-88,103,33,-71,-85,-76,23,-95,-94,-102,107,92,-96,61,121,-98,78,-33,-28,33,75,-10,32,-14,-125,-72,-96,-4,10,-65,7,-52,-27,92,-71,100,61,87,45,9,-43,110,-52,-70,19,45,-110,-66,-74,91,-126,-27,106,-110,58,114,-86,-52,-77,-63,-50,-65,67,-54,33,116,37,64,49,-7,76,-115,22,-124,-105,50,19,-126,81,86,124,-37,-5,-48,19,32,-65,-21,80,-93,-124,-23,-25,24,16,97,65,51,29,56,-79,-117,80,-50,14,-77,-23,87,96,-52,125,49,2,55,13,61,107,-106,93,-116,102,-37,-11,-23,-119,53,-43,-39,-86,-96,0,19,13,15,15,112,24,-73,76,79,-76,99,-127,90,-18,119,63,3,-29,111,38,34,-66,-34,111,31,-29,24,-95,-70,5,65,-15,86,-43,16,76,-127,-120,6,21,-29,97,-31,53,-57,-39,83,-117,-48,-99,126,38,56,-78,67,-18,43,72,-96,100,-37,109,-92,89,94,-88,36,121,112,-33,-69,-42,-99,112,-80,116,-42,49,20,5,124,26,26,-32,-118,-28,22,65,13,-105,81,-98,124,40,-76,52,-104,97,59,82,96,-99,-46,-27,-74,-125,-36,64,-31,114,-83,-28,-61,81,8,-81,-49,42,48,36,-81,12,-80,68,83,38,-115,-46,93,-86,62,-56,-52,-36,7,-88,-85,-80,38,5,-106,-8,-125,-94,-81,123,122,21,-112,45,-37,116,81,48,93,-122,32,-120,-28,48,-85,-99,-47,50,-67,-109,-14,78,-79,10,56,-98,41,-22,10,-20,74,94,-120,-30,110,50,86,74,91,51,43,-86,-44,11,65,-11,127,-97,-31,-24,119,-16,-66,-73,87,-95,-64,109,98,-127,-30,45,24,-11,54,61,76,109,126,24,45,-1,64,-24,-28,28,114,-113,-32,-103,122,-125,95,102,-7,-33,-25,-28,-7,-101,63,109,-9,111,-45,73,-41,-111,-48,-70,-113,-40,28,-32,-95,-41,76,33,-53,-112,-106,75,71,117,-94,81,19,19,53,96,125,-9,-82,40,85,6,65,36,-91,68,59,9,91,65,-67,-34,65,121,125,-25,-107,-38,-106,-122,20,-83,109,45,-103,122,-31,-42,-42,84,23,-57,49,-69,27,41,78,-116,3,-65,59,-28,-52,-101,-91,-29,-29,37,113,86,119,-51,-19,-104,-84,42,90,-113,125,-32,37,65,-21,119,126,11,-13,-37,59,-49,-80,60,90,-114,7,-117,-84,-22,-50,4,58,69,-93,106,-77,110,-46,125,78,93,-124,-20,-42,73,75,-60,-59,-52,80,-5,6,-105,-14,-58,-59,-72,34,59,-46,-96,-102,76,105,-8,-49,-79,-81,-47,-94,93,-100,77,-119,-115,-102,-115,-68,69,-126,107,-86,-103,91,83,-26,-42,73,-84,-54,5,-85,-104,-61,-28,22,100,-71,-126,-43,97,-128,38,88,41,112,94,-84,39,-55,-119,36,-115,60,107,87,1,-45,-114,-9,-80,88,-105,-67,-91,90,-111,-96,95,-113,-103,-24,-70,91,-113,-70,-122,-83,-92,-20,121,117,37,-105,-10,126,82,81,89,-2,-118,36,-21,-9,-85,124,-103,65,-6,118,-45,-33,-5,-113,122,124,87,58,-30,-47,-43,54,-10,-116,88,-17,44,29,94,-106,-59,41,54,-86,101,98,-116,106,-12,-12,95,13,-29,-103,72,55,-73,6,122,-106,124,79,54,-93,17,7,-101,69,-72,-102,-43,31,71,-44,92,37,28,-104,127,54,-7,-50,-74,-35,-125,-16,-119,28,-17,-44,122,63,117,92,-23,82,14,-28,122,-38,-90,26,88,-74,22,127,115,111,-128,61,-41,-104,-9,31,112,37,29,53,-3,58,52,-27,66,-76,-73,27,78,92,-33,-125,39,110,95,-96,-61,-125,-16,80,-107,101,44,63,114,47,-101,-47,124,21,-31,-99,-57,24,46,-24,18,121,-104,68,-113,37,-76,-71,102,-10,59,-124,112,123,121,91,78,-17,-14,32,-82,49,2,102,-47,-83,-30,-19,-3,67,-50,-42,41,-92,-21,-72,117,-111,-74,97,26,-26,18,-78,104,41,67,48,122,108,-19,105,64,-111,-45,-45,43,-80,-66,115,84,81,-36,-31,59,60,28,-10,125,72,30,-64,105,52,45,-74,11,38,-16,-118,-3,-46,98,-77,40,70,-69,-114,-77,-70,60,123,83,-102,-80,42,100,109,81,-77,115,7,-127,-87,-22,-48,8,57,-72,-41,-41,-9,3,-54,80,-30,103,-54,-16,118,105,-37,-87,22,71,-48,-33,121,62,-90,116,66,-38,-105,22,19,-21,-41,83,112,-39,-28,-81,-109,31,-125,-95,-1,54,-84,72,-108,112,89,-114,120,-73,110,20,-55,-126,-93,-58,68,-105,-107,65,122,8,-103,121,-97,61,-74,97,99,-65,1,46,7,57,69,-122,100,-112,94,-94,116,23,85,106,-105,79,-108,-128,39,-111,83,-87,-66,112,-102,24,-7,-72,-78,-97,-8,99,-113,-114,79,115,-51,89,-88,83,-90,28,56,113,-102,57,40,-104,-76,89,-8,38,-5,-67,-9,-18,38,-121,27,-25,-110,-29,3,-10,123,16,-40,-93,-36,116,-20,-73,-111,-18,87,-123,120,113,-121,-97,-47,69,105,-68,-97,-111,-53,-94,114,-81,77,92,-37,46,-80,-18,-9,108,-69,-25,-46,27,-101,-86,54,53,-109,-44,85,-11,-61,-87,34,-17,-25,79,-46,101,-22,-30,85,99,-65,-30,117,12,-80,-23,-16,54,106,-89,-120,-29,64,1,-94,-111,-75,82,-3,68,120,11,-103,-52,87,22,-46,-17,-117,-63,12,112,-123,-52,-121,71,-122,-55,101,-125,-41,105,-53,52,-9,60,-3,56,-1,85,15,-112,127,70,-7,4,48,-72,-29,34,11,-103,-46,114,56,-109,-32,17,9,89,-1,114,92,86,11,-55,-87,-80,-18,53,-4,42,86,-90,15,-50,120,49,-46,22,57,67,-59,90,110,-97,96,119,100,43,-90,-54,81,-89,21,-80,64,-14,-47,126,92,-17,-37,51,121,40,-34,110,-54,-99,36,-73,-43,85,52,-30,121,-9,-18,-51,91,102,-116,-71,86,95,-55,95,-35,74,118,101,-114,87,20,-48,-60,117,-76,55,-108,49,74,-22,20,-43,41,79,114,-96,-12,-68,43,-44,126,-28,83,19,111,-128,-19,102,-110,56,-77,71,89,17,-26,-16,32,-27,-14,-127,-37,62,-107,-34,126,110,74,104,6,85,8,79,-74,107,126,30,-52,80,29,-11,108,65,29,-128,109,-2,59,123,28,-107,62,110,110,-123,71,-68,-39,-20,-108,-57,38,-36,-12,126,100,112,-32,-103,55,98,-82,-5,89,-41,36,88,-92,99,118,-56,97,12,-16,113,88,71,-96,76,-77,117,60,-5,-84,23,-41,45,31,46,0,33,-3,69,4,38,-119,-20,96,-115,-50,28,-38,-9,85,-113,36,-106,3,-96,-23,-80,7,-19,-111,101,92,-107,116,-9,53,-120,-3,5,-13,-87,-115,1,-35,-125,-23,-89,19,53,117,69,-67,-107,-122,-33,-32,-10,-122,-69,75,-116,-35,-69,43,-74,109,-107,18,107,-48,-85,52,-38,50,83,115,-101,5,-39,62,-7,99,-46,97,44,78,31,27,105,-72,-117,-94,-69,-86,108,-59,-30,-48,49,-22,-124,-114,-2,-19,-126,-122,-29,-21,67,60,15,-111,-55,-22,35,81,37,-75,32,0,56,47,-18,108,41,-120,0,122,-4,51,95,-68,-20,125,78,77,119,-115,-9,109,59,-128,79,-124,-114,7,9,91,-8,11,-80,-112,29,-56,-32,11,-50,29,-82,74,-19,-6,-55,12,-115,18,-6,15,-123,-15,72,-62,12,43,1,82,-30,2,-17,26,-30,58,-85,63,-56,-100,-117,52,-90,-69,7,-26,121,111,-92,5,-61,-90,96,63,-18,60,-11,-52,-81,125,99,25,67,82,-71,110,97,122,51,39,33,93,28,-116,123,48,-107,-64,-9,-31,92,-62,-68,-103,-102,-107,48,-2,-100,83,127,41,-82,-105,-7,113,-120,10,58,-122,23,84,-18,20,-37,-82,11,46,42,-95,16,-58,-105,-78,62,-57,-82,39,-18,0,106,52,-51,36,-59,76,98,-108,124,-67,-40,-3,73,19,45,121,-45,20,76,-21,0,-57,46,-18,90,79,66,-56,-42,-47,-39,90,-120,79,103,34,-104,-30,-67,94,120,35,59,-41,25,-128,125,88,88,68,-48,-47,-25,-10,-12,92,125,20,-99,66,55,118,-42,46,114,67,-9,37,43,119,-84,79,-8,-21,123,48,82,76,-63,-23,-17,27,-108,97,53,95,-109,68,41,-50,-32,-119,-20,-71,80,-9,-57,-16,-4,17,-36,66,19,-113,82,-76,39,-128,23,47,9,30,-87,-35,-48,96,100,15,-4,-86,-58,-10,-1,83,-52,17,-102,37,-88,-13,-2,-23,-92,-52,-89,-33,-112,-47,60,122,28,-101,-99,92,-67,-88,77,101,118,-96,-123,-108,-108,-43,102,44,45,-48,84,-25,110,-74,86,-7,50,-109,-9,59,-92,-67,79,23,29,53,-57,-89,73,9,1,65,81,17,31,8,-107,92,126,-119,53,52,98,-126,60,-82,15,-15,79,110,111,22,-82,88,-110,-49,-113,-124,-127,-51,88,-48,-87,-17,-55,62,45,41,64,-111,-95,-122,-46,-91,116,-55,-125,103,75,95,-29,-56,29,-36,-115,-41,-56,-100,88,-81,-33,29,-81,-11,-90,77,-17,-10,-127,-6,-121,30,-4,30,-24,-124,109,67,112,25,-57,34,4,79,126,-109,126,-47,-101,-9,-38,117,-76,-43,37,-120,-86,85,54,-70,56,-15,39,-40,-80,3,26,-64,-45,-69,-35,-120,70,24,-97,-29,-53,19,69,-113,-112,-78,-53,-106,-74,-61,94,78,-57,97,-58,46,58,-21,62,-121,-97,-16,-38,35,35,-127,-120,125,2,54,-30,-44,-17,30,9,-20,30,117,-53,52,29,95,-92,16,60,-29,102,54,-66,122,-110,10,-113,68,-78,-120,-71,111,-96,-37,9,-11,39,111,-52,107,-25,-77,-9,81,28,0,-55,43,-98,-97,-37,-123,69,-4,23,-98,102,106,-11,-42,98,5,115,-121,-84,-86,-78,-69,11,34,-115,-94,3,-104,-9,51,-38,-113,29,-39,83,86,54,-116,-27,-108,61,10,27,-44,65,-91,-86,34,-40,99,38,-14,101,126,-82,-56,-8,37,-102,-52,102,126,-36,74,95,113,-83,-37,-66,-20,-55,-98,-115,-49,96,-44,-123,20,-1,75,-2,10,-90,-61,107,87,94,-63,74,-55,0,2,41,-123,-103,-85,-13,-107,-39,36,-47,6,-21,-70,98,78,-119,52,26,8,-40,72,117,115,-78,76,-57,-60,43,-25,-87,83,36,54,127,-78,127,19,98,125,-30,86,121,62,124,-32,-96,20,-110,97,-126,13,-104,6,-122,36,-105,55,105,-48,-121,-83,0,18,-113,-114,-39,20,9,-20,-23,-49,-115,83,-107,70,121,-30,86,-48,31,-23,125,-114,-67,48,-86,-90,21,83,-79,-107,64,-60,-91,69,54,-73,-77,99,88,-10,15,57,-29,-128,-47,101,-96,-50,112,-85,120,-16,-78,7,27,116,-128,-11,18,49,-19,-33,41,15,-35,84,-67,-15,-57,-73,36,41,15,9,77,83,39,27,-54,-82,33,4,115,-60,101,-117,46,-56,-18,100,74,126,-27,-25,-48,10,-51,-41,126,-81,-95,9,-60,85,99,80,-6,-16,27,108,77,44,46,114,-26,20,-69,15,92,98,107,-59,-114,-87,28,-121,-61,84,125,-125,-44,-13,116,-120,-55,94,-84,-86,-75,34,1,121,-25,-80,26,43,-97,-12,31,-58,75,84,2,-109,12,-61,-68,110,-21,92,-27,13,-117,36,21,107,-3,-125,80,87,45,-108,22,-61,41,75,-115,29,-29,33,-111,-4,-22,-94,8,24,97,-124,25,-52,25,-7,-74,-36,108,-114,12,3,-32,84,75,34,-60,-88,-10,96,84,12,17,114,-119,-41,41,-48,-3,-16,1,21,-14,-115,-11,-25,96,-36,10,-71,-14,-3,-83,6,85,-91,-18,-108,81,36,-33,70,-59,-80,-81,-31,11,19,74,-22,107,91,8,57,29,-95,-80,61,-40,-82,-110,97,122,-114,-102,-77,123,83,122,46,-24,-121,-28,111,18,-47,-35,-102,-120,114,-93,22,115,-82,113,77,-78,76,-66,65,117,28,86,82,27,79,-128,119,-88,63,-31,11,87,124,-10,-71,-99,94,-89,-82,76,-124,101,-53,58,-74,9,-50,-114,31,-3,-119,-51,57,-29,92,-75,113,-47,-103,40,-81,-43,-100,-12,-102,4,12,-36,-26,-70,27,-118,-88,50,-73,28,-113,-94,122,-1,4,-57,124,-126,100,70,-87,62,7,-91,-91,100,-102,-56,102,34,118,44,-90,-47,24,-32,30,-99,-98,36,113,-124,11,-126,-84,-15,72,117,3,-46,-18,97,-73,-38,24,-47,-4,109,-50,-86,-112,88,-97,-65,-73,112,72,-37,-125,20,-29,-43,-2,51,-16,94,58,119,-101,-48,121,-116,94,103,52,64,48,51,-70,-113,106,41,82,-44,111,-106,-62,71,-105,-66,78,-78,71,115,-50,-123,4,33,88,22,-40,-111,-46,-82,-34,-67,-58,120,-28,-18,-52,-126,-31,-109,11,84,-94,10,-15,94,-89,-106,125,-62,-6,98,62,-39,-11,-34,12,12,-18,-50,-78,-60,43,104,50,36,-62,-58,-36,-14,-104,-88,78,21,-18,43,-118,-124,-68,-35,-62,52,102,18,87,25,-106,-78,29,74,127,98,-2,-99,-86,37,80,6,-31,86,112,77,-51,121,-126,70,7,35,3,-85,-24,-78,114,-109,-25,-58,120,-127,-78,26,-100,8,-116,10,-20,-23,14,-18,120,42,-75,79,44,60,-58,102,69,-104,25,119,103,28,-70,22,26,25,124,3,-15,-11,10,87,-23,120,-68,-44,93,7,9,-8,-15,125,-79,-70,15,108,-66,-90,-5,-82,-14,115,-75,-122,74,127,108,-100,4,58,-106,66,-117,1,11,6,-69,-96,-65,55,-8,102,-41,-72,75,76,16,-2,-10,78,59,-42,-72,-1,-31,-100,113,26,-66,48,-4,103,57,71,-94,-2,14,-28,-36,22,-8,-25,39,-51,25,99,91,70,63,11,-124,69,46,-34,-21,99,-70,-110,-90,32,116,34,-74,82,43,-104,-56,31,-117,-43,67,12,-72,115,-84,-62,-9,21,-30,105,82,94,86,12,40,-47,-39,40,-114,-67,-89,-72,-64,-62,-124,-105,32,95,-124,-41,-14,48,26,8,-116,-57,24,-45,-45,-75,-40,-111,-118,107,116,66,-97,-57,-79,-96,-85,-55,49,-55,-32,-87,-76,-12,42,-85,85,-16,75,-41,-112,49,-29,-28,-124,-10,-60,62,-2,-112,15,-36,-33,81,-95,117,120,51,99,-64,30,11,106,-21,-42,43,-59,51,117,12,45,3,-116,110,88,104,60,67,102,-74,108,80,-58,-108,28,38,-108,16,63,100,-24,-36,-1,70,97,7,32,118,-112,-122,-31,-36,106,10,115,-89,35,58,-15,-5,63,19,-123,-99,-11,-94,108,-18,-13,70,-12,-1,126,-15,-9,-25,113,111,66,-59,81,-88,-114,97,-121,-76,16,8,72,62,3,-107,106,-43,92,-91,63,60,-90,-61,96,-9,93,-24,-17,-22,38,-24,29,-27,-36,-25,117,99,-10,76,66,-77,-71,33,-87,100,48,-13,-122,-49,56,-104,72,72,-84,103,72,115,-10,45,19,-22,52,-97,-77,-107,50,-81,-93,-79,102,-71,46,73,6,-21,-52,5,-96,32,112,15,-44,-4,110,5,-26,-85,89,-87,35,73,-17,59,-95,-5,-123,94,127,-83,9,-122,-64,-58,-72,-111,33,-91,-82,56,63,1,6,-67,-106,-55,26,-12,-105,-32,115,-38,-95,118,117,67,-17,95,99,120,-75,2,28,-113,-105,117,-15,111,22,-46,116,25,-91,40,44,84,37,-4,-66,-125,15,69,-14,49,-12,-11,87,-68,20,91,110,117,125,-65,-34,-36,84,-29,-87,-27,60,-66,-118,-125,49,69,81,54,7,-119,53,-23,-60,-9,22,-116,-125,-58} + +#define IP4_WEIGHT_Q15 {18,-12,-44,78,104,-34,61,92,-120,-75,40,-19,29,-80,-56,21,60,-92,107,-118,58,-104,94,47,62,106,11,-105,-6,-20,-32,24,43,43,-116,48,53,-86,-50,-38,-108,-80,0,-73,-5,115,-26,111,78,76,-101,-55,94,39,-61,118,94,13,-20,-81,100,70,-111,94,-125,63,71,-121,-70,-69,-14,-74,54,-121,60,107,-121,-106,51,-38,-61,26,110,103,-43,94,-116,111,60,-125,-28,88,83,120,62,-39,-79,112,-85,34,121,-93,-121,97,-45,-97,-90,12,-97,90,109,-45,-59,-100,-105,-21,0,-26,-122,-37,28,35,-10,-115,-87,6,-62,108,-15,26,118,-84,-26,1,-74,73,-41,-65,97,86,94,67,34,59,-99,106,-67,-80,-26,-71,-21,-20,115,109,-43,-107,-21,64,37,-2,-20,-75,115,108,53,35,-102,45,83,-106,-49,-59,-46,-102,121,-41,51,-55,22,19,-58,-103,-116,80,25,-126,122,-76,-7,-34,-2,110,15,-46,82,-16,15,-19,-52,-39,-73,62,93,67,117,-27,62,-12,-89,-15,-100,-57,59,20,-127,52,-37,-79,-41,-43,111,-31,99,13,-12,43,99,-1,-31,43,124,-15,-30,120,-69,-79,-36,-19,-89,89,46,116,54,-46,49,94,85,67,113,11,24,-59,-17,119,-119,110,-57,-81,-1,77,32,118,-38,-13,113,-53,-94,111,110,-19,-14,-53,4,117,-20,-35,121,24,-97,119,18,-31,108,54,30,-74,-121,16,101,65,3,107,-12,-38,14,-53,125,60,-59,17,52,21,-65,-118,76,91,-112,106,-38,98,26,-4,-53,-63,-108,95,-58,63,19,111,-74,73,37,63,-115,-84,-44,22,-47,-51,60,9,29,22,-57,81,-87,-27,-65,-63,-93,63,110,-26,-126,-12,7,-118,-127,-113,-70,45,107,103,-69,-48,56,25,55,-55,79,113,111,120,-2,43,108,-122,-41,93,40,44,88,107,-78,-34,124,122,63,-67,29,14,24,-69,-72,67,108,26,116,88,90,-48,93,-103,-37,127,-24,115,-76,-80,-97,-61,96,-54,-22,-14,-123,-49,62,-17,-1,21,-65,116,10,113,10,30,88,-24,-119,-95,89,58,124,-119,-112,-115,88,57,119,68,-17,31,-27,-9,-64,18,-26,109,-60,4,59,-89,-127,8,-35,-90,88,-76,22,109,-123,-51,88,-90,18,25,45,47,-80,75,-66,-24,-109,-47,-42,68,-8,-98,78,-122,19,33,-72,94,2,-109,-84,82,102,71,55,-121,19,76,76,93,66,-42,-23,-2,40,3,106,123,-111,8,83,105,117,121,-52,2,-4,-18,-4,-19,-125,38,80,83,25,-64,123,47,36,105,29,-71,-72,-127,-41,-82,31,3,-43,9,73,124,91,-3,-99,-27,101,77,-51,-96,60,15,74,54,35,-119,116,53,-4,46,-29,8,2,93,75,-18,38,49,40,30,-30,22,97,97,-8,-35,-111,21,-62,97,-96,-12,82,28,-118,87,-12,29,-16,46,110,8,95,58,40,41,29,105,-58,-108,-29,-117,36,106,-118,11,-124,60,84,-83,-87,21,53,-31,125,-5,114,-75,93,-41,-127,-98,49,31,96,64,-112,60,-126,2,69,-73,94,-23,-100,81,-115,-116,94,-25,-44,46,91,-89,12,-47,75,107,-77,-82,-10,79,-70,-106,75,-1,62,104,-69,-7,-41,73,53,-32,74,26,-113,111,-115,-55,66,20,-91,7,-47,51,-96,126,121,-75,63,81,-23,14,-124,-41,-39,-13,14,-27,16,-56,-48,-43,-84,120,33,41,98,26,-6,18,15,8,31,-9,-50,121,-107,-106,-33,-46,64,-19,127,-104,-59,86,-30,-121,60,-79,39,-38,-5,85,-119,-17,21,-120,44,-22,89,-17,73,-102,49,26,-73,-69,91,-71,-36,103,63,-8,125,61,103,-116,-20,11,105,-116,15,-78,-122,-80,-62,-80,-58,65,-119,-47,99,-26,-111,69,87,-38,-15,-44,-87,-14,-84,-37,-27,109,-90,-72,-4,-110,38,82,-97,-50,29,61,52,-44,-87,8,63,83,92,109,-124,-47,69,-110,-70,111,-10,25,15,104,80,66,32,-70,-16,-49,-52,-16,-41,122,104,22,-31,-109,18,62,102,125,-123,74,121,5,92,-92,-90,72,-61,98,-2,-125,-81,101,109,-120,60,58,10,53,94,38,-25,-56,-13,-80,80,-13,45,-77,-43,-44,-37,-62,46,38,-103,-124,-93,48,76,-82,1,73,74,67,63,-59,-26,76,116,66,70,-113,-30,106,109,25,75,-18,25,25,85,-83,81,78,-50,99,-53,-125,-68,44,-104,96,-44,-126,124,33,112,-75,-29,-9,-60,-126,-84,-119,-61,-127,-6,-46,-26,-57,118,105,-4,21,-120,54,-121,-35,-70,-101,-124,-79,-33,-30,105,57,-108,-48,-111,-65,-108,41,77,112,111,118,68,0,22,110,44,56,-91,-49,-111,62,-54,78,83,66,38,102,-14,41,52,14,-94,106,105,24,27,53,-40,-70,60,-119,56,-95,68,69,59,-101,-124,-25,-119,-45,102,-55,-38,61,57,104,-96,88,122,99,-122,77,106,122,33,126,-5,-74,46,116,-52,-51,-101,74,74,2,-3,-21,-38,68,-30,17,96,71,-124,-23,47,64,-35,24,107,49,41,-50,-23,88,19,55,-30,-91,3,-54,-14,125,10,84,-96,100,100,67,-116,-40,-124,2,53,-62,45,72,21,82,10,-47,-126,54,-84,-50,13,-2,-66,-1,103,96,-17,123,59,-111,-61,-70,-20,-57,54,-94,-110,-125,3,-101,14,-128,-86,80,-44,-94,37,113,123,-104,-9,-87,109,111,120,33,-7,-62,-51,-57,49,-71,3,18,-49,-94,-32,-92,40,-52,3,52,105,108,123,40,1,2,-86,38,-104,52,-93,-44,-73,-62,91,-88,5,-91,-61,-24,-40,-30,-48,-115,114,62,-128,-85,-93,-43,104,-20,102,-103,-52,-56,25,-103,49,-25,10,84,-52,51,-94,-110,26,-108,1,30,32,-23,126,-112,-82,86,-102,-17,-108,-32,78,32,80,-125,-112,91,8,-69,24,-95,-86,-73,-115,14,9,-2,-121,101,-109,-72,1,54,84,-36,25,95,-49,108,-110,4,24,126,66,-63,56,-8,99,-10,-80,-73,5,72,-103,-10,-35,78,3,42,-61,-83,-115,-99,84,78,20,30,-66,-88,97,-120,-66,120,-46,-29,-57,118,15,-94,-110,-29,25,89,113,-110,-52,90,-92,105,-30,48,92,-44,-1,-39,-96,118,115,37,-3,15,-1,-2,64,81,57,-47,24,-14,89,-103,48,-127,-95,-100,-114,14,-69,-82,-32,-9,-77,-38,33,-76,-63,-32,51,69,-8,26,-75,80,59,101,-31,40,-37,-23,76,-110,-23,-83,-84,111,-31,124,122,-56,-67,-112,4,-123,65,67,101,12,-23,-12,-43,54,-87,35,66,-89,-47,-105,55,100,19,-80,21,-76,-85,-117,-61,19,107,-71,42,86,-9,-80,33,-65,120,106,-49,77,-34,-38,-50,-27,21,-28,65,97,108,-77,42,120,69,24,127,-20,89,112,-66,-126,-110,103,43,0,-63,28,-17,36,-43,-68,-117,115,-69,70,107,2,94,95,9,-83,-99,47,53,80,-105,28,-27,119,59,82,95,-94,-16,-49,15,-122,16,-89,17,64,-6,88,4,21,47,-78,50,-25,121,-36,-47,72,-21,-101,29,9,-83,28,-113,-68,23,115,-67,-101,-101,102,-98,-124,-98,-89,-24,82,-28,40,-89,125,23,83,97,-53,-7,-108,-90,-83,-113,-26,-58,-119,28,97,35,-74,6,-15,-40,-10,11,-98,79,101,101,-72,8,-99,117,80,-65,127,95,15,60,-29,2,-92,60,-118,-116,46,79,-79,-62,-43,104,73,107,117,-43,-127,-67,113,44,-41,67,-98,-73,26,74,59,-111,79,45,21,-60,-26,18,-72,54,-70,-30,10,114,-82,-124,-126,-52,-97,108,120,-19,-111,-52,102,10,18,99,49,-128,-17,91,-46,83,-76,-3,-41,45,47,-72,3,-19,112,-104,122,14,-77,-35,-23,121,41,-123,-2,-60,50,44,84,-45,69,-58,-69,43,-98,-11,-17,112,-95,-36,-69,67,-52,-11,-45,98,-126,-33,81,51,101,-38,67,68,-37,-78,12,107,105,75,-100,-109,-55,0,11,45,-24,3,54,-70,77,-63,125,52,93,-16,-22,-97,35,97,58,46,-61,66,-98,-61,12,-43,-63,-45,-36,-79,41,-58,54,-49,48,-63,-33,-110,-49,-36,93,73,-78,-33,50,-76,-6,-48,4,-87,-88,-81,-30,-33,-109,10,104,-94,94,38,-124,30,6,102,37,97,56,73,-106,-18,84,70,4,-31,-27,-90,54,63,50,10,-18,-113,125,-116,-86,-119,64,33,26,-128,-25,-77,76,-127,-79,0,60,-65,5,-63,-5,101,-91,69,-49,67,71,121,-22,59,-87,26,66,-26,7,-79,-73,-51,0,-114,-22,40,-115,-87,29,-18,-23,-72,-96,-55,-119,69,68,-102,-99,124,16,74,-34,5,87,120,-28,-6,-92,-111,-42,-85,-36,123,-86,-52,83,-77,-15,43,124,59,-81,103,96,-80,41,0,-62,-22,-13,77,-99,71,-121,104,72,43,107,4,80,-62,54,-98,-63,-13,-92,10,-119,-95,-76,-90,76,78,95,-108,-117,122,-115,88,52,-10,26,122,39,101,-80,12,107,-108,36,-13,-72,36,82,63,119,-57,-44,-7,77,-55,-25,-54,102,-118,-93,-91,58,11,11,-30,80,-62,-77,111,3,105,39,-63,-50,-33,-6,29,52,-98,-80,51,-5,-50,-122,93,116,-77,-45,79,110,-103,-20,-123,-16,-58,93,-101,-11,57,24,44,-60,-118,64,32,80,3,-25,107,60,126,124,-90,-22,-95,-91,-57,83,-46,1,-28,78,-47,74,15,42,26,113,42,-76,14,20,33,-93,37,107,89,-22,16,23,-16,60,108,-117,74,111,52,78,-97,53,-127,123,9,-78,-15,-17,86,5,-17,-120,28,-76,69,13,-76,120,-64,-35,-17,20,-98,126,-42,-88,-99,10,-113,44,84,115,-35,18,81,2,99,-82,74,-125,12,110,55,-110,31,-94,23,62,-4,-62,-122,-120,40,42,110,34,84,2,-3,-24,-75,-10,124,-38,-46,-14,-11,109,57,27,111,6,-99,27,126,72,41,-29,106,-24,96,96,60,-18,42,-104,82,53,-69,15,92,-79,127,-70,-102,-53,102,79,32,84,-119,115,-36,7,-84,-24,2,103,-77,54,60,1,-7,-64,-7,-22,114,-5,19,80,-49,107,-7,-2,89,-63,-26,-111,-51,17,-108,-40,9,-51,58,108,-55,-68,-117,99,-51,-117,-17,46,-33,69,13,-23,4,-71,-110,4,-95,119,103,-30,31,23,76,39,-36,6,-117,76,6,80,106,18,-124,-3,78,112,3,40,23,-55,-100,75,-118,-16,-52,18,69,-77,-91,126,-87,41,103,-127,7,105,106,77,-23,72,50,75,-16,-19,126,112,67,-4,-102,-56,53,38,-72,-60,-69,30,0,47,-95,100,53,-127,-16,-18,-16,29,46,73,90,-112,-97,-111,-15,-38,23,44,45,115,-93,-68,-32,-10,86,19,69,32,-104,-112,97,60,64,87,61,69,55,-92,-4,-77,-28,76,-82,56,123,52,-105,-38,-1,81,80,-40,-14,-78,115,32,-59,-123,-115,50,3,69,-14,5,-39,70,-124,34,61,-35,-57,34,127,-120,-13,109,-108,68,-22,-125,81,89,35,-21,88,87,107,-32,110,-27,-19,-82,-114,-81,99,115,-54,-92,90,65,-126,26,64,-114,36,70,-93,10,-94,-111,-90,118,-45,-3,-121,106,80,10,-101,-25,-12,-72,39,114,47,43,125,33,88,-109,-81,10,98,28,-98,105,96,123,-43,-58,-115,-122,-88,85,-80,26,91,-26,103,-88,-121,-66,101,87,-88,125,20,-58,-62,-46,-113,-100,-36,93,79,33,-108,49,-45,0,-19,70,103,-48,-19,-15,29,122,40,121,118,102,86,-83,111,-86,-26,-124,6,86,49,50,-67,-104,-28,-28,35,52,42,-25,-87,-6,-70,18,126,123,-128,-3,-109,-49,-94,-120,-62,62,-89,-107,94,110,109,10,-37,-126,99,-116,-85,113,100,-19,-52,65,-101,-45,93,-49,96,-78,84,28,-44,5,-110,-48,-26,62,127,49,-53,57,67,-85,127,60,120,-67,-96,107,34,-60,91,-6,-80,-8,-77,-119,50,89,-52,-64,96,-60,127,-76,-34,-1,-52,34,-25,100,99,-94,-46,12,-47,47,-47,-14,45,59,3,-74,-85,-49,103,-79,-6,-1,-25,0,-2,-44,-29,-11,6,108,-23,-48,91,56,75,-77,-71,-46,-100,-98,-100,90,-29,-56,-35,-3,54,-126,-62,124,1,-88,-26,4,101,95,-113,-67,75,39,104,-106,68,127,-127,-15,-36,-12,23,-51,-118,-22,-67,-39,-71,-77,52,104,9,-106,10,53,34,-98,-67,-74,84,95,87,38,-35,-103,-38,-125,-124,-31,41,3,-89,-41,-107,-9,-90,-39,-58,83,-106,-86,-24,-93,18,23,14,36,-56,-36,75,-123,10,7,109,13,-119,113,80,-68,45,35,57,32,-17,-1,28,-98,52,6,-37,-97,118,48,-119,-69,-102,37,-18,-4,-59,101,15,91,40,-31,3,5,-9,105,-9,-33,-31,-7,-71,-112,-71,-2,70,98,46,73,-99,42,-77,53,-38,48,-1,-120,76,-33,-62,-35,117,67,-117,33,58,2,-127,-100,-66,-117,-82,91,115,-111,33,24,-125,-89,76,84,15,27,-5,-87,49,-72,-35,-128,-49,114,65,82,-71,127,100,41,74,-63,52,0,-67,8,117,-102,5,123,87,-37,8,36,126,71,-108,-73,20,104,-76,-71,-50,18,-56,8,-62,-52,-105,-127,41,16,-26,-122,31,11,70,-100,-109,117,-35,88,29,-45,-78,115,-86,102,40,18,-58,-54,-84,32,-36,56,51,52,107,126,38,78,-66,-77,20,65,-119,-113,26,85,-92,-67,-35,-24,-47,-9,43,62,-70,-66,-41,-7,-72,-77,-79,56,75,49,67,65,43,102,-78,113,98,53,-47,20,-116,-4,-2,-12,-36,50,8,-118,-79,-120,-37,4,103,62,51,107,-90,79,49,-17,61,-15,36,17,-117,39,123,-87,61,11,96,-108,1,53,51,36,-19,-51,-69,-40,-91,127,-90,-62,126,79,-72,-61,123,41,-27,11,14,76,-67,-17,-70,-104,47,73,32,-120,-109,61,38,31,-1,-37,35,-21,-26,59,-53,-85,18,75,106,93,-83,-31,-18,-127,18,19,66,-74,10,-25,45,18,-109,30,4,13,-62,-47,13,-59,44,-96,19,-18,-113,65,-5,-75,91,-21,68,-90,46,25,-110,1,-115,-88,-91,55,13,86,24,-60,85,108,93,27,-61,-14,28,-110,-17,-18,68,70,113,-52,58,-9,52,111,-64,-97,64,-100,0,43,32,-88,13,-32,0,110,-104,92,108,66,-112,65,34,-64,-125,106,-9,113,-116,91,-35,-88,-91,-16,13,-117,3,37,121,-84,-75,-1,-44,-49,13,-77,81,46,113,-115,15,-37,21,-17,33,-19,-83,-95,27,28,83,53,22,-23,66,-25,-57,-15,-56,69,106,49,63,-120,125,106,-86,55,40,4,-96,-26,43,60,-107,-116,-76,-89,101,51,98,-21,106,-49,53,110,83,27,-119,36,2,-5,86,-50,47,-75,42,52,-59,63,-71,-67,60,83,6,65,124,16,28,14,63,-58,52,23,30,-81,49,-123,-26,42,-39,60,-27,-61,-66,-18,-88,-22,-46,-61,-60,65,66,-100,111,116,100,50,92,103,-83,111,-72,-5,116,111,72,39,101,54,-65,-44,8,-128,-88,113,18,-70,-78,-70,87,29,112,-31,63,9,12,-109,-27,-42,-52,55,-48,-70,95,-71,93,122,-46,53,-115,-22,-27,125,125,50,-58,-50,21,-71,9,-6,-82,45,50,51,-14,-74,-72,104,95,-86,57,65,-39,6,-10,21,-76,-52,127,-128,17,-36,-23,87,103,24,-95,95,10,95,21,61,-96,-24,-8,0,74,126,-14,-102,-44,107,-119,83,-123,51,27,-64,-17,124,24,-96,79,118,43,8,-95,-75,-106,-84,115,69,3,-118,122,-64,96,-29,-106,-78,-97,-82,122,51,14,-80,65,121,-66,-119,74,121,82,-120,77,96,-82,56,106,-45,-28,-116,78,-70,-13,90,41,-77,-55,-78,-49,91,-109,-36,-91,97,-31,95,27,-91,-116,-21,-17,87,112,-82,-51,62,-42,64,111,106,68,92,53,-68,-38,-55,-25,-38,-121,74,5,-96,-77,-14,-109,-87,75,-62,-108,12,-97,93,-91,42,24,-5,-45,79,126,-10,-71,-97,97,6,-19,-80,77,39,-111,-69,42,-123,-61,-30,-78,64,18,77,-99,82,-40,127,-39,46,66,46,-82,-70,-117,77,-17,27,96,10,56,16,83,22,114,114,24,-89,118,-84,116,19,-88,80,16,-25,66,111,-70,70,-86,-88,10,-1,80,-82,-95,95,-20,-121,-114,26,-15,-104,-77,-120,-7,97,123,68,69,-12,59,24,-20,100,46,75,-76,-23,-41,79,82,-3,-115,44,-69,-55,-100,95,81,-108,-125,-121,-46,-48,-112,-22,-10,-40,-60,112,22,79,89,-99,53,-54,48,-110,16,-51,77,94,59,-103,-50,-10,34,-115,60,84,31,-58,-55,-10,64,23,-5,112,96,85,75,4,-106,-77,55,-33,87,-76,-79,53,71,-8,-92,63,118,-60,-84,99,107,46,88,-89,24,-41,98,-36,-22,34,-88,-23,78,84,56,52,-14,60,123,-20,38,-56,-66,67,-80,117,-6,115,121,39,-126,-77,-8,89,22,29,-101,55,29,-31,-108,123,125,-46,6,103,-88,-35,25,-58,65,-118,40,-39,26,62,15,-25,77,-50,117,44,79,-79,64,-114,94,-31,-26,-67,-10,-114,-19,69,24,111,14,-33,-52,110,50,95,-107,63,-71,36,-21,-22,-7,-95,19,-71,-38,-88,124,47,120,98,22,-69,73,-5,-114,-18,106,-41,-102,-26,28,-41,-101,-105,-31,-120,-26,22,-21,-31,-44,-50,-127,88,85,111,33,-53,-114,-12,71,53,126,-55,82,93,-104,-77,41,-50,46,90,54,-28,-38,-128,-68,-80,-13,34,-63,31,60,-81,40,55,77,-5,-17,94,-110,30,96,26,61,43,-48,-128,101,13,-8,-6,-29,-60,115,-62,107,-57,54,96,13,114,-89,36,-69,-40,106,98,107,19,-28,-4,14,-97,-60,-71,-64,-107,-48,75,-50,-54,90,60,108,-101,-104,25,92,-60,-17,48,-63,103,113,59,24,51,32,-26,-101,121,71,-21,-83,-68,79,-115,42,5,89,-38,65,28,-91,22,4,89,7,-57,122,-51,-120,-58,-110,-42,-70,105,102,-112,33,-83,21,-14,62,-116,123,-55,-114,95,-110,-46,76,-12,-6,-88,-48,-126,49,-67,95,-94,42,76,84,-112,-64,-20,114,9,-8,-96,-38,-38,-85,72,55,7,127,117,54,-52,41,-89,-46,-95,-121,-97,-113,46,95,79,-105,96,36,62,111,-38,89,-97,61,24,120,90,-111,-69,43,48,88,25,-58,-89,55,26,14,121,-126,42,79,56,-43,-88,109,-53,31,69,-114,-1,-81,94,-50,35,20,-93,62,69,-96,120,-35,-103,-86,126,-44,-96,102,54,12,-97,-79,97,-49,-18,80,-68,-111,-17,39,87,102,6,-10,11,2,-89,-74,-104,-43,-9,53,-68,28,-126,-71,66,-26,34,102,32,-36,-96,-83,87,-127,83,-50,-60,-98,71,-81,108,-97,-74,50,20,-98,-9,75,8,-48,0,124,-27,74,-59,1,-121,118,52,-57,15,112,81,120,-10,-66,42,87,-92,-89,-123,-1,-29,-74,126,57,-50,31,115,-47,-20,-89,-107,51,49,28,110,38,-73,-37,-72,-70,-124,-20,-109,67,7,-114,64,32,-76,101,-107,52,-89,-109,51,-51,-3,-98,122,100,-57,-2,34,-38,22,-101,15,92,9,-104,47,-9,-18,47,27,-38,-58,-122,-20,102,-78,-63,-19,-71,-112,65,-48,49,27,85,-113,-57,108,24,81,-96,-47,99,-67,-121,-17,2,-29,-9,89,109,-45,-127,-59,122,44,-81,-39,55,5,40,0,-11,61,37,-82,18,-97,-69,-45,27,11,-70,-88,31,117,-98,115,114,75,-104,46,-3,104,-67,49,21,18,95,31,-8,11,55,-76,22,39,-17,10,24,-63,-97,57,114,-46,-62,-66,34,-86,-94,-67,-109,124,68,26,42,-65,-60,97,-41,59,118,-104,55,16,-25,-13,-99,-28,-50,-50,103,51,-77,91,55,53,-17,-108,-82,-121,-54,118,24,77,24,-120,73,-61,36,-122,-63,51,-88,22,104,76,14,63,118,122,-31,59,-115,-92,29,-66,101,-48,-7,-5,30,86,-41,-87,11,71,-15,75,-30,-110,2,9,91,18,101,-102,-51,-115,-83,14,37,-41,-17,106,-43,-108,-42,34,-86,65,57,12,-13,114,25,-36,-69,-48,93,-99,-89,-104,54,19,15,-101,-105,24,-51,-26,93,95,-2,-43,51,-14,-112,-83,69,77,122,20,-7,107,-29,79,115,115,-102,-58,-111,46,8,112,-67,-20,-97,-88,98,75,-30,-47,90,110,25,3,-8,94,70,47,22,-91,-103,-54,58,-38,-12,-50,51,37,72,27,7,-112,-50,31,-14,70,-76,-95,-109,-111,48,-75,118,-2,30,-7,-123,32,33,-89,-47,25,-6,67,73,-29,-7,-93,49,111,112,76,-65,8,-76,-95,45,83,-79,84,23,20,-96,-52,15,-70,-56,7,-58,106,85,122,-96,8,-84,85,-101,-30,35,-14,23,112,33,-86,20,-93,73,-30,-8,-79,-39,-77,-36,-38,-107,-112,-89,49,-27,103,48,31,127,-22,68,-35,100,99,57,-26,74,85,118,101,-43,105,-76,-93,-127,44,-1,39,68,12,93,-33,13,-78,11,-51,85,44,-99,12,-85,-63,98,-5,-92,76,25,-68,-86,-121,-67,-64,-109,31,64,-90,-58,126,52,-41,20,27,120,-86,-117,71,-128,-128,-28,-39,82,-102,113,59,30,-128,78,30,103,-11,-95,117,74,113,94,46,56,-96,41,48,-85,-25,-28,-79,104,3,-73,2,30,-22,76,-103,101,83,-89,34,2,127,-26,25,-82,8,18,-3,-20,13,52,-21,36,-38,90,112,-85,-92,-79,9,-72,98,15,-26,-32,-4,26,-26,-94,112,-5,69,-21,31,-84,-17,-112,-83,46,-24,-105,3,-102,15,-60,-123,99,-6,-47,22,-120,70,125,86,35,38,35,5,-100,89,96,64,-33,-55,29,-82,55,-3,17,89,52,104,126,62,-125,-80,113,34,53,77,83,-28,-65,-27,2,68,-114,-37,-4,-94,89,-41,51,-85,43,-36,93,-93,74,-8,109,-92,-70,114,-120,44,-63,77,102,50,36,88,16,19,99,-9,64,-57,-43,-81,-67,-70,-9,89,-64,114,53,-99,5,-31,87,74,66,-37,75,108,-100,85,-101,-44,-120,-32,-70,92,80,30,-16,112,-102,96,99,-6,123,-89,100,102,-38,-90,102,-80,-9,52,9,-47,-114,-81,-128,-112,2,87,-40,-41,46,-15,119,-107,79,105,15,-53,108,72,-22,36,45,82,-88,59,19,118,27,123,-93,-46,-44,93,-98,64,105,-80,99,-110,-8,-51,33,-58,76,-103,87,-13,26,76,-93,-13,83,127,-4,-52,-54,21,70,-93,20,-7,19,7,102,94,41,67,14,-52,17,54,23,-81,93,-61,76,-23,-92,-118,9,110,99,-53,-128,123,-127,-24,-125,-76,88,-79,63,-65,71,-79,59,-45,-64,-85,-111,-53,55,-102,22,-78,48,-67,25,100,0,30,72,19,56,-54,-6,40,-71,-42,98,127,-46,58,40,34,-6,-112,21,-113,2,-14,-42,-25,-78,-55,12,62,58,-127,-44,-40,85,29,-80,-27,-72,73,8,-36,-32,-21,34,-46,84,41,75,109,-41,123,-92,20,-123,106,72,47,41,-73,-12,-38,117,-89,44,-128,-102,-65,49,-43,69,-53,-119,60,-97,-39,9,-118,-33,-58,28,105,-41,70,111,39,-41,90,58,20,-25,-21,110,50,-114,-68,-104,-35,96,58,-16,98,26,-80,-98,63,74,119,-85,21,-124,8,118,-61,-125,-112,23,30,-77,92,-11,-28,-101,-57,-9,93,-49,103,32,-97,87,116,-96,77,-48,-27,92,57,-29,-25,52,-107,-77,-50,114,99,-79,24,-58,-19,-96,-113,47,-80,8,-83,-72,69,-6,55,92,39,17,76,21,-127,-5,-60,-115,-55,-28,40,-43,-43,106,112,-35,-57,25,80,19,-39,-6,-111,-79,4,-59,-77,121,-103,-89,-127,-113,28,61,-50,-125,58,-38,-33,43,124,41,69,-105,2,99,83,-31,-119,-21,38,90,92,-88,113,-83,56,-56,61,-49,-74,-2,-23,101,-114,26,114,-95,-52,-73,-7,-53,116,32,49,119,81,-88,-49,-102,-126,50,-47,38,-13,76,69,-73,-124,5,-53,-63,11,-42,35,-97,46,29,-43,112,-2,46,58,83,-17,41,-5,125,-34,-96,67,49,-17,-80,38,-82,81,29,84,-13,96,-112,49,13,65,117,52,23,3,49,-26,-43,-88,-97,93,-60,-93,-34,-54,-74,5,-113,64,-73,23,-95,50,17,-112,123,-90,4,-35,103,16,-41,26,-104,109,-119,-71,95,28,60,-71,-41,-26,5,-118,-31,-126,58,-93,-50,-48,30,-51,-31,-2,-92,-75,85,-52,71,112,-48,74,-65,-24,41,104,121,-95,122,-83,-49,119,-20,38,97,23,-73,-22,55,-118,45,25,-37,47,-122,89,-4,125,-105,37,55,102,52,-12,34,7,85,15,-6,17,13,18,97,20,-92,79,107,-16,117,-80,60,-3,-23,81,-70,124,52,-36,105,-44,-125,-40,-81,28,88,-57,-111,-96,-49,18,-5,71,-37,32,-73,53,1,-124,77,-70,-107,33,-79,-83,-34,-125,43,20,-55,15,-53,59,59,-97,71,44,78,80,33,-20,65,68,-72,-125,23,-30,-3,-89,93,64,88,123,-44,126,117,59,38,-5,32,40,125,124,98,-104,-31,-59,-27,98,12,125,-43,-48,-74,43,62,-6,73,-3,19,100,-104,-62,35,47,-8,37,60,-125,-100,95,49,-74,-15,8,76,58,14,-85,20,-56,29,70,-125,94,-60,-56,-112,82,73,92,78,-40,-37,37,-50,22,19,63,23,-49,116,27,113,82,-5,24,46,85,41,106,-11,102,-123,60,45,-108,63,124,-67,114,53,-14,-126,-108,64,-6,-27,-19,-101,-27,102,112,-45,93,-4,-36,-68,-111,93,-64,69,-128,-109,-78,-16,-62,-79,-51,-8,-39,-40,-94,-4,123,-117,70,87,-91,-79,15,18,98,11,-51,-104,-76,-59,40,-82,110,100,102,13,71,42,117,-81,-41,-120,-48,-17,-20,44,-44,-120,76,79,123,-128,111,-51,71,-41,-76,-86,-32,80,-43,124,-65,123,21,5,5,55,34,73,-46,-55,58,-108,116,110,85,59,-61,-24,-86,111,-34,-128,-111,59,45,-125,-94,-47,-90,48,-109,-56,-95,-37,-127,79,-17,102,-52,-96,16,-77,31,40,-59,-93,-26,10,-28,108,-2,-85,95,-25,-88,-94,120,30,-24,-69,-9,90,81,67,-92,123,116,42,12,123,88,86,-86,10,-16,-77,54,-119,-54,-43,-7,104,-111,-75,-3,63,-96,-95,112,-68,80,68,-128,3,-13,-37,74,-113,62,-88,-32,-40,-48,55,-21,-64,64,118,-126,-41,-79,-75,-112,-78,-81,19,20,-10,86,97,-20,127,101,56,118,69,-62,73,52,125,-15,-84,-30,65,105,-53,-59,-54,87,-87,87,-116,49,-120,71,-48,-108,99,-19,-107,-98,-40,58,86,-119,-125,-62,-38,23,91,85,-55,52,-31,123,-76,120,77,49,122,-118,-19,-56,86,-74,-15,-82,47,-121,-83,21,-69,119,-86,-39,59,-84,87,1,19,-58,-67,-122,-45,54,-38,-96,-13,100,-91,-118,-97,-72,73,-30,23,-121,-30,-36,94,-38,20,22,-4,-85,-7,50,114,-105,95,35,-85,-41,-89,93,8,-53,45,87,93,117,30,17,-61,69,-61,48,-52,-75,-99,-104,-113,-27,10,80,89,119,107,-76,-30,75,125,122,55,-13,8,-37,-37,13,24,33,31,98,-14,101,-51,24,27,37,-51,110,-15,83,-49,-122,85,-30,18,-17,92,101,12,97,-54,-99,4,73,-82,-46,111,29,-7,-75,90,106,-91,45,68,-111,68,-63,99,86,-74,-122,-35,21,-28,-22,74,-80,-70,-93,50,-9,14,-84,45,-18,-41,-50,-105,-94,82,-89,102,74,-38,120,90,43,-17,-82,-83,-119,-17,-106,52,-80,-63,123,124,75,-118,98,0,-100,-76,77,-72,-18,80,-49,61,100,107,89,-27,93,-70,-52,-68,-89,-46,49,-9,-77,13,-29,103,-52,-69,-88,-65,-33,39,-119,-105,29,96,48,86,-76,55,62,-128,109,5,73,-94,-11,-43,-82,-32,52,122,33,29,63,-40,-89,-88,77,-16,67,-69,-106,-59,112,59,6,-67,-92,-115,107,-120,40,38,69,-33,87,81,9,8,9,-31,-110,-68,113,-117,44,-81,-62,-85,-23,77,-6,84,-63,-126,58,105,-48,75,38,80,-2,-45,34,-62,107,-8,-16,-82,-17,-128,57,-113,12,-99,-110,-47,100,-44,-23,121,42,-29,34,-64,100,-124,123,105,-7,-128,117,5,13,-13,-125,112,86,-4,53,-128,-81,-87,-75,-18,116,-77,-110,-122,100,-60,-124,117,82,-35,77,87,29,125,-127,123,-54,100,-117,-100,-49,-105,-77,2,-110,-4,-101,6,53,63,-103,76,-118,-40,108,-103,52,122,-3,54,57,-86,65,86,4,-106,-99,82,68,-44,15,-41,17,51,4,92,22,-63,-83,-126,63,65,-115,76,-109,80,-50,16,79,105,-115,96,-71,34,-61,-89,92,98,-36,-88,56,113,18,-123,120,32,110,81,108,-29,-31,34,-102,-24,-33,-8,76,25,-128,77,90,84,76,-98,-104,-4,-105,-65,-62,10,29,-80,-116,89,120,101,-36,22,-85,77,-44,3,-107,63,-19,45,-126,16,1,-29,31,-125,113,-108,30,-103,-127,-38,26,-18,-120,-56,-121,32,-25,102,-7,-85,-50,47,-121,-109,-127,-6,-34,55,-34,-114,82,-6,83,-44,-2,-69,101,-34,-21,123,33,25,-23,-108,-46,-107,-46,56,38,-30,108,106,-31,60,-78,8,4,25,124,12,37,29,2,89,40,100,-48,21,-53,-87,109,-116,77,-46,-60,-64,122,-68,-25,-109,28,-71,62,121,-73,-84,80,12,-88,-118,-89,109,-74,106,-62,89,-65,58,-73,-74,-110,-64,-73,-27,-87,96,-128,-122,54,-72,42,22,-37,73,-87,6,31,29,-46,62,23,-99,63,114,-20,10,-43,68,15,-24,124,-63,-25,76,-12,30,-43,-86,38,111,69,-121,-5,-49,-42,34,-51,119,80,39,86,-32,-74,27,-71,-24,-25,73,74,-11,104,53,117,87,-11,-32,-115,-24,-78,99,-7,-113,-76,-99,112,-20,50,121,-9,-103,111,-10,-68,-9,96,-35,-108,10,2,-38,-18,-73,90,-64,-105,94,-22,103,22,116,-68,99,-42,124,-117,-122,-119,-43,47,-6,72,90,52,-52,-76,2,-84,-22,-19,-85,92,-124,13,-115,2,36,107,15,-76,127,47,-39,3,-109,90,-24,-74,1,-29,-17,-21,-27,32,102,-57,26,-108,-114,-104,-112,76,-47,86,-17,-86,38,114,106,-81,-77,67,52,-28,-68,23,-63,-57,-110,95,-81,-35,-97,-96,-29,-11,64,-118,-1,-99,-25,68,-24,-118,-84,-113,68,94,-39,93,77,-80,-1,-123,12,97,80,-117,111,-52,5,5,-24,-98,-27,-96,48,-37,-108,-28,70,63,-21,23,123,67,-33,47,-96,-58,-50,-109,-124,-64,20,-37,44,-101,34,100,95,94,-57,-4,39,-21,-62,-37,-76,-72,-51,114,10,-21,113,-68,45,27,-77,105,47,18,122,43,-117,-99,-82,-15,40,-7,112,-86,27,-37,83,-53,-8,1,-110,64,47,-58,44,14,-50,18,-33,-17,69,-90,51,-58,35,-103,29,38,100,107,-44,106,-99,-49,-90,107,23,-44,-79,-21,7,-10,40,-58,-76,-50,-106,-47,84,34,91,23,-9,113,114,-91,-11,-62,64,58,20,44,-76,-55,-105,38,-101,94,121,-125,81,-128,-55,-101,-22,78,100,43,94,118,-46,-103,-36,48,81,45,90,2,-3,44,-8,-49,-66,104,116,-69,-90,-78,28,15,-65,-31,103,14,-71,-103,-90,36,-54,-81,-62,-35,70,-60,103,45,-13,20,-32,127,-93,59,127,-89,-54,-23,117,77,48,3,-84,-56,-35,37,87,-115,60,11,-27,103,44,78,-16,-3,-112,-44,45,-112,61,-102,-104,-67,88,102,121,104,-106,46,-39,-91,52,-77,-13,118,-79,-52,61,-5,-90,46,24,-84,-59,57,-34,-62,101,47,-66,122,-18,28,102,-123,32,-19,121,12,81,-110,89,-38,-78,8,-78,-2,-94,44,111,-2,-36,-66,22,-59,83,-43,92,-29,60,-71,92,7,-51,19,-2,-66,39,-100,116,92,-78,7,124,107,103,127,-115,62,80,99,98,-74,-95,109,-3,-126,59,-61,-93,-58,11,87,-24,113,100,21,-65,-103,-71,-106,122,-71,96,100,-38,-23,-118,72,0,-68,-55,-108,88,82,73,119,-105,59,-90,-41,99,76,37,-41,-62,18,94,-37,67,56,68,-41,110,-24,53,14,-62,-121,38,-84,13,48,48,116,-17,-80,110,-63,50,8,-4,111,-77,-4,77,112,19,64,-9,-32,-45,77,72,-90,-127,74,88,-61,-85,-75,63,125,-46,-86,-15,79,116,7,76,46,-99,14,36,-55,0,76,95,101,-115,-18,67,-35,71,-104,95,8,-124,-42,38,13,-70,98,18,77,51,-27,-82,-61,-66,26,2,2,-26,-119,-61,-70,44,27,114,99,-99,97,14,34,63,-44,-88,65,82,-47,30,-99,-97,-13,13,48,47,117,4,-29,37,-7,11,28,78,-59,41,-94,8,-125,99,32,-109,-13,14,-58,11,100,101,-94,-61,-49,45,90,47,77,84,19,12,-86,-24,-63,112,73,-48,4,-91,47,54,3,67,68,5,-26,-64,-71,110,113,-96,23,105,-14,-79,67,-18,36,-35,48,-36,68,-33,56,-5,39,-56,-11,-20,-43,6,-33,82,121,29,-78,8,28,-29,-76,-101,-81,116,-72,-98,97,-16,107,123,-89,-47,102,-84,-113,-107,-24,105,-112,-67,-41,-77,-18,29,-19,49,54,49,20,41,63,84,103,15,33,50,-118,-25,42,87,48,61,-48,-121,-74,16,-85,-13,-14,6,-76,82,-68,90,-4,-40,17,2,-101,81,102,-80,-2,-64,-74,-54,8,7,99,-117,21,21,74,-50,-36,-89,85,-75,-35,-29,2,-105,-55,2,71,28,-118,53,-84,126,2,9,-104,-20,45,4,-113,76,10,124,81,83,88,50,66,95,44,-110,17,122,30,92,26,-85,-53,73,-32,-78,-127,5,34,3,-75,81,-15,54,-13,9,-126,-42,-102,7,119,96,34,109,67,6,-70,116,-26,9,103,19,116,-9,88,-12,39,-88,92,85,-87,91,33,-43,96,120,-59,-53,12,84,-18,-68,3,-87,48,-99,87,-28,21,-88,-93,86,116,63,100,33,-65,-56,-36,-36,-38,-80,-62,-97,-87,66,77,-65,103,85,-99,73,103,102,-80,104,-70,60,-6,-96,-67,1,-44,-1,90,-80,-59,93,39,-81,63,66,-35,17,-56,-58,-49,83,-80,71,-54,-111,-7,92,-48,29,56,-7,-107,-114,21,-75,54,-124,-60,-3,-78,-13,-110,61,123,80,96,-49,-105,-115,112,-29,-68,126,-74,-87,82,70,-70,16,-84,53,-16,22,29,-40,-47,-90,14,-117,6,-3,-13,64,87,-84,-100,52,-57,23,108,74,59,-37,82,45,20,87,-65,52,-96,57,-61,2,-33,-39,78,-79,-61,84,63,34,27,37,-13,12,32,101,9,-16,21,-19,59,-119,57,-97,-124,127,76,6,83,80,27,-31,102,-105,56,118,85,89,16,98,-57,68,6,3,58,-95,-78,-77,26,-26,-21,5,-113,23,90,-110,-16,35,-108,-23,-47,-14,-42,102,119,46,10,58,83,-117,-49,80,-38,-58,80,25,-85,40,-2,-54,-35,-100,-77,-80,87,-122,-94,-45,-115,63,-10,86,84,-47,101,-114,123,111,71,-75,-111,-47,43,-35,-99,-22,-3,106,-89,-94,22,111,-52,95,104,-17,71,96,7,10,-99,-90,-38,32,-81,-7,30,-112,-16,-11,-104,106,-30,78,-110,99,30,-31,111,-125,-50,-19,-66,-50,109,-113,26,95,-74,-86,4,-66,70,-4,-2,-14,-86,-83,118,48,-62,-30,-2,-78,102,-105,83,-45,37,58,100,53,-66,46,-104,-25,125,-112,49,89,95,75,88,22,19,-76,101,-35,39,20,-82,54,61,-40,-106,-83,32,-106,-80,116,-52,-45,-126,-86,-56,-71,52,108,70,39,-24,103,71,121,117,120,9,5,-97,110,-79,-39,77,-56,71,-90,-97,3,-8,-64,-5,-102,105,59,-76,-100,-65,-99,-7,-6,85,115,14,112,118,65,-60,10,116,68,-83,69,-118,23,13,24,40,68,-2,-78,-43,79,-63,96,-5,-19,19,-56,94,-79,96,-7,19,-93,31,-47,30,22,89,43,-104,61,29,-49,-111,61,-41,121,32,116,121,-17,-109,-51,51,7,-6,-80,-84,-105,-41,88,-61,16,91,115,69,-25,-80,-12,45,-70,80,75,-22,-38,111,15,-71,39,62,68,-51,40,11,-9,51,44,29,-27,-106,112,-95,29,-105,-114,68,105,-109,-68,-13,-82,33,51,50,-48,-65,-103,-46,13,-29,-51,17,54,123,-91,108,-73,43,-120,27,100,-13,32,52,123,33,-52,-43,-110,-79,-76,-30,-86,-90,109,49,103,-28,39,-52,41,106,0,-13,10,124,-57,-15,10,-124,74,26,91,114,-63,-48,52,11,83,-44,95,13,-23,-57,114,82,-108,96,39,-34,27,29,-60,30,99,5,-101,-128,117,-74,-47,-118,-33,-69,-121,-18,-112,20,-6,117,-35,-80,-35,-102,109,24,-33,-5,47,-13,101,-127,4,25,1,-57,-117,-65,74,-107,-64,125,0,-60,-78,110,-100,-19,-1,-63,27,-17,61,-75,-84,-56,-29,-25,21,46,107,88,-33,109,-89,83,-83,-121,-100,-55,-48,29,-3,28,98,-59,-64,-73,-65,-86,-63,30,92,4,-29,65,-26,-111,47,1,-21,-109,26,-86,-119,113,-1,-29,-88,75,77,-54,-35,-95,22,24,-40,80,127,-56,-24,125,43,-18,97,-32,-77,61,-85,-105,69,19,9,127,65,10,9,-76,90,-37,-2,-15,-18,-57,2,11,27,-51,109,17,28,2,90,22,69,98,-55,-53,-63,125,48,44,-13,-96,-94,65,-116,88,-2,76,72,61,79,64,12,-112,-11,72,44,-103,-29,-24,106,78,91,-93,72,74,-123,-121,-36,4,79,-28,92,83,-109,-99,-98,63,92,-39,98,94,-43,10,-57,83,-23,50,92,79,-111,-79,-32,40,-34,91,-26,115,-124,68,-19,-72,56,-101,60,-73,-55,-83,36,-59,-86,3,-73,-98,-85,103,3,10,-113,53,34,-90,112,-122,-114,26,46,52,58,51,-101,29,-1,-87,-108,25,-77,-51,0,97,32,-36,57,117,67,-124,-61,-67,13,8,-108,-59,-50,28,95,10,-112,124,105,-127,-54,-43,-86,53,-50,-1,-108,65,-111,35,-42,-119,-28,-47,-92,15,-97,-50,12,-42,63,10,-71,-23,22,83,-24,20,-28,69,114,108,98,29,3,123,-42,-101,120,-36,13,-44,87,74,15,-89,77,-23,56,65,-12,19,54,66,-31,-111,-16,109,-43,-87,111,69,79,124,-8,-17,-46,15,-48,61,-28,-72,108,-58,-55,83,53,-80,118,-88,43,-54,74,-38,-102,56,116,-125,-80,-75,-3,43,105,88,-66,-120,117,-58,82,-5,74,6,78,-79,-72,-51,85,-100,-49,123,-42,90,4,-33,-55,127,88,60,-115,-123,20,123,117,-75,9,122,-19,-98,-97,-15,90,92,-32,94,-86,68,41,93,106,-41,-60,-80,40,-91,24,-86,-39,-120,73,-27,125,65,-87,-123,-41,35,-9,113,91,-111,-40,2,5,83,34,-66,114,90,-111,57,126,62,-93,-117,5,-68,60,11,-105,-33,-35,51,-52,97,-45,83,117,-81,36,45,59,64,-43,-62,69,110,-95,88,102,107,-125,-97,43,-122,95,4,1,25,-51,-12,43,100,-22,98,-64,64,94,-74,45,-46,-38,102,-21,29,-37,-123,-104,-2,119,-40,115,15,-31,2,21,75,-115,82,-8,74,18,8,27,90,-80,88,10,-104,37,-1,-82,80,77,-97,-99,35,-105,40,110,24,-49,99,-94,20,43,40,-40,113,10,-71,43,-22,-63,77,64,-79,-3,-82,-44,23,-53,86,110,97,-124,-27,-106,104,-95,-96,-121,-14,25,74,54,72,120,107,-128,-60,-9,21,49,-12,-67,18,-30,-91,-33,77,40,33,38,-70,7,-89,-43,44,-12,-108,111,14,36,85,-15,112,-85,-48,-109,98,57,-17,100,85,-123,-111,-72,60,15,11,-124,90,-105,-107,7,-121,91,-98,-10,83,-116,54,-10,-128,64,38,59,64,-25,-17,36,101,-96,67,-108,-89,46,26,20,126,-71,0,-1,77,32,-31,-72,-29,44,-8,-14,-74,42,-21,-11,95,119,123,84,-128,30,20,27,-74,38,-122,-11,41,94,-33,-51,-115,45,7,74,80,35,-30,18,-101,-6,-92,95,-69,33,15,16,-59,-111,-67,3,-86,28,40,-43,68,27,-95,-111,-26,98,83,38,106,-126,86,-34,-54,-102,-88,-110,38,40,46,-37,81,11,-8,-122,-46,30,90,112,-40,95,-73,-61,77,-123,105,-44,32,-109,81,-110,-23,127,81,-83,-55,77,-44,62,-33,-70,4,-62,52,115,-36,32,-96,-123,86,-33,127,86,43,38,53,21,-125,106,-69,-16,-98,84,-80,-12,-25,17,-70,-72,-33,34,-115,-119,42,48,-34,6,-18,91,-19,22,46,0,-92,-27,-116,106,35,78,50,44,-110,-113,14,7,18,-123,-112,22,113,-91,-17,-51,88,-83,-19,-51,30,28,-64,109,-114,86,-33,73,30,-1,-58,-121,51,-109,104,86,89,119,-76,-28,-90,-95,69,-100,-55,-23,58,-14,-112,30,125,-77,72,-99,39,55,67,54,4,-6,52,50,-47,92,-26,6,3,76,96,89,126,97,80,-80,-76,-100,67,-119,58,-36,-13,16,53,53,5,123,31,106,33,-67,-27,111,48,7,23,-111,-110,-42,-105,-16,38,43,-17,51,-12,-98,-32,89,3,64,65,118,21,-66,-93,-1,-115,93,7,-75,-25,126,107,59,-19,-26,-107,14,75,45,-110,-16,-34,50,-11,2,-109,19,125,-61,-94,-63,-24,123,-11,54,121,-115,-16,-39,2,98,77,102,52,90,-110,-55,-119,109,-47,-121,119,116,65,68,6,6,22,103,49,-121,-117,119,-90,-38,124,-32,90,104,109,-16,-92,-100,61,-115,60,-107,-26,93,111,27,-124,54,-77,-72,123,-79,-89,89,-54,-94,59,108,-49,78,-4,-108,-28,-119,42,55,36,95,-7,123,-99,-42,-6,-100,91,-65,32,-24,-77,106,-5,59,-93,-100,35,115,70,-90,-6,-7,40,-20,76,105,-32,-74,-32,77,-91,114,-126,49,-83,-81,113,84,80,-69,-13,-99,-29,-103,-69,102,-108,-127,-43,87,-11,-126,119,-113,-104,-11,62,79,26,-90,7,-22,-64,-107,77,77,-83,24,52,-90,-57,10,114,-22,-38,115,-52,-37,-63,-76,94,-13,-56,-96,59,78,33,85,-97,-82,10,74,-113,-95,-78,99,50,-66,4,32,69,102,20,-76,-57,-69,-26,5,127,-105,94,-72,-117,-19,-7,-38,-91,24,59,86,9,91,-58,126,-126,-81,-39,28,124,35,101,74,-90,120,54,14,-108,-31,80,94,50,-40,-56,26,19,-5,-37,-39,-117,-45,9,37,83,53,-73,-22,-102,-107,-104,38,-125,-126,90,-106,-98,74,72,21,-56,-76,20,109,52,29,-45,-42,51,-51,-1,122,12,91,-18,-69,-3,55,51,-111,123,-106,11,-108,51,-93,96,-100,-87,91,-51,70,15,-39,-81,35,-54,62,-87,33,-125,-64,-111,14,-89,-109,70,-36,-122,65,-47,126,-119,126,-49,-34,126,46,-87,88,-107,-117,119,29,25,-65,-89,62,-88,-89,-117,103,9,100,-36,56,95,79,-124,66,-126,-5,-9,9,-95,-95,-93,54,-54,-2,81,-106,-25,21,108,105,-9,-37,-97,69,84,122,39,-124,59,98,-25,-67,35,18,48,-105,78,117,-75,-42,-76,3,-107,76,3,79,-81,-61,-99,30,-99,101,-94,-118,112,-88,-82,-19,103,-67,-71,76,-105,-24,-20,-91,83,90,-7,120,34,-26,75,-110,41,62,-77,-116,23,109,74,107,-78,94,26,-125,-13,27,99,49,77,-73,87,100,77,0,93,88,-23,-115,-108,-36,-24,123,-60,-65,-63,-44,19,0,102,-19,69,89,85,-96,-103,88,123,108,-68,119,-99,89,-56,11,116,-106,-68,97,6,-60,52,47,-1,-53,-55,94,-107,-3,-105,-9,-3,-21,-37,-69,18,-59,37,78,127,118,-117,107,-79,-43,124,-108,33,-121,52,-25,-71,76,-2,64,27,-52,88,68,14,25,57,-115,30,-36,63,-16,-75,92,-57,110,-105,-82,-72,-21,30,113,-20,-92,-15,-77,-25,-20,106,22,79,56,21,68,115,98,71,32,122,20,-70,112,62,38,105,48,115,15,47,-124,-71,48,-41,-85,-6,127,9,122,-68,110,-45,-35,-103,-21,122,30,42,-70,68,9,13,83,105,110,98,8,-42,93,-26,117,21,-42,27,-82,110,-123,-98,10,-5,22,-112,29,-32,109,7,31,-91,22,-56,71,60,29,4,-126,63,-64,74,-77,-53,92,-54,-7,-128,72,-92,-20,6,-89,52,-20,46,32,-119,-94,-90,-92,74,106,22,-50,-69,88,107,8,55,3,-102,-64,-106,28,74,13,97,96,110,-59,83,58,-95,-49,87,-106,71,9,125,-19,26,-26,-28,-93,-52,20,49,-63,-73,-11,14,112,121,-65,-128,88,4,72,-29,-117,-74,-33,102,21,125,112,-82,-49,-7,-28,46,82,-71,12,4,118,121,97,28,16,85,50,-24,78,76,74,-47,107,-67,63,-112,-94,93,-59,-32,-48,119,84,74,108,52,-113,-96,-17,27,122,23,-67,-10,33,-54,-63,49,57,-58,-103,54,20,-18,102,-78,-125,20,62,109,7,107,-20,31,-85,104,5,81,-61,51,98,125,-32,125,-90,-100,6,104,64,56,126,-86,24,109,23,15,-100,23,50,-83,22,30,-128,123,-82,-89,14,-82,-48,-36,-92,-12,-65,10,107,-124,-61,-36,-75,0,49,-105,26,101,119,120,-37,-89,-38,18,-55,-118,-47,-92,-17,-14,48,-50,-72,-100,112,-125,-106,126,-114,-23,-105,102,-41,-7,-5,-25,87,71,-111,-76,-11,-106,57,39,-84,-28,123,47,50,-23,-66,102,-101,-65,103,10,32,84,82,32,34,-112,-14,-109,-125,79,28,97,-18,38,56,-70,-36,-6,-78,33,-80,-120,104,27,68,41,93,125,-95,90,-18,-33,-97,-102,53,4,-79,-27,30,41,-51,-72,-74,-102,92,28,-56,122,114,-105,121,-51,8,63,-117,-56,126,-127,-126,84,49,30,-76,-45,-13,53,57,34,3,-85,49,41,-112,-71,127,22,-111,-114,-34,-45,38,44,97,4,52,-111,-35,-98,-24,-53,42,-118,74,-86,-19,-52,-119,-88,22,119,-89,71,112,26,-21,52,35,65,126,117,-110,47,4,-66,21,-8,-51,-72,-120,72,-107,85,3,72,73,-27,-36,19,-114,71,-89,-111,-100,116,-97,-53,87,-68,-121,-29,17,-60,-28,-64,116,11,45,-125,-83,-55,71,4,-3,-123,53,-122,42,-45,104,101,-22,81,-24,49,-37,91,-2,44,-77,-72,-64,-80,-100,-75,-26,-102,108,19,-107,-23,-51,-11,-4,-18,118,-18,125,-84,90,41,8,30,-54,21,-91,-115,102,-99,-35,6,-35,24,102,26,-108,-8,39,-93,1,76,124,-9,28,114,-39,44,9,72,-72,67,-24,-41,-3,-92,-58,-31,-57,29,127,36,16,-87,-1,-124,-34,57,-23,118,-38,51,-19,121,15,-2,-44,8,-87,-82,-47,71,-14,16,-41,48,79,17,118,-83,-84,5,-62,-127,-20,28,-12,54,-95,115,-89,124,-18,-118,40,-125,-97,15,3,89,-21,-19,45,23,-58,39,-1,19,-18,127,-121,-46,2,-24,38,-64,-48,19,81,-16,80,-37,-128,123,-43,36,-73,-127,55,-62,121,14,93,42,56,-117,-43,24,-99,-79,-46,-34,-112,-99,38,11,-19,23,-70,-121,-128,-81,-110,-76,88,-53,-51,-128,51,52,54,-58,-80,-35,83,20,10,27,-109,112,119,38,-19,120,97,67,24,-65,51,84,37,-8,112,67,6,-127,-104,-50,118,58,-1,-97,-94,78,-103,10,30,-95,-94,-42,107,-67,-41,-39,63,-108,27,91,21,-23,-88,-118,-55,-1,-28,-9,16,-29,-37,-55,-80,78,-82,-112,62,48,46,-41,1,34,50,12,-53,46,123,1,37,71,108,3,41,-123,-94,-50,-16,8,-42,86,-39,51,-24,119,20,-55,22,115,-82,114,-86,-110,8,-15,-72,74,83,14,93,59,122,107,3,-17,93,41,51,-56,-125,-21,28,38,-59,69,71,-48,111,38,79,-29,-23,-17,0,-110,75,87,113,32,50,-113,4,-4,12,-20,-27,-61,-41,-117,-56,-99,-77,115,-87,-99,40,-95,-99,-31,26,-102,119,-53,2,4,29,-21,-86,94,112,-82,45,23,-65,-23,-85,-97,-17,100,75,-110,116,1,-109,29,-111,80,-90,74,93,3,95,-48,112,-106,-18,77,25,-29,-22,-117,72,94,9,113,95,-1,-104,-28,-124,12,97,66,-109,33,-94,91,-29,-88,-102,-76,77,21,-65,51,95,54,-16,78,-116,78,-79,-51,-107,-123,2,49,40,-124,-90,97,64,-3,-105,71,14,-114,112,3,124,-83,-105,94,-50,35,59,73,-63,120,-43,116,16,-91,-46,-117,-18,-108,-26,-84,84,75,123,-21,-97,-118,-119,34,72,-59,-108,-65,-104,21,70,-108,63,-35,-26,-63,-11,-55,53,-125,-81,-58,-115,-54,-16,59,7,-12,0,-67,126,81,-72,-118,-76,121,-13,5,27,80,-23,87,-125,-85,-14,-37,-6,-56,-79,-118,-19,-43,-45,72,71,-91,-49,31,-121,34,-90,89,-22,46,116,-62,-59,-4,49,12,23,-39,40,88,-54,12,120,34,26,42,-7,-18,-89,67,-37,123,61,74,-91,-36,-38,15,-104,113,46,0,54,28,100,-44,-75,25,-56,28,103,44,-92,34,-100,-113,28,-75,-16,-121,-7,38,58,-99,66,-20,-2,-122,-19,110,11,-58,45,-72,17,38,-45,6,41,64,-86,36,44,91,-45,17,-93,43,-73,-41,-70,52,121,-71,53,-90,14,115,110,29,36,-46,-75,92,97,102,-53,-88,-32,53,122,-39,20,55,-102,-101,117,82,-26,14,46,-120,-91,85,36,101,-108,-81,-26,-18,115,-50,-47,7,18,-125,-24,-46,33,-24,-108,-71,33,41,99,47,-66,-43,-25,117,10,53,-2,10,-14,126,-112,104,-74,-77,-57,24,-30,81,93,115,69,89,10,90,34,88,-116,-90,65,72,43,123,51,-85,55,8,-12,13,10,-90,-37,123,-4,109,40,105,112,99,64,-74,-83,104,44,-20,-16,54,25,-82,-54,64,-109,-37,-3,107,-17,124,14,60,-64,-47,-72,-84,40,-74,89,6,36,-98,-125,30,63,14,-70,109,-62,-38,112,127,-41,52,115,27,-56,-112,76,-107,-65,-118,26,-74,-53,-96,114,-120,78,24,77,48,60,29,49,-117,-15,-91,1,-26,58,-84,-9,-109,-115,-89,-21,82,104,36,116,-103,121,93,-50,-39,-103,37,52,-108,-28,49,-87,-115,-93,38,-37,-68,-28,14,-26,-41,19,107,-2,-107,-37,-49,11,17,-120,24,24,-110,-100,93,46,-84,-122,38,6,-53,-7,98,102,65,35,-8,-6,44,-99,86,-5,67,-4,-65,13,66,23,-111,24,19,7,9,-92,29,114,58,-43,-105,-61,-33,34,-57,-26,5,-11,77,48,0,-41,-49,22,-20,-44,-30,-99,10,45,47,-51,-29,20,-11,-61,104,99,-15,21,-67,44,-71,108,-83,-11,-104,57,39,-84,2,122,14,127,-110,5,-79,98,95,23,89,3,68,-87,94,-9,40,104,107,24,-97,26,-36,-111,-95,-100,31,-97,49,77,-69,112,-96,-111,-45,89,-9,127,114,85,-102,-5,16,-1,-53,31,-69,-53,113,-6,84,-6,-18,62,-44,-73,68,-15,-105,-36,127,12,-27,-28,-31,-42,51,-121,86,-19,-111,-86,-119,93,-74,67,32,51,73,35,-106,18,70,44,72,-82,50,-19,-45,98,-60,-84,-67,-84,-126,-5,38,-67,-2,-62,-54,-23,-110,113,-14,-89,52,28,-61,11,4,70,-100,-35,0,-46,-124,-11,49,118,39,-80,-70,-100,-120,-54,-69,102,59,39,16,-49,53,-50,-27,44,90,-115,69,-102,-113,65,20,-47,59,-115,127,-19,-54,-19,-27,-28,-94,39,65,-114,-115,75,-46,-85,75,-4,-67,127,27,-98,-42,1,-124,-43,22,-21,-27,-74,53,-45,-90,127,-83,-44,-86,-23,10,36,86,59,99,-126,108,-59,-99,-45,-16,91,-33,110,-120,106,-87,19,122,115,-86,85,67,-83,-4,-57,-111,4,-5,-58,-91,-2,95,11,-53,107,-68,-128,-68,-12,85,19,-36,-40,-56,10,-64,58,-12,-32,79,20,37,-65,-33,-9,88,123,114,94,31,67,-32,-2,86,-124,-116,-62,-100,41,-17,35,-81,67,-110,-85,83,45,-121,5,-120,-3,47,14,-65,-78,-114,-87,-9,-19,-21,-7,106,74,117,-40,78,-33,63,61,-70,26,56,-9,76,-121,14,-77,87,-125,69,-32,-101,50,30,104,-59,-117,43,80,-98,-11,-94,-23,-108,52,-38,97,24,-10,-41,125,-119,-19,-42,-56,25,65,7,-39,-102,-4,110,109,74,18,13,-126,96,95,-89,99,15,-3,106,6,72,35,82,-78,-15,73,116,61,-127,-83,54,98,-17,2,-7,88,-57,-37,-39,-102,-79,31,-6,111,-62,-24,103,69,74,113,-15,65,68,37,-65,123,94,117,-121,-32,-78,-5,120,59,104,60,68,5,-65,4,64,-85,-80,117,-101,61,46,-88,69,-123,-19,-57,-15,97,125,54,-23,84,-124,-27,114,-47,16,104,-100,44,-87,36,-27,81,-20,-73,-80,95,-64,-34,29,-77,66,-126,77,-120,105,-100,79,44,116,-18,-15,-27,-71,19,12,-80,-18,27,45,-92,116,-27,-14,14,-77,1,-40,-110,-26,-4,-120,-88,60,51,108,-101,-123,116,-83,111,1,-74,-69,87,11,124,2,93,-64,121,-45,62,-79,110,-37,-55,97,27,110,-79,-91,67,99,53,26,-74,43,98,9,-43,-103,80,-23,60,68,-36,-112,-64,-31,20,-52,-79,-7,-113,94,-30,-100,73,55,-111,-1,87,-29,-25,-94,42,-13,-63,-59,108,38,-16,-62,-85,-17,0,-90,47,116,-80,12,-11,-54,96,-12,-110,-6,-128,-64,-31,-109,103,58,-11,-118,-3,0,-102,64,39,-18,-67,93,95,102,-87,104,88,-62,-31,-36,-61,-105,-26,46,-53,117,93,-70,-54,-103,121,52,-24,82,-10,-124,-22,-122,29,84,-76,121,-64,-65,-6,80,52,-27,7,108,-118,64,-82,-44,73,81,-107,84,-88,-100,-59,-56,9,35,-39,-82,-68,26,65,-66,-73,-15,75,-31,-44,51,-65,-73,-62,100,51,78,-51,-112,-84,82,-19,93,-92,-69,53,-38,-66,127,5,-30,61,26,43,48,-63,24,31,-71,-67,-127,-60,-55,-26,38,-43,-63,-49,-37,-101,116,105,-109,10,3,-67,17,-42,-89,110,62,-103,-41,78,-47,-59,-47,-17,-51,10,-16,-31,68,-41,37,15,-123,94,101,77,116,-122,61,-96,-122,-8,-11,105,-74,109,-97,-111,114,44,105,45,42,-94,-99,-52,122,-113,87,-59,-109,85,-128,120,-49,21,-75,-89,-10,11,120,-51,-19,30,-79,-26,64,-32,-71,28,-11,-44,55,-28,109,59,-84,-22,-55,-113,-105,114,80,50,-26,77,54,36,42,-71,-64,-111,118,99,-121,-100,-128,56,-75,-10,-74,30,36,93,-122,16,-50,-105,85,19,-84,-99,-72,-20,96,-63,75,-53,59,-86,90,-23,-39,-73,96,-118,-127,-9,-106,42,-84,-122,108,-18,81,29,-58,46,94,12,-2,-94,-75,33,85,61,-100,122,2,101,106,45,-49,-43,-63,22,-128,94,5,-115,38,35,54,-8,15,35,87,-114,-76,110,37,-50,20,-114,84,115,-13,48,54,14,-58,-93,112,43,77,9,32,-99,-91,-55,34,-82,23,-40,17,62,66,84,82,-3,117,-100,33,32,19,-100,102,93,101,-33,-103,112,-38,114,38,-1,-89,-90,-86,-9,-101,-66,41,-71,-113,5,21,-40,50,89,-73,123,5,45,-75,68,58,-107,-67,3,-64,89,45,-117,51,16,-119,36,69,-78,-18,94,-18,61,22,-124,97,-55,-97,112,19,119,7,65,-109,23,-15,88,-47,-103,-84,-62,106,-5,-108,73,-109,34,-116,33,81,-41,-102,81,67,20,67,-46,-40,-9,10,-49,121,-57,61,-33,28,42,-36,-67,-113,-38,-94,-89,-67,-28,-17,52,-116,-96,-51,117,29,-84,-53,-38,-53,-44,54,-110,98,-76,117,18,83,10,-62,-36,102,104,80,124,34,15,108,47,91,-112,-10,-116,66,-68,-123,55,-67,87,51,74,-47,25,-122,-34,57,32,96,-96,-64,67,-41,31,-124,-87,-15,76,-125,1,-77,13,99,47,-44,74,97,67,-4,108,-9,-16,44,36,-53,3,-120,105,99,-55,-34,-30,118,8,106,40,-95,-122,-65,14,-23,86,-26,-64,114,89,-59,97,-10,71,10,-108,-60,61,-87,-19,-4,-28,-1,-32,35,-123,55,109,-47,-126,-1,-124,-36,120,3,-107,-17,121,-80,31,25,79,-32,127,-19,103,-4,118,21,-55,70,125,-95,-104,-78,-2,-24,90,-33,97,-79,-92,20,126,49,60,121,41,56,120,113,-102,74,1,-28,44,46,-19,-46,100,-127,77,-64,-8,-12,-13,11,-15,89,22,-95,86,36,-105,110,84,-83,37,-40,-56,-92,19,-82,-17,-25,83,33,4,-111,76,-85,-54,35,-107,-72,127,76,89,-103,-123,28,-96,-47,95,77,107,-35,-98,52,59,-76,75,87,-14,-56,-27,75,117,-34,67,91,-92,-95,-45,-116,-13,-81,5,-35,83,10,85,-112,-38,117,89,43,123,-73,-43,104,36,-106,-80,47,113,-82,51,36,93,33,-84,11,-53,-128,-84,82,-86,-118,0,-33,-6,44,-122,35,81,-71,-44,-73,-64,126,98,-20,-49,-126,-104,46,44,-63,-17,-62,-74,-61,-48,-28,67,-25,-99,92,66,73,-38,49,45,-69,92,-26,-91,80,105,-30,48,-76,85,108,-98,-56,-95,102,47,6,-70,-118,-31,60,-112,-62,89,115,-78,-85,4,36,-1,72,-17,-100,-56,-2,-104,24,-54,-56,-92,-106,-60,-115,-53,-106,49,85,33,-79,54,-77,44,-120,47,41,-60,44,-8,-28,5,90,114,42,74,106,-57,-81,79,83,-67,-97,-90,-120,-16,-57,-88,34,9,7,-107,-59,-92,40,71,-32,113,-85,89,33,89,-58,-78,-50,-22,58,96,66,-19,-125,-39,-42,90,25,70,-104,-31,-90,-21,98,118,-111,102,-35,44,-117,60,86,-62,-47,-4,14,-88,46,79,6,-81,-5,101,99,-12,96,43,-27,42,65,-3,-120,-93,112,32,-6,-111,89,105,122,-67,50,57,-54,-126,-46,35,48,-41,0,-98,71,-22,45,-125,7,81,-26,23,-60,118,25,101,-95,-128,117,22,-126,-29,74,86,-39,-53,65,-86,64,-62,-77,-8,90,-85,54,-28,-128,124,-1,-112,127,105,-124,-40,63,123,123,-77,13,-84,-5,53,-31,-46,-74,-36,27,-16,13,-124,-98,-24,-115,-83,48,101,92,13,-98,-5,-111,-10,-40,-51,-115,-81,-52,-82,24,102,97,98,109,107,-46,-1,109,50,-48,40,-23,71,34,-70,-13,-111,110,43,-41,-9,108,-1,37,45,-72,-28,-45,-50,9,121,-66,-4,-86,-10,18,16,64,-119,-36,33,-13,5,-125,93,-6,19,-61,126,95,48,-116,11,125,-62,-6,67,-1,111,-54,2,45,82,-103,-4,-66,19,20,18,15,48,94,-91,119,33,82,-15,116,-24,15,67,30,111,-106,90,13,80,-20,71,65,66,108,124,-94,-104,-124,120,-95,59,-80,16,83,-101,90,14,-96,25,-64,-38,98,-24,-17,-69,-89,108,-29,-30,-101,-11,99,13,-56,53,72,52,105,105,88,2,26,75,23,-13,3,122,-114,71,-70,-29,-9,-98,58,67,-122,87,126,7,-30,111,-61,69,7,11,-6,103,-6,-16,-32,56,23,94,-31,29,-63,-47,5,67,61,110,43,57,54,41,28,74,-65,97,-22,74,-115,-126,86,0,-50,-83,-93,-3,116,5,22,-29,21,-79,34,-54,68,77,-34,-76,84,-116,-102,-31,-13,-55,64,85,-42,44,43,-115,85,100,-104,-60,103,-54,-65,120,-69,44,59,-102,107,81,89,-79,-44,121,70,-24,-110,51,76,75,117,-7,110,61,-102,42,-28,-28,-67,-12,-19,102,-27,18,115,121,-46,68,-124,-81,-110,-33,108,56,-83,30,-97,4,-79,-17,88,114,-86,105,17,-9,0,61,101,11,7,14,-100,58,-38,-42,27,121,119,-48,56,62,94,39,-20,-49,7,26,108,-99,-44,120,-2,87,-117,-78,-56,64,76,-83,26,-105,21,-3,81,8,-74,-100,67,50,9,58,-14,-118,-96,-13,27,65,-122,-73,-83,102,-40,-60,-120,-13,16,51,-51,112,-81,-15,-7,127,100,-116,-20,83,-72,59,-39,121,-43,114,55,97,-9,-53,107,56,45,49,106,-102,-126,-54,-44,59,18,-64,-75,101,62,-123,-110,-70,-17,24,57,-44,-122,104,-119,43,-40,18,-113,-107,25,122,-90,-19,123,74,-86,-35,107,102,-51,-22,56,-14,109,-100,-124,1,-85,35,-16,-124,-21,-65,1,30,-75,55,67,-121,-78,109,-102,82,-94,-23,-60,46,-104,0,-96,6,39,12,101,62,-39,37,-84,-92,3,48,68,34,-47,26,-67,60,-2,25,118,-110,77,91,46,2,43,103,-85,-107,-23,83,-23,-71,-110,-7,42,43,-82,16,57,-55,-102,-52,-32,32,-111,-70,75,116,116,-11,-44,-75,1,-14,-123,-128,-85,31,71,33,78,-72,-102,70,48,-72,-15,60,56,38,79,93,-83,114,75,-6,120,-78,25,-127,82,112,-37,-90,-92,-121,-112,-35,119,8,-32,-35,77,58,-9,109,-107,69,-21,11,-42,-128,-70,48,-23,-30,-78,-81,-123,30,-40,-8,-127,106,9,64,-78,-51,122,95,81,-109,-15,-43,118,27,-92,88,-109,37,-106,52,-62,-8,119,-45,73,65,127,-96,53,-115,-125,46,89,47,115,8,70,71,-40,-107,15,24,-119,-64,41,115,54,-11,-108,-103,-20,6,104,-67,-8,95,90,102,19,15,-22,73,13,-7,113,55,-53,-123,51,-110,40,37,-103,-83,-61,34,114,59,-25,-113,87,-103,-26,-10,88,-121,-65,-79,92,-63,123,-62,59,31,-87,-11,31,113,14,88,23,25,35,-49,-21,-83,-59,53,109,-72,-22,-64,89,59,-104,-42,24,52,-60,62,91,3,7,-21,61,15,-117,-109,65,-1,-39,25,-34,-37,26,-2,62,-51,61,24,50,-15,-32,-48,-55,25,36,24,6,99,94,-25,86,-84,-30,-95,-102,-94,-53,29,-81,65,69,-85,65,117,-7,0,-23,-66,-75,127,62,-108,10,-5,-4,66,29,-59,41,-82,-55,58,65,9,-128,55,-67,-58,-28,123,-121,99,-70,-99,11,-6,122,-108,119,-18,1,78,61,103,121,-104,117,-68,-22,-108,64,31,-68,-68,52,-96,41,58,-54,11,-26,118,75,14,-54,21,-119,60,-66,-19,-64,11,-5,76,-9,-97,81,-126,72,62,-115,64,23,117,65,73,-121,-87,-40,-48,-82,90,73,-91,42,57,-53,54,6,-11,102,-104,0,-117,70,52,103,-56,104,-1,-103,-12,32,59,123,12,-75,-104,16,-123,31,-35,55,20,-116,-109,-50,-44,-63,24,35,76,-116,-29,-32,16,-43,-68,-56,-115,32,109,-9,-34,126,-39,-74,74,-46,-19,-105,-82,-115,32,17,94,105,-103,-50,68,-121,-29,-7,53,74,77,-123,98,-68,37,62,-8,-21,-23,-99,4,-80,-103,-58,45,-2,-95,58,5,35,19,-37,-65,108,-14,-90,35,-53,-123,28,-5,39,-21,-38,17,70,-53,30,94,62,24,-74,34,14,101,46,20,-61,94,-121,125,-122,88,-127,36,-97,-98,110,80,80,14,72,10,8,95,4,50,113,27,-124,54,-117,-48,122,-39,52,8,94,61,40,-69,21,-34,7,-56,-90,-123,24,23,57,89,-87,-97,-80,-16,63,-50,76,-118,-25,-17,90,24,-4,-112,32,-94,58,-32,-12,11,28,48,-38,118,-69,107,92,61,-104,116,-62,-112,55,-110,0,127,-46,-54,-57,17,116,54,-36,-90,114,-39,-32,53,33,-69,37,72,-70,121,60,-84,22,-95,-74,-105,-7,-67,-41,-49,55,98,-57,60,-51,-107,31,48,48,-72,-38,-35,-5,29,65,-102,78,79,-8,71,-113,122,90,76,-55,-31,77,102,-66,107,-128,112,101,122,-62,-83,111,126,101,-75,-55,-118,68,52,-128,115,76,63,32,-6,90,6,100,-109,-59,98,19,109,-1,114,84,-58,-52,79,95,121,114,-77,-52,56,-114,-13,67,91,-51,50,-94,-115,113,-58,-33,56,55,-92,-120,80,-85,-125,126,-114,44,-126,22,-29,113,-82,-92,91,63,-39,-34,-90,-21,43,-3,113,-5,-81,-91,69,120,-59,-126,127,66,43,113,-111,47,-99,-46,-73,55,-13,-7,73,110,37,-76,68,13,105,94,-36,108,10,-127,-76,10,126,100,21,-117,-80,21,-95,94,-79,77,-72,-63,98,24,93,-124,7,25,-15,84,-62,-99,28,-82,-99,113,-65,13,62,-51,-117,37,115,-125,-40,-96,85,70,31,-27,26,2,57,-15,43,-112,-36,-72,-5,106,44,126,-97,111,-31,-66,-89,76,-114,51,-111,120,69,56,-106,-70,1,105,-54,-56,-8,-123,-92,-71,40,-20,-52,-93,-102,76,-104,48,77,76,-30,53,-113,40,-16,88,44,34,-107,53,18,95,-21,123,-115,-28,53,21,47,76,82,-58,-114,22,-104,-97,-90,73,109,7,-108,-96,-30,89,-84,-46,-47,-62,110,-128,25,-54,-75,55,-62,121,42,69,-62,54,25,7,-75,122,87,-68,88,-83,-95,38,-100,-103,-96,-57,74,109,-34,72,51,86,89,66,120,85,18,-84,95,101,-86,-32,15,48,-104,62,-99,115,43,-14,76,76,-92,-5,27,-8,41,-114,-74,50,-77,-67,-97,-109,16,106,-36,-52,85,16,50,-68,-27,-22,-99,-112,122,63,-15,64,23,23,121,54,-31,64,126,76,16,-57,18,-75,97,-23,-94,-94,72,-53,-40,30,-55,-63,87,-13,116,9,-64,-72,11,-90,-45,11,59,44,110,28,-105,-80,62,-27,20,46,-7,45,57,5,35,126,29,77,-91,-65,-60,10,-56,-115,-42,-17,115,-67,34,56,12,39,-119,-66,-20,22,-39,-102,54,108,1,-75,107,14,-104,-87,-127,-17,-88,33,103,-71,-85,23,-76,-95,-94,107,-102,92,-96,121,61,-98,78,-28,-33,33,75,32,-10,-14,-125,-96,-72,-4,10,7,-65,-52,-27,-71,92,100,61,45,87,9,-43,-52,110,-70,19,-110,45,-66,-74,-126,91,-27,106,58,-110,114,-86,-77,-52,-63,-50,67,-65,-54,33,37,116,64,49,76,-7,-115,22,-105,-124,50,19,81,-126,86,124,-5,-37,-48,19,-65,32,-21,80,-124,-93,-23,-25,16,24,97,65,29,51,56,-79,80,-117,-50,14,-23,-77,87,96,125,-52,49,2,13,55,61,107,93,-106,-116,102,-11,-37,-23,-119,-43,53,-39,-86,0,-96,19,13,15,15,112,24,76,-73,79,-76,-127,99,90,-18,63,119,3,-29,38,111,34,-66,111,-34,31,-29,-95,24,-70,5,-15,65,86,-43,16,76,-127,-120,21,6,-29,97,53,-31,-57,-39,-117,83,-48,-99,38,126,56,-78,-18,67,43,72,100,-96,-37,109,89,-92,94,-88,121,36,112,-33,-42,-69,-99,112,116,-80,-42,49,5,20,124,26,-32,26,-118,-28,65,22,13,-105,-98,81,124,40,52,-76,-104,97,82,59,96,-99,-27,-46,-74,-125,64,-36,-31,114,-28,-83,-61,81,-81,8,-49,42,36,48,-81,12,68,-80,83,38,-46,-115,93,-86,-56,62,-52,-36,-88,7,-85,-80,5,38,-106,-8,-94,-125,-81,123,21,122,-112,45,116,-37,81,48,-122,93,32,-120,48,-28,-85,-99,50,-47,-67,-109,78,-14,-79,10,-98,56,41,-22,-20,10,74,94,-30,-120,110,50,74,86,91,51,-86,43,-44,11,-11,65,127,-97,-24,-31,119,-16,-73,-66,87,-95,109,-64,98,-127,45,-30,24,-11,61,54,76,109,24,126,45,-1,-24,64,-28,28,-113,114,-32,-103,-125,122,95,102,-33,-7,-25,-28,-101,-7,63,109,111,-9,-45,73,-111,-41,-48,-70,-40,-113,28,-32,-41,-95,76,33,-112,-53,-106,75,117,71,-94,81,19,19,53,96,-9,125,-82,40,6,85,65,36,68,-91,59,9,65,91,-67,-34,121,65,125,-25,-38,-107,-106,-122,-83,20,109,45,122,-103,-31,-42,84,-42,23,-57,-69,49,27,41,-116,78,3,-65,-28,59,-52,-101,-29,-91,-29,37,86,113,119,-51,-104,-19,-84,42,-113,90,125,-32,65,37,-21,119,11,126,-13,-37,-49,59,-80,60,-114,90,7,-117,-22,-84,-50,4,69,58,-93,106,110,-77,-46,125,93,78,-124,-20,73,-42,75,-60,-52,-59,80,-5,-105,6,-14,-58,-72,-59,34,59,-96,-46,-102,76,-8,105,-49,-79,-47,-81,-94,93,77,-100,-119,-115,-115,-102,-68,69,107,-126,-86,-103,83,91,-26,-42,-84,73,-54,5,-104,-85,-61,-28,100,22,-71,-126,97,-43,-128,38,41,88,112,94,39,-84,-55,-119,-115,36,60,107,1,87,-45,-114,-80,-9,88,-105,-91,-67,90,-111,95,-96,-113,-103,-70,-24,91,-113,-122,-70,-83,-92,121,-20,117,37,-10,-105,126,82,89,81,-2,-118,-21,36,-9,-85,-103,124,65,-6,-45,118,-33,-5,122,-113,124,87,-30,58,-47,-43,-10,54,-116,88,44,-17,29,94,-59,-106,41,54,101,-86,98,-116,-12,106,-12,95,-29,13,-103,72,-73,55,6,122,124,-106,79,54,17,-93,7,-101,-72,69,-102,-43,71,31,-44,92,28,37,-104,127,-7,54,-50,-74,-35,-125,-16,-119,-17,28,-44,122,117,63,92,-23,14,82,-28,122,-90,-38,26,88,22,-74,127,115,-128,111,61,-41,-9,-104,31,112,29,37,53,-3,52,58,-27,66,-73,-76,27,78,-33,92,-125,39,95,110,-96,-61,-16,-125,80,-107,44,101,63,114,-101,47,-47,124,-31,21,-99,-57,46,24,-24,18,-104,121,68,-113,-76,37,-71,102,59,-10,-124,112,121,123,91,78,-14,-17,32,-82,2,49,102,-47,-30,-83,-19,-3,-50,67,-42,41,-21,-92,-72,117,-74,-111,97,26,18,-26,-78,104,67,41,48,122,-19,108,105,64,-45,-111,-45,43,-66,-80,115,84,-36,81,-31,59,28,60,-10,125,30,72,-64,105,45,52,-74,11,-16,38,-118,-3,98,-46,-77,40,-69,70,-114,-77,60,-70,123,83,-80,-102,42,100,81,109,-77,115,-127,7,-87,-22,8,-48,57,-72,-41,-41,-9,3,80,-54,-30,103,-16,-54,118,105,-87,-37,22,71,-33,-48,121,62,116,-90,66,-38,22,-105,19,-21,83,-41,112,-39,-81,-28,-109,31,-95,-125,-1,54,72,-84,-108,112,-114,89,120,-73,20,110,-55,-126,-58,-93,68,-105,65,-107,122,8,121,-103,-97,61,97,-74,99,-65,46,1,7,57,-122,69,100,-112,-94,94,116,23,106,85,-105,79,-128,-108,39,-111,-87,83,-66,112,24,-102,-7,-72,-97,-78,-8,99,-114,-113,79,115,89,-51,-88,83,28,-90,56,113,57,-102,40,-104,89,-76,-8,38,-67,-5,-9,-18,-121,38,27,-25,-29,-110,3,-10,16,123,-40,-93,116,-36,-20,-73,-18,-111,87,-123,113,120,-121,-97,69,-47,105,-68,-111,-97,-53,-94,-81,114,77,92,46,-37,-80,-18,108,-9,-69,-25,27,-46,-101,-86,53,54,-109,-44,-11,85,-61,-87,-17,34,-25,79,101,-46,-22,-30,99,85,-65,-30,12,117,-80,-23,54,-16,106,-89,-29,-120,64,1,-111,-94,-75,82,68,-3,120,11,-52,-103,87,22,-17,-46,-117,-63,112,12,-123,-52,71,-121,-122,-55,-125,101,-41,105,52,-53,-9,60,56,-3,-1,85,-112,15,127,70,4,-7,48,-72,34,-29,11,-103,114,-46,56,-109,17,-32,9,89,114,-1,92,86,-55,11,-87,-80,53,-18,-4,42,-90,86,15,-50,49,120,-46,22,67,57,-59,90,-97,110,96,119,43,100,-90,-54,-89,81,21,-80,-14,64,-47,126,-17,92,-37,51,40,121,-34,110,-99,-54,36,-73,85,-43,52,-30,-9,121,-18,-51,102,91,-116,-71,95,86,-55,95,-35,74,118,101,87,-114,20,-48,117,-60,-76,55,49,-108,74,-22,-43,20,41,79,-96,114,-12,-68,-44,43,126,-28,19,83,111,-128,102,-19,-110,56,71,-77,89,17,-16,-26,32,-27,-127,-14,-37,62,-34,-107,126,110,104,74,6,85,79,8,-74,107,30,126,-52,80,-11,29,108,65,-128,29,109,-2,123,59,28,-107,110,62,110,-123,-68,71,-39,-20,-57,-108,38,-36,126,-12,100,112,-103,-32,55,98,-5,-82,89,-41,88,36,-92,99,-56,118,97,12,113,-16,88,71,76,-96,-77,117,-5,60,-84,23,45,-41,31,46,33,0,-3,69,38,4,-119,-20,-115,96,-50,28,-9,-38,85,-113,-106,36,3,-96,-80,-23,7,-19,101,-111,92,-107,-9,116,53,-120,5,-3,-13,-87,1,-115,-35,-125,-89,-23,19,53,69,117,-67,-107,-33,-122,-32,-10,-69,-122,75,-116,-69,-35,43,-74,-107,109,18,107,-85,-48,52,-38,83,50,115,-101,-39,5,62,-7,-46,99,97,44,31,78,27,105,-117,-72,-94,-69,108,-86,-59,-30,49,-48,-22,-124,-2,-114,-19,-126,-29,-122,-21,67,15,60,-111,-55,35,-22,81,37,32,-75,0,56,-18,47,108,41,0,-120,122,-4,95,51,-68,-20,78,125,77,119,-9,-115,109,59,79,-128,-124,-114,9,7,91,-8,-80,11,-112,29,-32,-56,11,-50,-82,29,74,-19,-55,-6,12,-115,-6,18,15,-123,72,-15,-62,12,1,43,82,-30,-17,2,26,-30,-85,58,63,-56,-117,-100,52,-90,7,-69,-26,121,-92,111,5,-61,96,-90,63,-18,-11,60,-52,-81,99,125,25,67,-71,82,110,97,51,122,39,33,28,93,-116,123,-107,48,-64,-9,92,-31,-62,-68,-102,-103,-107,48,-100,-2,83,127,-82,41,-105,-7,-120,113,10,58,23,-122,84,-18,-37,20,-82,11,42,46,-95,16,-105,-58,-78,62,-82,-57,39,-18,106,0,52,-51,-59,36,76,98,124,-108,-67,-40,73,-3,19,45,-45,121,20,76,0,-21,-57,46,90,-18,79,66,-42,-56,-47,-39,-120,90,79,103,-104,34,-30,-67,120,94,35,59,25,-41,-128,125,88,88,68,-48,-25,-47,-10,-12,125,92,20,-99,55,66,118,-42,114,46,67,-9,43,37,119,-84,-8,79,-21,123,82,48,76,-63,-17,-23,27,-108,53,97,95,-109,41,68,-50,-32,-20,-119,-71,80,-57,-9,-16,-4,-36,17,66,19,82,-113,-76,39,23,-128,47,9,-87,30,-35,-48,100,96,15,-4,-58,-86,-10,-1,83,-52,17,-102,-88,37,-13,-2,-92,-23,-52,-89,-112,-33,-47,60,28,122,-101,-99,-67,92,-88,77,118,101,-96,-123,-108,-108,-43,102,45,44,-48,84,110,-25,-74,86,50,-7,-109,-9,-92,59,-67,79,29,23,53,-57,73,-89,9,1,81,65,17,31,-107,8,92,126,53,-119,52,98,60,-126,-82,15,79,-15,110,111,-82,22,88,-110,-113,-49,-124,-127,88,-51,-48,-87,-55,-17,62,45,64,41,-111,-95,-46,-122,-91,116,-125,-55,103,75,-29,95,-56,29,-115,-36,-41,-56,88,-100,-81,-33,-81,29,-11,-90,-17,77,-10,-127,-121,-6,30,-4,-24,30,-124,109,112,67,25,-57,4,34,79,126,126,-109,-47,-101,-38,-9,117,-76,37,-43,-120,-86,54,85,-70,56,39,-15,-40,-80,26,3,-64,-45,-35,-69,-120,70,-97,24,-29,-53,69,19,-113,-112,-53,-78,-106,-74,94,-61,78,-57,-58,97,46,58,62,-21,-121,-97,-38,-16,35,35,-120,-127,125,2,-30,54,-44,-17,9,30,-20,30,-53,117,52,29,-92,95,16,60,102,-29,54,-66,-110,122,10,-113,-78,68,-120,-71,-96,111,-37,9,39,-11,111,-52,-25,107,-77,-9,28,81,0,-55,-98,43,-97,-37,69,-123,-4,23,102,-98,106,-11,98,-42,5,115,-84,-121,-86,-78,11,-69,34,-115,3,-94,-104,-9,-38,51,-113,29,83,-39,86,54,-27,-116,-108,61,27,10,-44,65,-86,-91,34,-40,38,99,-14,101,-82,126,-56,-8,-102,37,-52,102,-36,126,74,95,-83,113,-37,-66,-55,-20,-98,-115,96,-49,-44,-123,-1,20,75,-2,-90,10,-61,107,94,87,-63,74,0,-55,2,41,-103,-123,-85,-13,-39,-107,36,-47,-21,6,-70,98,-119,78,52,26,-40,8,72,117,-78,115,76,-57,43,-60,-25,-87,36,83,54,127,127,-78,19,98,-30,125,86,121,124,62,-32,-96,-110,20,97,-126,-104,13,6,-122,-105,36,55,105,-121,-48,-83,0,-113,18,-114,-39,9,20,-20,-23,-115,-49,83,-107,121,70,-30,86,31,-48,-23,125,-67,-114,48,-86,21,-90,83,-79,64,-107,-60,-91,54,69,-73,-77,88,99,-10,15,-29,57,-128,-47,-96,101,-50,112,120,-85,-16,-78,27,7,116,-128,18,-11,49,-19,41,-33,15,-35,-67,84,-15,-57,36,-73,41,15,77,9,83,39,-54,27,-82,33,115,4,-60,101,46,-117,-56,-18,74,100,126,-27,-48,-25,10,-51,126,-41,-81,-95,-60,9,85,99,-6,80,-16,27,77,108,44,46,114,-26,20,-69,92,15,98,107,-114,-59,-87,28,-61,-121,84,125,-44,-125,-13,116,-55,-120,94,-84,-75,-86,34,1,-25,121,-80,26,-97,43,-12,31,75,-58,84,2,12,-109,-61,-68,-21,110,92,-27,-117,13,36,21,-3,107,-125,80,45,87,-108,22,41,-61,75,-115,-29,29,33,-111,-22,-4,-94,8,97,24,-124,25,25,-52,-7,-74,108,-36,-114,12,-32,3,84,75,-60,34,-88,-10,84,96,12,17,-119,114,-41,41,-3,-48,-16,1,-14,21,-115,-11,96,-25,-36,10,-14,-71,-3,-83,85,6,-91,-18,81,-108,36,-33,-59,70,-80,-81,11,-31,19,74,107,-22,91,8,29,57,-95,-80,-40,61,-82,-110,122,97,-114,-102,123,-77,83,122,-24,46,-121,-28,18,111,-47,-35,-120,-102,114,-93,115,22,-82,113,-78,77,76,-66,117,65,28,86,27,82,79,-128,-88,119,63,-31,87,11,124,-10,-99,-71,94,-89,76,-82,-124,101,58,-53,-74,9,-114,-50,31,-3,-51,-119,57,-29,-75,92,113,-47,40,-103,-81,-43,-12,-100,-102,4,-36,12,-26,-70,-118,27,-88,50,28,-73,-113,-94,-1,122,4,-57,-126,124,100,70,62,-87,7,-91,100,-91,-102,-56,34,102,118,44,-47,-90,24,-32,-99,30,-98,36,-124,113,11,-126,-15,-84,72,117,-46,3,-18,97,-38,-73,24,-47,109,-4,-50,-86,88,-112,-97,-65,112,-73,72,-37,20,-125,-29,-43,51,-2,-16,94,119,58,-101,-48,-116,121,94,103,64,52,48,51,-113,-70,106,41,-44,82,111,-106,71,-62,-105,-66,-78,78,71,115,-123,-50,4,33,22,88,-40,-111,-82,-46,-34,-67,120,-58,-28,-18,-126,-52,-31,-109,84,11,-94,10,94,-15,-89,-106,-62,125,-6,98,-39,62,-11,-34,12,12,-18,-50,-60,-78,43,104,36,50,-62,-58,-14,-36,-104,-88,21,78,-18,43,-124,-118,-68,-35,52,-62,102,18,25,87,-106,-78,74,29,127,98,-99,-2,-86,37,6,80,-31,86,77,112,-51,121,70,-126,7,35,-85,3,-24,-78,-109,114,-25,-58,-127,120,-78,26,8,-100,-116,10,-23,-20,14,-18,42,120,-75,79,60,44,-58,102,-104,69,25,119,28,103,-70,22,25,26,124,3,-11,-15,10,87,120,-23,-68,-44,7,93,9,-8,125,-15,-79,-70,108,15,-66,-90,-82,-5,-14,115,-122,-75,74,127,-100,108,4,58,66,-106,-117,1,6,11,-69,-96,55,-65,-8,102,-72,-41,75,76,-2,16,-10,78,-42,59,-72,-1,-31,-100,113,26,-66,48,-4,103,57,71,-94,-2,14,-28,-36,22,-8,-25,39,-51,25,99,91,70,63,11,-124,69,46,-34,-21,99,-70,-110,-90,32,116,34,-74,82,43,-104,-56,31,-117,-43,67,12,-72,115,-84,-62,-9,21,-30,105,82,94,86,12,40,-47,-39,40,-114,-67,-89,-72,-64,-62,-124,-105,32,95,-124,-41,-14,48,26,8,-116,-57,24,-45,-45,-75,-40,-111,-118,107,116,66,-97,-57,-79,-96,-85,-55,49,-55,-32,-87,-76,-12,42,-85,85,-16,75,-41,-112,49,-29,-28,-124,-10,-60,62,-2,-112,15,-36,-33,81,-95,117,120,51,99,-64,30,11,106,-21,-42,43,-59,51,117,12,45,3,-116,110,88,104,60,67,102,-74,108,80,-58,-108,28,38,-108,16,63,100,-24,-36,-1,70,97,7,32,118,-112,-122,-31,-36,106,10,115,-89,35,58,-15,-5,63,19,-123,-99,-11,-94,108,-18,-13,70,-12,-1,126,-15,-9,-25,113,111,66,-59,81,-88,-114,97,-121,-76,16,8,72,62,3,-107,106,-43,92,-91,63,60,-90,-61,96,-9,93,-24,-17,-22,38,-24,29,-27,-36,-25,117,99,-10,76,66,-77,-71,33,-87,100,48,-13,-122,-49,56,-104,72,72,-84,103,72,115,-10,45,19,-22,52,-97,-77,-107,50,-81,-93,-79,102,-71,46,73,6,-21,-52,5,-96,32,112,15,-44,-4,110,5,-26,-85,89,-87,35,73,-17,59,-95,-5,-123,94,127,-83,9,-122,-64,-58,-72,-111,33,-91,-82,56,63,1,6,-67,-106,-55,26,-12,-105,-32,115,-38,-95,118,117,67,-17,95,99,120,-75,2,28,-113,-105,117,-15,111,22,-46,116,25,-91,40,44,84,37,-4,-66,-125,15,69,-14,49,-12,-11,87,-68,20,91,110,117,125,-65,-34,-36,84,-29,-87,-27,60,-66,-118,-125,49,69,81,54,7,-119,53,-23,-60,-9,22,-116,-125,-58} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/ref_functions.h b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/ref_functions.h new file mode 100644 index 0000000..5a25ffa --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/Ref_Implementations/ref_functions.h @@ -0,0 +1,250 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef _REF_FUNCTIONS_H_ +#define _REF_FUNCTIONS_H_ + +#include "arm_math.h" +#include "arm_nnfunctions.h" +//#include "arm_nnsupportfunctions.h" +#include "fully_connected_testing_weights.h" + +#ifdef __cplusplus +extern "C" +{ +#endif + +/* + * + * Convolution reference implemenation + * + */ + + void arm_convolve_HWC_q7_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimention + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel, // filter kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const q7_t * bias, // bias + const uint16_t bias_shift, const uint16_t out_shift, q7_t * Im_out, // output image + const uint16_t dim_im_out, // output image dimension + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ); + + void arm_convolve_HWC_q7_ref_nonsquare(const q7_t * Im_in, // input image + const uint16_t dim_im_in_x, // input image dimention x + const uint16_t dim_im_in_y, // input image dimention y + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel_x, // filter kernel size x + const uint16_t dim_kernel_y, // filter kernel size y + const uint16_t padding_x, // padding sizes x + const uint16_t padding_y, // padding sizes y + const uint16_t stride_x, // stride x + const uint16_t stride_y, // stride y + const q7_t * bias, // bias + const uint16_t bias_shift, const uint16_t out_shift, q7_t * Im_out, // output image + const uint16_t dim_im_out_x, // output image dimension x + const uint16_t dim_im_out_y, // output image dimension y + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ); + + void arm_convolve_HWC_q15_ref(const q15_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimention + const uint16_t ch_im_in, // number of input image channels + const q15_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel, // filter kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const q15_t * bias, // bias + const uint16_t bias_shift, const uint16_t out_shift, q15_t * Im_out, // output image + const uint16_t dim_im_out, // output image dimension + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ); + void arm_convolve_HWC_q15_nonsquare_ref(const q15_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB); + + void arm_depthwise_separable_conv_HWC_q7_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimention + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel, // filter kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const q7_t * bias, // bias + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + q7_t * Im_out, // output image + const uint16_t dim_im_out, // output image dimension + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ); + void arm_depthwise_separable_conv_HWC_q7_ref_nonsquare(const q7_t * Im_in, // input image + const uint16_t dim_im_in_x, // input image dimention x + const uint16_t dim_im_in_y, // input image dimention y + const uint16_t ch_im_in, // number of input image channels + const q7_t * wt, // kernel weights + const uint16_t ch_im_out, // number of filters, i.e., output image channels + const uint16_t dim_kernel_x, // filter kernel size x + const uint16_t dim_kernel_y, // filter kernel size y + const uint16_t padding_x, // padding sizes x + const uint16_t padding_y, // padding sizes y + const uint16_t stride_x, // stride x + const uint16_t stride_y, // stride y + const q7_t * bias, // bias + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + q7_t * Im_out, // output image + const uint16_t dim_im_out_x, // output image dimension x + const uint16_t dim_im_out_y, // output image dimension y + q15_t * bufferA, //buffer space for input + q7_t * bufferB //buffer space for output + ); + +/* + * + * Fully-connected reference implemenation + * + */ + + void arm_fully_connected_q7_ref(const q7_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q7_t * pOut, // output operand + q15_t * vec_buffer); + + void arm_fully_connected_q15_ref(const q15_t * pV, // pointer to vector + const q15_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q15_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer); + + void arm_fully_connected_mat_q7_vec_q15_ref(const q15_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer); + + void arm_fully_connected_q7_opt_ref(const q7_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q7_t * pOut, // output operand + q15_t * vec_buffer); + + void arm_fully_connected_q15_opt_ref(const q15_t * pV, // pointer to vector + const q15_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q15_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer); + + void arm_fully_connected_mat_q7_vec_q15_opt_ref(const q15_t * pV, // pointer to vector + const q7_t * pM, // pointer to matrix + const uint16_t dim_vec, // length of the vector + const uint16_t num_of_rows, // numCol of A + const uint16_t bias_shift, // amount of left-shift for bias + const uint16_t out_shift, // amount of right-shift for output + const q7_t * bias, q15_t * pOut, // output operand + q15_t * vec_buffer); + +/* + * + * Pooling reference implemenation + * + */ + + void arm_avepool_q7_HWC_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimension + const uint16_t ch_im_in, // number of input image channels + const uint16_t dim_kernel, // window kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const uint16_t dim_im_out, // output image dimension + q7_t * bufferA, // a buffer for local storage + q7_t * Im_out); + + void arm_maxpool_q7_HWC_ref(const q7_t * Im_in, // input image + const uint16_t dim_im_in, // input image dimension + const uint16_t ch_im_in, // number of input image channels + const uint16_t dim_kernel, // window kernel size + const uint16_t padding, // padding sizes + const uint16_t stride, // stride + const uint16_t dim_im_out, // output image dimension + q7_t * bufferA, // a buffer for local storage + q7_t * Im_out); + +/* + * + * Other reference implemenation + * + */ + + void arm_relu_q7_ref(q7_t * data, uint16_t size); + + void arm_relu_q15_ref(q15_t * data, uint16_t size); + + void arm_nn_mult_q7_ref(q7_t * pSrcA, q7_t * pSrcB, q7_t * pDst, const uint16_t out_shift, uint32_t blockSize); + + void arm_nn_mult_q15_ref(q15_t * pSrcA, q15_t * pSrcB, q15_t * pDst, const uint16_t out_shift, uint32_t blockSize); + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.cpp b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.cpp new file mode 100644 index 0000000..41088fe --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.cpp @@ -0,0 +1,801 @@ +/* ---------------------------------------------------------------------- +* Copyright (C) 2010-2018 Arm Limited. All rights reserved. +* +* +* Project: CMSIS NN Library +* Title: arm_nnexamples_nn_test.cpp +* +* Description: Example code for NN kernel testing. +* +* Target Processor: Cortex-M cores +* +* Redistribution and use in source and binary forms, with or without +* modification, are permitted provided that the following conditions +* are met: +* - Redistributions of source code must retain the above copyright +* notice, this list of conditions and the following disclaimer. +* - Redistributions in binary form must reproduce the above copyright +* notice, this list of conditions and the following disclaimer in +* the documentation and/or other materials provided with the +* distribution. +* - Neither the name of ARM LIMITED nor the names of its contributors +* may be used to endorse or promote products derived from this +* software without specific prior written permission. +* +* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS +* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE +* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, +* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, +* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN +* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +* POSSIBILITY OF SUCH DAMAGE. +* -------------------------------------------------------------------- */ + +#include "arm_nnexamples_nn_test.h" + +//#define TEST_SIGMOID +//#define TEST_TANH +#define TEST_POOL +#define TEST_RELU +#define TEST_IP +#define TEST_CONV +#define TEST_NONSQUARE +#define TEST_NNMULT + +int test_index = 0; +q7_t test_flags[50]; +bool test_pass; + +int main() +{ + printf("start tests\n"); + + srand(1); + + // common pointers for testing data + q7_t *test1; + q15_t *test2; + q7_t *test3; + q15_t *test4; + + for (test_index = 0; test_index<50; test_index++) { + test_flags[test_index] = -1; + } + test_index = 0; + +#ifdef TEST_NNMULT +#define NNMULT_DIM 128 + test1 = new q7_t[NNMULT_DIM*2]; + test2 = new q15_t[NNMULT_DIM*2]; + test3 = new q7_t[NNMULT_DIM*2]; + test4 = new q15_t[NNMULT_DIM*2]; + + q7_t * mult_out_q7 = test3; + q7_t * mult_ref_q7 = test3 + NNMULT_DIM; + q15_t * mult_out_q15 = test4; + q15_t * mult_ref_q15 = test4 + NNMULT_DIM; + + for (int i=0;i= 2 || pool_out_opt[i] - pool_out_ref[i] >= 2) + { + printf("Output mismatch at %d, expected %d, actual %d\n", i, pool_out_ref[i], pool_out_opt[i]); + if_ave_pool_match = false; + } + } + if (if_ave_pool_match == true) + { + printf("Outputs match.\n"); + } + + delete[]test1; + delete[]test2; + delete[]test3; + +#endif + +#ifdef TEST_RELU + +#define RELU_DIM 127 + + test1 = new q7_t[RELU_DIM]; + test2 = new q15_t[RELU_DIM]; + test3 = new q7_t[RELU_DIM]; + test4 = new q15_t[RELU_DIM]; + + for (int i = 0; i < RELU_DIM; i++) + { + test1[i] = (rand() % 256 - 128); + test2[i] = (rand() % 65536 - 32768); + test3[i] = test1[i]; + test4[i] = test2[i]; + } + + q7_t *relu_ref_data_q7 = test1; + q7_t *relu_opt_data_q7 = test3; + q15_t *relu_ref_data_q15 = test2; + q15_t *relu_opt_data_q15 = test4; + + printf("Start ref relu q7 implementation\n"); + + arm_relu_q7_ref(relu_ref_data_q7, RELU_DIM); + + printf("Start opt relu q7 implementation\n"); + + arm_relu_q7(relu_opt_data_q7, RELU_DIM); + + verify_results_q7(relu_ref_data_q7, relu_opt_data_q7, RELU_DIM); + + printf("Start ref relu q15 implementation\n"); + + arm_relu_q15_ref(relu_ref_data_q15, RELU_DIM); + + printf("Start opt relu q15 implementation\n"); + + arm_relu_q15(relu_opt_data_q15, RELU_DIM); + + verify_results_q15(relu_ref_data_q15, relu_opt_data_q15, RELU_DIM); + + delete[]test1; + delete[]test2; + delete[]test3; + delete[]test4; + +#endif + +#ifdef TEST_IP + +#define IP_ROW_DIM 127 +#define IP_COL_DIM 127 + + q7_t ip_weights[IP_ROW_DIM * IP_COL_DIM] = IP2_WEIGHT; + q7_t ip_q7_opt_weights[IP_ROW_DIM * IP_COL_DIM] = IP4_WEIGHT; + q7_t ip_q7_q15_opt_weights[IP_ROW_DIM * IP_COL_DIM] = IP4_q7_q15_WEIGHT; + q15_t ip_q15_weights[IP_ROW_DIM * IP_COL_DIM] = IP2_WEIGHT; + q15_t ip_q15_opt_weights[IP_ROW_DIM * IP_COL_DIM] = IP4_WEIGHT_Q15; + + test1 = new q7_t[IP_COL_DIM + IP_ROW_DIM]; + test2 = new q15_t[IP_COL_DIM]; + test3 = new q7_t[IP_ROW_DIM * 3]; + test4 = new q15_t[IP_COL_DIM + IP_ROW_DIM * 2]; + + for (int i = 0; i < IP_ROW_DIM + IP_COL_DIM; i++) + { + test1[i] = rand() % 256 - 100; + } + for (int i = 0; i < IP_ROW_DIM * 3; i++) + { + test3[i] = 0; + } + + q7_t *ip_bias_q7 = test1 + IP_COL_DIM; + + q7_t *ip_out_q7_ref = test3; + q7_t *ip_out_q7_opt = test3 + IP_ROW_DIM; + q7_t *ip_out_q7_opt_fast = test3 + 2 * IP_ROW_DIM; + q15_t *ip_out_q15_ref = test4 + IP_COL_DIM; + q15_t *ip_out_q15_opt = test4 + IP_COL_DIM + IP_ROW_DIM; + + initialize_results_q7(ip_out_q7_ref, ip_out_q7_opt, IP_ROW_DIM); + initialize_results_q7(ip_out_q7_ref, ip_out_q7_opt_fast, IP_ROW_DIM); + initialize_results_q7(ip_out_q7_ref, ip_out_q7_opt_fast, IP_ROW_DIM); + + printf("Start ref q7 implementation\n"); + + arm_fully_connected_q7_ref(test1, ip_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, ip_out_q7_ref, test2); + + printf("Start q7 implementation\n"); + + arm_fully_connected_q7(test1, ip_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, ip_out_q7_opt, test2); + + verify_results_q7(ip_out_q7_ref, ip_out_q7_opt, IP_ROW_DIM); + + printf("Start q7 ref opt implementation\n"); + + arm_fully_connected_q7_opt_ref(test1, ip_q7_opt_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, + ip_out_q7_opt_fast, test2); + + verify_results_q7(ip_out_q7_ref, ip_out_q7_opt_fast, IP_ROW_DIM); + + printf("Start q7 opt implementation\n"); + + arm_fully_connected_q7_opt(test1, ip_q7_opt_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, ip_out_q7_opt_fast, + test2); + + verify_results_q7(ip_out_q7_ref, ip_out_q7_opt_fast, IP_ROW_DIM); + + for (int i = 0; i < IP_ROW_DIM + IP_COL_DIM; i++) + { + test4[i] = (rand() % 65536 - 32768); + } + + initialize_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + printf("Start ref q15 implementation\n"); + + arm_fully_connected_q15_ref(test4, ip_q15_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, test2, ip_out_q15_ref, NULL); + + printf("Start q15 implementation\n"); + + arm_fully_connected_q15(test4, ip_q15_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, test2, ip_out_q15_opt, NULL); + + verify_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + printf("Start ref opt q15 implementation\n"); + + arm_fully_connected_q15_opt_ref(test4, ip_q15_opt_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, test2, ip_out_q15_opt, + NULL); + + verify_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + printf("Start opt q15 implementation\n"); + + arm_fully_connected_q15_opt(test4, ip_q15_opt_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, test2, ip_out_q15_opt, NULL); + + verify_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + initialize_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + printf("Start ref q7_q15 implementation\n"); + + arm_fully_connected_mat_q7_vec_q15_ref(test4, ip_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, ip_out_q15_ref, + test2); + + printf("Start q7_q15 implementation\n"); + + arm_fully_connected_mat_q7_vec_q15(test4, ip_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, ip_out_q15_opt, + test2); + + verify_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + printf("Start ref opt q7_q15 implementation\n"); + + arm_fully_connected_mat_q7_vec_q15_opt_ref(test4, ip_q7_q15_opt_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, + ip_out_q15_opt, test2); + + verify_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + printf("Start opt q7_q15 implementation\n"); + + arm_fully_connected_mat_q7_vec_q15_opt(test4, ip_q7_q15_opt_weights, IP_COL_DIM, IP_ROW_DIM, 1, 7, ip_bias_q7, + ip_out_q15_opt, test2); + + verify_results_q15(ip_out_q15_ref, ip_out_q15_opt, IP_ROW_DIM); + + delete[]test1; + delete[]test2; + delete[]test3; + delete[]test4; + +#endif + +#ifdef TEST_NONSQUARE + +/* Use RCONV to differential with square CONV */ + +#define RCONV_IM_DIM_X 10 +#define RCONV_IM_DIM_Y 8 +#define RCONV_IM_CH 4 +#define RCONV_KER_DIM_X 5 +#define RCONV_KER_DIM_Y 3 +#define RCONV_STRIDE_X 1 +#define RCONV_STRIDE_Y 1 +#define RCONV_PADDING_X 2 +#define RCONV_PADDING_Y 1 +#define RCONV_OUT_CH 4 +#define RCONV_OUT_DIM_X 10 +#define RCONV_OUT_DIM_Y 8 + + test1 = new q7_t[RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH * RCONV_OUT_CH + RCONV_OUT_CH]; + test2 = new q15_t[2 * RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH]; + test3 = + new q7_t[RCONV_IM_DIM_Y * RCONV_IM_DIM_X * RCONV_IM_CH + 2 * RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH]; + + for (int i = 0; i < RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH * RCONV_OUT_CH + RCONV_OUT_CH; i++) + { + test1[i] = rand() % 256 - 100; + } + + for (int i = 0; + i < RCONV_IM_DIM_Y * RCONV_IM_DIM_X * RCONV_IM_CH + 2 * RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH; i++) + { + test3[i] = rand() % 256 - 100; + } + + q7_t *rconv_weight_q7 = test1; + q7_t *rconv_bias_q7 = test1 + RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH * RCONV_OUT_CH; + + q15_t *rconv_buf = test2; + + q7_t *rconv_im_in_q7 = test3; + q7_t *rconv_im_out_ref_q7 = test3 + RCONV_IM_DIM_Y * RCONV_IM_DIM_X * RCONV_IM_CH; + q7_t *rconv_im_out_opt_q7 = + test3 + RCONV_IM_DIM_Y * RCONV_IM_DIM_X * RCONV_IM_CH + RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH; + + initialize_results_q7(rconv_im_out_ref_q7, rconv_im_out_opt_q7, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + printf("start conv q7 nonsquare ref implementation\n"); + arm_convolve_HWC_q7_ref_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q7, + RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, RCONV_PADDING_X, RCONV_PADDING_Y, + RCONV_STRIDE_X, RCONV_STRIDE_Y, rconv_bias_q7, 1, 7, rconv_im_out_ref_q7, + RCONV_OUT_DIM_X, RCONV_OUT_DIM_Y, rconv_buf, NULL); + + printf("start conv q7 nonsquare opt implementation\n"); + arm_convolve_HWC_q7_fast_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q7, + RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, RCONV_PADDING_X, RCONV_PADDING_Y, + RCONV_STRIDE_X, RCONV_STRIDE_Y, rconv_bias_q7, 1, 7, rconv_im_out_opt_q7, + RCONV_OUT_DIM_X, RCONV_OUT_DIM_Y, rconv_buf, NULL); + + verify_results_q7(rconv_im_out_ref_q7, rconv_im_out_opt_q7, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + initialize_results_q7(rconv_im_out_ref_q7, rconv_im_out_opt_q7, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + printf("start conv q7 nonsquare ref implementation\n"); + arm_convolve_HWC_q7_ref_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q7, + RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, RCONV_PADDING_X, RCONV_PADDING_Y, + RCONV_STRIDE_X, RCONV_STRIDE_Y, rconv_bias_q7, 1, 7, rconv_im_out_ref_q7, + RCONV_OUT_DIM_X, RCONV_OUT_DIM_Y, rconv_buf, NULL); + + printf("start conv q7 nonsquare basic implementation\n"); + arm_convolve_HWC_q7_basic_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q7, + RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, RCONV_PADDING_X, RCONV_PADDING_Y, + RCONV_STRIDE_X, RCONV_STRIDE_Y, rconv_bias_q7, 1, 7, rconv_im_out_opt_q7, + RCONV_OUT_DIM_X, RCONV_OUT_DIM_Y, rconv_buf, NULL); + + verify_results_q7(rconv_im_out_ref_q7, rconv_im_out_opt_q7, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + initialize_results_q7(rconv_im_out_ref_q7, rconv_im_out_opt_q7, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + printf("start 1x1 conv q7 nonsquare fast implementation\n"); + arm_convolve_HWC_q7_fast_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q7, + RCONV_OUT_CH, 1, 1, 0, 0, RCONV_STRIDE_X, + RCONV_STRIDE_Y, rconv_bias_q7, 1, 7, rconv_im_out_ref_q7, RCONV_OUT_DIM_X, + RCONV_OUT_DIM_Y, rconv_buf, NULL); + + printf("start 1x1 conv q7 nonsquare dedicated function implementation\n"); + arm_convolve_1x1_HWC_q7_fast_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q7, + RCONV_OUT_CH, 1, 1, 0, 0, RCONV_STRIDE_X, + RCONV_STRIDE_Y, rconv_bias_q7, 1, 7, rconv_im_out_opt_q7, RCONV_OUT_DIM_X, + RCONV_OUT_DIM_Y, rconv_buf, NULL); + + verify_results_q7(rconv_im_out_ref_q7, rconv_im_out_opt_q7, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + printf("start depthwise separable conv q7 nonsquare ref implementation\n"); + arm_depthwise_separable_conv_HWC_q7_ref_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, + rconv_weight_q7, RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, + RCONV_PADDING_X, RCONV_PADDING_Y, RCONV_STRIDE_X, RCONV_STRIDE_Y, + rconv_bias_q7, 1, 7, rconv_im_out_ref_q7, RCONV_OUT_DIM_X, + RCONV_OUT_DIM_Y, rconv_buf, NULL); + + printf("start depthwise separable conv q7 nonsquare opt implementation\n"); + arm_depthwise_separable_conv_HWC_q7_nonsquare(rconv_im_in_q7, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, + rconv_weight_q7, RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, + RCONV_PADDING_X, RCONV_PADDING_Y, RCONV_STRIDE_X, RCONV_STRIDE_Y, + rconv_bias_q7, 1, 7, rconv_im_out_opt_q7, RCONV_OUT_DIM_X, + RCONV_OUT_DIM_Y, rconv_buf, NULL); + + verify_results_q7(rconv_im_out_ref_q7, rconv_im_out_opt_q7, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + delete[]test1; + delete[]test2; + delete[]test3; + + test2 = new q15_t[RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH * RCONV_OUT_CH + RCONV_OUT_CH]; // weights + bias + test4 = new q15_t[2 * RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH //buffer + + RCONV_IM_DIM_Y * RCONV_IM_DIM_X * RCONV_IM_CH + 2 * RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH]; // i/o + + for (int i = 0; i < RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH * RCONV_OUT_CH + RCONV_OUT_CH; i++) + { + test2[i] = rand() % 256 - 100; + } + + for (int i = 0; + i < 2 * RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH + + RCONV_IM_DIM_Y * RCONV_IM_DIM_X * RCONV_IM_CH + 2 * RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH; + i++) + { + test4[i] = rand() % 256 - 100; + } + + q15_t *rconv_weight_q15 = test2; + q15_t *rconv_bias_q15 = test2 + RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH * RCONV_OUT_CH; + + rconv_buf = test4; + + q15_t *rconv_im_in_q15 = test4 + 2 * RCONV_KER_DIM_Y * RCONV_KER_DIM_X * RCONV_IM_CH; + q15_t *rconv_im_out_ref_q15 = rconv_im_in_q15 + RCONV_IM_DIM_Y * RCONV_IM_DIM_X * RCONV_IM_CH; + q15_t *rconv_im_out_opt_q15 = rconv_im_out_ref_q15 + RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH; + + initialize_results_q15(rconv_im_out_ref_q15, rconv_im_out_opt_q15, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + printf("start conv q15 nonsquare ref implementation\n"); + arm_convolve_HWC_q15_nonsquare_ref(rconv_im_in_q15, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q15, + RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, RCONV_PADDING_X, RCONV_PADDING_Y, + RCONV_STRIDE_X, RCONV_STRIDE_Y, rconv_bias_q15, 1, 7, rconv_im_out_ref_q15, + RCONV_OUT_DIM_X, RCONV_OUT_DIM_Y, rconv_buf, NULL); + + printf("start conv q5 nonsquare opt implementation\n"); + arm_convolve_HWC_q15_fast_nonsquare(rconv_im_in_q15, RCONV_IM_DIM_X, RCONV_IM_DIM_Y, RCONV_IM_CH, rconv_weight_q15, + RCONV_OUT_CH, RCONV_KER_DIM_X, RCONV_KER_DIM_Y, RCONV_PADDING_X, RCONV_PADDING_Y, + RCONV_STRIDE_X, RCONV_STRIDE_Y, rconv_bias_q15, 1, 7, rconv_im_out_opt_q15, + RCONV_OUT_DIM_X, RCONV_OUT_DIM_Y, rconv_buf, NULL); + + verify_results_q15(rconv_im_out_ref_q15, rconv_im_out_opt_q15, RCONV_OUT_DIM_Y * RCONV_OUT_DIM_X * RCONV_OUT_CH); + + delete [] test2; + delete [] test4; +#endif + +#ifdef TEST_CONV + +#define CONV_IM_DIM 16 +#define CONV_IM_CH 16 +#define CONV_KER_DIM 5 +#define CONV_OUT_CH 16 +#define CONV_OUT_DIM 16 + + test1 = new q7_t[CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH + CONV_OUT_CH]; + test2 = + new q15_t[CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH + + 2 * CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH + CONV_OUT_CH]; + test3 = new q7_t[CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH + 2 * CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH]; + test4 = new q15_t[CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH + 2 * CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH]; + + for (int i = 0; i < CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH + CONV_OUT_CH; i++) + { + test1[i] = rand() % 256 - 100; + } + + for (int i = 0; + i < + CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH + + 2 * CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH + CONV_OUT_CH; i++) + { + test2[i] = (rand() % 65536 - 32768); + } + + for (int i = 0; i < CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH + 2 * CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH; i++) + { + test3[i] = rand() % 256 - 100; + } + + for (int i = 0; i < CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH + 2 * CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH; i++) + { + test4[i] = (rand() % 65536 - 32768); + } + + q7_t *conv_weight_q7 = test1; + q7_t *conv_bias_q7 = test1 + CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH; + + q15_t *conv_weight_q15 = test2; + q15_t *conv_buf = test2 + CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH; + q15_t *conv_bias_q15 = + test2 + CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH + + 2 * CONV_KER_DIM * CONV_KER_DIM * CONV_IM_CH * CONV_OUT_CH; + + q7_t *conv_im_in_q7 = test3; + q7_t *conv_im_out_ref_q7 = test3 + CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH; + q7_t *conv_im_out_opt_q7 = + test3 + CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH + CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH; + + q15_t *conv_im_in_q15 = test4; + q15_t *conv_im_out_ref_q15 = test4 + CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH; + q15_t *conv_im_out_opt_q15 = + test4 + CONV_IM_DIM * CONV_IM_DIM * CONV_IM_CH + CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH; + + initialize_results_q7(conv_im_out_ref_q7, conv_im_out_opt_q7, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + printf("start q7 ref implementation\n"); + + arm_convolve_HWC_q7_ref(conv_im_in_q7, CONV_IM_DIM, CONV_IM_CH, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_ref_q7, + CONV_OUT_DIM, conv_buf, NULL); + + printf("start q7 basic implementation\n"); + + arm_convolve_HWC_q7_basic(conv_im_in_q7, CONV_IM_DIM, CONV_IM_CH, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_opt_q7, + CONV_OUT_DIM, conv_buf, NULL); + + verify_results_q7(conv_im_out_ref_q7, conv_im_out_opt_q7, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + printf("start q7 fast implementation\n"); + + arm_convolve_HWC_q7_fast(conv_im_in_q7, CONV_IM_DIM, CONV_IM_CH, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_opt_q7, + CONV_OUT_DIM, conv_buf, NULL); + + verify_results_q7(conv_im_out_ref_q7, conv_im_out_opt_q7, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + // testing with RGB + printf("start q7 ref implementation for RGB\n"); + + arm_convolve_HWC_q7_ref(conv_im_in_q7, CONV_IM_DIM, 3, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_ref_q7, + CONV_OUT_DIM, conv_buf, NULL); + + printf("start q7 basic implementation for RGB\n"); + + arm_convolve_HWC_q7_basic(conv_im_in_q7, CONV_IM_DIM, 3, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_opt_q7, + CONV_OUT_DIM, conv_buf, NULL); + + verify_results_q7(conv_im_out_ref_q7, conv_im_out_opt_q7, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + printf("start q7 RGB implementation for RGB\n"); + + arm_convolve_HWC_q7_RGB(conv_im_in_q7, CONV_IM_DIM, 3, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_opt_q7, + CONV_OUT_DIM, conv_buf, NULL); + + verify_results_q7(conv_im_out_ref_q7, conv_im_out_opt_q7, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + // testing q15 + initialize_results_q15(conv_im_out_ref_q15, conv_im_out_opt_q15, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + printf("start q15 ref implementation\n"); + + arm_convolve_HWC_q15_ref(conv_im_in_q15, CONV_IM_DIM, CONV_IM_CH, conv_weight_q15, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q15, 0, 15, conv_im_out_ref_q15, + CONV_OUT_DIM, conv_buf, NULL); + + printf("start q15 basic implementation\n"); + + arm_convolve_HWC_q15_basic(conv_im_in_q15, CONV_IM_DIM, CONV_IM_CH, conv_weight_q15, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q15, 0, 15, conv_im_out_opt_q15, + CONV_OUT_DIM, conv_buf, NULL); + + verify_results_q15(conv_im_out_ref_q15, conv_im_out_opt_q15, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + printf("start q15 fast implementation\n"); + + arm_convolve_HWC_q15_fast(conv_im_in_q15, CONV_IM_DIM, CONV_IM_CH, conv_weight_q15, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q15, 0, 15, conv_im_out_opt_q15, + CONV_OUT_DIM, conv_buf, NULL); + + verify_results_q15(conv_im_out_ref_q15, conv_im_out_opt_q15, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + // depthwise separable conv + initialize_results_q7(conv_im_out_ref_q7, conv_im_out_opt_q7, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + printf("start q7 depthwise_separable_conv ref implementation\n"); + + arm_depthwise_separable_conv_HWC_q7_ref(conv_im_in_q7, CONV_IM_DIM, CONV_IM_CH, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_ref_q7, + CONV_OUT_DIM, conv_buf, NULL); + + printf("start q7 depthwise_separable_conv implementation\n"); + + arm_depthwise_separable_conv_HWC_q7(conv_im_in_q7, CONV_IM_DIM, CONV_IM_CH, conv_weight_q7, + CONV_OUT_CH, CONV_KER_DIM, 2, 1, conv_bias_q7, 1, 7, conv_im_out_opt_q7, + CONV_OUT_DIM, conv_buf, NULL); + + verify_results_q7(conv_im_out_ref_q7, conv_im_out_opt_q7, CONV_OUT_DIM * CONV_OUT_DIM * CONV_OUT_CH); + + delete[]test1; + delete[]test2; + delete[]test3; + delete[]test4; + +#endif + + test_pass = true; + test_index = 0; + while (test_flags[test_index] != -1) { + if (test_flags[test_index]) { + test_pass = false; + } + test_index ++; + } + if (test_pass) { + printf("All tests passed\n"); + } else { + printf("Test failed passed\n"); + } + + return 0; +} diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.h b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.h new file mode 100644 index 0000000..2e33988 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/arm_nnexamples_nn_test.h @@ -0,0 +1,78 @@ +#ifndef _MAIN_H_ +#define _MAIN_H_ + +#include +#include +#include + +#include "arm_math.h" + +#include "arm_nnfunctions.h" +#include "ref_functions.h" + +extern int test_index; +extern q7_t test_flags[50]; + +void initialize_results_q7(q7_t * ref, q7_t * opt, int length) +{ + arm_fill_q7(0, ref, length); + arm_fill_q7(37, opt, length); +} + +void initialize_results_q15(q15_t * ref, q15_t * opt, int length) +{ + arm_fill_q15(0, ref, length); + arm_fill_q15(0x5F5, opt, length); +} + +void verify_results_q7(q7_t * ref, q7_t * opt, int length) +{ + + bool if_match = true; + + for (int i = 0; i < length; i++) + { + if (ref[i] != opt[i]) + { + printf("Output mismatch at %d, expected %d, actual %d\r\n", i, ref[i], opt[i]); + + if_match = false; + } + } + + if (if_match == true) + { + printf("Outputs match.\r\n\r\n"); + test_flags[test_index++] = 0; + } else { + test_flags[test_index++] = 1; + } + +} + +void verify_results_q15(q15_t * ref, q15_t * opt, int length) +{ + + bool if_match = true; + + for (int i = 0; i < length; i++) + { + if (ref[i] != opt[i]) + { + printf("Output mismatch at %d, expected %d, actual %d\r\n", i, ref[i], opt[i]); + + if_match = false; + } + } + + if (if_match == true) + { + printf("Outputs match.\r\n\r\n"); + test_flags[test_index++] = 0; + } else { + test_flags[test_index++] = 1; + } + +} + +#endif diff --git a/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/readme.txt b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/readme.txt new file mode 100644 index 0000000..0ea82e7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/NN_Lib_Tests/nn_test/readme.txt @@ -0,0 +1,4 @@ +CMSIS DSP_Lib example arm_nnexample_nn_test for + Cortex-M3, Cortex-M4 and Cortex-M7. + +The example is configured for uVision Simulator. diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q15.c b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q15.c new file mode 100644 index 0000000..fd447e5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q15.c @@ -0,0 +1,101 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nn_activations_q15.c + * Description: Q15 neural network activation function using direct table look-up + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_common_tables.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup Acti + * @{ + */ + + /** + * @brief Q15 neural network activation function using direct table look-up + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @param[in] int_width bit-width of the integer part, assume to be smaller than 3 + * @param[in] type type of activation functions + * @return none. + * + * @details + * + * This is the direct table look-up approach. + * + * Assume here the integer part of the fixed-point is <= 3. + * More than 3 just not making much sense, makes no difference with + * saturation followed by any of these activation functions. + */ + +void arm_nn_activations_direct_q15(q15_t * data, uint16_t size, uint16_t int_width, arm_nn_activation_type type) +{ + uint16_t i = size; + q15_t *pIn = data; + q15_t *pOut = data; + uint16_t shift_size = 8 + 3 - int_width; + uint32_t bit_mask = 0x7FF >> int_width; + uint32_t full_frac = bit_mask + 1; + const q15_t *lookup_table; + + switch (type) + { + case ARM_SIGMOID: + lookup_table = sigmoidTable_q15; + break; + case ARM_TANH: + default: + lookup_table = tanhTable_q15; + break; + } + + while (i) + { + q15_t out; + q15_t in = *pIn++; + q15_t frac = (uint32_t) in & bit_mask; + q15_t value = lookup_table[__USAT(in >> shift_size, 8)]; + q15_t value2 = lookup_table[__USAT(1 + (in >> shift_size), 8)]; + + /* doing the interpolation here for better accuracy */ + out = ((q31_t) (full_frac - frac) * value + (q31_t) value2 * frac) >> shift_size; + + *pOut++ = out; + i--; + } + +} + +/** + * @} end of Acti group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q7.c b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q7.c new file mode 100644 index 0000000..2953bd5 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_nn_activations_q7.c @@ -0,0 +1,91 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nn_activations_q7.c + * Description: Q7 neural network activation function using direct table look-up + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_common_tables.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup Acti + * @{ + */ + + /** + * @brief Q7 neural network activation function using direct table look-up + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @param[in] int_width bit-width of the integer part, assume to be smaller than 3 + * @param[in] type type of activation functions + * @return none. + * + * @details + * + * This is the direct table look-up approach. + * + * Assume here the integer part of the fixed-point is <= 3. + * More than 3 just not making much sense, makes no difference with + * saturation followed by any of these activation functions. + */ + +void arm_nn_activations_direct_q7(q7_t * data, uint16_t size, uint16_t int_width, arm_nn_activation_type type) +{ + uint16_t i = size; + q7_t *pIn = data; + q7_t *pOut = data; + q7_t in; + q7_t out; + uint16_t shift_size = 3 - int_width; + const q7_t *lookup_table; + switch (type) + { + case ARM_SIGMOID: + lookup_table = sigmoidTable_q7; + break; + case ARM_TANH: + default: + lookup_table = tanhTable_q7; + break; + } + while (i) + { + in = *pIn++; + out = lookup_table[(uint8_t) (in >> shift_size)]; + *pOut++ = out; + i--; + } +} + +/** + * @} end of Acti group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q15.c b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q15.c new file mode 100644 index 0000000..6a1b907 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q15.c @@ -0,0 +1,106 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_relu_q15.c + * Description: Q15 version of ReLU + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup Acti + * @{ + */ + + /** + * @brief Q15 RELU function + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @return none. + * + * @details + * + * Optimized relu with QSUB instructions. + * + */ + +void arm_relu_q15(q15_t * data, uint16_t size) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + uint16_t i = size >> 1; + q15_t *pIn = data; + q15_t *pOut = data; + q31_t in; + q31_t buf; + q31_t mask; + + while (i) + { + in = *__SIMD32(pIn)++; + + /* extract the first bit */ + buf = __ROR(in & 0x80008000, 15); + + /* if MSB=1, mask will be 0xFF, 0x0 otherwise */ + mask = __QSUB16(0x00000000, buf); + + *__SIMD32(pOut)++ = in & (~mask); + i--; + } + + if (size & 0x1) + { + if (*pIn < 0) + { + *pIn = 0; + } + pIn++; + } +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + uint16_t i; + + for (i = 0; i < size; i++) + { + if (data[i] < 0) + data[i] = 0; + } + +#endif /* ARM_MATH_DSP */ + +} + +/** + * @} end of Acti group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q7.c b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q7.c new file mode 100644 index 0000000..caa027b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ActivationFunctions/arm_relu_q7.c @@ -0,0 +1,110 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_relu_q7.c + * Description: Q7 version of ReLU + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup Acti + * @{ + */ + + /** + * @brief Q7 RELU function + * @param[in,out] data pointer to input + * @param[in] size number of elements + * @return none. + * + * @details + * + * Optimized relu with QSUB instructions. + * + */ + +void arm_relu_q7(q7_t * data, uint16_t size) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + uint16_t i = size >> 2; + q7_t *pIn = data; + q7_t *pOut = data; + q31_t in; + q31_t buf; + q31_t mask; + + while (i) + { + in = *__SIMD32(pIn)++; + + /* extract the first bit */ + buf = __ROR(in & 0x80808080, 7); + + /* if MSB=1, mask will be 0xFF, 0x0 otherwise */ + mask = __QSUB8(0x00000000, buf); + + *__SIMD32(pOut)++ = in & (~mask); + i--; + } + + i = size & 0x3; + while (i) + { + if (*pIn < 0) + { + *pIn = 0; + } + pIn++; + i--; + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + uint16_t i; + + for (i = 0; i < size; i++) + { + if (data[i] < 0) + data[i] = 0; + } + +#endif /* ARM_MATH_DSP */ + +} + +/** + * @} end of Acti group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_1x1_HWC_q7_fast_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_1x1_HWC_q7_fast_nonsquare.c new file mode 100644 index 0000000..4c69e7c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_1x1_HWC_q7_fast_nonsquare.c @@ -0,0 +1,235 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_1x1_HWC_q7_fast_nonsquare.c + * Description: Fast Q7 version of 1x1 convolution (non-square shape) + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + +/** + * @brief Fast Q7 version of 1x1 convolution (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is optimized for convolution with 1x1 kernel size (i.e., dim_kernel_x=1 + * and dim_kernel_y=1). It can be used for the second half of MobileNets [1] after depthwise + * separable convolution. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 4 + * ch_im_out is multiple of 2 + * + * [1] MobileNets: Efficient Convolutional Neural Networks for Mobile Vision Applications + * https://arxiv.org/abs/1704.04861 + */ + +arm_status arm_convolve_1x1_HWC_q7_fast_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_out_y, i_out_x; + int16_t i_ch_out; + + /* ----------------------- + * Here we use bufferA as q15_t internally as computation are done with q15_t level + * im2col are done to output in q15_t format from q7_t input + */ + + q15_t *pBuffer = bufferA; + q7_t *pOut = Im_out; + + if (ch_im_in % 4 != 0 || ch_im_out % 2 != 0 || dim_kernel_x != 1 || dim_kernel_y != 1 + || padding_x != 0 || padding_y != 0 || stride_x != 1 || stride_y != 1) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + for (i_out_y = 0; i_out_y < dim_im_out_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + /* This part implements the im2col function */ + arm_q7_to_q15_reordered_no_shift((q7_t *) Im_in + (i_out_y * dim_im_in_x + i_out_x) * ch_im_in, pBuffer, + ch_im_in); + pBuffer += ch_im_in; + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel_x * dim_kernel_y) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, bufferA, ch_im_out, ch_im_in, bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* check if there is left-over for compute */ + if (pBuffer != bufferA) + { + const q7_t *pA = wt; + for (i_ch_out = 0; i_ch_out < ch_im_out; i_ch_out++) + { + q31_t sum = ((q31_t)(bias[i_ch_out]) << bias_shift) + NN_ROUND(out_shift); + q15_t *pB = bufferA; + /* basically each time it process 4 entries */ + uint16_t colCnt = ch_im_in * dim_kernel_x * dim_kernel_y >> 2; + + while (colCnt) + { + + q31_t inA1, inA2; + q31_t inB1, inB2; + + pA = (const q7_t *)read_and_pad_reordered((void *)pA, &inA1, &inA2); + + inB1 = *__SIMD32(pB)++; + sum = __SMLAD(inA1, inB1, sum); + inB2 = *__SIMD32(pB)++; + sum = __SMLAD(inA2, inB2, sum); + + colCnt--; + } + colCnt = ch_im_in * dim_kernel_y * dim_kernel_x & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + sum += inA1 * inB1; + colCnt--; + } + *pOut = (q7_t) __SSAT((sum >> out_shift), 8); + pOut++; + + } + + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + int i, j, k, l, m, n; + int conv_out; + int in_row, in_col; + + if (ch_im_in % 4 != 0 || ch_im_out % 2 != 0 || dim_kernel_x != 1 || dim_kernel_y != 1 + || padding_x != 0 || padding_y != 0 || stride_x != 1 || stride_y != 1) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out_y; j++) + { + for (k = 0; k < dim_im_out_x; k++) + { + conv_out = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel_y; m++) + { + for (n = 0; n < dim_kernel_x; n++) + { + // if-for implementation + in_row = stride_y * j + m - padding_y; + in_col = stride_x * k + n - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + l] * + wt[i * ch_im_in * dim_kernel_y * dim_kernel_x + (m * dim_kernel_y + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out_x + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_basic.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_basic.c new file mode 100644 index 0000000..ee08d74 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_basic.c @@ -0,0 +1,207 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q15_basic.c + * Description: Q15 version of convolution + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + + /** + * @brief Basic Q15 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns ARM_MATH_SUCCESS + * + * @details + * + * Buffer size: + * + * bufferA size: ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * This basic version is designed to work for any input tensor and weight + * dimension. + */ + +arm_status +arm_convolve_HWC_q15_basic(const q15_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + uint16_t im2col_out_pixel_index = 0; + q15_t *pBuffer = bufferA; + q15_t *pOut = Im_out; + q15_t *im_buffer = bufferA; + const q15_t *pA; + int i; + + /* This part implements the im2col function */ + for (i_out_y = 0; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in || i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* Filling 0 for out-of-bound paddings */ + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + /* arm_copy_q15((q15_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); */ + memcpy(pBuffer, (q15_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, sizeof(q15_t)*ch_im_in); + } + pBuffer += ch_im_in; + } + } + + pA = wt; + for (i = 0; i < ch_im_out; i++) + { + q31_t sum = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + q15_t *pB = im_buffer; + uint16_t colCnt = ch_im_in * dim_kernel * dim_kernel >> 2; + while (colCnt) + { + q31_t inA1 = *__SIMD32(pA)++; + q31_t inB1 = *__SIMD32(pB)++; + q31_t inA2 = *__SIMD32(pA)++; + q31_t inB2 = *__SIMD32(pB)++; + + sum = __SMLAD(inA1, inB1, sum); + sum = __SMLAD(inA2, inB2, sum); + + colCnt--; + } + colCnt = ch_im_in * dim_kernel * dim_kernel & 0x3; + while (colCnt) + { + q15_t inA1 = *pA++; + q15_t inB1 = *pB++; + sum += inA1 * inB1; + colCnt--; + } + *pOut = (q15_t) __SSAT((sum >> out_shift), 16); + pOut++; + } + + /* counter reset */ + pBuffer = im_buffer; + im2col_out_pixel_index++; + } + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out; j++) + { + for (k = 0; k < dim_im_out; k++) + { + conv_out = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel; m++) + { + for (n = 0; n < dim_kernel; n++) + { + in_row = stride * j + m - padding; + in_col = stride * k + n - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in + in_col) * ch_im_in + + l] * wt[i * ch_im_in * dim_kernel * dim_kernel + (m * dim_kernel + + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out + k) * ch_im_out] = (q15_t) __SSAT((conv_out >> out_shift), 16); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast.c new file mode 100644 index 0000000..a02aaa0 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast.c @@ -0,0 +1,255 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q15_fast.c + * Description: Fast Q15 version of convolution + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + + /** + * @brief Fast Q15 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * + * Buffer size: + * + * bufferA size: 2*ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * Input dimension constraints: + * + * ch_im_in is multiple of 2 + * + * ch_im_out is multipe of 2 + * + */ + +arm_status +arm_convolve_HWC_q15_fast(const q15_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + q15_t *pBuffer = bufferA; + q15_t *im_buffer = bufferA; + q15_t *pOut = Im_out; + + if (ch_im_in % 2 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + /* This part implements the im2col function */ + for (i_out_y = 0; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in || i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + /* arm_copy_q15((q15_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); */ + memcpy(pBuffer, (q15_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, sizeof(q15_t)*ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (i_out_x & 0x1) + { + int i; + /* initialize the matrix pointers for A */ + const q15_t *pA = wt; + + /* set up the second output pointers */ + q15_t *pOut2 = pOut + ch_im_out; + + /* this loop over rows in A */ + for (i = 0; i < ch_im_out; i += 2) + { + /* setup pointers for B */ + q15_t *pB = im_buffer; + const q15_t *pB2 = pB + ch_im_in * dim_kernel * dim_kernel; + + /* aling the second pointer for A */ + const q15_t *pA2 = pA + ch_im_in * dim_kernel * dim_kernel; + + /* init the sum with bias */ + q31_t sum = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)bias[i + 1] << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)bias[i + 1] << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = ch_im_in * dim_kernel * dim_kernel >> 1; + /* accumulate over the vector */ + while (colCnt) + { + q31_t inA1 = *__SIMD32(pA)++; + q31_t inB1 = *__SIMD32(pB)++; + q31_t inA2 = *__SIMD32(pA2)++; + q31_t inB2 = *__SIMD32(pB2)++; + + sum = __SMLAD(inA1, inB1, sum); + sum2 = __SMLAD(inA1, inB2, sum2); + sum3 = __SMLAD(inA2, inB1, sum3); + sum4 = __SMLAD(inA2, inB2, sum4); + + colCnt--; + } /* while over colCnt */ + colCnt = ch_im_in * dim_kernel * dim_kernel & 0x1; + while (colCnt) + { + q15_t inA1 = *pA++; + q15_t inB1 = *pB++; + q15_t inA2 = *pA2++; + q15_t inB2 = *pB2++; + + sum += inA1 * inB1; + sum2 += inA1 * inB2; + sum3 += inA2 * inB1; + sum4 += inA2 * inB2; + colCnt--; + } /* while over colCnt */ + *pOut++ = (q15_t) __SSAT(sum >> out_shift, 16); + *pOut++ = (q15_t) __SSAT(sum3 >> out_shift, 16); + *pOut2++ = (q15_t) __SSAT(sum2 >> out_shift, 16); + *pOut2++ = (q15_t) __SSAT(sum4 >> out_shift, 16); + + /* skip the row computed with A2 */ + pA += ch_im_in * dim_kernel * dim_kernel; + } /* for over ch_im_out */ + + pOut += ch_im_out; + /* counter reset */ + pBuffer = im_buffer; + } + } + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + if (ch_im_in % 2 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out; j++) + { + for (k = 0; k < dim_im_out; k++) + { + conv_out = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel; m++) + { + for (n = 0; n < dim_kernel; n++) + { + in_row = stride * j + m - padding; + in_col = stride * k + n - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in + in_col) * ch_im_in + + l] * wt[i * ch_im_in * dim_kernel * dim_kernel + (m * dim_kernel + + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out + k) * ch_im_out] = (q15_t) __SSAT((conv_out >> out_shift), 16); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast_nonsquare.c new file mode 100644 index 0000000..14d9130 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q15_fast_nonsquare.c @@ -0,0 +1,265 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q15_fast.c + * Description: Fast Q15 version of convolution + * + * $Date: 24. May 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + + /** + * @brief Fast Q15 convolution function (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * + * Buffer size: + * + * bufferA size: 2*ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * Input dimension constraints: + * + * ch_im_in is multiple of 2 + * + * ch_im_out is multipe of 2 + * + */ + +arm_status +arm_convolve_HWC_q15_fast_nonsquare(const q15_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q15_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q15_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q15_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + q15_t *pBuffer = bufferA; + q15_t *im_buffer = bufferA; + q15_t *pOut = Im_out; + + if (ch_im_in % 2 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + /* This part implements the im2col function */ + for (i_out_y = 0; i_out_y < dim_im_out_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; i_ker_y++) + { + for (i_ker_x = i_out_x * stride_x - padding_x; i_ker_x < i_out_x * stride_x - padding_x + dim_kernel_x; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in_y || i_ker_x < 0 || i_ker_x >= dim_im_in_x) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + /* arm_copy_q15((q15_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, pBuffer, ch_im_in); */ + memcpy(pBuffer, (q15_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, sizeof(q15_t)*ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (i_out_x & 0x1) + { + int i; + /* initialize the matrix pointers for A */ + const q15_t *pA = wt; + + /* set up the second output pointers */ + q15_t *pOut2 = pOut + ch_im_out; + + /* this loop over rows in A */ + for (i = 0; i < ch_im_out; i += 2) + { + /* setup pointers for B */ + q15_t *pB = im_buffer; + const q15_t *pB2 = pB + ch_im_in * dim_kernel_y * dim_kernel_x; + + /* aling the second pointer for A */ + const q15_t *pA2 = pA + ch_im_in * dim_kernel_y * dim_kernel_x; + + /* init the sum with bias */ + q31_t sum = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)bias[i + 1] << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)bias[i + 1] << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = ch_im_in * dim_kernel_y * dim_kernel_x >> 1; + /* accumulate over the vector */ + while (colCnt) + { + q31_t inA1 = *__SIMD32(pA)++; + q31_t inB1 = *__SIMD32(pB)++; + q31_t inA2 = *__SIMD32(pA2)++; + q31_t inB2 = *__SIMD32(pB2)++; + + sum = __SMLAD(inA1, inB1, sum); + sum2 = __SMLAD(inA1, inB2, sum2); + sum3 = __SMLAD(inA2, inB1, sum3); + sum4 = __SMLAD(inA2, inB2, sum4); + + colCnt--; + } /* while over colCnt */ + colCnt = ch_im_in * dim_kernel_y * dim_kernel_x & 0x1; + while (colCnt) + { + q15_t inA1 = *pA++; + q15_t inB1 = *pB++; + q15_t inA2 = *pA2++; + q15_t inB2 = *pB2++; + + sum += inA1 * inB1; + sum2 += inA1 * inB2; + sum3 += inA2 * inB1; + sum4 += inA2 * inB2; + colCnt--; + } /* while over colCnt */ + *pOut++ = (q15_t) __SSAT(sum >> out_shift, 16); + *pOut++ = (q15_t) __SSAT(sum3 >> out_shift, 16); + *pOut2++ = (q15_t) __SSAT(sum2 >> out_shift, 16); + *pOut2++ = (q15_t) __SSAT(sum4 >> out_shift, 16); + + /* skip the row computed with A2 */ + pA += ch_im_in * dim_kernel_y * dim_kernel_x; + } /* for over ch_im_out */ + + pOut += ch_im_out; + /* counter reset */ + pBuffer = im_buffer; + } + } + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + if (ch_im_in % 2 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out_y; j++) + { + for (k = 0; k < dim_im_out_x; k++) + { + conv_out = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel_y; m++) + { + for (n = 0; n < dim_kernel_x; n++) + { + in_row = stride_y * j + m - padding_y; + in_col = stride_x * k + n - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + + l] * wt[i * ch_im_in * dim_kernel_x * dim_kernel_y + (m * dim_kernel_x + + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out_x + k) * ch_im_out] = (q15_t) __SSAT((conv_out >> out_shift), 16); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_RGB.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_RGB.c new file mode 100644 index 0000000..e53c6f9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_RGB.c @@ -0,0 +1,279 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q7_RGB.c + * Description: Q7 version of convolution for RGB image + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + + /** + * @brief Q7 convolution function for RGB image + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * + * Buffer size: + * + * bufferA size: 2*ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * Input dimension constraints: + * + * ch_im_in equals 3 + * + * This kernel is written exclusively for convolution with ch_im_in + * equals 3. This applies on the first layer of CNNs which has input + * image with RGB format. + */ + +arm_status +arm_convolve_HWC_q7_RGB(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, const uint16_t dim_im_out, q15_t * bufferA, q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + /* + * Here we use bufferA as q15_t internally as computation are done with q15_t level + * im2col are done to output in q15_t format from q7_t input + */ + q15_t *pBuffer = bufferA; + q7_t *pOut = Im_out; + + // check if number of input channels is 3 + if (ch_im_in != 3) + { + return ARM_MATH_SIZE_MISMATCH; + } + // This part implements the im2col function + for (i_out_y = 0; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in || i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* Equivalent to arm_fill_q15(0, pBuffer, ch_im_in) with assumption: ch_im_in = 3 */ + *__SIMD32(pBuffer) = 0x0; + *(pBuffer + 2) = 0; + pBuffer += 3; + } else + { + /* + * Equivalent to: + * arm_q7_to_q15_no_shift( (q7_t*)Im_in+(i_ker_y*dim_im_in+i_ker_x)*3, pBuffer, 3); + */ + + const q7_t *pPixel = Im_in + (i_ker_y * dim_im_in + i_ker_x) * 3; + q31_t buf = *__SIMD32(pPixel); + + union arm_nnword top; + union arm_nnword bottom; + + top.word = __SXTB16(buf); + bottom.word = __SXTB16(__ROR(buf, 8)); + +#ifndef ARM_MATH_BIG_ENDIAN + /* + * little-endian, | omit | 3rd | 2nd | 1st | + * MSB LSB + * top | 3rd | 1st |; bottom | omit | 2nd | + * + * version 1, need to swap 2nd and 3rd weight + * *__SIMD32(pBuffer) = top.word; + * *(pBuffer+2) = bottom.half_words[0]; + * + * version 2, no weight shuffling required + */ + *pBuffer++ = top.half_words[0]; + *__SIMD32(pBuffer) = __PKHBT(bottom.word, top.word, 0); +#else + /* + * big-endian, | 1st | 2nd | 3rd | omit | + * MSB LSB + * top | 2nd | omit |; bottom | 1st | 3rd | + * + * version 1, need to swap 2nd and 3rd weight + * *__SIMD32(pBuffer) = bottom.word; + * *(pBuffer+2) = top.half_words[1]; + * + * version 2, no weight shuffling required + */ + *pBuffer++ = bottom.half_words[0]; + *__SIMD32(pBuffer) = __PKHTB(top.word, bottom.word, 0); +#endif + pBuffer += 2; + } + } + } + + if (pBuffer == bufferA + 2 * 3 * dim_kernel * dim_kernel) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15(wt, bufferA, + ch_im_out, + 3 * dim_kernel * dim_kernel, bias_shift, out_shift, bias, pOut); + + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* left-over because odd number of output pixels */ + if (pBuffer != bufferA) + { + const q7_t *pA = wt; + int i; + + for (i = 0; i < ch_im_out; i++) + { + q31_t sum = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + q15_t *pB = bufferA; + /* basically each time it process 4 entries */ + uint16_t colCnt = 3 * dim_kernel * dim_kernel >> 2; + + while (colCnt) + { + + q31_t inA1, inA2; + q31_t inB1, inB2; + + pA = (q7_t *) read_and_pad((void *)pA, &inA1, &inA2); + + inB1 = *__SIMD32(pB)++; + sum = __SMLAD(inA1, inB1, sum); + inB2 = *__SIMD32(pB)++; + sum = __SMLAD(inA2, inB2, sum); + + colCnt--; + } + colCnt = 3 * dim_kernel * dim_kernel & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + sum += inA1 * inB1; + colCnt--; + } + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + } + } +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + // check if number of input channels is 3 + if (ch_im_in != 3) + { + return ARM_MATH_SIZE_MISMATCH; + } + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out; j++) + { + for (k = 0; k < dim_im_out; k++) + { + conv_out = (bias[i] << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel; m++) + { + for (n = 0; n < dim_kernel; n++) + { + /* if-for implementation */ + in_row = stride * j + m - padding; + in_col = stride * k + n - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in + in_col) * ch_im_in + + l] * wt[i * ch_im_in * dim_kernel * dim_kernel + (m * dim_kernel + + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return (ARM_MATH_SUCCESS); +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic.c new file mode 100644 index 0000000..7c9ec65 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic.c @@ -0,0 +1,230 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q7_basic.c + * Description: Q7 version of convolution + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + + /** + * @brief Basic Q7 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns ARM_MATH_SUCCESS + * + * @details + * + * Buffer size: + * + * bufferA size: 2*ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * This basic version is designed to work for any input tensor and weight + * dimension. + */ + +arm_status +arm_convolve_HWC_q7_basic(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + /* + * Here we use bufferA as q15_t internally as computation are done with q15_t level + * im2col are done to output in q15_t format from q7_t input + */ + q15_t *pBuffer = bufferA; + q7_t *pOut = Im_out; + + /* This part implements the im2col function */ + for (i_out_y = 0; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in || i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* Filling 0 for out-of-bound paddings */ + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + /* Copying the pixel data to column */ + arm_q7_to_q15_no_shift((q7_t *) + Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + /* Computation is filed for every 2 columns */ + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel * dim_kernel) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15(wt, bufferA, + ch_im_out, + ch_im_in * + dim_kernel * dim_kernel, bias_shift, out_shift, bias, pOut); + + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* left-over because odd number of output pixels */ + if (pBuffer != bufferA) + { + const q7_t *pA = wt; + int i; + + for (i = 0; i < ch_im_out; i++) + { + /* Load the accumulator with bias first */ + q31_t sum = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + + /* Point to the beging of the im2col buffer */ + q15_t *pB = bufferA; + + /* Each time it process 4 entries */ + uint16_t colCnt = ch_im_in * dim_kernel * dim_kernel >> 2; + + while (colCnt) + { + q31_t inA1, inA2; + q31_t inB1, inB2; + + pA = (q7_t *) read_and_pad((void *)pA, &inA1, &inA2); + + inB1 = *__SIMD32(pB)++; + sum = __SMLAD(inA1, inB1, sum); + inB2 = *__SIMD32(pB)++; + sum = __SMLAD(inA2, inB2, sum); + + colCnt--; + } + colCnt = ch_im_in * dim_kernel * dim_kernel & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + sum += inA1 * inB1; + colCnt--; + } + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + } + } +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out; j++) + { + for (k = 0; k < dim_im_out; k++) + { + conv_out = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel; m++) + { + for (n = 0; n < dim_kernel; n++) + { + // if-for implementation + in_row = stride * j + m - padding; + in_col = stride * k + n - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in + in_col) * ch_im_in + + l] * wt[i * ch_im_in * dim_kernel * dim_kernel + (m * dim_kernel + + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic_nonsquare.c new file mode 100644 index 0000000..24356d9 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_basic_nonsquare.c @@ -0,0 +1,228 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q7_basic.c + * Description: Q7 version of convolution + * + * $Date: 13. July 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + + /** + * @brief Basic Q7 convolution function (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns ARM_MATH_SUCCESS + */ + +arm_status arm_convolve_HWC_q7_basic_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + /* + * Here we use bufferA as q15_t internally as computation are done with q15_t level + * im2col are done to output in q15_t format from q7_t input + */ + q15_t *pBuffer = bufferA; + q7_t *pOut = Im_out; + + /* This part implements the im2col function */ + for (i_out_y = 0; i_out_y < dim_im_out_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; i_ker_y++) + { + for (i_ker_x = i_out_x * stride_x - padding_x; i_ker_x < i_out_x * stride_x - padding_x + dim_kernel_x; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in_y || i_ker_x < 0 || i_ker_x >= dim_im_in_x) + { + /* Filling 0 for out-of-bound paddings */ + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + /* Copying the pixel data to column */ + arm_q7_to_q15_no_shift((q7_t *) + Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + /* Computation is filed for every 2 columns */ + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel_y * dim_kernel_x) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15(wt, bufferA, + ch_im_out, + ch_im_in * + dim_kernel_y * dim_kernel_x, bias_shift, out_shift, bias, pOut); + + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* left-over because odd number of output pixels */ + if (pBuffer != bufferA) + { + const q7_t *pA = wt; + int i; + + for (i = 0; i < ch_im_out; i++) + { + /* Load the accumulator with bias first */ + q31_t sum = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + + /* Point to the beging of the im2col buffer */ + q15_t *pB = bufferA; + + /* Each time it process 4 entries */ + uint16_t colCnt = ch_im_in * dim_kernel_y * dim_kernel_x >> 2; + + while (colCnt) + { + q31_t inA1, inA2; + q31_t inB1, inB2; + + pA = (q7_t *) read_and_pad((void *)pA, &inA1, &inA2); + + inB1 = *__SIMD32(pB)++; + sum = __SMLAD(inA1, inB1, sum); + inB2 = *__SIMD32(pB)++; + sum = __SMLAD(inA2, inB2, sum); + + colCnt--; + } + colCnt = ch_im_in * dim_kernel_y * dim_kernel_x & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + sum += inA1 * inB1; + colCnt--; + } + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + } + } +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out_y; j++) + { + for (k = 0; k < dim_im_out_x; k++) + { + conv_out = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel_y; m++) + { + for (n = 0; n < dim_kernel_x; n++) + { + // if-for implementation + in_row = stride_y * j + m - padding_y; + in_col = stride_x * k + n - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + l] * + wt[i * ch_im_in * dim_kernel_y * dim_kernel_x + + (m * dim_kernel_x + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out_x + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast.c new file mode 100644 index 0000000..e2d469f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast.c @@ -0,0 +1,408 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q7_fast.c + * Description: Fast Q7 version of convolution + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + + /** + * @brief Fast Q7 convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * + * Buffer size: + * + * bufferA size: 2*ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * Input dimension constraints: + * + * ch_im_in is multiple of 4 ( because of the SIMD32 read and swap ) + * + * ch_im_out is multipe of 2 ( bacause 2x2 mat_mult kernel ) + * + * The im2col converts the Q7 tensor input into Q15 column, which is stored in + * bufferA. There is reordering happenning during this im2col process with + * arm_q7_to_q15_reordered_no_shift. For every four elements, the second and + * third elements are swapped. + * + * The computation kernel arm_nn_mat_mult_kernel_q7_q15_reordered does the + * GEMM computation with the reordered columns. + * + * To speed-up the determination of the padding condition, we split the + * computation into 3x3 parts, i.e., {top, mid, bottom} X {left, mid, right}. + * This reduces the total number of boundary condition checks and improves + * the data copying performance. + */ + +arm_status +arm_convolve_HWC_q7_fast(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + /* + * Here we use bufferA as q15_t internally as computation are done with q15_t level + * im2col are done to output in q15_t format from q7_t input + */ + + q15_t *pBuffer = bufferA; + q7_t *pOut = Im_out; + + if (ch_im_in % 4 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + /* + * Here we split the entire matrix into three regions depending on the padding situation + * Top: i_out_y from 0 to padding - 1 + * Middle: i_out_y from padding to dim_im_out-padding-1 + * Bottom: i_out_y from dim_im_out-padding to dim_im_out-1 + */ + + /* top part */ + for (i_out_y = 0; i_out_y < padding; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in || i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift + ((q7_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel * dim_kernel) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, + bufferA, + ch_im_out, + ch_im_in + * + dim_kernel * dim_kernel, bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* middle part, here we also divide the x into left, mid and right */ + for (; i_out_y < dim_im_out - padding; i_out_y++) + { + + /* left part */ + for (i_out_x = 0; i_out_x < padding; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift + ((q7_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel * dim_kernel) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, + bufferA, + ch_im_out, + ch_im_in + * + dim_kernel * dim_kernel, bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + + /* mid part */ + for (; i_out_x < dim_im_out - padding; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + arm_q7_to_q15_reordered_no_shift((q7_t *) Im_in + + + (i_ker_y * + dim_im_in + + i_out_x * + stride - padding) * ch_im_in, pBuffer, ch_im_in * dim_kernel); + pBuffer += ch_im_in * dim_kernel; + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel * dim_kernel) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, + bufferA, + ch_im_out, + ch_im_in + * + dim_kernel * dim_kernel, bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + + /* right part */ + for (; i_out_x < dim_im_out; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift + ((q7_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel * dim_kernel) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, + bufferA, + ch_im_out, + ch_im_in + * + dim_kernel * dim_kernel, bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + } + + for (; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in || i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift + ((q7_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel * dim_kernel) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, + bufferA, + ch_im_out, + ch_im_in + * + dim_kernel * dim_kernel, bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* check if there is left-over for compute */ + if (pBuffer != bufferA) + { + const q7_t *pA = wt; + int i; + + for (i = 0; i < ch_im_out; i++) + { + q31_t sum = ((q31_t)bias[i] << bias_shift) + NN_ROUND(out_shift); + q15_t *pB = bufferA; + /* each time it process 4 entries */ + uint16_t colCnt = ch_im_in * dim_kernel * dim_kernel >> 2; + + while (colCnt) + { + + q31_t inA1, inA2; + q31_t inB1, inB2; + + pA = (q7_t *) read_and_pad_reordered((void *)pA, &inA1, &inA2); + + inB1 = *__SIMD32(pB)++; + sum = __SMLAD(inA1, inB1, sum); + inB2 = *__SIMD32(pB)++; + sum = __SMLAD(inA2, inB2, sum); + + colCnt--; + } + colCnt = ch_im_in * dim_kernel * dim_kernel & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + sum += inA1 * inB1; + colCnt--; + } + *pOut = (q7_t) __SSAT((sum >> out_shift), 8); + pOut++; + + } + + } +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + uint16_t i, j, k, l, m, n; + int conv_out; + signed char in_row, in_col; + + if (ch_im_in % 4 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out; j++) + { + for (k = 0; k < dim_im_out; k++) + { + conv_out = (bias[i] << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel; m++) + { + for (n = 0; n < dim_kernel; n++) + { + // if-for implementation + in_row = stride * j + m - padding; + in_col = stride * k + n - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += + Im_in[(in_row * dim_im_in + in_col) * ch_im_in + + l] * wt[i * ch_im_in * dim_kernel * dim_kernel + (m * dim_kernel + + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast_nonsquare.c new file mode 100644 index 0000000..6dc6f0b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_convolve_HWC_q7_fast_nonsquare.c @@ -0,0 +1,379 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_convolve_HWC_q7_fast_nonsquare.c + * Description: Fast Q7 version of convolution (non-sqaure shape) + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + +/** + * @brief Fast Q7 convolution function (non-sqaure shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding size x + * @param[in] padding_y padding size y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 4 + * ch_im_out is multiple of 2 + */ + +arm_status arm_convolve_HWC_q7_fast_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_out_y, i_out_x, i_ker_y, i_ker_x; + + /* ----------------------- + * Here we use bufferA as q15_t internally as computation are done with q15_t level + * im2col are done to output in q15_t format from q7_t input + */ + + q15_t *pBuffer = bufferA; + q7_t *pOut = Im_out; + + if (ch_im_in % 4 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + /* + * Here we split the entire matrix into three regions depending on the padding situation + * Top: i_out_y from 0 to padding - 1 + * Middle: i_out_y from padding to dim_im_out-padding-1 + * Bottom: i_out_y from dim_im_out-padding to dim_im_out-1 + */ + + /* top part */ + for (i_out_y = 0; i_out_y < padding_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; + i_ker_y++) + { + for (i_ker_x = i_out_x * stride_x - padding_x; i_ker_x < i_out_x * stride_x - padding_x + dim_kernel_x; + i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in_y || i_ker_x < 0 || i_ker_x >= dim_im_in_x) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift((q7_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, + pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel_x * dim_kernel_y) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, bufferA, ch_im_out, ch_im_in * dim_kernel_x * dim_kernel_y, + bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* middle part, here we also divide the x into left, mid and right */ + for (; i_out_y < dim_im_out_y - padding_y; i_out_y++) + { + + /* left part */ + for (i_out_x = 0; i_out_x < padding_x; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; + i_ker_y++) + { + for (i_ker_x = i_out_x * stride_x - padding_x; i_ker_x < i_out_x * stride_x - padding_x + dim_kernel_x; + i_ker_x++) + { + if (i_ker_x < 0 || i_ker_x >= dim_im_in_x) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift((q7_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, + pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel_x * dim_kernel_y) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, bufferA, ch_im_out, ch_im_in * dim_kernel_x * dim_kernel_y, + bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + + /* mid part */ + for (; i_out_x < dim_im_out_x - padding_x; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; + i_ker_y++) + { + arm_q7_to_q15_reordered_no_shift((q7_t *) Im_in + + (i_ker_y * dim_im_in_x + i_out_x * stride_x - padding_x) * ch_im_in, + pBuffer, ch_im_in * dim_kernel_x); + pBuffer += ch_im_in * dim_kernel_x; + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel_x * dim_kernel_y) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, bufferA, ch_im_out, ch_im_in * dim_kernel_x * dim_kernel_y, + bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + + /* right part */ + for (; i_out_x < dim_im_out_x; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; + i_ker_y++) + { + for (i_ker_x = i_out_x * stride_x - padding_x; i_ker_x < i_out_x * stride_x - padding_x + dim_kernel_x; + i_ker_x++) + { + if (i_ker_x < 0 || i_ker_x >= dim_im_in_x) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift((q7_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, + pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel_x * dim_kernel_y) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, bufferA, ch_im_out, ch_im_in * dim_kernel_x * dim_kernel_y, + bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + } + + for (; i_out_y < dim_im_out_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + /* This part implements the im2col function */ + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; + i_ker_y++) + { + for (i_ker_x = i_out_x * stride_x - padding_x; i_ker_x < i_out_x * stride_x - padding_x + dim_kernel_x; + i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in_y || i_ker_x < 0 || i_ker_x >= dim_im_in_x) + { + /* arm_fill_q15(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, sizeof(q15_t)*ch_im_in); + } else + { + arm_q7_to_q15_reordered_no_shift((q7_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, + pBuffer, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + if (pBuffer == bufferA + 2 * ch_im_in * dim_kernel_x * dim_kernel_y) + { + pOut = + arm_nn_mat_mult_kernel_q7_q15_reordered(wt, bufferA, ch_im_out, ch_im_in * dim_kernel_x * dim_kernel_y, + bias_shift, out_shift, bias, pOut); + /* counter reset */ + pBuffer = bufferA; + } + } + } + + /* check if there is left-over for compute */ + if (pBuffer != bufferA) + { + const q7_t *pA = wt; + int i; + for (i = 0; i < ch_im_out; i++) + { + q31_t sum = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + q15_t *pB = bufferA; + /* basically each time it process 4 entries */ + uint16_t colCnt = ch_im_in * dim_kernel_x * dim_kernel_y >> 2; + + while (colCnt) + { + + q31_t inA1, inA2; + q31_t inB1, inB2; + + pA = (const q7_t *)read_and_pad_reordered((void *)pA, &inA1, &inA2); + + inB1 = *__SIMD32(pB)++; + sum = __SMLAD(inA1, inB1, sum); + inB2 = *__SIMD32(pB)++; + sum = __SMLAD(inA2, inB2, sum); + + colCnt--; + } + colCnt = (ch_im_in * dim_kernel_y * dim_kernel_x) & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + sum += inA1 * inB1; + colCnt--; + } + *pOut = (q7_t) __SSAT((sum >> out_shift), 8); + pOut++; + + } + + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + int i, j, k, l, m, n; + int conv_out; + int in_row, in_col; + + if (ch_im_in % 4 != 0 || ch_im_out % 2 != 0) + { + /* check if the input dimension meets the constraints */ + return ARM_MATH_SIZE_MISMATCH; + } + + for (i = 0; i < ch_im_out; i++) + { + for (j = 0; j < dim_im_out_y; j++) + { + for (k = 0; k < dim_im_out_x; k++) + { + conv_out = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + for (m = 0; m < dim_kernel_y; m++) + { + for (n = 0; n < dim_kernel_x; n++) + { + /* if-for implementation */ + in_row = stride_y * j + m - padding_y; + in_col = stride_x * k + n - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + for (l = 0; l < ch_im_in; l++) + { + conv_out += Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + l] * + wt[i * ch_im_in * dim_kernel_y * dim_kernel_x + (m * dim_kernel_x + n) * ch_im_in + l]; + } + } + } + } + Im_out[i + (j * dim_im_out_x + k) * ch_im_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7.c new file mode 100644 index 0000000..705fa6a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7.c @@ -0,0 +1,418 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_depthwise_separable_conv_HWC_q7.c + * Description: Q7 depthwise separable convolution function + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + +/** + * @brief Q7 depthwise separable convolution function + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * @details + * + * Buffer size: + * + * bufferA size: 2*ch_im_in*dim_kernel*dim_kernel + * + * bufferB size: 0 + * + * Input dimension constraints: + * + * ch_im_in equals ch_im_out + * + * Implementation: + * There are 3 nested loop here: + * Inner loop: calculate each output value with MAC instruction over an accumulator + * Mid loop: loop over different output channel + * Outer loop: loop over different output (x, y) + */ + +arm_status arm_depthwise_separable_conv_HWC_q7(const q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_out_y, i_out_x; + int16_t i_ker_y, i_ker_x; + q7_t *colBuffer = (q7_t *) bufferA; + q7_t *pBuffer = colBuffer; + const q7_t *pBias = bias; + q7_t *pOut = Im_out; + uint16_t rowCnt; + uint16_t row_shift; + + /* do some checking here, basically ch_im_in == ch_im_out */ + if (ch_im_in != ch_im_out) + { + return ARM_MATH_SIZE_MISMATCH; + } + + for (i_out_y = 0; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + /* we first do im2col here */ + for (i_ker_y = i_out_y * stride - padding; i_ker_y < i_out_y * stride - padding + dim_kernel; i_ker_y++) + { + for (i_ker_x = i_out_x * stride - padding; i_ker_x < i_out_x * stride - padding + dim_kernel; i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in || i_ker_x < 0 || i_ker_x >= dim_im_in) + { + /* arm_fill_q7(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, ch_im_in); + } else + { + /* arm_copy_q7((q7_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, pBuffer, ch_im_in); */ + memcpy(pBuffer, (q7_t *) Im_in + (i_ker_y * dim_im_in + i_ker_x) * ch_im_in, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + /* we will do the computation here for each channel */ + rowCnt = ch_im_out >> 2; + row_shift = 0; + pBias = bias; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = (dim_kernel * dim_kernel) >> 1; + q7_t *pB = colBuffer + row_shift; + const q7_t *pA = wt + row_shift; + row_shift += 4; + +#ifdef USE_INTRINSIC + +#ifndef ARM_MATH_BIG_ENDIAN + + while (colCnt) + { + q31_t inA1, inA2, inB1, inB2, opA, opB; + + inB1 = *__SIMD32(pB); + pB += ch_im_in; + opB = *__SIMD32(pB); + pB += ch_im_in; + inB2 = __PKHTB(opB, inB1, 16); + inB1 = __PKHBT(inB1, opB, 16); + inA1 = *__SIMD32(pA); + pA += ch_im_in; + opB = *__SIMD32(pA); + pA += ch_im_in; + inA2 = __PKHTB(opB, inA1, 16); + inA1 = __PKHBT(inA1, opB, 16); + opA = __SXTB16(inA1); + opB = __SXTB16(inB1); + sum = __SMLAD(opA, opB, sum); + opA = __SXTB16(__ROR(inA1, 8)); + opB = __SXTB16(__ROR(inB1, 8)); + sum2 = __SMLAD(opA, opB, sum2); + opA = __SXTB16(inA2); + opB = __SXTB16(inB2); + sum3 = __SMLAD(opA, opB, sum3); + opA = __SXTB16(__ROR(inA2, 8)); + opB = __SXTB16(__ROR(inB2, 8)); + sum4 = __SMLAD(opA, opB, sum4); + colCnt--; + } +#else + + while (colCnt) + { + q31_t inA1, inA2, inB1, inB2, opA, opB; + + inB1 = *__SIMD32(pB); + pB += ch_im_in; + opB = *__SIMD32(pB); + pB += ch_im_in; + inB2 = __PKHBT(opB, inB1, 16); + inB1 = __PKHTB(inB1, opB, 16); + inA1 = *__SIMD32(pA); + pA += ch_im_in; + opB = *__SIMD32(pA); + pA += ch_im_in; + inA2 = __PKHBT(opB, inA1, 16); + inA1 = __PKHTB(inA1, opB, 16); + opA = __SXTB16(inA1); + opB = __SXTB16(inB1); + sum2 = __SMLAD(opA, opB, sum2); + opA = __SXTB16(__ROR(inA1, 8)); + opB = __SXTB16(__ROR(inB1, 8)); + sum = __SMLAD(opA, opB, sum); + opA = __SXTB16(inA2); + opB = __SXTB16(inB2); + sum4 = __SMLAD(opA, opB, sum4); + opA = __SXTB16(__ROR(inA2, 8)); + opB = __SXTB16(__ROR(inB2, 8)); + sum3 = __SMLAD(opA, opB, sum3); + colCnt--; + } + +#endif /* ARM_MATH_BIG_ENDIAN */ + +#else + +#ifndef ARM_MATH_BIG_ENDIAN + /* + * r0 r1 r2 r3 r4 r5 + * inA1, inA2, inB1, inB2, opA, opB + */ + + asm volatile ("COL_LOOP_%=:\n" + "ldr.w r2, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "ldr.w r5, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "pkhtb r3, r5, r2, ASR #16\n" + "pkhbt r2, r2, r5, LSL #16\n" + "ldr.w r0, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "ldr.w r5, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "pkhtb r1, r5, r0, ASR #16\n" + "pkhbt r0, r0, r5, LSL #16\n" + "sxtb16 r4, r0\n" + "sxtb16 r5, r2\n" + "smlad %[sum], r4, r5, %[sum]\n" + "mov.w r4, r0, ror #8\n" + "mov.w r5, r2, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum2], r4, r5, %[sum2]\n" + "sxtb16 r4, r1\n" + "sxtb16 r5, r3\n" + "smlad %[sum3], r4, r5, %[sum3]\n" + "mov.w r4, r1, ror #8\n" + "mov.w r5, r3, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum4], r4, r5, %[sum4]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP_%=\n":[sum] + "+r"(sum),[sum2] "+r"(sum2), + [sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB), + [pA] "+r"(pA):[colCnt] + "r"(colCnt),[ch_im_in] "r"(ch_im_in):"r0", "r1", "r2", "r3", "r4", "r5"); +#else + /* + * r0 r1 r2 r3 r4 r5 + * inA1, inA2, inB1, inB2, opA, opB + */ + asm volatile ("COL_LOOP_%=:\n" + "ldr.w r2, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "ldr.w r5, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "pkhbt r3, r5, r2, LSL #16\n" + "pkhtb r2, r2, r5, ASR #16\n" + "ldr.w r0, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "ldr.w r5, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "pkhbt r1, r5, r0, LSL #16\n" + "pkhtb r0, r0, r5, ASR #16\n" + "sxtb16 r4, r0\n" + "sxtb16 r5, r2\n" + "smlad %[sum2], r4, r5, %[sum2]\n" + "mov.w r4, r0, ror #8\n" + "mov.w r5, r2, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum], r4, r5, %[sum]\n" + "sxtb16 r4, r1\n" + "sxtb16 r5, r3\n" + "smlad %[sum4], r4, r5, %[sum4]\n" + "mov.w r4, r1, ror #8\n" + "mov.w r5, r3, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum3], r4, r5, %[sum3]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP_%=\n":[sum] + "+r"(sum),[sum2] "+r"(sum2), + [sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB), + [pA] "+r"(pA):[colCnt] + "r"(colCnt),[ch_im_in] "r"(ch_im_in):"r0", "r1", "r2", "r3", "r4", "r5"); + +#endif /* ARM_MATH_BIG_ENDIAN */ + +#endif /* USE_INTRINSIC */ + + colCnt = (dim_kernel * dim_kernel) & 0x1; + while (colCnt) + { + union arm_nnword inA, inB; + inA.word = *__SIMD32(pA); + pA += ch_im_in; + inB.word = *__SIMD32(pB); + pB += ch_im_in; + sum += inA.bytes[0] * inB.bytes[0]; + sum2 += inA.bytes[1] * inB.bytes[1]; + sum3 += inA.bytes[2] * inB.bytes[2]; + sum4 += inA.bytes[3] * inB.bytes[3]; + colCnt--; + } + + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum2 >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum3 >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum4 >> out_shift), 8); + + rowCnt--; + } + + rowCnt = ch_im_out & 0x3; + while (rowCnt) + { + q7_t *pB = colBuffer + row_shift; + const q7_t *pA = wt + row_shift; + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + uint16_t colCnt = (dim_kernel * dim_kernel); + + row_shift += 1; + + while (colCnt) + { + q7_t A1 = *pA; + q7_t B1 = *pB; + pA += ch_im_in; + pB += ch_im_in; + sum += A1 * B1; + + colCnt--; + } + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + rowCnt--; + } + + /* clear counter and pointers */ + pBuffer = colBuffer; + } + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + int i_out_y, i_out_x, i_ch_out, i_ker_x, i_ker_y; + int conv_out; + + /* do some checking here, basically ch_im_in == ch_im_out */ + if (ch_im_in != ch_im_out) + { + return ARM_MATH_SIZE_MISMATCH; + } + + for (i_out_y = 0; i_out_y < dim_im_out; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out; i_out_x++) + { + for (i_ch_out = 0; i_ch_out < ch_im_out; i_ch_out++) + { + // for each output + conv_out = ((q31_t)(bias[i_ch_out]) << bias_shift) + NN_ROUND(out_shift); + for (i_ker_y = 0; i_ker_y < dim_kernel; i_ker_y++) + { + for (i_ker_x = 0; i_ker_x < dim_kernel; i_ker_x++) + { + int in_row = stride * i_out_y + i_ker_y - padding; + int in_col = stride * i_out_x + i_ker_x - padding; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in && in_col < dim_im_in) + { + conv_out += + Im_in[(in_row * + dim_im_in + + in_col) * + ch_im_in + + i_ch_out] * wt[(i_ker_y * dim_kernel + i_ker_x) * ch_im_out + i_ch_out]; + } + } + } + Im_out[(i_out_y * dim_im_out + + i_out_x) * ch_im_out + i_ch_out] = (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return ARM_MATH_SUCCESS; + +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7_nonsquare.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7_nonsquare.c new file mode 100644 index 0000000..5989304 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_depthwise_separable_conv_HWC_q7_nonsquare.c @@ -0,0 +1,411 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_depthwise_separable_conv_HWC_q7_nonsquare.c + * Description: Q7 depthwise separable convolution function (non-square shape) + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup NNConv + * @{ + */ + +/** + * @brief Q7 depthwise separable convolution function (non-square shape) + * @param[in] Im_in pointer to input tensor + * @param[in] dim_im_in_x input tensor dimention x + * @param[in] dim_im_in_y input tensor dimention y + * @param[in] ch_im_in number of input tensor channels + * @param[in] wt pointer to kernel weights + * @param[in] ch_im_out number of filters, i.e., output tensor channels + * @param[in] dim_kernel_x filter kernel size x + * @param[in] dim_kernel_y filter kernel size y + * @param[in] padding_x padding sizes x + * @param[in] padding_y padding sizes y + * @param[in] stride_x convolution stride x + * @param[in] stride_y convolution stride y + * @param[in] bias pointer to bias + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in,out] Im_out pointer to output tensor + * @param[in] dim_im_out_x output tensor dimension x + * @param[in] dim_im_out_y output tensor dimension y + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] bufferB pointer to buffer space for output + * @return The function returns either + * ARM_MATH_SIZE_MISMATCH or ARM_MATH_SUCCESS based on the outcome of size checking. + * + * This function is the version with full list of optimization tricks, but with + * some contraints: + * ch_im_in is multiple of 2 + * ch_im_out is multiple of 2 + */ + +arm_status arm_depthwise_separable_conv_HWC_q7_nonsquare(const q7_t * Im_in, + const uint16_t dim_im_in_x, + const uint16_t dim_im_in_y, + const uint16_t ch_im_in, + const q7_t * wt, + const uint16_t ch_im_out, + const uint16_t dim_kernel_x, + const uint16_t dim_kernel_y, + const uint16_t padding_x, + const uint16_t padding_y, + const uint16_t stride_x, + const uint16_t stride_y, + const q7_t * bias, + const uint16_t bias_shift, + const uint16_t out_shift, + q7_t * Im_out, + const uint16_t dim_im_out_x, + const uint16_t dim_im_out_y, + q15_t * bufferA, + q7_t * bufferB) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + +/* + * Implementation: + * There are 3 nested loop here: + * Inner loop: calculate each output value with MAC instruction over an accumulator + * Mid loop: loop over different output channel + * Outer loop: loop over different output (x, y) + * + */ + + int16_t i_out_y, i_out_x; + int16_t i_ker_y, i_ker_x; + q7_t *colBuffer = (q7_t *) bufferA; + q7_t *pBuffer = colBuffer; + const q7_t *pBias = bias; + q7_t *pOut = Im_out; + uint16_t rowCnt; + uint16_t row_shift; + + /* do some checking here, basically ch_im_in == ch_im_out */ + if (ch_im_in != ch_im_out) + { + return ARM_MATH_SIZE_MISMATCH; + } + + for (i_out_y = 0; i_out_y < dim_im_out_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + /* we first do im2col here */ + for (i_ker_y = i_out_y * stride_y - padding_y; i_ker_y < i_out_y * stride_y - padding_y + dim_kernel_y; + i_ker_y++) + { + for (i_ker_x = i_out_x * stride_x - padding_x; i_ker_x < i_out_x * stride_x - padding_x + dim_kernel_x; + i_ker_x++) + { + if (i_ker_y < 0 || i_ker_y >= dim_im_in_y || i_ker_x < 0 || i_ker_x >= dim_im_in_x) + { + /* arm_fill_q7(0, pBuffer, ch_im_in); */ + memset(pBuffer, 0, ch_im_in); + } else + { + /* arm_copy_q7((q7_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, pBuffer, ch_im_in); */ + memcpy(pBuffer, (q7_t *) Im_in + (i_ker_y * dim_im_in_x + i_ker_x) * ch_im_in, ch_im_in); + } + pBuffer += ch_im_in; + } + } + + /* we will do the computation here for each channel */ + rowCnt = ch_im_out >> 2; + row_shift = 0; + pBias = bias; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = (dim_kernel_x * dim_kernel_y) >> 1; + q7_t *pB = colBuffer + row_shift; + const q7_t *pA = wt + row_shift; + row_shift += 4; + +#ifdef USE_INTRINSIC + +#ifndef ARM_MATH_BIG_ENDIAN + + while (colCnt) + { + q31_t inA1, inA2, inB1, inB2, opA, opB; + + inB1 = *__SIMD32(pB); + pB += ch_im_in; + opB = *__SIMD32(pB); + pB += ch_im_in; + inB2 = __PKHTB(opB, inB1, 16); + inB1 = __PKHBT(inB1, opB, 16); + inA1 = *__SIMD32(pA); + pA += ch_im_in; + opB = *__SIMD32(pA); + pA += ch_im_in; + inA2 = __PKHTB(opB, inA1, 16); + inA1 = __PKHBT(inA1, opB, 16); + opA = __SXTB16(inA1); + opB = __SXTB16(inB1); + sum = __SMLAD(opA, opB, sum); + opA = __SXTB16(__ROR(inA1, 8)); + opB = __SXTB16(__ROR(inB1, 8)); + sum2 = __SMLAD(opA, opB, sum2); + opA = __SXTB16(inA2); + opB = __SXTB16(inB2); + sum3 = __SMLAD(opA, opB, sum3); + opA = __SXTB16(__ROR(inA2, 8)); + opB = __SXTB16(__ROR(inB2, 8)); + sum4 = __SMLAD(opA, opB, sum4); + colCnt--; + } +#else + + while (colCnt) + { + q31_t inA1, inA2, inB1, inB2, opA, opB; + + inB1 = *__SIMD32(pB); + pB += ch_im_in; + opB = *__SIMD32(pB); + pB += ch_im_in; + inB2 = __PKHBT(opB, inB1, 16); + inB1 = __PKHTB(inB1, opB, 16); + inA1 = *__SIMD32(pA); + pA += ch_im_in; + opB = *__SIMD32(pA); + pA += ch_im_in; + inA2 = __PKHBT(opB, inA1, 16); + inA1 = __PKHTB(inA1, opB, 16); + opA = __SXTB16(inA1); + opB = __SXTB16(inB1); + sum2 = __SMLAD(opA, opB, sum2); + opA = __SXTB16(__ROR(inA1, 8)); + opB = __SXTB16(__ROR(inB1, 8)); + sum = __SMLAD(opA, opB, sum); + opA = __SXTB16(inA2); + opB = __SXTB16(inB2); + sum4 = __SMLAD(opA, opB, sum4); + opA = __SXTB16(__ROR(inA2, 8)); + opB = __SXTB16(__ROR(inB2, 8)); + sum3 = __SMLAD(opA, opB, sum3); + colCnt--; + } + +#endif /* ARM_MATH_BIG_ENDIAN */ + +#else + +#ifndef ARM_MATH_BIG_ENDIAN + // r0 r1 r2 r3 r4 r5 + // inA1, inA2, inB1, inB2, opA, opB + asm volatile ("COL_LOOP:\n" + "ldr.w r2, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "ldr.w r5, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "pkhtb r3, r5, r2, ASR #16\n" + "pkhbt r2, r2, r5, LSL #16\n" + "ldr.w r0, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "ldr.w r5, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "pkhtb r1, r5, r0, ASR #16\n" + "pkhbt r0, r0, r5, LSL #16\n" + "sxtb16 r4, r0\n" + "sxtb16 r5, r2\n" + "smlad %[sum], r4, r5, %[sum]\n" + "mov.w r4, r0, ror #8\n" + "mov.w r5, r2, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum2], r4, r5, %[sum2]\n" + "sxtb16 r4, r1\n" + "sxtb16 r5, r3\n" + "smlad %[sum3], r4, r5, %[sum3]\n" + "mov.w r4, r1, ror #8\n" + "mov.w r5, r3, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum4], r4, r5, %[sum4]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP\n":[sum] "+r"(sum),[sum2] "+r"(sum2),[sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB),[pA] "+r"(pA):[colCnt] "r"(colCnt), + [ch_im_in] "r"(ch_im_in):"r0", "r1", "r2", "r3", "r4", "r5"); +#else + // r0 r1 r2 r3 r4 r5 + // inA1, inA2, inB1, inB2, opA, opB + asm volatile ("COL_LOOP:\n" + "ldr.w r2, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "ldr.w r5, [%[pB], #0]\n" + "add.w %[pB], %[pB], %[ch_im_in]\n" + "pkhbt r3, r5, r2, LSL #16\n" + "pkhtb r2, r2, r5, ASR #16\n" + "ldr.w r0, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "ldr.w r5, [%[pA], #0]\n" + "add.w %[pA], %[pA], %[ch_im_in]\n" + "pkhbt r1, r5, r0, LSL #16\n" + "pkhtb r0, r0, r5, ASR #16\n" + "sxtb16 r4, r0\n" + "sxtb16 r5, r2\n" + "smlad %[sum2], r4, r5, %[sum2]\n" + "mov.w r4, r0, ror #8\n" + "mov.w r5, r2, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum], r4, r5, %[sum]\n" + "sxtb16 r4, r1\n" + "sxtb16 r5, r3\n" + "smlad %[sum4], r4, r5, %[sum4]\n" + "mov.w r4, r1, ror #8\n" + "mov.w r5, r3, ror #8\n" + "sxtb16 r4, r4\n" + "sxtb16 r5, r5\n" + "smlad %[sum3], r4, r5, %[sum3]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP\n":[sum] "+r"(sum),[sum2] "+r"(sum2),[sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB),[pA] "+r"(pA):[colCnt] "r"(colCnt), + [ch_im_in] "r"(ch_im_in):"r0", "r1", "r2", "r3", "r4", "r5"); +#endif /*ARM_MATH_BIG_ENDIAN */ + +#endif /* USE_INTRINSIC */ + + colCnt = (dim_kernel_x * dim_kernel_y) & 0x1; + while (colCnt) + { + union arm_nnword inA, inB; + inA.word = *__SIMD32(pA); + pA += ch_im_in; + inB.word = *__SIMD32(pB); + pB += ch_im_in; + sum += inA.bytes[0] * inB.bytes[0]; + sum2 += inA.bytes[1] * inB.bytes[1]; + sum3 += inA.bytes[2] * inB.bytes[2]; + sum4 += inA.bytes[3] * inB.bytes[3]; + colCnt--; + } + + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum2 >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum3 >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum4 >> out_shift), 8); + + rowCnt--; + } + + rowCnt = ch_im_out & 0x3; + while (rowCnt) + { + q7_t *pB = colBuffer + row_shift; + const q7_t *pA = wt + row_shift; + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + uint16_t colCnt = (dim_kernel_x * dim_kernel_y); + + row_shift += 1; + + while (colCnt) + { + q7_t A1 = *pA; + q7_t B1 = *pB; + pA += ch_im_in; + pB += ch_im_in; + sum += A1 * B1; + + colCnt--; + } + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + rowCnt--; + } + + // clear counter and pointers + pBuffer = colBuffer; + } + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + int i_out_y, i_out_x, i_ch_out; + int i_ker_y, i_ker_x; + + /* do some checking here, basically ch_im_in == ch_im_out */ + if (ch_im_in != ch_im_out) + { + return ARM_MATH_SIZE_MISMATCH; + } + + for (i_out_y = 0; i_out_y < dim_im_out_y; i_out_y++) + { + for (i_out_x = 0; i_out_x < dim_im_out_x; i_out_x++) + { + for (i_ch_out = 0; i_ch_out < ch_im_out; i_ch_out++) + { + // for each output + int conv_out = ((q31_t)(bias[i_ch_out]) << bias_shift) + NN_ROUND(out_shift); + for (i_ker_y = 0; i_ker_y < dim_kernel_y; i_ker_y++) + { + for (i_ker_x = 0; i_ker_x < dim_kernel_x; i_ker_x++) + { + int in_row = stride_y * i_out_y + i_ker_y - padding_y; + int in_col = stride_x * i_out_x + i_ker_x - padding_x; + if (in_row >= 0 && in_col >= 0 && in_row < dim_im_in_y && in_col < dim_im_in_x) + { + conv_out += Im_in[(in_row * dim_im_in_x + in_col) * ch_im_in + i_ch_out] * + wt[(i_ker_y * dim_kernel_x + i_ker_x) * ch_im_out + i_ch_out]; + } + } + } + Im_out[(i_out_y * dim_im_out_x + i_out_x) * ch_im_out + i_ch_out] = + (q7_t) __SSAT((conv_out >> out_shift), 8); + } + } + } + +#endif /* ARM_MATH_DSP */ + + + /* Return to application */ + return ARM_MATH_SUCCESS; + +} + +/** + * @} end of NNConv group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15.c new file mode 100644 index 0000000..24ab412 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15.c @@ -0,0 +1,187 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nn_mat_mult_kernel_q7_q15.c + * Description: Matrix-multiplication function for convolution + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + + /** + * @brief Matrix-multiplication function for convolution + * @param[in] pA pointer to operand A + * @param[in] pInBuffer pointer to operand B, always conssists of 2 vectors + * @param[in] ch_im_out numRow of A + * @param[in] numCol_A numCol of A + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias the bias + * @param[in,out] pOut pointer to output + * @return The function returns the incremented output pointer + * + * @details + * + * This function does the matrix multiplication with weight matrix + * and 2 columns from im2col. + */ + +q7_t *arm_nn_mat_mult_kernel_q7_q15(const q7_t * pA, + const q15_t * pInBuffer, + const uint16_t ch_im_out, + const uint16_t numCol_A, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q7_t * pOut) +{ +#if defined (ARM_MATH_DSP) + /* set up the second output pointers */ + q7_t *pOut2 = pOut + ch_im_out; + const q7_t *pBias = bias; + + uint16_t rowCnt = ch_im_out >> 1; + /* this loop over rows in A */ + while (rowCnt) + { + /* setup pointers for B */ + const q15_t *pB = pInBuffer; + const q15_t *pB2 = pB + numCol_A; + + /* align the second pointer for A */ + const q7_t *pA2 = pA + numCol_A; + + /* init the sum with bias */ + q31_t sum = ((q31_t)(*pBias) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = numCol_A >> 2; + /* accumulate over the vector */ + while (colCnt) + { + q31_t inA11, inA12, inA21, inA22; + q31_t inB1 = *__SIMD32(pB)++; + q31_t inB2 = *__SIMD32(pB2)++; + + pA = (q7_t *) read_and_pad((void *)pA, &inA11, &inA12); + pA2 = (q7_t *) read_and_pad((void *)pA2, &inA21, &inA22); + + sum = __SMLAD(inA11, inB1, sum); + sum2 = __SMLAD(inA11, inB2, sum2); + sum3 = __SMLAD(inA21, inB1, sum3); + sum4 = __SMLAD(inA21, inB2, sum4); + + inB1 = *__SIMD32(pB)++; + inB2 = *__SIMD32(pB2)++; + + sum = __SMLAD(inA12, inB1, sum); + sum2 = __SMLAD(inA12, inB2, sum2); + sum3 = __SMLAD(inA22, inB1, sum3); + sum4 = __SMLAD(inA22, inB2, sum4); + + colCnt--; + } /* while over colCnt */ + colCnt = numCol_A & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + q7_t inA2 = *pA2++; + q15_t inB2 = *pB2++; + + sum += inA1 * inB1; + sum2 += inA1 * inB2; + sum3 += inA2 * inB1; + sum4 += inA2 * inB2; + colCnt--; + } /* while over colCnt */ + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum3 >> out_shift), 8); + *pOut2++ = (q7_t) __SSAT((sum2 >> out_shift), 8); + *pOut2++ = (q7_t) __SSAT((sum4 >> out_shift), 8); + + /* skip the row computed with A2 */ + pA += numCol_A; + rowCnt--; + } /* for over ch_im_out */ + + /* compute left-over row if any */ + if (ch_im_out & 0x1) + { + /* setup pointers for B */ + const q15_t *pB = pInBuffer; + const q15_t *pB2 = pB + numCol_A; + + /* load the bias */ + q31_t sum = ((q31_t)(*pBias) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = numCol_A >> 2; + while (colCnt) + { + q31_t inA11, inA12; + q31_t inB1 = *__SIMD32(pB)++; + q31_t inB2 = *__SIMD32(pB2)++; + + pA = (q7_t *) read_and_pad((void *)pA, &inA11, &inA12); + + sum = __SMLAD(inA11, inB1, sum); + sum2 = __SMLAD(inA11, inB2, sum2); + + inB1 = *__SIMD32(pB)++; + inB2 = *__SIMD32(pB2)++; + sum = __SMLAD(inA12, inB1, sum); + sum2 = __SMLAD(inA12, inB2, sum2); + + colCnt--; + } + colCnt = numCol_A & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + q15_t inB2 = *pB2++; + + sum += inA1 * inB1; + sum2 += inA1 * inB2; + colCnt--; + } + + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + *pOut2++ = (q7_t) __SSAT((sum2 >> out_shift), 8); + } + + pOut += ch_im_out; + + /* return the new output pointer with offset */ + return pOut; +#else + /* To be completed */ + return NULL; +#endif /* ARM_MATH_DSP */ + +} diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15_reordered.c b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15_reordered.c new file mode 100644 index 0000000..36af21a --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/ConvolutionFunctions/arm_nn_mat_mult_kernel_q7_q15_reordered.c @@ -0,0 +1,138 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nn_mat_mult_kernel_q7_q15_reordered.c + * Description: Matrix-multiplication function for convolution with reordered columns + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * -------------------------------------------------------------------- */ + +#include "arm_nnfunctions.h" +#include "arm_math.h" + + /** + * @brief Matrix-multiplication function for convolution with reordered columns + * @param[in] pA pointer to operand A + * @param[in] pInBuffer pointer to operand B, always conssists of 2 vectors + * @param[in] ch_im_out numRow of A + * @param[in] numCol_A numCol of A + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias the bias + * @param[in,out] pOut pointer to output + * @return The function returns the incremented output pointer + * + * @details + * + * This function assumes that data in pInBuffer are reordered + */ + +q7_t *arm_nn_mat_mult_kernel_q7_q15_reordered(const q7_t * pA, + const q15_t * pInBuffer, + const uint16_t ch_im_out, + const uint16_t numCol_A, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q7_t * pOut) +{ + +#if defined (ARM_MATH_DSP) + /* set up the second output pointers */ + q7_t *pOut2 = pOut + ch_im_out; + int i; + + /* this loop over rows in A */ + for (i = 0; i < ch_im_out; i += 2) + { + /* setup pointers for B */ + const q15_t *pB = pInBuffer; + const q15_t *pB2 = pB + numCol_A; + + /* align the second pointer for A */ + const q7_t *pA2 = pA + numCol_A; + + /* init the sum with bias */ + q31_t sum = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(bias[i + 1]) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(bias[i + 1]) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = numCol_A >> 2; + /* accumulate over the vector */ + while (colCnt) + { + q31_t inA11, inA12, inA21, inA22; + q31_t inB1 = *__SIMD32(pB)++; + q31_t inB2 = *__SIMD32(pB2)++; + + pA = (q7_t *) read_and_pad_reordered((void *)pA, &inA11, &inA12); + pA2 = (q7_t *) read_and_pad_reordered((void *)pA2, &inA21, &inA22); + + sum = __SMLAD(inA11, inB1, sum); + sum2 = __SMLAD(inA11, inB2, sum2); + sum3 = __SMLAD(inA21, inB1, sum3); + sum4 = __SMLAD(inA21, inB2, sum4); + + inB1 = *__SIMD32(pB)++; + inB2 = *__SIMD32(pB2)++; + + sum = __SMLAD(inA12, inB1, sum); + sum2 = __SMLAD(inA12, inB2, sum2); + sum3 = __SMLAD(inA22, inB1, sum3); + sum4 = __SMLAD(inA22, inB2, sum4); + + colCnt--; + } /* while over colCnt */ + colCnt = numCol_A & 0x3; + while (colCnt) + { + q7_t inA1 = *pA++; + q15_t inB1 = *pB++; + q7_t inA2 = *pA2++; + q15_t inB2 = *pB2++; + + sum += inA1 * inB1; + sum2 += inA1 * inB2; + sum3 += inA2 * inB1; + sum4 += inA2 * inB2; + colCnt--; + } /* while over colCnt */ + *pOut++ = (q7_t) __SSAT((sum >> out_shift), 8); + *pOut++ = (q7_t) __SSAT((sum3 >> out_shift), 8); + *pOut2++ = (q7_t) __SSAT((sum2 >> out_shift), 8); + *pOut2++ = (q7_t) __SSAT((sum4 >> out_shift), 8); + + /* skip the row computed with A2 */ + pA += numCol_A; + } /* for over ch_im_out */ + + pOut += ch_im_out; + + /* return the new output pointer with offset */ + return pOut; +#else + /* To be completed */ + return NULL; +#endif /* ARM_MATH_DSP */ +} diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15.c b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15.c new file mode 100644 index 0000000..bb9a091 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15.c @@ -0,0 +1,199 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_fully_connected_mat_q7_vec_q15.c + * Description: Mixed Q15-Q7 fully-connected layer function + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup FC + * @{ + */ + + /** + * @brief Mixed Q15-Q7 fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + * @details + * + * Buffer size: + * + * vec_buffer size: 0 + * + * Q7_Q15 version of the fully connected layer + * + * Weights are in q7_t and Activations are in q15_t + * + */ + +arm_status +arm_fully_connected_mat_q7_vec_q15(const q15_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q15_t * pOut, + q15_t * vec_buffer) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + const q7_t *pB = pM; + const q7_t *pB2; + q15_t *pO = pOut; + const q7_t *pBias = bias; + const q15_t *pA = pV; + + uint16_t rowCnt = num_of_rows >> 1; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + uint16_t colCnt = dim_vec >> 2; + + pA = pV; + pB2 = pB + dim_vec; + + while (colCnt) + { + q31_t inV, inM11, inM12, inM21, inM22; + pB = (q7_t *) read_and_pad((void *)pB, &inM11, &inM12); + pB2 = (q7_t *) read_and_pad((void *)pB2, &inM21, &inM22); + + inV = *__SIMD32(pA)++; + + sum = __SMLAD(inV, inM11, sum); + sum2 = __SMLAD(inV, inM21, sum2); + + inV = *__SIMD32(pA)++; + + sum = __SMLAD(inV, inM12, sum); + sum2 = __SMLAD(inV, inM22, sum2); + + colCnt--; + } + colCnt = dim_vec & 0x3; + while (colCnt) + { + q15_t inV = *pA++; + q7_t inM = *pB++; + q7_t inM2 = *pB2++; + + sum += inV * inM; + sum2 += inV * inM2; + colCnt--; + } /* while over colCnt */ + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum2 >> out_shift), 16)); + + /*adjust the pointers and counters */ + pB += dim_vec; + rowCnt--; + } + + /* left-over part of the rows */ + rowCnt = num_of_rows & 0x1; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + uint16_t colCnt = dim_vec >> 2; + + pA = pV; + + while (colCnt) + { + q31_t inV1, inV2, inM11, inM12; + + pB = (q7_t *) read_and_pad((void *)pB, &inM11, &inM12); + + inV1 = *__SIMD32(pA)++; + sum = __SMLAD(inV1, inM11, sum); + + inV2 = *__SIMD32(pA)++; + sum = __SMLAD(inV2, inM12, sum); + + colCnt--; + } + + /* left-over of the vector */ + colCnt = dim_vec & 0x3; + while (colCnt) + { + q15_t inV = *pA++; + q7_t inM = *pB++; + sum += inV * inM; + colCnt--; + } + + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + + rowCnt--; + } + +#else + int i, j; + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + for (i = 0; i < num_of_rows; i++) + { + int ip_out = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + for (j = 0; j < dim_vec; j++) + { + ip_out += pV[j] * pM[i * dim_vec + j]; + } + pOut[i] = (q15_t) __SSAT((ip_out >> out_shift), 16); + } + +#endif /* ARM_MATH_DSP */ + + /* Return to ARM_MATH_SUCCESS */ + return (ARM_MATH_SUCCESS); + +} + +/** + * @} end of FC group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15_opt.c b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15_opt.c new file mode 100644 index 0000000..b0c308b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_mat_q7_vec_q15_opt.c @@ -0,0 +1,403 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_fully_connected_mat_q7_vec_q15_opt.c + * Description: Mixed Q15-Q7 opt fully-connected layer function + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup FC + * @{ + */ + + /** + * @brief Mixed Q15-Q7 opt fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + * @details + * + * Buffer size: + * + * vec_buffer size: 0 + * + * Q7_Q15 version of the fully connected layer + * + * Weights are in q7_t and Activations are in q15_t + * + * Limitation: x4 version requires weight reordering to work + * + * Here we use only one pointer to read 4 rows in the weight + * matrix. So if the original q7_t matrix looks like this: + * + * | a11 | a12 | a13 | a14 | a15 | a16 | a17 | + * + * | a21 | a22 | a23 | a24 | a25 | a26 | a27 | + * + * | a31 | a32 | a33 | a34 | a35 | a36 | a37 | + * + * | a41 | a42 | a43 | a44 | a45 | a46 | a47 | + * + * | a51 | a52 | a53 | a54 | a55 | a56 | a57 | + * + * | a61 | a62 | a63 | a64 | a65 | a66 | a67 | + * + * We operates on multiple-of-4 rows, so the first four rows becomes + * + * | a11 | a21 | a12 | a22 | a31 | a41 | a32 | a42 | + * + * | a13 | a23 | a14 | a24 | a33 | a43 | a34 | a44 | + * + * | a15 | a25 | a16 | a26 | a35 | a45 | a36 | a46 | + * + * The column left over will be in-order. + * which is: + * | a17 | a27 | a37 | a47 | + * + * For the left-over rows, we do 1x1 computation, so the data remains + * as its original order. + * + * So the stored weight matrix looks like this: + * + * | a11 | a21 | a12 | a22 | a31 | a41 | + * + * | a32 | a42 | a13 | a23 | a14 | a24 | + * + * | a33 | a43 | a34 | a44 | a15 | a25 | + * + * | a16 | a26 | a35 | a45 | a36 | a46 | + * + * | a17 | a27 | a37 | a47 | a51 | a52 | + * + * | a53 | a54 | a55 | a56 | a57 | a61 | + * + * | a62 | a63 | a64 | a65 | a66 | a67 | + * + */ + +arm_status +arm_fully_connected_mat_q7_vec_q15_opt(const q15_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, const q7_t * bias, q15_t * pOut, q15_t * vec_buffer) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + const q7_t *pB = pM; + q15_t *pO = pOut; + const q7_t *pBias = bias; + const q15_t *pA = pV; + + uint16_t rowCnt = num_of_rows >> 2; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 1; + + pA = pV; + +#ifdef USE_INTRINSIC + +#ifndef ARM_MATH_BIG_ENDIAN + + while (colCnt) + { + q31_t inM11, inM12, inM13, inM14; + q31_t inV; + + inV = *__SIMD32(pA)++; + inM11 = *__SIMD32(pB)++; + inM12 = __SXTB16(__ROR(inM11, 8)); + inM11 = __SXTB16(inM11); + sum = __SMLAD(inM11, inV, sum); + sum2 = __SMLAD(inM12, inV, sum2); + inM13 = *__SIMD32(pB)++; + inM14 = __SXTB16(__ROR(inM13, 8)); + inM13 = __SXTB16(inM13); + sum3 = __SMLAD(inM13, inV, sum3); + sum4 = __SMLAD(inM14, inV, sum4); + colCnt--; + } + +#else + + while (colCnt) + { + q31_t inM11, inM12, inM13, inM14; + q31_t inV; + + inV = *__SIMD32(pA)++; + inM11 = *__SIMD32(pB)++; + inM12 = __SXTB16(__ROR(inM11, 8)); + inM11 = __SXTB16(inM11); + sum = __SMLAD(inM12, inV, sum); + sum2 = __SMLAD(inM11, inV, sum2); + inM13 = *__SIMD32(pB)++; + inM14 = __SXTB16(__ROR(inM13, 8)); + inM13 = __SXTB16(inM13); + sum3 = __SMLAD(inM14, inV, sum3); + sum4 = __SMLAD(inM13, inV, sum4); + colCnt--; + } + +#endif /* ARM_MATH_BIG_ENDIAN */ + +#else + + /* + * register needed: + * loop counter: colCnt + * accumulators: sum, sum2, sum3, sum4 + * pointers: pB, pA + * weight data: inM11, inM12, inM13, inM14 + * activation data: inV + */ + +#ifndef ARM_MATH_BIG_ENDIAN + asm volatile ("COL_LOOP_%=:\n" + "ldr.w r4, [%[pA]], #4\n" + "ldr.w r1, [%[pB]], #8\n" + "mov.w r0, r1, ror #8\n" + "sxtb16 r0, r0\n" + "sxtb16 r1, r1\n" + "smlad %[sum], r4, r1, %[sum]\n" + "smlad %[sum2], r4, r0, %[sum2]\n" + "ldr.w r3, [%[pB], #-4]\n" + "mov.w r2, r3, ror #8\n" + "sxtb16 r2, r2\n" + "sxtb16 r3, r3\n" + "smlad %[sum3], r4, r3, %[sum3]\n" + "smlad %[sum4], r4, r2, %[sum4]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP_%=\n":[sum] "+r"(sum), + [sum2] "+r"(sum2),[sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB),[pA] "+r"(pA):[colCnt] "r"(colCnt):"r0", "r1", "r2", "r3", "r4"); +#else + asm volatile ("COL_LOOP_%=:\n" + "ldr.w r4, [%[pA]], #4\n" + "ldr.w r1, [%[pB]], #8\n" + "mov.w r0, r1, ror #8\n" + "sxtb16 r0, r0\n" + "sxtb16 r1, r1\n" + "smlad %[sum], r4, r0, %[sum]\n" + "smlad %[sum2], r4, r1, %[sum2]\n" + "ldr.w r3, [%[pB], #-4]\n" + "mov.w r2, r3, ror #8\n" + "sxtb16 r2, r2\n" + "sxtb16 r3, r3\n" + "smlad %[sum3], r4, r2, %[sum3]\n" + "smlad %[sum4], r4, r3, %[sum4]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP_%=\n":[sum] "+r"(sum), + [sum2] "+r"(sum2),[sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB),[pA] "+r"(pA):[colCnt] "r"(colCnt):"r0", "r1", "r2", "r3", "r4"); +#endif /* ARM_MATH_BIG_ENDIAN */ + +#endif /* USE_INTRINSIC */ + + colCnt = dim_vec & 0x1; + while (colCnt) + { + q15_t inV = *pA++; + q7_t inM = *pB++; + q7_t inM2 = *pB++; + q7_t inM3 = *pB++; + q7_t inM4 = *pB++; + + sum += inV * inM; + sum2 += inV * inM2; + sum3 += inV * inM3; + sum4 += inV * inM4; + colCnt--; + } /* while over colCnt */ + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum2 >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum3 >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum4 >> out_shift), 16)); + + /* adjust the pointers and counters */ + rowCnt--; + } + + /* left-over part of the rows */ + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 2; + + pA = pV; + + while (colCnt) + { + q31_t inV1, inV2, inM11, inM12; + + pB = (q7_t *) read_and_pad((void *)pB, &inM11, &inM12); + + inV1 = *__SIMD32(pA)++; + sum = __SMLAD(inV1, inM11, sum); + + inV2 = *__SIMD32(pA)++; + sum = __SMLAD(inV2, inM12, sum); + + colCnt--; + } + + /* left-over of the vector */ + colCnt = dim_vec & 0x3; + while (colCnt) + { + q15_t inV = *pA++; + q7_t inM = *pB++; + sum += inV * inM; + colCnt--; + } + + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + + rowCnt--; + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + uint16_t rowCnt = num_of_rows >> 2; + const q7_t *pB = pM; + const q15_t *pA; + q15_t *pO = pOut; + const q7_t *pBias = bias; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + uint16_t colCnt = dim_vec >> 1; + + pA = pV; + + while (colCnt) + { + q15_t inA1 = *pA++; + q15_t inA2 = *pA++; + + q7_t inB1 = *pB++; + q7_t inB3 = *pB++; + q7_t inB2 = *pB++; + q7_t inB4 = *pB++; + + sum += inA1 * inB1 + inA2 * inB2; + sum2 += inA1 * inB3 + inA2 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum3 += inA1 * inB1 + inA2 * inB2; + sum4 += inA1 * inB3 + inA2 * inB4; + + colCnt--; + } + + colCnt = dim_vec & 0x1; + while (colCnt) + { + q15_t inA = *pA++; + q7_t inB = *pB++; + sum += inA * inB; + inB = *pB++; + sum2 += inA * inB; + inB = *pB++; + sum3 += inA * inB; + inB = *pB++; + sum4 += inA * inB; + + colCnt--; + } + *pO++ = (q15_t) __SSAT((sum >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum2 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum3 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum4 >> out_shift), 16); + + rowCnt--; + } + + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + int ip_out = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + int j; + + pA = pV; + for (j = 0; j < dim_vec; j++) + { + q15_t inA = *pA++; + q7_t inB = *pB++; + ip_out += inA * inB; + } + *pO++ = (q15_t) __SSAT((ip_out >> out_shift), 16); + + rowCnt--; + } + +#endif /* ARM_MATH_DSP */ + + /* Return to ARM_MATH_SUCCESS */ + return (ARM_MATH_SUCCESS); + +} + +/** + * @} end of FC group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15.c b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15.c new file mode 100644 index 0000000..a4c6bba --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15.c @@ -0,0 +1,193 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_fully_connected_q15.c + * Description: Q15 basic fully-connected layer function + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup FC + * @{ + */ + + /** + * @brief Q15 opt fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + * + * @details + * + * Buffer size: + * + * vec_buffer size: 0 + * + */ + +arm_status +arm_fully_connected_q15(const q15_t * pV, + const q15_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q15_t * bias, + q15_t * pOut, + q15_t * vec_buffer) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + const q15_t *pB = pM; + const q15_t *pB2 = pB + dim_vec; + q15_t *pO = pOut; + const q15_t *pA; + const q15_t *pBias = bias; + uint16_t rowCnt = num_of_rows >> 1; + + /* this loop loops over different output */ + while (rowCnt) { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 2; + + pA = pV; + pB2 = pB + dim_vec; + + while (colCnt) + { + q31_t inV1, inM1, inM2; + inV1 = *__SIMD32(pA)++; + inM1 = *__SIMD32(pB)++; + sum = __SMLAD(inV1, inM1, sum); + inM2 = *__SIMD32(pB2)++; + sum2 = __SMLAD(inV1, inM2, sum2); + + inV1 = *__SIMD32(pA)++; + inM1 = *__SIMD32(pB)++; + sum = __SMLAD(inV1, inM1, sum); + inM2 = *__SIMD32(pB2)++; + sum2 = __SMLAD(inV1, inM2, sum2); + + colCnt--; + } + colCnt = dim_vec & 0x3; + while (colCnt) + { + q15_t inV = *pA++; + q15_t inM = *pB++; + q15_t inM2 = *pB2++; + + sum += inV * inM; + sum2 += inV * inM2; + colCnt--; + } /* while over colCnt */ + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum2>> out_shift), 16)); + + /* adjust the pointers and counters */ + pB = pB + dim_vec; + rowCnt --; + } + + rowCnt = num_of_rows & 0x1; + + while (rowCnt) { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 2; + + pA = pV; + + while (colCnt) { + q31_t inV1, inM1; + inV1 = *__SIMD32(pA)++; + inM1 = *__SIMD32(pB)++; + sum = __SMLAD(inV1, inM1, sum); + + inV1 = *__SIMD32(pA)++; + inM1 = *__SIMD32(pB)++; + sum = __SMLAD(inV1, inM1, sum); + + colCnt--; + } + + /* left-over of the vector */ + colCnt = dim_vec & 0x3; + while(colCnt) { + q15_t inV = *pA++; + q15_t inM = *pB++; + + sum += inV * inM; + + colCnt--; + } + + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + + rowCnt --; + } + +#else + int i, j; + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + for (i = 0; i < num_of_rows; i++) + { + int ip_out = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + for (j = 0; j < dim_vec; j++) + { + ip_out += pV[j] * pM[i * dim_vec + j]; + } + pOut[i] = (q15_t) __SSAT((ip_out >> out_shift), 16); + } + +#endif /* ARM_MATH_DSP */ + + /* Return to application */ + return (ARM_MATH_SUCCESS); + +} + +/** + * @} end of FC group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15_opt.c b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15_opt.c new file mode 100644 index 0000000..8f3bbea --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q15_opt.c @@ -0,0 +1,332 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_fully_connected_q15_opt.c + * Description: Q15 opt fully-connected layer function + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup FC + * @{ + */ + + /** + * @brief Q15 opt fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + * + * @details + * + * Buffer size: + * + * vec_buffer size: 0 + * + * Here we use only one pointer to read 4 rows in the weight + * matrix. So if the original matrix looks like this: + * + * | a11 | a12 | a13 | + * + * | a21 | a22 | a23 | + * + * | a31 | a32 | a33 | + * + * | a41 | a42 | a43 | + * + * | a51 | a52 | a53 | + * + * | a61 | a62 | a63 | + * + * We operates on multiple-of-4 rows, so the first four rows becomes + * + * | a11 | a12 | a21 | a22 | a31 | a32 | a41 | a42 | + * + * | a13 | a23 | a33 | a43 | + * + * Remaining rows are kept the same original order. + * + * So the stored weight matrix looks like this: + * + * + * | a11 | a12 | a21 | a22 | a31 | a32 | a41 | a42 | + * + * | a13 | a23 | a33 | a43 | a51 | a52 | a53 | a61 | + * + * | a62 | a63 | + */ + +arm_status +arm_fully_connected_q15_opt(const q15_t * pV, + const q15_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q15_t * bias, + q15_t * pOut, + q15_t * vec_buffer) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + const q15_t *pB = pM; + q15_t *pO = pOut; + const q15_t *pBias = bias; + const q15_t *pA = pV; + + uint16_t rowCnt = num_of_rows >> 2; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 1; + + pA = pV; + +#ifdef USE_INTRINSIC + + while (colCnt) + { + q31_t inM11, inM12, inM13, inM14; + q31_t inV; + + inV = *__SIMD32(pA)++; + inM11 = *__SIMD32(pB)++; + sum = __SMLAD(inV, inM11, sum); + inM12 = *__SIMD32(pB)++; + sum2 = __SMLAD(inV, inM12, sum2); + inM13 = *__SIMD32(pB)++; + sum3 = __SMLAD(inV, inM13, sum3); + inM14 = *__SIMD32(pB)++; + sum4 = __SMLAD(inV, inM14, sum4); + colCnt--; + } + +#else + + /* + * register needed: + * loop counter: colCnt + * accumulators: sum, sum2, sum3, sum4 + * pointers: pB, pA + * weight data: inM11, inM12, inM13, inM14 + * activation data: inV + */ + + asm volatile ("COL_LOOP_%=:\n" + "ldr.w r4, [%[pA]], #4\n" + "ldr.w r0, [%[pB]], #16\n" + "smlad %[sum], r4, r0, %[sum]\n" + "ldr.w r1, [%[pB] , #-12]\n" + "smlad %[sum2], r4, r1, %[sum2]\n" + "ldr.w r2, [%[pB] , #-8]\n" + "smlad %[sum3], r4, r2, %[sum3]\n" + "ldr.w r3, [%[pB] , #-4]\n" + "smlad %[sum4], r4, r3, %[sum4]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP_%=\n":[sum] "+r"(sum), + [sum2] "+r"(sum2),[sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB),[pA] "+r"(pA):[colCnt] "r"(colCnt):"r0", "r1", "r2", "r3", "r4"); + +#endif /* USE_INTRINSIC */ + + colCnt = dim_vec & 0x1; + while (colCnt) + { + + q15_t inV = *pA++; + q15_t inM = *pB++; + q15_t inM2 = *pB++; + q15_t inM3 = *pB++; + q15_t inM4 = *pB++; + + sum += inV * inM; + sum2 += inV * inM2; + sum3 += inV * inM3; + sum4 += inV * inM4; + colCnt--; + } /* while over colCnt */ + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum2 >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum3 >> out_shift), 16)); + *pO++ = (q15_t) (__SSAT((sum4 >> out_shift), 16)); + + /* adjust the pointers and counters */ + rowCnt--; + } + + /* left-over part of the rows */ + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 2; + + pA = pV; + + while (colCnt) + { + q31_t inV1, inV2, inM1, inM2; + + inM1 = *__SIMD32(pB)++; + inV1 = *__SIMD32(pA)++; + sum = __SMLAD(inV1, inM1, sum); + + inM2 = *__SIMD32(pB)++; + inV2 = *__SIMD32(pA)++; + sum = __SMLAD(inV2, inM2, sum); + + colCnt--; + } + + /* left-over of the vector */ + colCnt = dim_vec & 0x3; + while (colCnt) + { + q15_t inV = *pA++; + q15_t inM = *pB++; + sum += inV * inM; + colCnt--; + } + + *pO++ = (q15_t) (__SSAT((sum >> out_shift), 16)); + + rowCnt--; + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + uint16_t rowCnt = num_of_rows >> 2; + const q15_t *pB = pM; + const q15_t *pA; + q15_t *pO = pOut; + const q15_t *pBias = bias; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 1; + + pA = pV; + while (colCnt) + { + q15_t inA1 = *pA++; + q15_t inA2 = *pA++; + + q15_t inB1 = *pB++; + q15_t inB2 = *pB++; + sum += inA1 * inB1 + inA2 * inB2; + + inB1 = *pB++; + inB2 = *pB++; + sum2 += inA1 * inB1 + inA2 * inB2; + + inB1 = *pB++; + inB2 = *pB++; + sum3 += inA1 * inB1 + inA2 * inB2; + + inB1 = *pB++; + inB2 = *pB++; + sum4 += inA1 * inB1 + inA2 * inB2; + + colCnt--; + } + colCnt = dim_vec & 0x1; + while (colCnt) + { + q15_t inA = *pA++; + q15_t inB = *pB++; + sum += inA * inB; + inB = *pB++; + sum2 += inA * inB; + inB = *pB++; + sum3 += inA * inB; + inB = *pB++; + sum4 += inA * inB; + colCnt--; + } + *pO++ = (q15_t) __SSAT((sum >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum2 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum3 >> out_shift), 16); + *pO++ = (q15_t) __SSAT((sum4 >> out_shift), 16); + + rowCnt--; + } + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + int ip_out = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + int j; + + pA = pV; + for (j = 0; j < dim_vec; j++) + { + q15_t inA = *pA++; + q15_t inB = *pB++; + ip_out += inA * inB; + } + *pO++ = (q15_t) __SSAT((ip_out >> out_shift), 16); + + rowCnt--; + } + +#endif /* ARM_MATH_DSP */ + + /* Return to ARM_MATH_SUCCESS */ + return (ARM_MATH_SUCCESS); + +} + +/** + * @} end of FC group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7.c b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7.c new file mode 100644 index 0000000..75e924f --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7.c @@ -0,0 +1,198 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_fully_connected_q7.c + * Description: Q7 basic fully-connected layer function + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup FC + * @{ + */ + + /** + * @brief Q7 basic fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + * @details + * + * Buffer size: + * + * vec_buffer size: dim_vec + * + * This basic function is designed to work with regular weight + * matrix without interleaving. + * + */ + +arm_status +arm_fully_connected_q7(const q7_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, const q7_t * bias, q7_t * pOut, q15_t * vec_buffer) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + const q7_t *pB = pM; + const q7_t *pB2; + q7_t *pO = pOut; + const q7_t *pBias = bias; + q15_t *pA; + uint16_t rowCnt = num_of_rows >> 1; + + /* expand the vector into the buffer */ + arm_q7_to_q15_reordered_no_shift(pV, vec_buffer, dim_vec); + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + uint16_t colCnt = dim_vec >> 2; + + pA = vec_buffer; + pB2 = pB + dim_vec; + + while (colCnt) + { + q31_t inV, inM11, inM12, inM21, inM22; + pB = (q7_t *) read_and_pad_reordered((void *)pB, &inM11, &inM12); + pB2 = (q7_t *) read_and_pad_reordered((void *)pB2, &inM21, &inM22); + + inV = *__SIMD32(pA)++; + + sum = __SMLAD(inV, inM11, sum); + sum2 = __SMLAD(inV, inM21, sum2); + + inV = *__SIMD32(pA)++; + + sum = __SMLAD(inV, inM12, sum); + sum2 = __SMLAD(inV, inM22, sum2); + + colCnt--; + } + colCnt = dim_vec & 0x3; + while (colCnt) + { + q7_t inV = *pA++; + q15_t inM = *pB++; + q15_t inM2 = *pB2++; + + sum += inV * inM; + sum2 += inV * inM2; + colCnt--; + } /* while over colCnt */ + *pO++ = (q7_t) (__SSAT((sum >> out_shift), 8)); + *pO++ = (q7_t) (__SSAT((sum2 >> out_shift), 8)); + + /* adjust the pointers and counters */ + pB += dim_vec; + rowCnt--; + } + + /* left-over part of the rows */ + rowCnt = num_of_rows & 0x1; + + while (rowCnt) + { + uint16_t colCnt = dim_vec >> 2; + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + pA = vec_buffer; + + while (colCnt) + { + q31_t inV1, inV2, inM11, inM12; + + pB = (q7_t *) read_and_pad_reordered((void *)pB, &inM11, &inM12); + + inV1 = *__SIMD32(pA)++; + sum = __SMLAD(inV1, inM11, sum); + + inV2 = *__SIMD32(pA)++; + sum = __SMLAD(inV2, inM12, sum); + + colCnt--; + } + + /* left-over of the vector */ + colCnt = dim_vec & 0x3; + while (colCnt) + { + q7_t inV = *pA++; + q15_t inM = *pB++; + sum += inV * inM; + colCnt--; + } + + *pO++ = (q7_t) (__SSAT((sum >> out_shift), 8)); + + rowCnt--; + } + +#else + int i, j; + + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + for (i = 0; i < num_of_rows; i++) + { + int ip_out = ((q31_t)(bias[i]) << bias_shift) + NN_ROUND(out_shift); + for (j = 0; j < dim_vec; j++) + { + ip_out += pV[j] * pM[i * dim_vec + j]; + } + pOut[i] = (q7_t) __SSAT((ip_out >> out_shift), 8); + } + +#endif /* ARM_MATH_DSP */ + + /* Return to ARM_MATH_SUCCESS */ + return (ARM_MATH_SUCCESS); + +} + +/** + * @} end of FC group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7_opt.c b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7_opt.c new file mode 100644 index 0000000..d197adc --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/FullyConnectedFunctions/arm_fully_connected_q7_opt.c @@ -0,0 +1,484 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_fully_connected_q7_opt.c + * Description: Q7 basic fully-connected layer function + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup FC + * @{ + */ + + /** + * @brief Q7 opt fully-connected layer function + * @param[in] pV pointer to input vector + * @param[in] pM pointer to matrix weights + * @param[in] dim_vec length of the vector + * @param[in] num_of_rows number of rows in weight matrix + * @param[in] bias_shift amount of left-shift for bias + * @param[in] out_shift amount of right-shift for output + * @param[in] bias pointer to bias + * @param[in,out] pOut pointer to output vector + * @param[in,out] vec_buffer pointer to buffer space for input + * @return The function returns ARM_MATH_SUCCESS + * + * @details + * + * Buffer size: + * + * vec_buffer size: dim_vec + * + * This opt function is designed to work with interleaved weight + * matrix. The vector input is assumed in q7_t format, we call + * arm_q7_to_q15_no_shift_shuffle function to expand into + * q15_t format with certain weight re-ordering, refer to the function + * comments for more details. + * Here we use only one pointer to read 4 rows in the weight + * matrix. So if the original q7_t matrix looks like this: + * + * | a11 | a12 | a13 | a14 | a15 | a16 | a17 | + * + * | a21 | a22 | a23 | a24 | a25 | a26 | a27 | + * + * | a31 | a32 | a33 | a34 | a35 | a36 | a37 | + * + * | a41 | a42 | a43 | a44 | a45 | a46 | a47 | + * + * | a51 | a52 | a53 | a54 | a55 | a56 | a57 | + * + * | a61 | a62 | a63 | a64 | a65 | a66 | a67 | + * + * + * We operates on multiple-of-4 rows, so the first four rows becomes + * + * | a11 | a21 | a13 | a23 | a31 | a41 | a33 | a43 | + * + * | a12 | a22 | a14 | a24 | a32 | a42 | a34 | a44 | + * + * | a15 | a25 | a35 | a45 | a16 | a26 | a36 | a46 | + * + * So within the kernel, we first read the re-ordered vector in as: + * + * | b1 | b3 | and | b2 | b4 | + * + * the four q31_t weights will look like + * + * | a11 | a13 |, | a21 | a23 |, | a31 | a33 |, | a41 | a43 | + * + * | a12 | a14 |, | a22 | a24 |, | a32 | a34 |, | a42 | a44 | + * + * The column left over will be in-order. + * which is: + * + * | a17 | a27 | a37 | a47 | + * + * For the left-over rows, we do 1x1 computation, so the data remains + * as its original order. + * + * So the stored weight matrix looks like this: + * + * | a11 | a21 | a13 | a23 | a31 | a41 | + * + * | a33 | a43 | a12 | a22 | a14 | a24 | + * + * | a32 | a42 | a34 | a44 | a15 | a25 | + * + * | a35 | a45 | a16 | a26 | a36 | a46 | + * + * | a17 | a27 | a37 | a47 | a51 | a52 | + * + * | a53 | a54 | a55 | a56 | a57 | a61 | + * + * | a62 | a63 | a64 | a65 | a66 | a67 | + * + * + */ + +arm_status +arm_fully_connected_q7_opt(const q7_t * pV, + const q7_t * pM, + const uint16_t dim_vec, + const uint16_t num_of_rows, + const uint16_t bias_shift, + const uint16_t out_shift, + const q7_t * bias, + q7_t * pOut, + q15_t * vec_buffer) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + const q7_t *pB = pM; + q7_t *pO = pOut; + const q7_t *pBias = bias; + q15_t *pA; + uint16_t rowCnt = num_of_rows >> 2; + + arm_q7_to_q15_reordered_no_shift(pV, vec_buffer, dim_vec); + + while (rowCnt) + { + + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 2; + + pA = vec_buffer; + +#ifdef USE_INTRINSIC + +#ifndef ARM_MATH_BIG_ENDIAN + while (colCnt) + { + q31_t inM11, inM12, inM13, inM14; + q31_t inV; + + inV = *__SIMD32(pA)++; + inM11 = *__SIMD32(pB)++; + inM12 = __SXTB16(__ROR(inM11, 8)); + inM11 = __SXTB16(inM11); + sum = __SMLAD(inM11, inV, sum); + sum2 = __SMLAD(inM12, inV, sum2); + inM13 = *__SIMD32(pB)++; + inM14 = __SXTB16(__ROR(inM13, 8)); + inM13 = __SXTB16(inM13); + sum3 = __SMLAD(inM13, inV, sum3); + sum4 = __SMLAD(inM14, inV, sum4); + + inV = *__SIMD32(pA)++; + inM11 = *__SIMD32(pB)++; + inM12 = __SXTB16(__ROR(inM11, 8)); + inM11 = __SXTB16(inM11); + sum = __SMLAD(inM11, inV, sum); + sum2 = __SMLAD(inM12, inV, sum2); + inM13 = *__SIMD32(pB)++; + inM14 = __SXTB16(__ROR(inM13, 8)); + inM13 = __SXTB16(inM13); + sum3 = __SMLAD(inM13, inV, sum3); + sum4 = __SMLAD(inM14, inV, sum4); + colCnt--; + } +#else + while (colCnt) + { + q31_t inM11, inM12, inM13, inM14; + q31_t inV; + + inV = *__SIMD32(pA)++; + inM11 = *__SIMD32(pB)++; + inM12 = __SXTB16(__ROR(inM11, 8)); + inM11 = __SXTB16(inM11); + sum = __SMLAD(inM12, inV, sum); + sum2 = __SMLAD(inM11, inV, sum2); + inM13 = *__SIMD32(pB)++; + inM14 = __SXTB16(__ROR(inM13, 8)); + inM13 = __SXTB16(inM13); + sum3 = __SMLAD(inM14, inV, sum3); + sum4 = __SMLAD(inM13, inV, sum4); + + inV = *__SIMD32(pA)++; + inM11 = *__SIMD32(pB)++; + inM12 = __SXTB16(__ROR(inM11, 8)); + inM11 = __SXTB16(inM11); + sum = __SMLAD(inM12, inV, sum); + sum2 = __SMLAD(inM11, inV, sum2); + inM13 = *__SIMD32(pB)++; + inM14 = __SXTB16(__ROR(inM13, 8)); + inM13 = __SXTB16(inM13); + sum3 = __SMLAD(inM14, inV, sum3); + sum4 = __SMLAD(inM13, inV, sum4); + colCnt--; + } +#endif /* ARM_MATH_BIG_ENDIAN */ + +#else + + /* + * register needed: + * loop counter: colCnt + * accumulators: sum, sum2, sum3, sum4 + * pointers: pB, pA + * weight data: inM11, inM12, inM13, inM14 + * activation data: inV + */ + +#ifndef ARM_MATH_BIG_ENDIAN + asm volatile ("COL_LOOP_%=:\n" + "ldr.w r4, [%[pA]], #8\n" + "ldr.w r1, [%[pB]], #16\n" + "mov.w r0, r1, ror #8\n" + "sxtb16 r0, r0\n" + "sxtb16 r1, r1\n" + "smlad %[sum], r4, r1, %[sum]\n" + "smlad %[sum2], r4, r0, %[sum2]\n" + "ldr.w r3, [%[pB], #-12]\n" + "mov.w r2, r3, ror #8\n" + "sxtb16 r2, r2\n" + "sxtb16 r3, r3\n" + "smlad %[sum3], r4, r3, %[sum3]\n" + "smlad %[sum4], r4, r2, %[sum4]\n" + "ldr.w r4, [%[pA], #-4]\n" + "ldr.w r1, [%[pB], #-8]\n" + "mov.w r0, r1, ror #8\n" + "sxtb16 r0, r0\n" + "sxtb16 r1, r1\n" + "smlad %[sum], r4, r1, %[sum]\n" + "smlad %[sum2], r4, r0, %[sum2]\n" + "ldr.w r3, [%[pB], #-4]\n" + "mov.w r2, r3, ror #8\n" + "sxtb16 r2, r2\n" + "sxtb16 r3, r3\n" + "smlad %[sum3], r4, r3, %[sum3]\n" + "smlad %[sum4], r4, r2, %[sum4]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP_%=\n":[sum] "+r"(sum), + [sum2] "+r"(sum2),[sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB),[pA] "+r"(pA):[colCnt] "r"(colCnt):"r0", "r1", "r2", "r3", "r4"); +#else + asm volatile ("COL_LOOP_%=:\n" + "ldr.w r4, [%[pA]], #8\n" + "ldr.w r1, [%[pB]], #16\n" + "mov.w r0, r1, ror #8\n" + "sxtb16 r0, r0\n" + "sxtb16 r1, r1\n" + "smlad %[sum], r4, r0, %[sum]\n" + "smlad %[sum2], r4, r1, %[sum2]\n" + "ldr.w r3, [%[pB], #-12]\n" + "mov.w r2, r3, ror #8\n" + "sxtb16 r2, r2\n" + "sxtb16 r3, r3\n" + "smlad %[sum3], r4, r2, %[sum3]\n" + "smlad %[sum4], r4, r3, %[sum4]\n" + "ldr.w r4, [%[pA], #-4]\n" + "ldr.w r1, [%[pB], #-8]\n" + "mov.w r0, r1, ror #8\n" + "sxtb16 r0, r0\n" + "sxtb16 r1, r1\n" + "smlad %[sum], r4, r0, %[sum]\n" + "smlad %[sum2], r4, r1, %[sum2]\n" + "ldr.w r3, [%[pB], #-4]\n" + "mov.w r2, r3, ror #8\n" + "sxtb16 r2, r2\n" + "sxtb16 r3, r3\n" + "smlad %[sum3], r4, r2, %[sum3]\n" + "smlad %[sum4], r4, r3, %[sum4]\n" + "subs %[colCnt], #1\n" + "bne COL_LOOP_%=\n":[sum] "+r"(sum), + [sum2] "+r"(sum2),[sum3] "+r"(sum3), + [sum4] "+r"(sum4),[pB] "+r"(pB),[pA] "+r"(pA):[colCnt] "r"(colCnt):"r0", "r1", "r2", "r3", "r4"); +#endif /* ARM_MATH_BIG_ENDIAN */ + +#endif /* USE_INTRINSIC */ + + colCnt = dim_vec & 0x3; + while (colCnt) + { + q15_t inV = *pA++; + q7_t inM = *pB++; + q7_t inM2 = *pB++; + q7_t inM3 = *pB++; + q7_t inM4 = *pB++; + + sum += inV * inM; + sum2 += inV * inM2; + sum3 += inV * inM3; + sum4 += inV * inM4; + colCnt--; + } /* while over colCnt */ + *pO++ = (q7_t) (__SSAT((sum >> out_shift), 8)); + *pO++ = (q7_t) (__SSAT((sum2 >> out_shift), 8)); + *pO++ = (q7_t) (__SSAT((sum3 >> out_shift), 8)); + *pO++ = (q7_t) (__SSAT((sum4 >> out_shift), 8)); + + /* adjust the pointers and counters */ + rowCnt--; + } + + /* left-over part of the rows */ + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + uint16_t colCnt = dim_vec >> 2; + + pA = vec_buffer; + + while (colCnt) + { + q31_t inV1, inV2, inM11, inM12; + + pB = (q7_t *) read_and_pad_reordered((void *)pB, &inM11, &inM12); + + inV1 = *__SIMD32(pA)++; + sum = __SMLAD(inV1, inM11, sum); + + inV2 = *__SIMD32(pA)++; + sum = __SMLAD(inV2, inM12, sum); + + colCnt--; + } + + /* left-over of the vector */ + colCnt = dim_vec & 0x3; + while (colCnt) + { + q15_t inV = *pA++; + q7_t inM = *pB++; + sum += inV * inM; + colCnt--; + } + + *pO++ = (q7_t) (__SSAT((sum >> out_shift), 8)); + + rowCnt--; + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + uint16_t rowCnt = num_of_rows >> 2; + const q7_t *pB = pM; + const q7_t *pA; + q7_t *pO = pOut; + const q7_t *pBias = bias; + + while (rowCnt) + { + q31_t sum = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum2 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum3 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + q31_t sum4 = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + uint16_t colCnt = dim_vec >> 2; + + pA = pV; + + while (colCnt) + { + q7_t inA1 = *pA++; + q7_t inA3 = *pA++; + q7_t inA2 = *pA++; + q7_t inA4 = *pA++; + + q7_t inB1 = *pB++; + q7_t inB3 = *pB++; + q7_t inB2 = *pB++; + q7_t inB4 = *pB++; + + sum += inA1 * inB1 + inA2 * inB2; + sum2 += inA1 * inB3 + inA2 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum3 += inA1 * inB1 + inA2 * inB2; + sum4 += inA1 * inB3 + inA2 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum += inA3 * inB1 + inA4 * inB2; + sum2 += inA3 * inB3 + inA4 * inB4; + + inB1 = *pB++; + inB3 = *pB++; + inB2 = *pB++; + inB4 = *pB++; + + sum3 += inA3 * inB1 + inA4 * inB2; + sum4 += inA3 * inB3 + inA4 * inB4; + + colCnt--; + } + colCnt = dim_vec & 0x3; + while (colCnt) + { + q7_t inA = *pA++; + q7_t inB = *pB++; + sum += inA * inB; + inB = *pB++; + sum2 += inA * inB; + inB = *pB++; + sum3 += inA * inB; + inB = *pB++; + sum4 += inA * inB; + + colCnt--; + } + *pO++ = (q7_t) __SSAT((sum >> out_shift), 8); + *pO++ = (q7_t) __SSAT((sum2 >> out_shift), 8); + *pO++ = (q7_t) __SSAT((sum3 >> out_shift), 8); + *pO++ = (q7_t) __SSAT((sum4 >> out_shift), 8); + + rowCnt--; + } + + rowCnt = num_of_rows & 0x3; + + while (rowCnt) + { + int ip_out = ((q31_t)(*pBias++) << bias_shift) + NN_ROUND(out_shift); + + int j; + + pA = pV; + for (j = 0; j < dim_vec; j++) + { + q7_t inA = *pA++; + q7_t inB = *pB++; + ip_out += inA * inB; + } + *pO++ = (q7_t) __SSAT((ip_out >> out_shift), 8); + + rowCnt--; + } + +#endif /* ARM_MATH_DSP */ + + /* Return to ARM_MATH_SUCCESS */ + return (ARM_MATH_SUCCESS); + +} + +/** + * @} end of FC group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q15.c b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q15.c new file mode 100644 index 0000000..de7668b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q15.c @@ -0,0 +1,147 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nn_mult_q15.c + * Description: Q15 vector multiplication with variable output shifts + * + * $Date: 13. July 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_nnfunctions.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup NNBasicMath + * @{ + */ + + +/** + * @brief Q7 vector multiplication with variable output shifts + * @param[in] *pSrcA pointer to the first input vector + * @param[in] *pSrcB pointer to the second input vector + * @param[out] *pDst pointer to the output vector + * @param[in] out_shift amount of right-shift for output + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q15 range [0x8000 0x7FFF] will be saturated. + */ + +void arm_nn_mult_q15( + q15_t * pSrcA, + q15_t * pSrcB, + q15_t * pDst, + const uint16_t out_shift, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counters */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q31_t inA1, inA2, inB1, inB2; /* temporary input variables */ + q15_t out1, out2, out3, out4; /* temporary output variables */ + q31_t mul1, mul2, mul3, mul4; /* temporary variables */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* read two samples at a time from sourceA */ + inA1 = *__SIMD32(pSrcA)++; + /* read two samples at a time from sourceB */ + inB1 = *__SIMD32(pSrcB)++; + /* read two samples at a time from sourceA */ + inA2 = *__SIMD32(pSrcA)++; + /* read two samples at a time from sourceB */ + inB2 = *__SIMD32(pSrcB)++; + + /* multiply mul = sourceA * sourceB */ + mul1 = (q31_t) ((q15_t) (inA1 >> 16) * (q15_t) (inB1 >> 16)); + mul2 = (q31_t) ((q15_t) inA1 * (q15_t) inB1); + mul3 = (q31_t) ((q15_t) (inA2 >> 16) * (q15_t) (inB2 >> 16)); + mul4 = (q31_t) ((q15_t) inA2 * (q15_t) inB2); + + /* saturate result to 16 bit */ + out1 = (q15_t) __SSAT((mul1 + NN_ROUND(out_shift)) >> out_shift, 16); + out2 = (q15_t) __SSAT((mul2 + NN_ROUND(out_shift)) >> out_shift, 16); + out3 = (q15_t) __SSAT((mul3 + NN_ROUND(out_shift)) >> out_shift, 16); + out4 = (q15_t) __SSAT((mul4 + NN_ROUND(out_shift)) >> out_shift, 16); + + /* store the result */ +#ifndef ARM_MATH_BIG_ENDIAN + + *__SIMD32(pDst)++ = __PKHBT(out2, out1, 16); + *__SIMD32(pDst)++ = __PKHBT(out4, out3, 16); + +#else + + *__SIMD32(pDst)++ = __PKHBT(out2, out1, 16); + *__SIMD32(pDst)++ = __PKHBT(out4, out3, 16); + +#endif /* #ifndef ARM_MATH_BIG_ENDIAN */ + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the result in the destination buffer */ + *pDst++ = (q15_t) __SSAT((((q31_t) (*pSrcA++) * (*pSrcB++) + NN_ROUND(out_shift)) >> out_shift), 16); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } +} + +/** + * @} end of NNBasicMath group + */ + diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q7.c b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q7.c new file mode 100644 index 0000000..1b4e02c --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nn_mult_q7.c @@ -0,0 +1,119 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nn_mult_q7.c + * Description: Q7 vector multiplication with variable output shifts + * + * $Date: 13. July 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_nnfunctions.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup NNBasicMath + * @{ + */ + +/** + * @brief Q7 vector multiplication with variable output shifts + * @param[in] *pSrcA pointer to the first input vector + * @param[in] *pSrcB pointer to the second input vector + * @param[out] *pDst pointer to the output vector + * @param[in] out_shift amount of right-shift for output + * @param[in] blockSize number of samples in each vector + * @return none. + * + * Scaling and Overflow Behavior: + * \par + * The function uses saturating arithmetic. + * Results outside of the allowable Q7 range [0x80 0x7F] will be saturated. + */ + +void arm_nn_mult_q7( + q7_t * pSrcA, + q7_t * pSrcB, + q7_t * pDst, + const uint16_t out_shift, + uint32_t blockSize) +{ + uint32_t blkCnt; /* loop counters */ + +#if defined (ARM_MATH_DSP) + +/* Run the below code for Cortex-M4 and Cortex-M3 */ + q7_t out1, out2, out3, out4; /* Temporary variables to store the product */ + + /* loop Unrolling */ + blkCnt = blockSize >> 2U; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the results in temporary variables */ + out1 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++) + NN_ROUND(out_shift)) >> out_shift), 8); + out2 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++) + NN_ROUND(out_shift)) >> out_shift), 8); + out3 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++) + NN_ROUND(out_shift)) >> out_shift), 8); + out4 = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++) + NN_ROUND(out_shift)) >> out_shift), 8); + + /* Store the results of 4 inputs in the destination buffer in single cycle by packing */ + *__SIMD32(pDst)++ = __PACKq7(out1, out2, out3, out4); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4U; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Initialize blkCnt with number of samples */ + blkCnt = blockSize; + +#endif /* #if defined (ARM_MATH_DSP) */ + + + while (blkCnt > 0U) + { + /* C = A * B */ + /* Multiply the inputs and store the result in the destination buffer */ + *pDst++ = (q7_t) __SSAT((((q15_t) (*pSrcA++) * (*pSrcB++) + NN_ROUND(out_shift)) >> out_shift), 8); + + /* Decrement the blockSize loop counter */ + blkCnt--; + } +} + +/** + * @} end of NNBasicMath group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nntables.c b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nntables.c new file mode 100644 index 0000000..cabd9b1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_nntables.c @@ -0,0 +1,297 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_nntables.c + * Description: Converts the elements of the Q7 vector to Q15 vector without left-shift + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_nnsupportfunctions.h" + +/** + * @brief tables for various activation functions + * + * This file include the declaration of common tables. + * Most of them are used for activation functions + * + * Assumption: + * Unified table: input is 3.x format, i.e, range of [-8, 8) + * sigmoid(8) = 0.9996646498695336 + * tanh(8) = 0.9999997749296758 + * The accuracy here should be good enough + * + * 2-stage HL table: + * + * The entire input range is divided into two parts: + * + * Low range table: 0x000x xxxx or 0x111x xxxx + * table entry will be the binary number excluding the first + * two digits, i.e., 0x0x xxxx or 0x1x xxxx + * + * + * + * High range table 0x0010 0000 -- 0x0111 1111 + * 0x1000 0000 -- 0x1101 1111 + * + * For positive numbers, table entry will be + * 0x0010 0000 -- 0x0111 1111 minus 0x0010 0000 + * i.e., 0x0000 0000 - 0x0101 11111 + * + * same thing for the negative numbers, table entry will be + * 0x1000 0000 -- 0x1101 1111 minux 0x0010 0000 + * i.e., 0x0110 0000 - 0x1011 1111 + */ + +const q7_t sigmoidTable_q7[256] = { + 0x40, 0x42, 0x44, 0x46, 0x48, 0x4a, 0x4c, 0x4e, + 0x50, 0x52, 0x53, 0x55, 0x57, 0x59, 0x5a, 0x5c, + 0x5e, 0x5f, 0x61, 0x62, 0x63, 0x65, 0x66, 0x67, + 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f, 0x70, + 0x71, 0x72, 0x72, 0x73, 0x74, 0x74, 0x75, 0x76, + 0x76, 0x77, 0x77, 0x78, 0x78, 0x79, 0x79, 0x7a, + 0x7a, 0x7a, 0x7b, 0x7b, 0x7b, 0x7c, 0x7c, 0x7c, + 0x7c, 0x7c, 0x7d, 0x7d, 0x7d, 0x7d, 0x7d, 0x7e, + 0x7e, 0x7e, 0x7e, 0x7e, 0x7e, 0x7e, 0x7e, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, + 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, + 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, + 0x01, 0x01, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, + 0x02, 0x02, 0x03, 0x03, 0x03, 0x03, 0x03, 0x04, + 0x04, 0x04, 0x04, 0x04, 0x05, 0x05, 0x05, 0x06, + 0x06, 0x06, 0x07, 0x07, 0x08, 0x08, 0x09, 0x09, + 0x0a, 0x0a, 0x0b, 0x0c, 0x0c, 0x0d, 0x0e, 0x0e, + 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, + 0x17, 0x19, 0x1a, 0x1b, 0x1d, 0x1e, 0x1f, 0x21, + 0x22, 0x24, 0x26, 0x27, 0x29, 0x2b, 0x2d, 0x2e, + 0x30, 0x32, 0x34, 0x36, 0x38, 0x3a, 0x3c, 0x3e, +}; + +const q15_t sigmoidTable_q15[256] = { + 0x4000, 0x4200, 0x43ff, 0x45fc, 0x47f5, 0x49eb, 0x4bdc, 0x4dc8, + 0x4fad, 0x518a, 0x5360, 0x552c, 0x56ef, 0x58a8, 0x5a57, 0x5bfb, + 0x5d93, 0x5f20, 0x60a1, 0x6216, 0x637f, 0x64db, 0x662b, 0x676f, + 0x68a6, 0x69d2, 0x6af1, 0x6c05, 0x6d0d, 0x6e09, 0x6efb, 0x6fe2, + 0x70be, 0x7190, 0x7258, 0x7316, 0x73cc, 0x7478, 0x751b, 0x75b7, + 0x764a, 0x76d6, 0x775b, 0x77d8, 0x784f, 0x78c0, 0x792a, 0x798f, + 0x79ee, 0x7a48, 0x7a9d, 0x7aed, 0x7b39, 0x7b80, 0x7bc4, 0x7c03, + 0x7c3f, 0x7c78, 0x7cad, 0x7ce0, 0x7d0f, 0x7d3c, 0x7d66, 0x7d8d, + 0x7db3, 0x7dd6, 0x7df7, 0x7e16, 0x7e33, 0x7e4f, 0x7e69, 0x7e81, + 0x7e98, 0x7eae, 0x7ec2, 0x7ed5, 0x7ee7, 0x7ef8, 0x7f08, 0x7f17, + 0x7f25, 0x7f32, 0x7f3e, 0x7f4a, 0x7f55, 0x7f5f, 0x7f69, 0x7f72, + 0x7f7b, 0x7f83, 0x7f8a, 0x7f91, 0x7f98, 0x7f9e, 0x7fa4, 0x7faa, + 0x7faf, 0x7fb4, 0x7fb8, 0x7fbd, 0x7fc1, 0x7fc5, 0x7fc8, 0x7fcc, + 0x7fcf, 0x7fd2, 0x7fd5, 0x7fd7, 0x7fda, 0x7fdc, 0x7fde, 0x7fe0, + 0x7fe2, 0x7fe4, 0x7fe6, 0x7fe7, 0x7fe9, 0x7fea, 0x7feb, 0x7fed, + 0x7fee, 0x7fef, 0x7ff0, 0x7ff1, 0x7ff2, 0x7ff3, 0x7ff4, 0x7ff4, + 0x000b, 0x000c, 0x000c, 0x000d, 0x000e, 0x000f, 0x0010, 0x0011, + 0x0012, 0x0013, 0x0015, 0x0016, 0x0017, 0x0019, 0x001a, 0x001c, + 0x001e, 0x0020, 0x0022, 0x0024, 0x0026, 0x0029, 0x002b, 0x002e, + 0x0031, 0x0034, 0x0038, 0x003b, 0x003f, 0x0043, 0x0048, 0x004c, + 0x0051, 0x0056, 0x005c, 0x0062, 0x0068, 0x006f, 0x0076, 0x007d, + 0x0085, 0x008e, 0x0097, 0x00a1, 0x00ab, 0x00b6, 0x00c2, 0x00ce, + 0x00db, 0x00e9, 0x00f8, 0x0108, 0x0119, 0x012b, 0x013e, 0x0152, + 0x0168, 0x017f, 0x0197, 0x01b1, 0x01cd, 0x01ea, 0x0209, 0x022a, + 0x024d, 0x0273, 0x029a, 0x02c4, 0x02f1, 0x0320, 0x0353, 0x0388, + 0x03c1, 0x03fd, 0x043c, 0x0480, 0x04c7, 0x0513, 0x0563, 0x05b8, + 0x0612, 0x0671, 0x06d6, 0x0740, 0x07b1, 0x0828, 0x08a5, 0x092a, + 0x09b6, 0x0a49, 0x0ae5, 0x0b88, 0x0c34, 0x0cea, 0x0da8, 0x0e70, + 0x0f42, 0x101e, 0x1105, 0x11f7, 0x12f3, 0x13fb, 0x150f, 0x162e, + 0x175a, 0x1891, 0x19d5, 0x1b25, 0x1c81, 0x1dea, 0x1f5f, 0x20e0, + 0x226d, 0x2405, 0x25a9, 0x2758, 0x2911, 0x2ad4, 0x2ca0, 0x2e76, + 0x3053, 0x3238, 0x3424, 0x3615, 0x380b, 0x3a04, 0x3c01, 0x3e00, +}; + +const q15_t sigmoidLTable_q15[128] = { + 0x4000, 0x4100, 0x4200, 0x42ff, 0x43ff, 0x44fd, 0x45fc, 0x46f9, + 0x47f5, 0x48f1, 0x49eb, 0x4ae5, 0x4bdc, 0x4cd3, 0x4dc8, 0x4ebb, + 0x4fad, 0x509c, 0x518a, 0x5276, 0x5360, 0x5447, 0x552c, 0x560f, + 0x56ef, 0x57cd, 0x58a8, 0x5981, 0x5a57, 0x5b2a, 0x5bfb, 0x5cc9, + 0x5d93, 0x5e5b, 0x5f20, 0x5fe2, 0x60a1, 0x615d, 0x6216, 0x62cc, + 0x637f, 0x642e, 0x64db, 0x6584, 0x662b, 0x66ce, 0x676f, 0x680c, + 0x68a6, 0x693d, 0x69d2, 0x6a63, 0x6af1, 0x6b7c, 0x6c05, 0x6c8a, + 0x6d0d, 0x6d8d, 0x6e09, 0x6e84, 0x6efb, 0x6f70, 0x6fe2, 0x7051, + 0x0f42, 0x0faf, 0x101e, 0x1090, 0x1105, 0x117c, 0x11f7, 0x1273, + 0x12f3, 0x1376, 0x13fb, 0x1484, 0x150f, 0x159d, 0x162e, 0x16c3, + 0x175a, 0x17f4, 0x1891, 0x1932, 0x19d5, 0x1a7c, 0x1b25, 0x1bd2, + 0x1c81, 0x1d34, 0x1dea, 0x1ea3, 0x1f5f, 0x201e, 0x20e0, 0x21a5, + 0x226d, 0x2337, 0x2405, 0x24d6, 0x25a9, 0x267f, 0x2758, 0x2833, + 0x2911, 0x29f1, 0x2ad4, 0x2bb9, 0x2ca0, 0x2d8a, 0x2e76, 0x2f64, + 0x3053, 0x3145, 0x3238, 0x332d, 0x3424, 0x351b, 0x3615, 0x370f, + 0x380b, 0x3907, 0x3a04, 0x3b03, 0x3c01, 0x3d01, 0x3e00, 0x3f00, +}; + +const q15_t sigmoidHTable_q15[192] = { + 0x70be, 0x7190, 0x7258, 0x7316, 0x73cc, 0x7478, 0x751b, 0x75b7, + 0x764a, 0x76d6, 0x775b, 0x77d8, 0x784f, 0x78c0, 0x792a, 0x798f, + 0x79ee, 0x7a48, 0x7a9d, 0x7aed, 0x7b39, 0x7b80, 0x7bc4, 0x7c03, + 0x7c3f, 0x7c78, 0x7cad, 0x7ce0, 0x7d0f, 0x7d3c, 0x7d66, 0x7d8d, + 0x7db3, 0x7dd6, 0x7df7, 0x7e16, 0x7e33, 0x7e4f, 0x7e69, 0x7e81, + 0x7e98, 0x7eae, 0x7ec2, 0x7ed5, 0x7ee7, 0x7ef8, 0x7f08, 0x7f17, + 0x7f25, 0x7f32, 0x7f3e, 0x7f4a, 0x7f55, 0x7f5f, 0x7f69, 0x7f72, + 0x7f7b, 0x7f83, 0x7f8a, 0x7f91, 0x7f98, 0x7f9e, 0x7fa4, 0x7faa, + 0x7faf, 0x7fb4, 0x7fb8, 0x7fbd, 0x7fc1, 0x7fc5, 0x7fc8, 0x7fcc, + 0x7fcf, 0x7fd2, 0x7fd5, 0x7fd7, 0x7fda, 0x7fdc, 0x7fde, 0x7fe0, + 0x7fe2, 0x7fe4, 0x7fe6, 0x7fe7, 0x7fe9, 0x7fea, 0x7feb, 0x7fed, + 0x7fee, 0x7fef, 0x7ff0, 0x7ff1, 0x7ff2, 0x7ff3, 0x7ff4, 0x7ff4, + 0x000b, 0x000c, 0x000c, 0x000d, 0x000e, 0x000f, 0x0010, 0x0011, + 0x0012, 0x0013, 0x0015, 0x0016, 0x0017, 0x0019, 0x001a, 0x001c, + 0x001e, 0x0020, 0x0022, 0x0024, 0x0026, 0x0029, 0x002b, 0x002e, + 0x0031, 0x0034, 0x0038, 0x003b, 0x003f, 0x0043, 0x0048, 0x004c, + 0x0051, 0x0056, 0x005c, 0x0062, 0x0068, 0x006f, 0x0076, 0x007d, + 0x0085, 0x008e, 0x0097, 0x00a1, 0x00ab, 0x00b6, 0x00c2, 0x00ce, + 0x00db, 0x00e9, 0x00f8, 0x0108, 0x0119, 0x012b, 0x013e, 0x0152, + 0x0168, 0x017f, 0x0197, 0x01b1, 0x01cd, 0x01ea, 0x0209, 0x022a, + 0x024d, 0x0273, 0x029a, 0x02c4, 0x02f1, 0x0320, 0x0353, 0x0388, + 0x03c1, 0x03fd, 0x043c, 0x0480, 0x04c7, 0x0513, 0x0563, 0x05b8, + 0x0612, 0x0671, 0x06d6, 0x0740, 0x07b1, 0x0828, 0x08a5, 0x092a, + 0x09b6, 0x0a49, 0x0ae5, 0x0b88, 0x0c34, 0x0cea, 0x0da8, 0x0e70, +}; + +const q7_t tanhTable_q7[256] = { + 0x00, 0x08, 0x10, 0x18, 0x1f, 0x27, 0x2e, 0x35, + 0x3b, 0x41, 0x47, 0x4c, 0x51, 0x56, 0x5a, 0x5e, + 0x61, 0x65, 0x68, 0x6a, 0x6d, 0x6f, 0x71, 0x72, + 0x74, 0x75, 0x76, 0x78, 0x78, 0x79, 0x7a, 0x7b, + 0x7b, 0x7c, 0x7c, 0x7d, 0x7d, 0x7e, 0x7e, 0x7e, + 0x7e, 0x7e, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, 0x7f, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, + 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x81, + 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x82, + 0x82, 0x82, 0x82, 0x82, 0x83, 0x83, 0x84, 0x84, + 0x85, 0x85, 0x86, 0x87, 0x88, 0x88, 0x8a, 0x8b, + 0x8c, 0x8e, 0x8f, 0x91, 0x93, 0x96, 0x98, 0x9b, + 0x9f, 0xa2, 0xa6, 0xaa, 0xaf, 0xb4, 0xb9, 0xbf, + 0xc5, 0xcb, 0xd2, 0xd9, 0xe1, 0xe8, 0xf0, 0xf8, +}; + +const q15_t tanhTable_q15[256] = { + 0x0000, 0x07fd, 0x0feb, 0x17b9, 0x1f59, 0x26bf, 0x2ddf, 0x34ae, + 0x3b27, 0x4142, 0x46fd, 0x4c56, 0x514d, 0x55e2, 0x5a1a, 0x5df6, + 0x617c, 0x64b0, 0x6797, 0x6a37, 0x6c95, 0x6eb5, 0x709e, 0x7254, + 0x73dc, 0x753a, 0x7672, 0x7788, 0x787f, 0x795b, 0x7a1e, 0x7acb, + 0x7b65, 0x7bee, 0x7c66, 0x7cd1, 0x7d30, 0x7d84, 0x7dce, 0x7e0f, + 0x7e49, 0x7e7d, 0x7eaa, 0x7ed2, 0x7ef5, 0x7f14, 0x7f30, 0x7f48, + 0x7f5e, 0x7f71, 0x7f82, 0x7f91, 0x7f9e, 0x7fa9, 0x7fb3, 0x7fbc, + 0x7fc4, 0x7fcb, 0x7fd1, 0x7fd7, 0x7fdc, 0x7fe0, 0x7fe4, 0x7fe7, + 0x7fea, 0x7fed, 0x7fef, 0x7ff1, 0x7ff3, 0x7ff4, 0x7ff6, 0x7ff7, + 0x7ff8, 0x7ff9, 0x7ffa, 0x7ffa, 0x7ffb, 0x7ffc, 0x7ffc, 0x7ffd, + 0x7ffd, 0x7ffd, 0x7ffe, 0x7ffe, 0x7ffe, 0x7ffe, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8001, 0x8001, 0x8001, 0x8001, 0x8001, 0x8001, + 0x8001, 0x8001, 0x8001, 0x8002, 0x8002, 0x8002, 0x8002, 0x8003, + 0x8003, 0x8003, 0x8004, 0x8004, 0x8005, 0x8006, 0x8006, 0x8007, + 0x8008, 0x8009, 0x800a, 0x800c, 0x800d, 0x800f, 0x8011, 0x8013, + 0x8016, 0x8019, 0x801c, 0x8020, 0x8024, 0x8029, 0x802f, 0x8035, + 0x803c, 0x8044, 0x804d, 0x8057, 0x8062, 0x806f, 0x807e, 0x808f, + 0x80a2, 0x80b8, 0x80d0, 0x80ec, 0x810b, 0x812e, 0x8156, 0x8183, + 0x81b7, 0x81f1, 0x8232, 0x827c, 0x82d0, 0x832f, 0x839a, 0x8412, + 0x849b, 0x8535, 0x85e2, 0x86a5, 0x8781, 0x8878, 0x898e, 0x8ac6, + 0x8c24, 0x8dac, 0x8f62, 0x914b, 0x936b, 0x95c9, 0x9869, 0x9b50, + 0x9e84, 0xa20a, 0xa5e6, 0xaa1e, 0xaeb3, 0xb3aa, 0xb903, 0xbebe, + 0xc4d9, 0xcb52, 0xd221, 0xd941, 0xe0a7, 0xe847, 0xf015, 0xf803, +}; + +const q15_t tanhLTable_q15[128] = { + 0x0000, 0x0400, 0x07fd, 0x0bf7, 0x0feb, 0x13d7, 0x17b9, 0x1b90, + 0x1f59, 0x2314, 0x26bf, 0x2a58, 0x2ddf, 0x3151, 0x34ae, 0x37f6, + 0x3b27, 0x3e40, 0x4142, 0x442c, 0x46fd, 0x49b6, 0x4c56, 0x4edd, + 0x514d, 0x53a3, 0x55e2, 0x580a, 0x5a1a, 0x5c13, 0x5df6, 0x5fc4, + 0x617c, 0x6320, 0x64b0, 0x662d, 0x6797, 0x68f0, 0x6a37, 0x6b6e, + 0x6c95, 0x6dac, 0x6eb5, 0x6fb0, 0x709e, 0x717f, 0x7254, 0x731e, + 0x73dc, 0x7490, 0x753a, 0x75da, 0x7672, 0x7701, 0x7788, 0x7807, + 0x787f, 0x78f0, 0x795b, 0x79bf, 0x7a1e, 0x7a77, 0x7acb, 0x7b1b, + 0x849b, 0x84e5, 0x8535, 0x8589, 0x85e2, 0x8641, 0x86a5, 0x8710, + 0x8781, 0x87f9, 0x8878, 0x88ff, 0x898e, 0x8a26, 0x8ac6, 0x8b70, + 0x8c24, 0x8ce2, 0x8dac, 0x8e81, 0x8f62, 0x9050, 0x914b, 0x9254, + 0x936b, 0x9492, 0x95c9, 0x9710, 0x9869, 0x99d3, 0x9b50, 0x9ce0, + 0x9e84, 0xa03c, 0xa20a, 0xa3ed, 0xa5e6, 0xa7f6, 0xaa1e, 0xac5d, + 0xaeb3, 0xb123, 0xb3aa, 0xb64a, 0xb903, 0xbbd4, 0xbebe, 0xc1c0, + 0xc4d9, 0xc80a, 0xcb52, 0xceaf, 0xd221, 0xd5a8, 0xd941, 0xdcec, + 0xe0a7, 0xe470, 0xe847, 0xec29, 0xf015, 0xf409, 0xf803, 0xfc00, +}; + +const q15_t tanhHTable_q15[192] = { + 0x7b65, 0x7bee, 0x7c66, 0x7cd1, 0x7d30, 0x7d84, 0x7dce, 0x7e0f, + 0x7e49, 0x7e7d, 0x7eaa, 0x7ed2, 0x7ef5, 0x7f14, 0x7f30, 0x7f48, + 0x7f5e, 0x7f71, 0x7f82, 0x7f91, 0x7f9e, 0x7fa9, 0x7fb3, 0x7fbc, + 0x7fc4, 0x7fcb, 0x7fd1, 0x7fd7, 0x7fdc, 0x7fe0, 0x7fe4, 0x7fe7, + 0x7fea, 0x7fed, 0x7fef, 0x7ff1, 0x7ff3, 0x7ff4, 0x7ff6, 0x7ff7, + 0x7ff8, 0x7ff9, 0x7ffa, 0x7ffa, 0x7ffb, 0x7ffc, 0x7ffc, 0x7ffd, + 0x7ffd, 0x7ffd, 0x7ffe, 0x7ffe, 0x7ffe, 0x7ffe, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, 0x7fff, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, 0x8000, + 0x8000, 0x8000, 0x8001, 0x8001, 0x8001, 0x8001, 0x8001, 0x8001, + 0x8001, 0x8001, 0x8001, 0x8002, 0x8002, 0x8002, 0x8002, 0x8003, + 0x8003, 0x8003, 0x8004, 0x8004, 0x8005, 0x8006, 0x8006, 0x8007, + 0x8008, 0x8009, 0x800a, 0x800c, 0x800d, 0x800f, 0x8011, 0x8013, + 0x8016, 0x8019, 0x801c, 0x8020, 0x8024, 0x8029, 0x802f, 0x8035, + 0x803c, 0x8044, 0x804d, 0x8057, 0x8062, 0x806f, 0x807e, 0x808f, + 0x80a2, 0x80b8, 0x80d0, 0x80ec, 0x810b, 0x812e, 0x8156, 0x8183, + 0x81b7, 0x81f1, 0x8232, 0x827c, 0x82d0, 0x832f, 0x839a, 0x8412, +}; diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_no_shift.c b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_no_shift.c new file mode 100644 index 0000000..e043b38 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_no_shift.c @@ -0,0 +1,134 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_q7_to_q15_no_shift.c + * Description: Converts the elements of the Q7 vector to Q15 vector without left-shift + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_nnsupportfunctions.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup nndata_convert + * @{ + */ + +/** + * @brief Converts the elements of the Q7 vector to Q15 vector without left-shift + * @param[in] *pSrc points to the Q7 input vector + * @param[out] *pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * \par Description: + * + * The equation used for the conversion process is: + * + *
        
    + * 	pDst[n] = (q15_t) pSrc[n];   0 <= n < blockSize.    
    + * 
    + * + */ + +void arm_q7_to_q15_no_shift(const q7_t * pSrc, q15_t * pDst, uint32_t blockSize) +{ + const q7_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#ifndef ARM_MATH_CM0_FAMILY + q31_t in; + q31_t in1, in2; + q31_t out1, out2; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2u; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0u) + { + /* C = (q15_t) A << 8 */ + /* convert from q7 to q15 and then store the results in the destination buffer */ + in = *__SIMD32(pIn)++; + + /* rotatate in by 8 and extend two q7_t values to q15_t values */ + in1 = __SXTB16(__ROR(in, 8)); + + /* extend remainig two q7_t values to q15_t values */ + in2 = __SXTB16(in); + +#ifndef ARM_MATH_BIG_ENDIAN + + out2 = __PKHTB(in1, in2, 16); + out1 = __PKHBT(in2, in1, 16); + +#else + + out1 = __PKHTB(in1, in2, 16); + out2 = __PKHBT(in2, in1, 16); + +#endif + + *__SIMD32(pDst)++ = out1; + *__SIMD32(pDst)++ = out2; + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4u; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #ifndef ARM_MATH_CM0_FAMILY */ + + while (blkCnt > 0u) + { + /* C = (q15_t) A << 8 */ + /* convert from q7 to q15 and then store the results in the destination buffer */ + *pDst++ = (q15_t) * pIn++; + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of nndata_convert group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_reordered_no_shift.c b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_reordered_no_shift.c new file mode 100644 index 0000000..52f5f8e --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/NNSupportFunctions/arm_q7_to_q15_reordered_no_shift.c @@ -0,0 +1,145 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_q7_to_q15_reordered_no_shift.c + * Description: Converts the elements of the Q7 vector to reordered Q15 vector without left-shift + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_nnsupportfunctions.h" + +/** + * @ingroup groupSupport + */ + +/** + * @addtogroup nndata_convert + * @{ + */ + +/** + * @brief Converts the elements of the Q7 vector to reordered Q15 vector without left-shift + * @param[in] *pSrc points to the Q7 input vector + * @param[out] *pDst points to the Q15 output vector + * @param[in] blockSize length of the input vector + * @return none. + * + * @details + * + * This function does the q7 to q15 expansion with re-ordering + * + *
    + *                          |   A1   |   A2   |   A3   |   A4   |
    + *
    + *                           0      7 8     15 16    23 24    31
    + * 
    + * + * is converted into: + * + *
    + *  |       A1       |       A3       |   and  |       A2       |       A4       |
    + *
    + *   0             15 16            31          0             15 16            31
    + * 
    + * + * + * This looks strange but is natural considering how sign-extension is done at + * assembly level. + * + * The expansion of other other oprand will follow the same rule so that the end + * results are the same. + * + * The tail (i.e., last (N % 4) elements) will still be in original order. + * + */ + +void arm_q7_to_q15_reordered_no_shift(const q7_t * pSrc, q15_t * pDst, uint32_t blockSize) +{ + const q7_t *pIn = pSrc; /* Src pointer */ + uint32_t blkCnt; /* loop counter */ + +#ifndef ARM_MATH_CM0_FAMILY + q31_t in; + q31_t in1, in2; + + /* Run the below code for Cortex-M4 and Cortex-M3 */ + + /*loop Unrolling */ + blkCnt = blockSize >> 2u; + + /* First part of the processing with loop unrolling. Compute 4 outputs at a time. + ** a second loop below computes the remaining 1 to 3 samples. */ + while (blkCnt > 0u) + { + /* C = (q15_t) A << 8 */ + /* convert from q7 to q15 and then store the results in the destination buffer */ + in = *__SIMD32(pIn)++; + + /* rotatate in by 8 and extend two q7_t values to q15_t values */ + in1 = __SXTB16(__ROR(in, 8)); + + /* extend remainig two q7_t values to q15_t values */ + in2 = __SXTB16(in); + +#ifndef ARM_MATH_BIG_ENDIAN + *__SIMD32(pDst)++ = in2; + *__SIMD32(pDst)++ = in1; +#else + *__SIMD32(pDst)++ = in1; + *__SIMD32(pDst)++ = in2; +#endif + + /* Decrement the loop counter */ + blkCnt--; + } + + /* If the blockSize is not a multiple of 4, compute any remaining output samples here. + ** No loop unrolling is used. */ + blkCnt = blockSize % 0x4u; + +#else + + /* Run the below code for Cortex-M0 */ + + /* Loop over blockSize number of values */ + blkCnt = blockSize; + +#endif /* #ifndef ARM_MATH_CM0_FAMILY */ + + while (blkCnt > 0u) + { + /* C = (q15_t) A << 8 */ + /* convert from q7 to q15 and then store the results in the destination buffer */ + *pDst++ = (q15_t) * pIn++; + + /* Decrement the loop counter */ + blkCnt--; + } + +} + +/** + * @} end of q7_to_x group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/PoolingFunctions/arm_pool_q7_HWC.c b/Chapter04/bare/platform/CMSIS/NN/Source/PoolingFunctions/arm_pool_q7_HWC.c new file mode 100644 index 0000000..2759731 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/PoolingFunctions/arm_pool_q7_HWC.c @@ -0,0 +1,448 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_pool_q7_HWC.c + * Description: Pooling function implementations + * + * $Date: 17. January 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +#if defined (ARM_MATH_DSP) + +/** + * @brief A few utility functions used by pooling functions + * + * + */ + +static void buffer_scale_back_q15_to_q7(q15_t * buffer, q7_t * target, uint16_t length, uint16_t scale) +{ + int i; + + for (i = 0; i < length; i++) + { + target[i] = (q7_t) (buffer[i] / scale); + } +} + +static void compare_and_replace_if_larger_q7(q7_t * base, // base data + q7_t * target, // compare target + const uint16_t length // data length + ) +{ + q7_t *pIn = base; + q7_t *pCom = target; + union arm_nnword in; + union arm_nnword com; + uint16_t cnt = length >> 2; + + while (cnt > 0u) + { + in.word = *__SIMD32(pIn); + com.word = *__SIMD32(pCom)++; + + // if version + if (com.bytes[0] > in.bytes[0]) + in.bytes[0] = com.bytes[0]; + if (com.bytes[1] > in.bytes[1]) + in.bytes[1] = com.bytes[1]; + if (com.bytes[2] > in.bytes[2]) + in.bytes[2] = com.bytes[2]; + if (com.bytes[3] > in.bytes[3]) + in.bytes[3] = com.bytes[3]; + + *__SIMD32(pIn)++ = in.word; + + cnt--; + } +} + +static void accumulate_q7_to_q15(q15_t * base, q7_t * target, const uint16_t length) +{ + q15_t *pCnt = base; + q7_t *pV = target; + q31_t v1, v2, vo1, vo2; + uint16_t cnt = length >> 2; + q31_t in; + + while (cnt > 0u) + { + q31_t value = *__SIMD32(pV)++; + v1 = __SXTB16(__ROR(value, 8)); + v2 = __SXTB16(value); +#ifndef ARM_MATH_BIG_ENDIAN + + vo2 = __PKHTB(v1, v2, 16); + vo1 = __PKHBT(v2, v1, 16); + +#else + + vo1 = __PKHTB(v1, v2, 16); + vo2 = __PKHBT(v2, v1, 16); + +#endif + + in = *__SIMD32(pCnt); + *__SIMD32(pCnt)++ = __QADD16(vo1, in); + + in = *__SIMD32(pCnt); + *__SIMD32(pCnt)++ = __QADD16(vo2, in); + + cnt--; + } + cnt = length & 0x3; + while (cnt > 0u) + { + *pCnt++ += *pV++; + cnt--; + } +} + +#endif // ARM_MATH_DSP + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup Pooling + * @{ + */ + + /** + * @brief Q7 max pooling function + * @param[in, out] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] Im_out pointer to output tensor + * @return none. + * + * @details + * + * Buffer size: + * + * bufferA size: 0 + * + * The pooling function is implemented as split x-pooling then + * y-pooling. + * + * This pooling function is input-destructive. Input data is undefined + * after calling this function. + * + */ + +void +arm_maxpool_q7_HWC(q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, const uint16_t dim_im_out, q7_t * bufferA, q7_t * Im_out) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + int16_t i_x, i_y; + + /* first does the pooling along x axis */ + for (i_y = 0; i_y < dim_im_in; i_y++) + { + + for (i_x = 0; i_x < dim_im_out; i_x++) + { + /* for each output pixel */ + q7_t *target = Im_in + (i_y * dim_im_in + i_x) * ch_im_in; + q7_t *win_start; + q7_t *win_stop; + if (i_x * stride - padding < 0) + { + win_start = target; + } else + { + win_start = Im_in + (i_y * dim_im_in + i_x * stride - padding) * ch_im_in; + } + + if (i_x * stride - padding + dim_kernel >= dim_im_in) + { + win_stop = Im_in + (i_y * dim_im_in + dim_im_in) * ch_im_in; + } else + { + win_stop = Im_in + (i_y * dim_im_in + i_x * stride - padding + dim_kernel) * ch_im_in; + } + + /* first step is to copy over initial data */ + /* arm_copy_q7(win_start, target, ch_im_in); */ + memmove(target, win_start, ch_im_in); + + /* start the max operation from the second part */ + win_start += ch_im_in; + for (; win_start < win_stop; win_start += ch_im_in) + { + compare_and_replace_if_larger_q7(target, win_start, ch_im_in); + } + } + } + + /* then does the pooling along y axis */ + for (i_y = 0; i_y < dim_im_out; i_y++) + { + + /* for each output row */ + q7_t *target = Im_out + i_y * dim_im_out * ch_im_in; + q7_t *row_start; + q7_t *row_end; + /* setting the starting row */ + if (i_y * stride - padding < 0) + { + row_start = Im_in; + } else + { + row_start = Im_in + (i_y * stride - padding) * dim_im_in * ch_im_in; + } + /* setting the stopping row */ + if (i_y * stride - padding + dim_kernel >= dim_im_in) + { + row_end = Im_in + dim_im_in * dim_im_in * ch_im_in; + } else + { + row_end = Im_in + (i_y * stride - padding + dim_kernel) * dim_im_in * ch_im_in; + } + + /* copy over the first row */ + /* arm_copy_q7(row_start, target, dim_im_out * ch_im_in); */ + memmove(target, row_start, dim_im_out * ch_im_in); + + /* move over to next row */ + row_start += ch_im_in * dim_im_in; + + for (; row_start < row_end; row_start += dim_im_in * ch_im_in) + { + compare_and_replace_if_larger_q7(target, row_start, dim_im_out * ch_im_in); + } + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + int16_t i_ch_in, i_x, i_y; + int16_t k_x, k_y; + + for (i_ch_in = 0; i_ch_in < ch_im_in; i_ch_in++) + { + for (i_y = 0; i_y < dim_im_out; i_y++) + { + for (i_x = 0; i_x < dim_im_out; i_x++) + { + int max = -129; + for (k_y = i_y * stride - padding; k_y < i_y * stride - padding + dim_kernel; k_y++) + { + for (k_x = i_x * stride - padding; k_x < i_x * stride - padding + dim_kernel; k_x++) + { + if (k_y >= 0 && k_x >= 0 && k_y < dim_im_in && k_x < dim_im_in) + { + if (Im_in[i_ch_in + ch_im_in * (k_x + k_y * dim_im_in)] > max) + { + max = Im_in[i_ch_in + ch_im_in * (k_x + k_y * dim_im_in)]; + } + } + } + } + Im_out[i_ch_in + ch_im_in * (i_x + i_y * dim_im_out)] = max; + } + } + } + +#endif /* ARM_MATH_DSP */ + +} + + /** + * @brief Q7 average pooling function + * @param[in,out] Im_in pointer to input tensor + * @param[in] dim_im_in input tensor dimention + * @param[in] ch_im_in number of input tensor channels + * @param[in] dim_kernel filter kernel size + * @param[in] padding padding sizes + * @param[in] stride convolution stride + * @param[in] dim_im_out output tensor dimension + * @param[in,out] bufferA pointer to buffer space for input + * @param[in,out] Im_out pointer to output tensor + * @return none. + * + * @details + * + * Buffer size: + * + * bufferA size: 2*dim_im_out*ch_im_in + * + * The pooling function is implemented as split x-pooling then + * y-pooling. + * + * This pooling function is input-destructive. Input data is undefined + * after calling this function. + * + */ + +void +arm_avepool_q7_HWC(q7_t * Im_in, + const uint16_t dim_im_in, + const uint16_t ch_im_in, + const uint16_t dim_kernel, + const uint16_t padding, + const uint16_t stride, const uint16_t dim_im_out, q7_t * bufferA, q7_t * Im_out) +{ + +#if defined (ARM_MATH_DSP) + /* Run the following code for Cortex-M4 and Cortex-M7 */ + + q15_t *buffer = (q15_t *) bufferA; + int16_t i_x, i_y; + int16_t count = 0; + + /* first does the pooling along x axis */ + for (i_y = 0; i_y < dim_im_in; i_y++) + { + + for (i_x = 0; i_x < dim_im_out; i_x++) + { + /* for each output pixel */ + q7_t *target = Im_in + (i_y * dim_im_in + i_x) * ch_im_in; + q7_t *win_start; + q7_t *win_stop; + if (i_x * stride - padding < 0) + { + win_start = target; + } else + { + win_start = Im_in + (i_y * dim_im_in + i_x * stride - padding) * ch_im_in; + } + + if (i_x * stride - padding + dim_kernel >= dim_im_in) + { + win_stop = Im_in + (i_y * dim_im_in + dim_im_in) * ch_im_in; + } else + { + win_stop = Im_in + (i_y * dim_im_in + i_x * stride - padding + dim_kernel) * ch_im_in; + } + + /* first step is to copy over initial data */ + arm_q7_to_q15_no_shift(win_start, buffer, ch_im_in); + count = 1; + + /* start the max operation from the second part */ + win_start += ch_im_in; + for (; win_start < win_stop; win_start += ch_im_in) + { + accumulate_q7_to_q15(buffer, win_start, ch_im_in); + count++; + } + buffer_scale_back_q15_to_q7(buffer, target, ch_im_in, count); + } + } + + /* then does the pooling along y axis */ + for (i_y = 0; i_y < dim_im_out; i_y++) + { + /* for each output row */ + q7_t *target = Im_out + i_y * dim_im_out * ch_im_in; + q7_t *row_start; + q7_t *row_end; + /* setting the starting row */ + if (i_y * stride - padding < 0) + { + row_start = Im_in; + } else + { + row_start = Im_in + (i_y * stride - padding) * dim_im_in * ch_im_in; + } + /* setting the stopping row */ + if (i_y * stride - padding + dim_kernel >= dim_im_in) + { + row_end = Im_in + dim_im_in * dim_im_in * ch_im_in; + } else + { + row_end = Im_in + (i_y * stride - padding + dim_kernel) * dim_im_in * ch_im_in; + } + + /* copy over the first row */ + arm_q7_to_q15_no_shift(row_start, buffer, dim_im_out * ch_im_in); + count = 1; + + /* move over to next row */ + row_start += ch_im_in * dim_im_in; + + for (; row_start < row_end; row_start += dim_im_in * ch_im_in) + { + accumulate_q7_to_q15(buffer, row_start, dim_im_out * ch_im_in); + count++; + } + buffer_scale_back_q15_to_q7(buffer, target, dim_im_out * ch_im_in, count); + } + +#else + /* Run the following code as reference implementation for Cortex-M0 and Cortex-M3 */ + + int16_t i_ch_in, i_x, i_y; + int16_t k_x, k_y; + + for (i_ch_in = 0; i_ch_in < ch_im_in; i_ch_in++) + { + for (i_y = 0; i_y < dim_im_out; i_y++) + { + for (i_x = 0; i_x < dim_im_out; i_x++) + { + int sum = 0; + int count = 0; + for (k_y = i_y * stride - padding; k_y < i_y * stride - padding + dim_kernel; k_y++) + { + for (k_x = i_x * stride - padding; k_x < i_x * stride - padding + dim_kernel; k_x++) + { + if (k_y >= 0 && k_x >= 0 && k_y < dim_im_in && k_x < dim_im_in) + { + sum += Im_in[i_ch_in + ch_im_in * (k_x + k_y * dim_im_in)]; + count++; + } + } + } + Im_out[i_ch_in + ch_im_in * (i_x + i_y * dim_im_out)] = sum / count; + } + } + } + +#endif /* ARM_MATH_DSP */ + +} + +/** + * @} end of Pooling group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q15.c b/Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q15.c new file mode 100644 index 0000000..22fa62b --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q15.c @@ -0,0 +1,120 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_softmax_q15.c + * Description: Q15 softmax function + * + * $Date: 20. February 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup Softmax + * @{ + */ + + /** + * @brief Q15 softmax function + * @param[in] vec_in pointer to input vector + * @param[in] dim_vec input vector dimention + * @param[out] p_out pointer to output vector + * @return none. + * + * @details + * + * Here, instead of typical e based softmax, we use + * 2-based softmax, i.e.,: + * + * y_i = 2^(x_i) / sum(2^x_j) + * + * The relative output will be different here. + * But mathematically, the gradient will be the same + * with a log(2) scaling factor. + * + */ + +void arm_softmax_q15(const q15_t * vec_in, const uint16_t dim_vec, q15_t * p_out) +{ + q31_t sum; + int16_t i; + uint8_t shift; + q31_t base; + base = -1 * 0x100000; + for (i = 0; i < dim_vec; i++) + { + if (vec_in[i] > base) + { + base = vec_in[i]; + } + } + + /* we ignore really small values + * anyway, they will be 0 after shrinking + * to q15_t + */ + base = base - 16; + + sum = 0; + + for (i = 0; i < dim_vec; i++) + { + if (vec_in[i] > base) + { + shift = (uint8_t)__USAT(vec_in[i] - base, 5); + sum += 0x1 << shift; + } + } + + /* This is effectively (0x1 << 32) / sum */ + int64_t div_base = 0x100000000LL; + int output_base = (int32_t)(div_base / sum); + + /* Final confidence will be output_base >> ( 17 - (vec_in[i] - base) ) + * so 32768 (0x1<<15) -> 100% confidence when sum = 0x1 << 16, output_base = 0x1 << 16 + * and vec_in[i]-base = 16 + */ + for (i = 0; i < dim_vec; i++) + { + if (vec_in[i] > base) + { + /* Here minimum value of 17+base-vec[i] will be 1 */ + shift = (uint8_t)__USAT(17+base-vec_in[i], 5); + p_out[i] = (q15_t) __SSAT((output_base >> shift), 16); + } else + { + p_out[i] = 0; + } + } + +} + +/** + * @} end of Softmax group + */ diff --git a/Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q7.c b/Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q7.c new file mode 100644 index 0000000..06a69e1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/NN/Source/SoftmaxFunctions/arm_softmax_q7.c @@ -0,0 +1,121 @@ +/* + * Copyright (C) 2010-2018 Arm Limited or its affiliates. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/* ---------------------------------------------------------------------- + * Project: CMSIS NN Library + * Title: arm_softmax_q7.c + * Description: Q7 softmax function + * + * $Date: 20. February 2018 + * $Revision: V.1.0.0 + * + * Target Processor: Cortex-M cores + * + * -------------------------------------------------------------------- */ + +#include "arm_math.h" +#include "arm_nnfunctions.h" + +/** + * @ingroup groupNN + */ + +/** + * @addtogroup Softmax + * @{ + */ + + /** + * @brief Q7 softmax function + * @param[in] vec_in pointer to input vector + * @param[in] dim_vec input vector dimention + * @param[out] p_out pointer to output vector + * @return none. + * + * @details + * + * Here, instead of typical natural logarithm e based softmax, we use + * 2-based softmax here, i.e.,: + * + * y_i = 2^(x_i) / sum(2^x_j) + * + * The relative output will be different here. + * But mathematically, the gradient will be the same + * with a log(2) scaling factor. + * + */ + +void arm_softmax_q7(const q7_t * vec_in, const uint16_t dim_vec, q7_t * p_out) +{ + q31_t sum; + int16_t i; + uint8_t shift; + q15_t base; + base = -257; + + /* We first search for the maximum */ + for (i = 0; i < dim_vec; i++) + { + if (vec_in[i] > base) + { + base = vec_in[i]; + } + } + + /* + * So the base is set to max-8, meaning + * that we ignore really small values. + * anyway, they will be 0 after shrinking to q7_t. + */ + base = base - 8; + + sum = 0; + + for (i = 0; i < dim_vec; i++) + { + if (vec_in[i] > base) + { + shift = (uint8_t)__USAT(vec_in[i] - base, 5); + sum += 0x1 << shift; + } + } + + /* This is effectively (0x1 << 20) / sum */ + int output_base = 0x100000 / sum; + + /* + * Final confidence will be output_base >> ( 13 - (vec_in[i] - base) ) + * so 128 (0x1<<7) -> 100% confidence when sum = 0x1 << 8, output_base = 0x1 << 12 + * and vec_in[i]-base = 8 + */ + for (i = 0; i < dim_vec; i++) + { + if (vec_in[i] > base) + { + /* Here minimum value of 13+base-vec_in[i] will be 5 */ + shift = (uint8_t)__USAT(13+base-vec_in[i], 5); + p_out[i] = (q7_t) __SSAT((output_base >> shift), 8); + } else { + p_out[i] = 0; + } + } +} + +/** + * @} end of Softmax group + */ diff --git a/Chapter04/bare/platform/CMSIS/RTOS/Template/cmsis_os.h b/Chapter04/bare/platform/CMSIS/RTOS/Template/cmsis_os.h new file mode 100644 index 0000000..85e24a4 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS/Template/cmsis_os.h @@ -0,0 +1,698 @@ +/* ---------------------------------------------------------------------- + * $Date: 5. February 2013 + * $Revision: V1.02 + * + * Project: CMSIS-RTOS API + * Title: cmsis_os.h template header file + * + * Version 0.02 + * Initial Proposal Phase + * Version 0.03 + * osKernelStart added, optional feature: main started as thread + * osSemaphores have standard behavior + * osTimerCreate does not start the timer, added osTimerStart + * osThreadPass is renamed to osThreadYield + * Version 1.01 + * Support for C++ interface + * - const attribute removed from the osXxxxDef_t typedef's + * - const attribute added to the osXxxxDef macros + * Added: osTimerDelete, osMutexDelete, osSemaphoreDelete + * Added: osKernelInitialize + * Version 1.02 + * Control functions for short timeouts in microsecond resolution: + * Added: osKernelSysTick, osKernelSysTickFrequency, osKernelSysTickMicroSec + * Removed: osSignalGet + *---------------------------------------------------------------------------- + * + * Copyright (c) 2013-2017 ARM LIMITED + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + *---------------------------------------------------------------------------*/ + + +#ifndef _CMSIS_OS_H +#define _CMSIS_OS_H + +/// \note MUST REMAIN UNCHANGED: \b osCMSIS identifies the CMSIS-RTOS API version. +#define osCMSIS 0x10002 ///< API version (main [31:16] .sub [15:0]) + +/// \note CAN BE CHANGED: \b osCMSIS_KERNEL identifies the underlying RTOS kernel and version number. +#define osCMSIS_KERNEL 0x10000 ///< RTOS identification and version (main [31:16] .sub [15:0]) + +/// \note MUST REMAIN UNCHANGED: \b osKernelSystemId shall be consistent in every CMSIS-RTOS. +#define osKernelSystemId "KERNEL V1.00" ///< RTOS identification string + +/// \note MUST REMAIN UNCHANGED: \b osFeature_xxx shall be consistent in every CMSIS-RTOS. +#define osFeature_MainThread 1 ///< main thread 1=main can be thread, 0=not available +#define osFeature_Pool 1 ///< Memory Pools: 1=available, 0=not available +#define osFeature_MailQ 1 ///< Mail Queues: 1=available, 0=not available +#define osFeature_MessageQ 1 ///< Message Queues: 1=available, 0=not available +#define osFeature_Signals 8 ///< maximum number of Signal Flags available per thread +#define osFeature_Semaphore 30 ///< maximum count for \ref osSemaphoreCreate function +#define osFeature_Wait 1 ///< osWait function: 1=available, 0=not available +#define osFeature_SysTick 1 ///< osKernelSysTick functions: 1=available, 0=not available + +#include +#include + +#ifdef __cplusplus +extern "C" +{ +#endif + + +// ==== Enumeration, structures, defines ==== + +/// Priority used for thread control. +/// \note MUST REMAIN UNCHANGED: \b osPriority shall be consistent in every CMSIS-RTOS. +typedef enum { + osPriorityIdle = -3, ///< priority: idle (lowest) + osPriorityLow = -2, ///< priority: low + osPriorityBelowNormal = -1, ///< priority: below normal + osPriorityNormal = 0, ///< priority: normal (default) + osPriorityAboveNormal = +1, ///< priority: above normal + osPriorityHigh = +2, ///< priority: high + osPriorityRealtime = +3, ///< priority: realtime (highest) + osPriorityError = 0x84 ///< system cannot determine priority or thread has illegal priority +} osPriority; + +/// Timeout value. +/// \note MUST REMAIN UNCHANGED: \b osWaitForever shall be consistent in every CMSIS-RTOS. +#define osWaitForever 0xFFFFFFFF ///< wait forever timeout value + +/// Status code values returned by CMSIS-RTOS functions. +/// \note MUST REMAIN UNCHANGED: \b osStatus shall be consistent in every CMSIS-RTOS. +typedef enum { + osOK = 0, ///< function completed; no error or event occurred. + osEventSignal = 0x08, ///< function completed; signal event occurred. + osEventMessage = 0x10, ///< function completed; message event occurred. + osEventMail = 0x20, ///< function completed; mail event occurred. + osEventTimeout = 0x40, ///< function completed; timeout occurred. + osErrorParameter = 0x80, ///< parameter error: a mandatory parameter was missing or specified an incorrect object. + osErrorResource = 0x81, ///< resource not available: a specified resource was not available. + osErrorTimeoutResource = 0xC1, ///< resource not available within given time: a specified resource was not available within the timeout period. + osErrorISR = 0x82, ///< not allowed in ISR context: the function cannot be called from interrupt service routines. + osErrorISRRecursive = 0x83, ///< function called multiple times from ISR with same object. + osErrorPriority = 0x84, ///< system cannot determine priority or thread has illegal priority. + osErrorNoMemory = 0x85, ///< system is out of memory: it was impossible to allocate or reserve memory for the operation. + osErrorValue = 0x86, ///< value of a parameter is out of range. + osErrorOS = 0xFF, ///< unspecified RTOS error: run-time error but no other error message fits. + os_status_reserved = 0x7FFFFFFF ///< prevent from enum down-size compiler optimization. +} osStatus; + + +/// Timer type value for the timer definition. +/// \note MUST REMAIN UNCHANGED: \b os_timer_type shall be consistent in every CMSIS-RTOS. +typedef enum { + osTimerOnce = 0, ///< one-shot timer + osTimerPeriodic = 1 ///< repeating timer +} os_timer_type; + +/// Entry point of a thread. +/// \note MUST REMAIN UNCHANGED: \b os_pthread shall be consistent in every CMSIS-RTOS. +typedef void (*os_pthread) (void const *argument); + +/// Entry point of a timer call back function. +/// \note MUST REMAIN UNCHANGED: \b os_ptimer shall be consistent in every CMSIS-RTOS. +typedef void (*os_ptimer) (void const *argument); + +// >>> the following data type definitions may shall adapted towards a specific RTOS + +/// Thread ID identifies the thread (pointer to a thread control block). +/// \note CAN BE CHANGED: \b os_thread_cb is implementation specific in every CMSIS-RTOS. +typedef struct os_thread_cb *osThreadId; + +/// Timer ID identifies the timer (pointer to a timer control block). +/// \note CAN BE CHANGED: \b os_timer_cb is implementation specific in every CMSIS-RTOS. +typedef struct os_timer_cb *osTimerId; + +/// Mutex ID identifies the mutex (pointer to a mutex control block). +/// \note CAN BE CHANGED: \b os_mutex_cb is implementation specific in every CMSIS-RTOS. +typedef struct os_mutex_cb *osMutexId; + +/// Semaphore ID identifies the semaphore (pointer to a semaphore control block). +/// \note CAN BE CHANGED: \b os_semaphore_cb is implementation specific in every CMSIS-RTOS. +typedef struct os_semaphore_cb *osSemaphoreId; + +/// Pool ID identifies the memory pool (pointer to a memory pool control block). +/// \note CAN BE CHANGED: \b os_pool_cb is implementation specific in every CMSIS-RTOS. +typedef struct os_pool_cb *osPoolId; + +/// Message ID identifies the message queue (pointer to a message queue control block). +/// \note CAN BE CHANGED: \b os_messageQ_cb is implementation specific in every CMSIS-RTOS. +typedef struct os_messageQ_cb *osMessageQId; + +/// Mail ID identifies the mail queue (pointer to a mail queue control block). +/// \note CAN BE CHANGED: \b os_mailQ_cb is implementation specific in every CMSIS-RTOS. +typedef struct os_mailQ_cb *osMailQId; + + +/// Thread Definition structure contains startup information of a thread. +/// \note CAN BE CHANGED: \b os_thread_def is implementation specific in every CMSIS-RTOS. +typedef struct os_thread_def { + os_pthread pthread; ///< start address of thread function + osPriority tpriority; ///< initial thread priority + uint32_t instances; ///< maximum number of instances of that thread function + uint32_t stacksize; ///< stack size requirements in bytes; 0 is default stack size +} osThreadDef_t; + +/// Timer Definition structure contains timer parameters. +/// \note CAN BE CHANGED: \b os_timer_def is implementation specific in every CMSIS-RTOS. +typedef struct os_timer_def { + os_ptimer ptimer; ///< start address of a timer function +} osTimerDef_t; + +/// Mutex Definition structure contains setup information for a mutex. +/// \note CAN BE CHANGED: \b os_mutex_def is implementation specific in every CMSIS-RTOS. +typedef struct os_mutex_def { + uint32_t dummy; ///< dummy value. +} osMutexDef_t; + +/// Semaphore Definition structure contains setup information for a semaphore. +/// \note CAN BE CHANGED: \b os_semaphore_def is implementation specific in every CMSIS-RTOS. +typedef struct os_semaphore_def { + uint32_t dummy; ///< dummy value. +} osSemaphoreDef_t; + +/// Definition structure for memory block allocation. +/// \note CAN BE CHANGED: \b os_pool_def is implementation specific in every CMSIS-RTOS. +typedef struct os_pool_def { + uint32_t pool_sz; ///< number of items (elements) in the pool + uint32_t item_sz; ///< size of an item + void *pool; ///< pointer to memory for pool +} osPoolDef_t; + +/// Definition structure for message queue. +/// \note CAN BE CHANGED: \b os_messageQ_def is implementation specific in every CMSIS-RTOS. +typedef struct os_messageQ_def { + uint32_t queue_sz; ///< number of elements in the queue + uint32_t item_sz; ///< size of an item + void *pool; ///< memory array for messages +} osMessageQDef_t; + +/// Definition structure for mail queue. +/// \note CAN BE CHANGED: \b os_mailQ_def is implementation specific in every CMSIS-RTOS. +typedef struct os_mailQ_def { + uint32_t queue_sz; ///< number of elements in the queue + uint32_t item_sz; ///< size of an item + void *pool; ///< memory array for mail +} osMailQDef_t; + +/// Event structure contains detailed information about an event. +/// \note MUST REMAIN UNCHANGED: \b os_event shall be consistent in every CMSIS-RTOS. +/// However the struct may be extended at the end. +typedef struct { + osStatus status; ///< status code: event or error information + union { + uint32_t v; ///< message as 32-bit value + void *p; ///< message or mail as void pointer + int32_t signals; ///< signal flags + } value; ///< event value + union { + osMailQId mail_id; ///< mail id obtained by \ref osMailCreate + osMessageQId message_id; ///< message id obtained by \ref osMessageCreate + } def; ///< event definition +} osEvent; + + +// ==== Kernel Control Functions ==== + +/// Initialize the RTOS Kernel for creating objects. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osKernelInitialize shall be consistent in every CMSIS-RTOS. +osStatus osKernelInitialize (void); + +/// Start the RTOS Kernel. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osKernelStart shall be consistent in every CMSIS-RTOS. +osStatus osKernelStart (void); + +/// Check if the RTOS kernel is already started. +/// \note MUST REMAIN UNCHANGED: \b osKernelRunning shall be consistent in every CMSIS-RTOS. +/// \return 0 RTOS is not started, 1 RTOS is started. +int32_t osKernelRunning(void); + +#if (defined (osFeature_SysTick) && (osFeature_SysTick != 0)) // System Timer available + +/// Get the RTOS kernel system timer counter +/// \note MUST REMAIN UNCHANGED: \b osKernelSysTick shall be consistent in every CMSIS-RTOS. +/// \return RTOS kernel system timer as 32-bit value +uint32_t osKernelSysTick (void); + +/// The RTOS kernel system timer frequency in Hz +/// \note Reflects the system timer setting and is typically defined in a configuration file. +#define osKernelSysTickFrequency 100000000 + +/// Convert a microseconds value to a RTOS kernel system timer value. +/// \param microsec time value in microseconds. +/// \return time value normalized to the \ref osKernelSysTickFrequency +#define osKernelSysTickMicroSec(microsec) (((uint64_t)microsec * (osKernelSysTickFrequency)) / 1000000) + +#endif // System Timer available + +// ==== Thread Management ==== + +/// Create a Thread Definition with function, priority, and stack requirements. +/// \param name name of the thread function. +/// \param priority initial priority of the thread function. +/// \param instances number of possible thread instances. +/// \param stacksz stack size (in bytes) requirements for the thread function. +/// \note CAN BE CHANGED: The parameters to \b osThreadDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osThreadDef(name, priority, instances, stacksz) \ +extern const osThreadDef_t os_thread_def_##name +#else // define the object +#define osThreadDef(name, priority, instances, stacksz) \ +const osThreadDef_t os_thread_def_##name = \ +{ (name), (priority), (instances), (stacksz) } +#endif + +/// Access a Thread definition. +/// \param name name of the thread definition object. +/// \note CAN BE CHANGED: The parameter to \b osThread shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osThread(name) \ +&os_thread_def_##name + +/// Create a thread and add it to Active Threads and set it to state READY. +/// \param[in] thread_def thread definition referenced with \ref osThread. +/// \param[in] argument pointer that is passed to the thread function as start argument. +/// \return thread ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osThreadCreate shall be consistent in every CMSIS-RTOS. +osThreadId osThreadCreate (const osThreadDef_t *thread_def, void *argument); + +/// Return the thread ID of the current running thread. +/// \return thread ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osThreadGetId shall be consistent in every CMSIS-RTOS. +osThreadId osThreadGetId (void); + +/// Terminate execution of a thread and remove it from Active Threads. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osThreadTerminate shall be consistent in every CMSIS-RTOS. +osStatus osThreadTerminate (osThreadId thread_id); + +/// Pass control to next thread that is in state \b READY. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osThreadYield shall be consistent in every CMSIS-RTOS. +osStatus osThreadYield (void); + +/// Change priority of an active thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \param[in] priority new priority value for the thread function. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osThreadSetPriority shall be consistent in every CMSIS-RTOS. +osStatus osThreadSetPriority (osThreadId thread_id, osPriority priority); + +/// Get current priority of an active thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \return current priority value of the thread function. +/// \note MUST REMAIN UNCHANGED: \b osThreadGetPriority shall be consistent in every CMSIS-RTOS. +osPriority osThreadGetPriority (osThreadId thread_id); + + +// ==== Generic Wait Functions ==== + +/// Wait for Timeout (Time Delay). +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue "time delay" value +/// \return status code that indicates the execution status of the function. +osStatus osDelay (uint32_t millisec); + +#if (defined (osFeature_Wait) && (osFeature_Wait != 0)) // Generic Wait available + +/// Wait for Signal, Message, Mail, or Timeout. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out +/// \return event that contains signal, message, or mail information or error code. +/// \note MUST REMAIN UNCHANGED: \b osWait shall be consistent in every CMSIS-RTOS. +osEvent osWait (uint32_t millisec); + +#endif // Generic Wait available + + +// ==== Timer Management Functions ==== +/// Define a Timer object. +/// \param name name of the timer object. +/// \param function name of the timer call back function. +/// \note CAN BE CHANGED: The parameter to \b osTimerDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osTimerDef(name, function) \ +extern const osTimerDef_t os_timer_def_##name +#else // define the object +#define osTimerDef(name, function) \ +const osTimerDef_t os_timer_def_##name = \ +{ (function) } +#endif + +/// Access a Timer definition. +/// \param name name of the timer object. +/// \note CAN BE CHANGED: The parameter to \b osTimer shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osTimer(name) \ +&os_timer_def_##name + +/// Create a timer. +/// \param[in] timer_def timer object referenced with \ref osTimer. +/// \param[in] type osTimerOnce for one-shot or osTimerPeriodic for periodic behavior. +/// \param[in] argument argument to the timer call back function. +/// \return timer ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osTimerCreate shall be consistent in every CMSIS-RTOS. +osTimerId osTimerCreate (const osTimerDef_t *timer_def, os_timer_type type, void *argument); + +/// Start or restart a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue "time delay" value of the timer. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osTimerStart shall be consistent in every CMSIS-RTOS. +osStatus osTimerStart (osTimerId timer_id, uint32_t millisec); + +/// Stop the timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerCreate. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osTimerStop shall be consistent in every CMSIS-RTOS. +osStatus osTimerStop (osTimerId timer_id); + +/// Delete a timer that was created by \ref osTimerCreate. +/// \param[in] timer_id timer ID obtained by \ref osTimerCreate. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osTimerDelete shall be consistent in every CMSIS-RTOS. +osStatus osTimerDelete (osTimerId timer_id); + + +// ==== Signal Management ==== + +/// Set the specified Signal Flags of an active thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \param[in] signals specifies the signal flags of the thread that should be set. +/// \return previous signal flags of the specified thread or 0x80000000 in case of incorrect parameters. +/// \note MUST REMAIN UNCHANGED: \b osSignalSet shall be consistent in every CMSIS-RTOS. +int32_t osSignalSet (osThreadId thread_id, int32_t signals); + +/// Clear the specified Signal Flags of an active thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \param[in] signals specifies the signal flags of the thread that shall be cleared. +/// \return previous signal flags of the specified thread or 0x80000000 in case of incorrect parameters or call from ISR. +/// \note MUST REMAIN UNCHANGED: \b osSignalClear shall be consistent in every CMSIS-RTOS. +int32_t osSignalClear (osThreadId thread_id, int32_t signals); + +/// Wait for one or more Signal Flags to become signaled for the current \b RUNNING thread. +/// \param[in] signals wait until all specified signal flags set or 0 for any single signal flag. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return event flag information or error code. +/// \note MUST REMAIN UNCHANGED: \b osSignalWait shall be consistent in every CMSIS-RTOS. +osEvent osSignalWait (int32_t signals, uint32_t millisec); + + +// ==== Mutex Management ==== + +/// Define a Mutex. +/// \param name name of the mutex object. +/// \note CAN BE CHANGED: The parameter to \b osMutexDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osMutexDef(name) \ +extern const osMutexDef_t os_mutex_def_##name +#else // define the object +#define osMutexDef(name) \ +const osMutexDef_t os_mutex_def_##name = { 0 } +#endif + +/// Access a Mutex definition. +/// \param name name of the mutex object. +/// \note CAN BE CHANGED: The parameter to \b osMutex shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osMutex(name) \ +&os_mutex_def_##name + +/// Create and Initialize a Mutex object. +/// \param[in] mutex_def mutex definition referenced with \ref osMutex. +/// \return mutex ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osMutexCreate shall be consistent in every CMSIS-RTOS. +osMutexId osMutexCreate (const osMutexDef_t *mutex_def); + +/// Wait until a Mutex becomes available. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osMutexWait shall be consistent in every CMSIS-RTOS. +osStatus osMutexWait (osMutexId mutex_id, uint32_t millisec); + +/// Release a Mutex that was obtained by \ref osMutexWait. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexCreate. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osMutexRelease shall be consistent in every CMSIS-RTOS. +osStatus osMutexRelease (osMutexId mutex_id); + +/// Delete a Mutex that was created by \ref osMutexCreate. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexCreate. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osMutexDelete shall be consistent in every CMSIS-RTOS. +osStatus osMutexDelete (osMutexId mutex_id); + + +// ==== Semaphore Management Functions ==== + +#if (defined (osFeature_Semaphore) && (osFeature_Semaphore != 0)) // Semaphore available + +/// Define a Semaphore object. +/// \param name name of the semaphore object. +/// \note CAN BE CHANGED: The parameter to \b osSemaphoreDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osSemaphoreDef(name) \ +extern const osSemaphoreDef_t os_semaphore_def_##name +#else // define the object +#define osSemaphoreDef(name) \ +const osSemaphoreDef_t os_semaphore_def_##name = { 0 } +#endif + +/// Access a Semaphore definition. +/// \param name name of the semaphore object. +/// \note CAN BE CHANGED: The parameter to \b osSemaphore shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osSemaphore(name) \ +&os_semaphore_def_##name + +/// Create and Initialize a Semaphore object used for managing resources. +/// \param[in] semaphore_def semaphore definition referenced with \ref osSemaphore. +/// \param[in] count number of available resources. +/// \return semaphore ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osSemaphoreCreate shall be consistent in every CMSIS-RTOS. +osSemaphoreId osSemaphoreCreate (const osSemaphoreDef_t *semaphore_def, int32_t count); + +/// Wait until a Semaphore token becomes available. +/// \param[in] semaphore_id semaphore object referenced with \ref osSemaphoreCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return number of available tokens, or -1 in case of incorrect parameters. +/// \note MUST REMAIN UNCHANGED: \b osSemaphoreWait shall be consistent in every CMSIS-RTOS. +int32_t osSemaphoreWait (osSemaphoreId semaphore_id, uint32_t millisec); + +/// Release a Semaphore token. +/// \param[in] semaphore_id semaphore object referenced with \ref osSemaphoreCreate. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osSemaphoreRelease shall be consistent in every CMSIS-RTOS. +osStatus osSemaphoreRelease (osSemaphoreId semaphore_id); + +/// Delete a Semaphore that was created by \ref osSemaphoreCreate. +/// \param[in] semaphore_id semaphore object referenced with \ref osSemaphoreCreate. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osSemaphoreDelete shall be consistent in every CMSIS-RTOS. +osStatus osSemaphoreDelete (osSemaphoreId semaphore_id); + +#endif // Semaphore available + + +// ==== Memory Pool Management Functions ==== + +#if (defined (osFeature_Pool) && (osFeature_Pool != 0)) // Memory Pool Management available + +/// \brief Define a Memory Pool. +/// \param name name of the memory pool. +/// \param no maximum number of blocks (objects) in the memory pool. +/// \param type data type of a single block (object). +/// \note CAN BE CHANGED: The parameter to \b osPoolDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osPoolDef(name, no, type) \ +extern const osPoolDef_t os_pool_def_##name +#else // define the object +#define osPoolDef(name, no, type) \ +const osPoolDef_t os_pool_def_##name = \ +{ (no), sizeof(type), NULL } +#endif + +/// \brief Access a Memory Pool definition. +/// \param name name of the memory pool +/// \note CAN BE CHANGED: The parameter to \b osPool shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osPool(name) \ +&os_pool_def_##name + +/// Create and Initialize a memory pool. +/// \param[in] pool_def memory pool definition referenced with \ref osPool. +/// \return memory pool ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osPoolCreate shall be consistent in every CMSIS-RTOS. +osPoolId osPoolCreate (const osPoolDef_t *pool_def); + +/// Allocate a memory block from a memory pool. +/// \param[in] pool_id memory pool ID obtain referenced with \ref osPoolCreate. +/// \return address of the allocated memory block or NULL in case of no memory available. +/// \note MUST REMAIN UNCHANGED: \b osPoolAlloc shall be consistent in every CMSIS-RTOS. +void *osPoolAlloc (osPoolId pool_id); + +/// Allocate a memory block from a memory pool and set memory block to zero. +/// \param[in] pool_id memory pool ID obtain referenced with \ref osPoolCreate. +/// \return address of the allocated memory block or NULL in case of no memory available. +/// \note MUST REMAIN UNCHANGED: \b osPoolCAlloc shall be consistent in every CMSIS-RTOS. +void *osPoolCAlloc (osPoolId pool_id); + +/// Return an allocated memory block back to a specific memory pool. +/// \param[in] pool_id memory pool ID obtain referenced with \ref osPoolCreate. +/// \param[in] block address of the allocated memory block that is returned to the memory pool. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osPoolFree shall be consistent in every CMSIS-RTOS. +osStatus osPoolFree (osPoolId pool_id, void *block); + +#endif // Memory Pool Management available + + +// ==== Message Queue Management Functions ==== + +#if (defined (osFeature_MessageQ) && (osFeature_MessageQ != 0)) // Message Queues available + +/// \brief Create a Message Queue Definition. +/// \param name name of the queue. +/// \param queue_sz maximum number of messages in the queue. +/// \param type data type of a single message element (for debugger). +/// \note CAN BE CHANGED: The parameter to \b osMessageQDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osMessageQDef(name, queue_sz, type) \ +extern const osMessageQDef_t os_messageQ_def_##name +#else // define the object +#define osMessageQDef(name, queue_sz, type) \ +const osMessageQDef_t os_messageQ_def_##name = \ +{ (queue_sz), sizeof (type) } +#endif + +/// \brief Access a Message Queue Definition. +/// \param name name of the queue +/// \note CAN BE CHANGED: The parameter to \b osMessageQ shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osMessageQ(name) \ +&os_messageQ_def_##name + +/// Create and Initialize a Message Queue. +/// \param[in] queue_def queue definition referenced with \ref osMessageQ. +/// \param[in] thread_id thread ID (obtained by \ref osThreadCreate or \ref osThreadGetId) or NULL. +/// \return message queue ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osMessageCreate shall be consistent in every CMSIS-RTOS. +osMessageQId osMessageCreate (const osMessageQDef_t *queue_def, osThreadId thread_id); + +/// Put a Message to a Queue. +/// \param[in] queue_id message queue ID obtained with \ref osMessageCreate. +/// \param[in] info message information. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osMessagePut shall be consistent in every CMSIS-RTOS. +osStatus osMessagePut (osMessageQId queue_id, uint32_t info, uint32_t millisec); + +/// Get a Message or Wait for a Message from a Queue. +/// \param[in] queue_id message queue ID obtained with \ref osMessageCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return event information that includes status code. +/// \note MUST REMAIN UNCHANGED: \b osMessageGet shall be consistent in every CMSIS-RTOS. +osEvent osMessageGet (osMessageQId queue_id, uint32_t millisec); + +#endif // Message Queues available + + +// ==== Mail Queue Management Functions ==== + +#if (defined (osFeature_MailQ) && (osFeature_MailQ != 0)) // Mail Queues available + +/// \brief Create a Mail Queue Definition. +/// \param name name of the queue +/// \param queue_sz maximum number of messages in queue +/// \param type data type of a single message element +/// \note CAN BE CHANGED: The parameter to \b osMailQDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osMailQDef(name, queue_sz, type) \ +extern const osMailQDef_t os_mailQ_def_##name +#else // define the object +#define osMailQDef(name, queue_sz, type) \ +const osMailQDef_t os_mailQ_def_##name = \ +{ (queue_sz), sizeof (type) } +#endif + +/// \brief Access a Mail Queue Definition. +/// \param name name of the queue +/// \note CAN BE CHANGED: The parameter to \b osMailQ shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osMailQ(name) \ +&os_mailQ_def_##name + +/// Create and Initialize mail queue. +/// \param[in] queue_def reference to the mail queue definition obtain with \ref osMailQ +/// \param[in] thread_id thread ID (obtained by \ref osThreadCreate or \ref osThreadGetId) or NULL. +/// \return mail queue ID for reference by other functions or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osMailCreate shall be consistent in every CMSIS-RTOS. +osMailQId osMailCreate (const osMailQDef_t *queue_def, osThreadId thread_id); + +/// Allocate a memory block from a mail. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out +/// \return pointer to memory block that can be filled with mail or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osMailAlloc shall be consistent in every CMSIS-RTOS. +void *osMailAlloc (osMailQId queue_id, uint32_t millisec); + +/// Allocate a memory block from a mail and set memory block to zero. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out +/// \return pointer to memory block that can be filled with mail or NULL in case of error. +/// \note MUST REMAIN UNCHANGED: \b osMailCAlloc shall be consistent in every CMSIS-RTOS. +void *osMailCAlloc (osMailQId queue_id, uint32_t millisec); + +/// Put a mail to a queue. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] mail memory block previously allocated with \ref osMailAlloc or \ref osMailCAlloc. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osMailPut shall be consistent in every CMSIS-RTOS. +osStatus osMailPut (osMailQId queue_id, void *mail); + +/// Get a mail from a queue. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out +/// \return event that contains mail information or error code. +/// \note MUST REMAIN UNCHANGED: \b osMailGet shall be consistent in every CMSIS-RTOS. +osEvent osMailGet (osMailQId queue_id, uint32_t millisec); + +/// Free a memory block from a mail. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] mail pointer to the memory block that was obtained with \ref osMailGet. +/// \return status code that indicates the execution status of the function. +/// \note MUST REMAIN UNCHANGED: \b osMailFree shall be consistent in every CMSIS-RTOS. +osStatus osMailFree (osMailQId queue_id, void *mail); + +#endif // Mail Queues available + + +#ifdef __cplusplus +} +#endif + +#endif // _CMSIS_OS_H diff --git a/Chapter04/bare/platform/CMSIS/RTOS2/Include/cmsis_os2.h b/Chapter04/bare/platform/CMSIS/RTOS2/Include/cmsis_os2.h new file mode 100644 index 0000000..c86740d --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS2/Include/cmsis_os2.h @@ -0,0 +1,756 @@ +/* + * Copyright (c) 2013-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * ---------------------------------------------------------------------- + * + * $Date: 18. June 2018 + * $Revision: V2.1.3 + * + * Project: CMSIS-RTOS2 API + * Title: cmsis_os2.h header file + * + * Version 2.1.3 + * Additional functions allowed to be called from Interrupt Service Routines: + * - osThreadGetId + * Version 2.1.2 + * Additional functions allowed to be called from Interrupt Service Routines: + * - osKernelGetInfo, osKernelGetState + * Version 2.1.1 + * Additional functions allowed to be called from Interrupt Service Routines: + * - osKernelGetTickCount, osKernelGetTickFreq + * Changed Kernel Tick type to uint32_t: + * - updated: osKernelGetTickCount, osDelayUntil + * Version 2.1.0 + * Support for critical and uncritical sections (nesting safe): + * - updated: osKernelLock, osKernelUnlock + * - added: osKernelRestoreLock + * Updated Thread and Event Flags: + * - changed flags parameter and return type from int32_t to uint32_t + * Version 2.0.0 + * Initial Release + *---------------------------------------------------------------------------*/ + +#ifndef CMSIS_OS2_H_ +#define CMSIS_OS2_H_ + +#ifndef __NO_RETURN +#if defined(__CC_ARM) +#define __NO_RETURN __declspec(noreturn) +#elif defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) +#define __NO_RETURN __attribute__((__noreturn__)) +#elif defined(__GNUC__) +#define __NO_RETURN __attribute__((__noreturn__)) +#elif defined(__ICCARM__) +#define __NO_RETURN __noreturn +#else +#define __NO_RETURN +#endif +#endif + +#include +#include + +#ifdef __cplusplus +extern "C" +{ +#endif + + +// ==== Enumerations, structures, defines ==== + +/// Version information. +typedef struct { + uint32_t api; ///< API version (major.minor.rev: mmnnnrrrr dec). + uint32_t kernel; ///< Kernel version (major.minor.rev: mmnnnrrrr dec). +} osVersion_t; + +/// Kernel state. +typedef enum { + osKernelInactive = 0, ///< Inactive. + osKernelReady = 1, ///< Ready. + osKernelRunning = 2, ///< Running. + osKernelLocked = 3, ///< Locked. + osKernelSuspended = 4, ///< Suspended. + osKernelError = -1, ///< Error. + osKernelReserved = 0x7FFFFFFFU ///< Prevents enum down-size compiler optimization. +} osKernelState_t; + +/// Thread state. +typedef enum { + osThreadInactive = 0, ///< Inactive. + osThreadReady = 1, ///< Ready. + osThreadRunning = 2, ///< Running. + osThreadBlocked = 3, ///< Blocked. + osThreadTerminated = 4, ///< Terminated. + osThreadError = -1, ///< Error. + osThreadReserved = 0x7FFFFFFF ///< Prevents enum down-size compiler optimization. +} osThreadState_t; + +/// Priority values. +typedef enum { + osPriorityNone = 0, ///< No priority (not initialized). + osPriorityIdle = 1, ///< Reserved for Idle thread. + osPriorityLow = 8, ///< Priority: low + osPriorityLow1 = 8+1, ///< Priority: low + 1 + osPriorityLow2 = 8+2, ///< Priority: low + 2 + osPriorityLow3 = 8+3, ///< Priority: low + 3 + osPriorityLow4 = 8+4, ///< Priority: low + 4 + osPriorityLow5 = 8+5, ///< Priority: low + 5 + osPriorityLow6 = 8+6, ///< Priority: low + 6 + osPriorityLow7 = 8+7, ///< Priority: low + 7 + osPriorityBelowNormal = 16, ///< Priority: below normal + osPriorityBelowNormal1 = 16+1, ///< Priority: below normal + 1 + osPriorityBelowNormal2 = 16+2, ///< Priority: below normal + 2 + osPriorityBelowNormal3 = 16+3, ///< Priority: below normal + 3 + osPriorityBelowNormal4 = 16+4, ///< Priority: below normal + 4 + osPriorityBelowNormal5 = 16+5, ///< Priority: below normal + 5 + osPriorityBelowNormal6 = 16+6, ///< Priority: below normal + 6 + osPriorityBelowNormal7 = 16+7, ///< Priority: below normal + 7 + osPriorityNormal = 24, ///< Priority: normal + osPriorityNormal1 = 24+1, ///< Priority: normal + 1 + osPriorityNormal2 = 24+2, ///< Priority: normal + 2 + osPriorityNormal3 = 24+3, ///< Priority: normal + 3 + osPriorityNormal4 = 24+4, ///< Priority: normal + 4 + osPriorityNormal5 = 24+5, ///< Priority: normal + 5 + osPriorityNormal6 = 24+6, ///< Priority: normal + 6 + osPriorityNormal7 = 24+7, ///< Priority: normal + 7 + osPriorityAboveNormal = 32, ///< Priority: above normal + osPriorityAboveNormal1 = 32+1, ///< Priority: above normal + 1 + osPriorityAboveNormal2 = 32+2, ///< Priority: above normal + 2 + osPriorityAboveNormal3 = 32+3, ///< Priority: above normal + 3 + osPriorityAboveNormal4 = 32+4, ///< Priority: above normal + 4 + osPriorityAboveNormal5 = 32+5, ///< Priority: above normal + 5 + osPriorityAboveNormal6 = 32+6, ///< Priority: above normal + 6 + osPriorityAboveNormal7 = 32+7, ///< Priority: above normal + 7 + osPriorityHigh = 40, ///< Priority: high + osPriorityHigh1 = 40+1, ///< Priority: high + 1 + osPriorityHigh2 = 40+2, ///< Priority: high + 2 + osPriorityHigh3 = 40+3, ///< Priority: high + 3 + osPriorityHigh4 = 40+4, ///< Priority: high + 4 + osPriorityHigh5 = 40+5, ///< Priority: high + 5 + osPriorityHigh6 = 40+6, ///< Priority: high + 6 + osPriorityHigh7 = 40+7, ///< Priority: high + 7 + osPriorityRealtime = 48, ///< Priority: realtime + osPriorityRealtime1 = 48+1, ///< Priority: realtime + 1 + osPriorityRealtime2 = 48+2, ///< Priority: realtime + 2 + osPriorityRealtime3 = 48+3, ///< Priority: realtime + 3 + osPriorityRealtime4 = 48+4, ///< Priority: realtime + 4 + osPriorityRealtime5 = 48+5, ///< Priority: realtime + 5 + osPriorityRealtime6 = 48+6, ///< Priority: realtime + 6 + osPriorityRealtime7 = 48+7, ///< Priority: realtime + 7 + osPriorityISR = 56, ///< Reserved for ISR deferred thread. + osPriorityError = -1, ///< System cannot determine priority or illegal priority. + osPriorityReserved = 0x7FFFFFFF ///< Prevents enum down-size compiler optimization. +} osPriority_t; + +/// Entry point of a thread. +typedef void (*osThreadFunc_t) (void *argument); + +/// Timer callback function. +typedef void (*osTimerFunc_t) (void *argument); + +/// Timer type. +typedef enum { + osTimerOnce = 0, ///< One-shot timer. + osTimerPeriodic = 1 ///< Repeating timer. +} osTimerType_t; + +// Timeout value. +#define osWaitForever 0xFFFFFFFFU ///< Wait forever timeout value. + +// Flags options (\ref osThreadFlagsWait and \ref osEventFlagsWait). +#define osFlagsWaitAny 0x00000000U ///< Wait for any flag (default). +#define osFlagsWaitAll 0x00000001U ///< Wait for all flags. +#define osFlagsNoClear 0x00000002U ///< Do not clear flags which have been specified to wait for. + +// Flags errors (returned by osThreadFlagsXxxx and osEventFlagsXxxx). +#define osFlagsError 0x80000000U ///< Error indicator. +#define osFlagsErrorUnknown 0xFFFFFFFFU ///< osError (-1). +#define osFlagsErrorTimeout 0xFFFFFFFEU ///< osErrorTimeout (-2). +#define osFlagsErrorResource 0xFFFFFFFDU ///< osErrorResource (-3). +#define osFlagsErrorParameter 0xFFFFFFFCU ///< osErrorParameter (-4). +#define osFlagsErrorISR 0xFFFFFFFAU ///< osErrorISR (-6). + +// Thread attributes (attr_bits in \ref osThreadAttr_t). +#define osThreadDetached 0x00000000U ///< Thread created in detached mode (default) +#define osThreadJoinable 0x00000001U ///< Thread created in joinable mode + +// Mutex attributes (attr_bits in \ref osMutexAttr_t). +#define osMutexRecursive 0x00000001U ///< Recursive mutex. +#define osMutexPrioInherit 0x00000002U ///< Priority inherit protocol. +#define osMutexRobust 0x00000008U ///< Robust mutex. + +/// Status code values returned by CMSIS-RTOS functions. +typedef enum { + osOK = 0, ///< Operation completed successfully. + osError = -1, ///< Unspecified RTOS error: run-time error but no other error message fits. + osErrorTimeout = -2, ///< Operation not completed within the timeout period. + osErrorResource = -3, ///< Resource not available. + osErrorParameter = -4, ///< Parameter error. + osErrorNoMemory = -5, ///< System is out of memory: it was impossible to allocate or reserve memory for the operation. + osErrorISR = -6, ///< Not allowed in ISR context: the function cannot be called from interrupt service routines. + osStatusReserved = 0x7FFFFFFF ///< Prevents enum down-size compiler optimization. +} osStatus_t; + + +/// \details Thread ID identifies the thread. +typedef void *osThreadId_t; + +/// \details Timer ID identifies the timer. +typedef void *osTimerId_t; + +/// \details Event Flags ID identifies the event flags. +typedef void *osEventFlagsId_t; + +/// \details Mutex ID identifies the mutex. +typedef void *osMutexId_t; + +/// \details Semaphore ID identifies the semaphore. +typedef void *osSemaphoreId_t; + +/// \details Memory Pool ID identifies the memory pool. +typedef void *osMemoryPoolId_t; + +/// \details Message Queue ID identifies the message queue. +typedef void *osMessageQueueId_t; + + +#ifndef TZ_MODULEID_T +#define TZ_MODULEID_T +/// \details Data type that identifies secure software modules called by a process. +typedef uint32_t TZ_ModuleId_t; +#endif + + +/// Attributes structure for thread. +typedef struct { + const char *name; ///< name of the thread + uint32_t attr_bits; ///< attribute bits + void *cb_mem; ///< memory for control block + uint32_t cb_size; ///< size of provided memory for control block + void *stack_mem; ///< memory for stack + uint32_t stack_size; ///< size of stack + osPriority_t priority; ///< initial thread priority (default: osPriorityNormal) + TZ_ModuleId_t tz_module; ///< TrustZone module identifier + uint32_t reserved; ///< reserved (must be 0) +} osThreadAttr_t; + +/// Attributes structure for timer. +typedef struct { + const char *name; ///< name of the timer + uint32_t attr_bits; ///< attribute bits + void *cb_mem; ///< memory for control block + uint32_t cb_size; ///< size of provided memory for control block +} osTimerAttr_t; + +/// Attributes structure for event flags. +typedef struct { + const char *name; ///< name of the event flags + uint32_t attr_bits; ///< attribute bits + void *cb_mem; ///< memory for control block + uint32_t cb_size; ///< size of provided memory for control block +} osEventFlagsAttr_t; + +/// Attributes structure for mutex. +typedef struct { + const char *name; ///< name of the mutex + uint32_t attr_bits; ///< attribute bits + void *cb_mem; ///< memory for control block + uint32_t cb_size; ///< size of provided memory for control block +} osMutexAttr_t; + +/// Attributes structure for semaphore. +typedef struct { + const char *name; ///< name of the semaphore + uint32_t attr_bits; ///< attribute bits + void *cb_mem; ///< memory for control block + uint32_t cb_size; ///< size of provided memory for control block +} osSemaphoreAttr_t; + +/// Attributes structure for memory pool. +typedef struct { + const char *name; ///< name of the memory pool + uint32_t attr_bits; ///< attribute bits + void *cb_mem; ///< memory for control block + uint32_t cb_size; ///< size of provided memory for control block + void *mp_mem; ///< memory for data storage + uint32_t mp_size; ///< size of provided memory for data storage +} osMemoryPoolAttr_t; + +/// Attributes structure for message queue. +typedef struct { + const char *name; ///< name of the message queue + uint32_t attr_bits; ///< attribute bits + void *cb_mem; ///< memory for control block + uint32_t cb_size; ///< size of provided memory for control block + void *mq_mem; ///< memory for data storage + uint32_t mq_size; ///< size of provided memory for data storage +} osMessageQueueAttr_t; + + +// ==== Kernel Management Functions ==== + +/// Initialize the RTOS Kernel. +/// \return status code that indicates the execution status of the function. +osStatus_t osKernelInitialize (void); + +/// Get RTOS Kernel Information. +/// \param[out] version pointer to buffer for retrieving version information. +/// \param[out] id_buf pointer to buffer for retrieving kernel identification string. +/// \param[in] id_size size of buffer for kernel identification string. +/// \return status code that indicates the execution status of the function. +osStatus_t osKernelGetInfo (osVersion_t *version, char *id_buf, uint32_t id_size); + +/// Get the current RTOS Kernel state. +/// \return current RTOS Kernel state. +osKernelState_t osKernelGetState (void); + +/// Start the RTOS Kernel scheduler. +/// \return status code that indicates the execution status of the function. +osStatus_t osKernelStart (void); + +/// Lock the RTOS Kernel scheduler. +/// \return previous lock state (1 - locked, 0 - not locked, error code if negative). +int32_t osKernelLock (void); + +/// Unlock the RTOS Kernel scheduler. +/// \return previous lock state (1 - locked, 0 - not locked, error code if negative). +int32_t osKernelUnlock (void); + +/// Restore the RTOS Kernel scheduler lock state. +/// \param[in] lock lock state obtained by \ref osKernelLock or \ref osKernelUnlock. +/// \return new lock state (1 - locked, 0 - not locked, error code if negative). +int32_t osKernelRestoreLock (int32_t lock); + +/// Suspend the RTOS Kernel scheduler. +/// \return time in ticks, for how long the system can sleep or power-down. +uint32_t osKernelSuspend (void); + +/// Resume the RTOS Kernel scheduler. +/// \param[in] sleep_ticks time in ticks for how long the system was in sleep or power-down mode. +void osKernelResume (uint32_t sleep_ticks); + +/// Get the RTOS kernel tick count. +/// \return RTOS kernel current tick count. +uint32_t osKernelGetTickCount (void); + +/// Get the RTOS kernel tick frequency. +/// \return frequency of the kernel tick in hertz, i.e. kernel ticks per second. +uint32_t osKernelGetTickFreq (void); + +/// Get the RTOS kernel system timer count. +/// \return RTOS kernel current system timer count as 32-bit value. +uint32_t osKernelGetSysTimerCount (void); + +/// Get the RTOS kernel system timer frequency. +/// \return frequency of the system timer in hertz, i.e. timer ticks per second. +uint32_t osKernelGetSysTimerFreq (void); + + +// ==== Thread Management Functions ==== + +/// Create a thread and add it to Active Threads. +/// \param[in] func thread function. +/// \param[in] argument pointer that is passed to the thread function as start argument. +/// \param[in] attr thread attributes; NULL: default values. +/// \return thread ID for reference by other functions or NULL in case of error. +osThreadId_t osThreadNew (osThreadFunc_t func, void *argument, const osThreadAttr_t *attr); + +/// Get name of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return name as null-terminated string. +const char *osThreadGetName (osThreadId_t thread_id); + +/// Return the thread ID of the current running thread. +/// \return thread ID for reference by other functions or NULL in case of error. +osThreadId_t osThreadGetId (void); + +/// Get current thread state of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return current thread state of the specified thread. +osThreadState_t osThreadGetState (osThreadId_t thread_id); + +/// Get stack size of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return stack size in bytes. +uint32_t osThreadGetStackSize (osThreadId_t thread_id); + +/// Get available stack space of a thread based on stack watermark recording during execution. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return remaining stack space in bytes. +uint32_t osThreadGetStackSpace (osThreadId_t thread_id); + +/// Change priority of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \param[in] priority new priority value for the thread function. +/// \return status code that indicates the execution status of the function. +osStatus_t osThreadSetPriority (osThreadId_t thread_id, osPriority_t priority); + +/// Get current priority of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return current priority value of the specified thread. +osPriority_t osThreadGetPriority (osThreadId_t thread_id); + +/// Pass control to next thread that is in state \b READY. +/// \return status code that indicates the execution status of the function. +osStatus_t osThreadYield (void); + +/// Suspend execution of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return status code that indicates the execution status of the function. +osStatus_t osThreadSuspend (osThreadId_t thread_id); + +/// Resume execution of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return status code that indicates the execution status of the function. +osStatus_t osThreadResume (osThreadId_t thread_id); + +/// Detach a thread (thread storage can be reclaimed when thread terminates). +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return status code that indicates the execution status of the function. +osStatus_t osThreadDetach (osThreadId_t thread_id); + +/// Wait for specified thread to terminate. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return status code that indicates the execution status of the function. +osStatus_t osThreadJoin (osThreadId_t thread_id); + +/// Terminate execution of current running thread. +__NO_RETURN void osThreadExit (void); + +/// Terminate execution of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \return status code that indicates the execution status of the function. +osStatus_t osThreadTerminate (osThreadId_t thread_id); + +/// Get number of active threads. +/// \return number of active threads. +uint32_t osThreadGetCount (void); + +/// Enumerate active threads. +/// \param[out] thread_array pointer to array for retrieving thread IDs. +/// \param[in] array_items maximum number of items in array for retrieving thread IDs. +/// \return number of enumerated threads. +uint32_t osThreadEnumerate (osThreadId_t *thread_array, uint32_t array_items); + + +// ==== Thread Flags Functions ==== + +/// Set the specified Thread Flags of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadNew or \ref osThreadGetId. +/// \param[in] flags specifies the flags of the thread that shall be set. +/// \return thread flags after setting or error code if highest bit set. +uint32_t osThreadFlagsSet (osThreadId_t thread_id, uint32_t flags); + +/// Clear the specified Thread Flags of current running thread. +/// \param[in] flags specifies the flags of the thread that shall be cleared. +/// \return thread flags before clearing or error code if highest bit set. +uint32_t osThreadFlagsClear (uint32_t flags); + +/// Get the current Thread Flags of current running thread. +/// \return current thread flags. +uint32_t osThreadFlagsGet (void); + +/// Wait for one or more Thread Flags of the current running thread to become signaled. +/// \param[in] flags specifies the flags to wait for. +/// \param[in] options specifies flags options (osFlagsXxxx). +/// \param[in] timeout \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return thread flags before clearing or error code if highest bit set. +uint32_t osThreadFlagsWait (uint32_t flags, uint32_t options, uint32_t timeout); + + +// ==== Generic Wait Functions ==== + +/// Wait for Timeout (Time Delay). +/// \param[in] ticks \ref CMSIS_RTOS_TimeOutValue "time ticks" value +/// \return status code that indicates the execution status of the function. +osStatus_t osDelay (uint32_t ticks); + +/// Wait until specified time. +/// \param[in] ticks absolute time in ticks +/// \return status code that indicates the execution status of the function. +osStatus_t osDelayUntil (uint32_t ticks); + + +// ==== Timer Management Functions ==== + +/// Create and Initialize a timer. +/// \param[in] func function pointer to callback function. +/// \param[in] type \ref osTimerOnce for one-shot or \ref osTimerPeriodic for periodic behavior. +/// \param[in] argument argument to the timer callback function. +/// \param[in] attr timer attributes; NULL: default values. +/// \return timer ID for reference by other functions or NULL in case of error. +osTimerId_t osTimerNew (osTimerFunc_t func, osTimerType_t type, void *argument, const osTimerAttr_t *attr); + +/// Get name of a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerNew. +/// \return name as null-terminated string. +const char *osTimerGetName (osTimerId_t timer_id); + +/// Start or restart a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerNew. +/// \param[in] ticks \ref CMSIS_RTOS_TimeOutValue "time ticks" value of the timer. +/// \return status code that indicates the execution status of the function. +osStatus_t osTimerStart (osTimerId_t timer_id, uint32_t ticks); + +/// Stop a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osTimerStop (osTimerId_t timer_id); + +/// Check if a timer is running. +/// \param[in] timer_id timer ID obtained by \ref osTimerNew. +/// \return 0 not running, 1 running. +uint32_t osTimerIsRunning (osTimerId_t timer_id); + +/// Delete a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osTimerDelete (osTimerId_t timer_id); + + +// ==== Event Flags Management Functions ==== + +/// Create and Initialize an Event Flags object. +/// \param[in] attr event flags attributes; NULL: default values. +/// \return event flags ID for reference by other functions or NULL in case of error. +osEventFlagsId_t osEventFlagsNew (const osEventFlagsAttr_t *attr); + +/// Get name of an Event Flags object. +/// \param[in] ef_id event flags ID obtained by \ref osEventFlagsNew. +/// \return name as null-terminated string. +const char *osEventFlagsGetName (osEventFlagsId_t ef_id); + +/// Set the specified Event Flags. +/// \param[in] ef_id event flags ID obtained by \ref osEventFlagsNew. +/// \param[in] flags specifies the flags that shall be set. +/// \return event flags after setting or error code if highest bit set. +uint32_t osEventFlagsSet (osEventFlagsId_t ef_id, uint32_t flags); + +/// Clear the specified Event Flags. +/// \param[in] ef_id event flags ID obtained by \ref osEventFlagsNew. +/// \param[in] flags specifies the flags that shall be cleared. +/// \return event flags before clearing or error code if highest bit set. +uint32_t osEventFlagsClear (osEventFlagsId_t ef_id, uint32_t flags); + +/// Get the current Event Flags. +/// \param[in] ef_id event flags ID obtained by \ref osEventFlagsNew. +/// \return current event flags. +uint32_t osEventFlagsGet (osEventFlagsId_t ef_id); + +/// Wait for one or more Event Flags to become signaled. +/// \param[in] ef_id event flags ID obtained by \ref osEventFlagsNew. +/// \param[in] flags specifies the flags to wait for. +/// \param[in] options specifies flags options (osFlagsXxxx). +/// \param[in] timeout \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return event flags before clearing or error code if highest bit set. +uint32_t osEventFlagsWait (osEventFlagsId_t ef_id, uint32_t flags, uint32_t options, uint32_t timeout); + +/// Delete an Event Flags object. +/// \param[in] ef_id event flags ID obtained by \ref osEventFlagsNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osEventFlagsDelete (osEventFlagsId_t ef_id); + + +// ==== Mutex Management Functions ==== + +/// Create and Initialize a Mutex object. +/// \param[in] attr mutex attributes; NULL: default values. +/// \return mutex ID for reference by other functions or NULL in case of error. +osMutexId_t osMutexNew (const osMutexAttr_t *attr); + +/// Get name of a Mutex object. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexNew. +/// \return name as null-terminated string. +const char *osMutexGetName (osMutexId_t mutex_id); + +/// Acquire a Mutex or timeout if it is locked. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexNew. +/// \param[in] timeout \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +osStatus_t osMutexAcquire (osMutexId_t mutex_id, uint32_t timeout); + +/// Release a Mutex that was acquired by \ref osMutexAcquire. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osMutexRelease (osMutexId_t mutex_id); + +/// Get Thread which owns a Mutex object. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexNew. +/// \return thread ID of owner thread or NULL when mutex was not acquired. +osThreadId_t osMutexGetOwner (osMutexId_t mutex_id); + +/// Delete a Mutex object. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osMutexDelete (osMutexId_t mutex_id); + + +// ==== Semaphore Management Functions ==== + +/// Create and Initialize a Semaphore object. +/// \param[in] max_count maximum number of available tokens. +/// \param[in] initial_count initial number of available tokens. +/// \param[in] attr semaphore attributes; NULL: default values. +/// \return semaphore ID for reference by other functions or NULL in case of error. +osSemaphoreId_t osSemaphoreNew (uint32_t max_count, uint32_t initial_count, const osSemaphoreAttr_t *attr); + +/// Get name of a Semaphore object. +/// \param[in] semaphore_id semaphore ID obtained by \ref osSemaphoreNew. +/// \return name as null-terminated string. +const char *osSemaphoreGetName (osSemaphoreId_t semaphore_id); + +/// Acquire a Semaphore token or timeout if no tokens are available. +/// \param[in] semaphore_id semaphore ID obtained by \ref osSemaphoreNew. +/// \param[in] timeout \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +osStatus_t osSemaphoreAcquire (osSemaphoreId_t semaphore_id, uint32_t timeout); + +/// Release a Semaphore token up to the initial maximum count. +/// \param[in] semaphore_id semaphore ID obtained by \ref osSemaphoreNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osSemaphoreRelease (osSemaphoreId_t semaphore_id); + +/// Get current Semaphore token count. +/// \param[in] semaphore_id semaphore ID obtained by \ref osSemaphoreNew. +/// \return number of tokens available. +uint32_t osSemaphoreGetCount (osSemaphoreId_t semaphore_id); + +/// Delete a Semaphore object. +/// \param[in] semaphore_id semaphore ID obtained by \ref osSemaphoreNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osSemaphoreDelete (osSemaphoreId_t semaphore_id); + + +// ==== Memory Pool Management Functions ==== + +/// Create and Initialize a Memory Pool object. +/// \param[in] block_count maximum number of memory blocks in memory pool. +/// \param[in] block_size memory block size in bytes. +/// \param[in] attr memory pool attributes; NULL: default values. +/// \return memory pool ID for reference by other functions or NULL in case of error. +osMemoryPoolId_t osMemoryPoolNew (uint32_t block_count, uint32_t block_size, const osMemoryPoolAttr_t *attr); + +/// Get name of a Memory Pool object. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \return name as null-terminated string. +const char *osMemoryPoolGetName (osMemoryPoolId_t mp_id); + +/// Allocate a memory block from a Memory Pool. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \param[in] timeout \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return address of the allocated memory block or NULL in case of no memory is available. +void *osMemoryPoolAlloc (osMemoryPoolId_t mp_id, uint32_t timeout); + +/// Return an allocated memory block back to a Memory Pool. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \param[in] block address of the allocated memory block to be returned to the memory pool. +/// \return status code that indicates the execution status of the function. +osStatus_t osMemoryPoolFree (osMemoryPoolId_t mp_id, void *block); + +/// Get maximum number of memory blocks in a Memory Pool. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \return maximum number of memory blocks. +uint32_t osMemoryPoolGetCapacity (osMemoryPoolId_t mp_id); + +/// Get memory block size in a Memory Pool. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \return memory block size in bytes. +uint32_t osMemoryPoolGetBlockSize (osMemoryPoolId_t mp_id); + +/// Get number of memory blocks used in a Memory Pool. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \return number of memory blocks used. +uint32_t osMemoryPoolGetCount (osMemoryPoolId_t mp_id); + +/// Get number of memory blocks available in a Memory Pool. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \return number of memory blocks available. +uint32_t osMemoryPoolGetSpace (osMemoryPoolId_t mp_id); + +/// Delete a Memory Pool object. +/// \param[in] mp_id memory pool ID obtained by \ref osMemoryPoolNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osMemoryPoolDelete (osMemoryPoolId_t mp_id); + + +// ==== Message Queue Management Functions ==== + +/// Create and Initialize a Message Queue object. +/// \param[in] msg_count maximum number of messages in queue. +/// \param[in] msg_size maximum message size in bytes. +/// \param[in] attr message queue attributes; NULL: default values. +/// \return message queue ID for reference by other functions or NULL in case of error. +osMessageQueueId_t osMessageQueueNew (uint32_t msg_count, uint32_t msg_size, const osMessageQueueAttr_t *attr); + +/// Get name of a Message Queue object. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \return name as null-terminated string. +const char *osMessageQueueGetName (osMessageQueueId_t mq_id); + +/// Put a Message into a Queue or timeout if Queue is full. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \param[in] msg_ptr pointer to buffer with message to put into a queue. +/// \param[in] msg_prio message priority. +/// \param[in] timeout \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +osStatus_t osMessageQueuePut (osMessageQueueId_t mq_id, const void *msg_ptr, uint8_t msg_prio, uint32_t timeout); + +/// Get a Message from a Queue or timeout if Queue is empty. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \param[out] msg_ptr pointer to buffer for message to get from a queue. +/// \param[out] msg_prio pointer to buffer for message priority or NULL. +/// \param[in] timeout \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +osStatus_t osMessageQueueGet (osMessageQueueId_t mq_id, void *msg_ptr, uint8_t *msg_prio, uint32_t timeout); + +/// Get maximum number of messages in a Message Queue. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \return maximum number of messages. +uint32_t osMessageQueueGetCapacity (osMessageQueueId_t mq_id); + +/// Get maximum message size in a Memory Pool. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \return maximum message size in bytes. +uint32_t osMessageQueueGetMsgSize (osMessageQueueId_t mq_id); + +/// Get number of queued messages in a Message Queue. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \return number of queued messages. +uint32_t osMessageQueueGetCount (osMessageQueueId_t mq_id); + +/// Get number of available slots for messages in a Message Queue. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \return number of available slots for messages. +uint32_t osMessageQueueGetSpace (osMessageQueueId_t mq_id); + +/// Reset a Message Queue to initial empty state. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osMessageQueueReset (osMessageQueueId_t mq_id); + +/// Delete a Message Queue object. +/// \param[in] mq_id message queue ID obtained by \ref osMessageQueueNew. +/// \return status code that indicates the execution status of the function. +osStatus_t osMessageQueueDelete (osMessageQueueId_t mq_id); + + +#ifdef __cplusplus +} +#endif + +#endif // CMSIS_OS2_H_ diff --git a/Chapter04/bare/platform/CMSIS/RTOS2/Include/os_tick.h b/Chapter04/bare/platform/CMSIS/RTOS2/Include/os_tick.h new file mode 100644 index 0000000..dfeb953 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS2/Include/os_tick.h @@ -0,0 +1,71 @@ +/**************************************************************************//** + * @file os_tick.h + * @brief CMSIS OS Tick header file + * @version V1.0.1 + * @date 24. November 2017 + ******************************************************************************/ +/* + * Copyright (c) 2017-2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef OS_TICK_H +#define OS_TICK_H + +#include + +/// IRQ Handler. +#ifndef IRQHANDLER_T +#define IRQHANDLER_T +typedef void (*IRQHandler_t) (void); +#endif + +/// Setup OS Tick timer to generate periodic RTOS Kernel Ticks +/// \param[in] freq tick frequency in Hz +/// \param[in] handler tick IRQ handler +/// \return 0 on success, -1 on error. +int32_t OS_Tick_Setup (uint32_t freq, IRQHandler_t handler); + +/// Enable OS Tick timer interrupt +void OS_Tick_Enable (void); + +/// Disable OS Tick timer interrupt +void OS_Tick_Disable (void); + +/// Acknowledge execution of OS Tick timer interrupt +void OS_Tick_AcknowledgeIRQ (void); + +/// Get OS Tick timer IRQ number +/// \return OS Tick IRQ number +int32_t OS_Tick_GetIRQn (void); + +/// Get OS Tick timer clock frequency +/// \return OS Tick timer clock frequency in Hz +uint32_t OS_Tick_GetClock (void); + +/// Get OS Tick timer interval reload value +/// \return OS Tick timer interval reload value +uint32_t OS_Tick_GetInterval (void); + +/// Get OS Tick timer counter value +/// \return OS Tick timer counter value +uint32_t OS_Tick_GetCount (void); + +/// Get OS Tick timer overflow status +/// \return OS Tick overflow status (1 - overflow, 0 - no overflow). +uint32_t OS_Tick_GetOverflow (void); + +#endif /* OS_TICK_H */ diff --git a/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_systick.c b/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_systick.c new file mode 100644 index 0000000..f114caa --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_systick.c @@ -0,0 +1,132 @@ +/**************************************************************************//** + * @file os_systick.c + * @brief CMSIS OS Tick SysTick implementation + * @version V1.0.1 + * @date 24. November 2017 + ******************************************************************************/ +/* + * Copyright (c) 2017-2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "os_tick.h" + +//lint -emacro((923,9078),SCB,SysTick) "cast from unsigned long to pointer" +#include "RTE_Components.h" +#include CMSIS_device_header + +#ifdef SysTick + +#ifndef SYSTICK_IRQ_PRIORITY +#define SYSTICK_IRQ_PRIORITY 0xFFU +#endif + +static uint8_t PendST; + +// Setup OS Tick. +__WEAK int32_t OS_Tick_Setup (uint32_t freq, IRQHandler_t handler) { + uint32_t load; + (void)handler; + + if (freq == 0U) { + //lint -e{904} "Return statement before end of function" + return (-1); + } + + load = (SystemCoreClock / freq) - 1U; + if (load > 0x00FFFFFFU) { + //lint -e{904} "Return statement before end of function" + return (-1); + } + + // Set SysTick Interrupt Priority +#if ((defined(__ARM_ARCH_8M_MAIN__) && (__ARM_ARCH_8M_MAIN__ != 0)) || \ + (defined(__CORTEX_M) && (__CORTEX_M == 7U))) + SCB->SHPR[11] = SYSTICK_IRQ_PRIORITY; +#elif (defined(__ARM_ARCH_8M_BASE__) && (__ARM_ARCH_8M_BASE__ != 0)) + SCB->SHPR[1] |= ((uint32_t)SYSTICK_IRQ_PRIORITY << 24); +#elif ((defined(__ARM_ARCH_7M__) && (__ARM_ARCH_7M__ != 0)) || \ + (defined(__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ != 0))) + SCB->SHP[11] = SYSTICK_IRQ_PRIORITY; +#elif (defined(__ARM_ARCH_6M__) && (__ARM_ARCH_6M__ != 0)) + SCB->SHP[1] |= ((uint32_t)SYSTICK_IRQ_PRIORITY << 24); +#else +#error "Unknown ARM Core!" +#endif + + SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk | SysTick_CTRL_TICKINT_Msk; + SysTick->LOAD = load; + SysTick->VAL = 0U; + + PendST = 0U; + + return (0); +} + +/// Enable OS Tick. +__WEAK void OS_Tick_Enable (void) { + + if (PendST != 0U) { + PendST = 0U; + SCB->ICSR = SCB_ICSR_PENDSTSET_Msk; + } + + SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk; +} + +/// Disable OS Tick. +__WEAK void OS_Tick_Disable (void) { + + SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk; + + if ((SCB->ICSR & SCB_ICSR_PENDSTSET_Msk) != 0U) { + SCB->ICSR = SCB_ICSR_PENDSTCLR_Msk; + PendST = 1U; + } +} + +// Acknowledge OS Tick IRQ. +__WEAK void OS_Tick_AcknowledgeIRQ (void) { + (void)SysTick->CTRL; +} + +// Get OS Tick IRQ number. +__WEAK int32_t OS_Tick_GetIRQn (void) { + return ((int32_t)SysTick_IRQn); +} + +// Get OS Tick clock. +__WEAK uint32_t OS_Tick_GetClock (void) { + return (SystemCoreClock); +} + +// Get OS Tick interval. +__WEAK uint32_t OS_Tick_GetInterval (void) { + return (SysTick->LOAD + 1U); +} + +// Get OS Tick count value. +__WEAK uint32_t OS_Tick_GetCount (void) { + uint32_t load = SysTick->LOAD; + return (load - SysTick->VAL); +} + +// Get OS Tick overflow status. +__WEAK uint32_t OS_Tick_GetOverflow (void) { + return ((SysTick->CTRL >> 16) & 1U); +} + +#endif // SysTick diff --git a/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_gtim.c b/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_gtim.c new file mode 100644 index 0000000..1778ab7 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_gtim.c @@ -0,0 +1,187 @@ +/**************************************************************************//** + * @file os_tick_gtim.c + * @brief CMSIS OS Tick implementation for Generic Timer + * @version V1.0.1 + * @date 24. November 2017 + ******************************************************************************/ +/* + * Copyright (c) 2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "os_tick.h" +#include "irq_ctrl.h" + +#include "RTE_Components.h" +#include CMSIS_device_header + +#ifndef GTIM_IRQ_PRIORITY +#define GTIM_IRQ_PRIORITY 0xFFU +#endif + +#ifndef GTIM_IRQ_NUM +#define GTIM_IRQ_NUM SecurePhyTimer_IRQn +#endif + +// Timer interrupt pending flag +static uint8_t GTIM_PendIRQ; + +// Timer tick frequency +static uint32_t GTIM_Clock; + +// Timer load value +static uint32_t GTIM_Load; + +// Setup OS Tick. +int32_t OS_Tick_Setup (uint32_t freq, IRQHandler_t handler) { + uint32_t prio, bits; + + if (freq == 0U) { + return (-1); + } + + GTIM_PendIRQ = 0U; + + // Get timer clock +#ifdef SCTR_BASE + GTIM_Clock = *(uint32_t*)(SCTR_BASE+0x20); +#else + // FVP REFCLK CNTControl 100MHz + GTIM_Clock = 100000000UL; +#endif + + PL1_SetCounterFrequency(GTIM_Clock); + + // Calculate load value + GTIM_Load = (GTIM_Clock / freq) - 1U; + + // Disable Generic Timer and set load value + PL1_SetControl(0U); + PL1_SetLoadValue(GTIM_Load); + + // Disable corresponding IRQ + IRQ_Disable(GTIM_IRQ_NUM); + IRQ_ClearPending(GTIM_IRQ_NUM); + + // Determine number of implemented priority bits + IRQ_SetPriority(GTIM_IRQ_NUM, 0xFFU); + + prio = IRQ_GetPriority(GTIM_IRQ_NUM); + + // At least bits [7:4] must be implemented + if ((prio & 0xF0U) == 0U) { + return (-1); + } + + for (bits = 0; bits < 4; bits++) { + if ((prio & 0x01) != 0) { + break; + } + prio >>= 1; + } + + // Adjust configured priority to the number of implemented priority bits + prio = (GTIM_IRQ_PRIORITY << bits) & 0xFFUL; + + // Set Private Timer interrupt priority + IRQ_SetPriority(GTIM_IRQ_NUM, prio-1U); + + // Set edge-triggered IRQ + IRQ_SetMode(GTIM_IRQ_NUM, IRQ_MODE_TRIG_EDGE); + + // Register tick interrupt handler function + IRQ_SetHandler(GTIM_IRQ_NUM, handler); + + // Enable corresponding interrupt + IRQ_Enable(GTIM_IRQ_NUM); + + // Enable system counter and timer control +#ifdef SCTR_BASE + *(uint32_t*)SCTR_BASE |= 3U; +#endif + + // Enable timer control + PL1_SetControl(1U); + + return (0); +} + +/// Enable OS Tick. +void OS_Tick_Enable (void) { + uint32_t ctrl; + + // Set pending interrupt if flag set + if (GTIM_PendIRQ != 0U) { + GTIM_PendIRQ = 0U; + IRQ_SetPending (GTIM_IRQ_NUM); + } + + // Start the Private Timer + ctrl = PL1_GetControl(); + // Set bit: Timer enable + ctrl |= 1U; + PL1_SetControl(ctrl); +} + +/// Disable OS Tick. +void OS_Tick_Disable (void) { + uint32_t ctrl; + + // Stop the Private Timer + ctrl = PL1_GetControl(); + // Clear bit: Timer enable + ctrl &= ~1U; + PL1_SetControl(ctrl); + + // Remember pending interrupt flag + if (IRQ_GetPending(GTIM_IRQ_NUM) != 0) { + IRQ_ClearPending(GTIM_IRQ_NUM); + GTIM_PendIRQ = 1U; + } +} + +// Acknowledge OS Tick IRQ. +void OS_Tick_AcknowledgeIRQ (void) { + IRQ_ClearPending (GTIM_IRQ_NUM); + PL1_SetLoadValue(GTIM_Load); +} + +// Get OS Tick IRQ number. +int32_t OS_Tick_GetIRQn (void) { + return (GTIM_IRQ_NUM); +} + +// Get OS Tick clock. +uint32_t OS_Tick_GetClock (void) { + return (GTIM_Clock); +} + +// Get OS Tick interval. +uint32_t OS_Tick_GetInterval (void) { + return (GTIM_Load + 1U); +} + +// Get OS Tick count value. +uint32_t OS_Tick_GetCount (void) { + return (GTIM_Load - PL1_GetCurrentValue()); +} + +// Get OS Tick overflow status. +uint32_t OS_Tick_GetOverflow (void) { + CNTP_CTL_Type cntp_ctl; + cntp_ctl.w = PL1_GetControl(); + return (cntp_ctl.b.ISTATUS); +} diff --git a/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_ptim.c b/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_ptim.c new file mode 100644 index 0000000..ccd9cb6 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS2/Source/os_tick_ptim.c @@ -0,0 +1,165 @@ +/**************************************************************************//** + * @file os_tick_ptim.c + * @brief CMSIS OS Tick implementation for Private Timer + * @version V1.0.2 + * @date 02. March 2018 + ******************************************************************************/ +/* + * Copyright (c) 2017-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "RTE_Components.h" +#include CMSIS_device_header + +#if defined(PTIM) + +#include "os_tick.h" +#include "irq_ctrl.h" + +#ifndef PTIM_IRQ_PRIORITY +#define PTIM_IRQ_PRIORITY 0xFFU +#endif + +static uint8_t PTIM_PendIRQ; // Timer interrupt pending flag + +// Setup OS Tick. +int32_t OS_Tick_Setup (uint32_t freq, IRQHandler_t handler) { + uint32_t load; + uint32_t prio; + uint32_t bits; + + if (freq == 0U) { + return (-1); + } + + PTIM_PendIRQ = 0U; + + // Private Timer runs with the system frequency + load = (SystemCoreClock / freq) - 1U; + + // Disable Private Timer and set load value + PTIM_SetControl (0U); + PTIM_SetLoadValue (load); + + // Disable corresponding IRQ + IRQ_Disable (PrivTimer_IRQn); + IRQ_ClearPending(PrivTimer_IRQn); + + // Determine number of implemented priority bits + IRQ_SetPriority (PrivTimer_IRQn, 0xFFU); + + prio = IRQ_GetPriority (PrivTimer_IRQn); + + // At least bits [7:4] must be implemented + if ((prio & 0xF0U) == 0U) { + return (-1); + } + + for (bits = 0; bits < 4; bits++) { + if ((prio & 0x01) != 0) { + break; + } + prio >>= 1; + } + + // Adjust configured priority to the number of implemented priority bits + prio = (PTIM_IRQ_PRIORITY << bits) & 0xFFUL; + + // Set Private Timer interrupt priority + IRQ_SetPriority(PrivTimer_IRQn, prio-1U); + + // Set edge-triggered IRQ + IRQ_SetMode(PrivTimer_IRQn, IRQ_MODE_TRIG_EDGE); + + // Register tick interrupt handler function + IRQ_SetHandler(PrivTimer_IRQn, handler); + + // Enable corresponding interrupt + IRQ_Enable (PrivTimer_IRQn); + + // Set bits: IRQ enable and Auto reload + PTIM_SetControl (0x06U); + + return (0); +} + +/// Enable OS Tick. +void OS_Tick_Enable (void) { + uint32_t ctrl; + + // Set pending interrupt if flag set + if (PTIM_PendIRQ != 0U) { + PTIM_PendIRQ = 0U; + IRQ_SetPending (PrivTimer_IRQn); + } + + // Start the Private Timer + ctrl = PTIM_GetControl(); + // Set bit: Timer enable + ctrl |= 1U; + PTIM_SetControl (ctrl); +} + +/// Disable OS Tick. +void OS_Tick_Disable (void) { + uint32_t ctrl; + + // Stop the Private Timer + ctrl = PTIM_GetControl(); + // Clear bit: Timer enable + ctrl &= ~1U; + PTIM_SetControl (ctrl); + + // Remember pending interrupt flag + if (IRQ_GetPending(PrivTimer_IRQn) != 0) { + IRQ_ClearPending (PrivTimer_IRQn); + PTIM_PendIRQ = 1U; + } +} + +// Acknowledge OS Tick IRQ. +void OS_Tick_AcknowledgeIRQ (void) { + PTIM_ClearEventFlag(); +} + +// Get OS Tick IRQ number. +int32_t OS_Tick_GetIRQn (void) { + return (PrivTimer_IRQn); +} + +// Get OS Tick clock. +uint32_t OS_Tick_GetClock (void) { + return (SystemCoreClock); +} + +// Get OS Tick interval. +uint32_t OS_Tick_GetInterval (void) { + return (PTIM_GetLoadValue() + 1U); +} + +// Get OS Tick count value. +uint32_t OS_Tick_GetCount (void) { + uint32_t load = PTIM_GetLoadValue(); + return (load - PTIM_GetCurrentValue()); +} + +// Get OS Tick overflow status. +uint32_t OS_Tick_GetOverflow (void) { + return (PTIM->ISR & 1); +} + +#endif // PTIM diff --git a/Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os.h b/Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os.h new file mode 100644 index 0000000..5447842 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os.h @@ -0,0 +1,922 @@ +/* + * Copyright (c) 2013-2018 Arm Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * ---------------------------------------------------------------------- + * + * $Date: 18. June 2018 + * $Revision: V2.1.3 + * + * Project: CMSIS-RTOS API + * Title: cmsis_os.h template header file + * + * Version 0.02 + * Initial Proposal Phase + * Version 0.03 + * osKernelStart added, optional feature: main started as thread + * osSemaphores have standard behavior + * osTimerCreate does not start the timer, added osTimerStart + * osThreadPass is renamed to osThreadYield + * Version 1.01 + * Support for C++ interface + * - const attribute removed from the osXxxxDef_t typedefs + * - const attribute added to the osXxxxDef macros + * Added: osTimerDelete, osMutexDelete, osSemaphoreDelete + * Added: osKernelInitialize + * Version 1.02 + * Control functions for short timeouts in microsecond resolution: + * Added: osKernelSysTick, osKernelSysTickFrequency, osKernelSysTickMicroSec + * Removed: osSignalGet + * Version 2.0.0 + * OS objects creation without macros (dynamic creation and resource allocation): + * - added: osXxxxNew functions which replace osXxxxCreate + * - added: osXxxxAttr_t structures + * - deprecated: osXxxxCreate functions, osXxxxDef_t structures + * - deprecated: osXxxxDef and osXxxx macros + * osStatus codes simplified and renamed to osStatus_t + * osEvent return structure deprecated + * Kernel: + * - added: osKernelInfo_t and osKernelGetInfo + * - added: osKernelState_t and osKernelGetState (replaces osKernelRunning) + * - added: osKernelLock, osKernelUnlock + * - added: osKernelSuspend, osKernelResume + * - added: osKernelGetTickCount, osKernelGetTickFreq + * - renamed osKernelSysTick to osKernelGetSysTimerCount + * - replaced osKernelSysTickFrequency with osKernelGetSysTimerFreq + * - deprecated osKernelSysTickMicroSec + * Thread: + * - extended number of thread priorities + * - renamed osPrioriry to osPrioriry_t + * - replaced osThreadCreate with osThreadNew + * - added: osThreadGetName + * - added: osThreadState_t and osThreadGetState + * - added: osThreadGetStackSize, osThreadGetStackSpace + * - added: osThreadSuspend, osThreadResume + * - added: osThreadJoin, osThreadDetach, osThreadExit + * - added: osThreadGetCount, osThreadEnumerate + * - added: Thread Flags (moved from Signals) + * Signals: + * - renamed osSignals to osThreadFlags (moved to Thread Flags) + * - changed return value of Set/Clear/Wait functions + * - Clear function limited to current running thread + * - extended Wait function (options) + * - added: osThreadFlagsGet + * Event Flags: + * - added new independent object for handling Event Flags + * Delay and Wait functions: + * - added: osDelayUntil + * - deprecated: osWait + * Timer: + * - replaced osTimerCreate with osTimerNew + * - added: osTimerGetName, osTimerIsRunning + * Mutex: + * - extended: attributes (Recursive, Priority Inherit, Robust) + * - replaced osMutexCreate with osMutexNew + * - renamed osMutexWait to osMutexAcquire + * - added: osMutexGetName, osMutexGetOwner + * Semaphore: + * - extended: maximum and initial token count + * - replaced osSemaphoreCreate with osSemaphoreNew + * - renamed osSemaphoreWait to osSemaphoreAcquire (changed return value) + * - added: osSemaphoreGetName, osSemaphoreGetCount + * Memory Pool: + * - using osMemoryPool prefix instead of osPool + * - replaced osPoolCreate with osMemoryPoolNew + * - extended osMemoryPoolAlloc (timeout) + * - added: osMemoryPoolGetName + * - added: osMemoryPoolGetCapacity, osMemoryPoolGetBlockSize + * - added: osMemoryPoolGetCount, osMemoryPoolGetSpace + * - added: osMemoryPoolDelete + * - deprecated: osPoolCAlloc + * Message Queue: + * - extended: fixed size message instead of a single 32-bit value + * - using osMessageQueue prefix instead of osMessage + * - replaced osMessageCreate with osMessageQueueNew + * - updated: osMessageQueuePut, osMessageQueueGet + * - added: osMessageQueueGetName + * - added: osMessageQueueGetCapacity, osMessageQueueGetMsgSize + * - added: osMessageQueueGetCount, osMessageQueueGetSpace + * - added: osMessageQueueReset, osMessageQueueDelete + * Mail Queue: + * - deprecated (superseded by extended Message Queue functionality) + * Version 2.1.0 + * Support for critical and uncritical sections (nesting safe): + * - updated: osKernelLock, osKernelUnlock + * - added: osKernelRestoreLock + * Updated Thread and Event Flags: + * - changed flags parameter and return type from int32_t to uint32_t + * Version 2.1.1 + * Additional functions allowed to be called from Interrupt Service Routines: + * - osKernelGetTickCount, osKernelGetTickFreq + * Changed Kernel Tick type to uint32_t: + * - updated: osKernelGetTickCount, osDelayUntil + * Version 2.1.2 + * Additional functions allowed to be called from Interrupt Service Routines: + * - osKernelGetInfo, osKernelGetState + * Version 2.1.3 + * Additional functions allowed to be called from Interrupt Service Routines: + * - osThreadGetId + *---------------------------------------------------------------------------*/ + +#ifndef CMSIS_OS_H_ +#define CMSIS_OS_H_ + +/// \b osCMSIS identifies the CMSIS-RTOS API version. +#define osCMSIS 0x20001U ///< API version (main[31:16].sub[15:0]) + +/// \note CAN BE CHANGED: \b osCMSIS_KERNEL identifies the underlying RTOS kernel and version number. +#define osCMSIS_KERNEL 0x10000U ///< RTOS identification and version (main[31:16].sub[15:0]) + +/// \note CAN BE CHANGED: \b osKernelSystemId identifies the underlying RTOS kernel. +#define osKernelSystemId "KERNEL V1.0" ///< RTOS identification string + +/// \note CAN BE CHANGED: \b osFeature_xxx identifies RTOS features. +#define osFeature_MainThread 0 ///< main thread 1=main can be thread, 0=not available +#define osFeature_Signals 16U ///< maximum number of Signal Flags available per thread +#define osFeature_Semaphore 65535U ///< maximum count for \ref osSemaphoreCreate function +#define osFeature_Wait 0 ///< osWait function: 1=available, 0=not available +#define osFeature_SysTick 1 ///< osKernelSysTick functions: 1=available, 0=not available +#define osFeature_Pool 1 ///< Memory Pools: 1=available, 0=not available +#define osFeature_MessageQ 1 ///< Message Queues: 1=available, 0=not available +#define osFeature_MailQ 1 ///< Mail Queues: 1=available, 0=not available + +#if (osCMSIS >= 0x20000U) +#include "cmsis_os2.h" +#else +#include +#include +#endif + +#ifdef __cplusplus +extern "C" +{ +#endif + + +// ==== Enumerations, structures, defines ==== + +/// Priority values. +#if (osCMSIS < 0x20000U) +typedef enum { + osPriorityIdle = -3, ///< Priority: idle (lowest) + osPriorityLow = -2, ///< Priority: low + osPriorityBelowNormal = -1, ///< Priority: below normal + osPriorityNormal = 0, ///< Priority: normal (default) + osPriorityAboveNormal = +1, ///< Priority: above normal + osPriorityHigh = +2, ///< Priority: high + osPriorityRealtime = +3, ///< Priority: realtime (highest) + osPriorityError = 0x84, ///< System cannot determine priority or illegal priority. + osPriorityReserved = 0x7FFFFFFF ///< Prevents enum down-size compiler optimization. +} osPriority; +#else +#define osPriority osPriority_t +#endif + +/// Entry point of a thread. +typedef void (*os_pthread) (void const *argument); + +/// Entry point of a timer call back function. +typedef void (*os_ptimer) (void const *argument); + +/// Timer type. +#if (osCMSIS < 0x20000U) +typedef enum { + osTimerOnce = 0, ///< One-shot timer. + osTimerPeriodic = 1 ///< Repeating timer. +} os_timer_type; +#else +#define os_timer_type osTimerType_t +#endif + +/// Timeout value. +#define osWaitForever 0xFFFFFFFFU ///< Wait forever timeout value. + +/// Status code values returned by CMSIS-RTOS functions. +#if (osCMSIS < 0x20000U) +typedef enum { + osOK = 0, ///< Function completed; no error or event occurred. + osEventSignal = 0x08, ///< Function completed; signal event occurred. + osEventMessage = 0x10, ///< Function completed; message event occurred. + osEventMail = 0x20, ///< Function completed; mail event occurred. + osEventTimeout = 0x40, ///< Function completed; timeout occurred. + osErrorParameter = 0x80, ///< Parameter error: a mandatory parameter was missing or specified an incorrect object. + osErrorResource = 0x81, ///< Resource not available: a specified resource was not available. + osErrorTimeoutResource = 0xC1, ///< Resource not available within given time: a specified resource was not available within the timeout period. + osErrorISR = 0x82, ///< Not allowed in ISR context: the function cannot be called from interrupt service routines. + osErrorISRRecursive = 0x83, ///< Function called multiple times from ISR with same object. + osErrorPriority = 0x84, ///< System cannot determine priority or thread has illegal priority. + osErrorNoMemory = 0x85, ///< System is out of memory: it was impossible to allocate or reserve memory for the operation. + osErrorValue = 0x86, ///< Value of a parameter is out of range. + osErrorOS = 0xFF, ///< Unspecified RTOS error: run-time error but no other error message fits. + osStatusReserved = 0x7FFFFFFF ///< Prevents enum down-size compiler optimization. +} osStatus; +#else +typedef int32_t osStatus; +#define osEventSignal (0x08) +#define osEventMessage (0x10) +#define osEventMail (0x20) +#define osEventTimeout (0x40) +#define osErrorOS osError +#define osErrorTimeoutResource osErrorTimeout +#define osErrorISRRecursive (-126) +#define osErrorValue (-127) +#define osErrorPriority (-128) +#endif + + +// >>> the following data type definitions may be adapted towards a specific RTOS + +/// Thread ID identifies the thread. +/// \note CAN BE CHANGED: \b implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef void *osThreadId; +#else +#define osThreadId osThreadId_t +#endif + +/// Timer ID identifies the timer. +/// \note CAN BE CHANGED: \b implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef void *osTimerId; +#else +#define osTimerId osTimerId_t +#endif + +/// Mutex ID identifies the mutex. +/// \note CAN BE CHANGED: \b implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef void *osMutexId; +#else +#define osMutexId osMutexId_t +#endif + +/// Semaphore ID identifies the semaphore. +/// \note CAN BE CHANGED: \b implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef void *osSemaphoreId; +#else +#define osSemaphoreId osSemaphoreId_t +#endif + +/// Pool ID identifies the memory pool. +/// \note CAN BE CHANGED: \b implementation specific in every CMSIS-RTOS. +typedef void *osPoolId; + +/// Message ID identifies the message queue. +/// \note CAN BE CHANGED: \b implementation specific in every CMSIS-RTOS. +typedef void *osMessageQId; + +/// Mail ID identifies the mail queue. +/// \note CAN BE CHANGED: \b implementation specific in every CMSIS-RTOS. +typedef void *osMailQId; + + +/// Thread Definition structure contains startup information of a thread. +/// \note CAN BE CHANGED: \b os_thread_def is implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef struct os_thread_def { + os_pthread pthread; ///< start address of thread function + osPriority tpriority; ///< initial thread priority + uint32_t instances; ///< maximum number of instances of that thread function + uint32_t stacksize; ///< stack size requirements in bytes; 0 is default stack size +} osThreadDef_t; +#else +typedef struct os_thread_def { + os_pthread pthread; ///< start address of thread function + osThreadAttr_t attr; ///< thread attributes +} osThreadDef_t; +#endif + +/// Timer Definition structure contains timer parameters. +/// \note CAN BE CHANGED: \b os_timer_def is implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef struct os_timer_def { + os_ptimer ptimer; ///< start address of a timer function +} osTimerDef_t; +#else +typedef struct os_timer_def { + os_ptimer ptimer; ///< start address of a timer function + osTimerAttr_t attr; ///< timer attributes +} osTimerDef_t; +#endif + +/// Mutex Definition structure contains setup information for a mutex. +/// \note CAN BE CHANGED: \b os_mutex_def is implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef struct os_mutex_def { + uint32_t dummy; ///< dummy value +} osMutexDef_t; +#else +#define osMutexDef_t osMutexAttr_t +#endif + +/// Semaphore Definition structure contains setup information for a semaphore. +/// \note CAN BE CHANGED: \b os_semaphore_def is implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef struct os_semaphore_def { + uint32_t dummy; ///< dummy value +} osSemaphoreDef_t; +#else +#define osSemaphoreDef_t osSemaphoreAttr_t +#endif + +/// Definition structure for memory block allocation. +/// \note CAN BE CHANGED: \b os_pool_def is implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef struct os_pool_def { + uint32_t pool_sz; ///< number of items (elements) in the pool + uint32_t item_sz; ///< size of an item + void *pool; ///< pointer to memory for pool +} osPoolDef_t; +#else +typedef struct os_pool_def { + uint32_t pool_sz; ///< number of items (elements) in the pool + uint32_t item_sz; ///< size of an item + osMemoryPoolAttr_t attr; ///< memory pool attributes +} osPoolDef_t; +#endif + +/// Definition structure for message queue. +/// \note CAN BE CHANGED: \b os_messageQ_def is implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef struct os_messageQ_def { + uint32_t queue_sz; ///< number of elements in the queue + void *pool; ///< memory array for messages +} osMessageQDef_t; +#else +typedef struct os_messageQ_def { + uint32_t queue_sz; ///< number of elements in the queue + osMessageQueueAttr_t attr; ///< message queue attributes +} osMessageQDef_t; +#endif + +/// Definition structure for mail queue. +/// \note CAN BE CHANGED: \b os_mailQ_def is implementation specific in every CMSIS-RTOS. +#if (osCMSIS < 0x20000U) +typedef struct os_mailQ_def { + uint32_t queue_sz; ///< number of elements in the queue + uint32_t item_sz; ///< size of an item + void *pool; ///< memory array for mail +} osMailQDef_t; +#else +typedef struct os_mailQ_def { + uint32_t queue_sz; ///< number of elements in the queue + uint32_t item_sz; ///< size of an item + void *mail; ///< pointer to mail + osMemoryPoolAttr_t mp_attr; ///< memory pool attributes + osMessageQueueAttr_t mq_attr; ///< message queue attributes +} osMailQDef_t; +#endif + + +/// Event structure contains detailed information about an event. +typedef struct { + osStatus status; ///< status code: event or error information + union { + uint32_t v; ///< message as 32-bit value + void *p; ///< message or mail as void pointer + int32_t signals; ///< signal flags + } value; ///< event value + union { + osMailQId mail_id; ///< mail id obtained by \ref osMailCreate + osMessageQId message_id; ///< message id obtained by \ref osMessageCreate + } def; ///< event definition +} osEvent; + + +// ==== Kernel Management Functions ==== + +/// Initialize the RTOS Kernel for creating objects. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osKernelInitialize (void); +#endif + +/// Start the RTOS Kernel scheduler. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osKernelStart (void); +#endif + +/// Check if the RTOS kernel is already started. +/// \return 0 RTOS is not started, 1 RTOS is started. +#if (osCMSIS < 0x20000U) +int32_t osKernelRunning(void); +#endif + +#if (defined(osFeature_SysTick) && (osFeature_SysTick != 0)) // System Timer available + +/// Get the RTOS kernel system timer counter. +/// \return RTOS kernel system timer as 32-bit value +#if (osCMSIS < 0x20000U) +uint32_t osKernelSysTick (void); +#else +#define osKernelSysTick osKernelGetSysTimerCount +#endif + +/// The RTOS kernel system timer frequency in Hz. +/// \note Reflects the system timer setting and is typically defined in a configuration file. +#if (osCMSIS < 0x20000U) +#define osKernelSysTickFrequency 100000000 +#endif + +/// Convert a microseconds value to a RTOS kernel system timer value. +/// \param microsec time value in microseconds. +/// \return time value normalized to the \ref osKernelSysTickFrequency +#if (osCMSIS < 0x20000U) +#define osKernelSysTickMicroSec(microsec) (((uint64_t)microsec * (osKernelSysTickFrequency)) / 1000000) +#else +#define osKernelSysTickMicroSec(microsec) (((uint64_t)microsec * osKernelGetSysTimerFreq()) / 1000000) +#endif + +#endif // System Timer available + + +// ==== Thread Management Functions ==== + +/// Create a Thread Definition with function, priority, and stack requirements. +/// \param name name of the thread function. +/// \param priority initial priority of the thread function. +/// \param instances number of possible thread instances. +/// \param stacksz stack size (in bytes) requirements for the thread function. +/// \note CAN BE CHANGED: The parameters to \b osThreadDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osThreadDef(name, priority, instances, stacksz) \ +extern const osThreadDef_t os_thread_def_##name +#else // define the object +#if (osCMSIS < 0x20000U) +#define osThreadDef(name, priority, instances, stacksz) \ +const osThreadDef_t os_thread_def_##name = \ +{ (name), (priority), (instances), (stacksz) } +#else +#define osThreadDef(name, priority, instances, stacksz) \ +const osThreadDef_t os_thread_def_##name = \ +{ (name), \ + { NULL, osThreadDetached, NULL, 0U, NULL, 8*((stacksz+7)/8), (priority), 0U, 0U } } +#endif +#endif + +/// Access a Thread definition. +/// \param name name of the thread definition object. +/// \note CAN BE CHANGED: The parameter to \b osThread shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osThread(name) \ +&os_thread_def_##name + +/// Create a thread and add it to Active Threads and set it to state READY. +/// \param[in] thread_def thread definition referenced with \ref osThread. +/// \param[in] argument pointer that is passed to the thread function as start argument. +/// \return thread ID for reference by other functions or NULL in case of error. +osThreadId osThreadCreate (const osThreadDef_t *thread_def, void *argument); + +/// Return the thread ID of the current running thread. +/// \return thread ID for reference by other functions or NULL in case of error. +#if (osCMSIS < 0x20000U) +osThreadId osThreadGetId (void); +#endif + +/// Change priority of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \param[in] priority new priority value for the thread function. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osThreadSetPriority (osThreadId thread_id, osPriority priority); +#endif + +/// Get current priority of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \return current priority value of the specified thread. +#if (osCMSIS < 0x20000U) +osPriority osThreadGetPriority (osThreadId thread_id); +#endif + +/// Pass control to next thread that is in state \b READY. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osThreadYield (void); +#endif + +/// Terminate execution of a thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osThreadTerminate (osThreadId thread_id); +#endif + + +// ==== Signal Management ==== + +/// Set the specified Signal Flags of an active thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \param[in] signals specifies the signal flags of the thread that should be set. +/// \return previous signal flags of the specified thread or 0x80000000 in case of incorrect parameters. +int32_t osSignalSet (osThreadId thread_id, int32_t signals); + +/// Clear the specified Signal Flags of an active thread. +/// \param[in] thread_id thread ID obtained by \ref osThreadCreate or \ref osThreadGetId. +/// \param[in] signals specifies the signal flags of the thread that shall be cleared. +/// \return previous signal flags of the specified thread or 0x80000000 in case of incorrect parameters or call from ISR. +int32_t osSignalClear (osThreadId thread_id, int32_t signals); + +/// Wait for one or more Signal Flags to become signaled for the current \b RUNNING thread. +/// \param[in] signals wait until all specified signal flags set or 0 for any single signal flag. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return event flag information or error code. +osEvent osSignalWait (int32_t signals, uint32_t millisec); + + +// ==== Generic Wait Functions ==== + +/// Wait for Timeout (Time Delay). +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue "time delay" value +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osDelay (uint32_t millisec); +#endif + +#if (defined (osFeature_Wait) && (osFeature_Wait != 0)) // Generic Wait available + +/// Wait for Signal, Message, Mail, or Timeout. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out +/// \return event that contains signal, message, or mail information or error code. +osEvent osWait (uint32_t millisec); + +#endif // Generic Wait available + + +// ==== Timer Management Functions ==== + +/// Define a Timer object. +/// \param name name of the timer object. +/// \param function name of the timer call back function. +/// \note CAN BE CHANGED: The parameter to \b osTimerDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osTimerDef(name, function) \ +extern const osTimerDef_t os_timer_def_##name +#else // define the object +#if (osCMSIS < 0x20000U) +#define osTimerDef(name, function) \ +const osTimerDef_t os_timer_def_##name = { (function) } +#else +#define osTimerDef(name, function) \ +const osTimerDef_t os_timer_def_##name = \ +{ (function), { NULL, 0U, NULL, 0U } } +#endif +#endif + +/// Access a Timer definition. +/// \param name name of the timer object. +/// \note CAN BE CHANGED: The parameter to \b osTimer shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osTimer(name) \ +&os_timer_def_##name + +/// Create and Initialize a timer. +/// \param[in] timer_def timer object referenced with \ref osTimer. +/// \param[in] type osTimerOnce for one-shot or osTimerPeriodic for periodic behavior. +/// \param[in] argument argument to the timer call back function. +/// \return timer ID for reference by other functions or NULL in case of error. +osTimerId osTimerCreate (const osTimerDef_t *timer_def, os_timer_type type, void *argument); + +/// Start or restart a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue "time delay" value of the timer. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osTimerStart (osTimerId timer_id, uint32_t millisec); +#endif + +/// Stop a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerCreate. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osTimerStop (osTimerId timer_id); +#endif + +/// Delete a timer. +/// \param[in] timer_id timer ID obtained by \ref osTimerCreate. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osTimerDelete (osTimerId timer_id); +#endif + + +// ==== Mutex Management Functions ==== + +/// Define a Mutex. +/// \param name name of the mutex object. +/// \note CAN BE CHANGED: The parameter to \b osMutexDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osMutexDef(name) \ +extern const osMutexDef_t os_mutex_def_##name +#else // define the object +#if (osCMSIS < 0x20000U) +#define osMutexDef(name) \ +const osMutexDef_t os_mutex_def_##name = { 0 } +#else +#define osMutexDef(name) \ +const osMutexDef_t os_mutex_def_##name = \ +{ NULL, osMutexRecursive | osMutexPrioInherit | osMutexRobust, NULL, 0U } +#endif +#endif + +/// Access a Mutex definition. +/// \param name name of the mutex object. +/// \note CAN BE CHANGED: The parameter to \b osMutex shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osMutex(name) \ +&os_mutex_def_##name + +/// Create and Initialize a Mutex object. +/// \param[in] mutex_def mutex definition referenced with \ref osMutex. +/// \return mutex ID for reference by other functions or NULL in case of error. +osMutexId osMutexCreate (const osMutexDef_t *mutex_def); + +/// Wait until a Mutex becomes available. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osMutexWait (osMutexId mutex_id, uint32_t millisec); +#else +#define osMutexWait osMutexAcquire +#endif + +/// Release a Mutex that was obtained by \ref osMutexWait. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexCreate. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osMutexRelease (osMutexId mutex_id); +#endif + +/// Delete a Mutex object. +/// \param[in] mutex_id mutex ID obtained by \ref osMutexCreate. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osMutexDelete (osMutexId mutex_id); +#endif + + +// ==== Semaphore Management Functions ==== + +#if (defined (osFeature_Semaphore) && (osFeature_Semaphore != 0U)) // Semaphore available + +/// Define a Semaphore object. +/// \param name name of the semaphore object. +/// \note CAN BE CHANGED: The parameter to \b osSemaphoreDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osSemaphoreDef(name) \ +extern const osSemaphoreDef_t os_semaphore_def_##name +#else // define the object +#if (osCMSIS < 0x20000U) +#define osSemaphoreDef(name) \ +const osSemaphoreDef_t os_semaphore_def_##name = { 0 } +#else +#define osSemaphoreDef(name) \ +const osSemaphoreDef_t os_semaphore_def_##name = \ +{ NULL, 0U, NULL, 0U } +#endif +#endif + +/// Access a Semaphore definition. +/// \param name name of the semaphore object. +/// \note CAN BE CHANGED: The parameter to \b osSemaphore shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osSemaphore(name) \ +&os_semaphore_def_##name + +/// Create and Initialize a Semaphore object. +/// \param[in] semaphore_def semaphore definition referenced with \ref osSemaphore. +/// \param[in] count maximum and initial number of available tokens. +/// \return semaphore ID for reference by other functions or NULL in case of error. +osSemaphoreId osSemaphoreCreate (const osSemaphoreDef_t *semaphore_def, int32_t count); + +/// Wait until a Semaphore token becomes available. +/// \param[in] semaphore_id semaphore object referenced with \ref osSemaphoreCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return number of available tokens, or -1 in case of incorrect parameters. +int32_t osSemaphoreWait (osSemaphoreId semaphore_id, uint32_t millisec); + +/// Release a Semaphore token. +/// \param[in] semaphore_id semaphore object referenced with \ref osSemaphoreCreate. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osSemaphoreRelease (osSemaphoreId semaphore_id); +#endif + +/// Delete a Semaphore object. +/// \param[in] semaphore_id semaphore object referenced with \ref osSemaphoreCreate. +/// \return status code that indicates the execution status of the function. +#if (osCMSIS < 0x20000U) +osStatus osSemaphoreDelete (osSemaphoreId semaphore_id); +#endif + +#endif // Semaphore available + + +// ==== Memory Pool Management Functions ==== + +#if (defined(osFeature_Pool) && (osFeature_Pool != 0)) // Memory Pool available + +/// \brief Define a Memory Pool. +/// \param name name of the memory pool. +/// \param no maximum number of blocks (objects) in the memory pool. +/// \param type data type of a single block (object). +/// \note CAN BE CHANGED: The parameter to \b osPoolDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osPoolDef(name, no, type) \ +extern const osPoolDef_t os_pool_def_##name +#else // define the object +#if (osCMSIS < 0x20000U) +#define osPoolDef(name, no, type) \ +const osPoolDef_t os_pool_def_##name = \ +{ (no), sizeof(type), NULL } +#else +#define osPoolDef(name, no, type) \ +const osPoolDef_t os_pool_def_##name = \ +{ (no), sizeof(type), { NULL, 0U, NULL, 0U, NULL, 0U } } +#endif +#endif + +/// \brief Access a Memory Pool definition. +/// \param name name of the memory pool +/// \note CAN BE CHANGED: The parameter to \b osPool shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osPool(name) \ +&os_pool_def_##name + +/// Create and Initialize a Memory Pool object. +/// \param[in] pool_def memory pool definition referenced with \ref osPool. +/// \return memory pool ID for reference by other functions or NULL in case of error. +osPoolId osPoolCreate (const osPoolDef_t *pool_def); + +/// Allocate a memory block from a Memory Pool. +/// \param[in] pool_id memory pool ID obtain referenced with \ref osPoolCreate. +/// \return address of the allocated memory block or NULL in case of no memory available. +void *osPoolAlloc (osPoolId pool_id); + +/// Allocate a memory block from a Memory Pool and set memory block to zero. +/// \param[in] pool_id memory pool ID obtain referenced with \ref osPoolCreate. +/// \return address of the allocated memory block or NULL in case of no memory available. +void *osPoolCAlloc (osPoolId pool_id); + +/// Return an allocated memory block back to a Memory Pool. +/// \param[in] pool_id memory pool ID obtain referenced with \ref osPoolCreate. +/// \param[in] block address of the allocated memory block to be returned to the memory pool. +/// \return status code that indicates the execution status of the function. +osStatus osPoolFree (osPoolId pool_id, void *block); + +#endif // Memory Pool available + + +// ==== Message Queue Management Functions ==== + +#if (defined(osFeature_MessageQ) && (osFeature_MessageQ != 0)) // Message Queue available + +/// \brief Create a Message Queue Definition. +/// \param name name of the queue. +/// \param queue_sz maximum number of messages in the queue. +/// \param type data type of a single message element (for debugger). +/// \note CAN BE CHANGED: The parameter to \b osMessageQDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osMessageQDef(name, queue_sz, type) \ +extern const osMessageQDef_t os_messageQ_def_##name +#else // define the object +#if (osCMSIS < 0x20000U) +#define osMessageQDef(name, queue_sz, type) \ +const osMessageQDef_t os_messageQ_def_##name = \ +{ (queue_sz), NULL } +#else +#define osMessageQDef(name, queue_sz, type) \ +const osMessageQDef_t os_messageQ_def_##name = \ +{ (queue_sz), { NULL, 0U, NULL, 0U, NULL, 0U } } +#endif +#endif + +/// \brief Access a Message Queue Definition. +/// \param name name of the queue +/// \note CAN BE CHANGED: The parameter to \b osMessageQ shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osMessageQ(name) \ +&os_messageQ_def_##name + +/// Create and Initialize a Message Queue object. +/// \param[in] queue_def message queue definition referenced with \ref osMessageQ. +/// \param[in] thread_id thread ID (obtained by \ref osThreadCreate or \ref osThreadGetId) or NULL. +/// \return message queue ID for reference by other functions or NULL in case of error. +osMessageQId osMessageCreate (const osMessageQDef_t *queue_def, osThreadId thread_id); + +/// Put a Message to a Queue. +/// \param[in] queue_id message queue ID obtained with \ref osMessageCreate. +/// \param[in] info message information. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return status code that indicates the execution status of the function. +osStatus osMessagePut (osMessageQId queue_id, uint32_t info, uint32_t millisec); + +/// Get a Message from a Queue or timeout if Queue is empty. +/// \param[in] queue_id message queue ID obtained with \ref osMessageCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return event information that includes status code. +osEvent osMessageGet (osMessageQId queue_id, uint32_t millisec); + +#endif // Message Queue available + + +// ==== Mail Queue Management Functions ==== + +#if (defined(osFeature_MailQ) && (osFeature_MailQ != 0)) // Mail Queue available + +/// \brief Create a Mail Queue Definition. +/// \param name name of the queue. +/// \param queue_sz maximum number of mails in the queue. +/// \param type data type of a single mail element. +/// \note CAN BE CHANGED: The parameter to \b osMailQDef shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#if defined (osObjectsExternal) // object is external +#define osMailQDef(name, queue_sz, type) \ +extern const osMailQDef_t os_mailQ_def_##name +#else // define the object +#if (osCMSIS < 0x20000U) +#define osMailQDef(name, queue_sz, type) \ +const osMailQDef_t os_mailQ_def_##name = \ +{ (queue_sz), sizeof(type), NULL } +#else +#define osMailQDef(name, queue_sz, type) \ +static void *os_mail_p_##name[2]; \ +const osMailQDef_t os_mailQ_def_##name = \ +{ (queue_sz), sizeof(type), (&os_mail_p_##name), \ + { NULL, 0U, NULL, 0U, NULL, 0U }, \ + { NULL, 0U, NULL, 0U, NULL, 0U } } +#endif +#endif + +/// \brief Access a Mail Queue Definition. +/// \param name name of the queue +/// \note CAN BE CHANGED: The parameter to \b osMailQ shall be consistent but the +/// macro body is implementation specific in every CMSIS-RTOS. +#define osMailQ(name) \ +&os_mailQ_def_##name + +/// Create and Initialize a Mail Queue object. +/// \param[in] queue_def mail queue definition referenced with \ref osMailQ. +/// \param[in] thread_id thread ID (obtained by \ref osThreadCreate or \ref osThreadGetId) or NULL. +/// \return mail queue ID for reference by other functions or NULL in case of error. +osMailQId osMailCreate (const osMailQDef_t *queue_def, osThreadId thread_id); + +/// Allocate a memory block for mail from a mail memory pool. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out +/// \return pointer to memory block that can be filled with mail or NULL in case of error. +void *osMailAlloc (osMailQId queue_id, uint32_t millisec); + +/// Allocate a memory block for mail from a mail memory pool and set memory block to zero. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out +/// \return pointer to memory block that can be filled with mail or NULL in case of error. +void *osMailCAlloc (osMailQId queue_id, uint32_t millisec); + +/// Put a Mail into a Queue. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] mail pointer to memory with mail to put into a queue. +/// \return status code that indicates the execution status of the function. +osStatus osMailPut (osMailQId queue_id, const void *mail); + +/// Get a Mail from a Queue or timeout if Queue is empty. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] millisec \ref CMSIS_RTOS_TimeOutValue or 0 in case of no time-out. +/// \return event information that includes status code. +osEvent osMailGet (osMailQId queue_id, uint32_t millisec); + +/// Free a memory block by returning it to a mail memory pool. +/// \param[in] queue_id mail queue ID obtained with \ref osMailCreate. +/// \param[in] mail pointer to memory block that was obtained with \ref osMailGet. +/// \return status code that indicates the execution status of the function. +osStatus osMailFree (osMailQId queue_id, void *mail); + +#endif // Mail Queue available + + +#ifdef __cplusplus +} +#endif + +#endif // CMSIS_OS_H_ diff --git a/Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os1.c b/Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os1.c new file mode 100644 index 0000000..effe4a1 --- /dev/null +++ b/Chapter04/bare/platform/CMSIS/RTOS2/Template/cmsis_os1.c @@ -0,0 +1,361 @@ +/* + * Copyright (c) 2013-2017 ARM Limited. All rights reserved. + * + * SPDX-License-Identifier: Apache-2.0 + * + * Licensed under the Apache License, Version 2.0 (the License); you may + * not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, WITHOUT + * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + * + * ---------------------------------------------------------------------- + * + * $Date: 10. January 2017 + * $Revision: V1.2 + * + * Project: CMSIS-RTOS API V1 + * Title: cmsis_os_v1.c V1 module file + *---------------------------------------------------------------------------*/ + +#include +#include "cmsis_os.h" + +#if (osCMSIS >= 0x20000U) + + +// Thread +osThreadId osThreadCreate (const osThreadDef_t *thread_def, void *argument) { + + if (thread_def == NULL) { + return (osThreadId)NULL; + } + return osThreadNew((osThreadFunc_t)thread_def->pthread, argument, &thread_def->attr); +} + + +// Signals + +#define SignalMask ((1U< 0U) && (flags < 0x80000000U)) { + event.status = osEventSignal; + event.value.signals = (int32_t)flags; + } else { + switch ((int32_t)flags) { + case osErrorResource: + event.status = osOK; + break; + case osErrorTimeout: + event.status = osEventTimeout; + break; + case osErrorParameter: + event.status = osErrorValue; + break; + default: + event.status = (osStatus)flags; + break; + } + } + return event; +} + + +// Timer +osTimerId osTimerCreate (const osTimerDef_t *timer_def, os_timer_type type, void *argument) { + + if (timer_def == NULL) { + return (osTimerId)NULL; + } + return osTimerNew((osTimerFunc_t)timer_def->ptimer, type, argument, &timer_def->attr); +} + + +// Mutex +osMutexId osMutexCreate (const osMutexDef_t *mutex_def) { + + if (mutex_def == NULL) { + return (osMutexId)NULL; + } + return osMutexNew(mutex_def); +} + + +// Semaphore + +#if (defined (osFeature_Semaphore) && (osFeature_Semaphore != 0U)) + +osSemaphoreId osSemaphoreCreate (const osSemaphoreDef_t *semaphore_def, int32_t count) { + + if (semaphore_def == NULL) { + return (osSemaphoreId)NULL; + } + return osSemaphoreNew((uint32_t)count, (uint32_t)count, semaphore_def); +} + +int32_t osSemaphoreWait (osSemaphoreId semaphore_id, uint32_t millisec) { + osStatus_t status; + uint32_t count; + + status = osSemaphoreAcquire(semaphore_id, millisec); + switch (status) { + case osOK: + count = osSemaphoreGetCount(semaphore_id); + return ((int32_t)count + 1); + case osErrorResource: + case osErrorTimeout: + return 0; + default: + break; + } + return -1; +} + +#endif // Semaphore + + +// Memory Pool + +#if (defined(osFeature_Pool) && (osFeature_Pool != 0)) + +osPoolId osPoolCreate (const osPoolDef_t *pool_def) { + + if (pool_def == NULL) { + return (osPoolId)NULL; + } + return ((osPoolId)(osMemoryPoolNew(pool_def->pool_sz, pool_def->item_sz, &pool_def->attr))); +} + +void *osPoolAlloc (osPoolId pool_id) { + return osMemoryPoolAlloc((osMemoryPoolId_t)pool_id, 0U); +} + +void *osPoolCAlloc (osPoolId pool_id) { + void *block; + uint32_t block_size; + + block_size = osMemoryPoolGetBlockSize((osMemoryPoolId_t)pool_id); + if (block_size == 0U) { + return NULL; + } + block = osMemoryPoolAlloc((osMemoryPoolId_t)pool_id, 0U); + if (block != NULL) { + memset(block, 0, block_size); + } + return block; +} + +osStatus osPoolFree (osPoolId pool_id, void *block) { + return osMemoryPoolFree((osMemoryPoolId_t)pool_id, block); +} + +#endif // Memory Pool + + +// Message Queue + +#if (defined(osFeature_MessageQ) && (osFeature_MessageQ != 0)) + +osMessageQId osMessageCreate (const osMessageQDef_t *queue_def, osThreadId thread_id) { + (void)thread_id; + + if (queue_def == NULL) { + return (osMessageQId)NULL; + } + return ((osMessageQId)(osMessageQueueNew(queue_def->queue_sz, sizeof(uint32_t), &queue_def->attr))); +} + +osStatus osMessagePut (osMessageQId queue_id, uint32_t info, uint32_t millisec) { + return osMessageQueuePut((osMessageQueueId_t)queue_id, &info, 0U, millisec); +} + +osEvent osMessageGet (osMessageQId queue_id, uint32_t millisec) { + osStatus_t status; + osEvent event; + uint32_t message; + + status = osMessageQueueGet((osMessageQueueId_t)queue_id, &message, NULL, millisec); + switch (status) { + case osOK: + event.status = osEventMessage; + event.value.v = message; + break; + case osErrorResource: + event.status = osOK; + break; + case osErrorTimeout: + event.status = osEventTimeout; + break; + default: + event.status = status; + break; + } + return event; +} + +#endif // Message Queue + + +// Mail Queue + +#if (defined(osFeature_MailQ) && (osFeature_MailQ != 0)) + +typedef struct os_mail_queue_s { + osMemoryPoolId_t mp_id; + osMessageQueueId_t mq_id; +} os_mail_queue_t; + +osMailQId osMailCreate (const osMailQDef_t *queue_def, osThreadId thread_id) { + os_mail_queue_t *ptr; + (void)thread_id; + + if (queue_def == NULL) { + return (osMailQId)NULL; + } + + ptr = queue_def->mail; + if (ptr == NULL) { + return (osMailQId)NULL; + } + + ptr->mp_id = osMemoryPoolNew (queue_def->queue_sz, queue_def->item_sz, &queue_def->mp_attr); + ptr->mq_id = osMessageQueueNew(queue_def->queue_sz, sizeof(void *), &queue_def->mq_attr); + if ((ptr->mp_id == (osMemoryPoolId_t)NULL) || (ptr->mq_id == (osMessageQueueId_t)NULL)) { + if (ptr->mp_id != (osMemoryPoolId_t)NULL) { + osMemoryPoolDelete(ptr->mp_id); + } + if (ptr->mq_id != (osMessageQueueId_t)NULL) { + osMessageQueueDelete(ptr->mq_id); + } + return (osMailQId)NULL; + } + + return (osMailQId)ptr; +} + +void *osMailAlloc (osMailQId queue_id, uint32_t millisec) { + os_mail_queue_t *ptr = (os_mail_queue_t *)queue_id; + + if (ptr == NULL) { + return NULL; + } + return osMemoryPoolAlloc(ptr->mp_id, millisec); +} + +void *osMailCAlloc (osMailQId queue_id, uint32_t millisec) { + os_mail_queue_t *ptr = (os_mail_queue_t *)queue_id; + void *block; + uint32_t block_size; + + if (ptr == NULL) { + return NULL; + } + block_size = osMemoryPoolGetBlockSize(ptr->mp_id); + if (block_size == 0U) { + return NULL; + } + block = osMemoryPoolAlloc(ptr->mp_id, millisec); + if (block != NULL) { + memset(block, 0, block_size); + } + + return block; + +} + +osStatus osMailPut (osMailQId queue_id, const void *mail) { + os_mail_queue_t *ptr = (os_mail_queue_t *)queue_id; + + if (ptr == NULL) { + return osErrorParameter; + } + if (mail == NULL) { + return osErrorValue; + } + return osMessageQueuePut(ptr->mq_id, &mail, 0U, 0U); +} + +osEvent osMailGet (osMailQId queue_id, uint32_t millisec) { + os_mail_queue_t *ptr = (os_mail_queue_t *)queue_id; + osStatus_t status; + osEvent event; + void *mail; + + if (ptr == NULL) { + event.status = osErrorParameter; + return event; + } + + status = osMessageQueueGet(ptr->mq_id, &mail, NULL, millisec); + switch (status) { + case osOK: + event.status = osEventMail; + event.value.p = mail; + break; + case osErrorResource: + event.status = osOK; + break; + case osErrorTimeout: + event.status = osEventTimeout; + break; + default: + event.status = status; + break; + } + return event; +} + +osStatus osMailFree (osMailQId queue_id, void *mail) { + os_mail_queue_t *ptr = (os_mail_queue_t *)queue_id; + + if (ptr == NULL) { + return osErrorParameter; + } + if (mail == NULL) { + return osErrorValue; + } + return osMemoryPoolFree(ptr->mp_id, mail); +} + +#endif // Mail Queue + + +#endif // osCMSIS diff --git a/Chapter04/bare/platform/STM32F072C8Tx_FLASH.ld b/Chapter04/bare/platform/STM32F072C8Tx_FLASH.ld new file mode 100644 index 0000000..d46f1d6 --- /dev/null +++ b/Chapter04/bare/platform/STM32F072C8Tx_FLASH.ld @@ -0,0 +1,189 @@ +/* +****************************************************************************** +** + +** File : LinkerScript.ld +** +** Author : STM32CubeMX +** +** Abstract : Linker script for STM32F072C8Tx series +** 64Kbytes FLASH and 16Kbytes RAM +** +** Set heap size, stack size and stack location according +** to application requirements. +** +** Set memory bank area and size if external memory is used. +** +** Target : STMicroelectronics STM32 +** +** Distribution: The file is distributed “as is,†without any warranty +** of any kind. +** +***************************************************************************** +** @attention +** +**

    © COPYRIGHT(c) 2019 STMicroelectronics

    +** +** Redistribution and use in source and binary forms, with or without modification, +** are permitted provided that the following conditions are met: +** 1. Redistributions of source code must retain the above copyright notice, +** this list of conditions and the following disclaimer. +** 2. Redistributions in binary form must reproduce the above copyright notice, +** this list of conditions and the following disclaimer in the documentation +** and/or other materials provided with the distribution. +** 3. Neither the name of STMicroelectronics nor the names of its contributors +** may be used to endorse or promote products derived from this software +** without specific prior written permission. +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +** DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE +** FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR +** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER +** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, +** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +** +***************************************************************************** +*/ + +/* Entry Point */ +ENTRY(Reset_Handler) + +/* Highest address of the user mode stack */ +_estack = ORIGIN(RAM) + LENGTH(RAM); /* end of RAM */ +/* Generate a link error if heap and stack don't fit into RAM */ +_Min_Heap_Size = 0x200; /* required amount of heap */ +_Min_Stack_Size = 0x400; /* required amount of stack */ + +/* Specify the memory areas */ +MEMORY +{ +RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 16K +FLASH (rx) : ORIGIN = 0x8000000, LENGTH = 128K +} + +/* Define output sections */ +SECTIONS +{ + /* The startup code goes first into FLASH */ + .isr_vector : + { + . = ALIGN(4); + KEEP(*(.isr_vector)) /* Startup code */ + . = ALIGN(4); + } >FLASH + + /* The program code and other data goes into FLASH */ + .text : + { + . = ALIGN(4); + *(.text) /* .text sections (code) */ + *(.text*) /* .text* sections (code) */ + *(.glue_7) /* glue arm to thumb code */ + *(.glue_7t) /* glue thumb to arm code */ + *(.eh_frame) + + KEEP (*(.init)) + KEEP (*(.fini)) + + . = ALIGN(4); + _etext = .; /* define a global symbols at end of code */ + } >FLASH + + /* Constant data goes into FLASH */ + .rodata : + { + . = ALIGN(4); + *(.rodata) /* .rodata sections (constants, strings, etc.) */ + *(.rodata*) /* .rodata* sections (constants, strings, etc.) */ + . = ALIGN(4); + } >FLASH + + .ARM.extab : { *(.ARM.extab* .gnu.linkonce.armextab.*) } >FLASH + .ARM : { + __exidx_start = .; + *(.ARM.exidx*) + __exidx_end = .; + } >FLASH + + .preinit_array : + { + PROVIDE_HIDDEN (__preinit_array_start = .); + KEEP (*(.preinit_array*)) + PROVIDE_HIDDEN (__preinit_array_end = .); + } >FLASH + .init_array : + { + PROVIDE_HIDDEN (__init_array_start = .); + KEEP (*(SORT(.init_array.*))) + KEEP (*(.init_array*)) + PROVIDE_HIDDEN (__init_array_end = .); + } >FLASH + .fini_array : + { + PROVIDE_HIDDEN (__fini_array_start = .); + KEEP (*(SORT(.fini_array.*))) + KEEP (*(.fini_array*)) + PROVIDE_HIDDEN (__fini_array_end = .); + } >FLASH + + /* used by the startup to initialize data */ + _sidata = LOADADDR(.data); + + /* Initialized data sections goes into RAM, load LMA copy after code */ + .data : + { + . = ALIGN(4); + _sdata = .; /* create a global symbol at data start */ + *(.data) /* .data sections */ + *(.data*) /* .data* sections */ + + . = ALIGN(4); + _edata = .; /* define a global symbol at data end */ + } >RAM AT> FLASH + + + /* Uninitialized data section */ + . = ALIGN(4); + .bss : + { + /* This is used by the startup in order to initialize the .bss secion */ + _sbss = .; /* define a global symbol at bss start */ + __bss_start__ = _sbss; + *(.bss) + *(.bss*) + *(COMMON) + + . = ALIGN(4); + _ebss = .; /* define a global symbol at bss end */ + __bss_end__ = _ebss; + } >RAM + + /* User_heap_stack section, used to check that there is enough RAM left */ + ._user_heap_stack : + { + . = ALIGN(8); + PROVIDE ( end = . ); + PROVIDE ( _end = . ); + . = . + _Min_Heap_Size; + . = . + _Min_Stack_Size; + . = ALIGN(8); + } >RAM + + + + /* Remove information from the standard libraries */ + /DISCARD/ : + { + libc.a ( * ) + libm.a ( * ) + libgcc.a ( * ) + } + + .ARM.attributes 0 : { *(.ARM.attributes) } +} + + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h new file mode 100644 index 0000000..cef98d0 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32_hal_legacy.h @@ -0,0 +1,3850 @@ +/** + ****************************************************************************** + * @file stm32_hal_legacy.h + * @author MCD Application Team + * @brief This file contains aliases definition for the STM32Cube HAL constants + * macros and functions maintained for legacy purpose. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2019 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32_HAL_LEGACY +#define STM32_HAL_LEGACY + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup HAL_AES_Aliased_Defines HAL CRYP Aliased Defines maintained for legacy purpose + * @{ + */ +#define AES_FLAG_RDERR CRYP_FLAG_RDERR +#define AES_FLAG_WRERR CRYP_FLAG_WRERR +#define AES_CLEARFLAG_CCF CRYP_CLEARFLAG_CCF +#define AES_CLEARFLAG_RDERR CRYP_CLEARFLAG_RDERR +#define AES_CLEARFLAG_WRERR CRYP_CLEARFLAG_WRERR +#if defined(STM32U5) +#define CRYP_DATATYPE_32B CRYP_NO_SWAP +#define CRYP_DATATYPE_16B CRYP_HALFWORD_SWAP +#define CRYP_DATATYPE_8B CRYP_BYTE_SWAP +#define CRYP_DATATYPE_1B CRYP_BIT_SWAP +#define CRYP_CCF_CLEAR CRYP_CLEAR_CCF +#define CRYP_ERR_CLEAR CRYP_CLEAR_RWEIF +#endif /* STM32U5 */ +/** + * @} + */ + +/** @defgroup HAL_ADC_Aliased_Defines HAL ADC Aliased Defines maintained for legacy purpose + * @{ + */ +#define ADC_RESOLUTION12b ADC_RESOLUTION_12B +#define ADC_RESOLUTION10b ADC_RESOLUTION_10B +#define ADC_RESOLUTION8b ADC_RESOLUTION_8B +#define ADC_RESOLUTION6b ADC_RESOLUTION_6B +#define OVR_DATA_OVERWRITTEN ADC_OVR_DATA_OVERWRITTEN +#define OVR_DATA_PRESERVED ADC_OVR_DATA_PRESERVED +#define EOC_SINGLE_CONV ADC_EOC_SINGLE_CONV +#define EOC_SEQ_CONV ADC_EOC_SEQ_CONV +#define EOC_SINGLE_SEQ_CONV ADC_EOC_SINGLE_SEQ_CONV +#define REGULAR_GROUP ADC_REGULAR_GROUP +#define INJECTED_GROUP ADC_INJECTED_GROUP +#define REGULAR_INJECTED_GROUP ADC_REGULAR_INJECTED_GROUP +#define AWD_EVENT ADC_AWD_EVENT +#define AWD1_EVENT ADC_AWD1_EVENT +#define AWD2_EVENT ADC_AWD2_EVENT +#define AWD3_EVENT ADC_AWD3_EVENT +#define OVR_EVENT ADC_OVR_EVENT +#define JQOVF_EVENT ADC_JQOVF_EVENT +#define ALL_CHANNELS ADC_ALL_CHANNELS +#define REGULAR_CHANNELS ADC_REGULAR_CHANNELS +#define INJECTED_CHANNELS ADC_INJECTED_CHANNELS +#define SYSCFG_FLAG_SENSOR_ADC ADC_FLAG_SENSOR +#define SYSCFG_FLAG_VREF_ADC ADC_FLAG_VREFINT +#define ADC_CLOCKPRESCALER_PCLK_DIV1 ADC_CLOCK_SYNC_PCLK_DIV1 +#define ADC_CLOCKPRESCALER_PCLK_DIV2 ADC_CLOCK_SYNC_PCLK_DIV2 +#define ADC_CLOCKPRESCALER_PCLK_DIV4 ADC_CLOCK_SYNC_PCLK_DIV4 +#define ADC_CLOCKPRESCALER_PCLK_DIV6 ADC_CLOCK_SYNC_PCLK_DIV6 +#define ADC_CLOCKPRESCALER_PCLK_DIV8 ADC_CLOCK_SYNC_PCLK_DIV8 +#define ADC_EXTERNALTRIG0_T6_TRGO ADC_EXTERNALTRIGCONV_T6_TRGO +#define ADC_EXTERNALTRIG1_T21_CC2 ADC_EXTERNALTRIGCONV_T21_CC2 +#define ADC_EXTERNALTRIG2_T2_TRGO ADC_EXTERNALTRIGCONV_T2_TRGO +#define ADC_EXTERNALTRIG3_T2_CC4 ADC_EXTERNALTRIGCONV_T2_CC4 +#define ADC_EXTERNALTRIG4_T22_TRGO ADC_EXTERNALTRIGCONV_T22_TRGO +#define ADC_EXTERNALTRIG7_EXT_IT11 ADC_EXTERNALTRIGCONV_EXT_IT11 +#define ADC_CLOCK_ASYNC ADC_CLOCK_ASYNC_DIV1 +#define ADC_EXTERNALTRIG_EDGE_NONE ADC_EXTERNALTRIGCONVEDGE_NONE +#define ADC_EXTERNALTRIG_EDGE_RISING ADC_EXTERNALTRIGCONVEDGE_RISING +#define ADC_EXTERNALTRIG_EDGE_FALLING ADC_EXTERNALTRIGCONVEDGE_FALLING +#define ADC_EXTERNALTRIG_EDGE_RISINGFALLING ADC_EXTERNALTRIGCONVEDGE_RISINGFALLING +#define ADC_SAMPLETIME_2CYCLE_5 ADC_SAMPLETIME_2CYCLES_5 + +#define HAL_ADC_STATE_BUSY_REG HAL_ADC_STATE_REG_BUSY +#define HAL_ADC_STATE_BUSY_INJ HAL_ADC_STATE_INJ_BUSY +#define HAL_ADC_STATE_EOC_REG HAL_ADC_STATE_REG_EOC +#define HAL_ADC_STATE_EOC_INJ HAL_ADC_STATE_INJ_EOC +#define HAL_ADC_STATE_ERROR HAL_ADC_STATE_ERROR_INTERNAL +#define HAL_ADC_STATE_BUSY HAL_ADC_STATE_BUSY_INTERNAL +#define HAL_ADC_STATE_AWD HAL_ADC_STATE_AWD1 + +#if defined(STM32H7) +#define ADC_CHANNEL_VBAT_DIV4 ADC_CHANNEL_VBAT +#endif /* STM32H7 */ +/** + * @} + */ + +/** @defgroup HAL_CEC_Aliased_Defines HAL CEC Aliased Defines maintained for legacy purpose + * @{ + */ + +#define __HAL_CEC_GET_IT __HAL_CEC_GET_FLAG + +/** + * @} + */ + +/** @defgroup HAL_COMP_Aliased_Defines HAL COMP Aliased Defines maintained for legacy purpose + * @{ + */ +#define COMP_WINDOWMODE_DISABLED COMP_WINDOWMODE_DISABLE +#define COMP_WINDOWMODE_ENABLED COMP_WINDOWMODE_ENABLE +#define COMP_EXTI_LINE_COMP1_EVENT COMP_EXTI_LINE_COMP1 +#define COMP_EXTI_LINE_COMP2_EVENT COMP_EXTI_LINE_COMP2 +#define COMP_EXTI_LINE_COMP3_EVENT COMP_EXTI_LINE_COMP3 +#define COMP_EXTI_LINE_COMP4_EVENT COMP_EXTI_LINE_COMP4 +#define COMP_EXTI_LINE_COMP5_EVENT COMP_EXTI_LINE_COMP5 +#define COMP_EXTI_LINE_COMP6_EVENT COMP_EXTI_LINE_COMP6 +#define COMP_EXTI_LINE_COMP7_EVENT COMP_EXTI_LINE_COMP7 +#if defined(STM32L0) +#define COMP_LPTIMCONNECTION_ENABLED ((uint32_t)0x00000003U) /*!< COMPX output generic naming: connected to LPTIM input 1 for COMP1, LPTIM input 2 for COMP2 */ +#endif +#define COMP_OUTPUT_COMP6TIM2OCREFCLR COMP_OUTPUT_COMP6_TIM2OCREFCLR +#if defined(STM32F373xC) || defined(STM32F378xx) +#define COMP_OUTPUT_TIM3IC1 COMP_OUTPUT_COMP1_TIM3IC1 +#define COMP_OUTPUT_TIM3OCREFCLR COMP_OUTPUT_COMP1_TIM3OCREFCLR +#endif /* STM32F373xC || STM32F378xx */ + +#if defined(STM32L0) || defined(STM32L4) +#define COMP_WINDOWMODE_ENABLE COMP_WINDOWMODE_COMP1_INPUT_PLUS_COMMON + +#define COMP_NONINVERTINGINPUT_IO1 COMP_INPUT_PLUS_IO1 +#define COMP_NONINVERTINGINPUT_IO2 COMP_INPUT_PLUS_IO2 +#define COMP_NONINVERTINGINPUT_IO3 COMP_INPUT_PLUS_IO3 +#define COMP_NONINVERTINGINPUT_IO4 COMP_INPUT_PLUS_IO4 +#define COMP_NONINVERTINGINPUT_IO5 COMP_INPUT_PLUS_IO5 +#define COMP_NONINVERTINGINPUT_IO6 COMP_INPUT_PLUS_IO6 + +#define COMP_INVERTINGINPUT_1_4VREFINT COMP_INPUT_MINUS_1_4VREFINT +#define COMP_INVERTINGINPUT_1_2VREFINT COMP_INPUT_MINUS_1_2VREFINT +#define COMP_INVERTINGINPUT_3_4VREFINT COMP_INPUT_MINUS_3_4VREFINT +#define COMP_INVERTINGINPUT_VREFINT COMP_INPUT_MINUS_VREFINT +#define COMP_INVERTINGINPUT_DAC1_CH1 COMP_INPUT_MINUS_DAC1_CH1 +#define COMP_INVERTINGINPUT_DAC1_CH2 COMP_INPUT_MINUS_DAC1_CH2 +#define COMP_INVERTINGINPUT_DAC1 COMP_INPUT_MINUS_DAC1_CH1 +#define COMP_INVERTINGINPUT_DAC2 COMP_INPUT_MINUS_DAC1_CH2 +#define COMP_INVERTINGINPUT_IO1 COMP_INPUT_MINUS_IO1 +#if defined(STM32L0) +/* Issue fixed on STM32L0 COMP driver: only 2 dedicated IO (IO1 and IO2), */ +/* IO2 was wrongly assigned to IO shared with DAC and IO3 was corresponding */ +/* to the second dedicated IO (only for COMP2). */ +#define COMP_INVERTINGINPUT_IO2 COMP_INPUT_MINUS_DAC1_CH2 +#define COMP_INVERTINGINPUT_IO3 COMP_INPUT_MINUS_IO2 +#else +#define COMP_INVERTINGINPUT_IO2 COMP_INPUT_MINUS_IO2 +#define COMP_INVERTINGINPUT_IO3 COMP_INPUT_MINUS_IO3 +#endif +#define COMP_INVERTINGINPUT_IO4 COMP_INPUT_MINUS_IO4 +#define COMP_INVERTINGINPUT_IO5 COMP_INPUT_MINUS_IO5 + +#define COMP_OUTPUTLEVEL_LOW COMP_OUTPUT_LEVEL_LOW +#define COMP_OUTPUTLEVEL_HIGH COMP_OUTPUT_LEVEL_HIGH + +/* Note: Literal "COMP_FLAG_LOCK" kept for legacy purpose. */ +/* To check COMP lock state, use macro "__HAL_COMP_IS_LOCKED()". */ +#if defined(COMP_CSR_LOCK) +#define COMP_FLAG_LOCK COMP_CSR_LOCK +#elif defined(COMP_CSR_COMP1LOCK) +#define COMP_FLAG_LOCK COMP_CSR_COMP1LOCK +#elif defined(COMP_CSR_COMPxLOCK) +#define COMP_FLAG_LOCK COMP_CSR_COMPxLOCK +#endif + +#if defined(STM32L4) +#define COMP_BLANKINGSRCE_TIM1OC5 COMP_BLANKINGSRC_TIM1_OC5_COMP1 +#define COMP_BLANKINGSRCE_TIM2OC3 COMP_BLANKINGSRC_TIM2_OC3_COMP1 +#define COMP_BLANKINGSRCE_TIM3OC3 COMP_BLANKINGSRC_TIM3_OC3_COMP1 +#define COMP_BLANKINGSRCE_TIM3OC4 COMP_BLANKINGSRC_TIM3_OC4_COMP2 +#define COMP_BLANKINGSRCE_TIM8OC5 COMP_BLANKINGSRC_TIM8_OC5_COMP2 +#define COMP_BLANKINGSRCE_TIM15OC1 COMP_BLANKINGSRC_TIM15_OC1_COMP2 +#define COMP_BLANKINGSRCE_NONE COMP_BLANKINGSRC_NONE +#endif + +#if defined(STM32L0) +#define COMP_MODE_HIGHSPEED COMP_POWERMODE_MEDIUMSPEED +#define COMP_MODE_LOWSPEED COMP_POWERMODE_ULTRALOWPOWER +#else +#define COMP_MODE_HIGHSPEED COMP_POWERMODE_HIGHSPEED +#define COMP_MODE_MEDIUMSPEED COMP_POWERMODE_MEDIUMSPEED +#define COMP_MODE_LOWPOWER COMP_POWERMODE_LOWPOWER +#define COMP_MODE_ULTRALOWPOWER COMP_POWERMODE_ULTRALOWPOWER +#endif + +#endif +/** + * @} + */ + +/** @defgroup HAL_CORTEX_Aliased_Defines HAL CORTEX Aliased Defines maintained for legacy purpose + * @{ + */ +#define __HAL_CORTEX_SYSTICKCLK_CONFIG HAL_SYSTICK_CLKSourceConfig +/** + * @} + */ + +/** + * @} + */ + +/** @defgroup HAL_CRC_Aliased_Defines HAL CRC Aliased Defines maintained for legacy purpose + * @{ + */ + +#define CRC_OUTPUTDATA_INVERSION_DISABLED CRC_OUTPUTDATA_INVERSION_DISABLE +#define CRC_OUTPUTDATA_INVERSION_ENABLED CRC_OUTPUTDATA_INVERSION_ENABLE + +/** + * @} + */ + +/** @defgroup HAL_DAC_Aliased_Defines HAL DAC Aliased Defines maintained for legacy purpose + * @{ + */ + +#define DAC1_CHANNEL_1 DAC_CHANNEL_1 +#define DAC1_CHANNEL_2 DAC_CHANNEL_2 +#define DAC2_CHANNEL_1 DAC_CHANNEL_1 +#define DAC_WAVE_NONE 0x00000000U +#define DAC_WAVE_NOISE DAC_CR_WAVE1_0 +#define DAC_WAVE_TRIANGLE DAC_CR_WAVE1_1 +#define DAC_WAVEGENERATION_NONE DAC_WAVE_NONE +#define DAC_WAVEGENERATION_NOISE DAC_WAVE_NOISE +#define DAC_WAVEGENERATION_TRIANGLE DAC_WAVE_TRIANGLE + +#if defined(STM32G4) || defined(STM32H7) || defined (STM32U5) +#define DAC_CHIPCONNECT_DISABLE DAC_CHIPCONNECT_EXTERNAL +#define DAC_CHIPCONNECT_ENABLE DAC_CHIPCONNECT_INTERNAL +#endif + +#if defined(STM32L1) || defined(STM32L4) || defined(STM32G0) || defined(STM32L5) || defined(STM32H7) || defined(STM32F4) || defined(STM32G4) +#define HAL_DAC_MSP_INIT_CB_ID HAL_DAC_MSPINIT_CB_ID +#define HAL_DAC_MSP_DEINIT_CB_ID HAL_DAC_MSPDEINIT_CB_ID +#endif + +/** + * @} + */ + +/** @defgroup HAL_DMA_Aliased_Defines HAL DMA Aliased Defines maintained for legacy purpose + * @{ + */ +#define HAL_REMAPDMA_ADC_DMA_CH2 DMA_REMAP_ADC_DMA_CH2 +#define HAL_REMAPDMA_USART1_TX_DMA_CH4 DMA_REMAP_USART1_TX_DMA_CH4 +#define HAL_REMAPDMA_USART1_RX_DMA_CH5 DMA_REMAP_USART1_RX_DMA_CH5 +#define HAL_REMAPDMA_TIM16_DMA_CH4 DMA_REMAP_TIM16_DMA_CH4 +#define HAL_REMAPDMA_TIM17_DMA_CH2 DMA_REMAP_TIM17_DMA_CH2 +#define HAL_REMAPDMA_USART3_DMA_CH32 DMA_REMAP_USART3_DMA_CH32 +#define HAL_REMAPDMA_TIM16_DMA_CH6 DMA_REMAP_TIM16_DMA_CH6 +#define HAL_REMAPDMA_TIM17_DMA_CH7 DMA_REMAP_TIM17_DMA_CH7 +#define HAL_REMAPDMA_SPI2_DMA_CH67 DMA_REMAP_SPI2_DMA_CH67 +#define HAL_REMAPDMA_USART2_DMA_CH67 DMA_REMAP_USART2_DMA_CH67 +#define HAL_REMAPDMA_I2C1_DMA_CH76 DMA_REMAP_I2C1_DMA_CH76 +#define HAL_REMAPDMA_TIM1_DMA_CH6 DMA_REMAP_TIM1_DMA_CH6 +#define HAL_REMAPDMA_TIM2_DMA_CH7 DMA_REMAP_TIM2_DMA_CH7 +#define HAL_REMAPDMA_TIM3_DMA_CH6 DMA_REMAP_TIM3_DMA_CH6 + +#define IS_HAL_REMAPDMA IS_DMA_REMAP +#define __HAL_REMAPDMA_CHANNEL_ENABLE __HAL_DMA_REMAP_CHANNEL_ENABLE +#define __HAL_REMAPDMA_CHANNEL_DISABLE __HAL_DMA_REMAP_CHANNEL_DISABLE + +#if defined(STM32L4) + +#define HAL_DMAMUX1_REQUEST_GEN_EXTI0 HAL_DMAMUX1_REQ_GEN_EXTI0 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI1 HAL_DMAMUX1_REQ_GEN_EXTI1 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI2 HAL_DMAMUX1_REQ_GEN_EXTI2 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI3 HAL_DMAMUX1_REQ_GEN_EXTI3 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI4 HAL_DMAMUX1_REQ_GEN_EXTI4 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI5 HAL_DMAMUX1_REQ_GEN_EXTI5 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI6 HAL_DMAMUX1_REQ_GEN_EXTI6 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI7 HAL_DMAMUX1_REQ_GEN_EXTI7 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI8 HAL_DMAMUX1_REQ_GEN_EXTI8 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI9 HAL_DMAMUX1_REQ_GEN_EXTI9 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI10 HAL_DMAMUX1_REQ_GEN_EXTI10 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI11 HAL_DMAMUX1_REQ_GEN_EXTI11 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI12 HAL_DMAMUX1_REQ_GEN_EXTI12 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI13 HAL_DMAMUX1_REQ_GEN_EXTI13 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI14 HAL_DMAMUX1_REQ_GEN_EXTI14 +#define HAL_DMAMUX1_REQUEST_GEN_EXTI15 HAL_DMAMUX1_REQ_GEN_EXTI15 +#define HAL_DMAMUX1_REQUEST_GEN_DMAMUX1_CH0_EVT HAL_DMAMUX1_REQ_GEN_DMAMUX1_CH0_EVT +#define HAL_DMAMUX1_REQUEST_GEN_DMAMUX1_CH1_EVT HAL_DMAMUX1_REQ_GEN_DMAMUX1_CH1_EVT +#define HAL_DMAMUX1_REQUEST_GEN_DMAMUX1_CH2_EVT HAL_DMAMUX1_REQ_GEN_DMAMUX1_CH2_EVT +#define HAL_DMAMUX1_REQUEST_GEN_DMAMUX1_CH3_EVT HAL_DMAMUX1_REQ_GEN_DMAMUX1_CH3_EVT +#define HAL_DMAMUX1_REQUEST_GEN_LPTIM1_OUT HAL_DMAMUX1_REQ_GEN_LPTIM1_OUT +#define HAL_DMAMUX1_REQUEST_GEN_LPTIM2_OUT HAL_DMAMUX1_REQ_GEN_LPTIM2_OUT +#define HAL_DMAMUX1_REQUEST_GEN_DSI_TE HAL_DMAMUX1_REQ_GEN_DSI_TE +#define HAL_DMAMUX1_REQUEST_GEN_DSI_EOT HAL_DMAMUX1_REQ_GEN_DSI_EOT +#define HAL_DMAMUX1_REQUEST_GEN_DMA2D_EOT HAL_DMAMUX1_REQ_GEN_DMA2D_EOT +#define HAL_DMAMUX1_REQUEST_GEN_LTDC_IT HAL_DMAMUX1_REQ_GEN_LTDC_IT + +#define HAL_DMAMUX_REQUEST_GEN_NO_EVENT HAL_DMAMUX_REQ_GEN_NO_EVENT +#define HAL_DMAMUX_REQUEST_GEN_RISING HAL_DMAMUX_REQ_GEN_RISING +#define HAL_DMAMUX_REQUEST_GEN_FALLING HAL_DMAMUX_REQ_GEN_FALLING +#define HAL_DMAMUX_REQUEST_GEN_RISING_FALLING HAL_DMAMUX_REQ_GEN_RISING_FALLING + +#if defined(STM32L4R5xx) || defined(STM32L4R9xx) || defined(STM32L4R9xx) || defined(STM32L4S5xx) || defined(STM32L4S7xx) || defined(STM32L4S9xx) +#define DMA_REQUEST_DCMI_PSSI DMA_REQUEST_DCMI +#endif + +#endif /* STM32L4 */ + +#if defined(STM32G0) +#define DMA_REQUEST_DAC1_CHANNEL1 DMA_REQUEST_DAC1_CH1 +#define DMA_REQUEST_DAC1_CHANNEL2 DMA_REQUEST_DAC1_CH2 +#define DMA_REQUEST_TIM16_TRIG_COM DMA_REQUEST_TIM16_COM +#define DMA_REQUEST_TIM17_TRIG_COM DMA_REQUEST_TIM17_COM + +#define LL_DMAMUX_REQ_TIM16_TRIG_COM LL_DMAMUX_REQ_TIM16_COM +#define LL_DMAMUX_REQ_TIM17_TRIG_COM LL_DMAMUX_REQ_TIM17_COM +#endif + +#if defined(STM32H7) + +#define DMA_REQUEST_DAC1 DMA_REQUEST_DAC1_CH1 +#define DMA_REQUEST_DAC2 DMA_REQUEST_DAC1_CH2 + +#define BDMA_REQUEST_LP_UART1_RX BDMA_REQUEST_LPUART1_RX +#define BDMA_REQUEST_LP_UART1_TX BDMA_REQUEST_LPUART1_TX + +#define HAL_DMAMUX1_REQUEST_GEN_DMAMUX1_CH0_EVT HAL_DMAMUX1_REQ_GEN_DMAMUX1_CH0_EVT +#define HAL_DMAMUX1_REQUEST_GEN_DMAMUX1_CH1_EVT HAL_DMAMUX1_REQ_GEN_DMAMUX1_CH1_EVT +#define HAL_DMAMUX1_REQUEST_GEN_DMAMUX1_CH2_EVT HAL_DMAMUX1_REQ_GEN_DMAMUX1_CH2_EVT +#define HAL_DMAMUX1_REQUEST_GEN_LPTIM1_OUT HAL_DMAMUX1_REQ_GEN_LPTIM1_OUT +#define HAL_DMAMUX1_REQUEST_GEN_LPTIM2_OUT HAL_DMAMUX1_REQ_GEN_LPTIM2_OUT +#define HAL_DMAMUX1_REQUEST_GEN_LPTIM3_OUT HAL_DMAMUX1_REQ_GEN_LPTIM3_OUT +#define HAL_DMAMUX1_REQUEST_GEN_EXTI0 HAL_DMAMUX1_REQ_GEN_EXTI0 +#define HAL_DMAMUX1_REQUEST_GEN_TIM12_TRGO HAL_DMAMUX1_REQ_GEN_TIM12_TRGO + +#define HAL_DMAMUX2_REQUEST_GEN_DMAMUX2_CH0_EVT HAL_DMAMUX2_REQ_GEN_DMAMUX2_CH0_EVT +#define HAL_DMAMUX2_REQUEST_GEN_DMAMUX2_CH1_EVT HAL_DMAMUX2_REQ_GEN_DMAMUX2_CH1_EVT +#define HAL_DMAMUX2_REQUEST_GEN_DMAMUX2_CH2_EVT HAL_DMAMUX2_REQ_GEN_DMAMUX2_CH2_EVT +#define HAL_DMAMUX2_REQUEST_GEN_DMAMUX2_CH3_EVT HAL_DMAMUX2_REQ_GEN_DMAMUX2_CH3_EVT +#define HAL_DMAMUX2_REQUEST_GEN_DMAMUX2_CH4_EVT HAL_DMAMUX2_REQ_GEN_DMAMUX2_CH4_EVT +#define HAL_DMAMUX2_REQUEST_GEN_DMAMUX2_CH5_EVT HAL_DMAMUX2_REQ_GEN_DMAMUX2_CH5_EVT +#define HAL_DMAMUX2_REQUEST_GEN_DMAMUX2_CH6_EVT HAL_DMAMUX2_REQ_GEN_DMAMUX2_CH6_EVT +#define HAL_DMAMUX2_REQUEST_GEN_LPUART1_RX_WKUP HAL_DMAMUX2_REQ_GEN_LPUART1_RX_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_LPUART1_TX_WKUP HAL_DMAMUX2_REQ_GEN_LPUART1_TX_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_LPTIM2_WKUP HAL_DMAMUX2_REQ_GEN_LPTIM2_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_LPTIM2_OUT HAL_DMAMUX2_REQ_GEN_LPTIM2_OUT +#define HAL_DMAMUX2_REQUEST_GEN_LPTIM3_WKUP HAL_DMAMUX2_REQ_GEN_LPTIM3_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_LPTIM3_OUT HAL_DMAMUX2_REQ_GEN_LPTIM3_OUT +#define HAL_DMAMUX2_REQUEST_GEN_LPTIM4_WKUP HAL_DMAMUX2_REQ_GEN_LPTIM4_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_LPTIM5_WKUP HAL_DMAMUX2_REQ_GEN_LPTIM5_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_I2C4_WKUP HAL_DMAMUX2_REQ_GEN_I2C4_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_SPI6_WKUP HAL_DMAMUX2_REQ_GEN_SPI6_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_COMP1_OUT HAL_DMAMUX2_REQ_GEN_COMP1_OUT +#define HAL_DMAMUX2_REQUEST_GEN_COMP2_OUT HAL_DMAMUX2_REQ_GEN_COMP2_OUT +#define HAL_DMAMUX2_REQUEST_GEN_RTC_WKUP HAL_DMAMUX2_REQ_GEN_RTC_WKUP +#define HAL_DMAMUX2_REQUEST_GEN_EXTI0 HAL_DMAMUX2_REQ_GEN_EXTI0 +#define HAL_DMAMUX2_REQUEST_GEN_EXTI2 HAL_DMAMUX2_REQ_GEN_EXTI2 +#define HAL_DMAMUX2_REQUEST_GEN_I2C4_IT_EVT HAL_DMAMUX2_REQ_GEN_I2C4_IT_EVT +#define HAL_DMAMUX2_REQUEST_GEN_SPI6_IT HAL_DMAMUX2_REQ_GEN_SPI6_IT +#define HAL_DMAMUX2_REQUEST_GEN_LPUART1_TX_IT HAL_DMAMUX2_REQ_GEN_LPUART1_TX_IT +#define HAL_DMAMUX2_REQUEST_GEN_LPUART1_RX_IT HAL_DMAMUX2_REQ_GEN_LPUART1_RX_IT +#define HAL_DMAMUX2_REQUEST_GEN_ADC3_IT HAL_DMAMUX2_REQ_GEN_ADC3_IT +#define HAL_DMAMUX2_REQUEST_GEN_ADC3_AWD1_OUT HAL_DMAMUX2_REQ_GEN_ADC3_AWD1_OUT +#define HAL_DMAMUX2_REQUEST_GEN_BDMA_CH0_IT HAL_DMAMUX2_REQ_GEN_BDMA_CH0_IT +#define HAL_DMAMUX2_REQUEST_GEN_BDMA_CH1_IT HAL_DMAMUX2_REQ_GEN_BDMA_CH1_IT + +#define HAL_DMAMUX_REQUEST_GEN_NO_EVENT HAL_DMAMUX_REQ_GEN_NO_EVENT +#define HAL_DMAMUX_REQUEST_GEN_RISING HAL_DMAMUX_REQ_GEN_RISING +#define HAL_DMAMUX_REQUEST_GEN_FALLING HAL_DMAMUX_REQ_GEN_FALLING +#define HAL_DMAMUX_REQUEST_GEN_RISING_FALLING HAL_DMAMUX_REQ_GEN_RISING_FALLING + +#define DFSDM_FILTER_EXT_TRIG_LPTIM1 DFSDM_FILTER_EXT_TRIG_LPTIM1_OUT +#define DFSDM_FILTER_EXT_TRIG_LPTIM2 DFSDM_FILTER_EXT_TRIG_LPTIM2_OUT +#define DFSDM_FILTER_EXT_TRIG_LPTIM3 DFSDM_FILTER_EXT_TRIG_LPTIM3_OUT + +#define DAC_TRIGGER_LP1_OUT DAC_TRIGGER_LPTIM1_OUT +#define DAC_TRIGGER_LP2_OUT DAC_TRIGGER_LPTIM2_OUT + +#endif /* STM32H7 */ +/** + * @} + */ + +/** @defgroup HAL_FLASH_Aliased_Defines HAL FLASH Aliased Defines maintained for legacy purpose + * @{ + */ + +#define TYPEPROGRAM_BYTE FLASH_TYPEPROGRAM_BYTE +#define TYPEPROGRAM_HALFWORD FLASH_TYPEPROGRAM_HALFWORD +#define TYPEPROGRAM_WORD FLASH_TYPEPROGRAM_WORD +#define TYPEPROGRAM_DOUBLEWORD FLASH_TYPEPROGRAM_DOUBLEWORD +#define TYPEERASE_SECTORS FLASH_TYPEERASE_SECTORS +#define TYPEERASE_PAGES FLASH_TYPEERASE_PAGES +#define TYPEERASE_PAGEERASE FLASH_TYPEERASE_PAGES +#define TYPEERASE_MASSERASE FLASH_TYPEERASE_MASSERASE +#define WRPSTATE_DISABLE OB_WRPSTATE_DISABLE +#define WRPSTATE_ENABLE OB_WRPSTATE_ENABLE +#define HAL_FLASH_TIMEOUT_VALUE FLASH_TIMEOUT_VALUE +#define OBEX_PCROP OPTIONBYTE_PCROP +#define OBEX_BOOTCONFIG OPTIONBYTE_BOOTCONFIG +#define PCROPSTATE_DISABLE OB_PCROP_STATE_DISABLE +#define PCROPSTATE_ENABLE OB_PCROP_STATE_ENABLE +#define TYPEERASEDATA_BYTE FLASH_TYPEERASEDATA_BYTE +#define TYPEERASEDATA_HALFWORD FLASH_TYPEERASEDATA_HALFWORD +#define TYPEERASEDATA_WORD FLASH_TYPEERASEDATA_WORD +#define TYPEPROGRAMDATA_BYTE FLASH_TYPEPROGRAMDATA_BYTE +#define TYPEPROGRAMDATA_HALFWORD FLASH_TYPEPROGRAMDATA_HALFWORD +#define TYPEPROGRAMDATA_WORD FLASH_TYPEPROGRAMDATA_WORD +#define TYPEPROGRAMDATA_FASTBYTE FLASH_TYPEPROGRAMDATA_FASTBYTE +#define TYPEPROGRAMDATA_FASTHALFWORD FLASH_TYPEPROGRAMDATA_FASTHALFWORD +#define TYPEPROGRAMDATA_FASTWORD FLASH_TYPEPROGRAMDATA_FASTWORD +#define PAGESIZE FLASH_PAGE_SIZE +#define TYPEPROGRAM_FASTBYTE FLASH_TYPEPROGRAM_BYTE +#define TYPEPROGRAM_FASTHALFWORD FLASH_TYPEPROGRAM_HALFWORD +#define TYPEPROGRAM_FASTWORD FLASH_TYPEPROGRAM_WORD +#define VOLTAGE_RANGE_1 FLASH_VOLTAGE_RANGE_1 +#define VOLTAGE_RANGE_2 FLASH_VOLTAGE_RANGE_2 +#define VOLTAGE_RANGE_3 FLASH_VOLTAGE_RANGE_3 +#define VOLTAGE_RANGE_4 FLASH_VOLTAGE_RANGE_4 +#define TYPEPROGRAM_FAST FLASH_TYPEPROGRAM_FAST +#define TYPEPROGRAM_FAST_AND_LAST FLASH_TYPEPROGRAM_FAST_AND_LAST +#define WRPAREA_BANK1_AREAA OB_WRPAREA_BANK1_AREAA +#define WRPAREA_BANK1_AREAB OB_WRPAREA_BANK1_AREAB +#define WRPAREA_BANK2_AREAA OB_WRPAREA_BANK2_AREAA +#define WRPAREA_BANK2_AREAB OB_WRPAREA_BANK2_AREAB +#define IWDG_STDBY_FREEZE OB_IWDG_STDBY_FREEZE +#define IWDG_STDBY_ACTIVE OB_IWDG_STDBY_RUN +#define IWDG_STOP_FREEZE OB_IWDG_STOP_FREEZE +#define IWDG_STOP_ACTIVE OB_IWDG_STOP_RUN +#define FLASH_ERROR_NONE HAL_FLASH_ERROR_NONE +#define FLASH_ERROR_RD HAL_FLASH_ERROR_RD +#define FLASH_ERROR_PG HAL_FLASH_ERROR_PROG +#define FLASH_ERROR_PGP HAL_FLASH_ERROR_PGS +#define FLASH_ERROR_WRP HAL_FLASH_ERROR_WRP +#define FLASH_ERROR_OPTV HAL_FLASH_ERROR_OPTV +#define FLASH_ERROR_OPTVUSR HAL_FLASH_ERROR_OPTVUSR +#define FLASH_ERROR_PROG HAL_FLASH_ERROR_PROG +#define FLASH_ERROR_OP HAL_FLASH_ERROR_OPERATION +#define FLASH_ERROR_PGA HAL_FLASH_ERROR_PGA +#define FLASH_ERROR_SIZE HAL_FLASH_ERROR_SIZE +#define FLASH_ERROR_SIZ HAL_FLASH_ERROR_SIZE +#define FLASH_ERROR_PGS HAL_FLASH_ERROR_PGS +#define FLASH_ERROR_MIS HAL_FLASH_ERROR_MIS +#define FLASH_ERROR_FAST HAL_FLASH_ERROR_FAST +#define FLASH_ERROR_FWWERR HAL_FLASH_ERROR_FWWERR +#define FLASH_ERROR_NOTZERO HAL_FLASH_ERROR_NOTZERO +#define FLASH_ERROR_OPERATION HAL_FLASH_ERROR_OPERATION +#define FLASH_ERROR_ERS HAL_FLASH_ERROR_ERS +#define OB_WDG_SW OB_IWDG_SW +#define OB_WDG_HW OB_IWDG_HW +#define OB_SDADC12_VDD_MONITOR_SET OB_SDACD_VDD_MONITOR_SET +#define OB_SDADC12_VDD_MONITOR_RESET OB_SDACD_VDD_MONITOR_RESET +#define OB_RAM_PARITY_CHECK_SET OB_SRAM_PARITY_SET +#define OB_RAM_PARITY_CHECK_RESET OB_SRAM_PARITY_RESET +#define IS_OB_SDADC12_VDD_MONITOR IS_OB_SDACD_VDD_MONITOR +#define OB_RDP_LEVEL0 OB_RDP_LEVEL_0 +#define OB_RDP_LEVEL1 OB_RDP_LEVEL_1 +#define OB_RDP_LEVEL2 OB_RDP_LEVEL_2 +#if defined(STM32G0) +#define OB_BOOT_LOCK_DISABLE OB_BOOT_ENTRY_FORCED_NONE +#define OB_BOOT_LOCK_ENABLE OB_BOOT_ENTRY_FORCED_FLASH +#else +#define OB_BOOT_ENTRY_FORCED_NONE OB_BOOT_LOCK_DISABLE +#define OB_BOOT_ENTRY_FORCED_FLASH OB_BOOT_LOCK_ENABLE +#endif +#if defined(STM32H7) +#define FLASH_FLAG_SNECCE_BANK1RR FLASH_FLAG_SNECCERR_BANK1 +#define FLASH_FLAG_DBECCE_BANK1RR FLASH_FLAG_DBECCERR_BANK1 +#define FLASH_FLAG_STRBER_BANK1R FLASH_FLAG_STRBERR_BANK1 +#define FLASH_FLAG_SNECCE_BANK2RR FLASH_FLAG_SNECCERR_BANK2 +#define FLASH_FLAG_DBECCE_BANK2RR FLASH_FLAG_DBECCERR_BANK2 +#define FLASH_FLAG_STRBER_BANK2R FLASH_FLAG_STRBERR_BANK2 +#define FLASH_FLAG_WDW FLASH_FLAG_WBNE +#define OB_WRP_SECTOR_All OB_WRP_SECTOR_ALL +#endif /* STM32H7 */ +#if defined(STM32U5) +#define OB_USER_nRST_STOP OB_USER_NRST_STOP +#define OB_USER_nRST_STDBY OB_USER_NRST_STDBY +#define OB_USER_nRST_SHDW OB_USER_NRST_SHDW +#define OB_USER_nSWBOOT0 OB_USER_NSWBOOT0 +#define OB_USER_nBOOT0 OB_USER_NBOOT0 +#define OB_nBOOT0_RESET OB_NBOOT0_RESET +#define OB_nBOOT0_SET OB_NBOOT0_SET +#endif /* STM32U5 */ + +/** + * @} + */ + +/** @defgroup HAL_JPEG_Aliased_Macros HAL JPEG Aliased Macros maintained for legacy purpose + * @{ + */ + +#if defined(STM32H7) +#define __HAL_RCC_JPEG_CLK_ENABLE __HAL_RCC_JPGDECEN_CLK_ENABLE +#define __HAL_RCC_JPEG_CLK_DISABLE __HAL_RCC_JPGDECEN_CLK_DISABLE +#define __HAL_RCC_JPEG_FORCE_RESET __HAL_RCC_JPGDECRST_FORCE_RESET +#define __HAL_RCC_JPEG_RELEASE_RESET __HAL_RCC_JPGDECRST_RELEASE_RESET +#define __HAL_RCC_JPEG_CLK_SLEEP_ENABLE __HAL_RCC_JPGDEC_CLK_SLEEP_ENABLE +#define __HAL_RCC_JPEG_CLK_SLEEP_DISABLE __HAL_RCC_JPGDEC_CLK_SLEEP_DISABLE +#endif /* STM32H7 */ + +/** + * @} + */ + +/** @defgroup HAL_SYSCFG_Aliased_Defines HAL SYSCFG Aliased Defines maintained for legacy purpose + * @{ + */ + +#define HAL_SYSCFG_FASTMODEPLUS_I2C_PA9 I2C_FASTMODEPLUS_PA9 +#define HAL_SYSCFG_FASTMODEPLUS_I2C_PA10 I2C_FASTMODEPLUS_PA10 +#define HAL_SYSCFG_FASTMODEPLUS_I2C_PB6 I2C_FASTMODEPLUS_PB6 +#define HAL_SYSCFG_FASTMODEPLUS_I2C_PB7 I2C_FASTMODEPLUS_PB7 +#define HAL_SYSCFG_FASTMODEPLUS_I2C_PB8 I2C_FASTMODEPLUS_PB8 +#define HAL_SYSCFG_FASTMODEPLUS_I2C_PB9 I2C_FASTMODEPLUS_PB9 +#define HAL_SYSCFG_FASTMODEPLUS_I2C1 I2C_FASTMODEPLUS_I2C1 +#define HAL_SYSCFG_FASTMODEPLUS_I2C2 I2C_FASTMODEPLUS_I2C2 +#define HAL_SYSCFG_FASTMODEPLUS_I2C3 I2C_FASTMODEPLUS_I2C3 +#if defined(STM32G4) + +#define HAL_SYSCFG_EnableIOAnalogSwitchBooster HAL_SYSCFG_EnableIOSwitchBooster +#define HAL_SYSCFG_DisableIOAnalogSwitchBooster HAL_SYSCFG_DisableIOSwitchBooster +#define HAL_SYSCFG_EnableIOAnalogSwitchVDD HAL_SYSCFG_EnableIOSwitchVDD +#define HAL_SYSCFG_DisableIOAnalogSwitchVDD HAL_SYSCFG_DisableIOSwitchVDD +#endif /* STM32G4 */ + +/** + * @} + */ + + +/** @defgroup LL_FMC_Aliased_Defines LL FMC Aliased Defines maintained for compatibility purpose + * @{ + */ +#if defined(STM32L4) || defined(STM32F7) || defined(STM32H7) || defined(STM32G4) +#define FMC_NAND_PCC_WAIT_FEATURE_DISABLE FMC_NAND_WAIT_FEATURE_DISABLE +#define FMC_NAND_PCC_WAIT_FEATURE_ENABLE FMC_NAND_WAIT_FEATURE_ENABLE +#define FMC_NAND_PCC_MEM_BUS_WIDTH_8 FMC_NAND_MEM_BUS_WIDTH_8 +#define FMC_NAND_PCC_MEM_BUS_WIDTH_16 FMC_NAND_MEM_BUS_WIDTH_16 +#elif defined(STM32F1) || defined(STM32F2) || defined(STM32F3) || defined(STM32F4) +#define FMC_NAND_WAIT_FEATURE_DISABLE FMC_NAND_PCC_WAIT_FEATURE_DISABLE +#define FMC_NAND_WAIT_FEATURE_ENABLE FMC_NAND_PCC_WAIT_FEATURE_ENABLE +#define FMC_NAND_MEM_BUS_WIDTH_8 FMC_NAND_PCC_MEM_BUS_WIDTH_8 +#define FMC_NAND_MEM_BUS_WIDTH_16 FMC_NAND_PCC_MEM_BUS_WIDTH_16 +#endif +/** + * @} + */ + +/** @defgroup LL_FSMC_Aliased_Defines LL FSMC Aliased Defines maintained for legacy purpose + * @{ + */ + +#define FSMC_NORSRAM_TYPEDEF FSMC_NORSRAM_TypeDef +#define FSMC_NORSRAM_EXTENDED_TYPEDEF FSMC_NORSRAM_EXTENDED_TypeDef +/** + * @} + */ + +/** @defgroup HAL_GPIO_Aliased_Macros HAL GPIO Aliased Macros maintained for legacy purpose + * @{ + */ +#define GET_GPIO_SOURCE GPIO_GET_INDEX +#define GET_GPIO_INDEX GPIO_GET_INDEX + +#if defined(STM32F4) +#define GPIO_AF12_SDMMC GPIO_AF12_SDIO +#define GPIO_AF12_SDMMC1 GPIO_AF12_SDIO +#endif + +#if defined(STM32F7) +#define GPIO_AF12_SDIO GPIO_AF12_SDMMC1 +#define GPIO_AF12_SDMMC GPIO_AF12_SDMMC1 +#endif + +#if defined(STM32L4) +#define GPIO_AF12_SDIO GPIO_AF12_SDMMC1 +#define GPIO_AF12_SDMMC GPIO_AF12_SDMMC1 +#endif + +#if defined(STM32H7) +#define GPIO_AF7_SDIO1 GPIO_AF7_SDMMC1 +#define GPIO_AF8_SDIO1 GPIO_AF8_SDMMC1 +#define GPIO_AF12_SDIO1 GPIO_AF12_SDMMC1 +#define GPIO_AF9_SDIO2 GPIO_AF9_SDMMC2 +#define GPIO_AF10_SDIO2 GPIO_AF10_SDMMC2 +#define GPIO_AF11_SDIO2 GPIO_AF11_SDMMC2 + +#if defined (STM32H743xx) || defined (STM32H753xx) || defined (STM32H750xx) || defined (STM32H742xx) || \ + defined (STM32H745xx) || defined (STM32H755xx) || defined (STM32H747xx) || defined (STM32H757xx) +#define GPIO_AF10_OTG2_HS GPIO_AF10_OTG2_FS +#define GPIO_AF10_OTG1_FS GPIO_AF10_OTG1_HS +#define GPIO_AF12_OTG2_FS GPIO_AF12_OTG1_FS +#endif /*STM32H743xx || STM32H753xx || STM32H750xx || STM32H742xx || STM32H745xx || STM32H755xx || STM32H747xx || STM32H757xx */ +#endif /* STM32H7 */ + +#define GPIO_AF0_LPTIM GPIO_AF0_LPTIM1 +#define GPIO_AF1_LPTIM GPIO_AF1_LPTIM1 +#define GPIO_AF2_LPTIM GPIO_AF2_LPTIM1 + +#if defined(STM32L0) || defined(STM32L4) || defined(STM32F4) || defined(STM32F2) || defined(STM32F7) || defined(STM32G4) || defined(STM32H7) || defined(STM32WB) || defined(STM32U5) +#define GPIO_SPEED_LOW GPIO_SPEED_FREQ_LOW +#define GPIO_SPEED_MEDIUM GPIO_SPEED_FREQ_MEDIUM +#define GPIO_SPEED_FAST GPIO_SPEED_FREQ_HIGH +#define GPIO_SPEED_HIGH GPIO_SPEED_FREQ_VERY_HIGH +#endif /* STM32L0 || STM32L4 || STM32F4 || STM32F2 || STM32F7 || STM32G4 || STM32H7 || STM32WB || STM32U5*/ + +#if defined(STM32L1) +#define GPIO_SPEED_VERY_LOW GPIO_SPEED_FREQ_LOW +#define GPIO_SPEED_LOW GPIO_SPEED_FREQ_MEDIUM +#define GPIO_SPEED_MEDIUM GPIO_SPEED_FREQ_HIGH +#define GPIO_SPEED_HIGH GPIO_SPEED_FREQ_VERY_HIGH +#endif /* STM32L1 */ + +#if defined(STM32F0) || defined(STM32F3) || defined(STM32F1) +#define GPIO_SPEED_LOW GPIO_SPEED_FREQ_LOW +#define GPIO_SPEED_MEDIUM GPIO_SPEED_FREQ_MEDIUM +#define GPIO_SPEED_HIGH GPIO_SPEED_FREQ_HIGH +#endif /* STM32F0 || STM32F3 || STM32F1 */ + +#define GPIO_AF6_DFSDM GPIO_AF6_DFSDM1 +/** + * @} + */ + +/** @defgroup HAL_HRTIM_Aliased_Macros HAL HRTIM Aliased Macros maintained for legacy purpose + * @{ + */ +#define HRTIM_TIMDELAYEDPROTECTION_DISABLED HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_DISABLED +#define HRTIM_TIMDELAYEDPROTECTION_DELAYEDOUT1_EEV68 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_DELAYEDOUT1_EEV6 +#define HRTIM_TIMDELAYEDPROTECTION_DELAYEDOUT2_EEV68 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_DELAYEDOUT2_EEV6 +#define HRTIM_TIMDELAYEDPROTECTION_DELAYEDBOTH_EEV68 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_DELAYEDBOTH_EEV6 +#define HRTIM_TIMDELAYEDPROTECTION_BALANCED_EEV68 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_BALANCED_EEV6 +#define HRTIM_TIMDELAYEDPROTECTION_DELAYEDOUT1_DEEV79 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_DELAYEDOUT1_DEEV7 +#define HRTIM_TIMDELAYEDPROTECTION_DELAYEDOUT2_DEEV79 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_DELAYEDOUT2_DEEV7 +#define HRTIM_TIMDELAYEDPROTECTION_DELAYEDBOTH_EEV79 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_DELAYEDBOTH_EEV7 +#define HRTIM_TIMDELAYEDPROTECTION_BALANCED_EEV79 HRTIM_TIMER_A_B_C_DELAYEDPROTECTION_BALANCED_EEV7 + +#define __HAL_HRTIM_SetCounter __HAL_HRTIM_SETCOUNTER +#define __HAL_HRTIM_GetCounter __HAL_HRTIM_GETCOUNTER +#define __HAL_HRTIM_SetPeriod __HAL_HRTIM_SETPERIOD +#define __HAL_HRTIM_GetPeriod __HAL_HRTIM_GETPERIOD +#define __HAL_HRTIM_SetClockPrescaler __HAL_HRTIM_SETCLOCKPRESCALER +#define __HAL_HRTIM_GetClockPrescaler __HAL_HRTIM_GETCLOCKPRESCALER +#define __HAL_HRTIM_SetCompare __HAL_HRTIM_SETCOMPARE +#define __HAL_HRTIM_GetCompare __HAL_HRTIM_GETCOMPARE + +#if defined(STM32G4) +#define HAL_HRTIM_ExternalEventCounterConfig HAL_HRTIM_ExtEventCounterConfig +#define HAL_HRTIM_ExternalEventCounterEnable HAL_HRTIM_ExtEventCounterEnable +#define HAL_HRTIM_ExternalEventCounterDisable HAL_HRTIM_ExtEventCounterDisable +#define HAL_HRTIM_ExternalEventCounterReset HAL_HRTIM_ExtEventCounterReset +#define HRTIM_TIMEEVENT_A HRTIM_EVENTCOUNTER_A +#define HRTIM_TIMEEVENT_B HRTIM_EVENTCOUNTER_B +#define HRTIM_TIMEEVENTRESETMODE_UNCONDITIONAL HRTIM_EVENTCOUNTER_RSTMODE_UNCONDITIONAL +#define HRTIM_TIMEEVENTRESETMODE_CONDITIONAL HRTIM_EVENTCOUNTER_RSTMODE_CONDITIONAL +#endif /* STM32G4 */ + +#if defined(STM32H7) +#define HRTIM_OUTPUTSET_TIMAEV1_TIMBCMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTSET_TIMAEV2_TIMBCMP2 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTSET_TIMAEV3_TIMCCMP2 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTSET_TIMAEV4_TIMCCMP3 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTSET_TIMAEV5_TIMDCMP1 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTSET_TIMAEV6_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTSET_TIMAEV7_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTSET_TIMAEV8_TIMECMP4 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTSET_TIMAEV9_TIMFCMP4 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTSET_TIMBEV1_TIMACMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTSET_TIMBEV2_TIMACMP2 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTSET_TIMBEV3_TIMCCMP3 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTSET_TIMBEV4_TIMCCMP4 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTSET_TIMBEV5_TIMDCMP3 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTSET_TIMBEV6_TIMDCMP4 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTSET_TIMBEV7_TIMECMP1 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTSET_TIMBEV8_TIMECMP2 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTSET_TIMBEV9_TIMFCMP3 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTSET_TIMCEV1_TIMACMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTSET_TIMCEV2_TIMACMP2 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTSET_TIMCEV3_TIMBCMP2 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTSET_TIMCEV4_TIMBCMP3 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTSET_TIMCEV5_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTSET_TIMCEV6_TIMDCMP4 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTSET_TIMCEV7_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTSET_TIMCEV8_TIMECMP4 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTSET_TIMCEV9_TIMFCMP2 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTSET_TIMDEV1_TIMACMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTSET_TIMDEV2_TIMACMP4 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTSET_TIMDEV3_TIMBCMP2 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTSET_TIMDEV4_TIMBCMP4 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTSET_TIMDEV5_TIMCCMP4 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTSET_TIMDEV6_TIMECMP1 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTSET_TIMDEV7_TIMECMP4 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTSET_TIMDEV8_TIMFCMP1 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTSET_TIMDEV9_TIMFCMP3 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTSET_TIMEEV1_TIMACMP4 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTSET_TIMEEV2_TIMBCMP3 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTSET_TIMEEV3_TIMBCMP4 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTSET_TIMEEV4_TIMCCMP1 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTSET_TIMEEV5_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTSET_TIMEEV6_TIMDCMP1 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTSET_TIMEEV7_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTSET_TIMEEV8_TIMFCMP3 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTSET_TIMEEV9_TIMFCMP4 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTSET_TIMFEV1_TIMACMP3 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTSET_TIMFEV2_TIMBCMP1 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTSET_TIMFEV3_TIMBCMP4 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTSET_TIMFEV4_TIMCCMP1 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTSET_TIMFEV5_TIMCCMP4 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTSET_TIMFEV6_TIMDCMP3 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTSET_TIMFEV7_TIMDCMP4 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTSET_TIMFEV8_TIMECMP2 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTSET_TIMFEV9_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_9 + +#define HRTIM_OUTPUTRESET_TIMAEV1_TIMBCMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTRESET_TIMAEV2_TIMBCMP2 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTRESET_TIMAEV3_TIMCCMP2 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTRESET_TIMAEV4_TIMCCMP3 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTRESET_TIMAEV5_TIMDCMP1 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTRESET_TIMAEV6_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTRESET_TIMAEV7_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTRESET_TIMAEV8_TIMECMP4 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTRESET_TIMAEV9_TIMFCMP4 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTRESET_TIMBEV1_TIMACMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTRESET_TIMBEV2_TIMACMP2 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTRESET_TIMBEV3_TIMCCMP3 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTRESET_TIMBEV4_TIMCCMP4 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTRESET_TIMBEV5_TIMDCMP3 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTRESET_TIMBEV6_TIMDCMP4 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTRESET_TIMBEV7_TIMECMP1 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTRESET_TIMBEV8_TIMECMP2 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTRESET_TIMBEV9_TIMFCMP3 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTRESET_TIMCEV1_TIMACMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTRESET_TIMCEV2_TIMACMP2 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTRESET_TIMCEV3_TIMBCMP2 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTRESET_TIMCEV4_TIMBCMP3 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTRESET_TIMCEV5_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTRESET_TIMCEV6_TIMDCMP4 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTRESET_TIMCEV7_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTRESET_TIMCEV8_TIMECMP4 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTRESET_TIMCEV9_TIMFCMP2 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTRESET_TIMDEV1_TIMACMP1 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTRESET_TIMDEV2_TIMACMP4 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTRESET_TIMDEV3_TIMBCMP2 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTRESET_TIMDEV4_TIMBCMP4 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTRESET_TIMDEV5_TIMCCMP4 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTRESET_TIMDEV6_TIMECMP1 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTRESET_TIMDEV7_TIMECMP4 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTRESET_TIMDEV8_TIMFCMP1 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTRESET_TIMDEV9_TIMFCMP3 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTRESET_TIMEEV1_TIMACMP4 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTRESET_TIMEEV2_TIMBCMP3 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTRESET_TIMEEV3_TIMBCMP4 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTRESET_TIMEEV4_TIMCCMP1 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTRESET_TIMEEV5_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTRESET_TIMEEV6_TIMDCMP1 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTRESET_TIMEEV7_TIMDCMP2 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTRESET_TIMEEV8_TIMFCMP3 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTRESET_TIMEEV9_TIMFCMP4 HRTIM_OUTPUTSET_TIMEV_9 +#define HRTIM_OUTPUTRESET_TIMFEV1_TIMACMP3 HRTIM_OUTPUTSET_TIMEV_1 +#define HRTIM_OUTPUTRESET_TIMFEV2_TIMBCMP1 HRTIM_OUTPUTSET_TIMEV_2 +#define HRTIM_OUTPUTRESET_TIMFEV3_TIMBCMP4 HRTIM_OUTPUTSET_TIMEV_3 +#define HRTIM_OUTPUTRESET_TIMFEV4_TIMCCMP1 HRTIM_OUTPUTSET_TIMEV_4 +#define HRTIM_OUTPUTRESET_TIMFEV5_TIMCCMP4 HRTIM_OUTPUTSET_TIMEV_5 +#define HRTIM_OUTPUTRESET_TIMFEV6_TIMDCMP3 HRTIM_OUTPUTSET_TIMEV_6 +#define HRTIM_OUTPUTRESET_TIMFEV7_TIMDCMP4 HRTIM_OUTPUTSET_TIMEV_7 +#define HRTIM_OUTPUTRESET_TIMFEV8_TIMECMP2 HRTIM_OUTPUTSET_TIMEV_8 +#define HRTIM_OUTPUTRESET_TIMFEV9_TIMECMP3 HRTIM_OUTPUTSET_TIMEV_9 +#endif /* STM32H7 */ + +#if defined(STM32F3) +/** @brief Constants defining available sources associated to external events. + */ +#define HRTIM_EVENTSRC_1 (0x00000000U) +#define HRTIM_EVENTSRC_2 (HRTIM_EECR1_EE1SRC_0) +#define HRTIM_EVENTSRC_3 (HRTIM_EECR1_EE1SRC_1) +#define HRTIM_EVENTSRC_4 (HRTIM_EECR1_EE1SRC_1 | HRTIM_EECR1_EE1SRC_0) + +/** @brief Constants defining the DLL calibration periods (in micro seconds) + */ +#define HRTIM_CALIBRATIONRATE_7300 0x00000000U +#define HRTIM_CALIBRATIONRATE_910 (HRTIM_DLLCR_CALRTE_0) +#define HRTIM_CALIBRATIONRATE_114 (HRTIM_DLLCR_CALRTE_1) +#define HRTIM_CALIBRATIONRATE_14 (HRTIM_DLLCR_CALRTE_1 | HRTIM_DLLCR_CALRTE_0) + +#endif /* STM32F3 */ +/** + * @} + */ + +/** @defgroup HAL_I2C_Aliased_Defines HAL I2C Aliased Defines maintained for legacy purpose + * @{ + */ +#define I2C_DUALADDRESS_DISABLED I2C_DUALADDRESS_DISABLE +#define I2C_DUALADDRESS_ENABLED I2C_DUALADDRESS_ENABLE +#define I2C_GENERALCALL_DISABLED I2C_GENERALCALL_DISABLE +#define I2C_GENERALCALL_ENABLED I2C_GENERALCALL_ENABLE +#define I2C_NOSTRETCH_DISABLED I2C_NOSTRETCH_DISABLE +#define I2C_NOSTRETCH_ENABLED I2C_NOSTRETCH_ENABLE +#define I2C_ANALOGFILTER_ENABLED I2C_ANALOGFILTER_ENABLE +#define I2C_ANALOGFILTER_DISABLED I2C_ANALOGFILTER_DISABLE +#if defined(STM32F0) || defined(STM32F1) || defined(STM32F3) || defined(STM32G0) || defined(STM32L4) || defined(STM32L1) || defined(STM32F7) +#define HAL_I2C_STATE_MEM_BUSY_TX HAL_I2C_STATE_BUSY_TX +#define HAL_I2C_STATE_MEM_BUSY_RX HAL_I2C_STATE_BUSY_RX +#define HAL_I2C_STATE_MASTER_BUSY_TX HAL_I2C_STATE_BUSY_TX +#define HAL_I2C_STATE_MASTER_BUSY_RX HAL_I2C_STATE_BUSY_RX +#define HAL_I2C_STATE_SLAVE_BUSY_TX HAL_I2C_STATE_BUSY_TX +#define HAL_I2C_STATE_SLAVE_BUSY_RX HAL_I2C_STATE_BUSY_RX +#endif +/** + * @} + */ + +/** @defgroup HAL_IRDA_Aliased_Defines HAL IRDA Aliased Defines maintained for legacy purpose + * @{ + */ +#define IRDA_ONE_BIT_SAMPLE_DISABLED IRDA_ONE_BIT_SAMPLE_DISABLE +#define IRDA_ONE_BIT_SAMPLE_ENABLED IRDA_ONE_BIT_SAMPLE_ENABLE + +/** + * @} + */ + +/** @defgroup HAL_IWDG_Aliased_Defines HAL IWDG Aliased Defines maintained for legacy purpose + * @{ + */ +#define KR_KEY_RELOAD IWDG_KEY_RELOAD +#define KR_KEY_ENABLE IWDG_KEY_ENABLE +#define KR_KEY_EWA IWDG_KEY_WRITE_ACCESS_ENABLE +#define KR_KEY_DWA IWDG_KEY_WRITE_ACCESS_DISABLE +/** + * @} + */ + +/** @defgroup HAL_LPTIM_Aliased_Defines HAL LPTIM Aliased Defines maintained for legacy purpose + * @{ + */ + +#define LPTIM_CLOCKSAMPLETIME_DIRECTTRANSISTION LPTIM_CLOCKSAMPLETIME_DIRECTTRANSITION +#define LPTIM_CLOCKSAMPLETIME_2TRANSISTIONS LPTIM_CLOCKSAMPLETIME_2TRANSITIONS +#define LPTIM_CLOCKSAMPLETIME_4TRANSISTIONS LPTIM_CLOCKSAMPLETIME_4TRANSITIONS +#define LPTIM_CLOCKSAMPLETIME_8TRANSISTIONS LPTIM_CLOCKSAMPLETIME_8TRANSITIONS + +#define LPTIM_CLOCKPOLARITY_RISINGEDGE LPTIM_CLOCKPOLARITY_RISING +#define LPTIM_CLOCKPOLARITY_FALLINGEDGE LPTIM_CLOCKPOLARITY_FALLING +#define LPTIM_CLOCKPOLARITY_BOTHEDGES LPTIM_CLOCKPOLARITY_RISING_FALLING + +#define LPTIM_TRIGSAMPLETIME_DIRECTTRANSISTION LPTIM_TRIGSAMPLETIME_DIRECTTRANSITION +#define LPTIM_TRIGSAMPLETIME_2TRANSISTIONS LPTIM_TRIGSAMPLETIME_2TRANSITIONS +#define LPTIM_TRIGSAMPLETIME_4TRANSISTIONS LPTIM_TRIGSAMPLETIME_4TRANSITIONS +#define LPTIM_TRIGSAMPLETIME_8TRANSISTIONS LPTIM_TRIGSAMPLETIME_8TRANSITIONS + +/* The following 3 definition have also been present in a temporary version of lptim.h */ +/* They need to be renamed also to the right name, just in case */ +#define LPTIM_TRIGSAMPLETIME_2TRANSITION LPTIM_TRIGSAMPLETIME_2TRANSITIONS +#define LPTIM_TRIGSAMPLETIME_4TRANSITION LPTIM_TRIGSAMPLETIME_4TRANSITIONS +#define LPTIM_TRIGSAMPLETIME_8TRANSITION LPTIM_TRIGSAMPLETIME_8TRANSITIONS + +#if defined(STM32U5) +#define LPTIM_ISR_CC1 LPTIM_ISR_CC1IF +#define LPTIM_ISR_CC2 LPTIM_ISR_CC2IF +#endif /* STM32U5 */ +/** + * @} + */ + +/** @defgroup HAL_NAND_Aliased_Defines HAL NAND Aliased Defines maintained for legacy purpose + * @{ + */ +#define HAL_NAND_Read_Page HAL_NAND_Read_Page_8b +#define HAL_NAND_Write_Page HAL_NAND_Write_Page_8b +#define HAL_NAND_Read_SpareArea HAL_NAND_Read_SpareArea_8b +#define HAL_NAND_Write_SpareArea HAL_NAND_Write_SpareArea_8b + +#define NAND_AddressTypedef NAND_AddressTypeDef + +#define __ARRAY_ADDRESS ARRAY_ADDRESS +#define __ADDR_1st_CYCLE ADDR_1ST_CYCLE +#define __ADDR_2nd_CYCLE ADDR_2ND_CYCLE +#define __ADDR_3rd_CYCLE ADDR_3RD_CYCLE +#define __ADDR_4th_CYCLE ADDR_4TH_CYCLE +/** + * @} + */ + +/** @defgroup HAL_NOR_Aliased_Defines HAL NOR Aliased Defines maintained for legacy purpose + * @{ + */ +#define NOR_StatusTypedef HAL_NOR_StatusTypeDef +#define NOR_SUCCESS HAL_NOR_STATUS_SUCCESS +#define NOR_ONGOING HAL_NOR_STATUS_ONGOING +#define NOR_ERROR HAL_NOR_STATUS_ERROR +#define NOR_TIMEOUT HAL_NOR_STATUS_TIMEOUT + +#define __NOR_WRITE NOR_WRITE +#define __NOR_ADDR_SHIFT NOR_ADDR_SHIFT +/** + * @} + */ + +/** @defgroup HAL_OPAMP_Aliased_Defines HAL OPAMP Aliased Defines maintained for legacy purpose + * @{ + */ + +#define OPAMP_NONINVERTINGINPUT_VP0 OPAMP_NONINVERTINGINPUT_IO0 +#define OPAMP_NONINVERTINGINPUT_VP1 OPAMP_NONINVERTINGINPUT_IO1 +#define OPAMP_NONINVERTINGINPUT_VP2 OPAMP_NONINVERTINGINPUT_IO2 +#define OPAMP_NONINVERTINGINPUT_VP3 OPAMP_NONINVERTINGINPUT_IO3 + +#define OPAMP_SEC_NONINVERTINGINPUT_VP0 OPAMP_SEC_NONINVERTINGINPUT_IO0 +#define OPAMP_SEC_NONINVERTINGINPUT_VP1 OPAMP_SEC_NONINVERTINGINPUT_IO1 +#define OPAMP_SEC_NONINVERTINGINPUT_VP2 OPAMP_SEC_NONINVERTINGINPUT_IO2 +#define OPAMP_SEC_NONINVERTINGINPUT_VP3 OPAMP_SEC_NONINVERTINGINPUT_IO3 + +#define OPAMP_INVERTINGINPUT_VM0 OPAMP_INVERTINGINPUT_IO0 +#define OPAMP_INVERTINGINPUT_VM1 OPAMP_INVERTINGINPUT_IO1 + +#define IOPAMP_INVERTINGINPUT_VM0 OPAMP_INVERTINGINPUT_IO0 +#define IOPAMP_INVERTINGINPUT_VM1 OPAMP_INVERTINGINPUT_IO1 + +#define OPAMP_SEC_INVERTINGINPUT_VM0 OPAMP_SEC_INVERTINGINPUT_IO0 +#define OPAMP_SEC_INVERTINGINPUT_VM1 OPAMP_SEC_INVERTINGINPUT_IO1 + +#define OPAMP_INVERTINGINPUT_VINM OPAMP_SEC_INVERTINGINPUT_IO1 + +#define OPAMP_PGACONNECT_NO OPAMP_PGA_CONNECT_INVERTINGINPUT_NO +#define OPAMP_PGACONNECT_VM0 OPAMP_PGA_CONNECT_INVERTINGINPUT_IO0 +#define OPAMP_PGACONNECT_VM1 OPAMP_PGA_CONNECT_INVERTINGINPUT_IO1 + +#if defined(STM32L1) || defined(STM32L4) || defined(STM32L5) || defined(STM32H7) || defined(STM32G4) +#define HAL_OPAMP_MSP_INIT_CB_ID HAL_OPAMP_MSPINIT_CB_ID +#define HAL_OPAMP_MSP_DEINIT_CB_ID HAL_OPAMP_MSPDEINIT_CB_ID +#endif + +#if defined(STM32L4) || defined(STM32L5) +#define OPAMP_POWERMODE_NORMAL OPAMP_POWERMODE_NORMALPOWER +#elif defined(STM32G4) +#define OPAMP_POWERMODE_NORMAL OPAMP_POWERMODE_NORMALSPEED +#endif + +/** + * @} + */ + +/** @defgroup HAL_I2S_Aliased_Defines HAL I2S Aliased Defines maintained for legacy purpose + * @{ + */ +#define I2S_STANDARD_PHILLIPS I2S_STANDARD_PHILIPS + +#if defined(STM32H7) +#define I2S_IT_TXE I2S_IT_TXP +#define I2S_IT_RXNE I2S_IT_RXP + +#define I2S_FLAG_TXE I2S_FLAG_TXP +#define I2S_FLAG_RXNE I2S_FLAG_RXP +#endif + +#if defined(STM32F7) +#define I2S_CLOCK_SYSCLK I2S_CLOCK_PLL +#endif +/** + * @} + */ + +/** @defgroup HAL_PCCARD_Aliased_Defines HAL PCCARD Aliased Defines maintained for legacy purpose + * @{ + */ + +/* Compact Flash-ATA registers description */ +#define CF_DATA ATA_DATA +#define CF_SECTOR_COUNT ATA_SECTOR_COUNT +#define CF_SECTOR_NUMBER ATA_SECTOR_NUMBER +#define CF_CYLINDER_LOW ATA_CYLINDER_LOW +#define CF_CYLINDER_HIGH ATA_CYLINDER_HIGH +#define CF_CARD_HEAD ATA_CARD_HEAD +#define CF_STATUS_CMD ATA_STATUS_CMD +#define CF_STATUS_CMD_ALTERNATE ATA_STATUS_CMD_ALTERNATE +#define CF_COMMON_DATA_AREA ATA_COMMON_DATA_AREA + +/* Compact Flash-ATA commands */ +#define CF_READ_SECTOR_CMD ATA_READ_SECTOR_CMD +#define CF_WRITE_SECTOR_CMD ATA_WRITE_SECTOR_CMD +#define CF_ERASE_SECTOR_CMD ATA_ERASE_SECTOR_CMD +#define CF_IDENTIFY_CMD ATA_IDENTIFY_CMD + +#define PCCARD_StatusTypedef HAL_PCCARD_StatusTypeDef +#define PCCARD_SUCCESS HAL_PCCARD_STATUS_SUCCESS +#define PCCARD_ONGOING HAL_PCCARD_STATUS_ONGOING +#define PCCARD_ERROR HAL_PCCARD_STATUS_ERROR +#define PCCARD_TIMEOUT HAL_PCCARD_STATUS_TIMEOUT +/** + * @} + */ + +/** @defgroup HAL_RTC_Aliased_Defines HAL RTC Aliased Defines maintained for legacy purpose + * @{ + */ + +#define FORMAT_BIN RTC_FORMAT_BIN +#define FORMAT_BCD RTC_FORMAT_BCD + +#define RTC_ALARMSUBSECONDMASK_None RTC_ALARMSUBSECONDMASK_NONE +#define RTC_TAMPERERASEBACKUP_DISABLED RTC_TAMPER_ERASE_BACKUP_DISABLE +#define RTC_TAMPERMASK_FLAG_DISABLED RTC_TAMPERMASK_FLAG_DISABLE +#define RTC_TAMPERMASK_FLAG_ENABLED RTC_TAMPERMASK_FLAG_ENABLE + +#define RTC_MASKTAMPERFLAG_DISABLED RTC_TAMPERMASK_FLAG_DISABLE +#define RTC_MASKTAMPERFLAG_ENABLED RTC_TAMPERMASK_FLAG_ENABLE +#define RTC_TAMPERERASEBACKUP_ENABLED RTC_TAMPER_ERASE_BACKUP_ENABLE +#define RTC_TAMPER1_2_INTERRUPT RTC_ALL_TAMPER_INTERRUPT +#define RTC_TAMPER1_2_3_INTERRUPT RTC_ALL_TAMPER_INTERRUPT + +#define RTC_TIMESTAMPPIN_PC13 RTC_TIMESTAMPPIN_DEFAULT +#define RTC_TIMESTAMPPIN_PA0 RTC_TIMESTAMPPIN_POS1 +#define RTC_TIMESTAMPPIN_PI8 RTC_TIMESTAMPPIN_POS1 +#define RTC_TIMESTAMPPIN_PC1 RTC_TIMESTAMPPIN_POS2 + +#define RTC_OUTPUT_REMAP_PC13 RTC_OUTPUT_REMAP_NONE +#define RTC_OUTPUT_REMAP_PB14 RTC_OUTPUT_REMAP_POS1 +#define RTC_OUTPUT_REMAP_PB2 RTC_OUTPUT_REMAP_POS1 + +#define RTC_TAMPERPIN_PC13 RTC_TAMPERPIN_DEFAULT +#define RTC_TAMPERPIN_PA0 RTC_TAMPERPIN_POS1 +#define RTC_TAMPERPIN_PI8 RTC_TAMPERPIN_POS1 + +#if defined(STM32H7) +#define RTC_TAMPCR_TAMPXE RTC_TAMPER_X +#define RTC_TAMPCR_TAMPXIE RTC_TAMPER_X_INTERRUPT + +#define RTC_TAMPER1_INTERRUPT RTC_IT_TAMP1 +#define RTC_TAMPER2_INTERRUPT RTC_IT_TAMP2 +#define RTC_TAMPER3_INTERRUPT RTC_IT_TAMP3 +#define RTC_ALL_TAMPER_INTERRUPT RTC_IT_TAMPALL +#endif /* STM32H7 */ + +/** + * @} + */ + + +/** @defgroup HAL_SMARTCARD_Aliased_Defines HAL SMARTCARD Aliased Defines maintained for legacy purpose + * @{ + */ +#define SMARTCARD_NACK_ENABLED SMARTCARD_NACK_ENABLE +#define SMARTCARD_NACK_DISABLED SMARTCARD_NACK_DISABLE + +#define SMARTCARD_ONEBIT_SAMPLING_DISABLED SMARTCARD_ONE_BIT_SAMPLE_DISABLE +#define SMARTCARD_ONEBIT_SAMPLING_ENABLED SMARTCARD_ONE_BIT_SAMPLE_ENABLE +#define SMARTCARD_ONEBIT_SAMPLING_DISABLE SMARTCARD_ONE_BIT_SAMPLE_DISABLE +#define SMARTCARD_ONEBIT_SAMPLING_ENABLE SMARTCARD_ONE_BIT_SAMPLE_ENABLE + +#define SMARTCARD_TIMEOUT_DISABLED SMARTCARD_TIMEOUT_DISABLE +#define SMARTCARD_TIMEOUT_ENABLED SMARTCARD_TIMEOUT_ENABLE + +#define SMARTCARD_LASTBIT_DISABLED SMARTCARD_LASTBIT_DISABLE +#define SMARTCARD_LASTBIT_ENABLED SMARTCARD_LASTBIT_ENABLE +/** + * @} + */ + + +/** @defgroup HAL_SMBUS_Aliased_Defines HAL SMBUS Aliased Defines maintained for legacy purpose + * @{ + */ +#define SMBUS_DUALADDRESS_DISABLED SMBUS_DUALADDRESS_DISABLE +#define SMBUS_DUALADDRESS_ENABLED SMBUS_DUALADDRESS_ENABLE +#define SMBUS_GENERALCALL_DISABLED SMBUS_GENERALCALL_DISABLE +#define SMBUS_GENERALCALL_ENABLED SMBUS_GENERALCALL_ENABLE +#define SMBUS_NOSTRETCH_DISABLED SMBUS_NOSTRETCH_DISABLE +#define SMBUS_NOSTRETCH_ENABLED SMBUS_NOSTRETCH_ENABLE +#define SMBUS_ANALOGFILTER_ENABLED SMBUS_ANALOGFILTER_ENABLE +#define SMBUS_ANALOGFILTER_DISABLED SMBUS_ANALOGFILTER_DISABLE +#define SMBUS_PEC_DISABLED SMBUS_PEC_DISABLE +#define SMBUS_PEC_ENABLED SMBUS_PEC_ENABLE +#define HAL_SMBUS_STATE_SLAVE_LISTEN HAL_SMBUS_STATE_LISTEN +/** + * @} + */ + +/** @defgroup HAL_SPI_Aliased_Defines HAL SPI Aliased Defines maintained for legacy purpose + * @{ + */ +#define SPI_TIMODE_DISABLED SPI_TIMODE_DISABLE +#define SPI_TIMODE_ENABLED SPI_TIMODE_ENABLE + +#define SPI_CRCCALCULATION_DISABLED SPI_CRCCALCULATION_DISABLE +#define SPI_CRCCALCULATION_ENABLED SPI_CRCCALCULATION_ENABLE + +#define SPI_NSS_PULSE_DISABLED SPI_NSS_PULSE_DISABLE +#define SPI_NSS_PULSE_ENABLED SPI_NSS_PULSE_ENABLE + +#if defined(STM32H7) + +#define SPI_FLAG_TXE SPI_FLAG_TXP +#define SPI_FLAG_RXNE SPI_FLAG_RXP + +#define SPI_IT_TXE SPI_IT_TXP +#define SPI_IT_RXNE SPI_IT_RXP + +#define SPI_FRLVL_EMPTY SPI_RX_FIFO_0PACKET +#define SPI_FRLVL_QUARTER_FULL SPI_RX_FIFO_1PACKET +#define SPI_FRLVL_HALF_FULL SPI_RX_FIFO_2PACKET +#define SPI_FRLVL_FULL SPI_RX_FIFO_3PACKET + +#endif /* STM32H7 */ + +/** + * @} + */ + +/** @defgroup HAL_TIM_Aliased_Defines HAL TIM Aliased Defines maintained for legacy purpose + * @{ + */ +#define CCER_CCxE_MASK TIM_CCER_CCxE_MASK +#define CCER_CCxNE_MASK TIM_CCER_CCxNE_MASK + +#define TIM_DMABase_CR1 TIM_DMABASE_CR1 +#define TIM_DMABase_CR2 TIM_DMABASE_CR2 +#define TIM_DMABase_SMCR TIM_DMABASE_SMCR +#define TIM_DMABase_DIER TIM_DMABASE_DIER +#define TIM_DMABase_SR TIM_DMABASE_SR +#define TIM_DMABase_EGR TIM_DMABASE_EGR +#define TIM_DMABase_CCMR1 TIM_DMABASE_CCMR1 +#define TIM_DMABase_CCMR2 TIM_DMABASE_CCMR2 +#define TIM_DMABase_CCER TIM_DMABASE_CCER +#define TIM_DMABase_CNT TIM_DMABASE_CNT +#define TIM_DMABase_PSC TIM_DMABASE_PSC +#define TIM_DMABase_ARR TIM_DMABASE_ARR +#define TIM_DMABase_RCR TIM_DMABASE_RCR +#define TIM_DMABase_CCR1 TIM_DMABASE_CCR1 +#define TIM_DMABase_CCR2 TIM_DMABASE_CCR2 +#define TIM_DMABase_CCR3 TIM_DMABASE_CCR3 +#define TIM_DMABase_CCR4 TIM_DMABASE_CCR4 +#define TIM_DMABase_BDTR TIM_DMABASE_BDTR +#define TIM_DMABase_DCR TIM_DMABASE_DCR +#define TIM_DMABase_DMAR TIM_DMABASE_DMAR +#define TIM_DMABase_OR1 TIM_DMABASE_OR1 +#define TIM_DMABase_CCMR3 TIM_DMABASE_CCMR3 +#define TIM_DMABase_CCR5 TIM_DMABASE_CCR5 +#define TIM_DMABase_CCR6 TIM_DMABASE_CCR6 +#define TIM_DMABase_OR2 TIM_DMABASE_OR2 +#define TIM_DMABase_OR3 TIM_DMABASE_OR3 +#define TIM_DMABase_OR TIM_DMABASE_OR + +#define TIM_EventSource_Update TIM_EVENTSOURCE_UPDATE +#define TIM_EventSource_CC1 TIM_EVENTSOURCE_CC1 +#define TIM_EventSource_CC2 TIM_EVENTSOURCE_CC2 +#define TIM_EventSource_CC3 TIM_EVENTSOURCE_CC3 +#define TIM_EventSource_CC4 TIM_EVENTSOURCE_CC4 +#define TIM_EventSource_COM TIM_EVENTSOURCE_COM +#define TIM_EventSource_Trigger TIM_EVENTSOURCE_TRIGGER +#define TIM_EventSource_Break TIM_EVENTSOURCE_BREAK +#define TIM_EventSource_Break2 TIM_EVENTSOURCE_BREAK2 + +#define TIM_DMABurstLength_1Transfer TIM_DMABURSTLENGTH_1TRANSFER +#define TIM_DMABurstLength_2Transfers TIM_DMABURSTLENGTH_2TRANSFERS +#define TIM_DMABurstLength_3Transfers TIM_DMABURSTLENGTH_3TRANSFERS +#define TIM_DMABurstLength_4Transfers TIM_DMABURSTLENGTH_4TRANSFERS +#define TIM_DMABurstLength_5Transfers TIM_DMABURSTLENGTH_5TRANSFERS +#define TIM_DMABurstLength_6Transfers TIM_DMABURSTLENGTH_6TRANSFERS +#define TIM_DMABurstLength_7Transfers TIM_DMABURSTLENGTH_7TRANSFERS +#define TIM_DMABurstLength_8Transfers TIM_DMABURSTLENGTH_8TRANSFERS +#define TIM_DMABurstLength_9Transfers TIM_DMABURSTLENGTH_9TRANSFERS +#define TIM_DMABurstLength_10Transfers TIM_DMABURSTLENGTH_10TRANSFERS +#define TIM_DMABurstLength_11Transfers TIM_DMABURSTLENGTH_11TRANSFERS +#define TIM_DMABurstLength_12Transfers TIM_DMABURSTLENGTH_12TRANSFERS +#define TIM_DMABurstLength_13Transfers TIM_DMABURSTLENGTH_13TRANSFERS +#define TIM_DMABurstLength_14Transfers TIM_DMABURSTLENGTH_14TRANSFERS +#define TIM_DMABurstLength_15Transfers TIM_DMABURSTLENGTH_15TRANSFERS +#define TIM_DMABurstLength_16Transfers TIM_DMABURSTLENGTH_16TRANSFERS +#define TIM_DMABurstLength_17Transfers TIM_DMABURSTLENGTH_17TRANSFERS +#define TIM_DMABurstLength_18Transfers TIM_DMABURSTLENGTH_18TRANSFERS + +#if defined(STM32L0) +#define TIM22_TI1_GPIO1 TIM22_TI1_GPIO +#define TIM22_TI1_GPIO2 TIM22_TI1_GPIO +#endif + +#if defined(STM32F3) +#define IS_TIM_HALL_INTERFACE_INSTANCE IS_TIM_HALL_SENSOR_INTERFACE_INSTANCE +#endif + +#if defined(STM32H7) +#define TIM_TIM1_ETR_COMP1_OUT TIM_TIM1_ETR_COMP1 +#define TIM_TIM1_ETR_COMP2_OUT TIM_TIM1_ETR_COMP2 +#define TIM_TIM8_ETR_COMP1_OUT TIM_TIM8_ETR_COMP1 +#define TIM_TIM8_ETR_COMP2_OUT TIM_TIM8_ETR_COMP2 +#define TIM_TIM2_ETR_COMP1_OUT TIM_TIM2_ETR_COMP1 +#define TIM_TIM2_ETR_COMP2_OUT TIM_TIM2_ETR_COMP2 +#define TIM_TIM3_ETR_COMP1_OUT TIM_TIM3_ETR_COMP1 +#define TIM_TIM1_TI1_COMP1_OUT TIM_TIM1_TI1_COMP1 +#define TIM_TIM8_TI1_COMP2_OUT TIM_TIM8_TI1_COMP2 +#define TIM_TIM2_TI4_COMP1_OUT TIM_TIM2_TI4_COMP1 +#define TIM_TIM2_TI4_COMP2_OUT TIM_TIM2_TI4_COMP2 +#define TIM_TIM2_TI4_COMP1COMP2_OUT TIM_TIM2_TI4_COMP1_COMP2 +#define TIM_TIM3_TI1_COMP1_OUT TIM_TIM3_TI1_COMP1 +#define TIM_TIM3_TI1_COMP2_OUT TIM_TIM3_TI1_COMP2 +#define TIM_TIM3_TI1_COMP1COMP2_OUT TIM_TIM3_TI1_COMP1_COMP2 +#endif + +/** + * @} + */ + +/** @defgroup HAL_TSC_Aliased_Defines HAL TSC Aliased Defines maintained for legacy purpose + * @{ + */ +#define TSC_SYNC_POL_FALL TSC_SYNC_POLARITY_FALLING +#define TSC_SYNC_POL_RISE_HIGH TSC_SYNC_POLARITY_RISING +/** + * @} + */ + +/** @defgroup HAL_UART_Aliased_Defines HAL UART Aliased Defines maintained for legacy purpose + * @{ + */ +#define UART_ONEBIT_SAMPLING_DISABLED UART_ONE_BIT_SAMPLE_DISABLE +#define UART_ONEBIT_SAMPLING_ENABLED UART_ONE_BIT_SAMPLE_ENABLE +#define UART_ONE_BIT_SAMPLE_DISABLED UART_ONE_BIT_SAMPLE_DISABLE +#define UART_ONE_BIT_SAMPLE_ENABLED UART_ONE_BIT_SAMPLE_ENABLE + +#define __HAL_UART_ONEBIT_ENABLE __HAL_UART_ONE_BIT_SAMPLE_ENABLE +#define __HAL_UART_ONEBIT_DISABLE __HAL_UART_ONE_BIT_SAMPLE_DISABLE + +#define __DIV_SAMPLING16 UART_DIV_SAMPLING16 +#define __DIVMANT_SAMPLING16 UART_DIVMANT_SAMPLING16 +#define __DIVFRAQ_SAMPLING16 UART_DIVFRAQ_SAMPLING16 +#define __UART_BRR_SAMPLING16 UART_BRR_SAMPLING16 + +#define __DIV_SAMPLING8 UART_DIV_SAMPLING8 +#define __DIVMANT_SAMPLING8 UART_DIVMANT_SAMPLING8 +#define __DIVFRAQ_SAMPLING8 UART_DIVFRAQ_SAMPLING8 +#define __UART_BRR_SAMPLING8 UART_BRR_SAMPLING8 + +#define __DIV_LPUART UART_DIV_LPUART + +#define UART_WAKEUPMETHODE_IDLELINE UART_WAKEUPMETHOD_IDLELINE +#define UART_WAKEUPMETHODE_ADDRESSMARK UART_WAKEUPMETHOD_ADDRESSMARK + +/** + * @} + */ + + +/** @defgroup HAL_USART_Aliased_Defines HAL USART Aliased Defines maintained for legacy purpose + * @{ + */ + +#define USART_CLOCK_DISABLED USART_CLOCK_DISABLE +#define USART_CLOCK_ENABLED USART_CLOCK_ENABLE + +#define USARTNACK_ENABLED USART_NACK_ENABLE +#define USARTNACK_DISABLED USART_NACK_DISABLE +/** + * @} + */ + +/** @defgroup HAL_WWDG_Aliased_Defines HAL WWDG Aliased Defines maintained for legacy purpose + * @{ + */ +#define CFR_BASE WWDG_CFR_BASE + +/** + * @} + */ + +/** @defgroup HAL_CAN_Aliased_Defines HAL CAN Aliased Defines maintained for legacy purpose + * @{ + */ +#define CAN_FilterFIFO0 CAN_FILTER_FIFO0 +#define CAN_FilterFIFO1 CAN_FILTER_FIFO1 +#define CAN_IT_RQCP0 CAN_IT_TME +#define CAN_IT_RQCP1 CAN_IT_TME +#define CAN_IT_RQCP2 CAN_IT_TME +#define INAK_TIMEOUT CAN_TIMEOUT_VALUE +#define SLAK_TIMEOUT CAN_TIMEOUT_VALUE +#define CAN_TXSTATUS_FAILED ((uint8_t)0x00U) +#define CAN_TXSTATUS_OK ((uint8_t)0x01U) +#define CAN_TXSTATUS_PENDING ((uint8_t)0x02U) + +/** + * @} + */ + +/** @defgroup HAL_ETH_Aliased_Defines HAL ETH Aliased Defines maintained for legacy purpose + * @{ + */ + +#define VLAN_TAG ETH_VLAN_TAG +#define MIN_ETH_PAYLOAD ETH_MIN_ETH_PAYLOAD +#define MAX_ETH_PAYLOAD ETH_MAX_ETH_PAYLOAD +#define JUMBO_FRAME_PAYLOAD ETH_JUMBO_FRAME_PAYLOAD +#define MACMIIAR_CR_MASK ETH_MACMIIAR_CR_MASK +#define MACCR_CLEAR_MASK ETH_MACCR_CLEAR_MASK +#define MACFCR_CLEAR_MASK ETH_MACFCR_CLEAR_MASK +#define DMAOMR_CLEAR_MASK ETH_DMAOMR_CLEAR_MASK + +#define ETH_MMCCR 0x00000100U +#define ETH_MMCRIR 0x00000104U +#define ETH_MMCTIR 0x00000108U +#define ETH_MMCRIMR 0x0000010CU +#define ETH_MMCTIMR 0x00000110U +#define ETH_MMCTGFSCCR 0x0000014CU +#define ETH_MMCTGFMSCCR 0x00000150U +#define ETH_MMCTGFCR 0x00000168U +#define ETH_MMCRFCECR 0x00000194U +#define ETH_MMCRFAECR 0x00000198U +#define ETH_MMCRGUFCR 0x000001C4U + +#define ETH_MAC_TXFIFO_FULL 0x02000000U /* Tx FIFO full */ +#define ETH_MAC_TXFIFONOT_EMPTY 0x01000000U /* Tx FIFO not empty */ +#define ETH_MAC_TXFIFO_WRITE_ACTIVE 0x00400000U /* Tx FIFO write active */ +#define ETH_MAC_TXFIFO_IDLE 0x00000000U /* Tx FIFO read status: Idle */ +#define ETH_MAC_TXFIFO_READ 0x00100000U /* Tx FIFO read status: Read (transferring data to the MAC transmitter) */ +#define ETH_MAC_TXFIFO_WAITING 0x00200000U /* Tx FIFO read status: Waiting for TxStatus from MAC transmitter */ +#define ETH_MAC_TXFIFO_WRITING 0x00300000U /* Tx FIFO read status: Writing the received TxStatus or flushing the TxFIFO */ +#define ETH_MAC_TRANSMISSION_PAUSE 0x00080000U /* MAC transmitter in pause */ +#define ETH_MAC_TRANSMITFRAMECONTROLLER_IDLE 0x00000000U /* MAC transmit frame controller: Idle */ +#define ETH_MAC_TRANSMITFRAMECONTROLLER_WAITING 0x00020000U /* MAC transmit frame controller: Waiting for Status of previous frame or IFG/backoff period to be over */ +#define ETH_MAC_TRANSMITFRAMECONTROLLER_GENRATING_PCF 0x00040000U /* MAC transmit frame controller: Generating and transmitting a Pause control frame (in full duplex mode) */ +#define ETH_MAC_TRANSMITFRAMECONTROLLER_TRANSFERRING 0x00060000U /* MAC transmit frame controller: Transferring input frame for transmission */ +#define ETH_MAC_MII_TRANSMIT_ACTIVE 0x00010000U /* MAC MII transmit engine active */ +#define ETH_MAC_RXFIFO_EMPTY 0x00000000U /* Rx FIFO fill level: empty */ +#define ETH_MAC_RXFIFO_BELOW_THRESHOLD 0x00000100U /* Rx FIFO fill level: fill-level below flow-control de-activate threshold */ +#define ETH_MAC_RXFIFO_ABOVE_THRESHOLD 0x00000200U /* Rx FIFO fill level: fill-level above flow-control activate threshold */ +#define ETH_MAC_RXFIFO_FULL 0x00000300U /* Rx FIFO fill level: full */ +#if defined(STM32F1) +#else +#define ETH_MAC_READCONTROLLER_IDLE 0x00000000U /* Rx FIFO read controller IDLE state */ +#define ETH_MAC_READCONTROLLER_READING_DATA 0x00000020U /* Rx FIFO read controller Reading frame data */ +#define ETH_MAC_READCONTROLLER_READING_STATUS 0x00000040U /* Rx FIFO read controller Reading frame status (or time-stamp) */ +#endif +#define ETH_MAC_READCONTROLLER_FLUSHING 0x00000060U /* Rx FIFO read controller Flushing the frame data and status */ +#define ETH_MAC_RXFIFO_WRITE_ACTIVE 0x00000010U /* Rx FIFO write controller active */ +#define ETH_MAC_SMALL_FIFO_NOTACTIVE 0x00000000U /* MAC small FIFO read / write controllers not active */ +#define ETH_MAC_SMALL_FIFO_READ_ACTIVE 0x00000002U /* MAC small FIFO read controller active */ +#define ETH_MAC_SMALL_FIFO_WRITE_ACTIVE 0x00000004U /* MAC small FIFO write controller active */ +#define ETH_MAC_SMALL_FIFO_RW_ACTIVE 0x00000006U /* MAC small FIFO read / write controllers active */ +#define ETH_MAC_MII_RECEIVE_PROTOCOL_ACTIVE 0x00000001U /* MAC MII receive protocol engine active */ + +/** + * @} + */ + +/** @defgroup HAL_DCMI_Aliased_Defines HAL DCMI Aliased Defines maintained for legacy purpose + * @{ + */ +#define HAL_DCMI_ERROR_OVF HAL_DCMI_ERROR_OVR +#define DCMI_IT_OVF DCMI_IT_OVR +#define DCMI_FLAG_OVFRI DCMI_FLAG_OVRRI +#define DCMI_FLAG_OVFMI DCMI_FLAG_OVRMI + +#define HAL_DCMI_ConfigCROP HAL_DCMI_ConfigCrop +#define HAL_DCMI_EnableCROP HAL_DCMI_EnableCrop +#define HAL_DCMI_DisableCROP HAL_DCMI_DisableCrop + +/** + * @} + */ + +#if defined(STM32L4) || defined(STM32F7) || defined(STM32F427xx) || defined(STM32F437xx) \ + || defined(STM32F429xx) || defined(STM32F439xx) || defined(STM32F469xx) || defined(STM32F479xx) \ + || defined(STM32H7) +/** @defgroup HAL_DMA2D_Aliased_Defines HAL DMA2D Aliased Defines maintained for legacy purpose + * @{ + */ +#define DMA2D_ARGB8888 DMA2D_OUTPUT_ARGB8888 +#define DMA2D_RGB888 DMA2D_OUTPUT_RGB888 +#define DMA2D_RGB565 DMA2D_OUTPUT_RGB565 +#define DMA2D_ARGB1555 DMA2D_OUTPUT_ARGB1555 +#define DMA2D_ARGB4444 DMA2D_OUTPUT_ARGB4444 + +#define CM_ARGB8888 DMA2D_INPUT_ARGB8888 +#define CM_RGB888 DMA2D_INPUT_RGB888 +#define CM_RGB565 DMA2D_INPUT_RGB565 +#define CM_ARGB1555 DMA2D_INPUT_ARGB1555 +#define CM_ARGB4444 DMA2D_INPUT_ARGB4444 +#define CM_L8 DMA2D_INPUT_L8 +#define CM_AL44 DMA2D_INPUT_AL44 +#define CM_AL88 DMA2D_INPUT_AL88 +#define CM_L4 DMA2D_INPUT_L4 +#define CM_A8 DMA2D_INPUT_A8 +#define CM_A4 DMA2D_INPUT_A4 +/** + * @} + */ +#endif /* STM32L4 || STM32F7 || STM32F4 || STM32H7 */ + +#if defined(STM32L4) || defined(STM32F7) || defined(STM32F427xx) || defined(STM32F437xx) \ + || defined(STM32F429xx) || defined(STM32F439xx) || defined(STM32F469xx) || defined(STM32F479xx) \ + || defined(STM32H7) || defined(STM32U5) +/** @defgroup DMA2D_Aliases DMA2D API Aliases + * @{ + */ +#define HAL_DMA2D_DisableCLUT HAL_DMA2D_CLUTLoading_Abort /*!< Aliased to HAL_DMA2D_CLUTLoading_Abort + for compatibility with legacy code */ +/** + * @} + */ + +#endif /* STM32L4 || STM32F7 || STM32F4 || STM32H7 || STM32U5 */ + +/** @defgroup HAL_PPP_Aliased_Defines HAL PPP Aliased Defines maintained for legacy purpose + * @{ + */ + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @defgroup HAL_CRYP_Aliased_Functions HAL CRYP Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_CRYP_ComputationCpltCallback HAL_CRYPEx_ComputationCpltCallback +/** + * @} + */ + +/** @defgroup HAL_DCACHE_Aliased_Functions HAL DCACHE Aliased Functions maintained for legacy purpose + * @{ + */ + +#if defined(STM32U5) +#define HAL_DCACHE_CleanInvalidateByAddr HAL_DCACHE_CleanInvalidByAddr +#define HAL_DCACHE_CleanInvalidateByAddr_IT HAL_DCACHE_CleanInvalidByAddr_IT +#endif /* STM32U5 */ + +/** + * @} + */ + +#if !defined(STM32F2) +/** @defgroup HASH_alias HASH API alias + * @{ + */ +#define HAL_HASHEx_IRQHandler HAL_HASH_IRQHandler /*!< Redirection for compatibility with legacy code */ +/** + * + * @} + */ +#endif /* STM32F2 */ +/** @defgroup HAL_HASH_Aliased_Functions HAL HASH Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_HASH_STATETypeDef HAL_HASH_StateTypeDef +#define HAL_HASHPhaseTypeDef HAL_HASH_PhaseTypeDef +#define HAL_HMAC_MD5_Finish HAL_HASH_MD5_Finish +#define HAL_HMAC_SHA1_Finish HAL_HASH_SHA1_Finish +#define HAL_HMAC_SHA224_Finish HAL_HASH_SHA224_Finish +#define HAL_HMAC_SHA256_Finish HAL_HASH_SHA256_Finish + +/*HASH Algorithm Selection*/ + +#define HASH_AlgoSelection_SHA1 HASH_ALGOSELECTION_SHA1 +#define HASH_AlgoSelection_SHA224 HASH_ALGOSELECTION_SHA224 +#define HASH_AlgoSelection_SHA256 HASH_ALGOSELECTION_SHA256 +#define HASH_AlgoSelection_MD5 HASH_ALGOSELECTION_MD5 + +#define HASH_AlgoMode_HASH HASH_ALGOMODE_HASH +#define HASH_AlgoMode_HMAC HASH_ALGOMODE_HMAC + +#define HASH_HMACKeyType_ShortKey HASH_HMAC_KEYTYPE_SHORTKEY +#define HASH_HMACKeyType_LongKey HASH_HMAC_KEYTYPE_LONGKEY + +#if defined(STM32L4) || defined(STM32L5) || defined(STM32F2) || defined(STM32F4) || defined(STM32F7) || defined(STM32H7) + +#define HAL_HASH_MD5_Accumulate HAL_HASH_MD5_Accmlt +#define HAL_HASH_MD5_Accumulate_End HAL_HASH_MD5_Accmlt_End +#define HAL_HASH_MD5_Accumulate_IT HAL_HASH_MD5_Accmlt_IT +#define HAL_HASH_MD5_Accumulate_End_IT HAL_HASH_MD5_Accmlt_End_IT + +#define HAL_HASH_SHA1_Accumulate HAL_HASH_SHA1_Accmlt +#define HAL_HASH_SHA1_Accumulate_End HAL_HASH_SHA1_Accmlt_End +#define HAL_HASH_SHA1_Accumulate_IT HAL_HASH_SHA1_Accmlt_IT +#define HAL_HASH_SHA1_Accumulate_End_IT HAL_HASH_SHA1_Accmlt_End_IT + +#define HAL_HASHEx_SHA224_Accumulate HAL_HASHEx_SHA224_Accmlt +#define HAL_HASHEx_SHA224_Accumulate_End HAL_HASHEx_SHA224_Accmlt_End +#define HAL_HASHEx_SHA224_Accumulate_IT HAL_HASHEx_SHA224_Accmlt_IT +#define HAL_HASHEx_SHA224_Accumulate_End_IT HAL_HASHEx_SHA224_Accmlt_End_IT + +#define HAL_HASHEx_SHA256_Accumulate HAL_HASHEx_SHA256_Accmlt +#define HAL_HASHEx_SHA256_Accumulate_End HAL_HASHEx_SHA256_Accmlt_End +#define HAL_HASHEx_SHA256_Accumulate_IT HAL_HASHEx_SHA256_Accmlt_IT +#define HAL_HASHEx_SHA256_Accumulate_End_IT HAL_HASHEx_SHA256_Accmlt_End_IT + +#endif /* STM32L4 || STM32L5 || STM32F2 || STM32F4 || STM32F7 || STM32H7 */ +/** + * @} + */ + +/** @defgroup HAL_Aliased_Functions HAL Generic Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_EnableDBGSleepMode HAL_DBGMCU_EnableDBGSleepMode +#define HAL_DisableDBGSleepMode HAL_DBGMCU_DisableDBGSleepMode +#define HAL_EnableDBGStopMode HAL_DBGMCU_EnableDBGStopMode +#define HAL_DisableDBGStopMode HAL_DBGMCU_DisableDBGStopMode +#define HAL_EnableDBGStandbyMode HAL_DBGMCU_EnableDBGStandbyMode +#define HAL_DisableDBGStandbyMode HAL_DBGMCU_DisableDBGStandbyMode +#define HAL_DBG_LowPowerConfig(Periph, cmd) (((cmd\ + )==ENABLE)? HAL_DBGMCU_DBG_EnableLowPowerConfig(Periph) : HAL_DBGMCU_DBG_DisableLowPowerConfig(Periph)) +#define HAL_VREFINT_OutputSelect HAL_SYSCFG_VREFINT_OutputSelect +#define HAL_Lock_Cmd(cmd) (((cmd)==ENABLE) ? HAL_SYSCFG_Enable_Lock_VREFINT() : HAL_SYSCFG_Disable_Lock_VREFINT()) +#if defined(STM32L0) +#else +#define HAL_VREFINT_Cmd(cmd) (((cmd)==ENABLE)? HAL_SYSCFG_EnableVREFINT() : HAL_SYSCFG_DisableVREFINT()) +#endif +#define HAL_ADC_EnableBuffer_Cmd(cmd) (((cmd)==ENABLE) ? HAL_ADCEx_EnableVREFINT() : HAL_ADCEx_DisableVREFINT()) +#define HAL_ADC_EnableBufferSensor_Cmd(cmd) (((cmd\ + )==ENABLE) ? HAL_ADCEx_EnableVREFINTTempSensor() : HAL_ADCEx_DisableVREFINTTempSensor()) +#if defined(STM32H7A3xx) || defined(STM32H7B3xx) || defined(STM32H7B0xx) || defined(STM32H7A3xxQ) || defined(STM32H7B3xxQ) || defined(STM32H7B0xxQ) +#define HAL_EnableSRDomainDBGStopMode HAL_EnableDomain3DBGStopMode +#define HAL_DisableSRDomainDBGStopMode HAL_DisableDomain3DBGStopMode +#define HAL_EnableSRDomainDBGStandbyMode HAL_EnableDomain3DBGStandbyMode +#define HAL_DisableSRDomainDBGStandbyMode HAL_DisableDomain3DBGStandbyMode +#endif /* STM32H7A3xx || STM32H7B3xx || STM32H7B0xx || STM32H7A3xxQ || STM32H7B3xxQ || STM32H7B0xxQ */ + +/** + * @} + */ + +/** @defgroup HAL_FLASH_Aliased_Functions HAL FLASH Aliased Functions maintained for legacy purpose + * @{ + */ +#define FLASH_HalfPageProgram HAL_FLASHEx_HalfPageProgram +#define FLASH_EnableRunPowerDown HAL_FLASHEx_EnableRunPowerDown +#define FLASH_DisableRunPowerDown HAL_FLASHEx_DisableRunPowerDown +#define HAL_DATA_EEPROMEx_Unlock HAL_FLASHEx_DATAEEPROM_Unlock +#define HAL_DATA_EEPROMEx_Lock HAL_FLASHEx_DATAEEPROM_Lock +#define HAL_DATA_EEPROMEx_Erase HAL_FLASHEx_DATAEEPROM_Erase +#define HAL_DATA_EEPROMEx_Program HAL_FLASHEx_DATAEEPROM_Program + +/** + * @} + */ + +/** @defgroup HAL_I2C_Aliased_Functions HAL I2C Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_I2CEx_AnalogFilter_Config HAL_I2CEx_ConfigAnalogFilter +#define HAL_I2CEx_DigitalFilter_Config HAL_I2CEx_ConfigDigitalFilter +#define HAL_FMPI2CEx_AnalogFilter_Config HAL_FMPI2CEx_ConfigAnalogFilter +#define HAL_FMPI2CEx_DigitalFilter_Config HAL_FMPI2CEx_ConfigDigitalFilter + +#define HAL_I2CFastModePlusConfig(SYSCFG_I2CFastModePlus, cmd) (((cmd\ + )==ENABLE)? HAL_I2CEx_EnableFastModePlus(SYSCFG_I2CFastModePlus): HAL_I2CEx_DisableFastModePlus(SYSCFG_I2CFastModePlus)) + +#if defined(STM32H7) || defined(STM32WB) || defined(STM32G0) || defined(STM32F0) || defined(STM32F1) || defined(STM32F2) || defined(STM32F3) || defined(STM32F4) || defined(STM32F7) || defined(STM32L0) || defined(STM32L4) || defined(STM32L5) || defined(STM32G4) || defined(STM32L1) +#define HAL_I2C_Master_Sequential_Transmit_IT HAL_I2C_Master_Seq_Transmit_IT +#define HAL_I2C_Master_Sequential_Receive_IT HAL_I2C_Master_Seq_Receive_IT +#define HAL_I2C_Slave_Sequential_Transmit_IT HAL_I2C_Slave_Seq_Transmit_IT +#define HAL_I2C_Slave_Sequential_Receive_IT HAL_I2C_Slave_Seq_Receive_IT +#endif /* STM32H7 || STM32WB || STM32G0 || STM32F0 || STM32F1 || STM32F2 || STM32F3 || STM32F4 || STM32F7 || STM32L0 || STM32L4 || STM32L5 || STM32G4 || STM32L1 */ +#if defined(STM32H7) || defined(STM32WB) || defined(STM32G0) || defined(STM32F4) || defined(STM32F7) || defined(STM32L0) || defined(STM32L4) || defined(STM32L5) || defined(STM32G4)|| defined(STM32L1) +#define HAL_I2C_Master_Sequential_Transmit_DMA HAL_I2C_Master_Seq_Transmit_DMA +#define HAL_I2C_Master_Sequential_Receive_DMA HAL_I2C_Master_Seq_Receive_DMA +#define HAL_I2C_Slave_Sequential_Transmit_DMA HAL_I2C_Slave_Seq_Transmit_DMA +#define HAL_I2C_Slave_Sequential_Receive_DMA HAL_I2C_Slave_Seq_Receive_DMA +#endif /* STM32H7 || STM32WB || STM32G0 || STM32F4 || STM32F7 || STM32L0 || STM32L4 || STM32L5 || STM32G4 || STM32L1 */ + +#if defined(STM32F4) +#define HAL_FMPI2C_Master_Sequential_Transmit_IT HAL_FMPI2C_Master_Seq_Transmit_IT +#define HAL_FMPI2C_Master_Sequential_Receive_IT HAL_FMPI2C_Master_Seq_Receive_IT +#define HAL_FMPI2C_Slave_Sequential_Transmit_IT HAL_FMPI2C_Slave_Seq_Transmit_IT +#define HAL_FMPI2C_Slave_Sequential_Receive_IT HAL_FMPI2C_Slave_Seq_Receive_IT +#define HAL_FMPI2C_Master_Sequential_Transmit_DMA HAL_FMPI2C_Master_Seq_Transmit_DMA +#define HAL_FMPI2C_Master_Sequential_Receive_DMA HAL_FMPI2C_Master_Seq_Receive_DMA +#define HAL_FMPI2C_Slave_Sequential_Transmit_DMA HAL_FMPI2C_Slave_Seq_Transmit_DMA +#define HAL_FMPI2C_Slave_Sequential_Receive_DMA HAL_FMPI2C_Slave_Seq_Receive_DMA +#endif /* STM32F4 */ +/** + * @} + */ + +/** @defgroup HAL_PWR_Aliased HAL PWR Aliased maintained for legacy purpose + * @{ + */ + +#if defined(STM32G0) +#define HAL_PWR_ConfigPVD HAL_PWREx_ConfigPVD +#define HAL_PWR_EnablePVD HAL_PWREx_EnablePVD +#define HAL_PWR_DisablePVD HAL_PWREx_DisablePVD +#define HAL_PWR_PVD_IRQHandler HAL_PWREx_PVD_IRQHandler +#endif +#define HAL_PWR_PVDConfig HAL_PWR_ConfigPVD +#define HAL_PWR_DisableBkUpReg HAL_PWREx_DisableBkUpReg +#define HAL_PWR_DisableFlashPowerDown HAL_PWREx_DisableFlashPowerDown +#define HAL_PWR_DisableVddio2Monitor HAL_PWREx_DisableVddio2Monitor +#define HAL_PWR_EnableBkUpReg HAL_PWREx_EnableBkUpReg +#define HAL_PWR_EnableFlashPowerDown HAL_PWREx_EnableFlashPowerDown +#define HAL_PWR_EnableVddio2Monitor HAL_PWREx_EnableVddio2Monitor +#define HAL_PWR_PVD_PVM_IRQHandler HAL_PWREx_PVD_PVM_IRQHandler +#define HAL_PWR_PVDLevelConfig HAL_PWR_ConfigPVD +#define HAL_PWR_Vddio2Monitor_IRQHandler HAL_PWREx_Vddio2Monitor_IRQHandler +#define HAL_PWR_Vddio2MonitorCallback HAL_PWREx_Vddio2MonitorCallback +#define HAL_PWREx_ActivateOverDrive HAL_PWREx_EnableOverDrive +#define HAL_PWREx_DeactivateOverDrive HAL_PWREx_DisableOverDrive +#define HAL_PWREx_DisableSDADCAnalog HAL_PWREx_DisableSDADC +#define HAL_PWREx_EnableSDADCAnalog HAL_PWREx_EnableSDADC +#define HAL_PWREx_PVMConfig HAL_PWREx_ConfigPVM + +#define PWR_MODE_NORMAL PWR_PVD_MODE_NORMAL +#define PWR_MODE_IT_RISING PWR_PVD_MODE_IT_RISING +#define PWR_MODE_IT_FALLING PWR_PVD_MODE_IT_FALLING +#define PWR_MODE_IT_RISING_FALLING PWR_PVD_MODE_IT_RISING_FALLING +#define PWR_MODE_EVENT_RISING PWR_PVD_MODE_EVENT_RISING +#define PWR_MODE_EVENT_FALLING PWR_PVD_MODE_EVENT_FALLING +#define PWR_MODE_EVENT_RISING_FALLING PWR_PVD_MODE_EVENT_RISING_FALLING + +#define CR_OFFSET_BB PWR_CR_OFFSET_BB +#define CSR_OFFSET_BB PWR_CSR_OFFSET_BB +#define PMODE_BIT_NUMBER VOS_BIT_NUMBER +#define CR_PMODE_BB CR_VOS_BB + +#define DBP_BitNumber DBP_BIT_NUMBER +#define PVDE_BitNumber PVDE_BIT_NUMBER +#define PMODE_BitNumber PMODE_BIT_NUMBER +#define EWUP_BitNumber EWUP_BIT_NUMBER +#define FPDS_BitNumber FPDS_BIT_NUMBER +#define ODEN_BitNumber ODEN_BIT_NUMBER +#define ODSWEN_BitNumber ODSWEN_BIT_NUMBER +#define MRLVDS_BitNumber MRLVDS_BIT_NUMBER +#define LPLVDS_BitNumber LPLVDS_BIT_NUMBER +#define BRE_BitNumber BRE_BIT_NUMBER + +#define PWR_MODE_EVT PWR_PVD_MODE_NORMAL + +/** + * @} + */ + +/** @defgroup HAL_SMBUS_Aliased_Functions HAL SMBUS Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_SMBUS_Slave_Listen_IT HAL_SMBUS_EnableListen_IT +#define HAL_SMBUS_SlaveAddrCallback HAL_SMBUS_AddrCallback +#define HAL_SMBUS_SlaveListenCpltCallback HAL_SMBUS_ListenCpltCallback +/** + * @} + */ + +/** @defgroup HAL_SPI_Aliased_Functions HAL SPI Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_SPI_FlushRxFifo HAL_SPIEx_FlushRxFifo +/** + * @} + */ + +/** @defgroup HAL_TIM_Aliased_Functions HAL TIM Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_TIM_DMADelayPulseCplt TIM_DMADelayPulseCplt +#define HAL_TIM_DMAError TIM_DMAError +#define HAL_TIM_DMACaptureCplt TIM_DMACaptureCplt +#define HAL_TIMEx_DMACommutationCplt TIMEx_DMACommutationCplt +#if defined(STM32H7) || defined(STM32G0) || defined(STM32F0) || defined(STM32F1) || defined(STM32F2) || defined(STM32F3) || defined(STM32F4) || defined(STM32F7) || defined(STM32L0) || defined(STM32L4) +#define HAL_TIM_SlaveConfigSynchronization HAL_TIM_SlaveConfigSynchro +#define HAL_TIM_SlaveConfigSynchronization_IT HAL_TIM_SlaveConfigSynchro_IT +#define HAL_TIMEx_CommutationCallback HAL_TIMEx_CommutCallback +#define HAL_TIMEx_ConfigCommutationEvent HAL_TIMEx_ConfigCommutEvent +#define HAL_TIMEx_ConfigCommutationEvent_IT HAL_TIMEx_ConfigCommutEvent_IT +#define HAL_TIMEx_ConfigCommutationEvent_DMA HAL_TIMEx_ConfigCommutEvent_DMA +#endif /* STM32H7 || STM32G0 || STM32F0 || STM32F1 || STM32F2 || STM32F3 || STM32F4 || STM32F7 || STM32L0 */ +/** + * @} + */ + +/** @defgroup HAL_UART_Aliased_Functions HAL UART Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_UART_WakeupCallback HAL_UARTEx_WakeupCallback +/** + * @} + */ + +/** @defgroup HAL_LTDC_Aliased_Functions HAL LTDC Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_LTDC_LineEvenCallback HAL_LTDC_LineEventCallback +#define HAL_LTDC_Relaod HAL_LTDC_Reload +#define HAL_LTDC_StructInitFromVideoConfig HAL_LTDCEx_StructInitFromVideoConfig +#define HAL_LTDC_StructInitFromAdaptedCommandConfig HAL_LTDCEx_StructInitFromAdaptedCommandConfig +/** + * @} + */ + + +/** @defgroup HAL_PPP_Aliased_Functions HAL PPP Aliased Functions maintained for legacy purpose + * @{ + */ + +/** + * @} + */ + +/* Exported macros ------------------------------------------------------------*/ + +/** @defgroup HAL_AES_Aliased_Macros HAL CRYP Aliased Macros maintained for legacy purpose + * @{ + */ +#define AES_IT_CC CRYP_IT_CC +#define AES_IT_ERR CRYP_IT_ERR +#define AES_FLAG_CCF CRYP_FLAG_CCF +/** + * @} + */ + +/** @defgroup HAL_Aliased_Macros HAL Generic Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_GET_BOOT_MODE __HAL_SYSCFG_GET_BOOT_MODE +#define __HAL_REMAPMEMORY_FLASH __HAL_SYSCFG_REMAPMEMORY_FLASH +#define __HAL_REMAPMEMORY_SYSTEMFLASH __HAL_SYSCFG_REMAPMEMORY_SYSTEMFLASH +#define __HAL_REMAPMEMORY_SRAM __HAL_SYSCFG_REMAPMEMORY_SRAM +#define __HAL_REMAPMEMORY_FMC __HAL_SYSCFG_REMAPMEMORY_FMC +#define __HAL_REMAPMEMORY_FMC_SDRAM __HAL_SYSCFG_REMAPMEMORY_FMC_SDRAM +#define __HAL_REMAPMEMORY_FSMC __HAL_SYSCFG_REMAPMEMORY_FSMC +#define __HAL_REMAPMEMORY_QUADSPI __HAL_SYSCFG_REMAPMEMORY_QUADSPI +#define __HAL_FMC_BANK __HAL_SYSCFG_FMC_BANK +#define __HAL_GET_FLAG __HAL_SYSCFG_GET_FLAG +#define __HAL_CLEAR_FLAG __HAL_SYSCFG_CLEAR_FLAG +#define __HAL_VREFINT_OUT_ENABLE __HAL_SYSCFG_VREFINT_OUT_ENABLE +#define __HAL_VREFINT_OUT_DISABLE __HAL_SYSCFG_VREFINT_OUT_DISABLE +#define __HAL_SYSCFG_SRAM2_WRP_ENABLE __HAL_SYSCFG_SRAM2_WRP_0_31_ENABLE + +#define SYSCFG_FLAG_VREF_READY SYSCFG_FLAG_VREFINT_READY +#define SYSCFG_FLAG_RC48 RCC_FLAG_HSI48 +#define IS_SYSCFG_FASTMODEPLUS_CONFIG IS_I2C_FASTMODEPLUS +#define UFB_MODE_BitNumber UFB_MODE_BIT_NUMBER +#define CMP_PD_BitNumber CMP_PD_BIT_NUMBER + +/** + * @} + */ + + +/** @defgroup HAL_ADC_Aliased_Macros HAL ADC Aliased Macros maintained for legacy purpose + * @{ + */ +#define __ADC_ENABLE __HAL_ADC_ENABLE +#define __ADC_DISABLE __HAL_ADC_DISABLE +#define __HAL_ADC_ENABLING_CONDITIONS ADC_ENABLING_CONDITIONS +#define __HAL_ADC_DISABLING_CONDITIONS ADC_DISABLING_CONDITIONS +#define __HAL_ADC_IS_ENABLED ADC_IS_ENABLE +#define __ADC_IS_ENABLED ADC_IS_ENABLE +#define __HAL_ADC_IS_SOFTWARE_START_REGULAR ADC_IS_SOFTWARE_START_REGULAR +#define __HAL_ADC_IS_SOFTWARE_START_INJECTED ADC_IS_SOFTWARE_START_INJECTED +#define __HAL_ADC_IS_CONVERSION_ONGOING_REGULAR_INJECTED ADC_IS_CONVERSION_ONGOING_REGULAR_INJECTED +#define __HAL_ADC_IS_CONVERSION_ONGOING_REGULAR ADC_IS_CONVERSION_ONGOING_REGULAR +#define __HAL_ADC_IS_CONVERSION_ONGOING_INJECTED ADC_IS_CONVERSION_ONGOING_INJECTED +#define __HAL_ADC_IS_CONVERSION_ONGOING ADC_IS_CONVERSION_ONGOING +#define __HAL_ADC_CLEAR_ERRORCODE ADC_CLEAR_ERRORCODE + +#define __HAL_ADC_GET_RESOLUTION ADC_GET_RESOLUTION +#define __HAL_ADC_JSQR_RK ADC_JSQR_RK +#define __HAL_ADC_CFGR_AWD1CH ADC_CFGR_AWD1CH_SHIFT +#define __HAL_ADC_CFGR_AWD23CR ADC_CFGR_AWD23CR +#define __HAL_ADC_CFGR_INJECT_AUTO_CONVERSION ADC_CFGR_INJECT_AUTO_CONVERSION +#define __HAL_ADC_CFGR_INJECT_CONTEXT_QUEUE ADC_CFGR_INJECT_CONTEXT_QUEUE +#define __HAL_ADC_CFGR_INJECT_DISCCONTINUOUS ADC_CFGR_INJECT_DISCCONTINUOUS +#define __HAL_ADC_CFGR_REG_DISCCONTINUOUS ADC_CFGR_REG_DISCCONTINUOUS +#define __HAL_ADC_CFGR_DISCONTINUOUS_NUM ADC_CFGR_DISCONTINUOUS_NUM +#define __HAL_ADC_CFGR_AUTOWAIT ADC_CFGR_AUTOWAIT +#define __HAL_ADC_CFGR_CONTINUOUS ADC_CFGR_CONTINUOUS +#define __HAL_ADC_CFGR_OVERRUN ADC_CFGR_OVERRUN +#define __HAL_ADC_CFGR_DMACONTREQ ADC_CFGR_DMACONTREQ +#define __HAL_ADC_CFGR_EXTSEL ADC_CFGR_EXTSEL_SET +#define __HAL_ADC_JSQR_JEXTSEL ADC_JSQR_JEXTSEL_SET +#define __HAL_ADC_OFR_CHANNEL ADC_OFR_CHANNEL +#define __HAL_ADC_DIFSEL_CHANNEL ADC_DIFSEL_CHANNEL +#define __HAL_ADC_CALFACT_DIFF_SET ADC_CALFACT_DIFF_SET +#define __HAL_ADC_CALFACT_DIFF_GET ADC_CALFACT_DIFF_GET +#define __HAL_ADC_TRX_HIGHTHRESHOLD ADC_TRX_HIGHTHRESHOLD + +#define __HAL_ADC_OFFSET_SHIFT_RESOLUTION ADC_OFFSET_SHIFT_RESOLUTION +#define __HAL_ADC_AWD1THRESHOLD_SHIFT_RESOLUTION ADC_AWD1THRESHOLD_SHIFT_RESOLUTION +#define __HAL_ADC_AWD23THRESHOLD_SHIFT_RESOLUTION ADC_AWD23THRESHOLD_SHIFT_RESOLUTION +#define __HAL_ADC_COMMON_REGISTER ADC_COMMON_REGISTER +#define __HAL_ADC_COMMON_CCR_MULTI ADC_COMMON_CCR_MULTI +#define __HAL_ADC_MULTIMODE_IS_ENABLED ADC_MULTIMODE_IS_ENABLE +#define __ADC_MULTIMODE_IS_ENABLED ADC_MULTIMODE_IS_ENABLE +#define __HAL_ADC_NONMULTIMODE_OR_MULTIMODEMASTER ADC_NONMULTIMODE_OR_MULTIMODEMASTER +#define __HAL_ADC_COMMON_ADC_OTHER ADC_COMMON_ADC_OTHER +#define __HAL_ADC_MULTI_SLAVE ADC_MULTI_SLAVE + +#define __HAL_ADC_SQR1_L ADC_SQR1_L_SHIFT +#define __HAL_ADC_JSQR_JL ADC_JSQR_JL_SHIFT +#define __HAL_ADC_JSQR_RK_JL ADC_JSQR_RK_JL +#define __HAL_ADC_CR1_DISCONTINUOUS_NUM ADC_CR1_DISCONTINUOUS_NUM +#define __HAL_ADC_CR1_SCAN ADC_CR1_SCAN_SET +#define __HAL_ADC_CONVCYCLES_MAX_RANGE ADC_CONVCYCLES_MAX_RANGE +#define __HAL_ADC_CLOCK_PRESCALER_RANGE ADC_CLOCK_PRESCALER_RANGE +#define __HAL_ADC_GET_CLOCK_PRESCALER ADC_GET_CLOCK_PRESCALER + +#define __HAL_ADC_SQR1 ADC_SQR1 +#define __HAL_ADC_SMPR1 ADC_SMPR1 +#define __HAL_ADC_SMPR2 ADC_SMPR2 +#define __HAL_ADC_SQR3_RK ADC_SQR3_RK +#define __HAL_ADC_SQR2_RK ADC_SQR2_RK +#define __HAL_ADC_SQR1_RK ADC_SQR1_RK +#define __HAL_ADC_CR2_CONTINUOUS ADC_CR2_CONTINUOUS +#define __HAL_ADC_CR1_DISCONTINUOUS ADC_CR1_DISCONTINUOUS +#define __HAL_ADC_CR1_SCANCONV ADC_CR1_SCANCONV +#define __HAL_ADC_CR2_EOCSelection ADC_CR2_EOCSelection +#define __HAL_ADC_CR2_DMAContReq ADC_CR2_DMAContReq +#define __HAL_ADC_JSQR ADC_JSQR + +#define __HAL_ADC_CHSELR_CHANNEL ADC_CHSELR_CHANNEL +#define __HAL_ADC_CFGR1_REG_DISCCONTINUOUS ADC_CFGR1_REG_DISCCONTINUOUS +#define __HAL_ADC_CFGR1_AUTOOFF ADC_CFGR1_AUTOOFF +#define __HAL_ADC_CFGR1_AUTOWAIT ADC_CFGR1_AUTOWAIT +#define __HAL_ADC_CFGR1_CONTINUOUS ADC_CFGR1_CONTINUOUS +#define __HAL_ADC_CFGR1_OVERRUN ADC_CFGR1_OVERRUN +#define __HAL_ADC_CFGR1_SCANDIR ADC_CFGR1_SCANDIR +#define __HAL_ADC_CFGR1_DMACONTREQ ADC_CFGR1_DMACONTREQ + +/** + * @} + */ + +/** @defgroup HAL_DAC_Aliased_Macros HAL DAC Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_DHR12R1_ALIGNEMENT DAC_DHR12R1_ALIGNMENT +#define __HAL_DHR12R2_ALIGNEMENT DAC_DHR12R2_ALIGNMENT +#define __HAL_DHR12RD_ALIGNEMENT DAC_DHR12RD_ALIGNMENT +#define IS_DAC_GENERATE_WAVE IS_DAC_WAVE + +/** + * @} + */ + +/** @defgroup HAL_DBGMCU_Aliased_Macros HAL DBGMCU Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_FREEZE_TIM1_DBGMCU __HAL_DBGMCU_FREEZE_TIM1 +#define __HAL_UNFREEZE_TIM1_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM1 +#define __HAL_FREEZE_TIM2_DBGMCU __HAL_DBGMCU_FREEZE_TIM2 +#define __HAL_UNFREEZE_TIM2_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM2 +#define __HAL_FREEZE_TIM3_DBGMCU __HAL_DBGMCU_FREEZE_TIM3 +#define __HAL_UNFREEZE_TIM3_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM3 +#define __HAL_FREEZE_TIM4_DBGMCU __HAL_DBGMCU_FREEZE_TIM4 +#define __HAL_UNFREEZE_TIM4_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM4 +#define __HAL_FREEZE_TIM5_DBGMCU __HAL_DBGMCU_FREEZE_TIM5 +#define __HAL_UNFREEZE_TIM5_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM5 +#define __HAL_FREEZE_TIM6_DBGMCU __HAL_DBGMCU_FREEZE_TIM6 +#define __HAL_UNFREEZE_TIM6_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM6 +#define __HAL_FREEZE_TIM7_DBGMCU __HAL_DBGMCU_FREEZE_TIM7 +#define __HAL_UNFREEZE_TIM7_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM7 +#define __HAL_FREEZE_TIM8_DBGMCU __HAL_DBGMCU_FREEZE_TIM8 +#define __HAL_UNFREEZE_TIM8_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM8 + +#define __HAL_FREEZE_TIM9_DBGMCU __HAL_DBGMCU_FREEZE_TIM9 +#define __HAL_UNFREEZE_TIM9_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM9 +#define __HAL_FREEZE_TIM10_DBGMCU __HAL_DBGMCU_FREEZE_TIM10 +#define __HAL_UNFREEZE_TIM10_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM10 +#define __HAL_FREEZE_TIM11_DBGMCU __HAL_DBGMCU_FREEZE_TIM11 +#define __HAL_UNFREEZE_TIM11_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM11 +#define __HAL_FREEZE_TIM12_DBGMCU __HAL_DBGMCU_FREEZE_TIM12 +#define __HAL_UNFREEZE_TIM12_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM12 +#define __HAL_FREEZE_TIM13_DBGMCU __HAL_DBGMCU_FREEZE_TIM13 +#define __HAL_UNFREEZE_TIM13_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM13 +#define __HAL_FREEZE_TIM14_DBGMCU __HAL_DBGMCU_FREEZE_TIM14 +#define __HAL_UNFREEZE_TIM14_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM14 +#define __HAL_FREEZE_CAN2_DBGMCU __HAL_DBGMCU_FREEZE_CAN2 +#define __HAL_UNFREEZE_CAN2_DBGMCU __HAL_DBGMCU_UNFREEZE_CAN2 + + +#define __HAL_FREEZE_TIM15_DBGMCU __HAL_DBGMCU_FREEZE_TIM15 +#define __HAL_UNFREEZE_TIM15_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM15 +#define __HAL_FREEZE_TIM16_DBGMCU __HAL_DBGMCU_FREEZE_TIM16 +#define __HAL_UNFREEZE_TIM16_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM16 +#define __HAL_FREEZE_TIM17_DBGMCU __HAL_DBGMCU_FREEZE_TIM17 +#define __HAL_UNFREEZE_TIM17_DBGMCU __HAL_DBGMCU_UNFREEZE_TIM17 +#define __HAL_FREEZE_RTC_DBGMCU __HAL_DBGMCU_FREEZE_RTC +#define __HAL_UNFREEZE_RTC_DBGMCU __HAL_DBGMCU_UNFREEZE_RTC +#if defined(STM32H7) +#define __HAL_FREEZE_WWDG_DBGMCU __HAL_DBGMCU_FREEZE_WWDG1 +#define __HAL_UNFREEZE_WWDG_DBGMCU __HAL_DBGMCU_UnFreeze_WWDG1 +#define __HAL_FREEZE_IWDG_DBGMCU __HAL_DBGMCU_FREEZE_IWDG1 +#define __HAL_UNFREEZE_IWDG_DBGMCU __HAL_DBGMCU_UnFreeze_IWDG1 +#else +#define __HAL_FREEZE_WWDG_DBGMCU __HAL_DBGMCU_FREEZE_WWDG +#define __HAL_UNFREEZE_WWDG_DBGMCU __HAL_DBGMCU_UNFREEZE_WWDG +#define __HAL_FREEZE_IWDG_DBGMCU __HAL_DBGMCU_FREEZE_IWDG +#define __HAL_UNFREEZE_IWDG_DBGMCU __HAL_DBGMCU_UNFREEZE_IWDG +#endif /* STM32H7 */ +#define __HAL_FREEZE_I2C1_TIMEOUT_DBGMCU __HAL_DBGMCU_FREEZE_I2C1_TIMEOUT +#define __HAL_UNFREEZE_I2C1_TIMEOUT_DBGMCU __HAL_DBGMCU_UNFREEZE_I2C1_TIMEOUT +#define __HAL_FREEZE_I2C2_TIMEOUT_DBGMCU __HAL_DBGMCU_FREEZE_I2C2_TIMEOUT +#define __HAL_UNFREEZE_I2C2_TIMEOUT_DBGMCU __HAL_DBGMCU_UNFREEZE_I2C2_TIMEOUT +#define __HAL_FREEZE_I2C3_TIMEOUT_DBGMCU __HAL_DBGMCU_FREEZE_I2C3_TIMEOUT +#define __HAL_UNFREEZE_I2C3_TIMEOUT_DBGMCU __HAL_DBGMCU_UNFREEZE_I2C3_TIMEOUT +#define __HAL_FREEZE_CAN1_DBGMCU __HAL_DBGMCU_FREEZE_CAN1 +#define __HAL_UNFREEZE_CAN1_DBGMCU __HAL_DBGMCU_UNFREEZE_CAN1 +#define __HAL_FREEZE_LPTIM1_DBGMCU __HAL_DBGMCU_FREEZE_LPTIM1 +#define __HAL_UNFREEZE_LPTIM1_DBGMCU __HAL_DBGMCU_UNFREEZE_LPTIM1 +#define __HAL_FREEZE_LPTIM2_DBGMCU __HAL_DBGMCU_FREEZE_LPTIM2 +#define __HAL_UNFREEZE_LPTIM2_DBGMCU __HAL_DBGMCU_UNFREEZE_LPTIM2 + +/** + * @} + */ + +/** @defgroup HAL_COMP_Aliased_Macros HAL COMP Aliased Macros maintained for legacy purpose + * @{ + */ +#if defined(STM32F3) +#define COMP_START __HAL_COMP_ENABLE +#define COMP_STOP __HAL_COMP_DISABLE +#define COMP_LOCK __HAL_COMP_LOCK + +#if defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx) || defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx) +#define __HAL_COMP_EXTI_RISING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_RISING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_ENABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_RISING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_RISING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_DISABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_ENABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_DISABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_ENABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_IT() : \ + __HAL_COMP_COMP6_EXTI_ENABLE_IT()) +#define __HAL_COMP_EXTI_DISABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_IT() : \ + __HAL_COMP_COMP6_EXTI_DISABLE_IT()) +#define __HAL_COMP_EXTI_GET_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_GET_FLAG() : \ + __HAL_COMP_COMP6_EXTI_GET_FLAG()) +#define __HAL_COMP_EXTI_CLEAR_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_CLEAR_FLAG() : \ + __HAL_COMP_COMP6_EXTI_CLEAR_FLAG()) +# endif +# if defined(STM32F302xE) || defined(STM32F302xC) +#define __HAL_COMP_EXTI_RISING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_RISING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_ENABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_RISING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_RISING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_DISABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_ENABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP6_EXTI_DISABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_ENABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_IT() : \ + __HAL_COMP_COMP6_EXTI_ENABLE_IT()) +#define __HAL_COMP_EXTI_DISABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_IT() : \ + __HAL_COMP_COMP6_EXTI_DISABLE_IT()) +#define __HAL_COMP_EXTI_GET_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_GET_FLAG() : \ + __HAL_COMP_COMP6_EXTI_GET_FLAG()) +#define __HAL_COMP_EXTI_CLEAR_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_CLEAR_FLAG() : \ + __HAL_COMP_COMP6_EXTI_CLEAR_FLAG()) +# endif +# if defined(STM32F303xE) || defined(STM32F398xx) || defined(STM32F303xC) || defined(STM32F358xx) +#define __HAL_COMP_EXTI_RISING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_ENABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_ENABLE_RISING_EDGE() : \ + __HAL_COMP_COMP7_EXTI_ENABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_RISING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_DISABLE_RISING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_DISABLE_RISING_EDGE() : \ + __HAL_COMP_COMP7_EXTI_DISABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_ENABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_ENABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP7_EXTI_ENABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_DISABLE_FALLING_EDGE() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_DISABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP7_EXTI_DISABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_ENABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_ENABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_ENABLE_IT() : \ + __HAL_COMP_COMP7_EXTI_ENABLE_IT()) +#define __HAL_COMP_EXTI_DISABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_DISABLE_IT() : \ + ((__EXTILINE__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_DISABLE_IT() : \ + __HAL_COMP_COMP7_EXTI_DISABLE_IT()) +#define __HAL_COMP_EXTI_GET_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_GET_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_GET_FLAG() : \ + __HAL_COMP_COMP7_EXTI_GET_FLAG()) +#define __HAL_COMP_EXTI_CLEAR_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP2) ? __HAL_COMP_COMP2_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP3) ? __HAL_COMP_COMP3_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP4) ? __HAL_COMP_COMP4_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP5) ? __HAL_COMP_COMP5_EXTI_CLEAR_FLAG() : \ + ((__FLAG__) == COMP_EXTI_LINE_COMP6) ? __HAL_COMP_COMP6_EXTI_CLEAR_FLAG() : \ + __HAL_COMP_COMP7_EXTI_CLEAR_FLAG()) +# endif +# if defined(STM32F373xC) ||defined(STM32F378xx) +#define __HAL_COMP_EXTI_RISING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_RISING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_ENABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_RISING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_RISING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_DISABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_ENABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_DISABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_ENABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_IT() : \ + __HAL_COMP_COMP2_EXTI_ENABLE_IT()) +#define __HAL_COMP_EXTI_DISABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_IT() : \ + __HAL_COMP_COMP2_EXTI_DISABLE_IT()) +#define __HAL_COMP_EXTI_GET_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_GET_FLAG() : \ + __HAL_COMP_COMP2_EXTI_GET_FLAG()) +#define __HAL_COMP_EXTI_CLEAR_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_CLEAR_FLAG() : \ + __HAL_COMP_COMP2_EXTI_CLEAR_FLAG()) +# endif +#else +#define __HAL_COMP_EXTI_RISING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_RISING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_ENABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_RISING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_RISING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_DISABLE_RISING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_ENABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_ENABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_FALLING_IT_DISABLE(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_FALLING_EDGE() : \ + __HAL_COMP_COMP2_EXTI_DISABLE_FALLING_EDGE()) +#define __HAL_COMP_EXTI_ENABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_ENABLE_IT() : \ + __HAL_COMP_COMP2_EXTI_ENABLE_IT()) +#define __HAL_COMP_EXTI_DISABLE_IT(__EXTILINE__) (((__EXTILINE__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_DISABLE_IT() : \ + __HAL_COMP_COMP2_EXTI_DISABLE_IT()) +#define __HAL_COMP_EXTI_GET_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_GET_FLAG() : \ + __HAL_COMP_COMP2_EXTI_GET_FLAG()) +#define __HAL_COMP_EXTI_CLEAR_FLAG(__FLAG__) (((__FLAG__) == COMP_EXTI_LINE_COMP1) ? __HAL_COMP_COMP1_EXTI_CLEAR_FLAG() : \ + __HAL_COMP_COMP2_EXTI_CLEAR_FLAG()) +#endif + +#define __HAL_COMP_GET_EXTI_LINE COMP_GET_EXTI_LINE + +#if defined(STM32L0) || defined(STM32L4) +/* Note: On these STM32 families, the only argument of this macro */ +/* is COMP_FLAG_LOCK. */ +/* This macro is replaced by __HAL_COMP_IS_LOCKED with only HAL handle */ +/* argument. */ +#define __HAL_COMP_GET_FLAG(__HANDLE__, __FLAG__) (__HAL_COMP_IS_LOCKED(__HANDLE__)) +#endif +/** + * @} + */ + +#if defined(STM32L0) || defined(STM32L4) +/** @defgroup HAL_COMP_Aliased_Functions HAL COMP Aliased Functions maintained for legacy purpose + * @{ + */ +#define HAL_COMP_Start_IT HAL_COMP_Start /* Function considered as legacy as EXTI event or IT configuration is done into HAL_COMP_Init() */ +#define HAL_COMP_Stop_IT HAL_COMP_Stop /* Function considered as legacy as EXTI event or IT configuration is done into HAL_COMP_Init() */ +/** + * @} + */ +#endif + +/** @defgroup HAL_DAC_Aliased_Macros HAL DAC Aliased Macros maintained for legacy purpose + * @{ + */ + +#define IS_DAC_WAVE(WAVE) (((WAVE) == DAC_WAVE_NONE) || \ + ((WAVE) == DAC_WAVE_NOISE)|| \ + ((WAVE) == DAC_WAVE_TRIANGLE)) + +/** + * @} + */ + +/** @defgroup HAL_FLASH_Aliased_Macros HAL FLASH Aliased Macros maintained for legacy purpose + * @{ + */ + +#define IS_WRPAREA IS_OB_WRPAREA +#define IS_TYPEPROGRAM IS_FLASH_TYPEPROGRAM +#define IS_TYPEPROGRAMFLASH IS_FLASH_TYPEPROGRAM +#define IS_TYPEERASE IS_FLASH_TYPEERASE +#define IS_NBSECTORS IS_FLASH_NBSECTORS +#define IS_OB_WDG_SOURCE IS_OB_IWDG_SOURCE + +/** + * @} + */ + +/** @defgroup HAL_I2C_Aliased_Macros HAL I2C Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __HAL_I2C_RESET_CR2 I2C_RESET_CR2 +#define __HAL_I2C_GENERATE_START I2C_GENERATE_START +#if defined(STM32F1) +#define __HAL_I2C_FREQ_RANGE I2C_FREQRANGE +#else +#define __HAL_I2C_FREQ_RANGE I2C_FREQ_RANGE +#endif /* STM32F1 */ +#define __HAL_I2C_RISE_TIME I2C_RISE_TIME +#define __HAL_I2C_SPEED_STANDARD I2C_SPEED_STANDARD +#define __HAL_I2C_SPEED_FAST I2C_SPEED_FAST +#define __HAL_I2C_SPEED I2C_SPEED +#define __HAL_I2C_7BIT_ADD_WRITE I2C_7BIT_ADD_WRITE +#define __HAL_I2C_7BIT_ADD_READ I2C_7BIT_ADD_READ +#define __HAL_I2C_10BIT_ADDRESS I2C_10BIT_ADDRESS +#define __HAL_I2C_10BIT_HEADER_WRITE I2C_10BIT_HEADER_WRITE +#define __HAL_I2C_10BIT_HEADER_READ I2C_10BIT_HEADER_READ +#define __HAL_I2C_MEM_ADD_MSB I2C_MEM_ADD_MSB +#define __HAL_I2C_MEM_ADD_LSB I2C_MEM_ADD_LSB +#define __HAL_I2C_FREQRANGE I2C_FREQRANGE +/** + * @} + */ + +/** @defgroup HAL_I2S_Aliased_Macros HAL I2S Aliased Macros maintained for legacy purpose + * @{ + */ + +#define IS_I2S_INSTANCE IS_I2S_ALL_INSTANCE +#define IS_I2S_INSTANCE_EXT IS_I2S_ALL_INSTANCE_EXT + +#if defined(STM32H7) +#define __HAL_I2S_CLEAR_FREFLAG __HAL_I2S_CLEAR_TIFREFLAG +#endif + +/** + * @} + */ + +/** @defgroup HAL_IRDA_Aliased_Macros HAL IRDA Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __IRDA_DISABLE __HAL_IRDA_DISABLE +#define __IRDA_ENABLE __HAL_IRDA_ENABLE + +#define __HAL_IRDA_GETCLOCKSOURCE IRDA_GETCLOCKSOURCE +#define __HAL_IRDA_MASK_COMPUTATION IRDA_MASK_COMPUTATION +#define __IRDA_GETCLOCKSOURCE IRDA_GETCLOCKSOURCE +#define __IRDA_MASK_COMPUTATION IRDA_MASK_COMPUTATION + +#define IS_IRDA_ONEBIT_SAMPLE IS_IRDA_ONE_BIT_SAMPLE + + +/** + * @} + */ + + +/** @defgroup HAL_IWDG_Aliased_Macros HAL IWDG Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_IWDG_ENABLE_WRITE_ACCESS IWDG_ENABLE_WRITE_ACCESS +#define __HAL_IWDG_DISABLE_WRITE_ACCESS IWDG_DISABLE_WRITE_ACCESS +/** + * @} + */ + + +/** @defgroup HAL_LPTIM_Aliased_Macros HAL LPTIM Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __HAL_LPTIM_ENABLE_INTERRUPT __HAL_LPTIM_ENABLE_IT +#define __HAL_LPTIM_DISABLE_INTERRUPT __HAL_LPTIM_DISABLE_IT +#define __HAL_LPTIM_GET_ITSTATUS __HAL_LPTIM_GET_IT_SOURCE + +/** + * @} + */ + + +/** @defgroup HAL_OPAMP_Aliased_Macros HAL OPAMP Aliased Macros maintained for legacy purpose + * @{ + */ +#define __OPAMP_CSR_OPAXPD OPAMP_CSR_OPAXPD +#define __OPAMP_CSR_S3SELX OPAMP_CSR_S3SELX +#define __OPAMP_CSR_S4SELX OPAMP_CSR_S4SELX +#define __OPAMP_CSR_S5SELX OPAMP_CSR_S5SELX +#define __OPAMP_CSR_S6SELX OPAMP_CSR_S6SELX +#define __OPAMP_CSR_OPAXCAL_L OPAMP_CSR_OPAXCAL_L +#define __OPAMP_CSR_OPAXCAL_H OPAMP_CSR_OPAXCAL_H +#define __OPAMP_CSR_OPAXLPM OPAMP_CSR_OPAXLPM +#define __OPAMP_CSR_ALL_SWITCHES OPAMP_CSR_ALL_SWITCHES +#define __OPAMP_CSR_ANAWSELX OPAMP_CSR_ANAWSELX +#define __OPAMP_CSR_OPAXCALOUT OPAMP_CSR_OPAXCALOUT +#define __OPAMP_OFFSET_TRIM_BITSPOSITION OPAMP_OFFSET_TRIM_BITSPOSITION +#define __OPAMP_OFFSET_TRIM_SET OPAMP_OFFSET_TRIM_SET + +/** + * @} + */ + + +/** @defgroup HAL_PWR_Aliased_Macros HAL PWR Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_PVD_EVENT_DISABLE __HAL_PWR_PVD_EXTI_DISABLE_EVENT +#define __HAL_PVD_EVENT_ENABLE __HAL_PWR_PVD_EXTI_ENABLE_EVENT +#define __HAL_PVD_EXTI_FALLINGTRIGGER_DISABLE __HAL_PWR_PVD_EXTI_DISABLE_FALLING_EDGE +#define __HAL_PVD_EXTI_FALLINGTRIGGER_ENABLE __HAL_PWR_PVD_EXTI_ENABLE_FALLING_EDGE +#define __HAL_PVD_EXTI_RISINGTRIGGER_DISABLE __HAL_PWR_PVD_EXTI_DISABLE_RISING_EDGE +#define __HAL_PVD_EXTI_RISINGTRIGGER_ENABLE __HAL_PWR_PVD_EXTI_ENABLE_RISING_EDGE +#define __HAL_PVM_EVENT_DISABLE __HAL_PWR_PVM_EVENT_DISABLE +#define __HAL_PVM_EVENT_ENABLE __HAL_PWR_PVM_EVENT_ENABLE +#define __HAL_PVM_EXTI_FALLINGTRIGGER_DISABLE __HAL_PWR_PVM_EXTI_FALLINGTRIGGER_DISABLE +#define __HAL_PVM_EXTI_FALLINGTRIGGER_ENABLE __HAL_PWR_PVM_EXTI_FALLINGTRIGGER_ENABLE +#define __HAL_PVM_EXTI_RISINGTRIGGER_DISABLE __HAL_PWR_PVM_EXTI_RISINGTRIGGER_DISABLE +#define __HAL_PVM_EXTI_RISINGTRIGGER_ENABLE __HAL_PWR_PVM_EXTI_RISINGTRIGGER_ENABLE +#define __HAL_PWR_INTERNALWAKEUP_DISABLE HAL_PWREx_DisableInternalWakeUpLine +#define __HAL_PWR_INTERNALWAKEUP_ENABLE HAL_PWREx_EnableInternalWakeUpLine +#define __HAL_PWR_PULL_UP_DOWN_CONFIG_DISABLE HAL_PWREx_DisablePullUpPullDownConfig +#define __HAL_PWR_PULL_UP_DOWN_CONFIG_ENABLE HAL_PWREx_EnablePullUpPullDownConfig +#define __HAL_PWR_PVD_EXTI_CLEAR_EGDE_TRIGGER() do { __HAL_PWR_PVD_EXTI_DISABLE_RISING_EDGE();__HAL_PWR_PVD_EXTI_DISABLE_FALLING_EDGE(); } while(0) +#define __HAL_PWR_PVD_EXTI_EVENT_DISABLE __HAL_PWR_PVD_EXTI_DISABLE_EVENT +#define __HAL_PWR_PVD_EXTI_EVENT_ENABLE __HAL_PWR_PVD_EXTI_ENABLE_EVENT +#define __HAL_PWR_PVD_EXTI_FALLINGTRIGGER_DISABLE __HAL_PWR_PVD_EXTI_DISABLE_FALLING_EDGE +#define __HAL_PWR_PVD_EXTI_FALLINGTRIGGER_ENABLE __HAL_PWR_PVD_EXTI_ENABLE_FALLING_EDGE +#define __HAL_PWR_PVD_EXTI_RISINGTRIGGER_DISABLE __HAL_PWR_PVD_EXTI_DISABLE_RISING_EDGE +#define __HAL_PWR_PVD_EXTI_RISINGTRIGGER_ENABLE __HAL_PWR_PVD_EXTI_ENABLE_RISING_EDGE +#define __HAL_PWR_PVD_EXTI_SET_FALLING_EGDE_TRIGGER __HAL_PWR_PVD_EXTI_ENABLE_FALLING_EDGE +#define __HAL_PWR_PVD_EXTI_SET_RISING_EDGE_TRIGGER __HAL_PWR_PVD_EXTI_ENABLE_RISING_EDGE +#define __HAL_PWR_PVM_DISABLE() do { HAL_PWREx_DisablePVM1();HAL_PWREx_DisablePVM2();HAL_PWREx_DisablePVM3();HAL_PWREx_DisablePVM4(); } while(0) +#define __HAL_PWR_PVM_ENABLE() do { HAL_PWREx_EnablePVM1();HAL_PWREx_EnablePVM2();HAL_PWREx_EnablePVM3();HAL_PWREx_EnablePVM4(); } while(0) +#define __HAL_PWR_SRAM2CONTENT_PRESERVE_DISABLE HAL_PWREx_DisableSRAM2ContentRetention +#define __HAL_PWR_SRAM2CONTENT_PRESERVE_ENABLE HAL_PWREx_EnableSRAM2ContentRetention +#define __HAL_PWR_VDDIO2_DISABLE HAL_PWREx_DisableVddIO2 +#define __HAL_PWR_VDDIO2_ENABLE HAL_PWREx_EnableVddIO2 +#define __HAL_PWR_VDDIO2_EXTI_CLEAR_EGDE_TRIGGER __HAL_PWR_VDDIO2_EXTI_DISABLE_FALLING_EDGE +#define __HAL_PWR_VDDIO2_EXTI_SET_FALLING_EGDE_TRIGGER __HAL_PWR_VDDIO2_EXTI_ENABLE_FALLING_EDGE +#define __HAL_PWR_VDDUSB_DISABLE HAL_PWREx_DisableVddUSB +#define __HAL_PWR_VDDUSB_ENABLE HAL_PWREx_EnableVddUSB + +#if defined (STM32F4) +#define __HAL_PVD_EXTI_ENABLE_IT(PWR_EXTI_LINE_PVD) __HAL_PWR_PVD_EXTI_ENABLE_IT() +#define __HAL_PVD_EXTI_DISABLE_IT(PWR_EXTI_LINE_PVD) __HAL_PWR_PVD_EXTI_DISABLE_IT() +#define __HAL_PVD_EXTI_GET_FLAG(PWR_EXTI_LINE_PVD) __HAL_PWR_PVD_EXTI_GET_FLAG() +#define __HAL_PVD_EXTI_CLEAR_FLAG(PWR_EXTI_LINE_PVD) __HAL_PWR_PVD_EXTI_CLEAR_FLAG() +#define __HAL_PVD_EXTI_GENERATE_SWIT(PWR_EXTI_LINE_PVD) __HAL_PWR_PVD_EXTI_GENERATE_SWIT() +#else +#define __HAL_PVD_EXTI_CLEAR_FLAG __HAL_PWR_PVD_EXTI_CLEAR_FLAG +#define __HAL_PVD_EXTI_DISABLE_IT __HAL_PWR_PVD_EXTI_DISABLE_IT +#define __HAL_PVD_EXTI_ENABLE_IT __HAL_PWR_PVD_EXTI_ENABLE_IT +#define __HAL_PVD_EXTI_GENERATE_SWIT __HAL_PWR_PVD_EXTI_GENERATE_SWIT +#define __HAL_PVD_EXTI_GET_FLAG __HAL_PWR_PVD_EXTI_GET_FLAG +#endif /* STM32F4 */ +/** + * @} + */ + + +/** @defgroup HAL_RCC_Aliased HAL RCC Aliased maintained for legacy purpose + * @{ + */ + +#define RCC_StopWakeUpClock_MSI RCC_STOP_WAKEUPCLOCK_MSI +#define RCC_StopWakeUpClock_HSI RCC_STOP_WAKEUPCLOCK_HSI + +#define HAL_RCC_CCSCallback HAL_RCC_CSSCallback +#define HAL_RC48_EnableBuffer_Cmd(cmd) (((cmd\ + )==ENABLE) ? HAL_RCCEx_EnableHSI48_VREFINT() : HAL_RCCEx_DisableHSI48_VREFINT()) + +#define __ADC_CLK_DISABLE __HAL_RCC_ADC_CLK_DISABLE +#define __ADC_CLK_ENABLE __HAL_RCC_ADC_CLK_ENABLE +#define __ADC_CLK_SLEEP_DISABLE __HAL_RCC_ADC_CLK_SLEEP_DISABLE +#define __ADC_CLK_SLEEP_ENABLE __HAL_RCC_ADC_CLK_SLEEP_ENABLE +#define __ADC_FORCE_RESET __HAL_RCC_ADC_FORCE_RESET +#define __ADC_RELEASE_RESET __HAL_RCC_ADC_RELEASE_RESET +#define __ADC1_CLK_DISABLE __HAL_RCC_ADC1_CLK_DISABLE +#define __ADC1_CLK_ENABLE __HAL_RCC_ADC1_CLK_ENABLE +#define __ADC1_FORCE_RESET __HAL_RCC_ADC1_FORCE_RESET +#define __ADC1_RELEASE_RESET __HAL_RCC_ADC1_RELEASE_RESET +#define __ADC1_CLK_SLEEP_ENABLE __HAL_RCC_ADC1_CLK_SLEEP_ENABLE +#define __ADC1_CLK_SLEEP_DISABLE __HAL_RCC_ADC1_CLK_SLEEP_DISABLE +#define __ADC2_CLK_DISABLE __HAL_RCC_ADC2_CLK_DISABLE +#define __ADC2_CLK_ENABLE __HAL_RCC_ADC2_CLK_ENABLE +#define __ADC2_FORCE_RESET __HAL_RCC_ADC2_FORCE_RESET +#define __ADC2_RELEASE_RESET __HAL_RCC_ADC2_RELEASE_RESET +#define __ADC3_CLK_DISABLE __HAL_RCC_ADC3_CLK_DISABLE +#define __ADC3_CLK_ENABLE __HAL_RCC_ADC3_CLK_ENABLE +#define __ADC3_FORCE_RESET __HAL_RCC_ADC3_FORCE_RESET +#define __ADC3_RELEASE_RESET __HAL_RCC_ADC3_RELEASE_RESET +#define __AES_CLK_DISABLE __HAL_RCC_AES_CLK_DISABLE +#define __AES_CLK_ENABLE __HAL_RCC_AES_CLK_ENABLE +#define __AES_CLK_SLEEP_DISABLE __HAL_RCC_AES_CLK_SLEEP_DISABLE +#define __AES_CLK_SLEEP_ENABLE __HAL_RCC_AES_CLK_SLEEP_ENABLE +#define __AES_FORCE_RESET __HAL_RCC_AES_FORCE_RESET +#define __AES_RELEASE_RESET __HAL_RCC_AES_RELEASE_RESET +#define __CRYP_CLK_SLEEP_ENABLE __HAL_RCC_CRYP_CLK_SLEEP_ENABLE +#define __CRYP_CLK_SLEEP_DISABLE __HAL_RCC_CRYP_CLK_SLEEP_DISABLE +#define __CRYP_CLK_ENABLE __HAL_RCC_CRYP_CLK_ENABLE +#define __CRYP_CLK_DISABLE __HAL_RCC_CRYP_CLK_DISABLE +#define __CRYP_FORCE_RESET __HAL_RCC_CRYP_FORCE_RESET +#define __CRYP_RELEASE_RESET __HAL_RCC_CRYP_RELEASE_RESET +#define __AFIO_CLK_DISABLE __HAL_RCC_AFIO_CLK_DISABLE +#define __AFIO_CLK_ENABLE __HAL_RCC_AFIO_CLK_ENABLE +#define __AFIO_FORCE_RESET __HAL_RCC_AFIO_FORCE_RESET +#define __AFIO_RELEASE_RESET __HAL_RCC_AFIO_RELEASE_RESET +#define __AHB_FORCE_RESET __HAL_RCC_AHB_FORCE_RESET +#define __AHB_RELEASE_RESET __HAL_RCC_AHB_RELEASE_RESET +#define __AHB1_FORCE_RESET __HAL_RCC_AHB1_FORCE_RESET +#define __AHB1_RELEASE_RESET __HAL_RCC_AHB1_RELEASE_RESET +#define __AHB2_FORCE_RESET __HAL_RCC_AHB2_FORCE_RESET +#define __AHB2_RELEASE_RESET __HAL_RCC_AHB2_RELEASE_RESET +#define __AHB3_FORCE_RESET __HAL_RCC_AHB3_FORCE_RESET +#define __AHB3_RELEASE_RESET __HAL_RCC_AHB3_RELEASE_RESET +#define __APB1_FORCE_RESET __HAL_RCC_APB1_FORCE_RESET +#define __APB1_RELEASE_RESET __HAL_RCC_APB1_RELEASE_RESET +#define __APB2_FORCE_RESET __HAL_RCC_APB2_FORCE_RESET +#define __APB2_RELEASE_RESET __HAL_RCC_APB2_RELEASE_RESET +#define __BKP_CLK_DISABLE __HAL_RCC_BKP_CLK_DISABLE +#define __BKP_CLK_ENABLE __HAL_RCC_BKP_CLK_ENABLE +#define __BKP_FORCE_RESET __HAL_RCC_BKP_FORCE_RESET +#define __BKP_RELEASE_RESET __HAL_RCC_BKP_RELEASE_RESET +#define __CAN1_CLK_DISABLE __HAL_RCC_CAN1_CLK_DISABLE +#define __CAN1_CLK_ENABLE __HAL_RCC_CAN1_CLK_ENABLE +#define __CAN1_CLK_SLEEP_DISABLE __HAL_RCC_CAN1_CLK_SLEEP_DISABLE +#define __CAN1_CLK_SLEEP_ENABLE __HAL_RCC_CAN1_CLK_SLEEP_ENABLE +#define __CAN1_FORCE_RESET __HAL_RCC_CAN1_FORCE_RESET +#define __CAN1_RELEASE_RESET __HAL_RCC_CAN1_RELEASE_RESET +#define __CAN_CLK_DISABLE __HAL_RCC_CAN1_CLK_DISABLE +#define __CAN_CLK_ENABLE __HAL_RCC_CAN1_CLK_ENABLE +#define __CAN_FORCE_RESET __HAL_RCC_CAN1_FORCE_RESET +#define __CAN_RELEASE_RESET __HAL_RCC_CAN1_RELEASE_RESET +#define __CAN2_CLK_DISABLE __HAL_RCC_CAN2_CLK_DISABLE +#define __CAN2_CLK_ENABLE __HAL_RCC_CAN2_CLK_ENABLE +#define __CAN2_FORCE_RESET __HAL_RCC_CAN2_FORCE_RESET +#define __CAN2_RELEASE_RESET __HAL_RCC_CAN2_RELEASE_RESET +#define __CEC_CLK_DISABLE __HAL_RCC_CEC_CLK_DISABLE +#define __CEC_CLK_ENABLE __HAL_RCC_CEC_CLK_ENABLE +#define __COMP_CLK_DISABLE __HAL_RCC_COMP_CLK_DISABLE +#define __COMP_CLK_ENABLE __HAL_RCC_COMP_CLK_ENABLE +#define __COMP_FORCE_RESET __HAL_RCC_COMP_FORCE_RESET +#define __COMP_RELEASE_RESET __HAL_RCC_COMP_RELEASE_RESET +#define __COMP_CLK_SLEEP_ENABLE __HAL_RCC_COMP_CLK_SLEEP_ENABLE +#define __COMP_CLK_SLEEP_DISABLE __HAL_RCC_COMP_CLK_SLEEP_DISABLE +#define __CEC_FORCE_RESET __HAL_RCC_CEC_FORCE_RESET +#define __CEC_RELEASE_RESET __HAL_RCC_CEC_RELEASE_RESET +#define __CRC_CLK_DISABLE __HAL_RCC_CRC_CLK_DISABLE +#define __CRC_CLK_ENABLE __HAL_RCC_CRC_CLK_ENABLE +#define __CRC_CLK_SLEEP_DISABLE __HAL_RCC_CRC_CLK_SLEEP_DISABLE +#define __CRC_CLK_SLEEP_ENABLE __HAL_RCC_CRC_CLK_SLEEP_ENABLE +#define __CRC_FORCE_RESET __HAL_RCC_CRC_FORCE_RESET +#define __CRC_RELEASE_RESET __HAL_RCC_CRC_RELEASE_RESET +#define __DAC_CLK_DISABLE __HAL_RCC_DAC_CLK_DISABLE +#define __DAC_CLK_ENABLE __HAL_RCC_DAC_CLK_ENABLE +#define __DAC_FORCE_RESET __HAL_RCC_DAC_FORCE_RESET +#define __DAC_RELEASE_RESET __HAL_RCC_DAC_RELEASE_RESET +#define __DAC1_CLK_DISABLE __HAL_RCC_DAC1_CLK_DISABLE +#define __DAC1_CLK_ENABLE __HAL_RCC_DAC1_CLK_ENABLE +#define __DAC1_CLK_SLEEP_DISABLE __HAL_RCC_DAC1_CLK_SLEEP_DISABLE +#define __DAC1_CLK_SLEEP_ENABLE __HAL_RCC_DAC1_CLK_SLEEP_ENABLE +#define __DAC1_FORCE_RESET __HAL_RCC_DAC1_FORCE_RESET +#define __DAC1_RELEASE_RESET __HAL_RCC_DAC1_RELEASE_RESET +#define __DBGMCU_CLK_ENABLE __HAL_RCC_DBGMCU_CLK_ENABLE +#define __DBGMCU_CLK_DISABLE __HAL_RCC_DBGMCU_CLK_DISABLE +#define __DBGMCU_FORCE_RESET __HAL_RCC_DBGMCU_FORCE_RESET +#define __DBGMCU_RELEASE_RESET __HAL_RCC_DBGMCU_RELEASE_RESET +#define __DFSDM_CLK_DISABLE __HAL_RCC_DFSDM_CLK_DISABLE +#define __DFSDM_CLK_ENABLE __HAL_RCC_DFSDM_CLK_ENABLE +#define __DFSDM_CLK_SLEEP_DISABLE __HAL_RCC_DFSDM_CLK_SLEEP_DISABLE +#define __DFSDM_CLK_SLEEP_ENABLE __HAL_RCC_DFSDM_CLK_SLEEP_ENABLE +#define __DFSDM_FORCE_RESET __HAL_RCC_DFSDM_FORCE_RESET +#define __DFSDM_RELEASE_RESET __HAL_RCC_DFSDM_RELEASE_RESET +#define __DMA1_CLK_DISABLE __HAL_RCC_DMA1_CLK_DISABLE +#define __DMA1_CLK_ENABLE __HAL_RCC_DMA1_CLK_ENABLE +#define __DMA1_CLK_SLEEP_DISABLE __HAL_RCC_DMA1_CLK_SLEEP_DISABLE +#define __DMA1_CLK_SLEEP_ENABLE __HAL_RCC_DMA1_CLK_SLEEP_ENABLE +#define __DMA1_FORCE_RESET __HAL_RCC_DMA1_FORCE_RESET +#define __DMA1_RELEASE_RESET __HAL_RCC_DMA1_RELEASE_RESET +#define __DMA2_CLK_DISABLE __HAL_RCC_DMA2_CLK_DISABLE +#define __DMA2_CLK_ENABLE __HAL_RCC_DMA2_CLK_ENABLE +#define __DMA2_CLK_SLEEP_DISABLE __HAL_RCC_DMA2_CLK_SLEEP_DISABLE +#define __DMA2_CLK_SLEEP_ENABLE __HAL_RCC_DMA2_CLK_SLEEP_ENABLE +#define __DMA2_FORCE_RESET __HAL_RCC_DMA2_FORCE_RESET +#define __DMA2_RELEASE_RESET __HAL_RCC_DMA2_RELEASE_RESET +#define __ETHMAC_CLK_DISABLE __HAL_RCC_ETHMAC_CLK_DISABLE +#define __ETHMAC_CLK_ENABLE __HAL_RCC_ETHMAC_CLK_ENABLE +#define __ETHMAC_FORCE_RESET __HAL_RCC_ETHMAC_FORCE_RESET +#define __ETHMAC_RELEASE_RESET __HAL_RCC_ETHMAC_RELEASE_RESET +#define __ETHMACRX_CLK_DISABLE __HAL_RCC_ETHMACRX_CLK_DISABLE +#define __ETHMACRX_CLK_ENABLE __HAL_RCC_ETHMACRX_CLK_ENABLE +#define __ETHMACTX_CLK_DISABLE __HAL_RCC_ETHMACTX_CLK_DISABLE +#define __ETHMACTX_CLK_ENABLE __HAL_RCC_ETHMACTX_CLK_ENABLE +#define __FIREWALL_CLK_DISABLE __HAL_RCC_FIREWALL_CLK_DISABLE +#define __FIREWALL_CLK_ENABLE __HAL_RCC_FIREWALL_CLK_ENABLE +#define __FLASH_CLK_DISABLE __HAL_RCC_FLASH_CLK_DISABLE +#define __FLASH_CLK_ENABLE __HAL_RCC_FLASH_CLK_ENABLE +#define __FLASH_CLK_SLEEP_DISABLE __HAL_RCC_FLASH_CLK_SLEEP_DISABLE +#define __FLASH_CLK_SLEEP_ENABLE __HAL_RCC_FLASH_CLK_SLEEP_ENABLE +#define __FLASH_FORCE_RESET __HAL_RCC_FLASH_FORCE_RESET +#define __FLASH_RELEASE_RESET __HAL_RCC_FLASH_RELEASE_RESET +#define __FLITF_CLK_DISABLE __HAL_RCC_FLITF_CLK_DISABLE +#define __FLITF_CLK_ENABLE __HAL_RCC_FLITF_CLK_ENABLE +#define __FLITF_FORCE_RESET __HAL_RCC_FLITF_FORCE_RESET +#define __FLITF_RELEASE_RESET __HAL_RCC_FLITF_RELEASE_RESET +#define __FLITF_CLK_SLEEP_ENABLE __HAL_RCC_FLITF_CLK_SLEEP_ENABLE +#define __FLITF_CLK_SLEEP_DISABLE __HAL_RCC_FLITF_CLK_SLEEP_DISABLE +#define __FMC_CLK_DISABLE __HAL_RCC_FMC_CLK_DISABLE +#define __FMC_CLK_ENABLE __HAL_RCC_FMC_CLK_ENABLE +#define __FMC_CLK_SLEEP_DISABLE __HAL_RCC_FMC_CLK_SLEEP_DISABLE +#define __FMC_CLK_SLEEP_ENABLE __HAL_RCC_FMC_CLK_SLEEP_ENABLE +#define __FMC_FORCE_RESET __HAL_RCC_FMC_FORCE_RESET +#define __FMC_RELEASE_RESET __HAL_RCC_FMC_RELEASE_RESET +#define __FSMC_CLK_DISABLE __HAL_RCC_FSMC_CLK_DISABLE +#define __FSMC_CLK_ENABLE __HAL_RCC_FSMC_CLK_ENABLE +#define __GPIOA_CLK_DISABLE __HAL_RCC_GPIOA_CLK_DISABLE +#define __GPIOA_CLK_ENABLE __HAL_RCC_GPIOA_CLK_ENABLE +#define __GPIOA_CLK_SLEEP_DISABLE __HAL_RCC_GPIOA_CLK_SLEEP_DISABLE +#define __GPIOA_CLK_SLEEP_ENABLE __HAL_RCC_GPIOA_CLK_SLEEP_ENABLE +#define __GPIOA_FORCE_RESET __HAL_RCC_GPIOA_FORCE_RESET +#define __GPIOA_RELEASE_RESET __HAL_RCC_GPIOA_RELEASE_RESET +#define __GPIOB_CLK_DISABLE __HAL_RCC_GPIOB_CLK_DISABLE +#define __GPIOB_CLK_ENABLE __HAL_RCC_GPIOB_CLK_ENABLE +#define __GPIOB_CLK_SLEEP_DISABLE __HAL_RCC_GPIOB_CLK_SLEEP_DISABLE +#define __GPIOB_CLK_SLEEP_ENABLE __HAL_RCC_GPIOB_CLK_SLEEP_ENABLE +#define __GPIOB_FORCE_RESET __HAL_RCC_GPIOB_FORCE_RESET +#define __GPIOB_RELEASE_RESET __HAL_RCC_GPIOB_RELEASE_RESET +#define __GPIOC_CLK_DISABLE __HAL_RCC_GPIOC_CLK_DISABLE +#define __GPIOC_CLK_ENABLE __HAL_RCC_GPIOC_CLK_ENABLE +#define __GPIOC_CLK_SLEEP_DISABLE __HAL_RCC_GPIOC_CLK_SLEEP_DISABLE +#define __GPIOC_CLK_SLEEP_ENABLE __HAL_RCC_GPIOC_CLK_SLEEP_ENABLE +#define __GPIOC_FORCE_RESET __HAL_RCC_GPIOC_FORCE_RESET +#define __GPIOC_RELEASE_RESET __HAL_RCC_GPIOC_RELEASE_RESET +#define __GPIOD_CLK_DISABLE __HAL_RCC_GPIOD_CLK_DISABLE +#define __GPIOD_CLK_ENABLE __HAL_RCC_GPIOD_CLK_ENABLE +#define __GPIOD_CLK_SLEEP_DISABLE __HAL_RCC_GPIOD_CLK_SLEEP_DISABLE +#define __GPIOD_CLK_SLEEP_ENABLE __HAL_RCC_GPIOD_CLK_SLEEP_ENABLE +#define __GPIOD_FORCE_RESET __HAL_RCC_GPIOD_FORCE_RESET +#define __GPIOD_RELEASE_RESET __HAL_RCC_GPIOD_RELEASE_RESET +#define __GPIOE_CLK_DISABLE __HAL_RCC_GPIOE_CLK_DISABLE +#define __GPIOE_CLK_ENABLE __HAL_RCC_GPIOE_CLK_ENABLE +#define __GPIOE_CLK_SLEEP_DISABLE __HAL_RCC_GPIOE_CLK_SLEEP_DISABLE +#define __GPIOE_CLK_SLEEP_ENABLE __HAL_RCC_GPIOE_CLK_SLEEP_ENABLE +#define __GPIOE_FORCE_RESET __HAL_RCC_GPIOE_FORCE_RESET +#define __GPIOE_RELEASE_RESET __HAL_RCC_GPIOE_RELEASE_RESET +#define __GPIOF_CLK_DISABLE __HAL_RCC_GPIOF_CLK_DISABLE +#define __GPIOF_CLK_ENABLE __HAL_RCC_GPIOF_CLK_ENABLE +#define __GPIOF_CLK_SLEEP_DISABLE __HAL_RCC_GPIOF_CLK_SLEEP_DISABLE +#define __GPIOF_CLK_SLEEP_ENABLE __HAL_RCC_GPIOF_CLK_SLEEP_ENABLE +#define __GPIOF_FORCE_RESET __HAL_RCC_GPIOF_FORCE_RESET +#define __GPIOF_RELEASE_RESET __HAL_RCC_GPIOF_RELEASE_RESET +#define __GPIOG_CLK_DISABLE __HAL_RCC_GPIOG_CLK_DISABLE +#define __GPIOG_CLK_ENABLE __HAL_RCC_GPIOG_CLK_ENABLE +#define __GPIOG_CLK_SLEEP_DISABLE __HAL_RCC_GPIOG_CLK_SLEEP_DISABLE +#define __GPIOG_CLK_SLEEP_ENABLE __HAL_RCC_GPIOG_CLK_SLEEP_ENABLE +#define __GPIOG_FORCE_RESET __HAL_RCC_GPIOG_FORCE_RESET +#define __GPIOG_RELEASE_RESET __HAL_RCC_GPIOG_RELEASE_RESET +#define __GPIOH_CLK_DISABLE __HAL_RCC_GPIOH_CLK_DISABLE +#define __GPIOH_CLK_ENABLE __HAL_RCC_GPIOH_CLK_ENABLE +#define __GPIOH_CLK_SLEEP_DISABLE __HAL_RCC_GPIOH_CLK_SLEEP_DISABLE +#define __GPIOH_CLK_SLEEP_ENABLE __HAL_RCC_GPIOH_CLK_SLEEP_ENABLE +#define __GPIOH_FORCE_RESET __HAL_RCC_GPIOH_FORCE_RESET +#define __GPIOH_RELEASE_RESET __HAL_RCC_GPIOH_RELEASE_RESET +#define __I2C1_CLK_DISABLE __HAL_RCC_I2C1_CLK_DISABLE +#define __I2C1_CLK_ENABLE __HAL_RCC_I2C1_CLK_ENABLE +#define __I2C1_CLK_SLEEP_DISABLE __HAL_RCC_I2C1_CLK_SLEEP_DISABLE +#define __I2C1_CLK_SLEEP_ENABLE __HAL_RCC_I2C1_CLK_SLEEP_ENABLE +#define __I2C1_FORCE_RESET __HAL_RCC_I2C1_FORCE_RESET +#define __I2C1_RELEASE_RESET __HAL_RCC_I2C1_RELEASE_RESET +#define __I2C2_CLK_DISABLE __HAL_RCC_I2C2_CLK_DISABLE +#define __I2C2_CLK_ENABLE __HAL_RCC_I2C2_CLK_ENABLE +#define __I2C2_CLK_SLEEP_DISABLE __HAL_RCC_I2C2_CLK_SLEEP_DISABLE +#define __I2C2_CLK_SLEEP_ENABLE __HAL_RCC_I2C2_CLK_SLEEP_ENABLE +#define __I2C2_FORCE_RESET __HAL_RCC_I2C2_FORCE_RESET +#define __I2C2_RELEASE_RESET __HAL_RCC_I2C2_RELEASE_RESET +#define __I2C3_CLK_DISABLE __HAL_RCC_I2C3_CLK_DISABLE +#define __I2C3_CLK_ENABLE __HAL_RCC_I2C3_CLK_ENABLE +#define __I2C3_CLK_SLEEP_DISABLE __HAL_RCC_I2C3_CLK_SLEEP_DISABLE +#define __I2C3_CLK_SLEEP_ENABLE __HAL_RCC_I2C3_CLK_SLEEP_ENABLE +#define __I2C3_FORCE_RESET __HAL_RCC_I2C3_FORCE_RESET +#define __I2C3_RELEASE_RESET __HAL_RCC_I2C3_RELEASE_RESET +#define __LCD_CLK_DISABLE __HAL_RCC_LCD_CLK_DISABLE +#define __LCD_CLK_ENABLE __HAL_RCC_LCD_CLK_ENABLE +#define __LCD_CLK_SLEEP_DISABLE __HAL_RCC_LCD_CLK_SLEEP_DISABLE +#define __LCD_CLK_SLEEP_ENABLE __HAL_RCC_LCD_CLK_SLEEP_ENABLE +#define __LCD_FORCE_RESET __HAL_RCC_LCD_FORCE_RESET +#define __LCD_RELEASE_RESET __HAL_RCC_LCD_RELEASE_RESET +#define __LPTIM1_CLK_DISABLE __HAL_RCC_LPTIM1_CLK_DISABLE +#define __LPTIM1_CLK_ENABLE __HAL_RCC_LPTIM1_CLK_ENABLE +#define __LPTIM1_CLK_SLEEP_DISABLE __HAL_RCC_LPTIM1_CLK_SLEEP_DISABLE +#define __LPTIM1_CLK_SLEEP_ENABLE __HAL_RCC_LPTIM1_CLK_SLEEP_ENABLE +#define __LPTIM1_FORCE_RESET __HAL_RCC_LPTIM1_FORCE_RESET +#define __LPTIM1_RELEASE_RESET __HAL_RCC_LPTIM1_RELEASE_RESET +#define __LPTIM2_CLK_DISABLE __HAL_RCC_LPTIM2_CLK_DISABLE +#define __LPTIM2_CLK_ENABLE __HAL_RCC_LPTIM2_CLK_ENABLE +#define __LPTIM2_CLK_SLEEP_DISABLE __HAL_RCC_LPTIM2_CLK_SLEEP_DISABLE +#define __LPTIM2_CLK_SLEEP_ENABLE __HAL_RCC_LPTIM2_CLK_SLEEP_ENABLE +#define __LPTIM2_FORCE_RESET __HAL_RCC_LPTIM2_FORCE_RESET +#define __LPTIM2_RELEASE_RESET __HAL_RCC_LPTIM2_RELEASE_RESET +#define __LPUART1_CLK_DISABLE __HAL_RCC_LPUART1_CLK_DISABLE +#define __LPUART1_CLK_ENABLE __HAL_RCC_LPUART1_CLK_ENABLE +#define __LPUART1_CLK_SLEEP_DISABLE __HAL_RCC_LPUART1_CLK_SLEEP_DISABLE +#define __LPUART1_CLK_SLEEP_ENABLE __HAL_RCC_LPUART1_CLK_SLEEP_ENABLE +#define __LPUART1_FORCE_RESET __HAL_RCC_LPUART1_FORCE_RESET +#define __LPUART1_RELEASE_RESET __HAL_RCC_LPUART1_RELEASE_RESET +#define __OPAMP_CLK_DISABLE __HAL_RCC_OPAMP_CLK_DISABLE +#define __OPAMP_CLK_ENABLE __HAL_RCC_OPAMP_CLK_ENABLE +#define __OPAMP_CLK_SLEEP_DISABLE __HAL_RCC_OPAMP_CLK_SLEEP_DISABLE +#define __OPAMP_CLK_SLEEP_ENABLE __HAL_RCC_OPAMP_CLK_SLEEP_ENABLE +#define __OPAMP_FORCE_RESET __HAL_RCC_OPAMP_FORCE_RESET +#define __OPAMP_RELEASE_RESET __HAL_RCC_OPAMP_RELEASE_RESET +#define __OTGFS_CLK_DISABLE __HAL_RCC_OTGFS_CLK_DISABLE +#define __OTGFS_CLK_ENABLE __HAL_RCC_OTGFS_CLK_ENABLE +#define __OTGFS_CLK_SLEEP_DISABLE __HAL_RCC_OTGFS_CLK_SLEEP_DISABLE +#define __OTGFS_CLK_SLEEP_ENABLE __HAL_RCC_OTGFS_CLK_SLEEP_ENABLE +#define __OTGFS_FORCE_RESET __HAL_RCC_OTGFS_FORCE_RESET +#define __OTGFS_RELEASE_RESET __HAL_RCC_OTGFS_RELEASE_RESET +#define __PWR_CLK_DISABLE __HAL_RCC_PWR_CLK_DISABLE +#define __PWR_CLK_ENABLE __HAL_RCC_PWR_CLK_ENABLE +#define __PWR_CLK_SLEEP_DISABLE __HAL_RCC_PWR_CLK_SLEEP_DISABLE +#define __PWR_CLK_SLEEP_ENABLE __HAL_RCC_PWR_CLK_SLEEP_ENABLE +#define __PWR_FORCE_RESET __HAL_RCC_PWR_FORCE_RESET +#define __PWR_RELEASE_RESET __HAL_RCC_PWR_RELEASE_RESET +#define __QSPI_CLK_DISABLE __HAL_RCC_QSPI_CLK_DISABLE +#define __QSPI_CLK_ENABLE __HAL_RCC_QSPI_CLK_ENABLE +#define __QSPI_CLK_SLEEP_DISABLE __HAL_RCC_QSPI_CLK_SLEEP_DISABLE +#define __QSPI_CLK_SLEEP_ENABLE __HAL_RCC_QSPI_CLK_SLEEP_ENABLE +#define __QSPI_FORCE_RESET __HAL_RCC_QSPI_FORCE_RESET +#define __QSPI_RELEASE_RESET __HAL_RCC_QSPI_RELEASE_RESET + +#if defined(STM32WB) +#define __HAL_RCC_QSPI_CLK_DISABLE __HAL_RCC_QUADSPI_CLK_DISABLE +#define __HAL_RCC_QSPI_CLK_ENABLE __HAL_RCC_QUADSPI_CLK_ENABLE +#define __HAL_RCC_QSPI_CLK_SLEEP_DISABLE __HAL_RCC_QUADSPI_CLK_SLEEP_DISABLE +#define __HAL_RCC_QSPI_CLK_SLEEP_ENABLE __HAL_RCC_QUADSPI_CLK_SLEEP_ENABLE +#define __HAL_RCC_QSPI_FORCE_RESET __HAL_RCC_QUADSPI_FORCE_RESET +#define __HAL_RCC_QSPI_RELEASE_RESET __HAL_RCC_QUADSPI_RELEASE_RESET +#define __HAL_RCC_QSPI_IS_CLK_ENABLED __HAL_RCC_QUADSPI_IS_CLK_ENABLED +#define __HAL_RCC_QSPI_IS_CLK_DISABLED __HAL_RCC_QUADSPI_IS_CLK_DISABLED +#define __HAL_RCC_QSPI_IS_CLK_SLEEP_ENABLED __HAL_RCC_QUADSPI_IS_CLK_SLEEP_ENABLED +#define __HAL_RCC_QSPI_IS_CLK_SLEEP_DISABLED __HAL_RCC_QUADSPI_IS_CLK_SLEEP_DISABLED +#define QSPI_IRQHandler QUADSPI_IRQHandler +#endif /* __HAL_RCC_QUADSPI_CLK_ENABLE */ + +#define __RNG_CLK_DISABLE __HAL_RCC_RNG_CLK_DISABLE +#define __RNG_CLK_ENABLE __HAL_RCC_RNG_CLK_ENABLE +#define __RNG_CLK_SLEEP_DISABLE __HAL_RCC_RNG_CLK_SLEEP_DISABLE +#define __RNG_CLK_SLEEP_ENABLE __HAL_RCC_RNG_CLK_SLEEP_ENABLE +#define __RNG_FORCE_RESET __HAL_RCC_RNG_FORCE_RESET +#define __RNG_RELEASE_RESET __HAL_RCC_RNG_RELEASE_RESET +#define __SAI1_CLK_DISABLE __HAL_RCC_SAI1_CLK_DISABLE +#define __SAI1_CLK_ENABLE __HAL_RCC_SAI1_CLK_ENABLE +#define __SAI1_CLK_SLEEP_DISABLE __HAL_RCC_SAI1_CLK_SLEEP_DISABLE +#define __SAI1_CLK_SLEEP_ENABLE __HAL_RCC_SAI1_CLK_SLEEP_ENABLE +#define __SAI1_FORCE_RESET __HAL_RCC_SAI1_FORCE_RESET +#define __SAI1_RELEASE_RESET __HAL_RCC_SAI1_RELEASE_RESET +#define __SAI2_CLK_DISABLE __HAL_RCC_SAI2_CLK_DISABLE +#define __SAI2_CLK_ENABLE __HAL_RCC_SAI2_CLK_ENABLE +#define __SAI2_CLK_SLEEP_DISABLE __HAL_RCC_SAI2_CLK_SLEEP_DISABLE +#define __SAI2_CLK_SLEEP_ENABLE __HAL_RCC_SAI2_CLK_SLEEP_ENABLE +#define __SAI2_FORCE_RESET __HAL_RCC_SAI2_FORCE_RESET +#define __SAI2_RELEASE_RESET __HAL_RCC_SAI2_RELEASE_RESET +#define __SDIO_CLK_DISABLE __HAL_RCC_SDIO_CLK_DISABLE +#define __SDIO_CLK_ENABLE __HAL_RCC_SDIO_CLK_ENABLE +#define __SDMMC_CLK_DISABLE __HAL_RCC_SDMMC_CLK_DISABLE +#define __SDMMC_CLK_ENABLE __HAL_RCC_SDMMC_CLK_ENABLE +#define __SDMMC_CLK_SLEEP_DISABLE __HAL_RCC_SDMMC_CLK_SLEEP_DISABLE +#define __SDMMC_CLK_SLEEP_ENABLE __HAL_RCC_SDMMC_CLK_SLEEP_ENABLE +#define __SDMMC_FORCE_RESET __HAL_RCC_SDMMC_FORCE_RESET +#define __SDMMC_RELEASE_RESET __HAL_RCC_SDMMC_RELEASE_RESET +#define __SPI1_CLK_DISABLE __HAL_RCC_SPI1_CLK_DISABLE +#define __SPI1_CLK_ENABLE __HAL_RCC_SPI1_CLK_ENABLE +#define __SPI1_CLK_SLEEP_DISABLE __HAL_RCC_SPI1_CLK_SLEEP_DISABLE +#define __SPI1_CLK_SLEEP_ENABLE __HAL_RCC_SPI1_CLK_SLEEP_ENABLE +#define __SPI1_FORCE_RESET __HAL_RCC_SPI1_FORCE_RESET +#define __SPI1_RELEASE_RESET __HAL_RCC_SPI1_RELEASE_RESET +#define __SPI2_CLK_DISABLE __HAL_RCC_SPI2_CLK_DISABLE +#define __SPI2_CLK_ENABLE __HAL_RCC_SPI2_CLK_ENABLE +#define __SPI2_CLK_SLEEP_DISABLE __HAL_RCC_SPI2_CLK_SLEEP_DISABLE +#define __SPI2_CLK_SLEEP_ENABLE __HAL_RCC_SPI2_CLK_SLEEP_ENABLE +#define __SPI2_FORCE_RESET __HAL_RCC_SPI2_FORCE_RESET +#define __SPI2_RELEASE_RESET __HAL_RCC_SPI2_RELEASE_RESET +#define __SPI3_CLK_DISABLE __HAL_RCC_SPI3_CLK_DISABLE +#define __SPI3_CLK_ENABLE __HAL_RCC_SPI3_CLK_ENABLE +#define __SPI3_CLK_SLEEP_DISABLE __HAL_RCC_SPI3_CLK_SLEEP_DISABLE +#define __SPI3_CLK_SLEEP_ENABLE __HAL_RCC_SPI3_CLK_SLEEP_ENABLE +#define __SPI3_FORCE_RESET __HAL_RCC_SPI3_FORCE_RESET +#define __SPI3_RELEASE_RESET __HAL_RCC_SPI3_RELEASE_RESET +#define __SRAM_CLK_DISABLE __HAL_RCC_SRAM_CLK_DISABLE +#define __SRAM_CLK_ENABLE __HAL_RCC_SRAM_CLK_ENABLE +#define __SRAM1_CLK_SLEEP_DISABLE __HAL_RCC_SRAM1_CLK_SLEEP_DISABLE +#define __SRAM1_CLK_SLEEP_ENABLE __HAL_RCC_SRAM1_CLK_SLEEP_ENABLE +#define __SRAM2_CLK_SLEEP_DISABLE __HAL_RCC_SRAM2_CLK_SLEEP_DISABLE +#define __SRAM2_CLK_SLEEP_ENABLE __HAL_RCC_SRAM2_CLK_SLEEP_ENABLE +#define __SWPMI1_CLK_DISABLE __HAL_RCC_SWPMI1_CLK_DISABLE +#define __SWPMI1_CLK_ENABLE __HAL_RCC_SWPMI1_CLK_ENABLE +#define __SWPMI1_CLK_SLEEP_DISABLE __HAL_RCC_SWPMI1_CLK_SLEEP_DISABLE +#define __SWPMI1_CLK_SLEEP_ENABLE __HAL_RCC_SWPMI1_CLK_SLEEP_ENABLE +#define __SWPMI1_FORCE_RESET __HAL_RCC_SWPMI1_FORCE_RESET +#define __SWPMI1_RELEASE_RESET __HAL_RCC_SWPMI1_RELEASE_RESET +#define __SYSCFG_CLK_DISABLE __HAL_RCC_SYSCFG_CLK_DISABLE +#define __SYSCFG_CLK_ENABLE __HAL_RCC_SYSCFG_CLK_ENABLE +#define __SYSCFG_CLK_SLEEP_DISABLE __HAL_RCC_SYSCFG_CLK_SLEEP_DISABLE +#define __SYSCFG_CLK_SLEEP_ENABLE __HAL_RCC_SYSCFG_CLK_SLEEP_ENABLE +#define __SYSCFG_FORCE_RESET __HAL_RCC_SYSCFG_FORCE_RESET +#define __SYSCFG_RELEASE_RESET __HAL_RCC_SYSCFG_RELEASE_RESET +#define __TIM1_CLK_DISABLE __HAL_RCC_TIM1_CLK_DISABLE +#define __TIM1_CLK_ENABLE __HAL_RCC_TIM1_CLK_ENABLE +#define __TIM1_CLK_SLEEP_DISABLE __HAL_RCC_TIM1_CLK_SLEEP_DISABLE +#define __TIM1_CLK_SLEEP_ENABLE __HAL_RCC_TIM1_CLK_SLEEP_ENABLE +#define __TIM1_FORCE_RESET __HAL_RCC_TIM1_FORCE_RESET +#define __TIM1_RELEASE_RESET __HAL_RCC_TIM1_RELEASE_RESET +#define __TIM10_CLK_DISABLE __HAL_RCC_TIM10_CLK_DISABLE +#define __TIM10_CLK_ENABLE __HAL_RCC_TIM10_CLK_ENABLE +#define __TIM10_FORCE_RESET __HAL_RCC_TIM10_FORCE_RESET +#define __TIM10_RELEASE_RESET __HAL_RCC_TIM10_RELEASE_RESET +#define __TIM11_CLK_DISABLE __HAL_RCC_TIM11_CLK_DISABLE +#define __TIM11_CLK_ENABLE __HAL_RCC_TIM11_CLK_ENABLE +#define __TIM11_FORCE_RESET __HAL_RCC_TIM11_FORCE_RESET +#define __TIM11_RELEASE_RESET __HAL_RCC_TIM11_RELEASE_RESET +#define __TIM12_CLK_DISABLE __HAL_RCC_TIM12_CLK_DISABLE +#define __TIM12_CLK_ENABLE __HAL_RCC_TIM12_CLK_ENABLE +#define __TIM12_FORCE_RESET __HAL_RCC_TIM12_FORCE_RESET +#define __TIM12_RELEASE_RESET __HAL_RCC_TIM12_RELEASE_RESET +#define __TIM13_CLK_DISABLE __HAL_RCC_TIM13_CLK_DISABLE +#define __TIM13_CLK_ENABLE __HAL_RCC_TIM13_CLK_ENABLE +#define __TIM13_FORCE_RESET __HAL_RCC_TIM13_FORCE_RESET +#define __TIM13_RELEASE_RESET __HAL_RCC_TIM13_RELEASE_RESET +#define __TIM14_CLK_DISABLE __HAL_RCC_TIM14_CLK_DISABLE +#define __TIM14_CLK_ENABLE __HAL_RCC_TIM14_CLK_ENABLE +#define __TIM14_FORCE_RESET __HAL_RCC_TIM14_FORCE_RESET +#define __TIM14_RELEASE_RESET __HAL_RCC_TIM14_RELEASE_RESET +#define __TIM15_CLK_DISABLE __HAL_RCC_TIM15_CLK_DISABLE +#define __TIM15_CLK_ENABLE __HAL_RCC_TIM15_CLK_ENABLE +#define __TIM15_CLK_SLEEP_DISABLE __HAL_RCC_TIM15_CLK_SLEEP_DISABLE +#define __TIM15_CLK_SLEEP_ENABLE __HAL_RCC_TIM15_CLK_SLEEP_ENABLE +#define __TIM15_FORCE_RESET __HAL_RCC_TIM15_FORCE_RESET +#define __TIM15_RELEASE_RESET __HAL_RCC_TIM15_RELEASE_RESET +#define __TIM16_CLK_DISABLE __HAL_RCC_TIM16_CLK_DISABLE +#define __TIM16_CLK_ENABLE __HAL_RCC_TIM16_CLK_ENABLE +#define __TIM16_CLK_SLEEP_DISABLE __HAL_RCC_TIM16_CLK_SLEEP_DISABLE +#define __TIM16_CLK_SLEEP_ENABLE __HAL_RCC_TIM16_CLK_SLEEP_ENABLE +#define __TIM16_FORCE_RESET __HAL_RCC_TIM16_FORCE_RESET +#define __TIM16_RELEASE_RESET __HAL_RCC_TIM16_RELEASE_RESET +#define __TIM17_CLK_DISABLE __HAL_RCC_TIM17_CLK_DISABLE +#define __TIM17_CLK_ENABLE __HAL_RCC_TIM17_CLK_ENABLE +#define __TIM17_CLK_SLEEP_DISABLE __HAL_RCC_TIM17_CLK_SLEEP_DISABLE +#define __TIM17_CLK_SLEEP_ENABLE __HAL_RCC_TIM17_CLK_SLEEP_ENABLE +#define __TIM17_FORCE_RESET __HAL_RCC_TIM17_FORCE_RESET +#define __TIM17_RELEASE_RESET __HAL_RCC_TIM17_RELEASE_RESET +#define __TIM2_CLK_DISABLE __HAL_RCC_TIM2_CLK_DISABLE +#define __TIM2_CLK_ENABLE __HAL_RCC_TIM2_CLK_ENABLE +#define __TIM2_CLK_SLEEP_DISABLE __HAL_RCC_TIM2_CLK_SLEEP_DISABLE +#define __TIM2_CLK_SLEEP_ENABLE __HAL_RCC_TIM2_CLK_SLEEP_ENABLE +#define __TIM2_FORCE_RESET __HAL_RCC_TIM2_FORCE_RESET +#define __TIM2_RELEASE_RESET __HAL_RCC_TIM2_RELEASE_RESET +#define __TIM3_CLK_DISABLE __HAL_RCC_TIM3_CLK_DISABLE +#define __TIM3_CLK_ENABLE __HAL_RCC_TIM3_CLK_ENABLE +#define __TIM3_CLK_SLEEP_DISABLE __HAL_RCC_TIM3_CLK_SLEEP_DISABLE +#define __TIM3_CLK_SLEEP_ENABLE __HAL_RCC_TIM3_CLK_SLEEP_ENABLE +#define __TIM3_FORCE_RESET __HAL_RCC_TIM3_FORCE_RESET +#define __TIM3_RELEASE_RESET __HAL_RCC_TIM3_RELEASE_RESET +#define __TIM4_CLK_DISABLE __HAL_RCC_TIM4_CLK_DISABLE +#define __TIM4_CLK_ENABLE __HAL_RCC_TIM4_CLK_ENABLE +#define __TIM4_CLK_SLEEP_DISABLE __HAL_RCC_TIM4_CLK_SLEEP_DISABLE +#define __TIM4_CLK_SLEEP_ENABLE __HAL_RCC_TIM4_CLK_SLEEP_ENABLE +#define __TIM4_FORCE_RESET __HAL_RCC_TIM4_FORCE_RESET +#define __TIM4_RELEASE_RESET __HAL_RCC_TIM4_RELEASE_RESET +#define __TIM5_CLK_DISABLE __HAL_RCC_TIM5_CLK_DISABLE +#define __TIM5_CLK_ENABLE __HAL_RCC_TIM5_CLK_ENABLE +#define __TIM5_CLK_SLEEP_DISABLE __HAL_RCC_TIM5_CLK_SLEEP_DISABLE +#define __TIM5_CLK_SLEEP_ENABLE __HAL_RCC_TIM5_CLK_SLEEP_ENABLE +#define __TIM5_FORCE_RESET __HAL_RCC_TIM5_FORCE_RESET +#define __TIM5_RELEASE_RESET __HAL_RCC_TIM5_RELEASE_RESET +#define __TIM6_CLK_DISABLE __HAL_RCC_TIM6_CLK_DISABLE +#define __TIM6_CLK_ENABLE __HAL_RCC_TIM6_CLK_ENABLE +#define __TIM6_CLK_SLEEP_DISABLE __HAL_RCC_TIM6_CLK_SLEEP_DISABLE +#define __TIM6_CLK_SLEEP_ENABLE __HAL_RCC_TIM6_CLK_SLEEP_ENABLE +#define __TIM6_FORCE_RESET __HAL_RCC_TIM6_FORCE_RESET +#define __TIM6_RELEASE_RESET __HAL_RCC_TIM6_RELEASE_RESET +#define __TIM7_CLK_DISABLE __HAL_RCC_TIM7_CLK_DISABLE +#define __TIM7_CLK_ENABLE __HAL_RCC_TIM7_CLK_ENABLE +#define __TIM7_CLK_SLEEP_DISABLE __HAL_RCC_TIM7_CLK_SLEEP_DISABLE +#define __TIM7_CLK_SLEEP_ENABLE __HAL_RCC_TIM7_CLK_SLEEP_ENABLE +#define __TIM7_FORCE_RESET __HAL_RCC_TIM7_FORCE_RESET +#define __TIM7_RELEASE_RESET __HAL_RCC_TIM7_RELEASE_RESET +#define __TIM8_CLK_DISABLE __HAL_RCC_TIM8_CLK_DISABLE +#define __TIM8_CLK_ENABLE __HAL_RCC_TIM8_CLK_ENABLE +#define __TIM8_CLK_SLEEP_DISABLE __HAL_RCC_TIM8_CLK_SLEEP_DISABLE +#define __TIM8_CLK_SLEEP_ENABLE __HAL_RCC_TIM8_CLK_SLEEP_ENABLE +#define __TIM8_FORCE_RESET __HAL_RCC_TIM8_FORCE_RESET +#define __TIM8_RELEASE_RESET __HAL_RCC_TIM8_RELEASE_RESET +#define __TIM9_CLK_DISABLE __HAL_RCC_TIM9_CLK_DISABLE +#define __TIM9_CLK_ENABLE __HAL_RCC_TIM9_CLK_ENABLE +#define __TIM9_FORCE_RESET __HAL_RCC_TIM9_FORCE_RESET +#define __TIM9_RELEASE_RESET __HAL_RCC_TIM9_RELEASE_RESET +#define __TSC_CLK_DISABLE __HAL_RCC_TSC_CLK_DISABLE +#define __TSC_CLK_ENABLE __HAL_RCC_TSC_CLK_ENABLE +#define __TSC_CLK_SLEEP_DISABLE __HAL_RCC_TSC_CLK_SLEEP_DISABLE +#define __TSC_CLK_SLEEP_ENABLE __HAL_RCC_TSC_CLK_SLEEP_ENABLE +#define __TSC_FORCE_RESET __HAL_RCC_TSC_FORCE_RESET +#define __TSC_RELEASE_RESET __HAL_RCC_TSC_RELEASE_RESET +#define __UART4_CLK_DISABLE __HAL_RCC_UART4_CLK_DISABLE +#define __UART4_CLK_ENABLE __HAL_RCC_UART4_CLK_ENABLE +#define __UART4_CLK_SLEEP_DISABLE __HAL_RCC_UART4_CLK_SLEEP_DISABLE +#define __UART4_CLK_SLEEP_ENABLE __HAL_RCC_UART4_CLK_SLEEP_ENABLE +#define __UART4_FORCE_RESET __HAL_RCC_UART4_FORCE_RESET +#define __UART4_RELEASE_RESET __HAL_RCC_UART4_RELEASE_RESET +#define __UART5_CLK_DISABLE __HAL_RCC_UART5_CLK_DISABLE +#define __UART5_CLK_ENABLE __HAL_RCC_UART5_CLK_ENABLE +#define __UART5_CLK_SLEEP_DISABLE __HAL_RCC_UART5_CLK_SLEEP_DISABLE +#define __UART5_CLK_SLEEP_ENABLE __HAL_RCC_UART5_CLK_SLEEP_ENABLE +#define __UART5_FORCE_RESET __HAL_RCC_UART5_FORCE_RESET +#define __UART5_RELEASE_RESET __HAL_RCC_UART5_RELEASE_RESET +#define __USART1_CLK_DISABLE __HAL_RCC_USART1_CLK_DISABLE +#define __USART1_CLK_ENABLE __HAL_RCC_USART1_CLK_ENABLE +#define __USART1_CLK_SLEEP_DISABLE __HAL_RCC_USART1_CLK_SLEEP_DISABLE +#define __USART1_CLK_SLEEP_ENABLE __HAL_RCC_USART1_CLK_SLEEP_ENABLE +#define __USART1_FORCE_RESET __HAL_RCC_USART1_FORCE_RESET +#define __USART1_RELEASE_RESET __HAL_RCC_USART1_RELEASE_RESET +#define __USART2_CLK_DISABLE __HAL_RCC_USART2_CLK_DISABLE +#define __USART2_CLK_ENABLE __HAL_RCC_USART2_CLK_ENABLE +#define __USART2_CLK_SLEEP_DISABLE __HAL_RCC_USART2_CLK_SLEEP_DISABLE +#define __USART2_CLK_SLEEP_ENABLE __HAL_RCC_USART2_CLK_SLEEP_ENABLE +#define __USART2_FORCE_RESET __HAL_RCC_USART2_FORCE_RESET +#define __USART2_RELEASE_RESET __HAL_RCC_USART2_RELEASE_RESET +#define __USART3_CLK_DISABLE __HAL_RCC_USART3_CLK_DISABLE +#define __USART3_CLK_ENABLE __HAL_RCC_USART3_CLK_ENABLE +#define __USART3_CLK_SLEEP_DISABLE __HAL_RCC_USART3_CLK_SLEEP_DISABLE +#define __USART3_CLK_SLEEP_ENABLE __HAL_RCC_USART3_CLK_SLEEP_ENABLE +#define __USART3_FORCE_RESET __HAL_RCC_USART3_FORCE_RESET +#define __USART3_RELEASE_RESET __HAL_RCC_USART3_RELEASE_RESET +#define __USART4_CLK_DISABLE __HAL_RCC_UART4_CLK_DISABLE +#define __USART4_CLK_ENABLE __HAL_RCC_UART4_CLK_ENABLE +#define __USART4_CLK_SLEEP_ENABLE __HAL_RCC_UART4_CLK_SLEEP_ENABLE +#define __USART4_CLK_SLEEP_DISABLE __HAL_RCC_UART4_CLK_SLEEP_DISABLE +#define __USART4_FORCE_RESET __HAL_RCC_UART4_FORCE_RESET +#define __USART4_RELEASE_RESET __HAL_RCC_UART4_RELEASE_RESET +#define __USART5_CLK_DISABLE __HAL_RCC_UART5_CLK_DISABLE +#define __USART5_CLK_ENABLE __HAL_RCC_UART5_CLK_ENABLE +#define __USART5_CLK_SLEEP_ENABLE __HAL_RCC_UART5_CLK_SLEEP_ENABLE +#define __USART5_CLK_SLEEP_DISABLE __HAL_RCC_UART5_CLK_SLEEP_DISABLE +#define __USART5_FORCE_RESET __HAL_RCC_UART5_FORCE_RESET +#define __USART5_RELEASE_RESET __HAL_RCC_UART5_RELEASE_RESET +#define __USART7_CLK_DISABLE __HAL_RCC_UART7_CLK_DISABLE +#define __USART7_CLK_ENABLE __HAL_RCC_UART7_CLK_ENABLE +#define __USART7_FORCE_RESET __HAL_RCC_UART7_FORCE_RESET +#define __USART7_RELEASE_RESET __HAL_RCC_UART7_RELEASE_RESET +#define __USART8_CLK_DISABLE __HAL_RCC_UART8_CLK_DISABLE +#define __USART8_CLK_ENABLE __HAL_RCC_UART8_CLK_ENABLE +#define __USART8_FORCE_RESET __HAL_RCC_UART8_FORCE_RESET +#define __USART8_RELEASE_RESET __HAL_RCC_UART8_RELEASE_RESET +#define __USB_CLK_DISABLE __HAL_RCC_USB_CLK_DISABLE +#define __USB_CLK_ENABLE __HAL_RCC_USB_CLK_ENABLE +#define __USB_FORCE_RESET __HAL_RCC_USB_FORCE_RESET +#define __USB_CLK_SLEEP_ENABLE __HAL_RCC_USB_CLK_SLEEP_ENABLE +#define __USB_CLK_SLEEP_DISABLE __HAL_RCC_USB_CLK_SLEEP_DISABLE +#define __USB_OTG_FS_CLK_DISABLE __HAL_RCC_USB_OTG_FS_CLK_DISABLE +#define __USB_OTG_FS_CLK_ENABLE __HAL_RCC_USB_OTG_FS_CLK_ENABLE +#define __USB_RELEASE_RESET __HAL_RCC_USB_RELEASE_RESET + +#if defined(STM32H7) +#define __HAL_RCC_WWDG_CLK_DISABLE __HAL_RCC_WWDG1_CLK_DISABLE +#define __HAL_RCC_WWDG_CLK_ENABLE __HAL_RCC_WWDG1_CLK_ENABLE +#define __HAL_RCC_WWDG_CLK_SLEEP_DISABLE __HAL_RCC_WWDG1_CLK_SLEEP_DISABLE +#define __HAL_RCC_WWDG_CLK_SLEEP_ENABLE __HAL_RCC_WWDG1_CLK_SLEEP_ENABLE + +#define __HAL_RCC_WWDG_FORCE_RESET ((void)0U) /* Not available on the STM32H7*/ +#define __HAL_RCC_WWDG_RELEASE_RESET ((void)0U) /* Not available on the STM32H7*/ + + +#define __HAL_RCC_WWDG_IS_CLK_ENABLED __HAL_RCC_WWDG1_IS_CLK_ENABLED +#define __HAL_RCC_WWDG_IS_CLK_DISABLED __HAL_RCC_WWDG1_IS_CLK_DISABLED +#endif + +#define __WWDG_CLK_DISABLE __HAL_RCC_WWDG_CLK_DISABLE +#define __WWDG_CLK_ENABLE __HAL_RCC_WWDG_CLK_ENABLE +#define __WWDG_CLK_SLEEP_DISABLE __HAL_RCC_WWDG_CLK_SLEEP_DISABLE +#define __WWDG_CLK_SLEEP_ENABLE __HAL_RCC_WWDG_CLK_SLEEP_ENABLE +#define __WWDG_FORCE_RESET __HAL_RCC_WWDG_FORCE_RESET +#define __WWDG_RELEASE_RESET __HAL_RCC_WWDG_RELEASE_RESET + +#define __TIM21_CLK_ENABLE __HAL_RCC_TIM21_CLK_ENABLE +#define __TIM21_CLK_DISABLE __HAL_RCC_TIM21_CLK_DISABLE +#define __TIM21_FORCE_RESET __HAL_RCC_TIM21_FORCE_RESET +#define __TIM21_RELEASE_RESET __HAL_RCC_TIM21_RELEASE_RESET +#define __TIM21_CLK_SLEEP_ENABLE __HAL_RCC_TIM21_CLK_SLEEP_ENABLE +#define __TIM21_CLK_SLEEP_DISABLE __HAL_RCC_TIM21_CLK_SLEEP_DISABLE +#define __TIM22_CLK_ENABLE __HAL_RCC_TIM22_CLK_ENABLE +#define __TIM22_CLK_DISABLE __HAL_RCC_TIM22_CLK_DISABLE +#define __TIM22_FORCE_RESET __HAL_RCC_TIM22_FORCE_RESET +#define __TIM22_RELEASE_RESET __HAL_RCC_TIM22_RELEASE_RESET +#define __TIM22_CLK_SLEEP_ENABLE __HAL_RCC_TIM22_CLK_SLEEP_ENABLE +#define __TIM22_CLK_SLEEP_DISABLE __HAL_RCC_TIM22_CLK_SLEEP_DISABLE +#define __CRS_CLK_DISABLE __HAL_RCC_CRS_CLK_DISABLE +#define __CRS_CLK_ENABLE __HAL_RCC_CRS_CLK_ENABLE +#define __CRS_CLK_SLEEP_DISABLE __HAL_RCC_CRS_CLK_SLEEP_DISABLE +#define __CRS_CLK_SLEEP_ENABLE __HAL_RCC_CRS_CLK_SLEEP_ENABLE +#define __CRS_FORCE_RESET __HAL_RCC_CRS_FORCE_RESET +#define __CRS_RELEASE_RESET __HAL_RCC_CRS_RELEASE_RESET +#define __RCC_BACKUPRESET_FORCE __HAL_RCC_BACKUPRESET_FORCE +#define __RCC_BACKUPRESET_RELEASE __HAL_RCC_BACKUPRESET_RELEASE + +#define __USB_OTG_FS_FORCE_RESET __HAL_RCC_USB_OTG_FS_FORCE_RESET +#define __USB_OTG_FS_RELEASE_RESET __HAL_RCC_USB_OTG_FS_RELEASE_RESET +#define __USB_OTG_FS_CLK_SLEEP_ENABLE __HAL_RCC_USB_OTG_FS_CLK_SLEEP_ENABLE +#define __USB_OTG_FS_CLK_SLEEP_DISABLE __HAL_RCC_USB_OTG_FS_CLK_SLEEP_DISABLE +#define __USB_OTG_HS_CLK_DISABLE __HAL_RCC_USB_OTG_HS_CLK_DISABLE +#define __USB_OTG_HS_CLK_ENABLE __HAL_RCC_USB_OTG_HS_CLK_ENABLE +#define __USB_OTG_HS_ULPI_CLK_ENABLE __HAL_RCC_USB_OTG_HS_ULPI_CLK_ENABLE +#define __USB_OTG_HS_ULPI_CLK_DISABLE __HAL_RCC_USB_OTG_HS_ULPI_CLK_DISABLE +#define __TIM9_CLK_SLEEP_ENABLE __HAL_RCC_TIM9_CLK_SLEEP_ENABLE +#define __TIM9_CLK_SLEEP_DISABLE __HAL_RCC_TIM9_CLK_SLEEP_DISABLE +#define __TIM10_CLK_SLEEP_ENABLE __HAL_RCC_TIM10_CLK_SLEEP_ENABLE +#define __TIM10_CLK_SLEEP_DISABLE __HAL_RCC_TIM10_CLK_SLEEP_DISABLE +#define __TIM11_CLK_SLEEP_ENABLE __HAL_RCC_TIM11_CLK_SLEEP_ENABLE +#define __TIM11_CLK_SLEEP_DISABLE __HAL_RCC_TIM11_CLK_SLEEP_DISABLE +#define __ETHMACPTP_CLK_SLEEP_ENABLE __HAL_RCC_ETHMACPTP_CLK_SLEEP_ENABLE +#define __ETHMACPTP_CLK_SLEEP_DISABLE __HAL_RCC_ETHMACPTP_CLK_SLEEP_DISABLE +#define __ETHMACPTP_CLK_ENABLE __HAL_RCC_ETHMACPTP_CLK_ENABLE +#define __ETHMACPTP_CLK_DISABLE __HAL_RCC_ETHMACPTP_CLK_DISABLE +#define __HASH_CLK_ENABLE __HAL_RCC_HASH_CLK_ENABLE +#define __HASH_FORCE_RESET __HAL_RCC_HASH_FORCE_RESET +#define __HASH_RELEASE_RESET __HAL_RCC_HASH_RELEASE_RESET +#define __HASH_CLK_SLEEP_ENABLE __HAL_RCC_HASH_CLK_SLEEP_ENABLE +#define __HASH_CLK_SLEEP_DISABLE __HAL_RCC_HASH_CLK_SLEEP_DISABLE +#define __HASH_CLK_DISABLE __HAL_RCC_HASH_CLK_DISABLE +#define __SPI5_CLK_ENABLE __HAL_RCC_SPI5_CLK_ENABLE +#define __SPI5_CLK_DISABLE __HAL_RCC_SPI5_CLK_DISABLE +#define __SPI5_FORCE_RESET __HAL_RCC_SPI5_FORCE_RESET +#define __SPI5_RELEASE_RESET __HAL_RCC_SPI5_RELEASE_RESET +#define __SPI5_CLK_SLEEP_ENABLE __HAL_RCC_SPI5_CLK_SLEEP_ENABLE +#define __SPI5_CLK_SLEEP_DISABLE __HAL_RCC_SPI5_CLK_SLEEP_DISABLE +#define __SPI6_CLK_ENABLE __HAL_RCC_SPI6_CLK_ENABLE +#define __SPI6_CLK_DISABLE __HAL_RCC_SPI6_CLK_DISABLE +#define __SPI6_FORCE_RESET __HAL_RCC_SPI6_FORCE_RESET +#define __SPI6_RELEASE_RESET __HAL_RCC_SPI6_RELEASE_RESET +#define __SPI6_CLK_SLEEP_ENABLE __HAL_RCC_SPI6_CLK_SLEEP_ENABLE +#define __SPI6_CLK_SLEEP_DISABLE __HAL_RCC_SPI6_CLK_SLEEP_DISABLE +#define __LTDC_CLK_ENABLE __HAL_RCC_LTDC_CLK_ENABLE +#define __LTDC_CLK_DISABLE __HAL_RCC_LTDC_CLK_DISABLE +#define __LTDC_FORCE_RESET __HAL_RCC_LTDC_FORCE_RESET +#define __LTDC_RELEASE_RESET __HAL_RCC_LTDC_RELEASE_RESET +#define __LTDC_CLK_SLEEP_ENABLE __HAL_RCC_LTDC_CLK_SLEEP_ENABLE +#define __ETHMAC_CLK_SLEEP_ENABLE __HAL_RCC_ETHMAC_CLK_SLEEP_ENABLE +#define __ETHMAC_CLK_SLEEP_DISABLE __HAL_RCC_ETHMAC_CLK_SLEEP_DISABLE +#define __ETHMACTX_CLK_SLEEP_ENABLE __HAL_RCC_ETHMACTX_CLK_SLEEP_ENABLE +#define __ETHMACTX_CLK_SLEEP_DISABLE __HAL_RCC_ETHMACTX_CLK_SLEEP_DISABLE +#define __ETHMACRX_CLK_SLEEP_ENABLE __HAL_RCC_ETHMACRX_CLK_SLEEP_ENABLE +#define __ETHMACRX_CLK_SLEEP_DISABLE __HAL_RCC_ETHMACRX_CLK_SLEEP_DISABLE +#define __TIM12_CLK_SLEEP_ENABLE __HAL_RCC_TIM12_CLK_SLEEP_ENABLE +#define __TIM12_CLK_SLEEP_DISABLE __HAL_RCC_TIM12_CLK_SLEEP_DISABLE +#define __TIM13_CLK_SLEEP_ENABLE __HAL_RCC_TIM13_CLK_SLEEP_ENABLE +#define __TIM13_CLK_SLEEP_DISABLE __HAL_RCC_TIM13_CLK_SLEEP_DISABLE +#define __TIM14_CLK_SLEEP_ENABLE __HAL_RCC_TIM14_CLK_SLEEP_ENABLE +#define __TIM14_CLK_SLEEP_DISABLE __HAL_RCC_TIM14_CLK_SLEEP_DISABLE +#define __BKPSRAM_CLK_ENABLE __HAL_RCC_BKPSRAM_CLK_ENABLE +#define __BKPSRAM_CLK_DISABLE __HAL_RCC_BKPSRAM_CLK_DISABLE +#define __BKPSRAM_CLK_SLEEP_ENABLE __HAL_RCC_BKPSRAM_CLK_SLEEP_ENABLE +#define __BKPSRAM_CLK_SLEEP_DISABLE __HAL_RCC_BKPSRAM_CLK_SLEEP_DISABLE +#define __CCMDATARAMEN_CLK_ENABLE __HAL_RCC_CCMDATARAMEN_CLK_ENABLE +#define __CCMDATARAMEN_CLK_DISABLE __HAL_RCC_CCMDATARAMEN_CLK_DISABLE +#define __USART6_CLK_ENABLE __HAL_RCC_USART6_CLK_ENABLE +#define __USART6_CLK_DISABLE __HAL_RCC_USART6_CLK_DISABLE +#define __USART6_FORCE_RESET __HAL_RCC_USART6_FORCE_RESET +#define __USART6_RELEASE_RESET __HAL_RCC_USART6_RELEASE_RESET +#define __USART6_CLK_SLEEP_ENABLE __HAL_RCC_USART6_CLK_SLEEP_ENABLE +#define __USART6_CLK_SLEEP_DISABLE __HAL_RCC_USART6_CLK_SLEEP_DISABLE +#define __SPI4_CLK_ENABLE __HAL_RCC_SPI4_CLK_ENABLE +#define __SPI4_CLK_DISABLE __HAL_RCC_SPI4_CLK_DISABLE +#define __SPI4_FORCE_RESET __HAL_RCC_SPI4_FORCE_RESET +#define __SPI4_RELEASE_RESET __HAL_RCC_SPI4_RELEASE_RESET +#define __SPI4_CLK_SLEEP_ENABLE __HAL_RCC_SPI4_CLK_SLEEP_ENABLE +#define __SPI4_CLK_SLEEP_DISABLE __HAL_RCC_SPI4_CLK_SLEEP_DISABLE +#define __GPIOI_CLK_ENABLE __HAL_RCC_GPIOI_CLK_ENABLE +#define __GPIOI_CLK_DISABLE __HAL_RCC_GPIOI_CLK_DISABLE +#define __GPIOI_FORCE_RESET __HAL_RCC_GPIOI_FORCE_RESET +#define __GPIOI_RELEASE_RESET __HAL_RCC_GPIOI_RELEASE_RESET +#define __GPIOI_CLK_SLEEP_ENABLE __HAL_RCC_GPIOI_CLK_SLEEP_ENABLE +#define __GPIOI_CLK_SLEEP_DISABLE __HAL_RCC_GPIOI_CLK_SLEEP_DISABLE +#define __GPIOJ_CLK_ENABLE __HAL_RCC_GPIOJ_CLK_ENABLE +#define __GPIOJ_CLK_DISABLE __HAL_RCC_GPIOJ_CLK_DISABLE +#define __GPIOJ_FORCE_RESET __HAL_RCC_GPIOJ_FORCE_RESET +#define __GPIOJ_RELEASE_RESET __HAL_RCC_GPIOJ_RELEASE_RESET +#define __GPIOJ_CLK_SLEEP_ENABLE __HAL_RCC_GPIOJ_CLK_SLEEP_ENABLE +#define __GPIOJ_CLK_SLEEP_DISABLE __HAL_RCC_GPIOJ_CLK_SLEEP_DISABLE +#define __GPIOK_CLK_ENABLE __HAL_RCC_GPIOK_CLK_ENABLE +#define __GPIOK_CLK_DISABLE __HAL_RCC_GPIOK_CLK_DISABLE +#define __GPIOK_RELEASE_RESET __HAL_RCC_GPIOK_RELEASE_RESET +#define __GPIOK_CLK_SLEEP_ENABLE __HAL_RCC_GPIOK_CLK_SLEEP_ENABLE +#define __GPIOK_CLK_SLEEP_DISABLE __HAL_RCC_GPIOK_CLK_SLEEP_DISABLE +#define __ETH_CLK_ENABLE __HAL_RCC_ETH_CLK_ENABLE +#define __ETH_CLK_DISABLE __HAL_RCC_ETH_CLK_DISABLE +#define __DCMI_CLK_ENABLE __HAL_RCC_DCMI_CLK_ENABLE +#define __DCMI_CLK_DISABLE __HAL_RCC_DCMI_CLK_DISABLE +#define __DCMI_FORCE_RESET __HAL_RCC_DCMI_FORCE_RESET +#define __DCMI_RELEASE_RESET __HAL_RCC_DCMI_RELEASE_RESET +#define __DCMI_CLK_SLEEP_ENABLE __HAL_RCC_DCMI_CLK_SLEEP_ENABLE +#define __DCMI_CLK_SLEEP_DISABLE __HAL_RCC_DCMI_CLK_SLEEP_DISABLE +#define __UART7_CLK_ENABLE __HAL_RCC_UART7_CLK_ENABLE +#define __UART7_CLK_DISABLE __HAL_RCC_UART7_CLK_DISABLE +#define __UART7_RELEASE_RESET __HAL_RCC_UART7_RELEASE_RESET +#define __UART7_FORCE_RESET __HAL_RCC_UART7_FORCE_RESET +#define __UART7_CLK_SLEEP_ENABLE __HAL_RCC_UART7_CLK_SLEEP_ENABLE +#define __UART7_CLK_SLEEP_DISABLE __HAL_RCC_UART7_CLK_SLEEP_DISABLE +#define __UART8_CLK_ENABLE __HAL_RCC_UART8_CLK_ENABLE +#define __UART8_CLK_DISABLE __HAL_RCC_UART8_CLK_DISABLE +#define __UART8_FORCE_RESET __HAL_RCC_UART8_FORCE_RESET +#define __UART8_RELEASE_RESET __HAL_RCC_UART8_RELEASE_RESET +#define __UART8_CLK_SLEEP_ENABLE __HAL_RCC_UART8_CLK_SLEEP_ENABLE +#define __UART8_CLK_SLEEP_DISABLE __HAL_RCC_UART8_CLK_SLEEP_DISABLE +#define __OTGHS_CLK_SLEEP_ENABLE __HAL_RCC_USB_OTG_HS_CLK_SLEEP_ENABLE +#define __OTGHS_CLK_SLEEP_DISABLE __HAL_RCC_USB_OTG_HS_CLK_SLEEP_DISABLE +#define __OTGHS_FORCE_RESET __HAL_RCC_USB_OTG_HS_FORCE_RESET +#define __OTGHS_RELEASE_RESET __HAL_RCC_USB_OTG_HS_RELEASE_RESET +#define __OTGHSULPI_CLK_SLEEP_ENABLE __HAL_RCC_USB_OTG_HS_ULPI_CLK_SLEEP_ENABLE +#define __OTGHSULPI_CLK_SLEEP_DISABLE __HAL_RCC_USB_OTG_HS_ULPI_CLK_SLEEP_DISABLE +#define __HAL_RCC_OTGHS_CLK_SLEEP_ENABLE __HAL_RCC_USB_OTG_HS_CLK_SLEEP_ENABLE +#define __HAL_RCC_OTGHS_CLK_SLEEP_DISABLE __HAL_RCC_USB_OTG_HS_CLK_SLEEP_DISABLE +#define __HAL_RCC_OTGHS_IS_CLK_SLEEP_ENABLED __HAL_RCC_USB_OTG_HS_IS_CLK_SLEEP_ENABLED +#define __HAL_RCC_OTGHS_IS_CLK_SLEEP_DISABLED __HAL_RCC_USB_OTG_HS_IS_CLK_SLEEP_DISABLED +#define __HAL_RCC_OTGHS_FORCE_RESET __HAL_RCC_USB_OTG_HS_FORCE_RESET +#define __HAL_RCC_OTGHS_RELEASE_RESET __HAL_RCC_USB_OTG_HS_RELEASE_RESET +#define __HAL_RCC_OTGHSULPI_CLK_SLEEP_ENABLE __HAL_RCC_USB_OTG_HS_ULPI_CLK_SLEEP_ENABLE +#define __HAL_RCC_OTGHSULPI_CLK_SLEEP_DISABLE __HAL_RCC_USB_OTG_HS_ULPI_CLK_SLEEP_DISABLE +#define __HAL_RCC_OTGHSULPI_IS_CLK_SLEEP_ENABLED __HAL_RCC_USB_OTG_HS_ULPI_IS_CLK_SLEEP_ENABLED +#define __HAL_RCC_OTGHSULPI_IS_CLK_SLEEP_DISABLED __HAL_RCC_USB_OTG_HS_ULPI_IS_CLK_SLEEP_DISABLED +#define __SRAM3_CLK_SLEEP_ENABLE __HAL_RCC_SRAM3_CLK_SLEEP_ENABLE +#define __CAN2_CLK_SLEEP_ENABLE __HAL_RCC_CAN2_CLK_SLEEP_ENABLE +#define __CAN2_CLK_SLEEP_DISABLE __HAL_RCC_CAN2_CLK_SLEEP_DISABLE +#define __DAC_CLK_SLEEP_ENABLE __HAL_RCC_DAC_CLK_SLEEP_ENABLE +#define __DAC_CLK_SLEEP_DISABLE __HAL_RCC_DAC_CLK_SLEEP_DISABLE +#define __ADC2_CLK_SLEEP_ENABLE __HAL_RCC_ADC2_CLK_SLEEP_ENABLE +#define __ADC2_CLK_SLEEP_DISABLE __HAL_RCC_ADC2_CLK_SLEEP_DISABLE +#define __ADC3_CLK_SLEEP_ENABLE __HAL_RCC_ADC3_CLK_SLEEP_ENABLE +#define __ADC3_CLK_SLEEP_DISABLE __HAL_RCC_ADC3_CLK_SLEEP_DISABLE +#define __FSMC_FORCE_RESET __HAL_RCC_FSMC_FORCE_RESET +#define __FSMC_RELEASE_RESET __HAL_RCC_FSMC_RELEASE_RESET +#define __FSMC_CLK_SLEEP_ENABLE __HAL_RCC_FSMC_CLK_SLEEP_ENABLE +#define __FSMC_CLK_SLEEP_DISABLE __HAL_RCC_FSMC_CLK_SLEEP_DISABLE +#define __SDIO_FORCE_RESET __HAL_RCC_SDIO_FORCE_RESET +#define __SDIO_RELEASE_RESET __HAL_RCC_SDIO_RELEASE_RESET +#define __SDIO_CLK_SLEEP_DISABLE __HAL_RCC_SDIO_CLK_SLEEP_DISABLE +#define __SDIO_CLK_SLEEP_ENABLE __HAL_RCC_SDIO_CLK_SLEEP_ENABLE +#define __DMA2D_CLK_ENABLE __HAL_RCC_DMA2D_CLK_ENABLE +#define __DMA2D_CLK_DISABLE __HAL_RCC_DMA2D_CLK_DISABLE +#define __DMA2D_FORCE_RESET __HAL_RCC_DMA2D_FORCE_RESET +#define __DMA2D_RELEASE_RESET __HAL_RCC_DMA2D_RELEASE_RESET +#define __DMA2D_CLK_SLEEP_ENABLE __HAL_RCC_DMA2D_CLK_SLEEP_ENABLE +#define __DMA2D_CLK_SLEEP_DISABLE __HAL_RCC_DMA2D_CLK_SLEEP_DISABLE + +/* alias define maintained for legacy */ +#define __HAL_RCC_OTGFS_FORCE_RESET __HAL_RCC_USB_OTG_FS_FORCE_RESET +#define __HAL_RCC_OTGFS_RELEASE_RESET __HAL_RCC_USB_OTG_FS_RELEASE_RESET + +#define __ADC12_CLK_ENABLE __HAL_RCC_ADC12_CLK_ENABLE +#define __ADC12_CLK_DISABLE __HAL_RCC_ADC12_CLK_DISABLE +#define __ADC34_CLK_ENABLE __HAL_RCC_ADC34_CLK_ENABLE +#define __ADC34_CLK_DISABLE __HAL_RCC_ADC34_CLK_DISABLE +#define __DAC2_CLK_ENABLE __HAL_RCC_DAC2_CLK_ENABLE +#define __DAC2_CLK_DISABLE __HAL_RCC_DAC2_CLK_DISABLE +#define __TIM18_CLK_ENABLE __HAL_RCC_TIM18_CLK_ENABLE +#define __TIM18_CLK_DISABLE __HAL_RCC_TIM18_CLK_DISABLE +#define __TIM19_CLK_ENABLE __HAL_RCC_TIM19_CLK_ENABLE +#define __TIM19_CLK_DISABLE __HAL_RCC_TIM19_CLK_DISABLE +#define __TIM20_CLK_ENABLE __HAL_RCC_TIM20_CLK_ENABLE +#define __TIM20_CLK_DISABLE __HAL_RCC_TIM20_CLK_DISABLE +#define __HRTIM1_CLK_ENABLE __HAL_RCC_HRTIM1_CLK_ENABLE +#define __HRTIM1_CLK_DISABLE __HAL_RCC_HRTIM1_CLK_DISABLE +#define __SDADC1_CLK_ENABLE __HAL_RCC_SDADC1_CLK_ENABLE +#define __SDADC2_CLK_ENABLE __HAL_RCC_SDADC2_CLK_ENABLE +#define __SDADC3_CLK_ENABLE __HAL_RCC_SDADC3_CLK_ENABLE +#define __SDADC1_CLK_DISABLE __HAL_RCC_SDADC1_CLK_DISABLE +#define __SDADC2_CLK_DISABLE __HAL_RCC_SDADC2_CLK_DISABLE +#define __SDADC3_CLK_DISABLE __HAL_RCC_SDADC3_CLK_DISABLE + +#define __ADC12_FORCE_RESET __HAL_RCC_ADC12_FORCE_RESET +#define __ADC12_RELEASE_RESET __HAL_RCC_ADC12_RELEASE_RESET +#define __ADC34_FORCE_RESET __HAL_RCC_ADC34_FORCE_RESET +#define __ADC34_RELEASE_RESET __HAL_RCC_ADC34_RELEASE_RESET +#define __DAC2_FORCE_RESET __HAL_RCC_DAC2_FORCE_RESET +#define __DAC2_RELEASE_RESET __HAL_RCC_DAC2_RELEASE_RESET +#define __TIM18_FORCE_RESET __HAL_RCC_TIM18_FORCE_RESET +#define __TIM18_RELEASE_RESET __HAL_RCC_TIM18_RELEASE_RESET +#define __TIM19_FORCE_RESET __HAL_RCC_TIM19_FORCE_RESET +#define __TIM19_RELEASE_RESET __HAL_RCC_TIM19_RELEASE_RESET +#define __TIM20_FORCE_RESET __HAL_RCC_TIM20_FORCE_RESET +#define __TIM20_RELEASE_RESET __HAL_RCC_TIM20_RELEASE_RESET +#define __HRTIM1_FORCE_RESET __HAL_RCC_HRTIM1_FORCE_RESET +#define __HRTIM1_RELEASE_RESET __HAL_RCC_HRTIM1_RELEASE_RESET +#define __SDADC1_FORCE_RESET __HAL_RCC_SDADC1_FORCE_RESET +#define __SDADC2_FORCE_RESET __HAL_RCC_SDADC2_FORCE_RESET +#define __SDADC3_FORCE_RESET __HAL_RCC_SDADC3_FORCE_RESET +#define __SDADC1_RELEASE_RESET __HAL_RCC_SDADC1_RELEASE_RESET +#define __SDADC2_RELEASE_RESET __HAL_RCC_SDADC2_RELEASE_RESET +#define __SDADC3_RELEASE_RESET __HAL_RCC_SDADC3_RELEASE_RESET + +#define __ADC1_IS_CLK_ENABLED __HAL_RCC_ADC1_IS_CLK_ENABLED +#define __ADC1_IS_CLK_DISABLED __HAL_RCC_ADC1_IS_CLK_DISABLED +#define __ADC12_IS_CLK_ENABLED __HAL_RCC_ADC12_IS_CLK_ENABLED +#define __ADC12_IS_CLK_DISABLED __HAL_RCC_ADC12_IS_CLK_DISABLED +#define __ADC34_IS_CLK_ENABLED __HAL_RCC_ADC34_IS_CLK_ENABLED +#define __ADC34_IS_CLK_DISABLED __HAL_RCC_ADC34_IS_CLK_DISABLED +#define __CEC_IS_CLK_ENABLED __HAL_RCC_CEC_IS_CLK_ENABLED +#define __CEC_IS_CLK_DISABLED __HAL_RCC_CEC_IS_CLK_DISABLED +#define __CRC_IS_CLK_ENABLED __HAL_RCC_CRC_IS_CLK_ENABLED +#define __CRC_IS_CLK_DISABLED __HAL_RCC_CRC_IS_CLK_DISABLED +#define __DAC1_IS_CLK_ENABLED __HAL_RCC_DAC1_IS_CLK_ENABLED +#define __DAC1_IS_CLK_DISABLED __HAL_RCC_DAC1_IS_CLK_DISABLED +#define __DAC2_IS_CLK_ENABLED __HAL_RCC_DAC2_IS_CLK_ENABLED +#define __DAC2_IS_CLK_DISABLED __HAL_RCC_DAC2_IS_CLK_DISABLED +#define __DMA1_IS_CLK_ENABLED __HAL_RCC_DMA1_IS_CLK_ENABLED +#define __DMA1_IS_CLK_DISABLED __HAL_RCC_DMA1_IS_CLK_DISABLED +#define __DMA2_IS_CLK_ENABLED __HAL_RCC_DMA2_IS_CLK_ENABLED +#define __DMA2_IS_CLK_DISABLED __HAL_RCC_DMA2_IS_CLK_DISABLED +#define __FLITF_IS_CLK_ENABLED __HAL_RCC_FLITF_IS_CLK_ENABLED +#define __FLITF_IS_CLK_DISABLED __HAL_RCC_FLITF_IS_CLK_DISABLED +#define __FMC_IS_CLK_ENABLED __HAL_RCC_FMC_IS_CLK_ENABLED +#define __FMC_IS_CLK_DISABLED __HAL_RCC_FMC_IS_CLK_DISABLED +#define __GPIOA_IS_CLK_ENABLED __HAL_RCC_GPIOA_IS_CLK_ENABLED +#define __GPIOA_IS_CLK_DISABLED __HAL_RCC_GPIOA_IS_CLK_DISABLED +#define __GPIOB_IS_CLK_ENABLED __HAL_RCC_GPIOB_IS_CLK_ENABLED +#define __GPIOB_IS_CLK_DISABLED __HAL_RCC_GPIOB_IS_CLK_DISABLED +#define __GPIOC_IS_CLK_ENABLED __HAL_RCC_GPIOC_IS_CLK_ENABLED +#define __GPIOC_IS_CLK_DISABLED __HAL_RCC_GPIOC_IS_CLK_DISABLED +#define __GPIOD_IS_CLK_ENABLED __HAL_RCC_GPIOD_IS_CLK_ENABLED +#define __GPIOD_IS_CLK_DISABLED __HAL_RCC_GPIOD_IS_CLK_DISABLED +#define __GPIOE_IS_CLK_ENABLED __HAL_RCC_GPIOE_IS_CLK_ENABLED +#define __GPIOE_IS_CLK_DISABLED __HAL_RCC_GPIOE_IS_CLK_DISABLED +#define __GPIOF_IS_CLK_ENABLED __HAL_RCC_GPIOF_IS_CLK_ENABLED +#define __GPIOF_IS_CLK_DISABLED __HAL_RCC_GPIOF_IS_CLK_DISABLED +#define __GPIOG_IS_CLK_ENABLED __HAL_RCC_GPIOG_IS_CLK_ENABLED +#define __GPIOG_IS_CLK_DISABLED __HAL_RCC_GPIOG_IS_CLK_DISABLED +#define __GPIOH_IS_CLK_ENABLED __HAL_RCC_GPIOH_IS_CLK_ENABLED +#define __GPIOH_IS_CLK_DISABLED __HAL_RCC_GPIOH_IS_CLK_DISABLED +#define __HRTIM1_IS_CLK_ENABLED __HAL_RCC_HRTIM1_IS_CLK_ENABLED +#define __HRTIM1_IS_CLK_DISABLED __HAL_RCC_HRTIM1_IS_CLK_DISABLED +#define __I2C1_IS_CLK_ENABLED __HAL_RCC_I2C1_IS_CLK_ENABLED +#define __I2C1_IS_CLK_DISABLED __HAL_RCC_I2C1_IS_CLK_DISABLED +#define __I2C2_IS_CLK_ENABLED __HAL_RCC_I2C2_IS_CLK_ENABLED +#define __I2C2_IS_CLK_DISABLED __HAL_RCC_I2C2_IS_CLK_DISABLED +#define __I2C3_IS_CLK_ENABLED __HAL_RCC_I2C3_IS_CLK_ENABLED +#define __I2C3_IS_CLK_DISABLED __HAL_RCC_I2C3_IS_CLK_DISABLED +#define __PWR_IS_CLK_ENABLED __HAL_RCC_PWR_IS_CLK_ENABLED +#define __PWR_IS_CLK_DISABLED __HAL_RCC_PWR_IS_CLK_DISABLED +#define __SYSCFG_IS_CLK_ENABLED __HAL_RCC_SYSCFG_IS_CLK_ENABLED +#define __SYSCFG_IS_CLK_DISABLED __HAL_RCC_SYSCFG_IS_CLK_DISABLED +#define __SPI1_IS_CLK_ENABLED __HAL_RCC_SPI1_IS_CLK_ENABLED +#define __SPI1_IS_CLK_DISABLED __HAL_RCC_SPI1_IS_CLK_DISABLED +#define __SPI2_IS_CLK_ENABLED __HAL_RCC_SPI2_IS_CLK_ENABLED +#define __SPI2_IS_CLK_DISABLED __HAL_RCC_SPI2_IS_CLK_DISABLED +#define __SPI3_IS_CLK_ENABLED __HAL_RCC_SPI3_IS_CLK_ENABLED +#define __SPI3_IS_CLK_DISABLED __HAL_RCC_SPI3_IS_CLK_DISABLED +#define __SPI4_IS_CLK_ENABLED __HAL_RCC_SPI4_IS_CLK_ENABLED +#define __SPI4_IS_CLK_DISABLED __HAL_RCC_SPI4_IS_CLK_DISABLED +#define __SDADC1_IS_CLK_ENABLED __HAL_RCC_SDADC1_IS_CLK_ENABLED +#define __SDADC1_IS_CLK_DISABLED __HAL_RCC_SDADC1_IS_CLK_DISABLED +#define __SDADC2_IS_CLK_ENABLED __HAL_RCC_SDADC2_IS_CLK_ENABLED +#define __SDADC2_IS_CLK_DISABLED __HAL_RCC_SDADC2_IS_CLK_DISABLED +#define __SDADC3_IS_CLK_ENABLED __HAL_RCC_SDADC3_IS_CLK_ENABLED +#define __SDADC3_IS_CLK_DISABLED __HAL_RCC_SDADC3_IS_CLK_DISABLED +#define __SRAM_IS_CLK_ENABLED __HAL_RCC_SRAM_IS_CLK_ENABLED +#define __SRAM_IS_CLK_DISABLED __HAL_RCC_SRAM_IS_CLK_DISABLED +#define __TIM1_IS_CLK_ENABLED __HAL_RCC_TIM1_IS_CLK_ENABLED +#define __TIM1_IS_CLK_DISABLED __HAL_RCC_TIM1_IS_CLK_DISABLED +#define __TIM2_IS_CLK_ENABLED __HAL_RCC_TIM2_IS_CLK_ENABLED +#define __TIM2_IS_CLK_DISABLED __HAL_RCC_TIM2_IS_CLK_DISABLED +#define __TIM3_IS_CLK_ENABLED __HAL_RCC_TIM3_IS_CLK_ENABLED +#define __TIM3_IS_CLK_DISABLED __HAL_RCC_TIM3_IS_CLK_DISABLED +#define __TIM4_IS_CLK_ENABLED __HAL_RCC_TIM4_IS_CLK_ENABLED +#define __TIM4_IS_CLK_DISABLED __HAL_RCC_TIM4_IS_CLK_DISABLED +#define __TIM5_IS_CLK_ENABLED __HAL_RCC_TIM5_IS_CLK_ENABLED +#define __TIM5_IS_CLK_DISABLED __HAL_RCC_TIM5_IS_CLK_DISABLED +#define __TIM6_IS_CLK_ENABLED __HAL_RCC_TIM6_IS_CLK_ENABLED +#define __TIM6_IS_CLK_DISABLED __HAL_RCC_TIM6_IS_CLK_DISABLED +#define __TIM7_IS_CLK_ENABLED __HAL_RCC_TIM7_IS_CLK_ENABLED +#define __TIM7_IS_CLK_DISABLED __HAL_RCC_TIM7_IS_CLK_DISABLED +#define __TIM8_IS_CLK_ENABLED __HAL_RCC_TIM8_IS_CLK_ENABLED +#define __TIM8_IS_CLK_DISABLED __HAL_RCC_TIM8_IS_CLK_DISABLED +#define __TIM12_IS_CLK_ENABLED __HAL_RCC_TIM12_IS_CLK_ENABLED +#define __TIM12_IS_CLK_DISABLED __HAL_RCC_TIM12_IS_CLK_DISABLED +#define __TIM13_IS_CLK_ENABLED __HAL_RCC_TIM13_IS_CLK_ENABLED +#define __TIM13_IS_CLK_DISABLED __HAL_RCC_TIM13_IS_CLK_DISABLED +#define __TIM14_IS_CLK_ENABLED __HAL_RCC_TIM14_IS_CLK_ENABLED +#define __TIM14_IS_CLK_DISABLED __HAL_RCC_TIM14_IS_CLK_DISABLED +#define __TIM15_IS_CLK_ENABLED __HAL_RCC_TIM15_IS_CLK_ENABLED +#define __TIM15_IS_CLK_DISABLED __HAL_RCC_TIM15_IS_CLK_DISABLED +#define __TIM16_IS_CLK_ENABLED __HAL_RCC_TIM16_IS_CLK_ENABLED +#define __TIM16_IS_CLK_DISABLED __HAL_RCC_TIM16_IS_CLK_DISABLED +#define __TIM17_IS_CLK_ENABLED __HAL_RCC_TIM17_IS_CLK_ENABLED +#define __TIM17_IS_CLK_DISABLED __HAL_RCC_TIM17_IS_CLK_DISABLED +#define __TIM18_IS_CLK_ENABLED __HAL_RCC_TIM18_IS_CLK_ENABLED +#define __TIM18_IS_CLK_DISABLED __HAL_RCC_TIM18_IS_CLK_DISABLED +#define __TIM19_IS_CLK_ENABLED __HAL_RCC_TIM19_IS_CLK_ENABLED +#define __TIM19_IS_CLK_DISABLED __HAL_RCC_TIM19_IS_CLK_DISABLED +#define __TIM20_IS_CLK_ENABLED __HAL_RCC_TIM20_IS_CLK_ENABLED +#define __TIM20_IS_CLK_DISABLED __HAL_RCC_TIM20_IS_CLK_DISABLED +#define __TSC_IS_CLK_ENABLED __HAL_RCC_TSC_IS_CLK_ENABLED +#define __TSC_IS_CLK_DISABLED __HAL_RCC_TSC_IS_CLK_DISABLED +#define __UART4_IS_CLK_ENABLED __HAL_RCC_UART4_IS_CLK_ENABLED +#define __UART4_IS_CLK_DISABLED __HAL_RCC_UART4_IS_CLK_DISABLED +#define __UART5_IS_CLK_ENABLED __HAL_RCC_UART5_IS_CLK_ENABLED +#define __UART5_IS_CLK_DISABLED __HAL_RCC_UART5_IS_CLK_DISABLED +#define __USART1_IS_CLK_ENABLED __HAL_RCC_USART1_IS_CLK_ENABLED +#define __USART1_IS_CLK_DISABLED __HAL_RCC_USART1_IS_CLK_DISABLED +#define __USART2_IS_CLK_ENABLED __HAL_RCC_USART2_IS_CLK_ENABLED +#define __USART2_IS_CLK_DISABLED __HAL_RCC_USART2_IS_CLK_DISABLED +#define __USART3_IS_CLK_ENABLED __HAL_RCC_USART3_IS_CLK_ENABLED +#define __USART3_IS_CLK_DISABLED __HAL_RCC_USART3_IS_CLK_DISABLED +#define __USB_IS_CLK_ENABLED __HAL_RCC_USB_IS_CLK_ENABLED +#define __USB_IS_CLK_DISABLED __HAL_RCC_USB_IS_CLK_DISABLED +#define __WWDG_IS_CLK_ENABLED __HAL_RCC_WWDG_IS_CLK_ENABLED +#define __WWDG_IS_CLK_DISABLED __HAL_RCC_WWDG_IS_CLK_DISABLED + +#if defined(STM32L1) +#define __HAL_RCC_CRYP_CLK_DISABLE __HAL_RCC_AES_CLK_DISABLE +#define __HAL_RCC_CRYP_CLK_ENABLE __HAL_RCC_AES_CLK_ENABLE +#define __HAL_RCC_CRYP_CLK_SLEEP_DISABLE __HAL_RCC_AES_CLK_SLEEP_DISABLE +#define __HAL_RCC_CRYP_CLK_SLEEP_ENABLE __HAL_RCC_AES_CLK_SLEEP_ENABLE +#define __HAL_RCC_CRYP_FORCE_RESET __HAL_RCC_AES_FORCE_RESET +#define __HAL_RCC_CRYP_RELEASE_RESET __HAL_RCC_AES_RELEASE_RESET +#endif /* STM32L1 */ + +#if defined(STM32F4) +#define __HAL_RCC_SDMMC1_FORCE_RESET __HAL_RCC_SDIO_FORCE_RESET +#define __HAL_RCC_SDMMC1_RELEASE_RESET __HAL_RCC_SDIO_RELEASE_RESET +#define __HAL_RCC_SDMMC1_CLK_SLEEP_ENABLE __HAL_RCC_SDIO_CLK_SLEEP_ENABLE +#define __HAL_RCC_SDMMC1_CLK_SLEEP_DISABLE __HAL_RCC_SDIO_CLK_SLEEP_DISABLE +#define __HAL_RCC_SDMMC1_CLK_ENABLE __HAL_RCC_SDIO_CLK_ENABLE +#define __HAL_RCC_SDMMC1_CLK_DISABLE __HAL_RCC_SDIO_CLK_DISABLE +#define __HAL_RCC_SDMMC1_IS_CLK_ENABLED __HAL_RCC_SDIO_IS_CLK_ENABLED +#define __HAL_RCC_SDMMC1_IS_CLK_DISABLED __HAL_RCC_SDIO_IS_CLK_DISABLED +#define Sdmmc1ClockSelection SdioClockSelection +#define RCC_PERIPHCLK_SDMMC1 RCC_PERIPHCLK_SDIO +#define RCC_SDMMC1CLKSOURCE_CLK48 RCC_SDIOCLKSOURCE_CK48 +#define RCC_SDMMC1CLKSOURCE_SYSCLK RCC_SDIOCLKSOURCE_SYSCLK +#define __HAL_RCC_SDMMC1_CONFIG __HAL_RCC_SDIO_CONFIG +#define __HAL_RCC_GET_SDMMC1_SOURCE __HAL_RCC_GET_SDIO_SOURCE +#endif + +#if defined(STM32F7) || defined(STM32L4) +#define __HAL_RCC_SDIO_FORCE_RESET __HAL_RCC_SDMMC1_FORCE_RESET +#define __HAL_RCC_SDIO_RELEASE_RESET __HAL_RCC_SDMMC1_RELEASE_RESET +#define __HAL_RCC_SDIO_CLK_SLEEP_ENABLE __HAL_RCC_SDMMC1_CLK_SLEEP_ENABLE +#define __HAL_RCC_SDIO_CLK_SLEEP_DISABLE __HAL_RCC_SDMMC1_CLK_SLEEP_DISABLE +#define __HAL_RCC_SDIO_CLK_ENABLE __HAL_RCC_SDMMC1_CLK_ENABLE +#define __HAL_RCC_SDIO_CLK_DISABLE __HAL_RCC_SDMMC1_CLK_DISABLE +#define __HAL_RCC_SDIO_IS_CLK_ENABLED __HAL_RCC_SDMMC1_IS_CLK_ENABLED +#define __HAL_RCC_SDIO_IS_CLK_DISABLED __HAL_RCC_SDMMC1_IS_CLK_DISABLED +#define SdioClockSelection Sdmmc1ClockSelection +#define RCC_PERIPHCLK_SDIO RCC_PERIPHCLK_SDMMC1 +#define __HAL_RCC_SDIO_CONFIG __HAL_RCC_SDMMC1_CONFIG +#define __HAL_RCC_GET_SDIO_SOURCE __HAL_RCC_GET_SDMMC1_SOURCE +#endif + +#if defined(STM32F7) +#define RCC_SDIOCLKSOURCE_CLK48 RCC_SDMMC1CLKSOURCE_CLK48 +#define RCC_SDIOCLKSOURCE_SYSCLK RCC_SDMMC1CLKSOURCE_SYSCLK +#endif + +#if defined(STM32H7) +#define __HAL_RCC_USB_OTG_HS_CLK_ENABLE() __HAL_RCC_USB1_OTG_HS_CLK_ENABLE() +#define __HAL_RCC_USB_OTG_HS_ULPI_CLK_ENABLE() __HAL_RCC_USB1_OTG_HS_ULPI_CLK_ENABLE() +#define __HAL_RCC_USB_OTG_HS_CLK_DISABLE() __HAL_RCC_USB1_OTG_HS_CLK_DISABLE() +#define __HAL_RCC_USB_OTG_HS_ULPI_CLK_DISABLE() __HAL_RCC_USB1_OTG_HS_ULPI_CLK_DISABLE() +#define __HAL_RCC_USB_OTG_HS_FORCE_RESET() __HAL_RCC_USB1_OTG_HS_FORCE_RESET() +#define __HAL_RCC_USB_OTG_HS_RELEASE_RESET() __HAL_RCC_USB1_OTG_HS_RELEASE_RESET() +#define __HAL_RCC_USB_OTG_HS_CLK_SLEEP_ENABLE() __HAL_RCC_USB1_OTG_HS_CLK_SLEEP_ENABLE() +#define __HAL_RCC_USB_OTG_HS_ULPI_CLK_SLEEP_ENABLE() __HAL_RCC_USB1_OTG_HS_ULPI_CLK_SLEEP_ENABLE() +#define __HAL_RCC_USB_OTG_HS_CLK_SLEEP_DISABLE() __HAL_RCC_USB1_OTG_HS_CLK_SLEEP_DISABLE() +#define __HAL_RCC_USB_OTG_HS_ULPI_CLK_SLEEP_DISABLE() __HAL_RCC_USB1_OTG_HS_ULPI_CLK_SLEEP_DISABLE() + +#define __HAL_RCC_USB_OTG_FS_CLK_ENABLE() __HAL_RCC_USB2_OTG_FS_CLK_ENABLE() +#define __HAL_RCC_USB_OTG_FS_ULPI_CLK_ENABLE() __HAL_RCC_USB2_OTG_FS_ULPI_CLK_ENABLE() +#define __HAL_RCC_USB_OTG_FS_CLK_DISABLE() __HAL_RCC_USB2_OTG_FS_CLK_DISABLE() +#define __HAL_RCC_USB_OTG_FS_ULPI_CLK_DISABLE() __HAL_RCC_USB2_OTG_FS_ULPI_CLK_DISABLE() +#define __HAL_RCC_USB_OTG_FS_FORCE_RESET() __HAL_RCC_USB2_OTG_FS_FORCE_RESET() +#define __HAL_RCC_USB_OTG_FS_RELEASE_RESET() __HAL_RCC_USB2_OTG_FS_RELEASE_RESET() +#define __HAL_RCC_USB_OTG_FS_CLK_SLEEP_ENABLE() __HAL_RCC_USB2_OTG_FS_CLK_SLEEP_ENABLE() +#define __HAL_RCC_USB_OTG_FS_ULPI_CLK_SLEEP_ENABLE() __HAL_RCC_USB2_OTG_FS_ULPI_CLK_SLEEP_ENABLE() +#define __HAL_RCC_USB_OTG_FS_CLK_SLEEP_DISABLE() __HAL_RCC_USB2_OTG_FS_CLK_SLEEP_DISABLE() +#define __HAL_RCC_USB_OTG_FS_ULPI_CLK_SLEEP_DISABLE() __HAL_RCC_USB2_OTG_FS_ULPI_CLK_SLEEP_DISABLE() +#endif + +#define __HAL_RCC_I2SCLK __HAL_RCC_I2S_CONFIG +#define __HAL_RCC_I2SCLK_CONFIG __HAL_RCC_I2S_CONFIG + +#define __RCC_PLLSRC RCC_GET_PLL_OSCSOURCE + +#define IS_RCC_MSIRANGE IS_RCC_MSI_CLOCK_RANGE +#define IS_RCC_RTCCLK_SOURCE IS_RCC_RTCCLKSOURCE +#define IS_RCC_SYSCLK_DIV IS_RCC_HCLK +#define IS_RCC_HCLK_DIV IS_RCC_PCLK +#define IS_RCC_PERIPHCLK IS_RCC_PERIPHCLOCK + +#define RCC_IT_HSI14 RCC_IT_HSI14RDY + +#define RCC_IT_CSSLSE RCC_IT_LSECSS +#define RCC_IT_CSSHSE RCC_IT_CSS + +#define RCC_PLLMUL_3 RCC_PLL_MUL3 +#define RCC_PLLMUL_4 RCC_PLL_MUL4 +#define RCC_PLLMUL_6 RCC_PLL_MUL6 +#define RCC_PLLMUL_8 RCC_PLL_MUL8 +#define RCC_PLLMUL_12 RCC_PLL_MUL12 +#define RCC_PLLMUL_16 RCC_PLL_MUL16 +#define RCC_PLLMUL_24 RCC_PLL_MUL24 +#define RCC_PLLMUL_32 RCC_PLL_MUL32 +#define RCC_PLLMUL_48 RCC_PLL_MUL48 + +#define RCC_PLLDIV_2 RCC_PLL_DIV2 +#define RCC_PLLDIV_3 RCC_PLL_DIV3 +#define RCC_PLLDIV_4 RCC_PLL_DIV4 + +#define IS_RCC_MCOSOURCE IS_RCC_MCO1SOURCE +#define __HAL_RCC_MCO_CONFIG __HAL_RCC_MCO1_CONFIG +#define RCC_MCO_NODIV RCC_MCODIV_1 +#define RCC_MCO_DIV1 RCC_MCODIV_1 +#define RCC_MCO_DIV2 RCC_MCODIV_2 +#define RCC_MCO_DIV4 RCC_MCODIV_4 +#define RCC_MCO_DIV8 RCC_MCODIV_8 +#define RCC_MCO_DIV16 RCC_MCODIV_16 +#define RCC_MCO_DIV32 RCC_MCODIV_32 +#define RCC_MCO_DIV64 RCC_MCODIV_64 +#define RCC_MCO_DIV128 RCC_MCODIV_128 +#define RCC_MCOSOURCE_NONE RCC_MCO1SOURCE_NOCLOCK +#define RCC_MCOSOURCE_LSI RCC_MCO1SOURCE_LSI +#define RCC_MCOSOURCE_LSE RCC_MCO1SOURCE_LSE +#define RCC_MCOSOURCE_SYSCLK RCC_MCO1SOURCE_SYSCLK +#define RCC_MCOSOURCE_HSI RCC_MCO1SOURCE_HSI +#define RCC_MCOSOURCE_HSI14 RCC_MCO1SOURCE_HSI14 +#define RCC_MCOSOURCE_HSI48 RCC_MCO1SOURCE_HSI48 +#define RCC_MCOSOURCE_HSE RCC_MCO1SOURCE_HSE +#define RCC_MCOSOURCE_PLLCLK_DIV1 RCC_MCO1SOURCE_PLLCLK +#define RCC_MCOSOURCE_PLLCLK_NODIV RCC_MCO1SOURCE_PLLCLK +#define RCC_MCOSOURCE_PLLCLK_DIV2 RCC_MCO1SOURCE_PLLCLK_DIV2 + +#if defined(STM32L4) || defined(STM32WB) || defined(STM32G0) || defined(STM32G4) || defined(STM32L5) || defined(STM32WL) +#define RCC_RTCCLKSOURCE_NO_CLK RCC_RTCCLKSOURCE_NONE +#else +#define RCC_RTCCLKSOURCE_NONE RCC_RTCCLKSOURCE_NO_CLK +#endif + +#define RCC_USBCLK_PLLSAI1 RCC_USBCLKSOURCE_PLLSAI1 +#define RCC_USBCLK_PLL RCC_USBCLKSOURCE_PLL +#define RCC_USBCLK_MSI RCC_USBCLKSOURCE_MSI +#define RCC_USBCLKSOURCE_PLLCLK RCC_USBCLKSOURCE_PLL +#define RCC_USBPLLCLK_DIV1 RCC_USBCLKSOURCE_PLL +#define RCC_USBPLLCLK_DIV1_5 RCC_USBCLKSOURCE_PLL_DIV1_5 +#define RCC_USBPLLCLK_DIV2 RCC_USBCLKSOURCE_PLL_DIV2 +#define RCC_USBPLLCLK_DIV3 RCC_USBCLKSOURCE_PLL_DIV3 + +#define HSION_BitNumber RCC_HSION_BIT_NUMBER +#define HSION_BITNUMBER RCC_HSION_BIT_NUMBER +#define HSEON_BitNumber RCC_HSEON_BIT_NUMBER +#define HSEON_BITNUMBER RCC_HSEON_BIT_NUMBER +#define MSION_BITNUMBER RCC_MSION_BIT_NUMBER +#define CSSON_BitNumber RCC_CSSON_BIT_NUMBER +#define CSSON_BITNUMBER RCC_CSSON_BIT_NUMBER +#define PLLON_BitNumber RCC_PLLON_BIT_NUMBER +#define PLLON_BITNUMBER RCC_PLLON_BIT_NUMBER +#define PLLI2SON_BitNumber RCC_PLLI2SON_BIT_NUMBER +#define I2SSRC_BitNumber RCC_I2SSRC_BIT_NUMBER +#define RTCEN_BitNumber RCC_RTCEN_BIT_NUMBER +#define RTCEN_BITNUMBER RCC_RTCEN_BIT_NUMBER +#define BDRST_BitNumber RCC_BDRST_BIT_NUMBER +#define BDRST_BITNUMBER RCC_BDRST_BIT_NUMBER +#define RTCRST_BITNUMBER RCC_RTCRST_BIT_NUMBER +#define LSION_BitNumber RCC_LSION_BIT_NUMBER +#define LSION_BITNUMBER RCC_LSION_BIT_NUMBER +#define LSEON_BitNumber RCC_LSEON_BIT_NUMBER +#define LSEON_BITNUMBER RCC_LSEON_BIT_NUMBER +#define LSEBYP_BITNUMBER RCC_LSEBYP_BIT_NUMBER +#define PLLSAION_BitNumber RCC_PLLSAION_BIT_NUMBER +#define TIMPRE_BitNumber RCC_TIMPRE_BIT_NUMBER +#define RMVF_BitNumber RCC_RMVF_BIT_NUMBER +#define RMVF_BITNUMBER RCC_RMVF_BIT_NUMBER +#define RCC_CR2_HSI14TRIM_BitNumber RCC_HSI14TRIM_BIT_NUMBER +#define CR_BYTE2_ADDRESS RCC_CR_BYTE2_ADDRESS +#define CIR_BYTE1_ADDRESS RCC_CIR_BYTE1_ADDRESS +#define CIR_BYTE2_ADDRESS RCC_CIR_BYTE2_ADDRESS +#define BDCR_BYTE0_ADDRESS RCC_BDCR_BYTE0_ADDRESS +#define DBP_TIMEOUT_VALUE RCC_DBP_TIMEOUT_VALUE +#define LSE_TIMEOUT_VALUE RCC_LSE_TIMEOUT_VALUE + +#define CR_HSION_BB RCC_CR_HSION_BB +#define CR_CSSON_BB RCC_CR_CSSON_BB +#define CR_PLLON_BB RCC_CR_PLLON_BB +#define CR_PLLI2SON_BB RCC_CR_PLLI2SON_BB +#define CR_MSION_BB RCC_CR_MSION_BB +#define CSR_LSION_BB RCC_CSR_LSION_BB +#define CSR_LSEON_BB RCC_CSR_LSEON_BB +#define CSR_LSEBYP_BB RCC_CSR_LSEBYP_BB +#define CSR_RTCEN_BB RCC_CSR_RTCEN_BB +#define CSR_RTCRST_BB RCC_CSR_RTCRST_BB +#define CFGR_I2SSRC_BB RCC_CFGR_I2SSRC_BB +#define BDCR_RTCEN_BB RCC_BDCR_RTCEN_BB +#define BDCR_BDRST_BB RCC_BDCR_BDRST_BB +#define CR_HSEON_BB RCC_CR_HSEON_BB +#define CSR_RMVF_BB RCC_CSR_RMVF_BB +#define CR_PLLSAION_BB RCC_CR_PLLSAION_BB +#define DCKCFGR_TIMPRE_BB RCC_DCKCFGR_TIMPRE_BB + +#define __HAL_RCC_CRS_ENABLE_FREQ_ERROR_COUNTER __HAL_RCC_CRS_FREQ_ERROR_COUNTER_ENABLE +#define __HAL_RCC_CRS_DISABLE_FREQ_ERROR_COUNTER __HAL_RCC_CRS_FREQ_ERROR_COUNTER_DISABLE +#define __HAL_RCC_CRS_ENABLE_AUTOMATIC_CALIB __HAL_RCC_CRS_AUTOMATIC_CALIB_ENABLE +#define __HAL_RCC_CRS_DISABLE_AUTOMATIC_CALIB __HAL_RCC_CRS_AUTOMATIC_CALIB_DISABLE +#define __HAL_RCC_CRS_CALCULATE_RELOADVALUE __HAL_RCC_CRS_RELOADVALUE_CALCULATE + +#define __HAL_RCC_GET_IT_SOURCE __HAL_RCC_GET_IT + +#define RCC_CRS_SYNCWARM RCC_CRS_SYNCWARN +#define RCC_CRS_TRIMOV RCC_CRS_TRIMOVF + +#define RCC_PERIPHCLK_CK48 RCC_PERIPHCLK_CLK48 +#define RCC_CK48CLKSOURCE_PLLQ RCC_CLK48CLKSOURCE_PLLQ +#define RCC_CK48CLKSOURCE_PLLSAIP RCC_CLK48CLKSOURCE_PLLSAIP +#define RCC_CK48CLKSOURCE_PLLI2SQ RCC_CLK48CLKSOURCE_PLLI2SQ +#define IS_RCC_CK48CLKSOURCE IS_RCC_CLK48CLKSOURCE +#define RCC_SDIOCLKSOURCE_CK48 RCC_SDIOCLKSOURCE_CLK48 + +#define __HAL_RCC_DFSDM_CLK_ENABLE __HAL_RCC_DFSDM1_CLK_ENABLE +#define __HAL_RCC_DFSDM_CLK_DISABLE __HAL_RCC_DFSDM1_CLK_DISABLE +#define __HAL_RCC_DFSDM_IS_CLK_ENABLED __HAL_RCC_DFSDM1_IS_CLK_ENABLED +#define __HAL_RCC_DFSDM_IS_CLK_DISABLED __HAL_RCC_DFSDM1_IS_CLK_DISABLED +#define __HAL_RCC_DFSDM_FORCE_RESET __HAL_RCC_DFSDM1_FORCE_RESET +#define __HAL_RCC_DFSDM_RELEASE_RESET __HAL_RCC_DFSDM1_RELEASE_RESET +#define __HAL_RCC_DFSDM_CLK_SLEEP_ENABLE __HAL_RCC_DFSDM1_CLK_SLEEP_ENABLE +#define __HAL_RCC_DFSDM_CLK_SLEEP_DISABLE __HAL_RCC_DFSDM1_CLK_SLEEP_DISABLE +#define __HAL_RCC_DFSDM_IS_CLK_SLEEP_ENABLED __HAL_RCC_DFSDM1_IS_CLK_SLEEP_ENABLED +#define __HAL_RCC_DFSDM_IS_CLK_SLEEP_DISABLED __HAL_RCC_DFSDM1_IS_CLK_SLEEP_DISABLED +#define DfsdmClockSelection Dfsdm1ClockSelection +#define RCC_PERIPHCLK_DFSDM RCC_PERIPHCLK_DFSDM1 +#define RCC_DFSDMCLKSOURCE_PCLK RCC_DFSDM1CLKSOURCE_PCLK2 +#define RCC_DFSDMCLKSOURCE_SYSCLK RCC_DFSDM1CLKSOURCE_SYSCLK +#define __HAL_RCC_DFSDM_CONFIG __HAL_RCC_DFSDM1_CONFIG +#define __HAL_RCC_GET_DFSDM_SOURCE __HAL_RCC_GET_DFSDM1_SOURCE +#define RCC_DFSDM1CLKSOURCE_PCLK RCC_DFSDM1CLKSOURCE_PCLK2 +#define RCC_SWPMI1CLKSOURCE_PCLK RCC_SWPMI1CLKSOURCE_PCLK1 +#define RCC_LPTIM1CLKSOURCE_PCLK RCC_LPTIM1CLKSOURCE_PCLK1 +#define RCC_LPTIM2CLKSOURCE_PCLK RCC_LPTIM2CLKSOURCE_PCLK1 + +#define RCC_DFSDM1AUDIOCLKSOURCE_I2SAPB1 RCC_DFSDM1AUDIOCLKSOURCE_I2S1 +#define RCC_DFSDM1AUDIOCLKSOURCE_I2SAPB2 RCC_DFSDM1AUDIOCLKSOURCE_I2S2 +#define RCC_DFSDM2AUDIOCLKSOURCE_I2SAPB1 RCC_DFSDM2AUDIOCLKSOURCE_I2S1 +#define RCC_DFSDM2AUDIOCLKSOURCE_I2SAPB2 RCC_DFSDM2AUDIOCLKSOURCE_I2S2 +#define RCC_DFSDM1CLKSOURCE_APB2 RCC_DFSDM1CLKSOURCE_PCLK2 +#define RCC_DFSDM2CLKSOURCE_APB2 RCC_DFSDM2CLKSOURCE_PCLK2 +#define RCC_FMPI2C1CLKSOURCE_APB RCC_FMPI2C1CLKSOURCE_PCLK1 +#if defined(STM32U5) +#define MSIKPLLModeSEL RCC_MSIKPLL_MODE_SEL +#define MSISPLLModeSEL RCC_MSISPLL_MODE_SEL +#define __HAL_RCC_AHB21_CLK_DISABLE __HAL_RCC_AHB2_1_CLK_DISABLE +#define __HAL_RCC_AHB22_CLK_DISABLE __HAL_RCC_AHB2_2_CLK_DISABLE +#define __HAL_RCC_AHB1_CLK_Disable_Clear __HAL_RCC_AHB1_CLK_ENABLE +#define __HAL_RCC_AHB21_CLK_Disable_Clear __HAL_RCC_AHB2_1_CLK_ENABLE +#define __HAL_RCC_AHB22_CLK_Disable_Clear __HAL_RCC_AHB2_2_CLK_ENABLE +#define __HAL_RCC_AHB3_CLK_Disable_Clear __HAL_RCC_AHB3_CLK_ENABLE +#define __HAL_RCC_APB1_CLK_Disable_Clear __HAL_RCC_APB1_CLK_ENABLE +#define __HAL_RCC_APB2_CLK_Disable_Clear __HAL_RCC_APB2_CLK_ENABLE +#define __HAL_RCC_APB3_CLK_Disable_Clear __HAL_RCC_APB3_CLK_ENABLE +#define IS_RCC_MSIPLLModeSelection IS_RCC_MSIPLLMODE_SELECT +#endif +/** + * @} + */ + +/** @defgroup HAL_RNG_Aliased_Macros HAL RNG Aliased Macros maintained for legacy purpose + * @{ + */ +#define HAL_RNG_ReadyCallback(__HANDLE__) HAL_RNG_ReadyDataCallback((__HANDLE__), uint32_t random32bit) + +/** + * @} + */ + +/** @defgroup HAL_RTC_Aliased_Macros HAL RTC Aliased Macros maintained for legacy purpose + * @{ + */ +#if defined (STM32G0) || defined (STM32L5) || defined (STM32L412xx) || defined (STM32L422xx) || defined (STM32L4P5xx) || defined (STM32L4Q5xx) || defined (STM32G4) || defined (STM32WL) || defined (STM32U5) +#else +#define __HAL_RTC_CLEAR_FLAG __HAL_RTC_EXTI_CLEAR_FLAG +#endif +#define __HAL_RTC_DISABLE_IT __HAL_RTC_EXTI_DISABLE_IT +#define __HAL_RTC_ENABLE_IT __HAL_RTC_EXTI_ENABLE_IT + +#if defined (STM32F1) +#define __HAL_RTC_EXTI_CLEAR_FLAG(RTC_EXTI_LINE_ALARM_EVENT) __HAL_RTC_ALARM_EXTI_CLEAR_FLAG() + +#define __HAL_RTC_EXTI_ENABLE_IT(RTC_EXTI_LINE_ALARM_EVENT) __HAL_RTC_ALARM_EXTI_ENABLE_IT() + +#define __HAL_RTC_EXTI_DISABLE_IT(RTC_EXTI_LINE_ALARM_EVENT) __HAL_RTC_ALARM_EXTI_DISABLE_IT() + +#define __HAL_RTC_EXTI_GET_FLAG(RTC_EXTI_LINE_ALARM_EVENT) __HAL_RTC_ALARM_EXTI_GET_FLAG() + +#define __HAL_RTC_EXTI_GENERATE_SWIT(RTC_EXTI_LINE_ALARM_EVENT) __HAL_RTC_ALARM_EXTI_GENERATE_SWIT() +#else +#define __HAL_RTC_EXTI_CLEAR_FLAG(__EXTI_LINE__) (((__EXTI_LINE__) == RTC_EXTI_LINE_ALARM_EVENT) ? __HAL_RTC_ALARM_EXTI_CLEAR_FLAG() : \ + (((__EXTI_LINE__) == RTC_EXTI_LINE_WAKEUPTIMER_EVENT) ? __HAL_RTC_WAKEUPTIMER_EXTI_CLEAR_FLAG() : \ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_CLEAR_FLAG())) +#define __HAL_RTC_EXTI_ENABLE_IT(__EXTI_LINE__) (((__EXTI_LINE__) == RTC_EXTI_LINE_ALARM_EVENT) ? __HAL_RTC_ALARM_EXTI_ENABLE_IT() : \ + (((__EXTI_LINE__) == RTC_EXTI_LINE_WAKEUPTIMER_EVENT) ? __HAL_RTC_WAKEUPTIMER_EXTI_ENABLE_IT() : \ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_ENABLE_IT())) +#define __HAL_RTC_EXTI_DISABLE_IT(__EXTI_LINE__) (((__EXTI_LINE__) == RTC_EXTI_LINE_ALARM_EVENT) ? __HAL_RTC_ALARM_EXTI_DISABLE_IT() : \ + (((__EXTI_LINE__) == RTC_EXTI_LINE_WAKEUPTIMER_EVENT) ? __HAL_RTC_WAKEUPTIMER_EXTI_DISABLE_IT() : \ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_DISABLE_IT())) +#define __HAL_RTC_EXTI_GET_FLAG(__EXTI_LINE__) (((__EXTI_LINE__) == RTC_EXTI_LINE_ALARM_EVENT) ? __HAL_RTC_ALARM_EXTI_GET_FLAG() : \ + (((__EXTI_LINE__) == RTC_EXTI_LINE_WAKEUPTIMER_EVENT) ? __HAL_RTC_WAKEUPTIMER_EXTI_GET_FLAG() : \ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_GET_FLAG())) +#define __HAL_RTC_EXTI_GENERATE_SWIT(__EXTI_LINE__) (((__EXTI_LINE__) == RTC_EXTI_LINE_ALARM_EVENT) ? __HAL_RTC_ALARM_EXTI_GENERATE_SWIT() : \ + (((__EXTI_LINE__) == RTC_EXTI_LINE_WAKEUPTIMER_EVENT) ? __HAL_RTC_WAKEUPTIMER_EXTI_GENERATE_SWIT() : \ + __HAL_RTC_TAMPER_TIMESTAMP_EXTI_GENERATE_SWIT())) +#endif /* STM32F1 */ + +#define IS_ALARM IS_RTC_ALARM +#define IS_ALARM_MASK IS_RTC_ALARM_MASK +#define IS_TAMPER IS_RTC_TAMPER +#define IS_TAMPER_ERASE_MODE IS_RTC_TAMPER_ERASE_MODE +#define IS_TAMPER_FILTER IS_RTC_TAMPER_FILTER +#define IS_TAMPER_INTERRUPT IS_RTC_TAMPER_INTERRUPT +#define IS_TAMPER_MASKFLAG_STATE IS_RTC_TAMPER_MASKFLAG_STATE +#define IS_TAMPER_PRECHARGE_DURATION IS_RTC_TAMPER_PRECHARGE_DURATION +#define IS_TAMPER_PULLUP_STATE IS_RTC_TAMPER_PULLUP_STATE +#define IS_TAMPER_SAMPLING_FREQ IS_RTC_TAMPER_SAMPLING_FREQ +#define IS_TAMPER_TIMESTAMPONTAMPER_DETECTION IS_RTC_TAMPER_TIMESTAMPONTAMPER_DETECTION +#define IS_TAMPER_TRIGGER IS_RTC_TAMPER_TRIGGER +#define IS_WAKEUP_CLOCK IS_RTC_WAKEUP_CLOCK +#define IS_WAKEUP_COUNTER IS_RTC_WAKEUP_COUNTER + +#define __RTC_WRITEPROTECTION_ENABLE __HAL_RTC_WRITEPROTECTION_ENABLE +#define __RTC_WRITEPROTECTION_DISABLE __HAL_RTC_WRITEPROTECTION_DISABLE + +/** + * @} + */ + +/** @defgroup HAL_SD_Aliased_Macros HAL SD/MMC Aliased Macros maintained for legacy purpose + * @{ + */ + +#define SD_OCR_CID_CSD_OVERWRIETE SD_OCR_CID_CSD_OVERWRITE +#define SD_CMD_SD_APP_STAUS SD_CMD_SD_APP_STATUS + +#if !defined(STM32F1) && !defined(STM32F2) && !defined(STM32F4) && !defined(STM32F7) && !defined(STM32L1) +#define eMMC_HIGH_VOLTAGE_RANGE EMMC_HIGH_VOLTAGE_RANGE +#define eMMC_DUAL_VOLTAGE_RANGE EMMC_DUAL_VOLTAGE_RANGE +#define eMMC_LOW_VOLTAGE_RANGE EMMC_LOW_VOLTAGE_RANGE + +#define SDMMC_NSpeed_CLK_DIV SDMMC_NSPEED_CLK_DIV +#define SDMMC_HSpeed_CLK_DIV SDMMC_HSPEED_CLK_DIV +#endif + +#if defined(STM32F4) || defined(STM32F2) +#define SD_SDMMC_DISABLED SD_SDIO_DISABLED +#define SD_SDMMC_FUNCTION_BUSY SD_SDIO_FUNCTION_BUSY +#define SD_SDMMC_FUNCTION_FAILED SD_SDIO_FUNCTION_FAILED +#define SD_SDMMC_UNKNOWN_FUNCTION SD_SDIO_UNKNOWN_FUNCTION +#define SD_CMD_SDMMC_SEN_OP_COND SD_CMD_SDIO_SEN_OP_COND +#define SD_CMD_SDMMC_RW_DIRECT SD_CMD_SDIO_RW_DIRECT +#define SD_CMD_SDMMC_RW_EXTENDED SD_CMD_SDIO_RW_EXTENDED +#define __HAL_SD_SDMMC_ENABLE __HAL_SD_SDIO_ENABLE +#define __HAL_SD_SDMMC_DISABLE __HAL_SD_SDIO_DISABLE +#define __HAL_SD_SDMMC_DMA_ENABLE __HAL_SD_SDIO_DMA_ENABLE +#define __HAL_SD_SDMMC_DMA_DISABLE __HAL_SD_SDIO_DMA_DISABL +#define __HAL_SD_SDMMC_ENABLE_IT __HAL_SD_SDIO_ENABLE_IT +#define __HAL_SD_SDMMC_DISABLE_IT __HAL_SD_SDIO_DISABLE_IT +#define __HAL_SD_SDMMC_GET_FLAG __HAL_SD_SDIO_GET_FLAG +#define __HAL_SD_SDMMC_CLEAR_FLAG __HAL_SD_SDIO_CLEAR_FLAG +#define __HAL_SD_SDMMC_GET_IT __HAL_SD_SDIO_GET_IT +#define __HAL_SD_SDMMC_CLEAR_IT __HAL_SD_SDIO_CLEAR_IT +#define SDMMC_STATIC_FLAGS SDIO_STATIC_FLAGS +#define SDMMC_CMD0TIMEOUT SDIO_CMD0TIMEOUT +#define SD_SDMMC_SEND_IF_COND SD_SDIO_SEND_IF_COND +/* alias CMSIS */ +#define SDMMC1_IRQn SDIO_IRQn +#define SDMMC1_IRQHandler SDIO_IRQHandler +#endif + +#if defined(STM32F7) || defined(STM32L4) +#define SD_SDIO_DISABLED SD_SDMMC_DISABLED +#define SD_SDIO_FUNCTION_BUSY SD_SDMMC_FUNCTION_BUSY +#define SD_SDIO_FUNCTION_FAILED SD_SDMMC_FUNCTION_FAILED +#define SD_SDIO_UNKNOWN_FUNCTION SD_SDMMC_UNKNOWN_FUNCTION +#define SD_CMD_SDIO_SEN_OP_COND SD_CMD_SDMMC_SEN_OP_COND +#define SD_CMD_SDIO_RW_DIRECT SD_CMD_SDMMC_RW_DIRECT +#define SD_CMD_SDIO_RW_EXTENDED SD_CMD_SDMMC_RW_EXTENDED +#define __HAL_SD_SDIO_ENABLE __HAL_SD_SDMMC_ENABLE +#define __HAL_SD_SDIO_DISABLE __HAL_SD_SDMMC_DISABLE +#define __HAL_SD_SDIO_DMA_ENABLE __HAL_SD_SDMMC_DMA_ENABLE +#define __HAL_SD_SDIO_DMA_DISABL __HAL_SD_SDMMC_DMA_DISABLE +#define __HAL_SD_SDIO_ENABLE_IT __HAL_SD_SDMMC_ENABLE_IT +#define __HAL_SD_SDIO_DISABLE_IT __HAL_SD_SDMMC_DISABLE_IT +#define __HAL_SD_SDIO_GET_FLAG __HAL_SD_SDMMC_GET_FLAG +#define __HAL_SD_SDIO_CLEAR_FLAG __HAL_SD_SDMMC_CLEAR_FLAG +#define __HAL_SD_SDIO_GET_IT __HAL_SD_SDMMC_GET_IT +#define __HAL_SD_SDIO_CLEAR_IT __HAL_SD_SDMMC_CLEAR_IT +#define SDIO_STATIC_FLAGS SDMMC_STATIC_FLAGS +#define SDIO_CMD0TIMEOUT SDMMC_CMD0TIMEOUT +#define SD_SDIO_SEND_IF_COND SD_SDMMC_SEND_IF_COND +/* alias CMSIS for compatibilities */ +#define SDIO_IRQn SDMMC1_IRQn +#define SDIO_IRQHandler SDMMC1_IRQHandler +#endif + +#if defined(STM32F7) || defined(STM32F4) || defined(STM32F2) || defined(STM32L4) || defined(STM32H7) +#define HAL_SD_CardCIDTypedef HAL_SD_CardCIDTypeDef +#define HAL_SD_CardCSDTypedef HAL_SD_CardCSDTypeDef +#define HAL_SD_CardStatusTypedef HAL_SD_CardStatusTypeDef +#define HAL_SD_CardStateTypedef HAL_SD_CardStateTypeDef +#endif + +#if defined(STM32H7) || defined(STM32L5) +#define HAL_MMCEx_Read_DMADoubleBuffer0CpltCallback HAL_MMCEx_Read_DMADoubleBuf0CpltCallback +#define HAL_MMCEx_Read_DMADoubleBuffer1CpltCallback HAL_MMCEx_Read_DMADoubleBuf1CpltCallback +#define HAL_MMCEx_Write_DMADoubleBuffer0CpltCallback HAL_MMCEx_Write_DMADoubleBuf0CpltCallback +#define HAL_MMCEx_Write_DMADoubleBuffer1CpltCallback HAL_MMCEx_Write_DMADoubleBuf1CpltCallback +#define HAL_SDEx_Read_DMADoubleBuffer0CpltCallback HAL_SDEx_Read_DMADoubleBuf0CpltCallback +#define HAL_SDEx_Read_DMADoubleBuffer1CpltCallback HAL_SDEx_Read_DMADoubleBuf1CpltCallback +#define HAL_SDEx_Write_DMADoubleBuffer0CpltCallback HAL_SDEx_Write_DMADoubleBuf0CpltCallback +#define HAL_SDEx_Write_DMADoubleBuffer1CpltCallback HAL_SDEx_Write_DMADoubleBuf1CpltCallback +#define HAL_SD_DriveTransciver_1_8V_Callback HAL_SD_DriveTransceiver_1_8V_Callback +#endif +/** + * @} + */ + +/** @defgroup HAL_SMARTCARD_Aliased_Macros HAL SMARTCARD Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __SMARTCARD_ENABLE_IT __HAL_SMARTCARD_ENABLE_IT +#define __SMARTCARD_DISABLE_IT __HAL_SMARTCARD_DISABLE_IT +#define __SMARTCARD_ENABLE __HAL_SMARTCARD_ENABLE +#define __SMARTCARD_DISABLE __HAL_SMARTCARD_DISABLE +#define __SMARTCARD_DMA_REQUEST_ENABLE __HAL_SMARTCARD_DMA_REQUEST_ENABLE +#define __SMARTCARD_DMA_REQUEST_DISABLE __HAL_SMARTCARD_DMA_REQUEST_DISABLE + +#define __HAL_SMARTCARD_GETCLOCKSOURCE SMARTCARD_GETCLOCKSOURCE +#define __SMARTCARD_GETCLOCKSOURCE SMARTCARD_GETCLOCKSOURCE + +#define IS_SMARTCARD_ONEBIT_SAMPLING IS_SMARTCARD_ONE_BIT_SAMPLE + +/** + * @} + */ + +/** @defgroup HAL_SMBUS_Aliased_Macros HAL SMBUS Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_SMBUS_RESET_CR1 SMBUS_RESET_CR1 +#define __HAL_SMBUS_RESET_CR2 SMBUS_RESET_CR2 +#define __HAL_SMBUS_GENERATE_START SMBUS_GENERATE_START +#define __HAL_SMBUS_GET_ADDR_MATCH SMBUS_GET_ADDR_MATCH +#define __HAL_SMBUS_GET_DIR SMBUS_GET_DIR +#define __HAL_SMBUS_GET_STOP_MODE SMBUS_GET_STOP_MODE +#define __HAL_SMBUS_GET_PEC_MODE SMBUS_GET_PEC_MODE +#define __HAL_SMBUS_GET_ALERT_ENABLED SMBUS_GET_ALERT_ENABLED +/** + * @} + */ + +/** @defgroup HAL_SPI_Aliased_Macros HAL SPI Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __HAL_SPI_1LINE_TX SPI_1LINE_TX +#define __HAL_SPI_1LINE_RX SPI_1LINE_RX +#define __HAL_SPI_RESET_CRC SPI_RESET_CRC + +/** + * @} + */ + +/** @defgroup HAL_UART_Aliased_Macros HAL UART Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __HAL_UART_GETCLOCKSOURCE UART_GETCLOCKSOURCE +#define __HAL_UART_MASK_COMPUTATION UART_MASK_COMPUTATION +#define __UART_GETCLOCKSOURCE UART_GETCLOCKSOURCE +#define __UART_MASK_COMPUTATION UART_MASK_COMPUTATION + +#define IS_UART_WAKEUPMETHODE IS_UART_WAKEUPMETHOD + +#define IS_UART_ONEBIT_SAMPLE IS_UART_ONE_BIT_SAMPLE +#define IS_UART_ONEBIT_SAMPLING IS_UART_ONE_BIT_SAMPLE + +/** + * @} + */ + + +/** @defgroup HAL_USART_Aliased_Macros HAL USART Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __USART_ENABLE_IT __HAL_USART_ENABLE_IT +#define __USART_DISABLE_IT __HAL_USART_DISABLE_IT +#define __USART_ENABLE __HAL_USART_ENABLE +#define __USART_DISABLE __HAL_USART_DISABLE + +#define __HAL_USART_GETCLOCKSOURCE USART_GETCLOCKSOURCE +#define __USART_GETCLOCKSOURCE USART_GETCLOCKSOURCE + +#if defined(STM32F0) || defined(STM32F3) || defined(STM32F7) +#define USART_OVERSAMPLING_16 0x00000000U +#define USART_OVERSAMPLING_8 USART_CR1_OVER8 + +#define IS_USART_OVERSAMPLING(__SAMPLING__) (((__SAMPLING__) == USART_OVERSAMPLING_16) || \ + ((__SAMPLING__) == USART_OVERSAMPLING_8)) +#endif /* STM32F0 || STM32F3 || STM32F7 */ +/** + * @} + */ + +/** @defgroup HAL_USB_Aliased_Macros HAL USB Aliased Macros maintained for legacy purpose + * @{ + */ +#define USB_EXTI_LINE_WAKEUP USB_WAKEUP_EXTI_LINE + +#define USB_FS_EXTI_TRIGGER_RISING_EDGE USB_OTG_FS_WAKEUP_EXTI_RISING_EDGE +#define USB_FS_EXTI_TRIGGER_FALLING_EDGE USB_OTG_FS_WAKEUP_EXTI_FALLING_EDGE +#define USB_FS_EXTI_TRIGGER_BOTH_EDGE USB_OTG_FS_WAKEUP_EXTI_RISING_FALLING_EDGE +#define USB_FS_EXTI_LINE_WAKEUP USB_OTG_FS_WAKEUP_EXTI_LINE + +#define USB_HS_EXTI_TRIGGER_RISING_EDGE USB_OTG_HS_WAKEUP_EXTI_RISING_EDGE +#define USB_HS_EXTI_TRIGGER_FALLING_EDGE USB_OTG_HS_WAKEUP_EXTI_FALLING_EDGE +#define USB_HS_EXTI_TRIGGER_BOTH_EDGE USB_OTG_HS_WAKEUP_EXTI_RISING_FALLING_EDGE +#define USB_HS_EXTI_LINE_WAKEUP USB_OTG_HS_WAKEUP_EXTI_LINE + +#define __HAL_USB_EXTI_ENABLE_IT __HAL_USB_WAKEUP_EXTI_ENABLE_IT +#define __HAL_USB_EXTI_DISABLE_IT __HAL_USB_WAKEUP_EXTI_DISABLE_IT +#define __HAL_USB_EXTI_GET_FLAG __HAL_USB_WAKEUP_EXTI_GET_FLAG +#define __HAL_USB_EXTI_CLEAR_FLAG __HAL_USB_WAKEUP_EXTI_CLEAR_FLAG +#define __HAL_USB_EXTI_SET_RISING_EDGE_TRIGGER __HAL_USB_WAKEUP_EXTI_ENABLE_RISING_EDGE +#define __HAL_USB_EXTI_SET_FALLING_EDGE_TRIGGER __HAL_USB_WAKEUP_EXTI_ENABLE_FALLING_EDGE +#define __HAL_USB_EXTI_SET_FALLINGRISING_TRIGGER __HAL_USB_WAKEUP_EXTI_ENABLE_RISING_FALLING_EDGE + +#define __HAL_USB_FS_EXTI_ENABLE_IT __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_IT +#define __HAL_USB_FS_EXTI_DISABLE_IT __HAL_USB_OTG_FS_WAKEUP_EXTI_DISABLE_IT +#define __HAL_USB_FS_EXTI_GET_FLAG __HAL_USB_OTG_FS_WAKEUP_EXTI_GET_FLAG +#define __HAL_USB_FS_EXTI_CLEAR_FLAG __HAL_USB_OTG_FS_WAKEUP_EXTI_CLEAR_FLAG +#define __HAL_USB_FS_EXTI_SET_RISING_EGDE_TRIGGER __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_EDGE +#define __HAL_USB_FS_EXTI_SET_FALLING_EGDE_TRIGGER __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_FALLING_EDGE +#define __HAL_USB_FS_EXTI_SET_FALLINGRISING_TRIGGER __HAL_USB_OTG_FS_WAKEUP_EXTI_ENABLE_RISING_FALLING_EDGE +#define __HAL_USB_FS_EXTI_GENERATE_SWIT __HAL_USB_OTG_FS_WAKEUP_EXTI_GENERATE_SWIT + +#define __HAL_USB_HS_EXTI_ENABLE_IT __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_IT +#define __HAL_USB_HS_EXTI_DISABLE_IT __HAL_USB_OTG_HS_WAKEUP_EXTI_DISABLE_IT +#define __HAL_USB_HS_EXTI_GET_FLAG __HAL_USB_OTG_HS_WAKEUP_EXTI_GET_FLAG +#define __HAL_USB_HS_EXTI_CLEAR_FLAG __HAL_USB_OTG_HS_WAKEUP_EXTI_CLEAR_FLAG +#define __HAL_USB_HS_EXTI_SET_RISING_EGDE_TRIGGER __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_RISING_EDGE +#define __HAL_USB_HS_EXTI_SET_FALLING_EGDE_TRIGGER __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_FALLING_EDGE +#define __HAL_USB_HS_EXTI_SET_FALLINGRISING_TRIGGER __HAL_USB_OTG_HS_WAKEUP_EXTI_ENABLE_RISING_FALLING_EDGE +#define __HAL_USB_HS_EXTI_GENERATE_SWIT __HAL_USB_OTG_HS_WAKEUP_EXTI_GENERATE_SWIT + +#define HAL_PCD_ActiveRemoteWakeup HAL_PCD_ActivateRemoteWakeup +#define HAL_PCD_DeActiveRemoteWakeup HAL_PCD_DeActivateRemoteWakeup + +#define HAL_PCD_SetTxFiFo HAL_PCDEx_SetTxFiFo +#define HAL_PCD_SetRxFiFo HAL_PCDEx_SetRxFiFo +/** + * @} + */ + +/** @defgroup HAL_TIM_Aliased_Macros HAL TIM Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_TIM_SetICPrescalerValue TIM_SET_ICPRESCALERVALUE +#define __HAL_TIM_ResetICPrescalerValue TIM_RESET_ICPRESCALERVALUE + +#define TIM_GET_ITSTATUS __HAL_TIM_GET_IT_SOURCE +#define TIM_GET_CLEAR_IT __HAL_TIM_CLEAR_IT + +#define __HAL_TIM_GET_ITSTATUS __HAL_TIM_GET_IT_SOURCE + +#define __HAL_TIM_DIRECTION_STATUS __HAL_TIM_IS_TIM_COUNTING_DOWN +#define __HAL_TIM_PRESCALER __HAL_TIM_SET_PRESCALER +#define __HAL_TIM_SetCounter __HAL_TIM_SET_COUNTER +#define __HAL_TIM_GetCounter __HAL_TIM_GET_COUNTER +#define __HAL_TIM_SetAutoreload __HAL_TIM_SET_AUTORELOAD +#define __HAL_TIM_GetAutoreload __HAL_TIM_GET_AUTORELOAD +#define __HAL_TIM_SetClockDivision __HAL_TIM_SET_CLOCKDIVISION +#define __HAL_TIM_GetClockDivision __HAL_TIM_GET_CLOCKDIVISION +#define __HAL_TIM_SetICPrescaler __HAL_TIM_SET_ICPRESCALER +#define __HAL_TIM_GetICPrescaler __HAL_TIM_GET_ICPRESCALER +#define __HAL_TIM_SetCompare __HAL_TIM_SET_COMPARE +#define __HAL_TIM_GetCompare __HAL_TIM_GET_COMPARE + +#define TIM_BREAKINPUTSOURCE_DFSDM TIM_BREAKINPUTSOURCE_DFSDM1 +/** + * @} + */ + +/** @defgroup HAL_ETH_Aliased_Macros HAL ETH Aliased Macros maintained for legacy purpose + * @{ + */ + +#define __HAL_ETH_EXTI_ENABLE_IT __HAL_ETH_WAKEUP_EXTI_ENABLE_IT +#define __HAL_ETH_EXTI_DISABLE_IT __HAL_ETH_WAKEUP_EXTI_DISABLE_IT +#define __HAL_ETH_EXTI_GET_FLAG __HAL_ETH_WAKEUP_EXTI_GET_FLAG +#define __HAL_ETH_EXTI_CLEAR_FLAG __HAL_ETH_WAKEUP_EXTI_CLEAR_FLAG +#define __HAL_ETH_EXTI_SET_RISING_EGDE_TRIGGER __HAL_ETH_WAKEUP_EXTI_ENABLE_RISING_EDGE_TRIGGER +#define __HAL_ETH_EXTI_SET_FALLING_EGDE_TRIGGER __HAL_ETH_WAKEUP_EXTI_ENABLE_FALLING_EDGE_TRIGGER +#define __HAL_ETH_EXTI_SET_FALLINGRISING_TRIGGER __HAL_ETH_WAKEUP_EXTI_ENABLE_FALLINGRISING_TRIGGER + +#define ETH_PROMISCIOUSMODE_ENABLE ETH_PROMISCUOUS_MODE_ENABLE +#define ETH_PROMISCIOUSMODE_DISABLE ETH_PROMISCUOUS_MODE_DISABLE +#define IS_ETH_PROMISCIOUS_MODE IS_ETH_PROMISCUOUS_MODE +/** + * @} + */ + +/** @defgroup HAL_LTDC_Aliased_Macros HAL LTDC Aliased Macros maintained for legacy purpose + * @{ + */ +#define __HAL_LTDC_LAYER LTDC_LAYER +#define __HAL_LTDC_RELOAD_CONFIG __HAL_LTDC_RELOAD_IMMEDIATE_CONFIG +/** + * @} + */ + +/** @defgroup HAL_SAI_Aliased_Macros HAL SAI Aliased Macros maintained for legacy purpose + * @{ + */ +#define SAI_OUTPUTDRIVE_DISABLED SAI_OUTPUTDRIVE_DISABLE +#define SAI_OUTPUTDRIVE_ENABLED SAI_OUTPUTDRIVE_ENABLE +#define SAI_MASTERDIVIDER_ENABLED SAI_MASTERDIVIDER_ENABLE +#define SAI_MASTERDIVIDER_DISABLED SAI_MASTERDIVIDER_DISABLE +#define SAI_STREOMODE SAI_STEREOMODE +#define SAI_FIFOStatus_Empty SAI_FIFOSTATUS_EMPTY +#define SAI_FIFOStatus_Less1QuarterFull SAI_FIFOSTATUS_LESS1QUARTERFULL +#define SAI_FIFOStatus_1QuarterFull SAI_FIFOSTATUS_1QUARTERFULL +#define SAI_FIFOStatus_HalfFull SAI_FIFOSTATUS_HALFFULL +#define SAI_FIFOStatus_3QuartersFull SAI_FIFOSTATUS_3QUARTERFULL +#define SAI_FIFOStatus_Full SAI_FIFOSTATUS_FULL +#define IS_SAI_BLOCK_MONO_STREO_MODE IS_SAI_BLOCK_MONO_STEREO_MODE +#define SAI_SYNCHRONOUS_EXT SAI_SYNCHRONOUS_EXT_SAI1 +#define SAI_SYNCEXT_IN_ENABLE SAI_SYNCEXT_OUTBLOCKA_ENABLE +/** + * @} + */ + +/** @defgroup HAL_SPDIFRX_Aliased_Macros HAL SPDIFRX Aliased Macros maintained for legacy purpose + * @{ + */ +#if defined(STM32H7) +#define HAL_SPDIFRX_ReceiveControlFlow HAL_SPDIFRX_ReceiveCtrlFlow +#define HAL_SPDIFRX_ReceiveControlFlow_IT HAL_SPDIFRX_ReceiveCtrlFlow_IT +#define HAL_SPDIFRX_ReceiveControlFlow_DMA HAL_SPDIFRX_ReceiveCtrlFlow_DMA +#endif +/** + * @} + */ + +/** @defgroup HAL_HRTIM_Aliased_Functions HAL HRTIM Aliased Functions maintained for legacy purpose + * @{ + */ +#if defined (STM32H7) || defined (STM32G4) || defined (STM32F3) +#define HAL_HRTIM_WaveformCounterStart_IT HAL_HRTIM_WaveformCountStart_IT +#define HAL_HRTIM_WaveformCounterStart_DMA HAL_HRTIM_WaveformCountStart_DMA +#define HAL_HRTIM_WaveformCounterStart HAL_HRTIM_WaveformCountStart +#define HAL_HRTIM_WaveformCounterStop_IT HAL_HRTIM_WaveformCountStop_IT +#define HAL_HRTIM_WaveformCounterStop_DMA HAL_HRTIM_WaveformCountStop_DMA +#define HAL_HRTIM_WaveformCounterStop HAL_HRTIM_WaveformCountStop +#endif +/** + * @} + */ + +/** @defgroup HAL_QSPI_Aliased_Macros HAL QSPI Aliased Macros maintained for legacy purpose + * @{ + */ +#if defined (STM32L4) || defined (STM32F4) || defined (STM32F7) || defined(STM32H7) +#define HAL_QPSI_TIMEOUT_DEFAULT_VALUE HAL_QSPI_TIMEOUT_DEFAULT_VALUE +#endif /* STM32L4 || STM32F4 || STM32F7 */ +/** + * @} + */ + +/** @defgroup HAL_Generic_Aliased_Macros HAL Generic Aliased Macros maintained for legacy purpose + * @{ + */ +#if defined (STM32F7) +#define ART_ACCLERATOR_ENABLE ART_ACCELERATOR_ENABLE +#endif /* STM32F7 */ +/** + * @} + */ + +/** @defgroup HAL_PPP_Aliased_Macros HAL PPP Aliased Macros maintained for legacy purpose + * @{ + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32_HAL_LEGACY */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32f0xx_hal_can_legacy.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32f0xx_hal_can_legacy.h new file mode 100644 index 0000000..0df56b5 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/Legacy/stm32f0xx_hal_can_legacy.h @@ -0,0 +1,794 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_can_legacy.h + * @author MCD Application Team + * @brief Header file of CAN HAL Legacy module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2017 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_CAN_LEGACY_H +#define __STM32F0xx_HAL_CAN_LEGACY_H + +#ifdef __cplusplus + extern "C" { +#endif + +#if defined(STM32F072xB) || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F078xx) || defined(STM32F091xC) || defined(STM32F098xx) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup CAN + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup CAN_Exported_Types CAN Exported Types + * @{ + */ +/** + * @brief HAL State structures definition + */ +typedef enum +{ + HAL_CAN_STATE_RESET = 0x00U, /*!< CAN not yet initialized or disabled */ + HAL_CAN_STATE_READY = 0x01U, /*!< CAN initialized and ready for use */ + HAL_CAN_STATE_BUSY = 0x02U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_BUSY_TX = 0x12U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_BUSY_RX0 = 0x22U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_BUSY_RX1 = 0x32U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_BUSY_TX_RX0 = 0x42U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_BUSY_TX_RX1 = 0x52U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_BUSY_RX0_RX1 = 0x62U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_BUSY_TX_RX0_RX1 = 0x72U, /*!< CAN process is ongoing */ + HAL_CAN_STATE_TIMEOUT = 0x03U, /*!< CAN in Timeout state */ + HAL_CAN_STATE_ERROR = 0x04U /*!< CAN error state */ + +}HAL_CAN_StateTypeDef; + +/** + * @brief CAN init structure definition + */ +typedef struct +{ + uint32_t Prescaler; /*!< Specifies the length of a time quantum. + This parameter must be a number between Min_Data = 1 and Max_Data = 1024. */ + + uint32_t Mode; /*!< Specifies the CAN operating mode. + This parameter can be a value of @ref CAN_operating_mode */ + + uint32_t SJW; /*!< Specifies the maximum number of time quanta + the CAN hardware is allowed to lengthen or + shorten a bit to perform resynchronization. + This parameter can be a value of @ref CAN_synchronisation_jump_width */ + + uint32_t BS1; /*!< Specifies the number of time quanta in Bit Segment 1. + This parameter can be a value of @ref CAN_time_quantum_in_bit_segment_1 */ + + uint32_t BS2; /*!< Specifies the number of time quanta in Bit Segment 2. + This parameter can be a value of @ref CAN_time_quantum_in_bit_segment_2 */ + + uint32_t TTCM; /*!< Enable or disable the time triggered communication mode. + This parameter can be set to ENABLE or DISABLE. */ + + uint32_t ABOM; /*!< Enable or disable the automatic bus-off management. + This parameter can be set to ENABLE or DISABLE. */ + + uint32_t AWUM; /*!< Enable or disable the automatic wake-up mode. + This parameter can be set to ENABLE or DISABLE. */ + + uint32_t NART; /*!< Enable or disable the non-automatic retransmission mode. + This parameter can be set to ENABLE or DISABLE. */ + + uint32_t RFLM; /*!< Enable or disable the Receive FIFO Locked mode. + This parameter can be set to ENABLE or DISABLE. */ + + uint32_t TXFP; /*!< Enable or disable the transmit FIFO priority. + This parameter can be set to ENABLE or DISABLE. */ +}CAN_InitTypeDef; + +/** + * @brief CAN filter configuration structure definition + */ +typedef struct +{ + uint32_t FilterIdHigh; /*!< Specifies the filter identification number (MSBs for a 32-bit + configuration, first one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterIdLow; /*!< Specifies the filter identification number (LSBs for a 32-bit + configuration, second one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterMaskIdHigh; /*!< Specifies the filter mask number or identification number, + according to the mode (MSBs for a 32-bit configuration, + first one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterMaskIdLow; /*!< Specifies the filter mask number or identification number, + according to the mode (LSBs for a 32-bit configuration, + second one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterFIFOAssignment; /*!< Specifies the FIFO (0 or 1U) which will be assigned to the filter. + This parameter can be a value of @ref CAN_filter_FIFO */ + + uint32_t FilterNumber; /*!< Specifies the filter which will be initialized. + This parameter must be a number between Min_Data = 0 and Max_Data = 27. */ + + uint32_t FilterMode; /*!< Specifies the filter mode to be initialized. + This parameter can be a value of @ref CAN_filter_mode */ + + uint32_t FilterScale; /*!< Specifies the filter scale. + This parameter can be a value of @ref CAN_filter_scale */ + + uint32_t FilterActivation; /*!< Enable or disable the filter. + This parameter can be set to ENABLE or DISABLE. */ + + uint32_t BankNumber; /*!< Select the start slave bank filter + This parameter must be a number between Min_Data = 0 and Max_Data = 28. */ + +}CAN_FilterConfTypeDef; + +/** + * @brief CAN Tx message structure definition + */ +typedef struct +{ + uint32_t StdId; /*!< Specifies the standard identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x7FF. */ + + uint32_t ExtId; /*!< Specifies the extended identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x1FFFFFFF. */ + + uint32_t IDE; /*!< Specifies the type of identifier for the message that will be transmitted. + This parameter can be a value of @ref CAN_identifier_type */ + + uint32_t RTR; /*!< Specifies the type of frame for the message that will be transmitted. + This parameter can be a value of @ref CAN_remote_transmission_request */ + + uint32_t DLC; /*!< Specifies the length of the frame that will be transmitted. + This parameter must be a number between Min_Data = 0 and Max_Data = 8. */ + + uint8_t Data[8]; /*!< Contains the data to be transmitted. + This parameter must be a number between Min_Data = 0 and Max_Data = 0xFF. */ + +}CanTxMsgTypeDef; + +/** + * @brief CAN Rx message structure definition + */ +typedef struct +{ + uint32_t StdId; /*!< Specifies the standard identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x7FF. */ + + uint32_t ExtId; /*!< Specifies the extended identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x1FFFFFFF. */ + + uint32_t IDE; /*!< Specifies the type of identifier for the message that will be received. + This parameter can be a value of @ref CAN_identifier_type */ + + uint32_t RTR; /*!< Specifies the type of frame for the received message. + This parameter can be a value of @ref CAN_remote_transmission_request */ + + uint32_t DLC; /*!< Specifies the length of the frame that will be received. + This parameter must be a number between Min_Data = 0 and Max_Data = 8. */ + + uint8_t Data[8]; /*!< Contains the data to be received. + This parameter must be a number between Min_Data = 0 and Max_Data = 0xFF. */ + + uint32_t FMI; /*!< Specifies the index of the filter the message stored in the mailbox passes through. + This parameter must be a number between Min_Data = 0 and Max_Data = 0xFF. */ + + uint32_t FIFONumber; /*!< Specifies the receive FIFO number. + This parameter can be CAN_FIFO0 or CAN_FIFO1 */ + +}CanRxMsgTypeDef; + +/** + * @brief CAN handle Structure definition + */ +typedef struct +{ + CAN_TypeDef *Instance; /*!< Register base address */ + + CAN_InitTypeDef Init; /*!< CAN required parameters */ + + CanTxMsgTypeDef* pTxMsg; /*!< Pointer to transmit structure */ + + CanRxMsgTypeDef* pRxMsg; /*!< Pointer to reception structure for RX FIFO0 msg */ + + CanRxMsgTypeDef* pRx1Msg; /*!< Pointer to reception structure for RX FIFO1 msg */ + + HAL_LockTypeDef Lock; /*!< CAN locking object */ + + __IO HAL_CAN_StateTypeDef State; /*!< CAN communication state */ + + __IO uint32_t ErrorCode; /*!< CAN Error code + This parameter can be a value of @ref CAN_Error_Code */ + +}CAN_HandleTypeDef; +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup CAN_Exported_Constants CAN Exported Constants + * @{ + */ + +/** @defgroup CAN_Error_Code CAN Error Code + * @{ + */ +#define HAL_CAN_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_CAN_ERROR_EWG (0x00000001U) /*!< EWG error */ +#define HAL_CAN_ERROR_EPV (0x00000002U) /*!< EPV error */ +#define HAL_CAN_ERROR_BOF (0x00000004U) /*!< BOF error */ +#define HAL_CAN_ERROR_STF (0x00000008U) /*!< Stuff error */ +#define HAL_CAN_ERROR_FOR (0x00000010U) /*!< Form error */ +#define HAL_CAN_ERROR_ACK (0x00000020U) /*!< Acknowledgment error */ +#define HAL_CAN_ERROR_BR (0x00000040U) /*!< Bit recessive */ +#define HAL_CAN_ERROR_BD (0x00000080U) /*!< LEC dominant */ +#define HAL_CAN_ERROR_CRC (0x00000100U) /*!< LEC transfer error */ +#define HAL_CAN_ERROR_FOV0 (0x00000200U) /*!< FIFO0 overrun error */ +#define HAL_CAN_ERROR_FOV1 (0x00000400U) /*!< FIFO1 overrun error */ +#define HAL_CAN_ERROR_TXFAIL (0x00000800U) /*!< Transmit failure */ +/** + * @} + */ + +/** @defgroup CAN_InitStatus CAN InitStatus + * @{ + */ +#define CAN_INITSTATUS_FAILED (0x00000000U) /*!< CAN initialization failed */ +#define CAN_INITSTATUS_SUCCESS (0x00000001U) /*!< CAN initialization OK */ +/** + * @} + */ + +/** @defgroup CAN_operating_mode CAN Operating Mode + * @{ + */ +#define CAN_MODE_NORMAL (0x00000000U) /*!< Normal mode */ +#define CAN_MODE_LOOPBACK ((uint32_t)CAN_BTR_LBKM) /*!< Loopback mode */ +#define CAN_MODE_SILENT ((uint32_t)CAN_BTR_SILM) /*!< Silent mode */ +#define CAN_MODE_SILENT_LOOPBACK ((uint32_t)(CAN_BTR_LBKM | CAN_BTR_SILM)) /*!< Loopback combined with silent mode */ +/** + * @} + */ + + +/** @defgroup CAN_synchronisation_jump_width CAN Synchronization Jump Width + * @{ + */ +#define CAN_SJW_1TQ (0x00000000U) /*!< 1 time quantum */ +#define CAN_SJW_2TQ ((uint32_t)CAN_BTR_SJW_0) /*!< 2 time quantum */ +#define CAN_SJW_3TQ ((uint32_t)CAN_BTR_SJW_1) /*!< 3 time quantum */ +#define CAN_SJW_4TQ ((uint32_t)CAN_BTR_SJW) /*!< 4 time quantum */ +/** + * @} + */ + +/** @defgroup CAN_time_quantum_in_bit_segment_1 CAN Time Quantum in Bit Segment 1 + * @{ + */ +#define CAN_BS1_1TQ (0x00000000U) /*!< 1 time quantum */ +#define CAN_BS1_2TQ ((uint32_t)CAN_BTR_TS1_0) /*!< 2 time quantum */ +#define CAN_BS1_3TQ ((uint32_t)CAN_BTR_TS1_1) /*!< 3 time quantum */ +#define CAN_BS1_4TQ ((uint32_t)(CAN_BTR_TS1_1 | CAN_BTR_TS1_0)) /*!< 4 time quantum */ +#define CAN_BS1_5TQ ((uint32_t)CAN_BTR_TS1_2) /*!< 5 time quantum */ +#define CAN_BS1_6TQ ((uint32_t)(CAN_BTR_TS1_2 | CAN_BTR_TS1_0)) /*!< 6 time quantum */ +#define CAN_BS1_7TQ ((uint32_t)(CAN_BTR_TS1_2 | CAN_BTR_TS1_1)) /*!< 7 time quantum */ +#define CAN_BS1_8TQ ((uint32_t)(CAN_BTR_TS1_2 | CAN_BTR_TS1_1 | CAN_BTR_TS1_0)) /*!< 8 time quantum */ +#define CAN_BS1_9TQ ((uint32_t)CAN_BTR_TS1_3) /*!< 9 time quantum */ +#define CAN_BS1_10TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_0)) /*!< 10 time quantum */ +#define CAN_BS1_11TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_1)) /*!< 11 time quantum */ +#define CAN_BS1_12TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_1 | CAN_BTR_TS1_0)) /*!< 12 time quantum */ +#define CAN_BS1_13TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_2)) /*!< 13 time quantum */ +#define CAN_BS1_14TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_2 | CAN_BTR_TS1_0)) /*!< 14 time quantum */ +#define CAN_BS1_15TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_2 | CAN_BTR_TS1_1)) /*!< 15 time quantum */ +#define CAN_BS1_16TQ ((uint32_t)CAN_BTR_TS1) /*!< 16 time quantum */ +/** + * @} + */ + +/** @defgroup CAN_time_quantum_in_bit_segment_2 CAN Time Quantum in Bit Segment 2 + * @{ + */ +#define CAN_BS2_1TQ (0x00000000U) /*!< 1 time quantum */ +#define CAN_BS2_2TQ ((uint32_t)CAN_BTR_TS2_0) /*!< 2 time quantum */ +#define CAN_BS2_3TQ ((uint32_t)CAN_BTR_TS2_1) /*!< 3 time quantum */ +#define CAN_BS2_4TQ ((uint32_t)(CAN_BTR_TS2_1 | CAN_BTR_TS2_0)) /*!< 4 time quantum */ +#define CAN_BS2_5TQ ((uint32_t)CAN_BTR_TS2_2) /*!< 5 time quantum */ +#define CAN_BS2_6TQ ((uint32_t)(CAN_BTR_TS2_2 | CAN_BTR_TS2_0)) /*!< 6 time quantum */ +#define CAN_BS2_7TQ ((uint32_t)(CAN_BTR_TS2_2 | CAN_BTR_TS2_1)) /*!< 7 time quantum */ +#define CAN_BS2_8TQ ((uint32_t)CAN_BTR_TS2) /*!< 8 time quantum */ +/** + * @} + */ + +/** @defgroup CAN_filter_mode CAN Filter Mode + * @{ + */ +#define CAN_FILTERMODE_IDMASK ((uint8_t)0x00U) /*!< Identifier mask mode */ +#define CAN_FILTERMODE_IDLIST ((uint8_t)0x01U) /*!< Identifier list mode */ +/** + * @} + */ + +/** @defgroup CAN_filter_scale CAN Filter Scale + * @{ + */ +#define CAN_FILTERSCALE_16BIT ((uint8_t)0x00U) /*!< Two 16-bit filters */ +#define CAN_FILTERSCALE_32BIT ((uint8_t)0x01U) /*!< One 32-bit filter */ +/** + * @} + */ + +/** @defgroup CAN_filter_FIFO CAN Filter FIFO + * @{ + */ +#define CAN_FILTER_FIFO0 ((uint8_t)0x00U) /*!< Filter FIFO 0 assignment for filter x */ +#define CAN_FILTER_FIFO1 ((uint8_t)0x01U) /*!< Filter FIFO 1 assignment for filter x */ +/** + * @} + */ + +/** @defgroup CAN_identifier_type CAN Identifier Type + * @{ + */ +#define CAN_ID_STD (0x00000000U) /*!< Standard Id */ +#define CAN_ID_EXT (0x00000004U) /*!< Extended Id */ +/** + * @} + */ + +/** @defgroup CAN_remote_transmission_request CAN Remote Transmission Request + * @{ + */ +#define CAN_RTR_DATA (0x00000000U) /*!< Data frame */ +#define CAN_RTR_REMOTE (0x00000002U) /*!< Remote frame */ +/** + * @} + */ + +/** @defgroup CAN_receive_FIFO_number_constants CAN Receive FIFO Number + * @{ + */ +#define CAN_FIFO0 ((uint8_t)0x00U) /*!< CAN FIFO 0 used to receive */ +#define CAN_FIFO1 ((uint8_t)0x01U) /*!< CAN FIFO 1 used to receive */ +/** + * @} + */ + +/** @defgroup CAN_flags CAN Flags + * @{ + */ +/* If the flag is 0x3XXXXXXX, it means that it can be used with CAN_GetFlagStatus() + and CAN_ClearFlag() functions. */ +/* If the flag is 0x1XXXXXXX, it means that it can only be used with + CAN_GetFlagStatus() function. */ + +/* Transmit Flags */ +#define CAN_FLAG_RQCP0 (0x00000500U) /*!< Request MailBox0 flag */ +#define CAN_FLAG_RQCP1 (0x00000508U) /*!< Request MailBox1 flag */ +#define CAN_FLAG_RQCP2 (0x00000510U) /*!< Request MailBox2 flag */ +#define CAN_FLAG_TXOK0 (0x00000501U) /*!< Transmission OK MailBox0 flag */ +#define CAN_FLAG_TXOK1 (0x00000509U) /*!< Transmission OK MailBox1 flag */ +#define CAN_FLAG_TXOK2 (0x00000511U) /*!< Transmission OK MailBox2 flag */ +#define CAN_FLAG_TME0 (0x0000051AU) /*!< Transmit mailbox 0 empty flag */ +#define CAN_FLAG_TME1 (0x0000051BU) /*!< Transmit mailbox 0 empty flag */ +#define CAN_FLAG_TME2 (0x0000051CU) /*!< Transmit mailbox 0 empty flag */ + +/* Receive Flags */ +#define CAN_FLAG_FF0 (0x00000203U) /*!< FIFO 0 Full flag */ +#define CAN_FLAG_FOV0 (0x00000204U) /*!< FIFO 0 Overrun flag */ + +#define CAN_FLAG_FF1 (0x00000403U) /*!< FIFO 1 Full flag */ +#define CAN_FLAG_FOV1 (0x00000404U) /*!< FIFO 1 Overrun flag */ + +/* Operating Mode Flags */ +#define CAN_FLAG_INAK (0x00000100U) /*!< Initialization acknowledge flag */ +#define CAN_FLAG_SLAK (0x00000101U) /*!< Sleep acknowledge flag */ +#define CAN_FLAG_ERRI (0x00000102U) /*!< Error flag */ +#define CAN_FLAG_WKU (0x00000103U) /*!< Wake up flag */ +#define CAN_FLAG_SLAKI (0x00000104U) /*!< Sleep acknowledge flag */ +/* @note When SLAK interrupt is disabled (SLKIE=0U), no polling on SLAKI is possible. + In this case the SLAK bit can be polled.*/ + +/* Error Flags */ +#define CAN_FLAG_EWG (0x00000300U) /*!< Error warning flag */ +#define CAN_FLAG_EPV (0x00000301U) /*!< Error passive flag */ +#define CAN_FLAG_BOF (0x00000302U) /*!< Bus-Off flag */ + +/** + * @} + */ + + +/** @defgroup CAN_interrupts CAN Interrupts + * @{ + */ +#define CAN_IT_TME ((uint32_t)CAN_IER_TMEIE) /*!< Transmit mailbox empty interrupt */ + +/* Receive Interrupts */ +#define CAN_IT_FMP0 ((uint32_t)CAN_IER_FMPIE0) /*!< FIFO 0 message pending interrupt */ +#define CAN_IT_FF0 ((uint32_t)CAN_IER_FFIE0) /*!< FIFO 0 full interrupt */ +#define CAN_IT_FOV0 ((uint32_t)CAN_IER_FOVIE0) /*!< FIFO 0 overrun interrupt */ +#define CAN_IT_FMP1 ((uint32_t)CAN_IER_FMPIE1) /*!< FIFO 1 message pending interrupt */ +#define CAN_IT_FF1 ((uint32_t)CAN_IER_FFIE1) /*!< FIFO 1 full interrupt */ +#define CAN_IT_FOV1 ((uint32_t)CAN_IER_FOVIE1) /*!< FIFO 1 overrun interrupt */ + +/* Operating Mode Interrupts */ +#define CAN_IT_WKU ((uint32_t)CAN_IER_WKUIE) /*!< Wake-up interrupt */ +#define CAN_IT_SLK ((uint32_t)CAN_IER_SLKIE) /*!< Sleep acknowledge interrupt */ + +/* Error Interrupts */ +#define CAN_IT_EWG ((uint32_t)CAN_IER_EWGIE) /*!< Error warning interrupt */ +#define CAN_IT_EPV ((uint32_t)CAN_IER_EPVIE) /*!< Error passive interrupt */ +#define CAN_IT_BOF ((uint32_t)CAN_IER_BOFIE) /*!< Bus-off interrupt */ +#define CAN_IT_LEC ((uint32_t)CAN_IER_LECIE) /*!< Last error code interrupt */ +#define CAN_IT_ERR ((uint32_t)CAN_IER_ERRIE) /*!< Error Interrupt */ + +/** + * @} + */ + +/** @defgroup CAN_Mailboxes CAN Mailboxes +* @{ +*/ +/* Mailboxes definition */ +#define CAN_TXMAILBOX_0 ((uint8_t)0x00U) +#define CAN_TXMAILBOX_1 ((uint8_t)0x01U) +#define CAN_TXMAILBOX_2 ((uint8_t)0x02U) +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup CAN_Exported_Macros CAN Exported Macros + * @{ + */ + +/** @brief Reset CAN handle state + * @param __HANDLE__ CAN handle. + * @retval None + */ +#define __HAL_CAN_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_CAN_STATE_RESET) + +/** + * @brief Enable the specified CAN interrupts. + * @param __HANDLE__ CAN handle. + * @param __INTERRUPT__ CAN Interrupt + * @retval None + */ +#define __HAL_CAN_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->IER) |= (__INTERRUPT__)) + +/** + * @brief Disable the specified CAN interrupts. + * @param __HANDLE__ CAN handle. + * @param __INTERRUPT__ CAN Interrupt + * @retval None + */ +#define __HAL_CAN_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->IER) &= ~(__INTERRUPT__)) + +/** + * @brief Return the number of pending received messages. + * @param __HANDLE__ CAN handle. + * @param __FIFONUMBER__ Receive FIFO number, CAN_FIFO0 or CAN_FIFO1. + * @retval The number of pending message. + */ +#define __HAL_CAN_MSG_PENDING(__HANDLE__, __FIFONUMBER__) (((__FIFONUMBER__) == CAN_FIFO0)? \ +((uint8_t)((__HANDLE__)->Instance->RF0R&0x03U)) : ((uint8_t)((__HANDLE__)->Instance->RF1R&0x03U))) + +/** @brief Check whether the specified CAN flag is set or not. + * @param __HANDLE__ specifies the CAN Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg CAN_TSR_RQCP0: Request MailBox0 Flag + * @arg CAN_TSR_RQCP1: Request MailBox1 Flag + * @arg CAN_TSR_RQCP2: Request MailBox2 Flag + * @arg CAN_FLAG_TXOK0: Transmission OK MailBox0 Flag + * @arg CAN_FLAG_TXOK1: Transmission OK MailBox1 Flag + * @arg CAN_FLAG_TXOK2: Transmission OK MailBox2 Flag + * @arg CAN_FLAG_TME0: Transmit mailbox 0 empty Flag + * @arg CAN_FLAG_TME1: Transmit mailbox 1 empty Flag + * @arg CAN_FLAG_TME2: Transmit mailbox 2 empty Flag + * @arg CAN_FLAG_FMP0: FIFO 0 Message Pending Flag + * @arg CAN_FLAG_FF0: FIFO 0 Full Flag + * @arg CAN_FLAG_FOV0: FIFO 0 Overrun Flag + * @arg CAN_FLAG_FMP1: FIFO 1 Message Pending Flag + * @arg CAN_FLAG_FF1: FIFO 1 Full Flag + * @arg CAN_FLAG_FOV1: FIFO 1 Overrun Flag + * @arg CAN_FLAG_WKU: Wake up Flag + * @arg CAN_FLAG_SLAK: Sleep acknowledge Flag + * @arg CAN_FLAG_SLAKI: Sleep acknowledge Flag + * @arg CAN_FLAG_EWG: Error Warning Flag + * @arg CAN_FLAG_EPV: Error Passive Flag + * @arg CAN_FLAG_BOF: Bus-Off Flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_CAN_GET_FLAG(__HANDLE__, __FLAG__) \ +((((__FLAG__) >> 8U) == 5U)? ((((__HANDLE__)->Instance->TSR) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 2U)? ((((__HANDLE__)->Instance->RF0R) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 4U)? ((((__HANDLE__)->Instance->RF1R) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 1U)? ((((__HANDLE__)->Instance->MSR) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + ((((__HANDLE__)->Instance->ESR) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK)))) + +/** @brief Clear the specified CAN pending flag. + * @param __HANDLE__ specifies the CAN Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg CAN_TSR_RQCP0: Request MailBox0 Flag + * @arg CAN_TSR_RQCP1: Request MailBox1 Flag + * @arg CAN_TSR_RQCP2: Request MailBox2 Flag + * @arg CAN_FLAG_TXOK0: Transmission OK MailBox0 Flag + * @arg CAN_FLAG_TXOK1: Transmission OK MailBox1 Flag + * @arg CAN_FLAG_TXOK2: Transmission OK MailBox2 Flag + * @arg CAN_FLAG_TME0: Transmit mailbox 0 empty Flag + * @arg CAN_FLAG_TME1: Transmit mailbox 1 empty Flag + * @arg CAN_FLAG_TME2: Transmit mailbox 2 empty Flag + * @arg CAN_FLAG_FMP0: FIFO 0 Message Pending Flag + * @arg CAN_FLAG_FF0: FIFO 0 Full Flag + * @arg CAN_FLAG_FOV0: FIFO 0 Overrun Flag + * @arg CAN_FLAG_FMP1: FIFO 1 Message Pending Flag + * @arg CAN_FLAG_FF1: FIFO 1 Full Flag + * @arg CAN_FLAG_FOV1: FIFO 1 Overrun Flag + * @arg CAN_FLAG_WKU: Wake up Flag + * @arg CAN_FLAG_SLAKI: Sleep acknowledge Flag + * @arg CAN_FLAG_EWG: Error Warning Flag + * @arg CAN_FLAG_EPV: Error Passive Flag + * @arg CAN_FLAG_BOF: Bus-Off Flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_CAN_CLEAR_FLAG(__HANDLE__, __FLAG__) \ +((((__FLAG__) >> 8U) == 5U)? (((__HANDLE__)->Instance->TSR) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 2U)? (((__HANDLE__)->Instance->RF0R) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 4U)? (((__HANDLE__)->Instance->RF1R) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 1U)? (((__HANDLE__)->Instance->MSR) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): 0U) + + +/** @brief Check if the specified CAN interrupt source is enabled or disabled. + * @param __HANDLE__ specifies the CAN Handle. + * @param __INTERRUPT__ specifies the CAN interrupt source to check. + * This parameter can be one of the following values: + * @arg CAN_IT_TME: Transmit mailbox empty interrupt enable + * @arg CAN_IT_FMP0: FIFO0 message pending interrupt enablev + * @arg CAN_IT_FMP1: FIFO1 message pending interrupt enable + * @retval The new state of __IT__ (TRUE or FALSE). + */ +#define __HAL_CAN_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->IER & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET) + +/** + * @brief Check the transmission status of a CAN Frame. + * @param __HANDLE__ CAN handle. + * @param __TRANSMITMAILBOX__ the number of the mailbox that is used for transmission. + * @retval The new status of transmission (TRUE or FALSE). + */ +#define __HAL_CAN_TRANSMIT_STATUS(__HANDLE__, __TRANSMITMAILBOX__)\ +(((__TRANSMITMAILBOX__) == CAN_TXMAILBOX_0)? ((((__HANDLE__)->Instance->TSR) & (CAN_TSR_RQCP0 | CAN_TSR_TME0)) == (CAN_TSR_RQCP0 | CAN_TSR_TME0)) :\ + ((__TRANSMITMAILBOX__) == CAN_TXMAILBOX_1)? ((((__HANDLE__)->Instance->TSR) & (CAN_TSR_RQCP1 | CAN_TSR_TME1)) == (CAN_TSR_RQCP1 | CAN_TSR_TME1)) :\ + ((((__HANDLE__)->Instance->TSR) & (CAN_TSR_RQCP2 | CAN_TSR_TME2)) == (CAN_TSR_RQCP2 | CAN_TSR_TME2))) + + /** + * @brief Release the specified receive FIFO. + * @param __HANDLE__ CAN handle. + * @param __FIFONUMBER__ Receive FIFO number, CAN_FIFO0 or CAN_FIFO1. + * @retval None + */ +#define __HAL_CAN_FIFO_RELEASE(__HANDLE__, __FIFONUMBER__) (((__FIFONUMBER__) == CAN_FIFO0)? \ +((__HANDLE__)->Instance->RF0R |= CAN_RF0R_RFOM0) : ((__HANDLE__)->Instance->RF1R |= CAN_RF1R_RFOM1)) + +/** + * @brief Cancel a transmit request. + * @param __HANDLE__ specifies the CAN Handle. + * @param __TRANSMITMAILBOX__ the number of the mailbox that is used for transmission. + * @retval None + */ +#define __HAL_CAN_CANCEL_TRANSMIT(__HANDLE__, __TRANSMITMAILBOX__)\ +(((__TRANSMITMAILBOX__) == CAN_TXMAILBOX_0)? ((__HANDLE__)->Instance->TSR |= CAN_TSR_ABRQ0) :\ + ((__TRANSMITMAILBOX__) == CAN_TXMAILBOX_1)? ((__HANDLE__)->Instance->TSR |= CAN_TSR_ABRQ1) :\ + ((__HANDLE__)->Instance->TSR |= CAN_TSR_ABRQ2)) + +/** + * @brief Enable or disables the DBG Freeze for CAN. + * @param __HANDLE__ specifies the CAN Handle. + * @param __NEWSTATE__ new state of the CAN peripheral. + * This parameter can be: ENABLE (CAN reception/transmission is frozen + * during debug. Reception FIFOs can still be accessed/controlled normally) + * or DISABLE (CAN is working during debug). + * @retval None + */ +#define __HAL_CAN_DBG_FREEZE(__HANDLE__, __NEWSTATE__) (((__NEWSTATE__) == ENABLE)? \ +((__HANDLE__)->Instance->MCR |= CAN_MCR_DBF) : ((__HANDLE__)->Instance->MCR &= ~CAN_MCR_DBF)) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup CAN_Exported_Functions CAN Exported Functions + * @{ + */ + +/** @addtogroup CAN_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * @{ + */ + +/* Initialization and de-initialization functions *****************************/ +HAL_StatusTypeDef HAL_CAN_Init(CAN_HandleTypeDef* hcan); +HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef* hcan, CAN_FilterConfTypeDef* sFilterConfig); +HAL_StatusTypeDef HAL_CAN_DeInit(CAN_HandleTypeDef* hcan); +void HAL_CAN_MspInit(CAN_HandleTypeDef* hcan); +void HAL_CAN_MspDeInit(CAN_HandleTypeDef* hcan); +/** + * @} + */ + +/** @addtogroup CAN_Exported_Functions_Group2 Input and Output operation functions + * @brief I/O operation functions + * @{ + */ +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_CAN_Transmit(CAN_HandleTypeDef *hcan, uint32_t Timeout); +HAL_StatusTypeDef HAL_CAN_Transmit_IT(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_Receive(CAN_HandleTypeDef *hcan, uint8_t FIFONumber, uint32_t Timeout); +HAL_StatusTypeDef HAL_CAN_Receive_IT(CAN_HandleTypeDef *hcan, uint8_t FIFONumber); +HAL_StatusTypeDef HAL_CAN_Sleep(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan); +void HAL_CAN_IRQHandler(CAN_HandleTypeDef* hcan); +void HAL_CAN_TxCpltCallback(CAN_HandleTypeDef* hcan); +void HAL_CAN_RxCpltCallback(CAN_HandleTypeDef* hcan); +void HAL_CAN_ErrorCallback(CAN_HandleTypeDef *hcan); +/** + * @} + */ + +/** @addtogroup CAN_Exported_Functions_Group3 Peripheral State and Error functions + * @brief CAN Peripheral State functions + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +uint32_t HAL_CAN_GetError(CAN_HandleTypeDef *hcan); +HAL_CAN_StateTypeDef HAL_CAN_GetState(CAN_HandleTypeDef* hcan); +/** + * @} + */ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/** @defgroup CAN_Private_Types CAN Private Types + * @{ + */ + +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/** @defgroup CAN_Private_Variables CAN Private Variables + * @{ + */ + +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup CAN_Private_Constants CAN Private Constants + * @{ + */ +#define CAN_TXSTATUS_NOMAILBOX ((uint8_t)0x04U) /*!< CAN cell did not provide CAN_TxStatus_NoMailBox */ +#define CAN_FLAG_MASK (0x000000FFU) +/** + * @} + */ + +/* Private Macros -----------------------------------------------------------*/ +/** @defgroup CAN_Private_Macros CAN Private Macros + * @{ + */ + +#define IS_CAN_MODE(MODE) (((MODE) == CAN_MODE_NORMAL) || \ + ((MODE) == CAN_MODE_LOOPBACK)|| \ + ((MODE) == CAN_MODE_SILENT) || \ + ((MODE) == CAN_MODE_SILENT_LOOPBACK)) + +#define IS_CAN_SJW(SJW) (((SJW) == CAN_SJW_1TQ) || ((SJW) == CAN_SJW_2TQ)|| \ + ((SJW) == CAN_SJW_3TQ) || ((SJW) == CAN_SJW_4TQ)) + +#define IS_CAN_BS1(BS1) ((BS1) <= CAN_BS1_16TQ) + +#define IS_CAN_BS2(BS2) ((BS2) <= CAN_BS2_8TQ) + +#define IS_CAN_PRESCALER(PRESCALER) (((PRESCALER) >= 1U) && ((PRESCALER) <= 1024U)) + +#define IS_CAN_FILTER_NUMBER(NUMBER) ((NUMBER) <= 27U) + +#define IS_CAN_FILTER_MODE(MODE) (((MODE) == CAN_FILTERMODE_IDMASK) || \ + ((MODE) == CAN_FILTERMODE_IDLIST)) + +#define IS_CAN_FILTER_SCALE(SCALE) (((SCALE) == CAN_FILTERSCALE_16BIT) || \ + ((SCALE) == CAN_FILTERSCALE_32BIT)) + +#define IS_CAN_FILTER_FIFO(FIFO) (((FIFO) == CAN_FILTER_FIFO0) || \ + ((FIFO) == CAN_FILTER_FIFO1)) + +#define IS_CAN_BANKNUMBER(BANKNUMBER) ((BANKNUMBER) <= 28U) + +#define IS_CAN_TRANSMITMAILBOX(TRANSMITMAILBOX) ((TRANSMITMAILBOX) <= ((uint8_t)0x02U)) +#define IS_CAN_STDID(STDID) ((STDID) <= (0x7FFU)) +#define IS_CAN_EXTID(EXTID) ((EXTID) <= (0x1FFFFFFFU)) +#define IS_CAN_DLC(DLC) ((DLC) <= ((uint8_t)0x08U)) + +#define IS_CAN_IDTYPE(IDTYPE) (((IDTYPE) == CAN_ID_STD) || \ + ((IDTYPE) == CAN_ID_EXT)) + +#define IS_CAN_RTR(RTR) (((RTR) == CAN_RTR_DATA) || ((RTR) == CAN_RTR_REMOTE)) + +#define IS_CAN_FIFO(FIFO) (((FIFO) == CAN_FIFO0) || ((FIFO) == CAN_FIFO1)) + +#define IS_CAN_IT(IT) (((IT) == CAN_IT_TME) || ((IT) == CAN_IT_FMP0) ||\ + ((IT) == CAN_IT_FF0) || ((IT) == CAN_IT_FOV0) ||\ + ((IT) == CAN_IT_FMP1) || ((IT) == CAN_IT_FF1) ||\ + ((IT) == CAN_IT_FOV1) || ((IT) == CAN_IT_EWG) ||\ + ((IT) == CAN_IT_EPV) || ((IT) == CAN_IT_BOF) ||\ + ((IT) == CAN_IT_LEC) || ((IT) == CAN_IT_ERR) ||\ + ((IT) == CAN_IT_WKU) || ((IT) == CAN_IT_SLK)) + +#define IS_CAN_CLEAR_IT(IT) (((IT) == CAN_IT_TME) || ((IT) == CAN_IT_FF0) ||\ + ((IT) == CAN_IT_FOV0)|| ((IT) == CAN_IT_FF1) ||\ + ((IT) == CAN_IT_FOV1)|| ((IT) == CAN_IT_EWG) ||\ + ((IT) == CAN_IT_EPV) || ((IT) == CAN_IT_BOF) ||\ + ((IT) == CAN_IT_LEC) || ((IT) == CAN_IT_ERR) ||\ + ((IT) == CAN_IT_WKU) || ((IT) == CAN_IT_SLK)) + +/** + * @} + */ +/* End of private macros -----------------------------------------------------*/ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* STM32F072xB || STM32F042x6 || STM32F048xx || STM32F078xx || STM32F091xC || STM32F098xx */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_CAN_LEGACY_H */ + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32_assert_template.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32_assert_template.h new file mode 100644 index 0000000..26110e6 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32_assert_template.h @@ -0,0 +1,57 @@ +/** + ****************************************************************************** + * @file stm32_assert.h + * @author MCD Application Team + * @brief STM32 assert template file. + * This file should be copied to the application folder and renamed + * to stm32_assert.h. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32_ASSERT_H +#define __STM32_ASSERT_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/* Includes ------------------------------------------------------------------*/ +/* Exported macro ------------------------------------------------------------*/ +#ifdef USE_FULL_ASSERT +/** + * @brief The assert_param macro is used for function's parameters check. + * @param expr If expr is false, it calls assert_failed function + * which reports the name of the source file and the source + * line number of the call that failed. + * If expr is true, it returns no value. + * @retval None + */ + #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__)) +/* Exported functions ------------------------------------------------------- */ + void assert_failed(uint8_t* file, uint32_t line); +#else + #define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32_ASSERT_H */ + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal.h new file mode 100644 index 0000000..a100055 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal.h @@ -0,0 +1,585 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal.h + * @author MCD Application Team + * @brief This file contains all the functions prototypes for the HAL + * module driver. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_H +#define __STM32F0xx_HAL_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_conf.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup HAL + * @{ + */ + +/* Private macros ------------------------------------------------------------*/ +/** @addtogroup HAL_Private_Macros + * @{ + */ +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F042x6) || defined(STM32F048xx) || \ + defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) || defined(STM32F070x6) || \ + defined(STM32F070xB) || defined(STM32F030x6) +#define IS_SYSCFG_FASTMODEPLUS(__PIN__) ((((__PIN__) & SYSCFG_FASTMODEPLUS_PA9) == SYSCFG_FASTMODEPLUS_PA9) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PA10) == SYSCFG_FASTMODEPLUS_PA10) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PB6) == SYSCFG_FASTMODEPLUS_PB6) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PB7) == SYSCFG_FASTMODEPLUS_PB7) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PB8) == SYSCFG_FASTMODEPLUS_PB8) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PB9) == SYSCFG_FASTMODEPLUS_PB9)) +#else +#define IS_SYSCFG_FASTMODEPLUS(__PIN__) ((((__PIN__) & SYSCFG_FASTMODEPLUS_PB6) == SYSCFG_FASTMODEPLUS_PB6) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PB7) == SYSCFG_FASTMODEPLUS_PB7) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PB8) == SYSCFG_FASTMODEPLUS_PB8) || \ + (((__PIN__) & SYSCFG_FASTMODEPLUS_PB9) == SYSCFG_FASTMODEPLUS_PB9)) +#endif +#if defined(SYSCFG_CFGR1_PA11_PA12_RMP) +#define IS_HAL_REMAP_PIN(RMP) ((RMP) == HAL_REMAP_PA11_PA12) +#endif /* SYSCFG_CFGR1_PA11_PA12_RMP */ +#if defined(STM32F091xC) || defined(STM32F098xx) +#define IS_HAL_SYSCFG_IRDA_ENV_SEL(SEL) (((SEL) == HAL_SYSCFG_IRDA_ENV_SEL_TIM16) || \ + ((SEL) == HAL_SYSCFG_IRDA_ENV_SEL_USART1) || \ + ((SEL) == HAL_SYSCFG_IRDA_ENV_SEL_USART4)) +#endif /* STM32F091xC || STM32F098xx */ +/** + * @} + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup HAL_Exported_Constants HAL Exported Constants + * @{ + */ + +/** @defgroup HAL_TICK_FREQ Tick Frequency + * @{ + */ +typedef enum +{ + HAL_TICK_FREQ_10HZ = 100U, + HAL_TICK_FREQ_100HZ = 10U, + HAL_TICK_FREQ_1KHZ = 1U, + HAL_TICK_FREQ_DEFAULT = HAL_TICK_FREQ_1KHZ +} HAL_TickFreqTypeDef; + +/** + * @} + */ + +#if defined(SYSCFG_CFGR1_PA11_PA12_RMP) +/** @defgroup HAL_Pin_remapping HAL Pin remapping + * @{ + */ +#define HAL_REMAP_PA11_PA12 (SYSCFG_CFGR1_PA11_PA12_RMP) /*!< PA11 and PA12 remapping bit for small packages (28 and 20 pins). + 0: No remap (pin pair PA9/10 mapped on the pins) + 1: Remap (pin pair PA11/12 mapped instead of PA9/10) */ + +/** + * @} + */ +#endif /* SYSCFG_CFGR1_PA11_PA12_RMP */ + +#if defined(STM32F091xC) || defined(STM32F098xx) +/** @defgroup HAL_IRDA_ENV_SEL HAL IRDA Enveloppe Selection + * @note Applicable on STM32F09x + * @{ + */ +#define HAL_SYSCFG_IRDA_ENV_SEL_TIM16 (SYSCFG_CFGR1_IRDA_ENV_SEL_0 & SYSCFG_CFGR1_IRDA_ENV_SEL_1) /* 00: Timer16 is selected as IRDA Modulation enveloppe source */ +#define HAL_SYSCFG_IRDA_ENV_SEL_USART1 (SYSCFG_CFGR1_IRDA_ENV_SEL_0) /* 01: USART1 is selected as IRDA Modulation enveloppe source */ +#define HAL_SYSCFG_IRDA_ENV_SEL_USART4 (SYSCFG_CFGR1_IRDA_ENV_SEL_1) /* 10: USART4 is selected as IRDA Modulation enveloppe source */ + +/** + * @} + */ +#endif /* STM32F091xC || STM32F098xx */ + + +/** @defgroup SYSCFG_FastModePlus_GPIO Fast-mode Plus on GPIO + * @{ + */ + +/** @brief Fast-mode Plus driving capability on a specific GPIO + */ +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F042x6) || defined(STM32F048xx) || \ + defined(STM32F030x6) || defined(STM32F031x6) || defined(STM32F038xx) || defined(STM32F070x6) || \ + defined(STM32F070xB) || defined(STM32F030x6) +#define SYSCFG_FASTMODEPLUS_PA9 SYSCFG_CFGR1_I2C_FMP_PA9 /*!< Enable Fast-mode Plus on PA9 */ +#define SYSCFG_FASTMODEPLUS_PA10 SYSCFG_CFGR1_I2C_FMP_PA10 /*!< Enable Fast-mode Plus on PA10 */ +#endif +#define SYSCFG_FASTMODEPLUS_PB6 SYSCFG_CFGR1_I2C_FMP_PB6 /*!< Enable Fast-mode Plus on PB6 */ +#define SYSCFG_FASTMODEPLUS_PB7 SYSCFG_CFGR1_I2C_FMP_PB7 /*!< Enable Fast-mode Plus on PB7 */ +#define SYSCFG_FASTMODEPLUS_PB8 SYSCFG_CFGR1_I2C_FMP_PB8 /*!< Enable Fast-mode Plus on PB8 */ +#define SYSCFG_FASTMODEPLUS_PB9 SYSCFG_CFGR1_I2C_FMP_PB9 /*!< Enable Fast-mode Plus on PB9 */ + +/** + * @} + */ + + +#if defined(STM32F091xC) || defined (STM32F098xx) +/** @defgroup HAL_ISR_Wrapper HAL ISR Wrapper + * @brief ISR Wrapper + * @note applicable on STM32F09x + * @{ + */ +#define HAL_SYSCFG_ITLINE0 ( 0x00000000U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE1 ( 0x00000001U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE2 ( 0x00000002U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE3 ( 0x00000003U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE4 ( 0x00000004U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE5 ( 0x00000005U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE6 ( 0x00000006U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE7 ( 0x00000007U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE8 ( 0x00000008U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE9 ( 0x00000009U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE10 ( 0x0000000AU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE11 ( 0x0000000BU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE12 ( 0x0000000CU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE13 ( 0x0000000DU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE14 ( 0x0000000EU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE15 ( 0x0000000FU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE16 ( 0x00000010U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE17 ( 0x00000011U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE18 ( 0x00000012U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE19 ( 0x00000013U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE20 ( 0x00000014U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE21 ( 0x00000015U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE22 ( 0x00000016U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE23 ( 0x00000017U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE24 ( 0x00000018U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE25 ( 0x00000019U) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE26 ( 0x0000001AU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE27 ( 0x0000001BU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE28 ( 0x0000001CU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE29 ( 0x0000001DU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE30 ( 0x0000001EU) /*!< Internal define for macro handling */ +#define HAL_SYSCFG_ITLINE31 ( 0x0000001FU) /*!< Internal define for macro handling */ + +#define HAL_ITLINE_EWDG ((uint32_t) ((HAL_SYSCFG_ITLINE0 << 0x18U) | SYSCFG_ITLINE0_SR_EWDG)) /*!< EWDG has expired .... */ +#if defined(STM32F091xC) +#define HAL_ITLINE_PVDOUT ((uint32_t) ((HAL_SYSCFG_ITLINE1 << 0x18U) | SYSCFG_ITLINE1_SR_PVDOUT)) /*!< Power voltage detection Interrupt .... */ +#endif +#define HAL_ITLINE_VDDIO2 ((uint32_t) ((HAL_SYSCFG_ITLINE1 << 0x18U) | SYSCFG_ITLINE1_SR_VDDIO2)) /*!< VDDIO2 Interrupt .... */ +#define HAL_ITLINE_RTC_WAKEUP ((uint32_t) ((HAL_SYSCFG_ITLINE2 << 0x18U) | SYSCFG_ITLINE2_SR_RTC_WAKEUP)) /*!< RTC WAKEUP -> exti[20] Interrupt */ +#define HAL_ITLINE_RTC_TSTAMP ((uint32_t) ((HAL_SYSCFG_ITLINE2 << 0x18U) | SYSCFG_ITLINE2_SR_RTC_TSTAMP)) /*!< RTC Time Stamp -> exti[19] interrupt */ +#define HAL_ITLINE_RTC_ALRA ((uint32_t) ((HAL_SYSCFG_ITLINE2 << 0x18U) | SYSCFG_ITLINE2_SR_RTC_ALRA)) /*!< RTC Alarm -> exti[17] interrupt .... */ +#define HAL_ITLINE_FLASH_ITF ((uint32_t) ((HAL_SYSCFG_ITLINE3 << 0x18U) | SYSCFG_ITLINE3_SR_FLASH_ITF)) /*!< Flash ITF Interrupt */ +#define HAL_ITLINE_CRS ((uint32_t) ((HAL_SYSCFG_ITLINE4 << 0x18U) | SYSCFG_ITLINE4_SR_CRS)) /*!< CRS Interrupt */ +#define HAL_ITLINE_CLK_CTRL ((uint32_t) ((HAL_SYSCFG_ITLINE4 << 0x18U) | SYSCFG_ITLINE4_SR_CLK_CTRL)) /*!< CLK Control Interrupt */ +#define HAL_ITLINE_EXTI0 ((uint32_t) ((HAL_SYSCFG_ITLINE5 << 0x18U) | SYSCFG_ITLINE5_SR_EXTI0)) /*!< External Interrupt 0 */ +#define HAL_ITLINE_EXTI1 ((uint32_t) ((HAL_SYSCFG_ITLINE5 << 0x18U) | SYSCFG_ITLINE5_SR_EXTI1)) /*!< External Interrupt 1 */ +#define HAL_ITLINE_EXTI2 ((uint32_t) ((HAL_SYSCFG_ITLINE6 << 0x18U) | SYSCFG_ITLINE6_SR_EXTI2)) /*!< External Interrupt 2 */ +#define HAL_ITLINE_EXTI3 ((uint32_t) ((HAL_SYSCFG_ITLINE6 << 0x18U) | SYSCFG_ITLINE6_SR_EXTI3)) /*!< External Interrupt 3 */ +#define HAL_ITLINE_EXTI4 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI4)) /*!< EXTI4 Interrupt */ +#define HAL_ITLINE_EXTI5 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI5)) /*!< EXTI5 Interrupt */ +#define HAL_ITLINE_EXTI6 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI6)) /*!< EXTI6 Interrupt */ +#define HAL_ITLINE_EXTI7 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI7)) /*!< EXTI7 Interrupt */ +#define HAL_ITLINE_EXTI8 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI8)) /*!< EXTI8 Interrupt */ +#define HAL_ITLINE_EXTI9 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI9)) /*!< EXTI9 Interrupt */ +#define HAL_ITLINE_EXTI10 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI10)) /*!< EXTI10 Interrupt */ +#define HAL_ITLINE_EXTI11 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI11)) /*!< EXTI11 Interrupt */ +#define HAL_ITLINE_EXTI12 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI12)) /*!< EXTI12 Interrupt */ +#define HAL_ITLINE_EXTI13 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI13)) /*!< EXTI13 Interrupt */ +#define HAL_ITLINE_EXTI14 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI14)) /*!< EXTI14 Interrupt */ +#define HAL_ITLINE_EXTI15 ((uint32_t) ((HAL_SYSCFG_ITLINE7 << 0x18U) | SYSCFG_ITLINE7_SR_EXTI15)) /*!< EXTI15 Interrupt */ +#define HAL_ITLINE_TSC_EOA ((uint32_t) ((HAL_SYSCFG_ITLINE8 << 0x18U) | SYSCFG_ITLINE8_SR_TSC_EOA)) /*!< Touch control EOA Interrupt */ +#define HAL_ITLINE_TSC_MCE ((uint32_t) ((HAL_SYSCFG_ITLINE8 << 0x18U) | SYSCFG_ITLINE8_SR_TSC_MCE)) /*!< Touch control MCE Interrupt */ +#define HAL_ITLINE_DMA1_CH1 ((uint32_t) ((HAL_SYSCFG_ITLINE9 << 0x18U) | SYSCFG_ITLINE9_SR_DMA1_CH1)) /*!< DMA1 Channel 1 Interrupt */ +#define HAL_ITLINE_DMA1_CH2 ((uint32_t) ((HAL_SYSCFG_ITLINE10 << 0x18U) | SYSCFG_ITLINE10_SR_DMA1_CH2)) /*!< DMA1 Channel 2 Interrupt */ +#define HAL_ITLINE_DMA1_CH3 ((uint32_t) ((HAL_SYSCFG_ITLINE10 << 0x18U) | SYSCFG_ITLINE10_SR_DMA1_CH3)) /*!< DMA1 Channel 3 Interrupt */ +#define HAL_ITLINE_DMA2_CH1 ((uint32_t) ((HAL_SYSCFG_ITLINE10 << 0x18U) | SYSCFG_ITLINE10_SR_DMA2_CH1)) /*!< DMA2 Channel 1 Interrupt */ +#define HAL_ITLINE_DMA2_CH2 ((uint32_t) ((HAL_SYSCFG_ITLINE10 << 0x18U) | SYSCFG_ITLINE10_SR_DMA2_CH2)) /*!< DMA2 Channel 2 Interrupt */ +#define HAL_ITLINE_DMA1_CH4 ((uint32_t) ((HAL_SYSCFG_ITLINE11 << 0x18U) | SYSCFG_ITLINE11_SR_DMA1_CH4)) /*!< DMA1 Channel 4 Interrupt */ +#define HAL_ITLINE_DMA1_CH5 ((uint32_t) ((HAL_SYSCFG_ITLINE11 << 0x18U) | SYSCFG_ITLINE11_SR_DMA1_CH5)) /*!< DMA1 Channel 5 Interrupt */ +#define HAL_ITLINE_DMA1_CH6 ((uint32_t) ((HAL_SYSCFG_ITLINE11 << 0x18U) | SYSCFG_ITLINE11_SR_DMA1_CH6)) /*!< DMA1 Channel 6 Interrupt */ +#define HAL_ITLINE_DMA1_CH7 ((uint32_t) ((HAL_SYSCFG_ITLINE11 << 0x18U) | SYSCFG_ITLINE11_SR_DMA1_CH7)) /*!< DMA1 Channel 7 Interrupt */ +#define HAL_ITLINE_DMA2_CH3 ((uint32_t) ((HAL_SYSCFG_ITLINE11 << 0x18U) | SYSCFG_ITLINE11_SR_DMA2_CH3)) /*!< DMA2 Channel 3 Interrupt */ +#define HAL_ITLINE_DMA2_CH4 ((uint32_t) ((HAL_SYSCFG_ITLINE11 << 0x18U) | SYSCFG_ITLINE11_SR_DMA2_CH4)) /*!< DMA2 Channel 4 Interrupt */ +#define HAL_ITLINE_DMA2_CH5 ((uint32_t) ((HAL_SYSCFG_ITLINE11 << 0x18U) | SYSCFG_ITLINE11_SR_DMA2_CH5)) /*!< DMA2 Channel 5 Interrupt */ +#define HAL_ITLINE_ADC ((uint32_t) ((HAL_SYSCFG_ITLINE12 << 0x18U) | SYSCFG_ITLINE12_SR_ADC)) /*!< ADC Interrupt */ +#define HAL_ITLINE_COMP1 ((uint32_t) ((HAL_SYSCFG_ITLINE12 << 0x18U) | SYSCFG_ITLINE12_SR_COMP1)) /*!< COMP1 Interrupt -> exti[21] */ +#define HAL_ITLINE_COMP2 ((uint32_t) ((HAL_SYSCFG_ITLINE12 << 0x18U) | SYSCFG_ITLINE12_SR_COMP2)) /*!< COMP2 Interrupt -> exti[21] */ +#define HAL_ITLINE_TIM1_BRK ((uint32_t) ((HAL_SYSCFG_ITLINE13 << 0x18U) | SYSCFG_ITLINE13_SR_TIM1_BRK)) /*!< TIM1 BRK Interrupt */ +#define HAL_ITLINE_TIM1_UPD ((uint32_t) ((HAL_SYSCFG_ITLINE13 << 0x18U) | SYSCFG_ITLINE13_SR_TIM1_UPD)) /*!< TIM1 UPD Interrupt */ +#define HAL_ITLINE_TIM1_TRG ((uint32_t) ((HAL_SYSCFG_ITLINE13 << 0x18U) | SYSCFG_ITLINE13_SR_TIM1_TRG)) /*!< TIM1 TRG Interrupt */ +#define HAL_ITLINE_TIM1_CCU ((uint32_t) ((HAL_SYSCFG_ITLINE13 << 0x18U) | SYSCFG_ITLINE13_SR_TIM1_CCU)) /*!< TIM1 CCU Interrupt */ +#define HAL_ITLINE_TIM1_CC ((uint32_t) ((HAL_SYSCFG_ITLINE14 << 0x18U) | SYSCFG_ITLINE14_SR_TIM1_CC)) /*!< TIM1 CC Interrupt */ +#define HAL_ITLINE_TIM2 ((uint32_t) ((HAL_SYSCFG_ITLINE15 << 0x18U) | SYSCFG_ITLINE15_SR_TIM2_GLB)) /*!< TIM2 Interrupt */ +#define HAL_ITLINE_TIM3 ((uint32_t) ((HAL_SYSCFG_ITLINE16 << 0x18U) | SYSCFG_ITLINE16_SR_TIM3_GLB)) /*!< TIM3 Interrupt */ +#define HAL_ITLINE_DAC ((uint32_t) ((HAL_SYSCFG_ITLINE17 << 0x18U) | SYSCFG_ITLINE17_SR_DAC)) /*!< DAC Interrupt */ +#define HAL_ITLINE_TIM6 ((uint32_t) ((HAL_SYSCFG_ITLINE17 << 0x18U) | SYSCFG_ITLINE17_SR_TIM6_GLB)) /*!< TIM6 Interrupt */ +#define HAL_ITLINE_TIM7 ((uint32_t) ((HAL_SYSCFG_ITLINE18 << 0x18U) | SYSCFG_ITLINE18_SR_TIM7_GLB)) /*!< TIM7 Interrupt */ +#define HAL_ITLINE_TIM14 ((uint32_t) ((HAL_SYSCFG_ITLINE19 << 0x18U) | SYSCFG_ITLINE19_SR_TIM14_GLB)) /*!< TIM14 Interrupt */ +#define HAL_ITLINE_TIM15 ((uint32_t) ((HAL_SYSCFG_ITLINE20 << 0x18U) | SYSCFG_ITLINE20_SR_TIM15_GLB)) /*!< TIM15 Interrupt */ +#define HAL_ITLINE_TIM16 ((uint32_t) ((HAL_SYSCFG_ITLINE21 << 0x18U) | SYSCFG_ITLINE21_SR_TIM16_GLB)) /*!< TIM16 Interrupt */ +#define HAL_ITLINE_TIM17 ((uint32_t) ((HAL_SYSCFG_ITLINE22 << 0x18U) | SYSCFG_ITLINE22_SR_TIM17_GLB)) /*!< TIM17 Interrupt */ +#define HAL_ITLINE_I2C1 ((uint32_t) ((HAL_SYSCFG_ITLINE23 << 0x18U) | SYSCFG_ITLINE23_SR_I2C1_GLB)) /*!< I2C1 Interrupt -> exti[23] */ +#define HAL_ITLINE_I2C2 ((uint32_t) ((HAL_SYSCFG_ITLINE24 << 0x18U) | SYSCFG_ITLINE24_SR_I2C2_GLB)) /*!< I2C2 Interrupt */ +#define HAL_ITLINE_SPI1 ((uint32_t) ((HAL_SYSCFG_ITLINE25 << 0x18U) | SYSCFG_ITLINE25_SR_SPI1)) /*!< I2C1 Interrupt -> exti[23] */ +#define HAL_ITLINE_SPI2 ((uint32_t) ((HAL_SYSCFG_ITLINE26 << 0x18U) | SYSCFG_ITLINE26_SR_SPI2)) /*!< SPI1 Interrupt */ +#define HAL_ITLINE_USART1 ((uint32_t) ((HAL_SYSCFG_ITLINE27 << 0x18U) | SYSCFG_ITLINE27_SR_USART1_GLB)) /*!< USART1 GLB Interrupt -> exti[25] */ +#define HAL_ITLINE_USART2 ((uint32_t) ((HAL_SYSCFG_ITLINE28 << 0x18U) | SYSCFG_ITLINE28_SR_USART2_GLB)) /*!< USART2 GLB Interrupt -> exti[26] */ +#define HAL_ITLINE_USART3 ((uint32_t) ((HAL_SYSCFG_ITLINE29 << 0x18U) | SYSCFG_ITLINE29_SR_USART3_GLB)) /*!< USART3 Interrupt .... */ +#define HAL_ITLINE_USART4 ((uint32_t) ((HAL_SYSCFG_ITLINE29 << 0x18U) | SYSCFG_ITLINE29_SR_USART4_GLB)) /*!< USART4 Interrupt .... */ +#define HAL_ITLINE_USART5 ((uint32_t) ((HAL_SYSCFG_ITLINE29 << 0x18U) | SYSCFG_ITLINE29_SR_USART5_GLB)) /*!< USART5 Interrupt .... */ +#define HAL_ITLINE_USART6 ((uint32_t) ((HAL_SYSCFG_ITLINE29 << 0x18U) | SYSCFG_ITLINE29_SR_USART6_GLB)) /*!< USART6 Interrupt .... */ +#define HAL_ITLINE_USART7 ((uint32_t) ((HAL_SYSCFG_ITLINE29 << 0x18U) | SYSCFG_ITLINE29_SR_USART7_GLB)) /*!< USART7 Interrupt .... */ +#define HAL_ITLINE_USART8 ((uint32_t) ((HAL_SYSCFG_ITLINE29 << 0x18U) | SYSCFG_ITLINE29_SR_USART8_GLB)) /*!< USART8 Interrupt .... */ +#define HAL_ITLINE_CAN ((uint32_t) ((HAL_SYSCFG_ITLINE30 << 0x18U) | SYSCFG_ITLINE30_SR_CAN)) /*!< CAN Interrupt */ +#define HAL_ITLINE_CEC ((uint32_t) ((HAL_SYSCFG_ITLINE30 << 0x18U) | SYSCFG_ITLINE30_SR_CEC)) /*!< CEC Interrupt -> exti[27] */ +/** + * @} + */ +#endif /* STM32F091xC || STM32F098xx */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup HAL_Exported_Macros HAL Exported Macros + * @{ + */ + +/** @defgroup HAL_Freeze_Unfreeze_Peripherals HAL Freeze Unfreeze Peripherals + * @brief Freeze/Unfreeze Peripherals in Debug mode + * @{ + */ + +#if defined(DBGMCU_APB1_FZ_DBG_CAN_STOP) +#define __HAL_FREEZE_CAN_DBGMCU() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_CAN_STOP)) +#define __HAL_UNFREEZE_CAN_DBGMCU() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_CAN_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_CAN_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_RTC_STOP) +#define __HAL_DBGMCU_FREEZE_RTC() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_RTC_STOP)) +#define __HAL_DBGMCU_UNFREEZE_RTC() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_RTC_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_RTC_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_I2C1_SMBUS_TIMEOUT) +#define __HAL_DBGMCU_FREEZE_I2C1_TIMEOUT() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_I2C1_SMBUS_TIMEOUT)) +#define __HAL_DBGMCU_UNFREEZE_I2C1_TIMEOUT() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_I2C1_SMBUS_TIMEOUT)) +#endif /* DBGMCU_APB1_FZ_DBG_I2C1_SMBUS_TIMEOUT */ + +#if defined(DBGMCU_APB1_FZ_DBG_IWDG_STOP) +#define __HAL_DBGMCU_FREEZE_IWDG() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_IWDG_STOP)) +#define __HAL_DBGMCU_UNFREEZE_IWDG() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_IWDG_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_IWDG_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_WWDG_STOP) +#define __HAL_DBGMCU_FREEZE_WWDG() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_WWDG_STOP)) +#define __HAL_DBGMCU_UNFREEZE_WWDG() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_WWDG_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_WWDG_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_TIM2_STOP) +#define __HAL_DBGMCU_FREEZE_TIM2() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_TIM2_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM2() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_TIM2_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_TIM2_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_TIM3_STOP) +#define __HAL_DBGMCU_FREEZE_TIM3() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_TIM3_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM3() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_TIM3_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_TIM3_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_TIM6_STOP) +#define __HAL_DBGMCU_FREEZE_TIM6() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_TIM6_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM6() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_TIM6_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_TIM6_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_TIM7_STOP) +#define __HAL_DBGMCU_FREEZE_TIM7() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_TIM7_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM7() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_TIM7_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_TIM7_STOP */ + +#if defined(DBGMCU_APB1_FZ_DBG_TIM14_STOP) +#define __HAL_DBGMCU_FREEZE_TIM14() (DBGMCU->APB1FZ |= (DBGMCU_APB1_FZ_DBG_TIM14_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM14() (DBGMCU->APB1FZ &= ~(DBGMCU_APB1_FZ_DBG_TIM14_STOP)) +#endif /* DBGMCU_APB1_FZ_DBG_TIM14_STOP */ + +#if defined(DBGMCU_APB2_FZ_DBG_TIM1_STOP) +#define __HAL_DBGMCU_FREEZE_TIM1() (DBGMCU->APB2FZ |= (DBGMCU_APB2_FZ_DBG_TIM1_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM1() (DBGMCU->APB2FZ &= ~(DBGMCU_APB2_FZ_DBG_TIM1_STOP)) +#endif /* DBGMCU_APB2_FZ_DBG_TIM1_STOP */ + +#if defined(DBGMCU_APB2_FZ_DBG_TIM15_STOP) +#define __HAL_DBGMCU_FREEZE_TIM15() (DBGMCU->APB2FZ |= (DBGMCU_APB2_FZ_DBG_TIM15_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM15() (DBGMCU->APB2FZ &= ~(DBGMCU_APB2_FZ_DBG_TIM15_STOP)) +#endif /* DBGMCU_APB2_FZ_DBG_TIM15_STOP */ + +#if defined(DBGMCU_APB2_FZ_DBG_TIM16_STOP) +#define __HAL_DBGMCU_FREEZE_TIM16() (DBGMCU->APB2FZ |= (DBGMCU_APB2_FZ_DBG_TIM16_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM16() (DBGMCU->APB2FZ &= ~(DBGMCU_APB2_FZ_DBG_TIM16_STOP)) +#endif /* DBGMCU_APB2_FZ_DBG_TIM16_STOP */ + +#if defined(DBGMCU_APB2_FZ_DBG_TIM17_STOP) +#define __HAL_DBGMCU_FREEZE_TIM17() (DBGMCU->APB2FZ |= (DBGMCU_APB2_FZ_DBG_TIM17_STOP)) +#define __HAL_DBGMCU_UNFREEZE_TIM17() (DBGMCU->APB2FZ &= ~(DBGMCU_APB2_FZ_DBG_TIM17_STOP)) +#endif /* DBGMCU_APB2_FZ_DBG_TIM17_STOP */ + +/** + * @} + */ + +/** @defgroup Memory_Mapping_Selection Memory Mapping Selection + * @{ + */ +#if defined(SYSCFG_CFGR1_MEM_MODE) +/** @brief Main Flash memory mapped at 0x00000000 + */ +#define __HAL_SYSCFG_REMAPMEMORY_FLASH() (SYSCFG->CFGR1 &= ~(SYSCFG_CFGR1_MEM_MODE)) +#endif /* SYSCFG_CFGR1_MEM_MODE */ + +#if defined(SYSCFG_CFGR1_MEM_MODE_0) +/** @brief System Flash memory mapped at 0x00000000 + */ +#define __HAL_SYSCFG_REMAPMEMORY_SYSTEMFLASH() do {SYSCFG->CFGR1 &= ~(SYSCFG_CFGR1_MEM_MODE); \ + SYSCFG->CFGR1 |= SYSCFG_CFGR1_MEM_MODE_0; \ + }while(0) +#endif /* SYSCFG_CFGR1_MEM_MODE_0 */ + +#if defined(SYSCFG_CFGR1_MEM_MODE_0) && defined(SYSCFG_CFGR1_MEM_MODE_1) +/** @brief Embedded SRAM mapped at 0x00000000 + */ +#define __HAL_SYSCFG_REMAPMEMORY_SRAM() do {SYSCFG->CFGR1 &= ~(SYSCFG_CFGR1_MEM_MODE); \ + SYSCFG->CFGR1 |= (SYSCFG_CFGR1_MEM_MODE_0 | SYSCFG_CFGR1_MEM_MODE_1); \ + }while(0) +#endif /* SYSCFG_CFGR1_MEM_MODE_0 && SYSCFG_CFGR1_MEM_MODE_1 */ +/** + * @} + */ + + +#if defined(SYSCFG_CFGR1_PA11_PA12_RMP) +/** @defgroup HAL_Pin_remap HAL Pin remap + * @brief Pin remapping enable/disable macros + * @param __PIN_REMAP__ This parameter can be a value of @ref HAL_Pin_remapping + * @{ + */ +#define __HAL_REMAP_PIN_ENABLE(__PIN_REMAP__) do {assert_param(IS_HAL_REMAP_PIN((__PIN_REMAP__))); \ + SYSCFG->CFGR1 |= (__PIN_REMAP__); \ + }while(0) +#define __HAL_REMAP_PIN_DISABLE(__PIN_REMAP__) do {assert_param(IS_HAL_REMAP_PIN((__PIN_REMAP__))); \ + SYSCFG->CFGR1 &= ~(__PIN_REMAP__); \ + }while(0) +/** + * @} + */ +#endif /* SYSCFG_CFGR1_PA11_PA12_RMP */ + +/** @brief Fast-mode Plus driving capability enable/disable macros + * @param __FASTMODEPLUS__ This parameter can be a value of @ref SYSCFG_FastModePlus_GPIO values. + * That you can find above these macros. + */ +#define __HAL_SYSCFG_FASTMODEPLUS_ENABLE(__FASTMODEPLUS__) do {assert_param(IS_SYSCFG_FASTMODEPLUS((__FASTMODEPLUS__)));\ + SET_BIT(SYSCFG->CFGR1, (__FASTMODEPLUS__));\ + }while(0) + +#define __HAL_SYSCFG_FASTMODEPLUS_DISABLE(__FASTMODEPLUS__) do {assert_param(IS_SYSCFG_FASTMODEPLUS((__FASTMODEPLUS__)));\ + CLEAR_BIT(SYSCFG->CFGR1, (__FASTMODEPLUS__));\ + }while(0) +#if defined(SYSCFG_CFGR2_LOCKUP_LOCK) +/** @defgroup Cortex_Lockup_Enable Cortex Lockup Enable + * @{ + */ +/** @brief SYSCFG Break Lockup lock + * Enables and locks the connection of Cortex-M0 LOCKUP (Hardfault) output to TIM1/15/16/17 Break input + * @note The selected configuration is locked and can be unlocked by system reset + */ +#define __HAL_SYSCFG_BREAK_LOCKUP_LOCK() do {SYSCFG->CFGR2 &= ~(SYSCFG_CFGR2_LOCKUP_LOCK); \ + SYSCFG->CFGR2 |= SYSCFG_CFGR2_LOCKUP_LOCK; \ + }while(0) +/** + * @} + */ +#endif /* SYSCFG_CFGR2_LOCKUP_LOCK */ + +#if defined(SYSCFG_CFGR2_PVD_LOCK) +/** @defgroup PVD_Lock_Enable PVD Lock + * @{ + */ +/** @brief SYSCFG Break PVD lock + * Enables and locks the PVD connection with Timer1/8/15/16/17 Break Input, , as well as the PVDE and PLS[2:0] in the PWR_CR register + * @note The selected configuration is locked and can be unlocked by system reset + */ +#define __HAL_SYSCFG_BREAK_PVD_LOCK() do {SYSCFG->CFGR2 &= ~(SYSCFG_CFGR2_PVD_LOCK); \ + SYSCFG->CFGR2 |= SYSCFG_CFGR2_PVD_LOCK; \ + }while(0) +/** + * @} + */ +#endif /* SYSCFG_CFGR2_PVD_LOCK */ + +#if defined(SYSCFG_CFGR2_SRAM_PARITY_LOCK) +/** @defgroup SRAM_Parity_Lock SRAM Parity Lock + * @{ + */ +/** @brief SYSCFG Break SRAM PARITY lock + * Enables and locks the SRAM_PARITY error signal with Break Input of TIMER1/8/15/16/17 + * @note The selected configuration is locked and can be unlocked by system reset + */ +#define __HAL_SYSCFG_BREAK_SRAMPARITY_LOCK() do {SYSCFG->CFGR2 &= ~(SYSCFG_CFGR2_SRAM_PARITY_LOCK); \ + SYSCFG->CFGR2 |= SYSCFG_CFGR2_SRAM_PARITY_LOCK; \ + }while(0) +/** + * @} + */ +#endif /* SYSCFG_CFGR2_SRAM_PARITY_LOCK */ + +#if defined(SYSCFG_CFGR2_SRAM_PEF) +/** @defgroup HAL_SYSCFG_Parity_check_on_RAM HAL SYSCFG Parity check on RAM + * @brief Parity check on RAM disable macro + * @note Disabling the parity check on RAM locks the configuration bit. + * To re-enable the parity check on RAM perform a system reset. + * @{ + */ +#define __HAL_SYSCFG_RAM_PARITYCHECK_DISABLE() (SYSCFG->CFGR2 |= SYSCFG_CFGR2_SRAM_PEF) +/** + * @} + */ +#endif /* SYSCFG_CFGR2_SRAM_PEF */ + + +#if defined(STM32F091xC) || defined (STM32F098xx) +/** @defgroup HAL_ISR_wrapper_check HAL ISR wrapper check + * @brief ISR wrapper check + * @note This feature is applicable on STM32F09x + * @note Allow to determine interrupt source per line. + * @{ + */ +#define __HAL_GET_PENDING_IT(__SOURCE__) (SYSCFG->IT_LINE_SR[((__SOURCE__) >> 0x18U)] & ((__SOURCE__) & 0x00FFFFFF)) +/** + * @} + */ +#endif /* (STM32F091xC) || defined (STM32F098xx)*/ + +#if defined(STM32F091xC) || defined (STM32F098xx) +/** @defgroup HAL_SYSCFG_IRDA_modulation_envelope_selection HAL SYSCFG IRDA modulation envelope selection + * @brief selection of the modulation envelope signal macro, using bits [7:6] of SYS_CTRL(CFGR1) register + * @note This feature is applicable on STM32F09x + * @param __SOURCE__ This parameter can be a value of @ref HAL_IRDA_ENV_SEL + * @{ + */ +#define __HAL_SYSCFG_IRDA_ENV_SELECTION(__SOURCE__) do {assert_param(IS_HAL_SYSCFG_IRDA_ENV_SEL((__SOURCE__))); \ + SYSCFG->CFGR1 &= ~(SYSCFG_CFGR1_IRDA_ENV_SEL); \ + SYSCFG->CFGR1 |= (__SOURCE__); \ + }while(0) + +#define __HAL_SYSCFG_GET_IRDA_ENV_SELECTION() ((SYSCFG->CFGR1) & 0x000000C0) +/** + * @} + */ +#endif /* (STM32F091xC) || defined (STM32F098xx)*/ + +/** + * @} + */ + +/** @defgroup HAL_Private_Macros HAL Private Macros + * @{ + */ +#define IS_TICKFREQ(FREQ) (((FREQ) == HAL_TICK_FREQ_10HZ) || \ + ((FREQ) == HAL_TICK_FREQ_100HZ) || \ + ((FREQ) == HAL_TICK_FREQ_1KHZ)) +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup HAL_Exported_Functions + * @{ + */ + +/** @addtogroup HAL_Exported_Functions_Group1 + * @{ + */ +/* Initialization and de-initialization functions ******************************/ +HAL_StatusTypeDef HAL_Init(void); +HAL_StatusTypeDef HAL_DeInit(void); +void HAL_MspInit(void); +void HAL_MspDeInit(void); +HAL_StatusTypeDef HAL_InitTick (uint32_t TickPriority); +/** + * @} + */ + +/* Exported variables ---------------------------------------------------------*/ +/** @addtogroup HAL_Exported_Variables + * @{ + */ +extern __IO uint32_t uwTick; +extern uint32_t uwTickPrio; +extern HAL_TickFreqTypeDef uwTickFreq; +/** + * @} + */ + +/** @addtogroup HAL_Exported_Functions_Group2 + * @{ + */ + +/* Peripheral Control functions ************************************************/ +void HAL_IncTick(void); +void HAL_Delay(uint32_t Delay); +uint32_t HAL_GetTick(void); +uint32_t HAL_GetTickPrio(void); +HAL_StatusTypeDef HAL_SetTickFreq(HAL_TickFreqTypeDef Freq); +HAL_TickFreqTypeDef HAL_GetTickFreq(void); +void HAL_SuspendTick(void); +void HAL_ResumeTick(void); +uint32_t HAL_GetHalVersion(void); +uint32_t HAL_GetREVID(void); +uint32_t HAL_GetDEVID(void); +uint32_t HAL_GetUIDw0(void); +uint32_t HAL_GetUIDw1(void); +uint32_t HAL_GetUIDw2(void); +void HAL_DBGMCU_EnableDBGStopMode(void); +void HAL_DBGMCU_DisableDBGStopMode(void); +void HAL_DBGMCU_EnableDBGStandbyMode(void); +void HAL_DBGMCU_DisableDBGStandbyMode(void); +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc.h new file mode 100644 index 0000000..31771b1 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc.h @@ -0,0 +1,1019 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_adc.h + * @author MCD Application Team + * @brief Header file containing functions prototypes of ADC HAL library. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_ADC_H +#define STM32F0xx_HAL_ADC_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup ADC + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup ADC_Exported_Types ADC Exported Types + * @{ + */ + +/** + * @brief Structure definition of ADC initialization and regular group + * @note The setting of these parameters with function HAL_ADC_Init() is conditioned to ADC state. + * ADC state can be either: + * - For all parameters: ADC disabled (this is the only possible ADC state to modify parameter 'ClockPrescaler') + * - For all parameters except 'ClockPrescaler' and 'resolution': ADC enabled without conversion on going on regular group. + * If ADC is not in the appropriate state to modify some parameters, these parameters setting is bypassed + * without error reporting (as it can be the expected behaviour in case of intended action to update another parameter (which fulfills the ADC state condition) on the fly). + */ +typedef struct +{ + uint32_t ClockPrescaler; /*!< Select ADC clock source (synchronous clock derived from APB clock or asynchronous clock derived from ADC dedicated HSI RC oscillator 14MHz) and clock prescaler. + This parameter can be a value of @ref ADC_ClockPrescaler + Note: In case of usage of the ADC dedicated HSI RC oscillator, it must be preliminarily enabled at RCC top level. + Note: This parameter can be modified only if the ADC is disabled */ + uint32_t Resolution; /*!< Configures the ADC resolution. + This parameter can be a value of @ref ADC_Resolution */ + uint32_t DataAlign; /*!< Specifies whether the ADC data alignment is left or right. + This parameter can be a value of @ref ADC_Data_align */ + uint32_t ScanConvMode; /*!< Configures the sequencer of regular group. + This parameter can be associated to parameter 'DiscontinuousConvMode' to have main sequence subdivided in successive parts. + Sequencer is automatically enabled if several channels are set (sequencer cannot be disabled, as it can be the case on other STM32 devices): + If only 1 channel is set: Conversion is performed in single mode. + If several channels are set: Conversions are performed in sequence mode (ranks defined by each channel number: channel 0 fixed on rank 0, channel 1 fixed on rank1, ...). + Scan direction can be set to forward (from channel 0 to channel 18) or backward (from channel 18 to channel 0). + This parameter can be a value of @ref ADC_Scan_mode */ + uint32_t EOCSelection; /*!< Specifies what EOC (End Of Conversion) flag is used for conversion by polling and interruption: end of conversion of each rank or complete sequence. + This parameter can be a value of @ref ADC_EOCSelection. */ + FunctionalState LowPowerAutoWait; /*!< Selects the dynamic low power Auto Delay: new conversion start only when the previous + conversion (for regular group) has been treated by user software, using function HAL_ADC_GetValue(). + This feature automatically adapts the ADC conversions trigs to the speed of the system that reads the data. Moreover, this avoids risk of overrun for low frequency applications. + This parameter can be set to ENABLE or DISABLE. + Note: Do not use with interruption or DMA (HAL_ADC_Start_IT(), HAL_ADC_Start_DMA()) since they have to clear immediately the EOC flag to free the IRQ vector sequencer. + Do use with polling: 1. Start conversion with HAL_ADC_Start(), 2. Later on, when conversion data is needed: use HAL_ADC_PollForConversion() to ensure that conversion is completed + and use HAL_ADC_GetValue() to retrieve conversion result and trig another conversion. */ + FunctionalState LowPowerAutoPowerOff; /*!< Selects the auto-off mode: the ADC automatically powers-off after a conversion and automatically wakes-up when a new conversion is triggered (with startup time between trigger and start of sampling). + This feature can be combined with automatic wait mode (parameter 'LowPowerAutoWait'). + This parameter can be set to ENABLE or DISABLE. + Note: If enabled, this feature also turns off the ADC dedicated 14 MHz RC oscillator (HSI14) */ + FunctionalState ContinuousConvMode; /*!< Specifies whether the conversion is performed in single mode (one conversion) or continuous mode for regular group, + after the selected trigger occurred (software start or external trigger). + This parameter can be set to ENABLE or DISABLE. */ + FunctionalState DiscontinuousConvMode; /*!< Specifies whether the conversions sequence of regular group is performed in Complete-sequence/Discontinuous-sequence (main sequence subdivided in successive parts). + Discontinuous mode is used only if sequencer is enabled (parameter 'ScanConvMode'). If sequencer is disabled, this parameter is discarded. + Discontinuous mode can be enabled only if continuous mode is disabled. If continuous mode is enabled, this parameter setting is discarded. + This parameter can be set to ENABLE or DISABLE + Note: Number of discontinuous ranks increment is fixed to one-by-one. */ + uint32_t ExternalTrigConv; /*!< Selects the external event used to trigger the conversion start of regular group. + If set to ADC_SOFTWARE_START, external triggers are disabled. + This parameter can be a value of @ref ADC_External_trigger_source_Regular */ + uint32_t ExternalTrigConvEdge; /*!< Selects the external trigger edge of regular group. + If trigger is set to ADC_SOFTWARE_START, this parameter is discarded. + This parameter can be a value of @ref ADC_External_trigger_edge_Regular */ + FunctionalState DMAContinuousRequests; /*!< Specifies whether the DMA requests are performed in one shot mode (DMA transfer stop when number of conversions is reached) + or in Continuous mode (DMA transfer unlimited, whatever number of conversions). + Note: In continuous mode, DMA must be configured in circular mode. Otherwise an overrun will be triggered when DMA buffer maximum pointer is reached. + This parameter can be set to ENABLE or DISABLE. */ + uint32_t Overrun; /*!< Select the behaviour in case of overrun: data preserved or overwritten + This parameter has an effect on regular group only, including in DMA mode. + This parameter can be a value of @ref ADC_Overrun */ + uint32_t SamplingTimeCommon; /*!< Sampling time value to be set for the selected channel. + Unit: ADC clock cycles + Conversion time is the addition of sampling time and processing time (12.5 ADC clock cycles at ADC resolution 12 bits, 10.5 cycles at 10 bits, 8.5 cycles at 8 bits, 6.5 cycles at 6 bits). + Note: On STM32F0 devices, the sampling time setting is common to all channels. On some other STM32 devices, this parameter in channel wise and is located into ADC channel initialization structure. + This parameter can be a value of @ref ADC_sampling_times + Note: In case of usage of internal measurement channels (VrefInt/Vbat/TempSensor), + sampling time constraints must be respected (sampling time can be adjusted in function of ADC clock frequency and sampling time setting) + Refer to device datasheet for timings values, parameters TS_vrefint, TS_vbat, TS_temp (values rough order: 5us to 17us). */ +}ADC_InitTypeDef; + +/** + * @brief Structure definition of ADC channel for regular group + * @note The setting of these parameters with function HAL_ADC_ConfigChannel() is conditioned to ADC state. + * ADC state can be either: + * - For all parameters: ADC disabled or enabled without conversion on going on regular group. + * If ADC is not in the appropriate state to modify some parameters, these parameters setting is bypassed + * without error reporting (as it can be the expected behaviour in case of intended action to update another parameter (which fulfills the ADC state condition) on the fly). + */ +typedef struct +{ + uint32_t Channel; /*!< Specifies the channel to configure into ADC regular group. + This parameter can be a value of @ref ADC_channels + Note: Depending on devices, some channels may not be available on package pins. Refer to device datasheet for channels availability. */ + uint32_t Rank; /*!< Add or remove the channel from ADC regular group sequencer. + On STM32F0 devices, number of ranks in the sequence is defined by number of channels enabled, rank of each channel is defined by channel number (channel 0 fixed on rank 0, channel 1 fixed on rank1, ...).. + Despite the channel rank is fixed, this parameter allow an additional possibility: to remove the selected rank (selected channel) from sequencer. + This parameter can be a value of @ref ADC_rank */ + uint32_t SamplingTime; /*!< Sampling time value to be set for the selected channel. + Unit: ADC clock cycles + Conversion time is the addition of sampling time and processing time (12.5 ADC clock cycles at ADC resolution 12 bits, 10.5 cycles at 10 bits, 8.5 cycles at 8 bits, 6.5 cycles at 6 bits). + This parameter can be a value of @ref ADC_sampling_times + Caution: this setting impacts the entire regular group. Therefore, call of HAL_ADC_ConfigChannel() to configure a channel can impact the configuration of other channels previously set. + Caution: Obsolete parameter. Use parameter "SamplingTimeCommon" in ADC initialization structure. + If parameter "SamplingTimeCommon" is set to a valid sampling time, parameter "SamplingTime" is discarded. + Note: In case of usage of internal measurement channels (VrefInt/Vbat/TempSensor), + sampling time constraints must be respected (sampling time can be adjusted in function of ADC clock frequency and sampling time setting) + Refer to device datasheet for timings values, parameters TS_vrefint, TS_vbat, TS_temp (values rough order: 5us to 17us). */ +}ADC_ChannelConfTypeDef; + +/** + * @brief Structure definition of ADC analog watchdog + * @note The setting of these parameters with function HAL_ADC_AnalogWDGConfig() is conditioned to ADC state. + * ADC state can be either: ADC disabled or ADC enabled without conversion on going on regular group. + */ +typedef struct +{ + uint32_t WatchdogMode; /*!< Configures the ADC analog watchdog mode: single/all/none channels. + This parameter can be a value of @ref ADC_analog_watchdog_mode. */ + uint32_t Channel; /*!< Selects which ADC channel to monitor by analog watchdog. + This parameter has an effect only if parameter 'WatchdogMode' is configured on single channel. Only 1 channel can be monitored. + This parameter can be a value of @ref ADC_channels. */ + FunctionalState ITMode; /*!< Specifies whether the analog watchdog is configured in interrupt or polling mode. + This parameter can be set to ENABLE or DISABLE */ + uint32_t HighThreshold; /*!< Configures the ADC analog watchdog High threshold value. + Depending of ADC resolution selected (12, 10, 8 or 6 bits), this parameter must be a number between Min_Data = 0x000 and Max_Data = 0xFFF, 0x3FF, 0xFF or 0x3F respectively. */ + uint32_t LowThreshold; /*!< Configures the ADC analog watchdog High threshold value. + Depending of ADC resolution selected (12, 10, 8 or 6 bits), this parameter must be a number between Min_Data = 0x000 and Max_Data = 0xFFF, 0x3FF, 0xFF or 0x3F respectively. */ +}ADC_AnalogWDGConfTypeDef; + +/** + * @brief HAL ADC state machine: ADC states definition (bitfields) + * @note ADC state machine is managed by bitfields, state must be compared + * with bit by bit. + * For example: + * " if (HAL_IS_BIT_SET(HAL_ADC_GetState(hadc1), HAL_ADC_STATE_REG_BUSY)) " + * " if (HAL_IS_BIT_SET(HAL_ADC_GetState(hadc1), HAL_ADC_STATE_AWD1) ) " + */ +/* States of ADC global scope */ +#define HAL_ADC_STATE_RESET (0x00000000U) /*!< ADC not yet initialized or disabled */ +#define HAL_ADC_STATE_READY (0x00000001U) /*!< ADC peripheral ready for use */ +#define HAL_ADC_STATE_BUSY_INTERNAL (0x00000002U) /*!< ADC is busy to internal process (initialization, calibration) */ +#define HAL_ADC_STATE_TIMEOUT (0x00000004U) /*!< TimeOut occurrence */ + +/* States of ADC errors */ +#define HAL_ADC_STATE_ERROR_INTERNAL (0x00000010U) /*!< Internal error occurrence */ +#define HAL_ADC_STATE_ERROR_CONFIG (0x00000020U) /*!< Configuration error occurrence */ +#define HAL_ADC_STATE_ERROR_DMA (0x00000040U) /*!< DMA error occurrence */ + +/* States of ADC group regular */ +#define HAL_ADC_STATE_REG_BUSY (0x00000100U) /*!< A conversion on group regular is ongoing or can occur (either by continuous mode, + external trigger, low power auto power-on, multimode ADC master control) */ +#define HAL_ADC_STATE_REG_EOC (0x00000200U) /*!< Conversion data available on group regular */ +#define HAL_ADC_STATE_REG_OVR (0x00000400U) /*!< Overrun occurrence */ +#define HAL_ADC_STATE_REG_EOSMP (0x00000800U) /*!< Not available on STM32F0 device: End Of Sampling flag raised */ + +/* States of ADC group injected */ +#define HAL_ADC_STATE_INJ_BUSY (0x00001000U) /*!< Not available on STM32F0 device: A conversion on group injected is ongoing or can occur (either by auto-injection mode, + external trigger, low power auto power-on, multimode ADC master control) */ +#define HAL_ADC_STATE_INJ_EOC (0x00002000U) /*!< Not available on STM32F0 device: Conversion data available on group injected */ +#define HAL_ADC_STATE_INJ_JQOVF (0x00004000U) /*!< Not available on STM32F0 device: Not available on STM32F0 device: Injected queue overflow occurrence */ + +/* States of ADC analog watchdogs */ +#define HAL_ADC_STATE_AWD1 (0x00010000U) /*!< Out-of-window occurrence of analog watchdog 1 */ +#define HAL_ADC_STATE_AWD2 (0x00020000U) /*!< Not available on STM32F0 device: Out-of-window occurrence of analog watchdog 2 */ +#define HAL_ADC_STATE_AWD3 (0x00040000U) /*!< Not available on STM32F0 device: Out-of-window occurrence of analog watchdog 3 */ + +/* States of ADC multi-mode */ +#define HAL_ADC_STATE_MULTIMODE_SLAVE (0x00100000U) /*!< Not available on STM32F0 device: ADC in multimode slave state, controlled by another ADC master ( */ + + +/** + * @brief ADC handle Structure definition + */ +typedef struct __ADC_HandleTypeDef +{ + ADC_TypeDef *Instance; /*!< Register base address */ + + ADC_InitTypeDef Init; /*!< ADC required parameters */ + + DMA_HandleTypeDef *DMA_Handle; /*!< Pointer DMA Handler */ + + HAL_LockTypeDef Lock; /*!< ADC locking object */ + + __IO uint32_t State; /*!< ADC communication state (bitmap of ADC states) */ + + __IO uint32_t ErrorCode; /*!< ADC Error code */ + + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) + void (* ConvCpltCallback)(struct __ADC_HandleTypeDef *hadc); /*!< ADC conversion complete callback */ + void (* ConvHalfCpltCallback)(struct __ADC_HandleTypeDef *hadc); /*!< ADC conversion DMA half-transfer callback */ + void (* LevelOutOfWindowCallback)(struct __ADC_HandleTypeDef *hadc); /*!< ADC analog watchdog 1 callback */ + void (* ErrorCallback)(struct __ADC_HandleTypeDef *hadc); /*!< ADC error callback */ + void (* MspInitCallback)(struct __ADC_HandleTypeDef *hadc); /*!< ADC Msp Init callback */ + void (* MspDeInitCallback)(struct __ADC_HandleTypeDef *hadc); /*!< ADC Msp DeInit callback */ +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ +}ADC_HandleTypeDef; + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) +/** + * @brief HAL ADC Callback ID enumeration definition + */ +typedef enum +{ + HAL_ADC_CONVERSION_COMPLETE_CB_ID = 0x00U, /*!< ADC conversion complete callback ID */ + HAL_ADC_CONVERSION_HALF_CB_ID = 0x01U, /*!< ADC conversion DMA half-transfer callback ID */ + HAL_ADC_LEVEL_OUT_OF_WINDOW_1_CB_ID = 0x02U, /*!< ADC analog watchdog 1 callback ID */ + HAL_ADC_ERROR_CB_ID = 0x03U, /*!< ADC error callback ID */ + HAL_ADC_INJ_CONVERSION_COMPLETE_CB_ID = 0x04U, /*!< ADC group injected conversion complete callback ID */ + HAL_ADC_MSPINIT_CB_ID = 0x09U, /*!< ADC Msp Init callback ID */ + HAL_ADC_MSPDEINIT_CB_ID = 0x0AU /*!< ADC Msp DeInit callback ID */ +} HAL_ADC_CallbackIDTypeDef; + +/** + * @brief HAL ADC Callback pointer definition + */ +typedef void (*pADC_CallbackTypeDef)(ADC_HandleTypeDef *hadc); /*!< pointer to a ADC callback function */ + +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + +/** + * @} + */ + + + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup ADC_Exported_Constants ADC Exported Constants + * @{ + */ + +/** @defgroup ADC_Error_Code ADC Error Code + * @{ + */ +#define HAL_ADC_ERROR_NONE (0x00U) /*!< No error */ +#define HAL_ADC_ERROR_INTERNAL (0x01U) /*!< ADC IP internal error: if problem of clocking, + enable/disable, erroneous state */ +#define HAL_ADC_ERROR_OVR (0x02U) /*!< Overrun error */ +#define HAL_ADC_ERROR_DMA (0x04U) /*!< DMA transfer error */ + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) +#define HAL_ADC_ERROR_INVALID_CALLBACK (0x10U) /*!< Invalid Callback error */ +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @defgroup ADC_ClockPrescaler ADC ClockPrescaler + * @{ + */ +#define ADC_CLOCK_ASYNC_DIV1 (0x00000000U) /*!< ADC asynchronous clock derived from ADC dedicated HSI */ + +#define ADC_CLOCK_SYNC_PCLK_DIV2 ((uint32_t)ADC_CFGR2_CKMODE_0) /*!< ADC synchronous clock derived from AHB clock divided by a prescaler of 2 */ +#define ADC_CLOCK_SYNC_PCLK_DIV4 ((uint32_t)ADC_CFGR2_CKMODE_1) /*!< ADC synchronous clock derived from AHB clock divided by a prescaler of 4 */ + +/** + * @} + */ + +/** @defgroup ADC_Resolution ADC Resolution + * @{ + */ +#define ADC_RESOLUTION_12B (0x00000000U) /*!< ADC 12-bit resolution */ +#define ADC_RESOLUTION_10B ((uint32_t)ADC_CFGR1_RES_0) /*!< ADC 10-bit resolution */ +#define ADC_RESOLUTION_8B ((uint32_t)ADC_CFGR1_RES_1) /*!< ADC 8-bit resolution */ +#define ADC_RESOLUTION_6B ((uint32_t)ADC_CFGR1_RES) /*!< ADC 6-bit resolution */ +/** + * @} + */ + +/** @defgroup ADC_Data_align ADC Data_align + * @{ + */ +#define ADC_DATAALIGN_RIGHT (0x00000000U) +#define ADC_DATAALIGN_LEFT ((uint32_t)ADC_CFGR1_ALIGN) +/** + * @} + */ + +/** @defgroup ADC_Scan_mode ADC Scan mode + * @{ + */ +/* Note: Scan mode values must be compatible with other STM32 devices having */ +/* a configurable sequencer. */ +/* Scan direction setting values are defined by taking in account */ +/* already defined values for other STM32 devices: */ +/* ADC_SCAN_DISABLE (0x00000000U) */ +/* ADC_SCAN_ENABLE (0x00000001U) */ +/* Scan direction forward is considered as default setting equivalent */ +/* to scan enable. */ +/* Scan direction backward is considered as additional setting. */ +/* In case of migration from another STM32 device, the user will be */ +/* warned of change of setting choices with assert check. */ +#define ADC_SCAN_DIRECTION_FORWARD (0x00000001U) /*!< Scan direction forward: from channel 0 to channel 18 */ +#define ADC_SCAN_DIRECTION_BACKWARD (0x00000002U) /*!< Scan direction backward: from channel 18 to channel 0 */ + +#define ADC_SCAN_ENABLE ADC_SCAN_DIRECTION_FORWARD /* For compatibility with other STM32 devices */ + +/** + * @} + */ + +/** @defgroup ADC_External_trigger_edge_Regular ADC External trigger edge Regular + * @{ + */ +#define ADC_EXTERNALTRIGCONVEDGE_NONE (0x00000000U) +#define ADC_EXTERNALTRIGCONVEDGE_RISING ((uint32_t)ADC_CFGR1_EXTEN_0) +#define ADC_EXTERNALTRIGCONVEDGE_FALLING ((uint32_t)ADC_CFGR1_EXTEN_1) +#define ADC_EXTERNALTRIGCONVEDGE_RISINGFALLING ((uint32_t)ADC_CFGR1_EXTEN) +/** + * @} + */ + +/** @defgroup ADC_EOCSelection ADC EOCSelection + * @{ + */ +#define ADC_EOC_SINGLE_CONV ((uint32_t) ADC_ISR_EOC) +#define ADC_EOC_SEQ_CONV ((uint32_t) ADC_ISR_EOS) +/** + * @} + */ + +/** @defgroup ADC_Overrun ADC Overrun + * @{ + */ +#define ADC_OVR_DATA_OVERWRITTEN (0x00000000U) +#define ADC_OVR_DATA_PRESERVED (0x00000001U) +/** + * @} + */ + +/** @defgroup ADC_rank ADC rank + * @{ + */ +#define ADC_RANK_CHANNEL_NUMBER (0x00001000U) /*!< Enable the rank of the selected channels. Number of ranks in the sequence is defined by number of channels enabled, rank of each channel is defined by channel number (channel 0 fixed on rank 0, channel 1 fixed on rank1, ...) */ +#define ADC_RANK_NONE (0x00001001U) /*!< Disable the selected rank (selected channel) from sequencer */ +/** + * @} + */ + +/** @defgroup ADC_sampling_times ADC sampling times + * @{ + */ +/* Note: Parameter "ADC_SAMPLETIME_1CYCLE_5" defined with a dummy bit */ +/* to distinguish this parameter versus reset value 0x00000000, */ +/* in the context of management of parameters "SamplingTimeCommon" */ +/* and "SamplingTime" (obsolete)). */ +#define ADC_SAMPLETIME_1CYCLE_5 (0x10000000U) /*!< Sampling time 1.5 ADC clock cycle */ +#define ADC_SAMPLETIME_7CYCLES_5 ((uint32_t) ADC_SMPR_SMP_0) /*!< Sampling time 7.5 ADC clock cycles */ +#define ADC_SAMPLETIME_13CYCLES_5 ((uint32_t) ADC_SMPR_SMP_1) /*!< Sampling time 13.5 ADC clock cycles */ +#define ADC_SAMPLETIME_28CYCLES_5 ((uint32_t)(ADC_SMPR_SMP_1 | ADC_SMPR_SMP_0)) /*!< Sampling time 28.5 ADC clock cycles */ +#define ADC_SAMPLETIME_41CYCLES_5 ((uint32_t) ADC_SMPR_SMP_2) /*!< Sampling time 41.5 ADC clock cycles */ +#define ADC_SAMPLETIME_55CYCLES_5 ((uint32_t)(ADC_SMPR_SMP_2 | ADC_SMPR_SMP_0)) /*!< Sampling time 55.5 ADC clock cycles */ +#define ADC_SAMPLETIME_71CYCLES_5 ((uint32_t)(ADC_SMPR_SMP_2 | ADC_SMPR_SMP_1)) /*!< Sampling time 71.5 ADC clock cycles */ +#define ADC_SAMPLETIME_239CYCLES_5 ((uint32_t) ADC_SMPR_SMP) /*!< Sampling time 239.5 ADC clock cycles */ +/** + * @} + */ + +/** @defgroup ADC_analog_watchdog_mode ADC analog watchdog mode + * @{ + */ +#define ADC_ANALOGWATCHDOG_NONE ( 0x00000000U) +#define ADC_ANALOGWATCHDOG_SINGLE_REG ((uint32_t)(ADC_CFGR1_AWDSGL | ADC_CFGR1_AWDEN)) +#define ADC_ANALOGWATCHDOG_ALL_REG ((uint32_t) ADC_CFGR1_AWDEN) +/** + * @} + */ + +/** @defgroup ADC_Event_type ADC Event type + * @{ + */ +#define ADC_AWD_EVENT ((uint32_t)ADC_FLAG_AWD) /*!< ADC Analog watchdog 1 event */ +#define ADC_OVR_EVENT ((uint32_t)ADC_FLAG_OVR) /*!< ADC overrun event */ +/** + * @} + */ + +/** @defgroup ADC_interrupts_definition ADC interrupts definition + * @{ + */ +#define ADC_IT_AWD ADC_IER_AWDIE /*!< ADC Analog watchdog interrupt source */ +#define ADC_IT_OVR ADC_IER_OVRIE /*!< ADC overrun interrupt source */ +#define ADC_IT_EOS ADC_IER_EOSEQIE /*!< ADC End of Regular sequence of Conversions interrupt source */ +#define ADC_IT_EOC ADC_IER_EOCIE /*!< ADC End of Regular Conversion interrupt source */ +#define ADC_IT_EOSMP ADC_IER_EOSMPIE /*!< ADC End of Sampling interrupt source */ +#define ADC_IT_RDY ADC_IER_ADRDYIE /*!< ADC Ready interrupt source */ +/** + * @} + */ + +/** @defgroup ADC_flags_definition ADC flags definition + * @{ + */ +#define ADC_FLAG_AWD ADC_ISR_AWD /*!< ADC Analog watchdog flag */ +#define ADC_FLAG_OVR ADC_ISR_OVR /*!< ADC overrun flag */ +#define ADC_FLAG_EOS ADC_ISR_EOSEQ /*!< ADC End of Regular sequence of Conversions flag */ +#define ADC_FLAG_EOC ADC_ISR_EOC /*!< ADC End of Regular Conversion flag */ +#define ADC_FLAG_EOSMP ADC_ISR_EOSMP /*!< ADC End of Sampling flag */ +#define ADC_FLAG_RDY ADC_ISR_ADRDY /*!< ADC Ready flag */ +/** + * @} + */ + +/** + * @} + */ + + +/* Private constants ---------------------------------------------------------*/ + +/** @addtogroup ADC_Private_Constants ADC Private Constants + * @{ + */ + +/** @defgroup ADC_Internal_HAL_driver_Ext_trig_src_Regular ADC Internal HAL driver Ext trig src Regular + * @{ + */ + +/* List of external triggers of regular group for ADC1: */ +/* (used internally by HAL driver. To not use into HAL structure parameters) */ +#define ADC1_2_EXTERNALTRIG_T1_TRGO (0x00000000U) +#define ADC1_2_EXTERNALTRIG_T1_CC4 ((uint32_t)ADC_CFGR1_EXTSEL_0) +#define ADC1_2_EXTERNALTRIG_T2_TRGO ((uint32_t)ADC_CFGR1_EXTSEL_1) +#define ADC1_2_EXTERNALTRIG_T3_TRGO ((uint32_t)(ADC_CFGR1_EXTSEL_1 | ADC_CFGR1_EXTSEL_0)) +#define ADC1_2_EXTERNALTRIG_T15_TRGO ((uint32_t)ADC_CFGR1_EXTSEL_2) +/** + * @} + */ + +/* Combination of all post-conversion flags bits: EOC/EOS, OVR, AWD */ +#define ADC_FLAG_POSTCONV_ALL (ADC_FLAG_AWD | ADC_FLAG_OVR | ADC_FLAG_EOS | ADC_FLAG_EOC) + +/** + * @} + */ + + +/* Exported macro ------------------------------------------------------------*/ + +/** @defgroup ADC_Exported_Macros ADC Exported Macros + * @{ + */ +/* Macro for internal HAL driver usage, and possibly can be used into code of */ +/* final user. */ + +/** + * @brief Enable the ADC peripheral + * @param __HANDLE__ ADC handle + * @retval None + */ +#define __HAL_ADC_ENABLE(__HANDLE__) \ + ((__HANDLE__)->Instance->CR |= ADC_CR_ADEN) + +/** + * @brief Disable the ADC peripheral + * @param __HANDLE__ ADC handle + * @retval None + */ +#define __HAL_ADC_DISABLE(__HANDLE__) \ + do{ \ + (__HANDLE__)->Instance->CR |= ADC_CR_ADDIS; \ + __HAL_ADC_CLEAR_FLAG((__HANDLE__), (ADC_FLAG_EOSMP | ADC_FLAG_RDY)); \ + } while(0) + +/** + * @brief Enable the ADC end of conversion interrupt. + * @param __HANDLE__ ADC handle + * @param __INTERRUPT__ ADC Interrupt + * This parameter can be any combination of the following values: + * @arg ADC_IT_EOC: ADC End of Regular Conversion interrupt source + * @arg ADC_IT_EOS: ADC End of Regular sequence of Conversions interrupt source + * @arg ADC_IT_AWD: ADC Analog watchdog interrupt source + * @arg ADC_IT_OVR: ADC overrun interrupt source + * @arg ADC_IT_EOSMP: ADC End of Sampling interrupt source + * @arg ADC_IT_RDY: ADC Ready interrupt source + * @retval None + */ +#define __HAL_ADC_ENABLE_IT(__HANDLE__, __INTERRUPT__) \ + (((__HANDLE__)->Instance->IER) |= (__INTERRUPT__)) + +/** + * @brief Disable the ADC end of conversion interrupt. + * @param __HANDLE__ ADC handle + * @param __INTERRUPT__ ADC Interrupt + * This parameter can be any combination of the following values: + * @arg ADC_IT_EOC: ADC End of Regular Conversion interrupt source + * @arg ADC_IT_EOS: ADC End of Regular sequence of Conversions interrupt source + * @arg ADC_IT_AWD: ADC Analog watchdog interrupt source + * @arg ADC_IT_OVR: ADC overrun interrupt source + * @arg ADC_IT_EOSMP: ADC End of Sampling interrupt source + * @arg ADC_IT_RDY: ADC Ready interrupt source + * @retval None + */ +#define __HAL_ADC_DISABLE_IT(__HANDLE__, __INTERRUPT__) \ + (((__HANDLE__)->Instance->IER) &= ~(__INTERRUPT__)) + +/** @brief Checks if the specified ADC interrupt source is enabled or disabled. + * @param __HANDLE__ ADC handle + * @param __INTERRUPT__ ADC interrupt source to check + * This parameter can be any combination of the following values: + * @arg ADC_IT_EOC: ADC End of Regular Conversion interrupt source + * @arg ADC_IT_EOS: ADC End of Regular sequence of Conversions interrupt source + * @arg ADC_IT_AWD: ADC Analog watchdog interrupt source + * @arg ADC_IT_OVR: ADC overrun interrupt source + * @arg ADC_IT_EOSMP: ADC End of Sampling interrupt source + * @arg ADC_IT_RDY: ADC Ready interrupt source + * @retval State ofinterruption (SET or RESET) + */ +#define __HAL_ADC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) \ + (((__HANDLE__)->Instance->IER & (__INTERRUPT__)) == (__INTERRUPT__)) + +/** + * @brief Get the selected ADC's flag status. + * @param __HANDLE__ ADC handle + * @param __FLAG__ ADC flag + * This parameter can be any combination of the following values: + * @arg ADC_FLAG_EOC: ADC End of Regular conversion flag + * @arg ADC_FLAG_EOS: ADC End of Regular sequence of Conversions flag + * @arg ADC_FLAG_AWD: ADC Analog watchdog flag + * @arg ADC_FLAG_OVR: ADC overrun flag + * @arg ADC_FLAG_EOSMP: ADC End of Sampling flag + * @arg ADC_FLAG_RDY: ADC Ready flag + * @retval None + */ +#define __HAL_ADC_GET_FLAG(__HANDLE__, __FLAG__) \ + ((((__HANDLE__)->Instance->ISR) & (__FLAG__)) == (__FLAG__)) + +/** + * @brief Clear the ADC's pending flags + * @param __HANDLE__ ADC handle + * @param __FLAG__ ADC flag + * This parameter can be any combination of the following values: + * @arg ADC_FLAG_EOC: ADC End of Regular conversion flag + * @arg ADC_FLAG_EOS: ADC End of Regular sequence of Conversions flag + * @arg ADC_FLAG_AWD: ADC Analog watchdog flag + * @arg ADC_FLAG_OVR: ADC overrun flag + * @arg ADC_FLAG_EOSMP: ADC End of Sampling flag + * @arg ADC_FLAG_RDY: ADC Ready flag + * @retval None + */ +/* Note: bit cleared bit by writing 1 (writing 0 has no effect on any bit of register ISR) */ +#define __HAL_ADC_CLEAR_FLAG(__HANDLE__, __FLAG__) \ + (((__HANDLE__)->Instance->ISR) = (__FLAG__)) + +/** @brief Reset ADC handle state + * @param __HANDLE__ ADC handle + * @retval None + */ +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) +#define __HAL_ADC_RESET_HANDLE_STATE(__HANDLE__) \ + do{ \ + (__HANDLE__)->State = HAL_ADC_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_ADC_RESET_HANDLE_STATE(__HANDLE__) \ + ((__HANDLE__)->State = HAL_ADC_STATE_RESET) +#endif + +/** + * @} + */ + + +/* Private macro -------------------------------------------------------------*/ + +/** @defgroup ADC_Private_Macros ADC Private Macros + * @{ + */ +/* Macro reserved for internal HAL driver usage, not intended to be used in */ +/* code of final user. */ + + +/** + * @brief Verification of hardware constraints before ADC can be enabled + * @param __HANDLE__ ADC handle + * @retval SET (ADC can be enabled) or RESET (ADC cannot be enabled) + */ +#define ADC_ENABLING_CONDITIONS(__HANDLE__) \ + (( ( ((__HANDLE__)->Instance->CR) & \ + (ADC_CR_ADCAL | ADC_CR_ADSTP | ADC_CR_ADSTART | ADC_CR_ADDIS | ADC_CR_ADEN) \ + ) == RESET \ + ) ? SET : RESET) + +/** + * @brief Verification of hardware constraints before ADC can be disabled + * @param __HANDLE__ ADC handle + * @retval SET (ADC can be disabled) or RESET (ADC cannot be disabled) + */ +#define ADC_DISABLING_CONDITIONS(__HANDLE__) \ + (( ( ((__HANDLE__)->Instance->CR) & \ + (ADC_CR_ADSTART | ADC_CR_ADEN)) == ADC_CR_ADEN \ + ) ? SET : RESET) + +/** + * @brief Verification of ADC state: enabled or disabled + * @param __HANDLE__ ADC handle + * @retval SET (ADC enabled) or RESET (ADC disabled) + */ +/* Note: If low power mode AutoPowerOff is enabled, power-on/off phases are */ +/* performed automatically by hardware and flag ADC_FLAG_RDY is not */ +/* set. */ +#define ADC_IS_ENABLE(__HANDLE__) \ + (( ((((__HANDLE__)->Instance->CR) & (ADC_CR_ADEN | ADC_CR_ADDIS)) == ADC_CR_ADEN) && \ + (((((__HANDLE__)->Instance->ISR) & ADC_FLAG_RDY) == ADC_FLAG_RDY) || \ + ((((__HANDLE__)->Instance->CFGR1) & ADC_CFGR1_AUTOFF) == ADC_CFGR1_AUTOFF) ) \ + ) ? SET : RESET) + +/** + * @brief Test if conversion trigger of regular group is software start + * or external trigger. + * @param __HANDLE__ ADC handle + * @retval SET (software start) or RESET (external trigger) + */ +#define ADC_IS_SOFTWARE_START_REGULAR(__HANDLE__) \ + (((__HANDLE__)->Instance->CFGR1 & ADC_CFGR1_EXTEN) == RESET) + +/** + * @brief Check if no conversion on going on regular group + * @param __HANDLE__ ADC handle + * @retval SET (conversion is on going) or RESET (no conversion is on going) + */ +#define ADC_IS_CONVERSION_ONGOING_REGULAR(__HANDLE__) \ + (( (((__HANDLE__)->Instance->CR) & ADC_CR_ADSTART) == RESET \ + ) ? RESET : SET) + +/** + * @brief Returns resolution bits in CFGR1 register: RES[1:0]. + * Returned value is among parameters to @ref ADC_Resolution. + * @param __HANDLE__ ADC handle + * @retval None + */ +#define ADC_GET_RESOLUTION(__HANDLE__) \ + (((__HANDLE__)->Instance->CFGR1) & ADC_CFGR1_RES) + +/** + * @brief Returns ADC sample time bits in SMPR register: SMP[2:0]. + * Returned value is among parameters to @ref ADC_Resolution. + * @param __HANDLE__ ADC handle + * @retval None + */ +#define ADC_GET_SAMPLINGTIME(__HANDLE__) \ + (((__HANDLE__)->Instance->SMPR) & ADC_SMPR_SMP) + +/** + * @brief Simultaneously clears and sets specific bits of the handle State + * @note: ADC_STATE_CLR_SET() macro is merely aliased to generic macro MODIFY_REG(), + * the first parameter is the ADC handle State, the second parameter is the + * bit field to clear, the third and last parameter is the bit field to set. + * @retval None + */ +#define ADC_STATE_CLR_SET MODIFY_REG + +/** + * @brief Clear ADC error code (set it to error code: "no error") + * @param __HANDLE__ ADC handle + * @retval None + */ +#define ADC_CLEAR_ERRORCODE(__HANDLE__) \ + ((__HANDLE__)->ErrorCode = HAL_ADC_ERROR_NONE) + + +/** + * @brief Configure the channel number into channel selection register + * @param _CHANNEL_ ADC Channel + * @retval None + */ +/* This function converts ADC channels from numbers (see defgroup ADC_channels) + to bitfields, to get the equivalence of CMSIS channels: + ADC_CHANNEL_0 ((uint32_t) ADC_CHSELR_CHSEL0) + ADC_CHANNEL_1 ((uint32_t) ADC_CHSELR_CHSEL1) + ADC_CHANNEL_2 ((uint32_t) ADC_CHSELR_CHSEL2) + ADC_CHANNEL_3 ((uint32_t) ADC_CHSELR_CHSEL3) + ADC_CHANNEL_4 ((uint32_t) ADC_CHSELR_CHSEL4) + ADC_CHANNEL_5 ((uint32_t) ADC_CHSELR_CHSEL5) + ADC_CHANNEL_6 ((uint32_t) ADC_CHSELR_CHSEL6) + ADC_CHANNEL_7 ((uint32_t) ADC_CHSELR_CHSEL7) + ADC_CHANNEL_8 ((uint32_t) ADC_CHSELR_CHSEL8) + ADC_CHANNEL_9 ((uint32_t) ADC_CHSELR_CHSEL9) + ADC_CHANNEL_10 ((uint32_t) ADC_CHSELR_CHSEL10) + ADC_CHANNEL_11 ((uint32_t) ADC_CHSELR_CHSEL11) + ADC_CHANNEL_12 ((uint32_t) ADC_CHSELR_CHSEL12) + ADC_CHANNEL_13 ((uint32_t) ADC_CHSELR_CHSEL13) + ADC_CHANNEL_14 ((uint32_t) ADC_CHSELR_CHSEL14) + ADC_CHANNEL_15 ((uint32_t) ADC_CHSELR_CHSEL15) + ADC_CHANNEL_16 ((uint32_t) ADC_CHSELR_CHSEL16) + ADC_CHANNEL_17 ((uint32_t) ADC_CHSELR_CHSEL17) + ADC_CHANNEL_18 ((uint32_t) ADC_CHSELR_CHSEL18) +*/ +#define ADC_CHSELR_CHANNEL(_CHANNEL_) \ + ( 1U << (_CHANNEL_)) + +/** + * @brief Set the ADC's sample time + * @param _SAMPLETIME_ Sample time parameter. + * @retval None + */ +/* Note: ADC sampling time set using mask ADC_SMPR_SMP due to parameter */ +/* "ADC_SAMPLETIME_1CYCLE_5" defined with a dummy bit (bit used to */ +/* distinguish this parameter versus reset value 0x00000000, */ +/* in the context of management of parameters "SamplingTimeCommon" */ +/* and "SamplingTime" (obsolete)). */ +#define ADC_SMPR_SET(_SAMPLETIME_) \ + ((_SAMPLETIME_) & (ADC_SMPR_SMP)) + +/** + * @brief Set the Analog Watchdog 1 channel. + * @param _CHANNEL_ channel to be monitored by Analog Watchdog 1. + * @retval None + */ +#define ADC_CFGR_AWDCH(_CHANNEL_) \ + ((_CHANNEL_) << 26U) + +/** + * @brief Enable ADC discontinuous conversion mode for regular group + * @param _REG_DISCONTINUOUS_MODE_ Regular discontinuous mode. + * @retval None + */ +#define ADC_CFGR1_REG_DISCCONTINUOUS(_REG_DISCONTINUOUS_MODE_) \ + ((_REG_DISCONTINUOUS_MODE_) << 16U) + +/** + * @brief Enable the ADC auto off mode. + * @param _AUTOOFF_ Auto off bit enable or disable. + * @retval None + */ +#define ADC_CFGR1_AUTOOFF(_AUTOOFF_) \ + ((_AUTOOFF_) << 15U) + +/** + * @brief Enable the ADC auto delay mode. + * @param _AUTOWAIT_ Auto delay bit enable or disable. + * @retval None + */ +#define ADC_CFGR1_AUTOWAIT(_AUTOWAIT_) \ + ((_AUTOWAIT_) << 14U) + +/** + * @brief Enable ADC continuous conversion mode. + * @param _CONTINUOUS_MODE_ Continuous mode. + * @retval None + */ +#define ADC_CFGR1_CONTINUOUS(_CONTINUOUS_MODE_) \ + ((_CONTINUOUS_MODE_) << 13U) + +/** + * @brief Enable ADC overrun mode. + * @param _OVERRUN_MODE_ Overrun mode. + * @retval Overun bit setting to be programmed into CFGR register + */ +/* Note: Bit ADC_CFGR1_OVRMOD not used directly in constant */ +/* "ADC_OVR_DATA_OVERWRITTEN" to have this case defined to 0x00, to set it */ +/* as the default case to be compliant with other STM32 devices. */ +#define ADC_CFGR1_OVERRUN(_OVERRUN_MODE_) \ + ( ( (_OVERRUN_MODE_) != (ADC_OVR_DATA_PRESERVED) \ + )? (ADC_CFGR1_OVRMOD) : (0x00000000) \ + ) + +/** + * @brief Enable ADC scan mode to convert multiple ranks with sequencer. + * @param _SCAN_MODE_ Scan conversion mode. + * @retval None + */ +/* Note: Scan mode set using this macro (instead of parameter direct set) */ +/* due to different modes on other STM32 devices: to avoid any */ +/* unwanted setting, the exact parameter corresponding to the device */ +/* must be passed to this macro. */ +#define ADC_SCANDIR(_SCAN_MODE_) \ + ( ( (_SCAN_MODE_) == (ADC_SCAN_DIRECTION_BACKWARD) \ + )? (ADC_CFGR1_SCANDIR) : (0x00000000) \ + ) + +/** + * @brief Enable the ADC DMA continuous request. + * @param _DMACONTREQ_MODE_ DMA continuous request mode. + * @retval None + */ +#define ADC_CFGR1_DMACONTREQ(_DMACONTREQ_MODE_) \ + ((_DMACONTREQ_MODE_) << 1U) + +/** + * @brief Configure the analog watchdog high threshold into register TR. + * @param _Threshold_ Threshold value + * @retval None + */ +#define ADC_TRX_HIGHTHRESHOLD(_Threshold_) \ + ((_Threshold_) << 16U) + +/** + * @brief Shift the AWD threshold in function of the selected ADC resolution. + * Thresholds have to be left-aligned on bit 11, the LSB (right bits) are set to 0. + * If resolution 12 bits, no shift. + * If resolution 10 bits, shift of 2 ranks on the left. + * If resolution 8 bits, shift of 4 ranks on the left. + * If resolution 6 bits, shift of 6 ranks on the left. + * therefore, shift = (12 - resolution) = 12 - (12- (((RES[1:0]) >> 3)*2)) + * @param __HANDLE__ ADC handle + * @param _Threshold_ Value to be shifted + * @retval None + */ +#define ADC_AWD1THRESHOLD_SHIFT_RESOLUTION(__HANDLE__, _Threshold_) \ + ((_Threshold_) << ((((__HANDLE__)->Instance->CFGR1 & ADC_CFGR1_RES) >> 3U)*2)) + + +#define IS_ADC_CLOCKPRESCALER(ADC_CLOCK) (((ADC_CLOCK) == ADC_CLOCK_ASYNC_DIV1) || \ + ((ADC_CLOCK) == ADC_CLOCK_SYNC_PCLK_DIV2) || \ + ((ADC_CLOCK) == ADC_CLOCK_SYNC_PCLK_DIV4) ) + +#define IS_ADC_RESOLUTION(RESOLUTION) (((RESOLUTION) == ADC_RESOLUTION_12B) || \ + ((RESOLUTION) == ADC_RESOLUTION_10B) || \ + ((RESOLUTION) == ADC_RESOLUTION_8B) || \ + ((RESOLUTION) == ADC_RESOLUTION_6B) ) + +#define IS_ADC_DATA_ALIGN(ALIGN) (((ALIGN) == ADC_DATAALIGN_RIGHT) || \ + ((ALIGN) == ADC_DATAALIGN_LEFT) ) + +#define IS_ADC_SCAN_MODE(SCAN_MODE) (((SCAN_MODE) == ADC_SCAN_DIRECTION_FORWARD) || \ + ((SCAN_MODE) == ADC_SCAN_DIRECTION_BACKWARD) ) + +#define IS_ADC_EXTTRIG_EDGE(EDGE) (((EDGE) == ADC_EXTERNALTRIGCONVEDGE_NONE) || \ + ((EDGE) == ADC_EXTERNALTRIGCONVEDGE_RISING) || \ + ((EDGE) == ADC_EXTERNALTRIGCONVEDGE_FALLING) || \ + ((EDGE) == ADC_EXTERNALTRIGCONVEDGE_RISINGFALLING) ) + +#define IS_ADC_EOC_SELECTION(EOC_SELECTION) (((EOC_SELECTION) == ADC_EOC_SINGLE_CONV) || \ + ((EOC_SELECTION) == ADC_EOC_SEQ_CONV) ) + +#define IS_ADC_OVERRUN(OVR) (((OVR) == ADC_OVR_DATA_PRESERVED) || \ + ((OVR) == ADC_OVR_DATA_OVERWRITTEN) ) + +#define IS_ADC_RANK(WATCHDOG) (((WATCHDOG) == ADC_RANK_CHANNEL_NUMBER) || \ + ((WATCHDOG) == ADC_RANK_NONE) ) + +#define IS_ADC_SAMPLE_TIME(TIME) (((TIME) == ADC_SAMPLETIME_1CYCLE_5) || \ + ((TIME) == ADC_SAMPLETIME_7CYCLES_5) || \ + ((TIME) == ADC_SAMPLETIME_13CYCLES_5) || \ + ((TIME) == ADC_SAMPLETIME_28CYCLES_5) || \ + ((TIME) == ADC_SAMPLETIME_41CYCLES_5) || \ + ((TIME) == ADC_SAMPLETIME_55CYCLES_5) || \ + ((TIME) == ADC_SAMPLETIME_71CYCLES_5) || \ + ((TIME) == ADC_SAMPLETIME_239CYCLES_5) ) + +#define IS_ADC_ANALOG_WATCHDOG_MODE(WATCHDOG) (((WATCHDOG) == ADC_ANALOGWATCHDOG_NONE) || \ + ((WATCHDOG) == ADC_ANALOGWATCHDOG_SINGLE_REG) || \ + ((WATCHDOG) == ADC_ANALOGWATCHDOG_ALL_REG) ) + +#define IS_ADC_EVENT_TYPE(EVENT) (((EVENT) == ADC_AWD_EVENT) || \ + ((EVENT) == ADC_OVR_EVENT) ) + +/** @defgroup ADC_range_verification ADC range verification + * in function of ADC resolution selected (12, 10, 8 or 6 bits) + * @{ + */ +#define IS_ADC_RANGE(RESOLUTION, ADC_VALUE) \ + ((((RESOLUTION) == ADC_RESOLUTION_12B) && ((ADC_VALUE) <= (0x0FFFU))) || \ + (((RESOLUTION) == ADC_RESOLUTION_10B) && ((ADC_VALUE) <= (0x03FFU))) || \ + (((RESOLUTION) == ADC_RESOLUTION_8B) && ((ADC_VALUE) <= (0x00FFU))) || \ + (((RESOLUTION) == ADC_RESOLUTION_6B) && ((ADC_VALUE) <= (0x003FU))) ) +/** + * @} + */ + +/** @defgroup ADC_regular_rank_verification ADC regular rank verification + * @{ + */ +#define IS_ADC_REGULAR_RANK(RANK) (((RANK) >= (1U)) && ((RANK) <= (16U))) +/** + * @} + */ + +/** + * @} + */ + +/* Include ADC HAL Extension module */ +#include "stm32f0xx_hal_adc_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup ADC_Exported_Functions + * @{ + */ + +/** @addtogroup ADC_Exported_Functions_Group1 + * @{ + */ + + +/* Initialization and de-initialization functions **********************************/ +HAL_StatusTypeDef HAL_ADC_Init(ADC_HandleTypeDef* hadc); +HAL_StatusTypeDef HAL_ADC_DeInit(ADC_HandleTypeDef *hadc); +void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc); +void HAL_ADC_MspDeInit(ADC_HandleTypeDef* hadc); + +#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1) +/* Callbacks Register/UnRegister functions ***********************************/ +HAL_StatusTypeDef HAL_ADC_RegisterCallback(ADC_HandleTypeDef *hadc, HAL_ADC_CallbackIDTypeDef CallbackID, pADC_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_ADC_UnRegisterCallback(ADC_HandleTypeDef *hadc, HAL_ADC_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* IO operation functions *****************************************************/ + +/** @addtogroup ADC_Exported_Functions_Group2 + * @{ + */ + + +/* Blocking mode: Polling */ +HAL_StatusTypeDef HAL_ADC_Start(ADC_HandleTypeDef* hadc); +HAL_StatusTypeDef HAL_ADC_Stop(ADC_HandleTypeDef* hadc); +HAL_StatusTypeDef HAL_ADC_PollForConversion(ADC_HandleTypeDef* hadc, uint32_t Timeout); +HAL_StatusTypeDef HAL_ADC_PollForEvent(ADC_HandleTypeDef* hadc, uint32_t EventType, uint32_t Timeout); + +/* Non-blocking mode: Interruption */ +HAL_StatusTypeDef HAL_ADC_Start_IT(ADC_HandleTypeDef* hadc); +HAL_StatusTypeDef HAL_ADC_Stop_IT(ADC_HandleTypeDef* hadc); + +/* Non-blocking mode: DMA */ +HAL_StatusTypeDef HAL_ADC_Start_DMA(ADC_HandleTypeDef* hadc, uint32_t* pData, uint32_t Length); +HAL_StatusTypeDef HAL_ADC_Stop_DMA(ADC_HandleTypeDef* hadc); + +/* ADC retrieve conversion value intended to be used with polling or interruption */ +uint32_t HAL_ADC_GetValue(ADC_HandleTypeDef* hadc); + +/* ADC IRQHandler and Callbacks used in non-blocking modes (Interruption and DMA) */ +void HAL_ADC_IRQHandler(ADC_HandleTypeDef* hadc); +void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc); +void HAL_ADC_ConvHalfCpltCallback(ADC_HandleTypeDef* hadc); +void HAL_ADC_LevelOutOfWindowCallback(ADC_HandleTypeDef* hadc); +void HAL_ADC_ErrorCallback(ADC_HandleTypeDef *hadc); +/** + * @} + */ + + +/* Peripheral Control functions ***********************************************/ +/** @addtogroup ADC_Exported_Functions_Group3 + * @{ + */ +HAL_StatusTypeDef HAL_ADC_ConfigChannel(ADC_HandleTypeDef* hadc, ADC_ChannelConfTypeDef* sConfig); +HAL_StatusTypeDef HAL_ADC_AnalogWDGConfig(ADC_HandleTypeDef* hadc, ADC_AnalogWDGConfTypeDef* AnalogWDGConfig); +/** + * @} + */ + + +/* Peripheral State functions *************************************************/ +/** @addtogroup ADC_Exported_Functions_Group4 + * @{ + */ +uint32_t HAL_ADC_GetState(ADC_HandleTypeDef* hadc); +uint32_t HAL_ADC_GetError(ADC_HandleTypeDef *hadc); +/** + * @} + */ + + +/** + * @} + */ + + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + + +#endif /* STM32F0xx_HAL_ADC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc_ex.h new file mode 100644 index 0000000..96e74cc --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_adc_ex.h @@ -0,0 +1,299 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_adc_ex.h + * @author MCD Application Team + * @brief Header file of ADC HAL Extension module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_ADC_EX_H +#define __STM32F0xx_HAL_ADC_EX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup ADCEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup ADC_Exported_Constants ADC Exported Constants + * @{ + */ + +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +#define ADC_CCR_ALL (ADC_CCR_VBATEN | ADC_CCR_TSEN | ADC_CCR_VREFEN) +#else +#define ADC_CCR_ALL (ADC_CCR_TSEN | ADC_CCR_VREFEN) +#endif + +/** @defgroup ADC_External_trigger_source_Regular ADC External trigger source Regular + * @{ + */ +/* List of external triggers with generic trigger name, sorted by trigger */ +/* name: */ + +/* External triggers of regular group for ADC1 */ +#define ADC_EXTERNALTRIGCONV_T1_TRGO ADC1_2_EXTERNALTRIG_T1_TRGO +#define ADC_EXTERNALTRIGCONV_T1_CC4 ADC1_2_EXTERNALTRIG_T1_CC4 +#define ADC_EXTERNALTRIGCONV_T3_TRGO ADC1_2_EXTERNALTRIG_T3_TRGO +#define ADC_SOFTWARE_START (ADC_CFGR1_EXTSEL + 1U) + +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +#define ADC_EXTERNALTRIGCONV_T2_TRGO ADC1_2_EXTERNALTRIG_T2_TRGO +#endif + +#if !defined(STM32F030x6) && !defined(STM32F070x6) && !defined(STM32F042x6) +#define ADC_EXTERNALTRIGCONV_T15_TRGO ADC1_2_EXTERNALTRIG_T15_TRGO +#endif + +/** + * @} + */ + + +/** @defgroup ADC_channels ADC channels + * @{ + */ +/* Note: Depending on devices, some channels may not be available on package */ +/* pins. Refer to device datasheet for channels availability. */ +/* Note: Channels are used by bitfields for setting of channel selection */ +/* (register ADC_CHSELR) and used by number for setting of analog */ +/* watchdog channel (bits AWDCH in register ADC_CFGR1). */ +/* Channels are defined with decimal numbers and converted them to */ +/* bitfields when needed. */ +#define ADC_CHANNEL_0 ( 0x00000000U) +#define ADC_CHANNEL_1 ( 0x00000001U) +#define ADC_CHANNEL_2 ( 0x00000002U) +#define ADC_CHANNEL_3 ( 0x00000003U) +#define ADC_CHANNEL_4 ( 0x00000004U) +#define ADC_CHANNEL_5 ( 0x00000005U) +#define ADC_CHANNEL_6 ( 0x00000006U) +#define ADC_CHANNEL_7 ( 0x00000007U) +#define ADC_CHANNEL_8 ( 0x00000008U) +#define ADC_CHANNEL_9 ( 0x00000009U) +#define ADC_CHANNEL_10 ( 0x0000000AU) +#define ADC_CHANNEL_11 ( 0x0000000BU) +#define ADC_CHANNEL_12 ( 0x0000000CU) +#define ADC_CHANNEL_13 ( 0x0000000DU) +#define ADC_CHANNEL_14 ( 0x0000000EU) +#define ADC_CHANNEL_15 ( 0x0000000FU) +#define ADC_CHANNEL_16 ( 0x00000010U) +#define ADC_CHANNEL_17 ( 0x00000011U) + +#define ADC_CHANNEL_TEMPSENSOR ADC_CHANNEL_16 +#define ADC_CHANNEL_VREFINT ADC_CHANNEL_17 + +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +#define ADC_CHANNEL_18 ( 0x00000012U) +#define ADC_CHANNEL_VBAT ADC_CHANNEL_18 +#endif + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ + + +/* Private macros ------------------------------------------------------------*/ + +/** @defgroup ADCEx_Private_Macros ADCEx Private Macros + * @{ + */ +/* Macro reserved for internal HAL driver usage, not intended to be used in */ +/* code of final user. */ + +/** + * @brief Test if the selected ADC channel is an internal channel + * VrefInt/TempSensor/Vbat + * Note: On STM32F0, availability of internal channel Vbat depends on + * devices lines. + * @param __CHANNEL__ ADC channel + * @retval None + */ +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +#define ADC_IS_CHANNEL_INTERNAL(__CHANNEL__) \ + (((__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR) || \ + ((__CHANNEL__) == ADC_CHANNEL_VREFINT) || \ + ((__CHANNEL__) == ADC_CHANNEL_VBAT) \ + ) +#else +#define ADC_IS_CHANNEL_INTERNAL(__CHANNEL__) \ + (((__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR) || \ + ((__CHANNEL__) == ADC_CHANNEL_VREFINT) \ + ) +#endif + +/** + * @brief Select the internal measurement path to be enabled/disabled + * corresponding to the selected ADC internal channel + * VrefInt/TempSensor/Vbat. + * Note: On STM32F0, availability of internal channel Vbat depends on + * devices lines. + * @param __CHANNEL__ ADC channel + * @retval Bit of register ADC_CCR + */ +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +#define ADC_CHANNEL_INTERNAL_PATH(__CHANNEL__) \ + (( (__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR \ + )? \ + (ADC_CCR_TSEN) \ + : \ + ( \ + ( (__CHANNEL__) == ADC_CHANNEL_VREFINT \ + )? \ + (ADC_CCR_VREFEN) \ + : \ + (ADC_CCR_VBATEN) \ + ) \ + ) +#else +#define ADC_CHANNEL_INTERNAL_PATH(__CHANNEL__) \ + (( (__CHANNEL__) == ADC_CHANNEL_TEMPSENSOR \ + )? \ + (ADC_CCR_TSEN) \ + : \ + (ADC_CCR_VREFEN) \ + ) +#endif + + +#if defined (STM32F030x6) || defined (STM32F070x6) +#define IS_ADC_EXTTRIG(REGTRIG) (((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_CC4) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T3_TRGO) || \ + ((REGTRIG) == ADC_SOFTWARE_START)) +#elif defined (STM32F042x6) +#define IS_ADC_EXTTRIG(REGTRIG) (((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_CC4) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T2_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T3_TRGO) || \ + ((REGTRIG) == ADC_SOFTWARE_START)) + +#elif defined (STM32F030xC) || defined (STM32F070xB) || defined (STM32F030x8) +#define IS_ADC_EXTTRIG(REGTRIG) (((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_CC4) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T3_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T15_TRGO) || \ + ((REGTRIG) == ADC_SOFTWARE_START)) +#else +#define IS_ADC_EXTTRIG(REGTRIG) (((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T1_CC4) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T2_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T3_TRGO) || \ + ((REGTRIG) == ADC_EXTERNALTRIGCONV_T15_TRGO) || \ + ((REGTRIG) == ADC_SOFTWARE_START)) +#endif + +#if !defined(STM32F030x6) && !defined(STM32F030x8) && !defined(STM32F070x6) && !defined(STM32F070xB) && !defined(STM32F030xC) +#define IS_ADC_CHANNEL(CHANNEL) (((CHANNEL) == ADC_CHANNEL_0) || \ + ((CHANNEL) == ADC_CHANNEL_1) || \ + ((CHANNEL) == ADC_CHANNEL_2) || \ + ((CHANNEL) == ADC_CHANNEL_3) || \ + ((CHANNEL) == ADC_CHANNEL_4) || \ + ((CHANNEL) == ADC_CHANNEL_5) || \ + ((CHANNEL) == ADC_CHANNEL_6) || \ + ((CHANNEL) == ADC_CHANNEL_7) || \ + ((CHANNEL) == ADC_CHANNEL_8) || \ + ((CHANNEL) == ADC_CHANNEL_9) || \ + ((CHANNEL) == ADC_CHANNEL_10) || \ + ((CHANNEL) == ADC_CHANNEL_11) || \ + ((CHANNEL) == ADC_CHANNEL_12) || \ + ((CHANNEL) == ADC_CHANNEL_13) || \ + ((CHANNEL) == ADC_CHANNEL_14) || \ + ((CHANNEL) == ADC_CHANNEL_15) || \ + ((CHANNEL) == ADC_CHANNEL_TEMPSENSOR) || \ + ((CHANNEL) == ADC_CHANNEL_VREFINT) || \ + ((CHANNEL) == ADC_CHANNEL_VBAT) ) +#else +#define IS_ADC_CHANNEL(CHANNEL) (((CHANNEL) == ADC_CHANNEL_0) || \ + ((CHANNEL) == ADC_CHANNEL_1) || \ + ((CHANNEL) == ADC_CHANNEL_2) || \ + ((CHANNEL) == ADC_CHANNEL_3) || \ + ((CHANNEL) == ADC_CHANNEL_4) || \ + ((CHANNEL) == ADC_CHANNEL_5) || \ + ((CHANNEL) == ADC_CHANNEL_6) || \ + ((CHANNEL) == ADC_CHANNEL_7) || \ + ((CHANNEL) == ADC_CHANNEL_8) || \ + ((CHANNEL) == ADC_CHANNEL_9) || \ + ((CHANNEL) == ADC_CHANNEL_10) || \ + ((CHANNEL) == ADC_CHANNEL_11) || \ + ((CHANNEL) == ADC_CHANNEL_12) || \ + ((CHANNEL) == ADC_CHANNEL_13) || \ + ((CHANNEL) == ADC_CHANNEL_14) || \ + ((CHANNEL) == ADC_CHANNEL_15) || \ + ((CHANNEL) == ADC_CHANNEL_TEMPSENSOR) || \ + ((CHANNEL) == ADC_CHANNEL_VREFINT) ) +#endif + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup ADCEx_Exported_Functions + * @{ + */ + +/* IO operation functions *****************************************************/ +/** @addtogroup ADCEx_Exported_Functions_Group1 + * @{ + */ + +/* ADC calibration */ +HAL_StatusTypeDef HAL_ADCEx_Calibration_Start(ADC_HandleTypeDef* hadc); +/** + * @} + */ + + +/** + * @} + */ + + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_ADC_EX_H */ + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_can.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_can.h new file mode 100644 index 0000000..953fafb --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_can.h @@ -0,0 +1,842 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_can.h + * @author MCD Application Team + * @brief Header file of CAN HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_CAN_H +#define STM32F0xx_HAL_CAN_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#if defined (CAN) +/** @addtogroup CAN + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup CAN_Exported_Types CAN Exported Types + * @{ + */ +/** + * @brief HAL State structures definition + */ +typedef enum +{ + HAL_CAN_STATE_RESET = 0x00U, /*!< CAN not yet initialized or disabled */ + HAL_CAN_STATE_READY = 0x01U, /*!< CAN initialized and ready for use */ + HAL_CAN_STATE_LISTENING = 0x02U, /*!< CAN receive process is ongoing */ + HAL_CAN_STATE_SLEEP_PENDING = 0x03U, /*!< CAN sleep request is pending */ + HAL_CAN_STATE_SLEEP_ACTIVE = 0x04U, /*!< CAN sleep mode is active */ + HAL_CAN_STATE_ERROR = 0x05U /*!< CAN error state */ + +} HAL_CAN_StateTypeDef; + +/** + * @brief CAN init structure definition + */ +typedef struct +{ + uint32_t Prescaler; /*!< Specifies the length of a time quantum. + This parameter must be a number between Min_Data = 1 and Max_Data = 1024. */ + + uint32_t Mode; /*!< Specifies the CAN operating mode. + This parameter can be a value of @ref CAN_operating_mode */ + + uint32_t SyncJumpWidth; /*!< Specifies the maximum number of time quanta the CAN hardware + is allowed to lengthen or shorten a bit to perform resynchronization. + This parameter can be a value of @ref CAN_synchronisation_jump_width */ + + uint32_t TimeSeg1; /*!< Specifies the number of time quanta in Bit Segment 1. + This parameter can be a value of @ref CAN_time_quantum_in_bit_segment_1 */ + + uint32_t TimeSeg2; /*!< Specifies the number of time quanta in Bit Segment 2. + This parameter can be a value of @ref CAN_time_quantum_in_bit_segment_2 */ + + FunctionalState TimeTriggeredMode; /*!< Enable or disable the time triggered communication mode. + This parameter can be set to ENABLE or DISABLE. */ + + FunctionalState AutoBusOff; /*!< Enable or disable the automatic bus-off management. + This parameter can be set to ENABLE or DISABLE. */ + + FunctionalState AutoWakeUp; /*!< Enable or disable the automatic wake-up mode. + This parameter can be set to ENABLE or DISABLE. */ + + FunctionalState AutoRetransmission; /*!< Enable or disable the non-automatic retransmission mode. + This parameter can be set to ENABLE or DISABLE. */ + + FunctionalState ReceiveFifoLocked; /*!< Enable or disable the Receive FIFO Locked mode. + This parameter can be set to ENABLE or DISABLE. */ + + FunctionalState TransmitFifoPriority;/*!< Enable or disable the transmit FIFO priority. + This parameter can be set to ENABLE or DISABLE. */ + +} CAN_InitTypeDef; + +/** + * @brief CAN filter configuration structure definition + */ +typedef struct +{ + uint32_t FilterIdHigh; /*!< Specifies the filter identification number (MSBs for a 32-bit + configuration, first one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterIdLow; /*!< Specifies the filter identification number (LSBs for a 32-bit + configuration, second one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterMaskIdHigh; /*!< Specifies the filter mask number or identification number, + according to the mode (MSBs for a 32-bit configuration, + first one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterMaskIdLow; /*!< Specifies the filter mask number or identification number, + according to the mode (LSBs for a 32-bit configuration, + second one for a 16-bit configuration). + This parameter must be a number between Min_Data = 0x0000 and Max_Data = 0xFFFF. */ + + uint32_t FilterFIFOAssignment; /*!< Specifies the FIFO (0 or 1U) which will be assigned to the filter. + This parameter can be a value of @ref CAN_filter_FIFO */ + + uint32_t FilterBank; /*!< Specifies the filter bank which will be initialized. + This parameter mus be a number between Min_Data = 0 and Max_Data = 13. */ + + uint32_t FilterMode; /*!< Specifies the filter mode to be initialized. + This parameter can be a value of @ref CAN_filter_mode */ + + uint32_t FilterScale; /*!< Specifies the filter scale. + This parameter can be a value of @ref CAN_filter_scale */ + + uint32_t FilterActivation; /*!< Enable or disable the filter. + This parameter can be a value of @ref CAN_filter_activation */ + + uint32_t SlaveStartFilterBank; /*!< Select the start filter bank for the slave CAN instance. + STM32F0xx devices don't support slave CAN instance (dual CAN). Therefore + this parameter is meaningless but it has been kept for compatibility accross + STM32 families. */ + +} CAN_FilterTypeDef; + +/** + * @brief CAN Tx message header structure definition + */ +typedef struct +{ + uint32_t StdId; /*!< Specifies the standard identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x7FF. */ + + uint32_t ExtId; /*!< Specifies the extended identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x1FFFFFFF. */ + + uint32_t IDE; /*!< Specifies the type of identifier for the message that will be transmitted. + This parameter can be a value of @ref CAN_identifier_type */ + + uint32_t RTR; /*!< Specifies the type of frame for the message that will be transmitted. + This parameter can be a value of @ref CAN_remote_transmission_request */ + + uint32_t DLC; /*!< Specifies the length of the frame that will be transmitted. + This parameter must be a number between Min_Data = 0 and Max_Data = 8. */ + + FunctionalState TransmitGlobalTime; /*!< Specifies whether the timestamp counter value captured on start + of frame transmission, is sent in DATA6 and DATA7 replacing pData[6] and pData[7]. + @note: Time Triggered Communication Mode must be enabled. + @note: DLC must be programmed as 8 bytes, in order these 2 bytes are sent. + This parameter can be set to ENABLE or DISABLE. */ + +} CAN_TxHeaderTypeDef; + +/** + * @brief CAN Rx message header structure definition + */ +typedef struct +{ + uint32_t StdId; /*!< Specifies the standard identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x7FF. */ + + uint32_t ExtId; /*!< Specifies the extended identifier. + This parameter must be a number between Min_Data = 0 and Max_Data = 0x1FFFFFFF. */ + + uint32_t IDE; /*!< Specifies the type of identifier for the message that will be transmitted. + This parameter can be a value of @ref CAN_identifier_type */ + + uint32_t RTR; /*!< Specifies the type of frame for the message that will be transmitted. + This parameter can be a value of @ref CAN_remote_transmission_request */ + + uint32_t DLC; /*!< Specifies the length of the frame that will be transmitted. + This parameter must be a number between Min_Data = 0 and Max_Data = 8. */ + + uint32_t Timestamp; /*!< Specifies the timestamp counter value captured on start of frame reception. + @note: Time Triggered Communication Mode must be enabled. + This parameter must be a number between Min_Data = 0 and Max_Data = 0xFFFF. */ + + uint32_t FilterMatchIndex; /*!< Specifies the index of matching acceptance filter element. + This parameter must be a number between Min_Data = 0 and Max_Data = 0xFF. */ + +} CAN_RxHeaderTypeDef; + +/** + * @brief CAN handle Structure definition + */ +typedef struct __CAN_HandleTypeDef +{ + CAN_TypeDef *Instance; /*!< Register base address */ + + CAN_InitTypeDef Init; /*!< CAN required parameters */ + + __IO HAL_CAN_StateTypeDef State; /*!< CAN communication state */ + + __IO uint32_t ErrorCode; /*!< CAN Error code. + This parameter can be a value of @ref CAN_Error_Code */ + +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 + void (* TxMailbox0CompleteCallback)(struct __CAN_HandleTypeDef *hcan);/*!< CAN Tx Mailbox 0 complete callback */ + void (* TxMailbox1CompleteCallback)(struct __CAN_HandleTypeDef *hcan);/*!< CAN Tx Mailbox 1 complete callback */ + void (* TxMailbox2CompleteCallback)(struct __CAN_HandleTypeDef *hcan);/*!< CAN Tx Mailbox 2 complete callback */ + void (* TxMailbox0AbortCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Tx Mailbox 0 abort callback */ + void (* TxMailbox1AbortCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Tx Mailbox 1 abort callback */ + void (* TxMailbox2AbortCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Tx Mailbox 2 abort callback */ + void (* RxFifo0MsgPendingCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Rx FIFO 0 msg pending callback */ + void (* RxFifo0FullCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Rx FIFO 0 full callback */ + void (* RxFifo1MsgPendingCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Rx FIFO 1 msg pending callback */ + void (* RxFifo1FullCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Rx FIFO 1 full callback */ + void (* SleepCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Sleep callback */ + void (* WakeUpFromRxMsgCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Wake Up from Rx msg callback */ + void (* ErrorCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Error callback */ + + void (* MspInitCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Msp Init callback */ + void (* MspDeInitCallback)(struct __CAN_HandleTypeDef *hcan); /*!< CAN Msp DeInit callback */ + +#endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */ +} CAN_HandleTypeDef; + +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 +/** + * @brief HAL CAN common Callback ID enumeration definition + */ +typedef enum +{ + HAL_CAN_TX_MAILBOX0_COMPLETE_CB_ID = 0x00U, /*!< CAN Tx Mailbox 0 complete callback ID */ + HAL_CAN_TX_MAILBOX1_COMPLETE_CB_ID = 0x01U, /*!< CAN Tx Mailbox 1 complete callback ID */ + HAL_CAN_TX_MAILBOX2_COMPLETE_CB_ID = 0x02U, /*!< CAN Tx Mailbox 2 complete callback ID */ + HAL_CAN_TX_MAILBOX0_ABORT_CB_ID = 0x03U, /*!< CAN Tx Mailbox 0 abort callback ID */ + HAL_CAN_TX_MAILBOX1_ABORT_CB_ID = 0x04U, /*!< CAN Tx Mailbox 1 abort callback ID */ + HAL_CAN_TX_MAILBOX2_ABORT_CB_ID = 0x05U, /*!< CAN Tx Mailbox 2 abort callback ID */ + HAL_CAN_RX_FIFO0_MSG_PENDING_CB_ID = 0x06U, /*!< CAN Rx FIFO 0 message pending callback ID */ + HAL_CAN_RX_FIFO0_FULL_CB_ID = 0x07U, /*!< CAN Rx FIFO 0 full callback ID */ + HAL_CAN_RX_FIFO1_MSG_PENDING_CB_ID = 0x08U, /*!< CAN Rx FIFO 1 message pending callback ID */ + HAL_CAN_RX_FIFO1_FULL_CB_ID = 0x09U, /*!< CAN Rx FIFO 1 full callback ID */ + HAL_CAN_SLEEP_CB_ID = 0x0AU, /*!< CAN Sleep callback ID */ + HAL_CAN_WAKEUP_FROM_RX_MSG_CB_ID = 0x0BU, /*!< CAN Wake Up from Rx msg callback ID */ + HAL_CAN_ERROR_CB_ID = 0x0CU, /*!< CAN Error callback ID */ + + HAL_CAN_MSPINIT_CB_ID = 0x0DU, /*!< CAN MspInit callback ID */ + HAL_CAN_MSPDEINIT_CB_ID = 0x0EU, /*!< CAN MspDeInit callback ID */ + +} HAL_CAN_CallbackIDTypeDef; + +/** + * @brief HAL CAN Callback pointer definition + */ +typedef void (*pCAN_CallbackTypeDef)(CAN_HandleTypeDef *hcan); /*!< pointer to a CAN callback function */ + +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup CAN_Exported_Constants CAN Exported Constants + * @{ + */ + +/** @defgroup CAN_Error_Code CAN Error Code + * @{ + */ +#define HAL_CAN_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_CAN_ERROR_EWG (0x00000001U) /*!< Protocol Error Warning */ +#define HAL_CAN_ERROR_EPV (0x00000002U) /*!< Error Passive */ +#define HAL_CAN_ERROR_BOF (0x00000004U) /*!< Bus-off error */ +#define HAL_CAN_ERROR_STF (0x00000008U) /*!< Stuff error */ +#define HAL_CAN_ERROR_FOR (0x00000010U) /*!< Form error */ +#define HAL_CAN_ERROR_ACK (0x00000020U) /*!< Acknowledgment error */ +#define HAL_CAN_ERROR_BR (0x00000040U) /*!< Bit recessive error */ +#define HAL_CAN_ERROR_BD (0x00000080U) /*!< Bit dominant error */ +#define HAL_CAN_ERROR_CRC (0x00000100U) /*!< CRC error */ +#define HAL_CAN_ERROR_RX_FOV0 (0x00000200U) /*!< Rx FIFO0 overrun error */ +#define HAL_CAN_ERROR_RX_FOV1 (0x00000400U) /*!< Rx FIFO1 overrun error */ +#define HAL_CAN_ERROR_TX_ALST0 (0x00000800U) /*!< TxMailbox 0 transmit failure due to arbitration lost */ +#define HAL_CAN_ERROR_TX_TERR0 (0x00001000U) /*!< TxMailbox 0 transmit failure due to transmit error */ +#define HAL_CAN_ERROR_TX_ALST1 (0x00002000U) /*!< TxMailbox 1 transmit failure due to arbitration lost */ +#define HAL_CAN_ERROR_TX_TERR1 (0x00004000U) /*!< TxMailbox 1 transmit failure due to transmit error */ +#define HAL_CAN_ERROR_TX_ALST2 (0x00008000U) /*!< TxMailbox 2 transmit failure due to arbitration lost */ +#define HAL_CAN_ERROR_TX_TERR2 (0x00010000U) /*!< TxMailbox 2 transmit failure due to transmit error */ +#define HAL_CAN_ERROR_TIMEOUT (0x00020000U) /*!< Timeout error */ +#define HAL_CAN_ERROR_NOT_INITIALIZED (0x00040000U) /*!< Peripheral not initialized */ +#define HAL_CAN_ERROR_NOT_READY (0x00080000U) /*!< Peripheral not ready */ +#define HAL_CAN_ERROR_NOT_STARTED (0x00100000U) /*!< Peripheral not started */ +#define HAL_CAN_ERROR_PARAM (0x00200000U) /*!< Parameter error */ + +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 +#define HAL_CAN_ERROR_INVALID_CALLBACK (0x00400000U) /*!< Invalid Callback error */ +#endif /* USE_HAL_CAN_REGISTER_CALLBACKS */ +#define HAL_CAN_ERROR_INTERNAL (0x00800000U) /*!< Internal error */ + +/** + * @} + */ + +/** @defgroup CAN_InitStatus CAN InitStatus + * @{ + */ +#define CAN_INITSTATUS_FAILED (0x00000000U) /*!< CAN initialization failed */ +#define CAN_INITSTATUS_SUCCESS (0x00000001U) /*!< CAN initialization OK */ +/** + * @} + */ + +/** @defgroup CAN_operating_mode CAN Operating Mode + * @{ + */ +#define CAN_MODE_NORMAL (0x00000000U) /*!< Normal mode */ +#define CAN_MODE_LOOPBACK ((uint32_t)CAN_BTR_LBKM) /*!< Loopback mode */ +#define CAN_MODE_SILENT ((uint32_t)CAN_BTR_SILM) /*!< Silent mode */ +#define CAN_MODE_SILENT_LOOPBACK ((uint32_t)(CAN_BTR_LBKM | CAN_BTR_SILM)) /*!< Loopback combined with silent mode */ +/** + * @} + */ + + +/** @defgroup CAN_synchronisation_jump_width CAN Synchronization Jump Width + * @{ + */ +#define CAN_SJW_1TQ (0x00000000U) /*!< 1 time quantum */ +#define CAN_SJW_2TQ ((uint32_t)CAN_BTR_SJW_0) /*!< 2 time quantum */ +#define CAN_SJW_3TQ ((uint32_t)CAN_BTR_SJW_1) /*!< 3 time quantum */ +#define CAN_SJW_4TQ ((uint32_t)CAN_BTR_SJW) /*!< 4 time quantum */ +/** + * @} + */ + +/** @defgroup CAN_time_quantum_in_bit_segment_1 CAN Time Quantum in Bit Segment 1 + * @{ + */ +#define CAN_BS1_1TQ (0x00000000U) /*!< 1 time quantum */ +#define CAN_BS1_2TQ ((uint32_t)CAN_BTR_TS1_0) /*!< 2 time quantum */ +#define CAN_BS1_3TQ ((uint32_t)CAN_BTR_TS1_1) /*!< 3 time quantum */ +#define CAN_BS1_4TQ ((uint32_t)(CAN_BTR_TS1_1 | CAN_BTR_TS1_0)) /*!< 4 time quantum */ +#define CAN_BS1_5TQ ((uint32_t)CAN_BTR_TS1_2) /*!< 5 time quantum */ +#define CAN_BS1_6TQ ((uint32_t)(CAN_BTR_TS1_2 | CAN_BTR_TS1_0)) /*!< 6 time quantum */ +#define CAN_BS1_7TQ ((uint32_t)(CAN_BTR_TS1_2 | CAN_BTR_TS1_1)) /*!< 7 time quantum */ +#define CAN_BS1_8TQ ((uint32_t)(CAN_BTR_TS1_2 | CAN_BTR_TS1_1 | CAN_BTR_TS1_0)) /*!< 8 time quantum */ +#define CAN_BS1_9TQ ((uint32_t)CAN_BTR_TS1_3) /*!< 9 time quantum */ +#define CAN_BS1_10TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_0)) /*!< 10 time quantum */ +#define CAN_BS1_11TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_1)) /*!< 11 time quantum */ +#define CAN_BS1_12TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_1 | CAN_BTR_TS1_0)) /*!< 12 time quantum */ +#define CAN_BS1_13TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_2)) /*!< 13 time quantum */ +#define CAN_BS1_14TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_2 | CAN_BTR_TS1_0)) /*!< 14 time quantum */ +#define CAN_BS1_15TQ ((uint32_t)(CAN_BTR_TS1_3 | CAN_BTR_TS1_2 | CAN_BTR_TS1_1)) /*!< 15 time quantum */ +#define CAN_BS1_16TQ ((uint32_t)CAN_BTR_TS1) /*!< 16 time quantum */ +/** + * @} + */ + +/** @defgroup CAN_time_quantum_in_bit_segment_2 CAN Time Quantum in Bit Segment 2 + * @{ + */ +#define CAN_BS2_1TQ (0x00000000U) /*!< 1 time quantum */ +#define CAN_BS2_2TQ ((uint32_t)CAN_BTR_TS2_0) /*!< 2 time quantum */ +#define CAN_BS2_3TQ ((uint32_t)CAN_BTR_TS2_1) /*!< 3 time quantum */ +#define CAN_BS2_4TQ ((uint32_t)(CAN_BTR_TS2_1 | CAN_BTR_TS2_0)) /*!< 4 time quantum */ +#define CAN_BS2_5TQ ((uint32_t)CAN_BTR_TS2_2) /*!< 5 time quantum */ +#define CAN_BS2_6TQ ((uint32_t)(CAN_BTR_TS2_2 | CAN_BTR_TS2_0)) /*!< 6 time quantum */ +#define CAN_BS2_7TQ ((uint32_t)(CAN_BTR_TS2_2 | CAN_BTR_TS2_1)) /*!< 7 time quantum */ +#define CAN_BS2_8TQ ((uint32_t)CAN_BTR_TS2) /*!< 8 time quantum */ +/** + * @} + */ + +/** @defgroup CAN_filter_mode CAN Filter Mode + * @{ + */ +#define CAN_FILTERMODE_IDMASK (0x00000000U) /*!< Identifier mask mode */ +#define CAN_FILTERMODE_IDLIST (0x00000001U) /*!< Identifier list mode */ +/** + * @} + */ + +/** @defgroup CAN_filter_scale CAN Filter Scale + * @{ + */ +#define CAN_FILTERSCALE_16BIT (0x00000000U) /*!< Two 16-bit filters */ +#define CAN_FILTERSCALE_32BIT (0x00000001U) /*!< One 32-bit filter */ +/** + * @} + */ + +/** @defgroup CAN_filter_activation CAN Filter Activation + * @{ + */ +#define CAN_FILTER_DISABLE (0x00000000U) /*!< Disable filter */ +#define CAN_FILTER_ENABLE (0x00000001U) /*!< Enable filter */ +/** + * @} + */ + +/** @defgroup CAN_filter_FIFO CAN Filter FIFO + * @{ + */ +#define CAN_FILTER_FIFO0 (0x00000000U) /*!< Filter FIFO 0 assignment for filter x */ +#define CAN_FILTER_FIFO1 (0x00000001U) /*!< Filter FIFO 1 assignment for filter x */ +/** + * @} + */ + +/** @defgroup CAN_identifier_type CAN Identifier Type + * @{ + */ +#define CAN_ID_STD (0x00000000U) /*!< Standard Id */ +#define CAN_ID_EXT (0x00000004U) /*!< Extended Id */ +/** + * @} + */ + +/** @defgroup CAN_remote_transmission_request CAN Remote Transmission Request + * @{ + */ +#define CAN_RTR_DATA (0x00000000U) /*!< Data frame */ +#define CAN_RTR_REMOTE (0x00000002U) /*!< Remote frame */ +/** + * @} + */ + +/** @defgroup CAN_receive_FIFO_number CAN Receive FIFO Number + * @{ + */ +#define CAN_RX_FIFO0 (0x00000000U) /*!< CAN receive FIFO 0 */ +#define CAN_RX_FIFO1 (0x00000001U) /*!< CAN receive FIFO 1 */ +/** + * @} + */ + +/** @defgroup CAN_Tx_Mailboxes CAN Tx Mailboxes + * @{ + */ +#define CAN_TX_MAILBOX0 (0x00000001U) /*!< Tx Mailbox 0 */ +#define CAN_TX_MAILBOX1 (0x00000002U) /*!< Tx Mailbox 1 */ +#define CAN_TX_MAILBOX2 (0x00000004U) /*!< Tx Mailbox 2 */ +/** + * @} + */ + +/** @defgroup CAN_flags CAN Flags + * @{ + */ +/* Transmit Flags */ +#define CAN_FLAG_RQCP0 (0x00000500U) /*!< Request complete MailBox 0 flag */ +#define CAN_FLAG_TXOK0 (0x00000501U) /*!< Transmission OK MailBox 0 flag */ +#define CAN_FLAG_ALST0 (0x00000502U) /*!< Arbitration Lost MailBox 0 flag */ +#define CAN_FLAG_TERR0 (0x00000503U) /*!< Transmission error MailBox 0 flag */ +#define CAN_FLAG_RQCP1 (0x00000508U) /*!< Request complete MailBox1 flag */ +#define CAN_FLAG_TXOK1 (0x00000509U) /*!< Transmission OK MailBox 1 flag */ +#define CAN_FLAG_ALST1 (0x0000050AU) /*!< Arbitration Lost MailBox 1 flag */ +#define CAN_FLAG_TERR1 (0x0000050BU) /*!< Transmission error MailBox 1 flag */ +#define CAN_FLAG_RQCP2 (0x00000510U) /*!< Request complete MailBox2 flag */ +#define CAN_FLAG_TXOK2 (0x00000511U) /*!< Transmission OK MailBox 2 flag */ +#define CAN_FLAG_ALST2 (0x00000512U) /*!< Arbitration Lost MailBox 2 flag */ +#define CAN_FLAG_TERR2 (0x00000513U) /*!< Transmission error MailBox 2 flag */ +#define CAN_FLAG_TME0 (0x0000051AU) /*!< Transmit mailbox 0 empty flag */ +#define CAN_FLAG_TME1 (0x0000051BU) /*!< Transmit mailbox 1 empty flag */ +#define CAN_FLAG_TME2 (0x0000051CU) /*!< Transmit mailbox 2 empty flag */ +#define CAN_FLAG_LOW0 (0x0000051DU) /*!< Lowest priority mailbox 0 flag */ +#define CAN_FLAG_LOW1 (0x0000051EU) /*!< Lowest priority mailbox 1 flag */ +#define CAN_FLAG_LOW2 (0x0000051FU) /*!< Lowest priority mailbox 2 flag */ + +/* Receive Flags */ +#define CAN_FLAG_FF0 (0x00000203U) /*!< RX FIFO 0 Full flag */ +#define CAN_FLAG_FOV0 (0x00000204U) /*!< RX FIFO 0 Overrun flag */ +#define CAN_FLAG_FF1 (0x00000403U) /*!< RX FIFO 1 Full flag */ +#define CAN_FLAG_FOV1 (0x00000404U) /*!< RX FIFO 1 Overrun flag */ + +/* Operating Mode Flags */ +#define CAN_FLAG_INAK (0x00000100U) /*!< Initialization acknowledge flag */ +#define CAN_FLAG_SLAK (0x00000101U) /*!< Sleep acknowledge flag */ +#define CAN_FLAG_ERRI (0x00000102U) /*!< Error flag */ +#define CAN_FLAG_WKU (0x00000103U) /*!< Wake up interrupt flag */ +#define CAN_FLAG_SLAKI (0x00000104U) /*!< Sleep acknowledge interrupt flag */ + +/* Error Flags */ +#define CAN_FLAG_EWG (0x00000300U) /*!< Error warning flag */ +#define CAN_FLAG_EPV (0x00000301U) /*!< Error passive flag */ +#define CAN_FLAG_BOF (0x00000302U) /*!< Bus-Off flag */ +/** + * @} + */ + + +/** @defgroup CAN_Interrupts CAN Interrupts + * @{ + */ +/* Transmit Interrupt */ +#define CAN_IT_TX_MAILBOX_EMPTY ((uint32_t)CAN_IER_TMEIE) /*!< Transmit mailbox empty interrupt */ + +/* Receive Interrupts */ +#define CAN_IT_RX_FIFO0_MSG_PENDING ((uint32_t)CAN_IER_FMPIE0) /*!< FIFO 0 message pending interrupt */ +#define CAN_IT_RX_FIFO0_FULL ((uint32_t)CAN_IER_FFIE0) /*!< FIFO 0 full interrupt */ +#define CAN_IT_RX_FIFO0_OVERRUN ((uint32_t)CAN_IER_FOVIE0) /*!< FIFO 0 overrun interrupt */ +#define CAN_IT_RX_FIFO1_MSG_PENDING ((uint32_t)CAN_IER_FMPIE1) /*!< FIFO 1 message pending interrupt */ +#define CAN_IT_RX_FIFO1_FULL ((uint32_t)CAN_IER_FFIE1) /*!< FIFO 1 full interrupt */ +#define CAN_IT_RX_FIFO1_OVERRUN ((uint32_t)CAN_IER_FOVIE1) /*!< FIFO 1 overrun interrupt */ + +/* Operating Mode Interrupts */ +#define CAN_IT_WAKEUP ((uint32_t)CAN_IER_WKUIE) /*!< Wake-up interrupt */ +#define CAN_IT_SLEEP_ACK ((uint32_t)CAN_IER_SLKIE) /*!< Sleep acknowledge interrupt */ + +/* Error Interrupts */ +#define CAN_IT_ERROR_WARNING ((uint32_t)CAN_IER_EWGIE) /*!< Error warning interrupt */ +#define CAN_IT_ERROR_PASSIVE ((uint32_t)CAN_IER_EPVIE) /*!< Error passive interrupt */ +#define CAN_IT_BUSOFF ((uint32_t)CAN_IER_BOFIE) /*!< Bus-off interrupt */ +#define CAN_IT_LAST_ERROR_CODE ((uint32_t)CAN_IER_LECIE) /*!< Last error code interrupt */ +#define CAN_IT_ERROR ((uint32_t)CAN_IER_ERRIE) /*!< Error Interrupt */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup CAN_Exported_Macros CAN Exported Macros + * @{ + */ + +/** @brief Reset CAN handle state + * @param __HANDLE__ CAN handle. + * @retval None + */ +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 +#define __HAL_CAN_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_CAN_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_CAN_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_CAN_STATE_RESET) +#endif /*USE_HAL_CAN_REGISTER_CALLBACKS */ + +/** + * @brief Enable the specified CAN interrupts. + * @param __HANDLE__ CAN handle. + * @param __INTERRUPT__ CAN Interrupt sources to enable. + * This parameter can be any combination of @arg CAN_Interrupts + * @retval None + */ +#define __HAL_CAN_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->IER) |= (__INTERRUPT__)) + +/** + * @brief Disable the specified CAN interrupts. + * @param __HANDLE__ CAN handle. + * @param __INTERRUPT__ CAN Interrupt sources to disable. + * This parameter can be any combination of @arg CAN_Interrupts + * @retval None + */ +#define __HAL_CAN_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->IER) &= ~(__INTERRUPT__)) + +/** @brief Check if the specified CAN interrupt source is enabled or disabled. + * @param __HANDLE__ specifies the CAN Handle. + * @param __INTERRUPT__ specifies the CAN interrupt source to check. + * This parameter can be a value of @arg CAN_Interrupts + * @retval The state of __IT__ (TRUE or FALSE). + */ +#define __HAL_CAN_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->IER) & (__INTERRUPT__)) + +/** @brief Check whether the specified CAN flag is set or not. + * @param __HANDLE__ specifies the CAN Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of @arg CAN_flags + * @retval The state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_CAN_GET_FLAG(__HANDLE__, __FLAG__) \ + ((((__FLAG__) >> 8U) == 5U)? ((((__HANDLE__)->Instance->TSR) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 2U)? ((((__HANDLE__)->Instance->RF0R) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 4U)? ((((__HANDLE__)->Instance->RF1R) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 1U)? ((((__HANDLE__)->Instance->MSR) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 3U)? ((((__HANDLE__)->Instance->ESR) & (1U << ((__FLAG__) & CAN_FLAG_MASK))) == (1U << ((__FLAG__) & CAN_FLAG_MASK))): 0U) + +/** @brief Clear the specified CAN pending flag. + * @param __HANDLE__ specifies the CAN Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg CAN_FLAG_RQCP0: Request complete MailBox 0 Flag + * @arg CAN_FLAG_TXOK0: Transmission OK MailBox 0 Flag + * @arg CAN_FLAG_ALST0: Arbitration Lost MailBox 0 Flag + * @arg CAN_FLAG_TERR0: Transmission error MailBox 0 Flag + * @arg CAN_FLAG_RQCP1: Request complete MailBox 1 Flag + * @arg CAN_FLAG_TXOK1: Transmission OK MailBox 1 Flag + * @arg CAN_FLAG_ALST1: Arbitration Lost MailBox 1 Flag + * @arg CAN_FLAG_TERR1: Transmission error MailBox 1 Flag + * @arg CAN_FLAG_RQCP2: Request complete MailBox 2 Flag + * @arg CAN_FLAG_TXOK2: Transmission OK MailBox 2 Flag + * @arg CAN_FLAG_ALST2: Arbitration Lost MailBox 2 Flag + * @arg CAN_FLAG_TERR2: Transmission error MailBox 2 Flag + * @arg CAN_FLAG_FF0: RX FIFO 0 Full Flag + * @arg CAN_FLAG_FOV0: RX FIFO 0 Overrun Flag + * @arg CAN_FLAG_FF1: RX FIFO 1 Full Flag + * @arg CAN_FLAG_FOV1: RX FIFO 1 Overrun Flag + * @arg CAN_FLAG_WKUI: Wake up Interrupt Flag + * @arg CAN_FLAG_SLAKI: Sleep acknowledge Interrupt Flag + * @retval None + */ +#define __HAL_CAN_CLEAR_FLAG(__HANDLE__, __FLAG__) \ + ((((__FLAG__) >> 8U) == 5U)? (((__HANDLE__)->Instance->TSR) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 2U)? (((__HANDLE__)->Instance->RF0R) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 4U)? (((__HANDLE__)->Instance->RF1R) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): \ + (((__FLAG__) >> 8U) == 1U)? (((__HANDLE__)->Instance->MSR) = (1U << ((__FLAG__) & CAN_FLAG_MASK))): 0U) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup CAN_Exported_Functions CAN Exported Functions + * @{ + */ + +/** @addtogroup CAN_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * @{ + */ + +/* Initialization and de-initialization functions *****************************/ +HAL_StatusTypeDef HAL_CAN_Init(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_DeInit(CAN_HandleTypeDef *hcan); +void HAL_CAN_MspInit(CAN_HandleTypeDef *hcan); +void HAL_CAN_MspDeInit(CAN_HandleTypeDef *hcan); + +#if USE_HAL_CAN_REGISTER_CALLBACKS == 1 +/* Callbacks Register/UnRegister functions ***********************************/ +HAL_StatusTypeDef HAL_CAN_RegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID, void (* pCallback)(CAN_HandleTypeDef *_hcan)); +HAL_StatusTypeDef HAL_CAN_UnRegisterCallback(CAN_HandleTypeDef *hcan, HAL_CAN_CallbackIDTypeDef CallbackID); + +#endif /* (USE_HAL_CAN_REGISTER_CALLBACKS) */ +/** + * @} + */ + +/** @addtogroup CAN_Exported_Functions_Group2 Configuration functions + * @brief Configuration functions + * @{ + */ + +/* Configuration functions ****************************************************/ +HAL_StatusTypeDef HAL_CAN_ConfigFilter(CAN_HandleTypeDef *hcan, CAN_FilterTypeDef *sFilterConfig); + +/** + * @} + */ + +/** @addtogroup CAN_Exported_Functions_Group3 Control functions + * @brief Control functions + * @{ + */ + +/* Control functions **********************************************************/ +HAL_StatusTypeDef HAL_CAN_Start(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_Stop(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_RequestSleep(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_WakeUp(CAN_HandleTypeDef *hcan); +uint32_t HAL_CAN_IsSleepActive(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_AddTxMessage(CAN_HandleTypeDef *hcan, CAN_TxHeaderTypeDef *pHeader, uint8_t aData[], uint32_t *pTxMailbox); +HAL_StatusTypeDef HAL_CAN_AbortTxRequest(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes); +uint32_t HAL_CAN_GetTxMailboxesFreeLevel(CAN_HandleTypeDef *hcan); +uint32_t HAL_CAN_IsTxMessagePending(CAN_HandleTypeDef *hcan, uint32_t TxMailboxes); +uint32_t HAL_CAN_GetTxTimestamp(CAN_HandleTypeDef *hcan, uint32_t TxMailbox); +HAL_StatusTypeDef HAL_CAN_GetRxMessage(CAN_HandleTypeDef *hcan, uint32_t RxFifo, CAN_RxHeaderTypeDef *pHeader, uint8_t aData[]); +uint32_t HAL_CAN_GetRxFifoFillLevel(CAN_HandleTypeDef *hcan, uint32_t RxFifo); + +/** + * @} + */ + +/** @addtogroup CAN_Exported_Functions_Group4 Interrupts management + * @brief Interrupts management + * @{ + */ +/* Interrupts management ******************************************************/ +HAL_StatusTypeDef HAL_CAN_ActivateNotification(CAN_HandleTypeDef *hcan, uint32_t ActiveITs); +HAL_StatusTypeDef HAL_CAN_DeactivateNotification(CAN_HandleTypeDef *hcan, uint32_t InactiveITs); +void HAL_CAN_IRQHandler(CAN_HandleTypeDef *hcan); + +/** + * @} + */ + +/** @addtogroup CAN_Exported_Functions_Group5 Callback functions + * @brief Callback functions + * @{ + */ +/* Callbacks functions ********************************************************/ + +void HAL_CAN_TxMailbox0CompleteCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_TxMailbox1CompleteCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_TxMailbox2CompleteCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_TxMailbox0AbortCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_TxMailbox1AbortCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_TxMailbox2AbortCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_RxFifo0MsgPendingCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_RxFifo0FullCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_RxFifo1MsgPendingCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_RxFifo1FullCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_SleepCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_WakeUpFromRxMsgCallback(CAN_HandleTypeDef *hcan); +void HAL_CAN_ErrorCallback(CAN_HandleTypeDef *hcan); + +/** + * @} + */ + +/** @addtogroup CAN_Exported_Functions_Group6 Peripheral State and Error functions + * @brief CAN Peripheral State functions + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +HAL_CAN_StateTypeDef HAL_CAN_GetState(CAN_HandleTypeDef *hcan); +uint32_t HAL_CAN_GetError(CAN_HandleTypeDef *hcan); +HAL_StatusTypeDef HAL_CAN_ResetError(CAN_HandleTypeDef *hcan); + +/** + * @} + */ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/** @defgroup CAN_Private_Types CAN Private Types + * @{ + */ + +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/** @defgroup CAN_Private_Variables CAN Private Variables + * @{ + */ + +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup CAN_Private_Constants CAN Private Constants + * @{ + */ +#define CAN_FLAG_MASK (0x000000FFU) +/** + * @} + */ + +/* Private Macros -----------------------------------------------------------*/ +/** @defgroup CAN_Private_Macros CAN Private Macros + * @{ + */ + +#define IS_CAN_MODE(MODE) (((MODE) == CAN_MODE_NORMAL) || \ + ((MODE) == CAN_MODE_LOOPBACK)|| \ + ((MODE) == CAN_MODE_SILENT) || \ + ((MODE) == CAN_MODE_SILENT_LOOPBACK)) +#define IS_CAN_SJW(SJW) (((SJW) == CAN_SJW_1TQ) || ((SJW) == CAN_SJW_2TQ) || \ + ((SJW) == CAN_SJW_3TQ) || ((SJW) == CAN_SJW_4TQ)) +#define IS_CAN_BS1(BS1) (((BS1) == CAN_BS1_1TQ) || ((BS1) == CAN_BS1_2TQ) || \ + ((BS1) == CAN_BS1_3TQ) || ((BS1) == CAN_BS1_4TQ) || \ + ((BS1) == CAN_BS1_5TQ) || ((BS1) == CAN_BS1_6TQ) || \ + ((BS1) == CAN_BS1_7TQ) || ((BS1) == CAN_BS1_8TQ) || \ + ((BS1) == CAN_BS1_9TQ) || ((BS1) == CAN_BS1_10TQ)|| \ + ((BS1) == CAN_BS1_11TQ)|| ((BS1) == CAN_BS1_12TQ)|| \ + ((BS1) == CAN_BS1_13TQ)|| ((BS1) == CAN_BS1_14TQ)|| \ + ((BS1) == CAN_BS1_15TQ)|| ((BS1) == CAN_BS1_16TQ)) +#define IS_CAN_BS2(BS2) (((BS2) == CAN_BS2_1TQ) || ((BS2) == CAN_BS2_2TQ) || \ + ((BS2) == CAN_BS2_3TQ) || ((BS2) == CAN_BS2_4TQ) || \ + ((BS2) == CAN_BS2_5TQ) || ((BS2) == CAN_BS2_6TQ) || \ + ((BS2) == CAN_BS2_7TQ) || ((BS2) == CAN_BS2_8TQ)) +#define IS_CAN_PRESCALER(PRESCALER) (((PRESCALER) >= 1U) && ((PRESCALER) <= 1024U)) +#define IS_CAN_FILTER_ID_HALFWORD(HALFWORD) ((HALFWORD) <= 0xFFFFU) +#define IS_CAN_FILTER_BANK_SINGLE(BANK) ((BANK) <= 13U) +#define IS_CAN_FILTER_MODE(MODE) (((MODE) == CAN_FILTERMODE_IDMASK) || \ + ((MODE) == CAN_FILTERMODE_IDLIST)) +#define IS_CAN_FILTER_SCALE(SCALE) (((SCALE) == CAN_FILTERSCALE_16BIT) || \ + ((SCALE) == CAN_FILTERSCALE_32BIT)) +#define IS_CAN_FILTER_ACTIVATION(ACTIVATION) (((ACTIVATION) == CAN_FILTER_DISABLE) || \ + ((ACTIVATION) == CAN_FILTER_ENABLE)) +#define IS_CAN_FILTER_FIFO(FIFO) (((FIFO) == CAN_FILTER_FIFO0) || \ + ((FIFO) == CAN_FILTER_FIFO1)) +#define IS_CAN_TX_MAILBOX(TRANSMITMAILBOX) (((TRANSMITMAILBOX) == CAN_TX_MAILBOX0 ) || \ + ((TRANSMITMAILBOX) == CAN_TX_MAILBOX1 ) || \ + ((TRANSMITMAILBOX) == CAN_TX_MAILBOX2 )) +#define IS_CAN_TX_MAILBOX_LIST(TRANSMITMAILBOX) ((TRANSMITMAILBOX) <= (CAN_TX_MAILBOX0 | CAN_TX_MAILBOX1 | CAN_TX_MAILBOX2)) +#define IS_CAN_STDID(STDID) ((STDID) <= 0x7FFU) +#define IS_CAN_EXTID(EXTID) ((EXTID) <= 0x1FFFFFFFU) +#define IS_CAN_DLC(DLC) ((DLC) <= 8U) +#define IS_CAN_IDTYPE(IDTYPE) (((IDTYPE) == CAN_ID_STD) || \ + ((IDTYPE) == CAN_ID_EXT)) +#define IS_CAN_RTR(RTR) (((RTR) == CAN_RTR_DATA) || ((RTR) == CAN_RTR_REMOTE)) +#define IS_CAN_RX_FIFO(FIFO) (((FIFO) == CAN_RX_FIFO0) || ((FIFO) == CAN_RX_FIFO1)) +#define IS_CAN_IT(IT) ((IT) <= (CAN_IT_TX_MAILBOX_EMPTY | CAN_IT_RX_FIFO0_MSG_PENDING | \ + CAN_IT_RX_FIFO0_FULL | CAN_IT_RX_FIFO0_OVERRUN | \ + CAN_IT_RX_FIFO1_MSG_PENDING | CAN_IT_RX_FIFO1_FULL | \ + CAN_IT_RX_FIFO1_OVERRUN | CAN_IT_WAKEUP | \ + CAN_IT_SLEEP_ACK | CAN_IT_ERROR_WARNING | \ + CAN_IT_ERROR_PASSIVE | CAN_IT_BUSOFF | \ + CAN_IT_LAST_ERROR_CODE | CAN_IT_ERROR)) + +/** + * @} + */ +/* End of private macros -----------------------------------------------------*/ + +/** + * @} + */ + + +#endif /* CAN */ +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_CAN_H */ + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cec.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cec.h new file mode 100644 index 0000000..6d1e2eb --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cec.h @@ -0,0 +1,794 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_cec.h + * @author MCD Application Team + * @brief Header file of CEC HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_CEC_H +#define STM32F0xx_HAL_CEC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +#if defined (CEC) + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup CEC + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup CEC_Exported_Types CEC Exported Types + * @{ + */ + +/** + * @brief CEC Init Structure definition + */ +typedef struct +{ + uint32_t SignalFreeTime; /*!< Set SFT field, specifies the Signal Free Time. + It can be one of @ref CEC_Signal_Free_Time + and belongs to the set {0,...,7} where + 0x0 is the default configuration + else means 0.5 + (SignalFreeTime - 1) nominal data bit periods */ + + uint32_t Tolerance; /*!< Set RXTOL bit, specifies the tolerance accepted on the received waveforms, + it can be a value of @ref CEC_Tolerance : it is either CEC_STANDARD_TOLERANCE + or CEC_EXTENDED_TOLERANCE */ + + uint32_t BRERxStop; /*!< Set BRESTP bit @ref CEC_BRERxStop : specifies whether or not a Bit Rising Error stops the reception. + CEC_NO_RX_STOP_ON_BRE: reception is not stopped. + CEC_RX_STOP_ON_BRE: reception is stopped. */ + + uint32_t BREErrorBitGen; /*!< Set BREGEN bit @ref CEC_BREErrorBitGen : specifies whether or not an Error-Bit is generated on the + CEC line upon Bit Rising Error detection. + CEC_BRE_ERRORBIT_NO_GENERATION: no error-bit generation. + CEC_BRE_ERRORBIT_GENERATION: error-bit generation if BRESTP is set. */ + + uint32_t LBPEErrorBitGen; /*!< Set LBPEGEN bit @ref CEC_LBPEErrorBitGen : specifies whether or not an Error-Bit is generated on the + CEC line upon Long Bit Period Error detection. + CEC_LBPE_ERRORBIT_NO_GENERATION: no error-bit generation. + CEC_LBPE_ERRORBIT_GENERATION: error-bit generation. */ + + uint32_t BroadcastMsgNoErrorBitGen; /*!< Set BRDNOGEN bit @ref CEC_BroadCastMsgErrorBitGen : allows to avoid an Error-Bit generation on the CEC line + upon an error detected on a broadcast message. + + It supersedes BREGEN and LBPEGEN bits for a broadcast message error handling. It can take two values: + + 1) CEC_BROADCASTERROR_ERRORBIT_GENERATION. + a) BRE detection: error-bit generation on the CEC line if BRESTP=CEC_RX_STOP_ON_BRE + and BREGEN=CEC_BRE_ERRORBIT_NO_GENERATION. + b) LBPE detection: error-bit generation on the CEC line + if LBPGEN=CEC_LBPE_ERRORBIT_NO_GENERATION. + + 2) CEC_BROADCASTERROR_NO_ERRORBIT_GENERATION. + no error-bit generation in case neither a) nor b) are satisfied. Additionally, + there is no error-bit generation in case of Short Bit Period Error detection in + a broadcast message while LSTN bit is set. */ + + uint32_t SignalFreeTimeOption; /*!< Set SFTOP bit @ref CEC_SFT_Option : specifies when SFT timer starts. + CEC_SFT_START_ON_TXSOM SFT: timer starts when TXSOM is set by software. + CEC_SFT_START_ON_TX_RX_END: SFT timer starts automatically at the end of message transmission/reception. */ + + uint32_t ListenMode; /*!< Set LSTN bit @ref CEC_Listening_Mode : specifies device listening mode. It can take two values: + + CEC_REDUCED_LISTENING_MODE: CEC peripheral receives only message addressed to its + own address (OAR). Messages addressed to different destination are ignored. + Broadcast messages are always received. + + CEC_FULL_LISTENING_MODE: CEC peripheral receives messages addressed to its own + address (OAR) with positive acknowledge. Messages addressed to different destination + are received, but without interfering with the CEC bus: no acknowledge sent. */ + + uint16_t OwnAddress; /*!< Own addresses configuration + This parameter can be a value of @ref CEC_OWN_ADDRESS */ + + uint8_t *RxBuffer; /*!< CEC Rx buffer pointeur */ + + +} CEC_InitTypeDef; + +/** + * @brief HAL CEC State definition + * @note HAL CEC State value is a combination of 2 different substates: gState and RxState (see @ref CEC_State_Definition). + * - gState contains CEC state information related to global Handle management + * and also information related to Tx operations. + * gState value coding follow below described bitmap : + * b7 (not used) + * x : Should be set to 0 + * b6 Error information + * 0 : No Error + * 1 : Error + * b5 CEC peripheral initialization status + * 0 : Reset (peripheral not initialized) + * 1 : Init done (peripheral initialized. HAL CEC Init function already called) + * b4-b3 (not used) + * xx : Should be set to 00 + * b2 Intrinsic process state + * 0 : Ready + * 1 : Busy (peripheral busy with some configuration or internal operations) + * b1 (not used) + * x : Should be set to 0 + * b0 Tx state + * 0 : Ready (no Tx operation ongoing) + * 1 : Busy (Tx operation ongoing) + * - RxState contains information related to Rx operations. + * RxState value coding follow below described bitmap : + * b7-b6 (not used) + * xx : Should be set to 00 + * b5 CEC peripheral initialization status + * 0 : Reset (peripheral not initialized) + * 1 : Init done (peripheral initialized) + * b4-b2 (not used) + * xxx : Should be set to 000 + * b1 Rx state + * 0 : Ready (no Rx operation ongoing) + * 1 : Busy (Rx operation ongoing) + * b0 (not used) + * x : Should be set to 0. + */ +typedef uint32_t HAL_CEC_StateTypeDef; + +/** + * @brief CEC handle Structure definition + */ +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) +typedef struct __CEC_HandleTypeDef +#else +typedef struct +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ +{ + CEC_TypeDef *Instance; /*!< CEC registers base address */ + + CEC_InitTypeDef Init; /*!< CEC communication parameters */ + + uint8_t *pTxBuffPtr; /*!< Pointer to CEC Tx transfer Buffer */ + + uint16_t TxXferCount; /*!< CEC Tx Transfer Counter */ + + uint16_t RxXferSize; /*!< CEC Rx Transfer size, 0: header received only */ + + HAL_LockTypeDef Lock; /*!< Locking object */ + + HAL_CEC_StateTypeDef gState; /*!< CEC state information related to global Handle management + and also related to Tx operations. + This parameter can be a value of @ref HAL_CEC_StateTypeDef */ + + HAL_CEC_StateTypeDef RxState; /*!< CEC state information related to Rx operations. + This parameter can be a value of @ref HAL_CEC_StateTypeDef */ + + uint32_t ErrorCode; /*!< For errors handling purposes, copy of ISR register + in case error is reported */ + +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) + void (* TxCpltCallback)(struct __CEC_HandleTypeDef + *hcec); /*!< CEC Tx Transfer completed callback */ + void (* RxCpltCallback)(struct __CEC_HandleTypeDef *hcec, + uint32_t RxFrameSize); /*!< CEC Rx Transfer completed callback */ + void (* ErrorCallback)(struct __CEC_HandleTypeDef *hcec); /*!< CEC error callback */ + + void (* MspInitCallback)(struct __CEC_HandleTypeDef *hcec); /*!< CEC Msp Init callback */ + void (* MspDeInitCallback)(struct __CEC_HandleTypeDef *hcec); /*!< CEC Msp DeInit callback */ + +#endif /* (USE_HAL_CEC_REGISTER_CALLBACKS) */ +} CEC_HandleTypeDef; + +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) +/** + * @brief HAL CEC Callback ID enumeration definition + */ +typedef enum +{ + HAL_CEC_TX_CPLT_CB_ID = 0x00U, /*!< CEC Tx Transfer completed callback ID */ + HAL_CEC_RX_CPLT_CB_ID = 0x01U, /*!< CEC Rx Transfer completed callback ID */ + HAL_CEC_ERROR_CB_ID = 0x02U, /*!< CEC error callback ID */ + HAL_CEC_MSPINIT_CB_ID = 0x03U, /*!< CEC Msp Init callback ID */ + HAL_CEC_MSPDEINIT_CB_ID = 0x04U /*!< CEC Msp DeInit callback ID */ +} HAL_CEC_CallbackIDTypeDef; + +/** + * @brief HAL CEC Callback pointer definition + */ +typedef void (*pCEC_CallbackTypeDef)(CEC_HandleTypeDef *hcec); /*!< pointer to an CEC callback function */ +typedef void (*pCEC_RxCallbackTypeDef)(CEC_HandleTypeDef *hcec, + uint32_t RxFrameSize); /*!< pointer to an Rx Transfer completed callback function */ +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup CEC_Exported_Constants CEC Exported Constants + * @{ + */ +/** @defgroup CEC_State_Definition CEC State Code Definition + * @{ + */ +#define HAL_CEC_STATE_RESET ((uint32_t)0x00000000) /*!< Peripheral is not yet Initialized + Value is allowed for gState and RxState */ +#define HAL_CEC_STATE_READY ((uint32_t)0x00000020) /*!< Peripheral Initialized and ready for use + Value is allowed for gState and RxState */ +#define HAL_CEC_STATE_BUSY ((uint32_t)0x00000024) /*!< an internal process is ongoing + Value is allowed for gState only */ +#define HAL_CEC_STATE_BUSY_RX ((uint32_t)0x00000022) /*!< Data Reception process is ongoing + Value is allowed for RxState only */ +#define HAL_CEC_STATE_BUSY_TX ((uint32_t)0x00000021) /*!< Data Transmission process is ongoing + Value is allowed for gState only */ +#define HAL_CEC_STATE_BUSY_RX_TX ((uint32_t)0x00000023) /*!< an internal process is ongoing + Value is allowed for gState only */ +#define HAL_CEC_STATE_ERROR ((uint32_t)0x00000050) /*!< Error Value is allowed for gState only */ +/** + * @} + */ +/** @defgroup CEC_Error_Code CEC Error Code + * @{ + */ +#define HAL_CEC_ERROR_NONE (uint32_t) 0x0000U /*!< no error */ +#define HAL_CEC_ERROR_RXOVR CEC_ISR_RXOVR /*!< CEC Rx-Overrun */ +#define HAL_CEC_ERROR_BRE CEC_ISR_BRE /*!< CEC Rx Bit Rising Error */ +#define HAL_CEC_ERROR_SBPE CEC_ISR_SBPE /*!< CEC Rx Short Bit period Error */ +#define HAL_CEC_ERROR_LBPE CEC_ISR_LBPE /*!< CEC Rx Long Bit period Error */ +#define HAL_CEC_ERROR_RXACKE CEC_ISR_RXACKE /*!< CEC Rx Missing Acknowledge */ +#define HAL_CEC_ERROR_ARBLST CEC_ISR_ARBLST /*!< CEC Arbitration Lost */ +#define HAL_CEC_ERROR_TXUDR CEC_ISR_TXUDR /*!< CEC Tx-Buffer Underrun */ +#define HAL_CEC_ERROR_TXERR CEC_ISR_TXERR /*!< CEC Tx-Error */ +#define HAL_CEC_ERROR_TXACKE CEC_ISR_TXACKE /*!< CEC Tx Missing Acknowledge */ +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) +#define HAL_CEC_ERROR_INVALID_CALLBACK ((uint32_t)0x00002000U) /*!< Invalid Callback Error */ +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup CEC_Signal_Free_Time CEC Signal Free Time setting parameter + * @{ + */ +#define CEC_DEFAULT_SFT ((uint32_t)0x00000000U) +#define CEC_0_5_BITPERIOD_SFT ((uint32_t)0x00000001U) +#define CEC_1_5_BITPERIOD_SFT ((uint32_t)0x00000002U) +#define CEC_2_5_BITPERIOD_SFT ((uint32_t)0x00000003U) +#define CEC_3_5_BITPERIOD_SFT ((uint32_t)0x00000004U) +#define CEC_4_5_BITPERIOD_SFT ((uint32_t)0x00000005U) +#define CEC_5_5_BITPERIOD_SFT ((uint32_t)0x00000006U) +#define CEC_6_5_BITPERIOD_SFT ((uint32_t)0x00000007U) +/** + * @} + */ + +/** @defgroup CEC_Tolerance CEC Receiver Tolerance + * @{ + */ +#define CEC_STANDARD_TOLERANCE ((uint32_t)0x00000000U) +#define CEC_EXTENDED_TOLERANCE ((uint32_t)CEC_CFGR_RXTOL) +/** + * @} + */ + +/** @defgroup CEC_BRERxStop CEC Reception Stop on Error + * @{ + */ +#define CEC_NO_RX_STOP_ON_BRE ((uint32_t)0x00000000U) +#define CEC_RX_STOP_ON_BRE ((uint32_t)CEC_CFGR_BRESTP) +/** + * @} + */ + +/** @defgroup CEC_BREErrorBitGen CEC Error Bit Generation if Bit Rise Error reported + * @{ + */ +#define CEC_BRE_ERRORBIT_NO_GENERATION ((uint32_t)0x00000000U) +#define CEC_BRE_ERRORBIT_GENERATION ((uint32_t)CEC_CFGR_BREGEN) +/** + * @} + */ + +/** @defgroup CEC_LBPEErrorBitGen CEC Error Bit Generation if Long Bit Period Error reported + * @{ + */ +#define CEC_LBPE_ERRORBIT_NO_GENERATION ((uint32_t)0x00000000U) +#define CEC_LBPE_ERRORBIT_GENERATION ((uint32_t)CEC_CFGR_LBPEGEN) +/** + * @} + */ + +/** @defgroup CEC_BroadCastMsgErrorBitGen CEC Error Bit Generation on Broadcast message + * @{ + */ +#define CEC_BROADCASTERROR_ERRORBIT_GENERATION ((uint32_t)0x00000000U) +#define CEC_BROADCASTERROR_NO_ERRORBIT_GENERATION ((uint32_t)CEC_CFGR_BRDNOGEN) +/** + * @} + */ + +/** @defgroup CEC_SFT_Option CEC Signal Free Time start option + * @{ + */ +#define CEC_SFT_START_ON_TXSOM ((uint32_t)0x00000000U) +#define CEC_SFT_START_ON_TX_RX_END ((uint32_t)CEC_CFGR_SFTOPT) +/** + * @} + */ + +/** @defgroup CEC_Listening_Mode CEC Listening mode option + * @{ + */ +#define CEC_REDUCED_LISTENING_MODE ((uint32_t)0x00000000U) +#define CEC_FULL_LISTENING_MODE ((uint32_t)CEC_CFGR_LSTN) +/** + * @} + */ + +/** @defgroup CEC_OAR_Position CEC Device Own Address position in CEC CFGR register + * @{ + */ +#define CEC_CFGR_OAR_LSB_POS ((uint32_t) 16U) +/** + * @} + */ + +/** @defgroup CEC_Initiator_Position CEC Initiator logical address position in message header + * @{ + */ +#define CEC_INITIATOR_LSB_POS ((uint32_t) 4U) +/** + * @} + */ + +/** @defgroup CEC_OWN_ADDRESS CEC Own Address + * @{ + */ +#define CEC_OWN_ADDRESS_NONE ((uint16_t) 0x0000U) /* Reset value */ +#define CEC_OWN_ADDRESS_0 ((uint16_t) 0x0001U) /* Logical Address 0 */ +#define CEC_OWN_ADDRESS_1 ((uint16_t) 0x0002U) /* Logical Address 1 */ +#define CEC_OWN_ADDRESS_2 ((uint16_t) 0x0004U) /* Logical Address 2 */ +#define CEC_OWN_ADDRESS_3 ((uint16_t) 0x0008U) /* Logical Address 3 */ +#define CEC_OWN_ADDRESS_4 ((uint16_t) 0x0010U) /* Logical Address 4 */ +#define CEC_OWN_ADDRESS_5 ((uint16_t) 0x0020U) /* Logical Address 5 */ +#define CEC_OWN_ADDRESS_6 ((uint16_t) 0x0040U) /* Logical Address 6 */ +#define CEC_OWN_ADDRESS_7 ((uint16_t) 0x0080U) /* Logical Address 7 */ +#define CEC_OWN_ADDRESS_8 ((uint16_t) 0x0100U) /* Logical Address 9 */ +#define CEC_OWN_ADDRESS_9 ((uint16_t) 0x0200U) /* Logical Address 10 */ +#define CEC_OWN_ADDRESS_10 ((uint16_t) 0x0400U) /* Logical Address 11 */ +#define CEC_OWN_ADDRESS_11 ((uint16_t) 0x0800U) /* Logical Address 12 */ +#define CEC_OWN_ADDRESS_12 ((uint16_t) 0x1000U) /* Logical Address 13 */ +#define CEC_OWN_ADDRESS_13 ((uint16_t) 0x2000U) /* Logical Address 14 */ +#define CEC_OWN_ADDRESS_14 ((uint16_t) 0x4000U) /* Logical Address 15 */ +/** + * @} + */ + +/** @defgroup CEC_Interrupts_Definitions CEC Interrupts definition + * @{ + */ +#define CEC_IT_TXACKE CEC_IER_TXACKEIE +#define CEC_IT_TXERR CEC_IER_TXERRIE +#define CEC_IT_TXUDR CEC_IER_TXUDRIE +#define CEC_IT_TXEND CEC_IER_TXENDIE +#define CEC_IT_TXBR CEC_IER_TXBRIE +#define CEC_IT_ARBLST CEC_IER_ARBLSTIE +#define CEC_IT_RXACKE CEC_IER_RXACKEIE +#define CEC_IT_LBPE CEC_IER_LBPEIE +#define CEC_IT_SBPE CEC_IER_SBPEIE +#define CEC_IT_BRE CEC_IER_BREIE +#define CEC_IT_RXOVR CEC_IER_RXOVRIE +#define CEC_IT_RXEND CEC_IER_RXENDIE +#define CEC_IT_RXBR CEC_IER_RXBRIE +/** + * @} + */ + +/** @defgroup CEC_Flags_Definitions CEC Flags definition + * @{ + */ +#define CEC_FLAG_TXACKE CEC_ISR_TXACKE +#define CEC_FLAG_TXERR CEC_ISR_TXERR +#define CEC_FLAG_TXUDR CEC_ISR_TXUDR +#define CEC_FLAG_TXEND CEC_ISR_TXEND +#define CEC_FLAG_TXBR CEC_ISR_TXBR +#define CEC_FLAG_ARBLST CEC_ISR_ARBLST +#define CEC_FLAG_RXACKE CEC_ISR_RXACKE +#define CEC_FLAG_LBPE CEC_ISR_LBPE +#define CEC_FLAG_SBPE CEC_ISR_SBPE +#define CEC_FLAG_BRE CEC_ISR_BRE +#define CEC_FLAG_RXOVR CEC_ISR_RXOVR +#define CEC_FLAG_RXEND CEC_ISR_RXEND +#define CEC_FLAG_RXBR CEC_ISR_RXBR +/** + * @} + */ + +/** @defgroup CEC_ALL_ERROR CEC all RX or TX errors flags + * @{ + */ +#define CEC_ISR_ALL_ERROR ((uint32_t)CEC_ISR_RXOVR|CEC_ISR_BRE|CEC_ISR_SBPE|CEC_ISR_LBPE|CEC_ISR_RXACKE|\ + CEC_ISR_ARBLST|CEC_ISR_TXUDR|CEC_ISR_TXERR|CEC_ISR_TXACKE) +/** + * @} + */ + +/** @defgroup CEC_IER_ALL_RX CEC all RX errors interrupts enabling flag + * @{ + */ +#define CEC_IER_RX_ALL_ERR ((uint32_t)CEC_IER_RXACKEIE|CEC_IER_LBPEIE|CEC_IER_SBPEIE|CEC_IER_BREIE|CEC_IER_RXOVRIE) +/** + * @} + */ + +/** @defgroup CEC_IER_ALL_TX CEC all TX errors interrupts enabling flag + * @{ + */ +#define CEC_IER_TX_ALL_ERR ((uint32_t)CEC_IER_TXACKEIE|CEC_IER_TXERRIE|CEC_IER_TXUDRIE|CEC_IER_ARBLSTIE) +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup CEC_Exported_Macros CEC Exported Macros + * @{ + */ + +/** @brief Reset CEC handle gstate & RxState + * @param __HANDLE__ CEC handle. + * @retval None + */ +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) +#define __HAL_CEC_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_CEC_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_CEC_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_CEC_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->gState = HAL_CEC_STATE_RESET; \ + (__HANDLE__)->RxState = HAL_CEC_STATE_RESET; \ + } while(0) +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ +/** @brief Checks whether or not the specified CEC interrupt flag is set. + * @param __HANDLE__ specifies the CEC Handle. + * @param __FLAG__ specifies the flag to check. + * @arg CEC_FLAG_TXACKE: Tx Missing acknowledge Error + * @arg CEC_FLAG_TXERR: Tx Error. + * @arg CEC_FLAG_TXUDR: Tx-Buffer Underrun. + * @arg CEC_FLAG_TXEND: End of transmission (successful transmission of the last byte). + * @arg CEC_FLAG_TXBR: Tx-Byte Request. + * @arg CEC_FLAG_ARBLST: Arbitration Lost + * @arg CEC_FLAG_RXACKE: Rx-Missing Acknowledge + * @arg CEC_FLAG_LBPE: Rx Long period Error + * @arg CEC_FLAG_SBPE: Rx Short period Error + * @arg CEC_FLAG_BRE: Rx Bit Rising Error + * @arg CEC_FLAG_RXOVR: Rx Overrun. + * @arg CEC_FLAG_RXEND: End Of Reception. + * @arg CEC_FLAG_RXBR: Rx-Byte Received. + * @retval ITStatus + */ +#define __HAL_CEC_GET_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR & (__FLAG__)) + +/** @brief Clears the interrupt or status flag when raised (write at 1) + * @param __HANDLE__ specifies the CEC Handle. + * @param __FLAG__ specifies the interrupt/status flag to clear. + * This parameter can be one of the following values: + * @arg CEC_FLAG_TXACKE: Tx Missing acknowledge Error + * @arg CEC_FLAG_TXERR: Tx Error. + * @arg CEC_FLAG_TXUDR: Tx-Buffer Underrun. + * @arg CEC_FLAG_TXEND: End of transmission (successful transmission of the last byte). + * @arg CEC_FLAG_TXBR: Tx-Byte Request. + * @arg CEC_FLAG_ARBLST: Arbitration Lost + * @arg CEC_FLAG_RXACKE: Rx-Missing Acknowledge + * @arg CEC_FLAG_LBPE: Rx Long period Error + * @arg CEC_FLAG_SBPE: Rx Short period Error + * @arg CEC_FLAG_BRE: Rx Bit Rising Error + * @arg CEC_FLAG_RXOVR: Rx Overrun. + * @arg CEC_FLAG_RXEND: End Of Reception. + * @arg CEC_FLAG_RXBR: Rx-Byte Received. + * @retval none + */ +#define __HAL_CEC_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ISR |= (__FLAG__)) + +/** @brief Enables the specified CEC interrupt. + * @param __HANDLE__ specifies the CEC Handle. + * @param __INTERRUPT__ specifies the CEC interrupt to enable. + * This parameter can be one of the following values: + * @arg CEC_IT_TXACKE: Tx Missing acknowledge Error IT Enable + * @arg CEC_IT_TXERR: Tx Error IT Enable + * @arg CEC_IT_TXUDR: Tx-Buffer Underrun IT Enable + * @arg CEC_IT_TXEND: End of transmission IT Enable + * @arg CEC_IT_TXBR: Tx-Byte Request IT Enable + * @arg CEC_IT_ARBLST: Arbitration Lost IT Enable + * @arg CEC_IT_RXACKE: Rx-Missing Acknowledge IT Enable + * @arg CEC_IT_LBPE: Rx Long period Error IT Enable + * @arg CEC_IT_SBPE: Rx Short period Error IT Enable + * @arg CEC_IT_BRE: Rx Bit Rising Error IT Enable + * @arg CEC_IT_RXOVR: Rx Overrun IT Enable + * @arg CEC_IT_RXEND: End Of Reception IT Enable + * @arg CEC_IT_RXBR: Rx-Byte Received IT Enable + * @retval none + */ +#define __HAL_CEC_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER |= (__INTERRUPT__)) + +/** @brief Disables the specified CEC interrupt. + * @param __HANDLE__ specifies the CEC Handle. + * @param __INTERRUPT__ specifies the CEC interrupt to disable. + * This parameter can be one of the following values: + * @arg CEC_IT_TXACKE: Tx Missing acknowledge Error IT Enable + * @arg CEC_IT_TXERR: Tx Error IT Enable + * @arg CEC_IT_TXUDR: Tx-Buffer Underrun IT Enable + * @arg CEC_IT_TXEND: End of transmission IT Enable + * @arg CEC_IT_TXBR: Tx-Byte Request IT Enable + * @arg CEC_IT_ARBLST: Arbitration Lost IT Enable + * @arg CEC_IT_RXACKE: Rx-Missing Acknowledge IT Enable + * @arg CEC_IT_LBPE: Rx Long period Error IT Enable + * @arg CEC_IT_SBPE: Rx Short period Error IT Enable + * @arg CEC_IT_BRE: Rx Bit Rising Error IT Enable + * @arg CEC_IT_RXOVR: Rx Overrun IT Enable + * @arg CEC_IT_RXEND: End Of Reception IT Enable + * @arg CEC_IT_RXBR: Rx-Byte Received IT Enable + * @retval none + */ +#define __HAL_CEC_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER &= (~(__INTERRUPT__))) + +/** @brief Checks whether or not the specified CEC interrupt is enabled. + * @param __HANDLE__ specifies the CEC Handle. + * @param __INTERRUPT__ specifies the CEC interrupt to check. + * This parameter can be one of the following values: + * @arg CEC_IT_TXACKE: Tx Missing acknowledge Error IT Enable + * @arg CEC_IT_TXERR: Tx Error IT Enable + * @arg CEC_IT_TXUDR: Tx-Buffer Underrun IT Enable + * @arg CEC_IT_TXEND: End of transmission IT Enable + * @arg CEC_IT_TXBR: Tx-Byte Request IT Enable + * @arg CEC_IT_ARBLST: Arbitration Lost IT Enable + * @arg CEC_IT_RXACKE: Rx-Missing Acknowledge IT Enable + * @arg CEC_IT_LBPE: Rx Long period Error IT Enable + * @arg CEC_IT_SBPE: Rx Short period Error IT Enable + * @arg CEC_IT_BRE: Rx Bit Rising Error IT Enable + * @arg CEC_IT_RXOVR: Rx Overrun IT Enable + * @arg CEC_IT_RXEND: End Of Reception IT Enable + * @arg CEC_IT_RXBR: Rx-Byte Received IT Enable + * @retval FlagStatus + */ +#define __HAL_CEC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER & (__INTERRUPT__)) + +/** @brief Enables the CEC device + * @param __HANDLE__ specifies the CEC Handle. + * @retval none + */ +#define __HAL_CEC_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= CEC_CR_CECEN) + +/** @brief Disables the CEC device + * @param __HANDLE__ specifies the CEC Handle. + * @retval none + */ +#define __HAL_CEC_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~CEC_CR_CECEN) + +/** @brief Set Transmission Start flag + * @param __HANDLE__ specifies the CEC Handle. + * @retval none + */ +#define __HAL_CEC_FIRST_BYTE_TX_SET(__HANDLE__) ((__HANDLE__)->Instance->CR |= CEC_CR_TXSOM) + +/** @brief Set Transmission End flag + * @param __HANDLE__ specifies the CEC Handle. + * @retval none + * If the CEC message consists of only one byte, TXEOM must be set before of TXSOM. + */ +#define __HAL_CEC_LAST_BYTE_TX_SET(__HANDLE__) ((__HANDLE__)->Instance->CR |= CEC_CR_TXEOM) + +/** @brief Get Transmission Start flag + * @param __HANDLE__ specifies the CEC Handle. + * @retval FlagStatus + */ +#define __HAL_CEC_GET_TRANSMISSION_START_FLAG(__HANDLE__) ((__HANDLE__)->Instance->CR & CEC_CR_TXSOM) + +/** @brief Get Transmission End flag + * @param __HANDLE__ specifies the CEC Handle. + * @retval FlagStatus + */ +#define __HAL_CEC_GET_TRANSMISSION_END_FLAG(__HANDLE__) ((__HANDLE__)->Instance->CR & CEC_CR_TXEOM) + +/** @brief Clear OAR register + * @param __HANDLE__ specifies the CEC Handle. + * @retval none + */ +#define __HAL_CEC_CLEAR_OAR(__HANDLE__) CLEAR_BIT((__HANDLE__)->Instance->CFGR, CEC_CFGR_OAR) + +/** @brief Set OAR register (without resetting previously set address in case of multi-address mode) + * To reset OAR, __HAL_CEC_CLEAR_OAR() needs to be called beforehand + * @param __HANDLE__ specifies the CEC Handle. + * @param __ADDRESS__ Own Address value (CEC logical address is identified by bit position) + * @retval none + */ +#define __HAL_CEC_SET_OAR(__HANDLE__,__ADDRESS__) SET_BIT((__HANDLE__)->Instance->CFGR, (__ADDRESS__)<< CEC_CFGR_OAR_LSB_POS) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup CEC_Exported_Functions + * @{ + */ + +/** @addtogroup CEC_Exported_Functions_Group1 + * @{ + */ +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_CEC_Init(CEC_HandleTypeDef *hcec); +HAL_StatusTypeDef HAL_CEC_DeInit(CEC_HandleTypeDef *hcec); +HAL_StatusTypeDef HAL_CEC_SetDeviceAddress(CEC_HandleTypeDef *hcec, uint16_t CEC_OwnAddress); +void HAL_CEC_MspInit(CEC_HandleTypeDef *hcec); +void HAL_CEC_MspDeInit(CEC_HandleTypeDef *hcec); + +#if (USE_HAL_CEC_REGISTER_CALLBACKS == 1) +HAL_StatusTypeDef HAL_CEC_RegisterCallback(CEC_HandleTypeDef *hcec, HAL_CEC_CallbackIDTypeDef CallbackID, + pCEC_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_CEC_UnRegisterCallback(CEC_HandleTypeDef *hcec, HAL_CEC_CallbackIDTypeDef CallbackID); + +HAL_StatusTypeDef HAL_CEC_RegisterRxCpltCallback(CEC_HandleTypeDef *hcec, pCEC_RxCallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_CEC_UnRegisterRxCpltCallback(CEC_HandleTypeDef *hcec); +#endif /* USE_HAL_CEC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @addtogroup CEC_Exported_Functions_Group2 + * @{ + */ +/* I/O operation functions ***************************************************/ +HAL_StatusTypeDef HAL_CEC_Transmit_IT(CEC_HandleTypeDef *hcec, uint8_t InitiatorAddress, uint8_t DestinationAddress, + uint8_t *pData, uint32_t Size); +uint32_t HAL_CEC_GetLastReceivedFrameSize(CEC_HandleTypeDef *hcec); +void HAL_CEC_ChangeRxBuffer(CEC_HandleTypeDef *hcec, uint8_t *Rxbuffer); +void HAL_CEC_IRQHandler(CEC_HandleTypeDef *hcec); +void HAL_CEC_TxCpltCallback(CEC_HandleTypeDef *hcec); +void HAL_CEC_RxCpltCallback(CEC_HandleTypeDef *hcec, uint32_t RxFrameSize); +void HAL_CEC_ErrorCallback(CEC_HandleTypeDef *hcec); +/** + * @} + */ + +/** @addtogroup CEC_Exported_Functions_Group3 + * @{ + */ +/* Peripheral State functions ************************************************/ +HAL_CEC_StateTypeDef HAL_CEC_GetState(CEC_HandleTypeDef *hcec); +uint32_t HAL_CEC_GetError(CEC_HandleTypeDef *hcec); +/** + * @} + */ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/** @defgroup CEC_Private_Types CEC Private Types + * @{ + */ + +/** + * @} + */ + +/* Private variables ---------------------------------------------------------*/ +/** @defgroup CEC_Private_Variables CEC Private Variables + * @{ + */ + +/** + * @} + */ + +/* Private constants ---------------------------------------------------------*/ +/** @defgroup CEC_Private_Constants CEC Private Constants + * @{ + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup CEC_Private_Macros CEC Private Macros + * @{ + */ + +#define IS_CEC_SIGNALFREETIME(__SFT__) ((__SFT__) <= CEC_CFGR_SFT) + +#define IS_CEC_TOLERANCE(__RXTOL__) (((__RXTOL__) == CEC_STANDARD_TOLERANCE) || \ + ((__RXTOL__) == CEC_EXTENDED_TOLERANCE)) + +#define IS_CEC_BRERXSTOP(__BRERXSTOP__) (((__BRERXSTOP__) == CEC_NO_RX_STOP_ON_BRE) || \ + ((__BRERXSTOP__) == CEC_RX_STOP_ON_BRE)) + +#define IS_CEC_BREERRORBITGEN(__ERRORBITGEN__) (((__ERRORBITGEN__) == CEC_BRE_ERRORBIT_NO_GENERATION) || \ + ((__ERRORBITGEN__) == CEC_BRE_ERRORBIT_GENERATION)) + +#define IS_CEC_LBPEERRORBITGEN(__ERRORBITGEN__) (((__ERRORBITGEN__) == CEC_LBPE_ERRORBIT_NO_GENERATION) || \ + ((__ERRORBITGEN__) == CEC_LBPE_ERRORBIT_GENERATION)) + +#define IS_CEC_BROADCASTERROR_NO_ERRORBIT_GENERATION(__ERRORBITGEN__) (((__ERRORBITGEN__) == CEC_BROADCASTERROR_ERRORBIT_GENERATION) || \ + ((__ERRORBITGEN__) == CEC_BROADCASTERROR_NO_ERRORBIT_GENERATION)) + +#define IS_CEC_SFTOP(__SFTOP__) (((__SFTOP__) == CEC_SFT_START_ON_TXSOM) || \ + ((__SFTOP__) == CEC_SFT_START_ON_TX_RX_END)) + +#define IS_CEC_LISTENING_MODE(__MODE__) (((__MODE__) == CEC_REDUCED_LISTENING_MODE) || \ + ((__MODE__) == CEC_FULL_LISTENING_MODE)) + +/** @brief Check CEC message size. + * The message size is the payload size: without counting the header, + * it varies from 0 byte (ping operation, one header only, no payload) to + * 15 bytes (1 opcode and up to 14 operands following the header). + * @param __SIZE__ CEC message size. + * @retval Test result (TRUE or FALSE). + */ +#define IS_CEC_MSGSIZE(__SIZE__) ((__SIZE__) <= 0x10U) + +/** @brief Check CEC device Own Address Register (OAR) setting. + * OAR address is written in a 15-bit field within CEC_CFGR register. + * @param __ADDRESS__ CEC own address. + * @retval Test result (TRUE or FALSE). + */ +#define IS_CEC_OWN_ADDRESS(__ADDRESS__) ((__ADDRESS__) <= 0x7FFFU) + +/** @brief Check CEC initiator or destination logical address setting. + * Initiator and destination addresses are coded over 4 bits. + * @param __ADDRESS__ CEC initiator or logical address. + * @retval Test result (TRUE or FALSE). + */ +#define IS_CEC_ADDRESS(__ADDRESS__) ((__ADDRESS__) <= 0xFU) +/** + * @} + */ +/* Private functions ---------------------------------------------------------*/ +/** @defgroup CEC_Private_Functions CEC Private Functions + * @{ + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* CEC */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xxHAL_CEC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_comp.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_comp.h new file mode 100644 index 0000000..1c2daac --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_comp.h @@ -0,0 +1,700 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_comp.h + * @author MCD Application Team + * @brief Header file of COMP HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_COMP_H +#define STM32F0xx_HAL_COMP_H + +#ifdef __cplusplus + extern "C" { +#endif + +#if defined (COMP1) || defined (COMP2) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup COMP COMP + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup COMP_Exported_Types COMP Exported Types + * @{ + */ + +/** + * @brief COMP Init structure definition + */ +typedef struct +{ + + uint32_t InvertingInput; /*!< Selects the inverting input of the comparator. + This parameter can be a value of @ref COMP_InvertingInput */ + + uint32_t NonInvertingInput; /*!< Selects the non inverting input of the comparator. + This parameter can be a value of @ref COMP_NonInvertingInput */ + + uint32_t Output; /*!< Selects the output redirection of the comparator. + This parameter can be a value of @ref COMP_Output */ + + uint32_t OutputPol; /*!< Selects the output polarity of the comparator. + This parameter can be a value of @ref COMP_OutputPolarity */ + + uint32_t Hysteresis; /*!< Selects the hysteresis voltage of the comparator. + This parameter can be a value of @ref COMP_Hysteresis */ + + uint32_t Mode; /*!< Selects the operating comsumption mode of the comparator + to adjust the speed/consumption. + This parameter can be a value of @ref COMP_Mode */ + + uint32_t WindowMode; /*!< Selects the window mode of the comparator 1 & 2. + This parameter can be a value of @ref COMP_WindowMode */ + + uint32_t TriggerMode; /*!< Selects the trigger mode of the comparator (interrupt mode). + This parameter can be a value of @ref COMP_TriggerMode */ + +}COMP_InitTypeDef; + +/** + * @brief COMP Handle Structure definition + */ +typedef struct __COMP_HandleTypeDef +{ + COMP_TypeDef *Instance; /*!< Register base address */ + COMP_InitTypeDef Init; /*!< COMP required parameters */ + HAL_LockTypeDef Lock; /*!< Locking object */ + __IO uint32_t State; /*!< COMP communication state + This parameter can be a value of @ref COMP_State */ + __IO uint32_t ErrorCode; /*!< COMP Error code */ +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) + void (* TriggerCallback)(struct __COMP_HandleTypeDef *hcomp); /*!< COMP trigger callback */ + void (* MspInitCallback)(struct __COMP_HandleTypeDef *hcomp); /*!< COMP Msp Init callback */ + void (* MspDeInitCallback)(struct __COMP_HandleTypeDef *hcomp); /*!< COMP Msp DeInit callback */ +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ +}COMP_HandleTypeDef; + +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) +/** + * @brief HAL COMP Callback ID enumeration definition + */ +typedef enum +{ + HAL_COMP_TRIGGER_CB_ID = 0x00U, /*!< COMP trigger callback ID */ + HAL_COMP_MSPINIT_CB_ID = 0x01U, /*!< COMP Msp Init callback ID */ + HAL_COMP_MSPDEINIT_CB_ID = 0x02U /*!< COMP Msp DeInit callback ID */ +} HAL_COMP_CallbackIDTypeDef; + +/** + * @brief HAL COMP Callback pointer definition + */ +typedef void (*pCOMP_CallbackTypeDef)(COMP_HandleTypeDef *hcomp); /*!< pointer to a COMP callback function */ + +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup COMP_Exported_Constants COMP Exported Constants + * @{ + */ + +/** @defgroup COMP_Error_Code COMP Error Code + * @{ + */ +#define HAL_COMP_ERROR_NONE (0x00U) /*!< No error */ +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) +#define HAL_COMP_ERROR_INVALID_CALLBACK (0x01U) /*!< Invalid Callback error */ +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup COMP_State COMP State + * @{ + */ +#define HAL_COMP_STATE_RESET (0x00000000U) /*!< COMP not yet initialized or disabled */ +#define HAL_COMP_STATE_READY (0x00000001U) /*!< COMP initialized and ready for use */ +#define HAL_COMP_STATE_READY_LOCKED (0x00000011U) /*!< COMP initialized but the configuration is locked */ +#define HAL_COMP_STATE_BUSY (0x00000002U) /*!< COMP is running */ +#define HAL_COMP_STATE_BUSY_LOCKED (0x00000012U) /*!< COMP is running and the configuration is locked */ +/** + * @} + */ + +/** @defgroup COMP_OutputPolarity COMP OutputPolarity + * @{ + */ +#define COMP_OUTPUTPOL_NONINVERTED (0x00000000U) /*!< COMP output on GPIO isn't inverted */ +#define COMP_OUTPUTPOL_INVERTED COMP_CSR_COMP1POL /*!< COMP output on GPIO is inverted */ +/** + * @} + */ + +/** @defgroup COMP_Hysteresis COMP Hysteresis + * @{ + */ +#define COMP_HYSTERESIS_NONE (0x00000000U) /*!< No hysteresis */ +#define COMP_HYSTERESIS_LOW COMP_CSR_COMP1HYST_0 /*!< Hysteresis level low */ +#define COMP_HYSTERESIS_MEDIUM COMP_CSR_COMP1HYST_1 /*!< Hysteresis level medium */ +#define COMP_HYSTERESIS_HIGH COMP_CSR_COMP1HYST /*!< Hysteresis level high */ +/** + * @} + */ + +/** @defgroup COMP_Mode COMP Mode + * @{ + */ +/* Please refer to the electrical characteristics in the device datasheet for + the power consumption values */ +#define COMP_MODE_HIGHSPEED (0x00000000U) /*!< High Speed */ +#define COMP_MODE_MEDIUMSPEED COMP_CSR_COMP1MODE_0 /*!< Medium Speed */ +#define COMP_MODE_LOWPOWER COMP_CSR_COMP1MODE_1 /*!< Low power mode */ +#define COMP_MODE_ULTRALOWPOWER COMP_CSR_COMP1MODE /*!< Ultra-low power mode */ +/** + * @} + */ + +/** @defgroup COMP_InvertingInput COMP InvertingInput + * @{ + */ + +#define COMP_INVERTINGINPUT_1_4VREFINT (0x00000000U) /*!< 1/4 VREFINT connected to comparator inverting input */ +#define COMP_INVERTINGINPUT_1_2VREFINT COMP_CSR_COMP1INSEL_0 /*!< 1/2 VREFINT connected to comparator inverting input */ +#define COMP_INVERTINGINPUT_3_4VREFINT COMP_CSR_COMP1INSEL_1 /*!< 3/4 VREFINT connected to comparator inverting input */ +#define COMP_INVERTINGINPUT_VREFINT (COMP_CSR_COMP1INSEL_1|COMP_CSR_COMP1INSEL_0) /*!< VREFINT connected to comparator inverting input */ +#define COMP_INVERTINGINPUT_DAC1 COMP_CSR_COMP1INSEL_2 /*!< DAC_OUT1 (PA4) connected to comparator inverting input */ +#define COMP_INVERTINGINPUT_DAC1SWITCHCLOSED (COMP_CSR_COMP1INSEL_2|COMP_CSR_COMP1SW1) /*!< DAC_OUT1 (PA4) connected to comparator inverting input + and close switch (PA0 for COMP1 only) */ +#define COMP_INVERTINGINPUT_DAC2 (COMP_CSR_COMP1INSEL_2|COMP_CSR_COMP1INSEL_0) /*!< DAC_OUT2 (PA5) connected to comparator inverting input */ +#define COMP_INVERTINGINPUT_IO1 (COMP_CSR_COMP1INSEL_2|COMP_CSR_COMP1INSEL_1) /*!< IO (PA0 for COMP1 and PA2 for COMP2) connected to comparator inverting input */ +/** + * @} + */ + +/** @defgroup COMP_NonInvertingInput COMP NonInvertingInput + * @{ + */ +#define COMP_NONINVERTINGINPUT_IO1 (0x00000000U) /*!< I/O1 (PA1 for COMP1, PA3 for COMP2) + connected to comparator non inverting input */ +#define COMP_NONINVERTINGINPUT_DAC1SWITCHCLOSED COMP_CSR_COMP1SW1 /*!< DAC ouput connected to comparator COMP1 non inverting input */ +/** + * @} + */ + +/** @defgroup COMP_Output COMP Output + * @{ + */ + +/* Output Redirection common for COMP1 and COMP2 */ +#define COMP_OUTPUT_NONE (0x00000000U) /*!< COMP output isn't connected to other peripherals */ +#define COMP_OUTPUT_TIM1BKIN COMP_CSR_COMP1OUTSEL_0 /*!< COMP output connected to TIM1 Break Input (BKIN) */ +#define COMP_OUTPUT_TIM1IC1 COMP_CSR_COMP1OUTSEL_1 /*!< COMP output connected to TIM1 Input Capture 1 */ +#define COMP_OUTPUT_TIM1OCREFCLR (COMP_CSR_COMP1OUTSEL_1|COMP_CSR_COMP1OUTSEL_0) /*!< COMP output connected to TIM1 OCREF Clear */ +#define COMP_OUTPUT_TIM2IC4 COMP_CSR_COMP1OUTSEL_2 /*!< COMP output connected to TIM2 Input Capture 4 */ +#define COMP_OUTPUT_TIM2OCREFCLR (COMP_CSR_COMP1OUTSEL_2|COMP_CSR_COMP1OUTSEL_0) /*!< COMP output connected to TIM2 OCREF Clear */ +#define COMP_OUTPUT_TIM3IC1 (COMP_CSR_COMP1OUTSEL_2|COMP_CSR_COMP1OUTSEL_1) /*!< COMP output connected to TIM3 Input Capture 1 */ +#define COMP_OUTPUT_TIM3OCREFCLR COMP_CSR_COMP1OUTSEL /*!< COMP output connected to TIM3 OCREF Clear */ +/** + * @} + */ + +/** @defgroup COMP_OutputLevel COMP OutputLevel + * @{ + */ +/* When output polarity is not inverted, comparator output is low when + the non-inverting input is at a lower voltage than the inverting input*/ +#define COMP_OUTPUTLEVEL_LOW (0x00000000U) +/* When output polarity is not inverted, comparator output is high when + the non-inverting input is at a higher voltage than the inverting input */ +#define COMP_OUTPUTLEVEL_HIGH COMP_CSR_COMP1OUT +/** + * @} + */ + +/** @defgroup COMP_TriggerMode COMP TriggerMode + * @{ + */ +#define COMP_TRIGGERMODE_NONE (0x00000000U) /*!< No External Interrupt trigger detection */ +#define COMP_TRIGGERMODE_IT_RISING (0x00000001U) /*!< External Interrupt Mode with Rising edge trigger detection */ +#define COMP_TRIGGERMODE_IT_FALLING (0x00000002U) /*!< External Interrupt Mode with Falling edge trigger detection */ +#define COMP_TRIGGERMODE_IT_RISING_FALLING (0x00000003U) /*!< External Interrupt Mode with Rising/Falling edge trigger detection */ +#define COMP_TRIGGERMODE_EVENT_RISING (0x00000010U) /*!< Event Mode with Rising edge trigger detection */ +#define COMP_TRIGGERMODE_EVENT_FALLING (0x00000020U) /*!< Event Mode with Falling edge trigger detection */ +#define COMP_TRIGGERMODE_EVENT_RISING_FALLING (0x00000030U) /*!< Event Mode with Rising/Falling edge trigger detection */ +/** + * @} + */ + +/** @defgroup COMP_WindowMode COMP WindowMode + * @{ + */ +#define COMP_WINDOWMODE_DISABLE (0x00000000U) /*!< Window mode disabled */ +#define COMP_WINDOWMODE_ENABLE COMP_CSR_WNDWEN /*!< Window mode enabled: non inverting input of comparator 2 + is connected to the non inverting input of comparator 1 (PA1) */ +/** + * @} + */ + +/** @defgroup COMP_Flag COMP Flag + * @{ + */ +#define COMP_FLAG_LOCK ((uint32_t)COMP_CSR_COMPxLOCK) /*!< Lock flag */ + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup COMP_Exported_Macros COMP Exported Macros + * @{ + */ + +/** @brief Reset COMP handle state + * @param __HANDLE__ COMP handle. + * @retval None + */ +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) +#define __HAL_COMP_RESET_HANDLE_STATE(__HANDLE__) do{ \ + (__HANDLE__)->State = HAL_COMP_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_COMP_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_COMP_STATE_RESET) +#endif + +/** + * @brief Clear COMP error code (set it to no error code "HAL_COMP_ERROR_NONE"). + * @param __HANDLE__ COMP handle + * @retval None + */ +#define COMP_CLEAR_ERRORCODE(__HANDLE__) ((__HANDLE__)->ErrorCode = HAL_COMP_ERROR_NONE) + +/** + * @brief Enable the specified comparator. + * @param __HANDLE__ COMP handle. + * @retval None + */ +#define __HAL_COMP_ENABLE(__HANDLE__) (((__HANDLE__)->Instance == COMP1) ? \ + SET_BIT(COMP->CSR, COMP_CSR_COMP1EN) : \ + SET_BIT(COMP->CSR, COMP_CSR_COMP2EN)) + +/** + * @brief Disable the specified comparator. + * @param __HANDLE__ COMP handle. + * @retval None + */ +#define __HAL_COMP_DISABLE(__HANDLE__) (((__HANDLE__)->Instance == COMP1) ? \ + CLEAR_BIT(COMP->CSR, COMP_CSR_COMP1EN) : \ + CLEAR_BIT(COMP->CSR, COMP_CSR_COMP2EN)) + +/** + * @brief Lock the specified comparator configuration. + * @param __HANDLE__ COMP handle. + * @retval None + */ +#define __HAL_COMP_LOCK(__HANDLE__) (((__HANDLE__)->Instance == COMP1) ? \ + SET_BIT(COMP->CSR, COMP_CSR_COMP1LOCK) : \ + SET_BIT(COMP->CSR, COMP_CSR_COMP2LOCK)) + +/** + * @brief Enable the COMP1 EXTI line rising edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_ENABLE_RISING_EDGE() SET_BIT(EXTI->RTSR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Disable the COMP1 EXTI line rising edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_DISABLE_RISING_EDGE() CLEAR_BIT(EXTI->RTSR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Enable the COMP1 EXTI line falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_ENABLE_FALLING_EDGE() SET_BIT(EXTI->FTSR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Disable the COMP1 EXTI line falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_DISABLE_FALLING_EDGE() CLEAR_BIT(EXTI->FTSR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Enable the COMP1 EXTI line rising & falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_ENABLE_RISING_FALLING_EDGE() do { \ + __HAL_COMP_COMP1_EXTI_ENABLE_RISING_EDGE(); \ + __HAL_COMP_COMP1_EXTI_ENABLE_FALLING_EDGE(); \ + } while(0) + +/** + * @brief Disable the COMP1 EXTI line rising & falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_DISABLE_RISING_FALLING_EDGE() do { \ + __HAL_COMP_COMP1_EXTI_DISABLE_RISING_EDGE(); \ + __HAL_COMP_COMP1_EXTI_DISABLE_FALLING_EDGE(); \ + } while(0) + +/** + * @brief Enable the COMP1 EXTI line in interrupt mode. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_ENABLE_IT() SET_BIT(EXTI->IMR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Disable the COMP1 EXTI line in interrupt mode. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_DISABLE_IT() CLEAR_BIT(EXTI->IMR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Generate a software interrupt on the COMP1 EXTI line. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_GENERATE_SWIT() SET_BIT(EXTI->SWIER, COMP_EXTI_LINE_COMP1) + +/** + * @brief Enable the COMP1 EXTI Line in event mode. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_ENABLE_EVENT() SET_BIT(EXTI->EMR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Disable the COMP1 EXTI Line in event mode. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_DISABLE_EVENT() CLEAR_BIT(EXTI->EMR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Check whether the COMP1 EXTI line flag is set or not. + * @retval RESET or SET + */ +#define __HAL_COMP_COMP1_EXTI_GET_FLAG() READ_BIT(EXTI->PR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Clear the COMP1 EXTI flag. + * @retval None + */ +#define __HAL_COMP_COMP1_EXTI_CLEAR_FLAG() WRITE_REG(EXTI->PR, COMP_EXTI_LINE_COMP1) + +/** + * @brief Enable the COMP2 EXTI line rising edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_ENABLE_RISING_EDGE() SET_BIT(EXTI->RTSR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Disable the COMP2 EXTI line rising edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_DISABLE_RISING_EDGE() CLEAR_BIT(EXTI->RTSR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Enable the COMP2 EXTI line falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_ENABLE_FALLING_EDGE() SET_BIT(EXTI->FTSR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Disable the COMP2 EXTI line falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_DISABLE_FALLING_EDGE() CLEAR_BIT(EXTI->FTSR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Enable the COMP2 EXTI line rising & falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_ENABLE_RISING_FALLING_EDGE() do { \ + __HAL_COMP_COMP2_EXTI_ENABLE_RISING_EDGE(); \ + __HAL_COMP_COMP2_EXTI_ENABLE_FALLING_EDGE(); \ + } while(0) + +/** + * @brief Disable the COMP2 EXTI line rising & falling edge trigger. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_DISABLE_RISING_FALLING_EDGE() do { \ + __HAL_COMP_COMP2_EXTI_DISABLE_RISING_EDGE(); \ + __HAL_COMP_COMP2_EXTI_DISABLE_FALLING_EDGE(); \ + } while(0) + +/** + * @brief Enable the COMP2 EXTI line in interrupt mode. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_ENABLE_IT() SET_BIT(EXTI->IMR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Disable the COMP2 EXTI line in interrupt mode. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_DISABLE_IT() CLEAR_BIT(EXTI->IMR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Generate a software interrupt on the COMP2 EXTI line. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_GENERATE_SWIT() SET_BIT(EXTI->SWIER, COMP_EXTI_LINE_COMP2) + +/** + * @brief Enable the COMP2 EXTI Line in event mode. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_ENABLE_EVENT() SET_BIT(EXTI->EMR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Disable the COMP2 EXTI Line in event mode. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_DISABLE_EVENT() CLEAR_BIT(EXTI->EMR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Check whether the COMP2 EXTI line flag is set or not. + * @retval RESET or SET + */ +#define __HAL_COMP_COMP2_EXTI_GET_FLAG() READ_BIT(EXTI->PR, COMP_EXTI_LINE_COMP2) + +/** + * @brief Clear the COMP2 EXTI flag. + * @retval None + */ +#define __HAL_COMP_COMP2_EXTI_CLEAR_FLAG() WRITE_REG(EXTI->PR, COMP_EXTI_LINE_COMP2) + +/** @brief Check whether the specified COMP flag is set or not. + * @param __HANDLE__ specifies the COMP Handle. + * @param __FLAG__ specifies the flag to check. + * This parameter can be one of the following values: + * @arg COMP_FLAG_LOCK: lock flag + * @retval The new state of __FLAG__ (TRUE or FALSE). + */ +#define __HAL_COMP_GET_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->CSR & (__FLAG__)) == (__FLAG__)) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup COMP_Exported_Functions COMP Exported Functions + * @{ + */ +/** @addtogroup COMP_Exported_Functions_Group1 Initialization/de-initialization functions + * @brief Initialization and Configuration functions + * @{ + */ +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_COMP_Init(COMP_HandleTypeDef *hcomp); +HAL_StatusTypeDef HAL_COMP_DeInit (COMP_HandleTypeDef *hcomp); +void HAL_COMP_MspInit(COMP_HandleTypeDef *hcomp); +void HAL_COMP_MspDeInit(COMP_HandleTypeDef *hcomp); + +#if (USE_HAL_COMP_REGISTER_CALLBACKS == 1) +/* Callbacks Register/UnRegister functions ***********************************/ +HAL_StatusTypeDef HAL_COMP_RegisterCallback(COMP_HandleTypeDef *hcomp, HAL_COMP_CallbackIDTypeDef CallbackID, pCOMP_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_COMP_UnRegisterCallback(COMP_HandleTypeDef *hcomp, HAL_COMP_CallbackIDTypeDef CallbackID); +#endif /* USE_HAL_COMP_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @addtogroup COMP_Exported_Functions_Group2 I/O operation functions + * @brief Data transfers functions + * @{ + */ +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_COMP_Start(COMP_HandleTypeDef *hcomp); +HAL_StatusTypeDef HAL_COMP_Stop(COMP_HandleTypeDef *hcomp); +HAL_StatusTypeDef HAL_COMP_Start_IT(COMP_HandleTypeDef *hcomp); +HAL_StatusTypeDef HAL_COMP_Stop_IT(COMP_HandleTypeDef *hcomp); +void HAL_COMP_IRQHandler(COMP_HandleTypeDef *hcomp); +/** + * @} + */ + +/** @addtogroup COMP_Exported_Functions_Group3 Peripheral Control functions + * @brief management functions + * @{ + */ +/* Peripheral Control functions ***********************************************/ +HAL_StatusTypeDef HAL_COMP_Lock(COMP_HandleTypeDef *hcomp); +uint32_t HAL_COMP_GetOutputLevel(COMP_HandleTypeDef *hcomp); + +/* Callback in Interrupt mode */ +void HAL_COMP_TriggerCallback(COMP_HandleTypeDef *hcomp); +/** + * @} + */ + +/** @addtogroup COMP_Exported_Functions_Group4 Peripheral State functions + * @brief Peripheral State functions + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +uint32_t HAL_COMP_GetState(COMP_HandleTypeDef *hcomp); +uint32_t HAL_COMP_GetError(COMP_HandleTypeDef *hcomp); +/** + * @} + */ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/** @defgroup COMP_Private_Constants COMP Private Constants + * @{ + */ +/** @defgroup COMP_ExtiLine COMP EXTI Lines + * Elements values convention: XXXX0000 + * - XXXX : Interrupt mask in the EMR/IMR/RTSR/FTSR register + * @{ + */ +#define COMP_EXTI_LINE_COMP1 ((uint32_t)EXTI_IMR_MR21) /*!< EXTI line 21 connected to COMP1 output */ +#define COMP_EXTI_LINE_COMP2 ((uint32_t)EXTI_IMR_MR22) /*!< EXTI line 22 connected to COMP2 output */ + +/** + * @} + */ + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup COMP_Private_Macros COMP Private Macros + * @{ + */ +/** @defgroup COMP_GET_EXTI_LINE COMP Private macros to get EXTI line associated with Comparators + * @{ + */ +/** + * @brief Get the specified EXTI line for a comparator instance. + * @param __INSTANCE__ specifies the COMP instance. + * @retval value of @ref COMP_ExtiLine + */ +#define COMP_GET_EXTI_LINE(__INSTANCE__) (((__INSTANCE__) == COMP1) ? COMP_EXTI_LINE_COMP1 : \ + COMP_EXTI_LINE_COMP2) +/** + * @} + */ + +/** @defgroup COMP_IS_COMP_Definitions COMP Private macros to check input parameters + * @{ + */ + +#define IS_COMP_OUTPUTPOL(POL) (((POL) == COMP_OUTPUTPOL_NONINVERTED) || \ + ((POL) == COMP_OUTPUTPOL_INVERTED)) + +#define IS_COMP_HYSTERESIS(HYSTERESIS) (((HYSTERESIS) == COMP_HYSTERESIS_NONE) || \ + ((HYSTERESIS) == COMP_HYSTERESIS_LOW) || \ + ((HYSTERESIS) == COMP_HYSTERESIS_MEDIUM) || \ + ((HYSTERESIS) == COMP_HYSTERESIS_HIGH)) + +#define IS_COMP_MODE(MODE) (((MODE) == COMP_MODE_HIGHSPEED) || \ + ((MODE) == COMP_MODE_MEDIUMSPEED) || \ + ((MODE) == COMP_MODE_LOWPOWER) || \ + ((MODE) == COMP_MODE_ULTRALOWPOWER)) + +#define IS_COMP_INVERTINGINPUT(INPUT) (((INPUT) == COMP_INVERTINGINPUT_1_4VREFINT) || \ + ((INPUT) == COMP_INVERTINGINPUT_1_2VREFINT) || \ + ((INPUT) == COMP_INVERTINGINPUT_3_4VREFINT) || \ + ((INPUT) == COMP_INVERTINGINPUT_VREFINT) || \ + ((INPUT) == COMP_INVERTINGINPUT_DAC1) || \ + ((INPUT) == COMP_INVERTINGINPUT_DAC1SWITCHCLOSED) || \ + ((INPUT) == COMP_INVERTINGINPUT_DAC2) || \ + ((INPUT) == COMP_INVERTINGINPUT_IO1)) + +#define IS_COMP_NONINVERTINGINPUT(INPUT) (((INPUT) == COMP_NONINVERTINGINPUT_IO1) || \ + ((INPUT) == COMP_NONINVERTINGINPUT_DAC1SWITCHCLOSED)) + +#define IS_COMP_OUTPUT(OUTPUT) (((OUTPUT) == COMP_OUTPUT_NONE) || \ + ((OUTPUT) == COMP_OUTPUT_TIM1BKIN) || \ + ((OUTPUT) == COMP_OUTPUT_TIM1IC1) || \ + ((OUTPUT) == COMP_OUTPUT_TIM1OCREFCLR) || \ + ((OUTPUT) == COMP_OUTPUT_TIM2IC4) || \ + ((OUTPUT) == COMP_OUTPUT_TIM2OCREFCLR) || \ + ((OUTPUT) == COMP_OUTPUT_TIM3IC1) || \ + ((OUTPUT) == COMP_OUTPUT_TIM3OCREFCLR)) + +#define IS_COMP_WINDOWMODE(WINDOWMODE) (((WINDOWMODE) == COMP_WINDOWMODE_DISABLE) || \ + ((WINDOWMODE) == COMP_WINDOWMODE_ENABLE)) + +#define IS_COMP_TRIGGERMODE(__MODE__) (((__MODE__) == COMP_TRIGGERMODE_NONE) || \ + ((__MODE__) == COMP_TRIGGERMODE_IT_RISING) || \ + ((__MODE__) == COMP_TRIGGERMODE_IT_FALLING) || \ + ((__MODE__) == COMP_TRIGGERMODE_IT_RISING_FALLING) || \ + ((__MODE__) == COMP_TRIGGERMODE_EVENT_RISING) || \ + ((__MODE__) == COMP_TRIGGERMODE_EVENT_FALLING) || \ + ((__MODE__) == COMP_TRIGGERMODE_EVENT_RISING_FALLING)) +/** + * @} + */ + +/** @defgroup COMP_Lock COMP Lock + * @{ + */ +#define COMP_LOCK_DISABLE (0x00000000U) +#define COMP_LOCK_ENABLE COMP_CSR_COMP1LOCK + +#define COMP_STATE_BIT_LOCK (0x10U) +/** + * @} + */ + +/** + * @} + */ + +/* Private functions ---------------------------------------------------------*/ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* COMP1 || COMP2 */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_COMP_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_conf_template.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_conf_template.h new file mode 100644 index 0000000..6035475 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_conf_template.h @@ -0,0 +1,326 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_conf.h + * @author MCD Application Team + * @brief HAL configuration file. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_CONF_H +#define __STM32F0xx_HAL_CONF_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/* ########################## Module Selection ############################## */ +/** + * @brief This is the list of modules to be used in the HAL driver + */ +#define HAL_MODULE_ENABLED +#define HAL_ADC_MODULE_ENABLED +/* #define HAL_CAN_LEGACY_MODULE_ENABLED */ +#define HAL_CAN_MODULE_ENABLED +#define HAL_CEC_MODULE_ENABLED +#define HAL_COMP_MODULE_ENABLED +#define HAL_CORTEX_MODULE_ENABLED +#define HAL_CRC_MODULE_ENABLED +#define HAL_DAC_MODULE_ENABLED +#define HAL_DMA_MODULE_ENABLED +#define HAL_FLASH_MODULE_ENABLED +#define HAL_GPIO_MODULE_ENABLED +#define HAL_EXTI_MODULE_ENABLED +#define HAL_I2C_MODULE_ENABLED +#define HAL_I2S_MODULE_ENABLED +#define HAL_IRDA_MODULE_ENABLED +#define HAL_IWDG_MODULE_ENABLED +#define HAL_PCD_MODULE_ENABLED +#define HAL_PWR_MODULE_ENABLED +#define HAL_RCC_MODULE_ENABLED +#define HAL_RTC_MODULE_ENABLED +#define HAL_SMARTCARD_MODULE_ENABLED +#define HAL_SMBUS_MODULE_ENABLED +#define HAL_SPI_MODULE_ENABLED +#define HAL_TIM_MODULE_ENABLED +#define HAL_TSC_MODULE_ENABLED +#define HAL_UART_MODULE_ENABLED +#define HAL_USART_MODULE_ENABLED +#define HAL_WWDG_MODULE_ENABLED + +/* ######################### Oscillator Values adaptation ################### */ +/** + * @brief Adjust the value of External High Speed oscillator (HSE) used in your application. + * This value is used by the RCC HAL module to compute the system frequency + * (when HSE is used as system clock source, directly or through the PLL). + */ +#if !defined (HSE_VALUE) + #define HSE_VALUE 8000000U /*!< Value of the External oscillator in Hz */ +#endif /* HSE_VALUE */ + +/** + * @brief In the following line adjust the External High Speed oscillator (HSE) Startup + * Timeout value + */ +#if !defined (HSE_STARTUP_TIMEOUT) + #define HSE_STARTUP_TIMEOUT 100U /*!< Time out for HSE start up, in ms */ +#endif /* HSE_STARTUP_TIMEOUT */ + +/** + * @brief Internal High Speed oscillator (HSI) value. + * This value is used by the RCC HAL module to compute the system frequency + * (when HSI is used as system clock source, directly or through the PLL). + */ +#if !defined (HSI_VALUE) + #define HSI_VALUE 8000000U /*!< Value of the Internal oscillator in Hz*/ +#endif /* HSI_VALUE */ + +/** + * @brief In the following line adjust the Internal High Speed oscillator (HSI) Startup + * Timeout value + */ +#if !defined (HSI_STARTUP_TIMEOUT) + #define HSI_STARTUP_TIMEOUT 5000U /*!< Time out for HSI start up */ +#endif /* HSI_STARTUP_TIMEOUT */ + +/** + * @brief Internal High Speed oscillator for ADC (HSI14) value. + */ +#if !defined (HSI14_VALUE) + #define HSI14_VALUE 14000000U /*!< Value of the Internal High Speed oscillator for ADC in Hz. + The real value may vary depending on the variations + in voltage and temperature. */ +#endif /* HSI14_VALUE */ + +/** + * @brief Internal High Speed oscillator for USB (HSI48) value. + */ +#if !defined (HSI48_VALUE) + #define HSI48_VALUE 48000000U /*!< Value of the Internal High Speed oscillator for USB in Hz. + The real value may vary depending on the variations + in voltage and temperature. */ +#endif /* HSI48_VALUE */ + +/** + * @brief Internal Low Speed oscillator (LSI) value. + */ +#if !defined (LSI_VALUE) + #define LSI_VALUE 32000U +#endif /* LSI_VALUE */ /*!< Value of the Internal Low Speed oscillator in Hz + The real value may vary depending on the variations + in voltage and temperature. */ +/** + * @brief External Low Speed oscillator (LSE) value. + */ +#if !defined (LSE_VALUE) + #define LSE_VALUE 32768U /*!< Value of the External Low Speed oscillator in Hz */ +#endif /* LSE_VALUE */ + +/** + * @brief Time out for LSE start up value in ms. + */ +#if !defined (LSE_STARTUP_TIMEOUT) + #define LSE_STARTUP_TIMEOUT 5000U /*!< Time out for LSE start up, in ms */ +#endif /* LSE_STARTUP_TIMEOUT */ + + +/* Tip: To avoid modifying this file each time you need to use different HSE, + === you can define the HSE value in your toolchain compiler preprocessor. */ + +/* ########################### System Configuration ######################### */ +/** + * @brief This is the HAL system configuration section + */ +#define VDD_VALUE 3300U /*!< Value of VDD in mv */ +#define TICK_INT_PRIORITY ((uint32_t)(1U<<__NVIC_PRIO_BITS) - 1U) /*!< tick interrupt priority (lowest by default) */ + /* Warning: Must be set to higher priority for HAL_Delay() */ + /* and HAL_GetTick() usage under interrupt context */ +#define USE_RTOS 0U +#define PREFETCH_ENABLE 1U +#define INSTRUCTION_CACHE_ENABLE 0U +#define DATA_CACHE_ENABLE 0U +#define USE_SPI_CRC 1U + +#define USE_HAL_ADC_REGISTER_CALLBACKS 0U /* ADC register callback disabled */ +#define USE_HAL_CAN_REGISTER_CALLBACKS 0U /* CAN register callback disabled */ +#define USE_HAL_COMP_REGISTER_CALLBACKS 0U /* COMP register callback disabled */ +#define USE_HAL_CEC_REGISTER_CALLBACKS 0U /* CEC register callback disabled */ +#define USE_HAL_DAC_REGISTER_CALLBACKS 0U /* DAC register callback disabled */ +#define USE_HAL_I2C_REGISTER_CALLBACKS 0U /* I2C register callback disabled */ +#define USE_HAL_SMBUS_REGISTER_CALLBACKS 0U /* SMBUS register callback disabled */ +#define USE_HAL_UART_REGISTER_CALLBACKS 0U /* UART register callback disabled */ +#define USE_HAL_USART_REGISTER_CALLBACKS 0U /* USART register callback disabled */ +#define USE_HAL_IRDA_REGISTER_CALLBACKS 0U /* IRDA register callback disabled */ +#define USE_HAL_SMARTCARD_REGISTER_CALLBACKS 0U /* SMARTCARD register callback disabled */ +#define USE_HAL_WWDG_REGISTER_CALLBACKS 0U /* WWDG register callback disabled */ +#define USE_HAL_RTC_REGISTER_CALLBACKS 0U /* RTC register callback disabled */ +#define USE_HAL_SPI_REGISTER_CALLBACKS 0U /* SPI register callback disabled */ +#define USE_HAL_I2S_REGISTER_CALLBACKS 0U /* I2S register callback disabled */ +#define USE_HAL_TIM_REGISTER_CALLBACKS 0U /* TIM register callback disabled */ +#define USE_HAL_TSC_REGISTER_CALLBACKS 0U /* TSC register callback disabled */ +#define USE_HAL_PCD_REGISTER_CALLBACKS 0U /* PCD register callback disabled */ + +/* ########################## Assert Selection ############################## */ +/** + * @brief Uncomment the line below to expanse the "assert_param" macro in the + * HAL drivers code + */ +/*#define USE_FULL_ASSERT 1*/ + +/* Includes ------------------------------------------------------------------*/ +/** + * @brief Include module's header file + */ + +#ifdef HAL_RCC_MODULE_ENABLED + #include "stm32f0xx_hal_rcc.h" +#endif /* HAL_RCC_MODULE_ENABLED */ + +#ifdef HAL_GPIO_MODULE_ENABLED + #include "stm32f0xx_hal_gpio.h" +#endif /* HAL_GPIO_MODULE_ENABLED */ + +#ifdef HAL_EXTI_MODULE_ENABLED + #include "stm32f0xx_hal_exti.h" +#endif /* HAL_EXTI_MODULE_ENABLED */ + +#ifdef HAL_DMA_MODULE_ENABLED + #include "stm32f0xx_hal_dma.h" +#endif /* HAL_DMA_MODULE_ENABLED */ + +#ifdef HAL_CORTEX_MODULE_ENABLED + #include "stm32f0xx_hal_cortex.h" +#endif /* HAL_CORTEX_MODULE_ENABLED */ + +#ifdef HAL_ADC_MODULE_ENABLED + #include "stm32f0xx_hal_adc.h" +#endif /* HAL_ADC_MODULE_ENABLED */ + +#ifdef HAL_CAN_MODULE_ENABLED + #include "stm32f0xx_hal_can.h" +#endif /* HAL_CAN_MODULE_ENABLED */ + +#ifdef HAL_CAN_LEGACY_MODULE_ENABLED + #include "stm32f0xx_hal_can_legacy.h" +#endif /* HAL_CAN_LEGACY_MODULE_ENABLED */ + +#ifdef HAL_CEC_MODULE_ENABLED + #include "stm32f0xx_hal_cec.h" +#endif /* HAL_CEC_MODULE_ENABLED */ + +#ifdef HAL_COMP_MODULE_ENABLED + #include "stm32f0xx_hal_comp.h" +#endif /* HAL_COMP_MODULE_ENABLED */ + +#ifdef HAL_CRC_MODULE_ENABLED + #include "stm32f0xx_hal_crc.h" +#endif /* HAL_CRC_MODULE_ENABLED */ + +#ifdef HAL_DAC_MODULE_ENABLED + #include "stm32f0xx_hal_dac.h" +#endif /* HAL_DAC_MODULE_ENABLED */ + +#ifdef HAL_FLASH_MODULE_ENABLED + #include "stm32f0xx_hal_flash.h" +#endif /* HAL_FLASH_MODULE_ENABLED */ + +#ifdef HAL_I2C_MODULE_ENABLED + #include "stm32f0xx_hal_i2c.h" +#endif /* HAL_I2C_MODULE_ENABLED */ + +#ifdef HAL_I2S_MODULE_ENABLED + #include "stm32f0xx_hal_i2s.h" +#endif /* HAL_I2S_MODULE_ENABLED */ + +#ifdef HAL_IRDA_MODULE_ENABLED + #include "stm32f0xx_hal_irda.h" +#endif /* HAL_IRDA_MODULE_ENABLED */ + +#ifdef HAL_IWDG_MODULE_ENABLED + #include "stm32f0xx_hal_iwdg.h" +#endif /* HAL_IWDG_MODULE_ENABLED */ + +#ifdef HAL_PCD_MODULE_ENABLED + #include "stm32f0xx_hal_pcd.h" +#endif /* HAL_PCD_MODULE_ENABLED */ + +#ifdef HAL_PWR_MODULE_ENABLED + #include "stm32f0xx_hal_pwr.h" +#endif /* HAL_PWR_MODULE_ENABLED */ + +#ifdef HAL_RTC_MODULE_ENABLED + #include "stm32f0xx_hal_rtc.h" +#endif /* HAL_RTC_MODULE_ENABLED */ + +#ifdef HAL_SMARTCARD_MODULE_ENABLED + #include "stm32f0xx_hal_smartcard.h" +#endif /* HAL_SMARTCARD_MODULE_ENABLED */ + +#ifdef HAL_SMBUS_MODULE_ENABLED + #include "stm32f0xx_hal_smbus.h" +#endif /* HAL_SMBUS_MODULE_ENABLED */ + +#ifdef HAL_SPI_MODULE_ENABLED + #include "stm32f0xx_hal_spi.h" +#endif /* HAL_SPI_MODULE_ENABLED */ + +#ifdef HAL_TIM_MODULE_ENABLED + #include "stm32f0xx_hal_tim.h" +#endif /* HAL_TIM_MODULE_ENABLED */ + +#ifdef HAL_TSC_MODULE_ENABLED + #include "stm32f0xx_hal_tsc.h" +#endif /* HAL_TSC_MODULE_ENABLED */ + +#ifdef HAL_UART_MODULE_ENABLED + #include "stm32f0xx_hal_uart.h" +#endif /* HAL_UART_MODULE_ENABLED */ + +#ifdef HAL_USART_MODULE_ENABLED + #include "stm32f0xx_hal_usart.h" +#endif /* HAL_USART_MODULE_ENABLED */ + +#ifdef HAL_WWDG_MODULE_ENABLED + #include "stm32f0xx_hal_wwdg.h" +#endif /* HAL_WWDG_MODULE_ENABLED */ + +/* Exported macro ------------------------------------------------------------*/ +#ifdef USE_FULL_ASSERT +/** + * @brief The assert_param macro is used for function's parameters check. + * @param expr If expr is false, it calls assert_failed function + * which reports the name of the source file and the source + * line number of the call that failed. + * If expr is true, it returns no value. + * @retval None + */ + #define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__)) +/* Exported functions ------------------------------------------------------- */ + void assert_failed(uint8_t* file, uint32_t line); +#else + #define assert_param(expr) ((void)0U) +#endif /* USE_FULL_ASSERT */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_CONF_H */ + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cortex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cortex.h new file mode 100644 index 0000000..e471200 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_cortex.h @@ -0,0 +1,133 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_cortex.h + * @author MCD Application Team + * @brief Header file of CORTEX HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_CORTEX_H +#define __STM32F0xx_HAL_CORTEX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup CORTEX CORTEX + * @{ + */ +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup CORTEX_Exported_Constants CORTEX Exported Constants + * @{ + */ + +/** @defgroup CORTEX_SysTick_clock_source CORTEX SysTick clock source + * @{ + */ +#define SYSTICK_CLKSOURCE_HCLK_DIV8 (0x00000000U) +#define SYSTICK_CLKSOURCE_HCLK (0x00000004U) + +/** + * @} + */ + +/** + * @} + */ + +/* Exported Macros -----------------------------------------------------------*/ + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup CORTEX_Exported_Functions CORTEX Exported Functions + * @{ + */ +/** @addtogroup CORTEX_Exported_Functions_Group1 Initialization and de-initialization functions + * @brief Initialization and Configuration functions + * @{ + */ +/* Initialization and de-initialization functions *******************************/ +void HAL_NVIC_SetPriority(IRQn_Type IRQn,uint32_t PreemptPriority, uint32_t SubPriority); +void HAL_NVIC_EnableIRQ(IRQn_Type IRQn); +void HAL_NVIC_DisableIRQ(IRQn_Type IRQn); +void HAL_NVIC_SystemReset(void); +uint32_t HAL_SYSTICK_Config(uint32_t TicksNumb); +/** + * @} + */ + +/** @addtogroup CORTEX_Exported_Functions_Group2 Peripheral Control functions + * @brief Cortex control functions + * @{ + */ + +/* Peripheral Control functions *************************************************/ +uint32_t HAL_NVIC_GetPriority(IRQn_Type IRQn); +uint32_t HAL_NVIC_GetPendingIRQ(IRQn_Type IRQn); +void HAL_NVIC_SetPendingIRQ(IRQn_Type IRQn); +void HAL_NVIC_ClearPendingIRQ(IRQn_Type IRQn); +void HAL_SYSTICK_CLKSourceConfig(uint32_t CLKSource); +void HAL_SYSTICK_IRQHandler(void); +void HAL_SYSTICK_Callback(void); +/** + * @} + */ + +/** + * @} + */ + +/* Private types -------------------------------------------------------------*/ +/* Private variables ---------------------------------------------------------*/ +/* Private constants ---------------------------------------------------------*/ +/* Private macros ------------------------------------------------------------*/ +/** @defgroup CORTEX_Private_Macros CORTEX Private Macros + * @{ + */ +#define IS_NVIC_PREEMPTION_PRIORITY(PRIORITY) ((PRIORITY) < 0x4) + +#define IS_NVIC_DEVICE_IRQ(IRQ) ((IRQ) >= 0x00) + +#define IS_SYSTICK_CLK_SOURCE(SOURCE) (((SOURCE) == SYSTICK_CLKSOURCE_HCLK) || \ + ((SOURCE) == SYSTICK_CLKSOURCE_HCLK_DIV8)) +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_CORTEX_H */ + + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc.h new file mode 100644 index 0000000..10f3486 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc.h @@ -0,0 +1,359 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_crc.h + * @author MCD Application Team + * @brief Header file of CRC HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_CRC_H +#define STM32F0xx_HAL_CRC_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup CRC + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup CRC_Exported_Types CRC Exported Types + * @{ + */ + +/** + * @brief CRC HAL State Structure definition + */ +typedef enum +{ + HAL_CRC_STATE_RESET = 0x00U, /*!< CRC not yet initialized or disabled */ + HAL_CRC_STATE_READY = 0x01U, /*!< CRC initialized and ready for use */ + HAL_CRC_STATE_BUSY = 0x02U, /*!< CRC internal process is ongoing */ + HAL_CRC_STATE_TIMEOUT = 0x03U, /*!< CRC timeout state */ + HAL_CRC_STATE_ERROR = 0x04U /*!< CRC error state */ +} HAL_CRC_StateTypeDef; + +/** + * @brief CRC Init Structure definition + */ +typedef struct +{ +#if defined(CRC_POL_POL) + uint8_t DefaultPolynomialUse; /*!< This parameter is a value of @ref CRC_Default_Polynomial and indicates if default polynomial is used. + If set to DEFAULT_POLYNOMIAL_ENABLE, resort to default + X^32 + X^26 + X^23 + X^22 + X^16 + X^12 + X^11 + X^10 +X^8 + X^7 + X^5 + + X^4 + X^2+ X +1. + In that case, there is no need to set GeneratingPolynomial field. + If otherwise set to DEFAULT_POLYNOMIAL_DISABLE, GeneratingPolynomial and + CRCLength fields must be set. */ +#endif /* CRC_POL_POL */ + + uint8_t DefaultInitValueUse; /*!< This parameter is a value of @ref CRC_Default_InitValue_Use and indicates if default init value is used. + If set to DEFAULT_INIT_VALUE_ENABLE, resort to default + 0xFFFFFFFF value. In that case, there is no need to set InitValue field. If + otherwise set to DEFAULT_INIT_VALUE_DISABLE, InitValue field must be set. */ + +#if defined(CRC_POL_POL) + uint32_t GeneratingPolynomial; /*!< Set CRC generating polynomial as a 7, 8, 16 or 32-bit long value for a polynomial degree + respectively equal to 7, 8, 16 or 32. This field is written in normal, + representation e.g., for a polynomial of degree 7, X^7 + X^6 + X^5 + X^2 + 1 + is written 0x65. No need to specify it if DefaultPolynomialUse is set to + DEFAULT_POLYNOMIAL_ENABLE. */ + + uint32_t CRCLength; /*!< This parameter is a value of @ref CRC_Polynomial_Sizes and indicates CRC length. + Value can be either one of + @arg @ref CRC_POLYLENGTH_32B (32-bit CRC), + @arg @ref CRC_POLYLENGTH_16B (16-bit CRC), + @arg @ref CRC_POLYLENGTH_8B (8-bit CRC), + @arg @ref CRC_POLYLENGTH_7B (7-bit CRC). */ +#endif /* CRC_POL_POL */ + + uint32_t InitValue; /*!< Init value to initiate CRC computation. No need to specify it if DefaultInitValueUse + is set to DEFAULT_INIT_VALUE_ENABLE. */ + + uint32_t InputDataInversionMode; /*!< This parameter is a value of @ref CRCEx_Input_Data_Inversion and specifies input data inversion mode. + Can be either one of the following values + @arg @ref CRC_INPUTDATA_INVERSION_NONE no input data inversion + @arg @ref CRC_INPUTDATA_INVERSION_BYTE byte-wise inversion, 0x1A2B3C4D + becomes 0x58D43CB2 + @arg @ref CRC_INPUTDATA_INVERSION_HALFWORD halfword-wise inversion, + 0x1A2B3C4D becomes 0xD458B23C + @arg @ref CRC_INPUTDATA_INVERSION_WORD word-wise inversion, 0x1A2B3C4D + becomes 0xB23CD458 */ + + uint32_t OutputDataInversionMode; /*!< This parameter is a value of @ref CRCEx_Output_Data_Inversion and specifies output data (i.e. CRC) inversion mode. + Can be either + @arg @ref CRC_OUTPUTDATA_INVERSION_DISABLE no CRC inversion, + @arg @ref CRC_OUTPUTDATA_INVERSION_ENABLE CRC 0x11223344 is converted + into 0x22CC4488 */ +} CRC_InitTypeDef; + +/** + * @brief CRC Handle Structure definition + */ +typedef struct +{ + CRC_TypeDef *Instance; /*!< Register base address */ + + CRC_InitTypeDef Init; /*!< CRC configuration parameters */ + + HAL_LockTypeDef Lock; /*!< CRC Locking object */ + + __IO HAL_CRC_StateTypeDef State; /*!< CRC communication state */ + + uint32_t InputDataFormat; /*!< This parameter is a value of @ref CRC_Input_Buffer_Format and specifies input data format. + Can be either + @arg @ref CRC_INPUTDATA_FORMAT_BYTES input data is a stream of bytes + (8-bit data) + @arg @ref CRC_INPUTDATA_FORMAT_HALFWORDS input data is a stream of + half-words (16-bit data) + @arg @ref CRC_INPUTDATA_FORMAT_WORDS input data is a stream of words + (32-bit data) + + Note that constant CRC_INPUT_FORMAT_UNDEFINED is defined but an initialization + error must occur if InputBufferFormat is not one of the three values listed + above */ +} CRC_HandleTypeDef; +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup CRC_Exported_Constants CRC Exported Constants + * @{ + */ + +#if defined(CRC_POL_POL) +/** @defgroup CRC_Default_Polynomial_Value Default CRC generating polynomial + * @{ + */ +#define DEFAULT_CRC32_POLY 0x04C11DB7U /*!< X^32 + X^26 + X^23 + X^22 + X^16 + X^12 + X^11 + X^10 +X^8 + X^7 + X^5 + X^4 + X^2+ X +1 */ +/** + * @} + */ +#endif /* CRC_POL_POL */ + +/** @defgroup CRC_Default_InitValue Default CRC computation initialization value + * @{ + */ +#define DEFAULT_CRC_INITVALUE 0xFFFFFFFFU /*!< Initial CRC default value */ +/** + * @} + */ + +#if defined(CRC_POL_POL) +/** @defgroup CRC_Default_Polynomial Indicates whether or not default polynomial is used + * @{ + */ +#define DEFAULT_POLYNOMIAL_ENABLE ((uint8_t)0x00U) /*!< Enable default generating polynomial 0x04C11DB7 */ +#define DEFAULT_POLYNOMIAL_DISABLE ((uint8_t)0x01U) /*!< Disable default generating polynomial 0x04C11DB7 */ +/** + * @} + */ +#endif /* CRC_POL_POL */ + +/** @defgroup CRC_Default_InitValue_Use Indicates whether or not default init value is used + * @{ + */ +#define DEFAULT_INIT_VALUE_ENABLE ((uint8_t)0x00U) /*!< Enable initial CRC default value */ +#define DEFAULT_INIT_VALUE_DISABLE ((uint8_t)0x01U) /*!< Disable initial CRC default value */ +/** + * @} + */ + +#if defined(CRC_POL_POL) +/** @defgroup CRC_Polynomial_Sizes Polynomial sizes to configure the peripheral + * @{ + */ +#define CRC_POLYLENGTH_32B 0x00000000U /*!< Resort to a 32-bit long generating polynomial */ +#define CRC_POLYLENGTH_16B CRC_CR_POLYSIZE_0 /*!< Resort to a 16-bit long generating polynomial */ +#define CRC_POLYLENGTH_8B CRC_CR_POLYSIZE_1 /*!< Resort to a 8-bit long generating polynomial */ +#define CRC_POLYLENGTH_7B CRC_CR_POLYSIZE /*!< Resort to a 7-bit long generating polynomial */ +/** + * @} + */ + +/** @defgroup CRC_Polynomial_Size_Definitions CRC polynomial possible sizes actual definitions + * @{ + */ +#define HAL_CRC_LENGTH_32B 32U /*!< 32-bit long CRC */ +#define HAL_CRC_LENGTH_16B 16U /*!< 16-bit long CRC */ +#define HAL_CRC_LENGTH_8B 8U /*!< 8-bit long CRC */ +#define HAL_CRC_LENGTH_7B 7U /*!< 7-bit long CRC */ +/** + * @} + */ +#endif /* CRC_POL_POL */ + +/** @defgroup CRC_Input_Buffer_Format Input Buffer Format + * @{ + */ +/* WARNING: CRC_INPUT_FORMAT_UNDEFINED is created for reference purposes but + * an error is triggered in HAL_CRC_Init() if InputDataFormat field is set + * to CRC_INPUT_FORMAT_UNDEFINED: the format MUST be defined by the user for + * the CRC APIs to provide a correct result */ +#define CRC_INPUTDATA_FORMAT_UNDEFINED 0x00000000U /*!< Undefined input data format */ +#define CRC_INPUTDATA_FORMAT_BYTES 0x00000001U /*!< Input data in byte format */ +#define CRC_INPUTDATA_FORMAT_HALFWORDS 0x00000002U /*!< Input data in half-word format */ +#define CRC_INPUTDATA_FORMAT_WORDS 0x00000003U /*!< Input data in word format */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macros -----------------------------------------------------------*/ +/** @defgroup CRC_Exported_Macros CRC Exported Macros + * @{ + */ + +/** @brief Reset CRC handle state. + * @param __HANDLE__ CRC handle. + * @retval None + */ +#define __HAL_CRC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_CRC_STATE_RESET) + +/** + * @brief Reset CRC Data Register. + * @param __HANDLE__ CRC handle + * @retval None + */ +#define __HAL_CRC_DR_RESET(__HANDLE__) ((__HANDLE__)->Instance->CR |= CRC_CR_RESET) + +/** + * @brief Set CRC INIT non-default value + * @param __HANDLE__ CRC handle + * @param __INIT__ 32-bit initial value + * @retval None + */ +#define __HAL_CRC_INITIALCRCVALUE_CONFIG(__HANDLE__, __INIT__) ((__HANDLE__)->Instance->INIT = (__INIT__)) + +/** + * @brief Store data in the Independent Data (ID) register. + * @param __HANDLE__ CRC handle + * @param __VALUE__ Value to be stored in the ID register + * @note Refer to the Reference Manual to get the authorized __VALUE__ length in bits + * @retval None + */ +#define __HAL_CRC_SET_IDR(__HANDLE__, __VALUE__) (WRITE_REG((__HANDLE__)->Instance->IDR, (__VALUE__))) + +/** + * @brief Return the data stored in the Independent Data (ID) register. + * @param __HANDLE__ CRC handle + * @note Refer to the Reference Manual to get the authorized __VALUE__ length in bits + * @retval Value of the ID register + */ +#define __HAL_CRC_GET_IDR(__HANDLE__) (((__HANDLE__)->Instance->IDR) & CRC_IDR_IDR) +/** + * @} + */ + + +/* Private macros --------------------------------------------------------*/ +/** @defgroup CRC_Private_Macros CRC Private Macros + * @{ + */ + +#if defined(CRC_POL_POL) +#define IS_DEFAULT_POLYNOMIAL(DEFAULT) (((DEFAULT) == DEFAULT_POLYNOMIAL_ENABLE) || \ + ((DEFAULT) == DEFAULT_POLYNOMIAL_DISABLE)) +#endif /* CRC_POL_POL */ + +#define IS_DEFAULT_INIT_VALUE(VALUE) (((VALUE) == DEFAULT_INIT_VALUE_ENABLE) || \ + ((VALUE) == DEFAULT_INIT_VALUE_DISABLE)) + +#if defined(CRC_POL_POL) +#define IS_CRC_POL_LENGTH(LENGTH) (((LENGTH) == CRC_POLYLENGTH_32B) || \ + ((LENGTH) == CRC_POLYLENGTH_16B) || \ + ((LENGTH) == CRC_POLYLENGTH_8B) || \ + ((LENGTH) == CRC_POLYLENGTH_7B)) +#endif /* CRC_POL_POL */ + +#define IS_CRC_INPUTDATA_FORMAT(FORMAT) (((FORMAT) == CRC_INPUTDATA_FORMAT_BYTES) || \ + ((FORMAT) == CRC_INPUTDATA_FORMAT_HALFWORDS) || \ + ((FORMAT) == CRC_INPUTDATA_FORMAT_WORDS)) + +/** + * @} + */ + +/* Include CRC HAL Extended module */ +#include "stm32f0xx_hal_crc_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup CRC_Exported_Functions CRC Exported Functions + * @{ + */ + +/* Initialization and de-initialization functions ****************************/ +/** @defgroup CRC_Exported_Functions_Group1 Initialization and de-initialization functions + * @{ + */ +HAL_StatusTypeDef HAL_CRC_Init(CRC_HandleTypeDef *hcrc); +HAL_StatusTypeDef HAL_CRC_DeInit(CRC_HandleTypeDef *hcrc); +void HAL_CRC_MspInit(CRC_HandleTypeDef *hcrc); +void HAL_CRC_MspDeInit(CRC_HandleTypeDef *hcrc); +/** + * @} + */ + +/* Peripheral Control functions ***********************************************/ +/** @defgroup CRC_Exported_Functions_Group2 Peripheral Control functions + * @{ + */ +uint32_t HAL_CRC_Accumulate(CRC_HandleTypeDef *hcrc, uint32_t pBuffer[], uint32_t BufferLength); +uint32_t HAL_CRC_Calculate(CRC_HandleTypeDef *hcrc, uint32_t pBuffer[], uint32_t BufferLength); +/** + * @} + */ + +/* Peripheral State and Error functions ***************************************/ +/** @defgroup CRC_Exported_Functions_Group3 Peripheral State functions + * @{ + */ +HAL_CRC_StateTypeDef HAL_CRC_GetState(CRC_HandleTypeDef *hcrc); +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_CRC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc_ex.h new file mode 100644 index 0000000..761ca94 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_crc_ex.h @@ -0,0 +1,153 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_crc_ex.h + * @author MCD Application Team + * @brief Header file of CRC HAL extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_CRC_EX_H +#define STM32F0xx_HAL_CRC_EX_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup CRCEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +/** @defgroup CRCEx_Exported_Constants CRC Extended Exported Constants + * @{ + */ + +/** @defgroup CRCEx_Input_Data_Inversion Input Data Inversion Modes + * @{ + */ +#define CRC_INPUTDATA_INVERSION_NONE 0x00000000U /*!< No input data inversion */ +#define CRC_INPUTDATA_INVERSION_BYTE CRC_CR_REV_IN_0 /*!< Byte-wise input data inversion */ +#define CRC_INPUTDATA_INVERSION_HALFWORD CRC_CR_REV_IN_1 /*!< HalfWord-wise input data inversion */ +#define CRC_INPUTDATA_INVERSION_WORD CRC_CR_REV_IN /*!< Word-wise input data inversion */ +/** + * @} + */ + +/** @defgroup CRCEx_Output_Data_Inversion Output Data Inversion Modes + * @{ + */ +#define CRC_OUTPUTDATA_INVERSION_DISABLE 0x00000000U /*!< No output data inversion */ +#define CRC_OUTPUTDATA_INVERSION_ENABLE CRC_CR_REV_OUT /*!< Bit-wise output data inversion */ +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup CRCEx_Exported_Macros CRC Extended Exported Macros + * @{ + */ + +/** + * @brief Set CRC output reversal + * @param __HANDLE__ CRC handle + * @retval None + */ +#define __HAL_CRC_OUTPUTREVERSAL_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= CRC_CR_REV_OUT) + +/** + * @brief Unset CRC output reversal + * @param __HANDLE__ CRC handle + * @retval None + */ +#define __HAL_CRC_OUTPUTREVERSAL_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~(CRC_CR_REV_OUT)) + +/** + * @brief Set CRC non-default polynomial + * @param __HANDLE__ CRC handle + * @param __POLYNOMIAL__ 7, 8, 16 or 32-bit polynomial + * @retval None + */ +#define __HAL_CRC_POLYNOMIAL_CONFIG(__HANDLE__, __POLYNOMIAL__) ((__HANDLE__)->Instance->POL = (__POLYNOMIAL__)) + +/** + * @} + */ + +/* Private macros --------------------------------------------------------*/ +/** @defgroup CRCEx_Private_Macros CRC Extended Private Macros + * @{ + */ + +#define IS_CRC_INPUTDATA_INVERSION_MODE(MODE) (((MODE) == CRC_INPUTDATA_INVERSION_NONE) || \ + ((MODE) == CRC_INPUTDATA_INVERSION_BYTE) || \ + ((MODE) == CRC_INPUTDATA_INVERSION_HALFWORD) || \ + ((MODE) == CRC_INPUTDATA_INVERSION_WORD)) + +#define IS_CRC_OUTPUTDATA_INVERSION_MODE(MODE) (((MODE) == CRC_OUTPUTDATA_INVERSION_DISABLE) || \ + ((MODE) == CRC_OUTPUTDATA_INVERSION_ENABLE)) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup CRCEx_Exported_Functions + * @{ + */ + +/** @addtogroup CRCEx_Exported_Functions_Group1 + * @{ + */ +/* Initialization and de-initialization functions ****************************/ +HAL_StatusTypeDef HAL_CRCEx_Polynomial_Set(CRC_HandleTypeDef *hcrc, uint32_t Pol, uint32_t PolyLength); +HAL_StatusTypeDef HAL_CRCEx_Input_Data_Reverse(CRC_HandleTypeDef *hcrc, uint32_t InputReverseMode); +HAL_StatusTypeDef HAL_CRCEx_Output_Data_Reverse(CRC_HandleTypeDef *hcrc, uint32_t OutputReverseMode); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_CRC_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac.h new file mode 100644 index 0000000..d613be8 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac.h @@ -0,0 +1,429 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_dac.h + * @author MCD Application Team + * @brief Header file of DAC HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_DAC_H +#define STM32F0xx_HAL_DAC_H + +#ifdef __cplusplus + extern "C" { +#endif + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#if defined (DAC1) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup DAC + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup DAC_Exported_Types DAC Exported Types + * @{ + */ + +/** + * @brief HAL State structures definition + */ +typedef enum +{ + HAL_DAC_STATE_RESET = 0x00U, /*!< DAC not yet initialized or disabled */ + HAL_DAC_STATE_READY = 0x01U, /*!< DAC initialized and ready for use */ + HAL_DAC_STATE_BUSY = 0x02U, /*!< DAC internal processing is ongoing */ + HAL_DAC_STATE_TIMEOUT = 0x03U, /*!< DAC timeout state */ + HAL_DAC_STATE_ERROR = 0x04U /*!< DAC error state */ + +}HAL_DAC_StateTypeDef; + +/** + * @brief DAC handle Structure definition + */ +typedef struct __DAC_HandleTypeDef +{ + DAC_TypeDef *Instance; /*!< Register base address */ + + __IO HAL_DAC_StateTypeDef State; /*!< DAC communication state */ + + HAL_LockTypeDef Lock; /*!< DAC locking object */ + + DMA_HandleTypeDef *DMA_Handle1; /*!< Pointer DMA handler for channel 1 */ + + DMA_HandleTypeDef *DMA_Handle2; /*!< Pointer DMA handler for channel 2 */ + + __IO uint32_t ErrorCode; /*!< DAC Error code */ + +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) + void (* ConvCpltCallbackCh1) (struct __DAC_HandleTypeDef *hdac); + void (* ConvHalfCpltCallbackCh1) (struct __DAC_HandleTypeDef *hdac); + void (* ErrorCallbackCh1) (struct __DAC_HandleTypeDef *hdac); + void (* DMAUnderrunCallbackCh1) (struct __DAC_HandleTypeDef *hdac); + void (* ConvCpltCallbackCh2) (struct __DAC_HandleTypeDef* hdac); + void (* ConvHalfCpltCallbackCh2) (struct __DAC_HandleTypeDef* hdac); + void (* ErrorCallbackCh2) (struct __DAC_HandleTypeDef* hdac); + void (* DMAUnderrunCallbackCh2) (struct __DAC_HandleTypeDef* hdac); + + void (* MspInitCallback) (struct __DAC_HandleTypeDef *hdac); + void (* MspDeInitCallback ) (struct __DAC_HandleTypeDef *hdac); +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + +}DAC_HandleTypeDef; + +/** + * @brief DAC Configuration regular Channel structure definition + */ +typedef struct +{ + uint32_t DAC_Trigger; /*!< Specifies the external trigger for the selected DAC channel. + This parameter can be a value of @ref DAC_trigger_selection */ + + uint32_t DAC_OutputBuffer; /*!< Specifies whether the DAC channel output buffer is enabled or disabled. + This parameter can be a value of @ref DAC_output_buffer */ + +}DAC_ChannelConfTypeDef; + +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) +/** + * @brief HAL DAC Callback ID enumeration definition + */ +typedef enum +{ + HAL_DAC_CH1_COMPLETE_CB_ID = 0x00U, /*!< DAC CH1 Complete Callback ID */ + HAL_DAC_CH1_HALF_COMPLETE_CB_ID = 0x01U, /*!< DAC CH1 half Complete Callback ID */ + HAL_DAC_CH1_ERROR_ID = 0x02U, /*!< DAC CH1 error Callback ID */ + HAL_DAC_CH1_UNDERRUN_CB_ID = 0x03U, /*!< DAC CH1 underrun Callback ID */ + HAL_DAC_CH2_COMPLETE_CB_ID = 0x04U, /*!< DAC CH2 Complete Callback ID */ + HAL_DAC_CH2_HALF_COMPLETE_CB_ID = 0x05U, /*!< DAC CH2 half Complete Callback ID */ + HAL_DAC_CH2_ERROR_ID = 0x06U, /*!< DAC CH2 error Callback ID */ + HAL_DAC_CH2_UNDERRUN_CB_ID = 0x07U, /*!< DAC CH2 underrun Callback ID */ + HAL_DAC_MSPINIT_CB_ID = 0x08U, /*!< DAC MspInit Callback ID */ + HAL_DAC_MSPDEINIT_CB_ID = 0x09U, /*!< DAC MspDeInit Callback ID */ + HAL_DAC_ALL_CB_ID = 0x0AU /*!< DAC All ID */ +} HAL_DAC_CallbackIDTypeDef; + +/** + * @brief HAL DAC Callback pointer definition + */ +typedef void (*pDAC_CallbackTypeDef)(DAC_HandleTypeDef *hdac); +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup DAC_Exported_Constants DAC Exported Constants + * @{ + */ + +/** @defgroup DAC_Error_Code DAC Error Code + * @{ + */ +#define HAL_DAC_ERROR_NONE 0x00U /*!< No error */ +#define HAL_DAC_ERROR_DMAUNDERRUNCH1 0x01U /*!< DAC channel1 DMA underrun error */ +#define HAL_DAC_ERROR_DMAUNDERRUNCH2 0x02U /*!< DAC channel2 DMA underrun error */ +#define HAL_DAC_ERROR_DMA 0x04U /*!< DMA error */ +#define HAL_DAC_ERROR_TIMEOUT 0x08U /*!< Timeout error */ +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) +#define HAL_DAC_ERROR_INVALID_CALLBACK 0x10U /*!< Invalid callback error */ +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ +/** + * @} + */ + +/** @defgroup DAC_output_buffer DAC output buffer + * @{ + */ +#define DAC_OUTPUTBUFFER_ENABLE (0x00000000U) +#define DAC_OUTPUTBUFFER_DISABLE ((uint32_t)DAC_CR_BOFF1) + +/** + * @} + */ + +/** @defgroup DAC_data_alignment DAC data alignment + * @{ + */ +#define DAC_ALIGN_12B_R (0x00000000U) +#define DAC_ALIGN_12B_L (0x00000004U) +#define DAC_ALIGN_8B_R (0x00000008U) + +/** + * @} + */ + +/** @defgroup DAC_flags_definition DAC flags definition + * @{ + */ +#define DAC_FLAG_DMAUDR1 ((uint32_t)DAC_SR_DMAUDR1) +#define DAC_FLAG_DMAUDR2 ((uint32_t)DAC_SR_DMAUDR2) +/** + * @} + */ + +/** @defgroup DAC_IT_definition DAC IT definition + * @{ + */ +#define DAC_IT_DMAUDR1 ((uint32_t)DAC_SR_DMAUDR1) +#define DAC_IT_DMAUDR2 ((uint32_t)DAC_SR_DMAUDR2) +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ + +/** @defgroup DAC_Exported_Macros DAC Exported Macros + * @{ + */ + +/** @brief Reset DAC handle state + * @param __HANDLE__ specifies the DAC handle. + * @retval None + */ +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) +#define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) do { \ + (__HANDLE__)->State = HAL_DAC_STATE_RESET; \ + (__HANDLE__)->MspInitCallback = NULL; \ + (__HANDLE__)->MspDeInitCallback = NULL; \ + } while(0) +#else +#define __HAL_DAC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_DAC_STATE_RESET) +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + +/** @brief Enable the DAC channel + * @param __HANDLE__ specifies the DAC handle. + * @param __DAC_Channel__ specifies the DAC channel + * @retval None + */ +#define __HAL_DAC_ENABLE(__HANDLE__, __DAC_Channel__) \ +((__HANDLE__)->Instance->CR |= (DAC_CR_EN1 << (__DAC_Channel__))) + +/** @brief Disable the DAC channel + * @param __HANDLE__ specifies the DAC handle + * @param __DAC_Channel__ specifies the DAC channel. + * @retval None + */ +#define __HAL_DAC_DISABLE(__HANDLE__, __DAC_Channel__) \ +((__HANDLE__)->Instance->CR &= ~(DAC_CR_EN1 << (__DAC_Channel__))) + +/** @brief Enable the DAC interrupt + * @param __HANDLE__ specifies the DAC handle + * @param __INTERRUPT__ specifies the DAC interrupt. + * This parameter can be any combination of the following values: + * @arg DAC_IT_DMAUDR1: DAC channel 1 DMA underrun interrupt + * @arg DAC_IT_DMAUDR2: DAC channel 2 DMA underrun interrupt + * @retval None + */ +#define __HAL_DAC_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) |= (__INTERRUPT__)) + +/** @brief Disable the DAC interrupt + * @param __HANDLE__ specifies the DAC handle + * @param __INTERRUPT__ specifies the DAC interrupt. + * This parameter can be any combination of the following values: + * @arg DAC_IT_DMAUDR1: DAC channel 1 DMA underrun interrupt + * @retval None + */ +#define __HAL_DAC_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR) &= ~(__INTERRUPT__)) + +/** @brief Check whether the specified DAC interrupt source is enabled or not + * @param __HANDLE__ DAC handle + * @param __INTERRUPT__ DAC interrupt source to check + * This parameter can be any combination of the following values: + * @arg DAC_IT_DMAUDR1: DAC channel 1 DMA underrun interrupt + * @arg DAC_IT_DMAUDR2: DAC channel 2 DMA underrun interrupt + * @retval State of interruption (SET or RESET) + */ +#define __HAL_DAC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CR & (__INTERRUPT__)) == (__INTERRUPT__)) + +/** @brief Get the selected DAC's flag status + * @param __HANDLE__ specifies the DAC handle. + * @param __FLAG__ specifies the DAC flag to get. + * This parameter can be any combination of the following values: + * @arg DAC_FLAG_DMAUDR1: DAC channel 1 DMA underrun flag + * @retval None + */ +#define __HAL_DAC_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->SR) & (__FLAG__)) == (__FLAG__)) + +/** @brief Clear the DAC's flag + * @param __HANDLE__ specifies the DAC handle. + * @param __FLAG__ specifies the DAC flag to clear. + * This parameter can be any combination of the following values: + * @arg DAC_FLAG_DMAUDR1: DAC channel 1 DMA underrun flag + * @retval None + */ +#define __HAL_DAC_CLEAR_FLAG(__HANDLE__, __FLAG__) (((__HANDLE__)->Instance->SR) = (__FLAG__)) + +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ + +/** @addtogroup DAC_Private_Macros + * @{ + */ +#define IS_DAC_OUTPUT_BUFFER_STATE(STATE) (((STATE) == DAC_OUTPUTBUFFER_ENABLE) || \ + ((STATE) == DAC_OUTPUTBUFFER_DISABLE)) + + +#if defined(DAC_CHANNEL2_SUPPORT) + +#define IS_DAC_CHANNEL(CHANNEL) (((CHANNEL) == DAC_CHANNEL_1) || \ + ((CHANNEL) == DAC_CHANNEL_2)) + +#else + +#define IS_DAC_CHANNEL(CHANNEL) (((CHANNEL) == DAC_CHANNEL_1)) + +#endif /* DAC_CHANNEL2_SUPPORT */ + + +#define IS_DAC_ALIGN(ALIGN) (((ALIGN) == DAC_ALIGN_12B_R) || \ + ((ALIGN) == DAC_ALIGN_12B_L) || \ + ((ALIGN) == DAC_ALIGN_8B_R)) + +#define IS_DAC_DATA(DATA) ((DATA) <= 0xFFF0U) + +/** @brief Set DHR12R1 alignment + * @param __ALIGNMENT__ specifies the DAC alignment + * @retval None + */ +#define DAC_DHR12R1_ALIGNMENT(__ALIGNMENT__) ((0x00000008U) + (__ALIGNMENT__)) + +/** @brief Set DHR12R2 alignment + * @param __ALIGNMENT__ specifies the DAC alignment + * @retval None + */ +#define DAC_DHR12R2_ALIGNMENT(__ALIGNMENT__) ((0x00000014U) + (__ALIGNMENT__)) + +/** @brief Set DHR12RD alignment + * @param __ALIGNMENT__ specifies the DAC alignment + * @retval None + */ +#define DAC_DHR12RD_ALIGNMENT(__ALIGNMENT__) ((0x00000020U) + (__ALIGNMENT__)) + +/** + * @} + */ + +/* Include DAC HAL Extension module */ +#include "stm32f0xx_hal_dac_ex.h" + +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup DAC_Exported_Functions + * @{ + */ + +/** @addtogroup DAC_Exported_Functions_Group1 + * @{ + */ +/* Initialization and de-initialization functions *****************************/ +HAL_StatusTypeDef HAL_DAC_Init(DAC_HandleTypeDef* hdac); +HAL_StatusTypeDef HAL_DAC_DeInit(DAC_HandleTypeDef* hdac); +void HAL_DAC_MspInit(DAC_HandleTypeDef* hdac); +void HAL_DAC_MspDeInit(DAC_HandleTypeDef* hdac); + +/** + * @} + */ + +/** @addtogroup DAC_Exported_Functions_Group2 + * @{ + */ +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_DAC_Start(DAC_HandleTypeDef* hdac, uint32_t Channel); +HAL_StatusTypeDef HAL_DAC_Stop(DAC_HandleTypeDef* hdac, uint32_t Channel); +HAL_StatusTypeDef HAL_DAC_Start_DMA(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t* pData, uint32_t Length, uint32_t Alignment); +HAL_StatusTypeDef HAL_DAC_Stop_DMA(DAC_HandleTypeDef* hdac, uint32_t Channel); + +void HAL_DAC_IRQHandler(DAC_HandleTypeDef* hdac); + +HAL_StatusTypeDef HAL_DAC_SetValue(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t Alignment, uint32_t Data); + +void HAL_DAC_ConvCpltCallbackCh1(DAC_HandleTypeDef* hdac); +void HAL_DAC_ConvHalfCpltCallbackCh1(DAC_HandleTypeDef* hdac); +void HAL_DAC_ErrorCallbackCh1(DAC_HandleTypeDef *hdac); +void HAL_DAC_DMAUnderrunCallbackCh1(DAC_HandleTypeDef *hdac); + +#if (USE_HAL_DAC_REGISTER_CALLBACKS == 1) +/* DAC callback registering/unregistering */ +HAL_StatusTypeDef HAL_DAC_RegisterCallback (DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackId, pDAC_CallbackTypeDef pCallback); +HAL_StatusTypeDef HAL_DAC_UnRegisterCallback (DAC_HandleTypeDef *hdac, HAL_DAC_CallbackIDTypeDef CallbackId); +#endif /* USE_HAL_DAC_REGISTER_CALLBACKS */ + +/** + * @} + */ + +/** @addtogroup DAC_Exported_Functions_Group3 + * @{ + */ +/* Peripheral Control functions ***********************************************/ +uint32_t HAL_DAC_GetValue(DAC_HandleTypeDef* hdac, uint32_t Channel); + +HAL_StatusTypeDef HAL_DAC_ConfigChannel(DAC_HandleTypeDef* hdac, DAC_ChannelConfTypeDef* sConfig, uint32_t Channel); +/** + * @} + */ + +/** @addtogroup DAC_Exported_Functions_Group4 + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +HAL_DAC_StateTypeDef HAL_DAC_GetState(DAC_HandleTypeDef* hdac); +uint32_t HAL_DAC_GetError(DAC_HandleTypeDef *hdac); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* DAC1 */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + + +#endif /* STM32F0xx_HAL_DAC_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac_ex.h new file mode 100644 index 0000000..84fd756 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dac_ex.h @@ -0,0 +1,292 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_dac_ex.h + * @author MCD Application Team + * @brief Header file of DAC HAL Extension module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_DAC_EX_H +#define __STM32F0xx_HAL_DAC_EX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +#if defined(STM32F051x8) || defined(STM32F058xx) || \ + defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup DACEx + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup DACEx_Exported_Constants DACEx Exported Constants + * @{ + */ + +/** @defgroup DACEx_lfsrunmask_triangleamplitude DACEx lfsrunmask triangleamplitude + * @{ + */ +#define DAC_LFSRUNMASK_BIT0 (0x00000000U) /*!< Unmask DAC channel LFSR bit0 for noise wave generation */ +#define DAC_LFSRUNMASK_BITS1_0 ((uint32_t)DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[1:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS2_0 ((uint32_t)DAC_CR_MAMP1_1) /*!< Unmask DAC channel LFSR bit[2:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS3_0 ((uint32_t)DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0)/*!< Unmask DAC channel LFSR bit[3:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS4_0 ((uint32_t)DAC_CR_MAMP1_2) /*!< Unmask DAC channel LFSR bit[4:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS5_0 ((uint32_t)DAC_CR_MAMP1_2 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[5:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS6_0 ((uint32_t)DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1) /*!< Unmask DAC channel LFSR bit[6:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS7_0 ((uint32_t)DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[7:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS8_0 ((uint32_t)DAC_CR_MAMP1_3) /*!< Unmask DAC channel LFSR bit[8:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS9_0 ((uint32_t)DAC_CR_MAMP1_3 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[9:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS10_0 ((uint32_t)DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1) /*!< Unmask DAC channel LFSR bit[10:0] for noise wave generation */ +#define DAC_LFSRUNMASK_BITS11_0 ((uint32_t)DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Unmask DAC channel LFSR bit[11:0] for noise wave generation */ +#define DAC_TRIANGLEAMPLITUDE_1 (0x00000000U) /*!< Select max triangle amplitude of 1 */ +#define DAC_TRIANGLEAMPLITUDE_3 ((uint32_t)DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 3 */ +#define DAC_TRIANGLEAMPLITUDE_7 ((uint32_t)DAC_CR_MAMP1_1) /*!< Select max triangle amplitude of 7 */ +#define DAC_TRIANGLEAMPLITUDE_15 ((uint32_t)DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 15 */ +#define DAC_TRIANGLEAMPLITUDE_31 ((uint32_t)DAC_CR_MAMP1_2) /*!< Select max triangle amplitude of 31 */ +#define DAC_TRIANGLEAMPLITUDE_63 ((uint32_t)DAC_CR_MAMP1_2 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 63 */ +#define DAC_TRIANGLEAMPLITUDE_127 ((uint32_t)DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1) /*!< Select max triangle amplitude of 127 */ +#define DAC_TRIANGLEAMPLITUDE_255 ((uint32_t)DAC_CR_MAMP1_2 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 255 */ +#define DAC_TRIANGLEAMPLITUDE_511 ((uint32_t)DAC_CR_MAMP1_3) /*!< Select max triangle amplitude of 511 */ +#define DAC_TRIANGLEAMPLITUDE_1023 ((uint32_t)DAC_CR_MAMP1_3 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 1023 */ +#define DAC_TRIANGLEAMPLITUDE_2047 ((uint32_t)DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1) /*!< Select max triangle amplitude of 2047 */ +#define DAC_TRIANGLEAMPLITUDE_4095 ((uint32_t)DAC_CR_MAMP1_3 | DAC_CR_MAMP1_1 | DAC_CR_MAMP1_0) /*!< Select max triangle amplitude of 4095 */ + + +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ + + +/** @defgroup DACEx_Exported_Macros DACEx Exported Macros + * @{ + */ + +/** @defgroup DAC_trigger_selection DAC trigger selection + * @{ + */ +#if defined(STM32F051x8) || defined(STM32F058xx) + +#define DAC_TRIGGER_NONE (0x00000000U) /*!< Conversion is automatic once the DAC1_DHRxxxx register + has been loaded, and not by external trigger */ +#define DAC_TRIGGER_T2_TRGO ((uint32_t)(DAC_CR_TSEL1_2 | DAC_CR_TEN1)) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_T3_TRGO ((uint32_t)(DAC_CR_TSEL1_0 | DAC_CR_TEN1)) /*!< TIM3 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_T6_TRGO ((uint32_t)DAC_CR_TEN1) /*!< TIM6 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_T15_TRGO ((uint32_t)(DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0 | DAC_CR_TEN1)) /*!< TIM15 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_EXT_IT9 ((uint32_t)(DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TEN1)) /*!< EXTI Line9 event selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_SOFTWARE ((uint32_t)(DAC_CR_TSEL1 | DAC_CR_TEN1)) /*!< Conversion started by software trigger for DAC channel */ + +#endif /* STM32F051x8 || STM32F058xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +#define DAC_TRIGGER_NONE (0x00000000U) /*!< Conversion is automatic once the DAC1_DHRxxxx register + has been loaded, and not by external trigger */ +#define DAC_TRIGGER_T2_TRGO ((uint32_t)(DAC_CR_TSEL1_2 | DAC_CR_TEN1)) /*!< TIM2 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_T3_TRGO ((uint32_t)(DAC_CR_TSEL1_0 | DAC_CR_TEN1)) /*!< TIM3 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_T6_TRGO ((uint32_t)DAC_CR_TEN1) /*!< TIM6 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_T7_TRGO ((uint32_t)(DAC_CR_TSEL1_1 | DAC_CR_TEN1)) /*!< TIM7 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_T15_TRGO ((uint32_t)(DAC_CR_TSEL1_1 | DAC_CR_TSEL1_0 | DAC_CR_TEN1)) /*!< TIM15 TRGO selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_EXT_IT9 ((uint32_t)(DAC_CR_TSEL1_2 | DAC_CR_TSEL1_1 | DAC_CR_TEN1)) /*!< EXTI Line9 event selected as external conversion trigger for DAC channel */ +#define DAC_TRIGGER_SOFTWARE ((uint32_t)(DAC_CR_TSEL1 | DAC_CR_TEN1)) /*!< Conversion started by software trigger for DAC channel */ + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +/** + * @} + */ + +/** @defgroup DAC_Channel_selection DAC Channel selection + * @{ + */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +#define DAC_CHANNEL_1 (0x00000000U) +#define DAC_CHANNEL_2 (0x00000010U) + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F051x8) || defined(STM32F058xx) + +#define DAC_CHANNEL_1 (0x00000000U) + +#endif /* STM32F051x8 || STM32F058xx */ + +/** + * @} + */ + +/** + * @} + */ + +/* Private macro -------------------------------------------------------------*/ + +/** @addtogroup DACEx_Private_Macros + * @{ + */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +#define IS_DAC_TRIGGER(TRIGGER) (((TRIGGER) == DAC_TRIGGER_NONE) || \ + ((TRIGGER) == DAC_TRIGGER_T2_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T3_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T6_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T7_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T15_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_EXT_IT9) || \ + ((TRIGGER) == DAC_TRIGGER_SOFTWARE)) + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F051x8) || defined(STM32F058xx) + +#define IS_DAC_TRIGGER(TRIGGER) (((TRIGGER) == DAC_TRIGGER_NONE) || \ + ((TRIGGER) == DAC_TRIGGER_T2_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T3_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T6_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T15_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_EXT_IT9) || \ + ((TRIGGER) == DAC_TRIGGER_SOFTWARE)) + +#endif /* STM32F051x8 || STM32F058xx */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || \ + defined(STM32F091xC) || defined(STM32F098xx) + +#define IS_DAC_TRIGGER(TRIGGER) (((TRIGGER) == DAC_TRIGGER_NONE) || \ + ((TRIGGER) == DAC_TRIGGER_T2_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T3_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T6_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T7_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_T15_TRGO) || \ + ((TRIGGER) == DAC_TRIGGER_EXT_IT9) || \ + ((TRIGGER) == DAC_TRIGGER_SOFTWARE)) + +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +#define IS_DAC_LFSR_UNMASK_TRIANGLE_AMPLITUDE(VALUE) (((VALUE) == DAC_LFSRUNMASK_BIT0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS1_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS2_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS3_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS4_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS5_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS6_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS7_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS8_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS9_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS10_0) || \ + ((VALUE) == DAC_LFSRUNMASK_BITS11_0) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_1) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_3) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_7) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_15) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_31) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_63) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_127) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_255) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_511) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_1023) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_2047) || \ + ((VALUE) == DAC_TRIANGLEAMPLITUDE_4095)) + +/** + * @} + */ + +/* Exported functions --------------------------------------------------------*/ + +/** @addtogroup DACEx_Exported_Functions + * @{ + */ + +/** @addtogroup DACEx_Exported_Functions_Group1 + * @{ + */ +/* IO operation functions *****************************************************/ + +HAL_StatusTypeDef HAL_DACEx_TriangleWaveGenerate(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t Amplitude); +HAL_StatusTypeDef HAL_DACEx_NoiseWaveGenerate(DAC_HandleTypeDef* hdac, uint32_t Channel, uint32_t Amplitude); +HAL_StatusTypeDef HAL_DACEx_DualSetValue(DAC_HandleTypeDef* hdac, uint32_t Alignment, uint32_t Data1, uint32_t Data2); + +void HAL_DACEx_ConvCpltCallbackCh2(DAC_HandleTypeDef* hdac); +void HAL_DACEx_ConvHalfCpltCallbackCh2(DAC_HandleTypeDef* hdac); +void HAL_DACEx_ErrorCallbackCh2(DAC_HandleTypeDef* hdac); +void HAL_DACEx_DMAUnderrunCallbackCh2(DAC_HandleTypeDef* hdac); + +/** + * @} + */ + +/** @addtogroup DACEx_Exported_Functions_Group3 + * @{ + */ +/* Peripheral Control functions ***********************************************/ + +uint32_t HAL_DACEx_DualGetValue(DAC_HandleTypeDef* hdac); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#endif /* STM32F051x8 || STM32F058xx || */ + /* STM32F071xB || STM32F072xB || STM32F078xx || */ + /* STM32F091xC || STM32F098xx */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /*__STM32F0xx_HAL_DAC_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_def.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_def.h new file mode 100644 index 0000000..b2f6105 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_def.h @@ -0,0 +1,178 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_def.h + * @author MCD Application Team + * @brief This file contains HAL common defines, enumeration, macros and + * structures definitions. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_DEF +#define __STM32F0xx_HAL_DEF + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx.h" +#include "Legacy/stm32_hal_legacy.h" +#include + +/* Exported types ------------------------------------------------------------*/ + +/** + * @brief HAL Status structures definition + */ +typedef enum +{ + HAL_OK = 0x00U, + HAL_ERROR = 0x01U, + HAL_BUSY = 0x02U, + HAL_TIMEOUT = 0x03U +} HAL_StatusTypeDef; + +/** + * @brief HAL Lock structures definition + */ +typedef enum +{ + HAL_UNLOCKED = 0x00U, + HAL_LOCKED = 0x01U +} HAL_LockTypeDef; + +/* Exported macro ------------------------------------------------------------*/ + +#define UNUSED(X) (void)X /* To avoid gcc/g++ warnings */ + +#define HAL_MAX_DELAY 0xFFFFFFFFU + +#define HAL_IS_BIT_SET(REG, BIT) (((REG) & (BIT)) == (BIT)) +#define HAL_IS_BIT_CLR(REG, BIT) (((REG) & (BIT)) == 0U) + +#define __HAL_LINKDMA(__HANDLE__, __PPP_DMA_FIELD__, __DMA_HANDLE__) \ + do{ \ + (__HANDLE__)->__PPP_DMA_FIELD__ = &(__DMA_HANDLE__); \ + (__DMA_HANDLE__).Parent = (__HANDLE__); \ + } while(0U) + +/** @brief Reset the Handle's State field. + * @param __HANDLE__ specifies the Peripheral Handle. + * @note This macro can be used for the following purpose: + * - When the Handle is declared as local variable; before passing it as parameter + * to HAL_PPP_Init() for the first time, it is mandatory to use this macro + * to set to 0 the Handle's "State" field. + * Otherwise, "State" field may have any random value and the first time the function + * HAL_PPP_Init() is called, the low level hardware initialization will be missed + * (i.e. HAL_PPP_MspInit() will not be executed). + * - When there is a need to reconfigure the low level hardware: instead of calling + * HAL_PPP_DeInit() then HAL_PPP_Init(), user can make a call to this macro then HAL_PPP_Init(). + * In this later function, when the Handle's "State" field is set to 0, it will execute the function + * HAL_PPP_MspInit() which will reconfigure the low level hardware. + * @retval None + */ +#define __HAL_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = 0U) + +#if (USE_RTOS == 1U) + /* Reserved for future use */ + #error " USE_RTOS should be 0 in the current HAL release " +#else + #define __HAL_LOCK(__HANDLE__) \ + do{ \ + if((__HANDLE__)->Lock == HAL_LOCKED) \ + { \ + return HAL_BUSY; \ + } \ + else \ + { \ + (__HANDLE__)->Lock = HAL_LOCKED; \ + } \ + }while (0U) + + #define __HAL_UNLOCK(__HANDLE__) \ + do{ \ + (__HANDLE__)->Lock = HAL_UNLOCKED; \ + }while (0U) +#endif /* USE_RTOS */ + +#if defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) /* ARM Compiler V6 */ + #ifndef __weak + #define __weak __attribute__((weak)) + #endif + #ifndef __packed + #define __packed __attribute__((packed)) + #endif +#elif defined ( __GNUC__ ) && !defined (__CC_ARM) /* GNU Compiler */ + #ifndef __weak + #define __weak __attribute__((weak)) + #endif /* __weak */ + #ifndef __packed + #define __packed __attribute__((__packed__)) + #endif /* __packed */ +#endif /* __GNUC__ */ + + +/* Macro to get variable aligned on 4-bytes, for __ICCARM__ the directive "#pragma data_alignment=4" must be used instead */ +#if defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) /* ARM Compiler V6 */ + #ifndef __ALIGN_BEGIN + #define __ALIGN_BEGIN + #endif + #ifndef __ALIGN_END + #define __ALIGN_END __attribute__ ((aligned (4))) + #endif +#elif defined ( __GNUC__ ) && !defined (__CC_ARM) /* GNU Compiler */ + #ifndef __ALIGN_END + #define __ALIGN_END __attribute__ ((aligned (4))) + #endif /* __ALIGN_END */ + #ifndef __ALIGN_BEGIN + #define __ALIGN_BEGIN + #endif /* __ALIGN_BEGIN */ +#else + #ifndef __ALIGN_END + #define __ALIGN_END + #endif /* __ALIGN_END */ + #ifndef __ALIGN_BEGIN + #if defined (__CC_ARM) /* ARM Compiler V5*/ + #define __ALIGN_BEGIN __align(4) + #elif defined (__ICCARM__) /* IAR Compiler */ + #define __ALIGN_BEGIN + #endif /* __CC_ARM */ + #endif /* __ALIGN_BEGIN */ +#endif /* __GNUC__ */ + +/** + * @brief __NOINLINE definition + */ +#if defined ( __CC_ARM ) || (defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)) || defined ( __GNUC__ ) +/* ARM V4/V5 and V6 & GNU Compiler + ------------------------------- +*/ +#define __NOINLINE __attribute__ ( (noinline) ) + +#elif defined ( __ICCARM__ ) +/* ICCARM Compiler + --------------- +*/ +#define __NOINLINE _Pragma("optimize = no_inline") + +#endif + +#ifdef __cplusplus +} +#endif + +#endif /* ___STM32F0xx_HAL_DEF */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma.h new file mode 100644 index 0000000..db71942 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma.h @@ -0,0 +1,563 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_dma.h + * @author MCD Application Team + * @brief Header file of DMA HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_DMA_H +#define __STM32F0xx_HAL_DMA_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup DMA + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup DMA_Exported_Types DMA Exported Types + * @{ + */ + +/** + * @brief DMA Configuration Structure definition + */ +typedef struct +{ + uint32_t Direction; /*!< Specifies if the data will be transferred from memory to peripheral, + from memory to memory or from peripheral to memory. + This parameter can be a value of @ref DMA_Data_transfer_direction */ + + uint32_t PeriphInc; /*!< Specifies whether the Peripheral address register should be incremented or not. + This parameter can be a value of @ref DMA_Peripheral_incremented_mode */ + + uint32_t MemInc; /*!< Specifies whether the memory address register should be incremented or not. + This parameter can be a value of @ref DMA_Memory_incremented_mode */ + + uint32_t PeriphDataAlignment; /*!< Specifies the Peripheral data width. + This parameter can be a value of @ref DMA_Peripheral_data_size */ + + uint32_t MemDataAlignment; /*!< Specifies the Memory data width. + This parameter can be a value of @ref DMA_Memory_data_size */ + + uint32_t Mode; /*!< Specifies the operation mode of the DMAy Channelx. + This parameter can be a value of @ref DMA_mode + @note The circular buffer mode cannot be used if the memory-to-memory + data transfer is configured on the selected Channel */ + + uint32_t Priority; /*!< Specifies the software priority for the DMAy Channelx. + This parameter can be a value of @ref DMA_Priority_level */ +} DMA_InitTypeDef; + +/** + * @brief HAL DMA State structures definition + */ +typedef enum +{ + HAL_DMA_STATE_RESET = 0x00U, /*!< DMA not yet initialized or disabled */ + HAL_DMA_STATE_READY = 0x01U, /*!< DMA initialized and ready for use */ + HAL_DMA_STATE_BUSY = 0x02U, /*!< DMA process is ongoing */ + HAL_DMA_STATE_TIMEOUT = 0x03U /*!< DMA timeout state */ +}HAL_DMA_StateTypeDef; + +/** + * @brief HAL DMA Error Code structure definition + */ +typedef enum +{ + HAL_DMA_FULL_TRANSFER = 0x00U, /*!< Full transfer */ + HAL_DMA_HALF_TRANSFER = 0x01U /*!< Half Transfer */ +}HAL_DMA_LevelCompleteTypeDef; + +/** + * @brief HAL DMA Callback ID structure definition + */ +typedef enum +{ + HAL_DMA_XFER_CPLT_CB_ID = 0x00U, /*!< Full transfer */ + HAL_DMA_XFER_HALFCPLT_CB_ID = 0x01U, /*!< Half transfer */ + HAL_DMA_XFER_ERROR_CB_ID = 0x02U, /*!< Error */ + HAL_DMA_XFER_ABORT_CB_ID = 0x03U, /*!< Abort */ + HAL_DMA_XFER_ALL_CB_ID = 0x04U /*!< All */ + +}HAL_DMA_CallbackIDTypeDef; + +/** + * @brief DMA handle Structure definition + */ +typedef struct __DMA_HandleTypeDef +{ + DMA_Channel_TypeDef *Instance; /*!< Register base address */ + + DMA_InitTypeDef Init; /*!< DMA communication parameters */ + + HAL_LockTypeDef Lock; /*!< DMA locking object */ + + __IO HAL_DMA_StateTypeDef State; /*!< DMA transfer state */ + + void *Parent; /*!< Parent object state */ + + void (* XferCpltCallback)( struct __DMA_HandleTypeDef * hdma); /*!< DMA transfer complete callback */ + + void (* XferHalfCpltCallback)( struct __DMA_HandleTypeDef * hdma); /*!< DMA Half transfer complete callback */ + + void (* XferErrorCallback)( struct __DMA_HandleTypeDef * hdma); /*!< DMA transfer error callback */ + + void (* XferAbortCallback)( struct __DMA_HandleTypeDef * hdma); /*!< DMA transfer abort callback */ + + __IO uint32_t ErrorCode; /*!< DMA Error code */ + + DMA_TypeDef *DmaBaseAddress; /*!< DMA Channel Base Address */ + + uint32_t ChannelIndex; /*!< DMA Channel Index */ +} DMA_HandleTypeDef; + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ + +/** @defgroup DMA_Exported_Constants DMA Exported Constants + * @{ + */ + +/** @defgroup DMA_Error_Code DMA Error Code + * @{ + */ +#define HAL_DMA_ERROR_NONE (0x00000000U) /*!< No error */ +#define HAL_DMA_ERROR_TE (0x00000001U) /*!< Transfer error */ +#define HAL_DMA_ERROR_NO_XFER (0x00000004U) /*!< no ongoin transfer */ +#define HAL_DMA_ERROR_TIMEOUT (0x00000020U) /*!< Timeout error */ +#define HAL_DMA_ERROR_NOT_SUPPORTED (0x00000100U) /*!< Not supported mode */ +/** + * @} + */ + +/** @defgroup DMA_Data_transfer_direction DMA Data transfer direction + * @{ + */ +#define DMA_PERIPH_TO_MEMORY (0x00000000U) /*!< Peripheral to memory direction */ +#define DMA_MEMORY_TO_PERIPH ((uint32_t)DMA_CCR_DIR) /*!< Memory to peripheral direction */ +#define DMA_MEMORY_TO_MEMORY ((uint32_t)(DMA_CCR_MEM2MEM)) /*!< Memory to memory direction */ + +/** + * @} + */ + +/** @defgroup DMA_Peripheral_incremented_mode DMA Peripheral incremented mode + * @{ + */ +#define DMA_PINC_ENABLE ((uint32_t)DMA_CCR_PINC) /*!< Peripheral increment mode Enable */ +#define DMA_PINC_DISABLE (0x00000000U) /*!< Peripheral increment mode Disable */ +/** + * @} + */ + +/** @defgroup DMA_Memory_incremented_mode DMA Memory incremented mode + * @{ + */ +#define DMA_MINC_ENABLE ((uint32_t)DMA_CCR_MINC) /*!< Memory increment mode Enable */ +#define DMA_MINC_DISABLE (0x00000000U) /*!< Memory increment mode Disable */ +/** + * @} + */ + +/** @defgroup DMA_Peripheral_data_size DMA Peripheral data size + * @{ + */ +#define DMA_PDATAALIGN_BYTE (0x00000000U) /*!< Peripheral data alignment : Byte */ +#define DMA_PDATAALIGN_HALFWORD ((uint32_t)DMA_CCR_PSIZE_0) /*!< Peripheral data alignment : HalfWord */ +#define DMA_PDATAALIGN_WORD ((uint32_t)DMA_CCR_PSIZE_1) /*!< Peripheral data alignment : Word */ +/** + * @} + */ + +/** @defgroup DMA_Memory_data_size DMA Memory data size + * @{ + */ +#define DMA_MDATAALIGN_BYTE (0x00000000U) /*!< Memory data alignment : Byte */ +#define DMA_MDATAALIGN_HALFWORD ((uint32_t)DMA_CCR_MSIZE_0) /*!< Memory data alignment : HalfWord */ +#define DMA_MDATAALIGN_WORD ((uint32_t)DMA_CCR_MSIZE_1) /*!< Memory data alignment : Word */ +/** + * @} + */ + +/** @defgroup DMA_mode DMA mode + * @{ + */ +#define DMA_NORMAL (0x00000000U) /*!< Normal Mode */ +#define DMA_CIRCULAR ((uint32_t)DMA_CCR_CIRC) /*!< Circular Mode */ +/** + * @} + */ + +/** @defgroup DMA_Priority_level DMA Priority level + * @{ + */ +#define DMA_PRIORITY_LOW (0x00000000U) /*!< Priority level : Low */ +#define DMA_PRIORITY_MEDIUM ((uint32_t)DMA_CCR_PL_0) /*!< Priority level : Medium */ +#define DMA_PRIORITY_HIGH ((uint32_t)DMA_CCR_PL_1) /*!< Priority level : High */ +#define DMA_PRIORITY_VERY_HIGH ((uint32_t)DMA_CCR_PL) /*!< Priority level : Very_High */ +/** + * @} + */ + + +/** @defgroup DMA_interrupt_enable_definitions DMA interrupt enable definitions + * @{ + */ +#define DMA_IT_TC ((uint32_t)DMA_CCR_TCIE) +#define DMA_IT_HT ((uint32_t)DMA_CCR_HTIE) +#define DMA_IT_TE ((uint32_t)DMA_CCR_TEIE) +/** + * @} + */ + +/** @defgroup DMA_flag_definitions DMA flag definitions + * @{ + */ + +#define DMA_FLAG_GL1 (0x00000001U) /*!< Channel 1 global interrupt flag */ +#define DMA_FLAG_TC1 (0x00000002U) /*!< Channel 1 transfer complete flag */ +#define DMA_FLAG_HT1 (0x00000004U) /*!< Channel 1 half transfer flag */ +#define DMA_FLAG_TE1 (0x00000008U) /*!< Channel 1 transfer error flag */ +#define DMA_FLAG_GL2 (0x00000010U) /*!< Channel 2 global interrupt flag */ +#define DMA_FLAG_TC2 (0x00000020U) /*!< Channel 2 transfer complete flag */ +#define DMA_FLAG_HT2 (0x00000040U) /*!< Channel 2 half transfer flag */ +#define DMA_FLAG_TE2 (0x00000080U) /*!< Channel 2 transfer error flag */ +#define DMA_FLAG_GL3 (0x00000100U) /*!< Channel 3 global interrupt flag */ +#define DMA_FLAG_TC3 (0x00000200U) /*!< Channel 3 transfer complete flag */ +#define DMA_FLAG_HT3 (0x00000400U) /*!< Channel 3 half transfer flag */ +#define DMA_FLAG_TE3 (0x00000800U) /*!< Channel 3 transfer error flag */ +#define DMA_FLAG_GL4 (0x00001000U) /*!< Channel 4 global interrupt flag */ +#define DMA_FLAG_TC4 (0x00002000U) /*!< Channel 4 transfer complete flag */ +#define DMA_FLAG_HT4 (0x00004000U) /*!< Channel 4 half transfer flag */ +#define DMA_FLAG_TE4 (0x00008000U) /*!< Channel 4 transfer error flag */ +#define DMA_FLAG_GL5 (0x00010000U) /*!< Channel 5 global interrupt flag */ +#define DMA_FLAG_TC5 (0x00020000U) /*!< Channel 5 transfer complete flag */ +#define DMA_FLAG_HT5 (0x00040000U) /*!< Channel 5 half transfer flag */ +#define DMA_FLAG_TE5 (0x00080000U) /*!< Channel 5 transfer error flag */ +#define DMA_FLAG_GL6 (0x00100000U) /*!< Channel 6 global interrupt flag */ +#define DMA_FLAG_TC6 (0x00200000U) /*!< Channel 6 transfer complete flag */ +#define DMA_FLAG_HT6 (0x00400000U) /*!< Channel 6 half transfer flag */ +#define DMA_FLAG_TE6 (0x00800000U) /*!< Channel 6 transfer error flag */ +#define DMA_FLAG_GL7 (0x01000000U) /*!< Channel 7 global interrupt flag */ +#define DMA_FLAG_TC7 (0x02000000U) /*!< Channel 7 transfer complete flag */ +#define DMA_FLAG_HT7 (0x04000000U) /*!< Channel 7 half transfer flag */ +#define DMA_FLAG_TE7 (0x08000000U) /*!< Channel 7 transfer error flag */ + +/** + * @} + */ + +#if defined(SYSCFG_CFGR1_DMA_RMP) +/** @defgroup HAL_DMA_remapping HAL DMA remapping + * Elements values convention: 0xYYYYYYYY + * - YYYYYYYY : Position in the SYSCFG register CFGR1 + * @{ + */ +#define DMA_REMAP_ADC_DMA_CH2 ((uint32_t)SYSCFG_CFGR1_ADC_DMA_RMP) /*!< ADC DMA remap + 0: No remap (ADC DMA requests mapped on DMA channel 1 + 1: Remap (ADC DMA requests mapped on DMA channel 2 */ +#define DMA_REMAP_USART1_TX_DMA_CH4 ((uint32_t)SYSCFG_CFGR1_USART1TX_DMA_RMP) /*!< USART1 TX DMA remap + 0: No remap (USART1_TX DMA request mapped on DMA channel 2 + 1: Remap (USART1_TX DMA request mapped on DMA channel 4 */ +#define DMA_REMAP_USART1_RX_DMA_CH5 ((uint32_t)SYSCFG_CFGR1_USART1RX_DMA_RMP) /*!< USART1 RX DMA remap + 0: No remap (USART1_RX DMA request mapped on DMA channel 3 + 1: Remap (USART1_RX DMA request mapped on DMA channel 5 */ +#define DMA_REMAP_TIM16_DMA_CH4 ((uint32_t)SYSCFG_CFGR1_TIM16_DMA_RMP) /*!< TIM16 DMA request remap + 0: No remap (TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 3) + 1: Remap (TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 4) */ +#define DMA_REMAP_TIM17_DMA_CH2 ((uint32_t)SYSCFG_CFGR1_TIM17_DMA_RMP) /*!< TIM17 DMA request remap + 0: No remap (TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 1 + 1: Remap (TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 2) */ +#if defined (STM32F070xB) +#define DMA_REMAP_USART3_DMA_CH32 ((uint32_t)SYSCFG_CFGR1_USART3_DMA_RMP) /*!< USART3 DMA request remapping bit. Available on STM32F070xB devices only. + 0: Disabled, need to remap before use + 1: Remap (USART3_RX and USART3_TX DMA requests mapped on DMA channel 3 and 2 respectively) */ + +#endif + +#if defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) +#define DMA_REMAP_TIM16_DMA_CH6 ((uint32_t)SYSCFG_CFGR1_TIM16_DMA_RMP2) /*!< TIM16 alternate DMA request remapping bit. Available on STM32F07x devices only + 0: No alternate remap (TIM16 DMA requestsmapped according to TIM16_DMA_RMP bit) + 1: Alternate remap (TIM16_CH1 and TIM16_UP DMA requests mapped on DMA channel 6) */ +#define DMA_REMAP_TIM17_DMA_CH7 ((uint32_t)SYSCFG_CFGR1_TIM17_DMA_RMP2) /*!< TIM17 alternate DMA request remapping bit. Available on STM32F07x devices only + 0: No alternate remap (TIM17 DMA requestsmapped according to TIM17_DMA_RMP bit) + 1: Alternate remap (TIM17_CH1 and TIM17_UP DMA requests mapped on DMA channel 7) */ +#define DMA_REMAP_SPI2_DMA_CH67 ((uint32_t)SYSCFG_CFGR1_SPI2_DMA_RMP) /*!< SPI2 DMA request remapping bit. Available on STM32F07x devices only. + 0: No remap (SPI2_RX and SPI2_TX DMA requests mapped on DMA channel 4 and 5 respectively) + 1: Remap (SPI2_RX and SPI2_TX DMA requests mapped on DMA channel 6 and 7 respectively) */ +#define DMA_REMAP_USART2_DMA_CH67 ((uint32_t)SYSCFG_CFGR1_USART2_DMA_RMP) /*!< USART2 DMA request remapping bit. Available on STM32F07x devices only. + 0: No remap (USART2_RX and USART2_TX DMA requests mapped on DMA channel 5 and 4 respectively) + 1: 1: Remap (USART2_RX and USART2_TX DMA requests mapped on DMA channel 6 and 7 respectively) */ +#define DMA_REMAP_USART3_DMA_CH32 ((uint32_t)SYSCFG_CFGR1_USART3_DMA_RMP) /*!< USART3 DMA request remapping bit. Available on STM32F07x devices only. + 0: No remap (USART3_RX and USART3_TX DMA requests mapped on DMA channel 6 and 7 respectively) + 1: Remap (USART3_RX and USART3_TX DMA requests mapped on DMA channel 3 and 2 respectively) */ +#define DMA_REMAP_I2C1_DMA_CH76 ((uint32_t)SYSCFG_CFGR1_I2C1_DMA_RMP) /*!< I2C1 DMA request remapping bit. Available on STM32F07x devices only. + 0: No remap (I2C1_RX and I2C1_TX DMA requests mapped on DMA channel 3 and 2 respectively) + 1: Remap (I2C1_RX and I2C1_TX DMA requests mapped on DMA channel 7 and 6 respectively) */ +#define DMA_REMAP_TIM1_DMA_CH6 ((uint32_t)SYSCFG_CFGR1_TIM1_DMA_RMP) /*!< TIM1 DMA request remapping bit. Available on STM32F07x devices only. + 0: No remap (TIM1_CH1, TIM1_CH2 and TIM1_CH3 DMA requests mapped on DMA channel 2, 3 and 4 respectively) + 1: Remap (TIM1_CH1, TIM1_CH2 and TIM1_CH3 DMA requests mapped on DMA channel 6 */ +#define DMA_REMAP_TIM2_DMA_CH7 ((uint32_t)SYSCFG_CFGR1_TIM2_DMA_RMP) /*!< TIM2 DMA request remapping bit. Available on STM32F07x devices only. + 0: No remap (TIM2_CH2 and TIM2_CH4 DMA requests mapped on DMA channel 3 and 4 respectively) + 1: Remap (TIM2_CH2 and TIM2_CH4 DMA requests mapped on DMA channel 7 */ +#define DMA_REMAP_TIM3_DMA_CH6 ((uint32_t)SYSCFG_CFGR1_TIM3_DMA_RMP) /*!< TIM3 DMA request remapping bit. Available on STM32F07x devices only. + 0: No remap (TIM3_CH1 and TIM3_TRIG DMA requests mapped on DMA channel 4) + 1: Remap (TIM3_CH1 and TIM3_TRIG DMA requests mapped on DMA channel 6) */ +#endif + +/** + * @} + */ + +#endif /* SYSCFG_CFGR1_DMA_RMP */ +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup DMA_Exported_Macros DMA Exported Macros + * @{ + */ + +/** @brief Reset DMA handle state + * @param __HANDLE__ DMA handle. + * @retval None + */ +#define __HAL_DMA_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_DMA_STATE_RESET) + +/** + * @brief Enable the specified DMA Channel. + * @param __HANDLE__ DMA handle + * @retval None + */ +#define __HAL_DMA_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CCR |= DMA_CCR_EN) + +/** + * @brief Disable the specified DMA Channel. + * @param __HANDLE__ DMA handle + * @retval None + */ +#define __HAL_DMA_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CCR &= ~DMA_CCR_EN) + + +/* Interrupt & Flag management */ + +/** + * @brief Enables the specified DMA Channel interrupts. + * @param __HANDLE__ DMA handle + * @param __INTERRUPT__ specifies the DMA interrupt sources to be enabled or disabled. + * This parameter can be any combination of the following values: + * @arg DMA_IT_TC: Transfer complete interrupt mask + * @arg DMA_IT_HT: Half transfer complete interrupt mask + * @arg DMA_IT_TE: Transfer error interrupt mask + * @retval None + */ +#define __HAL_DMA_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CCR |= (__INTERRUPT__)) + +/** + * @brief Disables the specified DMA Channel interrupts. + * @param __HANDLE__ DMA handle + * @param __INTERRUPT__ specifies the DMA interrupt sources to be enabled or disabled. + * This parameter can be any combination of the following values: + * @arg DMA_IT_TC: Transfer complete interrupt mask + * @arg DMA_IT_HT: Half transfer complete interrupt mask + * @arg DMA_IT_TE: Transfer error interrupt mask + * @retval None + */ +#define __HAL_DMA_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->CCR &= ~(__INTERRUPT__)) + +/** + * @brief Checks whether the specified DMA Channel interrupt is enabled or disabled. + * @param __HANDLE__ DMA handle + * @param __INTERRUPT__ specifies the DMA interrupt source to check. + * This parameter can be one of the following values: + * @arg DMA_IT_TC: Transfer complete interrupt mask + * @arg DMA_IT_HT: Half transfer complete interrupt mask + * @arg DMA_IT_TE: Transfer error interrupt mask + * @retval The state of DMA_IT (SET or RESET). + */ +#define __HAL_DMA_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->CCR & (__INTERRUPT__))) + +/** + * @brief Returns the number of remaining data units in the current DMAy Channelx transfer. + * @param __HANDLE__ DMA handle + * + * @retval The number of remaining data units in the current DMA Channel transfer. + */ +#define __HAL_DMA_GET_COUNTER(__HANDLE__) ((__HANDLE__)->Instance->CNDTR) + +#if defined(SYSCFG_CFGR1_DMA_RMP) +/** @brief DMA remapping enable/disable macros + * @param __DMA_REMAP__ This parameter can be a value of @ref HAL_DMA_remapping + */ +#define __HAL_DMA_REMAP_CHANNEL_ENABLE(__DMA_REMAP__) do {assert_param(IS_DMA_REMAP((__DMA_REMAP__))); \ + SYSCFG->CFGR1 |= (__DMA_REMAP__); \ + }while(0) +#define __HAL_DMA_REMAP_CHANNEL_DISABLE(__DMA_REMAP__) do {assert_param(IS_DMA_REMAP((__DMA_REMAP__))); \ + SYSCFG->CFGR1 &= ~(__DMA_REMAP__); \ + }while(0) +#endif /* SYSCFG_CFGR1_DMA_RMP */ + +/** + * @} + */ + +/* Include DMA HAL Extension module */ +#include "stm32f0xx_hal_dma_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup DMA_Exported_Functions + * @{ + */ + +/** @addtogroup DMA_Exported_Functions_Group1 + * @{ + */ +/* Initialization and de-initialization functions *****************************/ +HAL_StatusTypeDef HAL_DMA_Init(DMA_HandleTypeDef *hdma); +HAL_StatusTypeDef HAL_DMA_DeInit (DMA_HandleTypeDef *hdma); +/** + * @} + */ + +/** @addtogroup DMA_Exported_Functions_Group2 + * @{ + */ +/* Input and Output operation functions *****************************************************/ +HAL_StatusTypeDef HAL_DMA_Start (DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength); +HAL_StatusTypeDef HAL_DMA_Start_IT(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength); +HAL_StatusTypeDef HAL_DMA_Abort(DMA_HandleTypeDef *hdma); +HAL_StatusTypeDef HAL_DMA_Abort_IT(DMA_HandleTypeDef *hdma); +HAL_StatusTypeDef HAL_DMA_PollForTransfer(DMA_HandleTypeDef *hdma, uint32_t CompleteLevel, uint32_t Timeout); +void HAL_DMA_IRQHandler(DMA_HandleTypeDef *hdma); +HAL_StatusTypeDef HAL_DMA_RegisterCallback(DMA_HandleTypeDef *hdma, HAL_DMA_CallbackIDTypeDef CallbackID, void (* pCallback)( DMA_HandleTypeDef * _hdma)); +HAL_StatusTypeDef HAL_DMA_UnRegisterCallback(DMA_HandleTypeDef *hdma, HAL_DMA_CallbackIDTypeDef CallbackID); + +/** + * @} + */ + +/** @addtogroup DMA_Exported_Functions_Group3 + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +HAL_DMA_StateTypeDef HAL_DMA_GetState(DMA_HandleTypeDef *hdma); +uint32_t HAL_DMA_GetError(DMA_HandleTypeDef *hdma); +/** + * @} + */ + +/** + * @} + */ + +/** @addtogroup DMA_Private_Macros + * @{ + */ +#define IS_DMA_DIRECTION(DIRECTION) (((DIRECTION) == DMA_PERIPH_TO_MEMORY ) || \ + ((DIRECTION) == DMA_MEMORY_TO_PERIPH) || \ + ((DIRECTION) == DMA_MEMORY_TO_MEMORY)) +#define IS_DMA_PERIPHERAL_INC_STATE(STATE) (((STATE) == DMA_PINC_ENABLE) || \ + ((STATE) == DMA_PINC_DISABLE)) + +#define IS_DMA_MEMORY_INC_STATE(STATE) (((STATE) == DMA_MINC_ENABLE) || \ + ((STATE) == DMA_MINC_DISABLE)) + +#define IS_DMA_PERIPHERAL_DATA_SIZE(SIZE) (((SIZE) == DMA_PDATAALIGN_BYTE) || \ + ((SIZE) == DMA_PDATAALIGN_HALFWORD) || \ + ((SIZE) == DMA_PDATAALIGN_WORD)) + +#define IS_DMA_MEMORY_DATA_SIZE(SIZE) (((SIZE) == DMA_MDATAALIGN_BYTE) || \ + ((SIZE) == DMA_MDATAALIGN_HALFWORD) || \ + ((SIZE) == DMA_MDATAALIGN_WORD )) + +#define IS_DMA_MODE(MODE) (((MODE) == DMA_NORMAL ) || \ + ((MODE) == DMA_CIRCULAR)) +#define IS_DMA_PRIORITY(PRIORITY) (((PRIORITY) == DMA_PRIORITY_LOW ) || \ + ((PRIORITY) == DMA_PRIORITY_MEDIUM) || \ + ((PRIORITY) == DMA_PRIORITY_HIGH) || \ + ((PRIORITY) == DMA_PRIORITY_VERY_HIGH)) +#define IS_DMA_BUFFER_SIZE(SIZE) (((SIZE) >= 0x1U) && ((SIZE) < 0x10000U)) + +#if defined(SYSCFG_CFGR1_DMA_RMP) + +#if defined (STM32F071xB) || defined (STM32F072xB) || defined (STM32F078xx) +#define IS_DMA_REMAP(RMP) (((RMP) == DMA_REMAP_ADC_DMA_CH2) || \ + ((RMP) == DMA_REMAP_USART1_TX_DMA_CH4) || \ + ((RMP) == DMA_REMAP_USART1_RX_DMA_CH5) || \ + ((RMP) == DMA_REMAP_TIM16_DMA_CH4) || \ + ((RMP) == DMA_REMAP_TIM17_DMA_CH2) || \ + ((RMP) == DMA_REMAP_TIM16_DMA_CH6) || \ + ((RMP) == DMA_REMAP_TIM17_DMA_CH7) || \ + ((RMP) == DMA_REMAP_SPI2_DMA_CH67) || \ + ((RMP) == DMA_REMAP_USART2_DMA_CH67) || \ + ((RMP) == DMA_REMAP_USART3_DMA_CH32) || \ + ((RMP) == DMA_REMAP_I2C1_DMA_CH76) || \ + ((RMP) == DMA_REMAP_TIM1_DMA_CH6) || \ + ((RMP) == DMA_REMAP_TIM2_DMA_CH7) || \ + ((RMP) == DMA_REMAP_TIM3_DMA_CH6)) +#elif defined (STM32F070xB) +#define IS_DMA_REMAP(RMP) (((RMP) == DMA_REMAP_USART3_DMA_CH32) || \ + ((RMP) == DMA_REMAP_ADC_DMA_CH2) || \ + ((RMP) == DMA_REMAP_USART1_TX_DMA_CH4) || \ + ((RMP) == DMA_REMAP_USART1_RX_DMA_CH5) || \ + ((RMP) == DMA_REMAP_TIM16_DMA_CH4) || \ + ((RMP) == DMA_REMAP_TIM17_DMA_CH2)) +#else +#define IS_DMA_REMAP(RMP) (((RMP) == DMA_REMAP_ADC_DMA_CH2) || \ + ((RMP) == DMA_REMAP_USART1_TX_DMA_CH4) || \ + ((RMP) == DMA_REMAP_USART1_RX_DMA_CH5) || \ + ((RMP) == DMA_REMAP_TIM16_DMA_CH4) || \ + ((RMP) == DMA_REMAP_TIM17_DMA_CH2)) +#endif + +#endif /* SYSCFG_CFGR1_DMA_RMP */ + + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_DMA_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma_ex.h new file mode 100644 index 0000000..185f833 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_dma_ex.h @@ -0,0 +1,811 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_dma_ex.h + * @author MCD Application Team + * @brief Header file of DMA HAL Extension module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_DMA_EX_H +#define __STM32F0xx_HAL_DMA_EX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup DMAEx DMAEx + * @brief DMA HAL module driver + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ +/* Exported constants --------------------------------------------------------*/ +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) +/** @defgroup DMAEx_Exported_Constants DMAEx Exported Constants + * @{ + */ +#define DMA1_CHANNEL1_RMP 0x00000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA1_CHANNEL2_RMP 0x10000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA1_CHANNEL3_RMP 0x20000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA1_CHANNEL4_RMP 0x30000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA1_CHANNEL5_RMP 0x40000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#if !defined(STM32F030xC) +#define DMA1_CHANNEL6_RMP 0x50000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA1_CHANNEL7_RMP 0x60000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA2_CHANNEL1_RMP 0x00000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA2_CHANNEL2_RMP 0x10000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA2_CHANNEL3_RMP 0x20000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA2_CHANNEL4_RMP 0x30000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#define DMA2_CHANNEL5_RMP 0x40000000 /*!< Internal define for remaping on STM32F09x/30xC */ +#endif /* !defined(STM32F030xC) */ + +/****************** DMA1 remap bit field definition********************/ +/* DMA1 - Channel 1 */ +#define HAL_DMA1_CH1_DEFAULT (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */ +#define HAL_DMA1_CH1_ADC (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_ADC) /*!< Remap ADC on DMA1 Channel 1*/ +#define HAL_DMA1_CH1_TIM17_CH1 (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_TIM17_CH1) /*!< Remap TIM17 channel 1 on DMA1 channel 1 */ +#define HAL_DMA1_CH1_TIM17_UP (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_TIM17_UP) /*!< Remap TIM17 up on DMA1 channel 1 */ +#define HAL_DMA1_CH1_USART1_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 1 */ +#define HAL_DMA1_CH1_USART2_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 1 */ +#define HAL_DMA1_CH1_USART3_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 1 */ +#define HAL_DMA1_CH1_USART4_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 1 */ +#define HAL_DMA1_CH1_USART5_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 1 */ +#define HAL_DMA1_CH1_USART6_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 1 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH1_USART7_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 1 */ +#define HAL_DMA1_CH1_USART8_RX (uint32_t) (DMA1_CHANNEL1_RMP | DMA1_CSELR_CH1_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 1 */ +#endif /* !defined(STM32F030xC) */ + +/* DMA1 - Channel 2 */ +#define HAL_DMA1_CH2_DEFAULT (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */ +#define HAL_DMA1_CH2_ADC (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_ADC) /*!< Remap ADC on DMA1 channel 2 */ +#define HAL_DMA1_CH2_I2C1_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_I2C1_TX) /*!< Remap I2C1 Tx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_SPI1_RX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_SPI1_RX) /*!< Remap SPI1 Rx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_TIM1_CH1 (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_TIM1_CH1) /*!< Remap TIM1 channel 1 on DMA1 channel 2 */ +#define HAL_DMA1_CH2_TIM17_CH1 (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_TIM17_CH1) /*!< Remap TIM17 channel 1 on DMA1 channel 2 */ +#define HAL_DMA1_CH2_TIM17_UP (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_TIM17_UP) /*!< Remap TIM17 up on DMA1 channel 2 */ +#define HAL_DMA1_CH2_USART1_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART1_TX) /*!< Remap USART1 Tx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_USART2_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART2_TX) /*!< Remap USART2 Tx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_USART3_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART3_TX) /*!< Remap USART3 Tx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_USART4_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART4_TX) /*!< Remap USART4 Tx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_USART5_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART5_TX) /*!< Remap USART5 Tx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_USART6_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART6_TX) /*!< Remap USART6 Tx on DMA1 channel 2 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH2_USART7_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART7_TX) /*!< Remap USART7 Tx on DMA1 channel 2 */ +#define HAL_DMA1_CH2_USART8_TX (uint32_t) (DMA1_CHANNEL2_RMP | DMA1_CSELR_CH2_USART8_TX) /*!< Remap USART8 Tx on DMA1 channel 2 */ +#endif /* !defined(STM32F030xC) */ + +/* DMA1 - Channel 3 */ +#define HAL_DMA1_CH3_DEFAULT (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */ +#define HAL_DMA1_CH3_TIM6_UP (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM6_UP) /*!< Remap TIM6 up on DMA1 channel 3 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH3_DAC_CH1 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_DAC_CH1) /*!< Remap DAC Channel 1on DMA1 channel 3 */ +#endif /* !defined(STM32F030xC) */ +#define HAL_DMA1_CH3_I2C1_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_I2C1_RX) /*!< Remap I2C1 Rx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_SPI1_TX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_SPI1_TX) /*!< Remap SPI1 Tx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_TIM1_CH2 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM1_CH2) /*!< Remap TIM1 channel 2 on DMA1 channel 3 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH3_TIM2_CH2 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM2_CH2) /*!< Remap TIM2 channel 2 on DMA1 channel 3 */ +#endif /* !defined(STM32F030xC) */ +#define HAL_DMA1_CH3_TIM16_CH1 (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM16_CH1) /*!< Remap TIM16 channel 1 on DMA1 channel 3 */ +#define HAL_DMA1_CH3_TIM16_UP (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_TIM16_UP) /*!< Remap TIM16 up on DMA1 channel 3 */ +#define HAL_DMA1_CH3_USART1_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_USART2_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_USART3_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_USART4_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_USART5_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_USART6_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 3 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH3_USART7_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 3 */ +#define HAL_DMA1_CH3_USART8_RX (uint32_t) (DMA1_CHANNEL3_RMP | DMA1_CSELR_CH3_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 3 */ +#endif /* !defined(STM32F030xC) */ + +/* DMA1 - Channel 4 */ +#define HAL_DMA1_CH4_DEFAULT (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */ +#define HAL_DMA1_CH4_TIM7_UP (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM7_UP) /*!< Remap TIM7 up on DMA1 channel 4 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH4_DAC_CH2 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_DAC_CH2) /*!< Remap DAC Channel 2 on DMA1 channel 4 */ +#endif /* !defined(STM32F030xC) */ +#define HAL_DMA1_CH4_I2C2_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_I2C2_TX) /*!< Remap I2C2 Tx on DMA1 channel 4 */ +#define HAL_DMA1_CH4_SPI2_RX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_SPI2_RX) /*!< Remap SPI2 Rx on DMA1 channel 4 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH4_TIM2_CH4 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM2_CH4) /*!< Remap TIM2 channel 4 on DMA1 channel 4 */ +#endif /* !defined(STM32F030xC) */ +#define HAL_DMA1_CH4_TIM3_CH1 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM3_CH1) /*!< Remap TIM3 channel 1 on DMA1 channel 4 */ +#define HAL_DMA1_CH4_TIM3_TRIG (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM3_TRIG) /*!< Remap TIM3 Trig on DMA1 channel 4 */ +#define HAL_DMA1_CH4_TIM16_CH1 (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM16_CH1) /*!< Remap TIM16 channel 1 on DMA1 channel 4 */ +#define HAL_DMA1_CH4_TIM16_UP (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_TIM16_UP) /*!< Remap TIM16 up on DMA1 channel 4 */ +#define HAL_DMA1_CH4_USART1_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART1_TX) /*!< Remap USART1 Tx on DMA1 channel 4 */ +#define HAL_DMA1_CH4_USART2_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART2_TX) /*!< Remap USART2 Tx on DMA1 channel 4 */ +#define HAL_DMA1_CH4_USART3_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART3_TX) /*!< Remap USART3 Tx on DMA1 channel 4 */ +#define HAL_DMA1_CH4_USART4_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART4_TX) /*!< Remap USART4 Tx on DMA1 channel 4 */ +#define HAL_DMA1_CH4_USART5_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART5_TX) /*!< Remap USART5 Tx on DMA1 channel 4 */ +#define HAL_DMA1_CH4_USART6_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART6_TX) /*!< Remap USART6 Tx on DMA1 channel 4 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH4_USART7_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART7_TX) /*!< Remap USART7 Tx on DMA1 channel 4 */ +#define HAL_DMA1_CH4_USART8_TX (uint32_t) (DMA1_CHANNEL4_RMP | DMA1_CSELR_CH4_USART8_TX) /*!< Remap USART8 Tx on DMA1 channel 4 */ +#endif /* !defined(STM32F030xC) */ + +/* DMA1 - Channel 5 */ +#define HAL_DMA1_CH5_DEFAULT (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */ +#define HAL_DMA1_CH5_I2C2_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_I2C2_RX) /*!< Remap I2C2 Rx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_SPI2_TX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_SPI2_TX) /*!< Remap SPI1 Tx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_TIM1_CH3 (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_TIM1_CH3) /*!< Remap TIM1 channel 3 on DMA1 channel 5 */ +#define HAL_DMA1_CH5_USART1_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_USART2_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_USART3_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_USART4_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_USART5_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_USART6_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 5 */ +#if !defined(STM32F030xC) +#define HAL_DMA1_CH5_USART7_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 5 */ +#define HAL_DMA1_CH5_USART8_RX (uint32_t) (DMA1_CHANNEL5_RMP | DMA1_CSELR_CH5_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 5 */ +#endif /* !defined(STM32F030xC) */ + +#if !defined(STM32F030xC) +/* DMA1 - Channel 6 */ +#define HAL_DMA1_CH6_DEFAULT (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */ +#define HAL_DMA1_CH6_I2C1_TX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_I2C1_TX) /*!< Remap I2C1 Tx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_SPI2_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_SPI2_RX) /*!< Remap SPI2 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_TIM1_CH1 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM1_CH1) /*!< Remap TIM1 channel 1 on DMA1 channel 6 */ +#define HAL_DMA1_CH6_TIM1_CH2 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM1_CH2) /*!< Remap TIM1 channel 2 on DMA1 channel 6 */ +#define HAL_DMA1_CH6_TIM1_CH3 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM1_CH3) /*!< Remap TIM1 channel 3 on DMA1 channel 6 */ +#define HAL_DMA1_CH6_TIM3_CH1 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM3_CH1) /*!< Remap TIM3 channel 1 on DMA1 channel 6 */ +#define HAL_DMA1_CH6_TIM3_TRIG (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM3_TRIG) /*!< Remap TIM3 Trig on DMA1 channel 6 */ +#define HAL_DMA1_CH6_TIM16_CH1 (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM16_CH1) /*!< Remap TIM16 channel 1 on DMA1 channel 6 */ +#define HAL_DMA1_CH6_TIM16_UP (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_TIM16_UP) /*!< Remap TIM16 up on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART1_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART1_RX) /*!< Remap USART1 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART2_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART2_RX) /*!< Remap USART2 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART3_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART3_RX) /*!< Remap USART3 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART4_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART4_RX) /*!< Remap USART4 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART5_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART5_RX) /*!< Remap USART5 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART6_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART6_RX) /*!< Remap USART6 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART7_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART7_RX) /*!< Remap USART7 Rx on DMA1 channel 6 */ +#define HAL_DMA1_CH6_USART8_RX (uint32_t) (DMA1_CHANNEL6_RMP | DMA1_CSELR_CH6_USART8_RX) /*!< Remap USART8 Rx on DMA1 channel 6 */ +/* DMA1 - Channel 7 */ +#define HAL_DMA1_CH7_DEFAULT (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_DEFAULT) /*!< Default remap position for DMA1 */ +#define HAL_DMA1_CH7_I2C1_RX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_I2C1_RX) /*!< Remap I2C1 Rx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_SPI2_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_SPI2_TX) /*!< Remap SPI2 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_TIM2_CH2 (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM2_CH2) /*!< Remap TIM2 channel 2 on DMA1 channel 7 */ +#define HAL_DMA1_CH7_TIM2_CH4 (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM2_CH4) /*!< Remap TIM2 channel 4 on DMA1 channel 7 */ +#define HAL_DMA1_CH7_TIM17_CH1 (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM17_CH1) /*!< Remap TIM17 channel 1 on DMA1 channel 7 */ +#define HAL_DMA1_CH7_TIM17_UP (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_TIM17_UP) /*!< Remap TIM17 up on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART1_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART1_TX) /*!< Remap USART1 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART2_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART2_TX) /*!< Remap USART2 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART3_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART3_TX) /*!< Remap USART3 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART4_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART4_TX) /*!< Remap USART4 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART5_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART5_TX) /*!< Remap USART5 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART6_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART6_TX) /*!< Remap USART6 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART7_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART7_TX) /*!< Remap USART7 Tx on DMA1 channel 7 */ +#define HAL_DMA1_CH7_USART8_TX (uint32_t) (DMA1_CHANNEL7_RMP | DMA1_CSELR_CH7_USART8_TX) /*!< Remap USART8 Tx on DMA1 channel 7 */ + +/****************** DMA2 remap bit field definition********************/ +/* DMA2 - Channel 1 */ +#define HAL_DMA2_CH1_DEFAULT (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */ +#define HAL_DMA2_CH1_I2C2_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_I2C2_TX) /*!< Remap I2C2 TX on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART1_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART1_TX) /*!< Remap USART1 Tx on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART2_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART2_TX) /*!< Remap USART2 Tx on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART3_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART3_TX) /*!< Remap USART3 Tx on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART4_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART4_TX) /*!< Remap USART4 Tx on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART5_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART5_TX) /*!< Remap USART5 Tx on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART6_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART6_TX) /*!< Remap USART6 Tx on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART7_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART7_TX) /*!< Remap USART7 Tx on DMA2 channel 1 */ +#define HAL_DMA2_CH1_USART8_TX (uint32_t) (DMA2_CHANNEL1_RMP | DMA2_CSELR_CH1_USART8_TX) /*!< Remap USART8 Tx on DMA2 channel 1 */ +/* DMA2 - Channel 2 */ +#define HAL_DMA2_CH2_DEFAULT (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */ +#define HAL_DMA2_CH2_I2C2_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_I2C2_RX) /*!< Remap I2C2 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART1_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART1_RX) /*!< Remap USART1 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART2_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART2_RX) /*!< Remap USART2 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART3_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART3_RX) /*!< Remap USART3 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART4_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART4_RX) /*!< Remap USART4 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART5_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART5_RX) /*!< Remap USART5 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART6_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART6_RX) /*!< Remap USART6 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART7_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART7_RX) /*!< Remap USART7 Rx on DMA2 channel 2 */ +#define HAL_DMA2_CH2_USART8_RX (uint32_t) (DMA2_CHANNEL2_RMP | DMA2_CSELR_CH2_USART8_RX) /*!< Remap USART8 Rx on DMA2 channel 2 */ +/* DMA2 - Channel 3 */ +#define HAL_DMA2_CH3_DEFAULT (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */ +#define HAL_DMA2_CH3_TIM6_UP (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_TIM6_UP) /*!< Remap TIM6 up on DMA2 channel 3 */ +#define HAL_DMA2_CH3_DAC_CH1 (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_DAC_CH1) /*!< Remap DAC channel 1 on DMA2 channel 3 */ +#define HAL_DMA2_CH3_SPI1_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_SPI1_RX) /*!< Remap SPI1 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART1_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART1_RX) /*!< Remap USART1 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART2_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART2_RX) /*!< Remap USART2 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART3_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART3_RX) /*!< Remap USART3 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART4_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART4_RX) /*!< Remap USART4 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART5_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART5_RX) /*!< Remap USART5 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART6_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART6_RX) /*!< Remap USART6 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART7_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART7_RX) /*!< Remap USART7 Rx on DMA2 channel 3 */ +#define HAL_DMA2_CH3_USART8_RX (uint32_t) (DMA2_CHANNEL3_RMP | DMA2_CSELR_CH3_USART8_RX) /*!< Remap USART8 Rx on DMA2 channel 3 */ +/* DMA2 - Channel 4 */ +#define HAL_DMA2_CH4_DEFAULT (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */ +#define HAL_DMA2_CH4_TIM7_UP (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_TIM7_UP) /*!< Remap TIM7 up on DMA2 channel 4 */ +#define HAL_DMA2_CH4_DAC_CH2 (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_DAC_CH2) /*!< Remap DAC channel 2 on DMA2 channel 4 */ +#define HAL_DMA2_CH4_SPI1_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_SPI1_TX) /*!< Remap SPI1 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART1_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART1_TX) /*!< Remap USART1 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART2_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART2_TX) /*!< Remap USART2 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART3_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART3_TX) /*!< Remap USART3 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART4_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART4_TX) /*!< Remap USART4 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART5_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART5_TX) /*!< Remap USART5 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART6_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART6_TX) /*!< Remap USART6 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART7_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART7_TX) /*!< Remap USART7 Tx on DMA2 channel 4 */ +#define HAL_DMA2_CH4_USART8_TX (uint32_t) (DMA2_CHANNEL4_RMP | DMA2_CSELR_CH4_USART8_TX) /*!< Remap USART8 Tx on DMA2 channel 4 */ +/* DMA2 - Channel 5 */ +#define HAL_DMA2_CH5_DEFAULT (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_DEFAULT) /*!< Default remap position for DMA2 */ +#define HAL_DMA2_CH5_ADC (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_ADC) /*!< Remap ADC on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART1_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART1_TX) /*!< Remap USART1 Tx on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART2_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART2_TX) /*!< Remap USART2 Tx on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART3_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART3_TX) /*!< Remap USART3 Tx on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART4_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART4_TX) /*!< Remap USART4 Tx on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART5_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART5_TX) /*!< Remap USART5 Tx on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART6_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART6_TX) /*!< Remap USART6 Tx on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART7_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART7_TX) /*!< Remap USART7 Tx on DMA2 channel 5 */ +#define HAL_DMA2_CH5_USART8_TX (uint32_t) (DMA2_CHANNEL5_RMP | DMA2_CSELR_CH5_USART8_TX) /*!< Remap USART8 Tx on DMA2 channel 5 */ +#endif /* !defined(STM32F030xC) */ + +#if defined(STM32F091xC) || defined(STM32F098xx) +#define IS_HAL_DMA1_REMAP(REQUEST) (((REQUEST) == HAL_DMA1_CH1_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH1_ADC) ||\ + ((REQUEST) == HAL_DMA1_CH1_TIM17_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH1_TIM17_UP) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART3_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART4_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART5_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART6_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART7_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART8_RX) ||\ + ((REQUEST) == HAL_DMA1_CH2_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH2_ADC) ||\ + ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_SPI1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH2_TIM1_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_TIM17_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH2_TIM17_UP) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART3_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART4_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART5_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART6_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART7_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART8_TX) ||\ + ((REQUEST) == HAL_DMA1_CH3_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM6_UP) ||\ + ((REQUEST) == HAL_DMA1_CH3_DAC_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH3_I2C1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_SPI1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM1_CH2) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM2_CH2) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM16_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM16_UP) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART3_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART4_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART5_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART6_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART7_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART8_RX) ||\ + ((REQUEST) == HAL_DMA1_CH4_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM7_UP) ||\ + ((REQUEST) == HAL_DMA1_CH4_DAC_CH2) ||\ + ((REQUEST) == HAL_DMA1_CH4_I2C2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_SPI2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM2_CH4) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM3_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM3_TRIG) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM16_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM16_UP) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART3_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART4_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART5_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART6_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART7_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART8_TX) ||\ + ((REQUEST) == HAL_DMA1_CH5_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH5_I2C2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_SPI2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH5_TIM1_CH3) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART3_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART4_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART5_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART6_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART7_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART8_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH6_I2C1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH6_SPI2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_TIM1_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH6_TIM1_CH2) ||\ + ((REQUEST) == HAL_DMA1_CH6_TIM1_CH3) ||\ + ((REQUEST) == HAL_DMA1_CH6_TIM3_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH6_TIM3_TRIG) ||\ + ((REQUEST) == HAL_DMA1_CH6_TIM16_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH6_TIM16_UP) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART3_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART4_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART5_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART6_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART7_RX) ||\ + ((REQUEST) == HAL_DMA1_CH6_USART8_RX) ||\ + ((REQUEST) == HAL_DMA1_CH7_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH7_I2C1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH7_SPI2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_TIM2_CH2) ||\ + ((REQUEST) == HAL_DMA1_CH7_TIM2_CH4) ||\ + ((REQUEST) == HAL_DMA1_CH7_TIM17_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH7_TIM17_UP) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART3_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART4_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART5_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART6_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART7_TX) ||\ + ((REQUEST) == HAL_DMA1_CH7_USART8_TX)) + +#define IS_HAL_DMA2_REMAP(REQUEST) (((REQUEST) == HAL_DMA2_CH1_DEFAULT) ||\ + ((REQUEST) == HAL_DMA2_CH1_I2C2_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART1_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART2_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART3_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART4_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART5_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART6_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART7_TX) ||\ + ((REQUEST) == HAL_DMA2_CH1_USART8_TX) ||\ + ((REQUEST) == HAL_DMA2_CH2_DEFAULT) ||\ + ((REQUEST) == HAL_DMA2_CH2_I2C2_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART1_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART2_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART3_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART4_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART5_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART6_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART7_RX) ||\ + ((REQUEST) == HAL_DMA2_CH2_USART8_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_DEFAULT) ||\ + ((REQUEST) == HAL_DMA2_CH3_TIM6_UP) ||\ + ((REQUEST) == HAL_DMA2_CH3_DAC_CH1) ||\ + ((REQUEST) == HAL_DMA2_CH3_SPI1_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART1_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART2_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART3_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART4_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART5_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART6_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART7_RX) ||\ + ((REQUEST) == HAL_DMA2_CH3_USART8_RX) ||\ + ((REQUEST) == HAL_DMA2_CH4_DEFAULT) ||\ + ((REQUEST) == HAL_DMA2_CH4_TIM7_UP) ||\ + ((REQUEST) == HAL_DMA2_CH4_DAC_CH2) ||\ + ((REQUEST) == HAL_DMA2_CH4_SPI1_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART1_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART2_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART3_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART4_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART5_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART6_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART7_TX) ||\ + ((REQUEST) == HAL_DMA2_CH4_USART8_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_DEFAULT) ||\ + ((REQUEST) == HAL_DMA2_CH5_ADC) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART1_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART2_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART3_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART4_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART5_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART6_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART7_TX) ||\ + ((REQUEST) == HAL_DMA2_CH5_USART8_TX )) +#endif /* STM32F091xC || STM32F098xx */ + +#if defined(STM32F030xC) +#define IS_HAL_DMA1_REMAP(REQUEST) (((REQUEST) == HAL_DMA1_CH1_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH1_ADC) ||\ + ((REQUEST) == HAL_DMA1_CH1_TIM17_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH1_TIM17_UP) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART3_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART4_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART5_RX) ||\ + ((REQUEST) == HAL_DMA1_CH1_USART6_RX) ||\ + ((REQUEST) == HAL_DMA1_CH2_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH2_ADC) ||\ + ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_SPI1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH2_TIM1_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH2_I2C1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_TIM17_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH2_TIM17_UP) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART3_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART4_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART5_TX) ||\ + ((REQUEST) == HAL_DMA1_CH2_USART6_TX) ||\ + ((REQUEST) == HAL_DMA1_CH3_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM6_UP) ||\ + ((REQUEST) == HAL_DMA1_CH3_I2C1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_SPI1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM1_CH2) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM16_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH3_TIM16_UP) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART3_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART4_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART5_RX) ||\ + ((REQUEST) == HAL_DMA1_CH3_USART6_RX) ||\ + ((REQUEST) == HAL_DMA1_CH4_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM7_UP) ||\ + ((REQUEST) == HAL_DMA1_CH4_I2C2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_SPI2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM3_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM3_TRIG) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM16_CH1) ||\ + ((REQUEST) == HAL_DMA1_CH4_TIM16_UP) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART1_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART3_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART4_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART5_TX) ||\ + ((REQUEST) == HAL_DMA1_CH4_USART6_TX) ||\ + ((REQUEST) == HAL_DMA1_CH5_DEFAULT) ||\ + ((REQUEST) == HAL_DMA1_CH5_I2C2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_SPI2_TX) ||\ + ((REQUEST) == HAL_DMA1_CH5_TIM1_CH3) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART1_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART2_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART3_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART4_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART5_RX) ||\ + ((REQUEST) == HAL_DMA1_CH5_USART6_RX)) +#endif /* STM32F030xC */ + +/** + * @} + */ +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + +/* Exported macros -----------------------------------------------------------*/ + +/** @defgroup DMAEx_Exported_Macros DMAEx Exported Macros + * @{ + */ +/* Interrupt & Flag management */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) +/** + * @brief Returns the current DMA Channel transfer complete flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer complete flag index. + */ +#define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TC5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TC6 :\ + DMA_FLAG_TC7) + +/** + * @brief Returns the current DMA Channel half transfer complete flag. + * @param __HANDLE__ DMA handle + * @retval The specified half transfer complete flag index. + */ +#define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_HT5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_HT6 :\ + DMA_FLAG_HT7) + +/** + * @brief Returns the current DMA Channel transfer error flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer error flag index. + */ +#define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TE5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TE6 :\ + DMA_FLAG_TE7) + +/** + * @brief Return the current DMA Channel Global interrupt flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer error flag index. + */ +#define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_GL5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_GL6 :\ + DMA_FLAG_GL7) + +/** + * @brief Get the DMA Channel pending flags. + * @param __HANDLE__ DMA handle + * @param __FLAG__ Get the specified flag. + * This parameter can be any combination of the following values: + * @arg DMA_FLAG_TCx: Transfer complete flag + * @arg DMA_FLAG_HTx: Half transfer complete flag + * @arg DMA_FLAG_TEx: Transfer error flag + * Where x can be 1_7 to select the DMA Channel flag. + * @retval The state of FLAG (SET or RESET). + */ + +#define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__) (DMA1->ISR & (__FLAG__)) + +/** + * @brief Clears the DMA Channel pending flags. + * @param __HANDLE__ DMA handle + * @param __FLAG__ specifies the flag to clear. + * This parameter can be any combination of the following values: + * @arg DMA_FLAG_TCx: Transfer complete flag + * @arg DMA_FLAG_HTx: Half transfer complete flag + * @arg DMA_FLAG_TEx: Transfer error flag + * Where x can be 1_7 to select the DMA Channel flag. + * @retval None + */ +#define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) (DMA1->IFCR = (__FLAG__)) + +#elif defined(STM32F091xC) || defined(STM32F098xx) +/** + * @brief Returns the current DMA Channel transfer complete flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer complete flag index. + */ +#define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TC5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TC6 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_TC7 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_TC1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_TC2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_TC3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_TC4 :\ + DMA_FLAG_TC5) + +/** + * @brief Returns the current DMA Channel half transfer complete flag. + * @param __HANDLE__ DMA handle + * @retval The specified half transfer complete flag index. + */ +#define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_HT5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_HT6 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_HT7 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_HT1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_HT2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_HT3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_HT4 :\ + DMA_FLAG_HT5) + +/** + * @brief Returns the current DMA Channel transfer error flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer error flag index. + */ +#define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_TE5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_TE6 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_TE7 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_TE1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_TE2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_TE3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_TE4 :\ + DMA_FLAG_TE5) + +/** + * @brief Return the current DMA Channel Global interrupt flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer error flag index. + */ +#define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel5))? DMA_FLAG_GL5 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel6))? DMA_FLAG_GL6 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel7))? DMA_FLAG_GL7 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel1))? DMA_FLAG_GL1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel2))? DMA_FLAG_GL2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel3))? DMA_FLAG_GL3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA2_Channel4))? DMA_FLAG_GL4 :\ + DMA_FLAG_GL5) + +/** + * @brief Get the DMA Channel pending flags. + * @param __HANDLE__ DMA handle + * @param __FLAG__ Get the specified flag. + * This parameter can be any combination of the following values: + * @arg DMA_FLAG_TCx: Transfer complete flag + * @arg DMA_FLAG_HTx: Half transfer complete flag + * @arg DMA_FLAG_TEx: Transfer error flag + * Where x can be 0_4, 1_5, 2_6 or 3_7 to select the DMA Channel flag. + * @retval The state of FLAG (SET or RESET). + */ + +#define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__)\ +(((uint32_t)((__HANDLE__)->Instance) > (uint32_t)DMA1_Channel7)? (DMA2->ISR & (__FLAG__)) :\ + (DMA1->ISR & (__FLAG__))) + +/** + * @brief Clears the DMA Channel pending flags. + * @param __HANDLE__ DMA handle + * @param __FLAG__ specifies the flag to clear. + * This parameter can be any combination of the following values: + * @arg DMA_FLAG_TCx: Transfer complete flag + * @arg DMA_FLAG_HTx: Half transfer complete flag + * @arg DMA_FLAG_TEx: Transfer error flag + * Where x can be 0_4, 1_5, 2_6 or 3_7 to select the DMA Channel flag. + * @retval None + */ +#define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) \ +(((uint32_t)((__HANDLE__)->Instance) > (uint32_t)DMA1_Channel7)? (DMA2->IFCR = (__FLAG__)) :\ + (DMA1->IFCR = (__FLAG__))) + +#else /* STM32F030x8_STM32F030xC_STM32F031x6_STM32F038xx_STM32F051x8_STM32F058xx_STM32F070x6_STM32F070xB Product devices */ +/** + * @brief Returns the current DMA Channel transfer complete flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer complete flag index. + */ +#define __HAL_DMA_GET_TC_FLAG_INDEX(__HANDLE__) \ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TC1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TC2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TC3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TC4 :\ + DMA_FLAG_TC5) + +/** + * @brief Returns the current DMA Channel half transfer complete flag. + * @param __HANDLE__ DMA handle + * @retval The specified half transfer complete flag index. + */ +#define __HAL_DMA_GET_HT_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_HT1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_HT2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_HT3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_HT4 :\ + DMA_FLAG_HT5) + +/** + * @brief Returns the current DMA Channel transfer error flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer error flag index. + */ +#define __HAL_DMA_GET_TE_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_TE1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_TE2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_TE3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_TE4 :\ + DMA_FLAG_TE5) + +/** + * @brief Return the current DMA Channel Global interrupt flag. + * @param __HANDLE__ DMA handle + * @retval The specified transfer error flag index. + */ +#define __HAL_DMA_GET_GI_FLAG_INDEX(__HANDLE__)\ +(((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel1))? DMA_FLAG_GL1 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel2))? DMA_FLAG_GL2 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel3))? DMA_FLAG_GL3 :\ + ((uint32_t)((__HANDLE__)->Instance) == ((uint32_t)DMA1_Channel4))? DMA_FLAG_GL4 :\ + DMA_FLAG_GL5) + +/** + * @brief Get the DMA Channel pending flags. + * @param __HANDLE__ DMA handle + * @param __FLAG__ Get the specified flag. + * This parameter can be any combination of the following values: + * @arg DMA_FLAG_TCx: Transfer complete flag + * @arg DMA_FLAG_HTx: Half transfer complete flag + * @arg DMA_FLAG_TEx: Transfer error flag + * Where x can be 1_5 to select the DMA Channel flag. + * @retval The state of FLAG (SET or RESET). + */ + +#define __HAL_DMA_GET_FLAG(__HANDLE__, __FLAG__) (DMA1->ISR & (__FLAG__)) + +/** + * @brief Clears the DMA Channel pending flags. + * @param __HANDLE__ DMA handle + * @param __FLAG__ specifies the flag to clear. + * This parameter can be any combination of the following values: + * @arg DMA_FLAG_TCx: Transfer complete flag + * @arg DMA_FLAG_HTx: Half transfer complete flag + * @arg DMA_FLAG_TEx: Transfer error flag + * Where x can be 1_5 to select the DMA Channel flag. + * @retval None + */ +#define __HAL_DMA_CLEAR_FLAG(__HANDLE__, __FLAG__) (DMA1->IFCR = (__FLAG__)) + +#endif + + +#if defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) +#define __HAL_DMA1_REMAP(__REQUEST__) \ + do { assert_param(IS_HAL_DMA1_REMAP(__REQUEST__)); \ + DMA1->CSELR &= ~(0x0FU << (uint32_t)(((__REQUEST__) >> 28U) * 4U)); \ + DMA1->CSELR |= (uint32_t)((__REQUEST__) & 0x0FFFFFFFU); \ + }while(0) + +#if defined(STM32F091xC) || defined(STM32F098xx) +#define __HAL_DMA2_REMAP(__REQUEST__) \ + do { assert_param(IS_HAL_DMA2_REMAP(__REQUEST__)); \ + DMA2->CSELR &= ~(0x0FU << (uint32_t)(((__REQUEST__) >> 28U) * 4U)); \ + DMA2->CSELR |= (uint32_t)((__REQUEST__) & 0x0FFFFFFFU); \ + }while(0) +#endif /* STM32F091xC || STM32F098xx */ + +#endif /* STM32F091xC || STM32F098xx || STM32F030xC */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_DMA_EX_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_exti.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_exti.h new file mode 100644 index 0000000..7dc4823 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_exti.h @@ -0,0 +1,375 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_exti.h + * @author MCD Application Team + * @brief Header file of EXTI HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2019 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef STM32F0xx_HAL_EXTI_H +#define STM32F0xx_HAL_EXTI_H + +#ifdef __cplusplus +extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @defgroup EXTI EXTI + * @brief EXTI HAL module driver + * @{ + */ + +/* Exported types ------------------------------------------------------------*/ + +/** @defgroup EXTI_Exported_Types EXTI Exported Types + * @{ + */ + +/** + * @brief HAL EXTI common Callback ID enumeration definition + */ +typedef enum +{ + HAL_EXTI_COMMON_CB_ID = 0x00U +} EXTI_CallbackIDTypeDef; + +/** + * @brief EXTI Handle structure definition + */ +typedef struct +{ + uint32_t Line; /*!< Exti line number */ + void (* PendingCallback)(void); /*!< Exti pending callback */ +} EXTI_HandleTypeDef; + +/** + * @brief EXTI Configuration structure definition + */ +typedef struct +{ + uint32_t Line; /*!< The Exti line to be configured. This parameter + can be a value of @ref EXTI_Line */ + uint32_t Mode; /*!< The Exit Mode to be configured for a core. + This parameter can be a combination of @ref EXTI_Mode */ + uint32_t Trigger; /*!< The Exti Trigger to be configured. This parameter + can be a value of @ref EXTI_Trigger */ + uint32_t GPIOSel; /*!< The Exti GPIO multiplexer selection to be configured. + This parameter is only possible for line 0 to 15. It + can be a value of @ref EXTI_GPIOSel */ +} EXTI_ConfigTypeDef; + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup EXTI_Exported_Constants EXTI Exported Constants + * @{ + */ + +/** @defgroup EXTI_Line EXTI Line + * @{ + */ +#define EXTI_LINE_0 (EXTI_GPIO | 0x00u) /*!< External interrupt line 0 */ +#define EXTI_LINE_1 (EXTI_GPIO | 0x01u) /*!< External interrupt line 1 */ +#define EXTI_LINE_2 (EXTI_GPIO | 0x02u) /*!< External interrupt line 2 */ +#define EXTI_LINE_3 (EXTI_GPIO | 0x03u) /*!< External interrupt line 3 */ +#define EXTI_LINE_4 (EXTI_GPIO | 0x04u) /*!< External interrupt line 4 */ +#define EXTI_LINE_5 (EXTI_GPIO | 0x05u) /*!< External interrupt line 5 */ +#define EXTI_LINE_6 (EXTI_GPIO | 0x06u) /*!< External interrupt line 6 */ +#define EXTI_LINE_7 (EXTI_GPIO | 0x07u) /*!< External interrupt line 7 */ +#define EXTI_LINE_8 (EXTI_GPIO | 0x08u) /*!< External interrupt line 8 */ +#define EXTI_LINE_9 (EXTI_GPIO | 0x09u) /*!< External interrupt line 9 */ +#define EXTI_LINE_10 (EXTI_GPIO | 0x0Au) /*!< External interrupt line 10 */ +#define EXTI_LINE_11 (EXTI_GPIO | 0x0Bu) /*!< External interrupt line 11 */ +#define EXTI_LINE_12 (EXTI_GPIO | 0x0Cu) /*!< External interrupt line 12 */ +#define EXTI_LINE_13 (EXTI_GPIO | 0x0Du) /*!< External interrupt line 13 */ +#define EXTI_LINE_14 (EXTI_GPIO | 0x0Eu) /*!< External interrupt line 14 */ +#define EXTI_LINE_15 (EXTI_GPIO | 0x0Fu) /*!< External interrupt line 15 */ + +#if defined (EXTI_IMR_MR16) +#define EXTI_LINE_16 (EXTI_CONFIG | 0x10u) /*!< External interrupt line 16 Connected to the PVD Output */ +#else +#define EXTI_LINE_16 (EXTI_RESERVED | 0x10u) +#endif /* EXTI_IMR_MR16 */ + +#define EXTI_LINE_17 (EXTI_CONFIG | 0x11u) /*!< External interrupt line 17 Connected to the RTC Alarm event */ + +#if defined (EXTI_IMR_MR18) +#define EXTI_LINE_18 (EXTI_CONFIG | 0x12u) /*!< External interrupt line 18 Connected to the USB OTG FS Wakeup from suspend event */ +#else +#define EXTI_LINE_18 (EXTI_RESERVED | 0x12u) +#endif /* EXTI_IMR_MR18 */ + +#define EXTI_LINE_19 (EXTI_CONFIG | 0x13u) /*!< External interrupt line 19 Connected to the Ethernet Wakeup event */ + +#if defined (EXTI_IMR_MR20) +#define EXTI_LINE_20 (EXTI_CONFIG | 0x14u) /*!< External interrupt line 20 Connected to the USB OTG HS (configured in FS) Wakeup event */ +#else +#define EXTI_LINE_20 (EXTI_RESERVED | 0x14u) +#endif /* EXTI_IMR_MR20 */ + +#if defined (EXTI_IMR_MR21) +#define EXTI_LINE_21 (EXTI_CONFIG | 0x15u) /*!< External interrupt line 21 Connected to the Comparator 1 output */ +#else +#define EXTI_LINE_21 (EXTI_RESERVED | 0x15u) +#endif /* EXTI_IMR_MR21 */ + +#if defined (EXTI_IMR_MR22) +#define EXTI_LINE_22 (EXTI_CONFIG | 0x16u) /*!< External interrupt line 22 Connected to the Comparator 2 output */ +#else +#define EXTI_LINE_22 (EXTI_RESERVED | 0x16u) +#endif /* EXTI_IMR_MR22 */ + +#if defined (EXTI_IMR_MR23) +#define EXTI_LINE_23 (EXTI_DIRECT | 0x17u) /*!< External interrupt line 23 Connected to the internal I2C1 wakeup event */ +#else +#define EXTI_LINE_23 (EXTI_RESERVED | 0x17u) +#endif /* EXTI_IMR_MR23 */ + +#define EXTI_LINE_24 (EXTI_RESERVED | 0x18u) + +#if defined (EXTI_IMR_MR25) +#define EXTI_LINE_25 (EXTI_CONFIG | 0x19u) /*!< External interrupt line 25 Connected to the internal USART1 wakeup event */ +#else +#define EXTI_LINE_25 (EXTI_RESERVED | 0x19u) +#endif /* EXTI_IMR_MR25 */ + +#if defined (EXTI_IMR_MR26) +#define EXTI_LINE_26 (EXTI_CONFIG | 0x1Au) /*!< External interrupt line 26 Connected to the internal USART2 wakeup event */ +#else +#define EXTI_LINE_26 (EXTI_RESERVED | 0x1Au) +#endif /* EXTI_IMR_MR26 */ + +#if defined (EXTI_IMR_MR27) +#define EXTI_LINE_27 (EXTI_CONFIG | 0x1Bu) /*!< External interrupt line 27 Connected to the internal CEC wakeup event */ +#else +#define EXTI_LINE_27 (EXTI_RESERVED | 0x1Bu) +#endif /* EXTI_IMR_MR27 */ + +#if defined (EXTI_IMR_MR28) +#define EXTI_LINE_28 (EXTI_CONFIG | 0x1Cu) /*!< External interrupt line 28 Connected to the internal USART3 wakeup event */ +#else +#define EXTI_LINE_28 (EXTI_RESERVED | 0x1Cu) +#endif /* EXTI_IMR_MR28 */ + +#define EXTI_LINE_29 (EXTI_RESERVED | 0x1Du) +#define EXTI_LINE_30 (EXTI_RESERVED | 0x1Eu) + +#if defined (EXTI_IMR_MR31) +#define EXTI_LINE_31 (EXTI_CONFIG | 0x1Fu) /*!< External interrupt line 31 Connected to the VDDIO2 supply comparator output */ +#else +#define EXTI_LINE_31 (EXTI_RESERVED | 0x1Fu) +#endif /* EXTI_IMR_MR31 */ + +/** + * @} + */ + +/** @defgroup EXTI_Mode EXTI Mode + * @{ + */ +#define EXTI_MODE_NONE 0x00000000u +#define EXTI_MODE_INTERRUPT 0x00000001u +#define EXTI_MODE_EVENT 0x00000002u +/** + * @} + */ + +/** @defgroup EXTI_Trigger EXTI Trigger + * @{ + */ +#define EXTI_TRIGGER_NONE 0x00000000u +#define EXTI_TRIGGER_RISING 0x00000001u +#define EXTI_TRIGGER_FALLING 0x00000002u +#define EXTI_TRIGGER_RISING_FALLING (EXTI_TRIGGER_RISING | EXTI_TRIGGER_FALLING) +/** + * @} + */ + +/** @defgroup EXTI_GPIOSel EXTI GPIOSel + * @brief + * @{ + */ +#define EXTI_GPIOA 0x00000000u +#define EXTI_GPIOB 0x00000001u +#define EXTI_GPIOC 0x00000002u +#if defined (GPIOD) +#define EXTI_GPIOD 0x00000003u +#endif /* GPIOD */ +#if defined (GPIOE) +#define EXTI_GPIOE 0x00000004u +#endif /* GPIOE */ +#define EXTI_GPIOF 0x00000005u +/** + * @} + */ + +/** + * @} + */ + +/* Exported macro ------------------------------------------------------------*/ +/** @defgroup EXTI_Exported_Macros EXTI Exported Macros + * @{ + */ + +/** + * @} + */ + +/* Private constants --------------------------------------------------------*/ +/** @defgroup EXTI_Private_Constants EXTI Private Constants + * @{ + */ +/** + * @brief EXTI Line property definition + */ +#define EXTI_PROPERTY_SHIFT 24u +#define EXTI_DIRECT (0x01uL << EXTI_PROPERTY_SHIFT) +#define EXTI_CONFIG (0x02uL << EXTI_PROPERTY_SHIFT) +#define EXTI_GPIO ((0x04uL << EXTI_PROPERTY_SHIFT) | EXTI_CONFIG) +#define EXTI_RESERVED (0x08uL << EXTI_PROPERTY_SHIFT) +#define EXTI_PROPERTY_MASK (EXTI_DIRECT | EXTI_CONFIG | EXTI_GPIO) + +/** + * @brief EXTI bit usage + */ +#define EXTI_PIN_MASK 0x0000001Fu + +/** + * @brief EXTI Mask for interrupt & event mode + */ +#define EXTI_MODE_MASK (EXTI_MODE_EVENT | EXTI_MODE_INTERRUPT) + +/** + * @brief EXTI Mask for trigger possibilities + */ +#define EXTI_TRIGGER_MASK (EXTI_TRIGGER_RISING | EXTI_TRIGGER_FALLING) + +/** + * @brief EXTI Line number + */ +#define EXTI_LINE_NB 32uL + +/** + * @} + */ + +/* Private macros ------------------------------------------------------------*/ +/** @defgroup EXTI_Private_Macros EXTI Private Macros + * @{ + */ +#define IS_EXTI_LINE(__EXTI_LINE__) ((((__EXTI_LINE__) & ~(EXTI_PROPERTY_MASK | EXTI_PIN_MASK)) == 0x00u) && \ + ((((__EXTI_LINE__) & EXTI_PROPERTY_MASK) == EXTI_DIRECT) || \ + (((__EXTI_LINE__) & EXTI_PROPERTY_MASK) == EXTI_CONFIG) || \ + (((__EXTI_LINE__) & EXTI_PROPERTY_MASK) == EXTI_GPIO)) && \ + (((__EXTI_LINE__) & EXTI_PIN_MASK) < EXTI_LINE_NB)) + +#define IS_EXTI_MODE(__EXTI_LINE__) ((((__EXTI_LINE__) & EXTI_MODE_MASK) != 0x00u) && \ + (((__EXTI_LINE__) & ~EXTI_MODE_MASK) == 0x00u)) + +#define IS_EXTI_TRIGGER(__EXTI_LINE__) (((__EXTI_LINE__) & ~EXTI_TRIGGER_MASK) == 0x00u) + +#define IS_EXTI_PENDING_EDGE(__EXTI_LINE__) ((__EXTI_LINE__) == EXTI_TRIGGER_RISING_FALLING) + +#define IS_EXTI_CONFIG_LINE(__EXTI_LINE__) (((__EXTI_LINE__) & EXTI_CONFIG) != 0x00u) + +#if defined (GPIOE) +#define IS_EXTI_GPIO_PORT(__PORT__) (((__PORT__) == EXTI_GPIOA) || \ + ((__PORT__) == EXTI_GPIOB) || \ + ((__PORT__) == EXTI_GPIOC) || \ + ((__PORT__) == EXTI_GPIOD) || \ + ((__PORT__) == EXTI_GPIOE) || \ + ((__PORT__) == EXTI_GPIOF)) +#elif defined (GPIOD) +#define IS_EXTI_GPIO_PORT(__PORT__) (((__PORT__) == EXTI_GPIOA) || \ + ((__PORT__) == EXTI_GPIOB) || \ + ((__PORT__) == EXTI_GPIOC) || \ + ((__PORT__) == EXTI_GPIOD) || \ + ((__PORT__) == EXTI_GPIOF)) +#else +#define IS_EXTI_GPIO_PORT(__PORT__) (((__PORT__) == EXTI_GPIOA) || \ + ((__PORT__) == EXTI_GPIOB) || \ + ((__PORT__) == EXTI_GPIOC) || \ + ((__PORT__) == EXTI_GPIOF)) +#endif /* GPIOE */ + +#define IS_EXTI_GPIO_PIN(__PIN__) ((__PIN__) < 16u) + +/** + * @} + */ + + +/* Exported functions --------------------------------------------------------*/ +/** @defgroup EXTI_Exported_Functions EXTI Exported Functions + * @brief EXTI Exported Functions + * @{ + */ + +/** @defgroup EXTI_Exported_Functions_Group1 Configuration functions + * @brief Configuration functions + * @{ + */ +/* Configuration functions ****************************************************/ +HAL_StatusTypeDef HAL_EXTI_SetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigTypeDef *pExtiConfig); +HAL_StatusTypeDef HAL_EXTI_GetConfigLine(EXTI_HandleTypeDef *hexti, EXTI_ConfigTypeDef *pExtiConfig); +HAL_StatusTypeDef HAL_EXTI_ClearConfigLine(EXTI_HandleTypeDef *hexti); +HAL_StatusTypeDef HAL_EXTI_RegisterCallback(EXTI_HandleTypeDef *hexti, EXTI_CallbackIDTypeDef CallbackID, void (*pPendingCbfn)(void)); +HAL_StatusTypeDef HAL_EXTI_GetHandle(EXTI_HandleTypeDef *hexti, uint32_t ExtiLine); +/** + * @} + */ + +/** @defgroup EXTI_Exported_Functions_Group2 IO operation functions + * @brief IO operation functions + * @{ + */ +/* IO operation functions *****************************************************/ +void HAL_EXTI_IRQHandler(EXTI_HandleTypeDef *hexti); +uint32_t HAL_EXTI_GetPending(EXTI_HandleTypeDef *hexti, uint32_t Edge); +void HAL_EXTI_ClearPending(EXTI_HandleTypeDef *hexti, uint32_t Edge); +void HAL_EXTI_GenerateSWI(EXTI_HandleTypeDef *hexti); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* STM32F0xx_HAL_EXTI_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash.h new file mode 100644 index 0000000..ecce5da --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash.h @@ -0,0 +1,353 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_flash.h + * @author MCD Application Team + * @brief Header file of Flash HAL module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_FLASH_H +#define __STM32F0xx_HAL_FLASH_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup FLASH + * @{ + */ + +/** @addtogroup FLASH_Private_Constants + * @{ + */ +#define FLASH_TIMEOUT_VALUE (50000U) /* 50 s */ +/** + * @} + */ + +/** @addtogroup FLASH_Private_Macros + * @{ + */ + +#define IS_FLASH_TYPEPROGRAM(VALUE) (((VALUE) == FLASH_TYPEPROGRAM_HALFWORD) || \ + ((VALUE) == FLASH_TYPEPROGRAM_WORD) || \ + ((VALUE) == FLASH_TYPEPROGRAM_DOUBLEWORD)) + +#define IS_FLASH_LATENCY(__LATENCY__) (((__LATENCY__) == FLASH_LATENCY_0) || \ + ((__LATENCY__) == FLASH_LATENCY_1)) + +/** + * @} + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup FLASH_Exported_Types FLASH Exported Types + * @{ + */ + +/** + * @brief FLASH Procedure structure definition + */ +typedef enum +{ + FLASH_PROC_NONE = 0U, + FLASH_PROC_PAGEERASE = 1U, + FLASH_PROC_MASSERASE = 2U, + FLASH_PROC_PROGRAMHALFWORD = 3U, + FLASH_PROC_PROGRAMWORD = 4U, + FLASH_PROC_PROGRAMDOUBLEWORD = 5U +} FLASH_ProcedureTypeDef; + +/** + * @brief FLASH handle Structure definition + */ +typedef struct +{ + __IO FLASH_ProcedureTypeDef ProcedureOnGoing; /*!< Internal variable to indicate which procedure is ongoing or not in IT context */ + + __IO uint32_t DataRemaining; /*!< Internal variable to save the remaining pages to erase or half-word to program in IT context */ + + __IO uint32_t Address; /*!< Internal variable to save address selected for program or erase */ + + __IO uint64_t Data; /*!< Internal variable to save data to be programmed */ + + HAL_LockTypeDef Lock; /*!< FLASH locking object */ + + __IO uint32_t ErrorCode; /*!< FLASH error code + This parameter can be a value of @ref FLASH_Error_Codes */ +} FLASH_ProcessTypeDef; + +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup FLASH_Exported_Constants FLASH Exported Constants + * @{ + */ + +/** @defgroup FLASH_Error_Codes FLASH Error Codes + * @{ + */ + +#define HAL_FLASH_ERROR_NONE 0x00U /*!< No error */ +#define HAL_FLASH_ERROR_PROG 0x01U /*!< Programming error */ +#define HAL_FLASH_ERROR_WRP 0x02U /*!< Write protection error */ + +/** + * @} + */ + +/** @defgroup FLASH_Type_Program FLASH Type Program + * @{ + */ +#define FLASH_TYPEPROGRAM_HALFWORD (0x01U) /*!ACR = (FLASH->ACR&(~FLASH_ACR_LATENCY)) | (__LATENCY__)) + + +/** + * @brief Get the FLASH Latency. + * @retval FLASH Latency + * The value of this parameter depend on device used within the same series + */ +#define __HAL_FLASH_GET_LATENCY() (READ_BIT((FLASH->ACR), FLASH_ACR_LATENCY)) + +/** + * @} + */ + +/** @defgroup FLASH_Prefetch FLASH Prefetch + * @brief macros to handle FLASH Prefetch buffer + * @{ + */ +/** + * @brief Enable the FLASH prefetch buffer. + * @retval None + */ +#define __HAL_FLASH_PREFETCH_BUFFER_ENABLE() (FLASH->ACR |= FLASH_ACR_PRFTBE) + +/** + * @brief Disable the FLASH prefetch buffer. + * @retval None + */ +#define __HAL_FLASH_PREFETCH_BUFFER_DISABLE() (FLASH->ACR &= (~FLASH_ACR_PRFTBE)) + +/** + * @} + */ + +/** @defgroup FLASH_Interrupt FLASH Interrupts + * @brief macros to handle FLASH interrupts + * @{ + */ + +/** + * @brief Enable the specified FLASH interrupt. + * @param __INTERRUPT__ FLASH interrupt + * This parameter can be any combination of the following values: + * @arg @ref FLASH_IT_EOP End of FLASH Operation Interrupt + * @arg @ref FLASH_IT_ERR Error Interrupt + * @retval none + */ +#define __HAL_FLASH_ENABLE_IT(__INTERRUPT__) SET_BIT((FLASH->CR), (__INTERRUPT__)) + +/** + * @brief Disable the specified FLASH interrupt. + * @param __INTERRUPT__ FLASH interrupt + * This parameter can be any combination of the following values: + * @arg @ref FLASH_IT_EOP End of FLASH Operation Interrupt + * @arg @ref FLASH_IT_ERR Error Interrupt + * @retval none + */ +#define __HAL_FLASH_DISABLE_IT(__INTERRUPT__) CLEAR_BIT((FLASH->CR), (uint32_t)(__INTERRUPT__)) + +/** + * @brief Get the specified FLASH flag status. + * @param __FLAG__ specifies the FLASH flag to check. + * This parameter can be one of the following values: + * @arg @ref FLASH_FLAG_BSY FLASH Busy flag + * @arg @ref FLASH_FLAG_EOP FLASH End of Operation flag + * @arg @ref FLASH_FLAG_WRPERR FLASH Write protected error flag + * @arg @ref FLASH_FLAG_PGERR FLASH Programming error flag + * @retval The new state of __FLAG__ (SET or RESET). + */ +#define __HAL_FLASH_GET_FLAG(__FLAG__) (((FLASH->SR) & (__FLAG__)) == (__FLAG__)) + +/** + * @brief Clear the specified FLASH flag. + * @param __FLAG__ specifies the FLASH flags to clear. + * This parameter can be any combination of the following values: + * @arg @ref FLASH_FLAG_EOP FLASH End of Operation flag + * @arg @ref FLASH_FLAG_WRPERR FLASH Write protected error flag + * @arg @ref FLASH_FLAG_PGERR FLASH Programming error flag + * @retval none + */ +#define __HAL_FLASH_CLEAR_FLAG(__FLAG__) ((FLASH->SR) = (__FLAG__)) + +/** + * @} + */ + +/** + * @} + */ + +/* Include FLASH HAL Extended module */ +#include "stm32f0xx_hal_flash_ex.h" + +/* Exported functions --------------------------------------------------------*/ +/** @addtogroup FLASH_Exported_Functions + * @{ + */ + +/** @addtogroup FLASH_Exported_Functions_Group1 + * @{ + */ +/* IO operation functions *****************************************************/ +HAL_StatusTypeDef HAL_FLASH_Program(uint32_t TypeProgram, uint32_t Address, uint64_t Data); +HAL_StatusTypeDef HAL_FLASH_Program_IT(uint32_t TypeProgram, uint32_t Address, uint64_t Data); + +/* FLASH IRQ handler function */ +void HAL_FLASH_IRQHandler(void); +/* Callbacks in non blocking modes */ +void HAL_FLASH_EndOfOperationCallback(uint32_t ReturnValue); +void HAL_FLASH_OperationErrorCallback(uint32_t ReturnValue); + +/** + * @} + */ + +/** @addtogroup FLASH_Exported_Functions_Group2 + * @{ + */ +/* Peripheral Control functions ***********************************************/ +HAL_StatusTypeDef HAL_FLASH_Unlock(void); +HAL_StatusTypeDef HAL_FLASH_Lock(void); +HAL_StatusTypeDef HAL_FLASH_OB_Unlock(void); +HAL_StatusTypeDef HAL_FLASH_OB_Lock(void); +HAL_StatusTypeDef HAL_FLASH_OB_Launch(void); + +/** + * @} + */ + +/** @addtogroup FLASH_Exported_Functions_Group3 + * @{ + */ +/* Peripheral State and Error functions ***************************************/ +uint32_t HAL_FLASH_GetError(void); + +/** + * @} + */ + +/** + * @} + */ + +/* Private function -------------------------------------------------*/ +/** @addtogroup FLASH_Private_Functions + * @{ + */ +HAL_StatusTypeDef FLASH_WaitForLastOperation(uint32_t Timeout); + +/** + * @} + */ + +/** + * @} + */ + +/** + * @} + */ + +#ifdef __cplusplus +} +#endif + +#endif /* __STM32F0xx_HAL_FLASH_H */ + +/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ + diff --git a/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash_ex.h b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash_ex.h new file mode 100644 index 0000000..a4c79d8 --- /dev/null +++ b/Chapter04/bare/platform/STM32F0xx_HAL_Driver/Inc/stm32f0xx_hal_flash_ex.h @@ -0,0 +1,448 @@ +/** + ****************************************************************************** + * @file stm32f0xx_hal_flash_ex.h + * @author MCD Application Team + * @brief Header file of Flash HAL Extended module. + ****************************************************************************** + * @attention + * + *

    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    + * + * This software component is licensed by ST under BSD 3-Clause license, + * the "License"; You may not use this file except in compliance with the + * License. You may obtain a copy of the License at: + * opensource.org/licenses/BSD-3-Clause + * + ****************************************************************************** + */ + +/* Define to prevent recursive inclusion -------------------------------------*/ +#ifndef __STM32F0xx_HAL_FLASH_EX_H +#define __STM32F0xx_HAL_FLASH_EX_H + +#ifdef __cplusplus + extern "C" { +#endif + +/* Includes ------------------------------------------------------------------*/ +#include "stm32f0xx_hal_def.h" + +/** @addtogroup STM32F0xx_HAL_Driver + * @{ + */ + +/** @addtogroup FLASHEx + * @{ + */ + +/** @addtogroup FLASHEx_Private_Macros + * @{ + */ +#define IS_FLASH_TYPEERASE(VALUE) (((VALUE) == FLASH_TYPEERASE_PAGES) || \ + ((VALUE) == FLASH_TYPEERASE_MASSERASE)) + +#define IS_OPTIONBYTE(VALUE) ((VALUE) <= (OPTIONBYTE_WRP | OPTIONBYTE_RDP | OPTIONBYTE_USER | OPTIONBYTE_DATA)) + +#define IS_WRPSTATE(VALUE) (((VALUE) == OB_WRPSTATE_DISABLE) || \ + ((VALUE) == OB_WRPSTATE_ENABLE)) + +#define IS_OB_DATA_ADDRESS(ADDRESS) (((ADDRESS) == OB_DATA_ADDRESS_DATA0) || ((ADDRESS) == OB_DATA_ADDRESS_DATA1)) + +#define IS_OB_RDP_LEVEL(LEVEL) (((LEVEL) == OB_RDP_LEVEL_0) ||\ + ((LEVEL) == OB_RDP_LEVEL_1))/*||\ + ((LEVEL) == OB_RDP_LEVEL_2))*/ + +#define IS_OB_IWDG_SOURCE(SOURCE) (((SOURCE) == OB_IWDG_SW) || ((SOURCE) == OB_IWDG_HW)) + +#define IS_OB_STOP_SOURCE(SOURCE) (((SOURCE) == OB_STOP_NO_RST) || ((SOURCE) == OB_STOP_RST)) + +#define IS_OB_STDBY_SOURCE(SOURCE) (((SOURCE) == OB_STDBY_NO_RST) || ((SOURCE) == OB_STDBY_RST)) + +#define IS_OB_BOOT1(BOOT1) (((BOOT1) == OB_BOOT1_RESET) || ((BOOT1) == OB_BOOT1_SET)) + +#define IS_OB_VDDA_ANALOG(ANALOG) (((ANALOG) == OB_VDDA_ANALOG_ON) || ((ANALOG) == OB_VDDA_ANALOG_OFF)) + +#define IS_OB_SRAM_PARITY(PARITY) (((PARITY) == OB_SRAM_PARITY_SET) || ((PARITY) == OB_SRAM_PARITY_RESET)) + +#if defined(FLASH_OBR_BOOT_SEL) +#define IS_OB_BOOT_SEL(BOOT_SEL) (((BOOT_SEL) == OB_BOOT_SEL_RESET) || ((BOOT_SEL) == OB_BOOT_SEL_SET)) +#define IS_OB_BOOT0(BOOT0) (((BOOT0) == OB_BOOT0_RESET) || ((BOOT0) == OB_BOOT0_SET)) +#endif /* FLASH_OBR_BOOT_SEL */ + + +#define IS_OB_WRP(PAGE) (((PAGE) != 0x0000000U)) + +#define IS_FLASH_NB_PAGES(ADDRESS,NBPAGES) ((ADDRESS)+((NBPAGES)*FLASH_PAGE_SIZE)-1 <= FLASH_BANK1_END) + +#define IS_FLASH_PROGRAM_ADDRESS(ADDRESS) (((ADDRESS) >= FLASH_BASE) && ((ADDRESS) <= FLASH_BANK1_END)) + +/** + * @} + */ + +/* Exported types ------------------------------------------------------------*/ +/** @defgroup FLASHEx_Exported_Types FLASHEx Exported Types + * @{ + */ +/** + * @brief FLASH Erase structure definition + */ +typedef struct +{ + uint32_t TypeErase; /*!< TypeErase: Mass erase or page erase. + This parameter can be a value of @ref FLASHEx_Type_Erase */ + + uint32_t PageAddress; /*!< PageAdress: Initial FLASH page address to erase when mass erase is disabled + This parameter must be a number between Min_Data = FLASH_BASE and Max_Data = FLASH_BANK1_END */ + + uint32_t NbPages; /*!< NbPages: Number of pagess to be erased. + This parameter must be a value between Min_Data = 1 and Max_Data = (max number of pages - value of initial page)*/ + +} FLASH_EraseInitTypeDef; + +/** + * @brief FLASH Options bytes program structure definition + */ +typedef struct +{ + uint32_t OptionType; /*!< OptionType: Option byte to be configured. + This parameter can be a value of @ref FLASHEx_OB_Type */ + + uint32_t WRPState; /*!< WRPState: Write protection activation or deactivation. + This parameter can be a value of @ref FLASHEx_OB_WRP_State */ + + uint32_t WRPPage; /*!< WRPPage: specifies the page(s) to be write protected + This parameter can be a value of @ref FLASHEx_OB_Write_Protection */ + + uint8_t RDPLevel; /*!< RDPLevel: Set the read protection level.. + This parameter can be a value of @ref FLASHEx_OB_Read_Protection */ + + uint8_t USERConfig; /*!< USERConfig: Program the FLASH User Option Byte: + IWDG / STOP / STDBY / BOOT1 / VDDA_ANALOG / SRAM_PARITY + This parameter can be a combination of @ref FLASHEx_OB_IWatchdog, @ref FLASHEx_OB_nRST_STOP, + @ref FLASHEx_OB_nRST_STDBY, @ref FLASHEx_OB_BOOT1, @ref FLASHEx_OB_VDDA_Analog_Monitoring and + @ref FLASHEx_OB_RAM_Parity_Check_Enable */ + + uint32_t DATAAddress; /*!< DATAAddress: Address of the option byte DATA to be programmed + This parameter can be a value of @ref FLASHEx_OB_Data_Address */ + + uint8_t DATAData; /*!< DATAData: Data to be stored in the option byte DATA + This parameter must be a number between Min_Data = 0x00 and Max_Data = 0xFF */ +} FLASH_OBProgramInitTypeDef; +/** + * @} + */ + +/* Exported constants --------------------------------------------------------*/ +/** @defgroup FLASHEx_Exported_Constants FLASHEx Exported Constants + * @{ + */ + +/** @defgroup FLASHEx_Page_Size FLASHEx Page Size + * @{ + */ +#if defined(STM32F030x6) || defined(STM32F030x8) || defined(STM32F031x6) || defined(STM32F038xx) \ + || defined(STM32F051x8) || defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F058xx) || defined(STM32F070x6) +#define FLASH_PAGE_SIZE 0x400U +#endif /* STM32F030x6 || STM32F030x8 || STM32F031x6 || STM32F051x8 || STM32F042x6 || STM32F048xx || STM32F058xx || STM32F070x6 */ + +#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) \ + || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC) +#define FLASH_PAGE_SIZE 0x800U +#endif /* STM32F071xB || STM32F072xB || STM32F078xx || STM32F091xC || STM32F098xx || STM32F030xC */ +/** + * @} + */ + +/** @defgroup FLASHEx_Type_Erase FLASH Type Erase + * @{ + */ +#define FLASH_TYPEERASE_PAGES (0x00U) /*!
    © Copyright (c) 2016 STMicroelectronics. + * All rights reserved.

    =s9bQ?g@KEb_W3XNT~4*kqxf-I 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 GL|o- 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

    GI}iVpUe5l%*Z%#+{dsoy-}Ih%_;00fexGxz*n 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 *!@s8Cec?av$yxsMgUY9=CYtk2Z75Wmd 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